diff --git a/actions/plan/dist/.gitignore b/actions/plan/dist/.gitignore new file mode 100644 index 00000000..70e0bd1e --- /dev/null +++ b/actions/plan/dist/.gitignore @@ -0,0 +1,3 @@ +* +!index.js +!exec-child.js diff --git a/actions/plan/dist/index.js b/actions/plan/dist/index.js index 37400a64..c8b32fb0 100644 --- a/actions/plan/dist/index.js +++ b/actions/plan/dist/index.js @@ -1,7 +1,7 @@ /******/ (() => { // webpackBootstrap /******/ var __webpack_modules__ = ({ -/***/ 7513: +/***/ 11071: /***/ (function(__unused_webpack_module, exports, __nccwpck_require__) { "use strict"; @@ -28,7 +28,7 @@ var __importStar = (this && this.__importStar) || function (mod) { Object.defineProperty(exports, "__esModule", ({ value: true })); exports.issue = exports.issueCommand = void 0; const os = __importStar(__nccwpck_require__(22037)); -const utils_1 = __nccwpck_require__(77401); +const utils_1 = __nccwpck_require__(46023); /** * Commands * @@ -100,7 +100,7 @@ function escapeProperty(s) { /***/ }), -/***/ 57896: +/***/ 44712: /***/ (function(__unused_webpack_module, exports, __nccwpck_require__) { "use strict"; @@ -135,12 +135,12 @@ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, ge }; Object.defineProperty(exports, "__esModule", ({ value: true })); exports.getIDToken = exports.getState = exports.saveState = exports.group = exports.endGroup = exports.startGroup = exports.info = exports.notice = exports.warning = exports.error = exports.debug = exports.isDebug = exports.setFailed = exports.setCommandEcho = exports.setOutput = exports.getBooleanInput = exports.getMultilineInput = exports.getInput = exports.addPath = exports.setSecret = exports.exportVariable = exports.ExitCode = void 0; -const command_1 = __nccwpck_require__(7513); -const file_command_1 = __nccwpck_require__(36802); -const utils_1 = __nccwpck_require__(77401); +const command_1 = __nccwpck_require__(11071); +const file_command_1 = __nccwpck_require__(99034); +const utils_1 = __nccwpck_require__(46023); const os = __importStar(__nccwpck_require__(22037)); const path = __importStar(__nccwpck_require__(71017)); -const oidc_utils_1 = __nccwpck_require__(64852); +const oidc_utils_1 = __nccwpck_require__(6963); /** * The code to exit an action */ @@ -425,17 +425,17 @@ exports.getIDToken = getIDToken; /** * Summary exports */ -var summary_1 = __nccwpck_require__(67259); +var summary_1 = __nccwpck_require__(29140); Object.defineProperty(exports, "summary", ({ enumerable: true, get: function () { return summary_1.summary; } })); /** * @deprecated use core.summary */ -var summary_2 = __nccwpck_require__(67259); +var summary_2 = __nccwpck_require__(29140); Object.defineProperty(exports, "markdownSummary", ({ enumerable: true, get: function () { return summary_2.markdownSummary; } })); /** * Path exports */ -var path_utils_1 = __nccwpck_require__(29442); +var path_utils_1 = __nccwpck_require__(54531); Object.defineProperty(exports, "toPosixPath", ({ enumerable: true, get: function () { return path_utils_1.toPosixPath; } })); Object.defineProperty(exports, "toWin32Path", ({ enumerable: true, get: function () { return path_utils_1.toWin32Path; } })); Object.defineProperty(exports, "toPlatformPath", ({ enumerable: true, get: function () { return path_utils_1.toPlatformPath; } })); @@ -443,7 +443,7 @@ Object.defineProperty(exports, "toPlatformPath", ({ enumerable: true, get: funct /***/ }), -/***/ 36802: +/***/ 99034: /***/ (function(__unused_webpack_module, exports, __nccwpck_require__) { "use strict"; @@ -474,8 +474,8 @@ exports.prepareKeyValueMessage = exports.issueFileCommand = void 0; /* eslint-disable @typescript-eslint/no-explicit-any */ const fs = __importStar(__nccwpck_require__(57147)); const os = __importStar(__nccwpck_require__(22037)); -const uuid_1 = __nccwpck_require__(10580); -const utils_1 = __nccwpck_require__(77401); +const uuid_1 = __nccwpck_require__(37515); +const utils_1 = __nccwpck_require__(46023); function issueFileCommand(command, message) { const filePath = process.env[`GITHUB_${command}`]; if (!filePath) { @@ -508,7 +508,7 @@ exports.prepareKeyValueMessage = prepareKeyValueMessage; /***/ }), -/***/ 64852: +/***/ 6963: /***/ (function(__unused_webpack_module, exports, __nccwpck_require__) { "use strict"; @@ -524,9 +524,9 @@ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, ge }; Object.defineProperty(exports, "__esModule", ({ value: true })); exports.OidcClient = void 0; -const http_client_1 = __nccwpck_require__(57281); -const auth_1 = __nccwpck_require__(62669); -const core_1 = __nccwpck_require__(57896); +const http_client_1 = __nccwpck_require__(18158); +const auth_1 = __nccwpck_require__(42601); +const core_1 = __nccwpck_require__(44712); class OidcClient { static createHttpClient(allowRetry = true, maxRetry = 10) { const requestOptions = { @@ -558,7 +558,7 @@ class OidcClient { .catch(error => { throw new Error(`Failed to get ID Token. \n Error Code : ${error.statusCode}\n - Error Message: ${error.result.message}`); + Error Message: ${error.message}`); }); const id_token = (_a = res.result) === null || _a === void 0 ? void 0 : _a.value; if (!id_token) { @@ -592,7 +592,7 @@ exports.OidcClient = OidcClient; /***/ }), -/***/ 29442: +/***/ 54531: /***/ (function(__unused_webpack_module, exports, __nccwpck_require__) { "use strict"; @@ -657,7 +657,7 @@ exports.toPlatformPath = toPlatformPath; /***/ }), -/***/ 67259: +/***/ 29140: /***/ (function(__unused_webpack_module, exports, __nccwpck_require__) { "use strict"; @@ -947,7 +947,7 @@ exports.summary = _summary; /***/ }), -/***/ 77401: +/***/ 46023: /***/ ((__unused_webpack_module, exports) => { "use strict"; @@ -994,7 +994,7 @@ exports.toCommandProperties = toCommandProperties; /***/ }), -/***/ 62669: +/***/ 42601: /***/ (function(__unused_webpack_module, exports) { "use strict"; @@ -1082,7 +1082,7 @@ exports.PersonalAccessTokenCredentialHandler = PersonalAccessTokenCredentialHand /***/ }), -/***/ 57281: +/***/ 18158: /***/ (function(__unused_webpack_module, exports, __nccwpck_require__) { "use strict"; @@ -1120,8 +1120,8 @@ Object.defineProperty(exports, "__esModule", ({ value: true })); exports.HttpClient = exports.isHttps = exports.HttpClientResponse = exports.HttpClientError = exports.getProxyUrl = exports.MediaTypes = exports.Headers = exports.HttpCodes = void 0; const http = __importStar(__nccwpck_require__(13685)); const https = __importStar(__nccwpck_require__(95687)); -const pm = __importStar(__nccwpck_require__(32871)); -const tunnel = __importStar(__nccwpck_require__(57383)); +const pm = __importStar(__nccwpck_require__(34321)); +const tunnel = __importStar(__nccwpck_require__(2932)); var HttpCodes; (function (HttpCodes) { HttpCodes[HttpCodes["OK"] = 200] = "OK"; @@ -1694,7 +1694,7 @@ const lowercaseKeys = (obj) => Object.keys(obj).reduce((c, k) => ((c[k.toLowerCa /***/ }), -/***/ 32871: +/***/ 34321: /***/ ((__unused_webpack_module, exports) => { "use strict"; @@ -1777,267 +1777,11 @@ function isLoopbackAddress(host) { /***/ }), -/***/ 97127: -/***/ (function(module) { - -(function (global, factory) { - true ? module.exports = factory() : - 0; -})(this, (function () { 'use strict'; - - // Matches the scheme of a URL, eg "http://" - const schemeRegex = /^[\w+.-]+:\/\//; - /** - * Matches the parts of a URL: - * 1. Scheme, including ":", guaranteed. - * 2. User/password, including "@", optional. - * 3. Host, guaranteed. - * 4. Port, including ":", optional. - * 5. Path, including "/", optional. - * 6. Query, including "?", optional. - * 7. Hash, including "#", optional. - */ - const urlRegex = /^([\w+.-]+:)\/\/([^@/#?]*@)?([^:/#?]*)(:\d+)?(\/[^#?]*)?(\?[^#]*)?(#.*)?/; - /** - * File URLs are weird. They dont' need the regular `//` in the scheme, they may or may not start - * with a leading `/`, they can have a domain (but only if they don't start with a Windows drive). - * - * 1. Host, optional. - * 2. Path, which may include "/", guaranteed. - * 3. Query, including "?", optional. - * 4. Hash, including "#", optional. - */ - const fileRegex = /^file:(?:\/\/((?![a-z]:)[^/#?]*)?)?(\/?[^#?]*)(\?[^#]*)?(#.*)?/i; - var UrlType; - (function (UrlType) { - UrlType[UrlType["Empty"] = 1] = "Empty"; - UrlType[UrlType["Hash"] = 2] = "Hash"; - UrlType[UrlType["Query"] = 3] = "Query"; - UrlType[UrlType["RelativePath"] = 4] = "RelativePath"; - UrlType[UrlType["AbsolutePath"] = 5] = "AbsolutePath"; - UrlType[UrlType["SchemeRelative"] = 6] = "SchemeRelative"; - UrlType[UrlType["Absolute"] = 7] = "Absolute"; - })(UrlType || (UrlType = {})); - function isAbsoluteUrl(input) { - return schemeRegex.test(input); - } - function isSchemeRelativeUrl(input) { - return input.startsWith('//'); - } - function isAbsolutePath(input) { - return input.startsWith('/'); - } - function isFileUrl(input) { - return input.startsWith('file:'); - } - function isRelative(input) { - return /^[.?#]/.test(input); - } - function parseAbsoluteUrl(input) { - const match = urlRegex.exec(input); - return makeUrl(match[1], match[2] || '', match[3], match[4] || '', match[5] || '/', match[6] || '', match[7] || ''); - } - function parseFileUrl(input) { - const match = fileRegex.exec(input); - const path = match[2]; - return makeUrl('file:', '', match[1] || '', '', isAbsolutePath(path) ? path : '/' + path, match[3] || '', match[4] || ''); - } - function makeUrl(scheme, user, host, port, path, query, hash) { - return { - scheme, - user, - host, - port, - path, - query, - hash, - type: UrlType.Absolute, - }; - } - function parseUrl(input) { - if (isSchemeRelativeUrl(input)) { - const url = parseAbsoluteUrl('http:' + input); - url.scheme = ''; - url.type = UrlType.SchemeRelative; - return url; - } - if (isAbsolutePath(input)) { - const url = parseAbsoluteUrl('http://foo.com' + input); - url.scheme = ''; - url.host = ''; - url.type = UrlType.AbsolutePath; - return url; - } - if (isFileUrl(input)) - return parseFileUrl(input); - if (isAbsoluteUrl(input)) - return parseAbsoluteUrl(input); - const url = parseAbsoluteUrl('http://foo.com/' + input); - url.scheme = ''; - url.host = ''; - url.type = input - ? input.startsWith('?') - ? UrlType.Query - : input.startsWith('#') - ? UrlType.Hash - : UrlType.RelativePath - : UrlType.Empty; - return url; - } - function stripPathFilename(path) { - // If a path ends with a parent directory "..", then it's a relative path with excess parent - // paths. It's not a file, so we can't strip it. - if (path.endsWith('/..')) - return path; - const index = path.lastIndexOf('/'); - return path.slice(0, index + 1); - } - function mergePaths(url, base) { - normalizePath(base, base.type); - // If the path is just a "/", then it was an empty path to begin with (remember, we're a relative - // path). - if (url.path === '/') { - url.path = base.path; - } - else { - // Resolution happens relative to the base path's directory, not the file. - url.path = stripPathFilename(base.path) + url.path; - } - } - /** - * The path can have empty directories "//", unneeded parents "foo/..", or current directory - * "foo/.". We need to normalize to a standard representation. - */ - function normalizePath(url, type) { - const rel = type <= UrlType.RelativePath; - const pieces = url.path.split('/'); - // We need to preserve the first piece always, so that we output a leading slash. The item at - // pieces[0] is an empty string. - let pointer = 1; - // Positive is the number of real directories we've output, used for popping a parent directory. - // Eg, "foo/bar/.." will have a positive 2, and we can decrement to be left with just "foo". - let positive = 0; - // We need to keep a trailing slash if we encounter an empty directory (eg, splitting "foo/" will - // generate `["foo", ""]` pieces). And, if we pop a parent directory. But once we encounter a - // real directory, we won't need to append, unless the other conditions happen again. - let addTrailingSlash = false; - for (let i = 1; i < pieces.length; i++) { - const piece = pieces[i]; - // An empty directory, could be a trailing slash, or just a double "//" in the path. - if (!piece) { - addTrailingSlash = true; - continue; - } - // If we encounter a real directory, then we don't need to append anymore. - addTrailingSlash = false; - // A current directory, which we can always drop. - if (piece === '.') - continue; - // A parent directory, we need to see if there are any real directories we can pop. Else, we - // have an excess of parents, and we'll need to keep the "..". - if (piece === '..') { - if (positive) { - addTrailingSlash = true; - positive--; - pointer--; - } - else if (rel) { - // If we're in a relativePath, then we need to keep the excess parents. Else, in an absolute - // URL, protocol relative URL, or an absolute path, we don't need to keep excess. - pieces[pointer++] = piece; - } - continue; - } - // We've encountered a real directory. Move it to the next insertion pointer, which accounts for - // any popped or dropped directories. - pieces[pointer++] = piece; - positive++; - } - let path = ''; - for (let i = 1; i < pointer; i++) { - path += '/' + pieces[i]; - } - if (!path || (addTrailingSlash && !path.endsWith('/..'))) { - path += '/'; - } - url.path = path; - } - /** - * Attempts to resolve `input` URL/path relative to `base`. - */ - function resolve(input, base) { - if (!input && !base) - return ''; - const url = parseUrl(input); - let inputType = url.type; - if (base && inputType !== UrlType.Absolute) { - const baseUrl = parseUrl(base); - const baseType = baseUrl.type; - switch (inputType) { - case UrlType.Empty: - url.hash = baseUrl.hash; - // fall through - case UrlType.Hash: - url.query = baseUrl.query; - // fall through - case UrlType.Query: - case UrlType.RelativePath: - mergePaths(url, baseUrl); - // fall through - case UrlType.AbsolutePath: - // The host, user, and port are joined, you can't copy one without the others. - url.user = baseUrl.user; - url.host = baseUrl.host; - url.port = baseUrl.port; - // fall through - case UrlType.SchemeRelative: - // The input doesn't have a schema at least, so we need to copy at least that over. - url.scheme = baseUrl.scheme; - } - if (baseType > inputType) - inputType = baseType; - } - normalizePath(url, inputType); - const queryHash = url.query + url.hash; - switch (inputType) { - // This is impossible, because of the empty checks at the start of the function. - // case UrlType.Empty: - case UrlType.Hash: - case UrlType.Query: - return queryHash; - case UrlType.RelativePath: { - // The first char is always a "/", and we need it to be relative. - const path = url.path.slice(1); - if (!path) - return queryHash || '.'; - if (isRelative(base || input) && !isRelative(path)) { - // If base started with a leading ".", or there is no base and input started with a ".", - // then we need to ensure that the relative path starts with a ".". We don't know if - // relative starts with a "..", though, so check before prepending. - return './' + path + queryHash; - } - return path + queryHash; - } - case UrlType.AbsolutePath: - return url.path + queryHash; - default: - return url.scheme + '//' + url.user + url.host + url.port + url.path + queryHash; - } - } - - return resolve; - -})); -//# sourceMappingURL=resolve-uri.umd.js.map - - -/***/ }), - -/***/ 66980: +/***/ 88686: /***/ (function(__unused_webpack_module, exports, __nccwpck_require__) { (function (global, factory) { - true ? factory(exports, __nccwpck_require__(8205), __nccwpck_require__(97127)) : + true ? factory(exports, __nccwpck_require__(22447), __nccwpck_require__(45192)) : 0; })(this, (function (exports, sourcemapCodec, resolveUri) { 'use strict'; @@ -2567,11 +2311,11 @@ function isLoopbackAddress(host) { /***/ }), -/***/ 62090: +/***/ 89254: /***/ ((module, exports, __nccwpck_require__) => { /* module decorator */ module = __nccwpck_require__.nmd(module); -const { TraceMap, originalPositionFor, AnyMap } = __nccwpck_require__(66980); +const { TraceMap, originalPositionFor, AnyMap } = __nccwpck_require__(88686); var path = __nccwpck_require__(71017); const { fileURLToPath, pathToFileURL } = __nccwpck_require__(57310); var util = __nccwpck_require__(73837); @@ -3513,7 +3257,263 @@ exports.resetRetrieveHandlers = function() { /***/ }), -/***/ 8205: +/***/ 45192: +/***/ (function(module) { + +(function (global, factory) { + true ? module.exports = factory() : + 0; +})(this, (function () { 'use strict'; + + // Matches the scheme of a URL, eg "http://" + const schemeRegex = /^[\w+.-]+:\/\//; + /** + * Matches the parts of a URL: + * 1. Scheme, including ":", guaranteed. + * 2. User/password, including "@", optional. + * 3. Host, guaranteed. + * 4. Port, including ":", optional. + * 5. Path, including "/", optional. + * 6. Query, including "?", optional. + * 7. Hash, including "#", optional. + */ + const urlRegex = /^([\w+.-]+:)\/\/([^@/#?]*@)?([^:/#?]*)(:\d+)?(\/[^#?]*)?(\?[^#]*)?(#.*)?/; + /** + * File URLs are weird. They dont' need the regular `//` in the scheme, they may or may not start + * with a leading `/`, they can have a domain (but only if they don't start with a Windows drive). + * + * 1. Host, optional. + * 2. Path, which may include "/", guaranteed. + * 3. Query, including "?", optional. + * 4. Hash, including "#", optional. + */ + const fileRegex = /^file:(?:\/\/((?![a-z]:)[^/#?]*)?)?(\/?[^#?]*)(\?[^#]*)?(#.*)?/i; + var UrlType; + (function (UrlType) { + UrlType[UrlType["Empty"] = 1] = "Empty"; + UrlType[UrlType["Hash"] = 2] = "Hash"; + UrlType[UrlType["Query"] = 3] = "Query"; + UrlType[UrlType["RelativePath"] = 4] = "RelativePath"; + UrlType[UrlType["AbsolutePath"] = 5] = "AbsolutePath"; + UrlType[UrlType["SchemeRelative"] = 6] = "SchemeRelative"; + UrlType[UrlType["Absolute"] = 7] = "Absolute"; + })(UrlType || (UrlType = {})); + function isAbsoluteUrl(input) { + return schemeRegex.test(input); + } + function isSchemeRelativeUrl(input) { + return input.startsWith('//'); + } + function isAbsolutePath(input) { + return input.startsWith('/'); + } + function isFileUrl(input) { + return input.startsWith('file:'); + } + function isRelative(input) { + return /^[.?#]/.test(input); + } + function parseAbsoluteUrl(input) { + const match = urlRegex.exec(input); + return makeUrl(match[1], match[2] || '', match[3], match[4] || '', match[5] || '/', match[6] || '', match[7] || ''); + } + function parseFileUrl(input) { + const match = fileRegex.exec(input); + const path = match[2]; + return makeUrl('file:', '', match[1] || '', '', isAbsolutePath(path) ? path : '/' + path, match[3] || '', match[4] || ''); + } + function makeUrl(scheme, user, host, port, path, query, hash) { + return { + scheme, + user, + host, + port, + path, + query, + hash, + type: UrlType.Absolute, + }; + } + function parseUrl(input) { + if (isSchemeRelativeUrl(input)) { + const url = parseAbsoluteUrl('http:' + input); + url.scheme = ''; + url.type = UrlType.SchemeRelative; + return url; + } + if (isAbsolutePath(input)) { + const url = parseAbsoluteUrl('http://foo.com' + input); + url.scheme = ''; + url.host = ''; + url.type = UrlType.AbsolutePath; + return url; + } + if (isFileUrl(input)) + return parseFileUrl(input); + if (isAbsoluteUrl(input)) + return parseAbsoluteUrl(input); + const url = parseAbsoluteUrl('http://foo.com/' + input); + url.scheme = ''; + url.host = ''; + url.type = input + ? input.startsWith('?') + ? UrlType.Query + : input.startsWith('#') + ? UrlType.Hash + : UrlType.RelativePath + : UrlType.Empty; + return url; + } + function stripPathFilename(path) { + // If a path ends with a parent directory "..", then it's a relative path with excess parent + // paths. It's not a file, so we can't strip it. + if (path.endsWith('/..')) + return path; + const index = path.lastIndexOf('/'); + return path.slice(0, index + 1); + } + function mergePaths(url, base) { + normalizePath(base, base.type); + // If the path is just a "/", then it was an empty path to begin with (remember, we're a relative + // path). + if (url.path === '/') { + url.path = base.path; + } + else { + // Resolution happens relative to the base path's directory, not the file. + url.path = stripPathFilename(base.path) + url.path; + } + } + /** + * The path can have empty directories "//", unneeded parents "foo/..", or current directory + * "foo/.". We need to normalize to a standard representation. + */ + function normalizePath(url, type) { + const rel = type <= UrlType.RelativePath; + const pieces = url.path.split('/'); + // We need to preserve the first piece always, so that we output a leading slash. The item at + // pieces[0] is an empty string. + let pointer = 1; + // Positive is the number of real directories we've output, used for popping a parent directory. + // Eg, "foo/bar/.." will have a positive 2, and we can decrement to be left with just "foo". + let positive = 0; + // We need to keep a trailing slash if we encounter an empty directory (eg, splitting "foo/" will + // generate `["foo", ""]` pieces). And, if we pop a parent directory. But once we encounter a + // real directory, we won't need to append, unless the other conditions happen again. + let addTrailingSlash = false; + for (let i = 1; i < pieces.length; i++) { + const piece = pieces[i]; + // An empty directory, could be a trailing slash, or just a double "//" in the path. + if (!piece) { + addTrailingSlash = true; + continue; + } + // If we encounter a real directory, then we don't need to append anymore. + addTrailingSlash = false; + // A current directory, which we can always drop. + if (piece === '.') + continue; + // A parent directory, we need to see if there are any real directories we can pop. Else, we + // have an excess of parents, and we'll need to keep the "..". + if (piece === '..') { + if (positive) { + addTrailingSlash = true; + positive--; + pointer--; + } + else if (rel) { + // If we're in a relativePath, then we need to keep the excess parents. Else, in an absolute + // URL, protocol relative URL, or an absolute path, we don't need to keep excess. + pieces[pointer++] = piece; + } + continue; + } + // We've encountered a real directory. Move it to the next insertion pointer, which accounts for + // any popped or dropped directories. + pieces[pointer++] = piece; + positive++; + } + let path = ''; + for (let i = 1; i < pointer; i++) { + path += '/' + pieces[i]; + } + if (!path || (addTrailingSlash && !path.endsWith('/..'))) { + path += '/'; + } + url.path = path; + } + /** + * Attempts to resolve `input` URL/path relative to `base`. + */ + function resolve(input, base) { + if (!input && !base) + return ''; + const url = parseUrl(input); + let inputType = url.type; + if (base && inputType !== UrlType.Absolute) { + const baseUrl = parseUrl(base); + const baseType = baseUrl.type; + switch (inputType) { + case UrlType.Empty: + url.hash = baseUrl.hash; + // fall through + case UrlType.Hash: + url.query = baseUrl.query; + // fall through + case UrlType.Query: + case UrlType.RelativePath: + mergePaths(url, baseUrl); + // fall through + case UrlType.AbsolutePath: + // The host, user, and port are joined, you can't copy one without the others. + url.user = baseUrl.user; + url.host = baseUrl.host; + url.port = baseUrl.port; + // fall through + case UrlType.SchemeRelative: + // The input doesn't have a schema at least, so we need to copy at least that over. + url.scheme = baseUrl.scheme; + } + if (baseType > inputType) + inputType = baseType; + } + normalizePath(url, inputType); + const queryHash = url.query + url.hash; + switch (inputType) { + // This is impossible, because of the empty checks at the start of the function. + // case UrlType.Empty: + case UrlType.Hash: + case UrlType.Query: + return queryHash; + case UrlType.RelativePath: { + // The first char is always a "/", and we need it to be relative. + const path = url.path.slice(1); + if (!path) + return queryHash || '.'; + if (isRelative(base || input) && !isRelative(path)) { + // If base started with a leading ".", or there is no base and input started with a ".", + // then we need to ensure that the relative path starts with a ".". We don't know if + // relative starts with a "..", though, so check before prepending. + return './' + path + queryHash; + } + return path + queryHash; + } + case UrlType.AbsolutePath: + return url.path + queryHash; + default: + return url.scheme + '//' + url.user + url.host + url.port + url.path + queryHash; + } + } + + return resolve; + +})); +//# sourceMappingURL=resolve-uri.umd.js.map + + +/***/ }), + +/***/ 22447: /***/ (function(__unused_webpack_module, exports) { (function (global, factory) { @@ -3694,945 +3694,27 @@ exports.resetRetrieveHandlers = function() { /***/ }), -/***/ 50183: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { - -"use strict"; - -Object.defineProperty(exports, "__esModule", ({ value: true })); -exports.createFileSystemAdapter = exports.FILE_SYSTEM_ADAPTER = void 0; -const fs = __nccwpck_require__(57147); -exports.FILE_SYSTEM_ADAPTER = { - lstat: fs.lstat, - stat: fs.stat, - lstatSync: fs.lstatSync, - statSync: fs.statSync, - readdir: fs.readdir, - readdirSync: fs.readdirSync -}; -function createFileSystemAdapter(fsMethods) { - if (fsMethods === undefined) { - return exports.FILE_SYSTEM_ADAPTER; - } - return Object.assign(Object.assign({}, exports.FILE_SYSTEM_ADAPTER), fsMethods); -} -exports.createFileSystemAdapter = createFileSystemAdapter; - - -/***/ }), - -/***/ 68809: -/***/ ((__unused_webpack_module, exports) => { - -"use strict"; - -Object.defineProperty(exports, "__esModule", ({ value: true })); -exports.IS_SUPPORT_READDIR_WITH_FILE_TYPES = void 0; -const NODE_PROCESS_VERSION_PARTS = process.versions.node.split('.'); -if (NODE_PROCESS_VERSION_PARTS[0] === undefined || NODE_PROCESS_VERSION_PARTS[1] === undefined) { - throw new Error(`Unexpected behavior. The 'process.versions.node' variable has invalid value: ${process.versions.node}`); -} -const MAJOR_VERSION = Number.parseInt(NODE_PROCESS_VERSION_PARTS[0], 10); -const MINOR_VERSION = Number.parseInt(NODE_PROCESS_VERSION_PARTS[1], 10); -const SUPPORTED_MAJOR_VERSION = 10; -const SUPPORTED_MINOR_VERSION = 10; -const IS_MATCHED_BY_MAJOR = MAJOR_VERSION > SUPPORTED_MAJOR_VERSION; -const IS_MATCHED_BY_MAJOR_AND_MINOR = MAJOR_VERSION === SUPPORTED_MAJOR_VERSION && MINOR_VERSION >= SUPPORTED_MINOR_VERSION; -/** - * IS `true` for Node.js 10.10 and greater. - */ -exports.IS_SUPPORT_READDIR_WITH_FILE_TYPES = IS_MATCHED_BY_MAJOR || IS_MATCHED_BY_MAJOR_AND_MINOR; - - -/***/ }), - -/***/ 56595: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { - -"use strict"; - -Object.defineProperty(exports, "__esModule", ({ value: true })); -exports.Settings = exports.scandirSync = exports.scandir = void 0; -const async = __nccwpck_require__(46975); -const sync = __nccwpck_require__(7805); -const settings_1 = __nccwpck_require__(59549); -exports.Settings = settings_1.default; -function scandir(path, optionsOrSettingsOrCallback, callback) { - if (typeof optionsOrSettingsOrCallback === 'function') { - async.read(path, getSettings(), optionsOrSettingsOrCallback); - return; - } - async.read(path, getSettings(optionsOrSettingsOrCallback), callback); -} -exports.scandir = scandir; -function scandirSync(path, optionsOrSettings) { - const settings = getSettings(optionsOrSettings); - return sync.read(path, settings); -} -exports.scandirSync = scandirSync; -function getSettings(settingsOrOptions = {}) { - if (settingsOrOptions instanceof settings_1.default) { - return settingsOrOptions; - } - return new settings_1.default(settingsOrOptions); -} - - -/***/ }), - -/***/ 46975: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { - -"use strict"; - -Object.defineProperty(exports, "__esModule", ({ value: true })); -exports.readdir = exports.readdirWithFileTypes = exports.read = void 0; -const fsStat = __nccwpck_require__(25925); -const rpl = __nccwpck_require__(87851); -const constants_1 = __nccwpck_require__(68809); -const utils = __nccwpck_require__(65973); -const common = __nccwpck_require__(83292); -function read(directory, settings, callback) { - if (!settings.stats && constants_1.IS_SUPPORT_READDIR_WITH_FILE_TYPES) { - readdirWithFileTypes(directory, settings, callback); - return; - } - readdir(directory, settings, callback); -} -exports.read = read; -function readdirWithFileTypes(directory, settings, callback) { - settings.fs.readdir(directory, { withFileTypes: true }, (readdirError, dirents) => { - if (readdirError !== null) { - callFailureCallback(callback, readdirError); - return; - } - const entries = dirents.map((dirent) => ({ - dirent, - name: dirent.name, - path: common.joinPathSegments(directory, dirent.name, settings.pathSegmentSeparator) - })); - if (!settings.followSymbolicLinks) { - callSuccessCallback(callback, entries); - return; - } - const tasks = entries.map((entry) => makeRplTaskEntry(entry, settings)); - rpl(tasks, (rplError, rplEntries) => { - if (rplError !== null) { - callFailureCallback(callback, rplError); - return; - } - callSuccessCallback(callback, rplEntries); - }); - }); -} -exports.readdirWithFileTypes = readdirWithFileTypes; -function makeRplTaskEntry(entry, settings) { - return (done) => { - if (!entry.dirent.isSymbolicLink()) { - done(null, entry); - return; - } - settings.fs.stat(entry.path, (statError, stats) => { - if (statError !== null) { - if (settings.throwErrorOnBrokenSymbolicLink) { - done(statError); - return; - } - done(null, entry); - return; - } - entry.dirent = utils.fs.createDirentFromStats(entry.name, stats); - done(null, entry); - }); - }; -} -function readdir(directory, settings, callback) { - settings.fs.readdir(directory, (readdirError, names) => { - if (readdirError !== null) { - callFailureCallback(callback, readdirError); - return; - } - const tasks = names.map((name) => { - const path = common.joinPathSegments(directory, name, settings.pathSegmentSeparator); - return (done) => { - fsStat.stat(path, settings.fsStatSettings, (error, stats) => { - if (error !== null) { - done(error); - return; - } - const entry = { - name, - path, - dirent: utils.fs.createDirentFromStats(name, stats) - }; - if (settings.stats) { - entry.stats = stats; - } - done(null, entry); - }); - }; - }); - rpl(tasks, (rplError, entries) => { - if (rplError !== null) { - callFailureCallback(callback, rplError); - return; - } - callSuccessCallback(callback, entries); - }); - }); -} -exports.readdir = readdir; -function callFailureCallback(callback, error) { - callback(error); -} -function callSuccessCallback(callback, result) { - callback(null, result); -} - - -/***/ }), - -/***/ 83292: -/***/ ((__unused_webpack_module, exports) => { - -"use strict"; - -Object.defineProperty(exports, "__esModule", ({ value: true })); -exports.joinPathSegments = void 0; -function joinPathSegments(a, b, separator) { - /** - * The correct handling of cases when the first segment is a root (`/`, `C:/`) or UNC path (`//?/C:/`). - */ - if (a.endsWith(separator)) { - return a + b; - } - return a + separator + b; -} -exports.joinPathSegments = joinPathSegments; - - -/***/ }), - -/***/ 7805: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { - -"use strict"; - -Object.defineProperty(exports, "__esModule", ({ value: true })); -exports.readdir = exports.readdirWithFileTypes = exports.read = void 0; -const fsStat = __nccwpck_require__(25925); -const constants_1 = __nccwpck_require__(68809); -const utils = __nccwpck_require__(65973); -const common = __nccwpck_require__(83292); -function read(directory, settings) { - if (!settings.stats && constants_1.IS_SUPPORT_READDIR_WITH_FILE_TYPES) { - return readdirWithFileTypes(directory, settings); - } - return readdir(directory, settings); -} -exports.read = read; -function readdirWithFileTypes(directory, settings) { - const dirents = settings.fs.readdirSync(directory, { withFileTypes: true }); - return dirents.map((dirent) => { - const entry = { - dirent, - name: dirent.name, - path: common.joinPathSegments(directory, dirent.name, settings.pathSegmentSeparator) - }; - if (entry.dirent.isSymbolicLink() && settings.followSymbolicLinks) { - try { - const stats = settings.fs.statSync(entry.path); - entry.dirent = utils.fs.createDirentFromStats(entry.name, stats); - } - catch (error) { - if (settings.throwErrorOnBrokenSymbolicLink) { - throw error; - } - } - } - return entry; - }); -} -exports.readdirWithFileTypes = readdirWithFileTypes; -function readdir(directory, settings) { - const names = settings.fs.readdirSync(directory); - return names.map((name) => { - const entryPath = common.joinPathSegments(directory, name, settings.pathSegmentSeparator); - const stats = fsStat.statSync(entryPath, settings.fsStatSettings); - const entry = { - name, - path: entryPath, - dirent: utils.fs.createDirentFromStats(name, stats) - }; - if (settings.stats) { - entry.stats = stats; - } - return entry; - }); -} -exports.readdir = readdir; - - -/***/ }), - -/***/ 59549: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { - -"use strict"; - -Object.defineProperty(exports, "__esModule", ({ value: true })); -const path = __nccwpck_require__(71017); -const fsStat = __nccwpck_require__(25925); -const fs = __nccwpck_require__(50183); -class Settings { - constructor(_options = {}) { - this._options = _options; - this.followSymbolicLinks = this._getValue(this._options.followSymbolicLinks, false); - this.fs = fs.createFileSystemAdapter(this._options.fs); - this.pathSegmentSeparator = this._getValue(this._options.pathSegmentSeparator, path.sep); - this.stats = this._getValue(this._options.stats, false); - this.throwErrorOnBrokenSymbolicLink = this._getValue(this._options.throwErrorOnBrokenSymbolicLink, true); - this.fsStatSettings = new fsStat.Settings({ - followSymbolicLink: this.followSymbolicLinks, - fs: this.fs, - throwErrorOnBrokenSymbolicLink: this.throwErrorOnBrokenSymbolicLink - }); - } - _getValue(option, value) { - return option !== null && option !== void 0 ? option : value; - } -} -exports["default"] = Settings; - - -/***/ }), - -/***/ 60421: -/***/ ((__unused_webpack_module, exports) => { - -"use strict"; - -Object.defineProperty(exports, "__esModule", ({ value: true })); -exports.createDirentFromStats = void 0; -class DirentFromStats { - constructor(name, stats) { - this.name = name; - this.isBlockDevice = stats.isBlockDevice.bind(stats); - this.isCharacterDevice = stats.isCharacterDevice.bind(stats); - this.isDirectory = stats.isDirectory.bind(stats); - this.isFIFO = stats.isFIFO.bind(stats); - this.isFile = stats.isFile.bind(stats); - this.isSocket = stats.isSocket.bind(stats); - this.isSymbolicLink = stats.isSymbolicLink.bind(stats); - } -} -function createDirentFromStats(name, stats) { - return new DirentFromStats(name, stats); -} -exports.createDirentFromStats = createDirentFromStats; - - -/***/ }), - -/***/ 65973: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { - -"use strict"; - -Object.defineProperty(exports, "__esModule", ({ value: true })); -exports.fs = void 0; -const fs = __nccwpck_require__(60421); -exports.fs = fs; - - -/***/ }), - -/***/ 91892: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { - -"use strict"; - -Object.defineProperty(exports, "__esModule", ({ value: true })); -exports.createFileSystemAdapter = exports.FILE_SYSTEM_ADAPTER = void 0; -const fs = __nccwpck_require__(57147); -exports.FILE_SYSTEM_ADAPTER = { - lstat: fs.lstat, - stat: fs.stat, - lstatSync: fs.lstatSync, - statSync: fs.statSync -}; -function createFileSystemAdapter(fsMethods) { - if (fsMethods === undefined) { - return exports.FILE_SYSTEM_ADAPTER; - } - return Object.assign(Object.assign({}, exports.FILE_SYSTEM_ADAPTER), fsMethods); -} -exports.createFileSystemAdapter = createFileSystemAdapter; - - -/***/ }), - -/***/ 25925: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { - -"use strict"; - -Object.defineProperty(exports, "__esModule", ({ value: true })); -exports.statSync = exports.stat = exports.Settings = void 0; -const async = __nccwpck_require__(97178); -const sync = __nccwpck_require__(79804); -const settings_1 = __nccwpck_require__(5237); -exports.Settings = settings_1.default; -function stat(path, optionsOrSettingsOrCallback, callback) { - if (typeof optionsOrSettingsOrCallback === 'function') { - async.read(path, getSettings(), optionsOrSettingsOrCallback); - return; - } - async.read(path, getSettings(optionsOrSettingsOrCallback), callback); -} -exports.stat = stat; -function statSync(path, optionsOrSettings) { - const settings = getSettings(optionsOrSettings); - return sync.read(path, settings); -} -exports.statSync = statSync; -function getSettings(settingsOrOptions = {}) { - if (settingsOrOptions instanceof settings_1.default) { - return settingsOrOptions; - } - return new settings_1.default(settingsOrOptions); -} - - -/***/ }), - -/***/ 97178: -/***/ ((__unused_webpack_module, exports) => { - -"use strict"; - -Object.defineProperty(exports, "__esModule", ({ value: true })); -exports.read = void 0; -function read(path, settings, callback) { - settings.fs.lstat(path, (lstatError, lstat) => { - if (lstatError !== null) { - callFailureCallback(callback, lstatError); - return; - } - if (!lstat.isSymbolicLink() || !settings.followSymbolicLink) { - callSuccessCallback(callback, lstat); - return; - } - settings.fs.stat(path, (statError, stat) => { - if (statError !== null) { - if (settings.throwErrorOnBrokenSymbolicLink) { - callFailureCallback(callback, statError); - return; - } - callSuccessCallback(callback, lstat); - return; - } - if (settings.markSymbolicLink) { - stat.isSymbolicLink = () => true; - } - callSuccessCallback(callback, stat); - }); - }); -} -exports.read = read; -function callFailureCallback(callback, error) { - callback(error); -} -function callSuccessCallback(callback, result) { - callback(null, result); -} - - -/***/ }), - -/***/ 79804: -/***/ ((__unused_webpack_module, exports) => { - -"use strict"; - -Object.defineProperty(exports, "__esModule", ({ value: true })); -exports.read = void 0; -function read(path, settings) { - const lstat = settings.fs.lstatSync(path); - if (!lstat.isSymbolicLink() || !settings.followSymbolicLink) { - return lstat; - } - try { - const stat = settings.fs.statSync(path); - if (settings.markSymbolicLink) { - stat.isSymbolicLink = () => true; - } - return stat; - } - catch (error) { - if (!settings.throwErrorOnBrokenSymbolicLink) { - return lstat; - } - throw error; - } -} -exports.read = read; - - -/***/ }), - -/***/ 5237: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { - -"use strict"; - -Object.defineProperty(exports, "__esModule", ({ value: true })); -const fs = __nccwpck_require__(91892); -class Settings { - constructor(_options = {}) { - this._options = _options; - this.followSymbolicLink = this._getValue(this._options.followSymbolicLink, true); - this.fs = fs.createFileSystemAdapter(this._options.fs); - this.markSymbolicLink = this._getValue(this._options.markSymbolicLink, false); - this.throwErrorOnBrokenSymbolicLink = this._getValue(this._options.throwErrorOnBrokenSymbolicLink, true); - } - _getValue(option, value) { - return option !== null && option !== void 0 ? option : value; - } -} -exports["default"] = Settings; - - -/***/ }), - -/***/ 99155: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { - -"use strict"; - -Object.defineProperty(exports, "__esModule", ({ value: true })); -exports.Settings = exports.walkStream = exports.walkSync = exports.walk = void 0; -const async_1 = __nccwpck_require__(40315); -const stream_1 = __nccwpck_require__(77809); -const sync_1 = __nccwpck_require__(45863); -const settings_1 = __nccwpck_require__(45854); -exports.Settings = settings_1.default; -function walk(directory, optionsOrSettingsOrCallback, callback) { - if (typeof optionsOrSettingsOrCallback === 'function') { - new async_1.default(directory, getSettings()).read(optionsOrSettingsOrCallback); - return; - } - new async_1.default(directory, getSettings(optionsOrSettingsOrCallback)).read(callback); -} -exports.walk = walk; -function walkSync(directory, optionsOrSettings) { - const settings = getSettings(optionsOrSettings); - const provider = new sync_1.default(directory, settings); - return provider.read(); -} -exports.walkSync = walkSync; -function walkStream(directory, optionsOrSettings) { - const settings = getSettings(optionsOrSettings); - const provider = new stream_1.default(directory, settings); - return provider.read(); -} -exports.walkStream = walkStream; -function getSettings(settingsOrOptions = {}) { - if (settingsOrOptions instanceof settings_1.default) { - return settingsOrOptions; - } - return new settings_1.default(settingsOrOptions); -} - - -/***/ }), - -/***/ 40315: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { - -"use strict"; - -Object.defineProperty(exports, "__esModule", ({ value: true })); -const async_1 = __nccwpck_require__(34615); -class AsyncProvider { - constructor(_root, _settings) { - this._root = _root; - this._settings = _settings; - this._reader = new async_1.default(this._root, this._settings); - this._storage = []; - } - read(callback) { - this._reader.onError((error) => { - callFailureCallback(callback, error); - }); - this._reader.onEntry((entry) => { - this._storage.push(entry); - }); - this._reader.onEnd(() => { - callSuccessCallback(callback, this._storage); - }); - this._reader.read(); - } -} -exports["default"] = AsyncProvider; -function callFailureCallback(callback, error) { - callback(error); -} -function callSuccessCallback(callback, entries) { - callback(null, entries); -} - - -/***/ }), - -/***/ 77809: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { - -"use strict"; - -Object.defineProperty(exports, "__esModule", ({ value: true })); -const stream_1 = __nccwpck_require__(12781); -const async_1 = __nccwpck_require__(34615); -class StreamProvider { - constructor(_root, _settings) { - this._root = _root; - this._settings = _settings; - this._reader = new async_1.default(this._root, this._settings); - this._stream = new stream_1.Readable({ - objectMode: true, - read: () => { }, - destroy: () => { - if (!this._reader.isDestroyed) { - this._reader.destroy(); - } - } - }); - } - read() { - this._reader.onError((error) => { - this._stream.emit('error', error); - }); - this._reader.onEntry((entry) => { - this._stream.push(entry); - }); - this._reader.onEnd(() => { - this._stream.push(null); - }); - this._reader.read(); - return this._stream; - } -} -exports["default"] = StreamProvider; - - -/***/ }), - -/***/ 45863: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { - -"use strict"; - -Object.defineProperty(exports, "__esModule", ({ value: true })); -const sync_1 = __nccwpck_require__(47751); -class SyncProvider { - constructor(_root, _settings) { - this._root = _root; - this._settings = _settings; - this._reader = new sync_1.default(this._root, this._settings); - } - read() { - return this._reader.read(); - } -} -exports["default"] = SyncProvider; - - -/***/ }), - -/***/ 34615: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { - -"use strict"; - -Object.defineProperty(exports, "__esModule", ({ value: true })); -const events_1 = __nccwpck_require__(82361); -const fsScandir = __nccwpck_require__(56595); -const fastq = __nccwpck_require__(32027); -const common = __nccwpck_require__(55892); -const reader_1 = __nccwpck_require__(80707); -class AsyncReader extends reader_1.default { - constructor(_root, _settings) { - super(_root, _settings); - this._settings = _settings; - this._scandir = fsScandir.scandir; - this._emitter = new events_1.EventEmitter(); - this._queue = fastq(this._worker.bind(this), this._settings.concurrency); - this._isFatalError = false; - this._isDestroyed = false; - this._queue.drain = () => { - if (!this._isFatalError) { - this._emitter.emit('end'); - } - }; - } - read() { - this._isFatalError = false; - this._isDestroyed = false; - setImmediate(() => { - this._pushToQueue(this._root, this._settings.basePath); - }); - return this._emitter; - } - get isDestroyed() { - return this._isDestroyed; - } - destroy() { - if (this._isDestroyed) { - throw new Error('The reader is already destroyed'); - } - this._isDestroyed = true; - this._queue.killAndDrain(); - } - onEntry(callback) { - this._emitter.on('entry', callback); - } - onError(callback) { - this._emitter.once('error', callback); - } - onEnd(callback) { - this._emitter.once('end', callback); - } - _pushToQueue(directory, base) { - const queueItem = { directory, base }; - this._queue.push(queueItem, (error) => { - if (error !== null) { - this._handleError(error); - } - }); - } - _worker(item, done) { - this._scandir(item.directory, this._settings.fsScandirSettings, (error, entries) => { - if (error !== null) { - done(error, undefined); - return; - } - for (const entry of entries) { - this._handleEntry(entry, item.base); - } - done(null, undefined); - }); - } - _handleError(error) { - if (this._isDestroyed || !common.isFatalError(this._settings, error)) { - return; - } - this._isFatalError = true; - this._isDestroyed = true; - this._emitter.emit('error', error); - } - _handleEntry(entry, base) { - if (this._isDestroyed || this._isFatalError) { - return; - } - const fullpath = entry.path; - if (base !== undefined) { - entry.path = common.joinPathSegments(base, entry.name, this._settings.pathSegmentSeparator); - } - if (common.isAppliedFilter(this._settings.entryFilter, entry)) { - this._emitEntry(entry); - } - if (entry.dirent.isDirectory() && common.isAppliedFilter(this._settings.deepFilter, entry)) { - this._pushToQueue(fullpath, base === undefined ? undefined : entry.path); - } - } - _emitEntry(entry) { - this._emitter.emit('entry', entry); - } -} -exports["default"] = AsyncReader; - - -/***/ }), - -/***/ 55892: -/***/ ((__unused_webpack_module, exports) => { - -"use strict"; - -Object.defineProperty(exports, "__esModule", ({ value: true })); -exports.joinPathSegments = exports.replacePathSegmentSeparator = exports.isAppliedFilter = exports.isFatalError = void 0; -function isFatalError(settings, error) { - if (settings.errorFilter === null) { - return true; - } - return !settings.errorFilter(error); -} -exports.isFatalError = isFatalError; -function isAppliedFilter(filter, value) { - return filter === null || filter(value); -} -exports.isAppliedFilter = isAppliedFilter; -function replacePathSegmentSeparator(filepath, separator) { - return filepath.split(/[/\\]/).join(separator); -} -exports.replacePathSegmentSeparator = replacePathSegmentSeparator; -function joinPathSegments(a, b, separator) { - if (a === '') { - return b; - } - /** - * The correct handling of cases when the first segment is a root (`/`, `C:/`) or UNC path (`//?/C:/`). - */ - if (a.endsWith(separator)) { - return a + b; - } - return a + separator + b; -} -exports.joinPathSegments = joinPathSegments; - - -/***/ }), - -/***/ 80707: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { - -"use strict"; - -Object.defineProperty(exports, "__esModule", ({ value: true })); -const common = __nccwpck_require__(55892); -class Reader { - constructor(_root, _settings) { - this._root = _root; - this._settings = _settings; - this._root = common.replacePathSegmentSeparator(_root, _settings.pathSegmentSeparator); - } -} -exports["default"] = Reader; - - -/***/ }), - -/***/ 47751: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { - -"use strict"; - -Object.defineProperty(exports, "__esModule", ({ value: true })); -const fsScandir = __nccwpck_require__(56595); -const common = __nccwpck_require__(55892); -const reader_1 = __nccwpck_require__(80707); -class SyncReader extends reader_1.default { - constructor() { - super(...arguments); - this._scandir = fsScandir.scandirSync; - this._storage = []; - this._queue = new Set(); - } - read() { - this._pushToQueue(this._root, this._settings.basePath); - this._handleQueue(); - return this._storage; - } - _pushToQueue(directory, base) { - this._queue.add({ directory, base }); - } - _handleQueue() { - for (const item of this._queue.values()) { - this._handleDirectory(item.directory, item.base); - } - } - _handleDirectory(directory, base) { - try { - const entries = this._scandir(directory, this._settings.fsScandirSettings); - for (const entry of entries) { - this._handleEntry(entry, base); - } - } - catch (error) { - this._handleError(error); - } - } - _handleError(error) { - if (!common.isFatalError(this._settings, error)) { - return; - } - throw error; - } - _handleEntry(entry, base) { - const fullpath = entry.path; - if (base !== undefined) { - entry.path = common.joinPathSegments(base, entry.name, this._settings.pathSegmentSeparator); - } - if (common.isAppliedFilter(this._settings.entryFilter, entry)) { - this._pushToStorage(entry); - } - if (entry.dirent.isDirectory() && common.isAppliedFilter(this._settings.deepFilter, entry)) { - this._pushToQueue(fullpath, base === undefined ? undefined : entry.path); - } - } - _pushToStorage(entry) { - this._storage.push(entry); - } -} -exports["default"] = SyncReader; - - -/***/ }), - -/***/ 45854: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { - -"use strict"; - -Object.defineProperty(exports, "__esModule", ({ value: true })); -const path = __nccwpck_require__(71017); -const fsScandir = __nccwpck_require__(56595); -class Settings { - constructor(_options = {}) { - this._options = _options; - this.basePath = this._getValue(this._options.basePath, undefined); - this.concurrency = this._getValue(this._options.concurrency, Number.POSITIVE_INFINITY); - this.deepFilter = this._getValue(this._options.deepFilter, null); - this.entryFilter = this._getValue(this._options.entryFilter, null); - this.errorFilter = this._getValue(this._options.errorFilter, null); - this.pathSegmentSeparator = this._getValue(this._options.pathSegmentSeparator, path.sep); - this.fsScandirSettings = new fsScandir.Settings({ - followSymbolicLinks: this._options.followSymbolicLinks, - fs: this._options.fs, - pathSegmentSeparator: this._options.pathSegmentSeparator, - stats: this._options.stats, - throwErrorOnBrokenSymbolicLink: this._options.throwErrorOnBrokenSymbolicLink - }); - } - _getValue(option, value) { - return option !== null && option !== void 0 ? option : value; - } -} -exports["default"] = Settings; - - -/***/ }), - -/***/ 10763: +/***/ 47885: /***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { "use strict"; Object.defineProperty(exports, "__esModule", ({ value: true })); exports.transform = exports.transformJest = exports.transformSync = void 0; -const core_1 = __nccwpck_require__(76237); +const core_1 = __nccwpck_require__(65142); // Oldest LTS Node.js supported target const DEFAULT_ES_TARGET = 'es2018'; function transformOption(path, options, jest = false) { - var _a, _b, _c, _d, _e; - const opts = options == null ? {} : options; + var _a, _b, _c, _d, _e, _f, _g; + const opts = options !== null && options !== void 0 ? options : {}; opts.esModuleInterop = (_a = opts.esModuleInterop) !== null && _a !== void 0 ? _a : true; + const moduleType = (_b = options === null || options === void 0 ? void 0 : options.module) !== null && _b !== void 0 ? _b : 'commonjs'; return { filename: path, - jsc: ((_b = options === null || options === void 0 ? void 0 : options.swc) === null || _b === void 0 ? void 0 : _b.swcrc) + jsc: ((_c = options === null || options === void 0 ? void 0 : options.swc) === null || _c === void 0 ? void 0 : _c.swcrc) ? undefined : { - target: (_c = opts.target) !== null && _c !== void 0 ? _c : DEFAULT_ES_TARGET, + target: (_d = opts.target) !== null && _d !== void 0 ? _d : DEFAULT_ES_TARGET, externalHelpers: jest ? true : Boolean(opts.externalHelpers), parser: { syntax: 'typescript', @@ -4643,6 +3725,7 @@ function transformOption(path, options, jest = false) { transform: { legacyDecorator: Boolean(opts.experimentalDecorators), decoratorMetadata: Boolean(opts.emitDecoratorMetadata), + useDefineForClassFields: Boolean(opts.useDefineForClassFields), react: options === null || options === void 0 ? void 0 : options.react, // @ts-expect-error hidden: { @@ -4651,17 +3734,29 @@ function transformOption(path, options, jest = false) { }, keepClassNames: opts.keepClassNames, paths: opts.paths, + baseUrl: opts.baseUrl, }, minify: false, isModule: true, - module: { - type: (_d = options === null || options === void 0 ? void 0 : options.module) !== null && _d !== void 0 ? _d : 'commonjs', - noInterop: !opts.esModuleInterop, - }, - sourceMaps: jest || typeof opts.sourcemap === 'undefined' ? 'inline' : opts.sourcemap, + module: ((_e = options === null || options === void 0 ? void 0 : options.swc) === null || _e === void 0 ? void 0 : _e.swcrc) + ? undefined + : { + type: moduleType, + ...(moduleType === 'commonjs' || moduleType === 'umd' || moduleType === 'amd' + ? { + noInterop: !opts.esModuleInterop, + ignoreDynamic: opts.ignoreDynamic, + } + : undefined), + }, + sourceMaps: ((_f = options === null || options === void 0 ? void 0 : options.swc) === null || _f === void 0 ? void 0 : _f.swcrc) + ? undefined + : jest || typeof opts.sourcemap === 'undefined' + ? 'inline' + : opts.sourcemap, inlineSourcesContent: true, swcrc: false, - ...((_e = options === null || options === void 0 ? void 0 : options.swc) !== null && _e !== void 0 ? _e : {}), + ...((_g = options === null || options === void 0 ? void 0 : options.swc) !== null && _g !== void 0 ? _g : {}), }; } function transformSync(source, path, options) { @@ -4680,7 +3775,7 @@ exports.transform = transform; /***/ }), -/***/ 11642: +/***/ 66357: /***/ (function(__unused_webpack_module, exports, __nccwpck_require__) { "use strict"; @@ -4715,9 +3810,9 @@ Object.defineProperty(exports, "__esModule", ({ value: true })); exports.tsCompilerOptionsToSwcConfig = exports.readDefaultTsConfig = void 0; const fs_1 = __nccwpck_require__(57147); const path_1 = __nccwpck_require__(71017); -const colorette_1 = __nccwpck_require__(90583); -const debug_1 = __importDefault(__nccwpck_require__(44126)); -const ts = __importStar(__nccwpck_require__(70048)); +const colorette_1 = __nccwpck_require__(6613); +const debug_1 = __importDefault(__nccwpck_require__(93118)); +const ts = __importStar(__nccwpck_require__(81151)); const debug = (0, debug_1.default)('@swc-node'); function readDefaultTsConfig(tsConfigPath) { var _a, _b; @@ -4802,36 +3897,48 @@ function toModule(moduleKind) { throw new TypeError('Do not support system kind module'); } } +/** + * The default value for useDefineForClassFields depends on the emit target + * @see https://www.typescriptlang.org/tsconfig#useDefineForClassFields + */ +function getUseDefineForClassFields(compilerOptions, target) { + var _a; + return (_a = compilerOptions.useDefineForClassFields) !== null && _a !== void 0 ? _a : target >= ts.ScriptTarget.ES2022; +} function tsCompilerOptionsToSwcConfig(options, filename) { - var _a, _b, _c, _d, _e, _f, _g, _h; + var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m; const isJsx = filename.endsWith('.tsx') || filename.endsWith('.jsx') || Boolean(options.jsx); + const target = (_a = options.target) !== null && _a !== void 0 ? _a : ts.ScriptTarget.ES2018; return { - module: toModule((_a = options.module) !== null && _a !== void 0 ? _a : ts.ModuleKind.ES2015), - target: toTsTarget((_b = options.target) !== null && _b !== void 0 ? _b : ts.ScriptTarget.ES2018), + module: toModule((_b = options.module) !== null && _b !== void 0 ? _b : ts.ModuleKind.ES2015), + target: toTsTarget(target), jsx: isJsx, sourcemap: options.sourceMap && options.inlineSourceMap ? 'inline' : Boolean(options.sourceMap), experimentalDecorators: (_c = options.experimentalDecorators) !== null && _c !== void 0 ? _c : false, emitDecoratorMetadata: (_d = options.emitDecoratorMetadata) !== null && _d !== void 0 ? _d : false, + useDefineForClassFields: getUseDefineForClassFields(options, target), esModuleInterop: (_e = options.esModuleInterop) !== null && _e !== void 0 ? _e : false, dynamicImport: true, keepClassNames: true, externalHelpers: Boolean(options.importHelpers), - react: options.jsxFactory || options.jsxFragmentFactory || options.jsx || options.jsxImportSource + react: ((_h = (_g = (_f = options.jsxFactory) !== null && _f !== void 0 ? _f : options.jsxFragmentFactory) !== null && _g !== void 0 ? _g : options.jsx) !== null && _h !== void 0 ? _h : options.jsxImportSource) ? { pragma: options.jsxFactory, pragmaFrag: options.jsxFragmentFactory, - importSource: (_f = options.jsxImportSource) !== null && _f !== void 0 ? _f : 'react', - runtime: ((_g = options.jsx) !== null && _g !== void 0 ? _g : 0) >= ts.JsxEmit.ReactJSX ? 'automatic' : 'classic', + importSource: (_j = options.jsxImportSource) !== null && _j !== void 0 ? _j : 'react', + runtime: ((_k = options.jsx) !== null && _k !== void 0 ? _k : 0) >= ts.JsxEmit.ReactJSX ? 'automatic' : 'classic', useBuiltins: true, } : undefined, - paths: Object.fromEntries(Object.entries((_h = options.paths) !== null && _h !== void 0 ? _h : {}).map(([aliasKey, aliasPaths]) => { + baseUrl: (0, path_1.resolve)((_l = options.baseUrl) !== null && _l !== void 0 ? _l : './'), + paths: Object.fromEntries(Object.entries((_m = options.paths) !== null && _m !== void 0 ? _m : {}).map(([aliasKey, aliasPaths]) => { var _a; return [ aliasKey, ((_a = aliasPaths) !== null && _a !== void 0 ? _a : []).map((path) => { var _a; return (0, path_1.resolve)((_a = options.baseUrl) !== null && _a !== void 0 ? _a : './', path); }), ]; })), + ignoreDynamic: Boolean(process.env.SWC_NODE_IGNORE_DYNAMIC), swc: { sourceRoot: options.sourceRoot, inputSourceMap: options.inlineSourceMap, @@ -4843,7 +3950,7 @@ exports.tsCompilerOptionsToSwcConfig = tsCompilerOptionsToSwcConfig; /***/ }), -/***/ 61856: +/***/ 55204: /***/ (function(__unused_webpack_module, exports, __nccwpck_require__) { "use strict"; @@ -4875,11 +3982,11 @@ Object.defineProperty(exports, "__esModule", ({ value: true })); exports.register = exports.compile = void 0; const os_1 = __nccwpck_require__(22037); const path_1 = __nccwpck_require__(71017); -const core_1 = __nccwpck_require__(10763); -const sourcemap_support_1 = __nccwpck_require__(13756); -const pirates_1 = __nccwpck_require__(115); -const ts = __importStar(__nccwpck_require__(70048)); -const read_default_tsconfig_1 = __nccwpck_require__(11642); +const core_1 = __nccwpck_require__(47885); +const sourcemap_support_1 = __nccwpck_require__(80758); +const pirates_1 = __nccwpck_require__(16135); +const ts = __importStar(__nccwpck_require__(81151)); +const read_default_tsconfig_1 = __nccwpck_require__(66357); const DEFAULT_EXTENSIONS = ['.js', '.jsx', '.es6', '.es', '.mjs', '.ts', '.tsx']; const PLATFORM = (0, os_1.platform)(); const injectInlineSourceMap = ({ filename, code, map, }) => { @@ -4912,24 +4019,24 @@ function compile(sourcecode, filename, options, async = false) { }); return injectInlineSourceMap({ filename, code: outputText, map: sourceMapText }); } - else if (async) { - return (0, core_1.transform)(sourcecode, filename, (0, read_default_tsconfig_1.tsCompilerOptionsToSwcConfig)(options, filename)).then(({ code, map }) => { + let swcRegisterConfig; + if (process.env.SWCRC) { + // when SWCRC environment variable is set to true it will use swcrc file + swcRegisterConfig = { + swc: { + swcrc: true, + }, + }; + } + else { + swcRegisterConfig = (0, read_default_tsconfig_1.tsCompilerOptionsToSwcConfig)(options, filename); + } + if (async) { + return (0, core_1.transform)(sourcecode, filename, swcRegisterConfig).then(({ code, map }) => { return injectInlineSourceMap({ filename, code, map }); }); } else { - let swcRegisterConfig; - if (process.env.SWCRC) { - // when SWCRC environment variable is set to true it will use swcrc file - swcRegisterConfig = { - swc: { - swcrc: true, - }, - }; - } - else { - swcRegisterConfig = (0, read_default_tsconfig_1.tsCompilerOptionsToSwcConfig)(options, filename); - } const { code, map } = (0, core_1.transformSync)(sourcecode, filename, swcRegisterConfig); return injectInlineSourceMap({ filename, code, map }); } @@ -4937,7 +4044,7 @@ function compile(sourcecode, filename, options, async = false) { exports.compile = compile; function register(options = {}, hookOpts = {}) { if (!process.env.SWCRC) { - options = (0, read_default_tsconfig_1.readDefaultTsConfig)(); + options = Object.keys(options).length ? options : (0, read_default_tsconfig_1.readDefaultTsConfig)(); } options.module = ts.ModuleKind.CommonJS; (0, sourcemap_support_1.installSourceMapSupport)(); @@ -4951,7 +4058,7 @@ exports.register = register; /***/ }), -/***/ 13756: +/***/ 80758: /***/ (function(__unused_webpack_module, exports, __nccwpck_require__) { "use strict"; @@ -4961,7 +4068,7 @@ var __importDefault = (this && this.__importDefault) || function (mod) { }; Object.defineProperty(exports, "__esModule", ({ value: true })); exports.installSourceMapSupport = exports.SourcemapMap = void 0; -const source_map_support_1 = __importDefault(__nccwpck_require__(95953)); +const source_map_support_1 = __importDefault(__nccwpck_require__(98841)); exports.SourcemapMap = new Map(); function installSourceMapSupport() { source_map_support_1.default.install({ @@ -4983,1001 +4090,445 @@ exports.installSourceMapSupport = installSourceMapSupport; /***/ }), -/***/ 95953: -/***/ ((module, exports, __nccwpck_require__) => { - -/* module decorator */ module = __nccwpck_require__.nmd(module); -var SourceMapConsumer = (__nccwpck_require__(36096).SourceMapConsumer); -var path = __nccwpck_require__(71017); - -var fs; -try { - fs = __nccwpck_require__(57147); - if (!fs.existsSync || !fs.readFileSync) { - // fs doesn't have all methods we need - fs = null; - } -} catch (err) { - /* nop */ -} - -var bufferFrom = __nccwpck_require__(82415); - -/** - * Requires a module which is protected against bundler minification. - * - * @param {NodeModule} mod - * @param {string} request - */ -function dynamicRequire(mod, request) { - return mod.require(request); -} - -// Only install once if called multiple times -var errorFormatterInstalled = false; -var uncaughtShimInstalled = false; - -// If true, the caches are reset before a stack trace formatting operation -var emptyCacheBetweenOperations = false; - -// Supports {browser, node, auto} -var environment = "auto"; - -// Maps a file path to a string containing the file contents -var fileContentsCache = {}; - -// Maps a file path to a source map for that file -var sourceMapCache = {}; - -// Regex for detecting source maps -var reSourceMap = /^data:application\/json[^,]+base64,/; +/***/ 24279: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { -// Priority list of retrieve handlers -var retrieveFileHandlers = []; -var retrieveMapHandlers = []; +"use strict"; -function isInBrowser() { - if (environment === "browser") - return true; - if (environment === "node") +// prettier-ignore +/* eslint-disable */ +/* auto-generated by NAPI-RS */ +const { existsSync, readFileSync } = __nccwpck_require__(57147); +const { join } = __nccwpck_require__(71017); +const { platform, arch } = process; +let nativeBinding = null; +let localFileExisted = false; +let loadError = null; +const isMusl = () => { + let musl = false; + if (process.platform === 'linux') { + musl = isMuslFromFilesystem(); + if (musl === null) { + musl = isMuslFromReport(); + } + if (musl === null) { + musl = isMuslFromChildProcess(); + } + } + return musl; +}; +const isFileMusl = (f) => f.includes('libc.musl-') || f.includes('ld-musl-'); +const isMuslFromFilesystem = () => { + try { + return readFileSync('/usr/bin/ldd', 'utf-8').includes('musl'); + } + catch (_a) { + return null; + } +}; +const isMuslFromReport = () => { + const report = typeof process.report.getReport === 'function' ? process.report.getReport() : null; + if (!report) { + return null; + } + if (report.header && report.header.glibcVersionRuntime) { + return false; + } + if (Array.isArray(report.sharedObjects)) { + if (report.sharedObjects.some(isFileMusl)) { + return true; + } + } return false; - return ((typeof window !== 'undefined') && (typeof XMLHttpRequest === 'function') && !(window.require && window.module && window.process && window.process.type === "renderer")); -} - -function hasGlobalProcessEventEmitter() { - return ((typeof process === 'object') && (process !== null) && (typeof process.on === 'function')); -} - -function globalProcessVersion() { - if ((typeof process === 'object') && (process !== null)) { - return process.version; - } else { - return ''; - } -} - -function globalProcessStderr() { - if ((typeof process === 'object') && (process !== null)) { - return process.stderr; - } -} - -function globalProcessExit(code) { - if ((typeof process === 'object') && (process !== null) && (typeof process.exit === 'function')) { - return process.exit(code); - } -} - -function handlerExec(list) { - return function(arg) { - for (var i = 0; i < list.length; i++) { - var ret = list[i](arg); - if (ret) { - return ret; - } +}; +const isMuslFromChildProcess = () => { + try { + return (__nccwpck_require__(32081).execSync)('ldd --version', { encoding: 'utf8' }).includes('musl'); } - return null; - }; + catch (e) { + // If we reach this case, we don't know if the system is musl or not, so is better to just fallback to false + return false; + } +}; +switch (platform) { + case 'android': + switch (arch) { + case 'arm64': + localFileExisted = existsSync(join(__dirname, 'swc.android-arm64.node')); + try { + if (localFileExisted) { + nativeBinding = __nccwpck_require__(27607); + } + else { + nativeBinding = __nccwpck_require__(73543); + } + } + catch (e) { + loadError = e; + } + break; + case 'arm': + localFileExisted = existsSync(join(__dirname, 'swc.android-arm-eabi.node')); + try { + if (localFileExisted) { + nativeBinding = __nccwpck_require__(84384); + } + else { + nativeBinding = __nccwpck_require__(86670); + } + } + catch (e) { + loadError = e; + } + break; + default: + throw new Error(`Unsupported architecture on Android ${arch}`); + } + break; + case 'win32': + switch (arch) { + case 'x64': + localFileExisted = existsSync(join(__dirname, 'swc.win32-x64-msvc.node')); + try { + if (localFileExisted) { + nativeBinding = __nccwpck_require__(48865); + } + else { + nativeBinding = __nccwpck_require__(66995); + } + } + catch (e) { + loadError = e; + } + break; + case 'ia32': + localFileExisted = existsSync(join(__dirname, 'swc.win32-ia32-msvc.node')); + try { + if (localFileExisted) { + nativeBinding = __nccwpck_require__(56637); + } + else { + nativeBinding = __nccwpck_require__(46924); + } + } + catch (e) { + loadError = e; + } + break; + case 'arm64': + localFileExisted = existsSync(join(__dirname, 'swc.win32-arm64-msvc.node')); + try { + if (localFileExisted) { + nativeBinding = __nccwpck_require__(42395); + } + else { + nativeBinding = __nccwpck_require__(7470); + } + } + catch (e) { + loadError = e; + } + break; + default: + throw new Error(`Unsupported architecture on Windows: ${arch}`); + } + break; + case 'darwin': + localFileExisted = existsSync(join(__dirname, 'swc.darwin-universal.node')); + try { + if (localFileExisted) { + nativeBinding = __nccwpck_require__(29232); + } + else { + nativeBinding = __nccwpck_require__(66749); + } + break; + } + catch (_a) { } + switch (arch) { + case 'x64': + localFileExisted = existsSync(join(__dirname, 'swc.darwin-x64.node')); + try { + if (localFileExisted) { + nativeBinding = __nccwpck_require__(71110); + } + else { + nativeBinding = __nccwpck_require__(62659); + } + } + catch (e) { + loadError = e; + } + break; + case 'arm64': + localFileExisted = existsSync(join(__dirname, 'swc.darwin-arm64.node')); + try { + if (localFileExisted) { + nativeBinding = __nccwpck_require__(23827); + } + else { + nativeBinding = __nccwpck_require__(67754); + } + } + catch (e) { + loadError = e; + } + break; + default: + throw new Error(`Unsupported architecture on macOS: ${arch}`); + } + break; + case 'freebsd': + if (arch !== 'x64') { + throw new Error(`Unsupported architecture on FreeBSD: ${arch}`); + } + localFileExisted = existsSync(join(__dirname, 'swc.freebsd-x64.node')); + try { + if (localFileExisted) { + nativeBinding = __nccwpck_require__(96182); + } + else { + nativeBinding = __nccwpck_require__(26640); + } + } + catch (e) { + loadError = e; + } + break; + case 'linux': + switch (arch) { + case 'x64': + if (isMusl()) { + localFileExisted = existsSync(join(__dirname, 'swc.linux-x64-musl.node')); + try { + if (localFileExisted) { + nativeBinding = __nccwpck_require__(76885); + } + else { + nativeBinding = __nccwpck_require__(27110); + } + } + catch (e) { + loadError = e; + } + } + else { + localFileExisted = existsSync(join(__dirname, 'swc.linux-x64-gnu.node')); + try { + if (localFileExisted) { + nativeBinding = __nccwpck_require__(93305); + } + else { + nativeBinding = __nccwpck_require__(69653); + } + } + catch (e) { + loadError = e; + } + } + break; + case 'arm64': + if (isMusl()) { + localFileExisted = existsSync(join(__dirname, 'swc.linux-arm64-musl.node')); + try { + if (localFileExisted) { + nativeBinding = __nccwpck_require__(52614); + } + else { + nativeBinding = __nccwpck_require__(93346); + } + } + catch (e) { + loadError = e; + } + } + else { + localFileExisted = existsSync(join(__dirname, 'swc.linux-arm64-gnu.node')); + try { + if (localFileExisted) { + nativeBinding = __nccwpck_require__(7458); + } + else { + nativeBinding = __nccwpck_require__(13520); + } + } + catch (e) { + loadError = e; + } + } + break; + case 'arm': + localFileExisted = existsSync(join(__dirname, 'swc.linux-arm-gnueabihf.node')); + try { + if (localFileExisted) { + nativeBinding = __nccwpck_require__(10645); + } + else { + nativeBinding = __nccwpck_require__(19505); + } + } + catch (e) { + loadError = e; + } + break; + case 'riscv64': + if (isMusl()) { + localFileExisted = existsSync(join(__dirname, 'swc.linux-riscv64-musl.node')); + try { + if (localFileExisted) { + nativeBinding = __nccwpck_require__(899); + } + else { + nativeBinding = __nccwpck_require__(81873); + } + } + catch (e) { + loadError = e; + } + } + else { + localFileExisted = existsSync(join(__dirname, 'swc.linux-riscv64-gnu.node')); + try { + if (localFileExisted) { + nativeBinding = __nccwpck_require__(79306); + } + else { + nativeBinding = __nccwpck_require__(32636); + } + } + catch (e) { + loadError = e; + } + } + break; + default: + throw new Error(`Unsupported architecture on Linux: ${arch}`); + } + break; + default: + throw new Error(`Unsupported OS: ${platform}, architecture: ${arch}`); } - -var retrieveFile = handlerExec(retrieveFileHandlers); - -retrieveFileHandlers.push(function(path) { - // Trim the path to make sure there is no extra whitespace. - path = path.trim(); - if (/^file:/.test(path)) { - // existsSync/readFileSync can't handle file protocol, but once stripped, it works - path = path.replace(/file:\/\/\/(\w:)?/, function(protocol, drive) { - return drive ? - '' : // file:///C:/dir/file -> C:/dir/file - '/'; // file:///root-dir/file -> /root-dir/file - }); - } - if (path in fileContentsCache) { - return fileContentsCache[path]; - } - - var contents = ''; - try { - if (!fs) { - // Use SJAX if we are in the browser - var xhr = new XMLHttpRequest(); - xhr.open('GET', path, /** async */ false); - xhr.send(null); - if (xhr.readyState === 4 && xhr.status === 200) { - contents = xhr.responseText; - } - } else if (fs.existsSync(path)) { - // Otherwise, use the filesystem - contents = fs.readFileSync(path, 'utf8'); +if (!nativeBinding) { + if (loadError) { + throw loadError; } - } catch (er) { - /* ignore any errors */ - } - - return fileContentsCache[path] = contents; -}); - -// Support URLs relative to a directory, but be careful about a protocol prefix -// in case we are in the browser (i.e. directories may start with "http://" or "file:///") -function supportRelativeURL(file, url) { - if (!file) return url; - var dir = path.dirname(file); - var match = /^\w+:\/\/[^\/]*/.exec(dir); - var protocol = match ? match[0] : ''; - var startPath = dir.slice(protocol.length); - if (protocol && /^\/\w\:/.test(startPath)) { - // handle file:///C:/ paths - protocol += '/'; - return protocol + path.resolve(dir.slice(protocol.length), url).replace(/\\/g, '/'); - } - return protocol + path.resolve(dir.slice(protocol.length), url); + throw new Error(`Failed to load native binding`); } +module.exports.Compiler = nativeBinding.Compiler; +module.exports.JsCompiler = nativeBinding.JsCompiler; +module.exports.bundle = nativeBinding.bundle; +module.exports.getTargetTriple = nativeBinding.getTargetTriple; +module.exports.initCustomTraceSubscriber = nativeBinding.initCustomTraceSubscriber; +module.exports.minify = nativeBinding.minify; +module.exports.minifySync = nativeBinding.minifySync; +module.exports.parse = nativeBinding.parse; +module.exports.parseFile = nativeBinding.parseFile; +module.exports.parseFileSync = nativeBinding.parseFileSync; +module.exports.parseSync = nativeBinding.parseSync; +module.exports.print = nativeBinding.print; +module.exports.printSync = nativeBinding.printSync; +module.exports.transform = nativeBinding.transform; +module.exports.transformFile = nativeBinding.transformFile; +module.exports.transformFileSync = nativeBinding.transformFileSync; +module.exports.transformSync = nativeBinding.transformSync; -function retrieveSourceMapURL(source) { - var fileData; - - if (isInBrowser()) { - try { - var xhr = new XMLHttpRequest(); - xhr.open('GET', source, false); - xhr.send(null); - fileData = xhr.readyState === 4 ? xhr.responseText : null; - - // Support providing a sourceMappingURL via the SourceMap header - var sourceMapHeader = xhr.getResponseHeader("SourceMap") || - xhr.getResponseHeader("X-SourceMap"); - if (sourceMapHeader) { - return sourceMapHeader; - } - } catch (e) { - } - } - - // Get the URL of the source map - fileData = retrieveFile(source); - var re = /(?:\/\/[@#][\s]*sourceMappingURL=([^\s'"]+)[\s]*$)|(?:\/\*[@#][\s]*sourceMappingURL=([^\s*'"]+)[\s]*(?:\*\/)[\s]*$)/mg; - // Keep executing the search to find the *last* sourceMappingURL to avoid - // picking up sourceMappingURLs from comments, strings, etc. - var lastMatch, match; - while (match = re.exec(fileData)) lastMatch = match; - if (!lastMatch) return null; - return lastMatch[1]; -}; -// Can be overridden by the retrieveSourceMap option to install. Takes a -// generated source filename; returns a {map, optional url} object, or null if -// there is no source map. The map field may be either a string or the parsed -// JSON object (ie, it must be a valid argument to the SourceMapConsumer -// constructor). -var retrieveSourceMap = handlerExec(retrieveMapHandlers); -retrieveMapHandlers.push(function(source) { - var sourceMappingURL = retrieveSourceMapURL(source); - if (!sourceMappingURL) return null; +/***/ }), - // Read the contents of the source map - var sourceMapData; - if (reSourceMap.test(sourceMappingURL)) { - // Support source map URL as a data url - var rawData = sourceMappingURL.slice(sourceMappingURL.indexOf(',') + 1); - sourceMapData = bufferFrom(rawData, "base64").toString(); - sourceMappingURL = source; - } else { - // Support source map URLs relative to the source URL - sourceMappingURL = supportRelativeURL(source, sourceMappingURL); - sourceMapData = retrieveFile(sourceMappingURL); - } +/***/ 65142: +/***/ (function(__unused_webpack_module, exports, __nccwpck_require__) { - if (!sourceMapData) { - return null; - } +"use strict"; - return { - url: sourceMappingURL, - map: sourceMapData - }; +var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) { + if (k2 === undefined) k2 = k; + var desc = Object.getOwnPropertyDescriptor(m, k); + if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) { + desc = { enumerable: true, get: function() { return m[k]; } }; + } + Object.defineProperty(o, k2, desc); +}) : (function(o, m, k, k2) { + if (k2 === undefined) k2 = k; + o[k2] = m[k]; +})); +var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) { + Object.defineProperty(o, "default", { enumerable: true, value: v }); +}) : function(o, v) { + o["default"] = v; }); - -function mapSourcePosition(position) { - var sourceMap = sourceMapCache[position.source]; - if (!sourceMap) { - // Call the (overrideable) retrieveSourceMap function to get the source map. - var urlAndMap = retrieveSourceMap(position.source); - if (urlAndMap) { - sourceMap = sourceMapCache[position.source] = { - url: urlAndMap.url, - map: new SourceMapConsumer(urlAndMap.map) - }; - - // Load all sources stored inline with the source map into the file cache - // to pretend like they are already loaded. They may not exist on disk. - if (sourceMap.map.sourcesContent) { - sourceMap.map.sources.forEach(function(source, i) { - var contents = sourceMap.map.sourcesContent[i]; - if (contents) { - var url = supportRelativeURL(sourceMap.url, source); - fileContentsCache[url] = contents; - } - }); - } - } else { - sourceMap = sourceMapCache[position.source] = { - url: null, - map: null - }; +var __exportStar = (this && this.__exportStar) || function(m, exports) { + for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p); +}; +var __importStar = (this && this.__importStar) || function (mod) { + if (mod && mod.__esModule) return mod; + var result = {}; + if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k); + __setModuleDefault(result, mod); + return result; +}; +var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { + function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); } + return new (P || (P = Promise))(function (resolve, reject) { + function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } + function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } + function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); } + step((generator = generator.apply(thisArg, _arguments || [])).next()); + }); +}; +var __rest = (this && this.__rest) || function (s, e) { + var t = {}; + for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0) + t[p] = s[p]; + if (s != null && typeof Object.getOwnPropertySymbols === "function") + for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) { + if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i])) + t[p[i]] = s[p[i]]; + } + return t; +}; +Object.defineProperty(exports, "__esModule", ({ value: true })); +exports.DEFAULT_EXTENSIONS = exports.getBinaryMetadata = exports.__experimental_registerGlobalTraceConfig = exports.minifySync = exports.minify = exports.bundle = exports.transformFileSync = exports.transformFile = exports.transformSync = exports.transform = exports.printSync = exports.print = exports.parseFileSync = exports.parseFile = exports.parseSync = exports.parse = exports.Compiler = exports.plugins = exports.version = void 0; +const path_1 = __nccwpck_require__(71017); +__exportStar(__nccwpck_require__(71992), exports); +const spack_1 = __nccwpck_require__(82357); +const assert = __importStar(__nccwpck_require__(39491)); +// Allow overrides to the location of the .node binding file +const bindingsOverride = process.env["SWC_BINARY_PATH"]; +// `@swc/core` includes d.ts for the `@swc/wasm` to provide typed fallback bindings +// todo: fix package.json scripts +let fallbackBindings; +const bindings = (() => { + let binding; + try { + binding = !!bindingsOverride ? require((0, path_1.resolve)(bindingsOverride)) : __nccwpck_require__(24279); + // If native binding loaded successfully, it should return proper target triple constant. + const triple = binding.getTargetTriple(); + assert.ok(triple, 'Failed to read target triple from native binary.'); + return binding; } - } - - // Resolve the source URL relative to the URL of the source map - if (sourceMap && sourceMap.map && typeof sourceMap.map.originalPositionFor === 'function') { - var originalPosition = sourceMap.map.originalPositionFor(position); - - // Only return the original position if a matching line was found. If no - // matching line is found then we return position instead, which will cause - // the stack trace to print the path and line for the compiled file. It is - // better to give a precise location in the compiled file than a vague - // location in the original file. - if (originalPosition.source !== null) { - originalPosition.source = supportRelativeURL( - sourceMap.url, originalPosition.source); - return originalPosition; + catch (_) { + // postinstall supposed to install `@swc/wasm` already + fallbackBindings = __nccwpck_require__(7343); } - } - - return position; -} - -// Parses code generated by FormatEvalOrigin(), a function inside V8: -// https://code.google.com/p/v8/source/browse/trunk/src/messages.js -function mapEvalOrigin(origin) { - // Most eval() calls are in this format - var match = /^eval at ([^(]+) \((.+):(\d+):(\d+)\)$/.exec(origin); - if (match) { - var position = mapSourcePosition({ - source: match[2], - line: +match[3], - column: match[4] - 1 - }); - return 'eval at ' + match[1] + ' (' + position.source + ':' + - position.line + ':' + (position.column + 1) + ')'; - } - - // Parse nested eval() calls using recursion - match = /^eval at ([^(]+) \((.+)\)$/.exec(origin); - if (match) { - return 'eval at ' + match[1] + ' (' + mapEvalOrigin(match[2]) + ')'; - } - - // Make sure we still return useful information if we didn't find anything - return origin; -} - -// This is copied almost verbatim from the V8 source code at -// https://code.google.com/p/v8/source/browse/trunk/src/messages.js. The -// implementation of wrapCallSite() used to just forward to the actual source -// code of CallSite.prototype.toString but unfortunately a new release of V8 -// did something to the prototype chain and broke the shim. The only fix I -// could find was copy/paste. -function CallSiteToString() { - var fileName; - var fileLocation = ""; - if (this.isNative()) { - fileLocation = "native"; - } else { - fileName = this.getScriptNameOrSourceURL(); - if (!fileName && this.isEval()) { - fileLocation = this.getEvalOrigin(); - fileLocation += ", "; // Expecting source position to follow. - } - - if (fileName) { - fileLocation += fileName; - } else { - // Source code does not originate from a file and is not native, but we - // can still get the source position inside the source string, e.g. in - // an eval string. - fileLocation += ""; - } - var lineNumber = this.getLineNumber(); - if (lineNumber != null) { - fileLocation += ":" + lineNumber; - var columnNumber = this.getColumnNumber(); - if (columnNumber) { - fileLocation += ":" + columnNumber; - } - } - } - - var line = ""; - var functionName = this.getFunctionName(); - var addSuffix = true; - var isConstructor = this.isConstructor(); - var isMethodCall = !(this.isToplevel() || isConstructor); - if (isMethodCall) { - var typeName = this.getTypeName(); - // Fixes shim to be backward compatable with Node v0 to v4 - if (typeName === "[object Object]") { - typeName = "null"; - } - var methodName = this.getMethodName(); - if (functionName) { - if (typeName && functionName.indexOf(typeName) != 0) { - line += typeName + "."; - } - line += functionName; - if (methodName && functionName.indexOf("." + methodName) != functionName.length - methodName.length - 1) { - line += " [as " + methodName + "]"; - } - } else { - line += typeName + "." + (methodName || ""); - } - } else if (isConstructor) { - line += "new " + (functionName || ""); - } else if (functionName) { - line += functionName; - } else { - line += fileLocation; - addSuffix = false; - } - if (addSuffix) { - line += " (" + fileLocation + ")"; - } - return line; -} - -function cloneCallSite(frame) { - var object = {}; - Object.getOwnPropertyNames(Object.getPrototypeOf(frame)).forEach(function(name) { - object[name] = /^(?:is|get)/.test(name) ? function() { return frame[name].call(frame); } : frame[name]; - }); - object.toString = CallSiteToString; - return object; -} - -function wrapCallSite(frame, state) { - // provides interface backward compatibility - if (state === undefined) { - state = { nextPosition: null, curPosition: null } - } - if(frame.isNative()) { - state.curPosition = null; - return frame; - } - - // Most call sites will return the source file from getFileName(), but code - // passed to eval() ending in "//# sourceURL=..." will return the source file - // from getScriptNameOrSourceURL() instead - var source = frame.getFileName() || frame.getScriptNameOrSourceURL(); - if (source) { - var line = frame.getLineNumber(); - var column = frame.getColumnNumber() - 1; - - // Fix position in Node where some (internal) code is prepended. - // See https://github.com/evanw/node-source-map-support/issues/36 - // Header removed in node at ^10.16 || >=11.11.0 - // v11 is not an LTS candidate, we can just test the one version with it. - // Test node versions for: 10.16-19, 10.20+, 12-19, 20-99, 100+, or 11.11 - var noHeader = /^v(10\.1[6-9]|10\.[2-9][0-9]|10\.[0-9]{3,}|1[2-9]\d*|[2-9]\d|\d{3,}|11\.11)/; - var headerLength = noHeader.test(globalProcessVersion()) ? 0 : 62; - if (line === 1 && column > headerLength && !isInBrowser() && !frame.isEval()) { - column -= headerLength; - } - - var position = mapSourcePosition({ - source: source, - line: line, - column: column - }); - state.curPosition = position; - frame = cloneCallSite(frame); - var originalFunctionName = frame.getFunctionName; - frame.getFunctionName = function() { - if (state.nextPosition == null) { - return originalFunctionName(); - } - return state.nextPosition.name || originalFunctionName(); - }; - frame.getFileName = function() { return position.source; }; - frame.getLineNumber = function() { return position.line; }; - frame.getColumnNumber = function() { return position.column + 1; }; - frame.getScriptNameOrSourceURL = function() { return position.source; }; - return frame; - } - - // Code called using eval() needs special handling - var origin = frame.isEval() && frame.getEvalOrigin(); - if (origin) { - origin = mapEvalOrigin(origin); - frame = cloneCallSite(frame); - frame.getEvalOrigin = function() { return origin; }; - return frame; - } - - // If we get here then we were unable to change the source position - return frame; -} - -// This function is part of the V8 stack trace API, for more info see: -// https://v8.dev/docs/stack-trace-api -function prepareStackTrace(error, stack) { - if (emptyCacheBetweenOperations) { - fileContentsCache = {}; - sourceMapCache = {}; - } - - var name = error.name || 'Error'; - var message = error.message || ''; - var errorString = name + ": " + message; - - var state = { nextPosition: null, curPosition: null }; - var processedStack = []; - for (var i = stack.length - 1; i >= 0; i--) { - processedStack.push('\n at ' + wrapCallSite(stack[i], state)); - state.nextPosition = state.curPosition; - } - state.curPosition = state.nextPosition = null; - return errorString + processedStack.reverse().join(''); -} - -// Generate position and snippet of original source with pointer -function getErrorSource(error) { - var match = /\n at [^(]+ \((.*):(\d+):(\d+)\)/.exec(error.stack); - if (match) { - var source = match[1]; - var line = +match[2]; - var column = +match[3]; - - // Support the inline sourceContents inside the source map - var contents = fileContentsCache[source]; - - // Support files on disk - if (!contents && fs && fs.existsSync(source)) { - try { - contents = fs.readFileSync(source, 'utf8'); - } catch (er) { - contents = ''; - } - } - - // Format the line from the original source code like node does - if (contents) { - var code = contents.split(/(?:\r\n|\r|\n)/)[line - 1]; - if (code) { - return source + ':' + line + '\n' + code + '\n' + - new Array(column).join(' ') + '^'; - } - } - } - return null; -} - -function printErrorAndExit (error) { - var source = getErrorSource(error); - - // Ensure error is printed synchronously and not truncated - var stderr = globalProcessStderr(); - if (stderr && stderr._handle && stderr._handle.setBlocking) { - stderr._handle.setBlocking(true); - } - - if (source) { - console.error(); - console.error(source); - } - - console.error(error.stack); - globalProcessExit(1); -} - -function shimEmitUncaughtException () { - var origEmit = process.emit; - - process.emit = function (type) { - if (type === 'uncaughtException') { - var hasStack = (arguments[1] && arguments[1].stack); - var hasListeners = (this.listeners(type).length > 0); - - if (hasStack && !hasListeners) { - return printErrorAndExit(arguments[1]); - } - } - - return origEmit.apply(this, arguments); - }; -} - -var originalRetrieveFileHandlers = retrieveFileHandlers.slice(0); -var originalRetrieveMapHandlers = retrieveMapHandlers.slice(0); - -exports.wrapCallSite = wrapCallSite; -exports.getErrorSource = getErrorSource; -exports.mapSourcePosition = mapSourcePosition; -exports.retrieveSourceMap = retrieveSourceMap; - -exports.install = function(options) { - options = options || {}; - - if (options.environment) { - environment = options.environment; - if (["node", "browser", "auto"].indexOf(environment) === -1) { - throw new Error("environment " + environment + " was unknown. Available options are {auto, browser, node}") - } - } - - // Allow sources to be found by methods other than reading the files - // directly from disk. - if (options.retrieveFile) { - if (options.overrideRetrieveFile) { - retrieveFileHandlers.length = 0; - } - - retrieveFileHandlers.unshift(options.retrieveFile); - } - - // Allow source maps to be found by methods other than reading the files - // directly from disk. - if (options.retrieveSourceMap) { - if (options.overrideRetrieveSourceMap) { - retrieveMapHandlers.length = 0; - } - - retrieveMapHandlers.unshift(options.retrieveSourceMap); - } - - // Support runtime transpilers that include inline source maps - if (options.hookRequire && !isInBrowser()) { - // Use dynamicRequire to avoid including in browser bundles - var Module = dynamicRequire(module, 'module'); - var $compile = Module.prototype._compile; - - if (!$compile.__sourceMapSupport) { - Module.prototype._compile = function(content, filename) { - fileContentsCache[filename] = content; - sourceMapCache[filename] = undefined; - return $compile.call(this, content, filename); - }; - - Module.prototype._compile.__sourceMapSupport = true; - } - } - - // Configure options - if (!emptyCacheBetweenOperations) { - emptyCacheBetweenOperations = 'emptyCacheBetweenOperations' in options ? - options.emptyCacheBetweenOperations : false; - } - - // Install the error reformatter - if (!errorFormatterInstalled) { - errorFormatterInstalled = true; - Error.prepareStackTrace = prepareStackTrace; - } - - if (!uncaughtShimInstalled) { - var installHandler = 'handleUncaughtExceptions' in options ? - options.handleUncaughtExceptions : true; - - // Do not override 'uncaughtException' with our own handler in Node.js - // Worker threads. Workers pass the error to the main thread as an event, - // rather than printing something to stderr and exiting. - try { - // We need to use `dynamicRequire` because `require` on it's own will be optimized by WebPack/Browserify. - var worker_threads = dynamicRequire(module, 'worker_threads'); - if (worker_threads.isMainThread === false) { - installHandler = false; - } - } catch(e) {} - - // Provide the option to not install the uncaught exception handler. This is - // to support other uncaught exception handlers (in test frameworks, for - // example). If this handler is not installed and there are no other uncaught - // exception handlers, uncaught exceptions will be caught by node's built-in - // exception handler and the process will still be terminated. However, the - // generated JavaScript code will be shown above the stack trace instead of - // the original source code. - if (installHandler && hasGlobalProcessEventEmitter()) { - uncaughtShimInstalled = true; - shimEmitUncaughtException(); - } - } -}; - -exports.resetRetrieveHandlers = function() { - retrieveFileHandlers.length = 0; - retrieveMapHandlers.length = 0; - - retrieveFileHandlers = originalRetrieveFileHandlers.slice(0); - retrieveMapHandlers = originalRetrieveMapHandlers.slice(0); - - retrieveSourceMap = handlerExec(retrieveMapHandlers); - retrieveFile = handlerExec(retrieveFileHandlers); -} - - -/***/ }), - -/***/ 89484: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { - -"use strict"; - -const { existsSync, readFileSync } = __nccwpck_require__(57147); -const { join } = __nccwpck_require__(71017); -const { platform, arch } = process; -let nativeBinding = null; -let localFileExisted = false; -let loadError = null; -function isMusl() { - // For Node 10 - if (!process.report || typeof process.report.getReport !== 'function') { - try { - const lddPath = (__nccwpck_require__(32081).execSync)('which ldd').toString().trim(); - return readFileSync(lddPath, 'utf8').includes('musl'); - } - catch (e) { - return true; - } - } - else { - const { glibcVersionRuntime } = process.report.getReport().header; - return !glibcVersionRuntime; - } -} -switch (platform) { - case 'android': - switch (arch) { - case 'arm64': - localFileExisted = existsSync(join(__dirname, 'swc.android-arm64.node')); - try { - if (localFileExisted) { - nativeBinding = __nccwpck_require__(10849); - } - else { - nativeBinding = __nccwpck_require__(95833); - } - } - catch (e) { - loadError = e; - } - break; - case 'arm': - localFileExisted = existsSync(join(__dirname, 'swc.android-arm-eabi.node')); - try { - if (localFileExisted) { - nativeBinding = __nccwpck_require__(70243); - } - else { - nativeBinding = __nccwpck_require__(39423); - } - } - catch (e) { - loadError = e; - } - break; - default: - throw new Error(`Unsupported architecture on Android ${arch}`); - } - break; - case 'win32': - switch (arch) { - case 'x64': - localFileExisted = existsSync(join(__dirname, 'swc.win32-x64-msvc.node')); - try { - if (localFileExisted) { - nativeBinding = __nccwpck_require__(1779); - } - else { - nativeBinding = __nccwpck_require__(20250); - } - } - catch (e) { - loadError = e; - } - break; - case 'ia32': - localFileExisted = existsSync(join(__dirname, 'swc.win32-ia32-msvc.node')); - try { - if (localFileExisted) { - nativeBinding = __nccwpck_require__(12445); - } - else { - nativeBinding = __nccwpck_require__(48333); - } - } - catch (e) { - loadError = e; - } - break; - case 'arm64': - localFileExisted = existsSync(join(__dirname, 'swc.win32-arm64-msvc.node')); - try { - if (localFileExisted) { - nativeBinding = __nccwpck_require__(91156); - } - else { - nativeBinding = __nccwpck_require__(89962); - } - } - catch (e) { - loadError = e; - } - break; - default: - throw new Error(`Unsupported architecture on Windows: ${arch}`); - } - break; - case 'darwin': - switch (arch) { - case 'x64': - localFileExisted = existsSync(join(__dirname, 'swc.darwin-x64.node')); - try { - if (localFileExisted) { - nativeBinding = __nccwpck_require__(9172); - } - else { - nativeBinding = __nccwpck_require__(5829); - } - } - catch (e) { - loadError = e; - } - break; - case 'arm64': - localFileExisted = existsSync(join(__dirname, 'swc.darwin-arm64.node')); - try { - if (localFileExisted) { - nativeBinding = __nccwpck_require__(37969); - } - else { - nativeBinding = __nccwpck_require__(40679); - } - } - catch (e) { - loadError = e; - } - break; - default: - throw new Error(`Unsupported architecture on macOS: ${arch}`); - } - break; - case 'freebsd': - if (arch !== 'x64') { - throw new Error(`Unsupported architecture on FreeBSD: ${arch}`); - } - localFileExisted = existsSync(join(__dirname, 'swc.freebsd-x64.node')); - try { - if (localFileExisted) { - nativeBinding = __nccwpck_require__(71487); - } - else { - nativeBinding = __nccwpck_require__(95212); - } - } - catch (e) { - loadError = e; - } - break; - case 'linux': - switch (arch) { - case 'x64': - if (isMusl()) { - localFileExisted = existsSync(join(__dirname, 'swc.linux-x64-musl.node')); - try { - if (localFileExisted) { - nativeBinding = __nccwpck_require__(3394); - } - else { - nativeBinding = __nccwpck_require__(35887); - } - } - catch (e) { - loadError = e; - } - } - else { - localFileExisted = existsSync(join(__dirname, 'swc.linux-x64-gnu.node')); - try { - if (localFileExisted) { - nativeBinding = __nccwpck_require__(13546); - } - else { - nativeBinding = __nccwpck_require__(47663); - } - } - catch (e) { - loadError = e; - } - } - break; - case 'arm64': - if (isMusl()) { - localFileExisted = existsSync(join(__dirname, 'swc.linux-arm64-musl.node')); - try { - if (localFileExisted) { - nativeBinding = __nccwpck_require__(2168); - } - else { - nativeBinding = __nccwpck_require__(79914); - } - } - catch (e) { - loadError = e; - } - } - else { - localFileExisted = existsSync(join(__dirname, 'swc.linux-arm64-gnu.node')); - try { - if (localFileExisted) { - nativeBinding = __nccwpck_require__(37857); - } - else { - nativeBinding = __nccwpck_require__(25670); - } - } - catch (e) { - loadError = e; - } - } - break; - case 'arm': - localFileExisted = existsSync(join(__dirname, 'swc.linux-arm-gnueabihf.node')); - try { - if (localFileExisted) { - nativeBinding = __nccwpck_require__(21651); - } - else { - nativeBinding = __nccwpck_require__(70593); - } - } - catch (e) { - loadError = e; - } - break; - default: - throw new Error(`Unsupported architecture on Linux: ${arch}`); - } - break; - default: - throw new Error(`Unsupported OS: ${platform}, architecture: ${arch}`); -} -if (!nativeBinding) { - if (loadError) { - throw loadError; - } - throw new Error(`Failed to load native binding`); -} -const { bundle, minify, minifySync, parse, parseSync, parseFileSync, parseFile, print, printSync, transform, transformSync, transformFile, transformFileSync, getTargetTriple, initCustomTraceSubscriber, Compiler } = nativeBinding; -module.exports.bundle = bundle; -module.exports.minify = minify; -module.exports.minifySync = minifySync; -module.exports.parse = parse; -module.exports.parseSync = parseSync; -module.exports.parseFileSync = parseFileSync; -module.exports.parseFile = parseFile; -module.exports.print = print; -module.exports.printSync = printSync; -module.exports.transform = transform; -module.exports.transformSync = transformSync; -module.exports.transformFile = transformFile; -module.exports.transformFileSync = transformFileSync; -module.exports.getTargetTriple = getTargetTriple; -module.exports.initCustomTraceSubscriber = initCustomTraceSubscriber; -module.exports.Compiler = Compiler; - - -/***/ }), - -/***/ 76237: -/***/ (function(__unused_webpack_module, exports, __nccwpck_require__) { - -"use strict"; - -var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) { - if (k2 === undefined) k2 = k; - var desc = Object.getOwnPropertyDescriptor(m, k); - if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) { - desc = { enumerable: true, get: function() { return m[k]; } }; - } - Object.defineProperty(o, k2, desc); -}) : (function(o, m, k, k2) { - if (k2 === undefined) k2 = k; - o[k2] = m[k]; -})); -var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) { - Object.defineProperty(o, "default", { enumerable: true, value: v }); -}) : function(o, v) { - o["default"] = v; -}); -var __exportStar = (this && this.__exportStar) || function(m, exports) { - for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p); -}; -var __importStar = (this && this.__importStar) || function (mod) { - if (mod && mod.__esModule) return mod; - var result = {}; - if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k); - __setModuleDefault(result, mod); - return result; -}; -var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { - function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); } - return new (P || (P = Promise))(function (resolve, reject) { - function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } - function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } - function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); } - step((generator = generator.apply(thisArg, _arguments || [])).next()); - }); -}; -var __rest = (this && this.__rest) || function (s, e) { - var t = {}; - for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0) - t[p] = s[p]; - if (s != null && typeof Object.getOwnPropertySymbols === "function") - for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) { - if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i])) - t[p[i]] = s[p[i]]; - } - return t; -}; -Object.defineProperty(exports, "__esModule", ({ value: true })); -exports.DEFAULT_EXTENSIONS = exports.getBinaryMetadata = exports.__experimental_registerGlobalTraceConfig = exports.minifySync = exports.minify = exports.bundle = exports.transformFileSync = exports.transformFile = exports.transformSync = exports.transform = exports.printSync = exports.print = exports.parseFileSync = exports.parseFile = exports.parseSync = exports.parse = exports.Compiler = exports.plugins = exports.version = void 0; -const path_1 = __nccwpck_require__(71017); -__exportStar(__nccwpck_require__(34222), exports); -const spack_1 = __nccwpck_require__(58986); -const assert = __importStar(__nccwpck_require__(39491)); -// Allow overrides to the location of the .node binding file -const bindingsOverride = process.env["SWC_BINARY_PATH"]; -// `@swc/core` includes d.ts for the `@swc/wasm` to provide typed fallback bindings -// todo: fix package.json scripts -let fallbackBindings; -const bindings = (() => { - let binding; - try { - binding = !!bindingsOverride ? require((0, path_1.resolve)(bindingsOverride)) : __nccwpck_require__(89484); - // If native binding loaded successfully, it should return proper target triple constant. - const triple = binding.getTargetTriple(); - assert.ok(triple, 'Failed to read target triple from native binary.'); - return binding; - } - catch (_) { - // postinstall supposed to install `@swc/wasm` already - fallbackBindings = __nccwpck_require__(80083); - } - finally { - return binding; - } -})(); -/** - * Version of the swc binding. - */ -exports.version = __nccwpck_require__(21841).version; -function plugins(ps) { - return mod => { - let m = mod; - for (const p of ps) { - m = p(m); - } - return m; - }; + finally { + return binding; + } +})(); +/** + * Version of the swc binding. + */ +exports.version = __nccwpck_require__(21841).version; +/** + * @deprecated JavaScript API is deprecated. Please use Wasm plugin instead. + */ +function plugins(ps) { + return mod => { + let m = mod; + for (const p of ps) { + m = p(m); + } + return m; + }; } exports.plugins = plugins; class Compiler { @@ -6323,7 +4874,7 @@ function toBuffer(t) { /***/ }), -/***/ 58986: +/***/ 82357: /***/ (function(__unused_webpack_module, exports, __nccwpck_require__) { "use strict"; @@ -6416,7 +4967,7 @@ exports.config = config; /***/ }), -/***/ 34222: +/***/ 71992: /***/ ((__unused_webpack_module, exports) => { "use strict"; @@ -6426,7 +4977,7 @@ Object.defineProperty(exports, "__esModule", ({ value: true })); /***/ }), -/***/ 82035: +/***/ 4694: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { module.exports = @@ -16705,7 +15256,7 @@ module.exports = process && support(supportLevel); /***/ }), -/***/ 92378: +/***/ 44301: /***/ ((module) => { "use strict"; @@ -17243,7 +15794,7 @@ module.exports = { /***/ }), -/***/ 30505: +/***/ 25704: /***/ ((module) => { "use strict"; @@ -20904,7 +19455,7 @@ module.exports = { /***/ }), -/***/ 15748: +/***/ 28111: /***/ ((module) => { "use strict"; @@ -22823,14 +21374,14 @@ module.exports = { /***/ }), -/***/ 98006: +/***/ 2877: /***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { "use strict"; Object.defineProperty(exports, "__esModule", ({ value: true })); exports.stringifySyml = exports.parseSyml = exports.stringifyResolution = exports.parseResolution = exports.stringifyValueArgument = exports.stringifyShellLine = exports.stringifyRedirectArgument = exports.stringifyEnvSegment = exports.stringifyCommandLineThen = exports.stringifyCommandLine = exports.stringifyCommandChainThen = exports.stringifyCommandChain = exports.stringifyCommand = exports.stringifyArithmeticExpression = exports.stringifyArgumentSegment = exports.stringifyArgument = exports.stringifyShell = exports.parseShell = void 0; -var shell_1 = __nccwpck_require__(72216); +var shell_1 = __nccwpck_require__(86546); Object.defineProperty(exports, "parseShell", ({ enumerable: true, get: function () { return shell_1.parseShell; } })); Object.defineProperty(exports, "stringifyShell", ({ enumerable: true, get: function () { return shell_1.stringifyShell; } })); Object.defineProperty(exports, "stringifyArgument", ({ enumerable: true, get: function () { return shell_1.stringifyArgument; } })); @@ -22845,24 +21396,24 @@ Object.defineProperty(exports, "stringifyEnvSegment", ({ enumerable: true, get: Object.defineProperty(exports, "stringifyRedirectArgument", ({ enumerable: true, get: function () { return shell_1.stringifyRedirectArgument; } })); Object.defineProperty(exports, "stringifyShellLine", ({ enumerable: true, get: function () { return shell_1.stringifyShellLine; } })); Object.defineProperty(exports, "stringifyValueArgument", ({ enumerable: true, get: function () { return shell_1.stringifyValueArgument; } })); -var resolution_1 = __nccwpck_require__(79591); +var resolution_1 = __nccwpck_require__(31642); Object.defineProperty(exports, "parseResolution", ({ enumerable: true, get: function () { return resolution_1.parseResolution; } })); Object.defineProperty(exports, "stringifyResolution", ({ enumerable: true, get: function () { return resolution_1.stringifyResolution; } })); -var syml_1 = __nccwpck_require__(42481); +var syml_1 = __nccwpck_require__(2419); Object.defineProperty(exports, "parseSyml", ({ enumerable: true, get: function () { return syml_1.parseSyml; } })); Object.defineProperty(exports, "stringifySyml", ({ enumerable: true, get: function () { return syml_1.stringifySyml; } })); /***/ }), -/***/ 79591: +/***/ 31642: /***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { "use strict"; Object.defineProperty(exports, "__esModule", ({ value: true })); exports.stringifyResolution = exports.parseResolution = void 0; -const resolution_1 = __nccwpck_require__(92378); +const resolution_1 = __nccwpck_require__(44301); function parseResolution(source) { const legacyResolution = source.match(/^\*{1,2}\/(.*)/); if (legacyResolution) @@ -22895,14 +21446,14 @@ exports.stringifyResolution = stringifyResolution; /***/ }), -/***/ 72216: +/***/ 86546: /***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { "use strict"; Object.defineProperty(exports, "__esModule", ({ value: true })); exports.stringifyShell = exports.stringifyArithmeticExpression = exports.stringifyArgumentSegment = exports.stringifyValueArgument = exports.stringifyRedirectArgument = exports.stringifyArgument = exports.stringifyEnvSegment = exports.stringifyCommand = exports.stringifyCommandChainThen = exports.stringifyCommandChain = exports.stringifyCommandLineThen = exports.stringifyCommandLine = exports.stringifyShellLine = exports.parseShell = void 0; -const shell_1 = __nccwpck_require__(30505); +const shell_1 = __nccwpck_require__(25704); function parseShell(source, options = { isGlobPattern: () => false }) { try { return (0, shell_1.parse)(source, options); @@ -23051,15 +21602,15 @@ exports.stringifyArithmeticExpression = stringifyArithmeticExpression; /***/ }), -/***/ 42481: +/***/ 2419: /***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { "use strict"; Object.defineProperty(exports, "__esModule", ({ value: true })); exports.parseSyml = exports.stringifySyml = exports.PreserveOrdering = void 0; -const js_yaml_1 = __nccwpck_require__(13469); -const syml_1 = __nccwpck_require__(15748); +const js_yaml_1 = __nccwpck_require__(49685); +const syml_1 = __nccwpck_require__(28111); const simpleStringPattern = /^(?![-?:,\][{}#&*!|>'"%@` \t\r\n]).([ \t]*(?![,\][{}:# \t\r\n]).)*$/; // The following keys will always be stored at the top of the object, in the // specified order. It's not fair but life isn't fair either. @@ -23191,14 +21742,14 @@ exports.parseSyml = parseSyml; /***/ }), -/***/ 13469: +/***/ 49685: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { "use strict"; -var yaml = __nccwpck_require__(87497); +var yaml = __nccwpck_require__(87329); module.exports = yaml; @@ -23206,15 +21757,15 @@ module.exports = yaml; /***/ }), -/***/ 87497: +/***/ 87329: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { "use strict"; -var loader = __nccwpck_require__(39463); -var dumper = __nccwpck_require__(5500); +var loader = __nccwpck_require__(88527); +var dumper = __nccwpck_require__(21175); function deprecated(name) { @@ -23224,25 +21775,25 @@ function deprecated(name) { } -module.exports.Type = __nccwpck_require__(34592); -module.exports.Schema = __nccwpck_require__(27731); -module.exports.FAILSAFE_SCHEMA = __nccwpck_require__(45576); -module.exports.JSON_SCHEMA = __nccwpck_require__(99482); -module.exports.CORE_SCHEMA = __nccwpck_require__(89554); -module.exports.DEFAULT_SAFE_SCHEMA = __nccwpck_require__(3012); -module.exports.DEFAULT_FULL_SCHEMA = __nccwpck_require__(2726); +module.exports.Type = __nccwpck_require__(58153); +module.exports.Schema = __nccwpck_require__(76658); +module.exports.FAILSAFE_SCHEMA = __nccwpck_require__(13589); +module.exports.JSON_SCHEMA = __nccwpck_require__(67464); +module.exports.CORE_SCHEMA = __nccwpck_require__(75447); +module.exports.DEFAULT_SAFE_SCHEMA = __nccwpck_require__(30537); +module.exports.DEFAULT_FULL_SCHEMA = __nccwpck_require__(88227); module.exports.load = loader.load; module.exports.loadAll = loader.loadAll; module.exports.safeLoad = loader.safeLoad; module.exports.safeLoadAll = loader.safeLoadAll; module.exports.dump = dumper.dump; module.exports.safeDump = dumper.safeDump; -module.exports.YAMLException = __nccwpck_require__(28743); +module.exports.YAMLException = __nccwpck_require__(12406); // Deprecated schema names from JS-YAML 2.0.x -module.exports.MINIMAL_SCHEMA = __nccwpck_require__(45576); -module.exports.SAFE_SCHEMA = __nccwpck_require__(3012); -module.exports.DEFAULT_SCHEMA = __nccwpck_require__(2726); +module.exports.MINIMAL_SCHEMA = __nccwpck_require__(13589); +module.exports.SAFE_SCHEMA = __nccwpck_require__(30537); +module.exports.DEFAULT_SCHEMA = __nccwpck_require__(88227); // Deprecated functions from JS-YAML 1.x.x module.exports.scan = deprecated('scan'); @@ -23253,7 +21804,7 @@ module.exports.addConstructor = deprecated('addConstructor'); /***/ }), -/***/ 81108: +/***/ 50062: /***/ ((module) => { "use strict"; @@ -23320,7 +21871,7 @@ module.exports.extend = extend; /***/ }), -/***/ 5500: +/***/ 21175: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { "use strict"; @@ -23328,10 +21879,10 @@ module.exports.extend = extend; /*eslint-disable no-use-before-define*/ -var common = __nccwpck_require__(81108); -var YAMLException = __nccwpck_require__(28743); -var DEFAULT_FULL_SCHEMA = __nccwpck_require__(2726); -var DEFAULT_SAFE_SCHEMA = __nccwpck_require__(3012); +var common = __nccwpck_require__(50062); +var YAMLException = __nccwpck_require__(12406); +var DEFAULT_FULL_SCHEMA = __nccwpck_require__(88227); +var DEFAULT_SAFE_SCHEMA = __nccwpck_require__(30537); var _toString = Object.prototype.toString; var _hasOwnProperty = Object.prototype.hasOwnProperty; @@ -24178,7 +22729,7 @@ module.exports.safeDump = safeDump; /***/ }), -/***/ 28743: +/***/ 12406: /***/ ((module) => { "use strict"; @@ -24229,7 +22780,7 @@ module.exports = YAMLException; /***/ }), -/***/ 39463: +/***/ 88527: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { "use strict"; @@ -24237,11 +22788,11 @@ module.exports = YAMLException; /*eslint-disable max-len,no-use-before-define*/ -var common = __nccwpck_require__(81108); -var YAMLException = __nccwpck_require__(28743); -var Mark = __nccwpck_require__(49656); -var DEFAULT_SAFE_SCHEMA = __nccwpck_require__(3012); -var DEFAULT_FULL_SCHEMA = __nccwpck_require__(2726); +var common = __nccwpck_require__(50062); +var YAMLException = __nccwpck_require__(12406); +var Mark = __nccwpck_require__(54710); +var DEFAULT_SAFE_SCHEMA = __nccwpck_require__(30537); +var DEFAULT_FULL_SCHEMA = __nccwpck_require__(88227); var _hasOwnProperty = Object.prototype.hasOwnProperty; @@ -25881,14 +24432,14 @@ module.exports.safeLoad = safeLoad; /***/ }), -/***/ 49656: +/***/ 54710: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { "use strict"; -var common = __nccwpck_require__(81108); +var common = __nccwpck_require__(50062); function Mark(name, buffer, position, line, column) { @@ -25965,7 +24516,7 @@ module.exports = Mark; /***/ }), -/***/ 27731: +/***/ 76658: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { "use strict"; @@ -25973,9 +24524,9 @@ module.exports = Mark; /*eslint-disable max-len*/ -var common = __nccwpck_require__(81108); -var YAMLException = __nccwpck_require__(28743); -var Type = __nccwpck_require__(34592); +var common = __nccwpck_require__(50062); +var YAMLException = __nccwpck_require__(12406); +var Type = __nccwpck_require__(58153); function compileList(schema, name, result) { @@ -26081,7 +24632,7 @@ module.exports = Schema; /***/ }), -/***/ 89554: +/***/ 75447: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { "use strict"; @@ -26095,19 +24646,19 @@ module.exports = Schema; -var Schema = __nccwpck_require__(27731); +var Schema = __nccwpck_require__(76658); module.exports = new Schema({ include: [ - __nccwpck_require__(99482) + __nccwpck_require__(67464) ] }); /***/ }), -/***/ 2726: +/***/ 88227: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { "use strict"; @@ -26123,24 +24674,24 @@ module.exports = new Schema({ -var Schema = __nccwpck_require__(27731); +var Schema = __nccwpck_require__(76658); module.exports = Schema.DEFAULT = new Schema({ include: [ - __nccwpck_require__(3012) + __nccwpck_require__(30537) ], explicit: [ - __nccwpck_require__(73828), - __nccwpck_require__(94234), - __nccwpck_require__(15552) + __nccwpck_require__(58947), + __nccwpck_require__(99716), + __nccwpck_require__(71654) ] }); /***/ }), -/***/ 3012: +/***/ 30537: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { "use strict"; @@ -26154,29 +24705,29 @@ module.exports = Schema.DEFAULT = new Schema({ -var Schema = __nccwpck_require__(27731); +var Schema = __nccwpck_require__(76658); module.exports = new Schema({ include: [ - __nccwpck_require__(89554) + __nccwpck_require__(75447) ], implicit: [ - __nccwpck_require__(91278), - __nccwpck_require__(18363) + __nccwpck_require__(42711), + __nccwpck_require__(52332) ], explicit: [ - __nccwpck_require__(47650), - __nccwpck_require__(98516), - __nccwpck_require__(77376), - __nccwpck_require__(15169) + __nccwpck_require__(67866), + __nccwpck_require__(82807), + __nccwpck_require__(56026), + __nccwpck_require__(9605) ] }); /***/ }), -/***/ 45576: +/***/ 13589: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { "use strict"; @@ -26187,21 +24738,21 @@ module.exports = new Schema({ -var Schema = __nccwpck_require__(27731); +var Schema = __nccwpck_require__(76658); module.exports = new Schema({ explicit: [ - __nccwpck_require__(43337), - __nccwpck_require__(82627), - __nccwpck_require__(79411) + __nccwpck_require__(45477), + __nccwpck_require__(78800), + __nccwpck_require__(55135) ] }); /***/ }), -/***/ 99482: +/***/ 67464: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { "use strict"; @@ -26216,31 +24767,31 @@ module.exports = new Schema({ -var Schema = __nccwpck_require__(27731); +var Schema = __nccwpck_require__(76658); module.exports = new Schema({ include: [ - __nccwpck_require__(45576) + __nccwpck_require__(13589) ], implicit: [ - __nccwpck_require__(1195), - __nccwpck_require__(87975), - __nccwpck_require__(50231), - __nccwpck_require__(92067) + __nccwpck_require__(99432), + __nccwpck_require__(61131), + __nccwpck_require__(63357), + __nccwpck_require__(92026) ] }); /***/ }), -/***/ 34592: +/***/ 58153: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { "use strict"; -var YAMLException = __nccwpck_require__(28743); +var YAMLException = __nccwpck_require__(12406); var TYPE_CONSTRUCTOR_OPTIONS = [ 'kind', @@ -26303,7 +24854,7 @@ module.exports = Type; /***/ }), -/***/ 47650: +/***/ 67866: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { "use strict"; @@ -26319,7 +24870,7 @@ try { NodeBuffer = _require('buffer').Buffer; } catch (__) {} -var Type = __nccwpck_require__(34592); +var Type = __nccwpck_require__(58153); // [ 64, 65, 66 ] -> [ padding, CR, LF ] @@ -26449,13 +25000,13 @@ module.exports = new Type('tag:yaml.org,2002:binary', { /***/ }), -/***/ 87975: +/***/ 61131: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { "use strict"; -var Type = __nccwpck_require__(34592); +var Type = __nccwpck_require__(58153); function resolveYamlBoolean(data) { if (data === null) return false; @@ -26492,14 +25043,14 @@ module.exports = new Type('tag:yaml.org,2002:bool', { /***/ }), -/***/ 92067: +/***/ 92026: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { "use strict"; -var common = __nccwpck_require__(81108); -var Type = __nccwpck_require__(34592); +var common = __nccwpck_require__(50062); +var Type = __nccwpck_require__(58153); var YAML_FLOAT_PATTERN = new RegExp( // 2.5e4, 2.5 and integers @@ -26616,14 +25167,14 @@ module.exports = new Type('tag:yaml.org,2002:float', { /***/ }), -/***/ 50231: +/***/ 63357: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { "use strict"; -var common = __nccwpck_require__(81108); -var Type = __nccwpck_require__(34592); +var common = __nccwpck_require__(50062); +var Type = __nccwpck_require__(58153); function isHexCode(c) { return ((0x30/* 0 */ <= c) && (c <= 0x39/* 9 */)) || @@ -26797,7 +25348,7 @@ module.exports = new Type('tag:yaml.org,2002:int', { /***/ }), -/***/ 15552: +/***/ 71654: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { "use strict"; @@ -26822,7 +25373,7 @@ try { if (typeof window !== 'undefined') esprima = window.esprima; } -var Type = __nccwpck_require__(34592); +var Type = __nccwpck_require__(58153); function resolveJavascriptFunction(data) { if (data === null) return false; @@ -26898,13 +25449,13 @@ module.exports = new Type('tag:yaml.org,2002:js/function', { /***/ }), -/***/ 94234: +/***/ 99716: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { "use strict"; -var Type = __nccwpck_require__(34592); +var Type = __nccwpck_require__(58153); function resolveJavascriptRegExp(data) { if (data === null) return false; @@ -26966,13 +25517,13 @@ module.exports = new Type('tag:yaml.org,2002:js/regexp', { /***/ }), -/***/ 73828: +/***/ 58947: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { "use strict"; -var Type = __nccwpck_require__(34592); +var Type = __nccwpck_require__(58153); function resolveJavascriptUndefined() { return true; @@ -27002,13 +25553,13 @@ module.exports = new Type('tag:yaml.org,2002:js/undefined', { /***/ }), -/***/ 79411: +/***/ 55135: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { "use strict"; -var Type = __nccwpck_require__(34592); +var Type = __nccwpck_require__(58153); module.exports = new Type('tag:yaml.org,2002:map', { kind: 'mapping', @@ -27018,13 +25569,13 @@ module.exports = new Type('tag:yaml.org,2002:map', { /***/ }), -/***/ 18363: +/***/ 52332: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { "use strict"; -var Type = __nccwpck_require__(34592); +var Type = __nccwpck_require__(58153); function resolveYamlMerge(data) { return data === '<<' || data === null; @@ -27038,13 +25589,13 @@ module.exports = new Type('tag:yaml.org,2002:merge', { /***/ }), -/***/ 1195: +/***/ 99432: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { "use strict"; -var Type = __nccwpck_require__(34592); +var Type = __nccwpck_require__(58153); function resolveYamlNull(data) { if (data === null) return true; @@ -27080,13 +25631,13 @@ module.exports = new Type('tag:yaml.org,2002:null', { /***/ }), -/***/ 98516: +/***/ 82807: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { "use strict"; -var Type = __nccwpck_require__(34592); +var Type = __nccwpck_require__(58153); var _hasOwnProperty = Object.prototype.hasOwnProperty; var _toString = Object.prototype.toString; @@ -27132,13 +25683,13 @@ module.exports = new Type('tag:yaml.org,2002:omap', { /***/ }), -/***/ 77376: +/***/ 56026: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { "use strict"; -var Type = __nccwpck_require__(34592); +var Type = __nccwpck_require__(58153); var _toString = Object.prototype.toString; @@ -27193,13 +25744,13 @@ module.exports = new Type('tag:yaml.org,2002:pairs', { /***/ }), -/***/ 82627: +/***/ 78800: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { "use strict"; -var Type = __nccwpck_require__(34592); +var Type = __nccwpck_require__(58153); module.exports = new Type('tag:yaml.org,2002:seq', { kind: 'sequence', @@ -27209,13 +25760,13 @@ module.exports = new Type('tag:yaml.org,2002:seq', { /***/ }), -/***/ 15169: +/***/ 9605: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { "use strict"; -var Type = __nccwpck_require__(34592); +var Type = __nccwpck_require__(58153); var _hasOwnProperty = Object.prototype.hasOwnProperty; @@ -27246,13 +25797,13 @@ module.exports = new Type('tag:yaml.org,2002:set', { /***/ }), -/***/ 43337: +/***/ 45477: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { "use strict"; -var Type = __nccwpck_require__(34592); +var Type = __nccwpck_require__(58153); module.exports = new Type('tag:yaml.org,2002:str', { kind: 'scalar', @@ -27262,13 +25813,13 @@ module.exports = new Type('tag:yaml.org,2002:str', { /***/ }), -/***/ 91278: +/***/ 42711: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { "use strict"; -var Type = __nccwpck_require__(34592); +var Type = __nccwpck_require__(58153); var YAML_DATE_REGEXP = new RegExp( '^([0-9][0-9][0-9][0-9])' + // [1] year @@ -27358,15 +25909,15 @@ module.exports = new Type('tag:yaml.org,2002:timestamp', { /***/ }), -/***/ 89777: +/***/ 74529: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { "use strict"; -var loader = __nccwpck_require__(75421); -var dumper = __nccwpck_require__(14908); +var loader = __nccwpck_require__(16871); +var dumper = __nccwpck_require__(74169); function renamed(from, to) { @@ -27377,16 +25928,16 @@ function renamed(from, to) { } -module.exports.Type = __nccwpck_require__(33872); -module.exports.Schema = __nccwpck_require__(81043); -module.exports.FAILSAFE_SCHEMA = __nccwpck_require__(40167); -module.exports.JSON_SCHEMA = __nccwpck_require__(17223); -module.exports.CORE_SCHEMA = __nccwpck_require__(36141); -module.exports.DEFAULT_SCHEMA = __nccwpck_require__(19097); +module.exports.Type = __nccwpck_require__(92889); +module.exports.Schema = __nccwpck_require__(80554); +module.exports.FAILSAFE_SCHEMA = __nccwpck_require__(49625); +module.exports.JSON_SCHEMA = __nccwpck_require__(23775); +module.exports.CORE_SCHEMA = __nccwpck_require__(95385); +module.exports.DEFAULT_SCHEMA = __nccwpck_require__(11972); module.exports.load = loader.load; module.exports.loadAll = loader.loadAll; module.exports.dump = dumper.dump; -module.exports.YAMLException = __nccwpck_require__(85003); +module.exports.YAMLException = __nccwpck_require__(70730); // Removed functions from JS-YAML 3.0.x module.exports.safeLoad = renamed('safeLoad', 'load'); @@ -27396,7 +25947,7 @@ module.exports.safeDump = renamed('safeDump', 'dump'); /***/ }), -/***/ 52152: +/***/ 19827: /***/ ((module) => { "use strict"; @@ -27463,7 +26014,7 @@ module.exports.extend = extend; /***/ }), -/***/ 14908: +/***/ 74169: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { "use strict"; @@ -27471,9 +26022,9 @@ module.exports.extend = extend; /*eslint-disable no-use-before-define*/ -var common = __nccwpck_require__(52152); -var YAMLException = __nccwpck_require__(85003); -var DEFAULT_SCHEMA = __nccwpck_require__(19097); +var common = __nccwpck_require__(19827); +var YAMLException = __nccwpck_require__(70730); +var DEFAULT_SCHEMA = __nccwpck_require__(11972); var _toString = Object.prototype.toString; var _hasOwnProperty = Object.prototype.hasOwnProperty; @@ -28449,7 +27000,7 @@ module.exports.dump = dump; /***/ }), -/***/ 85003: +/***/ 70730: /***/ ((module) => { "use strict"; @@ -28512,7 +27063,7 @@ module.exports = YAMLException; /***/ }), -/***/ 75421: +/***/ 16871: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { "use strict"; @@ -28520,10 +27071,10 @@ module.exports = YAMLException; /*eslint-disable max-len,no-use-before-define*/ -var common = __nccwpck_require__(52152); -var YAMLException = __nccwpck_require__(85003); -var makeSnippet = __nccwpck_require__(89420); -var DEFAULT_SCHEMA = __nccwpck_require__(19097); +var common = __nccwpck_require__(19827); +var YAMLException = __nccwpck_require__(70730); +var makeSnippet = __nccwpck_require__(45649); +var DEFAULT_SCHEMA = __nccwpck_require__(11972); var _hasOwnProperty = Object.prototype.hasOwnProperty; @@ -30247,7 +28798,7 @@ module.exports.load = load; /***/ }), -/***/ 81043: +/***/ 80554: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { "use strict"; @@ -30255,8 +28806,8 @@ module.exports.load = load; /*eslint-disable max-len*/ -var YAMLException = __nccwpck_require__(85003); -var Type = __nccwpck_require__(33872); +var YAMLException = __nccwpck_require__(70730); +var Type = __nccwpck_require__(92889); function compileList(schema, name, result) { @@ -30376,7 +28927,7 @@ module.exports = Schema; /***/ }), -/***/ 36141: +/***/ 95385: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { "use strict"; @@ -30390,12 +28941,12 @@ module.exports = Schema; -module.exports = __nccwpck_require__(17223); +module.exports = __nccwpck_require__(23775); /***/ }), -/***/ 19097: +/***/ 11972: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { "use strict"; @@ -30409,23 +28960,23 @@ module.exports = __nccwpck_require__(17223); -module.exports = (__nccwpck_require__(36141).extend)({ +module.exports = (__nccwpck_require__(95385).extend)({ implicit: [ - __nccwpck_require__(86559), - __nccwpck_require__(93159) + __nccwpck_require__(26202), + __nccwpck_require__(94533) ], explicit: [ - __nccwpck_require__(29937), - __nccwpck_require__(6924), - __nccwpck_require__(48915), - __nccwpck_require__(20726) + __nccwpck_require__(75140), + __nccwpck_require__(36992), + __nccwpck_require__(86681), + __nccwpck_require__(13760) ] }); /***/ }), -/***/ 40167: +/***/ 49625: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { "use strict"; @@ -30436,21 +28987,21 @@ module.exports = (__nccwpck_require__(36141).extend)({ -var Schema = __nccwpck_require__(81043); +var Schema = __nccwpck_require__(80554); module.exports = new Schema({ explicit: [ - __nccwpck_require__(68647), - __nccwpck_require__(23208), - __nccwpck_require__(39172) + __nccwpck_require__(20819), + __nccwpck_require__(48021), + __nccwpck_require__(47070) ] }); /***/ }), -/***/ 17223: +/***/ 23775: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { "use strict"; @@ -30465,26 +29016,26 @@ module.exports = new Schema({ -module.exports = (__nccwpck_require__(40167).extend)({ +module.exports = (__nccwpck_require__(49625).extend)({ implicit: [ - __nccwpck_require__(80783), - __nccwpck_require__(80791), - __nccwpck_require__(62053), - __nccwpck_require__(83142) + __nccwpck_require__(10618), + __nccwpck_require__(67358), + __nccwpck_require__(44734), + __nccwpck_require__(75609) ] }); /***/ }), -/***/ 89420: +/***/ 45649: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { "use strict"; -var common = __nccwpck_require__(52152); +var common = __nccwpck_require__(19827); // get snippet for a single line, respecting maxLength @@ -30586,13 +29137,13 @@ module.exports = makeSnippet; /***/ }), -/***/ 33872: +/***/ 92889: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { "use strict"; -var YAMLException = __nccwpck_require__(85003); +var YAMLException = __nccwpck_require__(70730); var TYPE_CONSTRUCTOR_OPTIONS = [ 'kind', @@ -30659,7 +29210,7 @@ module.exports = Type; /***/ }), -/***/ 29937: +/***/ 75140: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { "use strict"; @@ -30668,7 +29219,7 @@ module.exports = Type; /*eslint-disable no-bitwise*/ -var Type = __nccwpck_require__(33872); +var Type = __nccwpck_require__(92889); // [ 64, 65, 66 ] -> [ padding, CR, LF ] @@ -30792,13 +29343,13 @@ module.exports = new Type('tag:yaml.org,2002:binary', { /***/ }), -/***/ 80791: +/***/ 67358: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { "use strict"; -var Type = __nccwpck_require__(33872); +var Type = __nccwpck_require__(92889); function resolveYamlBoolean(data) { if (data === null) return false; @@ -30835,14 +29386,14 @@ module.exports = new Type('tag:yaml.org,2002:bool', { /***/ }), -/***/ 83142: +/***/ 75609: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { "use strict"; -var common = __nccwpck_require__(52152); -var Type = __nccwpck_require__(33872); +var common = __nccwpck_require__(19827); +var Type = __nccwpck_require__(92889); var YAML_FLOAT_PATTERN = new RegExp( // 2.5e4, 2.5 and integers @@ -30940,14 +29491,14 @@ module.exports = new Type('tag:yaml.org,2002:float', { /***/ }), -/***/ 62053: +/***/ 44734: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { "use strict"; -var common = __nccwpck_require__(52152); -var Type = __nccwpck_require__(33872); +var common = __nccwpck_require__(19827); +var Type = __nccwpck_require__(92889); function isHexCode(c) { return ((0x30/* 0 */ <= c) && (c <= 0x39/* 9 */)) || @@ -31104,13 +29655,13 @@ module.exports = new Type('tag:yaml.org,2002:int', { /***/ }), -/***/ 39172: +/***/ 47070: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { "use strict"; -var Type = __nccwpck_require__(33872); +var Type = __nccwpck_require__(92889); module.exports = new Type('tag:yaml.org,2002:map', { kind: 'mapping', @@ -31120,13 +29671,13 @@ module.exports = new Type('tag:yaml.org,2002:map', { /***/ }), -/***/ 93159: +/***/ 94533: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { "use strict"; -var Type = __nccwpck_require__(33872); +var Type = __nccwpck_require__(92889); function resolveYamlMerge(data) { return data === '<<' || data === null; @@ -31140,13 +29691,13 @@ module.exports = new Type('tag:yaml.org,2002:merge', { /***/ }), -/***/ 80783: +/***/ 10618: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { "use strict"; -var Type = __nccwpck_require__(33872); +var Type = __nccwpck_require__(92889); function resolveYamlNull(data) { if (data === null) return true; @@ -31183,13 +29734,13 @@ module.exports = new Type('tag:yaml.org,2002:null', { /***/ }), -/***/ 6924: +/***/ 36992: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { "use strict"; -var Type = __nccwpck_require__(33872); +var Type = __nccwpck_require__(92889); var _hasOwnProperty = Object.prototype.hasOwnProperty; var _toString = Object.prototype.toString; @@ -31235,13 +29786,13 @@ module.exports = new Type('tag:yaml.org,2002:omap', { /***/ }), -/***/ 48915: +/***/ 86681: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { "use strict"; -var Type = __nccwpck_require__(33872); +var Type = __nccwpck_require__(92889); var _toString = Object.prototype.toString; @@ -31296,13 +29847,13 @@ module.exports = new Type('tag:yaml.org,2002:pairs', { /***/ }), -/***/ 23208: +/***/ 48021: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { "use strict"; -var Type = __nccwpck_require__(33872); +var Type = __nccwpck_require__(92889); module.exports = new Type('tag:yaml.org,2002:seq', { kind: 'sequence', @@ -31312,13 +29863,13 @@ module.exports = new Type('tag:yaml.org,2002:seq', { /***/ }), -/***/ 20726: +/***/ 13760: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { "use strict"; -var Type = __nccwpck_require__(33872); +var Type = __nccwpck_require__(92889); var _hasOwnProperty = Object.prototype.hasOwnProperty; @@ -31349,13 +29900,13 @@ module.exports = new Type('tag:yaml.org,2002:set', { /***/ }), -/***/ 68647: +/***/ 20819: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { "use strict"; -var Type = __nccwpck_require__(33872); +var Type = __nccwpck_require__(92889); module.exports = new Type('tag:yaml.org,2002:str', { kind: 'scalar', @@ -31365,13 +29916,13 @@ module.exports = new Type('tag:yaml.org,2002:str', { /***/ }), -/***/ 86559: +/***/ 26202: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { "use strict"; -var Type = __nccwpck_require__(33872); +var Type = __nccwpck_require__(92889); var YAML_DATE_REGEXP = new RegExp( '^([0-9][0-9][0-9][0-9])' + // [1] year @@ -31461,7 +30012,7 @@ module.exports = new Type('tag:yaml.org,2002:timestamp', { /***/ }), -/***/ 51697: +/***/ 95141: /***/ (function(__unused_webpack_module, exports) { (function (global, factory) { @@ -31930,7 +30481,7 @@ module.exports = new Type('tag:yaml.org,2002:timestamp', { /***/ }), -/***/ 89761: +/***/ 69241: /***/ (function(__unused_webpack_module, exports) { (function (global, factory) { @@ -37919,7 +36470,7 @@ module.exports = new Type('tag:yaml.org,2002:timestamp', { /***/ }), -/***/ 3537: +/***/ 93799: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { "use strict"; @@ -37966,7 +36517,7 @@ const setLazyProperty = (object, property, get) => { let colorConvert; const makeDynamicStyles = (wrap, targetSpace, identity, isBackground) => { if (colorConvert === undefined) { - colorConvert = __nccwpck_require__(69218); + colorConvert = __nccwpck_require__(79713); } const offset = isBackground ? 10 : 0; @@ -38091,3197 +36642,2620 @@ Object.defineProperty(module, 'exports', { /***/ }), -/***/ 62158: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { +/***/ 69888: +/***/ ((module) => { -/* MIT license */ -/* eslint-disable no-mixed-operators */ -const cssKeywords = __nccwpck_require__(58158); +const flagSymbol = Symbol('arg flag'); -// NOTE: conversions should only return primitive values (i.e. arrays, or -// values that give correct `typeof` results). -// do not use box values types (i.e. Number(), String(), etc.) +function arg(opts, {argv = process.argv.slice(2), permissive = false, stopAtPositional = false} = {}) { + if (!opts) { + throw new Error('Argument specification object is required'); + } -const reverseKeywords = {}; -for (const key of Object.keys(cssKeywords)) { - reverseKeywords[cssKeywords[key]] = key; -} + const result = {_: []}; -const convert = { - rgb: {channels: 3, labels: 'rgb'}, - hsl: {channels: 3, labels: 'hsl'}, - hsv: {channels: 3, labels: 'hsv'}, - hwb: {channels: 3, labels: 'hwb'}, - cmyk: {channels: 4, labels: 'cmyk'}, - xyz: {channels: 3, labels: 'xyz'}, - lab: {channels: 3, labels: 'lab'}, - lch: {channels: 3, labels: 'lch'}, - hex: {channels: 1, labels: ['hex']}, - keyword: {channels: 1, labels: ['keyword']}, - ansi16: {channels: 1, labels: ['ansi16']}, - ansi256: {channels: 1, labels: ['ansi256']}, - hcg: {channels: 3, labels: ['h', 'c', 'g']}, - apple: {channels: 3, labels: ['r16', 'g16', 'b16']}, - gray: {channels: 1, labels: ['gray']} -}; + const aliases = {}; + const handlers = {}; -module.exports = convert; + for (const key of Object.keys(opts)) { + if (!key) { + throw new TypeError('Argument key cannot be an empty string'); + } -// Hide .channels and .labels properties -for (const model of Object.keys(convert)) { - if (!('channels' in convert[model])) { - throw new Error('missing channels property: ' + model); - } + if (key[0] !== '-') { + throw new TypeError(`Argument key must start with '-' but found: '${key}'`); + } - if (!('labels' in convert[model])) { - throw new Error('missing channel labels property: ' + model); - } + if (key.length === 1) { + throw new TypeError(`Argument key must have a name; singular '-' keys are not allowed: ${key}`); + } - if (convert[model].labels.length !== convert[model].channels) { - throw new Error('channel and label counts mismatch: ' + model); - } + if (typeof opts[key] === 'string') { + aliases[key] = opts[key]; + continue; + } - const {channels, labels} = convert[model]; - delete convert[model].channels; - delete convert[model].labels; - Object.defineProperty(convert[model], 'channels', {value: channels}); - Object.defineProperty(convert[model], 'labels', {value: labels}); -} + let type = opts[key]; + let isFlag = false; -convert.rgb.hsl = function (rgb) { - const r = rgb[0] / 255; - const g = rgb[1] / 255; - const b = rgb[2] / 255; - const min = Math.min(r, g, b); - const max = Math.max(r, g, b); - const delta = max - min; - let h; - let s; + if (Array.isArray(type) && type.length === 1 && typeof type[0] === 'function') { + const [fn] = type; + type = (value, name, prev = []) => { + prev.push(fn(value, name, prev[prev.length - 1])); + return prev; + }; + isFlag = fn === Boolean || fn[flagSymbol] === true; + } else if (typeof type === 'function') { + isFlag = type === Boolean || type[flagSymbol] === true; + } else { + throw new TypeError(`Type missing or not a function or valid array type: ${key}`); + } - if (max === min) { - h = 0; - } else if (r === max) { - h = (g - b) / delta; - } else if (g === max) { - h = 2 + (b - r) / delta; - } else if (b === max) { - h = 4 + (r - g) / delta; + if (key[1] !== '-' && key.length > 2) { + throw new TypeError(`Short argument keys (with a single hyphen) must have only one character: ${key}`); + } + + handlers[key] = [type, isFlag]; } - h = Math.min(h * 60, 360); + for (let i = 0, len = argv.length; i < len; i++) { + const wholeArg = argv[i]; - if (h < 0) { - h += 360; - } + if (stopAtPositional && result._.length > 0) { + result._ = result._.concat(argv.slice(i)); + break; + } - const l = (min + max) / 2; + if (wholeArg === '--') { + result._ = result._.concat(argv.slice(i + 1)); + break; + } - if (max === min) { - s = 0; - } else if (l <= 0.5) { - s = delta / (max + min); - } else { - s = delta / (2 - max - min); - } + if (wholeArg.length > 1 && wholeArg[0] === '-') { + /* eslint-disable operator-linebreak */ + const separatedArguments = (wholeArg[1] === '-' || wholeArg.length === 2) + ? [wholeArg] + : wholeArg.slice(1).split('').map(a => `-${a}`); + /* eslint-enable operator-linebreak */ - return [h, s * 100, l * 100]; -}; + for (let j = 0; j < separatedArguments.length; j++) { + const arg = separatedArguments[j]; + const [originalArgName, argStr] = arg[1] === '-' ? arg.split(/=(.*)/, 2) : [arg, undefined]; -convert.rgb.hsv = function (rgb) { - let rdif; - let gdif; - let bdif; - let h; - let s; + let argName = originalArgName; + while (argName in aliases) { + argName = aliases[argName]; + } - const r = rgb[0] / 255; - const g = rgb[1] / 255; - const b = rgb[2] / 255; - const v = Math.max(r, g, b); - const diff = v - Math.min(r, g, b); - const diffc = function (c) { - return (v - c) / 6 / diff + 1 / 2; - }; + if (!(argName in handlers)) { + if (permissive) { + result._.push(arg); + continue; + } else { + const err = new Error(`Unknown or unexpected option: ${originalArgName}`); + err.code = 'ARG_UNKNOWN_OPTION'; + throw err; + } + } - if (diff === 0) { - h = 0; - s = 0; - } else { - s = diff / v; - rdif = diffc(r); - gdif = diffc(g); - bdif = diffc(b); + const [type, isFlag] = handlers[argName]; - if (r === v) { - h = bdif - gdif; - } else if (g === v) { - h = (1 / 3) + rdif - bdif; - } else if (b === v) { - h = (2 / 3) + gdif - rdif; - } + if (!isFlag && ((j + 1) < separatedArguments.length)) { + throw new TypeError(`Option requires argument (but was followed by another short argument): ${originalArgName}`); + } - if (h < 0) { - h += 1; - } else if (h > 1) { - h -= 1; + if (isFlag) { + result[argName] = type(true, argName, result[argName]); + } else if (argStr === undefined) { + if ( + argv.length < i + 2 || + ( + argv[i + 1].length > 1 && + (argv[i + 1][0] === '-') && + !( + argv[i + 1].match(/^-?\d*(\.(?=\d))?\d*$/) && + ( + type === Number || + // eslint-disable-next-line no-undef + (typeof BigInt !== 'undefined' && type === BigInt) + ) + ) + ) + ) { + const extended = originalArgName === argName ? '' : ` (alias for ${argName})`; + throw new Error(`Option requires argument: ${originalArgName}${extended}`); + } + + result[argName] = type(argv[i + 1], argName, result[argName]); + ++i; + } else { + result[argName] = type(argStr, argName, result[argName]); + } + } + } else { + result._.push(wholeArg); } } - return [ - h * 360, - s * 100, - v * 100 - ]; + return result; +} + +arg.flag = fn => { + fn[flagSymbol] = true; + return fn; }; -convert.rgb.hwb = function (rgb) { - const r = rgb[0]; - const g = rgb[1]; - let b = rgb[2]; - const h = convert.rgb.hsl(rgb)[0]; - const w = 1 / 255 * Math.min(r, Math.min(g, b)); +// Utility types +arg.COUNT = arg.flag((v, name, existingCount) => (existingCount || 0) + 1); - b = 1 - 1 / 255 * Math.max(r, Math.max(g, b)); +module.exports = arg; - return [h, w * 100, b * 100]; -}; -convert.rgb.cmyk = function (rgb) { - const r = rgb[0] / 255; - const g = rgb[1] / 255; - const b = rgb[2] / 255; +/***/ }), - const k = Math.min(1 - r, 1 - g, 1 - b); - const c = (1 - r - k) / (1 - k) || 0; - const m = (1 - g - k) / (1 - k) || 0; - const y = (1 - b - k) / (1 - k) || 0; +/***/ 77524: +/***/ ((module) => { - return [c * 100, m * 100, y * 100, k * 100]; -}; +"use strict"; -function comparativeDistance(x, y) { - /* - See https://en.m.wikipedia.org/wiki/Euclidean_distance#Squared_Euclidean_distance - */ - return ( - ((x[0] - y[0]) ** 2) + - ((x[1] - y[1]) ** 2) + - ((x[2] - y[2]) ** 2) - ); -} +module.exports = balanced; +function balanced(a, b, str) { + if (a instanceof RegExp) a = maybeMatch(a, str); + if (b instanceof RegExp) b = maybeMatch(b, str); -convert.rgb.keyword = function (rgb) { - const reversed = reverseKeywords[rgb]; - if (reversed) { - return reversed; - } + var r = range(a, b, str); - let currentClosestDistance = Infinity; - let currentClosestKeyword; + return r && { + start: r[0], + end: r[1], + pre: str.slice(0, r[0]), + body: str.slice(r[0] + a.length, r[1]), + post: str.slice(r[1] + b.length) + }; +} - for (const keyword of Object.keys(cssKeywords)) { - const value = cssKeywords[keyword]; +function maybeMatch(reg, str) { + var m = str.match(reg); + return m ? m[0] : null; +} - // Compute comparative distance - const distance = comparativeDistance(rgb, value); +balanced.range = range; +function range(a, b, str) { + var begs, beg, left, right, result; + var ai = str.indexOf(a); + var bi = str.indexOf(b, ai + 1); + var i = ai; - // Check if its less, if so set as closest - if (distance < currentClosestDistance) { - currentClosestDistance = distance; - currentClosestKeyword = keyword; - } - } + if (ai >= 0 && bi > 0) { + if(a===b) { + return [ai, bi]; + } + begs = []; + left = str.length; - return currentClosestKeyword; -}; + while (i >= 0 && !result) { + if (i == ai) { + begs.push(i); + ai = str.indexOf(a, i + 1); + } else if (begs.length == 1) { + result = [ begs.pop(), bi ]; + } else { + beg = begs.pop(); + if (beg < left) { + left = beg; + right = bi; + } -convert.keyword.rgb = function (keyword) { - return cssKeywords[keyword]; -}; + bi = str.indexOf(b, i + 1); + } -convert.rgb.xyz = function (rgb) { - let r = rgb[0] / 255; - let g = rgb[1] / 255; - let b = rgb[2] / 255; + i = ai < bi && ai >= 0 ? ai : bi; + } - // Assume sRGB - r = r > 0.04045 ? (((r + 0.055) / 1.055) ** 2.4) : (r / 12.92); - g = g > 0.04045 ? (((g + 0.055) / 1.055) ** 2.4) : (g / 12.92); - b = b > 0.04045 ? (((b + 0.055) / 1.055) ** 2.4) : (b / 12.92); + if (begs.length) { + result = [ left, right ]; + } + } - const x = (r * 0.4124) + (g * 0.3576) + (b * 0.1805); - const y = (r * 0.2126) + (g * 0.7152) + (b * 0.0722); - const z = (r * 0.0193) + (g * 0.1192) + (b * 0.9505); + return result; +} - return [x * 100, y * 100, z * 100]; -}; -convert.rgb.lab = function (rgb) { - const xyz = convert.rgb.xyz(rgb); - let x = xyz[0]; - let y = xyz[1]; - let z = xyz[2]; +/***/ }), - x /= 95.047; - y /= 100; - z /= 108.883; +/***/ 43858: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { - x = x > 0.008856 ? (x ** (1 / 3)) : (7.787 * x) + (16 / 116); - y = y > 0.008856 ? (y ** (1 / 3)) : (7.787 * y) + (16 / 116); - z = z > 0.008856 ? (z ** (1 / 3)) : (7.787 * z) + (16 / 116); +"use strict"; - const l = (116 * y) - 16; - const a = 500 * (x - y); - const b = 200 * (y - z); - return [l, a, b]; -}; +const { Buffer } = __nccwpck_require__(14300) +const symbol = Symbol.for('BufferList') -convert.hsl.rgb = function (hsl) { - const h = hsl[0] / 360; - const s = hsl[1] / 100; - const l = hsl[2] / 100; - let t2; - let t3; - let val; +function BufferList (buf) { + if (!(this instanceof BufferList)) { + return new BufferList(buf) + } - if (s === 0) { - val = l * 255; - return [val, val, val]; - } + BufferList._init.call(this, buf) +} - if (l < 0.5) { - t2 = l * (1 + s); - } else { - t2 = l + s - l * s; - } +BufferList._init = function _init (buf) { + Object.defineProperty(this, symbol, { value: true }) - const t1 = 2 * l - t2; + this._bufs = [] + this.length = 0 - const rgb = [0, 0, 0]; - for (let i = 0; i < 3; i++) { - t3 = h + 1 / 3 * -(i - 1); - if (t3 < 0) { - t3++; - } + if (buf) { + this.append(buf) + } +} - if (t3 > 1) { - t3--; - } +BufferList.prototype._new = function _new (buf) { + return new BufferList(buf) +} - if (6 * t3 < 1) { - val = t1 + (t2 - t1) * 6 * t3; - } else if (2 * t3 < 1) { - val = t2; - } else if (3 * t3 < 2) { - val = t1 + (t2 - t1) * (2 / 3 - t3) * 6; - } else { - val = t1; - } +BufferList.prototype._offset = function _offset (offset) { + if (offset === 0) { + return [0, 0] + } - rgb[i] = val * 255; - } + let tot = 0 - return rgb; -}; + for (let i = 0; i < this._bufs.length; i++) { + const _t = tot + this._bufs[i].length + if (offset < _t || i === this._bufs.length - 1) { + return [i, offset - tot] + } + tot = _t + } +} -convert.hsl.hsv = function (hsl) { - const h = hsl[0]; - let s = hsl[1] / 100; - let l = hsl[2] / 100; - let smin = s; - const lmin = Math.max(l, 0.01); +BufferList.prototype._reverseOffset = function (blOffset) { + const bufferId = blOffset[0] + let offset = blOffset[1] - l *= 2; - s *= (l <= 1) ? l : 2 - l; - smin *= lmin <= 1 ? lmin : 2 - lmin; - const v = (l + s) / 2; - const sv = l === 0 ? (2 * smin) / (lmin + smin) : (2 * s) / (l + s); + for (let i = 0; i < bufferId; i++) { + offset += this._bufs[i].length + } - return [h, sv * 100, v * 100]; -}; + return offset +} -convert.hsv.rgb = function (hsv) { - const h = hsv[0] / 60; - const s = hsv[1] / 100; - let v = hsv[2] / 100; - const hi = Math.floor(h) % 6; +BufferList.prototype.get = function get (index) { + if (index > this.length || index < 0) { + return undefined + } - const f = h - Math.floor(h); - const p = 255 * v * (1 - s); - const q = 255 * v * (1 - (s * f)); - const t = 255 * v * (1 - (s * (1 - f))); - v *= 255; + const offset = this._offset(index) - switch (hi) { - case 0: - return [v, t, p]; - case 1: - return [q, v, p]; - case 2: - return [p, v, t]; - case 3: - return [p, q, v]; - case 4: - return [t, p, v]; - case 5: - return [v, p, q]; - } -}; + return this._bufs[offset[0]][offset[1]] +} -convert.hsv.hsl = function (hsv) { - const h = hsv[0]; - const s = hsv[1] / 100; - const v = hsv[2] / 100; - const vmin = Math.max(v, 0.01); - let sl; - let l; +BufferList.prototype.slice = function slice (start, end) { + if (typeof start === 'number' && start < 0) { + start += this.length + } - l = (2 - s) * v; - const lmin = (2 - s) * vmin; - sl = s * vmin; - sl /= (lmin <= 1) ? lmin : 2 - lmin; - sl = sl || 0; - l /= 2; + if (typeof end === 'number' && end < 0) { + end += this.length + } - return [h, sl * 100, l * 100]; -}; + return this.copy(null, 0, start, end) +} -// http://dev.w3.org/csswg/css-color/#hwb-to-rgb -convert.hwb.rgb = function (hwb) { - const h = hwb[0] / 360; - let wh = hwb[1] / 100; - let bl = hwb[2] / 100; - const ratio = wh + bl; - let f; +BufferList.prototype.copy = function copy (dst, dstStart, srcStart, srcEnd) { + if (typeof srcStart !== 'number' || srcStart < 0) { + srcStart = 0 + } - // Wh + bl cant be > 1 - if (ratio > 1) { - wh /= ratio; - bl /= ratio; - } + if (typeof srcEnd !== 'number' || srcEnd > this.length) { + srcEnd = this.length + } - const i = Math.floor(6 * h); - const v = 1 - bl; - f = 6 * h - i; + if (srcStart >= this.length) { + return dst || Buffer.alloc(0) + } - if ((i & 0x01) !== 0) { - f = 1 - f; - } + if (srcEnd <= 0) { + return dst || Buffer.alloc(0) + } - const n = wh + f * (v - wh); // Linear interpolation + const copy = !!dst + const off = this._offset(srcStart) + const len = srcEnd - srcStart + let bytes = len + let bufoff = (copy && dstStart) || 0 + let start = off[1] - let r; - let g; - let b; - /* eslint-disable max-statements-per-line,no-multi-spaces */ - switch (i) { - default: - case 6: - case 0: r = v; g = n; b = wh; break; - case 1: r = n; g = v; b = wh; break; - case 2: r = wh; g = v; b = n; break; - case 3: r = wh; g = n; b = v; break; - case 4: r = n; g = wh; b = v; break; - case 5: r = v; g = wh; b = n; break; - } - /* eslint-enable max-statements-per-line,no-multi-spaces */ + // copy/slice everything + if (srcStart === 0 && srcEnd === this.length) { + if (!copy) { + // slice, but full concat if multiple buffers + return this._bufs.length === 1 + ? this._bufs[0] + : Buffer.concat(this._bufs, this.length) + } - return [r * 255, g * 255, b * 255]; -}; + // copy, need to copy individual buffers + for (let i = 0; i < this._bufs.length; i++) { + this._bufs[i].copy(dst, bufoff) + bufoff += this._bufs[i].length + } -convert.cmyk.rgb = function (cmyk) { - const c = cmyk[0] / 100; - const m = cmyk[1] / 100; - const y = cmyk[2] / 100; - const k = cmyk[3] / 100; + return dst + } - const r = 1 - Math.min(1, c * (1 - k) + k); - const g = 1 - Math.min(1, m * (1 - k) + k); - const b = 1 - Math.min(1, y * (1 - k) + k); + // easy, cheap case where it's a subset of one of the buffers + if (bytes <= this._bufs[off[0]].length - start) { + return copy + ? this._bufs[off[0]].copy(dst, dstStart, start, start + bytes) + : this._bufs[off[0]].slice(start, start + bytes) + } - return [r * 255, g * 255, b * 255]; -}; + if (!copy) { + // a slice, we need something to copy in to + dst = Buffer.allocUnsafe(len) + } -convert.xyz.rgb = function (xyz) { - const x = xyz[0] / 100; - const y = xyz[1] / 100; - const z = xyz[2] / 100; - let r; - let g; - let b; + for (let i = off[0]; i < this._bufs.length; i++) { + const l = this._bufs[i].length - start - r = (x * 3.2406) + (y * -1.5372) + (z * -0.4986); - g = (x * -0.9689) + (y * 1.8758) + (z * 0.0415); - b = (x * 0.0557) + (y * -0.2040) + (z * 1.0570); + if (bytes > l) { + this._bufs[i].copy(dst, bufoff, start) + bufoff += l + } else { + this._bufs[i].copy(dst, bufoff, start, start + bytes) + bufoff += l + break + } - // Assume sRGB - r = r > 0.0031308 - ? ((1.055 * (r ** (1.0 / 2.4))) - 0.055) - : r * 12.92; + bytes -= l - g = g > 0.0031308 - ? ((1.055 * (g ** (1.0 / 2.4))) - 0.055) - : g * 12.92; + if (start) { + start = 0 + } + } - b = b > 0.0031308 - ? ((1.055 * (b ** (1.0 / 2.4))) - 0.055) - : b * 12.92; + // safeguard so that we don't return uninitialized memory + if (dst.length > bufoff) return dst.slice(0, bufoff) - r = Math.min(Math.max(0, r), 1); - g = Math.min(Math.max(0, g), 1); - b = Math.min(Math.max(0, b), 1); + return dst +} - return [r * 255, g * 255, b * 255]; -}; +BufferList.prototype.shallowSlice = function shallowSlice (start, end) { + start = start || 0 + end = typeof end !== 'number' ? this.length : end -convert.xyz.lab = function (xyz) { - let x = xyz[0]; - let y = xyz[1]; - let z = xyz[2]; + if (start < 0) { + start += this.length + } - x /= 95.047; - y /= 100; - z /= 108.883; + if (end < 0) { + end += this.length + } - x = x > 0.008856 ? (x ** (1 / 3)) : (7.787 * x) + (16 / 116); - y = y > 0.008856 ? (y ** (1 / 3)) : (7.787 * y) + (16 / 116); - z = z > 0.008856 ? (z ** (1 / 3)) : (7.787 * z) + (16 / 116); + if (start === end) { + return this._new() + } - const l = (116 * y) - 16; - const a = 500 * (x - y); - const b = 200 * (y - z); + const startOffset = this._offset(start) + const endOffset = this._offset(end) + const buffers = this._bufs.slice(startOffset[0], endOffset[0] + 1) - return [l, a, b]; -}; + if (endOffset[1] === 0) { + buffers.pop() + } else { + buffers[buffers.length - 1] = buffers[buffers.length - 1].slice(0, endOffset[1]) + } -convert.lab.xyz = function (lab) { - const l = lab[0]; - const a = lab[1]; - const b = lab[2]; - let x; - let y; - let z; + if (startOffset[1] !== 0) { + buffers[0] = buffers[0].slice(startOffset[1]) + } - y = (l + 16) / 116; - x = a / 500 + y; - z = y - b / 200; + return this._new(buffers) +} - const y2 = y ** 3; - const x2 = x ** 3; - const z2 = z ** 3; - y = y2 > 0.008856 ? y2 : (y - 16 / 116) / 7.787; - x = x2 > 0.008856 ? x2 : (x - 16 / 116) / 7.787; - z = z2 > 0.008856 ? z2 : (z - 16 / 116) / 7.787; +BufferList.prototype.toString = function toString (encoding, start, end) { + return this.slice(start, end).toString(encoding) +} - x *= 95.047; - y *= 100; - z *= 108.883; +BufferList.prototype.consume = function consume (bytes) { + // first, normalize the argument, in accordance with how Buffer does it + bytes = Math.trunc(bytes) + // do nothing if not a positive number + if (Number.isNaN(bytes) || bytes <= 0) return this - return [x, y, z]; -}; + while (this._bufs.length) { + if (bytes >= this._bufs[0].length) { + bytes -= this._bufs[0].length + this.length -= this._bufs[0].length + this._bufs.shift() + } else { + this._bufs[0] = this._bufs[0].slice(bytes) + this.length -= bytes + break + } + } -convert.lab.lch = function (lab) { - const l = lab[0]; - const a = lab[1]; - const b = lab[2]; - let h; + return this +} - const hr = Math.atan2(b, a); - h = hr * 360 / 2 / Math.PI; +BufferList.prototype.duplicate = function duplicate () { + const copy = this._new() - if (h < 0) { - h += 360; - } + for (let i = 0; i < this._bufs.length; i++) { + copy.append(this._bufs[i]) + } - const c = Math.sqrt(a * a + b * b); + return copy +} - return [l, c, h]; -}; +BufferList.prototype.append = function append (buf) { + if (buf == null) { + return this + } -convert.lch.lab = function (lch) { - const l = lch[0]; - const c = lch[1]; - const h = lch[2]; + if (buf.buffer) { + // append a view of the underlying ArrayBuffer + this._appendBuffer(Buffer.from(buf.buffer, buf.byteOffset, buf.byteLength)) + } else if (Array.isArray(buf)) { + for (let i = 0; i < buf.length; i++) { + this.append(buf[i]) + } + } else if (this._isBufferList(buf)) { + // unwrap argument into individual BufferLists + for (let i = 0; i < buf._bufs.length; i++) { + this.append(buf._bufs[i]) + } + } else { + // coerce number arguments to strings, since Buffer(number) does + // uninitialized memory allocation + if (typeof buf === 'number') { + buf = buf.toString() + } - const hr = h / 360 * 2 * Math.PI; - const a = c * Math.cos(hr); - const b = c * Math.sin(hr); + this._appendBuffer(Buffer.from(buf)) + } - return [l, a, b]; -}; + return this +} -convert.rgb.ansi16 = function (args, saturation = null) { - const [r, g, b] = args; - let value = saturation === null ? convert.rgb.hsv(args)[2] : saturation; // Hsv -> ansi16 optimization +BufferList.prototype._appendBuffer = function appendBuffer (buf) { + this._bufs.push(buf) + this.length += buf.length +} - value = Math.round(value / 50); +BufferList.prototype.indexOf = function (search, offset, encoding) { + if (encoding === undefined && typeof offset === 'string') { + encoding = offset + offset = undefined + } - if (value === 0) { - return 30; - } + if (typeof search === 'function' || Array.isArray(search)) { + throw new TypeError('The "value" argument must be one of type string, Buffer, BufferList, or Uint8Array.') + } else if (typeof search === 'number') { + search = Buffer.from([search]) + } else if (typeof search === 'string') { + search = Buffer.from(search, encoding) + } else if (this._isBufferList(search)) { + search = search.slice() + } else if (Array.isArray(search.buffer)) { + search = Buffer.from(search.buffer, search.byteOffset, search.byteLength) + } else if (!Buffer.isBuffer(search)) { + search = Buffer.from(search) + } - let ansi = 30 - + ((Math.round(b / 255) << 2) - | (Math.round(g / 255) << 1) - | Math.round(r / 255)); + offset = Number(offset || 0) - if (value === 2) { - ansi += 60; - } + if (isNaN(offset)) { + offset = 0 + } - return ansi; -}; + if (offset < 0) { + offset = this.length + offset + } -convert.hsv.ansi16 = function (args) { - // Optimization here; we already know the value and don't need to get - // it converted for us. - return convert.rgb.ansi16(convert.hsv.rgb(args), args[2]); -}; + if (offset < 0) { + offset = 0 + } -convert.rgb.ansi256 = function (args) { - const r = args[0]; - const g = args[1]; - const b = args[2]; + if (search.length === 0) { + return offset > this.length ? this.length : offset + } - // We use the extended greyscale palette here, with the exception of - // black and white. normal palette only has 4 greyscale shades. - if (r === g && g === b) { - if (r < 8) { - return 16; - } + const blOffset = this._offset(offset) + let blIndex = blOffset[0] // index of which internal buffer we're working on + let buffOffset = blOffset[1] // offset of the internal buffer we're working on - if (r > 248) { - return 231; - } + // scan over each buffer + for (; blIndex < this._bufs.length; blIndex++) { + const buff = this._bufs[blIndex] - return Math.round(((r - 8) / 247) * 24) + 232; - } + while (buffOffset < buff.length) { + const availableWindow = buff.length - buffOffset - const ansi = 16 - + (36 * Math.round(r / 255 * 5)) - + (6 * Math.round(g / 255 * 5)) - + Math.round(b / 255 * 5); + if (availableWindow >= search.length) { + const nativeSearchResult = buff.indexOf(search, buffOffset) - return ansi; -}; + if (nativeSearchResult !== -1) { + return this._reverseOffset([blIndex, nativeSearchResult]) + } -convert.ansi16.rgb = function (args) { - let color = args % 10; + buffOffset = buff.length - search.length + 1 // end of native search window + } else { + const revOffset = this._reverseOffset([blIndex, buffOffset]) - // Handle greyscale - if (color === 0 || color === 7) { - if (args > 50) { - color += 3.5; - } + if (this._match(revOffset, search)) { + return revOffset + } - color = color / 10.5 * 255; + buffOffset++ + } + } - return [color, color, color]; - } + buffOffset = 0 + } - const mult = (~~(args > 50) + 1) * 0.5; - const r = ((color & 1) * mult) * 255; - const g = (((color >> 1) & 1) * mult) * 255; - const b = (((color >> 2) & 1) * mult) * 255; + return -1 +} - return [r, g, b]; -}; +BufferList.prototype._match = function (offset, search) { + if (this.length - offset < search.length) { + return false + } -convert.ansi256.rgb = function (args) { - // Handle greyscale - if (args >= 232) { - const c = (args - 232) * 10 + 8; - return [c, c, c]; - } + for (let searchOffset = 0; searchOffset < search.length; searchOffset++) { + if (this.get(offset + searchOffset) !== search[searchOffset]) { + return false + } + } + return true +} - args -= 16; +;(function () { + const methods = { + readDoubleBE: 8, + readDoubleLE: 8, + readFloatBE: 4, + readFloatLE: 4, + readInt32BE: 4, + readInt32LE: 4, + readUInt32BE: 4, + readUInt32LE: 4, + readInt16BE: 2, + readInt16LE: 2, + readUInt16BE: 2, + readUInt16LE: 2, + readInt8: 1, + readUInt8: 1, + readIntBE: null, + readIntLE: null, + readUIntBE: null, + readUIntLE: null + } - let rem; - const r = Math.floor(args / 36) / 5 * 255; - const g = Math.floor((rem = args % 36) / 6) / 5 * 255; - const b = (rem % 6) / 5 * 255; + for (const m in methods) { + (function (m) { + if (methods[m] === null) { + BufferList.prototype[m] = function (offset, byteLength) { + return this.slice(offset, offset + byteLength)[m](0, byteLength) + } + } else { + BufferList.prototype[m] = function (offset = 0) { + return this.slice(offset, offset + methods[m])[m](0) + } + } + }(m)) + } +}()) - return [r, g, b]; -}; +// Used internally by the class and also as an indicator of this object being +// a `BufferList`. It's not possible to use `instanceof BufferList` in a browser +// environment because there could be multiple different copies of the +// BufferList class and some `BufferList`s might be `BufferList`s. +BufferList.prototype._isBufferList = function _isBufferList (b) { + return b instanceof BufferList || BufferList.isBufferList(b) +} -convert.rgb.hex = function (args) { - const integer = ((Math.round(args[0]) & 0xFF) << 16) - + ((Math.round(args[1]) & 0xFF) << 8) - + (Math.round(args[2]) & 0xFF); +BufferList.isBufferList = function isBufferList (b) { + return b != null && b[symbol] +} - const string = integer.toString(16).toUpperCase(); - return '000000'.substring(string.length) + string; -}; +module.exports = BufferList -convert.hex.rgb = function (args) { - const match = args.toString(16).match(/[a-f0-9]{6}|[a-f0-9]{3}/i); - if (!match) { - return [0, 0, 0]; - } - let colorString = match[0]; +/***/ }), - if (match[0].length === 3) { - colorString = colorString.split('').map(char => { - return char + char; - }).join(''); - } +/***/ 82489: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { - const integer = parseInt(colorString, 16); - const r = (integer >> 16) & 0xFF; - const g = (integer >> 8) & 0xFF; - const b = integer & 0xFF; +"use strict"; - return [r, g, b]; -}; -convert.rgb.hcg = function (rgb) { - const r = rgb[0] / 255; - const g = rgb[1] / 255; - const b = rgb[2] / 255; - const max = Math.max(Math.max(r, g), b); - const min = Math.min(Math.min(r, g), b); - const chroma = (max - min); - let grayscale; - let hue; +const DuplexStream = (__nccwpck_require__(17067).Duplex) +const inherits = __nccwpck_require__(76401) +const BufferList = __nccwpck_require__(43858) - if (chroma < 1) { - grayscale = min / (1 - chroma); - } else { - grayscale = 0; - } +function BufferListStream (callback) { + if (!(this instanceof BufferListStream)) { + return new BufferListStream(callback) + } - if (chroma <= 0) { - hue = 0; - } else - if (max === r) { - hue = ((g - b) / chroma) % 6; - } else - if (max === g) { - hue = 2 + (b - r) / chroma; - } else { - hue = 4 + (r - g) / chroma; - } - - hue /= 6; - hue %= 1; + if (typeof callback === 'function') { + this._callback = callback - return [hue * 360, chroma * 100, grayscale * 100]; -}; + const piper = function piper (err) { + if (this._callback) { + this._callback(err) + this._callback = null + } + }.bind(this) -convert.hsl.hcg = function (hsl) { - const s = hsl[1] / 100; - const l = hsl[2] / 100; + this.on('pipe', function onPipe (src) { + src.on('error', piper) + }) + this.on('unpipe', function onUnpipe (src) { + src.removeListener('error', piper) + }) - const c = l < 0.5 ? (2.0 * s * l) : (2.0 * s * (1.0 - l)); + callback = null + } - let f = 0; - if (c < 1.0) { - f = (l - 0.5 * c) / (1.0 - c); - } + BufferList._init.call(this, callback) + DuplexStream.call(this) +} - return [hsl[0], c * 100, f * 100]; -}; +inherits(BufferListStream, DuplexStream) +Object.assign(BufferListStream.prototype, BufferList.prototype) -convert.hsv.hcg = function (hsv) { - const s = hsv[1] / 100; - const v = hsv[2] / 100; +BufferListStream.prototype._new = function _new (callback) { + return new BufferListStream(callback) +} - const c = s * v; - let f = 0; +BufferListStream.prototype._write = function _write (buf, encoding, callback) { + this._appendBuffer(buf) - if (c < 1.0) { - f = (v - c) / (1 - c); - } + if (typeof callback === 'function') { + callback() + } +} - return [hsv[0], c * 100, f * 100]; -}; +BufferListStream.prototype._read = function _read (size) { + if (!this.length) { + return this.push(null) + } -convert.hcg.rgb = function (hcg) { - const h = hcg[0] / 360; - const c = hcg[1] / 100; - const g = hcg[2] / 100; + size = Math.min(size, this.length) + this.push(this.slice(0, size)) + this.consume(size) +} - if (c === 0.0) { - return [g * 255, g * 255, g * 255]; - } +BufferListStream.prototype.end = function end (chunk) { + DuplexStream.prototype.end.call(this, chunk) - const pure = [0, 0, 0]; - const hi = (h % 1) * 6; - const v = hi % 1; - const w = 1 - v; - let mg = 0; + if (this._callback) { + this._callback(null, this.slice()) + this._callback = null + } +} - /* eslint-disable max-statements-per-line */ - switch (Math.floor(hi)) { - case 0: - pure[0] = 1; pure[1] = v; pure[2] = 0; break; - case 1: - pure[0] = w; pure[1] = 1; pure[2] = 0; break; - case 2: - pure[0] = 0; pure[1] = 1; pure[2] = v; break; - case 3: - pure[0] = 0; pure[1] = w; pure[2] = 1; break; - case 4: - pure[0] = v; pure[1] = 0; pure[2] = 1; break; - default: - pure[0] = 1; pure[1] = 0; pure[2] = w; - } - /* eslint-enable max-statements-per-line */ +BufferListStream.prototype._destroy = function _destroy (err, cb) { + this._bufs.length = 0 + this.length = 0 + cb(err) +} - mg = (1.0 - c) * g; +BufferListStream.prototype._isBufferList = function _isBufferList (b) { + return b instanceof BufferListStream || b instanceof BufferList || BufferListStream.isBufferList(b) +} - return [ - (c * pure[0] + mg) * 255, - (c * pure[1] + mg) * 255, - (c * pure[2] + mg) * 255 - ]; -}; +BufferListStream.isBufferList = BufferList.isBufferList -convert.hcg.hsv = function (hcg) { - const c = hcg[1] / 100; - const g = hcg[2] / 100; +module.exports = BufferListStream +module.exports.BufferListStream = BufferListStream +module.exports.BufferList = BufferList - const v = c + g * (1.0 - c); - let f = 0; - if (v > 0.0) { - f = c / v; - } +/***/ }), - return [hcg[0], f * 100, v * 100]; -}; +/***/ 82548: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { -convert.hcg.hsl = function (hcg) { - const c = hcg[1] / 100; - const g = hcg[2] / 100; +var balanced = __nccwpck_require__(77524); - const l = g * (1.0 - c) + 0.5 * c; - let s = 0; +module.exports = expandTop; - if (l > 0.0 && l < 0.5) { - s = c / (2 * l); - } else - if (l >= 0.5 && l < 1.0) { - s = c / (2 * (1 - l)); - } +var escSlash = '\0SLASH'+Math.random()+'\0'; +var escOpen = '\0OPEN'+Math.random()+'\0'; +var escClose = '\0CLOSE'+Math.random()+'\0'; +var escComma = '\0COMMA'+Math.random()+'\0'; +var escPeriod = '\0PERIOD'+Math.random()+'\0'; - return [hcg[0], s * 100, l * 100]; -}; +function numeric(str) { + return parseInt(str, 10) == str + ? parseInt(str, 10) + : str.charCodeAt(0); +} -convert.hcg.hwb = function (hcg) { - const c = hcg[1] / 100; - const g = hcg[2] / 100; - const v = c + g * (1.0 - c); - return [hcg[0], (v - c) * 100, (1 - v) * 100]; -}; +function escapeBraces(str) { + return str.split('\\\\').join(escSlash) + .split('\\{').join(escOpen) + .split('\\}').join(escClose) + .split('\\,').join(escComma) + .split('\\.').join(escPeriod); +} -convert.hwb.hcg = function (hwb) { - const w = hwb[1] / 100; - const b = hwb[2] / 100; - const v = 1 - b; - const c = v - w; - let g = 0; +function unescapeBraces(str) { + return str.split(escSlash).join('\\') + .split(escOpen).join('{') + .split(escClose).join('}') + .split(escComma).join(',') + .split(escPeriod).join('.'); +} - if (c < 1) { - g = (v - c) / (1 - c); - } - return [hwb[0], c * 100, g * 100]; -}; +// Basically just str.split(","), but handling cases +// where we have nested braced sections, which should be +// treated as individual members, like {a,{b,c},d} +function parseCommaParts(str) { + if (!str) + return ['']; -convert.apple.rgb = function (apple) { - return [(apple[0] / 65535) * 255, (apple[1] / 65535) * 255, (apple[2] / 65535) * 255]; -}; + var parts = []; + var m = balanced('{', '}', str); -convert.rgb.apple = function (rgb) { - return [(rgb[0] / 255) * 65535, (rgb[1] / 255) * 65535, (rgb[2] / 255) * 65535]; -}; + if (!m) + return str.split(','); -convert.gray.rgb = function (args) { - return [args[0] / 100 * 255, args[0] / 100 * 255, args[0] / 100 * 255]; -}; + var pre = m.pre; + var body = m.body; + var post = m.post; + var p = pre.split(','); -convert.gray.hsl = function (args) { - return [0, 0, args[0]]; -}; + p[p.length-1] += '{' + body + '}'; + var postParts = parseCommaParts(post); + if (post.length) { + p[p.length-1] += postParts.shift(); + p.push.apply(p, postParts); + } -convert.gray.hsv = convert.gray.hsl; + parts.push.apply(parts, p); -convert.gray.hwb = function (gray) { - return [0, 100, gray[0]]; -}; + return parts; +} -convert.gray.cmyk = function (gray) { - return [0, 0, 0, gray[0]]; -}; +function expandTop(str) { + if (!str) + return []; -convert.gray.lab = function (gray) { - return [gray[0], 0, 0]; -}; + // I don't know why Bash 4.3 does this, but it does. + // Anything starting with {} will have the first two bytes preserved + // but *only* at the top level, so {},a}b will not expand to anything, + // but a{},b}c will be expanded to [a}c,abc]. + // One could argue that this is a bug in Bash, but since the goal of + // this module is to match Bash's rules, we escape a leading {} + if (str.substr(0, 2) === '{}') { + str = '\\{\\}' + str.substr(2); + } -convert.gray.hex = function (gray) { - const val = Math.round(gray[0] / 100 * 255) & 0xFF; - const integer = (val << 16) + (val << 8) + val; + return expand(escapeBraces(str), true).map(unescapeBraces); +} - const string = integer.toString(16).toUpperCase(); - return '000000'.substring(string.length) + string; -}; +function embrace(str) { + return '{' + str + '}'; +} +function isPadded(el) { + return /^-?0\d/.test(el); +} -convert.rgb.gray = function (rgb) { - const val = (rgb[0] + rgb[1] + rgb[2]) / 3; - return [val / 255 * 100]; -}; +function lte(i, y) { + return i <= y; +} +function gte(i, y) { + return i >= y; +} +function expand(str, isTop) { + var expansions = []; -/***/ }), + var m = balanced('{', '}', str); + if (!m) return [str]; -/***/ 69218: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + // no need to expand pre, since it is guaranteed to be free of brace-sets + var pre = m.pre; + var post = m.post.length + ? expand(m.post, false) + : ['']; -const conversions = __nccwpck_require__(62158); -const route = __nccwpck_require__(20694); + if (/\$$/.test(m.pre)) { + for (var k = 0; k < post.length; k++) { + var expansion = pre+ '{' + m.body + '}' + post[k]; + expansions.push(expansion); + } + } else { + var isNumericSequence = /^-?\d+\.\.-?\d+(?:\.\.-?\d+)?$/.test(m.body); + var isAlphaSequence = /^[a-zA-Z]\.\.[a-zA-Z](?:\.\.-?\d+)?$/.test(m.body); + var isSequence = isNumericSequence || isAlphaSequence; + var isOptions = m.body.indexOf(',') >= 0; + if (!isSequence && !isOptions) { + // {a},b} + if (m.post.match(/,.*\}/)) { + str = m.pre + '{' + m.body + escClose + m.post; + return expand(str); + } + return [str]; + } + + var n; + if (isSequence) { + n = m.body.split(/\.\./); + } else { + n = parseCommaParts(m.body); + if (n.length === 1) { + // x{{a,b}}y ==> x{a}y x{b}y + n = expand(n[0], false).map(embrace); + if (n.length === 1) { + return post.map(function(p) { + return m.pre + n[0] + p; + }); + } + } + } -const convert = {}; + // at this point, n is the parts, and we know it's not a comma set + // with a single entry. + var N; -const models = Object.keys(conversions); + if (isSequence) { + var x = numeric(n[0]); + var y = numeric(n[1]); + var width = Math.max(n[0].length, n[1].length) + var incr = n.length == 3 + ? Math.abs(numeric(n[2])) + : 1; + var test = lte; + var reverse = y < x; + if (reverse) { + incr *= -1; + test = gte; + } + var pad = n.some(isPadded); -function wrapRaw(fn) { - const wrappedFn = function (...args) { - const arg0 = args[0]; - if (arg0 === undefined || arg0 === null) { - return arg0; - } + N = []; - if (arg0.length > 1) { - args = arg0; - } + for (var i = x; test(i, y); i += incr) { + var c; + if (isAlphaSequence) { + c = String.fromCharCode(i); + if (c === '\\') + c = ''; + } else { + c = String(i); + if (pad) { + var need = width - c.length; + if (need > 0) { + var z = new Array(need + 1).join('0'); + if (i < 0) + c = '-' + z + c.slice(1); + else + c = z + c; + } + } + } + N.push(c); + } + } else { + N = []; - return fn(args); - }; + for (var j = 0; j < n.length; j++) { + N.push.apply(N, expand(n[j], false)); + } + } - // Preserve .conversion property if there is one - if ('conversion' in fn) { - wrappedFn.conversion = fn.conversion; - } + for (var j = 0; j < N.length; j++) { + for (var k = 0; k < post.length; k++) { + var expansion = pre + N[j] + post[k]; + if (!isTop || isSequence || expansion) + expansions.push(expansion); + } + } + } - return wrappedFn; + return expansions; } -function wrapRounded(fn) { - const wrappedFn = function (...args) { - const arg0 = args[0]; - if (arg0 === undefined || arg0 === null) { - return arg0; - } - if (arg0.length > 1) { - args = arg0; - } +/***/ }), - const result = fn(args); +/***/ 11720: +/***/ ((module) => { - // We're assuming the result is an array here. - // see notice in conversions.js; don't use box types - // in conversion functions. - if (typeof result === 'object') { - for (let len = result.length, i = 0; i < len; i++) { - result[i] = Math.round(result[i]); - } - } +/* eslint-disable node/no-deprecated-api */ - return result; - }; +var toString = Object.prototype.toString - // Preserve .conversion property if there is one - if ('conversion' in fn) { - wrappedFn.conversion = fn.conversion; - } +var isModern = ( + typeof Buffer !== 'undefined' && + typeof Buffer.alloc === 'function' && + typeof Buffer.allocUnsafe === 'function' && + typeof Buffer.from === 'function' +) - return wrappedFn; +function isArrayBuffer (input) { + return toString.call(input).slice(8, -1) === 'ArrayBuffer' } -models.forEach(fromModel => { - convert[fromModel] = {}; - - Object.defineProperty(convert[fromModel], 'channels', {value: conversions[fromModel].channels}); - Object.defineProperty(convert[fromModel], 'labels', {value: conversions[fromModel].labels}); +function fromArrayBuffer (obj, byteOffset, length) { + byteOffset >>>= 0 - const routes = route(fromModel); - const routeModels = Object.keys(routes); + var maxLength = obj.byteLength - byteOffset - routeModels.forEach(toModel => { - const fn = routes[toModel]; + if (maxLength < 0) { + throw new RangeError("'offset' is out of bounds") + } - convert[fromModel][toModel] = wrapRounded(fn); - convert[fromModel][toModel].raw = wrapRaw(fn); - }); -}); + if (length === undefined) { + length = maxLength + } else { + length >>>= 0 -module.exports = convert; + if (length > maxLength) { + throw new RangeError("'length' is out of bounds") + } + } + return isModern + ? Buffer.from(obj.slice(byteOffset, byteOffset + length)) + : new Buffer(new Uint8Array(obj.slice(byteOffset, byteOffset + length))) +} -/***/ }), +function fromString (string, encoding) { + if (typeof encoding !== 'string' || encoding === '') { + encoding = 'utf8' + } -/***/ 20694: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + if (!Buffer.isEncoding(encoding)) { + throw new TypeError('"encoding" must be a valid string encoding') + } -const conversions = __nccwpck_require__(62158); + return isModern + ? Buffer.from(string, encoding) + : new Buffer(string, encoding) +} -/* - This function routes a model to all other models. +function bufferFrom (value, encodingOrOffset, length) { + if (typeof value === 'number') { + throw new TypeError('"value" argument must not be a number') + } - all functions that are routed have a property `.conversion` attached - to the returned synthetic function. This property is an array - of strings, each with the steps in between the 'from' and 'to' - color models (inclusive). + if (isArrayBuffer(value)) { + return fromArrayBuffer(value, encodingOrOffset, length) + } - conversions that are not possible simply are not included. -*/ + if (typeof value === 'string') { + return fromString(value, encodingOrOffset) + } -function buildGraph() { - const graph = {}; - // https://jsperf.com/object-keys-vs-for-in-with-closure/3 - const models = Object.keys(conversions); + return isModern + ? Buffer.from(value) + : new Buffer(value) +} - for (let len = models.length, i = 0; i < len; i++) { - graph[models[i]] = { - // http://jsperf.com/1-vs-infinity - // micro-opt, but this is simple. - distance: -1, - parent: null - }; - } +module.exports = bufferFrom - return graph; -} -// https://en.wikipedia.org/wiki/Breadth-first_search -function deriveBFS(fromModel) { - const graph = buildGraph(); - const queue = [fromModel]; // Unshift -> queue -> pop +/***/ }), - graph[fromModel].distance = 0; +/***/ 66573: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { - while (queue.length) { - const current = queue.pop(); - const adjacents = Object.keys(conversions[current]); +"use strict"; - for (let len = adjacents.length, i = 0; i < len; i++) { - const adjacent = adjacents[i]; - const node = graph[adjacent]; +const os = __nccwpck_require__(22037); +const tty = __nccwpck_require__(76224); +const hasFlag = __nccwpck_require__(87583); - if (node.distance === -1) { - node.distance = graph[current].distance + 1; - node.parent = current; - queue.unshift(adjacent); - } - } - } +const {env} = process; - return graph; +let forceColor; +if (hasFlag('no-color') || + hasFlag('no-colors') || + hasFlag('color=false') || + hasFlag('color=never')) { + forceColor = 0; +} else if (hasFlag('color') || + hasFlag('colors') || + hasFlag('color=true') || + hasFlag('color=always')) { + forceColor = 1; } -function link(from, to) { - return function (args) { - return to(from(args)); - }; +if ('FORCE_COLOR' in env) { + if (env.FORCE_COLOR === 'true') { + forceColor = 1; + } else if (env.FORCE_COLOR === 'false') { + forceColor = 0; + } else { + forceColor = env.FORCE_COLOR.length === 0 ? 1 : Math.min(parseInt(env.FORCE_COLOR, 10), 3); + } } -function wrapConversion(toModel, graph) { - const path = [graph[toModel].parent, toModel]; - let fn = conversions[graph[toModel].parent][toModel]; - - let cur = graph[toModel].parent; - while (graph[cur].parent) { - path.unshift(graph[cur].parent); - fn = link(conversions[graph[cur].parent][cur], fn); - cur = graph[cur].parent; +function translateLevel(level) { + if (level === 0) { + return false; } - fn.conversion = path; - return fn; + return { + level, + hasBasic: true, + has256: level >= 2, + has16m: level >= 3 + }; } -module.exports = function (fromModel) { - const graph = deriveBFS(fromModel); - const conversion = {}; - - const models = Object.keys(graph); - for (let len = models.length, i = 0; i < len; i++) { - const toModel = models[i]; - const node = graph[toModel]; - - if (node.parent === null) { - // No possible conversion, or this node is the source model. - continue; - } - - conversion[toModel] = wrapConversion(toModel, graph); +function supportsColor(haveStream, streamIsTTY) { + if (forceColor === 0) { + return 0; } - return conversion; -}; - - + if (hasFlag('color=16m') || + hasFlag('color=full') || + hasFlag('color=truecolor')) { + return 3; + } -/***/ }), + if (hasFlag('color=256')) { + return 2; + } -/***/ 13474: -/***/ ((module) => { + if (haveStream && !streamIsTTY && forceColor === undefined) { + return 0; + } -const flagSymbol = Symbol('arg flag'); + const min = forceColor || 0; -function arg(opts, {argv = process.argv.slice(2), permissive = false, stopAtPositional = false} = {}) { - if (!opts) { - throw new Error('Argument specification object is required'); + if (env.TERM === 'dumb') { + return min; } - const result = {_: []}; + if (process.platform === 'win32') { + // Windows 10 build 10586 is the first Windows release that supports 256 colors. + // Windows 10 build 14931 is the first release that supports 16m/TrueColor. + const osRelease = os.release().split('.'); + if ( + Number(osRelease[0]) >= 10 && + Number(osRelease[2]) >= 10586 + ) { + return Number(osRelease[2]) >= 14931 ? 3 : 2; + } - const aliases = {}; - const handlers = {}; + return 1; + } - for (const key of Object.keys(opts)) { - if (!key) { - throw new TypeError('Argument key cannot be an empty string'); + if ('CI' in env) { + if (['TRAVIS', 'CIRCLECI', 'APPVEYOR', 'GITLAB_CI', 'GITHUB_ACTIONS', 'BUILDKITE'].some(sign => sign in env) || env.CI_NAME === 'codeship') { + return 1; } - if (key[0] !== '-') { - throw new TypeError(`Argument key must start with '-' but found: '${key}'`); - } + return min; + } - if (key.length === 1) { - throw new TypeError(`Argument key must have a name; singular '-' keys are not allowed: ${key}`); - } + if ('TEAMCITY_VERSION' in env) { + return /^(9\.(0*[1-9]\d*)\.|\d{2,}\.)/.test(env.TEAMCITY_VERSION) ? 1 : 0; + } - if (typeof opts[key] === 'string') { - aliases[key] = opts[key]; - continue; - } + if (env.COLORTERM === 'truecolor') { + return 3; + } - let type = opts[key]; - let isFlag = false; + if ('TERM_PROGRAM' in env) { + const version = parseInt((env.TERM_PROGRAM_VERSION || '').split('.')[0], 10); - if (Array.isArray(type) && type.length === 1 && typeof type[0] === 'function') { - const [fn] = type; - type = (value, name, prev = []) => { - prev.push(fn(value, name, prev[prev.length - 1])); - return prev; - }; - isFlag = fn === Boolean || fn[flagSymbol] === true; - } else if (typeof type === 'function') { - isFlag = type === Boolean || type[flagSymbol] === true; - } else { - throw new TypeError(`Type missing or not a function or valid array type: ${key}`); + switch (env.TERM_PROGRAM) { + case 'iTerm.app': + return version >= 3 ? 3 : 2; + case 'Apple_Terminal': + return 2; + // No default } + } - if (key[1] !== '-' && key.length > 2) { - throw new TypeError(`Short argument keys (with a single hyphen) must have only one character: ${key}`); - } + if (/-256(color)?$/i.test(env.TERM)) { + return 2; + } - handlers[key] = [type, isFlag]; + if (/^screen|^xterm|^vt100|^vt220|^rxvt|color|ansi|cygwin|linux/i.test(env.TERM)) { + return 1; } - for (let i = 0, len = argv.length; i < len; i++) { - const wholeArg = argv[i]; + if ('COLORTERM' in env) { + return 1; + } - if (stopAtPositional && result._.length > 0) { - result._ = result._.concat(argv.slice(i)); - break; - } + return min; +} - if (wholeArg === '--') { - result._ = result._.concat(argv.slice(i + 1)); - break; - } +function getSupportLevel(stream) { + const level = supportsColor(stream, stream && stream.isTTY); + return translateLevel(level); +} - if (wholeArg.length > 1 && wholeArg[0] === '-') { - /* eslint-disable operator-linebreak */ - const separatedArguments = (wholeArg[1] === '-' || wholeArg.length === 2) - ? [wholeArg] - : wholeArg.slice(1).split('').map(a => `-${a}`); - /* eslint-enable operator-linebreak */ +module.exports = { + supportsColor: getSupportLevel, + stdout: translateLevel(supportsColor(true, tty.isatty(1))), + stderr: translateLevel(supportsColor(true, tty.isatty(2))) +}; - for (let j = 0; j < separatedArguments.length; j++) { - const arg = separatedArguments[j]; - const [originalArgName, argStr] = arg[1] === '-' ? arg.split(/=(.*)/, 2) : [arg, undefined]; - let argName = originalArgName; - while (argName in aliases) { - argName = aliases[argName]; - } +/***/ }), - if (!(argName in handlers)) { - if (permissive) { - result._.push(arg); - continue; - } else { - const err = new Error(`Unknown or unexpected option: ${originalArgName}`); - err.code = 'ARG_UNKNOWN_OPTION'; - throw err; - } - } +/***/ 36662: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { - const [type, isFlag] = handlers[argName]; +"use strict"; - if (!isFlag && ((j + 1) < separatedArguments.length)) { - throw new TypeError(`Option requires argument (but was followed by another short argument): ${originalArgName}`); - } +const ansiStyles = __nccwpck_require__(93799); +const {stdout: stdoutColor, stderr: stderrColor} = __nccwpck_require__(66573); +const { + stringReplaceAll, + stringEncaseCRLFWithFirstIndex +} = __nccwpck_require__(59207); - if (isFlag) { - result[argName] = type(true, argName, result[argName]); - } else if (argStr === undefined) { - if ( - argv.length < i + 2 || - ( - argv[i + 1].length > 1 && - (argv[i + 1][0] === '-') && - !( - argv[i + 1].match(/^-?\d*(\.(?=\d))?\d*$/) && - ( - type === Number || - // eslint-disable-next-line no-undef - (typeof BigInt !== 'undefined' && type === BigInt) - ) - ) - ) - ) { - const extended = originalArgName === argName ? '' : ` (alias for ${argName})`; - throw new Error(`Option requires argument: ${originalArgName}${extended}`); - } +const {isArray} = Array; - result[argName] = type(argv[i + 1], argName, result[argName]); - ++i; - } else { - result[argName] = type(argStr, argName, result[argName]); - } - } - } else { - result._.push(wholeArg); - } - } +// `supportsColor.level` → `ansiStyles.color[name]` mapping +const levelMapping = [ + 'ansi', + 'ansi', + 'ansi256', + 'ansi16m' +]; - return result; -} +const styles = Object.create(null); -arg.flag = fn => { - fn[flagSymbol] = true; - return fn; -}; +const applyOptions = (object, options = {}) => { + if (options.level && !(Number.isInteger(options.level) && options.level >= 0 && options.level <= 3)) { + throw new Error('The `level` option should be an integer from 0 to 3'); + } -// Utility types -arg.COUNT = arg.flag((v, name, existingCount) => (existingCount || 0) + 1); + // Detect level if not set manually + const colorLevel = stdoutColor ? stdoutColor.level : 0; + object.level = options.level === undefined ? colorLevel : options.level; +}; -module.exports = arg; +class ChalkClass { + constructor(options) { + // eslint-disable-next-line no-constructor-return + return chalkFactory(options); + } +} +const chalkFactory = options => { + const chalk = {}; + applyOptions(chalk, options); -/***/ }), + chalk.template = (...arguments_) => chalkTag(chalk.template, ...arguments_); -/***/ 94015: -/***/ ((module) => { + Object.setPrototypeOf(chalk, Chalk.prototype); + Object.setPrototypeOf(chalk.template, chalk); -"use strict"; + chalk.template.constructor = () => { + throw new Error('`chalk.constructor()` is deprecated. Use `new chalk.Instance()` instead.'); + }; -module.exports = balanced; -function balanced(a, b, str) { - if (a instanceof RegExp) a = maybeMatch(a, str); - if (b instanceof RegExp) b = maybeMatch(b, str); + chalk.template.Instance = ChalkClass; - var r = range(a, b, str); + return chalk.template; +}; - return r && { - start: r[0], - end: r[1], - pre: str.slice(0, r[0]), - body: str.slice(r[0] + a.length, r[1]), - post: str.slice(r[1] + b.length) - }; +function Chalk(options) { + return chalkFactory(options); } -function maybeMatch(reg, str) { - var m = str.match(reg); - return m ? m[0] : null; +for (const [styleName, style] of Object.entries(ansiStyles)) { + styles[styleName] = { + get() { + const builder = createBuilder(this, createStyler(style.open, style.close, this._styler), this._isEmpty); + Object.defineProperty(this, styleName, {value: builder}); + return builder; + } + }; } -balanced.range = range; -function range(a, b, str) { - var begs, beg, left, right, result; - var ai = str.indexOf(a); - var bi = str.indexOf(b, ai + 1); - var i = ai; +styles.visible = { + get() { + const builder = createBuilder(this, this._styler, true); + Object.defineProperty(this, 'visible', {value: builder}); + return builder; + } +}; - if (ai >= 0 && bi > 0) { - if(a===b) { - return [ai, bi]; - } - begs = []; - left = str.length; +const usedModels = ['rgb', 'hex', 'keyword', 'hsl', 'hsv', 'hwb', 'ansi', 'ansi256']; - while (i >= 0 && !result) { - if (i == ai) { - begs.push(i); - ai = str.indexOf(a, i + 1); - } else if (begs.length == 1) { - result = [ begs.pop(), bi ]; - } else { - beg = begs.pop(); - if (beg < left) { - left = beg; - right = bi; - } +for (const model of usedModels) { + styles[model] = { + get() { + const {level} = this; + return function (...arguments_) { + const styler = createStyler(ansiStyles.color[levelMapping[level]][model](...arguments_), ansiStyles.color.close, this._styler); + return createBuilder(this, styler, this._isEmpty); + }; + } + }; +} - bi = str.indexOf(b, i + 1); - } +for (const model of usedModels) { + const bgModel = 'bg' + model[0].toUpperCase() + model.slice(1); + styles[bgModel] = { + get() { + const {level} = this; + return function (...arguments_) { + const styler = createStyler(ansiStyles.bgColor[levelMapping[level]][model](...arguments_), ansiStyles.bgColor.close, this._styler); + return createBuilder(this, styler, this._isEmpty); + }; + } + }; +} - i = ai < bi && ai >= 0 ? ai : bi; - } +const proto = Object.defineProperties(() => {}, { + ...styles, + level: { + enumerable: true, + get() { + return this._generator.level; + }, + set(level) { + this._generator.level = level; + } + } +}); - if (begs.length) { - result = [ left, right ]; - } - } +const createStyler = (open, close, parent) => { + let openAll; + let closeAll; + if (parent === undefined) { + openAll = open; + closeAll = close; + } else { + openAll = parent.openAll + open; + closeAll = close + parent.closeAll; + } - return result; -} + return { + open, + close, + openAll, + closeAll, + parent + }; +}; +const createBuilder = (self, _styler, _isEmpty) => { + const builder = (...arguments_) => { + if (isArray(arguments_[0]) && isArray(arguments_[0].raw)) { + // Called as a template literal, for example: chalk.red`2 + 3 = {bold ${2+3}}` + return applyStyle(builder, chalkTag(builder, ...arguments_)); + } -/***/ }), + // Single argument is hot path, implicit coercion is faster than anything + // eslint-disable-next-line no-implicit-coercion + return applyStyle(builder, (arguments_.length === 1) ? ('' + arguments_[0]) : arguments_.join(' ')); + }; -/***/ 74286: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + // We alter the prototype because we must return a function, but there is + // no way to create a function with a different prototype + Object.setPrototypeOf(builder, proto); -"use strict"; + builder._generator = self; + builder._styler = _styler; + builder._isEmpty = _isEmpty; + return builder; +}; -const { Buffer } = __nccwpck_require__(14300) -const symbol = Symbol.for('BufferList') +const applyStyle = (self, string) => { + if (self.level <= 0 || !string) { + return self._isEmpty ? '' : string; + } -function BufferList (buf) { - if (!(this instanceof BufferList)) { - return new BufferList(buf) - } + let styler = self._styler; - BufferList._init.call(this, buf) -} + if (styler === undefined) { + return string; + } -BufferList._init = function _init (buf) { - Object.defineProperty(this, symbol, { value: true }) + const {openAll, closeAll} = styler; + if (string.indexOf('\u001B') !== -1) { + while (styler !== undefined) { + // Replace any instances already present with a re-opening code + // otherwise only the part of the string until said closing code + // will be colored, and the rest will simply be 'plain'. + string = stringReplaceAll(string, styler.close, styler.open); - this._bufs = [] - this.length = 0 + styler = styler.parent; + } + } - if (buf) { - this.append(buf) - } -} + // We can move both next actions out of loop, because remaining actions in loop won't have + // any/visible effect on parts we add here. Close the styling before a linebreak and reopen + // after next line to fix a bleed issue on macOS: https://github.com/chalk/chalk/pull/92 + const lfIndex = string.indexOf('\n'); + if (lfIndex !== -1) { + string = stringEncaseCRLFWithFirstIndex(string, closeAll, openAll, lfIndex); + } -BufferList.prototype._new = function _new (buf) { - return new BufferList(buf) -} + return openAll + string + closeAll; +}; -BufferList.prototype._offset = function _offset (offset) { - if (offset === 0) { - return [0, 0] - } +let template; +const chalkTag = (chalk, ...strings) => { + const [firstString] = strings; - let tot = 0 + if (!isArray(firstString) || !isArray(firstString.raw)) { + // If chalk() was called by itself or with a string, + // return the string itself as a string. + return strings.join(' '); + } - for (let i = 0; i < this._bufs.length; i++) { - const _t = tot + this._bufs[i].length - if (offset < _t || i === this._bufs.length - 1) { - return [i, offset - tot] - } - tot = _t - } -} + const arguments_ = strings.slice(1); + const parts = [firstString.raw[0]]; -BufferList.prototype._reverseOffset = function (blOffset) { - const bufferId = blOffset[0] - let offset = blOffset[1] + for (let i = 1; i < firstString.length; i++) { + parts.push( + String(arguments_[i - 1]).replace(/[{}\\]/g, '\\$&'), + String(firstString.raw[i]) + ); + } - for (let i = 0; i < bufferId; i++) { - offset += this._bufs[i].length - } + if (template === undefined) { + template = __nccwpck_require__(4081); + } - return offset -} + return template(chalk, parts.join('')); +}; -BufferList.prototype.get = function get (index) { - if (index > this.length || index < 0) { - return undefined - } +Object.defineProperties(Chalk.prototype, styles); - const offset = this._offset(index) +const chalk = Chalk(); // eslint-disable-line new-cap +chalk.supportsColor = stdoutColor; +chalk.stderr = Chalk({level: stderrColor ? stderrColor.level : 0}); // eslint-disable-line new-cap +chalk.stderr.supportsColor = stderrColor; - return this._bufs[offset[0]][offset[1]] -} +module.exports = chalk; -BufferList.prototype.slice = function slice (start, end) { - if (typeof start === 'number' && start < 0) { - start += this.length - } - if (typeof end === 'number' && end < 0) { - end += this.length - } +/***/ }), - return this.copy(null, 0, start, end) -} +/***/ 4081: +/***/ ((module) => { -BufferList.prototype.copy = function copy (dst, dstStart, srcStart, srcEnd) { - if (typeof srcStart !== 'number' || srcStart < 0) { - srcStart = 0 - } +"use strict"; - if (typeof srcEnd !== 'number' || srcEnd > this.length) { - srcEnd = this.length - } +const TEMPLATE_REGEX = /(?:\\(u(?:[a-f\d]{4}|\{[a-f\d]{1,6}\})|x[a-f\d]{2}|.))|(?:\{(~)?(\w+(?:\([^)]*\))?(?:\.\w+(?:\([^)]*\))?)*)(?:[ \t]|(?=\r?\n)))|(\})|((?:.|[\r\n\f])+?)/gi; +const STYLE_REGEX = /(?:^|\.)(\w+)(?:\(([^)]*)\))?/g; +const STRING_REGEX = /^(['"])((?:\\.|(?!\1)[^\\])*)\1$/; +const ESCAPE_REGEX = /\\(u(?:[a-f\d]{4}|{[a-f\d]{1,6}})|x[a-f\d]{2}|.)|([^\\])/gi; - if (srcStart >= this.length) { - return dst || Buffer.alloc(0) - } - - if (srcEnd <= 0) { - return dst || Buffer.alloc(0) - } +const ESCAPES = new Map([ + ['n', '\n'], + ['r', '\r'], + ['t', '\t'], + ['b', '\b'], + ['f', '\f'], + ['v', '\v'], + ['0', '\0'], + ['\\', '\\'], + ['e', '\u001B'], + ['a', '\u0007'] +]); - const copy = !!dst - const off = this._offset(srcStart) - const len = srcEnd - srcStart - let bytes = len - let bufoff = (copy && dstStart) || 0 - let start = off[1] +function unescape(c) { + const u = c[0] === 'u'; + const bracket = c[1] === '{'; - // copy/slice everything - if (srcStart === 0 && srcEnd === this.length) { - if (!copy) { - // slice, but full concat if multiple buffers - return this._bufs.length === 1 - ? this._bufs[0] - : Buffer.concat(this._bufs, this.length) - } + if ((u && !bracket && c.length === 5) || (c[0] === 'x' && c.length === 3)) { + return String.fromCharCode(parseInt(c.slice(1), 16)); + } - // copy, need to copy individual buffers - for (let i = 0; i < this._bufs.length; i++) { - this._bufs[i].copy(dst, bufoff) - bufoff += this._bufs[i].length - } + if (u && bracket) { + return String.fromCodePoint(parseInt(c.slice(2, -1), 16)); + } - return dst - } + return ESCAPES.get(c) || c; +} - // easy, cheap case where it's a subset of one of the buffers - if (bytes <= this._bufs[off[0]].length - start) { - return copy - ? this._bufs[off[0]].copy(dst, dstStart, start, start + bytes) - : this._bufs[off[0]].slice(start, start + bytes) - } +function parseArguments(name, arguments_) { + const results = []; + const chunks = arguments_.trim().split(/\s*,\s*/g); + let matches; - if (!copy) { - // a slice, we need something to copy in to - dst = Buffer.allocUnsafe(len) - } + for (const chunk of chunks) { + const number = Number(chunk); + if (!Number.isNaN(number)) { + results.push(number); + } else if ((matches = chunk.match(STRING_REGEX))) { + results.push(matches[2].replace(ESCAPE_REGEX, (m, escape, character) => escape ? unescape(escape) : character)); + } else { + throw new Error(`Invalid Chalk template style argument: ${chunk} (in style '${name}')`); + } + } - for (let i = off[0]; i < this._bufs.length; i++) { - const l = this._bufs[i].length - start + return results; +} - if (bytes > l) { - this._bufs[i].copy(dst, bufoff, start) - bufoff += l - } else { - this._bufs[i].copy(dst, bufoff, start, start + bytes) - bufoff += l - break - } +function parseStyle(style) { + STYLE_REGEX.lastIndex = 0; - bytes -= l + const results = []; + let matches; - if (start) { - start = 0 - } - } + while ((matches = STYLE_REGEX.exec(style)) !== null) { + const name = matches[1]; - // safeguard so that we don't return uninitialized memory - if (dst.length > bufoff) return dst.slice(0, bufoff) + if (matches[2]) { + const args = parseArguments(name, matches[2]); + results.push([name].concat(args)); + } else { + results.push([name]); + } + } - return dst + return results; } -BufferList.prototype.shallowSlice = function shallowSlice (start, end) { - start = start || 0 - end = typeof end !== 'number' ? this.length : end - - if (start < 0) { - start += this.length - } - - if (end < 0) { - end += this.length - } +function buildStyle(chalk, styles) { + const enabled = {}; - if (start === end) { - return this._new() - } + for (const layer of styles) { + for (const style of layer.styles) { + enabled[style[0]] = layer.inverse ? null : style.slice(1); + } + } - const startOffset = this._offset(start) - const endOffset = this._offset(end) - const buffers = this._bufs.slice(startOffset[0], endOffset[0] + 1) + let current = chalk; + for (const [styleName, styles] of Object.entries(enabled)) { + if (!Array.isArray(styles)) { + continue; + } - if (endOffset[1] === 0) { - buffers.pop() - } else { - buffers[buffers.length - 1] = buffers[buffers.length - 1].slice(0, endOffset[1]) - } + if (!(styleName in current)) { + throw new Error(`Unknown Chalk style: ${styleName}`); + } - if (startOffset[1] !== 0) { - buffers[0] = buffers[0].slice(startOffset[1]) - } + current = styles.length > 0 ? current[styleName](...styles) : current[styleName]; + } - return this._new(buffers) + return current; } -BufferList.prototype.toString = function toString (encoding, start, end) { - return this.slice(start, end).toString(encoding) -} +module.exports = (chalk, temporary) => { + const styles = []; + const chunks = []; + let chunk = []; -BufferList.prototype.consume = function consume (bytes) { - // first, normalize the argument, in accordance with how Buffer does it - bytes = Math.trunc(bytes) - // do nothing if not a positive number - if (Number.isNaN(bytes) || bytes <= 0) return this + // eslint-disable-next-line max-params + temporary.replace(TEMPLATE_REGEX, (m, escapeCharacter, inverse, style, close, character) => { + if (escapeCharacter) { + chunk.push(unescape(escapeCharacter)); + } else if (style) { + const string = chunk.join(''); + chunk = []; + chunks.push(styles.length === 0 ? string : buildStyle(chalk, styles)(string)); + styles.push({inverse, styles: parseStyle(style)}); + } else if (close) { + if (styles.length === 0) { + throw new Error('Found extraneous } in Chalk template literal'); + } - while (this._bufs.length) { - if (bytes >= this._bufs[0].length) { - bytes -= this._bufs[0].length - this.length -= this._bufs[0].length - this._bufs.shift() - } else { - this._bufs[0] = this._bufs[0].slice(bytes) - this.length -= bytes - break - } - } + chunks.push(buildStyle(chalk, styles)(chunk.join(''))); + chunk = []; + styles.pop(); + } else { + chunk.push(character); + } + }); - return this -} + chunks.push(chunk.join('')); -BufferList.prototype.duplicate = function duplicate () { - const copy = this._new() + if (styles.length > 0) { + const errMessage = `Chalk template literal is missing ${styles.length} closing bracket${styles.length === 1 ? '' : 's'} (\`}\`)`; + throw new Error(errMessage); + } - for (let i = 0; i < this._bufs.length; i++) { - copy.append(this._bufs[i]) - } + return chunks.join(''); +}; - return copy -} -BufferList.prototype.append = function append (buf) { - if (buf == null) { - return this - } +/***/ }), - if (buf.buffer) { - // append a view of the underlying ArrayBuffer - this._appendBuffer(Buffer.from(buf.buffer, buf.byteOffset, buf.byteLength)) - } else if (Array.isArray(buf)) { - for (let i = 0; i < buf.length; i++) { - this.append(buf[i]) - } - } else if (this._isBufferList(buf)) { - // unwrap argument into individual BufferLists - for (let i = 0; i < buf._bufs.length; i++) { - this.append(buf._bufs[i]) - } - } else { - // coerce number arguments to strings, since Buffer(number) does - // uninitialized memory allocation - if (typeof buf === 'number') { - buf = buf.toString() - } +/***/ 59207: +/***/ ((module) => { - this._appendBuffer(Buffer.from(buf)) - } +"use strict"; - return this -} -BufferList.prototype._appendBuffer = function appendBuffer (buf) { - this._bufs.push(buf) - this.length += buf.length -} +const stringReplaceAll = (string, substring, replacer) => { + let index = string.indexOf(substring); + if (index === -1) { + return string; + } -BufferList.prototype.indexOf = function (search, offset, encoding) { - if (encoding === undefined && typeof offset === 'string') { - encoding = offset - offset = undefined - } + const substringLength = substring.length; + let endIndex = 0; + let returnValue = ''; + do { + returnValue += string.substr(endIndex, index - endIndex) + substring + replacer; + endIndex = index + substringLength; + index = string.indexOf(substring, endIndex); + } while (index !== -1); - if (typeof search === 'function' || Array.isArray(search)) { - throw new TypeError('The "value" argument must be one of type string, Buffer, BufferList, or Uint8Array.') - } else if (typeof search === 'number') { - search = Buffer.from([search]) - } else if (typeof search === 'string') { - search = Buffer.from(search, encoding) - } else if (this._isBufferList(search)) { - search = search.slice() - } else if (Array.isArray(search.buffer)) { - search = Buffer.from(search.buffer, search.byteOffset, search.byteLength) - } else if (!Buffer.isBuffer(search)) { - search = Buffer.from(search) - } + returnValue += string.substr(endIndex); + return returnValue; +}; - offset = Number(offset || 0) +const stringEncaseCRLFWithFirstIndex = (string, prefix, postfix, index) => { + let endIndex = 0; + let returnValue = ''; + do { + const gotCR = string[index - 1] === '\r'; + returnValue += string.substr(endIndex, (gotCR ? index - 1 : index) - endIndex) + prefix + (gotCR ? '\r\n' : '\n') + postfix; + endIndex = index + 1; + index = string.indexOf('\n', endIndex); + } while (index !== -1); - if (isNaN(offset)) { - offset = 0 - } + returnValue += string.substr(endIndex); + return returnValue; +}; - if (offset < 0) { - offset = this.length + offset - } +module.exports = { + stringReplaceAll, + stringEncaseCRLFWithFirstIndex +}; - if (offset < 0) { - offset = 0 - } - if (search.length === 0) { - return offset > this.length ? this.length : offset - } +/***/ }), - const blOffset = this._offset(offset) - let blIndex = blOffset[0] // index of which internal buffer we're working on - let buffOffset = blOffset[1] // offset of the internal buffer we're working on +/***/ 78567: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { - // scan over each buffer - for (; blIndex < this._bufs.length; blIndex++) { - const buff = this._bufs[blIndex] +/* MIT license */ +/* eslint-disable no-mixed-operators */ +const cssKeywords = __nccwpck_require__(22365); - while (buffOffset < buff.length) { - const availableWindow = buff.length - buffOffset +// NOTE: conversions should only return primitive values (i.e. arrays, or +// values that give correct `typeof` results). +// do not use box values types (i.e. Number(), String(), etc.) - if (availableWindow >= search.length) { - const nativeSearchResult = buff.indexOf(search, buffOffset) +const reverseKeywords = {}; +for (const key of Object.keys(cssKeywords)) { + reverseKeywords[cssKeywords[key]] = key; +} - if (nativeSearchResult !== -1) { - return this._reverseOffset([blIndex, nativeSearchResult]) - } +const convert = { + rgb: {channels: 3, labels: 'rgb'}, + hsl: {channels: 3, labels: 'hsl'}, + hsv: {channels: 3, labels: 'hsv'}, + hwb: {channels: 3, labels: 'hwb'}, + cmyk: {channels: 4, labels: 'cmyk'}, + xyz: {channels: 3, labels: 'xyz'}, + lab: {channels: 3, labels: 'lab'}, + lch: {channels: 3, labels: 'lch'}, + hex: {channels: 1, labels: ['hex']}, + keyword: {channels: 1, labels: ['keyword']}, + ansi16: {channels: 1, labels: ['ansi16']}, + ansi256: {channels: 1, labels: ['ansi256']}, + hcg: {channels: 3, labels: ['h', 'c', 'g']}, + apple: {channels: 3, labels: ['r16', 'g16', 'b16']}, + gray: {channels: 1, labels: ['gray']} +}; - buffOffset = buff.length - search.length + 1 // end of native search window - } else { - const revOffset = this._reverseOffset([blIndex, buffOffset]) +module.exports = convert; - if (this._match(revOffset, search)) { - return revOffset - } +// Hide .channels and .labels properties +for (const model of Object.keys(convert)) { + if (!('channels' in convert[model])) { + throw new Error('missing channels property: ' + model); + } - buffOffset++ - } - } + if (!('labels' in convert[model])) { + throw new Error('missing channel labels property: ' + model); + } - buffOffset = 0 - } + if (convert[model].labels.length !== convert[model].channels) { + throw new Error('channel and label counts mismatch: ' + model); + } - return -1 + const {channels, labels} = convert[model]; + delete convert[model].channels; + delete convert[model].labels; + Object.defineProperty(convert[model], 'channels', {value: channels}); + Object.defineProperty(convert[model], 'labels', {value: labels}); } -BufferList.prototype._match = function (offset, search) { - if (this.length - offset < search.length) { - return false - } - - for (let searchOffset = 0; searchOffset < search.length; searchOffset++) { - if (this.get(offset + searchOffset) !== search[searchOffset]) { - return false - } - } - return true -} +convert.rgb.hsl = function (rgb) { + const r = rgb[0] / 255; + const g = rgb[1] / 255; + const b = rgb[2] / 255; + const min = Math.min(r, g, b); + const max = Math.max(r, g, b); + const delta = max - min; + let h; + let s; -;(function () { - const methods = { - readDoubleBE: 8, - readDoubleLE: 8, - readFloatBE: 4, - readFloatLE: 4, - readInt32BE: 4, - readInt32LE: 4, - readUInt32BE: 4, - readUInt32LE: 4, - readInt16BE: 2, - readInt16LE: 2, - readUInt16BE: 2, - readUInt16LE: 2, - readInt8: 1, - readUInt8: 1, - readIntBE: null, - readIntLE: null, - readUIntBE: null, - readUIntLE: null - } + if (max === min) { + h = 0; + } else if (r === max) { + h = (g - b) / delta; + } else if (g === max) { + h = 2 + (b - r) / delta; + } else if (b === max) { + h = 4 + (r - g) / delta; + } - for (const m in methods) { - (function (m) { - if (methods[m] === null) { - BufferList.prototype[m] = function (offset, byteLength) { - return this.slice(offset, offset + byteLength)[m](0, byteLength) - } - } else { - BufferList.prototype[m] = function (offset = 0) { - return this.slice(offset, offset + methods[m])[m](0) - } - } - }(m)) - } -}()) + h = Math.min(h * 60, 360); -// Used internally by the class and also as an indicator of this object being -// a `BufferList`. It's not possible to use `instanceof BufferList` in a browser -// environment because there could be multiple different copies of the -// BufferList class and some `BufferList`s might be `BufferList`s. -BufferList.prototype._isBufferList = function _isBufferList (b) { - return b instanceof BufferList || BufferList.isBufferList(b) -} + if (h < 0) { + h += 360; + } -BufferList.isBufferList = function isBufferList (b) { - return b != null && b[symbol] -} + const l = (min + max) / 2; -module.exports = BufferList + if (max === min) { + s = 0; + } else if (l <= 0.5) { + s = delta / (max + min); + } else { + s = delta / (2 - max - min); + } + return [h, s * 100, l * 100]; +}; -/***/ }), +convert.rgb.hsv = function (rgb) { + let rdif; + let gdif; + let bdif; + let h; + let s; -/***/ 1236: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + const r = rgb[0] / 255; + const g = rgb[1] / 255; + const b = rgb[2] / 255; + const v = Math.max(r, g, b); + const diff = v - Math.min(r, g, b); + const diffc = function (c) { + return (v - c) / 6 / diff + 1 / 2; + }; -"use strict"; + if (diff === 0) { + h = 0; + s = 0; + } else { + s = diff / v; + rdif = diffc(r); + gdif = diffc(g); + bdif = diffc(b); + if (r === v) { + h = bdif - gdif; + } else if (g === v) { + h = (1 / 3) + rdif - bdif; + } else if (b === v) { + h = (2 / 3) + gdif - rdif; + } -const DuplexStream = (__nccwpck_require__(88550).Duplex) -const inherits = __nccwpck_require__(2868) -const BufferList = __nccwpck_require__(74286) + if (h < 0) { + h += 1; + } else if (h > 1) { + h -= 1; + } + } -function BufferListStream (callback) { - if (!(this instanceof BufferListStream)) { - return new BufferListStream(callback) - } + return [ + h * 360, + s * 100, + v * 100 + ]; +}; - if (typeof callback === 'function') { - this._callback = callback +convert.rgb.hwb = function (rgb) { + const r = rgb[0]; + const g = rgb[1]; + let b = rgb[2]; + const h = convert.rgb.hsl(rgb)[0]; + const w = 1 / 255 * Math.min(r, Math.min(g, b)); - const piper = function piper (err) { - if (this._callback) { - this._callback(err) - this._callback = null - } - }.bind(this) + b = 1 - 1 / 255 * Math.max(r, Math.max(g, b)); - this.on('pipe', function onPipe (src) { - src.on('error', piper) - }) - this.on('unpipe', function onUnpipe (src) { - src.removeListener('error', piper) - }) + return [h, w * 100, b * 100]; +}; - callback = null - } +convert.rgb.cmyk = function (rgb) { + const r = rgb[0] / 255; + const g = rgb[1] / 255; + const b = rgb[2] / 255; - BufferList._init.call(this, callback) - DuplexStream.call(this) -} + const k = Math.min(1 - r, 1 - g, 1 - b); + const c = (1 - r - k) / (1 - k) || 0; + const m = (1 - g - k) / (1 - k) || 0; + const y = (1 - b - k) / (1 - k) || 0; -inherits(BufferListStream, DuplexStream) -Object.assign(BufferListStream.prototype, BufferList.prototype) + return [c * 100, m * 100, y * 100, k * 100]; +}; -BufferListStream.prototype._new = function _new (callback) { - return new BufferListStream(callback) +function comparativeDistance(x, y) { + /* + See https://en.m.wikipedia.org/wiki/Euclidean_distance#Squared_Euclidean_distance + */ + return ( + ((x[0] - y[0]) ** 2) + + ((x[1] - y[1]) ** 2) + + ((x[2] - y[2]) ** 2) + ); } -BufferListStream.prototype._write = function _write (buf, encoding, callback) { - this._appendBuffer(buf) - - if (typeof callback === 'function') { - callback() - } -} +convert.rgb.keyword = function (rgb) { + const reversed = reverseKeywords[rgb]; + if (reversed) { + return reversed; + } -BufferListStream.prototype._read = function _read (size) { - if (!this.length) { - return this.push(null) - } + let currentClosestDistance = Infinity; + let currentClosestKeyword; - size = Math.min(size, this.length) - this.push(this.slice(0, size)) - this.consume(size) -} + for (const keyword of Object.keys(cssKeywords)) { + const value = cssKeywords[keyword]; -BufferListStream.prototype.end = function end (chunk) { - DuplexStream.prototype.end.call(this, chunk) + // Compute comparative distance + const distance = comparativeDistance(rgb, value); - if (this._callback) { - this._callback(null, this.slice()) - this._callback = null - } -} + // Check if its less, if so set as closest + if (distance < currentClosestDistance) { + currentClosestDistance = distance; + currentClosestKeyword = keyword; + } + } -BufferListStream.prototype._destroy = function _destroy (err, cb) { - this._bufs.length = 0 - this.length = 0 - cb(err) -} + return currentClosestKeyword; +}; -BufferListStream.prototype._isBufferList = function _isBufferList (b) { - return b instanceof BufferListStream || b instanceof BufferList || BufferListStream.isBufferList(b) -} +convert.keyword.rgb = function (keyword) { + return cssKeywords[keyword]; +}; -BufferListStream.isBufferList = BufferList.isBufferList +convert.rgb.xyz = function (rgb) { + let r = rgb[0] / 255; + let g = rgb[1] / 255; + let b = rgb[2] / 255; -module.exports = BufferListStream -module.exports.BufferListStream = BufferListStream -module.exports.BufferList = BufferList + // Assume sRGB + r = r > 0.04045 ? (((r + 0.055) / 1.055) ** 2.4) : (r / 12.92); + g = g > 0.04045 ? (((g + 0.055) / 1.055) ** 2.4) : (g / 12.92); + b = b > 0.04045 ? (((b + 0.055) / 1.055) ** 2.4) : (b / 12.92); + const x = (r * 0.4124) + (g * 0.3576) + (b * 0.1805); + const y = (r * 0.2126) + (g * 0.7152) + (b * 0.0722); + const z = (r * 0.0193) + (g * 0.1192) + (b * 0.9505); -/***/ }), + return [x * 100, y * 100, z * 100]; +}; -/***/ 2473: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { +convert.rgb.lab = function (rgb) { + const xyz = convert.rgb.xyz(rgb); + let x = xyz[0]; + let y = xyz[1]; + let z = xyz[2]; -"use strict"; + x /= 95.047; + y /= 100; + z /= 108.883; + x = x > 0.008856 ? (x ** (1 / 3)) : (7.787 * x) + (16 / 116); + y = y > 0.008856 ? (y ** (1 / 3)) : (7.787 * y) + (16 / 116); + z = z > 0.008856 ? (z ** (1 / 3)) : (7.787 * z) + (16 / 116); -const stringify = __nccwpck_require__(50947); -const compile = __nccwpck_require__(41802); -const expand = __nccwpck_require__(59727); -const parse = __nccwpck_require__(89479); + const l = (116 * y) - 16; + const a = 500 * (x - y); + const b = 200 * (y - z); -/** - * Expand the given pattern or create a regex-compatible string. - * - * ```js - * const braces = require('braces'); - * console.log(braces('{a,b,c}', { compile: true })); //=> ['(a|b|c)'] - * console.log(braces('{a,b,c}')); //=> ['a', 'b', 'c'] - * ``` - * @param {String} `str` - * @param {Object} `options` - * @return {String} - * @api public - */ + return [l, a, b]; +}; -const braces = (input, options = {}) => { - let output = []; +convert.hsl.rgb = function (hsl) { + const h = hsl[0] / 360; + const s = hsl[1] / 100; + const l = hsl[2] / 100; + let t2; + let t3; + let val; - if (Array.isArray(input)) { - for (let pattern of input) { - let result = braces.create(pattern, options); - if (Array.isArray(result)) { - output.push(...result); - } else { - output.push(result); - } - } - } else { - output = [].concat(braces.create(input, options)); - } + if (s === 0) { + val = l * 255; + return [val, val, val]; + } - if (options && options.expand === true && options.nodupes === true) { - output = [...new Set(output)]; - } - return output; -}; + if (l < 0.5) { + t2 = l * (1 + s); + } else { + t2 = l + s - l * s; + } -/** - * Parse the given `str` with the given `options`. - * - * ```js - * // braces.parse(pattern, [, options]); - * const ast = braces.parse('a/{b,c}/d'); - * console.log(ast); - * ``` - * @param {String} pattern Brace pattern to parse - * @param {Object} options - * @return {Object} Returns an AST - * @api public - */ + const t1 = 2 * l - t2; -braces.parse = (input, options = {}) => parse(input, options); + const rgb = [0, 0, 0]; + for (let i = 0; i < 3; i++) { + t3 = h + 1 / 3 * -(i - 1); + if (t3 < 0) { + t3++; + } -/** - * Creates a braces string from an AST, or an AST node. - * - * ```js - * const braces = require('braces'); - * let ast = braces.parse('foo/{a,b}/bar'); - * console.log(stringify(ast.nodes[2])); //=> '{a,b}' - * ``` - * @param {String} `input` Brace pattern or AST. - * @param {Object} `options` - * @return {Array} Returns an array of expanded values. - * @api public - */ + if (t3 > 1) { + t3--; + } -braces.stringify = (input, options = {}) => { - if (typeof input === 'string') { - return stringify(braces.parse(input, options), options); - } - return stringify(input, options); -}; + if (6 * t3 < 1) { + val = t1 + (t2 - t1) * 6 * t3; + } else if (2 * t3 < 1) { + val = t2; + } else if (3 * t3 < 2) { + val = t1 + (t2 - t1) * (2 / 3 - t3) * 6; + } else { + val = t1; + } -/** - * Compiles a brace pattern into a regex-compatible, optimized string. - * This method is called by the main [braces](#braces) function by default. - * - * ```js - * const braces = require('braces'); - * console.log(braces.compile('a/{b,c}/d')); - * //=> ['a/(b|c)/d'] - * ``` - * @param {String} `input` Brace pattern or AST. - * @param {Object} `options` - * @return {Array} Returns an array of expanded values. - * @api public - */ + rgb[i] = val * 255; + } -braces.compile = (input, options = {}) => { - if (typeof input === 'string') { - input = braces.parse(input, options); - } - return compile(input, options); + return rgb; }; -/** - * Expands a brace pattern into an array. This method is called by the - * main [braces](#braces) function when `options.expand` is true. Before - * using this method it's recommended that you read the [performance notes](#performance)) - * and advantages of using [.compile](#compile) instead. - * - * ```js - * const braces = require('braces'); - * console.log(braces.expand('a/{b,c}/d')); - * //=> ['a/b/d', 'a/c/d']; - * ``` - * @param {String} `pattern` Brace pattern - * @param {Object} `options` - * @return {Array} Returns an array of expanded values. - * @api public - */ +convert.hsl.hsv = function (hsl) { + const h = hsl[0]; + let s = hsl[1] / 100; + let l = hsl[2] / 100; + let smin = s; + const lmin = Math.max(l, 0.01); -braces.expand = (input, options = {}) => { - if (typeof input === 'string') { - input = braces.parse(input, options); - } + l *= 2; + s *= (l <= 1) ? l : 2 - l; + smin *= lmin <= 1 ? lmin : 2 - lmin; + const v = (l + s) / 2; + const sv = l === 0 ? (2 * smin) / (lmin + smin) : (2 * s) / (l + s); - let result = expand(input, options); + return [h, sv * 100, v * 100]; +}; - // filter out empty strings if specified - if (options.noempty === true) { - result = result.filter(Boolean); - } +convert.hsv.rgb = function (hsv) { + const h = hsv[0] / 60; + const s = hsv[1] / 100; + let v = hsv[2] / 100; + const hi = Math.floor(h) % 6; - // filter out duplicates if specified - if (options.nodupes === true) { - result = [...new Set(result)]; - } + const f = h - Math.floor(h); + const p = 255 * v * (1 - s); + const q = 255 * v * (1 - (s * f)); + const t = 255 * v * (1 - (s * (1 - f))); + v *= 255; - return result; + switch (hi) { + case 0: + return [v, t, p]; + case 1: + return [q, v, p]; + case 2: + return [p, v, t]; + case 3: + return [p, q, v]; + case 4: + return [t, p, v]; + case 5: + return [v, p, q]; + } }; -/** - * Processes a brace pattern and returns either an expanded array - * (if `options.expand` is true), a highly optimized regex-compatible string. - * This method is called by the main [braces](#braces) function. - * - * ```js - * const braces = require('braces'); - * console.log(braces.create('user-{200..300}/project-{a,b,c}-{1..10}')) - * //=> 'user-(20[0-9]|2[1-9][0-9]|300)/project-(a|b|c)-([1-9]|10)' - * ``` - * @param {String} `pattern` Brace pattern - * @param {Object} `options` - * @return {Array} Returns an array of expanded values. - * @api public - */ +convert.hsv.hsl = function (hsv) { + const h = hsv[0]; + const s = hsv[1] / 100; + const v = hsv[2] / 100; + const vmin = Math.max(v, 0.01); + let sl; + let l; -braces.create = (input, options = {}) => { - if (input === '' || input.length < 3) { - return [input]; - } + l = (2 - s) * v; + const lmin = (2 - s) * vmin; + sl = s * vmin; + sl /= (lmin <= 1) ? lmin : 2 - lmin; + sl = sl || 0; + l /= 2; - return options.expand !== true - ? braces.compile(input, options) - : braces.expand(input, options); + return [h, sl * 100, l * 100]; }; -/** - * Expose "braces" - */ - -module.exports = braces; +// http://dev.w3.org/csswg/css-color/#hwb-to-rgb +convert.hwb.rgb = function (hwb) { + const h = hwb[0] / 360; + let wh = hwb[1] / 100; + let bl = hwb[2] / 100; + const ratio = wh + bl; + let f; + // Wh + bl cant be > 1 + if (ratio > 1) { + wh /= ratio; + bl /= ratio; + } -/***/ }), + const i = Math.floor(6 * h); + const v = 1 - bl; + f = 6 * h - i; -/***/ 41802: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + if ((i & 0x01) !== 0) { + f = 1 - f; + } -"use strict"; + const n = wh + f * (v - wh); // Linear interpolation + let r; + let g; + let b; + /* eslint-disable max-statements-per-line,no-multi-spaces */ + switch (i) { + default: + case 6: + case 0: r = v; g = n; b = wh; break; + case 1: r = n; g = v; b = wh; break; + case 2: r = wh; g = v; b = n; break; + case 3: r = wh; g = n; b = v; break; + case 4: r = n; g = wh; b = v; break; + case 5: r = v; g = wh; b = n; break; + } + /* eslint-enable max-statements-per-line,no-multi-spaces */ -const fill = __nccwpck_require__(12619); -const utils = __nccwpck_require__(25078); + return [r * 255, g * 255, b * 255]; +}; -const compile = (ast, options = {}) => { - let walk = (node, parent = {}) => { - let invalidBlock = utils.isInvalidBrace(parent); - let invalidNode = node.invalid === true && options.escapeInvalid === true; - let invalid = invalidBlock === true || invalidNode === true; - let prefix = options.escapeInvalid === true ? '\\' : ''; - let output = ''; +convert.cmyk.rgb = function (cmyk) { + const c = cmyk[0] / 100; + const m = cmyk[1] / 100; + const y = cmyk[2] / 100; + const k = cmyk[3] / 100; - if (node.isOpen === true) { - return prefix + node.value; - } - if (node.isClose === true) { - return prefix + node.value; - } + const r = 1 - Math.min(1, c * (1 - k) + k); + const g = 1 - Math.min(1, m * (1 - k) + k); + const b = 1 - Math.min(1, y * (1 - k) + k); - if (node.type === 'open') { - return invalid ? (prefix + node.value) : '('; - } + return [r * 255, g * 255, b * 255]; +}; - if (node.type === 'close') { - return invalid ? (prefix + node.value) : ')'; - } +convert.xyz.rgb = function (xyz) { + const x = xyz[0] / 100; + const y = xyz[1] / 100; + const z = xyz[2] / 100; + let r; + let g; + let b; - if (node.type === 'comma') { - return node.prev.type === 'comma' ? '' : (invalid ? node.value : '|'); - } + r = (x * 3.2406) + (y * -1.5372) + (z * -0.4986); + g = (x * -0.9689) + (y * 1.8758) + (z * 0.0415); + b = (x * 0.0557) + (y * -0.2040) + (z * 1.0570); - if (node.value) { - return node.value; - } + // Assume sRGB + r = r > 0.0031308 + ? ((1.055 * (r ** (1.0 / 2.4))) - 0.055) + : r * 12.92; - if (node.nodes && node.ranges > 0) { - let args = utils.reduce(node.nodes); - let range = fill(...args, { ...options, wrap: false, toRegex: true }); + g = g > 0.0031308 + ? ((1.055 * (g ** (1.0 / 2.4))) - 0.055) + : g * 12.92; - if (range.length !== 0) { - return args.length > 1 && range.length > 1 ? `(${range})` : range; - } - } + b = b > 0.0031308 + ? ((1.055 * (b ** (1.0 / 2.4))) - 0.055) + : b * 12.92; - if (node.nodes) { - for (let child of node.nodes) { - output += walk(child, node); - } - } - return output; - }; + r = Math.min(Math.max(0, r), 1); + g = Math.min(Math.max(0, g), 1); + b = Math.min(Math.max(0, b), 1); - return walk(ast); + return [r * 255, g * 255, b * 255]; }; -module.exports = compile; - - -/***/ }), +convert.xyz.lab = function (xyz) { + let x = xyz[0]; + let y = xyz[1]; + let z = xyz[2]; -/***/ 46867: -/***/ ((module) => { + x /= 95.047; + y /= 100; + z /= 108.883; -"use strict"; + x = x > 0.008856 ? (x ** (1 / 3)) : (7.787 * x) + (16 / 116); + y = y > 0.008856 ? (y ** (1 / 3)) : (7.787 * y) + (16 / 116); + z = z > 0.008856 ? (z ** (1 / 3)) : (7.787 * z) + (16 / 116); + const l = (116 * y) - 16; + const a = 500 * (x - y); + const b = 200 * (y - z); -module.exports = { - MAX_LENGTH: 1024 * 64, - - // Digits - CHAR_0: '0', /* 0 */ - CHAR_9: '9', /* 9 */ - - // Alphabet chars. - CHAR_UPPERCASE_A: 'A', /* A */ - CHAR_LOWERCASE_A: 'a', /* a */ - CHAR_UPPERCASE_Z: 'Z', /* Z */ - CHAR_LOWERCASE_Z: 'z', /* z */ - - CHAR_LEFT_PARENTHESES: '(', /* ( */ - CHAR_RIGHT_PARENTHESES: ')', /* ) */ - - CHAR_ASTERISK: '*', /* * */ - - // Non-alphabetic chars. - CHAR_AMPERSAND: '&', /* & */ - CHAR_AT: '@', /* @ */ - CHAR_BACKSLASH: '\\', /* \ */ - CHAR_BACKTICK: '`', /* ` */ - CHAR_CARRIAGE_RETURN: '\r', /* \r */ - CHAR_CIRCUMFLEX_ACCENT: '^', /* ^ */ - CHAR_COLON: ':', /* : */ - CHAR_COMMA: ',', /* , */ - CHAR_DOLLAR: '$', /* . */ - CHAR_DOT: '.', /* . */ - CHAR_DOUBLE_QUOTE: '"', /* " */ - CHAR_EQUAL: '=', /* = */ - CHAR_EXCLAMATION_MARK: '!', /* ! */ - CHAR_FORM_FEED: '\f', /* \f */ - CHAR_FORWARD_SLASH: '/', /* / */ - CHAR_HASH: '#', /* # */ - CHAR_HYPHEN_MINUS: '-', /* - */ - CHAR_LEFT_ANGLE_BRACKET: '<', /* < */ - CHAR_LEFT_CURLY_BRACE: '{', /* { */ - CHAR_LEFT_SQUARE_BRACKET: '[', /* [ */ - CHAR_LINE_FEED: '\n', /* \n */ - CHAR_NO_BREAK_SPACE: '\u00A0', /* \u00A0 */ - CHAR_PERCENT: '%', /* % */ - CHAR_PLUS: '+', /* + */ - CHAR_QUESTION_MARK: '?', /* ? */ - CHAR_RIGHT_ANGLE_BRACKET: '>', /* > */ - CHAR_RIGHT_CURLY_BRACE: '}', /* } */ - CHAR_RIGHT_SQUARE_BRACKET: ']', /* ] */ - CHAR_SEMICOLON: ';', /* ; */ - CHAR_SINGLE_QUOTE: '\'', /* ' */ - CHAR_SPACE: ' ', /* */ - CHAR_TAB: '\t', /* \t */ - CHAR_UNDERSCORE: '_', /* _ */ - CHAR_VERTICAL_LINE: '|', /* | */ - CHAR_ZERO_WIDTH_NOBREAK_SPACE: '\uFEFF' /* \uFEFF */ + return [l, a, b]; }; +convert.lab.xyz = function (lab) { + const l = lab[0]; + const a = lab[1]; + const b = lab[2]; + let x; + let y; + let z; -/***/ }), + y = (l + 16) / 116; + x = a / 500 + y; + z = y - b / 200; -/***/ 59727: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + const y2 = y ** 3; + const x2 = x ** 3; + const z2 = z ** 3; + y = y2 > 0.008856 ? y2 : (y - 16 / 116) / 7.787; + x = x2 > 0.008856 ? x2 : (x - 16 / 116) / 7.787; + z = z2 > 0.008856 ? z2 : (z - 16 / 116) / 7.787; -"use strict"; + x *= 95.047; + y *= 100; + z *= 108.883; + return [x, y, z]; +}; -const fill = __nccwpck_require__(12619); -const stringify = __nccwpck_require__(50947); -const utils = __nccwpck_require__(25078); +convert.lab.lch = function (lab) { + const l = lab[0]; + const a = lab[1]; + const b = lab[2]; + let h; -const append = (queue = '', stash = '', enclose = false) => { - let result = []; + const hr = Math.atan2(b, a); + h = hr * 360 / 2 / Math.PI; - queue = [].concat(queue); - stash = [].concat(stash); + if (h < 0) { + h += 360; + } - if (!stash.length) return queue; - if (!queue.length) { - return enclose ? utils.flatten(stash).map(ele => `{${ele}}`) : stash; - } + const c = Math.sqrt(a * a + b * b); - for (let item of queue) { - if (Array.isArray(item)) { - for (let value of item) { - result.push(append(value, stash, enclose)); - } - } else { - for (let ele of stash) { - if (enclose === true && typeof ele === 'string') ele = `{${ele}}`; - result.push(Array.isArray(ele) ? append(item, ele, enclose) : (item + ele)); - } - } - } - return utils.flatten(result); + return [l, c, h]; }; -const expand = (ast, options = {}) => { - let rangeLimit = options.rangeLimit === void 0 ? 1000 : options.rangeLimit; - - let walk = (node, parent = {}) => { - node.queue = []; - - let p = parent; - let q = parent.queue; - - while (p.type !== 'brace' && p.type !== 'root' && p.parent) { - p = p.parent; - q = p.queue; - } +convert.lch.lab = function (lch) { + const l = lch[0]; + const c = lch[1]; + const h = lch[2]; - if (node.invalid || node.dollar) { - q.push(append(q.pop(), stringify(node, options))); - return; - } + const hr = h / 360 * 2 * Math.PI; + const a = c * Math.cos(hr); + const b = c * Math.sin(hr); - if (node.type === 'brace' && node.invalid !== true && node.nodes.length === 2) { - q.push(append(q.pop(), ['{}'])); - return; - } + return [l, a, b]; +}; - if (node.nodes && node.ranges > 0) { - let args = utils.reduce(node.nodes); +convert.rgb.ansi16 = function (args, saturation = null) { + const [r, g, b] = args; + let value = saturation === null ? convert.rgb.hsv(args)[2] : saturation; // Hsv -> ansi16 optimization - if (utils.exceedsLimit(...args, options.step, rangeLimit)) { - throw new RangeError('expanded array length exceeds range limit. Use options.rangeLimit to increase or disable the limit.'); - } + value = Math.round(value / 50); - let range = fill(...args, options); - if (range.length === 0) { - range = stringify(node, options); - } + if (value === 0) { + return 30; + } - q.push(append(q.pop(), range)); - node.nodes = []; - return; - } + let ansi = 30 + + ((Math.round(b / 255) << 2) + | (Math.round(g / 255) << 1) + | Math.round(r / 255)); - let enclose = utils.encloseBrace(node); - let queue = node.queue; - let block = node; + if (value === 2) { + ansi += 60; + } - while (block.type !== 'brace' && block.type !== 'root' && block.parent) { - block = block.parent; - queue = block.queue; - } + return ansi; +}; - for (let i = 0; i < node.nodes.length; i++) { - let child = node.nodes[i]; +convert.hsv.ansi16 = function (args) { + // Optimization here; we already know the value and don't need to get + // it converted for us. + return convert.rgb.ansi16(convert.hsv.rgb(args), args[2]); +}; - if (child.type === 'comma' && node.type === 'brace') { - if (i === 1) queue.push(''); - queue.push(''); - continue; - } +convert.rgb.ansi256 = function (args) { + const r = args[0]; + const g = args[1]; + const b = args[2]; - if (child.type === 'close') { - q.push(append(q.pop(), queue, enclose)); - continue; - } + // We use the extended greyscale palette here, with the exception of + // black and white. normal palette only has 4 greyscale shades. + if (r === g && g === b) { + if (r < 8) { + return 16; + } - if (child.value && child.type !== 'open') { - queue.push(append(queue.pop(), child.value)); - continue; - } + if (r > 248) { + return 231; + } - if (child.nodes) { - walk(child, node); - } - } + return Math.round(((r - 8) / 247) * 24) + 232; + } - return queue; - }; + const ansi = 16 + + (36 * Math.round(r / 255 * 5)) + + (6 * Math.round(g / 255 * 5)) + + Math.round(b / 255 * 5); - return utils.flatten(walk(ast)); + return ansi; }; -module.exports = expand; +convert.ansi16.rgb = function (args) { + let color = args % 10; + // Handle greyscale + if (color === 0 || color === 7) { + if (args > 50) { + color += 3.5; + } -/***/ }), + color = color / 10.5 * 255; -/***/ 89479: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { - -"use strict"; - - -const stringify = __nccwpck_require__(50947); - -/** - * Constants - */ - -const { - MAX_LENGTH, - CHAR_BACKSLASH, /* \ */ - CHAR_BACKTICK, /* ` */ - CHAR_COMMA, /* , */ - CHAR_DOT, /* . */ - CHAR_LEFT_PARENTHESES, /* ( */ - CHAR_RIGHT_PARENTHESES, /* ) */ - CHAR_LEFT_CURLY_BRACE, /* { */ - CHAR_RIGHT_CURLY_BRACE, /* } */ - CHAR_LEFT_SQUARE_BRACKET, /* [ */ - CHAR_RIGHT_SQUARE_BRACKET, /* ] */ - CHAR_DOUBLE_QUOTE, /* " */ - CHAR_SINGLE_QUOTE, /* ' */ - CHAR_NO_BREAK_SPACE, - CHAR_ZERO_WIDTH_NOBREAK_SPACE -} = __nccwpck_require__(46867); - -/** - * parse - */ - -const parse = (input, options = {}) => { - if (typeof input !== 'string') { - throw new TypeError('Expected a string'); - } - - let opts = options || {}; - let max = typeof opts.maxLength === 'number' ? Math.min(MAX_LENGTH, opts.maxLength) : MAX_LENGTH; - if (input.length > max) { - throw new SyntaxError(`Input length (${input.length}), exceeds max characters (${max})`); - } - - let ast = { type: 'root', input, nodes: [] }; - let stack = [ast]; - let block = ast; - let prev = ast; - let brackets = 0; - let length = input.length; - let index = 0; - let depth = 0; - let value; - let memo = {}; - - /** - * Helpers - */ - - const advance = () => input[index++]; - const push = node => { - if (node.type === 'text' && prev.type === 'dot') { - prev.type = 'text'; - } - - if (prev && prev.type === 'text' && node.type === 'text') { - prev.value += node.value; - return; - } - - block.nodes.push(node); - node.parent = block; - node.prev = prev; - prev = node; - return node; - }; - - push({ type: 'bos' }); - - while (index < length) { - block = stack[stack.length - 1]; - value = advance(); - - /** - * Invalid chars - */ - - if (value === CHAR_ZERO_WIDTH_NOBREAK_SPACE || value === CHAR_NO_BREAK_SPACE) { - continue; - } - - /** - * Escaped chars - */ - - if (value === CHAR_BACKSLASH) { - push({ type: 'text', value: (options.keepEscaping ? value : '') + advance() }); - continue; - } - - /** - * Right square bracket (literal): ']' - */ - - if (value === CHAR_RIGHT_SQUARE_BRACKET) { - push({ type: 'text', value: '\\' + value }); - continue; - } - - /** - * Left square bracket: '[' - */ - - if (value === CHAR_LEFT_SQUARE_BRACKET) { - brackets++; - - let closed = true; - let next; - - while (index < length && (next = advance())) { - value += next; - - if (next === CHAR_LEFT_SQUARE_BRACKET) { - brackets++; - continue; - } - - if (next === CHAR_BACKSLASH) { - value += advance(); - continue; - } - - if (next === CHAR_RIGHT_SQUARE_BRACKET) { - brackets--; - - if (brackets === 0) { - break; - } - } - } - - push({ type: 'text', value }); - continue; - } - - /** - * Parentheses - */ - - if (value === CHAR_LEFT_PARENTHESES) { - block = push({ type: 'paren', nodes: [] }); - stack.push(block); - push({ type: 'text', value }); - continue; - } - - if (value === CHAR_RIGHT_PARENTHESES) { - if (block.type !== 'paren') { - push({ type: 'text', value }); - continue; - } - block = stack.pop(); - push({ type: 'text', value }); - block = stack[stack.length - 1]; - continue; - } - - /** - * Quotes: '|"|` - */ - - if (value === CHAR_DOUBLE_QUOTE || value === CHAR_SINGLE_QUOTE || value === CHAR_BACKTICK) { - let open = value; - let next; - - if (options.keepQuotes !== true) { - value = ''; - } - - while (index < length && (next = advance())) { - if (next === CHAR_BACKSLASH) { - value += next + advance(); - continue; - } - - if (next === open) { - if (options.keepQuotes === true) value += next; - break; - } - - value += next; - } - - push({ type: 'text', value }); - continue; - } + return [color, color, color]; + } - /** - * Left curly brace: '{' - */ + const mult = (~~(args > 50) + 1) * 0.5; + const r = ((color & 1) * mult) * 255; + const g = (((color >> 1) & 1) * mult) * 255; + const b = (((color >> 2) & 1) * mult) * 255; - if (value === CHAR_LEFT_CURLY_BRACE) { - depth++; - - let dollar = prev.value && prev.value.slice(-1) === '$' || block.dollar === true; - let brace = { - type: 'brace', - open: true, - close: false, - dollar, - depth, - commas: 0, - ranges: 0, - nodes: [] - }; + return [r, g, b]; +}; - block = push(brace); - stack.push(block); - push({ type: 'open', value }); - continue; - } +convert.ansi256.rgb = function (args) { + // Handle greyscale + if (args >= 232) { + const c = (args - 232) * 10 + 8; + return [c, c, c]; + } - /** - * Right curly brace: '}' - */ + args -= 16; - if (value === CHAR_RIGHT_CURLY_BRACE) { - if (block.type !== 'brace') { - push({ type: 'text', value }); - continue; - } + let rem; + const r = Math.floor(args / 36) / 5 * 255; + const g = Math.floor((rem = args % 36) / 6) / 5 * 255; + const b = (rem % 6) / 5 * 255; - let type = 'close'; - block = stack.pop(); - block.close = true; + return [r, g, b]; +}; - push({ type, value }); - depth--; +convert.rgb.hex = function (args) { + const integer = ((Math.round(args[0]) & 0xFF) << 16) + + ((Math.round(args[1]) & 0xFF) << 8) + + (Math.round(args[2]) & 0xFF); - block = stack[stack.length - 1]; - continue; - } + const string = integer.toString(16).toUpperCase(); + return '000000'.substring(string.length) + string; +}; - /** - * Comma: ',' - */ +convert.hex.rgb = function (args) { + const match = args.toString(16).match(/[a-f0-9]{6}|[a-f0-9]{3}/i); + if (!match) { + return [0, 0, 0]; + } - if (value === CHAR_COMMA && depth > 0) { - if (block.ranges > 0) { - block.ranges = 0; - let open = block.nodes.shift(); - block.nodes = [open, { type: 'text', value: stringify(block) }]; - } + let colorString = match[0]; - push({ type: 'comma', value }); - block.commas++; - continue; - } + if (match[0].length === 3) { + colorString = colorString.split('').map(char => { + return char + char; + }).join(''); + } - /** - * Dot: '.' - */ + const integer = parseInt(colorString, 16); + const r = (integer >> 16) & 0xFF; + const g = (integer >> 8) & 0xFF; + const b = integer & 0xFF; - if (value === CHAR_DOT && depth > 0 && block.commas === 0) { - let siblings = block.nodes; + return [r, g, b]; +}; - if (depth === 0 || siblings.length === 0) { - push({ type: 'text', value }); - continue; - } +convert.rgb.hcg = function (rgb) { + const r = rgb[0] / 255; + const g = rgb[1] / 255; + const b = rgb[2] / 255; + const max = Math.max(Math.max(r, g), b); + const min = Math.min(Math.min(r, g), b); + const chroma = (max - min); + let grayscale; + let hue; - if (prev.type === 'dot') { - block.range = []; - prev.value += value; - prev.type = 'range'; + if (chroma < 1) { + grayscale = min / (1 - chroma); + } else { + grayscale = 0; + } - if (block.nodes.length !== 3 && block.nodes.length !== 5) { - block.invalid = true; - block.ranges = 0; - prev.type = 'text'; - continue; - } + if (chroma <= 0) { + hue = 0; + } else + if (max === r) { + hue = ((g - b) / chroma) % 6; + } else + if (max === g) { + hue = 2 + (b - r) / chroma; + } else { + hue = 4 + (r - g) / chroma; + } - block.ranges++; - block.args = []; - continue; - } + hue /= 6; + hue %= 1; - if (prev.type === 'range') { - siblings.pop(); + return [hue * 360, chroma * 100, grayscale * 100]; +}; - let before = siblings[siblings.length - 1]; - before.value += prev.value + value; - prev = before; - block.ranges--; - continue; - } +convert.hsl.hcg = function (hsl) { + const s = hsl[1] / 100; + const l = hsl[2] / 100; - push({ type: 'dot', value }); - continue; - } + const c = l < 0.5 ? (2.0 * s * l) : (2.0 * s * (1.0 - l)); - /** - * Text - */ + let f = 0; + if (c < 1.0) { + f = (l - 0.5 * c) / (1.0 - c); + } - push({ type: 'text', value }); - } + return [hsl[0], c * 100, f * 100]; +}; - // Mark imbalanced braces and brackets as invalid - do { - block = stack.pop(); +convert.hsv.hcg = function (hsv) { + const s = hsv[1] / 100; + const v = hsv[2] / 100; - if (block.type !== 'root') { - block.nodes.forEach(node => { - if (!node.nodes) { - if (node.type === 'open') node.isOpen = true; - if (node.type === 'close') node.isClose = true; - if (!node.nodes) node.type = 'text'; - node.invalid = true; - } - }); + const c = s * v; + let f = 0; - // get the location of the block on parent.nodes (block's siblings) - let parent = stack[stack.length - 1]; - let index = parent.nodes.indexOf(block); - // replace the (invalid) block with it's nodes - parent.nodes.splice(index, 1, ...block.nodes); - } - } while (stack.length > 0); + if (c < 1.0) { + f = (v - c) / (1 - c); + } - push({ type: 'eos' }); - return ast; + return [hsv[0], c * 100, f * 100]; }; -module.exports = parse; - - -/***/ }), +convert.hcg.rgb = function (hcg) { + const h = hcg[0] / 360; + const c = hcg[1] / 100; + const g = hcg[2] / 100; -/***/ 50947: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + if (c === 0.0) { + return [g * 255, g * 255, g * 255]; + } -"use strict"; + const pure = [0, 0, 0]; + const hi = (h % 1) * 6; + const v = hi % 1; + const w = 1 - v; + let mg = 0; + /* eslint-disable max-statements-per-line */ + switch (Math.floor(hi)) { + case 0: + pure[0] = 1; pure[1] = v; pure[2] = 0; break; + case 1: + pure[0] = w; pure[1] = 1; pure[2] = 0; break; + case 2: + pure[0] = 0; pure[1] = 1; pure[2] = v; break; + case 3: + pure[0] = 0; pure[1] = w; pure[2] = 1; break; + case 4: + pure[0] = v; pure[1] = 0; pure[2] = 1; break; + default: + pure[0] = 1; pure[1] = 0; pure[2] = w; + } + /* eslint-enable max-statements-per-line */ -const utils = __nccwpck_require__(25078); + mg = (1.0 - c) * g; -module.exports = (ast, options = {}) => { - let stringify = (node, parent = {}) => { - let invalidBlock = options.escapeInvalid && utils.isInvalidBrace(parent); - let invalidNode = node.invalid === true && options.escapeInvalid === true; - let output = ''; + return [ + (c * pure[0] + mg) * 255, + (c * pure[1] + mg) * 255, + (c * pure[2] + mg) * 255 + ]; +}; - if (node.value) { - if ((invalidBlock || invalidNode) && utils.isOpenOrClose(node)) { - return '\\' + node.value; - } - return node.value; - } +convert.hcg.hsv = function (hcg) { + const c = hcg[1] / 100; + const g = hcg[2] / 100; - if (node.value) { - return node.value; - } + const v = c + g * (1.0 - c); + let f = 0; - if (node.nodes) { - for (let child of node.nodes) { - output += stringify(child); - } - } - return output; - }; + if (v > 0.0) { + f = c / v; + } - return stringify(ast); + return [hcg[0], f * 100, v * 100]; }; +convert.hcg.hsl = function (hcg) { + const c = hcg[1] / 100; + const g = hcg[2] / 100; + const l = g * (1.0 - c) + 0.5 * c; + let s = 0; -/***/ }), - -/***/ 25078: -/***/ ((__unused_webpack_module, exports) => { - -"use strict"; - + if (l > 0.0 && l < 0.5) { + s = c / (2 * l); + } else + if (l >= 0.5 && l < 1.0) { + s = c / (2 * (1 - l)); + } -exports.isInteger = num => { - if (typeof num === 'number') { - return Number.isInteger(num); - } - if (typeof num === 'string' && num.trim() !== '') { - return Number.isInteger(Number(num)); - } - return false; + return [hcg[0], s * 100, l * 100]; }; -/** - * Find a node of the given type - */ - -exports.find = (node, type) => node.nodes.find(node => node.type === type); - -/** - * Find a node of the given type - */ - -exports.exceedsLimit = (min, max, step = 1, limit) => { - if (limit === false) return false; - if (!exports.isInteger(min) || !exports.isInteger(max)) return false; - return ((Number(max) - Number(min)) / Number(step)) >= limit; +convert.hcg.hwb = function (hcg) { + const c = hcg[1] / 100; + const g = hcg[2] / 100; + const v = c + g * (1.0 - c); + return [hcg[0], (v - c) * 100, (1 - v) * 100]; }; -/** - * Escape the given node with '\\' before node.value - */ +convert.hwb.hcg = function (hwb) { + const w = hwb[1] / 100; + const b = hwb[2] / 100; + const v = 1 - b; + const c = v - w; + let g = 0; -exports.escapeNode = (block, n = 0, type) => { - let node = block.nodes[n]; - if (!node) return; + if (c < 1) { + g = (v - c) / (1 - c); + } - if ((type && node.type === type) || node.type === 'open' || node.type === 'close') { - if (node.escaped !== true) { - node.value = '\\' + node.value; - node.escaped = true; - } - } + return [hwb[0], c * 100, g * 100]; }; -/** - * Returns true if the given brace node should be enclosed in literal braces - */ - -exports.encloseBrace = node => { - if (node.type !== 'brace') return false; - if ((node.commas >> 0 + node.ranges >> 0) === 0) { - node.invalid = true; - return true; - } - return false; +convert.apple.rgb = function (apple) { + return [(apple[0] / 65535) * 255, (apple[1] / 65535) * 255, (apple[2] / 65535) * 255]; }; -/** - * Returns true if a brace node is invalid. - */ - -exports.isInvalidBrace = block => { - if (block.type !== 'brace') return false; - if (block.invalid === true || block.dollar) return true; - if ((block.commas >> 0 + block.ranges >> 0) === 0) { - block.invalid = true; - return true; - } - if (block.open !== true || block.close !== true) { - block.invalid = true; - return true; - } - return false; +convert.rgb.apple = function (rgb) { + return [(rgb[0] / 255) * 65535, (rgb[1] / 255) * 65535, (rgb[2] / 255) * 65535]; }; -/** - * Returns true if a node is an open or close node - */ - -exports.isOpenOrClose = node => { - if (node.type === 'open' || node.type === 'close') { - return true; - } - return node.open === true || node.close === true; +convert.gray.rgb = function (args) { + return [args[0] / 100 * 255, args[0] / 100 * 255, args[0] / 100 * 255]; }; -/** - * Reduce an array of text nodes. - */ - -exports.reduce = nodes => nodes.reduce((acc, node) => { - if (node.type === 'text') acc.push(node.value); - if (node.type === 'range') node.type = 'text'; - return acc; -}, []); - -/** - * Flatten an array - */ - -exports.flatten = (...args) => { - const result = []; - const flat = arr => { - for (let i = 0; i < arr.length; i++) { - let ele = arr[i]; - Array.isArray(ele) ? flat(ele, result) : ele !== void 0 && result.push(ele); - } - return result; - }; - flat(args); - return result; +convert.gray.hsl = function (args) { + return [0, 0, args[0]]; }; +convert.gray.hsv = convert.gray.hsl; -/***/ }), - -/***/ 82415: -/***/ ((module) => { - -/* eslint-disable node/no-deprecated-api */ - -var toString = Object.prototype.toString - -var isModern = ( - typeof Buffer !== 'undefined' && - typeof Buffer.alloc === 'function' && - typeof Buffer.allocUnsafe === 'function' && - typeof Buffer.from === 'function' -) - -function isArrayBuffer (input) { - return toString.call(input).slice(8, -1) === 'ArrayBuffer' -} - -function fromArrayBuffer (obj, byteOffset, length) { - byteOffset >>>= 0 - - var maxLength = obj.byteLength - byteOffset - - if (maxLength < 0) { - throw new RangeError("'offset' is out of bounds") - } - - if (length === undefined) { - length = maxLength - } else { - length >>>= 0 - - if (length > maxLength) { - throw new RangeError("'length' is out of bounds") - } - } - - return isModern - ? Buffer.from(obj.slice(byteOffset, byteOffset + length)) - : new Buffer(new Uint8Array(obj.slice(byteOffset, byteOffset + length))) -} - -function fromString (string, encoding) { - if (typeof encoding !== 'string' || encoding === '') { - encoding = 'utf8' - } - - if (!Buffer.isEncoding(encoding)) { - throw new TypeError('"encoding" must be a valid string encoding') - } - - return isModern - ? Buffer.from(string, encoding) - : new Buffer(string, encoding) -} +convert.gray.hwb = function (gray) { + return [0, 100, gray[0]]; +}; -function bufferFrom (value, encodingOrOffset, length) { - if (typeof value === 'number') { - throw new TypeError('"value" argument must not be a number') - } +convert.gray.cmyk = function (gray) { + return [0, 0, 0, gray[0]]; +}; - if (isArrayBuffer(value)) { - return fromArrayBuffer(value, encodingOrOffset, length) - } +convert.gray.lab = function (gray) { + return [gray[0], 0, 0]; +}; - if (typeof value === 'string') { - return fromString(value, encodingOrOffset) - } +convert.gray.hex = function (gray) { + const val = Math.round(gray[0] / 100 * 255) & 0xFF; + const integer = (val << 16) + (val << 8) + val; - return isModern - ? Buffer.from(value) - : new Buffer(value) -} + const string = integer.toString(16).toUpperCase(); + return '000000'.substring(string.length) + string; +}; -module.exports = bufferFrom +convert.rgb.gray = function (rgb) { + const val = (rgb[0] + rgb[1] + rgb[2]) / 3; + return [val / 255 * 100]; +}; /***/ }), -/***/ 29541: +/***/ 79713: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { -"use strict"; +const conversions = __nccwpck_require__(78567); +const route = __nccwpck_require__(8411); -const ansiStyles = __nccwpck_require__(3537); -const {stdout: stdoutColor, stderr: stderrColor} = __nccwpck_require__(9679); -const { - stringReplaceAll, - stringEncaseCRLFWithFirstIndex -} = __nccwpck_require__(94187); - -const {isArray} = Array; - -// `supportsColor.level` → `ansiStyles.color[name]` mapping -const levelMapping = [ - 'ansi', - 'ansi', - 'ansi256', - 'ansi16m' -]; - -const styles = Object.create(null); - -const applyOptions = (object, options = {}) => { - if (options.level && !(Number.isInteger(options.level) && options.level >= 0 && options.level <= 3)) { - throw new Error('The `level` option should be an integer from 0 to 3'); - } - - // Detect level if not set manually - const colorLevel = stdoutColor ? stdoutColor.level : 0; - object.level = options.level === undefined ? colorLevel : options.level; -}; - -class ChalkClass { - constructor(options) { - // eslint-disable-next-line no-constructor-return - return chalkFactory(options); - } -} - -const chalkFactory = options => { - const chalk = {}; - applyOptions(chalk, options); - - chalk.template = (...arguments_) => chalkTag(chalk.template, ...arguments_); - - Object.setPrototypeOf(chalk, Chalk.prototype); - Object.setPrototypeOf(chalk.template, chalk); - - chalk.template.constructor = () => { - throw new Error('`chalk.constructor()` is deprecated. Use `new chalk.Instance()` instead.'); - }; - - chalk.template.Instance = ChalkClass; - - return chalk.template; -}; +const convert = {}; -function Chalk(options) { - return chalkFactory(options); -} +const models = Object.keys(conversions); -for (const [styleName, style] of Object.entries(ansiStyles)) { - styles[styleName] = { - get() { - const builder = createBuilder(this, createStyler(style.open, style.close, this._styler), this._isEmpty); - Object.defineProperty(this, styleName, {value: builder}); - return builder; +function wrapRaw(fn) { + const wrappedFn = function (...args) { + const arg0 = args[0]; + if (arg0 === undefined || arg0 === null) { + return arg0; } - }; -} -styles.visible = { - get() { - const builder = createBuilder(this, this._styler, true); - Object.defineProperty(this, 'visible', {value: builder}); - return builder; - } -}; - -const usedModels = ['rgb', 'hex', 'keyword', 'hsl', 'hsv', 'hwb', 'ansi', 'ansi256']; - -for (const model of usedModels) { - styles[model] = { - get() { - const {level} = this; - return function (...arguments_) { - const styler = createStyler(ansiStyles.color[levelMapping[level]][model](...arguments_), ansiStyles.color.close, this._styler); - return createBuilder(this, styler, this._isEmpty); - }; + if (arg0.length > 1) { + args = arg0; } - }; -} -for (const model of usedModels) { - const bgModel = 'bg' + model[0].toUpperCase() + model.slice(1); - styles[bgModel] = { - get() { - const {level} = this; - return function (...arguments_) { - const styler = createStyler(ansiStyles.bgColor[levelMapping[level]][model](...arguments_), ansiStyles.bgColor.close, this._styler); - return createBuilder(this, styler, this._isEmpty); - }; - } + return fn(args); }; -} -const proto = Object.defineProperties(() => {}, { - ...styles, - level: { - enumerable: true, - get() { - return this._generator.level; - }, - set(level) { - this._generator.level = level; - } + // Preserve .conversion property if there is one + if ('conversion' in fn) { + wrappedFn.conversion = fn.conversion; } -}); -const createStyler = (open, close, parent) => { - let openAll; - let closeAll; - if (parent === undefined) { - openAll = open; - closeAll = close; - } else { - openAll = parent.openAll + open; - closeAll = close + parent.closeAll; - } + return wrappedFn; +} - return { - open, - close, - openAll, - closeAll, - parent - }; -}; +function wrapRounded(fn) { + const wrappedFn = function (...args) { + const arg0 = args[0]; -const createBuilder = (self, _styler, _isEmpty) => { - const builder = (...arguments_) => { - if (isArray(arguments_[0]) && isArray(arguments_[0].raw)) { - // Called as a template literal, for example: chalk.red`2 + 3 = {bold ${2+3}}` - return applyStyle(builder, chalkTag(builder, ...arguments_)); + if (arg0 === undefined || arg0 === null) { + return arg0; } - // Single argument is hot path, implicit coercion is faster than anything - // eslint-disable-next-line no-implicit-coercion - return applyStyle(builder, (arguments_.length === 1) ? ('' + arguments_[0]) : arguments_.join(' ')); - }; - - // We alter the prototype because we must return a function, but there is - // no way to create a function with a different prototype - Object.setPrototypeOf(builder, proto); - - builder._generator = self; - builder._styler = _styler; - builder._isEmpty = _isEmpty; - - return builder; -}; - -const applyStyle = (self, string) => { - if (self.level <= 0 || !string) { - return self._isEmpty ? '' : string; - } - - let styler = self._styler; - - if (styler === undefined) { - return string; - } - - const {openAll, closeAll} = styler; - if (string.indexOf('\u001B') !== -1) { - while (styler !== undefined) { - // Replace any instances already present with a re-opening code - // otherwise only the part of the string until said closing code - // will be colored, and the rest will simply be 'plain'. - string = stringReplaceAll(string, styler.close, styler.open); - - styler = styler.parent; + if (arg0.length > 1) { + args = arg0; } - } - // We can move both next actions out of loop, because remaining actions in loop won't have - // any/visible effect on parts we add here. Close the styling before a linebreak and reopen - // after next line to fix a bleed issue on macOS: https://github.com/chalk/chalk/pull/92 - const lfIndex = string.indexOf('\n'); - if (lfIndex !== -1) { - string = stringEncaseCRLFWithFirstIndex(string, closeAll, openAll, lfIndex); - } + const result = fn(args); - return openAll + string + closeAll; -}; + // We're assuming the result is an array here. + // see notice in conversions.js; don't use box types + // in conversion functions. + if (typeof result === 'object') { + for (let len = result.length, i = 0; i < len; i++) { + result[i] = Math.round(result[i]); + } + } -let template; -const chalkTag = (chalk, ...strings) => { - const [firstString] = strings; + return result; + }; - if (!isArray(firstString) || !isArray(firstString.raw)) { - // If chalk() was called by itself or with a string, - // return the string itself as a string. - return strings.join(' '); + // Preserve .conversion property if there is one + if ('conversion' in fn) { + wrappedFn.conversion = fn.conversion; } - const arguments_ = strings.slice(1); - const parts = [firstString.raw[0]]; + return wrappedFn; +} - for (let i = 1; i < firstString.length; i++) { - parts.push( - String(arguments_[i - 1]).replace(/[{}\\]/g, '\\$&'), - String(firstString.raw[i]) - ); - } +models.forEach(fromModel => { + convert[fromModel] = {}; - if (template === undefined) { - template = __nccwpck_require__(17353); - } + Object.defineProperty(convert[fromModel], 'channels', {value: conversions[fromModel].channels}); + Object.defineProperty(convert[fromModel], 'labels', {value: conversions[fromModel].labels}); - return template(chalk, parts.join('')); -}; + const routes = route(fromModel); + const routeModels = Object.keys(routes); -Object.defineProperties(Chalk.prototype, styles); + routeModels.forEach(toModel => { + const fn = routes[toModel]; -const chalk = Chalk(); // eslint-disable-line new-cap -chalk.supportsColor = stdoutColor; -chalk.stderr = Chalk({level: stderrColor ? stderrColor.level : 0}); // eslint-disable-line new-cap -chalk.stderr.supportsColor = stderrColor; + convert[fromModel][toModel] = wrapRounded(fn); + convert[fromModel][toModel].raw = wrapRaw(fn); + }); +}); -module.exports = chalk; +module.exports = convert; /***/ }), -/***/ 17353: -/***/ ((module) => { +/***/ 8411: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { -"use strict"; +const conversions = __nccwpck_require__(78567); -const TEMPLATE_REGEX = /(?:\\(u(?:[a-f\d]{4}|\{[a-f\d]{1,6}\})|x[a-f\d]{2}|.))|(?:\{(~)?(\w+(?:\([^)]*\))?(?:\.\w+(?:\([^)]*\))?)*)(?:[ \t]|(?=\r?\n)))|(\})|((?:.|[\r\n\f])+?)/gi; -const STYLE_REGEX = /(?:^|\.)(\w+)(?:\(([^)]*)\))?/g; -const STRING_REGEX = /^(['"])((?:\\.|(?!\1)[^\\])*)\1$/; -const ESCAPE_REGEX = /\\(u(?:[a-f\d]{4}|{[a-f\d]{1,6}})|x[a-f\d]{2}|.)|([^\\])/gi; +/* + This function routes a model to all other models. -const ESCAPES = new Map([ - ['n', '\n'], - ['r', '\r'], - ['t', '\t'], - ['b', '\b'], - ['f', '\f'], - ['v', '\v'], - ['0', '\0'], - ['\\', '\\'], - ['e', '\u001B'], - ['a', '\u0007'] -]); + all functions that are routed have a property `.conversion` attached + to the returned synthetic function. This property is an array + of strings, each with the steps in between the 'from' and 'to' + color models (inclusive). -function unescape(c) { - const u = c[0] === 'u'; - const bracket = c[1] === '{'; + conversions that are not possible simply are not included. +*/ - if ((u && !bracket && c.length === 5) || (c[0] === 'x' && c.length === 3)) { - return String.fromCharCode(parseInt(c.slice(1), 16)); - } +function buildGraph() { + const graph = {}; + // https://jsperf.com/object-keys-vs-for-in-with-closure/3 + const models = Object.keys(conversions); - if (u && bracket) { - return String.fromCodePoint(parseInt(c.slice(2, -1), 16)); + for (let len = models.length, i = 0; i < len; i++) { + graph[models[i]] = { + // http://jsperf.com/1-vs-infinity + // micro-opt, but this is simple. + distance: -1, + parent: null + }; } - return ESCAPES.get(c) || c; + return graph; } -function parseArguments(name, arguments_) { - const results = []; - const chunks = arguments_.trim().split(/\s*,\s*/g); - let matches; - - for (const chunk of chunks) { - const number = Number(chunk); - if (!Number.isNaN(number)) { - results.push(number); - } else if ((matches = chunk.match(STRING_REGEX))) { - results.push(matches[2].replace(ESCAPE_REGEX, (m, escape, character) => escape ? unescape(escape) : character)); - } else { - throw new Error(`Invalid Chalk template style argument: ${chunk} (in style '${name}')`); - } - } - - return results; -} +// https://en.wikipedia.org/wiki/Breadth-first_search +function deriveBFS(fromModel) { + const graph = buildGraph(); + const queue = [fromModel]; // Unshift -> queue -> pop -function parseStyle(style) { - STYLE_REGEX.lastIndex = 0; + graph[fromModel].distance = 0; - const results = []; - let matches; + while (queue.length) { + const current = queue.pop(); + const adjacents = Object.keys(conversions[current]); - while ((matches = STYLE_REGEX.exec(style)) !== null) { - const name = matches[1]; + for (let len = adjacents.length, i = 0; i < len; i++) { + const adjacent = adjacents[i]; + const node = graph[adjacent]; - if (matches[2]) { - const args = parseArguments(name, matches[2]); - results.push([name].concat(args)); - } else { - results.push([name]); + if (node.distance === -1) { + node.distance = graph[current].distance + 1; + node.parent = current; + queue.unshift(adjacent); + } } } - return results; + return graph; } -function buildStyle(chalk, styles) { - const enabled = {}; - - for (const layer of styles) { - for (const style of layer.styles) { - enabled[style[0]] = layer.inverse ? null : style.slice(1); - } - } - - let current = chalk; - for (const [styleName, styles] of Object.entries(enabled)) { - if (!Array.isArray(styles)) { - continue; - } +function link(from, to) { + return function (args) { + return to(from(args)); + }; +} - if (!(styleName in current)) { - throw new Error(`Unknown Chalk style: ${styleName}`); - } +function wrapConversion(toModel, graph) { + const path = [graph[toModel].parent, toModel]; + let fn = conversions[graph[toModel].parent][toModel]; - current = styles.length > 0 ? current[styleName](...styles) : current[styleName]; + let cur = graph[toModel].parent; + while (graph[cur].parent) { + path.unshift(graph[cur].parent); + fn = link(conversions[graph[cur].parent][cur], fn); + cur = graph[cur].parent; } - return current; + fn.conversion = path; + return fn; } -module.exports = (chalk, temporary) => { - const styles = []; - const chunks = []; - let chunk = []; +module.exports = function (fromModel) { + const graph = deriveBFS(fromModel); + const conversion = {}; - // eslint-disable-next-line max-params - temporary.replace(TEMPLATE_REGEX, (m, escapeCharacter, inverse, style, close, character) => { - if (escapeCharacter) { - chunk.push(unescape(escapeCharacter)); - } else if (style) { - const string = chunk.join(''); - chunk = []; - chunks.push(styles.length === 0 ? string : buildStyle(chalk, styles)(string)); - styles.push({inverse, styles: parseStyle(style)}); - } else if (close) { - if (styles.length === 0) { - throw new Error('Found extraneous } in Chalk template literal'); - } + const models = Object.keys(graph); + for (let len = models.length, i = 0; i < len; i++) { + const toModel = models[i]; + const node = graph[toModel]; - chunks.push(buildStyle(chalk, styles)(chunk.join(''))); - chunk = []; - styles.pop(); - } else { - chunk.push(character); + if (node.parent === null) { + // No possible conversion, or this node is the source model. + continue; } - }); - - chunks.push(chunk.join('')); - - if (styles.length > 0) { - const errMessage = `Chalk template literal is missing ${styles.length} closing bracket${styles.length === 1 ? '' : 's'} (\`}\`)`; - throw new Error(errMessage); - } - - return chunks.join(''); -}; - -/***/ }), - -/***/ 94187: -/***/ ((module) => { - -"use strict"; - - -const stringReplaceAll = (string, substring, replacer) => { - let index = string.indexOf(substring); - if (index === -1) { - return string; + conversion[toModel] = wrapConversion(toModel, graph); } - const substringLength = substring.length; - let endIndex = 0; - let returnValue = ''; - do { - returnValue += string.substr(endIndex, index - endIndex) + substring + replacer; - endIndex = index + substringLength; - index = string.indexOf(substring, endIndex); - } while (index !== -1); - - returnValue += string.substr(endIndex); - return returnValue; -}; - -const stringEncaseCRLFWithFirstIndex = (string, prefix, postfix, index) => { - let endIndex = 0; - let returnValue = ''; - do { - const gotCR = string[index - 1] === '\r'; - returnValue += string.substr(endIndex, (gotCR ? index - 1 : index) - endIndex) + prefix + (gotCR ? '\r\n' : '\n') + postfix; - endIndex = index + 1; - index = string.indexOf('\n', endIndex); - } while (index !== -1); - - returnValue += string.substr(endIndex); - return returnValue; + return conversion; }; -module.exports = { - stringReplaceAll, - stringEncaseCRLFWithFirstIndex -}; /***/ }), -/***/ 58158: +/***/ 22365: /***/ ((module) => { "use strict"; @@ -41441,7 +39415,7 @@ module.exports = { /***/ }), -/***/ 50819: +/***/ 90353: /***/ ((module) => { module.exports = function (xs, fn) { @@ -41461,7 +39435,7 @@ var isArray = Array.isArray || function (xs) { /***/ }), -/***/ 6691: +/***/ 14838: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { const nativeModule = __nccwpck_require__(98188) @@ -41517,7 +39491,7 @@ module.exports = createRequire /***/ }), -/***/ 69617: +/***/ 7398: /***/ ((module) => { /** @@ -41686,7 +39660,7 @@ function plural(ms, msAbs, n, name) { /***/ }), -/***/ 38617: +/***/ 76674: /***/ ((module, exports, __nccwpck_require__) => { /* eslint-env browser */ @@ -41943,7 +39917,7 @@ function localstorage() { } } -module.exports = __nccwpck_require__(50885)(exports); +module.exports = __nccwpck_require__(50923)(exports); const {formatters} = module.exports; @@ -41962,7 +39936,7 @@ formatters.j = function (v) { /***/ }), -/***/ 50885: +/***/ 50923: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { @@ -41978,7 +39952,7 @@ function setup(env) { createDebug.disable = disable; createDebug.enable = enable; createDebug.enabled = enabled; - createDebug.humanize = __nccwpck_require__(69617); + createDebug.humanize = __nccwpck_require__(7398); createDebug.destroy = destroy; Object.keys(env).forEach(key => { @@ -42243,7 +40217,7 @@ module.exports = setup; /***/ }), -/***/ 44126: +/***/ 93118: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { /** @@ -42252,15 +40226,15 @@ module.exports = setup; */ if (typeof process === 'undefined' || process.type === 'renderer' || process.browser === true || process.__nwjs) { - module.exports = __nccwpck_require__(38617); + module.exports = __nccwpck_require__(76674); } else { - module.exports = __nccwpck_require__(2202); + module.exports = __nccwpck_require__(37847); } /***/ }), -/***/ 2202: +/***/ 37847: /***/ ((module, exports, __nccwpck_require__) => { /** @@ -42294,7 +40268,7 @@ exports.colors = [6, 2, 3, 4, 5, 1]; try { // Optional dependency (as in, doesn't need to be installed, NOT like optionalDependencies in package.json) // eslint-disable-next-line import/no-extraneous-dependencies - const supportsColor = __nccwpck_require__(9679); + const supportsColor = __nccwpck_require__(26080); if (supportsColor && (supportsColor.stderr || supportsColor).level >= 2) { exports.colors = [ @@ -42502,7 +40476,7 @@ function init(debug) { } } -module.exports = __nccwpck_require__(50885)(exports); +module.exports = __nccwpck_require__(50923)(exports); const {formatters} = module.exports; @@ -42530,7 +40504,7 @@ formatters.O = function (v) { /***/ }), -/***/ 47375: +/***/ 9474: /***/ ((__unused_webpack_module, exports) => { "use strict"; @@ -42570,7 +40544,7 @@ function convertChangesToDMP(changes) { /***/ }), -/***/ 81828: +/***/ 67132: /***/ ((__unused_webpack_module, exports) => { "use strict"; @@ -42620,7 +40594,7 @@ function escapeHTML(s) { /***/ }), -/***/ 512: +/***/ 37475: /***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { "use strict"; @@ -42636,7 +40610,7 @@ exports.arrayDiff = void 0; /*istanbul ignore end*/ var /*istanbul ignore start*/ -_base = _interopRequireDefault(__nccwpck_require__(33385)) +_base = _interopRequireDefault(__nccwpck_require__(31095)) /*istanbul ignore end*/ ; @@ -42673,7 +40647,7 @@ function diffArrays(oldArr, newArr, callback) { /***/ }), -/***/ 33385: +/***/ 31095: /***/ ((__unused_webpack_module, exports) => { "use strict"; @@ -42985,7 +40959,7 @@ function clonePath(path) { /***/ }), -/***/ 58381: +/***/ 31045: /***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { "use strict"; @@ -43001,7 +40975,7 @@ exports.characterDiff = void 0; /*istanbul ignore end*/ var /*istanbul ignore start*/ -_base = _interopRequireDefault(__nccwpck_require__(33385)) +_base = _interopRequireDefault(__nccwpck_require__(31095)) /*istanbul ignore end*/ ; @@ -43030,7 +41004,7 @@ function diffChars(oldStr, newStr, options) { /***/ }), -/***/ 48802: +/***/ 56400: /***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { "use strict"; @@ -43046,7 +41020,7 @@ exports.cssDiff = void 0; /*istanbul ignore end*/ var /*istanbul ignore start*/ -_base = _interopRequireDefault(__nccwpck_require__(33385)) +_base = _interopRequireDefault(__nccwpck_require__(31095)) /*istanbul ignore end*/ ; @@ -43079,7 +41053,7 @@ function diffCss(oldStr, newStr, callback) { /***/ }), -/***/ 93818: +/***/ 75672: /***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { "use strict"; @@ -43096,13 +41070,13 @@ exports.jsonDiff = void 0; /*istanbul ignore end*/ var /*istanbul ignore start*/ -_base = _interopRequireDefault(__nccwpck_require__(33385)) +_base = _interopRequireDefault(__nccwpck_require__(31095)) /*istanbul ignore end*/ ; var /*istanbul ignore start*/ -_line = __nccwpck_require__(87234) +_line = __nccwpck_require__(60410) /*istanbul ignore end*/ ; @@ -43250,7 +41224,7 @@ function canonicalize(obj, stack, replacementStack, replacer, key) { /***/ }), -/***/ 87234: +/***/ 60410: /***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { "use strict"; @@ -43267,13 +41241,13 @@ exports.lineDiff = void 0; /*istanbul ignore end*/ var /*istanbul ignore start*/ -_base = _interopRequireDefault(__nccwpck_require__(33385)) +_base = _interopRequireDefault(__nccwpck_require__(31095)) /*istanbul ignore end*/ ; var /*istanbul ignore start*/ -_params = __nccwpck_require__(42308) +_params = __nccwpck_require__(35239) /*istanbul ignore end*/ ; @@ -43347,7 +41321,7 @@ function diffTrimmedLines(oldStr, newStr, callback) { /***/ }), -/***/ 47080: +/***/ 10320: /***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { "use strict"; @@ -43363,7 +41337,7 @@ exports.sentenceDiff = void 0; /*istanbul ignore end*/ var /*istanbul ignore start*/ -_base = _interopRequireDefault(__nccwpck_require__(33385)) +_base = _interopRequireDefault(__nccwpck_require__(31095)) /*istanbul ignore end*/ ; @@ -43396,7 +41370,7 @@ function diffSentences(oldStr, newStr, callback) { /***/ }), -/***/ 75496: +/***/ 74677: /***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { "use strict"; @@ -43413,13 +41387,13 @@ exports.wordDiff = void 0; /*istanbul ignore end*/ var /*istanbul ignore start*/ -_base = _interopRequireDefault(__nccwpck_require__(33385)) +_base = _interopRequireDefault(__nccwpck_require__(31095)) /*istanbul ignore end*/ ; var /*istanbul ignore start*/ -_params = __nccwpck_require__(42308) +_params = __nccwpck_require__(35239) /*istanbul ignore end*/ ; @@ -43511,7 +41485,7 @@ function diffWordsWithSpace(oldStr, newStr, options) { /***/ }), -/***/ 45604: +/***/ 95214: /***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { "use strict"; @@ -43645,85 +41619,85 @@ Object.defineProperty(exports, "convertChangesToXML", ({ /*istanbul ignore end*/ var /*istanbul ignore start*/ -_base = _interopRequireDefault(__nccwpck_require__(33385)) +_base = _interopRequireDefault(__nccwpck_require__(31095)) /*istanbul ignore end*/ ; var /*istanbul ignore start*/ -_character = __nccwpck_require__(58381) +_character = __nccwpck_require__(31045) /*istanbul ignore end*/ ; var /*istanbul ignore start*/ -_word = __nccwpck_require__(75496) +_word = __nccwpck_require__(74677) /*istanbul ignore end*/ ; var /*istanbul ignore start*/ -_line = __nccwpck_require__(87234) +_line = __nccwpck_require__(60410) /*istanbul ignore end*/ ; var /*istanbul ignore start*/ -_sentence = __nccwpck_require__(47080) +_sentence = __nccwpck_require__(10320) /*istanbul ignore end*/ ; var /*istanbul ignore start*/ -_css = __nccwpck_require__(48802) +_css = __nccwpck_require__(56400) /*istanbul ignore end*/ ; var /*istanbul ignore start*/ -_json = __nccwpck_require__(93818) +_json = __nccwpck_require__(75672) /*istanbul ignore end*/ ; var /*istanbul ignore start*/ -_array = __nccwpck_require__(512) +_array = __nccwpck_require__(37475) /*istanbul ignore end*/ ; var /*istanbul ignore start*/ -_apply = __nccwpck_require__(99960) +_apply = __nccwpck_require__(97505) /*istanbul ignore end*/ ; var /*istanbul ignore start*/ -_parse = __nccwpck_require__(99002) +_parse = __nccwpck_require__(4341) /*istanbul ignore end*/ ; var /*istanbul ignore start*/ -_merge = __nccwpck_require__(24545) +_merge = __nccwpck_require__(508) /*istanbul ignore end*/ ; var /*istanbul ignore start*/ -_create = __nccwpck_require__(12963) +_create = __nccwpck_require__(67450) /*istanbul ignore end*/ ; var /*istanbul ignore start*/ -_dmp = __nccwpck_require__(47375) +_dmp = __nccwpck_require__(9474) /*istanbul ignore end*/ ; var /*istanbul ignore start*/ -_xml = __nccwpck_require__(81828) +_xml = __nccwpck_require__(67132) /*istanbul ignore end*/ ; @@ -43735,7 +41709,7 @@ _xml = __nccwpck_require__(81828) /***/ }), -/***/ 99960: +/***/ 97505: /***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { "use strict"; @@ -43751,13 +41725,13 @@ exports.applyPatches = applyPatches; /*istanbul ignore end*/ var /*istanbul ignore start*/ -_parse = __nccwpck_require__(99002) +_parse = __nccwpck_require__(4341) /*istanbul ignore end*/ ; var /*istanbul ignore start*/ -_distanceIterator = _interopRequireDefault(__nccwpck_require__(89616)) +_distanceIterator = _interopRequireDefault(__nccwpck_require__(72368)) /*istanbul ignore end*/ ; @@ -43986,7 +41960,7 @@ function applyPatches(uniDiff, options) { /***/ }), -/***/ 12963: +/***/ 67450: /***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { "use strict"; @@ -44003,7 +41977,7 @@ exports.createPatch = createPatch; /*istanbul ignore end*/ var /*istanbul ignore start*/ -_line = __nccwpck_require__(87234) +_line = __nccwpck_require__(60410) /*istanbul ignore end*/ ; @@ -44241,7 +42215,7 @@ function createPatch(fileName, oldStr, newStr, oldHeader, newHeader, options) { /***/ }), -/***/ 24545: +/***/ 508: /***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { "use strict"; @@ -44257,19 +42231,19 @@ exports.merge = merge; /*istanbul ignore end*/ var /*istanbul ignore start*/ -_create = __nccwpck_require__(12963) +_create = __nccwpck_require__(67450) /*istanbul ignore end*/ ; var /*istanbul ignore start*/ -_parse = __nccwpck_require__(99002) +_parse = __nccwpck_require__(4341) /*istanbul ignore end*/ ; var /*istanbul ignore start*/ -_array = __nccwpck_require__(29773) +_array = __nccwpck_require__(39380) /*istanbul ignore end*/ ; @@ -44858,7 +42832,7 @@ function calcOldNewLineCount(lines) { /***/ }), -/***/ 99002: +/***/ 4341: /***/ ((__unused_webpack_module, exports) => { "use strict"; @@ -45022,7 +42996,7 @@ function parsePatch(uniDiff) { /***/ }), -/***/ 29773: +/***/ 39380: /***/ ((__unused_webpack_module, exports) => { "use strict"; @@ -45062,7 +43036,7 @@ function arrayStartsWith(array, start) { /***/ }), -/***/ 89616: +/***/ 72368: /***/ ((__unused_webpack_module, exports) => { "use strict"; @@ -45127,7 +43101,7 @@ _default /***/ }), -/***/ 42308: +/***/ 35239: /***/ ((__unused_webpack_module, exports) => { "use strict"; @@ -45159,10 +43133,10 @@ function generateOptions(options, defaults) { /***/ }), -/***/ 69867: +/***/ 44790: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { -var once = __nccwpck_require__(37909); +var once = __nccwpck_require__(63767); var noop = function() {}; @@ -45260,561 +43234,7 @@ module.exports = eos; /***/ }), -/***/ 32027: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { - -"use strict"; - - -/* eslint-disable no-var */ - -var reusify = __nccwpck_require__(36873) - -function fastqueue (context, worker, concurrency) { - if (typeof context === 'function') { - concurrency = worker - worker = context - context = null - } - - if (concurrency < 1) { - throw new Error('fastqueue concurrency must be greater than 1') - } - - var cache = reusify(Task) - var queueHead = null - var queueTail = null - var _running = 0 - var errorHandler = null - - var self = { - push: push, - drain: noop, - saturated: noop, - pause: pause, - paused: false, - concurrency: concurrency, - running: running, - resume: resume, - idle: idle, - length: length, - getQueue: getQueue, - unshift: unshift, - empty: noop, - kill: kill, - killAndDrain: killAndDrain, - error: error - } - - return self - - function running () { - return _running - } - - function pause () { - self.paused = true - } - - function length () { - var current = queueHead - var counter = 0 - - while (current) { - current = current.next - counter++ - } - - return counter - } - - function getQueue () { - var current = queueHead - var tasks = [] - - while (current) { - tasks.push(current.value) - current = current.next - } - - return tasks - } - - function resume () { - if (!self.paused) return - self.paused = false - for (var i = 0; i < self.concurrency; i++) { - _running++ - release() - } - } - - function idle () { - return _running === 0 && self.length() === 0 - } - - function push (value, done) { - var current = cache.get() - - current.context = context - current.release = release - current.value = value - current.callback = done || noop - current.errorHandler = errorHandler - - if (_running === self.concurrency || self.paused) { - if (queueTail) { - queueTail.next = current - queueTail = current - } else { - queueHead = current - queueTail = current - self.saturated() - } - } else { - _running++ - worker.call(context, current.value, current.worked) - } - } - - function unshift (value, done) { - var current = cache.get() - - current.context = context - current.release = release - current.value = value - current.callback = done || noop - - if (_running === self.concurrency || self.paused) { - if (queueHead) { - current.next = queueHead - queueHead = current - } else { - queueHead = current - queueTail = current - self.saturated() - } - } else { - _running++ - worker.call(context, current.value, current.worked) - } - } - - function release (holder) { - if (holder) { - cache.release(holder) - } - var next = queueHead - if (next) { - if (!self.paused) { - if (queueTail === queueHead) { - queueTail = null - } - queueHead = next.next - next.next = null - worker.call(context, next.value, next.worked) - if (queueTail === null) { - self.empty() - } - } else { - _running-- - } - } else if (--_running === 0) { - self.drain() - } - } - - function kill () { - queueHead = null - queueTail = null - self.drain = noop - } - - function killAndDrain () { - queueHead = null - queueTail = null - self.drain() - self.drain = noop - } - - function error (handler) { - errorHandler = handler - } -} - -function noop () {} - -function Task () { - this.value = null - this.callback = noop - this.next = null - this.release = noop - this.context = null - this.errorHandler = null - - var self = this - - this.worked = function worked (err, result) { - var callback = self.callback - var errorHandler = self.errorHandler - var val = self.value - self.value = null - self.callback = noop - if (self.errorHandler) { - errorHandler(err, val) - } - callback.call(self.context, err, result) - self.release(self) - } -} - -function queueAsPromised (context, worker, concurrency) { - if (typeof context === 'function') { - concurrency = worker - worker = context - context = null - } - - function asyncWrapper (arg, cb) { - worker.call(this, arg) - .then(function (res) { - cb(null, res) - }, cb) - } - - var queue = fastqueue(context, asyncWrapper, concurrency) - - var pushCb = queue.push - var unshiftCb = queue.unshift - - queue.push = push - queue.unshift = unshift - queue.drained = drained - - return queue - - function push (value) { - var p = new Promise(function (resolve, reject) { - pushCb(value, function (err, result) { - if (err) { - reject(err) - return - } - resolve(result) - }) - }) - - // Let's fork the promise chain to - // make the error bubble up to the user but - // not lead to a unhandledRejection - p.catch(noop) - - return p - } - - function unshift (value) { - var p = new Promise(function (resolve, reject) { - unshiftCb(value, function (err, result) { - if (err) { - reject(err) - return - } - resolve(result) - }) - }) - - // Let's fork the promise chain to - // make the error bubble up to the user but - // not lead to a unhandledRejection - p.catch(noop) - - return p - } - - function drained () { - if (queue.idle()) { - return new Promise(function (resolve) { - resolve() - }) - } - - var previousDrain = queue.drain - - var p = new Promise(function (resolve) { - queue.drain = function () { - previousDrain() - resolve() - } - }) - - return p - } -} - -module.exports = fastqueue -module.exports.promise = queueAsPromised - - -/***/ }), - -/***/ 12619: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { - -"use strict"; -/*! - * fill-range - * - * Copyright (c) 2014-present, Jon Schlinkert. - * Licensed under the MIT License. - */ - - - -const util = __nccwpck_require__(73837); -const toRegexRange = __nccwpck_require__(12085); - -const isObject = val => val !== null && typeof val === 'object' && !Array.isArray(val); - -const transform = toNumber => { - return value => toNumber === true ? Number(value) : String(value); -}; - -const isValidValue = value => { - return typeof value === 'number' || (typeof value === 'string' && value !== ''); -}; - -const isNumber = num => Number.isInteger(+num); - -const zeros = input => { - let value = `${input}`; - let index = -1; - if (value[0] === '-') value = value.slice(1); - if (value === '0') return false; - while (value[++index] === '0'); - return index > 0; -}; - -const stringify = (start, end, options) => { - if (typeof start === 'string' || typeof end === 'string') { - return true; - } - return options.stringify === true; -}; - -const pad = (input, maxLength, toNumber) => { - if (maxLength > 0) { - let dash = input[0] === '-' ? '-' : ''; - if (dash) input = input.slice(1); - input = (dash + input.padStart(dash ? maxLength - 1 : maxLength, '0')); - } - if (toNumber === false) { - return String(input); - } - return input; -}; - -const toMaxLen = (input, maxLength) => { - let negative = input[0] === '-' ? '-' : ''; - if (negative) { - input = input.slice(1); - maxLength--; - } - while (input.length < maxLength) input = '0' + input; - return negative ? ('-' + input) : input; -}; - -const toSequence = (parts, options) => { - parts.negatives.sort((a, b) => a < b ? -1 : a > b ? 1 : 0); - parts.positives.sort((a, b) => a < b ? -1 : a > b ? 1 : 0); - - let prefix = options.capture ? '' : '?:'; - let positives = ''; - let negatives = ''; - let result; - - if (parts.positives.length) { - positives = parts.positives.join('|'); - } - - if (parts.negatives.length) { - negatives = `-(${prefix}${parts.negatives.join('|')})`; - } - - if (positives && negatives) { - result = `${positives}|${negatives}`; - } else { - result = positives || negatives; - } - - if (options.wrap) { - return `(${prefix}${result})`; - } - - return result; -}; - -const toRange = (a, b, isNumbers, options) => { - if (isNumbers) { - return toRegexRange(a, b, { wrap: false, ...options }); - } - - let start = String.fromCharCode(a); - if (a === b) return start; - - let stop = String.fromCharCode(b); - return `[${start}-${stop}]`; -}; - -const toRegex = (start, end, options) => { - if (Array.isArray(start)) { - let wrap = options.wrap === true; - let prefix = options.capture ? '' : '?:'; - return wrap ? `(${prefix}${start.join('|')})` : start.join('|'); - } - return toRegexRange(start, end, options); -}; - -const rangeError = (...args) => { - return new RangeError('Invalid range arguments: ' + util.inspect(...args)); -}; - -const invalidRange = (start, end, options) => { - if (options.strictRanges === true) throw rangeError([start, end]); - return []; -}; - -const invalidStep = (step, options) => { - if (options.strictRanges === true) { - throw new TypeError(`Expected step "${step}" to be a number`); - } - return []; -}; - -const fillNumbers = (start, end, step = 1, options = {}) => { - let a = Number(start); - let b = Number(end); - - if (!Number.isInteger(a) || !Number.isInteger(b)) { - if (options.strictRanges === true) throw rangeError([start, end]); - return []; - } - - // fix negative zero - if (a === 0) a = 0; - if (b === 0) b = 0; - - let descending = a > b; - let startString = String(start); - let endString = String(end); - let stepString = String(step); - step = Math.max(Math.abs(step), 1); - - let padded = zeros(startString) || zeros(endString) || zeros(stepString); - let maxLen = padded ? Math.max(startString.length, endString.length, stepString.length) : 0; - let toNumber = padded === false && stringify(start, end, options) === false; - let format = options.transform || transform(toNumber); - - if (options.toRegex && step === 1) { - return toRange(toMaxLen(start, maxLen), toMaxLen(end, maxLen), true, options); - } - - let parts = { negatives: [], positives: [] }; - let push = num => parts[num < 0 ? 'negatives' : 'positives'].push(Math.abs(num)); - let range = []; - let index = 0; - - while (descending ? a >= b : a <= b) { - if (options.toRegex === true && step > 1) { - push(a); - } else { - range.push(pad(format(a, index), maxLen, toNumber)); - } - a = descending ? a - step : a + step; - index++; - } - - if (options.toRegex === true) { - return step > 1 - ? toSequence(parts, options) - : toRegex(range, null, { wrap: false, ...options }); - } - - return range; -}; - -const fillLetters = (start, end, step = 1, options = {}) => { - if ((!isNumber(start) && start.length > 1) || (!isNumber(end) && end.length > 1)) { - return invalidRange(start, end, options); - } - - - let format = options.transform || (val => String.fromCharCode(val)); - let a = `${start}`.charCodeAt(0); - let b = `${end}`.charCodeAt(0); - - let descending = a > b; - let min = Math.min(a, b); - let max = Math.max(a, b); - - if (options.toRegex && step === 1) { - return toRange(min, max, false, options); - } - - let range = []; - let index = 0; - - while (descending ? a >= b : a <= b) { - range.push(format(a, index)); - a = descending ? a - step : a + step; - index++; - } - - if (options.toRegex === true) { - return toRegex(range, null, { wrap: false, options }); - } - - return range; -}; - -const fill = (start, end, step, options = {}) => { - if (end == null && isValidValue(start)) { - return [start]; - } - - if (!isValidValue(start) || !isValidValue(end)) { - return invalidRange(start, end, options); - } - - if (typeof step === 'function') { - return fill(start, end, 1, { transform: step }); - } - - if (isObject(step)) { - return fill(start, end, 0, step); - } - - let opts = { ...options }; - if (opts.capture === true) opts.wrap = true; - step = step || opts.step || 1; - - if (!isNumber(step)) { - if (step != null && !isObject(step)) return invalidStep(step, opts); - return fill(start, end, 1, step); - } - - if (isNumber(start) && isNumber(end)) { - return fillNumbers(start, end, step, opts); - } - - return fillLetters(start, end, Math.max(Math.abs(step), 1), opts); -}; - -module.exports = fill; - - -/***/ }), - -/***/ 21978: +/***/ 69026: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { module.exports = (__nccwpck_require__(57147).constants) || __nccwpck_require__(22057) @@ -45822,7 +43242,7 @@ module.exports = (__nccwpck_require__(57147).constants) || __nccwpck_require__(2 /***/ }), -/***/ 45074: +/***/ 56318: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { module.exports = realpath @@ -45838,7 +43258,7 @@ var origRealpathSync = fs.realpathSync var version = process.version var ok = /^v[0-5]\./.test(version) -var old = __nccwpck_require__(11830) +var old = __nccwpck_require__(95086) function newError (er) { return er && er.syscall === 'realpath' && ( @@ -45895,7 +43315,7 @@ function unmonkeypatch () { /***/ }), -/***/ 11830: +/***/ 95086: /***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { // Copyright Joyent, Inc. and other Node contributors. @@ -46205,57 +43625,7 @@ exports.realpath = function realpath(p, cache, cb) { /***/ }), -/***/ 86420: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { - -"use strict"; - - -var isGlob = __nccwpck_require__(35411); -var pathPosixDirname = (__nccwpck_require__(71017).posix.dirname); -var isWin32 = (__nccwpck_require__(22037).platform)() === 'win32'; - -var slash = '/'; -var backslash = /\\/g; -var enclosure = /[\{\[].*[\}\]]$/; -var globby = /(^|[^\\])([\{\[]|\([^\)]+$)/; -var escaped = /\\([\!\*\?\|\[\]\(\)\{\}])/g; - -/** - * @param {string} str - * @param {Object} opts - * @param {boolean} [opts.flipBackslashes=true] - * @returns {string} - */ -module.exports = function globParent(str, opts) { - var options = Object.assign({ flipBackslashes: true }, opts); - - // flip windows path separators - if (options.flipBackslashes && isWin32 && str.indexOf(slash) < 0) { - str = str.replace(backslash, slash); - } - - // special case for strings ending in enclosure containing path separator - if (enclosure.test(str)) { - str += slash; - } - - // preserves full path in case of trailing path separator - str += 'a'; - - // remove path parts that are globby - do { - str = pathPosixDirname(str); - } while (isGlob(str) || globby.test(str)); - - // remove escape chars and return result - return str.replace(escaped, '$1'); -}; - - -/***/ }), - -/***/ 53434: +/***/ 94860: /***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { exports.setopts = setopts @@ -46272,8 +43642,8 @@ function ownProp (obj, field) { var fs = __nccwpck_require__(57147) var path = __nccwpck_require__(71017) -var minimatch = __nccwpck_require__(84546) -var isAbsolute = __nccwpck_require__(50124) +var minimatch = __nccwpck_require__(491) +var isAbsolute = __nccwpck_require__(76384) var Minimatch = minimatch.Minimatch function alphasort (a, b) { @@ -46500,7 +43870,7 @@ function childrenIgnored (self, path) { /***/ }), -/***/ 20557: +/***/ 69959: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { // Approach: @@ -46545,24 +43915,24 @@ function childrenIgnored (self, path) { module.exports = glob -var rp = __nccwpck_require__(45074) -var minimatch = __nccwpck_require__(84546) +var rp = __nccwpck_require__(56318) +var minimatch = __nccwpck_require__(491) var Minimatch = minimatch.Minimatch -var inherits = __nccwpck_require__(2868) +var inherits = __nccwpck_require__(76401) var EE = (__nccwpck_require__(82361).EventEmitter) var path = __nccwpck_require__(71017) var assert = __nccwpck_require__(39491) -var isAbsolute = __nccwpck_require__(50124) -var globSync = __nccwpck_require__(99278) -var common = __nccwpck_require__(53434) +var isAbsolute = __nccwpck_require__(76384) +var globSync = __nccwpck_require__(21498) +var common = __nccwpck_require__(94860) var setopts = common.setopts var ownProp = common.ownProp -var inflight = __nccwpck_require__(60629) +var inflight = __nccwpck_require__(88107) var util = __nccwpck_require__(73837) var childrenIgnored = common.childrenIgnored var isIgnored = common.isIgnored -var once = __nccwpck_require__(37909) +var once = __nccwpck_require__(63767) function glob (pattern, options, cb) { if (typeof options === 'function') cb = options, options = {} @@ -47297,21 +44667,21 @@ Glob.prototype._stat2 = function (f, abs, er, stat, cb) { /***/ }), -/***/ 99278: +/***/ 21498: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { module.exports = globSync globSync.GlobSync = GlobSync -var rp = __nccwpck_require__(45074) -var minimatch = __nccwpck_require__(84546) +var rp = __nccwpck_require__(56318) +var minimatch = __nccwpck_require__(491) var Minimatch = minimatch.Minimatch -var Glob = (__nccwpck_require__(20557).Glob) +var Glob = (__nccwpck_require__(69959).Glob) var util = __nccwpck_require__(73837) var path = __nccwpck_require__(71017) var assert = __nccwpck_require__(39491) -var isAbsolute = __nccwpck_require__(50124) -var common = __nccwpck_require__(53434) +var isAbsolute = __nccwpck_require__(76384) +var common = __nccwpck_require__(94860) var setopts = common.setopts var ownProp = common.ownProp var childrenIgnored = common.childrenIgnored @@ -47790,7 +45160,7 @@ GlobSync.prototype._makeAbs = function (f) { /***/ }), -/***/ 71316: +/***/ 83647: /***/ ((module) => { "use strict"; @@ -47821,13 +45191,13 @@ function clone (obj) { /***/ }), -/***/ 88285: +/***/ 59866: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { var fs = __nccwpck_require__(57147) -var polyfills = __nccwpck_require__(50142) -var legacy = __nccwpck_require__(66752) -var clone = __nccwpck_require__(71316) +var polyfills = __nccwpck_require__(71011) +var legacy = __nccwpck_require__(64356) +var clone = __nccwpck_require__(83647) var util = __nccwpck_require__(73837) @@ -48276,7 +45646,7 @@ function retry () { /***/ }), -/***/ 66752: +/***/ 64356: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { var Stream = (__nccwpck_require__(12781).Stream) @@ -48401,7 +45771,7 @@ function legacy (fs) { /***/ }), -/***/ 50142: +/***/ 71011: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { var constants = __nccwpck_require__(22057) @@ -48763,7 +46133,7 @@ function patch (fs) { /***/ }), -/***/ 97: +/***/ 87583: /***/ ((module) => { "use strict"; @@ -48779,7 +46149,7 @@ module.exports = (flag, argv = process.argv) => { /***/ }), -/***/ 98337: +/***/ 56508: /***/ ((module) => { // A simple implementation of make-array @@ -49404,12 +46774,12 @@ if ( /***/ }), -/***/ 60629: +/***/ 88107: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { -var wrappy = __nccwpck_require__(63180) +var wrappy = __nccwpck_require__(65173) var reqs = Object.create(null) -var once = __nccwpck_require__(37909) +var once = __nccwpck_require__(63767) module.exports = wrappy(inflight) @@ -49465,7 +46835,7 @@ function slice (args) { /***/ }), -/***/ 2868: +/***/ 76401: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { try { @@ -49475,13 +46845,13 @@ try { module.exports = util.inherits; } catch (e) { /* istanbul ignore next */ - module.exports = __nccwpck_require__(34278); + module.exports = __nccwpck_require__(15195); } /***/ }), -/***/ 34278: +/***/ 15195: /***/ ((module) => { if (typeof Object.create === 'function') { @@ -49515,199 +46885,15 @@ if (typeof Object.create === 'function') { /***/ }), -/***/ 10890: -/***/ ((module) => { - -/*! - * is-extglob - * - * Copyright (c) 2014-2016, Jon Schlinkert. - * Licensed under the MIT License. - */ - -module.exports = function isExtglob(str) { - if (typeof str !== 'string' || str === '') { - return false; - } - - var match; - while ((match = /(\\).|([@?!+*]\(.*\))/g.exec(str))) { - if (match[2]) return true; - str = str.slice(match.index + match[0].length); - } - - return false; -}; - - -/***/ }), - -/***/ 35411: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { - -/*! - * is-glob - * - * Copyright (c) 2014-2017, Jon Schlinkert. - * Released under the MIT License. - */ - -var isExtglob = __nccwpck_require__(10890); -var chars = { '{': '}', '(': ')', '[': ']'}; -var strictCheck = function(str) { - if (str[0] === '!') { - return true; - } - var index = 0; - var pipeIndex = -2; - var closeSquareIndex = -2; - var closeCurlyIndex = -2; - var closeParenIndex = -2; - var backSlashIndex = -2; - while (index < str.length) { - if (str[index] === '*') { - return true; - } - - if (str[index + 1] === '?' && /[\].+)]/.test(str[index])) { - return true; - } - - if (closeSquareIndex !== -1 && str[index] === '[' && str[index + 1] !== ']') { - if (closeSquareIndex < index) { - closeSquareIndex = str.indexOf(']', index); - } - if (closeSquareIndex > index) { - if (backSlashIndex === -1 || backSlashIndex > closeSquareIndex) { - return true; - } - backSlashIndex = str.indexOf('\\', index); - if (backSlashIndex === -1 || backSlashIndex > closeSquareIndex) { - return true; - } - } - } - - if (closeCurlyIndex !== -1 && str[index] === '{' && str[index + 1] !== '}') { - closeCurlyIndex = str.indexOf('}', index); - if (closeCurlyIndex > index) { - backSlashIndex = str.indexOf('\\', index); - if (backSlashIndex === -1 || backSlashIndex > closeCurlyIndex) { - return true; - } - } - } - - if (closeParenIndex !== -1 && str[index] === '(' && str[index + 1] === '?' && /[:!=]/.test(str[index + 2]) && str[index + 3] !== ')') { - closeParenIndex = str.indexOf(')', index); - if (closeParenIndex > index) { - backSlashIndex = str.indexOf('\\', index); - if (backSlashIndex === -1 || backSlashIndex > closeParenIndex) { - return true; - } - } - } - - if (pipeIndex !== -1 && str[index] === '(' && str[index + 1] !== '|') { - if (pipeIndex < index) { - pipeIndex = str.indexOf('|', index); - } - if (pipeIndex !== -1 && str[pipeIndex + 1] !== ')') { - closeParenIndex = str.indexOf(')', pipeIndex); - if (closeParenIndex > pipeIndex) { - backSlashIndex = str.indexOf('\\', pipeIndex); - if (backSlashIndex === -1 || backSlashIndex > closeParenIndex) { - return true; - } - } - } - } - - if (str[index] === '\\') { - var open = str[index + 1]; - index += 2; - var close = chars[open]; - - if (close) { - var n = str.indexOf(close, index); - if (n !== -1) { - index = n + 1; - } - } - - if (str[index] === '!') { - return true; - } - } else { - index++; - } - } - return false; -}; - -var relaxedCheck = function(str) { - if (str[0] === '!') { - return true; - } - var index = 0; - while (index < str.length) { - if (/[*?{}()[\]]/.test(str[index])) { - return true; - } - - if (str[index] === '\\') { - var open = str[index + 1]; - index += 2; - var close = chars[open]; - - if (close) { - var n = str.indexOf(close, index); - if (n !== -1) { - index = n + 1; - } - } - - if (str[index] === '!') { - return true; - } - } else { - index++; - } - } - return false; -}; - -module.exports = function isGlob(str, options) { - if (typeof str !== 'string' || str === '') { - return false; - } - - if (isExtglob(str)) { - return true; - } - - var check = strictCheck; - - // optionally relax check - if (options && options.strict === false) { - check = relaxedCheck; - } - - return check(str); -}; - - -/***/ }), - -/***/ 92595: +/***/ 45126: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { "use strict"; -var loader = __nccwpck_require__(61652); -var dumper = __nccwpck_require__(71136); +var loader = __nccwpck_require__(84199); +var dumper = __nccwpck_require__(78945); function renamed(from, to) { @@ -49718,32 +46904,32 @@ function renamed(from, to) { } -module.exports.Type = __nccwpck_require__(29957); -module.exports.Schema = __nccwpck_require__(28694); -module.exports.FAILSAFE_SCHEMA = __nccwpck_require__(85392); -module.exports.JSON_SCHEMA = __nccwpck_require__(75257); -module.exports.CORE_SCHEMA = __nccwpck_require__(15329); -module.exports.DEFAULT_SCHEMA = __nccwpck_require__(40142); +module.exports.Type = __nccwpck_require__(41646); +module.exports.Schema = __nccwpck_require__(58362); +module.exports.FAILSAFE_SCHEMA = __nccwpck_require__(5433); +module.exports.JSON_SCHEMA = __nccwpck_require__(49110); +module.exports.CORE_SCHEMA = __nccwpck_require__(66208); +module.exports.DEFAULT_SCHEMA = __nccwpck_require__(26625); module.exports.load = loader.load; module.exports.loadAll = loader.loadAll; module.exports.dump = dumper.dump; -module.exports.YAMLException = __nccwpck_require__(40674); +module.exports.YAMLException = __nccwpck_require__(61855); // Re-export all types in case user wants to create custom schema module.exports.types = { - binary: __nccwpck_require__(74451), - float: __nccwpck_require__(17137), - map: __nccwpck_require__(52978), - null: __nccwpck_require__(17743), - pairs: __nccwpck_require__(66592), - set: __nccwpck_require__(28060), - timestamp: __nccwpck_require__(10951), - bool: __nccwpck_require__(63548), - int: __nccwpck_require__(88461), - merge: __nccwpck_require__(85446), - omap: __nccwpck_require__(3461), - seq: __nccwpck_require__(69796), - str: __nccwpck_require__(47118) + binary: __nccwpck_require__(23647), + float: __nccwpck_require__(5258), + map: __nccwpck_require__(68765), + null: __nccwpck_require__(43016), + pairs: __nccwpck_require__(71369), + set: __nccwpck_require__(80346), + timestamp: __nccwpck_require__(81787), + bool: __nccwpck_require__(15767), + int: __nccwpck_require__(43225), + merge: __nccwpck_require__(61551), + omap: __nccwpck_require__(25111), + seq: __nccwpck_require__(18498), + str: __nccwpck_require__(64145) }; // Removed functions from JS-YAML 3.0.x @@ -49754,7 +46940,7 @@ module.exports.safeDump = renamed('safeDump', 'dump'); /***/ }), -/***/ 49647: +/***/ 6731: /***/ ((module) => { "use strict"; @@ -49821,7 +47007,7 @@ module.exports.extend = extend; /***/ }), -/***/ 71136: +/***/ 78945: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { "use strict"; @@ -49829,9 +47015,9 @@ module.exports.extend = extend; /*eslint-disable no-use-before-define*/ -var common = __nccwpck_require__(49647); -var YAMLException = __nccwpck_require__(40674); -var DEFAULT_SCHEMA = __nccwpck_require__(40142); +var common = __nccwpck_require__(6731); +var YAMLException = __nccwpck_require__(61855); +var DEFAULT_SCHEMA = __nccwpck_require__(26625); var _toString = Object.prototype.toString; var _hasOwnProperty = Object.prototype.hasOwnProperty; @@ -50794,7 +47980,7 @@ module.exports.dump = dump; /***/ }), -/***/ 40674: +/***/ 61855: /***/ ((module) => { "use strict"; @@ -50857,7 +48043,7 @@ module.exports = YAMLException; /***/ }), -/***/ 61652: +/***/ 84199: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { "use strict"; @@ -50865,10 +48051,10 @@ module.exports = YAMLException; /*eslint-disable max-len,no-use-before-define*/ -var common = __nccwpck_require__(49647); -var YAMLException = __nccwpck_require__(40674); -var makeSnippet = __nccwpck_require__(65229); -var DEFAULT_SCHEMA = __nccwpck_require__(40142); +var common = __nccwpck_require__(6731); +var YAMLException = __nccwpck_require__(61855); +var makeSnippet = __nccwpck_require__(90324); +var DEFAULT_SCHEMA = __nccwpck_require__(26625); var _hasOwnProperty = Object.prototype.hasOwnProperty; @@ -52592,7 +49778,7 @@ module.exports.load = load; /***/ }), -/***/ 28694: +/***/ 58362: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { "use strict"; @@ -52600,8 +49786,8 @@ module.exports.load = load; /*eslint-disable max-len*/ -var YAMLException = __nccwpck_require__(40674); -var Type = __nccwpck_require__(29957); +var YAMLException = __nccwpck_require__(61855); +var Type = __nccwpck_require__(41646); function compileList(schema, name) { @@ -52721,7 +49907,7 @@ module.exports = Schema; /***/ }), -/***/ 15329: +/***/ 66208: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { "use strict"; @@ -52735,12 +49921,12 @@ module.exports = Schema; -module.exports = __nccwpck_require__(75257); +module.exports = __nccwpck_require__(49110); /***/ }), -/***/ 40142: +/***/ 26625: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { "use strict"; @@ -52754,23 +49940,23 @@ module.exports = __nccwpck_require__(75257); -module.exports = (__nccwpck_require__(15329).extend)({ +module.exports = (__nccwpck_require__(66208).extend)({ implicit: [ - __nccwpck_require__(10951), - __nccwpck_require__(85446) + __nccwpck_require__(81787), + __nccwpck_require__(61551) ], explicit: [ - __nccwpck_require__(74451), - __nccwpck_require__(3461), - __nccwpck_require__(66592), - __nccwpck_require__(28060) + __nccwpck_require__(23647), + __nccwpck_require__(25111), + __nccwpck_require__(71369), + __nccwpck_require__(80346) ] }); /***/ }), -/***/ 85392: +/***/ 5433: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { "use strict"; @@ -52781,21 +49967,21 @@ module.exports = (__nccwpck_require__(15329).extend)({ -var Schema = __nccwpck_require__(28694); +var Schema = __nccwpck_require__(58362); module.exports = new Schema({ explicit: [ - __nccwpck_require__(47118), - __nccwpck_require__(69796), - __nccwpck_require__(52978) + __nccwpck_require__(64145), + __nccwpck_require__(18498), + __nccwpck_require__(68765) ] }); /***/ }), -/***/ 75257: +/***/ 49110: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { "use strict"; @@ -52810,26 +49996,26 @@ module.exports = new Schema({ -module.exports = (__nccwpck_require__(85392).extend)({ +module.exports = (__nccwpck_require__(5433).extend)({ implicit: [ - __nccwpck_require__(17743), - __nccwpck_require__(63548), - __nccwpck_require__(88461), - __nccwpck_require__(17137) + __nccwpck_require__(43016), + __nccwpck_require__(15767), + __nccwpck_require__(43225), + __nccwpck_require__(5258) ] }); /***/ }), -/***/ 65229: +/***/ 90324: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { "use strict"; -var common = __nccwpck_require__(49647); +var common = __nccwpck_require__(6731); // get snippet for a single line, respecting maxLength @@ -52931,13 +50117,13 @@ module.exports = makeSnippet; /***/ }), -/***/ 29957: +/***/ 41646: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { "use strict"; -var YAMLException = __nccwpck_require__(40674); +var YAMLException = __nccwpck_require__(61855); var TYPE_CONSTRUCTOR_OPTIONS = [ 'kind', @@ -53005,7 +50191,7 @@ module.exports = Type; /***/ }), -/***/ 74451: +/***/ 23647: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { "use strict"; @@ -53014,7 +50200,7 @@ module.exports = Type; /*eslint-disable no-bitwise*/ -var Type = __nccwpck_require__(29957); +var Type = __nccwpck_require__(41646); // [ 64, 65, 66 ] -> [ padding, CR, LF ] @@ -53138,13 +50324,13 @@ module.exports = new Type('tag:yaml.org,2002:binary', { /***/ }), -/***/ 63548: +/***/ 15767: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { "use strict"; -var Type = __nccwpck_require__(29957); +var Type = __nccwpck_require__(41646); function resolveYamlBoolean(data) { if (data === null) return false; @@ -53181,14 +50367,14 @@ module.exports = new Type('tag:yaml.org,2002:bool', { /***/ }), -/***/ 17137: +/***/ 5258: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { "use strict"; -var common = __nccwpck_require__(49647); -var Type = __nccwpck_require__(29957); +var common = __nccwpck_require__(6731); +var Type = __nccwpck_require__(41646); var YAML_FLOAT_PATTERN = new RegExp( // 2.5e4, 2.5 and integers @@ -53286,14 +50472,14 @@ module.exports = new Type('tag:yaml.org,2002:float', { /***/ }), -/***/ 88461: +/***/ 43225: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { "use strict"; -var common = __nccwpck_require__(49647); -var Type = __nccwpck_require__(29957); +var common = __nccwpck_require__(6731); +var Type = __nccwpck_require__(41646); function isHexCode(c) { return ((0x30/* 0 */ <= c) && (c <= 0x39/* 9 */)) || @@ -53450,13 +50636,13 @@ module.exports = new Type('tag:yaml.org,2002:int', { /***/ }), -/***/ 52978: +/***/ 68765: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { "use strict"; -var Type = __nccwpck_require__(29957); +var Type = __nccwpck_require__(41646); module.exports = new Type('tag:yaml.org,2002:map', { kind: 'mapping', @@ -53466,13 +50652,13 @@ module.exports = new Type('tag:yaml.org,2002:map', { /***/ }), -/***/ 85446: +/***/ 61551: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { "use strict"; -var Type = __nccwpck_require__(29957); +var Type = __nccwpck_require__(41646); function resolveYamlMerge(data) { return data === '<<' || data === null; @@ -53486,13 +50672,13 @@ module.exports = new Type('tag:yaml.org,2002:merge', { /***/ }), -/***/ 17743: +/***/ 43016: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { "use strict"; -var Type = __nccwpck_require__(29957); +var Type = __nccwpck_require__(41646); function resolveYamlNull(data) { if (data === null) return true; @@ -53529,13 +50715,13 @@ module.exports = new Type('tag:yaml.org,2002:null', { /***/ }), -/***/ 3461: +/***/ 25111: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { "use strict"; -var Type = __nccwpck_require__(29957); +var Type = __nccwpck_require__(41646); var _hasOwnProperty = Object.prototype.hasOwnProperty; var _toString = Object.prototype.toString; @@ -53581,13 +50767,13 @@ module.exports = new Type('tag:yaml.org,2002:omap', { /***/ }), -/***/ 66592: +/***/ 71369: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { "use strict"; -var Type = __nccwpck_require__(29957); +var Type = __nccwpck_require__(41646); var _toString = Object.prototype.toString; @@ -53642,13 +50828,13 @@ module.exports = new Type('tag:yaml.org,2002:pairs', { /***/ }), -/***/ 69796: +/***/ 18498: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { "use strict"; -var Type = __nccwpck_require__(29957); +var Type = __nccwpck_require__(41646); module.exports = new Type('tag:yaml.org,2002:seq', { kind: 'sequence', @@ -53658,13 +50844,13 @@ module.exports = new Type('tag:yaml.org,2002:seq', { /***/ }), -/***/ 28060: +/***/ 80346: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { "use strict"; -var Type = __nccwpck_require__(29957); +var Type = __nccwpck_require__(41646); var _hasOwnProperty = Object.prototype.hasOwnProperty; @@ -53695,13 +50881,13 @@ module.exports = new Type('tag:yaml.org,2002:set', { /***/ }), -/***/ 47118: +/***/ 64145: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { "use strict"; -var Type = __nccwpck_require__(29957); +var Type = __nccwpck_require__(41646); module.exports = new Type('tag:yaml.org,2002:str', { kind: 'scalar', @@ -53711,13 +50897,13 @@ module.exports = new Type('tag:yaml.org,2002:str', { /***/ }), -/***/ 10951: +/***/ 81787: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { "use strict"; -var Type = __nccwpck_require__(29957); +var Type = __nccwpck_require__(41646); var YAML_DATE_REGEXP = new RegExp( '^([0-9][0-9][0-9][0-9])' + // [1] year @@ -53807,11 +50993,11 @@ module.exports = new Type('tag:yaml.org,2002:timestamp', { /***/ }), -/***/ 89501: +/***/ 29941: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { -const parse = __nccwpck_require__(94362) -const stringify = __nccwpck_require__(11686) +const parse = __nccwpck_require__(84575) +const stringify = __nccwpck_require__(38193) const JSON5 = { parse, @@ -53823,10 +51009,10 @@ module.exports = JSON5 /***/ }), -/***/ 94362: +/***/ 84575: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { -const util = __nccwpck_require__(46400) +const util = __nccwpck_require__(70040) let source let parseState @@ -54944,10 +52130,10 @@ function syntaxError (message) { /***/ }), -/***/ 11686: +/***/ 38193: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { -const util = __nccwpck_require__(46400) +const util = __nccwpck_require__(70040) module.exports = function stringify (value, replacer, space) { const stack = [] @@ -55212,7 +52398,7 @@ module.exports = function stringify (value, replacer, space) { /***/ }), -/***/ 43366: +/***/ 90424: /***/ ((module) => { // This is a generated file. Do not edit. @@ -55223,10 +52409,10 @@ module.exports.ID_Continue = /[\xAA\xB5\xBA\xC0-\xD6\xD8-\xF6\xF8-\u02C1\u02C6-\ /***/ }), -/***/ 46400: +/***/ 70040: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { -const unicode = __nccwpck_require__(43366) +const unicode = __nccwpck_require__(90424) module.exports = { isSpaceSeparator (c) { @@ -55265,7 +52451,7 @@ module.exports = { /***/ }), -/***/ 99810: +/***/ 25515: /***/ ((module, exports, __nccwpck_require__) => { (function (factory) { @@ -55284,8 +52470,8 @@ module.exports = { 'use strict'; Object.defineProperty(exports, "__esModule", ({ value: true })); exports.isWS = exports.applyEdit = exports.setProperty = exports.removeProperty = void 0; - const format_1 = __nccwpck_require__(22018); - const parser_1 = __nccwpck_require__(22622); + const format_1 = __nccwpck_require__(37985); + const parser_1 = __nccwpck_require__(21169); function removeProperty(text, path, options) { return setProperty(text, path, void 0, options); } @@ -55473,7 +52659,7 @@ module.exports = { /***/ }), -/***/ 22018: +/***/ 37985: /***/ ((module, exports, __nccwpck_require__) => { (function (factory) { @@ -55492,7 +52678,7 @@ module.exports = { 'use strict'; Object.defineProperty(exports, "__esModule", ({ value: true })); exports.isEOL = exports.format = void 0; - const scanner_1 = __nccwpck_require__(78859); + const scanner_1 = __nccwpck_require__(16044); function format(documentText, range, options) { let initialIndentLevel; let formatText; @@ -55745,7 +52931,7 @@ module.exports = { /***/ }), -/***/ 22622: +/***/ 21169: /***/ ((module, exports, __nccwpck_require__) => { (function (factory) { @@ -55764,7 +52950,7 @@ module.exports = { 'use strict'; Object.defineProperty(exports, "__esModule", ({ value: true })); exports.getNodeType = exports.stripComments = exports.visit = exports.findNodeAtOffset = exports.contains = exports.getNodeValue = exports.getNodePath = exports.findNodeAtLocation = exports.parseTree = exports.parse = exports.getLocation = void 0; - const scanner_1 = __nccwpck_require__(78859); + const scanner_1 = __nccwpck_require__(16044); var ParseOptions; (function (ParseOptions) { ParseOptions.DEFAULT = { @@ -56407,7 +53593,7 @@ module.exports = { /***/ }), -/***/ 78859: +/***/ 16044: /***/ ((module, exports) => { (function (factory) { @@ -56870,7 +54056,7 @@ module.exports = { /***/ }), -/***/ 56416: +/***/ 18875: /***/ ((module, exports, __nccwpck_require__) => { (function (factory) { @@ -56889,10 +54075,10 @@ module.exports = { 'use strict'; Object.defineProperty(exports, "__esModule", ({ value: true })); exports.applyEdits = exports.modify = exports.format = exports.printParseErrorCode = exports.ParseErrorCode = exports.stripComments = exports.visit = exports.getNodeValue = exports.getNodePath = exports.findNodeAtOffset = exports.findNodeAtLocation = exports.parseTree = exports.parse = exports.getLocation = exports.SyntaxKind = exports.ScanError = exports.createScanner = void 0; - const formatter = __nccwpck_require__(22018); - const edit = __nccwpck_require__(99810); - const scanner = __nccwpck_require__(78859); - const parser = __nccwpck_require__(22622); + const formatter = __nccwpck_require__(37985); + const edit = __nccwpck_require__(25515); + const scanner = __nccwpck_require__(16044); + const parser = __nccwpck_require__(21169); /** * Creates a JSON scanner on the given text. * If ignoreTrivia is set, whitespaces or comments are ignored. @@ -57071,17 +54257,17 @@ module.exports = { /***/ }), -/***/ 77681: +/***/ 3653: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { let _fs try { - _fs = __nccwpck_require__(88285) + _fs = __nccwpck_require__(59866) } catch (_) { _fs = __nccwpck_require__(57147) } -const universalify = __nccwpck_require__(82787) -const { stringify, stripBom } = __nccwpck_require__(47667) +const universalify = __nccwpck_require__(63931) +const { stringify, stripBom } = __nccwpck_require__(13379) async function _readFile (file, options = {}) { if (typeof options === 'string') { @@ -57166,7 +54352,7 @@ module.exports = jsonfile /***/ }), -/***/ 47667: +/***/ 13379: /***/ ((module) => { function stringify (obj, { EOL = '\n', finalEOL = true, replacer = null, spaces } = {}) { @@ -57187,14 +54373,14 @@ module.exports = { stringify, stripBom } /***/ }), -/***/ 83617: +/***/ 17963: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { "use strict"; // A linked list to keep track of recently-used-ness -const Yallist = __nccwpck_require__(19385) +const Yallist = __nccwpck_require__(83278) const MAX = Symbol('max') const LENGTH = Symbol('length') @@ -57529,7 +54715,7 @@ module.exports = LRUCache /***/ }), -/***/ 80976: +/***/ 46419: /***/ ((module, exports) => { "use strict"; @@ -57688,634 +54874,7 @@ exports.BaseError = BaseError; /***/ }), -/***/ 30268: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { - -"use strict"; - -/* - * merge2 - * https://github.com/teambition/merge2 - * - * Copyright (c) 2014-2020 Teambition - * Licensed under the MIT license. - */ -const Stream = __nccwpck_require__(12781) -const PassThrough = Stream.PassThrough -const slice = Array.prototype.slice - -module.exports = merge2 - -function merge2 () { - const streamsQueue = [] - const args = slice.call(arguments) - let merging = false - let options = args[args.length - 1] - - if (options && !Array.isArray(options) && options.pipe == null) { - args.pop() - } else { - options = {} - } - - const doEnd = options.end !== false - const doPipeError = options.pipeError === true - if (options.objectMode == null) { - options.objectMode = true - } - if (options.highWaterMark == null) { - options.highWaterMark = 64 * 1024 - } - const mergedStream = PassThrough(options) - - function addStream () { - for (let i = 0, len = arguments.length; i < len; i++) { - streamsQueue.push(pauseStreams(arguments[i], options)) - } - mergeStream() - return this - } - - function mergeStream () { - if (merging) { - return - } - merging = true - - let streams = streamsQueue.shift() - if (!streams) { - process.nextTick(endStream) - return - } - if (!Array.isArray(streams)) { - streams = [streams] - } - - let pipesCount = streams.length + 1 - - function next () { - if (--pipesCount > 0) { - return - } - merging = false - mergeStream() - } - - function pipe (stream) { - function onend () { - stream.removeListener('merge2UnpipeEnd', onend) - stream.removeListener('end', onend) - if (doPipeError) { - stream.removeListener('error', onerror) - } - next() - } - function onerror (err) { - mergedStream.emit('error', err) - } - // skip ended stream - if (stream._readableState.endEmitted) { - return next() - } - - stream.on('merge2UnpipeEnd', onend) - stream.on('end', onend) - - if (doPipeError) { - stream.on('error', onerror) - } - - stream.pipe(mergedStream, { end: false }) - // compatible for old stream - stream.resume() - } - - for (let i = 0; i < streams.length; i++) { - pipe(streams[i]) - } - - next() - } - - function endStream () { - merging = false - // emit 'queueDrain' when all streams merged. - mergedStream.emit('queueDrain') - if (doEnd) { - mergedStream.end() - } - } - - mergedStream.setMaxListeners(0) - mergedStream.add = addStream - mergedStream.on('unpipe', function (stream) { - stream.emit('merge2UnpipeEnd') - }) - - if (args.length) { - addStream.apply(null, args) - } - return mergedStream -} - -// check and pause streams for pipe. -function pauseStreams (streams, options) { - if (!Array.isArray(streams)) { - // Backwards-compat with old-style streams - if (!streams._readableState && streams.pipe) { - streams = streams.pipe(PassThrough(options)) - } - if (!streams._readableState || !streams.pause || !streams.pipe) { - throw new Error('Only readable stream can be merged.') - } - streams.pause() - } else { - for (let i = 0, len = streams.length; i < len; i++) { - streams[i] = pauseStreams(streams[i], options) - } - } - return streams -} - - -/***/ }), - -/***/ 99573: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { - -"use strict"; - - -const util = __nccwpck_require__(73837); -const braces = __nccwpck_require__(2473); -const picomatch = __nccwpck_require__(21224); -const utils = __nccwpck_require__(76088); -const isEmptyString = val => val === '' || val === './'; - -/** - * Returns an array of strings that match one or more glob patterns. - * - * ```js - * const mm = require('micromatch'); - * // mm(list, patterns[, options]); - * - * console.log(mm(['a.js', 'a.txt'], ['*.js'])); - * //=> [ 'a.js' ] - * ``` - * @param {String|Array} `list` List of strings to match. - * @param {String|Array} `patterns` One or more glob patterns to use for matching. - * @param {Object} `options` See available [options](#options) - * @return {Array} Returns an array of matches - * @summary false - * @api public - */ - -const micromatch = (list, patterns, options) => { - patterns = [].concat(patterns); - list = [].concat(list); - - let omit = new Set(); - let keep = new Set(); - let items = new Set(); - let negatives = 0; - - let onResult = state => { - items.add(state.output); - if (options && options.onResult) { - options.onResult(state); - } - }; - - for (let i = 0; i < patterns.length; i++) { - let isMatch = picomatch(String(patterns[i]), { ...options, onResult }, true); - let negated = isMatch.state.negated || isMatch.state.negatedExtglob; - if (negated) negatives++; - - for (let item of list) { - let matched = isMatch(item, true); - - let match = negated ? !matched.isMatch : matched.isMatch; - if (!match) continue; - - if (negated) { - omit.add(matched.output); - } else { - omit.delete(matched.output); - keep.add(matched.output); - } - } - } - - let result = negatives === patterns.length ? [...items] : [...keep]; - let matches = result.filter(item => !omit.has(item)); - - if (options && matches.length === 0) { - if (options.failglob === true) { - throw new Error(`No matches found for "${patterns.join(', ')}"`); - } - - if (options.nonull === true || options.nullglob === true) { - return options.unescape ? patterns.map(p => p.replace(/\\/g, '')) : patterns; - } - } - - return matches; -}; - -/** - * Backwards compatibility - */ - -micromatch.match = micromatch; - -/** - * Returns a matcher function from the given glob `pattern` and `options`. - * The returned function takes a string to match as its only argument and returns - * true if the string is a match. - * - * ```js - * const mm = require('micromatch'); - * // mm.matcher(pattern[, options]); - * - * const isMatch = mm.matcher('*.!(*a)'); - * console.log(isMatch('a.a')); //=> false - * console.log(isMatch('a.b')); //=> true - * ``` - * @param {String} `pattern` Glob pattern - * @param {Object} `options` - * @return {Function} Returns a matcher function. - * @api public - */ - -micromatch.matcher = (pattern, options) => picomatch(pattern, options); - -/** - * Returns true if **any** of the given glob `patterns` match the specified `string`. - * - * ```js - * const mm = require('micromatch'); - * // mm.isMatch(string, patterns[, options]); - * - * console.log(mm.isMatch('a.a', ['b.*', '*.a'])); //=> true - * console.log(mm.isMatch('a.a', 'b.*')); //=> false - * ``` - * @param {String} `str` The string to test. - * @param {String|Array} `patterns` One or more glob patterns to use for matching. - * @param {Object} `[options]` See available [options](#options). - * @return {Boolean} Returns true if any patterns match `str` - * @api public - */ - -micromatch.isMatch = (str, patterns, options) => picomatch(patterns, options)(str); - -/** - * Backwards compatibility - */ - -micromatch.any = micromatch.isMatch; - -/** - * Returns a list of strings that _**do not match any**_ of the given `patterns`. - * - * ```js - * const mm = require('micromatch'); - * // mm.not(list, patterns[, options]); - * - * console.log(mm.not(['a.a', 'b.b', 'c.c'], '*.a')); - * //=> ['b.b', 'c.c'] - * ``` - * @param {Array} `list` Array of strings to match. - * @param {String|Array} `patterns` One or more glob pattern to use for matching. - * @param {Object} `options` See available [options](#options) for changing how matches are performed - * @return {Array} Returns an array of strings that **do not match** the given patterns. - * @api public - */ - -micromatch.not = (list, patterns, options = {}) => { - patterns = [].concat(patterns).map(String); - let result = new Set(); - let items = []; - - let onResult = state => { - if (options.onResult) options.onResult(state); - items.push(state.output); - }; - - let matches = new Set(micromatch(list, patterns, { ...options, onResult })); - - for (let item of items) { - if (!matches.has(item)) { - result.add(item); - } - } - return [...result]; -}; - -/** - * Returns true if the given `string` contains the given pattern. Similar - * to [.isMatch](#isMatch) but the pattern can match any part of the string. - * - * ```js - * var mm = require('micromatch'); - * // mm.contains(string, pattern[, options]); - * - * console.log(mm.contains('aa/bb/cc', '*b')); - * //=> true - * console.log(mm.contains('aa/bb/cc', '*d')); - * //=> false - * ``` - * @param {String} `str` The string to match. - * @param {String|Array} `patterns` Glob pattern to use for matching. - * @param {Object} `options` See available [options](#options) for changing how matches are performed - * @return {Boolean} Returns true if any of the patterns matches any part of `str`. - * @api public - */ - -micromatch.contains = (str, pattern, options) => { - if (typeof str !== 'string') { - throw new TypeError(`Expected a string: "${util.inspect(str)}"`); - } - - if (Array.isArray(pattern)) { - return pattern.some(p => micromatch.contains(str, p, options)); - } - - if (typeof pattern === 'string') { - if (isEmptyString(str) || isEmptyString(pattern)) { - return false; - } - - if (str.includes(pattern) || (str.startsWith('./') && str.slice(2).includes(pattern))) { - return true; - } - } - - return micromatch.isMatch(str, pattern, { ...options, contains: true }); -}; - -/** - * Filter the keys of the given object with the given `glob` pattern - * and `options`. Does not attempt to match nested keys. If you need this feature, - * use [glob-object][] instead. - * - * ```js - * const mm = require('micromatch'); - * // mm.matchKeys(object, patterns[, options]); - * - * const obj = { aa: 'a', ab: 'b', ac: 'c' }; - * console.log(mm.matchKeys(obj, '*b')); - * //=> { ab: 'b' } - * ``` - * @param {Object} `object` The object with keys to filter. - * @param {String|Array} `patterns` One or more glob patterns to use for matching. - * @param {Object} `options` See available [options](#options) for changing how matches are performed - * @return {Object} Returns an object with only keys that match the given patterns. - * @api public - */ - -micromatch.matchKeys = (obj, patterns, options) => { - if (!utils.isObject(obj)) { - throw new TypeError('Expected the first argument to be an object'); - } - let keys = micromatch(Object.keys(obj), patterns, options); - let res = {}; - for (let key of keys) res[key] = obj[key]; - return res; -}; - -/** - * Returns true if some of the strings in the given `list` match any of the given glob `patterns`. - * - * ```js - * const mm = require('micromatch'); - * // mm.some(list, patterns[, options]); - * - * console.log(mm.some(['foo.js', 'bar.js'], ['*.js', '!foo.js'])); - * // true - * console.log(mm.some(['foo.js'], ['*.js', '!foo.js'])); - * // false - * ``` - * @param {String|Array} `list` The string or array of strings to test. Returns as soon as the first match is found. - * @param {String|Array} `patterns` One or more glob patterns to use for matching. - * @param {Object} `options` See available [options](#options) for changing how matches are performed - * @return {Boolean} Returns true if any `patterns` matches any of the strings in `list` - * @api public - */ - -micromatch.some = (list, patterns, options) => { - let items = [].concat(list); - - for (let pattern of [].concat(patterns)) { - let isMatch = picomatch(String(pattern), options); - if (items.some(item => isMatch(item))) { - return true; - } - } - return false; -}; - -/** - * Returns true if every string in the given `list` matches - * any of the given glob `patterns`. - * - * ```js - * const mm = require('micromatch'); - * // mm.every(list, patterns[, options]); - * - * console.log(mm.every('foo.js', ['foo.js'])); - * // true - * console.log(mm.every(['foo.js', 'bar.js'], ['*.js'])); - * // true - * console.log(mm.every(['foo.js', 'bar.js'], ['*.js', '!foo.js'])); - * // false - * console.log(mm.every(['foo.js'], ['*.js', '!foo.js'])); - * // false - * ``` - * @param {String|Array} `list` The string or array of strings to test. - * @param {String|Array} `patterns` One or more glob patterns to use for matching. - * @param {Object} `options` See available [options](#options) for changing how matches are performed - * @return {Boolean} Returns true if all `patterns` matches all of the strings in `list` - * @api public - */ - -micromatch.every = (list, patterns, options) => { - let items = [].concat(list); - - for (let pattern of [].concat(patterns)) { - let isMatch = picomatch(String(pattern), options); - if (!items.every(item => isMatch(item))) { - return false; - } - } - return true; -}; - -/** - * Returns true if **all** of the given `patterns` match - * the specified string. - * - * ```js - * const mm = require('micromatch'); - * // mm.all(string, patterns[, options]); - * - * console.log(mm.all('foo.js', ['foo.js'])); - * // true - * - * console.log(mm.all('foo.js', ['*.js', '!foo.js'])); - * // false - * - * console.log(mm.all('foo.js', ['*.js', 'foo.js'])); - * // true - * - * console.log(mm.all('foo.js', ['*.js', 'f*', '*o*', '*o.js'])); - * // true - * ``` - * @param {String|Array} `str` The string to test. - * @param {String|Array} `patterns` One or more glob patterns to use for matching. - * @param {Object} `options` See available [options](#options) for changing how matches are performed - * @return {Boolean} Returns true if any patterns match `str` - * @api public - */ - -micromatch.all = (str, patterns, options) => { - if (typeof str !== 'string') { - throw new TypeError(`Expected a string: "${util.inspect(str)}"`); - } - - return [].concat(patterns).every(p => picomatch(p, options)(str)); -}; - -/** - * Returns an array of matches captured by `pattern` in `string, or `null` if the pattern did not match. - * - * ```js - * const mm = require('micromatch'); - * // mm.capture(pattern, string[, options]); - * - * console.log(mm.capture('test/*.js', 'test/foo.js')); - * //=> ['foo'] - * console.log(mm.capture('test/*.js', 'foo/bar.css')); - * //=> null - * ``` - * @param {String} `glob` Glob pattern to use for matching. - * @param {String} `input` String to match - * @param {Object} `options` See available [options](#options) for changing how matches are performed - * @return {Array|null} Returns an array of captures if the input matches the glob pattern, otherwise `null`. - * @api public - */ - -micromatch.capture = (glob, input, options) => { - let posix = utils.isWindows(options); - let regex = picomatch.makeRe(String(glob), { ...options, capture: true }); - let match = regex.exec(posix ? utils.toPosixSlashes(input) : input); - - if (match) { - return match.slice(1).map(v => v === void 0 ? '' : v); - } -}; - -/** - * Create a regular expression from the given glob `pattern`. - * - * ```js - * const mm = require('micromatch'); - * // mm.makeRe(pattern[, options]); - * - * console.log(mm.makeRe('*.js')); - * //=> /^(?:(\.[\\\/])?(?!\.)(?=.)[^\/]*?\.js)$/ - * ``` - * @param {String} `pattern` A glob pattern to convert to regex. - * @param {Object} `options` - * @return {RegExp} Returns a regex created from the given pattern. - * @api public - */ - -micromatch.makeRe = (...args) => picomatch.makeRe(...args); - -/** - * Scan a glob pattern to separate the pattern into segments. Used - * by the [split](#split) method. - * - * ```js - * const mm = require('micromatch'); - * const state = mm.scan(pattern[, options]); - * ``` - * @param {String} `pattern` - * @param {Object} `options` - * @return {Object} Returns an object with - * @api public - */ - -micromatch.scan = (...args) => picomatch.scan(...args); - -/** - * Parse a glob pattern to create the source string for a regular - * expression. - * - * ```js - * const mm = require('micromatch'); - * const state = mm.parse(pattern[, options]); - * ``` - * @param {String} `glob` - * @param {Object} `options` - * @return {Object} Returns an object with useful properties and output to be used as regex source string. - * @api public - */ - -micromatch.parse = (patterns, options) => { - let res = []; - for (let pattern of [].concat(patterns || [])) { - for (let str of braces(String(pattern), options)) { - res.push(picomatch.parse(str, options)); - } - } - return res; -}; - -/** - * Process the given brace `pattern`. - * - * ```js - * const { braces } = require('micromatch'); - * console.log(braces('foo/{a,b,c}/bar')); - * //=> [ 'foo/(a|b|c)/bar' ] - * - * console.log(braces('foo/{a,b,c}/bar', { expand: true })); - * //=> [ 'foo/a/bar', 'foo/b/bar', 'foo/c/bar' ] - * ``` - * @param {String} `pattern` String with brace pattern to process. - * @param {Object} `options` Any [options](#options) to change how expansion is performed. See the [braces][] library for all available options. - * @return {Array} - * @api public - */ - -micromatch.braces = (pattern, options) => { - if (typeof pattern !== 'string') throw new TypeError('Expected a string'); - if ((options && options.nobrace === true) || !/\{.*\}/.test(pattern)) { - return [pattern]; - } - return braces(pattern, options); -}; - -/** - * Expand braces - */ - -micromatch.braceExpand = (pattern, options) => { - if (typeof pattern !== 'string') throw new TypeError('Expected a string'); - return micromatch.braces(pattern, { ...options, expand: true }); -}; - -/** - * Expose micromatch - */ - -module.exports = micromatch; - - -/***/ }), - -/***/ 84546: +/***/ 491: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { module.exports = minimatch @@ -58327,7 +54886,7 @@ var path = (function () { try { return __nccwpck_require__(71017) } catch (e) {} minimatch.sep = path.sep var GLOBSTAR = minimatch.GLOBSTAR = Minimatch.GLOBSTAR = {} -var expand = __nccwpck_require__(6265) +var expand = __nccwpck_require__(34792) var plTypes = { '!': { open: '(?:(?!(?:', close: '))[^/]*?)'}, @@ -59269,11 +55828,11 @@ function regExpEscape (s) { /***/ }), -/***/ 6265: +/***/ 34792: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { -var concatMap = __nccwpck_require__(50819); -var balanced = __nccwpck_require__(94015); +var concatMap = __nccwpck_require__(90353); +var balanced = __nccwpck_require__(77524); module.exports = expandTop; @@ -59477,7 +56036,7 @@ function expand(str, isTop) { /***/ }), -/***/ 11474: +/***/ 40311: /***/ ((module) => { "use strict"; @@ -59748,1412 +56307,17 @@ module.exports = function (args, opts) { /***/ }), -/***/ 88149: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { - -var concatMap = __nccwpck_require__(50819); -var balanced = __nccwpck_require__(94015); - -module.exports = expandTop; - -var escSlash = '\0SLASH'+Math.random()+'\0'; -var escOpen = '\0OPEN'+Math.random()+'\0'; -var escClose = '\0CLOSE'+Math.random()+'\0'; -var escComma = '\0COMMA'+Math.random()+'\0'; -var escPeriod = '\0PERIOD'+Math.random()+'\0'; - -function numeric(str) { - return parseInt(str, 10) == str - ? parseInt(str, 10) - : str.charCodeAt(0); -} - -function escapeBraces(str) { - return str.split('\\\\').join(escSlash) - .split('\\{').join(escOpen) - .split('\\}').join(escClose) - .split('\\,').join(escComma) - .split('\\.').join(escPeriod); -} - -function unescapeBraces(str) { - return str.split(escSlash).join('\\') - .split(escOpen).join('{') - .split(escClose).join('}') - .split(escComma).join(',') - .split(escPeriod).join('.'); -} - - -// Basically just str.split(","), but handling cases -// where we have nested braced sections, which should be -// treated as individual members, like {a,{b,c},d} -function parseCommaParts(str) { - if (!str) - return ['']; - - var parts = []; - var m = balanced('{', '}', str); - - if (!m) - return str.split(','); - - var pre = m.pre; - var body = m.body; - var post = m.post; - var p = pre.split(','); - - p[p.length-1] += '{' + body + '}'; - var postParts = parseCommaParts(post); - if (post.length) { - p[p.length-1] += postParts.shift(); - p.push.apply(p, postParts); - } - - parts.push.apply(parts, p); - - return parts; -} - -function expandTop(str) { - if (!str) - return []; - - // I don't know why Bash 4.3 does this, but it does. - // Anything starting with {} will have the first two bytes preserved - // but *only* at the top level, so {},a}b will not expand to anything, - // but a{},b}c will be expanded to [a}c,abc]. - // One could argue that this is a bug in Bash, but since the goal of - // this module is to match Bash's rules, we escape a leading {} - if (str.substr(0, 2) === '{}') { - str = '\\{\\}' + str.substr(2); - } - - return expand(escapeBraces(str), true).map(unescapeBraces); -} - -function identity(e) { - return e; -} - -function embrace(str) { - return '{' + str + '}'; -} -function isPadded(el) { - return /^-?0\d/.test(el); -} - -function lte(i, y) { - return i <= y; -} -function gte(i, y) { - return i >= y; -} - -function expand(str, isTop) { - var expansions = []; - - var m = balanced('{', '}', str); - if (!m || /\$$/.test(m.pre)) return [str]; - - var isNumericSequence = /^-?\d+\.\.-?\d+(?:\.\.-?\d+)?$/.test(m.body); - var isAlphaSequence = /^[a-zA-Z]\.\.[a-zA-Z](?:\.\.-?\d+)?$/.test(m.body); - var isSequence = isNumericSequence || isAlphaSequence; - var isOptions = m.body.indexOf(',') >= 0; - if (!isSequence && !isOptions) { - // {a},b} - if (m.post.match(/,.*\}/)) { - str = m.pre + '{' + m.body + escClose + m.post; - return expand(str); - } - return [str]; - } - - var n; - if (isSequence) { - n = m.body.split(/\.\./); - } else { - n = parseCommaParts(m.body); - if (n.length === 1) { - // x{{a,b}}y ==> x{a}y x{b}y - n = expand(n[0], false).map(embrace); - if (n.length === 1) { - var post = m.post.length - ? expand(m.post, false) - : ['']; - return post.map(function(p) { - return m.pre + n[0] + p; - }); - } - } - } - - // at this point, n is the parts, and we know it's not a comma set - // with a single entry. - - // no need to expand pre, since it is guaranteed to be free of brace-sets - var pre = m.pre; - var post = m.post.length - ? expand(m.post, false) - : ['']; - - var N; - - if (isSequence) { - var x = numeric(n[0]); - var y = numeric(n[1]); - var width = Math.max(n[0].length, n[1].length) - var incr = n.length == 3 - ? Math.abs(numeric(n[2])) - : 1; - var test = lte; - var reverse = y < x; - if (reverse) { - incr *= -1; - test = gte; - } - var pad = n.some(isPadded); - - N = []; - - for (var i = x; test(i, y); i += incr) { - var c; - if (isAlphaSequence) { - c = String.fromCharCode(i); - if (c === '\\') - c = ''; - } else { - c = String(i); - if (pad) { - var need = width - c.length; - if (need > 0) { - var z = new Array(need + 1).join('0'); - if (i < 0) - c = '-' + z + c.slice(1); - else - c = z + c; - } - } - } - N.push(c); - } - } else { - N = concatMap(n, function(el) { return expand(el, false) }); - } - - for (var j = 0; j < N.length; j++) { - for (var k = 0; k < post.length; k++) { - var expansion = pre + N[j] + post[k]; - if (!isTop || isSequence || expansion) - expansions.push(expansion); - } - } - - return expansions; -} - - - -/***/ }), - -/***/ 19131: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { - -"use strict"; - -const taskManager = __nccwpck_require__(82845); -const async_1 = __nccwpck_require__(48123); -const stream_1 = __nccwpck_require__(36672); -const sync_1 = __nccwpck_require__(48463); -const settings_1 = __nccwpck_require__(67938); -const utils = __nccwpck_require__(74219); -async function FastGlob(source, options) { - assertPatternsInput(source); - const works = getWorks(source, async_1.default, options); - const result = await Promise.all(works); - return utils.array.flatten(result); -} -// https://github.com/typescript-eslint/typescript-eslint/issues/60 -// eslint-disable-next-line no-redeclare -(function (FastGlob) { - function sync(source, options) { - assertPatternsInput(source); - const works = getWorks(source, sync_1.default, options); - return utils.array.flatten(works); - } - FastGlob.sync = sync; - function stream(source, options) { - assertPatternsInput(source); - const works = getWorks(source, stream_1.default, options); - /** - * The stream returned by the provider cannot work with an asynchronous iterator. - * To support asynchronous iterators, regardless of the number of tasks, we always multiplex streams. - * This affects performance (+25%). I don't see best solution right now. - */ - return utils.stream.merge(works); - } - FastGlob.stream = stream; - function generateTasks(source, options) { - assertPatternsInput(source); - const patterns = [].concat(source); - const settings = new settings_1.default(options); - return taskManager.generate(patterns, settings); - } - FastGlob.generateTasks = generateTasks; - function isDynamicPattern(source, options) { - assertPatternsInput(source); - const settings = new settings_1.default(options); - return utils.pattern.isDynamicPattern(source, settings); - } - FastGlob.isDynamicPattern = isDynamicPattern; - function escapePath(source) { - assertPatternsInput(source); - return utils.path.escape(source); - } - FastGlob.escapePath = escapePath; -})(FastGlob || (FastGlob = {})); -function getWorks(source, _Provider, options) { - const patterns = [].concat(source); - const settings = new settings_1.default(options); - const tasks = taskManager.generate(patterns, settings); - const provider = new _Provider(settings); - return tasks.map(provider.read, provider); -} -function assertPatternsInput(input) { - const source = [].concat(input); - const isValidSource = source.every((item) => utils.string.isString(item) && !utils.string.isEmpty(item)); - if (!isValidSource) { - throw new TypeError('Patterns must be a string (non empty) or an array of strings'); - } -} -module.exports = FastGlob; - - -/***/ }), - -/***/ 82845: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { - -"use strict"; - -Object.defineProperty(exports, "__esModule", ({ value: true })); -exports.convertPatternGroupToTask = exports.convertPatternGroupsToTasks = exports.groupPatternsByBaseDirectory = exports.getNegativePatternsAsPositive = exports.getPositivePatterns = exports.convertPatternsToTasks = exports.generate = void 0; -const utils = __nccwpck_require__(74219); -function generate(patterns, settings) { - const positivePatterns = getPositivePatterns(patterns); - const negativePatterns = getNegativePatternsAsPositive(patterns, settings.ignore); - const staticPatterns = positivePatterns.filter((pattern) => utils.pattern.isStaticPattern(pattern, settings)); - const dynamicPatterns = positivePatterns.filter((pattern) => utils.pattern.isDynamicPattern(pattern, settings)); - const staticTasks = convertPatternsToTasks(staticPatterns, negativePatterns, /* dynamic */ false); - const dynamicTasks = convertPatternsToTasks(dynamicPatterns, negativePatterns, /* dynamic */ true); - return staticTasks.concat(dynamicTasks); -} -exports.generate = generate; -/** - * Returns tasks grouped by basic pattern directories. - * - * Patterns that can be found inside (`./`) and outside (`../`) the current directory are handled separately. - * This is necessary because directory traversal starts at the base directory and goes deeper. - */ -function convertPatternsToTasks(positive, negative, dynamic) { - const tasks = []; - const patternsOutsideCurrentDirectory = utils.pattern.getPatternsOutsideCurrentDirectory(positive); - const patternsInsideCurrentDirectory = utils.pattern.getPatternsInsideCurrentDirectory(positive); - const outsideCurrentDirectoryGroup = groupPatternsByBaseDirectory(patternsOutsideCurrentDirectory); - const insideCurrentDirectoryGroup = groupPatternsByBaseDirectory(patternsInsideCurrentDirectory); - tasks.push(...convertPatternGroupsToTasks(outsideCurrentDirectoryGroup, negative, dynamic)); - /* - * For the sake of reducing future accesses to the file system, we merge all tasks within the current directory - * into a global task, if at least one pattern refers to the root (`.`). In this case, the global task covers the rest. - */ - if ('.' in insideCurrentDirectoryGroup) { - tasks.push(convertPatternGroupToTask('.', patternsInsideCurrentDirectory, negative, dynamic)); - } - else { - tasks.push(...convertPatternGroupsToTasks(insideCurrentDirectoryGroup, negative, dynamic)); - } - return tasks; -} -exports.convertPatternsToTasks = convertPatternsToTasks; -function getPositivePatterns(patterns) { - return utils.pattern.getPositivePatterns(patterns); -} -exports.getPositivePatterns = getPositivePatterns; -function getNegativePatternsAsPositive(patterns, ignore) { - const negative = utils.pattern.getNegativePatterns(patterns).concat(ignore); - const positive = negative.map(utils.pattern.convertToPositivePattern); - return positive; -} -exports.getNegativePatternsAsPositive = getNegativePatternsAsPositive; -function groupPatternsByBaseDirectory(patterns) { - const group = {}; - return patterns.reduce((collection, pattern) => { - const base = utils.pattern.getBaseDirectory(pattern); - if (base in collection) { - collection[base].push(pattern); - } - else { - collection[base] = [pattern]; - } - return collection; - }, group); -} -exports.groupPatternsByBaseDirectory = groupPatternsByBaseDirectory; -function convertPatternGroupsToTasks(positive, negative, dynamic) { - return Object.keys(positive).map((base) => { - return convertPatternGroupToTask(base, positive[base], negative, dynamic); - }); -} -exports.convertPatternGroupsToTasks = convertPatternGroupsToTasks; -function convertPatternGroupToTask(base, positive, negative, dynamic) { - return { - dynamic, - positive, - negative, - base, - patterns: [].concat(positive, negative.map(utils.pattern.convertToNegativePattern)) - }; -} -exports.convertPatternGroupToTask = convertPatternGroupToTask; - - -/***/ }), - -/***/ 48123: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { - -"use strict"; - -Object.defineProperty(exports, "__esModule", ({ value: true })); -const stream_1 = __nccwpck_require__(67763); -const provider_1 = __nccwpck_require__(64746); -class ProviderAsync extends provider_1.default { - constructor() { - super(...arguments); - this._reader = new stream_1.default(this._settings); - } - read(task) { - const root = this._getRootDirectory(task); - const options = this._getReaderOptions(task); - const entries = []; - return new Promise((resolve, reject) => { - const stream = this.api(root, task, options); - stream.once('error', reject); - stream.on('data', (entry) => entries.push(options.transform(entry))); - stream.once('end', () => resolve(entries)); - }); - } - api(root, task, options) { - if (task.dynamic) { - return this._reader.dynamic(root, options); - } - return this._reader.static(task.patterns, options); - } -} -exports["default"] = ProviderAsync; - - -/***/ }), - -/***/ 60429: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { - -"use strict"; - -Object.defineProperty(exports, "__esModule", ({ value: true })); -const utils = __nccwpck_require__(74219); -const partial_1 = __nccwpck_require__(70221); -class DeepFilter { - constructor(_settings, _micromatchOptions) { - this._settings = _settings; - this._micromatchOptions = _micromatchOptions; - } - getFilter(basePath, positive, negative) { - const matcher = this._getMatcher(positive); - const negativeRe = this._getNegativePatternsRe(negative); - return (entry) => this._filter(basePath, entry, matcher, negativeRe); - } - _getMatcher(patterns) { - return new partial_1.default(patterns, this._settings, this._micromatchOptions); - } - _getNegativePatternsRe(patterns) { - const affectDepthOfReadingPatterns = patterns.filter(utils.pattern.isAffectDepthOfReadingPattern); - return utils.pattern.convertPatternsToRe(affectDepthOfReadingPatterns, this._micromatchOptions); - } - _filter(basePath, entry, matcher, negativeRe) { - if (this._isSkippedByDeep(basePath, entry.path)) { - return false; - } - if (this._isSkippedSymbolicLink(entry)) { - return false; - } - const filepath = utils.path.removeLeadingDotSegment(entry.path); - if (this._isSkippedByPositivePatterns(filepath, matcher)) { - return false; - } - return this._isSkippedByNegativePatterns(filepath, negativeRe); - } - _isSkippedByDeep(basePath, entryPath) { - /** - * Avoid unnecessary depth calculations when it doesn't matter. - */ - if (this._settings.deep === Infinity) { - return false; - } - return this._getEntryLevel(basePath, entryPath) >= this._settings.deep; - } - _getEntryLevel(basePath, entryPath) { - const entryPathDepth = entryPath.split('/').length; - if (basePath === '') { - return entryPathDepth; - } - const basePathDepth = basePath.split('/').length; - return entryPathDepth - basePathDepth; - } - _isSkippedSymbolicLink(entry) { - return !this._settings.followSymbolicLinks && entry.dirent.isSymbolicLink(); - } - _isSkippedByPositivePatterns(entryPath, matcher) { - return !this._settings.baseNameMatch && !matcher.match(entryPath); - } - _isSkippedByNegativePatterns(entryPath, patternsRe) { - return !utils.pattern.matchAny(entryPath, patternsRe); - } -} -exports["default"] = DeepFilter; - - -/***/ }), - -/***/ 26658: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { - -"use strict"; - -Object.defineProperty(exports, "__esModule", ({ value: true })); -const utils = __nccwpck_require__(74219); -class EntryFilter { - constructor(_settings, _micromatchOptions) { - this._settings = _settings; - this._micromatchOptions = _micromatchOptions; - this.index = new Map(); - } - getFilter(positive, negative) { - const positiveRe = utils.pattern.convertPatternsToRe(positive, this._micromatchOptions); - const negativeRe = utils.pattern.convertPatternsToRe(negative, this._micromatchOptions); - return (entry) => this._filter(entry, positiveRe, negativeRe); - } - _filter(entry, positiveRe, negativeRe) { - if (this._settings.unique && this._isDuplicateEntry(entry)) { - return false; - } - if (this._onlyFileFilter(entry) || this._onlyDirectoryFilter(entry)) { - return false; - } - if (this._isSkippedByAbsoluteNegativePatterns(entry.path, negativeRe)) { - return false; - } - const filepath = this._settings.baseNameMatch ? entry.name : entry.path; - const isMatched = this._isMatchToPatterns(filepath, positiveRe) && !this._isMatchToPatterns(entry.path, negativeRe); - if (this._settings.unique && isMatched) { - this._createIndexRecord(entry); - } - return isMatched; - } - _isDuplicateEntry(entry) { - return this.index.has(entry.path); - } - _createIndexRecord(entry) { - this.index.set(entry.path, undefined); - } - _onlyFileFilter(entry) { - return this._settings.onlyFiles && !entry.dirent.isFile(); - } - _onlyDirectoryFilter(entry) { - return this._settings.onlyDirectories && !entry.dirent.isDirectory(); - } - _isSkippedByAbsoluteNegativePatterns(entryPath, patternsRe) { - if (!this._settings.absolute) { - return false; - } - const fullpath = utils.path.makeAbsolute(this._settings.cwd, entryPath); - return utils.pattern.matchAny(fullpath, patternsRe); - } - _isMatchToPatterns(entryPath, patternsRe) { - const filepath = utils.path.removeLeadingDotSegment(entryPath); - return utils.pattern.matchAny(filepath, patternsRe); - } -} -exports["default"] = EntryFilter; - - -/***/ }), - -/***/ 52968: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { - -"use strict"; - -Object.defineProperty(exports, "__esModule", ({ value: true })); -const utils = __nccwpck_require__(74219); -class ErrorFilter { - constructor(_settings) { - this._settings = _settings; - } - getFilter() { - return (error) => this._isNonFatalError(error); - } - _isNonFatalError(error) { - return utils.errno.isEnoentCodeError(error) || this._settings.suppressErrors; - } -} -exports["default"] = ErrorFilter; - - -/***/ }), - -/***/ 84063: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { - -"use strict"; - -Object.defineProperty(exports, "__esModule", ({ value: true })); -const utils = __nccwpck_require__(74219); -class Matcher { - constructor(_patterns, _settings, _micromatchOptions) { - this._patterns = _patterns; - this._settings = _settings; - this._micromatchOptions = _micromatchOptions; - this._storage = []; - this._fillStorage(); - } - _fillStorage() { - /** - * The original pattern may include `{,*,**,a/*}`, which will lead to problems with matching (unresolved level). - * So, before expand patterns with brace expansion into separated patterns. - */ - const patterns = utils.pattern.expandPatternsWithBraceExpansion(this._patterns); - for (const pattern of patterns) { - const segments = this._getPatternSegments(pattern); - const sections = this._splitSegmentsIntoSections(segments); - this._storage.push({ - complete: sections.length <= 1, - pattern, - segments, - sections - }); - } - } - _getPatternSegments(pattern) { - const parts = utils.pattern.getPatternParts(pattern, this._micromatchOptions); - return parts.map((part) => { - const dynamic = utils.pattern.isDynamicPattern(part, this._settings); - if (!dynamic) { - return { - dynamic: false, - pattern: part - }; - } - return { - dynamic: true, - pattern: part, - patternRe: utils.pattern.makeRe(part, this._micromatchOptions) - }; - }); - } - _splitSegmentsIntoSections(segments) { - return utils.array.splitWhen(segments, (segment) => segment.dynamic && utils.pattern.hasGlobStar(segment.pattern)); - } -} -exports["default"] = Matcher; - - -/***/ }), - -/***/ 70221: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { - -"use strict"; - -Object.defineProperty(exports, "__esModule", ({ value: true })); -const matcher_1 = __nccwpck_require__(84063); -class PartialMatcher extends matcher_1.default { - match(filepath) { - const parts = filepath.split('/'); - const levels = parts.length; - const patterns = this._storage.filter((info) => !info.complete || info.segments.length > levels); - for (const pattern of patterns) { - const section = pattern.sections[0]; - /** - * In this case, the pattern has a globstar and we must read all directories unconditionally, - * but only if the level has reached the end of the first group. - * - * fixtures/{a,b}/** - * ^ true/false ^ always true - */ - if (!pattern.complete && levels > section.length) { - return true; - } - const match = parts.every((part, index) => { - const segment = pattern.segments[index]; - if (segment.dynamic && segment.patternRe.test(part)) { - return true; - } - if (!segment.dynamic && segment.pattern === part) { - return true; - } - return false; - }); - if (match) { - return true; - } - } - return false; - } -} -exports["default"] = PartialMatcher; - - -/***/ }), - -/***/ 64746: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { - -"use strict"; - -Object.defineProperty(exports, "__esModule", ({ value: true })); -const path = __nccwpck_require__(71017); -const deep_1 = __nccwpck_require__(60429); -const entry_1 = __nccwpck_require__(26658); -const error_1 = __nccwpck_require__(52968); -const entry_2 = __nccwpck_require__(58684); -class Provider { - constructor(_settings) { - this._settings = _settings; - this.errorFilter = new error_1.default(this._settings); - this.entryFilter = new entry_1.default(this._settings, this._getMicromatchOptions()); - this.deepFilter = new deep_1.default(this._settings, this._getMicromatchOptions()); - this.entryTransformer = new entry_2.default(this._settings); - } - _getRootDirectory(task) { - return path.resolve(this._settings.cwd, task.base); - } - _getReaderOptions(task) { - const basePath = task.base === '.' ? '' : task.base; - return { - basePath, - pathSegmentSeparator: '/', - concurrency: this._settings.concurrency, - deepFilter: this.deepFilter.getFilter(basePath, task.positive, task.negative), - entryFilter: this.entryFilter.getFilter(task.positive, task.negative), - errorFilter: this.errorFilter.getFilter(), - followSymbolicLinks: this._settings.followSymbolicLinks, - fs: this._settings.fs, - stats: this._settings.stats, - throwErrorOnBrokenSymbolicLink: this._settings.throwErrorOnBrokenSymbolicLink, - transform: this.entryTransformer.getTransformer() - }; - } - _getMicromatchOptions() { - return { - dot: this._settings.dot, - matchBase: this._settings.baseNameMatch, - nobrace: !this._settings.braceExpansion, - nocase: !this._settings.caseSensitiveMatch, - noext: !this._settings.extglob, - noglobstar: !this._settings.globstar, - posix: true, - strictSlashes: false - }; - } -} -exports["default"] = Provider; - - -/***/ }), - -/***/ 36672: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { - -"use strict"; - -Object.defineProperty(exports, "__esModule", ({ value: true })); -const stream_1 = __nccwpck_require__(12781); -const stream_2 = __nccwpck_require__(67763); -const provider_1 = __nccwpck_require__(64746); -class ProviderStream extends provider_1.default { - constructor() { - super(...arguments); - this._reader = new stream_2.default(this._settings); - } - read(task) { - const root = this._getRootDirectory(task); - const options = this._getReaderOptions(task); - const source = this.api(root, task, options); - const destination = new stream_1.Readable({ objectMode: true, read: () => { } }); - source - .once('error', (error) => destination.emit('error', error)) - .on('data', (entry) => destination.emit('data', options.transform(entry))) - .once('end', () => destination.emit('end')); - destination - .once('close', () => source.destroy()); - return destination; - } - api(root, task, options) { - if (task.dynamic) { - return this._reader.dynamic(root, options); - } - return this._reader.static(task.patterns, options); - } -} -exports["default"] = ProviderStream; - - -/***/ }), - -/***/ 48463: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { - -"use strict"; - -Object.defineProperty(exports, "__esModule", ({ value: true })); -const sync_1 = __nccwpck_require__(58162); -const provider_1 = __nccwpck_require__(64746); -class ProviderSync extends provider_1.default { - constructor() { - super(...arguments); - this._reader = new sync_1.default(this._settings); - } - read(task) { - const root = this._getRootDirectory(task); - const options = this._getReaderOptions(task); - const entries = this.api(root, task, options); - return entries.map(options.transform); - } - api(root, task, options) { - if (task.dynamic) { - return this._reader.dynamic(root, options); - } - return this._reader.static(task.patterns, options); - } -} -exports["default"] = ProviderSync; - - -/***/ }), - -/***/ 58684: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { - -"use strict"; - -Object.defineProperty(exports, "__esModule", ({ value: true })); -const utils = __nccwpck_require__(74219); -class EntryTransformer { - constructor(_settings) { - this._settings = _settings; - } - getTransformer() { - return (entry) => this._transform(entry); - } - _transform(entry) { - let filepath = entry.path; - if (this._settings.absolute) { - filepath = utils.path.makeAbsolute(this._settings.cwd, filepath); - filepath = utils.path.unixify(filepath); - } - if (this._settings.markDirectories && entry.dirent.isDirectory()) { - filepath += '/'; - } - if (!this._settings.objectMode) { - return filepath; - } - return Object.assign(Object.assign({}, entry), { path: filepath }); - } -} -exports["default"] = EntryTransformer; - - -/***/ }), - -/***/ 86255: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { - -"use strict"; - -Object.defineProperty(exports, "__esModule", ({ value: true })); -const path = __nccwpck_require__(71017); -const fsStat = __nccwpck_require__(25925); -const utils = __nccwpck_require__(74219); -class Reader { - constructor(_settings) { - this._settings = _settings; - this._fsStatSettings = new fsStat.Settings({ - followSymbolicLink: this._settings.followSymbolicLinks, - fs: this._settings.fs, - throwErrorOnBrokenSymbolicLink: this._settings.followSymbolicLinks - }); - } - _getFullEntryPath(filepath) { - return path.resolve(this._settings.cwd, filepath); - } - _makeEntry(stats, pattern) { - const entry = { - name: pattern, - path: pattern, - dirent: utils.fs.createDirentFromStats(pattern, stats) - }; - if (this._settings.stats) { - entry.stats = stats; - } - return entry; - } - _isFatalError(error) { - return !utils.errno.isEnoentCodeError(error) && !this._settings.suppressErrors; - } -} -exports["default"] = Reader; - - -/***/ }), - -/***/ 67763: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { - -"use strict"; - -Object.defineProperty(exports, "__esModule", ({ value: true })); -const stream_1 = __nccwpck_require__(12781); -const fsStat = __nccwpck_require__(25925); -const fsWalk = __nccwpck_require__(99155); -const reader_1 = __nccwpck_require__(86255); -class ReaderStream extends reader_1.default { - constructor() { - super(...arguments); - this._walkStream = fsWalk.walkStream; - this._stat = fsStat.stat; - } - dynamic(root, options) { - return this._walkStream(root, options); - } - static(patterns, options) { - const filepaths = patterns.map(this._getFullEntryPath, this); - const stream = new stream_1.PassThrough({ objectMode: true }); - stream._write = (index, _enc, done) => { - return this._getEntry(filepaths[index], patterns[index], options) - .then((entry) => { - if (entry !== null && options.entryFilter(entry)) { - stream.push(entry); - } - if (index === filepaths.length - 1) { - stream.end(); - } - done(); - }) - .catch(done); - }; - for (let i = 0; i < filepaths.length; i++) { - stream.write(i); - } - return stream; - } - _getEntry(filepath, pattern, options) { - return this._getStat(filepath) - .then((stats) => this._makeEntry(stats, pattern)) - .catch((error) => { - if (options.errorFilter(error)) { - return null; - } - throw error; - }); - } - _getStat(filepath) { - return new Promise((resolve, reject) => { - this._stat(filepath, this._fsStatSettings, (error, stats) => { - return error === null ? resolve(stats) : reject(error); - }); - }); - } -} -exports["default"] = ReaderStream; - - -/***/ }), - -/***/ 58162: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { - -"use strict"; - -Object.defineProperty(exports, "__esModule", ({ value: true })); -const fsStat = __nccwpck_require__(25925); -const fsWalk = __nccwpck_require__(99155); -const reader_1 = __nccwpck_require__(86255); -class ReaderSync extends reader_1.default { - constructor() { - super(...arguments); - this._walkSync = fsWalk.walkSync; - this._statSync = fsStat.statSync; - } - dynamic(root, options) { - return this._walkSync(root, options); - } - static(patterns, options) { - const entries = []; - for (const pattern of patterns) { - const filepath = this._getFullEntryPath(pattern); - const entry = this._getEntry(filepath, pattern, options); - if (entry === null || !options.entryFilter(entry)) { - continue; - } - entries.push(entry); - } - return entries; - } - _getEntry(filepath, pattern, options) { - try { - const stats = this._getStat(filepath); - return this._makeEntry(stats, pattern); - } - catch (error) { - if (options.errorFilter(error)) { - return null; - } - throw error; - } - } - _getStat(filepath) { - return this._statSync(filepath, this._fsStatSettings); - } -} -exports["default"] = ReaderSync; - - -/***/ }), - -/***/ 67938: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { - -"use strict"; - -Object.defineProperty(exports, "__esModule", ({ value: true })); -exports.DEFAULT_FILE_SYSTEM_ADAPTER = void 0; -const fs = __nccwpck_require__(57147); -const os = __nccwpck_require__(22037); -/** - * The `os.cpus` method can return zero. We expect the number of cores to be greater than zero. - * https://github.com/nodejs/node/blob/7faeddf23a98c53896f8b574a6e66589e8fb1eb8/lib/os.js#L106-L107 - */ -const CPU_COUNT = Math.max(os.cpus().length, 1); -exports.DEFAULT_FILE_SYSTEM_ADAPTER = { - lstat: fs.lstat, - lstatSync: fs.lstatSync, - stat: fs.stat, - statSync: fs.statSync, - readdir: fs.readdir, - readdirSync: fs.readdirSync -}; -class Settings { - constructor(_options = {}) { - this._options = _options; - this.absolute = this._getValue(this._options.absolute, false); - this.baseNameMatch = this._getValue(this._options.baseNameMatch, false); - this.braceExpansion = this._getValue(this._options.braceExpansion, true); - this.caseSensitiveMatch = this._getValue(this._options.caseSensitiveMatch, true); - this.concurrency = this._getValue(this._options.concurrency, CPU_COUNT); - this.cwd = this._getValue(this._options.cwd, process.cwd()); - this.deep = this._getValue(this._options.deep, Infinity); - this.dot = this._getValue(this._options.dot, false); - this.extglob = this._getValue(this._options.extglob, true); - this.followSymbolicLinks = this._getValue(this._options.followSymbolicLinks, true); - this.fs = this._getFileSystemMethods(this._options.fs); - this.globstar = this._getValue(this._options.globstar, true); - this.ignore = this._getValue(this._options.ignore, []); - this.markDirectories = this._getValue(this._options.markDirectories, false); - this.objectMode = this._getValue(this._options.objectMode, false); - this.onlyDirectories = this._getValue(this._options.onlyDirectories, false); - this.onlyFiles = this._getValue(this._options.onlyFiles, true); - this.stats = this._getValue(this._options.stats, false); - this.suppressErrors = this._getValue(this._options.suppressErrors, false); - this.throwErrorOnBrokenSymbolicLink = this._getValue(this._options.throwErrorOnBrokenSymbolicLink, false); - this.unique = this._getValue(this._options.unique, true); - if (this.onlyDirectories) { - this.onlyFiles = false; - } - if (this.stats) { - this.objectMode = true; - } - } - _getValue(option, value) { - return option === undefined ? value : option; - } - _getFileSystemMethods(methods = {}) { - return Object.assign(Object.assign({}, exports.DEFAULT_FILE_SYSTEM_ADAPTER), methods); - } -} -exports["default"] = Settings; - - -/***/ }), - -/***/ 1966: -/***/ ((__unused_webpack_module, exports) => { - -"use strict"; - -Object.defineProperty(exports, "__esModule", ({ value: true })); -exports.splitWhen = exports.flatten = void 0; -function flatten(items) { - return items.reduce((collection, item) => [].concat(collection, item), []); -} -exports.flatten = flatten; -function splitWhen(items, predicate) { - const result = [[]]; - let groupIndex = 0; - for (const item of items) { - if (predicate(item)) { - groupIndex++; - result[groupIndex] = []; - } - else { - result[groupIndex].push(item); - } - } - return result; -} -exports.splitWhen = splitWhen; - - -/***/ }), - -/***/ 30821: -/***/ ((__unused_webpack_module, exports) => { - -"use strict"; - -Object.defineProperty(exports, "__esModule", ({ value: true })); -exports.isEnoentCodeError = void 0; -function isEnoentCodeError(error) { - return error.code === 'ENOENT'; -} -exports.isEnoentCodeError = isEnoentCodeError; - - -/***/ }), - -/***/ 70274: -/***/ ((__unused_webpack_module, exports) => { - -"use strict"; - -Object.defineProperty(exports, "__esModule", ({ value: true })); -exports.createDirentFromStats = void 0; -class DirentFromStats { - constructor(name, stats) { - this.name = name; - this.isBlockDevice = stats.isBlockDevice.bind(stats); - this.isCharacterDevice = stats.isCharacterDevice.bind(stats); - this.isDirectory = stats.isDirectory.bind(stats); - this.isFIFO = stats.isFIFO.bind(stats); - this.isFile = stats.isFile.bind(stats); - this.isSocket = stats.isSocket.bind(stats); - this.isSymbolicLink = stats.isSymbolicLink.bind(stats); - } -} -function createDirentFromStats(name, stats) { - return new DirentFromStats(name, stats); -} -exports.createDirentFromStats = createDirentFromStats; - - -/***/ }), - -/***/ 74219: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { - -"use strict"; - -Object.defineProperty(exports, "__esModule", ({ value: true })); -exports.string = exports.stream = exports.pattern = exports.path = exports.fs = exports.errno = exports.array = void 0; -const array = __nccwpck_require__(1966); -exports.array = array; -const errno = __nccwpck_require__(30821); -exports.errno = errno; -const fs = __nccwpck_require__(70274); -exports.fs = fs; -const path = __nccwpck_require__(98478); -exports.path = path; -const pattern = __nccwpck_require__(48517); -exports.pattern = pattern; -const stream = __nccwpck_require__(2914); -exports.stream = stream; -const string = __nccwpck_require__(25039); -exports.string = string; - - -/***/ }), - -/***/ 98478: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { - -"use strict"; - -Object.defineProperty(exports, "__esModule", ({ value: true })); -exports.removeLeadingDotSegment = exports.escape = exports.makeAbsolute = exports.unixify = void 0; -const path = __nccwpck_require__(71017); -const LEADING_DOT_SEGMENT_CHARACTERS_COUNT = 2; // ./ or .\\ -const UNESCAPED_GLOB_SYMBOLS_RE = /(\\?)([()*?[\]{|}]|^!|[!+@](?=\())/g; -/** - * Designed to work only with simple paths: `dir\\file`. - */ -function unixify(filepath) { - return filepath.replace(/\\/g, '/'); -} -exports.unixify = unixify; -function makeAbsolute(cwd, filepath) { - return path.resolve(cwd, filepath); -} -exports.makeAbsolute = makeAbsolute; -function escape(pattern) { - return pattern.replace(UNESCAPED_GLOB_SYMBOLS_RE, '\\$2'); -} -exports.escape = escape; -function removeLeadingDotSegment(entry) { - // We do not use `startsWith` because this is 10x slower than current implementation for some cases. - // eslint-disable-next-line @typescript-eslint/prefer-string-starts-ends-with - if (entry.charAt(0) === '.') { - const secondCharactery = entry.charAt(1); - if (secondCharactery === '/' || secondCharactery === '\\') { - return entry.slice(LEADING_DOT_SEGMENT_CHARACTERS_COUNT); - } - } - return entry; -} -exports.removeLeadingDotSegment = removeLeadingDotSegment; - - -/***/ }), - -/***/ 48517: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { - -"use strict"; - -Object.defineProperty(exports, "__esModule", ({ value: true })); -exports.matchAny = exports.convertPatternsToRe = exports.makeRe = exports.getPatternParts = exports.expandBraceExpansion = exports.expandPatternsWithBraceExpansion = exports.isAffectDepthOfReadingPattern = exports.endsWithSlashGlobStar = exports.hasGlobStar = exports.getBaseDirectory = exports.isPatternRelatedToParentDirectory = exports.getPatternsOutsideCurrentDirectory = exports.getPatternsInsideCurrentDirectory = exports.getPositivePatterns = exports.getNegativePatterns = exports.isPositivePattern = exports.isNegativePattern = exports.convertToNegativePattern = exports.convertToPositivePattern = exports.isDynamicPattern = exports.isStaticPattern = void 0; -const path = __nccwpck_require__(71017); -const globParent = __nccwpck_require__(86420); -const micromatch = __nccwpck_require__(99573); -const GLOBSTAR = '**'; -const ESCAPE_SYMBOL = '\\'; -const COMMON_GLOB_SYMBOLS_RE = /[*?]|^!/; -const REGEX_CHARACTER_CLASS_SYMBOLS_RE = /\[.*]/; -const REGEX_GROUP_SYMBOLS_RE = /(?:^|[^!*+?@])\(.*\|.*\)/; -const GLOB_EXTENSION_SYMBOLS_RE = /[!*+?@]\(.*\)/; -const BRACE_EXPANSIONS_SYMBOLS_RE = /{.*(?:,|\.\.).*}/; -function isStaticPattern(pattern, options = {}) { - return !isDynamicPattern(pattern, options); -} -exports.isStaticPattern = isStaticPattern; -function isDynamicPattern(pattern, options = {}) { - /** - * A special case with an empty string is necessary for matching patterns that start with a forward slash. - * An empty string cannot be a dynamic pattern. - * For example, the pattern `/lib/*` will be spread into parts: '', 'lib', '*'. - */ - if (pattern === '') { - return false; - } - /** - * When the `caseSensitiveMatch` option is disabled, all patterns must be marked as dynamic, because we cannot check - * filepath directly (without read directory). - */ - if (options.caseSensitiveMatch === false || pattern.includes(ESCAPE_SYMBOL)) { - return true; - } - if (COMMON_GLOB_SYMBOLS_RE.test(pattern) || REGEX_CHARACTER_CLASS_SYMBOLS_RE.test(pattern) || REGEX_GROUP_SYMBOLS_RE.test(pattern)) { - return true; - } - if (options.extglob !== false && GLOB_EXTENSION_SYMBOLS_RE.test(pattern)) { - return true; - } - if (options.braceExpansion !== false && BRACE_EXPANSIONS_SYMBOLS_RE.test(pattern)) { - return true; - } - return false; -} -exports.isDynamicPattern = isDynamicPattern; -function convertToPositivePattern(pattern) { - return isNegativePattern(pattern) ? pattern.slice(1) : pattern; -} -exports.convertToPositivePattern = convertToPositivePattern; -function convertToNegativePattern(pattern) { - return '!' + pattern; -} -exports.convertToNegativePattern = convertToNegativePattern; -function isNegativePattern(pattern) { - return pattern.startsWith('!') && pattern[1] !== '('; -} -exports.isNegativePattern = isNegativePattern; -function isPositivePattern(pattern) { - return !isNegativePattern(pattern); -} -exports.isPositivePattern = isPositivePattern; -function getNegativePatterns(patterns) { - return patterns.filter(isNegativePattern); -} -exports.getNegativePatterns = getNegativePatterns; -function getPositivePatterns(patterns) { - return patterns.filter(isPositivePattern); -} -exports.getPositivePatterns = getPositivePatterns; -/** - * Returns patterns that can be applied inside the current directory. - * - * @example - * // ['./*', '*', 'a/*'] - * getPatternsInsideCurrentDirectory(['./*', '*', 'a/*', '../*', './../*']) - */ -function getPatternsInsideCurrentDirectory(patterns) { - return patterns.filter((pattern) => !isPatternRelatedToParentDirectory(pattern)); -} -exports.getPatternsInsideCurrentDirectory = getPatternsInsideCurrentDirectory; -/** - * Returns patterns to be expanded relative to (outside) the current directory. - * - * @example - * // ['../*', './../*'] - * getPatternsInsideCurrentDirectory(['./*', '*', 'a/*', '../*', './../*']) - */ -function getPatternsOutsideCurrentDirectory(patterns) { - return patterns.filter(isPatternRelatedToParentDirectory); -} -exports.getPatternsOutsideCurrentDirectory = getPatternsOutsideCurrentDirectory; -function isPatternRelatedToParentDirectory(pattern) { - return pattern.startsWith('..') || pattern.startsWith('./..'); -} -exports.isPatternRelatedToParentDirectory = isPatternRelatedToParentDirectory; -function getBaseDirectory(pattern) { - return globParent(pattern, { flipBackslashes: false }); -} -exports.getBaseDirectory = getBaseDirectory; -function hasGlobStar(pattern) { - return pattern.includes(GLOBSTAR); -} -exports.hasGlobStar = hasGlobStar; -function endsWithSlashGlobStar(pattern) { - return pattern.endsWith('/' + GLOBSTAR); -} -exports.endsWithSlashGlobStar = endsWithSlashGlobStar; -function isAffectDepthOfReadingPattern(pattern) { - const basename = path.basename(pattern); - return endsWithSlashGlobStar(pattern) || isStaticPattern(basename); -} -exports.isAffectDepthOfReadingPattern = isAffectDepthOfReadingPattern; -function expandPatternsWithBraceExpansion(patterns) { - return patterns.reduce((collection, pattern) => { - return collection.concat(expandBraceExpansion(pattern)); - }, []); -} -exports.expandPatternsWithBraceExpansion = expandPatternsWithBraceExpansion; -function expandBraceExpansion(pattern) { - return micromatch.braces(pattern, { - expand: true, - nodupes: true - }); -} -exports.expandBraceExpansion = expandBraceExpansion; -function getPatternParts(pattern, options) { - let { parts } = micromatch.scan(pattern, Object.assign(Object.assign({}, options), { parts: true })); - /** - * The scan method returns an empty array in some cases. - * See micromatch/picomatch#58 for more details. - */ - if (parts.length === 0) { - parts = [pattern]; - } - /** - * The scan method does not return an empty part for the pattern with a forward slash. - * This is another part of micromatch/picomatch#58. - */ - if (parts[0].startsWith('/')) { - parts[0] = parts[0].slice(1); - parts.unshift(''); - } - return parts; -} -exports.getPatternParts = getPatternParts; -function makeRe(pattern, options) { - return micromatch.makeRe(pattern, options); -} -exports.makeRe = makeRe; -function convertPatternsToRe(patterns, options) { - return patterns.map((pattern) => makeRe(pattern, options)); -} -exports.convertPatternsToRe = convertPatternsToRe; -function matchAny(entry, patternsRe) { - return patternsRe.some((patternRe) => patternRe.test(entry)); -} -exports.matchAny = matchAny; - - -/***/ }), - -/***/ 2914: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { - -"use strict"; - -Object.defineProperty(exports, "__esModule", ({ value: true })); -exports.merge = void 0; -const merge2 = __nccwpck_require__(30268); -function merge(streams) { - const mergedStream = merge2(streams); - streams.forEach((stream) => { - stream.once('error', (error) => mergedStream.emit('error', error)); - }); - mergedStream.once('close', () => propagateCloseEventToSources(streams)); - mergedStream.once('end', () => propagateCloseEventToSources(streams)); - return mergedStream; -} -exports.merge = merge; -function propagateCloseEventToSources(streams) { - streams.forEach((stream) => stream.emit('close')); -} - - -/***/ }), - -/***/ 25039: -/***/ ((__unused_webpack_module, exports) => { - -"use strict"; - -Object.defineProperty(exports, "__esModule", ({ value: true })); -exports.isEmpty = exports.isString = void 0; -function isString(input) { - return typeof input === 'string'; -} -exports.isString = isString; -function isEmpty(input) { - return input === ''; -} -exports.isEmpty = isEmpty; - - -/***/ }), - -/***/ 26920: +/***/ 38281: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { "use strict"; -const fs = __nccwpck_require__(88285) +const fs = __nccwpck_require__(59866) const path = __nccwpck_require__(71017) -const mkdirsSync = (__nccwpck_require__(68761).mkdirsSync) -const utimesMillisSync = (__nccwpck_require__(51144).utimesMillisSync) -const stat = __nccwpck_require__(27931) +const mkdirsSync = (__nccwpck_require__(52897).mkdirsSync) +const utimesMillisSync = (__nccwpck_require__(67670).utimesMillisSync) +const stat = __nccwpck_require__(15466) function copySync (src, dest, opts) { if (typeof opts === 'function') { @@ -61312,18 +56476,18 @@ module.exports = copySync /***/ }), -/***/ 40671: +/***/ 61745: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { "use strict"; -const fs = __nccwpck_require__(88285) +const fs = __nccwpck_require__(59866) const path = __nccwpck_require__(71017) -const mkdirs = (__nccwpck_require__(68761).mkdirs) -const pathExists = (__nccwpck_require__(29414).pathExists) -const utimesMillis = (__nccwpck_require__(51144).utimesMillis) -const stat = __nccwpck_require__(27931) +const mkdirs = (__nccwpck_require__(52897).mkdirs) +const pathExists = (__nccwpck_require__(84485).pathExists) +const utimesMillis = (__nccwpck_require__(67670).utimesMillis) +const stat = __nccwpck_require__(15466) function copy (src, dest, opts, cb) { if (typeof opts === 'function' && !cb) { @@ -61558,32 +56722,32 @@ module.exports = copy /***/ }), -/***/ 94109: +/***/ 20133: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { "use strict"; -const u = (__nccwpck_require__(82787).fromCallback) +const u = (__nccwpck_require__(63931).fromCallback) module.exports = { - copy: u(__nccwpck_require__(40671)), - copySync: __nccwpck_require__(26920) + copy: u(__nccwpck_require__(61745)), + copySync: __nccwpck_require__(38281) } /***/ }), -/***/ 6331: +/***/ 81168: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { "use strict"; -const u = (__nccwpck_require__(82787).fromPromise) -const fs = __nccwpck_require__(5944) +const u = (__nccwpck_require__(63931).fromPromise) +const fs = __nccwpck_require__(98397) const path = __nccwpck_require__(71017) -const mkdir = __nccwpck_require__(68761) -const remove = __nccwpck_require__(59954) +const mkdir = __nccwpck_require__(52897) +const remove = __nccwpck_require__(12039) const emptyDir = u(async function emptyDir (dir) { let items @@ -61620,16 +56784,16 @@ module.exports = { /***/ }), -/***/ 37453: +/***/ 9353: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { "use strict"; -const u = (__nccwpck_require__(82787).fromCallback) +const u = (__nccwpck_require__(63931).fromCallback) const path = __nccwpck_require__(71017) -const fs = __nccwpck_require__(88285) -const mkdir = __nccwpck_require__(68761) +const fs = __nccwpck_require__(59866) +const mkdir = __nccwpck_require__(52897) function createFile (file, callback) { function makeFile () { @@ -61697,15 +56861,15 @@ module.exports = { /***/ }), -/***/ 13406: +/***/ 53707: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { "use strict"; -const { createFile, createFileSync } = __nccwpck_require__(37453) -const { createLink, createLinkSync } = __nccwpck_require__(67603) -const { createSymlink, createSymlinkSync } = __nccwpck_require__(85385) +const { createFile, createFileSync } = __nccwpck_require__(9353) +const { createLink, createLinkSync } = __nccwpck_require__(75318) +const { createSymlink, createSymlinkSync } = __nccwpck_require__(8384) module.exports = { // file @@ -61728,18 +56892,18 @@ module.exports = { /***/ }), -/***/ 67603: +/***/ 75318: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { "use strict"; -const u = (__nccwpck_require__(82787).fromCallback) +const u = (__nccwpck_require__(63931).fromCallback) const path = __nccwpck_require__(71017) -const fs = __nccwpck_require__(88285) -const mkdir = __nccwpck_require__(68761) -const pathExists = (__nccwpck_require__(29414).pathExists) -const { areIdentical } = __nccwpck_require__(27931) +const fs = __nccwpck_require__(59866) +const mkdir = __nccwpck_require__(52897) +const pathExists = (__nccwpck_require__(84485).pathExists) +const { areIdentical } = __nccwpck_require__(15466) function createLink (srcpath, dstpath, callback) { function makeLink (srcpath, dstpath) { @@ -61800,15 +56964,15 @@ module.exports = { /***/ }), -/***/ 8537: +/***/ 88272: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { "use strict"; const path = __nccwpck_require__(71017) -const fs = __nccwpck_require__(88285) -const pathExists = (__nccwpck_require__(29414).pathExists) +const fs = __nccwpck_require__(59866) +const pathExists = (__nccwpck_require__(84485).pathExists) /** * Function that returns two types of paths, one relative to symlink, and one @@ -61907,13 +57071,13 @@ module.exports = { /***/ }), -/***/ 38909: +/***/ 12310: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { "use strict"; -const fs = __nccwpck_require__(88285) +const fs = __nccwpck_require__(59866) function symlinkType (srcpath, type, callback) { callback = (typeof type === 'function') ? type : callback @@ -61946,30 +57110,30 @@ module.exports = { /***/ }), -/***/ 85385: +/***/ 8384: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { "use strict"; -const u = (__nccwpck_require__(82787).fromCallback) +const u = (__nccwpck_require__(63931).fromCallback) const path = __nccwpck_require__(71017) -const fs = __nccwpck_require__(5944) -const _mkdirs = __nccwpck_require__(68761) +const fs = __nccwpck_require__(98397) +const _mkdirs = __nccwpck_require__(52897) const mkdirs = _mkdirs.mkdirs const mkdirsSync = _mkdirs.mkdirsSync -const _symlinkPaths = __nccwpck_require__(8537) +const _symlinkPaths = __nccwpck_require__(88272) const symlinkPaths = _symlinkPaths.symlinkPaths const symlinkPathsSync = _symlinkPaths.symlinkPathsSync -const _symlinkType = __nccwpck_require__(38909) +const _symlinkType = __nccwpck_require__(12310) const symlinkType = _symlinkType.symlinkType const symlinkTypeSync = _symlinkType.symlinkTypeSync -const pathExists = (__nccwpck_require__(29414).pathExists) +const pathExists = (__nccwpck_require__(84485).pathExists) -const { areIdentical } = __nccwpck_require__(27931) +const { areIdentical } = __nccwpck_require__(15466) function createSymlink (srcpath, dstpath, type, callback) { callback = (typeof type === 'function') ? type : callback @@ -62036,15 +57200,15 @@ module.exports = { /***/ }), -/***/ 5944: +/***/ 98397: /***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { "use strict"; // This is adapted from https://github.com/normalize/mz // Copyright (c) 2014-2016 Jonathan Ong me@jongleberry.com and Contributors -const u = (__nccwpck_require__(82787).fromCallback) -const fs = __nccwpck_require__(88285) +const u = (__nccwpck_require__(63931).fromCallback) +const fs = __nccwpck_require__(59866) const api = [ 'access', @@ -62184,7 +57348,7 @@ if (typeof fs.realpath.native === 'function') { /***/ }), -/***/ 59511: +/***/ 27475: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { "use strict"; @@ -62192,33 +57356,33 @@ if (typeof fs.realpath.native === 'function') { module.exports = { // Export promiseified graceful-fs: - ...__nccwpck_require__(5944), + ...__nccwpck_require__(98397), // Export extra methods: - ...__nccwpck_require__(94109), - ...__nccwpck_require__(6331), - ...__nccwpck_require__(13406), - ...__nccwpck_require__(87834), - ...__nccwpck_require__(68761), - ...__nccwpck_require__(66412), - ...__nccwpck_require__(16298), - ...__nccwpck_require__(29414), - ...__nccwpck_require__(59954) + ...__nccwpck_require__(20133), + ...__nccwpck_require__(81168), + ...__nccwpck_require__(53707), + ...__nccwpck_require__(32877), + ...__nccwpck_require__(52897), + ...__nccwpck_require__(94696), + ...__nccwpck_require__(73354), + ...__nccwpck_require__(84485), + ...__nccwpck_require__(12039) } /***/ }), -/***/ 87834: +/***/ 32877: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { "use strict"; -const u = (__nccwpck_require__(82787).fromPromise) -const jsonFile = __nccwpck_require__(38911) +const u = (__nccwpck_require__(63931).fromPromise) +const jsonFile = __nccwpck_require__(14314) -jsonFile.outputJson = u(__nccwpck_require__(94530)) -jsonFile.outputJsonSync = __nccwpck_require__(41266) +jsonFile.outputJson = u(__nccwpck_require__(19946)) +jsonFile.outputJsonSync = __nccwpck_require__(35938) // aliases jsonFile.outputJSON = jsonFile.outputJson jsonFile.outputJSONSync = jsonFile.outputJsonSync @@ -62232,13 +57396,13 @@ module.exports = jsonFile /***/ }), -/***/ 38911: +/***/ 14314: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { "use strict"; -const jsonFile = __nccwpck_require__(77681) +const jsonFile = __nccwpck_require__(3653) module.exports = { // jsonfile exports @@ -62251,14 +57415,14 @@ module.exports = { /***/ }), -/***/ 41266: +/***/ 35938: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { "use strict"; -const { stringify } = __nccwpck_require__(47667) -const { outputFileSync } = __nccwpck_require__(16298) +const { stringify } = __nccwpck_require__(13379) +const { outputFileSync } = __nccwpck_require__(73354) function outputJsonSync (file, data, options) { const str = stringify(data, options) @@ -62271,14 +57435,14 @@ module.exports = outputJsonSync /***/ }), -/***/ 94530: +/***/ 19946: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { "use strict"; -const { stringify } = __nccwpck_require__(47667) -const { outputFile } = __nccwpck_require__(16298) +const { stringify } = __nccwpck_require__(13379) +const { outputFile } = __nccwpck_require__(73354) async function outputJson (file, data, options = {}) { const str = stringify(data, options) @@ -62291,13 +57455,13 @@ module.exports = outputJson /***/ }), -/***/ 68761: +/***/ 52897: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { "use strict"; -const u = (__nccwpck_require__(82787).fromPromise) -const { makeDir: _makeDir, makeDirSync } = __nccwpck_require__(48701) +const u = (__nccwpck_require__(63931).fromPromise) +const { makeDir: _makeDir, makeDirSync } = __nccwpck_require__(58307) const makeDir = u(_makeDir) module.exports = { @@ -62313,13 +57477,13 @@ module.exports = { /***/ }), -/***/ 48701: +/***/ 58307: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { "use strict"; -const fs = __nccwpck_require__(5944) -const { checkPath } = __nccwpck_require__(34522) +const fs = __nccwpck_require__(98397) +const { checkPath } = __nccwpck_require__(78834) const getMode = options => { const defaults = { mode: 0o777 } @@ -62348,7 +57512,7 @@ module.exports.makeDirSync = (dir, options) => { /***/ }), -/***/ 34522: +/***/ 78834: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { "use strict"; @@ -62377,33 +57541,33 @@ module.exports.checkPath = function checkPath (pth) { /***/ }), -/***/ 66412: +/***/ 94696: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { "use strict"; -const u = (__nccwpck_require__(82787).fromCallback) +const u = (__nccwpck_require__(63931).fromCallback) module.exports = { - move: u(__nccwpck_require__(27230)), - moveSync: __nccwpck_require__(33080) + move: u(__nccwpck_require__(16984)), + moveSync: __nccwpck_require__(29562) } /***/ }), -/***/ 33080: +/***/ 29562: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { "use strict"; -const fs = __nccwpck_require__(88285) +const fs = __nccwpck_require__(59866) const path = __nccwpck_require__(71017) -const copySync = (__nccwpck_require__(94109).copySync) -const removeSync = (__nccwpck_require__(59954).removeSync) -const mkdirpSync = (__nccwpck_require__(68761).mkdirpSync) -const stat = __nccwpck_require__(27931) +const copySync = (__nccwpck_require__(20133).copySync) +const removeSync = (__nccwpck_require__(12039).removeSync) +const mkdirpSync = (__nccwpck_require__(52897).mkdirpSync) +const stat = __nccwpck_require__(15466) function moveSync (src, dest, opts) { opts = opts || {} @@ -62443,7 +57607,8 @@ function rename (src, dest, overwrite) { function moveAcrossDevice (src, dest, overwrite) { const opts = { overwrite, - errorOnExist: true + errorOnExist: true, + preserveTimestamps: true } copySync(src, dest, opts) return removeSync(src) @@ -62454,19 +57619,19 @@ module.exports = moveSync /***/ }), -/***/ 27230: +/***/ 16984: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { "use strict"; -const fs = __nccwpck_require__(88285) +const fs = __nccwpck_require__(59866) const path = __nccwpck_require__(71017) -const copy = (__nccwpck_require__(94109).copy) -const remove = (__nccwpck_require__(59954).remove) -const mkdirp = (__nccwpck_require__(68761).mkdirp) -const pathExists = (__nccwpck_require__(29414).pathExists) -const stat = __nccwpck_require__(27931) +const copy = (__nccwpck_require__(20133).copy) +const remove = (__nccwpck_require__(12039).remove) +const mkdirp = (__nccwpck_require__(52897).mkdirp) +const pathExists = (__nccwpck_require__(84485).pathExists) +const stat = __nccwpck_require__(15466) function move (src, dest, opts, cb) { if (typeof opts === 'function') { @@ -62524,7 +57689,8 @@ function rename (src, dest, overwrite, cb) { function moveAcrossDevice (src, dest, overwrite, cb) { const opts = { overwrite, - errorOnExist: true + errorOnExist: true, + preserveTimestamps: true } copy(src, dest, opts, err => { if (err) return cb(err) @@ -62537,17 +57703,17 @@ module.exports = move /***/ }), -/***/ 16298: +/***/ 73354: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { "use strict"; -const u = (__nccwpck_require__(82787).fromCallback) -const fs = __nccwpck_require__(88285) +const u = (__nccwpck_require__(63931).fromCallback) +const fs = __nccwpck_require__(59866) const path = __nccwpck_require__(71017) -const mkdir = __nccwpck_require__(68761) -const pathExists = (__nccwpck_require__(29414).pathExists) +const mkdir = __nccwpck_require__(52897) +const pathExists = (__nccwpck_require__(84485).pathExists) function outputFile (file, data, encoding, callback) { if (typeof encoding === 'function') { @@ -62585,13 +57751,13 @@ module.exports = { /***/ }), -/***/ 29414: +/***/ 84485: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { "use strict"; -const u = (__nccwpck_require__(82787).fromPromise) -const fs = __nccwpck_require__(5944) +const u = (__nccwpck_require__(63931).fromPromise) +const fs = __nccwpck_require__(98397) function pathExists (path) { return fs.access(path).then(() => true).catch(() => false) @@ -62605,14 +57771,14 @@ module.exports = { /***/ }), -/***/ 59954: +/***/ 12039: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { "use strict"; -const fs = __nccwpck_require__(88285) -const u = (__nccwpck_require__(82787).fromCallback) +const fs = __nccwpck_require__(59866) +const u = (__nccwpck_require__(63931).fromCallback) function remove (path, callback) { fs.rm(path, { recursive: true, force: true }, callback) @@ -62630,13 +57796,13 @@ module.exports = { /***/ }), -/***/ 27931: +/***/ 15466: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { "use strict"; -const fs = __nccwpck_require__(5944) +const fs = __nccwpck_require__(98397) const path = __nccwpck_require__(71017) const util = __nccwpck_require__(73837) @@ -62792,13 +57958,13 @@ module.exports = { /***/ }), -/***/ 51144: +/***/ 67670: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { "use strict"; -const fs = __nccwpck_require__(88285) +const fs = __nccwpck_require__(59866) function utimesMillis (path, atime, mtime, callback) { // if (!HAS_MILLIS_RES) return fs.utimes(path, atime, mtime, callback) @@ -62826,16960 +57992,14481 @@ module.exports = { /***/ }), -/***/ 72755: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { +/***/ 57265: +/***/ ((module) => { -module.exports = minimatch -minimatch.Minimatch = Minimatch +/****************************************************************************** +Copyright (c) Microsoft Corporation. -const path = (() => { try { return __nccwpck_require__(71017) } catch (e) {}})() || { - sep: '/' -} -minimatch.sep = path.sep +Permission to use, copy, modify, and/or distribute this software for any +purpose with or without fee is hereby granted. -const GLOBSTAR = minimatch.GLOBSTAR = Minimatch.GLOBSTAR = {} -const expand = __nccwpck_require__(88149) +THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH +REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY +AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, +INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM +LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR +OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR +PERFORMANCE OF THIS SOFTWARE. +***************************************************************************** */ +/* global global, define, System, Reflect, Promise */ +var __extends; +var __assign; +var __rest; +var __decorate; +var __param; +var __esDecorate; +var __runInitializers; +var __propKey; +var __setFunctionName; +var __metadata; +var __awaiter; +var __generator; +var __exportStar; +var __values; +var __read; +var __spread; +var __spreadArrays; +var __spreadArray; +var __await; +var __asyncGenerator; +var __asyncDelegator; +var __asyncValues; +var __makeTemplateObject; +var __importStar; +var __importDefault; +var __classPrivateFieldGet; +var __classPrivateFieldSet; +var __classPrivateFieldIn; +var __createBinding; +(function (factory) { + var root = typeof global === "object" ? global : typeof self === "object" ? self : typeof this === "object" ? this : {}; + if (typeof define === "function" && define.amd) { + define("tslib", ["exports"], function (exports) { factory(createExporter(root, createExporter(exports))); }); + } + else if ( true && typeof module.exports === "object") { + factory(createExporter(root, createExporter(module.exports))); + } + else { + factory(createExporter(root)); + } + function createExporter(exports, previous) { + if (exports !== root) { + if (typeof Object.create === "function") { + Object.defineProperty(exports, "__esModule", { value: true }); + } + else { + exports.__esModule = true; + } + } + return function (id, v) { return exports[id] = previous ? previous(id, v) : v; }; + } +}) +(function (exporter) { + var extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; }; -const plTypes = { - '!': { open: '(?:(?!(?:', close: '))[^/]*?)'}, - '?': { open: '(?:', close: ')?' }, - '+': { open: '(?:', close: ')+' }, - '*': { open: '(?:', close: ')*' }, - '@': { open: '(?:', close: ')' } -} + __extends = function (d, b) { + if (typeof b !== "function" && b !== null) + throw new TypeError("Class extends value " + String(b) + " is not a constructor or null"); + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + }; -// any single thing other than / -// don't need to escape / when using new RegExp() -const qmark = '[^/]' + __assign = Object.assign || function (t) { + for (var s, i = 1, n = arguments.length; i < n; i++) { + s = arguments[i]; + for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p]; + } + return t; + }; -// * => any number of characters -const star = qmark + '*?' + __rest = function (s, e) { + var t = {}; + for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0) + t[p] = s[p]; + if (s != null && typeof Object.getOwnPropertySymbols === "function") + for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) { + if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i])) + t[p[i]] = s[p[i]]; + } + return t; + }; -// ** when dots are allowed. Anything goes, except .. and . -// not (^ or / followed by one or two dots followed by $ or /), -// followed by anything, any number of times. -const twoStarDot = '(?:(?!(?:\\\/|^)(?:\\.{1,2})($|\\\/)).)*?' + __decorate = function (decorators, target, key, desc) { + var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; + if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); + else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; + return c > 3 && r && Object.defineProperty(target, key, r), r; + }; -// not a ^ or / followed by a dot, -// followed by anything, any number of times. -const twoStarNoDot = '(?:(?!(?:\\\/|^)\\.).)*?' + __param = function (paramIndex, decorator) { + return function (target, key) { decorator(target, key, paramIndex); } + }; -// characters that need to be escaped in RegExp. -const reSpecials = charSet('().*{}+?[]^$\\!') + __esDecorate = function (ctor, descriptorIn, decorators, contextIn, initializers, extraInitializers) { + function accept(f) { if (f !== void 0 && typeof f !== "function") throw new TypeError("Function expected"); return f; } + var kind = contextIn.kind, key = kind === "getter" ? "get" : kind === "setter" ? "set" : "value"; + var target = !descriptorIn && ctor ? contextIn["static"] ? ctor : ctor.prototype : null; + var descriptor = descriptorIn || (target ? Object.getOwnPropertyDescriptor(target, contextIn.name) : {}); + var _, done = false; + for (var i = decorators.length - 1; i >= 0; i--) { + var context = {}; + for (var p in contextIn) context[p] = p === "access" ? {} : contextIn[p]; + for (var p in contextIn.access) context.access[p] = contextIn.access[p]; + context.addInitializer = function (f) { if (done) throw new TypeError("Cannot add initializers after decoration has completed"); extraInitializers.push(accept(f || null)); }; + var result = (0, decorators[i])(kind === "accessor" ? { get: descriptor.get, set: descriptor.set } : descriptor[key], context); + if (kind === "accessor") { + if (result === void 0) continue; + if (result === null || typeof result !== "object") throw new TypeError("Object expected"); + if (_ = accept(result.get)) descriptor.get = _; + if (_ = accept(result.set)) descriptor.set = _; + if (_ = accept(result.init)) initializers.unshift(_); + } + else if (_ = accept(result)) { + if (kind === "field") initializers.unshift(_); + else descriptor[key] = _; + } + } + if (target) Object.defineProperty(target, contextIn.name, descriptor); + done = true; + }; -// "abc" -> { a:true, b:true, c:true } -function charSet (s) { - return s.split('').reduce(function (set, c) { - set[c] = true - return set - }, {}) -} + __runInitializers = function (thisArg, initializers, value) { + var useValue = arguments.length > 2; + for (var i = 0; i < initializers.length; i++) { + value = useValue ? initializers[i].call(thisArg, value) : initializers[i].call(thisArg); + } + return useValue ? value : void 0; + }; -// normalizes slashes. -const slashSplit = /\/+/ + __propKey = function (x) { + return typeof x === "symbol" ? x : "".concat(x); + }; -minimatch.filter = filter -function filter (pattern, options) { - options = options || {} - return function (p, i, list) { - return minimatch(p, pattern, options) - } -} + __setFunctionName = function (f, name, prefix) { + if (typeof name === "symbol") name = name.description ? "[".concat(name.description, "]") : ""; + return Object.defineProperty(f, "name", { configurable: true, value: prefix ? "".concat(prefix, " ", name) : name }); + }; -function ext (a, b) { - a = a || {} - b = b || {} - const t = {} - Object.keys(a).forEach(function (k) { - t[k] = a[k] - }) - Object.keys(b).forEach(function (k) { - t[k] = b[k] - }) - return t -} + __metadata = function (metadataKey, metadataValue) { + if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(metadataKey, metadataValue); + }; -minimatch.defaults = function (def) { - if (!def || typeof def !== 'object' || !Object.keys(def).length) { - return minimatch - } + __awaiter = function (thisArg, _arguments, P, generator) { + function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); } + return new (P || (P = Promise))(function (resolve, reject) { + function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } + function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } + function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); } + step((generator = generator.apply(thisArg, _arguments || [])).next()); + }); + }; - const orig = minimatch + __generator = function (thisArg, body) { + var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g; + return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g; + function verb(n) { return function (v) { return step([n, v]); }; } + function step(op) { + if (f) throw new TypeError("Generator is already executing."); + while (g && (g = 0, op[0] && (_ = 0)), _) try { + if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t; + if (y = 0, t) op = [op[0] & 2, t.value]; + switch (op[0]) { + case 0: case 1: t = op; break; + case 4: _.label++; return { value: op[1], done: false }; + case 5: _.label++; y = op[1]; op = [0]; continue; + case 7: op = _.ops.pop(); _.trys.pop(); continue; + default: + if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; } + if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; } + if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; } + if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; } + if (t[2]) _.ops.pop(); + _.trys.pop(); continue; + } + op = body.call(thisArg, _); + } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; } + if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true }; + } + }; - const m = function minimatch (p, pattern, options) { - return orig(p, pattern, ext(def, options)) - } + __exportStar = function(m, o) { + for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(o, p)) __createBinding(o, m, p); + }; - m.Minimatch = function Minimatch (pattern, options) { - return new orig.Minimatch(pattern, ext(def, options)) - } - m.Minimatch.defaults = options => { - return orig.defaults(ext(def, options)).Minimatch - } + __createBinding = Object.create ? (function(o, m, k, k2) { + if (k2 === undefined) k2 = k; + var desc = Object.getOwnPropertyDescriptor(m, k); + if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) { + desc = { enumerable: true, get: function() { return m[k]; } }; + } + Object.defineProperty(o, k2, desc); + }) : (function(o, m, k, k2) { + if (k2 === undefined) k2 = k; + o[k2] = m[k]; + }); - m.filter = function filter (pattern, options) { - return orig.filter(pattern, ext(def, options)) - } + __values = function (o) { + var s = typeof Symbol === "function" && Symbol.iterator, m = s && o[s], i = 0; + if (m) return m.call(o); + if (o && typeof o.length === "number") return { + next: function () { + if (o && i >= o.length) o = void 0; + return { value: o && o[i++], done: !o }; + } + }; + throw new TypeError(s ? "Object is not iterable." : "Symbol.iterator is not defined."); + }; - m.defaults = function defaults (options) { - return orig.defaults(ext(def, options)) - } + __read = function (o, n) { + var m = typeof Symbol === "function" && o[Symbol.iterator]; + if (!m) return o; + var i = m.call(o), r, ar = [], e; + try { + while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value); + } + catch (error) { e = { error: error }; } + finally { + try { + if (r && !r.done && (m = i["return"])) m.call(i); + } + finally { if (e) throw e.error; } + } + return ar; + }; - m.makeRe = function makeRe (pattern, options) { - return orig.makeRe(pattern, ext(def, options)) - } + /** @deprecated */ + __spread = function () { + for (var ar = [], i = 0; i < arguments.length; i++) + ar = ar.concat(__read(arguments[i])); + return ar; + }; - m.braceExpand = function braceExpand (pattern, options) { - return orig.braceExpand(pattern, ext(def, options)) - } + /** @deprecated */ + __spreadArrays = function () { + for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length; + for (var r = Array(s), k = 0, i = 0; i < il; i++) + for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++) + r[k] = a[j]; + return r; + }; - m.match = function (list, pattern, options) { - return orig.match(list, pattern, ext(def, options)) - } + __spreadArray = function (to, from, pack) { + if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) { + if (ar || !(i in from)) { + if (!ar) ar = Array.prototype.slice.call(from, 0, i); + ar[i] = from[i]; + } + } + return to.concat(ar || Array.prototype.slice.call(from)); + }; - return m -} + __await = function (v) { + return this instanceof __await ? (this.v = v, this) : new __await(v); + }; -Minimatch.defaults = function (def) { - return minimatch.defaults(def).Minimatch -} + __asyncGenerator = function (thisArg, _arguments, generator) { + if (!Symbol.asyncIterator) throw new TypeError("Symbol.asyncIterator is not defined."); + var g = generator.apply(thisArg, _arguments || []), i, q = []; + return i = {}, verb("next"), verb("throw"), verb("return"), i[Symbol.asyncIterator] = function () { return this; }, i; + function verb(n) { if (g[n]) i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; } + function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } } + function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); } + function fulfill(value) { resume("next", value); } + function reject(value) { resume("throw", value); } + function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); } + }; -function minimatch (p, pattern, options) { - assertValidPattern(pattern) + __asyncDelegator = function (o) { + var i, p; + return i = {}, verb("next"), verb("throw", function (e) { throw e; }), verb("return"), i[Symbol.iterator] = function () { return this; }, i; + function verb(n, f) { i[n] = o[n] ? function (v) { return (p = !p) ? { value: __await(o[n](v)), done: false } : f ? f(v) : v; } : f; } + }; - if (!options) options = {} + __asyncValues = function (o) { + if (!Symbol.asyncIterator) throw new TypeError("Symbol.asyncIterator is not defined."); + var m = o[Symbol.asyncIterator], i; + return m ? m.call(o) : (o = typeof __values === "function" ? __values(o) : o[Symbol.iterator](), i = {}, verb("next"), verb("throw"), verb("return"), i[Symbol.asyncIterator] = function () { return this; }, i); + function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; } + function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); } + }; - // shortcut: comments match nothing. - if (!options.nocomment && pattern.charAt(0) === '#') { - return false - } + __makeTemplateObject = function (cooked, raw) { + if (Object.defineProperty) { Object.defineProperty(cooked, "raw", { value: raw }); } else { cooked.raw = raw; } + return cooked; + }; - // "" only matches "" - if (pattern.trim() === '') return p === '' + var __setModuleDefault = Object.create ? (function(o, v) { + Object.defineProperty(o, "default", { enumerable: true, value: v }); + }) : function(o, v) { + o["default"] = v; + }; - return new Minimatch(pattern, options).match(p) -} + __importStar = function (mod) { + if (mod && mod.__esModule) return mod; + var result = {}; + if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k); + __setModuleDefault(result, mod); + return result; + }; -function Minimatch (pattern, options) { - if (!(this instanceof Minimatch)) { - return new Minimatch(pattern, options) - } + __importDefault = function (mod) { + return (mod && mod.__esModule) ? mod : { "default": mod }; + }; - assertValidPattern(pattern) + __classPrivateFieldGet = function (receiver, state, kind, f) { + if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a getter"); + if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot read private member from an object whose class did not declare it"); + return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver); + }; - if (!options) options = {} - pattern = pattern.trim() + __classPrivateFieldSet = function (receiver, state, value, kind, f) { + if (kind === "m") throw new TypeError("Private method is not writable"); + if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a setter"); + if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot write private member to an object whose class did not declare it"); + return (kind === "a" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value; + }; - // windows support: need to use /, not \ - if (path.sep !== '/') { - pattern = pattern.split(path.sep).join('/') - } + __classPrivateFieldIn = function (state, receiver) { + if (receiver === null || (typeof receiver !== "object" && typeof receiver !== "function")) throw new TypeError("Cannot use 'in' operator on non-object"); + return typeof state === "function" ? receiver === state : state.has(receiver); + }; - this.options = options - this.set = [] - this.pattern = pattern - this.regexp = null - this.negate = false - this.comment = false - this.empty = false + exporter("__extends", __extends); + exporter("__assign", __assign); + exporter("__rest", __rest); + exporter("__decorate", __decorate); + exporter("__param", __param); + exporter("__esDecorate", __esDecorate); + exporter("__runInitializers", __runInitializers); + exporter("__propKey", __propKey); + exporter("__setFunctionName", __setFunctionName); + exporter("__metadata", __metadata); + exporter("__awaiter", __awaiter); + exporter("__generator", __generator); + exporter("__exportStar", __exportStar); + exporter("__createBinding", __createBinding); + exporter("__values", __values); + exporter("__read", __read); + exporter("__spread", __spread); + exporter("__spreadArrays", __spreadArrays); + exporter("__spreadArray", __spreadArray); + exporter("__await", __await); + exporter("__asyncGenerator", __asyncGenerator); + exporter("__asyncDelegator", __asyncDelegator); + exporter("__asyncValues", __asyncValues); + exporter("__makeTemplateObject", __makeTemplateObject); + exporter("__importStar", __importStar); + exporter("__importDefault", __importDefault); + exporter("__classPrivateFieldGet", __classPrivateFieldGet); + exporter("__classPrivateFieldSet", __classPrivateFieldSet); + exporter("__classPrivateFieldIn", __classPrivateFieldIn); +}); - // make the set of regexps etc. - this.make() -} -Minimatch.prototype.debug = function () {} +/***/ }), -Minimatch.prototype.make = make -function make () { - // don't do it more than once. - if (this._made) return +/***/ 63767: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { - var pattern = this.pattern - var options = this.options +var wrappy = __nccwpck_require__(65173) +module.exports = wrappy(once) +module.exports.strict = wrappy(onceStrict) - // empty patterns and comments match nothing. - if (!options.nocomment && pattern.charAt(0) === '#') { - this.comment = true - return +once.proto = once(function () { + Object.defineProperty(Function.prototype, 'once', { + value: function () { + return once(this) + }, + configurable: true + }) + + Object.defineProperty(Function.prototype, 'onceStrict', { + value: function () { + return onceStrict(this) + }, + configurable: true + }) +}) + +function once (fn) { + var f = function () { + if (f.called) return f.value + f.called = true + return f.value = fn.apply(this, arguments) } - if (!pattern) { - this.empty = true - return + f.called = false + return f +} + +function onceStrict (fn) { + var f = function () { + if (f.called) + throw new Error(f.onceError) + f.called = true + return f.value = fn.apply(this, arguments) } + var name = fn.name || 'Function wrapped with `once`' + f.onceError = name + " shouldn't be called more than once" + f.called = false + return f +} - // step 1: figure out negation, etc. - this.parseNegate() - // step 2: expand braces - var set = this.globSet = this.braceExpand() +/***/ }), - if (options.debug) this.debug = console.error +/***/ 76384: +/***/ ((module) => { - this.debug(this.pattern, set) +"use strict"; - // step 3: now we have a set, so turn each one into a series of path-portion - // matching patterns. - // These will be regexps, except in the case of "**", which is - // set to the GLOBSTAR object for globstar behavior, - // and will not contain any / characters - set = this.globParts = set.map(function (s) { - return s.split(slashSplit) - }) - this.debug(this.pattern, set) +function posix(path) { + return path.charAt(0) === '/'; +} - // glob --> regexps - set = set.map(function (s, si, set) { - return s.map(this.parse, this) - }, this) +function win32(path) { + // https://github.com/nodejs/node/blob/b3fcc245fb25539909ef1d5eaa01dbf92e168633/lib/path.js#L56 + var splitDeviceRe = /^([a-zA-Z]:|[\\\/]{2}[^\\\/]+[\\\/]+[^\\\/]+)?([\\\/])?([\s\S]*?)$/; + var result = splitDeviceRe.exec(path); + var device = result[1] || ''; + var isUnc = Boolean(device && device.charAt(1) !== ':'); - this.debug(this.pattern, set) + // UNC paths are always absolute + return Boolean(result[2] || isUnc); +} - // filter out everything that didn't compile properly. - set = set.filter(function (s) { - return s.indexOf(false) === -1 - }) +module.exports = process.platform === 'win32' ? win32 : posix; +module.exports.posix = posix; +module.exports.win32 = win32; - this.debug(this.pattern, set) - this.set = set -} +/***/ }), -Minimatch.prototype.parseNegate = parseNegate -function parseNegate () { - var pattern = this.pattern - var negate = false - var options = this.options - var negateOffset = 0 +/***/ 16135: +/***/ ((module, exports, __nccwpck_require__) => { - if (options.nonegate) return +"use strict"; +/* module decorator */ module = __nccwpck_require__.nmd(module); - for (var i = 0, l = pattern.length - ; i < l && pattern.charAt(i) === '!' - ; i++) { - negate = !negate - negateOffset++ - } - if (negateOffset) this.pattern = pattern.substr(negateOffset) - this.negate = negate +Object.defineProperty(exports, "__esModule", ({ + value: true +})); +exports.addHook = addHook; +var _module = _interopRequireDefault(__nccwpck_require__(98188)); +var _path = _interopRequireDefault(__nccwpck_require__(71017)); +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } +/* (c) 2015 Ari Porad (@ariporad) . License: ariporad.mit-license.org */ + +const nodeModulesRegex = /^(?:.*[\\/])?node_modules(?:[\\/].*)?$/; +// Guard against poorly mocked module constructors. +const Module = module.constructor.length > 1 ? module.constructor : _module.default; +const HOOK_RETURNED_NOTHING_ERROR_MESSAGE = '[Pirates] A hook returned a non-string, or nothing at all! This is a' + ' violation of intergalactic law!\n' + '--------------------\n' + 'If you have no idea what this means or what Pirates is, let me explain: ' + 'Pirates is a module that makes is easy to implement require hooks. One of' + " the require hooks you're using uses it. One of these require hooks" + " didn't return anything from it's handler, so we don't know what to" + ' do. You might want to debug this.'; + +/** + * @param {string} filename The filename to check. + * @param {string[]} exts The extensions to hook. Should start with '.' (ex. ['.js']). + * @param {Matcher|null} matcher A matcher function, will be called with path to a file. Should return truthy if the file should be hooked, falsy otherwise. + * @param {boolean} ignoreNodeModules Auto-ignore node_modules. Independent of any matcher. + */ +function shouldCompile(filename, exts, matcher, ignoreNodeModules) { + if (typeof filename !== 'string') { + return false; + } + if (exts.indexOf(_path.default.extname(filename)) === -1) { + return false; + } + const resolvedFilename = _path.default.resolve(filename); + if (ignoreNodeModules && nodeModulesRegex.test(resolvedFilename)) { + return false; + } + if (matcher && typeof matcher === 'function') { + return !!matcher(resolvedFilename); + } + return true; } -// Brace expansion: -// a{b,c}d -> abd acd -// a{b,}c -> abc ac -// a{0..3}d -> a0d a1d a2d a3d -// a{b,c{d,e}f}g -> abg acdfg acefg -// a{b,c}d{e,f}g -> abdeg acdeg abdeg abdfg -// -// Invalid sets are not expanded. -// a{2..}b -> a{2..}b -// a{b}c -> a{b}c -minimatch.braceExpand = function (pattern, options) { - return braceExpand(pattern, options) +/** + * @callback Hook The hook. Accepts the code of the module and the filename. + * @param {string} code + * @param {string} filename + * @returns {string} + */ +/** + * @callback Matcher A matcher function, will be called with path to a file. + * + * Should return truthy if the file should be hooked, falsy otherwise. + * @param {string} path + * @returns {boolean} + */ +/** + * @callback RevertFunction Reverts the hook when called. + * @returns {void} + */ +/** + * @typedef {object} Options + * @property {Matcher|null} [matcher=null] A matcher function, will be called with path to a file. + * + * Should return truthy if the file should be hooked, falsy otherwise. + * + * @property {string[]} [extensions=['.js']] The extensions to hook. Should start with '.' (ex. ['.js']). + * @property {string[]} [exts=['.js']] The extensions to hook. Should start with '.' (ex. ['.js']). + * + * @property {string[]} [extension=['.js']] The extensions to hook. Should start with '.' (ex. ['.js']). + * @property {string[]} [ext=['.js']] The extensions to hook. Should start with '.' (ex. ['.js']). + * + * @property {boolean} [ignoreNodeModules=true] Auto-ignore node_modules. Independent of any matcher. + */ + +/** + * Add a require hook. + * + * @param {Hook} hook The hook. Accepts the code of the module and the filename. Required. + * @param {Options} [opts] Options + * @returns {RevertFunction} The `revert` function. Reverts the hook when called. + */ +function addHook(hook, opts = {}) { + let reverted = false; + const loaders = []; + const oldLoaders = []; + let exts; + + // We need to do this to fix #15. Basically, if you use a non-standard extension (ie. .jsx), then + // We modify the .js loader, then use the modified .js loader for as the base for .jsx. + // This prevents that. + const originalJSLoader = Module._extensions['.js']; + const matcher = opts.matcher || null; + const ignoreNodeModules = opts.ignoreNodeModules !== false; + exts = opts.extensions || opts.exts || opts.extension || opts.ext || ['.js']; + if (!Array.isArray(exts)) { + exts = [exts]; + } + exts.forEach(ext => { + if (typeof ext !== 'string') { + throw new TypeError(`Invalid Extension: ${ext}`); + } + const oldLoader = Module._extensions[ext] || originalJSLoader; + oldLoaders[ext] = Module._extensions[ext]; + loaders[ext] = Module._extensions[ext] = function newLoader(mod, filename) { + let compile; + if (!reverted) { + if (shouldCompile(filename, exts, matcher, ignoreNodeModules)) { + compile = mod._compile; + mod._compile = function _compile(code) { + // reset the compile immediately as otherwise we end up having the + // compile function being changed even though this loader might be reverted + // Not reverting it here leads to long useless compile chains when doing + // addHook -> revert -> addHook -> revert -> ... + // The compile function is also anyway created new when the loader is called a second time. + mod._compile = compile; + const newCode = hook(code, filename); + if (typeof newCode !== 'string') { + throw new Error(HOOK_RETURNED_NOTHING_ERROR_MESSAGE); + } + return mod._compile(newCode, filename); + }; + } + } + oldLoader(mod, filename); + }; + }); + return function revert() { + if (reverted) return; + reverted = true; + exts.forEach(ext => { + // if the current loader for the extension is our loader then unregister it and set the oldLoader again + // if not we can not do anything as we cannot remove a loader from within the loader-chain + if (Module._extensions[ext] === loaders[ext]) { + if (!oldLoaders[ext]) { + delete Module._extensions[ext]; + } else { + Module._extensions[ext] = oldLoaders[ext]; + } + } + }); + }; } -Minimatch.prototype.braceExpand = braceExpand +/***/ }), -function braceExpand (pattern, options) { - if (!options) { - if (this instanceof Minimatch) { - options = this.options +/***/ 90646: +/***/ ((module) => { + +"use strict"; + + +const codes = {}; + +function createErrorType(code, message, Base) { + if (!Base) { + Base = Error + } + + function getMessage (arg1, arg2, arg3) { + if (typeof message === 'string') { + return message } else { - options = {} + return message(arg1, arg2, arg3) } } - pattern = typeof pattern === 'undefined' - ? this.pattern : pattern + class NodeError extends Base { + constructor (arg1, arg2, arg3) { + super(getMessage(arg1, arg2, arg3)); + } + } - assertValidPattern(pattern) + NodeError.prototype.name = Base.name; + NodeError.prototype.code = code; - if (options.nobrace || !/\{(?:(?!\{).)*\}/.test(pattern)) { - // shortcut. no need to expand. - return [pattern] + codes[code] = NodeError; +} + +// https://github.com/nodejs/node/blob/v10.8.0/lib/internal/errors.js +function oneOf(expected, thing) { + if (Array.isArray(expected)) { + const len = expected.length; + expected = expected.map((i) => String(i)); + if (len > 2) { + return `one of ${thing} ${expected.slice(0, len - 1).join(', ')}, or ` + + expected[len - 1]; + } else if (len === 2) { + return `one of ${thing} ${expected[0]} or ${expected[1]}`; + } else { + return `of ${thing} ${expected[0]}`; + } + } else { + return `of ${thing} ${String(expected)}`; } +} - return expand(pattern) +// https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/startsWith +function startsWith(str, search, pos) { + return str.substr(!pos || pos < 0 ? 0 : +pos, search.length) === search; } -const MAX_PATTERN_LENGTH = 1024 * 64 -const assertValidPattern = pattern => { - if (typeof pattern !== 'string') { - throw new TypeError('invalid pattern') +// https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/endsWith +function endsWith(str, search, this_len) { + if (this_len === undefined || this_len > str.length) { + this_len = str.length; + } + return str.substring(this_len - search.length, this_len) === search; +} + +// https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/includes +function includes(str, search, start) { + if (typeof start !== 'number') { + start = 0; } - if (pattern.length > MAX_PATTERN_LENGTH) { - throw new TypeError('pattern is too long') + if (start + search.length > str.length) { + return false; + } else { + return str.indexOf(search, start) !== -1; } } -// parse a component of the expanded set. -// At this point, no pattern may contain "/" in it -// so we're going to return a 2d array, where each entry is the full -// pattern, split on '/', and then turned into a regular expression. -// A regexp is made at the end which joins each array with an -// escaped /, and another full one which joins each regexp with |. -// -// Following the lead of Bash 4.1, note that "**" only has special meaning -// when it is the *only* thing in a path portion. Otherwise, any series -// of * is equivalent to a single *. Globstar behavior is enabled by -// default, and can be disabled by setting options.noglobstar. -Minimatch.prototype.parse = parse -const SUBPARSE = {} -function parse (pattern, isSub) { - assertValidPattern(pattern) +createErrorType('ERR_INVALID_OPT_VALUE', function (name, value) { + return 'The value "' + value + '" is invalid for option "' + name + '"' +}, TypeError); +createErrorType('ERR_INVALID_ARG_TYPE', function (name, expected, actual) { + // determiner: 'must be' or 'must not be' + let determiner; + if (typeof expected === 'string' && startsWith(expected, 'not ')) { + determiner = 'must not be'; + expected = expected.replace(/^not /, ''); + } else { + determiner = 'must be'; + } - var options = this.options + let msg; + if (endsWith(name, ' argument')) { + // For cases like 'first argument' + msg = `The ${name} ${determiner} ${oneOf(expected, 'type')}`; + } else { + const type = includes(name, '.') ? 'property' : 'argument'; + msg = `The "${name}" ${type} ${determiner} ${oneOf(expected, 'type')}`; + } - // shortcuts - if (!options.noglobstar && pattern === '**') return GLOBSTAR - if (pattern === '') return '' + msg += `. Received type ${typeof actual}`; + return msg; +}, TypeError); +createErrorType('ERR_STREAM_PUSH_AFTER_EOF', 'stream.push() after EOF'); +createErrorType('ERR_METHOD_NOT_IMPLEMENTED', function (name) { + return 'The ' + name + ' method is not implemented' +}); +createErrorType('ERR_STREAM_PREMATURE_CLOSE', 'Premature close'); +createErrorType('ERR_STREAM_DESTROYED', function (name) { + return 'Cannot call ' + name + ' after a stream was destroyed'; +}); +createErrorType('ERR_MULTIPLE_CALLBACK', 'Callback called multiple times'); +createErrorType('ERR_STREAM_CANNOT_PIPE', 'Cannot pipe, not readable'); +createErrorType('ERR_STREAM_WRITE_AFTER_END', 'write after end'); +createErrorType('ERR_STREAM_NULL_VALUES', 'May not write null values to stream', TypeError); +createErrorType('ERR_UNKNOWN_ENCODING', function (arg) { + return 'Unknown encoding: ' + arg +}, TypeError); +createErrorType('ERR_STREAM_UNSHIFT_AFTER_END_EVENT', 'stream.unshift() after end event'); - var re = '' - var hasMagic = false - var escaping = false - // ? => one single character - var patternListStack = [] - var negativeLists = [] - var stateChar - var inClass = false - var reClassStart = -1 - var classStart = -1 - // . and .. never match anything that doesn't start with ., - // even when options.dot is set. - var patternStart = pattern.charAt(0) === '.' ? '' // anything - // not (start or / followed by . or .. followed by / or end) - : options.dot ? '(?!(?:^|\\\/)\\.{1,2}(?:$|\\\/))' - : '(?!\\.)' - var self = this +module.exports.q = codes; - function clearStateChar () { - if (stateChar) { - // we had some state-tracking character - // that wasn't consumed by this pass. - switch (stateChar) { - case '*': - re += star - hasMagic = true - break - case '?': - re += qmark - hasMagic = true - break - default: - re += '\\' + stateChar - break - } - self.debug('clearStateChar %j %j', stateChar, re) - stateChar = false - } - } - for (var i = 0, len = pattern.length, c - ; (i < len) && (c = pattern.charAt(i)) - ; i++) { - this.debug('%s\t%s %s %j', pattern, i, re, c) +/***/ }), - // skip over any that are escaped. - if (escaping && reSpecials[c]) { - re += '\\' + c - escaping = false - continue - } +/***/ 97256: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { - switch (c) { - case '/': /* istanbul ignore next */ { - // completely not allowed, even escaped. - // Should already be path-split by now. - return false - } +"use strict"; +// Copyright Joyent, Inc. and other Node contributors. +// +// 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. +// a duplex stream is just a stream that is both readable and writable. +// Since JS doesn't have multiple prototypal inheritance, this class +// prototypally inherits from Readable, and then parasitically from +// Writable. - case '\\': - clearStateChar() - escaping = true - continue +/**/ - // the various stateChar values - // for the "extglob" stuff. - case '?': - case '*': - case '+': - case '@': - case '!': - this.debug('%s\t%s %s %j <-- stateChar', pattern, i, re, c) +var objectKeys = Object.keys || function (obj) { + var keys = []; - // all of those are literals inside a class, except that - // the glob [!a] means [^a] in regexp - if (inClass) { - this.debug(' in class') - if (c === '!' && i === classStart + 1) c = '^' - re += c - continue - } + for (var key in obj) { + keys.push(key); + } - // if we already have a stateChar, then it means - // that there was something like ** or +? in there. - // Handle the stateChar, then proceed with this one. - self.debug('call clearStateChar %j', stateChar) - clearStateChar() - stateChar = c - // if extglob is disabled, then +(asdf|foo) isn't a thing. - // just clear the statechar *now*, rather than even diving into - // the patternList stuff. - if (options.noext) clearStateChar() - continue + return keys; +}; +/**/ - case '(': - if (inClass) { - re += '(' - continue - } - if (!stateChar) { - re += '\\(' - continue - } +module.exports = Duplex; - patternListStack.push({ - type: stateChar, - start: i - 1, - reStart: re.length, - open: plTypes[stateChar].open, - close: plTypes[stateChar].close - }) - // negation is (?:(?!js)[^/]*) - re += stateChar === '!' ? '(?:(?!(?:' : '(?:' - this.debug('plType %j %j', stateChar, re) - stateChar = false - continue +var Readable = __nccwpck_require__(90960); - case ')': - if (inClass || !patternListStack.length) { - re += '\\)' - continue - } +var Writable = __nccwpck_require__(23388); - clearStateChar() - hasMagic = true - var pl = patternListStack.pop() - // negation is (?:(?!js)[^/]*) - // The others are (?:) - re += pl.close - if (pl.type === '!') { - negativeLists.push(pl) - } - pl.reEnd = re.length - continue +__nccwpck_require__(76401)(Duplex, Readable); - case '|': - if (inClass || !patternListStack.length || escaping) { - re += '\\|' - escaping = false - continue - } +{ + // Allow the keys array to be GC'ed. + var keys = objectKeys(Writable.prototype); - clearStateChar() - re += '|' - continue + for (var v = 0; v < keys.length; v++) { + var method = keys[v]; + if (!Duplex.prototype[method]) Duplex.prototype[method] = Writable.prototype[method]; + } +} - // these are mostly the same in regexp and glob - case '[': - // swallow any state-tracking char before the [ - clearStateChar() +function Duplex(options) { + if (!(this instanceof Duplex)) return new Duplex(options); + Readable.call(this, options); + Writable.call(this, options); + this.allowHalfOpen = true; - if (inClass) { - re += '\\' + c - continue - } + if (options) { + if (options.readable === false) this.readable = false; + if (options.writable === false) this.writable = false; - inClass = true - classStart = i - reClassStart = re.length - re += c - continue + if (options.allowHalfOpen === false) { + this.allowHalfOpen = false; + this.once('end', onend); + } + } +} - case ']': - // a right bracket shall lose its special - // meaning and represent itself in - // a bracket expression if it occurs - // first in the list. -- POSIX.2 2.8.3.2 - if (i === classStart + 1 || !inClass) { - re += '\\' + c - escaping = false - continue - } +Object.defineProperty(Duplex.prototype, 'writableHighWaterMark', { + // making it explicit this property is not enumerable + // because otherwise some prototype manipulation in + // userland will fail + enumerable: false, + get: function get() { + return this._writableState.highWaterMark; + } +}); +Object.defineProperty(Duplex.prototype, 'writableBuffer', { + // making it explicit this property is not enumerable + // because otherwise some prototype manipulation in + // userland will fail + enumerable: false, + get: function get() { + return this._writableState && this._writableState.getBuffer(); + } +}); +Object.defineProperty(Duplex.prototype, 'writableLength', { + // making it explicit this property is not enumerable + // because otherwise some prototype manipulation in + // userland will fail + enumerable: false, + get: function get() { + return this._writableState.length; + } +}); // the no-half-open enforcer - // handle the case where we left a class open. - // "[z-a]" is valid, equivalent to "\[z-a\]" - if (inClass) { - // split where the last [ was, make sure we don't have - // an invalid re. if so, re-walk the contents of the - // would-be class to re-translate any characters that - // were passed through as-is - // TODO: It would probably be faster to determine this - // without a try/catch and a new RegExp, but it's tricky - // to do safely. For now, this is safe and works. - var cs = pattern.substring(classStart + 1, i) - try { - RegExp('[' + cs + ']') - } catch (er) { - // not a valid class! - var sp = this.parse(cs, SUBPARSE) - re = re.substr(0, reClassStart) + '\\[' + sp[0] + '\\]' - hasMagic = hasMagic || sp[1] - inClass = false - continue - } - } +function onend() { + // If the writable side ended, then we're ok. + if (this._writableState.ended) return; // no more data can be written. + // But allow more writes to happen in this tick. - // finish up the class. - hasMagic = true - inClass = false - re += c - continue + process.nextTick(onEndNT, this); +} - default: - // swallow any state char that wasn't consumed - clearStateChar() +function onEndNT(self) { + self.end(); +} - if (escaping) { - // no need - escaping = false - } else if (reSpecials[c] - && !(c === '^' && inClass)) { - re += '\\' - } +Object.defineProperty(Duplex.prototype, 'destroyed', { + // making it explicit this property is not enumerable + // because otherwise some prototype manipulation in + // userland will fail + enumerable: false, + get: function get() { + if (this._readableState === undefined || this._writableState === undefined) { + return false; + } - re += c + return this._readableState.destroyed && this._writableState.destroyed; + }, + set: function set(value) { + // we ignore the value if the stream + // has not been initialized yet + if (this._readableState === undefined || this._writableState === undefined) { + return; + } // backward compatibility, the user is explicitly + // managing destroyed - } // switch - } // for - // handle the case where we left a class open. - // "[abc" is valid, equivalent to "\[abc" - if (inClass) { - // split where the last [ was, and escape it - // this is a huge pita. We now have to re-walk - // the contents of the would-be class to re-translate - // any characters that were passed through as-is - cs = pattern.substr(classStart + 1) - sp = this.parse(cs, SUBPARSE) - re = re.substr(0, reClassStart) + '\\[' + sp[0] - hasMagic = hasMagic || sp[1] + this._readableState.destroyed = value; + this._writableState.destroyed = value; } +}); - // handle the case where we had a +( thing at the *end* - // of the pattern. - // each pattern list stack adds 3 chars, and we need to go through - // and escape any | chars that were passed through as-is for the regexp. - // Go through and escape them, taking care not to double-escape any - // | chars that were already escaped. - for (pl = patternListStack.pop(); pl; pl = patternListStack.pop()) { - var tail = re.slice(pl.reStart + pl.open.length) - this.debug('setting tail', re, pl) - // maybe some even number of \, then maybe 1 \, followed by a | - tail = tail.replace(/((?:\\{2}){0,64})(\\?)\|/g, function (_, $1, $2) { - if (!$2) { - // the | isn't already escaped, so escape it. - $2 = '\\' - } - - // need to escape all those slashes *again*, without escaping the - // one that we need for escaping the | character. As it works out, - // escaping an even number of slashes can be done by simply repeating - // it exactly after itself. That's why this trick works. - // - // I am sorry that you have to see this. - return $1 + $1 + $2 + '|' - }) - - this.debug('tail=%j\n %s', tail, tail, pl, re) - var t = pl.type === '*' ? star - : pl.type === '?' ? qmark - : '\\' + pl.type +/***/ }), - hasMagic = true - re = re.slice(0, pl.reStart) + t + '\\(' + tail - } +/***/ 17940: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { - // handle trailing things that only matter at the very end. - clearStateChar() - if (escaping) { - // trailing \\ - re += '\\\\' - } +"use strict"; +// Copyright Joyent, Inc. and other Node contributors. +// +// 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. +// a passthrough stream. +// basically just the most minimal sort of Transform stream. +// Every written chunk gets output as-is. - // only need to apply the nodot start if the re starts with - // something that could conceivably capture a dot - var addPatternStart = false - switch (re.charAt(0)) { - case '.': - case '[': - case '(': addPatternStart = true - } - // Hack to work around lack of negative lookbehind in JS - // A pattern like: *.!(x).!(y|z) needs to ensure that a name - // like 'a.xyz.yz' doesn't match. So, the first negative - // lookahead, has to look ALL the way ahead, to the end of - // the pattern. - for (var n = negativeLists.length - 1; n > -1; n--) { - var nl = negativeLists[n] +module.exports = PassThrough; - var nlBefore = re.slice(0, nl.reStart) - var nlFirst = re.slice(nl.reStart, nl.reEnd - 8) - var nlLast = re.slice(nl.reEnd - 8, nl.reEnd) - var nlAfter = re.slice(nl.reEnd) +var Transform = __nccwpck_require__(56765); - nlLast += nlAfter +__nccwpck_require__(76401)(PassThrough, Transform); - // Handle nested stuff like *(*.js|!(*.json)), where open parens - // mean that we should *not* include the ) in the bit that is considered - // "after" the negated section. - var openParensBefore = nlBefore.split('(').length - 1 - var cleanAfter = nlAfter - for (i = 0; i < openParensBefore; i++) { - cleanAfter = cleanAfter.replace(/\)[+*?]?/, '') - } - nlAfter = cleanAfter +function PassThrough(options) { + if (!(this instanceof PassThrough)) return new PassThrough(options); + Transform.call(this, options); +} - var dollar = '' - if (nlAfter === '' && isSub !== SUBPARSE) { - dollar = '$' - } - var newRe = nlBefore + nlFirst + nlAfter + dollar + nlLast - re = newRe - } +PassThrough.prototype._transform = function (chunk, encoding, cb) { + cb(null, chunk); +}; - // if the re is not "" at this point, then we need to make sure - // it doesn't match against an empty path part. - // Otherwise a/* will match a/, which it should not. - if (re !== '' && hasMagic) { - re = '(?=.)' + re - } +/***/ }), - if (addPatternStart) { - re = patternStart + re - } +/***/ 90960: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { - // parsing just a piece of a larger pattern. - if (isSub === SUBPARSE) { - return [re, hasMagic] - } +"use strict"; +// Copyright Joyent, Inc. and other Node contributors. +// +// 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. - // skip the regexp for non-magical patterns - // unescape anything in it, though, so that it'll be - // an exact match against a file etc. - if (!hasMagic) { - return globUnescape(pattern) - } - var flags = options.nocase ? 'i' : '' - try { - var regExp = new RegExp('^' + re + '$', flags) - } catch (er) /* istanbul ignore next - should be impossible */ { - // If it was an invalid regular expression, then it can't match - // anything. This trick looks for a character after the end of - // the string, which is of course impossible, except in multi-line - // mode, but it's not a /m regex. - return new RegExp('$.') - } +module.exports = Readable; +/**/ - regExp._glob = pattern - regExp._src = re +var Duplex; +/**/ - return regExp -} +Readable.ReadableState = ReadableState; +/**/ -minimatch.makeRe = function (pattern, options) { - return new Minimatch(pattern, options || {}).makeRe() -} +var EE = (__nccwpck_require__(82361).EventEmitter); -Minimatch.prototype.makeRe = makeRe -function makeRe () { - if (this.regexp || this.regexp === false) return this.regexp +var EElistenerCount = function EElistenerCount(emitter, type) { + return emitter.listeners(type).length; +}; +/**/ - // at this point, this.set is a 2d array of partial - // pattern strings, or "**". - // - // It's better to use .match(). This function shouldn't - // be used, really, but it's pretty convenient sometimes, - // when you just want to work with a regex. - var set = this.set +/**/ - if (!set.length) { - this.regexp = false - return this.regexp - } - var options = this.options - var twoStar = options.noglobstar ? star - : options.dot ? twoStarDot - : twoStarNoDot - var flags = options.nocase ? 'i' : '' +var Stream = __nccwpck_require__(99004); +/**/ - var re = set.map(function (pattern) { - return pattern.map(function (p) { - return (p === GLOBSTAR) ? twoStar - : (typeof p === 'string') ? regExpEscape(p) - : p._src - }).join('\\\/') - }).join('|') - // must match entire pattern - // ending in a * or ** will make it less strict. - re = '^(?:' + re + ')$' +var Buffer = (__nccwpck_require__(14300).Buffer); - // can match anything, as long as it's not this. - if (this.negate) re = '^(?!' + re + ').*$' +var OurUint8Array = global.Uint8Array || function () {}; - try { - this.regexp = new RegExp(re, flags) - } catch (ex) /* istanbul ignore next - should be impossible */ { - this.regexp = false - } - return this.regexp +function _uint8ArrayToBuffer(chunk) { + return Buffer.from(chunk); } -minimatch.match = function (list, pattern, options) { - options = options || {} - const mm = new Minimatch(pattern, options) - list = list.filter(function (f) { - return mm.match(f) - }) - if (mm.options.nonull && !list.length) { - list.push(pattern) - } - return list +function _isUint8Array(obj) { + return Buffer.isBuffer(obj) || obj instanceof OurUint8Array; } +/**/ -Minimatch.prototype.match = match -function match (f, partial) { - this.debug('match', f, this.pattern) - // short-circuit in the case of busted things. - // comments, etc. - if (this.comment) return false - if (this.empty) return f === '' - - if (f === '/' && partial) return true - var options = this.options +var debugUtil = __nccwpck_require__(73837); - // windows: need to use /, not \ - if (path.sep !== '/') { - f = f.split(path.sep).join('/') - } +var debug; - // treat the test path as a set of pathparts. - f = f.split(slashSplit) - this.debug(this.pattern, 'split', f) +if (debugUtil && debugUtil.debuglog) { + debug = debugUtil.debuglog('stream'); +} else { + debug = function debug() {}; +} +/**/ - // just ONE of the pattern sets in this.set needs to match - // in order for it to be valid. If negating, then just one - // match means that we have failed. - // Either way, return on the first hit. - var set = this.set - this.debug(this.pattern, 'set', set) +var BufferList = __nccwpck_require__(75920); - // Find the basename of the path by looking for the last non-empty segment - var filename - var i - for (i = f.length - 1; i >= 0; i--) { - filename = f[i] - if (filename) break - } +var destroyImpl = __nccwpck_require__(33148); - for (i = 0; i < set.length; i++) { - var pattern = set[i] - var file = f - if (options.matchBase && pattern.length === 1) { - file = [filename] - } - var hit = this.matchOne(file, pattern, partial) - if (hit) { - if (options.flipNegate) return true - return !this.negate - } - } +var _require = __nccwpck_require__(12138), + getHighWaterMark = _require.getHighWaterMark; - // didn't get any hits. this is success if it's a negative - // pattern, failure otherwise. - if (options.flipNegate) return false - return this.negate -} +var _require$codes = (__nccwpck_require__(90646)/* .codes */ .q), + ERR_INVALID_ARG_TYPE = _require$codes.ERR_INVALID_ARG_TYPE, + ERR_STREAM_PUSH_AFTER_EOF = _require$codes.ERR_STREAM_PUSH_AFTER_EOF, + ERR_METHOD_NOT_IMPLEMENTED = _require$codes.ERR_METHOD_NOT_IMPLEMENTED, + ERR_STREAM_UNSHIFT_AFTER_END_EVENT = _require$codes.ERR_STREAM_UNSHIFT_AFTER_END_EVENT; // Lazy loaded to improve the startup performance. -// set partial to true to test if, for example, -// "/a/b" matches the start of "/*/b/*/d" -// Partial means, if you run out of file before you run -// out of pattern, then that's fine, as long as all -// the parts match. -Minimatch.prototype.matchOne = function (file, pattern, partial) { - var options = this.options - this.debug('matchOne', - { 'this': this, file: file, pattern: pattern }) +var StringDecoder; +var createReadableStreamAsyncIterator; +var from; - this.debug('matchOne', file.length, pattern.length) +__nccwpck_require__(76401)(Readable, Stream); - for (var fi = 0, - pi = 0, - fl = file.length, - pl = pattern.length - ; (fi < fl) && (pi < pl) - ; fi++, pi++) { - this.debug('matchOne loop') - var p = pattern[pi] - var f = file[fi] +var errorOrDestroy = destroyImpl.errorOrDestroy; +var kProxyEvents = ['error', 'close', 'destroy', 'pause', 'resume']; - this.debug(pattern, p, f) +function prependListener(emitter, event, fn) { + // Sadly this is not cacheable as some libraries bundle their own + // event emitter implementation with them. + if (typeof emitter.prependListener === 'function') return emitter.prependListener(event, fn); // This is a hack to make sure that our error handler is attached before any + // userland ones. NEVER DO THIS. This is here only because this code needs + // to continue to work with older versions of Node.js that do not include + // the prependListener() method. The goal is to eventually remove this hack. - // should be impossible. - // some invalid regexp stuff in the set. - /* istanbul ignore if */ - if (p === false) return false + if (!emitter._events || !emitter._events[event]) emitter.on(event, fn);else if (Array.isArray(emitter._events[event])) emitter._events[event].unshift(fn);else emitter._events[event] = [fn, emitter._events[event]]; +} - if (p === GLOBSTAR) { - this.debug('GLOBSTAR', [pattern, p, f]) +function ReadableState(options, stream, isDuplex) { + Duplex = Duplex || __nccwpck_require__(97256); + options = options || {}; // Duplex streams are both readable and writable, but share + // the same options object. + // However, some cases require setting options to different + // values for the readable and the writable sides of the duplex stream. + // These options can be provided separately as readableXXX and writableXXX. - // "**" - // a/**/b/**/c would match the following: - // a/b/x/y/z/c - // a/x/y/z/b/c - // a/b/x/b/x/c - // a/b/c - // To do this, take the rest of the pattern after - // the **, and see if it would match the file remainder. - // If so, return success. - // If not, the ** "swallows" a segment, and try again. - // This is recursively awful. - // - // a/**/b/**/c matching a/b/x/y/z/c - // - a matches a - // - doublestar - // - matchOne(b/x/y/z/c, b/**/c) - // - b matches b - // - doublestar - // - matchOne(x/y/z/c, c) -> no - // - matchOne(y/z/c, c) -> no - // - matchOne(z/c, c) -> no - // - matchOne(c, c) yes, hit - var fr = fi - var pr = pi + 1 - if (pr === pl) { - this.debug('** at the end') - // a ** at the end will just swallow the rest. - // We have found a match. - // however, it will not swallow /.x, unless - // options.dot is set. - // . and .. are *never* matched by **, for explosively - // exponential reasons. - for (; fi < fl; fi++) { - if (file[fi] === '.' || file[fi] === '..' || - (!options.dot && file[fi].charAt(0) === '.')) return false - } - return true - } + if (typeof isDuplex !== 'boolean') isDuplex = stream instanceof Duplex; // object stream flag. Used to make read(n) ignore n and to + // make all the buffer merging and length checks go away - // ok, let's see if we can swallow whatever we can. - while (fr < fl) { - var swallowee = file[fr] + this.objectMode = !!options.objectMode; + if (isDuplex) this.objectMode = this.objectMode || !!options.readableObjectMode; // the point at which it stops calling _read() to fill the buffer + // Note: 0 is a valid value, means "don't call _read preemptively ever" - this.debug('\nglobstar while', file, fr, pattern, pr, swallowee) + this.highWaterMark = getHighWaterMark(this, options, 'readableHighWaterMark', isDuplex); // A linked list is used to store data chunks instead of an array because the + // linked list can remove elements from the beginning faster than + // array.shift() - // XXX remove this slice. Just pass the start index. - if (this.matchOne(file.slice(fr), pattern.slice(pr), partial)) { - this.debug('globstar found match!', fr, fl, swallowee) - // found a match. - return true - } else { - // can't swallow "." or ".." ever. - // can only swallow ".foo" when explicitly asked. - if (swallowee === '.' || swallowee === '..' || - (!options.dot && swallowee.charAt(0) === '.')) { - this.debug('dot detected!', file, fr, pattern, pr) - break - } + this.buffer = new BufferList(); + this.length = 0; + this.pipes = null; + this.pipesCount = 0; + this.flowing = null; + this.ended = false; + this.endEmitted = false; + this.reading = false; // a flag to be able to tell if the event 'readable'/'data' is emitted + // immediately, or on a later tick. We set this to true at first, because + // any actions that shouldn't happen until "later" should generally also + // not happen before the first read call. - // ** swallows a segment, and continue. - this.debug('globstar swallow a segment, and continue') - fr++ - } - } + this.sync = true; // whenever we return null, then we set a flag to say + // that we're awaiting a 'readable' event emission. - // no match was found. - // However, in partial mode, we can't say this is necessarily over. - // If there's more *pattern* left, then - /* istanbul ignore if */ - if (partial) { - // ran out of file - this.debug('\n>>> no match, partial?', file, fr, pattern, pr) - if (fr === fl) return true - } - return false - } + this.needReadable = false; + this.emittedReadable = false; + this.readableListening = false; + this.resumeScheduled = false; + this.paused = true; // Should close be emitted on destroy. Defaults to true. - // something other than ** - // non-magic patterns just have to match exactly - // patterns with magic have been turned into regexps. - var hit - if (typeof p === 'string') { - if (options.nocase) { - hit = f.toLowerCase() === p.toLowerCase() - } else { - hit = f === p - } - this.debug('string match', p, f, hit) - } else { - hit = f.match(p) - this.debug('pattern match', p, f, hit) - } + this.emitClose = options.emitClose !== false; // Should .destroy() be called after 'end' (and potentially 'finish') - if (!hit) return false - } + this.autoDestroy = !!options.autoDestroy; // has it been destroyed - // Note: ending in / means that we'll get a final "" - // at the end of the pattern. This can only match a - // corresponding "" at the end of the file. - // If the file ends in /, then it can only match a - // a pattern that ends in /, unless the pattern just - // doesn't have any more for it. But, a/b/ should *not* - // match "a/b/*", even though "" matches against the - // [^/]*? pattern, except in partial mode, where it might - // simply not be reached yet. - // However, a/b/ should still satisfy a/* + this.destroyed = false; // Crypto is kind of old and crusty. Historically, its default string + // encoding is 'binary' so we have to make this configurable. + // Everything else in the universe uses 'utf8', though. - // now either we fell off the end of the pattern, or we're done. - if (fi === fl && pi === pl) { - // ran out of pattern and filename at the same time. - // an exact hit! - return true - } else if (fi === fl) { - // ran out of file, but still had pattern left. - // this is ok if we're doing the match as part of - // a glob fs traversal. - return partial - } else /* istanbul ignore else */ if (pi === pl) { - // ran out of pattern, still have file left. - // this is only acceptable if we're on the very last - // empty segment of a file with a trailing slash. - // a/* should match a/b/ - return (fi === fl - 1) && (file[fi] === '') - } + this.defaultEncoding = options.defaultEncoding || 'utf8'; // the number of writers that are awaiting a drain event in .pipe()s - // should be unreachable. - /* istanbul ignore next */ - throw new Error('wtf?') -} + this.awaitDrain = 0; // if true, a maybeReadMore has been scheduled -// replace stuff like \* with * -function globUnescape (s) { - return s.replace(/\\(.)/g, '$1') -} + this.readingMore = false; + this.decoder = null; + this.encoding = null; -function regExpEscape (s) { - return s.replace(/[-[\]{}()*+?.,\\^$|#\s]/g, '\\$&') + if (options.encoding) { + if (!StringDecoder) StringDecoder = (__nccwpck_require__(59868)/* .StringDecoder */ .s); + this.decoder = new StringDecoder(options.encoding); + this.encoding = options.encoding; + } } +function Readable(options) { + Duplex = Duplex || __nccwpck_require__(97256); + if (!(this instanceof Readable)) return new Readable(options); // Checking for a Stream.Duplex instance is faster here instead of inside + // the ReadableState constructor, at least with V8 6.5 -/***/ }), + var isDuplex = this instanceof Duplex; + this._readableState = new ReadableState(options, this, isDuplex); // legacy -/***/ 32272: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + this.readable = true; -const ANY = Symbol('SemVer ANY') -// hoisted class for cyclic dependency -class Comparator { - static get ANY () { - return ANY + if (options) { + if (typeof options.read === 'function') this._read = options.read; + if (typeof options.destroy === 'function') this._destroy = options.destroy; } - constructor (comp, options) { - options = parseOptions(options) - if (comp instanceof Comparator) { - if (comp.loose === !!options.loose) { - return comp - } else { - comp = comp.value - } + Stream.call(this); +} + +Object.defineProperty(Readable.prototype, 'destroyed', { + // making it explicit this property is not enumerable + // because otherwise some prototype manipulation in + // userland will fail + enumerable: false, + get: function get() { + if (this._readableState === undefined) { + return false; } - debug('comparator', comp, options) - this.options = options - this.loose = !!options.loose - this.parse(comp) + return this._readableState.destroyed; + }, + set: function set(value) { + // we ignore the value if the stream + // has not been initialized yet + if (!this._readableState) { + return; + } // backward compatibility, the user is explicitly + // managing destroyed - if (this.semver === ANY) { - this.value = '' - } else { - this.value = this.operator + this.semver.version - } - debug('comp', this) + this._readableState.destroyed = value; } +}); +Readable.prototype.destroy = destroyImpl.destroy; +Readable.prototype._undestroy = destroyImpl.undestroy; - parse (comp) { - const r = this.options.loose ? re[t.COMPARATORLOOSE] : re[t.COMPARATOR] - const m = comp.match(r) +Readable.prototype._destroy = function (err, cb) { + cb(err); +}; // Manually shove something into the read() buffer. +// This returns true if the highWaterMark has not been hit yet, +// similar to how Writable.write() returns true if you should +// write() some more. - if (!m) { - throw new TypeError(`Invalid comparator: ${comp}`) - } - this.operator = m[1] !== undefined ? m[1] : '' - if (this.operator === '=') { - this.operator = '' - } +Readable.prototype.push = function (chunk, encoding) { + var state = this._readableState; + var skipChunkCheck; - // if it literally is just '>' or '' then allow anything. - if (!m[2]) { - this.semver = ANY - } else { - this.semver = new SemVer(m[2], this.options.loose) - } - } + if (!state.objectMode) { + if (typeof chunk === 'string') { + encoding = encoding || state.defaultEncoding; - toString () { - return this.value + if (encoding !== state.encoding) { + chunk = Buffer.from(chunk, encoding); + encoding = ''; + } + + skipChunkCheck = true; + } + } else { + skipChunkCheck = true; } - test (version) { - debug('Comparator.test', version, this.options.loose) + return readableAddChunk(this, chunk, encoding, false, skipChunkCheck); +}; // Unshift should *always* be something directly out of read() - if (this.semver === ANY || version === ANY) { - return true - } - if (typeof version === 'string') { - try { - version = new SemVer(version, this.options) - } catch (er) { - return false - } - } +Readable.prototype.unshift = function (chunk) { + return readableAddChunk(this, chunk, null, true, false); +}; - return cmp(version, this.operator, this.semver, this.options) - } +function readableAddChunk(stream, chunk, encoding, addToFront, skipChunkCheck) { + debug('readableAddChunk', chunk); + var state = stream._readableState; - intersects (comp, options) { - if (!(comp instanceof Comparator)) { - throw new TypeError('a Comparator is required') - } + if (chunk === null) { + state.reading = false; + onEofChunk(stream, state); + } else { + var er; + if (!skipChunkCheck) er = chunkInvalid(state, chunk); - if (!options || typeof options !== 'object') { - options = { - loose: !!options, - includePrerelease: false + if (er) { + errorOrDestroy(stream, er); + } else if (state.objectMode || chunk && chunk.length > 0) { + if (typeof chunk !== 'string' && !state.objectMode && Object.getPrototypeOf(chunk) !== Buffer.prototype) { + chunk = _uint8ArrayToBuffer(chunk); } - } - if (this.operator === '') { - if (this.value === '') { - return true - } - return new Range(comp.value, options).test(this.value) - } else if (comp.operator === '') { - if (comp.value === '') { - return true + if (addToFront) { + if (state.endEmitted) errorOrDestroy(stream, new ERR_STREAM_UNSHIFT_AFTER_END_EVENT());else addChunk(stream, state, chunk, true); + } else if (state.ended) { + errorOrDestroy(stream, new ERR_STREAM_PUSH_AFTER_EOF()); + } else if (state.destroyed) { + return false; + } else { + state.reading = false; + + if (state.decoder && !encoding) { + chunk = state.decoder.write(chunk); + if (state.objectMode || chunk.length !== 0) addChunk(stream, state, chunk, false);else maybeReadMore(stream, state); + } else { + addChunk(stream, state, chunk, false); + } } - return new Range(this.value, options).test(comp.semver) + } else if (!addToFront) { + state.reading = false; + maybeReadMore(stream, state); } + } // We can push more data if we are below the highWaterMark. + // Also, if we have no data yet, we can stand some more bytes. + // This is to work around cases where hwm=0, such as the repl. - const sameDirectionIncreasing = - (this.operator === '>=' || this.operator === '>') && - (comp.operator === '>=' || comp.operator === '>') - const sameDirectionDecreasing = - (this.operator === '<=' || this.operator === '<') && - (comp.operator === '<=' || comp.operator === '<') - const sameSemVer = this.semver.version === comp.semver.version - const differentDirectionsInclusive = - (this.operator === '>=' || this.operator === '<=') && - (comp.operator === '>=' || comp.operator === '<=') - const oppositeDirectionsLessThan = - cmp(this.semver, '<', comp.semver, options) && - (this.operator === '>=' || this.operator === '>') && - (comp.operator === '<=' || comp.operator === '<') - const oppositeDirectionsGreaterThan = - cmp(this.semver, '>', comp.semver, options) && - (this.operator === '<=' || this.operator === '<') && - (comp.operator === '>=' || comp.operator === '>') - return ( - sameDirectionIncreasing || - sameDirectionDecreasing || - (sameSemVer && differentDirectionsInclusive) || - oppositeDirectionsLessThan || - oppositeDirectionsGreaterThan - ) + return !state.ended && (state.length < state.highWaterMark || state.length === 0); +} + +function addChunk(stream, state, chunk, addToFront) { + if (state.flowing && state.length === 0 && !state.sync) { + state.awaitDrain = 0; + stream.emit('data', chunk); + } else { + // update the buffer info. + state.length += state.objectMode ? 1 : chunk.length; + if (addToFront) state.buffer.unshift(chunk);else state.buffer.push(chunk); + if (state.needReadable) emitReadable(stream); } + + maybeReadMore(stream, state); } -module.exports = Comparator +function chunkInvalid(state, chunk) { + var er; -const parseOptions = __nccwpck_require__(84615) -const {re, t} = __nccwpck_require__(69493) -const cmp = __nccwpck_require__(21292) -const debug = __nccwpck_require__(96839) -const SemVer = __nccwpck_require__(21098) -const Range = __nccwpck_require__(39378) + if (!_isUint8Array(chunk) && typeof chunk !== 'string' && chunk !== undefined && !state.objectMode) { + er = new ERR_INVALID_ARG_TYPE('chunk', ['string', 'Buffer', 'Uint8Array'], chunk); + } + return er; +} -/***/ }), +Readable.prototype.isPaused = function () { + return this._readableState.flowing === false; +}; // backwards compatibility. -/***/ 39378: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { -// hoisted class for cyclic dependency -class Range { - constructor (range, options) { - options = parseOptions(options) +Readable.prototype.setEncoding = function (enc) { + if (!StringDecoder) StringDecoder = (__nccwpck_require__(59868)/* .StringDecoder */ .s); + var decoder = new StringDecoder(enc); + this._readableState.decoder = decoder; // If setEncoding(null), decoder.encoding equals utf8 - if (range instanceof Range) { - if ( - range.loose === !!options.loose && - range.includePrerelease === !!options.includePrerelease - ) { - return range - } else { - return new Range(range.raw, options) - } - } + this._readableState.encoding = this._readableState.decoder.encoding; // Iterate over current buffer to convert already stored Buffers: - if (range instanceof Comparator) { - // just put it in the set and return - this.raw = range.value - this.set = [[range]] - this.format() - return this - } + var p = this._readableState.buffer.head; + var content = ''; - this.options = options - this.loose = !!options.loose - this.includePrerelease = !!options.includePrerelease + while (p !== null) { + content += decoder.write(p.data); + p = p.next; + } - // First, split based on boolean or || - this.raw = range - this.set = range - .split(/\s*\|\|\s*/) - // map the range to a 2d array of comparators - .map(range => this.parseRange(range.trim())) - // throw out any comparator lists that are empty - // this generally means that it was not a valid range, which is allowed - // in loose mode, but will still throw if the WHOLE range is invalid. - .filter(c => c.length) + this._readableState.buffer.clear(); - if (!this.set.length) { - throw new TypeError(`Invalid SemVer Range: ${range}`) - } + if (content !== '') this._readableState.buffer.push(content); + this._readableState.length = content.length; + return this; +}; // Don't raise the hwm > 1GB - // if we have any that are not the null set, throw out null sets. - if (this.set.length > 1) { - // keep the first one, in case they're all null sets - const first = this.set[0] - this.set = this.set.filter(c => !isNullSet(c[0])) - if (this.set.length === 0) - this.set = [first] - else if (this.set.length > 1) { - // if we have any that are *, then the range is just * - for (const c of this.set) { - if (c.length === 1 && isAny(c[0])) { - this.set = [c] - break - } - } - } - } - this.format() - } +var MAX_HWM = 0x40000000; - format () { - this.range = this.set - .map((comps) => { - return comps.join(' ').trim() - }) - .join('||') - .trim() - return this.range +function computeNewHighWaterMark(n) { + if (n >= MAX_HWM) { + // TODO(ronag): Throw ERR_VALUE_OUT_OF_RANGE. + n = MAX_HWM; + } else { + // Get the next highest power of 2 to prevent increasing hwm excessively in + // tiny amounts + n--; + n |= n >>> 1; + n |= n >>> 2; + n |= n >>> 4; + n |= n >>> 8; + n |= n >>> 16; + n++; } - toString () { - return this.range - } + return n; +} // This function is designed to be inlinable, so please take care when making +// changes to the function body. - parseRange (range) { - range = range.trim() - // memoize range parsing for performance. - // this is a very hot path, and fully deterministic. - const memoOpts = Object.keys(this.options).join(',') - const memoKey = `parseRange:${memoOpts}:${range}` - const cached = cache.get(memoKey) - if (cached) - return cached +function howMuchToRead(n, state) { + if (n <= 0 || state.length === 0 && state.ended) return 0; + if (state.objectMode) return 1; - const loose = this.options.loose - // `1.2.3 - 1.2.4` => `>=1.2.3 <=1.2.4` - const hr = loose ? re[t.HYPHENRANGELOOSE] : re[t.HYPHENRANGE] - range = range.replace(hr, hyphenReplace(this.options.includePrerelease)) - debug('hyphen replace', range) - // `> 1.2.3 < 1.2.5` => `>1.2.3 <1.2.5` - range = range.replace(re[t.COMPARATORTRIM], comparatorTrimReplace) - debug('comparator trim', range, re[t.COMPARATORTRIM]) + if (n !== n) { + // Only flow one buffer at a time + if (state.flowing && state.length) return state.buffer.head.data.length;else return state.length; + } // If we're asking for more than the current hwm, then raise the hwm. - // `~ 1.2.3` => `~1.2.3` - range = range.replace(re[t.TILDETRIM], tildeTrimReplace) - // `^ 1.2.3` => `^1.2.3` - range = range.replace(re[t.CARETTRIM], caretTrimReplace) + if (n > state.highWaterMark) state.highWaterMark = computeNewHighWaterMark(n); + if (n <= state.length) return n; // Don't have enough - // normalize spaces - range = range.split(/\s+/).join(' ') + if (!state.ended) { + state.needReadable = true; + return 0; + } - // At this point, the range is completely trimmed and - // ready to be split into comparators. + return state.length; +} // you can override either this method, or the async _read(n) below. - const compRe = loose ? re[t.COMPARATORLOOSE] : re[t.COMPARATOR] - const rangeList = range - .split(' ') - .map(comp => parseComparator(comp, this.options)) - .join(' ') - .split(/\s+/) - // >=0.0.0 is equivalent to * - .map(comp => replaceGTE0(comp, this.options)) - // in loose mode, throw out any that are not valid comparators - .filter(this.options.loose ? comp => !!comp.match(compRe) : () => true) - .map(comp => new Comparator(comp, this.options)) - // if any comparators are the null set, then replace with JUST null set - // if more than one comparator, remove any * comparators - // also, don't include the same comparator more than once - const l = rangeList.length - const rangeMap = new Map() - for (const comp of rangeList) { - if (isNullSet(comp)) - return [comp] - rangeMap.set(comp.value, comp) - } - if (rangeMap.size > 1 && rangeMap.has('')) - rangeMap.delete('') +Readable.prototype.read = function (n) { + debug('read', n); + n = parseInt(n, 10); + var state = this._readableState; + var nOrig = n; + if (n !== 0) state.emittedReadable = false; // if we're doing read(0) to trigger a readable event, but we + // already have a bunch of data in the buffer, then just trigger + // the 'readable' event and move on. - const result = [...rangeMap.values()] - cache.set(memoKey, result) - return result + if (n === 0 && state.needReadable && ((state.highWaterMark !== 0 ? state.length >= state.highWaterMark : state.length > 0) || state.ended)) { + debug('read: emitReadable', state.length, state.ended); + if (state.length === 0 && state.ended) endReadable(this);else emitReadable(this); + return null; } - intersects (range, options) { - if (!(range instanceof Range)) { - throw new TypeError('a Range is required') - } - - return this.set.some((thisComparators) => { - return ( - isSatisfiable(thisComparators, options) && - range.set.some((rangeComparators) => { - return ( - isSatisfiable(rangeComparators, options) && - thisComparators.every((thisComparator) => { - return rangeComparators.every((rangeComparator) => { - return thisComparator.intersects(rangeComparator, options) - }) - }) - ) - }) - ) - }) - } + n = howMuchToRead(n, state); // if we've ended, and we're now clear, then finish it up. - // if ANY of the sets match ALL of its comparators, then pass - test (version) { - if (!version) { - return false - } - - if (typeof version === 'string') { - try { - version = new SemVer(version, this.options) - } catch (er) { - return false - } - } + if (n === 0 && state.ended) { + if (state.length === 0) endReadable(this); + return null; + } // All the actual chunk generation logic needs to be + // *below* the call to _read. The reason is that in certain + // synthetic stream cases, such as passthrough streams, _read + // may be a completely synchronous operation which may change + // the state of the read buffer, providing enough data when + // before there was *not* enough. + // + // So, the steps are: + // 1. Figure out what the state of things will be after we do + // a read from the buffer. + // + // 2. If that resulting state will trigger a _read, then call _read. + // Note that this may be asynchronous, or synchronous. Yes, it is + // deeply ugly to write APIs this way, but that still doesn't mean + // that the Readable class should behave improperly, as streams are + // designed to be sync/async agnostic. + // Take note if the _read call is sync or async (ie, if the read call + // has returned yet), so that we know whether or not it's safe to emit + // 'readable' etc. + // + // 3. Actually pull the requested chunks out of the buffer and return. + // if we need a readable event, then we need to do some reading. - for (let i = 0; i < this.set.length; i++) { - if (testSet(this.set[i], version, this.options)) { - return true - } - } - return false - } -} -module.exports = Range -const LRU = __nccwpck_require__(83617) -const cache = new LRU({ max: 1000 }) + var doRead = state.needReadable; + debug('need readable', doRead); // if we currently have less than the highWaterMark, then also read some -const parseOptions = __nccwpck_require__(84615) -const Comparator = __nccwpck_require__(32272) -const debug = __nccwpck_require__(96839) -const SemVer = __nccwpck_require__(21098) -const { - re, - t, - comparatorTrimReplace, - tildeTrimReplace, - caretTrimReplace -} = __nccwpck_require__(69493) + if (state.length === 0 || state.length - n < state.highWaterMark) { + doRead = true; + debug('length less than watermark', doRead); + } // however, if we've ended, then there's no point, and if we're already + // reading, then it's unnecessary. -const isNullSet = c => c.value === '<0.0.0-0' -const isAny = c => c.value === '' -// take a set of comparators and determine whether there -// exists a version which can satisfy it -const isSatisfiable = (comparators, options) => { - let result = true - const remainingComparators = comparators.slice() - let testComparator = remainingComparators.pop() + if (state.ended || state.reading) { + doRead = false; + debug('reading or ended', doRead); + } else if (doRead) { + debug('do read'); + state.reading = true; + state.sync = true; // if the length is currently zero, then we *need* a readable event. - while (result && remainingComparators.length) { - result = remainingComparators.every((otherComparator) => { - return testComparator.intersects(otherComparator, options) - }) + if (state.length === 0) state.needReadable = true; // call internal read method - testComparator = remainingComparators.pop() - } + this._read(state.highWaterMark); - return result -} + state.sync = false; // If _read pushed data synchronously, then `reading` will be false, + // and we need to re-evaluate how much data we can return to the user. -// comprised of xranges, tildes, stars, and gtlt's at this point. -// already replaced the hyphen ranges -// turn into a set of JUST comparators. -const parseComparator = (comp, options) => { - debug('comp', comp, options) - comp = replaceCarets(comp, options) - debug('caret', comp) - comp = replaceTildes(comp, options) - debug('tildes', comp) - comp = replaceXRanges(comp, options) - debug('xrange', comp) - comp = replaceStars(comp, options) - debug('stars', comp) - return comp -} + if (!state.reading) n = howMuchToRead(nOrig, state); + } -const isX = id => !id || id.toLowerCase() === 'x' || id === '*' + var ret; + if (n > 0) ret = fromList(n, state);else ret = null; -// ~, ~> --> * (any, kinda silly) -// ~2, ~2.x, ~2.x.x, ~>2, ~>2.x ~>2.x.x --> >=2.0.0 <3.0.0-0 -// ~2.0, ~2.0.x, ~>2.0, ~>2.0.x --> >=2.0.0 <2.1.0-0 -// ~1.2, ~1.2.x, ~>1.2, ~>1.2.x --> >=1.2.0 <1.3.0-0 -// ~1.2.3, ~>1.2.3 --> >=1.2.3 <1.3.0-0 -// ~1.2.0, ~>1.2.0 --> >=1.2.0 <1.3.0-0 -const replaceTildes = (comp, options) => - comp.trim().split(/\s+/).map((comp) => { - return replaceTilde(comp, options) - }).join(' ') + if (ret === null) { + state.needReadable = state.length <= state.highWaterMark; + n = 0; + } else { + state.length -= n; + state.awaitDrain = 0; + } -const replaceTilde = (comp, options) => { - const r = options.loose ? re[t.TILDELOOSE] : re[t.TILDE] - return comp.replace(r, (_, M, m, p, pr) => { - debug('tilde', comp, _, M, m, p, pr) - let ret + if (state.length === 0) { + // If we have nothing in the buffer, then we want to know + // as soon as we *do* get something into the buffer. + if (!state.ended) state.needReadable = true; // If we tried to read() past the EOF, then emit end on the next tick. - if (isX(M)) { - ret = '' - } else if (isX(m)) { - ret = `>=${M}.0.0 <${+M + 1}.0.0-0` - } else if (isX(p)) { - // ~1.2 == >=1.2.0 <1.3.0-0 - ret = `>=${M}.${m}.0 <${M}.${+m + 1}.0-0` - } else if (pr) { - debug('replaceTilde pr', pr) - ret = `>=${M}.${m}.${p}-${pr - } <${M}.${+m + 1}.0-0` - } else { - // ~1.2.3 == >=1.2.3 <1.3.0-0 - ret = `>=${M}.${m}.${p - } <${M}.${+m + 1}.0-0` - } + if (nOrig !== n && state.ended) endReadable(this); + } - debug('tilde return', ret) - return ret - }) -} + if (ret !== null) this.emit('data', ret); + return ret; +}; -// ^ --> * (any, kinda silly) -// ^2, ^2.x, ^2.x.x --> >=2.0.0 <3.0.0-0 -// ^2.0, ^2.0.x --> >=2.0.0 <3.0.0-0 -// ^1.2, ^1.2.x --> >=1.2.0 <2.0.0-0 -// ^1.2.3 --> >=1.2.3 <2.0.0-0 -// ^1.2.0 --> >=1.2.0 <2.0.0-0 -const replaceCarets = (comp, options) => - comp.trim().split(/\s+/).map((comp) => { - return replaceCaret(comp, options) - }).join(' ') +function onEofChunk(stream, state) { + debug('onEofChunk'); + if (state.ended) return; -const replaceCaret = (comp, options) => { - debug('caret', comp, options) - const r = options.loose ? re[t.CARETLOOSE] : re[t.CARET] - const z = options.includePrerelease ? '-0' : '' - return comp.replace(r, (_, M, m, p, pr) => { - debug('caret', comp, _, M, m, p, pr) - let ret + if (state.decoder) { + var chunk = state.decoder.end(); - if (isX(M)) { - ret = '' - } else if (isX(m)) { - ret = `>=${M}.0.0${z} <${+M + 1}.0.0-0` - } else if (isX(p)) { - if (M === '0') { - ret = `>=${M}.${m}.0${z} <${M}.${+m + 1}.0-0` - } else { - ret = `>=${M}.${m}.0${z} <${+M + 1}.0.0-0` - } - } else if (pr) { - debug('replaceCaret pr', pr) - if (M === '0') { - if (m === '0') { - ret = `>=${M}.${m}.${p}-${pr - } <${M}.${m}.${+p + 1}-0` - } else { - ret = `>=${M}.${m}.${p}-${pr - } <${M}.${+m + 1}.0-0` - } - } else { - ret = `>=${M}.${m}.${p}-${pr - } <${+M + 1}.0.0-0` - } - } else { - debug('no pr') - if (M === '0') { - if (m === '0') { - ret = `>=${M}.${m}.${p - }${z} <${M}.${m}.${+p + 1}-0` - } else { - ret = `>=${M}.${m}.${p - }${z} <${M}.${+m + 1}.0-0` - } - } else { - ret = `>=${M}.${m}.${p - } <${+M + 1}.0.0-0` - } + if (chunk && chunk.length) { + state.buffer.push(chunk); + state.length += state.objectMode ? 1 : chunk.length; } + } - debug('caret return', ret) - return ret - }) -} - -const replaceXRanges = (comp, options) => { - debug('replaceXRanges', comp, options) - return comp.split(/\s+/).map((comp) => { - return replaceXRange(comp, options) - }).join(' ') -} + state.ended = true; -const replaceXRange = (comp, options) => { - comp = comp.trim() - const r = options.loose ? re[t.XRANGELOOSE] : re[t.XRANGE] - return comp.replace(r, (ret, gtlt, M, m, p, pr) => { - debug('xRange', comp, ret, gtlt, M, m, p, pr) - const xM = isX(M) - const xm = xM || isX(m) - const xp = xm || isX(p) - const anyX = xp + if (state.sync) { + // if we are sync, wait until next tick to emit the data. + // Otherwise we risk emitting data in the flow() + // the readable code triggers during a read() call + emitReadable(stream); + } else { + // emit 'readable' now to make sure it gets picked up. + state.needReadable = false; - if (gtlt === '=' && anyX) { - gtlt = '' + if (!state.emittedReadable) { + state.emittedReadable = true; + emitReadable_(stream); } + } +} // Don't emit readable right away in sync mode, because this can trigger +// another read() call => stack overflow. This way, it might trigger +// a nextTick recursion warning, but that's not so bad. - // if we're including prereleases in the match, then we need - // to fix this to -0, the lowest possible prerelease value - pr = options.includePrerelease ? '-0' : '' - - if (xM) { - if (gtlt === '>' || gtlt === '<') { - // nothing is allowed - ret = '<0.0.0-0' - } else { - // nothing is forbidden - ret = '*' - } - } else if (gtlt && anyX) { - // we know patch is an x, because we have any x at all. - // replace X with 0 - if (xm) { - m = 0 - } - p = 0 - - if (gtlt === '>') { - // >1 => >=2.0.0 - // >1.2 => >=1.3.0 - gtlt = '>=' - if (xm) { - M = +M + 1 - m = 0 - p = 0 - } else { - m = +m + 1 - p = 0 - } - } else if (gtlt === '<=') { - // <=0.7.x is actually <0.8.0, since any 0.7.x should - // pass. Similarly, <=7.x is actually <8.0.0, etc. - gtlt = '<' - if (xm) { - M = +M + 1 - } else { - m = +m + 1 - } - } - if (gtlt === '<') - pr = '-0' +function emitReadable(stream) { + var state = stream._readableState; + debug('emitReadable', state.needReadable, state.emittedReadable); + state.needReadable = false; - ret = `${gtlt + M}.${m}.${p}${pr}` - } else if (xm) { - ret = `>=${M}.0.0${pr} <${+M + 1}.0.0-0` - } else if (xp) { - ret = `>=${M}.${m}.0${pr - } <${M}.${+m + 1}.0-0` - } + if (!state.emittedReadable) { + debug('emitReadable', state.flowing); + state.emittedReadable = true; + process.nextTick(emitReadable_, stream); + } +} - debug('xRange return', ret) +function emitReadable_(stream) { + var state = stream._readableState; + debug('emitReadable_', state.destroyed, state.length, state.ended); - return ret - }) -} + if (!state.destroyed && (state.length || state.ended)) { + stream.emit('readable'); + state.emittedReadable = false; + } // The stream needs another readable event if + // 1. It is not flowing, as the flow mechanism will take + // care of it. + // 2. It is not ended. + // 3. It is below the highWaterMark, so we can schedule + // another readable later. -// Because * is AND-ed with everything else in the comparator, -// and '' means "any version", just remove the *s entirely. -const replaceStars = (comp, options) => { - debug('replaceStars', comp, options) - // Looseness is ignored here. star is always as loose as it gets! - return comp.trim().replace(re[t.STAR], '') -} -const replaceGTE0 = (comp, options) => { - debug('replaceGTE0', comp, options) - return comp.trim() - .replace(re[options.includePrerelease ? t.GTE0PRE : t.GTE0], '') -} + state.needReadable = !state.flowing && !state.ended && state.length <= state.highWaterMark; + flow(stream); +} // at this point, the user has presumably seen the 'readable' event, +// and called read() to consume some data. that may have triggered +// in turn another _read(n) call, in which case reading = true if +// it's in progress. +// However, if we're not ended, or reading, and the length < hwm, +// then go ahead and try to read some more preemptively. -// This function is passed to string.replace(re[t.HYPHENRANGE]) -// M, m, patch, prerelease, build -// 1.2 - 3.4.5 => >=1.2.0 <=3.4.5 -// 1.2.3 - 3.4 => >=1.2.0 <3.5.0-0 Any 3.4.x will do -// 1.2 - 3.4 => >=1.2.0 <3.5.0-0 -const hyphenReplace = incPr => ($0, - from, fM, fm, fp, fpr, fb, - to, tM, tm, tp, tpr, tb) => { - if (isX(fM)) { - from = '' - } else if (isX(fm)) { - from = `>=${fM}.0.0${incPr ? '-0' : ''}` - } else if (isX(fp)) { - from = `>=${fM}.${fm}.0${incPr ? '-0' : ''}` - } else if (fpr) { - from = `>=${from}` - } else { - from = `>=${from}${incPr ? '-0' : ''}` - } - if (isX(tM)) { - to = '' - } else if (isX(tm)) { - to = `<${+tM + 1}.0.0-0` - } else if (isX(tp)) { - to = `<${tM}.${+tm + 1}.0-0` - } else if (tpr) { - to = `<=${tM}.${tm}.${tp}-${tpr}` - } else if (incPr) { - to = `<${tM}.${tm}.${+tp + 1}-0` - } else { - to = `<=${to}` +function maybeReadMore(stream, state) { + if (!state.readingMore) { + state.readingMore = true; + process.nextTick(maybeReadMore_, stream, state); } - - return (`${from} ${to}`).trim() } -const testSet = (set, version, options) => { - for (let i = 0; i < set.length; i++) { - if (!set[i].test(version)) { - return false - } +function maybeReadMore_(stream, state) { + // Attempt to read more data if we should. + // + // The conditions for reading more data are (one of): + // - Not enough data buffered (state.length < state.highWaterMark). The loop + // is responsible for filling the buffer with enough data if such data + // is available. If highWaterMark is 0 and we are not in the flowing mode + // we should _not_ attempt to buffer any extra data. We'll get more data + // when the stream consumer calls read() instead. + // - No data in the buffer, and the stream is in flowing mode. In this mode + // the loop below is responsible for ensuring read() is called. Failing to + // call read here would abort the flow and there's no other mechanism for + // continuing the flow if the stream consumer has just subscribed to the + // 'data' event. + // + // In addition to the above conditions to keep reading data, the following + // conditions prevent the data from being read: + // - The stream has ended (state.ended). + // - There is already a pending 'read' operation (state.reading). This is a + // case where the the stream has called the implementation defined _read() + // method, but they are processing the call asynchronously and have _not_ + // called push() with new data. In this case we skip performing more + // read()s. The execution ends in this method again after the _read() ends + // up calling push() with more data. + while (!state.reading && !state.ended && (state.length < state.highWaterMark || state.flowing && state.length === 0)) { + var len = state.length; + debug('maybeReadMore read 0'); + stream.read(0); + if (len === state.length) // didn't get any data, stop spinning. + break; } - if (version.prerelease.length && !options.includePrerelease) { - // Find the set of versions that are allowed to have prereleases - // For example, ^1.2.3-pr.1 desugars to >=1.2.3-pr.1 <2.0.0 - // That should allow `1.2.3-pr.2` to pass. - // However, `1.2.4-alpha.notready` should NOT be allowed, - // even though it's within the range set by the comparators. - for (let i = 0; i < set.length; i++) { - debug(set[i].semver) - if (set[i].semver === Comparator.ANY) { - continue - } + state.readingMore = false; +} // abstract method. to be overridden in specific implementation classes. +// call cb(er, data) where data is <= n in length. +// for virtual (non-string, non-buffer) streams, "length" is somewhat +// arbitrary, and perhaps not very meaningful. - if (set[i].semver.prerelease.length > 0) { - const allowed = set[i].semver - if (allowed.major === version.major && - allowed.minor === version.minor && - allowed.patch === version.patch) { - return true - } - } - } - // Version has a -pre, but it's not one of the ones we like. - return false - } +Readable.prototype._read = function (n) { + errorOrDestroy(this, new ERR_METHOD_NOT_IMPLEMENTED('_read()')); +}; - return true -} +Readable.prototype.pipe = function (dest, pipeOpts) { + var src = this; + var state = this._readableState; + switch (state.pipesCount) { + case 0: + state.pipes = dest; + break; -/***/ }), + case 1: + state.pipes = [state.pipes, dest]; + break; -/***/ 21098: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + default: + state.pipes.push(dest); + break; + } -const debug = __nccwpck_require__(96839) -const { MAX_LENGTH, MAX_SAFE_INTEGER } = __nccwpck_require__(76930) -const { re, t } = __nccwpck_require__(69493) + state.pipesCount += 1; + debug('pipe count=%d opts=%j', state.pipesCount, pipeOpts); + var doEnd = (!pipeOpts || pipeOpts.end !== false) && dest !== process.stdout && dest !== process.stderr; + var endFn = doEnd ? onend : unpipe; + if (state.endEmitted) process.nextTick(endFn);else src.once('end', endFn); + dest.on('unpipe', onunpipe); -const parseOptions = __nccwpck_require__(84615) -const { compareIdentifiers } = __nccwpck_require__(17665) -class SemVer { - constructor (version, options) { - options = parseOptions(options) + function onunpipe(readable, unpipeInfo) { + debug('onunpipe'); - if (version instanceof SemVer) { - if (version.loose === !!options.loose && - version.includePrerelease === !!options.includePrerelease) { - return version - } else { - version = version.version + if (readable === src) { + if (unpipeInfo && unpipeInfo.hasUnpiped === false) { + unpipeInfo.hasUnpiped = true; + cleanup(); } - } else if (typeof version !== 'string') { - throw new TypeError(`Invalid Version: ${version}`) } + } - if (version.length > MAX_LENGTH) { - throw new TypeError( - `version is longer than ${MAX_LENGTH} characters` - ) - } + function onend() { + debug('onend'); + dest.end(); + } // when the dest drains, it reduces the awaitDrain counter + // on the source. This would be more elegant with a .once() + // handler in flow(), but adding and removing repeatedly is + // too slow. - debug('SemVer', version, options) - this.options = options - this.loose = !!options.loose - // this isn't actually relevant for versions, but keep it so that we - // don't run into trouble passing this.options around. - this.includePrerelease = !!options.includePrerelease - const m = version.trim().match(options.loose ? re[t.LOOSE] : re[t.FULL]) + var ondrain = pipeOnDrain(src); + dest.on('drain', ondrain); + var cleanedUp = false; - if (!m) { - throw new TypeError(`Invalid Version: ${version}`) - } + function cleanup() { + debug('cleanup'); // cleanup event handlers once the pipe is broken - this.raw = version + dest.removeListener('close', onclose); + dest.removeListener('finish', onfinish); + dest.removeListener('drain', ondrain); + dest.removeListener('error', onerror); + dest.removeListener('unpipe', onunpipe); + src.removeListener('end', onend); + src.removeListener('end', unpipe); + src.removeListener('data', ondata); + cleanedUp = true; // if the reader is waiting for a drain event from this + // specific writer, then it would cause it to never start + // flowing again. + // So, if this is awaiting a drain, then we just call it now. + // If we don't know, then assume that we are waiting for one. - // these are actually numbers - this.major = +m[1] - this.minor = +m[2] - this.patch = +m[3] + if (state.awaitDrain && (!dest._writableState || dest._writableState.needDrain)) ondrain(); + } - if (this.major > MAX_SAFE_INTEGER || this.major < 0) { - throw new TypeError('Invalid major version') - } + src.on('data', ondata); - if (this.minor > MAX_SAFE_INTEGER || this.minor < 0) { - throw new TypeError('Invalid minor version') - } + function ondata(chunk) { + debug('ondata'); + var ret = dest.write(chunk); + debug('dest.write', ret); - if (this.patch > MAX_SAFE_INTEGER || this.patch < 0) { - throw new TypeError('Invalid patch version') - } + if (ret === false) { + // If the user unpiped during `dest.write()`, it is possible + // to get stuck in a permanently paused state if that write + // also returned false. + // => Check whether `dest` is still a piping destination. + if ((state.pipesCount === 1 && state.pipes === dest || state.pipesCount > 1 && indexOf(state.pipes, dest) !== -1) && !cleanedUp) { + debug('false write response, pause', state.awaitDrain); + state.awaitDrain++; + } - // numberify any prerelease numeric ids - if (!m[4]) { - this.prerelease = [] - } else { - this.prerelease = m[4].split('.').map((id) => { - if (/^[0-9]+$/.test(id)) { - const num = +id - if (num >= 0 && num < MAX_SAFE_INTEGER) { - return num - } - } - return id - }) + src.pause(); } + } // if the dest has an error, then stop piping into it. + // however, don't suppress the throwing behavior for this. - this.build = m[5] ? m[5].split('.') : [] - this.format() - } - - format () { - this.version = `${this.major}.${this.minor}.${this.patch}` - if (this.prerelease.length) { - this.version += `-${this.prerelease.join('.')}` - } - return this.version - } - toString () { - return this.version - } + function onerror(er) { + debug('onerror', er); + unpipe(); + dest.removeListener('error', onerror); + if (EElistenerCount(dest, 'error') === 0) errorOrDestroy(dest, er); + } // Make sure our error handler is attached before userland ones. - compare (other) { - debug('SemVer.compare', this.version, this.options, other) - if (!(other instanceof SemVer)) { - if (typeof other === 'string' && other === this.version) { - return 0 - } - other = new SemVer(other, this.options) - } - if (other.version === this.version) { - return 0 - } + prependListener(dest, 'error', onerror); // Both close and finish should trigger unpipe, but only once. - return this.compareMain(other) || this.comparePre(other) + function onclose() { + dest.removeListener('finish', onfinish); + unpipe(); } - compareMain (other) { - if (!(other instanceof SemVer)) { - other = new SemVer(other, this.options) - } + dest.once('close', onclose); - return ( - compareIdentifiers(this.major, other.major) || - compareIdentifiers(this.minor, other.minor) || - compareIdentifiers(this.patch, other.patch) - ) + function onfinish() { + debug('onfinish'); + dest.removeListener('close', onclose); + unpipe(); } - comparePre (other) { - if (!(other instanceof SemVer)) { - other = new SemVer(other, this.options) - } + dest.once('finish', onfinish); - // NOT having a prerelease is > having one - if (this.prerelease.length && !other.prerelease.length) { - return -1 - } else if (!this.prerelease.length && other.prerelease.length) { - return 1 - } else if (!this.prerelease.length && !other.prerelease.length) { - return 0 - } + function unpipe() { + debug('unpipe'); + src.unpipe(dest); + } // tell the dest that it's being piped to - let i = 0 - do { - const a = this.prerelease[i] - const b = other.prerelease[i] - debug('prerelease compare', i, a, b) - if (a === undefined && b === undefined) { - return 0 - } else if (b === undefined) { - return 1 - } else if (a === undefined) { - return -1 - } else if (a === b) { - continue - } else { - return compareIdentifiers(a, b) - } - } while (++i) - } - compareBuild (other) { - if (!(other instanceof SemVer)) { - other = new SemVer(other, this.options) - } + dest.emit('pipe', src); // start the flow if it hasn't been started already. - let i = 0 - do { - const a = this.build[i] - const b = other.build[i] - debug('prerelease compare', i, a, b) - if (a === undefined && b === undefined) { - return 0 - } else if (b === undefined) { - return 1 - } else if (a === undefined) { - return -1 - } else if (a === b) { - continue - } else { - return compareIdentifiers(a, b) - } - } while (++i) + if (!state.flowing) { + debug('pipe resume'); + src.resume(); } - // preminor will bump the version up to the next minor release, and immediately - // down to pre-release. premajor and prepatch work the same way. - inc (release, identifier) { - switch (release) { - case 'premajor': - this.prerelease.length = 0 - this.patch = 0 - this.minor = 0 - this.major++ - this.inc('pre', identifier) - break - case 'preminor': - this.prerelease.length = 0 - this.patch = 0 - this.minor++ - this.inc('pre', identifier) - break - case 'prepatch': - // If this is already a prerelease, it will bump to the next version - // drop any prereleases that might already exist, since they are not - // relevant at this point. - this.prerelease.length = 0 - this.inc('patch', identifier) - this.inc('pre', identifier) - break - // If the input is a non-prerelease version, this acts the same as - // prepatch. - case 'prerelease': - if (this.prerelease.length === 0) { - this.inc('patch', identifier) - } - this.inc('pre', identifier) - break + return dest; +}; - case 'major': - // If this is a pre-major version, bump up to the same major version. - // Otherwise increment major. - // 1.0.0-5 bumps to 1.0.0 - // 1.1.0 bumps to 2.0.0 - if ( - this.minor !== 0 || - this.patch !== 0 || - this.prerelease.length === 0 - ) { - this.major++ - } - this.minor = 0 - this.patch = 0 - this.prerelease = [] - break - case 'minor': - // If this is a pre-minor version, bump up to the same minor version. - // Otherwise increment minor. - // 1.2.0-5 bumps to 1.2.0 - // 1.2.1 bumps to 1.3.0 - if (this.patch !== 0 || this.prerelease.length === 0) { - this.minor++ - } - this.patch = 0 - this.prerelease = [] - break - case 'patch': - // If this is not a pre-release version, it will increment the patch. - // If it is a pre-release it will bump up to the same patch version. - // 1.2.0-5 patches to 1.2.0 - // 1.2.0 patches to 1.2.1 - if (this.prerelease.length === 0) { - this.patch++ - } - this.prerelease = [] - break - // This probably shouldn't be used publicly. - // 1.0.0 'pre' would become 1.0.0-0 which is the wrong direction. - case 'pre': - if (this.prerelease.length === 0) { - this.prerelease = [0] - } else { - let i = this.prerelease.length - while (--i >= 0) { - if (typeof this.prerelease[i] === 'number') { - this.prerelease[i]++ - i = -2 - } - } - if (i === -1) { - // didn't increment anything - this.prerelease.push(0) - } - } - if (identifier) { - // 1.2.0-beta.1 bumps to 1.2.0-beta.2, - // 1.2.0-beta.fooblz or 1.2.0-beta bumps to 1.2.0-beta.0 - if (this.prerelease[0] === identifier) { - if (isNaN(this.prerelease[1])) { - this.prerelease = [identifier, 0] - } - } else { - this.prerelease = [identifier, 0] - } - } - break +function pipeOnDrain(src) { + return function pipeOnDrainFunctionResult() { + var state = src._readableState; + debug('pipeOnDrain', state.awaitDrain); + if (state.awaitDrain) state.awaitDrain--; - default: - throw new Error(`invalid increment argument: ${release}`) + if (state.awaitDrain === 0 && EElistenerCount(src, 'data')) { + state.flowing = true; + flow(src); } - this.format() - this.raw = this.version - return this - } + }; } -module.exports = SemVer +Readable.prototype.unpipe = function (dest) { + var state = this._readableState; + var unpipeInfo = { + hasUnpiped: false + }; // if we're not piping anywhere, then do nothing. + if (state.pipesCount === 0) return this; // just one destination. most common case. -/***/ }), + if (state.pipesCount === 1) { + // passed in one, but it's not the right one. + if (dest && dest !== state.pipes) return this; + if (!dest) dest = state.pipes; // got a match. -/***/ 87225: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + state.pipes = null; + state.pipesCount = 0; + state.flowing = false; + if (dest) dest.emit('unpipe', this, unpipeInfo); + return this; + } // slow case. multiple pipe destinations. -const parse = __nccwpck_require__(93863) -const clean = (version, options) => { - const s = parse(version.trim().replace(/^[=v]+/, ''), options) - return s ? s.version : null -} -module.exports = clean + if (!dest) { + // remove all. + var dests = state.pipes; + var len = state.pipesCount; + state.pipes = null; + state.pipesCount = 0; + state.flowing = false; -/***/ }), + for (var i = 0; i < len; i++) { + dests[i].emit('unpipe', this, { + hasUnpiped: false + }); + } -/***/ 21292: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + return this; + } // try to find the right one. -const eq = __nccwpck_require__(77477) -const neq = __nccwpck_require__(18094) -const gt = __nccwpck_require__(10609) -const gte = __nccwpck_require__(52469) -const lt = __nccwpck_require__(67703) -const lte = __nccwpck_require__(84015) -const cmp = (a, op, b, loose) => { - switch (op) { - case '===': - if (typeof a === 'object') - a = a.version - if (typeof b === 'object') - b = b.version - return a === b + var index = indexOf(state.pipes, dest); + if (index === -1) return this; + state.pipes.splice(index, 1); + state.pipesCount -= 1; + if (state.pipesCount === 1) state.pipes = state.pipes[0]; + dest.emit('unpipe', this, unpipeInfo); + return this; +}; // set up data events if they are asked for +// Ensure readable listeners eventually get something - case '!==': - if (typeof a === 'object') - a = a.version - if (typeof b === 'object') - b = b.version - return a !== b - case '': - case '=': - case '==': - return eq(a, b, loose) +Readable.prototype.on = function (ev, fn) { + var res = Stream.prototype.on.call(this, ev, fn); + var state = this._readableState; - case '!=': - return neq(a, b, loose) + if (ev === 'data') { + // update readableListening so that resume() may be a no-op + // a few lines down. This is needed to support once('readable'). + state.readableListening = this.listenerCount('readable') > 0; // Try start flowing on next tick if stream isn't explicitly paused - case '>': - return gt(a, b, loose) + if (state.flowing !== false) this.resume(); + } else if (ev === 'readable') { + if (!state.endEmitted && !state.readableListening) { + state.readableListening = state.needReadable = true; + state.flowing = false; + state.emittedReadable = false; + debug('on readable', state.length, state.reading); - case '>=': - return gte(a, b, loose) + if (state.length) { + emitReadable(this); + } else if (!state.reading) { + process.nextTick(nReadingNextTick, this); + } + } + } - case '<': - return lt(a, b, loose) + return res; +}; - case '<=': - return lte(a, b, loose) +Readable.prototype.addListener = Readable.prototype.on; - default: - throw new TypeError(`Invalid operator: ${op}`) +Readable.prototype.removeListener = function (ev, fn) { + var res = Stream.prototype.removeListener.call(this, ev, fn); + + if (ev === 'readable') { + // We need to check if there is someone still listening to + // readable and reset the state. However this needs to happen + // after readable has been emitted but before I/O (nextTick) to + // support once('readable', fn) cycles. This means that calling + // resume within the same tick will have no + // effect. + process.nextTick(updateReadableListening, this); } -} -module.exports = cmp + return res; +}; -/***/ }), +Readable.prototype.removeAllListeners = function (ev) { + var res = Stream.prototype.removeAllListeners.apply(this, arguments); -/***/ 77548: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + if (ev === 'readable' || ev === undefined) { + // We need to check if there is someone still listening to + // readable and reset the state. However this needs to happen + // after readable has been emitted but before I/O (nextTick) to + // support once('readable', fn) cycles. This means that calling + // resume within the same tick will have no + // effect. + process.nextTick(updateReadableListening, this); + } -const SemVer = __nccwpck_require__(21098) -const parse = __nccwpck_require__(93863) -const {re, t} = __nccwpck_require__(69493) + return res; +}; -const coerce = (version, options) => { - if (version instanceof SemVer) { - return version - } +function updateReadableListening(self) { + var state = self._readableState; + state.readableListening = self.listenerCount('readable') > 0; - if (typeof version === 'number') { - version = String(version) + if (state.resumeScheduled && !state.paused) { + // flowing needs to be set to true now, otherwise + // the upcoming resume will not flow. + state.flowing = true; // crude way to check if we should resume + } else if (self.listenerCount('data') > 0) { + self.resume(); } +} - if (typeof version !== 'string') { - return null - } +function nReadingNextTick(self) { + debug('readable nexttick read 0'); + self.read(0); +} // pause() and resume() are remnants of the legacy readable stream API +// If the user uses them, then switch into old mode. - options = options || {} - let match = null - if (!options.rtl) { - match = version.match(re[t.COERCE]) - } else { - // Find the right-most coercible string that does not share - // a terminus with a more left-ward coercible string. - // Eg, '1.2.3.4' wants to coerce '2.3.4', not '3.4' or '4' - // - // Walk through the string checking with a /g regexp - // Manually set the index so as to pick up overlapping matches. - // Stop when we get a match that ends at the string end, since no - // coercible string can be more right-ward without the same terminus. - let next - while ((next = re[t.COERCERTL].exec(version)) && - (!match || match.index + match[0].length !== version.length) - ) { - if (!match || - next.index + next[0].length !== match.index + match[0].length) { - match = next - } - re[t.COERCERTL].lastIndex = next.index + next[1].length + next[2].length - } - // leave it in a clean state - re[t.COERCERTL].lastIndex = -1 +Readable.prototype.resume = function () { + var state = this._readableState; + + if (!state.flowing) { + debug('resume'); // we flow only if there is no one listening + // for readable, but we still have to call + // resume() + + state.flowing = !state.readableListening; + resume(this, state); } - if (match === null) - return null + state.paused = false; + return this; +}; - return parse(`${match[2]}.${match[3] || '0'}.${match[4] || '0'}`, options) +function resume(stream, state) { + if (!state.resumeScheduled) { + state.resumeScheduled = true; + process.nextTick(resume_, stream, state); + } } -module.exports = coerce - -/***/ }), +function resume_(stream, state) { + debug('resume', state.reading); -/***/ 17349: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + if (!state.reading) { + stream.read(0); + } -const SemVer = __nccwpck_require__(21098) -const compareBuild = (a, b, loose) => { - const versionA = new SemVer(a, loose) - const versionB = new SemVer(b, loose) - return versionA.compare(versionB) || versionA.compareBuild(versionB) + state.resumeScheduled = false; + stream.emit('resume'); + flow(stream); + if (state.flowing && !state.reading) stream.read(0); } -module.exports = compareBuild +Readable.prototype.pause = function () { + debug('call pause flowing=%j', this._readableState.flowing); -/***/ }), + if (this._readableState.flowing !== false) { + debug('pause'); + this._readableState.flowing = false; + this.emit('pause'); + } -/***/ 70310: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + this._readableState.paused = true; + return this; +}; -const compare = __nccwpck_require__(43234) -const compareLoose = (a, b) => compare(a, b, true) -module.exports = compareLoose +function flow(stream) { + var state = stream._readableState; + debug('flow', state.flowing); + while (state.flowing && stream.read() !== null) { + ; + } +} // wrap an old-style stream as the async data source. +// This is *not* part of the readable stream interface. +// It is an ugly unfortunate mess of history. -/***/ }), -/***/ 43234: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { +Readable.prototype.wrap = function (stream) { + var _this = this; -const SemVer = __nccwpck_require__(21098) -const compare = (a, b, loose) => - new SemVer(a, loose).compare(new SemVer(b, loose)) - -module.exports = compare + var state = this._readableState; + var paused = false; + stream.on('end', function () { + debug('wrapped end'); + if (state.decoder && !state.ended) { + var chunk = state.decoder.end(); + if (chunk && chunk.length) _this.push(chunk); + } -/***/ }), + _this.push(null); + }); + stream.on('data', function (chunk) { + debug('wrapped data'); + if (state.decoder) chunk = state.decoder.write(chunk); // don't skip over falsy values in objectMode -/***/ 89313: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + if (state.objectMode && (chunk === null || chunk === undefined)) return;else if (!state.objectMode && (!chunk || !chunk.length)) return; -const parse = __nccwpck_require__(93863) -const eq = __nccwpck_require__(77477) + var ret = _this.push(chunk); -const diff = (version1, version2) => { - if (eq(version1, version2)) { - return null - } else { - const v1 = parse(version1) - const v2 = parse(version2) - const hasPre = v1.prerelease.length || v2.prerelease.length - const prefix = hasPre ? 'pre' : '' - const defaultResult = hasPre ? 'prerelease' : '' - for (const key in v1) { - if (key === 'major' || key === 'minor' || key === 'patch') { - if (v1[key] !== v2[key]) { - return prefix + key - } - } + if (!ret) { + paused = true; + stream.pause(); } - return defaultResult // may be undefined - } -} -module.exports = diff + }); // proxy all the other methods. + // important when wrapping filters and duplexes. + for (var i in stream) { + if (this[i] === undefined && typeof stream[i] === 'function') { + this[i] = function methodWrap(method) { + return function methodWrapReturnFunction() { + return stream[method].apply(stream, arguments); + }; + }(i); + } + } // proxy certain important events. -/***/ }), -/***/ 77477: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + for (var n = 0; n < kProxyEvents.length; n++) { + stream.on(kProxyEvents[n], this.emit.bind(this, kProxyEvents[n])); + } // when we try to consume some more bytes, simply unpause the + // underlying stream. -const compare = __nccwpck_require__(43234) -const eq = (a, b, loose) => compare(a, b, loose) === 0 -module.exports = eq + this._read = function (n) { + debug('wrapped _read', n); -/***/ }), + if (paused) { + paused = false; + stream.resume(); + } + }; -/***/ 10609: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + return this; +}; -const compare = __nccwpck_require__(43234) -const gt = (a, b, loose) => compare(a, b, loose) > 0 -module.exports = gt +if (typeof Symbol === 'function') { + Readable.prototype[Symbol.asyncIterator] = function () { + if (createReadableStreamAsyncIterator === undefined) { + createReadableStreamAsyncIterator = __nccwpck_require__(51780); + } + return createReadableStreamAsyncIterator(this); + }; +} -/***/ }), +Object.defineProperty(Readable.prototype, 'readableHighWaterMark', { + // making it explicit this property is not enumerable + // because otherwise some prototype manipulation in + // userland will fail + enumerable: false, + get: function get() { + return this._readableState.highWaterMark; + } +}); +Object.defineProperty(Readable.prototype, 'readableBuffer', { + // making it explicit this property is not enumerable + // because otherwise some prototype manipulation in + // userland will fail + enumerable: false, + get: function get() { + return this._readableState && this._readableState.buffer; + } +}); +Object.defineProperty(Readable.prototype, 'readableFlowing', { + // making it explicit this property is not enumerable + // because otherwise some prototype manipulation in + // userland will fail + enumerable: false, + get: function get() { + return this._readableState.flowing; + }, + set: function set(state) { + if (this._readableState) { + this._readableState.flowing = state; + } + } +}); // exposed for testing purposes only. -/***/ 52469: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { +Readable._fromList = fromList; +Object.defineProperty(Readable.prototype, 'readableLength', { + // making it explicit this property is not enumerable + // because otherwise some prototype manipulation in + // userland will fail + enumerable: false, + get: function get() { + return this._readableState.length; + } +}); // Pluck off n bytes from an array of buffers. +// Length is the combined lengths of all the buffers in the list. +// This function is designed to be inlinable, so please take care when making +// changes to the function body. -const compare = __nccwpck_require__(43234) -const gte = (a, b, loose) => compare(a, b, loose) >= 0 -module.exports = gte +function fromList(n, state) { + // nothing buffered + if (state.length === 0) return null; + var ret; + if (state.objectMode) ret = state.buffer.shift();else if (!n || n >= state.length) { + // read it all, truncate the list + if (state.decoder) ret = state.buffer.join('');else if (state.buffer.length === 1) ret = state.buffer.first();else ret = state.buffer.concat(state.length); + state.buffer.clear(); + } else { + // read part of list + ret = state.buffer.consume(n, state.decoder); + } + return ret; +} +function endReadable(stream) { + var state = stream._readableState; + debug('endReadable', state.endEmitted); -/***/ }), + if (!state.endEmitted) { + state.ended = true; + process.nextTick(endReadableNT, state, stream); + } +} -/***/ 10243: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { +function endReadableNT(state, stream) { + debug('endReadableNT', state.endEmitted, state.length); // Check that we didn't get one last unshift. -const SemVer = __nccwpck_require__(21098) + if (!state.endEmitted && state.length === 0) { + state.endEmitted = true; + stream.readable = false; + stream.emit('end'); -const inc = (version, release, options, identifier) => { - if (typeof (options) === 'string') { - identifier = options - options = undefined - } + if (state.autoDestroy) { + // In case of duplex streams we need a way to detect + // if the writable side is ready for autoDestroy as well + var wState = stream._writableState; - try { - return new SemVer(version, options).inc(release, identifier).version - } catch (er) { - return null + if (!wState || wState.autoDestroy && wState.finished) { + stream.destroy(); + } + } } } -module.exports = inc +if (typeof Symbol === 'function') { + Readable.from = function (iterable, opts) { + if (from === undefined) { + from = __nccwpck_require__(42881); + } -/***/ }), - -/***/ 67703: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + return from(Readable, iterable, opts); + }; +} -const compare = __nccwpck_require__(43234) -const lt = (a, b, loose) => compare(a, b, loose) < 0 -module.exports = lt +function indexOf(xs, x) { + for (var i = 0, l = xs.length; i < l; i++) { + if (xs[i] === x) return i; + } + return -1; +} /***/ }), -/***/ 84015: +/***/ 56765: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { -const compare = __nccwpck_require__(43234) -const lte = (a, b, loose) => compare(a, b, loose) <= 0 -module.exports = lte - - -/***/ }), +"use strict"; +// Copyright Joyent, Inc. and other Node contributors. +// +// 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. +// a transform stream is a readable/writable stream where you do +// something with the data. Sometimes it's called a "filter", +// but that's not a great name for it, since that implies a thing where +// some bits pass through, and others are simply ignored. (That would +// be a valid example of a transform, of course.) +// +// While the output is causally related to the input, it's not a +// necessarily symmetric or synchronous transformation. For example, +// a zlib stream might take multiple plain-text writes(), and then +// emit a single compressed chunk some time in the future. +// +// Here's how this works: +// +// The Transform stream has all the aspects of the readable and writable +// stream classes. When you write(chunk), that calls _write(chunk,cb) +// internally, and returns false if there's a lot of pending writes +// buffered up. When you call read(), that calls _read(n) until +// there's enough pending readable data buffered up. +// +// In a transform stream, the written data is placed in a buffer. When +// _read(n) is called, it transforms the queued up data, calling the +// buffered _write cb's as it consumes chunks. If consuming a single +// written chunk would result in multiple output chunks, then the first +// outputted bit calls the readcb, and subsequent chunks just go into +// the read buffer, and will cause it to emit 'readable' if necessary. +// +// This way, back-pressure is actually determined by the reading side, +// since _read has to be called to start processing a new chunk. However, +// a pathological inflate type of transform can cause excessive buffering +// here. For example, imagine a stream where every byte of input is +// interpreted as an integer from 0-255, and then results in that many +// bytes of output. Writing the 4 bytes {ff,ff,ff,ff} would result in +// 1kb of data being output. In this case, you could write a very small +// amount of input, and end up with a very large amount of output. In +// such a pathological inflating mechanism, there'd be no way to tell +// the system to stop doing the transform. A single 4MB write could +// cause the system to run out of memory. +// +// However, even in such a pathological case, only a single written chunk +// would be consumed, and then the rest would wait (un-transformed) until +// the results of the previous transformed chunk were consumed. -/***/ 8222: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { -const SemVer = __nccwpck_require__(21098) -const major = (a, loose) => new SemVer(a, loose).major -module.exports = major +module.exports = Transform; +var _require$codes = (__nccwpck_require__(90646)/* .codes */ .q), + ERR_METHOD_NOT_IMPLEMENTED = _require$codes.ERR_METHOD_NOT_IMPLEMENTED, + ERR_MULTIPLE_CALLBACK = _require$codes.ERR_MULTIPLE_CALLBACK, + ERR_TRANSFORM_ALREADY_TRANSFORMING = _require$codes.ERR_TRANSFORM_ALREADY_TRANSFORMING, + ERR_TRANSFORM_WITH_LENGTH_0 = _require$codes.ERR_TRANSFORM_WITH_LENGTH_0; -/***/ }), +var Duplex = __nccwpck_require__(97256); -/***/ 8940: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { +__nccwpck_require__(76401)(Transform, Duplex); -const SemVer = __nccwpck_require__(21098) -const minor = (a, loose) => new SemVer(a, loose).minor -module.exports = minor +function afterTransform(er, data) { + var ts = this._transformState; + ts.transforming = false; + var cb = ts.writecb; + if (cb === null) { + return this.emit('error', new ERR_MULTIPLE_CALLBACK()); + } -/***/ }), + ts.writechunk = null; + ts.writecb = null; + if (data != null) // single equals check for both `null` and `undefined` + this.push(data); + cb(er); + var rs = this._readableState; + rs.reading = false; -/***/ 18094: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + if (rs.needReadable || rs.length < rs.highWaterMark) { + this._read(rs.highWaterMark); + } +} -const compare = __nccwpck_require__(43234) -const neq = (a, b, loose) => compare(a, b, loose) !== 0 -module.exports = neq +function Transform(options) { + if (!(this instanceof Transform)) return new Transform(options); + Duplex.call(this, options); + this._transformState = { + afterTransform: afterTransform.bind(this), + needTransform: false, + transforming: false, + writecb: null, + writechunk: null, + writeencoding: null + }; // start out asking for a readable event once data is transformed. + this._readableState.needReadable = true; // we have implemented the _read method, and done the other things + // that Readable wants before the first _read call, so unset the + // sync guard flag. -/***/ }), + this._readableState.sync = false; -/***/ 93863: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + if (options) { + if (typeof options.transform === 'function') this._transform = options.transform; + if (typeof options.flush === 'function') this._flush = options.flush; + } // When the writable side finishes, then flush out anything remaining. -const {MAX_LENGTH} = __nccwpck_require__(76930) -const { re, t } = __nccwpck_require__(69493) -const SemVer = __nccwpck_require__(21098) -const parseOptions = __nccwpck_require__(84615) -const parse = (version, options) => { - options = parseOptions(options) + this.on('prefinish', prefinish); +} - if (version instanceof SemVer) { - return version - } +function prefinish() { + var _this = this; - if (typeof version !== 'string') { - return null + if (typeof this._flush === 'function' && !this._readableState.destroyed) { + this._flush(function (er, data) { + done(_this, er, data); + }); + } else { + done(this, null, null); } +} - if (version.length > MAX_LENGTH) { - return null - } +Transform.prototype.push = function (chunk, encoding) { + this._transformState.needTransform = false; + return Duplex.prototype.push.call(this, chunk, encoding); +}; // This is the part where you do stuff! +// override this function in implementation classes. +// 'chunk' is an input chunk. +// +// Call `push(newChunk)` to pass along transformed output +// to the readable side. You may call 'push' zero or more times. +// +// Call `cb(err)` when you are done with this chunk. If you pass +// an error, then that'll put the hurt on the whole operation. If you +// never call cb(), then you'll never get another chunk. - const r = options.loose ? re[t.LOOSE] : re[t.FULL] - if (!r.test(version)) { - return null - } - try { - return new SemVer(version, options) - } catch (er) { - return null - } -} +Transform.prototype._transform = function (chunk, encoding, cb) { + cb(new ERR_METHOD_NOT_IMPLEMENTED('_transform()')); +}; -module.exports = parse +Transform.prototype._write = function (chunk, encoding, cb) { + var ts = this._transformState; + ts.writecb = cb; + ts.writechunk = chunk; + ts.writeencoding = encoding; + if (!ts.transforming) { + var rs = this._readableState; + if (ts.needTransform || rs.needReadable || rs.length < rs.highWaterMark) this._read(rs.highWaterMark); + } +}; // Doesn't matter what the args are here. +// _transform does all the work. +// That we got here means that the readable side wants more data. -/***/ }), -/***/ 74620: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { +Transform.prototype._read = function (n) { + var ts = this._transformState; -const SemVer = __nccwpck_require__(21098) -const patch = (a, loose) => new SemVer(a, loose).patch -module.exports = patch + if (ts.writechunk !== null && !ts.transforming) { + ts.transforming = true; + this._transform(ts.writechunk, ts.writeencoding, ts.afterTransform); + } else { + // mark that we need a transform, so that any data that comes in + // will get processed, now that we've asked for it. + ts.needTransform = true; + } +}; -/***/ }), +Transform.prototype._destroy = function (err, cb) { + Duplex.prototype._destroy.call(this, err, function (err2) { + cb(err2); + }); +}; -/***/ 53811: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { +function done(stream, er, data) { + if (er) return stream.emit('error', er); + if (data != null) // single equals check for both `null` and `undefined` + stream.push(data); // TODO(BridgeAR): Write a test for these two error cases + // if there's nothing in the write buffer, then that means + // that nothing more will ever be provided -const parse = __nccwpck_require__(93863) -const prerelease = (version, options) => { - const parsed = parse(version, options) - return (parsed && parsed.prerelease.length) ? parsed.prerelease : null + if (stream._writableState.length) throw new ERR_TRANSFORM_WITH_LENGTH_0(); + if (stream._transformState.transforming) throw new ERR_TRANSFORM_ALREADY_TRANSFORMING(); + return stream.push(null); } -module.exports = prerelease - /***/ }), -/***/ 80370: +/***/ 23388: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { -const compare = __nccwpck_require__(43234) -const rcompare = (a, b, loose) => compare(b, a, loose) -module.exports = rcompare - +"use strict"; +// Copyright Joyent, Inc. and other Node contributors. +// +// 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. +// A bit simpler than readable streams. +// Implement an async ._write(chunk, encoding, cb), and it'll handle all +// the drain event emission and buffering. -/***/ }), -/***/ 46526: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { +module.exports = Writable; +/* */ -const compareBuild = __nccwpck_require__(17349) -const rsort = (list, loose) => list.sort((a, b) => compareBuild(b, a, loose)) -module.exports = rsort +function WriteReq(chunk, encoding, cb) { + this.chunk = chunk; + this.encoding = encoding; + this.callback = cb; + this.next = null; +} // It seems a linked list but it is not +// there will be only 2 of these for each stream -/***/ }), +function CorkedRequest(state) { + var _this = this; -/***/ 19847: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + this.next = null; + this.entry = null; -const Range = __nccwpck_require__(39378) -const satisfies = (version, range, options) => { - try { - range = new Range(range, options) - } catch (er) { - return false - } - return range.test(version) + this.finish = function () { + onCorkedFinish(_this, state); + }; } -module.exports = satisfies - +/* */ -/***/ }), +/**/ -/***/ 59008: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { -const compareBuild = __nccwpck_require__(17349) -const sort = (list, loose) => list.sort((a, b) => compareBuild(a, b, loose)) -module.exports = sort +var Duplex; +/**/ +Writable.WritableState = WritableState; +/**/ -/***/ }), +var internalUtil = { + deprecate: __nccwpck_require__(96083) +}; +/**/ -/***/ 13742: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { +/**/ -const parse = __nccwpck_require__(93863) -const valid = (version, options) => { - const v = parse(version, options) - return v ? v.version : null -} -module.exports = valid +var Stream = __nccwpck_require__(99004); +/**/ -/***/ }), +var Buffer = (__nccwpck_require__(14300).Buffer); -/***/ 56192: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { +var OurUint8Array = global.Uint8Array || function () {}; -// just pre-load all the stuff that index.js lazily exports -const internalRe = __nccwpck_require__(69493) -module.exports = { - re: internalRe.re, - src: internalRe.src, - tokens: internalRe.t, - SEMVER_SPEC_VERSION: (__nccwpck_require__(76930).SEMVER_SPEC_VERSION), - SemVer: __nccwpck_require__(21098), - compareIdentifiers: (__nccwpck_require__(17665).compareIdentifiers), - rcompareIdentifiers: (__nccwpck_require__(17665).rcompareIdentifiers), - parse: __nccwpck_require__(93863), - valid: __nccwpck_require__(13742), - clean: __nccwpck_require__(87225), - inc: __nccwpck_require__(10243), - diff: __nccwpck_require__(89313), - major: __nccwpck_require__(8222), - minor: __nccwpck_require__(8940), - patch: __nccwpck_require__(74620), - prerelease: __nccwpck_require__(53811), - compare: __nccwpck_require__(43234), - rcompare: __nccwpck_require__(80370), - compareLoose: __nccwpck_require__(70310), - compareBuild: __nccwpck_require__(17349), - sort: __nccwpck_require__(59008), - rsort: __nccwpck_require__(46526), - gt: __nccwpck_require__(10609), - lt: __nccwpck_require__(67703), - eq: __nccwpck_require__(77477), - neq: __nccwpck_require__(18094), - gte: __nccwpck_require__(52469), - lte: __nccwpck_require__(84015), - cmp: __nccwpck_require__(21292), - coerce: __nccwpck_require__(77548), - Comparator: __nccwpck_require__(32272), - Range: __nccwpck_require__(39378), - satisfies: __nccwpck_require__(19847), - toComparators: __nccwpck_require__(9005), - maxSatisfying: __nccwpck_require__(89518), - minSatisfying: __nccwpck_require__(27542), - minVersion: __nccwpck_require__(89296), - validRange: __nccwpck_require__(35569), - outside: __nccwpck_require__(3170), - gtr: __nccwpck_require__(5302), - ltr: __nccwpck_require__(68457), - intersects: __nccwpck_require__(53188), - simplifyRange: __nccwpck_require__(75830), - subset: __nccwpck_require__(54774), +function _uint8ArrayToBuffer(chunk) { + return Buffer.from(chunk); } +function _isUint8Array(obj) { + return Buffer.isBuffer(obj) || obj instanceof OurUint8Array; +} -/***/ }), - -/***/ 76930: -/***/ ((module) => { - -// Note: this is the semver.org version of the spec that it implements -// Not necessarily the package version of this code. -const SEMVER_SPEC_VERSION = '2.0.0' +var destroyImpl = __nccwpck_require__(33148); -const MAX_LENGTH = 256 -const MAX_SAFE_INTEGER = Number.MAX_SAFE_INTEGER || - /* istanbul ignore next */ 9007199254740991 +var _require = __nccwpck_require__(12138), + getHighWaterMark = _require.getHighWaterMark; -// Max safe segment length for coercion. -const MAX_SAFE_COMPONENT_LENGTH = 16 +var _require$codes = (__nccwpck_require__(90646)/* .codes */ .q), + ERR_INVALID_ARG_TYPE = _require$codes.ERR_INVALID_ARG_TYPE, + ERR_METHOD_NOT_IMPLEMENTED = _require$codes.ERR_METHOD_NOT_IMPLEMENTED, + ERR_MULTIPLE_CALLBACK = _require$codes.ERR_MULTIPLE_CALLBACK, + ERR_STREAM_CANNOT_PIPE = _require$codes.ERR_STREAM_CANNOT_PIPE, + ERR_STREAM_DESTROYED = _require$codes.ERR_STREAM_DESTROYED, + ERR_STREAM_NULL_VALUES = _require$codes.ERR_STREAM_NULL_VALUES, + ERR_STREAM_WRITE_AFTER_END = _require$codes.ERR_STREAM_WRITE_AFTER_END, + ERR_UNKNOWN_ENCODING = _require$codes.ERR_UNKNOWN_ENCODING; -module.exports = { - SEMVER_SPEC_VERSION, - MAX_LENGTH, - MAX_SAFE_INTEGER, - MAX_SAFE_COMPONENT_LENGTH -} +var errorOrDestroy = destroyImpl.errorOrDestroy; +__nccwpck_require__(76401)(Writable, Stream); -/***/ }), +function nop() {} -/***/ 96839: -/***/ ((module) => { +function WritableState(options, stream, isDuplex) { + Duplex = Duplex || __nccwpck_require__(97256); + options = options || {}; // Duplex streams are both readable and writable, but share + // the same options object. + // However, some cases require setting options to different + // values for the readable and the writable sides of the duplex stream, + // e.g. options.readableObjectMode vs. options.writableObjectMode, etc. -const debug = ( - typeof process === 'object' && - process.env && - process.env.NODE_DEBUG && - /\bsemver\b/i.test(process.env.NODE_DEBUG) -) ? (...args) => console.error('SEMVER', ...args) - : () => {} + if (typeof isDuplex !== 'boolean') isDuplex = stream instanceof Duplex; // object stream flag to indicate whether or not this stream + // contains buffers or objects. -module.exports = debug + this.objectMode = !!options.objectMode; + if (isDuplex) this.objectMode = this.objectMode || !!options.writableObjectMode; // the point at which write() starts returning false + // Note: 0 is a valid value, means that we always return false if + // the entire buffer is not flushed immediately on write() + this.highWaterMark = getHighWaterMark(this, options, 'writableHighWaterMark', isDuplex); // if _final has been called -/***/ }), + this.finalCalled = false; // drain event flag. -/***/ 17665: -/***/ ((module) => { + this.needDrain = false; // at the start of calling end() -const numeric = /^[0-9]+$/ -const compareIdentifiers = (a, b) => { - const anum = numeric.test(a) - const bnum = numeric.test(b) + this.ending = false; // when end() has been called, and returned - if (anum && bnum) { - a = +a - b = +b - } + this.ended = false; // when 'finish' is emitted - return a === b ? 0 - : (anum && !bnum) ? -1 - : (bnum && !anum) ? 1 - : a < b ? -1 - : 1 -} + this.finished = false; // has it been destroyed -const rcompareIdentifiers = (a, b) => compareIdentifiers(b, a) + this.destroyed = false; // should we decode strings into buffers before passing to _write? + // this is here so that some node-core streams can optimize string + // handling at a lower level. -module.exports = { - compareIdentifiers, - rcompareIdentifiers -} + var noDecode = options.decodeStrings === false; + this.decodeStrings = !noDecode; // Crypto is kind of old and crusty. Historically, its default string + // encoding is 'binary' so we have to make this configurable. + // Everything else in the universe uses 'utf8', though. + this.defaultEncoding = options.defaultEncoding || 'utf8'; // not an actual buffer we keep track of, but a measurement + // of how much we're waiting to get pushed to some underlying + // socket or file. -/***/ }), + this.length = 0; // a flag to see when we're in the middle of a write. -/***/ 84615: -/***/ ((module) => { + this.writing = false; // when true all writes will be buffered until .uncork() call -// parse out just the options we care about so we always get a consistent -// obj with keys in a consistent order. -const opts = ['includePrerelease', 'loose', 'rtl'] -const parseOptions = options => - !options ? {} - : typeof options !== 'object' ? { loose: true } - : opts.filter(k => options[k]).reduce((options, k) => { - options[k] = true - return options - }, {}) -module.exports = parseOptions + this.corked = 0; // a flag to be able to tell if the onwrite cb is called immediately, + // or on a later tick. We set this to true at first, because any + // actions that shouldn't happen until "later" should generally also + // not happen before the first write call. + this.sync = true; // a flag to know if we're processing previously buffered items, which + // may call the _write() callback in the same tick, so that we don't + // end up in an overlapped onwrite situation. -/***/ }), + this.bufferProcessing = false; // the callback that's passed to _write(chunk,cb) -/***/ 69493: -/***/ ((module, exports, __nccwpck_require__) => { + this.onwrite = function (er) { + onwrite(stream, er); + }; // the callback that the user supplies to write(chunk,encoding,cb) -const { MAX_SAFE_COMPONENT_LENGTH } = __nccwpck_require__(76930) -const debug = __nccwpck_require__(96839) -exports = module.exports = {} -// The actual regexps go on exports.re -const re = exports.re = [] -const src = exports.src = [] -const t = exports.t = {} -let R = 0 + this.writecb = null; // the amount that is being written when _write is called. -const createToken = (name, value, isGlobal) => { - const index = R++ - debug(index, value) - t[name] = index - src[index] = value - re[index] = new RegExp(value, isGlobal ? 'g' : undefined) -} + this.writelen = 0; + this.bufferedRequest = null; + this.lastBufferedRequest = null; // number of pending user-supplied write callbacks + // this must be 0 before 'finish' can be emitted -// The following Regular Expressions can be used for tokenizing, -// validating, and parsing SemVer version strings. + this.pendingcb = 0; // emit prefinish if the only thing we're waiting for is _write cbs + // This is relevant for synchronous Transform streams -// ## Numeric Identifier -// A single `0`, or a non-zero digit followed by zero or more digits. + this.prefinished = false; // True if the error was already emitted and should not be thrown again -createToken('NUMERICIDENTIFIER', '0|[1-9]\\d*') -createToken('NUMERICIDENTIFIERLOOSE', '[0-9]+') + this.errorEmitted = false; // Should close be emitted on destroy. Defaults to true. -// ## Non-numeric Identifier -// Zero or more digits, followed by a letter or hyphen, and then zero or -// more letters, digits, or hyphens. + this.emitClose = options.emitClose !== false; // Should .destroy() be called after 'finish' (and potentially 'end') -createToken('NONNUMERICIDENTIFIER', '\\d*[a-zA-Z-][a-zA-Z0-9-]*') + this.autoDestroy = !!options.autoDestroy; // count buffered requests -// ## Main Version -// Three dot-separated numeric identifiers. + this.bufferedRequestCount = 0; // allocate the first CorkedRequest, there is always + // one allocated and free to use, and we maintain at most two -createToken('MAINVERSION', `(${src[t.NUMERICIDENTIFIER]})\\.` + - `(${src[t.NUMERICIDENTIFIER]})\\.` + - `(${src[t.NUMERICIDENTIFIER]})`) + this.corkedRequestsFree = new CorkedRequest(this); +} -createToken('MAINVERSIONLOOSE', `(${src[t.NUMERICIDENTIFIERLOOSE]})\\.` + - `(${src[t.NUMERICIDENTIFIERLOOSE]})\\.` + - `(${src[t.NUMERICIDENTIFIERLOOSE]})`) +WritableState.prototype.getBuffer = function getBuffer() { + var current = this.bufferedRequest; + var out = []; -// ## Pre-release Version Identifier -// A numeric identifier, or a non-numeric identifier. + while (current) { + out.push(current); + current = current.next; + } -createToken('PRERELEASEIDENTIFIER', `(?:${src[t.NUMERICIDENTIFIER] -}|${src[t.NONNUMERICIDENTIFIER]})`) + return out; +}; -createToken('PRERELEASEIDENTIFIERLOOSE', `(?:${src[t.NUMERICIDENTIFIERLOOSE] -}|${src[t.NONNUMERICIDENTIFIER]})`) +(function () { + try { + Object.defineProperty(WritableState.prototype, 'buffer', { + get: internalUtil.deprecate(function writableStateBufferGetter() { + return this.getBuffer(); + }, '_writableState.buffer is deprecated. Use _writableState.getBuffer ' + 'instead.', 'DEP0003') + }); + } catch (_) {} +})(); // Test _writableState for inheritance to account for Duplex streams, +// whose prototype chain only points to Readable. -// ## Pre-release Version -// Hyphen, followed by one or more dot-separated pre-release version -// identifiers. -createToken('PRERELEASE', `(?:-(${src[t.PRERELEASEIDENTIFIER] -}(?:\\.${src[t.PRERELEASEIDENTIFIER]})*))`) +var realHasInstance; -createToken('PRERELEASELOOSE', `(?:-?(${src[t.PRERELEASEIDENTIFIERLOOSE] -}(?:\\.${src[t.PRERELEASEIDENTIFIERLOOSE]})*))`) +if (typeof Symbol === 'function' && Symbol.hasInstance && typeof Function.prototype[Symbol.hasInstance] === 'function') { + realHasInstance = Function.prototype[Symbol.hasInstance]; + Object.defineProperty(Writable, Symbol.hasInstance, { + value: function value(object) { + if (realHasInstance.call(this, object)) return true; + if (this !== Writable) return false; + return object && object._writableState instanceof WritableState; + } + }); +} else { + realHasInstance = function realHasInstance(object) { + return object instanceof this; + }; +} -// ## Build Metadata Identifier -// Any combination of digits, letters, or hyphens. +function Writable(options) { + Duplex = Duplex || __nccwpck_require__(97256); // Writable ctor is applied to Duplexes, too. + // `realHasInstance` is necessary because using plain `instanceof` + // would return false, as no `_writableState` property is attached. + // Trying to use the custom `instanceof` for Writable here will also break the + // Node.js LazyTransform implementation, which has a non-trivial getter for + // `_writableState` that would lead to infinite recursion. + // Checking for a Stream.Duplex instance is faster here instead of inside + // the WritableState constructor, at least with V8 6.5 -createToken('BUILDIDENTIFIER', '[0-9A-Za-z-]+') + var isDuplex = this instanceof Duplex; + if (!isDuplex && !realHasInstance.call(Writable, this)) return new Writable(options); + this._writableState = new WritableState(options, this, isDuplex); // legacy. -// ## Build Metadata -// Plus sign, followed by one or more period-separated build metadata -// identifiers. + this.writable = true; -createToken('BUILD', `(?:\\+(${src[t.BUILDIDENTIFIER] -}(?:\\.${src[t.BUILDIDENTIFIER]})*))`) + if (options) { + if (typeof options.write === 'function') this._write = options.write; + if (typeof options.writev === 'function') this._writev = options.writev; + if (typeof options.destroy === 'function') this._destroy = options.destroy; + if (typeof options.final === 'function') this._final = options.final; + } -// ## Full Version String -// A main version, followed optionally by a pre-release version and -// build metadata. + Stream.call(this); +} // Otherwise people can pipe Writable streams, which is just wrong. -// Note that the only major, minor, patch, and pre-release sections of -// the version string are capturing groups. The build metadata is not a -// capturing group, because it should not ever be used in version -// comparison. -createToken('FULLPLAIN', `v?${src[t.MAINVERSION] -}${src[t.PRERELEASE]}?${ - src[t.BUILD]}?`) +Writable.prototype.pipe = function () { + errorOrDestroy(this, new ERR_STREAM_CANNOT_PIPE()); +}; -createToken('FULL', `^${src[t.FULLPLAIN]}$`) +function writeAfterEnd(stream, cb) { + var er = new ERR_STREAM_WRITE_AFTER_END(); // TODO: defer error events consistently everywhere, not just the cb -// like full, but allows v1.2.3 and =1.2.3, which people do sometimes. -// also, 1.0.0alpha1 (prerelease without the hyphen) which is pretty -// common in the npm registry. -createToken('LOOSEPLAIN', `[v=\\s]*${src[t.MAINVERSIONLOOSE] -}${src[t.PRERELEASELOOSE]}?${ - src[t.BUILD]}?`) + errorOrDestroy(stream, er); + process.nextTick(cb, er); +} // Checks that a user-supplied chunk is valid, especially for the particular +// mode the stream is in. Currently this means that `null` is never accepted +// and undefined/non-string values are only allowed in object mode. -createToken('LOOSE', `^${src[t.LOOSEPLAIN]}$`) -createToken('GTLT', '((?:<|>)?=?)') +function validChunk(stream, state, chunk, cb) { + var er; -// Something like "2.*" or "1.2.x". -// Note that "x.x" is a valid xRange identifer, meaning "any version" -// Only the first item is strictly required. -createToken('XRANGEIDENTIFIERLOOSE', `${src[t.NUMERICIDENTIFIERLOOSE]}|x|X|\\*`) -createToken('XRANGEIDENTIFIER', `${src[t.NUMERICIDENTIFIER]}|x|X|\\*`) + if (chunk === null) { + er = new ERR_STREAM_NULL_VALUES(); + } else if (typeof chunk !== 'string' && !state.objectMode) { + er = new ERR_INVALID_ARG_TYPE('chunk', ['string', 'Buffer'], chunk); + } -createToken('XRANGEPLAIN', `[v=\\s]*(${src[t.XRANGEIDENTIFIER]})` + - `(?:\\.(${src[t.XRANGEIDENTIFIER]})` + - `(?:\\.(${src[t.XRANGEIDENTIFIER]})` + - `(?:${src[t.PRERELEASE]})?${ - src[t.BUILD]}?` + - `)?)?`) + if (er) { + errorOrDestroy(stream, er); + process.nextTick(cb, er); + return false; + } -createToken('XRANGEPLAINLOOSE', `[v=\\s]*(${src[t.XRANGEIDENTIFIERLOOSE]})` + - `(?:\\.(${src[t.XRANGEIDENTIFIERLOOSE]})` + - `(?:\\.(${src[t.XRANGEIDENTIFIERLOOSE]})` + - `(?:${src[t.PRERELEASELOOSE]})?${ - src[t.BUILD]}?` + - `)?)?`) + return true; +} -createToken('XRANGE', `^${src[t.GTLT]}\\s*${src[t.XRANGEPLAIN]}$`) -createToken('XRANGELOOSE', `^${src[t.GTLT]}\\s*${src[t.XRANGEPLAINLOOSE]}$`) +Writable.prototype.write = function (chunk, encoding, cb) { + var state = this._writableState; + var ret = false; -// Coercion. -// Extract anything that could conceivably be a part of a valid semver -createToken('COERCE', `${'(^|[^\\d])' + - '(\\d{1,'}${MAX_SAFE_COMPONENT_LENGTH}})` + - `(?:\\.(\\d{1,${MAX_SAFE_COMPONENT_LENGTH}}))?` + - `(?:\\.(\\d{1,${MAX_SAFE_COMPONENT_LENGTH}}))?` + - `(?:$|[^\\d])`) -createToken('COERCERTL', src[t.COERCE], true) + var isBuf = !state.objectMode && _isUint8Array(chunk); -// Tilde ranges. -// Meaning is "reasonably at or greater than" -createToken('LONETILDE', '(?:~>?)') + if (isBuf && !Buffer.isBuffer(chunk)) { + chunk = _uint8ArrayToBuffer(chunk); + } -createToken('TILDETRIM', `(\\s*)${src[t.LONETILDE]}\\s+`, true) -exports.tildeTrimReplace = '$1~' + if (typeof encoding === 'function') { + cb = encoding; + encoding = null; + } -createToken('TILDE', `^${src[t.LONETILDE]}${src[t.XRANGEPLAIN]}$`) -createToken('TILDELOOSE', `^${src[t.LONETILDE]}${src[t.XRANGEPLAINLOOSE]}$`) + if (isBuf) encoding = 'buffer';else if (!encoding) encoding = state.defaultEncoding; + if (typeof cb !== 'function') cb = nop; + if (state.ending) writeAfterEnd(this, cb);else if (isBuf || validChunk(this, state, chunk, cb)) { + state.pendingcb++; + ret = writeOrBuffer(this, state, isBuf, chunk, encoding, cb); + } + return ret; +}; -// Caret ranges. -// Meaning is "at least and backwards compatible with" -createToken('LONECARET', '(?:\\^)') +Writable.prototype.cork = function () { + this._writableState.corked++; +}; -createToken('CARETTRIM', `(\\s*)${src[t.LONECARET]}\\s+`, true) -exports.caretTrimReplace = '$1^' +Writable.prototype.uncork = function () { + var state = this._writableState; -createToken('CARET', `^${src[t.LONECARET]}${src[t.XRANGEPLAIN]}$`) -createToken('CARETLOOSE', `^${src[t.LONECARET]}${src[t.XRANGEPLAINLOOSE]}$`) + if (state.corked) { + state.corked--; + if (!state.writing && !state.corked && !state.bufferProcessing && state.bufferedRequest) clearBuffer(this, state); + } +}; -// A simple gt/lt/eq thing, or just "" to indicate "any version" -createToken('COMPARATORLOOSE', `^${src[t.GTLT]}\\s*(${src[t.LOOSEPLAIN]})$|^$`) -createToken('COMPARATOR', `^${src[t.GTLT]}\\s*(${src[t.FULLPLAIN]})$|^$`) +Writable.prototype.setDefaultEncoding = function setDefaultEncoding(encoding) { + // node::ParseEncoding() requires lower case. + if (typeof encoding === 'string') encoding = encoding.toLowerCase(); + if (!(['hex', 'utf8', 'utf-8', 'ascii', 'binary', 'base64', 'ucs2', 'ucs-2', 'utf16le', 'utf-16le', 'raw'].indexOf((encoding + '').toLowerCase()) > -1)) throw new ERR_UNKNOWN_ENCODING(encoding); + this._writableState.defaultEncoding = encoding; + return this; +}; -// An expression to strip any whitespace between the gtlt and the thing -// it modifies, so that `> 1.2.3` ==> `>1.2.3` -createToken('COMPARATORTRIM', `(\\s*)${src[t.GTLT] -}\\s*(${src[t.LOOSEPLAIN]}|${src[t.XRANGEPLAIN]})`, true) -exports.comparatorTrimReplace = '$1$2$3' +Object.defineProperty(Writable.prototype, 'writableBuffer', { + // making it explicit this property is not enumerable + // because otherwise some prototype manipulation in + // userland will fail + enumerable: false, + get: function get() { + return this._writableState && this._writableState.getBuffer(); + } +}); -// Something like `1.2.3 - 1.2.4` -// Note that these all use the loose form, because they'll be -// checked against either the strict or loose comparator form -// later. -createToken('HYPHENRANGE', `^\\s*(${src[t.XRANGEPLAIN]})` + - `\\s+-\\s+` + - `(${src[t.XRANGEPLAIN]})` + - `\\s*$`) +function decodeChunk(state, chunk, encoding) { + if (!state.objectMode && state.decodeStrings !== false && typeof chunk === 'string') { + chunk = Buffer.from(chunk, encoding); + } -createToken('HYPHENRANGELOOSE', `^\\s*(${src[t.XRANGEPLAINLOOSE]})` + - `\\s+-\\s+` + - `(${src[t.XRANGEPLAINLOOSE]})` + - `\\s*$`) + return chunk; +} -// Star ranges basically just allow anything at all. -createToken('STAR', '(<|>)?=?\\s*\\*') -// >=0.0.0 is like a star -createToken('GTE0', '^\\s*>=\\s*0\.0\.0\\s*$') -createToken('GTE0PRE', '^\\s*>=\\s*0\.0\.0-0\\s*$') +Object.defineProperty(Writable.prototype, 'writableHighWaterMark', { + // making it explicit this property is not enumerable + // because otherwise some prototype manipulation in + // userland will fail + enumerable: false, + get: function get() { + return this._writableState.highWaterMark; + } +}); // if we're already writing something, then just put this +// in the queue, and wait our turn. Otherwise, call _write +// If we return false, then we need a drain event, so set that flag. +function writeOrBuffer(stream, state, isBuf, chunk, encoding, cb) { + if (!isBuf) { + var newChunk = decodeChunk(state, chunk, encoding); -/***/ }), + if (chunk !== newChunk) { + isBuf = true; + encoding = 'buffer'; + chunk = newChunk; + } + } -/***/ 5302: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + var len = state.objectMode ? 1 : chunk.length; + state.length += len; + var ret = state.length < state.highWaterMark; // we must ensure that previous needDrain will not be reset to false. -// Determine if version is greater than all the versions possible in the range. -const outside = __nccwpck_require__(3170) -const gtr = (version, range, options) => outside(version, range, '>', options) -module.exports = gtr + if (!ret) state.needDrain = true; + if (state.writing || state.corked) { + var last = state.lastBufferedRequest; + state.lastBufferedRequest = { + chunk: chunk, + encoding: encoding, + isBuf: isBuf, + callback: cb, + next: null + }; -/***/ }), + if (last) { + last.next = state.lastBufferedRequest; + } else { + state.bufferedRequest = state.lastBufferedRequest; + } -/***/ 53188: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + state.bufferedRequestCount += 1; + } else { + doWrite(stream, state, false, len, chunk, encoding, cb); + } -const Range = __nccwpck_require__(39378) -const intersects = (r1, r2, options) => { - r1 = new Range(r1, options) - r2 = new Range(r2, options) - return r1.intersects(r2) + return ret; } -module.exports = intersects +function doWrite(stream, state, writev, len, chunk, encoding, cb) { + state.writelen = len; + state.writecb = cb; + state.writing = true; + state.sync = true; + if (state.destroyed) state.onwrite(new ERR_STREAM_DESTROYED('write'));else if (writev) stream._writev(chunk, state.onwrite);else stream._write(chunk, encoding, state.onwrite); + state.sync = false; +} -/***/ }), +function onwriteError(stream, state, sync, er, cb) { + --state.pendingcb; -/***/ 68457: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + if (sync) { + // defer the callback if we are being called synchronously + // to avoid piling up things on the stack + process.nextTick(cb, er); // this can emit finish, and it will always happen + // after error -const outside = __nccwpck_require__(3170) -// Determine if version is less than all the versions possible in the range -const ltr = (version, range, options) => outside(version, range, '<', options) -module.exports = ltr + process.nextTick(finishMaybe, stream, state); + stream._writableState.errorEmitted = true; + errorOrDestroy(stream, er); + } else { + // the caller expect this to happen before if + // it is async + cb(er); + stream._writableState.errorEmitted = true; + errorOrDestroy(stream, er); // this can emit finish, but finish must + // always follow error + finishMaybe(stream, state); + } +} -/***/ }), +function onwriteStateUpdate(state) { + state.writing = false; + state.writecb = null; + state.length -= state.writelen; + state.writelen = 0; +} -/***/ 89518: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { +function onwrite(stream, er) { + var state = stream._writableState; + var sync = state.sync; + var cb = state.writecb; + if (typeof cb !== 'function') throw new ERR_MULTIPLE_CALLBACK(); + onwriteStateUpdate(state); + if (er) onwriteError(stream, state, sync, er, cb);else { + // Check if we're actually ready to finish, but don't emit yet + var finished = needFinish(state) || stream.destroyed; -const SemVer = __nccwpck_require__(21098) -const Range = __nccwpck_require__(39378) + if (!finished && !state.corked && !state.bufferProcessing && state.bufferedRequest) { + clearBuffer(stream, state); + } -const maxSatisfying = (versions, range, options) => { - let max = null - let maxSV = null - let rangeObj = null - try { - rangeObj = new Range(range, options) - } catch (er) { - return null - } - versions.forEach((v) => { - if (rangeObj.test(v)) { - // satisfies(v, range, options) - if (!max || maxSV.compare(v) === -1) { - // compare(max, v, true) - max = v - maxSV = new SemVer(max, options) - } + if (sync) { + process.nextTick(afterWrite, stream, state, finished, cb); + } else { + afterWrite(stream, state, finished, cb); } - }) - return max + } } -module.exports = maxSatisfying +function afterWrite(stream, state, finished, cb) { + if (!finished) onwriteDrain(stream, state); + state.pendingcb--; + cb(); + finishMaybe(stream, state); +} // Must force callback to be called on nextTick, so that we don't +// emit 'drain' before the write() consumer gets the 'false' return +// value, and has a chance to attach a 'drain' listener. -/***/ }), -/***/ 27542: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { - -const SemVer = __nccwpck_require__(21098) -const Range = __nccwpck_require__(39378) -const minSatisfying = (versions, range, options) => { - let min = null - let minSV = null - let rangeObj = null - try { - rangeObj = new Range(range, options) - } catch (er) { - return null - } - versions.forEach((v) => { - if (rangeObj.test(v)) { - // satisfies(v, range, options) - if (!min || minSV.compare(v) === 1) { - // compare(min, v, true) - min = v - minSV = new SemVer(min, options) - } - } - }) - return min -} -module.exports = minSatisfying +function onwriteDrain(stream, state) { + if (state.length === 0 && state.needDrain) { + state.needDrain = false; + stream.emit('drain'); + } +} // if there's something in the buffer waiting, then process it -/***/ }), +function clearBuffer(stream, state) { + state.bufferProcessing = true; + var entry = state.bufferedRequest; -/***/ 89296: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + if (stream._writev && entry && entry.next) { + // Fast case, write everything using _writev() + var l = state.bufferedRequestCount; + var buffer = new Array(l); + var holder = state.corkedRequestsFree; + holder.entry = entry; + var count = 0; + var allBuffers = true; -const SemVer = __nccwpck_require__(21098) -const Range = __nccwpck_require__(39378) -const gt = __nccwpck_require__(10609) + while (entry) { + buffer[count] = entry; + if (!entry.isBuf) allBuffers = false; + entry = entry.next; + count += 1; + } -const minVersion = (range, loose) => { - range = new Range(range, loose) + buffer.allBuffers = allBuffers; + doWrite(stream, state, true, state.length, buffer, '', holder.finish); // doWrite is almost always async, defer these to save a bit of time + // as the hot path ends with doWrite - let minver = new SemVer('0.0.0') - if (range.test(minver)) { - return minver - } + state.pendingcb++; + state.lastBufferedRequest = null; - minver = new SemVer('0.0.0-0') - if (range.test(minver)) { - return minver - } + if (holder.next) { + state.corkedRequestsFree = holder.next; + holder.next = null; + } else { + state.corkedRequestsFree = new CorkedRequest(state); + } - minver = null - for (let i = 0; i < range.set.length; ++i) { - const comparators = range.set[i] + state.bufferedRequestCount = 0; + } else { + // Slow case, write chunks one-by-one + while (entry) { + var chunk = entry.chunk; + var encoding = entry.encoding; + var cb = entry.callback; + var len = state.objectMode ? 1 : chunk.length; + doWrite(stream, state, false, len, chunk, encoding, cb); + entry = entry.next; + state.bufferedRequestCount--; // if we didn't call the onwrite immediately, then + // it means that we need to wait until it does. + // also, that means that the chunk and cb are currently + // being processed, so move the buffer counter past them. - let setMin = null - comparators.forEach((comparator) => { - // Clone to avoid manipulating the comparator's semver object. - const compver = new SemVer(comparator.semver.version) - switch (comparator.operator) { - case '>': - if (compver.prerelease.length === 0) { - compver.patch++ - } else { - compver.prerelease.push(0) - } - compver.raw = compver.format() - /* fallthrough */ - case '': - case '>=': - if (!setMin || gt(compver, setMin)) { - setMin = compver - } - break - case '<': - case '<=': - /* Ignore maximum versions */ - break - /* istanbul ignore next */ - default: - throw new Error(`Unexpected operation: ${comparator.operator}`) + if (state.writing) { + break; } - }) - if (setMin && (!minver || gt(minver, setMin))) - minver = setMin - } + } - if (minver && range.test(minver)) { - return minver + if (entry === null) state.lastBufferedRequest = null; } - return null + state.bufferedRequest = entry; + state.bufferProcessing = false; } -module.exports = minVersion +Writable.prototype._write = function (chunk, encoding, cb) { + cb(new ERR_METHOD_NOT_IMPLEMENTED('_write()')); +}; -/***/ }), +Writable.prototype._writev = null; -/***/ 3170: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { +Writable.prototype.end = function (chunk, encoding, cb) { + var state = this._writableState; -const SemVer = __nccwpck_require__(21098) -const Comparator = __nccwpck_require__(32272) -const {ANY} = Comparator -const Range = __nccwpck_require__(39378) -const satisfies = __nccwpck_require__(19847) -const gt = __nccwpck_require__(10609) -const lt = __nccwpck_require__(67703) -const lte = __nccwpck_require__(84015) -const gte = __nccwpck_require__(52469) + if (typeof chunk === 'function') { + cb = chunk; + chunk = null; + encoding = null; + } else if (typeof encoding === 'function') { + cb = encoding; + encoding = null; + } -const outside = (version, range, hilo, options) => { - version = new SemVer(version, options) - range = new Range(range, options) + if (chunk !== null && chunk !== undefined) this.write(chunk, encoding); // .end() fully uncorks - let gtfn, ltefn, ltfn, comp, ecomp - switch (hilo) { - case '>': - gtfn = gt - ltefn = lte - ltfn = lt - comp = '>' - ecomp = '>=' - break - case '<': - gtfn = lt - ltefn = gte - ltfn = gt - comp = '<' - ecomp = '<=' - break - default: - throw new TypeError('Must provide a hilo val of "<" or ">"') - } + if (state.corked) { + state.corked = 1; + this.uncork(); + } // ignore unnecessary end() calls. - // If it satisfies the range it is not outside - if (satisfies(version, range, options)) { - return false - } - // From now on, variable terms are as if we're in "gtr" mode. - // but note that everything is flipped for the "ltr" function. + if (!state.ending) endWritable(this, state, cb); + return this; +}; - for (let i = 0; i < range.set.length; ++i) { - const comparators = range.set[i] +Object.defineProperty(Writable.prototype, 'writableLength', { + // making it explicit this property is not enumerable + // because otherwise some prototype manipulation in + // userland will fail + enumerable: false, + get: function get() { + return this._writableState.length; + } +}); - let high = null - let low = null +function needFinish(state) { + return state.ending && state.length === 0 && state.bufferedRequest === null && !state.finished && !state.writing; +} - comparators.forEach((comparator) => { - if (comparator.semver === ANY) { - comparator = new Comparator('>=0.0.0') - } - high = high || comparator - low = low || comparator - if (gtfn(comparator.semver, high.semver, options)) { - high = comparator - } else if (ltfn(comparator.semver, low.semver, options)) { - low = comparator - } - }) +function callFinal(stream, state) { + stream._final(function (err) { + state.pendingcb--; - // If the edge version comparator has a operator then our version - // isn't outside it - if (high.operator === comp || high.operator === ecomp) { - return false + if (err) { + errorOrDestroy(stream, err); } - // If the lowest version comparator has an operator and our version - // is less than it then it isn't higher than the range - if ((!low.operator || low.operator === comp) && - ltefn(version, low.semver)) { - return false - } else if (low.operator === ecomp && ltfn(version, low.semver)) { - return false + state.prefinished = true; + stream.emit('prefinish'); + finishMaybe(stream, state); + }); +} + +function prefinish(stream, state) { + if (!state.prefinished && !state.finalCalled) { + if (typeof stream._final === 'function' && !state.destroyed) { + state.pendingcb++; + state.finalCalled = true; + process.nextTick(callFinal, stream, state); + } else { + state.prefinished = true; + stream.emit('prefinish'); } } - return true } -module.exports = outside +function finishMaybe(stream, state) { + var need = needFinish(state); + if (need) { + prefinish(stream, state); -/***/ }), + if (state.pendingcb === 0) { + state.finished = true; + stream.emit('finish'); -/***/ 75830: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + if (state.autoDestroy) { + // In case of duplex streams we need a way to detect + // if the readable side is ready for autoDestroy as well + var rState = stream._readableState; -// given a set of versions and a range, create a "simplified" range -// that includes the same versions that the original range does -// If the original range is shorter than the simplified one, return that. -const satisfies = __nccwpck_require__(19847) -const compare = __nccwpck_require__(43234) -module.exports = (versions, range, options) => { - const set = [] - let min = null - let prev = null - const v = versions.sort((a, b) => compare(a, b, options)) - for (const version of v) { - const included = satisfies(version, range, options) - if (included) { - prev = version - if (!min) - min = version - } else { - if (prev) { - set.push([min, prev]) + if (!rState || rState.autoDestroy && rState.endEmitted) { + stream.destroy(); + } } - prev = null - min = null } } - if (min) - set.push([min, null]) - const ranges = [] - for (const [min, max] of set) { - if (min === max) - ranges.push(min) - else if (!max && min === v[0]) - ranges.push('*') - else if (!max) - ranges.push(`>=${min}`) - else if (min === v[0]) - ranges.push(`<=${max}`) - else - ranges.push(`${min} - ${max}`) - } - const simplified = ranges.join(' || ') - const original = typeof range.raw === 'string' ? range.raw : String(range) - return simplified.length < original.length ? simplified : range + return need; } +function endWritable(stream, state, cb) { + state.ending = true; + finishMaybe(stream, state); -/***/ }), + if (cb) { + if (state.finished) process.nextTick(cb);else stream.once('finish', cb); + } -/***/ 54774: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + state.ended = true; + stream.writable = false; +} -const Range = __nccwpck_require__(39378) -const { ANY } = __nccwpck_require__(32272) -const satisfies = __nccwpck_require__(19847) -const compare = __nccwpck_require__(43234) +function onCorkedFinish(corkReq, state, err) { + var entry = corkReq.entry; + corkReq.entry = null; -// Complex range `r1 || r2 || ...` is a subset of `R1 || R2 || ...` iff: -// - Every simple range `r1, r2, ...` is a subset of some `R1, R2, ...` -// -// Simple range `c1 c2 ...` is a subset of simple range `C1 C2 ...` iff: -// - If c is only the ANY comparator -// - If C is only the ANY comparator, return true -// - Else return false -// - Let EQ be the set of = comparators in c -// - If EQ is more than one, return true (null set) -// - Let GT be the highest > or >= comparator in c -// - Let LT be the lowest < or <= comparator in c -// - If GT and LT, and GT.semver > LT.semver, return true (null set) -// - If EQ -// - If GT, and EQ does not satisfy GT, return true (null set) -// - If LT, and EQ does not satisfy LT, return true (null set) -// - If EQ satisfies every C, return true -// - Else return false -// - If GT -// - If GT.semver is lower than any > or >= comp in C, return false -// - If GT is >=, and GT.semver does not satisfy every C, return false -// - If LT -// - If LT.semver is greater than any < or <= comp in C, return false -// - If LT is <=, and LT.semver does not satisfy every C, return false -// - If any C is a = range, and GT or LT are set, return false -// - Else return true + while (entry) { + var cb = entry.callback; + state.pendingcb--; + cb(err); + entry = entry.next; + } // reuse the free corkReq. -const subset = (sub, dom, options) => { - if (sub === dom) - return true - sub = new Range(sub, options) - dom = new Range(dom, options) - let sawNonNull = false + state.corkedRequestsFree.next = corkReq; +} - OUTER: for (const simpleSub of sub.set) { - for (const simpleDom of dom.set) { - const isSub = simpleSubset(simpleSub, simpleDom, options) - sawNonNull = sawNonNull || isSub !== null - if (isSub) - continue OUTER +Object.defineProperty(Writable.prototype, 'destroyed', { + // making it explicit this property is not enumerable + // because otherwise some prototype manipulation in + // userland will fail + enumerable: false, + get: function get() { + if (this._writableState === undefined) { + return false; } - // the null set is a subset of everything, but null simple ranges in - // a complex range should be ignored. so if we saw a non-null range, - // then we know this isn't a subset, but if EVERY simple range was null, - // then it is a subset. - if (sawNonNull) - return false - } - return true -} -const simpleSubset = (sub, dom, options) => { - if (sub === dom) - return true + return this._writableState.destroyed; + }, + set: function set(value) { + // we ignore the value if the stream + // has not been initialized yet + if (!this._writableState) { + return; + } // backward compatibility, the user is explicitly + // managing destroyed - if (sub.length === 1 && sub[0].semver === ANY) - return dom.length === 1 && dom[0].semver === ANY - const eqSet = new Set() - let gt, lt - for (const c of sub) { - if (c.operator === '>' || c.operator === '>=') - gt = higherGT(gt, c, options) - else if (c.operator === '<' || c.operator === '<=') - lt = lowerLT(lt, c, options) - else - eqSet.add(c.semver) + this._writableState.destroyed = value; } +}); +Writable.prototype.destroy = destroyImpl.destroy; +Writable.prototype._undestroy = destroyImpl.undestroy; - if (eqSet.size > 1) - return null +Writable.prototype._destroy = function (err, cb) { + cb(err); +}; - let gtltComp - if (gt && lt) { - gtltComp = compare(gt.semver, lt.semver, options) - if (gtltComp > 0) - return null - else if (gtltComp === 0 && (gt.operator !== '>=' || lt.operator !== '<=')) - return null - } +/***/ }), - // will iterate one or zero times - for (const eq of eqSet) { - if (gt && !satisfies(eq, String(gt), options)) - return null +/***/ 51780: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { - if (lt && !satisfies(eq, String(lt), options)) - return null +"use strict"; - for (const c of dom) { - if (!satisfies(eq, String(c), options)) - return false - } - return true - } +var _Object$setPrototypeO; - let higher, lower - let hasDomLT, hasDomGT - for (const c of dom) { - hasDomGT = hasDomGT || c.operator === '>' || c.operator === '>=' - hasDomLT = hasDomLT || c.operator === '<' || c.operator === '<=' - if (gt) { - if (c.operator === '>' || c.operator === '>=') { - higher = higherGT(gt, c, options) - if (higher === c && higher !== gt) - return false - } else if (gt.operator === '>=' && !satisfies(gt.semver, String(c), options)) - return false - } - if (lt) { - if (c.operator === '<' || c.operator === '<=') { - lower = lowerLT(lt, c, options) - if (lower === c && lower !== lt) - return false - } else if (lt.operator === '<=' && !satisfies(lt.semver, String(c), options)) - return false - } - if (!c.operator && (lt || gt) && gtltComp !== 0) - return false - } +function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; } - // if there was a < or >, and nothing in the dom, then must be false - // UNLESS it was limited by another range in the other direction. - // Eg, >1.0.0 <1.0.1 is still a subset of <2.0.0 - if (gt && hasDomLT && !lt && gtltComp !== 0) - return false +var finished = __nccwpck_require__(75628); - if (lt && hasDomGT && !gt && gtltComp !== 0) - return false +var kLastResolve = Symbol('lastResolve'); +var kLastReject = Symbol('lastReject'); +var kError = Symbol('error'); +var kEnded = Symbol('ended'); +var kLastPromise = Symbol('lastPromise'); +var kHandlePromise = Symbol('handlePromise'); +var kStream = Symbol('stream'); - return true +function createIterResult(value, done) { + return { + value: value, + done: done + }; } -// >=1.2.3 is lower than >1.2.3 -const higherGT = (a, b, options) => { - if (!a) - return b - const comp = compare(a.semver, b.semver, options) - return comp > 0 ? a - : comp < 0 ? b - : b.operator === '>' && a.operator === '>=' ? b - : a +function readAndResolve(iter) { + var resolve = iter[kLastResolve]; + + if (resolve !== null) { + var data = iter[kStream].read(); // we defer if data is null + // we can be expecting either 'end' or + // 'error' + + if (data !== null) { + iter[kLastPromise] = null; + iter[kLastResolve] = null; + iter[kLastReject] = null; + resolve(createIterResult(data, false)); + } + } } -// <=1.2.3 is higher than <1.2.3 -const lowerLT = (a, b, options) => { - if (!a) - return b - const comp = compare(a.semver, b.semver, options) - return comp < 0 ? a - : comp > 0 ? b - : b.operator === '<' && a.operator === '<=' ? b - : a +function onReadable(iter) { + // we wait for the next tick, because it might + // emit an error with process.nextTick + process.nextTick(readAndResolve, iter); } -module.exports = subset +function wrapForNext(lastPromise, iter) { + return function (resolve, reject) { + lastPromise.then(function () { + if (iter[kEnded]) { + resolve(createIterResult(undefined, true)); + return; + } + iter[kHandlePromise](resolve, reject); + }, reject); + }; +} -/***/ }), +var AsyncIteratorPrototype = Object.getPrototypeOf(function () {}); +var ReadableStreamAsyncIteratorPrototype = Object.setPrototypeOf((_Object$setPrototypeO = { + get stream() { + return this[kStream]; + }, -/***/ 9005: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + next: function next() { + var _this = this; -const Range = __nccwpck_require__(39378) + // if we have detected an error in the meanwhile + // reject straight away + var error = this[kError]; -// Mostly just for testing and legacy API reasons -const toComparators = (range, options) => - new Range(range, options).set - .map(comp => comp.map(c => c.value).join(' ').trim().split(' ')) + if (error !== null) { + return Promise.reject(error); + } -module.exports = toComparators + if (this[kEnded]) { + return Promise.resolve(createIterResult(undefined, true)); + } + if (this[kStream].destroyed) { + // We need to defer via nextTick because if .destroy(err) is + // called, the error will be emitted via nextTick, and + // we cannot guarantee that there is no error lingering around + // waiting to be emitted. + return new Promise(function (resolve, reject) { + process.nextTick(function () { + if (_this[kError]) { + reject(_this[kError]); + } else { + resolve(createIterResult(undefined, true)); + } + }); + }); + } // if we have multiple next() calls + // we will wait for the previous Promise to finish + // this logic is optimized to support for await loops, + // where next() is only called once at a time -/***/ }), -/***/ 35569: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + var lastPromise = this[kLastPromise]; + var promise; -const Range = __nccwpck_require__(39378) -const validRange = (range, options) => { - try { - // Return '*' instead of '' so that truthiness works. - // This will throw if it's invalid anyway - return new Range(range, options).range || '*' - } catch (er) { - return null - } -} -module.exports = validRange + if (lastPromise) { + promise = new Promise(wrapForNext(lastPromise, this)); + } else { + // fast path needed to support multiple this.push() + // without triggering the next() queue + var data = this[kStream].read(); + if (data !== null) { + return Promise.resolve(createIterResult(data, false)); + } -/***/ }), + promise = new Promise(this[kHandlePromise]); + } -/***/ 51796: -/***/ ((module) => { + this[kLastPromise] = promise; + return promise; + } +}, _defineProperty(_Object$setPrototypeO, Symbol.asyncIterator, function () { + return this; +}), _defineProperty(_Object$setPrototypeO, "return", function _return() { + var _this2 = this; -/****************************************************************************** -Copyright (c) Microsoft Corporation. + // destroy(err, cb) is a private API + // we can guarantee we have that here, because we control the + // Readable class this is attached to + return new Promise(function (resolve, reject) { + _this2[kStream].destroy(null, function (err) { + if (err) { + reject(err); + return; + } -Permission to use, copy, modify, and/or distribute this software for any -purpose with or without fee is hereby granted. + resolve(createIterResult(undefined, true)); + }); + }); +}), _Object$setPrototypeO), AsyncIteratorPrototype); -THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH -REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY -AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, -INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM -LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR -OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR -PERFORMANCE OF THIS SOFTWARE. -***************************************************************************** */ -/* global global, define, System, Reflect, Promise */ -var __extends; -var __assign; -var __rest; -var __decorate; -var __param; -var __esDecorate; -var __runInitializers; -var __propKey; -var __setFunctionName; -var __metadata; -var __awaiter; -var __generator; -var __exportStar; -var __values; -var __read; -var __spread; -var __spreadArrays; -var __spreadArray; -var __await; -var __asyncGenerator; -var __asyncDelegator; -var __asyncValues; -var __makeTemplateObject; -var __importStar; -var __importDefault; -var __classPrivateFieldGet; -var __classPrivateFieldSet; -var __classPrivateFieldIn; -var __createBinding; -(function (factory) { - var root = typeof global === "object" ? global : typeof self === "object" ? self : typeof this === "object" ? this : {}; - if (typeof define === "function" && define.amd) { - define("tslib", ["exports"], function (exports) { factory(createExporter(root, createExporter(exports))); }); - } - else if ( true && typeof module.exports === "object") { - factory(createExporter(root, createExporter(module.exports))); - } - else { - factory(createExporter(root)); - } - function createExporter(exports, previous) { - if (exports !== root) { - if (typeof Object.create === "function") { - Object.defineProperty(exports, "__esModule", { value: true }); - } - else { - exports.__esModule = true; - } - } - return function (id, v) { return exports[id] = previous ? previous(id, v) : v; }; - } -}) -(function (exporter) { - var extendStatics = Object.setPrototypeOf || - ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || - function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; }; +var createReadableStreamAsyncIterator = function createReadableStreamAsyncIterator(stream) { + var _Object$create; - __extends = function (d, b) { - if (typeof b !== "function" && b !== null) - throw new TypeError("Class extends value " + String(b) + " is not a constructor or null"); - extendStatics(d, b); - function __() { this.constructor = d; } - d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); - }; + var iterator = Object.create(ReadableStreamAsyncIteratorPrototype, (_Object$create = {}, _defineProperty(_Object$create, kStream, { + value: stream, + writable: true + }), _defineProperty(_Object$create, kLastResolve, { + value: null, + writable: true + }), _defineProperty(_Object$create, kLastReject, { + value: null, + writable: true + }), _defineProperty(_Object$create, kError, { + value: null, + writable: true + }), _defineProperty(_Object$create, kEnded, { + value: stream._readableState.endEmitted, + writable: true + }), _defineProperty(_Object$create, kHandlePromise, { + value: function value(resolve, reject) { + var data = iterator[kStream].read(); - __assign = Object.assign || function (t) { - for (var s, i = 1, n = arguments.length; i < n; i++) { - s = arguments[i]; - for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p]; - } - return t; - }; + if (data) { + iterator[kLastPromise] = null; + iterator[kLastResolve] = null; + iterator[kLastReject] = null; + resolve(createIterResult(data, false)); + } else { + iterator[kLastResolve] = resolve; + iterator[kLastReject] = reject; + } + }, + writable: true + }), _Object$create)); + iterator[kLastPromise] = null; + finished(stream, function (err) { + if (err && err.code !== 'ERR_STREAM_PREMATURE_CLOSE') { + var reject = iterator[kLastReject]; // reject if we are waiting for data in the Promise + // returned by next() and store the error - __rest = function (s, e) { - var t = {}; - for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0) - t[p] = s[p]; - if (s != null && typeof Object.getOwnPropertySymbols === "function") - for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) { - if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i])) - t[p[i]] = s[p[i]]; - } - return t; - }; + if (reject !== null) { + iterator[kLastPromise] = null; + iterator[kLastResolve] = null; + iterator[kLastReject] = null; + reject(err); + } - __decorate = function (decorators, target, key, desc) { - var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; - if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); - else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; - return c > 3 && r && Object.defineProperty(target, key, r), r; - }; + iterator[kError] = err; + return; + } - __param = function (paramIndex, decorator) { - return function (target, key) { decorator(target, key, paramIndex); } - }; + var resolve = iterator[kLastResolve]; - __esDecorate = function (ctor, descriptorIn, decorators, contextIn, initializers, extraInitializers) { - function accept(f) { if (f !== void 0 && typeof f !== "function") throw new TypeError("Function expected"); return f; } - var kind = contextIn.kind, key = kind === "getter" ? "get" : kind === "setter" ? "set" : "value"; - var target = !descriptorIn && ctor ? contextIn["static"] ? ctor : ctor.prototype : null; - var descriptor = descriptorIn || (target ? Object.getOwnPropertyDescriptor(target, contextIn.name) : {}); - var _, done = false; - for (var i = decorators.length - 1; i >= 0; i--) { - var context = {}; - for (var p in contextIn) context[p] = p === "access" ? {} : contextIn[p]; - for (var p in contextIn.access) context.access[p] = contextIn.access[p]; - context.addInitializer = function (f) { if (done) throw new TypeError("Cannot add initializers after decoration has completed"); extraInitializers.push(accept(f || null)); }; - var result = (0, decorators[i])(kind === "accessor" ? { get: descriptor.get, set: descriptor.set } : descriptor[key], context); - if (kind === "accessor") { - if (result === void 0) continue; - if (result === null || typeof result !== "object") throw new TypeError("Object expected"); - if (_ = accept(result.get)) descriptor.get = _; - if (_ = accept(result.set)) descriptor.set = _; - if (_ = accept(result.init)) initializers.unshift(_); - } - else if (_ = accept(result)) { - if (kind === "field") initializers.unshift(_); - else descriptor[key] = _; - } - } - if (target) Object.defineProperty(target, contextIn.name, descriptor); - done = true; - }; + if (resolve !== null) { + iterator[kLastPromise] = null; + iterator[kLastResolve] = null; + iterator[kLastReject] = null; + resolve(createIterResult(undefined, true)); + } - __runInitializers = function (thisArg, initializers, value) { - var useValue = arguments.length > 2; - for (var i = 0; i < initializers.length; i++) { - value = useValue ? initializers[i].call(thisArg, value) : initializers[i].call(thisArg); - } - return useValue ? value : void 0; - }; + iterator[kEnded] = true; + }); + stream.on('readable', onReadable.bind(null, iterator)); + return iterator; +}; - __propKey = function (x) { - return typeof x === "symbol" ? x : "".concat(x); - }; +module.exports = createReadableStreamAsyncIterator; - __setFunctionName = function (f, name, prefix) { - if (typeof name === "symbol") name = name.description ? "[".concat(name.description, "]") : ""; - return Object.defineProperty(f, "name", { configurable: true, value: prefix ? "".concat(prefix, " ", name) : name }); - }; +/***/ }), - __metadata = function (metadataKey, metadataValue) { - if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(metadataKey, metadataValue); - }; +/***/ 75920: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { - __awaiter = function (thisArg, _arguments, P, generator) { - function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); } - return new (P || (P = Promise))(function (resolve, reject) { - function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } - function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } - function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); } - step((generator = generator.apply(thisArg, _arguments || [])).next()); - }); - }; +"use strict"; - __generator = function (thisArg, body) { - var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g; - return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g; - function verb(n) { return function (v) { return step([n, v]); }; } - function step(op) { - if (f) throw new TypeError("Generator is already executing."); - while (g && (g = 0, op[0] && (_ = 0)), _) try { - if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t; - if (y = 0, t) op = [op[0] & 2, t.value]; - switch (op[0]) { - case 0: case 1: t = op; break; - case 4: _.label++; return { value: op[1], done: false }; - case 5: _.label++; y = op[1]; op = [0]; continue; - case 7: op = _.ops.pop(); _.trys.pop(); continue; - default: - if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; } - if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; } - if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; } - if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; } - if (t[2]) _.ops.pop(); - _.trys.pop(); continue; - } - op = body.call(thisArg, _); - } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; } - if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true }; - } - }; - __exportStar = function(m, o) { - for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(o, p)) __createBinding(o, m, p); - }; +function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; } - __createBinding = Object.create ? (function(o, m, k, k2) { - if (k2 === undefined) k2 = k; - var desc = Object.getOwnPropertyDescriptor(m, k); - if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) { - desc = { enumerable: true, get: function() { return m[k]; } }; - } - Object.defineProperty(o, k2, desc); - }) : (function(o, m, k, k2) { - if (k2 === undefined) k2 = k; - o[k2] = m[k]; - }); +function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; } - __values = function (o) { - var s = typeof Symbol === "function" && Symbol.iterator, m = s && o[s], i = 0; - if (m) return m.call(o); - if (o && typeof o.length === "number") return { - next: function () { - if (o && i >= o.length) o = void 0; - return { value: o && o[i++], done: !o }; - } - }; - throw new TypeError(s ? "Object is not iterable." : "Symbol.iterator is not defined."); - }; +function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; } - __read = function (o, n) { - var m = typeof Symbol === "function" && o[Symbol.iterator]; - if (!m) return o; - var i = m.call(o), r, ar = [], e; - try { - while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value); - } - catch (error) { e = { error: error }; } - finally { - try { - if (r && !r.done && (m = i["return"])) m.call(i); - } - finally { if (e) throw e.error; } - } - return ar; - }; +function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } - /** @deprecated */ - __spread = function () { - for (var ar = [], i = 0; i < arguments.length; i++) - ar = ar.concat(__read(arguments[i])); - return ar; - }; +function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } - /** @deprecated */ - __spreadArrays = function () { - for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length; - for (var r = Array(s), k = 0, i = 0; i < il; i++) - for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++) - r[k] = a[j]; - return r; - }; +function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; } - __spreadArray = function (to, from, pack) { - if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) { - if (ar || !(i in from)) { - if (!ar) ar = Array.prototype.slice.call(from, 0, i); - ar[i] = from[i]; - } - } - return to.concat(ar || Array.prototype.slice.call(from)); - }; +var _require = __nccwpck_require__(14300), + Buffer = _require.Buffer; - __await = function (v) { - return this instanceof __await ? (this.v = v, this) : new __await(v); - }; +var _require2 = __nccwpck_require__(73837), + inspect = _require2.inspect; - __asyncGenerator = function (thisArg, _arguments, generator) { - if (!Symbol.asyncIterator) throw new TypeError("Symbol.asyncIterator is not defined."); - var g = generator.apply(thisArg, _arguments || []), i, q = []; - return i = {}, verb("next"), verb("throw"), verb("return"), i[Symbol.asyncIterator] = function () { return this; }, i; - function verb(n) { if (g[n]) i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; } - function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } } - function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); } - function fulfill(value) { resume("next", value); } - function reject(value) { resume("throw", value); } - function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); } - }; +var custom = inspect && inspect.custom || 'inspect'; - __asyncDelegator = function (o) { - var i, p; - return i = {}, verb("next"), verb("throw", function (e) { throw e; }), verb("return"), i[Symbol.iterator] = function () { return this; }, i; - function verb(n, f) { i[n] = o[n] ? function (v) { return (p = !p) ? { value: __await(o[n](v)), done: false } : f ? f(v) : v; } : f; } - }; +function copyBuffer(src, target, offset) { + Buffer.prototype.copy.call(src, target, offset); +} - __asyncValues = function (o) { - if (!Symbol.asyncIterator) throw new TypeError("Symbol.asyncIterator is not defined."); - var m = o[Symbol.asyncIterator], i; - return m ? m.call(o) : (o = typeof __values === "function" ? __values(o) : o[Symbol.iterator](), i = {}, verb("next"), verb("throw"), verb("return"), i[Symbol.asyncIterator] = function () { return this; }, i); - function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; } - function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); } - }; +module.exports = +/*#__PURE__*/ +function () { + function BufferList() { + _classCallCheck(this, BufferList); - __makeTemplateObject = function (cooked, raw) { - if (Object.defineProperty) { Object.defineProperty(cooked, "raw", { value: raw }); } else { cooked.raw = raw; } - return cooked; - }; + this.head = null; + this.tail = null; + this.length = 0; + } - var __setModuleDefault = Object.create ? (function(o, v) { - Object.defineProperty(o, "default", { enumerable: true, value: v }); - }) : function(o, v) { - o["default"] = v; - }; + _createClass(BufferList, [{ + key: "push", + value: function push(v) { + var entry = { + data: v, + next: null + }; + if (this.length > 0) this.tail.next = entry;else this.head = entry; + this.tail = entry; + ++this.length; + } + }, { + key: "unshift", + value: function unshift(v) { + var entry = { + data: v, + next: this.head + }; + if (this.length === 0) this.tail = entry; + this.head = entry; + ++this.length; + } + }, { + key: "shift", + value: function shift() { + if (this.length === 0) return; + var ret = this.head.data; + if (this.length === 1) this.head = this.tail = null;else this.head = this.head.next; + --this.length; + return ret; + } + }, { + key: "clear", + value: function clear() { + this.head = this.tail = null; + this.length = 0; + } + }, { + key: "join", + value: function join(s) { + if (this.length === 0) return ''; + var p = this.head; + var ret = '' + p.data; - __importStar = function (mod) { - if (mod && mod.__esModule) return mod; - var result = {}; - if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k); - __setModuleDefault(result, mod); - return result; - }; + while (p = p.next) { + ret += s + p.data; + } - __importDefault = function (mod) { - return (mod && mod.__esModule) ? mod : { "default": mod }; - }; + return ret; + } + }, { + key: "concat", + value: function concat(n) { + if (this.length === 0) return Buffer.alloc(0); + var ret = Buffer.allocUnsafe(n >>> 0); + var p = this.head; + var i = 0; - __classPrivateFieldGet = function (receiver, state, kind, f) { - if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a getter"); - if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot read private member from an object whose class did not declare it"); - return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver); - }; + while (p) { + copyBuffer(p.data, ret, i); + i += p.data.length; + p = p.next; + } - __classPrivateFieldSet = function (receiver, state, value, kind, f) { - if (kind === "m") throw new TypeError("Private method is not writable"); - if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a setter"); - if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot write private member to an object whose class did not declare it"); - return (kind === "a" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value; - }; + return ret; + } // Consumes a specified amount of bytes or characters from the buffered data. - __classPrivateFieldIn = function (state, receiver) { - if (receiver === null || (typeof receiver !== "object" && typeof receiver !== "function")) throw new TypeError("Cannot use 'in' operator on non-object"); - return typeof state === "function" ? receiver === state : state.has(receiver); - }; + }, { + key: "consume", + value: function consume(n, hasStrings) { + var ret; - exporter("__extends", __extends); - exporter("__assign", __assign); - exporter("__rest", __rest); - exporter("__decorate", __decorate); - exporter("__param", __param); - exporter("__esDecorate", __esDecorate); - exporter("__runInitializers", __runInitializers); - exporter("__propKey", __propKey); - exporter("__setFunctionName", __setFunctionName); - exporter("__metadata", __metadata); - exporter("__awaiter", __awaiter); - exporter("__generator", __generator); - exporter("__exportStar", __exportStar); - exporter("__createBinding", __createBinding); - exporter("__values", __values); - exporter("__read", __read); - exporter("__spread", __spread); - exporter("__spreadArrays", __spreadArrays); - exporter("__spreadArray", __spreadArray); - exporter("__await", __await); - exporter("__asyncGenerator", __asyncGenerator); - exporter("__asyncDelegator", __asyncDelegator); - exporter("__asyncValues", __asyncValues); - exporter("__makeTemplateObject", __makeTemplateObject); - exporter("__importStar", __importStar); - exporter("__importDefault", __importDefault); - exporter("__classPrivateFieldGet", __classPrivateFieldGet); - exporter("__classPrivateFieldSet", __classPrivateFieldSet); - exporter("__classPrivateFieldIn", __classPrivateFieldIn); -}); + if (n < this.head.data.length) { + // `slice` is the same for buffers and strings. + ret = this.head.data.slice(0, n); + this.head.data = this.head.data.slice(n); + } else if (n === this.head.data.length) { + // First chunk is a perfect match. + ret = this.shift(); + } else { + // Result spans more than one buffer. + ret = hasStrings ? this._getString(n) : this._getBuffer(n); + } + + return ret; + } + }, { + key: "first", + value: function first() { + return this.head.data; + } // Consumes a specified amount of characters from the buffered data. + + }, { + key: "_getString", + value: function _getString(n) { + var p = this.head; + var c = 1; + var ret = p.data; + n -= ret.length; + + while (p = p.next) { + var str = p.data; + var nb = n > str.length ? str.length : n; + if (nb === str.length) ret += str;else ret += str.slice(0, n); + n -= nb; + + if (n === 0) { + if (nb === str.length) { + ++c; + if (p.next) this.head = p.next;else this.head = this.tail = null; + } else { + this.head = p; + p.data = str.slice(nb); + } + + break; + } + + ++c; + } + + this.length -= c; + return ret; + } // Consumes a specified amount of bytes from the buffered data. + + }, { + key: "_getBuffer", + value: function _getBuffer(n) { + var ret = Buffer.allocUnsafe(n); + var p = this.head; + var c = 1; + p.data.copy(ret); + n -= p.data.length; + + while (p = p.next) { + var buf = p.data; + var nb = n > buf.length ? buf.length : n; + buf.copy(ret, ret.length - n, 0, nb); + n -= nb; + + if (n === 0) { + if (nb === buf.length) { + ++c; + if (p.next) this.head = p.next;else this.head = this.tail = null; + } else { + this.head = p; + p.data = buf.slice(nb); + } + + break; + } + + ++c; + } + + this.length -= c; + return ret; + } // Make sure the linked list only shows the minimal necessary information. + + }, { + key: custom, + value: function value(_, options) { + return inspect(this, _objectSpread({}, options, { + // Only inspect one level. + depth: 0, + // It should not recurse. + customInspect: false + })); + } + }]); + return BufferList; +}(); /***/ }), -/***/ 36803: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { +/***/ 33148: +/***/ ((module) => { "use strict"; + // undocumented cb() API, needed for core, not for public API -Object.defineProperty(exports, "__esModule", ({ value: true })); -exports.toOldFormat = exports.toNewFormat = exports.mergeAngularJsonAndGlobProjects = exports.isAngularPluginInstalled = exports.shouldMergeAngularProjects = void 0; -const fs_1 = __nccwpck_require__(57147); -const path = __nccwpck_require__(71017); -const fileutils_1 = __nccwpck_require__(47930); -const workspaces_1 = __nccwpck_require__(98715); -function shouldMergeAngularProjects(root, includeProjectsFromAngularJson) { - if ((0, fs_1.existsSync)(path.join(root, 'angular.json')) && - // Include projects from angular.json if explicitly required. - // e.g. when invoked from `packages/devkit/src/utils/convert-nx-executor.ts` - (includeProjectsFromAngularJson || - // Or if a workspace has `@nrwl/angular`/`@nx/angular` installed then projects from `angular.json` to be considered by Nx. - isAngularPluginInstalled())) { - return true; +function destroy(err, cb) { + var _this = this; + + var readableDestroyed = this._readableState && this._readableState.destroyed; + var writableDestroyed = this._writableState && this._writableState.destroyed; + + if (readableDestroyed || writableDestroyed) { + if (cb) { + cb(err); + } else if (err) { + if (!this._writableState) { + process.nextTick(emitErrorNT, this, err); + } else if (!this._writableState.errorEmitted) { + this._writableState.errorEmitted = true; + process.nextTick(emitErrorNT, this, err); + } } - else { - return false; + + return this; + } // we set destroyed to true before firing error callbacks in order + // to make it re-entrance safe in case destroy() is called within callbacks + + + if (this._readableState) { + this._readableState.destroyed = true; + } // if this is a duplex stream mark the writable part as destroyed as well + + + if (this._writableState) { + this._writableState.destroyed = true; + } + + this._destroy(err || null, function (err) { + if (!cb && err) { + if (!_this._writableState) { + process.nextTick(emitErrorAndCloseNT, _this, err); + } else if (!_this._writableState.errorEmitted) { + _this._writableState.errorEmitted = true; + process.nextTick(emitErrorAndCloseNT, _this, err); + } else { + process.nextTick(emitCloseNT, _this); + } + } else if (cb) { + process.nextTick(emitCloseNT, _this); + cb(err); + } else { + process.nextTick(emitCloseNT, _this); } + }); + + return this; } -exports.shouldMergeAngularProjects = shouldMergeAngularProjects; -function isAngularPluginInstalled() { - try { - require.resolve('@nx/angular'); - return true; - } - catch (_a) { - try { - require.resolve('@nrwl/angular'); - return true; - } - catch (_b) { - return false; - } - } + +function emitErrorAndCloseNT(self, err) { + emitErrorNT(self, err); + emitCloseNT(self); } -exports.isAngularPluginInstalled = isAngularPluginInstalled; -function readAngularJson(angularCliWorkspaceRoot) { - return toNewFormat((0, fileutils_1.readJsonFile)(path.join(angularCliWorkspaceRoot, 'angular.json'))).projects; + +function emitCloseNT(self) { + if (self._writableState && !self._writableState.emitClose) return; + if (self._readableState && !self._readableState.emitClose) return; + self.emit('close'); } -function mergeAngularJsonAndGlobProjects(globProjects, angularCliWorkspaceRoot) { - const res = readAngularJson(angularCliWorkspaceRoot); - const folders = new Set(); - for (let k of Object.keys(res)) { - folders.add(res[k].root); - } - for (let k of Object.keys(globProjects)) { - if (!folders.has(globProjects[k].root)) { - res[k] = globProjects[k]; - } - } - return res; + +function undestroy() { + if (this._readableState) { + this._readableState.destroyed = false; + this._readableState.reading = false; + this._readableState.ended = false; + this._readableState.endEmitted = false; + } + + if (this._writableState) { + this._writableState.destroyed = false; + this._writableState.ended = false; + this._writableState.ending = false; + this._writableState.finalCalled = false; + this._writableState.prefinished = false; + this._writableState.finished = false; + this._writableState.errorEmitted = false; + } } -exports.mergeAngularJsonAndGlobProjects = mergeAngularJsonAndGlobProjects; -function toNewFormat(w) { - Object.values(w.projects || {}).forEach((projectConfig) => { - if (projectConfig.architect) { - (0, workspaces_1.renamePropertyWithStableKeys)(projectConfig, 'architect', 'targets'); - } - if (projectConfig.schematics) { - (0, workspaces_1.renamePropertyWithStableKeys)(projectConfig, 'schematics', 'generators'); - } - Object.values(projectConfig.targets || {}).forEach((target) => { - if (target.builder !== undefined) { - (0, workspaces_1.renamePropertyWithStableKeys)(target, 'builder', 'executor'); - } - }); - }); - if (w.schematics) { - (0, workspaces_1.renamePropertyWithStableKeys)(w, 'schematics', 'generators'); - } - if (w.version !== 2) { - w.version = 2; - } - return w; + +function emitErrorNT(self, err) { + self.emit('error', err); } -exports.toNewFormat = toNewFormat; -function toOldFormat(w) { - Object.values(w.projects || {}).forEach((projectConfig) => { - if (typeof projectConfig === 'string') { - throw new Error("'project.json' files are incompatible with version 1 workspace schemas."); - } - if (projectConfig.targets) { - (0, workspaces_1.renamePropertyWithStableKeys)(projectConfig, 'targets', 'architect'); - } - if (projectConfig.generators) { - (0, workspaces_1.renamePropertyWithStableKeys)(projectConfig, 'generators', 'schematics'); - } - delete projectConfig.name; - Object.values(projectConfig.architect || {}).forEach((target) => { - if (target.executor !== undefined) { - (0, workspaces_1.renamePropertyWithStableKeys)(target, 'executor', 'builder'); - } - }); - }); - if (w.generators) { - (0, workspaces_1.renamePropertyWithStableKeys)(w, 'generators', 'schematics'); - } - if (w.version !== 1) { - w.version = 1; - } - return w; + +function errorOrDestroy(stream, err) { + // We have tests that rely on errors being emitted + // in the same tick, so changing this is semver major. + // For now when you opt-in to autoDestroy we allow + // the error to be emitted nextTick. In a future + // semver major update we should change the default to this. + var rState = stream._readableState; + var wState = stream._writableState; + if (rState && rState.autoDestroy || wState && wState.autoDestroy) stream.destroy(err);else stream.emit('error', err); } -exports.toOldFormat = toOldFormat; +module.exports = { + destroy: destroy, + undestroy: undestroy, + errorOrDestroy: errorOrDestroy +}; /***/ }), -/***/ 65459: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { +/***/ 75628: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { "use strict"; +// Ported from https://github.com/mafintosh/end-of-stream with +// permission from the author, Mathias Buus (@mafintosh). -Object.defineProperty(exports, "__esModule", ({ value: true })); -exports.workspaceLayout = exports.readAllWorkspaceConfiguration = exports.readNxJson = void 0; -const workspaces_1 = __nccwpck_require__(98715); -const workspace_root_1 = __nccwpck_require__(65766); -function readNxJson() { - return new workspaces_1.Workspaces(workspace_root_1.workspaceRoot).readNxJson(); -} -exports.readNxJson = readNxJson; -// TODO(vsavkin): Remove after Nx 16 is out -/** - * @deprecated Use readProjectsConfigurationFromProjectGraph(await createProjectGraphAsync()) - */ -function readAllWorkspaceConfiguration() { - return new workspaces_1.Workspaces(workspace_root_1.workspaceRoot).readProjectsConfigurations(); + +var ERR_STREAM_PREMATURE_CLOSE = (__nccwpck_require__(90646)/* .codes.ERR_STREAM_PREMATURE_CLOSE */ .q.ERR_STREAM_PREMATURE_CLOSE); + +function once(callback) { + var called = false; + return function () { + if (called) return; + called = true; + + for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) { + args[_key] = arguments[_key]; + } + + callback.apply(this, args); + }; } -exports.readAllWorkspaceConfiguration = readAllWorkspaceConfiguration; -/** - * Returns information about where apps and libs will be created. - */ -function workspaceLayout() { - var _a, _b, _c, _d; - const nxJson = readNxJson(); - return { - appsDir: (_b = (_a = nxJson.workspaceLayout) === null || _a === void 0 ? void 0 : _a.appsDir) !== null && _b !== void 0 ? _b : 'apps', - libsDir: (_d = (_c = nxJson.workspaceLayout) === null || _c === void 0 ? void 0 : _c.libsDir) !== null && _d !== void 0 ? _d : 'libs', - }; + +function noop() {} + +function isRequest(stream) { + return stream.setHeader && typeof stream.abort === 'function'; } -exports.workspaceLayout = workspaceLayout; +function eos(stream, opts, callback) { + if (typeof opts === 'function') return eos(stream, null, opts); + if (!opts) opts = {}; + callback = once(callback || noop); + var readable = opts.readable || opts.readable !== false && stream.readable; + var writable = opts.writable || opts.writable !== false && stream.writable; -/***/ }), + var onlegacyfinish = function onlegacyfinish() { + if (!stream.writable) onfinish(); + }; -/***/ 49899: -/***/ ((__unused_webpack_module, exports) => { + var writableEnded = stream._writableState && stream._writableState.finished; -"use strict"; + var onfinish = function onfinish() { + writable = false; + writableEnded = true; + if (!readable) callback.call(stream); + }; -Object.defineProperty(exports, "__esModule", ({ value: true })); -exports.DependencyType = exports.fileDataDepType = exports.fileDataDepTarget = void 0; -function fileDataDepTarget(dep) { - return typeof dep === 'string' ? dep : dep[0]; -} -exports.fileDataDepTarget = fileDataDepTarget; -function fileDataDepType(dep) { - return typeof dep === 'string' ? 'static' : dep[1]; + var readableEnded = stream._readableState && stream._readableState.endEmitted; + + var onend = function onend() { + readable = false; + readableEnded = true; + if (!writable) callback.call(stream); + }; + + var onerror = function onerror(err) { + callback.call(stream, err); + }; + + var onclose = function onclose() { + var err; + + if (readable && !readableEnded) { + if (!stream._readableState || !stream._readableState.ended) err = new ERR_STREAM_PREMATURE_CLOSE(); + return callback.call(stream, err); + } + + if (writable && !writableEnded) { + if (!stream._writableState || !stream._writableState.ended) err = new ERR_STREAM_PREMATURE_CLOSE(); + return callback.call(stream, err); + } + }; + + var onrequest = function onrequest() { + stream.req.on('finish', onfinish); + }; + + if (isRequest(stream)) { + stream.on('complete', onfinish); + stream.on('abort', onclose); + if (stream.req) onrequest();else stream.on('request', onrequest); + } else if (writable && !stream._writableState) { + // legacy streams + stream.on('end', onlegacyfinish); + stream.on('close', onlegacyfinish); + } + + stream.on('end', onend); + stream.on('finish', onfinish); + if (opts.error !== false) stream.on('error', onerror); + stream.on('close', onclose); + return function () { + stream.removeListener('complete', onfinish); + stream.removeListener('abort', onclose); + stream.removeListener('request', onrequest); + if (stream.req) stream.req.removeListener('finish', onfinish); + stream.removeListener('end', onlegacyfinish); + stream.removeListener('close', onlegacyfinish); + stream.removeListener('finish', onfinish); + stream.removeListener('end', onend); + stream.removeListener('error', onerror); + stream.removeListener('close', onclose); + }; } -exports.fileDataDepType = fileDataDepType; -/** - * Type of dependency between projects - */ -var DependencyType; -(function (DependencyType) { - /** - * Static dependencies are tied to the loading of the module - */ - DependencyType["static"] = "static"; - /** - * Dynamic dependencies are brought in by the module at run time - */ - DependencyType["dynamic"] = "dynamic"; - /** - * Implicit dependencies are inferred - */ - DependencyType["implicit"] = "implicit"; -})(DependencyType = exports.DependencyType || (exports.DependencyType = {})); +module.exports = eos; /***/ }), -/***/ 98715: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { +/***/ 42881: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { "use strict"; -Object.defineProperty(exports, "__esModule", ({ value: true })); -exports.renamePropertyWithStableKeys = exports.readTargetDefaultsForTarget = exports.mergeTargetConfigurations = exports.buildProjectsConfigurationsFromGlobs = exports.inferProjectFromNonStandardFile = exports.deduplicateProjectFiles = exports.globForProjectFiles = exports.getGlobPatternsFromPackageManagerWorkspaces = exports.getGlobPatternsFromPluginsAsync = exports.getGlobPatternsFromPlugins = exports.toProjectName = exports.normalizeExecutorSchema = exports.Workspaces = void 0; -const tslib_1 = __nccwpck_require__(51796); -const fast_glob_1 = __nccwpck_require__(19131); -const fs_1 = __nccwpck_require__(57147); -const path = __nccwpck_require__(71017); -const path_1 = __nccwpck_require__(71017); -const perf_hooks_1 = __nccwpck_require__(4074); -const workspace_root_1 = __nccwpck_require__(65766); -const fileutils_1 = __nccwpck_require__(47930); -const logger_1 = __nccwpck_require__(95324); -const nx_plugin_1 = __nccwpck_require__(86740); -const output_1 = __nccwpck_require__(34548); -const path_2 = __nccwpck_require__(75878); -const angular_json_1 = __nccwpck_require__(36803); -const installation_directory_1 = __nccwpck_require__(35075); -const ignore_1 = __nccwpck_require__(98845); -const find_project_for_path_1 = __nccwpck_require__(36265); -class Workspaces { - constructor(root) { - this.root = root; - } - relativeCwd(cwd) { - return path.relative(this.root, cwd).replace(/\\/g, '/') || null; - } - calculateDefaultProjectName(cwd, { projects }, nxJson) { - var _a; - const relativeCwd = this.relativeCwd(cwd); - if (relativeCwd) { - const matchingProject = findMatchingProjectInCwd(projects, relativeCwd); - // We have found a project - if (matchingProject) { - // That is not at the root - if (projects[matchingProject].root !== '.' && - projects[matchingProject].root !== '') { - return matchingProject; - // But its at the root, and NX_DEFAULT_PROJECT is set - } - else if (process.env.NX_DEFAULT_PROJECT) { - return process.env.NX_DEFAULT_PROJECT; - // Its root, and NX_DEFAULT_PROJECT is not set - } - else { - return matchingProject; - } - } - } - // There was no matching project in cwd. - return (_a = process.env.NX_DEFAULT_PROJECT) !== null && _a !== void 0 ? _a : nxJson === null || nxJson === void 0 ? void 0 : nxJson.defaultProject; - } - /** - * @deprecated - */ - readProjectsConfigurations(opts) { - if (this.cachedProjectsConfig && - process.env.NX_CACHE_PROJECTS_CONFIG !== 'false') { - return this.cachedProjectsConfig; - } - const nxJson = this.readNxJson(); - const projectsConfigurations = buildProjectsConfigurationsFromGlobs(nxJson, globForProjectFiles(this.root, (opts === null || opts === void 0 ? void 0 : opts._ignorePluginInference) - ? [] - : getGlobPatternsFromPlugins(nxJson, (0, installation_directory_1.getNxRequirePaths)(this.root), this.root), nxJson), (path) => (0, fileutils_1.readJsonFile)((0, path_1.join)(this.root, path))); - if ((0, angular_json_1.shouldMergeAngularProjects)(this.root, opts === null || opts === void 0 ? void 0 : opts._includeProjectsFromAngularJson)) { - projectsConfigurations.projects = (0, angular_json_1.mergeAngularJsonAndGlobProjects)(projectsConfigurations.projects, this.root); - } - this.cachedProjectsConfig = this.mergeTargetDefaultsIntoProjectDescriptions(projectsConfigurations, nxJson); - return this.cachedProjectsConfig; - } - /** - * Deprecated. Use readProjectsConfigurations - */ - readWorkspaceConfiguration(opts) { - const nxJson = this.readNxJson(); - return Object.assign(Object.assign({}, this.readProjectsConfigurations(opts)), nxJson); - } - mergeTargetDefaultsIntoProjectDescriptions(config, nxJson) { - for (const proj of Object.values(config.projects)) { - if (proj.targets) { - for (const targetName of Object.keys(proj.targets)) { - const projectTargetDefinition = proj.targets[targetName]; - const defaults = readTargetDefaultsForTarget(targetName, nxJson.targetDefaults, projectTargetDefinition.executor); - if (defaults) { - proj.targets[targetName] = mergeTargetConfigurations(proj, targetName, defaults); - } - } - } - } - return config; - } - isNxExecutor(nodeModule, executor) { - return !this.readExecutor(nodeModule, executor).isNgCompat; - } - isNxGenerator(collectionName, generatorName) { - return !this.readGenerator(collectionName, generatorName).isNgCompat; - } - readExecutor(nodeModule, executor) { - try { - const { executorsFilePath, executorConfig, isNgCompat } = this.readExecutorsJson(nodeModule, executor); - const executorsDir = path.dirname(executorsFilePath); - const schemaPath = this.resolveSchema(executorConfig.schema, executorsDir); - const schema = normalizeExecutorSchema((0, fileutils_1.readJsonFile)(schemaPath)); - const implementationFactory = this.getImplementationFactory(executorConfig.implementation, executorsDir); - const batchImplementationFactory = executorConfig.batchImplementation - ? this.getImplementationFactory(executorConfig.batchImplementation, executorsDir) - : null; - const hasherFactory = executorConfig.hasher - ? this.getImplementationFactory(executorConfig.hasher, executorsDir) - : null; - return { - schema, - implementationFactory, - batchImplementationFactory, - hasherFactory, - isNgCompat, - }; - } - catch (e) { - throw new Error(`Unable to resolve ${nodeModule}:${executor}.\n${e.message}`); - } - } - readGenerator(collectionName, generatorName) { - var _a, _b, _c, _d; - try { - const { generatorsFilePath, generatorsJson, resolvedCollectionName, normalizedGeneratorName, } = this.readGeneratorsJson(collectionName, generatorName); - const generatorsDir = path.dirname(generatorsFilePath); - const generatorConfig = ((_a = generatorsJson.generators) === null || _a === void 0 ? void 0 : _a[normalizedGeneratorName]) || - ((_b = generatorsJson.schematics) === null || _b === void 0 ? void 0 : _b[normalizedGeneratorName]); - const isNgCompat = !((_c = generatorsJson.generators) === null || _c === void 0 ? void 0 : _c[normalizedGeneratorName]); - const schemaPath = this.resolveSchema(generatorConfig.schema, generatorsDir); - const schema = (0, fileutils_1.readJsonFile)(schemaPath); - if (!schema.properties || typeof schema.properties !== 'object') { - schema.properties = {}; - } - generatorConfig.implementation = - generatorConfig.implementation || generatorConfig.factory; - const implementationFactory = this.getImplementationFactory(generatorConfig.implementation, generatorsDir); - const normalizedGeneratorConfiguration = Object.assign(Object.assign({}, generatorConfig), { aliases: (_d = generatorConfig.aliases) !== null && _d !== void 0 ? _d : [], hidden: !!generatorConfig.hidden }); - return { - resolvedCollectionName, - normalizedGeneratorName, - schema, - implementationFactory, - isNgCompat, - aliases: generatorConfig.aliases || [], - generatorConfiguration: normalizedGeneratorConfiguration, - }; - } - catch (e) { - throw new Error(`Unable to resolve ${collectionName}:${generatorName}.\n${e.message}`); - } - } - hasNxJson() { - const nxJson = path.join(this.root, 'nx.json'); - return (0, fs_1.existsSync)(nxJson); - } - readNxJson() { - const nxJson = path.join(this.root, 'nx.json'); - if ((0, fs_1.existsSync)(nxJson)) { - const nxJsonConfiguration = (0, fileutils_1.readJsonFile)(nxJson); - if (nxJsonConfiguration.extends) { - const extendedNxJsonPath = require.resolve(nxJsonConfiguration.extends, { - paths: [(0, path_1.dirname)(nxJson)], - }); - const baseNxJson = (0, fileutils_1.readJsonFile)(extendedNxJsonPath); - return Object.assign(Object.assign({}, baseNxJson), nxJsonConfiguration); - } - else { - return nxJsonConfiguration; - } - } - else { - try { - return (0, fileutils_1.readJsonFile)((0, path_1.join)(__dirname, '..', '..', 'presets', 'core.json')); - } - catch (e) { - return {}; - } - } - } - getImplementationFactory(implementation, directory) { - const [implementationModulePath, implementationExportName] = implementation.split('#'); - return () => { - var _a; - const modulePath = this.resolveImplementation(implementationModulePath, directory); - if ((0, path_1.extname)(modulePath) === '.ts') { - (0, nx_plugin_1.registerPluginTSTranspiler)(); - } - const module = require(modulePath); - return implementationExportName - ? module[implementationExportName] - : (_a = module.default) !== null && _a !== void 0 ? _a : module; - }; - } - resolveSchema(schemaPath, directory) { - const maybeSchemaPath = (0, path_1.join)(directory, schemaPath); - if ((0, fs_1.existsSync)(maybeSchemaPath)) { - return maybeSchemaPath; - } - return require.resolve(schemaPath, { - paths: [directory], - }); - } - resolveImplementation(implementationModulePath, directory) { - const validImplementations = ['', '.js', '.ts'].map((x) => implementationModulePath + x); - for (const maybeImplementation of validImplementations) { - const maybeImplementationPath = (0, path_1.join)(directory, maybeImplementation); - if ((0, fs_1.existsSync)(maybeImplementationPath)) { - return maybeImplementationPath; - } - try { - return require.resolve(maybeImplementation, { - paths: [directory], - }); - } - catch (_a) { } - } - throw new Error(`Could not resolve "${implementationModulePath}" from "${directory}".`); - } - readExecutorsJson(nodeModule, executor) { - var _a, _b, _c, _d; - const { json: packageJson, path: packageJsonPath } = (0, nx_plugin_1.readPluginPackageJson)(nodeModule, this.resolvePaths()); - const executorsFile = (_a = packageJson.executors) !== null && _a !== void 0 ? _a : packageJson.builders; - if (!executorsFile) { - throw new Error(`The "${nodeModule}" package does not support Nx executors.`); - } - const executorsFilePath = require.resolve(path.join(path.dirname(packageJsonPath), executorsFile)); - const executorsJson = (0, fileutils_1.readJsonFile)(executorsFilePath); - const executorConfig = ((_b = executorsJson.executors) === null || _b === void 0 ? void 0 : _b[executor]) || ((_c = executorsJson.builders) === null || _c === void 0 ? void 0 : _c[executor]); - if (!executorConfig) { - throw new Error(`Cannot find executor '${executor}' in ${executorsFilePath}.`); - } - const isNgCompat = !((_d = executorsJson.executors) === null || _d === void 0 ? void 0 : _d[executor]); - return { executorsFilePath, executorConfig, isNgCompat }; - } - readGeneratorsJson(collectionName, generator) { - var _a; - let generatorsFilePath; - if (collectionName.endsWith('.json')) { - generatorsFilePath = require.resolve(collectionName, { - paths: this.resolvePaths(), - }); - } - else { - const { json: packageJson, path: packageJsonPath } = (0, nx_plugin_1.readPluginPackageJson)(collectionName, this.resolvePaths()); - const generatorsFile = (_a = packageJson.generators) !== null && _a !== void 0 ? _a : packageJson.schematics; - if (!generatorsFile) { - throw new Error(`The "${collectionName}" package does not support Nx generators.`); - } - generatorsFilePath = require.resolve(path.join(path.dirname(packageJsonPath), generatorsFile)); - } - const generatorsJson = (0, fileutils_1.readJsonFile)(generatorsFilePath); - let normalizedGeneratorName = findFullGeneratorName(generator, generatorsJson.generators) || - findFullGeneratorName(generator, generatorsJson.schematics); - if (!normalizedGeneratorName) { - for (let parent of generatorsJson.extends || []) { - try { - return this.readGeneratorsJson(parent, generator); - } - catch (e) { } - } - throw new Error(`Cannot find generator '${generator}' in ${generatorsFilePath}.`); - } - return { - generatorsFilePath, - generatorsJson, - normalizedGeneratorName, - resolvedCollectionName: collectionName, - }; - } - resolvePaths() { - return this.root ? [this.root, __dirname] : [__dirname]; - } -} -exports.Workspaces = Workspaces; -function findMatchingProjectInCwd(projects, relativeCwd) { - const projectRootMappings = new Map(); - for (const projectName of Object.keys(projects)) { - const { root } = projects[projectName]; - projectRootMappings.set((0, find_project_for_path_1.normalizeProjectRoot)(root), projectName); - } - const matchingProject = (0, find_project_for_path_1.findProjectForPath)(relativeCwd, projectRootMappings); - return matchingProject; -} -function normalizeExecutorSchema(schema) { - var _a, _b; - const version = ((_a = schema.version) !== null && _a !== void 0 ? _a : (schema.version = 1)); - return Object.assign({ version, outputCapture: ((_b = schema.outputCapture) !== null && _b !== void 0 ? _b : version < 2) ? 'direct-nodejs' : 'pipe', properties: !schema.properties || typeof schema.properties !== 'object' - ? {} - : schema.properties }, schema); -} -exports.normalizeExecutorSchema = normalizeExecutorSchema; -function findFullGeneratorName(name, generators) { - if (generators) { - for (let [key, data] of Object.entries(generators)) { - if (key === name || - (data.aliases && data.aliases.includes(name))) { - return key; - } - } - } -} -/** - * Pulled from toFileName in names from @nx/devkit. - * Todo: Should refactor, not duplicate. - */ -function toProjectName(fileName) { - const parts = (0, path_1.dirname)(fileName).split(/[\/\\]/g); - return parts[parts.length - 1].toLowerCase(); -} -exports.toProjectName = toProjectName; -let projectGlobCache; -let projectGlobCacheKey; -/** - * @deprecated Use getGlobPatternsFromPluginsAsync instead. - */ -function getGlobPatternsFromPlugins(nxJson, paths, root = workspace_root_1.workspaceRoot) { - const plugins = (0, nx_plugin_1.loadNxPluginsSync)(nxJson === null || nxJson === void 0 ? void 0 : nxJson.plugins, paths, root); - const patterns = []; - for (const plugin of plugins) { - if (!plugin.projectFilePatterns) { - continue; - } - for (const filePattern of plugin.projectFilePatterns) { - patterns.push('**/' + filePattern); - } + +function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) { try { var info = gen[key](arg); var value = info.value; } catch (error) { reject(error); return; } if (info.done) { resolve(value); } else { Promise.resolve(value).then(_next, _throw); } } + +function _asyncToGenerator(fn) { return function () { var self = this, args = arguments; return new Promise(function (resolve, reject) { var gen = fn.apply(self, args); function _next(value) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, "next", value); } function _throw(err) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, "throw", err); } _next(undefined); }); }; } + +function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; } + +function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; } + +function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; } + +var ERR_INVALID_ARG_TYPE = (__nccwpck_require__(90646)/* .codes.ERR_INVALID_ARG_TYPE */ .q.ERR_INVALID_ARG_TYPE); + +function from(Readable, iterable, opts) { + var iterator; + + if (iterable && typeof iterable.next === 'function') { + iterator = iterable; + } else if (iterable && iterable[Symbol.asyncIterator]) iterator = iterable[Symbol.asyncIterator]();else if (iterable && iterable[Symbol.iterator]) iterator = iterable[Symbol.iterator]();else throw new ERR_INVALID_ARG_TYPE('iterable', ['Iterable'], iterable); + + var readable = new Readable(_objectSpread({ + objectMode: true + }, opts)); // Reading boolean to protect against _read + // being called before last iteration completion. + + var reading = false; + + readable._read = function () { + if (!reading) { + reading = true; + next(); } - return patterns; -} -exports.getGlobPatternsFromPlugins = getGlobPatternsFromPlugins; -function getGlobPatternsFromPluginsAsync(nxJson, paths, root = workspace_root_1.workspaceRoot) { - return tslib_1.__awaiter(this, void 0, void 0, function* () { - const plugins = yield (0, nx_plugin_1.loadNxPlugins)(nxJson === null || nxJson === void 0 ? void 0 : nxJson.plugins, paths, root); - const patterns = []; - for (const plugin of plugins) { - if (!plugin.projectFilePatterns) { - continue; - } - for (const filePattern of plugin.projectFilePatterns) { - patterns.push('**/' + filePattern); - } - } - return patterns; - }); -} -exports.getGlobPatternsFromPluginsAsync = getGlobPatternsFromPluginsAsync; -/** - * Get the package.json globs from package manager workspaces - */ -function getGlobPatternsFromPackageManagerWorkspaces(root) { - var _a, _b; - try { - const patterns = []; - const packageJson = (0, fileutils_1.readJsonFile)((0, path_1.join)(root, 'package.json')); - patterns.push(...normalizePatterns(Array.isArray(packageJson.workspaces) - ? packageJson.workspaces - : (_b = (_a = packageJson.workspaces) === null || _a === void 0 ? void 0 : _a.packages) !== null && _b !== void 0 ? _b : [])); - if ((0, fs_1.existsSync)((0, path_1.join)(root, 'pnpm-workspace.yaml'))) { - try { - const { packages } = (0, fileutils_1.readYamlFile)((0, path_1.join)(root, 'pnpm-workspace.yaml')); - patterns.push(...normalizePatterns(packages || [])); - } - catch (e) { - output_1.output.warn({ - title: `${logger_1.NX_PREFIX} Unable to parse pnpm-workspace.yaml`, - bodyLines: [e.toString()], - }); - } - } - if ((0, fs_1.existsSync)((0, path_1.join)(root, 'lerna.json'))) { - try { - const { packages } = (0, fileutils_1.readJsonFile)((0, path_1.join)(root, 'lerna.json')); - patterns.push(...normalizePatterns((packages === null || packages === void 0 ? void 0 : packages.length) > 0 ? packages : ['packages/*'])); - } - catch (e) { - output_1.output.warn({ - title: `${logger_1.NX_PREFIX} Unable to parse lerna.json`, - bodyLines: [e.toString()], - }); - } + }; + + function next() { + return _next2.apply(this, arguments); + } + + function _next2() { + _next2 = _asyncToGenerator(function* () { + try { + var _ref = yield iterator.next(), + value = _ref.value, + done = _ref.done; + + if (done) { + readable.push(null); + } else if (readable.push((yield value))) { + next(); + } else { + reading = false; } - // Merge patterns from workspaces definitions - // TODO(@AgentEnder): update logic after better way to determine root project inclusion - // Include the root project - return packageJson.nx ? patterns.concat('package.json') : patterns; - } - catch (_c) { } -} -exports.getGlobPatternsFromPackageManagerWorkspaces = getGlobPatternsFromPackageManagerWorkspaces; -function normalizePatterns(patterns) { - return patterns.map((pattern) => removeRelativePath(pattern.endsWith('/package.json') - ? pattern - : (0, path_2.joinPathFragments)(pattern, 'package.json'))); -} -function removeRelativePath(pattern) { - return pattern.startsWith('./') ? pattern.substring(2) : pattern; -} -function globForProjectFiles(root, pluginsGlobPatterns, nxJson) { - // Deal w/ Caching - const cacheKey = [root, ...pluginsGlobPatterns].join(','); - if (process.env.NX_PROJECT_GLOB_CACHE !== 'false' && - projectGlobCache && - cacheKey === projectGlobCacheKey) { - return projectGlobCache; - } - projectGlobCacheKey = cacheKey; - const _globPatternsFromPackageManagerWorkspaces = getGlobPatternsFromPackageManagerWorkspaces(root); - const globPatternsFromPackageManagerWorkspaces = _globPatternsFromPackageManagerWorkspaces !== null && _globPatternsFromPackageManagerWorkspaces !== void 0 ? _globPatternsFromPackageManagerWorkspaces : []; - const globsToInclude = globPatternsFromPackageManagerWorkspaces.filter((glob) => !glob.startsWith('!')); - const globsToExclude = globPatternsFromPackageManagerWorkspaces - .filter((glob) => glob.startsWith('!')) - .map((glob) => glob.substring(1)) - .map((glob) => (glob.startsWith('/') ? glob.substring(1) : glob)); - const projectGlobPatterns = [ - 'project.json', - '**/project.json', - ...globsToInclude, - ]; - projectGlobPatterns.push(...pluginsGlobPatterns); - const combinedProjectGlobPattern = '{' + projectGlobPatterns.join(',') + '}'; - perf_hooks_1.performance.mark('start-glob-for-projects'); - /** - * This configures the files and directories which we always want to ignore as part of file watching - * and which we know the location of statically (meaning irrespective of user configuration files). - * This has the advantage of being ignored directly within globSync - * - * Other ignored entries will need to be determined dynamically by reading and evaluating the user's - * .gitignore and .nxignore files below. - */ - const staticIgnores = [ - 'node_modules', - '**/node_modules', - 'dist', - '.git', - ...globsToExclude, - ...(0, ignore_1.getIgnoredGlobs)(root, false), - ]; - /** - * TODO: This utility has been implemented multiple times across the Nx codebase, - * discuss whether it should be moved to a shared location. - */ - const opts = { - ignore: staticIgnores, - absolute: false, - cwd: root, - dot: true, - suppressErrors: true, - }; - const globResults = (0, fast_glob_1.sync)(combinedProjectGlobPattern, opts); - projectGlobCache = deduplicateProjectFiles(globResults); - // TODO @vsavkin remove after Nx 16 - if (projectGlobCache.length === 0 && - _globPatternsFromPackageManagerWorkspaces === undefined && - (nxJson === null || nxJson === void 0 ? void 0 : nxJson.extends) === 'nx/presets/npm.json') { - output_1.output.warn({ - title: 'Nx could not find any projects. Check if you need to configure workspaces in package.json or pnpm-workspace.yaml', - }); - } - perf_hooks_1.performance.mark('finish-glob-for-projects'); - perf_hooks_1.performance.measure('glob-for-project-files', 'start-glob-for-projects', 'finish-glob-for-projects'); - return projectGlobCache; -} -exports.globForProjectFiles = globForProjectFiles; -/** - * @description Loops through files and reduces them to 1 file per project. - * @param files Array of files that may represent projects - */ -function deduplicateProjectFiles(files) { - const filtered = new Map(); - files.forEach((file) => { - const projectFolder = (0, path_1.dirname)(file); - const projectFile = (0, path_1.basename)(file); - if (filtered.has(projectFolder) && projectFile !== 'project.json') - return; - filtered.set(projectFolder, projectFile); + } catch (err) { + readable.destroy(err); + } }); - return Array.from(filtered.entries()).map(([folder, file]) => (0, path_1.join)(folder, file)); -} -exports.deduplicateProjectFiles = deduplicateProjectFiles; -function buildProjectConfigurationFromPackageJson(path, packageJson, nxJson) { - var _a, _b, _c, _d; - const normalizedPath = path.split('\\').join('/'); - const directory = (0, path_1.dirname)(normalizedPath); - if (!packageJson.name && directory === '.') { - throw new Error('Nx requires the root package.json to specify a name if it is being used as an Nx project.'); - } - let name = (_a = packageJson.name) !== null && _a !== void 0 ? _a : toProjectName(normalizedPath); - if (nxJson === null || nxJson === void 0 ? void 0 : nxJson.npmScope) { - const npmPrefix = `@${nxJson.npmScope}/`; - if (name.startsWith(npmPrefix)) { - name = name.replace(npmPrefix, ''); - } - } - const projectType = ((_b = nxJson === null || nxJson === void 0 ? void 0 : nxJson.workspaceLayout) === null || _b === void 0 ? void 0 : _b.appsDir) != ((_c = nxJson === null || nxJson === void 0 ? void 0 : nxJson.workspaceLayout) === null || _c === void 0 ? void 0 : _c.libsDir) && - ((_d = nxJson === null || nxJson === void 0 ? void 0 : nxJson.workspaceLayout) === null || _d === void 0 ? void 0 : _d.appsDir) && - directory.startsWith(nxJson.workspaceLayout.appsDir) - ? 'application' - : 'library'; - return { - root: directory, - sourceRoot: directory, - name, - projectType, - }; + return _next2.apply(this, arguments); + } + + return readable; } -function inferProjectFromNonStandardFile(file) { - const directory = (0, path_1.dirname)(file).split('\\').join('/'); - return { - name: toProjectName(file), - root: directory, - }; + +module.exports = from; + +/***/ }), + +/***/ 21451: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + +"use strict"; +// Ported from https://github.com/mafintosh/pump with +// permission from the author, Mathias Buus (@mafintosh). + + +var eos; + +function once(callback) { + var called = false; + return function () { + if (called) return; + called = true; + callback.apply(void 0, arguments); + }; } -exports.inferProjectFromNonStandardFile = inferProjectFromNonStandardFile; -function buildProjectsConfigurationsFromGlobs(nxJson, projectFiles, // making this parameter allows devkit to pick up newly created projects -readJson = (string) => (0, fileutils_1.readJsonFile)(string) // making this an arg allows us to reuse in devkit -) { - const projects = {}; - for (const file of projectFiles) { - const directory = (0, path_1.dirname)(file).split('\\').join('/'); - const fileName = (0, path_1.basename)(file); - if (fileName === 'project.json') { - // Nx specific project configuration (`project.json` files) in the same - // directory as a package.json should overwrite the inferred package.json - // project configuration. - const configuration = readJson(file); - configuration.root = directory; - let name = configuration.name; - if (!configuration.name) { - name = toProjectName(file); - } - if (!projects[name]) { - projects[name] = configuration; - } - else { - logger_1.logger.warn(`Skipping project found at ${directory} since project ${name} already exists at ${projects[name].root}! Specify a unique name for the project to allow Nx to differentiate between the two projects.`); - } - } - else { - // We can infer projects from package.json files, - // if a package.json file is in a directory w/o a `project.json` file. - // this results in targets being inferred by Nx from package scripts, - // and the root / sourceRoot both being the directory. - if (fileName === 'package.json') { - const projectPackageJson = readJson(file); - const _a = buildProjectConfigurationFromPackageJson(file, projectPackageJson, nxJson), { name } = _a, config = tslib_1.__rest(_a, ["name"]); - if (!projects[name]) { - projects[name] = config; - } - else { - logger_1.logger.warn(`Skipping project found at ${directory} since project ${name} already exists at ${projects[name].root}! Specify a unique name for the project to allow Nx to differentiate between the two projects.`); - } - } - else { - // This project was created from an nx plugin. - // The only thing we know about the file is its location - const _b = inferProjectFromNonStandardFile(file), { name } = _b, config = tslib_1.__rest(_b, ["name"]); - if (!projects[name]) { - projects[name] = config; - } - else { - logger_1.logger.error(`Skipping project inferred from ${file} since project ${name} already exists.`); - throw new Error(); - } - } - } - } - return { - version: 2, - projects: projects, - }; + +var _require$codes = (__nccwpck_require__(90646)/* .codes */ .q), + ERR_MISSING_ARGS = _require$codes.ERR_MISSING_ARGS, + ERR_STREAM_DESTROYED = _require$codes.ERR_STREAM_DESTROYED; + +function noop(err) { + // Rethrow the error if it exists to avoid swallowing it + if (err) throw err; } -exports.buildProjectsConfigurationsFromGlobs = buildProjectsConfigurationsFromGlobs; -function mergeTargetConfigurations(projectConfiguration, target, targetDefaults) { - var _a, _b; - const targetConfiguration = (_a = projectConfiguration.targets) === null || _a === void 0 ? void 0 : _a[target]; - if (!targetConfiguration) { - throw new Error(`Attempted to merge targetDefaults for ${projectConfiguration.name}.${target}, which doesn't exist.`); - } - const { configurations: defaultConfigurations, options: defaultOptions } = targetDefaults, defaults = tslib_1.__rest(targetDefaults, ["configurations", "options"]); - const result = Object.assign(Object.assign({}, defaults), targetConfiguration); - // Target is "compatible", e.g. executor is defined only once or is the same - // in both places. This means that it is likely safe to merge options - if (!targetDefaults.executor || - !targetConfiguration.executor || - targetDefaults.executor === targetConfiguration.executor) { - result.options = mergeOptions(defaultOptions, (_b = targetConfiguration.options) !== null && _b !== void 0 ? _b : {}, projectConfiguration, target); - result.configurations = mergeConfigurations(defaultConfigurations, targetConfiguration.configurations, projectConfiguration, target); - } - return result; + +function isRequest(stream) { + return stream.setHeader && typeof stream.abort === 'function'; } -exports.mergeTargetConfigurations = mergeTargetConfigurations; -function mergeOptions(defaults, options, project, key) { - return Object.assign(Object.assign({}, resolvePathTokensInOptions(defaults, project, key)), options); + +function destroyer(stream, reading, writing, callback) { + callback = once(callback); + var closed = false; + stream.on('close', function () { + closed = true; + }); + if (eos === undefined) eos = __nccwpck_require__(75628); + eos(stream, { + readable: reading, + writable: writing + }, function (err) { + if (err) return callback(err); + closed = true; + callback(); + }); + var destroyed = false; + return function (err) { + if (closed) return; + if (destroyed) return; + destroyed = true; // request.destroy just do .end - .abort is what we want + + if (isRequest(stream)) return stream.abort(); + if (typeof stream.destroy === 'function') return stream.destroy(); + callback(err || new ERR_STREAM_DESTROYED('pipe')); + }; } -function mergeConfigurations(defaultConfigurations, projectDefinedConfigurations, project, targetName) { - const configurations = Object.assign({}, projectDefinedConfigurations); - for (const configuration in defaultConfigurations) { - configurations[configuration] = mergeOptions(defaultConfigurations[configuration], configurations[configuration], project, `${targetName}.${configuration}`); - } - return configurations; + +function call(fn) { + fn(); } -function resolvePathTokensInOptions(object, project, key) { - const result = Array.isArray(object) ? [...object] : Object.assign({}, object); - for (let [opt, value] of Object.entries(object !== null && object !== void 0 ? object : {})) { - if (typeof value === 'string') { - if (value.startsWith('{workspaceRoot}/')) { - value = value.replace(/^\{workspaceRoot\}\//, ''); - } - if (value.includes('{workspaceRoot}')) { - throw new Error(`${logger_1.NX_PREFIX} The {workspaceRoot} token is only valid at the beginning of an option. (${key})`); - } - value = value.replace(/\{projectRoot\}/g, project.root); - result[opt] = value.replace(/\{projectName\}/g, project.name); - } - else if (typeof value === 'object' && value) { - result[opt] = resolvePathTokensInOptions(value, project, [key, opt].join('.')); - } - } - return result; + +function pipe(from, to) { + return from.pipe(to); } -function readTargetDefaultsForTarget(targetName, targetDefaults, executor) { - if (executor) { - // If an executor is defined in project.json, defaults should be read - // from the most specific key that matches that executor. - // e.g. If executor === run-commands, and the target is named build: - // Use, use nx:run-commands if it is present - // If not, use build if it is present. - const key = [executor, targetName].find((x) => targetDefaults === null || targetDefaults === void 0 ? void 0 : targetDefaults[x]); - return key ? targetDefaults === null || targetDefaults === void 0 ? void 0 : targetDefaults[key] : null; - } - else { - // If the executor is not defined, the only key we have is the target name. - return targetDefaults === null || targetDefaults === void 0 ? void 0 : targetDefaults[targetName]; - } + +function popCallback(streams) { + if (!streams.length) return noop; + if (typeof streams[streams.length - 1] !== 'function') return noop; + return streams.pop(); } -exports.readTargetDefaultsForTarget = readTargetDefaultsForTarget; -// we have to do it this way to preserve the order of properties -// not to screw up the formatting -function renamePropertyWithStableKeys(obj, from, to) { - const copy = Object.assign({}, obj); - Object.keys(obj).forEach((k) => { - delete obj[k]; - }); - Object.keys(copy).forEach((k) => { - if (k === from) { - obj[to] = copy[k]; - } - else { - obj[k] = copy[k]; - } + +function pipeline() { + for (var _len = arguments.length, streams = new Array(_len), _key = 0; _key < _len; _key++) { + streams[_key] = arguments[_key]; + } + + var callback = popCallback(streams); + if (Array.isArray(streams[0])) streams = streams[0]; + + if (streams.length < 2) { + throw new ERR_MISSING_ARGS('streams'); + } + + var error; + var destroys = streams.map(function (stream, i) { + var reading = i < streams.length - 1; + var writing = i > 0; + return destroyer(stream, reading, writing, function (err) { + if (!error) error = err; + if (err) destroys.forEach(call); + if (reading) return; + destroys.forEach(call); + callback(error); }); + }); + return streams.reduce(pipe); } -exports.renamePropertyWithStableKeys = renamePropertyWithStableKeys; +module.exports = pipeline; /***/ }), -/***/ 15015: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { +/***/ 12138: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { "use strict"; -Object.defineProperty(exports, "__esModule", ({ value: true })); -exports.getDaemonProcessIdSync = exports.safelyCleanUpExistingProcess = exports.writeDaemonJsonProcessCache = exports.deleteDaemonJsonProcessCache = exports.readDaemonProcessJsonCache = exports.serverProcessJsonPath = void 0; -const tslib_1 = __nccwpck_require__(51796); -const fs_extra_1 = __nccwpck_require__(59511); -const path_1 = __nccwpck_require__(71017); -const tmp_dir_1 = __nccwpck_require__(87196); -exports.serverProcessJsonPath = (0, path_1.join)(tmp_dir_1.DAEMON_DIR_FOR_CURRENT_WORKSPACE, 'server-process.json'); -function readDaemonProcessJsonCache() { - return tslib_1.__awaiter(this, void 0, void 0, function* () { - if (!(0, fs_extra_1.existsSync)(exports.serverProcessJsonPath)) { - return null; - } - return yield (0, fs_extra_1.readJson)(exports.serverProcessJsonPath); - }); + +var ERR_INVALID_OPT_VALUE = (__nccwpck_require__(90646)/* .codes.ERR_INVALID_OPT_VALUE */ .q.ERR_INVALID_OPT_VALUE); + +function highWaterMarkFrom(options, isDuplex, duplexKey) { + return options.highWaterMark != null ? options.highWaterMark : isDuplex ? options[duplexKey] : null; } -exports.readDaemonProcessJsonCache = readDaemonProcessJsonCache; -function deleteDaemonJsonProcessCache() { - try { - if (getDaemonProcessIdSync() === process.pid) { - (0, fs_extra_1.unlinkSync)(exports.serverProcessJsonPath); - } + +function getHighWaterMark(state, options, duplexKey, isDuplex) { + var hwm = highWaterMarkFrom(options, isDuplex, duplexKey); + + if (hwm != null) { + if (!(isFinite(hwm) && Math.floor(hwm) === hwm) || hwm < 0) { + var name = isDuplex ? duplexKey : 'highWaterMark'; + throw new ERR_INVALID_OPT_VALUE(name, hwm); } - catch (_a) { } + + return Math.floor(hwm); + } // Default value + + + return state.objectMode ? 16 : 16 * 1024; } -exports.deleteDaemonJsonProcessCache = deleteDaemonJsonProcessCache; -function writeDaemonJsonProcessCache(daemonJson) { - return tslib_1.__awaiter(this, void 0, void 0, function* () { - yield (0, fs_extra_1.writeJson)(exports.serverProcessJsonPath, daemonJson); - }); + +module.exports = { + getHighWaterMark: getHighWaterMark +}; + +/***/ }), + +/***/ 99004: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + +module.exports = __nccwpck_require__(12781); + + +/***/ }), + +/***/ 17067: +/***/ ((module, exports, __nccwpck_require__) => { + +var Stream = __nccwpck_require__(12781); +if (process.env.READABLE_STREAM === 'disable' && Stream) { + module.exports = Stream.Readable; + Object.assign(module.exports, Stream); + module.exports.Stream = Stream; +} else { + exports = module.exports = __nccwpck_require__(90960); + exports.Stream = Stream || exports; + exports.Readable = exports; + exports.Writable = __nccwpck_require__(23388); + exports.Duplex = __nccwpck_require__(97256); + exports.Transform = __nccwpck_require__(56765); + exports.PassThrough = __nccwpck_require__(17940); + exports.finished = __nccwpck_require__(75628); + exports.pipeline = __nccwpck_require__(21451); } -exports.writeDaemonJsonProcessCache = writeDaemonJsonProcessCache; -function safelyCleanUpExistingProcess() { - return tslib_1.__awaiter(this, void 0, void 0, function* () { - const daemonProcessJson = yield readDaemonProcessJsonCache(); - if (daemonProcessJson && daemonProcessJson.processId) { - try { - process.kill(daemonProcessJson.processId); - } - catch (_a) { } - } - deleteDaemonJsonProcessCache(); - }); + + +/***/ }), + +/***/ 88624: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + +const assert = __nccwpck_require__(39491) +const path = __nccwpck_require__(71017) +const fs = __nccwpck_require__(57147) +let glob = undefined +try { + glob = __nccwpck_require__(69959) +} catch (_err) { + // treat glob as optional. } -exports.safelyCleanUpExistingProcess = safelyCleanUpExistingProcess; -// Must be sync for the help output use case -function getDaemonProcessIdSync() { - if (!(0, fs_extra_1.existsSync)(exports.serverProcessJsonPath)) { - return null; - } - try { - const daemonProcessJson = (0, fs_extra_1.readJsonSync)(exports.serverProcessJsonPath); - return daemonProcessJson.processId; - } - catch (_a) { - return null; - } + +const defaultGlobOpts = { + nosort: true, + silent: true } -exports.getDaemonProcessIdSync = getDaemonProcessIdSync; +// for EMFILE handling +let timeout = 0 -/***/ }), +const isWindows = (process.platform === "win32") -/***/ 55942: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { +const defaults = options => { + const methods = [ + 'unlink', + 'chmod', + 'stat', + 'lstat', + 'rmdir', + 'readdir' + ] + methods.forEach(m => { + options[m] = options[m] || fs[m] + m = m + 'Sync' + options[m] = options[m] || fs[m] + }) -"use strict"; + options.maxBusyTries = options.maxBusyTries || 3 + options.emfileWait = options.emfileWait || 1000 + if (options.glob === false) { + options.disableGlob = true + } + if (options.disableGlob !== true && glob === undefined) { + throw Error('glob dependency not found, set `options.disableGlob = true` if intentional') + } + options.disableGlob = options.disableGlob || false + options.glob = options.glob || defaultGlobOpts +} -Object.defineProperty(exports, "__esModule", ({ value: true })); -exports.daemonClient = exports.DaemonClient = void 0; -const tslib_1 = __nccwpck_require__(51796); -const workspace_root_1 = __nccwpck_require__(65766); -const child_process_1 = __nccwpck_require__(32081); -const fs_1 = __nccwpck_require__(57147); -const promises_1 = __nccwpck_require__(73292); -const fs_extra_1 = __nccwpck_require__(59511); -const net_1 = __nccwpck_require__(41808); -const path_1 = __nccwpck_require__(71017); -const perf_hooks_1 = __nccwpck_require__(4074); -const output_1 = __nccwpck_require__(34548); -const socket_utils_1 = __nccwpck_require__(3497); -const tmp_dir_1 = __nccwpck_require__(87196); -const is_ci_1 = __nccwpck_require__(28839); -const configuration_1 = __nccwpck_require__(65459); -const promised_based_queue_1 = __nccwpck_require__(45208); -const workspaces_1 = __nccwpck_require__(98715); -const socket_messenger_1 = __nccwpck_require__(4850); -const cache_1 = __nccwpck_require__(15015); -const DAEMON_ENV_SETTINGS = Object.assign(Object.assign({}, process.env), { NX_PROJECT_GLOB_CACHE: 'false', NX_CACHE_PROJECTS_CONFIG: 'false' }); -class DaemonClient { - constructor(nxJson) { - this.nxJson = nxJson; - this._out = null; - this._err = null; - this.reset(); - } - enabled() { - var _a, _b, _c; - if (this._enabled === undefined) { - const useDaemonProcessOption = (_c = (_b = (_a = this.nxJson.tasksRunnerOptions) === null || _a === void 0 ? void 0 : _a['default']) === null || _b === void 0 ? void 0 : _b.options) === null || _c === void 0 ? void 0 : _c.useDaemonProcess; - const env = process.env.NX_DAEMON; - // env takes precedence - // option=true,env=false => no daemon - // option=false,env=undefined => no daemon - // option=false,env=false => no daemon - // option=undefined,env=undefined => daemon - // option=true,env=true => daemon - // option=false,env=true => daemon - // CI=true,env=undefined => no daemon - // CI=true,env=false => no daemon - // CI=true,env=true => daemon - if (((0, is_ci_1.isCI)() && env !== 'true') || - isDocker() || - (0, tmp_dir_1.isDaemonDisabled)() || - nxJsonIsNotPresent() || - (useDaemonProcessOption === undefined && env === 'false') || - (useDaemonProcessOption === true && env === 'false') || - (useDaemonProcessOption === false && env === undefined) || - (useDaemonProcessOption === false && env === 'false')) { - this._enabled = false; - } - else { - this._enabled = true; - } - } - return this._enabled; - } - reset() { - var _a, _b, _c; - (_a = this.socketMessenger) === null || _a === void 0 ? void 0 : _a.close(); - this.socketMessenger = null; - this.queue = new promised_based_queue_1.PromisedBasedQueue(); - this.currentMessage = null; - this.currentResolve = null; - this.currentReject = null; - this._enabled = undefined; - (_b = this._out) === null || _b === void 0 ? void 0 : _b.close(); - (_c = this._err) === null || _c === void 0 ? void 0 : _c.close(); - this._out = null; - this._err = null; - this._connected = false; - } - requestShutdown() { - return tslib_1.__awaiter(this, void 0, void 0, function* () { - return this.sendToDaemonViaQueue({ type: 'REQUEST_SHUTDOWN' }); - }); - } - getProjectGraph() { - return tslib_1.__awaiter(this, void 0, void 0, function* () { - return (yield this.sendToDaemonViaQueue({ type: 'REQUEST_PROJECT_GRAPH' })) - .projectGraph; - }); - } - getAllFileData() { - return tslib_1.__awaiter(this, void 0, void 0, function* () { - return yield this.sendToDaemonViaQueue({ type: 'REQUEST_FILE_DATA' }); - }); - } - hashTasks(runnerOptions, tasks) { - return this.sendToDaemonViaQueue({ - type: 'HASH_TASKS', - runnerOptions, - tasks, - }); - } - registerFileWatcher(config, callback) { - return tslib_1.__awaiter(this, void 0, void 0, function* () { - yield this.getProjectGraph(); - const messenger = new socket_messenger_1.SocketMessenger((0, net_1.connect)(socket_utils_1.FULL_OS_SOCKET_PATH)).listen((message) => { - try { - const parsedMessage = JSON.parse(message); - callback(null, parsedMessage); - } - catch (e) { - callback(e, null); - } - }, () => { - callback('closed', null); - }, (err) => callback(err, null)); - yield this.queue.sendToQueue(() => messenger.sendMessage({ type: 'REGISTER_FILE_WATCHER', config })); - return () => { - messenger.close(); - }; - }); - } - processInBackground(requirePath, data) { - return this.sendToDaemonViaQueue({ - type: 'PROCESS_IN_BACKGROUND', - requirePath, - data, - }); - } - recordOutputsHash(outputs, hash) { - return this.sendToDaemonViaQueue({ - type: 'RECORD_OUTPUTS_HASH', - data: { - outputs, - hash, - }, - }); - } - outputsHashesMatch(outputs, hash) { - return this.sendToDaemonViaQueue({ - type: 'OUTPUTS_HASHES_MATCH', - data: { - outputs, - hash, - }, - }); - } - isServerAvailable() { - return tslib_1.__awaiter(this, void 0, void 0, function* () { - return new Promise((resolve) => { - try { - const socket = (0, net_1.connect)(socket_utils_1.FULL_OS_SOCKET_PATH, () => { - socket.destroy(); - resolve(true); - }); - socket.once('error', () => { - resolve(false); - }); - } - catch (err) { - resolve(false); - } - }); - }); - } - sendToDaemonViaQueue(messageToDaemon) { - return tslib_1.__awaiter(this, void 0, void 0, function* () { - return this.queue.sendToQueue(() => this.sendMessageToDaemon(messageToDaemon)); - }); - } - setUpConnection() { - this.socketMessenger = new socket_messenger_1.SocketMessenger((0, net_1.connect)(socket_utils_1.FULL_OS_SOCKET_PATH)).listen((message) => this.handleMessage(message), () => { - // it's ok for the daemon to terminate if the client doesn't wait on - // any messages from the daemon - if (this.queue.isEmpty()) { - this._connected = false; - } - else { - output_1.output.error({ - title: 'Daemon process terminated and closed the connection', - bodyLines: [ - 'Please rerun the command, which will restart the daemon.', - ], - }); - process.exit(1); - } - }, (err) => { - if (!err.message) { - return this.currentReject(daemonProcessException(err.toString())); - } - if (err.message.startsWith('LOCK-FILES-CHANGED')) { - // retry the current message - // we cannot send it via the queue because we are in the middle of processing - // a message from the queue - return this.sendMessageToDaemon(this.currentMessage).then(this.currentResolve, this.currentReject); - } - let error; - if (err.message.startsWith('connect ENOENT')) { - error = daemonProcessException('The Daemon Server is not running'); - } - else if (err.message.startsWith('connect ECONNREFUSED')) { - error = daemonProcessException(`A server instance had not been fully shut down. Please try running the command again.`); - (0, socket_utils_1.killSocketOrPath)(); - } - else if (err.message.startsWith('read ECONNRESET')) { - error = daemonProcessException(`Unable to connect to the daemon process.`); - } - else { - error = daemonProcessException(err.toString()); - } - return this.currentReject(error); - }); - } - sendMessageToDaemon(message) { - return tslib_1.__awaiter(this, void 0, void 0, function* () { - if (!this._connected) { - this._connected = true; - if (!(yield this.isServerAvailable())) { - yield this.startInBackground(); - } - this.setUpConnection(); - } - return new Promise((resolve, reject) => { - perf_hooks_1.performance.mark('sendMessageToDaemon-start'); - this.currentMessage = message; - this.currentResolve = resolve; - this.currentReject = reject; - this.socketMessenger.sendMessage(message); - }); - }); - } - handleMessage(serializedResult) { - try { - perf_hooks_1.performance.mark('json-parse-start'); - const parsedResult = JSON.parse(serializedResult); - perf_hooks_1.performance.mark('json-parse-end'); - perf_hooks_1.performance.measure('deserialize daemon response', 'json-parse-start', 'json-parse-end'); - if (parsedResult.error) { - this.currentReject(parsedResult.error); - } - else { - perf_hooks_1.performance.measure('total for sendMessageToDaemon()', 'sendMessageToDaemon-start', 'json-parse-end'); - return this.currentResolve(parsedResult); - } - } - catch (e) { - const endOfResponse = serializedResult.length > 300 - ? serializedResult.substring(serializedResult.length - 300) - : serializedResult; - this.currentReject(daemonProcessException([ - 'Could not deserialize response from Nx daemon.', - `Message: ${e.message}`, - '\n', - `Received:`, - endOfResponse, - '\n', - ].join('\n'))); +const rimraf = (p, options, cb) => { + if (typeof options === 'function') { + cb = options + options = {} + } + + assert(p, 'rimraf: missing path') + assert.equal(typeof p, 'string', 'rimraf: path should be a string') + assert.equal(typeof cb, 'function', 'rimraf: callback function required') + assert(options, 'rimraf: invalid options argument provided') + assert.equal(typeof options, 'object', 'rimraf: options should be object') + + defaults(options) + + let busyTries = 0 + let errState = null + let n = 0 + + const next = (er) => { + errState = errState || er + if (--n === 0) + cb(errState) + } + + const afterGlob = (er, results) => { + if (er) + return cb(er) + + n = results.length + if (n === 0) + return cb() + + results.forEach(p => { + const CB = (er) => { + if (er) { + if ((er.code === "EBUSY" || er.code === "ENOTEMPTY" || er.code === "EPERM") && + busyTries < options.maxBusyTries) { + busyTries ++ + // try again, with the same exact callback as this one. + return setTimeout(() => rimraf_(p, options, CB), busyTries * 100) + } + + // this one won't happen if graceful-fs is used. + if (er.code === "EMFILE" && timeout < options.emfileWait) { + return setTimeout(() => rimraf_(p, options, CB), timeout ++) + } + + // already gone + if (er.code === "ENOENT") er = null } - } - startInBackground() { - return tslib_1.__awaiter(this, void 0, void 0, function* () { - (0, fs_extra_1.ensureDirSync)(tmp_dir_1.DAEMON_DIR_FOR_CURRENT_WORKSPACE); - (0, fs_extra_1.ensureFileSync)(tmp_dir_1.DAEMON_OUTPUT_LOG_FILE); - this._out = yield (0, promises_1.open)(tmp_dir_1.DAEMON_OUTPUT_LOG_FILE, 'a'); - this._err = yield (0, promises_1.open)(tmp_dir_1.DAEMON_OUTPUT_LOG_FILE, 'a'); - const backgroundProcess = (0, child_process_1.spawn)(process.execPath, [(0, path_1.join)(__dirname, '../server/start.js')], { - cwd: workspace_root_1.workspaceRoot, - stdio: ['ignore', this._out.fd, this._err.fd], - detached: true, - windowsHide: true, - shell: false, - env: DAEMON_ENV_SETTINGS, - }); - backgroundProcess.unref(); - // - /** - * Ensure the server is actually available to connect to via IPC before resolving - */ - let attempts = 0; - return new Promise((resolve, reject) => { - const id = setInterval(() => tslib_1.__awaiter(this, void 0, void 0, function* () { - if (yield this.isServerAvailable()) { - clearInterval(id); - resolve(backgroundProcess.pid); - } - else if (attempts > 1000) { - // daemon fails to start, the process probably exited - // we print the logs and exit the client - reject(daemonProcessException('Failed to start or connect to the Nx Daemon process.')); - } - else { - attempts++; - } - }), 10); - }); - }); - } - stop() { - return tslib_1.__awaiter(this, void 0, void 0, function* () { - try { - yield (0, cache_1.safelyCleanUpExistingProcess)(); - } - catch (err) { - output_1.output.error({ - title: (err === null || err === void 0 ? void 0 : err.message) || - 'Something unexpected went wrong when stopping the server', - }); - } - (0, tmp_dir_1.removeSocketDir)(); - }); - } + + timeout = 0 + next(er) + } + rimraf_(p, options, CB) + }) + } + + if (options.disableGlob || !glob.hasMagic(p)) + return afterGlob(null, [p]) + + options.lstat(p, (er, stat) => { + if (!er) + return afterGlob(null, [p]) + + glob(p, options.glob, afterGlob) + }) + } -exports.DaemonClient = DaemonClient; -exports.daemonClient = new DaemonClient((0, configuration_1.readNxJson)()); -function isDocker() { - var _a; - try { - (0, fs_1.statSync)('/.dockerenv'); - return true; - } - catch (_b) { - try { - return (_a = (0, fs_1.readFileSync)('/proc/self/cgroup', 'utf8')) === null || _a === void 0 ? void 0 : _a.includes('docker'); - } - catch (_c) { } - return false; - } + +// Two possible strategies. +// 1. Assume it's a file. unlink it, then do the dir stuff on EPERM or EISDIR +// 2. Assume it's a directory. readdir, then do the file stuff on ENOTDIR +// +// Both result in an extra syscall when you guess wrong. However, there +// are likely far more normal files in the world than directories. This +// is based on the assumption that a the average number of files per +// directory is >= 1. +// +// If anyone ever complains about this, then I guess the strategy could +// be made configurable somehow. But until then, YAGNI. +const rimraf_ = (p, options, cb) => { + assert(p) + assert(options) + assert(typeof cb === 'function') + + // sunos lets the root user unlink directories, which is... weird. + // so we have to lstat here and make sure it's not a dir. + options.lstat(p, (er, st) => { + if (er && er.code === "ENOENT") + return cb(null) + + // Windows can EPERM on stat. Life is suffering. + if (er && er.code === "EPERM" && isWindows) + fixWinEPERM(p, options, er, cb) + + if (st && st.isDirectory()) + return rmdir(p, options, er, cb) + + options.unlink(p, er => { + if (er) { + if (er.code === "ENOENT") + return cb(null) + if (er.code === "EPERM") + return (isWindows) + ? fixWinEPERM(p, options, er, cb) + : rmdir(p, options, er, cb) + if (er.code === "EISDIR") + return rmdir(p, options, er, cb) + } + return cb(er) + }) + }) } -function nxJsonIsNotPresent() { - return !new workspaces_1.Workspaces(workspace_root_1.workspaceRoot).hasNxJson(); + +const fixWinEPERM = (p, options, er, cb) => { + assert(p) + assert(options) + assert(typeof cb === 'function') + + options.chmod(p, 0o666, er2 => { + if (er2) + cb(er2.code === "ENOENT" ? null : er) + else + options.stat(p, (er3, stats) => { + if (er3) + cb(er3.code === "ENOENT" ? null : er) + else if (stats.isDirectory()) + rmdir(p, options, er, cb) + else + options.unlink(p, cb) + }) + }) } -function daemonProcessException(message) { - try { - let log = (0, fs_1.readFileSync)(tmp_dir_1.DAEMON_OUTPUT_LOG_FILE).toString().split('\n'); - if (log.length > 20) { - log = log.slice(log.length - 20); - } - const error = new Error([ - message, - '', - 'Messages from the log:', - ...log, - '\n', - `More information: ${tmp_dir_1.DAEMON_OUTPUT_LOG_FILE}`, - ].join('\n')); - error.internalDaemonError = true; - return error; - } - catch (e) { - return new Error(message); - } + +const fixWinEPERMSync = (p, options, er) => { + assert(p) + assert(options) + + try { + options.chmodSync(p, 0o666) + } catch (er2) { + if (er2.code === "ENOENT") + return + else + throw er + } + + let stats + try { + stats = options.statSync(p) + } catch (er3) { + if (er3.code === "ENOENT") + return + else + throw er + } + + if (stats.isDirectory()) + rmdirSync(p, options, er) + else + options.unlinkSync(p) } +const rmdir = (p, options, originalEr, cb) => { + assert(p) + assert(options) + assert(typeof cb === 'function') -/***/ }), + // try to rmdir first, and only readdir on ENOTEMPTY or EEXIST (SunOS) + // if we guessed wrong, and it's not a directory, then + // raise the original error. + options.rmdir(p, er => { + if (er && (er.code === "ENOTEMPTY" || er.code === "EEXIST" || er.code === "EPERM")) + rmkids(p, options, cb) + else if (er && er.code === "ENOTDIR") + cb(originalEr) + else + cb(er) + }) +} -/***/ 4850: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { +const rmkids = (p, options, cb) => { + assert(p) + assert(options) + assert(typeof cb === 'function') -"use strict"; + options.readdir(p, (er, files) => { + if (er) + return cb(er) + let n = files.length + if (n === 0) + return options.rmdir(p, cb) + let errState + files.forEach(f => { + rimraf(path.join(p, f), options, er => { + if (errState) + return + if (er) + return cb(errState = er) + if (--n === 0) + options.rmdir(p, cb) + }) + }) + }) +} -Object.defineProperty(exports, "__esModule", ({ value: true })); -exports.SocketMessenger = void 0; -const tslib_1 = __nccwpck_require__(51796); -const consume_messages_from_socket_1 = __nccwpck_require__(81904); -class SocketMessenger { - constructor(socket) { - this.socket = socket; - } - sendMessage(messageToDaemon) { - return tslib_1.__awaiter(this, void 0, void 0, function* () { - this.socket.write(JSON.stringify(messageToDaemon)); - // send EOT to indicate that the message has been fully written - this.socket.write(String.fromCodePoint(4)); - }); - } - listen(onData, onClose = () => { }, onError = (err) => { }) { - this.socket.on('data', (0, consume_messages_from_socket_1.consumeMessagesFromSocket)((message) => tslib_1.__awaiter(this, void 0, void 0, function* () { - onData(message); - }))); - this.socket.on('close', onClose); - this.socket.on('error', onError); - return this; - } - close() { - this.socket.destroy(); +// this looks simpler, and is strictly *faster*, but will +// tie up the JavaScript thread and fail on excessively +// deep directory trees. +const rimrafSync = (p, options) => { + options = options || {} + defaults(options) + + assert(p, 'rimraf: missing path') + assert.equal(typeof p, 'string', 'rimraf: path should be a string') + assert(options, 'rimraf: missing options') + assert.equal(typeof options, 'object', 'rimraf: options should be object') + + let results + + if (options.disableGlob || !glob.hasMagic(p)) { + results = [p] + } else { + try { + options.lstatSync(p) + results = [p] + } catch (er) { + results = glob.sync(p, options.glob) } -} -exports.SocketMessenger = SocketMessenger; + } + if (!results.length) + return -/***/ }), + for (let i = 0; i < results.length; i++) { + const p = results[i] -/***/ 3497: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { + let st + try { + st = options.lstatSync(p) + } catch (er) { + if (er.code === "ENOENT") + return -"use strict"; + // Windows can EPERM on stat. Life is suffering. + if (er.code === "EPERM" && isWindows) + fixWinEPERMSync(p, options, er) + } -Object.defineProperty(exports, "__esModule", ({ value: true })); -exports.serializeResult = exports.killSocketOrPath = exports.FULL_OS_SOCKET_PATH = exports.isWindows = void 0; -const fs_1 = __nccwpck_require__(57147); -const os_1 = __nccwpck_require__(22037); -const path_1 = __nccwpck_require__(71017); -const tmp_dir_1 = __nccwpck_require__(87196); -exports.isWindows = (0, os_1.platform)() === 'win32'; -/** - * For IPC with the daemon server we use unix sockets or windows named pipes, depending on the user's operating system. - * - * See https://nodejs.org/dist/latest-v14.x/docs/api/net.html#net_identifying_paths_for_ipc_connections for a full breakdown - * of OS differences between Unix domain sockets and named pipes. - */ -exports.FULL_OS_SOCKET_PATH = exports.isWindows - ? '\\\\.\\pipe\\nx\\' + (0, path_1.resolve)(tmp_dir_1.DAEMON_SOCKET_PATH) - : (0, path_1.resolve)(tmp_dir_1.DAEMON_SOCKET_PATH); -function killSocketOrPath() { try { - (0, fs_1.unlinkSync)(exports.FULL_OS_SOCKET_PATH); + // sunos lets the root user unlink directories, which is... weird. + if (st && st.isDirectory()) + rmdirSync(p, options, null) + else + options.unlinkSync(p) + } catch (er) { + if (er.code === "ENOENT") + return + if (er.code === "EPERM") + return isWindows ? fixWinEPERMSync(p, options, er) : rmdirSync(p, options, er) + if (er.code !== "EISDIR") + throw er + + rmdirSync(p, options, er) } - catch (_a) { } + } } -exports.killSocketOrPath = killSocketOrPath; -// Include the original stack trace within the serialized error so that the client can show it to the user. -function serializeError(error) { - if (!error) { - return null; - } - return JSON.stringify(error, Object.getOwnPropertyNames(error)); + +const rmdirSync = (p, options, originalEr) => { + assert(p) + assert(options) + + try { + options.rmdirSync(p) + } catch (er) { + if (er.code === "ENOENT") + return + if (er.code === "ENOTDIR") + throw originalEr + if (er.code === "ENOTEMPTY" || er.code === "EEXIST" || er.code === "EPERM") + rmkidsSync(p, options) + } } -// Prepare a serialized project graph result for sending over IPC from the server to the client -function serializeResult(error, serializedProjectGraph) { - // We do not want to repeat work `JSON.stringify`ing an object containing the potentially large project graph so merge as strings - return `{ "error": ${serializeError(error)}, "projectGraph": ${serializedProjectGraph} }`; + +const rmkidsSync = (p, options) => { + assert(p) + assert(options) + options.readdirSync(p).forEach(f => rimrafSync(path.join(p, f), options)) + + // We only end up here once we got ENOTEMPTY at least once, and + // at this point, we are guaranteed to have removed all the kids. + // So, we know that it won't be ENOENT or ENOTDIR or anything else. + // try really hard to delete stuff on windows, because it has a + // PROFOUNDLY annoying habit of not closing handles promptly when + // files are deleted, resulting in spurious ENOTEMPTY errors. + const retries = isWindows ? 100 : 1 + let i = 0 + do { + let threw = true + try { + const ret = options.rmdirSync(p, options) + threw = false + return ret + } finally { + if (++i < retries && threw) + continue + } + } while (true) } -exports.serializeResult = serializeResult; + +module.exports = rimraf +rimraf.sync = rimrafSync /***/ }), -/***/ 87196: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { +/***/ 54184: +/***/ ((module, exports, __nccwpck_require__) => { -"use strict"; +/*! safe-buffer. MIT License. Feross Aboukhadijeh */ +/* eslint-disable node/no-deprecated-api */ +var buffer = __nccwpck_require__(14300) +var Buffer = buffer.Buffer -Object.defineProperty(exports, "__esModule", ({ value: true })); -exports.removeSocketDir = exports.isDaemonDisabled = exports.markDaemonAsDisabled = exports.writeDaemonLogs = exports.DAEMON_SOCKET_PATH = exports.DAEMON_OUTPUT_LOG_FILE = exports.DAEMON_DIR_FOR_CURRENT_WORKSPACE = void 0; -/** - * Per workspace (to avoid subtle differences and issues), we want to have a deterministic - * location within the OS's tmp directory where we write log files for background processes - * and where we create the actual unix socket/named pipe for the daemon. - */ -const fs_1 = __nccwpck_require__(57147); -const fs_extra_1 = __nccwpck_require__(59511); -const path_1 = __nccwpck_require__(71017); -const cache_directory_1 = __nccwpck_require__(20858); -const crypto_1 = __nccwpck_require__(6113); -const tmp_1 = __nccwpck_require__(49503); -const workspace_root_1 = __nccwpck_require__(65766); -exports.DAEMON_DIR_FOR_CURRENT_WORKSPACE = (0, path_1.join)(cache_directory_1.projectGraphCacheDirectory, 'd'); -exports.DAEMON_OUTPUT_LOG_FILE = (0, path_1.join)(exports.DAEMON_DIR_FOR_CURRENT_WORKSPACE, 'daemon.log'); -const socketDir = createSocketDir(); -exports.DAEMON_SOCKET_PATH = (0, path_1.join)(socketDir, -// As per notes above on socket/named pipe length limitations, we keep this intentionally short -'d.sock'); -function writeDaemonLogs(error) { - const file = (0, path_1.join)(exports.DAEMON_DIR_FOR_CURRENT_WORKSPACE, 'daemon-error.log'); - (0, fs_1.writeFileSync)(file, error); - return file; +// alternative to using Object.keys for old browsers +function copyProps (src, dst) { + for (var key in src) { + dst[key] = src[key] + } } -exports.writeDaemonLogs = writeDaemonLogs; -function markDaemonAsDisabled() { - (0, fs_1.writeFileSync)((0, path_1.join)(exports.DAEMON_DIR_FOR_CURRENT_WORKSPACE, 'disabled'), 'true'); +if (Buffer.from && Buffer.alloc && Buffer.allocUnsafe && Buffer.allocUnsafeSlow) { + module.exports = buffer +} else { + // Copy properties from require('buffer') + copyProps(buffer, exports) + exports.Buffer = SafeBuffer } -exports.markDaemonAsDisabled = markDaemonAsDisabled; -function isDaemonDisabled() { - try { - (0, fs_1.statSync)((0, path_1.join)(exports.DAEMON_DIR_FOR_CURRENT_WORKSPACE, 'disabled')); - return true; - } - catch (e) { - return false; - } + +function SafeBuffer (arg, encodingOrOffset, length) { + return Buffer(arg, encodingOrOffset, length) } -exports.isDaemonDisabled = isDaemonDisabled; -function socketDirName() { - const hasher = (0, crypto_1.createHash)('sha256'); - hasher.update(workspace_root_1.workspaceRoot.toLowerCase()); - const unique = hasher.digest('hex').substring(0, 20); - return (0, path_1.join)(tmp_1.tmpdir, unique); + +SafeBuffer.prototype = Object.create(Buffer.prototype) + +// Copy static methods from Buffer +copyProps(Buffer, SafeBuffer) + +SafeBuffer.from = function (arg, encodingOrOffset, length) { + if (typeof arg === 'number') { + throw new TypeError('Argument must not be a number') + } + return Buffer(arg, encodingOrOffset, length) } -/** - * We try to create a socket file in a tmp dir, but if it doesn't work because - * for instance we don't have permissions, we create it in DAEMON_DIR_FOR_CURRENT_WORKSPACE - */ -function createSocketDir() { - try { - const dir = socketDirName(); - (0, fs_extra_1.ensureDirSync)(dir); - return dir; - } - catch (e) { - return exports.DAEMON_DIR_FOR_CURRENT_WORKSPACE; + +SafeBuffer.alloc = function (size, fill, encoding) { + if (typeof size !== 'number') { + throw new TypeError('Argument must be a number') + } + var buf = Buffer(size) + if (fill !== undefined) { + if (typeof encoding === 'string') { + buf.fill(fill, encoding) + } else { + buf.fill(fill) } + } else { + buf.fill(0) + } + return buf } -function removeSocketDir() { - try { - (0, fs_extra_1.rmdirSync)(socketDir); - } - catch (e) { } + +SafeBuffer.allocUnsafe = function (size) { + if (typeof size !== 'number') { + throw new TypeError('Argument must be a number') + } + return Buffer(size) +} + +SafeBuffer.allocUnsafeSlow = function (size) { + if (typeof size !== 'number') { + throw new TypeError('Argument must be a number') + } + return buffer.SlowBuffer(size) } -exports.removeSocketDir = removeSocketDir; /***/ }), -/***/ 75138: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { +/***/ 14658: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { -"use strict"; +const ANY = Symbol('SemVer ANY') +// hoisted class for cyclic dependency +class Comparator { + static get ANY () { + return ANY + } -Object.defineProperty(exports, "__esModule", ({ value: true })); -exports.printChanges = exports.flushChanges = exports.FsTree = void 0; -const fs_extra_1 = __nccwpck_require__(59511); -const logger_1 = __nccwpck_require__(95324); -const output_1 = __nccwpck_require__(34548); -const path_1 = __nccwpck_require__(71017); -const chalk = __nccwpck_require__(29541); -class FsTree { - constructor(root, isVerbose, logOperationId) { - this.root = root; - this.isVerbose = isVerbose; - this.logOperationId = logOperationId; - this.recordedChanges = {}; - /** - * Signifies if operations on the tree instance - * are allowed. Set to false after changes are written - * to disk, to prevent someone trying to use the tree to update - * files when the tree is no longer effective. - */ - this.locked = false; - } - read(filePath, encoding) { - filePath = this.normalize(filePath); - try { - let content; - if (this.recordedChanges[this.rp(filePath)]) { - content = this.recordedChanges[this.rp(filePath)].content; - } - else { - content = this.fsReadFile(filePath); - } - return encoding ? content.toString(encoding) : content; - } - catch (e) { - if (this.isVerbose) { - logger_1.logger.error(e); - } - return null; - } - } - write(filePath, content, options) { - var _a; - this.assertUnlocked(); - filePath = this.normalize(filePath); - // Remove any recorded changes where a parent directory has been - // deleted when writing a new file within the directory. - let parent = (0, path_1.dirname)(this.rp(filePath)); - while (parent !== '.') { - if ((_a = this.recordedChanges[parent]) === null || _a === void 0 ? void 0 : _a.isDeleted) { - delete this.recordedChanges[parent]; - } - parent = (0, path_1.dirname)(parent); - } - if (this.fsExists(this.rp(filePath)) && - Buffer.from(content).equals(this.fsReadFile(filePath))) { - // Remove recorded change because the file has been restored to it's original contents - delete this.recordedChanges[this.rp(filePath)]; - return; - } - try { - this.recordedChanges[this.rp(filePath)] = { - content: Buffer.from(content), - isDeleted: false, - options, - }; - } - catch (e) { - if (this.isVerbose) { - logger_1.logger.error(e); - } - } - } - overwrite(filePath, content, options) { - filePath = this.normalize(filePath); - this.write(filePath, content, options); - } - delete(filePath) { - this.assertUnlocked(); - filePath = this.normalize(filePath); - if (this.filesForDir(this.rp(filePath)).length > 0) { - this.filesForDir(this.rp(filePath)).forEach((f) => (this.recordedChanges[f] = { content: null, isDeleted: true })); - } - this.recordedChanges[this.rp(filePath)] = { - content: null, - isDeleted: true, - }; - // Delete directory when is not root and there are no children - if (filePath !== '' && - this.children((0, path_1.dirname)(this.rp(filePath))).length < 1) { - this.delete((0, path_1.dirname)(this.rp(filePath))); - } - } - exists(filePath) { - filePath = this.normalize(filePath); - try { - if (this.recordedChanges[this.rp(filePath)]) { - return !this.recordedChanges[this.rp(filePath)].isDeleted; - } - else if (this.filesForDir(this.rp(filePath)).length > 0) { - return true; - } - else { - return this.fsExists(filePath); - } - } - catch (_a) { - return false; - } + constructor (comp, options) { + options = parseOptions(options) + + if (comp instanceof Comparator) { + if (comp.loose === !!options.loose) { + return comp + } else { + comp = comp.value + } } - rename(from, to) { - this.assertUnlocked(); - from = this.normalize(from); - to = this.normalize(to); - if (from === to) { - return; - } - if (this.isFile(from)) { - const content = this.read(this.rp(from)); - this.write(this.rp(to), content); - this.delete(this.rp(from)); - } - else { - for (const child of this.children(from)) { - this.rename((0, path_1.join)(from, child), (0, path_1.join)(to, child)); - } - } + + comp = comp.trim().split(/\s+/).join(' ') + debug('comparator', comp, options) + this.options = options + this.loose = !!options.loose + this.parse(comp) + + if (this.semver === ANY) { + this.value = '' + } else { + this.value = this.operator + this.semver.version } - isFile(filePath) { - filePath = this.normalize(filePath); - try { - if (this.recordedChanges[this.rp(filePath)]) { - return !this.recordedChanges[this.rp(filePath)].isDeleted; - } - else { - return this.fsIsFile(filePath); - } - } - catch (_a) { - return false; - } + + debug('comp', this) + } + + parse (comp) { + const r = this.options.loose ? re[t.COMPARATORLOOSE] : re[t.COMPARATOR] + const m = comp.match(r) + + if (!m) { + throw new TypeError(`Invalid comparator: ${comp}`) } - children(dirPath) { - dirPath = this.normalize(dirPath); - let res = this.fsReadDir(dirPath); - res = [...res, ...this.directChildrenOfDir(this.rp(dirPath))]; - res = res.filter((q) => { - const r = this.recordedChanges[this.normalize((0, path_1.join)(this.rp(dirPath), q))]; - return !(r === null || r === void 0 ? void 0 : r.isDeleted); - }); - // Dedupe - return Array.from(new Set(res)); + + this.operator = m[1] !== undefined ? m[1] : '' + if (this.operator === '=') { + this.operator = '' } - listChanges() { - const res = []; - Object.keys(this.recordedChanges).forEach((f) => { - if (this.recordedChanges[f].isDeleted) { - if (this.fsExists(f)) { - res.push({ path: f, type: 'DELETE', content: null }); - } - } - else { - if (this.fsExists(f)) { - res.push({ - path: f, - type: 'UPDATE', - content: this.recordedChanges[f].content, - options: this.recordedChanges[f].options, - }); - } - else { - res.push({ - path: f, - type: 'CREATE', - content: this.recordedChanges[f].content, - options: this.recordedChanges[f].options, - }); - } - } - }); - return res; + + // if it literally is just '>' or '' then allow anything. + if (!m[2]) { + this.semver = ANY + } else { + this.semver = new SemVer(m[2], this.options.loose) } - changePermissions(filePath, mode) { - this.assertUnlocked(); - filePath = this.normalize(filePath); - const filePathChangeKey = this.rp(filePath); - if (this.recordedChanges[filePathChangeKey]) { - if (this.recordedChanges[filePathChangeKey].isDeleted) { - throw new Error(`Cannot change permissions of deleted file ${filePath}.`); - } - this.recordedChanges[filePathChangeKey].options = { mode }; - } - else if (!this.fsExists(filePath)) { - throw new Error(`Cannot change permissions of non-existing file ${filePath}.`); - } - else if (!this.fsIsFile(filePath)) { - // To fully support directories we'd need to change how we store - // changes to keep a record of directories so we can associate - // permissions to them. - throw new Error(`Cannot change permissions of non-file ${filePath}.`); - } - else { - this.recordedChanges[filePathChangeKey] = { - content: this.fsReadFile(filePath), - isDeleted: false, - options: { mode }, - }; - } + } + + toString () { + return this.value + } + + test (version) { + debug('Comparator.test', version, this.options.loose) + + if (this.semver === ANY || version === ANY) { + return true } - // Marks FsTree as final. - lock() { - this.locked = true; + + if (typeof version === 'string') { + try { + version = new SemVer(version, this.options) + } catch (er) { + return false + } } - assertUnlocked() { - if (this.locked) { - output_1.output.error({ - title: `File changes have already been written to disk. Further changes were attempted ${this.logOperationId ? ` while running ${this.logOperationId}.` : '.'}`, - bodyLines: [ - 'The file system can no longer be modified. This commonly happens when a generator attempts to make further changes in its callback, or an asynchronous operation is still running after the generator completes.', - ], - }); - throw new Error('Tree changed after commit to disk.'); - } + + return cmp(version, this.operator, this.semver, this.options) + } + + intersects (comp, options) { + if (!(comp instanceof Comparator)) { + throw new TypeError('a Comparator is required') } - normalize(path) { - return (0, path_1.relative)(this.root, (0, path_1.join)(this.root, path)).split(path_1.sep).join('/'); + + if (this.operator === '') { + if (this.value === '') { + return true + } + return new Range(comp.value, options).test(this.value) + } else if (comp.operator === '') { + if (comp.value === '') { + return true + } + return new Range(this.value, options).test(comp.semver) } - fsReadDir(dirPath) { - try { - return (0, fs_extra_1.readdirSync)((0, path_1.join)(this.root, dirPath)); - } - catch (_a) { - return []; - } + + options = parseOptions(options) + + // Special cases where nothing can possibly be lower + if (options.includePrerelease && + (this.value === '<0.0.0-0' || comp.value === '<0.0.0-0')) { + return false } - fsIsFile(filePath) { - const stat = (0, fs_extra_1.statSync)((0, path_1.join)(this.root, filePath)); - return stat.isFile(); + if (!options.includePrerelease && + (this.value.startsWith('<0.0.0') || comp.value.startsWith('<0.0.0'))) { + return false } - fsReadFile(filePath) { - return (0, fs_extra_1.readFileSync)((0, path_1.join)(this.root, filePath)); + + // Same direction increasing (> or >=) + if (this.operator.startsWith('>') && comp.operator.startsWith('>')) { + return true } - fsExists(filePath) { - try { - const stat = (0, fs_extra_1.statSync)((0, path_1.join)(this.root, filePath)); - return stat.isFile() || stat.isDirectory(); - } - catch (_a) { - return false; - } + // Same direction decreasing (< or <=) + if (this.operator.startsWith('<') && comp.operator.startsWith('<')) { + return true } - filesForDir(path) { - return Object.keys(this.recordedChanges).filter((f) => f.startsWith(`${path}/`) && !this.recordedChanges[f].isDeleted); + // same SemVer and both sides are inclusive (<= or >=) + if ( + (this.semver.version === comp.semver.version) && + this.operator.includes('=') && comp.operator.includes('=')) { + return true } - directChildrenOfDir(path) { - const res = {}; - if (path === '') { - return Object.keys(this.recordedChanges).map((file) => file.split('/')[0]); - } - Object.keys(this.recordedChanges).forEach((f) => { - if (f.startsWith(`${path}/`)) { - // Remove the current folder's path from the directory - const file = f.substring(path.length + 1); - // Split the path on segments, and take the first one - const basePath = file.split('/')[0]; - // Mark it as a child of the current directory - res[basePath] = true; - } - }); - return Object.keys(res); + // opposite directions less than + if (cmp(this.semver, '<', comp.semver, options) && + this.operator.startsWith('>') && comp.operator.startsWith('<')) { + return true } - rp(pp) { - return pp.startsWith('/') ? pp.substring(1) : pp; + // opposite directions greater than + if (cmp(this.semver, '>', comp.semver, options) && + this.operator.startsWith('<') && comp.operator.startsWith('>')) { + return true } + return false + } } -exports.FsTree = FsTree; -function flushChanges(root, fileChanges) { - fileChanges.forEach((f) => { - var _a, _b; - const fpath = (0, path_1.join)(root, f.path); - if (f.type === 'CREATE') { - (0, fs_extra_1.ensureDirSync)((0, path_1.dirname)(fpath)); - (0, fs_extra_1.writeFileSync)(fpath, f.content); - if ((_a = f.options) === null || _a === void 0 ? void 0 : _a.mode) - (0, fs_extra_1.chmodSync)(fpath, f.options.mode); - } - else if (f.type === 'UPDATE') { - (0, fs_extra_1.writeFileSync)(fpath, f.content); - if ((_b = f.options) === null || _b === void 0 ? void 0 : _b.mode) - (0, fs_extra_1.chmodSync)(fpath, f.options.mode); - } - else if (f.type === 'DELETE') { - (0, fs_extra_1.removeSync)(fpath); - } - }); -} -exports.flushChanges = flushChanges; -function printChanges(fileChanges, indent = '') { - fileChanges.forEach((f) => { - if (f.type === 'CREATE') { - console.log(`${indent}${chalk.green('CREATE')} ${f.path}`); - } - else if (f.type === 'UPDATE') { - console.log(`${indent}${chalk.white('UPDATE')} ${f.path}`); - } - else if (f.type === 'DELETE') { - console.log(`${indent}${chalk.yellow('DELETE')} ${f.path}`); - } - }); -} -exports.printChanges = printChanges; + +module.exports = Comparator + +const parseOptions = __nccwpck_require__(35375) +const { safeRe: re, t } = __nccwpck_require__(49815) +const cmp = __nccwpck_require__(97714) +const debug = __nccwpck_require__(19723) +const SemVer = __nccwpck_require__(93097) +const Range = __nccwpck_require__(70434) /***/ }), -/***/ 55060: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { +/***/ 70434: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { -"use strict"; +// hoisted class for cyclic dependency +class Range { + constructor (range, options) { + options = parseOptions(options) -Object.defineProperty(exports, "__esModule", ({ value: true })); -exports.getWorkspacePath = exports.readWorkspaceConfiguration = exports.isStandaloneProject = exports.updateWorkspaceConfiguration = void 0; -const nx_json_1 = __nccwpck_require__(29931); -// TODO(v16): Remove this -/** - * Update general workspace configuration such as the default project or cli settings. - * - * This does _not_ update projects configuration, use {@link updateProjectConfiguration} or {@link addProjectConfiguration} instead. - * - * @deprecated use updateNxJson - */ -function updateWorkspaceConfiguration(tree, workspaceConfig) { - const { - // Nx Json Properties - cli, defaultProject, generators, implicitDependencies, plugins, pluginsConfig, npmScope, namedInputs, targetDefaults, workspaceLayout, tasksRunnerOptions, affected, extends: ext, installation, } = workspaceConfig; - const nxJson = { - implicitDependencies, - plugins, - pluginsConfig, - npmScope, - namedInputs, - targetDefaults, - workspaceLayout, - tasksRunnerOptions, - affected, - cli, - generators, - defaultProject, - extends: ext, - installation, - }; - (0, nx_json_1.updateNxJson)(tree, nxJson); -} -exports.updateWorkspaceConfiguration = updateWorkspaceConfiguration; -// TODO(v16): Remove this -/** - * Returns if a project has a standalone configuration (project.json). - * - * @param tree - the file system tree - * @param project - the project name - * - * @deprecated non-standalone projects were deprecated - */ -function isStandaloneProject(tree, project) { - return true; -} -exports.isStandaloneProject = isStandaloneProject; -// TODO(v16): Remove this -/** - * Read general workspace configuration such as the default project or cli settings - * - * This does _not_ provide projects configuration, use {@link readProjectConfiguration} instead. - * @deprecated use readNxJson - */ -function readWorkspaceConfiguration(tree) { - return (0, nx_json_1.readNxJson)(tree); -} -exports.readWorkspaceConfiguration = readWorkspaceConfiguration; -// TODO(v16): Remove this -/** - * @deprecated all projects are configured using project.json - */ -function getWorkspacePath(tree) { - if (tree.exists('workspace.json')) - return 'workspace.json'; - if (tree.exists('angular.json')) - return 'angular.json'; - return null; -} -exports.getWorkspacePath = getWorkspacePath; + if (range instanceof Range) { + if ( + range.loose === !!options.loose && + range.includePrerelease === !!options.includePrerelease + ) { + return range + } else { + return new Range(range.raw, options) + } + } + if (range instanceof Comparator) { + // just put it in the set and return + this.raw = range.value + this.set = [[range]] + this.format() + return this + } -/***/ }), + this.options = options + this.loose = !!options.loose + this.includePrerelease = !!options.includePrerelease -/***/ 57038: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { + // First reduce all whitespace as much as possible so we do not have to rely + // on potentially slow regexes like \s*. This is then stored and used for + // future error messages as well. + this.raw = range + .trim() + .split(/\s+/) + .join(' ') -"use strict"; + // First, split on || + this.set = this.raw + .split('||') + // map the range to a 2d array of comparators + .map(r => this.parseRange(r.trim())) + // throw out any comparator lists that are empty + // this generally means that it was not a valid range, which is allowed + // in loose mode, but will still throw if the WHOLE range is invalid. + .filter(c => c.length) -Object.defineProperty(exports, "__esModule", ({ value: true })); -exports.updateJson = exports.writeJson = exports.readJson = void 0; -const json_1 = __nccwpck_require__(43684); -/** - * Reads a json file, removes all comments and parses JSON. - * - * @param tree - file system tree - * @param path - file path - * @param options - Optional JSON Parse Options - */ -function readJson(tree, path, options) { - if (!tree.exists(path)) { - throw new Error(`Cannot find ${path}`); - } - try { - return (0, json_1.parseJson)(tree.read(path, 'utf-8'), options); + if (!this.set.length) { + throw new TypeError(`Invalid SemVer Range: ${this.raw}`) } - catch (e) { - throw new Error(`Cannot parse ${path}: ${e.message}`); + + // if we have any that are not the null set, throw out null sets. + if (this.set.length > 1) { + // keep the first one, in case they're all null sets + const first = this.set[0] + this.set = this.set.filter(c => !isNullSet(c[0])) + if (this.set.length === 0) { + this.set = [first] + } else if (this.set.length > 1) { + // if we have any that are *, then the range is just * + for (const c of this.set) { + if (c.length === 1 && isAny(c[0])) { + this.set = [c] + break + } + } + } } -} -exports.readJson = readJson; -/** - * Writes a JSON value to the file system tree - * @param tree File system tree - * @param path Path of JSON file in the Tree - * @param value Serializable value to write - * @param options Optional JSON Serialize Options - */ -function writeJson(tree, path, value, options) { - tree.write(path, (0, json_1.serializeJson)(value, options)); -} -exports.writeJson = writeJson; -/** - * Updates a JSON value to the file system tree - * - * @param tree File system tree - * @param path Path of JSON file in the Tree - * @param updater Function that maps the current value of a JSON document to a new value to be written to the document - * @param options Optional JSON Parse and Serialize Options - */ -function updateJson(tree, path, updater, options) { - const updatedValue = updater(readJson(tree, path, options)); - writeJson(tree, path, updatedValue, options); -} -exports.updateJson = updateJson; + this.format() + } + format () { + this.range = this.set + .map((comps) => comps.join(' ').trim()) + .join('||') + .trim() + return this.range + } -/***/ }), + toString () { + return this.range + } -/***/ 29931: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { + parseRange (range) { + // memoize range parsing for performance. + // this is a very hot path, and fully deterministic. + const memoOpts = + (this.options.includePrerelease && FLAG_INCLUDE_PRERELEASE) | + (this.options.loose && FLAG_LOOSE) + const memoKey = memoOpts + ':' + range + const cached = cache.get(memoKey) + if (cached) { + return cached + } -"use strict"; + const loose = this.options.loose + // `1.2.3 - 1.2.4` => `>=1.2.3 <=1.2.4` + const hr = loose ? re[t.HYPHENRANGELOOSE] : re[t.HYPHENRANGE] + range = range.replace(hr, hyphenReplace(this.options.includePrerelease)) + debug('hyphen replace', range) -Object.defineProperty(exports, "__esModule", ({ value: true })); -exports.updateNxJson = exports.readNxJson = void 0; -const path_1 = __nccwpck_require__(71017); -const json_1 = __nccwpck_require__(57038); -const file_utils_1 = __nccwpck_require__(93155); -/** - * Reads nx.json - */ -function readNxJson(tree) { - if (tree) { - if (!tree.exists('nx.json')) { - return null; - } - let nxJson = (0, json_1.readJson)(tree, 'nx.json'); - if (nxJson.extends) { - nxJson = Object.assign(Object.assign({}, readNxJsonExtends(tree, nxJson.extends)), nxJson); - } - return nxJson; - } - else { - return (0, file_utils_1.readNxJson)(); - } -} -exports.readNxJson = readNxJson; -/** - * Update nx.json - */ -function updateNxJson(tree, nxJson) { - if (tree.exists('nx.json')) { - (0, json_1.updateJson)(tree, 'nx.json', (json) => { - if (json.extends) { - const nxJsonExtends = readNxJsonExtends(tree, json.extends); - const changedPropsOfNxJson = {}; - Object.keys(nxJson).forEach((prop) => { - if (JSON.stringify(nxJson[prop], null, 2) != - JSON.stringify(nxJsonExtends[prop], null, 2)) { - changedPropsOfNxJson[prop] = nxJson[prop]; - } - }); - return changedPropsOfNxJson; - } - else { - return nxJson; - } - }); - } -} -exports.updateNxJson = updateNxJson; -function readNxJsonExtends(tree, extendsPath) { - try { - return (0, json_1.readJson)(tree, (0, path_1.relative)(tree.root, require.resolve(extendsPath, { - paths: [tree.root], - }))); - } - catch (e) { - throw new Error(`Unable to resolve nx.json extends. Error: ${e.message}`); - } -} + // `> 1.2.3 < 1.2.5` => `>1.2.3 <1.2.5` + range = range.replace(re[t.COMPARATORTRIM], comparatorTrimReplace) + debug('comparator trim', range) + // `~ 1.2.3` => `~1.2.3` + range = range.replace(re[t.TILDETRIM], tildeTrimReplace) + debug('tilde trim', range) -/***/ }), + // `^ 1.2.3` => `^1.2.3` + range = range.replace(re[t.CARETTRIM], caretTrimReplace) + debug('caret trim', range) -/***/ 41172: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { + // At this point, the range is completely trimmed and + // ready to be split into comparators. -"use strict"; + let rangeList = range + .split(' ') + .map(comp => parseComparator(comp, this.options)) + .join(' ') + .split(/\s+/) + // >=0.0.0 is equivalent to * + .map(comp => replaceGTE0(comp, this.options)) -Object.defineProperty(exports, "__esModule", ({ value: true })); -exports.getRelativeProjectJsonSchemaPath = exports.getProjects = exports.readProjectConfiguration = exports.removeProjectConfiguration = exports.updateProjectConfiguration = exports.addProjectConfiguration = exports.getWorkspacePath = exports.isStandaloneProject = exports.updateWorkspaceConfiguration = exports.readWorkspaceConfiguration = exports.updateNxJson = exports.readNxJson = void 0; -const path_1 = __nccwpck_require__(71017); -const workspaces_1 = __nccwpck_require__(98715); -const path_2 = __nccwpck_require__(75878); -const json_1 = __nccwpck_require__(57038); -const nx_json_1 = __nccwpck_require__(29931); -const output_1 = __nccwpck_require__(34548); -const installation_directory_1 = __nccwpck_require__(35075); -var nx_json_2 = __nccwpck_require__(29931); -Object.defineProperty(exports, "readNxJson", ({ enumerable: true, get: function () { return nx_json_2.readNxJson; } })); -Object.defineProperty(exports, "updateNxJson", ({ enumerable: true, get: function () { return nx_json_2.updateNxJson; } })); -var deprecated_1 = __nccwpck_require__(55060); -Object.defineProperty(exports, "readWorkspaceConfiguration", ({ enumerable: true, get: function () { return deprecated_1.readWorkspaceConfiguration; } })); -Object.defineProperty(exports, "updateWorkspaceConfiguration", ({ enumerable: true, get: function () { return deprecated_1.updateWorkspaceConfiguration; } })); -Object.defineProperty(exports, "isStandaloneProject", ({ enumerable: true, get: function () { return deprecated_1.isStandaloneProject; } })); -Object.defineProperty(exports, "getWorkspacePath", ({ enumerable: true, get: function () { return deprecated_1.getWorkspacePath; } })); -/** - * Adds project configuration to the Nx workspace. - * - * @param tree - the file system tree - * @param projectName - unique name. Often directories are part of the name (e.g., mydir-mylib) - * @param projectConfiguration - project configuration - * @param standalone - whether the project is configured in workspace.json or not - */ -function addProjectConfiguration(tree, projectName, projectConfiguration, standalone = true) { - const projectConfigFile = (0, path_2.joinPathFragments)(projectConfiguration.root, 'project.json'); - if (!standalone) { - output_1.output.warn({ - title: 'Nx only supports standalone projects. Setting standalone to false is ignored.', - }); + if (loose) { + // in loose mode, throw out any that are not valid comparators + rangeList = rangeList.filter(comp => { + debug('loose invalid filter', comp, this.options) + return !!comp.match(re[t.COMPARATORLOOSE]) + }) } - if (tree.exists(projectConfigFile)) { - throw new Error(`Cannot create a new project ${projectName} at ${projectConfiguration.root}. It already exists.`); + debug('range list', rangeList) + + // if any comparators are the null set, then replace with JUST null set + // if more than one comparator, remove any * comparators + // also, don't include the same comparator more than once + const rangeMap = new Map() + const comparators = rangeList.map(comp => new Comparator(comp, this.options)) + for (const comp of comparators) { + if (isNullSet(comp)) { + return [comp] + } + rangeMap.set(comp.value, comp) } - delete projectConfiguration.$schema; - (0, json_1.writeJson)(tree, projectConfigFile, Object.assign(Object.assign({ name: projectName, $schema: getRelativeProjectJsonSchemaPath(tree, projectConfiguration) }, projectConfiguration), { root: undefined })); -} -exports.addProjectConfiguration = addProjectConfiguration; -/** - * Updates the configuration of an existing project. - * - * @param tree - the file system tree - * @param projectName - unique name. Often directories are part of the name (e.g., mydir-mylib) - * @param projectConfiguration - project configuration - */ -function updateProjectConfiguration(tree, projectName, projectConfiguration) { - var _a; - const projectConfigFile = (0, path_2.joinPathFragments)(projectConfiguration.root, 'project.json'); - if (!tree.exists(projectConfigFile)) { - throw new Error(`Cannot update Project ${projectName} at ${projectConfiguration.root}. It doesn't exist or uses package.json configuration.`); + if (rangeMap.size > 1 && rangeMap.has('')) { + rangeMap.delete('') } - (0, json_1.writeJson)(tree, projectConfigFile, Object.assign(Object.assign({ name: (_a = projectConfiguration.name) !== null && _a !== void 0 ? _a : projectName, $schema: getRelativeProjectJsonSchemaPath(tree, projectConfiguration) }, projectConfiguration), { root: undefined })); -} -exports.updateProjectConfiguration = updateProjectConfiguration; -/** - * Removes the configuration of an existing project. - * - * @param tree - the file system tree - * @param projectName - unique name. Often directories are part of the name (e.g., mydir-mylib) - */ -function removeProjectConfiguration(tree, projectName) { - const projectConfiguration = readProjectConfiguration(tree, projectName); - if (!projectConfiguration) { - throw new Error(`Cannot delete Project ${projectName}`); + + const result = [...rangeMap.values()] + cache.set(memoKey, result) + return result + } + + intersects (range, options) { + if (!(range instanceof Range)) { + throw new TypeError('a Range is required') } - const projectConfigFile = (0, path_2.joinPathFragments)(projectConfiguration.root, 'project.json'); - if (tree.exists(projectConfigFile)) { - tree.delete(projectConfigFile); + + return this.set.some((thisComparators) => { + return ( + isSatisfiable(thisComparators, options) && + range.set.some((rangeComparators) => { + return ( + isSatisfiable(rangeComparators, options) && + thisComparators.every((thisComparator) => { + return rangeComparators.every((rangeComparator) => { + return thisComparator.intersects(rangeComparator, options) + }) + }) + ) + }) + ) + }) + } + + // if ANY of the sets match ALL of its comparators, then pass + test (version) { + if (!version) { + return false } -} -exports.removeProjectConfiguration = removeProjectConfiguration; -/** - * Reads a project configuration. - * - * @param tree - the file system tree - * @param projectName - unique name. Often directories are part of the name (e.g., mydir-mylib) - * @throws If supplied projectName cannot be found - */ -function readProjectConfiguration(tree, projectName) { - const allProjects = readAndCombineAllProjectConfigurations(tree); - if (!allProjects[projectName]) { - // temporary polyfill to make sure our generators work for existing angularcli workspaces - if (tree.exists('angular.json')) { - const angularJson = toNewFormat((0, json_1.readJson)(tree, 'angular.json')); - if (angularJson.projects[projectName]) - return angularJson.projects[projectName]; - } - throw new Error(`Cannot find configuration for '${projectName}'`); + + if (typeof version === 'string') { + try { + version = new SemVer(version, this.options) + } catch (er) { + return false + } } - return allProjects[projectName]; -} -exports.readProjectConfiguration = readProjectConfiguration; -/** - * Get a map of all projects in a workspace. - * - * Use {@link readProjectConfiguration} if only one project is needed. - */ -function getProjects(tree) { - let allProjects = readAndCombineAllProjectConfigurations(tree); - // temporary polyfill to make sure our generators work for existing angularcli workspaces - if (tree.exists('angular.json')) { - const angularJson = toNewFormat((0, json_1.readJson)(tree, 'angular.json')); - allProjects = Object.assign(Object.assign({}, allProjects), angularJson.projects); + + for (let i = 0; i < this.set.length; i++) { + if (testSet(this.set[i], version, this.options)) { + return true + } } - return new Map(Object.keys(allProjects || {}).map((projectName) => { - return [projectName, allProjects[projectName]]; - })); + return false + } } -exports.getProjects = getProjects; -function getRelativeProjectJsonSchemaPath(tree, project) { - return (0, path_2.normalizePath)((0, path_1.relative)((0, path_1.join)(tree.root, project.root), (0, path_1.join)(tree.root, 'node_modules/nx/schemas/project-schema.json'))); + +module.exports = Range + +const LRU = __nccwpck_require__(17963) +const cache = new LRU({ max: 1000 }) + +const parseOptions = __nccwpck_require__(35375) +const Comparator = __nccwpck_require__(14658) +const debug = __nccwpck_require__(19723) +const SemVer = __nccwpck_require__(93097) +const { + safeRe: re, + t, + comparatorTrimReplace, + tildeTrimReplace, + caretTrimReplace, +} = __nccwpck_require__(49815) +const { FLAG_INCLUDE_PRERELEASE, FLAG_LOOSE } = __nccwpck_require__(96730) + +const isNullSet = c => c.value === '<0.0.0-0' +const isAny = c => c.value === '' + +// take a set of comparators and determine whether there +// exists a version which can satisfy it +const isSatisfiable = (comparators, options) => { + let result = true + const remainingComparators = comparators.slice() + let testComparator = remainingComparators.pop() + + while (result && remainingComparators.length) { + result = remainingComparators.every((otherComparator) => { + return testComparator.intersects(otherComparator, options) + }) + + testComparator = remainingComparators.pop() + } + + return result } -exports.getRelativeProjectJsonSchemaPath = getRelativeProjectJsonSchemaPath; -function readAndCombineAllProjectConfigurations(tree) { - const nxJson = (0, nx_json_1.readNxJson)(tree); - const globbedFiles = (0, workspaces_1.globForProjectFiles)(tree.root, (0, workspaces_1.getGlobPatternsFromPlugins)(nxJson, (0, installation_directory_1.getNxRequirePaths)(tree.root), tree.root), nxJson).map(path_2.normalizePath); - const createdFiles = findCreatedProjectFiles(tree); - const deletedFiles = findDeletedProjectFiles(tree); - const projectFiles = [...globbedFiles, ...createdFiles].filter((r) => deletedFiles.indexOf(r) === -1); - return (0, workspaces_1.buildProjectsConfigurationsFromGlobs)(nxJson, projectFiles, (file) => (0, json_1.readJson)(tree, file)).projects; + +// comprised of xranges, tildes, stars, and gtlt's at this point. +// already replaced the hyphen ranges +// turn into a set of JUST comparators. +const parseComparator = (comp, options) => { + debug('comp', comp, options) + comp = replaceCarets(comp, options) + debug('caret', comp) + comp = replaceTildes(comp, options) + debug('tildes', comp) + comp = replaceXRanges(comp, options) + debug('xrange', comp) + comp = replaceStars(comp, options) + debug('stars', comp) + return comp } -/** - * Used to ensure that projects created during - * the same devkit generator run show up when - * there is no project.json file, as `glob` - * cannot find them. - * - * We exclude the root `package.json` from this list unless - * considered a project during workspace generation - */ -function findCreatedProjectFiles(tree) { - const createdProjectFiles = []; - for (const change of tree.listChanges()) { - if (change.type === 'CREATE') { - const fileName = (0, path_1.basename)(change.path); - // all created project json files are created projects - if (fileName === 'project.json') { - createdProjectFiles.push(change.path); - } - else if (fileName === 'package.json') { - try { - const contents = JSON.parse(change.content.toString()); - if (contents.nx) { - createdProjectFiles.push(change.path); - } - } - catch (_a) { } - } - } + +const isX = id => !id || id.toLowerCase() === 'x' || id === '*' + +// ~, ~> --> * (any, kinda silly) +// ~2, ~2.x, ~2.x.x, ~>2, ~>2.x ~>2.x.x --> >=2.0.0 <3.0.0-0 +// ~2.0, ~2.0.x, ~>2.0, ~>2.0.x --> >=2.0.0 <2.1.0-0 +// ~1.2, ~1.2.x, ~>1.2, ~>1.2.x --> >=1.2.0 <1.3.0-0 +// ~1.2.3, ~>1.2.3 --> >=1.2.3 <1.3.0-0 +// ~1.2.0, ~>1.2.0 --> >=1.2.0 <1.3.0-0 +// ~0.0.1 --> >=0.0.1 <0.1.0-0 +const replaceTildes = (comp, options) => { + return comp + .trim() + .split(/\s+/) + .map((c) => replaceTilde(c, options)) + .join(' ') +} + +const replaceTilde = (comp, options) => { + const r = options.loose ? re[t.TILDELOOSE] : re[t.TILDE] + return comp.replace(r, (_, M, m, p, pr) => { + debug('tilde', comp, _, M, m, p, pr) + let ret + + if (isX(M)) { + ret = '' + } else if (isX(m)) { + ret = `>=${M}.0.0 <${+M + 1}.0.0-0` + } else if (isX(p)) { + // ~1.2 == >=1.2.0 <1.3.0-0 + ret = `>=${M}.${m}.0 <${M}.${+m + 1}.0-0` + } else if (pr) { + debug('replaceTilde pr', pr) + ret = `>=${M}.${m}.${p}-${pr + } <${M}.${+m + 1}.0-0` + } else { + // ~1.2.3 == >=1.2.3 <1.3.0-0 + ret = `>=${M}.${m}.${p + } <${M}.${+m + 1}.0-0` } - return (0, workspaces_1.deduplicateProjectFiles)(createdProjectFiles).map(path_2.normalizePath); + + debug('tilde return', ret) + return ret + }) } -/** - * Used to ensure that projects created during - * the same devkit generator run show up when - * there is no project.json file, as `glob` - * cannot find them. - */ -function findDeletedProjectFiles(tree) { - return tree - .listChanges() - .filter((f) => { - const fileName = (0, path_1.basename)(f.path); - return (f.type === 'DELETE' && - (fileName === 'project.json' || fileName === 'package.json')); - }) - .map((r) => r.path); + +// ^ --> * (any, kinda silly) +// ^2, ^2.x, ^2.x.x --> >=2.0.0 <3.0.0-0 +// ^2.0, ^2.0.x --> >=2.0.0 <3.0.0-0 +// ^1.2, ^1.2.x --> >=1.2.0 <2.0.0-0 +// ^1.2.3 --> >=1.2.3 <2.0.0-0 +// ^1.2.0 --> >=1.2.0 <2.0.0-0 +// ^0.0.1 --> >=0.0.1 <0.0.2-0 +// ^0.1.0 --> >=0.1.0 <0.2.0-0 +const replaceCarets = (comp, options) => { + return comp + .trim() + .split(/\s+/) + .map((c) => replaceCaret(c, options)) + .join(' ') } -function toNewFormat(w) { - const projects = {}; - Object.keys(w.projects || {}).forEach((name) => { - if (typeof w.projects[name] === 'string') - return; - const projectConfig = w.projects[name]; - if (projectConfig.architect) { - (0, workspaces_1.renamePropertyWithStableKeys)(projectConfig, 'architect', 'targets'); + +const replaceCaret = (comp, options) => { + debug('caret', comp, options) + const r = options.loose ? re[t.CARETLOOSE] : re[t.CARET] + const z = options.includePrerelease ? '-0' : '' + return comp.replace(r, (_, M, m, p, pr) => { + debug('caret', comp, _, M, m, p, pr) + let ret + + if (isX(M)) { + ret = '' + } else if (isX(m)) { + ret = `>=${M}.0.0${z} <${+M + 1}.0.0-0` + } else if (isX(p)) { + if (M === '0') { + ret = `>=${M}.${m}.0${z} <${M}.${+m + 1}.0-0` + } else { + ret = `>=${M}.${m}.0${z} <${+M + 1}.0.0-0` + } + } else if (pr) { + debug('replaceCaret pr', pr) + if (M === '0') { + if (m === '0') { + ret = `>=${M}.${m}.${p}-${pr + } <${M}.${m}.${+p + 1}-0` + } else { + ret = `>=${M}.${m}.${p}-${pr + } <${M}.${+m + 1}.0-0` } - if (projectConfig.schematics) { - (0, workspaces_1.renamePropertyWithStableKeys)(projectConfig, 'schematics', 'generators'); + } else { + ret = `>=${M}.${m}.${p}-${pr + } <${+M + 1}.0.0-0` + } + } else { + debug('no pr') + if (M === '0') { + if (m === '0') { + ret = `>=${M}.${m}.${p + }${z} <${M}.${m}.${+p + 1}-0` + } else { + ret = `>=${M}.${m}.${p + }${z} <${M}.${+m + 1}.0-0` } - Object.values(projectConfig.targets || {}).forEach((target) => { - if (target.builder !== undefined) { - (0, workspaces_1.renamePropertyWithStableKeys)(target, 'builder', 'executor'); - } - }); - projects[name] = projectConfig; - }); - w.projects = projects; - if (w.schematics) { - (0, workspaces_1.renamePropertyWithStableKeys)(w, 'schematics', 'generators'); - } - if (w.version !== 2) { - w.version = 2; + } else { + ret = `>=${M}.${m}.${p + } <${+M + 1}.0.0-0` + } } - return w; + + debug('caret return', ret) + return ret + }) } +const replaceXRanges = (comp, options) => { + debug('replaceXRanges', comp, options) + return comp + .split(/\s+/) + .map((c) => replaceXRange(c, options)) + .join(' ') +} -/***/ }), +const replaceXRange = (comp, options) => { + comp = comp.trim() + const r = options.loose ? re[t.XRANGELOOSE] : re[t.XRANGE] + return comp.replace(r, (ret, gtlt, M, m, p, pr) => { + debug('xRange', comp, ret, gtlt, M, m, p, pr) + const xM = isX(M) + const xm = xM || isX(m) + const xp = xm || isX(p) + const anyX = xp -/***/ 94076: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { + if (gtlt === '=' && anyX) { + gtlt = '' + } -"use strict"; + // if we're including prereleases in the match, then we need + // to fix this to -0, the lowest possible prerelease value + pr = options.includePrerelease ? '-0' : '' -Object.defineProperty(exports, "__esModule", ({ value: true })); -exports.FileHasherBase = void 0; -const tslib_1 = __nccwpck_require__(51796); -const perf_hooks_1 = __nccwpck_require__(4074); -class FileHasherBase { - constructor() { - this.isInitialized = false; - } - clear() { - this.fileHashes = new Map(); - this.isInitialized = false; - } - ensureInitialized() { - return tslib_1.__awaiter(this, void 0, void 0, function* () { - if (!this.isInitialized) { - yield this.init(); - } - }); - } - hashFiles(files) { - return tslib_1.__awaiter(this, void 0, void 0, function* () { - const r = new Map(); - for (let f of files) { - r.set(f, this.hashFile(f)); - } - return r; - }); - } - allFileData() { - const res = []; - this.fileHashes.forEach((hash, file) => { - res.push({ - file, - hash, - }); - }); - res.sort((x, y) => x.file.localeCompare(y.file)); - return res; - } - incrementalUpdate(updatedFiles, deletedFiles = []) { - perf_hooks_1.performance.mark('incremental hashing:start'); - updatedFiles.forEach((hash, filename) => { - this.fileHashes.set(filename, hash); - }); - for (const deletedFile of deletedFiles) { - this.fileHashes.delete(deletedFile); + if (xM) { + if (gtlt === '>' || gtlt === '<') { + // nothing is allowed + ret = '<0.0.0-0' + } else { + // nothing is forbidden + ret = '*' + } + } else if (gtlt && anyX) { + // we know patch is an x, because we have any x at all. + // replace X with 0 + if (xm) { + m = 0 + } + p = 0 + + if (gtlt === '>') { + // >1 => >=2.0.0 + // >1.2 => >=1.3.0 + gtlt = '>=' + if (xm) { + M = +M + 1 + m = 0 + p = 0 + } else { + m = +m + 1 + p = 0 + } + } else if (gtlt === '<=') { + // <=0.7.x is actually <0.8.0, since any 0.7.x should + // pass. Similarly, <=7.x is actually <8.0.0, etc. + gtlt = '<' + if (xm) { + M = +M + 1 + } else { + m = +m + 1 } - perf_hooks_1.performance.mark('incremental hashing:end'); - perf_hooks_1.performance.measure('incremental hashing', 'incremental hashing:start', 'incremental hashing:end'); + } + + if (gtlt === '<') { + pr = '-0' + } + + ret = `${gtlt + M}.${m}.${p}${pr}` + } else if (xm) { + ret = `>=${M}.0.0${pr} <${+M + 1}.0.0-0` + } else if (xp) { + ret = `>=${M}.${m}.0${pr + } <${M}.${+m + 1}.0-0` } + + debug('xRange return', ret) + + return ret + }) } -exports.FileHasherBase = FileHasherBase; +// Because * is AND-ed with everything else in the comparator, +// and '' means "any version", just remove the *s entirely. +const replaceStars = (comp, options) => { + debug('replaceStars', comp, options) + // Looseness is ignored here. star is always as loose as it gets! + return comp + .trim() + .replace(re[t.STAR], '') +} -/***/ }), +const replaceGTE0 = (comp, options) => { + debug('replaceGTE0', comp, options) + return comp + .trim() + .replace(re[options.includePrerelease ? t.GTE0PRE : t.GTE0], '') +} -/***/ 43265: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { +// This function is passed to string.replace(re[t.HYPHENRANGE]) +// M, m, patch, prerelease, build +// 1.2 - 3.4.5 => >=1.2.0 <=3.4.5 +// 1.2.3 - 3.4 => >=1.2.0 <3.5.0-0 Any 3.4.x will do +// 1.2 - 3.4 => >=1.2.0 <3.5.0-0 +const hyphenReplace = incPr => ($0, + from, fM, fm, fp, fpr, fb, + to, tM, tm, tp, tpr, tb) => { + if (isX(fM)) { + from = '' + } else if (isX(fm)) { + from = `>=${fM}.0.0${incPr ? '-0' : ''}` + } else if (isX(fp)) { + from = `>=${fM}.${fm}.0${incPr ? '-0' : ''}` + } else if (fpr) { + from = `>=${from}` + } else { + from = `>=${from}${incPr ? '-0' : ''}` + } -"use strict"; + if (isX(tM)) { + to = '' + } else if (isX(tm)) { + to = `<${+tM + 1}.0.0-0` + } else if (isX(tp)) { + to = `<${tM}.${+tm + 1}.0-0` + } else if (tpr) { + to = `<=${tM}.${tm}.${tp}-${tpr}` + } else if (incPr) { + to = `<${tM}.${tm}.${+tp + 1}-0` + } else { + to = `<=${to}` + } -Object.defineProperty(exports, "__esModule", ({ value: true })); -exports.hashArray = exports.fileHasher = exports.getHashingImplementation = exports.HasherImplementation = void 0; -const node_file_hasher_1 = __nccwpck_require__(18638); -const native_file_hasher_1 = __nccwpck_require__(34419); -var HasherImplementation; -(function (HasherImplementation) { - HasherImplementation["Native"] = "Native"; - HasherImplementation["Node"] = "Node"; -})(HasherImplementation = exports.HasherImplementation || (exports.HasherImplementation = {})); -function getHashingImplementation() { - try { - if ((!process.env.NX_NON_NATIVE_HASHER || - process.env.NX_NON_NATIVE_HASHER != 'true') && - native_file_hasher_1.NativeFileHasher.available()) { - return HasherImplementation.Native; - } - return HasherImplementation.Node; - } - catch (_a) { - return HasherImplementation.Node; - } + return `${from} ${to}`.trim() } -exports.getHashingImplementation = getHashingImplementation; -function createFileHasher() { - switch (getHashingImplementation()) { - case HasherImplementation.Native: - return new native_file_hasher_1.NativeFileHasher(); - case HasherImplementation.Node: - return new node_file_hasher_1.NodeFileHasher(); + +const testSet = (set, version, options) => { + for (let i = 0; i < set.length; i++) { + if (!set[i].test(version)) { + return false } -} -function createHashArray() { - switch (getHashingImplementation()) { - case HasherImplementation.Native: - return native_file_hasher_1.nativeHashArray; - case HasherImplementation.Node: - return node_file_hasher_1.nodeHashArray; + } + + if (version.prerelease.length && !options.includePrerelease) { + // Find the set of versions that are allowed to have prereleases + // For example, ^1.2.3-pr.1 desugars to >=1.2.3-pr.1 <2.0.0 + // That should allow `1.2.3-pr.2` to pass. + // However, `1.2.4-alpha.notready` should NOT be allowed, + // even though it's within the range set by the comparators. + for (let i = 0; i < set.length; i++) { + debug(set[i].semver) + if (set[i].semver === Comparator.ANY) { + continue + } + + if (set[i].semver.prerelease.length > 0) { + const allowed = set[i].semver + if (allowed.major === version.major && + allowed.minor === version.minor && + allowed.patch === version.patch) { + return true + } + } } + + // Version has a -pre, but it's not one of the ones we like. + return false + } + + return true } -exports.fileHasher = createFileHasher(); -exports.hashArray = createHashArray(); /***/ }), -/***/ 34419: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { +/***/ 93097: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { -"use strict"; +const debug = __nccwpck_require__(19723) +const { MAX_LENGTH, MAX_SAFE_INTEGER } = __nccwpck_require__(96730) +const { safeRe: re, t } = __nccwpck_require__(49815) -Object.defineProperty(exports, "__esModule", ({ value: true })); -exports.nativeHashArray = exports.NativeFileHasher = void 0; -const tslib_1 = __nccwpck_require__(51796); -const file_hasher_base_1 = __nccwpck_require__(94076); -const perf_hooks_1 = __nccwpck_require__(4074); -const workspace_root_1 = __nccwpck_require__(65766); -class NativeFileHasher extends file_hasher_base_1.FileHasherBase { - static available() { - try { - __nccwpck_require__(78176); - return true; - } - catch (_a) { - return false; - } +const parseOptions = __nccwpck_require__(35375) +const { compareIdentifiers } = __nccwpck_require__(67701) +class SemVer { + constructor (version, options) { + options = parseOptions(options) + + if (version instanceof SemVer) { + if (version.loose === !!options.loose && + version.includePrerelease === !!options.includePrerelease) { + return version + } else { + version = version.version + } + } else if (typeof version !== 'string') { + throw new TypeError(`Invalid version. Must be a string. Got type "${typeof version}".`) } - init() { - return tslib_1.__awaiter(this, void 0, void 0, function* () { - perf_hooks_1.performance.mark('init hashing:start'); - // Import as needed. There is also an issue running unit tests in Nx repo if this is a top-level import. - const { hashFiles } = __nccwpck_require__(78176); - this.clear(); - const filesObject = hashFiles(workspace_root_1.workspaceRoot); - this.fileHashes = new Map(Object.entries(filesObject)); - perf_hooks_1.performance.mark('init hashing:end'); - perf_hooks_1.performance.measure('init hashing', 'init hashing:start', 'init hashing:end'); - }); + + if (version.length > MAX_LENGTH) { + throw new TypeError( + `version is longer than ${MAX_LENGTH} characters` + ) } - hashFile(path) { - // Import as needed. There is also an issue running unit tests in Nx repo if this is a top-level import. - const { hashFile } = __nccwpck_require__(78176); - return hashFile(path).hash; + + debug('SemVer', version, options) + this.options = options + this.loose = !!options.loose + // this isn't actually relevant for versions, but keep it so that we + // don't run into trouble passing this.options around. + this.includePrerelease = !!options.includePrerelease + + const m = version.trim().match(options.loose ? re[t.LOOSE] : re[t.FULL]) + + if (!m) { + throw new TypeError(`Invalid Version: ${version}`) } -} -exports.NativeFileHasher = NativeFileHasher; -function nativeHashArray(input) { - // Import as needed. There is also an issue running unit tests in Nx repo if this is a top-level import. - const { hashArray } = __nccwpck_require__(78176); - return hashArray(input); -} -exports.nativeHashArray = nativeHashArray; + this.raw = version -/***/ }), + // these are actually numbers + this.major = +m[1] + this.minor = +m[2] + this.patch = +m[3] -/***/ 18638: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { + if (this.major > MAX_SAFE_INTEGER || this.major < 0) { + throw new TypeError('Invalid major version') + } -"use strict"; + if (this.minor > MAX_SAFE_INTEGER || this.minor < 0) { + throw new TypeError('Invalid minor version') + } -Object.defineProperty(exports, "__esModule", ({ value: true })); -exports.nodeHashArray = exports.NodeFileHasher = void 0; -const tslib_1 = __nccwpck_require__(51796); -const workspace_root_1 = __nccwpck_require__(65766); -const perf_hooks_1 = __nccwpck_require__(4074); -const path_1 = __nccwpck_require__(71017); -const fs_1 = __nccwpck_require__(57147); -const file_hasher_base_1 = __nccwpck_require__(94076); -const strip_indents_1 = __nccwpck_require__(4477); -const path_2 = __nccwpck_require__(75878); -const ignore_1 = __nccwpck_require__(98845); -const path_3 = __nccwpck_require__(75878); -const crypto_1 = __nccwpck_require__(6113); -class NodeFileHasher extends file_hasher_base_1.FileHasherBase { - constructor() { - super(...arguments); - this.ignoredGlobs = getIgnoredGlobs(); - } - init() { - return tslib_1.__awaiter(this, void 0, void 0, function* () { - perf_hooks_1.performance.mark('init hashing:start'); - this.clear(); - this.allFilesInDir(workspace_root_1.workspaceRoot, true); - perf_hooks_1.performance.mark('init hashing:end'); - perf_hooks_1.performance.measure('init hashing', 'init hashing:start', 'init hashing:end'); - }); + if (this.patch > MAX_SAFE_INTEGER || this.patch < 0) { + throw new TypeError('Invalid patch version') } - allFilesInDir(absoluteDirName, recurse = true) { - const relDirName = (0, path_1.relative)(workspace_root_1.workspaceRoot, absoluteDirName); - if (relDirName && this.ignoredGlobs.ignores(relDirName)) { - return; - } - try { - (0, fs_1.readdirSync)(absoluteDirName).forEach((c) => { - const absoluteChild = (0, path_1.join)(absoluteDirName, c); - const relChild = (0, path_1.relative)(workspace_root_1.workspaceRoot, absoluteChild); - if (this.ignoredGlobs.ignores(relChild)) { - return; - } - try { - const s = (0, fs_1.statSync)(absoluteChild); - if (s.isFile()) { - this.fileHashes.set((0, path_2.normalizePath)(relChild), this.hashFile(relChild)); - } - else if (s.isDirectory() && recurse) { - this.allFilesInDir(absoluteChild, true); - } - } - catch (_a) { } - }); + + // numberify any prerelease numeric ids + if (!m[4]) { + this.prerelease = [] + } else { + this.prerelease = m[4].split('.').map((id) => { + if (/^[0-9]+$/.test(id)) { + const num = +id + if (num >= 0 && num < MAX_SAFE_INTEGER) { + return num + } } - catch (_a) { } + return id + }) } - hashFile(path) { - if (!this.fileHashes) { - throw new Error('FileHasher is invoked before being initialized'); - } - const relativePath = (0, path_2.normalizePath)(path.startsWith(workspace_root_1.workspaceRoot) - ? path.slice(workspace_root_1.workspaceRoot.length + 1) - : path); - try { - // this has to be absolute to avoid issues with cwd - return this.hashContent((0, fs_1.readFileSync)((0, path_3.joinPathFragments)(workspace_root_1.workspaceRoot, relativePath))); - } - catch (_a) { - return ''; - } + + this.build = m[5] ? m[5].split('.') : [] + this.format() + } + + format () { + this.version = `${this.major}.${this.minor}.${this.patch}` + if (this.prerelease.length) { + this.version += `-${this.prerelease.join('.')}` } - hashContent(content) { - const hasher = (0, crypto_1.createHash)('sha256'); - hasher.update(content); - return hasher.digest('hex'); + return this.version + } + + toString () { + return this.version + } + + compare (other) { + debug('SemVer.compare', this.version, this.options, other) + if (!(other instanceof SemVer)) { + if (typeof other === 'string' && other === this.version) { + return 0 + } + other = new SemVer(other, this.options) } -} -exports.NodeFileHasher = NodeFileHasher; -function nodeHashArray(input) { - const hasher = (0, crypto_1.createHash)('sha256'); - for (const part of input) { - // intentional single equals to check for null and undefined - if (part != undefined) { - hasher.update(part); - } - } - return hasher.digest('hex'); -} -exports.nodeHashArray = nodeHashArray; -function getIgnoredGlobs() { - const ig = (0, ignore_1.getIgnoreObject)(); - ig.add((0, strip_indents_1.stripIndents) ` - node_modules - tmp - dist - build - `); - return ig; -} + if (other.version === this.version) { + return 0 + } -/***/ }), + return this.compareMain(other) || this.comparePre(other) + } -/***/ 78176: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + compareMain (other) { + if (!(other instanceof SemVer)) { + other = new SemVer(other, this.options) + } -const { existsSync, readFileSync } = __nccwpck_require__(57147) -const { join } = __nccwpck_require__(71017) + return ( + compareIdentifiers(this.major, other.major) || + compareIdentifiers(this.minor, other.minor) || + compareIdentifiers(this.patch, other.patch) + ) + } -const { platform, arch } = process + comparePre (other) { + if (!(other instanceof SemVer)) { + other = new SemVer(other, this.options) + } -let nativeBinding = null -let localFileExisted = false -let loadError = null + // NOT having a prerelease is > having one + if (this.prerelease.length && !other.prerelease.length) { + return -1 + } else if (!this.prerelease.length && other.prerelease.length) { + return 1 + } else if (!this.prerelease.length && !other.prerelease.length) { + return 0 + } -function isMusl() { - // For Node 10 - if (!process.report || typeof process.report.getReport !== 'function') { - try { - const lddPath = (__nccwpck_require__(32081).execSync)('which ldd').toString().trim(); - return readFileSync(lddPath, 'utf8').includes('musl') - } catch (e) { - return true + let i = 0 + do { + const a = this.prerelease[i] + const b = other.prerelease[i] + debug('prerelease compare', i, a, b) + if (a === undefined && b === undefined) { + return 0 + } else if (b === undefined) { + return 1 + } else if (a === undefined) { + return -1 + } else if (a === b) { + continue + } else { + return compareIdentifiers(a, b) + } + } while (++i) + } + + compareBuild (other) { + if (!(other instanceof SemVer)) { + other = new SemVer(other, this.options) } - } else { - const { glibcVersionRuntime } = process.report.getReport().header - return !glibcVersionRuntime + + let i = 0 + do { + const a = this.build[i] + const b = other.build[i] + debug('prerelease compare', i, a, b) + if (a === undefined && b === undefined) { + return 0 + } else if (b === undefined) { + return 1 + } else if (a === undefined) { + return -1 + } else if (a === b) { + continue + } else { + return compareIdentifiers(a, b) + } + } while (++i) } -} -switch (platform) { - case 'android': - switch (arch) { - case 'arm64': - localFileExisted = existsSync(join(__dirname, 'nx.android-arm64.node')) - try { - if (localFileExisted) { - nativeBinding = __nccwpck_require__(68615) - } else { - nativeBinding = __nccwpck_require__(96024) - } - } catch (e) { - loadError = e - } + // preminor will bump the version up to the next minor release, and immediately + // down to pre-release. premajor and prepatch work the same way. + inc (release, identifier, identifierBase) { + switch (release) { + case 'premajor': + this.prerelease.length = 0 + this.patch = 0 + this.minor = 0 + this.major++ + this.inc('pre', identifier, identifierBase) break - case 'arm': - localFileExisted = existsSync(join(__dirname, 'nx.android-arm-eabi.node')) - try { - if (localFileExisted) { - nativeBinding = __nccwpck_require__(3479) - } else { - nativeBinding = __nccwpck_require__(63182) - } - } catch (e) { - loadError = e - } + case 'preminor': + this.prerelease.length = 0 + this.patch = 0 + this.minor++ + this.inc('pre', identifier, identifierBase) break - default: - throw new Error(`Unsupported architecture on Android ${arch}`) - } - break - case 'win32': - switch (arch) { - case 'x64': - localFileExisted = existsSync( - join(__dirname, 'nx.win32-x64-msvc.node') - ) - try { - if (localFileExisted) { - nativeBinding = __nccwpck_require__(23186) - } else { - nativeBinding = __nccwpck_require__(37840) - } - } catch (e) { - loadError = e - } + case 'prepatch': + // If this is already a prerelease, it will bump to the next version + // drop any prereleases that might already exist, since they are not + // relevant at this point. + this.prerelease.length = 0 + this.inc('patch', identifier, identifierBase) + this.inc('pre', identifier, identifierBase) break - case 'ia32': - localFileExisted = existsSync( - join(__dirname, 'nx.win32-ia32-msvc.node') - ) - try { - if (localFileExisted) { - nativeBinding = __nccwpck_require__(75836) - } else { - nativeBinding = __nccwpck_require__(75323) - } - } catch (e) { - loadError = e + // If the input is a non-prerelease version, this acts the same as + // prepatch. + case 'prerelease': + if (this.prerelease.length === 0) { + this.inc('patch', identifier, identifierBase) } + this.inc('pre', identifier, identifierBase) break - case 'arm64': - localFileExisted = existsSync( - join(__dirname, 'nx.win32-arm64-msvc.node') - ) - try { - if (localFileExisted) { - nativeBinding = __nccwpck_require__(80491) - } else { - nativeBinding = __nccwpck_require__(48358) - } - } catch (e) { - loadError = e + + case 'major': + // If this is a pre-major version, bump up to the same major version. + // Otherwise increment major. + // 1.0.0-5 bumps to 1.0.0 + // 1.1.0 bumps to 2.0.0 + if ( + this.minor !== 0 || + this.patch !== 0 || + this.prerelease.length === 0 + ) { + this.major++ } + this.minor = 0 + this.patch = 0 + this.prerelease = [] break - default: - throw new Error(`Unsupported architecture on Windows: ${arch}`) - } - break - case 'darwin': - localFileExisted = existsSync(join(__dirname, 'nx.darwin-universal.node')) - try { - if (localFileExisted) { - nativeBinding = __nccwpck_require__(99829) - } else { - nativeBinding = __nccwpck_require__(51641) - } - break - } catch {} - switch (arch) { - case 'x64': - localFileExisted = existsSync(join(__dirname, 'nx.darwin-x64.node')) - try { - if (localFileExisted) { - nativeBinding = __nccwpck_require__(79412) - } else { - nativeBinding = __nccwpck_require__(85775) - } - } catch (e) { - loadError = e + case 'minor': + // If this is a pre-minor version, bump up to the same minor version. + // Otherwise increment minor. + // 1.2.0-5 bumps to 1.2.0 + // 1.2.1 bumps to 1.3.0 + if (this.patch !== 0 || this.prerelease.length === 0) { + this.minor++ } + this.patch = 0 + this.prerelease = [] break - case 'arm64': - localFileExisted = existsSync( - join(__dirname, 'nx.darwin-arm64.node') - ) - try { - if (localFileExisted) { - nativeBinding = __nccwpck_require__(64639) - } else { - nativeBinding = __nccwpck_require__(10498) - } - } catch (e) { - loadError = e + case 'patch': + // If this is not a pre-release version, it will increment the patch. + // If it is a pre-release it will bump up to the same patch version. + // 1.2.0-5 patches to 1.2.0 + // 1.2.0 patches to 1.2.1 + if (this.prerelease.length === 0) { + this.patch++ } + this.prerelease = [] break - default: - throw new Error(`Unsupported architecture on macOS: ${arch}`) - } - break - case 'freebsd': - if (arch !== 'x64') { - throw new Error(`Unsupported architecture on FreeBSD: ${arch}`) - } - localFileExisted = existsSync(join(__dirname, 'nx.freebsd-x64.node')) - try { - if (localFileExisted) { - nativeBinding = __nccwpck_require__(7678) - } else { - nativeBinding = __nccwpck_require__(64160) - } - } catch (e) { - loadError = e - } - break - case 'linux': - switch (arch) { - case 'x64': - if (isMusl()) { - localFileExisted = existsSync( - join(__dirname, 'nx.linux-x64-musl.node') - ) - try { - if (localFileExisted) { - nativeBinding = __nccwpck_require__(67479) - } else { - nativeBinding = __nccwpck_require__(93490) + // This probably shouldn't be used publicly. + // 1.0.0 'pre' would become 1.0.0-0 which is the wrong direction. + case 'pre': { + const base = Number(identifierBase) ? 1 : 0 + + if (!identifier && identifierBase === false) { + throw new Error('invalid increment argument: identifier is empty') + } + + if (this.prerelease.length === 0) { + this.prerelease = [base] + } else { + let i = this.prerelease.length + while (--i >= 0) { + if (typeof this.prerelease[i] === 'number') { + this.prerelease[i]++ + i = -2 } - } catch (e) { - loadError = e } - } else { - localFileExisted = existsSync( - join(__dirname, 'nx.linux-x64-gnu.node') - ) - try { - if (localFileExisted) { - nativeBinding = __nccwpck_require__(46888) - } else { - nativeBinding = __nccwpck_require__(94444) + if (i === -1) { + // didn't increment anything + if (identifier === this.prerelease.join('.') && identifierBase === false) { + throw new Error('invalid increment argument: identifier already exists') } - } catch (e) { - loadError = e + this.prerelease.push(base) } } - break - case 'arm64': - if (isMusl()) { - localFileExisted = existsSync( - join(__dirname, 'nx.linux-arm64-musl.node') - ) - try { - if (localFileExisted) { - nativeBinding = __nccwpck_require__(32938) - } else { - nativeBinding = __nccwpck_require__(67311) - } - } catch (e) { - loadError = e + if (identifier) { + // 1.2.0-beta.1 bumps to 1.2.0-beta.2, + // 1.2.0-beta.fooblz or 1.2.0-beta bumps to 1.2.0-beta.0 + let prerelease = [identifier, base] + if (identifierBase === false) { + prerelease = [identifier] } - } else { - localFileExisted = existsSync( - join(__dirname, 'nx.linux-arm64-gnu.node') - ) - try { - if (localFileExisted) { - nativeBinding = __nccwpck_require__(90179) - } else { - nativeBinding = __nccwpck_require__(36708) + if (compareIdentifiers(this.prerelease[0], identifier) === 0) { + if (isNaN(this.prerelease[1])) { + this.prerelease = prerelease } - } catch (e) { - loadError = e - } - } - break - case 'arm': - localFileExisted = existsSync( - join(__dirname, 'nx.linux-arm-gnueabihf.node') - ) - try { - if (localFileExisted) { - nativeBinding = __nccwpck_require__(50050) } else { - nativeBinding = __nccwpck_require__(8429) + this.prerelease = prerelease } - } catch (e) { - loadError = e } break + } default: - throw new Error(`Unsupported architecture on Linux: ${arch}`) + throw new Error(`invalid increment argument: ${release}`) } - break - default: - throw new Error(`Unsupported OS: ${platform}, architecture: ${arch}`) -} - -if (!nativeBinding) { - if (loadError) { - throw loadError + this.raw = this.format() + if (this.build.length) { + this.raw += `+${this.build.join('.')}` + } + return this } - throw new Error(`Failed to load native binding`) } -const { hashArray, hashFile, hashFiles } = nativeBinding +module.exports = SemVer -module.exports.hashArray = hashArray -module.exports.hashFile = hashFile -module.exports.hashFiles = hashFiles + +/***/ }), + +/***/ 30262: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + +const parse = __nccwpck_require__(13857) +const clean = (version, options) => { + const s = parse(version.trim().replace(/^[=v]+/, ''), options) + return s ? s.version : null +} +module.exports = clean /***/ }), -/***/ 71777: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { +/***/ 97714: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { -"use strict"; +const eq = __nccwpck_require__(68537) +const neq = __nccwpck_require__(89176) +const gt = __nccwpck_require__(71381) +const gte = __nccwpck_require__(52498) +const lt = __nccwpck_require__(75330) +const lte = __nccwpck_require__(84698) -Object.defineProperty(exports, "__esModule", ({ value: true })); -exports.processProjectGraph = void 0; -const tslib_1 = __nccwpck_require__(51796); -const project_graph_builder_1 = __nccwpck_require__(14812); -const build_dependencies_1 = __nccwpck_require__(89977); -const configuration_1 = __nccwpck_require__(65459); -const fileutils_1 = __nccwpck_require__(47930); -const lock_file_1 = __nccwpck_require__(88740); -const path_1 = __nccwpck_require__(71017); -const cache_directory_1 = __nccwpck_require__(20858); -const fs_1 = __nccwpck_require__(57147); -const workspace_root_1 = __nccwpck_require__(65766); -const fs_extra_1 = __nccwpck_require__(59511); -const processProjectGraph = (graph, context) => tslib_1.__awaiter(void 0, void 0, void 0, function* () { - const builder = new project_graph_builder_1.ProjectGraphBuilder(graph, context.fileMap); - const pluginConfig = jsPluginConfig((0, configuration_1.readNxJson)()); - if (pluginConfig.analyzePackageJson) { - // during the create-nx-workspace lock file might not exists yet - if ((0, lock_file_1.lockFileExists)()) { - const lockHash = (0, lock_file_1.lockFileHash)(); - let parsedLockFile; - if (lockFileNeedsReprocessing(lockHash)) { - parsedLockFile = (0, lock_file_1.parseLockFile)(); - writeLastProcessedLockfileHash(lockHash, parsedLockFile); - } - else { - parsedLockFile = readParsedLockFile(); - } - builder.mergeProjectGraph(parsedLockFile); - } - } - yield (0, build_dependencies_1.buildExplicitDependencies)(pluginConfig, context, builder); - return builder.getUpdatedProjectGraph(); -}); -exports.processProjectGraph = processProjectGraph; -const lockFileHashFile = (0, path_1.join)(cache_directory_1.projectGraphCacheDirectory, 'lockfile.hash'); -const parsedLockFile = (0, path_1.join)(cache_directory_1.projectGraphCacheDirectory, 'parsed-lock-file.json'); -function lockFileNeedsReprocessing(lockHash) { - try { - return (0, fs_1.readFileSync)(lockFileHashFile).toString() !== lockHash; - } - catch (_a) { - return true; - } -} -function writeLastProcessedLockfileHash(hash, lockFile) { - (0, fs_extra_1.ensureDirSync)((0, path_1.dirname)(lockFileHashFile)); - (0, fs_1.writeFileSync)(parsedLockFile, JSON.stringify(lockFile, null, 2)); - (0, fs_1.writeFileSync)(lockFileHashFile, hash); -} -function readParsedLockFile() { - return JSON.parse((0, fs_1.readFileSync)(parsedLockFile).toString()); -} -function jsPluginConfig(nxJson) { - var _a, _b, _c; - const nxJsonConfig = (_b = (_a = nxJson === null || nxJson === void 0 ? void 0 : nxJson.pluginsConfig) === null || _a === void 0 ? void 0 : _a['@nx/js']) !== null && _b !== void 0 ? _b : (_c = nxJson === null || nxJson === void 0 ? void 0 : nxJson.pluginsConfig) === null || _c === void 0 ? void 0 : _c['@nrwl/js']; - if (nxJsonConfig) { - return Object.assign({ analyzePackageJson: true, analyzeSourceFiles: true }, nxJsonConfig); - } - if (!(0, fileutils_1.fileExists)((0, path_1.join)(workspace_root_1.workspaceRoot, 'package.json'))) { - return { - analyzePackageJson: false, - analyzeSourceFiles: false, - }; - } - const packageJson = (0, fileutils_1.readJsonFile)((0, path_1.join)(workspace_root_1.workspaceRoot, 'package.json')); - const packageJsonDeps = Object.assign(Object.assign({}, packageJson.dependencies), packageJson.devDependencies); - if (packageJsonDeps['@nx/workspace'] || - packageJsonDeps['@nx/js'] || - packageJsonDeps['@nx/node'] || - packageJsonDeps['@nx/next'] || - packageJsonDeps['@nx/react'] || - packageJsonDeps['@nx/angular'] || - packageJsonDeps['@nx/web'] || - packageJsonDeps['@nrwl/workspace'] || - packageJsonDeps['@nrwl/js'] || - packageJsonDeps['@nrwl/node'] || - packageJsonDeps['@nrwl/next'] || - packageJsonDeps['@nrwl/react'] || - packageJsonDeps['@nrwl/angular'] || - packageJsonDeps['@nrwl/web']) { - return { analyzePackageJson: true, analyzeSourceFiles: true }; - } - else { - return { analyzePackageJson: true, analyzeSourceFiles: false }; - } +const cmp = (a, op, b, loose) => { + switch (op) { + case '===': + if (typeof a === 'object') { + a = a.version + } + if (typeof b === 'object') { + b = b.version + } + return a === b + + case '!==': + if (typeof a === 'object') { + a = a.version + } + if (typeof b === 'object') { + b = b.version + } + return a !== b + + case '': + case '=': + case '==': + return eq(a, b, loose) + + case '!=': + return neq(a, b, loose) + + case '>': + return gt(a, b, loose) + + case '>=': + return gte(a, b, loose) + + case '<': + return lt(a, b, loose) + + case '<=': + return lte(a, b, loose) + + default: + throw new TypeError(`Invalid operator: ${op}`) + } } +module.exports = cmp /***/ }), -/***/ 88740: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { +/***/ 93292: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { -"use strict"; +const SemVer = __nccwpck_require__(93097) +const parse = __nccwpck_require__(13857) +const { safeRe: re, t } = __nccwpck_require__(49815) -/** - * This is the main API for accessing the lock file functionality. - * It encapsulates the package manager specific logic and implementation details. - */ -Object.defineProperty(exports, "__esModule", ({ value: true })); -exports.createLockFile = exports.getLockFileName = exports.parseLockFile = exports.lockFileHash = exports.lockFileExists = void 0; -const fs_1 = __nccwpck_require__(57147); -const path_1 = __nccwpck_require__(71017); -const package_manager_1 = __nccwpck_require__(15425); -const workspace_root_1 = __nccwpck_require__(65766); -const project_graph_builder_1 = __nccwpck_require__(14812); -const impl_1 = __nccwpck_require__(43265); -const output_1 = __nccwpck_require__(34548); -const npm_parser_1 = __nccwpck_require__(695); -const pnpm_parser_1 = __nccwpck_require__(93369); -const yarn_parser_1 = __nccwpck_require__(33875); -const project_graph_pruning_1 = __nccwpck_require__(38770); -const package_json_1 = __nccwpck_require__(6500); -const YARN_LOCK_FILE = 'yarn.lock'; -const NPM_LOCK_FILE = 'package-lock.json'; -const PNPM_LOCK_FILE = 'pnpm-lock.yaml'; -const YARN_LOCK_PATH = (0, path_1.join)(workspace_root_1.workspaceRoot, YARN_LOCK_FILE); -const NPM_LOCK_PATH = (0, path_1.join)(workspace_root_1.workspaceRoot, NPM_LOCK_FILE); -const PNPM_LOCK_PATH = (0, path_1.join)(workspace_root_1.workspaceRoot, PNPM_LOCK_FILE); -/** - * Check if lock file exists - */ -function lockFileExists(packageManager = (0, package_manager_1.detectPackageManager)(workspace_root_1.workspaceRoot)) { - if (packageManager === 'yarn') { - return (0, fs_1.existsSync)(YARN_LOCK_PATH); - } - if (packageManager === 'pnpm') { - return (0, fs_1.existsSync)(PNPM_LOCK_PATH); - } - if (packageManager === 'npm') { - return (0, fs_1.existsSync)(NPM_LOCK_PATH); - } - throw new Error(`Unknown package manager ${packageManager} or lock file missing`); -} -exports.lockFileExists = lockFileExists; -/** - * Hashes lock file content - */ -function lockFileHash(packageManager = (0, package_manager_1.detectPackageManager)(workspace_root_1.workspaceRoot)) { - let content; - if (packageManager === 'yarn') { - content = (0, fs_1.readFileSync)(YARN_LOCK_PATH, 'utf8'); - } - if (packageManager === 'pnpm') { - content = (0, fs_1.readFileSync)(PNPM_LOCK_PATH, 'utf8'); - } - if (packageManager === 'npm') { - content = (0, fs_1.readFileSync)(NPM_LOCK_PATH, 'utf8'); - } - if (content) { - return (0, impl_1.hashArray)([content]); - } - else { - throw new Error(`Unknown package manager ${packageManager} or lock file missing`); - } -} -exports.lockFileHash = lockFileHash; -/** - * Parses lock file and maps dependencies and metadata to {@link LockFileGraph} - */ -function parseLockFile(packageManager = (0, package_manager_1.detectPackageManager)(workspace_root_1.workspaceRoot)) { - const builder = new project_graph_builder_1.ProjectGraphBuilder(null, null); - try { - if (packageManager === 'yarn') { - const content = (0, fs_1.readFileSync)(YARN_LOCK_PATH, 'utf8'); - (0, yarn_parser_1.parseYarnLockfile)(content, builder); - return builder.getUpdatedProjectGraph(); - } - if (packageManager === 'pnpm') { - const content = (0, fs_1.readFileSync)(PNPM_LOCK_PATH, 'utf8'); - (0, pnpm_parser_1.parsePnpmLockfile)(content, builder); - return builder.getUpdatedProjectGraph(); - } - if (packageManager === 'npm') { - const content = (0, fs_1.readFileSync)(NPM_LOCK_PATH, 'utf8'); - (0, npm_parser_1.parseNpmLockfile)(content, builder); - return builder.getUpdatedProjectGraph(); - } - } - catch (e) { - if (!isPostInstallProcess()) { - output_1.output.error({ - title: `Failed to parse ${packageManager} lockfile`, - bodyLines: errorBodyLines(e), - }); - } - return; - } - throw new Error(`Unknown package manager: ${packageManager}`); -} -exports.parseLockFile = parseLockFile; -/** - * Returns lock file name based on the detected package manager in the root - * @param packageManager - * @returns - */ -function getLockFileName(packageManager = (0, package_manager_1.detectPackageManager)(workspace_root_1.workspaceRoot)) { - if (packageManager === 'yarn') { - return YARN_LOCK_FILE; - } - if (packageManager === 'pnpm') { - return PNPM_LOCK_FILE; - } - if (packageManager === 'npm') { - return NPM_LOCK_FILE; - } - throw new Error(`Unknown package manager: ${packageManager}`); -} -exports.getLockFileName = getLockFileName; -/** - * Create lock file based on the root level lock file and (pruned) package.json - * - * @param packageJson - * @param isProduction - * @param packageManager - * @returns - */ -function createLockFile(packageJson, packageManager = (0, package_manager_1.detectPackageManager)(workspace_root_1.workspaceRoot)) { - const normalizedPackageJson = (0, package_json_1.normalizePackageJson)(packageJson); - const content = (0, fs_1.readFileSync)(getLockFileName(packageManager), 'utf8'); - const builder = new project_graph_builder_1.ProjectGraphBuilder(); - try { - if (packageManager === 'yarn') { - (0, yarn_parser_1.parseYarnLockfile)(content, builder); - const graph = builder.getUpdatedProjectGraph(); - const prunedGraph = (0, project_graph_pruning_1.pruneProjectGraph)(graph, packageJson); - return (0, yarn_parser_1.stringifyYarnLockfile)(prunedGraph, content, normalizedPackageJson); - } - if (packageManager === 'pnpm') { - (0, pnpm_parser_1.parsePnpmLockfile)(content, builder); - const graph = builder.getUpdatedProjectGraph(); - const prunedGraph = (0, project_graph_pruning_1.pruneProjectGraph)(graph, packageJson); - return (0, pnpm_parser_1.stringifyPnpmLockfile)(prunedGraph, content, normalizedPackageJson); - } - if (packageManager === 'npm') { - (0, npm_parser_1.parseNpmLockfile)(content, builder); - const graph = builder.getUpdatedProjectGraph(); - const prunedGraph = (0, project_graph_pruning_1.pruneProjectGraph)(graph, packageJson); - return (0, npm_parser_1.stringifyNpmLockfile)(prunedGraph, content, normalizedPackageJson); - } - } - catch (e) { - if (!isPostInstallProcess()) { - const additionalInfo = [ - 'To prevent the build from breaking we are returning the root lock file.', - ]; - if (packageManager === 'npm') { - additionalInfo.push('If you run `npm install --package-lock-only` in your output folder it will regenerate the correct pruned lockfile.'); - } - if (packageManager === 'pnpm') { - additionalInfo.push('If you run `pnpm install --lockfile-only` in your output folder it will regenerate the correct pruned lockfile.'); - } - output_1.output.error({ - title: 'An error occured while creating pruned lockfile', - bodyLines: errorBodyLines(e, additionalInfo), - }); - } - return content; +const coerce = (version, options) => { + if (version instanceof SemVer) { + return version + } + + if (typeof version === 'number') { + version = String(version) + } + + if (typeof version !== 'string') { + return null + } + + options = options || {} + + let match = null + if (!options.rtl) { + match = version.match(re[t.COERCE]) + } else { + // Find the right-most coercible string that does not share + // a terminus with a more left-ward coercible string. + // Eg, '1.2.3.4' wants to coerce '2.3.4', not '3.4' or '4' + // + // Walk through the string checking with a /g regexp + // Manually set the index so as to pick up overlapping matches. + // Stop when we get a match that ends at the string end, since no + // coercible string can be more right-ward without the same terminus. + let next + while ((next = re[t.COERCERTL].exec(version)) && + (!match || match.index + match[0].length !== version.length) + ) { + if (!match || + next.index + next[0].length !== match.index + match[0].length) { + match = next + } + re[t.COERCERTL].lastIndex = next.index + next[1].length + next[2].length } + // leave it in a clean state + re[t.COERCERTL].lastIndex = -1 + } + + if (match === null) { + return null + } + + return parse(`${match[2]}.${match[3] || '0'}.${match[4] || '0'}`, options) } -exports.createLockFile = createLockFile; -// generate body lines for error message -function errorBodyLines(originalError, additionalInfo = []) { - return [ - 'Please open an issue at `https://github.com/nrwl/nx/issues/new?template=1-bug.yml` and provide a reproduction.', - ...additionalInfo, - `\nOriginal error: ${originalError.message}\n\n`, - originalError.stack, - ]; -} -function isPostInstallProcess() { - return (process.env.npm_command === 'install' && - process.env.npm_lifecycle_event === 'postinstall'); +module.exports = coerce + + +/***/ }), + +/***/ 73756: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + +const SemVer = __nccwpck_require__(93097) +const compareBuild = (a, b, loose) => { + const versionA = new SemVer(a, loose) + const versionB = new SemVer(b, loose) + return versionA.compare(versionB) || versionA.compareBuild(versionB) } +module.exports = compareBuild /***/ }), -/***/ 695: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { +/***/ 25250: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { -"use strict"; +const compare = __nccwpck_require__(36208) +const compareLoose = (a, b) => compare(a, b, true) +module.exports = compareLoose -Object.defineProperty(exports, "__esModule", ({ value: true })); -exports.stringifyNpmLockfile = exports.parseNpmLockfile = void 0; -const tslib_1 = __nccwpck_require__(51796); -const fs_1 = __nccwpck_require__(57147); -const semver_1 = __nccwpck_require__(56192); -const workspace_root_1 = __nccwpck_require__(65766); -const operators_1 = __nccwpck_require__(97607); -const impl_1 = __nccwpck_require__(43265); -function parseNpmLockfile(lockFileContent, builder) { - const data = JSON.parse(lockFileContent); - // we use key => node map to avoid duplicate work when parsing keys - const keyMap = new Map(); - addNodes(data, builder, keyMap); - addDependencies(data, builder, keyMap); -} -exports.parseNpmLockfile = parseNpmLockfile; -function addNodes(data, builder, keyMap) { - const nodes = new Map(); - if (data.lockfileVersion > 1) { - Object.entries(data.packages).forEach(([path, snapshot]) => { - // skip workspaces packages - if (path === '' || !path.includes('node_modules') || snapshot.link) { - return; - } - const packageName = path.split('node_modules/').pop(); - const version = findV3Version(snapshot, packageName); - createNode(packageName, version, path, nodes, keyMap, snapshot); - }); + +/***/ }), + +/***/ 36208: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + +const SemVer = __nccwpck_require__(93097) +const compare = (a, b, loose) => + new SemVer(a, loose).compare(new SemVer(b, loose)) + +module.exports = compare + + +/***/ }), + +/***/ 79439: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + +const parse = __nccwpck_require__(13857) + +const diff = (version1, version2) => { + const v1 = parse(version1, null, true) + const v2 = parse(version2, null, true) + const comparison = v1.compare(v2) + + if (comparison === 0) { + return null + } + + const v1Higher = comparison > 0 + const highVersion = v1Higher ? v1 : v2 + const lowVersion = v1Higher ? v2 : v1 + const highHasPre = !!highVersion.prerelease.length + const lowHasPre = !!lowVersion.prerelease.length + + if (lowHasPre && !highHasPre) { + // Going from prerelease -> no prerelease requires some special casing + + // If the low version has only a major, then it will always be a major + // Some examples: + // 1.0.0-1 -> 1.0.0 + // 1.0.0-1 -> 1.1.1 + // 1.0.0-1 -> 2.0.0 + if (!lowVersion.patch && !lowVersion.minor) { + return 'major' } - else { - Object.entries(data.dependencies).forEach(([packageName, snapshot]) => { - var _a; - // we only care about dependencies of workspace packages - if ((_a = snapshot.version) === null || _a === void 0 ? void 0 : _a.startsWith('file:')) { - if (snapshot.dependencies) { - Object.entries(snapshot.dependencies).forEach(([depName, depSnapshot]) => { - addV1Node(depName, depSnapshot, `${snapshot.version.slice(5)}/node_modules/${depName}`, nodes, keyMap, builder); - }); - } - } - else { - addV1Node(packageName, snapshot, `node_modules/${packageName}`, nodes, keyMap, builder); - } - }); + + // Otherwise it can be determined by checking the high version + + if (highVersion.patch) { + // anything higher than a patch bump would result in the wrong version + return 'patch' } - // some packages can be both hoisted and nested - // so we need to run this check once we have all the nodes and paths - for (const [packageName, versionMap] of nodes.entries()) { - const hoistedNode = keyMap.get(`node_modules/${packageName}`); - if (hoistedNode) { - hoistedNode.name = `npm:${packageName}`; - } - versionMap.forEach((node) => { - builder.addExternalNode(node); - }); + + if (highVersion.minor) { + // anything higher than a minor bump would result in the wrong version + return 'minor' } + + // bumping major/minor/patch all have same result + return 'major' + } + + // add the `pre` prefix if we are going to a prerelease version + const prefix = highHasPre ? 'pre' : '' + + if (v1.major !== v2.major) { + return prefix + 'major' + } + + if (v1.minor !== v2.minor) { + return prefix + 'minor' + } + + if (v1.patch !== v2.patch) { + return prefix + 'patch' + } + + // high and low are preleases + return 'prerelease' } -function addV1Node(packageName, snapshot, path, nodes, keyMap, builder) { - createNode(packageName, snapshot.version, path, nodes, keyMap, snapshot); - // traverse nested dependencies - if (snapshot.dependencies) { - Object.entries(snapshot.dependencies).forEach(([depName, depSnapshot]) => { - addV1Node(depName, depSnapshot, `${path}/node_modules/${depName}`, nodes, keyMap, builder); - }); - } + +module.exports = diff + + +/***/ }), + +/***/ 68537: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + +const compare = __nccwpck_require__(36208) +const eq = (a, b, loose) => compare(a, b, loose) === 0 +module.exports = eq + + +/***/ }), + +/***/ 71381: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + +const compare = __nccwpck_require__(36208) +const gt = (a, b, loose) => compare(a, b, loose) > 0 +module.exports = gt + + +/***/ }), + +/***/ 52498: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + +const compare = __nccwpck_require__(36208) +const gte = (a, b, loose) => compare(a, b, loose) >= 0 +module.exports = gte + + +/***/ }), + +/***/ 7788: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + +const SemVer = __nccwpck_require__(93097) + +const inc = (version, release, options, identifier, identifierBase) => { + if (typeof (options) === 'string') { + identifierBase = identifier + identifier = options + options = undefined + } + + try { + return new SemVer( + version instanceof SemVer ? version.version : version, + options + ).inc(release, identifier, identifierBase).version + } catch (er) { + return null + } } -function createNode(packageName, version, key, nodes, keyMap, snapshot) { - var _a; - const existingNode = (_a = nodes.get(packageName)) === null || _a === void 0 ? void 0 : _a.get(version); - if (existingNode) { - keyMap.set(key, existingNode); - return; - } - const node = { - type: 'npm', - name: version ? `npm:${packageName}@${version}` : `npm:${packageName}`, - data: { - version, - packageName, - hash: snapshot.integrity || - (0, impl_1.hashArray)(snapshot.resolved ? [snapshot.resolved] : [packageName, version]), - }, - }; - keyMap.set(key, node); - if (!nodes.has(packageName)) { - nodes.set(packageName, new Map([[version, node]])); - } - else { - nodes.get(packageName).set(version, node); +module.exports = inc + + +/***/ }), + +/***/ 75330: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + +const compare = __nccwpck_require__(36208) +const lt = (a, b, loose) => compare(a, b, loose) < 0 +module.exports = lt + + +/***/ }), + +/***/ 84698: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + +const compare = __nccwpck_require__(36208) +const lte = (a, b, loose) => compare(a, b, loose) <= 0 +module.exports = lte + + +/***/ }), + +/***/ 91163: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + +const SemVer = __nccwpck_require__(93097) +const major = (a, loose) => new SemVer(a, loose).major +module.exports = major + + +/***/ }), + +/***/ 55612: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + +const SemVer = __nccwpck_require__(93097) +const minor = (a, loose) => new SemVer(a, loose).minor +module.exports = minor + + +/***/ }), + +/***/ 89176: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + +const compare = __nccwpck_require__(36208) +const neq = (a, b, loose) => compare(a, b, loose) !== 0 +module.exports = neq + + +/***/ }), + +/***/ 13857: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + +const SemVer = __nccwpck_require__(93097) +const parse = (version, options, throwErrors = false) => { + if (version instanceof SemVer) { + return version + } + try { + return new SemVer(version, options) + } catch (er) { + if (!throwErrors) { + return null } + throw er + } } -function findV3Version(snapshot, packageName) { - let version = snapshot.version; - const resolved = snapshot.resolved; - // for tarball packages version might not exist or be useless - if (!version || (resolved && !resolved.includes(version))) { - version = resolved; - } - // for alias packages name is set - if (snapshot.name && snapshot.name !== packageName) { - if (version) { - version = `npm:${snapshot.name}@${version}`; - } - else { - version = `npm:${snapshot.name}`; - } - } - return version; + +module.exports = parse + + +/***/ }), + +/***/ 38899: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + +const SemVer = __nccwpck_require__(93097) +const patch = (a, loose) => new SemVer(a, loose).patch +module.exports = patch + + +/***/ }), + +/***/ 7958: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + +const parse = __nccwpck_require__(13857) +const prerelease = (version, options) => { + const parsed = parse(version, options) + return (parsed && parsed.prerelease.length) ? parsed.prerelease : null } -function addDependencies(data, builder, keyMap) { - if (data.lockfileVersion > 1) { - Object.entries(data.packages).forEach(([path, snapshot]) => { - // we are skipping workspaces packages - if (!keyMap.has(path)) { - return; - } - const sourceName = keyMap.get(path).name; - [ - snapshot.peerDependencies, - snapshot.dependencies, - snapshot.optionalDependencies, - ].forEach((section) => { - if (section) { - Object.entries(section).forEach(([name, versionRange]) => { - const target = findTarget(path, keyMap, name, versionRange); - if (target) { - builder.addStaticDependency(sourceName, target.name); - } - }); - } - }); - }); - } - else { - Object.entries(data.dependencies).forEach(([packageName, snapshot]) => { - addV1NodeDependencies(`node_modules/${packageName}`, snapshot, builder, keyMap); - }); - } +module.exports = prerelease + + +/***/ }), + +/***/ 3628: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + +const compare = __nccwpck_require__(36208) +const rcompare = (a, b, loose) => compare(b, a, loose) +module.exports = rcompare + + +/***/ }), + +/***/ 84358: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + +const compareBuild = __nccwpck_require__(73756) +const rsort = (list, loose) => list.sort((a, b) => compareBuild(b, a, loose)) +module.exports = rsort + + +/***/ }), + +/***/ 77477: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + +const Range = __nccwpck_require__(70434) +const satisfies = (version, range, options) => { + try { + range = new Range(range, options) + } catch (er) { + return false + } + return range.test(version) } -function findTarget(sourcePath, keyMap, targetName, versionRange) { - if (sourcePath && !sourcePath.endsWith('/')) { - sourcePath = `${sourcePath}/`; - } - const searchPath = `${sourcePath}node_modules/${targetName}`; - if (keyMap.has(searchPath)) { - const child = keyMap.get(searchPath); - if (child.data.version === versionRange || - (0, semver_1.satisfies)(child.data.version, versionRange)) { - return child; - } - } - // the hoisted package did not match, this dependency is missing - if (!sourcePath) { - return; - } - return findTarget(sourcePath.split('node_modules/').slice(0, -1).join('node_modules/'), keyMap, targetName, versionRange); +module.exports = satisfies + + +/***/ }), + +/***/ 40241: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + +const compareBuild = __nccwpck_require__(73756) +const sort = (list, loose) => list.sort((a, b) => compareBuild(a, b, loose)) +module.exports = sort + + +/***/ }), + +/***/ 17503: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + +const parse = __nccwpck_require__(13857) +const valid = (version, options) => { + const v = parse(version, options) + return v ? v.version : null } -function addV1NodeDependencies(path, snapshot, builder, keyMap) { - if (keyMap.has(path) && snapshot.requires) { - const source = keyMap.get(path).name; - Object.entries(snapshot.requires).forEach(([name, versionRange]) => { - const target = findTarget(path, keyMap, name, versionRange); - if (target) { - builder.addStaticDependency(source, target.name); - } - }); - } - if (snapshot.dependencies) { - Object.entries(snapshot.dependencies).forEach(([depName, depSnapshot]) => { - addV1NodeDependencies(`${path}/node_modules/${depName}`, depSnapshot, builder, keyMap); - }); - } - const { peerDependencies } = getPeerDependencies(path); - if (peerDependencies) { - const node = keyMap.get(path); - Object.entries(peerDependencies).forEach(([depName, depSpec]) => { - var _a; - if (!((_a = builder.graph.dependencies[node.name]) === null || _a === void 0 ? void 0 : _a.find((d) => d.target === depName))) { - const target = findTarget(path, keyMap, depName, depSpec); - if (target) { - builder.addStaticDependency(node.name, target.name); - } - } - }); - } +module.exports = valid + + +/***/ }), + +/***/ 66195: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + +// just pre-load all the stuff that index.js lazily exports +const internalRe = __nccwpck_require__(49815) +const constants = __nccwpck_require__(96730) +const SemVer = __nccwpck_require__(93097) +const identifiers = __nccwpck_require__(67701) +const parse = __nccwpck_require__(13857) +const valid = __nccwpck_require__(17503) +const clean = __nccwpck_require__(30262) +const inc = __nccwpck_require__(7788) +const diff = __nccwpck_require__(79439) +const major = __nccwpck_require__(91163) +const minor = __nccwpck_require__(55612) +const patch = __nccwpck_require__(38899) +const prerelease = __nccwpck_require__(7958) +const compare = __nccwpck_require__(36208) +const rcompare = __nccwpck_require__(3628) +const compareLoose = __nccwpck_require__(25250) +const compareBuild = __nccwpck_require__(73756) +const sort = __nccwpck_require__(40241) +const rsort = __nccwpck_require__(84358) +const gt = __nccwpck_require__(71381) +const lt = __nccwpck_require__(75330) +const eq = __nccwpck_require__(68537) +const neq = __nccwpck_require__(89176) +const gte = __nccwpck_require__(52498) +const lte = __nccwpck_require__(84698) +const cmp = __nccwpck_require__(97714) +const coerce = __nccwpck_require__(93292) +const Comparator = __nccwpck_require__(14658) +const Range = __nccwpck_require__(70434) +const satisfies = __nccwpck_require__(77477) +const toComparators = __nccwpck_require__(45827) +const maxSatisfying = __nccwpck_require__(59530) +const minSatisfying = __nccwpck_require__(81539) +const minVersion = __nccwpck_require__(56296) +const validRange = __nccwpck_require__(88902) +const outside = __nccwpck_require__(69808) +const gtr = __nccwpck_require__(97557) +const ltr = __nccwpck_require__(64666) +const intersects = __nccwpck_require__(28658) +const simplifyRange = __nccwpck_require__(1259) +const subset = __nccwpck_require__(95865) +module.exports = { + parse, + valid, + clean, + inc, + diff, + major, + minor, + patch, + prerelease, + compare, + rcompare, + compareLoose, + compareBuild, + sort, + rsort, + gt, + lt, + eq, + neq, + gte, + lte, + cmp, + coerce, + Comparator, + Range, + satisfies, + toComparators, + maxSatisfying, + minSatisfying, + minVersion, + validRange, + outside, + gtr, + ltr, + intersects, + simplifyRange, + subset, + SemVer, + re: internalRe.re, + src: internalRe.src, + tokens: internalRe.t, + SEMVER_SPEC_VERSION: constants.SEMVER_SPEC_VERSION, + RELEASE_TYPES: constants.RELEASE_TYPES, + compareIdentifiers: identifiers.compareIdentifiers, + rcompareIdentifiers: identifiers.rcompareIdentifiers, } -function stringifyNpmLockfile(graph, rootLockFileContent, packageJson) { - const rootLockFile = JSON.parse(rootLockFileContent); - const { lockfileVersion } = JSON.parse(rootLockFileContent); - const mappedPackages = mapSnapshots(rootLockFile, graph); - const output = { - name: packageJson.name || rootLockFile.name, - version: packageJson.version || '0.0.1', - lockfileVersion: rootLockFile.lockfileVersion, - }; - if (rootLockFile.requires) { - output.requires = rootLockFile.requires; - } - if (lockfileVersion > 1) { - output.packages = mapV3Snapshots(mappedPackages, packageJson); - } - if (lockfileVersion < 3) { - output.dependencies = mapV1Snapshots(mappedPackages); - } - return JSON.stringify(output, null, 2); + + +/***/ }), + +/***/ 96730: +/***/ ((module) => { + +// Note: this is the semver.org version of the spec that it implements +// Not necessarily the package version of this code. +const SEMVER_SPEC_VERSION = '2.0.0' + +const MAX_LENGTH = 256 +const MAX_SAFE_INTEGER = Number.MAX_SAFE_INTEGER || +/* istanbul ignore next */ 9007199254740991 + +// Max safe segment length for coercion. +const MAX_SAFE_COMPONENT_LENGTH = 16 + +// Max safe length for a build identifier. The max length minus 6 characters for +// the shortest version with a build 0.0.0+BUILD. +const MAX_SAFE_BUILD_LENGTH = MAX_LENGTH - 6 + +const RELEASE_TYPES = [ + 'major', + 'premajor', + 'minor', + 'preminor', + 'patch', + 'prepatch', + 'prerelease', +] + +module.exports = { + MAX_LENGTH, + MAX_SAFE_COMPONENT_LENGTH, + MAX_SAFE_BUILD_LENGTH, + MAX_SAFE_INTEGER, + RELEASE_TYPES, + SEMVER_SPEC_VERSION, + FLAG_INCLUDE_PRERELEASE: 0b001, + FLAG_LOOSE: 0b010, } -exports.stringifyNpmLockfile = stringifyNpmLockfile; -function mapV3Snapshots(mappedPackages, packageJson) { - const output = {}; - output[''] = packageJson; - mappedPackages.forEach((p) => { - output[p.path] = p.valueV3; - }); - return output; + + +/***/ }), + +/***/ 19723: +/***/ ((module) => { + +const debug = ( + typeof process === 'object' && + process.env && + process.env.NODE_DEBUG && + /\bsemver\b/i.test(process.env.NODE_DEBUG) +) ? (...args) => console.error('SEMVER', ...args) + : () => {} + +module.exports = debug + + +/***/ }), + +/***/ 67701: +/***/ ((module) => { + +const numeric = /^[0-9]+$/ +const compareIdentifiers = (a, b) => { + const anum = numeric.test(a) + const bnum = numeric.test(b) + + if (anum && bnum) { + a = +a + b = +b + } + + return a === b ? 0 + : (anum && !bnum) ? -1 + : (bnum && !anum) ? 1 + : a < b ? -1 + : 1 } -function mapV1Snapshots(mappedPackages) { - const output = {}; - mappedPackages.forEach((p) => { - getPackageParent(p.path, output)[p.name] = p.valueV1; - }); - return output; + +const rcompareIdentifiers = (a, b) => compareIdentifiers(b, a) + +module.exports = { + compareIdentifiers, + rcompareIdentifiers, } -function getPackageParent(path, packages) { - const segments = path.split(/\/?node_modules\//).slice(1, -1); - if (!segments.length) { - return packages; - } - let parent = packages[segments.shift()]; - if (!parent.dependencies) { - parent.dependencies = {}; - } - while (segments.length) { - parent = parent.dependencies[segments.shift()]; - if (!parent.dependencies) { - parent.dependencies = {}; - } - } - return parent.dependencies; + + +/***/ }), + +/***/ 35375: +/***/ ((module) => { + +// parse out just the options we care about +const looseOption = Object.freeze({ loose: true }) +const emptyOpts = Object.freeze({ }) +const parseOptions = options => { + if (!options) { + return emptyOpts + } + + if (typeof options !== 'object') { + return looseOption + } + + return options } -function mapSnapshots(rootLockFile, graph) { - const nestedNodes = new Set(); - const visitedNodes = new Map(); - const visitedPaths = new Set(); - const remappedPackages = new Map(); - // add first level children - Object.values(graph.externalNodes).forEach((node) => { - if (node.name === `npm:${node.data.packageName}`) { - const mappedPackage = mapPackage(rootLockFile, node.data.packageName, node.data.version); - remappedPackages.set(mappedPackage.path, mappedPackage); - visitedNodes.set(node, new Set([mappedPackage.path])); - visitedPaths.add(mappedPackage.path); - } - else { - nestedNodes.add(node); - } - }); - let remappedPackagesArray; - if (nestedNodes.size) { - const invertedGraph = (0, operators_1.reverse)(graph); - nestMappedPackages(invertedGraph, remappedPackages, nestedNodes, visitedNodes, visitedPaths, rootLockFile); - // initially we naively map package paths to topParent/../parent/child - // but some of those should be nested higher up the tree - remappedPackagesArray = elevateNestedPaths(remappedPackages); - } - else { - remappedPackagesArray = Array.from(remappedPackages.values()); - } - return remappedPackagesArray.sort((a, b) => a.path.localeCompare(b.path)); +module.exports = parseOptions + + +/***/ }), + +/***/ 49815: +/***/ ((module, exports, __nccwpck_require__) => { + +const { + MAX_SAFE_COMPONENT_LENGTH, + MAX_SAFE_BUILD_LENGTH, + MAX_LENGTH, +} = __nccwpck_require__(96730) +const debug = __nccwpck_require__(19723) +exports = module.exports = {} + +// The actual regexps go on exports.re +const re = exports.re = [] +const safeRe = exports.safeRe = [] +const src = exports.src = [] +const t = exports.t = {} +let R = 0 + +const LETTERDASHNUMBER = '[a-zA-Z0-9-]' + +// Replace some greedy regex tokens to prevent regex dos issues. These regex are +// used internally via the safeRe object since all inputs in this library get +// normalized first to trim and collapse all extra whitespace. The original +// regexes are exported for userland consumption and lower level usage. A +// future breaking change could export the safer regex only with a note that +// all input should have extra whitespace removed. +const safeRegexReplacements = [ + ['\\s', 1], + ['\\d', MAX_LENGTH], + [LETTERDASHNUMBER, MAX_SAFE_BUILD_LENGTH], +] + +const makeSafeRegex = (value) => { + for (const [token, max] of safeRegexReplacements) { + value = value + .split(`${token}*`).join(`${token}{0,${max}}`) + .split(`${token}+`).join(`${token}{1,${max}}`) + } + return value } -function mapPackage(rootLockFile, packageName, version, parentPath = '') { - const lockfileVersion = rootLockFile.lockfileVersion; - let valueV3, valueV1; - if (lockfileVersion < 3) { - valueV1 = findMatchingPackageV1(rootLockFile.dependencies, packageName, version); - } - if (lockfileVersion > 1) { - valueV3 = findMatchingPackageV3(rootLockFile.packages, packageName, version); - } - return { - path: parentPath + `node_modules/${packageName}`, - name: packageName, - valueV1, - valueV3, - }; + +const createToken = (name, value, isGlobal) => { + const safe = makeSafeRegex(value) + const index = R++ + debug(name, index, value) + t[name] = index + src[index] = value + re[index] = new RegExp(value, isGlobal ? 'g' : undefined) + safeRe[index] = new RegExp(safe, isGlobal ? 'g' : undefined) } -function nestMappedPackages(invertedGraph, result, nestedNodes, visitedNodes, visitedPaths, rootLockFile) { - const initialSize = nestedNodes.size; - if (!initialSize) { - return; - } - nestedNodes.forEach((node) => { - let unresolvedParents = invertedGraph.dependencies[node.name].length; - invertedGraph.dependencies[node.name].forEach(({ target }) => { - const targetNode = invertedGraph.externalNodes[target]; - if (visitedNodes.has(targetNode)) { - visitedNodes.get(targetNode).forEach((path) => { - const mappedPackage = mapPackage(rootLockFile, node.data.packageName, node.data.version, path + '/'); - result.set(mappedPackage.path, mappedPackage); - if (visitedNodes.has(node)) { - visitedNodes.get(node).add(mappedPackage.path); - } - else { - visitedNodes.set(node, new Set([mappedPackage.path])); - } - visitedPaths.add(mappedPackage.path); - }); - unresolvedParents--; - } - }); - if (!unresolvedParents) { - nestedNodes.delete(node); - } - }); - if (initialSize === nestedNodes.size) { - throw new Error([ - 'Following packages could not be mapped to the NPM lockfile:', - ...Array.from(nestedNodes).map((n) => `- ${n.name}`), - ].join('\n')); - } - else { - nestMappedPackages(invertedGraph, result, nestedNodes, visitedNodes, visitedPaths, rootLockFile); - } -} -// sort paths by number of segments and then alphabetically -function sortMappedPackagesPaths(mappedPackages) { - return Array.from(mappedPackages.keys()).sort((a, b) => { - const aLength = a.split('/node_modules/').length; - const bLength = b.split('/node_modules/').length; - if (aLength > bLength) { - return 1; - } - if (aLength < bLength) { - return -1; - } - return a.localeCompare(b); - }); -} -function elevateNestedPaths(remappedPackages) { - const result = new Map(); - const sortedPaths = sortMappedPackagesPaths(remappedPackages); - sortedPaths.forEach((path) => { - const segments = path.split('/node_modules/'); - const mappedPackage = remappedPackages.get(path); - // we keep hoisted packages intact - if (segments.length === 1) { - result.set(path, mappedPackage); - return; - } - const packageName = segments.pop(); - const getNewPath = (segs) => `${segs.join('/node_modules/')}/node_modules/${packageName}`; - // check if grandparent has the same package - const shouldElevate = (segs) => { - var _a, _b, _c, _d; - const elevatedPath = getNewPath(segs.slice(0, -1)); - if (result.has(elevatedPath)) { - const match = result.get(elevatedPath); - return (((_a = match.valueV1) === null || _a === void 0 ? void 0 : _a.version) === ((_b = mappedPackage.valueV1) === null || _b === void 0 ? void 0 : _b.version) && - ((_c = match.valueV3) === null || _c === void 0 ? void 0 : _c.version) === ((_d = mappedPackage.valueV3) === null || _d === void 0 ? void 0 : _d.version)); - } - return true; - }; - while (segments.length > 1 && shouldElevate(segments)) { - segments.pop(); - } - const newPath = getNewPath(segments); - if (path !== newPath) { - if (!result.has(newPath)) { - mappedPackage.path = newPath; - result.set(newPath, mappedPackage); - } - } - else { - result.set(path, mappedPackage); - } - }); - return Array.from(result.values()); + +// The following Regular Expressions can be used for tokenizing, +// validating, and parsing SemVer version strings. + +// ## Numeric Identifier +// A single `0`, or a non-zero digit followed by zero or more digits. + +createToken('NUMERICIDENTIFIER', '0|[1-9]\\d*') +createToken('NUMERICIDENTIFIERLOOSE', '\\d+') + +// ## Non-numeric Identifier +// Zero or more digits, followed by a letter or hyphen, and then zero or +// more letters, digits, or hyphens. + +createToken('NONNUMERICIDENTIFIER', `\\d*[a-zA-Z-]${LETTERDASHNUMBER}*`) + +// ## Main Version +// Three dot-separated numeric identifiers. + +createToken('MAINVERSION', `(${src[t.NUMERICIDENTIFIER]})\\.` + + `(${src[t.NUMERICIDENTIFIER]})\\.` + + `(${src[t.NUMERICIDENTIFIER]})`) + +createToken('MAINVERSIONLOOSE', `(${src[t.NUMERICIDENTIFIERLOOSE]})\\.` + + `(${src[t.NUMERICIDENTIFIERLOOSE]})\\.` + + `(${src[t.NUMERICIDENTIFIERLOOSE]})`) + +// ## Pre-release Version Identifier +// A numeric identifier, or a non-numeric identifier. + +createToken('PRERELEASEIDENTIFIER', `(?:${src[t.NUMERICIDENTIFIER] +}|${src[t.NONNUMERICIDENTIFIER]})`) + +createToken('PRERELEASEIDENTIFIERLOOSE', `(?:${src[t.NUMERICIDENTIFIERLOOSE] +}|${src[t.NONNUMERICIDENTIFIER]})`) + +// ## Pre-release Version +// Hyphen, followed by one or more dot-separated pre-release version +// identifiers. + +createToken('PRERELEASE', `(?:-(${src[t.PRERELEASEIDENTIFIER] +}(?:\\.${src[t.PRERELEASEIDENTIFIER]})*))`) + +createToken('PRERELEASELOOSE', `(?:-?(${src[t.PRERELEASEIDENTIFIERLOOSE] +}(?:\\.${src[t.PRERELEASEIDENTIFIERLOOSE]})*))`) + +// ## Build Metadata Identifier +// Any combination of digits, letters, or hyphens. + +createToken('BUILDIDENTIFIER', `${LETTERDASHNUMBER}+`) + +// ## Build Metadata +// Plus sign, followed by one or more period-separated build metadata +// identifiers. + +createToken('BUILD', `(?:\\+(${src[t.BUILDIDENTIFIER] +}(?:\\.${src[t.BUILDIDENTIFIER]})*))`) + +// ## Full Version String +// A main version, followed optionally by a pre-release version and +// build metadata. + +// Note that the only major, minor, patch, and pre-release sections of +// the version string are capturing groups. The build metadata is not a +// capturing group, because it should not ever be used in version +// comparison. + +createToken('FULLPLAIN', `v?${src[t.MAINVERSION] +}${src[t.PRERELEASE]}?${ + src[t.BUILD]}?`) + +createToken('FULL', `^${src[t.FULLPLAIN]}$`) + +// like full, but allows v1.2.3 and =1.2.3, which people do sometimes. +// also, 1.0.0alpha1 (prerelease without the hyphen) which is pretty +// common in the npm registry. +createToken('LOOSEPLAIN', `[v=\\s]*${src[t.MAINVERSIONLOOSE] +}${src[t.PRERELEASELOOSE]}?${ + src[t.BUILD]}?`) + +createToken('LOOSE', `^${src[t.LOOSEPLAIN]}$`) + +createToken('GTLT', '((?:<|>)?=?)') + +// Something like "2.*" or "1.2.x". +// Note that "x.x" is a valid xRange identifer, meaning "any version" +// Only the first item is strictly required. +createToken('XRANGEIDENTIFIERLOOSE', `${src[t.NUMERICIDENTIFIERLOOSE]}|x|X|\\*`) +createToken('XRANGEIDENTIFIER', `${src[t.NUMERICIDENTIFIER]}|x|X|\\*`) + +createToken('XRANGEPLAIN', `[v=\\s]*(${src[t.XRANGEIDENTIFIER]})` + + `(?:\\.(${src[t.XRANGEIDENTIFIER]})` + + `(?:\\.(${src[t.XRANGEIDENTIFIER]})` + + `(?:${src[t.PRERELEASE]})?${ + src[t.BUILD]}?` + + `)?)?`) + +createToken('XRANGEPLAINLOOSE', `[v=\\s]*(${src[t.XRANGEIDENTIFIERLOOSE]})` + + `(?:\\.(${src[t.XRANGEIDENTIFIERLOOSE]})` + + `(?:\\.(${src[t.XRANGEIDENTIFIERLOOSE]})` + + `(?:${src[t.PRERELEASELOOSE]})?${ + src[t.BUILD]}?` + + `)?)?`) + +createToken('XRANGE', `^${src[t.GTLT]}\\s*${src[t.XRANGEPLAIN]}$`) +createToken('XRANGELOOSE', `^${src[t.GTLT]}\\s*${src[t.XRANGEPLAINLOOSE]}$`) + +// Coercion. +// Extract anything that could conceivably be a part of a valid semver +createToken('COERCE', `${'(^|[^\\d])' + + '(\\d{1,'}${MAX_SAFE_COMPONENT_LENGTH}})` + + `(?:\\.(\\d{1,${MAX_SAFE_COMPONENT_LENGTH}}))?` + + `(?:\\.(\\d{1,${MAX_SAFE_COMPONENT_LENGTH}}))?` + + `(?:$|[^\\d])`) +createToken('COERCERTL', src[t.COERCE], true) + +// Tilde ranges. +// Meaning is "reasonably at or greater than" +createToken('LONETILDE', '(?:~>?)') + +createToken('TILDETRIM', `(\\s*)${src[t.LONETILDE]}\\s+`, true) +exports.tildeTrimReplace = '$1~' + +createToken('TILDE', `^${src[t.LONETILDE]}${src[t.XRANGEPLAIN]}$`) +createToken('TILDELOOSE', `^${src[t.LONETILDE]}${src[t.XRANGEPLAINLOOSE]}$`) + +// Caret ranges. +// Meaning is "at least and backwards compatible with" +createToken('LONECARET', '(?:\\^)') + +createToken('CARETTRIM', `(\\s*)${src[t.LONECARET]}\\s+`, true) +exports.caretTrimReplace = '$1^' + +createToken('CARET', `^${src[t.LONECARET]}${src[t.XRANGEPLAIN]}$`) +createToken('CARETLOOSE', `^${src[t.LONECARET]}${src[t.XRANGEPLAINLOOSE]}$`) + +// A simple gt/lt/eq thing, or just "" to indicate "any version" +createToken('COMPARATORLOOSE', `^${src[t.GTLT]}\\s*(${src[t.LOOSEPLAIN]})$|^$`) +createToken('COMPARATOR', `^${src[t.GTLT]}\\s*(${src[t.FULLPLAIN]})$|^$`) + +// An expression to strip any whitespace between the gtlt and the thing +// it modifies, so that `> 1.2.3` ==> `>1.2.3` +createToken('COMPARATORTRIM', `(\\s*)${src[t.GTLT] +}\\s*(${src[t.LOOSEPLAIN]}|${src[t.XRANGEPLAIN]})`, true) +exports.comparatorTrimReplace = '$1$2$3' + +// Something like `1.2.3 - 1.2.4` +// Note that these all use the loose form, because they'll be +// checked against either the strict or loose comparator form +// later. +createToken('HYPHENRANGE', `^\\s*(${src[t.XRANGEPLAIN]})` + + `\\s+-\\s+` + + `(${src[t.XRANGEPLAIN]})` + + `\\s*$`) + +createToken('HYPHENRANGELOOSE', `^\\s*(${src[t.XRANGEPLAINLOOSE]})` + + `\\s+-\\s+` + + `(${src[t.XRANGEPLAINLOOSE]})` + + `\\s*$`) + +// Star ranges basically just allow anything at all. +createToken('STAR', '(<|>)?=?\\s*\\*') +// >=0.0.0 is like a star +createToken('GTE0', '^\\s*>=\\s*0\\.0\\.0\\s*$') +createToken('GTE0PRE', '^\\s*>=\\s*0\\.0\\.0-0\\s*$') + + +/***/ }), + +/***/ 97557: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + +// Determine if version is greater than all the versions possible in the range. +const outside = __nccwpck_require__(69808) +const gtr = (version, range, options) => outside(version, range, '>', options) +module.exports = gtr + + +/***/ }), + +/***/ 28658: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + +const Range = __nccwpck_require__(70434) +const intersects = (r1, r2, options) => { + r1 = new Range(r1, options) + r2 = new Range(r2, options) + return r1.intersects(r2, options) } -function findMatchingPackageV3(packages, name, version) { - for (let _a of Object.entries(packages)) { - const [key, _b] = _a, { dev, peer } = _b, snapshot = tslib_1.__rest(_b, ["dev", "peer"]); - if (key.endsWith(`node_modules/${name}`)) { - if ([ - snapshot.version, - snapshot.resolved, - `npm:${snapshot.name}@${snapshot.version}`, - ].includes(version)) { - return snapshot; - } - } +module.exports = intersects + + +/***/ }), + +/***/ 64666: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + +const outside = __nccwpck_require__(69808) +// Determine if version is less than all the versions possible in the range +const ltr = (version, range, options) => outside(version, range, '<', options) +module.exports = ltr + + +/***/ }), + +/***/ 59530: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + +const SemVer = __nccwpck_require__(93097) +const Range = __nccwpck_require__(70434) + +const maxSatisfying = (versions, range, options) => { + let max = null + let maxSV = null + let rangeObj = null + try { + rangeObj = new Range(range, options) + } catch (er) { + return null + } + versions.forEach((v) => { + if (rangeObj.test(v)) { + // satisfies(v, range, options) + if (!max || maxSV.compare(v) === -1) { + // compare(max, v, true) + max = v + maxSV = new SemVer(max, options) + } } + }) + return max } -function findMatchingPackageV1(packages, name, version) { - for (let _a of Object.entries(packages)) { - const [packageName, _b] = _a, { dev, peer, dependencies } = _b, snapshot = tslib_1.__rest(_b, ["dev", "peer", "dependencies"]); - if (packageName === name) { - if (snapshot.version === version) { - return snapshot; - } - } - if (dependencies) { - const found = findMatchingPackageV1(dependencies, name, version); - if (found) { - return found; - } - } +module.exports = maxSatisfying + + +/***/ }), + +/***/ 81539: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + +const SemVer = __nccwpck_require__(93097) +const Range = __nccwpck_require__(70434) +const minSatisfying = (versions, range, options) => { + let min = null + let minSV = null + let rangeObj = null + try { + rangeObj = new Range(range, options) + } catch (er) { + return null + } + versions.forEach((v) => { + if (rangeObj.test(v)) { + // satisfies(v, range, options) + if (!min || minSV.compare(v) === 1) { + // compare(min, v, true) + min = v + minSV = new SemVer(min, options) + } } + }) + return min } -// NPM V1 does not track the peer dependencies in the lock file -// so we need to parse them directly from the package.json -function getPeerDependencies(path) { - const fullPath = `${workspace_root_1.workspaceRoot}/${path}/package.json`; - if ((0, fs_1.existsSync)(fullPath)) { - const content = (0, fs_1.readFileSync)(fullPath, 'utf-8'); - const { peerDependencies, peerDependenciesMeta } = JSON.parse(content); - return Object.assign(Object.assign({}, (peerDependencies && { peerDependencies })), (peerDependenciesMeta && { peerDependenciesMeta })); - } - else { - if (process.env.NX_VERBOSE_LOGGING === 'true') { - console.warn(`Could not find package.json at "${path}"`); - } - return {}; +module.exports = minSatisfying + + +/***/ }), + +/***/ 56296: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + +const SemVer = __nccwpck_require__(93097) +const Range = __nccwpck_require__(70434) +const gt = __nccwpck_require__(71381) + +const minVersion = (range, loose) => { + range = new Range(range, loose) + + let minver = new SemVer('0.0.0') + if (range.test(minver)) { + return minver + } + + minver = new SemVer('0.0.0-0') + if (range.test(minver)) { + return minver + } + + minver = null + for (let i = 0; i < range.set.length; ++i) { + const comparators = range.set[i] + + let setMin = null + comparators.forEach((comparator) => { + // Clone to avoid manipulating the comparator's semver object. + const compver = new SemVer(comparator.semver.version) + switch (comparator.operator) { + case '>': + if (compver.prerelease.length === 0) { + compver.patch++ + } else { + compver.prerelease.push(0) + } + compver.raw = compver.format() + /* fallthrough */ + case '': + case '>=': + if (!setMin || gt(compver, setMin)) { + setMin = compver + } + break + case '<': + case '<=': + /* Ignore maximum versions */ + break + /* istanbul ignore next */ + default: + throw new Error(`Unexpected operation: ${comparator.operator}`) + } + }) + if (setMin && (!minver || gt(minver, setMin))) { + minver = setMin } + } + + if (minver && range.test(minver)) { + return minver + } + + return null } +module.exports = minVersion /***/ }), -/***/ 93369: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { +/***/ 69808: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { -"use strict"; +const SemVer = __nccwpck_require__(93097) +const Comparator = __nccwpck_require__(14658) +const { ANY } = Comparator +const Range = __nccwpck_require__(70434) +const satisfies = __nccwpck_require__(77477) +const gt = __nccwpck_require__(71381) +const lt = __nccwpck_require__(75330) +const lte = __nccwpck_require__(84698) +const gte = __nccwpck_require__(52498) -Object.defineProperty(exports, "__esModule", ({ value: true })); -exports.stringifyPnpmLockfile = exports.parsePnpmLockfile = void 0; -const pnpm_normalizer_1 = __nccwpck_require__(83463); -const package_json_1 = __nccwpck_require__(6500); -const object_sort_1 = __nccwpck_require__(95961); -const impl_1 = __nccwpck_require__(43265); -function parsePnpmLockfile(lockFileContent, builder) { - const data = (0, pnpm_normalizer_1.parseAndNormalizePnpmLockfile)(lockFileContent); - const isV6 = (0, pnpm_normalizer_1.isV6Lockfile)(data); - // we use key => node map to avoid duplicate work when parsing keys - const keyMap = new Map(); - addNodes(data, builder, keyMap, isV6); - addDependencies(data, builder, keyMap, isV6); -} -exports.parsePnpmLockfile = parsePnpmLockfile; -function addNodes(data, builder, keyMap, isV6) { - const nodes = new Map(); - Object.entries(data.packages).forEach(([key, snapshot]) => { - var _a, _b, _c; - const packageName = findPackageName(key, snapshot, data); - const rawVersion = findVersion(key, packageName); - const version = parseBaseVersion(rawVersion, isV6); - // we don't need to keep duplicates, we can just track the keys - const existingNode = (_a = nodes.get(packageName)) === null || _a === void 0 ? void 0 : _a.get(version); - if (existingNode) { - keyMap.set(key, existingNode); - return; - } - const node = { - type: 'npm', - name: version ? `npm:${packageName}@${version}` : `npm:${packageName}`, - data: { - version, - packageName, - hash: ((_b = snapshot.resolution) === null || _b === void 0 ? void 0 : _b['integrity']) || - (0, impl_1.hashArray)(((_c = snapshot.resolution) === null || _c === void 0 ? void 0 : _c['tarball']) - ? [snapshot.resolution['tarball']] - : [packageName, version]), - }, - }; - keyMap.set(key, node); - if (!nodes.has(packageName)) { - nodes.set(packageName, new Map([[version, node]])); - } - else { - nodes.get(packageName).set(version, node); - } - }); - const hoistedDeps = (0, pnpm_normalizer_1.loadPnpmHoistedDepsDefinition)(); - for (const [packageName, versionMap] of nodes.entries()) { - let hoistedNode; - if (versionMap.size === 1) { - hoistedNode = versionMap.values().next().value; - } - else { - const hoistedVersion = getHoistedVersion(hoistedDeps, packageName, isV6); - hoistedNode = versionMap.get(hoistedVersion); - } - if (hoistedNode) { - hoistedNode.name = `npm:${packageName}`; - } - versionMap.forEach((node) => { - builder.addExternalNode(node); - }); +const outside = (version, range, hilo, options) => { + version = new SemVer(version, options) + range = new Range(range, options) + + let gtfn, ltefn, ltfn, comp, ecomp + switch (hilo) { + case '>': + gtfn = gt + ltefn = lte + ltfn = lt + comp = '>' + ecomp = '>=' + break + case '<': + gtfn = lt + ltefn = gte + ltfn = gt + comp = '<' + ecomp = '<=' + break + default: + throw new TypeError('Must provide a hilo val of "<" or ">"') + } + + // If it satisfies the range it is not outside + if (satisfies(version, range, options)) { + return false + } + + // From now on, variable terms are as if we're in "gtr" mode. + // but note that everything is flipped for the "ltr" function. + + for (let i = 0; i < range.set.length; ++i) { + const comparators = range.set[i] + + let high = null + let low = null + + comparators.forEach((comparator) => { + if (comparator.semver === ANY) { + comparator = new Comparator('>=0.0.0') + } + high = high || comparator + low = low || comparator + if (gtfn(comparator.semver, high.semver, options)) { + high = comparator + } else if (ltfn(comparator.semver, low.semver, options)) { + low = comparator + } + }) + + // If the edge version comparator has a operator then our version + // isn't outside it + if (high.operator === comp || high.operator === ecomp) { + return false } -} -function getHoistedVersion(hoistedDependencies, packageName, isV6) { - let version = (0, package_json_1.getHoistedPackageVersion)(packageName); - if (!version) { - const key = Object.keys(hoistedDependencies).find((k) => k.startsWith(`/${packageName}/`)); - if (key) { - version = parseBaseVersion(getVersion(key, packageName), isV6); - } - else { - // pnpm might not hoist every package - // similarly those packages will not be available to be used via import - return; - } + + // If the lowest version comparator has an operator and our version + // is less than it then it isn't higher than the range + if ((!low.operator || low.operator === comp) && + ltefn(version, low.semver)) { + return false + } else if (low.operator === ecomp && ltfn(version, low.semver)) { + return false } - return version; -} -function addDependencies(data, builder, keyMap, isV6) { - Object.entries(data.packages).forEach(([key, snapshot]) => { - const node = keyMap.get(key); - [snapshot.dependencies, snapshot.optionalDependencies].forEach((section) => { - if (section) { - Object.entries(section).forEach(([name, versionRange]) => { - const version = parseBaseVersion(findVersion(versionRange, name), isV6); - const target = builder.graph.externalNodes[`npm:${name}@${version}`] || - builder.graph.externalNodes[`npm:${name}`]; - if (target) { - builder.addStaticDependency(node.name, target.name); - } - }); - } - }); - }); -} -function parseBaseVersion(rawVersion, isV6) { - return isV6 ? rawVersion.split('(')[0] : rawVersion.split('_')[0]; -} -function stringifyPnpmLockfile(graph, rootLockFileContent, packageJson) { - const data = (0, pnpm_normalizer_1.parseAndNormalizePnpmLockfile)(rootLockFileContent); - const { lockfileVersion, packages } = data; - const output = { - lockfileVersion, - importers: { - '.': mapRootSnapshot(packageJson, packages, graph.externalNodes), - }, - packages: (0, object_sort_1.sortObjectByKeys)(mapSnapshots(data.packages, graph.externalNodes)), - }; - return (0, pnpm_normalizer_1.stringifyToPnpmYaml)(output); -} -exports.stringifyPnpmLockfile = stringifyPnpmLockfile; -function mapSnapshots(packages, nodes) { - const result = {}; - Object.values(nodes).forEach((node) => { - const matchedKeys = findOriginalKeys(packages, node, { - returnFullKey: true, - }); - // the package manager doesn't check for types of dependencies - // so we can safely set all to prod - matchedKeys.forEach(([key, snapshot]) => { - snapshot.dev = false; - result[key] = snapshot; - }); - }); - return result; + } + return true } -function findOriginalKeys(packages, { data: { packageName, version } }, { returnFullKey } = {}) { - const matchedKeys = []; - for (const key of Object.keys(packages)) { - const snapshot = packages[key]; - // standard package - if (key.startsWith(`/${packageName}/${version}`)) { - matchedKeys.push([ - returnFullKey ? key : getVersion(key, packageName), - snapshot, - ]); - } - // tarball package - if (key === version) { - matchedKeys.push([version, snapshot]); - } - // alias package - if (versionIsAlias(key, version)) { - matchedKeys.push([key, snapshot]); - } + +module.exports = outside + + +/***/ }), + +/***/ 1259: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + +// given a set of versions and a range, create a "simplified" range +// that includes the same versions that the original range does +// If the original range is shorter than the simplified one, return that. +const satisfies = __nccwpck_require__(77477) +const compare = __nccwpck_require__(36208) +module.exports = (versions, range, options) => { + const set = [] + let first = null + let prev = null + const v = versions.sort((a, b) => compare(a, b, options)) + for (const version of v) { + const included = satisfies(version, range, options) + if (included) { + prev = version + if (!first) { + first = version + } + } else { + if (prev) { + set.push([first, prev]) + } + prev = null + first = null } - return matchedKeys; -} -// check if version has a form of npm:packageName@version and -// key starts with /packageName/version -function versionIsAlias(key, versionExpr) { - const PREFIX = 'npm:'; - if (!versionExpr.startsWith(PREFIX)) - return false; - const indexOfVersionSeparator = versionExpr.indexOf('@', PREFIX.length + 1); - const packageName = versionExpr.slice(PREFIX.length, indexOfVersionSeparator); - const version = versionExpr.slice(indexOfVersionSeparator + 1); - return key.startsWith(`/${packageName}/${version}`); -} -function mapRootSnapshot(packageJson, packages, nodes) { - const snapshot = { specifiers: {} }; - [ - 'dependencies', - 'optionalDependencies', - 'devDependencies', - 'peerDependencies', - ].forEach((depType) => { - if (packageJson[depType]) { - Object.keys(packageJson[depType]).forEach((packageName) => { - const version = packageJson[depType][packageName]; - const node = nodes[`npm:${packageName}@${version}`] || nodes[`npm:${packageName}`]; - snapshot.specifiers[packageName] = version; - // peer dependencies are mapped to dependencies - let section = depType === 'peerDependencies' ? 'dependencies' : depType; - snapshot[section] = snapshot[section] || {}; - snapshot[section][packageName] = findOriginalKeys(packages, node)[0][0]; - }); - } - }); - Object.keys(snapshot).forEach((key) => { - snapshot[key] = (0, object_sort_1.sortObjectByKeys)(snapshot[key]); - }); - return snapshot; + } + if (first) { + set.push([first, null]) + } + + const ranges = [] + for (const [min, max] of set) { + if (min === max) { + ranges.push(min) + } else if (!max && min === v[0]) { + ranges.push('*') + } else if (!max) { + ranges.push(`>=${min}`) + } else if (min === v[0]) { + ranges.push(`<=${max}`) + } else { + ranges.push(`${min} - ${max}`) + } + } + const simplified = ranges.join(' || ') + const original = typeof range.raw === 'string' ? range.raw : String(range) + return simplified.length < original.length ? simplified : range } -function findVersion(key, packageName) { - if (key.startsWith(`/${packageName}/`)) { - return getVersion(key, packageName); + + +/***/ }), + +/***/ 95865: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + +const Range = __nccwpck_require__(70434) +const Comparator = __nccwpck_require__(14658) +const { ANY } = Comparator +const satisfies = __nccwpck_require__(77477) +const compare = __nccwpck_require__(36208) + +// Complex range `r1 || r2 || ...` is a subset of `R1 || R2 || ...` iff: +// - Every simple range `r1, r2, ...` is a null set, OR +// - Every simple range `r1, r2, ...` which is not a null set is a subset of +// some `R1, R2, ...` +// +// Simple range `c1 c2 ...` is a subset of simple range `C1 C2 ...` iff: +// - If c is only the ANY comparator +// - If C is only the ANY comparator, return true +// - Else if in prerelease mode, return false +// - else replace c with `[>=0.0.0]` +// - If C is only the ANY comparator +// - if in prerelease mode, return true +// - else replace C with `[>=0.0.0]` +// - Let EQ be the set of = comparators in c +// - If EQ is more than one, return true (null set) +// - Let GT be the highest > or >= comparator in c +// - Let LT be the lowest < or <= comparator in c +// - If GT and LT, and GT.semver > LT.semver, return true (null set) +// - If any C is a = range, and GT or LT are set, return false +// - If EQ +// - If GT, and EQ does not satisfy GT, return true (null set) +// - If LT, and EQ does not satisfy LT, return true (null set) +// - If EQ satisfies every C, return true +// - Else return false +// - If GT +// - If GT.semver is lower than any > or >= comp in C, return false +// - If GT is >=, and GT.semver does not satisfy every C, return false +// - If GT.semver has a prerelease, and not in prerelease mode +// - If no C has a prerelease and the GT.semver tuple, return false +// - If LT +// - If LT.semver is greater than any < or <= comp in C, return false +// - If LT is <=, and LT.semver does not satisfy every C, return false +// - If GT.semver has a prerelease, and not in prerelease mode +// - If no C has a prerelease and the LT.semver tuple, return false +// - Else return true + +const subset = (sub, dom, options = {}) => { + if (sub === dom) { + return true + } + + sub = new Range(sub, options) + dom = new Range(dom, options) + let sawNonNull = false + + OUTER: for (const simpleSub of sub.set) { + for (const simpleDom of dom.set) { + const isSub = simpleSubset(simpleSub, simpleDom, options) + sawNonNull = sawNonNull || isSub !== null + if (isSub) { + continue OUTER + } } - // for alias packages prepend with "npm:" - if (key.startsWith('/')) { - const aliasName = key.slice(1, key.lastIndexOf('/')); - const version = getVersion(key, aliasName); - return `npm:${aliasName}@${version}`; + // the null set is a subset of everything, but null simple ranges in + // a complex range should be ignored. so if we saw a non-null range, + // then we know this isn't a subset, but if EVERY simple range was null, + // then it is a subset. + if (sawNonNull) { + return false } - // for tarball package the entire key is the version spec - return key; + } + return true } -function findPackageName(key, snapshot, data) { - const matchPropValue = (record) => { - if (!record) { - return undefined; - } - const index = Object.values(record).findIndex((version) => version === key); - if (index > -1) { - return Object.keys(record)[index]; - } - }; - const matchedDependencyName = (importer) => { - return (matchPropValue(importer.dependencies) || - matchPropValue(importer.optionalDependencies) || - matchPropValue(importer.peerDependencies)); - }; - // snapshot already has a name - if (snapshot.name) { - return snapshot.name; + +const minimumVersionWithPreRelease = [new Comparator('>=0.0.0-0')] +const minimumVersion = [new Comparator('>=0.0.0')] + +const simpleSubset = (sub, dom, options) => { + if (sub === dom) { + return true + } + + if (sub.length === 1 && sub[0].semver === ANY) { + if (dom.length === 1 && dom[0].semver === ANY) { + return true + } else if (options.includePrerelease) { + sub = minimumVersionWithPreRelease + } else { + sub = minimumVersion } - // it'a a root dependency - const rootDependencyName = matchedDependencyName(data.importers['.']) || - // only root importers have devDependencies - matchPropValue(data.importers['.'].devDependencies); - if (rootDependencyName) { - return rootDependencyName; + } + + if (dom.length === 1 && dom[0].semver === ANY) { + if (options.includePrerelease) { + return true + } else { + dom = minimumVersion } - // find a snapshot that has a dependency that points to this snapshot - const snapshots = Object.values(data.packages); - for (let i = 0; i < snapshots.length; i++) { - const dependencyName = matchedDependencyName(snapshots[i]); - if (dependencyName) { - return dependencyName; - } + } + + const eqSet = new Set() + let gt, lt + for (const c of sub) { + if (c.operator === '>' || c.operator === '>=') { + gt = higherGT(gt, c, options) + } else if (c.operator === '<' || c.operator === '<=') { + lt = lowerLT(lt, c, options) + } else { + eqSet.add(c.semver) } - return extractNameFromKey(key); -} -function getVersion(key, packageName) { - const KEY_NAME_SEPARATOR_LENGTH = 2; // leading and trailing slash - return key.slice(packageName.length + KEY_NAME_SEPARATOR_LENGTH); -} -function extractNameFromKey(key) { - // if package name contains org e.g. "/@babel/runtime/7.12.5" - // we want slice until the third slash - if (key.startsWith('/@')) { - // find the position of the '/' after org name - const startFrom = key.indexOf('/', 1); - return key.slice(1, key.indexOf('/', startFrom + 1)); + } + + if (eqSet.size > 1) { + return null + } + + let gtltComp + if (gt && lt) { + gtltComp = compare(gt.semver, lt.semver, options) + if (gtltComp > 0) { + return null + } else if (gtltComp === 0 && (gt.operator !== '>=' || lt.operator !== '<=')) { + return null } - if (key.startsWith('/')) { - // if package has just a name e.g. "/react/7.12.5..." - return key.slice(1, key.indexOf('/', 1)); + } + + // will iterate one or zero times + for (const eq of eqSet) { + if (gt && !satisfies(eq, String(gt), options)) { + return null } - return key; -} + if (lt && !satisfies(eq, String(lt), options)) { + return null + } -/***/ }), + for (const c of dom) { + if (!satisfies(eq, String(c), options)) { + return false + } + } -/***/ 38770: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { + return true + } -"use strict"; + let higher, lower + let hasDomLT, hasDomGT + // if the subset has a prerelease, we need a comparator in the superset + // with the same tuple and a prerelease, or it's not a subset + let needDomLTPre = lt && + !options.includePrerelease && + lt.semver.prerelease.length ? lt.semver : false + let needDomGTPre = gt && + !options.includePrerelease && + gt.semver.prerelease.length ? gt.semver : false + // exception: <1.2.3-0 is the same as <1.2.3 + if (needDomLTPre && needDomLTPre.prerelease.length === 1 && + lt.operator === '<' && needDomLTPre.prerelease[0] === 0) { + needDomLTPre = false + } -Object.defineProperty(exports, "__esModule", ({ value: true })); -exports.pruneProjectGraph = void 0; -const semver_1 = __nccwpck_require__(56192); -const project_graph_builder_1 = __nccwpck_require__(14812); -const operators_1 = __nccwpck_require__(97607); -/** - * Prune project graph's external nodes and their dependencies - * based on the pruned package.json - */ -function pruneProjectGraph(graph, prunedPackageJson) { - const builder = new project_graph_builder_1.ProjectGraphBuilder(); - const combinedDependencies = normalizeDependencies(prunedPackageJson, graph); - addNodesAndDependencies(graph, combinedDependencies, builder); - // for NPM (as well as the graph consistency) - // we need to distinguish between hoisted and non-hoisted dependencies - rehoistNodes(graph, combinedDependencies, builder); - return builder.getUpdatedProjectGraph(); -} -exports.pruneProjectGraph = pruneProjectGraph; -// ensure that dependency ranges from package.json (e.g. ^1.0.0) -// are replaced with the actual version based on the available nodes (e.g. 1.0.1) -function normalizeDependencies(packageJson, graph) { - const { dependencies, devDependencies, optionalDependencies, peerDependencies, } = packageJson; - const combinedDependencies = Object.assign(Object.assign(Object.assign(Object.assign({}, dependencies), devDependencies), optionalDependencies), peerDependencies); - Object.entries(combinedDependencies).forEach(([packageName, versionRange]) => { - if (graph.externalNodes[`npm:${packageName}@${versionRange}`]) { - return; - } - if (graph.externalNodes[`npm:${packageName}`] && - graph.externalNodes[`npm:${packageName}`].data.version === versionRange) { - return; - } - // otherwise we need to find the correct version - const node = findNodeMatchingVersion(graph, packageName, versionRange); - if (node) { - combinedDependencies[packageName] = node.data.version; + for (const c of dom) { + hasDomGT = hasDomGT || c.operator === '>' || c.operator === '>=' + hasDomLT = hasDomLT || c.operator === '<' || c.operator === '<=' + if (gt) { + if (needDomGTPre) { + if (c.semver.prerelease && c.semver.prerelease.length && + c.semver.major === needDomGTPre.major && + c.semver.minor === needDomGTPre.minor && + c.semver.patch === needDomGTPre.patch) { + needDomGTPre = false } - else { - throw new Error(`Pruned lock file creation failed. The following package was not found in the root lock file: ${packageName}@${versionRange}`); + } + if (c.operator === '>' || c.operator === '>=') { + higher = higherGT(gt, c, options) + if (higher === c && higher !== gt) { + return false } - }); - return combinedDependencies; -} -function findNodeMatchingVersion(graph, packageName, versionExpr) { - if (versionExpr === '*') { - return graph.externalNodes[`npm:${packageName}`]; - } - const nodes = Object.values(graph.externalNodes) - .filter((n) => n.data.packageName === packageName) - .sort((a, b) => ((0, semver_1.gte)(b.data.version, a.data.version) ? 1 : -1)); - if (versionExpr === 'latest') { - return nodes.sort((a, b) => +(0, semver_1.gte)(b.data.version, a.data.version))[0]; - } - if (graph.externalNodes[`npm:${packageName}`] && - (0, semver_1.satisfies)(graph.externalNodes[`npm:${packageName}`].data.version, versionExpr)) { - return graph.externalNodes[`npm:${packageName}`]; - } - return nodes.find((n) => (0, semver_1.satisfies)(n.data.version, versionExpr)); -} -function addNodesAndDependencies(graph, packageJsonDeps, builder) { - Object.entries(packageJsonDeps).forEach(([name, version]) => { - const node = graph.externalNodes[`npm:${name}@${version}`] || - graph.externalNodes[`npm:${name}`]; - traverseNode(graph, builder, node); - }); -} -function traverseNode(graph, builder, node) { - var _a; - if (builder.graph.externalNodes[node.name]) { - return; + } else if (gt.operator === '>=' && !satisfies(gt.semver, String(c), options)) { + return false + } } - builder.addExternalNode(node); - (_a = graph.dependencies[node.name]) === null || _a === void 0 ? void 0 : _a.forEach((dep) => { - const depNode = graph.externalNodes[dep.target]; - traverseNode(graph, builder, depNode); - builder.addStaticDependency(node.name, dep.target); - }); -} -function rehoistNodes(graph, packageJsonDeps, builder) { - const packagesToRehoist = new Map(); - // find all packages that need to be rehoisted - Object.values(graph.externalNodes).forEach((node) => { - if (node.name === `npm:${node.data.packageName}` && - !builder.graph.externalNodes[node.name]) { - const nestedNodes = Object.values(builder.graph.externalNodes).filter((n) => n.data.packageName === node.data.packageName); - if (nestedNodes.length > 0) { - packagesToRehoist.set(node.data.packageName, nestedNodes); - } - } - }); - // invert dependencies for easier traversal back - const invertedGraph = (0, operators_1.reverse)(builder.graph); - const invBuilder = new project_graph_builder_1.ProjectGraphBuilder(invertedGraph, {}); - // find new hoisted version - packagesToRehoist.forEach((nestedNodes) => { - if (nestedNodes.length === 1) { - switchNodeToHoisted(nestedNodes[0], builder, invBuilder); - } - else { - let minDistance = Infinity; - let closest; - nestedNodes.forEach((node) => { - const distance = pathLengthToIncoming(node, packageJsonDeps, builder, invertedGraph); - if (distance < minDistance) { - minDistance = distance; - closest = node; - } - }); - switchNodeToHoisted(closest, builder, invBuilder); - } - }); -} -function switchNodeToHoisted(node, builder, invBuilder) { - // make a copy of current name, all the dependencies and dependents - const previousName = node.name; - const targets = (builder.graph.dependencies[node.name] || []).map((d) => d.target); - const sources = Object.keys(builder.graph.dependencies).filter((name) => builder.graph.dependencies[name].some((d) => d.target === previousName)); - builder.removeNode(node.name); - invBuilder.removeNode(node.name); - // modify the node and re-add it - node.name = `npm:${node.data.packageName}`; - builder.addExternalNode(node); - invBuilder.addExternalNode(node); - targets.forEach((target) => { - builder.addStaticDependency(node.name, target); - invBuilder.addStaticDependency(target, node.name); - }); - sources.forEach((source) => { - builder.addStaticDependency(source, node.name); - invBuilder.addStaticDependency(node.name, source); - }); -} -// BFS to find the shortest path to a dependency specified in package.json -// package version with the shortest path is the one that should be hoisted -function pathLengthToIncoming(node, packageJsonDeps, builder, invertedGraph) { - const visited = new Set([node.name]); - const queue = [[node, 0]]; - while (queue.length > 0) { - const [current, distance] = queue.shift(); - if (packageJsonDeps[current.data.packageName] === current.data.version) { - return distance; + if (lt) { + if (needDomLTPre) { + if (c.semver.prerelease && c.semver.prerelease.length && + c.semver.major === needDomLTPre.major && + c.semver.minor === needDomLTPre.minor && + c.semver.patch === needDomLTPre.patch) { + needDomLTPre = false } - for (let { target } of invertedGraph.dependencies[current.name] || []) { - if (!visited.has(target)) { - visited.add(target); - queue.push([builder.graph.externalNodes[target], distance + 1]); - } + } + if (c.operator === '<' || c.operator === '<=') { + lower = lowerLT(lt, c, options) + if (lower === c && lower !== lt) { + return false } + } else if (lt.operator === '<=' && !satisfies(lt.semver, String(c), options)) { + return false + } } -} - + if (!c.operator && (lt || gt) && gtltComp !== 0) { + return false + } + } -/***/ }), + // if there was a < or >, and nothing in the dom, then must be false + // UNLESS it was limited by another range in the other direction. + // Eg, >1.0.0 <1.0.1 is still a subset of <2.0.0 + if (gt && hasDomLT && !lt && gtltComp !== 0) { + return false + } -/***/ 6500: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { + if (lt && hasDomGT && !gt && gtltComp !== 0) { + return false + } -"use strict"; + // we needed a prerelease range in a specific tuple, but didn't get one + // then this isn't a subset. eg >=1.2.3-pre is not a subset of >=1.0.0, + // because it includes prereleases in the 1.2.3 tuple + if (needDomGTPre || needDomLTPre) { + return false + } -Object.defineProperty(exports, "__esModule", ({ value: true })); -exports.normalizePackageJson = exports.getHoistedPackageVersion = void 0; -const fs_1 = __nccwpck_require__(57147); -const workspace_root_1 = __nccwpck_require__(65766); -/** - * Get version of hoisted package if available - */ -function getHoistedPackageVersion(packageName) { - var _a; - const fullPath = `${workspace_root_1.workspaceRoot}/node_modules/${packageName}/package.json`; - if ((0, fs_1.existsSync)(fullPath)) { - const content = (0, fs_1.readFileSync)(fullPath, 'utf-8'); - return (_a = JSON.parse(content)) === null || _a === void 0 ? void 0 : _a.version; - } - return; + return true } -exports.getHoistedPackageVersion = getHoistedPackageVersion; -/** - * Strip off non-pruning related fields from package.json - */ -function normalizePackageJson(packageJson) { - const { name, version, license, dependencies, devDependencies, peerDependencies, peerDependenciesMeta, optionalDependencies, } = packageJson; - return { - name, - version, - license, - dependencies, - devDependencies, - peerDependencies, - peerDependenciesMeta, - optionalDependencies, - }; -} -exports.normalizePackageJson = normalizePackageJson; - -/***/ }), - -/***/ 83463: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { - -"use strict"; - -/** - * This file contains the logic to convert pnpm lockfile to a standard format. - * It will convert inline specifiers to the separate specifiers format and ensure importers are present. - */ -Object.defineProperty(exports, "__esModule", ({ value: true })); -exports.stringifyToPnpmYaml = exports.parseAndNormalizePnpmLockfile = exports.loadPnpmHoistedDepsDefinition = exports.isV6Lockfile = void 0; -const tslib_1 = __nccwpck_require__(51796); -const js_yaml_1 = __nccwpck_require__(89777); -const fs_1 = __nccwpck_require__(57147); -const workspace_root_1 = __nccwpck_require__(65766); -const semver_1 = __nccwpck_require__(56192); -function isV6Lockfile(data) { - return data.lockfileVersion.toString().startsWith('6.'); -} -exports.isV6Lockfile = isV6Lockfile; -function loadPnpmHoistedDepsDefinition() { - var _a, _b; - const fullPath = `${workspace_root_1.workspaceRoot}/node_modules/.modules.yaml`; - if ((0, fs_1.existsSync)(fullPath)) { - const content = (0, fs_1.readFileSync)(fullPath, 'utf-8'); - return (_b = (_a = (0, js_yaml_1.load)(content)) === null || _a === void 0 ? void 0 : _a.hoistedDependencies) !== null && _b !== void 0 ? _b : {}; - } - else { - throw new Error(`Could not find ".modules.yaml" at "${fullPath}"`); - } -} -exports.loadPnpmHoistedDepsDefinition = loadPnpmHoistedDepsDefinition; -/************************************************************************* - * THE FOLLOWING CODE IS COPIED & simplified FROM @pnpm/lockfile-file for convenience - *************************************************************************/ -/** - * Parsing and mapping logic from pnpm lockfile `read` function - * https://github.com/pnpm/pnpm/blob/af3e5559d377870d4c3d303429b3ed1a4e64fedc/lockfile/lockfile-file/src/read.ts#L91 - */ -function parseAndNormalizePnpmLockfile(content) { - const lockFileData = (0, js_yaml_1.load)(content); - return revertFromInlineSpecifiersFormatIfNecessary(convertFromLockfileFileMutable(lockFileData)); -} -exports.parseAndNormalizePnpmLockfile = parseAndNormalizePnpmLockfile; -/** - * Reverts changes from the "forceSharedFormat" write option if necessary. - * https://github.com/pnpm/pnpm/blob/af3e5559d377870d4c3d303429b3ed1a4e64fedc/lockfile/lockfile-file/src/read.ts#L234 - */ -function convertFromLockfileFileMutable(lockfileFile) { - var _a; - if (typeof (lockfileFile === null || lockfileFile === void 0 ? void 0 : lockfileFile['importers']) === 'undefined') { - lockfileFile.importers = { - '.': { - specifiers: (_a = lockfileFile['specifiers']) !== null && _a !== void 0 ? _a : {}, - dependenciesMeta: lockfileFile['dependenciesMeta'], - publishDirectory: lockfileFile['publishDirectory'], - }, - }; - delete lockfileFile.specifiers; - for (const depType of DEPENDENCIES_FIELDS) { - if (lockfileFile[depType] != null) { - lockfileFile.importers['.'][depType] = lockfileFile[depType]; - delete lockfileFile[depType]; - } - } - } - return lockfileFile; -} -// https://github.com/pnpm/pnpm/blob/af3e5559d377870d4c3d303429b3ed1a4e64fedc/lockfile/lockfile-file/src/write.ts#L27 -const LOCKFILE_YAML_FORMAT = { - blankLines: true, - lineWidth: 1000, - noCompatMode: true, - noRefs: true, - sortKeys: false, -}; -/** - * Mapping and writing logic from pnpm lockfile `write` function - * https://github.com/pnpm/pnpm/blob/af3e5559d377870d4c3d303429b3ed1a4e64fedc/lockfile/lockfile-file/src/write.ts#L77 - */ -function stringifyToPnpmYaml(lockfile) { - const isLockfileV6 = isV6Lockfile(lockfile); - const adaptedLockfile = isLockfileV6 - ? convertToInlineSpecifiersFormat(lockfile) - : lockfile; - return (0, js_yaml_1.dump)(sortLockfileKeys(normalizeLockfile(adaptedLockfile, isLockfileV6)), LOCKFILE_YAML_FORMAT); -} -exports.stringifyToPnpmYaml = stringifyToPnpmYaml; -// https://github.com/pnpm/pnpm/blob/af3e5559d377870d4c3d303429b3ed1a4e64fedc/lockfile/lockfile-file/src/write.ts#L106 -function normalizeLockfile(lockfile, isLockfileV6) { - let lockfileToSave; - if (Object.keys(lockfile.importers).length === 1 && lockfile.importers['.']) { - lockfileToSave = Object.assign(Object.assign({}, lockfile), lockfile.importers['.']); - delete lockfileToSave.importers; - for (const depType of DEPENDENCIES_FIELDS) { - if (isEmpty(lockfileToSave[depType])) { - delete lockfileToSave[depType]; - } - } - if (isEmpty(lockfileToSave.packages) || lockfileToSave.packages == null) { - delete lockfileToSave.packages; - } - } - else { - lockfileToSave = Object.assign(Object.assign({}, lockfile), { importers: mapValues(lockfile.importers, (importer) => { - var _a, _b, _c; - const normalizedImporter = {}; - if (!isEmpty((_a = importer.specifiers) !== null && _a !== void 0 ? _a : {}) || !isLockfileV6) { - normalizedImporter['specifiers'] = (_b = importer.specifiers) !== null && _b !== void 0 ? _b : {}; - } - if (importer.dependenciesMeta != null && - !isEmpty(importer.dependenciesMeta)) { - normalizedImporter['dependenciesMeta'] = importer.dependenciesMeta; - } - for (const depType of DEPENDENCIES_FIELDS) { - if (!isEmpty((_c = importer[depType]) !== null && _c !== void 0 ? _c : {})) { - normalizedImporter[depType] = importer[depType]; - } - } - if (importer.publishDirectory) { - normalizedImporter.publishDirectory = importer.publishDirectory; - } - return normalizedImporter; - }) }); - if (isEmpty(lockfileToSave.packages) || lockfileToSave.packages == null) { - delete lockfileToSave.packages; - } - } - if (lockfileToSave.time) { - lockfileToSave.time = (isLockfileV6 ? pruneTimeInLockfileV6 : pruneTime)(lockfileToSave.time, lockfile.importers); - } - if (lockfileToSave.overrides != null && isEmpty(lockfileToSave.overrides)) { - delete lockfileToSave.overrides; - } - if (lockfileToSave.patchedDependencies != null && - isEmpty(lockfileToSave.patchedDependencies)) { - delete lockfileToSave.patchedDependencies; - } - if (lockfileToSave.neverBuiltDependencies != null) { - if (isEmpty(lockfileToSave.neverBuiltDependencies)) { - delete lockfileToSave.neverBuiltDependencies; - } - else { - lockfileToSave.neverBuiltDependencies = - lockfileToSave.neverBuiltDependencies.sort(); - } - } - if (lockfileToSave.onlyBuiltDependencies != null) { - lockfileToSave.onlyBuiltDependencies = - lockfileToSave.onlyBuiltDependencies.sort(); - } - if (!lockfileToSave.packageExtensionsChecksum) { - delete lockfileToSave.packageExtensionsChecksum; - } - return lockfileToSave; -} -// https://github.com/pnpm/pnpm/blob/af3e5559d377870d4c3d303429b3ed1a4e64fedc/lockfile/lockfile-file/src/write.ts#L173 -function pruneTimeInLockfileV6(time, importers) { - var _a; - const rootDepPaths = new Set(); - for (const importer of Object.values(importers)) { - for (const depType of DEPENDENCIES_FIELDS) { - for (let [depName, ref] of Object.entries((_a = importer[depType]) !== null && _a !== void 0 ? _a : {})) { - let version; - if (ref['version']) { - version = ref['version']; - } - else { - version = ref; - } - const suffixStart = version.indexOf('('); - const refWithoutPeerSuffix = suffixStart === -1 ? version : version.slice(0, suffixStart); - const depPath = refToRelative(refWithoutPeerSuffix, depName); - if (!depPath) - continue; - rootDepPaths.add(depPath); - } - } - } - return pickBy((prop) => rootDepPaths.has(prop), time); -} -// https://github.com/pnpm/pnpm/blob/af3e5559d377870d4c3d303429b3ed1a4e64fedc/lockfile/lockfile-file/src/write.ts#L191 -function refToRelative(reference, pkgName) { - if (reference.startsWith('link:')) { - return null; - } - if (reference.startsWith('file:')) { - return reference; - } - if (!reference.includes('/') || - !reference.replace(/(\([^)]+\))+$/, '').includes('/')) { - return `/${pkgName}@${reference}`; - } - return reference; -} -// https://github.com/pnpm/pnpm/blob/af3e5559d377870d4c3d303429b3ed1a4e64fedc/lockfile/lockfile-file/src/write.ts#L207 -function pruneTime(time, importers) { - var _a; - const rootDepPaths = new Set(); - for (const importer of Object.values(importers)) { - for (const depType of DEPENDENCIES_FIELDS) { - for (let [depName, ref] of Object.entries((_a = importer[depType]) !== null && _a !== void 0 ? _a : {})) { - let version; - if (ref['version']) { - version = ref['version']; - } - else { - version = ref; - } - const suffixStart = version.indexOf('_'); - const refWithoutPeerSuffix = suffixStart === -1 ? version : version.slice(0, suffixStart); - const depPath = dpRefToRelative(refWithoutPeerSuffix, depName); - if (!depPath) - continue; - rootDepPaths.add(depPath); - } - } - } - return pickBy((depPath) => rootDepPaths.has(depPath), time); -} -// https://github.com/pnpm/pnpm/blob/af3e5559d377870d4c3d303429b3ed1a4e64fedc/lockfile/lockfile-file/src/sortLockfileKeys.ts#L34 -const ROOT_KEYS_ORDER = { - lockfileVersion: 1, - // only and never are conflict options. - neverBuiltDependencies: 2, - onlyBuiltDependencies: 2, - overrides: 3, - packageExtensionsChecksum: 4, - patchedDependencies: 5, - specifiers: 10, - dependencies: 11, - optionalDependencies: 12, - devDependencies: 13, - dependenciesMeta: 14, - importers: 15, - packages: 16, -}; -// https://github.com/pnpm/pnpm/blob/af3e5559d377870d4c3d303429b3ed1a4e64fedc/lockfile/lockfile-file/src/sortLockfileKeys.ts#L60 -function sortLockfileKeys(lockfile) { - let sortedLockfile = {}; - const sortedKeys = Object.keys(lockfile).sort((a, b) => ROOT_KEYS_ORDER[a] - ROOT_KEYS_ORDER[b]); - for (const key of sortedKeys) { - sortedLockfile[key] = lockfile[key]; - } - return sortedLockfile; -} -/** - * Types from https://github.com/pnpm/pnpm/blob/af3e5559d377870d4c3d303429b3ed1a4e64fedc/lockfile/lockfile-file/src/experiments/InlineSpecifiersLockfile.ts - */ -const INLINE_SPECIFIERS_FORMAT_LOCKFILE_VERSION_SUFFIX = '-inlineSpecifiers'; -// https://github.com/pnpm/pnpm/blob/af3e5559d377870d4c3d303429b3ed1a4e64fedc/lockfile/lockfile-file/src/experiments/inlineSpecifiersLockfileConverters.ts#L10 -function isExperimentalInlineSpecifiersFormat(lockfile) { - const { lockfileVersion } = lockfile; - return (lockfileVersion.toString().startsWith('6.') || - (typeof lockfileVersion === 'string' && - lockfileVersion.endsWith(INLINE_SPECIFIERS_FORMAT_LOCKFILE_VERSION_SUFFIX))); -} -// https://github.com/pnpm/pnpm/blob/af3e5559d377870d4c3d303429b3ed1a4e64fedc/lockfile/lockfile-file/src/experiments/inlineSpecifiersLockfileConverters.ts#L17 -function convertToInlineSpecifiersFormat(lockfile) { - var _a, _b; - let importers = lockfile.importers; - let packages = lockfile.packages; - if (isV6Lockfile(lockfile)) { - importers = Object.fromEntries(Object.entries((_a = lockfile.importers) !== null && _a !== void 0 ? _a : {}).map(([importerId, pkgSnapshot]) => { - const newSnapshot = Object.assign({}, pkgSnapshot); - if (newSnapshot.dependencies != null) { - newSnapshot.dependencies = mapValues(newSnapshot.dependencies, convertOldRefToNewRef); - } - if (newSnapshot.optionalDependencies != null) { - newSnapshot.optionalDependencies = mapValues(newSnapshot.optionalDependencies, convertOldRefToNewRef); - } - if (newSnapshot.devDependencies != null) { - newSnapshot.devDependencies = mapValues(newSnapshot.devDependencies, convertOldRefToNewRef); - } - return [importerId, newSnapshot]; - })); - packages = Object.fromEntries(Object.entries((_b = lockfile.packages) !== null && _b !== void 0 ? _b : {}).map(([depPath, pkgSnapshot]) => { - const newSnapshot = Object.assign({}, pkgSnapshot); - if (newSnapshot.dependencies != null) { - newSnapshot.dependencies = mapValues(newSnapshot.dependencies, convertOldRefToNewRef); - } - if (newSnapshot.optionalDependencies != null) { - newSnapshot.optionalDependencies = mapValues(newSnapshot.optionalDependencies, convertOldRefToNewRef); - } - return [convertOldDepPathToNewDepPath(depPath), newSnapshot]; - })); - } - const newLockfile = Object.assign(Object.assign({}, lockfile), { packages, lockfileVersion: isV6Lockfile(lockfile) - ? lockfile.lockfileVersion.toString() - : lockfile.lockfileVersion - .toString() - .endsWith(INLINE_SPECIFIERS_FORMAT_LOCKFILE_VERSION_SUFFIX) - ? lockfile.lockfileVersion.toString() - : `${lockfile.lockfileVersion}${INLINE_SPECIFIERS_FORMAT_LOCKFILE_VERSION_SUFFIX}`, importers: mapValues(importers, convertProjectSnapshotToInlineSpecifiersFormat) }); - if (isV6Lockfile(lockfile) && newLockfile.time) { - newLockfile.time = Object.fromEntries(Object.entries(newLockfile.time).map(([depPath, time]) => [ - convertOldDepPathToNewDepPath(depPath), - time, - ])); - } - return newLockfile; -} -// https://github.com/pnpm/pnpm/blob/af3e5559d377870d4c3d303429b3ed1a4e64fedc/lockfile/lockfile-file/src/experiments/inlineSpecifiersLockfileConverters.ts#L72 -function convertOldDepPathToNewDepPath(oldDepPath) { - const parsedDepPath = dpParse(oldDepPath); - if (!parsedDepPath.name || !parsedDepPath.version) - return oldDepPath; - let newDepPath = `/${parsedDepPath.name}@${parsedDepPath.version}`; - if (parsedDepPath.peersSuffix) { - if (parsedDepPath.peersSuffix.startsWith('(')) { - newDepPath += parsedDepPath.peersSuffix; - } - else { - newDepPath += `_${parsedDepPath.peersSuffix}`; - } - } - if (parsedDepPath.host) { - newDepPath = `${parsedDepPath.host}${newDepPath}`; - } - return newDepPath; -} -// https://github.com/pnpm/pnpm/blob/af3e5559d377870d4c3d303429b3ed1a4e64fedc/lockfile/lockfile-file/src/experiments/inlineSpecifiersLockfileConverters.ts#L89 -function convertOldRefToNewRef(oldRef) { - if (oldRef.startsWith('link:') || oldRef.startsWith('file:')) { - return oldRef; - } - if (oldRef.includes('/')) { - return convertOldDepPathToNewDepPath(oldRef); - } - return oldRef; -} -// https://github.com/pnpm/pnpm/blob/af3e5559d377870d4c3d303429b3ed1a4e64fedc/lockfile/lockfile-file/src/experiments/inlineSpecifiersLockfileConverters.ts#L99 -function revertFromInlineSpecifiersFormatIfNecessary(lockfile) { - return isExperimentalInlineSpecifiersFormat(lockfile) - ? revertFromInlineSpecifiersFormat(lockfile) - : lockfile; -} -// https://github.com/pnpm/pnpm/blob/af3e5559d377870d4c3d303429b3ed1a4e64fedc/lockfile/lockfile-file/src/experiments/inlineSpecifiersLockfileConverters.ts#L105 -function revertFromInlineSpecifiersFormat(lockfile) { - var _a; - const { lockfileVersion, importers } = lockfile, rest = tslib_1.__rest(lockfile, ["lockfileVersion", "importers"]); - const originalVersionStr = lockfileVersion.replace(INLINE_SPECIFIERS_FORMAT_LOCKFILE_VERSION_SUFFIX, ''); - const originalVersion = Number(originalVersionStr); - if (isNaN(originalVersion)) { - throw new Error(`Unable to revert lockfile from inline specifiers format. Invalid version parsed: ${originalVersionStr}`); - } - let revertedImporters = mapValues(importers, revertProjectSnapshot); - let packages = lockfile.packages; - if (originalVersion === 6) { - revertedImporters = Object.fromEntries(Object.entries(revertedImporters !== null && revertedImporters !== void 0 ? revertedImporters : {}).map(([importerId, pkgSnapshot]) => { - const newSnapshot = Object.assign({}, pkgSnapshot); - if (newSnapshot.dependencies != null) { - newSnapshot.dependencies = mapValues(newSnapshot.dependencies, convertNewRefToOldRef); - } - if (newSnapshot.optionalDependencies != null) { - newSnapshot.optionalDependencies = mapValues(newSnapshot.optionalDependencies, convertNewRefToOldRef); - } - if (newSnapshot.devDependencies != null) { - newSnapshot.devDependencies = mapValues(newSnapshot.devDependencies, convertNewRefToOldRef); - } - return [importerId, newSnapshot]; - })); - packages = Object.fromEntries(Object.entries((_a = lockfile.packages) !== null && _a !== void 0 ? _a : {}).map(([depPath, pkgSnapshot]) => { - const newSnapshot = Object.assign({}, pkgSnapshot); - if (newSnapshot.dependencies != null) { - newSnapshot.dependencies = mapValues(newSnapshot.dependencies, convertNewRefToOldRef); - } - if (newSnapshot.optionalDependencies != null) { - newSnapshot.optionalDependencies = mapValues(newSnapshot.optionalDependencies, convertNewRefToOldRef); - } - return [convertNewDepPathToOldDepPath(depPath), newSnapshot]; - })); - } - const newLockfile = Object.assign(Object.assign({}, rest), { lockfileVersion: lockfileVersion.endsWith(INLINE_SPECIFIERS_FORMAT_LOCKFILE_VERSION_SUFFIX) - ? originalVersion - : lockfileVersion, packages, importers: revertedImporters }); - if (originalVersion === 6 && newLockfile.time) { - newLockfile.time = Object.fromEntries(Object.entries(newLockfile.time).map(([depPath, time]) => [ - convertNewDepPathToOldDepPath(depPath), - time, - ])); - } - return newLockfile; -} -// https://github.com/pnpm/pnpm/blob/af3e5559d377870d4c3d303429b3ed1a4e64fedc/lockfile/lockfile-file/src/experiments/inlineSpecifiersLockfileConverters.ts#L162 -function convertNewDepPathToOldDepPath(oldDepPath) { - if (!oldDepPath.includes('@', 2)) - return oldDepPath; - const index = oldDepPath.indexOf('@', oldDepPath.indexOf('/@') + 2); - if (oldDepPath.includes('(') && index > oldDepPath.indexOf('(')) - return oldDepPath; - return `${oldDepPath.substring(0, index)}/${oldDepPath.substring(index + 1)}`; -} -// https://github.com/pnpm/pnpm/blob/af3e5559d377870d4c3d303429b3ed1a4e64fedc/lockfile/lockfile-file/src/experiments/inlineSpecifiersLockfileConverters.ts#L169 -function convertNewRefToOldRef(oldRef) { - if (oldRef.startsWith('link:') || oldRef.startsWith('file:')) { - return oldRef; - } - if (oldRef.includes('@')) { - return convertNewDepPathToOldDepPath(oldRef); - } - return oldRef; -} -// https://github.com/pnpm/pnpm/blob/af3e5559d377870d4c3d303429b3ed1a4e64fedc/lockfile/lockfile-file/src/experiments/inlineSpecifiersLockfileConverters.ts#L179 -function convertProjectSnapshotToInlineSpecifiersFormat(projectSnapshot) { - const { specifiers } = projectSnapshot, rest = tslib_1.__rest(projectSnapshot, ["specifiers"]); - const convertBlock = (block) => block != null - ? convertResolvedDependenciesToInlineSpecifiersFormat(block, { - specifiers, - }) - : block; - return Object.assign(Object.assign({}, rest), { dependencies: convertBlock(projectSnapshot.dependencies), optionalDependencies: convertBlock(projectSnapshot.optionalDependencies), devDependencies: convertBlock(projectSnapshot.devDependencies) }); -} -// https://github.com/pnpm/pnpm/blob/af3e5559d377870d4c3d303429b3ed1a4e64fedc/lockfile/lockfile-file/src/experiments/inlineSpecifiersLockfileConverters.ts#L195 -function convertResolvedDependenciesToInlineSpecifiersFormat(resolvedDependencies, { specifiers }) { - return mapValues(resolvedDependencies, (version, depName) => ({ - specifier: specifiers[depName], - version, - })); -} -// https://github.com/pnpm/pnpm/blob/af3e5559d377870d4c3d303429b3ed1a4e64fedc/lockfile/lockfile-file/src/experiments/inlineSpecifiersLockfileConverters.ts#L205 -function revertProjectSnapshot(from) { - const specifiers = {}; - function moveSpecifiers(from) { - const resolvedDependencies = {}; - for (const [depName, { specifier, version }] of Object.entries(from)) { - const existingValue = specifiers[depName]; - if (existingValue != null && existingValue !== specifier) { - throw new Error(`Project snapshot lists the same dependency more than once with conflicting versions: ${depName}`); - } - specifiers[depName] = specifier; - resolvedDependencies[depName] = version; - } - return resolvedDependencies; - } - const dependencies = from.dependencies - ? moveSpecifiers(from.dependencies) - : null; - const devDependencies = from.devDependencies - ? moveSpecifiers(from.devDependencies) - : null; - const optionalDependencies = from.optionalDependencies - ? moveSpecifiers(from.optionalDependencies) - : null; - return Object.assign(Object.assign({}, from), { specifiers, - dependencies, - devDependencies, - optionalDependencies }); -} -// https://github.com/pnpm/pnpm/blob/af3e5559d377870d4c3d303429b3ed1a4e64fedc/lockfile/lockfile-file/src/experiments/inlineSpecifiersLockfileConverters.ts#L241 -function mapValues(obj, mapper) { - const result = {}; - for (const [key, value] of Object.entries(obj)) { - result[key] = mapper(value, key); - } - return result; -} -/************************************************************************* - * THE FOLLOWING CODE IS COPIED FROM @pnpm/types for convenience - *************************************************************************/ -// https://github.com/pnpm/pnpm/blob/af3e5559d377870d4c3d303429b3ed1a4e64fedc/packages/types/src/misc.ts#L6 -const DEPENDENCIES_FIELDS = [ - 'optionalDependencies', - 'dependencies', - 'devDependencies', -]; -/************************************************************************* - * THE FOLLOWING CODE IS COPIED FROM @pnpm/dependency-path for convenience - *************************************************************************/ -// https://github.com/pnpm/pnpm/blob/af3e5559d377870d4c3d303429b3ed1a4e64fedc/packages/dependency-path/src/index.ts#L6 -function isAbsolute(dependencyPath) { - return dependencyPath[0] !== '/'; -} -// https://github.com/pnpm/pnpm/blob/af3e5559d377870d4c3d303429b3ed1a4e64fedc/packages/dependency-path/src/index.ts#L80 -function dpRefToRelative(reference, pkgName) { - if (reference.startsWith('link:')) { - return null; - } - if (reference.startsWith('file:')) { - return reference; - } - if (!reference.includes('/') || - (reference.includes('(') && - reference.lastIndexOf('/', reference.indexOf('(')) === -1)) { - return `/${pkgName}/${reference}`; - } - return reference; -} -// https://github.com/pnpm/pnpm/blob/af3e5559d377870d4c3d303429b3ed1a4e64fedc/packages/dependency-path/src/index.ts#L96 -function dpParse(dependencyPath) { - // eslint-disable-next-line: strict-type-predicates - if (typeof dependencyPath !== 'string') { - throw new TypeError(`Expected \`dependencyPath\` to be of type \`string\`, got \`${ - // eslint-disable-next-line: strict-type-predicates - dependencyPath === null ? 'null' : typeof dependencyPath}\``); - } - const _isAbsolute = isAbsolute(dependencyPath); - const parts = dependencyPath.split('/'); - if (!_isAbsolute) - parts.shift(); - const host = _isAbsolute ? parts.shift() : undefined; - if (parts.length === 0) - return { - host, - isAbsolute: _isAbsolute, - }; - const name = parts[0].startsWith('@') - ? `${parts.shift()}/${parts.shift()}` // eslint-disable-line @typescript-eslint/restrict-template-expressions - : parts.shift(); - let version = parts.join('/'); - if (version) { - let peerSepIndex; - let peersSuffix; - if (version.includes('(') && version.endsWith(')')) { - peerSepIndex = version.indexOf('('); - if (peerSepIndex !== -1) { - peersSuffix = version.substring(peerSepIndex); - version = version.substring(0, peerSepIndex); - } - } - else { - peerSepIndex = version.indexOf('_'); - if (peerSepIndex !== -1) { - peersSuffix = version.substring(peerSepIndex + 1); - version = version.substring(0, peerSepIndex); - } - } - if ((0, semver_1.valid)(version)) { - return { - host, - isAbsolute: _isAbsolute, - name, - peersSuffix, - version, - }; - } - } - if (!_isAbsolute) - throw new Error(`${dependencyPath} is an invalid relative dependency path`); - return { - host, - isAbsolute: _isAbsolute, - }; -} -/******************************************************************************** - * THE FOLLOWING CODE IS COPIED AND SIMPLIFIED FROM @pnpm/ramda for convenience - *******************************************************************************/ -// https://github.com/pnpm/ramda/blob/50c6b57110b2f3631ed8633141f12012b7768d85/source/pickBy.js#L24 -function pickBy(test, obj) { - let result = {}; - for (const prop in obj) { - if (test(obj[prop])) { - result[prop] = obj[prop]; - } - } - return result; +// >=1.2.3 is lower than >1.2.3 +const higherGT = (a, b, options) => { + if (!a) { + return b + } + const comp = compare(a.semver, b.semver, options) + return comp > 0 ? a + : comp < 0 ? b + : b.operator === '>' && a.operator === '>=' ? b + : a } -// https://github.com/pnpm/ramda/blob/50c6b57110b2f3631ed8633141f12012b7768d85/source/isEmpty.js#L28 -function isEmpty(obj) { - return obj != null && Object.keys(obj).length === 0; + +// <=1.2.3 is higher than <1.2.3 +const lowerLT = (a, b, options) => { + if (!a) { + return b + } + const comp = compare(a.semver, b.semver, options) + return comp < 0 ? a + : comp > 0 ? b + : b.operator === '<' && a.operator === '<=' ? b + : a } +module.exports = subset + /***/ }), -/***/ 33875: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { +/***/ 45827: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { -"use strict"; +const Range = __nccwpck_require__(70434) -Object.defineProperty(exports, "__esModule", ({ value: true })); -exports.stringifyYarnLockfile = exports.parseYarnLockfile = void 0; -const tslib_1 = __nccwpck_require__(51796); -const parsers_1 = __nccwpck_require__(98006); -const lockfile_1 = __nccwpck_require__(82035); -const package_json_1 = __nccwpck_require__(6500); -const semver_1 = __nccwpck_require__(56192); -const impl_1 = __nccwpck_require__(43265); -const object_sort_1 = __nccwpck_require__(95961); -function parseYarnLockfile(lockFileContent, builder) { - const data = (0, parsers_1.parseSyml)(lockFileContent); - // we use key => node map to avoid duplicate work when parsing keys - const keyMap = new Map(); - addNodes(data, builder, keyMap); - addDependencies(data, builder, keyMap); -} -exports.parseYarnLockfile = parseYarnLockfile; -function addNodes(_a, builder, keyMap) { - var { __metadata } = _a, dependencies = tslib_1.__rest(_a, ["__metadata"]); - const isBerry = !!__metadata; - const nodes = new Map(); - Object.entries(dependencies).forEach(([keys, snapshot]) => { - // ignore workspace projects & patches - if (snapshot.linkType === 'soft' || keys.includes('@patch:')) { - return; - } - const packageName = keys.slice(0, keys.indexOf('@', 1)); - const version = findVersion(packageName, keys.split(', ')[0], snapshot, isBerry); - keys.split(', ').forEach((key) => { - var _a; - // we don't need to keep duplicates, we can just track the keys - const existingNode = (_a = nodes.get(packageName)) === null || _a === void 0 ? void 0 : _a.get(version); - if (existingNode) { - keyMap.set(key, existingNode); - return; - } - const node = { - type: 'npm', - name: version ? `npm:${packageName}@${version}` : `npm:${packageName}`, - data: { - version, - packageName, - hash: snapshot.integrity || - snapshot.checksum || - (0, impl_1.hashArray)([packageName, version]), - }, - }; - keyMap.set(key, node); - if (!nodes.has(packageName)) { - nodes.set(packageName, new Map([[version, node]])); - } - else { - nodes.get(packageName).set(version, node); - } - }); - }); - for (const [packageName, versionMap] of nodes.entries()) { - let hoistedNode; - if (versionMap.size === 1) { - hoistedNode = versionMap.values().next().value; - } - else { - const hoistedVersion = getHoistedVersion(packageName); - hoistedNode = versionMap.get(hoistedVersion); - } - if (hoistedNode) { - hoistedNode.name = `npm:${packageName}`; - } - versionMap.forEach((node) => { - builder.addExternalNode(node); - }); - } -} -function findVersion(packageName, key, snapshot, isBerry) { - const versionRange = key.slice(packageName.length + 1); - // check for alias packages - const isAlias = isBerry - ? snapshot.resolution && !snapshot.resolution.startsWith(`${packageName}@`) - : versionRange.startsWith('npm:'); - if (isAlias) { - return versionRange; - } - // check for berry tarball packages - if (isBerry && - snapshot.resolution && - // different registry would yield suffix following '::' which we don't need - snapshot.resolution.split('::')[0] !== - `${packageName}@npm:${snapshot.version}`) { - return snapshot.resolution.slice(packageName.length + 1); - } - if (!isBerry && snapshot.resolved && !isValidVersionRange(versionRange)) { - return snapshot.resolved; - } - // otherwise it's a standard version - return snapshot.version; -} -// check if value can be parsed as a semver range -function isValidVersionRange(versionRange) { - try { - new semver_1.Range(versionRange); - return true; - } - catch (_a) { - return false; - } -} -function getHoistedVersion(packageName) { - const version = (0, package_json_1.getHoistedPackageVersion)(packageName); - if (version) { - return version; - } -} -function addDependencies(_a, builder, keyMap) { - var { __metadata } = _a, dependencies = tslib_1.__rest(_a, ["__metadata"]); - Object.keys(dependencies).forEach((keys) => { - const snapshot = dependencies[keys]; - keys.split(', ').forEach((key) => { - if (keyMap.has(key)) { - const node = keyMap.get(key); - [snapshot.dependencies, snapshot.optionalDependencies].forEach((section) => { - if (section) { - Object.entries(section).forEach(([name, versionRange]) => { - const target = keyMap.get(`${name}@npm:${versionRange}`) || - keyMap.get(`${name}@${versionRange}`); - if (target) { - builder.addStaticDependency(node.name, target.name); - } - }); - } - }); - } - }); - }); -} -function stringifyYarnLockfile(graph, rootLockFileContent, packageJson) { - const _a = (0, parsers_1.parseSyml)(rootLockFileContent), { __metadata } = _a, dependencies = tslib_1.__rest(_a, ["__metadata"]); - const isBerry = !!__metadata; - const snapshots = mapSnapshots(dependencies, graph.externalNodes, packageJson, isBerry); - if (isBerry) { - // add root workspace package - const workspacePackage = generateRootWorkspacePackage(packageJson); - snapshots[workspacePackage.resolution] = workspacePackage; - return (BERRY_LOCK_FILE_DISCLAIMER + - (0, parsers_1.stringifySyml)(Object.assign({ __metadata }, (0, object_sort_1.sortObjectByKeys)(snapshots)))); - } - else { - return (0, lockfile_1.stringify)((0, object_sort_1.sortObjectByKeys)(snapshots)); - } -} -exports.stringifyYarnLockfile = stringifyYarnLockfile; -function groupDependencies(dependencies) { - let groupedDependencies; - const resolutionMap = new Map(); - const snapshotMap = new Map(); - Object.entries(dependencies).forEach(([key, snapshot]) => { - const resolutionKey = `${snapshot.resolved}${snapshot.integrity}`; - if (resolutionMap.has(resolutionKey)) { - const existingSnapshot = resolutionMap.get(resolutionKey); - snapshotMap.get(existingSnapshot).add(key); - } - else { - resolutionMap.set(resolutionKey, snapshot); - snapshotMap.set(snapshot, new Set([key])); - } - }); - groupedDependencies = {}; - snapshotMap.forEach((keys, snapshot) => { - groupedDependencies[Array.from(keys).join(', ')] = snapshot; - }); - return groupedDependencies; -} -function addPackageVersion(packageName, version, collection, isBerry) { - if (!collection.has(packageName)) { - collection.set(packageName, new Set()); - } - collection.get(packageName).add(`${packageName}@${version}`); - if (isBerry && !version.startsWith('npm:')) { - collection.get(packageName).add(`${packageName}@npm:${version}`); - } -} -function mapSnapshots(dependencies, nodes, packageJson, isBerry) { - // map snapshot to set of keys (e.g. `eslint@^7.0.0, eslint@npm:^7.0.0`) - const snapshotMap = new Map(); - // track all existing dependencies's keys - const existingKeys = new Map(); - const combinedDependencies = Object.assign(Object.assign(Object.assign(Object.assign({}, packageJson.dependencies), packageJson.devDependencies), packageJson.optionalDependencies), packageJson.peerDependencies); - let groupedDependencies; - if (isBerry) { - groupedDependencies = dependencies; - } - else { - // yarn classic splits keys when parsing so we need to stich them back together - groupedDependencies = groupDependencies(dependencies); - } - // collect snapshots and their matching keys - Object.values(nodes).forEach((node) => { - const foundOriginalKeys = findOriginalKeys(groupedDependencies, node); - if (!foundOriginalKeys) { - throw new Error(`Original key(s) not found for "${node.data.packageName}@${node.data.version}" while pruning yarn.lock.`); - } - const [matchedKeys, snapshot] = foundOriginalKeys; - snapshotMap.set(snapshot, new Set(matchedKeys)); - // separately save keys that still exist - [snapshot.dependencies, snapshot.optionalDependencies].forEach((section) => { - Object.entries(section || {}).forEach(([name, versionSpec]) => addPackageVersion(name, versionSpec, existingKeys, isBerry)); - }); - // add package.json requested version to keys - const requestedVersion = getPackageJsonVersion(combinedDependencies, node); - if (requestedVersion) { - addPackageVersion(node.data.packageName, requestedVersion, existingKeys, isBerry); - const requestedKey = isBerry - ? reverseMapBerryKey(node, requestedVersion, snapshot) - : `${node.data.packageName}@${requestedVersion}`; - if (!snapshotMap.get(snapshot).has(requestedKey)) { - snapshotMap.get(snapshot).add(requestedKey); - } - } - if (isBerry) { - // look for patched versions - const patch = findPatchedKeys(groupedDependencies, node); - if (patch) { - const [matchedKeys, snapshot] = patch; - snapshotMap.set(snapshot, new Set(matchedKeys)); - } - } - }); - // remove keys that match version ranges that have been pruned away - snapshotMap.forEach((keysSet) => { - for (const key of keysSet.values()) { - const packageName = key.slice(0, key.indexOf('@', 1)); - let normalizedKey = key; - if (isBerry && key.includes('@patch:') && key.includes('#')) { - normalizedKey = key - .slice(0, key.indexOf('#')) - .replace(`@patch:${packageName}@`, '@npm:'); - } - if (!existingKeys.get(packageName).has(normalizedKey)) { - keysSet.delete(key); - } - } - }); - // join mapped snapshots to lock json file - const result = {}; - snapshotMap.forEach((keysSet, snapshot) => { - if (isBerry) { - result[Array.from(keysSet).sort().join(', ')] = snapshot; - } - else { - for (const key of keysSet.values()) { - result[key] = snapshot; - } - } - }); - return result; -} -function reverseMapBerryKey(node, version, snapshot) { - // alias packages already have version - if (version.startsWith('npm:')) { - `${node.data.packageName}@${version}`; - } - // check for berry tarball packages - if (snapshot.resolution && - snapshot.resolution === `${node.data.packageName}@${version}`) { - return snapshot.resolution; - } - return `${node.data.packageName}@npm:${version}`; -} -function getPackageJsonVersion(combinedDependencies, node) { - const { packageName, version } = node.data; - if (combinedDependencies[packageName]) { - if (combinedDependencies[packageName] === version || - (0, semver_1.satisfies)(version, combinedDependencies[packageName])) { - return combinedDependencies[packageName]; - } - } -} -function findOriginalKeys(dependencies, node) { - for (const keyExpr of Object.keys(dependencies)) { - const snapshot = dependencies[keyExpr]; - const keys = keyExpr.split(', '); - if (!keys.some((k) => k.startsWith(`${node.data.packageName}@`))) { - continue; - } - // standard package - if (snapshot.version === node.data.version) { - return [keys, snapshot]; - } - // berry alias package - if (snapshot.resolution && - `npm:${snapshot.resolution}` === node.data.version) { - return [keys, snapshot]; - } - // classic alias - if (node.data.version.startsWith('npm:') && - keys.some((k) => k === `${node.data.packageName}@${node.data.version}`)) { - return [keys, snapshot]; - } - // tarball package - if (snapshot.resolved === node.data.version || - snapshot.resolution === `${node.data.packageName}@${node.data.version}`) { - return [keys, snapshot]; - } - } -} -function findPatchedKeys(dependencies, node) { - for (const keyExpr of Object.keys(dependencies)) { - const snapshot = dependencies[keyExpr]; - const keys = keyExpr.split(', '); - if (!keys[0].startsWith(`${node.data.packageName}@patch:`)) { - continue; - } - if (snapshot.version === node.data.version) { - return [keys, snapshot]; - } - } -} -const BERRY_LOCK_FILE_DISCLAIMER = `# This file is generated by running "yarn install" inside your project.\n# Manual changes might be lost - proceed with caution!\n\n`; -function generateRootWorkspacePackage(packageJson) { - return Object.assign(Object.assign(Object.assign(Object.assign(Object.assign({ version: '0.0.0-use.local', resolution: `${packageJson.name}@workspace:.` }, (packageJson.dependencies && { dependencies: packageJson.dependencies })), (packageJson.peerDependencies && { - peerDependencies: packageJson.peerDependencies, - })), (packageJson.devDependencies && { - devDependencies: packageJson.devDependencies, - })), (packageJson.optionalDependencies && { - optionalDependencies: packageJson.optionalDependencies, - })), { languageName: 'unknown', linkType: 'soft' }); -} +// Mostly just for testing and legacy API reasons +const toComparators = (range, options) => + new Range(range, options).set + .map(comp => comp.map(c => c.value).join(' ').trim().split(' ')) + +module.exports = toComparators /***/ }), -/***/ 89977: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { - -"use strict"; +/***/ 88902: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { -Object.defineProperty(exports, "__esModule", ({ value: true })); -exports.buildExplicitDependencies = void 0; -const project_graph_1 = __nccwpck_require__(49899); -const path_1 = __nccwpck_require__(71017); -const build_explicit_typescript_and_package_json_dependencies_1 = __nccwpck_require__(91714); -const os = __nccwpck_require__(22037); -function buildExplicitDependencies(jsPluginConfig, ctx, builder) { - let totalNumOfFilesToProcess = totalNumberOfFilesToProcess(ctx); - if (totalNumOfFilesToProcess === 0) - return; - // using workers has an overhead, so we only do it when the number of - // files we need to process is >= 100 and there are more than 2 CPUs - // to be able to use at least 2 workers (1 worker per CPU and - // 1 CPU for the main thread) - if (jsPluginConfig.analyzeSourceFiles === false || - totalNumOfFilesToProcess < 100 || - getNumberOfWorkers() <= 2) { - return buildExplicitDependenciesWithoutWorkers(jsPluginConfig, ctx, builder); - } - else { - return buildExplicitDependenciesUsingWorkers(jsPluginConfig, ctx, totalNumOfFilesToProcess, builder); - } -} -exports.buildExplicitDependencies = buildExplicitDependencies; -function totalNumberOfFilesToProcess(ctx) { - let totalNumOfFilesToProcess = 0; - Object.values(ctx.filesToProcess).forEach((t) => (totalNumOfFilesToProcess += t.length)); - return totalNumOfFilesToProcess; -} -function splitFilesIntoBins(ctx, totalNumOfFilesToProcess, numberOfWorkers) { - // we want to have numberOfWorkers * 5 bins - const filesPerBin = Math.round(totalNumOfFilesToProcess / numberOfWorkers / 5) + 1; - const bins = []; - let currentProjectFileMap = {}; - let currentNumberOfFiles = 0; - for (const source of Object.keys(ctx.filesToProcess)) { - for (const f of Object.values(ctx.filesToProcess[source])) { - if (!currentProjectFileMap[source]) - currentProjectFileMap[source] = []; - currentProjectFileMap[source].push(f); - currentNumberOfFiles++; - if (currentNumberOfFiles >= filesPerBin) { - bins.push(currentProjectFileMap); - currentProjectFileMap = {}; - currentNumberOfFiles = 0; - } - } - } - bins.push(currentProjectFileMap); - return bins; -} -function createWorkerPool(numberOfWorkers) { - const res = []; - for (let i = 0; i < numberOfWorkers; ++i) { - res.push(new ((__nccwpck_require__(71267).Worker))((0, path_1.join)(__dirname, './project-graph-worker.js'), { - env: process.env, - })); - } - return res; -} -function buildExplicitDependenciesWithoutWorkers(jsPluginConfig, ctx, builder) { - (0, build_explicit_typescript_and_package_json_dependencies_1.buildExplicitTypescriptAndPackageJsonDependencies)(jsPluginConfig, ctx.nxJsonConfiguration, ctx.projectsConfigurations, builder.graph, ctx.filesToProcess).forEach((r) => { - if (r.type === project_graph_1.DependencyType.static) { - builder.addStaticDependency(r.sourceProjectName, r.targetProjectName, r.sourceProjectFile); - } - else { - builder.addDynamicDependency(r.sourceProjectName, r.targetProjectName, r.sourceProjectFile); - } - }); -} -function buildExplicitDependenciesUsingWorkers(jsPluginConfig, ctx, totalNumOfFilesToProcess, builder) { - const numberOfWorkers = Math.min(totalNumOfFilesToProcess, getNumberOfWorkers()); - const bins = splitFilesIntoBins(ctx, totalNumOfFilesToProcess, numberOfWorkers); - const workers = createWorkerPool(numberOfWorkers); - let numberOfExpectedResponses = bins.length; - return new Promise((res, reject) => { - for (let w of workers) { - w.on('message', (explicitDependencies) => { - explicitDependencies.forEach((r) => { - builder.addExplicitDependency(r.sourceProjectName, r.sourceProjectFile, r.targetProjectName); - }); - if (bins.length > 0) { - w.postMessage({ filesToProcess: bins.shift() }); - } - // we processed all the bins - if (--numberOfExpectedResponses === 0) { - for (let w of workers) { - w.terminate(); - } - res(null); - } - }); - w.on('error', reject); - w.on('exit', (code) => { - if (code !== 0) { - reject(new Error(`Unable to complete project graph creation. Worker stopped with exit code: ${code}`)); - } - }); - w.postMessage({ - nxJsonConfiguration: ctx.nxJsonConfiguration, - projectsConfigurations: ctx.projectsConfigurations, - projectGraph: builder.graph, - jsPluginConfig, - }); - w.postMessage({ filesToProcess: bins.shift() }); - } - }); -} -function getNumberOfWorkers() { - return process.env.NX_PROJECT_GRAPH_MAX_WORKERS - ? +process.env.NX_PROJECT_GRAPH_MAX_WORKERS - : Math.min(os.cpus().length - 1, 8); // This is capped for cases in CI where `os.cpus()` returns way more CPUs than the resources that are allocated +const Range = __nccwpck_require__(70434) +const validRange = (range, options) => { + try { + // Return '*' instead of '' so that truthiness works. + // This will throw if it's invalid anyway + return new Range(range, options).range || '*' + } catch (er) { + return null + } } +module.exports = validRange /***/ }), -/***/ 91714: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { - -"use strict"; +/***/ 65907: +/***/ ((module) => { -Object.defineProperty(exports, "__esModule", ({ value: true })); -exports.buildExplicitTypescriptAndPackageJsonDependencies = void 0; -const explicit_project_dependencies_1 = __nccwpck_require__(24718); -const explicit_package_json_dependencies_1 = __nccwpck_require__(21054); -function buildExplicitTypescriptAndPackageJsonDependencies(jsPluginConfig, nxJsonConfiguration, projectsConfigurations, projectGraph, filesToProcess) { - let res = []; - if (jsPluginConfig.analyzeSourceFiles === undefined || - jsPluginConfig.analyzeSourceFiles === true) { - let tsExists = false; - try { - __nccwpck_require__.ab + "typescript.js" - tsExists = true; - } - catch (_a) { } - if (tsExists) { - res = res.concat((0, explicit_project_dependencies_1.buildExplicitTypeScriptDependencies)(projectGraph, filesToProcess)); - } - } - if (jsPluginConfig.analyzePackageJson === undefined || - jsPluginConfig.analyzePackageJson === true) { - res = res.concat((0, explicit_package_json_dependencies_1.buildExplicitPackageJsonDependencies)(nxJsonConfiguration, projectsConfigurations, projectGraph, filesToProcess)); - } - return res; -} -exports.buildExplicitTypescriptAndPackageJsonDependencies = buildExplicitTypescriptAndPackageJsonDependencies; +module.exports = [ + 'cat', + 'cd', + 'chmod', + 'cp', + 'dirs', + 'echo', + 'exec', + 'find', + 'grep', + 'head', + 'ln', + 'ls', + 'mkdir', + 'mv', + 'pwd', + 'rm', + 'sed', + 'set', + 'sort', + 'tail', + 'tempdir', + 'test', + 'to', + 'toEnd', + 'touch', + 'uniq', + 'which', +]; /***/ }), -/***/ 21054: +/***/ 26877: /***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { -"use strict"; +// +// ShellJS +// Unix shell commands on top of Node's API +// +// Copyright (c) 2012 Artur Adib +// http://github.com/shelljs/shelljs +// -Object.defineProperty(exports, "__esModule", ({ value: true })); -exports.buildExplicitPackageJsonDependencies = void 0; -const file_utils_1 = __nccwpck_require__(93155); -const path_1 = __nccwpck_require__(71017); -const project_graph_1 = __nccwpck_require__(49899); -const json_1 = __nccwpck_require__(43684); -const path_2 = __nccwpck_require__(75878); -function buildExplicitPackageJsonDependencies(nxJsonConfiguration, projectsConfigurations, graph, filesToProcess) { - const res = []; - let packageNameMap = undefined; - const nodes = Object.values(graph.nodes); - Object.keys(filesToProcess).forEach((source) => { - Object.values(filesToProcess[source]).forEach((f) => { - if (isPackageJsonAtProjectRoot(nodes, f.file)) { - // we only create the package name map once and only if a package.json file changes - packageNameMap = - packageNameMap || - createPackageNameMap(nxJsonConfiguration, projectsConfigurations); - processPackageJson(source, f.file, graph, res, packageNameMap); - } - }); - }); - return res; -} -exports.buildExplicitPackageJsonDependencies = buildExplicitPackageJsonDependencies; -function createPackageNameMap(nxJsonConfiguration, projectsConfigurations) { - var _a; - const res = {}; - for (let projectName of Object.keys(projectsConfigurations.projects)) { - try { - const packageJson = (0, json_1.parseJson)((0, file_utils_1.defaultFileRead)((0, path_1.join)(projectsConfigurations.projects[projectName].root, 'package.json'))); - // TODO(v17): Stop reading nx.json for the npmScope - const npmScope = nxJsonConfiguration.npmScope; - res[(_a = packageJson.name) !== null && _a !== void 0 ? _a : (npmScope - ? `${npmScope === '@' ? '' : '@'}${npmScope}/${projectName}` - : projectName)] = projectName; - } - catch (e) { } - } - return res; -} -function isPackageJsonAtProjectRoot(nodes, fileName) { - return (fileName.endsWith('package.json') && - nodes.find((projectNode) => (projectNode.type === 'lib' || projectNode.type === 'app') && - (0, path_2.joinPathFragments)(projectNode.data.root, 'package.json') === fileName)); -} -function processPackageJson(sourceProject, fileName, graph, collectedDeps, packageNameMap) { - try { - const deps = readDeps((0, json_1.parseJson)((0, file_utils_1.defaultFileRead)(fileName))); - // the name matches the import path - deps.forEach((d) => { - // package.json refers to another project in the monorepo - if (packageNameMap[d]) { - collectedDeps.push({ - sourceProjectName: sourceProject, - targetProjectName: packageNameMap[d], - sourceProjectFile: fileName, - type: project_graph_1.DependencyType.static, - }); - } - else if (graph.externalNodes[`npm:${d}`]) { - collectedDeps.push({ - sourceProjectName: sourceProject, - targetProjectName: `npm:${d}`, - sourceProjectFile: fileName, - type: project_graph_1.DependencyType.static, - }); - } - }); - } - catch (e) { - if (process.env.NX_VERBOSE_LOGGING === 'true') { - console.log(e); - } - } -} -function readDeps(packageJson) { - var _a, _b, _c, _d; - return [ - ...Object.keys((_a = packageJson === null || packageJson === void 0 ? void 0 : packageJson.dependencies) !== null && _a !== void 0 ? _a : {}), - ...Object.keys((_b = packageJson === null || packageJson === void 0 ? void 0 : packageJson.devDependencies) !== null && _b !== void 0 ? _b : {}), - ...Object.keys((_c = packageJson === null || packageJson === void 0 ? void 0 : packageJson.peerDependencies) !== null && _c !== void 0 ? _c : {}), - ...Object.keys((_d = packageJson === null || packageJson === void 0 ? void 0 : packageJson.optionalDependencies) !== null && _d !== void 0 ? _d : {}), - ]; -} +function __ncc_wildcard$0 (arg) { + if (arg === "cat.js" || arg === "cat") return __nccwpck_require__(87587); + else if (arg === "cd.js" || arg === "cd") return __nccwpck_require__(79117); + else if (arg === "chmod.js" || arg === "chmod") return __nccwpck_require__(19879); + else if (arg === "common.js" || arg === "common") return __nccwpck_require__(60624); + else if (arg === "cp.js" || arg === "cp") return __nccwpck_require__(64395); + else if (arg === "dirs.js" || arg === "dirs") return __nccwpck_require__(11060); + else if (arg === "echo.js" || arg === "echo") return __nccwpck_require__(60607); + else if (arg === "error.js" || arg === "error") return __nccwpck_require__(66829); + else if (arg === "exec-child.js" || arg === "exec-child") return __nccwpck_require__(148); + else if (arg === "exec.js" || arg === "exec") return __nccwpck_require__(25239); + else if (arg === "find.js" || arg === "find") return __nccwpck_require__(52388); + else if (arg === "grep.js" || arg === "grep") return __nccwpck_require__(47294); + else if (arg === "head.js" || arg === "head") return __nccwpck_require__(24902); + else if (arg === "ln.js" || arg === "ln") return __nccwpck_require__(68092); + else if (arg === "ls.js" || arg === "ls") return __nccwpck_require__(42248); + else if (arg === "mkdir.js" || arg === "mkdir") return __nccwpck_require__(27707); + else if (arg === "mv.js" || arg === "mv") return __nccwpck_require__(78146); + else if (arg === "popd.js" || arg === "popd") return __nccwpck_require__(12425); + else if (arg === "pushd.js" || arg === "pushd") return __nccwpck_require__(68943); + else if (arg === "pwd.js" || arg === "pwd") return __nccwpck_require__(90909); + else if (arg === "rm.js" || arg === "rm") return __nccwpck_require__(54369); + else if (arg === "sed.js" || arg === "sed") return __nccwpck_require__(83401); + else if (arg === "set.js" || arg === "set") return __nccwpck_require__(62833); + else if (arg === "sort.js" || arg === "sort") return __nccwpck_require__(22675); + else if (arg === "tail.js" || arg === "tail") return __nccwpck_require__(61434); + else if (arg === "tempdir.js" || arg === "tempdir") return __nccwpck_require__(68691); + else if (arg === "test.js" || arg === "test") return __nccwpck_require__(22766); + else if (arg === "to.js" || arg === "to") return __nccwpck_require__(83181); + else if (arg === "toEnd.js" || arg === "toEnd") return __nccwpck_require__(5836); + else if (arg === "touch.js" || arg === "touch") return __nccwpck_require__(19811); + else if (arg === "uniq.js" || arg === "uniq") return __nccwpck_require__(29095); + else if (arg === "which.js" || arg === "which") return __nccwpck_require__(70858); +} +var common = __nccwpck_require__(60624); +//@ +//@ All commands run synchronously, unless otherwise stated. +//@ All commands accept standard bash globbing characters (`*`, `?`, etc.), +//@ compatible with the [node `glob` module](https://github.com/isaacs/node-glob). +//@ +//@ For less-commonly used commands and features, please check out our [wiki +//@ page](https://github.com/shelljs/shelljs/wiki). +//@ -/***/ }), +// Include the docs for all the default commands +//@commands -/***/ 24718: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { +// Load all default commands +(__nccwpck_require__(65907).forEach)(function (command) { + __ncc_wildcard$0(command); +}); -"use strict"; +//@ +//@ ### exit(code) +//@ +//@ Exits the current process with the given exit `code`. +exports.exit = process.exit; -Object.defineProperty(exports, "__esModule", ({ value: true })); -exports.buildExplicitTypeScriptDependencies = void 0; -const typescript_import_locator_1 = __nccwpck_require__(40234); -const target_project_locator_1 = __nccwpck_require__(99113); -function buildExplicitTypeScriptDependencies(graph, filesToProcess) { - function isRoot(projectName) { - var _a, _b; - return ((_b = (_a = graph.nodes[projectName]) === null || _a === void 0 ? void 0 : _a.data) === null || _b === void 0 ? void 0 : _b.root) === '.'; - } - const importLocator = new typescript_import_locator_1.TypeScriptImportLocator(); - const targetProjectLocator = new target_project_locator_1.TargetProjectLocator(graph.nodes, graph.externalNodes); - const res = []; - Object.keys(filesToProcess).forEach((source) => { - Object.values(filesToProcess[source]).forEach((f) => { - importLocator.fromFile(f.file, (importExpr, filePath, type) => { - const target = targetProjectLocator.findProjectWithImport(importExpr, f.file); - let targetProjectName; - if (target) { - if (!isRoot(source) && isRoot(target)) { - // TODO: These edges technically should be allowed but we need to figure out how to separate config files out from root - return; - } - targetProjectName = target; - } - else { - // treat all unknowns as npm packages, they can be eiher - // - mistyped local import, which has to be fixed manually - // - node internals, which should still be tracked as a dependency - // - npm packages, which are not yet installed but should be tracked - targetProjectName = `npm:${importExpr}`; - } - res.push({ - sourceProjectName: source, - targetProjectName, - sourceProjectFile: f.file, - type, - }); - }); - }); - }); - return res; -} -exports.buildExplicitTypeScriptDependencies = buildExplicitTypeScriptDependencies; +//@include ./src/error +exports.error = __nccwpck_require__(66829); +//@include ./src/common +exports.ShellString = common.ShellString; -/***/ }), +//@ +//@ ### env['VAR_NAME'] +//@ +//@ Object containing environment variables (both getter and setter). Shortcut +//@ to `process.env`. +exports.env = process.env; -/***/ 84447: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { +//@ +//@ ### Pipes +//@ +//@ Examples: +//@ +//@ ```javascript +//@ grep('foo', 'file1.txt', 'file2.txt').sed(/o/g, 'a').to('output.txt'); +//@ echo('files with o\'s in the name:\n' + ls().grep('o')); +//@ cat('test.js').exec('node'); // pipe to exec() call +//@ ``` +//@ +//@ Commands can send their output to another command in a pipe-like fashion. +//@ `sed`, `grep`, `cat`, `exec`, `to`, and `toEnd` can appear on the right-hand +//@ side of a pipe. Pipes can be chained. -"use strict"; +//@ +//@ ## Configuration +//@ -Object.defineProperty(exports, "__esModule", ({ value: true })); -exports.stripSourceCode = void 0; -let SyntaxKind; -function shouldRescanSlashToken(lastNonTriviaToken) { - switch (lastNonTriviaToken) { - case SyntaxKind.Identifier: - case SyntaxKind.StringLiteral: - case SyntaxKind.NumericLiteral: - case SyntaxKind.BigIntLiteral: - case SyntaxKind.RegularExpressionLiteral: - case SyntaxKind.ThisKeyword: - case SyntaxKind.PlusPlusToken: - case SyntaxKind.MinusMinusToken: - case SyntaxKind.CloseParenToken: - case SyntaxKind.CloseBracketToken: - case SyntaxKind.CloseBraceToken: - case SyntaxKind.TrueKeyword: - case SyntaxKind.FalseKeyword: - return false; - default: - return true; - } -} -function stripSourceCode(scanner, contents) { - if (!SyntaxKind) { - SyntaxKind = (__nccwpck_require__(70048).SyntaxKind); - } - if (contents.indexOf('loadChildren') > -1) { - return contents; - } - scanner.setText(contents); - let token = scanner.scan(); - let lastNonTriviaToken = SyntaxKind.Unknown; - const statements = []; - const templateStack = []; - let ignoringLine = false; - let braceDepth = 0; - let start = null; - while (token !== SyntaxKind.EndOfFileToken) { - const currentToken = token; - const potentialStart = scanner.getStartPos(); - switch (token) { - case SyntaxKind.MultiLineCommentTrivia: - case SyntaxKind.SingleLineCommentTrivia: { - const isMultiLineCommentTrivia = token === SyntaxKind.MultiLineCommentTrivia; - const start = potentialStart + 2; - token = scanner.scan(); - const end = scanner.getStartPos() - (isMultiLineCommentTrivia ? 2 : 0); - const comment = contents.substring(start, end).trim(); - if (comment === 'nx-ignore-next-line') { - // reading till the end of the line - while (token === SyntaxKind.WhitespaceTrivia || - token === SyntaxKind.NewLineTrivia) { - token = scanner.scan(); - } - ignoringLine = true; - } - break; - } - case SyntaxKind.NewLineTrivia: { - ignoringLine = false; - token = scanner.scan(); - break; - } - case SyntaxKind.RequireKeyword: - case SyntaxKind.ImportKeyword: { - token = scanner.scan(); - if (ignoringLine) { - break; - } - while (token === SyntaxKind.WhitespaceTrivia || - token === SyntaxKind.NewLineTrivia) { - token = scanner.scan(); - } - start = potentialStart; - break; - } - case SyntaxKind.TemplateHead: { - templateStack.push(braceDepth); - braceDepth = 0; - token = scanner.scan(); - break; - } - case SyntaxKind.SlashToken: { - if (shouldRescanSlashToken(lastNonTriviaToken)) { - token = scanner.reScanSlashToken(); - } - token = scanner.scan(); - break; - } - case SyntaxKind.OpenBraceToken: { - ++braceDepth; - token = scanner.scan(); - break; - } - case SyntaxKind.CloseBraceToken: { - if (braceDepth) { - --braceDepth; - } - else if (templateStack.length) { - token = scanner.reScanTemplateToken(false); - if (token === SyntaxKind.LastTemplateToken) { - braceDepth = templateStack.pop(); - } - } - token = scanner.scan(); - break; - } - case SyntaxKind.ExportKeyword: { - token = scanner.scan(); - if (ignoringLine) { - break; - } - while (token === SyntaxKind.WhitespaceTrivia || - token === SyntaxKind.NewLineTrivia) { - token = scanner.scan(); - } - if (token === SyntaxKind.OpenBraceToken || - token === SyntaxKind.AsteriskToken || - token === SyntaxKind.TypeKeyword) { - start = potentialStart; - } - break; - } - case SyntaxKind.StringLiteral: { - if (start !== null) { - token = scanner.scan(); - if (token === SyntaxKind.CloseParenToken) { - token = scanner.scan(); - } - const end = scanner.getStartPos(); - statements.push(contents.substring(start, end)); - start = null; - } - else { - token = scanner.scan(); - } - break; - } - default: { - token = scanner.scan(); - } - } - if (currentToken > SyntaxKind.LastTriviaToken) { - lastNonTriviaToken = currentToken; - } - } - return statements.join('\n'); -} -exports.stripSourceCode = stripSourceCode; +exports.config = common.config; + +//@ +//@ ### config.silent +//@ +//@ Example: +//@ +//@ ```javascript +//@ var sh = require('shelljs'); +//@ var silentState = sh.config.silent; // save old silent state +//@ sh.config.silent = true; +//@ /* ... */ +//@ sh.config.silent = silentState; // restore old silent state +//@ ``` +//@ +//@ Suppresses all command output if `true`, except for `echo()` calls. +//@ Default is `false`. + +//@ +//@ ### config.fatal +//@ +//@ Example: +//@ +//@ ```javascript +//@ require('shelljs/global'); +//@ config.fatal = true; // or set('-e'); +//@ cp('this_file_does_not_exist', '/dev/null'); // throws Error here +//@ /* more commands... */ +//@ ``` +//@ +//@ If `true`, the script will throw a Javascript error when any shell.js +//@ command encounters an error. Default is `false`. This is analogous to +//@ Bash's `set -e`. + +//@ +//@ ### config.verbose +//@ +//@ Example: +//@ +//@ ```javascript +//@ config.verbose = true; // or set('-v'); +//@ cd('dir/'); +//@ rm('-rf', 'foo.txt', 'bar.txt'); +//@ exec('echo hello'); +//@ ``` +//@ +//@ Will print each command as follows: +//@ +//@ ``` +//@ cd dir/ +//@ rm -rf foo.txt bar.txt +//@ exec echo hello +//@ ``` + +//@ +//@ ### config.globOptions +//@ +//@ Example: +//@ +//@ ```javascript +//@ config.globOptions = {nodir: true}; +//@ ``` +//@ +//@ Use this value for calls to `glob.sync()` instead of the default options. + +//@ +//@ ### config.reset() +//@ +//@ Example: +//@ +//@ ```javascript +//@ var shell = require('shelljs'); +//@ // Make changes to shell.config, and do stuff... +//@ /* ... */ +//@ shell.config.reset(); // reset to original state +//@ // Do more stuff, but with original settings +//@ /* ... */ +//@ ``` +//@ +//@ Reset `shell.config` to the defaults: +//@ +//@ ```javascript +//@ { +//@ fatal: false, +//@ globOptions: {}, +//@ maxdepth: 255, +//@ noglob: false, +//@ silent: false, +//@ verbose: false, +//@ } +//@ ``` /***/ }), -/***/ 99113: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { +/***/ 87587: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { -"use strict"; +var common = __nccwpck_require__(60624); +var fs = __nccwpck_require__(57147); -Object.defineProperty(exports, "__esModule", ({ value: true })); -exports.TargetProjectLocator = void 0; -const typescript_1 = __nccwpck_require__(62029); -const fileutils_1 = __nccwpck_require__(47930); -const path_1 = __nccwpck_require__(71017); -const workspace_root_1 = __nccwpck_require__(65766); -const module_1 = __nccwpck_require__(98188); -const find_project_for_path_1 = __nccwpck_require__(36265); -const builtInModuleSet = new Set([ - ...module_1.builtinModules, - ...module_1.builtinModules.map((x) => `node:${x}`), -]); -class TargetProjectLocator { - constructor(nodes, externalNodes) { - var _a, _b; - this.nodes = nodes; - this.externalNodes = externalNodes; - this.projectRootMappings = (0, find_project_for_path_1.createProjectRootMappings)(this.nodes); - this.npmProjects = filterRootExternalDependencies(this.externalNodes); - this.tsConfig = this.getRootTsConfig(); - this.paths = (_b = (_a = this.tsConfig.config) === null || _a === void 0 ? void 0 : _a.compilerOptions) === null || _b === void 0 ? void 0 : _b.paths; - this.typescriptResolutionCache = new Map(); - this.npmResolutionCache = new Map(); - } - /** - * Find a project based on its import - * - * @param importExpr - * @param filePath - */ - findProjectWithImport(importExpr, filePath) { - const normalizedImportExpr = importExpr.split('#')[0]; - if ((0, fileutils_1.isRelativePath)(normalizedImportExpr)) { - const resolvedModule = path_1.posix.join((0, path_1.dirname)(filePath), normalizedImportExpr); - return this.findProjectOfResolvedModule(resolvedModule); - } - // find project using tsconfig paths - const paths = this.findPaths(normalizedImportExpr); - if (paths) { - for (let p of paths) { - const maybeResolvedProject = this.findProjectOfResolvedModule(p); - if (maybeResolvedProject) { - return maybeResolvedProject; - } - } - } - // try to find npm package before using expensive typescript resolution - const npmProject = this.findNpmPackage(normalizedImportExpr); - if (npmProject) { - return npmProject; - } - if (this.tsConfig.config) { - // TODO(meeroslav): this block is probably obsolete - // and existed only because of the incomplete `paths` matching - // if import cannot be matched using tsconfig `paths` the compilation would fail anyway - const resolvedProject = this.resolveImportWithTypescript(normalizedImportExpr, filePath); - if (resolvedProject) { - return resolvedProject; - } - } - if (builtInModuleSet.has(normalizedImportExpr)) { - this.npmResolutionCache.set(normalizedImportExpr, null); - return null; - } - try { - const resolvedModule = this.resolveImportWithRequire(normalizedImportExpr, filePath); - return this.findProjectOfResolvedModule(resolvedModule); - } - catch (_a) { } - // nothing found, cache for later - this.npmResolutionCache.set(normalizedImportExpr, null); - return null; - } - /** - * Return file paths matching the import relative to the repo root - * @param normalizedImportExpr - * @returns - */ - findPaths(normalizedImportExpr) { - if (!this.paths) { - return undefined; - } - if (this.paths[normalizedImportExpr]) { - return this.paths[normalizedImportExpr]; - } - const wildcardPath = Object.keys(this.paths).find((path) => path.endsWith('/*') && - (normalizedImportExpr.startsWith(path.replace(/\*$/, '')) || - normalizedImportExpr === path.replace(/\/\*$/, ''))); - if (wildcardPath) { - return this.paths[wildcardPath]; - } - return undefined; - } - resolveImportWithTypescript(normalizedImportExpr, filePath) { - let resolvedModule; - if (this.typescriptResolutionCache.has(normalizedImportExpr)) { - resolvedModule = this.typescriptResolutionCache.get(normalizedImportExpr); - } - else { - resolvedModule = (0, typescript_1.resolveModuleByImport)(normalizedImportExpr, filePath, this.tsConfig.absolutePath); - this.typescriptResolutionCache.set(normalizedImportExpr, resolvedModule ? resolvedModule : null); - } - // TODO: vsavkin temporary workaround. Remove it once we reworking handling of npm packages. - if (resolvedModule && resolvedModule.indexOf('node_modules/') === -1) { - const resolvedProject = this.findProjectOfResolvedModule(resolvedModule); - if (resolvedProject) { - return resolvedProject; - } - } - return; - } - resolveImportWithRequire(normalizedImportExpr, filePath) { - return path_1.posix.relative(workspace_root_1.workspaceRoot, require.resolve(normalizedImportExpr, { - paths: [(0, path_1.dirname)(filePath)], - })); - } - findNpmPackage(npmImport) { - if (this.npmResolutionCache.has(npmImport)) { - return this.npmResolutionCache.get(npmImport); - } - else { - const pkg = this.npmProjects.find((pkg) => npmImport === pkg.data.packageName || - npmImport.startsWith(`${pkg.data.packageName}/`)); - if (pkg) { - this.npmResolutionCache.set(npmImport, pkg.name); - return pkg.name; - } - } - } - findProjectOfResolvedModule(resolvedModule) { - if (resolvedModule.startsWith('node_modules/')) - return undefined; - const normalizedResolvedModule = resolvedModule.startsWith('./') - ? resolvedModule.substring(2) - : resolvedModule; - const importedProject = this.findMatchingProjectFiles(normalizedResolvedModule); - return importedProject ? importedProject.name : void 0; - } - getAbsolutePath(path) { - return (0, path_1.join)(workspace_root_1.workspaceRoot, path); - } - getRootTsConfig() { - const path = (0, typescript_1.getRootTsConfigFileName)(); - if (!path) { - return { - path: null, - absolutePath: null, - config: null, - }; - } - const absolutePath = this.getAbsolutePath(path); - return { - absolutePath, - path, - config: (0, fileutils_1.readJsonFile)(absolutePath), - }; - } - findMatchingProjectFiles(file) { - const project = (0, find_project_for_path_1.findProjectForPath)(file, this.projectRootMappings); - return this.nodes[project]; - } -} -exports.TargetProjectLocator = TargetProjectLocator; -// matches `npm:@scope/name`, `npm:name` but not `npm:@scope/name@version` and `npm:name@version` -const ROOT_VERSION_PACKAGE_NAME_REGEX = /^npm:(?!.+@.+)/; -function filterRootExternalDependencies(externalNodes) { - if (!externalNodes) { - return []; - } - const keys = Object.keys(externalNodes); - const nodes = []; - for (let i = 0; i < keys.length; i++) { - if (keys[i].match(ROOT_VERSION_PACKAGE_NAME_REGEX)) { - nodes.push(externalNodes[keys[i]]); - } +common.register('cat', _cat, { + canReceivePipe: true, + cmdOptions: { + 'n': 'number', + }, +}); + +//@ +//@ ### cat([options,] file [, file ...]) +//@ ### cat([options,] file_array) +//@ +//@ Available options: +//@ +//@ + `-n`: number all output lines +//@ +//@ Examples: +//@ +//@ ```javascript +//@ var str = cat('file*.txt'); +//@ var str = cat('file1', 'file2'); +//@ var str = cat(['file1', 'file2']); // same as above +//@ ``` +//@ +//@ Returns a string containing the given file, or a concatenated string +//@ containing the files if more than one file is given (a new line character is +//@ introduced between each file). +function _cat(options, files) { + var cat = common.readFromPipe(); + + if (!files && !cat) common.error('no paths given'); + + files = [].slice.call(arguments, 1); + + files.forEach(function (file) { + if (!fs.existsSync(file)) { + common.error('no such file or directory: ' + file); + } else if (common.statFollowLinks(file).isDirectory()) { + common.error(file + ': Is a directory'); } - return nodes; + + cat += fs.readFileSync(file, 'utf8'); + }); + + if (options.number) { + cat = addNumbers(cat); + } + + return cat; } +module.exports = _cat; +function addNumbers(cat) { + var lines = cat.split('\n'); + var lastLine = lines.pop(); -/***/ }), + lines = lines.map(function (line, i) { + return numberedLine(i + 1, line); + }); -/***/ 40234: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { + if (lastLine.length) { + lastLine = numberedLine(lines.length + 1, lastLine); + } + lines.push(lastLine); -"use strict"; + return lines.join('\n'); +} -Object.defineProperty(exports, "__esModule", ({ value: true })); -exports.TypeScriptImportLocator = void 0; -const path = __nccwpck_require__(71017); -const strip_source_code_1 = __nccwpck_require__(84447); -const project_graph_1 = __nccwpck_require__(49899); -const file_utils_1 = __nccwpck_require__(93155); -let tsModule; -class TypeScriptImportLocator { - constructor() { - tsModule = __nccwpck_require__(70048); - this.scanner = tsModule.createScanner(tsModule.ScriptTarget.Latest, false); - } - fromFile(filePath, visitor) { - const extension = path.extname(filePath); - if (extension !== '.ts' && - extension !== '.mts' && - extension !== '.tsx' && - extension !== '.js' && - extension !== '.mjs' && - extension !== '.jsx') { - return; - } - const content = (0, file_utils_1.defaultFileRead)(filePath); - const strippedContent = (0, strip_source_code_1.stripSourceCode)(this.scanner, content); - if (strippedContent !== '') { - const tsFile = tsModule.createSourceFile(filePath, strippedContent, tsModule.ScriptTarget.Latest, true); - this.fromNode(filePath, tsFile, visitor); - } - } - fromNode(filePath, node, visitor) { - if (tsModule.isImportDeclaration(node) || - (tsModule.isExportDeclaration(node) && node.moduleSpecifier)) { - if (!this.ignoreStatement(node)) { - const imp = this.getStringLiteralValue(node.moduleSpecifier); - visitor(imp, filePath, project_graph_1.DependencyType.static); - } - return; // stop traversing downwards - } - if (tsModule.isCallExpression(node) && - node.expression.kind === tsModule.SyntaxKind.ImportKeyword && - node.arguments.length === 1 && - tsModule.isStringLiteral(node.arguments[0])) { - if (!this.ignoreStatement(node)) { - const imp = this.getStringLiteralValue(node.arguments[0]); - visitor(imp, filePath, project_graph_1.DependencyType.dynamic); - } - return; - } - if (tsModule.isCallExpression(node) && - node.expression.getText() === 'require' && - node.arguments.length === 1 && - tsModule.isStringLiteral(node.arguments[0])) { - if (!this.ignoreStatement(node)) { - const imp = this.getStringLiteralValue(node.arguments[0]); - visitor(imp, filePath, project_graph_1.DependencyType.static); - } - return; - } - if (node.kind === tsModule.SyntaxKind.PropertyAssignment) { - const name = this.getPropertyAssignmentName(node.name); - if (name === 'loadChildren') { - const init = node.initializer; - if (init.kind === tsModule.SyntaxKind.StringLiteral && - !this.ignoreLoadChildrenDependency(node.getFullText())) { - const childrenExpr = this.getStringLiteralValue(init); - visitor(childrenExpr, filePath, project_graph_1.DependencyType.dynamic); - return; // stop traversing downwards - } - } - } - /** - * Continue traversing down the AST from the current node - */ - tsModule.forEachChild(node, (child) => this.fromNode(filePath, child, visitor)); - } - ignoreStatement(node) { - return (0, strip_source_code_1.stripSourceCode)(this.scanner, node.getFullText()) === ''; - } - ignoreLoadChildrenDependency(contents) { - this.scanner.setText(contents); - let token = this.scanner.scan(); - while (token !== tsModule.SyntaxKind.EndOfFileToken) { - if (token === tsModule.SyntaxKind.SingleLineCommentTrivia || - token === tsModule.SyntaxKind.MultiLineCommentTrivia) { - const start = this.scanner.getStartPos() + 2; - token = this.scanner.scan(); - const isMultiLineCommentTrivia = token === tsModule.SyntaxKind.MultiLineCommentTrivia; - const end = this.scanner.getStartPos() - (isMultiLineCommentTrivia ? 2 : 0); - const comment = contents.substring(start, end).trim(); - if (comment === 'nx-ignore-next-line') { - return true; - } - } - else { - token = this.scanner.scan(); - } - } - return false; - } - getPropertyAssignmentName(nameNode) { - switch (nameNode.kind) { - case tsModule.SyntaxKind.Identifier: - return nameNode.getText(); - case tsModule.SyntaxKind.StringLiteral: - return nameNode.text; - default: - return null; - } - } - getStringLiteralValue(node) { - return node.getText().slice(1, -1); - } +function numberedLine(n, line) { + // GNU cat use six pad start number + tab. See http://lingrok.org/xref/coreutils/src/cat.c#57 + // https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/padStart + var number = (' ' + n).slice(-6) + '\t'; + return number + line; } -exports.TypeScriptImportLocator = TypeScriptImportLocator; /***/ }), -/***/ 16354: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { +/***/ 79117: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { -"use strict"; +var os = __nccwpck_require__(22037); +var common = __nccwpck_require__(60624); -Object.defineProperty(exports, "__esModule", ({ value: true })); -exports.getTsNodeCompilerOptions = exports.registerTsConfigPaths = exports.registerTranspiler = exports.getTranspiler = exports.getTsNodeTranspiler = exports.getSwcTranspiler = exports.registerTsProject = void 0; -const path_1 = __nccwpck_require__(71017); -const logger_1 = __nccwpck_require__(95324); -const swcNodeInstalled = packageIsInstalled('@swc-node/register'); -const tsNodeInstalled = packageIsInstalled('ts-node/register'); -let ts; -/** - * Optionally, if swc-node and tsconfig-paths are available in the current workspace, apply the require - * register hooks so that .ts files can be used for writing custom workspace projects. - * - * If ts-node and tsconfig-paths are not available, the user can still provide an index.js file in - * the root of their project and the fundamentals will still work (but - * workspace path mapping will not, for example). - * - * @returns cleanup function - */ -const registerTsProject = (path, configFilename = 'tsconfig.json') => { - const tsConfigPath = (0, path_1.join)(path, configFilename); - const compilerOptions = readCompilerOptions(tsConfigPath); - const cleanupFunctions = [ - registerTsConfigPaths(tsConfigPath), - registerTranspiler(compilerOptions), - ]; - return () => { - for (const fn of cleanupFunctions) { - fn(); - } - }; -}; -exports.registerTsProject = registerTsProject; -function getSwcTranspiler(compilerOptions) { - // These are requires to prevent it from registering when it shouldn't - const register = (__nccwpck_require__(61856).register); - const cleanupFn = register(compilerOptions); - return typeof cleanupFn === 'function' ? cleanupFn : () => { }; -} -exports.getSwcTranspiler = getSwcTranspiler; -function getTsNodeTranspiler(compilerOptions) { - const { register } = __nccwpck_require__(51351); - // ts-node doesn't provide a cleanup method - const service = register({ - transpileOnly: true, - compilerOptions: getTsNodeCompilerOptions(compilerOptions), - }); - const { transpiler, swc } = service.options; - // Don't warn if a faster transpiler is enabled - if (!transpiler && !swc) { - warnTsNodeUsage(); - } - return () => { }; -} -exports.getTsNodeTranspiler = getTsNodeTranspiler; -function getTranspiler(compilerOptions) { - const preferTsNode = process.env.NX_PREFER_TS_NODE === 'true'; - if (swcNodeInstalled && !preferTsNode) { - return () => getSwcTranspiler(compilerOptions); - } - // We can fall back on ts-node if it's available - if (tsNodeInstalled) { - return () => getTsNodeTranspiler(compilerOptions); - } -} -exports.getTranspiler = getTranspiler; -/** - * Register ts-node or swc-node given a set of compiler options. - * - * Note: Several options require enums from typescript. To avoid importing typescript, - * use import type + raw values - * - * @returns cleanup method - */ -function registerTranspiler(compilerOptions) { - // Function to register transpiler that returns cleanup function - const transpiler = getTranspiler(compilerOptions); - if (!transpiler) { - warnNoTranspiler(); - return () => { }; - } - return transpiler(); -} -exports.registerTranspiler = registerTranspiler; -/** - * @param tsConfigPath Adds the paths from a tsconfig file into node resolutions - * @returns cleanup function - */ -function registerTsConfigPaths(tsConfigPath) { - try { - /** - * Load the ts config from the source project - */ - const tsconfigPaths = __nccwpck_require__(10839); - const tsConfigResult = tsconfigPaths.loadConfig(tsConfigPath); - /** - * Register the custom workspace path mappings with node so that workspace libraries - * can be imported and used within project - */ - if (tsConfigResult.resultType === 'success') { - return tsconfigPaths.register({ - baseUrl: tsConfigResult.absoluteBaseUrl, - paths: tsConfigResult.paths, - }); - } - } - catch (err) { - warnNoTsconfigPaths(); - } - return () => { }; -} -exports.registerTsConfigPaths = registerTsConfigPaths; -function readCompilerOptions(tsConfigPath) { - if (swcNodeInstalled) { - const { readDefaultTsConfig, } = __nccwpck_require__(11642); - return readDefaultTsConfig(tsConfigPath); - } - else { - return readCompilerOptionsWithTypescript(tsConfigPath); - } -} -function readCompilerOptionsWithTypescript(tsConfigPath) { - if (!ts) { - ts = __nccwpck_require__(70048); +common.register('cd', _cd, {}); + +//@ +//@ ### cd([dir]) +//@ +//@ Changes to directory `dir` for the duration of the script. Changes to home +//@ directory if no argument is supplied. +function _cd(options, dir) { + if (!dir) dir = os.homedir(); + + if (dir === '-') { + if (!process.env.OLDPWD) { + common.error('could not find previous directory'); + } else { + dir = process.env.OLDPWD; } - const { readConfigFile, parseJsonConfigFileContent, sys } = ts; - const jsonContent = readConfigFile(tsConfigPath, sys.readFile); - const { options } = parseJsonConfigFileContent(jsonContent.config, sys, (0, path_1.dirname)(tsConfigPath)); - // This property is returned in compiler options for some reason, but not part of the typings. - // ts-node fails on unknown props, so we have to remove it. - delete options.configFilePath; - return options; -} -function warnTsNodeUsage() { - logger_1.logger.warn((0, logger_1.stripIndent)(`${logger_1.NX_PREFIX} Falling back to ts-node for local typescript execution. This may be a little slower. - - To fix this, ensure @swc-node/register and @swc/core have been installed`)); -} -function warnNoTsconfigPaths() { - logger_1.logger.warn((0, logger_1.stripIndent)(`${logger_1.NX_PREFIX} Unable to load tsconfig-paths, workspace libraries may be inaccessible. - - To fix this, install tsconfig-paths with npm/yarn/pnpm`)); -} -function warnNoTranspiler() { - logger_1.logger.warn((0, logger_1.stripIndent)(`${logger_1.NX_PREFIX} Unable to locate swc-node or ts-node. Nx will be unable to run local ts files without transpiling. - - To fix this, ensure @swc-node/register and @swc/core have been installed`)); -} -function packageIsInstalled(m) { + } + + try { + var curDir = process.cwd(); + process.chdir(dir); + process.env.OLDPWD = curDir; + } catch (e) { + // something went wrong, let's figure out the error + var err; try { - const p = require.resolve(m); - return true; - } - catch (_a) { - return false; - } -} -/** - * ts-node requires string values for enum based typescript options. - * `register`'s signature just types the field as `object`, so we - * unfortunately do not get any kind of type safety on this. - */ -function getTsNodeCompilerOptions(compilerOptions) { - var _a; - if (!ts) { - ts = __nccwpck_require__(70048); - } - const flagMap = { - module: 'ModuleKind', - target: 'ScriptTarget', - moduleDetection: 'ModuleDetectionKind', - newLine: 'NewLineKind', - moduleResolution: 'ModuleResolutionKind', - importsNotUsedAsValues: 'ImportsNotUsedAsValues', - }; - const result = Object.assign({}, compilerOptions); - for (const flag in flagMap) { - if (compilerOptions[flag]) { - result[flag] = ts[flagMap[flag]][compilerOptions[flag]]; - } - } - delete result.pathsBasePath; - delete result.configFilePath; - // instead of mapping to enum value we just remove it as it shouldn't ever need to be set for ts-node - delete result.jsx; - // lib option is in the format `lib.es2022.d.ts`, so we need to remove the leading `lib.` and trailing `.d.ts` to make it valid - result.lib = (_a = result.lib) === null || _a === void 0 ? void 0 : _a.map((value) => { - return value.replace(/^lib\./, '').replace(/\.d\.ts$/, ''); - }); - if (result.moduleResolution) { - result.moduleResolution = - result.moduleResolution === 'NodeJs' - ? 'node' - : result.moduleResolution.toLowerCase(); + common.statFollowLinks(dir); // if this succeeds, it must be some sort of file + err = 'not a directory: ' + dir; + } catch (e2) { + err = 'no such file or directory: ' + dir; } - return result; + if (err) common.error(err); + } + return ''; } -exports.getTsNodeCompilerOptions = getTsNodeCompilerOptions; +module.exports = _cd; /***/ }), -/***/ 62029: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { +/***/ 19879: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { -"use strict"; +var common = __nccwpck_require__(60624); +var fs = __nccwpck_require__(57147); +var path = __nccwpck_require__(71017); -Object.defineProperty(exports, "__esModule", ({ value: true })); -exports.findNodes = exports.getRootTsConfigPath = exports.getRootTsConfigFileName = exports.resolveModuleByImport = exports.readTsConfig = void 0; -const workspace_root_1 = __nccwpck_require__(65766); -const fs_1 = __nccwpck_require__(57147); -const path_1 = __nccwpck_require__(71017); -const normalizedAppRoot = workspace_root_1.workspaceRoot.replace(/\\/g, '/'); -let tsModule; -function readTsConfig(tsConfigPath) { - if (!tsModule) { - tsModule = __nccwpck_require__(70048); - } - const readResult = tsModule.readConfigFile(tsConfigPath, tsModule.sys.readFile); - return tsModule.parseJsonConfigFileContent(readResult.config, tsModule.sys, (0, path_1.dirname)(tsConfigPath)); -} -exports.readTsConfig = readTsConfig; -function readTsConfigOptions(tsConfigPath) { - if (!tsModule) { - tsModule = __nccwpck_require__(70048); - } - const readResult = tsModule.readConfigFile(tsConfigPath, tsModule.sys.readFile); - // we don't need to scan the files, we only care about options - const host = { - readDirectory: () => [], - readFile: () => '', - fileExists: tsModule.sys.fileExists, - }; - return tsModule.parseJsonConfigFileContent(readResult.config, host, (0, path_1.dirname)(tsConfigPath)).options; -} -let compilerHost; -/** - * Find a module based on its import - * - * @param importExpr Import used to resolve to a module - * @param filePath - * @param tsConfigPath - */ -function resolveModuleByImport(importExpr, filePath, tsConfigPath) { - compilerHost = compilerHost || getCompilerHost(tsConfigPath); - const { options, host, moduleResolutionCache } = compilerHost; - const { resolvedModule } = tsModule.resolveModuleName(importExpr, filePath, options, host, moduleResolutionCache); - if (!resolvedModule) { - return; - } - else { - return resolvedModule.resolvedFileName.replace(`${normalizedAppRoot}/`, ''); - } -} -exports.resolveModuleByImport = resolveModuleByImport; -function getCompilerHost(tsConfigPath) { - const options = readTsConfigOptions(tsConfigPath); - const host = tsModule.createCompilerHost(options, true); - const moduleResolutionCache = tsModule.createModuleResolutionCache(workspace_root_1.workspaceRoot, host.getCanonicalFileName); - return { options, host, moduleResolutionCache }; -} -function getRootTsConfigFileName() { - for (const tsConfigName of ['tsconfig.base.json', 'tsconfig.json']) { - const tsConfigPath = (0, path_1.join)(workspace_root_1.workspaceRoot, tsConfigName); - if ((0, fs_1.existsSync)(tsConfigPath)) { - return tsConfigName; - } - } - return null; -} -exports.getRootTsConfigFileName = getRootTsConfigFileName; -function getRootTsConfigPath() { - const tsConfigFileName = getRootTsConfigFileName(); - return tsConfigFileName ? (0, path_1.join)(workspace_root_1.workspaceRoot, tsConfigFileName) : null; -} -exports.getRootTsConfigPath = getRootTsConfigPath; -function findNodes(node, kind, max = Infinity) { - if (!node || max == 0) { - return []; - } - const arr = []; - const hasMatch = Array.isArray(kind) - ? kind.includes(node.kind) - : node.kind === kind; - if (hasMatch) { - arr.push(node); - max--; - } - if (max > 0) { - for (const child of node.getChildren()) { - findNodes(child, kind, max).forEach((node) => { - if (max > 0) { - arr.push(node); - } - max--; - }); - if (max <= 0) { - break; - } - } +var PERMS = (function (base) { + return { + OTHER_EXEC: base.EXEC, + OTHER_WRITE: base.WRITE, + OTHER_READ: base.READ, + + GROUP_EXEC: base.EXEC << 3, + GROUP_WRITE: base.WRITE << 3, + GROUP_READ: base.READ << 3, + + OWNER_EXEC: base.EXEC << 6, + OWNER_WRITE: base.WRITE << 6, + OWNER_READ: base.READ << 6, + + // Literal octal numbers are apparently not allowed in "strict" javascript. + STICKY: parseInt('01000', 8), + SETGID: parseInt('02000', 8), + SETUID: parseInt('04000', 8), + + TYPE_MASK: parseInt('0770000', 8), + }; +}({ + EXEC: 1, + WRITE: 2, + READ: 4, +})); + +common.register('chmod', _chmod, { +}); + +//@ +//@ ### chmod([options,] octal_mode || octal_string, file) +//@ ### chmod([options,] symbolic_mode, file) +//@ +//@ Available options: +//@ +//@ + `-v`: output a diagnostic for every file processed//@ +//@ + `-c`: like verbose, but report only when a change is made//@ +//@ + `-R`: change files and directories recursively//@ +//@ +//@ Examples: +//@ +//@ ```javascript +//@ chmod(755, '/Users/brandon'); +//@ chmod('755', '/Users/brandon'); // same as above +//@ chmod('u+x', '/Users/brandon'); +//@ chmod('-R', 'a-w', '/Users/brandon'); +//@ ``` +//@ +//@ Alters the permissions of a file or directory by either specifying the +//@ absolute permissions in octal form or expressing the changes in symbols. +//@ This command tries to mimic the POSIX behavior as much as possible. +//@ Notable exceptions: +//@ +//@ + In symbolic modes, `a-r` and `-r` are identical. No consideration is +//@ given to the `umask`. +//@ + There is no "quiet" option, since default behavior is to run silent. +function _chmod(options, mode, filePattern) { + if (!filePattern) { + if (options.length > 0 && options.charAt(0) === '-') { + // Special case where the specified file permissions started with - to subtract perms, which + // get picked up by the option parser as command flags. + // If we are down by one argument and options starts with -, shift everything over. + [].unshift.call(arguments, ''); + } else { + common.error('You must specify a file.'); } - return arr; -} -exports.findNodes = findNodes; + } + options = common.parseOptions(options, { + 'R': 'recursive', + 'c': 'changes', + 'v': 'verbose', + }); -/***/ }), + filePattern = [].slice.call(arguments, 2); -/***/ 84445: -/***/ ((__unused_webpack_module, exports) => { + var files; -"use strict"; + // TODO: replace this with a call to common.expand() + if (options.recursive) { + files = []; + filePattern.forEach(function addFile(expandedFile) { + var stat = common.statNoFollowLinks(expandedFile); -Object.defineProperty(exports, "__esModule", ({ value: true })); -exports.buildImplicitProjectDependencies = void 0; -function buildImplicitProjectDependencies(ctx, builder) { - Object.keys(ctx.projectsConfigurations.projects).forEach((source) => { - const p = ctx.projectsConfigurations.projects[source]; - if (p.implicitDependencies && p.implicitDependencies.length > 0) { - p.implicitDependencies.forEach((target) => { - if (target.startsWith('!')) { - builder.removeDependency(source, target.slice(1)); - } - else { - builder.addImplicitDependency(source, target); - } - }); + if (!stat.isSymbolicLink()) { + files.push(expandedFile); + + if (stat.isDirectory()) { // intentionally does not follow symlinks. + fs.readdirSync(expandedFile).forEach(function (child) { + addFile(expandedFile + '/' + child); + }); } + } }); -} -exports.buildImplicitProjectDependencies = buildImplicitProjectDependencies; + } else { + files = filePattern; + } + files.forEach(function innerChmod(file) { + file = path.resolve(file); + if (!fs.existsSync(file)) { + common.error('File not found: ' + file); + } -/***/ }), + // When recursing, don't follow symlinks. + if (options.recursive && common.statNoFollowLinks(file).isSymbolicLink()) { + return; + } -/***/ 54031: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { + var stat = common.statFollowLinks(file); + var isDir = stat.isDirectory(); + var perms = stat.mode; + var type = perms & PERMS.TYPE_MASK; -"use strict"; + var newPerms = perms; -Object.defineProperty(exports, "__esModule", ({ value: true })); -const tslib_1 = __nccwpck_require__(51796); -tslib_1.__exportStar(__nccwpck_require__(84445), exports); + if (isNaN(parseInt(mode, 8))) { + // parse options + mode.split(',').forEach(function (symbolicMode) { + var pattern = /([ugoa]*)([=\+-])([rwxXst]*)/i; + var matches = pattern.exec(symbolicMode); + if (matches) { + var applyTo = matches[1]; + var operator = matches[2]; + var change = matches[3]; -/***/ }), + var changeOwner = applyTo.indexOf('u') !== -1 || applyTo === 'a' || applyTo === ''; + var changeGroup = applyTo.indexOf('g') !== -1 || applyTo === 'a' || applyTo === ''; + var changeOther = applyTo.indexOf('o') !== -1 || applyTo === 'a' || applyTo === ''; -/***/ 58729: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { + var changeRead = change.indexOf('r') !== -1; + var changeWrite = change.indexOf('w') !== -1; + var changeExec = change.indexOf('x') !== -1; + var changeExecDir = change.indexOf('X') !== -1; + var changeSticky = change.indexOf('t') !== -1; + var changeSetuid = change.indexOf('s') !== -1; -"use strict"; + if (changeExecDir && isDir) { + changeExec = true; + } -Object.defineProperty(exports, "__esModule", ({ value: true })); -const tslib_1 = __nccwpck_require__(51796); -tslib_1.__exportStar(__nccwpck_require__(66055), exports); + var mask = 0; + if (changeOwner) { + mask |= (changeRead ? PERMS.OWNER_READ : 0) + (changeWrite ? PERMS.OWNER_WRITE : 0) + (changeExec ? PERMS.OWNER_EXEC : 0) + (changeSetuid ? PERMS.SETUID : 0); + } + if (changeGroup) { + mask |= (changeRead ? PERMS.GROUP_READ : 0) + (changeWrite ? PERMS.GROUP_WRITE : 0) + (changeExec ? PERMS.GROUP_EXEC : 0) + (changeSetuid ? PERMS.SETGID : 0); + } + if (changeOther) { + mask |= (changeRead ? PERMS.OTHER_READ : 0) + (changeWrite ? PERMS.OTHER_WRITE : 0) + (changeExec ? PERMS.OTHER_EXEC : 0); + } + // Sticky bit is special - it's not tied to user, group or other. + if (changeSticky) { + mask |= PERMS.STICKY; + } -/***/ }), + switch (operator) { + case '+': + newPerms |= mask; + break; -/***/ 66055: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { + case '-': + newPerms &= ~mask; + break; -"use strict"; + case '=': + newPerms = type + mask; -Object.defineProperty(exports, "__esModule", ({ value: true })); -exports.normalizeImplicitDependencies = exports.buildWorkspaceProjectNodes = void 0; -const tslib_1 = __nccwpck_require__(51796); -const path_1 = __nccwpck_require__(71017); -const fs_1 = __nccwpck_require__(57147); -const workspace_root_1 = __nccwpck_require__(65766); -const nx_plugin_1 = __nccwpck_require__(86740); -const project_graph_utils_1 = __nccwpck_require__(27377); -const fileutils_1 = __nccwpck_require__(47930); -const find_matching_projects_1 = __nccwpck_require__(56668); -const logger_1 = __nccwpck_require__(95324); -const workspaces_1 = __nccwpck_require__(98715); -function buildWorkspaceProjectNodes(ctx, builder, nxJson) { - var _a, _b; - return tslib_1.__awaiter(this, void 0, void 0, function* () { - const toAdd = []; - const projects = Object.keys(ctx.projectsConfigurations.projects); - // Used for expanding implicit dependencies (e.g. `@proj/*` or `tag:foo`) - const partialProjectGraphNodes = projects.reduce((graph, project) => { - const projectConfiguration = ctx.projectsConfigurations.projects[project]; - graph[project] = { - name: project, - type: projectConfiguration.projectType === 'library' ? 'lib' : 'app', - data: Object.assign({}, projectConfiguration), - }; - return graph; - }, {}); - for (const key of projects) { - const p = ctx.projectsConfigurations.projects[key]; - const projectRoot = (0, path_1.join)(workspace_root_1.workspaceRoot, p.root); - if ((0, fs_1.existsSync)((0, path_1.join)(projectRoot, 'package.json'))) { - p.targets = (0, project_graph_utils_1.mergeNpmScriptsWithTargets)(projectRoot, p.targets); - try { - const { nx } = (0, fileutils_1.readJsonFile)((0, path_1.join)(projectRoot, 'package.json')); - if (nx === null || nx === void 0 ? void 0 : nx.tags) { - p.tags = [...(p.tags || []), ...nx.tags]; - } - if (nx === null || nx === void 0 ? void 0 : nx.implicitDependencies) { - p.implicitDependencies = [ - ...(p.implicitDependencies || []), - ...nx.implicitDependencies, - ]; - } - if (nx === null || nx === void 0 ? void 0 : nx.namedInputs) { - p.namedInputs = Object.assign(Object.assign({}, (p.namedInputs || {})), nx.namedInputs); - } - } - catch (_c) { - // ignore json parser errors - } - } - p.implicitDependencies = normalizeImplicitDependencies(key, p.implicitDependencies, partialProjectGraphNodes); - p.targets = (0, nx_plugin_1.mergePluginTargetsWithNxTargets)(p.root, p.targets, yield (0, nx_plugin_1.loadNxPlugins)(ctx.nxJsonConfiguration.plugins)); - p.targets = normalizeProjectTargets(p, nxJson.targetDefaults, key); - // TODO: remove in v16 - const projectType = p.projectType === 'application' - ? key.endsWith('-e2e') || key === 'e2e' - ? 'e2e' - : 'app' - : 'lib'; - const tags = ((_b = (_a = ctx.projectsConfigurations.projects) === null || _a === void 0 ? void 0 : _a[key]) === null || _b === void 0 ? void 0 : _b.tags) || []; - toAdd.push({ - name: key, - type: projectType, - data: Object.assign(Object.assign({}, p), { tags }), - }); - } - // Sort by root directory length (do we need this?) - toAdd.sort((a, b) => { - if (!a.data.root) - return -1; - if (!b.data.root) - return -1; - return a.data.root.length > b.data.root.length ? -1 : 1; - }); - toAdd.forEach((n) => { - builder.addNode({ - name: n.name, - type: n.type, - data: n.data, - }); - }); - }); -} -exports.buildWorkspaceProjectNodes = buildWorkspaceProjectNodes; -/** - * Apply target defaults and normalization - */ -function normalizeProjectTargets(project, targetDefaults, projectName) { - var _a; - const targets = project.targets; - for (const target in targets) { - const executor = ((_a = targets[target].executor) !== null && _a !== void 0 ? _a : targets[target].command) - ? 'nx:run-commands' - : null; - const defaults = (0, workspaces_1.readTargetDefaultsForTarget)(target, targetDefaults, executor); - if (defaults) { - targets[target] = (0, workspaces_1.mergeTargetConfigurations)(project, target, defaults); - } - const config = targets[target]; - if (config.command) { - if (config.executor) { - throw new Error(`${logger_1.NX_PREFIX} ${projectName}: ${target} should not have executor and command both configured.`); - } - else { - targets[target] = Object.assign(Object.assign({}, targets[target]), { executor, options: Object.assign(Object.assign({}, config.options), { command: config.command }) }); - delete config.command; + // According to POSIX, when using = to explicitly set the + // permissions, setuid and setgid can never be cleared. + if (common.statFollowLinks(file).isDirectory()) { + newPerms |= (PERMS.SETUID + PERMS.SETGID) & perms; + } + break; + default: + common.error('Could not recognize operator: `' + operator + '`'); + } + + if (options.verbose) { + console.log(file + ' -> ' + newPerms.toString(8)); + } + + if (perms !== newPerms) { + if (!options.verbose && options.changes) { + console.log(file + ' -> ' + newPerms.toString(8)); } + fs.chmodSync(file, newPerms); + perms = newPerms; // for the next round of changes! + } + } else { + common.error('Invalid symbolic mode change: ' + symbolicMode); } + }); + } else { + // they gave us a full number + newPerms = type + parseInt(mode, 8); + + // POSIX rules are that setuid and setgid can only be added using numeric + // form, but not cleared. + if (common.statFollowLinks(file).isDirectory()) { + newPerms |= (PERMS.SETUID + PERMS.SETGID) & perms; + } + + fs.chmodSync(file, newPerms); } - return targets; -} -function normalizeImplicitDependencies(source, implicitDependencies, projects) { - if (!(implicitDependencies === null || implicitDependencies === void 0 ? void 0 : implicitDependencies.length)) { - return implicitDependencies !== null && implicitDependencies !== void 0 ? implicitDependencies : []; - } - const matches = (0, find_matching_projects_1.findMatchingProjects)(implicitDependencies, projects); - return (matches - .filter((x) => x !== source) - // implicit dependencies that start with ! should hang around, to be processed by - // implicit-project-dependencies.ts after explicit deps are added to graph. - .concat(implicitDependencies.filter((x) => x.startsWith('!')))); + }); + return ''; } -exports.normalizeImplicitDependencies = normalizeImplicitDependencies; +module.exports = _chmod; /***/ }), -/***/ 60214: +/***/ 60624: /***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { "use strict"; +// Ignore warning about 'new String()' +/* eslint no-new-wrappers: 0 */ -Object.defineProperty(exports, "__esModule", ({ value: true })); -exports.buildProjectGraphUsingProjectFileMap = exports.getProjectFileMap = void 0; -const tslib_1 = __nccwpck_require__(51796); -const workspace_root_1 = __nccwpck_require__(65766); -const path_1 = __nccwpck_require__(71017); -const perf_hooks_1 = __nccwpck_require__(4074); -const assert_workspace_validity_1 = __nccwpck_require__(51635); -const nx_deps_cache_1 = __nccwpck_require__(65959); -const build_dependencies_1 = __nccwpck_require__(54031); -const build_nodes_1 = __nccwpck_require__(58729); -const nx_plugin_1 = __nccwpck_require__(86740); -const typescript_1 = __nccwpck_require__(62029); -const fileutils_1 = __nccwpck_require__(47930); -const project_graph_builder_1 = __nccwpck_require__(14812); -const configuration_1 = __nccwpck_require__(65459); -const fs_1 = __nccwpck_require__(57147); -let storedProjectFileMap = null; -let storedAllWorkspaceFiles = null; -function getProjectFileMap() { - if (!!storedProjectFileMap) { - return { - projectFileMap: storedProjectFileMap, - allWorkspaceFiles: storedAllWorkspaceFiles, - }; - } - else { - return { projectFileMap: {}, allWorkspaceFiles: [] }; - } -} -exports.getProjectFileMap = getProjectFileMap; -function buildProjectGraphUsingProjectFileMap(projectsConfigurations, projectFileMap, allWorkspaceFiles, fileMap, shouldWriteCache) { - return tslib_1.__awaiter(this, void 0, void 0, function* () { - storedProjectFileMap = projectFileMap; - storedAllWorkspaceFiles = allWorkspaceFiles; - const nxJson = (0, configuration_1.readNxJson)(); - const projectGraphVersion = '6.0'; - (0, assert_workspace_validity_1.assertWorkspaceValidity)(projectsConfigurations, nxJson); - const packageJsonDeps = readCombinedDeps(); - const rootTsConfig = readRootTsConfig(); - let filesToProcess; - let cachedFileData; - const useCacheData = fileMap && - !(0, nx_deps_cache_1.shouldRecomputeWholeGraph)(fileMap, packageJsonDeps, projectsConfigurations, nxJson, rootTsConfig); - if (useCacheData) { - const fromCache = (0, nx_deps_cache_1.extractCachedFileData)(projectFileMap, fileMap); - filesToProcess = fromCache.filesToProcess; - cachedFileData = fromCache.cachedFileData; - } - else { - filesToProcess = projectFileMap; - cachedFileData = {}; - } - const context = createContext(projectsConfigurations, nxJson, projectFileMap, filesToProcess); - let projectGraph = yield buildProjectGraphUsingContext(nxJson, context, cachedFileData, projectGraphVersion); - const projectFileMapCache = (0, nx_deps_cache_1.createProjectFileMapCache)(nxJson, packageJsonDeps, projectFileMap, rootTsConfig); - if (shouldWriteCache) { - (0, nx_deps_cache_1.writeCache)(projectFileMapCache, projectGraph); - } - return { - projectGraph, - projectFileMapCache, - }; - }); -} -exports.buildProjectGraphUsingProjectFileMap = buildProjectGraphUsingProjectFileMap; -function readCombinedDeps() { - const installationPackageJsonPath = (0, path_1.join)(workspace_root_1.workspaceRoot, '.nx', 'installation', 'package.json'); - const installationPackageJson = (0, fs_1.existsSync)(installationPackageJsonPath) - ? (0, fileutils_1.readJsonFile)(installationPackageJsonPath) - : {}; - const rootPackageJsonPath = (0, path_1.join)(workspace_root_1.workspaceRoot, 'package.json'); - const rootPackageJson = (0, fs_1.existsSync)(rootPackageJsonPath) - ? (0, fileutils_1.readJsonFile)(rootPackageJsonPath) - : {}; - return Object.assign(Object.assign(Object.assign(Object.assign({}, rootPackageJson.dependencies), rootPackageJson.devDependencies), installationPackageJson.dependencies), installationPackageJson.devDependencies); -} -function buildProjectGraphUsingContext(nxJson, ctx, cachedFileData, projectGraphVersion) { - return tslib_1.__awaiter(this, void 0, void 0, function* () { - perf_hooks_1.performance.mark('build project graph:start'); - const builder = new project_graph_builder_1.ProjectGraphBuilder(null, ctx.fileMap); - builder.setVersion(projectGraphVersion); - yield (0, build_nodes_1.buildWorkspaceProjectNodes)(ctx, builder, nxJson); - const initProjectGraph = builder.getUpdatedProjectGraph(); - const r = yield updateProjectGraphWithPlugins(ctx, initProjectGraph); - const updatedBuilder = new project_graph_builder_1.ProjectGraphBuilder(r, ctx.fileMap); - for (const proj of Object.keys(cachedFileData)) { - for (const f of ctx.fileMap[proj] || []) { - const cached = cachedFileData[proj][f.file]; - if (cached && cached.deps) { - f.deps = [...cached.deps]; - } - } - } - (0, build_dependencies_1.buildImplicitProjectDependencies)(ctx, updatedBuilder); - const finalGraph = updatedBuilder.getUpdatedProjectGraph(); - perf_hooks_1.performance.mark('build project graph:end'); - perf_hooks_1.performance.measure('build project graph', 'build project graph:start', 'build project graph:end'); - return finalGraph; - }); -} -function createContext(projectsConfigurations, nxJson, fileMap, filesToProcess) { - const projects = Object.keys(projectsConfigurations.projects).reduce((map, projectName) => { - map[projectName] = Object.assign({}, projectsConfigurations.projects[projectName]); - return map; - }, {}); - return { - nxJsonConfiguration: nxJson, - projectsConfigurations, - workspace: Object.assign(Object.assign(Object.assign({}, projectsConfigurations), nxJson), { projects }), - fileMap, - filesToProcess, - }; -} -function updateProjectGraphWithPlugins(context, initProjectGraph) { - return tslib_1.__awaiter(this, void 0, void 0, function* () { - const plugins = (yield (0, nx_plugin_1.loadNxPlugins)(context.nxJsonConfiguration.plugins)).filter((x) => !!x.processProjectGraph); - let graph = initProjectGraph; - for (const plugin of plugins) { - try { - graph = yield plugin.processProjectGraph(graph, context); - } - catch (e) { - let message = `Failed to process the project graph with "${plugin.name}".`; - if (e instanceof Error) { - e.message = message + '\n' + e.message; - throw e; - } - throw new Error(message); - } - } - return graph; - }); -} -function readRootTsConfig() { - try { - const tsConfigPath = (0, typescript_1.getRootTsConfigPath)(); - if (tsConfigPath) { - return (0, fileutils_1.readJsonFile)(tsConfigPath, { expectComments: true }); - } - } - catch (e) { - return {}; + +var os = __nccwpck_require__(22037); +var fs = __nccwpck_require__(57147); +var glob = __nccwpck_require__(69959); +var shell = __nccwpck_require__(26877); + +var shellMethods = Object.create(shell); + +exports.extend = Object.assign; + +// Check if we're running under electron +var isElectron = Boolean(process.versions.electron); + +// Module globals (assume no execPath by default) +var DEFAULT_CONFIG = { + fatal: false, + globOptions: {}, + maxdepth: 255, + noglob: false, + silent: false, + verbose: false, + execPath: null, + bufLength: 64 * 1024, // 64KB +}; + +var config = { + reset: function () { + Object.assign(this, DEFAULT_CONFIG); + if (!isElectron) { + this.execPath = process.execPath; } -} + }, + resetForTesting: function () { + this.reset(); + this.silent = true; + }, +}; +config.reset(); +exports.config = config; -/***/ }), +// Note: commands should generally consider these as read-only values. +var state = { + error: null, + errorCode: 0, + currentCmd: 'shell.js', +}; +exports.state = state; -/***/ 11223: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { +delete process.env.OLDPWD; // initially, there's no previous directory -"use strict"; +// Reliably test if something is any sort of javascript object +function isObject(a) { + return typeof a === 'object' && a !== null; +} +exports.isObject = isObject; -Object.defineProperty(exports, "__esModule", ({ value: true })); -exports.updateProjectFileMap = exports.createProjectFileMap = exports.createProjectFileMapUsingProjectGraph = void 0; -const tslib_1 = __nccwpck_require__(51796); -const find_project_for_path_1 = __nccwpck_require__(36265); -const client_1 = __nccwpck_require__(55942); -const project_graph_1 = __nccwpck_require__(22055); -const impl_1 = __nccwpck_require__(43265); -function createProjectFileMapUsingProjectGraph(graph) { - return tslib_1.__awaiter(this, void 0, void 0, function* () { - const configs = (0, project_graph_1.readProjectsConfigurationFromProjectGraph)(graph); - const files = client_1.daemonClient.enabled() - ? yield client_1.daemonClient.getAllFileData() - : impl_1.fileHasher.allFileData(); - return createProjectFileMap(configs, files).projectFileMap; - }); +function log() { + /* istanbul ignore next */ + if (!config.silent) { + console.error.apply(console, arguments); + } } -exports.createProjectFileMapUsingProjectGraph = createProjectFileMapUsingProjectGraph; -function createProjectFileMap(projectsConfigurations, allWorkspaceFiles) { - var _a; - const projectFileMap = {}; - const projectRootMappings = (0, find_project_for_path_1.createProjectRootMappingsFromProjectConfigurations)(projectsConfigurations.projects); - for (const projectName of Object.keys(projectsConfigurations.projects)) { - (_a = projectFileMap[projectName]) !== null && _a !== void 0 ? _a : (projectFileMap[projectName] = []); - } - for (const f of allWorkspaceFiles) { - const projectFileMapKey = (0, find_project_for_path_1.findProjectForPath)(f.file, projectRootMappings); - const matchingProjectFiles = projectFileMap[projectFileMapKey]; - if (matchingProjectFiles) { - matchingProjectFiles.push(f); - } - } - return { projectFileMap, allWorkspaceFiles }; +exports.log = log; + +// Converts strings to be equivalent across all platforms. Primarily responsible +// for making sure we use '/' instead of '\' as path separators, but this may be +// expanded in the future if necessary +function convertErrorOutput(msg) { + if (typeof msg !== 'string') { + throw new TypeError('input must be a string'); + } + return msg.replace(/\\/g, '/'); } -exports.createProjectFileMap = createProjectFileMap; -function updateProjectFileMap(projectsConfigurations, projectFileMap, allWorkspaceFiles, updatedFiles, deletedFiles) { - var _a, _b; - const projectRootMappings = (0, find_project_for_path_1.createProjectRootMappingsFromProjectConfigurations)(projectsConfigurations.projects); - for (const f of updatedFiles.keys()) { - const matchingProjectFiles = (_a = projectFileMap[(0, find_project_for_path_1.findProjectForPath)(f, projectRootMappings)]) !== null && _a !== void 0 ? _a : []; - if (matchingProjectFiles) { - const fileData = matchingProjectFiles.find((t) => t.file === f); - if (fileData) { - fileData.hash = updatedFiles.get(f); - } - else { - matchingProjectFiles.push({ - file: f, - hash: updatedFiles.get(f), - }); - } - } - const fileData = allWorkspaceFiles.find((t) => t.file === f); - if (fileData) { - fileData.hash = updatedFiles.get(f); - } - else { - allWorkspaceFiles.push({ - file: f, - hash: updatedFiles.get(f), - }); - } - } - for (const f of deletedFiles) { - const matchingProjectFiles = (_b = projectFileMap[(0, find_project_for_path_1.findProjectForPath)(f, projectRootMappings)]) !== null && _b !== void 0 ? _b : []; - if (matchingProjectFiles) { - const index = matchingProjectFiles.findIndex((t) => t.file === f); - if (index > -1) { - matchingProjectFiles.splice(index, 1); - } - } - const index = allWorkspaceFiles.findIndex((t) => t.file === f); - if (index > -1) { - allWorkspaceFiles.splice(index, 1); - } - } - return { projectFileMap, allWorkspaceFiles }; +exports.convertErrorOutput = convertErrorOutput; + +// Shows error message. Throws if config.fatal is true +function error(msg, _code, options) { + // Validate input + if (typeof msg !== 'string') throw new Error('msg must be a string'); + + var DEFAULT_OPTIONS = { + continue: false, + code: 1, + prefix: state.currentCmd + ': ', + silent: false, + }; + + if (typeof _code === 'number' && isObject(options)) { + options.code = _code; + } else if (isObject(_code)) { // no 'code' + options = _code; + } else if (typeof _code === 'number') { // no 'options' + options = { code: _code }; + } else if (typeof _code !== 'number') { // only 'msg' + options = {}; + } + options = Object.assign({}, DEFAULT_OPTIONS, options); + + if (!state.errorCode) state.errorCode = options.code; + + var logEntry = convertErrorOutput(options.prefix + msg); + state.error = state.error ? state.error + '\n' : ''; + state.error += logEntry; + + // Throw an error, or log the entry + if (config.fatal) throw new Error(logEntry); + if (msg.length > 0 && !options.silent) log(logEntry); + + if (!options.continue) { + throw { + msg: 'earlyExit', + retValue: (new ShellString('', state.error, state.errorCode)), + }; + } } -exports.updateProjectFileMap = updateProjectFileMap; +exports.error = error; +//@ +//@ ### ShellString(str) +//@ +//@ Examples: +//@ +//@ ```javascript +//@ var foo = ShellString('hello world'); +//@ ``` +//@ +//@ Turns a regular string into a string-like object similar to what each +//@ command returns. This has special methods, like `.to()` and `.toEnd()`. +function ShellString(stdout, stderr, code) { + var that; + if (stdout instanceof Array) { + that = stdout; + that.stdout = stdout.join('\n'); + if (stdout.length > 0) that.stdout += '\n'; + } else { + that = new String(stdout); + that.stdout = stdout; + } + that.stderr = stderr; + that.code = code; + // A list of all commands that can appear on the right-hand side of a pipe + // (populated by calls to common.wrap()) + pipeMethods.forEach(function (cmd) { + that[cmd] = shellMethods[cmd].bind(that); + }); + return that; +} -/***/ }), +exports.ShellString = ShellString; -/***/ 93155: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { +// Returns {'alice': true, 'bob': false} when passed a string and dictionary as follows: +// parseOptions('-a', {'a':'alice', 'b':'bob'}); +// Returns {'reference': 'string-value', 'bob': false} when passed two dictionaries of the form: +// parseOptions({'-r': 'string-value'}, {'r':'reference', 'b':'bob'}); +// Throws an error when passed a string that does not start with '-': +// parseOptions('a', {'a':'alice'}); // throws +function parseOptions(opt, map, errorOptions) { + // Validate input + if (typeof opt !== 'string' && !isObject(opt)) { + throw new Error('options must be strings or key-value pairs'); + } else if (!isObject(map)) { + throw new Error('parseOptions() internal error: map must be an object'); + } else if (errorOptions && !isObject(errorOptions)) { + throw new Error('parseOptions() internal error: errorOptions must be object'); + } -"use strict"; + if (opt === '--') { + // This means there are no options. + return {}; + } -Object.defineProperty(exports, "__esModule", ({ value: true })); -exports.workspaceLayout = exports.readAllWorkspaceConfiguration = exports.readNxJson = exports.readPackageJson = exports.defaultFileRead = exports.readWorkspaceConfig = exports.TEN_MEGABYTES = exports.calculateFileChanges = exports.isDeletedFileChange = exports.isWholeFileChange = exports.DeletedFileChange = exports.WholeFileChange = void 0; -const workspaces_1 = __nccwpck_require__(98715); -const child_process_1 = __nccwpck_require__(32081); -const fs_1 = __nccwpck_require__(57147); -const path_1 = __nccwpck_require__(71017); -const configuration_1 = __nccwpck_require__(65459); -const workspace_root_1 = __nccwpck_require__(65766); -const fileutils_1 = __nccwpck_require__(47930); -const json_diff_1 = __nccwpck_require__(65058); -const project_graph_1 = __nccwpck_require__(22055); -const angular_json_1 = __nccwpck_require__(36803); -const ignore_1 = __nccwpck_require__(98845); -class WholeFileChange { - constructor() { - this.type = 'WholeFileChange'; + // All options are false by default + var options = {}; + Object.keys(map).forEach(function (letter) { + var optName = map[letter]; + if (optName[0] !== '!') { + options[optName] = false; } -} -exports.WholeFileChange = WholeFileChange; -class DeletedFileChange { - constructor() { - this.type = 'WholeFileDeleted'; + }); + + if (opt === '') return options; // defaults + + if (typeof opt === 'string') { + if (opt[0] !== '-') { + throw new Error("Options string must start with a '-'"); } -} -exports.DeletedFileChange = DeletedFileChange; -function isWholeFileChange(change) { - return change.type === 'WholeFileChange'; -} -exports.isWholeFileChange = isWholeFileChange; -function isDeletedFileChange(change) { - return change.type === 'WholeFileDeleted'; -} -exports.isDeletedFileChange = isDeletedFileChange; -function calculateFileChanges(files, allWorkspaceFiles, nxArgs, readFileAtRevision = defaultReadFileAtRevision, ignore = (0, ignore_1.getIgnoreObject)()) { - files = files.filter((f) => !ignore.ignores(f)); - return files.map((f) => { - const ext = (0, path_1.extname)(f); - const file = allWorkspaceFiles.find((fileData) => fileData.file == f); - const hash = file === null || file === void 0 ? void 0 : file.hash; - return { - file: f, - ext, - hash, - getChanges: () => { - if (!(0, fs_1.existsSync)((0, path_1.join)(workspace_root_1.workspaceRoot, f))) { - return [new DeletedFileChange()]; - } - if (!nxArgs) { - return [new WholeFileChange()]; - } - if (nxArgs.files && nxArgs.files.includes(f)) { - return [new WholeFileChange()]; - } - switch (ext) { - case '.json': - try { - const atBase = readFileAtRevision(f, nxArgs.base); - const atHead = readFileAtRevision(f, nxArgs.head); - return (0, json_diff_1.jsonDiff)(JSON.parse(atBase), JSON.parse(atHead)); - } - catch (e) { - return [new WholeFileChange()]; - } - default: - return [new WholeFileChange()]; - } - }, - }; + + // e.g. chars = ['R', 'f'] + var chars = opt.slice(1).split(''); + + chars.forEach(function (c) { + if (c in map) { + var optionName = map[c]; + if (optionName[0] === '!') { + options[optionName.slice(1)] = false; + } else { + options[optionName] = true; + } + } else { + error('option not recognized: ' + c, errorOptions || {}); + } + }); + } else { // opt is an Object + Object.keys(opt).forEach(function (key) { + // key is a string of the form '-r', '-d', etc. + var c = key[1]; + if (c in map) { + var optionName = map[c]; + options[optionName] = opt[key]; // assign the given value + } else { + error('option not recognized: ' + c, errorOptions || {}); + } }); + } + return options; } -exports.calculateFileChanges = calculateFileChanges; -exports.TEN_MEGABYTES = 1024 * 10000; -function defaultReadFileAtRevision(file, revision) { - try { - const fileFullPath = `${workspace_root_1.workspaceRoot}${path_1.sep}${file}`; - const gitRepositoryPath = (0, child_process_1.execSync)('git rev-parse --show-toplevel') - .toString() - .trim(); - const filePathInGitRepository = (0, path_1.relative)(gitRepositoryPath, fileFullPath) - .split(path_1.sep) - .join('/'); - return !revision - ? (0, fs_1.readFileSync)(file, 'utf-8') - : (0, child_process_1.execSync)(`git show ${revision}:${filePathInGitRepository}`, { - maxBuffer: exports.TEN_MEGABYTES, - stdio: ['pipe', 'pipe', 'ignore'], - }) - .toString() - .trim(); - } - catch (_a) { - return ''; +exports.parseOptions = parseOptions; + +// Expands wildcards with matching (ie. existing) file names. +// For example: +// expand(['file*.js']) = ['file1.js', 'file2.js', ...] +// (if the files 'file1.js', 'file2.js', etc, exist in the current dir) +function expand(list) { + if (!Array.isArray(list)) { + throw new TypeError('must be an array'); + } + var expanded = []; + list.forEach(function (listEl) { + // Don't expand non-strings + if (typeof listEl !== 'string') { + expanded.push(listEl); + } else { + var ret; + try { + ret = glob.sync(listEl, config.globOptions); + // if nothing matched, interpret the string literally + ret = ret.length > 0 ? ret : [listEl]; + } catch (e) { + // if glob fails, interpret the string literally + ret = [listEl]; + } + expanded = expanded.concat(ret); } + }); + return expanded; } -function readWorkspaceConfig(opts) { - let configuration = null; - try { - const projectGraph = (0, project_graph_1.readCachedProjectGraph)(); - configuration = Object.assign(Object.assign({}, (0, configuration_1.readNxJson)()), (0, project_graph_1.readProjectsConfigurationFromProjectGraph)(projectGraph)); - } - catch (_a) { - const ws = new workspaces_1.Workspaces(opts.path || process.cwd()); - configuration = ws.readProjectsConfigurations(); - } - if (opts.format === 'angularCli') { - return (0, angular_json_1.toOldFormat)(configuration); - } - else { - return configuration; +exports.expand = expand; + +// Normalizes Buffer creation, using Buffer.alloc if possible. +// Also provides a good default buffer length for most use cases. +var buffer = typeof Buffer.alloc === 'function' ? + function (len) { + return Buffer.alloc(len || config.bufLength); + } : + function (len) { + return new Buffer(len || config.bufLength); + }; +exports.buffer = buffer; + +// Normalizes _unlinkSync() across platforms to match Unix behavior, i.e. +// file can be unlinked even if it's read-only, see https://github.com/joyent/node/issues/3006 +function unlinkSync(file) { + try { + fs.unlinkSync(file); + } catch (e) { + // Try to override file permission + /* istanbul ignore next */ + if (e.code === 'EPERM') { + fs.chmodSync(file, '0666'); + fs.unlinkSync(file); + } else { + throw e; } + } } -exports.readWorkspaceConfig = readWorkspaceConfig; -function defaultFileRead(filePath) { - return (0, fs_1.readFileSync)((0, path_1.join)(workspace_root_1.workspaceRoot, filePath), 'utf-8'); +exports.unlinkSync = unlinkSync; + +// wrappers around common.statFollowLinks and common.statNoFollowLinks that clarify intent +// and improve readability +function statFollowLinks() { + return fs.statSync.apply(fs, arguments); } -exports.defaultFileRead = defaultFileRead; -function readPackageJson() { - try { - return (0, fileutils_1.readJsonFile)(`${workspace_root_1.workspaceRoot}/package.json`); +exports.statFollowLinks = statFollowLinks; + +function statNoFollowLinks() { + return fs.lstatSync.apply(fs, arguments); +} +exports.statNoFollowLinks = statNoFollowLinks; + +// e.g. 'shelljs_a5f185d0443ca...' +function randomFileName() { + function randomHash(count) { + if (count === 1) { + return parseInt(16 * Math.random(), 10).toString(16); } - catch (_a) { - return {}; // if package.json doesn't exist + var hash = ''; + for (var i = 0; i < count; i++) { + hash += randomHash(1); } + return hash; + } + + return 'shelljs_' + randomHash(20); } -exports.readPackageJson = readPackageJson; -// TODO(v16): Remove these exports -var configuration_2 = __nccwpck_require__(65459); -Object.defineProperty(exports, "readNxJson", ({ enumerable: true, get: function () { return configuration_2.readNxJson; } })); -Object.defineProperty(exports, "readAllWorkspaceConfiguration", ({ enumerable: true, get: function () { return configuration_2.readAllWorkspaceConfiguration; } })); -Object.defineProperty(exports, "workspaceLayout", ({ enumerable: true, get: function () { return configuration_2.workspaceLayout; } })); +exports.randomFileName = randomFileName; +// Common wrapper for all Unix-like commands that performs glob expansion, +// command-logging, and other nice things +function wrap(cmd, fn, options) { + options = options || {}; + return function () { + var retValue = null; -/***/ }), + state.currentCmd = cmd; + state.error = null; + state.errorCode = 0; -/***/ 65959: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { + try { + var args = [].slice.call(arguments, 0); -"use strict"; + // Log the command to stderr, if appropriate + if (config.verbose) { + console.error.apply(console, [cmd].concat(args)); + } -Object.defineProperty(exports, "__esModule", ({ value: true })); -exports.extractCachedFileData = exports.shouldRecomputeWholeGraph = exports.writeCache = exports.createProjectFileMapCache = exports.readProjectGraphCache = exports.readProjectFileMapCache = exports.ensureCacheDirectory = exports.nxFileMap = exports.nxProjectGraph = void 0; -const fs_1 = __nccwpck_require__(57147); -const fs_extra_1 = __nccwpck_require__(59511); -const path_1 = __nccwpck_require__(71017); -const perf_hooks_1 = __nccwpck_require__(4074); -const cache_directory_1 = __nccwpck_require__(20858); -const fileutils_1 = __nccwpck_require__(47930); -const versions_1 = __nccwpck_require__(39317); -exports.nxProjectGraph = (0, path_1.join)(cache_directory_1.projectGraphCacheDirectory, 'project-graph.json'); -exports.nxFileMap = (0, path_1.join)(cache_directory_1.projectGraphCacheDirectory, 'file-map.json'); -function ensureCacheDirectory() { - try { - if (!(0, fs_1.existsSync)(cache_directory_1.projectGraphCacheDirectory)) { - (0, fs_extra_1.ensureDirSync)(cache_directory_1.projectGraphCacheDirectory); - } - } - catch (e) { - /* - * @jeffbcross: Node JS docs recommend against checking for existence of directory immediately before creating it. - * Instead, just try to create the directory and handle the error. - * - * We ran into race conditions when running scripts concurrently, where multiple scripts were - * arriving here simultaneously, checking for directory existence, then trying to create the directory simultaneously. - * - * In this case, we're creating the directory. If the operation failed, we ensure that the directory - * exists before continuing (or raise an exception). - */ - if (!(0, fileutils_1.directoryExists)(cache_directory_1.projectGraphCacheDirectory)) { - throw new Error(`Failed to create directory: ${cache_directory_1.projectGraphCacheDirectory}`); - } - } -} -exports.ensureCacheDirectory = ensureCacheDirectory; -function readProjectFileMapCache() { - perf_hooks_1.performance.mark('read cache:start'); - ensureCacheDirectory(); - let data = null; - try { - if ((0, fileutils_1.fileExists)(exports.nxFileMap)) { - data = (0, fileutils_1.readJsonFile)(exports.nxFileMap); + // If this is coming from a pipe, let's set the pipedValue (otherwise, set + // it to the empty string) + state.pipedValue = (this && typeof this.stdout === 'string') ? this.stdout : ''; + + if (options.unix === false) { // this branch is for exec() + retValue = fn.apply(this, args); + } else { // and this branch is for everything else + if (isObject(args[0]) && args[0].constructor.name === 'Object') { + // a no-op, allowing the syntax `touch({'-r': file}, ...)` + } else if (args.length === 0 || typeof args[0] !== 'string' || args[0].length <= 1 || args[0][0] !== '-') { + args.unshift(''); // only add dummy option if '-option' not already present } - } - catch (error) { - console.log(`Error reading '${exports.nxFileMap}'. Continue the process without the cache.`); - console.log(error); - } - perf_hooks_1.performance.mark('read cache:end'); - perf_hooks_1.performance.measure('read cache', 'read cache:start', 'read cache:end'); - return data !== null && data !== void 0 ? data : null; -} -exports.readProjectFileMapCache = readProjectFileMapCache; -function readProjectGraphCache() { - perf_hooks_1.performance.mark('read project-graph:start'); - ensureCacheDirectory(); - let data = null; - try { - if ((0, fileutils_1.fileExists)(exports.nxProjectGraph)) { - data = (0, fileutils_1.readJsonFile)(exports.nxProjectGraph); + + // flatten out arrays that are arguments, to make the syntax: + // `cp([file1, file2, file3], dest);` + // equivalent to: + // `cp(file1, file2, file3, dest);` + args = args.reduce(function (accum, cur) { + if (Array.isArray(cur)) { + return accum.concat(cur); + } + accum.push(cur); + return accum; + }, []); + + // Convert ShellStrings (basically just String objects) to regular strings + args = args.map(function (arg) { + if (isObject(arg) && arg.constructor.name === 'String') { + return arg.toString(); + } + return arg; + }); + + // Expand the '~' if appropriate + var homeDir = os.homedir(); + args = args.map(function (arg) { + if (typeof arg === 'string' && arg.slice(0, 2) === '~/' || arg === '~') { + return arg.replace(/^~/, homeDir); + } + return arg; + }); + + // Perform glob-expansion on all arguments after globStart, but preserve + // the arguments before it (like regexes for sed and grep) + if (!config.noglob && options.allowGlobbing === true) { + args = args.slice(0, options.globStart).concat(expand(args.slice(options.globStart))); } - } - catch (error) { - console.log(`Error reading '${exports.nxProjectGraph}'. Continue the process without the cache.`); - console.log(error); - } - perf_hooks_1.performance.mark('read project-graph:end'); - perf_hooks_1.performance.measure('read cache', 'read project-graph:start', 'read project-graph:end'); - return data !== null && data !== void 0 ? data : null; -} -exports.readProjectGraphCache = readProjectGraphCache; -function createProjectFileMapCache(nxJson, packageJsonDeps, projectFileMap, tsConfig) { - var _a; - const nxJsonPlugins = (nxJson.plugins || []).map((p) => ({ - name: p, - version: packageJsonDeps[p], - })); - const newValue = { - version: '6.0', - nxVersion: versions_1.nxVersion, - deps: packageJsonDeps, - // compilerOptions may not exist, especially for package-based repos - pathMappings: ((_a = tsConfig === null || tsConfig === void 0 ? void 0 : tsConfig.compilerOptions) === null || _a === void 0 ? void 0 : _a.paths) || {}, - nxJsonPlugins, - pluginsConfig: nxJson.pluginsConfig, - projectFileMap, - }; - return newValue; -} -exports.createProjectFileMapCache = createProjectFileMapCache; -function writeCache(cache, projectGraph) { - perf_hooks_1.performance.mark('write cache:start'); - let retry = 1; - let done = false; - do { - // write first to a unique temporary filename and then do a - // rename of the file to the correct filename - // this is to avoid any problems with half-written files - // in case of crash and/or partially written files due - // to multiple parallel processes reading and writing this file - const unique = (Math.random().toString(16) + '0000000').slice(2, 10); - const tmpProjectGraphPath = `${exports.nxProjectGraph}~${unique}`; - const tmpFileMapPath = `${exports.nxFileMap}~${unique}`; + try { - (0, fileutils_1.writeJsonFile)(tmpProjectGraphPath, projectGraph); - (0, fs_extra_1.renameSync)(tmpProjectGraphPath, exports.nxProjectGraph); - (0, fileutils_1.writeJsonFile)(tmpFileMapPath, cache); - (0, fs_extra_1.renameSync)(tmpFileMapPath, exports.nxFileMap); - done = true; - } - catch (err) { - if (err instanceof Error) { - console.log(`ERROR (${retry}) when writing \n${err.message}\n${err.stack}`); - } - else { - console.log(`ERROR (${retry}) unknown error when writing ${exports.nxProjectGraph} and ${exports.nxFileMap}`); - } - ++retry; + // parse options if options are provided + if (isObject(options.cmdOptions)) { + args[0] = parseOptions(args[0], options.cmdOptions); + } + + retValue = fn.apply(this, args); + } catch (e) { + /* istanbul ignore else */ + if (e.msg === 'earlyExit') { + retValue = e.retValue; + } else { + throw e; // this is probably a bug that should be thrown up the call stack + } } - } while (!done && retry < 5); - perf_hooks_1.performance.mark('write cache:end'); - perf_hooks_1.performance.measure('write cache', 'write cache:start', 'write cache:end'); -} -exports.writeCache = writeCache; -function shouldRecomputeWholeGraph(cache, packageJsonDeps, projects, nxJson, tsConfig) { - if (cache.version !== '6.0') { - return true; - } - if (cache.nxVersion !== versions_1.nxVersion) { - return true; - } - // we have a cached project that is no longer present - const cachedNodes = Object.keys(cache.projectFileMap); - if (cachedNodes.some((p) => projects.projects[p] === undefined)) { - return true; - } - // a path mapping for an existing project has changed - if (Object.keys(cache.pathMappings).some((t) => { - var _a, _b; - const cached = cache.pathMappings && cache.pathMappings[t] - ? JSON.stringify(cache.pathMappings[t]) - : undefined; - const notCached = ((_a = tsConfig === null || tsConfig === void 0 ? void 0 : tsConfig.compilerOptions) === null || _a === void 0 ? void 0 : _a.paths) && ((_b = tsConfig === null || tsConfig === void 0 ? void 0 : tsConfig.compilerOptions) === null || _b === void 0 ? void 0 : _b.paths[t]) - ? JSON.stringify(tsConfig.compilerOptions.paths[t]) - : undefined; - return cached !== notCached; - })) { - return true; - } - // a new plugin has been added - if ((nxJson.plugins || []).length !== cache.nxJsonPlugins.length) - return true; - // a plugin has changed - if ((nxJson.plugins || []).some((t) => { - const matchingPlugin = cache.nxJsonPlugins.find((p) => p.name === t); - if (!matchingPlugin) - return true; - return matchingPlugin.version !== packageJsonDeps[t]; - })) { - return true; + } + } catch (e) { + /* istanbul ignore next */ + if (!state.error) { + // If state.error hasn't been set it's an error thrown by Node, not us - probably a bug... + e.name = 'ShellJSInternalError'; + throw e; + } + if (config.fatal) throw e; } - if (JSON.stringify(nxJson.pluginsConfig) !== JSON.stringify(cache.pluginsConfig)) { - return true; + + if (options.wrapOutput && + (typeof retValue === 'string' || Array.isArray(retValue))) { + retValue = new ShellString(retValue, state.error, state.errorCode); } - return false; -} -exports.shouldRecomputeWholeGraph = shouldRecomputeWholeGraph; -/* -This can only be invoked when the list of projects is either the same -or new projects have been added, so every project in the cache has a corresponding -project in fileMap -*/ -function extractCachedFileData(fileMap, c) { - const filesToProcess = {}; - const cachedFileData = {}; - const currentProjects = Object.keys(fileMap).filter((name) => fileMap[name].length > 0); - currentProjects.forEach((p) => { - processProjectNode(p, c.projectFileMap, cachedFileData, filesToProcess, fileMap); - }); - return { - filesToProcess, - cachedFileData, - }; + + state.currentCmd = 'shell.js'; + return retValue; + }; +} // wrap +exports.wrap = wrap; + +// This returns all the input that is piped into the current command (or the +// empty string, if this isn't on the right-hand side of a pipe +function _readFromPipe() { + return state.pipedValue; } -exports.extractCachedFileData = extractCachedFileData; -function processProjectNode(projectName, cachedFileMap, cachedFileData, filesToProcess, fileMap) { - if (!cachedFileMap[projectName]) { - filesToProcess[projectName] = fileMap[projectName]; - return; - } - const fileDataFromCache = {}; - for (let f of cachedFileMap[projectName]) { - fileDataFromCache[f.file] = f; - } - if (!cachedFileData[projectName]) { - cachedFileData[projectName] = {}; +exports.readFromPipe = _readFromPipe; + +var DEFAULT_WRAP_OPTIONS = { + allowGlobbing: true, + canReceivePipe: false, + cmdOptions: null, + globStart: 1, + pipeOnly: false, + wrapOutput: true, + unix: true, +}; + +// This is populated during plugin registration +var pipeMethods = []; + +// Register a new ShellJS command +function _register(name, implementation, wrapOptions) { + wrapOptions = wrapOptions || {}; + + // Validate options + Object.keys(wrapOptions).forEach(function (option) { + if (!DEFAULT_WRAP_OPTIONS.hasOwnProperty(option)) { + throw new Error("Unknown option '" + option + "'"); } - for (let f of fileMap[projectName]) { - const fromCache = fileDataFromCache[f.file]; - if (fromCache && fromCache.hash == f.hash) { - cachedFileData[projectName][f.file] = fromCache; - } - else { - if (!filesToProcess[projectName]) { - filesToProcess[projectName] = []; - } - filesToProcess[projectName].push(f); - } + if (typeof wrapOptions[option] !== typeof DEFAULT_WRAP_OPTIONS[option]) { + throw new TypeError("Unsupported type '" + typeof wrapOptions[option] + + "' for option '" + option + "'"); } + }); + + // If an option isn't specified, use the default + wrapOptions = Object.assign({}, DEFAULT_WRAP_OPTIONS, wrapOptions); + + if (shell.hasOwnProperty(name)) { + throw new Error('Command `' + name + '` already exists'); + } + + if (wrapOptions.pipeOnly) { + wrapOptions.canReceivePipe = true; + shellMethods[name] = wrap(name, implementation, wrapOptions); + } else { + shell[name] = wrap(name, implementation, wrapOptions); + } + + if (wrapOptions.canReceivePipe) { + pipeMethods.push(name); + } } +exports.register = _register; /***/ }), -/***/ 97607: -/***/ ((__unused_webpack_module, exports) => { +/***/ 64395: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { -"use strict"; +var fs = __nccwpck_require__(57147); +var path = __nccwpck_require__(71017); +var common = __nccwpck_require__(60624); -Object.defineProperty(exports, "__esModule", ({ value: true })); -exports.withDeps = exports.pruneExternalNodes = exports.isNpmProject = exports.filterNodes = exports.reverse = void 0; -const reverseMemo = new Map(); -/** - * Returns a new project graph where all the edges are reversed. - * - * For instance, if project A depends on B, in the reversed graph - * B will depend on A. - */ -function reverse(graph) { - const resultFromMemo = reverseMemo.get(graph); - if (resultFromMemo) { - return resultFromMemo; +common.register('cp', _cp, { + cmdOptions: { + 'f': '!no_force', + 'n': 'no_force', + 'u': 'update', + 'R': 'recursive', + 'r': 'recursive', + 'L': 'followsymlink', + 'P': 'noFollowsymlink', + }, + wrapOutput: false, +}); + +// Buffered file copy, synchronous +// (Using readFileSync() + writeFileSync() could easily cause a memory overflow +// with large files) +function copyFileSync(srcFile, destFile, options) { + if (!fs.existsSync(srcFile)) { + common.error('copyFileSync: no such file or directory: ' + srcFile); + } + + var isWindows = process.platform === 'win32'; + + // Check the mtimes of the files if the '-u' flag is provided + try { + if (options.update && common.statFollowLinks(srcFile).mtime < fs.statSync(destFile).mtime) { + return; } - const result = Object.assign(Object.assign({}, graph), { nodes: Object.assign({}, graph.nodes), externalNodes: Object.assign({}, graph.externalNodes), dependencies: {} }); - Object.keys(graph.nodes).forEach((n) => (result.dependencies[n] = [])); - // we need to keep external node's reverse dependencies to trace our route back - if (graph.externalNodes) { - Object.keys(graph.externalNodes).forEach((n) => (result.dependencies[n] = [])); + } catch (e) { + // If we're here, destFile probably doesn't exist, so just do a normal copy + } + + if (common.statNoFollowLinks(srcFile).isSymbolicLink() && !options.followsymlink) { + try { + common.statNoFollowLinks(destFile); + common.unlinkSync(destFile); // re-link it + } catch (e) { + // it doesn't exist, so no work needs to be done } - Object.values(graph.dependencies).forEach((byProject) => { - byProject.forEach((dep) => { - const dependency = result.dependencies[dep.target]; - if (dependency) { - dependency.push({ - type: dep.type, - source: dep.target, - target: dep.source, - }); - } - }); - }); - reverseMemo.set(graph, result); - reverseMemo.set(result, graph); - return result; -} -exports.reverse = reverse; -function filterNodes(predicate) { - return (original) => { - const graph = { nodes: {}, dependencies: {} }; - const added = new Set(); - Object.values(original.nodes).forEach((n) => { - if (!predicate || predicate(n)) { - graph.nodes[n.name] = n; - graph.dependencies[n.name] = []; - added.add(n.name); - } - }); - Object.values(original.dependencies).forEach((ds) => { - ds.forEach((d) => { - if (added.has(d.source) && added.has(d.target)) { - graph.dependencies[d.source].push(d); - } - }); - }); - return graph; - }; -} -exports.filterNodes = filterNodes; -function isNpmProject(project) { - return (project === null || project === void 0 ? void 0 : project.type) === 'npm'; -} -exports.isNpmProject = isNpmProject; -exports.pruneExternalNodes = filterNodes(); -function withDeps(original, subsetNodes) { - const res = { nodes: {}, dependencies: {} }; - const visitedNodes = []; - const visitedEdges = []; - Object.values(subsetNodes).forEach(recurNodes); - Object.values(subsetNodes).forEach(recurEdges); - return res; - // --------------------------------------------------------------------------- - function recurNodes(node) { - if (visitedNodes.indexOf(node.name) > -1) - return; - res.nodes[node.name] = node; - if (!res.dependencies[node.name]) { - res.dependencies[node.name] = []; - } - visitedNodes.push(node.name); - original.dependencies[node.name].forEach((n) => { - if (original.nodes[n.target]) { - recurNodes(original.nodes[n.target]); - } - }); + + var symlinkFull = fs.readlinkSync(srcFile); + fs.symlinkSync(symlinkFull, destFile, isWindows ? 'junction' : null); + } else { + var buf = common.buffer(); + var bufLength = buf.length; + var bytesRead = bufLength; + var pos = 0; + var fdr = null; + var fdw = null; + + try { + fdr = fs.openSync(srcFile, 'r'); + } catch (e) { + /* istanbul ignore next */ + common.error('copyFileSync: could not read src file (' + srcFile + ')'); } - function recurEdges(node) { - if (visitedEdges.indexOf(node.name) > -1) - return; - visitedEdges.push(node.name); - const ds = original.dependencies[node.name]; - ds.forEach((n) => { - if (!original.nodes[n.target]) { - return; - } - if (!res.dependencies[n.source]) { - res.dependencies[n.source] = []; - } - res.dependencies[n.source].push(n); - }); - ds.forEach((n) => { - if (original.nodes[n.target]) { - recurEdges(original.nodes[n.target]); - } - }); + + try { + fdw = fs.openSync(destFile, 'w'); + } catch (e) { + /* istanbul ignore next */ + common.error('copyFileSync: could not write to dest file (code=' + e.code + '):' + destFile); + } + + while (bytesRead === bufLength) { + bytesRead = fs.readSync(fdr, buf, 0, bufLength, pos); + fs.writeSync(fdw, buf, 0, bytesRead); + pos += bytesRead; } + + fs.closeSync(fdr); + fs.closeSync(fdw); + + fs.chmodSync(destFile, common.statFollowLinks(srcFile).mode); + } } -exports.withDeps = withDeps; +// Recursively copies 'sourceDir' into 'destDir' +// Adapted from https://github.com/ryanmcgrath/wrench-js +// +// Copyright (c) 2010 Ryan McGrath +// Copyright (c) 2012 Artur Adib +// +// Licensed under the MIT License +// http://www.opensource.org/licenses/mit-license.php +function cpdirSyncRecursive(sourceDir, destDir, currentDepth, opts) { + if (!opts) opts = {}; -/***/ }), + // Ensure there is not a run away recursive copy + if (currentDepth >= common.config.maxdepth) return; + currentDepth++; -/***/ 14812: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { + var isWindows = process.platform === 'win32'; -"use strict"; + // Create the directory where all our junk is moving to; read the mode of the + // source directory and mirror it + try { + fs.mkdirSync(destDir); + } catch (e) { + // if the directory already exists, that's okay + if (e.code !== 'EEXIST') throw e; + } -Object.defineProperty(exports, "__esModule", ({ value: true })); -exports.ProjectGraphBuilder = void 0; -/** - * Builder for adding nodes and dependencies to a {@link ProjectGraph} - */ -const project_graph_1 = __nccwpck_require__(49899); -const build_project_graph_1 = __nccwpck_require__(60214); -class ProjectGraphBuilder { - constructor(g, fileMap) { - this.removedEdges = {}; - if (g) { - this.graph = g; - this.fileMap = fileMap || (0, build_project_graph_1.getProjectFileMap)().projectFileMap; - } - else { - this.graph = { - nodes: {}, - externalNodes: {}, - dependencies: {}, - }; - this.fileMap = fileMap || {}; - } - } - /** - * Merges the nodes and dependencies of p into the built project graph. - */ - mergeProjectGraph(p) { - this.graph.nodes = Object.assign(Object.assign({}, this.graph.nodes), p.nodes); - this.graph.externalNodes = Object.assign(Object.assign({}, this.graph.externalNodes), p.externalNodes); - this.graph.dependencies = Object.assign(Object.assign({}, this.graph.dependencies), p.dependencies); - } - /** - * Adds a project node to the project graph - */ - addNode(node) { - // Check if project with the same name already exists - if (this.graph.nodes[node.name]) { - // Throw if existing project is of a different type - if (this.graph.nodes[node.name].type !== node.type) { - throw new Error(`Multiple projects are named "${node.name}". One is of type "${node.type}" and the other is of type "${this.graph.nodes[node.name].type}". Please resolve the conflicting project names.`); - } - } - this.graph.nodes[node.name] = node; + var files = fs.readdirSync(sourceDir); + + for (var i = 0; i < files.length; i++) { + var srcFile = sourceDir + '/' + files[i]; + var destFile = destDir + '/' + files[i]; + var srcFileStat = common.statNoFollowLinks(srcFile); + + var symlinkFull; + if (opts.followsymlink) { + if (cpcheckcycle(sourceDir, srcFile)) { + // Cycle link found. + console.error('Cycle link found.'); + symlinkFull = fs.readlinkSync(srcFile); + fs.symlinkSync(symlinkFull, destFile, isWindows ? 'junction' : null); + continue; + } } - /** - * Removes a node and all of its dependency edges from the graph - */ - removeNode(name) { - if (!this.graph.nodes[name] && !this.graph.externalNodes[name]) { - throw new Error(`There is no node named: "${name}"`); - } - this.removeDependenciesWithNode(name); - if (this.graph.nodes[name]) { - delete this.graph.nodes[name]; - } - else { - delete this.graph.externalNodes[name]; - } - } - /** - * Adds a external node to the project graph - */ - addExternalNode(node) { - // Check if project with the same name already exists - if (this.graph.externalNodes[node.name]) { - throw new Error(`Multiple projects are named "${node.name}". One has version "${node.data.version}" and the other has version "${this.graph.externalNodes[node.name].data.version}". Please resolve the conflicting package names.`); - } - this.graph.externalNodes[node.name] = node; - } - /** - * Adds static dependency from source project to target project - */ - addStaticDependency(sourceProjectName, targetProjectName, sourceProjectFile) { - // internal nodes must provide sourceProjectFile when creating static dependency - // externalNodes do not have sourceProjectFile - if (this.graph.nodes[sourceProjectName] && !sourceProjectFile) { - throw new Error(`Source project file is required`); - } - this.addDependency(sourceProjectName, targetProjectName, project_graph_1.DependencyType.static, sourceProjectFile); - } - /** - * Adds dynamic dependency from source project to target project - */ - addDynamicDependency(sourceProjectName, targetProjectName, sourceProjectFile) { - if (this.graph.externalNodes[sourceProjectName]) { - throw new Error(`External projects can't have "dynamic" dependencies`); - } - // dynamic dependency is always bound to a file - if (!sourceProjectFile) { - throw new Error(`Source project file is required`); - } - this.addDependency(sourceProjectName, targetProjectName, project_graph_1.DependencyType.dynamic, sourceProjectFile); - } - /** - * Adds implicit dependency from source project to target project - */ - addImplicitDependency(sourceProjectName, targetProjectName) { - if (this.graph.externalNodes[sourceProjectName]) { - throw new Error(`External projects can't have "implicit" dependencies`); - } - this.addDependency(sourceProjectName, targetProjectName, project_graph_1.DependencyType.implicit); - } - /** - * Removes a dependency from source project to target project - */ - removeDependency(sourceProjectName, targetProjectName) { - if (sourceProjectName === targetProjectName) { - return; - } - if (!this.graph.nodes[sourceProjectName]) { - throw new Error(`Source project does not exist: ${sourceProjectName}`); - } - if (!this.graph.nodes[targetProjectName] && - !this.graph.externalNodes[targetProjectName]) { - throw new Error(`Target project does not exist: ${targetProjectName}`); - } - // this.graph.dependencies[sourceProjectName] = this.graph.dependencies[ - // sourceProjectName - // ].filter((d) => d.target !== targetProjectName); - if (!this.removedEdges[sourceProjectName]) { - this.removedEdges[sourceProjectName] = new Set(); - } - this.removedEdges[sourceProjectName].add(targetProjectName); - } - /** - * Add an explicit dependency from a file in source project to target project - * @deprecated this method will be removed in v17. Use {@link addStaticDependency} or {@link addDynamicDependency} instead - */ - addExplicitDependency(sourceProjectName, sourceProjectFile, targetProjectName) { - this.addStaticDependency(sourceProjectName, targetProjectName, sourceProjectFile); - } - /** - * Set version of the project graph - */ - setVersion(version) { - this.graph.version = version; - } - getUpdatedProjectGraph() { - for (const sourceProject of Object.keys(this.graph.nodes)) { - const alreadySetTargetProjects = this.calculateAlreadySetTargetDeps(sourceProject); - this.graph.dependencies[sourceProject] = [ - ...alreadySetTargetProjects.values(), - ].flatMap((depsMap) => [...depsMap.values()]); - const fileDeps = this.calculateTargetDepsFromFiles(sourceProject); - for (const [targetProject, types] of fileDeps.entries()) { - // only add known nodes - if (!this.graph.nodes[targetProject] && - !this.graph.externalNodes[targetProject]) { - continue; - } - for (const type of types.values()) { - if (!alreadySetTargetProjects.has(targetProject) || - !alreadySetTargetProjects.get(targetProject).has(type)) { - if (!this.removedEdges[sourceProject] || - !this.removedEdges[sourceProject].has(targetProject)) { - this.graph.dependencies[sourceProject].push({ - source: sourceProject, - target: targetProject, - type, - }); - } - } - } - } - } - return this.graph; + if (srcFileStat.isDirectory()) { + /* recursion this thing right on back. */ + cpdirSyncRecursive(srcFile, destFile, currentDepth, opts); + } else if (srcFileStat.isSymbolicLink() && !opts.followsymlink) { + symlinkFull = fs.readlinkSync(srcFile); + try { + common.statNoFollowLinks(destFile); + common.unlinkSync(destFile); // re-link it + } catch (e) { + // it doesn't exist, so no work needs to be done + } + fs.symlinkSync(symlinkFull, destFile, isWindows ? 'junction' : null); + } else if (srcFileStat.isSymbolicLink() && opts.followsymlink) { + srcFileStat = common.statFollowLinks(srcFile); + if (srcFileStat.isDirectory()) { + cpdirSyncRecursive(srcFile, destFile, currentDepth, opts); + } else { + copyFileSync(srcFile, destFile, opts); + } + } else { + /* At this point, we've hit a file actually worth copying... so copy it on over. */ + if (fs.existsSync(destFile) && opts.no_force) { + common.log('skipping existing file: ' + files[i]); + } else { + copyFileSync(srcFile, destFile, opts); + } } - addDependency(sourceProjectName, targetProjectName, type, sourceProjectFile) { - if (sourceProjectName === targetProjectName) { - return; - } - if (!this.graph.nodes[sourceProjectName] && - !this.graph.externalNodes[sourceProjectName]) { - throw new Error(`Source project does not exist: ${sourceProjectName}`); - } - if (!this.graph.nodes[targetProjectName] && - !this.graph.externalNodes[targetProjectName] && - !sourceProjectFile) { - throw new Error(`Target project does not exist: ${targetProjectName}`); - } - if (this.graph.externalNodes[sourceProjectName] && - this.graph.nodes[targetProjectName]) { - throw new Error(`External projects can't depend on internal projects`); - } - if (!this.graph.dependencies[sourceProjectName]) { - this.graph.dependencies[sourceProjectName] = []; - } - const isDuplicate = !!this.graph.dependencies[sourceProjectName].find((d) => d.target === targetProjectName && d.type === type); - if (sourceProjectFile) { - const source = this.graph.nodes[sourceProjectName]; - if (!source) { - throw new Error(`Source project is not a project node: ${sourceProjectName}`); - } - const fileData = (this.fileMap[sourceProjectName] || []).find((f) => f.file === sourceProjectFile); - if (!fileData) { - throw new Error(`Source project ${sourceProjectName} does not have a file: ${sourceProjectFile}`); - } - if (!fileData.deps) { - fileData.deps = []; - } - if (!fileData.deps.find((t) => (0, project_graph_1.fileDataDepTarget)(t) === targetProjectName && - (0, project_graph_1.fileDataDepType)(t) === type)) { - const dep = type === 'static' ? targetProjectName : [targetProjectName, type]; - fileData.deps.push(dep); - } - } - else if (!isDuplicate) { - // only add to dependencies section if the source file is not specified - // and not already added - this.graph.dependencies[sourceProjectName].push({ - source: sourceProjectName, - target: targetProjectName, - type, - }); - } + } // for files + + // finally change the mode for the newly created directory (otherwise, we + // couldn't add files to a read-only directory). + var checkDir = common.statFollowLinks(sourceDir); + fs.chmodSync(destDir, checkDir.mode); +} // cpdirSyncRecursive + +// Checks if cureent file was created recently +function checkRecentCreated(sources, index) { + var lookedSource = sources[index]; + return sources.slice(0, index).some(function (src) { + return path.basename(src) === path.basename(lookedSource); + }); +} + +function cpcheckcycle(sourceDir, srcFile) { + var srcFileStat = common.statNoFollowLinks(srcFile); + if (srcFileStat.isSymbolicLink()) { + // Do cycle check. For example: + // $ mkdir -p 1/2/3/4 + // $ cd 1/2/3/4 + // $ ln -s ../../3 link + // $ cd ../../../.. + // $ cp -RL 1 copy + var cyclecheck = common.statFollowLinks(srcFile); + if (cyclecheck.isDirectory()) { + var sourcerealpath = fs.realpathSync(sourceDir); + var symlinkrealpath = fs.realpathSync(srcFile); + var re = new RegExp(symlinkrealpath); + if (re.test(sourcerealpath)) { + return true; + } } - removeDependenciesWithNode(name) { - // remove all source dependencies - delete this.graph.dependencies[name]; - // remove all target dependencies - for (const dependencies of Object.values(this.graph.dependencies)) { - for (const [index, { source, target }] of dependencies.entries()) { - if (target === name) { - const deps = this.graph.dependencies[source]; - this.graph.dependencies[source] = [ - ...deps.slice(0, index), - ...deps.slice(index + 1), - ]; - if (this.graph.dependencies[source].length === 0) { - delete this.graph.dependencies[source]; - } - } - } - } + } + return false; +} + +//@ +//@ ### cp([options,] source [, source ...], dest) +//@ ### cp([options,] source_array, dest) +//@ +//@ Available options: +//@ +//@ + `-f`: force (default behavior) +//@ + `-n`: no-clobber +//@ + `-u`: only copy if `source` is newer than `dest` +//@ + `-r`, `-R`: recursive +//@ + `-L`: follow symlinks +//@ + `-P`: don't follow symlinks +//@ +//@ Examples: +//@ +//@ ```javascript +//@ cp('file1', 'dir1'); +//@ cp('-R', 'path/to/dir/', '~/newCopy/'); +//@ cp('-Rf', '/tmp/*', '/usr/local/*', '/home/tmp'); +//@ cp('-Rf', ['/tmp/*', '/usr/local/*'], '/home/tmp'); // same as above +//@ ``` +//@ +//@ Copies files. +function _cp(options, sources, dest) { + // If we're missing -R, it actually implies -L (unless -P is explicit) + if (options.followsymlink) { + options.noFollowsymlink = false; + } + if (!options.recursive && !options.noFollowsymlink) { + options.followsymlink = true; + } + + // Get sources, dest + if (arguments.length < 3) { + common.error('missing and/or '); + } else { + sources = [].slice.call(arguments, 1, arguments.length - 1); + dest = arguments[arguments.length - 1]; + } + + var destExists = fs.existsSync(dest); + var destStat = destExists && common.statFollowLinks(dest); + + // Dest is not existing dir, but multiple sources given + if ((!destExists || !destStat.isDirectory()) && sources.length > 1) { + common.error('dest is not a directory (too many sources)'); + } + + // Dest is an existing file, but -n is given + if (destExists && destStat.isFile() && options.no_force) { + return new common.ShellString('', '', 0); + } + + sources.forEach(function (src, srcIndex) { + if (!fs.existsSync(src)) { + if (src === '') src = "''"; // if src was empty string, display empty string + common.error('no such file or directory: ' + src, { continue: true }); + return; // skip file } - calculateTargetDepsFromFiles(sourceProject) { - const fileDeps = new Map(); - const files = this.fileMap[sourceProject] || []; - if (!files) { - return fileDeps; - } - for (let f of files) { - if (f.deps) { - for (let d of f.deps) { - const target = (0, project_graph_1.fileDataDepTarget)(d); - if (!fileDeps.has(target)) { - fileDeps.set(target, new Set([(0, project_graph_1.fileDataDepType)(d)])); - } - else { - fileDeps.get(target).add((0, project_graph_1.fileDataDepType)(d)); - } - } - } + var srcStat = common.statFollowLinks(src); + if (!options.noFollowsymlink && srcStat.isDirectory()) { + if (!options.recursive) { + // Non-Recursive + common.error("omitting directory '" + src + "'", { continue: true }); + } else { + // Recursive + // 'cp /a/source dest' should create 'source' in 'dest' + var newDest = (destStat && destStat.isDirectory()) ? + path.join(dest, path.basename(src)) : + dest; + + try { + common.statFollowLinks(path.dirname(dest)); + cpdirSyncRecursive(src, newDest, 0, { no_force: options.no_force, followsymlink: options.followsymlink }); + } catch (e) { + /* istanbul ignore next */ + common.error("cannot create directory '" + dest + "': No such file or directory"); } - return fileDeps; - } - calculateAlreadySetTargetDeps(sourceProject) { - const alreadySetTargetProjects = new Map(); - if (this.graph.dependencies[sourceProject]) { - const removed = this.removedEdges[sourceProject]; - for (const d of this.graph.dependencies[sourceProject]) { - // static and dynamic dependencies of internal projects - // will be rebuilt based on the file dependencies - // we only need to keep the implicit dependencies - if (d.type === project_graph_1.DependencyType.implicit && !(removed === null || removed === void 0 ? void 0 : removed.has(d.target))) { - if (!alreadySetTargetProjects.has(d.target)) { - alreadySetTargetProjects.set(d.target, new Map([[d.type, d]])); - } - else { - alreadySetTargetProjects.get(d.target).set(d.type, d); - } - } - } + } + } else { + // If here, src is a file + + // When copying to '/path/dir': + // thisDest = '/path/dir/file1' + var thisDest = dest; + if (destStat && destStat.isDirectory()) { + thisDest = path.normalize(dest + '/' + path.basename(src)); + } + + var thisDestExists = fs.existsSync(thisDest); + if (thisDestExists && checkRecentCreated(sources, srcIndex)) { + // cannot overwrite file created recently in current execution, but we want to continue copying other files + if (!options.no_force) { + common.error("will not overwrite just-created '" + thisDest + "' with '" + src + "'", { continue: true }); } - return alreadySetTargetProjects; + return; + } + + if (thisDestExists && options.no_force) { + return; // skip file + } + + if (path.relative(src, thisDest) === '') { + // a file cannot be copied to itself, but we want to continue copying other files + common.error("'" + thisDest + "' and '" + src + "' are the same file", { continue: true }); + return; + } + + copyFileSync(src, thisDest, options); } + }); // forEach(src) + + return new common.ShellString('', common.state.error, common.state.errorCode); } -exports.ProjectGraphBuilder = ProjectGraphBuilder; +module.exports = _cp; /***/ }), -/***/ 22055: +/***/ 11060: /***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { -"use strict"; +var common = __nccwpck_require__(60624); +var _cd = __nccwpck_require__(79117); +var path = __nccwpck_require__(71017); -Object.defineProperty(exports, "__esModule", ({ value: true })); -exports.createProjectGraphAsync = exports.buildProjectGraphWithoutDaemon = exports.readProjectsConfigurationFromProjectGraph = exports.readCachedProjectConfiguration = exports.readCachedProjectGraph = void 0; -const tslib_1 = __nccwpck_require__(51796); -const nx_deps_cache_1 = __nccwpck_require__(65959); -const build_project_graph_1 = __nccwpck_require__(60214); -const output_1 = __nccwpck_require__(34548); -const impl_1 = __nccwpck_require__(43265); -const tmp_dir_1 = __nccwpck_require__(87196); -const strip_indents_1 = __nccwpck_require__(4477); -const client_1 = __nccwpck_require__(55942); -const fileutils_1 = __nccwpck_require__(47930); -const workspace_root_1 = __nccwpck_require__(65766); -const workspaces_1 = __nccwpck_require__(98715); -const file_map_utils_1 = __nccwpck_require__(11223); -const perf_hooks_1 = __nccwpck_require__(4074); -/** - * Synchronously reads the latest cached copy of the workspace's ProjectGraph. - * @throws {Error} if there is no cached ProjectGraph to read from - */ -function readCachedProjectGraph() { - const projectGraphCache = (0, nx_deps_cache_1.readProjectGraphCache)(); - const angularSpecificError = (0, fileutils_1.fileExists)(`${workspace_root_1.workspaceRoot}/angular.json`) - ? (0, strip_indents_1.stripIndents) ` - Make sure invoke 'node ./decorate-angular-cli.js' in your postinstall script. - The decorated CLI will compute the project graph. - 'ng --help' should say 'Smart, Fast and Extensible Build System'. - ` - : ''; - if (!projectGraphCache) { - throw new Error((0, strip_indents_1.stripIndents) ` - [readCachedProjectGraph] ERROR: No cached ProjectGraph is available. +common.register('dirs', _dirs, { + wrapOutput: false, +}); +common.register('pushd', _pushd, { + wrapOutput: false, +}); +common.register('popd', _popd, { + wrapOutput: false, +}); - If you are leveraging \`readCachedProjectGraph()\` directly then you will need to refactor your usage to first ensure that - the ProjectGraph is created by calling \`await createProjectGraphAsync()\` somewhere before attempting to read the data. +// Pushd/popd/dirs internals +var _dirStack = []; - If you encounter this error as part of running standard \`nx\` commands then please open an issue on https://github.com/nrwl/nx +function _isStackIndex(index) { + return (/^[\-+]\d+$/).test(index); +} - ${angularSpecificError} - `); +function _parseStackIndex(index) { + if (_isStackIndex(index)) { + if (Math.abs(index) < _dirStack.length + 1) { // +1 for pwd + return (/^-/).test(index) ? Number(index) - 1 : Number(index); } - return projectGraphCache; -} -exports.readCachedProjectGraph = readCachedProjectGraph; -function readCachedProjectConfiguration(projectName) { - const graph = readCachedProjectGraph(); - const node = graph.nodes[projectName]; - return node.data; -} -exports.readCachedProjectConfiguration = readCachedProjectConfiguration; -function readProjectsConfigurationFromProjectGraph(projectGraph) { - return { - projects: Object.fromEntries(Object.entries(projectGraph.nodes).map(([project, { data }]) => [ - project, - data, - ])), - version: 2, - }; + common.error(index + ': directory stack index out of range'); + } else { + common.error(index + ': invalid number'); + } } -exports.readProjectsConfigurationFromProjectGraph = readProjectsConfigurationFromProjectGraph; -function buildProjectGraphWithoutDaemon() { - return tslib_1.__awaiter(this, void 0, void 0, function* () { - yield impl_1.fileHasher.ensureInitialized(); - const projectConfigurations = new workspaces_1.Workspaces(workspace_root_1.workspaceRoot).readProjectsConfigurations(); - const { projectFileMap, allWorkspaceFiles } = (0, file_map_utils_1.createProjectFileMap)(projectConfigurations, impl_1.fileHasher.allFileData()); - const cacheEnabled = process.env.NX_CACHE_PROJECT_GRAPH !== 'false'; - return (yield (0, build_project_graph_1.buildProjectGraphUsingProjectFileMap)(projectConfigurations, projectFileMap, allWorkspaceFiles, cacheEnabled ? (0, nx_deps_cache_1.readProjectFileMapCache)() : null, cacheEnabled)).projectGraph; - }); + +function _actualDirStack() { + return [process.cwd()].concat(_dirStack); } -exports.buildProjectGraphWithoutDaemon = buildProjectGraphWithoutDaemon; -function handleProjectGraphError(opts, e) { - if (opts.exitOnError) { - const lines = e.message.split('\n'); - output_1.output.error({ - title: lines[0], - bodyLines: lines.slice(1), - }); - if (process.env.NX_VERBOSE_LOGGING === 'true') { - console.error(e); - } - process.exit(1); + +//@ +//@ ### pushd([options,] [dir | '-N' | '+N']) +//@ +//@ Available options: +//@ +//@ + `-n`: Suppresses the normal change of directory when adding directories to the stack, so that only the stack is manipulated. +//@ + `-q`: Supresses output to the console. +//@ +//@ Arguments: +//@ +//@ + `dir`: Sets the current working directory to the top of the stack, then executes the equivalent of `cd dir`. +//@ + `+N`: Brings the Nth directory (counting from the left of the list printed by dirs, starting with zero) to the top of the list by rotating the stack. +//@ + `-N`: Brings the Nth directory (counting from the right of the list printed by dirs, starting with zero) to the top of the list by rotating the stack. +//@ +//@ Examples: +//@ +//@ ```javascript +//@ // process.cwd() === '/usr' +//@ pushd('/etc'); // Returns /etc /usr +//@ pushd('+1'); // Returns /usr /etc +//@ ``` +//@ +//@ Save the current directory on the top of the directory stack and then `cd` to `dir`. With no arguments, `pushd` exchanges the top two directories. Returns an array of paths in the stack. +function _pushd(options, dir) { + if (_isStackIndex(options)) { + dir = options; + options = ''; + } + + options = common.parseOptions(options, { + 'n': 'no-cd', + 'q': 'quiet', + }); + + var dirs = _actualDirStack(); + + if (dir === '+0') { + return dirs; // +0 is a noop + } else if (!dir) { + if (dirs.length > 1) { + dirs = dirs.splice(1, 1).concat(dirs); + } else { + return common.error('no other directory'); } - else { - throw e; + } else if (_isStackIndex(dir)) { + var n = _parseStackIndex(dir); + dirs = dirs.slice(n).concat(dirs.slice(0, n)); + } else { + if (options['no-cd']) { + dirs.splice(1, 0, dir); + } else { + dirs.unshift(dir); } + } + + if (options['no-cd']) { + dirs = dirs.slice(1); + } else { + dir = path.resolve(dirs.shift()); + _cd('', dir); + } + + _dirStack = dirs; + return _dirs(options.quiet ? '-q' : ''); } -/** - * Computes and returns a ProjectGraph. - * - * Nx will compute the graph either in a daemon process or in the current process. - * - * Nx will compute it in the current process if: - * * The process is running in CI (CI env variable is to true or other common variables used by CI providers are set). - * * It is running in the docker container. - * * The daemon process is disabled because of the previous error when starting the daemon. - * * `NX_DAEMON` is set to `false`. - * * `useDaemon` is set to false in `nx.json` - * - * `NX_DAEMON` env variable takes precedence: - * * If it is set to true, the daemon will always be used. - * * If it is set to false, the graph will always be computed in the current process. - * - * Tip: If you want to debug project graph creation, run your command with NX_DAEMON=false. - * - * Nx uses two layers of caching: the information about explicit dependencies stored on the disk and the information - * stored in the daemon process. To reset both run: `nx reset`. - */ -function createProjectGraphAsync(opts = { - exitOnError: false, - resetDaemonClient: false, -}) { - return tslib_1.__awaiter(this, void 0, void 0, function* () { - perf_hooks_1.performance.mark('create-project-graph-async:start'); - if (!client_1.daemonClient.enabled()) { - try { - const res = yield buildProjectGraphWithoutDaemon(); - perf_hooks_1.performance.mark('create-project-graph-async:end'); - perf_hooks_1.performance.measure('create-project-graph-async', 'create-project-graph-async:start', 'create-project-graph-async:end'); - return res; - } - catch (e) { - handleProjectGraphError(opts, e); - } - } - else { - try { - const projectGraph = yield client_1.daemonClient.getProjectGraph(); - if (opts.resetDaemonClient) { - client_1.daemonClient.reset(); - } - perf_hooks_1.performance.mark('create-project-graph-async:end'); - perf_hooks_1.performance.measure('create-project-graph-async', 'create-project-graph-async:start', 'create-project-graph-async:end'); - return projectGraph; - } - catch (e) { - if (e.message.indexOf('inotify_add_watch') > -1) { - // common errors with the daemon due to OS settings (cannot watch all the files available) - output_1.output.note({ - title: `Unable to start Nx Daemon due to the limited amount of inotify watches, continuing without the daemon.`, - bodyLines: [ - 'For more information read: https://askubuntu.com/questions/1088272/inotify-add-watch-failed-no-space-left-on-device', - 'Nx Daemon is going to be disabled until you run "nx reset".', - ], - }); - (0, tmp_dir_1.markDaemonAsDisabled)(); - return buildProjectGraphWithoutDaemon(); - } - if (e.internalDaemonError) { - const errorLogFile = (0, tmp_dir_1.writeDaemonLogs)(e.message); - output_1.output.warn({ - title: `Nx Daemon was not able to compute the project graph.`, - bodyLines: [ - `Log file with the error: ${errorLogFile}`, - `Please file an issue at https://github.com/nrwl/nx`, - 'Nx Daemon is going to be disabled until you run "nx reset".', - ], - }); - (0, tmp_dir_1.markDaemonAsDisabled)(); - return buildProjectGraphWithoutDaemon(); - } - handleProjectGraphError(opts, e); - } - } - }); -} -exports.createProjectGraphAsync = createProjectGraphAsync; +exports.pushd = _pushd; + +//@ +//@ +//@ ### popd([options,] ['-N' | '+N']) +//@ +//@ Available options: +//@ +//@ + `-n`: Suppress the normal directory change when removing directories from the stack, so that only the stack is manipulated. +//@ + `-q`: Supresses output to the console. +//@ +//@ Arguments: +//@ +//@ + `+N`: Removes the Nth directory (counting from the left of the list printed by dirs), starting with zero. +//@ + `-N`: Removes the Nth directory (counting from the right of the list printed by dirs), starting with zero. +//@ +//@ Examples: +//@ +//@ ```javascript +//@ echo(process.cwd()); // '/usr' +//@ pushd('/etc'); // '/etc /usr' +//@ echo(process.cwd()); // '/etc' +//@ popd(); // '/usr' +//@ echo(process.cwd()); // '/usr' +//@ ``` +//@ +//@ When no arguments are given, `popd` removes the top directory from the stack and performs a `cd` to the new top directory. The elements are numbered from 0, starting at the first directory listed with dirs (i.e., `popd` is equivalent to `popd +0`). Returns an array of paths in the stack. +function _popd(options, index) { + if (_isStackIndex(options)) { + index = options; + options = ''; + } + options = common.parseOptions(options, { + 'n': 'no-cd', + 'q': 'quiet', + }); -/***/ }), + if (!_dirStack.length) { + return common.error('directory stack empty'); + } -/***/ 36265: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { + index = _parseStackIndex(index || '+0'); -"use strict"; + if (options['no-cd'] || index > 0 || _dirStack.length + index === 0) { + index = index > 0 ? index - 1 : index; + _dirStack.splice(index, 1); + } else { + var dir = path.resolve(_dirStack.shift()); + _cd('', dir); + } -Object.defineProperty(exports, "__esModule", ({ value: true })); -exports.normalizeProjectRoot = exports.findProjectForPath = exports.createProjectRootMappings = exports.createProjectRootMappingsFromProjectConfigurations = void 0; -const path_1 = __nccwpck_require__(71017); -/** - * This creates a map of project roots to project names to easily look up the project of a file - * @param projects This is the map of project configurations commonly found in "workspace.json" - */ -function createProjectRootMappingsFromProjectConfigurations(projects) { - const projectRootMappings = new Map(); - for (const projectName of Object.keys(projects)) { - const root = projects[projectName].root; - projectRootMappings.set(normalizeProjectRoot(root), projectName); - } - return projectRootMappings; + return _dirs(options.quiet ? '-q' : ''); } -exports.createProjectRootMappingsFromProjectConfigurations = createProjectRootMappingsFromProjectConfigurations; -/** - * This creates a map of project roots to project names to easily look up the project of a file - * @param nodes This is the nodes from the project graph - */ -function createProjectRootMappings(nodes) { - const projectRootMappings = new Map(); - for (const projectName of Object.keys(nodes)) { - let root = nodes[projectName].data.root; - projectRootMappings.set(normalizeProjectRoot(root), projectName); +exports.popd = _popd; + +//@ +//@ +//@ ### dirs([options | '+N' | '-N']) +//@ +//@ Available options: +//@ +//@ + `-c`: Clears the directory stack by deleting all of the elements. +//@ + `-q`: Supresses output to the console. +//@ +//@ Arguments: +//@ +//@ + `+N`: Displays the Nth directory (counting from the left of the list printed by dirs when invoked without options), starting with zero. +//@ + `-N`: Displays the Nth directory (counting from the right of the list printed by dirs when invoked without options), starting with zero. +//@ +//@ Display the list of currently remembered directories. Returns an array of paths in the stack, or a single path if `+N` or `-N` was specified. +//@ +//@ See also: `pushd`, `popd` +function _dirs(options, index) { + if (_isStackIndex(options)) { + index = options; + options = ''; + } + + options = common.parseOptions(options, { + 'c': 'clear', + 'q': 'quiet', + }); + + if (options.clear) { + _dirStack = []; + return _dirStack; + } + + var stack = _actualDirStack(); + + if (index) { + index = _parseStackIndex(index); + + if (index < 0) { + index = stack.length + index; } - return projectRootMappings; -} -exports.createProjectRootMappings = createProjectRootMappings; -/** - * Locates a project in projectRootMap based on a file within it - * @param filePath path that is inside of projectName. This should be relative from the workspace root - * @param projectRootMap Map Use {@link createProjectRootMappings} to create this - */ -function findProjectForPath(filePath, projectRootMap) { - let currentPath = filePath; - for (; currentPath != (0, path_1.dirname)(currentPath); currentPath = (0, path_1.dirname)(currentPath)) { - const p = projectRootMap.get(currentPath); - if (p) { - return p; - } + + if (!options.quiet) { + common.log(stack[index]); } - return projectRootMap.get(currentPath); -} -exports.findProjectForPath = findProjectForPath; -function normalizeProjectRoot(root) { - root = root === '' ? '.' : root; - return root && root.endsWith('/') ? root.substring(0, root.length - 1) : root; + return stack[index]; + } + + if (!options.quiet) { + common.log(stack.join(' ')); + } + + return stack; } -exports.normalizeProjectRoot = normalizeProjectRoot; +exports.dirs = _dirs; /***/ }), -/***/ 51635: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { +/***/ 60607: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { -"use strict"; +var format = (__nccwpck_require__(73837).format); -Object.defineProperty(exports, "__esModule", ({ value: true })); -exports.assertWorkspaceValidity = void 0; -const find_matching_projects_1 = __nccwpck_require__(56668); -const output_1 = __nccwpck_require__(34548); -function assertWorkspaceValidity(projectsConfigurations, nxJson) { - const projectNames = Object.keys(projectsConfigurations.projects); - const projectGraphNodes = projectNames.reduce((graph, project) => { - const projectConfiguration = projectsConfigurations.projects[project]; - graph[project] = { - name: project, - type: projectConfiguration.projectType === 'library' ? 'lib' : 'app', - data: Object.assign({}, projectConfiguration), - }; - return graph; - }, {}); - const projects = Object.assign({}, projectsConfigurations.projects); - const invalidImplicitDependencies = new Map(); - if (nxJson.implicitDependencies) { - output_1.output.warn({ - title: 'Using `implicitDependencies` for global implicit dependencies configuration is no longer supported.', - bodyLines: [ - 'Use "namedInputs" instead. You can run "nx repair" to automatically migrate your configuration.', - 'For more information about the usage of "namedInputs" see https://nx.dev/deprecated/global-implicit-dependencies#global-implicit-dependencies', - ], - }); - } - projectNames - .filter((projectName) => { - const project = projects[projectName]; - return !!project.implicitDependencies; - }) - .reduce((map, projectName) => { - const project = projects[projectName]; - detectAndSetInvalidProjectGlobValues(map, projectName, project.implicitDependencies, projects, projectGraphNodes); - return map; - }, invalidImplicitDependencies); - if (invalidImplicitDependencies.size === 0) { - return; - } - let message = `The following implicitDependencies point to non-existent project(s):\n`; - message += [...invalidImplicitDependencies.keys()] - .map((key) => { - const projectNames = invalidImplicitDependencies.get(key); - return ` ${key}\n${projectNames - .map((projectName) => ` ${projectName}`) - .join('\n')}`; - }) - .join('\n\n'); - throw new Error(`Configuration Error\n${message}`); -} -exports.assertWorkspaceValidity = assertWorkspaceValidity; -function detectAndSetInvalidProjectGlobValues(map, sourceName, desiredImplicitDeps, projectConfigurations, projects) { - const invalidProjectsOrGlobs = desiredImplicitDeps.filter((implicit) => { - const projectName = implicit.startsWith('!') - ? implicit.substring(1) - : implicit; - return !(projectConfigurations[projectName] || - (0, find_matching_projects_1.findMatchingProjects)([implicit], projects).length); +var common = __nccwpck_require__(60624); + +common.register('echo', _echo, { + allowGlobbing: false, +}); + +//@ +//@ ### echo([options,] string [, string ...]) +//@ +//@ Available options: +//@ +//@ + `-e`: interpret backslash escapes (default) +//@ + `-n`: remove trailing newline from output +//@ +//@ Examples: +//@ +//@ ```javascript +//@ echo('hello world'); +//@ var str = echo('hello world'); +//@ echo('-n', 'no newline at end'); +//@ ``` +//@ +//@ Prints `string` to stdout, and returns string with additional utility methods +//@ like `.to()`. +function _echo(opts) { + // allow strings starting with '-', see issue #20 + var messages = [].slice.call(arguments, opts ? 0 : 1); + var options = {}; + + // If the first argument starts with '-', parse it as options string. + // If parseOptions throws, it wasn't an options string. + try { + options = common.parseOptions(messages[0], { + 'e': 'escapes', + 'n': 'no_newline', + }, { + silent: true, }); - if (invalidProjectsOrGlobs.length > 0) { - map.set(sourceName, invalidProjectsOrGlobs); + + // Allow null to be echoed + if (messages[0]) { + messages.shift(); } + } catch (_) { + // Clear out error if an error occurred + common.state.error = null; + } + + var output = format.apply(null, messages); + + // Add newline if -n is not passed. + if (!options.no_newline) { + output += '\n'; + } + + process.stdout.write(output); + + return output; } +module.exports = _echo; + /***/ }), -/***/ 20858: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { +/***/ 66829: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { -"use strict"; +var common = __nccwpck_require__(60624); -var _a; -Object.defineProperty(exports, "__esModule", ({ value: true })); -exports.projectGraphCacheDirectory = exports.cacheDir = void 0; -const fs_1 = __nccwpck_require__(57147); -const path_1 = __nccwpck_require__(71017); -const fileutils_1 = __nccwpck_require__(47930); -const workspace_root_1 = __nccwpck_require__(65766); -function readCacheDirectoryProperty(root) { - try { - const nxJson = (0, fileutils_1.readJsonFile)((0, path_1.join)(root, 'nx.json')); - return nxJson.tasksRunnerOptions.default.options.cacheDirectory; - } - catch (_a) { - return undefined; - } -} -function absolutePath(root, path) { - if ((0, path_1.isAbsolute)(path)) { - return path; - } - else { - return (0, path_1.join)(root, path); - } -} -function cacheDirectory(root, cacheDirectory) { - const cacheDirFromEnv = process.env.NX_CACHE_DIRECTORY; - if (cacheDirFromEnv) { - cacheDirectory = cacheDirFromEnv; - } - if (cacheDirectory) { - return absolutePath(root, cacheDirectory); - } - else { - return defaultCacheDirectory(root); - } -} -function defaultCacheDirectory(root) { - return (0, fs_1.existsSync)((0, path_1.join)(root, '.nx')) - ? (0, path_1.join)(root, '.nx', 'cache') - : (0, path_1.join)(root, 'node_modules', '.cache', 'nx'); +//@ +//@ ### error() +//@ +//@ Tests if error occurred in the last command. Returns a truthy value if an +//@ error returned, or a falsy value otherwise. +//@ +//@ **Note**: do not rely on the +//@ return value to be an error message. If you need the last error message, use +//@ the `.stderr` attribute from the last command's return value instead. +function error() { + return common.state.error; } -/** - * Path to the directory where Nx stores its cache and daemon-related files. - */ -exports.cacheDir = cacheDirectory(workspace_root_1.workspaceRoot, readCacheDirectoryProperty(workspace_root_1.workspaceRoot)); -exports.projectGraphCacheDirectory = absolutePath(workspace_root_1.workspaceRoot, (_a = process.env.NX_PROJECT_GRAPH_CACHE_DIRECTORY) !== null && _a !== void 0 ? _a : defaultCacheDirectory(workspace_root_1.workspaceRoot)); +module.exports = error; /***/ }), -/***/ 73133: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { - -"use strict"; +/***/ 148: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { -Object.defineProperty(exports, "__esModule", ({ value: true })); -exports.codeFrameColumns = void 0; -// Adapted from https://raw.githubusercontent.com/babel/babel/4108524/packages/babel-code-frame/src/index.js -const chalk = __nccwpck_require__(29541); -/** - * Chalk styles for code frame token types. - */ -function getDefs(chalk) { - return { - gutter: chalk.grey, - marker: chalk.red.bold, - message: chalk.red.bold, - }; -} -/** - * RegExp to test for newlines in terminal. - */ -const NEWLINE = /\r\n|[\n\r\u2028\u2029]/; -/** - * Extract what lines should be marked and highlighted. - */ -function getMarkerLines(loc, source, opts = {}) { - const startLoc = Object.assign({ column: 0, line: -1 }, loc.start); - const endLoc = Object.assign(Object.assign({}, startLoc), loc.end); - const { linesAbove = 2, linesBelow = 3 } = opts || {}; - const startLine = startLoc.line; - const startColumn = startLoc.column; - const endLine = endLoc.line; - const endColumn = endLoc.column; - let start = Math.max(startLine - (linesAbove + 1), 0); - let end = Math.min(source.length, endLine + linesBelow); - if (startLine === -1) { - start = 0; - } - if (endLine === -1) { - end = source.length; - } - const lineDiff = endLine - startLine; - const markerLines = {}; - if (lineDiff) { - for (let i = 0; i <= lineDiff; i++) { - const lineNumber = i + startLine; - if (!startColumn) { - markerLines[lineNumber] = true; - } - else if (i === 0) { - const sourceLength = source[lineNumber - 1].length; - markerLines[lineNumber] = [startColumn, sourceLength - startColumn + 1]; - } - else if (i === lineDiff) { - markerLines[lineNumber] = [0, endColumn]; - } - else { - const sourceLength = source[lineNumber - i].length; - markerLines[lineNumber] = [0, sourceLength]; - } - } - } - else { - if (startColumn === endColumn) { - if (startColumn) { - markerLines[startLine] = [startColumn, 0]; - } - else { - markerLines[startLine] = true; - } - } - else { - markerLines[startLine] = [startColumn, endColumn - startColumn]; - } - } - return { start, end, markerLines }; -} -function codeFrameColumns(rawLines, loc, opts = {}) { - const defs = getDefs(chalk); - const lines = rawLines.split(NEWLINE); - const { start, end, markerLines } = getMarkerLines(loc, lines, opts); - const numberMaxWidth = String(end).length; - const highlightedLines = opts.highlight ? opts.highlight(rawLines) : rawLines; - let frame = highlightedLines - .split(NEWLINE) - .slice(start, end) - .map((line, index) => { - const number = start + 1 + index; - const paddedNumber = ` ${number}`.slice(-numberMaxWidth); - const gutter = ` ${paddedNumber} | `; - const hasMarker = markerLines[number]; - if (hasMarker) { - let markerLine = ''; - if (Array.isArray(hasMarker)) { - const markerSpacing = line - .slice(0, Math.max(hasMarker[0] - 1, 0)) - .replace(/[^\t]/g, ' '); - const numberOfMarkers = hasMarker[1] || 1; - markerLine = [ - '\n ', - defs.gutter(gutter.replace(/\d/g, ' ')), - markerSpacing, - defs.marker('^').repeat(numberOfMarkers), - ].join(''); - } - return [defs.marker('>'), defs.gutter(gutter), line, markerLine].join(''); - } - else { - return ` ${defs.gutter(gutter)}${line}`; - } - }) - .join('\n'); - return chalk.reset(frame); +/* module decorator */ module = __nccwpck_require__.nmd(module); +if (require.main !== module) { + throw new Error('This file should not be required'); } -exports.codeFrameColumns = codeFrameColumns; +var childProcess = __nccwpck_require__(32081); +var fs = __nccwpck_require__(57147); -/***/ }), +var paramFilePath = process.argv[2]; -/***/ 81904: -/***/ ((__unused_webpack_module, exports) => { +var serializedParams = fs.readFileSync(paramFilePath, 'utf8'); +var params = JSON.parse(serializedParams); -"use strict"; +var cmd = params.command; +var execOptions = params.execOptions; +var pipe = params.pipe; +var stdoutFile = params.stdoutFile; +var stderrFile = params.stderrFile; -Object.defineProperty(exports, "__esModule", ({ value: true })); -exports.consumeMessagesFromSocket = void 0; -function consumeMessagesFromSocket(callback) { - let message = ''; - return (data) => { - const chunk = data.toString(); - if (chunk.codePointAt(chunk.length - 1) === 4) { - message += chunk.substring(0, chunk.length - 1); - // Server may send multiple messages in one chunk, so splitting by 0x4 - const messages = message.split(''); - for (const splitMessage of messages) { - callback(splitMessage); - } - message = ''; - } - else { - message += chunk; - } - }; +var c = childProcess.exec(cmd, execOptions, function (err) { + if (!err) { + process.exitCode = 0; + } else if (err.code === undefined) { + process.exitCode = 1; + } else { + process.exitCode = err.code; + } +}); + +var stdoutStream = fs.createWriteStream(stdoutFile); +var stderrStream = fs.createWriteStream(stderrFile); + +c.stdout.pipe(stdoutStream); +c.stderr.pipe(stderrStream); +c.stdout.pipe(process.stdout); +c.stderr.pipe(process.stderr); + +if (pipe) { + c.stdin.end(pipe); } -exports.consumeMessagesFromSocket = consumeMessagesFromSocket; /***/ }), -/***/ 47930: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { +/***/ 25239: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { -"use strict"; +var common = __nccwpck_require__(60624); +var _tempDir = (__nccwpck_require__(68691).tempDir); +var _pwd = __nccwpck_require__(90909); +var path = __nccwpck_require__(71017); +var fs = __nccwpck_require__(57147); +var child = __nccwpck_require__(32081); -Object.defineProperty(exports, "__esModule", ({ value: true })); -exports.readFileIfExisting = exports.extractFileFromTarball = exports.isRelativePath = exports.createDirectory = exports.fileExists = exports.directoryExists = exports.writeJsonFile = exports.readYamlFile = exports.readJsonFile = void 0; -const tslib_1 = __nccwpck_require__(51796); -const json_1 = __nccwpck_require__(43684); -const fs_1 = __nccwpck_require__(57147); -const path_1 = __nccwpck_require__(71017); -const tar = __nccwpck_require__(93983); -const zlib_1 = __nccwpck_require__(59796); -/** - * Reads a JSON file and returns the object the JSON content represents. - * - * @param path A path to a file. - * @param options JSON parse options - * @returns Object the JSON content of the file represents - */ -function readJsonFile(path, options) { - const content = (0, fs_1.readFileSync)(path, 'utf-8'); - if (options) { - options.endsWithNewline = content.charCodeAt(content.length - 1) === 10; - } - try { - return (0, json_1.parseJson)(content, options); - } - catch (e) { - e.message = e.message.replace('JSON', path); - throw e; - } -} -exports.readJsonFile = readJsonFile; -/** - * Reads a YAML file and returns the object the YAML content represents. - * - * @param path A path to a file. - * @returns - */ -function readYamlFile(path, options) { - const content = (0, fs_1.readFileSync)(path, 'utf-8'); - const { load } = __nccwpck_require__(92595); - return load(content, Object.assign(Object.assign({}, options), { filename: path })); -} -exports.readYamlFile = readYamlFile; -/** - * Serializes the given data to JSON and writes it to a file. - * - * @param path A path to a file. - * @param data data which should be serialized to JSON and written to the file - * @param options JSON serialize options - */ -function writeJsonFile(path, data, options) { - (0, fs_1.mkdirSync)((0, path_1.dirname)(path), { recursive: true }); - const serializedJson = (0, json_1.serializeJson)(data, options); - const content = (options === null || options === void 0 ? void 0 : options.appendNewLine) - ? `${serializedJson}\n` - : serializedJson; - (0, fs_1.writeFileSync)(path, content, { encoding: 'utf-8' }); -} -exports.writeJsonFile = writeJsonFile; -/** - * Check if a directory exists - * @param path Path to directory - */ -function directoryExists(path) { - try { - return (0, fs_1.statSync)(path).isDirectory(); - } - catch (_a) { - return false; - } -} -exports.directoryExists = directoryExists; -/** - * Check if a file exists. - * @param path Path to file - */ -function fileExists(path) { - try { - return (0, fs_1.statSync)(path).isFile(); - } - catch (_a) { - return false; - } -} -exports.fileExists = fileExists; -function createDirectory(path) { - (0, fs_1.mkdirSync)(path, { recursive: true }); -} -exports.createDirectory = createDirectory; -function isRelativePath(path) { - return (path === '.' || - path === '..' || - path.startsWith('./') || - path.startsWith('../')); -} -exports.isRelativePath = isRelativePath; -/** - * Extracts a file from a given tarball to the specified destination. - * @param tarballPath The path to the tarball from where the file should be extracted. - * @param file The path to the file inside the tarball. - * @param destinationFilePath The destination file path. - * @returns True if the file was extracted successfully, false otherwise. - */ -function extractFileFromTarball(tarballPath, file, destinationFilePath) { - return tslib_1.__awaiter(this, void 0, void 0, function* () { - return new Promise((resolve, reject) => { - (0, fs_1.mkdirSync)((0, path_1.dirname)(destinationFilePath), { recursive: true }); - var tarExtractStream = tar.extract(); - const destinationFileStream = (0, fs_1.createWriteStream)(destinationFilePath); - let isFileExtracted = false; - tarExtractStream.on('entry', function (header, stream, next) { - if (header.name === file) { - stream.pipe(destinationFileStream); - stream.on('end', () => { - isFileExtracted = true; - }); - destinationFileStream.on('close', () => { - resolve(destinationFilePath); - }); - } - stream.on('end', function () { - next(); - }); - stream.resume(); - }); - tarExtractStream.on('finish', function () { - if (!isFileExtracted) { - reject(); - } - }); - (0, fs_1.createReadStream)(tarballPath).pipe((0, zlib_1.createGunzip)()).pipe(tarExtractStream); - }); +var DEFAULT_MAXBUFFER_SIZE = 20 * 1024 * 1024; +var DEFAULT_ERROR_CODE = 1; + +common.register('exec', _exec, { + unix: false, + canReceivePipe: true, + wrapOutput: false, +}); + +// We use this function to run `exec` synchronously while also providing realtime +// output. +function execSync(cmd, opts, pipe) { + if (!common.config.execPath) { + common.error('Unable to find a path to the node binary. Please manually set config.execPath'); + } + + var tempDir = _tempDir(); + var paramsFile = path.resolve(tempDir + '/' + common.randomFileName()); + var stderrFile = path.resolve(tempDir + '/' + common.randomFileName()); + var stdoutFile = path.resolve(tempDir + '/' + common.randomFileName()); + + opts = common.extend({ + silent: common.config.silent, + cwd: _pwd().toString(), + env: process.env, + maxBuffer: DEFAULT_MAXBUFFER_SIZE, + encoding: 'utf8', + }, opts); + + if (fs.existsSync(paramsFile)) common.unlinkSync(paramsFile); + if (fs.existsSync(stderrFile)) common.unlinkSync(stderrFile); + if (fs.existsSync(stdoutFile)) common.unlinkSync(stdoutFile); + + opts.cwd = path.resolve(opts.cwd); + + var paramsToSerialize = { + command: cmd, + execOptions: opts, + pipe: pipe, + stdoutFile: stdoutFile, + stderrFile: stderrFile, + }; + + // Create the files and ensure these are locked down (for read and write) to + // the current user. The main concerns here are: + // + // * If we execute a command which prints sensitive output, then + // stdoutFile/stderrFile must not be readable by other users. + // * paramsFile must not be readable by other users, or else they can read it + // to figure out the path for stdoutFile/stderrFile and create these first + // (locked down to their own access), which will crash exec() when it tries + // to write to the files. + function writeFileLockedDown(filePath, data) { + fs.writeFileSync(filePath, data, { + encoding: 'utf8', + mode: parseInt('600', 8), }); -} -exports.extractFileFromTarball = extractFileFromTarball; -function readFileIfExisting(path) { - return (0, fs_1.existsSync)(path) ? (0, fs_1.readFileSync)(path, 'utf-8') : ''; -} -exports.readFileIfExisting = readFileIfExisting; + } + writeFileLockedDown(stdoutFile, ''); + writeFileLockedDown(stderrFile, ''); + writeFileLockedDown(paramsFile, JSON.stringify(paramsToSerialize)); + var execArgs = [ + __nccwpck_require__.ab + "exec-child.js", + paramsFile, + ]; -/***/ }), + /* istanbul ignore else */ + if (opts.silent) { + opts.stdio = 'ignore'; + } else { + opts.stdio = [0, 1, 2]; + } -/***/ 56668: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { + var code = 0; -"use strict"; + // Welcome to the future + try { + // Bad things if we pass in a `shell` option to child_process.execFileSync, + // so we need to explicitly remove it here. + delete opts.shell; -Object.defineProperty(exports, "__esModule", ({ value: true })); -exports.getMatchingStringsWithCache = exports.findMatchingProjects = void 0; -const minimatch = __nccwpck_require__(72755); -const validPatternTypes = [ - 'name', - 'tag', - 'directory', - 'unlabeled', // Pattern was passed without specifying a type -]; -const globCharacters = ['*', '|', '{', '}', '(', ')']; -/** - * Find matching project names given a list of potential project names or globs. - * - * @param patterns A list of project names or globs to match against. - * @param projects A map of {@link ProjectGraphProjectNode} by project name. - * @returns - */ -function findMatchingProjects(patterns = [], projects) { - if (!patterns.length || patterns.filter((p) => p.length).length === 0) { - return []; // Short circuit if called with no patterns - } - const projectNames = Object.keys(projects); - const selectedProjects = new Set(); - const excludedProjects = new Set(); - for (const stringPattern of patterns) { - if (!stringPattern.length) { - continue; - } - const pattern = parseStringPattern(stringPattern, projects); - // Handle wildcard with short-circuit, as its a common case with potentially - // large project sets and we can avoid the more expensive glob matching. - if (pattern.value === '*') { - for (const projectName of projectNames) { - if (pattern.exclude) { - excludedProjects.add(projectName); - } - else { - selectedProjects.add(projectName); - } - } - continue; - } - switch (pattern.type) { - case 'tag': { - addMatchingProjectsByTag(projectNames, projects, pattern, excludedProjects, selectedProjects); - continue; - } - case 'name': { - addMatchingProjectsByName(projectNames, projects, pattern, excludedProjects, selectedProjects); - continue; - } - case 'directory': { - addMatchingProjectsByDirectory(projectNames, projects, pattern, excludedProjects, selectedProjects); - continue; - } - // Same thing as `type:unlabeled`. If no specific type is set, - // we can waterfall through the different types until we find a match - default: { - // The size of the selected and excluded projects set, before we - // start updating it with this pattern. If the size changes, we - // know we found a match and can skip the other types. - const originalSize = selectedProjects.size + excludedProjects.size; - addMatchingProjectsByName(projectNames, projects, pattern, excludedProjects, selectedProjects); - if (selectedProjects.size + excludedProjects.size > originalSize) { - // There was some match by name, don't check other types - continue; - } - addMatchingProjectsByDirectory(projectNames, projects, pattern, excludedProjects, selectedProjects); - if (selectedProjects.size + excludedProjects.size > originalSize) { - // There was some match by directory, don't check other types - // Note - this doesn't do anything currently, but preps for future - // types - continue; - } - } - } - } - for (const project of excludedProjects) { - selectedProjects.delete(project); - } - return Array.from(selectedProjects); -} -exports.findMatchingProjects = findMatchingProjects; -function addMatchingProjectsByDirectory(projectNames, projects, pattern, excludedProjects, selectedProjects) { - for (const projectName of projectNames) { - const root = projects[projectName].data.root; - if ((0, exports.getMatchingStringsWithCache)(pattern.value, [root]).length > 0) { - (pattern.exclude ? excludedProjects : selectedProjects).add(projectName); - } - } -} -function addMatchingProjectsByName(projectNames, projects, pattern, excludedProjects, selectedProjects) { - if (projects[pattern.value]) { - (pattern.exclude ? excludedProjects : selectedProjects).add(pattern.value); - return; - } - if (!globCharacters.some((c) => pattern.value.includes(c))) { - return; - } - const matchedProjectNames = (0, exports.getMatchingStringsWithCache)(pattern.value, projectNames); - for (const projectName of matchedProjectNames) { - if (pattern.exclude) { - excludedProjects.add(projectName); - } - else { - selectedProjects.add(projectName); - } - } -} -function addMatchingProjectsByTag(projectNames, projects, pattern, excludedProjects, selectedProjects) { - for (const projectName of projectNames) { - const tags = projects[projectName].data.tags || []; - if (tags.includes(pattern.value)) { - (pattern.exclude ? excludedProjects : selectedProjects).add(projectName); - continue; - } - if (!globCharacters.some((c) => pattern.value.includes(c))) { - continue; - } - if ((0, exports.getMatchingStringsWithCache)(pattern.value, tags).length) { - (pattern.exclude ? excludedProjects : selectedProjects).add(projectName); - } - } -} -function parseStringPattern(pattern, projects) { - const isExclude = pattern.startsWith('!'); - // Support for things like: `!{type}:value` - if (isExclude) { - pattern = pattern.substring(1); - } - const indexOfFirstPotentialSeparator = pattern.indexOf(':'); - // There is a project that matches directly - if (projects[pattern]) { - return { type: 'name', value: pattern, exclude: isExclude }; - // The pattern does not contain a label - } - else if (indexOfFirstPotentialSeparator === -1) { - return { type: 'unlabeled', value: pattern, exclude: isExclude }; - // The pattern may contain a label - } - else { - const potentialType = pattern.substring(0, indexOfFirstPotentialSeparator); - return { - type: isValidPatternType(potentialType) ? potentialType : 'unlabeled', - value: pattern.substring(indexOfFirstPotentialSeparator + 1), - exclude: isExclude, - }; + child.execFileSync(common.config.execPath, execArgs, opts); + } catch (e) { + // Commands with non-zero exit code raise an exception. + code = e.status || DEFAULT_ERROR_CODE; + } + + // fs.readFileSync uses buffer encoding by default, so call + // it without the encoding option if the encoding is 'buffer'. + // Also, if the exec timeout is too short for node to start up, + // the files will not be created, so these calls will throw. + var stdout = ''; + var stderr = ''; + if (opts.encoding === 'buffer') { + stdout = fs.readFileSync(stdoutFile); + stderr = fs.readFileSync(stderrFile); + } else { + stdout = fs.readFileSync(stdoutFile, opts.encoding); + stderr = fs.readFileSync(stderrFile, opts.encoding); + } + + // No biggie if we can't erase the files now -- they're in a temp dir anyway + // and we locked down permissions (see the note above). + try { common.unlinkSync(paramsFile); } catch (e) {} + try { common.unlinkSync(stderrFile); } catch (e) {} + try { common.unlinkSync(stdoutFile); } catch (e) {} + + if (code !== 0) { + // Note: `silent` should be unconditionally true to avoid double-printing + // the command's stderr, and to avoid printing any stderr when the user has + // set `shell.config.silent`. + common.error(stderr, code, { continue: true, silent: true }); + } + var obj = common.ShellString(stdout, stderr, code); + return obj; +} // execSync() + +// Wrapper around exec() to enable echoing output to console in real time +function execAsync(cmd, opts, pipe, callback) { + opts = common.extend({ + silent: common.config.silent, + cwd: _pwd().toString(), + env: process.env, + maxBuffer: DEFAULT_MAXBUFFER_SIZE, + encoding: 'utf8', + }, opts); + + var c = child.exec(cmd, opts, function (err, stdout, stderr) { + if (callback) { + if (!err) { + callback(0, stdout, stderr); + } else if (err.code === undefined) { + // See issue #536 + /* istanbul ignore next */ + callback(1, stdout, stderr); + } else { + callback(err.code, stdout, stderr); + } } + }); + + if (pipe) c.stdin.end(pipe); + + if (!opts.silent) { + c.stdout.pipe(process.stdout); + c.stderr.pipe(process.stderr); + } + + return c; } -function isValidPatternType(type) { - return validPatternTypes.includes(type); + +//@ +//@ ### exec(command [, options] [, callback]) +//@ +//@ Available options: +//@ +//@ + `async`: Asynchronous execution. If a callback is provided, it will be set to +//@ `true`, regardless of the passed value (default: `false`). +//@ + `silent`: Do not echo program output to console (default: `false`). +//@ + `encoding`: Character encoding to use. Affects the values returned to stdout and stderr, and +//@ what is written to stdout and stderr when not in silent mode (default: `'utf8'`). +//@ + and any option available to Node.js's +//@ [`child_process.exec()`](https://nodejs.org/api/child_process.html#child_process_child_process_exec_command_options_callback) +//@ +//@ Examples: +//@ +//@ ```javascript +//@ var version = exec('node --version', {silent:true}).stdout; +//@ +//@ var child = exec('some_long_running_process', {async:true}); +//@ child.stdout.on('data', function(data) { +//@ /* ... do something with data ... */ +//@ }); +//@ +//@ exec('some_long_running_process', function(code, stdout, stderr) { +//@ console.log('Exit code:', code); +//@ console.log('Program output:', stdout); +//@ console.log('Program stderr:', stderr); +//@ }); +//@ ``` +//@ +//@ Executes the given `command` _synchronously_, unless otherwise specified. When in synchronous +//@ mode, this returns a `ShellString` (compatible with ShellJS v0.6.x, which returns an object +//@ of the form `{ code:..., stdout:... , stderr:... }`). Otherwise, this returns the child process +//@ object, and the `callback` receives the arguments `(code, stdout, stderr)`. +//@ +//@ Not seeing the behavior you want? `exec()` runs everything through `sh` +//@ by default (or `cmd.exe` on Windows), which differs from `bash`. If you +//@ need bash-specific behavior, try out the `{shell: 'path/to/bash'}` option. +function _exec(command, options, callback) { + options = options || {}; + if (!command) common.error('must specify command'); + + var pipe = common.readFromPipe(); + + // Callback is defined instead of options. + if (typeof options === 'function') { + callback = options; + options = { async: true }; + } + + // Callback is defined with options. + if (typeof options === 'object' && typeof callback === 'function') { + options.async = true; + } + + options = common.extend({ + silent: common.config.silent, + async: false, + }, options); + + if (options.async) { + return execAsync(command, options, pipe, callback); + } else { + return execSync(command, options, pipe); + } } -exports.getMatchingStringsWithCache = (() => { - // Map< Pattern, Map< Item, Result >> - const minimatchCache = new Map(); - const regexCache = new Map(); - return (pattern, items) => { - if (!minimatchCache.has(pattern)) { - minimatchCache.set(pattern, new Map()); - } - const patternCache = minimatchCache.get(pattern); - if (!regexCache.has(pattern)) { - regexCache.set(pattern, minimatch.makeRe(pattern)); - } - const matcher = regexCache.get(pattern); - return items.filter((item) => { - let entry = patternCache.get(item); - if (entry === undefined || entry === null) { - entry = item === pattern ? true : matcher.test(item); - patternCache.set(item, entry); - } - return entry; - }); - }; -})(); +module.exports = _exec; /***/ }), -/***/ 98845: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { +/***/ 52388: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { -"use strict"; +var path = __nccwpck_require__(71017); +var common = __nccwpck_require__(60624); +var _ls = __nccwpck_require__(42248); -Object.defineProperty(exports, "__esModule", ({ value: true })); -exports.getIgnoreObject = exports.getAlwaysIgnore = exports.getIgnoredGlobs = exports.ALWAYS_IGNORE = void 0; -const fs_extra_1 = __nccwpck_require__(59511); -const ignore_1 = __nccwpck_require__(98337); -const fileutils_1 = __nccwpck_require__(47930); -const path_1 = __nccwpck_require__(75878); -const workspace_root_1 = __nccwpck_require__(65766); -/** - * An array of glob patterns that should always be ignored. - * Uses path/posix, since fast-glob requires unix paths. - */ -exports.ALWAYS_IGNORE = getAlwaysIgnore(); -function getIgnoredGlobs(root = workspace_root_1.workspaceRoot, prependRoot = true) { - const files = ['.gitignore', '.nxignore']; - if (prependRoot) { - return [ - ...getAlwaysIgnore(root), - ...files.flatMap((f) => getIgnoredGlobsFromFile((0, path_1.joinPathFragments)(root, f), root)), - ]; - } - else { - return [ - ...getAlwaysIgnore(), - ...files.flatMap((f) => getIgnoredGlobsFromFile((0, path_1.joinPathFragments)(root, f))), - ]; +common.register('find', _find, {}); + +//@ +//@ ### find(path [, path ...]) +//@ ### find(path_array) +//@ +//@ Examples: +//@ +//@ ```javascript +//@ find('src', 'lib'); +//@ find(['src', 'lib']); // same as above +//@ find('.').filter(function(file) { return file.match(/\.js$/); }); +//@ ``` +//@ +//@ Returns array of all files (however deep) in the given paths. +//@ +//@ The main difference from `ls('-R', path)` is that the resulting file names +//@ include the base directories (e.g., `lib/resources/file1` instead of just `file1`). +function _find(options, paths) { + if (!paths) { + common.error('no path specified'); + } else if (typeof paths === 'string') { + paths = [].slice.call(arguments, 1); + } + + var list = []; + + function pushFile(file) { + if (process.platform === 'win32') { + file = file.replace(/\\/g, '/'); } -} -exports.getIgnoredGlobs = getIgnoredGlobs; -function getAlwaysIgnore(root) { - const paths = ['node_modules', '**/node_modules', '.git']; - return root ? paths.map((x) => (0, path_1.joinPathFragments)(root, x)) : paths; -} -exports.getAlwaysIgnore = getAlwaysIgnore; -function getIgnoreObject(root = workspace_root_1.workspaceRoot) { - const ig = (0, ignore_1.default)(); - ig.add((0, fileutils_1.readFileIfExisting)(`${root}/.gitignore`)); - ig.add((0, fileutils_1.readFileIfExisting)(`${root}/.nxignore`)); - return ig; -} -exports.getIgnoreObject = getIgnoreObject; -function getIgnoredGlobsFromFile(file, root) { + list.push(file); + } + + // why not simply do `ls('-R', paths)`? because the output wouldn't give the base dirs + // to get the base dir in the output, we need instead `ls('-R', 'dir/*')` for every directory + + paths.forEach(function (file) { + var stat; try { - const results = []; - const contents = (0, fs_extra_1.readFileSync)(file, 'utf-8'); - const lines = contents.split('\n'); - for (const line of lines) { - const trimmed = line.trim(); - if (!trimmed || trimmed.startsWith('#')) { - continue; - } - else if (trimmed.startsWith('/')) { - if (root) { - results.push((0, path_1.joinPathFragments)(root, trimmed)); - } - else { - results.push((0, path_1.joinPathFragments)('.', trimmed)); - } - } - else { - results.push(trimmed); - } - } - return results; + stat = common.statFollowLinks(file); + } catch (e) { + common.error('no such file or directory: ' + file); } - catch (e) { - return []; + + pushFile(file); + + if (stat.isDirectory()) { + _ls({ recursive: true, all: true }, file).forEach(function (subfile) { + pushFile(path.join(file, subfile)); + }); } + }); + + return list; } +module.exports = _find; /***/ }), -/***/ 35075: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { +/***/ 47294: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { -"use strict"; +var common = __nccwpck_require__(60624); +var fs = __nccwpck_require__(57147); -Object.defineProperty(exports, "__esModule", ({ value: true })); -exports.getNxRequirePaths = exports.getNxInstallationPath = void 0; -const path_1 = __nccwpck_require__(71017); -const workspace_root_1 = __nccwpck_require__(65766); -function getNxInstallationPath(root = workspace_root_1.workspaceRoot) { - return (0, path_1.join)(root, '.nx', 'installation'); -} -exports.getNxInstallationPath = getNxInstallationPath; -function getNxRequirePaths(root = workspace_root_1.workspaceRoot) { - return [root, getNxInstallationPath(root)]; -} -exports.getNxRequirePaths = getNxRequirePaths; +common.register('grep', _grep, { + globStart: 2, // don't glob-expand the regex + canReceivePipe: true, + cmdOptions: { + 'v': 'inverse', + 'l': 'nameOnly', + 'i': 'ignoreCase', + }, +}); +//@ +//@ ### grep([options,] regex_filter, file [, file ...]) +//@ ### grep([options,] regex_filter, file_array) +//@ +//@ Available options: +//@ +//@ + `-v`: Invert `regex_filter` (only print non-matching lines). +//@ + `-l`: Print only filenames of matching files. +//@ + `-i`: Ignore case. +//@ +//@ Examples: +//@ +//@ ```javascript +//@ grep('-v', 'GLOBAL_VARIABLE', '*.js'); +//@ grep('GLOBAL_VARIABLE', '*.js'); +//@ ``` +//@ +//@ Reads input string from given files and returns a string containing all lines of the +//@ file that match the given `regex_filter`. +function _grep(options, regex, files) { + // Check if this is coming from a pipe + var pipe = common.readFromPipe(); -/***/ }), + if (!files && !pipe) common.error('no paths given', 2); -/***/ 28839: -/***/ ((__unused_webpack_module, exports) => { + files = [].slice.call(arguments, 2); -"use strict"; + if (pipe) { + files.unshift('-'); + } -Object.defineProperty(exports, "__esModule", ({ value: true })); -exports.isCI = void 0; -function isCI() { - return (process.env.CI === 'true' || - process.env.TF_BUILD === 'true' || - process.env.GITHUB_ACTIONS === 'true' || - process.env.BUILDKITE === 'true' || - process.env.CIRCLECI === 'true' || - process.env.CIRRUS_CI === 'true' || - process.env.TRAVIS === 'true' || - !!process.env['bamboo.buildKey'] || - !!process.env.CODEBUILD_BUILD_ID || - !!process.env.GITLAB_CI || - !!process.env.HEROKU_TEST_RUN_ID || - !!process.env.BUILD_ID || - !!process.env.BUILD_BUILDID || - !!process.env.TEAMCITY_VERSION); + var grep = []; + if (options.ignoreCase) { + regex = new RegExp(regex, 'i'); + } + files.forEach(function (file) { + if (!fs.existsSync(file) && file !== '-') { + common.error('no such file or directory: ' + file, 2, { continue: true }); + return; + } + + var contents = file === '-' ? pipe : fs.readFileSync(file, 'utf8'); + if (options.nameOnly) { + if (contents.match(regex)) { + grep.push(file); + } + } else { + var lines = contents.split('\n'); + lines.forEach(function (line) { + var matched = line.match(regex); + if ((options.inverse && !matched) || (!options.inverse && matched)) { + grep.push(line); + } + }); + } + }); + + return grep.join('\n') + '\n'; } -exports.isCI = isCI; +module.exports = _grep; /***/ }), -/***/ 65058: -/***/ ((__unused_webpack_module, exports) => { +/***/ 24902: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { -"use strict"; +var common = __nccwpck_require__(60624); +var fs = __nccwpck_require__(57147); -Object.defineProperty(exports, "__esModule", ({ value: true })); -exports.walkJsonTree = exports.jsonDiff = exports.isJsonChange = exports.JsonDiffType = void 0; -var JsonDiffType; -(function (JsonDiffType) { - JsonDiffType["Deleted"] = "JsonPropertyDeleted"; - JsonDiffType["Added"] = "JsonPropertyAdded"; - JsonDiffType["Modified"] = "JsonPropertyModified"; -})(JsonDiffType = exports.JsonDiffType || (exports.JsonDiffType = {})); -function isJsonChange(change) { - return (change.type === JsonDiffType.Added || - change.type === JsonDiffType.Deleted || - change.type === JsonDiffType.Modified); -} -exports.isJsonChange = isJsonChange; -function jsonDiff(lhs, rhs) { - const result = []; - const seenInLhs = new Set(); - walkJsonTree(lhs, [], (path, lhsValue) => { - seenInLhs.add(hashArray(path)); - const rhsValue = getJsonValue(path, rhs); - if (rhsValue === undefined) { - result.push({ - type: JsonDiffType.Deleted, - path, - value: { - lhs: lhsValue, - rhs: undefined, - }, - }); - } - else if (!deepEquals(lhsValue, rhsValue)) { - result.push({ - type: JsonDiffType.Modified, - path, - value: { - lhs: lhsValue, - rhs: rhsValue, - }, - }); - } - return typeof lhsValue === 'object' || Array.isArray(lhsValue); - }); - walkJsonTree(rhs, [], (path, rhsValue) => { - const addedInRhs = !seenInLhs.has(hashArray(path)); - if (addedInRhs) { - result.push({ - type: JsonDiffType.Added, - path, - value: { - lhs: undefined, - rhs: rhsValue, - }, - }); - } - return typeof rhsValue === 'object' || Array.isArray(rhsValue); - }); - return result; +common.register('head', _head, { + canReceivePipe: true, + cmdOptions: { + 'n': 'numLines', + }, +}); + +// Reads |numLines| lines or the entire file, whichever is less. +function readSomeLines(file, numLines) { + var buf = common.buffer(); + var bufLength = buf.length; + var bytesRead = bufLength; + var pos = 0; + + var fdr = fs.openSync(file, 'r'); + var numLinesRead = 0; + var ret = ''; + while (bytesRead === bufLength && numLinesRead < numLines) { + bytesRead = fs.readSync(fdr, buf, 0, bufLength, pos); + var bufStr = buf.toString('utf8', 0, bytesRead); + numLinesRead += bufStr.split('\n').length - 1; + ret += bufStr; + pos += bytesRead; + } + + fs.closeSync(fdr); + return ret; } -exports.jsonDiff = jsonDiff; -// Depth-first walk down JSON tree. -function walkJsonTree(json, currPath, visitor) { - if (!json || typeof json !== 'object') { + +//@ +//@ ### head([{'-n': \},] file [, file ...]) +//@ ### head([{'-n': \},] file_array) +//@ +//@ Available options: +//@ +//@ + `-n `: Show the first `` lines of the files +//@ +//@ Examples: +//@ +//@ ```javascript +//@ var str = head({'-n': 1}, 'file*.txt'); +//@ var str = head('file1', 'file2'); +//@ var str = head(['file1', 'file2']); // same as above +//@ ``` +//@ +//@ Read the start of a file. +function _head(options, files) { + var head = []; + var pipe = common.readFromPipe(); + + if (!files && !pipe) common.error('no paths given'); + + var idx = 1; + if (options.numLines === true) { + idx = 2; + options.numLines = Number(arguments[1]); + } else if (options.numLines === false) { + options.numLines = 10; + } + files = [].slice.call(arguments, idx); + + if (pipe) { + files.unshift('-'); + } + + var shouldAppendNewline = false; + files.forEach(function (file) { + if (file !== '-') { + if (!fs.existsSync(file)) { + common.error('no such file or directory: ' + file, { continue: true }); return; + } else if (common.statFollowLinks(file).isDirectory()) { + common.error("error reading '" + file + "': Is a directory", { + continue: true, + }); + return; + } } - Object.keys(json).forEach((key) => { - const path = currPath.concat([key]); - const shouldContinue = visitor(path, json[key]); - if (shouldContinue) { - walkJsonTree(json[key], path, visitor); - } - }); -} -exports.walkJsonTree = walkJsonTree; -function hashArray(ary) { - return JSON.stringify(ary); -} -function getJsonValue(path, json) { - let curr = json; - for (const k of path) { - curr = curr[k]; - if (curr === undefined) { - break; - } - } - return curr; -} -function deepEquals(a, b) { - if (a === b) { - return true; + + var contents; + if (file === '-') { + contents = pipe; + } else if (options.numLines < 0) { + contents = fs.readFileSync(file, 'utf8'); + } else { + contents = readSomeLines(file, options.numLines); } - // Values do not need to be checked for deep equality and the above is false - if ( - // Values are different types - typeof a !== typeof b || - // Values are the same type but not an object or array - (typeof a !== 'object' && !Array.isArray(a)) || - // Objects are the same type, objects or arrays, but do not have the same number of keys - Object.keys(a).length !== Object.keys(b).length) { - return false; + + var lines = contents.split('\n'); + var hasTrailingNewline = (lines[lines.length - 1] === ''); + if (hasTrailingNewline) { + lines.pop(); } - // Values need to be checked for deep equality - return Object.entries(a).reduce((equal, [key, aValue]) => { - // Skip other keys if it is already not equal. - if (!equal) { - return equal; - } - // Traverse the object - return deepEquals(aValue, b[key]); - }, true); + shouldAppendNewline = (hasTrailingNewline || options.numLines < lines.length); + + head = head.concat(lines.slice(0, options.numLines)); + }); + + if (shouldAppendNewline) { + head.push(''); // to add a trailing newline once we join + } + return head.join('\n'); } +module.exports = _head; /***/ }), -/***/ 43684: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { +/***/ 68092: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { -"use strict"; +var fs = __nccwpck_require__(57147); +var path = __nccwpck_require__(71017); +var common = __nccwpck_require__(60624); + +common.register('ln', _ln, { + cmdOptions: { + 's': 'symlink', + 'f': 'force', + }, +}); + +//@ +//@ ### ln([options,] source, dest) +//@ +//@ Available options: +//@ +//@ + `-s`: symlink +//@ + `-f`: force +//@ +//@ Examples: +//@ +//@ ```javascript +//@ ln('file', 'newlink'); +//@ ln('-sf', 'file', 'existing'); +//@ ``` +//@ +//@ Links `source` to `dest`. Use `-f` to force the link, should `dest` already exist. +function _ln(options, source, dest) { + if (!source || !dest) { + common.error('Missing and/or '); + } + + source = String(source); + var sourcePath = path.normalize(source).replace(RegExp(path.sep + '$'), ''); + var isAbsolute = (path.resolve(source) === sourcePath); + dest = path.resolve(process.cwd(), String(dest)); + + if (fs.existsSync(dest)) { + if (!options.force) { + common.error('Destination file exists', { continue: true }); + } + + fs.unlinkSync(dest); + } + + if (options.symlink) { + var isWindows = process.platform === 'win32'; + var linkType = isWindows ? 'file' : null; + var resolvedSourcePath = isAbsolute ? sourcePath : path.resolve(process.cwd(), path.dirname(dest), source); + if (!fs.existsSync(resolvedSourcePath)) { + common.error('Source file does not exist', { continue: true }); + } else if (isWindows && common.statFollowLinks(resolvedSourcePath).isDirectory()) { + linkType = 'junction'; + } -Object.defineProperty(exports, "__esModule", ({ value: true })); -exports.serializeJson = exports.parseJson = exports.stripJsonComments = void 0; -const jsonc_parser_1 = __nccwpck_require__(56416); -Object.defineProperty(exports, "stripJsonComments", ({ enumerable: true, get: function () { return jsonc_parser_1.stripComments; } })); -const lines_and_columns_1 = __nccwpck_require__(74570); -const code_frames_1 = __nccwpck_require__(73133); -/** - * Parses the given JSON string and returns the object the JSON content represents. - * By default javascript-style comments and trailing commas are allowed. - * - * @param input JSON content as string - * @param options JSON parse options - * @returns Object the JSON content represents - */ -function parseJson(input, options) { try { - return JSON.parse(input); + fs.symlinkSync(linkType === 'junction' ? resolvedSourcePath : source, dest, linkType); + } catch (err) { + common.error(err.message); } - catch (_a) { } - options = Object.assign({ allowTrailingComma: true }, options); - const errors = []; - const result = (0, jsonc_parser_1.parse)(input, errors, options); - if (errors.length > 0) { - throw new Error(formatParseError(input, errors[0])); + } else { + if (!fs.existsSync(source)) { + common.error('Source file does not exist', { continue: true }); } - return result; -} -exports.parseJson = parseJson; -/** - * Nicely formats a JSON error with context - * - * @param input JSON content as string - * @param parseError jsonc ParseError - * @returns - */ -function formatParseError(input, parseError) { - const { error, offset, length } = parseError; - let { line, column } = new lines_and_columns_1.LinesAndColumns(input).locationForIndex(offset); - line++; - column++; - return (`${(0, jsonc_parser_1.printParseErrorCode)(error)} in JSON at ${line}:${column}\n` + - (0, code_frames_1.codeFrameColumns)(input, { - start: { line, column }, - end: { line, column: column + length }, - }) + - '\n'); -} -/** - * Serializes the given data to a JSON string. - * By default the JSON string is formatted with a 2 space indentation to be easy readable. - * - * @param input Object which should be serialized to JSON - * @param options JSON serialize options - * @returns the formatted JSON representation of the object - */ -function serializeJson(input, options) { - var _a; - return JSON.stringify(input, null, (_a = options === null || options === void 0 ? void 0 : options.spaces) !== null && _a !== void 0 ? _a : 2) + '\n'; + try { + fs.linkSync(source, dest); + } catch (err) { + common.error(err.message); + } + } + return ''; } -exports.serializeJson = serializeJson; +module.exports = _ln; /***/ }), -/***/ 95324: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { +/***/ 42248: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { -"use strict"; +var path = __nccwpck_require__(71017); +var fs = __nccwpck_require__(57147); +var common = __nccwpck_require__(60624); +var glob = __nccwpck_require__(69959); -Object.defineProperty(exports, "__esModule", ({ value: true })); -exports.stripIndent = exports.logger = exports.NX_ERROR = exports.NX_PREFIX = void 0; -const chalk = __nccwpck_require__(29541); -exports.NX_PREFIX = `${chalk.cyan('>')} ${chalk.inverse(chalk.bold(chalk.cyan(' NX ')))}`; -exports.NX_ERROR = chalk.inverse(chalk.bold(chalk.red(' ERROR '))); -exports.logger = { - warn: (s) => console.warn(chalk.bold(chalk.yellow(s))), - error: (s) => { - if (typeof s === 'string' && s.startsWith('NX ')) { - console.error(`\n${exports.NX_ERROR} ${chalk.bold(chalk.red(s.slice(3)))}\n`); - } - else if (s instanceof Error && s.stack) { - console.error(chalk.bold(chalk.red(s.stack))); - } - else { - console.error(chalk.bold(chalk.red(s))); - } - }, - info: (s) => { - if (typeof s === 'string' && s.startsWith('NX ')) { - console.info(`\n${exports.NX_PREFIX} ${chalk.bold(s.slice(3))}\n`); - } - else { - console.info(s); - } - }, - log: (...s) => { - console.log(...s); - }, - debug: (...s) => { - console.debug(...s); - }, - fatal: (...s) => { - console.error(...s); - }, -}; -function stripIndent(str) { - const match = str.match(/^[ \t]*(?=\S)/gm); - if (!match) { - return str; - } - const indent = match.reduce((r, a) => Math.min(r, a.length), Infinity); - const regex = new RegExp(`^[ \\t]{${indent}}`, 'gm'); - return str.replace(regex, ''); -} -exports.stripIndent = stripIndent; +var globPatternRecursive = path.sep + '**'; +common.register('ls', _ls, { + cmdOptions: { + 'R': 'recursive', + 'A': 'all', + 'L': 'link', + 'a': 'all_deprecated', + 'd': 'directory', + 'l': 'long', + }, +}); -/***/ }), +//@ +//@ ### ls([options,] [path, ...]) +//@ ### ls([options,] path_array) +//@ +//@ Available options: +//@ +//@ + `-R`: recursive +//@ + `-A`: all files (include files beginning with `.`, except for `.` and `..`) +//@ + `-L`: follow symlinks +//@ + `-d`: list directories themselves, not their contents +//@ + `-l`: list objects representing each file, each with fields containing `ls +//@ -l` output fields. See +//@ [`fs.Stats`](https://nodejs.org/api/fs.html#fs_class_fs_stats) +//@ for more info +//@ +//@ Examples: +//@ +//@ ```javascript +//@ ls('projs/*.js'); +//@ ls('-R', '/users/me', '/tmp'); +//@ ls('-R', ['/users/me', '/tmp']); // same as above +//@ ls('-l', 'file.txt'); // { name: 'file.txt', mode: 33188, nlink: 1, ...} +//@ ``` +//@ +//@ Returns array of files in the given `path`, or files in +//@ the current directory if no `path` is provided. +function _ls(options, paths) { + if (options.all_deprecated) { + // We won't support the -a option as it's hard to image why it's useful + // (it includes '.' and '..' in addition to '.*' files) + // For backwards compatibility we'll dump a deprecated message and proceed as before + common.log('ls: Option -a is deprecated. Use -A instead'); + options.all = true; + } -/***/ 86740: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { + if (!paths) { + paths = ['.']; + } else { + paths = [].slice.call(arguments, 1); + } -"use strict"; + var list = []; -Object.defineProperty(exports, "__esModule", ({ value: true })); -exports.registerPluginTSTranspiler = exports.resolveLocalNxPlugin = exports.readPluginPackageJson = exports.mergePluginTargetsWithNxTargets = exports.loadNxPlugins = exports.loadNxPluginsSync = exports.loadNxPluginAsync = void 0; -const tslib_1 = __nccwpck_require__(51796); -const fast_glob_1 = __nccwpck_require__(19131); -const fs_1 = __nccwpck_require__(57147); -const path = __nccwpck_require__(71017); -const workspaces_1 = __nccwpck_require__(98715); -const workspace_root_1 = __nccwpck_require__(65766); -const fileutils_1 = __nccwpck_require__(47930); -const package_json_1 = __nccwpck_require__(14482); -const register_1 = __nccwpck_require__(16354); -const logger_1 = __nccwpck_require__(95324); -const find_project_for_path_1 = __nccwpck_require__(36265); -const path_1 = __nccwpck_require__(75878); -const path_2 = __nccwpck_require__(71017); -const installation_directory_1 = __nccwpck_require__(35075); -const typescript_1 = __nccwpck_require__(62029); -// Short lived cache (cleared between cmd runs) -// holding resolved nx plugin objects. -// Allows loadNxPlugins to be called multiple times w/o -// executing resolution mulitple times. -let nxPluginCache = new Map(); -function getPluginPathAndName(moduleName, paths, root) { - let pluginPath; - try { - pluginPath = require.resolve(moduleName, { - paths, - }); - } - catch (e) { - if (e.code === 'MODULE_NOT_FOUND') { - const plugin = resolveLocalNxPlugin(moduleName, root); - if (plugin) { - const main = readPluginMainFromProjectConfiguration(plugin.projectConfig); - pluginPath = main ? path.join(root, main) : plugin.path; - } - else { - logger_1.logger.error(`Plugin listed in \`nx.json\` not found: ${moduleName}`); - throw e; - } - } - else { - throw e; - } + function pushFile(abs, relName, stat) { + if (process.platform === 'win32') { + relName = relName.replace(/\\/g, '/'); } - const packageJsonPath = path.join(pluginPath, 'package.json'); - const { name } = !['.ts', '.js'].some((x) => x === path.extname(pluginPath)) && // Not trying to point to a ts or js file - (0, fs_1.existsSync)(packageJsonPath) // plugin has a package.json - ? (0, fileutils_1.readJsonFile)(packageJsonPath) // read name from package.json - : { name: moduleName }; - return { pluginPath, name }; -} -function loadNxPluginAsync(moduleName, paths, root) { - return tslib_1.__awaiter(this, void 0, void 0, function* () { - let pluginModule = nxPluginCache.get(moduleName); - if (pluginModule) { - return pluginModule; - } - let { pluginPath, name } = getPluginPathAndName(moduleName, paths, root); - const plugin = (yield Promise.resolve(`${pluginPath}`).then(s => require(s))); - plugin.name = name; - nxPluginCache.set(moduleName, plugin); - return plugin; - }); -} -exports.loadNxPluginAsync = loadNxPluginAsync; -function loadNxPluginSync(moduleName, paths, root) { - let pluginModule = nxPluginCache.get(moduleName); - if (pluginModule) { - return pluginModule; + if (options.long) { + stat = stat || (options.link ? common.statFollowLinks(abs) : common.statNoFollowLinks(abs)); + list.push(addLsAttributes(relName, stat)); + } else { + // list.push(path.relative(rel || '.', file)); + list.push(relName); } - let { pluginPath, name } = getPluginPathAndName(moduleName, paths, root); - const plugin = require(pluginPath); - plugin.name = name; - nxPluginCache.set(moduleName, plugin); - return plugin; -} -/** - * @deprecated Use loadNxPlugins instead. - */ -function loadNxPluginsSync(plugins, paths = (0, installation_directory_1.getNxRequirePaths)(), root = workspace_root_1.workspaceRoot) { - const result = []; - // TODO: This should be specified in nx.json - // Temporarily load js as if it were a plugin which is built into nx - // In the future, this will be optional and need to be specified in nx.json - const jsPlugin = __nccwpck_require__(71777); - jsPlugin.name = 'nx-js-graph-plugin'; - result.push(jsPlugin); - plugins !== null && plugins !== void 0 ? plugins : (plugins = []); - for (const plugin of plugins) { + } + + paths.forEach(function (p) { + var stat; + + try { + stat = options.link ? common.statFollowLinks(p) : common.statNoFollowLinks(p); + // follow links to directories by default + if (stat.isSymbolicLink()) { + /* istanbul ignore next */ + // workaround for https://github.com/shelljs/shelljs/issues/795 + // codecov seems to have a bug that miscalculate this block as uncovered. + // but according to nyc report this block does get covered. try { - result.push(loadNxPluginSync(plugin, paths, root)); - } - catch (e) { - if (e.code === 'ERR_REQUIRE_ESM') { - throw new Error(`Unable to load "${plugin}". Plugins cannot be ESM modules. They must be CommonJS modules. Follow the issue on github: https://github.com/nrwl/nx/issues/15682`); + var _stat = common.statFollowLinks(p); + if (_stat.isDirectory()) { + stat = _stat; + } + } catch (_) {} // bad symlink, treat it like a file + } + } catch (e) { + common.error('no such file or directory: ' + p, 2, { continue: true }); + return; + } + + // If the stat succeeded + if (stat.isDirectory() && !options.directory) { + if (options.recursive) { + // use glob, because it's simple + glob.sync(p + globPatternRecursive, { dot: options.all, follow: options.link }) + .forEach(function (item) { + // Glob pattern returns the directory itself and needs to be filtered out. + if (path.relative(p, item)) { + pushFile(item, path.relative(p, item)); } - throw e; - } + }); + } else if (options.all) { + // use fs.readdirSync, because it's fast + fs.readdirSync(p).forEach(function (item) { + pushFile(path.join(p, item), item); + }); + } else { + // use fs.readdirSync and then filter out secret files + fs.readdirSync(p).forEach(function (item) { + if (item[0] !== '.') { + pushFile(path.join(p, item), item); + } + }); + } + } else { + pushFile(p, p, stat); } - return result; + }); + + // Add methods, to make this more compatible with ShellStrings + return list; } -exports.loadNxPluginsSync = loadNxPluginsSync; -function loadNxPlugins(plugins, paths = (0, installation_directory_1.getNxRequirePaths)(), root = workspace_root_1.workspaceRoot) { - return tslib_1.__awaiter(this, void 0, void 0, function* () { - const result = []; - // TODO: This should be specified in nx.json - // Temporarily load js as if it were a plugin which is built into nx - // In the future, this will be optional and need to be specified in nx.json - const jsPlugin = yield Promise.resolve().then(() => __nccwpck_require__(71777)); - jsPlugin.name = 'nx-js-graph-plugin'; - result.push(jsPlugin); - plugins !== null && plugins !== void 0 ? plugins : (plugins = []); - for (const plugin of plugins) { - result.push(yield loadNxPluginAsync(plugin, paths, root)); - } - return result; - }); + +function addLsAttributes(pathName, stats) { + // Note: this object will contain more information than .toString() returns + stats.name = pathName; + stats.toString = function () { + // Return a string resembling unix's `ls -l` format + return [this.mode, this.nlink, this.uid, this.gid, this.size, this.mtime, this.name].join(' '); + }; + return stats; } -exports.loadNxPlugins = loadNxPlugins; -function mergePluginTargetsWithNxTargets(projectRoot, targets, plugins) { - var _a; - let newTargets = {}; - for (const plugin of plugins) { - if (!((_a = plugin.projectFilePatterns) === null || _a === void 0 ? void 0 : _a.length) || !plugin.registerProjectTargets) { - continue; - } - const projectFiles = (0, fast_glob_1.sync)(`+(${plugin.projectFilePatterns.join('|')})`, { - cwd: path.join(workspace_root_1.workspaceRoot, projectRoot), - }); - for (const projectFile of projectFiles) { - newTargets = Object.assign(Object.assign({}, newTargets), plugin.registerProjectTargets(path.join(projectRoot, projectFile))); - } - } - return Object.assign(Object.assign({}, newTargets), targets); + +module.exports = _ls; + + +/***/ }), + +/***/ 27707: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + +var common = __nccwpck_require__(60624); +var fs = __nccwpck_require__(57147); +var path = __nccwpck_require__(71017); + +common.register('mkdir', _mkdir, { + cmdOptions: { + 'p': 'fullpath', + }, +}); + +// Recursively creates `dir` +function mkdirSyncRecursive(dir) { + var baseDir = path.dirname(dir); + + // Prevents some potential problems arising from malformed UNCs or + // insufficient permissions. + /* istanbul ignore next */ + if (baseDir === dir) { + common.error('dirname() failed: [' + dir + ']'); + } + + // Base dir exists, no recursion necessary + if (fs.existsSync(baseDir)) { + fs.mkdirSync(dir, parseInt('0777', 8)); + return; + } + + // Base dir does not exist, go recursive + mkdirSyncRecursive(baseDir); + + // Base dir created, can create dir + fs.mkdirSync(dir, parseInt('0777', 8)); } -exports.mergePluginTargetsWithNxTargets = mergePluginTargetsWithNxTargets; -function readPluginPackageJson(pluginName, paths = (0, installation_directory_1.getNxRequirePaths)()) { + +//@ +//@ ### mkdir([options,] dir [, dir ...]) +//@ ### mkdir([options,] dir_array) +//@ +//@ Available options: +//@ +//@ + `-p`: full path (and create intermediate directories, if necessary) +//@ +//@ Examples: +//@ +//@ ```javascript +//@ mkdir('-p', '/tmp/a/b/c/d', '/tmp/e/f/g'); +//@ mkdir('-p', ['/tmp/a/b/c/d', '/tmp/e/f/g']); // same as above +//@ ``` +//@ +//@ Creates directories. +function _mkdir(options, dirs) { + if (!dirs) common.error('no paths given'); + + if (typeof dirs === 'string') { + dirs = [].slice.call(arguments, 1); + } + // if it's array leave it as it is + + dirs.forEach(function (dir) { try { - const result = (0, package_json_1.readModulePackageJsonWithoutFallbacks)(pluginName, paths); - return { - json: result.packageJson, - path: result.path, - }; + var stat = common.statNoFollowLinks(dir); + if (!options.fullpath) { + common.error('path already exists: ' + dir, { continue: true }); + } else if (stat.isFile()) { + common.error('cannot create directory ' + dir + ': File exists', { continue: true }); + } + return; // skip dir + } catch (e) { + // do nothing } - catch (e) { - if (e.code === 'MODULE_NOT_FOUND') { - const localPluginPath = resolveLocalNxPlugin(pluginName); - if (localPluginPath) { - const localPluginPackageJson = path.join(localPluginPath.path, 'package.json'); - return { - path: localPluginPackageJson, - json: (0, fileutils_1.readJsonFile)(localPluginPackageJson), - }; - } - } + + // Base dir does not exist, and no -p option given + var baseDir = path.dirname(dir); + if (!fs.existsSync(baseDir) && !options.fullpath) { + common.error('no such file or directory: ' + baseDir, { continue: true }); + return; // skip dir + } + + try { + if (options.fullpath) { + mkdirSyncRecursive(path.resolve(dir)); + } else { + fs.mkdirSync(dir, parseInt('0777', 8)); + } + } catch (e) { + var reason; + if (e.code === 'EACCES') { + reason = 'Permission denied'; + } else if (e.code === 'ENOTDIR' || e.code === 'ENOENT') { + reason = 'Not a directory'; + } else { + /* istanbul ignore next */ throw e; + } + common.error('cannot create directory ' + dir + ': ' + reason, { continue: true }); } + }); + return ''; +} // mkdir +module.exports = _mkdir; + + +/***/ }), + +/***/ 78146: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + +var fs = __nccwpck_require__(57147); +var path = __nccwpck_require__(71017); +var common = __nccwpck_require__(60624); +var cp = __nccwpck_require__(64395); +var rm = __nccwpck_require__(54369); + +common.register('mv', _mv, { + cmdOptions: { + 'f': '!no_force', + 'n': 'no_force', + }, +}); + +// Checks if cureent file was created recently +function checkRecentCreated(sources, index) { + var lookedSource = sources[index]; + return sources.slice(0, index).some(function (src) { + return path.basename(src) === path.basename(lookedSource); + }); } -exports.readPluginPackageJson = readPluginPackageJson; -/** - * Builds a plugin package and returns the path to output - * @param importPath What is the import path that refers to a potential plugin? - * @returns The path to the built plugin, or null if it doesn't exist - */ -const localPluginCache = {}; -function resolveLocalNxPlugin(importPath, root = workspace_root_1.workspaceRoot) { - var _a; - (_a = localPluginCache[importPath]) !== null && _a !== void 0 ? _a : (localPluginCache[importPath] = lookupLocalPlugin(importPath, root)); - return localPluginCache[importPath]; -} -exports.resolveLocalNxPlugin = resolveLocalNxPlugin; -let tsNodeAndPathsRegistered = false; -/** - * Register swc-node or ts-node if they are not currently registered - * with some default settings which work well for Nx plugins. - */ -function registerPluginTSTranspiler() { - if (!tsNodeAndPathsRegistered) { - // nx-ignore-next-line - const ts = __nccwpck_require__(70048); - // Get the first tsconfig that matches the allowed set - const tsConfigName = [ - (0, path_2.join)(workspace_root_1.workspaceRoot, 'tsconfig.base.json'), - (0, path_2.join)(workspace_root_1.workspaceRoot, 'tsconfig.json'), - ].find((x) => (0, fs_1.existsSync)(x)); - const tsConfig = tsConfigName - ? (0, typescript_1.readTsConfig)(tsConfigName) - : {}; - (0, register_1.registerTsConfigPaths)(tsConfigName); - (0, register_1.registerTranspiler)(Object.assign(Object.assign({ experimentalDecorators: true, emitDecoratorMetadata: true }, tsConfig.options), { lib: ['es2021'], module: ts.ModuleKind.CommonJS, target: ts.ScriptTarget.ES2021, inlineSourceMap: true, skipLibCheck: true })); + +//@ +//@ ### mv([options ,] source [, source ...], dest') +//@ ### mv([options ,] source_array, dest') +//@ +//@ Available options: +//@ +//@ + `-f`: force (default behavior) +//@ + `-n`: no-clobber +//@ +//@ Examples: +//@ +//@ ```javascript +//@ mv('-n', 'file', 'dir/'); +//@ mv('file1', 'file2', 'dir/'); +//@ mv(['file1', 'file2'], 'dir/'); // same as above +//@ ``` +//@ +//@ Moves `source` file(s) to `dest`. +function _mv(options, sources, dest) { + // Get sources, dest + if (arguments.length < 3) { + common.error('missing and/or '); + } else if (arguments.length > 3) { + sources = [].slice.call(arguments, 1, arguments.length - 1); + dest = arguments[arguments.length - 1]; + } else if (typeof sources === 'string') { + sources = [sources]; + } else { + // TODO(nate): figure out if we actually need this line + common.error('invalid arguments'); + } + + var exists = fs.existsSync(dest); + var stats = exists && common.statFollowLinks(dest); + + // Dest is not existing dir, but multiple sources given + if ((!exists || !stats.isDirectory()) && sources.length > 1) { + common.error('dest is not a directory (too many sources)'); + } + + // Dest is an existing file, but no -f given + if (exists && stats.isFile() && options.no_force) { + common.error('dest file already exists: ' + dest); + } + + sources.forEach(function (src, srcIndex) { + if (!fs.existsSync(src)) { + common.error('no such file or directory: ' + src, { continue: true }); + return; // skip file } - tsNodeAndPathsRegistered = true; -} -exports.registerPluginTSTranspiler = registerPluginTSTranspiler; -function lookupLocalPlugin(importPath, root = workspace_root_1.workspaceRoot) { - const workspace = new workspaces_1.Workspaces(root).readProjectsConfigurations({ - _ignorePluginInference: true, - }); - const plugin = findNxProjectForImportPath(importPath, workspace, root); - if (!plugin) { - return null; + + // If here, src exists + + // When copying to '/path/dir': + // thisDest = '/path/dir/file1' + var thisDest = dest; + if (fs.existsSync(dest) && common.statFollowLinks(dest).isDirectory()) { + thisDest = path.normalize(dest + '/' + path.basename(src)); } - if (!tsNodeAndPathsRegistered) { - registerPluginTSTranspiler(); + + var thisDestExists = fs.existsSync(thisDest); + + if (thisDestExists && checkRecentCreated(sources, srcIndex)) { + // cannot overwrite file created recently in current execution, but we want to continue copying other files + if (!options.no_force) { + common.error("will not overwrite just-created '" + thisDest + "' with '" + src + "'", { continue: true }); + } + return; } - const projectConfig = workspace.projects[plugin]; - return { path: path.join(root, projectConfig.root), projectConfig }; -} -function findNxProjectForImportPath(importPath, projects, root = workspace_root_1.workspaceRoot) { - var _a; - const tsConfigPaths = readTsConfigPaths(root); - const possiblePaths = (_a = tsConfigPaths[importPath]) === null || _a === void 0 ? void 0 : _a.map((p) => (0, path_1.normalizePath)(path.relative(root, path.join(root, p)))); - if (possiblePaths === null || possiblePaths === void 0 ? void 0 : possiblePaths.length) { - const projectRootMappings = (0, find_project_for_path_1.createProjectRootMappingsFromProjectConfigurations)(projects.projects); - for (const tsConfigPath of possiblePaths) { - const nxProject = (0, find_project_for_path_1.findProjectForPath)(tsConfigPath, projectRootMappings); - if (nxProject) { - return nxProject; - } - } - if (process.env.NX_VERBOSE_LOGGING) { - console.log('Unable to find local plugin', possiblePaths, projectRootMappings); - } - throw new Error('Unable to resolve local plugin with import path ' + importPath); + + if (fs.existsSync(thisDest) && options.no_force) { + common.error('dest file already exists: ' + thisDest, { continue: true }); + return; // skip file } -} -let tsconfigPaths; -function readTsConfigPaths(root = workspace_root_1.workspaceRoot) { - if (!tsconfigPaths) { - const tsconfigPath = ['tsconfig.base.json', 'tsconfig.json'] - .map((x) => path.join(root, x)) - .filter((x) => (0, fs_1.existsSync)(x))[0]; - if (!tsconfigPath) { - throw new Error('unable to find tsconfig.base.json or tsconfig.json'); - } - const { compilerOptions } = (0, fileutils_1.readJsonFile)(tsconfigPath); - tsconfigPaths = compilerOptions === null || compilerOptions === void 0 ? void 0 : compilerOptions.paths; + + if (path.resolve(src) === path.dirname(path.resolve(thisDest))) { + common.error('cannot move to self: ' + src, { continue: true }); + return; // skip file } - return tsconfigPaths !== null && tsconfigPaths !== void 0 ? tsconfigPaths : {}; -} -function readPluginMainFromProjectConfiguration(plugin) { - var _a, _b, _c; - const { main } = ((_a = Object.values(plugin.targets).find((x) => [ - '@nx/js:tsc', - '@nrwl/js:tsc', - '@nx/js:swc', - '@nrwl/js:swc', - '@nx/node:package', - '@nrwl/node:package', - ].includes(x.executor))) === null || _a === void 0 ? void 0 : _a.options) || - ((_c = (_b = plugin.targets) === null || _b === void 0 ? void 0 : _b.build) === null || _c === void 0 ? void 0 : _c.options) || - {}; - return main; -} + + try { + fs.renameSync(src, thisDest); + } catch (e) { + /* istanbul ignore next */ + if (e.code === 'EXDEV') { + // If we're trying to `mv` to an external partition, we'll actually need + // to perform a copy and then clean up the original file. If either the + // copy or the rm fails with an exception, we should allow this + // exception to pass up to the top level. + cp('-r', src, thisDest); + rm('-rf', src); + } + } + }); // forEach(src) + return ''; +} // mv +module.exports = _mv; /***/ }), -/***/ 95961: -/***/ ((__unused_webpack_module, exports) => { +/***/ 12425: +/***/ (() => { -"use strict"; +// see dirs.js -Object.defineProperty(exports, "__esModule", ({ value: true })); -exports.sortObjectByKeys = void 0; -function sortObjectByKeys(originalObject) { - const keys = Object.keys(originalObject).sort(); - const sortedObject = {}; - keys.forEach((key) => (sortedObject[key] = originalObject[key])); - return sortedObject; -} -exports.sortObjectByKeys = sortObjectByKeys; + +/***/ }), + +/***/ 68943: +/***/ (() => { + +// see dirs.js /***/ }), -/***/ 34548: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { +/***/ 90909: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { -"use strict"; +var path = __nccwpck_require__(71017); +var common = __nccwpck_require__(60624); -Object.defineProperty(exports, "__esModule", ({ value: true })); -exports.output = void 0; -const chalk = __nccwpck_require__(29541); -const os_1 = __nccwpck_require__(22037); -const is_ci_1 = __nccwpck_require__(28839); -/** - * Automatically disable styling applied by chalk if CI=true - */ -const forceColor = process.env.FORCE_COLOR === '' || process.env.FORCE_COLOR === 'true'; -if ((0, is_ci_1.isCI)() && !forceColor) { - chalk.level = 0; +common.register('pwd', _pwd, { + allowGlobbing: false, +}); + +//@ +//@ ### pwd() +//@ +//@ Returns the current directory. +function _pwd() { + var pwd = path.resolve(process.cwd()); + return pwd; } -class CLIOutput { - constructor() { - this.X_PADDING = ' '; - this.cliName = 'NX'; - this.formatCommand = (taskId) => `${chalk.dim('nx run')} ${taskId}`; - /** - * Expose some color and other utility functions so that other parts of the codebase that need - * more fine-grained control of message bodies are still using a centralized - * implementation. - */ - this.colors = { - gray: chalk.gray, - green: chalk.green, - red: chalk.red, - cyan: chalk.cyan, - white: chalk.white, - }; - this.bold = chalk.bold; - this.underline = chalk.underline; - this.dim = chalk.dim; - } - /** - * Longer dash character which forms more of a continuous line when place side to side - * with itself, unlike the standard dash character - */ - get VERTICAL_SEPARATOR() { - let divider = ''; - for (let i = 0; i < process.stdout.columns - this.X_PADDING.length * 2; i++) { - divider += '\u2014'; - } - return divider; - } - writeToStdOut(str) { - process.stdout.write(str); - } - writeOutputTitle({ color, title, }) { - this.writeToStdOut(` ${this.applyNxPrefix(color, title)}${os_1.EOL}`); - } - writeOptionalOutputBody(bodyLines) { - if (!bodyLines) { - return; - } - this.addNewline(); - bodyLines.forEach((bodyLine) => this.writeToStdOut(` ${bodyLine}${os_1.EOL}`)); - } - applyNxPrefix(color = 'cyan', text) { - let nxPrefix = ''; - if (chalk[color]) { - nxPrefix = `${chalk[color]('>')} ${chalk.reset.inverse.bold[color](` ${this.cliName} `)}`; - } - else { - nxPrefix = `${chalk.keyword(color)('>')} ${chalk.reset.inverse.bold.keyword(color)(` ${this.cliName} `)}`; - } - return `${nxPrefix} ${text}`; - } - addNewline() { - this.writeToStdOut(os_1.EOL); - } - addVerticalSeparator(color = 'gray') { - this.addNewline(); - this.addVerticalSeparatorWithoutNewLines(color); - this.addNewline(); - } - addVerticalSeparatorWithoutNewLines(color = 'gray') { - this.writeToStdOut(`${this.X_PADDING}${chalk.dim[color](this.VERTICAL_SEPARATOR)}${os_1.EOL}`); - } - error({ title, slug, bodyLines }) { - this.addNewline(); - this.writeOutputTitle({ - color: 'red', - title: chalk.red(title), - }); - this.writeOptionalOutputBody(bodyLines); - /** - * Optional slug to be used in an Nx error message redirect URL - */ - if (slug && typeof slug === 'string') { - this.addNewline(); - this.writeToStdOut(`${chalk.grey(' Learn more about this error: ')}https://errors.nx.dev/${slug}${os_1.EOL}`); - } - this.addNewline(); - } - warn({ title, slug, bodyLines }) { - this.addNewline(); - this.writeOutputTitle({ - color: 'yellow', - title: chalk.yellow(title), - }); - this.writeOptionalOutputBody(bodyLines); - /** - * Optional slug to be used in an Nx warning message redirect URL - */ - if (slug && typeof slug === 'string') { - this.addNewline(); - this.writeToStdOut(`${chalk.grey(' Learn more about this warning: ')}https://errors.nx.dev/${slug}\n`); - } - this.addNewline(); - } - note({ title, bodyLines }) { - this.addNewline(); - this.writeOutputTitle({ - color: 'orange', - title: chalk.keyword('orange')(title), - }); - this.writeOptionalOutputBody(bodyLines); - this.addNewline(); - } - success({ title, bodyLines }) { - this.addNewline(); - this.writeOutputTitle({ - color: 'green', - title: chalk.green(title), - }); - this.writeOptionalOutputBody(bodyLines); - this.addNewline(); - } - logSingleLine(message) { - this.addNewline(); - this.writeOutputTitle({ - color: 'gray', - title: message, - }); - this.addNewline(); - } - logCommand(message, taskStatus) { - this.addNewline(); - const commandOutput = chalk.dim('> ') + this.formatCommand(this.normalizeMessage(message)); - const commandOutputWithStatus = this.addTaskStatus(taskStatus, commandOutput); - this.writeToStdOut(commandOutputWithStatus); - this.addNewline(); - } - normalizeMessage(message) { - if (message.startsWith('nx run ')) { - return message.substring('nx run '.length); - } - else if (message.startsWith('run ')) { - return message.substring('run '.length); - } - else { - return message; +module.exports = _pwd; + + +/***/ }), + +/***/ 54369: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + +var common = __nccwpck_require__(60624); +var fs = __nccwpck_require__(57147); + +common.register('rm', _rm, { + cmdOptions: { + 'f': 'force', + 'r': 'recursive', + 'R': 'recursive', + }, +}); + +// Recursively removes 'dir' +// Adapted from https://github.com/ryanmcgrath/wrench-js +// +// Copyright (c) 2010 Ryan McGrath +// Copyright (c) 2012 Artur Adib +// +// Licensed under the MIT License +// http://www.opensource.org/licenses/mit-license.php +function rmdirSyncRecursive(dir, force, fromSymlink) { + var files; + + files = fs.readdirSync(dir); + + // Loop through and delete everything in the sub-tree after checking it + for (var i = 0; i < files.length; i++) { + var file = dir + '/' + files[i]; + var currFile = common.statNoFollowLinks(file); + + if (currFile.isDirectory()) { // Recursive function back to the beginning + rmdirSyncRecursive(file, force); + } else { // Assume it's a file - perhaps a try/catch belongs here? + if (force || isWriteable(file)) { + try { + common.unlinkSync(file); + } catch (e) { + /* istanbul ignore next */ + common.error('could not remove file (code ' + e.code + '): ' + file, { + continue: true, + }); } + } } - addTaskStatus(taskStatus, commandOutput) { - if (taskStatus === 'local-cache') { - return `${commandOutput} ${chalk.dim('[local cache]')}`; - } - else if (taskStatus === 'remote-cache') { - return `${commandOutput} ${chalk.dim('[remote cache]')}`; - } - else if (taskStatus === 'local-cache-kept-existing') { - return `${commandOutput} ${chalk.dim('[existing outputs match the cache, left as is]')}`; - } - else { - return commandOutput; + } + + // if was directory was referenced through a symbolic link, + // the contents should be removed, but not the directory itself + if (fromSymlink) return; + + // Now that we know everything in the sub-tree has been deleted, we can delete the main directory. + // Huzzah for the shopkeep. + + var result; + try { + // Retry on windows, sometimes it takes a little time before all the files in the directory are gone + var start = Date.now(); + + // TODO: replace this with a finite loop + for (;;) { + try { + result = fs.rmdirSync(dir); + if (fs.existsSync(dir)) throw { code: 'EAGAIN' }; + break; + } catch (er) { + /* istanbul ignore next */ + // In addition to error codes, also check if the directory still exists and loop again if true + if (process.platform === 'win32' && (er.code === 'ENOTEMPTY' || er.code === 'EBUSY' || er.code === 'EPERM' || er.code === 'EAGAIN')) { + if (Date.now() - start > 1000) throw er; + } else if (er.code === 'ENOENT') { + // Directory did not exist, deletion was successful + break; + } else { + throw er; } + } } - log({ title, bodyLines, color }) { - this.addNewline(); - this.writeOutputTitle({ - color: 'cyan', - title: color ? chalk[color](title) : title, - }); - this.writeOptionalOutputBody(bodyLines); - this.addNewline(); - } - drain() { - return new Promise((resolve) => { - if (process.stdout.writableNeedDrain) { - process.stdout.once('drain', resolve); - } - else { - resolve(); - } - }); - } -} -exports.output = new CLIOutput(); - + } catch (e) { + common.error('could not remove directory (code ' + e.code + '): ' + dir, { continue: true }); + } -/***/ }), + return result; +} // rmdirSyncRecursive -/***/ 14482: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { +// Hack to determine if file has write permissions for current user +// Avoids having to check user, group, etc, but it's probably slow +function isWriteable(file) { + var writePermission = true; + try { + var __fd = fs.openSync(file, 'a'); + fs.closeSync(__fd); + } catch (e) { + writePermission = false; + } -"use strict"; + return writePermission; +} -Object.defineProperty(exports, "__esModule", ({ value: true })); -exports.readModulePackageJson = exports.readModulePackageJsonWithoutFallbacks = exports.buildTargetFromScript = exports.readNxMigrateConfig = exports.normalizePackageGroup = void 0; -const fs_1 = __nccwpck_require__(57147); -const path_1 = __nccwpck_require__(71017); -const fileutils_1 = __nccwpck_require__(47930); -const installation_directory_1 = __nccwpck_require__(35075); -function normalizePackageGroup(packageGroup) { - return Array.isArray(packageGroup) - ? packageGroup.map((x) => typeof x === 'string' ? { package: x, version: '*' } : x) - : Object.entries(packageGroup).map(([pkg, version]) => ({ - package: pkg, - version, - })); +function handleFile(file, options) { + if (options.force || isWriteable(file)) { + // -f was passed, or file is writable, so it can be removed + common.unlinkSync(file); + } else { + common.error('permission denied: ' + file, { continue: true }); + } } -exports.normalizePackageGroup = normalizePackageGroup; -function readNxMigrateConfig(json) { - const parseNxMigrationsConfig = (fromJson) => { - if (!fromJson) { - return {}; - } - if (typeof fromJson === 'string') { - return { migrations: fromJson, packageGroup: [] }; - } - return Object.assign(Object.assign({}, (fromJson.migrations ? { migrations: fromJson.migrations } : {})), (fromJson.packageGroup - ? { packageGroup: normalizePackageGroup(fromJson.packageGroup) } - : {})); - }; - return Object.assign(Object.assign(Object.assign({}, parseNxMigrationsConfig(json['ng-update'])), parseNxMigrationsConfig(json['nx-migrations'])), parseNxMigrationsConfig(json)); + +function handleDirectory(file, options) { + if (options.recursive) { + // -r was passed, so directory can be removed + rmdirSyncRecursive(file, options.force); + } else { + common.error('path is a directory', { continue: true }); + } } -exports.readNxMigrateConfig = readNxMigrateConfig; -function buildTargetFromScript(script, nx) { - var _a; - const nxTargetConfiguration = ((_a = nx === null || nx === void 0 ? void 0 : nx.targets) === null || _a === void 0 ? void 0 : _a[script]) || {}; - return Object.assign(Object.assign({}, nxTargetConfiguration), { executor: 'nx:run-script', options: Object.assign(Object.assign({}, (nxTargetConfiguration.options || {})), { script }) }); + +function handleSymbolicLink(file, options) { + var stats; + try { + stats = common.statFollowLinks(file); + } catch (e) { + // symlink is broken, so remove the symlink itself + common.unlinkSync(file); + return; + } + + if (stats.isFile()) { + common.unlinkSync(file); + } else if (stats.isDirectory()) { + if (file[file.length - 1] === '/') { + // trailing separator, so remove the contents, not the link + if (options.recursive) { + // -r was passed, so directory can be removed + var fromSymlink = true; + rmdirSyncRecursive(file, options.force, fromSymlink); + } else { + common.error('path is a directory', { continue: true }); + } + } else { + // no trailing separator, so remove the link + common.unlinkSync(file); + } + } } -exports.buildTargetFromScript = buildTargetFromScript; -/** - * Uses `require.resolve` to read the package.json for a module. - * - * This will fail if the module doesn't export package.json - * - * @returns package json contents and path - */ -function readModulePackageJsonWithoutFallbacks(moduleSpecifier, requirePaths = (0, installation_directory_1.getNxRequirePaths)()) { - const packageJsonPath = require.resolve(`${moduleSpecifier}/package.json`, { - paths: requirePaths, - }); - const packageJson = (0, fileutils_1.readJsonFile)(packageJsonPath); - return { - path: packageJsonPath, - packageJson, - }; + +function handleFIFO(file) { + common.unlinkSync(file); } -exports.readModulePackageJsonWithoutFallbacks = readModulePackageJsonWithoutFallbacks; -/** - * Reads the package.json file for a specified module. - * - * Includes a fallback that accounts for modules that don't export package.json - * - * @param {string} moduleSpecifier The module to look up - * @param {string[]} requirePaths List of paths look in. Pass `module.paths` to ensure non-hoisted dependencies are found. - * - * @example - * // Use the caller's lookup paths for non-hoisted dependencies - * readModulePackageJson('http-server', module.paths); - * - * @returns package json contents and path - */ -function readModulePackageJson(moduleSpecifier, requirePaths = (0, installation_directory_1.getNxRequirePaths)()) { - let packageJsonPath; - let packageJson; + +//@ +//@ ### rm([options,] file [, file ...]) +//@ ### rm([options,] file_array) +//@ +//@ Available options: +//@ +//@ + `-f`: force +//@ + `-r, -R`: recursive +//@ +//@ Examples: +//@ +//@ ```javascript +//@ rm('-rf', '/tmp/*'); +//@ rm('some_file.txt', 'another_file.txt'); +//@ rm(['some_file.txt', 'another_file.txt']); // same as above +//@ ``` +//@ +//@ Removes files. +function _rm(options, files) { + if (!files) common.error('no paths given'); + + // Convert to array + files = [].slice.call(arguments, 1); + + files.forEach(function (file) { + var lstats; try { - ({ path: packageJsonPath, packageJson } = - readModulePackageJsonWithoutFallbacks(moduleSpecifier, requirePaths)); + var filepath = (file[file.length - 1] === '/') + ? file.slice(0, -1) // remove the '/' so lstatSync can detect symlinks + : file; + lstats = common.statNoFollowLinks(filepath); // test for existence + } catch (e) { + // Path does not exist, no force flag given + if (!options.force) { + common.error('no such file or directory: ' + file, { continue: true }); + } + return; // skip file } - catch (_a) { - const entryPoint = require.resolve(moduleSpecifier, { - paths: requirePaths, - }); - let moduleRootPath = (0, path_1.dirname)(entryPoint); - packageJsonPath = (0, path_1.join)(moduleRootPath, 'package.json'); - while (!(0, fs_1.existsSync)(packageJsonPath)) { - moduleRootPath = (0, path_1.dirname)(moduleRootPath); - packageJsonPath = (0, path_1.join)(moduleRootPath, 'package.json'); - } - packageJson = (0, fileutils_1.readJsonFile)(packageJsonPath); - if (packageJson.name && packageJson.name !== moduleSpecifier) { - throw new Error(`Found module ${packageJson.name} while trying to locate ${moduleSpecifier}/package.json`); - } + + // If here, path exists + if (lstats.isFile()) { + handleFile(file, options); + } else if (lstats.isDirectory()) { + handleDirectory(file, options); + } else if (lstats.isSymbolicLink()) { + handleSymbolicLink(file, options); + } else if (lstats.isFIFO()) { + handleFIFO(file); } - return { - packageJson, - path: packageJsonPath, - }; -} -exports.readModulePackageJson = readModulePackageJson; + }); // forEach(file) + return ''; +} // rm +module.exports = _rm; /***/ }), -/***/ 15425: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { +/***/ 83401: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { -"use strict"; +var common = __nccwpck_require__(60624); +var fs = __nccwpck_require__(57147); -Object.defineProperty(exports, "__esModule", ({ value: true })); -exports.packageRegistryPack = exports.packageRegistryView = exports.resolvePackageVersionUsingInstallation = exports.resolvePackageVersionUsingRegistry = exports.createTempNpmDirectory = exports.copyPackageManagerConfigurationFiles = exports.modifyYarnRcToFitNewDirectory = exports.modifyYarnRcYmlToFitNewDirectory = exports.findFileInPackageJsonDirectory = exports.getPackageManagerVersion = exports.getPackageManagerCommand = exports.detectPackageManager = void 0; -const tslib_1 = __nccwpck_require__(51796); -const child_process_1 = __nccwpck_require__(32081); -const fs_1 = __nccwpck_require__(57147); -const fs_extra_1 = __nccwpck_require__(59511); -const path_1 = __nccwpck_require__(71017); -const tmp_1 = __nccwpck_require__(49503); -const util_1 = __nccwpck_require__(73837); -const fileutils_1 = __nccwpck_require__(47930); -const package_json_1 = __nccwpck_require__(14482); -const semver_1 = __nccwpck_require__(56192); -const workspace_root_1 = __nccwpck_require__(65766); -const configuration_1 = __nccwpck_require__(65459); -const execAsync = (0, util_1.promisify)(child_process_1.exec); -/** - * Detects which package manager is used in the workspace based on the lock file. - */ -function detectPackageManager(dir = '') { - var _a, _b; - const nxJson = (0, configuration_1.readNxJson)(); - return ((_b = (_a = nxJson.cli) === null || _a === void 0 ? void 0 : _a.packageManager) !== null && _b !== void 0 ? _b : ((0, fs_1.existsSync)((0, path_1.join)(dir, 'yarn.lock')) - ? 'yarn' - : (0, fs_1.existsSync)((0, path_1.join)(dir, 'pnpm-lock.yaml')) - ? 'pnpm' - : 'npm')); -} -exports.detectPackageManager = detectPackageManager; -/** - * Returns commands for the package manager used in the workspace. - * By default, the package manager is derived based on the lock file, - * but it can also be passed in explicitly. - * - * Example: - * - * ```javascript - * execSync(`${getPackageManagerCommand().addDev} my-dev-package`); - * ``` - * - * @param packageManager The package manager to use. If not provided, it will be detected based on the lock file. - * @param root The directory the commands will be ran inside of. Defaults to the current workspace's root. - */ -function getPackageManagerCommand(packageManager = detectPackageManager(), root = workspace_root_1.workspaceRoot) { - const commands = { - yarn: () => { - const yarnVersion = getPackageManagerVersion('yarn'); - const useBerry = (0, semver_1.gte)(yarnVersion, '2.0.0'); - return { - install: 'yarn', - ciInstall: useBerry - ? 'yarn install --immutable' - : 'yarn install --frozen-lockfile', - add: useBerry ? 'yarn add' : 'yarn add -W', - addDev: useBerry ? 'yarn add -D' : 'yarn add -D -W', - rm: 'yarn remove', - exec: useBerry ? 'yarn exec' : 'yarn', - run: (script, args) => `yarn ${script} ${args}`, - list: useBerry ? 'yarn info --name-only' : 'yarn list', - }; - }, - pnpm: () => { - const pnpmVersion = getPackageManagerVersion('pnpm'); - const useExec = (0, semver_1.gte)(pnpmVersion, '6.13.0'); - const includeDoubleDashBeforeArgs = (0, semver_1.lt)(pnpmVersion, '7.0.0'); - const isPnpmWorkspace = (0, fs_1.existsSync)((0, path_1.join)(root, 'pnpm-workspace.yaml')); - return { - install: 'pnpm install --no-frozen-lockfile', - ciInstall: 'pnpm install --frozen-lockfile', - add: isPnpmWorkspace ? 'pnpm add -w' : 'pnpm add', - addDev: isPnpmWorkspace ? 'pnpm add -Dw' : 'pnpm add -D', - rm: 'pnpm rm', - exec: useExec ? 'pnpm exec' : 'pnpx', - run: (script, args) => includeDoubleDashBeforeArgs - ? `pnpm run ${script} -- ${args}` - : `pnpm run ${script} ${args}`, - list: 'pnpm ls --depth 100', - }; - }, - npm: () => { - var _a; - var _b; - // TODO: Remove this - (_a = (_b = process.env).npm_config_legacy_peer_deps) !== null && _a !== void 0 ? _a : (_b.npm_config_legacy_peer_deps = 'true'); - return { - install: 'npm install', - ciInstall: 'npm ci', - add: 'npm install', - addDev: 'npm install -D', - rm: 'npm rm', - exec: 'npx', - run: (script, args) => `npm run ${script} -- ${args}`, - list: 'npm ls', - }; - }, - }; - return commands[packageManager](); -} -exports.getPackageManagerCommand = getPackageManagerCommand; -/** - * Returns the version of the package manager used in the workspace. - * By default, the package manager is derived based on the lock file, - * but it can also be passed in explicitly. - */ -function getPackageManagerVersion(packageManager = detectPackageManager()) { - return (0, child_process_1.execSync)(`${packageManager} --version`).toString('utf-8').trim(); -} -exports.getPackageManagerVersion = getPackageManagerVersion; -/** - * Checks for a project level npmrc file by crawling up the file tree until - * hitting a package.json file, as this is how npm finds them as well. - */ -function findFileInPackageJsonDirectory(file, directory = process.cwd()) { - while (!(0, fs_1.existsSync)((0, path_1.join)(directory, 'package.json'))) { - directory = (0, path_1.dirname)(directory); - } - const path = (0, path_1.join)(directory, file); - return (0, fs_1.existsSync)(path) ? path : null; -} -exports.findFileInPackageJsonDirectory = findFileInPackageJsonDirectory; -/** - * We copy yarnrc.yml to the temporary directory to ensure things like the specified - * package registry are still used. However, there are a few relative paths that can - * cause issues, so we modify them to fit the new directory. - * - * Exported for testing - not meant to be used outside of this file. - * - * @param contents The string contents of the yarnrc.yml file - * @returns Updated string contents of the yarnrc.yml file - */ -function modifyYarnRcYmlToFitNewDirectory(contents) { - const { parseSyml, stringifySyml } = __nccwpck_require__(98006); - const parsed = parseSyml(contents); - if (parsed.yarnPath) { - // yarnPath is relative to the workspace root, so we need to make it relative - // to the new directory s.t. it still points to the same yarn binary. - delete parsed.yarnPath; - } - if (parsed.plugins) { - // Plugins specified by a string are relative paths from workspace root. - // ex: https://yarnpkg.com/advanced/plugin-tutorial#writing-our-first-plugin - delete parsed.plugins; - } - return stringifySyml(parsed); -} -exports.modifyYarnRcYmlToFitNewDirectory = modifyYarnRcYmlToFitNewDirectory; -/** - * We copy .yarnrc to the temporary directory to ensure things like the specified - * package registry are still used. However, there are a few relative paths that can - * cause issues, so we modify them to fit the new directory. - * - * Exported for testing - not meant to be used outside of this file. - * - * @param contents The string contents of the yarnrc.yml file - * @returns Updated string contents of the yarnrc.yml file - */ -function modifyYarnRcToFitNewDirectory(contents) { - const lines = contents.split('\n'); - const yarnPathIndex = lines.findIndex((line) => line.startsWith('yarn-path')); - if (yarnPathIndex !== -1) { - lines.splice(yarnPathIndex, 1); - } - return lines.join('\n'); -} -exports.modifyYarnRcToFitNewDirectory = modifyYarnRcToFitNewDirectory; -function copyPackageManagerConfigurationFiles(root, destination) { - for (const packageManagerConfigFile of ['.npmrc', '.yarnrc', '.yarnrc.yml']) { - // f is an absolute path, including the {workspaceRoot}. - const f = findFileInPackageJsonDirectory(packageManagerConfigFile, root); - if (f) { - // Destination should be the same relative path from the {workspaceRoot}, - // but now relative to the destination. `relative` makes `{workspaceRoot}/some/path` - // look like `./some/path`, and joining that gets us `{destination}/some/path - const destinationPath = (0, path_1.join)(destination, (0, path_1.relative)(root, f)); - switch (packageManagerConfigFile) { - case '.npmrc': { - (0, fs_1.copyFileSync)(f, destinationPath); - break; - } - case '.yarnrc': { - const updated = modifyYarnRcToFitNewDirectory((0, fileutils_1.readFileIfExisting)(f)); - (0, fs_1.writeFileSync)(destinationPath, updated); - break; - } - case '.yarnrc.yml': { - const updated = modifyYarnRcYmlToFitNewDirectory((0, fileutils_1.readFileIfExisting)(f)); - (0, fs_1.writeFileSync)(destinationPath, updated); - break; - } - } - } - } -} -exports.copyPackageManagerConfigurationFiles = copyPackageManagerConfigurationFiles; -/** - * Creates a temporary directory where you can run package manager commands safely. - * - * For cases where you'd want to install packages that require an `.npmrc` set up, - * this function looks up for the nearest `.npmrc` (if exists) and copies it over to the - * temp directory. - */ -function createTempNpmDirectory() { - const dir = (0, tmp_1.dirSync)().name; - // A package.json is needed for pnpm pack and for .npmrc to resolve - (0, fileutils_1.writeJsonFile)(`${dir}/package.json`, {}); - copyPackageManagerConfigurationFiles(workspace_root_1.workspaceRoot, dir); - const cleanup = () => tslib_1.__awaiter(this, void 0, void 0, function* () { - try { - yield (0, fs_extra_1.remove)(dir); - } - catch (_a) { - // It's okay if this fails, the OS will clean it up eventually - } - }); - return { dir, cleanup }; -} -exports.createTempNpmDirectory = createTempNpmDirectory; -/** - * Returns the resolved version for a given package and version tag using the - * NPM registry (when using Yarn it will fall back to NPM to fetch the info). - */ -function resolvePackageVersionUsingRegistry(packageName, version) { - return tslib_1.__awaiter(this, void 0, void 0, function* () { - try { - const result = yield packageRegistryView(packageName, version, 'version'); - if (!result) { - throw new Error(`Unable to resolve version ${packageName}@${version}.`); - } - // get the last line of the output, strip the package version and quotes - const resolvedVersion = result - .split('\n') - .pop() - .split(' ') - .pop() - .replace(/'/g, ''); - return resolvedVersion; - } - catch (_a) { - throw new Error(`Unable to resolve version ${packageName}@${version}.`); - } - }); -} -exports.resolvePackageVersionUsingRegistry = resolvePackageVersionUsingRegistry; -/** - * Return the resolved version for a given package and version tag using by - * installing it in a temporary directory and fetching the version from the - * package.json. - */ -function resolvePackageVersionUsingInstallation(packageName, version) { - return tslib_1.__awaiter(this, void 0, void 0, function* () { - const { dir, cleanup } = createTempNpmDirectory(); - try { - const pmc = getPackageManagerCommand(); - yield execAsync(`${pmc.add} ${packageName}@${version}`, { cwd: dir }); - const { packageJson } = (0, package_json_1.readModulePackageJson)(packageName, [dir]); - return packageJson.version; - } - finally { - yield cleanup(); - } - }); -} -exports.resolvePackageVersionUsingInstallation = resolvePackageVersionUsingInstallation; -function packageRegistryView(pkg, version, args) { - return tslib_1.__awaiter(this, void 0, void 0, function* () { - let pm = detectPackageManager(); - if (pm === 'yarn') { - /** - * yarn has `yarn info` but it behaves differently than (p)npm, - * which makes it's usage unreliable - * - * @see https://github.com/nrwl/nx/pull/9667#discussion_r842553994 - */ - pm = 'npm'; - } - const { stdout } = yield execAsync(`${pm} view ${pkg}@${version} ${args}`); - return stdout.toString().trim(); - }); -} -exports.packageRegistryView = packageRegistryView; -function packageRegistryPack(cwd, pkg, version) { - return tslib_1.__awaiter(this, void 0, void 0, function* () { - let pm = detectPackageManager(); - if (pm === 'yarn') { - /** - * `(p)npm pack` will download a tarball of the specified version, - * whereas `yarn` pack creates a tarball of the active workspace, so it - * does not work for getting the content of a library. - * - * @see https://github.com/nrwl/nx/pull/9667#discussion_r842553994 - */ - pm = 'npm'; - } - const { stdout } = yield execAsync(`${pm} pack ${pkg}@${version}`, { cwd }); - const tarballPath = stdout.trim(); - return { tarballPath }; - }); -} -exports.packageRegistryPack = packageRegistryPack; - - -/***/ }), - -/***/ 75878: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { - -"use strict"; - -Object.defineProperty(exports, "__esModule", ({ value: true })); -exports.joinPathFragments = exports.normalizePath = void 0; -const path = __nccwpck_require__(71017); -function removeWindowsDriveLetter(osSpecificPath) { - return osSpecificPath.replace(/^[A-Z]:/, ''); -} -/** - * Coverts an os specific path to a unix style path - */ -function normalizePath(osSpecificPath) { - return removeWindowsDriveLetter(osSpecificPath).split('\\').join('/'); -} -exports.normalizePath = normalizePath; -/** - * Normalized path fragments and joins them - */ -function joinPathFragments(...fragments) { - return normalizePath(path.join(...fragments)); -} -exports.joinPathFragments = joinPathFragments; - - -/***/ }), - -/***/ 27377: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { +common.register('sed', _sed, { + globStart: 3, // don't glob-expand regexes + canReceivePipe: true, + cmdOptions: { + 'i': 'inplace', + }, +}); -"use strict"; +//@ +//@ ### sed([options,] search_regex, replacement, file [, file ...]) +//@ ### sed([options,] search_regex, replacement, file_array) +//@ +//@ Available options: +//@ +//@ + `-i`: Replace contents of `file` in-place. _Note that no backups will be created!_ +//@ +//@ Examples: +//@ +//@ ```javascript +//@ sed('-i', 'PROGRAM_VERSION', 'v0.1.3', 'source.js'); +//@ sed(/.*DELETE_THIS_LINE.*\n/, '', 'source.js'); +//@ ``` +//@ +//@ Reads an input string from `file`s, and performs a JavaScript `replace()` on the input +//@ using the given `search_regex` and `replacement` string or function. Returns the new string after replacement. +//@ +//@ Note: +//@ +//@ Like unix `sed`, ShellJS `sed` supports capture groups. Capture groups are specified +//@ using the `$n` syntax: +//@ +//@ ```javascript +//@ sed(/(\w+)\s(\w+)/, '$2, $1', 'file.txt'); +//@ ``` +function _sed(options, regex, replacement, files) { + // Check if this is coming from a pipe + var pipe = common.readFromPipe(); -Object.defineProperty(exports, "__esModule", ({ value: true })); -exports.findAllProjectNodeDependencies = exports.getSourceDirOfDependentProjects = exports.mergeNpmScriptsWithTargets = exports.projectHasTargetAndConfiguration = exports.projectHasTarget = void 0; -const package_json_1 = __nccwpck_require__(14482); -const path_1 = __nccwpck_require__(71017); -const fileutils_1 = __nccwpck_require__(47930); -const project_graph_1 = __nccwpck_require__(22055); -function projectHasTarget(project, target) { - return !!(project.data && - project.data.targets && - project.data.targets[target]); -} -exports.projectHasTarget = projectHasTarget; -function projectHasTargetAndConfiguration(project, target, configuration) { - return (projectHasTarget(project, target) && - project.data.targets[target].configurations && - project.data.targets[target].configurations[configuration]); -} -exports.projectHasTargetAndConfiguration = projectHasTargetAndConfiguration; -function mergeNpmScriptsWithTargets(projectRoot, targets) { - try { - const { scripts, nx } = (0, fileutils_1.readJsonFile)((0, path_1.join)(projectRoot, 'package.json')); - const res = {}; - // handle no scripts - Object.keys(scripts || {}).forEach((script) => { - if (!(nx === null || nx === void 0 ? void 0 : nx.includedScripts) || (nx === null || nx === void 0 ? void 0 : nx.includedScripts.includes(script))) { - res[script] = (0, package_json_1.buildTargetFromScript)(script, nx); - } - }); - return Object.assign(Object.assign({}, res), (targets || {})); - } - catch (e) { - return targets; - } -} -exports.mergeNpmScriptsWithTargets = mergeNpmScriptsWithTargets; -function getSourceDirOfDependentProjects(projectName, projectGraph = (0, project_graph_1.readCachedProjectGraph)()) { - if (!projectGraph.nodes[projectName]) { - throw new Error(`Couldn't find project "${projectName}" in this Nx workspace`); - } - const nodeNames = findAllProjectNodeDependencies(projectName, projectGraph); - return nodeNames.reduce((result, nodeName) => { - if (projectGraph.nodes[nodeName].data.sourceRoot) { - result[0].push(projectGraph.nodes[nodeName].data.sourceRoot); - } - else { - result[1].push(nodeName); - } - return result; - }, [[], []]); -} -exports.getSourceDirOfDependentProjects = getSourceDirOfDependentProjects; -/** - * Find all internal project dependencies. - * All the external (npm) dependencies will be filtered out - * @param {string} parentNodeName - * @param {ProjectGraph} projectGraph - * @returns {string[]} - */ -function findAllProjectNodeDependencies(parentNodeName, projectGraph = (0, project_graph_1.readCachedProjectGraph)()) { - const dependencyNodeNames = new Set(); - collectDependentProjectNodesNames(projectGraph, dependencyNodeNames, parentNodeName); - return Array.from(dependencyNodeNames); -} -exports.findAllProjectNodeDependencies = findAllProjectNodeDependencies; -// Recursively get all the dependencies of the node -function collectDependentProjectNodesNames(nxDeps, dependencyNodeNames, parentNodeName) { - var _a; - const dependencies = nxDeps.dependencies[parentNodeName]; - if (!dependencies) { - // no dependencies for the given node, so silently return, - // as we probably wouldn't want to throw here - return; - } - for (const dependency of dependencies) { - const dependencyName = dependency.target; - // we're only interested in internal nodes, not external - if ((_a = nxDeps.externalNodes) === null || _a === void 0 ? void 0 : _a[dependencyName]) { - continue; - } - // skip dependencies already added (avoid circular dependencies) - if (dependencyNodeNames.has(dependencyName)) { - continue; - } - dependencyNodeNames.add(dependencyName); - // Get the dependencies of the dependencies - collectDependentProjectNodesNames(nxDeps, dependencyNodeNames, dependencyName); + if (typeof replacement !== 'string' && typeof replacement !== 'function') { + if (typeof replacement === 'number') { + replacement = replacement.toString(); // fallback + } else { + common.error('invalid replacement string'); } -} + } + // Convert all search strings to RegExp + if (typeof regex === 'string') { + regex = RegExp(regex); + } -/***/ }), + if (!files && !pipe) { + common.error('no files given'); + } -/***/ 45208: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { + files = [].slice.call(arguments, 3); -"use strict"; + if (pipe) { + files.unshift('-'); + } -Object.defineProperty(exports, "__esModule", ({ value: true })); -exports.PromisedBasedQueue = void 0; -const tslib_1 = __nccwpck_require__(51796); -class PromisedBasedQueue { - constructor() { - this.counter = 0; - this.promise = Promise.resolve(null); - } - sendToQueue(fn) { - this.counter++; - let res, rej; - const r = new Promise((_res, _rej) => { - res = _res; - rej = _rej; - }); - this.promise = this.promise - .then(() => tslib_1.__awaiter(this, void 0, void 0, function* () { - try { - res(yield fn()); - this.counter--; - } - catch (e) { - rej(e); - this.counter--; - } - })) - .catch(() => tslib_1.__awaiter(this, void 0, void 0, function* () { - try { - res(yield fn()); - this.counter--; - } - catch (e) { - rej(e); - this.counter--; - } - })); - return r; - } - isEmpty() { - return this.counter === 0; + var sed = []; + files.forEach(function (file) { + if (!fs.existsSync(file) && file !== '-') { + common.error('no such file or directory: ' + file, 2, { continue: true }); + return; } -} -exports.PromisedBasedQueue = PromisedBasedQueue; + var contents = file === '-' ? pipe : fs.readFileSync(file, 'utf8'); + var lines = contents.split('\n'); + var result = lines.map(function (line) { + return line.replace(regex, replacement); + }).join('\n'); -/***/ }), - -/***/ 4477: -/***/ ((__unused_webpack_module, exports) => { + sed.push(result); -"use strict"; + if (options.inplace) { + fs.writeFileSync(file, result, 'utf8'); + } + }); -Object.defineProperty(exports, "__esModule", ({ value: true })); -exports.stripIndents = void 0; -/** - * Removes indents, which is useful for printing warning and messages. - * - * Example: - * - * ```typescript - * stripIndents` - * Options: - * - option1 - * - option2 - * ` - * ``` - */ -function stripIndents(strings, ...values) { - return String.raw(strings, ...values) - .split('\n') - .map((line) => line.trim()) - .join('\n') - .trim(); + return sed.join('\n'); } -exports.stripIndents = stripIndents; +module.exports = _sed; /***/ }), -/***/ 39317: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { - -"use strict"; - -Object.defineProperty(exports, "__esModule", ({ value: true })); -exports.nxVersion = void 0; -exports.nxVersion = __nccwpck_require__(89617).version; +/***/ 62833: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { +var common = __nccwpck_require__(60624); -/***/ }), +common.register('set', _set, { + allowGlobbing: false, + wrapOutput: false, +}); -/***/ 65766: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { +//@ +//@ ### set(options) +//@ +//@ Available options: +//@ +//@ + `+/-e`: exit upon error (`config.fatal`) +//@ + `+/-v`: verbose: show all commands (`config.verbose`) +//@ + `+/-f`: disable filename expansion (globbing) +//@ +//@ Examples: +//@ +//@ ```javascript +//@ set('-e'); // exit upon first error +//@ set('+e'); // this undoes a "set('-e')" +//@ ``` +//@ +//@ Sets global configuration variables. +function _set(options) { + if (!options) { + var args = [].slice.call(arguments, 0); + if (args.length < 2) common.error('must provide an argument'); + options = args[1]; + } + var negate = (options[0] === '+'); + if (negate) { + options = '-' + options.slice(1); // parseOptions needs a '-' prefix + } + options = common.parseOptions(options, { + 'e': 'fatal', + 'v': 'verbose', + 'f': 'noglob', + }); -"use strict"; + if (negate) { + Object.keys(options).forEach(function (key) { + options[key] = !options[key]; + }); + } -Object.defineProperty(exports, "__esModule", ({ value: true })); -exports.workspaceRootInner = exports.setWorkspaceRoot = exports.workspaceRoot = void 0; -const path = __nccwpck_require__(71017); -const fileutils_1 = __nccwpck_require__(47930); -/** - * The root of the workspace - */ -exports.workspaceRoot = workspaceRootInner(process.cwd(), process.cwd()); -function setWorkspaceRoot(root) { - exports.workspaceRoot = root; -} -exports.setWorkspaceRoot = setWorkspaceRoot; -function workspaceRootInner(dir, candidateRoot) { - if (process.env.NX_WORKSPACE_ROOT_PATH) - return process.env.NX_WORKSPACE_ROOT_PATH; - if (path.dirname(dir) === dir) - return candidateRoot; - const matches = [ - path.join(dir, 'nx.json'), - path.join(dir, 'nx'), - path.join(dir, 'nx.bat'), - ]; - if (matches.some((x) => (0, fileutils_1.fileExists)(x))) { - return dir; - // This handles the case where we have a workspace which uses npm / yarn / pnpm - // workspaces, and has a project which contains Nx in its dependency tree. - // e.g. packages/my-lib/package.json contains @nx/devkit, which references Nx and is - // thus located in //packages/my-lib/node_modules/nx/package.json - } - else if ((0, fileutils_1.fileExists)(path.join(dir, 'node_modules', 'nx', 'package.json'))) { - return workspaceRootInner(path.dirname(dir), dir); - } - else { - return workspaceRootInner(path.dirname(dir), candidateRoot); + Object.keys(options).forEach(function (key) { + // Only change the global config if `negate` is false and the option is true + // or if `negate` is true and the option is false (aka negate !== option) + if (negate !== options[key]) { + common.config[key] = options[key]; } + }); + return; } -exports.workspaceRootInner = workspaceRootInner; +module.exports = _set; /***/ }), -/***/ 37909: +/***/ 22675: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { -var wrappy = __nccwpck_require__(63180) -module.exports = wrappy(once) -module.exports.strict = wrappy(onceStrict) +var common = __nccwpck_require__(60624); +var fs = __nccwpck_require__(57147); -once.proto = once(function () { - Object.defineProperty(Function.prototype, 'once', { - value: function () { - return once(this) - }, - configurable: true - }) +common.register('sort', _sort, { + canReceivePipe: true, + cmdOptions: { + 'r': 'reverse', + 'n': 'numerical', + }, +}); - Object.defineProperty(Function.prototype, 'onceStrict', { - value: function () { - return onceStrict(this) - }, - configurable: true - }) -}) +// parse out the number prefix of a line +function parseNumber(str) { + var match = str.match(/^\s*(\d*)\s*(.*)$/); + return { num: Number(match[1]), value: match[2] }; +} -function once (fn) { - var f = function () { - if (f.called) return f.value - f.called = true - return f.value = fn.apply(this, arguments) - } - f.called = false - return f +// compare two strings case-insensitively, but examine case for strings that are +// case-insensitive equivalent +function unixCmp(a, b) { + var aLower = a.toLowerCase(); + var bLower = b.toLowerCase(); + return (aLower === bLower ? + -1 * a.localeCompare(b) : // unix sort treats case opposite how javascript does + aLower.localeCompare(bLower)); } -function onceStrict (fn) { - var f = function () { - if (f.called) - throw new Error(f.onceError) - f.called = true - return f.value = fn.apply(this, arguments) +// compare two strings in the fashion that unix sort's -n option works +function numericalCmp(a, b) { + var objA = parseNumber(a); + var objB = parseNumber(b); + if (objA.hasOwnProperty('num') && objB.hasOwnProperty('num')) { + return ((objA.num !== objB.num) ? + (objA.num - objB.num) : + unixCmp(objA.value, objB.value)); + } else { + return unixCmp(objA.value, objB.value); } - var name = fn.name || 'Function wrapped with `once`' - f.onceError = name + " shouldn't be called more than once" - f.called = false - return f } +//@ +//@ ### sort([options,] file [, file ...]) +//@ ### sort([options,] file_array) +//@ +//@ Available options: +//@ +//@ + `-r`: Reverse the results +//@ + `-n`: Compare according to numerical value +//@ +//@ Examples: +//@ +//@ ```javascript +//@ sort('foo.txt', 'bar.txt'); +//@ sort('-r', 'foo.txt'); +//@ ``` +//@ +//@ Return the contents of the `file`s, sorted line-by-line. Sorting multiple +//@ files mixes their content (just as unix `sort` does). +function _sort(options, files) { + // Check if this is coming from a pipe + var pipe = common.readFromPipe(); -/***/ }), - -/***/ 50124: -/***/ ((module) => { - -"use strict"; - - -function posix(path) { - return path.charAt(0) === '/'; -} - -function win32(path) { - // https://github.com/nodejs/node/blob/b3fcc245fb25539909ef1d5eaa01dbf92e168633/lib/path.js#L56 - var splitDeviceRe = /^([a-zA-Z]:|[\\\/]{2}[^\\\/]+[\\\/]+[^\\\/]+)?([\\\/])?([\s\S]*?)$/; - var result = splitDeviceRe.exec(path); - var device = result[1] || ''; - var isUnc = Boolean(device && device.charAt(1) !== ':'); + if (!files && !pipe) common.error('no files given'); - // UNC paths are always absolute - return Boolean(result[2] || isUnc); -} + files = [].slice.call(arguments, 1); -module.exports = process.platform === 'win32' ? win32 : posix; -module.exports.posix = posix; -module.exports.win32 = win32; + if (pipe) { + files.unshift('-'); + } + var lines = files.reduce(function (accum, file) { + if (file !== '-') { + if (!fs.existsSync(file)) { + common.error('no such file or directory: ' + file, { continue: true }); + return accum; + } else if (common.statFollowLinks(file).isDirectory()) { + common.error('read failed: ' + file + ': Is a directory', { + continue: true, + }); + return accum; + } + } -/***/ }), + var contents = file === '-' ? pipe : fs.readFileSync(file, 'utf8'); + return accum.concat(contents.trimRight().split('\n')); + }, []); -/***/ 21224: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + var sorted = lines.sort(options.numerical ? numericalCmp : unixCmp); -"use strict"; + if (options.reverse) { + sorted = sorted.reverse(); + } + return sorted.join('\n') + '\n'; +} -module.exports = __nccwpck_require__(74070); +module.exports = _sort; /***/ }), -/***/ 67582: +/***/ 61434: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { -"use strict"; - - -const path = __nccwpck_require__(71017); -const WIN_SLASH = '\\\\/'; -const WIN_NO_SLASH = `[^${WIN_SLASH}]`; - -/** - * Posix glob regex - */ - -const DOT_LITERAL = '\\.'; -const PLUS_LITERAL = '\\+'; -const QMARK_LITERAL = '\\?'; -const SLASH_LITERAL = '\\/'; -const ONE_CHAR = '(?=.)'; -const QMARK = '[^/]'; -const END_ANCHOR = `(?:${SLASH_LITERAL}|$)`; -const START_ANCHOR = `(?:^|${SLASH_LITERAL})`; -const DOTS_SLASH = `${DOT_LITERAL}{1,2}${END_ANCHOR}`; -const NO_DOT = `(?!${DOT_LITERAL})`; -const NO_DOTS = `(?!${START_ANCHOR}${DOTS_SLASH})`; -const NO_DOT_SLASH = `(?!${DOT_LITERAL}{0,1}${END_ANCHOR})`; -const NO_DOTS_SLASH = `(?!${DOTS_SLASH})`; -const QMARK_NO_DOT = `[^.${SLASH_LITERAL}]`; -const STAR = `${QMARK}*?`; - -const POSIX_CHARS = { - DOT_LITERAL, - PLUS_LITERAL, - QMARK_LITERAL, - SLASH_LITERAL, - ONE_CHAR, - QMARK, - END_ANCHOR, - DOTS_SLASH, - NO_DOT, - NO_DOTS, - NO_DOT_SLASH, - NO_DOTS_SLASH, - QMARK_NO_DOT, - STAR, - START_ANCHOR -}; +var common = __nccwpck_require__(60624); +var fs = __nccwpck_require__(57147); -/** - * Windows glob regex - */ +common.register('tail', _tail, { + canReceivePipe: true, + cmdOptions: { + 'n': 'numLines', + }, +}); -const WINDOWS_CHARS = { - ...POSIX_CHARS, - - SLASH_LITERAL: `[${WIN_SLASH}]`, - QMARK: WIN_NO_SLASH, - STAR: `${WIN_NO_SLASH}*?`, - DOTS_SLASH: `${DOT_LITERAL}{1,2}(?:[${WIN_SLASH}]|$)`, - NO_DOT: `(?!${DOT_LITERAL})`, - NO_DOTS: `(?!(?:^|[${WIN_SLASH}])${DOT_LITERAL}{1,2}(?:[${WIN_SLASH}]|$))`, - NO_DOT_SLASH: `(?!${DOT_LITERAL}{0,1}(?:[${WIN_SLASH}]|$))`, - NO_DOTS_SLASH: `(?!${DOT_LITERAL}{1,2}(?:[${WIN_SLASH}]|$))`, - QMARK_NO_DOT: `[^.${WIN_SLASH}]`, - START_ANCHOR: `(?:^|[${WIN_SLASH}])`, - END_ANCHOR: `(?:[${WIN_SLASH}]|$)` -}; +//@ +//@ ### tail([{'-n': \},] file [, file ...]) +//@ ### tail([{'-n': \},] file_array) +//@ +//@ Available options: +//@ +//@ + `-n `: Show the last `` lines of `file`s +//@ +//@ Examples: +//@ +//@ ```javascript +//@ var str = tail({'-n': 1}, 'file*.txt'); +//@ var str = tail('file1', 'file2'); +//@ var str = tail(['file1', 'file2']); // same as above +//@ ``` +//@ +//@ Read the end of a `file`. +function _tail(options, files) { + var tail = []; + var pipe = common.readFromPipe(); -/** - * POSIX Bracket Regex - */ + if (!files && !pipe) common.error('no paths given'); -const POSIX_REGEX_SOURCE = { - alnum: 'a-zA-Z0-9', - alpha: 'a-zA-Z', - ascii: '\\x00-\\x7F', - blank: ' \\t', - cntrl: '\\x00-\\x1F\\x7F', - digit: '0-9', - graph: '\\x21-\\x7E', - lower: 'a-z', - print: '\\x20-\\x7E ', - punct: '\\-!"#$%&\'()\\*+,./:;<=>?@[\\]^_`{|}~', - space: ' \\t\\r\\n\\v\\f', - upper: 'A-Z', - word: 'A-Za-z0-9_', - xdigit: 'A-Fa-f0-9' -}; + var idx = 1; + if (options.numLines === true) { + idx = 2; + options.numLines = Number(arguments[1]); + } else if (options.numLines === false) { + options.numLines = 10; + } + options.numLines = -1 * Math.abs(options.numLines); + files = [].slice.call(arguments, idx); -module.exports = { - MAX_LENGTH: 1024 * 64, - POSIX_REGEX_SOURCE, - - // regular expressions - REGEX_BACKSLASH: /\\(?![*+?^${}(|)[\]])/g, - REGEX_NON_SPECIAL_CHARS: /^[^@![\].,$*+?^{}()|\\/]+/, - REGEX_SPECIAL_CHARS: /[-*+?.^${}(|)[\]]/, - REGEX_SPECIAL_CHARS_BACKREF: /(\\?)((\W)(\3*))/g, - REGEX_SPECIAL_CHARS_GLOBAL: /([-*+?.^${}(|)[\]])/g, - REGEX_REMOVE_BACKSLASH: /(?:\[.*?[^\\]\]|\\(?=.))/g, - - // Replace globs with equivalent patterns to reduce parsing time. - REPLACEMENTS: { - '***': '*', - '**/**': '**', - '**/**/**': '**' - }, + if (pipe) { + files.unshift('-'); + } - // Digits - CHAR_0: 48, /* 0 */ - CHAR_9: 57, /* 9 */ - - // Alphabet chars. - CHAR_UPPERCASE_A: 65, /* A */ - CHAR_LOWERCASE_A: 97, /* a */ - CHAR_UPPERCASE_Z: 90, /* Z */ - CHAR_LOWERCASE_Z: 122, /* z */ - - CHAR_LEFT_PARENTHESES: 40, /* ( */ - CHAR_RIGHT_PARENTHESES: 41, /* ) */ - - CHAR_ASTERISK: 42, /* * */ - - // Non-alphabetic chars. - CHAR_AMPERSAND: 38, /* & */ - CHAR_AT: 64, /* @ */ - CHAR_BACKWARD_SLASH: 92, /* \ */ - CHAR_CARRIAGE_RETURN: 13, /* \r */ - CHAR_CIRCUMFLEX_ACCENT: 94, /* ^ */ - CHAR_COLON: 58, /* : */ - CHAR_COMMA: 44, /* , */ - CHAR_DOT: 46, /* . */ - CHAR_DOUBLE_QUOTE: 34, /* " */ - CHAR_EQUAL: 61, /* = */ - CHAR_EXCLAMATION_MARK: 33, /* ! */ - CHAR_FORM_FEED: 12, /* \f */ - CHAR_FORWARD_SLASH: 47, /* / */ - CHAR_GRAVE_ACCENT: 96, /* ` */ - CHAR_HASH: 35, /* # */ - CHAR_HYPHEN_MINUS: 45, /* - */ - CHAR_LEFT_ANGLE_BRACKET: 60, /* < */ - CHAR_LEFT_CURLY_BRACE: 123, /* { */ - CHAR_LEFT_SQUARE_BRACKET: 91, /* [ */ - CHAR_LINE_FEED: 10, /* \n */ - CHAR_NO_BREAK_SPACE: 160, /* \u00A0 */ - CHAR_PERCENT: 37, /* % */ - CHAR_PLUS: 43, /* + */ - CHAR_QUESTION_MARK: 63, /* ? */ - CHAR_RIGHT_ANGLE_BRACKET: 62, /* > */ - CHAR_RIGHT_CURLY_BRACE: 125, /* } */ - CHAR_RIGHT_SQUARE_BRACKET: 93, /* ] */ - CHAR_SEMICOLON: 59, /* ; */ - CHAR_SINGLE_QUOTE: 39, /* ' */ - CHAR_SPACE: 32, /* */ - CHAR_TAB: 9, /* \t */ - CHAR_UNDERSCORE: 95, /* _ */ - CHAR_VERTICAL_LINE: 124, /* | */ - CHAR_ZERO_WIDTH_NOBREAK_SPACE: 65279, /* \uFEFF */ - - SEP: path.sep, + var shouldAppendNewline = false; + files.forEach(function (file) { + if (file !== '-') { + if (!fs.existsSync(file)) { + common.error('no such file or directory: ' + file, { continue: true }); + return; + } else if (common.statFollowLinks(file).isDirectory()) { + common.error("error reading '" + file + "': Is a directory", { + continue: true, + }); + return; + } + } - /** - * Create EXTGLOB_CHARS - */ + var contents = file === '-' ? pipe : fs.readFileSync(file, 'utf8'); - extglobChars(chars) { - return { - '!': { type: 'negate', open: '(?:(?!(?:', close: `))${chars.STAR})` }, - '?': { type: 'qmark', open: '(?:', close: ')?' }, - '+': { type: 'plus', open: '(?:', close: ')+' }, - '*': { type: 'star', open: '(?:', close: ')*' }, - '@': { type: 'at', open: '(?:', close: ')' } - }; - }, + var lines = contents.split('\n'); + if (lines[lines.length - 1] === '') { + lines.pop(); + shouldAppendNewline = true; + } else { + shouldAppendNewline = false; + } - /** - * Create GLOB_CHARS - */ + tail = tail.concat(lines.slice(options.numLines)); + }); - globChars(win32) { - return win32 === true ? WINDOWS_CHARS : POSIX_CHARS; + if (shouldAppendNewline) { + tail.push(''); // to add a trailing newline once we join } -}; + return tail.join('\n'); +} +module.exports = _tail; /***/ }), -/***/ 90207: +/***/ 68691: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { -"use strict"; - - -const constants = __nccwpck_require__(67582); -const utils = __nccwpck_require__(76088); - -/** - * Constants - */ - -const { - MAX_LENGTH, - POSIX_REGEX_SOURCE, - REGEX_NON_SPECIAL_CHARS, - REGEX_SPECIAL_CHARS_BACKREF, - REPLACEMENTS -} = constants; +var common = __nccwpck_require__(60624); +var os = __nccwpck_require__(22037); +var fs = __nccwpck_require__(57147); -/** - * Helpers - */ +common.register('tempdir', _tempDir, { + allowGlobbing: false, + wrapOutput: false, +}); -const expandRange = (args, options) => { - if (typeof options.expandRange === 'function') { - return options.expandRange(...args, options); - } +// Returns false if 'dir' is not a writeable directory, 'dir' otherwise +function writeableDir(dir) { + if (!dir || !fs.existsSync(dir)) return false; - args.sort(); - const value = `[${args.join('-')}]`; + if (!common.statFollowLinks(dir).isDirectory()) return false; + var testFile = dir + '/' + common.randomFileName(); try { - /* eslint-disable-next-line no-new */ - new RegExp(value); - } catch (ex) { - return args.map(v => utils.escapeRegex(v)).join('..'); - } - - return value; -}; - -/** - * Create the message for a syntax error - */ - -const syntaxError = (type, char) => { - return `Missing ${type}: "${char}" - use "\\\\${char}" to match literal characters`; -}; - -/** - * Parse the given input string. - * @param {String} input - * @param {Object} options - * @return {Object} - */ - -const parse = (input, options) => { - if (typeof input !== 'string') { - throw new TypeError('Expected a string'); - } - - input = REPLACEMENTS[input] || input; - - const opts = { ...options }; - const max = typeof opts.maxLength === 'number' ? Math.min(MAX_LENGTH, opts.maxLength) : MAX_LENGTH; - - let len = input.length; - if (len > max) { - throw new SyntaxError(`Input length: ${len}, exceeds maximum allowed length: ${max}`); + fs.writeFileSync(testFile, ' '); + common.unlinkSync(testFile); + return dir; + } catch (e) { + /* istanbul ignore next */ + return false; } +} - const bos = { type: 'bos', value: '', output: opts.prepend || '' }; - const tokens = [bos]; - - const capture = opts.capture ? '' : '?:'; - const win32 = utils.isWindows(options); +// Variable to cache the tempdir value for successive lookups. +var cachedTempDir; - // create constants based on platform, for windows or posix - const PLATFORM_CHARS = constants.globChars(win32); - const EXTGLOB_CHARS = constants.extglobChars(PLATFORM_CHARS); +//@ +//@ ### tempdir() +//@ +//@ Examples: +//@ +//@ ```javascript +//@ var tmp = tempdir(); // "/tmp" for most *nix platforms +//@ ``` +//@ +//@ Searches and returns string containing a writeable, platform-dependent temporary directory. +//@ Follows Python's [tempfile algorithm](http://docs.python.org/library/tempfile.html#tempfile.tempdir). +function _tempDir() { + if (cachedTempDir) return cachedTempDir; - const { - DOT_LITERAL, - PLUS_LITERAL, - SLASH_LITERAL, - ONE_CHAR, - DOTS_SLASH, - NO_DOT, - NO_DOT_SLASH, - NO_DOTS_SLASH, - QMARK, - QMARK_NO_DOT, - STAR, - START_ANCHOR - } = PLATFORM_CHARS; + cachedTempDir = writeableDir(os.tmpdir()) || + writeableDir(process.env.TMPDIR) || + writeableDir(process.env.TEMP) || + writeableDir(process.env.TMP) || + writeableDir(process.env.Wimp$ScrapDir) || // RiscOS + writeableDir('C:\\TEMP') || // Windows + writeableDir('C:\\TMP') || // Windows + writeableDir('\\TEMP') || // Windows + writeableDir('\\TMP') || // Windows + writeableDir('/tmp') || + writeableDir('/var/tmp') || + writeableDir('/usr/tmp') || + writeableDir('.'); // last resort - const globstar = opts => { - return `(${capture}(?:(?!${START_ANCHOR}${opts.dot ? DOTS_SLASH : DOT_LITERAL}).)*?)`; - }; + return cachedTempDir; +} - const nodot = opts.dot ? '' : NO_DOT; - const qmarkNoDot = opts.dot ? QMARK : QMARK_NO_DOT; - let star = opts.bash === true ? globstar(opts) : STAR; +// Indicates if the tempdir value is currently cached. This is exposed for tests +// only. The return value should only be tested for truthiness. +function isCached() { + return cachedTempDir; +} - if (opts.capture) { - star = `(${star})`; - } +// Clears the cached tempDir value, if one is cached. This is exposed for tests +// only. +function clearCache() { + cachedTempDir = undefined; +} - // minimatch options support - if (typeof opts.noext === 'boolean') { - opts.noextglob = opts.noext; - } +module.exports.tempDir = _tempDir; +module.exports.isCached = isCached; +module.exports.clearCache = clearCache; - const state = { - input, - index: -1, - start: 0, - dot: opts.dot === true, - consumed: '', - output: '', - prefix: '', - backtrack: false, - negated: false, - brackets: 0, - braces: 0, - parens: 0, - quotes: 0, - globstar: false, - tokens - }; - input = utils.removePrefix(input, state); - len = input.length; +/***/ }), - const extglobs = []; - const braces = []; - const stack = []; - let prev = bos; - let value; +/***/ 22766: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { - /** - * Tokenizing helpers - */ +var common = __nccwpck_require__(60624); +var fs = __nccwpck_require__(57147); - const eos = () => state.index === len - 1; - const peek = state.peek = (n = 1) => input[state.index + n]; - const advance = state.advance = () => input[++state.index] || ''; - const remaining = () => input.slice(state.index + 1); - const consume = (value = '', num = 0) => { - state.consumed += value; - state.index += num; - }; +common.register('test', _test, { + cmdOptions: { + 'b': 'block', + 'c': 'character', + 'd': 'directory', + 'e': 'exists', + 'f': 'file', + 'L': 'link', + 'p': 'pipe', + 'S': 'socket', + }, + wrapOutput: false, + allowGlobbing: false, +}); - const append = token => { - state.output += token.output != null ? token.output : token.value; - consume(token.value); - }; - const negate = () => { - let count = 1; +//@ +//@ ### test(expression) +//@ +//@ Available expression primaries: +//@ +//@ + `'-b', 'path'`: true if path is a block device +//@ + `'-c', 'path'`: true if path is a character device +//@ + `'-d', 'path'`: true if path is a directory +//@ + `'-e', 'path'`: true if path exists +//@ + `'-f', 'path'`: true if path is a regular file +//@ + `'-L', 'path'`: true if path is a symbolic link +//@ + `'-p', 'path'`: true if path is a pipe (FIFO) +//@ + `'-S', 'path'`: true if path is a socket +//@ +//@ Examples: +//@ +//@ ```javascript +//@ if (test('-d', path)) { /* do something with dir */ }; +//@ if (!test('-f', path)) continue; // skip if it's a regular file +//@ ``` +//@ +//@ Evaluates `expression` using the available primaries and returns corresponding value. +function _test(options, path) { + if (!path) common.error('no path given'); - while (peek() === '!' && (peek(2) !== '(' || peek(3) === '?')) { - advance(); - state.start++; - count++; + var canInterpret = false; + Object.keys(options).forEach(function (key) { + if (options[key] === true) { + canInterpret = true; } + }); + + if (!canInterpret) common.error('could not interpret expression'); - if (count % 2 === 0) { + if (options.link) { + try { + return common.statNoFollowLinks(path).isSymbolicLink(); + } catch (e) { return false; } + } - state.negated = true; - state.start++; - return true; - }; - - const increment = type => { - state[type]++; - stack.push(type); - }; - - const decrement = type => { - state[type]--; - stack.pop(); - }; - - /** - * Push tokens onto the tokens array. This helper speeds up - * tokenizing by 1) helping us avoid backtracking as much as possible, - * and 2) helping us avoid creating extra tokens when consecutive - * characters are plain text. This improves performance and simplifies - * lookbehinds. - */ + if (!fs.existsSync(path)) return false; - const push = tok => { - if (prev.type === 'globstar') { - const isBrace = state.braces > 0 && (tok.type === 'comma' || tok.type === 'brace'); - const isExtglob = tok.extglob === true || (extglobs.length && (tok.type === 'pipe' || tok.type === 'paren')); + if (options.exists) return true; - if (tok.type !== 'slash' && tok.type !== 'paren' && !isBrace && !isExtglob) { - state.output = state.output.slice(0, -prev.output.length); - prev.type = 'star'; - prev.value = '*'; - prev.output = star; - state.output += prev.output; - } - } + var stats = common.statFollowLinks(path); - if (extglobs.length && tok.type !== 'paren') { - extglobs[extglobs.length - 1].inner += tok.value; - } + if (options.block) return stats.isBlockDevice(); - if (tok.value || tok.output) append(tok); - if (prev && prev.type === 'text' && tok.type === 'text') { - prev.value += tok.value; - prev.output = (prev.output || '') + tok.value; - return; - } + if (options.character) return stats.isCharacterDevice(); - tok.prev = prev; - tokens.push(tok); - prev = tok; - }; + if (options.directory) return stats.isDirectory(); - const extglobOpen = (type, value) => { - const token = { ...EXTGLOB_CHARS[value], conditions: 1, inner: '' }; + if (options.file) return stats.isFile(); - token.prev = prev; - token.parens = state.parens; - token.output = state.output; - const output = (opts.capture ? '(' : '') + token.open; + /* istanbul ignore next */ + if (options.pipe) return stats.isFIFO(); - increment('parens'); - push({ type, value, output: state.output ? '' : ONE_CHAR }); - push({ type: 'paren', extglob: true, value: advance(), output }); - extglobs.push(token); - }; + /* istanbul ignore next */ + if (options.socket) return stats.isSocket(); - const extglobClose = token => { - let output = token.close + (opts.capture ? ')' : ''); - let rest; + /* istanbul ignore next */ + return false; // fallback +} // test +module.exports = _test; - if (token.type === 'negate') { - let extglobStar = star; - if (token.inner && token.inner.length > 1 && token.inner.includes('/')) { - extglobStar = globstar(opts); - } +/***/ }), - if (extglobStar !== star || eos() || /^\)+$/.test(remaining())) { - output = token.close = `)$))${extglobStar}`; - } +/***/ 83181: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { - if (token.inner.includes('*') && (rest = remaining()) && /^\.[^\\/.]+$/.test(rest)) { - // Any non-magical string (`.ts`) or even nested expression (`.{ts,tsx}`) can follow after the closing parenthesis. - // In this case, we need to parse the string and use it in the output of the original pattern. - // Suitable patterns: `/!(*.d).ts`, `/!(*.d).{ts,tsx}`, `**/!(*-dbg).@(js)`. - // - // Disabling the `fastpaths` option due to a problem with parsing strings as `.ts` in the pattern like `**/!(*.d).ts`. - const expression = parse(rest, { ...options, fastpaths: false }).output; +var common = __nccwpck_require__(60624); +var fs = __nccwpck_require__(57147); +var path = __nccwpck_require__(71017); - output = token.close = `)${expression})${extglobStar})`; - } +common.register('to', _to, { + pipeOnly: true, + wrapOutput: false, +}); - if (token.prev.type === 'bos') { - state.negatedExtglob = true; - } - } +//@ +//@ ### ShellString.prototype.to(file) +//@ +//@ Examples: +//@ +//@ ```javascript +//@ cat('input.txt').to('output.txt'); +//@ ``` +//@ +//@ Analogous to the redirection operator `>` in Unix, but works with +//@ `ShellStrings` (such as those returned by `cat`, `grep`, etc.). _Like Unix +//@ redirections, `to()` will overwrite any existing file!_ +function _to(options, file) { + if (!file) common.error('wrong arguments'); - push({ type: 'paren', extglob: true, value, output }); - decrement('parens'); - }; + if (!fs.existsSync(path.dirname(file))) { + common.error('no such file or directory: ' + path.dirname(file)); + } - /** - * Fast paths - */ + try { + fs.writeFileSync(file, this.stdout || this.toString(), 'utf8'); + return this; + } catch (e) { + /* istanbul ignore next */ + common.error('could not write to file (code ' + e.code + '): ' + file, { continue: true }); + } +} +module.exports = _to; - if (opts.fastpaths !== false && !/(^[*!]|[/()[\]{}"])/.test(input)) { - let backslashes = false; - let output = input.replace(REGEX_SPECIAL_CHARS_BACKREF, (m, esc, chars, first, rest, index) => { - if (first === '\\') { - backslashes = true; - return m; - } +/***/ }), - if (first === '?') { - if (esc) { - return esc + first + (rest ? QMARK.repeat(rest.length) : ''); - } - if (index === 0) { - return qmarkNoDot + (rest ? QMARK.repeat(rest.length) : ''); - } - return QMARK.repeat(chars.length); - } +/***/ 5836: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { - if (first === '.') { - return DOT_LITERAL.repeat(chars.length); - } +var common = __nccwpck_require__(60624); +var fs = __nccwpck_require__(57147); +var path = __nccwpck_require__(71017); - if (first === '*') { - if (esc) { - return esc + first + (rest ? star : ''); - } - return star; - } - return esc ? m : `\\${m}`; - }); +common.register('toEnd', _toEnd, { + pipeOnly: true, + wrapOutput: false, +}); - if (backslashes === true) { - if (opts.unescape === true) { - output = output.replace(/\\/g, ''); - } else { - output = output.replace(/\\+/g, m => { - return m.length % 2 === 0 ? '\\\\' : (m ? '\\' : ''); - }); - } - } +//@ +//@ ### ShellString.prototype.toEnd(file) +//@ +//@ Examples: +//@ +//@ ```javascript +//@ cat('input.txt').toEnd('output.txt'); +//@ ``` +//@ +//@ Analogous to the redirect-and-append operator `>>` in Unix, but works with +//@ `ShellStrings` (such as those returned by `cat`, `grep`, etc.). +function _toEnd(options, file) { + if (!file) common.error('wrong arguments'); - if (output === input && opts.contains === true) { - state.output = input; - return state; - } + if (!fs.existsSync(path.dirname(file))) { + common.error('no such file or directory: ' + path.dirname(file)); + } - state.output = utils.wrapOutput(output, state, options); - return state; + try { + fs.appendFileSync(file, this.stdout || this.toString(), 'utf8'); + return this; + } catch (e) { + /* istanbul ignore next */ + common.error('could not append to file (code ' + e.code + '): ' + file, { continue: true }); } +} +module.exports = _toEnd; - /** - * Tokenize input until we reach end-of-string - */ - while (!eos()) { - value = advance(); +/***/ }), - if (value === '\u0000') { - continue; - } +/***/ 19811: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { - /** - * Escaped characters - */ +var common = __nccwpck_require__(60624); +var fs = __nccwpck_require__(57147); - if (value === '\\') { - const next = peek(); +common.register('touch', _touch, { + cmdOptions: { + 'a': 'atime_only', + 'c': 'no_create', + 'd': 'date', + 'm': 'mtime_only', + 'r': 'reference', + }, +}); - if (next === '/' && opts.bash !== true) { - continue; - } +//@ +//@ ### touch([options,] file [, file ...]) +//@ ### touch([options,] file_array) +//@ +//@ Available options: +//@ +//@ + `-a`: Change only the access time +//@ + `-c`: Do not create any files +//@ + `-m`: Change only the modification time +//@ + `-d DATE`: Parse `DATE` and use it instead of current time +//@ + `-r FILE`: Use `FILE`'s times instead of current time +//@ +//@ Examples: +//@ +//@ ```javascript +//@ touch('source.js'); +//@ touch('-c', '/path/to/some/dir/source.js'); +//@ touch({ '-r': FILE }, '/path/to/some/dir/source.js'); +//@ ``` +//@ +//@ Update the access and modification times of each `FILE` to the current time. +//@ A `FILE` argument that does not exist is created empty, unless `-c` is supplied. +//@ This is a partial implementation of [`touch(1)`](http://linux.die.net/man/1/touch). +function _touch(opts, files) { + if (!files) { + common.error('no files given'); + } else if (typeof files === 'string') { + files = [].slice.call(arguments, 1); + } else { + common.error('file arg should be a string file path or an Array of string file paths'); + } - if (next === '.' || next === ';') { - continue; - } + files.forEach(function (f) { + touchFile(opts, f); + }); + return ''; +} - if (!next) { - value += '\\'; - push({ type: 'text', value }); - continue; - } +function touchFile(opts, file) { + var stat = tryStatFile(file); - // collapse slashes to reduce potential for exploits - const match = /^\\+/.exec(remaining()); - let slashes = 0; + if (stat && stat.isDirectory()) { + // don't error just exit + return; + } - if (match && match[0].length > 2) { - slashes = match[0].length; - state.index += slashes; - if (slashes % 2 !== 0) { - value += '\\'; - } - } + // if the file doesn't already exist and the user has specified --no-create then + // this script is finished + if (!stat && opts.no_create) { + return; + } - if (opts.unescape === true) { - value = advance(); - } else { - value += advance(); - } + // open the file and then close it. this will create it if it doesn't exist but will + // not truncate the file + fs.closeSync(fs.openSync(file, 'a')); - if (state.brackets === 0) { - push({ type: 'text', value }); - continue; - } - } + // + // Set timestamps + // - /** - * If we're inside a regex character class, continue - * until we reach the closing bracket. - */ + // setup some defaults + var now = new Date(); + var mtime = opts.date || now; + var atime = opts.date || now; - if (state.brackets > 0 && (value !== ']' || prev.value === '[' || prev.value === '[^')) { - if (opts.posix !== false && value === ':') { - const inner = prev.value.slice(1); - if (inner.includes('[')) { - prev.posix = true; - - if (inner.includes(':')) { - const idx = prev.value.lastIndexOf('['); - const pre = prev.value.slice(0, idx); - const rest = prev.value.slice(idx + 2); - const posix = POSIX_REGEX_SOURCE[rest]; - if (posix) { - prev.value = pre + posix; - state.backtrack = true; - advance(); - - if (!bos.output && tokens.indexOf(prev) === 1) { - bos.output = ONE_CHAR; - } - continue; - } - } - } - } + // use reference file + if (opts.reference) { + var refStat = tryStatFile(opts.reference); + if (!refStat) { + common.error('failed to get attributess of ' + opts.reference); + } + mtime = refStat.mtime; + atime = refStat.atime; + } else if (opts.date) { + mtime = opts.date; + atime = opts.date; + } - if ((value === '[' && peek() !== ':') || (value === '-' && peek() === ']')) { - value = `\\${value}`; - } + if (opts.atime_only && opts.mtime_only) { + // keep the new values of mtime and atime like GNU + } else if (opts.atime_only) { + mtime = stat.mtime; + } else if (opts.mtime_only) { + atime = stat.atime; + } - if (value === ']' && (prev.value === '[' || prev.value === '[^')) { - value = `\\${value}`; - } + fs.utimesSync(file, atime, mtime); +} - if (opts.posix === true && value === '!' && prev.value === '[') { - value = '^'; - } +module.exports = _touch; - prev.value += value; - append({ value }); - continue; - } +function tryStatFile(filePath) { + try { + return common.statFollowLinks(filePath); + } catch (e) { + return null; + } +} - /** - * If we're inside a quoted string, continue - * until we reach the closing double quote. - */ - if (state.quotes === 1 && value !== '"') { - value = utils.escapeRegex(value); - prev.value += value; - append({ value }); - continue; - } +/***/ }), - /** - * Double quotes - */ +/***/ 29095: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { - if (value === '"') { - state.quotes = state.quotes === 1 ? 0 : 1; - if (opts.keepQuotes === true) { - push({ type: 'text', value }); - } - continue; - } +var common = __nccwpck_require__(60624); +var fs = __nccwpck_require__(57147); - /** - * Parentheses - */ +// add c spaces to the left of str +function lpad(c, str) { + var res = '' + str; + if (res.length < c) { + res = Array((c - res.length) + 1).join(' ') + res; + } + return res; +} - if (value === '(') { - increment('parens'); - push({ type: 'paren', value }); - continue; - } +common.register('uniq', _uniq, { + canReceivePipe: true, + cmdOptions: { + 'i': 'ignoreCase', + 'c': 'count', + 'd': 'duplicates', + }, +}); - if (value === ')') { - if (state.parens === 0 && opts.strictBrackets === true) { - throw new SyntaxError(syntaxError('opening', '(')); - } +//@ +//@ ### uniq([options,] [input, [output]]) +//@ +//@ Available options: +//@ +//@ + `-i`: Ignore case while comparing +//@ + `-c`: Prefix lines by the number of occurrences +//@ + `-d`: Only print duplicate lines, one for each group of identical lines +//@ +//@ Examples: +//@ +//@ ```javascript +//@ uniq('foo.txt'); +//@ uniq('-i', 'foo.txt'); +//@ uniq('-cd', 'foo.txt', 'bar.txt'); +//@ ``` +//@ +//@ Filter adjacent matching lines from `input`. +function _uniq(options, input, output) { + // Check if this is coming from a pipe + var pipe = common.readFromPipe(); - const extglob = extglobs[extglobs.length - 1]; - if (extglob && state.parens === extglob.parens + 1) { - extglobClose(extglobs.pop()); - continue; - } + if (!pipe) { + if (!input) common.error('no input given'); - push({ type: 'paren', value, output: state.parens ? ')' : '\\)' }); - decrement('parens'); - continue; + if (!fs.existsSync(input)) { + common.error(input + ': No such file or directory'); + } else if (common.statFollowLinks(input).isDirectory()) { + common.error("error reading '" + input + "'"); } + } + if (output && fs.existsSync(output) && common.statFollowLinks(output).isDirectory()) { + common.error(output + ': Is a directory'); + } - /** - * Square brackets - */ - - if (value === '[') { - if (opts.nobracket === true || !remaining().includes(']')) { - if (opts.nobracket !== true && opts.strictBrackets === true) { - throw new SyntaxError(syntaxError('closing', ']')); - } - - value = `\\${value}`; - } else { - increment('brackets'); - } + var lines = (input ? fs.readFileSync(input, 'utf8') : pipe). + trimRight(). + split('\n'); - push({ type: 'bracket', value }); - continue; + var compare = function (a, b) { + return options.ignoreCase ? + a.toLocaleLowerCase().localeCompare(b.toLocaleLowerCase()) : + a.localeCompare(b); + }; + var uniqed = lines.reduceRight(function (res, e) { + // Perform uniq -c on the input + if (res.length === 0) { + return [{ count: 1, ln: e }]; + } else if (compare(res[0].ln, e) === 0) { + return [{ count: res[0].count + 1, ln: e }].concat(res.slice(1)); + } else { + return [{ count: 1, ln: e }].concat(res); } + }, []).filter(function (obj) { + // Do we want only duplicated objects? + return options.duplicates ? obj.count > 1 : true; + }).map(function (obj) { + // Are we tracking the counts of each line? + return (options.count ? (lpad(7, obj.count) + ' ') : '') + obj.ln; + }).join('\n') + '\n'; - if (value === ']') { - if (opts.nobracket === true || (prev && prev.type === 'bracket' && prev.value.length === 1)) { - push({ type: 'text', value, output: `\\${value}` }); - continue; - } + if (output) { + (new common.ShellString(uniqed)).to(output); + // if uniq writes to output, nothing is passed to the next command in the pipeline (if any) + return ''; + } else { + return uniqed; + } +} - if (state.brackets === 0) { - if (opts.strictBrackets === true) { - throw new SyntaxError(syntaxError('opening', '[')); - } +module.exports = _uniq; - push({ type: 'text', value, output: `\\${value}` }); - continue; - } - decrement('brackets'); +/***/ }), - const prevValue = prev.value.slice(1); - if (prev.posix !== true && prevValue[0] === '^' && !prevValue.includes('/')) { - value = `/${value}`; - } +/***/ 70858: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { - prev.value += value; - append({ value }); +var common = __nccwpck_require__(60624); +var fs = __nccwpck_require__(57147); +var path = __nccwpck_require__(71017); - // when literal brackets are explicitly disabled - // assume we should match with a regex character class - if (opts.literalBrackets === false || utils.hasRegexChars(prevValue)) { - continue; - } +common.register('which', _which, { + allowGlobbing: false, + cmdOptions: { + 'a': 'all', + }, +}); - const escaped = utils.escapeRegex(prev.value); - state.output = state.output.slice(0, -prev.value.length); +// XP's system default value for `PATHEXT` system variable, just in case it's not +// set on Windows. +var XP_DEFAULT_PATHEXT = '.com;.exe;.bat;.cmd;.vbs;.vbe;.js;.jse;.wsf;.wsh'; - // when literal brackets are explicitly enabled - // assume we should escape the brackets to match literal characters - if (opts.literalBrackets === true) { - state.output += escaped; - prev.value = escaped; - continue; - } +// For earlier versions of NodeJS that doesn't have a list of constants (< v6) +var FILE_EXECUTABLE_MODE = 1; - // when the user specifies nothing, try to match both - prev.value = `(${capture}${escaped}|${prev.value})`; - state.output += prev.value; - continue; - } +function isWindowsPlatform() { + return process.platform === 'win32'; +} - /** - * Braces - */ +// Cross-platform method for splitting environment `PATH` variables +function splitPath(p) { + return p ? p.split(path.delimiter) : []; +} - if (value === '{' && opts.nobrace !== true) { - increment('braces'); +// Tests are running all cases for this func but it stays uncovered by codecov due to unknown reason +/* istanbul ignore next */ +function isExecutable(pathName) { + try { + // TODO(node-support): replace with fs.constants.X_OK once remove support for node < v6 + fs.accessSync(pathName, FILE_EXECUTABLE_MODE); + } catch (err) { + return false; + } + return true; +} - const open = { - type: 'brace', - value, - output: '(', - outputIndex: state.output.length, - tokensIndex: state.tokens.length - }; +function checkPath(pathName) { + return fs.existsSync(pathName) && !common.statFollowLinks(pathName).isDirectory() + && (isWindowsPlatform() || isExecutable(pathName)); +} - braces.push(open); - push(open); - continue; - } +//@ +//@ ### which(command) +//@ +//@ Examples: +//@ +//@ ```javascript +//@ var nodeExec = which('node'); +//@ ``` +//@ +//@ Searches for `command` in the system's `PATH`. On Windows, this uses the +//@ `PATHEXT` variable to append the extension if it's not already executable. +//@ Returns string containing the absolute path to `command`. +function _which(options, cmd) { + if (!cmd) common.error('must specify command'); - if (value === '}') { - const brace = braces[braces.length - 1]; + var isWindows = isWindowsPlatform(); + var pathArray = splitPath(process.env.PATH); - if (opts.nobrace === true || !brace) { - push({ type: 'text', value, output: value }); - continue; - } + var queryMatches = []; - let output = ')'; + // No relative/absolute paths provided? + if (cmd.indexOf('/') === -1) { + // Assume that there are no extensions to append to queries (this is the + // case for unix) + var pathExtArray = ['']; + if (isWindows) { + // In case the PATHEXT variable is somehow not set (e.g. + // child_process.spawn with an empty environment), use the XP default. + var pathExtEnv = process.env.PATHEXT || XP_DEFAULT_PATHEXT; + pathExtArray = splitPath(pathExtEnv.toUpperCase()); + } - if (brace.dots === true) { - const arr = tokens.slice(); - const range = []; + // Search for command in PATH + for (var k = 0; k < pathArray.length; k++) { + // already found it + if (queryMatches.length > 0 && !options.all) break; - for (let i = arr.length - 1; i >= 0; i--) { - tokens.pop(); - if (arr[i].type === 'brace') { - break; - } - if (arr[i].type !== 'dots') { - range.unshift(arr[i].value); - } - } + var attempt = path.resolve(pathArray[k], cmd); - output = expandRange(range, opts); - state.backtrack = true; + if (isWindows) { + attempt = attempt.toUpperCase(); } - if (brace.comma !== true && brace.dots !== true) { - const out = state.output.slice(0, brace.outputIndex); - const toks = state.tokens.slice(brace.tokensIndex); - brace.value = brace.output = '\\{'; - value = output = '\\}'; - state.output = out; - for (const t of toks) { - state.output += (t.output || t.value); + var match = attempt.match(/\.[^<>:"/\|?*.]+$/); + if (match && pathExtArray.indexOf(match[0]) >= 0) { // this is Windows-only + // The user typed a query with the file extension, like + // `which('node.exe')` + if (checkPath(attempt)) { + queryMatches.push(attempt); + break; + } + } else { // All-platforms + // Cycle through the PATHEXT array, and check each extension + // Note: the array is always [''] on Unix + for (var i = 0; i < pathExtArray.length; i++) { + var ext = pathExtArray[i]; + var newAttempt = attempt + ext; + if (checkPath(newAttempt)) { + queryMatches.push(newAttempt); + break; + } } } - - push({ type: 'brace', value, output }); - decrement('braces'); - braces.pop(); - continue; } + } else if (checkPath(cmd)) { // a valid absolute or relative path + queryMatches.push(path.resolve(cmd)); + } - /** - * Pipes - */ + if (queryMatches.length > 0) { + return options.all ? queryMatches : queryMatches[0]; + } + return options.all ? [] : null; +} +module.exports = _which; - if (value === '|') { - if (extglobs.length > 0) { - extglobs[extglobs.length - 1].conditions++; - } - push({ type: 'text', value }); - continue; - } - /** - * Commas - */ +/***/ }), - if (value === ',') { - let output = value; +/***/ 98841: +/***/ ((module, exports, __nccwpck_require__) => { - const brace = braces[braces.length - 1]; - if (brace && stack[stack.length - 1] === 'braces') { - brace.comma = true; - output = '|'; - } +/* module decorator */ module = __nccwpck_require__.nmd(module); +var SourceMapConsumer = (__nccwpck_require__(53439).SourceMapConsumer); +var path = __nccwpck_require__(71017); - push({ type: 'comma', value, output }); - continue; - } +var fs; +try { + fs = __nccwpck_require__(57147); + if (!fs.existsSync || !fs.readFileSync) { + // fs doesn't have all methods we need + fs = null; + } +} catch (err) { + /* nop */ +} - /** - * Slashes - */ +var bufferFrom = __nccwpck_require__(11720); - if (value === '/') { - // if the beginning of the glob is "./", advance the start - // to the current index, and don't add the "./" characters - // to the state. This greatly simplifies lookbehinds when - // checking for BOS characters like "!" and "." (not "./") - if (prev.type === 'dot' && state.index === state.start + 1) { - state.start = state.index + 1; - state.consumed = ''; - state.output = ''; - tokens.pop(); - prev = bos; // reset "prev" to the first token - continue; - } +/** + * Requires a module which is protected against bundler minification. + * + * @param {NodeModule} mod + * @param {string} request + */ +function dynamicRequire(mod, request) { + return mod.require(request); +} - push({ type: 'slash', value, output: SLASH_LITERAL }); - continue; - } +// Only install once if called multiple times +var errorFormatterInstalled = false; +var uncaughtShimInstalled = false; - /** - * Dots - */ +// If true, the caches are reset before a stack trace formatting operation +var emptyCacheBetweenOperations = false; - if (value === '.') { - if (state.braces > 0 && prev.type === 'dot') { - if (prev.value === '.') prev.output = DOT_LITERAL; - const brace = braces[braces.length - 1]; - prev.type = 'dots'; - prev.output += value; - prev.value += value; - brace.dots = true; - continue; - } +// Supports {browser, node, auto} +var environment = "auto"; - if ((state.braces + state.parens) === 0 && prev.type !== 'bos' && prev.type !== 'slash') { - push({ type: 'text', value, output: DOT_LITERAL }); - continue; - } +// Maps a file path to a string containing the file contents +var fileContentsCache = {}; - push({ type: 'dot', value, output: DOT_LITERAL }); - continue; - } +// Maps a file path to a source map for that file +var sourceMapCache = {}; - /** - * Question marks - */ +// Regex for detecting source maps +var reSourceMap = /^data:application\/json[^,]+base64,/; - if (value === '?') { - const isGroup = prev && prev.value === '('; - if (!isGroup && opts.noextglob !== true && peek() === '(' && peek(2) !== '?') { - extglobOpen('qmark', value); - continue; - } +// Priority list of retrieve handlers +var retrieveFileHandlers = []; +var retrieveMapHandlers = []; - if (prev && prev.type === 'paren') { - const next = peek(); - let output = value; +function isInBrowser() { + if (environment === "browser") + return true; + if (environment === "node") + return false; + return ((typeof window !== 'undefined') && (typeof XMLHttpRequest === 'function') && !(window.require && window.module && window.process && window.process.type === "renderer")); +} - if (next === '<' && !utils.supportsLookbehinds()) { - throw new Error('Node.js v10 or higher is required for regex lookbehinds'); - } +function hasGlobalProcessEventEmitter() { + return ((typeof process === 'object') && (process !== null) && (typeof process.on === 'function')); +} - if ((prev.value === '(' && !/[!=<:]/.test(next)) || (next === '<' && !/<([!=]|\w+>)/.test(remaining()))) { - output = `\\${value}`; - } +function globalProcessVersion() { + if ((typeof process === 'object') && (process !== null)) { + return process.version; + } else { + return ''; + } +} - push({ type: 'text', value, output }); - continue; - } +function globalProcessStderr() { + if ((typeof process === 'object') && (process !== null)) { + return process.stderr; + } +} - if (opts.dot !== true && (prev.type === 'slash' || prev.type === 'bos')) { - push({ type: 'qmark', value, output: QMARK_NO_DOT }); - continue; - } +function globalProcessExit(code) { + if ((typeof process === 'object') && (process !== null) && (typeof process.exit === 'function')) { + return process.exit(code); + } +} - push({ type: 'qmark', value, output: QMARK }); - continue; +function handlerExec(list) { + return function(arg) { + for (var i = 0; i < list.length; i++) { + var ret = list[i](arg); + if (ret) { + return ret; + } } + return null; + }; +} - /** - * Exclamation - */ +var retrieveFile = handlerExec(retrieveFileHandlers); - if (value === '!') { - if (opts.noextglob !== true && peek() === '(') { - if (peek(2) !== '?' || !/[!=<:]/.test(peek(3))) { - extglobOpen('negate', value); - continue; - } - } +retrieveFileHandlers.push(function(path) { + // Trim the path to make sure there is no extra whitespace. + path = path.trim(); + if (/^file:/.test(path)) { + // existsSync/readFileSync can't handle file protocol, but once stripped, it works + path = path.replace(/file:\/\/\/(\w:)?/, function(protocol, drive) { + return drive ? + '' : // file:///C:/dir/file -> C:/dir/file + '/'; // file:///root-dir/file -> /root-dir/file + }); + } + if (path in fileContentsCache) { + return fileContentsCache[path]; + } - if (opts.nonegate !== true && state.index === 0) { - negate(); - continue; + var contents = ''; + try { + if (!fs) { + // Use SJAX if we are in the browser + var xhr = new XMLHttpRequest(); + xhr.open('GET', path, /** async */ false); + xhr.send(null); + if (xhr.readyState === 4 && xhr.status === 200) { + contents = xhr.responseText; } + } else if (fs.existsSync(path)) { + // Otherwise, use the filesystem + contents = fs.readFileSync(path, 'utf8'); } + } catch (er) { + /* ignore any errors */ + } - /** - * Plus - */ + return fileContentsCache[path] = contents; +}); - if (value === '+') { - if (opts.noextglob !== true && peek() === '(' && peek(2) !== '?') { - extglobOpen('plus', value); - continue; - } +// Support URLs relative to a directory, but be careful about a protocol prefix +// in case we are in the browser (i.e. directories may start with "http://" or "file:///") +function supportRelativeURL(file, url) { + if (!file) return url; + var dir = path.dirname(file); + var match = /^\w+:\/\/[^\/]*/.exec(dir); + var protocol = match ? match[0] : ''; + var startPath = dir.slice(protocol.length); + if (protocol && /^\/\w\:/.test(startPath)) { + // handle file:///C:/ paths + protocol += '/'; + return protocol + path.resolve(dir.slice(protocol.length), url).replace(/\\/g, '/'); + } + return protocol + path.resolve(dir.slice(protocol.length), url); +} - if ((prev && prev.value === '(') || opts.regex === false) { - push({ type: 'plus', value, output: PLUS_LITERAL }); - continue; - } +function retrieveSourceMapURL(source) { + var fileData; - if ((prev && (prev.type === 'bracket' || prev.type === 'paren' || prev.type === 'brace')) || state.parens > 0) { - push({ type: 'plus', value }); - continue; - } + if (isInBrowser()) { + try { + var xhr = new XMLHttpRequest(); + xhr.open('GET', source, false); + xhr.send(null); + fileData = xhr.readyState === 4 ? xhr.responseText : null; - push({ type: 'plus', value: PLUS_LITERAL }); - continue; - } + // Support providing a sourceMappingURL via the SourceMap header + var sourceMapHeader = xhr.getResponseHeader("SourceMap") || + xhr.getResponseHeader("X-SourceMap"); + if (sourceMapHeader) { + return sourceMapHeader; + } + } catch (e) { + } + } - /** - * Plain text - */ + // Get the URL of the source map + fileData = retrieveFile(source); + var re = /(?:\/\/[@#][\s]*sourceMappingURL=([^\s'"]+)[\s]*$)|(?:\/\*[@#][\s]*sourceMappingURL=([^\s*'"]+)[\s]*(?:\*\/)[\s]*$)/mg; + // Keep executing the search to find the *last* sourceMappingURL to avoid + // picking up sourceMappingURLs from comments, strings, etc. + var lastMatch, match; + while (match = re.exec(fileData)) lastMatch = match; + if (!lastMatch) return null; + return lastMatch[1]; +}; - if (value === '@') { - if (opts.noextglob !== true && peek() === '(' && peek(2) !== '?') { - push({ type: 'at', extglob: true, value, output: '' }); - continue; - } +// Can be overridden by the retrieveSourceMap option to install. Takes a +// generated source filename; returns a {map, optional url} object, or null if +// there is no source map. The map field may be either a string or the parsed +// JSON object (ie, it must be a valid argument to the SourceMapConsumer +// constructor). +var retrieveSourceMap = handlerExec(retrieveMapHandlers); +retrieveMapHandlers.push(function(source) { + var sourceMappingURL = retrieveSourceMapURL(source); + if (!sourceMappingURL) return null; - push({ type: 'text', value }); - continue; - } + // Read the contents of the source map + var sourceMapData; + if (reSourceMap.test(sourceMappingURL)) { + // Support source map URL as a data url + var rawData = sourceMappingURL.slice(sourceMappingURL.indexOf(',') + 1); + sourceMapData = bufferFrom(rawData, "base64").toString(); + sourceMappingURL = source; + } else { + // Support source map URLs relative to the source URL + sourceMappingURL = supportRelativeURL(source, sourceMappingURL); + sourceMapData = retrieveFile(sourceMappingURL); + } - /** - * Plain text - */ + if (!sourceMapData) { + return null; + } - if (value !== '*') { - if (value === '$' || value === '^') { - value = `\\${value}`; - } + return { + url: sourceMappingURL, + map: sourceMapData + }; +}); - const match = REGEX_NON_SPECIAL_CHARS.exec(remaining()); - if (match) { - value += match[0]; - state.index += match[0].length; - } +function mapSourcePosition(position) { + var sourceMap = sourceMapCache[position.source]; + if (!sourceMap) { + // Call the (overrideable) retrieveSourceMap function to get the source map. + var urlAndMap = retrieveSourceMap(position.source); + if (urlAndMap) { + sourceMap = sourceMapCache[position.source] = { + url: urlAndMap.url, + map: new SourceMapConsumer(urlAndMap.map) + }; - push({ type: 'text', value }); - continue; + // Load all sources stored inline with the source map into the file cache + // to pretend like they are already loaded. They may not exist on disk. + if (sourceMap.map.sourcesContent) { + sourceMap.map.sources.forEach(function(source, i) { + var contents = sourceMap.map.sourcesContent[i]; + if (contents) { + var url = supportRelativeURL(sourceMap.url, source); + fileContentsCache[url] = contents; + } + }); + } + } else { + sourceMap = sourceMapCache[position.source] = { + url: null, + map: null + }; } + } - /** - * Stars - */ + // Resolve the source URL relative to the URL of the source map + if (sourceMap && sourceMap.map && typeof sourceMap.map.originalPositionFor === 'function') { + var originalPosition = sourceMap.map.originalPositionFor(position); - if (prev && (prev.type === 'globstar' || prev.star === true)) { - prev.type = 'star'; - prev.star = true; - prev.value += value; - prev.output = star; - state.backtrack = true; - state.globstar = true; - consume(value); - continue; + // Only return the original position if a matching line was found. If no + // matching line is found then we return position instead, which will cause + // the stack trace to print the path and line for the compiled file. It is + // better to give a precise location in the compiled file than a vague + // location in the original file. + if (originalPosition.source !== null) { + originalPosition.source = supportRelativeURL( + sourceMap.url, originalPosition.source); + return originalPosition; } + } - let rest = remaining(); - if (opts.noextglob !== true && /^\([^?]/.test(rest)) { - extglobOpen('star', value); - continue; - } + return position; +} - if (prev.type === 'star') { - if (opts.noglobstar === true) { - consume(value); - continue; - } +// Parses code generated by FormatEvalOrigin(), a function inside V8: +// https://code.google.com/p/v8/source/browse/trunk/src/messages.js +function mapEvalOrigin(origin) { + // Most eval() calls are in this format + var match = /^eval at ([^(]+) \((.+):(\d+):(\d+)\)$/.exec(origin); + if (match) { + var position = mapSourcePosition({ + source: match[2], + line: +match[3], + column: match[4] - 1 + }); + return 'eval at ' + match[1] + ' (' + position.source + ':' + + position.line + ':' + (position.column + 1) + ')'; + } - const prior = prev.prev; - const before = prior.prev; - const isStart = prior.type === 'slash' || prior.type === 'bos'; - const afterStar = before && (before.type === 'star' || before.type === 'globstar'); + // Parse nested eval() calls using recursion + match = /^eval at ([^(]+) \((.+)\)$/.exec(origin); + if (match) { + return 'eval at ' + match[1] + ' (' + mapEvalOrigin(match[2]) + ')'; + } - if (opts.bash === true && (!isStart || (rest[0] && rest[0] !== '/'))) { - push({ type: 'star', value, output: '' }); - continue; - } + // Make sure we still return useful information if we didn't find anything + return origin; +} - const isBrace = state.braces > 0 && (prior.type === 'comma' || prior.type === 'brace'); - const isExtglob = extglobs.length && (prior.type === 'pipe' || prior.type === 'paren'); - if (!isStart && prior.type !== 'paren' && !isBrace && !isExtglob) { - push({ type: 'star', value, output: '' }); - continue; - } +// This is copied almost verbatim from the V8 source code at +// https://code.google.com/p/v8/source/browse/trunk/src/messages.js. The +// implementation of wrapCallSite() used to just forward to the actual source +// code of CallSite.prototype.toString but unfortunately a new release of V8 +// did something to the prototype chain and broke the shim. The only fix I +// could find was copy/paste. +function CallSiteToString() { + var fileName; + var fileLocation = ""; + if (this.isNative()) { + fileLocation = "native"; + } else { + fileName = this.getScriptNameOrSourceURL(); + if (!fileName && this.isEval()) { + fileLocation = this.getEvalOrigin(); + fileLocation += ", "; // Expecting source position to follow. + } - // strip consecutive `/**/` - while (rest.slice(0, 3) === '/**') { - const after = input[state.index + 4]; - if (after && after !== '/') { - break; - } - rest = rest.slice(3); - consume('/**', 3); + if (fileName) { + fileLocation += fileName; + } else { + // Source code does not originate from a file and is not native, but we + // can still get the source position inside the source string, e.g. in + // an eval string. + fileLocation += ""; + } + var lineNumber = this.getLineNumber(); + if (lineNumber != null) { + fileLocation += ":" + lineNumber; + var columnNumber = this.getColumnNumber(); + if (columnNumber) { + fileLocation += ":" + columnNumber; } + } + } - if (prior.type === 'bos' && eos()) { - prev.type = 'globstar'; - prev.value += value; - prev.output = globstar(opts); - state.output = prev.output; - state.globstar = true; - consume(value); - continue; + var line = ""; + var functionName = this.getFunctionName(); + var addSuffix = true; + var isConstructor = this.isConstructor(); + var isMethodCall = !(this.isToplevel() || isConstructor); + if (isMethodCall) { + var typeName = this.getTypeName(); + // Fixes shim to be backward compatable with Node v0 to v4 + if (typeName === "[object Object]") { + typeName = "null"; + } + var methodName = this.getMethodName(); + if (functionName) { + if (typeName && functionName.indexOf(typeName) != 0) { + line += typeName + "."; } - - if (prior.type === 'slash' && prior.prev.type !== 'bos' && !afterStar && eos()) { - state.output = state.output.slice(0, -(prior.output + prev.output).length); - prior.output = `(?:${prior.output}`; - - prev.type = 'globstar'; - prev.output = globstar(opts) + (opts.strictSlashes ? ')' : '|$)'); - prev.value += value; - state.globstar = true; - state.output += prior.output + prev.output; - consume(value); - continue; + line += functionName; + if (methodName && functionName.indexOf("." + methodName) != functionName.length - methodName.length - 1) { + line += " [as " + methodName + "]"; } + } else { + line += typeName + "." + (methodName || ""); + } + } else if (isConstructor) { + line += "new " + (functionName || ""); + } else if (functionName) { + line += functionName; + } else { + line += fileLocation; + addSuffix = false; + } + if (addSuffix) { + line += " (" + fileLocation + ")"; + } + return line; +} - if (prior.type === 'slash' && prior.prev.type !== 'bos' && rest[0] === '/') { - const end = rest[1] !== void 0 ? '|$' : ''; - - state.output = state.output.slice(0, -(prior.output + prev.output).length); - prior.output = `(?:${prior.output}`; - - prev.type = 'globstar'; - prev.output = `${globstar(opts)}${SLASH_LITERAL}|${SLASH_LITERAL}${end})`; - prev.value += value; +function cloneCallSite(frame) { + var object = {}; + Object.getOwnPropertyNames(Object.getPrototypeOf(frame)).forEach(function(name) { + object[name] = /^(?:is|get)/.test(name) ? function() { return frame[name].call(frame); } : frame[name]; + }); + object.toString = CallSiteToString; + return object; +} - state.output += prior.output + prev.output; - state.globstar = true; +function wrapCallSite(frame, state) { + // provides interface backward compatibility + if (state === undefined) { + state = { nextPosition: null, curPosition: null } + } + if(frame.isNative()) { + state.curPosition = null; + return frame; + } - consume(value + advance()); + // Most call sites will return the source file from getFileName(), but code + // passed to eval() ending in "//# sourceURL=..." will return the source file + // from getScriptNameOrSourceURL() instead + var source = frame.getFileName() || frame.getScriptNameOrSourceURL(); + if (source) { + var line = frame.getLineNumber(); + var column = frame.getColumnNumber() - 1; - push({ type: 'slash', value: '/', output: '' }); - continue; - } + // Fix position in Node where some (internal) code is prepended. + // See https://github.com/evanw/node-source-map-support/issues/36 + // Header removed in node at ^10.16 || >=11.11.0 + // v11 is not an LTS candidate, we can just test the one version with it. + // Test node versions for: 10.16-19, 10.20+, 12-19, 20-99, 100+, or 11.11 + var noHeader = /^v(10\.1[6-9]|10\.[2-9][0-9]|10\.[0-9]{3,}|1[2-9]\d*|[2-9]\d|\d{3,}|11\.11)/; + var headerLength = noHeader.test(globalProcessVersion()) ? 0 : 62; + if (line === 1 && column > headerLength && !isInBrowser() && !frame.isEval()) { + column -= headerLength; + } - if (prior.type === 'bos' && rest[0] === '/') { - prev.type = 'globstar'; - prev.value += value; - prev.output = `(?:^|${SLASH_LITERAL}|${globstar(opts)}${SLASH_LITERAL})`; - state.output = prev.output; - state.globstar = true; - consume(value + advance()); - push({ type: 'slash', value: '/', output: '' }); - continue; + var position = mapSourcePosition({ + source: source, + line: line, + column: column + }); + state.curPosition = position; + frame = cloneCallSite(frame); + var originalFunctionName = frame.getFunctionName; + frame.getFunctionName = function() { + if (state.nextPosition == null) { + return originalFunctionName(); } + return state.nextPosition.name || originalFunctionName(); + }; + frame.getFileName = function() { return position.source; }; + frame.getLineNumber = function() { return position.line; }; + frame.getColumnNumber = function() { return position.column + 1; }; + frame.getScriptNameOrSourceURL = function() { return position.source; }; + return frame; + } - // remove single star from output - state.output = state.output.slice(0, -prev.output.length); - - // reset previous token to globstar - prev.type = 'globstar'; - prev.output = globstar(opts); - prev.value += value; + // Code called using eval() needs special handling + var origin = frame.isEval() && frame.getEvalOrigin(); + if (origin) { + origin = mapEvalOrigin(origin); + frame = cloneCallSite(frame); + frame.getEvalOrigin = function() { return origin; }; + return frame; + } - // reset output with globstar - state.output += prev.output; - state.globstar = true; - consume(value); - continue; - } + // If we get here then we were unable to change the source position + return frame; +} - const token = { type: 'star', value, output: star }; +// This function is part of the V8 stack trace API, for more info see: +// https://v8.dev/docs/stack-trace-api +function prepareStackTrace(error, stack) { + if (emptyCacheBetweenOperations) { + fileContentsCache = {}; + sourceMapCache = {}; + } - if (opts.bash === true) { - token.output = '.*?'; - if (prev.type === 'bos' || prev.type === 'slash') { - token.output = nodot + token.output; - } - push(token); - continue; - } + var name = error.name || 'Error'; + var message = error.message || ''; + var errorString = name + ": " + message; - if (prev && (prev.type === 'bracket' || prev.type === 'paren') && opts.regex === true) { - token.output = value; - push(token); - continue; - } + var state = { nextPosition: null, curPosition: null }; + var processedStack = []; + for (var i = stack.length - 1; i >= 0; i--) { + processedStack.push('\n at ' + wrapCallSite(stack[i], state)); + state.nextPosition = state.curPosition; + } + state.curPosition = state.nextPosition = null; + return errorString + processedStack.reverse().join(''); +} - if (state.index === state.start || prev.type === 'slash' || prev.type === 'dot') { - if (prev.type === 'dot') { - state.output += NO_DOT_SLASH; - prev.output += NO_DOT_SLASH; +// Generate position and snippet of original source with pointer +function getErrorSource(error) { + var match = /\n at [^(]+ \((.*):(\d+):(\d+)\)/.exec(error.stack); + if (match) { + var source = match[1]; + var line = +match[2]; + var column = +match[3]; - } else if (opts.dot === true) { - state.output += NO_DOTS_SLASH; - prev.output += NO_DOTS_SLASH; + // Support the inline sourceContents inside the source map + var contents = fileContentsCache[source]; - } else { - state.output += nodot; - prev.output += nodot; + // Support files on disk + if (!contents && fs && fs.existsSync(source)) { + try { + contents = fs.readFileSync(source, 'utf8'); + } catch (er) { + contents = ''; } + } - if (peek() !== '*') { - state.output += ONE_CHAR; - prev.output += ONE_CHAR; + // Format the line from the original source code like node does + if (contents) { + var code = contents.split(/(?:\r\n|\r|\n)/)[line - 1]; + if (code) { + return source + ':' + line + '\n' + code + '\n' + + new Array(column).join(' ') + '^'; } } - - push(token); } + return null; +} - while (state.brackets > 0) { - if (opts.strictBrackets === true) throw new SyntaxError(syntaxError('closing', ']')); - state.output = utils.escapeLast(state.output, '['); - decrement('brackets'); - } +function printErrorAndExit (error) { + var source = getErrorSource(error); - while (state.parens > 0) { - if (opts.strictBrackets === true) throw new SyntaxError(syntaxError('closing', ')')); - state.output = utils.escapeLast(state.output, '('); - decrement('parens'); + // Ensure error is printed synchronously and not truncated + var stderr = globalProcessStderr(); + if (stderr && stderr._handle && stderr._handle.setBlocking) { + stderr._handle.setBlocking(true); } - while (state.braces > 0) { - if (opts.strictBrackets === true) throw new SyntaxError(syntaxError('closing', '}')); - state.output = utils.escapeLast(state.output, '{'); - decrement('braces'); + if (source) { + console.error(); + console.error(source); } - if (opts.strictSlashes !== true && (prev.type === 'star' || prev.type === 'bracket')) { - push({ type: 'maybe_slash', value: '', output: `${SLASH_LITERAL}?` }); - } + console.error(error.stack); + globalProcessExit(1); +} - // rebuild the output if we had to backtrack at any point - if (state.backtrack === true) { - state.output = ''; +function shimEmitUncaughtException () { + var origEmit = process.emit; - for (const token of state.tokens) { - state.output += token.output != null ? token.output : token.value; + process.emit = function (type) { + if (type === 'uncaughtException') { + var hasStack = (arguments[1] && arguments[1].stack); + var hasListeners = (this.listeners(type).length > 0); - if (token.suffix) { - state.output += token.suffix; + if (hasStack && !hasListeners) { + return printErrorAndExit(arguments[1]); } } - } - return state; -}; - -/** - * Fast paths for creating regular expressions for common glob patterns. - * This can significantly speed up processing and has very little downside - * impact when none of the fast paths match. - */ - -parse.fastpaths = (input, options) => { - const opts = { ...options }; - const max = typeof opts.maxLength === 'number' ? Math.min(MAX_LENGTH, opts.maxLength) : MAX_LENGTH; - const len = input.length; - if (len > max) { - throw new SyntaxError(`Input length: ${len}, exceeds maximum allowed length: ${max}`); - } - - input = REPLACEMENTS[input] || input; - const win32 = utils.isWindows(options); - - // create constants based on platform, for windows or posix - const { - DOT_LITERAL, - SLASH_LITERAL, - ONE_CHAR, - DOTS_SLASH, - NO_DOT, - NO_DOTS, - NO_DOTS_SLASH, - STAR, - START_ANCHOR - } = constants.globChars(win32); - - const nodot = opts.dot ? NO_DOTS : NO_DOT; - const slashDot = opts.dot ? NO_DOTS_SLASH : NO_DOT; - const capture = opts.capture ? '' : '?:'; - const state = { negated: false, prefix: '' }; - let star = opts.bash === true ? '.*?' : STAR; - - if (opts.capture) { - star = `(${star})`; - } - - const globstar = opts => { - if (opts.noglobstar === true) return star; - return `(${capture}(?:(?!${START_ANCHOR}${opts.dot ? DOTS_SLASH : DOT_LITERAL}).)*?)`; + return origEmit.apply(this, arguments); }; +} - const create = str => { - switch (str) { - case '*': - return `${nodot}${ONE_CHAR}${star}`; - - case '.*': - return `${DOT_LITERAL}${ONE_CHAR}${star}`; - - case '*.*': - return `${nodot}${star}${DOT_LITERAL}${ONE_CHAR}${star}`; - - case '*/*': - return `${nodot}${star}${SLASH_LITERAL}${ONE_CHAR}${slashDot}${star}`; - - case '**': - return nodot + globstar(opts); - - case '**/*': - return `(?:${nodot}${globstar(opts)}${SLASH_LITERAL})?${slashDot}${ONE_CHAR}${star}`; - - case '**/*.*': - return `(?:${nodot}${globstar(opts)}${SLASH_LITERAL})?${slashDot}${star}${DOT_LITERAL}${ONE_CHAR}${star}`; - - case '**/.*': - return `(?:${nodot}${globstar(opts)}${SLASH_LITERAL})?${DOT_LITERAL}${ONE_CHAR}${star}`; +var originalRetrieveFileHandlers = retrieveFileHandlers.slice(0); +var originalRetrieveMapHandlers = retrieveMapHandlers.slice(0); - default: { - const match = /^(.*?)\.(\w+)$/.exec(str); - if (!match) return; +exports.wrapCallSite = wrapCallSite; +exports.getErrorSource = getErrorSource; +exports.mapSourcePosition = mapSourcePosition; +exports.retrieveSourceMap = retrieveSourceMap; - const source = create(match[1]); - if (!source) return; +exports.install = function(options) { + options = options || {}; - return source + DOT_LITERAL + match[2]; - } + if (options.environment) { + environment = options.environment; + if (["node", "browser", "auto"].indexOf(environment) === -1) { + throw new Error("environment " + environment + " was unknown. Available options are {auto, browser, node}") } - }; - - const output = utils.removePrefix(input, state); - let source = create(output); - - if (source && opts.strictSlashes !== true) { - source += `${SLASH_LITERAL}?`; } - return source; -}; - -module.exports = parse; - - -/***/ }), - -/***/ 74070: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { - -"use strict"; - - -const path = __nccwpck_require__(71017); -const scan = __nccwpck_require__(61910); -const parse = __nccwpck_require__(90207); -const utils = __nccwpck_require__(76088); -const constants = __nccwpck_require__(67582); -const isObject = val => val && typeof val === 'object' && !Array.isArray(val); - -/** - * Creates a matcher function from one or more glob patterns. The - * returned function takes a string to match as its first argument, - * and returns true if the string is a match. The returned matcher - * function also takes a boolean as the second argument that, when true, - * returns an object with additional information. - * - * ```js - * const picomatch = require('picomatch'); - * // picomatch(glob[, options]); - * - * const isMatch = picomatch('*.!(*a)'); - * console.log(isMatch('a.a')); //=> false - * console.log(isMatch('a.b')); //=> true - * ``` - * @name picomatch - * @param {String|Array} `globs` One or more glob patterns. - * @param {Object=} `options` - * @return {Function=} Returns a matcher function. - * @api public - */ + // Allow sources to be found by methods other than reading the files + // directly from disk. + if (options.retrieveFile) { + if (options.overrideRetrieveFile) { + retrieveFileHandlers.length = 0; + } -const picomatch = (glob, options, returnState = false) => { - if (Array.isArray(glob)) { - const fns = glob.map(input => picomatch(input, options, returnState)); - const arrayMatcher = str => { - for (const isMatch of fns) { - const state = isMatch(str); - if (state) return state; - } - return false; - }; - return arrayMatcher; + retrieveFileHandlers.unshift(options.retrieveFile); } - const isState = isObject(glob) && glob.tokens && glob.input; + // Allow source maps to be found by methods other than reading the files + // directly from disk. + if (options.retrieveSourceMap) { + if (options.overrideRetrieveSourceMap) { + retrieveMapHandlers.length = 0; + } - if (glob === '' || (typeof glob !== 'string' && !isState)) { - throw new TypeError('Expected pattern to be a non-empty string'); + retrieveMapHandlers.unshift(options.retrieveSourceMap); } - const opts = options || {}; - const posix = utils.isWindows(options); - const regex = isState - ? picomatch.compileRe(glob, options) - : picomatch.makeRe(glob, options, false, true); + // Support runtime transpilers that include inline source maps + if (options.hookRequire && !isInBrowser()) { + // Use dynamicRequire to avoid including in browser bundles + var Module = dynamicRequire(module, 'module'); + var $compile = Module.prototype._compile; - const state = regex.state; - delete regex.state; + if (!$compile.__sourceMapSupport) { + Module.prototype._compile = function(content, filename) { + fileContentsCache[filename] = content; + sourceMapCache[filename] = undefined; + return $compile.call(this, content, filename); + }; - let isIgnored = () => false; - if (opts.ignore) { - const ignoreOpts = { ...options, ignore: null, onMatch: null, onResult: null }; - isIgnored = picomatch(opts.ignore, ignoreOpts, returnState); + Module.prototype._compile.__sourceMapSupport = true; + } } - const matcher = (input, returnObject = false) => { - const { isMatch, match, output } = picomatch.test(input, regex, options, { glob, posix }); - const result = { glob, state, regex, posix, input, output, match, isMatch }; + // Configure options + if (!emptyCacheBetweenOperations) { + emptyCacheBetweenOperations = 'emptyCacheBetweenOperations' in options ? + options.emptyCacheBetweenOperations : false; + } - if (typeof opts.onResult === 'function') { - opts.onResult(result); - } + // Install the error reformatter + if (!errorFormatterInstalled) { + errorFormatterInstalled = true; + Error.prepareStackTrace = prepareStackTrace; + } - if (isMatch === false) { - result.isMatch = false; - return returnObject ? result : false; - } + if (!uncaughtShimInstalled) { + var installHandler = 'handleUncaughtExceptions' in options ? + options.handleUncaughtExceptions : true; - if (isIgnored(input)) { - if (typeof opts.onIgnore === 'function') { - opts.onIgnore(result); + // Do not override 'uncaughtException' with our own handler in Node.js + // Worker threads. Workers pass the error to the main thread as an event, + // rather than printing something to stderr and exiting. + try { + // We need to use `dynamicRequire` because `require` on it's own will be optimized by WebPack/Browserify. + var worker_threads = dynamicRequire(module, 'worker_threads'); + if (worker_threads.isMainThread === false) { + installHandler = false; } - result.isMatch = false; - return returnObject ? result : false; - } + } catch(e) {} - if (typeof opts.onMatch === 'function') { - opts.onMatch(result); + // Provide the option to not install the uncaught exception handler. This is + // to support other uncaught exception handlers (in test frameworks, for + // example). If this handler is not installed and there are no other uncaught + // exception handlers, uncaught exceptions will be caught by node's built-in + // exception handler and the process will still be terminated. However, the + // generated JavaScript code will be shown above the stack trace instead of + // the original source code. + if (installHandler && hasGlobalProcessEventEmitter()) { + uncaughtShimInstalled = true; + shimEmitUncaughtException(); } - return returnObject ? result : true; - }; - - if (returnState) { - matcher.state = state; } - - return matcher; }; -/** - * Test `input` with the given `regex`. This is used by the main - * `picomatch()` function to test the input string. - * - * ```js - * const picomatch = require('picomatch'); - * // picomatch.test(input, regex[, options]); - * - * console.log(picomatch.test('foo/bar', /^(?:([^/]*?)\/([^/]*?))$/)); - * // { isMatch: true, match: [ 'foo/', 'foo', 'bar' ], output: 'foo/bar' } - * ``` - * @param {String} `input` String to test. - * @param {RegExp} `regex` - * @return {Object} Returns an object with matching info. - * @api public - */ +exports.resetRetrieveHandlers = function() { + retrieveFileHandlers.length = 0; + retrieveMapHandlers.length = 0; -picomatch.test = (input, regex, options, { glob, posix } = {}) => { - if (typeof input !== 'string') { - throw new TypeError('Expected input to be a string'); - } + retrieveFileHandlers = originalRetrieveFileHandlers.slice(0); + retrieveMapHandlers = originalRetrieveMapHandlers.slice(0); - if (input === '') { - return { isMatch: false, output: '' }; - } + retrieveSourceMap = handlerExec(retrieveMapHandlers); + retrieveFile = handlerExec(retrieveFileHandlers); +} - const opts = options || {}; - const format = opts.format || (posix ? utils.toPosixSlashes : null); - let match = input === glob; - let output = (match && format) ? format(input) : input; - if (match === false) { - output = format ? format(input) : input; - match = output === glob; - } +/***/ }), - if (match === false || opts.capture === true) { - if (opts.matchBase === true || opts.basename === true) { - match = picomatch.matchBase(input, regex, options, posix); - } else { - match = regex.exec(output); - } - } - - return { isMatch: Boolean(match), match, output }; -}; +/***/ 62880: +/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { -/** - * Match the basename of a filepath. - * - * ```js - * const picomatch = require('picomatch'); - * // picomatch.matchBase(input, glob[, options]); - * console.log(picomatch.matchBase('foo/bar.js', '*.js'); // true - * ``` - * @param {String} `input` String to test. - * @param {RegExp|String} `glob` Glob pattern or regex created by [.makeRe](#makeRe). - * @return {Boolean} - * @api public +/* -*- Mode: js; js-indent-level: 2; -*- */ +/* + * Copyright 2011 Mozilla Foundation and contributors + * Licensed under the New BSD license. See LICENSE or: + * http://opensource.org/licenses/BSD-3-Clause */ -picomatch.matchBase = (input, glob, options, posix = utils.isWindows(options)) => { - const regex = glob instanceof RegExp ? glob : picomatch.makeRe(glob, options); - return regex.test(path.basename(input)); -}; +var util = __nccwpck_require__(89479); +var has = Object.prototype.hasOwnProperty; +var hasNativeMap = typeof Map !== "undefined"; /** - * Returns true if **any** of the given glob `patterns` match the specified `string`. - * - * ```js - * const picomatch = require('picomatch'); - * // picomatch.isMatch(string, patterns[, options]); - * - * console.log(picomatch.isMatch('a.a', ['b.*', '*.a'])); //=> true - * console.log(picomatch.isMatch('a.a', 'b.*')); //=> false - * ``` - * @param {String|Array} str The string to test. - * @param {String|Array} patterns One or more glob patterns to use for matching. - * @param {Object} [options] See available [options](#options). - * @return {Boolean} Returns true if any patterns match `str` - * @api public + * A data structure which is a combination of an array and a set. Adding a new + * member is O(1), testing for membership is O(1), and finding the index of an + * element is O(1). Removing elements from the set is not supported. Only + * strings are supported for membership. */ - -picomatch.isMatch = (str, patterns, options) => picomatch(patterns, options)(str); +function ArraySet() { + this._array = []; + this._set = hasNativeMap ? new Map() : Object.create(null); +} /** - * Parse a glob pattern to create the source string for a regular - * expression. - * - * ```js - * const picomatch = require('picomatch'); - * const result = picomatch.parse(pattern[, options]); - * ``` - * @param {String} `pattern` - * @param {Object} `options` - * @return {Object} Returns an object with useful properties and output to be used as a regex source string. - * @api public + * Static method for creating ArraySet instances from an existing array. */ - -picomatch.parse = (pattern, options) => { - if (Array.isArray(pattern)) return pattern.map(p => picomatch.parse(p, options)); - return parse(pattern, { ...options, fastpaths: false }); +ArraySet.fromArray = function ArraySet_fromArray(aArray, aAllowDuplicates) { + var set = new ArraySet(); + for (var i = 0, len = aArray.length; i < len; i++) { + set.add(aArray[i], aAllowDuplicates); + } + return set; }; /** - * Scan a glob pattern to separate the pattern into segments. - * - * ```js - * const picomatch = require('picomatch'); - * // picomatch.scan(input[, options]); + * Return how many unique items are in this ArraySet. If duplicates have been + * added, than those do not count towards the size. * - * const result = picomatch.scan('!./foo/*.js'); - * console.log(result); - * { prefix: '!./', - * input: '!./foo/*.js', - * start: 3, - * base: 'foo', - * glob: '*.js', - * isBrace: false, - * isBracket: false, - * isGlob: true, - * isExtglob: false, - * isGlobstar: false, - * negated: true } - * ``` - * @param {String} `input` Glob pattern to scan. - * @param {Object} `options` - * @return {Object} Returns an object with - * @api public + * @returns Number */ - -picomatch.scan = (input, options) => scan(input, options); +ArraySet.prototype.size = function ArraySet_size() { + return hasNativeMap ? this._set.size : Object.getOwnPropertyNames(this._set).length; +}; /** - * Compile a regular expression from the `state` object returned by the - * [parse()](#parse) method. + * Add the given string to this set. * - * @param {Object} `state` - * @param {Object} `options` - * @param {Boolean} `returnOutput` Intended for implementors, this argument allows you to return the raw output from the parser. - * @param {Boolean} `returnState` Adds the state to a `state` property on the returned regex. Useful for implementors and debugging. - * @return {RegExp} - * @api public + * @param String aStr */ - -picomatch.compileRe = (state, options, returnOutput = false, returnState = false) => { - if (returnOutput === true) { - return state.output; - } - - const opts = options || {}; - const prepend = opts.contains ? '' : '^'; - const append = opts.contains ? '' : '$'; - - let source = `${prepend}(?:${state.output})${append}`; - if (state && state.negated === true) { - source = `^(?!${source}).*$`; +ArraySet.prototype.add = function ArraySet_add(aStr, aAllowDuplicates) { + var sStr = hasNativeMap ? aStr : util.toSetString(aStr); + var isDuplicate = hasNativeMap ? this.has(aStr) : has.call(this._set, sStr); + var idx = this._array.length; + if (!isDuplicate || aAllowDuplicates) { + this._array.push(aStr); } - - const regex = picomatch.toRegex(source, options); - if (returnState === true) { - regex.state = state; + if (!isDuplicate) { + if (hasNativeMap) { + this._set.set(aStr, idx); + } else { + this._set[sStr] = idx; + } } - - return regex; }; /** - * Create a regular expression from a parsed glob pattern. - * - * ```js - * const picomatch = require('picomatch'); - * const state = picomatch.parse('*.js'); - * // picomatch.compileRe(state[, options]); + * Is the given string a member of this set? * - * console.log(picomatch.compileRe(state)); - * //=> /^(?:(?!\.)(?=.)[^/]*?\.js)$/ - * ``` - * @param {String} `state` The object returned from the `.parse` method. - * @param {Object} `options` - * @param {Boolean} `returnOutput` Implementors may use this argument to return the compiled output, instead of a regular expression. This is not exposed on the options to prevent end-users from mutating the result. - * @param {Boolean} `returnState` Implementors may use this argument to return the state from the parsed glob with the returned regular expression. - * @return {RegExp} Returns a regex created from the given pattern. - * @api public + * @param String aStr */ - -picomatch.makeRe = (input, options = {}, returnOutput = false, returnState = false) => { - if (!input || typeof input !== 'string') { - throw new TypeError('Expected a non-empty string'); - } - - let parsed = { negated: false, fastpaths: true }; - - if (options.fastpaths !== false && (input[0] === '.' || input[0] === '*')) { - parsed.output = parse.fastpaths(input, options); - } - - if (!parsed.output) { - parsed = parse(input, options); +ArraySet.prototype.has = function ArraySet_has(aStr) { + if (hasNativeMap) { + return this._set.has(aStr); + } else { + var sStr = util.toSetString(aStr); + return has.call(this._set, sStr); } - - return picomatch.compileRe(parsed, options, returnOutput, returnState); }; /** - * Create a regular expression from the given regex source string. - * - * ```js - * const picomatch = require('picomatch'); - * // picomatch.toRegex(source[, options]); + * What is the index of the given string in the array? * - * const { output } = picomatch.parse('*.js'); - * console.log(picomatch.toRegex(output)); - * //=> /^(?:(?!\.)(?=.)[^/]*?\.js)$/ - * ``` - * @param {String} `source` Regular expression source string. - * @param {Object} `options` - * @return {RegExp} - * @api public + * @param String aStr */ - -picomatch.toRegex = (source, options) => { - try { - const opts = options || {}; - return new RegExp(source, opts.flags || (opts.nocase ? 'i' : '')); - } catch (err) { - if (options && options.debug === true) throw err; - return /$^/; +ArraySet.prototype.indexOf = function ArraySet_indexOf(aStr) { + if (hasNativeMap) { + var idx = this._set.get(aStr); + if (idx >= 0) { + return idx; + } + } else { + var sStr = util.toSetString(aStr); + if (has.call(this._set, sStr)) { + return this._set[sStr]; + } } + + throw new Error('"' + aStr + '" is not in the set.'); }; /** - * Picomatch constants. - * @return {Object} + * What is the element at the given index? + * + * @param Number aIdx */ - -picomatch.constants = constants; +ArraySet.prototype.at = function ArraySet_at(aIdx) { + if (aIdx >= 0 && aIdx < this._array.length) { + return this._array[aIdx]; + } + throw new Error('No element indexed by ' + aIdx); +}; /** - * Expose "picomatch" + * Returns the array representation of this set (which has the proper indices + * indicated by indexOf). Note that this is a copy of the internal array used + * for storing the members so that no one can mess with internal state. */ +ArraySet.prototype.toArray = function ArraySet_toArray() { + return this._array.slice(); +}; -module.exports = picomatch; +exports.I = ArraySet; /***/ }), -/***/ 61910: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { - -"use strict"; - - -const utils = __nccwpck_require__(76088); -const { - CHAR_ASTERISK, /* * */ - CHAR_AT, /* @ */ - CHAR_BACKWARD_SLASH, /* \ */ - CHAR_COMMA, /* , */ - CHAR_DOT, /* . */ - CHAR_EXCLAMATION_MARK, /* ! */ - CHAR_FORWARD_SLASH, /* / */ - CHAR_LEFT_CURLY_BRACE, /* { */ - CHAR_LEFT_PARENTHESES, /* ( */ - CHAR_LEFT_SQUARE_BRACKET, /* [ */ - CHAR_PLUS, /* + */ - CHAR_QUESTION_MARK, /* ? */ - CHAR_RIGHT_CURLY_BRACE, /* } */ - CHAR_RIGHT_PARENTHESES, /* ) */ - CHAR_RIGHT_SQUARE_BRACKET /* ] */ -} = __nccwpck_require__(67582); - -const isPathSeparator = code => { - return code === CHAR_FORWARD_SLASH || code === CHAR_BACKWARD_SLASH; -}; - -const depth = token => { - if (token.isPrefix !== true) { - token.depth = token.isGlobstar ? Infinity : 1; - } -}; +/***/ 26672: +/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { -/** - * Quickly scans a glob pattern and returns an object with a handful of - * useful properties, like `isGlob`, `path` (the leading non-glob, if it exists), - * `glob` (the actual pattern), `negated` (true if the path starts with `!` but not - * with `!(`) and `negatedExtglob` (true if the path starts with `!(`). +/* -*- Mode: js; js-indent-level: 2; -*- */ +/* + * Copyright 2011 Mozilla Foundation and contributors + * Licensed under the New BSD license. See LICENSE or: + * http://opensource.org/licenses/BSD-3-Clause * - * ```js - * const pm = require('picomatch'); - * console.log(pm.scan('foo/bar/*.js')); - * { isGlob: true, input: 'foo/bar/*.js', base: 'foo/bar', glob: '*.js' } - * ``` - * @param {String} `str` - * @param {Object} `options` - * @return {Object} Returns an object with tokens and regex source string. - * @api public + * Based on the Base 64 VLQ implementation in Closure Compiler: + * https://code.google.com/p/closure-compiler/source/browse/trunk/src/com/google/debugging/sourcemap/Base64VLQ.java + * + * Copyright 2011 The Closure Compiler Authors. All rights reserved. + * Redistribution and use in source and binary forms, with or without + * modification, are permitted provided that the following conditions are + * met: + * + * * Redistributions of source code must retain the above copyright + * notice, this list of conditions and the following disclaimer. + * * Redistributions in binary form must reproduce the above + * copyright notice, this list of conditions and the following + * disclaimer in the documentation and/or other materials provided + * with the distribution. + * * Neither the name of Google Inc. nor the names of its + * contributors may be used to endorse or promote products derived + * from this software without specific prior written permission. + * + * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS + * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT + * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR + * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT + * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, + * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT + * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, + * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY + * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT + * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE + * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */ -const scan = (input, options) => { - const opts = options || {}; - - const length = input.length - 1; - const scanToEnd = opts.parts === true || opts.scanToEnd === true; - const slashes = []; - const tokens = []; - const parts = []; - - let str = input; - let index = -1; - let start = 0; - let lastIndex = 0; - let isBrace = false; - let isBracket = false; - let isGlob = false; - let isExtglob = false; - let isGlobstar = false; - let braceEscaped = false; - let backslashes = false; - let negated = false; - let negatedExtglob = false; - let finished = false; - let braces = 0; - let prev; - let code; - let token = { value: '', depth: 0, isGlob: false }; - - const eos = () => index >= length; - const peek = () => str.charCodeAt(index + 1); - const advance = () => { - prev = code; - return str.charCodeAt(++index); - }; - - while (index < length) { - code = advance(); - let next; - - if (code === CHAR_BACKWARD_SLASH) { - backslashes = token.backslashes = true; - code = advance(); - - if (code === CHAR_LEFT_CURLY_BRACE) { - braceEscaped = true; - } - continue; - } - - if (braceEscaped === true || code === CHAR_LEFT_CURLY_BRACE) { - braces++; - - while (eos() !== true && (code = advance())) { - if (code === CHAR_BACKWARD_SLASH) { - backslashes = token.backslashes = true; - advance(); - continue; - } - - if (code === CHAR_LEFT_CURLY_BRACE) { - braces++; - continue; - } - - if (braceEscaped !== true && code === CHAR_DOT && (code = advance()) === CHAR_DOT) { - isBrace = token.isBrace = true; - isGlob = token.isGlob = true; - finished = true; - - if (scanToEnd === true) { - continue; - } - - break; - } +var base64 = __nccwpck_require__(35533); - if (braceEscaped !== true && code === CHAR_COMMA) { - isBrace = token.isBrace = true; - isGlob = token.isGlob = true; - finished = true; +// A single base 64 digit can contain 6 bits of data. For the base 64 variable +// length quantities we use in the source map spec, the first bit is the sign, +// the next four bits are the actual value, and the 6th bit is the +// continuation bit. The continuation bit tells us whether there are more +// digits in this value following this digit. +// +// Continuation +// | Sign +// | | +// V V +// 101011 - if (scanToEnd === true) { - continue; - } +var VLQ_BASE_SHIFT = 5; - break; - } +// binary: 100000 +var VLQ_BASE = 1 << VLQ_BASE_SHIFT; - if (code === CHAR_RIGHT_CURLY_BRACE) { - braces--; +// binary: 011111 +var VLQ_BASE_MASK = VLQ_BASE - 1; - if (braces === 0) { - braceEscaped = false; - isBrace = token.isBrace = true; - finished = true; - break; - } - } - } +// binary: 100000 +var VLQ_CONTINUATION_BIT = VLQ_BASE; - if (scanToEnd === true) { - continue; - } +/** + * Converts from a two-complement value to a value where the sign bit is + * placed in the least significant bit. For example, as decimals: + * 1 becomes 2 (10 binary), -1 becomes 3 (11 binary) + * 2 becomes 4 (100 binary), -2 becomes 5 (101 binary) + */ +function toVLQSigned(aValue) { + return aValue < 0 + ? ((-aValue) << 1) + 1 + : (aValue << 1) + 0; +} - break; - } +/** + * Converts to a two-complement value from a value where the sign bit is + * placed in the least significant bit. For example, as decimals: + * 2 (10 binary) becomes 1, 3 (11 binary) becomes -1 + * 4 (100 binary) becomes 2, 5 (101 binary) becomes -2 + */ +function fromVLQSigned(aValue) { + var isNegative = (aValue & 1) === 1; + var shifted = aValue >> 1; + return isNegative + ? -shifted + : shifted; +} - if (code === CHAR_FORWARD_SLASH) { - slashes.push(index); - tokens.push(token); - token = { value: '', depth: 0, isGlob: false }; +/** + * Returns the base 64 VLQ encoded value. + */ +exports.encode = function base64VLQ_encode(aValue) { + var encoded = ""; + var digit; - if (finished === true) continue; - if (prev === CHAR_DOT && index === (start + 1)) { - start += 2; - continue; - } + var vlq = toVLQSigned(aValue); - lastIndex = index + 1; - continue; + do { + digit = vlq & VLQ_BASE_MASK; + vlq >>>= VLQ_BASE_SHIFT; + if (vlq > 0) { + // There are still more digits in this value, so we must make sure the + // continuation bit is marked. + digit |= VLQ_CONTINUATION_BIT; } + encoded += base64.encode(digit); + } while (vlq > 0); - if (opts.noext !== true) { - const isExtglobChar = code === CHAR_PLUS - || code === CHAR_AT - || code === CHAR_ASTERISK - || code === CHAR_QUESTION_MARK - || code === CHAR_EXCLAMATION_MARK; - - if (isExtglobChar === true && peek() === CHAR_LEFT_PARENTHESES) { - isGlob = token.isGlob = true; - isExtglob = token.isExtglob = true; - finished = true; - if (code === CHAR_EXCLAMATION_MARK && index === start) { - negatedExtglob = true; - } - - if (scanToEnd === true) { - while (eos() !== true && (code = advance())) { - if (code === CHAR_BACKWARD_SLASH) { - backslashes = token.backslashes = true; - code = advance(); - continue; - } - - if (code === CHAR_RIGHT_PARENTHESES) { - isGlob = token.isGlob = true; - finished = true; - break; - } - } - continue; - } - break; - } - } + return encoded; +}; - if (code === CHAR_ASTERISK) { - if (prev === CHAR_ASTERISK) isGlobstar = token.isGlobstar = true; - isGlob = token.isGlob = true; - finished = true; +/** + * Decodes the next base 64 VLQ value from the given string and returns the + * value and the rest of the string via the out parameter. + */ +exports.decode = function base64VLQ_decode(aStr, aIndex, aOutParam) { + var strLen = aStr.length; + var result = 0; + var shift = 0; + var continuation, digit; - if (scanToEnd === true) { - continue; - } - break; + do { + if (aIndex >= strLen) { + throw new Error("Expected more digits in base 64 VLQ value."); } - if (code === CHAR_QUESTION_MARK) { - isGlob = token.isGlob = true; - finished = true; - - if (scanToEnd === true) { - continue; - } - break; + digit = base64.decode(aStr.charCodeAt(aIndex++)); + if (digit === -1) { + throw new Error("Invalid base64 digit: " + aStr.charAt(aIndex - 1)); } - if (code === CHAR_LEFT_SQUARE_BRACKET) { - while (eos() !== true && (next = advance())) { - if (next === CHAR_BACKWARD_SLASH) { - backslashes = token.backslashes = true; - advance(); - continue; - } - - if (next === CHAR_RIGHT_SQUARE_BRACKET) { - isBracket = token.isBracket = true; - isGlob = token.isGlob = true; - finished = true; - break; - } - } + continuation = !!(digit & VLQ_CONTINUATION_BIT); + digit &= VLQ_BASE_MASK; + result = result + (digit << shift); + shift += VLQ_BASE_SHIFT; + } while (continuation); - if (scanToEnd === true) { - continue; - } + aOutParam.value = fromVLQSigned(result); + aOutParam.rest = aIndex; +}; - break; - } - if (opts.nonegate !== true && code === CHAR_EXCLAMATION_MARK && index === start) { - negated = token.negated = true; - start++; - continue; - } +/***/ }), - if (opts.noparen !== true && code === CHAR_LEFT_PARENTHESES) { - isGlob = token.isGlob = true; +/***/ 35533: +/***/ ((__unused_webpack_module, exports) => { - if (scanToEnd === true) { - while (eos() !== true && (code = advance())) { - if (code === CHAR_LEFT_PARENTHESES) { - backslashes = token.backslashes = true; - code = advance(); - continue; - } +/* -*- Mode: js; js-indent-level: 2; -*- */ +/* + * Copyright 2011 Mozilla Foundation and contributors + * Licensed under the New BSD license. See LICENSE or: + * http://opensource.org/licenses/BSD-3-Clause + */ - if (code === CHAR_RIGHT_PARENTHESES) { - finished = true; - break; - } - } - continue; - } - break; - } +var intToCharMap = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/'.split(''); - if (isGlob === true) { - finished = true; +/** + * Encode an integer in the range of 0 to 63 to a single base 64 digit. + */ +exports.encode = function (number) { + if (0 <= number && number < intToCharMap.length) { + return intToCharMap[number]; + } + throw new TypeError("Must be between 0 and 63: " + number); +}; - if (scanToEnd === true) { - continue; - } +/** + * Decode a single base 64 character code digit to an integer. Returns -1 on + * failure. + */ +exports.decode = function (charCode) { + var bigA = 65; // 'A' + var bigZ = 90; // 'Z' - break; - } - } + var littleA = 97; // 'a' + var littleZ = 122; // 'z' - if (opts.noext === true) { - isExtglob = false; - isGlob = false; - } + var zero = 48; // '0' + var nine = 57; // '9' - let base = str; - let prefix = ''; - let glob = ''; + var plus = 43; // '+' + var slash = 47; // '/' - if (start > 0) { - prefix = str.slice(0, start); - str = str.slice(start); - lastIndex -= start; - } + var littleOffset = 26; + var numberOffset = 52; - if (base && isGlob === true && lastIndex > 0) { - base = str.slice(0, lastIndex); - glob = str.slice(lastIndex); - } else if (isGlob === true) { - base = ''; - glob = str; - } else { - base = str; + // 0 - 25: ABCDEFGHIJKLMNOPQRSTUVWXYZ + if (bigA <= charCode && charCode <= bigZ) { + return (charCode - bigA); } - if (base && base !== '' && base !== '/' && base !== str) { - if (isPathSeparator(base.charCodeAt(base.length - 1))) { - base = base.slice(0, -1); - } + // 26 - 51: abcdefghijklmnopqrstuvwxyz + if (littleA <= charCode && charCode <= littleZ) { + return (charCode - littleA + littleOffset); } - if (opts.unescape === true) { - if (glob) glob = utils.removeBackslashes(glob); - - if (base && backslashes === true) { - base = utils.removeBackslashes(base); - } + // 52 - 61: 0123456789 + if (zero <= charCode && charCode <= nine) { + return (charCode - zero + numberOffset); } - const state = { - prefix, - input, - start, - base, - glob, - isBrace, - isBracket, - isGlob, - isExtglob, - isGlobstar, - negated, - negatedExtglob - }; - - if (opts.tokens === true) { - state.maxDepth = 0; - if (!isPathSeparator(code)) { - tokens.push(token); - } - state.tokens = tokens; + // 62: + + if (charCode == plus) { + return 62; } - if (opts.parts === true || opts.tokens === true) { - let prevIndex; - - for (let idx = 0; idx < slashes.length; idx++) { - const n = prevIndex ? prevIndex + 1 : start; - const i = slashes[idx]; - const value = input.slice(n, i); - if (opts.tokens) { - if (idx === 0 && start !== 0) { - tokens[idx].isPrefix = true; - tokens[idx].value = prefix; - } else { - tokens[idx].value = value; - } - depth(tokens[idx]); - state.maxDepth += tokens[idx].depth; - } - if (idx !== 0 || value !== '') { - parts.push(value); - } - prevIndex = i; - } - - if (prevIndex && prevIndex + 1 < input.length) { - const value = input.slice(prevIndex + 1); - parts.push(value); - - if (opts.tokens) { - tokens[tokens.length - 1].value = value; - depth(tokens[tokens.length - 1]); - state.maxDepth += tokens[tokens.length - 1].depth; - } - } - - state.slashes = slashes; - state.parts = parts; + // 63: / + if (charCode == slash) { + return 63; } - return state; + // Invalid base64 digit. + return -1; }; -module.exports = scan; - /***/ }), -/***/ 76088: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { - -"use strict"; +/***/ 35039: +/***/ ((__unused_webpack_module, exports) => { +/* -*- Mode: js; js-indent-level: 2; -*- */ +/* + * Copyright 2011 Mozilla Foundation and contributors + * Licensed under the New BSD license. See LICENSE or: + * http://opensource.org/licenses/BSD-3-Clause + */ -const path = __nccwpck_require__(71017); -const win32 = process.platform === 'win32'; -const { - REGEX_BACKSLASH, - REGEX_REMOVE_BACKSLASH, - REGEX_SPECIAL_CHARS, - REGEX_SPECIAL_CHARS_GLOBAL -} = __nccwpck_require__(67582); - -exports.isObject = val => val !== null && typeof val === 'object' && !Array.isArray(val); -exports.hasRegexChars = str => REGEX_SPECIAL_CHARS.test(str); -exports.isRegexChar = str => str.length === 1 && exports.hasRegexChars(str); -exports.escapeRegex = str => str.replace(REGEX_SPECIAL_CHARS_GLOBAL, '\\$1'); -exports.toPosixSlashes = str => str.replace(REGEX_BACKSLASH, '/'); - -exports.removeBackslashes = str => { - return str.replace(REGEX_REMOVE_BACKSLASH, match => { - return match === '\\' ? '' : match; - }); -}; +exports.GREATEST_LOWER_BOUND = 1; +exports.LEAST_UPPER_BOUND = 2; -exports.supportsLookbehinds = () => { - const segs = process.version.slice(1).split('.').map(Number); - if (segs.length === 3 && segs[0] >= 9 || (segs[0] === 8 && segs[1] >= 10)) { - return true; +/** + * Recursive implementation of binary search. + * + * @param aLow Indices here and lower do not contain the needle. + * @param aHigh Indices here and higher do not contain the needle. + * @param aNeedle The element being searched for. + * @param aHaystack The non-empty array being searched. + * @param aCompare Function which takes two elements and returns -1, 0, or 1. + * @param aBias Either 'binarySearch.GREATEST_LOWER_BOUND' or + * 'binarySearch.LEAST_UPPER_BOUND'. Specifies whether to return the + * closest element that is smaller than or greater than the one we are + * searching for, respectively, if the exact element cannot be found. + */ +function recursiveSearch(aLow, aHigh, aNeedle, aHaystack, aCompare, aBias) { + // This function terminates when one of the following is true: + // + // 1. We find the exact element we are looking for. + // + // 2. We did not find the exact element, but we can return the index of + // the next-closest element. + // + // 3. We did not find the exact element, and there is no next-closest + // element than the one we are searching for, so we return -1. + var mid = Math.floor((aHigh - aLow) / 2) + aLow; + var cmp = aCompare(aNeedle, aHaystack[mid], true); + if (cmp === 0) { + // Found the element we are looking for. + return mid; } - return false; -}; + else if (cmp > 0) { + // Our needle is greater than aHaystack[mid]. + if (aHigh - mid > 1) { + // The element is in the upper half. + return recursiveSearch(mid, aHigh, aNeedle, aHaystack, aCompare, aBias); + } -exports.isWindows = options => { - if (options && typeof options.windows === 'boolean') { - return options.windows; + // The exact needle element was not found in this haystack. Determine if + // we are in termination case (3) or (2) and return the appropriate thing. + if (aBias == exports.LEAST_UPPER_BOUND) { + return aHigh < aHaystack.length ? aHigh : -1; + } else { + return mid; + } } - return win32 === true || path.sep === '\\'; -}; + else { + // Our needle is less than aHaystack[mid]. + if (mid - aLow > 1) { + // The element is in the lower half. + return recursiveSearch(aLow, mid, aNeedle, aHaystack, aCompare, aBias); + } -exports.escapeLast = (input, char, lastIdx) => { - const idx = input.lastIndexOf(char, lastIdx); - if (idx === -1) return input; - if (input[idx - 1] === '\\') return exports.escapeLast(input, char, idx - 1); - return `${input.slice(0, idx)}\\${input.slice(idx)}`; -}; + // we are in termination case (3) or (2) and return the appropriate thing. + if (aBias == exports.LEAST_UPPER_BOUND) { + return mid; + } else { + return aLow < 0 ? -1 : aLow; + } + } +} -exports.removePrefix = (input, state = {}) => { - let output = input; - if (output.startsWith('./')) { - output = output.slice(2); - state.prefix = './'; +/** + * This is an implementation of binary search which will always try and return + * the index of the closest element if there is no exact hit. This is because + * mappings between original and generated line/col pairs are single points, + * and there is an implicit region between each of them, so a miss just means + * that you aren't on the very start of a region. + * + * @param aNeedle The element you are looking for. + * @param aHaystack The array that is being searched. + * @param aCompare A function which takes the needle and an element in the + * array and returns -1, 0, or 1 depending on whether the needle is less + * than, equal to, or greater than the element, respectively. + * @param aBias Either 'binarySearch.GREATEST_LOWER_BOUND' or + * 'binarySearch.LEAST_UPPER_BOUND'. Specifies whether to return the + * closest element that is smaller than or greater than the one we are + * searching for, respectively, if the exact element cannot be found. + * Defaults to 'binarySearch.GREATEST_LOWER_BOUND'. + */ +exports.search = function search(aNeedle, aHaystack, aCompare, aBias) { + if (aHaystack.length === 0) { + return -1; } - return output; -}; -exports.wrapOutput = (input, state = {}, options = {}) => { - const prepend = options.contains ? '' : '^'; - const append = options.contains ? '' : '$'; + var index = recursiveSearch(-1, aHaystack.length, aNeedle, aHaystack, + aCompare, aBias || exports.GREATEST_LOWER_BOUND); + if (index < 0) { + return -1; + } - let output = `${prepend}(?:${input})${append}`; - if (state.negated === true) { - output = `(?:^(?!${output}).*$)`; + // We have found either the exact element, or the next-closest element than + // the one we are searching for. However, there may be more than one such + // element. Make sure we always return the smallest of these. + while (index - 1 >= 0) { + if (aCompare(aHaystack[index], aHaystack[index - 1], true) !== 0) { + break; + } + --index; } - return output; + + return index; }; /***/ }), -/***/ 115: -/***/ ((module, exports, __nccwpck_require__) => { - -"use strict"; -/* module decorator */ module = __nccwpck_require__.nmd(module); - +/***/ 66439: +/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { -Object.defineProperty(exports, "__esModule", ({ - value: true -})); -exports.addHook = addHook; -var _module = _interopRequireDefault(__nccwpck_require__(98188)); -var _path = _interopRequireDefault(__nccwpck_require__(71017)); -function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } -/* (c) 2015 Ari Porad (@ariporad) . License: ariporad.mit-license.org */ +/* -*- Mode: js; js-indent-level: 2; -*- */ +/* + * Copyright 2014 Mozilla Foundation and contributors + * Licensed under the New BSD license. See LICENSE or: + * http://opensource.org/licenses/BSD-3-Clause + */ -const nodeModulesRegex = /^(?:.*[\\/])?node_modules(?:[\\/].*)?$/; -// Guard against poorly mocked module constructors. -const Module = module.constructor.length > 1 ? module.constructor : _module.default; -const HOOK_RETURNED_NOTHING_ERROR_MESSAGE = '[Pirates] A hook returned a non-string, or nothing at all! This is a' + ' violation of intergalactic law!\n' + '--------------------\n' + 'If you have no idea what this means or what Pirates is, let me explain: ' + 'Pirates is a module that makes is easy to implement require hooks. One of' + " the require hooks you're using uses it. One of these require hooks" + " didn't return anything from it's handler, so we don't know what to" + ' do. You might want to debug this.'; +var util = __nccwpck_require__(89479); /** - * @param {string} filename The filename to check. - * @param {string[]} exts The extensions to hook. Should start with '.' (ex. ['.js']). - * @param {Matcher|null} matcher A matcher function, will be called with path to a file. Should return truthy if the file should be hooked, falsy otherwise. - * @param {boolean} ignoreNodeModules Auto-ignore node_modules. Independent of any matcher. + * Determine whether mappingB is after mappingA with respect to generated + * position. */ -function shouldCompile(filename, exts, matcher, ignoreNodeModules) { - if (typeof filename !== 'string') { - return false; - } - if (exts.indexOf(_path.default.extname(filename)) === -1) { - return false; - } - const resolvedFilename = _path.default.resolve(filename); - if (ignoreNodeModules && nodeModulesRegex.test(resolvedFilename)) { - return false; - } - if (matcher && typeof matcher === 'function') { - return !!matcher(resolvedFilename); - } - return true; +function generatedPositionAfter(mappingA, mappingB) { + // Optimized for most common case + var lineA = mappingA.generatedLine; + var lineB = mappingB.generatedLine; + var columnA = mappingA.generatedColumn; + var columnB = mappingB.generatedColumn; + return lineB > lineA || lineB == lineA && columnB >= columnA || + util.compareByGeneratedPositionsInflated(mappingA, mappingB) <= 0; } /** - * @callback Hook The hook. Accepts the code of the module and the filename. - * @param {string} code - * @param {string} filename - * @returns {string} + * A data structure to provide a sorted view of accumulated mappings in a + * performance conscious manner. It trades a neglibable overhead in general + * case for a large speedup in case of mappings being added in order. */ +function MappingList() { + this._array = []; + this._sorted = true; + // Serves as infimum + this._last = {generatedLine: -1, generatedColumn: 0}; +} + /** - * @callback Matcher A matcher function, will be called with path to a file. + * Iterate through internal items. This method takes the same arguments that + * `Array.prototype.forEach` takes. * - * Should return truthy if the file should be hooked, falsy otherwise. - * @param {string} path - * @returns {boolean} - */ -/** - * @callback RevertFunction Reverts the hook when called. - * @returns {void} + * NOTE: The order of the mappings is NOT guaranteed. */ +MappingList.prototype.unsortedForEach = + function MappingList_forEach(aCallback, aThisArg) { + this._array.forEach(aCallback, aThisArg); + }; + /** - * @typedef {object} Options - * @property {Matcher|null} [matcher=null] A matcher function, will be called with path to a file. - * - * Should return truthy if the file should be hooked, falsy otherwise. - * - * @property {string[]} [extensions=['.js']] The extensions to hook. Should start with '.' (ex. ['.js']). - * @property {string[]} [exts=['.js']] The extensions to hook. Should start with '.' (ex. ['.js']). - * - * @property {string[]} [extension=['.js']] The extensions to hook. Should start with '.' (ex. ['.js']). - * @property {string[]} [ext=['.js']] The extensions to hook. Should start with '.' (ex. ['.js']). + * Add the given source mapping. * - * @property {boolean} [ignoreNodeModules=true] Auto-ignore node_modules. Independent of any matcher. + * @param Object aMapping */ +MappingList.prototype.add = function MappingList_add(aMapping) { + if (generatedPositionAfter(this._last, aMapping)) { + this._last = aMapping; + this._array.push(aMapping); + } else { + this._sorted = false; + this._array.push(aMapping); + } +}; /** - * Add a require hook. + * Returns the flat, sorted array of mappings. The mappings are sorted by + * generated position. * - * @param {Hook} hook The hook. Accepts the code of the module and the filename. Required. - * @param {Options} [opts] Options - * @returns {RevertFunction} The `revert` function. Reverts the hook when called. + * WARNING: This method returns internal data without copying, for + * performance. The return value must NOT be mutated, and should be treated as + * an immutable borrow. If you want to take ownership, you must make your own + * copy. */ -function addHook(hook, opts = {}) { - let reverted = false; - const loaders = []; - const oldLoaders = []; - let exts; - - // We need to do this to fix #15. Basically, if you use a non-standard extension (ie. .jsx), then - // We modify the .js loader, then use the modified .js loader for as the base for .jsx. - // This prevents that. - const originalJSLoader = Module._extensions['.js']; - const matcher = opts.matcher || null; - const ignoreNodeModules = opts.ignoreNodeModules !== false; - exts = opts.extensions || opts.exts || opts.extension || opts.ext || ['.js']; - if (!Array.isArray(exts)) { - exts = [exts]; +MappingList.prototype.toArray = function MappingList_toArray() { + if (!this._sorted) { + this._array.sort(util.compareByGeneratedPositionsInflated); + this._sorted = true; } - exts.forEach(ext => { - if (typeof ext !== 'string') { - throw new TypeError(`Invalid Extension: ${ext}`); - } - const oldLoader = Module._extensions[ext] || originalJSLoader; - oldLoaders[ext] = Module._extensions[ext]; - loaders[ext] = Module._extensions[ext] = function newLoader(mod, filename) { - let compile; - if (!reverted) { - if (shouldCompile(filename, exts, matcher, ignoreNodeModules)) { - compile = mod._compile; - mod._compile = function _compile(code) { - // reset the compile immediately as otherwise we end up having the - // compile function being changed even though this loader might be reverted - // Not reverting it here leads to long useless compile chains when doing - // addHook -> revert -> addHook -> revert -> ... - // The compile function is also anyway created new when the loader is called a second time. - mod._compile = compile; - const newCode = hook(code, filename); - if (typeof newCode !== 'string') { - throw new Error(HOOK_RETURNED_NOTHING_ERROR_MESSAGE); - } - return mod._compile(newCode, filename); - }; - } - } - oldLoader(mod, filename); - }; - }); - return function revert() { - if (reverted) return; - reverted = true; - exts.forEach(ext => { - // if the current loader for the extension is our loader then unregister it and set the oldLoader again - // if not we can not do anything as we cannot remove a loader from within the loader-chain - if (Module._extensions[ext] === loaders[ext]) { - if (!oldLoaders[ext]) { - delete Module._extensions[ext]; - } else { - Module._extensions[ext] = oldLoaders[ext]; - } - } - }); - }; -} + return this._array; +}; -/***/ }), +exports.H = MappingList; -/***/ 98431: -/***/ ((module) => { -/*! queue-microtask. MIT License. Feross Aboukhadijeh */ -let promise +/***/ }), -module.exports = typeof queueMicrotask === 'function' - ? queueMicrotask.bind(typeof window !== 'undefined' ? window : global) - // reuse resolved promise, and allocate it lazily - : cb => (promise || (promise = Promise.resolve())) - .then(cb) - .catch(err => setTimeout(() => { throw err }, 0)) +/***/ 94438: +/***/ ((__unused_webpack_module, exports) => { +/* -*- Mode: js; js-indent-level: 2; -*- */ +/* + * Copyright 2011 Mozilla Foundation and contributors + * Licensed under the New BSD license. See LICENSE or: + * http://opensource.org/licenses/BSD-3-Clause + */ -/***/ }), +// It turns out that some (most?) JavaScript engines don't self-host +// `Array.prototype.sort`. This makes sense because C++ will likely remain +// faster than JS when doing raw CPU-intensive sorting. However, when using a +// custom comparator function, calling back and forth between the VM's C++ and +// JIT'd JS is rather slow *and* loses JIT type information, resulting in +// worse generated code for the comparator function than would be optimal. In +// fact, when sorting with a comparator, these costs outweigh the benefits of +// sorting in C++. By using our own JS-implemented Quick Sort (below), we get +// a ~3500ms mean speed-up in `bench/bench.html`. -/***/ 91042: -/***/ ((module) => { +/** + * Swap the elements indexed by `x` and `y` in the array `ary`. + * + * @param {Array} ary + * The array. + * @param {Number} x + * The index of the first item. + * @param {Number} y + * The index of the second item. + */ +function swap(ary, x, y) { + var temp = ary[x]; + ary[x] = ary[y]; + ary[y] = temp; +} -"use strict"; +/** + * Returns a random integer within the range `low .. high` inclusive. + * + * @param {Number} low + * The lower bound on the range. + * @param {Number} high + * The upper bound on the range. + */ +function randomIntInRange(low, high) { + return Math.round(low + (Math.random() * (high - low))); +} +/** + * The Quick Sort algorithm. + * + * @param {Array} ary + * An array to sort. + * @param {function} comparator + * Function to use to compare two items. + * @param {Number} p + * Start index of the array + * @param {Number} r + * End index of the array + */ +function doQuickSort(ary, comparator, p, r) { + // If our lower bound is less than our upper bound, we (1) partition the + // array into two pieces and (2) recurse on each half. If it is not, this is + // the empty array and our base case. -const codes = {}; + if (p < r) { + // (1) Partitioning. + // + // The partitioning chooses a pivot between `p` and `r` and moves all + // elements that are less than or equal to the pivot to the before it, and + // all the elements that are greater than it after it. The effect is that + // once partition is done, the pivot is in the exact place it will be when + // the array is put in sorted order, and it will not need to be moved + // again. This runs in O(n) time. -function createErrorType(code, message, Base) { - if (!Base) { - Base = Error - } + // Always choose a random pivot so that an input array which is reverse + // sorted does not cause O(n^2) running time. + var pivotIndex = randomIntInRange(p, r); + var i = p - 1; - function getMessage (arg1, arg2, arg3) { - if (typeof message === 'string') { - return message - } else { - return message(arg1, arg2, arg3) - } - } + swap(ary, pivotIndex, r); + var pivot = ary[r]; - class NodeError extends Base { - constructor (arg1, arg2, arg3) { - super(getMessage(arg1, arg2, arg3)); + // Immediately after `j` is incremented in this loop, the following hold + // true: + // + // * Every element in `ary[p .. i]` is less than or equal to the pivot. + // + // * Every element in `ary[i+1 .. j-1]` is greater than the pivot. + for (var j = p; j < r; j++) { + if (comparator(ary[j], pivot) <= 0) { + i += 1; + swap(ary, i, j); + } } - } - NodeError.prototype.name = Base.name; - NodeError.prototype.code = code; + swap(ary, i + 1, j); + var q = i + 1; - codes[code] = NodeError; -} + // (2) Recurse on each half. -// https://github.com/nodejs/node/blob/v10.8.0/lib/internal/errors.js -function oneOf(expected, thing) { - if (Array.isArray(expected)) { - const len = expected.length; - expected = expected.map((i) => String(i)); - if (len > 2) { - return `one of ${thing} ${expected.slice(0, len - 1).join(', ')}, or ` + - expected[len - 1]; - } else if (len === 2) { - return `one of ${thing} ${expected[0]} or ${expected[1]}`; - } else { - return `of ${thing} ${expected[0]}`; - } - } else { - return `of ${thing} ${String(expected)}`; + doQuickSort(ary, comparator, p, q - 1); + doQuickSort(ary, comparator, q + 1, r); } } -// https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/startsWith -function startsWith(str, search, pos) { - return str.substr(!pos || pos < 0 ? 0 : +pos, search.length) === search; -} - -// https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/endsWith -function endsWith(str, search, this_len) { - if (this_len === undefined || this_len > str.length) { - this_len = str.length; - } - return str.substring(this_len - search.length, this_len) === search; -} +/** + * Sort the given array in-place with the given comparator function. + * + * @param {Array} ary + * An array to sort. + * @param {function} comparator + * Function to use to compare two items. + */ +exports.U = function (ary, comparator) { + doQuickSort(ary, comparator, 0, ary.length - 1); +}; -// https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/includes -function includes(str, search, start) { - if (typeof start !== 'number') { - start = 0; - } - if (start + search.length > str.length) { - return false; - } else { - return str.indexOf(search, start) !== -1; - } -} +/***/ }), -createErrorType('ERR_INVALID_OPT_VALUE', function (name, value) { - return 'The value "' + value + '" is invalid for option "' + name + '"' -}, TypeError); -createErrorType('ERR_INVALID_ARG_TYPE', function (name, expected, actual) { - // determiner: 'must be' or 'must not be' - let determiner; - if (typeof expected === 'string' && startsWith(expected, 'not ')) { - determiner = 'must not be'; - expected = expected.replace(/^not /, ''); - } else { - determiner = 'must be'; - } +/***/ 89457: +/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { - let msg; - if (endsWith(name, ' argument')) { - // For cases like 'first argument' - msg = `The ${name} ${determiner} ${oneOf(expected, 'type')}`; - } else { - const type = includes(name, '.') ? 'property' : 'argument'; - msg = `The "${name}" ${type} ${determiner} ${oneOf(expected, 'type')}`; - } +var __webpack_unused_export__; +/* -*- Mode: js; js-indent-level: 2; -*- */ +/* + * Copyright 2011 Mozilla Foundation and contributors + * Licensed under the New BSD license. See LICENSE or: + * http://opensource.org/licenses/BSD-3-Clause + */ - msg += `. Received type ${typeof actual}`; - return msg; -}, TypeError); -createErrorType('ERR_STREAM_PUSH_AFTER_EOF', 'stream.push() after EOF'); -createErrorType('ERR_METHOD_NOT_IMPLEMENTED', function (name) { - return 'The ' + name + ' method is not implemented' -}); -createErrorType('ERR_STREAM_PREMATURE_CLOSE', 'Premature close'); -createErrorType('ERR_STREAM_DESTROYED', function (name) { - return 'Cannot call ' + name + ' after a stream was destroyed'; -}); -createErrorType('ERR_MULTIPLE_CALLBACK', 'Callback called multiple times'); -createErrorType('ERR_STREAM_CANNOT_PIPE', 'Cannot pipe, not readable'); -createErrorType('ERR_STREAM_WRITE_AFTER_END', 'write after end'); -createErrorType('ERR_STREAM_NULL_VALUES', 'May not write null values to stream', TypeError); -createErrorType('ERR_UNKNOWN_ENCODING', function (arg) { - return 'Unknown encoding: ' + arg -}, TypeError); -createErrorType('ERR_STREAM_UNSHIFT_AFTER_END_EVENT', 'stream.unshift() after end event'); +var util = __nccwpck_require__(89479); +var binarySearch = __nccwpck_require__(35039); +var ArraySet = (__nccwpck_require__(62880)/* .ArraySet */ .I); +var base64VLQ = __nccwpck_require__(26672); +var quickSort = (__nccwpck_require__(94438)/* .quickSort */ .U); -module.exports.q = codes; +function SourceMapConsumer(aSourceMap, aSourceMapURL) { + var sourceMap = aSourceMap; + if (typeof aSourceMap === 'string') { + sourceMap = util.parseSourceMapInput(aSourceMap); + } + return sourceMap.sections != null + ? new IndexedSourceMapConsumer(sourceMap, aSourceMapURL) + : new BasicSourceMapConsumer(sourceMap, aSourceMapURL); +} -/***/ }), +SourceMapConsumer.fromSourceMap = function(aSourceMap, aSourceMapURL) { + return BasicSourceMapConsumer.fromSourceMap(aSourceMap, aSourceMapURL); +} -/***/ 25408: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { +/** + * The version of the source mapping spec that we are consuming. + */ +SourceMapConsumer.prototype._version = 3; -"use strict"; -// Copyright Joyent, Inc. and other Node contributors. +// `__generatedMappings` and `__originalMappings` are arrays that hold the +// parsed mapping coordinates from the source map's "mappings" attribute. They +// are lazily instantiated, accessed via the `_generatedMappings` and +// `_originalMappings` getters respectively, and we only parse the mappings +// and create these arrays once queried for a source location. We jump through +// these hoops because there can be many thousands of mappings, and parsing +// them is expensive, so we only want to do it if we must. // -// 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: +// Each object in the arrays is of the form: // -// The above copyright notice and this permission notice shall be included -// in all copies or substantial portions of the Software. +// { +// generatedLine: The line number in the generated code, +// generatedColumn: The column number in the generated code, +// source: The path to the original source file that generated this +// chunk of code, +// originalLine: The line number in the original source that +// corresponds to this chunk of generated code, +// originalColumn: The column number in the original source that +// corresponds to this chunk of generated code, +// name: The name of the original symbol which generated this chunk of +// code. +// } // -// 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. -// a duplex stream is just a stream that is both readable and writable. -// Since JS doesn't have multiple prototypal inheritance, this class -// prototypally inherits from Readable, and then parasitically from -// Writable. - -/**/ +// All properties except for `generatedLine` and `generatedColumn` can be +// `null`. +// +// `_generatedMappings` is ordered by the generated positions. +// +// `_originalMappings` is ordered by the original positions. -var objectKeys = Object.keys || function (obj) { - var keys = []; +SourceMapConsumer.prototype.__generatedMappings = null; +Object.defineProperty(SourceMapConsumer.prototype, '_generatedMappings', { + configurable: true, + enumerable: true, + get: function () { + if (!this.__generatedMappings) { + this._parseMappings(this._mappings, this.sourceRoot); + } - for (var key in obj) { - keys.push(key); + return this.__generatedMappings; } +}); - return keys; -}; -/**/ - +SourceMapConsumer.prototype.__originalMappings = null; +Object.defineProperty(SourceMapConsumer.prototype, '_originalMappings', { + configurable: true, + enumerable: true, + get: function () { + if (!this.__originalMappings) { + this._parseMappings(this._mappings, this.sourceRoot); + } -module.exports = Duplex; + return this.__originalMappings; + } +}); -var Readable = __nccwpck_require__(17911); - -var Writable = __nccwpck_require__(51898); - -__nccwpck_require__(2868)(Duplex, Readable); +SourceMapConsumer.prototype._charIsMappingSeparator = + function SourceMapConsumer_charIsMappingSeparator(aStr, index) { + var c = aStr.charAt(index); + return c === ";" || c === ","; + }; -{ - // Allow the keys array to be GC'ed. - var keys = objectKeys(Writable.prototype); +/** + * Parse the mappings in a string in to a data structure which we can easily + * query (the ordered arrays in the `this.__generatedMappings` and + * `this.__originalMappings` properties). + */ +SourceMapConsumer.prototype._parseMappings = + function SourceMapConsumer_parseMappings(aStr, aSourceRoot) { + throw new Error("Subclasses must implement _parseMappings"); + }; - for (var v = 0; v < keys.length; v++) { - var method = keys[v]; - if (!Duplex.prototype[method]) Duplex.prototype[method] = Writable.prototype[method]; - } -} +SourceMapConsumer.GENERATED_ORDER = 1; +SourceMapConsumer.ORIGINAL_ORDER = 2; -function Duplex(options) { - if (!(this instanceof Duplex)) return new Duplex(options); - Readable.call(this, options); - Writable.call(this, options); - this.allowHalfOpen = true; +SourceMapConsumer.GREATEST_LOWER_BOUND = 1; +SourceMapConsumer.LEAST_UPPER_BOUND = 2; - if (options) { - if (options.readable === false) this.readable = false; - if (options.writable === false) this.writable = false; +/** + * Iterate over each mapping between an original source/line/column and a + * generated line/column in this source map. + * + * @param Function aCallback + * The function that is called with each mapping. + * @param Object aContext + * Optional. If specified, this object will be the value of `this` every + * time that `aCallback` is called. + * @param aOrder + * Either `SourceMapConsumer.GENERATED_ORDER` or + * `SourceMapConsumer.ORIGINAL_ORDER`. Specifies whether you want to + * iterate over the mappings sorted by the generated file's line/column + * order or the original's source/line/column order, respectively. Defaults to + * `SourceMapConsumer.GENERATED_ORDER`. + */ +SourceMapConsumer.prototype.eachMapping = + function SourceMapConsumer_eachMapping(aCallback, aContext, aOrder) { + var context = aContext || null; + var order = aOrder || SourceMapConsumer.GENERATED_ORDER; - if (options.allowHalfOpen === false) { - this.allowHalfOpen = false; - this.once('end', onend); + var mappings; + switch (order) { + case SourceMapConsumer.GENERATED_ORDER: + mappings = this._generatedMappings; + break; + case SourceMapConsumer.ORIGINAL_ORDER: + mappings = this._originalMappings; + break; + default: + throw new Error("Unknown order of iteration."); } - } -} - -Object.defineProperty(Duplex.prototype, 'writableHighWaterMark', { - // making it explicit this property is not enumerable - // because otherwise some prototype manipulation in - // userland will fail - enumerable: false, - get: function get() { - return this._writableState.highWaterMark; - } -}); -Object.defineProperty(Duplex.prototype, 'writableBuffer', { - // making it explicit this property is not enumerable - // because otherwise some prototype manipulation in - // userland will fail - enumerable: false, - get: function get() { - return this._writableState && this._writableState.getBuffer(); - } -}); -Object.defineProperty(Duplex.prototype, 'writableLength', { - // making it explicit this property is not enumerable - // because otherwise some prototype manipulation in - // userland will fail - enumerable: false, - get: function get() { - return this._writableState.length; - } -}); // the no-half-open enforcer -function onend() { - // If the writable side ended, then we're ok. - if (this._writableState.ended) return; // no more data can be written. - // But allow more writes to happen in this tick. + var sourceRoot = this.sourceRoot; + mappings.map(function (mapping) { + var source = mapping.source === null ? null : this._sources.at(mapping.source); + source = util.computeSourceURL(sourceRoot, source, this._sourceMapURL); + return { + source: source, + generatedLine: mapping.generatedLine, + generatedColumn: mapping.generatedColumn, + originalLine: mapping.originalLine, + originalColumn: mapping.originalColumn, + name: mapping.name === null ? null : this._names.at(mapping.name) + }; + }, this).forEach(aCallback, context); + }; - process.nextTick(onEndNT, this); -} +/** + * Returns all generated line and column information for the original source, + * line, and column provided. If no column is provided, returns all mappings + * corresponding to a either the line we are searching for or the next + * closest line that has any mappings. Otherwise, returns all mappings + * corresponding to the given line and either the column we are searching for + * or the next closest column that has any offsets. + * + * The only argument is an object with the following properties: + * + * - source: The filename of the original source. + * - line: The line number in the original source. The line number is 1-based. + * - column: Optional. the column number in the original source. + * The column number is 0-based. + * + * and an array of objects is returned, each with the following properties: + * + * - line: The line number in the generated source, or null. The + * line number is 1-based. + * - column: The column number in the generated source, or null. + * The column number is 0-based. + */ +SourceMapConsumer.prototype.allGeneratedPositionsFor = + function SourceMapConsumer_allGeneratedPositionsFor(aArgs) { + var line = util.getArg(aArgs, 'line'); -function onEndNT(self) { - self.end(); -} + // When there is no exact match, BasicSourceMapConsumer.prototype._findMapping + // returns the index of the closest mapping less than the needle. By + // setting needle.originalColumn to 0, we thus find the last mapping for + // the given line, provided such a mapping exists. + var needle = { + source: util.getArg(aArgs, 'source'), + originalLine: line, + originalColumn: util.getArg(aArgs, 'column', 0) + }; -Object.defineProperty(Duplex.prototype, 'destroyed', { - // making it explicit this property is not enumerable - // because otherwise some prototype manipulation in - // userland will fail - enumerable: false, - get: function get() { - if (this._readableState === undefined || this._writableState === undefined) { - return false; + needle.source = this._findSourceIndex(needle.source); + if (needle.source < 0) { + return []; } - return this._readableState.destroyed && this._writableState.destroyed; - }, - set: function set(value) { - // we ignore the value if the stream - // has not been initialized yet - if (this._readableState === undefined || this._writableState === undefined) { - return; - } // backward compatibility, the user is explicitly - // managing destroyed - - - this._readableState.destroyed = value; - this._writableState.destroyed = value; - } -}); - -/***/ }), - -/***/ 37838: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { - -"use strict"; -// Copyright Joyent, Inc. and other Node contributors. -// -// 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. -// a passthrough stream. -// basically just the most minimal sort of Transform stream. -// Every written chunk gets output as-is. - - -module.exports = PassThrough; - -var Transform = __nccwpck_require__(660); - -__nccwpck_require__(2868)(PassThrough, Transform); - -function PassThrough(options) { - if (!(this instanceof PassThrough)) return new PassThrough(options); - Transform.call(this, options); -} - -PassThrough.prototype._transform = function (chunk, encoding, cb) { - cb(null, chunk); -}; - -/***/ }), + var mappings = []; -/***/ 17911: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + var index = this._findMapping(needle, + this._originalMappings, + "originalLine", + "originalColumn", + util.compareByOriginalPositions, + binarySearch.LEAST_UPPER_BOUND); + if (index >= 0) { + var mapping = this._originalMappings[index]; -"use strict"; -// Copyright Joyent, Inc. and other Node contributors. -// -// 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. + if (aArgs.column === undefined) { + var originalLine = mapping.originalLine; + // Iterate until either we run out of mappings, or we run into + // a mapping for a different line than the one we found. Since + // mappings are sorted, this is guaranteed to find all mappings for + // the line we found. + while (mapping && mapping.originalLine === originalLine) { + mappings.push({ + line: util.getArg(mapping, 'generatedLine', null), + column: util.getArg(mapping, 'generatedColumn', null), + lastColumn: util.getArg(mapping, 'lastGeneratedColumn', null) + }); -module.exports = Readable; -/**/ + mapping = this._originalMappings[++index]; + } + } else { + var originalColumn = mapping.originalColumn; -var Duplex; -/**/ + // Iterate until either we run out of mappings, or we run into + // a mapping for a different line than the one we were searching for. + // Since mappings are sorted, this is guaranteed to find all mappings for + // the line we are searching for. + while (mapping && + mapping.originalLine === line && + mapping.originalColumn == originalColumn) { + mappings.push({ + line: util.getArg(mapping, 'generatedLine', null), + column: util.getArg(mapping, 'generatedColumn', null), + lastColumn: util.getArg(mapping, 'lastGeneratedColumn', null) + }); -Readable.ReadableState = ReadableState; -/**/ + mapping = this._originalMappings[++index]; + } + } + } -var EE = (__nccwpck_require__(82361).EventEmitter); + return mappings; + }; -var EElistenerCount = function EElistenerCount(emitter, type) { - return emitter.listeners(type).length; -}; -/**/ +exports.SourceMapConsumer = SourceMapConsumer; -/**/ +/** + * A BasicSourceMapConsumer instance represents a parsed source map which we can + * query for information about the original file positions by giving it a file + * position in the generated source. + * + * The first parameter is the raw source map (either as a JSON string, or + * already parsed to an object). According to the spec, source maps have the + * following attributes: + * + * - version: Which version of the source map spec this map is following. + * - sources: An array of URLs to the original source files. + * - names: An array of identifiers which can be referrenced by individual mappings. + * - sourceRoot: Optional. The URL root from which all sources are relative. + * - sourcesContent: Optional. An array of contents of the original source files. + * - mappings: A string of base64 VLQs which contain the actual mappings. + * - file: Optional. The generated file this source map is associated with. + * + * Here is an example source map, taken from the source map spec[0]: + * + * { + * version : 3, + * file: "out.js", + * sourceRoot : "", + * sources: ["foo.js", "bar.js"], + * names: ["src", "maps", "are", "fun"], + * mappings: "AA,AB;;ABCDE;" + * } + * + * The second parameter, if given, is a string whose value is the URL + * at which the source map was found. This URL is used to compute the + * sources array. + * + * [0]: https://docs.google.com/document/d/1U1RGAehQwRypUTovF1KRlpiOFze0b-_2gc6fAH0KY0k/edit?pli=1# + */ +function BasicSourceMapConsumer(aSourceMap, aSourceMapURL) { + var sourceMap = aSourceMap; + if (typeof aSourceMap === 'string') { + sourceMap = util.parseSourceMapInput(aSourceMap); + } + var version = util.getArg(sourceMap, 'version'); + var sources = util.getArg(sourceMap, 'sources'); + // Sass 3.3 leaves out the 'names' array, so we deviate from the spec (which + // requires the array) to play nice here. + var names = util.getArg(sourceMap, 'names', []); + var sourceRoot = util.getArg(sourceMap, 'sourceRoot', null); + var sourcesContent = util.getArg(sourceMap, 'sourcesContent', null); + var mappings = util.getArg(sourceMap, 'mappings'); + var file = util.getArg(sourceMap, 'file', null); -var Stream = __nccwpck_require__(4297); -/**/ + // Once again, Sass deviates from the spec and supplies the version as a + // string rather than a number, so we use loose equality checking here. + if (version != this._version) { + throw new Error('Unsupported version: ' + version); + } + if (sourceRoot) { + sourceRoot = util.normalize(sourceRoot); + } -var Buffer = (__nccwpck_require__(14300).Buffer); + sources = sources + .map(String) + // Some source maps produce relative source paths like "./foo.js" instead of + // "foo.js". Normalize these first so that future comparisons will succeed. + // See bugzil.la/1090768. + .map(util.normalize) + // Always ensure that absolute sources are internally stored relative to + // the source root, if the source root is absolute. Not doing this would + // be particularly problematic when the source root is a prefix of the + // source (valid, but why??). See github issue #199 and bugzil.la/1188982. + .map(function (source) { + return sourceRoot && util.isAbsolute(sourceRoot) && util.isAbsolute(source) + ? util.relative(sourceRoot, source) + : source; + }); -var OurUint8Array = global.Uint8Array || function () {}; + // Pass `true` below to allow duplicate names and sources. While source maps + // are intended to be compressed and deduplicated, the TypeScript compiler + // sometimes generates source maps with duplicates in them. See Github issue + // #72 and bugzil.la/889492. + this._names = ArraySet.fromArray(names.map(String), true); + this._sources = ArraySet.fromArray(sources, true); -function _uint8ArrayToBuffer(chunk) { - return Buffer.from(chunk); -} + this._absoluteSources = this._sources.toArray().map(function (s) { + return util.computeSourceURL(sourceRoot, s, aSourceMapURL); + }); -function _isUint8Array(obj) { - return Buffer.isBuffer(obj) || obj instanceof OurUint8Array; + this.sourceRoot = sourceRoot; + this.sourcesContent = sourcesContent; + this._mappings = mappings; + this._sourceMapURL = aSourceMapURL; + this.file = file; } -/**/ - -var debugUtil = __nccwpck_require__(73837); - -var debug; - -if (debugUtil && debugUtil.debuglog) { - debug = debugUtil.debuglog('stream'); -} else { - debug = function debug() {}; -} -/**/ +BasicSourceMapConsumer.prototype = Object.create(SourceMapConsumer.prototype); +BasicSourceMapConsumer.prototype.consumer = SourceMapConsumer; +/** + * Utility function to find the index of a source. Returns -1 if not + * found. + */ +BasicSourceMapConsumer.prototype._findSourceIndex = function(aSource) { + var relativeSource = aSource; + if (this.sourceRoot != null) { + relativeSource = util.relative(this.sourceRoot, relativeSource); + } -var BufferList = __nccwpck_require__(85243); + if (this._sources.has(relativeSource)) { + return this._sources.indexOf(relativeSource); + } -var destroyImpl = __nccwpck_require__(70079); + // Maybe aSource is an absolute URL as returned by |sources|. In + // this case we can't simply undo the transform. + var i; + for (i = 0; i < this._absoluteSources.length; ++i) { + if (this._absoluteSources[i] == aSource) { + return i; + } + } -var _require = __nccwpck_require__(97458), - getHighWaterMark = _require.getHighWaterMark; + return -1; +}; -var _require$codes = (__nccwpck_require__(91042)/* .codes */ .q), - ERR_INVALID_ARG_TYPE = _require$codes.ERR_INVALID_ARG_TYPE, - ERR_STREAM_PUSH_AFTER_EOF = _require$codes.ERR_STREAM_PUSH_AFTER_EOF, - ERR_METHOD_NOT_IMPLEMENTED = _require$codes.ERR_METHOD_NOT_IMPLEMENTED, - ERR_STREAM_UNSHIFT_AFTER_END_EVENT = _require$codes.ERR_STREAM_UNSHIFT_AFTER_END_EVENT; // Lazy loaded to improve the startup performance. +/** + * Create a BasicSourceMapConsumer from a SourceMapGenerator. + * + * @param SourceMapGenerator aSourceMap + * The source map that will be consumed. + * @param String aSourceMapURL + * The URL at which the source map can be found (optional) + * @returns BasicSourceMapConsumer + */ +BasicSourceMapConsumer.fromSourceMap = + function SourceMapConsumer_fromSourceMap(aSourceMap, aSourceMapURL) { + var smc = Object.create(BasicSourceMapConsumer.prototype); + var names = smc._names = ArraySet.fromArray(aSourceMap._names.toArray(), true); + var sources = smc._sources = ArraySet.fromArray(aSourceMap._sources.toArray(), true); + smc.sourceRoot = aSourceMap._sourceRoot; + smc.sourcesContent = aSourceMap._generateSourcesContent(smc._sources.toArray(), + smc.sourceRoot); + smc.file = aSourceMap._file; + smc._sourceMapURL = aSourceMapURL; + smc._absoluteSources = smc._sources.toArray().map(function (s) { + return util.computeSourceURL(smc.sourceRoot, s, aSourceMapURL); + }); -var StringDecoder; -var createReadableStreamAsyncIterator; -var from; + // Because we are modifying the entries (by converting string sources and + // names to indices into the sources and names ArraySets), we have to make + // a copy of the entry or else bad things happen. Shared mutable state + // strikes again! See github issue #191. -__nccwpck_require__(2868)(Readable, Stream); + var generatedMappings = aSourceMap._mappings.toArray().slice(); + var destGeneratedMappings = smc.__generatedMappings = []; + var destOriginalMappings = smc.__originalMappings = []; -var errorOrDestroy = destroyImpl.errorOrDestroy; -var kProxyEvents = ['error', 'close', 'destroy', 'pause', 'resume']; + for (var i = 0, length = generatedMappings.length; i < length; i++) { + var srcMapping = generatedMappings[i]; + var destMapping = new Mapping; + destMapping.generatedLine = srcMapping.generatedLine; + destMapping.generatedColumn = srcMapping.generatedColumn; -function prependListener(emitter, event, fn) { - // Sadly this is not cacheable as some libraries bundle their own - // event emitter implementation with them. - if (typeof emitter.prependListener === 'function') return emitter.prependListener(event, fn); // This is a hack to make sure that our error handler is attached before any - // userland ones. NEVER DO THIS. This is here only because this code needs - // to continue to work with older versions of Node.js that do not include - // the prependListener() method. The goal is to eventually remove this hack. + if (srcMapping.source) { + destMapping.source = sources.indexOf(srcMapping.source); + destMapping.originalLine = srcMapping.originalLine; + destMapping.originalColumn = srcMapping.originalColumn; - if (!emitter._events || !emitter._events[event]) emitter.on(event, fn);else if (Array.isArray(emitter._events[event])) emitter._events[event].unshift(fn);else emitter._events[event] = [fn, emitter._events[event]]; -} + if (srcMapping.name) { + destMapping.name = names.indexOf(srcMapping.name); + } -function ReadableState(options, stream, isDuplex) { - Duplex = Duplex || __nccwpck_require__(25408); - options = options || {}; // Duplex streams are both readable and writable, but share - // the same options object. - // However, some cases require setting options to different - // values for the readable and the writable sides of the duplex stream. - // These options can be provided separately as readableXXX and writableXXX. + destOriginalMappings.push(destMapping); + } - if (typeof isDuplex !== 'boolean') isDuplex = stream instanceof Duplex; // object stream flag. Used to make read(n) ignore n and to - // make all the buffer merging and length checks go away + destGeneratedMappings.push(destMapping); + } - this.objectMode = !!options.objectMode; - if (isDuplex) this.objectMode = this.objectMode || !!options.readableObjectMode; // the point at which it stops calling _read() to fill the buffer - // Note: 0 is a valid value, means "don't call _read preemptively ever" + quickSort(smc.__originalMappings, util.compareByOriginalPositions); - this.highWaterMark = getHighWaterMark(this, options, 'readableHighWaterMark', isDuplex); // A linked list is used to store data chunks instead of an array because the - // linked list can remove elements from the beginning faster than - // array.shift() + return smc; + }; - this.buffer = new BufferList(); - this.length = 0; - this.pipes = null; - this.pipesCount = 0; - this.flowing = null; - this.ended = false; - this.endEmitted = false; - this.reading = false; // a flag to be able to tell if the event 'readable'/'data' is emitted - // immediately, or on a later tick. We set this to true at first, because - // any actions that shouldn't happen until "later" should generally also - // not happen before the first read call. +/** + * The version of the source mapping spec that we are consuming. + */ +BasicSourceMapConsumer.prototype._version = 3; - this.sync = true; // whenever we return null, then we set a flag to say - // that we're awaiting a 'readable' event emission. +/** + * The list of original sources. + */ +Object.defineProperty(BasicSourceMapConsumer.prototype, 'sources', { + get: function () { + return this._absoluteSources.slice(); + } +}); - this.needReadable = false; - this.emittedReadable = false; - this.readableListening = false; - this.resumeScheduled = false; - this.paused = true; // Should close be emitted on destroy. Defaults to true. +/** + * Provide the JIT with a nice shape / hidden class. + */ +function Mapping() { + this.generatedLine = 0; + this.generatedColumn = 0; + this.source = null; + this.originalLine = null; + this.originalColumn = null; + this.name = null; +} - this.emitClose = options.emitClose !== false; // Should .destroy() be called after 'end' (and potentially 'finish') +/** + * Parse the mappings in a string in to a data structure which we can easily + * query (the ordered arrays in the `this.__generatedMappings` and + * `this.__originalMappings` properties). + */ +BasicSourceMapConsumer.prototype._parseMappings = + function SourceMapConsumer_parseMappings(aStr, aSourceRoot) { + var generatedLine = 1; + var previousGeneratedColumn = 0; + var previousOriginalLine = 0; + var previousOriginalColumn = 0; + var previousSource = 0; + var previousName = 0; + var length = aStr.length; + var index = 0; + var cachedSegments = {}; + var temp = {}; + var originalMappings = []; + var generatedMappings = []; + var mapping, str, segment, end, value; - this.autoDestroy = !!options.autoDestroy; // has it been destroyed + while (index < length) { + if (aStr.charAt(index) === ';') { + generatedLine++; + index++; + previousGeneratedColumn = 0; + } + else if (aStr.charAt(index) === ',') { + index++; + } + else { + mapping = new Mapping(); + mapping.generatedLine = generatedLine; - this.destroyed = false; // Crypto is kind of old and crusty. Historically, its default string - // encoding is 'binary' so we have to make this configurable. - // Everything else in the universe uses 'utf8', though. + // Because each offset is encoded relative to the previous one, + // many segments often have the same encoding. We can exploit this + // fact by caching the parsed variable length fields of each segment, + // allowing us to avoid a second parse if we encounter the same + // segment again. + for (end = index; end < length; end++) { + if (this._charIsMappingSeparator(aStr, end)) { + break; + } + } + str = aStr.slice(index, end); - this.defaultEncoding = options.defaultEncoding || 'utf8'; // the number of writers that are awaiting a drain event in .pipe()s + segment = cachedSegments[str]; + if (segment) { + index += str.length; + } else { + segment = []; + while (index < end) { + base64VLQ.decode(aStr, index, temp); + value = temp.value; + index = temp.rest; + segment.push(value); + } - this.awaitDrain = 0; // if true, a maybeReadMore has been scheduled + if (segment.length === 2) { + throw new Error('Found a source, but no line and column'); + } - this.readingMore = false; - this.decoder = null; - this.encoding = null; + if (segment.length === 3) { + throw new Error('Found a source and line, but no column'); + } - if (options.encoding) { - if (!StringDecoder) StringDecoder = (__nccwpck_require__(26590)/* .StringDecoder */ .s); - this.decoder = new StringDecoder(options.encoding); - this.encoding = options.encoding; - } -} + cachedSegments[str] = segment; + } -function Readable(options) { - Duplex = Duplex || __nccwpck_require__(25408); - if (!(this instanceof Readable)) return new Readable(options); // Checking for a Stream.Duplex instance is faster here instead of inside - // the ReadableState constructor, at least with V8 6.5 + // Generated column. + mapping.generatedColumn = previousGeneratedColumn + segment[0]; + previousGeneratedColumn = mapping.generatedColumn; - var isDuplex = this instanceof Duplex; - this._readableState = new ReadableState(options, this, isDuplex); // legacy + if (segment.length > 1) { + // Original source. + mapping.source = previousSource + segment[1]; + previousSource += segment[1]; - this.readable = true; + // Original line. + mapping.originalLine = previousOriginalLine + segment[2]; + previousOriginalLine = mapping.originalLine; + // Lines are stored 0-based + mapping.originalLine += 1; - if (options) { - if (typeof options.read === 'function') this._read = options.read; - if (typeof options.destroy === 'function') this._destroy = options.destroy; - } + // Original column. + mapping.originalColumn = previousOriginalColumn + segment[3]; + previousOriginalColumn = mapping.originalColumn; - Stream.call(this); -} + if (segment.length > 4) { + // Original name. + mapping.name = previousName + segment[4]; + previousName += segment[4]; + } + } -Object.defineProperty(Readable.prototype, 'destroyed', { - // making it explicit this property is not enumerable - // because otherwise some prototype manipulation in - // userland will fail - enumerable: false, - get: function get() { - if (this._readableState === undefined) { - return false; + generatedMappings.push(mapping); + if (typeof mapping.originalLine === 'number') { + originalMappings.push(mapping); + } + } } - return this._readableState.destroyed; - }, - set: function set(value) { - // we ignore the value if the stream - // has not been initialized yet - if (!this._readableState) { - return; - } // backward compatibility, the user is explicitly - // managing destroyed + quickSort(generatedMappings, util.compareByGeneratedPositionsDeflated); + this.__generatedMappings = generatedMappings; + quickSort(originalMappings, util.compareByOriginalPositions); + this.__originalMappings = originalMappings; + }; - this._readableState.destroyed = value; - } -}); -Readable.prototype.destroy = destroyImpl.destroy; -Readable.prototype._undestroy = destroyImpl.undestroy; +/** + * Find the mapping that best matches the hypothetical "needle" mapping that + * we are searching for in the given "haystack" of mappings. + */ +BasicSourceMapConsumer.prototype._findMapping = + function SourceMapConsumer_findMapping(aNeedle, aMappings, aLineName, + aColumnName, aComparator, aBias) { + // To return the position we are searching for, we must first find the + // mapping for the given position and then return the opposite position it + // points to. Because the mappings are sorted, we can use binary search to + // find the best mapping. -Readable.prototype._destroy = function (err, cb) { - cb(err); -}; // Manually shove something into the read() buffer. -// This returns true if the highWaterMark has not been hit yet, -// similar to how Writable.write() returns true if you should -// write() some more. + if (aNeedle[aLineName] <= 0) { + throw new TypeError('Line must be greater than or equal to 1, got ' + + aNeedle[aLineName]); + } + if (aNeedle[aColumnName] < 0) { + throw new TypeError('Column must be greater than or equal to 0, got ' + + aNeedle[aColumnName]); + } + return binarySearch.search(aNeedle, aMappings, aComparator, aBias); + }; -Readable.prototype.push = function (chunk, encoding) { - var state = this._readableState; - var skipChunkCheck; +/** + * Compute the last column for each generated mapping. The last column is + * inclusive. + */ +BasicSourceMapConsumer.prototype.computeColumnSpans = + function SourceMapConsumer_computeColumnSpans() { + for (var index = 0; index < this._generatedMappings.length; ++index) { + var mapping = this._generatedMappings[index]; - if (!state.objectMode) { - if (typeof chunk === 'string') { - encoding = encoding || state.defaultEncoding; + // Mappings do not contain a field for the last generated columnt. We + // can come up with an optimistic estimate, however, by assuming that + // mappings are contiguous (i.e. given two consecutive mappings, the + // first mapping ends where the second one starts). + if (index + 1 < this._generatedMappings.length) { + var nextMapping = this._generatedMappings[index + 1]; - if (encoding !== state.encoding) { - chunk = Buffer.from(chunk, encoding); - encoding = ''; + if (mapping.generatedLine === nextMapping.generatedLine) { + mapping.lastGeneratedColumn = nextMapping.generatedColumn - 1; + continue; + } } - skipChunkCheck = true; + // The last mapping for each line spans the entire line. + mapping.lastGeneratedColumn = Infinity; } - } else { - skipChunkCheck = true; - } - - return readableAddChunk(this, chunk, encoding, false, skipChunkCheck); -}; // Unshift should *always* be something directly out of read() - - -Readable.prototype.unshift = function (chunk) { - return readableAddChunk(this, chunk, null, true, false); -}; - -function readableAddChunk(stream, chunk, encoding, addToFront, skipChunkCheck) { - debug('readableAddChunk', chunk); - var state = stream._readableState; + }; - if (chunk === null) { - state.reading = false; - onEofChunk(stream, state); - } else { - var er; - if (!skipChunkCheck) er = chunkInvalid(state, chunk); +/** + * Returns the original source, line, and column information for the generated + * source's line and column positions provided. The only argument is an object + * with the following properties: + * + * - line: The line number in the generated source. The line number + * is 1-based. + * - column: The column number in the generated source. The column + * number is 0-based. + * - bias: Either 'SourceMapConsumer.GREATEST_LOWER_BOUND' or + * 'SourceMapConsumer.LEAST_UPPER_BOUND'. Specifies whether to return the + * closest element that is smaller than or greater than the one we are + * searching for, respectively, if the exact element cannot be found. + * Defaults to 'SourceMapConsumer.GREATEST_LOWER_BOUND'. + * + * and an object is returned with the following properties: + * + * - source: The original source file, or null. + * - line: The line number in the original source, or null. The + * line number is 1-based. + * - column: The column number in the original source, or null. The + * column number is 0-based. + * - name: The original identifier, or null. + */ +BasicSourceMapConsumer.prototype.originalPositionFor = + function SourceMapConsumer_originalPositionFor(aArgs) { + var needle = { + generatedLine: util.getArg(aArgs, 'line'), + generatedColumn: util.getArg(aArgs, 'column') + }; - if (er) { - errorOrDestroy(stream, er); - } else if (state.objectMode || chunk && chunk.length > 0) { - if (typeof chunk !== 'string' && !state.objectMode && Object.getPrototypeOf(chunk) !== Buffer.prototype) { - chunk = _uint8ArrayToBuffer(chunk); - } + var index = this._findMapping( + needle, + this._generatedMappings, + "generatedLine", + "generatedColumn", + util.compareByGeneratedPositionsDeflated, + util.getArg(aArgs, 'bias', SourceMapConsumer.GREATEST_LOWER_BOUND) + ); - if (addToFront) { - if (state.endEmitted) errorOrDestroy(stream, new ERR_STREAM_UNSHIFT_AFTER_END_EVENT());else addChunk(stream, state, chunk, true); - } else if (state.ended) { - errorOrDestroy(stream, new ERR_STREAM_PUSH_AFTER_EOF()); - } else if (state.destroyed) { - return false; - } else { - state.reading = false; + if (index >= 0) { + var mapping = this._generatedMappings[index]; - if (state.decoder && !encoding) { - chunk = state.decoder.write(chunk); - if (state.objectMode || chunk.length !== 0) addChunk(stream, state, chunk, false);else maybeReadMore(stream, state); - } else { - addChunk(stream, state, chunk, false); + if (mapping.generatedLine === needle.generatedLine) { + var source = util.getArg(mapping, 'source', null); + if (source !== null) { + source = this._sources.at(source); + source = util.computeSourceURL(this.sourceRoot, source, this._sourceMapURL); + } + var name = util.getArg(mapping, 'name', null); + if (name !== null) { + name = this._names.at(name); } + return { + source: source, + line: util.getArg(mapping, 'originalLine', null), + column: util.getArg(mapping, 'originalColumn', null), + name: name + }; } - } else if (!addToFront) { - state.reading = false; - maybeReadMore(stream, state); } - } // We can push more data if we are below the highWaterMark. - // Also, if we have no data yet, we can stand some more bytes. - // This is to work around cases where hwm=0, such as the repl. + return { + source: null, + line: null, + column: null, + name: null + }; + }; - return !state.ended && (state.length < state.highWaterMark || state.length === 0); -} +/** + * Return true if we have the source content for every source in the source + * map, false otherwise. + */ +BasicSourceMapConsumer.prototype.hasContentsOfAllSources = + function BasicSourceMapConsumer_hasContentsOfAllSources() { + if (!this.sourcesContent) { + return false; + } + return this.sourcesContent.length >= this._sources.size() && + !this.sourcesContent.some(function (sc) { return sc == null; }); + }; -function addChunk(stream, state, chunk, addToFront) { - if (state.flowing && state.length === 0 && !state.sync) { - state.awaitDrain = 0; - stream.emit('data', chunk); - } else { - // update the buffer info. - state.length += state.objectMode ? 1 : chunk.length; - if (addToFront) state.buffer.unshift(chunk);else state.buffer.push(chunk); - if (state.needReadable) emitReadable(stream); - } +/** + * Returns the original source content. The only argument is the url of the + * original source file. Returns null if no original source content is + * available. + */ +BasicSourceMapConsumer.prototype.sourceContentFor = + function SourceMapConsumer_sourceContentFor(aSource, nullOnMissing) { + if (!this.sourcesContent) { + return null; + } - maybeReadMore(stream, state); -} + var index = this._findSourceIndex(aSource); + if (index >= 0) { + return this.sourcesContent[index]; + } -function chunkInvalid(state, chunk) { - var er; + var relativeSource = aSource; + if (this.sourceRoot != null) { + relativeSource = util.relative(this.sourceRoot, relativeSource); + } - if (!_isUint8Array(chunk) && typeof chunk !== 'string' && chunk !== undefined && !state.objectMode) { - er = new ERR_INVALID_ARG_TYPE('chunk', ['string', 'Buffer', 'Uint8Array'], chunk); - } + var url; + if (this.sourceRoot != null + && (url = util.urlParse(this.sourceRoot))) { + // XXX: file:// URIs and absolute paths lead to unexpected behavior for + // many users. We can help them out when they expect file:// URIs to + // behave like it would if they were running a local HTTP server. See + // https://bugzilla.mozilla.org/show_bug.cgi?id=885597. + var fileUriAbsPath = relativeSource.replace(/^file:\/\//, ""); + if (url.scheme == "file" + && this._sources.has(fileUriAbsPath)) { + return this.sourcesContent[this._sources.indexOf(fileUriAbsPath)] + } - return er; -} + if ((!url.path || url.path == "/") + && this._sources.has("/" + relativeSource)) { + return this.sourcesContent[this._sources.indexOf("/" + relativeSource)]; + } + } -Readable.prototype.isPaused = function () { - return this._readableState.flowing === false; -}; // backwards compatibility. + // This function is used recursively from + // IndexedSourceMapConsumer.prototype.sourceContentFor. In that case, we + // don't want to throw if we can't find the source - we just want to + // return null, so we provide a flag to exit gracefully. + if (nullOnMissing) { + return null; + } + else { + throw new Error('"' + relativeSource + '" is not in the SourceMap.'); + } + }; +/** + * Returns the generated line and column information for the original source, + * line, and column positions provided. The only argument is an object with + * the following properties: + * + * - source: The filename of the original source. + * - line: The line number in the original source. The line number + * is 1-based. + * - column: The column number in the original source. The column + * number is 0-based. + * - bias: Either 'SourceMapConsumer.GREATEST_LOWER_BOUND' or + * 'SourceMapConsumer.LEAST_UPPER_BOUND'. Specifies whether to return the + * closest element that is smaller than or greater than the one we are + * searching for, respectively, if the exact element cannot be found. + * Defaults to 'SourceMapConsumer.GREATEST_LOWER_BOUND'. + * + * and an object is returned with the following properties: + * + * - line: The line number in the generated source, or null. The + * line number is 1-based. + * - column: The column number in the generated source, or null. + * The column number is 0-based. + */ +BasicSourceMapConsumer.prototype.generatedPositionFor = + function SourceMapConsumer_generatedPositionFor(aArgs) { + var source = util.getArg(aArgs, 'source'); + source = this._findSourceIndex(source); + if (source < 0) { + return { + line: null, + column: null, + lastColumn: null + }; + } -Readable.prototype.setEncoding = function (enc) { - if (!StringDecoder) StringDecoder = (__nccwpck_require__(26590)/* .StringDecoder */ .s); - var decoder = new StringDecoder(enc); - this._readableState.decoder = decoder; // If setEncoding(null), decoder.encoding equals utf8 + var needle = { + source: source, + originalLine: util.getArg(aArgs, 'line'), + originalColumn: util.getArg(aArgs, 'column') + }; - this._readableState.encoding = this._readableState.decoder.encoding; // Iterate over current buffer to convert already stored Buffers: + var index = this._findMapping( + needle, + this._originalMappings, + "originalLine", + "originalColumn", + util.compareByOriginalPositions, + util.getArg(aArgs, 'bias', SourceMapConsumer.GREATEST_LOWER_BOUND) + ); - var p = this._readableState.buffer.head; - var content = ''; + if (index >= 0) { + var mapping = this._originalMappings[index]; - while (p !== null) { - content += decoder.write(p.data); - p = p.next; - } + if (mapping.source === needle.source) { + return { + line: util.getArg(mapping, 'generatedLine', null), + column: util.getArg(mapping, 'generatedColumn', null), + lastColumn: util.getArg(mapping, 'lastGeneratedColumn', null) + }; + } + } - this._readableState.buffer.clear(); + return { + line: null, + column: null, + lastColumn: null + }; + }; - if (content !== '') this._readableState.buffer.push(content); - this._readableState.length = content.length; - return this; -}; // Don't raise the hwm > 1GB - - -var MAX_HWM = 0x40000000; +__webpack_unused_export__ = BasicSourceMapConsumer; -function computeNewHighWaterMark(n) { - if (n >= MAX_HWM) { - // TODO(ronag): Throw ERR_VALUE_OUT_OF_RANGE. - n = MAX_HWM; - } else { - // Get the next highest power of 2 to prevent increasing hwm excessively in - // tiny amounts - n--; - n |= n >>> 1; - n |= n >>> 2; - n |= n >>> 4; - n |= n >>> 8; - n |= n >>> 16; - n++; +/** + * An IndexedSourceMapConsumer instance represents a parsed source map which + * we can query for information. It differs from BasicSourceMapConsumer in + * that it takes "indexed" source maps (i.e. ones with a "sections" field) as + * input. + * + * The first parameter is a raw source map (either as a JSON string, or already + * parsed to an object). According to the spec for indexed source maps, they + * have the following attributes: + * + * - version: Which version of the source map spec this map is following. + * - file: Optional. The generated file this source map is associated with. + * - sections: A list of section definitions. + * + * Each value under the "sections" field has two fields: + * - offset: The offset into the original specified at which this section + * begins to apply, defined as an object with a "line" and "column" + * field. + * - map: A source map definition. This source map could also be indexed, + * but doesn't have to be. + * + * Instead of the "map" field, it's also possible to have a "url" field + * specifying a URL to retrieve a source map from, but that's currently + * unsupported. + * + * Here's an example source map, taken from the source map spec[0], but + * modified to omit a section which uses the "url" field. + * + * { + * version : 3, + * file: "app.js", + * sections: [{ + * offset: {line:100, column:10}, + * map: { + * version : 3, + * file: "section.js", + * sources: ["foo.js", "bar.js"], + * names: ["src", "maps", "are", "fun"], + * mappings: "AAAA,E;;ABCDE;" + * } + * }], + * } + * + * The second parameter, if given, is a string whose value is the URL + * at which the source map was found. This URL is used to compute the + * sources array. + * + * [0]: https://docs.google.com/document/d/1U1RGAehQwRypUTovF1KRlpiOFze0b-_2gc6fAH0KY0k/edit#heading=h.535es3xeprgt + */ +function IndexedSourceMapConsumer(aSourceMap, aSourceMapURL) { + var sourceMap = aSourceMap; + if (typeof aSourceMap === 'string') { + sourceMap = util.parseSourceMapInput(aSourceMap); } - return n; -} // This function is designed to be inlinable, so please take care when making -// changes to the function body. - - -function howMuchToRead(n, state) { - if (n <= 0 || state.length === 0 && state.ended) return 0; - if (state.objectMode) return 1; - - if (n !== n) { - // Only flow one buffer at a time - if (state.flowing && state.length) return state.buffer.head.data.length;else return state.length; - } // If we're asking for more than the current hwm, then raise the hwm. - - - if (n > state.highWaterMark) state.highWaterMark = computeNewHighWaterMark(n); - if (n <= state.length) return n; // Don't have enough + var version = util.getArg(sourceMap, 'version'); + var sections = util.getArg(sourceMap, 'sections'); - if (!state.ended) { - state.needReadable = true; - return 0; + if (version != this._version) { + throw new Error('Unsupported version: ' + version); } - return state.length; -} // you can override either this method, or the async _read(n) below. - - -Readable.prototype.read = function (n) { - debug('read', n); - n = parseInt(n, 10); - var state = this._readableState; - var nOrig = n; - if (n !== 0) state.emittedReadable = false; // if we're doing read(0) to trigger a readable event, but we - // already have a bunch of data in the buffer, then just trigger - // the 'readable' event and move on. - - if (n === 0 && state.needReadable && ((state.highWaterMark !== 0 ? state.length >= state.highWaterMark : state.length > 0) || state.ended)) { - debug('read: emitReadable', state.length, state.ended); - if (state.length === 0 && state.ended) endReadable(this);else emitReadable(this); - return null; - } + this._sources = new ArraySet(); + this._names = new ArraySet(); - n = howMuchToRead(n, state); // if we've ended, and we're now clear, then finish it up. + var lastOffset = { + line: -1, + column: 0 + }; + this._sections = sections.map(function (s) { + if (s.url) { + // The url field will require support for asynchronicity. + // See https://github.com/mozilla/source-map/issues/16 + throw new Error('Support for url field in sections not implemented.'); + } + var offset = util.getArg(s, 'offset'); + var offsetLine = util.getArg(offset, 'line'); + var offsetColumn = util.getArg(offset, 'column'); - if (n === 0 && state.ended) { - if (state.length === 0) endReadable(this); - return null; - } // All the actual chunk generation logic needs to be - // *below* the call to _read. The reason is that in certain - // synthetic stream cases, such as passthrough streams, _read - // may be a completely synchronous operation which may change - // the state of the read buffer, providing enough data when - // before there was *not* enough. - // - // So, the steps are: - // 1. Figure out what the state of things will be after we do - // a read from the buffer. - // - // 2. If that resulting state will trigger a _read, then call _read. - // Note that this may be asynchronous, or synchronous. Yes, it is - // deeply ugly to write APIs this way, but that still doesn't mean - // that the Readable class should behave improperly, as streams are - // designed to be sync/async agnostic. - // Take note if the _read call is sync or async (ie, if the read call - // has returned yet), so that we know whether or not it's safe to emit - // 'readable' etc. - // - // 3. Actually pull the requested chunks out of the buffer and return. - // if we need a readable event, then we need to do some reading. + if (offsetLine < lastOffset.line || + (offsetLine === lastOffset.line && offsetColumn < lastOffset.column)) { + throw new Error('Section offsets must be ordered and non-overlapping.'); + } + lastOffset = offset; + return { + generatedOffset: { + // The offset fields are 0-based, but we use 1-based indices when + // encoding/decoding from VLQ. + generatedLine: offsetLine + 1, + generatedColumn: offsetColumn + 1 + }, + consumer: new SourceMapConsumer(util.getArg(s, 'map'), aSourceMapURL) + } + }); +} - var doRead = state.needReadable; - debug('need readable', doRead); // if we currently have less than the highWaterMark, then also read some +IndexedSourceMapConsumer.prototype = Object.create(SourceMapConsumer.prototype); +IndexedSourceMapConsumer.prototype.constructor = SourceMapConsumer; - if (state.length === 0 || state.length - n < state.highWaterMark) { - doRead = true; - debug('length less than watermark', doRead); - } // however, if we've ended, then there's no point, and if we're already - // reading, then it's unnecessary. +/** + * The version of the source mapping spec that we are consuming. + */ +IndexedSourceMapConsumer.prototype._version = 3; +/** + * The list of original sources. + */ +Object.defineProperty(IndexedSourceMapConsumer.prototype, 'sources', { + get: function () { + var sources = []; + for (var i = 0; i < this._sections.length; i++) { + for (var j = 0; j < this._sections[i].consumer.sources.length; j++) { + sources.push(this._sections[i].consumer.sources[j]); + } + } + return sources; + } +}); - if (state.ended || state.reading) { - doRead = false; - debug('reading or ended', doRead); - } else if (doRead) { - debug('do read'); - state.reading = true; - state.sync = true; // if the length is currently zero, then we *need* a readable event. +/** + * Returns the original source, line, and column information for the generated + * source's line and column positions provided. The only argument is an object + * with the following properties: + * + * - line: The line number in the generated source. The line number + * is 1-based. + * - column: The column number in the generated source. The column + * number is 0-based. + * + * and an object is returned with the following properties: + * + * - source: The original source file, or null. + * - line: The line number in the original source, or null. The + * line number is 1-based. + * - column: The column number in the original source, or null. The + * column number is 0-based. + * - name: The original identifier, or null. + */ +IndexedSourceMapConsumer.prototype.originalPositionFor = + function IndexedSourceMapConsumer_originalPositionFor(aArgs) { + var needle = { + generatedLine: util.getArg(aArgs, 'line'), + generatedColumn: util.getArg(aArgs, 'column') + }; - if (state.length === 0) state.needReadable = true; // call internal read method + // Find the section containing the generated position we're trying to map + // to an original position. + var sectionIndex = binarySearch.search(needle, this._sections, + function(needle, section) { + var cmp = needle.generatedLine - section.generatedOffset.generatedLine; + if (cmp) { + return cmp; + } - this._read(state.highWaterMark); + return (needle.generatedColumn - + section.generatedOffset.generatedColumn); + }); + var section = this._sections[sectionIndex]; - state.sync = false; // If _read pushed data synchronously, then `reading` will be false, - // and we need to re-evaluate how much data we can return to the user. + if (!section) { + return { + source: null, + line: null, + column: null, + name: null + }; + } - if (!state.reading) n = howMuchToRead(nOrig, state); - } + return section.consumer.originalPositionFor({ + line: needle.generatedLine - + (section.generatedOffset.generatedLine - 1), + column: needle.generatedColumn - + (section.generatedOffset.generatedLine === needle.generatedLine + ? section.generatedOffset.generatedColumn - 1 + : 0), + bias: aArgs.bias + }); + }; - var ret; - if (n > 0) ret = fromList(n, state);else ret = null; +/** + * Return true if we have the source content for every source in the source + * map, false otherwise. + */ +IndexedSourceMapConsumer.prototype.hasContentsOfAllSources = + function IndexedSourceMapConsumer_hasContentsOfAllSources() { + return this._sections.every(function (s) { + return s.consumer.hasContentsOfAllSources(); + }); + }; - if (ret === null) { - state.needReadable = state.length <= state.highWaterMark; - n = 0; - } else { - state.length -= n; - state.awaitDrain = 0; - } +/** + * Returns the original source content. The only argument is the url of the + * original source file. Returns null if no original source content is + * available. + */ +IndexedSourceMapConsumer.prototype.sourceContentFor = + function IndexedSourceMapConsumer_sourceContentFor(aSource, nullOnMissing) { + for (var i = 0; i < this._sections.length; i++) { + var section = this._sections[i]; - if (state.length === 0) { - // If we have nothing in the buffer, then we want to know - // as soon as we *do* get something into the buffer. - if (!state.ended) state.needReadable = true; // If we tried to read() past the EOF, then emit end on the next tick. + var content = section.consumer.sourceContentFor(aSource, true); + if (content) { + return content; + } + } + if (nullOnMissing) { + return null; + } + else { + throw new Error('"' + aSource + '" is not in the SourceMap.'); + } + }; - if (nOrig !== n && state.ended) endReadable(this); - } +/** + * Returns the generated line and column information for the original source, + * line, and column positions provided. The only argument is an object with + * the following properties: + * + * - source: The filename of the original source. + * - line: The line number in the original source. The line number + * is 1-based. + * - column: The column number in the original source. The column + * number is 0-based. + * + * and an object is returned with the following properties: + * + * - line: The line number in the generated source, or null. The + * line number is 1-based. + * - column: The column number in the generated source, or null. + * The column number is 0-based. + */ +IndexedSourceMapConsumer.prototype.generatedPositionFor = + function IndexedSourceMapConsumer_generatedPositionFor(aArgs) { + for (var i = 0; i < this._sections.length; i++) { + var section = this._sections[i]; - if (ret !== null) this.emit('data', ret); - return ret; -}; + // Only consider this section if the requested source is in the list of + // sources of the consumer. + if (section.consumer._findSourceIndex(util.getArg(aArgs, 'source')) === -1) { + continue; + } + var generatedPosition = section.consumer.generatedPositionFor(aArgs); + if (generatedPosition) { + var ret = { + line: generatedPosition.line + + (section.generatedOffset.generatedLine - 1), + column: generatedPosition.column + + (section.generatedOffset.generatedLine === generatedPosition.line + ? section.generatedOffset.generatedColumn - 1 + : 0) + }; + return ret; + } + } -function onEofChunk(stream, state) { - debug('onEofChunk'); - if (state.ended) return; + return { + line: null, + column: null + }; + }; - if (state.decoder) { - var chunk = state.decoder.end(); +/** + * Parse the mappings in a string in to a data structure which we can easily + * query (the ordered arrays in the `this.__generatedMappings` and + * `this.__originalMappings` properties). + */ +IndexedSourceMapConsumer.prototype._parseMappings = + function IndexedSourceMapConsumer_parseMappings(aStr, aSourceRoot) { + this.__generatedMappings = []; + this.__originalMappings = []; + for (var i = 0; i < this._sections.length; i++) { + var section = this._sections[i]; + var sectionMappings = section.consumer._generatedMappings; + for (var j = 0; j < sectionMappings.length; j++) { + var mapping = sectionMappings[j]; - if (chunk && chunk.length) { - state.buffer.push(chunk); - state.length += state.objectMode ? 1 : chunk.length; - } - } + var source = section.consumer._sources.at(mapping.source); + source = util.computeSourceURL(section.consumer.sourceRoot, source, this._sourceMapURL); + this._sources.add(source); + source = this._sources.indexOf(source); - state.ended = true; + var name = null; + if (mapping.name) { + name = section.consumer._names.at(mapping.name); + this._names.add(name); + name = this._names.indexOf(name); + } - if (state.sync) { - // if we are sync, wait until next tick to emit the data. - // Otherwise we risk emitting data in the flow() - // the readable code triggers during a read() call - emitReadable(stream); - } else { - // emit 'readable' now to make sure it gets picked up. - state.needReadable = false; + // The mappings coming from the consumer for the section have + // generated positions relative to the start of the section, so we + // need to offset them to be relative to the start of the concatenated + // generated file. + var adjustedMapping = { + source: source, + generatedLine: mapping.generatedLine + + (section.generatedOffset.generatedLine - 1), + generatedColumn: mapping.generatedColumn + + (section.generatedOffset.generatedLine === mapping.generatedLine + ? section.generatedOffset.generatedColumn - 1 + : 0), + originalLine: mapping.originalLine, + originalColumn: mapping.originalColumn, + name: name + }; - if (!state.emittedReadable) { - state.emittedReadable = true; - emitReadable_(stream); + this.__generatedMappings.push(adjustedMapping); + if (typeof adjustedMapping.originalLine === 'number') { + this.__originalMappings.push(adjustedMapping); + } + } } - } -} // Don't emit readable right away in sync mode, because this can trigger -// another read() call => stack overflow. This way, it might trigger -// a nextTick recursion warning, but that's not so bad. + quickSort(this.__generatedMappings, util.compareByGeneratedPositionsDeflated); + quickSort(this.__originalMappings, util.compareByOriginalPositions); + }; -function emitReadable(stream) { - var state = stream._readableState; - debug('emitReadable', state.needReadable, state.emittedReadable); - state.needReadable = false; - - if (!state.emittedReadable) { - debug('emitReadable', state.flowing); - state.emittedReadable = true; - process.nextTick(emitReadable_, stream); - } -} +__webpack_unused_export__ = IndexedSourceMapConsumer; -function emitReadable_(stream) { - var state = stream._readableState; - debug('emitReadable_', state.destroyed, state.length, state.ended); - if (!state.destroyed && (state.length || state.ended)) { - stream.emit('readable'); - state.emittedReadable = false; - } // The stream needs another readable event if - // 1. It is not flowing, as the flow mechanism will take - // care of it. - // 2. It is not ended. - // 3. It is below the highWaterMark, so we can schedule - // another readable later. +/***/ }), +/***/ 22370: +/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { - state.needReadable = !state.flowing && !state.ended && state.length <= state.highWaterMark; - flow(stream); -} // at this point, the user has presumably seen the 'readable' event, -// and called read() to consume some data. that may have triggered -// in turn another _read(n) call, in which case reading = true if -// it's in progress. -// However, if we're not ended, or reading, and the length < hwm, -// then go ahead and try to read some more preemptively. +/* -*- Mode: js; js-indent-level: 2; -*- */ +/* + * Copyright 2011 Mozilla Foundation and contributors + * Licensed under the New BSD license. See LICENSE or: + * http://opensource.org/licenses/BSD-3-Clause + */ +var base64VLQ = __nccwpck_require__(26672); +var util = __nccwpck_require__(89479); +var ArraySet = (__nccwpck_require__(62880)/* .ArraySet */ .I); +var MappingList = (__nccwpck_require__(66439)/* .MappingList */ .H); -function maybeReadMore(stream, state) { - if (!state.readingMore) { - state.readingMore = true; - process.nextTick(maybeReadMore_, stream, state); +/** + * An instance of the SourceMapGenerator represents a source map which is + * being built incrementally. You may pass an object with the following + * properties: + * + * - file: The filename of the generated source. + * - sourceRoot: A root for all relative URLs in this source map. + */ +function SourceMapGenerator(aArgs) { + if (!aArgs) { + aArgs = {}; } + this._file = util.getArg(aArgs, 'file', null); + this._sourceRoot = util.getArg(aArgs, 'sourceRoot', null); + this._skipValidation = util.getArg(aArgs, 'skipValidation', false); + this._sources = new ArraySet(); + this._names = new ArraySet(); + this._mappings = new MappingList(); + this._sourcesContents = null; } -function maybeReadMore_(stream, state) { - // Attempt to read more data if we should. - // - // The conditions for reading more data are (one of): - // - Not enough data buffered (state.length < state.highWaterMark). The loop - // is responsible for filling the buffer with enough data if such data - // is available. If highWaterMark is 0 and we are not in the flowing mode - // we should _not_ attempt to buffer any extra data. We'll get more data - // when the stream consumer calls read() instead. - // - No data in the buffer, and the stream is in flowing mode. In this mode - // the loop below is responsible for ensuring read() is called. Failing to - // call read here would abort the flow and there's no other mechanism for - // continuing the flow if the stream consumer has just subscribed to the - // 'data' event. - // - // In addition to the above conditions to keep reading data, the following - // conditions prevent the data from being read: - // - The stream has ended (state.ended). - // - There is already a pending 'read' operation (state.reading). This is a - // case where the the stream has called the implementation defined _read() - // method, but they are processing the call asynchronously and have _not_ - // called push() with new data. In this case we skip performing more - // read()s. The execution ends in this method again after the _read() ends - // up calling push() with more data. - while (!state.reading && !state.ended && (state.length < state.highWaterMark || state.flowing && state.length === 0)) { - var len = state.length; - debug('maybeReadMore read 0'); - stream.read(0); - if (len === state.length) // didn't get any data, stop spinning. - break; - } +SourceMapGenerator.prototype._version = 3; - state.readingMore = false; -} // abstract method. to be overridden in specific implementation classes. -// call cb(er, data) where data is <= n in length. -// for virtual (non-string, non-buffer) streams, "length" is somewhat -// arbitrary, and perhaps not very meaningful. +/** + * Creates a new SourceMapGenerator based on a SourceMapConsumer + * + * @param aSourceMapConsumer The SourceMap. + */ +SourceMapGenerator.fromSourceMap = + function SourceMapGenerator_fromSourceMap(aSourceMapConsumer) { + var sourceRoot = aSourceMapConsumer.sourceRoot; + var generator = new SourceMapGenerator({ + file: aSourceMapConsumer.file, + sourceRoot: sourceRoot + }); + aSourceMapConsumer.eachMapping(function (mapping) { + var newMapping = { + generated: { + line: mapping.generatedLine, + column: mapping.generatedColumn + } + }; + if (mapping.source != null) { + newMapping.source = mapping.source; + if (sourceRoot != null) { + newMapping.source = util.relative(sourceRoot, newMapping.source); + } -Readable.prototype._read = function (n) { - errorOrDestroy(this, new ERR_METHOD_NOT_IMPLEMENTED('_read()')); -}; + newMapping.original = { + line: mapping.originalLine, + column: mapping.originalColumn + }; -Readable.prototype.pipe = function (dest, pipeOpts) { - var src = this; - var state = this._readableState; + if (mapping.name != null) { + newMapping.name = mapping.name; + } + } - switch (state.pipesCount) { - case 0: - state.pipes = dest; - break; + generator.addMapping(newMapping); + }); + aSourceMapConsumer.sources.forEach(function (sourceFile) { + var sourceRelative = sourceFile; + if (sourceRoot !== null) { + sourceRelative = util.relative(sourceRoot, sourceFile); + } - case 1: - state.pipes = [state.pipes, dest]; - break; + if (!generator._sources.has(sourceRelative)) { + generator._sources.add(sourceRelative); + } - default: - state.pipes.push(dest); - break; - } + var content = aSourceMapConsumer.sourceContentFor(sourceFile); + if (content != null) { + generator.setSourceContent(sourceFile, content); + } + }); + return generator; + }; - state.pipesCount += 1; - debug('pipe count=%d opts=%j', state.pipesCount, pipeOpts); - var doEnd = (!pipeOpts || pipeOpts.end !== false) && dest !== process.stdout && dest !== process.stderr; - var endFn = doEnd ? onend : unpipe; - if (state.endEmitted) process.nextTick(endFn);else src.once('end', endFn); - dest.on('unpipe', onunpipe); +/** + * Add a single mapping from original source line and column to the generated + * source's line and column for this source map being created. The mapping + * object should have the following properties: + * + * - generated: An object with the generated line and column positions. + * - original: An object with the original line and column positions. + * - source: The original source file (relative to the sourceRoot). + * - name: An optional original token name for this mapping. + */ +SourceMapGenerator.prototype.addMapping = + function SourceMapGenerator_addMapping(aArgs) { + var generated = util.getArg(aArgs, 'generated'); + var original = util.getArg(aArgs, 'original', null); + var source = util.getArg(aArgs, 'source', null); + var name = util.getArg(aArgs, 'name', null); - function onunpipe(readable, unpipeInfo) { - debug('onunpipe'); + if (!this._skipValidation) { + this._validateMapping(generated, original, source, name); + } - if (readable === src) { - if (unpipeInfo && unpipeInfo.hasUnpiped === false) { - unpipeInfo.hasUnpiped = true; - cleanup(); + if (source != null) { + source = String(source); + if (!this._sources.has(source)) { + this._sources.add(source); } } - } - function onend() { - debug('onend'); - dest.end(); - } // when the dest drains, it reduces the awaitDrain counter - // on the source. This would be more elegant with a .once() - // handler in flow(), but adding and removing repeatedly is - // too slow. + if (name != null) { + name = String(name); + if (!this._names.has(name)) { + this._names.add(name); + } + } + this._mappings.add({ + generatedLine: generated.line, + generatedColumn: generated.column, + originalLine: original != null && original.line, + originalColumn: original != null && original.column, + source: source, + name: name + }); + }; - var ondrain = pipeOnDrain(src); - dest.on('drain', ondrain); - var cleanedUp = false; +/** + * Set the source content for a source file. + */ +SourceMapGenerator.prototype.setSourceContent = + function SourceMapGenerator_setSourceContent(aSourceFile, aSourceContent) { + var source = aSourceFile; + if (this._sourceRoot != null) { + source = util.relative(this._sourceRoot, source); + } - function cleanup() { - debug('cleanup'); // cleanup event handlers once the pipe is broken + if (aSourceContent != null) { + // Add the source content to the _sourcesContents map. + // Create a new _sourcesContents map if the property is null. + if (!this._sourcesContents) { + this._sourcesContents = Object.create(null); + } + this._sourcesContents[util.toSetString(source)] = aSourceContent; + } else if (this._sourcesContents) { + // Remove the source file from the _sourcesContents map. + // If the _sourcesContents map is empty, set the property to null. + delete this._sourcesContents[util.toSetString(source)]; + if (Object.keys(this._sourcesContents).length === 0) { + this._sourcesContents = null; + } + } + }; - dest.removeListener('close', onclose); - dest.removeListener('finish', onfinish); - dest.removeListener('drain', ondrain); - dest.removeListener('error', onerror); - dest.removeListener('unpipe', onunpipe); - src.removeListener('end', onend); - src.removeListener('end', unpipe); - src.removeListener('data', ondata); - cleanedUp = true; // if the reader is waiting for a drain event from this - // specific writer, then it would cause it to never start - // flowing again. - // So, if this is awaiting a drain, then we just call it now. - // If we don't know, then assume that we are waiting for one. +/** + * Applies the mappings of a sub-source-map for a specific source file to the + * source map being generated. Each mapping to the supplied source file is + * rewritten using the supplied source map. Note: The resolution for the + * resulting mappings is the minimium of this map and the supplied map. + * + * @param aSourceMapConsumer The source map to be applied. + * @param aSourceFile Optional. The filename of the source file. + * If omitted, SourceMapConsumer's file property will be used. + * @param aSourceMapPath Optional. The dirname of the path to the source map + * to be applied. If relative, it is relative to the SourceMapConsumer. + * This parameter is needed when the two source maps aren't in the same + * directory, and the source map to be applied contains relative source + * paths. If so, those relative source paths need to be rewritten + * relative to the SourceMapGenerator. + */ +SourceMapGenerator.prototype.applySourceMap = + function SourceMapGenerator_applySourceMap(aSourceMapConsumer, aSourceFile, aSourceMapPath) { + var sourceFile = aSourceFile; + // If aSourceFile is omitted, we will use the file property of the SourceMap + if (aSourceFile == null) { + if (aSourceMapConsumer.file == null) { + throw new Error( + 'SourceMapGenerator.prototype.applySourceMap requires either an explicit source file, ' + + 'or the source map\'s "file" property. Both were omitted.' + ); + } + sourceFile = aSourceMapConsumer.file; + } + var sourceRoot = this._sourceRoot; + // Make "sourceFile" relative if an absolute Url is passed. + if (sourceRoot != null) { + sourceFile = util.relative(sourceRoot, sourceFile); + } + // Applying the SourceMap can add and remove items from the sources and + // the names array. + var newSources = new ArraySet(); + var newNames = new ArraySet(); - if (state.awaitDrain && (!dest._writableState || dest._writableState.needDrain)) ondrain(); - } + // Find mappings for the "sourceFile" + this._mappings.unsortedForEach(function (mapping) { + if (mapping.source === sourceFile && mapping.originalLine != null) { + // Check if it can be mapped by the source map, then update the mapping. + var original = aSourceMapConsumer.originalPositionFor({ + line: mapping.originalLine, + column: mapping.originalColumn + }); + if (original.source != null) { + // Copy mapping + mapping.source = original.source; + if (aSourceMapPath != null) { + mapping.source = util.join(aSourceMapPath, mapping.source) + } + if (sourceRoot != null) { + mapping.source = util.relative(sourceRoot, mapping.source); + } + mapping.originalLine = original.line; + mapping.originalColumn = original.column; + if (original.name != null) { + mapping.name = original.name; + } + } + } - src.on('data', ondata); + var source = mapping.source; + if (source != null && !newSources.has(source)) { + newSources.add(source); + } - function ondata(chunk) { - debug('ondata'); - var ret = dest.write(chunk); - debug('dest.write', ret); + var name = mapping.name; + if (name != null && !newNames.has(name)) { + newNames.add(name); + } - if (ret === false) { - // If the user unpiped during `dest.write()`, it is possible - // to get stuck in a permanently paused state if that write - // also returned false. - // => Check whether `dest` is still a piping destination. - if ((state.pipesCount === 1 && state.pipes === dest || state.pipesCount > 1 && indexOf(state.pipes, dest) !== -1) && !cleanedUp) { - debug('false write response, pause', state.awaitDrain); - state.awaitDrain++; + }, this); + this._sources = newSources; + this._names = newNames; + + // Copy sourcesContents of applied map. + aSourceMapConsumer.sources.forEach(function (sourceFile) { + var content = aSourceMapConsumer.sourceContentFor(sourceFile); + if (content != null) { + if (aSourceMapPath != null) { + sourceFile = util.join(aSourceMapPath, sourceFile); + } + if (sourceRoot != null) { + sourceFile = util.relative(sourceRoot, sourceFile); + } + this.setSourceContent(sourceFile, content); } + }, this); + }; - src.pause(); +/** + * A mapping can have one of the three levels of data: + * + * 1. Just the generated position. + * 2. The Generated position, original position, and original source. + * 3. Generated and original position, original source, as well as a name + * token. + * + * To maintain consistency, we validate that any new mapping being added falls + * in to one of these categories. + */ +SourceMapGenerator.prototype._validateMapping = + function SourceMapGenerator_validateMapping(aGenerated, aOriginal, aSource, + aName) { + // When aOriginal is truthy but has empty values for .line and .column, + // it is most likely a programmer error. In this case we throw a very + // specific error message to try to guide them the right way. + // For example: https://github.com/Polymer/polymer-bundler/pull/519 + if (aOriginal && typeof aOriginal.line !== 'number' && typeof aOriginal.column !== 'number') { + throw new Error( + 'original.line and original.column are not numbers -- you probably meant to omit ' + + 'the original mapping entirely and only map the generated position. If so, pass ' + + 'null for the original mapping instead of an object with empty or null values.' + ); } - } // if the dest has an error, then stop piping into it. - // however, don't suppress the throwing behavior for this. + if (aGenerated && 'line' in aGenerated && 'column' in aGenerated + && aGenerated.line > 0 && aGenerated.column >= 0 + && !aOriginal && !aSource && !aName) { + // Case 1. + return; + } + else if (aGenerated && 'line' in aGenerated && 'column' in aGenerated + && aOriginal && 'line' in aOriginal && 'column' in aOriginal + && aGenerated.line > 0 && aGenerated.column >= 0 + && aOriginal.line > 0 && aOriginal.column >= 0 + && aSource) { + // Cases 2 and 3. + return; + } + else { + throw new Error('Invalid mapping: ' + JSON.stringify({ + generated: aGenerated, + source: aSource, + original: aOriginal, + name: aName + })); + } + }; - function onerror(er) { - debug('onerror', er); - unpipe(); - dest.removeListener('error', onerror); - if (EElistenerCount(dest, 'error') === 0) errorOrDestroy(dest, er); - } // Make sure our error handler is attached before userland ones. +/** + * Serialize the accumulated mappings in to the stream of base 64 VLQs + * specified by the source map format. + */ +SourceMapGenerator.prototype._serializeMappings = + function SourceMapGenerator_serializeMappings() { + var previousGeneratedColumn = 0; + var previousGeneratedLine = 1; + var previousOriginalColumn = 0; + var previousOriginalLine = 0; + var previousName = 0; + var previousSource = 0; + var result = ''; + var next; + var mapping; + var nameIdx; + var sourceIdx; + var mappings = this._mappings.toArray(); + for (var i = 0, len = mappings.length; i < len; i++) { + mapping = mappings[i]; + next = '' - prependListener(dest, 'error', onerror); // Both close and finish should trigger unpipe, but only once. + if (mapping.generatedLine !== previousGeneratedLine) { + previousGeneratedColumn = 0; + while (mapping.generatedLine !== previousGeneratedLine) { + next += ';'; + previousGeneratedLine++; + } + } + else { + if (i > 0) { + if (!util.compareByGeneratedPositionsInflated(mapping, mappings[i - 1])) { + continue; + } + next += ','; + } + } - function onclose() { - dest.removeListener('finish', onfinish); - unpipe(); - } + next += base64VLQ.encode(mapping.generatedColumn + - previousGeneratedColumn); + previousGeneratedColumn = mapping.generatedColumn; - dest.once('close', onclose); + if (mapping.source != null) { + sourceIdx = this._sources.indexOf(mapping.source); + next += base64VLQ.encode(sourceIdx - previousSource); + previousSource = sourceIdx; - function onfinish() { - debug('onfinish'); - dest.removeListener('close', onclose); - unpipe(); - } + // lines are stored 0-based in SourceMap spec version 3 + next += base64VLQ.encode(mapping.originalLine - 1 + - previousOriginalLine); + previousOriginalLine = mapping.originalLine - 1; - dest.once('finish', onfinish); + next += base64VLQ.encode(mapping.originalColumn + - previousOriginalColumn); + previousOriginalColumn = mapping.originalColumn; - function unpipe() { - debug('unpipe'); - src.unpipe(dest); - } // tell the dest that it's being piped to + if (mapping.name != null) { + nameIdx = this._names.indexOf(mapping.name); + next += base64VLQ.encode(nameIdx - previousName); + previousName = nameIdx; + } + } + result += next; + } - dest.emit('pipe', src); // start the flow if it hasn't been started already. + return result; + }; - if (!state.flowing) { - debug('pipe resume'); - src.resume(); - } +SourceMapGenerator.prototype._generateSourcesContent = + function SourceMapGenerator_generateSourcesContent(aSources, aSourceRoot) { + return aSources.map(function (source) { + if (!this._sourcesContents) { + return null; + } + if (aSourceRoot != null) { + source = util.relative(aSourceRoot, source); + } + var key = util.toSetString(source); + return Object.prototype.hasOwnProperty.call(this._sourcesContents, key) + ? this._sourcesContents[key] + : null; + }, this); + }; - return dest; -}; +/** + * Externalize the source map. + */ +SourceMapGenerator.prototype.toJSON = + function SourceMapGenerator_toJSON() { + var map = { + version: this._version, + sources: this._sources.toArray(), + names: this._names.toArray(), + mappings: this._serializeMappings() + }; + if (this._file != null) { + map.file = this._file; + } + if (this._sourceRoot != null) { + map.sourceRoot = this._sourceRoot; + } + if (this._sourcesContents) { + map.sourcesContent = this._generateSourcesContent(map.sources, map.sourceRoot); + } -function pipeOnDrain(src) { - return function pipeOnDrainFunctionResult() { - var state = src._readableState; - debug('pipeOnDrain', state.awaitDrain); - if (state.awaitDrain) state.awaitDrain--; + return map; + }; - if (state.awaitDrain === 0 && EElistenerCount(src, 'data')) { - state.flowing = true; - flow(src); - } +/** + * Render the source map being generated to a string. + */ +SourceMapGenerator.prototype.toString = + function SourceMapGenerator_toString() { + return JSON.stringify(this.toJSON()); }; -} -Readable.prototype.unpipe = function (dest) { - var state = this._readableState; - var unpipeInfo = { - hasUnpiped: false - }; // if we're not piping anywhere, then do nothing. +exports.h = SourceMapGenerator; - if (state.pipesCount === 0) return this; // just one destination. most common case. - if (state.pipesCount === 1) { - // passed in one, but it's not the right one. - if (dest && dest !== state.pipes) return this; - if (!dest) dest = state.pipes; // got a match. +/***/ }), - state.pipes = null; - state.pipesCount = 0; - state.flowing = false; - if (dest) dest.emit('unpipe', this, unpipeInfo); - return this; - } // slow case. multiple pipe destinations. +/***/ 53146: +/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { +var __webpack_unused_export__; +/* -*- Mode: js; js-indent-level: 2; -*- */ +/* + * Copyright 2011 Mozilla Foundation and contributors + * Licensed under the New BSD license. See LICENSE or: + * http://opensource.org/licenses/BSD-3-Clause + */ - if (!dest) { - // remove all. - var dests = state.pipes; - var len = state.pipesCount; - state.pipes = null; - state.pipesCount = 0; - state.flowing = false; +var SourceMapGenerator = (__nccwpck_require__(22370)/* .SourceMapGenerator */ .h); +var util = __nccwpck_require__(89479); - for (var i = 0; i < len; i++) { - dests[i].emit('unpipe', this, { - hasUnpiped: false - }); - } +// Matches a Windows-style `\r\n` newline or a `\n` newline used by all other +// operating systems these days (capturing the result). +var REGEX_NEWLINE = /(\r?\n)/; - return this; - } // try to find the right one. +// Newline character code for charCodeAt() comparisons +var NEWLINE_CODE = 10; +// Private symbol for identifying `SourceNode`s when multiple versions of +// the source-map library are loaded. This MUST NOT CHANGE across +// versions! +var isSourceNode = "$$$isSourceNode$$$"; - var index = indexOf(state.pipes, dest); - if (index === -1) return this; - state.pipes.splice(index, 1); - state.pipesCount -= 1; - if (state.pipesCount === 1) state.pipes = state.pipes[0]; - dest.emit('unpipe', this, unpipeInfo); - return this; -}; // set up data events if they are asked for -// Ensure readable listeners eventually get something +/** + * SourceNodes provide a way to abstract over interpolating/concatenating + * snippets of generated JavaScript source code while maintaining the line and + * column information associated with the original source code. + * + * @param aLine The original line number. + * @param aColumn The original column number. + * @param aSource The original source's filename. + * @param aChunks Optional. An array of strings which are snippets of + * generated JS, or other SourceNodes. + * @param aName The original identifier. + */ +function SourceNode(aLine, aColumn, aSource, aChunks, aName) { + this.children = []; + this.sourceContents = {}; + this.line = aLine == null ? null : aLine; + this.column = aColumn == null ? null : aColumn; + this.source = aSource == null ? null : aSource; + this.name = aName == null ? null : aName; + this[isSourceNode] = true; + if (aChunks != null) this.add(aChunks); +} +/** + * Creates a SourceNode from generated code and a SourceMapConsumer. + * + * @param aGeneratedCode The generated code + * @param aSourceMapConsumer The SourceMap for the generated code + * @param aRelativePath Optional. The path that relative sources in the + * SourceMapConsumer should be relative to. + */ +SourceNode.fromStringWithSourceMap = + function SourceNode_fromStringWithSourceMap(aGeneratedCode, aSourceMapConsumer, aRelativePath) { + // The SourceNode we want to fill with the generated code + // and the SourceMap + var node = new SourceNode(); -Readable.prototype.on = function (ev, fn) { - var res = Stream.prototype.on.call(this, ev, fn); - var state = this._readableState; + // All even indices of this array are one line of the generated code, + // while all odd indices are the newlines between two adjacent lines + // (since `REGEX_NEWLINE` captures its match). + // Processed fragments are accessed by calling `shiftNextLine`. + var remainingLines = aGeneratedCode.split(REGEX_NEWLINE); + var remainingLinesIndex = 0; + var shiftNextLine = function() { + var lineContents = getNextLine(); + // The last line of a file might not have a newline. + var newLine = getNextLine() || ""; + return lineContents + newLine; - if (ev === 'data') { - // update readableListening so that resume() may be a no-op - // a few lines down. This is needed to support once('readable'). - state.readableListening = this.listenerCount('readable') > 0; // Try start flowing on next tick if stream isn't explicitly paused + function getNextLine() { + return remainingLinesIndex < remainingLines.length ? + remainingLines[remainingLinesIndex++] : undefined; + } + }; - if (state.flowing !== false) this.resume(); - } else if (ev === 'readable') { - if (!state.endEmitted && !state.readableListening) { - state.readableListening = state.needReadable = true; - state.flowing = false; - state.emittedReadable = false; - debug('on readable', state.length, state.reading); + // We need to remember the position of "remainingLines" + var lastGeneratedLine = 1, lastGeneratedColumn = 0; - if (state.length) { - emitReadable(this); - } else if (!state.reading) { - process.nextTick(nReadingNextTick, this); + // The generate SourceNodes we need a code range. + // To extract it current and last mapping is used. + // Here we store the last mapping. + var lastMapping = null; + + aSourceMapConsumer.eachMapping(function (mapping) { + if (lastMapping !== null) { + // We add the code from "lastMapping" to "mapping": + // First check if there is a new line in between. + if (lastGeneratedLine < mapping.generatedLine) { + // Associate first line with "lastMapping" + addMappingWithCode(lastMapping, shiftNextLine()); + lastGeneratedLine++; + lastGeneratedColumn = 0; + // The remaining code is added without mapping + } else { + // There is no new line in between. + // Associate the code between "lastGeneratedColumn" and + // "mapping.generatedColumn" with "lastMapping" + var nextLine = remainingLines[remainingLinesIndex] || ''; + var code = nextLine.substr(0, mapping.generatedColumn - + lastGeneratedColumn); + remainingLines[remainingLinesIndex] = nextLine.substr(mapping.generatedColumn - + lastGeneratedColumn); + lastGeneratedColumn = mapping.generatedColumn; + addMappingWithCode(lastMapping, code); + // No more remaining code, continue + lastMapping = mapping; + return; + } } + // We add the generated code until the first mapping + // to the SourceNode without any mapping. + // Each line is added as separate string. + while (lastGeneratedLine < mapping.generatedLine) { + node.add(shiftNextLine()); + lastGeneratedLine++; + } + if (lastGeneratedColumn < mapping.generatedColumn) { + var nextLine = remainingLines[remainingLinesIndex] || ''; + node.add(nextLine.substr(0, mapping.generatedColumn)); + remainingLines[remainingLinesIndex] = nextLine.substr(mapping.generatedColumn); + lastGeneratedColumn = mapping.generatedColumn; + } + lastMapping = mapping; + }, this); + // We have processed all mappings. + if (remainingLinesIndex < remainingLines.length) { + if (lastMapping) { + // Associate the remaining code in the current line with "lastMapping" + addMappingWithCode(lastMapping, shiftNextLine()); + } + // and add the remaining lines without any mapping + node.add(remainingLines.splice(remainingLinesIndex).join("")); } - } - return res; -}; + // Copy sourcesContent into SourceNode + aSourceMapConsumer.sources.forEach(function (sourceFile) { + var content = aSourceMapConsumer.sourceContentFor(sourceFile); + if (content != null) { + if (aRelativePath != null) { + sourceFile = util.join(aRelativePath, sourceFile); + } + node.setSourceContent(sourceFile, content); + } + }); -Readable.prototype.addListener = Readable.prototype.on; + return node; -Readable.prototype.removeListener = function (ev, fn) { - var res = Stream.prototype.removeListener.call(this, ev, fn); + function addMappingWithCode(mapping, code) { + if (mapping === null || mapping.source === undefined) { + node.add(code); + } else { + var source = aRelativePath + ? util.join(aRelativePath, mapping.source) + : mapping.source; + node.add(new SourceNode(mapping.originalLine, + mapping.originalColumn, + source, + code, + mapping.name)); + } + } + }; - if (ev === 'readable') { - // We need to check if there is someone still listening to - // readable and reset the state. However this needs to happen - // after readable has been emitted but before I/O (nextTick) to - // support once('readable', fn) cycles. This means that calling - // resume within the same tick will have no - // effect. - process.nextTick(updateReadableListening, this); +/** + * Add a chunk of generated JS to this source node. + * + * @param aChunk A string snippet of generated JS code, another instance of + * SourceNode, or an array where each member is one of those things. + */ +SourceNode.prototype.add = function SourceNode_add(aChunk) { + if (Array.isArray(aChunk)) { + aChunk.forEach(function (chunk) { + this.add(chunk); + }, this); } - - return res; + else if (aChunk[isSourceNode] || typeof aChunk === "string") { + if (aChunk) { + this.children.push(aChunk); + } + } + else { + throw new TypeError( + "Expected a SourceNode, string, or an array of SourceNodes and strings. Got " + aChunk + ); + } + return this; }; -Readable.prototype.removeAllListeners = function (ev) { - var res = Stream.prototype.removeAllListeners.apply(this, arguments); - - if (ev === 'readable' || ev === undefined) { - // We need to check if there is someone still listening to - // readable and reset the state. However this needs to happen - // after readable has been emitted but before I/O (nextTick) to - // support once('readable', fn) cycles. This means that calling - // resume within the same tick will have no - // effect. - process.nextTick(updateReadableListening, this); +/** + * Add a chunk of generated JS to the beginning of this source node. + * + * @param aChunk A string snippet of generated JS code, another instance of + * SourceNode, or an array where each member is one of those things. + */ +SourceNode.prototype.prepend = function SourceNode_prepend(aChunk) { + if (Array.isArray(aChunk)) { + for (var i = aChunk.length-1; i >= 0; i--) { + this.prepend(aChunk[i]); + } } - - return res; + else if (aChunk[isSourceNode] || typeof aChunk === "string") { + this.children.unshift(aChunk); + } + else { + throw new TypeError( + "Expected a SourceNode, string, or an array of SourceNodes and strings. Got " + aChunk + ); + } + return this; }; -function updateReadableListening(self) { - var state = self._readableState; - state.readableListening = self.listenerCount('readable') > 0; - - if (state.resumeScheduled && !state.paused) { - // flowing needs to be set to true now, otherwise - // the upcoming resume will not flow. - state.flowing = true; // crude way to check if we should resume - } else if (self.listenerCount('data') > 0) { - self.resume(); +/** + * Walk over the tree of JS snippets in this node and its children. The + * walking function is called once for each snippet of JS and is passed that + * snippet and the its original associated source's line/column location. + * + * @param aFn The traversal function. + */ +SourceNode.prototype.walk = function SourceNode_walk(aFn) { + var chunk; + for (var i = 0, len = this.children.length; i < len; i++) { + chunk = this.children[i]; + if (chunk[isSourceNode]) { + chunk.walk(aFn); + } + else { + if (chunk !== '') { + aFn(chunk, { source: this.source, + line: this.line, + column: this.column, + name: this.name }); + } + } } -} - -function nReadingNextTick(self) { - debug('readable nexttick read 0'); - self.read(0); -} // pause() and resume() are remnants of the legacy readable stream API -// If the user uses them, then switch into old mode. - - -Readable.prototype.resume = function () { - var state = this._readableState; - - if (!state.flowing) { - debug('resume'); // we flow only if there is no one listening - // for readable, but we still have to call - // resume() +}; - state.flowing = !state.readableListening; - resume(this, state); +/** + * Like `String.prototype.join` except for SourceNodes. Inserts `aStr` between + * each of `this.children`. + * + * @param aSep The separator. + */ +SourceNode.prototype.join = function SourceNode_join(aSep) { + var newChildren; + var i; + var len = this.children.length; + if (len > 0) { + newChildren = []; + for (i = 0; i < len-1; i++) { + newChildren.push(this.children[i]); + newChildren.push(aSep); + } + newChildren.push(this.children[i]); + this.children = newChildren; } - - state.paused = false; return this; }; -function resume(stream, state) { - if (!state.resumeScheduled) { - state.resumeScheduled = true; - process.nextTick(resume_, stream, state); +/** + * Call String.prototype.replace on the very right-most source snippet. Useful + * for trimming whitespace from the end of a source node, etc. + * + * @param aPattern The pattern to replace. + * @param aReplacement The thing to replace the pattern with. + */ +SourceNode.prototype.replaceRight = function SourceNode_replaceRight(aPattern, aReplacement) { + var lastChild = this.children[this.children.length - 1]; + if (lastChild[isSourceNode]) { + lastChild.replaceRight(aPattern, aReplacement); } -} - -function resume_(stream, state) { - debug('resume', state.reading); - - if (!state.reading) { - stream.read(0); + else if (typeof lastChild === 'string') { + this.children[this.children.length - 1] = lastChild.replace(aPattern, aReplacement); } - - state.resumeScheduled = false; - stream.emit('resume'); - flow(stream); - if (state.flowing && !state.reading) stream.read(0); -} - -Readable.prototype.pause = function () { - debug('call pause flowing=%j', this._readableState.flowing); - - if (this._readableState.flowing !== false) { - debug('pause'); - this._readableState.flowing = false; - this.emit('pause'); + else { + this.children.push(''.replace(aPattern, aReplacement)); } - - this._readableState.paused = true; return this; }; -function flow(stream) { - var state = stream._readableState; - debug('flow', state.flowing); - - while (state.flowing && stream.read() !== null) { - ; - } -} // wrap an old-style stream as the async data source. -// This is *not* part of the readable stream interface. -// It is an ugly unfortunate mess of history. +/** + * Set the source content for a source file. This will be added to the SourceMapGenerator + * in the sourcesContent field. + * + * @param aSourceFile The filename of the source file + * @param aSourceContent The content of the source file + */ +SourceNode.prototype.setSourceContent = + function SourceNode_setSourceContent(aSourceFile, aSourceContent) { + this.sourceContents[util.toSetString(aSourceFile)] = aSourceContent; + }; +/** + * Walk over the tree of SourceNodes. The walking function is called for each + * source file content and is passed the filename and source content. + * + * @param aFn The traversal function. + */ +SourceNode.prototype.walkSourceContents = + function SourceNode_walkSourceContents(aFn) { + for (var i = 0, len = this.children.length; i < len; i++) { + if (this.children[i][isSourceNode]) { + this.children[i].walkSourceContents(aFn); + } + } -Readable.prototype.wrap = function (stream) { - var _this = this; + var sources = Object.keys(this.sourceContents); + for (var i = 0, len = sources.length; i < len; i++) { + aFn(util.fromSetString(sources[i]), this.sourceContents[sources[i]]); + } + }; - var state = this._readableState; - var paused = false; - stream.on('end', function () { - debug('wrapped end'); +/** + * Return the string representation of this source node. Walks over the tree + * and concatenates all the various snippets together to one string. + */ +SourceNode.prototype.toString = function SourceNode_toString() { + var str = ""; + this.walk(function (chunk) { + str += chunk; + }); + return str; +}; - if (state.decoder && !state.ended) { - var chunk = state.decoder.end(); - if (chunk && chunk.length) _this.push(chunk); +/** + * Returns the string representation of this source node along with a source + * map. + */ +SourceNode.prototype.toStringWithSourceMap = function SourceNode_toStringWithSourceMap(aArgs) { + var generated = { + code: "", + line: 1, + column: 0 + }; + var map = new SourceMapGenerator(aArgs); + var sourceMappingActive = false; + var lastOriginalSource = null; + var lastOriginalLine = null; + var lastOriginalColumn = null; + var lastOriginalName = null; + this.walk(function (chunk, original) { + generated.code += chunk; + if (original.source !== null + && original.line !== null + && original.column !== null) { + if(lastOriginalSource !== original.source + || lastOriginalLine !== original.line + || lastOriginalColumn !== original.column + || lastOriginalName !== original.name) { + map.addMapping({ + source: original.source, + original: { + line: original.line, + column: original.column + }, + generated: { + line: generated.line, + column: generated.column + }, + name: original.name + }); + } + lastOriginalSource = original.source; + lastOriginalLine = original.line; + lastOriginalColumn = original.column; + lastOriginalName = original.name; + sourceMappingActive = true; + } else if (sourceMappingActive) { + map.addMapping({ + generated: { + line: generated.line, + column: generated.column + } + }); + lastOriginalSource = null; + sourceMappingActive = false; + } + for (var idx = 0, length = chunk.length; idx < length; idx++) { + if (chunk.charCodeAt(idx) === NEWLINE_CODE) { + generated.line++; + generated.column = 0; + // Mappings end at eol + if (idx + 1 === length) { + lastOriginalSource = null; + sourceMappingActive = false; + } else if (sourceMappingActive) { + map.addMapping({ + source: original.source, + original: { + line: original.line, + column: original.column + }, + generated: { + line: generated.line, + column: generated.column + }, + name: original.name + }); + } + } else { + generated.column++; + } } - - _this.push(null); }); - stream.on('data', function (chunk) { - debug('wrapped data'); - if (state.decoder) chunk = state.decoder.write(chunk); // don't skip over falsy values in objectMode + this.walkSourceContents(function (sourceFile, sourceContent) { + map.setSourceContent(sourceFile, sourceContent); + }); - if (state.objectMode && (chunk === null || chunk === undefined)) return;else if (!state.objectMode && (!chunk || !chunk.length)) return; + return { code: generated.code, map: map }; +}; - var ret = _this.push(chunk); +__webpack_unused_export__ = SourceNode; - if (!ret) { - paused = true; - stream.pause(); - } - }); // proxy all the other methods. - // important when wrapping filters and duplexes. - for (var i in stream) { - if (this[i] === undefined && typeof stream[i] === 'function') { - this[i] = function methodWrap(method) { - return function methodWrapReturnFunction() { - return stream[method].apply(stream, arguments); - }; - }(i); - } - } // proxy certain important events. +/***/ }), +/***/ 89479: +/***/ ((__unused_webpack_module, exports) => { - for (var n = 0; n < kProxyEvents.length; n++) { - stream.on(kProxyEvents[n], this.emit.bind(this, kProxyEvents[n])); - } // when we try to consume some more bytes, simply unpause the - // underlying stream. +/* -*- Mode: js; js-indent-level: 2; -*- */ +/* + * Copyright 2011 Mozilla Foundation and contributors + * Licensed under the New BSD license. See LICENSE or: + * http://opensource.org/licenses/BSD-3-Clause + */ +/** + * This is a helper function for getting values from parameter/options + * objects. + * + * @param args The object we are extracting values from + * @param name The name of the property we are getting. + * @param defaultValue An optional value to return if the property is missing + * from the object. If this is not specified and the property is missing, an + * error will be thrown. + */ +function getArg(aArgs, aName, aDefaultValue) { + if (aName in aArgs) { + return aArgs[aName]; + } else if (arguments.length === 3) { + return aDefaultValue; + } else { + throw new Error('"' + aName + '" is a required argument.'); + } +} +exports.getArg = getArg; - this._read = function (n) { - debug('wrapped _read', n); +var urlRegexp = /^(?:([\w+\-.]+):)?\/\/(?:(\w+:\w+)@)?([\w.-]*)(?::(\d+))?(.*)$/; +var dataUrlRegexp = /^data:.+\,.+$/; - if (paused) { - paused = false; - stream.resume(); - } +function urlParse(aUrl) { + var match = aUrl.match(urlRegexp); + if (!match) { + return null; + } + return { + scheme: match[1], + auth: match[2], + host: match[3], + port: match[4], + path: match[5] }; +} +exports.urlParse = urlParse; - return this; -}; +function urlGenerate(aParsedUrl) { + var url = ''; + if (aParsedUrl.scheme) { + url += aParsedUrl.scheme + ':'; + } + url += '//'; + if (aParsedUrl.auth) { + url += aParsedUrl.auth + '@'; + } + if (aParsedUrl.host) { + url += aParsedUrl.host; + } + if (aParsedUrl.port) { + url += ":" + aParsedUrl.port + } + if (aParsedUrl.path) { + url += aParsedUrl.path; + } + return url; +} +exports.urlGenerate = urlGenerate; -if (typeof Symbol === 'function') { - Readable.prototype[Symbol.asyncIterator] = function () { - if (createReadableStreamAsyncIterator === undefined) { - createReadableStreamAsyncIterator = __nccwpck_require__(29634); +/** + * Normalizes a path, or the path portion of a URL: + * + * - Replaces consecutive slashes with one slash. + * - Removes unnecessary '.' parts. + * - Removes unnecessary '/..' parts. + * + * Based on code in the Node.js 'path' core module. + * + * @param aPath The path or url to normalize. + */ +function normalize(aPath) { + var path = aPath; + var url = urlParse(aPath); + if (url) { + if (!url.path) { + return aPath; } + path = url.path; + } + var isAbsolute = exports.isAbsolute(path); - return createReadableStreamAsyncIterator(this); - }; + var parts = path.split(/\/+/); + for (var part, up = 0, i = parts.length - 1; i >= 0; i--) { + part = parts[i]; + if (part === '.') { + parts.splice(i, 1); + } else if (part === '..') { + up++; + } else if (up > 0) { + if (part === '') { + // The first part is blank if the path is absolute. Trying to go + // above the root is a no-op. Therefore we can remove all '..' parts + // directly after the root. + parts.splice(i + 1, up); + up = 0; + } else { + parts.splice(i, 2); + up--; + } + } + } + path = parts.join('/'); + + if (path === '') { + path = isAbsolute ? '/' : '.'; + } + + if (url) { + url.path = path; + return urlGenerate(url); + } + return path; } +exports.normalize = normalize; -Object.defineProperty(Readable.prototype, 'readableHighWaterMark', { - // making it explicit this property is not enumerable - // because otherwise some prototype manipulation in - // userland will fail - enumerable: false, - get: function get() { - return this._readableState.highWaterMark; +/** + * Joins two paths/URLs. + * + * @param aRoot The root path or URL. + * @param aPath The path or URL to be joined with the root. + * + * - If aPath is a URL or a data URI, aPath is returned, unless aPath is a + * scheme-relative URL: Then the scheme of aRoot, if any, is prepended + * first. + * - Otherwise aPath is a path. If aRoot is a URL, then its path portion + * is updated with the result and aRoot is returned. Otherwise the result + * is returned. + * - If aPath is absolute, the result is aPath. + * - Otherwise the two paths are joined with a slash. + * - Joining for example 'http://' and 'www.example.com' is also supported. + */ +function join(aRoot, aPath) { + if (aRoot === "") { + aRoot = "."; } -}); -Object.defineProperty(Readable.prototype, 'readableBuffer', { - // making it explicit this property is not enumerable - // because otherwise some prototype manipulation in - // userland will fail - enumerable: false, - get: function get() { - return this._readableState && this._readableState.buffer; + if (aPath === "") { + aPath = "."; } -}); -Object.defineProperty(Readable.prototype, 'readableFlowing', { - // making it explicit this property is not enumerable - // because otherwise some prototype manipulation in - // userland will fail - enumerable: false, - get: function get() { - return this._readableState.flowing; - }, - set: function set(state) { - if (this._readableState) { - this._readableState.flowing = state; + var aPathUrl = urlParse(aPath); + var aRootUrl = urlParse(aRoot); + if (aRootUrl) { + aRoot = aRootUrl.path || '/'; + } + + // `join(foo, '//www.example.org')` + if (aPathUrl && !aPathUrl.scheme) { + if (aRootUrl) { + aPathUrl.scheme = aRootUrl.scheme; } + return urlGenerate(aPathUrl); } -}); // exposed for testing purposes only. -Readable._fromList = fromList; -Object.defineProperty(Readable.prototype, 'readableLength', { - // making it explicit this property is not enumerable - // because otherwise some prototype manipulation in - // userland will fail - enumerable: false, - get: function get() { - return this._readableState.length; + if (aPathUrl || aPath.match(dataUrlRegexp)) { + return aPath; } -}); // Pluck off n bytes from an array of buffers. -// Length is the combined lengths of all the buffers in the list. -// This function is designed to be inlinable, so please take care when making -// changes to the function body. -function fromList(n, state) { - // nothing buffered - if (state.length === 0) return null; - var ret; - if (state.objectMode) ret = state.buffer.shift();else if (!n || n >= state.length) { - // read it all, truncate the list - if (state.decoder) ret = state.buffer.join('');else if (state.buffer.length === 1) ret = state.buffer.first();else ret = state.buffer.concat(state.length); - state.buffer.clear(); - } else { - // read part of list - ret = state.buffer.consume(n, state.decoder); + // `join('http://', 'www.example.com')` + if (aRootUrl && !aRootUrl.host && !aRootUrl.path) { + aRootUrl.host = aPath; + return urlGenerate(aRootUrl); } - return ret; -} -function endReadable(stream) { - var state = stream._readableState; - debug('endReadable', state.endEmitted); + var joined = aPath.charAt(0) === '/' + ? aPath + : normalize(aRoot.replace(/\/+$/, '') + '/' + aPath); - if (!state.endEmitted) { - state.ended = true; - process.nextTick(endReadableNT, state, stream); + if (aRootUrl) { + aRootUrl.path = joined; + return urlGenerate(aRootUrl); } + return joined; } +exports.join = join; -function endReadableNT(state, stream) { - debug('endReadableNT', state.endEmitted, state.length); // Check that we didn't get one last unshift. +exports.isAbsolute = function (aPath) { + return aPath.charAt(0) === '/' || urlRegexp.test(aPath); +}; - if (!state.endEmitted && state.length === 0) { - state.endEmitted = true; - stream.readable = false; - stream.emit('end'); +/** + * Make a path relative to a URL or another path. + * + * @param aRoot The root path or URL. + * @param aPath The path or URL to be made relative to aRoot. + */ +function relative(aRoot, aPath) { + if (aRoot === "") { + aRoot = "."; + } - if (state.autoDestroy) { - // In case of duplex streams we need a way to detect - // if the writable side is ready for autoDestroy as well - var wState = stream._writableState; + aRoot = aRoot.replace(/\/$/, ''); - if (!wState || wState.autoDestroy && wState.finished) { - stream.destroy(); - } + // It is possible for the path to be above the root. In this case, simply + // checking whether the root is a prefix of the path won't work. Instead, we + // need to remove components from the root one by one, until either we find + // a prefix that fits, or we run out of components to remove. + var level = 0; + while (aPath.indexOf(aRoot + '/') !== 0) { + var index = aRoot.lastIndexOf("/"); + if (index < 0) { + return aPath; } - } -} -if (typeof Symbol === 'function') { - Readable.from = function (iterable, opts) { - if (from === undefined) { - from = __nccwpck_require__(23919); + // If the only part of the root that is left is the scheme (i.e. http://, + // file:///, etc.), one or more slashes (/), or simply nothing at all, we + // have exhausted all components, so the path is not relative to the root. + aRoot = aRoot.slice(0, index); + if (aRoot.match(/^([^\/]+:\/)?\/*$/)) { + return aPath; } - return from(Readable, iterable, opts); - }; -} - -function indexOf(xs, x) { - for (var i = 0, l = xs.length; i < l; i++) { - if (xs[i] === x) return i; + ++level; } - return -1; + // Make sure we add a "../" for each component we removed from the root. + return Array(level + 1).join("../") + aPath.substr(aRoot.length + 1); } +exports.relative = relative; -/***/ }), - -/***/ 660: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { +var supportsNullProto = (function () { + var obj = Object.create(null); + return !('__proto__' in obj); +}()); -"use strict"; -// Copyright Joyent, Inc. and other Node contributors. -// -// 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. -// a transform stream is a readable/writable stream where you do -// something with the data. Sometimes it's called a "filter", -// but that's not a great name for it, since that implies a thing where -// some bits pass through, and others are simply ignored. (That would -// be a valid example of a transform, of course.) -// -// While the output is causally related to the input, it's not a -// necessarily symmetric or synchronous transformation. For example, -// a zlib stream might take multiple plain-text writes(), and then -// emit a single compressed chunk some time in the future. -// -// Here's how this works: -// -// The Transform stream has all the aspects of the readable and writable -// stream classes. When you write(chunk), that calls _write(chunk,cb) -// internally, and returns false if there's a lot of pending writes -// buffered up. When you call read(), that calls _read(n) until -// there's enough pending readable data buffered up. -// -// In a transform stream, the written data is placed in a buffer. When -// _read(n) is called, it transforms the queued up data, calling the -// buffered _write cb's as it consumes chunks. If consuming a single -// written chunk would result in multiple output chunks, then the first -// outputted bit calls the readcb, and subsequent chunks just go into -// the read buffer, and will cause it to emit 'readable' if necessary. -// -// This way, back-pressure is actually determined by the reading side, -// since _read has to be called to start processing a new chunk. However, -// a pathological inflate type of transform can cause excessive buffering -// here. For example, imagine a stream where every byte of input is -// interpreted as an integer from 0-255, and then results in that many -// bytes of output. Writing the 4 bytes {ff,ff,ff,ff} would result in -// 1kb of data being output. In this case, you could write a very small -// amount of input, and end up with a very large amount of output. In -// such a pathological inflating mechanism, there'd be no way to tell -// the system to stop doing the transform. A single 4MB write could -// cause the system to run out of memory. -// -// However, even in such a pathological case, only a single written chunk -// would be consumed, and then the rest would wait (un-transformed) until -// the results of the previous transformed chunk were consumed. +function identity (s) { + return s; +} +/** + * Because behavior goes wacky when you set `__proto__` on objects, we + * have to prefix all the strings in our set with an arbitrary character. + * + * See https://github.com/mozilla/source-map/pull/31 and + * https://github.com/mozilla/source-map/issues/30 + * + * @param String aStr + */ +function toSetString(aStr) { + if (isProtoString(aStr)) { + return '$' + aStr; + } -module.exports = Transform; + return aStr; +} +exports.toSetString = supportsNullProto ? identity : toSetString; -var _require$codes = (__nccwpck_require__(91042)/* .codes */ .q), - ERR_METHOD_NOT_IMPLEMENTED = _require$codes.ERR_METHOD_NOT_IMPLEMENTED, - ERR_MULTIPLE_CALLBACK = _require$codes.ERR_MULTIPLE_CALLBACK, - ERR_TRANSFORM_ALREADY_TRANSFORMING = _require$codes.ERR_TRANSFORM_ALREADY_TRANSFORMING, - ERR_TRANSFORM_WITH_LENGTH_0 = _require$codes.ERR_TRANSFORM_WITH_LENGTH_0; +function fromSetString(aStr) { + if (isProtoString(aStr)) { + return aStr.slice(1); + } -var Duplex = __nccwpck_require__(25408); + return aStr; +} +exports.fromSetString = supportsNullProto ? identity : fromSetString; -__nccwpck_require__(2868)(Transform, Duplex); +function isProtoString(s) { + if (!s) { + return false; + } -function afterTransform(er, data) { - var ts = this._transformState; - ts.transforming = false; - var cb = ts.writecb; + var length = s.length; - if (cb === null) { - return this.emit('error', new ERR_MULTIPLE_CALLBACK()); + if (length < 9 /* "__proto__".length */) { + return false; } - ts.writechunk = null; - ts.writecb = null; - if (data != null) // single equals check for both `null` and `undefined` - this.push(data); - cb(er); - var rs = this._readableState; - rs.reading = false; + if (s.charCodeAt(length - 1) !== 95 /* '_' */ || + s.charCodeAt(length - 2) !== 95 /* '_' */ || + s.charCodeAt(length - 3) !== 111 /* 'o' */ || + s.charCodeAt(length - 4) !== 116 /* 't' */ || + s.charCodeAt(length - 5) !== 111 /* 'o' */ || + s.charCodeAt(length - 6) !== 114 /* 'r' */ || + s.charCodeAt(length - 7) !== 112 /* 'p' */ || + s.charCodeAt(length - 8) !== 95 /* '_' */ || + s.charCodeAt(length - 9) !== 95 /* '_' */) { + return false; + } - if (rs.needReadable || rs.length < rs.highWaterMark) { - this._read(rs.highWaterMark); + for (var i = length - 10; i >= 0; i--) { + if (s.charCodeAt(i) !== 36 /* '$' */) { + return false; + } } + + return true; } -function Transform(options) { - if (!(this instanceof Transform)) return new Transform(options); - Duplex.call(this, options); - this._transformState = { - afterTransform: afterTransform.bind(this), - needTransform: false, - transforming: false, - writecb: null, - writechunk: null, - writeencoding: null - }; // start out asking for a readable event once data is transformed. +/** + * Comparator between two mappings where the original positions are compared. + * + * Optionally pass in `true` as `onlyCompareGenerated` to consider two + * mappings with the same original source/line/column, but different generated + * line and column the same. Useful when searching for a mapping with a + * stubbed out mapping. + */ +function compareByOriginalPositions(mappingA, mappingB, onlyCompareOriginal) { + var cmp = strcmp(mappingA.source, mappingB.source); + if (cmp !== 0) { + return cmp; + } - this._readableState.needReadable = true; // we have implemented the _read method, and done the other things - // that Readable wants before the first _read call, so unset the - // sync guard flag. + cmp = mappingA.originalLine - mappingB.originalLine; + if (cmp !== 0) { + return cmp; + } - this._readableState.sync = false; + cmp = mappingA.originalColumn - mappingB.originalColumn; + if (cmp !== 0 || onlyCompareOriginal) { + return cmp; + } - if (options) { - if (typeof options.transform === 'function') this._transform = options.transform; - if (typeof options.flush === 'function') this._flush = options.flush; - } // When the writable side finishes, then flush out anything remaining. + cmp = mappingA.generatedColumn - mappingB.generatedColumn; + if (cmp !== 0) { + return cmp; + } + cmp = mappingA.generatedLine - mappingB.generatedLine; + if (cmp !== 0) { + return cmp; + } - this.on('prefinish', prefinish); + return strcmp(mappingA.name, mappingB.name); } +exports.compareByOriginalPositions = compareByOriginalPositions; -function prefinish() { - var _this = this; - - if (typeof this._flush === 'function' && !this._readableState.destroyed) { - this._flush(function (er, data) { - done(_this, er, data); - }); - } else { - done(this, null, null); - } +/** + * Comparator between two mappings with deflated source and name indices where + * the generated positions are compared. + * + * Optionally pass in `true` as `onlyCompareGenerated` to consider two + * mappings with the same generated line and column, but different + * source/name/original line and column the same. Useful when searching for a + * mapping with a stubbed out mapping. + */ +function compareByGeneratedPositionsDeflated(mappingA, mappingB, onlyCompareGenerated) { + var cmp = mappingA.generatedLine - mappingB.generatedLine; + if (cmp !== 0) { + return cmp; + } + + cmp = mappingA.generatedColumn - mappingB.generatedColumn; + if (cmp !== 0 || onlyCompareGenerated) { + return cmp; + } + + cmp = strcmp(mappingA.source, mappingB.source); + if (cmp !== 0) { + return cmp; + } + + cmp = mappingA.originalLine - mappingB.originalLine; + if (cmp !== 0) { + return cmp; + } + + cmp = mappingA.originalColumn - mappingB.originalColumn; + if (cmp !== 0) { + return cmp; + } + + return strcmp(mappingA.name, mappingB.name); } +exports.compareByGeneratedPositionsDeflated = compareByGeneratedPositionsDeflated; -Transform.prototype.push = function (chunk, encoding) { - this._transformState.needTransform = false; - return Duplex.prototype.push.call(this, chunk, encoding); -}; // This is the part where you do stuff! -// override this function in implementation classes. -// 'chunk' is an input chunk. -// -// Call `push(newChunk)` to pass along transformed output -// to the readable side. You may call 'push' zero or more times. -// -// Call `cb(err)` when you are done with this chunk. If you pass -// an error, then that'll put the hurt on the whole operation. If you -// never call cb(), then you'll never get another chunk. +function strcmp(aStr1, aStr2) { + if (aStr1 === aStr2) { + return 0; + } + if (aStr1 === null) { + return 1; // aStr2 !== null + } -Transform.prototype._transform = function (chunk, encoding, cb) { - cb(new ERR_METHOD_NOT_IMPLEMENTED('_transform()')); -}; + if (aStr2 === null) { + return -1; // aStr1 !== null + } -Transform.prototype._write = function (chunk, encoding, cb) { - var ts = this._transformState; - ts.writecb = cb; - ts.writechunk = chunk; - ts.writeencoding = encoding; + if (aStr1 > aStr2) { + return 1; + } - if (!ts.transforming) { - var rs = this._readableState; - if (ts.needTransform || rs.needReadable || rs.length < rs.highWaterMark) this._read(rs.highWaterMark); + return -1; +} + +/** + * Comparator between two mappings with inflated source and name strings where + * the generated positions are compared. + */ +function compareByGeneratedPositionsInflated(mappingA, mappingB) { + var cmp = mappingA.generatedLine - mappingB.generatedLine; + if (cmp !== 0) { + return cmp; } -}; // Doesn't matter what the args are here. -// _transform does all the work. -// That we got here means that the readable side wants more data. + cmp = mappingA.generatedColumn - mappingB.generatedColumn; + if (cmp !== 0) { + return cmp; + } -Transform.prototype._read = function (n) { - var ts = this._transformState; + cmp = strcmp(mappingA.source, mappingB.source); + if (cmp !== 0) { + return cmp; + } - if (ts.writechunk !== null && !ts.transforming) { - ts.transforming = true; + cmp = mappingA.originalLine - mappingB.originalLine; + if (cmp !== 0) { + return cmp; + } - this._transform(ts.writechunk, ts.writeencoding, ts.afterTransform); - } else { - // mark that we need a transform, so that any data that comes in - // will get processed, now that we've asked for it. - ts.needTransform = true; + cmp = mappingA.originalColumn - mappingB.originalColumn; + if (cmp !== 0) { + return cmp; } -}; -Transform.prototype._destroy = function (err, cb) { - Duplex.prototype._destroy.call(this, err, function (err2) { - cb(err2); - }); -}; + return strcmp(mappingA.name, mappingB.name); +} +exports.compareByGeneratedPositionsInflated = compareByGeneratedPositionsInflated; -function done(stream, er, data) { - if (er) return stream.emit('error', er); - if (data != null) // single equals check for both `null` and `undefined` - stream.push(data); // TODO(BridgeAR): Write a test for these two error cases - // if there's nothing in the write buffer, then that means - // that nothing more will ever be provided +/** + * Strip any JSON XSSI avoidance prefix from the string (as documented + * in the source maps specification), and then parse the string as + * JSON. + */ +function parseSourceMapInput(str) { + return JSON.parse(str.replace(/^\)]}'[^\n]*\n/, '')); +} +exports.parseSourceMapInput = parseSourceMapInput; - if (stream._writableState.length) throw new ERR_TRANSFORM_WITH_LENGTH_0(); - if (stream._transformState.transforming) throw new ERR_TRANSFORM_ALREADY_TRANSFORMING(); - return stream.push(null); +/** + * Compute the URL of a source given the the source root, the source's + * URL, and the source map's URL. + */ +function computeSourceURL(sourceRoot, sourceURL, sourceMapURL) { + sourceURL = sourceURL || ''; + + if (sourceRoot) { + // This follows what Chrome does. + if (sourceRoot[sourceRoot.length - 1] !== '/' && sourceURL[0] !== '/') { + sourceRoot += '/'; + } + // The spec says: + // Line 4: An optional source root, useful for relocating source + // files on a server or removing repeated values in the + // “sources” entry. This value is prepended to the individual + // entries in the “source” field. + sourceURL = sourceRoot + sourceURL; + } + + // Historically, SourceMapConsumer did not take the sourceMapURL as + // a parameter. This mode is still somewhat supported, which is why + // this code block is conditional. However, it's preferable to pass + // the source map URL to SourceMapConsumer, so that this function + // can implement the source URL resolution algorithm as outlined in + // the spec. This block is basically the equivalent of: + // new URL(sourceURL, sourceMapURL).toString() + // ... except it avoids using URL, which wasn't available in the + // older releases of node still supported by this library. + // + // The spec says: + // If the sources are not absolute URLs after prepending of the + // “sourceRoot”, the sources are resolved relative to the + // SourceMap (like resolving script src in a html document). + if (sourceMapURL) { + var parsed = urlParse(sourceMapURL); + if (!parsed) { + throw new Error("sourceMapURL could not be parsed"); + } + if (parsed.path) { + // Strip the last path component, but keep the "/". + var index = parsed.path.lastIndexOf('/'); + if (index >= 0) { + parsed.path = parsed.path.substring(0, index + 1); + } + } + sourceURL = join(urlGenerate(parsed), sourceURL); + } + + return normalize(sourceURL); } +exports.computeSourceURL = computeSourceURL; + /***/ }), -/***/ 51898: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { +/***/ 53439: +/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { + +/* + * Copyright 2009-2011 Mozilla Foundation and contributors + * Licensed under the New BSD license. See LICENSE.txt or: + * http://opensource.org/licenses/BSD-3-Clause + */ +/* unused reexport */ __nccwpck_require__(22370)/* .SourceMapGenerator */ .h; +exports.SourceMapConsumer = __nccwpck_require__(89457).SourceMapConsumer; +/* unused reexport */ __nccwpck_require__(53146); + + +/***/ }), + +/***/ 59868: +/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { "use strict"; // Copyright Joyent, Inc. and other Node contributors. @@ -79802,22782 +72489,12689 @@ function done(stream, er, data) { // 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. -// A bit simpler than readable streams. -// Implement an async ._write(chunk, encoding, cb), and it'll handle all -// the drain event emission and buffering. -module.exports = Writable; -/* */ -function WriteReq(chunk, encoding, cb) { - this.chunk = chunk; - this.encoding = encoding; - this.callback = cb; - this.next = null; -} // It seems a linked list but it is not -// there will be only 2 of these for each stream +/**/ +var Buffer = (__nccwpck_require__(54184).Buffer); +/**/ -function CorkedRequest(state) { - var _this = this; +var isEncoding = Buffer.isEncoding || function (encoding) { + encoding = '' + encoding; + switch (encoding && encoding.toLowerCase()) { + case 'hex':case 'utf8':case 'utf-8':case 'ascii':case 'binary':case 'base64':case 'ucs2':case 'ucs-2':case 'utf16le':case 'utf-16le':case 'raw': + return true; + default: + return false; + } +}; - this.next = null; - this.entry = null; +function _normalizeEncoding(enc) { + if (!enc) return 'utf8'; + var retried; + while (true) { + switch (enc) { + case 'utf8': + case 'utf-8': + return 'utf8'; + case 'ucs2': + case 'ucs-2': + case 'utf16le': + case 'utf-16le': + return 'utf16le'; + case 'latin1': + case 'binary': + return 'latin1'; + case 'base64': + case 'ascii': + case 'hex': + return enc; + default: + if (retried) return; // undefined + enc = ('' + enc).toLowerCase(); + retried = true; + } + } +}; - this.finish = function () { - onCorkedFinish(_this, state); - }; +// Do not cache `Buffer.isEncoding` when checking encoding names as some +// modules monkey-patch it to support additional encodings +function normalizeEncoding(enc) { + var nenc = _normalizeEncoding(enc); + if (typeof nenc !== 'string' && (Buffer.isEncoding === isEncoding || !isEncoding(enc))) throw new Error('Unknown encoding: ' + enc); + return nenc || enc; } -/* */ - -/**/ - - -var Duplex; -/**/ -Writable.WritableState = WritableState; -/**/ +// StringDecoder provides an interface for efficiently splitting a series of +// buffers into a series of JS strings without breaking apart multi-byte +// characters. +exports.s = StringDecoder; +function StringDecoder(encoding) { + this.encoding = normalizeEncoding(encoding); + var nb; + switch (this.encoding) { + case 'utf16le': + this.text = utf16Text; + this.end = utf16End; + nb = 4; + break; + case 'utf8': + this.fillLast = utf8FillLast; + nb = 4; + break; + case 'base64': + this.text = base64Text; + this.end = base64End; + nb = 3; + break; + default: + this.write = simpleWrite; + this.end = simpleEnd; + return; + } + this.lastNeed = 0; + this.lastTotal = 0; + this.lastChar = Buffer.allocUnsafe(nb); +} -var internalUtil = { - deprecate: __nccwpck_require__(40538) +StringDecoder.prototype.write = function (buf) { + if (buf.length === 0) return ''; + var r; + var i; + if (this.lastNeed) { + r = this.fillLast(buf); + if (r === undefined) return ''; + i = this.lastNeed; + this.lastNeed = 0; + } else { + i = 0; + } + if (i < buf.length) return r ? r + this.text(buf, i) : this.text(buf, i); + return r || ''; }; -/**/ -/**/ +StringDecoder.prototype.end = utf8End; -var Stream = __nccwpck_require__(4297); -/**/ +// Returns only complete characters in a Buffer +StringDecoder.prototype.text = utf8Text; +// Attempts to complete a partial non-UTF-8 character using bytes from a Buffer +StringDecoder.prototype.fillLast = function (buf) { + if (this.lastNeed <= buf.length) { + buf.copy(this.lastChar, this.lastTotal - this.lastNeed, 0, this.lastNeed); + return this.lastChar.toString(this.encoding, 0, this.lastTotal); + } + buf.copy(this.lastChar, this.lastTotal - this.lastNeed, 0, buf.length); + this.lastNeed -= buf.length; +}; -var Buffer = (__nccwpck_require__(14300).Buffer); +// Checks the type of a UTF-8 byte, whether it's ASCII, a leading byte, or a +// continuation byte. If an invalid byte is detected, -2 is returned. +function utf8CheckByte(byte) { + if (byte <= 0x7F) return 0;else if (byte >> 5 === 0x06) return 2;else if (byte >> 4 === 0x0E) return 3;else if (byte >> 3 === 0x1E) return 4; + return byte >> 6 === 0x02 ? -1 : -2; +} -var OurUint8Array = global.Uint8Array || function () {}; +// Checks at most 3 bytes at the end of a Buffer in order to detect an +// incomplete multi-byte UTF-8 character. The total number of bytes (2, 3, or 4) +// needed to complete the UTF-8 character (if applicable) are returned. +function utf8CheckIncomplete(self, buf, i) { + var j = buf.length - 1; + if (j < i) return 0; + var nb = utf8CheckByte(buf[j]); + if (nb >= 0) { + if (nb > 0) self.lastNeed = nb - 1; + return nb; + } + if (--j < i || nb === -2) return 0; + nb = utf8CheckByte(buf[j]); + if (nb >= 0) { + if (nb > 0) self.lastNeed = nb - 2; + return nb; + } + if (--j < i || nb === -2) return 0; + nb = utf8CheckByte(buf[j]); + if (nb >= 0) { + if (nb > 0) { + if (nb === 2) nb = 0;else self.lastNeed = nb - 3; + } + return nb; + } + return 0; +} -function _uint8ArrayToBuffer(chunk) { - return Buffer.from(chunk); +// Validates as many continuation bytes for a multi-byte UTF-8 character as +// needed or are available. If we see a non-continuation byte where we expect +// one, we "replace" the validated continuation bytes we've seen so far with +// a single UTF-8 replacement character ('\ufffd'), to match v8's UTF-8 decoding +// behavior. The continuation byte check is included three times in the case +// where all of the continuation bytes for a character exist in the same buffer. +// It is also done this way as a slight performance increase instead of using a +// loop. +function utf8CheckExtraBytes(self, buf, p) { + if ((buf[0] & 0xC0) !== 0x80) { + self.lastNeed = 0; + return '\ufffd'; + } + if (self.lastNeed > 1 && buf.length > 1) { + if ((buf[1] & 0xC0) !== 0x80) { + self.lastNeed = 1; + return '\ufffd'; + } + if (self.lastNeed > 2 && buf.length > 2) { + if ((buf[2] & 0xC0) !== 0x80) { + self.lastNeed = 2; + return '\ufffd'; + } + } + } } -function _isUint8Array(obj) { - return Buffer.isBuffer(obj) || obj instanceof OurUint8Array; +// Attempts to complete a multi-byte UTF-8 character using bytes from a Buffer. +function utf8FillLast(buf) { + var p = this.lastTotal - this.lastNeed; + var r = utf8CheckExtraBytes(this, buf, p); + if (r !== undefined) return r; + if (this.lastNeed <= buf.length) { + buf.copy(this.lastChar, p, 0, this.lastNeed); + return this.lastChar.toString(this.encoding, 0, this.lastTotal); + } + buf.copy(this.lastChar, p, 0, buf.length); + this.lastNeed -= buf.length; } -var destroyImpl = __nccwpck_require__(70079); +// Returns all complete UTF-8 characters in a Buffer. If the Buffer ended on a +// partial character, the character's bytes are buffered until the required +// number of bytes are available. +function utf8Text(buf, i) { + var total = utf8CheckIncomplete(this, buf, i); + if (!this.lastNeed) return buf.toString('utf8', i); + this.lastTotal = total; + var end = buf.length - (total - this.lastNeed); + buf.copy(this.lastChar, 0, end); + return buf.toString('utf8', i, end); +} -var _require = __nccwpck_require__(97458), - getHighWaterMark = _require.getHighWaterMark; +// For UTF-8, a replacement character is added when ending on a partial +// character. +function utf8End(buf) { + var r = buf && buf.length ? this.write(buf) : ''; + if (this.lastNeed) return r + '\ufffd'; + return r; +} -var _require$codes = (__nccwpck_require__(91042)/* .codes */ .q), - ERR_INVALID_ARG_TYPE = _require$codes.ERR_INVALID_ARG_TYPE, - ERR_METHOD_NOT_IMPLEMENTED = _require$codes.ERR_METHOD_NOT_IMPLEMENTED, - ERR_MULTIPLE_CALLBACK = _require$codes.ERR_MULTIPLE_CALLBACK, - ERR_STREAM_CANNOT_PIPE = _require$codes.ERR_STREAM_CANNOT_PIPE, - ERR_STREAM_DESTROYED = _require$codes.ERR_STREAM_DESTROYED, - ERR_STREAM_NULL_VALUES = _require$codes.ERR_STREAM_NULL_VALUES, - ERR_STREAM_WRITE_AFTER_END = _require$codes.ERR_STREAM_WRITE_AFTER_END, - ERR_UNKNOWN_ENCODING = _require$codes.ERR_UNKNOWN_ENCODING; +// UTF-16LE typically needs two bytes per character, but even if we have an even +// number of bytes available, we need to check if we end on a leading/high +// surrogate. In that case, we need to wait for the next two bytes in order to +// decode the last character properly. +function utf16Text(buf, i) { + if ((buf.length - i) % 2 === 0) { + var r = buf.toString('utf16le', i); + if (r) { + var c = r.charCodeAt(r.length - 1); + if (c >= 0xD800 && c <= 0xDBFF) { + this.lastNeed = 2; + this.lastTotal = 4; + this.lastChar[0] = buf[buf.length - 2]; + this.lastChar[1] = buf[buf.length - 1]; + return r.slice(0, -1); + } + } + return r; + } + this.lastNeed = 1; + this.lastTotal = 2; + this.lastChar[0] = buf[buf.length - 1]; + return buf.toString('utf16le', i, buf.length - 1); +} -var errorOrDestroy = destroyImpl.errorOrDestroy; +// For UTF-16LE we do not explicitly append special replacement characters if we +// end on a partial character, we simply let v8 handle that. +function utf16End(buf) { + var r = buf && buf.length ? this.write(buf) : ''; + if (this.lastNeed) { + var end = this.lastTotal - this.lastNeed; + return r + this.lastChar.toString('utf16le', 0, end); + } + return r; +} -__nccwpck_require__(2868)(Writable, Stream); +function base64Text(buf, i) { + var n = (buf.length - i) % 3; + if (n === 0) return buf.toString('base64', i); + this.lastNeed = 3 - n; + this.lastTotal = 3; + if (n === 1) { + this.lastChar[0] = buf[buf.length - 1]; + } else { + this.lastChar[0] = buf[buf.length - 2]; + this.lastChar[1] = buf[buf.length - 1]; + } + return buf.toString('base64', i, buf.length - n); +} -function nop() {} +function base64End(buf) { + var r = buf && buf.length ? this.write(buf) : ''; + if (this.lastNeed) return r + this.lastChar.toString('base64', 0, 3 - this.lastNeed); + return r; +} -function WritableState(options, stream, isDuplex) { - Duplex = Duplex || __nccwpck_require__(25408); - options = options || {}; // Duplex streams are both readable and writable, but share - // the same options object. - // However, some cases require setting options to different - // values for the readable and the writable sides of the duplex stream, - // e.g. options.readableObjectMode vs. options.writableObjectMode, etc. +// Pass bytes on through for single-byte encodings (e.g. ascii, latin1, hex) +function simpleWrite(buf) { + return buf.toString(this.encoding); +} - if (typeof isDuplex !== 'boolean') isDuplex = stream instanceof Duplex; // object stream flag to indicate whether or not this stream - // contains buffers or objects. +function simpleEnd(buf) { + return buf && buf.length ? this.write(buf) : ''; +} - this.objectMode = !!options.objectMode; - if (isDuplex) this.objectMode = this.objectMode || !!options.writableObjectMode; // the point at which write() starts returning false - // Note: 0 is a valid value, means that we always return false if - // the entire buffer is not flushed immediately on write() +/***/ }), - this.highWaterMark = getHighWaterMark(this, options, 'writableHighWaterMark', isDuplex); // if _final has been called +/***/ 26080: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { - this.finalCalled = false; // drain event flag. +"use strict"; - this.needDrain = false; // at the start of calling end() +const os = __nccwpck_require__(22037); +const hasFlag = __nccwpck_require__(54402); - this.ending = false; // when end() has been called, and returned +const env = process.env; - this.ended = false; // when 'finish' is emitted +let forceColor; +if (hasFlag('no-color') || + hasFlag('no-colors') || + hasFlag('color=false')) { + forceColor = false; +} else if (hasFlag('color') || + hasFlag('colors') || + hasFlag('color=true') || + hasFlag('color=always')) { + forceColor = true; +} +if ('FORCE_COLOR' in env) { + forceColor = env.FORCE_COLOR.length === 0 || parseInt(env.FORCE_COLOR, 10) !== 0; +} - this.finished = false; // has it been destroyed +function translateLevel(level) { + if (level === 0) { + return false; + } - this.destroyed = false; // should we decode strings into buffers before passing to _write? - // this is here so that some node-core streams can optimize string - // handling at a lower level. + return { + level, + hasBasic: true, + has256: level >= 2, + has16m: level >= 3 + }; +} - var noDecode = options.decodeStrings === false; - this.decodeStrings = !noDecode; // Crypto is kind of old and crusty. Historically, its default string - // encoding is 'binary' so we have to make this configurable. - // Everything else in the universe uses 'utf8', though. +function supportsColor(stream) { + if (forceColor === false) { + return 0; + } - this.defaultEncoding = options.defaultEncoding || 'utf8'; // not an actual buffer we keep track of, but a measurement - // of how much we're waiting to get pushed to some underlying - // socket or file. + if (hasFlag('color=16m') || + hasFlag('color=full') || + hasFlag('color=truecolor')) { + return 3; + } - this.length = 0; // a flag to see when we're in the middle of a write. + if (hasFlag('color=256')) { + return 2; + } - this.writing = false; // when true all writes will be buffered until .uncork() call + if (stream && !stream.isTTY && forceColor !== true) { + return 0; + } - this.corked = 0; // a flag to be able to tell if the onwrite cb is called immediately, - // or on a later tick. We set this to true at first, because any - // actions that shouldn't happen until "later" should generally also - // not happen before the first write call. + const min = forceColor ? 1 : 0; - this.sync = true; // a flag to know if we're processing previously buffered items, which - // may call the _write() callback in the same tick, so that we don't - // end up in an overlapped onwrite situation. + if (process.platform === 'win32') { + // Node.js 7.5.0 is the first version of Node.js to include a patch to + // libuv that enables 256 color output on Windows. Anything earlier and it + // won't work. However, here we target Node.js 8 at minimum as it is an LTS + // release, and Node.js 7 is not. Windows 10 build 10586 is the first Windows + // release that supports 256 colors. Windows 10 build 14931 is the first release + // that supports 16m/TrueColor. + const osRelease = os.release().split('.'); + if ( + Number(process.versions.node.split('.')[0]) >= 8 && + Number(osRelease[0]) >= 10 && + Number(osRelease[2]) >= 10586 + ) { + return Number(osRelease[2]) >= 14931 ? 3 : 2; + } - this.bufferProcessing = false; // the callback that's passed to _write(chunk,cb) + return 1; + } - this.onwrite = function (er) { - onwrite(stream, er); - }; // the callback that the user supplies to write(chunk,encoding,cb) + if ('CI' in env) { + if (['TRAVIS', 'CIRCLECI', 'APPVEYOR', 'GITLAB_CI'].some(sign => sign in env) || env.CI_NAME === 'codeship') { + return 1; + } + return min; + } - this.writecb = null; // the amount that is being written when _write is called. + if ('TEAMCITY_VERSION' in env) { + return /^(9\.(0*[1-9]\d*)\.|\d{2,}\.)/.test(env.TEAMCITY_VERSION) ? 1 : 0; + } - this.writelen = 0; - this.bufferedRequest = null; - this.lastBufferedRequest = null; // number of pending user-supplied write callbacks - // this must be 0 before 'finish' can be emitted + if (env.COLORTERM === 'truecolor') { + return 3; + } - this.pendingcb = 0; // emit prefinish if the only thing we're waiting for is _write cbs - // This is relevant for synchronous Transform streams + if ('TERM_PROGRAM' in env) { + const version = parseInt((env.TERM_PROGRAM_VERSION || '').split('.')[0], 10); - this.prefinished = false; // True if the error was already emitted and should not be thrown again + switch (env.TERM_PROGRAM) { + case 'iTerm.app': + return version >= 3 ? 3 : 2; + case 'Apple_Terminal': + return 2; + // No default + } + } - this.errorEmitted = false; // Should close be emitted on destroy. Defaults to true. + if (/-256(color)?$/i.test(env.TERM)) { + return 2; + } - this.emitClose = options.emitClose !== false; // Should .destroy() be called after 'finish' (and potentially 'end') + if (/^screen|^xterm|^vt100|^vt220|^rxvt|color|ansi|cygwin|linux/i.test(env.TERM)) { + return 1; + } - this.autoDestroy = !!options.autoDestroy; // count buffered requests + if ('COLORTERM' in env) { + return 1; + } - this.bufferedRequestCount = 0; // allocate the first CorkedRequest, there is always - // one allocated and free to use, and we maintain at most two + if (env.TERM === 'dumb') { + return min; + } - this.corkedRequestsFree = new CorkedRequest(this); + return min; } -WritableState.prototype.getBuffer = function getBuffer() { - var current = this.bufferedRequest; - var out = []; - - while (current) { - out.push(current); - current = current.next; - } +function getSupportLevel(stream) { + const level = supportsColor(stream); + return translateLevel(level); +} - return out; +module.exports = { + supportsColor: getSupportLevel, + stdout: getSupportLevel(process.stdout), + stderr: getSupportLevel(process.stderr) }; -(function () { - try { - Object.defineProperty(WritableState.prototype, 'buffer', { - get: internalUtil.deprecate(function writableStateBufferGetter() { - return this.getBuffer(); - }, '_writableState.buffer is deprecated. Use _writableState.getBuffer ' + 'instead.', 'DEP0003') - }); - } catch (_) {} -})(); // Test _writableState for inheritance to account for Duplex streams, -// whose prototype chain only points to Readable. - -var realHasInstance; +/***/ }), -if (typeof Symbol === 'function' && Symbol.hasInstance && typeof Function.prototype[Symbol.hasInstance] === 'function') { - realHasInstance = Function.prototype[Symbol.hasInstance]; - Object.defineProperty(Writable, Symbol.hasInstance, { - value: function value(object) { - if (realHasInstance.call(this, object)) return true; - if (this !== Writable) return false; - return object && object._writableState instanceof WritableState; - } - }); -} else { - realHasInstance = function realHasInstance(object) { - return object instanceof this; - }; -} +/***/ 54402: +/***/ ((module) => { -function Writable(options) { - Duplex = Duplex || __nccwpck_require__(25408); // Writable ctor is applied to Duplexes, too. - // `realHasInstance` is necessary because using plain `instanceof` - // would return false, as no `_writableState` property is attached. - // Trying to use the custom `instanceof` for Writable here will also break the - // Node.js LazyTransform implementation, which has a non-trivial getter for - // `_writableState` that would lead to infinite recursion. - // Checking for a Stream.Duplex instance is faster here instead of inside - // the WritableState constructor, at least with V8 6.5 +"use strict"; - var isDuplex = this instanceof Duplex; - if (!isDuplex && !realHasInstance.call(Writable, this)) return new Writable(options); - this._writableState = new WritableState(options, this, isDuplex); // legacy. +module.exports = (flag, argv) => { + argv = argv || process.argv; + const prefix = flag.startsWith('-') ? '' : (flag.length === 1 ? '-' : '--'); + const pos = argv.indexOf(prefix + flag); + const terminatorPos = argv.indexOf('--'); + return pos !== -1 && (terminatorPos === -1 ? true : pos < terminatorPos); +}; - this.writable = true; - if (options) { - if (typeof options.write === 'function') this._write = options.write; - if (typeof options.writev === 'function') this._writev = options.writev; - if (typeof options.destroy === 'function') this._destroy = options.destroy; - if (typeof options.final === 'function') this._final = options.final; - } +/***/ }), - Stream.call(this); -} // Otherwise people can pipe Writable streams, which is just wrong. +/***/ 91674: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { +var util = __nccwpck_require__(73837) +var bl = __nccwpck_require__(82489) +var headers = __nccwpck_require__(53350) -Writable.prototype.pipe = function () { - errorOrDestroy(this, new ERR_STREAM_CANNOT_PIPE()); -}; +var Writable = (__nccwpck_require__(17067).Writable) +var PassThrough = (__nccwpck_require__(17067).PassThrough) -function writeAfterEnd(stream, cb) { - var er = new ERR_STREAM_WRITE_AFTER_END(); // TODO: defer error events consistently everywhere, not just the cb +var noop = function () {} - errorOrDestroy(stream, er); - process.nextTick(cb, er); -} // Checks that a user-supplied chunk is valid, especially for the particular -// mode the stream is in. Currently this means that `null` is never accepted -// and undefined/non-string values are only allowed in object mode. +var overflow = function (size) { + size &= 511 + return size && 512 - size +} +var emptyStream = function (self, offset) { + var s = new Source(self, offset) + s.end() + return s +} -function validChunk(stream, state, chunk, cb) { - var er; +var mixinPax = function (header, pax) { + if (pax.path) header.name = pax.path + if (pax.linkpath) header.linkname = pax.linkpath + if (pax.size) header.size = parseInt(pax.size, 10) + header.pax = pax + return header +} - if (chunk === null) { - er = new ERR_STREAM_NULL_VALUES(); - } else if (typeof chunk !== 'string' && !state.objectMode) { - er = new ERR_INVALID_ARG_TYPE('chunk', ['string', 'Buffer'], chunk); - } +var Source = function (self, offset) { + this._parent = self + this.offset = offset + PassThrough.call(this, { autoDestroy: false }) +} - if (er) { - errorOrDestroy(stream, er); - process.nextTick(cb, er); - return false; - } +util.inherits(Source, PassThrough) - return true; +Source.prototype.destroy = function (err) { + this._parent.destroy(err) } -Writable.prototype.write = function (chunk, encoding, cb) { - var state = this._writableState; - var ret = false; +var Extract = function (opts) { + if (!(this instanceof Extract)) return new Extract(opts) + Writable.call(this, opts) - var isBuf = !state.objectMode && _isUint8Array(chunk); + opts = opts || {} - if (isBuf && !Buffer.isBuffer(chunk)) { - chunk = _uint8ArrayToBuffer(chunk); - } + this._offset = 0 + this._buffer = bl() + this._missing = 0 + this._partial = false + this._onparse = noop + this._header = null + this._stream = null + this._overflow = null + this._cb = null + this._locked = false + this._destroyed = false + this._pax = null + this._paxGlobal = null + this._gnuLongPath = null + this._gnuLongLinkPath = null - if (typeof encoding === 'function') { - cb = encoding; - encoding = null; - } + var self = this + var b = self._buffer - if (isBuf) encoding = 'buffer';else if (!encoding) encoding = state.defaultEncoding; - if (typeof cb !== 'function') cb = nop; - if (state.ending) writeAfterEnd(this, cb);else if (isBuf || validChunk(this, state, chunk, cb)) { - state.pendingcb++; - ret = writeOrBuffer(this, state, isBuf, chunk, encoding, cb); + var oncontinue = function () { + self._continue() } - return ret; -}; - -Writable.prototype.cork = function () { - this._writableState.corked++; -}; -Writable.prototype.uncork = function () { - var state = this._writableState; + var onunlock = function (err) { + self._locked = false + if (err) return self.destroy(err) + if (!self._stream) oncontinue() + } - if (state.corked) { - state.corked--; - if (!state.writing && !state.corked && !state.bufferProcessing && state.bufferedRequest) clearBuffer(this, state); + var onstreamend = function () { + self._stream = null + var drain = overflow(self._header.size) + if (drain) self._parse(drain, ondrain) + else self._parse(512, onheader) + if (!self._locked) oncontinue() } -}; -Writable.prototype.setDefaultEncoding = function setDefaultEncoding(encoding) { - // node::ParseEncoding() requires lower case. - if (typeof encoding === 'string') encoding = encoding.toLowerCase(); - if (!(['hex', 'utf8', 'utf-8', 'ascii', 'binary', 'base64', 'ucs2', 'ucs-2', 'utf16le', 'utf-16le', 'raw'].indexOf((encoding + '').toLowerCase()) > -1)) throw new ERR_UNKNOWN_ENCODING(encoding); - this._writableState.defaultEncoding = encoding; - return this; -}; + var ondrain = function () { + self._buffer.consume(overflow(self._header.size)) + self._parse(512, onheader) + oncontinue() + } -Object.defineProperty(Writable.prototype, 'writableBuffer', { - // making it explicit this property is not enumerable - // because otherwise some prototype manipulation in - // userland will fail - enumerable: false, - get: function get() { - return this._writableState && this._writableState.getBuffer(); + var onpaxglobalheader = function () { + var size = self._header.size + self._paxGlobal = headers.decodePax(b.slice(0, size)) + b.consume(size) + onstreamend() } -}); -function decodeChunk(state, chunk, encoding) { - if (!state.objectMode && state.decodeStrings !== false && typeof chunk === 'string') { - chunk = Buffer.from(chunk, encoding); + var onpaxheader = function () { + var size = self._header.size + self._pax = headers.decodePax(b.slice(0, size)) + if (self._paxGlobal) self._pax = Object.assign({}, self._paxGlobal, self._pax) + b.consume(size) + onstreamend() } - return chunk; -} + var ongnulongpath = function () { + var size = self._header.size + this._gnuLongPath = headers.decodeLongPath(b.slice(0, size), opts.filenameEncoding) + b.consume(size) + onstreamend() + } -Object.defineProperty(Writable.prototype, 'writableHighWaterMark', { - // making it explicit this property is not enumerable - // because otherwise some prototype manipulation in - // userland will fail - enumerable: false, - get: function get() { - return this._writableState.highWaterMark; + var ongnulonglinkpath = function () { + var size = self._header.size + this._gnuLongLinkPath = headers.decodeLongPath(b.slice(0, size), opts.filenameEncoding) + b.consume(size) + onstreamend() } -}); // if we're already writing something, then just put this -// in the queue, and wait our turn. Otherwise, call _write -// If we return false, then we need a drain event, so set that flag. -function writeOrBuffer(stream, state, isBuf, chunk, encoding, cb) { - if (!isBuf) { - var newChunk = decodeChunk(state, chunk, encoding); + var onheader = function () { + var offset = self._offset + var header + try { + header = self._header = headers.decode(b.slice(0, 512), opts.filenameEncoding, opts.allowUnknownFormat) + } catch (err) { + self.emit('error', err) + } + b.consume(512) - if (chunk !== newChunk) { - isBuf = true; - encoding = 'buffer'; - chunk = newChunk; + if (!header) { + self._parse(512, onheader) + oncontinue() + return + } + if (header.type === 'gnu-long-path') { + self._parse(header.size, ongnulongpath) + oncontinue() + return + } + if (header.type === 'gnu-long-link-path') { + self._parse(header.size, ongnulonglinkpath) + oncontinue() + return + } + if (header.type === 'pax-global-header') { + self._parse(header.size, onpaxglobalheader) + oncontinue() + return + } + if (header.type === 'pax-header') { + self._parse(header.size, onpaxheader) + oncontinue() + return } - } - var len = state.objectMode ? 1 : chunk.length; - state.length += len; - var ret = state.length < state.highWaterMark; // we must ensure that previous needDrain will not be reset to false. + if (self._gnuLongPath) { + header.name = self._gnuLongPath + self._gnuLongPath = null + } - if (!ret) state.needDrain = true; + if (self._gnuLongLinkPath) { + header.linkname = self._gnuLongLinkPath + self._gnuLongLinkPath = null + } - if (state.writing || state.corked) { - var last = state.lastBufferedRequest; - state.lastBufferedRequest = { - chunk: chunk, - encoding: encoding, - isBuf: isBuf, - callback: cb, - next: null - }; + if (self._pax) { + self._header = header = mixinPax(header, self._pax) + self._pax = null + } - if (last) { - last.next = state.lastBufferedRequest; - } else { - state.bufferedRequest = state.lastBufferedRequest; + self._locked = true + + if (!header.size || header.type === 'directory') { + self._parse(512, onheader) + self.emit('entry', header, emptyStream(self, offset), onunlock) + return } - state.bufferedRequestCount += 1; - } else { - doWrite(stream, state, false, len, chunk, encoding, cb); - } + self._stream = new Source(self, offset) - return ret; -} + self.emit('entry', header, self._stream, onunlock) + self._parse(header.size, onstreamend) + oncontinue() + } -function doWrite(stream, state, writev, len, chunk, encoding, cb) { - state.writelen = len; - state.writecb = cb; - state.writing = true; - state.sync = true; - if (state.destroyed) state.onwrite(new ERR_STREAM_DESTROYED('write'));else if (writev) stream._writev(chunk, state.onwrite);else stream._write(chunk, encoding, state.onwrite); - state.sync = false; + this._onheader = onheader + this._parse(512, onheader) } -function onwriteError(stream, state, sync, er, cb) { - --state.pendingcb; +util.inherits(Extract, Writable) - if (sync) { - // defer the callback if we are being called synchronously - // to avoid piling up things on the stack - process.nextTick(cb, er); // this can emit finish, and it will always happen - // after error +Extract.prototype.destroy = function (err) { + if (this._destroyed) return + this._destroyed = true - process.nextTick(finishMaybe, stream, state); - stream._writableState.errorEmitted = true; - errorOrDestroy(stream, er); - } else { - // the caller expect this to happen before if - // it is async - cb(er); - stream._writableState.errorEmitted = true; - errorOrDestroy(stream, er); // this can emit finish, but finish must - // always follow error + if (err) this.emit('error', err) + this.emit('close') + if (this._stream) this._stream.emit('close') +} - finishMaybe(stream, state); - } +Extract.prototype._parse = function (size, onparse) { + if (this._destroyed) return + this._offset += size + this._missing = size + if (onparse === this._onheader) this._partial = false + this._onparse = onparse } -function onwriteStateUpdate(state) { - state.writing = false; - state.writecb = null; - state.length -= state.writelen; - state.writelen = 0; +Extract.prototype._continue = function () { + if (this._destroyed) return + var cb = this._cb + this._cb = noop + if (this._overflow) this._write(this._overflow, undefined, cb) + else cb() } -function onwrite(stream, er) { - var state = stream._writableState; - var sync = state.sync; - var cb = state.writecb; - if (typeof cb !== 'function') throw new ERR_MULTIPLE_CALLBACK(); - onwriteStateUpdate(state); - if (er) onwriteError(stream, state, sync, er, cb);else { - // Check if we're actually ready to finish, but don't emit yet - var finished = needFinish(state) || stream.destroyed; +Extract.prototype._write = function (data, enc, cb) { + if (this._destroyed) return - if (!finished && !state.corked && !state.bufferProcessing && state.bufferedRequest) { - clearBuffer(stream, state); - } + var s = this._stream + var b = this._buffer + var missing = this._missing + if (data.length) this._partial = true - if (sync) { - process.nextTick(afterWrite, stream, state, finished, cb); - } else { - afterWrite(stream, state, finished, cb); - } + // we do not reach end-of-chunk now. just forward it + + if (data.length < missing) { + this._missing -= data.length + this._overflow = null + if (s) return s.write(data, cb) + b.append(data) + return cb() } -} -function afterWrite(stream, state, finished, cb) { - if (!finished) onwriteDrain(stream, state); - state.pendingcb--; - cb(); - finishMaybe(stream, state); -} // Must force callback to be called on nextTick, so that we don't -// emit 'drain' before the write() consumer gets the 'false' return -// value, and has a chance to attach a 'drain' listener. + // end-of-chunk. the parser should call cb. + this._cb = cb + this._missing = 0 -function onwriteDrain(stream, state) { - if (state.length === 0 && state.needDrain) { - state.needDrain = false; - stream.emit('drain'); + var overflow = null + if (data.length > missing) { + overflow = data.slice(missing) + data = data.slice(0, missing) } -} // if there's something in the buffer waiting, then process it + if (s) s.end(data) + else b.append(data) -function clearBuffer(stream, state) { - state.bufferProcessing = true; - var entry = state.bufferedRequest; + this._overflow = overflow + this._onparse() +} - if (stream._writev && entry && entry.next) { - // Fast case, write everything using _writev() - var l = state.bufferedRequestCount; - var buffer = new Array(l); - var holder = state.corkedRequestsFree; - holder.entry = entry; - var count = 0; - var allBuffers = true; +Extract.prototype._final = function (cb) { + if (this._partial) return this.destroy(new Error('Unexpected end of data')) + cb() +} - while (entry) { - buffer[count] = entry; - if (!entry.isBuf) allBuffers = false; - entry = entry.next; - count += 1; - } +module.exports = Extract - buffer.allBuffers = allBuffers; - doWrite(stream, state, true, state.length, buffer, '', holder.finish); // doWrite is almost always async, defer these to save a bit of time - // as the hot path ends with doWrite - state.pendingcb++; - state.lastBufferedRequest = null; +/***/ }), - if (holder.next) { - state.corkedRequestsFree = holder.next; - holder.next = null; - } else { - state.corkedRequestsFree = new CorkedRequest(state); - } +/***/ 53350: +/***/ ((__unused_webpack_module, exports) => { - state.bufferedRequestCount = 0; - } else { - // Slow case, write chunks one-by-one - while (entry) { - var chunk = entry.chunk; - var encoding = entry.encoding; - var cb = entry.callback; - var len = state.objectMode ? 1 : chunk.length; - doWrite(stream, state, false, len, chunk, encoding, cb); - entry = entry.next; - state.bufferedRequestCount--; // if we didn't call the onwrite immediately, then - // it means that we need to wait until it does. - // also, that means that the chunk and cb are currently - // being processed, so move the buffer counter past them. +var alloc = Buffer.alloc - if (state.writing) { - break; - } - } +var ZEROS = '0000000000000000000' +var SEVENS = '7777777777777777777' +var ZERO_OFFSET = '0'.charCodeAt(0) +var USTAR_MAGIC = Buffer.from('ustar\x00', 'binary') +var USTAR_VER = Buffer.from('00', 'binary') +var GNU_MAGIC = Buffer.from('ustar\x20', 'binary') +var GNU_VER = Buffer.from('\x20\x00', 'binary') +var MASK = parseInt('7777', 8) +var MAGIC_OFFSET = 257 +var VERSION_OFFSET = 263 - if (entry === null) state.lastBufferedRequest = null; +var clamp = function (index, len, defaultValue) { + if (typeof index !== 'number') return defaultValue + index = ~~index // Coerce to integer. + if (index >= len) return len + if (index >= 0) return index + index += len + if (index >= 0) return index + return 0 +} + +var toType = function (flag) { + switch (flag) { + case 0: + return 'file' + case 1: + return 'link' + case 2: + return 'symlink' + case 3: + return 'character-device' + case 4: + return 'block-device' + case 5: + return 'directory' + case 6: + return 'fifo' + case 7: + return 'contiguous-file' + case 72: + return 'pax-header' + case 55: + return 'pax-global-header' + case 27: + return 'gnu-long-link-path' + case 28: + case 30: + return 'gnu-long-path' } - state.bufferedRequest = entry; - state.bufferProcessing = false; + return null } -Writable.prototype._write = function (chunk, encoding, cb) { - cb(new ERR_METHOD_NOT_IMPLEMENTED('_write()')); -}; - -Writable.prototype._writev = null; +var toTypeflag = function (flag) { + switch (flag) { + case 'file': + return 0 + case 'link': + return 1 + case 'symlink': + return 2 + case 'character-device': + return 3 + case 'block-device': + return 4 + case 'directory': + return 5 + case 'fifo': + return 6 + case 'contiguous-file': + return 7 + case 'pax-header': + return 72 + } -Writable.prototype.end = function (chunk, encoding, cb) { - var state = this._writableState; + return 0 +} - if (typeof chunk === 'function') { - cb = chunk; - chunk = null; - encoding = null; - } else if (typeof encoding === 'function') { - cb = encoding; - encoding = null; +var indexOf = function (block, num, offset, end) { + for (; offset < end; offset++) { + if (block[offset] === num) return offset } + return end +} - if (chunk !== null && chunk !== undefined) this.write(chunk, encoding); // .end() fully uncorks +var cksum = function (block) { + var sum = 8 * 32 + for (var i = 0; i < 148; i++) sum += block[i] + for (var j = 156; j < 512; j++) sum += block[j] + return sum +} - if (state.corked) { - state.corked = 1; - this.uncork(); - } // ignore unnecessary end() calls. +var encodeOct = function (val, n) { + val = val.toString(8) + if (val.length > n) return SEVENS.slice(0, n) + ' ' + else return ZEROS.slice(0, n - val.length) + val + ' ' +} +/* Copied from the node-tar repo and modified to meet + * tar-stream coding standard. + * + * Source: https://github.com/npm/node-tar/blob/51b6627a1f357d2eb433e7378e5f05e83b7aa6cd/lib/header.js#L349 + */ +function parse256 (buf) { + // first byte MUST be either 80 or FF + // 80 for positive, FF for 2's comp + var positive + if (buf[0] === 0x80) positive = true + else if (buf[0] === 0xFF) positive = false + else return null - if (!state.ending) endWritable(this, state, cb); - return this; -}; + // build up a base-256 tuple from the least sig to the highest + var tuple = [] + for (var i = buf.length - 1; i > 0; i--) { + var byte = buf[i] + if (positive) tuple.push(byte) + else tuple.push(0xFF - byte) + } -Object.defineProperty(Writable.prototype, 'writableLength', { - // making it explicit this property is not enumerable - // because otherwise some prototype manipulation in - // userland will fail - enumerable: false, - get: function get() { - return this._writableState.length; + var sum = 0 + var l = tuple.length + for (i = 0; i < l; i++) { + sum += tuple[i] * Math.pow(256, i) } -}); -function needFinish(state) { - return state.ending && state.length === 0 && state.bufferedRequest === null && !state.finished && !state.writing; + return positive ? sum : -1 * sum } -function callFinal(stream, state) { - stream._final(function (err) { - state.pendingcb--; +var decodeOct = function (val, offset, length) { + val = val.slice(offset, offset + length) + offset = 0 - if (err) { - errorOrDestroy(stream, err); - } + // If prefixed with 0x80 then parse as a base-256 integer + if (val[offset] & 0x80) { + return parse256(val) + } else { + // Older versions of tar can prefix with spaces + while (offset < val.length && val[offset] === 32) offset++ + var end = clamp(indexOf(val, 32, offset, val.length), val.length, val.length) + while (offset < end && val[offset] === 0) offset++ + if (end === offset) return 0 + return parseInt(val.slice(offset, end).toString(), 8) + } +} - state.prefinished = true; - stream.emit('prefinish'); - finishMaybe(stream, state); - }); +var decodeStr = function (val, offset, length, encoding) { + return val.slice(offset, indexOf(val, 0, offset, offset + length)).toString(encoding) } -function prefinish(stream, state) { - if (!state.prefinished && !state.finalCalled) { - if (typeof stream._final === 'function' && !state.destroyed) { - state.pendingcb++; - state.finalCalled = true; - process.nextTick(callFinal, stream, state); - } else { - state.prefinished = true; - stream.emit('prefinish'); +var addLength = function (str) { + var len = Buffer.byteLength(str) + var digits = Math.floor(Math.log(len) / Math.log(10)) + 1 + if (len + digits >= Math.pow(10, digits)) digits++ + + return (len + digits) + str +} + +exports.decodeLongPath = function (buf, encoding) { + return decodeStr(buf, 0, buf.length, encoding) +} + +exports.encodePax = function (opts) { // TODO: encode more stuff in pax + var result = '' + if (opts.name) result += addLength(' path=' + opts.name + '\n') + if (opts.linkname) result += addLength(' linkpath=' + opts.linkname + '\n') + var pax = opts.pax + if (pax) { + for (var key in pax) { + result += addLength(' ' + key + '=' + pax[key] + '\n') } } + return Buffer.from(result) } -function finishMaybe(stream, state) { - var need = needFinish(state); - - if (need) { - prefinish(stream, state); +exports.decodePax = function (buf) { + var result = {} - if (state.pendingcb === 0) { - state.finished = true; - stream.emit('finish'); + while (buf.length) { + var i = 0 + while (i < buf.length && buf[i] !== 32) i++ + var len = parseInt(buf.slice(0, i).toString(), 10) + if (!len) return result - if (state.autoDestroy) { - // In case of duplex streams we need a way to detect - // if the readable side is ready for autoDestroy as well - var rState = stream._readableState; + var b = buf.slice(i + 1, len - 1).toString() + var keyIndex = b.indexOf('=') + if (keyIndex === -1) return result + result[b.slice(0, keyIndex)] = b.slice(keyIndex + 1) - if (!rState || rState.autoDestroy && rState.endEmitted) { - stream.destroy(); - } - } - } + buf = buf.slice(len) } - return need; + return result } -function endWritable(stream, state, cb) { - state.ending = true; - finishMaybe(stream, state); +exports.encode = function (opts) { + var buf = alloc(512) + var name = opts.name + var prefix = '' - if (cb) { - if (state.finished) process.nextTick(cb);else stream.once('finish', cb); + if (opts.typeflag === 5 && name[name.length - 1] !== '/') name += '/' + if (Buffer.byteLength(name) !== name.length) return null // utf-8 + + while (Buffer.byteLength(name) > 100) { + var i = name.indexOf('/') + if (i === -1) return null + prefix += prefix ? '/' + name.slice(0, i) : name.slice(0, i) + name = name.slice(i + 1) } - state.ended = true; - stream.writable = false; -} + if (Buffer.byteLength(name) > 100 || Buffer.byteLength(prefix) > 155) return null + if (opts.linkname && Buffer.byteLength(opts.linkname) > 100) return null -function onCorkedFinish(corkReq, state, err) { - var entry = corkReq.entry; - corkReq.entry = null; + buf.write(name) + buf.write(encodeOct(opts.mode & MASK, 6), 100) + buf.write(encodeOct(opts.uid, 6), 108) + buf.write(encodeOct(opts.gid, 6), 116) + buf.write(encodeOct(opts.size, 11), 124) + buf.write(encodeOct((opts.mtime.getTime() / 1000) | 0, 11), 136) - while (entry) { - var cb = entry.callback; - state.pendingcb--; - cb(err); - entry = entry.next; - } // reuse the free corkReq. + buf[156] = ZERO_OFFSET + toTypeflag(opts.type) + if (opts.linkname) buf.write(opts.linkname, 157) - state.corkedRequestsFree.next = corkReq; + USTAR_MAGIC.copy(buf, MAGIC_OFFSET) + USTAR_VER.copy(buf, VERSION_OFFSET) + if (opts.uname) buf.write(opts.uname, 265) + if (opts.gname) buf.write(opts.gname, 297) + buf.write(encodeOct(opts.devmajor || 0, 6), 329) + buf.write(encodeOct(opts.devminor || 0, 6), 337) + + if (prefix) buf.write(prefix, 345) + + buf.write(encodeOct(cksum(buf), 6), 148) + + return buf } -Object.defineProperty(Writable.prototype, 'destroyed', { - // making it explicit this property is not enumerable - // because otherwise some prototype manipulation in - // userland will fail - enumerable: false, - get: function get() { - if (this._writableState === undefined) { - return false; - } +exports.decode = function (buf, filenameEncoding, allowUnknownFormat) { + var typeflag = buf[156] === 0 ? 0 : buf[156] - ZERO_OFFSET - return this._writableState.destroyed; - }, - set: function set(value) { - // we ignore the value if the stream - // has not been initialized yet - if (!this._writableState) { - return; - } // backward compatibility, the user is explicitly - // managing destroyed + var name = decodeStr(buf, 0, 100, filenameEncoding) + var mode = decodeOct(buf, 100, 8) + var uid = decodeOct(buf, 108, 8) + var gid = decodeOct(buf, 116, 8) + var size = decodeOct(buf, 124, 12) + var mtime = decodeOct(buf, 136, 12) + var type = toType(typeflag) + var linkname = buf[157] === 0 ? null : decodeStr(buf, 157, 100, filenameEncoding) + var uname = decodeStr(buf, 265, 32) + var gname = decodeStr(buf, 297, 32) + var devmajor = decodeOct(buf, 329, 8) + var devminor = decodeOct(buf, 337, 8) + var c = cksum(buf) - this._writableState.destroyed = value; + // checksum is still initial value if header was null. + if (c === 8 * 32) return null + + // valid checksum + if (c !== decodeOct(buf, 148, 8)) throw new Error('Invalid tar header. Maybe the tar is corrupted or it needs to be gunzipped?') + + if (USTAR_MAGIC.compare(buf, MAGIC_OFFSET, MAGIC_OFFSET + 6) === 0) { + // ustar (posix) format. + // prepend prefix, if present. + if (buf[345]) name = decodeStr(buf, 345, 155, filenameEncoding) + '/' + name + } else if (GNU_MAGIC.compare(buf, MAGIC_OFFSET, MAGIC_OFFSET + 6) === 0 && + GNU_VER.compare(buf, VERSION_OFFSET, VERSION_OFFSET + 2) === 0) { + // 'gnu'/'oldgnu' format. Similar to ustar, but has support for incremental and + // multi-volume tarballs. + } else { + if (!allowUnknownFormat) { + throw new Error('Invalid tar header: unknown format.') + } } -}); -Writable.prototype.destroy = destroyImpl.destroy; -Writable.prototype._undestroy = destroyImpl.undestroy; -Writable.prototype._destroy = function (err, cb) { - cb(err); -}; + // to support old tar versions that use trailing / to indicate dirs + if (typeflag === 0 && name && name[name.length - 1] === '/') typeflag = 5 + + return { + name, + mode, + uid, + gid, + size, + mtime: new Date(1000 * mtime), + type, + linkname, + uname, + gname, + devmajor, + devminor + } +} + + +/***/ }), + +/***/ 18571: +/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { + +exports.extract = __nccwpck_require__(91674) +exports.pack = __nccwpck_require__(5080) + /***/ }), -/***/ 29634: +/***/ 5080: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { -"use strict"; +var constants = __nccwpck_require__(69026) +var eos = __nccwpck_require__(44790) +var inherits = __nccwpck_require__(76401) +var alloc = Buffer.alloc +var Readable = (__nccwpck_require__(17067).Readable) +var Writable = (__nccwpck_require__(17067).Writable) +var StringDecoder = (__nccwpck_require__(71576).StringDecoder) -var _Object$setPrototypeO; +var headers = __nccwpck_require__(53350) -function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; } +var DMODE = parseInt('755', 8) +var FMODE = parseInt('644', 8) -var finished = __nccwpck_require__(40841); +var END_OF_TAR = alloc(1024) -var kLastResolve = Symbol('lastResolve'); -var kLastReject = Symbol('lastReject'); -var kError = Symbol('error'); -var kEnded = Symbol('ended'); -var kLastPromise = Symbol('lastPromise'); -var kHandlePromise = Symbol('handlePromise'); -var kStream = Symbol('stream'); +var noop = function () {} -function createIterResult(value, done) { - return { - value: value, - done: done - }; +var overflow = function (self, size) { + size &= 511 + if (size) self.push(END_OF_TAR.slice(0, 512 - size)) } -function readAndResolve(iter) { - var resolve = iter[kLastResolve]; +function modeToType (mode) { + switch (mode & constants.S_IFMT) { + case constants.S_IFBLK: return 'block-device' + case constants.S_IFCHR: return 'character-device' + case constants.S_IFDIR: return 'directory' + case constants.S_IFIFO: return 'fifo' + case constants.S_IFLNK: return 'symlink' + } - if (resolve !== null) { - var data = iter[kStream].read(); // we defer if data is null - // we can be expecting either 'end' or - // 'error' + return 'file' +} - if (data !== null) { - iter[kLastPromise] = null; - iter[kLastResolve] = null; - iter[kLastReject] = null; - resolve(createIterResult(data, false)); - } - } +var Sink = function (to) { + Writable.call(this) + this.written = 0 + this._to = to + this._destroyed = false } -function onReadable(iter) { - // we wait for the next tick, because it might - // emit an error with process.nextTick - process.nextTick(readAndResolve, iter); +inherits(Sink, Writable) + +Sink.prototype._write = function (data, enc, cb) { + this.written += data.length + if (this._to.push(data)) return cb() + this._to._drain = cb } -function wrapForNext(lastPromise, iter) { - return function (resolve, reject) { - lastPromise.then(function () { - if (iter[kEnded]) { - resolve(createIterResult(undefined, true)); - return; - } +Sink.prototype.destroy = function () { + if (this._destroyed) return + this._destroyed = true + this.emit('close') +} - iter[kHandlePromise](resolve, reject); - }, reject); - }; +var LinkSink = function () { + Writable.call(this) + this.linkname = '' + this._decoder = new StringDecoder('utf-8') + this._destroyed = false } -var AsyncIteratorPrototype = Object.getPrototypeOf(function () {}); -var ReadableStreamAsyncIteratorPrototype = Object.setPrototypeOf((_Object$setPrototypeO = { - get stream() { - return this[kStream]; - }, +inherits(LinkSink, Writable) - next: function next() { - var _this = this; +LinkSink.prototype._write = function (data, enc, cb) { + this.linkname += this._decoder.write(data) + cb() +} - // if we have detected an error in the meanwhile - // reject straight away - var error = this[kError]; +LinkSink.prototype.destroy = function () { + if (this._destroyed) return + this._destroyed = true + this.emit('close') +} - if (error !== null) { - return Promise.reject(error); - } +var Void = function () { + Writable.call(this) + this._destroyed = false +} - if (this[kEnded]) { - return Promise.resolve(createIterResult(undefined, true)); - } +inherits(Void, Writable) - if (this[kStream].destroyed) { - // We need to defer via nextTick because if .destroy(err) is - // called, the error will be emitted via nextTick, and - // we cannot guarantee that there is no error lingering around - // waiting to be emitted. - return new Promise(function (resolve, reject) { - process.nextTick(function () { - if (_this[kError]) { - reject(_this[kError]); - } else { - resolve(createIterResult(undefined, true)); - } - }); - }); - } // if we have multiple next() calls - // we will wait for the previous Promise to finish - // this logic is optimized to support for await loops, - // where next() is only called once at a time +Void.prototype._write = function (data, enc, cb) { + cb(new Error('No body allowed for this entry')) +} +Void.prototype.destroy = function () { + if (this._destroyed) return + this._destroyed = true + this.emit('close') +} - var lastPromise = this[kLastPromise]; - var promise; +var Pack = function (opts) { + if (!(this instanceof Pack)) return new Pack(opts) + Readable.call(this, opts) - if (lastPromise) { - promise = new Promise(wrapForNext(lastPromise, this)); - } else { - // fast path needed to support multiple this.push() - // without triggering the next() queue - var data = this[kStream].read(); + this._drain = noop + this._finalized = false + this._finalizing = false + this._destroyed = false + this._stream = null +} - if (data !== null) { - return Promise.resolve(createIterResult(data, false)); - } +inherits(Pack, Readable) - promise = new Promise(this[kHandlePromise]); - } +Pack.prototype.entry = function (header, buffer, callback) { + if (this._stream) throw new Error('already piping an entry') + if (this._finalized || this._destroyed) return - this[kLastPromise] = promise; - return promise; + if (typeof buffer === 'function') { + callback = buffer + buffer = null } -}, _defineProperty(_Object$setPrototypeO, Symbol.asyncIterator, function () { - return this; -}), _defineProperty(_Object$setPrototypeO, "return", function _return() { - var _this2 = this; - - // destroy(err, cb) is a private API - // we can guarantee we have that here, because we control the - // Readable class this is attached to - return new Promise(function (resolve, reject) { - _this2[kStream].destroy(null, function (err) { - if (err) { - reject(err); - return; - } - resolve(createIterResult(undefined, true)); - }); - }); -}), _Object$setPrototypeO), AsyncIteratorPrototype); + if (!callback) callback = noop -var createReadableStreamAsyncIterator = function createReadableStreamAsyncIterator(stream) { - var _Object$create; + var self = this - var iterator = Object.create(ReadableStreamAsyncIteratorPrototype, (_Object$create = {}, _defineProperty(_Object$create, kStream, { - value: stream, - writable: true - }), _defineProperty(_Object$create, kLastResolve, { - value: null, - writable: true - }), _defineProperty(_Object$create, kLastReject, { - value: null, - writable: true - }), _defineProperty(_Object$create, kError, { - value: null, - writable: true - }), _defineProperty(_Object$create, kEnded, { - value: stream._readableState.endEmitted, - writable: true - }), _defineProperty(_Object$create, kHandlePromise, { - value: function value(resolve, reject) { - var data = iterator[kStream].read(); + if (!header.size || header.type === 'symlink') header.size = 0 + if (!header.type) header.type = modeToType(header.mode) + if (!header.mode) header.mode = header.type === 'directory' ? DMODE : FMODE + if (!header.uid) header.uid = 0 + if (!header.gid) header.gid = 0 + if (!header.mtime) header.mtime = new Date() - if (data) { - iterator[kLastPromise] = null; - iterator[kLastResolve] = null; - iterator[kLastReject] = null; - resolve(createIterResult(data, false)); - } else { - iterator[kLastResolve] = resolve; - iterator[kLastReject] = reject; - } - }, - writable: true - }), _Object$create)); - iterator[kLastPromise] = null; - finished(stream, function (err) { - if (err && err.code !== 'ERR_STREAM_PREMATURE_CLOSE') { - var reject = iterator[kLastReject]; // reject if we are waiting for data in the Promise - // returned by next() and store the error + if (typeof buffer === 'string') buffer = Buffer.from(buffer) + if (Buffer.isBuffer(buffer)) { + header.size = buffer.length + this._encode(header) + var ok = this.push(buffer) + overflow(self, header.size) + if (ok) process.nextTick(callback) + else this._drain = callback + return new Void() + } - if (reject !== null) { - iterator[kLastPromise] = null; - iterator[kLastResolve] = null; - iterator[kLastReject] = null; - reject(err); + if (header.type === 'symlink' && !header.linkname) { + var linkSink = new LinkSink() + eos(linkSink, function (err) { + if (err) { // stream was closed + self.destroy() + return callback(err) } - iterator[kError] = err; - return; - } - - var resolve = iterator[kLastResolve]; - - if (resolve !== null) { - iterator[kLastPromise] = null; - iterator[kLastResolve] = null; - iterator[kLastReject] = null; - resolve(createIterResult(undefined, true)); - } - - iterator[kEnded] = true; - }); - stream.on('readable', onReadable.bind(null, iterator)); - return iterator; -}; + header.linkname = linkSink.linkname + self._encode(header) + callback() + }) -module.exports = createReadableStreamAsyncIterator; + return linkSink + } -/***/ }), + this._encode(header) -/***/ 85243: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + if (header.type !== 'file' && header.type !== 'contiguous-file') { + process.nextTick(callback) + return new Void() + } -"use strict"; + var sink = new Sink(this) + this._stream = sink -function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; } + eos(sink, function (err) { + self._stream = null -function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; } + if (err) { // stream was closed + self.destroy() + return callback(err) + } -function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; } + if (sink.written !== header.size) { // corrupting tar + self.destroy() + return callback(new Error('size mismatch')) + } -function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } + overflow(self, header.size) + if (self._finalizing) self.finalize() + callback() + }) -function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } + return sink +} -function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; } +Pack.prototype.finalize = function () { + if (this._stream) { + this._finalizing = true + return + } -var _require = __nccwpck_require__(14300), - Buffer = _require.Buffer; + if (this._finalized) return + this._finalized = true + this.push(END_OF_TAR) + this.push(null) +} -var _require2 = __nccwpck_require__(73837), - inspect = _require2.inspect; +Pack.prototype.destroy = function (err) { + if (this._destroyed) return + this._destroyed = true -var custom = inspect && inspect.custom || 'inspect'; + if (err) this.emit('error', err) + this.emit('close') + if (this._stream && this._stream.destroy) this._stream.destroy() +} -function copyBuffer(src, target, offset) { - Buffer.prototype.copy.call(src, target, offset); +Pack.prototype._encode = function (header) { + if (!header.pax) { + var buf = headers.encode(header) + if (buf) { + this.push(buf) + return + } + } + this._encodePax(header) } -module.exports = -/*#__PURE__*/ -function () { - function BufferList() { - _classCallCheck(this, BufferList); +Pack.prototype._encodePax = function (header) { + var paxHeader = headers.encodePax({ + name: header.name, + linkname: header.linkname, + pax: header.pax + }) - this.head = null; - this.tail = null; - this.length = 0; + var newHeader = { + name: 'PaxHeader', + mode: header.mode, + uid: header.uid, + gid: header.gid, + size: paxHeader.length, + mtime: header.mtime, + type: 'pax-header', + linkname: header.linkname && 'PaxHeader', + uname: header.uname, + gname: header.gname, + devmajor: header.devmajor, + devminor: header.devminor } - _createClass(BufferList, [{ - key: "push", - value: function push(v) { - var entry = { - data: v, - next: null - }; - if (this.length > 0) this.tail.next = entry;else this.head = entry; - this.tail = entry; - ++this.length; - } - }, { - key: "unshift", - value: function unshift(v) { - var entry = { - data: v, - next: this.head - }; - if (this.length === 0) this.tail = entry; - this.head = entry; - ++this.length; - } - }, { - key: "shift", - value: function shift() { - if (this.length === 0) return; - var ret = this.head.data; - if (this.length === 1) this.head = this.tail = null;else this.head = this.head.next; - --this.length; - return ret; - } - }, { - key: "clear", - value: function clear() { - this.head = this.tail = null; - this.length = 0; - } - }, { - key: "join", - value: function join(s) { - if (this.length === 0) return ''; - var p = this.head; - var ret = '' + p.data; + this.push(headers.encode(newHeader)) + this.push(paxHeader) + overflow(this, paxHeader.length) - while (p = p.next) { - ret += s + p.data; - } + newHeader.size = header.size + newHeader.type = header.type + this.push(headers.encode(newHeader)) +} - return ret; - } - }, { - key: "concat", - value: function concat(n) { - if (this.length === 0) return Buffer.alloc(0); - var ret = Buffer.allocUnsafe(n >>> 0); - var p = this.head; - var i = 0; +Pack.prototype._read = function (n) { + var drain = this._drain + this._drain = noop + drain() +} - while (p) { - copyBuffer(p.data, ret, i); - i += p.data.length; - p = p.next; - } +module.exports = Pack - return ret; - } // Consumes a specified amount of bytes or characters from the buffered data. - }, { - key: "consume", - value: function consume(n, hasStrings) { - var ret; +/***/ }), - if (n < this.head.data.length) { - // `slice` is the same for buffers and strings. - ret = this.head.data.slice(0, n); - this.head.data = this.head.data.slice(n); - } else if (n === this.head.data.length) { - // First chunk is a perfect match. - ret = this.shift(); - } else { - // Result spans more than one buffer. - ret = hasStrings ? this._getString(n) : this._getBuffer(n); - } +/***/ 81866: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { - return ret; - } - }, { - key: "first", - value: function first() { - return this.head.data; - } // Consumes a specified amount of characters from the buffered data. +/*! + * Tmp + * + * Copyright (c) 2011-2017 KARASZI Istvan + * + * MIT Licensed + */ - }, { - key: "_getString", - value: function _getString(n) { - var p = this.head; - var c = 1; - var ret = p.data; - n -= ret.length; +/* + * Module dependencies. + */ +const fs = __nccwpck_require__(57147); +const os = __nccwpck_require__(22037); +const path = __nccwpck_require__(71017); +const crypto = __nccwpck_require__(6113); +const _c = { fs: fs.constants, os: os.constants }; +const rimraf = __nccwpck_require__(88624); - while (p = p.next) { - var str = p.data; - var nb = n > str.length ? str.length : n; - if (nb === str.length) ret += str;else ret += str.slice(0, n); - n -= nb; +/* + * The working inner variables. + */ +const + // the random characters to choose from + RANDOM_CHARS = '0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz', - if (n === 0) { - if (nb === str.length) { - ++c; - if (p.next) this.head = p.next;else this.head = this.tail = null; - } else { - this.head = p; - p.data = str.slice(nb); - } + TEMPLATE_PATTERN = /XXXXXX/, - break; - } + DEFAULT_TRIES = 3, - ++c; - } + CREATE_FLAGS = (_c.O_CREAT || _c.fs.O_CREAT) | (_c.O_EXCL || _c.fs.O_EXCL) | (_c.O_RDWR || _c.fs.O_RDWR), - this.length -= c; - return ret; - } // Consumes a specified amount of bytes from the buffered data. + // constants are off on the windows platform and will not match the actual errno codes + IS_WIN32 = os.platform() === 'win32', + EBADF = _c.EBADF || _c.os.errno.EBADF, + ENOENT = _c.ENOENT || _c.os.errno.ENOENT, - }, { - key: "_getBuffer", - value: function _getBuffer(n) { - var ret = Buffer.allocUnsafe(n); - var p = this.head; - var c = 1; - p.data.copy(ret); - n -= p.data.length; + DIR_MODE = 0o700 /* 448 */, + FILE_MODE = 0o600 /* 384 */, - while (p = p.next) { - var buf = p.data; - var nb = n > buf.length ? buf.length : n; - buf.copy(ret, ret.length - n, 0, nb); - n -= nb; + EXIT = 'exit', - if (n === 0) { - if (nb === buf.length) { - ++c; - if (p.next) this.head = p.next;else this.head = this.tail = null; - } else { - this.head = p; - p.data = buf.slice(nb); - } + // this will hold the objects need to be removed on exit + _removeObjects = [], - break; - } + // API change in fs.rmdirSync leads to error when passing in a second parameter, e.g. the callback + FN_RMDIR_SYNC = fs.rmdirSync.bind(fs), + FN_RIMRAF_SYNC = rimraf.sync; - ++c; - } +let + _gracefulCleanup = false; - this.length -= c; - return ret; - } // Make sure the linked list only shows the minimal necessary information. +/** + * Gets a temporary file name. + * + * @param {(Options|tmpNameCallback)} options options or callback + * @param {?tmpNameCallback} callback the callback function + */ +function tmpName(options, callback) { + const + args = _parseArguments(options, callback), + opts = args[0], + cb = args[1]; - }, { - key: custom, - value: function value(_, options) { - return inspect(this, _objectSpread({}, options, { - // Only inspect one level. - depth: 0, - // It should not recurse. - customInspect: false - })); - } - }]); + try { + _assertAndSanitizeOptions(opts); + } catch (err) { + return cb(err); + } - return BufferList; -}(); + let tries = opts.tries; + (function _getUniqueName() { + try { + const name = _generateTmpName(opts); -/***/ }), + // check whether the path exists then retry if needed + fs.stat(name, function (err) { + /* istanbul ignore else */ + if (!err) { + /* istanbul ignore else */ + if (tries-- > 0) return _getUniqueName(); -/***/ 70079: -/***/ ((module) => { + return cb(new Error('Could not get a unique tmp filename, max tries reached ' + name)); + } -"use strict"; - // undocumented cb() API, needed for core, not for public API + cb(null, name); + }); + } catch (err) { + cb(err); + } + }()); +} -function destroy(err, cb) { - var _this = this; +/** + * Synchronous version of tmpName. + * + * @param {Object} options + * @returns {string} the generated random name + * @throws {Error} if the options are invalid or could not generate a filename + */ +function tmpNameSync(options) { + const + args = _parseArguments(options), + opts = args[0]; - var readableDestroyed = this._readableState && this._readableState.destroyed; - var writableDestroyed = this._writableState && this._writableState.destroyed; + _assertAndSanitizeOptions(opts); - if (readableDestroyed || writableDestroyed) { - if (cb) { - cb(err); - } else if (err) { - if (!this._writableState) { - process.nextTick(emitErrorNT, this, err); - } else if (!this._writableState.errorEmitted) { - this._writableState.errorEmitted = true; - process.nextTick(emitErrorNT, this, err); - } + let tries = opts.tries; + do { + const name = _generateTmpName(opts); + try { + fs.statSync(name); + } catch (e) { + return name; } + } while (tries-- > 0); - return this; - } // we set destroyed to true before firing error callbacks in order - // to make it re-entrance safe in case destroy() is called within callbacks - + throw new Error('Could not get a unique tmp filename, max tries reached'); +} - if (this._readableState) { - this._readableState.destroyed = true; - } // if this is a duplex stream mark the writable part as destroyed as well +/** + * Creates and opens a temporary file. + * + * @param {(Options|null|undefined|fileCallback)} options the config options or the callback function or null or undefined + * @param {?fileCallback} callback + */ +function file(options, callback) { + const + args = _parseArguments(options, callback), + opts = args[0], + cb = args[1]; + // gets a temporary filename + tmpName(opts, function _tmpNameCreated(err, name) { + /* istanbul ignore else */ + if (err) return cb(err); - if (this._writableState) { - this._writableState.destroyed = true; - } + // create and open the file + fs.open(name, CREATE_FLAGS, opts.mode || FILE_MODE, function _fileCreated(err, fd) { + /* istanbu ignore else */ + if (err) return cb(err); - this._destroy(err || null, function (err) { - if (!cb && err) { - if (!_this._writableState) { - process.nextTick(emitErrorAndCloseNT, _this, err); - } else if (!_this._writableState.errorEmitted) { - _this._writableState.errorEmitted = true; - process.nextTick(emitErrorAndCloseNT, _this, err); + if (opts.discardDescriptor) { + return fs.close(fd, function _discardCallback(possibleErr) { + // the chance of getting an error on close here is rather low and might occur in the most edgiest cases only + return cb(possibleErr, name, undefined, _prepareTmpFileRemoveCallback(name, -1, opts, false)); + }); } else { - process.nextTick(emitCloseNT, _this); + // detachDescriptor passes the descriptor whereas discardDescriptor closes it, either way, we no longer care + // about the descriptor + const discardOrDetachDescriptor = opts.discardDescriptor || opts.detachDescriptor; + cb(null, name, fd, _prepareTmpFileRemoveCallback(name, discardOrDetachDescriptor ? -1 : fd, opts, false)); } - } else if (cb) { - process.nextTick(emitCloseNT, _this); - cb(err); - } else { - process.nextTick(emitCloseNT, _this); - } + }); }); - - return this; -} - -function emitErrorAndCloseNT(self, err) { - emitErrorNT(self, err); - emitCloseNT(self); -} - -function emitCloseNT(self) { - if (self._writableState && !self._writableState.emitClose) return; - if (self._readableState && !self._readableState.emitClose) return; - self.emit('close'); } -function undestroy() { - if (this._readableState) { - this._readableState.destroyed = false; - this._readableState.reading = false; - this._readableState.ended = false; - this._readableState.endEmitted = false; - } +/** + * Synchronous version of file. + * + * @param {Options} options + * @returns {FileSyncObject} object consists of name, fd and removeCallback + * @throws {Error} if cannot create a file + */ +function fileSync(options) { + const + args = _parseArguments(options), + opts = args[0]; - if (this._writableState) { - this._writableState.destroyed = false; - this._writableState.ended = false; - this._writableState.ending = false; - this._writableState.finalCalled = false; - this._writableState.prefinished = false; - this._writableState.finished = false; - this._writableState.errorEmitted = false; + const discardOrDetachDescriptor = opts.discardDescriptor || opts.detachDescriptor; + const name = tmpNameSync(opts); + var fd = fs.openSync(name, CREATE_FLAGS, opts.mode || FILE_MODE); + /* istanbul ignore else */ + if (opts.discardDescriptor) { + fs.closeSync(fd); + fd = undefined; } -} - -function emitErrorNT(self, err) { - self.emit('error', err); -} -function errorOrDestroy(stream, err) { - // We have tests that rely on errors being emitted - // in the same tick, so changing this is semver major. - // For now when you opt-in to autoDestroy we allow - // the error to be emitted nextTick. In a future - // semver major update we should change the default to this. - var rState = stream._readableState; - var wState = stream._writableState; - if (rState && rState.autoDestroy || wState && wState.autoDestroy) stream.destroy(err);else stream.emit('error', err); + return { + name: name, + fd: fd, + removeCallback: _prepareTmpFileRemoveCallback(name, discardOrDetachDescriptor ? -1 : fd, opts, true) + }; } -module.exports = { - destroy: destroy, - undestroy: undestroy, - errorOrDestroy: errorOrDestroy -}; - -/***/ }), - -/***/ 40841: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { +/** + * Creates a temporary directory. + * + * @param {(Options|dirCallback)} options the options or the callback function + * @param {?dirCallback} callback + */ +function dir(options, callback) { + const + args = _parseArguments(options, callback), + opts = args[0], + cb = args[1]; -"use strict"; -// Ported from https://github.com/mafintosh/end-of-stream with -// permission from the author, Mathias Buus (@mafintosh). + // gets a temporary filename + tmpName(opts, function _tmpNameCreated(err, name) { + /* istanbul ignore else */ + if (err) return cb(err); + // create the directory + fs.mkdir(name, opts.mode || DIR_MODE, function _dirCreated(err) { + /* istanbul ignore else */ + if (err) return cb(err); -var ERR_STREAM_PREMATURE_CLOSE = (__nccwpck_require__(91042)/* .codes.ERR_STREAM_PREMATURE_CLOSE */ .q.ERR_STREAM_PREMATURE_CLOSE); + cb(null, name, _prepareTmpDirRemoveCallback(name, opts, false)); + }); + }); +} -function once(callback) { - var called = false; - return function () { - if (called) return; - called = true; +/** + * Synchronous version of dir. + * + * @param {Options} options + * @returns {DirSyncObject} object consists of name and removeCallback + * @throws {Error} if it cannot create a directory + */ +function dirSync(options) { + const + args = _parseArguments(options), + opts = args[0]; - for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) { - args[_key] = arguments[_key]; - } + const name = tmpNameSync(opts); + fs.mkdirSync(name, opts.mode || DIR_MODE); - callback.apply(this, args); + return { + name: name, + removeCallback: _prepareTmpDirRemoveCallback(name, opts, true) }; } -function noop() {} +/** + * Removes files asynchronously. + * + * @param {Object} fdPath + * @param {Function} next + * @private + */ +function _removeFileAsync(fdPath, next) { + const _handler = function (err) { + if (err && !_isENOENT(err)) { + // reraise any unanticipated error + return next(err); + } + next(); + }; -function isRequest(stream) { - return stream.setHeader && typeof stream.abort === 'function'; + if (0 <= fdPath[0]) + fs.close(fdPath[0], function () { + fs.unlink(fdPath[1], _handler); + }); + else fs.unlink(fdPath[1], _handler); } -function eos(stream, opts, callback) { - if (typeof opts === 'function') return eos(stream, null, opts); - if (!opts) opts = {}; - callback = once(callback || noop); - var readable = opts.readable || opts.readable !== false && stream.readable; - var writable = opts.writable || opts.writable !== false && stream.writable; +/** + * Removes files synchronously. + * + * @param {Object} fdPath + * @private + */ +function _removeFileSync(fdPath) { + let rethrownException = null; + try { + if (0 <= fdPath[0]) fs.closeSync(fdPath[0]); + } catch (e) { + // reraise any unanticipated error + if (!_isEBADF(e) && !_isENOENT(e)) throw e; + } finally { + try { + fs.unlinkSync(fdPath[1]); + } + catch (e) { + // reraise any unanticipated error + if (!_isENOENT(e)) rethrownException = e; + } + } + if (rethrownException !== null) { + throw rethrownException; + } +} - var onlegacyfinish = function onlegacyfinish() { - if (!stream.writable) onfinish(); - }; +/** + * Prepares the callback for removal of the temporary file. + * + * Returns either a sync callback or a async callback depending on whether + * fileSync or file was called, which is expressed by the sync parameter. + * + * @param {string} name the path of the file + * @param {number} fd file descriptor + * @param {Object} opts + * @param {boolean} sync + * @returns {fileCallback | fileCallbackSync} + * @private + */ +function _prepareTmpFileRemoveCallback(name, fd, opts, sync) { + const removeCallbackSync = _prepareRemoveCallback(_removeFileSync, [fd, name], sync); + const removeCallback = _prepareRemoveCallback(_removeFileAsync, [fd, name], sync, removeCallbackSync); - var writableEnded = stream._writableState && stream._writableState.finished; + if (!opts.keep) _removeObjects.unshift(removeCallbackSync); - var onfinish = function onfinish() { - writable = false; - writableEnded = true; - if (!readable) callback.call(stream); - }; + return sync ? removeCallbackSync : removeCallback; +} - var readableEnded = stream._readableState && stream._readableState.endEmitted; +/** + * Prepares the callback for removal of the temporary directory. + * + * Returns either a sync callback or a async callback depending on whether + * tmpFileSync or tmpFile was called, which is expressed by the sync parameter. + * + * @param {string} name + * @param {Object} opts + * @param {boolean} sync + * @returns {Function} the callback + * @private + */ +function _prepareTmpDirRemoveCallback(name, opts, sync) { + const removeFunction = opts.unsafeCleanup ? rimraf : fs.rmdir.bind(fs); + const removeFunctionSync = opts.unsafeCleanup ? FN_RIMRAF_SYNC : FN_RMDIR_SYNC; + const removeCallbackSync = _prepareRemoveCallback(removeFunctionSync, name, sync); + const removeCallback = _prepareRemoveCallback(removeFunction, name, sync, removeCallbackSync); + if (!opts.keep) _removeObjects.unshift(removeCallbackSync); - var onend = function onend() { - readable = false; - readableEnded = true; - if (!writable) callback.call(stream); - }; + return sync ? removeCallbackSync : removeCallback; +} - var onerror = function onerror(err) { - callback.call(stream, err); - }; +/** + * Creates a guarded function wrapping the removeFunction call. + * + * The cleanup callback is save to be called multiple times. + * Subsequent invocations will be ignored. + * + * @param {Function} removeFunction + * @param {string} fileOrDirName + * @param {boolean} sync + * @param {cleanupCallbackSync?} cleanupCallbackSync + * @returns {cleanupCallback | cleanupCallbackSync} + * @private + */ +function _prepareRemoveCallback(removeFunction, fileOrDirName, sync, cleanupCallbackSync) { + let called = false; - var onclose = function onclose() { - var err; + // if sync is true, the next parameter will be ignored + return function _cleanupCallback(next) { - if (readable && !readableEnded) { - if (!stream._readableState || !stream._readableState.ended) err = new ERR_STREAM_PREMATURE_CLOSE(); - return callback.call(stream, err); - } + /* istanbul ignore else */ + if (!called) { + // remove cleanupCallback from cache + const toRemove = cleanupCallbackSync || _cleanupCallback; + const index = _removeObjects.indexOf(toRemove); + /* istanbul ignore else */ + if (index >= 0) _removeObjects.splice(index, 1); - if (writable && !writableEnded) { - if (!stream._writableState || !stream._writableState.ended) err = new ERR_STREAM_PREMATURE_CLOSE(); - return callback.call(stream, err); + called = true; + if (sync || removeFunction === FN_RMDIR_SYNC || removeFunction === FN_RIMRAF_SYNC) { + return removeFunction(fileOrDirName); + } else { + return removeFunction(fileOrDirName, next || function() {}); + } } }; +} - var onrequest = function onrequest() { - stream.req.on('finish', onfinish); - }; +/** + * The garbage collector. + * + * @private + */ +function _garbageCollector() { + /* istanbul ignore else */ + if (!_gracefulCleanup) return; - if (isRequest(stream)) { - stream.on('complete', onfinish); - stream.on('abort', onclose); - if (stream.req) onrequest();else stream.on('request', onrequest); - } else if (writable && !stream._writableState) { - // legacy streams - stream.on('end', onlegacyfinish); - stream.on('close', onlegacyfinish); + // the function being called removes itself from _removeObjects, + // loop until _removeObjects is empty + while (_removeObjects.length) { + try { + _removeObjects[0](); + } catch (e) { + // already removed? + } } - - stream.on('end', onend); - stream.on('finish', onfinish); - if (opts.error !== false) stream.on('error', onerror); - stream.on('close', onclose); - return function () { - stream.removeListener('complete', onfinish); - stream.removeListener('abort', onclose); - stream.removeListener('request', onrequest); - if (stream.req) stream.req.removeListener('finish', onfinish); - stream.removeListener('end', onlegacyfinish); - stream.removeListener('close', onlegacyfinish); - stream.removeListener('finish', onfinish); - stream.removeListener('end', onend); - stream.removeListener('error', onerror); - stream.removeListener('close', onclose); - }; } -module.exports = eos; - -/***/ }), - -/***/ 23919: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { - -"use strict"; - +/** + * Random name generator based on crypto. + * Adapted from http://blog.tompawlak.org/how-to-generate-random-values-nodejs-javascript + * + * @param {number} howMany + * @returns {string} the generated random name + * @private + */ +function _randomChars(howMany) { + let + value = [], + rnd = null; -function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) { try { var info = gen[key](arg); var value = info.value; } catch (error) { reject(error); return; } if (info.done) { resolve(value); } else { Promise.resolve(value).then(_next, _throw); } } + // make sure that we do not fail because we ran out of entropy + try { + rnd = crypto.randomBytes(howMany); + } catch (e) { + rnd = crypto.pseudoRandomBytes(howMany); + } -function _asyncToGenerator(fn) { return function () { var self = this, args = arguments; return new Promise(function (resolve, reject) { var gen = fn.apply(self, args); function _next(value) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, "next", value); } function _throw(err) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, "throw", err); } _next(undefined); }); }; } + for (var i = 0; i < howMany; i++) { + value.push(RANDOM_CHARS[rnd[i] % RANDOM_CHARS.length]); + } -function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; } + return value.join(''); +} -function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; } +/** + * Helper which determines whether a string s is blank, that is undefined, or empty or null. + * + * @private + * @param {string} s + * @returns {Boolean} true whether the string s is blank, false otherwise + */ +function _isBlank(s) { + return s === null || _isUndefined(s) || !s.trim(); +} -function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; } +/** + * Checks whether the `obj` parameter is defined or not. + * + * @param {Object} obj + * @returns {boolean} true if the object is undefined + * @private + */ +function _isUndefined(obj) { + return typeof obj === 'undefined'; +} -var ERR_INVALID_ARG_TYPE = (__nccwpck_require__(91042)/* .codes.ERR_INVALID_ARG_TYPE */ .q.ERR_INVALID_ARG_TYPE); +/** + * Parses the function arguments. + * + * This function helps to have optional arguments. + * + * @param {(Options|null|undefined|Function)} options + * @param {?Function} callback + * @returns {Array} parsed arguments + * @private + */ +function _parseArguments(options, callback) { + /* istanbul ignore else */ + if (typeof options === 'function') { + return [{}, options]; + } -function from(Readable, iterable, opts) { - var iterator; + /* istanbul ignore else */ + if (_isUndefined(options)) { + return [{}, callback]; + } - if (iterable && typeof iterable.next === 'function') { - iterator = iterable; - } else if (iterable && iterable[Symbol.asyncIterator]) iterator = iterable[Symbol.asyncIterator]();else if (iterable && iterable[Symbol.iterator]) iterator = iterable[Symbol.iterator]();else throw new ERR_INVALID_ARG_TYPE('iterable', ['Iterable'], iterable); + // copy options so we do not leak the changes we make internally + const actualOptions = {}; + for (const key of Object.getOwnPropertyNames(options)) { + actualOptions[key] = options[key]; + } - var readable = new Readable(_objectSpread({ - objectMode: true - }, opts)); // Reading boolean to protect against _read - // being called before last iteration completion. + return [actualOptions, callback]; +} - var reading = false; +/** + * Generates a new temporary name. + * + * @param {Object} opts + * @returns {string} the new random name according to opts + * @private + */ +function _generateTmpName(opts) { - readable._read = function () { - if (!reading) { - reading = true; - next(); - } - }; + const tmpDir = opts.tmpdir; - function next() { - return _next2.apply(this, arguments); - } + /* istanbul ignore else */ + if (!_isUndefined(opts.name)) + return path.join(tmpDir, opts.dir, opts.name); - function _next2() { - _next2 = _asyncToGenerator(function* () { - try { - var _ref = yield iterator.next(), - value = _ref.value, - done = _ref.done; + /* istanbul ignore else */ + if (!_isUndefined(opts.template)) + return path.join(tmpDir, opts.dir, opts.template).replace(TEMPLATE_PATTERN, _randomChars(6)); - if (done) { - readable.push(null); - } else if (readable.push((yield value))) { - next(); - } else { - reading = false; - } - } catch (err) { - readable.destroy(err); - } - }); - return _next2.apply(this, arguments); - } + // prefix and postfix + const name = [ + opts.prefix ? opts.prefix : 'tmp', + '-', + process.pid, + '-', + _randomChars(12), + opts.postfix ? '-' + opts.postfix : '' + ].join(''); - return readable; + return path.join(tmpDir, opts.dir, name); } -module.exports = from; +/** + * Asserts whether the specified options are valid, also sanitizes options and provides sane defaults for missing + * options. + * + * @param {Options} options + * @private + */ +function _assertAndSanitizeOptions(options) { -/***/ }), + options.tmpdir = _getTmpDir(options); -/***/ 72928: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + const tmpDir = options.tmpdir; -"use strict"; -// Ported from https://github.com/mafintosh/pump with -// permission from the author, Mathias Buus (@mafintosh). + /* istanbul ignore else */ + if (!_isUndefined(options.name)) + _assertIsRelative(options.name, 'name', tmpDir); + /* istanbul ignore else */ + if (!_isUndefined(options.dir)) + _assertIsRelative(options.dir, 'dir', tmpDir); + /* istanbul ignore else */ + if (!_isUndefined(options.template)) { + _assertIsRelative(options.template, 'template', tmpDir); + if (!options.template.match(TEMPLATE_PATTERN)) + throw new Error(`Invalid template, found "${options.template}".`); + } + /* istanbul ignore else */ + if (!_isUndefined(options.tries) && isNaN(options.tries) || options.tries < 0) + throw new Error(`Invalid tries, found "${options.tries}".`); + // if a name was specified we will try once + options.tries = _isUndefined(options.name) ? options.tries || DEFAULT_TRIES : 1; + options.keep = !!options.keep; + options.detachDescriptor = !!options.detachDescriptor; + options.discardDescriptor = !!options.discardDescriptor; + options.unsafeCleanup = !!options.unsafeCleanup; -var eos; + // sanitize dir, also keep (multiple) blanks if the user, purportedly sane, requests us to + options.dir = _isUndefined(options.dir) ? '' : path.relative(tmpDir, _resolvePath(options.dir, tmpDir)); + options.template = _isUndefined(options.template) ? undefined : path.relative(tmpDir, _resolvePath(options.template, tmpDir)); + // sanitize further if template is relative to options.dir + options.template = _isBlank(options.template) ? undefined : path.relative(options.dir, options.template); -function once(callback) { - var called = false; - return function () { - if (called) return; - called = true; - callback.apply(void 0, arguments); - }; + // for completeness' sake only, also keep (multiple) blanks if the user, purportedly sane, requests us to + options.name = _isUndefined(options.name) ? undefined : _sanitizeName(options.name); + options.prefix = _isUndefined(options.prefix) ? '' : options.prefix; + options.postfix = _isUndefined(options.postfix) ? '' : options.postfix; } -var _require$codes = (__nccwpck_require__(91042)/* .codes */ .q), - ERR_MISSING_ARGS = _require$codes.ERR_MISSING_ARGS, - ERR_STREAM_DESTROYED = _require$codes.ERR_STREAM_DESTROYED; - -function noop(err) { - // Rethrow the error if it exists to avoid swallowing it - if (err) throw err; +/** + * Resolve the specified path name in respect to tmpDir. + * + * The specified name might include relative path components, e.g. ../ + * so we need to resolve in order to be sure that is is located inside tmpDir + * + * @param name + * @param tmpDir + * @returns {string} + * @private + */ +function _resolvePath(name, tmpDir) { + const sanitizedName = _sanitizeName(name); + if (sanitizedName.startsWith(tmpDir)) { + return path.resolve(sanitizedName); + } else { + return path.resolve(path.join(tmpDir, sanitizedName)); + } } -function isRequest(stream) { - return stream.setHeader && typeof stream.abort === 'function'; +/** + * Sanitize the specified path name by removing all quote characters. + * + * @param name + * @returns {string} + * @private + */ +function _sanitizeName(name) { + if (_isBlank(name)) { + return name; + } + return name.replace(/["']/g, ''); } -function destroyer(stream, reading, writing, callback) { - callback = once(callback); - var closed = false; - stream.on('close', function () { - closed = true; - }); - if (eos === undefined) eos = __nccwpck_require__(40841); - eos(stream, { - readable: reading, - writable: writing - }, function (err) { - if (err) return callback(err); - closed = true; - callback(); - }); - var destroyed = false; - return function (err) { - if (closed) return; - if (destroyed) return; - destroyed = true; // request.destroy just do .end - .abort is what we want - - if (isRequest(stream)) return stream.abort(); - if (typeof stream.destroy === 'function') return stream.destroy(); - callback(err || new ERR_STREAM_DESTROYED('pipe')); - }; +/** + * Asserts whether specified name is relative to the specified tmpDir. + * + * @param {string} name + * @param {string} option + * @param {string} tmpDir + * @throws {Error} + * @private + */ +function _assertIsRelative(name, option, tmpDir) { + if (option === 'name') { + // assert that name is not absolute and does not contain a path + if (path.isAbsolute(name)) + throw new Error(`${option} option must not contain an absolute path, found "${name}".`); + // must not fail on valid . or .. or similar such constructs + let basename = path.basename(name); + if (basename === '..' || basename === '.' || basename !== name) + throw new Error(`${option} option must not contain a path, found "${name}".`); + } + else { // if (option === 'dir' || option === 'template') { + // assert that dir or template are relative to tmpDir + if (path.isAbsolute(name) && !name.startsWith(tmpDir)) { + throw new Error(`${option} option must be relative to "${tmpDir}", found "${name}".`); + } + let resolvedPath = _resolvePath(name, tmpDir); + if (!resolvedPath.startsWith(tmpDir)) + throw new Error(`${option} option must be relative to "${tmpDir}", found "${resolvedPath}".`); + } } -function call(fn) { - fn(); +/** + * Helper for testing against EBADF to compensate changes made to Node 7.x under Windows. + * + * @private + */ +function _isEBADF(error) { + return _isExpectedError(error, -EBADF, 'EBADF'); } -function pipe(from, to) { - return from.pipe(to); +/** + * Helper for testing against ENOENT to compensate changes made to Node 7.x under Windows. + * + * @private + */ +function _isENOENT(error) { + return _isExpectedError(error, -ENOENT, 'ENOENT'); } -function popCallback(streams) { - if (!streams.length) return noop; - if (typeof streams[streams.length - 1] !== 'function') return noop; - return streams.pop(); +/** + * Helper to determine whether the expected error code matches the actual code and errno, + * which will differ between the supported node versions. + * + * - Node >= 7.0: + * error.code {string} + * error.errno {number} any numerical value will be negated + * + * CAVEAT + * + * On windows, the errno for EBADF is -4083 but os.constants.errno.EBADF is different and we must assume that ENOENT + * is no different here. + * + * @param {SystemError} error + * @param {number} errno + * @param {string} code + * @private + */ +function _isExpectedError(error, errno, code) { + return IS_WIN32 ? error.code === code : error.code === code && error.errno === errno; } -function pipeline() { - for (var _len = arguments.length, streams = new Array(_len), _key = 0; _key < _len; _key++) { - streams[_key] = arguments[_key]; - } +/** + * Sets the graceful cleanup. + * + * If graceful cleanup is set, tmp will remove all controlled temporary objects on process exit, otherwise the + * temporary objects will remain in place, waiting to be cleaned up on system restart or otherwise scheduled temporary + * object removals. + */ +function setGracefulCleanup() { + _gracefulCleanup = true; +} - var callback = popCallback(streams); - if (Array.isArray(streams[0])) streams = streams[0]; +/** + * Returns the currently configured tmp dir from os.tmpdir(). + * + * @private + * @param {?Options} options + * @returns {string} the currently configured tmp dir + */ +function _getTmpDir(options) { + return path.resolve(_sanitizeName(options && options.tmpdir || os.tmpdir())); +} - if (streams.length < 2) { - throw new ERR_MISSING_ARGS('streams'); - } +// Install process exit listener +process.addListener(EXIT, _garbageCollector); - var error; - var destroys = streams.map(function (stream, i) { - var reading = i < streams.length - 1; - var writing = i > 0; - return destroyer(stream, reading, writing, function (err) { - if (!error) error = err; - if (err) destroys.forEach(call); - if (reading) return; - destroys.forEach(call); - callback(error); - }); - }); - return streams.reduce(pipe); -} +/** + * Configuration options. + * + * @typedef {Object} Options + * @property {?boolean} keep the temporary object (file or dir) will not be garbage collected + * @property {?number} tries the number of tries before give up the name generation + * @property (?int) mode the access mode, defaults are 0o700 for directories and 0o600 for files + * @property {?string} template the "mkstemp" like filename template + * @property {?string} name fixed name relative to tmpdir or the specified dir option + * @property {?string} dir tmp directory relative to the root tmp directory in use + * @property {?string} prefix prefix for the generated name + * @property {?string} postfix postfix for the generated name + * @property {?string} tmpdir the root tmp directory which overrides the os tmpdir + * @property {?boolean} unsafeCleanup recursively removes the created temporary directory, even when it's not empty + * @property {?boolean} detachDescriptor detaches the file descriptor, caller is responsible for closing the file, tmp will no longer try closing the file during garbage collection + * @property {?boolean} discardDescriptor discards the file descriptor (closes file, fd is -1), tmp will no longer try closing the file during garbage collection + */ -module.exports = pipeline; +/** + * @typedef {Object} FileSyncObject + * @property {string} name the name of the file + * @property {string} fd the file descriptor or -1 if the fd has been discarded + * @property {fileCallback} removeCallback the callback function to remove the file + */ -/***/ }), +/** + * @typedef {Object} DirSyncObject + * @property {string} name the name of the directory + * @property {fileCallback} removeCallback the callback function to remove the directory + */ -/***/ 97458: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { +/** + * @callback tmpNameCallback + * @param {?Error} err the error object if anything goes wrong + * @param {string} name the temporary file name + */ -"use strict"; +/** + * @callback fileCallback + * @param {?Error} err the error object if anything goes wrong + * @param {string} name the temporary file name + * @param {number} fd the file descriptor or -1 if the fd had been discarded + * @param {cleanupCallback} fn the cleanup callback function + */ +/** + * @callback fileCallbackSync + * @param {?Error} err the error object if anything goes wrong + * @param {string} name the temporary file name + * @param {number} fd the file descriptor or -1 if the fd had been discarded + * @param {cleanupCallbackSync} fn the cleanup callback function + */ -var ERR_INVALID_OPT_VALUE = (__nccwpck_require__(91042)/* .codes.ERR_INVALID_OPT_VALUE */ .q.ERR_INVALID_OPT_VALUE); +/** + * @callback dirCallback + * @param {?Error} err the error object if anything goes wrong + * @param {string} name the temporary file name + * @param {cleanupCallback} fn the cleanup callback function + */ -function highWaterMarkFrom(options, isDuplex, duplexKey) { - return options.highWaterMark != null ? options.highWaterMark : isDuplex ? options[duplexKey] : null; -} +/** + * @callback dirCallbackSync + * @param {?Error} err the error object if anything goes wrong + * @param {string} name the temporary file name + * @param {cleanupCallbackSync} fn the cleanup callback function + */ -function getHighWaterMark(state, options, duplexKey, isDuplex) { - var hwm = highWaterMarkFrom(options, isDuplex, duplexKey); +/** + * Removes the temporary created file or directory. + * + * @callback cleanupCallback + * @param {simpleCallback} [next] function to call whenever the tmp object needs to be removed + */ - if (hwm != null) { - if (!(isFinite(hwm) && Math.floor(hwm) === hwm) || hwm < 0) { - var name = isDuplex ? duplexKey : 'highWaterMark'; - throw new ERR_INVALID_OPT_VALUE(name, hwm); - } +/** + * Removes the temporary created file or directory. + * + * @callback cleanupCallbackSync + */ - return Math.floor(hwm); - } // Default value +/** + * Callback function for function composition. + * @see {@link https://github.com/raszi/node-tmp/issues/57|raszi/node-tmp#57} + * + * @callback simpleCallback + */ +// exporting all the needed methods - return state.objectMode ? 16 : 16 * 1024; -} +// evaluate _getTmpDir() lazily, mainly for simplifying testing but it also will +// allow users to reconfigure the temporary directory +Object.defineProperty(module.exports, "tmpdir", ({ + enumerable: true, + configurable: false, + get: function () { + return _getTmpDir(); + } +})); -module.exports = { - getHighWaterMark: getHighWaterMark -}; +module.exports.dir = dir; +module.exports.dirSync = dirSync; -/***/ }), +module.exports.file = file; +module.exports.fileSync = fileSync; -/***/ 4297: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { +module.exports.tmpName = tmpName; +module.exports.tmpNameSync = tmpNameSync; -module.exports = __nccwpck_require__(12781); +module.exports.setGracefulCleanup = setGracefulCleanup; /***/ }), -/***/ 88550: -/***/ ((module, exports, __nccwpck_require__) => { +/***/ 19841: +/***/ ((module) => { -var Stream = __nccwpck_require__(12781); -if (process.env.READABLE_STREAM === 'disable' && Stream) { - module.exports = Stream.Readable; - Object.assign(module.exports, Stream); - module.exports.Stream = Stream; -} else { - exports = module.exports = __nccwpck_require__(17911); - exports.Stream = Stream || exports; - exports.Readable = exports; - exports.Writable = __nccwpck_require__(51898); - exports.Duplex = __nccwpck_require__(25408); - exports.Transform = __nccwpck_require__(660); - exports.PassThrough = __nccwpck_require__(37838); - exports.finished = __nccwpck_require__(40841); - exports.pipeline = __nccwpck_require__(72928); -} +// Copied from https://github.com/nodejs/node/blob/master/lib/internal/constants.js +module.exports = { + CHAR_FORWARD_SLASH: 47, /* / */ +}; /***/ }), -/***/ 36873: -/***/ ((module) => { +/***/ 5604: +/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { "use strict"; -function reusify (Constructor) { - var head = new Constructor() - var tail = head - - function get () { - var current = head - - if (current.next) { - head = current.next - } else { - head = new Constructor() - tail = head - } - - current.next = null +const path = __nccwpck_require__(71017); - return current - } +exports.codes = { + ERR_INPUT_TYPE_NOT_ALLOWED: createErrorCtor(joinArgs('ERR_INPUT_TYPE_NOT_ALLOWED')), + ERR_INVALID_ARG_VALUE: createErrorCtor(joinArgs('ERR_INVALID_ARG_VALUE')), + ERR_INVALID_MODULE_SPECIFIER: createErrorCtor(joinArgs('ERR_INVALID_MODULE_SPECIFIER')), + ERR_INVALID_PACKAGE_CONFIG: createErrorCtor(joinArgs('ERR_INVALID_PACKAGE_CONFIG')), + ERR_INVALID_PACKAGE_TARGET: createErrorCtor(joinArgs('ERR_INVALID_PACKAGE_TARGET')), + ERR_MANIFEST_DEPENDENCY_MISSING: createErrorCtor(joinArgs('ERR_MANIFEST_DEPENDENCY_MISSING')), + ERR_MODULE_NOT_FOUND: createErrorCtor((path, base, type = 'package') => { + return `Cannot find ${type} '${path}' imported from ${base}` + }), + ERR_PACKAGE_IMPORT_NOT_DEFINED: createErrorCtor(joinArgs('ERR_PACKAGE_IMPORT_NOT_DEFINED')), + ERR_PACKAGE_PATH_NOT_EXPORTED: createErrorCtor(joinArgs('ERR_PACKAGE_PATH_NOT_EXPORTED')), + ERR_UNSUPPORTED_DIR_IMPORT: createErrorCtor(joinArgs('ERR_UNSUPPORTED_DIR_IMPORT')), + ERR_UNSUPPORTED_ESM_URL_SCHEME: createErrorCtor(joinArgs('ERR_UNSUPPORTED_ESM_URL_SCHEME')), + ERR_UNKNOWN_FILE_EXTENSION: createErrorCtor(joinArgs('ERR_UNKNOWN_FILE_EXTENSION')), +} - function release (obj) { - tail.next = obj - tail = obj +function joinArgs(name) { + return (...args) => { + return [name, ...args].join(' ') } +} - return { - get: get, - release: release +function createErrorCtor(errorMessageCreator) { + return class CustomError extends Error { + constructor(...args) { + super(errorMessageCreator(...args)) + } } } +exports.createErrRequireEsm = createErrRequireEsm; -module.exports = reusify - - -/***/ }), - -/***/ 8414: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { - -const assert = __nccwpck_require__(39491) -const path = __nccwpck_require__(71017) -const fs = __nccwpck_require__(57147) -let glob = undefined -try { - glob = __nccwpck_require__(20557) -} catch (_err) { - // treat glob as optional. +// Native ERR_REQUIRE_ESM Error is declared here: +// https://github.com/nodejs/node/blob/2d5d77306f6dff9110c1f77fefab25f973415770/lib/internal/errors.js#L1294-L1313 +// Error class factory is implemented here: +// function E: https://github.com/nodejs/node/blob/2d5d77306f6dff9110c1f77fefab25f973415770/lib/internal/errors.js#L323-L341 +// function makeNodeErrorWithCode: https://github.com/nodejs/node/blob/2d5d77306f6dff9110c1f77fefab25f973415770/lib/internal/errors.js#L251-L278 +// The code below should create an error that matches the native error as closely as possible. +// Third-party libraries which attempt to catch the native ERR_REQUIRE_ESM should recognize our imitation error. +function createErrRequireEsm(filename, parentPath, packageJsonPath) { + const code = 'ERR_REQUIRE_ESM' + const err = new Error(getErrRequireEsmMessage(filename, parentPath, packageJsonPath)) + // Set `name` to be used in stack trace, generate stack trace with that name baked in, then re-declare the `name` field. + // This trick is copied from node's source. + err.name = `Error [${ code }]` + err.stack + Object.defineProperty(err, 'name', { + value: 'Error', + enumerable: false, + writable: true, + configurable: true + }) + err.code = code + return err } -const defaultGlobOpts = { - nosort: true, - silent: true +// Copy-pasted from https://github.com/nodejs/node/blob/b533fb3508009e5f567cc776daba8fbf665386a6/lib/internal/errors.js#L1293-L1311 +// so that our error message is identical to the native message. +function getErrRequireEsmMessage(filename, parentPath = null, packageJsonPath = null) { + const ext = path.extname(filename) + let msg = `Must use import to load ES Module: ${filename}`; + if (parentPath && packageJsonPath) { + const path = __nccwpck_require__(71017); + const basename = path.basename(filename) === path.basename(parentPath) ? + filename : path.basename(filename); + msg += + '\nrequire() of ES modules is not supported.\nrequire() of ' + + `${filename} ${parentPath ? `from ${parentPath} ` : ''}` + + `is an ES module file as it is a ${ext} file whose nearest parent ` + + `package.json contains "type": "module" which defines all ${ext} ` + + 'files in that package scope as ES modules.\nInstead ' + + 'change the requiring code to use ' + + 'import(), or remove "type": "module" from ' + + `${packageJsonPath}.\n`; + return msg; + } + return msg; } -// for EMFILE handling -let timeout = 0 -const isWindows = (process.platform === "win32") +/***/ }), -const defaults = options => { - const methods = [ - 'unlink', - 'chmod', - 'stat', - 'lstat', - 'rmdir', - 'readdir' - ] - methods.forEach(m => { - options[m] = options[m] || fs[m] - m = m + 'Sync' - options[m] = options[m] || fs[m] - }) +/***/ 2076: +/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { - options.maxBusyTries = options.maxBusyTries || 3 - options.emfileWait = options.emfileWait || 1000 - if (options.glob === false) { - options.disableGlob = true - } - if (options.disableGlob !== true && glob === undefined) { - throw Error('glob dependency not found, set `options.disableGlob = true` if intentional') - } - options.disableGlob = options.disableGlob || false - options.glob = options.glob || defaultGlobOpts -} +"use strict"; +// Copied from https://github.com/nodejs/node/blob/v17.0.1/lib/internal/modules/cjs/helpers.js -const rimraf = (p, options, cb) => { - if (typeof options === 'function') { - cb = options - options = {} - } - assert(p, 'rimraf: missing path') - assert.equal(typeof p, 'string', 'rimraf: path should be a string') - assert.equal(typeof cb, 'function', 'rimraf: callback function required') - assert(options, 'rimraf: invalid options argument provided') - assert.equal(typeof options, 'object', 'rimraf: options should be object') - defaults(options) +const { + ArrayPrototypeForEach, + ObjectDefineProperty, + ObjectPrototypeHasOwnProperty, + SafeSet, + StringPrototypeIncludes, + StringPrototypeStartsWith, +} = __nccwpck_require__(57523); - let busyTries = 0 - let errState = null - let n = 0 +const { getOptionValue } = __nccwpck_require__(92060); +const userConditions = getOptionValue('--conditions'); - const next = (er) => { - errState = errState || er - if (--n === 0) - cb(errState) - } +const noAddons = getOptionValue('--no-addons'); +const addonConditions = noAddons ? [] : ['node-addons']; - const afterGlob = (er, results) => { - if (er) - return cb(er) +// TODO: Use this set when resolving pkg#exports conditions in loader.js. +const cjsConditions = new SafeSet([ + 'require', + 'node', + ...addonConditions, + ...userConditions, +]); - n = results.length - if (n === 0) - return cb() +/** + * @param {any} object + * @param {string} [dummyModuleName] + * @return {void} + */ +function addBuiltinLibsToObject(object, dummyModuleName) { + // Make built-in modules available directly (loaded lazily). + const Module = (__nccwpck_require__(98188).Module); + const { builtinModules } = Module; - results.forEach(p => { - const CB = (er) => { - if (er) { - if ((er.code === "EBUSY" || er.code === "ENOTEMPTY" || er.code === "EPERM") && - busyTries < options.maxBusyTries) { - busyTries ++ - // try again, with the same exact callback as this one. - return setTimeout(() => rimraf_(p, options, CB), busyTries * 100) - } + // To require built-in modules in user-land and ignore modules whose + // `canBeRequiredByUsers` is false. So we create a dummy module object and not + // use `require()` directly. + const dummyModule = new Module(dummyModuleName); - // this one won't happen if graceful-fs is used. - if (er.code === "EMFILE" && timeout < options.emfileWait) { - return setTimeout(() => rimraf_(p, options, CB), timeout ++) - } + ArrayPrototypeForEach(builtinModules, (name) => { + // Neither add underscored modules, nor ones that contain slashes (e.g., + // 'fs/promises') or ones that are already defined. + if (StringPrototypeStartsWith(name, '_') || + StringPrototypeIncludes(name, '/') || + ObjectPrototypeHasOwnProperty(object, name)) { + return; + } + // Goals of this mechanism are: + // - Lazy loading of built-in modules + // - Having all built-in modules available as non-enumerable properties + // - Allowing the user to re-assign these variables as if there were no + // pre-existing globals with the same name. - // already gone - if (er.code === "ENOENT") er = null - } + const setReal = (val) => { + // Deleting the property before re-assigning it disables the + // getter/setter mechanism. + delete object[name]; + object[name] = val; + }; - timeout = 0 - next(er) - } - rimraf_(p, options, CB) - }) - } + ObjectDefineProperty(object, name, { + get: () => { + // Node 12 hack; remove when we drop node12 support + const lib = (dummyModule.require || require)(name); - if (options.disableGlob || !glob.hasMagic(p)) - return afterGlob(null, [p]) + // Disable the current getter/setter and set up a new + // non-enumerable property. + delete object[name]; + ObjectDefineProperty(object, name, { + get: () => lib, + set: setReal, + configurable: true, + enumerable: false + }); - options.lstat(p, (er, stat) => { - if (!er) - return afterGlob(null, [p]) + return lib; + }, + set: setReal, + configurable: true, + enumerable: false + }); + }); +} - glob(p, options.glob, afterGlob) - }) +exports.addBuiltinLibsToObject = addBuiltinLibsToObject; +exports.cjsConditions = cjsConditions; -} -// Two possible strategies. -// 1. Assume it's a file. unlink it, then do the dir stuff on EPERM or EISDIR -// 2. Assume it's a directory. readdir, then do the file stuff on ENOTDIR -// -// Both result in an extra syscall when you guess wrong. However, there -// are likely far more normal files in the world than directories. This -// is based on the assumption that a the average number of files per -// directory is >= 1. -// -// If anyone ever complains about this, then I guess the strategy could -// be made configurable somehow. But until then, YAGNI. -const rimraf_ = (p, options, cb) => { - assert(p) - assert(options) - assert(typeof cb === 'function') +/***/ }), - // sunos lets the root user unlink directories, which is... weird. - // so we have to lstat here and make sure it's not a dir. - options.lstat(p, (er, st) => { - if (er && er.code === "ENOENT") - return cb(null) +/***/ 88232: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { - // Windows can EPERM on stat. Life is suffering. - if (er && er.code === "EPERM" && isWindows) - fixWinEPERM(p, options, er, cb) +"use strict"; +// Copied from several files in node's source code. +// https://github.com/nodejs/node/blob/2d5d77306f6dff9110c1f77fefab25f973415770/lib/internal/modules/cjs/loader.js +// Each function and variable below must have a comment linking to the source in node's github repo. - if (st && st.isDirectory()) - return rmdir(p, options, er, cb) - options.unlink(p, er => { - if (er) { - if (er.code === "ENOENT") - return cb(null) - if (er.code === "EPERM") - return (isWindows) - ? fixWinEPERM(p, options, er, cb) - : rmdir(p, options, er, cb) - if (er.code === "EISDIR") - return rmdir(p, options, er, cb) - } - return cb(er) - }) - }) -} -const fixWinEPERM = (p, options, er, cb) => { - assert(p) - assert(options) - assert(typeof cb === 'function') +const { + ArrayIsArray, + ArrayPrototypeIncludes, + ArrayPrototypeJoin, + ArrayPrototypePush, + JSONParse, + ObjectKeys, + RegExpPrototypeTest, + SafeMap, + SafeWeakMap, + StringPrototypeCharCodeAt, + StringPrototypeEndsWith, + StringPrototypeLastIndexOf, + StringPrototypeIndexOf, + StringPrototypeMatch, + StringPrototypeSlice, + StringPrototypeStartsWith, +} = __nccwpck_require__(57523); +const { NativeModule } = __nccwpck_require__(12061); +const { pathToFileURL, fileURLToPath } = __nccwpck_require__(57310); +const fs = __nccwpck_require__(57147); +const path = __nccwpck_require__(71017); +const { sep } = path; +const { internalModuleStat } = __nccwpck_require__(69149); +const packageJsonReader = __nccwpck_require__(73104); +const { + cjsConditions, +} = __nccwpck_require__(2076); +const { getOptionValue } = __nccwpck_require__(92060); +const preserveSymlinks = getOptionValue('--preserve-symlinks'); +const preserveSymlinksMain = getOptionValue('--preserve-symlinks-main'); +const {normalizeSlashes} = __nccwpck_require__(26239); +const {createErrRequireEsm} = __nccwpck_require__(5604); +const { + codes: { + ERR_INVALID_MODULE_SPECIFIER, + }, +} = __nccwpck_require__(5604); - options.chmod(p, 0o666, er2 => { - if (er2) - cb(er2.code === "ENOENT" ? null : er) - else - options.stat(p, (er3, stats) => { - if (er3) - cb(er3.code === "ENOENT" ? null : er) - else if (stats.isDirectory()) - rmdir(p, options, er, cb) - else - options.unlink(p, cb) - }) - }) +const { + CHAR_FORWARD_SLASH, +} = __nccwpck_require__(19841); + +const Module = __nccwpck_require__(98188); + +const isWindows = process.platform === 'win32'; + +let statCache = null; + +function stat(filename) { + filename = path.toNamespacedPath(filename); + if (statCache !== null) { + const result = statCache.get(filename); + if (result !== undefined) return result; + } + const result = internalModuleStat(filename); + if (statCache !== null && result >= 0) { + // Only set cache when `internalModuleStat(filename)` succeeds. + statCache.set(filename, result); + } + return result; } -const fixWinEPERMSync = (p, options, er) => { - assert(p) - assert(options) +// Note: +// we cannot get access to node's internal cache, which is populated from +// within node's Module constructor. So the cache here will always be empty. +// It's possible we could approximate our own cache by building it up with +// hacky workarounds, but it's not worth the complexity and flakiness. +const moduleParentCache = new SafeWeakMap(); - try { - options.chmodSync(p, 0o666) - } catch (er2) { - if (er2.code === "ENOENT") - return - else - throw er +// Given a module name, and a list of paths to test, returns the first +// matching file in the following precedence. +// +// require("a.") +// -> a. +// +// require("a") +// -> a +// -> a. +// -> a/index. + +const packageJsonCache = new SafeMap(); + +function readPackage(requestPath) { + const jsonPath = path.resolve(requestPath, 'package.json'); + + const existing = packageJsonCache.get(jsonPath); + if (existing !== undefined) return existing; + + const result = packageJsonReader.read(jsonPath); + const json = result.containsKeys === false ? '{}' : result.string; + if (json === undefined) { + packageJsonCache.set(jsonPath, false); + return false; } - let stats try { - stats = options.statSync(p) - } catch (er3) { - if (er3.code === "ENOENT") - return - else - throw er + const parsed = JSONParse(json); + const filtered = { + name: parsed.name, + main: parsed.main, + exports: parsed.exports, + imports: parsed.imports, + type: parsed.type + }; + packageJsonCache.set(jsonPath, filtered); + return filtered; + } catch (e) { + e.path = jsonPath; + e.message = 'Error parsing ' + jsonPath + ': ' + e.message; + throw e; } +} - if (stats.isDirectory()) - rmdirSync(p, options, er) - else - options.unlinkSync(p) +function readPackageScope(checkPath) { + const rootSeparatorIndex = StringPrototypeIndexOf(checkPath, sep); + let separatorIndex; + do { + separatorIndex = StringPrototypeLastIndexOf(checkPath, sep); + checkPath = StringPrototypeSlice(checkPath, 0, separatorIndex); + if (StringPrototypeEndsWith(checkPath, sep + 'node_modules')) + return false; + const pjson = readPackage(checkPath + sep); + if (pjson) return { + data: pjson, + path: checkPath, + }; + } while (separatorIndex > rootSeparatorIndex); + return false; } -const rmdir = (p, options, originalEr, cb) => { - assert(p) - assert(options) - assert(typeof cb === 'function') +/** + * @param {{ + * nodeEsmResolver: ReturnType, + * extensions: import('../src/file-extensions').Extensions, + * preferTsExts + * }} opts + */ +function createCjsLoader(opts) { +const {nodeEsmResolver, preferTsExts} = opts; +const {replacementsForCjs, replacementsForJs, replacementsForMjs, replacementsForJsx} = opts.extensions; +const { + encodedSepRegEx, + packageExportsResolve, + packageImportsResolve +} = nodeEsmResolver; - // try to rmdir first, and only readdir on ENOTEMPTY or EEXIST (SunOS) - // if we guessed wrong, and it's not a directory, then - // raise the original error. - options.rmdir(p, er => { - if (er && (er.code === "ENOTEMPTY" || er.code === "EEXIST" || er.code === "EPERM")) - rmkids(p, options, cb) - else if (er && er.code === "ENOTDIR") - cb(originalEr) - else - cb(er) - }) -} +function tryPackage(requestPath, exts, isMain, originalPath) { + // const pkg = readPackage(requestPath)?.main; + const tmp = readPackage(requestPath) + const pkg = tmp != null ? tmp.main : undefined; -const rmkids = (p, options, cb) => { - assert(p) - assert(options) - assert(typeof cb === 'function') + if (!pkg) { + return tryExtensions(path.resolve(requestPath, 'index'), exts, isMain); + } - options.readdir(p, (er, files) => { - if (er) - return cb(er) - let n = files.length - if (n === 0) - return options.rmdir(p, cb) - let errState - files.forEach(f => { - rimraf(path.join(p, f), options, er => { - if (errState) - return - if (er) - return cb(errState = er) - if (--n === 0) - options.rmdir(p, cb) - }) - }) - }) + const filename = path.resolve(requestPath, pkg); + let actual = tryReplacementExtensions(filename, isMain) || + tryFile(filename, isMain) || + tryExtensions(filename, exts, isMain) || + tryExtensions(path.resolve(filename, 'index'), exts, isMain); + if (actual === false) { + actual = tryExtensions(path.resolve(requestPath, 'index'), exts, isMain); + if (!actual) { + // eslint-disable-next-line no-restricted-syntax + const err = new Error( + `Cannot find module '${filename}'. ` + + 'Please verify that the package.json has a valid "main" entry' + ); + err.code = 'MODULE_NOT_FOUND'; + err.path = path.resolve(requestPath, 'package.json'); + err.requestPath = originalPath; + // TODO(BridgeAR): Add the requireStack as well. + throw err; + } else { + const jsonPath = path.resolve(requestPath, 'package.json'); + process.emitWarning( + `Invalid 'main' field in '${jsonPath}' of '${pkg}'. ` + + 'Please either fix that or report it to the module author', + 'DeprecationWarning', + 'DEP0128' + ); + } + } + return actual; } -// this looks simpler, and is strictly *faster*, but will -// tie up the JavaScript thread and fail on excessively -// deep directory trees. -const rimrafSync = (p, options) => { - options = options || {} - defaults(options) +// In order to minimize unnecessary lstat() calls, +// this cache is a list of known-real paths. +// Set to an empty Map to reset. +const realpathCache = new SafeMap(); - assert(p, 'rimraf: missing path') - assert.equal(typeof p, 'string', 'rimraf: path should be a string') - assert(options, 'rimraf: missing options') - assert.equal(typeof options, 'object', 'rimraf: options should be object') +// Check if the file exists and is not a directory +// if using --preserve-symlinks and isMain is false, +// keep symlinks intact, otherwise resolve to the +// absolute realpath. +function tryFile(requestPath, isMain) { + const rc = stat(requestPath); + if (rc !== 0) return; + if (preserveSymlinks && !isMain) { + return path.resolve(requestPath); + } + return toRealPath(requestPath); +} - let results +function toRealPath(requestPath) { + return fs.realpathSync(requestPath, { + // [internalFS.realpathCacheKey]: realpathCache + }); +} - if (options.disableGlob || !glob.hasMagic(p)) { - results = [p] - } else { - try { - options.lstatSync(p) - results = [p] - } catch (er) { - results = glob.sync(p, options.glob) +function statReplacementExtensions(p) { + const lastDotIndex = p.lastIndexOf('.'); + if(lastDotIndex >= 0) { + const ext = p.slice(lastDotIndex); + if (ext === '.js' || ext === '.jsx' || ext === '.mjs' || ext === '.cjs') { + const pathnameWithoutExtension = p.slice(0, lastDotIndex); + const replacementExts = + ext === '.js' ? replacementsForJs + : ext === '.jsx' ? replacementsForJsx + : ext === '.mjs' ? replacementsForMjs + : replacementsForCjs; + for (let i = 0; i < replacementExts.length; i++) { + const filename = pathnameWithoutExtension + replacementExts[i]; + const rc = stat(filename); + if (rc === 0) { + return [rc, filename]; + } + } } } + return [stat(p), p]; +} +function tryReplacementExtensions(p, isMain) { + const lastDotIndex = p.lastIndexOf('.'); + if(lastDotIndex >= 0) { + const ext = p.slice(lastDotIndex); + if (ext === '.js' || ext === '.jsx' || ext === '.mjs' || ext === '.cjs') { + const pathnameWithoutExtension = p.slice(0, lastDotIndex); + const replacementExts = + ext === '.js' ? replacementsForJs + : ext === '.jsx' ? replacementsForJsx + : ext === '.mjs' ? replacementsForMjs + : replacementsForCjs; + for (let i = 0; i < replacementExts.length; i++) { + const filename = tryFile(pathnameWithoutExtension + replacementExts[i], isMain); + if (filename) { + return filename; + } + } + } + } + return false; +} - if (!results.length) - return - - for (let i = 0; i < results.length; i++) { - const p = results[i] - - let st - try { - st = options.lstatSync(p) - } catch (er) { - if (er.code === "ENOENT") - return +// Given a path, check if the file exists with any of the set extensions +function tryExtensions(p, exts, isMain) { + for (let i = 0; i < exts.length; i++) { + const filename = tryFile(p + exts[i], isMain); - // Windows can EPERM on stat. Life is suffering. - if (er.code === "EPERM" && isWindows) - fixWinEPERMSync(p, options, er) + if (filename) { + return filename; } + } + return false; +} - try { - // sunos lets the root user unlink directories, which is... weird. - if (st && st.isDirectory()) - rmdirSync(p, options, null) - else - options.unlinkSync(p) - } catch (er) { - if (er.code === "ENOENT") - return - if (er.code === "EPERM") - return isWindows ? fixWinEPERMSync(p, options, er) : rmdirSync(p, options, er) - if (er.code !== "EISDIR") - throw er +function trySelfParentPath(parent) { + if (!parent) return false; - rmdirSync(p, options, er) + if (parent.filename) { + return parent.filename; + } else if (parent.id === '' || parent.id === 'internal/preload') { + try { + return process.cwd() + path.sep; + } catch { + return false; } } } -const rmdirSync = (p, options, originalEr) => { - assert(p) - assert(options) +function trySelf(parentPath, request) { + if (!parentPath) return false; + + const { data: pkg, path: pkgPath } = readPackageScope(parentPath) || {}; + if (!pkg || pkg.exports === undefined) return false; + if (typeof pkg.name !== 'string') return false; + + let expansion; + if (request === pkg.name) { + expansion = '.'; + } else if (StringPrototypeStartsWith(request, `${pkg.name}/`)) { + expansion = '.' + StringPrototypeSlice(request, pkg.name.length); + } else { + return false; + } try { - options.rmdirSync(p) - } catch (er) { - if (er.code === "ENOENT") - return - if (er.code === "ENOTDIR") - throw originalEr - if (er.code === "ENOTEMPTY" || er.code === "EEXIST" || er.code === "EPERM") - rmkidsSync(p, options) + return finalizeEsmResolution(packageExportsResolve( + pathToFileURL(pkgPath + '/package.json'), expansion, pkg, + pathToFileURL(parentPath), cjsConditions).resolved, parentPath, pkgPath); + } catch (e) { + if (e.code === 'ERR_MODULE_NOT_FOUND') + throw createEsmNotFoundErr(request, pkgPath + '/package.json'); + throw e; } } -const rmkidsSync = (p, options) => { - assert(p) - assert(options) - options.readdirSync(p).forEach(f => rimrafSync(path.join(p, f), options)) - - // We only end up here once we got ENOTEMPTY at least once, and - // at this point, we are guaranteed to have removed all the kids. - // So, we know that it won't be ENOENT or ENOTDIR or anything else. - // try really hard to delete stuff on windows, because it has a - // PROFOUNDLY annoying habit of not closing handles promptly when - // files are deleted, resulting in spurious ENOTEMPTY errors. - const retries = isWindows ? 100 : 1 - let i = 0 - do { - let threw = true +// This only applies to requests of a specific form: +// 1. name/.* +// 2. @scope/name/.* +const EXPORTS_PATTERN = /^((?:@[^/\\%]+\/)?[^./\\%][^/\\%]*)(\/.*)?$/; +function resolveExports(nmPath, request) { + // The implementation's behavior is meant to mirror resolution in ESM. + const { 1: name, 2: expansion = '' } = + StringPrototypeMatch(request, EXPORTS_PATTERN) || []; + if (!name) + return; + const pkgPath = path.resolve(nmPath, name); + const pkg = readPackage(pkgPath); + // if (pkg?.exports != null) { + if (pkg != null && pkg.exports != null) { try { - const ret = options.rmdirSync(p, options) - threw = false - return ret - } finally { - if (++i < retries && threw) - continue + return finalizeEsmResolution(packageExportsResolve( + pathToFileURL(pkgPath + '/package.json'), '.' + expansion, pkg, null, + cjsConditions).resolved, null, pkgPath); + } catch (e) { + if (e.code === 'ERR_MODULE_NOT_FOUND') + throw createEsmNotFoundErr(request, pkgPath + '/package.json'); + throw e; } - } while (true) + } } -module.exports = rimraf -rimraf.sync = rimrafSync +// Backwards compat for old node versions +const hasModulePathCache = !!(__nccwpck_require__(98188)._pathCache); +const Module_pathCache = Object.create(null); +const Module_pathCache_get = hasModulePathCache ? (cacheKey) => Module._pathCache[cacheKey] : (cacheKey) => Module_pathCache[cacheKey]; +const Module_pathCache_set = hasModulePathCache ? (cacheKey, value) => (Module._pathCache[cacheKey] = value) : (cacheKey) => (Module_pathCache[cacheKey] = value); +const trailingSlashRegex = /(?:^|\/)\.?\.$/; +const Module_findPath = function _findPath(request, paths, isMain) { + const absoluteRequest = path.isAbsolute(request); + if (absoluteRequest) { + paths = ['']; + } else if (!paths || paths.length === 0) { + return false; + } -/***/ }), + const cacheKey = request + '\x00' + ArrayPrototypeJoin(paths, '\x00'); + const entry = Module_pathCache_get(cacheKey); + if (entry) + return entry; -/***/ 87851: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + let exts; + let trailingSlash = request.length > 0 && + StringPrototypeCharCodeAt(request, request.length - 1) === + CHAR_FORWARD_SLASH; + if (!trailingSlash) { + trailingSlash = RegExpPrototypeTest(trailingSlashRegex, request); + } -/*! run-parallel. MIT License. Feross Aboukhadijeh */ -module.exports = runParallel + // For each path + for (let i = 0; i < paths.length; i++) { + // Don't search further if path doesn't exist + const curPath = paths[i]; + if (curPath && stat(curPath) < 1) continue; -const queueMicrotask = __nccwpck_require__(98431) + if (!absoluteRequest) { + const exportsResolved = resolveExports(curPath, request); + if (exportsResolved) + return exportsResolved; + } -function runParallel (tasks, cb) { - let results, pending, keys - let isSync = true + const _basePath = path.resolve(curPath, request); + let filename; - if (Array.isArray(tasks)) { - results = [] - pending = tasks.length - } else { - keys = Object.keys(tasks) - results = {} - pending = keys.length - } + const [rc, basePath] = statReplacementExtensions(_basePath); + if (!trailingSlash) { + if (rc === 0) { // File. + if (!isMain) { + if (preserveSymlinks) { + filename = path.resolve(basePath); + } else { + filename = toRealPath(basePath); + } + } else if (preserveSymlinksMain) { + // For the main module, we use the preserveSymlinksMain flag instead + // mainly for backward compatibility, as the preserveSymlinks flag + // historically has not applied to the main module. Most likely this + // was intended to keep .bin/ binaries working, as following those + // symlinks is usually required for the imports in the corresponding + // files to resolve; that said, in some use cases following symlinks + // causes bigger problems which is why the preserveSymlinksMain option + // is needed. + filename = path.resolve(basePath); + } else { + filename = toRealPath(basePath); + } + } - function done (err) { - function end () { - if (cb) cb(err, results) - cb = null + if (!filename) { + // Try it with each of the extensions + if (exts === undefined) + exts = ObjectKeys(Module._extensions); + filename = tryExtensions(basePath, exts, isMain); + } } - if (isSync) queueMicrotask(end) - else end() - } - function each (i, err, result) { - results[i] = result - if (--pending === 0 || err) { - done(err) + if (!filename && rc === 1) { // Directory. + // try it with each of the extensions at "index" + if (exts === undefined) + exts = ObjectKeys(Module._extensions); + filename = tryPackage(basePath, exts, isMain, request); + } + + if (filename) { + Module_pathCache_set(cacheKey, filename); + return filename; } } - if (!pending) { - // empty - done(null) - } else if (keys) { - // object - keys.forEach(function (key) { - tasks[key](function (err, result) { each(key, err, result) }) - }) - } else { - // array - tasks.forEach(function (task, i) { - task(function (err, result) { each(i, err, result) }) - }) + return false; +}; + +const Module_resolveFilename = function _resolveFilename(request, parent, isMain, options) { + if (StringPrototypeStartsWith(request, 'node:') || + NativeModule.canBeRequiredByUsers(request)) { + return request; } - isSync = false -} + let paths; + if (typeof options === 'object' && options !== null) { + if (ArrayIsArray(options.paths)) { + const isRelative = StringPrototypeStartsWith(request, './') || + StringPrototypeStartsWith(request, '../') || + ((isWindows && StringPrototypeStartsWith(request, '.\\')) || + StringPrototypeStartsWith(request, '..\\')); -/***/ }), + if (isRelative) { + paths = options.paths; + } else { + const fakeParent = new Module('', null); -/***/ 87128: -/***/ ((module, exports, __nccwpck_require__) => { + paths = []; -/*! safe-buffer. MIT License. Feross Aboukhadijeh */ -/* eslint-disable node/no-deprecated-api */ -var buffer = __nccwpck_require__(14300) -var Buffer = buffer.Buffer + for (let i = 0; i < options.paths.length; i++) { + const path = options.paths[i]; + fakeParent.paths = Module._nodeModulePaths(path); + const lookupPaths = Module._resolveLookupPaths(request, fakeParent); -// alternative to using Object.keys for old browsers -function copyProps (src, dst) { - for (var key in src) { - dst[key] = src[key] + for (let j = 0; j < lookupPaths.length; j++) { + if (!ArrayPrototypeIncludes(paths, lookupPaths[j])) + ArrayPrototypePush(paths, lookupPaths[j]); + } + } + } + } else if (options.paths === undefined) { + paths = Module._resolveLookupPaths(request, parent); + } else { + throw new ERR_INVALID_ARG_VALUE('options.paths', options.paths); + } + } else { + paths = Module._resolveLookupPaths(request, parent); } -} -if (Buffer.from && Buffer.alloc && Buffer.allocUnsafe && Buffer.allocUnsafeSlow) { - module.exports = buffer -} else { - // Copy properties from require('buffer') - copyProps(buffer, exports) - exports.Buffer = SafeBuffer -} - -function SafeBuffer (arg, encodingOrOffset, length) { - return Buffer(arg, encodingOrOffset, length) -} -SafeBuffer.prototype = Object.create(Buffer.prototype) + // if (parent?.filename) { + // node 12 hack + if (parent != null && parent.filename) { + if (request[0] === '#') { + const pkg = readPackageScope(parent.filename) || {}; -// Copy static methods from Buffer -copyProps(Buffer, SafeBuffer) + // if (pkg.data?.imports != null) { + // node 12 hack + if (pkg.data != null && pkg.data.imports != null) { + try { + return finalizeEsmResolution( + packageImportsResolve(request, pathToFileURL(parent.filename), + cjsConditions), parent.filename, + pkg.path); + } catch (e) { + if (e.code === 'ERR_MODULE_NOT_FOUND') + throw createEsmNotFoundErr(request); + throw e; + } + } + } + } -SafeBuffer.from = function (arg, encodingOrOffset, length) { - if (typeof arg === 'number') { - throw new TypeError('Argument must not be a number') + // Try module self resolution first + const parentPath = trySelfParentPath(parent); + const selfResolved = trySelf(parentPath, request); + if (selfResolved) { + const cacheKey = request + '\x00' + + (paths.length === 1 ? paths[0] : ArrayPrototypeJoin(paths, '\x00')); + Module._pathCache[cacheKey] = selfResolved; + return selfResolved; } - return Buffer(arg, encodingOrOffset, length) -} -SafeBuffer.alloc = function (size, fill, encoding) { - if (typeof size !== 'number') { - throw new TypeError('Argument must be a number') + // Look up the filename first, since that's the cache key. + const filename = Module._findPath(request, paths, isMain, false); + if (filename) return filename; + const requireStack = []; + for (let cursor = parent; + cursor; + cursor = moduleParentCache.get(cursor)) { + ArrayPrototypePush(requireStack, cursor.filename || cursor.id); } - var buf = Buffer(size) - if (fill !== undefined) { - if (typeof encoding === 'string') { - buf.fill(fill, encoding) - } else { - buf.fill(fill) - } - } else { - buf.fill(0) + let message = `Cannot find module '${request}'`; + if (requireStack.length > 0) { + message = message + '\nRequire stack:\n- ' + + ArrayPrototypeJoin(requireStack, '\n- '); } - return buf -} + // eslint-disable-next-line no-restricted-syntax + const err = new Error(message); + err.code = 'MODULE_NOT_FOUND'; + err.requireStack = requireStack; + throw err; +}; -SafeBuffer.allocUnsafe = function (size) { - if (typeof size !== 'number') { - throw new TypeError('Argument must be a number') - } - return Buffer(size) +function finalizeEsmResolution(resolved, parentPath, pkgPath) { + if (RegExpPrototypeTest(encodedSepRegEx, resolved)) + throw new ERR_INVALID_MODULE_SPECIFIER( + resolved, 'must not include encoded "/" or "\\" characters', parentPath); + const filename = fileURLToPath(resolved); + const actual = tryReplacementExtensions(filename) || tryFile(filename); + if (actual) + return actual; + const err = createEsmNotFoundErr(filename, + path.resolve(pkgPath, 'package.json')); + throw err; } -SafeBuffer.allocUnsafeSlow = function (size) { - if (typeof size !== 'number') { - throw new TypeError('Argument must be a number') - } - return buffer.SlowBuffer(size) +function createEsmNotFoundErr(request, path) { + // eslint-disable-next-line no-restricted-syntax + const err = new Error(`Cannot find module '${request}'`); + err.code = 'MODULE_NOT_FOUND'; + if (path) + err.path = path; + // TODO(BridgeAR): Add the requireStack as well. + return err; } -/***/ }), +return { + Module_findPath, + Module_resolveFilename +} -/***/ 37270: -/***/ ((module) => { +} -module.exports = [ - 'cat', - 'cd', - 'chmod', - 'cp', - 'dirs', - 'echo', - 'exec', - 'find', - 'grep', - 'head', - 'ln', - 'ls', - 'mkdir', - 'mv', - 'pwd', - 'rm', - 'sed', - 'set', - 'sort', - 'tail', - 'tempdir', - 'test', - 'to', - 'toEnd', - 'touch', - 'uniq', - 'which', -]; +/** + * copied from Module._extensions['.js'] + * https://github.com/nodejs/node/blob/v15.3.0/lib/internal/modules/cjs/loader.js#L1113-L1120 + * @param {import('../src/index').Service} service + * @param {NodeJS.Module} module + * @param {string} filename + */ +function assertScriptCanLoadAsCJSImpl(service, module, filename) { + const pkg = readPackageScope(filename); + // ts-node modification: allow our configuration to override + const tsNodeClassification = service.moduleTypeClassifier.classifyModuleByModuleTypeOverrides(normalizeSlashes(filename)); + if(tsNodeClassification.moduleType === 'cjs') return; -/***/ }), + // ignore package.json when file extension is ESM-only or CJS-only + // [MUST_UPDATE_FOR_NEW_FILE_EXTENSIONS] + const lastDotIndex = filename.lastIndexOf('.'); + const ext = lastDotIndex >= 0 ? filename.slice(lastDotIndex) : ''; -/***/ 54572: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { + if((ext === '.cts' || ext === '.cjs') && tsNodeClassification.moduleType === 'auto') return; -// -// ShellJS -// Unix shell commands on top of Node's API -// -// Copyright (c) 2012 Artur Adib -// http://github.com/shelljs/shelljs -// + // Function require shouldn't be used in ES modules. + if (ext === '.mts' || ext === '.mjs' || tsNodeClassification.moduleType === 'esm' || (pkg && pkg.data && pkg.data.type === 'module')) { + const parentPath = module.parent && module.parent.filename; + const packageJsonPath = pkg ? path.resolve(pkg.path, 'package.json') : null; + throw createErrRequireEsm(filename, parentPath, packageJsonPath); + } +} -function __ncc_wildcard$0 (arg) { - if (arg === "cat.js" || arg === "cat") return __nccwpck_require__(95562); - else if (arg === "cd.js" || arg === "cd") return __nccwpck_require__(51829); - else if (arg === "chmod.js" || arg === "chmod") return __nccwpck_require__(81072); - else if (arg === "common.js" || arg === "common") return __nccwpck_require__(17673); - else if (arg === "cp.js" || arg === "cp") return __nccwpck_require__(6135); - else if (arg === "dirs.js" || arg === "dirs") return __nccwpck_require__(80220); - else if (arg === "echo.js" || arg === "echo") return __nccwpck_require__(99534); - else if (arg === "error.js" || arg === "error") return __nccwpck_require__(49862); - else if (arg === "exec-child.js" || arg === "exec-child") return __nccwpck_require__(24416); - else if (arg === "exec.js" || arg === "exec") return __nccwpck_require__(74221); - else if (arg === "find.js" || arg === "find") return __nccwpck_require__(49198); - else if (arg === "grep.js" || arg === "grep") return __nccwpck_require__(78869); - else if (arg === "head.js" || arg === "head") return __nccwpck_require__(41712); - else if (arg === "ln.js" || arg === "ln") return __nccwpck_require__(76786); - else if (arg === "ls.js" || arg === "ls") return __nccwpck_require__(9644); - else if (arg === "mkdir.js" || arg === "mkdir") return __nccwpck_require__(69494); - else if (arg === "mv.js" || arg === "mv") return __nccwpck_require__(31285); - else if (arg === "popd.js" || arg === "popd") return __nccwpck_require__(42535); - else if (arg === "pushd.js" || arg === "pushd") return __nccwpck_require__(47928); - else if (arg === "pwd.js" || arg === "pwd") return __nccwpck_require__(24020); - else if (arg === "rm.js" || arg === "rm") return __nccwpck_require__(37720); - else if (arg === "sed.js" || arg === "sed") return __nccwpck_require__(46926); - else if (arg === "set.js" || arg === "set") return __nccwpck_require__(20011); - else if (arg === "sort.js" || arg === "sort") return __nccwpck_require__(37472); - else if (arg === "tail.js" || arg === "tail") return __nccwpck_require__(18968); - else if (arg === "tempdir.js" || arg === "tempdir") return __nccwpck_require__(40591); - else if (arg === "test.js" || arg === "test") return __nccwpck_require__(39063); - else if (arg === "to.js" || arg === "to") return __nccwpck_require__(94897); - else if (arg === "toEnd.js" || arg === "toEnd") return __nccwpck_require__(60228); - else if (arg === "touch.js" || arg === "touch") return __nccwpck_require__(28440); - else if (arg === "uniq.js" || arg === "uniq") return __nccwpck_require__(55499); - else if (arg === "which.js" || arg === "which") return __nccwpck_require__(5405); -} -var common = __nccwpck_require__(17673); -//@ -//@ All commands run synchronously, unless otherwise stated. -//@ All commands accept standard bash globbing characters (`*`, `?`, etc.), -//@ compatible with the [node `glob` module](https://github.com/isaacs/node-glob). -//@ -//@ For less-commonly used commands and features, please check out our [wiki -//@ page](https://github.com/shelljs/shelljs/wiki). -//@ +module.exports = { + createCjsLoader, + assertScriptCanLoadAsCJSImpl, + readPackageScope +}; -// Include the docs for all the default commands -//@commands -// Load all default commands -(__nccwpck_require__(37270).forEach)(function (command) { - __ncc_wildcard$0(command); -}); +/***/ }), -//@ -//@ ### exit(code) -//@ -//@ Exits the current process with the given exit `code`. -exports.exit = process.exit; +/***/ 17604: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { -//@include ./src/error -exports.error = __nccwpck_require__(49862); +"use strict"; +// Copied from https://raw.githubusercontent.com/nodejs/node/v15.3.0/lib/internal/modules/esm/get_format.js -//@include ./src/common -exports.ShellString = common.ShellString; -//@ -//@ ### env['VAR_NAME'] -//@ -//@ Object containing environment variables (both getter and setter). Shortcut -//@ to `process.env`. -exports.env = process.env; +const { + RegExpPrototypeExec, + StringPrototypeStartsWith, +} = __nccwpck_require__(57523); +const { extname } = __nccwpck_require__(71017); +const { getOptionValue } = __nccwpck_require__(92060); -//@ -//@ ### Pipes -//@ -//@ Examples: -//@ -//@ ```javascript -//@ grep('foo', 'file1.txt', 'file2.txt').sed(/o/g, 'a').to('output.txt'); -//@ echo('files with o\'s in the name:\n' + ls().grep('o')); -//@ cat('test.js').exec('node'); // pipe to exec() call -//@ ``` -//@ -//@ Commands can send their output to another command in a pipe-like fashion. -//@ `sed`, `grep`, `cat`, `exec`, `to`, and `toEnd` can appear on the right-hand -//@ side of a pipe. Pipes can be chained. +const [nodeMajor, nodeMinor] = process.versions.node.split('.').map(s => parseInt(s, 10)); +const experimentalJsonModules = + nodeMajor > 17 + || (nodeMajor === 17 && nodeMinor >= 5) + || (nodeMajor === 16 && nodeMinor >= 15) + || getOptionValue('--experimental-json-modules'); +const experimentalWasmModules = getOptionValue('--experimental-wasm-modules'); +const { URL, fileURLToPath } = __nccwpck_require__(57310); +const { ERR_UNKNOWN_FILE_EXTENSION } = (__nccwpck_require__(5604).codes); -//@ -//@ ## Configuration -//@ +const extensionFormatMap = { + '__proto__': null, + '.cjs': 'commonjs', + '.js': 'module', + '.mjs': 'module' +}; -exports.config = common.config; +const legacyExtensionFormatMap = { + '__proto__': null, + '.cjs': 'commonjs', + '.js': 'commonjs', + '.json': 'commonjs', + '.mjs': 'module', + '.node': 'commonjs' +}; -//@ -//@ ### config.silent -//@ -//@ Example: -//@ -//@ ```javascript -//@ var sh = require('shelljs'); -//@ var silentState = sh.config.silent; // save old silent state -//@ sh.config.silent = true; -//@ /* ... */ -//@ sh.config.silent = silentState; // restore old silent state -//@ ``` -//@ -//@ Suppresses all command output if `true`, except for `echo()` calls. -//@ Default is `false`. +if (experimentalWasmModules) + extensionFormatMap['.wasm'] = legacyExtensionFormatMap['.wasm'] = 'wasm'; -//@ -//@ ### config.fatal -//@ -//@ Example: -//@ -//@ ```javascript -//@ require('shelljs/global'); -//@ config.fatal = true; // or set('-e'); -//@ cp('this_file_does_not_exist', '/dev/null'); // throws Error here -//@ /* more commands... */ -//@ ``` -//@ -//@ If `true`, the script will throw a Javascript error when any shell.js -//@ command encounters an error. Default is `false`. This is analogous to -//@ Bash's `set -e`. +if (experimentalJsonModules) + extensionFormatMap['.json'] = legacyExtensionFormatMap['.json'] = 'json'; -//@ -//@ ### config.verbose -//@ -//@ Example: -//@ -//@ ```javascript -//@ config.verbose = true; // or set('-v'); -//@ cd('dir/'); -//@ rm('-rf', 'foo.txt', 'bar.txt'); -//@ exec('echo hello'); -//@ ``` -//@ -//@ Will print each command as follows: -//@ -//@ ``` -//@ cd dir/ -//@ rm -rf foo.txt bar.txt -//@ exec echo hello -//@ ``` +/** + * + * @param {'node' | 'explicit'} [tsNodeExperimentalSpecifierResolution] + * @param {ReturnType< + * typeof import('../dist-raw/node-internal-modules-esm-resolve').createResolve + * >} nodeEsmResolver + */ +function createGetFormat(tsNodeExperimentalSpecifierResolution, nodeEsmResolver) { +// const experimentalSpeciferResolution = tsNodeExperimentalSpecifierResolution ?? getOptionValue('--experimental-specifier-resolution'); +let experimentalSpeciferResolution = tsNodeExperimentalSpecifierResolution != null ? tsNodeExperimentalSpecifierResolution : getOptionValue('--experimental-specifier-resolution'); +const { getPackageType } = nodeEsmResolver; -//@ -//@ ### config.globOptions -//@ -//@ Example: -//@ -//@ ```javascript -//@ config.globOptions = {nodir: true}; -//@ ``` -//@ -//@ Use this value for calls to `glob.sync()` instead of the default options. +/** + * @param {string} url + * @param {{}} context + * @param {any} defaultGetFormatUnused + * @returns {ReturnType} + */ +function defaultGetFormat(url, context, defaultGetFormatUnused) { + if (StringPrototypeStartsWith(url, 'node:')) { + return { format: 'builtin' }; + } + const parsed = new URL(url); + if (parsed.protocol === 'data:') { + const [ , mime ] = RegExpPrototypeExec( + /^([^/]+\/[^;,]+)(?:[^,]*?)(;base64)?,/, + parsed.pathname, + ) || [ null, null, null ]; + const format = ({ + '__proto__': null, + 'text/javascript': 'module', + 'application/json': experimentalJsonModules ? 'json' : null, + 'application/wasm': experimentalWasmModules ? 'wasm' : null + })[mime] || null; + return { format }; + } else if (parsed.protocol === 'file:') { + const ext = extname(parsed.pathname); + let format; + if (ext === '.js') { + format = getPackageType(parsed.href) === 'module' ? 'module' : 'commonjs'; + } else { + format = extensionFormatMap[ext]; + } + if (!format) { + if (experimentalSpeciferResolution === 'node') { + process.emitWarning( + 'The Node.js specifier resolution in ESM is experimental.', + 'ExperimentalWarning'); + format = legacyExtensionFormatMap[ext]; + } else { + throw new ERR_UNKNOWN_FILE_EXTENSION(ext, fileURLToPath(url)); + } + } + return { format: format || null }; + } + return { format: null }; +} -//@ -//@ ### config.reset() -//@ -//@ Example: -//@ -//@ ```javascript -//@ var shell = require('shelljs'); -//@ // Make changes to shell.config, and do stuff... -//@ /* ... */ -//@ shell.config.reset(); // reset to original state -//@ // Do more stuff, but with original settings -//@ /* ... */ -//@ ``` -//@ -//@ Reset `shell.config` to the defaults: -//@ -//@ ```javascript -//@ { -//@ fatal: false, -//@ globOptions: {}, -//@ maxdepth: 255, -//@ noglob: false, -//@ silent: false, -//@ verbose: false, -//@ } -//@ ``` +return {defaultGetFormat}; +} + +module.exports = { + createGetFormat +}; /***/ }), -/***/ 95562: +/***/ 74284: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { -var common = __nccwpck_require__(17673); -var fs = __nccwpck_require__(57147); +"use strict"; +// Copied from https://raw.githubusercontent.com/nodejs/node/v15.3.0/lib/internal/modules/esm/resolve.js -common.register('cat', _cat, { - canReceivePipe: true, - cmdOptions: { - 'n': 'number', - }, -}); -//@ -//@ ### cat([options,] file [, file ...]) -//@ ### cat([options,] file_array) -//@ -//@ Available options: -//@ -//@ + `-n`: number all output lines -//@ -//@ Examples: -//@ -//@ ```javascript -//@ var str = cat('file*.txt'); -//@ var str = cat('file1', 'file2'); -//@ var str = cat(['file1', 'file2']); // same as above -//@ ``` -//@ -//@ Returns a string containing the given file, or a concatenated string -//@ containing the files if more than one file is given (a new line character is -//@ introduced between each file). -function _cat(options, files) { - var cat = common.readFromPipe(); - if (!files && !cat) common.error('no paths given'); +const {versionGteLt} = __nccwpck_require__(26239); - files = [].slice.call(arguments, 1); +// Test for node >14.13.1 || (>=12.20.0 && <13) +const builtinModuleProtocol = + versionGteLt(process.versions.node, '14.13.1') || + versionGteLt(process.versions.node, '12.20.0', '13.0.0') + ? 'node:' + : 'nodejs:'; - files.forEach(function (file) { - if (!fs.existsSync(file)) { - common.error('no such file or directory: ' + file); - } else if (common.statFollowLinks(file).isDirectory()) { - common.error(file + ': Is a directory'); - } +const { + ArrayIsArray, + ArrayPrototypeJoin, + ArrayPrototypeShift, + JSONParse, + JSONStringify, + ObjectFreeze, + ObjectGetOwnPropertyNames, + ObjectPrototypeHasOwnProperty, + RegExpPrototypeTest, + SafeMap, + SafeSet, + StringPrototypeEndsWith, + StringPrototypeIndexOf, + StringPrototypeLastIndexOf, + StringPrototypeReplace, + StringPrototypeSlice, + StringPrototypeSplit, + StringPrototypeStartsWith, + StringPrototypeSubstr, +} = __nccwpck_require__(57523); - cat += fs.readFileSync(file, 'utf8'); - }); +// const internalFS = require('internal/fs/utils'); +const Module = __nccwpck_require__(98188); +const { NativeModule } = __nccwpck_require__(12061); +const { + realpathSync, + statSync, + Stats, +} = __nccwpck_require__(57147); +// const { getOptionValue } = require('internal/options'); +const { getOptionValue } = __nccwpck_require__(92060); +// // Do not eagerly grab .manifest, it may be in TDZ +// const policy = getOptionValue('--experimental-policy') ? +// require('internal/process/policy') : +// null; +// disabled for now. I am not sure if/how we should support this +const policy = null; +const { sep, relative } = __nccwpck_require__(71017); +const preserveSymlinks = getOptionValue('--preserve-symlinks'); +const preserveSymlinksMain = getOptionValue('--preserve-symlinks-main'); +const typeFlag = getOptionValue('--input-type'); +// const { URL, pathToFileURL, fileURLToPath } = require('internal/url'); +const { URL, pathToFileURL, fileURLToPath } = __nccwpck_require__(57310); +const { + ERR_INPUT_TYPE_NOT_ALLOWED, + ERR_INVALID_ARG_VALUE, + ERR_INVALID_MODULE_SPECIFIER, + ERR_INVALID_PACKAGE_CONFIG, + ERR_INVALID_PACKAGE_TARGET, + ERR_MANIFEST_DEPENDENCY_MISSING, + ERR_MODULE_NOT_FOUND, + ERR_PACKAGE_IMPORT_NOT_DEFINED, + ERR_PACKAGE_PATH_NOT_EXPORTED, + ERR_UNSUPPORTED_DIR_IMPORT, + ERR_UNSUPPORTED_ESM_URL_SCHEME, +// } = require('internal/errors').codes; +} = (__nccwpck_require__(5604).codes); - if (options.number) { - cat = addNumbers(cat); - } +// const { Module: CJSModule } = require('internal/modules/cjs/loader'); +const CJSModule = Module; - return cat; -} -module.exports = _cat; +// const packageJsonReader = require('internal/modules/package_json_reader'); +const packageJsonReader = __nccwpck_require__(73104); +const userConditions = getOptionValue('--conditions'); +const DEFAULT_CONDITIONS = ObjectFreeze(['node', 'import', ...userConditions]); +const DEFAULT_CONDITIONS_SET = new SafeSet(DEFAULT_CONDITIONS); -function addNumbers(cat) { - var lines = cat.split('\n'); - var lastLine = lines.pop(); +const pendingDeprecation = getOptionValue('--pending-deprecation'); - lines = lines.map(function (line, i) { - return numberedLine(i + 1, line); - }); +/** + * @param {{ + * extensions: import('../src/file-extensions').Extensions, + * preferTsExts: boolean | undefined; + * tsNodeExperimentalSpecifierResolution: import('../src/index').ExperimentalSpecifierResolution | undefined; + * }} opts + */ +function createResolve(opts) { +// TODO receive cached fs implementations here +const {preferTsExts, tsNodeExperimentalSpecifierResolution, extensions} = opts; +const esrnExtensions = extensions.experimentalSpecifierResolutionAddsIfOmitted; +const {legacyMainResolveAddsIfOmitted, replacementsForCjs, replacementsForJs, replacementsForMjs, replacementsForJsx} = extensions; +// const experimentalSpecifierResolution = tsNodeExperimentalSpecifierResolution ?? getOptionValue('--experimental-specifier-resolution'); +const experimentalSpecifierResolution = tsNodeExperimentalSpecifierResolution != null ? tsNodeExperimentalSpecifierResolution : getOptionValue('--experimental-specifier-resolution'); - if (lastLine.length) { - lastLine = numberedLine(lines.length + 1, lastLine); +const emittedPackageWarnings = new SafeSet(); +function emitFolderMapDeprecation(match, pjsonUrl, isExports, base) { + const pjsonPath = fileURLToPath(pjsonUrl); + if (!pendingDeprecation) { + const nodeModulesIndex = StringPrototypeLastIndexOf(pjsonPath, + '/node_modules/'); + if (nodeModulesIndex !== -1) { + const afterNodeModulesPath = StringPrototypeSlice(pjsonPath, + nodeModulesIndex + 14, + -13); + try { + const { packageSubpath } = parsePackageName(afterNodeModulesPath); + if (packageSubpath === '.') + return; + } catch {} + } } - lines.push(lastLine); - - return lines.join('\n'); -} - -function numberedLine(n, line) { - // GNU cat use six pad start number + tab. See http://lingrok.org/xref/coreutils/src/cat.c#57 - // https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/padStart - var number = (' ' + n).slice(-6) + '\t'; - return number + line; + if (emittedPackageWarnings.has(pjsonPath + '|' + match)) + return; + emittedPackageWarnings.add(pjsonPath + '|' + match); + process.emitWarning( + `Use of deprecated folder mapping "${match}" in the ${isExports ? + '"exports"' : '"imports"'} field module resolution of the package at ${ + pjsonPath}${base ? ` imported from ${fileURLToPath(base)}` : ''}.\n` + + `Update this package.json to use a subpath pattern like "${match}*".`, + 'DeprecationWarning', + 'DEP0148' + ); } - -/***/ }), - -/***/ 51829: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { - -var os = __nccwpck_require__(22037); -var common = __nccwpck_require__(17673); - -common.register('cd', _cd, {}); - -//@ -//@ ### cd([dir]) -//@ -//@ Changes to directory `dir` for the duration of the script. Changes to home -//@ directory if no argument is supplied. -function _cd(options, dir) { - if (!dir) dir = os.homedir(); - - if (dir === '-') { - if (!process.env.OLDPWD) { - common.error('could not find previous directory'); - } else { - dir = process.env.OLDPWD; +function getConditionsSet(conditions) { + if (conditions !== undefined && conditions !== DEFAULT_CONDITIONS) { + if (!ArrayIsArray(conditions)) { + throw new ERR_INVALID_ARG_VALUE('conditions', conditions, + 'expected an array'); } + return new SafeSet(conditions); } + return DEFAULT_CONDITIONS_SET; +} +const realpathCache = new SafeMap(); +const packageJSONCache = new SafeMap(); /* string -> PackageConfig */ + +const statSupportsThrowIfNoEntry = versionGteLt(process.versions.node, '15.3.0') || + versionGteLt(process.versions.node, '14.17.0', '15.0.0'); +const tryStatSync = statSupportsThrowIfNoEntry ? tryStatSyncWithoutErrors : tryStatSyncWithErrors; +const statsIfNotFound = new Stats(); +function tryStatSyncWithoutErrors(path) { + const stats = statSync(path, { throwIfNoEntry: false }); + if(stats != null) return stats; + return statsIfNotFound; +} +function tryStatSyncWithErrors(path) { try { - var curDir = process.cwd(); - process.chdir(dir); - process.env.OLDPWD = curDir; - } catch (e) { - // something went wrong, let's figure out the error - var err; - try { - common.statFollowLinks(dir); // if this succeeds, it must be some sort of file - err = 'not a directory: ' + dir; - } catch (e2) { - err = 'no such file or directory: ' + dir; - } - if (err) common.error(err); + return statSync(path); + } catch { + return statsIfNotFound; } - return ''; } -module.exports = _cd; - -/***/ }), - -/***/ 81072: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { +function getPackageConfig(path, specifier, base) { + const existing = packageJSONCache.get(path); + if (existing !== undefined) { + return existing; + } + const source = packageJsonReader.read(path).string; + if (source === undefined) { + const packageConfig = { + pjsonPath: path, + exists: false, + main: undefined, + name: undefined, + type: 'none', + exports: undefined, + imports: undefined, + }; + packageJSONCache.set(path, packageConfig); + return packageConfig; + } -var common = __nccwpck_require__(17673); -var fs = __nccwpck_require__(57147); -var path = __nccwpck_require__(71017); + let packageJSON; + try { + packageJSON = JSONParse(source); + } catch (error) { + throw new ERR_INVALID_PACKAGE_CONFIG( + path, + (base ? `"${specifier}" from ` : '') + fileURLToPath(base || specifier), + error.message + ); + } -var PERMS = (function (base) { - return { - OTHER_EXEC: base.EXEC, - OTHER_WRITE: base.WRITE, - OTHER_READ: base.READ, + let { imports, main, name, type } = packageJSON; + const { exports } = packageJSON; + if (typeof imports !== 'object' || imports === null) imports = undefined; + if (typeof main !== 'string') main = undefined; + if (typeof name !== 'string') name = undefined; + // Ignore unknown types for forwards compatibility + if (type !== 'module' && type !== 'commonjs') type = 'none'; - GROUP_EXEC: base.EXEC << 3, - GROUP_WRITE: base.WRITE << 3, - GROUP_READ: base.READ << 3, + const packageConfig = { + pjsonPath: path, + exists: true, + main, + name, + type, + exports, + imports, + }; + packageJSONCache.set(path, packageConfig); + return packageConfig; +} - OWNER_EXEC: base.EXEC << 6, - OWNER_WRITE: base.WRITE << 6, - OWNER_READ: base.READ << 6, +function getPackageScopeConfig(resolved) { + let packageJSONUrl = new URL('./package.json', resolved); + while (true) { + const packageJSONPath = packageJSONUrl.pathname; + if (StringPrototypeEndsWith(packageJSONPath, 'node_modules/package.json')) + break; + const packageConfig = getPackageConfig(fileURLToPath(packageJSONUrl), + resolved); + if (packageConfig.exists) return packageConfig; - // Literal octal numbers are apparently not allowed in "strict" javascript. - STICKY: parseInt('01000', 8), - SETGID: parseInt('02000', 8), - SETUID: parseInt('04000', 8), + const lastPackageJSONUrl = packageJSONUrl; + packageJSONUrl = new URL('../package.json', packageJSONUrl); - TYPE_MASK: parseInt('0770000', 8), + // Terminates at root where ../package.json equals ../../package.json + // (can't just check "/package.json" for Windows support). + if (packageJSONUrl.pathname === lastPackageJSONUrl.pathname) break; + } + const packageJSONPath = fileURLToPath(packageJSONUrl); + const packageConfig = { + pjsonPath: packageJSONPath, + exists: false, + main: undefined, + name: undefined, + type: 'none', + exports: undefined, + imports: undefined, }; -}({ - EXEC: 1, - WRITE: 2, - READ: 4, -})); + packageJSONCache.set(packageJSONPath, packageConfig); + return packageConfig; +} -common.register('chmod', _chmod, { -}); +/* + * Legacy CommonJS main resolution: + * 1. let M = pkg_url + (json main field) + * 2. TRY(M, M.js, M.json, M.node) + * 3. TRY(M/index.js, M/index.json, M/index.node) + * 4. TRY(pkg_url/index.js, pkg_url/index.json, pkg_url/index.node) + * 5. NOT_FOUND + */ +function fileExists(url) { + return tryStatSync(fileURLToPath(url)).isFile(); +} -//@ -//@ ### chmod([options,] octal_mode || octal_string, file) -//@ ### chmod([options,] symbolic_mode, file) -//@ -//@ Available options: -//@ -//@ + `-v`: output a diagnostic for every file processed//@ -//@ + `-c`: like verbose, but report only when a change is made//@ -//@ + `-R`: change files and directories recursively//@ -//@ -//@ Examples: -//@ -//@ ```javascript -//@ chmod(755, '/Users/brandon'); -//@ chmod('755', '/Users/brandon'); // same as above -//@ chmod('u+x', '/Users/brandon'); -//@ chmod('-R', 'a-w', '/Users/brandon'); -//@ ``` -//@ -//@ Alters the permissions of a file or directory by either specifying the -//@ absolute permissions in octal form or expressing the changes in symbols. -//@ This command tries to mimic the POSIX behavior as much as possible. -//@ Notable exceptions: -//@ -//@ + In symbolic modes, `a-r` and `-r` are identical. No consideration is -//@ given to the `umask`. -//@ + There is no "quiet" option, since default behavior is to run silent. -function _chmod(options, mode, filePattern) { - if (!filePattern) { - if (options.length > 0 && options.charAt(0) === '-') { - // Special case where the specified file permissions started with - to subtract perms, which - // get picked up by the option parser as command flags. - // If we are down by one argument and options starts with -, shift everything over. - [].unshift.call(arguments, ''); - } else { - common.error('You must specify a file.'); +function legacyMainResolve(packageJSONUrl, packageConfig, base) { + let guess; + if (packageConfig.main !== undefined) { + // Note: fs check redundances will be handled by Descriptor cache here. + if(guess = resolveReplacementExtensions(new URL(`./${packageConfig.main}`, packageJSONUrl))) { + return guess; + } + if (fileExists(guess = new URL(`./${packageConfig.main}`, + packageJSONUrl))) { + return guess; } + for(const extension of legacyMainResolveAddsIfOmitted) { + if (fileExists(guess = new URL(`./${packageConfig.main}${extension}`, + packageJSONUrl))) { + return guess; + } + } + for(const extension of legacyMainResolveAddsIfOmitted) { + if (fileExists(guess = new URL(`./${packageConfig.main}/index${extension}`, + packageJSONUrl))) { + return guess; + } + } + // Fallthrough. } + for(const extension of legacyMainResolveAddsIfOmitted) { + if (fileExists(guess = new URL(`./index${extension}`, packageJSONUrl))) { + return guess; + } + } + // Not found. + throw new ERR_MODULE_NOT_FOUND( + fileURLToPath(new URL('.', packageJSONUrl)), fileURLToPath(base)); +} - options = common.parseOptions(options, { - 'R': 'recursive', - 'c': 'changes', - 'v': 'verbose', - }); - - filePattern = [].slice.call(arguments, 2); - - var files; - - // TODO: replace this with a call to common.expand() - if (options.recursive) { - files = []; - filePattern.forEach(function addFile(expandedFile) { - var stat = common.statNoFollowLinks(expandedFile); +/** attempts replacement extensions, then tries exact name, then attempts appending extensions */ +function resolveExtensionsWithTryExactName(search) { + const resolvedReplacementExtension = resolveReplacementExtensions(search); + if(resolvedReplacementExtension) return resolvedReplacementExtension; + if (fileExists(search)) return search; + return resolveExtensions(search); +} - if (!stat.isSymbolicLink()) { - files.push(expandedFile); +// This appends missing extensions +function resolveExtensions(search) { + for (let i = 0; i < esrnExtensions.length; i++) { + const extension = esrnExtensions[i]; + const guess = new URL(`${search.pathname}${extension}`, search); + if (fileExists(guess)) return guess; + } + return undefined; +} - if (stat.isDirectory()) { // intentionally does not follow symlinks. - fs.readdirSync(expandedFile).forEach(function (child) { - addFile(expandedFile + '/' + child); - }); - } +/** This replaces JS with TS extensions */ +function resolveReplacementExtensions(search) { + const lastDotIndex = search.pathname.lastIndexOf('.'); + if(lastDotIndex >= 0) { + const ext = search.pathname.slice(lastDotIndex); + if (ext === '.js' || ext === '.jsx' || ext === '.mjs' || ext === '.cjs') { + const pathnameWithoutExtension = search.pathname.slice(0, lastDotIndex); + const replacementExts = + ext === '.js' ? replacementsForJs + : ext === '.jsx' ? replacementsForJsx + : ext === '.mjs' ? replacementsForMjs + : replacementsForCjs; + const guess = new URL(search.toString()); + for (let i = 0; i < replacementExts.length; i++) { + const extension = replacementExts[i]; + guess.pathname = `${pathnameWithoutExtension}${extension}`; + if (fileExists(guess)) return guess; } - }); - } else { - files = filePattern; + } } + return undefined; +} - files.forEach(function innerChmod(file) { - file = path.resolve(file); - if (!fs.existsSync(file)) { - common.error('File not found: ' + file); - } +function resolveIndex(search) { + return resolveExtensions(new URL('index', search)); +} - // When recursing, don't follow symlinks. - if (options.recursive && common.statNoFollowLinks(file).isSymbolicLink()) { - return; +const encodedSepRegEx = /%2F|%2C/i; +function finalizeResolution(resolved, base) { + if (RegExpPrototypeTest(encodedSepRegEx, resolved.pathname)) + throw new ERR_INVALID_MODULE_SPECIFIER( + resolved.pathname, 'must not include encoded "/" or "\\" characters', + fileURLToPath(base)); + + if (experimentalSpecifierResolution === 'node') { + const path = fileURLToPath(resolved); + let file = resolveExtensionsWithTryExactName(resolved); + if (file !== undefined) return file; + if (!StringPrototypeEndsWith(path, '/')) { + file = resolveIndex(new URL(`${resolved}/`)); + if (file !== undefined) return file; + } else { + return resolveIndex(resolved) || resolved; } + throw new ERR_MODULE_NOT_FOUND( + resolved.pathname, fileURLToPath(base), 'module'); + } - var stat = common.statFollowLinks(file); - var isDir = stat.isDirectory(); - var perms = stat.mode; - var type = perms & PERMS.TYPE_MASK; + const file = resolveReplacementExtensions(resolved) || resolved; + const path = fileURLToPath(file); - var newPerms = perms; + const stats = tryStatSync(StringPrototypeEndsWith(path, '/') ? + StringPrototypeSlice(path, -1) : path); + if (stats.isDirectory()) { + const err = new ERR_UNSUPPORTED_DIR_IMPORT(path, fileURLToPath(base)); + err.url = String(resolved); + throw err; + } else if (!stats.isFile()) { + throw new ERR_MODULE_NOT_FOUND( + path || resolved.pathname, fileURLToPath(base), 'module'); + } - if (isNaN(parseInt(mode, 8))) { - // parse options - mode.split(',').forEach(function (symbolicMode) { - var pattern = /([ugoa]*)([=\+-])([rwxXst]*)/i; - var matches = pattern.exec(symbolicMode); + return file; +} - if (matches) { - var applyTo = matches[1]; - var operator = matches[2]; - var change = matches[3]; +function throwImportNotDefined(specifier, packageJSONUrl, base) { + throw new ERR_PACKAGE_IMPORT_NOT_DEFINED( + specifier, packageJSONUrl && fileURLToPath(new URL('.', packageJSONUrl)), + fileURLToPath(base)); +} - var changeOwner = applyTo.indexOf('u') !== -1 || applyTo === 'a' || applyTo === ''; - var changeGroup = applyTo.indexOf('g') !== -1 || applyTo === 'a' || applyTo === ''; - var changeOther = applyTo.indexOf('o') !== -1 || applyTo === 'a' || applyTo === ''; +function throwExportsNotFound(subpath, packageJSONUrl, base) { + throw new ERR_PACKAGE_PATH_NOT_EXPORTED( + fileURLToPath(new URL('.', packageJSONUrl)), subpath, + base && fileURLToPath(base)); +} - var changeRead = change.indexOf('r') !== -1; - var changeWrite = change.indexOf('w') !== -1; - var changeExec = change.indexOf('x') !== -1; - var changeExecDir = change.indexOf('X') !== -1; - var changeSticky = change.indexOf('t') !== -1; - var changeSetuid = change.indexOf('s') !== -1; +function throwInvalidSubpath(subpath, packageJSONUrl, internal, base) { + const reason = `request is not a valid subpath for the "${internal ? + 'imports' : 'exports'}" resolution of ${fileURLToPath(packageJSONUrl)}`; + throw new ERR_INVALID_MODULE_SPECIFIER(subpath, reason, + base && fileURLToPath(base)); +} - if (changeExecDir && isDir) { - changeExec = true; - } +function throwInvalidPackageTarget( + subpath, target, packageJSONUrl, internal, base) { + if (typeof target === 'object' && target !== null) { + target = JSONStringify(target, null, ''); + } else { + target = `${target}`; + } + throw new ERR_INVALID_PACKAGE_TARGET( + fileURLToPath(new URL('.', packageJSONUrl)), subpath, target, + internal, base && fileURLToPath(base)); +} - var mask = 0; - if (changeOwner) { - mask |= (changeRead ? PERMS.OWNER_READ : 0) + (changeWrite ? PERMS.OWNER_WRITE : 0) + (changeExec ? PERMS.OWNER_EXEC : 0) + (changeSetuid ? PERMS.SETUID : 0); - } - if (changeGroup) { - mask |= (changeRead ? PERMS.GROUP_READ : 0) + (changeWrite ? PERMS.GROUP_WRITE : 0) + (changeExec ? PERMS.GROUP_EXEC : 0) + (changeSetuid ? PERMS.SETGID : 0); - } - if (changeOther) { - mask |= (changeRead ? PERMS.OTHER_READ : 0) + (changeWrite ? PERMS.OTHER_WRITE : 0) + (changeExec ? PERMS.OTHER_EXEC : 0); - } +const invalidSegmentRegEx = /(^|\\|\/)(\.\.?|node_modules)(\\|\/|$)/; +const patternRegEx = /\*/g; - // Sticky bit is special - it's not tied to user, group or other. - if (changeSticky) { - mask |= PERMS.STICKY; - } +function resolvePackageTargetString( + target, subpath, match, packageJSONUrl, base, pattern, internal, conditions) { + if (subpath !== '' && !pattern && target[target.length - 1] !== '/') + throwInvalidPackageTarget(match, target, packageJSONUrl, internal, base); - switch (operator) { - case '+': - newPerms |= mask; - break; + if (!StringPrototypeStartsWith(target, './')) { + if (internal && !StringPrototypeStartsWith(target, '../') && + !StringPrototypeStartsWith(target, '/')) { + let isURL = false; + try { + new URL(target); + isURL = true; + } catch {} + if (!isURL) { + const exportTarget = pattern ? + StringPrototypeReplace(target, patternRegEx, subpath) : + target + subpath; + return packageResolve(exportTarget, packageJSONUrl, conditions); + } + } + throwInvalidPackageTarget(match, target, packageJSONUrl, internal, base); + } - case '-': - newPerms &= ~mask; - break; + if (RegExpPrototypeTest(invalidSegmentRegEx, StringPrototypeSlice(target, 2))) + throwInvalidPackageTarget(match, target, packageJSONUrl, internal, base); - case '=': - newPerms = type + mask; + const resolved = new URL(target, packageJSONUrl); + const resolvedPath = resolved.pathname; + const packagePath = new URL('.', packageJSONUrl).pathname; - // According to POSIX, when using = to explicitly set the - // permissions, setuid and setgid can never be cleared. - if (common.statFollowLinks(file).isDirectory()) { - newPerms |= (PERMS.SETUID + PERMS.SETGID) & perms; - } - break; - default: - common.error('Could not recognize operator: `' + operator + '`'); - } + if (!StringPrototypeStartsWith(resolvedPath, packagePath)) + throwInvalidPackageTarget(match, target, packageJSONUrl, internal, base); - if (options.verbose) { - console.log(file + ' -> ' + newPerms.toString(8)); - } + if (subpath === '') return resolved; - if (perms !== newPerms) { - if (!options.verbose && options.changes) { - console.log(file + ' -> ' + newPerms.toString(8)); - } - fs.chmodSync(file, newPerms); - perms = newPerms; // for the next round of changes! - } - } else { - common.error('Invalid symbolic mode change: ' + symbolicMode); - } - }); - } else { - // they gave us a full number - newPerms = type + parseInt(mode, 8); + if (RegExpPrototypeTest(invalidSegmentRegEx, subpath)) + throwInvalidSubpath(match + subpath, packageJSONUrl, internal, base); - // POSIX rules are that setuid and setgid can only be added using numeric - // form, but not cleared. - if (common.statFollowLinks(file).isDirectory()) { - newPerms |= (PERMS.SETUID + PERMS.SETGID) & perms; - } + if (pattern) + return new URL(StringPrototypeReplace(resolved.href, patternRegEx, + subpath)); + return new URL(subpath, resolved); +} - fs.chmodSync(file, newPerms); - } - }); - return ''; +/** + * @param {string} key + * @returns {boolean} + */ +function isArrayIndex(key) { + const keyNum = +key; + if (`${keyNum}` !== key) return false; + return keyNum >= 0 && keyNum < 0xFFFF_FFFF; } -module.exports = _chmod; +function resolvePackageTarget(packageJSONUrl, target, subpath, packageSubpath, + base, pattern, internal, conditions) { + if (typeof target === 'string') { + return resolvePackageTargetString( + target, subpath, packageSubpath, packageJSONUrl, base, pattern, internal, + conditions); + } else if (ArrayIsArray(target)) { + if (target.length === 0) + return null; -/***/ }), + let lastException; + for (let i = 0; i < target.length; i++) { + const targetItem = target[i]; + let resolved; + try { + resolved = resolvePackageTarget( + packageJSONUrl, targetItem, subpath, packageSubpath, base, pattern, + internal, conditions); + } catch (e) { + lastException = e; + if (e.code === 'ERR_INVALID_PACKAGE_TARGET') + continue; + throw e; + } + if (resolved === undefined) + continue; + if (resolved === null) { + lastException = null; + continue; + } + return resolved; + } + if (lastException === undefined || lastException === null) + return lastException; + throw lastException; + } else if (typeof target === 'object' && target !== null) { + const keys = ObjectGetOwnPropertyNames(target); + for (let i = 0; i < keys.length; i++) { + const key = keys[i]; + if (isArrayIndex(key)) { + throw new ERR_INVALID_PACKAGE_CONFIG( + fileURLToPath(packageJSONUrl), base, + '"exports" cannot contain numeric property keys.'); + } + } + for (let i = 0; i < keys.length; i++) { + const key = keys[i]; + if (key === 'default' || conditions.has(key)) { + const conditionalTarget = target[key]; + const resolved = resolvePackageTarget( + packageJSONUrl, conditionalTarget, subpath, packageSubpath, base, + pattern, internal, conditions); + if (resolved === undefined) + continue; + return resolved; + } + } + return undefined; + } else if (target === null) { + return null; + } + throwInvalidPackageTarget(packageSubpath, target, packageJSONUrl, internal, + base); +} -/***/ 17673: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { +function isConditionalExportsMainSugar(exports, packageJSONUrl, base) { + if (typeof exports === 'string' || ArrayIsArray(exports)) return true; + if (typeof exports !== 'object' || exports === null) return false; -"use strict"; -// Ignore warning about 'new String()' -/* eslint no-new-wrappers: 0 */ + const keys = ObjectGetOwnPropertyNames(exports); + let isConditionalSugar = false; + let i = 0; + for (let j = 0; j < keys.length; j++) { + const key = keys[j]; + const curIsConditionalSugar = key === '' || key[0] !== '.'; + if (i++ === 0) { + isConditionalSugar = curIsConditionalSugar; + } else if (isConditionalSugar !== curIsConditionalSugar) { + throw new ERR_INVALID_PACKAGE_CONFIG( + fileURLToPath(packageJSONUrl), base, + '"exports" cannot contain some keys starting with \'.\' and some not.' + + ' The exports object must either be an object of package subpath keys' + + ' or an object of main entry condition name keys only.'); + } + } + return isConditionalSugar; +} +/** + * @param {URL} packageJSONUrl + * @param {string} packageSubpath + * @param {object} packageConfig + * @param {string} base + * @param {Set} conditions + * @returns {{resolved: URL, exact: boolean}} + */ +function packageExportsResolve( + packageJSONUrl, packageSubpath, packageConfig, base, conditions) { + let exports = packageConfig.exports; + if (isConditionalExportsMainSugar(exports, packageJSONUrl, base)) + exports = { '.': exports }; -var os = __nccwpck_require__(22037); -var fs = __nccwpck_require__(57147); -var glob = __nccwpck_require__(20557); -var shell = __nccwpck_require__(54572); + if (ObjectPrototypeHasOwnProperty(exports, packageSubpath)) { + const target = exports[packageSubpath]; + const resolved = resolvePackageTarget( + packageJSONUrl, target, '', packageSubpath, base, false, false, conditions + ); + if (resolved === null || resolved === undefined) + throwExportsNotFound(packageSubpath, packageJSONUrl, base); + return { resolved, exact: true }; + } -var shellMethods = Object.create(shell); + let bestMatch = ''; + const keys = ObjectGetOwnPropertyNames(exports); + for (let i = 0; i < keys.length; i++) { + const key = keys[i]; + if (key[key.length - 1] === '*' && + StringPrototypeStartsWith(packageSubpath, + StringPrototypeSlice(key, 0, -1)) && + packageSubpath.length >= key.length && + key.length > bestMatch.length) { + bestMatch = key; + } else if (key[key.length - 1] === '/' && + StringPrototypeStartsWith(packageSubpath, key) && + key.length > bestMatch.length) { + bestMatch = key; + } + } -exports.extend = Object.assign; - -// Check if we're running under electron -var isElectron = Boolean(process.versions.electron); - -// Module globals (assume no execPath by default) -var DEFAULT_CONFIG = { - fatal: false, - globOptions: {}, - maxdepth: 255, - noglob: false, - silent: false, - verbose: false, - execPath: null, - bufLength: 64 * 1024, // 64KB -}; - -var config = { - reset: function () { - Object.assign(this, DEFAULT_CONFIG); - if (!isElectron) { - this.execPath = process.execPath; - } - }, - resetForTesting: function () { - this.reset(); - this.silent = true; - }, -}; - -config.reset(); -exports.config = config; - -// Note: commands should generally consider these as read-only values. -var state = { - error: null, - errorCode: 0, - currentCmd: 'shell.js', -}; -exports.state = state; - -delete process.env.OLDPWD; // initially, there's no previous directory + if (bestMatch) { + const target = exports[bestMatch]; + const pattern = bestMatch[bestMatch.length - 1] === '*'; + const subpath = StringPrototypeSubstr(packageSubpath, bestMatch.length - + (pattern ? 1 : 0)); + const resolved = resolvePackageTarget(packageJSONUrl, target, subpath, + bestMatch, base, pattern, false, + conditions); + if (resolved === null || resolved === undefined) + throwExportsNotFound(packageSubpath, packageJSONUrl, base); + if (!pattern) + emitFolderMapDeprecation(bestMatch, packageJSONUrl, true, base); + return { resolved, exact: pattern }; + } -// Reliably test if something is any sort of javascript object -function isObject(a) { - return typeof a === 'object' && a !== null; + throwExportsNotFound(packageSubpath, packageJSONUrl, base); } -exports.isObject = isObject; -function log() { - /* istanbul ignore next */ - if (!config.silent) { - console.error.apply(console, arguments); +function packageImportsResolve(name, base, conditions) { + if (name === '#' || StringPrototypeStartsWith(name, '#/')) { + const reason = 'is not a valid internal imports specifier name'; + throw new ERR_INVALID_MODULE_SPECIFIER(name, reason, fileURLToPath(base)); } -} -exports.log = log; + let packageJSONUrl; + const packageConfig = getPackageScopeConfig(base); + if (packageConfig.exists) { + packageJSONUrl = pathToFileURL(packageConfig.pjsonPath); + const imports = packageConfig.imports; + if (imports) { + if (ObjectPrototypeHasOwnProperty(imports, name)) { + const resolved = resolvePackageTarget( + packageJSONUrl, imports[name], '', name, base, false, true, conditions + ); + if (resolved !== null) + return { resolved, exact: true }; + } else { + let bestMatch = ''; + const keys = ObjectGetOwnPropertyNames(imports); + for (let i = 0; i < keys.length; i++) { + const key = keys[i]; + if (key[key.length - 1] === '*' && + StringPrototypeStartsWith(name, + StringPrototypeSlice(key, 0, -1)) && + name.length >= key.length && + key.length > bestMatch.length) { + bestMatch = key; + } else if (key[key.length - 1] === '/' && + StringPrototypeStartsWith(name, key) && + key.length > bestMatch.length) { + bestMatch = key; + } + } -// Converts strings to be equivalent across all platforms. Primarily responsible -// for making sure we use '/' instead of '\' as path separators, but this may be -// expanded in the future if necessary -function convertErrorOutput(msg) { - if (typeof msg !== 'string') { - throw new TypeError('input must be a string'); + if (bestMatch) { + const target = imports[bestMatch]; + const pattern = bestMatch[bestMatch.length - 1] === '*'; + const subpath = StringPrototypeSubstr(name, bestMatch.length - + (pattern ? 1 : 0)); + const resolved = resolvePackageTarget( + packageJSONUrl, target, subpath, bestMatch, base, pattern, true, + conditions); + if (resolved !== null) { + if (!pattern) + emitFolderMapDeprecation(bestMatch, packageJSONUrl, false, base); + return { resolved, exact: pattern }; + } + } + } + } } - return msg.replace(/\\/g, '/'); + throwImportNotDefined(name, packageJSONUrl, base); } -exports.convertErrorOutput = convertErrorOutput; - -// Shows error message. Throws if config.fatal is true -function error(msg, _code, options) { - // Validate input - if (typeof msg !== 'string') throw new Error('msg must be a string'); - var DEFAULT_OPTIONS = { - continue: false, - code: 1, - prefix: state.currentCmd + ': ', - silent: false, - }; +function getPackageType(url) { + const packageConfig = getPackageScopeConfig(url); + return packageConfig.type; +} - if (typeof _code === 'number' && isObject(options)) { - options.code = _code; - } else if (isObject(_code)) { // no 'code' - options = _code; - } else if (typeof _code === 'number') { // no 'options' - options = { code: _code }; - } else if (typeof _code !== 'number') { // only 'msg' - options = {}; +function parsePackageName(specifier, base) { + let separatorIndex = StringPrototypeIndexOf(specifier, '/'); + let validPackageName = true; + let isScoped = false; + if (specifier[0] === '@') { + isScoped = true; + if (separatorIndex === -1 || specifier.length === 0) { + validPackageName = false; + } else { + separatorIndex = StringPrototypeIndexOf( + specifier, '/', separatorIndex + 1); + } } - options = Object.assign({}, DEFAULT_OPTIONS, options); - if (!state.errorCode) state.errorCode = options.code; - - var logEntry = convertErrorOutput(options.prefix + msg); - state.error = state.error ? state.error + '\n' : ''; - state.error += logEntry; - - // Throw an error, or log the entry - if (config.fatal) throw new Error(logEntry); - if (msg.length > 0 && !options.silent) log(logEntry); + const packageName = separatorIndex === -1 ? + specifier : StringPrototypeSlice(specifier, 0, separatorIndex); - if (!options.continue) { - throw { - msg: 'earlyExit', - retValue: (new ShellString('', state.error, state.errorCode)), - }; + // Package name cannot have leading . and cannot have percent-encoding or + // separators. + for (let i = 0; i < packageName.length; i++) { + if (packageName[i] === '%' || packageName[i] === '\\') { + validPackageName = false; + break; + } } -} -exports.error = error; -//@ -//@ ### ShellString(str) -//@ -//@ Examples: -//@ -//@ ```javascript -//@ var foo = ShellString('hello world'); -//@ ``` -//@ -//@ Turns a regular string into a string-like object similar to what each -//@ command returns. This has special methods, like `.to()` and `.toEnd()`. -function ShellString(stdout, stderr, code) { - var that; - if (stdout instanceof Array) { - that = stdout; - that.stdout = stdout.join('\n'); - if (stdout.length > 0) that.stdout += '\n'; - } else { - that = new String(stdout); - that.stdout = stdout; + if (!validPackageName) { + throw new ERR_INVALID_MODULE_SPECIFIER( + specifier, 'is not a valid package name', fileURLToPath(base)); } - that.stderr = stderr; - that.code = code; - // A list of all commands that can appear on the right-hand side of a pipe - // (populated by calls to common.wrap()) - pipeMethods.forEach(function (cmd) { - that[cmd] = shellMethods[cmd].bind(that); - }); - return that; -} -exports.ShellString = ShellString; + const packageSubpath = '.' + (separatorIndex === -1 ? '' : + StringPrototypeSlice(specifier, separatorIndex)); -// Returns {'alice': true, 'bob': false} when passed a string and dictionary as follows: -// parseOptions('-a', {'a':'alice', 'b':'bob'}); -// Returns {'reference': 'string-value', 'bob': false} when passed two dictionaries of the form: -// parseOptions({'-r': 'string-value'}, {'r':'reference', 'b':'bob'}); -// Throws an error when passed a string that does not start with '-': -// parseOptions('a', {'a':'alice'}); // throws -function parseOptions(opt, map, errorOptions) { - // Validate input - if (typeof opt !== 'string' && !isObject(opt)) { - throw new Error('options must be strings or key-value pairs'); - } else if (!isObject(map)) { - throw new Error('parseOptions() internal error: map must be an object'); - } else if (errorOptions && !isObject(errorOptions)) { - throw new Error('parseOptions() internal error: errorOptions must be object'); - } + return { packageName, packageSubpath, isScoped }; +} - if (opt === '--') { - // This means there are no options. - return {}; - } +/** + * @param {string} specifier + * @param {URL} base + * @param {Set} conditions + * @returns {URL} + */ +function packageResolve(specifier, base, conditions) { + const { packageName, packageSubpath, isScoped } = + parsePackageName(specifier, base); - // All options are false by default - var options = {}; - Object.keys(map).forEach(function (letter) { - var optName = map[letter]; - if (optName[0] !== '!') { - options[optName] = false; + // ResolveSelf + const packageConfig = getPackageScopeConfig(base); + if (packageConfig.exists) { + const packageJSONUrl = pathToFileURL(packageConfig.pjsonPath); + if (packageConfig.name === packageName && + packageConfig.exports !== undefined && packageConfig.exports !== null) { + return packageExportsResolve( + packageJSONUrl, packageSubpath, packageConfig, base, conditions + ).resolved; } - }); - - if (opt === '') return options; // defaults + } - if (typeof opt === 'string') { - if (opt[0] !== '-') { - throw new Error("Options string must start with a '-'"); + let packageJSONUrl = + new URL('./node_modules/' + packageName + '/package.json', base); + let packageJSONPath = fileURLToPath(packageJSONUrl); + let lastPath; + do { + const stat = tryStatSync(StringPrototypeSlice(packageJSONPath, 0, + packageJSONPath.length - 13)); + if (!stat.isDirectory()) { + lastPath = packageJSONPath; + packageJSONUrl = new URL((isScoped ? + '../../../../node_modules/' : '../../../node_modules/') + + packageName + '/package.json', packageJSONUrl); + packageJSONPath = fileURLToPath(packageJSONUrl); + continue; } - // e.g. chars = ['R', 'f'] - var chars = opt.slice(1).split(''); + // Package match. + const packageConfig = getPackageConfig(packageJSONPath, specifier, base); + if (packageConfig.exports !== undefined && packageConfig.exports !== null) + return packageExportsResolve( + packageJSONUrl, packageSubpath, packageConfig, base, conditions + ).resolved; + if (packageSubpath === '.') + return legacyMainResolve(packageJSONUrl, packageConfig, base); + return new URL(packageSubpath, packageJSONUrl); + // Cross-platform root check. + } while (packageJSONPath.length !== lastPath.length); - chars.forEach(function (c) { - if (c in map) { - var optionName = map[c]; - if (optionName[0] === '!') { - options[optionName.slice(1)] = false; - } else { - options[optionName] = true; - } - } else { - error('option not recognized: ' + c, errorOptions || {}); - } - }); - } else { // opt is an Object - Object.keys(opt).forEach(function (key) { - // key is a string of the form '-r', '-d', etc. - var c = key[1]; - if (c in map) { - var optionName = map[c]; - options[optionName] = opt[key]; // assign the given value - } else { - error('option not recognized: ' + c, errorOptions || {}); - } - }); - } - return options; + // eslint can't handle the above code. + // eslint-disable-next-line no-unreachable + throw new ERR_MODULE_NOT_FOUND(packageName, fileURLToPath(base)); } -exports.parseOptions = parseOptions; -// Expands wildcards with matching (ie. existing) file names. -// For example: -// expand(['file*.js']) = ['file1.js', 'file2.js', ...] -// (if the files 'file1.js', 'file2.js', etc, exist in the current dir) -function expand(list) { - if (!Array.isArray(list)) { - throw new TypeError('must be an array'); - } - var expanded = []; - list.forEach(function (listEl) { - // Don't expand non-strings - if (typeof listEl !== 'string') { - expanded.push(listEl); - } else { - var ret; - try { - ret = glob.sync(listEl, config.globOptions); - // if nothing matched, interpret the string literally - ret = ret.length > 0 ? ret : [listEl]; - } catch (e) { - // if glob fails, interpret the string literally - ret = [listEl]; - } - expanded = expanded.concat(ret); - } - }); - return expanded; +function isBareSpecifier(specifier) { + return specifier[0] && specifier[0] !== '/' && specifier[0] !== '.'; } -exports.expand = expand; - -// Normalizes Buffer creation, using Buffer.alloc if possible. -// Also provides a good default buffer length for most use cases. -var buffer = typeof Buffer.alloc === 'function' ? - function (len) { - return Buffer.alloc(len || config.bufLength); - } : - function (len) { - return new Buffer(len || config.bufLength); - }; -exports.buffer = buffer; -// Normalizes _unlinkSync() across platforms to match Unix behavior, i.e. -// file can be unlinked even if it's read-only, see https://github.com/joyent/node/issues/3006 -function unlinkSync(file) { - try { - fs.unlinkSync(file); - } catch (e) { - // Try to override file permission - /* istanbul ignore next */ - if (e.code === 'EPERM') { - fs.chmodSync(file, '0666'); - fs.unlinkSync(file); - } else { - throw e; +function isRelativeSpecifier(specifier) { + if (specifier[0] === '.') { + if (specifier.length === 1 || specifier[1] === '/') return true; + if (specifier[1] === '.') { + if (specifier.length === 2 || specifier[2] === '/') return true; } } + return false; } -exports.unlinkSync = unlinkSync; - -// wrappers around common.statFollowLinks and common.statNoFollowLinks that clarify intent -// and improve readability -function statFollowLinks() { - return fs.statSync.apply(fs, arguments); -} -exports.statFollowLinks = statFollowLinks; -function statNoFollowLinks() { - return fs.lstatSync.apply(fs, arguments); +function shouldBeTreatedAsRelativeOrAbsolutePath(specifier) { + if (specifier === '') return false; + if (specifier[0] === '/') return true; + return isRelativeSpecifier(specifier); } -exports.statNoFollowLinks = statNoFollowLinks; -// e.g. 'shelljs_a5f185d0443ca...' -function randomFileName() { - function randomHash(count) { - if (count === 1) { - return parseInt(16 * Math.random(), 10).toString(16); - } - var hash = ''; - for (var i = 0; i < count; i++) { - hash += randomHash(1); +/** + * @param {string} specifier + * @param {URL} base + * @param {Set} conditions + * @returns {URL} + */ +function moduleResolve(specifier, base, conditions) { + // Order swapped from spec for minor perf gain. + // Ok since relative URLs cannot parse as URLs. + let resolved; + if (shouldBeTreatedAsRelativeOrAbsolutePath(specifier)) { + resolved = new URL(specifier, base); + } else if (specifier[0] === '#') { + ({ resolved } = packageImportsResolve(specifier, base, conditions)); + } else { + try { + resolved = new URL(specifier); + } catch { + resolved = packageResolve(specifier, base, conditions); } - return hash; } - - return 'shelljs_' + randomHash(20); + return finalizeResolution(resolved, base); } -exports.randomFileName = randomFileName; - -// Common wrapper for all Unix-like commands that performs glob expansion, -// command-logging, and other nice things -function wrap(cmd, fn, options) { - options = options || {}; - return function () { - var retValue = null; - state.currentCmd = cmd; - state.error = null; - state.errorCode = 0; +/** + * Try to resolve an import as a CommonJS module + * @param {string} specifier + * @param {string} parentURL + * @returns {boolean|string} + */ +function resolveAsCommonJS(specifier, parentURL) { + try { + const parent = fileURLToPath(parentURL); + const tmpModule = new CJSModule(parent, null); + tmpModule.paths = CJSModule._nodeModulePaths(parent); - try { - var args = [].slice.call(arguments, 0); + let found = CJSModule._resolveFilename(specifier, tmpModule, false); - // Log the command to stderr, if appropriate - if (config.verbose) { - console.error.apply(console, [cmd].concat(args)); + // If it is a relative specifier return the relative path + // to the parent + if (isRelativeSpecifier(specifier)) { + found = relative(parent, found); + // Add '.separator if the path does not start with '..separator' + // This should be a safe assumption because when loading + // esm modules there should be always a file specified so + // there should not be a specifier like '..' or '.' + if (!StringPrototypeStartsWith(found, `..${sep}`)) { + found = `.${sep}${found}`; } + } else if (isBareSpecifier(specifier)) { + // If it is a bare specifier return the relative path within the + // module + const pkg = StringPrototypeSplit(specifier, '/')[0]; + const index = StringPrototypeIndexOf(found, pkg); + if (index !== -1) { + found = StringPrototypeSlice(found, index); + } + } + // Normalize the path separator to give a valid suggestion + // on Windows + if (process.platform === 'win32') { + found = StringPrototypeReplace(found, new RegExp(`\\${sep}`, 'g'), '/'); + } + return found; + } catch { + return false; + } +} - // If this is coming from a pipe, let's set the pipedValue (otherwise, set - // it to the empty string) - state.pipedValue = (this && typeof this.stdout === 'string') ? this.stdout : ''; - - if (options.unix === false) { // this branch is for exec() - retValue = fn.apply(this, args); - } else { // and this branch is for everything else - if (isObject(args[0]) && args[0].constructor.name === 'Object') { - // a no-op, allowing the syntax `touch({'-r': file}, ...)` - } else if (args.length === 0 || typeof args[0] !== 'string' || args[0].length <= 1 || args[0][0] !== '-') { - args.unshift(''); // only add dummy option if '-option' not already present - } - - // flatten out arrays that are arguments, to make the syntax: - // `cp([file1, file2, file3], dest);` - // equivalent to: - // `cp(file1, file2, file3, dest);` - args = args.reduce(function (accum, cur) { - if (Array.isArray(cur)) { - return accum.concat(cur); - } - accum.push(cur); - return accum; - }, []); - - // Convert ShellStrings (basically just String objects) to regular strings - args = args.map(function (arg) { - if (isObject(arg) && arg.constructor.name === 'String') { - return arg.toString(); - } - return arg; - }); - - // Expand the '~' if appropriate - var homeDir = os.homedir(); - args = args.map(function (arg) { - if (typeof arg === 'string' && arg.slice(0, 2) === '~/' || arg === '~') { - return arg.replace(/^~/, homeDir); - } - return arg; - }); +function defaultResolve(specifier, context = {}, defaultResolveUnused) { + let { parentURL, conditions } = context; + if (parentURL && policy != null && policy.manifest) { + const redirects = policy.manifest.getDependencyMapper(parentURL); + if (redirects) { + const { resolve, reaction } = redirects; + const destination = resolve(specifier, new SafeSet(conditions)); + let missing = true; + if (destination === true) { + missing = false; + } else if (destination) { + const href = destination.href; + return { url: href }; + } + if (missing) { + reaction(new ERR_MANIFEST_DEPENDENCY_MISSING( + parentURL, + specifier, + ArrayPrototypeJoin([...conditions], ', ')) + ); + } + } + } + let parsed; + try { + parsed = new URL(specifier); + if (parsed.protocol === 'data:') { + return { + url: specifier + }; + } + } catch {} + if (parsed && parsed.protocol === builtinModuleProtocol) + return { url: specifier }; + if (parsed && parsed.protocol !== 'file:' && parsed.protocol !== 'data:') + throw new ERR_UNSUPPORTED_ESM_URL_SCHEME(parsed); + if (NativeModule.canBeRequiredByUsers(specifier)) { + return { + url: builtinModuleProtocol + specifier + }; + } + if (parentURL && StringPrototypeStartsWith(parentURL, 'data:')) { + // This is gonna blow up, we want the error + new URL(specifier, parentURL); + } - // Perform glob-expansion on all arguments after globStart, but preserve - // the arguments before it (like regexes for sed and grep) - if (!config.noglob && options.allowGlobbing === true) { - args = args.slice(0, options.globStart).concat(expand(args.slice(options.globStart))); - } + const isMain = parentURL === undefined; + if (isMain) { + parentURL = pathToFileURL(`${process.cwd()}/`).href; - try { - // parse options if options are provided - if (isObject(options.cmdOptions)) { - args[0] = parseOptions(args[0], options.cmdOptions); - } + // This is the initial entry point to the program, and --input-type has + // been passed as an option; but --input-type can only be used with + // --eval, --print or STDIN string input. It is not allowed with file + // input, to avoid user confusion over how expansive the effect of the + // flag should be (i.e. entry point only, package scope surrounding the + // entry point, etc.). + if (typeFlag) + throw new ERR_INPUT_TYPE_NOT_ALLOWED(); + } - retValue = fn.apply(this, args); - } catch (e) { - /* istanbul ignore else */ - if (e.msg === 'earlyExit') { - retValue = e.retValue; - } else { - throw e; // this is probably a bug that should be thrown up the call stack - } - } + conditions = getConditionsSet(conditions); + let url; + try { + url = moduleResolve(specifier, parentURL, conditions); + } catch (error) { + // Try to give the user a hint of what would have been the + // resolved CommonJS module + if (error.code === 'ERR_MODULE_NOT_FOUND' || + error.code === 'ERR_UNSUPPORTED_DIR_IMPORT') { + if (StringPrototypeStartsWith(specifier, 'file://')) { + specifier = fileURLToPath(specifier); } - } catch (e) { - /* istanbul ignore next */ - if (!state.error) { - // If state.error hasn't been set it's an error thrown by Node, not us - probably a bug... - e.name = 'ShellJSInternalError'; - throw e; + const found = resolveAsCommonJS(specifier, parentURL); + if (found) { + // Modify the stack and message string to include the hint + const lines = StringPrototypeSplit(error.stack, '\n'); + const hint = `Did you mean to import ${found}?`; + error.stack = + ArrayPrototypeShift(lines) + '\n' + + hint + '\n' + + ArrayPrototypeJoin(lines, '\n'); + error.message += `\n${hint}`; } - if (config.fatal) throw e; - } - - if (options.wrapOutput && - (typeof retValue === 'string' || Array.isArray(retValue))) { - retValue = new ShellString(retValue, state.error, state.errorCode); } + throw error; + } - state.currentCmd = 'shell.js'; - return retValue; - }; -} // wrap -exports.wrap = wrap; + if (isMain ? !preserveSymlinksMain : !preserveSymlinks) { + const urlPath = fileURLToPath(url); + const real = realpathSync(urlPath, { + // [internalFS.realpathCacheKey]: realpathCache + }); + const old = url; + url = pathToFileURL( + real + (StringPrototypeEndsWith(urlPath, sep) ? '/' : '')); + url.search = old.search; + url.hash = old.hash; + } -// This returns all the input that is piped into the current command (or the -// empty string, if this isn't on the right-hand side of a pipe -function _readFromPipe() { - return state.pipedValue; + return { url: `${url}` }; } -exports.readFromPipe = _readFromPipe; -var DEFAULT_WRAP_OPTIONS = { - allowGlobbing: true, - canReceivePipe: false, - cmdOptions: null, - globStart: 1, - pipeOnly: false, - wrapOutput: true, - unix: true, +return { + DEFAULT_CONDITIONS, + defaultResolve, + encodedSepRegEx, + getPackageType, + packageExportsResolve, + packageImportsResolve +}; +} +module.exports = { + createResolve }; -// This is populated during plugin registration -var pipeMethods = []; -// Register a new ShellJS command -function _register(name, implementation, wrapOptions) { - wrapOptions = wrapOptions || {}; +/***/ }), - // Validate options - Object.keys(wrapOptions).forEach(function (option) { - if (!DEFAULT_WRAP_OPTIONS.hasOwnProperty(option)) { - throw new Error("Unknown option '" + option + "'"); - } - if (typeof wrapOptions[option] !== typeof DEFAULT_WRAP_OPTIONS[option]) { - throw new TypeError("Unsupported type '" + typeof wrapOptions[option] + - "' for option '" + option + "'"); - } - }); +/***/ 73104: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { - // If an option isn't specified, use the default - wrapOptions = Object.assign({}, DEFAULT_WRAP_OPTIONS, wrapOptions); +"use strict"; +// copied from https://github.com/nodejs/node/blob/v15.3.0/lib/internal/modules/package_json_reader.js - if (shell.hasOwnProperty(name)) { - throw new Error('Command `' + name + '` already exists'); - } - if (wrapOptions.pipeOnly) { - wrapOptions.canReceivePipe = true; - shellMethods[name] = wrap(name, implementation, wrapOptions); - } else { - shell[name] = wrap(name, implementation, wrapOptions); +const { SafeMap } = __nccwpck_require__(57523); +const { internalModuleReadJSON } = __nccwpck_require__(69149); +const { pathToFileURL } = __nccwpck_require__(57310); +const { toNamespacedPath } = __nccwpck_require__(71017); +// const { getOptionValue } = require('./node-options'); + +const cache = new SafeMap(); + +let manifest; + +/** + * @param {string} jsonPath + * @return {{string: string, containsKeys: boolean}} + */ +function read(jsonPath) { + if (cache.has(jsonPath)) { + return cache.get(jsonPath); } - if (wrapOptions.canReceivePipe) { - pipeMethods.push(name); + const [string, containsKeys] = internalModuleReadJSON( + toNamespacedPath(jsonPath) + ); + const result = { string, containsKeys }; + if (string !== undefined) { + if (manifest === undefined) { + // manifest = getOptionValue('--experimental-policy') ? + // require('internal/process/policy').manifest : + // null; + // disabled for now. I am not sure if/how we should support this + manifest = null; + } + if (manifest !== null) { + const jsonURL = pathToFileURL(jsonPath); + manifest.assertIntegrity(jsonURL, string); + } } + cache.set(jsonPath, result); + return result; } -exports.register = _register; + +module.exports = { read }; /***/ }), -/***/ 6135: +/***/ 18088: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { -var fs = __nccwpck_require__(57147); -var path = __nccwpck_require__(71017); -var common = __nccwpck_require__(17673); - -common.register('cp', _cp, { - cmdOptions: { - 'f': '!no_force', - 'n': 'no_force', - 'u': 'update', - 'R': 'recursive', - 'r': 'recursive', - 'L': 'followsymlink', - 'P': 'noFollowsymlink', - }, - wrapOutput: false, -}); - -// Buffered file copy, synchronous -// (Using readFileSync() + writeFileSync() could easily cause a memory overflow -// with large files) -function copyFileSync(srcFile, destFile, options) { - if (!fs.existsSync(srcFile)) { - common.error('copyFileSync: no such file or directory: ' + srcFile); - } +"use strict"; +// copied from https://github.com/nodejs/node/blob/88799930794045795e8abac874730f9eba7e2300/lib/internal/repl/await.js - var isWindows = process.platform === 'win32'; - // Check the mtimes of the files if the '-u' flag is provided - try { - if (options.update && common.statFollowLinks(srcFile).mtime < fs.statSync(destFile).mtime) { - return; - } - } catch (e) { - // If we're here, destFile probably doesn't exist, so just do a normal copy - } +const { + ArrayFrom, + ArrayPrototypeForEach, + ArrayPrototypeIncludes, + ArrayPrototypeJoin, + ArrayPrototypePop, + ArrayPrototypePush, + FunctionPrototype, + ObjectKeys, + RegExpPrototypeSymbolReplace, + StringPrototypeEndsWith, + StringPrototypeIncludes, + StringPrototypeIndexOf, + StringPrototypeRepeat, + StringPrototypeSplit, + StringPrototypeStartsWith, + SyntaxError, +} = __nccwpck_require__(57523); - if (common.statNoFollowLinks(srcFile).isSymbolicLink() && !options.followsymlink) { - try { - common.statNoFollowLinks(destFile); - common.unlinkSync(destFile); // re-link it - } catch (e) { - // it doesn't exist, so no work needs to be done - } +const parser = (__nccwpck_require__(69241).Parser); +const walk = __nccwpck_require__(95141); +const { Recoverable } = __nccwpck_require__(38102); - var symlinkFull = fs.readlinkSync(srcFile); - fs.symlinkSync(symlinkFull, destFile, isWindows ? 'junction' : null); - } else { - var buf = common.buffer(); - var bufLength = buf.length; - var bytesRead = bufLength; - var pos = 0; - var fdr = null; - var fdw = null; +function isTopLevelDeclaration(state) { + return state.ancestors[state.ancestors.length - 2] === state.body; +} - try { - fdr = fs.openSync(srcFile, 'r'); - } catch (e) { - /* istanbul ignore next */ - common.error('copyFileSync: could not read src file (' + srcFile + ')'); +const noop = FunctionPrototype; +const visitorsWithoutAncestors = { + ClassDeclaration(node, state, c) { + if (isTopLevelDeclaration(state)) { + state.prepend(node, `${node.id.name}=`); + ArrayPrototypePush( + state.hoistedDeclarationStatements, + `let ${node.id.name}; ` + ); } - try { - fdw = fs.openSync(destFile, 'w'); - } catch (e) { - /* istanbul ignore next */ - common.error('copyFileSync: could not write to dest file (code=' + e.code + '):' + destFile); + walk.base.ClassDeclaration(node, state, c); + }, + ForOfStatement(node, state, c) { + if (node.await === true) { + state.containsAwait = true; } + walk.base.ForOfStatement(node, state, c); + }, + FunctionDeclaration(node, state, c) { + state.prepend(node, `${node.id.name}=`); + ArrayPrototypePush( + state.hoistedDeclarationStatements, + `var ${node.id.name}; ` + ); + }, + FunctionExpression: noop, + ArrowFunctionExpression: noop, + MethodDefinition: noop, + AwaitExpression(node, state, c) { + state.containsAwait = true; + walk.base.AwaitExpression(node, state, c); + }, + ReturnStatement(node, state, c) { + state.containsReturn = true; + walk.base.ReturnStatement(node, state, c); + }, + VariableDeclaration(node, state, c) { + const variableKind = node.kind; + const isIterableForDeclaration = ArrayPrototypeIncludes( + ['ForOfStatement', 'ForInStatement'], + state.ancestors[state.ancestors.length - 2].type + ); - while (bytesRead === bufLength) { - bytesRead = fs.readSync(fdr, buf, 0, bufLength, pos); - fs.writeSync(fdw, buf, 0, bytesRead); - pos += bytesRead; - } + if (variableKind === 'var' || isTopLevelDeclaration(state)) { + state.replace( + node.start, + node.start + variableKind.length + (isIterableForDeclaration ? 1 : 0), + variableKind === 'var' && isIterableForDeclaration ? + '' : + 'void' + (node.declarations.length === 1 ? '' : ' (') + ); - fs.closeSync(fdr); - fs.closeSync(fdw); + if (!isIterableForDeclaration) { + ArrayPrototypeForEach(node.declarations, (decl) => { + state.prepend(decl, '('); + state.append(decl, decl.init ? ')' : '=undefined)'); + }); - fs.chmodSync(destFile, common.statFollowLinks(srcFile).mode); - } -} + if (node.declarations.length !== 1) { + state.append(node.declarations[node.declarations.length - 1], ')'); + } + } -// Recursively copies 'sourceDir' into 'destDir' -// Adapted from https://github.com/ryanmcgrath/wrench-js -// -// Copyright (c) 2010 Ryan McGrath -// Copyright (c) 2012 Artur Adib -// -// Licensed under the MIT License -// http://www.opensource.org/licenses/mit-license.php -function cpdirSyncRecursive(sourceDir, destDir, currentDepth, opts) { - if (!opts) opts = {}; + const variableIdentifiersToHoist = [ + ['var', []], + ['let', []], + ]; + function registerVariableDeclarationIdentifiers(node) { + switch (node.type) { + case 'Identifier': + ArrayPrototypePush( + variableIdentifiersToHoist[variableKind === 'var' ? 0 : 1][1], + node.name + ); + break; + case 'ObjectPattern': + ArrayPrototypeForEach(node.properties, (property) => { + registerVariableDeclarationIdentifiers(property.value); + }); + break; + case 'ArrayPattern': + ArrayPrototypeForEach(node.elements, (element) => { + registerVariableDeclarationIdentifiers(element); + }); + break; + } + } - // Ensure there is not a run away recursive copy - if (currentDepth >= common.config.maxdepth) return; - currentDepth++; + ArrayPrototypeForEach(node.declarations, (decl) => { + registerVariableDeclarationIdentifiers(decl.id); + }); - var isWindows = process.platform === 'win32'; + ArrayPrototypeForEach( + variableIdentifiersToHoist, + ({ 0: kind, 1: identifiers }) => { + if (identifiers.length > 0) { + ArrayPrototypePush( + state.hoistedDeclarationStatements, + `${kind} ${ArrayPrototypeJoin(identifiers, ', ')}; ` + ); + } + } + ); + } - // Create the directory where all our junk is moving to; read the mode of the - // source directory and mirror it - try { - fs.mkdirSync(destDir); - } catch (e) { - // if the directory already exists, that's okay - if (e.code !== 'EEXIST') throw e; + walk.base.VariableDeclaration(node, state, c); } +}; - var files = fs.readdirSync(sourceDir); - - for (var i = 0; i < files.length; i++) { - var srcFile = sourceDir + '/' + files[i]; - var destFile = destDir + '/' + files[i]; - var srcFileStat = common.statNoFollowLinks(srcFile); - - var symlinkFull; - if (opts.followsymlink) { - if (cpcheckcycle(sourceDir, srcFile)) { - // Cycle link found. - console.error('Cycle link found.'); - symlinkFull = fs.readlinkSync(srcFile); - fs.symlinkSync(symlinkFull, destFile, isWindows ? 'junction' : null); - continue; - } +const visitors = {}; +for (const nodeType of ObjectKeys(walk.base)) { + const callback = visitorsWithoutAncestors[nodeType] || walk.base[nodeType]; + visitors[nodeType] = (node, state, c) => { + const isNew = node !== state.ancestors[state.ancestors.length - 1]; + if (isNew) { + ArrayPrototypePush(state.ancestors, node); } - if (srcFileStat.isDirectory()) { - /* recursion this thing right on back. */ - cpdirSyncRecursive(srcFile, destFile, currentDepth, opts); - } else if (srcFileStat.isSymbolicLink() && !opts.followsymlink) { - symlinkFull = fs.readlinkSync(srcFile); - try { - common.statNoFollowLinks(destFile); - common.unlinkSync(destFile); // re-link it - } catch (e) { - // it doesn't exist, so no work needs to be done - } - fs.symlinkSync(symlinkFull, destFile, isWindows ? 'junction' : null); - } else if (srcFileStat.isSymbolicLink() && opts.followsymlink) { - srcFileStat = common.statFollowLinks(srcFile); - if (srcFileStat.isDirectory()) { - cpdirSyncRecursive(srcFile, destFile, currentDepth, opts); - } else { - copyFileSync(srcFile, destFile, opts); - } - } else { - /* At this point, we've hit a file actually worth copying... so copy it on over. */ - if (fs.existsSync(destFile) && opts.no_force) { - common.log('skipping existing file: ' + files[i]); - } else { - copyFileSync(srcFile, destFile, opts); - } + callback(node, state, c); + if (isNew) { + ArrayPrototypePop(state.ancestors); } - } // for files - - // finally change the mode for the newly created directory (otherwise, we - // couldn't add files to a read-only directory). - var checkDir = common.statFollowLinks(sourceDir); - fs.chmodSync(destDir, checkDir.mode); -} // cpdirSyncRecursive + }; +} -// Checks if cureent file was created recently -function checkRecentCreated(sources, index) { - var lookedSource = sources[index]; - return sources.slice(0, index).some(function (src) { - return path.basename(src) === path.basename(lookedSource); - }); -} - -function cpcheckcycle(sourceDir, srcFile) { - var srcFileStat = common.statNoFollowLinks(srcFile); - if (srcFileStat.isSymbolicLink()) { - // Do cycle check. For example: - // $ mkdir -p 1/2/3/4 - // $ cd 1/2/3/4 - // $ ln -s ../../3 link - // $ cd ../../../.. - // $ cp -RL 1 copy - var cyclecheck = common.statFollowLinks(srcFile); - if (cyclecheck.isDirectory()) { - var sourcerealpath = fs.realpathSync(sourceDir); - var symlinkrealpath = fs.realpathSync(srcFile); - var re = new RegExp(symlinkrealpath); - if (re.test(sourcerealpath)) { - return true; - } - } - } - return false; -} - -//@ -//@ ### cp([options,] source [, source ...], dest) -//@ ### cp([options,] source_array, dest) -//@ -//@ Available options: -//@ -//@ + `-f`: force (default behavior) -//@ + `-n`: no-clobber -//@ + `-u`: only copy if `source` is newer than `dest` -//@ + `-r`, `-R`: recursive -//@ + `-L`: follow symlinks -//@ + `-P`: don't follow symlinks -//@ -//@ Examples: -//@ -//@ ```javascript -//@ cp('file1', 'dir1'); -//@ cp('-R', 'path/to/dir/', '~/newCopy/'); -//@ cp('-Rf', '/tmp/*', '/usr/local/*', '/home/tmp'); -//@ cp('-Rf', ['/tmp/*', '/usr/local/*'], '/home/tmp'); // same as above -//@ ``` -//@ -//@ Copies files. -function _cp(options, sources, dest) { - // If we're missing -R, it actually implies -L (unless -P is explicit) - if (options.followsymlink) { - options.noFollowsymlink = false; - } - if (!options.recursive && !options.noFollowsymlink) { - options.followsymlink = true; - } - - // Get sources, dest - if (arguments.length < 3) { - common.error('missing and/or '); - } else { - sources = [].slice.call(arguments, 1, arguments.length - 1); - dest = arguments[arguments.length - 1]; +function processTopLevelAwait(src) { + const wrapPrefix = '(async () => { '; + const wrapped = `${wrapPrefix}${src} })()`; + const wrappedArray = ArrayFrom(wrapped); + let root; + try { + root = parser.parse(wrapped, { ecmaVersion: 'latest' }); + } catch (e) { + if (StringPrototypeStartsWith(e.message, 'Unterminated ')) + throw new Recoverable(e); + // If the parse error is before the first "await", then use the execution + // error. Otherwise we must emit this parse error, making it look like a + // proper syntax error. + const awaitPos = StringPrototypeIndexOf(src, 'await'); + const errPos = e.pos - wrapPrefix.length; + if (awaitPos > errPos) + return null; + // Convert keyword parse errors on await into their original errors when + // possible. + if (errPos === awaitPos + 6 && + StringPrototypeIncludes(e.message, 'Expecting Unicode escape sequence')) + return null; + if (errPos === awaitPos + 7 && + StringPrototypeIncludes(e.message, 'Unexpected token')) + return null; + const line = e.loc.line; + const column = line === 1 ? e.loc.column - wrapPrefix.length : e.loc.column; + let message = '\n' + StringPrototypeSplit(src, '\n')[line - 1] + '\n' + + StringPrototypeRepeat(' ', column) + + '^\n\n' + RegExpPrototypeSymbolReplace(/ \([^)]+\)/, e.message, ''); + // V8 unexpected token errors include the token string. + if (StringPrototypeEndsWith(message, 'Unexpected token')) + message += " '" + + // Wrapper end may cause acorn to report error position after the source + ((src.length - 1) >= (e.pos - wrapPrefix.length) + ? src[e.pos - wrapPrefix.length] + : src[src.length - 1]) + + "'"; + // eslint-disable-next-line no-restricted-syntax + throw new SyntaxError(message); } + const body = root.body[0].expression.callee.body; + const state = { + body, + ancestors: [], + hoistedDeclarationStatements: [], + replace(from, to, str) { + for (let i = from; i < to; i++) { + wrappedArray[i] = ''; + } + if (from === to) str += wrappedArray[from]; + wrappedArray[from] = str; + }, + prepend(node, str) { + wrappedArray[node.start] = str + wrappedArray[node.start]; + }, + append(node, str) { + wrappedArray[node.end - 1] += str; + }, + containsAwait: false, + containsReturn: false + }; - var destExists = fs.existsSync(dest); - var destStat = destExists && common.statFollowLinks(dest); + walk.recursive(body, state, visitors); - // Dest is not existing dir, but multiple sources given - if ((!destExists || !destStat.isDirectory()) && sources.length > 1) { - common.error('dest is not a directory (too many sources)'); + // Do not transform if + // 1. False alarm: there isn't actually an await expression. + // 2. There is a top-level return, which is not allowed. + if (!state.containsAwait || state.containsReturn) { + return null; } - // Dest is an existing file, but -n is given - if (destExists && destStat.isFile() && options.no_force) { - return new common.ShellString('', '', 0); + const last = body.body[body.body.length - 1]; + if (last.type === 'ExpressionStatement') { + // For an expression statement of the form + // ( expr ) ; + // ^^^^^^^^^^ // last + // ^^^^ // last.expression + // + // We do not want the left parenthesis before the `return` keyword; + // therefore we prepend the `return (` to `last`. + // + // On the other hand, we do not want the right parenthesis after the + // semicolon. Since there can only be more right parentheses between + // last.expression.end and the semicolon, appending one more to + // last.expression should be fine. + state.prepend(last, 'return ('); + state.append(last.expression, ')'); } - sources.forEach(function (src, srcIndex) { - if (!fs.existsSync(src)) { - if (src === '') src = "''"; // if src was empty string, display empty string - common.error('no such file or directory: ' + src, { continue: true }); - return; // skip file - } - var srcStat = common.statFollowLinks(src); - if (!options.noFollowsymlink && srcStat.isDirectory()) { - if (!options.recursive) { - // Non-Recursive - common.error("omitting directory '" + src + "'", { continue: true }); - } else { - // Recursive - // 'cp /a/source dest' should create 'source' in 'dest' - var newDest = (destStat && destStat.isDirectory()) ? - path.join(dest, path.basename(src)) : - dest; - - try { - common.statFollowLinks(path.dirname(dest)); - cpdirSyncRecursive(src, newDest, 0, { no_force: options.no_force, followsymlink: options.followsymlink }); - } catch (e) { - /* istanbul ignore next */ - common.error("cannot create directory '" + dest + "': No such file or directory"); - } - } - } else { - // If here, src is a file - - // When copying to '/path/dir': - // thisDest = '/path/dir/file1' - var thisDest = dest; - if (destStat && destStat.isDirectory()) { - thisDest = path.normalize(dest + '/' + path.basename(src)); - } - - var thisDestExists = fs.existsSync(thisDest); - if (thisDestExists && checkRecentCreated(sources, srcIndex)) { - // cannot overwrite file created recently in current execution, but we want to continue copying other files - if (!options.no_force) { - common.error("will not overwrite just-created '" + thisDest + "' with '" + src + "'", { continue: true }); - } - return; - } - - if (thisDestExists && options.no_force) { - return; // skip file - } - - if (path.relative(src, thisDest) === '') { - // a file cannot be copied to itself, but we want to continue copying other files - common.error("'" + thisDest + "' and '" + src + "' are the same file", { continue: true }); - return; - } - - copyFileSync(src, thisDest, options); - } - }); // forEach(src) - - return new common.ShellString('', common.state.error, common.state.errorCode); + return ( + ArrayPrototypeJoin(state.hoistedDeclarationStatements, '') + + ArrayPrototypeJoin(wrappedArray, '') + ); } -module.exports = _cp; - -/***/ }), - -/***/ 80220: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { +module.exports = { + processTopLevelAwait +}; -var common = __nccwpck_require__(17673); -var _cd = __nccwpck_require__(51829); -var path = __nccwpck_require__(71017); -common.register('dirs', _dirs, { - wrapOutput: false, -}); -common.register('pushd', _pushd, { - wrapOutput: false, -}); -common.register('popd', _popd, { - wrapOutput: false, -}); +/***/ }), -// Pushd/popd/dirs internals -var _dirStack = []; +/***/ 69149: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { -function _isStackIndex(index) { - return (/^[\-+]\d+$/).test(index); -} +const fs = __nccwpck_require__(57147); +const {versionGteLt} = __nccwpck_require__(26239); -function _parseStackIndex(index) { - if (_isStackIndex(index)) { - if (Math.abs(index) < _dirStack.length + 1) { // +1 for pwd - return (/^-/).test(index) ? Number(index) - 1 : Number(index); - } - common.error(index + ': directory stack index out of range'); - } else { - common.error(index + ': invalid number'); +// In node's core, this is implemented in C +// https://github.com/nodejs/node/blob/v15.3.0/src/node_file.cc#L891-L985 +/** + * @param {string} path + * @returns {[] | [string, boolean]} + */ +function internalModuleReadJSON(path) { + let string + try { + string = fs.readFileSync(path, 'utf8') + } catch (e) { + if (e.code === 'ENOENT') return [] + throw e } + // Node's implementation checks for the presence of relevant keys: main, name, type, exports, imports + // Node does this for performance to skip unnecessary parsing. + // This would slow us down and, based on our usage, we can skip it. + const containsKeys = true + return [string, containsKeys] } -function _actualDirStack() { - return [process.cwd()].concat(_dirStack); -} - -//@ -//@ ### pushd([options,] [dir | '-N' | '+N']) -//@ -//@ Available options: -//@ -//@ + `-n`: Suppresses the normal change of directory when adding directories to the stack, so that only the stack is manipulated. -//@ + `-q`: Supresses output to the console. -//@ -//@ Arguments: -//@ -//@ + `dir`: Sets the current working directory to the top of the stack, then executes the equivalent of `cd dir`. -//@ + `+N`: Brings the Nth directory (counting from the left of the list printed by dirs, starting with zero) to the top of the list by rotating the stack. -//@ + `-N`: Brings the Nth directory (counting from the right of the list printed by dirs, starting with zero) to the top of the list by rotating the stack. -//@ -//@ Examples: -//@ -//@ ```javascript -//@ // process.cwd() === '/usr' -//@ pushd('/etc'); // Returns /etc /usr -//@ pushd('+1'); // Returns /usr /etc -//@ ``` -//@ -//@ Save the current directory on the top of the directory stack and then `cd` to `dir`. With no arguments, `pushd` exchanges the top two directories. Returns an array of paths in the stack. -function _pushd(options, dir) { - if (_isStackIndex(options)) { - dir = options; - options = ''; - } - - options = common.parseOptions(options, { - 'n': 'no-cd', - 'q': 'quiet', - }); - - var dirs = _actualDirStack(); - - if (dir === '+0') { - return dirs; // +0 is a noop - } else if (!dir) { - if (dirs.length > 1) { - dirs = dirs.splice(1, 1).concat(dirs); - } else { - return common.error('no other directory'); - } - } else if (_isStackIndex(dir)) { - var n = _parseStackIndex(dir); - dirs = dirs.slice(n).concat(dirs.slice(0, n)); - } else { - if (options['no-cd']) { - dirs.splice(1, 0, dir); - } else { - dirs.unshift(dir); - } - } - - if (options['no-cd']) { - dirs = dirs.slice(1); - } else { - dir = path.resolve(dirs.shift()); - _cd('', dir); - } - - _dirStack = dirs; - return _dirs(options.quiet ? '-q' : ''); +// In node's core, this is implemented in C +// https://github.com/nodejs/node/blob/63e7dc1e5c71b70c80ed9eda230991edb00811e2/src/node_file.cc#L987-L1005 +/** + * @param {string} path + * @returns {number} 0 = file, 1 = dir, negative = error + */ +function internalModuleStat(path) { + const stat = fs.statSync(path, { throwIfNoEntry: false }); + if(!stat) return -1; + if(stat.isFile()) return 0; + if(stat.isDirectory()) return 1; } -exports.pushd = _pushd; - -//@ -//@ -//@ ### popd([options,] ['-N' | '+N']) -//@ -//@ Available options: -//@ -//@ + `-n`: Suppress the normal directory change when removing directories from the stack, so that only the stack is manipulated. -//@ + `-q`: Supresses output to the console. -//@ -//@ Arguments: -//@ -//@ + `+N`: Removes the Nth directory (counting from the left of the list printed by dirs), starting with zero. -//@ + `-N`: Removes the Nth directory (counting from the right of the list printed by dirs), starting with zero. -//@ -//@ Examples: -//@ -//@ ```javascript -//@ echo(process.cwd()); // '/usr' -//@ pushd('/etc'); // '/etc /usr' -//@ echo(process.cwd()); // '/etc' -//@ popd(); // '/usr' -//@ echo(process.cwd()); // '/usr' -//@ ``` -//@ -//@ When no arguments are given, `popd` removes the top directory from the stack and performs a `cd` to the new top directory. The elements are numbered from 0, starting at the first directory listed with dirs (i.e., `popd` is equivalent to `popd +0`). Returns an array of paths in the stack. -function _popd(options, index) { - if (_isStackIndex(options)) { - index = options; - options = ''; - } - - options = common.parseOptions(options, { - 'n': 'no-cd', - 'q': 'quiet', - }); - - if (!_dirStack.length) { - return common.error('directory stack empty'); - } - - index = _parseStackIndex(index || '+0'); - if (options['no-cd'] || index > 0 || _dirStack.length + index === 0) { - index = index > 0 ? index - 1 : index; - _dirStack.splice(index, 1); - } else { - var dir = path.resolve(_dirStack.shift()); - _cd('', dir); +/** + * @param {string} path + * @returns {number} 0 = file, 1 = dir, negative = error + */ +function internalModuleStatInefficient(path) { + try { + const stat = fs.statSync(path); + if(stat.isFile()) return 0; + if(stat.isDirectory()) return 1; + } catch(e) { + return -e.errno || -1; } - - return _dirs(options.quiet ? '-q' : ''); } -exports.popd = _popd; -//@ -//@ -//@ ### dirs([options | '+N' | '-N']) -//@ -//@ Available options: -//@ -//@ + `-c`: Clears the directory stack by deleting all of the elements. -//@ + `-q`: Supresses output to the console. -//@ -//@ Arguments: -//@ -//@ + `+N`: Displays the Nth directory (counting from the left of the list printed by dirs when invoked without options), starting with zero. -//@ + `-N`: Displays the Nth directory (counting from the right of the list printed by dirs when invoked without options), starting with zero. -//@ -//@ Display the list of currently remembered directories. Returns an array of paths in the stack, or a single path if `+N` or `-N` was specified. -//@ -//@ See also: `pushd`, `popd` -function _dirs(options, index) { - if (_isStackIndex(options)) { - index = options; - options = ''; - } - - options = common.parseOptions(options, { - 'c': 'clear', - 'q': 'quiet', - }); +const statSupportsThrowIfNoEntry = versionGteLt(process.versions.node, '15.3.0') || + versionGteLt(process.versions.node, '14.17.0', '15.0.0'); - if (options.clear) { - _dirStack = []; - return _dirStack; - } +module.exports = { + internalModuleReadJSON, + internalModuleStat: statSupportsThrowIfNoEntry ? internalModuleStat : internalModuleStatInefficient +}; - var stack = _actualDirStack(); - if (index) { - index = _parseStackIndex(index); +/***/ }), - if (index < 0) { - index = stack.length + index; - } +/***/ 12061: +/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { - if (!options.quiet) { - common.log(stack[index]); - } - return stack[index]; - } - if (!options.quiet) { - common.log(stack.join(' ')); +// Node imports this from 'internal/bootstrap/loaders' +const Module = __nccwpck_require__(98188); +const NativeModule = { + canBeRequiredByUsers(specifier) { + return Module.builtinModules.includes(specifier) } - - return stack; -} -exports.dirs = _dirs; +}; +exports.NativeModule = NativeModule; /***/ }), -/***/ 99534: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { - -var format = (__nccwpck_require__(73837).format); - -var common = __nccwpck_require__(17673); - -common.register('echo', _echo, { - allowGlobbing: false, -}); +/***/ 92060: +/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { -//@ -//@ ### echo([options,] string [, string ...]) -//@ -//@ Available options: -//@ -//@ + `-e`: interpret backslash escapes (default) -//@ + `-n`: remove trailing newline from output -//@ -//@ Examples: -//@ -//@ ```javascript -//@ echo('hello world'); -//@ var str = echo('hello world'); -//@ echo('-n', 'no newline at end'); -//@ ``` -//@ -//@ Prints `string` to stdout, and returns string with additional utility methods -//@ like `.to()`. -function _echo(opts) { - // allow strings starting with '-', see issue #20 - var messages = [].slice.call(arguments, opts ? 0 : 1); - var options = {}; +// Replacement for node's internal 'internal/options' module - // If the first argument starts with '-', parse it as options string. - // If parseOptions throws, it wasn't an options string. - try { - options = common.parseOptions(messages[0], { - 'e': 'escapes', - 'n': 'no_newline', - }, { - silent: true, - }); +exports.getOptionValue = getOptionValue; +function getOptionValue(opt) { + parseOptions(); + return options[opt]; +} - // Allow null to be echoed - if (messages[0]) { - messages.shift(); +let options; +function parseOptions() { + if (!options) { + options = { + '--preserve-symlinks': false, + '--preserve-symlinks-main': false, + '--input-type': undefined, + '--experimental-specifier-resolution': 'explicit', + '--experimental-policy': undefined, + '--conditions': [], + '--pending-deprecation': false, + ...parseArgv(getNodeOptionsEnvArgv()), + ...parseArgv(process.execArgv), + ...getOptionValuesFromOtherEnvVars() } - } catch (_) { - // Clear out error if an error occurred - common.state.error = null; - } - - var output = format.apply(null, messages); - - // Add newline if -n is not passed. - if (!options.no_newline) { - output += '\n'; } - - process.stdout.write(output); - - return output; -} - -module.exports = _echo; - - -/***/ }), - -/***/ 49862: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { - -var common = __nccwpck_require__(17673); - -//@ -//@ ### error() -//@ -//@ Tests if error occurred in the last command. Returns a truthy value if an -//@ error returned, or a falsy value otherwise. -//@ -//@ **Note**: do not rely on the -//@ return value to be an error message. If you need the last error message, use -//@ the `.stderr` attribute from the last command's return value instead. -function error() { - return common.state.error; } -module.exports = error; - - -/***/ }), - -/***/ 24416: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { -/* module decorator */ module = __nccwpck_require__.nmd(module); -if (require.main !== module) { - throw new Error('This file should not be required'); +function parseArgv(argv) { + return __nccwpck_require__(69888)({ + '--preserve-symlinks': Boolean, + '--preserve-symlinks-main': Boolean, + '--input-type': String, + '--experimental-specifier-resolution': String, + // Legacy alias for node versions prior to 12.16 + '--es-module-specifier-resolution': '--experimental-specifier-resolution', + '--experimental-policy': String, + '--conditions': [String], + '--pending-deprecation': Boolean, + '--experimental-json-modules': Boolean, + '--experimental-wasm-modules': Boolean, + }, { + argv, + permissive: true + }); } -var childProcess = __nccwpck_require__(32081); -var fs = __nccwpck_require__(57147); - -var paramFilePath = process.argv[2]; - -var serializedParams = fs.readFileSync(paramFilePath, 'utf8'); -var params = JSON.parse(serializedParams); - -var cmd = params.command; -var execOptions = params.execOptions; -var pipe = params.pipe; -var stdoutFile = params.stdoutFile; -var stderrFile = params.stderrFile; - -var c = childProcess.exec(cmd, execOptions, function (err) { - if (!err) { - process.exitCode = 0; - } else if (err.code === undefined) { - process.exitCode = 1; - } else { - process.exitCode = err.code; +function getNodeOptionsEnvArgv() { + const errors = []; + const envArgv = ParseNodeOptionsEnvVar(process.env.NODE_OPTIONS || '', errors); + if (errors.length !== 0) { + // TODO: handle errors somehow } -}); - -var stdoutStream = fs.createWriteStream(stdoutFile); -var stderrStream = fs.createWriteStream(stderrFile); - -c.stdout.pipe(stdoutStream); -c.stderr.pipe(stderrStream); -c.stdout.pipe(process.stdout); -c.stderr.pipe(process.stderr); - -if (pipe) { - c.stdin.end(pipe); + return envArgv; } +// Direct JS port of C implementation: https://github.com/nodejs/node/blob/67ba825037b4082d5d16f922fb9ce54516b4a869/src/node_options.cc#L1024-L1063 +function ParseNodeOptionsEnvVar(node_options, errors) { + const env_argv = []; -/***/ }), - -/***/ 74221: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { - -var common = __nccwpck_require__(17673); -var _tempDir = (__nccwpck_require__(40591).tempDir); -var _pwd = __nccwpck_require__(24020); -var path = __nccwpck_require__(71017); -var fs = __nccwpck_require__(57147); -var child = __nccwpck_require__(32081); - -var DEFAULT_MAXBUFFER_SIZE = 20 * 1024 * 1024; -var DEFAULT_ERROR_CODE = 1; - -common.register('exec', _exec, { - unix: false, - canReceivePipe: true, - wrapOutput: false, -}); - -// We use this function to run `exec` synchronously while also providing realtime -// output. -function execSync(cmd, opts, pipe) { - if (!common.config.execPath) { - common.error('Unable to find a path to the node binary. Please manually set config.execPath'); - } - - var tempDir = _tempDir(); - var paramsFile = path.resolve(tempDir + '/' + common.randomFileName()); - var stderrFile = path.resolve(tempDir + '/' + common.randomFileName()); - var stdoutFile = path.resolve(tempDir + '/' + common.randomFileName()); - - opts = common.extend({ - silent: common.config.silent, - cwd: _pwd().toString(), - env: process.env, - maxBuffer: DEFAULT_MAXBUFFER_SIZE, - encoding: 'utf8', - }, opts); - - if (fs.existsSync(paramsFile)) common.unlinkSync(paramsFile); - if (fs.existsSync(stderrFile)) common.unlinkSync(stderrFile); - if (fs.existsSync(stdoutFile)) common.unlinkSync(stdoutFile); - - opts.cwd = path.resolve(opts.cwd); - - var paramsToSerialize = { - command: cmd, - execOptions: opts, - pipe: pipe, - stdoutFile: stdoutFile, - stderrFile: stderrFile, - }; - - // Create the files and ensure these are locked down (for read and write) to - // the current user. The main concerns here are: - // - // * If we execute a command which prints sensitive output, then - // stdoutFile/stderrFile must not be readable by other users. - // * paramsFile must not be readable by other users, or else they can read it - // to figure out the path for stdoutFile/stderrFile and create these first - // (locked down to their own access), which will crash exec() when it tries - // to write to the files. - function writeFileLockedDown(filePath, data) { - fs.writeFileSync(filePath, data, { - encoding: 'utf8', - mode: parseInt('600', 8), - }); - } - writeFileLockedDown(stdoutFile, ''); - writeFileLockedDown(stderrFile, ''); - writeFileLockedDown(paramsFile, JSON.stringify(paramsToSerialize)); - - var execArgs = [ - __nccwpck_require__.ab + "exec-child.js", - paramsFile, - ]; - - /* istanbul ignore else */ - if (opts.silent) { - opts.stdio = 'ignore'; - } else { - opts.stdio = [0, 1, 2]; - } - - var code = 0; - - // Welcome to the future - try { - // Bad things if we pass in a `shell` option to child_process.execFileSync, - // so we need to explicitly remove it here. - delete opts.shell; - - child.execFileSync(common.config.execPath, execArgs, opts); - } catch (e) { - // Commands with non-zero exit code raise an exception. - code = e.status || DEFAULT_ERROR_CODE; - } - - // fs.readFileSync uses buffer encoding by default, so call - // it without the encoding option if the encoding is 'buffer'. - // Also, if the exec timeout is too short for node to start up, - // the files will not be created, so these calls will throw. - var stdout = ''; - var stderr = ''; - if (opts.encoding === 'buffer') { - stdout = fs.readFileSync(stdoutFile); - stderr = fs.readFileSync(stderrFile); - } else { - stdout = fs.readFileSync(stdoutFile, opts.encoding); - stderr = fs.readFileSync(stderrFile, opts.encoding); - } - - // No biggie if we can't erase the files now -- they're in a temp dir anyway - // and we locked down permissions (see the note above). - try { common.unlinkSync(paramsFile); } catch (e) {} - try { common.unlinkSync(stderrFile); } catch (e) {} - try { common.unlinkSync(stdoutFile); } catch (e) {} - - if (code !== 0) { - // Note: `silent` should be unconditionally true to avoid double-printing - // the command's stderr, and to avoid printing any stderr when the user has - // set `shell.config.silent`. - common.error(stderr, code, { continue: true, silent: true }); - } - var obj = common.ShellString(stdout, stderr, code); - return obj; -} // execSync() + let is_in_string = false; + let will_start_new_arg = true; + for (let index = 0; index < node_options.length; ++index) { + let c = node_options[index]; -// Wrapper around exec() to enable echoing output to console in real time -function execAsync(cmd, opts, pipe, callback) { - opts = common.extend({ - silent: common.config.silent, - cwd: _pwd().toString(), - env: process.env, - maxBuffer: DEFAULT_MAXBUFFER_SIZE, - encoding: 'utf8', - }, opts); + // Backslashes escape the following character + if (c === '\\' && is_in_string) { + if (index + 1 === node_options.length) { + errors.push("invalid value for NODE_OPTIONS " + + "(invalid escape)\n"); + return env_argv; + } else { + c = node_options[++index]; + } + } else if (c === ' ' && !is_in_string) { + will_start_new_arg = true; + continue; + } else if (c === '"') { + is_in_string = !is_in_string; + continue; + } - var c = child.exec(cmd, opts, function (err, stdout, stderr) { - if (callback) { - if (!err) { - callback(0, stdout, stderr); - } else if (err.code === undefined) { - // See issue #536 - /* istanbul ignore next */ - callback(1, stdout, stderr); + if (will_start_new_arg) { + env_argv.push(c); + will_start_new_arg = false; } else { - callback(err.code, stdout, stderr); + env_argv[env_argv.length - 1] += c; } - } - }); - - if (pipe) c.stdin.end(pipe); - - if (!opts.silent) { - c.stdout.pipe(process.stdout); - c.stderr.pipe(process.stderr); - } - - return c; -} - -//@ -//@ ### exec(command [, options] [, callback]) -//@ -//@ Available options: -//@ -//@ + `async`: Asynchronous execution. If a callback is provided, it will be set to -//@ `true`, regardless of the passed value (default: `false`). -//@ + `silent`: Do not echo program output to console (default: `false`). -//@ + `encoding`: Character encoding to use. Affects the values returned to stdout and stderr, and -//@ what is written to stdout and stderr when not in silent mode (default: `'utf8'`). -//@ + and any option available to Node.js's -//@ [`child_process.exec()`](https://nodejs.org/api/child_process.html#child_process_child_process_exec_command_options_callback) -//@ -//@ Examples: -//@ -//@ ```javascript -//@ var version = exec('node --version', {silent:true}).stdout; -//@ -//@ var child = exec('some_long_running_process', {async:true}); -//@ child.stdout.on('data', function(data) { -//@ /* ... do something with data ... */ -//@ }); -//@ -//@ exec('some_long_running_process', function(code, stdout, stderr) { -//@ console.log('Exit code:', code); -//@ console.log('Program output:', stdout); -//@ console.log('Program stderr:', stderr); -//@ }); -//@ ``` -//@ -//@ Executes the given `command` _synchronously_, unless otherwise specified. When in synchronous -//@ mode, this returns a `ShellString` (compatible with ShellJS v0.6.x, which returns an object -//@ of the form `{ code:..., stdout:... , stderr:... }`). Otherwise, this returns the child process -//@ object, and the `callback` receives the arguments `(code, stdout, stderr)`. -//@ -//@ Not seeing the behavior you want? `exec()` runs everything through `sh` -//@ by default (or `cmd.exe` on Windows), which differs from `bash`. If you -//@ need bash-specific behavior, try out the `{shell: 'path/to/bash'}` option. -function _exec(command, options, callback) { - options = options || {}; - if (!command) common.error('must specify command'); - - var pipe = common.readFromPipe(); - - // Callback is defined instead of options. - if (typeof options === 'function') { - callback = options; - options = { async: true }; } - // Callback is defined with options. - if (typeof options === 'object' && typeof callback === 'function') { - options.async = true; + if (is_in_string) { + errors.push("invalid value for NODE_OPTIONS " + + "(unterminated string)\n"); } + return env_argv; +} - options = common.extend({ - silent: common.config.silent, - async: false, - }, options); - - if (options.async) { - return execAsync(command, options, pipe, callback); - } else { - return execSync(command, options, pipe); +// Get option values that can be specified via env vars besides NODE_OPTIONS +function getOptionValuesFromOtherEnvVars() { + const options = {}; + if(process.env.NODE_PENDING_DEPRECATION === '1') { + options['--pending-deprecation'] = true; } + return options; } -module.exports = _exec; /***/ }), -/***/ 49198: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { - -var path = __nccwpck_require__(71017); -var common = __nccwpck_require__(17673); -var _ls = __nccwpck_require__(9644); - -common.register('find', _find, {}); - -//@ -//@ ### find(path [, path ...]) -//@ ### find(path_array) -//@ -//@ Examples: -//@ -//@ ```javascript -//@ find('src', 'lib'); -//@ find(['src', 'lib']); // same as above -//@ find('.').filter(function(file) { return file.match(/\.js$/); }); -//@ ``` -//@ -//@ Returns array of all files (however deep) in the given paths. -//@ -//@ The main difference from `ls('-R', path)` is that the resulting file names -//@ include the base directories (e.g., `lib/resources/file1` instead of just `file1`). -function _find(options, paths) { - if (!paths) { - common.error('no path specified'); - } else if (typeof paths === 'string') { - paths = [].slice.call(arguments, 1); - } +/***/ 57523: +/***/ ((module) => { - var list = []; +module.exports = { + ArrayFrom: Array.from, + ArrayIsArray: Array.isArray, + ArrayPrototypeShift: (obj) => Array.prototype.shift.call(obj), + ArrayPrototypeForEach: (arr, ...rest) => Array.prototype.forEach.apply(arr, rest), + ArrayPrototypeIncludes: (arr, ...rest) => Array.prototype.includes.apply(arr, rest), + ArrayPrototypeJoin: (arr, ...rest) => Array.prototype.join.apply(arr, rest), + ArrayPrototypePop: (arr, ...rest) => Array.prototype.pop.apply(arr, rest), + ArrayPrototypePush: (arr, ...rest) => Array.prototype.push.apply(arr, rest), + FunctionPrototype: Function.prototype, + JSONParse: JSON.parse, + JSONStringify: JSON.stringify, + ObjectFreeze: Object.freeze, + ObjectKeys: Object.keys, + ObjectGetOwnPropertyNames: Object.getOwnPropertyNames, + ObjectDefineProperty: Object.defineProperty, + ObjectPrototypeHasOwnProperty: (obj, prop) => Object.prototype.hasOwnProperty.call(obj, prop), + RegExpPrototypeExec: (obj, string) => RegExp.prototype.exec.call(obj, string), + RegExpPrototypeTest: (obj, string) => RegExp.prototype.test.call(obj, string), + RegExpPrototypeSymbolReplace: (obj, ...rest) => RegExp.prototype[Symbol.replace].apply(obj, rest), + SafeMap: Map, + SafeSet: Set, + SafeWeakMap: WeakMap, + StringPrototypeEndsWith: (str, ...rest) => String.prototype.endsWith.apply(str, rest), + StringPrototypeIncludes: (str, ...rest) => String.prototype.includes.apply(str, rest), + StringPrototypeLastIndexOf: (str, ...rest) => String.prototype.lastIndexOf.apply(str, rest), + StringPrototypeIndexOf: (str, ...rest) => String.prototype.indexOf.apply(str, rest), + StringPrototypeRepeat: (str, ...rest) => String.prototype.repeat.apply(str, rest), + StringPrototypeReplace: (str, ...rest) => String.prototype.replace.apply(str, rest), + StringPrototypeSlice: (str, ...rest) => String.prototype.slice.apply(str, rest), + StringPrototypeSplit: (str, ...rest) => String.prototype.split.apply(str, rest), + StringPrototypeStartsWith: (str, ...rest) => String.prototype.startsWith.apply(str, rest), + StringPrototypeSubstr: (str, ...rest) => String.prototype.substr.apply(str, rest), + StringPrototypeCharCodeAt: (str, ...rest) => String.prototype.charCodeAt.apply(str, rest), + StringPrototypeMatch: (str, ...rest) => String.prototype.match.apply(str, rest), + SyntaxError: SyntaxError +}; - function pushFile(file) { - if (process.platform === 'win32') { - file = file.replace(/\\/g, '/'); - } - list.push(file); - } - // why not simply do `ls('-R', paths)`? because the output wouldn't give the base dirs - // to get the base dir in the output, we need instead `ls('-R', 'dir/*')` for every directory +/***/ }), - paths.forEach(function (file) { - var stat; - try { - stat = common.statFollowLinks(file); - } catch (e) { - common.error('no such file or directory: ' + file); - } +/***/ 72501: +/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { - pushFile(file); +"use strict"; - if (stat.isDirectory()) { - _ls({ recursive: true, all: true }, file).forEach(function (subfile) { - pushFile(path.join(file, subfile)); - }); +Object.defineProperty(exports, "__esModule", ({ value: true })); +exports.installCommonjsResolveHooksIfNecessary = void 0; +/** + * @internal + */ +function installCommonjsResolveHooksIfNecessary(tsNodeService) { + const Module = __nccwpck_require__(98188); + const originalResolveFilename = Module._resolveFilename; + const originalFindPath = Module._findPath; + const shouldInstallHook = tsNodeService.options.experimentalResolver; + if (shouldInstallHook) { + const { Module_findPath, Module_resolveFilename } = tsNodeService.getNodeCjsLoader(); + Module._resolveFilename = _resolveFilename; + Module._findPath = _findPath; + function _resolveFilename(request, parent, isMain, options, ...rest) { + if (!tsNodeService.enabled()) + return originalResolveFilename.call(this, request, parent, isMain, options, ...rest); + return Module_resolveFilename.call(this, request, parent, isMain, options, ...rest); + } + function _findPath() { + if (!tsNodeService.enabled()) + return originalFindPath.apply(this, arguments); + return Module_findPath.apply(this, arguments); + } } - }); - - return list; } -module.exports = _find; - +exports.installCommonjsResolveHooksIfNecessary = installCommonjsResolveHooksIfNecessary; +//# sourceMappingURL=cjs-resolve-hooks.js.map /***/ }), -/***/ 78869: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { +/***/ 45981: +/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { -var common = __nccwpck_require__(17673); -var fs = __nccwpck_require__(57147); +"use strict"; -common.register('grep', _grep, { - globStart: 2, // don't glob-expand the regex - canReceivePipe: true, - cmdOptions: { - 'v': 'inverse', - 'l': 'nameOnly', - 'i': 'ignoreCase', - }, -}); - -//@ -//@ ### grep([options,] regex_filter, file [, file ...]) -//@ ### grep([options,] regex_filter, file_array) -//@ -//@ Available options: -//@ -//@ + `-v`: Invert `regex_filter` (only print non-matching lines). -//@ + `-l`: Print only filenames of matching files. -//@ + `-i`: Ignore case. -//@ -//@ Examples: -//@ -//@ ```javascript -//@ grep('-v', 'GLOBAL_VARIABLE', '*.js'); -//@ grep('GLOBAL_VARIABLE', '*.js'); -//@ ``` -//@ -//@ Reads input string from given files and returns a string containing all lines of the -//@ file that match the given `regex_filter`. -function _grep(options, regex, files) { - // Check if this is coming from a pipe - var pipe = common.readFromPipe(); - - if (!files && !pipe) common.error('no paths given', 2); - - files = [].slice.call(arguments, 2); - - if (pipe) { - files.unshift('-'); - } - - var grep = []; - if (options.ignoreCase) { - regex = new RegExp(regex, 'i'); - } - files.forEach(function (file) { - if (!fs.existsSync(file) && file !== '-') { - common.error('no such file or directory: ' + file, 2, { continue: true }); - return; +Object.defineProperty(exports, "__esModule", ({ value: true })); +exports.getTsConfigDefaults = exports.ComputeAsCommonRootOfFiles = exports.loadCompiler = exports.resolveAndLoadCompiler = exports.readConfig = exports.findAndReadConfig = void 0; +const path_1 = __nccwpck_require__(71017); +const index_1 = __nccwpck_require__(94828); +const ts_internals_1 = __nccwpck_require__(80301); +const tsconfigs_1 = __nccwpck_require__(88933); +const util_1 = __nccwpck_require__(26239); +/** + * TypeScript compiler option values required by `ts-node` which cannot be overridden. + */ +const TS_NODE_COMPILER_OPTIONS = { + sourceMap: true, + inlineSourceMap: false, + inlineSources: true, + declaration: false, + noEmit: false, + outDir: '.ts-node', +}; +/* + * Do post-processing on config options to support `ts-node`. + */ +function fixConfig(ts, config) { + // Delete options that *should not* be passed through. + delete config.options.out; + delete config.options.outFile; + delete config.options.composite; + delete config.options.declarationDir; + delete config.options.declarationMap; + delete config.options.emitDeclarationOnly; + // Target ES5 output by default (instead of ES3). + if (config.options.target === undefined) { + config.options.target = ts.ScriptTarget.ES5; } - - var contents = file === '-' ? pipe : fs.readFileSync(file, 'utf8'); - if (options.nameOnly) { - if (contents.match(regex)) { - grep.push(file); - } - } else { - var lines = contents.split('\n'); - lines.forEach(function (line) { - var matched = line.match(regex); - if ((options.inverse && !matched) || (!options.inverse && matched)) { - grep.push(line); - } - }); + // Target CommonJS modules by default (instead of magically switching to ES6 when the target is ES6). + if (config.options.module === undefined) { + config.options.module = ts.ModuleKind.CommonJS; } - }); - - return grep.join('\n') + '\n'; + return config; } -module.exports = _grep; - - -/***/ }), - -/***/ 41712: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { - -var common = __nccwpck_require__(17673); -var fs = __nccwpck_require__(57147); - -common.register('head', _head, { - canReceivePipe: true, - cmdOptions: { - 'n': 'numLines', - }, -}); - -// Reads |numLines| lines or the entire file, whichever is less. -function readSomeLines(file, numLines) { - var buf = common.buffer(); - var bufLength = buf.length; - var bytesRead = bufLength; - var pos = 0; - - var fdr = fs.openSync(file, 'r'); - var numLinesRead = 0; - var ret = ''; - while (bytesRead === bufLength && numLinesRead < numLines) { - bytesRead = fs.readSync(fdr, buf, 0, bufLength, pos); - var bufStr = buf.toString('utf8', 0, bytesRead); - numLinesRead += bufStr.split('\n').length - 1; - ret += bufStr; - pos += bytesRead; - } - - fs.closeSync(fdr); - return ret; +/** @internal */ +function findAndReadConfig(rawOptions) { + var _a, _b, _c, _d, _e; + const cwd = (0, path_1.resolve)((_c = (_b = (_a = rawOptions.cwd) !== null && _a !== void 0 ? _a : rawOptions.dir) !== null && _b !== void 0 ? _b : index_1.DEFAULTS.cwd) !== null && _c !== void 0 ? _c : process.cwd()); + const compilerName = (_d = rawOptions.compiler) !== null && _d !== void 0 ? _d : index_1.DEFAULTS.compiler; + // Compute minimum options to read the config file. + let projectLocalResolveDir = (0, util_1.getBasePathForProjectLocalDependencyResolution)(undefined, rawOptions.projectSearchDir, rawOptions.project, cwd); + let { compiler, ts } = resolveAndLoadCompiler(compilerName, projectLocalResolveDir); + // Read config file and merge new options between env and CLI options. + const { configFilePath, config, tsNodeOptionsFromTsconfig, optionBasePaths } = readConfig(cwd, ts, rawOptions); + const options = (0, util_1.assign)({}, index_1.DEFAULTS, tsNodeOptionsFromTsconfig || {}, { optionBasePaths }, rawOptions); + options.require = [ + ...(tsNodeOptionsFromTsconfig.require || []), + ...(rawOptions.require || []), + ]; + // Re-resolve the compiler in case it has changed. + // Compiler is loaded relative to tsconfig.json, so tsconfig discovery may cause us to load a + // different compiler than we did above, even if the name has not changed. + if (configFilePath) { + projectLocalResolveDir = (0, util_1.getBasePathForProjectLocalDependencyResolution)(configFilePath, rawOptions.projectSearchDir, rawOptions.project, cwd); + ({ compiler } = resolveCompiler(options.compiler, (_e = optionBasePaths.compiler) !== null && _e !== void 0 ? _e : projectLocalResolveDir)); + } + return { + options, + config, + projectLocalResolveDir, + optionBasePaths, + configFilePath, + cwd, + compiler, + }; } - -//@ -//@ ### head([{'-n': \},] file [, file ...]) -//@ ### head([{'-n': \},] file_array) -//@ -//@ Available options: -//@ -//@ + `-n `: Show the first `` lines of the files -//@ -//@ Examples: -//@ -//@ ```javascript -//@ var str = head({'-n': 1}, 'file*.txt'); -//@ var str = head('file1', 'file2'); -//@ var str = head(['file1', 'file2']); // same as above -//@ ``` -//@ -//@ Read the start of a file. -function _head(options, files) { - var head = []; - var pipe = common.readFromPipe(); - - if (!files && !pipe) common.error('no paths given'); - - var idx = 1; - if (options.numLines === true) { - idx = 2; - options.numLines = Number(arguments[1]); - } else if (options.numLines === false) { - options.numLines = 10; - } - files = [].slice.call(arguments, idx); - - if (pipe) { - files.unshift('-'); - } - - var shouldAppendNewline = false; - files.forEach(function (file) { - if (file !== '-') { - if (!fs.existsSync(file)) { - common.error('no such file or directory: ' + file, { continue: true }); - return; - } else if (common.statFollowLinks(file).isDirectory()) { - common.error("error reading '" + file + "': Is a directory", { - continue: true, - }); - return; - } +exports.findAndReadConfig = findAndReadConfig; +/** + * Load TypeScript configuration. Returns the parsed TypeScript config and + * any `ts-node` options specified in the config file. + * + * Even when a tsconfig.json is not loaded, this function still handles merging + * compilerOptions from various sources: API, environment variables, etc. + * + * @internal + */ +function readConfig(cwd, ts, rawApiOptions) { + var _a, _b, _c; + // Ordered [a, b, c] where config a extends b extends c + const configChain = []; + let config = { compilerOptions: {} }; + let basePath = cwd; + let configFilePath = undefined; + const projectSearchDir = (0, path_1.resolve)(cwd, (_a = rawApiOptions.projectSearchDir) !== null && _a !== void 0 ? _a : cwd); + const { fileExists = ts.sys.fileExists, readFile = ts.sys.readFile, skipProject = index_1.DEFAULTS.skipProject, project = index_1.DEFAULTS.project, tsTrace = index_1.DEFAULTS.tsTrace, } = rawApiOptions; + // Read project configuration when available. + if (!skipProject) { + if (project) { + const resolved = (0, path_1.resolve)(cwd, project); + const nested = (0, path_1.join)(resolved, 'tsconfig.json'); + configFilePath = fileExists(nested) ? nested : resolved; + } + else { + configFilePath = ts.findConfigFile(projectSearchDir, fileExists); + } + if (configFilePath) { + let pathToNextConfigInChain = configFilePath; + const tsInternals = (0, ts_internals_1.createTsInternals)(ts); + const errors = []; + // Follow chain of "extends" + while (true) { + const result = ts.readConfigFile(pathToNextConfigInChain, readFile); + // Return diagnostics. + if (result.error) { + return { + configFilePath, + config: { errors: [result.error], fileNames: [], options: {} }, + tsNodeOptionsFromTsconfig: {}, + optionBasePaths: {}, + }; + } + const c = result.config; + const bp = (0, path_1.dirname)(pathToNextConfigInChain); + configChain.push({ + config: c, + basePath: bp, + configPath: pathToNextConfigInChain, + }); + if (c.extends == null) + break; + const resolvedExtendedConfigPath = tsInternals.getExtendsConfigPath(c.extends, { + fileExists, + readDirectory: ts.sys.readDirectory, + readFile, + useCaseSensitiveFileNames: ts.sys.useCaseSensitiveFileNames, + trace: tsTrace, + }, bp, errors, ts.createCompilerDiagnostic); + if (errors.length) { + return { + configFilePath, + config: { errors, fileNames: [], options: {} }, + tsNodeOptionsFromTsconfig: {}, + optionBasePaths: {}, + }; + } + if (resolvedExtendedConfigPath == null) + break; + pathToNextConfigInChain = resolvedExtendedConfigPath; + } + ({ config, basePath } = configChain[0]); + } } - - var contents; - if (file === '-') { - contents = pipe; - } else if (options.numLines < 0) { - contents = fs.readFileSync(file, 'utf8'); - } else { - contents = readSomeLines(file, options.numLines); + // Merge and fix ts-node options that come from tsconfig.json(s) + const tsNodeOptionsFromTsconfig = {}; + const optionBasePaths = {}; + for (let i = configChain.length - 1; i >= 0; i--) { + const { config, basePath, configPath } = configChain[i]; + const options = filterRecognizedTsConfigTsNodeOptions(config['ts-node']).recognized; + // Some options are relative to the config file, so must be converted to absolute paths here + if (options.require) { + // Modules are found relative to the tsconfig file, not the `dir` option + const tsconfigRelativeResolver = (0, util_1.createProjectLocalResolveHelper)((0, path_1.dirname)(configPath)); + options.require = options.require.map((path) => tsconfigRelativeResolver(path, false)); + } + if (options.scopeDir) { + options.scopeDir = (0, path_1.resolve)(basePath, options.scopeDir); + } + // Downstream code uses the basePath; we do not do that here. + if (options.moduleTypes) { + optionBasePaths.moduleTypes = basePath; + } + if (options.transpiler != null) { + optionBasePaths.transpiler = basePath; + } + if (options.compiler != null) { + optionBasePaths.compiler = basePath; + } + if (options.swc != null) { + optionBasePaths.swc = basePath; + } + (0, util_1.assign)(tsNodeOptionsFromTsconfig, options); } - - var lines = contents.split('\n'); - var hasTrailingNewline = (lines[lines.length - 1] === ''); - if (hasTrailingNewline) { - lines.pop(); + // Remove resolution of "files". + const files = (_c = (_b = rawApiOptions.files) !== null && _b !== void 0 ? _b : tsNodeOptionsFromTsconfig.files) !== null && _c !== void 0 ? _c : index_1.DEFAULTS.files; + // Only if a config file is *not* loaded, load an implicit configuration from @tsconfig/bases + const skipDefaultCompilerOptions = configFilePath != null; + const defaultCompilerOptionsForNodeVersion = skipDefaultCompilerOptions + ? undefined + : { + ...(0, tsconfigs_1.getDefaultTsconfigJsonForNodeVersion)(ts).compilerOptions, + types: ['node'], + }; + // Merge compilerOptions from all sources + config.compilerOptions = Object.assign({}, + // automatically-applied options from @tsconfig/bases + defaultCompilerOptionsForNodeVersion, + // tsconfig.json "compilerOptions" + config.compilerOptions, + // from env var + index_1.DEFAULTS.compilerOptions, + // tsconfig.json "ts-node": "compilerOptions" + tsNodeOptionsFromTsconfig.compilerOptions, + // passed programmatically + rawApiOptions.compilerOptions, + // overrides required by ts-node, cannot be changed + TS_NODE_COMPILER_OPTIONS); + const fixedConfig = fixConfig(ts, ts.parseJsonConfigFileContent(config, { + fileExists, + readFile, + // Only used for globbing "files", "include", "exclude" + // When `files` option disabled, we want to avoid the fs calls + readDirectory: files ? ts.sys.readDirectory : () => [], + useCaseSensitiveFileNames: ts.sys.useCaseSensitiveFileNames, + }, basePath, undefined, configFilePath)); + return { + configFilePath, + config: fixedConfig, + tsNodeOptionsFromTsconfig, + optionBasePaths, + }; +} +exports.readConfig = readConfig; +/** + * Load the typescript compiler. It is required to load the tsconfig but might + * be changed by the tsconfig, so we have to do this twice. + * @internal + */ +function resolveAndLoadCompiler(name, relativeToPath) { + const { compiler } = resolveCompiler(name, relativeToPath); + const ts = loadCompiler(compiler); + return { compiler, ts }; +} +exports.resolveAndLoadCompiler = resolveAndLoadCompiler; +function resolveCompiler(name, relativeToPath) { + const projectLocalResolveHelper = (0, util_1.createProjectLocalResolveHelper)(relativeToPath); + const compiler = projectLocalResolveHelper(name || 'typescript', true); + return { compiler }; +} +/** @internal */ +function loadCompiler(compiler) { + return (0, util_1.attemptRequireWithV8CompileCache)(require, compiler); +} +exports.loadCompiler = loadCompiler; +/** + * Given the raw "ts-node" sub-object from a tsconfig, return an object with only the properties + * recognized by "ts-node" + */ +function filterRecognizedTsConfigTsNodeOptions(jsonObject) { + if (jsonObject == null) + return { recognized: {}, unrecognized: {} }; + const { compiler, compilerHost, compilerOptions, emit, files, ignore, ignoreDiagnostics, logError, preferTsExts, pretty, require, skipIgnore, transpileOnly, typeCheck, transpiler, scope, scopeDir, moduleTypes, experimentalReplAwait, swc, experimentalResolver, esm, experimentalSpecifierResolution, experimentalTsImportSpecifiers, ...unrecognized } = jsonObject; + const filteredTsConfigOptions = { + compiler, + compilerHost, + compilerOptions, + emit, + experimentalReplAwait, + files, + ignore, + ignoreDiagnostics, + logError, + preferTsExts, + pretty, + require, + skipIgnore, + transpileOnly, + typeCheck, + transpiler, + scope, + scopeDir, + moduleTypes, + swc, + experimentalResolver, + esm, + experimentalSpecifierResolution, + experimentalTsImportSpecifiers, + }; + // Use the typechecker to make sure this implementation has the correct set of properties + const catchExtraneousProps = null; + const catchMissingProps = null; + return { recognized: filteredTsConfigOptions, unrecognized }; +} +/** @internal */ +exports.ComputeAsCommonRootOfFiles = Symbol(); +/** + * Some TS compiler options have defaults which are not provided by TS's config parsing functions. + * This function centralizes the logic for computing those defaults. + * @internal + */ +function getTsConfigDefaults(config, basePath, _files, _include, _exclude) { + const { composite = false } = config.options; + let rootDir = config.options.rootDir; + if (rootDir == null) { + if (composite) + rootDir = basePath; + // Return this symbol to avoid computing from `files`, which would require fs calls + else + rootDir = exports.ComputeAsCommonRootOfFiles; } - shouldAppendNewline = (hasTrailingNewline || options.numLines < lines.length); - - head = head.concat(lines.slice(0, options.numLines)); - }); - - if (shouldAppendNewline) { - head.push(''); // to add a trailing newline once we join - } - return head.join('\n'); + const { outDir = rootDir } = config.options; + // Docs are wrong: https://www.typescriptlang.org/tsconfig#include + // Docs say **, but it's actually **/*; compiler throws error for ** + const include = _files ? [] : ['**/*']; + const files = _files !== null && _files !== void 0 ? _files : []; + // Docs are misleading: https://www.typescriptlang.org/tsconfig#exclude + // Docs say it excludes node_modules, bower_components, jspm_packages, but actually those are excluded via behavior of "include" + const exclude = _exclude !== null && _exclude !== void 0 ? _exclude : [outDir]; // TODO technically, outDir is absolute path, but exclude should be relative glob pattern? + // TODO compute baseUrl + return { rootDir, outDir, include, files, exclude, composite }; } -module.exports = _head; - +exports.getTsConfigDefaults = getTsConfigDefaults; +//# sourceMappingURL=configuration.js.map /***/ }), -/***/ 76786: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { - -var fs = __nccwpck_require__(57147); -var path = __nccwpck_require__(71017); -var common = __nccwpck_require__(17673); - -common.register('ln', _ln, { - cmdOptions: { - 's': 'symlink', - 'f': 'force', - }, -}); - -//@ -//@ ### ln([options,] source, dest) -//@ -//@ Available options: -//@ -//@ + `-s`: symlink -//@ + `-f`: force -//@ -//@ Examples: -//@ -//@ ```javascript -//@ ln('file', 'newlink'); -//@ ln('-sf', 'file', 'existing'); -//@ ``` -//@ -//@ Links `source` to `dest`. Use `-f` to force the link, should `dest` already exist. -function _ln(options, source, dest) { - if (!source || !dest) { - common.error('Missing and/or '); - } +/***/ 36057: +/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { - source = String(source); - var sourcePath = path.normalize(source).replace(RegExp(path.sep + '$'), ''); - var isAbsolute = (path.resolve(source) === sourcePath); - dest = path.resolve(process.cwd(), String(dest)); +"use strict"; +var __webpack_unused_export__; - if (fs.existsSync(dest)) { - if (!options.force) { - common.error('Destination file exists', { continue: true }); +__webpack_unused_export__ = ({ value: true }); +exports.lT = __webpack_unused_export__ = __webpack_unused_export__ = void 0; +const index_1 = __nccwpck_require__(94828); +const url_1 = __nccwpck_require__(57310); +const path_1 = __nccwpck_require__(71017); +const assert = __nccwpck_require__(39491); +const util_1 = __nccwpck_require__(26239); +const module_1 = __nccwpck_require__(98188); +// The hooks API changed in node version X so we need to check for backwards compatibility. +const newHooksAPI = (0, util_1.versionGteLt)(process.versions.node, '16.12.0'); +/** @internal */ +function filterHooksByAPIVersion(hooks) { + const { getFormat, load, resolve, transformSource } = hooks; + // Explicit return type to avoid TS's non-ideal inferred type + const hooksAPI = newHooksAPI + ? { resolve, load, getFormat: undefined, transformSource: undefined } + : { resolve, getFormat, transformSource, load: undefined }; + return hooksAPI; +} +__webpack_unused_export__ = filterHooksByAPIVersion; +/** @internal */ +function registerAndCreateEsmHooks(opts) { + // Automatically performs registration just like `-r ts-node/register` + const tsNodeInstance = (0, index_1.register)(opts); + return createEsmHooks(tsNodeInstance); +} +__webpack_unused_export__ = registerAndCreateEsmHooks; +function createEsmHooks(tsNodeService) { + tsNodeService.enableExperimentalEsmLoaderInterop(); + // Custom implementation that considers additional file extensions and automatically adds file extensions + const nodeResolveImplementation = tsNodeService.getNodeEsmResolver(); + const nodeGetFormatImplementation = tsNodeService.getNodeEsmGetFormat(); + const extensions = tsNodeService.extensions; + const hooksAPI = filterHooksByAPIVersion({ + resolve, + load, + getFormat, + transformSource, + }); + function isFileUrlOrNodeStyleSpecifier(parsed) { + // We only understand file:// URLs, but in node, the specifier can be a node-style `./foo` or `foo` + const { protocol } = parsed; + return protocol === null || protocol === 'file:'; } - - fs.unlinkSync(dest); - } - - if (options.symlink) { - var isWindows = process.platform === 'win32'; - var linkType = isWindows ? 'file' : null; - var resolvedSourcePath = isAbsolute ? sourcePath : path.resolve(process.cwd(), path.dirname(dest), source); - if (!fs.existsSync(resolvedSourcePath)) { - common.error('Source file does not exist', { continue: true }); - } else if (isWindows && common.statFollowLinks(resolvedSourcePath).isDirectory()) { - linkType = 'junction'; + /** + * Named "probably" as a reminder that this is a guess. + * node does not explicitly tell us if we're resolving the entrypoint or not. + */ + function isProbablyEntrypoint(specifier, parentURL) { + return parentURL === undefined && specifier.startsWith('file://'); } - - try { - fs.symlinkSync(linkType === 'junction' ? resolvedSourcePath : source, dest, linkType); - } catch (err) { - common.error(err.message); + // Side-channel between `resolve()` and `load()` hooks + const rememberIsProbablyEntrypoint = new Set(); + const rememberResolvedViaCommonjsFallback = new Set(); + async function resolve(specifier, context, defaultResolve) { + const defer = async () => { + const r = await defaultResolve(specifier, context, defaultResolve); + return r; + }; + // See: https://github.com/nodejs/node/discussions/41711 + // nodejs will likely implement a similar fallback. Till then, we can do our users a favor and fallback today. + async function entrypointFallback(cb) { + try { + const resolution = await cb(); + if ((resolution === null || resolution === void 0 ? void 0 : resolution.url) && + isProbablyEntrypoint(specifier, context.parentURL)) + rememberIsProbablyEntrypoint.add(resolution.url); + return resolution; + } + catch (esmResolverError) { + if (!isProbablyEntrypoint(specifier, context.parentURL)) + throw esmResolverError; + try { + let cjsSpecifier = specifier; + // Attempt to convert from ESM file:// to CommonJS path + try { + if (specifier.startsWith('file://')) + cjsSpecifier = (0, url_1.fileURLToPath)(specifier); + } + catch { } + const resolution = (0, url_1.pathToFileURL)((0, module_1.createRequire)(process.cwd()).resolve(cjsSpecifier)).toString(); + rememberIsProbablyEntrypoint.add(resolution); + rememberResolvedViaCommonjsFallback.add(resolution); + return { url: resolution, format: 'commonjs' }; + } + catch (commonjsResolverError) { + throw esmResolverError; + } + } + } + return addShortCircuitFlag(async () => { + const parsed = (0, url_1.parse)(specifier); + const { pathname, protocol, hostname } = parsed; + if (!isFileUrlOrNodeStyleSpecifier(parsed)) { + return entrypointFallback(defer); + } + if (protocol !== null && protocol !== 'file:') { + return entrypointFallback(defer); + } + // Malformed file:// URL? We should always see `null` or `''` + if (hostname) { + // TODO file://./foo sets `hostname` to `'.'`. Perhaps we should special-case this. + return entrypointFallback(defer); + } + // pathname is the path to be resolved + return entrypointFallback(() => nodeResolveImplementation.defaultResolve(specifier, context, defaultResolve)); + }); } - } else { - if (!fs.existsSync(source)) { - common.error('Source file does not exist', { continue: true }); + // `load` from new loader hook API (See description at the top of this file) + async function load(url, context, defaultLoad) { + return addShortCircuitFlag(async () => { + var _a; + // If we get a format hint from resolve() on the context then use it + // otherwise call the old getFormat() hook using node's old built-in defaultGetFormat() that ships with ts-node + const format = (_a = context.format) !== null && _a !== void 0 ? _a : (await getFormat(url, context, nodeGetFormatImplementation.defaultGetFormat)).format; + let source = undefined; + if (format !== 'builtin' && format !== 'commonjs') { + // Call the new defaultLoad() to get the source + const { source: rawSource } = await defaultLoad(url, { + ...context, + format, + }, defaultLoad); + if (rawSource === undefined || rawSource === null) { + throw new Error(`Failed to load raw source: Format was '${format}' and url was '${url}''.`); + } + // Emulate node's built-in old defaultTransformSource() so we can re-use the old transformSource() hook + const defaultTransformSource = async (source, _context, _defaultTransformSource) => ({ source }); + // Call the old hook + const { source: transformedSource } = await transformSource(rawSource, { url, format }, defaultTransformSource); + source = transformedSource; + } + return { format, source }; + }); } - try { - fs.linkSync(source, dest); - } catch (err) { - common.error(err.message); + async function getFormat(url, context, defaultGetFormat) { + const defer = (overrideUrl = url) => defaultGetFormat(overrideUrl, context, defaultGetFormat); + // See: https://github.com/nodejs/node/discussions/41711 + // nodejs will likely implement a similar fallback. Till then, we can do our users a favor and fallback today. + async function entrypointFallback(cb) { + try { + return await cb(); + } + catch (getFormatError) { + if (!rememberIsProbablyEntrypoint.has(url)) + throw getFormatError; + return { format: 'commonjs' }; + } + } + const parsed = (0, url_1.parse)(url); + if (!isFileUrlOrNodeStyleSpecifier(parsed)) { + return entrypointFallback(defer); + } + const { pathname } = parsed; + assert(pathname !== null, 'ESM getFormat() hook: URL should never have null pathname'); + const nativePath = (0, url_1.fileURLToPath)(url); + let nodeSays; + // If file has extension not understood by node, then ask node how it would treat the emitted extension. + // E.g. .mts compiles to .mjs, so ask node how to classify an .mjs file. + const ext = (0, path_1.extname)(nativePath); + const tsNodeIgnored = tsNodeService.ignored(nativePath); + const nodeEquivalentExt = extensions.nodeEquivalents.get(ext); + if (nodeEquivalentExt && !tsNodeIgnored) { + nodeSays = await entrypointFallback(() => defer((0, url_1.format)((0, url_1.pathToFileURL)(nativePath + nodeEquivalentExt)))); + } + else { + try { + nodeSays = await entrypointFallback(defer); + } + catch (e) { + if (e instanceof Error && + tsNodeIgnored && + extensions.nodeDoesNotUnderstand.includes(ext)) { + e.message += + `\n\n` + + `Hint:\n` + + `ts-node is configured to ignore this file.\n` + + `If you want ts-node to handle this file, consider enabling the "skipIgnore" option or adjusting your "ignore" patterns.\n` + + `https://typestrong.org/ts-node/docs/scope\n`; + } + throw e; + } + } + // For files compiled by ts-node that node believes are either CJS or ESM, check if we should override that classification + if (!tsNodeService.ignored(nativePath) && + (nodeSays.format === 'commonjs' || nodeSays.format === 'module')) { + const { moduleType } = tsNodeService.moduleTypeClassifier.classifyModuleByModuleTypeOverrides((0, util_1.normalizeSlashes)(nativePath)); + if (moduleType === 'cjs') { + return { format: 'commonjs' }; + } + else if (moduleType === 'esm') { + return { format: 'module' }; + } + } + return nodeSays; } - } - return ''; + async function transformSource(source, context, defaultTransformSource) { + if (source === null || source === undefined) { + throw new Error('No source'); + } + const defer = () => defaultTransformSource(source, context, defaultTransformSource); + const sourceAsString = typeof source === 'string' ? source : source.toString('utf8'); + const { url } = context; + const parsed = (0, url_1.parse)(url); + if (!isFileUrlOrNodeStyleSpecifier(parsed)) { + return defer(); + } + const nativePath = (0, url_1.fileURLToPath)(url); + if (tsNodeService.ignored(nativePath)) { + return defer(); + } + const emittedJs = tsNodeService.compile(sourceAsString, nativePath); + return { source: emittedJs }; + } + return hooksAPI; } -module.exports = _ln; - +exports.lT = createEsmHooks; +async function addShortCircuitFlag(fn) { + const ret = await fn(); + // Not sure if this is necessary; being lazy. Can revisit in the future. + if (ret == null) + return ret; + return { + ...ret, + shortCircuit: true, + }; +} +//# sourceMappingURL=esm.js.map /***/ }), -/***/ 9644: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { - -var path = __nccwpck_require__(71017); -var fs = __nccwpck_require__(57147); -var common = __nccwpck_require__(17673); -var glob = __nccwpck_require__(20557); - -var globPatternRecursive = path.sep + '**'; - -common.register('ls', _ls, { - cmdOptions: { - 'R': 'recursive', - 'A': 'all', - 'L': 'link', - 'a': 'all_deprecated', - 'd': 'directory', - 'l': 'long', - }, -}); - -//@ -//@ ### ls([options,] [path, ...]) -//@ ### ls([options,] path_array) -//@ -//@ Available options: -//@ -//@ + `-R`: recursive -//@ + `-A`: all files (include files beginning with `.`, except for `.` and `..`) -//@ + `-L`: follow symlinks -//@ + `-d`: list directories themselves, not their contents -//@ + `-l`: list objects representing each file, each with fields containing `ls -//@ -l` output fields. See -//@ [`fs.Stats`](https://nodejs.org/api/fs.html#fs_class_fs_stats) -//@ for more info -//@ -//@ Examples: -//@ -//@ ```javascript -//@ ls('projs/*.js'); -//@ ls('-R', '/users/me', '/tmp'); -//@ ls('-R', ['/users/me', '/tmp']); // same as above -//@ ls('-l', 'file.txt'); // { name: 'file.txt', mode: 33188, nlink: 1, ...} -//@ ``` -//@ -//@ Returns array of files in the given `path`, or files in -//@ the current directory if no `path` is provided. -function _ls(options, paths) { - if (options.all_deprecated) { - // We won't support the -a option as it's hard to image why it's useful - // (it includes '.' and '..' in addition to '.*' files) - // For backwards compatibility we'll dump a deprecated message and proceed as before - common.log('ls: Option -a is deprecated. Use -A instead'); - options.all = true; - } - - if (!paths) { - paths = ['.']; - } else { - paths = [].slice.call(arguments, 1); - } - - var list = []; - - function pushFile(abs, relName, stat) { - if (process.platform === 'win32') { - relName = relName.replace(/\\/g, '/'); - } - if (options.long) { - stat = stat || (options.link ? common.statFollowLinks(abs) : common.statNoFollowLinks(abs)); - list.push(addLsAttributes(relName, stat)); - } else { - // list.push(path.relative(rel || '.', file)); - list.push(relName); - } - } - - paths.forEach(function (p) { - var stat; +/***/ 9156: +/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { - try { - stat = options.link ? common.statFollowLinks(p) : common.statNoFollowLinks(p); - // follow links to directories by default - if (stat.isSymbolicLink()) { - /* istanbul ignore next */ - // workaround for https://github.com/shelljs/shelljs/issues/795 - // codecov seems to have a bug that miscalculate this block as uncovered. - // but according to nyc report this block does get covered. - try { - var _stat = common.statFollowLinks(p); - if (_stat.isDirectory()) { - stat = _stat; - } - } catch (_) {} // bad symlink, treat it like a file - } - } catch (e) { - common.error('no such file or directory: ' + p, 2, { continue: true }); - return; - } +"use strict"; - // If the stat succeeded - if (stat.isDirectory() && !options.directory) { - if (options.recursive) { - // use glob, because it's simple - glob.sync(p + globPatternRecursive, { dot: options.all, follow: options.link }) - .forEach(function (item) { - // Glob pattern returns the directory itself and needs to be filtered out. - if (path.relative(p, item)) { - pushFile(item, path.relative(p, item)); - } - }); - } else if (options.all) { - // use fs.readdirSync, because it's fast - fs.readdirSync(p).forEach(function (item) { - pushFile(path.join(p, item), item); - }); - } else { - // use fs.readdirSync and then filter out secret files - fs.readdirSync(p).forEach(function (item) { - if (item[0] !== '.') { - pushFile(path.join(p, item), item); - } - }); - } - } else { - pushFile(p, p, stat); +Object.defineProperty(exports, "__esModule", ({ value: true })); +exports.getExtensions = void 0; +const util_1 = __nccwpck_require__(26239); +const nodeEquivalents = new Map([ + ['.ts', '.js'], + ['.tsx', '.js'], + ['.jsx', '.js'], + ['.mts', '.mjs'], + ['.cts', '.cjs'], +]); +const tsResolverEquivalents = new Map([ + ['.ts', ['.js']], + ['.tsx', ['.js', '.jsx']], + ['.mts', ['.mjs']], + ['.cts', ['.cjs']], +]); +// All extensions understood by vanilla node +const vanillaNodeExtensions = [ + '.js', + '.json', + '.node', + '.mjs', + '.cjs', +]; +// Extensions added by vanilla node's require() if you omit them: +// js, json, node +// Extensions added by vanilla node if you omit them with --experimental-specifier-resolution=node +// js, json, node, mjs +// Extensions added by ESM codepath's legacy package.json "main" resolver +// js, json, node (not mjs!) +const nodeDoesNotUnderstand = [ + '.ts', + '.tsx', + '.jsx', + '.cts', + '.mts', +]; +/** + * [MUST_UPDATE_FOR_NEW_FILE_EXTENSIONS] + * @internal + */ +function getExtensions(config, options, tsVersion) { + // TS 4.5 is first version to understand .cts, .mts, .cjs, and .mjs extensions + const tsSupportsMtsCtsExts = (0, util_1.versionGteLt)(tsVersion, '4.5.0'); + const requiresHigherTypescriptVersion = []; + if (!tsSupportsMtsCtsExts) + requiresHigherTypescriptVersion.push('.cts', '.cjs', '.mts', '.mjs'); + const allPossibleExtensionsSortedByPreference = Array.from(new Set([ + ...(options.preferTsExts ? nodeDoesNotUnderstand : []), + ...vanillaNodeExtensions, + ...nodeDoesNotUnderstand, + ])); + const compiledJsUnsorted = ['.ts']; + const compiledJsxUnsorted = []; + if (config.options.jsx) + compiledJsxUnsorted.push('.tsx'); + if (tsSupportsMtsCtsExts) + compiledJsUnsorted.push('.mts', '.cts'); + if (config.options.allowJs) { + compiledJsUnsorted.push('.js'); + if (config.options.jsx) + compiledJsxUnsorted.push('.jsx'); + if (tsSupportsMtsCtsExts) + compiledJsUnsorted.push('.mjs', '.cjs'); } - }); - - // Add methods, to make this more compatible with ShellStrings - return list; + const compiledUnsorted = [...compiledJsUnsorted, ...compiledJsxUnsorted]; + const compiled = allPossibleExtensionsSortedByPreference.filter((ext) => compiledUnsorted.includes(ext)); + const compiledNodeDoesNotUnderstand = nodeDoesNotUnderstand.filter((ext) => compiled.includes(ext)); + /** + * TS's resolver can resolve foo.js to foo.ts, by replacing .js extension with several source extensions. + * IMPORTANT: Must preserve ordering according to preferTsExts! + * Must include the .js/.mjs/.cjs extension in the array! + * This affects resolution behavior! + * [MUST_UPDATE_FOR_NEW_FILE_EXTENSIONS] + */ + const r = allPossibleExtensionsSortedByPreference.filter((ext) => [...compiledUnsorted, '.js', '.mjs', '.cjs', '.mts', '.cts'].includes(ext)); + const replacementsForJs = r.filter((ext) => ['.js', '.jsx', '.ts', '.tsx'].includes(ext)); + const replacementsForJsx = r.filter((ext) => ['.jsx', '.tsx'].includes(ext)); + const replacementsForMjs = r.filter((ext) => ['.mjs', '.mts'].includes(ext)); + const replacementsForCjs = r.filter((ext) => ['.cjs', '.cts'].includes(ext)); + const replacementsForJsOrMjs = r.filter((ext) => ['.js', '.jsx', '.ts', '.tsx', '.mjs', '.mts'].includes(ext)); + // Node allows omitting .js or .mjs extension in certain situations (CJS, ESM w/experimental flag) + // So anything that compiles to .js or .mjs can also be omitted. + const experimentalSpecifierResolutionAddsIfOmitted = Array.from(new Set([...replacementsForJsOrMjs, '.json', '.node'])); + // Same as above, except node curiuosly doesn't do .mjs here + const legacyMainResolveAddsIfOmitted = Array.from(new Set([...replacementsForJs, '.json', '.node'])); + return { + /** All file extensions we transform, ordered by resolution preference according to preferTsExts */ + compiled, + /** Resolved extensions that vanilla node will not understand; we should handle them */ + nodeDoesNotUnderstand, + /** Like the above, but only the ones we're compiling */ + compiledNodeDoesNotUnderstand, + /** + * Mapping from extensions understood by tsc to the equivalent for node, + * as far as getFormat is concerned. + */ + nodeEquivalents, + /** + * Mapping from extensions rejected by TSC in import specifiers, to the + * possible alternatives that TS's resolver will accept. + * + * When we allow users to opt-in to .ts extensions in import specifiers, TS's + * resolver requires us to replace the .ts extensions with .js alternatives. + * Otherwise, resolution fails. + * + * Note TS's resolver is only used by, and only required for, typechecking. + * This is separate from node's resolver, which we hook separately and which + * does not require this mapping. + */ + tsResolverEquivalents, + /** + * Extensions that we can support if the user upgrades their typescript version. + * Used when raising hints. + */ + requiresHigherTypescriptVersion, + /** + * --experimental-specifier-resolution=node will add these extensions. + */ + experimentalSpecifierResolutionAddsIfOmitted, + /** + * ESM loader will add these extensions to package.json "main" field + */ + legacyMainResolveAddsIfOmitted, + replacementsForMjs, + replacementsForCjs, + replacementsForJsx, + replacementsForJs, + }; } +exports.getExtensions = getExtensions; +//# sourceMappingURL=file-extensions.js.map -function addLsAttributes(pathName, stats) { - // Note: this object will contain more information than .toString() returns - stats.name = pathName; - stats.toString = function () { - // Return a string resembling unix's `ls -l` format - return [this.mode, this.nlink, this.uid, this.gid, this.size, this.mtime, this.name].join(' '); - }; - return stats; -} +/***/ }), -module.exports = _ls; +/***/ 94828: +/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { +"use strict"; -/***/ }), - -/***/ 69494: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { - -var common = __nccwpck_require__(17673); -var fs = __nccwpck_require__(57147); -var path = __nccwpck_require__(71017); - -common.register('mkdir', _mkdir, { - cmdOptions: { - 'p': 'fullpath', - }, -}); - -// Recursively creates `dir` -function mkdirSyncRecursive(dir) { - var baseDir = path.dirname(dir); - - // Prevents some potential problems arising from malformed UNCs or - // insufficient permissions. - /* istanbul ignore next */ - if (baseDir === dir) { - common.error('dirname() failed: [' + dir + ']'); - } - - // Base dir exists, no recursion necessary - if (fs.existsSync(baseDir)) { - fs.mkdirSync(dir, parseInt('0777', 8)); - return; - } - - // Base dir does not exist, go recursive - mkdirSyncRecursive(baseDir); - - // Base dir created, can create dir - fs.mkdirSync(dir, parseInt('0777', 8)); -} - -//@ -//@ ### mkdir([options,] dir [, dir ...]) -//@ ### mkdir([options,] dir_array) -//@ -//@ Available options: -//@ -//@ + `-p`: full path (and create intermediate directories, if necessary) -//@ -//@ Examples: -//@ -//@ ```javascript -//@ mkdir('-p', '/tmp/a/b/c/d', '/tmp/e/f/g'); -//@ mkdir('-p', ['/tmp/a/b/c/d', '/tmp/e/f/g']); // same as above -//@ ``` -//@ -//@ Creates directories. -function _mkdir(options, dirs) { - if (!dirs) common.error('no paths given'); - - if (typeof dirs === 'string') { - dirs = [].slice.call(arguments, 1); - } - // if it's array leave it as it is - - dirs.forEach(function (dir) { - try { - var stat = common.statNoFollowLinks(dir); - if (!options.fullpath) { - common.error('path already exists: ' + dir, { continue: true }); - } else if (stat.isFile()) { - common.error('cannot create directory ' + dir + ': File exists', { continue: true }); - } - return; // skip dir - } catch (e) { - // do nothing +var _a, _b; +Object.defineProperty(exports, "__esModule", ({ value: true })); +exports.createEsmHooks = exports.createFromPreloadedConfig = exports.create = exports.register = exports.TSError = exports.DEFAULTS = exports.VERSION = exports.debug = exports.INSPECT_CUSTOM = exports.env = exports.REGISTER_INSTANCE = exports.createRepl = void 0; +const path_1 = __nccwpck_require__(71017); +const module_1 = __nccwpck_require__(98188); +const util = __nccwpck_require__(73837); +const url_1 = __nccwpck_require__(57310); +const make_error_1 = __nccwpck_require__(46419); +const util_1 = __nccwpck_require__(26239); +const configuration_1 = __nccwpck_require__(45981); +const module_type_classifier_1 = __nccwpck_require__(74025); +const resolver_functions_1 = __nccwpck_require__(83638); +const cjs_resolve_hooks_1 = __nccwpck_require__(72501); +const node_module_type_classifier_1 = __nccwpck_require__(76652); +const file_extensions_1 = __nccwpck_require__(9156); +const ts_transpile_module_1 = __nccwpck_require__(87857); +var repl_1 = __nccwpck_require__(8371); +Object.defineProperty(exports, "createRepl", ({ enumerable: true, get: function () { return repl_1.createRepl; } })); +/** + * Does this version of node obey the package.json "type" field + * and throw ERR_REQUIRE_ESM when attempting to require() an ESM modules. + */ +const engineSupportsPackageTypeField = parseInt(process.versions.node.split('.')[0], 10) >= 12; +/** + * Assert that script can be loaded as CommonJS when we attempt to require it. + * If it should be loaded as ESM, throw ERR_REQUIRE_ESM like node does. + * + * Loaded conditionally so we don't need to support older node versions + */ +let assertScriptCanLoadAsCJS = engineSupportsPackageTypeField + ? (__nccwpck_require__(88232).assertScriptCanLoadAsCJSImpl) + : () => { + /* noop */ + }; +/** + * Registered `ts-node` instance information. + */ +exports.REGISTER_INSTANCE = Symbol.for('ts-node.register.instance'); +/** @internal */ +exports.env = process.env; +/** + * @internal + */ +exports.INSPECT_CUSTOM = util.inspect.custom || 'inspect'; +/** + * Debugging `ts-node`. + */ +const shouldDebug = (0, util_1.yn)(exports.env.TS_NODE_DEBUG); +/** @internal */ +exports.debug = shouldDebug + ? (...args) => console.log(`[ts-node ${new Date().toISOString()}]`, ...args) + : () => undefined; +const debugFn = shouldDebug + ? (key, fn) => { + let i = 0; + return (x) => { + (0, exports.debug)(key, x, ++i); + return fn(x); + }; } - - // Base dir does not exist, and no -p option given - var baseDir = path.dirname(dir); - if (!fs.existsSync(baseDir) && !options.fullpath) { - common.error('no such file or directory: ' + baseDir, { continue: true }); - return; // skip dir + : (_, fn) => fn; +/** + * Export the current version. + */ +exports.VERSION = __nccwpck_require__(46686).version; +/** + * Default register options, including values specified via environment + * variables. + * @internal + */ +exports.DEFAULTS = { + cwd: (_a = exports.env.TS_NODE_CWD) !== null && _a !== void 0 ? _a : exports.env.TS_NODE_DIR, + emit: (0, util_1.yn)(exports.env.TS_NODE_EMIT), + scope: (0, util_1.yn)(exports.env.TS_NODE_SCOPE), + scopeDir: exports.env.TS_NODE_SCOPE_DIR, + files: (0, util_1.yn)(exports.env.TS_NODE_FILES), + pretty: (0, util_1.yn)(exports.env.TS_NODE_PRETTY), + compiler: exports.env.TS_NODE_COMPILER, + compilerOptions: (0, util_1.parse)(exports.env.TS_NODE_COMPILER_OPTIONS), + ignore: (0, util_1.split)(exports.env.TS_NODE_IGNORE), + project: exports.env.TS_NODE_PROJECT, + skipProject: (0, util_1.yn)(exports.env.TS_NODE_SKIP_PROJECT), + skipIgnore: (0, util_1.yn)(exports.env.TS_NODE_SKIP_IGNORE), + preferTsExts: (0, util_1.yn)(exports.env.TS_NODE_PREFER_TS_EXTS), + ignoreDiagnostics: (0, util_1.split)(exports.env.TS_NODE_IGNORE_DIAGNOSTICS), + transpileOnly: (0, util_1.yn)(exports.env.TS_NODE_TRANSPILE_ONLY), + typeCheck: (0, util_1.yn)(exports.env.TS_NODE_TYPE_CHECK), + compilerHost: (0, util_1.yn)(exports.env.TS_NODE_COMPILER_HOST), + logError: (0, util_1.yn)(exports.env.TS_NODE_LOG_ERROR), + experimentalReplAwait: (_b = (0, util_1.yn)(exports.env.TS_NODE_EXPERIMENTAL_REPL_AWAIT)) !== null && _b !== void 0 ? _b : undefined, + tsTrace: console.log.bind(console), +}; +/** + * TypeScript diagnostics error. + */ +class TSError extends make_error_1.BaseError { + constructor(diagnosticText, diagnosticCodes, diagnostics = []) { + super(`⨯ Unable to compile TypeScript:\n${diagnosticText}`); + this.diagnosticCodes = diagnosticCodes; + this.name = 'TSError'; + Object.defineProperty(this, 'diagnosticText', { + configurable: true, + writable: true, + value: diagnosticText, + }); + Object.defineProperty(this, 'diagnostics', { + configurable: true, + writable: true, + value: diagnostics, + }); } - - try { - if (options.fullpath) { - mkdirSyncRecursive(path.resolve(dir)); - } else { - fs.mkdirSync(dir, parseInt('0777', 8)); - } - } catch (e) { - var reason; - if (e.code === 'EACCES') { - reason = 'Permission denied'; - } else if (e.code === 'ENOTDIR' || e.code === 'ENOENT') { - reason = 'Not a directory'; - } else { - /* istanbul ignore next */ - throw e; - } - common.error('cannot create directory ' + dir + ': ' + reason, { continue: true }); + /** + * @internal + */ + [exports.INSPECT_CUSTOM]() { + return this.diagnosticText; } - }); - return ''; -} // mkdir -module.exports = _mkdir; - - -/***/ }), - -/***/ 31285: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { - -var fs = __nccwpck_require__(57147); -var path = __nccwpck_require__(71017); -var common = __nccwpck_require__(17673); -var cp = __nccwpck_require__(6135); -var rm = __nccwpck_require__(37720); - -common.register('mv', _mv, { - cmdOptions: { - 'f': '!no_force', - 'n': 'no_force', - }, -}); - -// Checks if cureent file was created recently -function checkRecentCreated(sources, index) { - var lookedSource = sources[index]; - return sources.slice(0, index).some(function (src) { - return path.basename(src) === path.basename(lookedSource); - }); } - -//@ -//@ ### mv([options ,] source [, source ...], dest') -//@ ### mv([options ,] source_array, dest') -//@ -//@ Available options: -//@ -//@ + `-f`: force (default behavior) -//@ + `-n`: no-clobber -//@ -//@ Examples: -//@ -//@ ```javascript -//@ mv('-n', 'file', 'dir/'); -//@ mv('file1', 'file2', 'dir/'); -//@ mv(['file1', 'file2'], 'dir/'); // same as above -//@ ``` -//@ -//@ Moves `source` file(s) to `dest`. -function _mv(options, sources, dest) { - // Get sources, dest - if (arguments.length < 3) { - common.error('missing and/or '); - } else if (arguments.length > 3) { - sources = [].slice.call(arguments, 1, arguments.length - 1); - dest = arguments[arguments.length - 1]; - } else if (typeof sources === 'string') { - sources = [sources]; - } else { - // TODO(nate): figure out if we actually need this line - common.error('invalid arguments'); - } - - var exists = fs.existsSync(dest); - var stats = exists && common.statFollowLinks(dest); - - // Dest is not existing dir, but multiple sources given - if ((!exists || !stats.isDirectory()) && sources.length > 1) { - common.error('dest is not a directory (too many sources)'); - } - - // Dest is an existing file, but no -f given - if (exists && stats.isFile() && options.no_force) { - common.error('dest file already exists: ' + dest); - } - - sources.forEach(function (src, srcIndex) { - if (!fs.existsSync(src)) { - common.error('no such file or directory: ' + src, { continue: true }); - return; // skip file +exports.TSError = TSError; +const TS_NODE_SERVICE_BRAND = Symbol('TS_NODE_SERVICE_BRAND'); +function register(serviceOrOpts) { + // Is this a Service or a RegisterOptions? + let service = serviceOrOpts; + if (!(serviceOrOpts === null || serviceOrOpts === void 0 ? void 0 : serviceOrOpts[TS_NODE_SERVICE_BRAND])) { + // Not a service; is options + service = create((serviceOrOpts !== null && serviceOrOpts !== void 0 ? serviceOrOpts : {})); } - - // If here, src exists - - // When copying to '/path/dir': - // thisDest = '/path/dir/file1' - var thisDest = dest; - if (fs.existsSync(dest) && common.statFollowLinks(dest).isDirectory()) { - thisDest = path.normalize(dest + '/' + path.basename(src)); + const originalJsHandler = require.extensions['.js']; + // Expose registered instance globally. + process[exports.REGISTER_INSTANCE] = service; + // Register the extensions. + registerExtensions(service.options.preferTsExts, service.extensions.compiled, service, originalJsHandler); + (0, cjs_resolve_hooks_1.installCommonjsResolveHooksIfNecessary)(service); + // Require specified modules before start-up. + module_1.Module._preloadModules(service.options.require); + return service; +} +exports.register = register; +/** + * Create TypeScript compiler instance. + * + * @category Basic + */ +function create(rawOptions = {}) { + const foundConfigResult = (0, configuration_1.findAndReadConfig)(rawOptions); + return createFromPreloadedConfig(foundConfigResult); +} +exports.create = create; +/** @internal */ +function createFromPreloadedConfig(foundConfigResult) { + var _a, _b, _c, _d; + const { configFilePath, cwd, options, config, compiler, projectLocalResolveDir, optionBasePaths, } = foundConfigResult; + const projectLocalResolveHelper = (0, util_1.createProjectLocalResolveHelper)(projectLocalResolveDir); + const ts = (0, configuration_1.loadCompiler)(compiler); + // Experimental REPL await is not compatible targets lower than ES2018 + const targetSupportsTla = config.options.target >= ts.ScriptTarget.ES2018; + if (options.experimentalReplAwait === true && !targetSupportsTla) { + throw new Error('Experimental REPL await is not compatible with targets lower than ES2018'); } - - var thisDestExists = fs.existsSync(thisDest); - - if (thisDestExists && checkRecentCreated(sources, srcIndex)) { - // cannot overwrite file created recently in current execution, but we want to continue copying other files - if (!options.no_force) { - common.error("will not overwrite just-created '" + thisDest + "' with '" + src + "'", { continue: true }); - } - return; + // Top-level await was added in TS 3.8 + const tsVersionSupportsTla = (0, util_1.versionGteLt)(ts.version, '3.8.0'); + if (options.experimentalReplAwait === true && !tsVersionSupportsTla) { + throw new Error('Experimental REPL await is not compatible with TypeScript versions older than 3.8'); } - - if (fs.existsSync(thisDest) && options.no_force) { - common.error('dest file already exists: ' + thisDest, { continue: true }); - return; // skip file + const shouldReplAwait = options.experimentalReplAwait !== false && + tsVersionSupportsTla && + targetSupportsTla; + // swc implies two other options + // typeCheck option was implemented specifically to allow overriding tsconfig transpileOnly from the command-line + // So we should allow using typeCheck to override swc + if (options.swc && !options.typeCheck) { + if (options.transpileOnly === false) { + throw new Error("Cannot enable 'swc' option with 'transpileOnly: false'. 'swc' implies 'transpileOnly'."); + } + if (options.transpiler) { + throw new Error("Cannot specify both 'swc' and 'transpiler' options. 'swc' uses the built-in swc transpiler."); + } } - - if (path.resolve(src) === path.dirname(path.resolve(thisDest))) { - common.error('cannot move to self: ' + src, { continue: true }); - return; // skip file + const readFile = options.readFile || ts.sys.readFile; + const fileExists = options.fileExists || ts.sys.fileExists; + // typeCheck can override transpileOnly, useful for CLI flag to override config file + const transpileOnly = (options.transpileOnly === true || options.swc === true) && + options.typeCheck !== true; + let transpiler = undefined; + let transpilerBasePath = undefined; + if (options.transpiler) { + transpiler = options.transpiler; + transpilerBasePath = optionBasePaths.transpiler; } - - try { - fs.renameSync(src, thisDest); - } catch (e) { - /* istanbul ignore next */ - if (e.code === 'EXDEV') { - // If we're trying to `mv` to an external partition, we'll actually need - // to perform a copy and then clean up the original file. If either the - // copy or the rm fails with an exception, we should allow this - // exception to pass up to the top level. - cp('-r', src, thisDest); - rm('-rf', src); - } + else if (options.swc) { + transpiler = __nccwpck_require__.ab + "swc.js"; + transpilerBasePath = optionBasePaths.swc; } - }); // forEach(src) - return ''; -} // mv -module.exports = _mv; - - -/***/ }), - -/***/ 42535: -/***/ (() => { - -// see dirs.js - - -/***/ }), - -/***/ 47928: -/***/ (() => { - -// see dirs.js - - -/***/ }), - -/***/ 24020: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { - -var path = __nccwpck_require__(71017); -var common = __nccwpck_require__(17673); - -common.register('pwd', _pwd, { - allowGlobbing: false, -}); - -//@ -//@ ### pwd() -//@ -//@ Returns the current directory. -function _pwd() { - var pwd = path.resolve(process.cwd()); - return pwd; -} -module.exports = _pwd; - - -/***/ }), - -/***/ 37720: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { - -var common = __nccwpck_require__(17673); -var fs = __nccwpck_require__(57147); - -common.register('rm', _rm, { - cmdOptions: { - 'f': 'force', - 'r': 'recursive', - 'R': 'recursive', - }, -}); - -// Recursively removes 'dir' -// Adapted from https://github.com/ryanmcgrath/wrench-js -// -// Copyright (c) 2010 Ryan McGrath -// Copyright (c) 2012 Artur Adib -// -// Licensed under the MIT License -// http://www.opensource.org/licenses/mit-license.php -function rmdirSyncRecursive(dir, force, fromSymlink) { - var files; - - files = fs.readdirSync(dir); - - // Loop through and delete everything in the sub-tree after checking it - for (var i = 0; i < files.length; i++) { - var file = dir + '/' + files[i]; - var currFile = common.statNoFollowLinks(file); - - if (currFile.isDirectory()) { // Recursive function back to the beginning - rmdirSyncRecursive(file, force); - } else { // Assume it's a file - perhaps a try/catch belongs here? - if (force || isWriteable(file)) { - try { - common.unlinkSync(file); - } catch (e) { - /* istanbul ignore next */ - common.error('could not remove file (code ' + e.code + '): ' + file, { - continue: true, - }); - } - } + const transformers = options.transformers || undefined; + const diagnosticFilters = [ + { + appliesToAllFiles: true, + filenamesAbsolute: [], + diagnosticsIgnored: [ + 6059, + 18002, + 18003, + ...(options.experimentalTsImportSpecifiers + ? [ + 2691, // "An import path cannot end with a '.ts' extension. Consider importing '' instead." + ] + : []), + ...(options.ignoreDiagnostics || []), + ].map(Number), + }, + ]; + const configDiagnosticList = filterDiagnostics(config.errors, diagnosticFilters); + const outputCache = new Map(); + const configFileDirname = configFilePath ? (0, path_1.dirname)(configFilePath) : null; + const scopeDir = (_c = (_b = (_a = options.scopeDir) !== null && _a !== void 0 ? _a : config.options.rootDir) !== null && _b !== void 0 ? _b : configFileDirname) !== null && _c !== void 0 ? _c : cwd; + const ignoreBaseDir = configFileDirname !== null && configFileDirname !== void 0 ? configFileDirname : cwd; + const isScoped = options.scope + ? (fileName) => (0, path_1.relative)(scopeDir, fileName).charAt(0) !== '.' + : () => true; + const shouldIgnore = createIgnore(ignoreBaseDir, options.skipIgnore + ? [] + : (options.ignore || ['(?:^|/)node_modules/']).map((str) => new RegExp(str))); + const diagnosticHost = { + getNewLine: () => ts.sys.newLine, + getCurrentDirectory: () => cwd, + // TODO switch to getCanonicalFileName we already create later in scope + getCanonicalFileName: ts.sys.useCaseSensitiveFileNames + ? (x) => x + : (x) => x.toLowerCase(), + }; + if (options.transpileOnly && typeof transformers === 'function') { + throw new TypeError('Transformers function is unavailable in "--transpile-only"'); } - } - - // if was directory was referenced through a symbolic link, - // the contents should be removed, but not the directory itself - if (fromSymlink) return; - - // Now that we know everything in the sub-tree has been deleted, we can delete the main directory. - // Huzzah for the shopkeep. - - var result; - try { - // Retry on windows, sometimes it takes a little time before all the files in the directory are gone - var start = Date.now(); - - // TODO: replace this with a finite loop - for (;;) { - try { - result = fs.rmdirSync(dir); - if (fs.existsSync(dir)) throw { code: 'EAGAIN' }; - break; - } catch (er) { - /* istanbul ignore next */ - // In addition to error codes, also check if the directory still exists and loop again if true - if (process.platform === 'win32' && (er.code === 'ENOTEMPTY' || er.code === 'EBUSY' || er.code === 'EPERM' || er.code === 'EAGAIN')) { - if (Date.now() - start > 1000) throw er; - } else if (er.code === 'ENOENT') { - // Directory did not exist, deletion was successful - break; - } else { - throw er; + let createTranspiler = initializeTranspilerFactory(); + function initializeTranspilerFactory() { + var _a; + if (__nccwpck_require__.ab + "swc.js") { + if (!transpileOnly) + throw new Error('Custom transpiler can only be used when transpileOnly is enabled.'); + const transpilerName = typeof transpiler === 'string' ? transpiler : transpiler[0]; + const transpilerOptions = typeof transpiler === 'string' ? {} : (_a = transpiler[1]) !== null && _a !== void 0 ? _a : {}; + const transpilerConfigLocalResolveHelper = transpilerBasePath + ? (0, util_1.createProjectLocalResolveHelper)(transpilerBasePath) + : projectLocalResolveHelper; + const transpilerPath = transpilerConfigLocalResolveHelper(transpilerName, true); + const transpilerFactory = __nccwpck_require__(3833)(transpilerPath) + .create; + return createTranspiler; + function createTranspiler(compilerOptions, nodeModuleEmitKind) { + return transpilerFactory === null || transpilerFactory === void 0 ? void 0 : transpilerFactory({ + service: { + options, + config: { + ...config, + options: compilerOptions, + }, + projectLocalResolveHelper, + }, + transpilerConfigLocalResolveHelper, + nodeModuleEmitKind, + ...transpilerOptions, + }); + } } - } - } - } catch (e) { - common.error('could not remove directory (code ' + e.code + '): ' + dir, { continue: true }); - } - - return result; -} // rmdirSyncRecursive - -// Hack to determine if file has write permissions for current user -// Avoids having to check user, group, etc, but it's probably slow -function isWriteable(file) { - var writePermission = true; - try { - var __fd = fs.openSync(file, 'a'); - fs.closeSync(__fd); - } catch (e) { - writePermission = false; - } - - return writePermission; -} - -function handleFile(file, options) { - if (options.force || isWriteable(file)) { - // -f was passed, or file is writable, so it can be removed - common.unlinkSync(file); - } else { - common.error('permission denied: ' + file, { continue: true }); - } -} - -function handleDirectory(file, options) { - if (options.recursive) { - // -r was passed, so directory can be removed - rmdirSyncRecursive(file, options.force); - } else { - common.error('path is a directory', { continue: true }); - } -} - -function handleSymbolicLink(file, options) { - var stats; - try { - stats = common.statFollowLinks(file); - } catch (e) { - // symlink is broken, so remove the symlink itself - common.unlinkSync(file); - return; - } - - if (stats.isFile()) { - common.unlinkSync(file); - } else if (stats.isDirectory()) { - if (file[file.length - 1] === '/') { - // trailing separator, so remove the contents, not the link - if (options.recursive) { - // -r was passed, so directory can be removed - var fromSymlink = true; - rmdirSyncRecursive(file, options.force, fromSymlink); - } else { - common.error('path is a directory', { continue: true }); - } - } else { - // no trailing separator, so remove the link - common.unlinkSync(file); } - } -} - -function handleFIFO(file) { - common.unlinkSync(file); -} - -//@ -//@ ### rm([options,] file [, file ...]) -//@ ### rm([options,] file_array) -//@ -//@ Available options: -//@ -//@ + `-f`: force -//@ + `-r, -R`: recursive -//@ -//@ Examples: -//@ -//@ ```javascript -//@ rm('-rf', '/tmp/*'); -//@ rm('some_file.txt', 'another_file.txt'); -//@ rm(['some_file.txt', 'another_file.txt']); // same as above -//@ ``` -//@ -//@ Removes files. -function _rm(options, files) { - if (!files) common.error('no paths given'); - - // Convert to array - files = [].slice.call(arguments, 1); - - files.forEach(function (file) { - var lstats; - try { - var filepath = (file[file.length - 1] === '/') - ? file.slice(0, -1) // remove the '/' so lstatSync can detect symlinks - : file; - lstats = common.statNoFollowLinks(filepath); // test for existence - } catch (e) { - // Path does not exist, no force flag given - if (!options.force) { - common.error('no such file or directory: ' + file, { continue: true }); - } - return; // skip file + /** + * True if require() hooks should interop with experimental ESM loader. + * Enabled explicitly via a flag since it is a breaking change. + */ + let experimentalEsmLoader = false; + function enableExperimentalEsmLoaderInterop() { + experimentalEsmLoader = true; } - - // If here, path exists - if (lstats.isFile()) { - handleFile(file, options); - } else if (lstats.isDirectory()) { - handleDirectory(file, options); - } else if (lstats.isSymbolicLink()) { - handleSymbolicLink(file, options); - } else if (lstats.isFIFO()) { - handleFIFO(file); + // Install source map support and read from memory cache. + installSourceMapSupport(); + function installSourceMapSupport() { + const sourceMapSupport = __nccwpck_require__(89254); + sourceMapSupport.install({ + environment: 'node', + retrieveFile(pathOrUrl) { + var _a; + let path = pathOrUrl; + // If it's a file URL, convert to local path + // Note: fileURLToPath does not exist on early node v10 + // I could not find a way to handle non-URLs except to swallow an error + if (experimentalEsmLoader && path.startsWith('file://')) { + try { + path = (0, url_1.fileURLToPath)(path); + } + catch (e) { + /* swallow error */ + } + } + path = (0, util_1.normalizeSlashes)(path); + return ((_a = outputCache.get(path)) === null || _a === void 0 ? void 0 : _a.content) || ''; + }, + redirectConflictingLibrary: true, + onConflictingLibraryRedirect(request, parent, isMain, options, redirectedRequest) { + (0, exports.debug)(`Redirected an attempt to require source-map-support to instead receive @cspotcode/source-map-support. "${parent.filename}" attempted to require or resolve "${request}" and was redirected to "${redirectedRequest}".`); + }, + }); } - }); // forEach(file) - return ''; -} // rm -module.exports = _rm; - - -/***/ }), - -/***/ 46926: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { - -var common = __nccwpck_require__(17673); -var fs = __nccwpck_require__(57147); - -common.register('sed', _sed, { - globStart: 3, // don't glob-expand regexes - canReceivePipe: true, - cmdOptions: { - 'i': 'inplace', - }, -}); - -//@ -//@ ### sed([options,] search_regex, replacement, file [, file ...]) -//@ ### sed([options,] search_regex, replacement, file_array) -//@ -//@ Available options: -//@ -//@ + `-i`: Replace contents of `file` in-place. _Note that no backups will be created!_ -//@ -//@ Examples: -//@ -//@ ```javascript -//@ sed('-i', 'PROGRAM_VERSION', 'v0.1.3', 'source.js'); -//@ sed(/.*DELETE_THIS_LINE.*\n/, '', 'source.js'); -//@ ``` -//@ -//@ Reads an input string from `file`s, and performs a JavaScript `replace()` on the input -//@ using the given `search_regex` and `replacement` string or function. Returns the new string after replacement. -//@ -//@ Note: -//@ -//@ Like unix `sed`, ShellJS `sed` supports capture groups. Capture groups are specified -//@ using the `$n` syntax: -//@ -//@ ```javascript -//@ sed(/(\w+)\s(\w+)/, '$2, $1', 'file.txt'); -//@ ``` -function _sed(options, regex, replacement, files) { - // Check if this is coming from a pipe - var pipe = common.readFromPipe(); - - if (typeof replacement !== 'string' && typeof replacement !== 'function') { - if (typeof replacement === 'number') { - replacement = replacement.toString(); // fallback - } else { - common.error('invalid replacement string'); + const shouldHavePrettyErrors = options.pretty === undefined ? process.stdout.isTTY : options.pretty; + const formatDiagnostics = shouldHavePrettyErrors + ? ts.formatDiagnosticsWithColorAndContext || ts.formatDiagnostics + : ts.formatDiagnostics; + function createTSError(diagnostics) { + const diagnosticText = formatDiagnostics(diagnostics, diagnosticHost); + const diagnosticCodes = diagnostics.map((x) => x.code); + return new TSError(diagnosticText, diagnosticCodes, diagnostics); } - } - - // Convert all search strings to RegExp - if (typeof regex === 'string') { - regex = RegExp(regex); - } - - if (!files && !pipe) { - common.error('no files given'); - } - - files = [].slice.call(arguments, 3); - - if (pipe) { - files.unshift('-'); - } - - var sed = []; - files.forEach(function (file) { - if (!fs.existsSync(file) && file !== '-') { - common.error('no such file or directory: ' + file, 2, { continue: true }); - return; + function reportTSError(configDiagnosticList) { + const error = createTSError(configDiagnosticList); + if (options.logError) { + // Print error in red color and continue execution. + console.error('\x1b[31m%s\x1b[0m', error); + } + else { + // Throw error and exit the script. + throw error; + } } - - var contents = file === '-' ? pipe : fs.readFileSync(file, 'utf8'); - var lines = contents.split('\n'); - var result = lines.map(function (line) { - return line.replace(regex, replacement); - }).join('\n'); - - sed.push(result); - - if (options.inplace) { - fs.writeFileSync(file, result, 'utf8'); + // Render the configuration errors. + if (configDiagnosticList.length) + reportTSError(configDiagnosticList); + const jsxEmitPreserve = config.options.jsx === ts.JsxEmit.Preserve; + /** + * Get the extension for a transpiled file. + * [MUST_UPDATE_FOR_NEW_FILE_EXTENSIONS] + */ + function getEmitExtension(path) { + const lastDotIndex = path.lastIndexOf('.'); + if (lastDotIndex >= 0) { + const ext = path.slice(lastDotIndex); + switch (ext) { + case '.js': + case '.ts': + return '.js'; + case '.jsx': + case '.tsx': + return jsxEmitPreserve ? '.jsx' : '.js'; + case '.mjs': + case '.mts': + return '.mjs'; + case '.cjs': + case '.cts': + return '.cjs'; + } + } + return '.js'; } - }); - - return sed.join('\n'); -} -module.exports = _sed; - - -/***/ }), - -/***/ 20011: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { - -var common = __nccwpck_require__(17673); - -common.register('set', _set, { - allowGlobbing: false, - wrapOutput: false, -}); - -//@ -//@ ### set(options) -//@ -//@ Available options: -//@ -//@ + `+/-e`: exit upon error (`config.fatal`) -//@ + `+/-v`: verbose: show all commands (`config.verbose`) -//@ + `+/-f`: disable filename expansion (globbing) -//@ -//@ Examples: -//@ -//@ ```javascript -//@ set('-e'); // exit upon first error -//@ set('+e'); // this undoes a "set('-e')" -//@ ``` -//@ -//@ Sets global configuration variables. -function _set(options) { - if (!options) { - var args = [].slice.call(arguments, 0); - if (args.length < 2) common.error('must provide an argument'); - options = args[1]; - } - var negate = (options[0] === '+'); - if (negate) { - options = '-' + options.slice(1); // parseOptions needs a '-' prefix - } - options = common.parseOptions(options, { - 'e': 'fatal', - 'v': 'verbose', - 'f': 'noglob', - }); - - if (negate) { - Object.keys(options).forEach(function (key) { - options[key] = !options[key]; + /** + * Get output from TS compiler w/typechecking. `undefined` in `transpileOnly` + * mode. + */ + let getOutput; + let getTypeInfo; + const getCanonicalFileName = ts.createGetCanonicalFileName(ts.sys.useCaseSensitiveFileNames); + const moduleTypeClassifier = (0, module_type_classifier_1.createModuleTypeClassifier)({ + basePath: (_d = options.optionBasePaths) === null || _d === void 0 ? void 0 : _d.moduleTypes, + patterns: options.moduleTypes, }); - } - - Object.keys(options).forEach(function (key) { - // Only change the global config if `negate` is false and the option is true - // or if `negate` is true and the option is false (aka negate !== option) - if (negate !== options[key]) { - common.config[key] = options[key]; - } - }); - return; -} -module.exports = _set; - - -/***/ }), - -/***/ 37472: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { - -var common = __nccwpck_require__(17673); -var fs = __nccwpck_require__(57147); - -common.register('sort', _sort, { - canReceivePipe: true, - cmdOptions: { - 'r': 'reverse', - 'n': 'numerical', - }, -}); - -// parse out the number prefix of a line -function parseNumber(str) { - var match = str.match(/^\s*(\d*)\s*(.*)$/); - return { num: Number(match[1]), value: match[2] }; -} - -// compare two strings case-insensitively, but examine case for strings that are -// case-insensitive equivalent -function unixCmp(a, b) { - var aLower = a.toLowerCase(); - var bLower = b.toLowerCase(); - return (aLower === bLower ? - -1 * a.localeCompare(b) : // unix sort treats case opposite how javascript does - aLower.localeCompare(bLower)); -} - -// compare two strings in the fashion that unix sort's -n option works -function numericalCmp(a, b) { - var objA = parseNumber(a); - var objB = parseNumber(b); - if (objA.hasOwnProperty('num') && objB.hasOwnProperty('num')) { - return ((objA.num !== objB.num) ? - (objA.num - objB.num) : - unixCmp(objA.value, objB.value)); - } else { - return unixCmp(objA.value, objB.value); - } -} - -//@ -//@ ### sort([options,] file [, file ...]) -//@ ### sort([options,] file_array) -//@ -//@ Available options: -//@ -//@ + `-r`: Reverse the results -//@ + `-n`: Compare according to numerical value -//@ -//@ Examples: -//@ -//@ ```javascript -//@ sort('foo.txt', 'bar.txt'); -//@ sort('-r', 'foo.txt'); -//@ ``` -//@ -//@ Return the contents of the `file`s, sorted line-by-line. Sorting multiple -//@ files mixes their content (just as unix `sort` does). -function _sort(options, files) { - // Check if this is coming from a pipe - var pipe = common.readFromPipe(); - - if (!files && !pipe) common.error('no files given'); - - files = [].slice.call(arguments, 1); - - if (pipe) { - files.unshift('-'); - } - - var lines = files.reduce(function (accum, file) { - if (file !== '-') { - if (!fs.existsSync(file)) { - common.error('no such file or directory: ' + file, { continue: true }); - return accum; - } else if (common.statFollowLinks(file).isDirectory()) { - common.error('read failed: ' + file + ': Is a directory', { - continue: true, - }); - return accum; - } - } - - var contents = file === '-' ? pipe : fs.readFileSync(file, 'utf8'); - return accum.concat(contents.trimRight().split('\n')); - }, []); - - var sorted = lines.sort(options.numerical ? numericalCmp : unixCmp); - - if (options.reverse) { - sorted = sorted.reverse(); - } - - return sorted.join('\n') + '\n'; -} - -module.exports = _sort; - - -/***/ }), - -/***/ 18968: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { - -var common = __nccwpck_require__(17673); -var fs = __nccwpck_require__(57147); - -common.register('tail', _tail, { - canReceivePipe: true, - cmdOptions: { - 'n': 'numLines', - }, -}); - -//@ -//@ ### tail([{'-n': \},] file [, file ...]) -//@ ### tail([{'-n': \},] file_array) -//@ -//@ Available options: -//@ -//@ + `-n `: Show the last `` lines of `file`s -//@ -//@ Examples: -//@ -//@ ```javascript -//@ var str = tail({'-n': 1}, 'file*.txt'); -//@ var str = tail('file1', 'file2'); -//@ var str = tail(['file1', 'file2']); // same as above -//@ ``` -//@ -//@ Read the end of a `file`. -function _tail(options, files) { - var tail = []; - var pipe = common.readFromPipe(); - - if (!files && !pipe) common.error('no paths given'); - - var idx = 1; - if (options.numLines === true) { - idx = 2; - options.numLines = Number(arguments[1]); - } else if (options.numLines === false) { - options.numLines = 10; - } - options.numLines = -1 * Math.abs(options.numLines); - files = [].slice.call(arguments, idx); - - if (pipe) { - files.unshift('-'); - } - - var shouldAppendNewline = false; - files.forEach(function (file) { - if (file !== '-') { - if (!fs.existsSync(file)) { - common.error('no such file or directory: ' + file, { continue: true }); - return; - } else if (common.statFollowLinks(file).isDirectory()) { - common.error("error reading '" + file + "': Is a directory", { - continue: true, + const extensions = (0, file_extensions_1.getExtensions)(config, options, ts.version); + // Use full language services when the fast option is disabled. + if (!transpileOnly) { + const fileContents = new Map(); + const rootFileNames = new Set(config.fileNames); + const cachedReadFile = (0, util_1.cachedLookup)(debugFn('readFile', readFile)); + // Use language services by default + if (!options.compilerHost) { + let projectVersion = 1; + const fileVersions = new Map(Array.from(rootFileNames).map((fileName) => [fileName, 0])); + const getCustomTransformers = () => { + if (typeof transformers === 'function') { + const program = service.getProgram(); + return program ? transformers(program) : undefined; + } + return transformers; + }; + // Create the compiler host for type checking. + const serviceHost = { + getProjectVersion: () => String(projectVersion), + getScriptFileNames: () => Array.from(rootFileNames), + getScriptVersion: (fileName) => { + const version = fileVersions.get(fileName); + return version ? version.toString() : ''; + }, + getScriptSnapshot(fileName) { + // TODO ordering of this with getScriptVersion? Should they sync up? + let contents = fileContents.get(fileName); + // Read contents into TypeScript memory cache. + if (contents === undefined) { + contents = cachedReadFile(fileName); + if (contents === undefined) + return; + fileVersions.set(fileName, 1); + fileContents.set(fileName, contents); + projectVersion++; + } + return ts.ScriptSnapshot.fromString(contents); + }, + readFile: cachedReadFile, + readDirectory: ts.sys.readDirectory, + getDirectories: (0, util_1.cachedLookup)(debugFn('getDirectories', ts.sys.getDirectories)), + fileExists: (0, util_1.cachedLookup)(debugFn('fileExists', fileExists)), + directoryExists: (0, util_1.cachedLookup)(debugFn('directoryExists', ts.sys.directoryExists)), + realpath: ts.sys.realpath + ? (0, util_1.cachedLookup)(debugFn('realpath', ts.sys.realpath)) + : undefined, + getNewLine: () => ts.sys.newLine, + useCaseSensitiveFileNames: () => ts.sys.useCaseSensitiveFileNames, + getCurrentDirectory: () => cwd, + getCompilationSettings: () => config.options, + getDefaultLibFileName: () => ts.getDefaultLibFilePath(config.options), + getCustomTransformers: getCustomTransformers, + trace: options.tsTrace, + }; + const { resolveModuleNames, getResolvedModuleWithFailedLookupLocationsFromCache, resolveTypeReferenceDirectives, isFileKnownToBeInternal, markBucketOfFilenameInternal, } = (0, resolver_functions_1.createResolverFunctions)({ + host: serviceHost, + getCanonicalFileName, + ts, + cwd, + config, + projectLocalResolveHelper, + options, + extensions, + }); + serviceHost.resolveModuleNames = resolveModuleNames; + serviceHost.getResolvedModuleWithFailedLookupLocationsFromCache = + getResolvedModuleWithFailedLookupLocationsFromCache; + serviceHost.resolveTypeReferenceDirectives = + resolveTypeReferenceDirectives; + const registry = ts.createDocumentRegistry(ts.sys.useCaseSensitiveFileNames, cwd); + const service = ts.createLanguageService(serviceHost, registry); + const updateMemoryCache = (contents, fileName) => { + // Add to `rootFiles` as necessary, either to make TS include a file it has not seen, + // or to trigger a re-classification of files from external to internal. + if (!rootFileNames.has(fileName) && + !isFileKnownToBeInternal(fileName)) { + markBucketOfFilenameInternal(fileName); + rootFileNames.add(fileName); + // Increment project version for every change to rootFileNames. + projectVersion++; + } + const previousVersion = fileVersions.get(fileName) || 0; + const previousContents = fileContents.get(fileName); + // Avoid incrementing cache when nothing has changed. + if (contents !== previousContents) { + fileVersions.set(fileName, previousVersion + 1); + fileContents.set(fileName, contents); + // Increment project version for every file change. + projectVersion++; + } + }; + let previousProgram = undefined; + getOutput = (code, fileName) => { + updateMemoryCache(code, fileName); + const programBefore = service.getProgram(); + if (programBefore !== previousProgram) { + (0, exports.debug)(`compiler rebuilt Program instance when getting output for ${fileName}`); + } + const output = service.getEmitOutput(fileName); + // Get the relevant diagnostics - this is 3x faster than `getPreEmitDiagnostics`. + const diagnostics = service + .getSemanticDiagnostics(fileName) + .concat(service.getSyntacticDiagnostics(fileName)); + const programAfter = service.getProgram(); + (0, exports.debug)('invariant: Is service.getProject() identical before and after getting emit output and diagnostics? (should always be true) ', programBefore === programAfter); + previousProgram = programAfter; + const diagnosticList = filterDiagnostics(diagnostics, diagnosticFilters); + if (diagnosticList.length) + reportTSError(diagnosticList); + if (output.emitSkipped) { + return [undefined, undefined, true]; + } + // Throw an error when requiring `.d.ts` files. + if (output.outputFiles.length === 0) { + throw new TypeError(`Unable to require file: ${(0, path_1.relative)(cwd, fileName)}\n` + + 'This is usually the result of a faulty configuration or import. ' + + 'Make sure there is a `.js`, `.json` or other executable extension with ' + + 'loader attached before `ts-node` available.'); + } + return [output.outputFiles[1].text, output.outputFiles[0].text, false]; + }; + getTypeInfo = (code, fileName, position) => { + const normalizedFileName = (0, util_1.normalizeSlashes)(fileName); + updateMemoryCache(code, normalizedFileName); + const info = service.getQuickInfoAtPosition(normalizedFileName, position); + const name = ts.displayPartsToString(info ? info.displayParts : []); + const comment = ts.displayPartsToString(info ? info.documentation : []); + return { name, comment }; + }; + } + else { + const sys = { + ...ts.sys, + ...diagnosticHost, + readFile: (fileName) => { + const cacheContents = fileContents.get(fileName); + if (cacheContents !== undefined) + return cacheContents; + const contents = cachedReadFile(fileName); + if (contents) + fileContents.set(fileName, contents); + return contents; + }, + readDirectory: ts.sys.readDirectory, + getDirectories: (0, util_1.cachedLookup)(debugFn('getDirectories', ts.sys.getDirectories)), + fileExists: (0, util_1.cachedLookup)(debugFn('fileExists', fileExists)), + directoryExists: (0, util_1.cachedLookup)(debugFn('directoryExists', ts.sys.directoryExists)), + resolvePath: (0, util_1.cachedLookup)(debugFn('resolvePath', ts.sys.resolvePath)), + realpath: ts.sys.realpath + ? (0, util_1.cachedLookup)(debugFn('realpath', ts.sys.realpath)) + : undefined, + }; + const host = ts.createIncrementalCompilerHost + ? ts.createIncrementalCompilerHost(config.options, sys) + : { + ...sys, + getSourceFile: (fileName, languageVersion) => { + const contents = sys.readFile(fileName); + if (contents === undefined) + return; + return ts.createSourceFile(fileName, contents, languageVersion); + }, + getDefaultLibLocation: () => (0, util_1.normalizeSlashes)((0, path_1.dirname)(compiler)), + getDefaultLibFileName: () => (0, util_1.normalizeSlashes)((0, path_1.join)((0, path_1.dirname)(compiler), ts.getDefaultLibFileName(config.options))), + useCaseSensitiveFileNames: () => sys.useCaseSensitiveFileNames, + }; + host.trace = options.tsTrace; + const { resolveModuleNames, resolveTypeReferenceDirectives, isFileKnownToBeInternal, markBucketOfFilenameInternal, } = (0, resolver_functions_1.createResolverFunctions)({ + host, + cwd, + config, + ts, + getCanonicalFileName, + projectLocalResolveHelper, + options, + extensions, + }); + host.resolveModuleNames = resolveModuleNames; + host.resolveTypeReferenceDirectives = resolveTypeReferenceDirectives; + // Fallback for older TypeScript releases without incremental API. + let builderProgram = ts.createIncrementalProgram + ? ts.createIncrementalProgram({ + rootNames: Array.from(rootFileNames), + options: config.options, + host, + configFileParsingDiagnostics: config.errors, + projectReferences: config.projectReferences, + }) + : ts.createEmitAndSemanticDiagnosticsBuilderProgram(Array.from(rootFileNames), config.options, host, undefined, config.errors, config.projectReferences); + // Read and cache custom transformers. + const customTransformers = typeof transformers === 'function' + ? transformers(builderProgram.getProgram()) + : transformers; + // Set the file contents into cache manually. + const updateMemoryCache = (contents, fileName) => { + const previousContents = fileContents.get(fileName); + const contentsChanged = previousContents !== contents; + if (contentsChanged) { + fileContents.set(fileName, contents); + } + // Add to `rootFiles` when discovered by compiler for the first time. + let addedToRootFileNames = false; + if (!rootFileNames.has(fileName) && + !isFileKnownToBeInternal(fileName)) { + markBucketOfFilenameInternal(fileName); + rootFileNames.add(fileName); + addedToRootFileNames = true; + } + // Update program when file changes. + if (addedToRootFileNames || contentsChanged) { + builderProgram = ts.createEmitAndSemanticDiagnosticsBuilderProgram(Array.from(rootFileNames), config.options, host, builderProgram, config.errors, config.projectReferences); + } + }; + getOutput = (code, fileName) => { + let outText = ''; + let outMap = ''; + updateMemoryCache(code, fileName); + const sourceFile = builderProgram.getSourceFile(fileName); + if (!sourceFile) + throw new TypeError(`Unable to read file: ${fileName}`); + const program = builderProgram.getProgram(); + const diagnostics = ts.getPreEmitDiagnostics(program, sourceFile); + const diagnosticList = filterDiagnostics(diagnostics, diagnosticFilters); + if (diagnosticList.length) + reportTSError(diagnosticList); + const result = builderProgram.emit(sourceFile, (path, file, writeByteOrderMark) => { + if (path.endsWith('.map')) { + outMap = file; + } + else { + outText = file; + } + if (options.emit) + sys.writeFile(path, file, writeByteOrderMark); + }, undefined, undefined, customTransformers); + if (result.emitSkipped) { + return [undefined, undefined, true]; + } + // Throw an error when requiring files that cannot be compiled. + if (outText === '') { + if (program.isSourceFileFromExternalLibrary(sourceFile)) { + throw new TypeError(`Unable to compile file from external library: ${(0, path_1.relative)(cwd, fileName)}`); + } + throw new TypeError(`Unable to require file: ${(0, path_1.relative)(cwd, fileName)}\n` + + 'This is usually the result of a faulty configuration or import. ' + + 'Make sure there is a `.js`, `.json` or other executable extension with ' + + 'loader attached before `ts-node` available.'); + } + return [outText, outMap, false]; + }; + getTypeInfo = (code, fileName, position) => { + const normalizedFileName = (0, util_1.normalizeSlashes)(fileName); + updateMemoryCache(code, normalizedFileName); + const sourceFile = builderProgram.getSourceFile(normalizedFileName); + if (!sourceFile) + throw new TypeError(`Unable to read file: ${fileName}`); + const node = getTokenAtPosition(ts, sourceFile, position); + const checker = builderProgram.getProgram().getTypeChecker(); + const symbol = checker.getSymbolAtLocation(node); + if (!symbol) + return { name: '', comment: '' }; + const type = checker.getTypeOfSymbolAtLocation(symbol, node); + const signatures = [ + ...type.getConstructSignatures(), + ...type.getCallSignatures(), + ]; + return { + name: signatures.length + ? signatures.map((x) => checker.signatureToString(x)).join('\n') + : checker.typeToString(type), + comment: ts.displayPartsToString(symbol ? symbol.getDocumentationComment(checker) : []), + }; + }; + // Write `.tsbuildinfo` when `--build` is enabled. + if (options.emit && config.options.incremental) { + process.on('exit', () => { + // Emits `.tsbuildinfo` to filesystem. + builderProgram.getProgram().emitBuildInfo(); + }); + } + } + } + else { + getTypeInfo = () => { + throw new TypeError('Type information is unavailable in "--transpile-only"'); + }; + } + function createTranspileOnlyGetOutputFunction(overrideModuleType, nodeModuleEmitKind) { + const compilerOptions = { ...config.options }; + if (overrideModuleType !== undefined) + compilerOptions.module = overrideModuleType; + let customTranspiler = createTranspiler === null || createTranspiler === void 0 ? void 0 : createTranspiler(compilerOptions, nodeModuleEmitKind); + let tsTranspileModule = (0, util_1.versionGteLt)(ts.version, '4.7.0') + ? (0, ts_transpile_module_1.createTsTranspileModule)(ts, { + compilerOptions, + reportDiagnostics: true, + transformers: transformers, + }) + : undefined; + return (code, fileName) => { + let result; + if (customTranspiler) { + result = customTranspiler.transpile(code, { + fileName, + }); + } + else if (tsTranspileModule) { + result = tsTranspileModule(code, { + fileName, + }, nodeModuleEmitKind === 'nodeesm' ? 'module' : 'commonjs'); + } + else { + result = ts.transpileModule(code, { + fileName, + compilerOptions, + reportDiagnostics: true, + transformers: transformers, + }); + } + const diagnosticList = filterDiagnostics(result.diagnostics || [], diagnosticFilters); + if (diagnosticList.length) + reportTSError(diagnosticList); + return [result.outputText, result.sourceMapText, false]; + }; + } + // When true, these mean that a `moduleType` override will cause a different emit + // than the TypeScript compiler, so we *must* overwrite the emit. + const shouldOverwriteEmitWhenForcingCommonJS = config.options.module !== ts.ModuleKind.CommonJS; + // [MUST_UPDATE_FOR_NEW_MODULEKIND] + const shouldOverwriteEmitWhenForcingEsm = !(config.options.module === ts.ModuleKind.ES2015 || + (ts.ModuleKind.ES2020 && config.options.module === ts.ModuleKind.ES2020) || + (ts.ModuleKind.ES2022 && config.options.module === ts.ModuleKind.ES2022) || + config.options.module === ts.ModuleKind.ESNext); + /** + * node16 or nodenext + * [MUST_UPDATE_FOR_NEW_MODULEKIND] + */ + const isNodeModuleType = (ts.ModuleKind.Node16 && config.options.module === ts.ModuleKind.Node16) || + (ts.ModuleKind.NodeNext && + config.options.module === ts.ModuleKind.NodeNext); + const getOutputForceCommonJS = createTranspileOnlyGetOutputFunction(ts.ModuleKind.CommonJS); + const getOutputForceNodeCommonJS = createTranspileOnlyGetOutputFunction(ts.ModuleKind.NodeNext, 'nodecjs'); + const getOutputForceNodeESM = createTranspileOnlyGetOutputFunction(ts.ModuleKind.NodeNext, 'nodeesm'); + // [MUST_UPDATE_FOR_NEW_MODULEKIND] + const getOutputForceESM = createTranspileOnlyGetOutputFunction(ts.ModuleKind.ES2022 || ts.ModuleKind.ES2020 || ts.ModuleKind.ES2015); + const getOutputTranspileOnly = createTranspileOnlyGetOutputFunction(); + // Create a simple TypeScript compiler proxy. + function compile(code, fileName, lineOffset = 0) { + const normalizedFileName = (0, util_1.normalizeSlashes)(fileName); + const classification = moduleTypeClassifier.classifyModuleByModuleTypeOverrides(normalizedFileName); + let value = ''; + let sourceMap = ''; + let emitSkipped = true; + if (getOutput) { + // Must always call normal getOutput to throw typechecking errors + [value, sourceMap, emitSkipped] = getOutput(code, normalizedFileName); + } + // If module classification contradicts the above, call the relevant transpiler + if (classification.moduleType === 'cjs' && + (shouldOverwriteEmitWhenForcingCommonJS || emitSkipped)) { + [value, sourceMap] = getOutputForceCommonJS(code, normalizedFileName); + } + else if (classification.moduleType === 'esm' && + (shouldOverwriteEmitWhenForcingEsm || emitSkipped)) { + [value, sourceMap] = getOutputForceESM(code, normalizedFileName); + } + else if (emitSkipped) { + // Happens when ts compiler skips emit or in transpileOnly mode + const classification = (0, node_module_type_classifier_1.classifyModule)(fileName, isNodeModuleType); + [value, sourceMap] = + classification === 'nodecjs' + ? getOutputForceNodeCommonJS(code, normalizedFileName) + : classification === 'nodeesm' + ? getOutputForceNodeESM(code, normalizedFileName) + : classification === 'cjs' + ? getOutputForceCommonJS(code, normalizedFileName) + : classification === 'esm' + ? getOutputForceESM(code, normalizedFileName) + : getOutputTranspileOnly(code, normalizedFileName); + } + const output = updateOutput(value, normalizedFileName, sourceMap, getEmitExtension); + outputCache.set(normalizedFileName, { content: output }); + return output; + } + let active = true; + const enabled = (enabled) => enabled === undefined ? active : (active = !!enabled); + const ignored = (fileName) => { + if (!active) + return true; + const ext = (0, path_1.extname)(fileName); + if (extensions.compiled.includes(ext)) { + return !isScoped(fileName) || shouldIgnore(fileName); + } + return true; + }; + function addDiagnosticFilter(filter) { + diagnosticFilters.push({ + ...filter, + filenamesAbsolute: filter.filenamesAbsolute.map((f) => (0, util_1.normalizeSlashes)(f)), }); - return; - } } - - var contents = file === '-' ? pipe : fs.readFileSync(file, 'utf8'); - - var lines = contents.split('\n'); - if (lines[lines.length - 1] === '') { - lines.pop(); - shouldAppendNewline = true; - } else { - shouldAppendNewline = false; + const getNodeEsmResolver = (0, util_1.once)(() => (__nccwpck_require__(74284).createResolve)({ + extensions, + preferTsExts: options.preferTsExts, + tsNodeExperimentalSpecifierResolution: options.experimentalSpecifierResolution, + })); + const getNodeEsmGetFormat = (0, util_1.once)(() => (__nccwpck_require__(17604).createGetFormat)(options.experimentalSpecifierResolution, getNodeEsmResolver())); + const getNodeCjsLoader = (0, util_1.once)(() => (__nccwpck_require__(88232).createCjsLoader)({ + extensions, + preferTsExts: options.preferTsExts, + nodeEsmResolver: getNodeEsmResolver(), + })); + return { + [TS_NODE_SERVICE_BRAND]: true, + ts, + compilerPath: compiler, + config, + compile, + getTypeInfo, + ignored, + enabled, + options, + configFilePath, + moduleTypeClassifier, + shouldReplAwait, + addDiagnosticFilter, + installSourceMapSupport, + enableExperimentalEsmLoaderInterop, + transpileOnly, + projectLocalResolveHelper, + getNodeEsmResolver, + getNodeEsmGetFormat, + getNodeCjsLoader, + extensions, + }; +} +exports.createFromPreloadedConfig = createFromPreloadedConfig; +/** + * Check if the filename should be ignored. + */ +function createIgnore(ignoreBaseDir, ignore) { + return (fileName) => { + const relname = (0, path_1.relative)(ignoreBaseDir, fileName); + const path = (0, util_1.normalizeSlashes)(relname); + return ignore.some((x) => x.test(path)); + }; +} +/** + * Register the extensions to support when importing files. + */ +function registerExtensions(preferTsExts, extensions, service, originalJsHandler) { + const exts = new Set(extensions); + // Can't add these extensions cuz would allow omitting file extension; node requires ext for .cjs and .mjs + // Unless they're already registered by something else (nyc does this): + // then we *must* hook them or else our transformer will not be called. + for (const cannotAdd of ['.mts', '.cts', '.mjs', '.cjs']) { + if (exts.has(cannotAdd) && !(0, util_1.hasOwnProperty)(require.extensions, cannotAdd)) { + // Unrecognized file exts can be transformed via the `.js` handler. + exts.add('.js'); + exts.delete(cannotAdd); + } + } + // Register new extensions. + for (const ext of exts) { + registerExtension(ext, service, originalJsHandler); + } + if (preferTsExts) { + const preferredExtensions = new Set([ + ...exts, + ...Object.keys(require.extensions), + ]); + // Re-sort iteration order of Object.keys() + for (const ext of preferredExtensions) { + const old = Object.getOwnPropertyDescriptor(require.extensions, ext); + delete require.extensions[ext]; + Object.defineProperty(require.extensions, ext, old); + } } - - tail = tail.concat(lines.slice(options.numLines)); - }); - - if (shouldAppendNewline) { - tail.push(''); // to add a trailing newline once we join - } - return tail.join('\n'); } -module.exports = _tail; - - -/***/ }), - -/***/ 40591: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { - -var common = __nccwpck_require__(17673); -var os = __nccwpck_require__(22037); -var fs = __nccwpck_require__(57147); - -common.register('tempdir', _tempDir, { - allowGlobbing: false, - wrapOutput: false, -}); - -// Returns false if 'dir' is not a writeable directory, 'dir' otherwise -function writeableDir(dir) { - if (!dir || !fs.existsSync(dir)) return false; - - if (!common.statFollowLinks(dir).isDirectory()) return false; - - var testFile = dir + '/' + common.randomFileName(); - try { - fs.writeFileSync(testFile, ' '); - common.unlinkSync(testFile); - return dir; - } catch (e) { - /* istanbul ignore next */ - return false; - } +/** + * Register the extension for node. + */ +function registerExtension(ext, service, originalHandler) { + const old = require.extensions[ext] || originalHandler; + require.extensions[ext] = function (m, filename) { + if (service.ignored(filename)) + return old(m, filename); + assertScriptCanLoadAsCJS(service, m, filename); + const _compile = m._compile; + m._compile = function (code, fileName) { + (0, exports.debug)('module._compile', fileName); + const result = service.compile(code, fileName); + return _compile.call(this, result, fileName); + }; + return old(m, filename); + }; } - -// Variable to cache the tempdir value for successive lookups. -var cachedTempDir; - -//@ -//@ ### tempdir() -//@ -//@ Examples: -//@ -//@ ```javascript -//@ var tmp = tempdir(); // "/tmp" for most *nix platforms -//@ ``` -//@ -//@ Searches and returns string containing a writeable, platform-dependent temporary directory. -//@ Follows Python's [tempfile algorithm](http://docs.python.org/library/tempfile.html#tempfile.tempdir). -function _tempDir() { - if (cachedTempDir) return cachedTempDir; - - cachedTempDir = writeableDir(os.tmpdir()) || - writeableDir(process.env.TMPDIR) || - writeableDir(process.env.TEMP) || - writeableDir(process.env.TMP) || - writeableDir(process.env.Wimp$ScrapDir) || // RiscOS - writeableDir('C:\\TEMP') || // Windows - writeableDir('C:\\TMP') || // Windows - writeableDir('\\TEMP') || // Windows - writeableDir('\\TMP') || // Windows - writeableDir('/tmp') || - writeableDir('/var/tmp') || - writeableDir('/usr/tmp') || - writeableDir('.'); // last resort - - return cachedTempDir; +/** + * Update the output remapping the source map. + */ +function updateOutput(outputText, fileName, sourceMap, getEmitExtension) { + const base64Map = Buffer.from(updateSourceMap(sourceMap, fileName), 'utf8').toString('base64'); + const sourceMapContent = `//# sourceMappingURL=data:application/json;charset=utf-8;base64,${base64Map}`; + // Expected form: `//# sourceMappingURL=foo bar.js.map` or `//# sourceMappingURL=foo%20bar.js.map` for input file "foo bar.tsx" + // Percent-encoding behavior added in TS 4.1.1: https://github.com/microsoft/TypeScript/issues/40951 + const prefix = '//# sourceMappingURL='; + const prefixLength = prefix.length; + const baseName = /*foo.tsx*/ (0, path_1.basename)(fileName); + const extName = /*.tsx*/ (0, path_1.extname)(fileName); + const extension = /*.js*/ getEmitExtension(fileName); + const sourcemapFilename = baseName.slice(0, -extName.length) + extension + '.map'; + const sourceMapLengthWithoutPercentEncoding = prefixLength + sourcemapFilename.length; + /* + * Only rewrite if existing directive exists at the location we expect, to support: + * a) compilers that do not append a sourcemap directive + * b) situations where we did the math wrong + * Not ideal, but appending our sourcemap *after* a pre-existing sourcemap still overrides, so the end-user is happy. + */ + if (outputText.substr(-sourceMapLengthWithoutPercentEncoding, prefixLength) === + prefix) { + return (outputText.slice(0, -sourceMapLengthWithoutPercentEncoding) + + sourceMapContent); + } + // If anyone asks why we're not using URL, the URL equivalent is: `u = new URL('http://d'); u.pathname = "/" + sourcemapFilename; return u.pathname.slice(1); + const sourceMapLengthWithPercentEncoding = prefixLength + encodeURI(sourcemapFilename).length; + if (outputText.substr(-sourceMapLengthWithPercentEncoding, prefixLength) === + prefix) { + return (outputText.slice(0, -sourceMapLengthWithPercentEncoding) + + sourceMapContent); + } + return `${outputText}\n${sourceMapContent}`; } - -// Indicates if the tempdir value is currently cached. This is exposed for tests -// only. The return value should only be tested for truthiness. -function isCached() { - return cachedTempDir; +/** + * Update the source map contents for improved output. + */ +function updateSourceMap(sourceMapText, fileName) { + const sourceMap = JSON.parse(sourceMapText); + sourceMap.file = fileName; + sourceMap.sources = [fileName]; + delete sourceMap.sourceRoot; + return JSON.stringify(sourceMap); } - -// Clears the cached tempDir value, if one is cached. This is exposed for tests -// only. -function clearCache() { - cachedTempDir = undefined; +/** + * Filter diagnostics. + */ +function filterDiagnostics(diagnostics, filters) { + return diagnostics.filter((d) => filters.every((f) => { + var _a; + return (!f.appliesToAllFiles && + f.filenamesAbsolute.indexOf((_a = d.file) === null || _a === void 0 ? void 0 : _a.fileName) === -1) || + f.diagnosticsIgnored.indexOf(d.code) === -1; + })); } - -module.exports.tempDir = _tempDir; -module.exports.isCached = isCached; -module.exports.clearCache = clearCache; - +/** + * Get token at file position. + * + * Reference: https://github.com/microsoft/TypeScript/blob/fcd9334f57d85b73dd66ad2d21c02e84822f4841/src/services/utilities.ts#L705-L731 + */ +function getTokenAtPosition(ts, sourceFile, position) { + let current = sourceFile; + outer: while (true) { + for (const child of current.getChildren(sourceFile)) { + const start = child.getFullStart(); + if (start > position) + break; + const end = child.getEnd(); + if (position <= end) { + current = child; + continue outer; + } + } + return current; + } +} +/** + * Create an implementation of node's ESM loader hooks. + * + * This may be useful if you + * want to wrap or compose the loader hooks to add additional functionality or + * combine with another loader. + * + * Node changed the hooks API, so there are two possible APIs. This function + * detects your node version and returns the appropriate API. + * + * @category ESM Loader + */ +const createEsmHooks = (tsNodeService) => (__nccwpck_require__(36057)/* .createEsmHooks */ .lT)(tsNodeService); +exports.createEsmHooks = createEsmHooks; +//# sourceMappingURL=index.js.map /***/ }), -/***/ 39063: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { - -var common = __nccwpck_require__(17673); -var fs = __nccwpck_require__(57147); - -common.register('test', _test, { - cmdOptions: { - 'b': 'block', - 'c': 'character', - 'd': 'directory', - 'e': 'exists', - 'f': 'file', - 'L': 'link', - 'p': 'pipe', - 'S': 'socket', - }, - wrapOutput: false, - allowGlobbing: false, -}); - +/***/ 74025: +/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { -//@ -//@ ### test(expression) -//@ -//@ Available expression primaries: -//@ -//@ + `'-b', 'path'`: true if path is a block device -//@ + `'-c', 'path'`: true if path is a character device -//@ + `'-d', 'path'`: true if path is a directory -//@ + `'-e', 'path'`: true if path exists -//@ + `'-f', 'path'`: true if path is a regular file -//@ + `'-L', 'path'`: true if path is a symbolic link -//@ + `'-p', 'path'`: true if path is a pipe (FIFO) -//@ + `'-S', 'path'`: true if path is a socket -//@ -//@ Examples: -//@ -//@ ```javascript -//@ if (test('-d', path)) { /* do something with dir */ }; -//@ if (!test('-f', path)) continue; // skip if it's a regular file -//@ ``` -//@ -//@ Evaluates `expression` using the available primaries and returns corresponding value. -function _test(options, path) { - if (!path) common.error('no path given'); +"use strict"; - var canInterpret = false; - Object.keys(options).forEach(function (key) { - if (options[key] === true) { - canInterpret = true; +Object.defineProperty(exports, "__esModule", ({ value: true })); +exports.createModuleTypeClassifier = void 0; +const ts_internals_1 = __nccwpck_require__(80301); +const util_1 = __nccwpck_require__(26239); +/** + * @internal + * May receive non-normalized options -- basePath and patterns -- and will normalize them + * internally. + * However, calls to `classifyModule` must pass pre-normalized paths! + */ +function createModuleTypeClassifier(options) { + const { patterns, basePath: _basePath } = options; + const basePath = _basePath !== undefined + ? (0, util_1.normalizeSlashes)(_basePath).replace(/\/$/, '') + : undefined; + const patternTypePairs = Object.entries(patterns !== null && patterns !== void 0 ? patterns : []).map(([_pattern, type]) => { + const pattern = (0, util_1.normalizeSlashes)(_pattern); + return { pattern: parsePattern(basePath, pattern), type }; + }); + const classifications = { + package: { + moduleType: 'auto', + }, + cjs: { + moduleType: 'cjs', + }, + esm: { + moduleType: 'esm', + }, + }; + const auto = classifications.package; + // Passed path must be normalized! + function classifyModuleNonCached(path) { + const matched = matchPatterns(patternTypePairs, (_) => _.pattern, path); + if (matched) + return classifications[matched.type]; + return auto; } - }); - - if (!canInterpret) common.error('could not interpret expression'); - - if (options.link) { - try { - return common.statNoFollowLinks(path).isSymbolicLink(); - } catch (e) { - return false; + const classifyModule = (0, util_1.cachedLookup)(classifyModuleNonCached); + function classifyModuleAuto(path) { + return auto; } - } - - if (!fs.existsSync(path)) return false; - - if (options.exists) return true; - - var stats = common.statFollowLinks(path); - - if (options.block) return stats.isBlockDevice(); - - if (options.character) return stats.isCharacterDevice(); - - if (options.directory) return stats.isDirectory(); - - if (options.file) return stats.isFile(); - - /* istanbul ignore next */ - if (options.pipe) return stats.isFIFO(); - - /* istanbul ignore next */ - if (options.socket) return stats.isSocket(); - - /* istanbul ignore next */ - return false; // fallback -} // test -module.exports = _test; - - -/***/ }), - -/***/ 94897: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { - -var common = __nccwpck_require__(17673); -var fs = __nccwpck_require__(57147); -var path = __nccwpck_require__(71017); - -common.register('to', _to, { - pipeOnly: true, - wrapOutput: false, -}); - -//@ -//@ ### ShellString.prototype.to(file) -//@ -//@ Examples: -//@ -//@ ```javascript -//@ cat('input.txt').to('output.txt'); -//@ ``` -//@ -//@ Analogous to the redirection operator `>` in Unix, but works with -//@ `ShellStrings` (such as those returned by `cat`, `grep`, etc.). _Like Unix -//@ redirections, `to()` will overwrite any existing file!_ -function _to(options, file) { - if (!file) common.error('wrong arguments'); - - if (!fs.existsSync(path.dirname(file))) { - common.error('no such file or directory: ' + path.dirname(file)); - } - - try { - fs.writeFileSync(file, this.stdout || this.toString(), 'utf8'); - return this; - } catch (e) { - /* istanbul ignore next */ - common.error('could not write to file (code ' + e.code + '): ' + file, { continue: true }); - } + return { + classifyModuleByModuleTypeOverrides: patternTypePairs.length + ? classifyModule + : classifyModuleAuto, + }; } -module.exports = _to; - +exports.createModuleTypeClassifier = createModuleTypeClassifier; +function parsePattern(basePath, patternString) { + const pattern = (0, ts_internals_1.getPatternFromSpec)(patternString, basePath); + return pattern !== undefined ? new RegExp(pattern) : /(?:)/; +} +function matchPatterns(objects, getPattern, candidate) { + for (let i = objects.length - 1; i >= 0; i--) { + const object = objects[i]; + const pattern = getPattern(object); + if (pattern === null || pattern === void 0 ? void 0 : pattern.test(candidate)) { + return object; + } + } +} +//# sourceMappingURL=module-type-classifier.js.map /***/ }), -/***/ 60228: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { - -var common = __nccwpck_require__(17673); -var fs = __nccwpck_require__(57147); -var path = __nccwpck_require__(71017); - -common.register('toEnd', _toEnd, { - pipeOnly: true, - wrapOutput: false, -}); - -//@ -//@ ### ShellString.prototype.toEnd(file) -//@ -//@ Examples: -//@ -//@ ```javascript -//@ cat('input.txt').toEnd('output.txt'); -//@ ``` -//@ -//@ Analogous to the redirect-and-append operator `>>` in Unix, but works with -//@ `ShellStrings` (such as those returned by `cat`, `grep`, etc.). -function _toEnd(options, file) { - if (!file) common.error('wrong arguments'); +/***/ 76652: +/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { - if (!fs.existsSync(path.dirname(file))) { - common.error('no such file or directory: ' + path.dirname(file)); - } +"use strict"; - try { - fs.appendFileSync(file, this.stdout || this.toString(), 'utf8'); - return this; - } catch (e) { - /* istanbul ignore next */ - common.error('could not append to file (code ' + e.code + '): ' + file, { continue: true }); - } +Object.defineProperty(exports, "__esModule", ({ value: true })); +exports.classifyModule = void 0; +const node_internal_modules_cjs_loader_1 = __nccwpck_require__(88232); +/** + * Determine how to emit a module based on tsconfig "module" and package.json "type" + * + * Supports module=nodenext/node16 with transpileOnly, where we cannot ask the + * TS typechecker to tell us if a file is CJS or ESM. + * + * Return values indicate: + * - cjs + * - esm + * - nodecjs == node-flavored cjs where dynamic imports are *not* transformed into `require()` + * - undefined == emit according to tsconfig `module` config, whatever that is + * @internal + */ +function classifyModule(nativeFilename, isNodeModuleType) { + // [MUST_UPDATE_FOR_NEW_FILE_EXTENSIONS] + const lastDotIndex = nativeFilename.lastIndexOf('.'); + const ext = lastDotIndex >= 0 ? nativeFilename.slice(lastDotIndex) : ''; + switch (ext) { + case '.cjs': + case '.cts': + return isNodeModuleType ? 'nodecjs' : 'cjs'; + case '.mjs': + case '.mts': + return isNodeModuleType ? 'nodeesm' : 'esm'; + } + if (isNodeModuleType) { + const packageScope = (0, node_internal_modules_cjs_loader_1.readPackageScope)(nativeFilename); + if (packageScope && packageScope.data.type === 'module') + return 'nodeesm'; + return 'nodecjs'; + } + return undefined; } -module.exports = _toEnd; - +exports.classifyModule = classifyModule; +//# sourceMappingURL=node-module-type-classifier.js.map /***/ }), -/***/ 28440: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { - -var common = __nccwpck_require__(17673); -var fs = __nccwpck_require__(57147); +/***/ 8371: +/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { -common.register('touch', _touch, { - cmdOptions: { - 'a': 'atime_only', - 'c': 'no_create', - 'd': 'date', - 'm': 'mtime_only', - 'r': 'reference', - }, -}); +"use strict"; -//@ -//@ ### touch([options,] file [, file ...]) -//@ ### touch([options,] file_array) -//@ -//@ Available options: -//@ -//@ + `-a`: Change only the access time -//@ + `-c`: Do not create any files -//@ + `-m`: Change only the modification time -//@ + `-d DATE`: Parse `DATE` and use it instead of current time -//@ + `-r FILE`: Use `FILE`'s times instead of current time -//@ -//@ Examples: -//@ -//@ ```javascript -//@ touch('source.js'); -//@ touch('-c', '/path/to/some/dir/source.js'); -//@ touch({ '-r': FILE }, '/path/to/some/dir/source.js'); -//@ ``` -//@ -//@ Update the access and modification times of each `FILE` to the current time. -//@ A `FILE` argument that does not exist is created empty, unless `-c` is supplied. -//@ This is a partial implementation of [`touch(1)`](http://linux.die.net/man/1/touch). -function _touch(opts, files) { - if (!files) { - common.error('no files given'); - } else if (typeof files === 'string') { - files = [].slice.call(arguments, 1); - } else { - common.error('file arg should be a string file path or an Array of string file paths'); - } - - files.forEach(function (f) { - touchFile(opts, f); - }); - return ''; +Object.defineProperty(exports, "__esModule", ({ value: true })); +exports.setupContext = exports.createEvalAwarePartialHost = exports.EvalState = exports.createRepl = exports.REPL_NAME = exports.REPL_FILENAME = exports.STDIN_NAME = exports.STDIN_FILENAME = exports.EVAL_NAME = exports.EVAL_FILENAME = void 0; +const os_1 = __nccwpck_require__(22037); +const path_1 = __nccwpck_require__(71017); +const repl_1 = __nccwpck_require__(38102); +const vm_1 = __nccwpck_require__(26144); +const index_1 = __nccwpck_require__(94828); +const fs_1 = __nccwpck_require__(57147); +const console_1 = __nccwpck_require__(96206); +const assert = __nccwpck_require__(39491); +const module_1 = __nccwpck_require__(98188); +// Lazy-loaded. +let _processTopLevelAwait; +function getProcessTopLevelAwait() { + if (_processTopLevelAwait === undefined) { + ({ + processTopLevelAwait: _processTopLevelAwait, + } = __nccwpck_require__(18088)); + } + return _processTopLevelAwait; } - -function touchFile(opts, file) { - var stat = tryStatFile(file); - - if (stat && stat.isDirectory()) { - // don't error just exit - return; - } - - // if the file doesn't already exist and the user has specified --no-create then - // this script is finished - if (!stat && opts.no_create) { - return; - } - - // open the file and then close it. this will create it if it doesn't exist but will - // not truncate the file - fs.closeSync(fs.openSync(file, 'a')); - - // - // Set timestamps - // - - // setup some defaults - var now = new Date(); - var mtime = opts.date || now; - var atime = opts.date || now; - - // use reference file - if (opts.reference) { - var refStat = tryStatFile(opts.reference); - if (!refStat) { - common.error('failed to get attributess of ' + opts.reference); +let diff; +function getDiffLines() { + if (diff === undefined) { + diff = __nccwpck_require__(95214); } - mtime = refStat.mtime; - atime = refStat.atime; - } else if (opts.date) { - mtime = opts.date; - atime = opts.date; - } - - if (opts.atime_only && opts.mtime_only) { - // keep the new values of mtime and atime like GNU - } else if (opts.atime_only) { - mtime = stat.mtime; - } else if (opts.mtime_only) { - atime = stat.atime; - } - - fs.utimesSync(file, atime, mtime); + return diff.diffLines; } - -module.exports = _touch; - -function tryStatFile(filePath) { - try { - return common.statFollowLinks(filePath); - } catch (e) { - return null; - } +/** @internal */ +exports.EVAL_FILENAME = `[eval].ts`; +/** @internal */ +exports.EVAL_NAME = `[eval]`; +/** @internal */ +exports.STDIN_FILENAME = `[stdin].ts`; +/** @internal */ +exports.STDIN_NAME = `[stdin]`; +/** @internal */ +exports.REPL_FILENAME = '.ts'; +/** @internal */ +exports.REPL_NAME = ''; +/** + * Create a ts-node REPL instance. + * + * Pay close attention to the example below. Today, the API requires a few lines + * of boilerplate to correctly bind the `ReplService` to the ts-node `Service` and + * vice-versa. + * + * Usage example: + * + * const repl = tsNode.createRepl(); + * const service = tsNode.create({...repl.evalAwarePartialHost}); + * repl.setService(service); + * repl.start(); + * + * @category REPL + */ +function createRepl(options = {}) { + var _a, _b, _c, _d, _e; + const { ignoreDiagnosticsThatAreAnnoyingInInteractiveRepl = true } = options; + let service = options.service; + let nodeReplServer; + // If `useGlobal` is not true, then REPL creates a context when started. + // This stores a reference to it or to `global`, whichever is used, after REPL has started. + let context; + const state = (_a = options.state) !== null && _a !== void 0 ? _a : new EvalState((0, path_1.join)(process.cwd(), exports.REPL_FILENAME)); + const evalAwarePartialHost = createEvalAwarePartialHost(state, options.composeWithEvalAwarePartialHost); + const stdin = (_b = options.stdin) !== null && _b !== void 0 ? _b : process.stdin; + const stdout = (_c = options.stdout) !== null && _c !== void 0 ? _c : process.stdout; + const stderr = (_d = options.stderr) !== null && _d !== void 0 ? _d : process.stderr; + const _console = stdout === process.stdout && stderr === process.stderr + ? console + : new console_1.Console(stdout, stderr); + const replService = { + state: (_e = options.state) !== null && _e !== void 0 ? _e : new EvalState((0, path_1.join)(process.cwd(), exports.EVAL_FILENAME)), + setService, + evalCode, + evalCodeInternal, + nodeEval, + evalAwarePartialHost, + start, + startInternal, + stdin, + stdout, + stderr, + console: _console, + }; + return replService; + function setService(_service) { + service = _service; + if (ignoreDiagnosticsThatAreAnnoyingInInteractiveRepl) { + service.addDiagnosticFilter({ + appliesToAllFiles: false, + filenamesAbsolute: [state.path], + diagnosticsIgnored: [ + 2393, + 6133, + 7027, + ...(service.shouldReplAwait ? topLevelAwaitDiagnosticCodes : []), + ], + }); + } + } + function evalCode(code) { + const result = appendCompileAndEvalInput({ + service: service, + state, + input: code, + context, + overrideIsCompletion: false, + }); + assert(result.containsTopLevelAwait === false); + return result.value; + } + function evalCodeInternal(options) { + const { code, enableTopLevelAwait, context } = options; + return appendCompileAndEvalInput({ + service: service, + state, + input: code, + enableTopLevelAwait, + context, + }); + } + function nodeEval(code, context, _filename, callback) { + // TODO: Figure out how to handle completion here. + if (code === '.scope') { + callback(null); + return; + } + try { + const evalResult = evalCodeInternal({ + code, + enableTopLevelAwait: true, + context, + }); + if (evalResult.containsTopLevelAwait) { + (async () => { + try { + callback(null, await evalResult.valuePromise); + } + catch (promiseError) { + handleError(promiseError); + } + })(); + } + else { + callback(null, evalResult.value); + } + } + catch (error) { + handleError(error); + } + // Log TSErrors, check if they're recoverable, log helpful hints for certain + // well-known errors, and invoke `callback()` + // TODO should evalCode API get the same error-handling benefits? + function handleError(error) { + var _a, _b; + // Don't show TLA hint if the user explicitly disabled repl top level await + const canLogTopLevelAwaitHint = service.options.experimentalReplAwait !== false && + !service.shouldReplAwait; + if (error instanceof index_1.TSError) { + // Support recoverable compilations using >= node 6. + if (repl_1.Recoverable && isRecoverable(error)) { + callback(new repl_1.Recoverable(error)); + return; + } + else { + _console.error(error); + if (canLogTopLevelAwaitHint && + error.diagnosticCodes.some((dC) => topLevelAwaitDiagnosticCodes.includes(dC))) { + _console.error(getTopLevelAwaitHint()); + } + callback(null); + } + } + else { + let _error = error; + if (canLogTopLevelAwaitHint && + _error instanceof SyntaxError && + ((_a = _error.message) === null || _a === void 0 ? void 0 : _a.includes('await is only valid'))) { + try { + // Only way I know to make our hint appear after the error + _error.message += `\n\n${getTopLevelAwaitHint()}`; + _error.stack = (_b = _error.stack) === null || _b === void 0 ? void 0 : _b.replace(/(SyntaxError:.*)/, (_, $1) => `${$1}\n\n${getTopLevelAwaitHint()}`); + } + catch { } + } + callback(_error); + } + } + function getTopLevelAwaitHint() { + return `Hint: REPL top-level await requires TypeScript version 3.8 or higher and target ES2018 or higher. You are using TypeScript ${service.ts.version} and target ${service.ts.ScriptTarget[service.config.options.target]}.`; + } + } + // Note: `code` argument is deprecated + function start(code) { + startInternal({ code }); + } + // Note: `code` argument is deprecated + function startInternal(options) { + const { code, forceToBeModule = true, ...optionsOverride } = options !== null && options !== void 0 ? options : {}; + // TODO assert that `service` is set; remove all `service!` non-null assertions + // Eval incoming code before the REPL starts. + // Note: deprecated + if (code) { + try { + evalCode(`${code}\n`); + } + catch (err) { + _console.error(err); + // Note: should not be killing the process here, but this codepath is deprecated anyway + process.exit(1); + } + } + // In case the typescript compiler hasn't compiled anything yet, + // make it run though compilation at least one time before + // the REPL starts for a snappier user experience on startup. + service === null || service === void 0 ? void 0 : service.compile('', state.path); + const repl = (0, repl_1.start)({ + prompt: '> ', + input: replService.stdin, + output: replService.stdout, + // Mimicking node's REPL implementation: https://github.com/nodejs/node/blob/168b22ba073ee1cbf8d0bcb4ded7ff3099335d04/lib/internal/repl.js#L28-L30 + terminal: stdout.isTTY && + !parseInt(index_1.env.NODE_NO_READLINE, 10), + eval: nodeEval, + useGlobal: true, + ...optionsOverride, + }); + nodeReplServer = repl; + context = repl.context; + // Bookmark the point where we should reset the REPL state. + const resetEval = appendToEvalState(state, ''); + function reset() { + resetEval(); + // Hard fix for TypeScript forcing `Object.defineProperty(exports, ...)`. + runInContext('exports = module.exports', state.path, context); + if (forceToBeModule) { + state.input += 'export {};void 0;\n'; + } + // Declare node builtins. + // Skip the same builtins as `addBuiltinLibsToObject`: + // those starting with _ + // those containing / + // those that already exist as globals + // Intentionally suppress type errors in case @types/node does not declare any of them, and because + // `declare import` is technically invalid syntax. + // Avoid this when in transpileOnly, because third-party transpilers may not handle `declare import`. + if (!(service === null || service === void 0 ? void 0 : service.transpileOnly)) { + state.input += `// @ts-ignore\n${module_1.builtinModules + .filter((name) => !name.startsWith('_') && + !name.includes('/') && + !['console', 'module', 'process'].includes(name)) + .map((name) => `declare import ${name} = require('${name}')`) + .join(';')}\n`; + } + } + reset(); + repl.on('reset', reset); + repl.defineCommand('type', { + help: 'Check the type of a TypeScript identifier', + action: function (identifier) { + if (!identifier) { + repl.displayPrompt(); + return; + } + const undo = appendToEvalState(state, identifier); + const { name, comment } = service.getTypeInfo(state.input, state.path, state.input.length); + undo(); + if (name) + repl.outputStream.write(`${name}\n`); + if (comment) + repl.outputStream.write(`${comment}\n`); + repl.displayPrompt(); + }, + }); + // Set up REPL history when available natively via node.js >= 11. + if (repl.setupHistory) { + const historyPath = index_1.env.TS_NODE_HISTORY || (0, path_1.join)((0, os_1.homedir)(), '.ts_node_repl_history'); + repl.setupHistory(historyPath, (err) => { + if (!err) + return; + _console.error(err); + process.exit(1); + }); + } + return repl; + } } - - -/***/ }), - -/***/ 55499: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { - -var common = __nccwpck_require__(17673); -var fs = __nccwpck_require__(57147); - -// add c spaces to the left of str -function lpad(c, str) { - var res = '' + str; - if (res.length < c) { - res = Array((c - res.length) + 1).join(' ') + res; - } - return res; +exports.createRepl = createRepl; +/** + * Eval state management. Stores virtual `[eval].ts` file + */ +class EvalState { + constructor(path) { + this.path = path; + /** @internal */ + this.input = ''; + /** @internal */ + this.output = ''; + /** @internal */ + this.version = 0; + /** @internal */ + this.lines = 0; + } } - -common.register('uniq', _uniq, { - canReceivePipe: true, - cmdOptions: { - 'i': 'ignoreCase', - 'c': 'count', - 'd': 'duplicates', - }, -}); - -//@ -//@ ### uniq([options,] [input, [output]]) -//@ -//@ Available options: -//@ -//@ + `-i`: Ignore case while comparing -//@ + `-c`: Prefix lines by the number of occurrences -//@ + `-d`: Only print duplicate lines, one for each group of identical lines -//@ -//@ Examples: -//@ -//@ ```javascript -//@ uniq('foo.txt'); -//@ uniq('-i', 'foo.txt'); -//@ uniq('-cd', 'foo.txt', 'bar.txt'); -//@ ``` -//@ -//@ Filter adjacent matching lines from `input`. -function _uniq(options, input, output) { - // Check if this is coming from a pipe - var pipe = common.readFromPipe(); - - if (!pipe) { - if (!input) common.error('no input given'); - - if (!fs.existsSync(input)) { - common.error(input + ': No such file or directory'); - } else if (common.statFollowLinks(input).isDirectory()) { - common.error("error reading '" + input + "'"); +exports.EvalState = EvalState; +function createEvalAwarePartialHost(state, composeWith) { + function readFile(path) { + if (path === state.path) + return state.input; + if (composeWith === null || composeWith === void 0 ? void 0 : composeWith.readFile) + return composeWith.readFile(path); + try { + return (0, fs_1.readFileSync)(path, 'utf8'); + } + catch (err) { + /* Ignore. */ + } } - } - if (output && fs.existsSync(output) && common.statFollowLinks(output).isDirectory()) { - common.error(output + ': Is a directory'); - } - - var lines = (input ? fs.readFileSync(input, 'utf8') : pipe). - trimRight(). - split('\n'); - - var compare = function (a, b) { - return options.ignoreCase ? - a.toLocaleLowerCase().localeCompare(b.toLocaleLowerCase()) : - a.localeCompare(b); - }; - var uniqed = lines.reduceRight(function (res, e) { - // Perform uniq -c on the input - if (res.length === 0) { - return [{ count: 1, ln: e }]; - } else if (compare(res[0].ln, e) === 0) { - return [{ count: res[0].count + 1, ln: e }].concat(res.slice(1)); - } else { - return [{ count: 1, ln: e }].concat(res); + function fileExists(path) { + if (path === state.path) + return true; + if (composeWith === null || composeWith === void 0 ? void 0 : composeWith.fileExists) + return composeWith.fileExists(path); + try { + const stats = (0, fs_1.statSync)(path); + return stats.isFile() || stats.isFIFO(); + } + catch (err) { + return false; + } } - }, []).filter(function (obj) { - // Do we want only duplicated objects? - return options.duplicates ? obj.count > 1 : true; - }).map(function (obj) { - // Are we tracking the counts of each line? - return (options.count ? (lpad(7, obj.count) + ' ') : '') + obj.ln; - }).join('\n') + '\n'; - - if (output) { - (new common.ShellString(uniqed)).to(output); - // if uniq writes to output, nothing is passed to the next command in the pipeline (if any) - return ''; - } else { - return uniqed; - } + return { readFile, fileExists }; } - -module.exports = _uniq; - - -/***/ }), - -/***/ 5405: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { - -var common = __nccwpck_require__(17673); -var fs = __nccwpck_require__(57147); -var path = __nccwpck_require__(71017); - -common.register('which', _which, { - allowGlobbing: false, - cmdOptions: { - 'a': 'all', - }, -}); - -// XP's system default value for `PATHEXT` system variable, just in case it's not -// set on Windows. -var XP_DEFAULT_PATHEXT = '.com;.exe;.bat;.cmd;.vbs;.vbe;.js;.jse;.wsf;.wsh'; - -// For earlier versions of NodeJS that doesn't have a list of constants (< v6) -var FILE_EXECUTABLE_MODE = 1; - -function isWindowsPlatform() { - return process.platform === 'win32'; +exports.createEvalAwarePartialHost = createEvalAwarePartialHost; +const sourcemapCommentRe = /\/\/# ?sourceMappingURL=\S+[\s\r\n]*$/; +/** + * Evaluate the code snippet. + * + * Append it to virtual .ts file, compile, handle compiler errors, compute a diff of the JS, and eval any code that + * appears as "added" in the diff. + */ +function appendCompileAndEvalInput(options) { + const { service, state, wrappedErr, enableTopLevelAwait = false, context, overrideIsCompletion, } = options; + let { input } = options; + // It's confusing for `{ a: 1 }` to be interpreted as a block statement + // rather than an object literal. So, we first try to wrap it in + // parentheses, so that it will be interpreted as an expression. + // Based on https://github.com/nodejs/node/blob/c2e6822153bad023ab7ebd30a6117dcc049e475c/lib/repl.js#L413-L422 + let wrappedCmd = false; + if (!wrappedErr && /^\s*{/.test(input) && !/;\s*$/.test(input)) { + input = `(${input.trim()})\n`; + wrappedCmd = true; + } + const lines = state.lines; + const isCompletion = overrideIsCompletion !== null && overrideIsCompletion !== void 0 ? overrideIsCompletion : !/\n$/.test(input); + const undo = appendToEvalState(state, input); + let output; + // Based on https://github.com/nodejs/node/blob/92573721c7cff104ccb82b6ed3e8aa69c4b27510/lib/repl.js#L457-L461 + function adjustUseStrict(code) { + // "void 0" keeps the repl from returning "use strict" as the result + // value for statements and declarations that don't return a value. + return code.replace(/^"use strict";/, '"use strict"; void 0;'); + } + try { + output = service.compile(state.input, state.path, -lines); + } + catch (err) { + undo(); + if (wrappedCmd) { + if (err instanceof index_1.TSError && err.diagnosticCodes[0] === 2339) { + // Ensure consistent and more sane behavior between { a: 1 }['b'] and ({ a: 1 }['b']) + throw err; + } + // Unwrap and try again + return appendCompileAndEvalInput({ + ...options, + wrappedErr: err, + }); + } + if (wrappedErr) + throw wrappedErr; + throw err; + } + output = adjustUseStrict(output); + // Note: REPL does not respect sourcemaps! + // To properly do that, we'd need to prefix the code we eval -- which comes + // from `diffLines` -- with newlines so that it's at the proper line numbers. + // Then we'd need to ensure each bit of eval-ed code, if there are multiples, + // has the sourcemap appended to it. + // We might also need to integrate with our sourcemap hooks' cache; I'm not sure. + const outputWithoutSourcemapComment = output.replace(sourcemapCommentRe, ''); + const oldOutputWithoutSourcemapComment = state.output.replace(sourcemapCommentRe, ''); + // Use `diff` to check for new JavaScript to execute. + const changes = getDiffLines()(oldOutputWithoutSourcemapComment, outputWithoutSourcemapComment); + if (isCompletion) { + undo(); + } + else { + state.output = output; + // Insert a semicolon to make sure that the code doesn't interact with the next line, + // for example to prevent `2\n+ 2` from producing 4. + // This is safe since the output will not change since we can only get here with successful inputs, + // and adding a semicolon to the end of a successful input won't ever change the output. + state.input = state.input.replace(/([^\n\s])([\n\s]*)$/, (all, lastChar, whitespace) => { + if (lastChar !== ';') + return `${lastChar};${whitespace}`; + return all; + }); + } + let commands = []; + let containsTopLevelAwait = false; + // Build a list of "commands": bits of JS code in the diff that must be executed. + for (const change of changes) { + if (change.added) { + if (enableTopLevelAwait && + service.shouldReplAwait && + change.value.indexOf('await') > -1) { + const processTopLevelAwait = getProcessTopLevelAwait(); + // Newline prevents comments to mess with wrapper + const wrappedResult = processTopLevelAwait(change.value + '\n'); + if (wrappedResult !== null) { + containsTopLevelAwait = true; + commands.push({ + mustAwait: true, + execCommand: () => runInContext(wrappedResult, state.path, context), + }); + continue; + } + } + commands.push({ + execCommand: () => runInContext(change.value, state.path, context), + }); + } + } + // Execute all commands asynchronously if necessary, returning the result or a + // promise of the result. + if (containsTopLevelAwait) { + return { + containsTopLevelAwait, + valuePromise: (async () => { + let value; + for (const command of commands) { + const r = command.execCommand(); + value = command.mustAwait ? await r : r; + } + return value; + })(), + }; + } + else { + return { + containsTopLevelAwait: false, + value: commands.reduce((_, c) => c.execCommand(), undefined), + }; + } } - -// Cross-platform method for splitting environment `PATH` variables -function splitPath(p) { - return p ? p.split(path.delimiter) : []; +/** + * Low-level execution of JS code in context + */ +function runInContext(code, filename, context) { + const script = new vm_1.Script(code, { filename }); + if (context === undefined || context === global) { + return script.runInThisContext(); + } + else { + return script.runInContext(context); + } } - -// Tests are running all cases for this func but it stays uncovered by codecov due to unknown reason -/* istanbul ignore next */ -function isExecutable(pathName) { - try { - // TODO(node-support): replace with fs.constants.X_OK once remove support for node < v6 - fs.accessSync(pathName, FILE_EXECUTABLE_MODE); - } catch (err) { - return false; - } - return true; +/** + * Append to the eval instance and return an undo function. + */ +function appendToEvalState(state, input) { + const undoInput = state.input; + const undoVersion = state.version; + const undoOutput = state.output; + const undoLines = state.lines; + state.input += input; + state.lines += lineCount(input); + state.version++; + return function () { + state.input = undoInput; + state.output = undoOutput; + state.version = undoVersion; + state.lines = undoLines; + }; } - -function checkPath(pathName) { - return fs.existsSync(pathName) && !common.statFollowLinks(pathName).isDirectory() - && (isWindowsPlatform() || isExecutable(pathName)); +/** + * Count the number of lines. + */ +function lineCount(value) { + let count = 0; + for (const char of value) { + if (char === '\n') { + count++; + } + } + return count; } - -//@ -//@ ### which(command) -//@ -//@ Examples: -//@ -//@ ```javascript -//@ var nodeExec = which('node'); -//@ ``` -//@ -//@ Searches for `command` in the system's `PATH`. On Windows, this uses the -//@ `PATHEXT` variable to append the extension if it's not already executable. -//@ Returns string containing the absolute path to `command`. -function _which(options, cmd) { - if (!cmd) common.error('must specify command'); - - var isWindows = isWindowsPlatform(); - var pathArray = splitPath(process.env.PATH); - - var queryMatches = []; - - // No relative/absolute paths provided? - if (cmd.indexOf('/') === -1) { - // Assume that there are no extensions to append to queries (this is the - // case for unix) - var pathExtArray = ['']; - if (isWindows) { - // In case the PATHEXT variable is somehow not set (e.g. - // child_process.spawn with an empty environment), use the XP default. - var pathExtEnv = process.env.PATHEXT || XP_DEFAULT_PATHEXT; - pathExtArray = splitPath(pathExtEnv.toUpperCase()); +/** + * TS diagnostic codes which are recoverable, meaning that the user likely entered an incomplete line of code + * and should be prompted for the next. For example, starting a multi-line for() loop and not finishing it. + * null value means code is always recoverable. `Set` means code is only recoverable when occurring alongside at least one + * of the other codes. + */ +const RECOVERY_CODES = new Map([ + [1003, null], + [1005, null], + [1109, null], + [1126, null], + [ + 1136, + new Set([1005]), // happens when typing out an object literal or block scope across multiple lines: '{ foo: 123,' + ], + [1160, null], + [1161, null], + [2355, null], + [2391, null], + [ + 7010, + new Set([1005]), // happens when fn signature spread across multiple lines: 'function a(\nb: any\n) {' + ], +]); +/** + * Diagnostic codes raised when using top-level await. + * These are suppressed when top-level await is enabled. + * When it is *not* enabled, these trigger a helpful hint about enabling top-level await. + */ +const topLevelAwaitDiagnosticCodes = [ + 1375, + 1378, + 1431, + 1432, // Top-level 'for await' loops are only allowed when the 'module' option is set to 'esnext' or 'system', and the 'target' option is set to 'es2017' or higher. +]; +/** + * Check if a function can recover gracefully. + */ +function isRecoverable(error) { + return error.diagnosticCodes.every((code) => { + const deps = RECOVERY_CODES.get(code); + return (deps === null || + (deps && error.diagnosticCodes.some((code) => deps.has(code)))); + }); +} +/** + * @internal + * Set properties on `context` before eval-ing [stdin] or [eval] input. + */ +function setupContext(context, module, filenameAndDirname) { + if (filenameAndDirname) { + context.__dirname = '.'; + context.__filename = `[${filenameAndDirname}]`; } + context.module = module; + context.exports = module.exports; + context.require = __nccwpck_require__(3833).bind(module); +} +exports.setupContext = setupContext; +//# sourceMappingURL=repl.js.map - // Search for command in PATH - for (var k = 0; k < pathArray.length; k++) { - // already found it - if (queryMatches.length > 0 && !options.all) break; +/***/ }), - var attempt = path.resolve(pathArray[k], cmd); +/***/ 83638: +/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { - if (isWindows) { - attempt = attempt.toUpperCase(); - } +"use strict"; - var match = attempt.match(/\.[^<>:"/\|?*.]+$/); - if (match && pathExtArray.indexOf(match[0]) >= 0) { // this is Windows-only - // The user typed a query with the file extension, like - // `which('node.exe')` - if (checkPath(attempt)) { - queryMatches.push(attempt); - break; +Object.defineProperty(exports, "__esModule", ({ value: true })); +exports.createResolverFunctions = void 0; +const path_1 = __nccwpck_require__(71017); +/** + * @internal + * In a factory because these are shared across both CompilerHost and LanguageService codepaths + */ +function createResolverFunctions(kwargs) { + const { host, ts, config, cwd, getCanonicalFileName, projectLocalResolveHelper, options, extensions, } = kwargs; + const moduleResolutionCache = ts.createModuleResolutionCache(cwd, getCanonicalFileName, config.options); + const knownInternalFilenames = new Set(); + /** "Buckets" (module directories) whose contents should be marked "internal" */ + const internalBuckets = new Set(); + // Get bucket for a source filename. Bucket is the containing `./node_modules/*/` directory + // For '/project/node_modules/foo/node_modules/bar/lib/index.js' bucket is '/project/node_modules/foo/node_modules/bar/' + // For '/project/node_modules/foo/node_modules/@scope/bar/lib/index.js' bucket is '/project/node_modules/foo/node_modules/@scope/bar/' + const moduleBucketRe = /.*\/node_modules\/(?:@[^\/]+\/)?[^\/]+\//; + function getModuleBucket(filename) { + const find = moduleBucketRe.exec(filename); + if (find) + return find[0]; + return ''; + } + // Mark that this file and all siblings in its bucket should be "internal" + function markBucketOfFilenameInternal(filename) { + internalBuckets.add(getModuleBucket(filename)); + } + function isFileInInternalBucket(filename) { + return internalBuckets.has(getModuleBucket(filename)); + } + function isFileKnownToBeInternal(filename) { + return knownInternalFilenames.has(filename); + } + /** + * If we need to emit JS for a file, force TS to consider it non-external + */ + const fixupResolvedModule = (resolvedModule) => { + const { resolvedFileName } = resolvedModule; + if (resolvedFileName === undefined) + return; + // [MUST_UPDATE_FOR_NEW_FILE_EXTENSIONS] + // .ts,.mts,.cts is always switched to internal + // .js is switched on-demand + if (resolvedModule.isExternalLibraryImport && + ((resolvedFileName.endsWith('.ts') && + !resolvedFileName.endsWith('.d.ts')) || + (resolvedFileName.endsWith('.cts') && + !resolvedFileName.endsWith('.d.cts')) || + (resolvedFileName.endsWith('.mts') && + !resolvedFileName.endsWith('.d.mts')) || + isFileKnownToBeInternal(resolvedFileName) || + isFileInInternalBucket(resolvedFileName))) { + resolvedModule.isExternalLibraryImport = false; } - } else { // All-platforms - // Cycle through the PATHEXT array, and check each extension - // Note: the array is always [''] on Unix - for (var i = 0; i < pathExtArray.length; i++) { - var ext = pathExtArray[i]; - var newAttempt = attempt + ext; - if (checkPath(newAttempt)) { - queryMatches.push(newAttempt); - break; - } + if (!resolvedModule.isExternalLibraryImport) { + knownInternalFilenames.add(resolvedFileName); } - } - } - } else if (checkPath(cmd)) { // a valid absolute or relative path - queryMatches.push(path.resolve(cmd)); - } - - if (queryMatches.length > 0) { - return options.all ? queryMatches : queryMatches[0]; - } - return options.all ? [] : null; + }; + /* + * NOTE: + * Older ts versions do not pass `redirectedReference` nor `options`. + * We must pass `redirectedReference` to newer ts versions, but cannot rely on `options`, hence the weird argument name + */ + const resolveModuleNames = (moduleNames, containingFile, reusedNames, redirectedReference, optionsOnlyWithNewerTsVersions, containingSourceFile) => { + return moduleNames.map((moduleName, i) => { + var _a, _b; + const mode = containingSourceFile + ? (_b = (_a = ts).getModeForResolutionAtIndex) === null || _b === void 0 ? void 0 : _b.call(_a, containingSourceFile, i) + : undefined; + let { resolvedModule } = ts.resolveModuleName(moduleName, containingFile, config.options, host, moduleResolutionCache, redirectedReference, mode); + if (!resolvedModule && options.experimentalTsImportSpecifiers) { + const lastDotIndex = moduleName.lastIndexOf('.'); + const ext = lastDotIndex >= 0 ? moduleName.slice(lastDotIndex) : ''; + if (ext) { + const replacements = extensions.tsResolverEquivalents.get(ext); + for (const replacementExt of replacements !== null && replacements !== void 0 ? replacements : []) { + ({ resolvedModule } = ts.resolveModuleName(moduleName.slice(0, -ext.length) + replacementExt, containingFile, config.options, host, moduleResolutionCache, redirectedReference, mode)); + if (resolvedModule) + break; + } + } + } + if (resolvedModule) { + fixupResolvedModule(resolvedModule); + } + return resolvedModule; + }); + }; + // language service never calls this, but TS docs recommend that we implement it + const getResolvedModuleWithFailedLookupLocationsFromCache = (moduleName, containingFile, resolutionMode) => { + const ret = ts.resolveModuleNameFromCache(moduleName, containingFile, moduleResolutionCache, resolutionMode); + if (ret && ret.resolvedModule) { + fixupResolvedModule(ret.resolvedModule); + } + return ret; + }; + const resolveTypeReferenceDirectives = (typeDirectiveNames, containingFile, redirectedReference, options, containingFileMode // new impliedNodeFormat is accepted by compilerHost + ) => { + // Note: seems to be called with empty typeDirectiveNames array for all files. + // TODO consider using `ts.loadWithTypeDirectiveCache` + return typeDirectiveNames.map((typeDirectiveName) => { + // Copy-pasted from TS source: + const nameIsString = typeof typeDirectiveName === 'string'; + const mode = nameIsString + ? undefined + : ts.getModeForFileReference(typeDirectiveName, containingFileMode); + const strName = nameIsString + ? typeDirectiveName + : typeDirectiveName.fileName.toLowerCase(); + let { resolvedTypeReferenceDirective } = ts.resolveTypeReferenceDirective(strName, containingFile, config.options, host, redirectedReference, undefined, mode); + if (typeDirectiveName === 'node' && !resolvedTypeReferenceDirective) { + // Resolve @types/node relative to project first, then __dirname (copy logic from elsewhere / refactor into reusable function) + let typesNodePackageJsonPath; + try { + typesNodePackageJsonPath = projectLocalResolveHelper('@types/node/package.json', true); + } + catch { } // gracefully do nothing when @types/node is not installed for any reason + if (typesNodePackageJsonPath) { + const typeRoots = [(0, path_1.resolve)(typesNodePackageJsonPath, '../..')]; + ({ resolvedTypeReferenceDirective } = + ts.resolveTypeReferenceDirective(typeDirectiveName, containingFile, { + ...config.options, + typeRoots, + }, host, redirectedReference)); + } + } + if (resolvedTypeReferenceDirective) { + fixupResolvedModule(resolvedTypeReferenceDirective); + } + return resolvedTypeReferenceDirective; + }); + }; + return { + resolveModuleNames, + getResolvedModuleWithFailedLookupLocationsFromCache, + resolveTypeReferenceDirectives, + isFileKnownToBeInternal, + markBucketOfFilenameInternal, + }; } -module.exports = _which; - +exports.createResolverFunctions = createResolverFunctions; +//# sourceMappingURL=resolver-functions.js.map /***/ }), -/***/ 42059: +/***/ 80301: /***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { -var SourceMapConsumer = (__nccwpck_require__(36096).SourceMapConsumer); -var path = __nccwpck_require__(71017); - -var fs; -try { - fs = __nccwpck_require__(57147); - if (!fs.existsSync || !fs.readFileSync) { - // fs doesn't have all methods we need - fs = null; - } -} catch (err) { - /* nop */ -} - -var bufferFrom = __nccwpck_require__(82415); - -// Only install once if called multiple times -var errorFormatterInstalled = false; -var uncaughtShimInstalled = false; - -// If true, the caches are reset before a stack trace formatting operation -var emptyCacheBetweenOperations = false; - -// Supports {browser, node, auto} -var environment = "auto"; - -// Maps a file path to a string containing the file contents -var fileContentsCache = {}; - -// Maps a file path to a source map for that file -var sourceMapCache = {}; - -// Regex for detecting source maps -var reSourceMap = /^data:application\/json[^,]+base64,/; - -// Priority list of retrieve handlers -var retrieveFileHandlers = []; -var retrieveMapHandlers = []; - -function isInBrowser() { - if (environment === "browser") - return true; - if (environment === "node") - return false; - return ((typeof window !== 'undefined') && (typeof XMLHttpRequest === 'function') && !(window.require && window.module && window.process && window.process.type === "renderer")); -} +"use strict"; -function hasGlobalProcessEventEmitter() { - return ((typeof process === 'object') && (process !== null) && (typeof process.on === 'function')); -} - -function handlerExec(list) { - return function(arg) { - for (var i = 0; i < list.length; i++) { - var ret = list[i](arg); - if (ret) { - return ret; - } +Object.defineProperty(exports, "__esModule", ({ value: true })); +exports.getEmitScriptTarget = exports.getUseDefineForClassFields = exports.getPatternFromSpec = exports.createTsInternals = void 0; +const path_1 = __nccwpck_require__(71017); +const util_1 = __nccwpck_require__(26239); +/** @internal */ +exports.createTsInternals = (0, util_1.cachedLookup)(createTsInternalsUncached); +/** + * Given a reference to the TS compiler, return some TS internal functions that we + * could not or did not want to grab off the `ts` object. + * These have been copy-pasted from TS's source and tweaked as necessary. + * + * NOTE: This factory returns *only* functions which need a reference to the TS + * compiler. Other functions do not need a reference to the TS compiler so are + * exported directly from this file. + */ +function createTsInternalsUncached(_ts) { + const ts = _ts; + /** + * Copied from: + * https://github.com/microsoft/TypeScript/blob/v4.3.2/src/compiler/commandLineParser.ts#L2821-L2846 + */ + function getExtendsConfigPath(extendedConfig, host, basePath, errors, createDiagnostic) { + extendedConfig = (0, util_1.normalizeSlashes)(extendedConfig); + if (isRootedDiskPath(extendedConfig) || + startsWith(extendedConfig, './') || + startsWith(extendedConfig, '../')) { + let extendedConfigPath = getNormalizedAbsolutePath(extendedConfig, basePath); + if (!host.fileExists(extendedConfigPath) && + !endsWith(extendedConfigPath, ts.Extension.Json)) { + extendedConfigPath = `${extendedConfigPath}.json`; + if (!host.fileExists(extendedConfigPath)) { + errors.push(createDiagnostic(ts.Diagnostics.File_0_not_found, extendedConfig)); + return undefined; + } + } + return extendedConfigPath; + } + // If the path isn't a rooted or relative path, resolve like a module + const tsGte5_3_0 = (0, util_1.versionGteLt)(ts.version, '5.3.0'); + const resolved = ts.nodeModuleNameResolver(extendedConfig, combinePaths(basePath, 'tsconfig.json'), { moduleResolution: ts.ModuleResolutionKind.NodeJs }, host, + /*cache*/ undefined, + /*projectRefs*/ undefined, + /*conditionsOrIsConfigLookup*/ tsGte5_3_0 ? undefined : true, + /*isConfigLookup*/ tsGte5_3_0 ? true : undefined); + if (resolved.resolvedModule) { + return resolved.resolvedModule.resolvedFileName; + } + errors.push(createDiagnostic(ts.Diagnostics.File_0_not_found, extendedConfig)); + return undefined; } - return null; - }; + return { getExtendsConfigPath }; } - -var retrieveFile = handlerExec(retrieveFileHandlers); - -retrieveFileHandlers.push(function(path) { - // Trim the path to make sure there is no extra whitespace. - path = path.trim(); - if (/^file:/.test(path)) { - // existsSync/readFileSync can't handle file protocol, but once stripped, it works - path = path.replace(/file:\/\/\/(\w:)?/, function(protocol, drive) { - return drive ? - '' : // file:///C:/dir/file -> C:/dir/file - '/'; // file:///root-dir/file -> /root-dir/file - }); - } - if (path in fileContentsCache) { - return fileContentsCache[path]; - } - - var contents = ''; - try { - if (!fs) { - // Use SJAX if we are in the browser - var xhr = new XMLHttpRequest(); - xhr.open('GET', path, /** async */ false); - xhr.send(null); - if (xhr.readyState === 4 && xhr.status === 200) { - contents = xhr.responseText; - } - } else if (fs.existsSync(path)) { - // Otherwise, use the filesystem - contents = fs.readFileSync(path, 'utf8'); - } - } catch (er) { - /* ignore any errors */ - } - - return fileContentsCache[path] = contents; -}); - -// Support URLs relative to a directory, but be careful about a protocol prefix -// in case we are in the browser (i.e. directories may start with "http://" or "file:///") -function supportRelativeURL(file, url) { - if (!file) return url; - var dir = path.dirname(file); - var match = /^\w+:\/\/[^\/]*/.exec(dir); - var protocol = match ? match[0] : ''; - var startPath = dir.slice(protocol.length); - if (protocol && /^\/\w\:/.test(startPath)) { - // handle file:///C:/ paths - protocol += '/'; - return protocol + path.resolve(dir.slice(protocol.length), url).replace(/\\/g, '/'); - } - return protocol + path.resolve(dir.slice(protocol.length), url); +// These functions have alternative implementation to avoid copying too much from TS +function isRootedDiskPath(path) { + return (0, path_1.isAbsolute)(path); } - -function retrieveSourceMapURL(source) { - var fileData; - - if (isInBrowser()) { - try { - var xhr = new XMLHttpRequest(); - xhr.open('GET', source, false); - xhr.send(null); - fileData = xhr.readyState === 4 ? xhr.responseText : null; - - // Support providing a sourceMappingURL via the SourceMap header - var sourceMapHeader = xhr.getResponseHeader("SourceMap") || - xhr.getResponseHeader("X-SourceMap"); - if (sourceMapHeader) { - return sourceMapHeader; - } - } catch (e) { - } - } - - // Get the URL of the source map - fileData = retrieveFile(source); - var re = /(?:\/\/[@#][\s]*sourceMappingURL=([^\s'"]+)[\s]*$)|(?:\/\*[@#][\s]*sourceMappingURL=([^\s*'"]+)[\s]*(?:\*\/)[\s]*$)/mg; - // Keep executing the search to find the *last* sourceMappingURL to avoid - // picking up sourceMappingURLs from comments, strings, etc. - var lastMatch, match; - while (match = re.exec(fileData)) lastMatch = match; - if (!lastMatch) return null; - return lastMatch[1]; -}; - -// Can be overridden by the retrieveSourceMap option to install. Takes a -// generated source filename; returns a {map, optional url} object, or null if -// there is no source map. The map field may be either a string or the parsed -// JSON object (ie, it must be a valid argument to the SourceMapConsumer -// constructor). -var retrieveSourceMap = handlerExec(retrieveMapHandlers); -retrieveMapHandlers.push(function(source) { - var sourceMappingURL = retrieveSourceMapURL(source); - if (!sourceMappingURL) return null; - - // Read the contents of the source map - var sourceMapData; - if (reSourceMap.test(sourceMappingURL)) { - // Support source map URL as a data url - var rawData = sourceMappingURL.slice(sourceMappingURL.indexOf(',') + 1); - sourceMapData = bufferFrom(rawData, "base64").toString(); - sourceMappingURL = source; - } else { - // Support source map URLs relative to the source URL - sourceMappingURL = supportRelativeURL(source, sourceMappingURL); - sourceMapData = retrieveFile(sourceMappingURL); - } - - if (!sourceMapData) { - return null; - } - - return { - url: sourceMappingURL, - map: sourceMapData - }; -}); - -function mapSourcePosition(position) { - var sourceMap = sourceMapCache[position.source]; - if (!sourceMap) { - // Call the (overrideable) retrieveSourceMap function to get the source map. - var urlAndMap = retrieveSourceMap(position.source); - if (urlAndMap) { - sourceMap = sourceMapCache[position.source] = { - url: urlAndMap.url, - map: new SourceMapConsumer(urlAndMap.map) - }; - - // Load all sources stored inline with the source map into the file cache - // to pretend like they are already loaded. They may not exist on disk. - if (sourceMap.map.sourcesContent) { - sourceMap.map.sources.forEach(function(source, i) { - var contents = sourceMap.map.sourcesContent[i]; - if (contents) { - var url = supportRelativeURL(sourceMap.url, source); - fileContentsCache[url] = contents; - } - }); - } - } else { - sourceMap = sourceMapCache[position.source] = { - url: null, - map: null - }; +function combinePaths(path, ...paths) { + return (0, util_1.normalizeSlashes)((0, path_1.resolve)(path, ...paths.filter((path) => path))); +} +function getNormalizedAbsolutePath(fileName, currentDirectory) { + return (0, util_1.normalizeSlashes)(currentDirectory != null + ? (0, path_1.resolve)(currentDirectory, fileName) + : (0, path_1.resolve)(fileName)); +} +function startsWith(str, prefix) { + return str.lastIndexOf(prefix, 0) === 0; +} +function endsWith(str, suffix) { + const expectedPos = str.length - suffix.length; + return expectedPos >= 0 && str.indexOf(suffix, expectedPos) === expectedPos; +} +// Reserved characters, forces escaping of any non-word (or digit), non-whitespace character. +// It may be inefficient (we could just match (/[-[\]{}()*+?.,\\^$|#\s]/g), but this is future +// proof. +const reservedCharacterPattern = /[^\w\s\/]/g; +/** + * @internal + * See also: getRegularExpressionForWildcard, which seems to do almost the same thing + */ +function getPatternFromSpec(spec, basePath) { + const pattern = spec && getSubPatternFromSpec(spec, basePath, excludeMatcher); + return pattern && `^(${pattern})${'($|/)'}`; +} +exports.getPatternFromSpec = getPatternFromSpec; +function getSubPatternFromSpec(spec, basePath, { singleAsteriskRegexFragment, doubleAsteriskRegexFragment, replaceWildcardCharacter, }) { + let subpattern = ''; + let hasWrittenComponent = false; + const components = getNormalizedPathComponents(spec, basePath); + const lastComponent = last(components); + // getNormalizedPathComponents includes the separator for the root component. + // We need to remove to create our regex correctly. + components[0] = removeTrailingDirectorySeparator(components[0]); + if (isImplicitGlob(lastComponent)) { + components.push('**', '*'); } - } - - // Resolve the source URL relative to the URL of the source map - if (sourceMap && sourceMap.map && typeof sourceMap.map.originalPositionFor === 'function') { - var originalPosition = sourceMap.map.originalPositionFor(position); - - // Only return the original position if a matching line was found. If no - // matching line is found then we return position instead, which will cause - // the stack trace to print the path and line for the compiled file. It is - // better to give a precise location in the compiled file than a vague - // location in the original file. - if (originalPosition.source !== null) { - originalPosition.source = supportRelativeURL( - sourceMap.url, originalPosition.source); - return originalPosition; + let optionalCount = 0; + for (let component of components) { + if (component === '**') { + subpattern += doubleAsteriskRegexFragment; + } + else { + if (hasWrittenComponent) { + subpattern += directorySeparator; + } + subpattern += component.replace(reservedCharacterPattern, replaceWildcardCharacter); + } + hasWrittenComponent = true; } - } - - return position; + while (optionalCount > 0) { + subpattern += ')?'; + optionalCount--; + } + return subpattern; } - -// Parses code generated by FormatEvalOrigin(), a function inside V8: -// https://code.google.com/p/v8/source/browse/trunk/src/messages.js -function mapEvalOrigin(origin) { - // Most eval() calls are in this format - var match = /^eval at ([^(]+) \((.+):(\d+):(\d+)\)$/.exec(origin); - if (match) { - var position = mapSourcePosition({ - source: match[2], - line: +match[3], - column: match[4] - 1 - }); - return 'eval at ' + match[1] + ' (' + position.source + ':' + - position.line + ':' + (position.column + 1) + ')'; - } - - // Parse nested eval() calls using recursion - match = /^eval at ([^(]+) \((.+)\)$/.exec(origin); - if (match) { - return 'eval at ' + match[1] + ' (' + mapEvalOrigin(match[2]) + ')'; - } - - // Make sure we still return useful information if we didn't find anything - return origin; +const directoriesMatcher = { + singleAsteriskRegexFragment: '[^/]*', + /** + * Regex for the ** wildcard. Matches any num of subdirectories. When used for including + * files or directories, does not match subdirectories that start with a . character + */ + doubleAsteriskRegexFragment: `(/[^/.][^/]*)*?`, + replaceWildcardCharacter: (match) => replaceWildcardCharacter(match, directoriesMatcher.singleAsteriskRegexFragment), +}; +const excludeMatcher = { + singleAsteriskRegexFragment: '[^/]*', + doubleAsteriskRegexFragment: '(/.+?)?', + replaceWildcardCharacter: (match) => replaceWildcardCharacter(match, excludeMatcher.singleAsteriskRegexFragment), +}; +function getNormalizedPathComponents(path, currentDirectory) { + return reducePathComponents(getPathComponents(path, currentDirectory)); } - -// This is copied almost verbatim from the V8 source code at -// https://code.google.com/p/v8/source/browse/trunk/src/messages.js. The -// implementation of wrapCallSite() used to just forward to the actual source -// code of CallSite.prototype.toString but unfortunately a new release of V8 -// did something to the prototype chain and broke the shim. The only fix I -// could find was copy/paste. -function CallSiteToString() { - var fileName; - var fileLocation = ""; - if (this.isNative()) { - fileLocation = "native"; - } else { - fileName = this.getScriptNameOrSourceURL(); - if (!fileName && this.isEval()) { - fileLocation = this.getEvalOrigin(); - fileLocation += ", "; // Expecting source position to follow. +function getPathComponents(path, currentDirectory = '') { + path = combinePaths(currentDirectory, path); + return pathComponents(path, getRootLength(path)); +} +function reducePathComponents(components) { + if (!some(components)) + return []; + const reduced = [components[0]]; + for (let i = 1; i < components.length; i++) { + const component = components[i]; + if (!component) + continue; + if (component === '.') + continue; + if (component === '..') { + if (reduced.length > 1) { + if (reduced[reduced.length - 1] !== '..') { + reduced.pop(); + continue; + } + } + else if (reduced[0]) + continue; + } + reduced.push(component); } - - if (fileName) { - fileLocation += fileName; - } else { - // Source code does not originate from a file and is not native, but we - // can still get the source position inside the source string, e.g. in - // an eval string. - fileLocation += ""; + return reduced; +} +function getRootLength(path) { + const rootLength = getEncodedRootLength(path); + return rootLength < 0 ? ~rootLength : rootLength; +} +function getEncodedRootLength(path) { + if (!path) + return 0; + const ch0 = path.charCodeAt(0); + // POSIX or UNC + if (ch0 === 47 /* CharacterCodes.slash */ || ch0 === 92 /* CharacterCodes.backslash */) { + if (path.charCodeAt(1) !== ch0) + return 1; // POSIX: "/" (or non-normalized "\") + const p1 = path.indexOf(ch0 === 47 /* CharacterCodes.slash */ ? directorySeparator : altDirectorySeparator, 2); + if (p1 < 0) + return path.length; // UNC: "//server" or "\\server" + return p1 + 1; // UNC: "//server/" or "\\server\" } - var lineNumber = this.getLineNumber(); - if (lineNumber != null) { - fileLocation += ":" + lineNumber; - var columnNumber = this.getColumnNumber(); - if (columnNumber) { - fileLocation += ":" + columnNumber; - } + // DOS + if (isVolumeCharacter(ch0) && path.charCodeAt(1) === 58 /* CharacterCodes.colon */) { + const ch2 = path.charCodeAt(2); + if (ch2 === 47 /* CharacterCodes.slash */ || ch2 === 92 /* CharacterCodes.backslash */) + return 3; // DOS: "c:/" or "c:\" + if (path.length === 2) + return 2; // DOS: "c:" (but not "c:d") } - } - - var line = ""; - var functionName = this.getFunctionName(); - var addSuffix = true; - var isConstructor = this.isConstructor(); - var isMethodCall = !(this.isToplevel() || isConstructor); - if (isMethodCall) { - var typeName = this.getTypeName(); - // Fixes shim to be backward compatable with Node v0 to v4 - if (typeName === "[object Object]") { - typeName = "null"; + // URL + const schemeEnd = path.indexOf(urlSchemeSeparator); + if (schemeEnd !== -1) { + const authorityStart = schemeEnd + urlSchemeSeparator.length; + const authorityEnd = path.indexOf(directorySeparator, authorityStart); + if (authorityEnd !== -1) { + // URL: "file:///", "file://server/", "file://server/path" + // For local "file" URLs, include the leading DOS volume (if present). + // Per https://www.ietf.org/rfc/rfc1738.txt, a host of "" or "localhost" is a + // special case interpreted as "the machine from which the URL is being interpreted". + const scheme = path.slice(0, schemeEnd); + const authority = path.slice(authorityStart, authorityEnd); + if (scheme === 'file' && + (authority === '' || authority === 'localhost') && + isVolumeCharacter(path.charCodeAt(authorityEnd + 1))) { + const volumeSeparatorEnd = getFileUrlVolumeSeparatorEnd(path, authorityEnd + 2); + if (volumeSeparatorEnd !== -1) { + if (path.charCodeAt(volumeSeparatorEnd) === 47 /* CharacterCodes.slash */) { + // URL: "file:///c:/", "file://localhost/c:/", "file:///c%3a/", "file://localhost/c%3a/" + return ~(volumeSeparatorEnd + 1); + } + if (volumeSeparatorEnd === path.length) { + // URL: "file:///c:", "file://localhost/c:", "file:///c$3a", "file://localhost/c%3a" + // but not "file:///c:d" or "file:///c%3ad" + return ~volumeSeparatorEnd; + } + } + } + return ~(authorityEnd + 1); // URL: "file://server/", "http://server/" + } + return ~path.length; // URL: "file://server", "http://server" } - var methodName = this.getMethodName(); - if (functionName) { - if (typeName && functionName.indexOf(typeName) != 0) { - line += typeName + "."; - } - line += functionName; - if (methodName && functionName.indexOf("." + methodName) != functionName.length - methodName.length - 1) { - line += " [as " + methodName + "]"; - } - } else { - line += typeName + "." + (methodName || ""); + // relative + return 0; +} +function ensureTrailingDirectorySeparator(path) { + if (!hasTrailingDirectorySeparator(path)) { + return path + directorySeparator; } - } else if (isConstructor) { - line += "new " + (functionName || ""); - } else if (functionName) { - line += functionName; - } else { - line += fileLocation; - addSuffix = false; - } - if (addSuffix) { - line += " (" + fileLocation + ")"; - } - return line; + return path; } - -function cloneCallSite(frame) { - var object = {}; - Object.getOwnPropertyNames(Object.getPrototypeOf(frame)).forEach(function(name) { - object[name] = /^(?:is|get)/.test(name) ? function() { return frame[name].call(frame); } : frame[name]; - }); - object.toString = CallSiteToString; - return object; +function hasTrailingDirectorySeparator(path) { + return (path.length > 0 && isAnyDirectorySeparator(path.charCodeAt(path.length - 1))); } - -function wrapCallSite(frame) { - if(frame.isNative()) { - return frame; - } - - // Most call sites will return the source file from getFileName(), but code - // passed to eval() ending in "//# sourceURL=..." will return the source file - // from getScriptNameOrSourceURL() instead - var source = frame.getFileName() || frame.getScriptNameOrSourceURL(); - if (source) { - var line = frame.getLineNumber(); - var column = frame.getColumnNumber() - 1; - - // Fix position in Node where some (internal) code is prepended. - // See https://github.com/evanw/node-source-map-support/issues/36 - var headerLength = 62; - if (line === 1 && column > headerLength && !isInBrowser() && !frame.isEval()) { - column -= headerLength; +function isAnyDirectorySeparator(charCode) { + return (charCode === 47 /* CharacterCodes.slash */ || charCode === 92 /* CharacterCodes.backslash */); +} +function removeTrailingDirectorySeparator(path) { + if (hasTrailingDirectorySeparator(path)) { + return path.substr(0, path.length - 1); } - - var position = mapSourcePosition({ - source: source, - line: line, - column: column - }); - frame = cloneCallSite(frame); - var originalFunctionName = frame.getFunctionName; - frame.getFunctionName = function() { return position.name || originalFunctionName(); }; - frame.getFileName = function() { return position.source; }; - frame.getLineNumber = function() { return position.line; }; - frame.getColumnNumber = function() { return position.column + 1; }; - frame.getScriptNameOrSourceURL = function() { return position.source; }; - return frame; - } - - // Code called using eval() needs special handling - var origin = frame.isEval() && frame.getEvalOrigin(); - if (origin) { - origin = mapEvalOrigin(origin); - frame = cloneCallSite(frame); - frame.getEvalOrigin = function() { return origin; }; - return frame; - } - - // If we get here then we were unable to change the source position - return frame; + return path; } - -// This function is part of the V8 stack trace API, for more info see: -// https://v8.dev/docs/stack-trace-api -function prepareStackTrace(error, stack) { - if (emptyCacheBetweenOperations) { - fileContentsCache = {}; - sourceMapCache = {}; - } - - var name = error.name || 'Error'; - var message = error.message || ''; - var errorString = name + ": " + message; - - return errorString + stack.map(function(frame) { - return '\n at ' + wrapCallSite(frame); - }).join(''); +const directorySeparator = '/'; +const altDirectorySeparator = '\\'; +const urlSchemeSeparator = '://'; +function isVolumeCharacter(charCode) { + return ((charCode >= 97 /* CharacterCodes.a */ && charCode <= 122 /* CharacterCodes.z */) || + (charCode >= 65 /* CharacterCodes.A */ && charCode <= 90 /* CharacterCodes.Z */)); } - -// Generate position and snippet of original source with pointer -function getErrorSource(error) { - var match = /\n at [^(]+ \((.*):(\d+):(\d+)\)/.exec(error.stack); - if (match) { - var source = match[1]; - var line = +match[2]; - var column = +match[3]; - - // Support the inline sourceContents inside the source map - var contents = fileContentsCache[source]; - - // Support files on disk - if (!contents && fs && fs.existsSync(source)) { - try { - contents = fs.readFileSync(source, 'utf8'); - } catch (er) { - contents = ''; - } +function getFileUrlVolumeSeparatorEnd(url, start) { + const ch0 = url.charCodeAt(start); + if (ch0 === 58 /* CharacterCodes.colon */) + return start + 1; + if (ch0 === 37 /* CharacterCodes.percent */ && + url.charCodeAt(start + 1) === 51 /* CharacterCodes._3 */) { + const ch2 = url.charCodeAt(start + 2); + if (ch2 === 97 /* CharacterCodes.a */ || ch2 === 65 /* CharacterCodes.A */) + return start + 3; } - - // Format the line from the original source code like node does - if (contents) { - var code = contents.split(/(?:\r\n|\r|\n)/)[line - 1]; - if (code) { - return source + ':' + line + '\n' + code + '\n' + - new Array(column).join(' ') + '^'; - } + return -1; +} +function some(array, predicate) { + if (array) { + if (predicate) { + for (const v of array) { + if (predicate(v)) { + return true; + } + } + } + else { + return array.length > 0; + } } - } - return null; + return false; } - -function printErrorAndExit (error) { - var source = getErrorSource(error); - - // Ensure error is printed synchronously and not truncated - if (process.stderr._handle && process.stderr._handle.setBlocking) { - process.stderr._handle.setBlocking(true); - } - - if (source) { - console.error(); - console.error(source); - } - - console.error(error.stack); - process.exit(1); +function pathComponents(path, rootLength) { + const root = path.substring(0, rootLength); + const rest = path.substring(rootLength).split(directorySeparator); + if (rest.length && !lastOrUndefined(rest)) + rest.pop(); + return [root, ...rest]; } - -function shimEmitUncaughtException () { - var origEmit = process.emit; - - process.emit = function (type) { - if (type === 'uncaughtException') { - var hasStack = (arguments[1] && arguments[1].stack); - var hasListeners = (this.listeners(type).length > 0); - - if (hasStack && !hasListeners) { - return printErrorAndExit(arguments[1]); - } - } - - return origEmit.apply(this, arguments); - }; +function lastOrUndefined(array) { + return array.length === 0 ? undefined : array[array.length - 1]; +} +function last(array) { + // Debug.assert(array.length !== 0); + return array[array.length - 1]; +} +function replaceWildcardCharacter(match, singleAsteriskRegexFragment) { + return match === '*' + ? singleAsteriskRegexFragment + : match === '?' + ? '[^/]' + : '\\' + match; +} +/** + * An "includes" path "foo" is implicitly a glob "foo/** /*" (without the space) if its last component has no extension, + * and does not contain any glob characters itself. + */ +function isImplicitGlob(lastPathComponent) { + return !/[.*?]/.test(lastPathComponent); +} +const ts_ScriptTarget_ES5 = 1; +const ts_ScriptTarget_ES2022 = 9; +const ts_ScriptTarget_ESNext = 99; +const ts_ModuleKind_Node16 = 100; +const ts_ModuleKind_NodeNext = 199; +// https://github.com/microsoft/TypeScript/blob/fc418a2e611c88cf9afa0115ff73490b2397d311/src/compiler/utilities.ts#L8761 +function getUseDefineForClassFields(compilerOptions) { + return compilerOptions.useDefineForClassFields === undefined + ? getEmitScriptTarget(compilerOptions) >= ts_ScriptTarget_ES2022 + : compilerOptions.useDefineForClassFields; +} +exports.getUseDefineForClassFields = getUseDefineForClassFields; +// https://github.com/microsoft/TypeScript/blob/fc418a2e611c88cf9afa0115ff73490b2397d311/src/compiler/utilities.ts#L8556 +function getEmitScriptTarget(compilerOptions) { + var _a; + return ((_a = compilerOptions.target) !== null && _a !== void 0 ? _a : ((compilerOptions.module === ts_ModuleKind_Node16 && ts_ScriptTarget_ES2022) || + (compilerOptions.module === ts_ModuleKind_NodeNext && ts_ScriptTarget_ESNext) || + ts_ScriptTarget_ES5)); } +exports.getEmitScriptTarget = getEmitScriptTarget; +//# sourceMappingURL=ts-internals.js.map -var originalRetrieveFileHandlers = retrieveFileHandlers.slice(0); -var originalRetrieveMapHandlers = retrieveMapHandlers.slice(0); +/***/ }), -exports.wrapCallSite = wrapCallSite; -exports.getErrorSource = getErrorSource; -exports.mapSourcePosition = mapSourcePosition; -exports.retrieveSourceMap = retrieveSourceMap; +/***/ 87857: +/***/ ((__unused_webpack_module, exports) => { -exports.install = function(options) { - options = options || {}; +"use strict"; - if (options.environment) { - environment = options.environment; - if (["node", "browser", "auto"].indexOf(environment) === -1) { - throw new Error("environment " + environment + " was unknown. Available options are {auto, browser, node}") +Object.defineProperty(exports, "__esModule", ({ value: true })); +exports.createTsTranspileModule = void 0; +/** @internal */ +function createTsTranspileModule(ts, transpileOptions) { + const { createProgram, createSourceFile, getDefaultCompilerOptions, getImpliedNodeFormatForFile, fixupCompilerOptions, transpileOptionValueCompilerOptions, getNewLineCharacter, fileExtensionIs, normalizePath, Debug, toPath, getSetExternalModuleIndicator, getEntries, addRange, hasProperty, getEmitScriptTarget, getDirectoryPath, } = ts; + const compilerOptionsDiagnostics = []; + const options = transpileOptions.compilerOptions + ? fixupCompilerOptions(transpileOptions.compilerOptions, compilerOptionsDiagnostics) + : {}; + // mix in default options + const defaultOptions = getDefaultCompilerOptions(); + for (const key in defaultOptions) { + if (hasProperty(defaultOptions, key) && options[key] === undefined) { + options[key] = defaultOptions[key]; + } } - } - - // Allow sources to be found by methods other than reading the files - // directly from disk. - if (options.retrieveFile) { - if (options.overrideRetrieveFile) { - retrieveFileHandlers.length = 0; + for (const option of transpileOptionValueCompilerOptions) { + options[option.name] = option.transpileOptionValue; } - - retrieveFileHandlers.unshift(options.retrieveFile); - } - - // Allow source maps to be found by methods other than reading the files - // directly from disk. - if (options.retrieveSourceMap) { - if (options.overrideRetrieveSourceMap) { - retrieveMapHandlers.length = 0; + // transpileModule does not write anything to disk so there is no need to verify that there are no conflicts between input and output paths. + options.suppressOutputPathCheck = true; + // Filename can be non-ts file. + options.allowNonTsExtensions = true; + const newLine = getNewLineCharacter(options); + // Create a compilerHost object to allow the compiler to read and write files + const compilerHost = { + getSourceFile: (fileName) => fileName === normalizePath(inputFileName) ? sourceFile : undefined, + writeFile: (name, text) => { + if (fileExtensionIs(name, '.map')) { + Debug.assertEqual(sourceMapText, undefined, 'Unexpected multiple source map outputs, file:', name); + sourceMapText = text; + } + else { + Debug.assertEqual(outputText, undefined, 'Unexpected multiple outputs, file:', name); + outputText = text; + } + }, + getDefaultLibFileName: () => 'lib.d.ts', + useCaseSensitiveFileNames: () => true, + getCanonicalFileName: (fileName) => fileName, + getCurrentDirectory: () => '', + getNewLine: () => newLine, + fileExists: (fileName) => fileName === inputFileName || fileName === packageJsonFileName, + readFile: (fileName) => fileName === packageJsonFileName ? `{"type": "${_packageJsonType}"}` : '', + directoryExists: () => true, + getDirectories: () => [], + }; + let inputFileName; + let packageJsonFileName; + let _packageJsonType; + let sourceFile; + let outputText; + let sourceMapText; + return transpileModule; + function transpileModule(input, transpileOptions2, packageJsonType = 'commonjs') { + // if jsx is specified then treat file as .tsx + inputFileName = + transpileOptions2.fileName || + (transpileOptions.compilerOptions && transpileOptions.compilerOptions.jsx + ? 'module.tsx' + : 'module.ts'); + packageJsonFileName = getDirectoryPath(inputFileName) + '/package.json'; + _packageJsonType = packageJsonType; + sourceFile = createSourceFile(inputFileName, input, { + languageVersion: getEmitScriptTarget(options), + impliedNodeFormat: getImpliedNodeFormatForFile(toPath(inputFileName, '', compilerHost.getCanonicalFileName), + /*cache*/ undefined, compilerHost, options), + setExternalModuleIndicator: getSetExternalModuleIndicator(options), + }); + if (transpileOptions2.moduleName) { + sourceFile.moduleName = transpileOptions2.moduleName; + } + if (transpileOptions2.renamedDependencies) { + sourceFile.renamedDependencies = new Map(getEntries(transpileOptions2.renamedDependencies)); + } + // Output + outputText = undefined; + sourceMapText = undefined; + const program = createProgram([inputFileName], options, compilerHost); + const diagnostics = compilerOptionsDiagnostics.slice(); + if (transpileOptions.reportDiagnostics) { + addRange( + /*to*/ diagnostics, + /*from*/ program.getSyntacticDiagnostics(sourceFile)); + addRange(/*to*/ diagnostics, /*from*/ program.getOptionsDiagnostics()); + } + // Emit + program.emit( + /*targetSourceFile*/ undefined, + /*writeFile*/ undefined, + /*cancellationToken*/ undefined, + /*emitOnlyDtsFiles*/ undefined, transpileOptions.transformers); + if (outputText === undefined) + return Debug.fail('Output generation failed'); + return { outputText, diagnostics, sourceMapText }; } +} +exports.createTsTranspileModule = createTsTranspileModule; +//# sourceMappingURL=ts-transpile-module.js.map - retrieveMapHandlers.unshift(options.retrieveSourceMap); - } +/***/ }), - // Support runtime transpilers that include inline source maps - if (options.hookRequire && !isInBrowser()) { - var Module; - try { - Module = __nccwpck_require__(98188); - } catch (err) { - // NOP: Loading in catch block to convert webpack error to warning. - } - var $compile = Module.prototype._compile; +/***/ 88933: +/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { - if (!$compile.__sourceMapSupport) { - Module.prototype._compile = function(content, filename) { - fileContentsCache[filename] = content; - sourceMapCache[filename] = undefined; - return $compile.call(this, content, filename); - }; +"use strict"; - Module.prototype._compile.__sourceMapSupport = true; +Object.defineProperty(exports, "__esModule", ({ value: true })); +exports.getDefaultTsconfigJsonForNodeVersion = void 0; +const nodeMajor = parseInt(process.versions.node.split('.')[0], 10); +/** + * return parsed JSON of the bundled @tsconfig/bases config appropriate for the + * running version of nodejs + * @internal + */ +function getDefaultTsconfigJsonForNodeVersion(ts) { + const tsInternal = ts; + if (nodeMajor >= 16) { + const config = __nccwpck_require__(39777); + if (configCompatible(config)) + return config; } - } - - // Configure options - if (!emptyCacheBetweenOperations) { - emptyCacheBetweenOperations = 'emptyCacheBetweenOperations' in options ? - options.emptyCacheBetweenOperations : false; - } - - // Install the error reformatter - if (!errorFormatterInstalled) { - errorFormatterInstalled = true; - Error.prepareStackTrace = prepareStackTrace; - } - - if (!uncaughtShimInstalled) { - var installHandler = 'handleUncaughtExceptions' in options ? - options.handleUncaughtExceptions : true; - - // Provide the option to not install the uncaught exception handler. This is - // to support other uncaught exception handlers (in test frameworks, for - // example). If this handler is not installed and there are no other uncaught - // exception handlers, uncaught exceptions will be caught by node's built-in - // exception handler and the process will still be terminated. However, the - // generated JavaScript code will be shown above the stack trace instead of - // the original source code. - if (installHandler && hasGlobalProcessEventEmitter()) { - uncaughtShimInstalled = true; - shimEmitUncaughtException(); + if (nodeMajor >= 14) { + const config = __nccwpck_require__(83754); + if (configCompatible(config)) + return config; + } + if (nodeMajor >= 12) { + const config = __nccwpck_require__(56049); + if (configCompatible(config)) + return config; + } + return __nccwpck_require__(78250); + // Verify that tsconfig target and lib options are compatible with TypeScript compiler + function configCompatible(config) { + return (typeof ts.ScriptTarget[config.compilerOptions.target.toUpperCase()] === 'number' && + tsInternal.libs && + config.compilerOptions.lib.every((lib) => tsInternal.libs.includes(lib))); } - } -}; - -exports.resetRetrieveHandlers = function() { - retrieveFileHandlers.length = 0; - retrieveMapHandlers.length = 0; - - retrieveFileHandlers = originalRetrieveFileHandlers.slice(0); - retrieveMapHandlers = originalRetrieveMapHandlers.slice(0); - - retrieveSourceMap = handlerExec(retrieveMapHandlers); - retrieveFile = handlerExec(retrieveFileHandlers); } - +exports.getDefaultTsconfigJsonForNodeVersion = getDefaultTsconfigJsonForNodeVersion; +//# sourceMappingURL=tsconfigs.js.map /***/ }), -/***/ 30176: +/***/ 26239: /***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { -/* -*- Mode: js; js-indent-level: 2; -*- */ -/* - * Copyright 2011 Mozilla Foundation and contributors - * Licensed under the New BSD license. See LICENSE or: - * http://opensource.org/licenses/BSD-3-Clause - */ - -var util = __nccwpck_require__(16511); -var has = Object.prototype.hasOwnProperty; -var hasNativeMap = typeof Map !== "undefined"; +"use strict"; +var _a; +Object.defineProperty(exports, "__esModule", ({ value: true })); +exports.versionGteLt = exports.once = exports.getBasePathForProjectLocalDependencyResolution = exports.createProjectLocalResolveHelper = exports.attemptRequireWithV8CompileCache = exports.cachedLookup = exports.hasOwnProperty = exports.normalizeSlashes = exports.parse = exports.split = exports.assign = exports.yn = exports.createRequire = void 0; +const module_1 = __nccwpck_require__(98188); +const ynModule = __nccwpck_require__(45001); +const path_1 = __nccwpck_require__(71017); +/** @internal */ +exports.createRequire = (_a = module_1.createRequire !== null && module_1.createRequire !== void 0 ? module_1.createRequire : module_1.createRequireFromPath) !== null && _a !== void 0 ? _a : __nccwpck_require__(14838); /** - * A data structure which is a combination of an array and a set. Adding a new - * member is O(1), testing for membership is O(1), and finding the index of an - * element is O(1). Removing elements from the set is not supported. Only - * strings are supported for membership. + * Wrapper around yn module that returns `undefined` instead of `null`. + * This is implemented by yn v4, but we're staying on v3 to avoid v4's node 10 requirement. + * @internal */ -function ArraySet() { - this._array = []; - this._set = hasNativeMap ? new Map() : Object.create(null); +function yn(value) { + var _a; + return (_a = ynModule(value)) !== null && _a !== void 0 ? _a : undefined; } - -/** - * Static method for creating ArraySet instances from an existing array. - */ -ArraySet.fromArray = function ArraySet_fromArray(aArray, aAllowDuplicates) { - var set = new ArraySet(); - for (var i = 0, len = aArray.length; i < len; i++) { - set.add(aArray[i], aAllowDuplicates); - } - return set; -}; - +exports.yn = yn; /** - * Return how many unique items are in this ArraySet. If duplicates have been - * added, than those do not count towards the size. + * Like `Object.assign`, but ignores `undefined` properties. * - * @returns Number + * @internal */ -ArraySet.prototype.size = function ArraySet_size() { - return hasNativeMap ? this._set.size : Object.getOwnPropertyNames(this._set).length; -}; - +function assign(initialValue, ...sources) { + for (const source of sources) { + for (const key of Object.keys(source)) { + const value = source[key]; + if (value !== undefined) + initialValue[key] = value; + } + } + return initialValue; +} +exports.assign = assign; /** - * Add the given string to this set. - * - * @param String aStr + * Split a string array of values + * and remove empty strings from the resulting array. + * @internal */ -ArraySet.prototype.add = function ArraySet_add(aStr, aAllowDuplicates) { - var sStr = hasNativeMap ? aStr : util.toSetString(aStr); - var isDuplicate = hasNativeMap ? this.has(aStr) : has.call(this._set, sStr); - var idx = this._array.length; - if (!isDuplicate || aAllowDuplicates) { - this._array.push(aStr); - } - if (!isDuplicate) { - if (hasNativeMap) { - this._set.set(aStr, idx); - } else { - this._set[sStr] = idx; - } - } -}; - +function split(value) { + return typeof value === 'string' + ? value.split(/ *, */g).filter((v) => v !== '') + : undefined; +} +exports.split = split; /** - * Is the given string a member of this set? - * - * @param String aStr + * Parse a string as JSON. + * @internal */ -ArraySet.prototype.has = function ArraySet_has(aStr) { - if (hasNativeMap) { - return this._set.has(aStr); - } else { - var sStr = util.toSetString(aStr); - return has.call(this._set, sStr); - } -}; - +function parse(value) { + return typeof value === 'string' ? JSON.parse(value) : undefined; +} +exports.parse = parse; +const directorySeparator = '/'; +const backslashRegExp = /\\/g; /** - * What is the index of the given string in the array? - * - * @param String aStr + * Replace backslashes with forward slashes. + * @internal */ -ArraySet.prototype.indexOf = function ArraySet_indexOf(aStr) { - if (hasNativeMap) { - var idx = this._set.get(aStr); - if (idx >= 0) { - return idx; - } - } else { - var sStr = util.toSetString(aStr); - if (has.call(this._set, sStr)) { - return this._set[sStr]; - } - } - - throw new Error('"' + aStr + '" is not in the set.'); -}; - +function normalizeSlashes(value) { + return value.replace(backslashRegExp, directorySeparator); +} +exports.normalizeSlashes = normalizeSlashes; /** - * What is the element at the given index? - * - * @param Number aIdx + * Safe `hasOwnProperty` + * @internal */ -ArraySet.prototype.at = function ArraySet_at(aIdx) { - if (aIdx >= 0 && aIdx < this._array.length) { - return this._array[aIdx]; - } - throw new Error('No element indexed by ' + aIdx); -}; - +function hasOwnProperty(object, property) { + return Object.prototype.hasOwnProperty.call(object, property); +} +exports.hasOwnProperty = hasOwnProperty; /** - * Returns the array representation of this set (which has the proper indices - * indicated by indexOf). Note that this is a copy of the internal array used - * for storing the members so that no one can mess with internal state. - */ -ArraySet.prototype.toArray = function ArraySet_toArray() { - return this._array.slice(); -}; - -exports.I = ArraySet; - - -/***/ }), - -/***/ 14590: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { - -/* -*- Mode: js; js-indent-level: 2; -*- */ -/* - * Copyright 2011 Mozilla Foundation and contributors - * Licensed under the New BSD license. See LICENSE or: - * http://opensource.org/licenses/BSD-3-Clause - * - * Based on the Base 64 VLQ implementation in Closure Compiler: - * https://code.google.com/p/closure-compiler/source/browse/trunk/src/com/google/debugging/sourcemap/Base64VLQ.java - * - * Copyright 2011 The Closure Compiler Authors. All rights reserved. - * Redistribution and use in source and binary forms, with or without - * modification, are permitted provided that the following conditions are - * met: - * - * * Redistributions of source code must retain the above copyright - * notice, this list of conditions and the following disclaimer. - * * Redistributions in binary form must reproduce the above - * copyright notice, this list of conditions and the following - * disclaimer in the documentation and/or other materials provided - * with the distribution. - * * Neither the name of Google Inc. nor the names of its - * contributors may be used to endorse or promote products derived - * from this software without specific prior written permission. - * - * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS - * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT - * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR - * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT - * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, - * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT - * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, - * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY - * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT - * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE - * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. + * Cached fs operation wrapper. */ - -var base64 = __nccwpck_require__(94521); - -// A single base 64 digit can contain 6 bits of data. For the base 64 variable -// length quantities we use in the source map spec, the first bit is the sign, -// the next four bits are the actual value, and the 6th bit is the -// continuation bit. The continuation bit tells us whether there are more -// digits in this value following this digit. -// -// Continuation -// | Sign -// | | -// V V -// 101011 - -var VLQ_BASE_SHIFT = 5; - -// binary: 100000 -var VLQ_BASE = 1 << VLQ_BASE_SHIFT; - -// binary: 011111 -var VLQ_BASE_MASK = VLQ_BASE - 1; - -// binary: 100000 -var VLQ_CONTINUATION_BIT = VLQ_BASE; - +function cachedLookup(fn) { + const cache = new Map(); + return (arg) => { + if (!cache.has(arg)) { + const v = fn(arg); + cache.set(arg, v); + return v; + } + return cache.get(arg); + }; +} +exports.cachedLookup = cachedLookup; /** - * Converts from a two-complement value to a value where the sign bit is - * placed in the least significant bit. For example, as decimals: - * 1 becomes 2 (10 binary), -1 becomes 3 (11 binary) - * 2 becomes 4 (100 binary), -2 becomes 5 (101 binary) + * @internal + * Require something with v8-compile-cache, which should make subsequent requires faster. + * Do lots of error-handling so that, worst case, we require without the cache, and users are not blocked. */ -function toVLQSigned(aValue) { - return aValue < 0 - ? ((-aValue) << 1) + 1 - : (aValue << 1) + 0; +function attemptRequireWithV8CompileCache(requireFn, specifier) { + try { + const v8CC = (__nccwpck_require__(26669).install)(); + try { + return requireFn(specifier); + } + finally { + v8CC === null || v8CC === void 0 ? void 0 : v8CC.uninstall(); + } + } + catch (e) { + return requireFn(specifier); + } } - +exports.attemptRequireWithV8CompileCache = attemptRequireWithV8CompileCache; /** - * Converts to a two-complement value from a value where the sign bit is - * placed in the least significant bit. For example, as decimals: - * 2 (10 binary) becomes 1, 3 (11 binary) becomes -1 - * 4 (100 binary) becomes 2, 5 (101 binary) becomes -2 + * Helper to discover dependencies relative to a user's project, optionally + * falling back to relative to ts-node. This supports global installations of + * ts-node, for example where someone does `#!/usr/bin/env -S ts-node --swc` and + * we need to fallback to a global install of @swc/core + * @internal */ -function fromVLQSigned(aValue) { - var isNegative = (aValue & 1) === 1; - var shifted = aValue >> 1; - return isNegative - ? -shifted - : shifted; +function createProjectLocalResolveHelper(localDirectory) { + return function projectLocalResolveHelper(specifier, fallbackToTsNodeRelative) { + return require.resolve(specifier, { + paths: fallbackToTsNodeRelative + ? [localDirectory, __dirname] + : [localDirectory], + }); + }; } - +exports.createProjectLocalResolveHelper = createProjectLocalResolveHelper; /** - * Returns the base 64 VLQ encoded value. + * Used as a reminder of all the factors we must consider when finding project-local dependencies and when a config file + * on disk may or may not exist. + * @internal */ -exports.encode = function base64VLQ_encode(aValue) { - var encoded = ""; - var digit; - - var vlq = toVLQSigned(aValue); - - do { - digit = vlq & VLQ_BASE_MASK; - vlq >>>= VLQ_BASE_SHIFT; - if (vlq > 0) { - // There are still more digits in this value, so we must make sure the - // continuation bit is marked. - digit |= VLQ_CONTINUATION_BIT; +function getBasePathForProjectLocalDependencyResolution(configFilePath, projectSearchDirOption, projectOption, cwdOption) { + var _a; + if (configFilePath != null) + return (0, path_1.dirname)(configFilePath); + return (_a = projectSearchDirOption !== null && projectSearchDirOption !== void 0 ? projectSearchDirOption : projectOption) !== null && _a !== void 0 ? _a : cwdOption; + // TODO technically breaks if projectOption is path to a file, not a directory, + // and we attempt to resolve relative specifiers. By the time we resolve relative specifiers, + // should have configFilePath, so not reach this codepath. +} +exports.getBasePathForProjectLocalDependencyResolution = getBasePathForProjectLocalDependencyResolution; +/** @internal */ +function once(fn) { + let value; + let ran = false; + function onceFn(...args) { + if (ran) + return value; + value = fn(...args); + ran = true; + return value; } - encoded += base64.encode(digit); - } while (vlq > 0); - - return encoded; -}; - -/** - * Decodes the next base 64 VLQ value from the given string and returns the - * value and the rest of the string via the out parameter. - */ -exports.decode = function base64VLQ_decode(aStr, aIndex, aOutParam) { - var strLen = aStr.length; - var result = 0; - var shift = 0; - var continuation, digit; - - do { - if (aIndex >= strLen) { - throw new Error("Expected more digits in base 64 VLQ value."); + return onceFn; +} +exports.once = once; +/** @internal */ +function versionGteLt(version, gteRequirement, ltRequirement) { + const [major, minor, patch, extra] = parse(version); + const [gteMajor, gteMinor, gtePatch] = parse(gteRequirement); + const isGte = major > gteMajor || + (major === gteMajor && + (minor > gteMinor || (minor === gteMinor && patch >= gtePatch))); + let isLt = true; + if (ltRequirement) { + const [ltMajor, ltMinor, ltPatch] = parse(ltRequirement); + isLt = + major < ltMajor || + (major === ltMajor && + (minor < ltMinor || (minor === ltMinor && patch < ltPatch))); } - - digit = base64.decode(aStr.charCodeAt(aIndex++)); - if (digit === -1) { - throw new Error("Invalid base64 digit: " + aStr.charAt(aIndex - 1)); + return isGte && isLt; + function parse(requirement) { + return requirement.split(/[\.-]/).map((s) => parseInt(s, 10)); } - - continuation = !!(digit & VLQ_CONTINUATION_BIT); - digit &= VLQ_BASE_MASK; - result = result + (digit << shift); - shift += VLQ_BASE_SHIFT; - } while (continuation); - - aOutParam.value = fromVLQSigned(result); - aOutParam.rest = aIndex; -}; - +} +exports.versionGteLt = versionGteLt; +//# sourceMappingURL=util.js.map /***/ }), -/***/ 94521: -/***/ ((__unused_webpack_module, exports) => { - -/* -*- Mode: js; js-indent-level: 2; -*- */ -/* - * Copyright 2011 Mozilla Foundation and contributors - * Licensed under the New BSD license. See LICENSE or: - * http://opensource.org/licenses/BSD-3-Clause - */ - -var intToCharMap = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/'.split(''); - -/** - * Encode an integer in the range of 0 to 63 to a single base 64 digit. - */ -exports.encode = function (number) { - if (0 <= number && number < intToCharMap.length) { - return intToCharMap[number]; - } - throw new TypeError("Must be between 0 and 63: " + number); -}; - -/** - * Decode a single base 64 character code digit to an integer. Returns -1 on - * failure. - */ -exports.decode = function (charCode) { - var bigA = 65; // 'A' - var bigZ = 90; // 'Z' - - var littleA = 97; // 'a' - var littleZ = 122; // 'z' - - var zero = 48; // '0' - var nine = 57; // '9' - - var plus = 43; // '+' - var slash = 47; // '/' - - var littleOffset = 26; - var numberOffset = 52; - - // 0 - 25: ABCDEFGHIJKLMNOPQRSTUVWXYZ - if (bigA <= charCode && charCode <= bigZ) { - return (charCode - bigA); - } - - // 26 - 51: abcdefghijklmnopqrstuvwxyz - if (littleA <= charCode && charCode <= littleZ) { - return (charCode - littleA + littleOffset); - } - - // 52 - 61: 0123456789 - if (zero <= charCode && charCode <= nine) { - return (charCode - zero + numberOffset); - } - - // 62: + - if (charCode == plus) { - return 62; - } - - // 63: / - if (charCode == slash) { - return 63; - } +/***/ 12047: +/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { - // Invalid base64 digit. - return -1; -}; +"use strict"; +Object.defineProperty(exports, "__esModule", ({ value: true })); +exports.configLoader = exports.loadConfig = void 0; +var TsConfigLoader2 = __nccwpck_require__(94009); +var path = __nccwpck_require__(71017); +function loadConfig(cwd) { + if (cwd === void 0) { cwd = process.cwd(); } + return configLoader({ cwd: cwd }); +} +exports.loadConfig = loadConfig; +function configLoader(_a) { + var cwd = _a.cwd, explicitParams = _a.explicitParams, _b = _a.tsConfigLoader, tsConfigLoader = _b === void 0 ? TsConfigLoader2.tsConfigLoader : _b; + if (explicitParams) { + var absoluteBaseUrl = path.isAbsolute(explicitParams.baseUrl) + ? explicitParams.baseUrl + : path.join(cwd, explicitParams.baseUrl); + return { + resultType: "success", + configFileAbsolutePath: "", + baseUrl: explicitParams.baseUrl, + absoluteBaseUrl: absoluteBaseUrl, + paths: explicitParams.paths, + mainFields: explicitParams.mainFields, + addMatchAll: explicitParams.addMatchAll, + }; + } + // Load tsconfig and create path matching function + var loadResult = tsConfigLoader({ + cwd: cwd, + getEnv: function (key) { return process.env[key]; }, + }); + if (!loadResult.tsConfigPath) { + return { + resultType: "failed", + message: "Couldn't find tsconfig.json", + }; + } + return { + resultType: "success", + configFileAbsolutePath: loadResult.tsConfigPath, + baseUrl: loadResult.baseUrl, + absoluteBaseUrl: path.resolve(path.dirname(loadResult.tsConfigPath), loadResult.baseUrl || ""), + paths: loadResult.paths || {}, + addMatchAll: loadResult.baseUrl !== undefined, + }; +} +exports.configLoader = configLoader; +//# sourceMappingURL=config-loader.js.map /***/ }), -/***/ 94351: -/***/ ((__unused_webpack_module, exports) => { - -/* -*- Mode: js; js-indent-level: 2; -*- */ -/* - * Copyright 2011 Mozilla Foundation and contributors - * Licensed under the New BSD license. See LICENSE or: - * http://opensource.org/licenses/BSD-3-Clause - */ - -exports.GREATEST_LOWER_BOUND = 1; -exports.LEAST_UPPER_BOUND = 2; +/***/ 40250: +/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { -/** - * Recursive implementation of binary search. - * - * @param aLow Indices here and lower do not contain the needle. - * @param aHigh Indices here and higher do not contain the needle. - * @param aNeedle The element being searched for. - * @param aHaystack The non-empty array being searched. - * @param aCompare Function which takes two elements and returns -1, 0, or 1. - * @param aBias Either 'binarySearch.GREATEST_LOWER_BOUND' or - * 'binarySearch.LEAST_UPPER_BOUND'. Specifies whether to return the - * closest element that is smaller than or greater than the one we are - * searching for, respectively, if the exact element cannot be found. - */ -function recursiveSearch(aLow, aHigh, aNeedle, aHaystack, aCompare, aBias) { - // This function terminates when one of the following is true: - // - // 1. We find the exact element we are looking for. - // - // 2. We did not find the exact element, but we can return the index of - // the next-closest element. - // - // 3. We did not find the exact element, and there is no next-closest - // element than the one we are searching for, so we return -1. - var mid = Math.floor((aHigh - aLow) / 2) + aLow; - var cmp = aCompare(aNeedle, aHaystack[mid], true); - if (cmp === 0) { - // Found the element we are looking for. - return mid; - } - else if (cmp > 0) { - // Our needle is greater than aHaystack[mid]. - if (aHigh - mid > 1) { - // The element is in the upper half. - return recursiveSearch(mid, aHigh, aNeedle, aHaystack, aCompare, aBias); - } +"use strict"; - // The exact needle element was not found in this haystack. Determine if - // we are in termination case (3) or (2) and return the appropriate thing. - if (aBias == exports.LEAST_UPPER_BOUND) { - return aHigh < aHaystack.length ? aHigh : -1; - } else { - return mid; +Object.defineProperty(exports, "__esModule", ({ value: true })); +exports.removeExtension = exports.fileExistsAsync = exports.readJsonFromDiskAsync = exports.readJsonFromDiskSync = exports.fileExistsSync = void 0; +var fs = __nccwpck_require__(57147); +function fileExistsSync(path) { + // If the file doesn't exist, avoid throwing an exception over the native barrier for every miss + if (!fs.existsSync(path)) { + return false; } - } - else { - // Our needle is less than aHaystack[mid]. - if (mid - aLow > 1) { - // The element is in the lower half. - return recursiveSearch(aLow, mid, aNeedle, aHaystack, aCompare, aBias); + try { + var stats = fs.statSync(path); + return stats.isFile(); } - - // we are in termination case (3) or (2) and return the appropriate thing. - if (aBias == exports.LEAST_UPPER_BOUND) { - return mid; - } else { - return aLow < 0 ? -1 : aLow; + catch (err) { + // If error, assume file did not exist + return false; } - } } - +exports.fileExistsSync = fileExistsSync; /** - * This is an implementation of binary search which will always try and return - * the index of the closest element if there is no exact hit. This is because - * mappings between original and generated line/col pairs are single points, - * and there is an implicit region between each of them, so a miss just means - * that you aren't on the very start of a region. + * Reads package.json from disk * - * @param aNeedle The element you are looking for. - * @param aHaystack The array that is being searched. - * @param aCompare A function which takes the needle and an element in the - * array and returns -1, 0, or 1 depending on whether the needle is less - * than, equal to, or greater than the element, respectively. - * @param aBias Either 'binarySearch.GREATEST_LOWER_BOUND' or - * 'binarySearch.LEAST_UPPER_BOUND'. Specifies whether to return the - * closest element that is smaller than or greater than the one we are - * searching for, respectively, if the exact element cannot be found. - * Defaults to 'binarySearch.GREATEST_LOWER_BOUND'. + * @param file Path to package.json */ -exports.search = function search(aNeedle, aHaystack, aCompare, aBias) { - if (aHaystack.length === 0) { - return -1; - } +// eslint-disable-next-line @typescript-eslint/no-explicit-any +function readJsonFromDiskSync(packageJsonPath) { + if (!fs.existsSync(packageJsonPath)) { + return undefined; + } + // eslint-disable-next-line @typescript-eslint/no-require-imports + return require(packageJsonPath); +} +exports.readJsonFromDiskSync = readJsonFromDiskSync; +function readJsonFromDiskAsync(path, +// eslint-disable-next-line @typescript-eslint/no-explicit-any +callback) { + fs.readFile(path, "utf8", function (err, result) { + // If error, assume file did not exist + if (err || !result) { + return callback(); + } + var json = JSON.parse(result); + return callback(undefined, json); + }); +} +exports.readJsonFromDiskAsync = readJsonFromDiskAsync; +function fileExistsAsync(path2, callback2) { + fs.stat(path2, function (err, stats) { + if (err) { + // If error assume file does not exist + return callback2(undefined, false); + } + callback2(undefined, stats ? stats.isFile() : false); + }); +} +exports.fileExistsAsync = fileExistsAsync; +function removeExtension(path) { + return path.substring(0, path.lastIndexOf(".")) || path; +} +exports.removeExtension = removeExtension; +//# sourceMappingURL=filesystem.js.map - var index = recursiveSearch(-1, aHaystack.length, aNeedle, aHaystack, - aCompare, aBias || exports.GREATEST_LOWER_BOUND); - if (index < 0) { - return -1; - } +/***/ }), - // We have found either the exact element, or the next-closest element than - // the one we are searching for. However, there may be more than one such - // element. Make sure we always return the smallest of these. - while (index - 1 >= 0) { - if (aCompare(aHaystack[index], aHaystack[index - 1], true) !== 0) { - break; - } - --index; - } +/***/ 24961: +/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { - return index; -}; +"use strict"; +Object.defineProperty(exports, "__esModule", ({ value: true })); +exports.loadConfig = exports.register = exports.matchFromAbsolutePathsAsync = exports.createMatchPathAsync = exports.matchFromAbsolutePaths = exports.createMatchPath = void 0; +// register is used from register.js in root dir +var match_path_sync_1 = __nccwpck_require__(48600); +Object.defineProperty(exports, "createMatchPath", ({ enumerable: true, get: function () { return match_path_sync_1.createMatchPath; } })); +Object.defineProperty(exports, "matchFromAbsolutePaths", ({ enumerable: true, get: function () { return match_path_sync_1.matchFromAbsolutePaths; } })); +var match_path_async_1 = __nccwpck_require__(51294); +Object.defineProperty(exports, "createMatchPathAsync", ({ enumerable: true, get: function () { return match_path_async_1.createMatchPathAsync; } })); +Object.defineProperty(exports, "matchFromAbsolutePathsAsync", ({ enumerable: true, get: function () { return match_path_async_1.matchFromAbsolutePathsAsync; } })); +var register_1 = __nccwpck_require__(24186); +Object.defineProperty(exports, "register", ({ enumerable: true, get: function () { return register_1.register; } })); +var config_loader_1 = __nccwpck_require__(12047); +Object.defineProperty(exports, "loadConfig", ({ enumerable: true, get: function () { return config_loader_1.loadConfig; } })); +//# sourceMappingURL=index.js.map /***/ }), -/***/ 31247: +/***/ 68262: /***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { -/* -*- Mode: js; js-indent-level: 2; -*- */ -/* - * Copyright 2014 Mozilla Foundation and contributors - * Licensed under the New BSD license. See LICENSE or: - * http://opensource.org/licenses/BSD-3-Clause - */ - -var util = __nccwpck_require__(16511); +"use strict"; +Object.defineProperty(exports, "__esModule", ({ value: true })); +exports.getAbsoluteMappingEntries = void 0; +var path = __nccwpck_require__(71017); /** - * Determine whether mappingB is after mappingA with respect to generated - * position. + * Converts an absolute baseUrl and paths to an array of absolute mapping entries. + * The array is sorted by longest prefix. + * Having an array with entries allows us to keep a sorting order rather than + * sort by keys each time we use the mappings. + * + * @param absoluteBaseUrl + * @param paths + * @param addMatchAll */ -function generatedPositionAfter(mappingA, mappingB) { - // Optimized for most common case - var lineA = mappingA.generatedLine; - var lineB = mappingB.generatedLine; - var columnA = mappingA.generatedColumn; - var columnB = mappingB.generatedColumn; - return lineB > lineA || lineB == lineA && columnB >= columnA || - util.compareByGeneratedPositionsInflated(mappingA, mappingB) <= 0; +function getAbsoluteMappingEntries(absoluteBaseUrl, paths, addMatchAll) { + // Resolve all paths to absolute form once here, and sort them by + // longest prefix once here, this saves time on each request later. + // We need to put them in an array to preserve the sorting order. + var sortedKeys = sortByLongestPrefix(Object.keys(paths)); + var absolutePaths = []; + for (var _i = 0, sortedKeys_1 = sortedKeys; _i < sortedKeys_1.length; _i++) { + var key = sortedKeys_1[_i]; + absolutePaths.push({ + pattern: key, + paths: paths[key].map(function (pathToResolve) { + return path.resolve(absoluteBaseUrl, pathToResolve); + }), + }); + } + // If there is no match-all path specified in the paths section of tsconfig, then try to match + // all paths relative to baseUrl, this is how typescript works. + if (!paths["*"] && addMatchAll) { + absolutePaths.push({ + pattern: "*", + paths: ["".concat(absoluteBaseUrl.replace(/\/$/, ""), "/*")], + }); + } + return absolutePaths; } - +exports.getAbsoluteMappingEntries = getAbsoluteMappingEntries; /** - * A data structure to provide a sorted view of accumulated mappings in a - * performance conscious manner. It trades a neglibable overhead in general - * case for a large speedup in case of mappings being added in order. + * Sort path patterns. + * If a module name can be matched with multiple patterns then pattern with the longest prefix will be picked. */ -function MappingList() { - this._array = []; - this._sorted = true; - // Serves as infimum - this._last = {generatedLine: -1, generatedColumn: 0}; +function sortByLongestPrefix(arr) { + return arr + .concat() + .sort(function (a, b) { return getPrefixLength(b) - getPrefixLength(a); }); +} +function getPrefixLength(pattern) { + var prefixLength = pattern.indexOf("*"); + return pattern.substr(0, prefixLength).length; } +//# sourceMappingURL=mapping-entry.js.map -/** - * Iterate through internal items. This method takes the same arguments that - * `Array.prototype.forEach` takes. - * - * NOTE: The order of the mappings is NOT guaranteed. - */ -MappingList.prototype.unsortedForEach = - function MappingList_forEach(aCallback, aThisArg) { - this._array.forEach(aCallback, aThisArg); - }; +/***/ }), + +/***/ 51294: +/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { +"use strict"; + +Object.defineProperty(exports, "__esModule", ({ value: true })); +exports.matchFromAbsolutePathsAsync = exports.createMatchPathAsync = void 0; +var path = __nccwpck_require__(71017); +var TryPath = __nccwpck_require__(3998); +var MappingEntry = __nccwpck_require__(68262); +var Filesystem = __nccwpck_require__(40250); /** - * Add the given source mapping. - * - * @param Object aMapping + * See the sync version for docs. */ -MappingList.prototype.add = function MappingList_add(aMapping) { - if (generatedPositionAfter(this._last, aMapping)) { - this._last = aMapping; - this._array.push(aMapping); - } else { - this._sorted = false; - this._array.push(aMapping); - } -}; - +function createMatchPathAsync(absoluteBaseUrl, paths, mainFields, addMatchAll) { + if (mainFields === void 0) { mainFields = ["main"]; } + if (addMatchAll === void 0) { addMatchAll = true; } + var absolutePaths = MappingEntry.getAbsoluteMappingEntries(absoluteBaseUrl, paths, addMatchAll); + return function (requestedModule, readJson, fileExists, extensions, callback) { + return matchFromAbsolutePathsAsync(absolutePaths, requestedModule, readJson, fileExists, extensions, callback, mainFields); + }; +} +exports.createMatchPathAsync = createMatchPathAsync; /** - * Returns the flat, sorted array of mappings. The mappings are sorted by - * generated position. - * - * WARNING: This method returns internal data without copying, for - * performance. The return value must NOT be mutated, and should be treated as - * an immutable borrow. If you want to take ownership, you must make your own - * copy. + * See the sync version for docs. */ -MappingList.prototype.toArray = function MappingList_toArray() { - if (!this._sorted) { - this._array.sort(util.compareByGeneratedPositionsInflated); - this._sorted = true; - } - return this._array; -}; - -exports.H = MappingList; - +function matchFromAbsolutePathsAsync(absolutePathMappings, requestedModule, readJson, fileExists, extensions, callback, mainFields) { + if (readJson === void 0) { readJson = Filesystem.readJsonFromDiskAsync; } + if (fileExists === void 0) { fileExists = Filesystem.fileExistsAsync; } + if (extensions === void 0) { extensions = Object.keys(require.extensions); } + if (mainFields === void 0) { mainFields = ["main"]; } + var tryPaths = TryPath.getPathsToTry(extensions, absolutePathMappings, requestedModule); + if (!tryPaths) { + return callback(); + } + findFirstExistingPath(tryPaths, readJson, fileExists, callback, 0, mainFields); +} +exports.matchFromAbsolutePathsAsync = matchFromAbsolutePathsAsync; +function findFirstExistingMainFieldMappedFile(packageJson, mainFields, packageJsonPath, fileExistsAsync, doneCallback, index) { + if (index === void 0) { index = 0; } + if (index >= mainFields.length) { + return doneCallback(undefined, undefined); + } + var tryNext = function () { + return findFirstExistingMainFieldMappedFile(packageJson, mainFields, packageJsonPath, fileExistsAsync, doneCallback, index + 1); + }; + var mainFieldSelector = mainFields[index]; + var mainFieldMapping = typeof mainFieldSelector === "string" + ? packageJson[mainFieldSelector] + : mainFieldSelector.reduce(function (obj, key) { return obj[key]; }, packageJson); + if (typeof mainFieldMapping !== "string") { + // Skip mappings that are not pointers to replacement files + return tryNext(); + } + var mappedFilePath = path.join(path.dirname(packageJsonPath), mainFieldMapping); + fileExistsAsync(mappedFilePath, function (err, exists) { + if (err) { + return doneCallback(err); + } + if (exists) { + return doneCallback(undefined, mappedFilePath); + } + return tryNext(); + }); +} +// Recursive loop to probe for physical files +function findFirstExistingPath(tryPaths, readJson, fileExists, doneCallback, index, mainFields) { + if (index === void 0) { index = 0; } + if (mainFields === void 0) { mainFields = ["main"]; } + var tryPath = tryPaths[index]; + if (tryPath.type === "file" || + tryPath.type === "extension" || + tryPath.type === "index") { + fileExists(tryPath.path, function (err, exists) { + if (err) { + return doneCallback(err); + } + if (exists) { + return doneCallback(undefined, TryPath.getStrippedPath(tryPath)); + } + if (index === tryPaths.length - 1) { + return doneCallback(); + } + // Continue with the next path + return findFirstExistingPath(tryPaths, readJson, fileExists, doneCallback, index + 1, mainFields); + }); + } + else if (tryPath.type === "package") { + readJson(tryPath.path, function (err, packageJson) { + if (err) { + return doneCallback(err); + } + if (packageJson) { + return findFirstExistingMainFieldMappedFile(packageJson, mainFields, tryPath.path, fileExists, function (mainFieldErr, mainFieldMappedFile) { + if (mainFieldErr) { + return doneCallback(mainFieldErr); + } + if (mainFieldMappedFile) { + return doneCallback(undefined, mainFieldMappedFile); + } + // No field in package json was a valid option. Continue with the next path. + return findFirstExistingPath(tryPaths, readJson, fileExists, doneCallback, index + 1, mainFields); + }); + } + // This is async code, we need to return unconditionally, otherwise the code still falls + // through and keeps recursing. While this might work in general, libraries that use neo-async + // like Webpack will actually not allow you to call the same callback twice. + // + // An example of where this caused issues: + // https://github.com/dividab/tsconfig-paths-webpack-plugin/issues/11 + // + // Continue with the next path + return findFirstExistingPath(tryPaths, readJson, fileExists, doneCallback, index + 1, mainFields); + }); + } + else { + TryPath.exhaustiveTypeException(tryPath.type); + } +} +//# sourceMappingURL=match-path-async.js.map /***/ }), -/***/ 44347: -/***/ ((__unused_webpack_module, exports) => { - -/* -*- Mode: js; js-indent-level: 2; -*- */ -/* - * Copyright 2011 Mozilla Foundation and contributors - * Licensed under the New BSD license. See LICENSE or: - * http://opensource.org/licenses/BSD-3-Clause - */ +/***/ 48600: +/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { -// It turns out that some (most?) JavaScript engines don't self-host -// `Array.prototype.sort`. This makes sense because C++ will likely remain -// faster than JS when doing raw CPU-intensive sorting. However, when using a -// custom comparator function, calling back and forth between the VM's C++ and -// JIT'd JS is rather slow *and* loses JIT type information, resulting in -// worse generated code for the comparator function than would be optimal. In -// fact, when sorting with a comparator, these costs outweigh the benefits of -// sorting in C++. By using our own JS-implemented Quick Sort (below), we get -// a ~3500ms mean speed-up in `bench/bench.html`. +"use strict"; +Object.defineProperty(exports, "__esModule", ({ value: true })); +exports.matchFromAbsolutePaths = exports.createMatchPath = void 0; +var path = __nccwpck_require__(71017); +var Filesystem = __nccwpck_require__(40250); +var MappingEntry = __nccwpck_require__(68262); +var TryPath = __nccwpck_require__(3998); /** - * Swap the elements indexed by `x` and `y` in the array `ary`. + * Creates a function that can resolve paths according to tsconfig paths property. * - * @param {Array} ary - * The array. - * @param {Number} x - * The index of the first item. - * @param {Number} y - * The index of the second item. + * @param absoluteBaseUrl Absolute version of baseUrl as specified in tsconfig. + * @param paths The paths as specified in tsconfig. + * @param mainFields A list of package.json field names to try when resolving module files. Select a nested field using an array of field names. + * @param addMatchAll Add a match-all "*" rule if none is present + * @returns a function that can resolve paths. */ -function swap(ary, x, y) { - var temp = ary[x]; - ary[x] = ary[y]; - ary[y] = temp; +function createMatchPath(absoluteBaseUrl, paths, mainFields, addMatchAll) { + if (mainFields === void 0) { mainFields = ["main"]; } + if (addMatchAll === void 0) { addMatchAll = true; } + var absolutePaths = MappingEntry.getAbsoluteMappingEntries(absoluteBaseUrl, paths, addMatchAll); + return function (requestedModule, readJson, fileExists, extensions) { + return matchFromAbsolutePaths(absolutePaths, requestedModule, readJson, fileExists, extensions, mainFields); + }; } - +exports.createMatchPath = createMatchPath; /** - * Returns a random integer within the range `low .. high` inclusive. + * Finds a path from tsconfig that matches a module load request. * - * @param {Number} low - * The lower bound on the range. - * @param {Number} high - * The upper bound on the range. + * @param absolutePathMappings The paths to try as specified in tsconfig but resolved to absolute form. + * @param requestedModule The required module name. + * @param readJson Function that can read json from a path (useful for testing). + * @param fileExists Function that checks for existence of a file at a path (useful for testing). + * @param extensions File extensions to probe for (useful for testing). + * @param mainFields A list of package.json field names to try when resolving module files. Select a nested field using an array of field names. + * @returns the found path, or undefined if no path was found. */ -function randomIntInRange(low, high) { - return Math.round(low + (Math.random() * (high - low))); +function matchFromAbsolutePaths(absolutePathMappings, requestedModule, readJson, fileExists, extensions, mainFields) { + if (readJson === void 0) { readJson = Filesystem.readJsonFromDiskSync; } + if (fileExists === void 0) { fileExists = Filesystem.fileExistsSync; } + if (extensions === void 0) { extensions = Object.keys(require.extensions); } + if (mainFields === void 0) { mainFields = ["main"]; } + var tryPaths = TryPath.getPathsToTry(extensions, absolutePathMappings, requestedModule); + if (!tryPaths) { + return undefined; + } + return findFirstExistingPath(tryPaths, readJson, fileExists, mainFields); } - -/** - * The Quick Sort algorithm. - * - * @param {Array} ary - * An array to sort. - * @param {function} comparator - * Function to use to compare two items. - * @param {Number} p - * Start index of the array - * @param {Number} r - * End index of the array - */ -function doQuickSort(ary, comparator, p, r) { - // If our lower bound is less than our upper bound, we (1) partition the - // array into two pieces and (2) recurse on each half. If it is not, this is - // the empty array and our base case. - - if (p < r) { - // (1) Partitioning. - // - // The partitioning chooses a pivot between `p` and `r` and moves all - // elements that are less than or equal to the pivot to the before it, and - // all the elements that are greater than it after it. The effect is that - // once partition is done, the pivot is in the exact place it will be when - // the array is put in sorted order, and it will not need to be moved - // again. This runs in O(n) time. - - // Always choose a random pivot so that an input array which is reverse - // sorted does not cause O(n^2) running time. - var pivotIndex = randomIntInRange(p, r); - var i = p - 1; - - swap(ary, pivotIndex, r); - var pivot = ary[r]; - - // Immediately after `j` is incremented in this loop, the following hold - // true: - // - // * Every element in `ary[p .. i]` is less than or equal to the pivot. - // - // * Every element in `ary[i+1 .. j-1]` is greater than the pivot. - for (var j = p; j < r; j++) { - if (comparator(ary[j], pivot) <= 0) { - i += 1; - swap(ary, i, j); - } +exports.matchFromAbsolutePaths = matchFromAbsolutePaths; +function findFirstExistingMainFieldMappedFile(packageJson, mainFields, packageJsonPath, fileExists) { + for (var index = 0; index < mainFields.length; index++) { + var mainFieldSelector = mainFields[index]; + var candidateMapping = typeof mainFieldSelector === "string" + ? packageJson[mainFieldSelector] + : mainFieldSelector.reduce(function (obj, key) { return obj[key]; }, packageJson); + if (candidateMapping && typeof candidateMapping === "string") { + var candidateFilePath = path.join(path.dirname(packageJsonPath), candidateMapping); + if (fileExists(candidateFilePath)) { + return candidateFilePath; + } + } } - - swap(ary, i + 1, j); - var q = i + 1; - - // (2) Recurse on each half. - - doQuickSort(ary, comparator, p, q - 1); - doQuickSort(ary, comparator, q + 1, r); - } + return undefined; } - -/** - * Sort the given array in-place with the given comparator function. - * - * @param {Array} ary - * An array to sort. - * @param {function} comparator - * Function to use to compare two items. - */ -exports.U = function (ary, comparator) { - doQuickSort(ary, comparator, 0, ary.length - 1); -}; - +function findFirstExistingPath(tryPaths, readJson, fileExists, mainFields) { + if (readJson === void 0) { readJson = Filesystem.readJsonFromDiskSync; } + if (mainFields === void 0) { mainFields = ["main"]; } + for (var _i = 0, tryPaths_1 = tryPaths; _i < tryPaths_1.length; _i++) { + var tryPath = tryPaths_1[_i]; + if (tryPath.type === "file" || + tryPath.type === "extension" || + tryPath.type === "index") { + if (fileExists(tryPath.path)) { + return TryPath.getStrippedPath(tryPath); + } + } + else if (tryPath.type === "package") { + var packageJson = readJson(tryPath.path); + if (packageJson) { + var mainFieldMappedFile = findFirstExistingMainFieldMappedFile(packageJson, mainFields, tryPath.path, fileExists); + if (mainFieldMappedFile) { + return mainFieldMappedFile; + } + } + } + else { + TryPath.exhaustiveTypeException(tryPath.type); + } + } + return undefined; +} +//# sourceMappingURL=match-path-sync.js.map /***/ }), -/***/ 52718: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { - -var __webpack_unused_export__; -/* -*- Mode: js; js-indent-level: 2; -*- */ -/* - * Copyright 2011 Mozilla Foundation and contributors - * Licensed under the New BSD license. See LICENSE or: - * http://opensource.org/licenses/BSD-3-Clause - */ - -var util = __nccwpck_require__(16511); -var binarySearch = __nccwpck_require__(94351); -var ArraySet = (__nccwpck_require__(30176)/* .ArraySet */ .I); -var base64VLQ = __nccwpck_require__(14590); -var quickSort = (__nccwpck_require__(44347)/* .quickSort */ .U); - -function SourceMapConsumer(aSourceMap, aSourceMapURL) { - var sourceMap = aSourceMap; - if (typeof aSourceMap === 'string') { - sourceMap = util.parseSourceMapInput(aSourceMap); - } +/***/ 24186: +/***/ (function(__unused_webpack_module, exports, __nccwpck_require__) { - return sourceMap.sections != null - ? new IndexedSourceMapConsumer(sourceMap, aSourceMapURL) - : new BasicSourceMapConsumer(sourceMap, aSourceMapURL); -} +"use strict"; -SourceMapConsumer.fromSourceMap = function(aSourceMap, aSourceMapURL) { - return BasicSourceMapConsumer.fromSourceMap(aSourceMap, aSourceMapURL); +var __spreadArray = (this && this.__spreadArray) || function (to, from, pack) { + if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) { + if (ar || !(i in from)) { + if (!ar) ar = Array.prototype.slice.call(from, 0, i); + ar[i] = from[i]; + } + } + return to.concat(ar || Array.prototype.slice.call(from)); +}; +Object.defineProperty(exports, "__esModule", ({ value: true })); +exports.register = void 0; +var match_path_sync_1 = __nccwpck_require__(48600); +var config_loader_1 = __nccwpck_require__(12047); +var noOp = function () { return void 0; }; +function getCoreModules(builtinModules) { + builtinModules = builtinModules || [ + "assert", + "buffer", + "child_process", + "cluster", + "crypto", + "dgram", + "dns", + "domain", + "events", + "fs", + "http", + "https", + "net", + "os", + "path", + "punycode", + "querystring", + "readline", + "stream", + "string_decoder", + "tls", + "tty", + "url", + "util", + "v8", + "vm", + "zlib", + ]; + var coreModules = {}; + for (var _i = 0, builtinModules_1 = builtinModules; _i < builtinModules_1.length; _i++) { + var module_1 = builtinModules_1[_i]; + coreModules[module_1] = true; + } + return coreModules; } - /** - * The version of the source mapping spec that we are consuming. + * Installs a custom module load function that can adhere to paths in tsconfig. + * Returns a function to undo paths registration. */ -SourceMapConsumer.prototype._version = 3; - -// `__generatedMappings` and `__originalMappings` are arrays that hold the -// parsed mapping coordinates from the source map's "mappings" attribute. They -// are lazily instantiated, accessed via the `_generatedMappings` and -// `_originalMappings` getters respectively, and we only parse the mappings -// and create these arrays once queried for a source location. We jump through -// these hoops because there can be many thousands of mappings, and parsing -// them is expensive, so we only want to do it if we must. -// -// Each object in the arrays is of the form: -// -// { -// generatedLine: The line number in the generated code, -// generatedColumn: The column number in the generated code, -// source: The path to the original source file that generated this -// chunk of code, -// originalLine: The line number in the original source that -// corresponds to this chunk of generated code, -// originalColumn: The column number in the original source that -// corresponds to this chunk of generated code, -// name: The name of the original symbol which generated this chunk of -// code. -// } -// -// All properties except for `generatedLine` and `generatedColumn` can be -// `null`. -// -// `_generatedMappings` is ordered by the generated positions. -// -// `_originalMappings` is ordered by the original positions. - -SourceMapConsumer.prototype.__generatedMappings = null; -Object.defineProperty(SourceMapConsumer.prototype, '_generatedMappings', { - configurable: true, - enumerable: true, - get: function () { - if (!this.__generatedMappings) { - this._parseMappings(this._mappings, this.sourceRoot); +function register(params) { + var cwd; + var explicitParams; + if (params) { + cwd = params.cwd; + if (params.baseUrl || params.paths) { + explicitParams = params; + } } - - return this.__generatedMappings; - } -}); - -SourceMapConsumer.prototype.__originalMappings = null; -Object.defineProperty(SourceMapConsumer.prototype, '_originalMappings', { - configurable: true, - enumerable: true, - get: function () { - if (!this.__originalMappings) { - this._parseMappings(this._mappings, this.sourceRoot); + else { + // eslint-disable-next-line + var minimist = __nccwpck_require__(40311); + var argv = minimist(process.argv.slice(2), { + // eslint-disable-next-line id-denylist + string: ["project"], + alias: { + project: ["P"], + }, + }); + cwd = argv.project; } + var configLoaderResult = (0, config_loader_1.configLoader)({ + cwd: cwd !== null && cwd !== void 0 ? cwd : process.cwd(), + explicitParams: explicitParams, + }); + if (configLoaderResult.resultType === "failed") { + console.warn("".concat(configLoaderResult.message, ". tsconfig-paths will be skipped")); + return noOp; + } + var matchPath = (0, match_path_sync_1.createMatchPath)(configLoaderResult.absoluteBaseUrl, configLoaderResult.paths, configLoaderResult.mainFields, configLoaderResult.addMatchAll); + // Patch node's module loading + // eslint-disable-next-line @typescript-eslint/no-require-imports,@typescript-eslint/no-var-requires + var Module = __nccwpck_require__(98188); + // eslint-disable-next-line no-underscore-dangle + var originalResolveFilename = Module._resolveFilename; + var coreModules = getCoreModules(Module.builtinModules); + // eslint-disable-next-line @typescript-eslint/no-explicit-any,no-underscore-dangle + Module._resolveFilename = function (request, _parent) { + var isCoreModule = coreModules.hasOwnProperty(request); + if (!isCoreModule) { + var found = matchPath(request); + if (found) { + var modifiedArguments = __spreadArray([found], [].slice.call(arguments, 1), true); // Passes all arguments. Even those that is not specified above. + return originalResolveFilename.apply(this, modifiedArguments); + } + } + return originalResolveFilename.apply(this, arguments); + }; + return function () { + // Return node's module loading to original state. + // eslint-disable-next-line no-underscore-dangle + Module._resolveFilename = originalResolveFilename; + }; +} +exports.register = register; +//# sourceMappingURL=register.js.map - return this.__originalMappings; - } -}); - -SourceMapConsumer.prototype._charIsMappingSeparator = - function SourceMapConsumer_charIsMappingSeparator(aStr, index) { - var c = aStr.charAt(index); - return c === ";" || c === ","; - }; - -/** - * Parse the mappings in a string in to a data structure which we can easily - * query (the ordered arrays in the `this.__generatedMappings` and - * `this.__originalMappings` properties). - */ -SourceMapConsumer.prototype._parseMappings = - function SourceMapConsumer_parseMappings(aStr, aSourceRoot) { - throw new Error("Subclasses must implement _parseMappings"); - }; +/***/ }), -SourceMapConsumer.GENERATED_ORDER = 1; -SourceMapConsumer.ORIGINAL_ORDER = 2; +/***/ 3998: +/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { -SourceMapConsumer.GREATEST_LOWER_BOUND = 1; -SourceMapConsumer.LEAST_UPPER_BOUND = 2; +"use strict"; +Object.defineProperty(exports, "__esModule", ({ value: true })); +exports.exhaustiveTypeException = exports.getStrippedPath = exports.getPathsToTry = void 0; +var path = __nccwpck_require__(71017); +var path_1 = __nccwpck_require__(71017); +var filesystem_1 = __nccwpck_require__(40250); /** - * Iterate over each mapping between an original source/line/column and a - * generated line/column in this source map. - * - * @param Function aCallback - * The function that is called with each mapping. - * @param Object aContext - * Optional. If specified, this object will be the value of `this` every - * time that `aCallback` is called. - * @param aOrder - * Either `SourceMapConsumer.GENERATED_ORDER` or - * `SourceMapConsumer.ORIGINAL_ORDER`. Specifies whether you want to - * iterate over the mappings sorted by the generated file's line/column - * order or the original's source/line/column order, respectively. Defaults to - * `SourceMapConsumer.GENERATED_ORDER`. + * Builds a list of all physical paths to try by: + * 1. Check for file named exactly as request. + * 2. Check for files named as request ending in any of the extensions. + * 3. Check for file specified in package.json's main property. + * 4. Check for files named as request ending in "index" with any of the extensions. */ -SourceMapConsumer.prototype.eachMapping = - function SourceMapConsumer_eachMapping(aCallback, aContext, aOrder) { - var context = aContext || null; - var order = aOrder || SourceMapConsumer.GENERATED_ORDER; - - var mappings; - switch (order) { - case SourceMapConsumer.GENERATED_ORDER: - mappings = this._generatedMappings; - break; - case SourceMapConsumer.ORIGINAL_ORDER: - mappings = this._originalMappings; - break; - default: - throw new Error("Unknown order of iteration."); +function getPathsToTry(extensions, absolutePathMappings, requestedModule) { + if (!absolutePathMappings || !requestedModule || requestedModule[0] === ".") { + return undefined; } - - var sourceRoot = this.sourceRoot; - mappings.map(function (mapping) { - var source = mapping.source === null ? null : this._sources.at(mapping.source); - source = util.computeSourceURL(sourceRoot, source, this._sourceMapURL); - return { - source: source, - generatedLine: mapping.generatedLine, - generatedColumn: mapping.generatedColumn, - originalLine: mapping.originalLine, - originalColumn: mapping.originalColumn, - name: mapping.name === null ? null : this._names.at(mapping.name) - }; - }, this).forEach(aCallback, context); - }; - + var pathsToTry = []; + for (var _i = 0, absolutePathMappings_1 = absolutePathMappings; _i < absolutePathMappings_1.length; _i++) { + var entry = absolutePathMappings_1[_i]; + var starMatch = entry.pattern === requestedModule + ? "" + : matchStar(entry.pattern, requestedModule); + if (starMatch !== undefined) { + var _loop_1 = function (physicalPathPattern) { + var physicalPath = physicalPathPattern.replace("*", starMatch); + pathsToTry.push({ type: "file", path: physicalPath }); + pathsToTry.push.apply(pathsToTry, extensions.map(function (e) { return ({ type: "extension", path: physicalPath + e }); })); + pathsToTry.push({ + type: "package", + path: path.join(physicalPath, "/package.json"), + }); + var indexPath = path.join(physicalPath, "/index"); + pathsToTry.push.apply(pathsToTry, extensions.map(function (e) { return ({ type: "index", path: indexPath + e }); })); + }; + for (var _a = 0, _b = entry.paths; _a < _b.length; _a++) { + var physicalPathPattern = _b[_a]; + _loop_1(physicalPathPattern); + } + } + } + return pathsToTry.length === 0 ? undefined : pathsToTry; +} +exports.getPathsToTry = getPathsToTry; +// Not sure why we don't just return the full found path? +function getStrippedPath(tryPath) { + return tryPath.type === "index" + ? (0, path_1.dirname)(tryPath.path) + : tryPath.type === "file" + ? tryPath.path + : tryPath.type === "extension" + ? (0, filesystem_1.removeExtension)(tryPath.path) + : tryPath.type === "package" + ? tryPath.path + : exhaustiveTypeException(tryPath.type); +} +exports.getStrippedPath = getStrippedPath; +function exhaustiveTypeException(check) { + throw new Error("Unknown type ".concat(check)); +} +exports.exhaustiveTypeException = exhaustiveTypeException; /** - * Returns all generated line and column information for the original source, - * line, and column provided. If no column is provided, returns all mappings - * corresponding to a either the line we are searching for or the next - * closest line that has any mappings. Otherwise, returns all mappings - * corresponding to the given line and either the column we are searching for - * or the next closest column that has any offsets. - * - * The only argument is an object with the following properties: - * - * - source: The filename of the original source. - * - line: The line number in the original source. The line number is 1-based. - * - column: Optional. the column number in the original source. - * The column number is 0-based. - * - * and an array of objects is returned, each with the following properties: + * Matches pattern with a single star against search. + * Star must match at least one character to be considered a match. * - * - line: The line number in the generated source, or null. The - * line number is 1-based. - * - column: The column number in the generated source, or null. - * The column number is 0-based. + * @param patttern for example "foo*" + * @param search for example "fooawesomebar" + * @returns the part of search that * matches, or undefined if no match. */ -SourceMapConsumer.prototype.allGeneratedPositionsFor = - function SourceMapConsumer_allGeneratedPositionsFor(aArgs) { - var line = util.getArg(aArgs, 'line'); - - // When there is no exact match, BasicSourceMapConsumer.prototype._findMapping - // returns the index of the closest mapping less than the needle. By - // setting needle.originalColumn to 0, we thus find the last mapping for - // the given line, provided such a mapping exists. - var needle = { - source: util.getArg(aArgs, 'source'), - originalLine: line, - originalColumn: util.getArg(aArgs, 'column', 0) - }; - - needle.source = this._findSourceIndex(needle.source); - if (needle.source < 0) { - return []; +function matchStar(pattern, search) { + if (search.length < pattern.length) { + return undefined; } + if (pattern === "*") { + return search; + } + var star = pattern.indexOf("*"); + if (star === -1) { + return undefined; + } + var part1 = pattern.substring(0, star); + var part2 = pattern.substring(star + 1); + if (search.substr(0, star) !== part1) { + return undefined; + } + if (search.substr(search.length - part2.length) !== part2) { + return undefined; + } + return search.substr(star, search.length - part2.length); +} +//# sourceMappingURL=try-path.js.map - var mappings = []; - - var index = this._findMapping(needle, - this._originalMappings, - "originalLine", - "originalColumn", - util.compareByOriginalPositions, - binarySearch.LEAST_UPPER_BOUND); - if (index >= 0) { - var mapping = this._originalMappings[index]; +/***/ }), - if (aArgs.column === undefined) { - var originalLine = mapping.originalLine; +/***/ 94009: +/***/ (function(__unused_webpack_module, exports, __nccwpck_require__) { - // Iterate until either we run out of mappings, or we run into - // a mapping for a different line than the one we found. Since - // mappings are sorted, this is guaranteed to find all mappings for - // the line we found. - while (mapping && mapping.originalLine === originalLine) { - mappings.push({ - line: util.getArg(mapping, 'generatedLine', null), - column: util.getArg(mapping, 'generatedColumn', null), - lastColumn: util.getArg(mapping, 'lastGeneratedColumn', null) - }); +"use strict"; - mapping = this._originalMappings[++index]; +var __assign = (this && this.__assign) || function () { + __assign = Object.assign || function(t) { + for (var s, i = 1, n = arguments.length; i < n; i++) { + s = arguments[i]; + for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) + t[p] = s[p]; } - } else { - var originalColumn = mapping.originalColumn; - - // Iterate until either we run out of mappings, or we run into - // a mapping for a different line than the one we were searching for. - // Since mappings are sorted, this is guaranteed to find all mappings for - // the line we are searching for. - while (mapping && - mapping.originalLine === line && - mapping.originalColumn == originalColumn) { - mappings.push({ - line: util.getArg(mapping, 'generatedLine', null), - column: util.getArg(mapping, 'generatedColumn', null), - lastColumn: util.getArg(mapping, 'lastGeneratedColumn', null) - }); - - mapping = this._originalMappings[++index]; + return t; + }; + return __assign.apply(this, arguments); +}; +Object.defineProperty(exports, "__esModule", ({ value: true })); +exports.loadTsconfig = exports.walkForTsConfig = exports.tsConfigLoader = void 0; +var path = __nccwpck_require__(71017); +var fs = __nccwpck_require__(57147); +// eslint-disable-next-line @typescript-eslint/no-require-imports +var JSON5 = __nccwpck_require__(29941); +// eslint-disable-next-line @typescript-eslint/no-require-imports +var StripBom = __nccwpck_require__(65891); +function tsConfigLoader(_a) { + var getEnv = _a.getEnv, cwd = _a.cwd, _b = _a.loadSync, loadSync = _b === void 0 ? loadSyncDefault : _b; + var TS_NODE_PROJECT = getEnv("TS_NODE_PROJECT"); + var TS_NODE_BASEURL = getEnv("TS_NODE_BASEURL"); + // tsconfig.loadSync handles if TS_NODE_PROJECT is a file or directory + // and also overrides baseURL if TS_NODE_BASEURL is available. + var loadResult = loadSync(cwd, TS_NODE_PROJECT, TS_NODE_BASEURL); + return loadResult; +} +exports.tsConfigLoader = tsConfigLoader; +function loadSyncDefault(cwd, filename, baseUrl) { + // Tsconfig.loadSync uses path.resolve. This is why we can use an absolute path as filename + var configPath = resolveConfigPath(cwd, filename); + if (!configPath) { + return { + tsConfigPath: undefined, + baseUrl: undefined, + paths: undefined, + }; + } + var config = loadTsconfig(configPath); + return { + tsConfigPath: configPath, + baseUrl: baseUrl || + (config && config.compilerOptions && config.compilerOptions.baseUrl), + paths: config && config.compilerOptions && config.compilerOptions.paths, + }; +} +function resolveConfigPath(cwd, filename) { + if (filename) { + var absolutePath = fs.lstatSync(filename).isDirectory() + ? path.resolve(filename, "./tsconfig.json") + : path.resolve(cwd, filename); + return absolutePath; + } + if (fs.statSync(cwd).isFile()) { + return path.resolve(cwd); + } + var configAbsolutePath = walkForTsConfig(cwd); + return configAbsolutePath ? path.resolve(configAbsolutePath) : undefined; +} +function walkForTsConfig(directory, readdirSync) { + if (readdirSync === void 0) { readdirSync = fs.readdirSync; } + var files = readdirSync(directory); + var filesToCheck = ["tsconfig.json", "jsconfig.json"]; + for (var _i = 0, filesToCheck_1 = filesToCheck; _i < filesToCheck_1.length; _i++) { + var fileToCheck = filesToCheck_1[_i]; + if (files.indexOf(fileToCheck) !== -1) { + return path.join(directory, fileToCheck); } - } } + var parentDirectory = path.dirname(directory); + // If we reached the top + if (directory === parentDirectory) { + return undefined; + } + return walkForTsConfig(parentDirectory, readdirSync); +} +exports.walkForTsConfig = walkForTsConfig; +function loadTsconfig(configFilePath, +// eslint-disable-next-line no-shadow +existsSync, readFileSync) { + if (existsSync === void 0) { existsSync = fs.existsSync; } + if (readFileSync === void 0) { readFileSync = function (filename) { + return fs.readFileSync(filename, "utf8"); + }; } + if (!existsSync(configFilePath)) { + return undefined; + } + var configString = readFileSync(configFilePath); + var cleanedJson = StripBom(configString); + var config; + try { + config = JSON5.parse(cleanedJson); + } + catch (e) { + throw new Error("".concat(configFilePath, " is malformed ").concat(e.message)); + } + var extendedConfig = config.extends; + if (extendedConfig) { + if (typeof extendedConfig === "string" && + extendedConfig.indexOf(".json") === -1) { + extendedConfig += ".json"; + } + var currentDir = path.dirname(configFilePath); + var extendedConfigPath = path.join(currentDir, extendedConfig); + if (extendedConfig.indexOf("/") !== -1 && + extendedConfig.indexOf(".") !== -1 && + !existsSync(extendedConfigPath)) { + extendedConfigPath = path.join(currentDir, "node_modules", extendedConfig); + } + var base = loadTsconfig(extendedConfigPath, existsSync, readFileSync) || {}; + // baseUrl should be interpreted as relative to the base tsconfig, + // but we need to update it so it is relative to the original tsconfig being loaded + if (base.compilerOptions && base.compilerOptions.baseUrl) { + var extendsDir = path.dirname(extendedConfig); + base.compilerOptions.baseUrl = path.join(extendsDir, base.compilerOptions.baseUrl); + } + return __assign(__assign(__assign({}, base), config), { compilerOptions: __assign(__assign({}, base.compilerOptions), config.compilerOptions) }); + } + return config; +} +exports.loadTsconfig = loadTsconfig; +//# sourceMappingURL=tsconfig-loader.js.map - return mappings; - }; - -exports.SourceMapConsumer = SourceMapConsumer; - -/** - * A BasicSourceMapConsumer instance represents a parsed source map which we can - * query for information about the original file positions by giving it a file - * position in the generated source. - * - * The first parameter is the raw source map (either as a JSON string, or - * already parsed to an object). According to the spec, source maps have the - * following attributes: - * - * - version: Which version of the source map spec this map is following. - * - sources: An array of URLs to the original source files. - * - names: An array of identifiers which can be referrenced by individual mappings. - * - sourceRoot: Optional. The URL root from which all sources are relative. - * - sourcesContent: Optional. An array of contents of the original source files. - * - mappings: A string of base64 VLQs which contain the actual mappings. - * - file: Optional. The generated file this source map is associated with. - * - * Here is an example source map, taken from the source map spec[0]: - * - * { - * version : 3, - * file: "out.js", - * sourceRoot : "", - * sources: ["foo.js", "bar.js"], - * names: ["src", "maps", "are", "fun"], - * mappings: "AA,AB;;ABCDE;" - * } - * - * The second parameter, if given, is a string whose value is the URL - * at which the source map was found. This URL is used to compute the - * sources array. - * - * [0]: https://docs.google.com/document/d/1U1RGAehQwRypUTovF1KRlpiOFze0b-_2gc6fAH0KY0k/edit?pli=1# - */ -function BasicSourceMapConsumer(aSourceMap, aSourceMapURL) { - var sourceMap = aSourceMap; - if (typeof aSourceMap === 'string') { - sourceMap = util.parseSourceMapInput(aSourceMap); - } +/***/ }), - var version = util.getArg(sourceMap, 'version'); - var sources = util.getArg(sourceMap, 'sources'); - // Sass 3.3 leaves out the 'names' array, so we deviate from the spec (which - // requires the array) to play nice here. - var names = util.getArg(sourceMap, 'names', []); - var sourceRoot = util.getArg(sourceMap, 'sourceRoot', null); - var sourcesContent = util.getArg(sourceMap, 'sourcesContent', null); - var mappings = util.getArg(sourceMap, 'mappings'); - var file = util.getArg(sourceMap, 'file', null); +/***/ 65891: +/***/ ((module) => { - // Once again, Sass deviates from the spec and supplies the version as a - // string rather than a number, so we use loose equality checking here. - if (version != this._version) { - throw new Error('Unsupported version: ' + version); - } +"use strict"; - if (sourceRoot) { - sourceRoot = util.normalize(sourceRoot); - } +module.exports = x => { + if (typeof x !== 'string') { + throw new TypeError('Expected a string, got ' + typeof x); + } - sources = sources - .map(String) - // Some source maps produce relative source paths like "./foo.js" instead of - // "foo.js". Normalize these first so that future comparisons will succeed. - // See bugzil.la/1090768. - .map(util.normalize) - // Always ensure that absolute sources are internally stored relative to - // the source root, if the source root is absolute. Not doing this would - // be particularly problematic when the source root is a prefix of the - // source (valid, but why??). See github issue #199 and bugzil.la/1188982. - .map(function (source) { - return sourceRoot && util.isAbsolute(sourceRoot) && util.isAbsolute(source) - ? util.relative(sourceRoot, source) - : source; - }); + // Catches EFBBBF (UTF-8 BOM) because the buffer-to-string + // conversion translates it to FEFF (UTF-16 BOM) + if (x.charCodeAt(0) === 0xFEFF) { + return x.slice(1); + } - // Pass `true` below to allow duplicate names and sources. While source maps - // are intended to be compressed and deduplicated, the TypeScript compiler - // sometimes generates source maps with duplicates in them. See Github issue - // #72 and bugzil.la/889492. - this._names = ArraySet.fromArray(names.map(String), true); - this._sources = ArraySet.fromArray(sources, true); + return x; +}; - this._absoluteSources = this._sources.toArray().map(function (s) { - return util.computeSourceURL(sourceRoot, s, aSourceMapURL); - }); - this.sourceRoot = sourceRoot; - this.sourcesContent = sourcesContent; - this._mappings = mappings; - this._sourceMapURL = aSourceMapURL; - this.file = file; -} +/***/ }), -BasicSourceMapConsumer.prototype = Object.create(SourceMapConsumer.prototype); -BasicSourceMapConsumer.prototype.consumer = SourceMapConsumer; +/***/ 41464: +/***/ ((module) => { -/** - * Utility function to find the index of a source. Returns -1 if not - * found. - */ -BasicSourceMapConsumer.prototype._findSourceIndex = function(aSource) { - var relativeSource = aSource; - if (this.sourceRoot != null) { - relativeSource = util.relative(this.sourceRoot, relativeSource); - } +/****************************************************************************** +Copyright (c) Microsoft Corporation. - if (this._sources.has(relativeSource)) { - return this._sources.indexOf(relativeSource); - } +Permission to use, copy, modify, and/or distribute this software for any +purpose with or without fee is hereby granted. - // Maybe aSource is an absolute URL as returned by |sources|. In - // this case we can't simply undo the transform. - var i; - for (i = 0; i < this._absoluteSources.length; ++i) { - if (this._absoluteSources[i] == aSource) { - return i; +THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH +REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY +AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, +INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM +LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR +OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR +PERFORMANCE OF THIS SOFTWARE. +***************************************************************************** */ +/* global global, define, Symbol, Reflect, Promise, SuppressedError */ +var __extends; +var __assign; +var __rest; +var __decorate; +var __param; +var __esDecorate; +var __runInitializers; +var __propKey; +var __setFunctionName; +var __metadata; +var __awaiter; +var __generator; +var __exportStar; +var __values; +var __read; +var __spread; +var __spreadArrays; +var __spreadArray; +var __await; +var __asyncGenerator; +var __asyncDelegator; +var __asyncValues; +var __makeTemplateObject; +var __importStar; +var __importDefault; +var __classPrivateFieldGet; +var __classPrivateFieldSet; +var __classPrivateFieldIn; +var __createBinding; +var __addDisposableResource; +var __disposeResources; +(function (factory) { + var root = typeof global === "object" ? global : typeof self === "object" ? self : typeof this === "object" ? this : {}; + if (typeof define === "function" && define.amd) { + define("tslib", ["exports"], function (exports) { factory(createExporter(root, createExporter(exports))); }); } - } - - return -1; -}; - -/** - * Create a BasicSourceMapConsumer from a SourceMapGenerator. - * - * @param SourceMapGenerator aSourceMap - * The source map that will be consumed. - * @param String aSourceMapURL - * The URL at which the source map can be found (optional) - * @returns BasicSourceMapConsumer - */ -BasicSourceMapConsumer.fromSourceMap = - function SourceMapConsumer_fromSourceMap(aSourceMap, aSourceMapURL) { - var smc = Object.create(BasicSourceMapConsumer.prototype); + else if ( true && typeof module.exports === "object") { + factory(createExporter(root, createExporter(module.exports))); + } + else { + factory(createExporter(root)); + } + function createExporter(exports, previous) { + if (exports !== root) { + if (typeof Object.create === "function") { + Object.defineProperty(exports, "__esModule", { value: true }); + } + else { + exports.__esModule = true; + } + } + return function (id, v) { return exports[id] = previous ? previous(id, v) : v; }; + } +}) +(function (exporter) { + var extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; }; - var names = smc._names = ArraySet.fromArray(aSourceMap._names.toArray(), true); - var sources = smc._sources = ArraySet.fromArray(aSourceMap._sources.toArray(), true); - smc.sourceRoot = aSourceMap._sourceRoot; - smc.sourcesContent = aSourceMap._generateSourcesContent(smc._sources.toArray(), - smc.sourceRoot); - smc.file = aSourceMap._file; - smc._sourceMapURL = aSourceMapURL; - smc._absoluteSources = smc._sources.toArray().map(function (s) { - return util.computeSourceURL(smc.sourceRoot, s, aSourceMapURL); - }); + __extends = function (d, b) { + if (typeof b !== "function" && b !== null) + throw new TypeError("Class extends value " + String(b) + " is not a constructor or null"); + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + }; - // Because we are modifying the entries (by converting string sources and - // names to indices into the sources and names ArraySets), we have to make - // a copy of the entry or else bad things happen. Shared mutable state - // strikes again! See github issue #191. + __assign = Object.assign || function (t) { + for (var s, i = 1, n = arguments.length; i < n; i++) { + s = arguments[i]; + for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p]; + } + return t; + }; - var generatedMappings = aSourceMap._mappings.toArray().slice(); - var destGeneratedMappings = smc.__generatedMappings = []; - var destOriginalMappings = smc.__originalMappings = []; + __rest = function (s, e) { + var t = {}; + for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0) + t[p] = s[p]; + if (s != null && typeof Object.getOwnPropertySymbols === "function") + for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) { + if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i])) + t[p[i]] = s[p[i]]; + } + return t; + }; - for (var i = 0, length = generatedMappings.length; i < length; i++) { - var srcMapping = generatedMappings[i]; - var destMapping = new Mapping; - destMapping.generatedLine = srcMapping.generatedLine; - destMapping.generatedColumn = srcMapping.generatedColumn; + __decorate = function (decorators, target, key, desc) { + var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; + if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); + else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; + return c > 3 && r && Object.defineProperty(target, key, r), r; + }; - if (srcMapping.source) { - destMapping.source = sources.indexOf(srcMapping.source); - destMapping.originalLine = srcMapping.originalLine; - destMapping.originalColumn = srcMapping.originalColumn; + __param = function (paramIndex, decorator) { + return function (target, key) { decorator(target, key, paramIndex); } + }; - if (srcMapping.name) { - destMapping.name = names.indexOf(srcMapping.name); + __esDecorate = function (ctor, descriptorIn, decorators, contextIn, initializers, extraInitializers) { + function accept(f) { if (f !== void 0 && typeof f !== "function") throw new TypeError("Function expected"); return f; } + var kind = contextIn.kind, key = kind === "getter" ? "get" : kind === "setter" ? "set" : "value"; + var target = !descriptorIn && ctor ? contextIn["static"] ? ctor : ctor.prototype : null; + var descriptor = descriptorIn || (target ? Object.getOwnPropertyDescriptor(target, contextIn.name) : {}); + var _, done = false; + for (var i = decorators.length - 1; i >= 0; i--) { + var context = {}; + for (var p in contextIn) context[p] = p === "access" ? {} : contextIn[p]; + for (var p in contextIn.access) context.access[p] = contextIn.access[p]; + context.addInitializer = function (f) { if (done) throw new TypeError("Cannot add initializers after decoration has completed"); extraInitializers.push(accept(f || null)); }; + var result = (0, decorators[i])(kind === "accessor" ? { get: descriptor.get, set: descriptor.set } : descriptor[key], context); + if (kind === "accessor") { + if (result === void 0) continue; + if (result === null || typeof result !== "object") throw new TypeError("Object expected"); + if (_ = accept(result.get)) descriptor.get = _; + if (_ = accept(result.set)) descriptor.set = _; + if (_ = accept(result.init)) initializers.unshift(_); + } + else if (_ = accept(result)) { + if (kind === "field") initializers.unshift(_); + else descriptor[key] = _; + } } + if (target) Object.defineProperty(target, contextIn.name, descriptor); + done = true; + }; - destOriginalMappings.push(destMapping); - } + __runInitializers = function (thisArg, initializers, value) { + var useValue = arguments.length > 2; + for (var i = 0; i < initializers.length; i++) { + value = useValue ? initializers[i].call(thisArg, value) : initializers[i].call(thisArg); + } + return useValue ? value : void 0; + }; - destGeneratedMappings.push(destMapping); - } + __propKey = function (x) { + return typeof x === "symbol" ? x : "".concat(x); + }; - quickSort(smc.__originalMappings, util.compareByOriginalPositions); + __setFunctionName = function (f, name, prefix) { + if (typeof name === "symbol") name = name.description ? "[".concat(name.description, "]") : ""; + return Object.defineProperty(f, "name", { configurable: true, value: prefix ? "".concat(prefix, " ", name) : name }); + }; - return smc; - }; + __metadata = function (metadataKey, metadataValue) { + if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(metadataKey, metadataValue); + }; -/** - * The version of the source mapping spec that we are consuming. - */ -BasicSourceMapConsumer.prototype._version = 3; + __awaiter = function (thisArg, _arguments, P, generator) { + function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); } + return new (P || (P = Promise))(function (resolve, reject) { + function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } + function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } + function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); } + step((generator = generator.apply(thisArg, _arguments || [])).next()); + }); + }; -/** - * The list of original sources. - */ -Object.defineProperty(BasicSourceMapConsumer.prototype, 'sources', { - get: function () { - return this._absoluteSources.slice(); - } -}); + __generator = function (thisArg, body) { + var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g; + return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g; + function verb(n) { return function (v) { return step([n, v]); }; } + function step(op) { + if (f) throw new TypeError("Generator is already executing."); + while (g && (g = 0, op[0] && (_ = 0)), _) try { + if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t; + if (y = 0, t) op = [op[0] & 2, t.value]; + switch (op[0]) { + case 0: case 1: t = op; break; + case 4: _.label++; return { value: op[1], done: false }; + case 5: _.label++; y = op[1]; op = [0]; continue; + case 7: op = _.ops.pop(); _.trys.pop(); continue; + default: + if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; } + if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; } + if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; } + if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; } + if (t[2]) _.ops.pop(); + _.trys.pop(); continue; + } + op = body.call(thisArg, _); + } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; } + if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true }; + } + }; -/** - * Provide the JIT with a nice shape / hidden class. - */ -function Mapping() { - this.generatedLine = 0; - this.generatedColumn = 0; - this.source = null; - this.originalLine = null; - this.originalColumn = null; - this.name = null; -} + __exportStar = function(m, o) { + for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(o, p)) __createBinding(o, m, p); + }; -/** - * Parse the mappings in a string in to a data structure which we can easily - * query (the ordered arrays in the `this.__generatedMappings` and - * `this.__originalMappings` properties). - */ -BasicSourceMapConsumer.prototype._parseMappings = - function SourceMapConsumer_parseMappings(aStr, aSourceRoot) { - var generatedLine = 1; - var previousGeneratedColumn = 0; - var previousOriginalLine = 0; - var previousOriginalColumn = 0; - var previousSource = 0; - var previousName = 0; - var length = aStr.length; - var index = 0; - var cachedSegments = {}; - var temp = {}; - var originalMappings = []; - var generatedMappings = []; - var mapping, str, segment, end, value; + __createBinding = Object.create ? (function(o, m, k, k2) { + if (k2 === undefined) k2 = k; + var desc = Object.getOwnPropertyDescriptor(m, k); + if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) { + desc = { enumerable: true, get: function() { return m[k]; } }; + } + Object.defineProperty(o, k2, desc); + }) : (function(o, m, k, k2) { + if (k2 === undefined) k2 = k; + o[k2] = m[k]; + }); - while (index < length) { - if (aStr.charAt(index) === ';') { - generatedLine++; - index++; - previousGeneratedColumn = 0; - } - else if (aStr.charAt(index) === ',') { - index++; - } - else { - mapping = new Mapping(); - mapping.generatedLine = generatedLine; + __values = function (o) { + var s = typeof Symbol === "function" && Symbol.iterator, m = s && o[s], i = 0; + if (m) return m.call(o); + if (o && typeof o.length === "number") return { + next: function () { + if (o && i >= o.length) o = void 0; + return { value: o && o[i++], done: !o }; + } + }; + throw new TypeError(s ? "Object is not iterable." : "Symbol.iterator is not defined."); + }; - // Because each offset is encoded relative to the previous one, - // many segments often have the same encoding. We can exploit this - // fact by caching the parsed variable length fields of each segment, - // allowing us to avoid a second parse if we encounter the same - // segment again. - for (end = index; end < length; end++) { - if (this._charIsMappingSeparator(aStr, end)) { - break; - } + __read = function (o, n) { + var m = typeof Symbol === "function" && o[Symbol.iterator]; + if (!m) return o; + var i = m.call(o), r, ar = [], e; + try { + while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value); } - str = aStr.slice(index, end); - - segment = cachedSegments[str]; - if (segment) { - index += str.length; - } else { - segment = []; - while (index < end) { - base64VLQ.decode(aStr, index, temp); - value = temp.value; - index = temp.rest; - segment.push(value); - } + catch (error) { e = { error: error }; } + finally { + try { + if (r && !r.done && (m = i["return"])) m.call(i); + } + finally { if (e) throw e.error; } + } + return ar; + }; - if (segment.length === 2) { - throw new Error('Found a source, but no line and column'); - } + /** @deprecated */ + __spread = function () { + for (var ar = [], i = 0; i < arguments.length; i++) + ar = ar.concat(__read(arguments[i])); + return ar; + }; - if (segment.length === 3) { - throw new Error('Found a source and line, but no column'); - } + /** @deprecated */ + __spreadArrays = function () { + for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length; + for (var r = Array(s), k = 0, i = 0; i < il; i++) + for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++) + r[k] = a[j]; + return r; + }; - cachedSegments[str] = segment; + __spreadArray = function (to, from, pack) { + if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) { + if (ar || !(i in from)) { + if (!ar) ar = Array.prototype.slice.call(from, 0, i); + ar[i] = from[i]; + } } + return to.concat(ar || Array.prototype.slice.call(from)); + }; - // Generated column. - mapping.generatedColumn = previousGeneratedColumn + segment[0]; - previousGeneratedColumn = mapping.generatedColumn; + __await = function (v) { + return this instanceof __await ? (this.v = v, this) : new __await(v); + }; - if (segment.length > 1) { - // Original source. - mapping.source = previousSource + segment[1]; - previousSource += segment[1]; + __asyncGenerator = function (thisArg, _arguments, generator) { + if (!Symbol.asyncIterator) throw new TypeError("Symbol.asyncIterator is not defined."); + var g = generator.apply(thisArg, _arguments || []), i, q = []; + return i = {}, verb("next"), verb("throw"), verb("return"), i[Symbol.asyncIterator] = function () { return this; }, i; + function verb(n) { if (g[n]) i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; } + function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } } + function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); } + function fulfill(value) { resume("next", value); } + function reject(value) { resume("throw", value); } + function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); } + }; - // Original line. - mapping.originalLine = previousOriginalLine + segment[2]; - previousOriginalLine = mapping.originalLine; - // Lines are stored 0-based - mapping.originalLine += 1; + __asyncDelegator = function (o) { + var i, p; + return i = {}, verb("next"), verb("throw", function (e) { throw e; }), verb("return"), i[Symbol.iterator] = function () { return this; }, i; + function verb(n, f) { i[n] = o[n] ? function (v) { return (p = !p) ? { value: __await(o[n](v)), done: false } : f ? f(v) : v; } : f; } + }; - // Original column. - mapping.originalColumn = previousOriginalColumn + segment[3]; - previousOriginalColumn = mapping.originalColumn; + __asyncValues = function (o) { + if (!Symbol.asyncIterator) throw new TypeError("Symbol.asyncIterator is not defined."); + var m = o[Symbol.asyncIterator], i; + return m ? m.call(o) : (o = typeof __values === "function" ? __values(o) : o[Symbol.iterator](), i = {}, verb("next"), verb("throw"), verb("return"), i[Symbol.asyncIterator] = function () { return this; }, i); + function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; } + function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); } + }; - if (segment.length > 4) { - // Original name. - mapping.name = previousName + segment[4]; - previousName += segment[4]; - } - } + __makeTemplateObject = function (cooked, raw) { + if (Object.defineProperty) { Object.defineProperty(cooked, "raw", { value: raw }); } else { cooked.raw = raw; } + return cooked; + }; - generatedMappings.push(mapping); - if (typeof mapping.originalLine === 'number') { - originalMappings.push(mapping); - } - } - } + var __setModuleDefault = Object.create ? (function(o, v) { + Object.defineProperty(o, "default", { enumerable: true, value: v }); + }) : function(o, v) { + o["default"] = v; + }; - quickSort(generatedMappings, util.compareByGeneratedPositionsDeflated); - this.__generatedMappings = generatedMappings; + __importStar = function (mod) { + if (mod && mod.__esModule) return mod; + var result = {}; + if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k); + __setModuleDefault(result, mod); + return result; + }; - quickSort(originalMappings, util.compareByOriginalPositions); - this.__originalMappings = originalMappings; - }; - -/** - * Find the mapping that best matches the hypothetical "needle" mapping that - * we are searching for in the given "haystack" of mappings. - */ -BasicSourceMapConsumer.prototype._findMapping = - function SourceMapConsumer_findMapping(aNeedle, aMappings, aLineName, - aColumnName, aComparator, aBias) { - // To return the position we are searching for, we must first find the - // mapping for the given position and then return the opposite position it - // points to. Because the mappings are sorted, we can use binary search to - // find the best mapping. - - if (aNeedle[aLineName] <= 0) { - throw new TypeError('Line must be greater than or equal to 1, got ' - + aNeedle[aLineName]); - } - if (aNeedle[aColumnName] < 0) { - throw new TypeError('Column must be greater than or equal to 0, got ' - + aNeedle[aColumnName]); - } + __importDefault = function (mod) { + return (mod && mod.__esModule) ? mod : { "default": mod }; + }; - return binarySearch.search(aNeedle, aMappings, aComparator, aBias); - }; + __classPrivateFieldGet = function (receiver, state, kind, f) { + if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a getter"); + if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot read private member from an object whose class did not declare it"); + return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver); + }; -/** - * Compute the last column for each generated mapping. The last column is - * inclusive. - */ -BasicSourceMapConsumer.prototype.computeColumnSpans = - function SourceMapConsumer_computeColumnSpans() { - for (var index = 0; index < this._generatedMappings.length; ++index) { - var mapping = this._generatedMappings[index]; + __classPrivateFieldSet = function (receiver, state, value, kind, f) { + if (kind === "m") throw new TypeError("Private method is not writable"); + if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a setter"); + if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot write private member to an object whose class did not declare it"); + return (kind === "a" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value; + }; - // Mappings do not contain a field for the last generated columnt. We - // can come up with an optimistic estimate, however, by assuming that - // mappings are contiguous (i.e. given two consecutive mappings, the - // first mapping ends where the second one starts). - if (index + 1 < this._generatedMappings.length) { - var nextMapping = this._generatedMappings[index + 1]; + __classPrivateFieldIn = function (state, receiver) { + if (receiver === null || (typeof receiver !== "object" && typeof receiver !== "function")) throw new TypeError("Cannot use 'in' operator on non-object"); + return typeof state === "function" ? receiver === state : state.has(receiver); + }; - if (mapping.generatedLine === nextMapping.generatedLine) { - mapping.lastGeneratedColumn = nextMapping.generatedColumn - 1; - continue; + __addDisposableResource = function (env, value, async) { + if (value !== null && value !== void 0) { + if (typeof value !== "object" && typeof value !== "function") throw new TypeError("Object expected."); + var dispose; + if (async) { + if (!Symbol.asyncDispose) throw new TypeError("Symbol.asyncDispose is not defined."); + dispose = value[Symbol.asyncDispose]; + } + if (dispose === void 0) { + if (!Symbol.dispose) throw new TypeError("Symbol.dispose is not defined."); + dispose = value[Symbol.dispose]; + } + if (typeof dispose !== "function") throw new TypeError("Object not disposable."); + env.stack.push({ value: value, dispose: dispose, async: async }); } - } - - // The last mapping for each line spans the entire line. - mapping.lastGeneratedColumn = Infinity; - } - }; - -/** - * Returns the original source, line, and column information for the generated - * source's line and column positions provided. The only argument is an object - * with the following properties: - * - * - line: The line number in the generated source. The line number - * is 1-based. - * - column: The column number in the generated source. The column - * number is 0-based. - * - bias: Either 'SourceMapConsumer.GREATEST_LOWER_BOUND' or - * 'SourceMapConsumer.LEAST_UPPER_BOUND'. Specifies whether to return the - * closest element that is smaller than or greater than the one we are - * searching for, respectively, if the exact element cannot be found. - * Defaults to 'SourceMapConsumer.GREATEST_LOWER_BOUND'. - * - * and an object is returned with the following properties: - * - * - source: The original source file, or null. - * - line: The line number in the original source, or null. The - * line number is 1-based. - * - column: The column number in the original source, or null. The - * column number is 0-based. - * - name: The original identifier, or null. - */ -BasicSourceMapConsumer.prototype.originalPositionFor = - function SourceMapConsumer_originalPositionFor(aArgs) { - var needle = { - generatedLine: util.getArg(aArgs, 'line'), - generatedColumn: util.getArg(aArgs, 'column') + else if (async) { + env.stack.push({ async: true }); + } + return value; }; - var index = this._findMapping( - needle, - this._generatedMappings, - "generatedLine", - "generatedColumn", - util.compareByGeneratedPositionsDeflated, - util.getArg(aArgs, 'bias', SourceMapConsumer.GREATEST_LOWER_BOUND) - ); - - if (index >= 0) { - var mapping = this._generatedMappings[index]; + var _SuppressedError = typeof SuppressedError === "function" ? SuppressedError : function (error, suppressed, message) { + var e = new Error(message); + return e.name = "SuppressedError", e.error = error, e.suppressed = suppressed, e; + }; - if (mapping.generatedLine === needle.generatedLine) { - var source = util.getArg(mapping, 'source', null); - if (source !== null) { - source = this._sources.at(source); - source = util.computeSourceURL(this.sourceRoot, source, this._sourceMapURL); + __disposeResources = function (env) { + function fail(e) { + env.error = env.hasError ? new _SuppressedError(e, env.error, "An error was suppressed during disposal.") : e; + env.hasError = true; } - var name = util.getArg(mapping, 'name', null); - if (name !== null) { - name = this._names.at(name); + function next() { + while (env.stack.length) { + var rec = env.stack.pop(); + try { + var result = rec.dispose && rec.dispose.call(rec.value); + if (rec.async) return Promise.resolve(result).then(next, function(e) { fail(e); return next(); }); + } + catch (e) { + fail(e); + } + } + if (env.hasError) throw env.error; } - return { - source: source, - line: util.getArg(mapping, 'originalLine', null), - column: util.getArg(mapping, 'originalColumn', null), - name: name - }; - } - } - - return { - source: null, - line: null, - column: null, - name: null + return next(); }; - }; -/** - * Return true if we have the source content for every source in the source - * map, false otherwise. - */ -BasicSourceMapConsumer.prototype.hasContentsOfAllSources = - function BasicSourceMapConsumer_hasContentsOfAllSources() { - if (!this.sourcesContent) { - return false; - } - return this.sourcesContent.length >= this._sources.size() && - !this.sourcesContent.some(function (sc) { return sc == null; }); - }; + exporter("__extends", __extends); + exporter("__assign", __assign); + exporter("__rest", __rest); + exporter("__decorate", __decorate); + exporter("__param", __param); + exporter("__esDecorate", __esDecorate); + exporter("__runInitializers", __runInitializers); + exporter("__propKey", __propKey); + exporter("__setFunctionName", __setFunctionName); + exporter("__metadata", __metadata); + exporter("__awaiter", __awaiter); + exporter("__generator", __generator); + exporter("__exportStar", __exportStar); + exporter("__createBinding", __createBinding); + exporter("__values", __values); + exporter("__read", __read); + exporter("__spread", __spread); + exporter("__spreadArrays", __spreadArrays); + exporter("__spreadArray", __spreadArray); + exporter("__await", __await); + exporter("__asyncGenerator", __asyncGenerator); + exporter("__asyncDelegator", __asyncDelegator); + exporter("__asyncValues", __asyncValues); + exporter("__makeTemplateObject", __makeTemplateObject); + exporter("__importStar", __importStar); + exporter("__importDefault", __importDefault); + exporter("__classPrivateFieldGet", __classPrivateFieldGet); + exporter("__classPrivateFieldSet", __classPrivateFieldSet); + exporter("__classPrivateFieldIn", __classPrivateFieldIn); + exporter("__addDisposableResource", __addDisposableResource); + exporter("__disposeResources", __disposeResources); +}); -/** - * Returns the original source content. The only argument is the url of the - * original source file. Returns null if no original source content is - * available. - */ -BasicSourceMapConsumer.prototype.sourceContentFor = - function SourceMapConsumer_sourceContentFor(aSource, nullOnMissing) { - if (!this.sourcesContent) { - return null; - } - var index = this._findSourceIndex(aSource); - if (index >= 0) { - return this.sourcesContent[index]; - } +/***/ }), - var relativeSource = aSource; - if (this.sourceRoot != null) { - relativeSource = util.relative(this.sourceRoot, relativeSource); - } +/***/ 2932: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { - var url; - if (this.sourceRoot != null - && (url = util.urlParse(this.sourceRoot))) { - // XXX: file:// URIs and absolute paths lead to unexpected behavior for - // many users. We can help them out when they expect file:// URIs to - // behave like it would if they were running a local HTTP server. See - // https://bugzilla.mozilla.org/show_bug.cgi?id=885597. - var fileUriAbsPath = relativeSource.replace(/^file:\/\//, ""); - if (url.scheme == "file" - && this._sources.has(fileUriAbsPath)) { - return this.sourcesContent[this._sources.indexOf(fileUriAbsPath)] - } +module.exports = __nccwpck_require__(17146); - if ((!url.path || url.path == "/") - && this._sources.has("/" + relativeSource)) { - return this.sourcesContent[this._sources.indexOf("/" + relativeSource)]; - } - } - // This function is used recursively from - // IndexedSourceMapConsumer.prototype.sourceContentFor. In that case, we - // don't want to throw if we can't find the source - we just want to - // return null, so we provide a flag to exit gracefully. - if (nullOnMissing) { - return null; - } - else { - throw new Error('"' + relativeSource + '" is not in the SourceMap.'); - } - }; +/***/ }), -/** - * Returns the generated line and column information for the original source, - * line, and column positions provided. The only argument is an object with - * the following properties: - * - * - source: The filename of the original source. - * - line: The line number in the original source. The line number - * is 1-based. - * - column: The column number in the original source. The column - * number is 0-based. - * - bias: Either 'SourceMapConsumer.GREATEST_LOWER_BOUND' or - * 'SourceMapConsumer.LEAST_UPPER_BOUND'. Specifies whether to return the - * closest element that is smaller than or greater than the one we are - * searching for, respectively, if the exact element cannot be found. - * Defaults to 'SourceMapConsumer.GREATEST_LOWER_BOUND'. - * - * and an object is returned with the following properties: - * - * - line: The line number in the generated source, or null. The - * line number is 1-based. - * - column: The column number in the generated source, or null. - * The column number is 0-based. - */ -BasicSourceMapConsumer.prototype.generatedPositionFor = - function SourceMapConsumer_generatedPositionFor(aArgs) { - var source = util.getArg(aArgs, 'source'); - source = this._findSourceIndex(source); - if (source < 0) { - return { - line: null, - column: null, - lastColumn: null - }; - } +/***/ 17146: +/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { - var needle = { - source: source, - originalLine: util.getArg(aArgs, 'line'), - originalColumn: util.getArg(aArgs, 'column') - }; +"use strict"; - var index = this._findMapping( - needle, - this._originalMappings, - "originalLine", - "originalColumn", - util.compareByOriginalPositions, - util.getArg(aArgs, 'bias', SourceMapConsumer.GREATEST_LOWER_BOUND) - ); - if (index >= 0) { - var mapping = this._originalMappings[index]; +var net = __nccwpck_require__(41808); +var tls = __nccwpck_require__(24404); +var http = __nccwpck_require__(13685); +var https = __nccwpck_require__(95687); +var events = __nccwpck_require__(82361); +var assert = __nccwpck_require__(39491); +var util = __nccwpck_require__(73837); - if (mapping.source === needle.source) { - return { - line: util.getArg(mapping, 'generatedLine', null), - column: util.getArg(mapping, 'generatedColumn', null), - lastColumn: util.getArg(mapping, 'lastGeneratedColumn', null) - }; - } - } - return { - line: null, - column: null, - lastColumn: null - }; - }; +exports.httpOverHttp = httpOverHttp; +exports.httpsOverHttp = httpsOverHttp; +exports.httpOverHttps = httpOverHttps; +exports.httpsOverHttps = httpsOverHttps; -__webpack_unused_export__ = BasicSourceMapConsumer; -/** - * An IndexedSourceMapConsumer instance represents a parsed source map which - * we can query for information. It differs from BasicSourceMapConsumer in - * that it takes "indexed" source maps (i.e. ones with a "sections" field) as - * input. - * - * The first parameter is a raw source map (either as a JSON string, or already - * parsed to an object). According to the spec for indexed source maps, they - * have the following attributes: - * - * - version: Which version of the source map spec this map is following. - * - file: Optional. The generated file this source map is associated with. - * - sections: A list of section definitions. - * - * Each value under the "sections" field has two fields: - * - offset: The offset into the original specified at which this section - * begins to apply, defined as an object with a "line" and "column" - * field. - * - map: A source map definition. This source map could also be indexed, - * but doesn't have to be. - * - * Instead of the "map" field, it's also possible to have a "url" field - * specifying a URL to retrieve a source map from, but that's currently - * unsupported. - * - * Here's an example source map, taken from the source map spec[0], but - * modified to omit a section which uses the "url" field. - * - * { - * version : 3, - * file: "app.js", - * sections: [{ - * offset: {line:100, column:10}, - * map: { - * version : 3, - * file: "section.js", - * sources: ["foo.js", "bar.js"], - * names: ["src", "maps", "are", "fun"], - * mappings: "AAAA,E;;ABCDE;" - * } - * }], - * } - * - * The second parameter, if given, is a string whose value is the URL - * at which the source map was found. This URL is used to compute the - * sources array. - * - * [0]: https://docs.google.com/document/d/1U1RGAehQwRypUTovF1KRlpiOFze0b-_2gc6fAH0KY0k/edit#heading=h.535es3xeprgt - */ -function IndexedSourceMapConsumer(aSourceMap, aSourceMapURL) { - var sourceMap = aSourceMap; - if (typeof aSourceMap === 'string') { - sourceMap = util.parseSourceMapInput(aSourceMap); - } +function httpOverHttp(options) { + var agent = new TunnelingAgent(options); + agent.request = http.request; + return agent; +} - var version = util.getArg(sourceMap, 'version'); - var sections = util.getArg(sourceMap, 'sections'); +function httpsOverHttp(options) { + var agent = new TunnelingAgent(options); + agent.request = http.request; + agent.createSocket = createSecureSocket; + agent.defaultPort = 443; + return agent; +} - if (version != this._version) { - throw new Error('Unsupported version: ' + version); - } +function httpOverHttps(options) { + var agent = new TunnelingAgent(options); + agent.request = https.request; + return agent; +} - this._sources = new ArraySet(); - this._names = new ArraySet(); +function httpsOverHttps(options) { + var agent = new TunnelingAgent(options); + agent.request = https.request; + agent.createSocket = createSecureSocket; + agent.defaultPort = 443; + return agent; +} - var lastOffset = { - line: -1, - column: 0 - }; - this._sections = sections.map(function (s) { - if (s.url) { - // The url field will require support for asynchronicity. - // See https://github.com/mozilla/source-map/issues/16 - throw new Error('Support for url field in sections not implemented.'); - } - var offset = util.getArg(s, 'offset'); - var offsetLine = util.getArg(offset, 'line'); - var offsetColumn = util.getArg(offset, 'column'); - if (offsetLine < lastOffset.line || - (offsetLine === lastOffset.line && offsetColumn < lastOffset.column)) { - throw new Error('Section offsets must be ordered and non-overlapping.'); - } - lastOffset = offset; +function TunnelingAgent(options) { + var self = this; + self.options = options || {}; + self.proxyOptions = self.options.proxy || {}; + self.maxSockets = self.options.maxSockets || http.Agent.defaultMaxSockets; + self.requests = []; + self.sockets = []; - return { - generatedOffset: { - // The offset fields are 0-based, but we use 1-based indices when - // encoding/decoding from VLQ. - generatedLine: offsetLine + 1, - generatedColumn: offsetColumn + 1 - }, - consumer: new SourceMapConsumer(util.getArg(s, 'map'), aSourceMapURL) + self.on('free', function onFree(socket, host, port, localAddress) { + var options = toOptions(host, port, localAddress); + for (var i = 0, len = self.requests.length; i < len; ++i) { + var pending = self.requests[i]; + if (pending.host === options.host && pending.port === options.port) { + // Detect the request to connect same origin server, + // reuse the connection. + self.requests.splice(i, 1); + pending.request.onSocket(socket); + return; + } } + socket.destroy(); + self.removeSocket(socket); }); } +util.inherits(TunnelingAgent, events.EventEmitter); -IndexedSourceMapConsumer.prototype = Object.create(SourceMapConsumer.prototype); -IndexedSourceMapConsumer.prototype.constructor = SourceMapConsumer; - -/** - * The version of the source mapping spec that we are consuming. - */ -IndexedSourceMapConsumer.prototype._version = 3; +TunnelingAgent.prototype.addRequest = function addRequest(req, host, port, localAddress) { + var self = this; + var options = mergeOptions({request: req}, self.options, toOptions(host, port, localAddress)); -/** - * The list of original sources. - */ -Object.defineProperty(IndexedSourceMapConsumer.prototype, 'sources', { - get: function () { - var sources = []; - for (var i = 0; i < this._sections.length; i++) { - for (var j = 0; j < this._sections[i].consumer.sources.length; j++) { - sources.push(this._sections[i].consumer.sources[j]); - } - } - return sources; + if (self.sockets.length >= this.maxSockets) { + // We are over limit so we'll add it to the queue. + self.requests.push(options); + return; } -}); -/** - * Returns the original source, line, and column information for the generated - * source's line and column positions provided. The only argument is an object - * with the following properties: - * - * - line: The line number in the generated source. The line number - * is 1-based. - * - column: The column number in the generated source. The column - * number is 0-based. - * - * and an object is returned with the following properties: - * - * - source: The original source file, or null. - * - line: The line number in the original source, or null. The - * line number is 1-based. - * - column: The column number in the original source, or null. The - * column number is 0-based. - * - name: The original identifier, or null. - */ -IndexedSourceMapConsumer.prototype.originalPositionFor = - function IndexedSourceMapConsumer_originalPositionFor(aArgs) { - var needle = { - generatedLine: util.getArg(aArgs, 'line'), - generatedColumn: util.getArg(aArgs, 'column') - }; + // If we are under maxSockets create a new one. + self.createSocket(options, function(socket) { + socket.on('free', onFree); + socket.on('close', onCloseOrRemove); + socket.on('agentRemove', onCloseOrRemove); + req.onSocket(socket); - // Find the section containing the generated position we're trying to map - // to an original position. - var sectionIndex = binarySearch.search(needle, this._sections, - function(needle, section) { - var cmp = needle.generatedLine - section.generatedOffset.generatedLine; - if (cmp) { - return cmp; - } + function onFree() { + self.emit('free', socket, options); + } - return (needle.generatedColumn - - section.generatedOffset.generatedColumn); - }); - var section = this._sections[sectionIndex]; + function onCloseOrRemove(err) { + self.removeSocket(socket); + socket.removeListener('free', onFree); + socket.removeListener('close', onCloseOrRemove); + socket.removeListener('agentRemove', onCloseOrRemove); + } + }); +}; - if (!section) { - return { - source: null, - line: null, - column: null, - name: null - }; +TunnelingAgent.prototype.createSocket = function createSocket(options, cb) { + var self = this; + var placeholder = {}; + self.sockets.push(placeholder); + + var connectOptions = mergeOptions({}, self.proxyOptions, { + method: 'CONNECT', + path: options.host + ':' + options.port, + agent: false, + headers: { + host: options.host + ':' + options.port } + }); + if (options.localAddress) { + connectOptions.localAddress = options.localAddress; + } + if (connectOptions.proxyAuth) { + connectOptions.headers = connectOptions.headers || {}; + connectOptions.headers['Proxy-Authorization'] = 'Basic ' + + new Buffer(connectOptions.proxyAuth).toString('base64'); + } - return section.consumer.originalPositionFor({ - line: needle.generatedLine - - (section.generatedOffset.generatedLine - 1), - column: needle.generatedColumn - - (section.generatedOffset.generatedLine === needle.generatedLine - ? section.generatedOffset.generatedColumn - 1 - : 0), - bias: aArgs.bias - }); - }; + debug('making CONNECT request'); + var connectReq = self.request(connectOptions); + connectReq.useChunkedEncodingByDefault = false; // for v0.6 + connectReq.once('response', onResponse); // for v0.6 + connectReq.once('upgrade', onUpgrade); // for v0.6 + connectReq.once('connect', onConnect); // for v0.7 or later + connectReq.once('error', onError); + connectReq.end(); -/** - * Return true if we have the source content for every source in the source - * map, false otherwise. - */ -IndexedSourceMapConsumer.prototype.hasContentsOfAllSources = - function IndexedSourceMapConsumer_hasContentsOfAllSources() { - return this._sections.every(function (s) { - return s.consumer.hasContentsOfAllSources(); + function onResponse(res) { + // Very hacky. This is necessary to avoid http-parser leaks. + res.upgrade = true; + } + + function onUpgrade(res, socket, head) { + // Hacky. + process.nextTick(function() { + onConnect(res, socket, head); }); - }; + } -/** - * Returns the original source content. The only argument is the url of the - * original source file. Returns null if no original source content is - * available. - */ -IndexedSourceMapConsumer.prototype.sourceContentFor = - function IndexedSourceMapConsumer_sourceContentFor(aSource, nullOnMissing) { - for (var i = 0; i < this._sections.length; i++) { - var section = this._sections[i]; + function onConnect(res, socket, head) { + connectReq.removeAllListeners(); + socket.removeAllListeners(); - var content = section.consumer.sourceContentFor(aSource, true); - if (content) { - return content; - } - } - if (nullOnMissing) { - return null; + if (res.statusCode !== 200) { + debug('tunneling socket could not be established, statusCode=%d', + res.statusCode); + socket.destroy(); + var error = new Error('tunneling socket could not be established, ' + + 'statusCode=' + res.statusCode); + error.code = 'ECONNRESET'; + options.request.emit('error', error); + self.removeSocket(placeholder); + return; } - else { - throw new Error('"' + aSource + '" is not in the SourceMap.'); + if (head.length > 0) { + debug('got illegal response body from proxy'); + socket.destroy(); + var error = new Error('got illegal response body from proxy'); + error.code = 'ECONNRESET'; + options.request.emit('error', error); + self.removeSocket(placeholder); + return; } - }; + debug('tunneling connection has established'); + self.sockets[self.sockets.indexOf(placeholder)] = socket; + return cb(socket); + } -/** - * Returns the generated line and column information for the original source, - * line, and column positions provided. The only argument is an object with - * the following properties: - * - * - source: The filename of the original source. - * - line: The line number in the original source. The line number - * is 1-based. - * - column: The column number in the original source. The column - * number is 0-based. - * - * and an object is returned with the following properties: - * - * - line: The line number in the generated source, or null. The - * line number is 1-based. - * - column: The column number in the generated source, or null. - * The column number is 0-based. - */ -IndexedSourceMapConsumer.prototype.generatedPositionFor = - function IndexedSourceMapConsumer_generatedPositionFor(aArgs) { - for (var i = 0; i < this._sections.length; i++) { - var section = this._sections[i]; + function onError(cause) { + connectReq.removeAllListeners(); - // Only consider this section if the requested source is in the list of - // sources of the consumer. - if (section.consumer._findSourceIndex(util.getArg(aArgs, 'source')) === -1) { - continue; - } - var generatedPosition = section.consumer.generatedPositionFor(aArgs); - if (generatedPosition) { - var ret = { - line: generatedPosition.line + - (section.generatedOffset.generatedLine - 1), - column: generatedPosition.column + - (section.generatedOffset.generatedLine === generatedPosition.line - ? section.generatedOffset.generatedColumn - 1 - : 0) - }; - return ret; - } - } + debug('tunneling socket could not be established, cause=%s\n', + cause.message, cause.stack); + var error = new Error('tunneling socket could not be established, ' + + 'cause=' + cause.message); + error.code = 'ECONNRESET'; + options.request.emit('error', error); + self.removeSocket(placeholder); + } +}; - return { - line: null, - column: null - }; - }; +TunnelingAgent.prototype.removeSocket = function removeSocket(socket) { + var pos = this.sockets.indexOf(socket) + if (pos === -1) { + return; + } + this.sockets.splice(pos, 1); -/** - * Parse the mappings in a string in to a data structure which we can easily - * query (the ordered arrays in the `this.__generatedMappings` and - * `this.__originalMappings` properties). - */ -IndexedSourceMapConsumer.prototype._parseMappings = - function IndexedSourceMapConsumer_parseMappings(aStr, aSourceRoot) { - this.__generatedMappings = []; - this.__originalMappings = []; - for (var i = 0; i < this._sections.length; i++) { - var section = this._sections[i]; - var sectionMappings = section.consumer._generatedMappings; - for (var j = 0; j < sectionMappings.length; j++) { - var mapping = sectionMappings[j]; + var pending = this.requests.shift(); + if (pending) { + // If we have pending requests and a socket gets closed a new one + // needs to be created to take over in the pool for the one that closed. + this.createSocket(pending, function(socket) { + pending.request.onSocket(socket); + }); + } +}; - var source = section.consumer._sources.at(mapping.source); - source = util.computeSourceURL(section.consumer.sourceRoot, source, this._sourceMapURL); - this._sources.add(source); - source = this._sources.indexOf(source); +function createSecureSocket(options, cb) { + var self = this; + TunnelingAgent.prototype.createSocket.call(self, options, function(socket) { + var hostHeader = options.request.getHeader('host'); + var tlsOptions = mergeOptions({}, self.options, { + socket: socket, + servername: hostHeader ? hostHeader.replace(/:.*$/, '') : options.host + }); - var name = null; - if (mapping.name) { - name = section.consumer._names.at(mapping.name); - this._names.add(name); - name = this._names.indexOf(name); - } + // 0 is dummy port for v0.6 + var secureSocket = tls.connect(0, tlsOptions); + self.sockets[self.sockets.indexOf(socket)] = secureSocket; + cb(secureSocket); + }); +} - // The mappings coming from the consumer for the section have - // generated positions relative to the start of the section, so we - // need to offset them to be relative to the start of the concatenated - // generated file. - var adjustedMapping = { - source: source, - generatedLine: mapping.generatedLine + - (section.generatedOffset.generatedLine - 1), - generatedColumn: mapping.generatedColumn + - (section.generatedOffset.generatedLine === mapping.generatedLine - ? section.generatedOffset.generatedColumn - 1 - : 0), - originalLine: mapping.originalLine, - originalColumn: mapping.originalColumn, - name: name - }; - this.__generatedMappings.push(adjustedMapping); - if (typeof adjustedMapping.originalLine === 'number') { - this.__originalMappings.push(adjustedMapping); +function toOptions(host, port, localAddress) { + if (typeof host === 'string') { // since v0.10 + return { + host: host, + port: port, + localAddress: localAddress + }; + } + return host; // for v0.11 or later +} + +function mergeOptions(target) { + for (var i = 1, len = arguments.length; i < len; ++i) { + var overrides = arguments[i]; + if (typeof overrides === 'object') { + var keys = Object.keys(overrides); + for (var j = 0, keyLen = keys.length; j < keyLen; ++j) { + var k = keys[j]; + if (overrides[k] !== undefined) { + target[k] = overrides[k]; } } } + } + return target; +} - quickSort(this.__generatedMappings, util.compareByGeneratedPositionsDeflated); - quickSort(this.__originalMappings, util.compareByOriginalPositions); - }; -__webpack_unused_export__ = IndexedSourceMapConsumer; +var debug; +if (process.env.NODE_DEBUG && /\btunnel\b/.test(process.env.NODE_DEBUG)) { + debug = function() { + var args = Array.prototype.slice.call(arguments); + if (typeof args[0] === 'string') { + args[0] = 'TUNNEL: ' + args[0]; + } else { + args.unshift('TUNNEL:'); + } + console.error.apply(console, args); + } +} else { + debug = function() {}; +} +exports.debug = debug; // for test /***/ }), -/***/ 66677: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { +/***/ 81151: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { -/* -*- Mode: js; js-indent-level: 2; -*- */ -/* - * Copyright 2011 Mozilla Foundation and contributors - * Licensed under the New BSD license. See LICENSE or: - * http://opensource.org/licenses/BSD-3-Clause - */ +"use strict"; +/*! ***************************************************************************** +Copyright (c) Microsoft Corporation. All rights reserved. +Licensed under the Apache License, Version 2.0 (the "License"); you may not use +this file except in compliance with the License. You may obtain a copy of the +License at http://www.apache.org/licenses/LICENSE-2.0 -var base64VLQ = __nccwpck_require__(14590); -var util = __nccwpck_require__(16511); -var ArraySet = (__nccwpck_require__(30176)/* .ArraySet */ .I); -var MappingList = (__nccwpck_require__(31247)/* .MappingList */ .H); +THIS CODE IS PROVIDED ON AN *AS IS* BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY +KIND, EITHER EXPRESS OR IMPLIED, INCLUDING WITHOUT LIMITATION ANY IMPLIED +WARRANTIES OR CONDITIONS OF TITLE, FITNESS FOR A PARTICULAR PURPOSE, +MERCHANTABLITY OR NON-INFRINGEMENT. -/** - * An instance of the SourceMapGenerator represents a source map which is - * being built incrementally. You may pass an object with the following - * properties: - * - * - file: The filename of the generated source. - * - sourceRoot: A root for all relative URLs in this source map. - */ -function SourceMapGenerator(aArgs) { - if (!aArgs) { - aArgs = {}; - } - this._file = util.getArg(aArgs, 'file', null); - this._sourceRoot = util.getArg(aArgs, 'sourceRoot', null); - this._skipValidation = util.getArg(aArgs, 'skipValidation', false); - this._sources = new ArraySet(); - this._names = new ArraySet(); - this._mappings = new MappingList(); - this._sourcesContents = null; -} +See the Apache Version 2.0 License for specific language governing permissions +and limitations under the License. +***************************************************************************** */ -SourceMapGenerator.prototype._version = 3; -/** - * Creates a new SourceMapGenerator based on a SourceMapConsumer - * - * @param aSourceMapConsumer The SourceMap. - */ -SourceMapGenerator.fromSourceMap = - function SourceMapGenerator_fromSourceMap(aSourceMapConsumer) { - var sourceRoot = aSourceMapConsumer.sourceRoot; - var generator = new SourceMapGenerator({ - file: aSourceMapConsumer.file, - sourceRoot: sourceRoot - }); - aSourceMapConsumer.eachMapping(function (mapping) { - var newMapping = { - generated: { - line: mapping.generatedLine, - column: mapping.generatedColumn - } - }; - if (mapping.source != null) { - newMapping.source = mapping.source; - if (sourceRoot != null) { - newMapping.source = util.relative(sourceRoot, newMapping.source); - } +var ts = (() => { + var __defProp = Object.defineProperty; + var __getOwnPropNames = Object.getOwnPropertyNames; + var __esm = (fn, res) => function __init() { + return fn && (res = (0, fn[__getOwnPropNames(fn)[0]])(fn = 0)), res; + }; + var __commonJS = (cb, mod) => function __require() { + return mod || (0, cb[__getOwnPropNames(cb)[0]])((mod = { exports: {} }).exports, mod), mod.exports; + }; + var __export = (target, all) => { + for (var name in all) + __defProp(target, name, { get: all[name], enumerable: true }); + }; - newMapping.original = { - line: mapping.originalLine, - column: mapping.originalColumn - }; + // src/compiler/corePublic.ts + var versionMajorMinor, version, Comparison; + var init_corePublic = __esm({ + "src/compiler/corePublic.ts"() { + "use strict"; + versionMajorMinor = "5.3"; + version = "5.3.3"; + Comparison = /* @__PURE__ */ ((Comparison3) => { + Comparison3[Comparison3["LessThan"] = -1] = "LessThan"; + Comparison3[Comparison3["EqualTo"] = 0] = "EqualTo"; + Comparison3[Comparison3["GreaterThan"] = 1] = "GreaterThan"; + return Comparison3; + })(Comparison || {}); + } + }); - if (mapping.name != null) { - newMapping.name = mapping.name; + // src/compiler/core.ts + function length(array) { + return array ? array.length : 0; + } + function forEach(array, callback) { + if (array) { + for (let i = 0; i < array.length; i++) { + const result = callback(array[i], i); + if (result) { + return result; } } - - generator.addMapping(newMapping); - }); - aSourceMapConsumer.sources.forEach(function (sourceFile) { - var sourceRelative = sourceFile; - if (sourceRoot !== null) { - sourceRelative = util.relative(sourceRoot, sourceFile); - } - - if (!generator._sources.has(sourceRelative)) { - generator._sources.add(sourceRelative); + } + return void 0; + } + function forEachRight(array, callback) { + if (array) { + for (let i = array.length - 1; i >= 0; i--) { + const result = callback(array[i], i); + if (result) { + return result; + } } - - var content = aSourceMapConsumer.sourceContentFor(sourceFile); - if (content != null) { - generator.setSourceContent(sourceFile, content); + } + return void 0; + } + function firstDefined(array, callback) { + if (array === void 0) { + return void 0; + } + for (let i = 0; i < array.length; i++) { + const result = callback(array[i], i); + if (result !== void 0) { + return result; } - }); - return generator; - }; - -/** - * Add a single mapping from original source line and column to the generated - * source's line and column for this source map being created. The mapping - * object should have the following properties: - * - * - generated: An object with the generated line and column positions. - * - original: An object with the original line and column positions. - * - source: The original source file (relative to the sourceRoot). - * - name: An optional original token name for this mapping. - */ -SourceMapGenerator.prototype.addMapping = - function SourceMapGenerator_addMapping(aArgs) { - var generated = util.getArg(aArgs, 'generated'); - var original = util.getArg(aArgs, 'original', null); - var source = util.getArg(aArgs, 'source', null); - var name = util.getArg(aArgs, 'name', null); - - if (!this._skipValidation) { - this._validateMapping(generated, original, source, name); } - - if (source != null) { - source = String(source); - if (!this._sources.has(source)) { - this._sources.add(source); + return void 0; + } + function firstDefinedIterator(iter, callback) { + for (const value of iter) { + const result = callback(value); + if (result !== void 0) { + return result; } } - - if (name != null) { - name = String(name); - if (!this._names.has(name)) { - this._names.add(name); + return void 0; + } + function reduceLeftIterator(iterator, f, initial) { + let result = initial; + if (iterator) { + let pos = 0; + for (const value of iterator) { + result = f(result, value, pos); + pos++; } } - - this._mappings.add({ - generatedLine: generated.line, - generatedColumn: generated.column, - originalLine: original != null && original.line, - originalColumn: original != null && original.column, - source: source, - name: name - }); - }; - -/** - * Set the source content for a source file. - */ -SourceMapGenerator.prototype.setSourceContent = - function SourceMapGenerator_setSourceContent(aSourceFile, aSourceContent) { - var source = aSourceFile; - if (this._sourceRoot != null) { - source = util.relative(this._sourceRoot, source); + return result; + } + function zipWith(arrayA, arrayB, callback) { + const result = []; + Debug.assertEqual(arrayA.length, arrayB.length); + for (let i = 0; i < arrayA.length; i++) { + result.push(callback(arrayA[i], arrayB[i], i)); } - - if (aSourceContent != null) { - // Add the source content to the _sourcesContents map. - // Create a new _sourcesContents map if the property is null. - if (!this._sourcesContents) { - this._sourcesContents = Object.create(null); + return result; + } + function intersperse(input, element) { + if (input.length <= 1) { + return input; + } + const result = []; + for (let i = 0, n = input.length; i < n; i++) { + if (i) + result.push(element); + result.push(input[i]); + } + return result; + } + function every(array, callback) { + if (array) { + for (let i = 0; i < array.length; i++) { + if (!callback(array[i], i)) { + return false; + } } - this._sourcesContents[util.toSetString(source)] = aSourceContent; - } else if (this._sourcesContents) { - // Remove the source file from the _sourcesContents map. - // If the _sourcesContents map is empty, set the property to null. - delete this._sourcesContents[util.toSetString(source)]; - if (Object.keys(this._sourcesContents).length === 0) { - this._sourcesContents = null; + } + return true; + } + function find(array, predicate, startIndex) { + if (array === void 0) + return void 0; + for (let i = startIndex ?? 0; i < array.length; i++) { + const value = array[i]; + if (predicate(value, i)) { + return value; } } - }; - -/** - * Applies the mappings of a sub-source-map for a specific source file to the - * source map being generated. Each mapping to the supplied source file is - * rewritten using the supplied source map. Note: The resolution for the - * resulting mappings is the minimium of this map and the supplied map. - * - * @param aSourceMapConsumer The source map to be applied. - * @param aSourceFile Optional. The filename of the source file. - * If omitted, SourceMapConsumer's file property will be used. - * @param aSourceMapPath Optional. The dirname of the path to the source map - * to be applied. If relative, it is relative to the SourceMapConsumer. - * This parameter is needed when the two source maps aren't in the same - * directory, and the source map to be applied contains relative source - * paths. If so, those relative source paths need to be rewritten - * relative to the SourceMapGenerator. - */ -SourceMapGenerator.prototype.applySourceMap = - function SourceMapGenerator_applySourceMap(aSourceMapConsumer, aSourceFile, aSourceMapPath) { - var sourceFile = aSourceFile; - // If aSourceFile is omitted, we will use the file property of the SourceMap - if (aSourceFile == null) { - if (aSourceMapConsumer.file == null) { - throw new Error( - 'SourceMapGenerator.prototype.applySourceMap requires either an explicit source file, ' + - 'or the source map\'s "file" property. Both were omitted.' - ); + return void 0; + } + function findLast(array, predicate, startIndex) { + if (array === void 0) + return void 0; + for (let i = startIndex ?? array.length - 1; i >= 0; i--) { + const value = array[i]; + if (predicate(value, i)) { + return value; } - sourceFile = aSourceMapConsumer.file; } - var sourceRoot = this._sourceRoot; - // Make "sourceFile" relative if an absolute Url is passed. - if (sourceRoot != null) { - sourceFile = util.relative(sourceRoot, sourceFile); + return void 0; + } + function findIndex(array, predicate, startIndex) { + if (array === void 0) + return -1; + for (let i = startIndex ?? 0; i < array.length; i++) { + if (predicate(array[i], i)) { + return i; + } } - // Applying the SourceMap can add and remove items from the sources and - // the names array. - var newSources = new ArraySet(); - var newNames = new ArraySet(); - - // Find mappings for the "sourceFile" - this._mappings.unsortedForEach(function (mapping) { - if (mapping.source === sourceFile && mapping.originalLine != null) { - // Check if it can be mapped by the source map, then update the mapping. - var original = aSourceMapConsumer.originalPositionFor({ - line: mapping.originalLine, - column: mapping.originalColumn - }); - if (original.source != null) { - // Copy mapping - mapping.source = original.source; - if (aSourceMapPath != null) { - mapping.source = util.join(aSourceMapPath, mapping.source) - } - if (sourceRoot != null) { - mapping.source = util.relative(sourceRoot, mapping.source); - } - mapping.originalLine = original.line; - mapping.originalColumn = original.column; - if (original.name != null) { - mapping.name = original.name; - } - } + return -1; + } + function findLastIndex(array, predicate, startIndex) { + if (array === void 0) + return -1; + for (let i = startIndex ?? array.length - 1; i >= 0; i--) { + if (predicate(array[i], i)) { + return i; } - - var source = mapping.source; - if (source != null && !newSources.has(source)) { - newSources.add(source); + } + return -1; + } + function findMap(array, callback) { + for (let i = 0; i < array.length; i++) { + const result = callback(array[i], i); + if (result) { + return result; } - - var name = mapping.name; - if (name != null && !newNames.has(name)) { - newNames.add(name); + } + return Debug.fail(); + } + function contains(array, value, equalityComparer = equateValues) { + if (array) { + for (const v of array) { + if (equalityComparer(v, value)) { + return true; + } } - - }, this); - this._sources = newSources; - this._names = newNames; - - // Copy sourcesContents of applied map. - aSourceMapConsumer.sources.forEach(function (sourceFile) { - var content = aSourceMapConsumer.sourceContentFor(sourceFile); - if (content != null) { - if (aSourceMapPath != null) { - sourceFile = util.join(aSourceMapPath, sourceFile); + } + return false; + } + function arraysEqual(a, b, equalityComparer = equateValues) { + return a.length === b.length && a.every((x, i) => equalityComparer(x, b[i])); + } + function indexOfAnyCharCode(text, charCodes, start) { + for (let i = start || 0; i < text.length; i++) { + if (contains(charCodes, text.charCodeAt(i))) { + return i; + } + } + return -1; + } + function countWhere(array, predicate) { + let count = 0; + if (array) { + for (let i = 0; i < array.length; i++) { + const v = array[i]; + if (predicate(v, i)) { + count++; } - if (sourceRoot != null) { - sourceFile = util.relative(sourceRoot, sourceFile); + } + } + return count; + } + function filter(array, f) { + if (array) { + const len = array.length; + let i = 0; + while (i < len && f(array[i])) + i++; + if (i < len) { + const result = array.slice(0, i); + i++; + while (i < len) { + const item = array[i]; + if (f(item)) { + result.push(item); + } + i++; } - this.setSourceContent(sourceFile, content); + return result; } - }, this); - }; - -/** - * A mapping can have one of the three levels of data: - * - * 1. Just the generated position. - * 2. The Generated position, original position, and original source. - * 3. Generated and original position, original source, as well as a name - * token. - * - * To maintain consistency, we validate that any new mapping being added falls - * in to one of these categories. - */ -SourceMapGenerator.prototype._validateMapping = - function SourceMapGenerator_validateMapping(aGenerated, aOriginal, aSource, - aName) { - // When aOriginal is truthy but has empty values for .line and .column, - // it is most likely a programmer error. In this case we throw a very - // specific error message to try to guide them the right way. - // For example: https://github.com/Polymer/polymer-bundler/pull/519 - if (aOriginal && typeof aOriginal.line !== 'number' && typeof aOriginal.column !== 'number') { - throw new Error( - 'original.line and original.column are not numbers -- you probably meant to omit ' + - 'the original mapping entirely and only map the generated position. If so, pass ' + - 'null for the original mapping instead of an object with empty or null values.' - ); } - - if (aGenerated && 'line' in aGenerated && 'column' in aGenerated - && aGenerated.line > 0 && aGenerated.column >= 0 - && !aOriginal && !aSource && !aName) { - // Case 1. - return; + return array; + } + function filterMutate(array, f) { + let outIndex = 0; + for (let i = 0; i < array.length; i++) { + if (f(array[i], i, array)) { + array[outIndex] = array[i]; + outIndex++; + } } - else if (aGenerated && 'line' in aGenerated && 'column' in aGenerated - && aOriginal && 'line' in aOriginal && 'column' in aOriginal - && aGenerated.line > 0 && aGenerated.column >= 0 - && aOriginal.line > 0 && aOriginal.column >= 0 - && aSource) { - // Cases 2 and 3. - return; + array.length = outIndex; + } + function clear(array) { + array.length = 0; + } + function map(array, f) { + let result; + if (array) { + result = []; + for (let i = 0; i < array.length; i++) { + result.push(f(array[i], i)); + } } - else { - throw new Error('Invalid mapping: ' + JSON.stringify({ - generated: aGenerated, - source: aSource, - original: aOriginal, - name: aName - })); + return result; + } + function* mapIterator(iter, mapFn) { + for (const x of iter) { + yield mapFn(x); } - }; - -/** - * Serialize the accumulated mappings in to the stream of base 64 VLQs - * specified by the source map format. - */ -SourceMapGenerator.prototype._serializeMappings = - function SourceMapGenerator_serializeMappings() { - var previousGeneratedColumn = 0; - var previousGeneratedLine = 1; - var previousOriginalColumn = 0; - var previousOriginalLine = 0; - var previousName = 0; - var previousSource = 0; - var result = ''; - var next; - var mapping; - var nameIdx; - var sourceIdx; - - var mappings = this._mappings.toArray(); - for (var i = 0, len = mappings.length; i < len; i++) { - mapping = mappings[i]; - next = '' - - if (mapping.generatedLine !== previousGeneratedLine) { - previousGeneratedColumn = 0; - while (mapping.generatedLine !== previousGeneratedLine) { - next += ';'; - previousGeneratedLine++; - } - } - else { - if (i > 0) { - if (!util.compareByGeneratedPositionsInflated(mapping, mappings[i - 1])) { - continue; + } + function sameMap(array, f) { + if (array) { + for (let i = 0; i < array.length; i++) { + const item = array[i]; + const mapped = f(item, i); + if (item !== mapped) { + const result = array.slice(0, i); + result.push(mapped); + for (i++; i < array.length; i++) { + result.push(f(array[i], i)); } - next += ','; + return result; } } - - next += base64VLQ.encode(mapping.generatedColumn - - previousGeneratedColumn); - previousGeneratedColumn = mapping.generatedColumn; - - if (mapping.source != null) { - sourceIdx = this._sources.indexOf(mapping.source); - next += base64VLQ.encode(sourceIdx - previousSource); - previousSource = sourceIdx; - - // lines are stored 0-based in SourceMap spec version 3 - next += base64VLQ.encode(mapping.originalLine - 1 - - previousOriginalLine); - previousOriginalLine = mapping.originalLine - 1; - - next += base64VLQ.encode(mapping.originalColumn - - previousOriginalColumn); - previousOriginalColumn = mapping.originalColumn; - - if (mapping.name != null) { - nameIdx = this._names.indexOf(mapping.name); - next += base64VLQ.encode(nameIdx - previousName); - previousName = nameIdx; + } + return array; + } + function flatten(array) { + const result = []; + for (const v of array) { + if (v) { + if (isArray(v)) { + addRange(result, v); + } else { + result.push(v); } } - - result += next; } - return result; - }; - -SourceMapGenerator.prototype._generateSourcesContent = - function SourceMapGenerator_generateSourcesContent(aSources, aSourceRoot) { - return aSources.map(function (source) { - if (!this._sourcesContents) { - return null; + } + function flatMap(array, mapfn) { + let result; + if (array) { + for (let i = 0; i < array.length; i++) { + const v = mapfn(array[i], i); + if (v) { + if (isArray(v)) { + result = addRange(result, v); + } else { + result = append(result, v); + } + } } - if (aSourceRoot != null) { - source = util.relative(aSourceRoot, source); + } + return result || emptyArray; + } + function flatMapToMutable(array, mapfn) { + const result = []; + if (array) { + for (let i = 0; i < array.length; i++) { + const v = mapfn(array[i], i); + if (v) { + if (isArray(v)) { + addRange(result, v); + } else { + result.push(v); + } + } } - var key = util.toSetString(source); - return Object.prototype.hasOwnProperty.call(this._sourcesContents, key) - ? this._sourcesContents[key] - : null; - }, this); - }; - -/** - * Externalize the source map. - */ -SourceMapGenerator.prototype.toJSON = - function SourceMapGenerator_toJSON() { - var map = { - version: this._version, - sources: this._sources.toArray(), - names: this._names.toArray(), - mappings: this._serializeMappings() - }; - if (this._file != null) { - map.file = this._file; } - if (this._sourceRoot != null) { - map.sourceRoot = this._sourceRoot; + return result; + } + function* flatMapIterator(iter, mapfn) { + for (const x of iter) { + const iter2 = mapfn(x); + if (!iter2) + continue; + yield* iter2; } - if (this._sourcesContents) { - map.sourcesContent = this._generateSourcesContent(map.sources, map.sourceRoot); + } + function sameFlatMap(array, mapfn) { + let result; + if (array) { + for (let i = 0; i < array.length; i++) { + const item = array[i]; + const mapped = mapfn(item, i); + if (result || item !== mapped || isArray(mapped)) { + if (!result) { + result = array.slice(0, i); + } + if (isArray(mapped)) { + addRange(result, mapped); + } else { + result.push(mapped); + } + } + } } - - return map; - }; - -/** - * Render the source map being generated to a string. - */ -SourceMapGenerator.prototype.toString = - function SourceMapGenerator_toString() { - return JSON.stringify(this.toJSON()); - }; - -exports.h = SourceMapGenerator; - - -/***/ }), - -/***/ 3129: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { - -var __webpack_unused_export__; -/* -*- Mode: js; js-indent-level: 2; -*- */ -/* - * Copyright 2011 Mozilla Foundation and contributors - * Licensed under the New BSD license. See LICENSE or: - * http://opensource.org/licenses/BSD-3-Clause - */ - -var SourceMapGenerator = (__nccwpck_require__(66677)/* .SourceMapGenerator */ .h); -var util = __nccwpck_require__(16511); - -// Matches a Windows-style `\r\n` newline or a `\n` newline used by all other -// operating systems these days (capturing the result). -var REGEX_NEWLINE = /(\r?\n)/; - -// Newline character code for charCodeAt() comparisons -var NEWLINE_CODE = 10; - -// Private symbol for identifying `SourceNode`s when multiple versions of -// the source-map library are loaded. This MUST NOT CHANGE across -// versions! -var isSourceNode = "$$$isSourceNode$$$"; - -/** - * SourceNodes provide a way to abstract over interpolating/concatenating - * snippets of generated JavaScript source code while maintaining the line and - * column information associated with the original source code. - * - * @param aLine The original line number. - * @param aColumn The original column number. - * @param aSource The original source's filename. - * @param aChunks Optional. An array of strings which are snippets of - * generated JS, or other SourceNodes. - * @param aName The original identifier. - */ -function SourceNode(aLine, aColumn, aSource, aChunks, aName) { - this.children = []; - this.sourceContents = {}; - this.line = aLine == null ? null : aLine; - this.column = aColumn == null ? null : aColumn; - this.source = aSource == null ? null : aSource; - this.name = aName == null ? null : aName; - this[isSourceNode] = true; - if (aChunks != null) this.add(aChunks); -} - -/** - * Creates a SourceNode from generated code and a SourceMapConsumer. - * - * @param aGeneratedCode The generated code - * @param aSourceMapConsumer The SourceMap for the generated code - * @param aRelativePath Optional. The path that relative sources in the - * SourceMapConsumer should be relative to. - */ -SourceNode.fromStringWithSourceMap = - function SourceNode_fromStringWithSourceMap(aGeneratedCode, aSourceMapConsumer, aRelativePath) { - // The SourceNode we want to fill with the generated code - // and the SourceMap - var node = new SourceNode(); - - // All even indices of this array are one line of the generated code, - // while all odd indices are the newlines between two adjacent lines - // (since `REGEX_NEWLINE` captures its match). - // Processed fragments are accessed by calling `shiftNextLine`. - var remainingLines = aGeneratedCode.split(REGEX_NEWLINE); - var remainingLinesIndex = 0; - var shiftNextLine = function() { - var lineContents = getNextLine(); - // The last line of a file might not have a newline. - var newLine = getNextLine() || ""; - return lineContents + newLine; - - function getNextLine() { - return remainingLinesIndex < remainingLines.length ? - remainingLines[remainingLinesIndex++] : undefined; + return result || array; + } + function mapAllOrFail(array, mapFn) { + const result = []; + for (let i = 0; i < array.length; i++) { + const mapped = mapFn(array[i], i); + if (mapped === void 0) { + return void 0; } - }; - - // We need to remember the position of "remainingLines" - var lastGeneratedLine = 1, lastGeneratedColumn = 0; - - // The generate SourceNodes we need a code range. - // To extract it current and last mapping is used. - // Here we store the last mapping. - var lastMapping = null; - - aSourceMapConsumer.eachMapping(function (mapping) { - if (lastMapping !== null) { - // We add the code from "lastMapping" to "mapping": - // First check if there is a new line in between. - if (lastGeneratedLine < mapping.generatedLine) { - // Associate first line with "lastMapping" - addMappingWithCode(lastMapping, shiftNextLine()); - lastGeneratedLine++; - lastGeneratedColumn = 0; - // The remaining code is added without mapping - } else { - // There is no new line in between. - // Associate the code between "lastGeneratedColumn" and - // "mapping.generatedColumn" with "lastMapping" - var nextLine = remainingLines[remainingLinesIndex] || ''; - var code = nextLine.substr(0, mapping.generatedColumn - - lastGeneratedColumn); - remainingLines[remainingLinesIndex] = nextLine.substr(mapping.generatedColumn - - lastGeneratedColumn); - lastGeneratedColumn = mapping.generatedColumn; - addMappingWithCode(lastMapping, code); - // No more remaining code, continue - lastMapping = mapping; - return; + result.push(mapped); + } + return result; + } + function mapDefined(array, mapFn) { + const result = []; + if (array) { + for (let i = 0; i < array.length; i++) { + const mapped = mapFn(array[i], i); + if (mapped !== void 0) { + result.push(mapped); } } - // We add the generated code until the first mapping - // to the SourceNode without any mapping. - // Each line is added as separate string. - while (lastGeneratedLine < mapping.generatedLine) { - node.add(shiftNextLine()); - lastGeneratedLine++; - } - if (lastGeneratedColumn < mapping.generatedColumn) { - var nextLine = remainingLines[remainingLinesIndex] || ''; - node.add(nextLine.substr(0, mapping.generatedColumn)); - remainingLines[remainingLinesIndex] = nextLine.substr(mapping.generatedColumn); - lastGeneratedColumn = mapping.generatedColumn; + } + return result; + } + function* mapDefinedIterator(iter, mapFn) { + for (const x of iter) { + const value = mapFn(x); + if (value !== void 0) { + yield value; } - lastMapping = mapping; - }, this); - // We have processed all mappings. - if (remainingLinesIndex < remainingLines.length) { - if (lastMapping) { - // Associate the remaining code in the current line with "lastMapping" - addMappingWithCode(lastMapping, shiftNextLine()); + } + } + function mapDefinedEntries(map2, f) { + if (!map2) { + return void 0; + } + const result = /* @__PURE__ */ new Map(); + map2.forEach((value, key) => { + const entry = f(key, value); + if (entry !== void 0) { + const [newKey, newValue] = entry; + if (newKey !== void 0 && newValue !== void 0) { + result.set(newKey, newValue); + } } - // and add the remaining lines without any mapping - node.add(remainingLines.splice(remainingLinesIndex).join("")); + }); + return result; + } + function getOrUpdate(map2, key, callback) { + if (map2.has(key)) { + return map2.get(key); } - - // Copy sourcesContent into SourceNode - aSourceMapConsumer.sources.forEach(function (sourceFile) { - var content = aSourceMapConsumer.sourceContentFor(sourceFile); - if (content != null) { - if (aRelativePath != null) { - sourceFile = util.join(aRelativePath, sourceFile); + const value = callback(); + map2.set(key, value); + return value; + } + function tryAddToSet(set, value) { + if (!set.has(value)) { + set.add(value); + return true; + } + return false; + } + function* singleIterator(value) { + yield value; + } + function spanMap(array, keyfn, mapfn) { + let result; + if (array) { + result = []; + const len = array.length; + let previousKey; + let key; + let start = 0; + let pos = 0; + while (start < len) { + while (pos < len) { + const value = array[pos]; + key = keyfn(value, pos); + if (pos === 0) { + previousKey = key; + } else if (key !== previousKey) { + break; + } + pos++; } - node.setSourceContent(sourceFile, content); + if (start < pos) { + const v = mapfn(array.slice(start, pos), previousKey, start, pos); + if (v) { + result.push(v); + } + start = pos; + } + previousKey = key; + pos++; } + } + return result; + } + function mapEntries(map2, f) { + if (!map2) { + return void 0; + } + const result = /* @__PURE__ */ new Map(); + map2.forEach((value, key) => { + const [newKey, newValue] = f(key, value); + result.set(newKey, newValue); }); - - return node; - - function addMappingWithCode(mapping, code) { - if (mapping === null || mapping.source === undefined) { - node.add(code); + return result; + } + function some(array, predicate) { + if (array) { + if (predicate) { + for (const v of array) { + if (predicate(v)) { + return true; + } + } } else { - var source = aRelativePath - ? util.join(aRelativePath, mapping.source) - : mapping.source; - node.add(new SourceNode(mapping.originalLine, - mapping.originalColumn, - source, - code, - mapping.name)); + return array.length > 0; } } - }; - -/** - * Add a chunk of generated JS to this source node. - * - * @param aChunk A string snippet of generated JS code, another instance of - * SourceNode, or an array where each member is one of those things. - */ -SourceNode.prototype.add = function SourceNode_add(aChunk) { - if (Array.isArray(aChunk)) { - aChunk.forEach(function (chunk) { - this.add(chunk); - }, this); + return false; } - else if (aChunk[isSourceNode] || typeof aChunk === "string") { - if (aChunk) { - this.children.push(aChunk); + function getRangesWhere(arr, pred, cb) { + let start; + for (let i = 0; i < arr.length; i++) { + if (pred(arr[i])) { + start = start === void 0 ? i : start; + } else { + if (start !== void 0) { + cb(start, i); + start = void 0; + } + } } + if (start !== void 0) + cb(start, arr.length); } - else { - throw new TypeError( - "Expected a SourceNode, string, or an array of SourceNodes and strings. Got " + aChunk - ); + function concatenate(array1, array2) { + if (!some(array2)) + return array1; + if (!some(array1)) + return array2; + return [...array1, ...array2]; } - return this; -}; - -/** - * Add a chunk of generated JS to the beginning of this source node. - * - * @param aChunk A string snippet of generated JS code, another instance of - * SourceNode, or an array where each member is one of those things. - */ -SourceNode.prototype.prepend = function SourceNode_prepend(aChunk) { - if (Array.isArray(aChunk)) { - for (var i = aChunk.length-1; i >= 0; i--) { - this.prepend(aChunk[i]); - } + function selectIndex(_, i) { + return i; } - else if (aChunk[isSourceNode] || typeof aChunk === "string") { - this.children.unshift(aChunk); + function indicesOf(array) { + return array.map(selectIndex); } - else { - throw new TypeError( - "Expected a SourceNode, string, or an array of SourceNodes and strings. Got " + aChunk - ); + function deduplicateRelational(array, equalityComparer, comparer) { + const indices = indicesOf(array); + stableSortIndices(array, indices, comparer); + let last2 = array[indices[0]]; + const deduplicated = [indices[0]]; + for (let i = 1; i < indices.length; i++) { + const index = indices[i]; + const item = array[index]; + if (!equalityComparer(last2, item)) { + deduplicated.push(index); + last2 = item; + } + } + deduplicated.sort(); + return deduplicated.map((i) => array[i]); } - return this; -}; - -/** - * Walk over the tree of JS snippets in this node and its children. The - * walking function is called once for each snippet of JS and is passed that - * snippet and the its original associated source's line/column location. - * - * @param aFn The traversal function. - */ -SourceNode.prototype.walk = function SourceNode_walk(aFn) { - var chunk; - for (var i = 0, len = this.children.length; i < len; i++) { - chunk = this.children[i]; - if (chunk[isSourceNode]) { - chunk.walk(aFn); + function deduplicateEquality(array, equalityComparer) { + const result = []; + for (const item of array) { + pushIfUnique(result, item, equalityComparer); } - else { - if (chunk !== '') { - aFn(chunk, { source: this.source, - line: this.line, - column: this.column, - name: this.name }); + return result; + } + function deduplicate(array, equalityComparer, comparer) { + return array.length === 0 ? [] : array.length === 1 ? array.slice() : comparer ? deduplicateRelational(array, equalityComparer, comparer) : deduplicateEquality(array, equalityComparer); + } + function deduplicateSorted(array, comparer) { + if (array.length === 0) + return emptyArray; + let last2 = array[0]; + const deduplicated = [last2]; + for (let i = 1; i < array.length; i++) { + const next = array[i]; + switch (comparer(next, last2)) { + case true: + case 0 /* EqualTo */: + continue; + case -1 /* LessThan */: + return Debug.fail("Array is unsorted."); } + deduplicated.push(last2 = next); } + return deduplicated; } -}; - -/** - * Like `String.prototype.join` except for SourceNodes. Inserts `aStr` between - * each of `this.children`. - * - * @param aSep The separator. - */ -SourceNode.prototype.join = function SourceNode_join(aSep) { - var newChildren; - var i; - var len = this.children.length; - if (len > 0) { - newChildren = []; - for (i = 0; i < len-1; i++) { - newChildren.push(this.children[i]); - newChildren.push(aSep); + function createSortedArray() { + return []; + } + function insertSorted(array, insert, compare, allowDuplicates) { + if (array.length === 0) { + array.push(insert); + return true; } - newChildren.push(this.children[i]); - this.children = newChildren; + const insertIndex = binarySearch(array, insert, identity, compare); + if (insertIndex < 0) { + array.splice(~insertIndex, 0, insert); + return true; + } + if (allowDuplicates) { + array.splice(insertIndex, 0, insert); + return true; + } + return false; } - return this; -}; - -/** - * Call String.prototype.replace on the very right-most source snippet. Useful - * for trimming whitespace from the end of a source node, etc. - * - * @param aPattern The pattern to replace. - * @param aReplacement The thing to replace the pattern with. - */ -SourceNode.prototype.replaceRight = function SourceNode_replaceRight(aPattern, aReplacement) { - var lastChild = this.children[this.children.length - 1]; - if (lastChild[isSourceNode]) { - lastChild.replaceRight(aPattern, aReplacement); + function sortAndDeduplicate(array, comparer, equalityComparer) { + return deduplicateSorted(sort(array, comparer), equalityComparer || comparer || compareStringsCaseSensitive); } - else if (typeof lastChild === 'string') { - this.children[this.children.length - 1] = lastChild.replace(aPattern, aReplacement); + function arrayIsSorted(array, comparer) { + if (array.length < 2) + return true; + for (let i = 1, len = array.length; i < len; i++) { + if (comparer(array[i - 1], array[i]) === 1 /* GreaterThan */) { + return false; + } + } + return true; } - else { - this.children.push(''.replace(aPattern, aReplacement)); + function detectSortCaseSensitivity(array, getString, compareStringsCaseSensitive2, compareStringsCaseInsensitive2) { + let kind = 3 /* Both */; + if (array.length < 2) + return kind; + let prevElement = getString(array[0]); + for (let i = 1, len = array.length; i < len && kind !== 0 /* None */; i++) { + const element = getString(array[i]); + if (kind & 1 /* CaseSensitive */ && compareStringsCaseSensitive2(prevElement, element) > 0) { + kind &= ~1 /* CaseSensitive */; + } + if (kind & 2 /* CaseInsensitive */ && compareStringsCaseInsensitive2(prevElement, element) > 0) { + kind &= ~2 /* CaseInsensitive */; + } + prevElement = element; + } + return kind; } - return this; -}; - -/** - * Set the source content for a source file. This will be added to the SourceMapGenerator - * in the sourcesContent field. - * - * @param aSourceFile The filename of the source file - * @param aSourceContent The content of the source file - */ -SourceNode.prototype.setSourceContent = - function SourceNode_setSourceContent(aSourceFile, aSourceContent) { - this.sourceContents[util.toSetString(aSourceFile)] = aSourceContent; - }; - -/** - * Walk over the tree of SourceNodes. The walking function is called for each - * source file content and is passed the filename and source content. - * - * @param aFn The traversal function. - */ -SourceNode.prototype.walkSourceContents = - function SourceNode_walkSourceContents(aFn) { - for (var i = 0, len = this.children.length; i < len; i++) { - if (this.children[i][isSourceNode]) { - this.children[i].walkSourceContents(aFn); + function arrayIsEqualTo(array1, array2, equalityComparer = equateValues) { + if (!array1 || !array2) { + return array1 === array2; + } + if (array1.length !== array2.length) { + return false; + } + for (let i = 0; i < array1.length; i++) { + if (!equalityComparer(array1[i], array2[i], i)) { + return false; } } - - var sources = Object.keys(this.sourceContents); - for (var i = 0, len = sources.length; i < len; i++) { - aFn(util.fromSetString(sources[i]), this.sourceContents[sources[i]]); + return true; + } + function compact(array) { + let result; + if (array) { + for (let i = 0; i < array.length; i++) { + const v = array[i]; + if (result || !v) { + if (!result) { + result = array.slice(0, i); + } + if (v) { + result.push(v); + } + } + } } - }; - -/** - * Return the string representation of this source node. Walks over the tree - * and concatenates all the various snippets together to one string. - */ -SourceNode.prototype.toString = function SourceNode_toString() { - var str = ""; - this.walk(function (chunk) { - str += chunk; - }); - return str; -}; - -/** - * Returns the string representation of this source node along with a source - * map. - */ -SourceNode.prototype.toStringWithSourceMap = function SourceNode_toStringWithSourceMap(aArgs) { - var generated = { - code: "", - line: 1, - column: 0 - }; - var map = new SourceMapGenerator(aArgs); - var sourceMappingActive = false; - var lastOriginalSource = null; - var lastOriginalLine = null; - var lastOriginalColumn = null; - var lastOriginalName = null; - this.walk(function (chunk, original) { - generated.code += chunk; - if (original.source !== null - && original.line !== null - && original.column !== null) { - if(lastOriginalSource !== original.source - || lastOriginalLine !== original.line - || lastOriginalColumn !== original.column - || lastOriginalName !== original.name) { - map.addMapping({ - source: original.source, - original: { - line: original.line, - column: original.column - }, - generated: { - line: generated.line, - column: generated.column - }, - name: original.name - }); - } - lastOriginalSource = original.source; - lastOriginalLine = original.line; - lastOriginalColumn = original.column; - lastOriginalName = original.name; - sourceMappingActive = true; - } else if (sourceMappingActive) { - map.addMapping({ - generated: { - line: generated.line, - column: generated.column - } - }); - lastOriginalSource = null; - sourceMappingActive = false; - } - for (var idx = 0, length = chunk.length; idx < length; idx++) { - if (chunk.charCodeAt(idx) === NEWLINE_CODE) { - generated.line++; - generated.column = 0; - // Mappings end at eol - if (idx + 1 === length) { - lastOriginalSource = null; - sourceMappingActive = false; - } else if (sourceMappingActive) { - map.addMapping({ - source: original.source, - original: { - line: original.line, - column: original.column - }, - generated: { - line: generated.line, - column: generated.column - }, - name: original.name - }); + return result || array; + } + function relativeComplement(arrayA, arrayB, comparer) { + if (!arrayB || !arrayA || arrayB.length === 0 || arrayA.length === 0) + return arrayB; + const result = []; + loopB: + for (let offsetA = 0, offsetB = 0; offsetB < arrayB.length; offsetB++) { + if (offsetB > 0) { + Debug.assertGreaterThanOrEqual(comparer(arrayB[offsetB], arrayB[offsetB - 1]), 0 /* EqualTo */); } - } else { - generated.column++; + loopA: + for (const startA = offsetA; offsetA < arrayA.length; offsetA++) { + if (offsetA > startA) { + Debug.assertGreaterThanOrEqual(comparer(arrayA[offsetA], arrayA[offsetA - 1]), 0 /* EqualTo */); + } + switch (comparer(arrayB[offsetB], arrayA[offsetA])) { + case -1 /* LessThan */: + result.push(arrayB[offsetB]); + continue loopB; + case 0 /* EqualTo */: + continue loopB; + case 1 /* GreaterThan */: + continue loopA; + } + } } - } - }); - this.walkSourceContents(function (sourceFile, sourceContent) { - map.setSourceContent(sourceFile, sourceContent); - }); - - return { code: generated.code, map: map }; -}; - -__webpack_unused_export__ = SourceNode; - - -/***/ }), - -/***/ 16511: -/***/ ((__unused_webpack_module, exports) => { - -/* -*- Mode: js; js-indent-level: 2; -*- */ -/* - * Copyright 2011 Mozilla Foundation and contributors - * Licensed under the New BSD license. See LICENSE or: - * http://opensource.org/licenses/BSD-3-Clause - */ - -/** - * This is a helper function for getting values from parameter/options - * objects. - * - * @param args The object we are extracting values from - * @param name The name of the property we are getting. - * @param defaultValue An optional value to return if the property is missing - * from the object. If this is not specified and the property is missing, an - * error will be thrown. - */ -function getArg(aArgs, aName, aDefaultValue) { - if (aName in aArgs) { - return aArgs[aName]; - } else if (arguments.length === 3) { - return aDefaultValue; - } else { - throw new Error('"' + aName + '" is a required argument.'); - } -} -exports.getArg = getArg; - -var urlRegexp = /^(?:([\w+\-.]+):)?\/\/(?:(\w+:\w+)@)?([\w.-]*)(?::(\d+))?(.*)$/; -var dataUrlRegexp = /^data:.+\,.+$/; - -function urlParse(aUrl) { - var match = aUrl.match(urlRegexp); - if (!match) { - return null; - } - return { - scheme: match[1], - auth: match[2], - host: match[3], - port: match[4], - path: match[5] - }; -} -exports.urlParse = urlParse; - -function urlGenerate(aParsedUrl) { - var url = ''; - if (aParsedUrl.scheme) { - url += aParsedUrl.scheme + ':'; - } - url += '//'; - if (aParsedUrl.auth) { - url += aParsedUrl.auth + '@'; - } - if (aParsedUrl.host) { - url += aParsedUrl.host; + return result; } - if (aParsedUrl.port) { - url += ":" + aParsedUrl.port + function append(to, value) { + if (value === void 0) + return to; + if (to === void 0) + return [value]; + to.push(value); + return to; } - if (aParsedUrl.path) { - url += aParsedUrl.path; + function combine(xs, ys) { + if (xs === void 0) + return ys; + if (ys === void 0) + return xs; + if (isArray(xs)) + return isArray(ys) ? concatenate(xs, ys) : append(xs, ys); + if (isArray(ys)) + return append(ys, xs); + return [xs, ys]; } - return url; -} -exports.urlGenerate = urlGenerate; - -/** - * Normalizes a path, or the path portion of a URL: - * - * - Replaces consecutive slashes with one slash. - * - Removes unnecessary '.' parts. - * - Removes unnecessary '/..' parts. - * - * Based on code in the Node.js 'path' core module. - * - * @param aPath The path or url to normalize. - */ -function normalize(aPath) { - var path = aPath; - var url = urlParse(aPath); - if (url) { - if (!url.path) { - return aPath; - } - path = url.path; + function toOffset(array, offset) { + return offset < 0 ? array.length + offset : offset; } - var isAbsolute = exports.isAbsolute(path); - - var parts = path.split(/\/+/); - for (var part, up = 0, i = parts.length - 1; i >= 0; i--) { - part = parts[i]; - if (part === '.') { - parts.splice(i, 1); - } else if (part === '..') { - up++; - } else if (up > 0) { - if (part === '') { - // The first part is blank if the path is absolute. Trying to go - // above the root is a no-op. Therefore we can remove all '..' parts - // directly after the root. - parts.splice(i + 1, up); - up = 0; - } else { - parts.splice(i, 2); - up--; + function addRange(to, from, start, end) { + if (from === void 0 || from.length === 0) + return to; + if (to === void 0) + return from.slice(start, end); + start = start === void 0 ? 0 : toOffset(from, start); + end = end === void 0 ? from.length : toOffset(from, end); + for (let i = start; i < end && i < from.length; i++) { + if (from[i] !== void 0) { + to.push(from[i]); } } + return to; } - path = parts.join('/'); - - if (path === '') { - path = isAbsolute ? '/' : '.'; - } - - if (url) { - url.path = path; - return urlGenerate(url); + function pushIfUnique(array, toAdd, equalityComparer) { + if (contains(array, toAdd, equalityComparer)) { + return false; + } else { + array.push(toAdd); + return true; + } } - return path; -} -exports.normalize = normalize; - -/** - * Joins two paths/URLs. - * - * @param aRoot The root path or URL. - * @param aPath The path or URL to be joined with the root. - * - * - If aPath is a URL or a data URI, aPath is returned, unless aPath is a - * scheme-relative URL: Then the scheme of aRoot, if any, is prepended - * first. - * - Otherwise aPath is a path. If aRoot is a URL, then its path portion - * is updated with the result and aRoot is returned. Otherwise the result - * is returned. - * - If aPath is absolute, the result is aPath. - * - Otherwise the two paths are joined with a slash. - * - Joining for example 'http://' and 'www.example.com' is also supported. - */ -function join(aRoot, aPath) { - if (aRoot === "") { - aRoot = "."; + function appendIfUnique(array, toAdd, equalityComparer) { + if (array) { + pushIfUnique(array, toAdd, equalityComparer); + return array; + } else { + return [toAdd]; + } } - if (aPath === "") { - aPath = "."; + function stableSortIndices(array, indices, comparer) { + indices.sort((x, y) => comparer(array[x], array[y]) || compareValues(x, y)); } - var aPathUrl = urlParse(aPath); - var aRootUrl = urlParse(aRoot); - if (aRootUrl) { - aRoot = aRootUrl.path || '/'; + function sort(array, comparer) { + return array.length === 0 ? array : array.slice().sort(comparer); } - - // `join(foo, '//www.example.org')` - if (aPathUrl && !aPathUrl.scheme) { - if (aRootUrl) { - aPathUrl.scheme = aRootUrl.scheme; + function* arrayReverseIterator(array) { + for (let i = array.length - 1; i >= 0; i--) { + yield array[i]; } - return urlGenerate(aPathUrl); } - - if (aPathUrl || aPath.match(dataUrlRegexp)) { - return aPath; - } - - // `join('http://', 'www.example.com')` - if (aRootUrl && !aRootUrl.host && !aRootUrl.path) { - aRootUrl.host = aPath; - return urlGenerate(aRootUrl); + function stableSort(array, comparer) { + const indices = indicesOf(array); + stableSortIndices(array, indices, comparer); + return indices.map((i) => array[i]); } - - var joined = aPath.charAt(0) === '/' - ? aPath - : normalize(aRoot.replace(/\/+$/, '') + '/' + aPath); - - if (aRootUrl) { - aRootUrl.path = joined; - return urlGenerate(aRootUrl); + function rangeEquals(array1, array2, pos, end) { + while (pos < end) { + if (array1[pos] !== array2[pos]) { + return false; + } + pos++; + } + return true; } - return joined; -} -exports.join = join; - -exports.isAbsolute = function (aPath) { - return aPath.charAt(0) === '/' || urlRegexp.test(aPath); -}; - -/** - * Make a path relative to a URL or another path. - * - * @param aRoot The root path or URL. - * @param aPath The path or URL to be made relative to aRoot. - */ -function relative(aRoot, aPath) { - if (aRoot === "") { - aRoot = "."; + function firstOrUndefined(array) { + return array === void 0 || array.length === 0 ? void 0 : array[0]; } - - aRoot = aRoot.replace(/\/$/, ''); - - // It is possible for the path to be above the root. In this case, simply - // checking whether the root is a prefix of the path won't work. Instead, we - // need to remove components from the root one by one, until either we find - // a prefix that fits, or we run out of components to remove. - var level = 0; - while (aPath.indexOf(aRoot + '/') !== 0) { - var index = aRoot.lastIndexOf("/"); - if (index < 0) { - return aPath; - } - - // If the only part of the root that is left is the scheme (i.e. http://, - // file:///, etc.), one or more slashes (/), or simply nothing at all, we - // have exhausted all components, so the path is not relative to the root. - aRoot = aRoot.slice(0, index); - if (aRoot.match(/^([^\/]+:\/)?\/*$/)) { - return aPath; + function firstOrUndefinedIterator(iter) { + if (iter) { + for (const value of iter) { + return value; + } } - - ++level; + return void 0; } - - // Make sure we add a "../" for each component we removed from the root. - return Array(level + 1).join("../") + aPath.substr(aRoot.length + 1); -} -exports.relative = relative; - -var supportsNullProto = (function () { - var obj = Object.create(null); - return !('__proto__' in obj); -}()); - -function identity (s) { - return s; -} - -/** - * Because behavior goes wacky when you set `__proto__` on objects, we - * have to prefix all the strings in our set with an arbitrary character. - * - * See https://github.com/mozilla/source-map/pull/31 and - * https://github.com/mozilla/source-map/issues/30 - * - * @param String aStr - */ -function toSetString(aStr) { - if (isProtoString(aStr)) { - return '$' + aStr; + function first(array) { + Debug.assert(array.length !== 0); + return array[0]; } - - return aStr; -} -exports.toSetString = supportsNullProto ? identity : toSetString; - -function fromSetString(aStr) { - if (isProtoString(aStr)) { - return aStr.slice(1); + function firstIterator(iter) { + for (const value of iter) { + return value; + } + Debug.fail("iterator is empty"); } - - return aStr; -} -exports.fromSetString = supportsNullProto ? identity : fromSetString; - -function isProtoString(s) { - if (!s) { - return false; + function lastOrUndefined(array) { + return array === void 0 || array.length === 0 ? void 0 : array[array.length - 1]; } - - var length = s.length; - - if (length < 9 /* "__proto__".length */) { - return false; + function last(array) { + Debug.assert(array.length !== 0); + return array[array.length - 1]; } - - if (s.charCodeAt(length - 1) !== 95 /* '_' */ || - s.charCodeAt(length - 2) !== 95 /* '_' */ || - s.charCodeAt(length - 3) !== 111 /* 'o' */ || - s.charCodeAt(length - 4) !== 116 /* 't' */ || - s.charCodeAt(length - 5) !== 111 /* 'o' */ || - s.charCodeAt(length - 6) !== 114 /* 'r' */ || - s.charCodeAt(length - 7) !== 112 /* 'p' */ || - s.charCodeAt(length - 8) !== 95 /* '_' */ || - s.charCodeAt(length - 9) !== 95 /* '_' */) { - return false; + function singleOrUndefined(array) { + return array && array.length === 1 ? array[0] : void 0; } - - for (var i = length - 10; i >= 0; i--) { - if (s.charCodeAt(i) !== 36 /* '$' */) { - return false; - } + function single(array) { + return Debug.checkDefined(singleOrUndefined(array)); } - - return true; -} - -/** - * Comparator between two mappings where the original positions are compared. - * - * Optionally pass in `true` as `onlyCompareGenerated` to consider two - * mappings with the same original source/line/column, but different generated - * line and column the same. Useful when searching for a mapping with a - * stubbed out mapping. - */ -function compareByOriginalPositions(mappingA, mappingB, onlyCompareOriginal) { - var cmp = strcmp(mappingA.source, mappingB.source); - if (cmp !== 0) { - return cmp; + function singleOrMany(array) { + return array && array.length === 1 ? array[0] : array; } - - cmp = mappingA.originalLine - mappingB.originalLine; - if (cmp !== 0) { - return cmp; + function replaceElement(array, index, value) { + const result = array.slice(0); + result[index] = value; + return result; } - - cmp = mappingA.originalColumn - mappingB.originalColumn; - if (cmp !== 0 || onlyCompareOriginal) { - return cmp; + function binarySearch(array, value, keySelector, keyComparer, offset) { + return binarySearchKey(array, keySelector(value), keySelector, keyComparer, offset); } - - cmp = mappingA.generatedColumn - mappingB.generatedColumn; - if (cmp !== 0) { - return cmp; + function binarySearchKey(array, key, keySelector, keyComparer, offset) { + if (!some(array)) { + return -1; + } + let low = offset || 0; + let high = array.length - 1; + while (low <= high) { + const middle = low + (high - low >> 1); + const midKey = keySelector(array[middle], middle); + switch (keyComparer(midKey, key)) { + case -1 /* LessThan */: + low = middle + 1; + break; + case 0 /* EqualTo */: + return middle; + case 1 /* GreaterThan */: + high = middle - 1; + break; + } + } + return ~low; } - - cmp = mappingA.generatedLine - mappingB.generatedLine; - if (cmp !== 0) { - return cmp; + function reduceLeft(array, f, initial, start, count) { + if (array && array.length > 0) { + const size = array.length; + if (size > 0) { + let pos = start === void 0 || start < 0 ? 0 : start; + const end = count === void 0 || pos + count > size - 1 ? size - 1 : pos + count; + let result; + if (arguments.length <= 2) { + result = array[pos]; + pos++; + } else { + result = initial; + } + while (pos <= end) { + result = f(result, array[pos], pos); + pos++; + } + return result; + } + } + return initial; } - - return strcmp(mappingA.name, mappingB.name); -} -exports.compareByOriginalPositions = compareByOriginalPositions; - -/** - * Comparator between two mappings with deflated source and name indices where - * the generated positions are compared. - * - * Optionally pass in `true` as `onlyCompareGenerated` to consider two - * mappings with the same generated line and column, but different - * source/name/original line and column the same. Useful when searching for a - * mapping with a stubbed out mapping. - */ -function compareByGeneratedPositionsDeflated(mappingA, mappingB, onlyCompareGenerated) { - var cmp = mappingA.generatedLine - mappingB.generatedLine; - if (cmp !== 0) { - return cmp; + function hasProperty(map2, key) { + return hasOwnProperty.call(map2, key); } - - cmp = mappingA.generatedColumn - mappingB.generatedColumn; - if (cmp !== 0 || onlyCompareGenerated) { - return cmp; + function getProperty(map2, key) { + return hasOwnProperty.call(map2, key) ? map2[key] : void 0; } - - cmp = strcmp(mappingA.source, mappingB.source); - if (cmp !== 0) { - return cmp; + function getOwnKeys(map2) { + const keys = []; + for (const key in map2) { + if (hasOwnProperty.call(map2, key)) { + keys.push(key); + } + } + return keys; } - - cmp = mappingA.originalLine - mappingB.originalLine; - if (cmp !== 0) { - return cmp; + function getAllKeys(obj) { + const result = []; + do { + const names = Object.getOwnPropertyNames(obj); + for (const name of names) { + pushIfUnique(result, name); + } + } while (obj = Object.getPrototypeOf(obj)); + return result; } - - cmp = mappingA.originalColumn - mappingB.originalColumn; - if (cmp !== 0) { - return cmp; + function getOwnValues(collection) { + const values = []; + for (const key in collection) { + if (hasOwnProperty.call(collection, key)) { + values.push(collection[key]); + } + } + return values; } - - return strcmp(mappingA.name, mappingB.name); -} -exports.compareByGeneratedPositionsDeflated = compareByGeneratedPositionsDeflated; - -function strcmp(aStr1, aStr2) { - if (aStr1 === aStr2) { - return 0; + function arrayOf(count, f) { + const result = new Array(count); + for (let i = 0; i < count; i++) { + result[i] = f(i); + } + return result; } - - if (aStr1 === null) { - return 1; // aStr2 !== null + function arrayFrom(iterator, map2) { + const result = []; + for (const value of iterator) { + result.push(map2 ? map2(value) : value); + } + return result; } - - if (aStr2 === null) { - return -1; // aStr1 !== null + function assign(t, ...args) { + for (const arg of args) { + if (arg === void 0) + continue; + for (const p in arg) { + if (hasProperty(arg, p)) { + t[p] = arg[p]; + } + } + } + return t; } - - if (aStr1 > aStr2) { - return 1; + function equalOwnProperties(left, right, equalityComparer = equateValues) { + if (left === right) + return true; + if (!left || !right) + return false; + for (const key in left) { + if (hasOwnProperty.call(left, key)) { + if (!hasOwnProperty.call(right, key)) + return false; + if (!equalityComparer(left[key], right[key])) + return false; + } + } + for (const key in right) { + if (hasOwnProperty.call(right, key)) { + if (!hasOwnProperty.call(left, key)) + return false; + } + } + return true; } - - return -1; -} - -/** - * Comparator between two mappings with inflated source and name strings where - * the generated positions are compared. - */ -function compareByGeneratedPositionsInflated(mappingA, mappingB) { - var cmp = mappingA.generatedLine - mappingB.generatedLine; - if (cmp !== 0) { - return cmp; + function arrayToMap(array, makeKey, makeValue = identity) { + const result = /* @__PURE__ */ new Map(); + for (const value of array) { + const key = makeKey(value); + if (key !== void 0) + result.set(key, makeValue(value)); + } + return result; } - - cmp = mappingA.generatedColumn - mappingB.generatedColumn; - if (cmp !== 0) { - return cmp; + function arrayToNumericMap(array, makeKey, makeValue = identity) { + const result = []; + for (const value of array) { + result[makeKey(value)] = makeValue(value); + } + return result; } - - cmp = strcmp(mappingA.source, mappingB.source); - if (cmp !== 0) { - return cmp; + function arrayToMultiMap(values, makeKey, makeValue = identity) { + const result = createMultiMap(); + for (const value of values) { + result.add(makeKey(value), makeValue(value)); + } + return result; } - - cmp = mappingA.originalLine - mappingB.originalLine; - if (cmp !== 0) { - return cmp; + function group(values, getGroupId, resultSelector = identity) { + return arrayFrom(arrayToMultiMap(values, getGroupId).values(), resultSelector); } - - cmp = mappingA.originalColumn - mappingB.originalColumn; - if (cmp !== 0) { - return cmp; + function groupBy(values, keySelector) { + const result = {}; + if (values) { + for (const value of values) { + const key = `${keySelector(value)}`; + const array = result[key] ?? (result[key] = []); + array.push(value); + } + } + return result; } - - return strcmp(mappingA.name, mappingB.name); -} -exports.compareByGeneratedPositionsInflated = compareByGeneratedPositionsInflated; - -/** - * Strip any JSON XSSI avoidance prefix from the string (as documented - * in the source maps specification), and then parse the string as - * JSON. - */ -function parseSourceMapInput(str) { - return JSON.parse(str.replace(/^\)]}'[^\n]*\n/, '')); -} -exports.parseSourceMapInput = parseSourceMapInput; - -/** - * Compute the URL of a source given the the source root, the source's - * URL, and the source map's URL. - */ -function computeSourceURL(sourceRoot, sourceURL, sourceMapURL) { - sourceURL = sourceURL || ''; - - if (sourceRoot) { - // This follows what Chrome does. - if (sourceRoot[sourceRoot.length - 1] !== '/' && sourceURL[0] !== '/') { - sourceRoot += '/'; + function clone(object) { + const result = {}; + for (const id in object) { + if (hasOwnProperty.call(object, id)) { + result[id] = object[id]; + } } - // The spec says: - // Line 4: An optional source root, useful for relocating source - // files on a server or removing repeated values in the - // “sources” entry. This value is prepended to the individual - // entries in the “source” field. - sourceURL = sourceRoot + sourceURL; + return result; } - - // Historically, SourceMapConsumer did not take the sourceMapURL as - // a parameter. This mode is still somewhat supported, which is why - // this code block is conditional. However, it's preferable to pass - // the source map URL to SourceMapConsumer, so that this function - // can implement the source URL resolution algorithm as outlined in - // the spec. This block is basically the equivalent of: - // new URL(sourceURL, sourceMapURL).toString() - // ... except it avoids using URL, which wasn't available in the - // older releases of node still supported by this library. - // - // The spec says: - // If the sources are not absolute URLs after prepending of the - // “sourceRoot”, the sources are resolved relative to the - // SourceMap (like resolving script src in a html document). - if (sourceMapURL) { - var parsed = urlParse(sourceMapURL); - if (!parsed) { - throw new Error("sourceMapURL could not be parsed"); + function extend(first2, second) { + const result = {}; + for (const id in second) { + if (hasOwnProperty.call(second, id)) { + result[id] = second[id]; + } } - if (parsed.path) { - // Strip the last path component, but keep the "/". - var index = parsed.path.lastIndexOf('/'); - if (index >= 0) { - parsed.path = parsed.path.substring(0, index + 1); + for (const id in first2) { + if (hasOwnProperty.call(first2, id)) { + result[id] = first2[id]; } } - sourceURL = join(urlGenerate(parsed), sourceURL); - } - - return normalize(sourceURL); -} -exports.computeSourceURL = computeSourceURL; - - -/***/ }), - -/***/ 36096: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { - -/* - * Copyright 2009-2011 Mozilla Foundation and contributors - * Licensed under the New BSD license. See LICENSE.txt or: - * http://opensource.org/licenses/BSD-3-Clause - */ -/* unused reexport */ __nccwpck_require__(66677)/* .SourceMapGenerator */ .h; -exports.SourceMapConsumer = __nccwpck_require__(52718).SourceMapConsumer; -/* unused reexport */ __nccwpck_require__(3129); - - -/***/ }), - -/***/ 26590: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { - -"use strict"; -// Copyright Joyent, Inc. and other Node contributors. -// -// 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. - - - -/**/ - -var Buffer = (__nccwpck_require__(87128).Buffer); -/**/ - -var isEncoding = Buffer.isEncoding || function (encoding) { - encoding = '' + encoding; - switch (encoding && encoding.toLowerCase()) { - case 'hex':case 'utf8':case 'utf-8':case 'ascii':case 'binary':case 'base64':case 'ucs2':case 'ucs-2':case 'utf16le':case 'utf-16le':case 'raw': - return true; - default: - return false; + return result; } -}; - -function _normalizeEncoding(enc) { - if (!enc) return 'utf8'; - var retried; - while (true) { - switch (enc) { - case 'utf8': - case 'utf-8': - return 'utf8'; - case 'ucs2': - case 'ucs-2': - case 'utf16le': - case 'utf-16le': - return 'utf16le'; - case 'latin1': - case 'binary': - return 'latin1'; - case 'base64': - case 'ascii': - case 'hex': - return enc; - default: - if (retried) return; // undefined - enc = ('' + enc).toLowerCase(); - retried = true; + function copyProperties(first2, second) { + for (const id in second) { + if (hasOwnProperty.call(second, id)) { + first2[id] = second[id]; + } } } -}; - -// Do not cache `Buffer.isEncoding` when checking encoding names as some -// modules monkey-patch it to support additional encodings -function normalizeEncoding(enc) { - var nenc = _normalizeEncoding(enc); - if (typeof nenc !== 'string' && (Buffer.isEncoding === isEncoding || !isEncoding(enc))) throw new Error('Unknown encoding: ' + enc); - return nenc || enc; -} - -// StringDecoder provides an interface for efficiently splitting a series of -// buffers into a series of JS strings without breaking apart multi-byte -// characters. -exports.s = StringDecoder; -function StringDecoder(encoding) { - this.encoding = normalizeEncoding(encoding); - var nb; - switch (this.encoding) { - case 'utf16le': - this.text = utf16Text; - this.end = utf16End; - nb = 4; - break; - case 'utf8': - this.fillLast = utf8FillLast; - nb = 4; - break; - case 'base64': - this.text = base64Text; - this.end = base64End; - nb = 3; - break; - default: - this.write = simpleWrite; - this.end = simpleEnd; - return; + function maybeBind(obj, fn) { + return fn ? fn.bind(obj) : void 0; } - this.lastNeed = 0; - this.lastTotal = 0; - this.lastChar = Buffer.allocUnsafe(nb); -} - -StringDecoder.prototype.write = function (buf) { - if (buf.length === 0) return ''; - var r; - var i; - if (this.lastNeed) { - r = this.fillLast(buf); - if (r === undefined) return ''; - i = this.lastNeed; - this.lastNeed = 0; - } else { - i = 0; + function createMultiMap() { + const map2 = /* @__PURE__ */ new Map(); + map2.add = multiMapAdd; + map2.remove = multiMapRemove; + return map2; } - if (i < buf.length) return r ? r + this.text(buf, i) : this.text(buf, i); - return r || ''; -}; - -StringDecoder.prototype.end = utf8End; - -// Returns only complete characters in a Buffer -StringDecoder.prototype.text = utf8Text; - -// Attempts to complete a partial non-UTF-8 character using bytes from a Buffer -StringDecoder.prototype.fillLast = function (buf) { - if (this.lastNeed <= buf.length) { - buf.copy(this.lastChar, this.lastTotal - this.lastNeed, 0, this.lastNeed); - return this.lastChar.toString(this.encoding, 0, this.lastTotal); + function multiMapAdd(key, value) { + let values = this.get(key); + if (values) { + values.push(value); + } else { + this.set(key, values = [value]); + } + return values; } - buf.copy(this.lastChar, this.lastTotal - this.lastNeed, 0, buf.length); - this.lastNeed -= buf.length; -}; - -// Checks the type of a UTF-8 byte, whether it's ASCII, a leading byte, or a -// continuation byte. If an invalid byte is detected, -2 is returned. -function utf8CheckByte(byte) { - if (byte <= 0x7F) return 0;else if (byte >> 5 === 0x06) return 2;else if (byte >> 4 === 0x0E) return 3;else if (byte >> 3 === 0x1E) return 4; - return byte >> 6 === 0x02 ? -1 : -2; -} - -// Checks at most 3 bytes at the end of a Buffer in order to detect an -// incomplete multi-byte UTF-8 character. The total number of bytes (2, 3, or 4) -// needed to complete the UTF-8 character (if applicable) are returned. -function utf8CheckIncomplete(self, buf, i) { - var j = buf.length - 1; - if (j < i) return 0; - var nb = utf8CheckByte(buf[j]); - if (nb >= 0) { - if (nb > 0) self.lastNeed = nb - 1; - return nb; + function multiMapRemove(key, value) { + const values = this.get(key); + if (values) { + unorderedRemoveItem(values, value); + if (!values.length) { + this.delete(key); + } + } } - if (--j < i || nb === -2) return 0; - nb = utf8CheckByte(buf[j]); - if (nb >= 0) { - if (nb > 0) self.lastNeed = nb - 2; - return nb; + function createQueue(items) { + const elements = (items == null ? void 0 : items.slice()) || []; + let headIndex = 0; + function isEmpty() { + return headIndex === elements.length; + } + function enqueue(...items2) { + elements.push(...items2); + } + function dequeue() { + if (isEmpty()) { + throw new Error("Queue is empty"); + } + const result = elements[headIndex]; + elements[headIndex] = void 0; + headIndex++; + if (headIndex > 100 && headIndex > elements.length >> 1) { + const newLength = elements.length - headIndex; + elements.copyWithin( + /*target*/ + 0, + /*start*/ + headIndex + ); + elements.length = newLength; + headIndex = 0; + } + return result; + } + return { + enqueue, + dequeue, + isEmpty + }; } - if (--j < i || nb === -2) return 0; - nb = utf8CheckByte(buf[j]); - if (nb >= 0) { - if (nb > 0) { - if (nb === 2) nb = 0;else self.lastNeed = nb - 3; + function createSet(getHashCode, equals) { + const multiMap = /* @__PURE__ */ new Map(); + let size = 0; + function* getElementIterator() { + for (const value of multiMap.values()) { + if (isArray(value)) { + yield* value; + } else { + yield value; + } + } } - return nb; + const set = { + has(element) { + const hash = getHashCode(element); + if (!multiMap.has(hash)) + return false; + const candidates = multiMap.get(hash); + if (!isArray(candidates)) + return equals(candidates, element); + for (const candidate of candidates) { + if (equals(candidate, element)) { + return true; + } + } + return false; + }, + add(element) { + const hash = getHashCode(element); + if (multiMap.has(hash)) { + const values = multiMap.get(hash); + if (isArray(values)) { + if (!contains(values, element, equals)) { + values.push(element); + size++; + } + } else { + const value = values; + if (!equals(value, element)) { + multiMap.set(hash, [value, element]); + size++; + } + } + } else { + multiMap.set(hash, element); + size++; + } + return this; + }, + delete(element) { + const hash = getHashCode(element); + if (!multiMap.has(hash)) + return false; + const candidates = multiMap.get(hash); + if (isArray(candidates)) { + for (let i = 0; i < candidates.length; i++) { + if (equals(candidates[i], element)) { + if (candidates.length === 1) { + multiMap.delete(hash); + } else if (candidates.length === 2) { + multiMap.set(hash, candidates[1 - i]); + } else { + unorderedRemoveItemAt(candidates, i); + } + size--; + return true; + } + } + } else { + const candidate = candidates; + if (equals(candidate, element)) { + multiMap.delete(hash); + size--; + return true; + } + } + return false; + }, + clear() { + multiMap.clear(); + size = 0; + }, + get size() { + return size; + }, + forEach(action) { + for (const elements of arrayFrom(multiMap.values())) { + if (isArray(elements)) { + for (const element of elements) { + action(element, element, set); + } + } else { + const element = elements; + action(element, element, set); + } + } + }, + keys() { + return getElementIterator(); + }, + values() { + return getElementIterator(); + }, + *entries() { + for (const value of getElementIterator()) { + yield [value, value]; + } + }, + [Symbol.iterator]: () => { + return getElementIterator(); + }, + [Symbol.toStringTag]: multiMap[Symbol.toStringTag] + }; + return set; } - return 0; -} - -// Validates as many continuation bytes for a multi-byte UTF-8 character as -// needed or are available. If we see a non-continuation byte where we expect -// one, we "replace" the validated continuation bytes we've seen so far with -// a single UTF-8 replacement character ('\ufffd'), to match v8's UTF-8 decoding -// behavior. The continuation byte check is included three times in the case -// where all of the continuation bytes for a character exist in the same buffer. -// It is also done this way as a slight performance increase instead of using a -// loop. -function utf8CheckExtraBytes(self, buf, p) { - if ((buf[0] & 0xC0) !== 0x80) { - self.lastNeed = 0; - return '\ufffd'; + function isArray(value) { + return Array.isArray(value); } - if (self.lastNeed > 1 && buf.length > 1) { - if ((buf[1] & 0xC0) !== 0x80) { - self.lastNeed = 1; - return '\ufffd'; - } - if (self.lastNeed > 2 && buf.length > 2) { - if ((buf[2] & 0xC0) !== 0x80) { - self.lastNeed = 2; - return '\ufffd'; + function toArray(value) { + return isArray(value) ? value : [value]; + } + function isString(text) { + return typeof text === "string"; + } + function isNumber(x) { + return typeof x === "number"; + } + function tryCast(value, test) { + return value !== void 0 && test(value) ? value : void 0; + } + function cast(value, test) { + if (value !== void 0 && test(value)) + return value; + return Debug.fail(`Invalid cast. The supplied value ${value} did not pass the test '${Debug.getFunctionName(test)}'.`); + } + function noop(_) { + } + function returnFalse() { + return false; + } + function returnTrue() { + return true; + } + function returnUndefined() { + return void 0; + } + function identity(x) { + return x; + } + function toLowerCase(x) { + return x.toLowerCase(); + } + function toFileNameLowerCase(x) { + return fileNameLowerCaseRegExp.test(x) ? x.replace(fileNameLowerCaseRegExp, toLowerCase) : x; + } + function notImplemented() { + throw new Error("Not implemented"); + } + function memoize(callback) { + let value; + return () => { + if (callback) { + value = callback(); + callback = void 0; } - } + return value; + }; } -} - -// Attempts to complete a multi-byte UTF-8 character using bytes from a Buffer. -function utf8FillLast(buf) { - var p = this.lastTotal - this.lastNeed; - var r = utf8CheckExtraBytes(this, buf, p); - if (r !== undefined) return r; - if (this.lastNeed <= buf.length) { - buf.copy(this.lastChar, p, 0, this.lastNeed); - return this.lastChar.toString(this.encoding, 0, this.lastTotal); + function memoizeOne(callback) { + const map2 = /* @__PURE__ */ new Map(); + return (arg) => { + const key = `${typeof arg}:${arg}`; + let value = map2.get(key); + if (value === void 0 && !map2.has(key)) { + value = callback(arg); + map2.set(key, value); + } + return value; + }; } - buf.copy(this.lastChar, p, 0, buf.length); - this.lastNeed -= buf.length; -} - -// Returns all complete UTF-8 characters in a Buffer. If the Buffer ended on a -// partial character, the character's bytes are buffered until the required -// number of bytes are available. -function utf8Text(buf, i) { - var total = utf8CheckIncomplete(this, buf, i); - if (!this.lastNeed) return buf.toString('utf8', i); - this.lastTotal = total; - var end = buf.length - (total - this.lastNeed); - buf.copy(this.lastChar, 0, end); - return buf.toString('utf8', i, end); -} - -// For UTF-8, a replacement character is added when ending on a partial -// character. -function utf8End(buf) { - var r = buf && buf.length ? this.write(buf) : ''; - if (this.lastNeed) return r + '\ufffd'; - return r; -} - -// UTF-16LE typically needs two bytes per character, but even if we have an even -// number of bytes available, we need to check if we end on a leading/high -// surrogate. In that case, we need to wait for the next two bytes in order to -// decode the last character properly. -function utf16Text(buf, i) { - if ((buf.length - i) % 2 === 0) { - var r = buf.toString('utf16le', i); - if (r) { - var c = r.charCodeAt(r.length - 1); - if (c >= 0xD800 && c <= 0xDBFF) { - this.lastNeed = 2; - this.lastTotal = 4; - this.lastChar[0] = buf[buf.length - 2]; - this.lastChar[1] = buf[buf.length - 1]; - return r.slice(0, -1); + function memoizeWeak(callback) { + const map2 = /* @__PURE__ */ new WeakMap(); + return (arg) => { + let value = map2.get(arg); + if (value === void 0 && !map2.has(arg)) { + value = callback(arg); + map2.set(arg, value); + } + return value; + }; + } + function memoizeCached(callback, cache) { + return (...args) => { + let value = cache.get(args); + if (value === void 0 && !cache.has(args)) { + value = callback(...args); + cache.set(args, value); + } + return value; + }; + } + function compose(a, b, c, d, e) { + if (!!e) { + const args = []; + for (let i = 0; i < arguments.length; i++) { + args[i] = arguments[i]; } + return (t) => reduceLeft(args, (u, f) => f(u), t); + } else if (d) { + return (t) => d(c(b(a(t)))); + } else if (c) { + return (t) => c(b(a(t))); + } else if (b) { + return (t) => b(a(t)); + } else if (a) { + return (t) => a(t); + } else { + return (t) => t; } - return r; } - this.lastNeed = 1; - this.lastTotal = 2; - this.lastChar[0] = buf[buf.length - 1]; - return buf.toString('utf16le', i, buf.length - 1); -} - -// For UTF-16LE we do not explicitly append special replacement characters if we -// end on a partial character, we simply let v8 handle that. -function utf16End(buf) { - var r = buf && buf.length ? this.write(buf) : ''; - if (this.lastNeed) { - var end = this.lastTotal - this.lastNeed; - return r + this.lastChar.toString('utf16le', 0, end); + function equateValues(a, b) { + return a === b; } - return r; -} - -function base64Text(buf, i) { - var n = (buf.length - i) % 3; - if (n === 0) return buf.toString('base64', i); - this.lastNeed = 3 - n; - this.lastTotal = 3; - if (n === 1) { - this.lastChar[0] = buf[buf.length - 1]; - } else { - this.lastChar[0] = buf[buf.length - 2]; - this.lastChar[1] = buf[buf.length - 1]; + function equateStringsCaseInsensitive(a, b) { + return a === b || a !== void 0 && b !== void 0 && a.toUpperCase() === b.toUpperCase(); } - return buf.toString('base64', i, buf.length - n); -} - -function base64End(buf) { - var r = buf && buf.length ? this.write(buf) : ''; - if (this.lastNeed) return r + this.lastChar.toString('base64', 0, 3 - this.lastNeed); - return r; -} - -// Pass bytes on through for single-byte encodings (e.g. ascii, latin1, hex) -function simpleWrite(buf) { - return buf.toString(this.encoding); -} - -function simpleEnd(buf) { - return buf && buf.length ? this.write(buf) : ''; -} - -/***/ }), - -/***/ 22196: -/***/ ((module) => { - -"use strict"; - -module.exports = x => { - if (typeof x !== 'string') { - throw new TypeError('Expected a string, got ' + typeof x); - } - - // Catches EFBBBF (UTF-8 BOM) because the buffer-to-string - // conversion translates it to FEFF (UTF-16 BOM) - if (x.charCodeAt(0) === 0xFEFF) { - return x.slice(1); - } - - return x; -}; - - -/***/ }), - -/***/ 9679: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { - -"use strict"; - -const os = __nccwpck_require__(22037); -const tty = __nccwpck_require__(76224); -const hasFlag = __nccwpck_require__(97); - -const {env} = process; - -let forceColor; -if (hasFlag('no-color') || - hasFlag('no-colors') || - hasFlag('color=false') || - hasFlag('color=never')) { - forceColor = 0; -} else if (hasFlag('color') || - hasFlag('colors') || - hasFlag('color=true') || - hasFlag('color=always')) { - forceColor = 1; -} - -if ('FORCE_COLOR' in env) { - if (env.FORCE_COLOR === 'true') { - forceColor = 1; - } else if (env.FORCE_COLOR === 'false') { - forceColor = 0; - } else { - forceColor = env.FORCE_COLOR.length === 0 ? 1 : Math.min(parseInt(env.FORCE_COLOR, 10), 3); - } -} - -function translateLevel(level) { - if (level === 0) { - return false; - } - - return { - level, - hasBasic: true, - has256: level >= 2, - has16m: level >= 3 - }; -} - -function supportsColor(haveStream, streamIsTTY) { - if (forceColor === 0) { - return 0; - } - - if (hasFlag('color=16m') || - hasFlag('color=full') || - hasFlag('color=truecolor')) { - return 3; - } - - if (hasFlag('color=256')) { - return 2; - } - - if (haveStream && !streamIsTTY && forceColor === undefined) { - return 0; - } - - const min = forceColor || 0; - - if (env.TERM === 'dumb') { - return min; - } - - if (process.platform === 'win32') { - // Windows 10 build 10586 is the first Windows release that supports 256 colors. - // Windows 10 build 14931 is the first release that supports 16m/TrueColor. - const osRelease = os.release().split('.'); - if ( - Number(osRelease[0]) >= 10 && - Number(osRelease[2]) >= 10586 - ) { - return Number(osRelease[2]) >= 14931 ? 3 : 2; - } - - return 1; - } - - if ('CI' in env) { - if (['TRAVIS', 'CIRCLECI', 'APPVEYOR', 'GITLAB_CI', 'GITHUB_ACTIONS', 'BUILDKITE'].some(sign => sign in env) || env.CI_NAME === 'codeship') { - return 1; - } - - return min; - } - - if ('TEAMCITY_VERSION' in env) { - return /^(9\.(0*[1-9]\d*)\.|\d{2,}\.)/.test(env.TEAMCITY_VERSION) ? 1 : 0; - } - - if (env.COLORTERM === 'truecolor') { - return 3; - } - - if ('TERM_PROGRAM' in env) { - const version = parseInt((env.TERM_PROGRAM_VERSION || '').split('.')[0], 10); - - switch (env.TERM_PROGRAM) { - case 'iTerm.app': - return version >= 3 ? 3 : 2; - case 'Apple_Terminal': - return 2; - // No default - } - } - - if (/-256(color)?$/i.test(env.TERM)) { - return 2; - } - - if (/^screen|^xterm|^vt100|^vt220|^rxvt|color|ansi|cygwin|linux/i.test(env.TERM)) { - return 1; - } - - if ('COLORTERM' in env) { - return 1; - } - - return min; -} - -function getSupportLevel(stream) { - const level = supportsColor(stream, stream && stream.isTTY); - return translateLevel(level); -} - -module.exports = { - supportsColor: getSupportLevel, - stdout: translateLevel(supportsColor(true, tty.isatty(1))), - stderr: translateLevel(supportsColor(true, tty.isatty(2))) -}; - - -/***/ }), - -/***/ 57218: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { - -var util = __nccwpck_require__(73837) -var bl = __nccwpck_require__(1236) -var headers = __nccwpck_require__(82249) - -var Writable = (__nccwpck_require__(88550).Writable) -var PassThrough = (__nccwpck_require__(88550).PassThrough) - -var noop = function () {} - -var overflow = function (size) { - size &= 511 - return size && 512 - size -} - -var emptyStream = function (self, offset) { - var s = new Source(self, offset) - s.end() - return s -} - -var mixinPax = function (header, pax) { - if (pax.path) header.name = pax.path - if (pax.linkpath) header.linkname = pax.linkpath - if (pax.size) header.size = parseInt(pax.size, 10) - header.pax = pax - return header -} - -var Source = function (self, offset) { - this._parent = self - this.offset = offset - PassThrough.call(this, { autoDestroy: false }) -} - -util.inherits(Source, PassThrough) - -Source.prototype.destroy = function (err) { - this._parent.destroy(err) -} - -var Extract = function (opts) { - if (!(this instanceof Extract)) return new Extract(opts) - Writable.call(this, opts) - - opts = opts || {} - - this._offset = 0 - this._buffer = bl() - this._missing = 0 - this._partial = false - this._onparse = noop - this._header = null - this._stream = null - this._overflow = null - this._cb = null - this._locked = false - this._destroyed = false - this._pax = null - this._paxGlobal = null - this._gnuLongPath = null - this._gnuLongLinkPath = null - - var self = this - var b = self._buffer - - var oncontinue = function () { - self._continue() + function equateStringsCaseSensitive(a, b) { + return equateValues(a, b); } - - var onunlock = function (err) { - self._locked = false - if (err) return self.destroy(err) - if (!self._stream) oncontinue() + function compareComparableValues(a, b) { + return a === b ? 0 /* EqualTo */ : a === void 0 ? -1 /* LessThan */ : b === void 0 ? 1 /* GreaterThan */ : a < b ? -1 /* LessThan */ : 1 /* GreaterThan */; } - - var onstreamend = function () { - self._stream = null - var drain = overflow(self._header.size) - if (drain) self._parse(drain, ondrain) - else self._parse(512, onheader) - if (!self._locked) oncontinue() + function compareValues(a, b) { + return compareComparableValues(a, b); } - - var ondrain = function () { - self._buffer.consume(overflow(self._header.size)) - self._parse(512, onheader) - oncontinue() + function compareTextSpans(a, b) { + return compareValues(a == null ? void 0 : a.start, b == null ? void 0 : b.start) || compareValues(a == null ? void 0 : a.length, b == null ? void 0 : b.length); } - - var onpaxglobalheader = function () { - var size = self._header.size - self._paxGlobal = headers.decodePax(b.slice(0, size)) - b.consume(size) - onstreamend() + function min(items, compare) { + return reduceLeft(items, (x, y) => compare(x, y) === -1 /* LessThan */ ? x : y); } - - var onpaxheader = function () { - var size = self._header.size - self._pax = headers.decodePax(b.slice(0, size)) - if (self._paxGlobal) self._pax = Object.assign({}, self._paxGlobal, self._pax) - b.consume(size) - onstreamend() + function compareStringsCaseInsensitive(a, b) { + if (a === b) + return 0 /* EqualTo */; + if (a === void 0) + return -1 /* LessThan */; + if (b === void 0) + return 1 /* GreaterThan */; + a = a.toUpperCase(); + b = b.toUpperCase(); + return a < b ? -1 /* LessThan */ : a > b ? 1 /* GreaterThan */ : 0 /* EqualTo */; } - - var ongnulongpath = function () { - var size = self._header.size - this._gnuLongPath = headers.decodeLongPath(b.slice(0, size), opts.filenameEncoding) - b.consume(size) - onstreamend() + function compareStringsCaseInsensitiveEslintCompatible(a, b) { + if (a === b) + return 0 /* EqualTo */; + if (a === void 0) + return -1 /* LessThan */; + if (b === void 0) + return 1 /* GreaterThan */; + a = a.toLowerCase(); + b = b.toLowerCase(); + return a < b ? -1 /* LessThan */ : a > b ? 1 /* GreaterThan */ : 0 /* EqualTo */; } - - var ongnulonglinkpath = function () { - var size = self._header.size - this._gnuLongLinkPath = headers.decodeLongPath(b.slice(0, size), opts.filenameEncoding) - b.consume(size) - onstreamend() + function compareStringsCaseSensitive(a, b) { + return compareComparableValues(a, b); } - - var onheader = function () { - var offset = self._offset - var header - try { - header = self._header = headers.decode(b.slice(0, 512), opts.filenameEncoding, opts.allowUnknownFormat) - } catch (err) { - self.emit('error', err) - } - b.consume(512) - - if (!header) { - self._parse(512, onheader) - oncontinue() - return - } - if (header.type === 'gnu-long-path') { - self._parse(header.size, ongnulongpath) - oncontinue() - return + function getStringComparer(ignoreCase) { + return ignoreCase ? compareStringsCaseInsensitive : compareStringsCaseSensitive; + } + function getUILocale() { + return uiLocale; + } + function setUILocale(value) { + if (uiLocale !== value) { + uiLocale = value; + uiComparerCaseSensitive = void 0; } - if (header.type === 'gnu-long-link-path') { - self._parse(header.size, ongnulonglinkpath) - oncontinue() - return + } + function compareStringsCaseSensitiveUI(a, b) { + const comparer = uiComparerCaseSensitive || (uiComparerCaseSensitive = createUIStringComparer(uiLocale)); + return comparer(a, b); + } + function compareProperties(a, b, key, comparer) { + return a === b ? 0 /* EqualTo */ : a === void 0 ? -1 /* LessThan */ : b === void 0 ? 1 /* GreaterThan */ : comparer(a[key], b[key]); + } + function compareBooleans(a, b) { + return compareValues(a ? 1 : 0, b ? 1 : 0); + } + function getSpellingSuggestion(name, candidates, getName) { + const maximumLengthDifference = Math.max(2, Math.floor(name.length * 0.34)); + let bestDistance = Math.floor(name.length * 0.4) + 1; + let bestCandidate; + for (const candidate of candidates) { + const candidateName = getName(candidate); + if (candidateName !== void 0 && Math.abs(candidateName.length - name.length) <= maximumLengthDifference) { + if (candidateName === name) { + continue; + } + if (candidateName.length < 3 && candidateName.toLowerCase() !== name.toLowerCase()) { + continue; + } + const distance = levenshteinWithMax(name, candidateName, bestDistance - 0.1); + if (distance === void 0) { + continue; + } + Debug.assert(distance < bestDistance); + bestDistance = distance; + bestCandidate = candidate; + } } - if (header.type === 'pax-global-header') { - self._parse(header.size, onpaxglobalheader) - oncontinue() - return + return bestCandidate; + } + function levenshteinWithMax(s1, s2, max) { + let previous = new Array(s2.length + 1); + let current = new Array(s2.length + 1); + const big = max + 0.01; + for (let i = 0; i <= s2.length; i++) { + previous[i] = i; } - if (header.type === 'pax-header') { - self._parse(header.size, onpaxheader) - oncontinue() - return + for (let i = 1; i <= s1.length; i++) { + const c1 = s1.charCodeAt(i - 1); + const minJ = Math.ceil(i > max ? i - max : 1); + const maxJ = Math.floor(s2.length > max + i ? max + i : s2.length); + current[0] = i; + let colMin = i; + for (let j = 1; j < minJ; j++) { + current[j] = big; + } + for (let j = minJ; j <= maxJ; j++) { + const substitutionDistance = s1[i - 1].toLowerCase() === s2[j - 1].toLowerCase() ? previous[j - 1] + 0.1 : previous[j - 1] + 2; + const dist = c1 === s2.charCodeAt(j - 1) ? previous[j - 1] : Math.min( + /*delete*/ + previous[j] + 1, + /*insert*/ + current[j - 1] + 1, + /*substitute*/ + substitutionDistance + ); + current[j] = dist; + colMin = Math.min(colMin, dist); + } + for (let j = maxJ + 1; j <= s2.length; j++) { + current[j] = big; + } + if (colMin > max) { + return void 0; + } + const temp = previous; + previous = current; + current = temp; } - - if (self._gnuLongPath) { - header.name = self._gnuLongPath - self._gnuLongPath = null + const res = previous[s2.length]; + return res > max ? void 0 : res; + } + function endsWith(str, suffix) { + const expectedPos = str.length - suffix.length; + return expectedPos >= 0 && str.indexOf(suffix, expectedPos) === expectedPos; + } + function removeSuffix(str, suffix) { + return endsWith(str, suffix) ? str.slice(0, str.length - suffix.length) : str; + } + function tryRemoveSuffix(str, suffix) { + return endsWith(str, suffix) ? str.slice(0, str.length - suffix.length) : void 0; + } + function removeMinAndVersionNumbers(fileName) { + let end = fileName.length; + for (let pos = end - 1; pos > 0; pos--) { + let ch = fileName.charCodeAt(pos); + if (ch >= 48 /* _0 */ && ch <= 57 /* _9 */) { + do { + --pos; + ch = fileName.charCodeAt(pos); + } while (pos > 0 && ch >= 48 /* _0 */ && ch <= 57 /* _9 */); + } else if (pos > 4 && (ch === 110 /* n */ || ch === 78 /* N */)) { + --pos; + ch = fileName.charCodeAt(pos); + if (ch !== 105 /* i */ && ch !== 73 /* I */) { + break; + } + --pos; + ch = fileName.charCodeAt(pos); + if (ch !== 109 /* m */ && ch !== 77 /* M */) { + break; + } + --pos; + ch = fileName.charCodeAt(pos); + } else { + break; + } + if (ch !== 45 /* minus */ && ch !== 46 /* dot */) { + break; + } + end = pos; } - - if (self._gnuLongLinkPath) { - header.linkname = self._gnuLongLinkPath - self._gnuLongLinkPath = null + return end === fileName.length ? fileName : fileName.slice(0, end); + } + function orderedRemoveItem(array, item) { + for (let i = 0; i < array.length; i++) { + if (array[i] === item) { + orderedRemoveItemAt(array, i); + return true; + } } - - if (self._pax) { - self._header = header = mixinPax(header, self._pax) - self._pax = null + return false; + } + function orderedRemoveItemAt(array, index) { + for (let i = index; i < array.length - 1; i++) { + array[i] = array[i + 1]; } - - self._locked = true - - if (!header.size || header.type === 'directory') { - self._parse(512, onheader) - self.emit('entry', header, emptyStream(self, offset), onunlock) - return + array.pop(); + } + function unorderedRemoveItemAt(array, index) { + array[index] = array[array.length - 1]; + array.pop(); + } + function unorderedRemoveItem(array, item) { + return unorderedRemoveFirstItemWhere(array, (element) => element === item); + } + function unorderedRemoveFirstItemWhere(array, predicate) { + for (let i = 0; i < array.length; i++) { + if (predicate(array[i])) { + unorderedRemoveItemAt(array, i); + return true; + } } - - self._stream = new Source(self, offset) - - self.emit('entry', header, self._stream, onunlock) - self._parse(header.size, onstreamend) - oncontinue() + return false; } - - this._onheader = onheader - this._parse(512, onheader) -} - -util.inherits(Extract, Writable) - -Extract.prototype.destroy = function (err) { - if (this._destroyed) return - this._destroyed = true - - if (err) this.emit('error', err) - this.emit('close') - if (this._stream) this._stream.emit('close') -} - -Extract.prototype._parse = function (size, onparse) { - if (this._destroyed) return - this._offset += size - this._missing = size - if (onparse === this._onheader) this._partial = false - this._onparse = onparse -} - -Extract.prototype._continue = function () { - if (this._destroyed) return - var cb = this._cb - this._cb = noop - if (this._overflow) this._write(this._overflow, undefined, cb) - else cb() -} - -Extract.prototype._write = function (data, enc, cb) { - if (this._destroyed) return - - var s = this._stream - var b = this._buffer - var missing = this._missing - if (data.length) this._partial = true - - // we do not reach end-of-chunk now. just forward it - - if (data.length < missing) { - this._missing -= data.length - this._overflow = null - if (s) return s.write(data, cb) - b.append(data) - return cb() + function createGetCanonicalFileName(useCaseSensitiveFileNames2) { + return useCaseSensitiveFileNames2 ? identity : toFileNameLowerCase; } - - // end-of-chunk. the parser should call cb. - - this._cb = cb - this._missing = 0 - - var overflow = null - if (data.length > missing) { - overflow = data.slice(missing) - data = data.slice(0, missing) + function patternText({ prefix, suffix }) { + return `${prefix}*${suffix}`; } - - if (s) s.end(data) - else b.append(data) - - this._overflow = overflow - this._onparse() -} - -Extract.prototype._final = function (cb) { - if (this._partial) return this.destroy(new Error('Unexpected end of data')) - cb() -} - -module.exports = Extract - - -/***/ }), - -/***/ 82249: -/***/ ((__unused_webpack_module, exports) => { - -var alloc = Buffer.alloc - -var ZEROS = '0000000000000000000' -var SEVENS = '7777777777777777777' -var ZERO_OFFSET = '0'.charCodeAt(0) -var USTAR_MAGIC = Buffer.from('ustar\x00', 'binary') -var USTAR_VER = Buffer.from('00', 'binary') -var GNU_MAGIC = Buffer.from('ustar\x20', 'binary') -var GNU_VER = Buffer.from('\x20\x00', 'binary') -var MASK = parseInt('7777', 8) -var MAGIC_OFFSET = 257 -var VERSION_OFFSET = 263 - -var clamp = function (index, len, defaultValue) { - if (typeof index !== 'number') return defaultValue - index = ~~index // Coerce to integer. - if (index >= len) return len - if (index >= 0) return index - index += len - if (index >= 0) return index - return 0 -} - -var toType = function (flag) { - switch (flag) { - case 0: - return 'file' - case 1: - return 'link' - case 2: - return 'symlink' - case 3: - return 'character-device' - case 4: - return 'block-device' - case 5: - return 'directory' - case 6: - return 'fifo' - case 7: - return 'contiguous-file' - case 72: - return 'pax-header' - case 55: - return 'pax-global-header' - case 27: - return 'gnu-long-link-path' - case 28: - case 30: - return 'gnu-long-path' + function matchedText(pattern, candidate) { + Debug.assert(isPatternMatch(pattern, candidate)); + return candidate.substring(pattern.prefix.length, candidate.length - pattern.suffix.length); } - - return null -} - -var toTypeflag = function (flag) { - switch (flag) { - case 'file': - return 0 - case 'link': - return 1 - case 'symlink': - return 2 - case 'character-device': - return 3 - case 'block-device': - return 4 - case 'directory': - return 5 - case 'fifo': - return 6 - case 'contiguous-file': - return 7 - case 'pax-header': - return 72 - } - - return 0 -} - -var indexOf = function (block, num, offset, end) { - for (; offset < end; offset++) { - if (block[offset] === num) return offset - } - return end -} - -var cksum = function (block) { - var sum = 8 * 32 - for (var i = 0; i < 148; i++) sum += block[i] - for (var j = 156; j < 512; j++) sum += block[j] - return sum -} - -var encodeOct = function (val, n) { - val = val.toString(8) - if (val.length > n) return SEVENS.slice(0, n) + ' ' - else return ZEROS.slice(0, n - val.length) + val + ' ' -} - -/* Copied from the node-tar repo and modified to meet - * tar-stream coding standard. - * - * Source: https://github.com/npm/node-tar/blob/51b6627a1f357d2eb433e7378e5f05e83b7aa6cd/lib/header.js#L349 - */ -function parse256 (buf) { - // first byte MUST be either 80 or FF - // 80 for positive, FF for 2's comp - var positive - if (buf[0] === 0x80) positive = true - else if (buf[0] === 0xFF) positive = false - else return null - - // build up a base-256 tuple from the least sig to the highest - var tuple = [] - for (var i = buf.length - 1; i > 0; i--) { - var byte = buf[i] - if (positive) tuple.push(byte) - else tuple.push(0xFF - byte) - } - - var sum = 0 - var l = tuple.length - for (i = 0; i < l; i++) { - sum += tuple[i] * Math.pow(256, i) - } - - return positive ? sum : -1 * sum -} - -var decodeOct = function (val, offset, length) { - val = val.slice(offset, offset + length) - offset = 0 - - // If prefixed with 0x80 then parse as a base-256 integer - if (val[offset] & 0x80) { - return parse256(val) - } else { - // Older versions of tar can prefix with spaces - while (offset < val.length && val[offset] === 32) offset++ - var end = clamp(indexOf(val, 32, offset, val.length), val.length, val.length) - while (offset < end && val[offset] === 0) offset++ - if (end === offset) return 0 - return parseInt(val.slice(offset, end).toString(), 8) - } -} - -var decodeStr = function (val, offset, length, encoding) { - return val.slice(offset, indexOf(val, 0, offset, offset + length)).toString(encoding) -} - -var addLength = function (str) { - var len = Buffer.byteLength(str) - var digits = Math.floor(Math.log(len) / Math.log(10)) + 1 - if (len + digits >= Math.pow(10, digits)) digits++ - - return (len + digits) + str -} - -exports.decodeLongPath = function (buf, encoding) { - return decodeStr(buf, 0, buf.length, encoding) -} - -exports.encodePax = function (opts) { // TODO: encode more stuff in pax - var result = '' - if (opts.name) result += addLength(' path=' + opts.name + '\n') - if (opts.linkname) result += addLength(' linkpath=' + opts.linkname + '\n') - var pax = opts.pax - if (pax) { - for (var key in pax) { - result += addLength(' ' + key + '=' + pax[key] + '\n') + function findBestPatternMatch(values, getPattern, candidate) { + let matchedValue; + let longestMatchPrefixLength = -1; + for (const v of values) { + const pattern = getPattern(v); + if (isPatternMatch(pattern, candidate) && pattern.prefix.length > longestMatchPrefixLength) { + longestMatchPrefixLength = pattern.prefix.length; + matchedValue = v; + } } + return matchedValue; } - return Buffer.from(result) -} - -exports.decodePax = function (buf) { - var result = {} - - while (buf.length) { - var i = 0 - while (i < buf.length && buf[i] !== 32) i++ - var len = parseInt(buf.slice(0, i).toString(), 10) - if (!len) return result - - var b = buf.slice(i + 1, len - 1).toString() - var keyIndex = b.indexOf('=') - if (keyIndex === -1) return result - result[b.slice(0, keyIndex)] = b.slice(keyIndex + 1) - - buf = buf.slice(len) - } - - return result -} - -exports.encode = function (opts) { - var buf = alloc(512) - var name = opts.name - var prefix = '' - - if (opts.typeflag === 5 && name[name.length - 1] !== '/') name += '/' - if (Buffer.byteLength(name) !== name.length) return null // utf-8 - - while (Buffer.byteLength(name) > 100) { - var i = name.indexOf('/') - if (i === -1) return null - prefix += prefix ? '/' + name.slice(0, i) : name.slice(0, i) - name = name.slice(i + 1) - } - - if (Buffer.byteLength(name) > 100 || Buffer.byteLength(prefix) > 155) return null - if (opts.linkname && Buffer.byteLength(opts.linkname) > 100) return null - - buf.write(name) - buf.write(encodeOct(opts.mode & MASK, 6), 100) - buf.write(encodeOct(opts.uid, 6), 108) - buf.write(encodeOct(opts.gid, 6), 116) - buf.write(encodeOct(opts.size, 11), 124) - buf.write(encodeOct((opts.mtime.getTime() / 1000) | 0, 11), 136) - - buf[156] = ZERO_OFFSET + toTypeflag(opts.type) - - if (opts.linkname) buf.write(opts.linkname, 157) - - USTAR_MAGIC.copy(buf, MAGIC_OFFSET) - USTAR_VER.copy(buf, VERSION_OFFSET) - if (opts.uname) buf.write(opts.uname, 265) - if (opts.gname) buf.write(opts.gname, 297) - buf.write(encodeOct(opts.devmajor || 0, 6), 329) - buf.write(encodeOct(opts.devminor || 0, 6), 337) - - if (prefix) buf.write(prefix, 345) - - buf.write(encodeOct(cksum(buf), 6), 148) - - return buf -} - -exports.decode = function (buf, filenameEncoding, allowUnknownFormat) { - var typeflag = buf[156] === 0 ? 0 : buf[156] - ZERO_OFFSET - - var name = decodeStr(buf, 0, 100, filenameEncoding) - var mode = decodeOct(buf, 100, 8) - var uid = decodeOct(buf, 108, 8) - var gid = decodeOct(buf, 116, 8) - var size = decodeOct(buf, 124, 12) - var mtime = decodeOct(buf, 136, 12) - var type = toType(typeflag) - var linkname = buf[157] === 0 ? null : decodeStr(buf, 157, 100, filenameEncoding) - var uname = decodeStr(buf, 265, 32) - var gname = decodeStr(buf, 297, 32) - var devmajor = decodeOct(buf, 329, 8) - var devminor = decodeOct(buf, 337, 8) - - var c = cksum(buf) - - // checksum is still initial value if header was null. - if (c === 8 * 32) return null - - // valid checksum - if (c !== decodeOct(buf, 148, 8)) throw new Error('Invalid tar header. Maybe the tar is corrupted or it needs to be gunzipped?') - - if (USTAR_MAGIC.compare(buf, MAGIC_OFFSET, MAGIC_OFFSET + 6) === 0) { - // ustar (posix) format. - // prepend prefix, if present. - if (buf[345]) name = decodeStr(buf, 345, 155, filenameEncoding) + '/' + name - } else if (GNU_MAGIC.compare(buf, MAGIC_OFFSET, MAGIC_OFFSET + 6) === 0 && - GNU_VER.compare(buf, VERSION_OFFSET, VERSION_OFFSET + 2) === 0) { - // 'gnu'/'oldgnu' format. Similar to ustar, but has support for incremental and - // multi-volume tarballs. - } else { - if (!allowUnknownFormat) { - throw new Error('Invalid tar header: unknown format.') - } + function startsWith(str, prefix) { + return str.lastIndexOf(prefix, 0) === 0; } - - // to support old tar versions that use trailing / to indicate dirs - if (typeflag === 0 && name && name[name.length - 1] === '/') typeflag = 5 - - return { - name, - mode, - uid, - gid, - size, - mtime: new Date(1000 * mtime), - type, - linkname, - uname, - gname, - devmajor, - devminor + function removePrefix(str, prefix) { + return startsWith(str, prefix) ? str.substr(prefix.length) : str; } -} - - -/***/ }), - -/***/ 93983: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { - -exports.extract = __nccwpck_require__(57218) -exports.pack = __nccwpck_require__(89766) - - -/***/ }), - -/***/ 89766: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { - -var constants = __nccwpck_require__(21978) -var eos = __nccwpck_require__(69867) -var inherits = __nccwpck_require__(2868) -var alloc = Buffer.alloc - -var Readable = (__nccwpck_require__(88550).Readable) -var Writable = (__nccwpck_require__(88550).Writable) -var StringDecoder = (__nccwpck_require__(71576).StringDecoder) - -var headers = __nccwpck_require__(82249) - -var DMODE = parseInt('755', 8) -var FMODE = parseInt('644', 8) - -var END_OF_TAR = alloc(1024) - -var noop = function () {} - -var overflow = function (self, size) { - size &= 511 - if (size) self.push(END_OF_TAR.slice(0, 512 - size)) -} - -function modeToType (mode) { - switch (mode & constants.S_IFMT) { - case constants.S_IFBLK: return 'block-device' - case constants.S_IFCHR: return 'character-device' - case constants.S_IFDIR: return 'directory' - case constants.S_IFIFO: return 'fifo' - case constants.S_IFLNK: return 'symlink' + function tryRemovePrefix(str, prefix, getCanonicalFileName = identity) { + return startsWith(getCanonicalFileName(str), getCanonicalFileName(prefix)) ? str.substring(prefix.length) : void 0; } - - return 'file' -} - -var Sink = function (to) { - Writable.call(this) - this.written = 0 - this._to = to - this._destroyed = false -} - -inherits(Sink, Writable) - -Sink.prototype._write = function (data, enc, cb) { - this.written += data.length - if (this._to.push(data)) return cb() - this._to._drain = cb -} - -Sink.prototype.destroy = function () { - if (this._destroyed) return - this._destroyed = true - this.emit('close') -} - -var LinkSink = function () { - Writable.call(this) - this.linkname = '' - this._decoder = new StringDecoder('utf-8') - this._destroyed = false -} - -inherits(LinkSink, Writable) - -LinkSink.prototype._write = function (data, enc, cb) { - this.linkname += this._decoder.write(data) - cb() -} - -LinkSink.prototype.destroy = function () { - if (this._destroyed) return - this._destroyed = true - this.emit('close') -} - -var Void = function () { - Writable.call(this) - this._destroyed = false -} - -inherits(Void, Writable) - -Void.prototype._write = function (data, enc, cb) { - cb(new Error('No body allowed for this entry')) -} - -Void.prototype.destroy = function () { - if (this._destroyed) return - this._destroyed = true - this.emit('close') -} - -var Pack = function (opts) { - if (!(this instanceof Pack)) return new Pack(opts) - Readable.call(this, opts) - - this._drain = noop - this._finalized = false - this._finalizing = false - this._destroyed = false - this._stream = null -} - -inherits(Pack, Readable) - -Pack.prototype.entry = function (header, buffer, callback) { - if (this._stream) throw new Error('already piping an entry') - if (this._finalized || this._destroyed) return - - if (typeof buffer === 'function') { - callback = buffer - buffer = null + function isPatternMatch({ prefix, suffix }, candidate) { + return candidate.length >= prefix.length + suffix.length && startsWith(candidate, prefix) && endsWith(candidate, suffix); } - - if (!callback) callback = noop - - var self = this - - if (!header.size || header.type === 'symlink') header.size = 0 - if (!header.type) header.type = modeToType(header.mode) - if (!header.mode) header.mode = header.type === 'directory' ? DMODE : FMODE - if (!header.uid) header.uid = 0 - if (!header.gid) header.gid = 0 - if (!header.mtime) header.mtime = new Date() - - if (typeof buffer === 'string') buffer = Buffer.from(buffer) - if (Buffer.isBuffer(buffer)) { - header.size = buffer.length - this._encode(header) - var ok = this.push(buffer) - overflow(self, header.size) - if (ok) process.nextTick(callback) - else this._drain = callback - return new Void() + function and(f, g) { + return (arg) => f(arg) && g(arg); } - - if (header.type === 'symlink' && !header.linkname) { - var linkSink = new LinkSink() - eos(linkSink, function (err) { - if (err) { // stream was closed - self.destroy() - return callback(err) + function or(...fs) { + return (...args) => { + let lastResult; + for (const f of fs) { + lastResult = f(...args); + if (lastResult) { + return lastResult; + } } - - header.linkname = linkSink.linkname - self._encode(header) - callback() - }) - - return linkSink - } - - this._encode(header) - - if (header.type !== 'file' && header.type !== 'contiguous-file') { - process.nextTick(callback) - return new Void() - } - - var sink = new Sink(this) - - this._stream = sink - - eos(sink, function (err) { - self._stream = null - - if (err) { // stream was closed - self.destroy() - return callback(err) - } - - if (sink.written !== header.size) { // corrupting tar - self.destroy() - return callback(new Error('size mismatch')) - } - - overflow(self, header.size) - if (self._finalizing) self.finalize() - callback() - }) - - return sink -} - -Pack.prototype.finalize = function () { - if (this._stream) { - this._finalizing = true - return + return lastResult; + }; } - - if (this._finalized) return - this._finalized = true - this.push(END_OF_TAR) - this.push(null) -} - -Pack.prototype.destroy = function (err) { - if (this._destroyed) return - this._destroyed = true - - if (err) this.emit('error', err) - this.emit('close') - if (this._stream && this._stream.destroy) this._stream.destroy() -} - -Pack.prototype._encode = function (header) { - if (!header.pax) { - var buf = headers.encode(header) - if (buf) { - this.push(buf) - return - } + function not(fn) { + return (...args) => !fn(...args); } - this._encodePax(header) -} - -Pack.prototype._encodePax = function (header) { - var paxHeader = headers.encodePax({ - name: header.name, - linkname: header.linkname, - pax: header.pax - }) - - var newHeader = { - name: 'PaxHeader', - mode: header.mode, - uid: header.uid, - gid: header.gid, - size: paxHeader.length, - mtime: header.mtime, - type: 'pax-header', - linkname: header.linkname && 'PaxHeader', - uname: header.uname, - gname: header.gname, - devmajor: header.devmajor, - devminor: header.devminor + function assertType(_) { } - - this.push(headers.encode(newHeader)) - this.push(paxHeader) - overflow(this, paxHeader.length) - - newHeader.size = header.size - newHeader.type = header.type - this.push(headers.encode(newHeader)) -} - -Pack.prototype._read = function (n) { - var drain = this._drain - this._drain = noop - drain() -} - -module.exports = Pack - - -/***/ }), - -/***/ 49503: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { - -/*! - * Tmp - * - * Copyright (c) 2011-2017 KARASZI Istvan - * - * MIT Licensed - */ - -/* - * Module dependencies. - */ -const fs = __nccwpck_require__(57147); -const os = __nccwpck_require__(22037); -const path = __nccwpck_require__(71017); -const crypto = __nccwpck_require__(6113); -const _c = { fs: fs.constants, os: os.constants }; -const rimraf = __nccwpck_require__(8414); - -/* - * The working inner variables. - */ -const - // the random characters to choose from - RANDOM_CHARS = '0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz', - - TEMPLATE_PATTERN = /XXXXXX/, - - DEFAULT_TRIES = 3, - - CREATE_FLAGS = (_c.O_CREAT || _c.fs.O_CREAT) | (_c.O_EXCL || _c.fs.O_EXCL) | (_c.O_RDWR || _c.fs.O_RDWR), - - // constants are off on the windows platform and will not match the actual errno codes - IS_WIN32 = os.platform() === 'win32', - EBADF = _c.EBADF || _c.os.errno.EBADF, - ENOENT = _c.ENOENT || _c.os.errno.ENOENT, - - DIR_MODE = 0o700 /* 448 */, - FILE_MODE = 0o600 /* 384 */, - - EXIT = 'exit', - - // this will hold the objects need to be removed on exit - _removeObjects = [], - - // API change in fs.rmdirSync leads to error when passing in a second parameter, e.g. the callback - FN_RMDIR_SYNC = fs.rmdirSync.bind(fs), - FN_RIMRAF_SYNC = rimraf.sync; - -let - _gracefulCleanup = false; - -/** - * Gets a temporary file name. - * - * @param {(Options|tmpNameCallback)} options options or callback - * @param {?tmpNameCallback} callback the callback function - */ -function tmpName(options, callback) { - const - args = _parseArguments(options, callback), - opts = args[0], - cb = args[1]; - - try { - _assertAndSanitizeOptions(opts); - } catch (err) { - return cb(err); + function singleElementArray(t) { + return t === void 0 ? void 0 : [t]; } - - let tries = opts.tries; - (function _getUniqueName() { - try { - const name = _generateTmpName(opts); - - // check whether the path exists then retry if needed - fs.stat(name, function (err) { - /* istanbul ignore else */ - if (!err) { - /* istanbul ignore else */ - if (tries-- > 0) return _getUniqueName(); - - return cb(new Error('Could not get a unique tmp filename, max tries reached ' + name)); - } - - cb(null, name); - }); - } catch (err) { - cb(err); - } - }()); -} - -/** - * Synchronous version of tmpName. - * - * @param {Object} options - * @returns {string} the generated random name - * @throws {Error} if the options are invalid or could not generate a filename - */ -function tmpNameSync(options) { - const - args = _parseArguments(options), - opts = args[0]; - - _assertAndSanitizeOptions(opts); - - let tries = opts.tries; - do { - const name = _generateTmpName(opts); - try { - fs.statSync(name); - } catch (e) { - return name; - } - } while (tries-- > 0); - - throw new Error('Could not get a unique tmp filename, max tries reached'); -} - -/** - * Creates and opens a temporary file. - * - * @param {(Options|null|undefined|fileCallback)} options the config options or the callback function or null or undefined - * @param {?fileCallback} callback - */ -function file(options, callback) { - const - args = _parseArguments(options, callback), - opts = args[0], - cb = args[1]; - - // gets a temporary filename - tmpName(opts, function _tmpNameCreated(err, name) { - /* istanbul ignore else */ - if (err) return cb(err); - - // create and open the file - fs.open(name, CREATE_FLAGS, opts.mode || FILE_MODE, function _fileCreated(err, fd) { - /* istanbu ignore else */ - if (err) return cb(err); - - if (opts.discardDescriptor) { - return fs.close(fd, function _discardCallback(possibleErr) { - // the chance of getting an error on close here is rather low and might occur in the most edgiest cases only - return cb(possibleErr, name, undefined, _prepareTmpFileRemoveCallback(name, -1, opts, false)); - }); + function enumerateInsertsAndDeletes(newItems, oldItems, comparer, inserted, deleted, unchanged) { + unchanged = unchanged || noop; + let newIndex = 0; + let oldIndex = 0; + const newLen = newItems.length; + const oldLen = oldItems.length; + let hasChanges = false; + while (newIndex < newLen && oldIndex < oldLen) { + const newItem = newItems[newIndex]; + const oldItem = oldItems[oldIndex]; + const compareResult = comparer(newItem, oldItem); + if (compareResult === -1 /* LessThan */) { + inserted(newItem); + newIndex++; + hasChanges = true; + } else if (compareResult === 1 /* GreaterThan */) { + deleted(oldItem); + oldIndex++; + hasChanges = true; } else { - // detachDescriptor passes the descriptor whereas discardDescriptor closes it, either way, we no longer care - // about the descriptor - const discardOrDetachDescriptor = opts.discardDescriptor || opts.detachDescriptor; - cb(null, name, fd, _prepareTmpFileRemoveCallback(name, discardOrDetachDescriptor ? -1 : fd, opts, false)); + unchanged(oldItem, newItem); + newIndex++; + oldIndex++; } - }); - }); -} - -/** - * Synchronous version of file. - * - * @param {Options} options - * @returns {FileSyncObject} object consists of name, fd and removeCallback - * @throws {Error} if cannot create a file - */ -function fileSync(options) { - const - args = _parseArguments(options), - opts = args[0]; - - const discardOrDetachDescriptor = opts.discardDescriptor || opts.detachDescriptor; - const name = tmpNameSync(opts); - var fd = fs.openSync(name, CREATE_FLAGS, opts.mode || FILE_MODE); - /* istanbul ignore else */ - if (opts.discardDescriptor) { - fs.closeSync(fd); - fd = undefined; - } - - return { - name: name, - fd: fd, - removeCallback: _prepareTmpFileRemoveCallback(name, discardOrDetachDescriptor ? -1 : fd, opts, true) - }; -} - -/** - * Creates a temporary directory. - * - * @param {(Options|dirCallback)} options the options or the callback function - * @param {?dirCallback} callback - */ -function dir(options, callback) { - const - args = _parseArguments(options, callback), - opts = args[0], - cb = args[1]; - - // gets a temporary filename - tmpName(opts, function _tmpNameCreated(err, name) { - /* istanbul ignore else */ - if (err) return cb(err); - - // create the directory - fs.mkdir(name, opts.mode || DIR_MODE, function _dirCreated(err) { - /* istanbul ignore else */ - if (err) return cb(err); - - cb(null, name, _prepareTmpDirRemoveCallback(name, opts, false)); - }); - }); -} - -/** - * Synchronous version of dir. - * - * @param {Options} options - * @returns {DirSyncObject} object consists of name and removeCallback - * @throws {Error} if it cannot create a directory - */ -function dirSync(options) { - const - args = _parseArguments(options), - opts = args[0]; - - const name = tmpNameSync(opts); - fs.mkdirSync(name, opts.mode || DIR_MODE); - - return { - name: name, - removeCallback: _prepareTmpDirRemoveCallback(name, opts, true) - }; -} - -/** - * Removes files asynchronously. - * - * @param {Object} fdPath - * @param {Function} next - * @private - */ -function _removeFileAsync(fdPath, next) { - const _handler = function (err) { - if (err && !_isENOENT(err)) { - // reraise any unanticipated error - return next(err); } - next(); - }; - - if (0 <= fdPath[0]) - fs.close(fdPath[0], function () { - fs.unlink(fdPath[1], _handler); - }); - else fs.unlink(fdPath[1], _handler); -} - -/** - * Removes files synchronously. - * - * @param {Object} fdPath - * @private - */ -function _removeFileSync(fdPath) { - let rethrownException = null; - try { - if (0 <= fdPath[0]) fs.closeSync(fdPath[0]); - } catch (e) { - // reraise any unanticipated error - if (!_isEBADF(e) && !_isENOENT(e)) throw e; - } finally { - try { - fs.unlinkSync(fdPath[1]); + while (newIndex < newLen) { + inserted(newItems[newIndex++]); + hasChanges = true; } - catch (e) { - // reraise any unanticipated error - if (!_isENOENT(e)) rethrownException = e; + while (oldIndex < oldLen) { + deleted(oldItems[oldIndex++]); + hasChanges = true; } + return hasChanges; } - if (rethrownException !== null) { - throw rethrownException; + function cartesianProduct(arrays) { + const result = []; + cartesianProductWorker( + arrays, + result, + /*outer*/ + void 0, + 0 + ); + return result; } -} - -/** - * Prepares the callback for removal of the temporary file. - * - * Returns either a sync callback or a async callback depending on whether - * fileSync or file was called, which is expressed by the sync parameter. - * - * @param {string} name the path of the file - * @param {number} fd file descriptor - * @param {Object} opts - * @param {boolean} sync - * @returns {fileCallback | fileCallbackSync} - * @private - */ -function _prepareTmpFileRemoveCallback(name, fd, opts, sync) { - const removeCallbackSync = _prepareRemoveCallback(_removeFileSync, [fd, name], sync); - const removeCallback = _prepareRemoveCallback(_removeFileAsync, [fd, name], sync, removeCallbackSync); - - if (!opts.keep) _removeObjects.unshift(removeCallbackSync); - - return sync ? removeCallbackSync : removeCallback; -} - -/** - * Prepares the callback for removal of the temporary directory. - * - * Returns either a sync callback or a async callback depending on whether - * tmpFileSync or tmpFile was called, which is expressed by the sync parameter. - * - * @param {string} name - * @param {Object} opts - * @param {boolean} sync - * @returns {Function} the callback - * @private - */ -function _prepareTmpDirRemoveCallback(name, opts, sync) { - const removeFunction = opts.unsafeCleanup ? rimraf : fs.rmdir.bind(fs); - const removeFunctionSync = opts.unsafeCleanup ? FN_RIMRAF_SYNC : FN_RMDIR_SYNC; - const removeCallbackSync = _prepareRemoveCallback(removeFunctionSync, name, sync); - const removeCallback = _prepareRemoveCallback(removeFunction, name, sync, removeCallbackSync); - if (!opts.keep) _removeObjects.unshift(removeCallbackSync); - - return sync ? removeCallbackSync : removeCallback; -} - -/** - * Creates a guarded function wrapping the removeFunction call. - * - * The cleanup callback is save to be called multiple times. - * Subsequent invocations will be ignored. - * - * @param {Function} removeFunction - * @param {string} fileOrDirName - * @param {boolean} sync - * @param {cleanupCallbackSync?} cleanupCallbackSync - * @returns {cleanupCallback | cleanupCallbackSync} - * @private - */ -function _prepareRemoveCallback(removeFunction, fileOrDirName, sync, cleanupCallbackSync) { - let called = false; - - // if sync is true, the next parameter will be ignored - return function _cleanupCallback(next) { - - /* istanbul ignore else */ - if (!called) { - // remove cleanupCallback from cache - const toRemove = cleanupCallbackSync || _cleanupCallback; - const index = _removeObjects.indexOf(toRemove); - /* istanbul ignore else */ - if (index >= 0) _removeObjects.splice(index, 1); - - called = true; - if (sync || removeFunction === FN_RMDIR_SYNC || removeFunction === FN_RIMRAF_SYNC) { - return removeFunction(fileOrDirName); + function cartesianProductWorker(arrays, result, outer, index) { + for (const element of arrays[index]) { + let inner; + if (outer) { + inner = outer.slice(); + inner.push(element); } else { - return removeFunction(fileOrDirName, next || function() {}); + inner = [element]; + } + if (index === arrays.length - 1) { + result.push(inner); + } else { + cartesianProductWorker(arrays, result, inner, index + 1); } } - }; -} - -/** - * The garbage collector. - * - * @private - */ -function _garbageCollector() { - /* istanbul ignore else */ - if (!_gracefulCleanup) return; - - // the function being called removes itself from _removeObjects, - // loop until _removeObjects is empty - while (_removeObjects.length) { - try { - _removeObjects[0](); - } catch (e) { - // already removed? + } + function takeWhile(array, predicate) { + if (array) { + const len = array.length; + let index = 0; + while (index < len && predicate(array[index])) { + index++; + } + return array.slice(0, index); } } -} - -/** - * Random name generator based on crypto. - * Adapted from http://blog.tompawlak.org/how-to-generate-random-values-nodejs-javascript - * - * @param {number} howMany - * @returns {string} the generated random name - * @private - */ -function _randomChars(howMany) { - let - value = [], - rnd = null; - - // make sure that we do not fail because we ran out of entropy - try { - rnd = crypto.randomBytes(howMany); - } catch (e) { - rnd = crypto.pseudoRandomBytes(howMany); + function skipWhile(array, predicate) { + if (array) { + const len = array.length; + let index = 0; + while (index < len && predicate(array[index])) { + index++; + } + return array.slice(index); + } } - - for (var i = 0; i < howMany; i++) { - value.push(RANDOM_CHARS[rnd[i] % RANDOM_CHARS.length]); + function isNodeLikeSystem() { + return typeof process !== "undefined" && !!process.nextTick && !process.browser && "object" === "object"; } - - return value.join(''); -} - -/** - * Helper which determines whether a string s is blank, that is undefined, or empty or null. - * - * @private - * @param {string} s - * @returns {Boolean} true whether the string s is blank, false otherwise - */ -function _isBlank(s) { - return s === null || _isUndefined(s) || !s.trim(); -} - -/** - * Checks whether the `obj` parameter is defined or not. - * - * @param {Object} obj - * @returns {boolean} true if the object is undefined - * @private - */ -function _isUndefined(obj) { - return typeof obj === 'undefined'; -} - -/** - * Parses the function arguments. - * - * This function helps to have optional arguments. - * - * @param {(Options|null|undefined|Function)} options - * @param {?Function} callback - * @returns {Array} parsed arguments - * @private - */ -function _parseArguments(options, callback) { - /* istanbul ignore else */ - if (typeof options === 'function') { - return [{}, options]; - } - - /* istanbul ignore else */ - if (_isUndefined(options)) { - return [{}, callback]; - } - - // copy options so we do not leak the changes we make internally - const actualOptions = {}; - for (const key of Object.getOwnPropertyNames(options)) { - actualOptions[key] = options[key]; - } - - return [actualOptions, callback]; -} - -/** - * Generates a new temporary name. - * - * @param {Object} opts - * @returns {string} the new random name according to opts - * @private - */ -function _generateTmpName(opts) { - - const tmpDir = opts.tmpdir; - - /* istanbul ignore else */ - if (!_isUndefined(opts.name)) - return path.join(tmpDir, opts.dir, opts.name); - - /* istanbul ignore else */ - if (!_isUndefined(opts.template)) - return path.join(tmpDir, opts.dir, opts.template).replace(TEMPLATE_PATTERN, _randomChars(6)); - - // prefix and postfix - const name = [ - opts.prefix ? opts.prefix : 'tmp', - '-', - process.pid, - '-', - _randomChars(12), - opts.postfix ? '-' + opts.postfix : '' - ].join(''); - - return path.join(tmpDir, opts.dir, name); -} - -/** - * Asserts whether the specified options are valid, also sanitizes options and provides sane defaults for missing - * options. - * - * @param {Options} options - * @private - */ -function _assertAndSanitizeOptions(options) { - - options.tmpdir = _getTmpDir(options); - - const tmpDir = options.tmpdir; - - /* istanbul ignore else */ - if (!_isUndefined(options.name)) - _assertIsRelative(options.name, 'name', tmpDir); - /* istanbul ignore else */ - if (!_isUndefined(options.dir)) - _assertIsRelative(options.dir, 'dir', tmpDir); - /* istanbul ignore else */ - if (!_isUndefined(options.template)) { - _assertIsRelative(options.template, 'template', tmpDir); - if (!options.template.match(TEMPLATE_PATTERN)) - throw new Error(`Invalid template, found "${options.template}".`); - } - /* istanbul ignore else */ - if (!_isUndefined(options.tries) && isNaN(options.tries) || options.tries < 0) - throw new Error(`Invalid tries, found "${options.tries}".`); - - // if a name was specified we will try once - options.tries = _isUndefined(options.name) ? options.tries || DEFAULT_TRIES : 1; - options.keep = !!options.keep; - options.detachDescriptor = !!options.detachDescriptor; - options.discardDescriptor = !!options.discardDescriptor; - options.unsafeCleanup = !!options.unsafeCleanup; - - // sanitize dir, also keep (multiple) blanks if the user, purportedly sane, requests us to - options.dir = _isUndefined(options.dir) ? '' : path.relative(tmpDir, _resolvePath(options.dir, tmpDir)); - options.template = _isUndefined(options.template) ? undefined : path.relative(tmpDir, _resolvePath(options.template, tmpDir)); - // sanitize further if template is relative to options.dir - options.template = _isBlank(options.template) ? undefined : path.relative(options.dir, options.template); - - // for completeness' sake only, also keep (multiple) blanks if the user, purportedly sane, requests us to - options.name = _isUndefined(options.name) ? undefined : _sanitizeName(options.name); - options.prefix = _isUndefined(options.prefix) ? '' : options.prefix; - options.postfix = _isUndefined(options.postfix) ? '' : options.postfix; -} - -/** - * Resolve the specified path name in respect to tmpDir. - * - * The specified name might include relative path components, e.g. ../ - * so we need to resolve in order to be sure that is is located inside tmpDir - * - * @param name - * @param tmpDir - * @returns {string} - * @private - */ -function _resolvePath(name, tmpDir) { - const sanitizedName = _sanitizeName(name); - if (sanitizedName.startsWith(tmpDir)) { - return path.resolve(sanitizedName); - } else { - return path.resolve(path.join(tmpDir, sanitizedName)); - } -} - -/** - * Sanitize the specified path name by removing all quote characters. - * - * @param name - * @returns {string} - * @private - */ -function _sanitizeName(name) { - if (_isBlank(name)) { - return name; - } - return name.replace(/["']/g, ''); -} - -/** - * Asserts whether specified name is relative to the specified tmpDir. - * - * @param {string} name - * @param {string} option - * @param {string} tmpDir - * @throws {Error} - * @private - */ -function _assertIsRelative(name, option, tmpDir) { - if (option === 'name') { - // assert that name is not absolute and does not contain a path - if (path.isAbsolute(name)) - throw new Error(`${option} option must not contain an absolute path, found "${name}".`); - // must not fail on valid . or .. or similar such constructs - let basename = path.basename(name); - if (basename === '..' || basename === '.' || basename !== name) - throw new Error(`${option} option must not contain a path, found "${name}".`); - } - else { // if (option === 'dir' || option === 'template') { - // assert that dir or template are relative to tmpDir - if (path.isAbsolute(name) && !name.startsWith(tmpDir)) { - throw new Error(`${option} option must be relative to "${tmpDir}", found "${name}".`); - } - let resolvedPath = _resolvePath(name, tmpDir); - if (!resolvedPath.startsWith(tmpDir)) - throw new Error(`${option} option must be relative to "${tmpDir}", found "${resolvedPath}".`); - } -} - -/** - * Helper for testing against EBADF to compensate changes made to Node 7.x under Windows. - * - * @private - */ -function _isEBADF(error) { - return _isExpectedError(error, -EBADF, 'EBADF'); -} - -/** - * Helper for testing against ENOENT to compensate changes made to Node 7.x under Windows. - * - * @private - */ -function _isENOENT(error) { - return _isExpectedError(error, -ENOENT, 'ENOENT'); -} - -/** - * Helper to determine whether the expected error code matches the actual code and errno, - * which will differ between the supported node versions. - * - * - Node >= 7.0: - * error.code {string} - * error.errno {number} any numerical value will be negated - * - * CAVEAT - * - * On windows, the errno for EBADF is -4083 but os.constants.errno.EBADF is different and we must assume that ENOENT - * is no different here. - * - * @param {SystemError} error - * @param {number} errno - * @param {string} code - * @private - */ -function _isExpectedError(error, errno, code) { - return IS_WIN32 ? error.code === code : error.code === code && error.errno === errno; -} - -/** - * Sets the graceful cleanup. - * - * If graceful cleanup is set, tmp will remove all controlled temporary objects on process exit, otherwise the - * temporary objects will remain in place, waiting to be cleaned up on system restart or otherwise scheduled temporary - * object removals. - */ -function setGracefulCleanup() { - _gracefulCleanup = true; -} - -/** - * Returns the currently configured tmp dir from os.tmpdir(). - * - * @private - * @param {?Options} options - * @returns {string} the currently configured tmp dir - */ -function _getTmpDir(options) { - return path.resolve(_sanitizeName(options && options.tmpdir || os.tmpdir())); -} - -// Install process exit listener -process.addListener(EXIT, _garbageCollector); - -/** - * Configuration options. - * - * @typedef {Object} Options - * @property {?boolean} keep the temporary object (file or dir) will not be garbage collected - * @property {?number} tries the number of tries before give up the name generation - * @property (?int) mode the access mode, defaults are 0o700 for directories and 0o600 for files - * @property {?string} template the "mkstemp" like filename template - * @property {?string} name fixed name relative to tmpdir or the specified dir option - * @property {?string} dir tmp directory relative to the root tmp directory in use - * @property {?string} prefix prefix for the generated name - * @property {?string} postfix postfix for the generated name - * @property {?string} tmpdir the root tmp directory which overrides the os tmpdir - * @property {?boolean} unsafeCleanup recursively removes the created temporary directory, even when it's not empty - * @property {?boolean} detachDescriptor detaches the file descriptor, caller is responsible for closing the file, tmp will no longer try closing the file during garbage collection - * @property {?boolean} discardDescriptor discards the file descriptor (closes file, fd is -1), tmp will no longer try closing the file during garbage collection - */ - -/** - * @typedef {Object} FileSyncObject - * @property {string} name the name of the file - * @property {string} fd the file descriptor or -1 if the fd has been discarded - * @property {fileCallback} removeCallback the callback function to remove the file - */ - -/** - * @typedef {Object} DirSyncObject - * @property {string} name the name of the directory - * @property {fileCallback} removeCallback the callback function to remove the directory - */ - -/** - * @callback tmpNameCallback - * @param {?Error} err the error object if anything goes wrong - * @param {string} name the temporary file name - */ - -/** - * @callback fileCallback - * @param {?Error} err the error object if anything goes wrong - * @param {string} name the temporary file name - * @param {number} fd the file descriptor or -1 if the fd had been discarded - * @param {cleanupCallback} fn the cleanup callback function - */ - -/** - * @callback fileCallbackSync - * @param {?Error} err the error object if anything goes wrong - * @param {string} name the temporary file name - * @param {number} fd the file descriptor or -1 if the fd had been discarded - * @param {cleanupCallbackSync} fn the cleanup callback function - */ - -/** - * @callback dirCallback - * @param {?Error} err the error object if anything goes wrong - * @param {string} name the temporary file name - * @param {cleanupCallback} fn the cleanup callback function - */ - -/** - * @callback dirCallbackSync - * @param {?Error} err the error object if anything goes wrong - * @param {string} name the temporary file name - * @param {cleanupCallbackSync} fn the cleanup callback function - */ - -/** - * Removes the temporary created file or directory. - * - * @callback cleanupCallback - * @param {simpleCallback} [next] function to call whenever the tmp object needs to be removed - */ - -/** - * Removes the temporary created file or directory. - * - * @callback cleanupCallbackSync - */ - -/** - * Callback function for function composition. - * @see {@link https://github.com/raszi/node-tmp/issues/57|raszi/node-tmp#57} - * - * @callback simpleCallback - */ - -// exporting all the needed methods - -// evaluate _getTmpDir() lazily, mainly for simplifying testing but it also will -// allow users to reconfigure the temporary directory -Object.defineProperty(module.exports, "tmpdir", ({ - enumerable: true, - configurable: false, - get: function () { - return _getTmpDir(); - } -})); - -module.exports.dir = dir; -module.exports.dirSync = dirSync; - -module.exports.file = file; -module.exports.fileSync = fileSync; - -module.exports.tmpName = tmpName; -module.exports.tmpNameSync = tmpNameSync; - -module.exports.setGracefulCleanup = setGracefulCleanup; - - -/***/ }), - -/***/ 12085: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { - -"use strict"; -/*! - * to-regex-range - * - * Copyright (c) 2015-present, Jon Schlinkert. - * Released under the MIT License. - */ - - - -const isNumber = __nccwpck_require__(83834); - -const toRegexRange = (min, max, options) => { - if (isNumber(min) === false) { - throw new TypeError('toRegexRange: expected the first argument to be a number'); - } - - if (max === void 0 || min === max) { - return String(min); - } - - if (isNumber(max) === false) { - throw new TypeError('toRegexRange: expected the second argument to be a number.'); - } - - let opts = { relaxZeros: true, ...options }; - if (typeof opts.strictZeros === 'boolean') { - opts.relaxZeros = opts.strictZeros === false; - } - - let relax = String(opts.relaxZeros); - let shorthand = String(opts.shorthand); - let capture = String(opts.capture); - let wrap = String(opts.wrap); - let cacheKey = min + ':' + max + '=' + relax + shorthand + capture + wrap; - - if (toRegexRange.cache.hasOwnProperty(cacheKey)) { - return toRegexRange.cache[cacheKey].result; - } - - let a = Math.min(min, max); - let b = Math.max(min, max); - - if (Math.abs(a - b) === 1) { - let result = min + '|' + max; - if (opts.capture) { - return `(${result})`; - } - if (opts.wrap === false) { - return result; - } - return `(?:${result})`; - } - - let isPadded = hasPadding(min) || hasPadding(max); - let state = { min, max, a, b }; - let positives = []; - let negatives = []; - - if (isPadded) { - state.isPadded = isPadded; - state.maxLen = String(state.max).length; - } - - if (a < 0) { - let newMin = b < 0 ? Math.abs(b) : 1; - negatives = splitToPatterns(newMin, Math.abs(a), state, opts); - a = state.a = 0; - } - - if (b >= 0) { - positives = splitToPatterns(a, b, state, opts); - } - - state.negatives = negatives; - state.positives = positives; - state.result = collatePatterns(negatives, positives, opts); - - if (opts.capture === true) { - state.result = `(${state.result})`; - } else if (opts.wrap !== false && (positives.length + negatives.length) > 1) { - state.result = `(?:${state.result})`; - } - - toRegexRange.cache[cacheKey] = state; - return state.result; -}; - -function collatePatterns(neg, pos, options) { - let onlyNegative = filterPatterns(neg, pos, '-', false, options) || []; - let onlyPositive = filterPatterns(pos, neg, '', false, options) || []; - let intersected = filterPatterns(neg, pos, '-?', true, options) || []; - let subpatterns = onlyNegative.concat(intersected).concat(onlyPositive); - return subpatterns.join('|'); -} - -function splitToRanges(min, max) { - let nines = 1; - let zeros = 1; - - let stop = countNines(min, nines); - let stops = new Set([max]); - - while (min <= stop && stop <= max) { - stops.add(stop); - nines += 1; - stop = countNines(min, nines); - } - - stop = countZeros(max + 1, zeros) - 1; - - while (min < stop && stop <= max) { - stops.add(stop); - zeros += 1; - stop = countZeros(max + 1, zeros) - 1; - } - - stops = [...stops]; - stops.sort(compare); - return stops; -} - -/** - * Convert a range to a regex pattern - * @param {Number} `start` - * @param {Number} `stop` - * @return {String} - */ - -function rangeToPattern(start, stop, options) { - if (start === stop) { - return { pattern: start, count: [], digits: 0 }; - } - - let zipped = zip(start, stop); - let digits = zipped.length; - let pattern = ''; - let count = 0; - - for (let i = 0; i < digits; i++) { - let [startDigit, stopDigit] = zipped[i]; - - if (startDigit === stopDigit) { - pattern += startDigit; - - } else if (startDigit !== '0' || stopDigit !== '9') { - pattern += toCharacterClass(startDigit, stopDigit, options); - - } else { - count++; - } - } - - if (count) { - pattern += options.shorthand === true ? '\\d' : '[0-9]'; - } - - return { pattern, count: [count], digits }; -} - -function splitToPatterns(min, max, tok, options) { - let ranges = splitToRanges(min, max); - let tokens = []; - let start = min; - let prev; - - for (let i = 0; i < ranges.length; i++) { - let max = ranges[i]; - let obj = rangeToPattern(String(start), String(max), options); - let zeros = ''; - - if (!tok.isPadded && prev && prev.pattern === obj.pattern) { - if (prev.count.length > 1) { - prev.count.pop(); - } - - prev.count.push(obj.count[0]); - prev.string = prev.pattern + toQuantifier(prev.count); - start = max + 1; - continue; - } - - if (tok.isPadded) { - zeros = padZeros(max, tok, options); - } - - obj.string = zeros + obj.pattern + toQuantifier(obj.count); - tokens.push(obj); - start = max + 1; - prev = obj; - } - - return tokens; -} - -function filterPatterns(arr, comparison, prefix, intersection, options) { - let result = []; - - for (let ele of arr) { - let { string } = ele; - - // only push if _both_ are negative... - if (!intersection && !contains(comparison, 'string', string)) { - result.push(prefix + string); - } - - // or _both_ are positive - if (intersection && contains(comparison, 'string', string)) { - result.push(prefix + string); - } - } - return result; -} - -/** - * Zip strings - */ - -function zip(a, b) { - let arr = []; - for (let i = 0; i < a.length; i++) arr.push([a[i], b[i]]); - return arr; -} - -function compare(a, b) { - return a > b ? 1 : b > a ? -1 : 0; -} - -function contains(arr, key, val) { - return arr.some(ele => ele[key] === val); -} - -function countNines(min, len) { - return Number(String(min).slice(0, -len) + '9'.repeat(len)); -} - -function countZeros(integer, zeros) { - return integer - (integer % Math.pow(10, zeros)); -} - -function toQuantifier(digits) { - let [start = 0, stop = ''] = digits; - if (stop || start > 1) { - return `{${start + (stop ? ',' + stop : '')}}`; - } - return ''; -} - -function toCharacterClass(a, b, options) { - return `[${a}${(b - a === 1) ? '' : '-'}${b}]`; -} - -function hasPadding(str) { - return /^-?(0+)\d/.test(str); -} - -function padZeros(value, tok, options) { - if (!tok.isPadded) { - return value; - } - - let diff = Math.abs(tok.maxLen - String(value).length); - let relax = options.relaxZeros !== false; - - switch (diff) { - case 0: - return ''; - case 1: - return relax ? '0?' : '0'; - case 2: - return relax ? '0{0,2}' : '00'; - default: { - return relax ? `0{0,${diff}}` : `0{${diff}}`; - } - } -} - -/** - * Cache - */ - -toRegexRange.cache = {}; -toRegexRange.clearCache = () => (toRegexRange.cache = {}); - -/** - * Expose `toRegexRange` - */ - -module.exports = toRegexRange; - - -/***/ }), - -/***/ 83834: -/***/ ((module) => { - -"use strict"; -/*! - * is-number - * - * Copyright (c) 2014-present, Jon Schlinkert. - * Released under the MIT License. - */ - - - -module.exports = function(num) { - if (typeof num === 'number') { - return num - num === 0; - } - if (typeof num === 'string' && num.trim() !== '') { - return Number.isFinite ? Number.isFinite(+num) : isFinite(+num); - } - return false; -}; - - -/***/ }), - -/***/ 87956: -/***/ ((module) => { - -// Copied from https://github.com/nodejs/node/blob/master/lib/internal/constants.js -module.exports = { - CHAR_FORWARD_SLASH: 47, /* / */ -}; - - -/***/ }), - -/***/ 79944: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { - -"use strict"; - - -const path = __nccwpck_require__(71017); - -exports.codes = { - ERR_INPUT_TYPE_NOT_ALLOWED: createErrorCtor(joinArgs('ERR_INPUT_TYPE_NOT_ALLOWED')), - ERR_INVALID_ARG_VALUE: createErrorCtor(joinArgs('ERR_INVALID_ARG_VALUE')), - ERR_INVALID_MODULE_SPECIFIER: createErrorCtor(joinArgs('ERR_INVALID_MODULE_SPECIFIER')), - ERR_INVALID_PACKAGE_CONFIG: createErrorCtor(joinArgs('ERR_INVALID_PACKAGE_CONFIG')), - ERR_INVALID_PACKAGE_TARGET: createErrorCtor(joinArgs('ERR_INVALID_PACKAGE_TARGET')), - ERR_MANIFEST_DEPENDENCY_MISSING: createErrorCtor(joinArgs('ERR_MANIFEST_DEPENDENCY_MISSING')), - ERR_MODULE_NOT_FOUND: createErrorCtor((path, base, type = 'package') => { - return `Cannot find ${type} '${path}' imported from ${base}` - }), - ERR_PACKAGE_IMPORT_NOT_DEFINED: createErrorCtor(joinArgs('ERR_PACKAGE_IMPORT_NOT_DEFINED')), - ERR_PACKAGE_PATH_NOT_EXPORTED: createErrorCtor(joinArgs('ERR_PACKAGE_PATH_NOT_EXPORTED')), - ERR_UNSUPPORTED_DIR_IMPORT: createErrorCtor(joinArgs('ERR_UNSUPPORTED_DIR_IMPORT')), - ERR_UNSUPPORTED_ESM_URL_SCHEME: createErrorCtor(joinArgs('ERR_UNSUPPORTED_ESM_URL_SCHEME')), - ERR_UNKNOWN_FILE_EXTENSION: createErrorCtor(joinArgs('ERR_UNKNOWN_FILE_EXTENSION')), -} - -function joinArgs(name) { - return (...args) => { - return [name, ...args].join(' ') - } -} - -function createErrorCtor(errorMessageCreator) { - return class CustomError extends Error { - constructor(...args) { - super(errorMessageCreator(...args)) - } - } -} -exports.createErrRequireEsm = createErrRequireEsm; - -// Native ERR_REQUIRE_ESM Error is declared here: -// https://github.com/nodejs/node/blob/2d5d77306f6dff9110c1f77fefab25f973415770/lib/internal/errors.js#L1294-L1313 -// Error class factory is implemented here: -// function E: https://github.com/nodejs/node/blob/2d5d77306f6dff9110c1f77fefab25f973415770/lib/internal/errors.js#L323-L341 -// function makeNodeErrorWithCode: https://github.com/nodejs/node/blob/2d5d77306f6dff9110c1f77fefab25f973415770/lib/internal/errors.js#L251-L278 -// The code below should create an error that matches the native error as closely as possible. -// Third-party libraries which attempt to catch the native ERR_REQUIRE_ESM should recognize our imitation error. -function createErrRequireEsm(filename, parentPath, packageJsonPath) { - const code = 'ERR_REQUIRE_ESM' - const err = new Error(getErrRequireEsmMessage(filename, parentPath, packageJsonPath)) - // Set `name` to be used in stack trace, generate stack trace with that name baked in, then re-declare the `name` field. - // This trick is copied from node's source. - err.name = `Error [${ code }]` - err.stack - Object.defineProperty(err, 'name', { - value: 'Error', - enumerable: false, - writable: true, - configurable: true - }) - err.code = code - return err -} - -// Copy-pasted from https://github.com/nodejs/node/blob/b533fb3508009e5f567cc776daba8fbf665386a6/lib/internal/errors.js#L1293-L1311 -// so that our error message is identical to the native message. -function getErrRequireEsmMessage(filename, parentPath = null, packageJsonPath = null) { - const ext = path.extname(filename) - let msg = `Must use import to load ES Module: ${filename}`; - if (parentPath && packageJsonPath) { - const path = __nccwpck_require__(71017); - const basename = path.basename(filename) === path.basename(parentPath) ? - filename : path.basename(filename); - msg += - '\nrequire() of ES modules is not supported.\nrequire() of ' + - `${filename} ${parentPath ? `from ${parentPath} ` : ''}` + - `is an ES module file as it is a ${ext} file whose nearest parent ` + - `package.json contains "type": "module" which defines all ${ext} ` + - 'files in that package scope as ES modules.\nInstead ' + - 'change the requiring code to use ' + - 'import(), or remove "type": "module" from ' + - `${packageJsonPath}.\n`; - return msg; - } - return msg; -} - - -/***/ }), - -/***/ 6836: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { - -"use strict"; -// Copied from https://github.com/nodejs/node/blob/v17.0.1/lib/internal/modules/cjs/helpers.js - - - -const { - ArrayPrototypeForEach, - ObjectDefineProperty, - ObjectPrototypeHasOwnProperty, - SafeSet, - StringPrototypeIncludes, - StringPrototypeStartsWith, -} = __nccwpck_require__(5335); - -const { getOptionValue } = __nccwpck_require__(45519); -const userConditions = getOptionValue('--conditions'); - -const noAddons = getOptionValue('--no-addons'); -const addonConditions = noAddons ? [] : ['node-addons']; - -// TODO: Use this set when resolving pkg#exports conditions in loader.js. -const cjsConditions = new SafeSet([ - 'require', - 'node', - ...addonConditions, - ...userConditions, -]); - -/** - * @param {any} object - * @param {string} [dummyModuleName] - * @return {void} - */ -function addBuiltinLibsToObject(object, dummyModuleName) { - // Make built-in modules available directly (loaded lazily). - const Module = (__nccwpck_require__(98188).Module); - const { builtinModules } = Module; - - // To require built-in modules in user-land and ignore modules whose - // `canBeRequiredByUsers` is false. So we create a dummy module object and not - // use `require()` directly. - const dummyModule = new Module(dummyModuleName); - - ArrayPrototypeForEach(builtinModules, (name) => { - // Neither add underscored modules, nor ones that contain slashes (e.g., - // 'fs/promises') or ones that are already defined. - if (StringPrototypeStartsWith(name, '_') || - StringPrototypeIncludes(name, '/') || - ObjectPrototypeHasOwnProperty(object, name)) { - return; - } - // Goals of this mechanism are: - // - Lazy loading of built-in modules - // - Having all built-in modules available as non-enumerable properties - // - Allowing the user to re-assign these variables as if there were no - // pre-existing globals with the same name. - - const setReal = (val) => { - // Deleting the property before re-assigning it disables the - // getter/setter mechanism. - delete object[name]; - object[name] = val; - }; - - ObjectDefineProperty(object, name, { - get: () => { - // Node 12 hack; remove when we drop node12 support - const lib = (dummyModule.require || require)(name); - - // Disable the current getter/setter and set up a new - // non-enumerable property. - delete object[name]; - ObjectDefineProperty(object, name, { - get: () => lib, - set: setReal, - configurable: true, - enumerable: false - }); - - return lib; - }, - set: setReal, - configurable: true, - enumerable: false - }); - }); -} - -exports.addBuiltinLibsToObject = addBuiltinLibsToObject; -exports.cjsConditions = cjsConditions; - - -/***/ }), - -/***/ 11717: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { - -"use strict"; -// Copied from several files in node's source code. -// https://github.com/nodejs/node/blob/2d5d77306f6dff9110c1f77fefab25f973415770/lib/internal/modules/cjs/loader.js -// Each function and variable below must have a comment linking to the source in node's github repo. - - - -const { - ArrayIsArray, - ArrayPrototypeIncludes, - ArrayPrototypeJoin, - ArrayPrototypePush, - JSONParse, - ObjectKeys, - RegExpPrototypeTest, - SafeMap, - SafeWeakMap, - StringPrototypeCharCodeAt, - StringPrototypeEndsWith, - StringPrototypeLastIndexOf, - StringPrototypeIndexOf, - StringPrototypeMatch, - StringPrototypeSlice, - StringPrototypeStartsWith, -} = __nccwpck_require__(5335); -const { NativeModule } = __nccwpck_require__(10765); -const { pathToFileURL, fileURLToPath } = __nccwpck_require__(57310); -const fs = __nccwpck_require__(57147); -const path = __nccwpck_require__(71017); -const { sep } = path; -const { internalModuleStat } = __nccwpck_require__(22785); -const packageJsonReader = __nccwpck_require__(19867); -const { - cjsConditions, -} = __nccwpck_require__(6836); -const { getOptionValue } = __nccwpck_require__(45519); -const preserveSymlinks = getOptionValue('--preserve-symlinks'); -const preserveSymlinksMain = getOptionValue('--preserve-symlinks-main'); -const {normalizeSlashes} = __nccwpck_require__(81842); -const {createErrRequireEsm} = __nccwpck_require__(79944); -const { - codes: { - ERR_INVALID_MODULE_SPECIFIER, - }, -} = __nccwpck_require__(79944); - -const { - CHAR_FORWARD_SLASH, -} = __nccwpck_require__(87956); - -const Module = __nccwpck_require__(98188); - -const isWindows = process.platform === 'win32'; - -let statCache = null; - -function stat(filename) { - filename = path.toNamespacedPath(filename); - if (statCache !== null) { - const result = statCache.get(filename); - if (result !== undefined) return result; - } - const result = internalModuleStat(filename); - if (statCache !== null && result >= 0) { - // Only set cache when `internalModuleStat(filename)` succeeds. - statCache.set(filename, result); - } - return result; -} - -// Note: -// we cannot get access to node's internal cache, which is populated from -// within node's Module constructor. So the cache here will always be empty. -// It's possible we could approximate our own cache by building it up with -// hacky workarounds, but it's not worth the complexity and flakiness. -const moduleParentCache = new SafeWeakMap(); - -// Given a module name, and a list of paths to test, returns the first -// matching file in the following precedence. -// -// require("a.") -// -> a. -// -// require("a") -// -> a -// -> a. -// -> a/index. - -const packageJsonCache = new SafeMap(); - -function readPackage(requestPath) { - const jsonPath = path.resolve(requestPath, 'package.json'); - - const existing = packageJsonCache.get(jsonPath); - if (existing !== undefined) return existing; - - const result = packageJsonReader.read(jsonPath); - const json = result.containsKeys === false ? '{}' : result.string; - if (json === undefined) { - packageJsonCache.set(jsonPath, false); - return false; - } - - try { - const parsed = JSONParse(json); - const filtered = { - name: parsed.name, - main: parsed.main, - exports: parsed.exports, - imports: parsed.imports, - type: parsed.type - }; - packageJsonCache.set(jsonPath, filtered); - return filtered; - } catch (e) { - e.path = jsonPath; - e.message = 'Error parsing ' + jsonPath + ': ' + e.message; - throw e; - } -} - -function readPackageScope(checkPath) { - const rootSeparatorIndex = StringPrototypeIndexOf(checkPath, sep); - let separatorIndex; - do { - separatorIndex = StringPrototypeLastIndexOf(checkPath, sep); - checkPath = StringPrototypeSlice(checkPath, 0, separatorIndex); - if (StringPrototypeEndsWith(checkPath, sep + 'node_modules')) - return false; - const pjson = readPackage(checkPath + sep); - if (pjson) return { - data: pjson, - path: checkPath, - }; - } while (separatorIndex > rootSeparatorIndex); - return false; -} - -/** - * @param {{ - * nodeEsmResolver: ReturnType, - * extensions: import('../src/file-extensions').Extensions, - * preferTsExts - * }} opts - */ -function createCjsLoader(opts) { -const {nodeEsmResolver, preferTsExts} = opts; -const {replacementsForCjs, replacementsForJs, replacementsForMjs, replacementsForJsx} = opts.extensions; -const { - encodedSepRegEx, - packageExportsResolve, - packageImportsResolve -} = nodeEsmResolver; - -function tryPackage(requestPath, exts, isMain, originalPath) { - // const pkg = readPackage(requestPath)?.main; - const tmp = readPackage(requestPath) - const pkg = tmp != null ? tmp.main : undefined; - - if (!pkg) { - return tryExtensions(path.resolve(requestPath, 'index'), exts, isMain); - } - - const filename = path.resolve(requestPath, pkg); - let actual = tryReplacementExtensions(filename, isMain) || - tryFile(filename, isMain) || - tryExtensions(filename, exts, isMain) || - tryExtensions(path.resolve(filename, 'index'), exts, isMain); - if (actual === false) { - actual = tryExtensions(path.resolve(requestPath, 'index'), exts, isMain); - if (!actual) { - // eslint-disable-next-line no-restricted-syntax - const err = new Error( - `Cannot find module '${filename}'. ` + - 'Please verify that the package.json has a valid "main" entry' - ); - err.code = 'MODULE_NOT_FOUND'; - err.path = path.resolve(requestPath, 'package.json'); - err.requestPath = originalPath; - // TODO(BridgeAR): Add the requireStack as well. - throw err; - } else { - const jsonPath = path.resolve(requestPath, 'package.json'); - process.emitWarning( - `Invalid 'main' field in '${jsonPath}' of '${pkg}'. ` + - 'Please either fix that or report it to the module author', - 'DeprecationWarning', - 'DEP0128' - ); + var emptyArray, emptyMap, emptySet, SortKind, elementAt, hasOwnProperty, fileNameLowerCaseRegExp, AssertionLevel, createUIStringComparer, uiComparerCaseSensitive, uiLocale; + var init_core = __esm({ + "src/compiler/core.ts"() { + "use strict"; + init_ts2(); + emptyArray = []; + emptyMap = /* @__PURE__ */ new Map(); + emptySet = /* @__PURE__ */ new Set(); + SortKind = /* @__PURE__ */ ((SortKind2) => { + SortKind2[SortKind2["None"] = 0] = "None"; + SortKind2[SortKind2["CaseSensitive"] = 1] = "CaseSensitive"; + SortKind2[SortKind2["CaseInsensitive"] = 2] = "CaseInsensitive"; + SortKind2[SortKind2["Both"] = 3] = "Both"; + return SortKind2; + })(SortKind || {}); + elementAt = !!Array.prototype.at ? (array, offset) => array == null ? void 0 : array.at(offset) : (array, offset) => { + if (array) { + offset = toOffset(array, offset); + if (offset < array.length) { + return array[offset]; + } + } + return void 0; + }; + hasOwnProperty = Object.prototype.hasOwnProperty; + fileNameLowerCaseRegExp = /[^\u0130\u0131\u00DFa-z0-9\\/:\-_. ]+/g; + AssertionLevel = /* @__PURE__ */ ((AssertionLevel2) => { + AssertionLevel2[AssertionLevel2["None"] = 0] = "None"; + AssertionLevel2[AssertionLevel2["Normal"] = 1] = "Normal"; + AssertionLevel2[AssertionLevel2["Aggressive"] = 2] = "Aggressive"; + AssertionLevel2[AssertionLevel2["VeryAggressive"] = 3] = "VeryAggressive"; + return AssertionLevel2; + })(AssertionLevel || {}); + createUIStringComparer = (() => { + return createIntlCollatorStringComparer; + function compareWithCallback(a, b, comparer) { + if (a === b) + return 0 /* EqualTo */; + if (a === void 0) + return -1 /* LessThan */; + if (b === void 0) + return 1 /* GreaterThan */; + const value = comparer(a, b); + return value < 0 ? -1 /* LessThan */ : value > 0 ? 1 /* GreaterThan */ : 0 /* EqualTo */; + } + function createIntlCollatorStringComparer(locale) { + const comparer = new Intl.Collator(locale, { usage: "sort", sensitivity: "variant" }).compare; + return (a, b) => compareWithCallback(a, b, comparer); + } + })(); } - } - return actual; -} - -// In order to minimize unnecessary lstat() calls, -// this cache is a list of known-real paths. -// Set to an empty Map to reset. -const realpathCache = new SafeMap(); - -// Check if the file exists and is not a directory -// if using --preserve-symlinks and isMain is false, -// keep symlinks intact, otherwise resolve to the -// absolute realpath. -function tryFile(requestPath, isMain) { - const rc = stat(requestPath); - if (rc !== 0) return; - if (preserveSymlinks && !isMain) { - return path.resolve(requestPath); - } - return toRealPath(requestPath); -} - -function toRealPath(requestPath) { - return fs.realpathSync(requestPath, { - // [internalFS.realpathCacheKey]: realpathCache }); -} -function statReplacementExtensions(p) { - const lastDotIndex = p.lastIndexOf('.'); - if(lastDotIndex >= 0) { - const ext = p.slice(lastDotIndex); - if (ext === '.js' || ext === '.jsx' || ext === '.mjs' || ext === '.cjs') { - const pathnameWithoutExtension = p.slice(0, lastDotIndex); - const replacementExts = - ext === '.js' ? replacementsForJs - : ext === '.jsx' ? replacementsForJsx - : ext === '.mjs' ? replacementsForMjs - : replacementsForCjs; - for (let i = 0; i < replacementExts.length; i++) { - const filename = pathnameWithoutExtension + replacementExts[i]; - const rc = stat(filename); - if (rc === 0) { - return [rc, filename]; + // src/compiler/debug.ts + var LogLevel, Debug; + var init_debug = __esm({ + "src/compiler/debug.ts"() { + "use strict"; + init_ts2(); + init_ts2(); + LogLevel = /* @__PURE__ */ ((LogLevel3) => { + LogLevel3[LogLevel3["Off"] = 0] = "Off"; + LogLevel3[LogLevel3["Error"] = 1] = "Error"; + LogLevel3[LogLevel3["Warning"] = 2] = "Warning"; + LogLevel3[LogLevel3["Info"] = 3] = "Info"; + LogLevel3[LogLevel3["Verbose"] = 4] = "Verbose"; + return LogLevel3; + })(LogLevel || {}); + ((Debug2) => { + let currentAssertionLevel = 0 /* None */; + Debug2.currentLogLevel = 2 /* Warning */; + Debug2.isDebugging = false; + function shouldLog(level) { + return Debug2.currentLogLevel <= level; } - } - } - } - return [stat(p), p]; -} -function tryReplacementExtensions(p, isMain) { - const lastDotIndex = p.lastIndexOf('.'); - if(lastDotIndex >= 0) { - const ext = p.slice(lastDotIndex); - if (ext === '.js' || ext === '.jsx' || ext === '.mjs' || ext === '.cjs') { - const pathnameWithoutExtension = p.slice(0, lastDotIndex); - const replacementExts = - ext === '.js' ? replacementsForJs - : ext === '.jsx' ? replacementsForJsx - : ext === '.mjs' ? replacementsForMjs - : replacementsForCjs; - for (let i = 0; i < replacementExts.length; i++) { - const filename = tryFile(pathnameWithoutExtension + replacementExts[i], isMain); - if (filename) { - return filename; + Debug2.shouldLog = shouldLog; + function logMessage(level, s) { + if (Debug2.loggingHost && shouldLog(level)) { + Debug2.loggingHost.log(level, s); + } } - } - } - } - return false; -} - -// Given a path, check if the file exists with any of the set extensions -function tryExtensions(p, exts, isMain) { - for (let i = 0; i < exts.length; i++) { - const filename = tryFile(p + exts[i], isMain); - - if (filename) { - return filename; - } - } - return false; -} - -function trySelfParentPath(parent) { - if (!parent) return false; - - if (parent.filename) { - return parent.filename; - } else if (parent.id === '' || parent.id === 'internal/preload') { - try { - return process.cwd() + path.sep; - } catch { - return false; - } - } -} - -function trySelf(parentPath, request) { - if (!parentPath) return false; - - const { data: pkg, path: pkgPath } = readPackageScope(parentPath) || {}; - if (!pkg || pkg.exports === undefined) return false; - if (typeof pkg.name !== 'string') return false; - - let expansion; - if (request === pkg.name) { - expansion = '.'; - } else if (StringPrototypeStartsWith(request, `${pkg.name}/`)) { - expansion = '.' + StringPrototypeSlice(request, pkg.name.length); - } else { - return false; - } - - try { - return finalizeEsmResolution(packageExportsResolve( - pathToFileURL(pkgPath + '/package.json'), expansion, pkg, - pathToFileURL(parentPath), cjsConditions).resolved, parentPath, pkgPath); - } catch (e) { - if (e.code === 'ERR_MODULE_NOT_FOUND') - throw createEsmNotFoundErr(request, pkgPath + '/package.json'); - throw e; - } -} - -// This only applies to requests of a specific form: -// 1. name/.* -// 2. @scope/name/.* -const EXPORTS_PATTERN = /^((?:@[^/\\%]+\/)?[^./\\%][^/\\%]*)(\/.*)?$/; -function resolveExports(nmPath, request) { - // The implementation's behavior is meant to mirror resolution in ESM. - const { 1: name, 2: expansion = '' } = - StringPrototypeMatch(request, EXPORTS_PATTERN) || []; - if (!name) - return; - const pkgPath = path.resolve(nmPath, name); - const pkg = readPackage(pkgPath); - // if (pkg?.exports != null) { - if (pkg != null && pkg.exports != null) { - try { - return finalizeEsmResolution(packageExportsResolve( - pathToFileURL(pkgPath + '/package.json'), '.' + expansion, pkg, null, - cjsConditions).resolved, null, pkgPath); - } catch (e) { - if (e.code === 'ERR_MODULE_NOT_FOUND') - throw createEsmNotFoundErr(request, pkgPath + '/package.json'); - throw e; - } - } -} - -// Backwards compat for old node versions -const hasModulePathCache = !!(__nccwpck_require__(98188)._pathCache); -const Module_pathCache = Object.create(null); -const Module_pathCache_get = hasModulePathCache ? (cacheKey) => Module._pathCache[cacheKey] : (cacheKey) => Module_pathCache[cacheKey]; -const Module_pathCache_set = hasModulePathCache ? (cacheKey, value) => (Module._pathCache[cacheKey] = value) : (cacheKey) => (Module_pathCache[cacheKey] = value); - -const trailingSlashRegex = /(?:^|\/)\.?\.$/; -const Module_findPath = function _findPath(request, paths, isMain) { - const absoluteRequest = path.isAbsolute(request); - if (absoluteRequest) { - paths = ['']; - } else if (!paths || paths.length === 0) { - return false; - } - - const cacheKey = request + '\x00' + ArrayPrototypeJoin(paths, '\x00'); - const entry = Module_pathCache_get(cacheKey); - if (entry) - return entry; - - let exts; - let trailingSlash = request.length > 0 && - StringPrototypeCharCodeAt(request, request.length - 1) === - CHAR_FORWARD_SLASH; - if (!trailingSlash) { - trailingSlash = RegExpPrototypeTest(trailingSlashRegex, request); - } - - // For each path - for (let i = 0; i < paths.length; i++) { - // Don't search further if path doesn't exist - const curPath = paths[i]; - if (curPath && stat(curPath) < 1) continue; - - if (!absoluteRequest) { - const exportsResolved = resolveExports(curPath, request); - if (exportsResolved) - return exportsResolved; - } - - const _basePath = path.resolve(curPath, request); - let filename; - - const [rc, basePath] = statReplacementExtensions(_basePath); - if (!trailingSlash) { - if (rc === 0) { // File. - if (!isMain) { - if (preserveSymlinks) { - filename = path.resolve(basePath); - } else { - filename = toRealPath(basePath); + function log(s) { + logMessage(3 /* Info */, s); + } + Debug2.log = log; + ((_log) => { + function error2(s) { + logMessage(1 /* Error */, s); } - } else if (preserveSymlinksMain) { - // For the main module, we use the preserveSymlinksMain flag instead - // mainly for backward compatibility, as the preserveSymlinks flag - // historically has not applied to the main module. Most likely this - // was intended to keep .bin/ binaries working, as following those - // symlinks is usually required for the imports in the corresponding - // files to resolve; that said, in some use cases following symlinks - // causes bigger problems which is why the preserveSymlinksMain option - // is needed. - filename = path.resolve(basePath); - } else { - filename = toRealPath(basePath); + _log.error = error2; + function warn(s) { + logMessage(2 /* Warning */, s); + } + _log.warn = warn; + function log2(s) { + logMessage(3 /* Info */, s); + } + _log.log = log2; + function trace2(s) { + logMessage(4 /* Verbose */, s); + } + _log.trace = trace2; + })(log = Debug2.log || (Debug2.log = {})); + const assertionCache = {}; + function getAssertionLevel() { + return currentAssertionLevel; } - } - - if (!filename) { - // Try it with each of the extensions - if (exts === undefined) - exts = ObjectKeys(Module._extensions); - filename = tryExtensions(basePath, exts, isMain); - } - } - - if (!filename && rc === 1) { // Directory. - // try it with each of the extensions at "index" - if (exts === undefined) - exts = ObjectKeys(Module._extensions); - filename = tryPackage(basePath, exts, isMain, request); - } - - if (filename) { - Module_pathCache_set(cacheKey, filename); - return filename; - } - } - - return false; -}; - -const Module_resolveFilename = function _resolveFilename(request, parent, isMain, options) { - if (StringPrototypeStartsWith(request, 'node:') || - NativeModule.canBeRequiredByUsers(request)) { - return request; - } - - let paths; - - if (typeof options === 'object' && options !== null) { - if (ArrayIsArray(options.paths)) { - const isRelative = StringPrototypeStartsWith(request, './') || - StringPrototypeStartsWith(request, '../') || - ((isWindows && StringPrototypeStartsWith(request, '.\\')) || - StringPrototypeStartsWith(request, '..\\')); - - if (isRelative) { - paths = options.paths; - } else { - const fakeParent = new Module('', null); - - paths = []; - - for (let i = 0; i < options.paths.length; i++) { - const path = options.paths[i]; - fakeParent.paths = Module._nodeModulePaths(path); - const lookupPaths = Module._resolveLookupPaths(request, fakeParent); - - for (let j = 0; j < lookupPaths.length; j++) { - if (!ArrayPrototypeIncludes(paths, lookupPaths[j])) - ArrayPrototypePush(paths, lookupPaths[j]); + Debug2.getAssertionLevel = getAssertionLevel; + function setAssertionLevel(level) { + const prevAssertionLevel = currentAssertionLevel; + currentAssertionLevel = level; + if (level > prevAssertionLevel) { + for (const key of getOwnKeys(assertionCache)) { + const cachedFunc = assertionCache[key]; + if (cachedFunc !== void 0 && Debug2[key] !== cachedFunc.assertion && level >= cachedFunc.level) { + Debug2[key] = cachedFunc; + assertionCache[key] = void 0; + } + } } } - } - } else if (options.paths === undefined) { - paths = Module._resolveLookupPaths(request, parent); - } else { - throw new ERR_INVALID_ARG_VALUE('options.paths', options.paths); - } - } else { - paths = Module._resolveLookupPaths(request, parent); - } - - // if (parent?.filename) { - // node 12 hack - if (parent != null && parent.filename) { - if (request[0] === '#') { - const pkg = readPackageScope(parent.filename) || {}; - - // if (pkg.data?.imports != null) { - // node 12 hack - if (pkg.data != null && pkg.data.imports != null) { - try { - return finalizeEsmResolution( - packageImportsResolve(request, pathToFileURL(parent.filename), - cjsConditions), parent.filename, - pkg.path); - } catch (e) { - if (e.code === 'ERR_MODULE_NOT_FOUND') - throw createEsmNotFoundErr(request); + Debug2.setAssertionLevel = setAssertionLevel; + function shouldAssert(level) { + return currentAssertionLevel >= level; + } + Debug2.shouldAssert = shouldAssert; + function shouldAssertFunction(level, name) { + if (!shouldAssert(level)) { + assertionCache[name] = { level, assertion: Debug2[name] }; + Debug2[name] = noop; + return false; + } + return true; + } + function fail(message, stackCrawlMark) { + debugger; + const e = new Error(message ? `Debug Failure. ${message}` : "Debug Failure."); + if (Error.captureStackTrace) { + Error.captureStackTrace(e, stackCrawlMark || fail); + } throw e; } - } - } - } - - // Try module self resolution first - const parentPath = trySelfParentPath(parent); - const selfResolved = trySelf(parentPath, request); - if (selfResolved) { - const cacheKey = request + '\x00' + - (paths.length === 1 ? paths[0] : ArrayPrototypeJoin(paths, '\x00')); - Module._pathCache[cacheKey] = selfResolved; - return selfResolved; - } - - // Look up the filename first, since that's the cache key. - const filename = Module._findPath(request, paths, isMain, false); - if (filename) return filename; - const requireStack = []; - for (let cursor = parent; - cursor; - cursor = moduleParentCache.get(cursor)) { - ArrayPrototypePush(requireStack, cursor.filename || cursor.id); - } - let message = `Cannot find module '${request}'`; - if (requireStack.length > 0) { - message = message + '\nRequire stack:\n- ' + - ArrayPrototypeJoin(requireStack, '\n- '); - } - // eslint-disable-next-line no-restricted-syntax - const err = new Error(message); - err.code = 'MODULE_NOT_FOUND'; - err.requireStack = requireStack; - throw err; -}; - -function finalizeEsmResolution(resolved, parentPath, pkgPath) { - if (RegExpPrototypeTest(encodedSepRegEx, resolved)) - throw new ERR_INVALID_MODULE_SPECIFIER( - resolved, 'must not include encoded "/" or "\\" characters', parentPath); - const filename = fileURLToPath(resolved); - const actual = tryReplacementExtensions(filename) || tryFile(filename); - if (actual) - return actual; - const err = createEsmNotFoundErr(filename, - path.resolve(pkgPath, 'package.json')); - throw err; -} - -function createEsmNotFoundErr(request, path) { - // eslint-disable-next-line no-restricted-syntax - const err = new Error(`Cannot find module '${request}'`); - err.code = 'MODULE_NOT_FOUND'; - if (path) - err.path = path; - // TODO(BridgeAR): Add the requireStack as well. - return err; -} - - -return { - Module_findPath, - Module_resolveFilename -} - -} - -/** - * copied from Module._extensions['.js'] - * https://github.com/nodejs/node/blob/v15.3.0/lib/internal/modules/cjs/loader.js#L1113-L1120 - * @param {import('../src/index').Service} service - * @param {NodeJS.Module} module - * @param {string} filename - */ -function assertScriptCanLoadAsCJSImpl(service, module, filename) { - const pkg = readPackageScope(filename); - - // ts-node modification: allow our configuration to override - const tsNodeClassification = service.moduleTypeClassifier.classifyModuleByModuleTypeOverrides(normalizeSlashes(filename)); - if(tsNodeClassification.moduleType === 'cjs') return; - - // ignore package.json when file extension is ESM-only or CJS-only - // [MUST_UPDATE_FOR_NEW_FILE_EXTENSIONS] - const lastDotIndex = filename.lastIndexOf('.'); - const ext = lastDotIndex >= 0 ? filename.slice(lastDotIndex) : ''; - - if((ext === '.cts' || ext === '.cjs') && tsNodeClassification.moduleType === 'auto') return; - - // Function require shouldn't be used in ES modules. - if (ext === '.mts' || ext === '.mjs' || tsNodeClassification.moduleType === 'esm' || (pkg && pkg.data && pkg.data.type === 'module')) { - const parentPath = module.parent && module.parent.filename; - const packageJsonPath = pkg ? path.resolve(pkg.path, 'package.json') : null; - throw createErrRequireEsm(filename, parentPath, packageJsonPath); - } -} - - -module.exports = { - createCjsLoader, - assertScriptCanLoadAsCJSImpl, - readPackageScope -}; - - -/***/ }), - -/***/ 77114: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { - -"use strict"; -// Copied from https://raw.githubusercontent.com/nodejs/node/v15.3.0/lib/internal/modules/esm/get_format.js - - -const { - RegExpPrototypeExec, - StringPrototypeStartsWith, -} = __nccwpck_require__(5335); -const { extname } = __nccwpck_require__(71017); -const { getOptionValue } = __nccwpck_require__(45519); - -const [nodeMajor, nodeMinor] = process.versions.node.split('.').map(s => parseInt(s, 10)); -const experimentalJsonModules = - nodeMajor > 17 - || (nodeMajor === 17 && nodeMinor >= 5) - || (nodeMajor === 16 && nodeMinor >= 15) - || getOptionValue('--experimental-json-modules'); -const experimentalWasmModules = getOptionValue('--experimental-wasm-modules'); -const { URL, fileURLToPath } = __nccwpck_require__(57310); -const { ERR_UNKNOWN_FILE_EXTENSION } = (__nccwpck_require__(79944).codes); - -const extensionFormatMap = { - '__proto__': null, - '.cjs': 'commonjs', - '.js': 'module', - '.mjs': 'module' -}; - -const legacyExtensionFormatMap = { - '__proto__': null, - '.cjs': 'commonjs', - '.js': 'commonjs', - '.json': 'commonjs', - '.mjs': 'module', - '.node': 'commonjs' -}; - -if (experimentalWasmModules) - extensionFormatMap['.wasm'] = legacyExtensionFormatMap['.wasm'] = 'wasm'; - -if (experimentalJsonModules) - extensionFormatMap['.json'] = legacyExtensionFormatMap['.json'] = 'json'; - -/** - * - * @param {'node' | 'explicit'} [tsNodeExperimentalSpecifierResolution] - * @param {ReturnType< - * typeof import('../dist-raw/node-internal-modules-esm-resolve').createResolve - * >} nodeEsmResolver - */ -function createGetFormat(tsNodeExperimentalSpecifierResolution, nodeEsmResolver) { -// const experimentalSpeciferResolution = tsNodeExperimentalSpecifierResolution ?? getOptionValue('--experimental-specifier-resolution'); -let experimentalSpeciferResolution = tsNodeExperimentalSpecifierResolution != null ? tsNodeExperimentalSpecifierResolution : getOptionValue('--experimental-specifier-resolution'); -const { getPackageType } = nodeEsmResolver; - -/** - * @param {string} url - * @param {{}} context - * @param {any} defaultGetFormatUnused - * @returns {ReturnType} - */ -function defaultGetFormat(url, context, defaultGetFormatUnused) { - if (StringPrototypeStartsWith(url, 'node:')) { - return { format: 'builtin' }; - } - const parsed = new URL(url); - if (parsed.protocol === 'data:') { - const [ , mime ] = RegExpPrototypeExec( - /^([^/]+\/[^;,]+)(?:[^,]*?)(;base64)?,/, - parsed.pathname, - ) || [ null, null, null ]; - const format = ({ - '__proto__': null, - 'text/javascript': 'module', - 'application/json': experimentalJsonModules ? 'json' : null, - 'application/wasm': experimentalWasmModules ? 'wasm' : null - })[mime] || null; - return { format }; - } else if (parsed.protocol === 'file:') { - const ext = extname(parsed.pathname); - let format; - if (ext === '.js') { - format = getPackageType(parsed.href) === 'module' ? 'module' : 'commonjs'; - } else { - format = extensionFormatMap[ext]; - } - if (!format) { - if (experimentalSpeciferResolution === 'node') { - process.emitWarning( - 'The Node.js specifier resolution in ESM is experimental.', - 'ExperimentalWarning'); - format = legacyExtensionFormatMap[ext]; - } else { - throw new ERR_UNKNOWN_FILE_EXTENSION(ext, fileURLToPath(url)); - } - } - return { format: format || null }; - } - return { format: null }; -} - -return {defaultGetFormat}; -} - -module.exports = { - createGetFormat -}; - - -/***/ }), - -/***/ 83788: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { - -"use strict"; -// Copied from https://raw.githubusercontent.com/nodejs/node/v15.3.0/lib/internal/modules/esm/resolve.js - - - -const {versionGteLt} = __nccwpck_require__(81842); - -// Test for node >14.13.1 || (>=12.20.0 && <13) -const builtinModuleProtocol = - versionGteLt(process.versions.node, '14.13.1') || - versionGteLt(process.versions.node, '12.20.0', '13.0.0') - ? 'node:' - : 'nodejs:'; - -const { - ArrayIsArray, - ArrayPrototypeJoin, - ArrayPrototypeShift, - JSONParse, - JSONStringify, - ObjectFreeze, - ObjectGetOwnPropertyNames, - ObjectPrototypeHasOwnProperty, - RegExpPrototypeTest, - SafeMap, - SafeSet, - StringPrototypeEndsWith, - StringPrototypeIndexOf, - StringPrototypeLastIndexOf, - StringPrototypeReplace, - StringPrototypeSlice, - StringPrototypeSplit, - StringPrototypeStartsWith, - StringPrototypeSubstr, -} = __nccwpck_require__(5335); - -// const internalFS = require('internal/fs/utils'); -const Module = __nccwpck_require__(98188); -const { NativeModule } = __nccwpck_require__(10765); -const { - realpathSync, - statSync, - Stats, -} = __nccwpck_require__(57147); -// const { getOptionValue } = require('internal/options'); -const { getOptionValue } = __nccwpck_require__(45519); -// // Do not eagerly grab .manifest, it may be in TDZ -// const policy = getOptionValue('--experimental-policy') ? -// require('internal/process/policy') : -// null; -// disabled for now. I am not sure if/how we should support this -const policy = null; -const { sep, relative } = __nccwpck_require__(71017); -const preserveSymlinks = getOptionValue('--preserve-symlinks'); -const preserveSymlinksMain = getOptionValue('--preserve-symlinks-main'); -const typeFlag = getOptionValue('--input-type'); -// const { URL, pathToFileURL, fileURLToPath } = require('internal/url'); -const { URL, pathToFileURL, fileURLToPath } = __nccwpck_require__(57310); -const { - ERR_INPUT_TYPE_NOT_ALLOWED, - ERR_INVALID_ARG_VALUE, - ERR_INVALID_MODULE_SPECIFIER, - ERR_INVALID_PACKAGE_CONFIG, - ERR_INVALID_PACKAGE_TARGET, - ERR_MANIFEST_DEPENDENCY_MISSING, - ERR_MODULE_NOT_FOUND, - ERR_PACKAGE_IMPORT_NOT_DEFINED, - ERR_PACKAGE_PATH_NOT_EXPORTED, - ERR_UNSUPPORTED_DIR_IMPORT, - ERR_UNSUPPORTED_ESM_URL_SCHEME, -// } = require('internal/errors').codes; -} = (__nccwpck_require__(79944).codes); - -// const { Module: CJSModule } = require('internal/modules/cjs/loader'); -const CJSModule = Module; - -// const packageJsonReader = require('internal/modules/package_json_reader'); -const packageJsonReader = __nccwpck_require__(19867); -const userConditions = getOptionValue('--conditions'); -const DEFAULT_CONDITIONS = ObjectFreeze(['node', 'import', ...userConditions]); -const DEFAULT_CONDITIONS_SET = new SafeSet(DEFAULT_CONDITIONS); - -const pendingDeprecation = getOptionValue('--pending-deprecation'); - -/** - * @param {{ - * extensions: import('../src/file-extensions').Extensions, - * preferTsExts: boolean | undefined; - * tsNodeExperimentalSpecifierResolution: import('../src/index').ExperimentalSpecifierResolution | undefined; - * }} opts - */ -function createResolve(opts) { -// TODO receive cached fs implementations here -const {preferTsExts, tsNodeExperimentalSpecifierResolution, extensions} = opts; -const esrnExtensions = extensions.experimentalSpecifierResolutionAddsIfOmitted; -const {legacyMainResolveAddsIfOmitted, replacementsForCjs, replacementsForJs, replacementsForMjs, replacementsForJsx} = extensions; -// const experimentalSpecifierResolution = tsNodeExperimentalSpecifierResolution ?? getOptionValue('--experimental-specifier-resolution'); -const experimentalSpecifierResolution = tsNodeExperimentalSpecifierResolution != null ? tsNodeExperimentalSpecifierResolution : getOptionValue('--experimental-specifier-resolution'); - -const emittedPackageWarnings = new SafeSet(); -function emitFolderMapDeprecation(match, pjsonUrl, isExports, base) { - const pjsonPath = fileURLToPath(pjsonUrl); - if (!pendingDeprecation) { - const nodeModulesIndex = StringPrototypeLastIndexOf(pjsonPath, - '/node_modules/'); - if (nodeModulesIndex !== -1) { - const afterNodeModulesPath = StringPrototypeSlice(pjsonPath, - nodeModulesIndex + 14, - -13); - try { - const { packageSubpath } = parsePackageName(afterNodeModulesPath); - if (packageSubpath === '.') - return; - } catch {} - } - } - if (emittedPackageWarnings.has(pjsonPath + '|' + match)) - return; - emittedPackageWarnings.add(pjsonPath + '|' + match); - process.emitWarning( - `Use of deprecated folder mapping "${match}" in the ${isExports ? - '"exports"' : '"imports"'} field module resolution of the package at ${ - pjsonPath}${base ? ` imported from ${fileURLToPath(base)}` : ''}.\n` + - `Update this package.json to use a subpath pattern like "${match}*".`, - 'DeprecationWarning', - 'DEP0148' - ); -} - -function getConditionsSet(conditions) { - if (conditions !== undefined && conditions !== DEFAULT_CONDITIONS) { - if (!ArrayIsArray(conditions)) { - throw new ERR_INVALID_ARG_VALUE('conditions', conditions, - 'expected an array'); - } - return new SafeSet(conditions); - } - return DEFAULT_CONDITIONS_SET; -} - -const realpathCache = new SafeMap(); -const packageJSONCache = new SafeMap(); /* string -> PackageConfig */ - -const statSupportsThrowIfNoEntry = versionGteLt(process.versions.node, '15.3.0') || - versionGteLt(process.versions.node, '14.17.0', '15.0.0'); -const tryStatSync = statSupportsThrowIfNoEntry ? tryStatSyncWithoutErrors : tryStatSyncWithErrors; -const statsIfNotFound = new Stats(); -function tryStatSyncWithoutErrors(path) { - const stats = statSync(path, { throwIfNoEntry: false }); - if(stats != null) return stats; - return statsIfNotFound; -} -function tryStatSyncWithErrors(path) { - try { - return statSync(path); - } catch { - return statsIfNotFound; - } -} - -function getPackageConfig(path, specifier, base) { - const existing = packageJSONCache.get(path); - if (existing !== undefined) { - return existing; - } - const source = packageJsonReader.read(path).string; - if (source === undefined) { - const packageConfig = { - pjsonPath: path, - exists: false, - main: undefined, - name: undefined, - type: 'none', - exports: undefined, - imports: undefined, - }; - packageJSONCache.set(path, packageConfig); - return packageConfig; - } - - let packageJSON; - try { - packageJSON = JSONParse(source); - } catch (error) { - throw new ERR_INVALID_PACKAGE_CONFIG( - path, - (base ? `"${specifier}" from ` : '') + fileURLToPath(base || specifier), - error.message - ); - } - - let { imports, main, name, type } = packageJSON; - const { exports } = packageJSON; - if (typeof imports !== 'object' || imports === null) imports = undefined; - if (typeof main !== 'string') main = undefined; - if (typeof name !== 'string') name = undefined; - // Ignore unknown types for forwards compatibility - if (type !== 'module' && type !== 'commonjs') type = 'none'; - - const packageConfig = { - pjsonPath: path, - exists: true, - main, - name, - type, - exports, - imports, - }; - packageJSONCache.set(path, packageConfig); - return packageConfig; -} - -function getPackageScopeConfig(resolved) { - let packageJSONUrl = new URL('./package.json', resolved); - while (true) { - const packageJSONPath = packageJSONUrl.pathname; - if (StringPrototypeEndsWith(packageJSONPath, 'node_modules/package.json')) - break; - const packageConfig = getPackageConfig(fileURLToPath(packageJSONUrl), - resolved); - if (packageConfig.exists) return packageConfig; - - const lastPackageJSONUrl = packageJSONUrl; - packageJSONUrl = new URL('../package.json', packageJSONUrl); - - // Terminates at root where ../package.json equals ../../package.json - // (can't just check "/package.json" for Windows support). - if (packageJSONUrl.pathname === lastPackageJSONUrl.pathname) break; - } - const packageJSONPath = fileURLToPath(packageJSONUrl); - const packageConfig = { - pjsonPath: packageJSONPath, - exists: false, - main: undefined, - name: undefined, - type: 'none', - exports: undefined, - imports: undefined, - }; - packageJSONCache.set(packageJSONPath, packageConfig); - return packageConfig; -} - -/* - * Legacy CommonJS main resolution: - * 1. let M = pkg_url + (json main field) - * 2. TRY(M, M.js, M.json, M.node) - * 3. TRY(M/index.js, M/index.json, M/index.node) - * 4. TRY(pkg_url/index.js, pkg_url/index.json, pkg_url/index.node) - * 5. NOT_FOUND - */ -function fileExists(url) { - return tryStatSync(fileURLToPath(url)).isFile(); -} - -function legacyMainResolve(packageJSONUrl, packageConfig, base) { - let guess; - if (packageConfig.main !== undefined) { - // Note: fs check redundances will be handled by Descriptor cache here. - if(guess = resolveReplacementExtensions(new URL(`./${packageConfig.main}`, packageJSONUrl))) { - return guess; - } - if (fileExists(guess = new URL(`./${packageConfig.main}`, - packageJSONUrl))) { - return guess; - } - for(const extension of legacyMainResolveAddsIfOmitted) { - if (fileExists(guess = new URL(`./${packageConfig.main}${extension}`, - packageJSONUrl))) { - return guess; - } - } - for(const extension of legacyMainResolveAddsIfOmitted) { - if (fileExists(guess = new URL(`./${packageConfig.main}/index${extension}`, - packageJSONUrl))) { - return guess; - } - } - // Fallthrough. - } - for(const extension of legacyMainResolveAddsIfOmitted) { - if (fileExists(guess = new URL(`./index${extension}`, packageJSONUrl))) { - return guess; - } - } - // Not found. - throw new ERR_MODULE_NOT_FOUND( - fileURLToPath(new URL('.', packageJSONUrl)), fileURLToPath(base)); -} - -/** attempts replacement extensions, then tries exact name, then attempts appending extensions */ -function resolveExtensionsWithTryExactName(search) { - const resolvedReplacementExtension = resolveReplacementExtensions(search); - if(resolvedReplacementExtension) return resolvedReplacementExtension; - if (fileExists(search)) return search; - return resolveExtensions(search); -} - -// This appends missing extensions -function resolveExtensions(search) { - for (let i = 0; i < esrnExtensions.length; i++) { - const extension = esrnExtensions[i]; - const guess = new URL(`${search.pathname}${extension}`, search); - if (fileExists(guess)) return guess; - } - return undefined; -} - -/** This replaces JS with TS extensions */ -function resolveReplacementExtensions(search) { - const lastDotIndex = search.pathname.lastIndexOf('.'); - if(lastDotIndex >= 0) { - const ext = search.pathname.slice(lastDotIndex); - if (ext === '.js' || ext === '.jsx' || ext === '.mjs' || ext === '.cjs') { - const pathnameWithoutExtension = search.pathname.slice(0, lastDotIndex); - const replacementExts = - ext === '.js' ? replacementsForJs - : ext === '.jsx' ? replacementsForJsx - : ext === '.mjs' ? replacementsForMjs - : replacementsForCjs; - const guess = new URL(search.toString()); - for (let i = 0; i < replacementExts.length; i++) { - const extension = replacementExts[i]; - guess.pathname = `${pathnameWithoutExtension}${extension}`; - if (fileExists(guess)) return guess; - } - } - } - return undefined; -} - -function resolveIndex(search) { - return resolveExtensions(new URL('index', search)); -} - -const encodedSepRegEx = /%2F|%2C/i; -function finalizeResolution(resolved, base) { - if (RegExpPrototypeTest(encodedSepRegEx, resolved.pathname)) - throw new ERR_INVALID_MODULE_SPECIFIER( - resolved.pathname, 'must not include encoded "/" or "\\" characters', - fileURLToPath(base)); - - if (experimentalSpecifierResolution === 'node') { - const path = fileURLToPath(resolved); - let file = resolveExtensionsWithTryExactName(resolved); - if (file !== undefined) return file; - if (!StringPrototypeEndsWith(path, '/')) { - file = resolveIndex(new URL(`${resolved}/`)); - if (file !== undefined) return file; - } else { - return resolveIndex(resolved) || resolved; - } - throw new ERR_MODULE_NOT_FOUND( - resolved.pathname, fileURLToPath(base), 'module'); - } - - const file = resolveReplacementExtensions(resolved) || resolved; - const path = fileURLToPath(file); - - const stats = tryStatSync(StringPrototypeEndsWith(path, '/') ? - StringPrototypeSlice(path, -1) : path); - if (stats.isDirectory()) { - const err = new ERR_UNSUPPORTED_DIR_IMPORT(path, fileURLToPath(base)); - err.url = String(resolved); - throw err; - } else if (!stats.isFile()) { - throw new ERR_MODULE_NOT_FOUND( - path || resolved.pathname, fileURLToPath(base), 'module'); - } - - return file; -} - -function throwImportNotDefined(specifier, packageJSONUrl, base) { - throw new ERR_PACKAGE_IMPORT_NOT_DEFINED( - specifier, packageJSONUrl && fileURLToPath(new URL('.', packageJSONUrl)), - fileURLToPath(base)); -} - -function throwExportsNotFound(subpath, packageJSONUrl, base) { - throw new ERR_PACKAGE_PATH_NOT_EXPORTED( - fileURLToPath(new URL('.', packageJSONUrl)), subpath, - base && fileURLToPath(base)); -} - -function throwInvalidSubpath(subpath, packageJSONUrl, internal, base) { - const reason = `request is not a valid subpath for the "${internal ? - 'imports' : 'exports'}" resolution of ${fileURLToPath(packageJSONUrl)}`; - throw new ERR_INVALID_MODULE_SPECIFIER(subpath, reason, - base && fileURLToPath(base)); -} - -function throwInvalidPackageTarget( - subpath, target, packageJSONUrl, internal, base) { - if (typeof target === 'object' && target !== null) { - target = JSONStringify(target, null, ''); - } else { - target = `${target}`; - } - throw new ERR_INVALID_PACKAGE_TARGET( - fileURLToPath(new URL('.', packageJSONUrl)), subpath, target, - internal, base && fileURLToPath(base)); -} - -const invalidSegmentRegEx = /(^|\\|\/)(\.\.?|node_modules)(\\|\/|$)/; -const patternRegEx = /\*/g; - -function resolvePackageTargetString( - target, subpath, match, packageJSONUrl, base, pattern, internal, conditions) { - if (subpath !== '' && !pattern && target[target.length - 1] !== '/') - throwInvalidPackageTarget(match, target, packageJSONUrl, internal, base); - - if (!StringPrototypeStartsWith(target, './')) { - if (internal && !StringPrototypeStartsWith(target, '../') && - !StringPrototypeStartsWith(target, '/')) { - let isURL = false; - try { - new URL(target); - isURL = true; - } catch {} - if (!isURL) { - const exportTarget = pattern ? - StringPrototypeReplace(target, patternRegEx, subpath) : - target + subpath; - return packageResolve(exportTarget, packageJSONUrl, conditions); - } - } - throwInvalidPackageTarget(match, target, packageJSONUrl, internal, base); - } - - if (RegExpPrototypeTest(invalidSegmentRegEx, StringPrototypeSlice(target, 2))) - throwInvalidPackageTarget(match, target, packageJSONUrl, internal, base); - - const resolved = new URL(target, packageJSONUrl); - const resolvedPath = resolved.pathname; - const packagePath = new URL('.', packageJSONUrl).pathname; - - if (!StringPrototypeStartsWith(resolvedPath, packagePath)) - throwInvalidPackageTarget(match, target, packageJSONUrl, internal, base); - - if (subpath === '') return resolved; - - if (RegExpPrototypeTest(invalidSegmentRegEx, subpath)) - throwInvalidSubpath(match + subpath, packageJSONUrl, internal, base); - - if (pattern) - return new URL(StringPrototypeReplace(resolved.href, patternRegEx, - subpath)); - return new URL(subpath, resolved); -} - -/** - * @param {string} key - * @returns {boolean} - */ -function isArrayIndex(key) { - const keyNum = +key; - if (`${keyNum}` !== key) return false; - return keyNum >= 0 && keyNum < 0xFFFF_FFFF; -} - -function resolvePackageTarget(packageJSONUrl, target, subpath, packageSubpath, - base, pattern, internal, conditions) { - if (typeof target === 'string') { - return resolvePackageTargetString( - target, subpath, packageSubpath, packageJSONUrl, base, pattern, internal, - conditions); - } else if (ArrayIsArray(target)) { - if (target.length === 0) - return null; - - let lastException; - for (let i = 0; i < target.length; i++) { - const targetItem = target[i]; - let resolved; - try { - resolved = resolvePackageTarget( - packageJSONUrl, targetItem, subpath, packageSubpath, base, pattern, - internal, conditions); - } catch (e) { - lastException = e; - if (e.code === 'ERR_INVALID_PACKAGE_TARGET') - continue; - throw e; - } - if (resolved === undefined) - continue; - if (resolved === null) { - lastException = null; - continue; - } - return resolved; - } - if (lastException === undefined || lastException === null) - return lastException; - throw lastException; - } else if (typeof target === 'object' && target !== null) { - const keys = ObjectGetOwnPropertyNames(target); - for (let i = 0; i < keys.length; i++) { - const key = keys[i]; - if (isArrayIndex(key)) { - throw new ERR_INVALID_PACKAGE_CONFIG( - fileURLToPath(packageJSONUrl), base, - '"exports" cannot contain numeric property keys.'); - } - } - for (let i = 0; i < keys.length; i++) { - const key = keys[i]; - if (key === 'default' || conditions.has(key)) { - const conditionalTarget = target[key]; - const resolved = resolvePackageTarget( - packageJSONUrl, conditionalTarget, subpath, packageSubpath, base, - pattern, internal, conditions); - if (resolved === undefined) - continue; - return resolved; - } - } - return undefined; - } else if (target === null) { - return null; - } - throwInvalidPackageTarget(packageSubpath, target, packageJSONUrl, internal, - base); -} - -function isConditionalExportsMainSugar(exports, packageJSONUrl, base) { - if (typeof exports === 'string' || ArrayIsArray(exports)) return true; - if (typeof exports !== 'object' || exports === null) return false; - - const keys = ObjectGetOwnPropertyNames(exports); - let isConditionalSugar = false; - let i = 0; - for (let j = 0; j < keys.length; j++) { - const key = keys[j]; - const curIsConditionalSugar = key === '' || key[0] !== '.'; - if (i++ === 0) { - isConditionalSugar = curIsConditionalSugar; - } else if (isConditionalSugar !== curIsConditionalSugar) { - throw new ERR_INVALID_PACKAGE_CONFIG( - fileURLToPath(packageJSONUrl), base, - '"exports" cannot contain some keys starting with \'.\' and some not.' + - ' The exports object must either be an object of package subpath keys' + - ' or an object of main entry condition name keys only.'); - } - } - return isConditionalSugar; -} - -/** - * @param {URL} packageJSONUrl - * @param {string} packageSubpath - * @param {object} packageConfig - * @param {string} base - * @param {Set} conditions - * @returns {{resolved: URL, exact: boolean}} - */ -function packageExportsResolve( - packageJSONUrl, packageSubpath, packageConfig, base, conditions) { - let exports = packageConfig.exports; - if (isConditionalExportsMainSugar(exports, packageJSONUrl, base)) - exports = { '.': exports }; - - if (ObjectPrototypeHasOwnProperty(exports, packageSubpath)) { - const target = exports[packageSubpath]; - const resolved = resolvePackageTarget( - packageJSONUrl, target, '', packageSubpath, base, false, false, conditions - ); - if (resolved === null || resolved === undefined) - throwExportsNotFound(packageSubpath, packageJSONUrl, base); - return { resolved, exact: true }; - } - - let bestMatch = ''; - const keys = ObjectGetOwnPropertyNames(exports); - for (let i = 0; i < keys.length; i++) { - const key = keys[i]; - if (key[key.length - 1] === '*' && - StringPrototypeStartsWith(packageSubpath, - StringPrototypeSlice(key, 0, -1)) && - packageSubpath.length >= key.length && - key.length > bestMatch.length) { - bestMatch = key; - } else if (key[key.length - 1] === '/' && - StringPrototypeStartsWith(packageSubpath, key) && - key.length > bestMatch.length) { - bestMatch = key; - } - } - - if (bestMatch) { - const target = exports[bestMatch]; - const pattern = bestMatch[bestMatch.length - 1] === '*'; - const subpath = StringPrototypeSubstr(packageSubpath, bestMatch.length - - (pattern ? 1 : 0)); - const resolved = resolvePackageTarget(packageJSONUrl, target, subpath, - bestMatch, base, pattern, false, - conditions); - if (resolved === null || resolved === undefined) - throwExportsNotFound(packageSubpath, packageJSONUrl, base); - if (!pattern) - emitFolderMapDeprecation(bestMatch, packageJSONUrl, true, base); - return { resolved, exact: pattern }; - } - - throwExportsNotFound(packageSubpath, packageJSONUrl, base); -} - -function packageImportsResolve(name, base, conditions) { - if (name === '#' || StringPrototypeStartsWith(name, '#/')) { - const reason = 'is not a valid internal imports specifier name'; - throw new ERR_INVALID_MODULE_SPECIFIER(name, reason, fileURLToPath(base)); - } - let packageJSONUrl; - const packageConfig = getPackageScopeConfig(base); - if (packageConfig.exists) { - packageJSONUrl = pathToFileURL(packageConfig.pjsonPath); - const imports = packageConfig.imports; - if (imports) { - if (ObjectPrototypeHasOwnProperty(imports, name)) { - const resolved = resolvePackageTarget( - packageJSONUrl, imports[name], '', name, base, false, true, conditions - ); - if (resolved !== null) - return { resolved, exact: true }; - } else { - let bestMatch = ''; - const keys = ObjectGetOwnPropertyNames(imports); - for (let i = 0; i < keys.length; i++) { - const key = keys[i]; - if (key[key.length - 1] === '*' && - StringPrototypeStartsWith(name, - StringPrototypeSlice(key, 0, -1)) && - name.length >= key.length && - key.length > bestMatch.length) { - bestMatch = key; - } else if (key[key.length - 1] === '/' && - StringPrototypeStartsWith(name, key) && - key.length > bestMatch.length) { - bestMatch = key; + Debug2.fail = fail; + function failBadSyntaxKind(node, message, stackCrawlMark) { + return fail( + `${message || "Unexpected node."}\r +Node ${formatSyntaxKind(node.kind)} was unexpected.`, + stackCrawlMark || failBadSyntaxKind + ); + } + Debug2.failBadSyntaxKind = failBadSyntaxKind; + function assert(expression, message, verboseDebugInfo, stackCrawlMark) { + if (!expression) { + message = message ? `False expression: ${message}` : "False expression."; + if (verboseDebugInfo) { + message += "\r\nVerbose Debug Information: " + (typeof verboseDebugInfo === "string" ? verboseDebugInfo : verboseDebugInfo()); + } + fail(message, stackCrawlMark || assert); } } - - if (bestMatch) { - const target = imports[bestMatch]; - const pattern = bestMatch[bestMatch.length - 1] === '*'; - const subpath = StringPrototypeSubstr(name, bestMatch.length - - (pattern ? 1 : 0)); - const resolved = resolvePackageTarget( - packageJSONUrl, target, subpath, bestMatch, base, pattern, true, - conditions); - if (resolved !== null) { - if (!pattern) - emitFolderMapDeprecation(bestMatch, packageJSONUrl, false, base); - return { resolved, exact: pattern }; + Debug2.assert = assert; + function assertEqual(a, b, msg, msg2, stackCrawlMark) { + if (a !== b) { + const message = msg ? msg2 ? `${msg} ${msg2}` : msg : ""; + fail(`Expected ${a} === ${b}. ${message}`, stackCrawlMark || assertEqual); } } - } - } - } - throwImportNotDefined(name, packageJSONUrl, base); -} - -function getPackageType(url) { - const packageConfig = getPackageScopeConfig(url); - return packageConfig.type; -} - -function parsePackageName(specifier, base) { - let separatorIndex = StringPrototypeIndexOf(specifier, '/'); - let validPackageName = true; - let isScoped = false; - if (specifier[0] === '@') { - isScoped = true; - if (separatorIndex === -1 || specifier.length === 0) { - validPackageName = false; - } else { - separatorIndex = StringPrototypeIndexOf( - specifier, '/', separatorIndex + 1); - } - } - - const packageName = separatorIndex === -1 ? - specifier : StringPrototypeSlice(specifier, 0, separatorIndex); - - // Package name cannot have leading . and cannot have percent-encoding or - // separators. - for (let i = 0; i < packageName.length; i++) { - if (packageName[i] === '%' || packageName[i] === '\\') { - validPackageName = false; - break; - } - } - - if (!validPackageName) { - throw new ERR_INVALID_MODULE_SPECIFIER( - specifier, 'is not a valid package name', fileURLToPath(base)); - } - - const packageSubpath = '.' + (separatorIndex === -1 ? '' : - StringPrototypeSlice(specifier, separatorIndex)); - - return { packageName, packageSubpath, isScoped }; -} - -/** - * @param {string} specifier - * @param {URL} base - * @param {Set} conditions - * @returns {URL} - */ -function packageResolve(specifier, base, conditions) { - const { packageName, packageSubpath, isScoped } = - parsePackageName(specifier, base); - - // ResolveSelf - const packageConfig = getPackageScopeConfig(base); - if (packageConfig.exists) { - const packageJSONUrl = pathToFileURL(packageConfig.pjsonPath); - if (packageConfig.name === packageName && - packageConfig.exports !== undefined && packageConfig.exports !== null) { - return packageExportsResolve( - packageJSONUrl, packageSubpath, packageConfig, base, conditions - ).resolved; - } - } - - let packageJSONUrl = - new URL('./node_modules/' + packageName + '/package.json', base); - let packageJSONPath = fileURLToPath(packageJSONUrl); - let lastPath; - do { - const stat = tryStatSync(StringPrototypeSlice(packageJSONPath, 0, - packageJSONPath.length - 13)); - if (!stat.isDirectory()) { - lastPath = packageJSONPath; - packageJSONUrl = new URL((isScoped ? - '../../../../node_modules/' : '../../../node_modules/') + - packageName + '/package.json', packageJSONUrl); - packageJSONPath = fileURLToPath(packageJSONUrl); - continue; - } - - // Package match. - const packageConfig = getPackageConfig(packageJSONPath, specifier, base); - if (packageConfig.exports !== undefined && packageConfig.exports !== null) - return packageExportsResolve( - packageJSONUrl, packageSubpath, packageConfig, base, conditions - ).resolved; - if (packageSubpath === '.') - return legacyMainResolve(packageJSONUrl, packageConfig, base); - return new URL(packageSubpath, packageJSONUrl); - // Cross-platform root check. - } while (packageJSONPath.length !== lastPath.length); - - // eslint can't handle the above code. - // eslint-disable-next-line no-unreachable - throw new ERR_MODULE_NOT_FOUND(packageName, fileURLToPath(base)); -} - -function isBareSpecifier(specifier) { - return specifier[0] && specifier[0] !== '/' && specifier[0] !== '.'; -} - -function isRelativeSpecifier(specifier) { - if (specifier[0] === '.') { - if (specifier.length === 1 || specifier[1] === '/') return true; - if (specifier[1] === '.') { - if (specifier.length === 2 || specifier[2] === '/') return true; - } - } - return false; -} - -function shouldBeTreatedAsRelativeOrAbsolutePath(specifier) { - if (specifier === '') return false; - if (specifier[0] === '/') return true; - return isRelativeSpecifier(specifier); -} - -/** - * @param {string} specifier - * @param {URL} base - * @param {Set} conditions - * @returns {URL} - */ -function moduleResolve(specifier, base, conditions) { - // Order swapped from spec for minor perf gain. - // Ok since relative URLs cannot parse as URLs. - let resolved; - if (shouldBeTreatedAsRelativeOrAbsolutePath(specifier)) { - resolved = new URL(specifier, base); - } else if (specifier[0] === '#') { - ({ resolved } = packageImportsResolve(specifier, base, conditions)); - } else { - try { - resolved = new URL(specifier); - } catch { - resolved = packageResolve(specifier, base, conditions); - } - } - return finalizeResolution(resolved, base); -} - -/** - * Try to resolve an import as a CommonJS module - * @param {string} specifier - * @param {string} parentURL - * @returns {boolean|string} - */ -function resolveAsCommonJS(specifier, parentURL) { - try { - const parent = fileURLToPath(parentURL); - const tmpModule = new CJSModule(parent, null); - tmpModule.paths = CJSModule._nodeModulePaths(parent); - - let found = CJSModule._resolveFilename(specifier, tmpModule, false); - - // If it is a relative specifier return the relative path - // to the parent - if (isRelativeSpecifier(specifier)) { - found = relative(parent, found); - // Add '.separator if the path does not start with '..separator' - // This should be a safe assumption because when loading - // esm modules there should be always a file specified so - // there should not be a specifier like '..' or '.' - if (!StringPrototypeStartsWith(found, `..${sep}`)) { - found = `.${sep}${found}`; - } - } else if (isBareSpecifier(specifier)) { - // If it is a bare specifier return the relative path within the - // module - const pkg = StringPrototypeSplit(specifier, '/')[0]; - const index = StringPrototypeIndexOf(found, pkg); - if (index !== -1) { - found = StringPrototypeSlice(found, index); - } - } - // Normalize the path separator to give a valid suggestion - // on Windows - if (process.platform === 'win32') { - found = StringPrototypeReplace(found, new RegExp(`\\${sep}`, 'g'), '/'); - } - return found; - } catch { - return false; - } -} - -function defaultResolve(specifier, context = {}, defaultResolveUnused) { - let { parentURL, conditions } = context; - if (parentURL && policy != null && policy.manifest) { - const redirects = policy.manifest.getDependencyMapper(parentURL); - if (redirects) { - const { resolve, reaction } = redirects; - const destination = resolve(specifier, new SafeSet(conditions)); - let missing = true; - if (destination === true) { - missing = false; - } else if (destination) { - const href = destination.href; - return { url: href }; - } - if (missing) { - reaction(new ERR_MANIFEST_DEPENDENCY_MISSING( - parentURL, - specifier, - ArrayPrototypeJoin([...conditions], ', ')) - ); - } - } - } - let parsed; - try { - parsed = new URL(specifier); - if (parsed.protocol === 'data:') { - return { - url: specifier - }; - } - } catch {} - if (parsed && parsed.protocol === builtinModuleProtocol) - return { url: specifier }; - if (parsed && parsed.protocol !== 'file:' && parsed.protocol !== 'data:') - throw new ERR_UNSUPPORTED_ESM_URL_SCHEME(parsed); - if (NativeModule.canBeRequiredByUsers(specifier)) { - return { - url: builtinModuleProtocol + specifier - }; - } - if (parentURL && StringPrototypeStartsWith(parentURL, 'data:')) { - // This is gonna blow up, we want the error - new URL(specifier, parentURL); - } - - const isMain = parentURL === undefined; - if (isMain) { - parentURL = pathToFileURL(`${process.cwd()}/`).href; - - // This is the initial entry point to the program, and --input-type has - // been passed as an option; but --input-type can only be used with - // --eval, --print or STDIN string input. It is not allowed with file - // input, to avoid user confusion over how expansive the effect of the - // flag should be (i.e. entry point only, package scope surrounding the - // entry point, etc.). - if (typeFlag) - throw new ERR_INPUT_TYPE_NOT_ALLOWED(); - } - - conditions = getConditionsSet(conditions); - let url; - try { - url = moduleResolve(specifier, parentURL, conditions); - } catch (error) { - // Try to give the user a hint of what would have been the - // resolved CommonJS module - if (error.code === 'ERR_MODULE_NOT_FOUND' || - error.code === 'ERR_UNSUPPORTED_DIR_IMPORT') { - if (StringPrototypeStartsWith(specifier, 'file://')) { - specifier = fileURLToPath(specifier); - } - const found = resolveAsCommonJS(specifier, parentURL); - if (found) { - // Modify the stack and message string to include the hint - const lines = StringPrototypeSplit(error.stack, '\n'); - const hint = `Did you mean to import ${found}?`; - error.stack = - ArrayPrototypeShift(lines) + '\n' + - hint + '\n' + - ArrayPrototypeJoin(lines, '\n'); - error.message += `\n${hint}`; - } - } - throw error; - } - - if (isMain ? !preserveSymlinksMain : !preserveSymlinks) { - const urlPath = fileURLToPath(url); - const real = realpathSync(urlPath, { - // [internalFS.realpathCacheKey]: realpathCache - }); - const old = url; - url = pathToFileURL( - real + (StringPrototypeEndsWith(urlPath, sep) ? '/' : '')); - url.search = old.search; - url.hash = old.hash; - } - - return { url: `${url}` }; -} - -return { - DEFAULT_CONDITIONS, - defaultResolve, - encodedSepRegEx, - getPackageType, - packageExportsResolve, - packageImportsResolve -}; -} -module.exports = { - createResolve -}; - - -/***/ }), - -/***/ 19867: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { - -"use strict"; -// copied from https://github.com/nodejs/node/blob/v15.3.0/lib/internal/modules/package_json_reader.js - - -const { SafeMap } = __nccwpck_require__(5335); -const { internalModuleReadJSON } = __nccwpck_require__(22785); -const { pathToFileURL } = __nccwpck_require__(57310); -const { toNamespacedPath } = __nccwpck_require__(71017); -// const { getOptionValue } = require('./node-options'); - -const cache = new SafeMap(); - -let manifest; - -/** - * @param {string} jsonPath - * @return {{string: string, containsKeys: boolean}} - */ -function read(jsonPath) { - if (cache.has(jsonPath)) { - return cache.get(jsonPath); - } - - const [string, containsKeys] = internalModuleReadJSON( - toNamespacedPath(jsonPath) - ); - const result = { string, containsKeys }; - if (string !== undefined) { - if (manifest === undefined) { - // manifest = getOptionValue('--experimental-policy') ? - // require('internal/process/policy').manifest : - // null; - // disabled for now. I am not sure if/how we should support this - manifest = null; - } - if (manifest !== null) { - const jsonURL = pathToFileURL(jsonPath); - manifest.assertIntegrity(jsonURL, string); - } - } - cache.set(jsonPath, result); - return result; -} - -module.exports = { read }; - - -/***/ }), - -/***/ 43803: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { - -"use strict"; -// copied from https://github.com/nodejs/node/blob/88799930794045795e8abac874730f9eba7e2300/lib/internal/repl/await.js - - -const { - ArrayFrom, - ArrayPrototypeForEach, - ArrayPrototypeIncludes, - ArrayPrototypeJoin, - ArrayPrototypePop, - ArrayPrototypePush, - FunctionPrototype, - ObjectKeys, - RegExpPrototypeSymbolReplace, - StringPrototypeEndsWith, - StringPrototypeIncludes, - StringPrototypeIndexOf, - StringPrototypeRepeat, - StringPrototypeSplit, - StringPrototypeStartsWith, - SyntaxError, -} = __nccwpck_require__(5335); - -const parser = (__nccwpck_require__(89761).Parser); -const walk = __nccwpck_require__(51697); -const { Recoverable } = __nccwpck_require__(38102); - -function isTopLevelDeclaration(state) { - return state.ancestors[state.ancestors.length - 2] === state.body; -} - -const noop = FunctionPrototype; -const visitorsWithoutAncestors = { - ClassDeclaration(node, state, c) { - if (isTopLevelDeclaration(state)) { - state.prepend(node, `${node.id.name}=`); - ArrayPrototypePush( - state.hoistedDeclarationStatements, - `let ${node.id.name}; ` - ); - } - - walk.base.ClassDeclaration(node, state, c); - }, - ForOfStatement(node, state, c) { - if (node.await === true) { - state.containsAwait = true; - } - walk.base.ForOfStatement(node, state, c); - }, - FunctionDeclaration(node, state, c) { - state.prepend(node, `${node.id.name}=`); - ArrayPrototypePush( - state.hoistedDeclarationStatements, - `var ${node.id.name}; ` - ); - }, - FunctionExpression: noop, - ArrowFunctionExpression: noop, - MethodDefinition: noop, - AwaitExpression(node, state, c) { - state.containsAwait = true; - walk.base.AwaitExpression(node, state, c); - }, - ReturnStatement(node, state, c) { - state.containsReturn = true; - walk.base.ReturnStatement(node, state, c); - }, - VariableDeclaration(node, state, c) { - const variableKind = node.kind; - const isIterableForDeclaration = ArrayPrototypeIncludes( - ['ForOfStatement', 'ForInStatement'], - state.ancestors[state.ancestors.length - 2].type - ); - - if (variableKind === 'var' || isTopLevelDeclaration(state)) { - state.replace( - node.start, - node.start + variableKind.length + (isIterableForDeclaration ? 1 : 0), - variableKind === 'var' && isIterableForDeclaration ? - '' : - 'void' + (node.declarations.length === 1 ? '' : ' (') - ); - - if (!isIterableForDeclaration) { - ArrayPrototypeForEach(node.declarations, (decl) => { - state.prepend(decl, '('); - state.append(decl, decl.init ? ')' : '=undefined)'); - }); - - if (node.declarations.length !== 1) { - state.append(node.declarations[node.declarations.length - 1], ')'); + Debug2.assertEqual = assertEqual; + function assertLessThan(a, b, msg, stackCrawlMark) { + if (a >= b) { + fail(`Expected ${a} < ${b}. ${msg || ""}`, stackCrawlMark || assertLessThan); + } } - } - - const variableIdentifiersToHoist = [ - ['var', []], - ['let', []], - ]; - function registerVariableDeclarationIdentifiers(node) { - switch (node.type) { - case 'Identifier': - ArrayPrototypePush( - variableIdentifiersToHoist[variableKind === 'var' ? 0 : 1][1], - node.name + Debug2.assertLessThan = assertLessThan; + function assertLessThanOrEqual(a, b, stackCrawlMark) { + if (a > b) { + fail(`Expected ${a} <= ${b}`, stackCrawlMark || assertLessThanOrEqual); + } + } + Debug2.assertLessThanOrEqual = assertLessThanOrEqual; + function assertGreaterThanOrEqual(a, b, stackCrawlMark) { + if (a < b) { + fail(`Expected ${a} >= ${b}`, stackCrawlMark || assertGreaterThanOrEqual); + } + } + Debug2.assertGreaterThanOrEqual = assertGreaterThanOrEqual; + function assertIsDefined(value, message, stackCrawlMark) { + if (value === void 0 || value === null) { + fail(message, stackCrawlMark || assertIsDefined); + } + } + Debug2.assertIsDefined = assertIsDefined; + function checkDefined(value, message, stackCrawlMark) { + assertIsDefined(value, message, stackCrawlMark || checkDefined); + return value; + } + Debug2.checkDefined = checkDefined; + function assertEachIsDefined(value, message, stackCrawlMark) { + for (const v of value) { + assertIsDefined(v, message, stackCrawlMark || assertEachIsDefined); + } + } + Debug2.assertEachIsDefined = assertEachIsDefined; + function checkEachDefined(value, message, stackCrawlMark) { + assertEachIsDefined(value, message, stackCrawlMark || checkEachDefined); + return value; + } + Debug2.checkEachDefined = checkEachDefined; + function assertNever(member, message = "Illegal value:", stackCrawlMark) { + const detail = typeof member === "object" && hasProperty(member, "kind") && hasProperty(member, "pos") ? "SyntaxKind: " + formatSyntaxKind(member.kind) : JSON.stringify(member); + return fail(`${message} ${detail}`, stackCrawlMark || assertNever); + } + Debug2.assertNever = assertNever; + function assertEachNode(nodes, test, message, stackCrawlMark) { + if (shouldAssertFunction(1 /* Normal */, "assertEachNode")) { + assert( + test === void 0 || every(nodes, test), + message || "Unexpected node.", + () => `Node array did not pass test '${getFunctionName(test)}'.`, + stackCrawlMark || assertEachNode ); - break; - case 'ObjectPattern': - ArrayPrototypeForEach(node.properties, (property) => { - registerVariableDeclarationIdentifiers(property.value); - }); - break; - case 'ArrayPattern': - ArrayPrototypeForEach(node.elements, (element) => { - registerVariableDeclarationIdentifiers(element); - }); - break; + } } - } - - ArrayPrototypeForEach(node.declarations, (decl) => { - registerVariableDeclarationIdentifiers(decl.id); - }); - - ArrayPrototypeForEach( - variableIdentifiersToHoist, - ({ 0: kind, 1: identifiers }) => { - if (identifiers.length > 0) { - ArrayPrototypePush( - state.hoistedDeclarationStatements, - `${kind} ${ArrayPrototypeJoin(identifiers, ', ')}; ` + Debug2.assertEachNode = assertEachNode; + function assertNode(node, test, message, stackCrawlMark) { + if (shouldAssertFunction(1 /* Normal */, "assertNode")) { + assert( + node !== void 0 && (test === void 0 || test(node)), + message || "Unexpected node.", + () => `Node ${formatSyntaxKind(node == null ? void 0 : node.kind)} did not pass test '${getFunctionName(test)}'.`, + stackCrawlMark || assertNode ); } } - ); - } - - walk.base.VariableDeclaration(node, state, c); - } -}; - -const visitors = {}; -for (const nodeType of ObjectKeys(walk.base)) { - const callback = visitorsWithoutAncestors[nodeType] || walk.base[nodeType]; - visitors[nodeType] = (node, state, c) => { - const isNew = node !== state.ancestors[state.ancestors.length - 1]; - if (isNew) { - ArrayPrototypePush(state.ancestors, node); - } - callback(node, state, c); - if (isNew) { - ArrayPrototypePop(state.ancestors); - } - }; -} - -function processTopLevelAwait(src) { - const wrapPrefix = '(async () => { '; - const wrapped = `${wrapPrefix}${src} })()`; - const wrappedArray = ArrayFrom(wrapped); - let root; - try { - root = parser.parse(wrapped, { ecmaVersion: 'latest' }); - } catch (e) { - if (StringPrototypeStartsWith(e.message, 'Unterminated ')) - throw new Recoverable(e); - // If the parse error is before the first "await", then use the execution - // error. Otherwise we must emit this parse error, making it look like a - // proper syntax error. - const awaitPos = StringPrototypeIndexOf(src, 'await'); - const errPos = e.pos - wrapPrefix.length; - if (awaitPos > errPos) - return null; - // Convert keyword parse errors on await into their original errors when - // possible. - if (errPos === awaitPos + 6 && - StringPrototypeIncludes(e.message, 'Expecting Unicode escape sequence')) - return null; - if (errPos === awaitPos + 7 && - StringPrototypeIncludes(e.message, 'Unexpected token')) - return null; - const line = e.loc.line; - const column = line === 1 ? e.loc.column - wrapPrefix.length : e.loc.column; - let message = '\n' + StringPrototypeSplit(src, '\n')[line - 1] + '\n' + - StringPrototypeRepeat(' ', column) + - '^\n\n' + RegExpPrototypeSymbolReplace(/ \([^)]+\)/, e.message, ''); - // V8 unexpected token errors include the token string. - if (StringPrototypeEndsWith(message, 'Unexpected token')) - message += " '" + - // Wrapper end may cause acorn to report error position after the source - ((src.length - 1) >= (e.pos - wrapPrefix.length) - ? src[e.pos - wrapPrefix.length] - : src[src.length - 1]) + - "'"; - // eslint-disable-next-line no-restricted-syntax - throw new SyntaxError(message); - } - const body = root.body[0].expression.callee.body; - const state = { - body, - ancestors: [], - hoistedDeclarationStatements: [], - replace(from, to, str) { - for (let i = from; i < to; i++) { - wrappedArray[i] = ''; - } - if (from === to) str += wrappedArray[from]; - wrappedArray[from] = str; - }, - prepend(node, str) { - wrappedArray[node.start] = str + wrappedArray[node.start]; - }, - append(node, str) { - wrappedArray[node.end - 1] += str; - }, - containsAwait: false, - containsReturn: false - }; - - walk.recursive(body, state, visitors); - - // Do not transform if - // 1. False alarm: there isn't actually an await expression. - // 2. There is a top-level return, which is not allowed. - if (!state.containsAwait || state.containsReturn) { - return null; - } - - const last = body.body[body.body.length - 1]; - if (last.type === 'ExpressionStatement') { - // For an expression statement of the form - // ( expr ) ; - // ^^^^^^^^^^ // last - // ^^^^ // last.expression - // - // We do not want the left parenthesis before the `return` keyword; - // therefore we prepend the `return (` to `last`. - // - // On the other hand, we do not want the right parenthesis after the - // semicolon. Since there can only be more right parentheses between - // last.expression.end and the semicolon, appending one more to - // last.expression should be fine. - state.prepend(last, 'return ('); - state.append(last.expression, ')'); - } - - return ( - ArrayPrototypeJoin(state.hoistedDeclarationStatements, '') + - ArrayPrototypeJoin(wrappedArray, '') - ); -} - -module.exports = { - processTopLevelAwait -}; - - -/***/ }), - -/***/ 22785: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { - -const fs = __nccwpck_require__(57147); -const {versionGteLt} = __nccwpck_require__(81842); - -// In node's core, this is implemented in C -// https://github.com/nodejs/node/blob/v15.3.0/src/node_file.cc#L891-L985 -/** - * @param {string} path - * @returns {[] | [string, boolean]} - */ -function internalModuleReadJSON(path) { - let string - try { - string = fs.readFileSync(path, 'utf8') - } catch (e) { - if (e.code === 'ENOENT') return [] - throw e - } - // Node's implementation checks for the presence of relevant keys: main, name, type, exports, imports - // Node does this for performance to skip unnecessary parsing. - // This would slow us down and, based on our usage, we can skip it. - const containsKeys = true - return [string, containsKeys] -} - -// In node's core, this is implemented in C -// https://github.com/nodejs/node/blob/63e7dc1e5c71b70c80ed9eda230991edb00811e2/src/node_file.cc#L987-L1005 -/** - * @param {string} path - * @returns {number} 0 = file, 1 = dir, negative = error - */ -function internalModuleStat(path) { - const stat = fs.statSync(path, { throwIfNoEntry: false }); - if(!stat) return -1; - if(stat.isFile()) return 0; - if(stat.isDirectory()) return 1; -} - -/** - * @param {string} path - * @returns {number} 0 = file, 1 = dir, negative = error - */ -function internalModuleStatInefficient(path) { - try { - const stat = fs.statSync(path); - if(stat.isFile()) return 0; - if(stat.isDirectory()) return 1; - } catch(e) { - return -e.errno || -1; - } -} - -const statSupportsThrowIfNoEntry = versionGteLt(process.versions.node, '15.3.0') || - versionGteLt(process.versions.node, '14.17.0', '15.0.0'); - -module.exports = { - internalModuleReadJSON, - internalModuleStat: statSupportsThrowIfNoEntry ? internalModuleStat : internalModuleStatInefficient -}; - - -/***/ }), - -/***/ 10765: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { - - -// Node imports this from 'internal/bootstrap/loaders' -const Module = __nccwpck_require__(98188); -const NativeModule = { - canBeRequiredByUsers(specifier) { - return Module.builtinModules.includes(specifier) - } -}; -exports.NativeModule = NativeModule; - - -/***/ }), - -/***/ 45519: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { - -// Replacement for node's internal 'internal/options' module - -exports.getOptionValue = getOptionValue; -function getOptionValue(opt) { - parseOptions(); - return options[opt]; -} - -let options; -function parseOptions() { - if (!options) { - options = { - '--preserve-symlinks': false, - '--preserve-symlinks-main': false, - '--input-type': undefined, - '--experimental-specifier-resolution': 'explicit', - '--experimental-policy': undefined, - '--conditions': [], - '--pending-deprecation': false, - ...parseArgv(getNodeOptionsEnvArgv()), - ...parseArgv(process.execArgv), - ...getOptionValuesFromOtherEnvVars() - } - } -} - -function parseArgv(argv) { - return __nccwpck_require__(13474)({ - '--preserve-symlinks': Boolean, - '--preserve-symlinks-main': Boolean, - '--input-type': String, - '--experimental-specifier-resolution': String, - // Legacy alias for node versions prior to 12.16 - '--es-module-specifier-resolution': '--experimental-specifier-resolution', - '--experimental-policy': String, - '--conditions': [String], - '--pending-deprecation': Boolean, - '--experimental-json-modules': Boolean, - '--experimental-wasm-modules': Boolean, - }, { - argv, - permissive: true - }); -} - -function getNodeOptionsEnvArgv() { - const errors = []; - const envArgv = ParseNodeOptionsEnvVar(process.env.NODE_OPTIONS || '', errors); - if (errors.length !== 0) { - // TODO: handle errors somehow - } - return envArgv; -} - -// Direct JS port of C implementation: https://github.com/nodejs/node/blob/67ba825037b4082d5d16f922fb9ce54516b4a869/src/node_options.cc#L1024-L1063 -function ParseNodeOptionsEnvVar(node_options, errors) { - const env_argv = []; - - let is_in_string = false; - let will_start_new_arg = true; - for (let index = 0; index < node_options.length; ++index) { - let c = node_options[index]; - - // Backslashes escape the following character - if (c === '\\' && is_in_string) { - if (index + 1 === node_options.length) { - errors.push("invalid value for NODE_OPTIONS " + - "(invalid escape)\n"); - return env_argv; + Debug2.assertNode = assertNode; + function assertNotNode(node, test, message, stackCrawlMark) { + if (shouldAssertFunction(1 /* Normal */, "assertNotNode")) { + assert( + node === void 0 || test === void 0 || !test(node), + message || "Unexpected node.", + () => `Node ${formatSyntaxKind(node.kind)} should not have passed test '${getFunctionName(test)}'.`, + stackCrawlMark || assertNotNode + ); + } + } + Debug2.assertNotNode = assertNotNode; + function assertOptionalNode(node, test, message, stackCrawlMark) { + if (shouldAssertFunction(1 /* Normal */, "assertOptionalNode")) { + assert( + test === void 0 || node === void 0 || test(node), + message || "Unexpected node.", + () => `Node ${formatSyntaxKind(node == null ? void 0 : node.kind)} did not pass test '${getFunctionName(test)}'.`, + stackCrawlMark || assertOptionalNode + ); + } + } + Debug2.assertOptionalNode = assertOptionalNode; + function assertOptionalToken(node, kind, message, stackCrawlMark) { + if (shouldAssertFunction(1 /* Normal */, "assertOptionalToken")) { + assert( + kind === void 0 || node === void 0 || node.kind === kind, + message || "Unexpected node.", + () => `Node ${formatSyntaxKind(node == null ? void 0 : node.kind)} was not a '${formatSyntaxKind(kind)}' token.`, + stackCrawlMark || assertOptionalToken + ); + } + } + Debug2.assertOptionalToken = assertOptionalToken; + function assertMissingNode(node, message, stackCrawlMark) { + if (shouldAssertFunction(1 /* Normal */, "assertMissingNode")) { + assert( + node === void 0, + message || "Unexpected node.", + () => `Node ${formatSyntaxKind(node.kind)} was unexpected'.`, + stackCrawlMark || assertMissingNode + ); + } + } + Debug2.assertMissingNode = assertMissingNode; + function type(_value) { + } + Debug2.type = type; + function getFunctionName(func) { + if (typeof func !== "function") { + return ""; + } else if (hasProperty(func, "name")) { + return func.name; } else { - c = node_options[++index]; + const text = Function.prototype.toString.call(func); + const match = /^function\s+([\w$]+)\s*\(/.exec(text); + return match ? match[1] : ""; } - } else if (c === ' ' && !is_in_string) { - will_start_new_arg = true; - continue; - } else if (c === '"') { - is_in_string = !is_in_string; - continue; - } - - if (will_start_new_arg) { - env_argv.push(c); - will_start_new_arg = false; - } else { - env_argv[env_argv.length - 1] += c; - } - } - - if (is_in_string) { - errors.push("invalid value for NODE_OPTIONS " + - "(unterminated string)\n"); - } - return env_argv; -} - -// Get option values that can be specified via env vars besides NODE_OPTIONS -function getOptionValuesFromOtherEnvVars() { - const options = {}; - if(process.env.NODE_PENDING_DEPRECATION === '1') { - options['--pending-deprecation'] = true; - } - return options; -} - - -/***/ }), - -/***/ 5335: -/***/ ((module) => { - -module.exports = { - ArrayFrom: Array.from, - ArrayIsArray: Array.isArray, - ArrayPrototypeShift: (obj) => Array.prototype.shift.call(obj), - ArrayPrototypeForEach: (arr, ...rest) => Array.prototype.forEach.apply(arr, rest), - ArrayPrototypeIncludes: (arr, ...rest) => Array.prototype.includes.apply(arr, rest), - ArrayPrototypeJoin: (arr, ...rest) => Array.prototype.join.apply(arr, rest), - ArrayPrototypePop: (arr, ...rest) => Array.prototype.pop.apply(arr, rest), - ArrayPrototypePush: (arr, ...rest) => Array.prototype.push.apply(arr, rest), - FunctionPrototype: Function.prototype, - JSONParse: JSON.parse, - JSONStringify: JSON.stringify, - ObjectFreeze: Object.freeze, - ObjectKeys: Object.keys, - ObjectGetOwnPropertyNames: Object.getOwnPropertyNames, - ObjectDefineProperty: Object.defineProperty, - ObjectPrototypeHasOwnProperty: (obj, prop) => Object.prototype.hasOwnProperty.call(obj, prop), - RegExpPrototypeExec: (obj, string) => RegExp.prototype.exec.call(obj, string), - RegExpPrototypeTest: (obj, string) => RegExp.prototype.test.call(obj, string), - RegExpPrototypeSymbolReplace: (obj, ...rest) => RegExp.prototype[Symbol.replace].apply(obj, rest), - SafeMap: Map, - SafeSet: Set, - SafeWeakMap: WeakMap, - StringPrototypeEndsWith: (str, ...rest) => String.prototype.endsWith.apply(str, rest), - StringPrototypeIncludes: (str, ...rest) => String.prototype.includes.apply(str, rest), - StringPrototypeLastIndexOf: (str, ...rest) => String.prototype.lastIndexOf.apply(str, rest), - StringPrototypeIndexOf: (str, ...rest) => String.prototype.indexOf.apply(str, rest), - StringPrototypeRepeat: (str, ...rest) => String.prototype.repeat.apply(str, rest), - StringPrototypeReplace: (str, ...rest) => String.prototype.replace.apply(str, rest), - StringPrototypeSlice: (str, ...rest) => String.prototype.slice.apply(str, rest), - StringPrototypeSplit: (str, ...rest) => String.prototype.split.apply(str, rest), - StringPrototypeStartsWith: (str, ...rest) => String.prototype.startsWith.apply(str, rest), - StringPrototypeSubstr: (str, ...rest) => String.prototype.substr.apply(str, rest), - StringPrototypeCharCodeAt: (str, ...rest) => String.prototype.charCodeAt.apply(str, rest), - StringPrototypeMatch: (str, ...rest) => String.prototype.match.apply(str, rest), - SyntaxError: SyntaxError -}; - - -/***/ }), - -/***/ 26972: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { - -"use strict"; - -Object.defineProperty(exports, "__esModule", ({ value: true })); -exports.installCommonjsResolveHooksIfNecessary = void 0; -/** - * @internal - */ -function installCommonjsResolveHooksIfNecessary(tsNodeService) { - const Module = __nccwpck_require__(98188); - const originalResolveFilename = Module._resolveFilename; - const originalFindPath = Module._findPath; - const shouldInstallHook = tsNodeService.options.experimentalResolver; - if (shouldInstallHook) { - const { Module_findPath, Module_resolveFilename } = tsNodeService.getNodeCjsLoader(); - Module._resolveFilename = _resolveFilename; - Module._findPath = _findPath; - function _resolveFilename(request, parent, isMain, options, ...rest) { - if (!tsNodeService.enabled()) - return originalResolveFilename.call(this, request, parent, isMain, options, ...rest); - return Module_resolveFilename.call(this, request, parent, isMain, options, ...rest); - } - function _findPath() { - if (!tsNodeService.enabled()) - return originalFindPath.apply(this, arguments); - return Module_findPath.apply(this, arguments); } - } -} -exports.installCommonjsResolveHooksIfNecessary = installCommonjsResolveHooksIfNecessary; -//# sourceMappingURL=cjs-resolve-hooks.js.map - -/***/ }), - -/***/ 76692: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { - -"use strict"; - -Object.defineProperty(exports, "__esModule", ({ value: true })); -exports.getTsConfigDefaults = exports.ComputeAsCommonRootOfFiles = exports.loadCompiler = exports.resolveAndLoadCompiler = exports.readConfig = exports.findAndReadConfig = void 0; -const path_1 = __nccwpck_require__(71017); -const index_1 = __nccwpck_require__(51351); -const ts_internals_1 = __nccwpck_require__(37432); -const tsconfigs_1 = __nccwpck_require__(7518); -const util_1 = __nccwpck_require__(81842); -/** - * TypeScript compiler option values required by `ts-node` which cannot be overridden. - */ -const TS_NODE_COMPILER_OPTIONS = { - sourceMap: true, - inlineSourceMap: false, - inlineSources: true, - declaration: false, - noEmit: false, - outDir: '.ts-node', -}; -/* - * Do post-processing on config options to support `ts-node`. - */ -function fixConfig(ts, config) { - // Delete options that *should not* be passed through. - delete config.options.out; - delete config.options.outFile; - delete config.options.composite; - delete config.options.declarationDir; - delete config.options.declarationMap; - delete config.options.emitDeclarationOnly; - // Target ES5 output by default (instead of ES3). - if (config.options.target === undefined) { - config.options.target = ts.ScriptTarget.ES5; - } - // Target CommonJS modules by default (instead of magically switching to ES6 when the target is ES6). - if (config.options.module === undefined) { - config.options.module = ts.ModuleKind.CommonJS; - } - return config; -} -/** @internal */ -function findAndReadConfig(rawOptions) { - var _a, _b, _c, _d, _e; - const cwd = (0, path_1.resolve)((_c = (_b = (_a = rawOptions.cwd) !== null && _a !== void 0 ? _a : rawOptions.dir) !== null && _b !== void 0 ? _b : index_1.DEFAULTS.cwd) !== null && _c !== void 0 ? _c : process.cwd()); - const compilerName = (_d = rawOptions.compiler) !== null && _d !== void 0 ? _d : index_1.DEFAULTS.compiler; - // Compute minimum options to read the config file. - let projectLocalResolveDir = (0, util_1.getBasePathForProjectLocalDependencyResolution)(undefined, rawOptions.projectSearchDir, rawOptions.project, cwd); - let { compiler, ts } = resolveAndLoadCompiler(compilerName, projectLocalResolveDir); - // Read config file and merge new options between env and CLI options. - const { configFilePath, config, tsNodeOptionsFromTsconfig, optionBasePaths } = readConfig(cwd, ts, rawOptions); - const options = (0, util_1.assign)({}, index_1.DEFAULTS, tsNodeOptionsFromTsconfig || {}, { optionBasePaths }, rawOptions); - options.require = [ - ...(tsNodeOptionsFromTsconfig.require || []), - ...(rawOptions.require || []), - ]; - // Re-resolve the compiler in case it has changed. - // Compiler is loaded relative to tsconfig.json, so tsconfig discovery may cause us to load a - // different compiler than we did above, even if the name has not changed. - if (configFilePath) { - projectLocalResolveDir = (0, util_1.getBasePathForProjectLocalDependencyResolution)(configFilePath, rawOptions.projectSearchDir, rawOptions.project, cwd); - ({ compiler } = resolveCompiler(options.compiler, (_e = optionBasePaths.compiler) !== null && _e !== void 0 ? _e : projectLocalResolveDir)); - } - return { - options, - config, - projectLocalResolveDir, - optionBasePaths, - configFilePath, - cwd, - compiler, - }; -} -exports.findAndReadConfig = findAndReadConfig; -/** - * Load TypeScript configuration. Returns the parsed TypeScript config and - * any `ts-node` options specified in the config file. - * - * Even when a tsconfig.json is not loaded, this function still handles merging - * compilerOptions from various sources: API, environment variables, etc. - * - * @internal - */ -function readConfig(cwd, ts, rawApiOptions) { - var _a, _b, _c; - // Ordered [a, b, c] where config a extends b extends c - const configChain = []; - let config = { compilerOptions: {} }; - let basePath = cwd; - let configFilePath = undefined; - const projectSearchDir = (0, path_1.resolve)(cwd, (_a = rawApiOptions.projectSearchDir) !== null && _a !== void 0 ? _a : cwd); - const { fileExists = ts.sys.fileExists, readFile = ts.sys.readFile, skipProject = index_1.DEFAULTS.skipProject, project = index_1.DEFAULTS.project, tsTrace = index_1.DEFAULTS.tsTrace, } = rawApiOptions; - // Read project configuration when available. - if (!skipProject) { - if (project) { - const resolved = (0, path_1.resolve)(cwd, project); - const nested = (0, path_1.join)(resolved, 'tsconfig.json'); - configFilePath = fileExists(nested) ? nested : resolved; + Debug2.getFunctionName = getFunctionName; + function formatSymbol(symbol) { + return `{ name: ${unescapeLeadingUnderscores(symbol.escapedName)}; flags: ${formatSymbolFlags(symbol.flags)}; declarations: ${map(symbol.declarations, (node) => formatSyntaxKind(node.kind))} }`; } - else { - configFilePath = ts.findConfigFile(projectSearchDir, fileExists); + Debug2.formatSymbol = formatSymbol; + function formatEnum(value = 0, enumObject, isFlags) { + const members = getEnumMembers(enumObject); + if (value === 0) { + return members.length > 0 && members[0][0] === 0 ? members[0][1] : "0"; + } + if (isFlags) { + const result = []; + let remainingFlags = value; + for (const [enumValue, enumName] of members) { + if (enumValue > value) { + break; + } + if (enumValue !== 0 && enumValue & value) { + result.push(enumName); + remainingFlags &= ~enumValue; + } + } + if (remainingFlags === 0) { + return result.join("|"); + } + } else { + for (const [enumValue, enumName] of members) { + if (enumValue === value) { + return enumName; + } + } + } + return value.toString(); } - if (configFilePath) { - let pathToNextConfigInChain = configFilePath; - const tsInternals = (0, ts_internals_1.createTsInternals)(ts); - const errors = []; - // Follow chain of "extends" - while (true) { - const result = ts.readConfigFile(pathToNextConfigInChain, readFile); - // Return diagnostics. - if (result.error) { - return { - configFilePath, - config: { errors: [result.error], fileNames: [], options: {} }, - tsNodeOptionsFromTsconfig: {}, - optionBasePaths: {}, - }; - } - const c = result.config; - const bp = (0, path_1.dirname)(pathToNextConfigInChain); - configChain.push({ - config: c, - basePath: bp, - configPath: pathToNextConfigInChain, - }); - if (c.extends == null) - break; - const resolvedExtendedConfigPath = tsInternals.getExtendsConfigPath(c.extends, { - fileExists, - readDirectory: ts.sys.readDirectory, - readFile, - useCaseSensitiveFileNames: ts.sys.useCaseSensitiveFileNames, - trace: tsTrace, - }, bp, errors, ts.createCompilerDiagnostic); - if (errors.length) { - return { - configFilePath, - config: { errors, fileNames: [], options: {} }, - tsNodeOptionsFromTsconfig: {}, - optionBasePaths: {}, - }; - } - if (resolvedExtendedConfigPath == null) - break; - pathToNextConfigInChain = resolvedExtendedConfigPath; + Debug2.formatEnum = formatEnum; + const enumMemberCache = /* @__PURE__ */ new Map(); + function getEnumMembers(enumObject) { + const existing = enumMemberCache.get(enumObject); + if (existing) { + return existing; + } + const result = []; + for (const name in enumObject) { + const value = enumObject[name]; + if (typeof value === "number") { + result.push([value, name]); } - ({ config, basePath } = configChain[0]); + } + const sorted = stableSort(result, (x, y) => compareValues(x[0], y[0])); + enumMemberCache.set(enumObject, sorted); + return sorted; } - } - // Merge and fix ts-node options that come from tsconfig.json(s) - const tsNodeOptionsFromTsconfig = {}; - const optionBasePaths = {}; - for (let i = configChain.length - 1; i >= 0; i--) { - const { config, basePath, configPath } = configChain[i]; - const options = filterRecognizedTsConfigTsNodeOptions(config['ts-node']).recognized; - // Some options are relative to the config file, so must be converted to absolute paths here - if (options.require) { - // Modules are found relative to the tsconfig file, not the `dir` option - const tsconfigRelativeResolver = (0, util_1.createProjectLocalResolveHelper)((0, path_1.dirname)(configPath)); - options.require = options.require.map((path) => tsconfigRelativeResolver(path, false)); + function formatSyntaxKind(kind) { + return formatEnum( + kind, + SyntaxKind, + /*isFlags*/ + false + ); } - if (options.scopeDir) { - options.scopeDir = (0, path_1.resolve)(basePath, options.scopeDir); + Debug2.formatSyntaxKind = formatSyntaxKind; + function formatSnippetKind(kind) { + return formatEnum( + kind, + SnippetKind, + /*isFlags*/ + false + ); } - // Downstream code uses the basePath; we do not do that here. - if (options.moduleTypes) { - optionBasePaths.moduleTypes = basePath; + Debug2.formatSnippetKind = formatSnippetKind; + function formatScriptKind(kind) { + return formatEnum( + kind, + ScriptKind, + /*isFlags*/ + false + ); } - if (options.transpiler != null) { - optionBasePaths.transpiler = basePath; + Debug2.formatScriptKind = formatScriptKind; + function formatNodeFlags(flags) { + return formatEnum( + flags, + NodeFlags, + /*isFlags*/ + true + ); } - if (options.compiler != null) { - optionBasePaths.compiler = basePath; + Debug2.formatNodeFlags = formatNodeFlags; + function formatModifierFlags(flags) { + return formatEnum( + flags, + ModifierFlags, + /*isFlags*/ + true + ); } - if (options.swc != null) { - optionBasePaths.swc = basePath; + Debug2.formatModifierFlags = formatModifierFlags; + function formatTransformFlags(flags) { + return formatEnum( + flags, + TransformFlags, + /*isFlags*/ + true + ); } - (0, util_1.assign)(tsNodeOptionsFromTsconfig, options); - } - // Remove resolution of "files". - const files = (_c = (_b = rawApiOptions.files) !== null && _b !== void 0 ? _b : tsNodeOptionsFromTsconfig.files) !== null && _c !== void 0 ? _c : index_1.DEFAULTS.files; - // Only if a config file is *not* loaded, load an implicit configuration from @tsconfig/bases - const skipDefaultCompilerOptions = configFilePath != null; - const defaultCompilerOptionsForNodeVersion = skipDefaultCompilerOptions - ? undefined - : { - ...(0, tsconfigs_1.getDefaultTsconfigJsonForNodeVersion)(ts).compilerOptions, - types: ['node'], - }; - // Merge compilerOptions from all sources - config.compilerOptions = Object.assign({}, - // automatically-applied options from @tsconfig/bases - defaultCompilerOptionsForNodeVersion, - // tsconfig.json "compilerOptions" - config.compilerOptions, - // from env var - index_1.DEFAULTS.compilerOptions, - // tsconfig.json "ts-node": "compilerOptions" - tsNodeOptionsFromTsconfig.compilerOptions, - // passed programmatically - rawApiOptions.compilerOptions, - // overrides required by ts-node, cannot be changed - TS_NODE_COMPILER_OPTIONS); - const fixedConfig = fixConfig(ts, ts.parseJsonConfigFileContent(config, { - fileExists, - readFile, - // Only used for globbing "files", "include", "exclude" - // When `files` option disabled, we want to avoid the fs calls - readDirectory: files ? ts.sys.readDirectory : () => [], - useCaseSensitiveFileNames: ts.sys.useCaseSensitiveFileNames, - }, basePath, undefined, configFilePath)); - return { - configFilePath, - config: fixedConfig, - tsNodeOptionsFromTsconfig, - optionBasePaths, - }; -} -exports.readConfig = readConfig; -/** - * Load the typescript compiler. It is required to load the tsconfig but might - * be changed by the tsconfig, so we have to do this twice. - * @internal - */ -function resolveAndLoadCompiler(name, relativeToPath) { - const { compiler } = resolveCompiler(name, relativeToPath); - const ts = loadCompiler(compiler); - return { compiler, ts }; -} -exports.resolveAndLoadCompiler = resolveAndLoadCompiler; -function resolveCompiler(name, relativeToPath) { - const projectLocalResolveHelper = (0, util_1.createProjectLocalResolveHelper)(relativeToPath); - const compiler = projectLocalResolveHelper(name || 'typescript', true); - return { compiler }; -} -/** @internal */ -function loadCompiler(compiler) { - return (0, util_1.attemptRequireWithV8CompileCache)(require, compiler); -} -exports.loadCompiler = loadCompiler; -/** - * Given the raw "ts-node" sub-object from a tsconfig, return an object with only the properties - * recognized by "ts-node" - */ -function filterRecognizedTsConfigTsNodeOptions(jsonObject) { - if (jsonObject == null) - return { recognized: {}, unrecognized: {} }; - const { compiler, compilerHost, compilerOptions, emit, files, ignore, ignoreDiagnostics, logError, preferTsExts, pretty, require, skipIgnore, transpileOnly, typeCheck, transpiler, scope, scopeDir, moduleTypes, experimentalReplAwait, swc, experimentalResolver, esm, experimentalSpecifierResolution, experimentalTsImportSpecifiers, ...unrecognized } = jsonObject; - const filteredTsConfigOptions = { - compiler, - compilerHost, - compilerOptions, - emit, - experimentalReplAwait, - files, - ignore, - ignoreDiagnostics, - logError, - preferTsExts, - pretty, - require, - skipIgnore, - transpileOnly, - typeCheck, - transpiler, - scope, - scopeDir, - moduleTypes, - swc, - experimentalResolver, - esm, - experimentalSpecifierResolution, - experimentalTsImportSpecifiers, - }; - // Use the typechecker to make sure this implementation has the correct set of properties - const catchExtraneousProps = null; - const catchMissingProps = null; - return { recognized: filteredTsConfigOptions, unrecognized }; -} -/** @internal */ -exports.ComputeAsCommonRootOfFiles = Symbol(); -/** - * Some TS compiler options have defaults which are not provided by TS's config parsing functions. - * This function centralizes the logic for computing those defaults. - * @internal - */ -function getTsConfigDefaults(config, basePath, _files, _include, _exclude) { - const { composite = false } = config.options; - let rootDir = config.options.rootDir; - if (rootDir == null) { - if (composite) - rootDir = basePath; - // Return this symbol to avoid computing from `files`, which would require fs calls - else - rootDir = exports.ComputeAsCommonRootOfFiles; - } - const { outDir = rootDir } = config.options; - // Docs are wrong: https://www.typescriptlang.org/tsconfig#include - // Docs say **, but it's actually **/*; compiler throws error for ** - const include = _files ? [] : ['**/*']; - const files = _files !== null && _files !== void 0 ? _files : []; - // Docs are misleading: https://www.typescriptlang.org/tsconfig#exclude - // Docs say it excludes node_modules, bower_components, jspm_packages, but actually those are excluded via behavior of "include" - const exclude = _exclude !== null && _exclude !== void 0 ? _exclude : [outDir]; // TODO technically, outDir is absolute path, but exclude should be relative glob pattern? - // TODO compute baseUrl - return { rootDir, outDir, include, files, exclude, composite }; -} -exports.getTsConfigDefaults = getTsConfigDefaults; -//# sourceMappingURL=configuration.js.map - -/***/ }), - -/***/ 13108: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { - -"use strict"; -var __webpack_unused_export__; - -__webpack_unused_export__ = ({ value: true }); -exports.lT = __webpack_unused_export__ = __webpack_unused_export__ = void 0; -const index_1 = __nccwpck_require__(51351); -const url_1 = __nccwpck_require__(57310); -const path_1 = __nccwpck_require__(71017); -const assert = __nccwpck_require__(39491); -const util_1 = __nccwpck_require__(81842); -const module_1 = __nccwpck_require__(98188); -// The hooks API changed in node version X so we need to check for backwards compatibility. -const newHooksAPI = (0, util_1.versionGteLt)(process.versions.node, '16.12.0'); -/** @internal */ -function filterHooksByAPIVersion(hooks) { - const { getFormat, load, resolve, transformSource } = hooks; - // Explicit return type to avoid TS's non-ideal inferred type - const hooksAPI = newHooksAPI - ? { resolve, load, getFormat: undefined, transformSource: undefined } - : { resolve, getFormat, transformSource, load: undefined }; - return hooksAPI; -} -__webpack_unused_export__ = filterHooksByAPIVersion; -/** @internal */ -function registerAndCreateEsmHooks(opts) { - // Automatically performs registration just like `-r ts-node/register` - const tsNodeInstance = (0, index_1.register)(opts); - return createEsmHooks(tsNodeInstance); -} -__webpack_unused_export__ = registerAndCreateEsmHooks; -function createEsmHooks(tsNodeService) { - tsNodeService.enableExperimentalEsmLoaderInterop(); - // Custom implementation that considers additional file extensions and automatically adds file extensions - const nodeResolveImplementation = tsNodeService.getNodeEsmResolver(); - const nodeGetFormatImplementation = tsNodeService.getNodeEsmGetFormat(); - const extensions = tsNodeService.extensions; - const hooksAPI = filterHooksByAPIVersion({ - resolve, - load, - getFormat, - transformSource, - }); - function isFileUrlOrNodeStyleSpecifier(parsed) { - // We only understand file:// URLs, but in node, the specifier can be a node-style `./foo` or `foo` - const { protocol } = parsed; - return protocol === null || protocol === 'file:'; - } - /** - * Named "probably" as a reminder that this is a guess. - * node does not explicitly tell us if we're resolving the entrypoint or not. - */ - function isProbablyEntrypoint(specifier, parentURL) { - return parentURL === undefined && specifier.startsWith('file://'); - } - // Side-channel between `resolve()` and `load()` hooks - const rememberIsProbablyEntrypoint = new Set(); - const rememberResolvedViaCommonjsFallback = new Set(); - async function resolve(specifier, context, defaultResolve) { - const defer = async () => { - const r = await defaultResolve(specifier, context, defaultResolve); - return r; - }; - // See: https://github.com/nodejs/node/discussions/41711 - // nodejs will likely implement a similar fallback. Till then, we can do our users a favor and fallback today. - async function entrypointFallback(cb) { - try { - const resolution = await cb(); - if ((resolution === null || resolution === void 0 ? void 0 : resolution.url) && - isProbablyEntrypoint(specifier, context.parentURL)) - rememberIsProbablyEntrypoint.add(resolution.url); - return resolution; - } - catch (esmResolverError) { - if (!isProbablyEntrypoint(specifier, context.parentURL)) - throw esmResolverError; - try { - let cjsSpecifier = specifier; - // Attempt to convert from ESM file:// to CommonJS path - try { - if (specifier.startsWith('file://')) - cjsSpecifier = (0, url_1.fileURLToPath)(specifier); - } - catch { } - const resolution = (0, url_1.pathToFileURL)((0, module_1.createRequire)(process.cwd()).resolve(cjsSpecifier)).toString(); - rememberIsProbablyEntrypoint.add(resolution); - rememberResolvedViaCommonjsFallback.add(resolution); - return { url: resolution, format: 'commonjs' }; + Debug2.formatTransformFlags = formatTransformFlags; + function formatEmitFlags(flags) { + return formatEnum( + flags, + EmitFlags, + /*isFlags*/ + true + ); + } + Debug2.formatEmitFlags = formatEmitFlags; + function formatSymbolFlags(flags) { + return formatEnum( + flags, + SymbolFlags, + /*isFlags*/ + true + ); + } + Debug2.formatSymbolFlags = formatSymbolFlags; + function formatTypeFlags(flags) { + return formatEnum( + flags, + TypeFlags, + /*isFlags*/ + true + ); + } + Debug2.formatTypeFlags = formatTypeFlags; + function formatSignatureFlags(flags) { + return formatEnum( + flags, + SignatureFlags, + /*isFlags*/ + true + ); + } + Debug2.formatSignatureFlags = formatSignatureFlags; + function formatObjectFlags(flags) { + return formatEnum( + flags, + ObjectFlags, + /*isFlags*/ + true + ); + } + Debug2.formatObjectFlags = formatObjectFlags; + function formatFlowFlags(flags) { + return formatEnum( + flags, + FlowFlags, + /*isFlags*/ + true + ); + } + Debug2.formatFlowFlags = formatFlowFlags; + function formatRelationComparisonResult(result) { + return formatEnum( + result, + RelationComparisonResult, + /*isFlags*/ + true + ); + } + Debug2.formatRelationComparisonResult = formatRelationComparisonResult; + function formatCheckMode(mode) { + return formatEnum( + mode, + CheckMode, + /*isFlags*/ + true + ); + } + Debug2.formatCheckMode = formatCheckMode; + function formatSignatureCheckMode(mode) { + return formatEnum( + mode, + SignatureCheckMode, + /*isFlags*/ + true + ); + } + Debug2.formatSignatureCheckMode = formatSignatureCheckMode; + function formatTypeFacts(facts) { + return formatEnum( + facts, + TypeFacts, + /*isFlags*/ + true + ); + } + Debug2.formatTypeFacts = formatTypeFacts; + let isDebugInfoEnabled = false; + let flowNodeProto; + function attachFlowNodeDebugInfoWorker(flowNode) { + if (!("__debugFlowFlags" in flowNode)) { + Object.defineProperties(flowNode, { + // for use with vscode-js-debug's new customDescriptionGenerator in launch.json + __tsDebuggerDisplay: { + value() { + const flowHeader = this.flags & 2 /* Start */ ? "FlowStart" : this.flags & 4 /* BranchLabel */ ? "FlowBranchLabel" : this.flags & 8 /* LoopLabel */ ? "FlowLoopLabel" : this.flags & 16 /* Assignment */ ? "FlowAssignment" : this.flags & 32 /* TrueCondition */ ? "FlowTrueCondition" : this.flags & 64 /* FalseCondition */ ? "FlowFalseCondition" : this.flags & 128 /* SwitchClause */ ? "FlowSwitchClause" : this.flags & 256 /* ArrayMutation */ ? "FlowArrayMutation" : this.flags & 512 /* Call */ ? "FlowCall" : this.flags & 1024 /* ReduceLabel */ ? "FlowReduceLabel" : this.flags & 1 /* Unreachable */ ? "FlowUnreachable" : "UnknownFlow"; + const remainingFlags = this.flags & ~(2048 /* Referenced */ - 1); + return `${flowHeader}${remainingFlags ? ` (${formatFlowFlags(remainingFlags)})` : ""}`; } - catch (commonjsResolverError) { - throw esmResolverError; + }, + __debugFlowFlags: { + get() { + return formatEnum( + this.flags, + FlowFlags, + /*isFlags*/ + true + ); } - } - } - return addShortCircuitFlag(async () => { - const parsed = (0, url_1.parse)(specifier); - const { pathname, protocol, hostname } = parsed; - if (!isFileUrlOrNodeStyleSpecifier(parsed)) { - return entrypointFallback(defer); - } - if (protocol !== null && protocol !== 'file:') { - return entrypointFallback(defer); - } - // Malformed file:// URL? We should always see `null` or `''` - if (hostname) { - // TODO file://./foo sets `hostname` to `'.'`. Perhaps we should special-case this. - return entrypointFallback(defer); - } - // pathname is the path to be resolved - return entrypointFallback(() => nodeResolveImplementation.defaultResolve(specifier, context, defaultResolve)); - }); - } - // `load` from new loader hook API (See description at the top of this file) - async function load(url, context, defaultLoad) { - return addShortCircuitFlag(async () => { - var _a; - // If we get a format hint from resolve() on the context then use it - // otherwise call the old getFormat() hook using node's old built-in defaultGetFormat() that ships with ts-node - const format = (_a = context.format) !== null && _a !== void 0 ? _a : (await getFormat(url, context, nodeGetFormatImplementation.defaultGetFormat)).format; - let source = undefined; - if (format !== 'builtin' && format !== 'commonjs') { - // Call the new defaultLoad() to get the source - const { source: rawSource } = await defaultLoad(url, { - ...context, - format, - }, defaultLoad); - if (rawSource === undefined || rawSource === null) { - throw new Error(`Failed to load raw source: Format was '${format}' and url was '${url}''.`); + }, + __debugToString: { + value() { + return formatControlFlowGraph(this); } - // Emulate node's built-in old defaultTransformSource() so we can re-use the old transformSource() hook - const defaultTransformSource = async (source, _context, _defaultTransformSource) => ({ source }); - // Call the old hook - const { source: transformedSource } = await transformSource(rawSource, { url, format }, defaultTransformSource); - source = transformedSource; - } - return { format, source }; - }); - } - async function getFormat(url, context, defaultGetFormat) { - const defer = (overrideUrl = url) => defaultGetFormat(overrideUrl, context, defaultGetFormat); - // See: https://github.com/nodejs/node/discussions/41711 - // nodejs will likely implement a similar fallback. Till then, we can do our users a favor and fallback today. - async function entrypointFallback(cb) { - try { - return await cb(); - } - catch (getFormatError) { - if (!rememberIsProbablyEntrypoint.has(url)) - throw getFormatError; - return { format: 'commonjs' }; + } + }); + } + } + function attachFlowNodeDebugInfo(flowNode) { + if (isDebugInfoEnabled) { + if (typeof Object.setPrototypeOf === "function") { + if (!flowNodeProto) { + flowNodeProto = Object.create(Object.prototype); + attachFlowNodeDebugInfoWorker(flowNodeProto); + } + Object.setPrototypeOf(flowNode, flowNodeProto); + } else { + attachFlowNodeDebugInfoWorker(flowNode); } + } } - const parsed = (0, url_1.parse)(url); - if (!isFileUrlOrNodeStyleSpecifier(parsed)) { - return entrypointFallback(defer); + Debug2.attachFlowNodeDebugInfo = attachFlowNodeDebugInfo; + let nodeArrayProto; + function attachNodeArrayDebugInfoWorker(array) { + if (!("__tsDebuggerDisplay" in array)) { + Object.defineProperties(array, { + __tsDebuggerDisplay: { + value(defaultValue) { + defaultValue = String(defaultValue).replace(/(?:,[\s\w\d_]+:[^,]+)+\]$/, "]"); + return `NodeArray ${defaultValue}`; + } + } + }); + } } - const { pathname } = parsed; - assert(pathname !== null, 'ESM getFormat() hook: URL should never have null pathname'); - const nativePath = (0, url_1.fileURLToPath)(url); - let nodeSays; - // If file has extension not understood by node, then ask node how it would treat the emitted extension. - // E.g. .mts compiles to .mjs, so ask node how to classify an .mjs file. - const ext = (0, path_1.extname)(nativePath); - const tsNodeIgnored = tsNodeService.ignored(nativePath); - const nodeEquivalentExt = extensions.nodeEquivalents.get(ext); - if (nodeEquivalentExt && !tsNodeIgnored) { - nodeSays = await entrypointFallback(() => defer((0, url_1.format)((0, url_1.pathToFileURL)(nativePath + nodeEquivalentExt)))); + function attachNodeArrayDebugInfo(array) { + if (isDebugInfoEnabled) { + if (typeof Object.setPrototypeOf === "function") { + if (!nodeArrayProto) { + nodeArrayProto = Object.create(Array.prototype); + attachNodeArrayDebugInfoWorker(nodeArrayProto); + } + Object.setPrototypeOf(array, nodeArrayProto); + } else { + attachNodeArrayDebugInfoWorker(array); + } + } } - else { - try { - nodeSays = await entrypointFallback(defer); + Debug2.attachNodeArrayDebugInfo = attachNodeArrayDebugInfo; + function enableDebugInfo() { + if (isDebugInfoEnabled) + return; + const weakTypeTextMap = /* @__PURE__ */ new WeakMap(); + const weakNodeTextMap = /* @__PURE__ */ new WeakMap(); + Object.defineProperties(objectAllocator.getSymbolConstructor().prototype, { + // for use with vscode-js-debug's new customDescriptionGenerator in launch.json + __tsDebuggerDisplay: { + value() { + const symbolHeader = this.flags & 33554432 /* Transient */ ? "TransientSymbol" : "Symbol"; + const remainingSymbolFlags = this.flags & ~33554432 /* Transient */; + return `${symbolHeader} '${symbolName(this)}'${remainingSymbolFlags ? ` (${formatSymbolFlags(remainingSymbolFlags)})` : ""}`; + } + }, + __debugFlags: { + get() { + return formatSymbolFlags(this.flags); + } } - catch (e) { - if (e instanceof Error && - tsNodeIgnored && - extensions.nodeDoesNotUnderstand.includes(ext)) { - e.message += - `\n\n` + - `Hint:\n` + - `ts-node is configured to ignore this file.\n` + - `If you want ts-node to handle this file, consider enabling the "skipIgnore" option or adjusting your "ignore" patterns.\n` + - `https://typestrong.org/ts-node/docs/scope\n`; + }); + Object.defineProperties(objectAllocator.getTypeConstructor().prototype, { + // for use with vscode-js-debug's new customDescriptionGenerator in launch.json + __tsDebuggerDisplay: { + value() { + const typeHeader = this.flags & 67359327 /* Intrinsic */ ? `IntrinsicType ${this.intrinsicName}${this.debugIntrinsicName ? ` (${this.debugIntrinsicName})` : ""}` : this.flags & 98304 /* Nullable */ ? "NullableType" : this.flags & 384 /* StringOrNumberLiteral */ ? `LiteralType ${JSON.stringify(this.value)}` : this.flags & 2048 /* BigIntLiteral */ ? `LiteralType ${this.value.negative ? "-" : ""}${this.value.base10Value}n` : this.flags & 8192 /* UniqueESSymbol */ ? "UniqueESSymbolType" : this.flags & 32 /* Enum */ ? "EnumType" : this.flags & 1048576 /* Union */ ? "UnionType" : this.flags & 2097152 /* Intersection */ ? "IntersectionType" : this.flags & 4194304 /* Index */ ? "IndexType" : this.flags & 8388608 /* IndexedAccess */ ? "IndexedAccessType" : this.flags & 16777216 /* Conditional */ ? "ConditionalType" : this.flags & 33554432 /* Substitution */ ? "SubstitutionType" : this.flags & 262144 /* TypeParameter */ ? "TypeParameter" : this.flags & 524288 /* Object */ ? this.objectFlags & 3 /* ClassOrInterface */ ? "InterfaceType" : this.objectFlags & 4 /* Reference */ ? "TypeReference" : this.objectFlags & 8 /* Tuple */ ? "TupleType" : this.objectFlags & 16 /* Anonymous */ ? "AnonymousType" : this.objectFlags & 32 /* Mapped */ ? "MappedType" : this.objectFlags & 1024 /* ReverseMapped */ ? "ReverseMappedType" : this.objectFlags & 256 /* EvolvingArray */ ? "EvolvingArrayType" : "ObjectType" : "Type"; + const remainingObjectFlags = this.flags & 524288 /* Object */ ? this.objectFlags & ~1343 /* ObjectTypeKindMask */ : 0; + return `${typeHeader}${this.symbol ? ` '${symbolName(this.symbol)}'` : ""}${remainingObjectFlags ? ` (${formatObjectFlags(remainingObjectFlags)})` : ""}`; + } + }, + __debugFlags: { + get() { + return formatTypeFlags(this.flags); + } + }, + __debugObjectFlags: { + get() { + return this.flags & 524288 /* Object */ ? formatObjectFlags(this.objectFlags) : ""; + } + }, + __debugTypeToString: { + value() { + let text = weakTypeTextMap.get(this); + if (text === void 0) { + text = this.checker.typeToString(this); + weakTypeTextMap.set(this, text); } - throw e; + return text; + } } - } - // For files compiled by ts-node that node believes are either CJS or ESM, check if we should override that classification - if (!tsNodeService.ignored(nativePath) && - (nodeSays.format === 'commonjs' || nodeSays.format === 'module')) { - const { moduleType } = tsNodeService.moduleTypeClassifier.classifyModuleByModuleTypeOverrides((0, util_1.normalizeSlashes)(nativePath)); - if (moduleType === 'cjs') { - return { format: 'commonjs' }; + }); + Object.defineProperties(objectAllocator.getSignatureConstructor().prototype, { + __debugFlags: { + get() { + return formatSignatureFlags(this.flags); + } + }, + __debugSignatureToString: { + value() { + var _a; + return (_a = this.checker) == null ? void 0 : _a.signatureToString(this); + } } - else if (moduleType === 'esm') { - return { format: 'module' }; + }); + const nodeConstructors = [ + objectAllocator.getNodeConstructor(), + objectAllocator.getIdentifierConstructor(), + objectAllocator.getTokenConstructor(), + objectAllocator.getSourceFileConstructor() + ]; + for (const ctor of nodeConstructors) { + if (!hasProperty(ctor.prototype, "__debugKind")) { + Object.defineProperties(ctor.prototype, { + // for use with vscode-js-debug's new customDescriptionGenerator in launch.json + __tsDebuggerDisplay: { + value() { + const nodeHeader = isGeneratedIdentifier(this) ? "GeneratedIdentifier" : isIdentifier(this) ? `Identifier '${idText(this)}'` : isPrivateIdentifier(this) ? `PrivateIdentifier '${idText(this)}'` : isStringLiteral(this) ? `StringLiteral ${JSON.stringify(this.text.length < 10 ? this.text : this.text.slice(10) + "...")}` : isNumericLiteral(this) ? `NumericLiteral ${this.text}` : isBigIntLiteral(this) ? `BigIntLiteral ${this.text}n` : isTypeParameterDeclaration(this) ? "TypeParameterDeclaration" : isParameter(this) ? "ParameterDeclaration" : isConstructorDeclaration(this) ? "ConstructorDeclaration" : isGetAccessorDeclaration(this) ? "GetAccessorDeclaration" : isSetAccessorDeclaration(this) ? "SetAccessorDeclaration" : isCallSignatureDeclaration(this) ? "CallSignatureDeclaration" : isConstructSignatureDeclaration(this) ? "ConstructSignatureDeclaration" : isIndexSignatureDeclaration(this) ? "IndexSignatureDeclaration" : isTypePredicateNode(this) ? "TypePredicateNode" : isTypeReferenceNode(this) ? "TypeReferenceNode" : isFunctionTypeNode(this) ? "FunctionTypeNode" : isConstructorTypeNode(this) ? "ConstructorTypeNode" : isTypeQueryNode(this) ? "TypeQueryNode" : isTypeLiteralNode(this) ? "TypeLiteralNode" : isArrayTypeNode(this) ? "ArrayTypeNode" : isTupleTypeNode(this) ? "TupleTypeNode" : isOptionalTypeNode(this) ? "OptionalTypeNode" : isRestTypeNode(this) ? "RestTypeNode" : isUnionTypeNode(this) ? "UnionTypeNode" : isIntersectionTypeNode(this) ? "IntersectionTypeNode" : isConditionalTypeNode(this) ? "ConditionalTypeNode" : isInferTypeNode(this) ? "InferTypeNode" : isParenthesizedTypeNode(this) ? "ParenthesizedTypeNode" : isThisTypeNode(this) ? "ThisTypeNode" : isTypeOperatorNode(this) ? "TypeOperatorNode" : isIndexedAccessTypeNode(this) ? "IndexedAccessTypeNode" : isMappedTypeNode(this) ? "MappedTypeNode" : isLiteralTypeNode(this) ? "LiteralTypeNode" : isNamedTupleMember(this) ? "NamedTupleMember" : isImportTypeNode(this) ? "ImportTypeNode" : formatSyntaxKind(this.kind); + return `${nodeHeader}${this.flags ? ` (${formatNodeFlags(this.flags)})` : ""}`; + } + }, + __debugKind: { + get() { + return formatSyntaxKind(this.kind); + } + }, + __debugNodeFlags: { + get() { + return formatNodeFlags(this.flags); + } + }, + __debugModifierFlags: { + get() { + return formatModifierFlags(getEffectiveModifierFlagsNoCache(this)); + } + }, + __debugTransformFlags: { + get() { + return formatTransformFlags(this.transformFlags); + } + }, + __debugIsParseTreeNode: { + get() { + return isParseTreeNode(this); + } + }, + __debugEmitFlags: { + get() { + return formatEmitFlags(getEmitFlags(this)); + } + }, + __debugGetText: { + value(includeTrivia) { + if (nodeIsSynthesized(this)) + return ""; + let text = weakNodeTextMap.get(this); + if (text === void 0) { + const parseNode = getParseTreeNode(this); + const sourceFile = parseNode && getSourceFileOfNode(parseNode); + text = sourceFile ? getSourceTextOfNodeFromSourceFile(sourceFile, parseNode, includeTrivia) : ""; + weakNodeTextMap.set(this, text); + } + return text; + } + } + }); } + } + isDebugInfoEnabled = true; } - return nodeSays; - } - async function transformSource(source, context, defaultTransformSource) { - if (source === null || source === undefined) { - throw new Error('No source'); + Debug2.enableDebugInfo = enableDebugInfo; + function formatVariance(varianceFlags) { + const variance = varianceFlags & 7 /* VarianceMask */; + let result = variance === 0 /* Invariant */ ? "in out" : variance === 3 /* Bivariant */ ? "[bivariant]" : variance === 2 /* Contravariant */ ? "in" : variance === 1 /* Covariant */ ? "out" : variance === 4 /* Independent */ ? "[independent]" : ""; + if (varianceFlags & 8 /* Unmeasurable */) { + result += " (unmeasurable)"; + } else if (varianceFlags & 16 /* Unreliable */) { + result += " (unreliable)"; + } + return result; } - const defer = () => defaultTransformSource(source, context, defaultTransformSource); - const sourceAsString = typeof source === 'string' ? source : source.toString('utf8'); - const { url } = context; - const parsed = (0, url_1.parse)(url); - if (!isFileUrlOrNodeStyleSpecifier(parsed)) { - return defer(); + Debug2.formatVariance = formatVariance; + class DebugTypeMapper { + __debugToString() { + var _a; + type(this); + switch (this.kind) { + case 3 /* Function */: + return ((_a = this.debugInfo) == null ? void 0 : _a.call(this)) || "(function mapper)"; + case 0 /* Simple */: + return `${this.source.__debugTypeToString()} -> ${this.target.__debugTypeToString()}`; + case 1 /* Array */: + return zipWith( + this.sources, + this.targets || map(this.sources, () => "any"), + (s, t) => `${s.__debugTypeToString()} -> ${typeof t === "string" ? t : t.__debugTypeToString()}` + ).join(", "); + case 2 /* Deferred */: + return zipWith( + this.sources, + this.targets, + (s, t) => `${s.__debugTypeToString()} -> ${t().__debugTypeToString()}` + ).join(", "); + case 5 /* Merged */: + case 4 /* Composite */: + return `m1: ${this.mapper1.__debugToString().split("\n").join("\n ")} +m2: ${this.mapper2.__debugToString().split("\n").join("\n ")}`; + default: + return assertNever(this); + } + } } - const nativePath = (0, url_1.fileURLToPath)(url); - if (tsNodeService.ignored(nativePath)) { - return defer(); + Debug2.DebugTypeMapper = DebugTypeMapper; + function attachDebugPrototypeIfDebug(mapper) { + if (Debug2.isDebugging) { + return Object.setPrototypeOf(mapper, DebugTypeMapper.prototype); + } + return mapper; } - const emittedJs = tsNodeService.compile(sourceAsString, nativePath); - return { source: emittedJs }; - } - return hooksAPI; -} -exports.lT = createEsmHooks; -async function addShortCircuitFlag(fn) { - const ret = await fn(); - // Not sure if this is necessary; being lazy. Can revisit in the future. - if (ret == null) - return ret; - return { - ...ret, - shortCircuit: true, - }; -} -//# sourceMappingURL=esm.js.map - -/***/ }), - -/***/ 50872: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { - -"use strict"; - -Object.defineProperty(exports, "__esModule", ({ value: true })); -exports.getExtensions = void 0; -const util_1 = __nccwpck_require__(81842); -const nodeEquivalents = new Map([ - ['.ts', '.js'], - ['.tsx', '.js'], - ['.jsx', '.js'], - ['.mts', '.mjs'], - ['.cts', '.cjs'], -]); -const tsResolverEquivalents = new Map([ - ['.ts', ['.js']], - ['.tsx', ['.js', '.jsx']], - ['.mts', ['.mjs']], - ['.cts', ['.cjs']], -]); -// All extensions understood by vanilla node -const vanillaNodeExtensions = [ - '.js', - '.json', - '.node', - '.mjs', - '.cjs', -]; -// Extensions added by vanilla node's require() if you omit them: -// js, json, node -// Extensions added by vanilla node if you omit them with --experimental-specifier-resolution=node -// js, json, node, mjs -// Extensions added by ESM codepath's legacy package.json "main" resolver -// js, json, node (not mjs!) -const nodeDoesNotUnderstand = [ - '.ts', - '.tsx', - '.jsx', - '.cts', - '.mts', -]; -/** - * [MUST_UPDATE_FOR_NEW_FILE_EXTENSIONS] - * @internal - */ -function getExtensions(config, options, tsVersion) { - // TS 4.5 is first version to understand .cts, .mts, .cjs, and .mjs extensions - const tsSupportsMtsCtsExts = (0, util_1.versionGteLt)(tsVersion, '4.5.0'); - const requiresHigherTypescriptVersion = []; - if (!tsSupportsMtsCtsExts) - requiresHigherTypescriptVersion.push('.cts', '.cjs', '.mts', '.mjs'); - const allPossibleExtensionsSortedByPreference = Array.from(new Set([ - ...(options.preferTsExts ? nodeDoesNotUnderstand : []), - ...vanillaNodeExtensions, - ...nodeDoesNotUnderstand, - ])); - const compiledJsUnsorted = ['.ts']; - const compiledJsxUnsorted = []; - if (config.options.jsx) - compiledJsxUnsorted.push('.tsx'); - if (tsSupportsMtsCtsExts) - compiledJsUnsorted.push('.mts', '.cts'); - if (config.options.allowJs) { - compiledJsUnsorted.push('.js'); - if (config.options.jsx) - compiledJsxUnsorted.push('.jsx'); - if (tsSupportsMtsCtsExts) - compiledJsUnsorted.push('.mjs', '.cjs'); + Debug2.attachDebugPrototypeIfDebug = attachDebugPrototypeIfDebug; + function printControlFlowGraph(flowNode) { + return console.log(formatControlFlowGraph(flowNode)); + } + Debug2.printControlFlowGraph = printControlFlowGraph; + function formatControlFlowGraph(flowNode) { + let nextDebugFlowId = -1; + function getDebugFlowNodeId(f) { + if (!f.id) { + f.id = nextDebugFlowId; + nextDebugFlowId--; + } + return f.id; + } + let BoxCharacter; + ((BoxCharacter2) => { + BoxCharacter2["lr"] = "\u2500"; + BoxCharacter2["ud"] = "\u2502"; + BoxCharacter2["dr"] = "\u256D"; + BoxCharacter2["dl"] = "\u256E"; + BoxCharacter2["ul"] = "\u256F"; + BoxCharacter2["ur"] = "\u2570"; + BoxCharacter2["udr"] = "\u251C"; + BoxCharacter2["udl"] = "\u2524"; + BoxCharacter2["dlr"] = "\u252C"; + BoxCharacter2["ulr"] = "\u2534"; + BoxCharacter2["udlr"] = "\u256B"; + })(BoxCharacter || (BoxCharacter = {})); + let Connection; + ((Connection2) => { + Connection2[Connection2["None"] = 0] = "None"; + Connection2[Connection2["Up"] = 1] = "Up"; + Connection2[Connection2["Down"] = 2] = "Down"; + Connection2[Connection2["Left"] = 4] = "Left"; + Connection2[Connection2["Right"] = 8] = "Right"; + Connection2[Connection2["UpDown"] = 3] = "UpDown"; + Connection2[Connection2["LeftRight"] = 12] = "LeftRight"; + Connection2[Connection2["UpLeft"] = 5] = "UpLeft"; + Connection2[Connection2["UpRight"] = 9] = "UpRight"; + Connection2[Connection2["DownLeft"] = 6] = "DownLeft"; + Connection2[Connection2["DownRight"] = 10] = "DownRight"; + Connection2[Connection2["UpDownLeft"] = 7] = "UpDownLeft"; + Connection2[Connection2["UpDownRight"] = 11] = "UpDownRight"; + Connection2[Connection2["UpLeftRight"] = 13] = "UpLeftRight"; + Connection2[Connection2["DownLeftRight"] = 14] = "DownLeftRight"; + Connection2[Connection2["UpDownLeftRight"] = 15] = "UpDownLeftRight"; + Connection2[Connection2["NoChildren"] = 16] = "NoChildren"; + })(Connection || (Connection = {})); + const hasAntecedentFlags = 16 /* Assignment */ | 96 /* Condition */ | 128 /* SwitchClause */ | 256 /* ArrayMutation */ | 512 /* Call */ | 1024 /* ReduceLabel */; + const hasNodeFlags = 2 /* Start */ | 16 /* Assignment */ | 512 /* Call */ | 96 /* Condition */ | 256 /* ArrayMutation */; + const links = /* @__PURE__ */ Object.create( + /*o*/ + null + ); + const nodes = []; + const edges = []; + const root = buildGraphNode(flowNode, /* @__PURE__ */ new Set()); + for (const node of nodes) { + node.text = renderFlowNode(node.flowNode, node.circular); + computeLevel(node); + } + const height = computeHeight(root); + const columnWidths = computeColumnWidths(height); + computeLanes(root, 0); + return renderGraph(); + function isFlowSwitchClause(f) { + return !!(f.flags & 128 /* SwitchClause */); + } + function hasAntecedents(f) { + return !!(f.flags & 12 /* Label */) && !!f.antecedents; + } + function hasAntecedent(f) { + return !!(f.flags & hasAntecedentFlags); + } + function hasNode(f) { + return !!(f.flags & hasNodeFlags); + } + function getChildren(node) { + const children = []; + for (const edge of node.edges) { + if (edge.source === node) { + children.push(edge.target); + } + } + return children; + } + function getParents(node) { + const parents = []; + for (const edge of node.edges) { + if (edge.target === node) { + parents.push(edge.source); + } + } + return parents; + } + function buildGraphNode(flowNode2, seen) { + const id = getDebugFlowNodeId(flowNode2); + let graphNode = links[id]; + if (graphNode && seen.has(flowNode2)) { + graphNode.circular = true; + graphNode = { + id: -1, + flowNode: flowNode2, + edges: [], + text: "", + lane: -1, + endLane: -1, + level: -1, + circular: "circularity" + }; + nodes.push(graphNode); + return graphNode; + } + seen.add(flowNode2); + if (!graphNode) { + links[id] = graphNode = { id, flowNode: flowNode2, edges: [], text: "", lane: -1, endLane: -1, level: -1, circular: false }; + nodes.push(graphNode); + if (hasAntecedents(flowNode2)) { + for (const antecedent of flowNode2.antecedents) { + buildGraphEdge(graphNode, antecedent, seen); + } + } else if (hasAntecedent(flowNode2)) { + buildGraphEdge(graphNode, flowNode2.antecedent, seen); + } + } + seen.delete(flowNode2); + return graphNode; + } + function buildGraphEdge(source, antecedent, seen) { + const target = buildGraphNode(antecedent, seen); + const edge = { source, target }; + edges.push(edge); + source.edges.push(edge); + target.edges.push(edge); + } + function computeLevel(node) { + if (node.level !== -1) { + return node.level; + } + let level = 0; + for (const parent2 of getParents(node)) { + level = Math.max(level, computeLevel(parent2) + 1); + } + return node.level = level; + } + function computeHeight(node) { + let height2 = 0; + for (const child of getChildren(node)) { + height2 = Math.max(height2, computeHeight(child)); + } + return height2 + 1; + } + function computeColumnWidths(height2) { + const columns = fill(Array(height2), 0); + for (const node of nodes) { + columns[node.level] = Math.max(columns[node.level], node.text.length); + } + return columns; + } + function computeLanes(node, lane) { + if (node.lane === -1) { + node.lane = lane; + node.endLane = lane; + const children = getChildren(node); + for (let i = 0; i < children.length; i++) { + if (i > 0) + lane++; + const child = children[i]; + computeLanes(child, lane); + if (child.endLane > node.endLane) { + lane = child.endLane; + } + } + node.endLane = lane; + } + } + function getHeader(flags) { + if (flags & 2 /* Start */) + return "Start"; + if (flags & 4 /* BranchLabel */) + return "Branch"; + if (flags & 8 /* LoopLabel */) + return "Loop"; + if (flags & 16 /* Assignment */) + return "Assignment"; + if (flags & 32 /* TrueCondition */) + return "True"; + if (flags & 64 /* FalseCondition */) + return "False"; + if (flags & 128 /* SwitchClause */) + return "SwitchClause"; + if (flags & 256 /* ArrayMutation */) + return "ArrayMutation"; + if (flags & 512 /* Call */) + return "Call"; + if (flags & 1024 /* ReduceLabel */) + return "ReduceLabel"; + if (flags & 1 /* Unreachable */) + return "Unreachable"; + throw new Error(); + } + function getNodeText(node) { + const sourceFile = getSourceFileOfNode(node); + return getSourceTextOfNodeFromSourceFile( + sourceFile, + node, + /*includeTrivia*/ + false + ); + } + function renderFlowNode(flowNode2, circular) { + let text = getHeader(flowNode2.flags); + if (circular) { + text = `${text}#${getDebugFlowNodeId(flowNode2)}`; + } + if (hasNode(flowNode2)) { + if (flowNode2.node) { + text += ` (${getNodeText(flowNode2.node)})`; + } + } else if (isFlowSwitchClause(flowNode2)) { + const clauses = []; + for (let i = flowNode2.clauseStart; i < flowNode2.clauseEnd; i++) { + const clause = flowNode2.switchStatement.caseBlock.clauses[i]; + if (isDefaultClause(clause)) { + clauses.push("default"); + } else { + clauses.push(getNodeText(clause.expression)); + } + } + text += ` (${clauses.join(", ")})`; + } + return circular === "circularity" ? `Circular(${text})` : text; + } + function renderGraph() { + const columnCount = columnWidths.length; + const laneCount = nodes.reduce((x, n) => Math.max(x, n.lane), 0) + 1; + const lanes = fill(Array(laneCount), ""); + const grid = columnWidths.map(() => Array(laneCount)); + const connectors = columnWidths.map(() => fill(Array(laneCount), 0)); + for (const node of nodes) { + grid[node.level][node.lane] = node; + const children = getChildren(node); + for (let i = 0; i < children.length; i++) { + const child = children[i]; + let connector = 8 /* Right */; + if (child.lane === node.lane) + connector |= 4 /* Left */; + if (i > 0) + connector |= 1 /* Up */; + if (i < children.length - 1) + connector |= 2 /* Down */; + connectors[node.level][child.lane] |= connector; + } + if (children.length === 0) { + connectors[node.level][node.lane] |= 16 /* NoChildren */; + } + const parents = getParents(node); + for (let i = 0; i < parents.length; i++) { + const parent2 = parents[i]; + let connector = 4 /* Left */; + if (i > 0) + connector |= 1 /* Up */; + if (i < parents.length - 1) + connector |= 2 /* Down */; + connectors[node.level - 1][parent2.lane] |= connector; + } + } + for (let column = 0; column < columnCount; column++) { + for (let lane = 0; lane < laneCount; lane++) { + const left = column > 0 ? connectors[column - 1][lane] : 0; + const above = lane > 0 ? connectors[column][lane - 1] : 0; + let connector = connectors[column][lane]; + if (!connector) { + if (left & 8 /* Right */) + connector |= 12 /* LeftRight */; + if (above & 2 /* Down */) + connector |= 3 /* UpDown */; + connectors[column][lane] = connector; + } + } + } + for (let column = 0; column < columnCount; column++) { + for (let lane = 0; lane < lanes.length; lane++) { + const connector = connectors[column][lane]; + const fill2 = connector & 4 /* Left */ ? "\u2500" /* lr */ : " "; + const node = grid[column][lane]; + if (!node) { + if (column < columnCount - 1) { + writeLane(lane, repeat(fill2, columnWidths[column] + 1)); + } + } else { + writeLane(lane, node.text); + if (column < columnCount - 1) { + writeLane(lane, " "); + writeLane(lane, repeat(fill2, columnWidths[column] - node.text.length)); + } + } + writeLane(lane, getBoxCharacter(connector)); + writeLane(lane, connector & 8 /* Right */ && column < columnCount - 1 && !grid[column + 1][lane] ? "\u2500" /* lr */ : " "); + } + } + return ` +${lanes.join("\n")} +`; + function writeLane(lane, text) { + lanes[lane] += text; + } + } + function getBoxCharacter(connector) { + switch (connector) { + case 3 /* UpDown */: + return "\u2502" /* ud */; + case 12 /* LeftRight */: + return "\u2500" /* lr */; + case 5 /* UpLeft */: + return "\u256F" /* ul */; + case 9 /* UpRight */: + return "\u2570" /* ur */; + case 6 /* DownLeft */: + return "\u256E" /* dl */; + case 10 /* DownRight */: + return "\u256D" /* dr */; + case 7 /* UpDownLeft */: + return "\u2524" /* udl */; + case 11 /* UpDownRight */: + return "\u251C" /* udr */; + case 13 /* UpLeftRight */: + return "\u2534" /* ulr */; + case 14 /* DownLeftRight */: + return "\u252C" /* dlr */; + case 15 /* UpDownLeftRight */: + return "\u256B" /* udlr */; + } + return " "; + } + function fill(array, value) { + if (array.fill) { + array.fill(value); + } else { + for (let i = 0; i < array.length; i++) { + array[i] = value; + } + } + return array; + } + function repeat(ch, length2) { + if (ch.repeat) { + return length2 > 0 ? ch.repeat(length2) : ""; + } + let s = ""; + while (s.length < length2) { + s += ch; + } + return s; + } + } + Debug2.formatControlFlowGraph = formatControlFlowGraph; + })(Debug || (Debug = {})); } - const compiledUnsorted = [...compiledJsUnsorted, ...compiledJsxUnsorted]; - const compiled = allPossibleExtensionsSortedByPreference.filter((ext) => compiledUnsorted.includes(ext)); - const compiledNodeDoesNotUnderstand = nodeDoesNotUnderstand.filter((ext) => compiled.includes(ext)); - /** - * TS's resolver can resolve foo.js to foo.ts, by replacing .js extension with several source extensions. - * IMPORTANT: Must preserve ordering according to preferTsExts! - * Must include the .js/.mjs/.cjs extension in the array! - * This affects resolution behavior! - * [MUST_UPDATE_FOR_NEW_FILE_EXTENSIONS] - */ - const r = allPossibleExtensionsSortedByPreference.filter((ext) => [...compiledUnsorted, '.js', '.mjs', '.cjs', '.mts', '.cts'].includes(ext)); - const replacementsForJs = r.filter((ext) => ['.js', '.jsx', '.ts', '.tsx'].includes(ext)); - const replacementsForJsx = r.filter((ext) => ['.jsx', '.tsx'].includes(ext)); - const replacementsForMjs = r.filter((ext) => ['.mjs', '.mts'].includes(ext)); - const replacementsForCjs = r.filter((ext) => ['.cjs', '.cts'].includes(ext)); - const replacementsForJsOrMjs = r.filter((ext) => ['.js', '.jsx', '.ts', '.tsx', '.mjs', '.mts'].includes(ext)); - // Node allows omitting .js or .mjs extension in certain situations (CJS, ESM w/experimental flag) - // So anything that compiles to .js or .mjs can also be omitted. - const experimentalSpecifierResolutionAddsIfOmitted = Array.from(new Set([...replacementsForJsOrMjs, '.json', '.node'])); - // Same as above, except node curiuosly doesn't do .mjs here - const legacyMainResolveAddsIfOmitted = Array.from(new Set([...replacementsForJs, '.json', '.node'])); - return { - /** All file extensions we transform, ordered by resolution preference according to preferTsExts */ - compiled, - /** Resolved extensions that vanilla node will not understand; we should handle them */ - nodeDoesNotUnderstand, - /** Like the above, but only the ones we're compiling */ - compiledNodeDoesNotUnderstand, - /** - * Mapping from extensions understood by tsc to the equivalent for node, - * as far as getFormat is concerned. - */ - nodeEquivalents, - /** - * Mapping from extensions rejected by TSC in import specifiers, to the - * possible alternatives that TS's resolver will accept. - * - * When we allow users to opt-in to .ts extensions in import specifiers, TS's - * resolver requires us to replace the .ts extensions with .js alternatives. - * Otherwise, resolution fails. - * - * Note TS's resolver is only used by, and only required for, typechecking. - * This is separate from node's resolver, which we hook separately and which - * does not require this mapping. - */ - tsResolverEquivalents, - /** - * Extensions that we can support if the user upgrades their typescript version. - * Used when raising hints. - */ - requiresHigherTypescriptVersion, - /** - * --experimental-specifier-resolution=node will add these extensions. - */ - experimentalSpecifierResolutionAddsIfOmitted, - /** - * ESM loader will add these extensions to package.json "main" field - */ - legacyMainResolveAddsIfOmitted, - replacementsForMjs, - replacementsForCjs, - replacementsForJsx, - replacementsForJs, - }; -} -exports.getExtensions = getExtensions; -//# sourceMappingURL=file-extensions.js.map - -/***/ }), - -/***/ 51351: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { - -"use strict"; + }); -var _a, _b; -Object.defineProperty(exports, "__esModule", ({ value: true })); -exports.createEsmHooks = exports.createFromPreloadedConfig = exports.create = exports.register = exports.TSError = exports.DEFAULTS = exports.VERSION = exports.debug = exports.INSPECT_CUSTOM = exports.env = exports.REGISTER_INSTANCE = exports.createRepl = void 0; -const path_1 = __nccwpck_require__(71017); -const module_1 = __nccwpck_require__(98188); -const util = __nccwpck_require__(73837); -const url_1 = __nccwpck_require__(57310); -const make_error_1 = __nccwpck_require__(80976); -const util_1 = __nccwpck_require__(81842); -const configuration_1 = __nccwpck_require__(76692); -const module_type_classifier_1 = __nccwpck_require__(26705); -const resolver_functions_1 = __nccwpck_require__(59765); -const cjs_resolve_hooks_1 = __nccwpck_require__(26972); -const node_module_type_classifier_1 = __nccwpck_require__(59503); -const file_extensions_1 = __nccwpck_require__(50872); -const ts_transpile_module_1 = __nccwpck_require__(72598); -var repl_1 = __nccwpck_require__(45890); -Object.defineProperty(exports, "createRepl", ({ enumerable: true, get: function () { return repl_1.createRepl; } })); -/** - * Does this version of node obey the package.json "type" field - * and throw ERR_REQUIRE_ESM when attempting to require() an ESM modules. - */ -const engineSupportsPackageTypeField = parseInt(process.versions.node.split('.')[0], 10) >= 12; -/** - * Assert that script can be loaded as CommonJS when we attempt to require it. - * If it should be loaded as ESM, throw ERR_REQUIRE_ESM like node does. - * - * Loaded conditionally so we don't need to support older node versions - */ -let assertScriptCanLoadAsCJS = engineSupportsPackageTypeField - ? (__nccwpck_require__(11717).assertScriptCanLoadAsCJSImpl) - : () => { - /* noop */ + // src/compiler/semver.ts + function tryParseComponents(text) { + const match = versionRegExp.exec(text); + if (!match) + return void 0; + const [, major, minor = "0", patch = "0", prerelease = "", build2 = ""] = match; + if (prerelease && !prereleaseRegExp.test(prerelease)) + return void 0; + if (build2 && !buildRegExp.test(build2)) + return void 0; + return { + major: parseInt(major, 10), + minor: parseInt(minor, 10), + patch: parseInt(patch, 10), + prerelease, + build: build2 }; -/** - * Registered `ts-node` instance information. - */ -exports.REGISTER_INSTANCE = Symbol.for('ts-node.register.instance'); -/** @internal */ -exports.env = process.env; -/** - * @internal - */ -exports.INSPECT_CUSTOM = util.inspect.custom || 'inspect'; -/** - * Debugging `ts-node`. - */ -const shouldDebug = (0, util_1.yn)(exports.env.TS_NODE_DEBUG); -/** @internal */ -exports.debug = shouldDebug - ? (...args) => console.log(`[ts-node ${new Date().toISOString()}]`, ...args) - : () => undefined; -const debugFn = shouldDebug - ? (key, fn) => { - let i = 0; - return (x) => { - (0, exports.debug)(key, x, ++i); - return fn(x); - }; + } + function comparePrereleaseIdentifiers(left, right) { + if (left === right) + return 0 /* EqualTo */; + if (left.length === 0) + return right.length === 0 ? 0 /* EqualTo */ : 1 /* GreaterThan */; + if (right.length === 0) + return -1 /* LessThan */; + const length2 = Math.min(left.length, right.length); + for (let i = 0; i < length2; i++) { + const leftIdentifier = left[i]; + const rightIdentifier = right[i]; + if (leftIdentifier === rightIdentifier) + continue; + const leftIsNumeric = numericIdentifierRegExp.test(leftIdentifier); + const rightIsNumeric = numericIdentifierRegExp.test(rightIdentifier); + if (leftIsNumeric || rightIsNumeric) { + if (leftIsNumeric !== rightIsNumeric) + return leftIsNumeric ? -1 /* LessThan */ : 1 /* GreaterThan */; + const result = compareValues(+leftIdentifier, +rightIdentifier); + if (result) + return result; + } else { + const result = compareStringsCaseSensitive(leftIdentifier, rightIdentifier); + if (result) + return result; + } } - : (_, fn) => fn; -/** - * Export the current version. - */ -exports.VERSION = __nccwpck_require__(46686).version; -/** - * Default register options, including values specified via environment - * variables. - * @internal - */ -exports.DEFAULTS = { - cwd: (_a = exports.env.TS_NODE_CWD) !== null && _a !== void 0 ? _a : exports.env.TS_NODE_DIR, - emit: (0, util_1.yn)(exports.env.TS_NODE_EMIT), - scope: (0, util_1.yn)(exports.env.TS_NODE_SCOPE), - scopeDir: exports.env.TS_NODE_SCOPE_DIR, - files: (0, util_1.yn)(exports.env.TS_NODE_FILES), - pretty: (0, util_1.yn)(exports.env.TS_NODE_PRETTY), - compiler: exports.env.TS_NODE_COMPILER, - compilerOptions: (0, util_1.parse)(exports.env.TS_NODE_COMPILER_OPTIONS), - ignore: (0, util_1.split)(exports.env.TS_NODE_IGNORE), - project: exports.env.TS_NODE_PROJECT, - skipProject: (0, util_1.yn)(exports.env.TS_NODE_SKIP_PROJECT), - skipIgnore: (0, util_1.yn)(exports.env.TS_NODE_SKIP_IGNORE), - preferTsExts: (0, util_1.yn)(exports.env.TS_NODE_PREFER_TS_EXTS), - ignoreDiagnostics: (0, util_1.split)(exports.env.TS_NODE_IGNORE_DIAGNOSTICS), - transpileOnly: (0, util_1.yn)(exports.env.TS_NODE_TRANSPILE_ONLY), - typeCheck: (0, util_1.yn)(exports.env.TS_NODE_TYPE_CHECK), - compilerHost: (0, util_1.yn)(exports.env.TS_NODE_COMPILER_HOST), - logError: (0, util_1.yn)(exports.env.TS_NODE_LOG_ERROR), - experimentalReplAwait: (_b = (0, util_1.yn)(exports.env.TS_NODE_EXPERIMENTAL_REPL_AWAIT)) !== null && _b !== void 0 ? _b : undefined, - tsTrace: console.log.bind(console), -}; -/** - * TypeScript diagnostics error. - */ -class TSError extends make_error_1.BaseError { - constructor(diagnosticText, diagnosticCodes, diagnostics = []) { - super(`⨯ Unable to compile TypeScript:\n${diagnosticText}`); - this.diagnosticCodes = diagnosticCodes; - this.name = 'TSError'; - Object.defineProperty(this, 'diagnosticText', { - configurable: true, - writable: true, - value: diagnosticText, - }); - Object.defineProperty(this, 'diagnostics', { - configurable: true, - writable: true, - value: diagnostics, - }); + return compareValues(left.length, right.length); + } + function parseRange(text) { + const alternatives = []; + for (let range of text.trim().split(logicalOrRegExp)) { + if (!range) + continue; + const comparators = []; + range = range.trim(); + const match = hyphenRegExp.exec(range); + if (match) { + if (!parseHyphen(match[1], match[2], comparators)) + return void 0; + } else { + for (const simple of range.split(whitespaceRegExp)) { + const match2 = rangeRegExp.exec(simple.trim()); + if (!match2 || !parseComparator(match2[1], match2[2], comparators)) + return void 0; + } + } + alternatives.push(comparators); } - /** - * @internal - */ - [exports.INSPECT_CUSTOM]() { - return this.diagnosticText; + return alternatives; + } + function parsePartial(text) { + const match = partialRegExp.exec(text); + if (!match) + return void 0; + const [, major, minor = "*", patch = "*", prerelease, build2] = match; + const version2 = new Version( + isWildcard(major) ? 0 : parseInt(major, 10), + isWildcard(major) || isWildcard(minor) ? 0 : parseInt(minor, 10), + isWildcard(major) || isWildcard(minor) || isWildcard(patch) ? 0 : parseInt(patch, 10), + prerelease, + build2 + ); + return { version: version2, major, minor, patch }; + } + function parseHyphen(left, right, comparators) { + const leftResult = parsePartial(left); + if (!leftResult) + return false; + const rightResult = parsePartial(right); + if (!rightResult) + return false; + if (!isWildcard(leftResult.major)) { + comparators.push(createComparator(">=", leftResult.version)); } -} -exports.TSError = TSError; -const TS_NODE_SERVICE_BRAND = Symbol('TS_NODE_SERVICE_BRAND'); -function register(serviceOrOpts) { - // Is this a Service or a RegisterOptions? - let service = serviceOrOpts; - if (!(serviceOrOpts === null || serviceOrOpts === void 0 ? void 0 : serviceOrOpts[TS_NODE_SERVICE_BRAND])) { - // Not a service; is options - service = create((serviceOrOpts !== null && serviceOrOpts !== void 0 ? serviceOrOpts : {})); + if (!isWildcard(rightResult.major)) { + comparators.push( + isWildcard(rightResult.minor) ? createComparator("<", rightResult.version.increment("major")) : isWildcard(rightResult.patch) ? createComparator("<", rightResult.version.increment("minor")) : createComparator("<=", rightResult.version) + ); } - const originalJsHandler = require.extensions['.js']; - // Expose registered instance globally. - process[exports.REGISTER_INSTANCE] = service; - // Register the extensions. - registerExtensions(service.options.preferTsExts, service.extensions.compiled, service, originalJsHandler); - (0, cjs_resolve_hooks_1.installCommonjsResolveHooksIfNecessary)(service); - // Require specified modules before start-up. - module_1.Module._preloadModules(service.options.require); - return service; -} -exports.register = register; -/** - * Create TypeScript compiler instance. - * - * @category Basic - */ -function create(rawOptions = {}) { - const foundConfigResult = (0, configuration_1.findAndReadConfig)(rawOptions); - return createFromPreloadedConfig(foundConfigResult); -} -exports.create = create; -/** @internal */ -function createFromPreloadedConfig(foundConfigResult) { - var _a, _b, _c, _d; - const { configFilePath, cwd, options, config, compiler, projectLocalResolveDir, optionBasePaths, } = foundConfigResult; - const projectLocalResolveHelper = (0, util_1.createProjectLocalResolveHelper)(projectLocalResolveDir); - const ts = (0, configuration_1.loadCompiler)(compiler); - // Experimental REPL await is not compatible targets lower than ES2018 - const targetSupportsTla = config.options.target >= ts.ScriptTarget.ES2018; - if (options.experimentalReplAwait === true && !targetSupportsTla) { - throw new Error('Experimental REPL await is not compatible with targets lower than ES2018'); + return true; + } + function parseComparator(operator, text, comparators) { + const result = parsePartial(text); + if (!result) + return false; + const { version: version2, major, minor, patch } = result; + if (!isWildcard(major)) { + switch (operator) { + case "~": + comparators.push(createComparator(">=", version2)); + comparators.push(createComparator( + "<", + version2.increment( + isWildcard(minor) ? "major" : "minor" + ) + )); + break; + case "^": + comparators.push(createComparator(">=", version2)); + comparators.push(createComparator( + "<", + version2.increment( + version2.major > 0 || isWildcard(minor) ? "major" : version2.minor > 0 || isWildcard(patch) ? "minor" : "patch" + ) + )); + break; + case "<": + case ">=": + comparators.push( + isWildcard(minor) || isWildcard(patch) ? createComparator(operator, version2.with({ prerelease: "0" })) : createComparator(operator, version2) + ); + break; + case "<=": + case ">": + comparators.push( + isWildcard(minor) ? createComparator(operator === "<=" ? "<" : ">=", version2.increment("major").with({ prerelease: "0" })) : isWildcard(patch) ? createComparator(operator === "<=" ? "<" : ">=", version2.increment("minor").with({ prerelease: "0" })) : createComparator(operator, version2) + ); + break; + case "=": + case void 0: + if (isWildcard(minor) || isWildcard(patch)) { + comparators.push(createComparator(">=", version2.with({ prerelease: "0" }))); + comparators.push(createComparator("<", version2.increment(isWildcard(minor) ? "major" : "minor").with({ prerelease: "0" }))); + } else { + comparators.push(createComparator("=", version2)); + } + break; + default: + return false; + } + } else if (operator === "<" || operator === ">") { + comparators.push(createComparator("<", Version.zero)); } - // Top-level await was added in TS 3.8 - const tsVersionSupportsTla = (0, util_1.versionGteLt)(ts.version, '3.8.0'); - if (options.experimentalReplAwait === true && !tsVersionSupportsTla) { - throw new Error('Experimental REPL await is not compatible with TypeScript versions older than 3.8'); + return true; + } + function isWildcard(part) { + return part === "*" || part === "x" || part === "X"; + } + function createComparator(operator, operand) { + return { operator, operand }; + } + function testDisjunction(version2, alternatives) { + if (alternatives.length === 0) + return true; + for (const alternative of alternatives) { + if (testAlternative(version2, alternative)) + return true; } - const shouldReplAwait = options.experimentalReplAwait !== false && - tsVersionSupportsTla && - targetSupportsTla; - // swc implies two other options - // typeCheck option was implemented specifically to allow overriding tsconfig transpileOnly from the command-line - // So we should allow using typeCheck to override swc - if (options.swc && !options.typeCheck) { - if (options.transpileOnly === false) { - throw new Error("Cannot enable 'swc' option with 'transpileOnly: false'. 'swc' implies 'transpileOnly'."); + return false; + } + function testAlternative(version2, comparators) { + for (const comparator of comparators) { + if (!testComparator(version2, comparator.operator, comparator.operand)) + return false; + } + return true; + } + function testComparator(version2, operator, operand) { + const cmp = version2.compareTo(operand); + switch (operator) { + case "<": + return cmp < 0; + case "<=": + return cmp <= 0; + case ">": + return cmp > 0; + case ">=": + return cmp >= 0; + case "=": + return cmp === 0; + default: + return Debug.assertNever(operator); + } + } + function formatDisjunction(alternatives) { + return map(alternatives, formatAlternative).join(" || ") || "*"; + } + function formatAlternative(comparators) { + return map(comparators, formatComparator).join(" "); + } + function formatComparator(comparator) { + return `${comparator.operator}${comparator.operand}`; + } + var versionRegExp, prereleaseRegExp, prereleasePartRegExp, buildRegExp, buildPartRegExp, numericIdentifierRegExp, _Version, Version, VersionRange, logicalOrRegExp, whitespaceRegExp, partialRegExp, hyphenRegExp, rangeRegExp; + var init_semver = __esm({ + "src/compiler/semver.ts"() { + "use strict"; + init_ts2(); + versionRegExp = /^(0|[1-9]\d*)(?:\.(0|[1-9]\d*)(?:\.(0|[1-9]\d*)(?:-([a-z0-9-.]+))?(?:\+([a-z0-9-.]+))?)?)?$/i; + prereleaseRegExp = /^(?:0|[1-9]\d*|[a-z-][a-z0-9-]*)(?:\.(?:0|[1-9]\d*|[a-z-][a-z0-9-]*))*$/i; + prereleasePartRegExp = /^(?:0|[1-9]\d*|[a-z-][a-z0-9-]*)$/i; + buildRegExp = /^[a-z0-9-]+(?:\.[a-z0-9-]+)*$/i; + buildPartRegExp = /^[a-z0-9-]+$/i; + numericIdentifierRegExp = /^(0|[1-9]\d*)$/; + _Version = class _Version { + constructor(major, minor = 0, patch = 0, prerelease = "", build2 = "") { + if (typeof major === "string") { + const result = Debug.checkDefined(tryParseComponents(major), "Invalid version"); + ({ major, minor, patch, prerelease, build: build2 } = result); + } + Debug.assert(major >= 0, "Invalid argument: major"); + Debug.assert(minor >= 0, "Invalid argument: minor"); + Debug.assert(patch >= 0, "Invalid argument: patch"); + const prereleaseArray = prerelease ? isArray(prerelease) ? prerelease : prerelease.split(".") : emptyArray; + const buildArray = build2 ? isArray(build2) ? build2 : build2.split(".") : emptyArray; + Debug.assert(every(prereleaseArray, (s) => prereleasePartRegExp.test(s)), "Invalid argument: prerelease"); + Debug.assert(every(buildArray, (s) => buildPartRegExp.test(s)), "Invalid argument: build"); + this.major = major; + this.minor = minor; + this.patch = patch; + this.prerelease = prereleaseArray; + this.build = buildArray; } - if (options.transpiler) { - throw new Error("Cannot specify both 'swc' and 'transpiler' options. 'swc' uses the built-in swc transpiler."); + static tryParse(text) { + const result = tryParseComponents(text); + if (!result) + return void 0; + const { major, minor, patch, prerelease, build: build2 } = result; + return new _Version(major, minor, patch, prerelease, build2); + } + compareTo(other) { + if (this === other) + return 0 /* EqualTo */; + if (other === void 0) + return 1 /* GreaterThan */; + return compareValues(this.major, other.major) || compareValues(this.minor, other.minor) || compareValues(this.patch, other.patch) || comparePrereleaseIdentifiers(this.prerelease, other.prerelease); + } + increment(field) { + switch (field) { + case "major": + return new _Version(this.major + 1, 0, 0); + case "minor": + return new _Version(this.major, this.minor + 1, 0); + case "patch": + return new _Version(this.major, this.minor, this.patch + 1); + default: + return Debug.assertNever(field); + } + } + with(fields) { + const { + major = this.major, + minor = this.minor, + patch = this.patch, + prerelease = this.prerelease, + build: build2 = this.build + } = fields; + return new _Version(major, minor, patch, prerelease, build2); + } + toString() { + let result = `${this.major}.${this.minor}.${this.patch}`; + if (some(this.prerelease)) + result += `-${this.prerelease.join(".")}`; + if (some(this.build)) + result += `+${this.build.join(".")}`; + return result; + } + }; + _Version.zero = new _Version(0, 0, 0, ["0"]); + Version = _Version; + VersionRange = class _VersionRange { + constructor(spec) { + this._alternatives = spec ? Debug.checkDefined(parseRange(spec), "Invalid range spec.") : emptyArray; + } + static tryParse(text) { + const sets = parseRange(text); + if (sets) { + const range = new _VersionRange(""); + range._alternatives = sets; + return range; + } + return void 0; + } + /** + * Tests whether a version matches the range. This is equivalent to `satisfies(version, range, { includePrerelease: true })`. + * in `node-semver`. + */ + test(version2) { + if (typeof version2 === "string") + version2 = new Version(version2); + return testDisjunction(version2, this._alternatives); + } + toString() { + return formatDisjunction(this._alternatives); + } + }; + logicalOrRegExp = /\|\|/g; + whitespaceRegExp = /\s+/g; + partialRegExp = /^([xX*0]|[1-9]\d*)(?:\.([xX*0]|[1-9]\d*)(?:\.([xX*0]|[1-9]\d*)(?:-([a-z0-9-.]+))?(?:\+([a-z0-9-.]+))?)?)?$/i; + hyphenRegExp = /^\s*([a-z0-9-+.*]+)\s+-\s+([a-z0-9-+.*]+)\s*$/i; + rangeRegExp = /^(~|\^|<|<=|>|>=|=)?\s*([a-z0-9-+.*]+)$/i; + } + }); + + // src/compiler/performanceCore.ts + function hasRequiredAPI(performance2, PerformanceObserver2) { + return typeof performance2 === "object" && typeof performance2.timeOrigin === "number" && typeof performance2.mark === "function" && typeof performance2.measure === "function" && typeof performance2.now === "function" && typeof performance2.clearMarks === "function" && typeof performance2.clearMeasures === "function" && typeof PerformanceObserver2 === "function"; + } + function tryGetWebPerformanceHooks() { + if (typeof performance === "object" && typeof PerformanceObserver === "function" && hasRequiredAPI(performance, PerformanceObserver)) { + return { + // For now we always write native performance events when running in the browser. We may + // make this conditional in the future if we find that native web performance hooks + // in the browser also slow down compilation. + shouldWriteNativeEvents: true, + performance, + PerformanceObserver + }; + } + } + function tryGetNodePerformanceHooks() { + if (isNodeLikeSystem()) { + try { + const { performance: performance2, PerformanceObserver: PerformanceObserver2 } = __nccwpck_require__(4074); + if (hasRequiredAPI(performance2, PerformanceObserver2)) { + return { + // By default, only write native events when generating a cpu profile or using the v8 profiler. + shouldWriteNativeEvents: false, + performance: performance2, + PerformanceObserver: PerformanceObserver2 + }; } + } catch { + } } - const readFile = options.readFile || ts.sys.readFile; - const fileExists = options.fileExists || ts.sys.fileExists; - // typeCheck can override transpileOnly, useful for CLI flag to override config file - const transpileOnly = (options.transpileOnly === true || options.swc === true) && - options.typeCheck !== true; - let transpiler = undefined; - let transpilerBasePath = undefined; - if (options.transpiler) { - transpiler = options.transpiler; - transpilerBasePath = optionBasePaths.transpiler; + } + function tryGetNativePerformanceHooks() { + return nativePerformanceHooks; + } + var nativePerformanceHooks, nativePerformance, timestamp; + var init_performanceCore = __esm({ + "src/compiler/performanceCore.ts"() { + "use strict"; + init_ts2(); + nativePerformanceHooks = tryGetWebPerformanceHooks() || tryGetNodePerformanceHooks(); + nativePerformance = nativePerformanceHooks == null ? void 0 : nativePerformanceHooks.performance; + timestamp = nativePerformance ? () => nativePerformance.now() : Date.now ? Date.now : () => +/* @__PURE__ */ new Date(); } - else if (options.swc) { - transpiler = __nccwpck_require__.ab + "swc.js"; - transpilerBasePath = optionBasePaths.swc; + }); + + // src/compiler/perfLogger.ts + var etwModule, perfLogger; + var init_perfLogger = __esm({ + "src/compiler/perfLogger.ts"() { + "use strict"; + try { + const etwModulePath = process.env.TS_ETW_MODULE_PATH ?? "./node_modules/@microsoft/typescript-etw"; + etwModule = require(etwModulePath); + } catch (e) { + etwModule = void 0; + } + perfLogger = (etwModule == null ? void 0 : etwModule.logEvent) ? etwModule : void 0; } - const transformers = options.transformers || undefined; - const diagnosticFilters = [ - { - appliesToAllFiles: true, - filenamesAbsolute: [], - diagnosticsIgnored: [ - 6059, - 18002, - 18003, - ...(options.experimentalTsImportSpecifiers - ? [ - 2691, // "An import path cannot end with a '.ts' extension. Consider importing '' instead." - ] - : []), - ...(options.ignoreDiagnostics || []), - ].map(Number), - }, - ]; - const configDiagnosticList = filterDiagnostics(config.errors, diagnosticFilters); - const outputCache = new Map(); - const configFileDirname = configFilePath ? (0, path_1.dirname)(configFilePath) : null; - const scopeDir = (_c = (_b = (_a = options.scopeDir) !== null && _a !== void 0 ? _a : config.options.rootDir) !== null && _b !== void 0 ? _b : configFileDirname) !== null && _c !== void 0 ? _c : cwd; - const ignoreBaseDir = configFileDirname !== null && configFileDirname !== void 0 ? configFileDirname : cwd; - const isScoped = options.scope - ? (fileName) => (0, path_1.relative)(scopeDir, fileName).charAt(0) !== '.' - : () => true; - const shouldIgnore = createIgnore(ignoreBaseDir, options.skipIgnore - ? [] - : (options.ignore || ['(?:^|/)node_modules/']).map((str) => new RegExp(str))); - const diagnosticHost = { - getNewLine: () => ts.sys.newLine, - getCurrentDirectory: () => cwd, - // TODO switch to getCanonicalFileName we already create later in scope - getCanonicalFileName: ts.sys.useCaseSensitiveFileNames - ? (x) => x - : (x) => x.toLowerCase(), + }); + + // src/compiler/performance.ts + function createTimerIf(condition, measureName, startMarkName, endMarkName) { + return condition ? createTimer(measureName, startMarkName, endMarkName) : nullTimer; + } + function createTimer(measureName, startMarkName, endMarkName) { + let enterCount = 0; + return { + enter, + exit }; - if (options.transpileOnly && typeof transformers === 'function') { - throw new TypeError('Transformers function is unavailable in "--transpile-only"'); + function enter() { + if (++enterCount === 1) { + mark(startMarkName); + } } - let createTranspiler = initializeTranspilerFactory(); - function initializeTranspilerFactory() { - var _a; - if (__nccwpck_require__.ab + "swc.js") { - if (!transpileOnly) - throw new Error('Custom transpiler can only be used when transpileOnly is enabled.'); - const transpilerName = typeof transpiler === 'string' ? transpiler : transpiler[0]; - const transpilerOptions = typeof transpiler === 'string' ? {} : (_a = transpiler[1]) !== null && _a !== void 0 ? _a : {}; - const transpilerConfigLocalResolveHelper = transpilerBasePath - ? (0, util_1.createProjectLocalResolveHelper)(transpilerBasePath) - : projectLocalResolveHelper; - const transpilerPath = transpilerConfigLocalResolveHelper(transpilerName, true); - const transpilerFactory = __nccwpck_require__(3833)(transpilerPath) - .create; - return createTranspiler; - function createTranspiler(compilerOptions, nodeModuleEmitKind) { - return transpilerFactory === null || transpilerFactory === void 0 ? void 0 : transpilerFactory({ - service: { - options, - config: { - ...config, - options: compilerOptions, - }, - projectLocalResolveHelper, - }, - transpilerConfigLocalResolveHelper, - nodeModuleEmitKind, - ...transpilerOptions, - }); - } - } + function exit() { + if (--enterCount === 0) { + mark(endMarkName); + measure(measureName, startMarkName, endMarkName); + } else if (enterCount < 0) { + Debug.fail("enter/exit count does not match."); + } } - /** - * True if require() hooks should interop with experimental ESM loader. - * Enabled explicitly via a flag since it is a breaking change. - */ - let experimentalEsmLoader = false; - function enableExperimentalEsmLoaderInterop() { - experimentalEsmLoader = true; + } + function mark(markName) { + if (enabled) { + const count = counts.get(markName) ?? 0; + counts.set(markName, count + 1); + marks.set(markName, timestamp()); + performanceImpl == null ? void 0 : performanceImpl.mark(markName); + if (typeof onProfilerEvent === "function") { + onProfilerEvent(markName); + } } - // Install source map support and read from memory cache. - installSourceMapSupport(); - function installSourceMapSupport() { - const sourceMapSupport = __nccwpck_require__(62090); - sourceMapSupport.install({ - environment: 'node', - retrieveFile(pathOrUrl) { - var _a; - let path = pathOrUrl; - // If it's a file URL, convert to local path - // Note: fileURLToPath does not exist on early node v10 - // I could not find a way to handle non-URLs except to swallow an error - if (experimentalEsmLoader && path.startsWith('file://')) { - try { - path = (0, url_1.fileURLToPath)(path); - } - catch (e) { - /* swallow error */ - } - } - path = (0, util_1.normalizeSlashes)(path); - return ((_a = outputCache.get(path)) === null || _a === void 0 ? void 0 : _a.content) || ''; - }, - redirectConflictingLibrary: true, - onConflictingLibraryRedirect(request, parent, isMain, options, redirectedRequest) { - (0, exports.debug)(`Redirected an attempt to require source-map-support to instead receive @cspotcode/source-map-support. "${parent.filename}" attempted to require or resolve "${request}" and was redirected to "${redirectedRequest}".`); - }, - }); + } + function measure(measureName, startMarkName, endMarkName) { + if (enabled) { + const end = (endMarkName !== void 0 ? marks.get(endMarkName) : void 0) ?? timestamp(); + const start = (startMarkName !== void 0 ? marks.get(startMarkName) : void 0) ?? timeorigin; + const previousDuration = durations.get(measureName) || 0; + durations.set(measureName, previousDuration + (end - start)); + performanceImpl == null ? void 0 : performanceImpl.measure(measureName, startMarkName, endMarkName); } - const shouldHavePrettyErrors = options.pretty === undefined ? process.stdout.isTTY : options.pretty; - const formatDiagnostics = shouldHavePrettyErrors - ? ts.formatDiagnosticsWithColorAndContext || ts.formatDiagnostics - : ts.formatDiagnostics; - function createTSError(diagnostics) { - const diagnosticText = formatDiagnostics(diagnostics, diagnosticHost); - const diagnosticCodes = diagnostics.map((x) => x.code); - return new TSError(diagnosticText, diagnosticCodes, diagnostics); + } + function getCount(markName) { + return counts.get(markName) || 0; + } + function getDuration(measureName) { + return durations.get(measureName) || 0; + } + function forEachMeasure(cb) { + durations.forEach((duration, measureName) => cb(measureName, duration)); + } + function forEachMark(cb) { + marks.forEach((_time, markName) => cb(markName)); + } + function clearMeasures(name) { + if (name !== void 0) + durations.delete(name); + else + durations.clear(); + performanceImpl == null ? void 0 : performanceImpl.clearMeasures(name); + } + function clearMarks(name) { + if (name !== void 0) { + counts.delete(name); + marks.delete(name); + } else { + counts.clear(); + marks.clear(); } - function reportTSError(configDiagnosticList) { - const error = createTSError(configDiagnosticList); - if (options.logError) { - // Print error in red color and continue execution. - console.error('\x1b[31m%s\x1b[0m', error); - } - else { - // Throw error and exit the script. - throw error; + performanceImpl == null ? void 0 : performanceImpl.clearMarks(name); + } + function isEnabled() { + return enabled; + } + function enable(system = sys) { + var _a; + if (!enabled) { + enabled = true; + perfHooks || (perfHooks = tryGetNativePerformanceHooks()); + if (perfHooks) { + timeorigin = perfHooks.performance.timeOrigin; + if (perfHooks.shouldWriteNativeEvents || ((_a = system == null ? void 0 : system.cpuProfilingEnabled) == null ? void 0 : _a.call(system)) || (system == null ? void 0 : system.debugMode)) { + performanceImpl = perfHooks.performance; } + } } - // Render the configuration errors. - if (configDiagnosticList.length) - reportTSError(configDiagnosticList); - const jsxEmitPreserve = config.options.jsx === ts.JsxEmit.Preserve; - /** - * Get the extension for a transpiled file. - * [MUST_UPDATE_FOR_NEW_FILE_EXTENSIONS] - */ - function getEmitExtension(path) { - const lastDotIndex = path.lastIndexOf('.'); - if (lastDotIndex >= 0) { - const ext = path.slice(lastDotIndex); - switch (ext) { - case '.js': - case '.ts': - return '.js'; - case '.jsx': - case '.tsx': - return jsxEmitPreserve ? '.jsx' : '.js'; - case '.mjs': - case '.mts': - return '.mjs'; - case '.cjs': - case '.cts': - return '.cjs'; - } - } - return '.js'; + return true; + } + function disable() { + if (enabled) { + marks.clear(); + counts.clear(); + durations.clear(); + performanceImpl = void 0; + enabled = false; } - /** - * Get output from TS compiler w/typechecking. `undefined` in `transpileOnly` - * mode. - */ - let getOutput; - let getTypeInfo; - const getCanonicalFileName = ts.createGetCanonicalFileName(ts.sys.useCaseSensitiveFileNames); - const moduleTypeClassifier = (0, module_type_classifier_1.createModuleTypeClassifier)({ - basePath: (_d = options.optionBasePaths) === null || _d === void 0 ? void 0 : _d.moduleTypes, - patterns: options.moduleTypes, - }); - const extensions = (0, file_extensions_1.getExtensions)(config, options, ts.version); - // Use full language services when the fast option is disabled. - if (!transpileOnly) { - const fileContents = new Map(); - const rootFileNames = new Set(config.fileNames); - const cachedReadFile = (0, util_1.cachedLookup)(debugFn('readFile', readFile)); - // Use language services by default - if (!options.compilerHost) { - let projectVersion = 1; - const fileVersions = new Map(Array.from(rootFileNames).map((fileName) => [fileName, 0])); - const getCustomTransformers = () => { - if (typeof transformers === 'function') { - const program = service.getProgram(); - return program ? transformers(program) : undefined; - } - return transformers; - }; - // Create the compiler host for type checking. - const serviceHost = { - getProjectVersion: () => String(projectVersion), - getScriptFileNames: () => Array.from(rootFileNames), - getScriptVersion: (fileName) => { - const version = fileVersions.get(fileName); - return version ? version.toString() : ''; - }, - getScriptSnapshot(fileName) { - // TODO ordering of this with getScriptVersion? Should they sync up? - let contents = fileContents.get(fileName); - // Read contents into TypeScript memory cache. - if (contents === undefined) { - contents = cachedReadFile(fileName); - if (contents === undefined) - return; - fileVersions.set(fileName, 1); - fileContents.set(fileName, contents); - projectVersion++; - } - return ts.ScriptSnapshot.fromString(contents); - }, - readFile: cachedReadFile, - readDirectory: ts.sys.readDirectory, - getDirectories: (0, util_1.cachedLookup)(debugFn('getDirectories', ts.sys.getDirectories)), - fileExists: (0, util_1.cachedLookup)(debugFn('fileExists', fileExists)), - directoryExists: (0, util_1.cachedLookup)(debugFn('directoryExists', ts.sys.directoryExists)), - realpath: ts.sys.realpath - ? (0, util_1.cachedLookup)(debugFn('realpath', ts.sys.realpath)) - : undefined, - getNewLine: () => ts.sys.newLine, - useCaseSensitiveFileNames: () => ts.sys.useCaseSensitiveFileNames, - getCurrentDirectory: () => cwd, - getCompilationSettings: () => config.options, - getDefaultLibFileName: () => ts.getDefaultLibFilePath(config.options), - getCustomTransformers: getCustomTransformers, - trace: options.tsTrace, - }; - const { resolveModuleNames, getResolvedModuleWithFailedLookupLocationsFromCache, resolveTypeReferenceDirectives, isFileKnownToBeInternal, markBucketOfFilenameInternal, } = (0, resolver_functions_1.createResolverFunctions)({ - host: serviceHost, - getCanonicalFileName, - ts, - cwd, - config, - projectLocalResolveHelper, - options, - extensions, - }); - serviceHost.resolveModuleNames = resolveModuleNames; - serviceHost.getResolvedModuleWithFailedLookupLocationsFromCache = - getResolvedModuleWithFailedLookupLocationsFromCache; - serviceHost.resolveTypeReferenceDirectives = - resolveTypeReferenceDirectives; - const registry = ts.createDocumentRegistry(ts.sys.useCaseSensitiveFileNames, cwd); - const service = ts.createLanguageService(serviceHost, registry); - const updateMemoryCache = (contents, fileName) => { - // Add to `rootFiles` as necessary, either to make TS include a file it has not seen, - // or to trigger a re-classification of files from external to internal. - if (!rootFileNames.has(fileName) && - !isFileKnownToBeInternal(fileName)) { - markBucketOfFilenameInternal(fileName); - rootFileNames.add(fileName); - // Increment project version for every change to rootFileNames. - projectVersion++; - } - const previousVersion = fileVersions.get(fileName) || 0; - const previousContents = fileContents.get(fileName); - // Avoid incrementing cache when nothing has changed. - if (contents !== previousContents) { - fileVersions.set(fileName, previousVersion + 1); - fileContents.set(fileName, contents); - // Increment project version for every file change. - projectVersion++; - } - }; - let previousProgram = undefined; - getOutput = (code, fileName) => { - updateMemoryCache(code, fileName); - const programBefore = service.getProgram(); - if (programBefore !== previousProgram) { - (0, exports.debug)(`compiler rebuilt Program instance when getting output for ${fileName}`); - } - const output = service.getEmitOutput(fileName); - // Get the relevant diagnostics - this is 3x faster than `getPreEmitDiagnostics`. - const diagnostics = service - .getSemanticDiagnostics(fileName) - .concat(service.getSyntacticDiagnostics(fileName)); - const programAfter = service.getProgram(); - (0, exports.debug)('invariant: Is service.getProject() identical before and after getting emit output and diagnostics? (should always be true) ', programBefore === programAfter); - previousProgram = programAfter; - const diagnosticList = filterDiagnostics(diagnostics, diagnosticFilters); - if (diagnosticList.length) - reportTSError(diagnosticList); - if (output.emitSkipped) { - return [undefined, undefined, true]; - } - // Throw an error when requiring `.d.ts` files. - if (output.outputFiles.length === 0) { - throw new TypeError(`Unable to require file: ${(0, path_1.relative)(cwd, fileName)}\n` + - 'This is usually the result of a faulty configuration or import. ' + - 'Make sure there is a `.js`, `.json` or other executable extension with ' + - 'loader attached before `ts-node` available.'); - } - return [output.outputFiles[1].text, output.outputFiles[0].text, false]; - }; - getTypeInfo = (code, fileName, position) => { - const normalizedFileName = (0, util_1.normalizeSlashes)(fileName); - updateMemoryCache(code, normalizedFileName); - const info = service.getQuickInfoAtPosition(normalizedFileName, position); - const name = ts.displayPartsToString(info ? info.displayParts : []); - const comment = ts.displayPartsToString(info ? info.documentation : []); - return { name, comment }; - }; - } - else { - const sys = { - ...ts.sys, - ...diagnosticHost, - readFile: (fileName) => { - const cacheContents = fileContents.get(fileName); - if (cacheContents !== undefined) - return cacheContents; - const contents = cachedReadFile(fileName); - if (contents) - fileContents.set(fileName, contents); - return contents; - }, - readDirectory: ts.sys.readDirectory, - getDirectories: (0, util_1.cachedLookup)(debugFn('getDirectories', ts.sys.getDirectories)), - fileExists: (0, util_1.cachedLookup)(debugFn('fileExists', fileExists)), - directoryExists: (0, util_1.cachedLookup)(debugFn('directoryExists', ts.sys.directoryExists)), - resolvePath: (0, util_1.cachedLookup)(debugFn('resolvePath', ts.sys.resolvePath)), - realpath: ts.sys.realpath - ? (0, util_1.cachedLookup)(debugFn('realpath', ts.sys.realpath)) - : undefined, - }; - const host = ts.createIncrementalCompilerHost - ? ts.createIncrementalCompilerHost(config.options, sys) - : { - ...sys, - getSourceFile: (fileName, languageVersion) => { - const contents = sys.readFile(fileName); - if (contents === undefined) - return; - return ts.createSourceFile(fileName, contents, languageVersion); - }, - getDefaultLibLocation: () => (0, util_1.normalizeSlashes)((0, path_1.dirname)(compiler)), - getDefaultLibFileName: () => (0, util_1.normalizeSlashes)((0, path_1.join)((0, path_1.dirname)(compiler), ts.getDefaultLibFileName(config.options))), - useCaseSensitiveFileNames: () => sys.useCaseSensitiveFileNames, - }; - host.trace = options.tsTrace; - const { resolveModuleNames, resolveTypeReferenceDirectives, isFileKnownToBeInternal, markBucketOfFilenameInternal, } = (0, resolver_functions_1.createResolverFunctions)({ - host, - cwd, - config, - ts, - getCanonicalFileName, - projectLocalResolveHelper, - options, - extensions, - }); - host.resolveModuleNames = resolveModuleNames; - host.resolveTypeReferenceDirectives = resolveTypeReferenceDirectives; - // Fallback for older TypeScript releases without incremental API. - let builderProgram = ts.createIncrementalProgram - ? ts.createIncrementalProgram({ - rootNames: Array.from(rootFileNames), - options: config.options, - host, - configFileParsingDiagnostics: config.errors, - projectReferences: config.projectReferences, - }) - : ts.createEmitAndSemanticDiagnosticsBuilderProgram(Array.from(rootFileNames), config.options, host, undefined, config.errors, config.projectReferences); - // Read and cache custom transformers. - const customTransformers = typeof transformers === 'function' - ? transformers(builderProgram.getProgram()) - : transformers; - // Set the file contents into cache manually. - const updateMemoryCache = (contents, fileName) => { - const previousContents = fileContents.get(fileName); - const contentsChanged = previousContents !== contents; - if (contentsChanged) { - fileContents.set(fileName, contents); - } - // Add to `rootFiles` when discovered by compiler for the first time. - let addedToRootFileNames = false; - if (!rootFileNames.has(fileName) && - !isFileKnownToBeInternal(fileName)) { - markBucketOfFilenameInternal(fileName); - rootFileNames.add(fileName); - addedToRootFileNames = true; - } - // Update program when file changes. - if (addedToRootFileNames || contentsChanged) { - builderProgram = ts.createEmitAndSemanticDiagnosticsBuilderProgram(Array.from(rootFileNames), config.options, host, builderProgram, config.errors, config.projectReferences); - } - }; - getOutput = (code, fileName) => { - let outText = ''; - let outMap = ''; - updateMemoryCache(code, fileName); - const sourceFile = builderProgram.getSourceFile(fileName); - if (!sourceFile) - throw new TypeError(`Unable to read file: ${fileName}`); - const program = builderProgram.getProgram(); - const diagnostics = ts.getPreEmitDiagnostics(program, sourceFile); - const diagnosticList = filterDiagnostics(diagnostics, diagnosticFilters); - if (diagnosticList.length) - reportTSError(diagnosticList); - const result = builderProgram.emit(sourceFile, (path, file, writeByteOrderMark) => { - if (path.endsWith('.map')) { - outMap = file; - } - else { - outText = file; - } - if (options.emit) - sys.writeFile(path, file, writeByteOrderMark); - }, undefined, undefined, customTransformers); - if (result.emitSkipped) { - return [undefined, undefined, true]; - } - // Throw an error when requiring files that cannot be compiled. - if (outText === '') { - if (program.isSourceFileFromExternalLibrary(sourceFile)) { - throw new TypeError(`Unable to compile file from external library: ${(0, path_1.relative)(cwd, fileName)}`); - } - throw new TypeError(`Unable to require file: ${(0, path_1.relative)(cwd, fileName)}\n` + - 'This is usually the result of a faulty configuration or import. ' + - 'Make sure there is a `.js`, `.json` or other executable extension with ' + - 'loader attached before `ts-node` available.'); - } - return [outText, outMap, false]; - }; - getTypeInfo = (code, fileName, position) => { - const normalizedFileName = (0, util_1.normalizeSlashes)(fileName); - updateMemoryCache(code, normalizedFileName); - const sourceFile = builderProgram.getSourceFile(normalizedFileName); - if (!sourceFile) - throw new TypeError(`Unable to read file: ${fileName}`); - const node = getTokenAtPosition(ts, sourceFile, position); - const checker = builderProgram.getProgram().getTypeChecker(); - const symbol = checker.getSymbolAtLocation(node); - if (!symbol) - return { name: '', comment: '' }; - const type = checker.getTypeOfSymbolAtLocation(symbol, node); - const signatures = [ - ...type.getConstructSignatures(), - ...type.getCallSignatures(), - ]; - return { - name: signatures.length - ? signatures.map((x) => checker.signatureToString(x)).join('\n') - : checker.typeToString(type), - comment: ts.displayPartsToString(symbol ? symbol.getDocumentationComment(checker) : []), - }; - }; - // Write `.tsbuildinfo` when `--build` is enabled. - if (options.emit && config.options.incremental) { - process.on('exit', () => { - // Emits `.tsbuildinfo` to filesystem. - builderProgram.getProgram().emitBuildInfo(); - }); - } - } + } + var perfHooks, performanceImpl, nullTimer, enabled, timeorigin, marks, counts, durations; + var init_performance = __esm({ + "src/compiler/performance.ts"() { + "use strict"; + init_ts2(); + nullTimer = { enter: noop, exit: noop }; + enabled = false; + timeorigin = timestamp(); + marks = /* @__PURE__ */ new Map(); + counts = /* @__PURE__ */ new Map(); + durations = /* @__PURE__ */ new Map(); } - else { - getTypeInfo = () => { - throw new TypeError('Type information is unavailable in "--transpile-only"'); - }; + }); + + // src/compiler/_namespaces/ts.performance.ts + var ts_performance_exports = {}; + __export(ts_performance_exports, { + clearMarks: () => clearMarks, + clearMeasures: () => clearMeasures, + createTimer: () => createTimer, + createTimerIf: () => createTimerIf, + disable: () => disable, + enable: () => enable, + forEachMark: () => forEachMark, + forEachMeasure: () => forEachMeasure, + getCount: () => getCount, + getDuration: () => getDuration, + isEnabled: () => isEnabled, + mark: () => mark, + measure: () => measure, + nullTimer: () => nullTimer + }); + var init_ts_performance = __esm({ + "src/compiler/_namespaces/ts.performance.ts"() { + "use strict"; + init_performance(); } - function createTranspileOnlyGetOutputFunction(overrideModuleType, nodeModuleEmitKind) { - const compilerOptions = { ...config.options }; - if (overrideModuleType !== undefined) - compilerOptions.module = overrideModuleType; - let customTranspiler = createTranspiler === null || createTranspiler === void 0 ? void 0 : createTranspiler(compilerOptions, nodeModuleEmitKind); - let tsTranspileModule = (0, util_1.versionGteLt)(ts.version, '4.7.0') - ? (0, ts_transpile_module_1.createTsTranspileModule)(ts, { - compilerOptions, - reportDiagnostics: true, - transformers: transformers, - }) - : undefined; - return (code, fileName) => { - let result; - if (customTranspiler) { - result = customTranspiler.transpile(code, { - fileName, - }); - } - else if (tsTranspileModule) { - result = tsTranspileModule(code, { - fileName, - }, nodeModuleEmitKind === 'nodeesm' ? 'module' : 'commonjs'); - } - else { - result = ts.transpileModule(code, { - fileName, - compilerOptions, - reportDiagnostics: true, - transformers: transformers, - }); + }); + + // src/compiler/tracing.ts + var tracing, tracingEnabled, startTracing, dumpTracingLegend; + var init_tracing = __esm({ + "src/compiler/tracing.ts"() { + "use strict"; + init_ts2(); + init_ts_performance(); + ((tracingEnabled2) => { + let fs; + let traceCount = 0; + let traceFd = 0; + let mode; + const typeCatalog = []; + let legendPath; + const legend = []; + function startTracing2(tracingMode, traceDir, configFilePath) { + Debug.assert(!tracing, "Tracing already started"); + if (fs === void 0) { + try { + fs = __nccwpck_require__(57147); + } catch (e) { + throw new Error(`tracing requires having fs +(original error: ${e.message || e})`); } - const diagnosticList = filterDiagnostics(result.diagnostics || [], diagnosticFilters); - if (diagnosticList.length) - reportTSError(diagnosticList); - return [result.outputText, result.sourceMapText, false]; - }; - } - // When true, these mean that a `moduleType` override will cause a different emit - // than the TypeScript compiler, so we *must* overwrite the emit. - const shouldOverwriteEmitWhenForcingCommonJS = config.options.module !== ts.ModuleKind.CommonJS; - // [MUST_UPDATE_FOR_NEW_MODULEKIND] - const shouldOverwriteEmitWhenForcingEsm = !(config.options.module === ts.ModuleKind.ES2015 || - (ts.ModuleKind.ES2020 && config.options.module === ts.ModuleKind.ES2020) || - (ts.ModuleKind.ES2022 && config.options.module === ts.ModuleKind.ES2022) || - config.options.module === ts.ModuleKind.ESNext); - /** - * node16 or nodenext - * [MUST_UPDATE_FOR_NEW_MODULEKIND] - */ - const isNodeModuleType = (ts.ModuleKind.Node16 && config.options.module === ts.ModuleKind.Node16) || - (ts.ModuleKind.NodeNext && - config.options.module === ts.ModuleKind.NodeNext); - const getOutputForceCommonJS = createTranspileOnlyGetOutputFunction(ts.ModuleKind.CommonJS); - const getOutputForceNodeCommonJS = createTranspileOnlyGetOutputFunction(ts.ModuleKind.NodeNext, 'nodecjs'); - const getOutputForceNodeESM = createTranspileOnlyGetOutputFunction(ts.ModuleKind.NodeNext, 'nodeesm'); - // [MUST_UPDATE_FOR_NEW_MODULEKIND] - const getOutputForceESM = createTranspileOnlyGetOutputFunction(ts.ModuleKind.ES2022 || ts.ModuleKind.ES2020 || ts.ModuleKind.ES2015); - const getOutputTranspileOnly = createTranspileOnlyGetOutputFunction(); - // Create a simple TypeScript compiler proxy. - function compile(code, fileName, lineOffset = 0) { - const normalizedFileName = (0, util_1.normalizeSlashes)(fileName); - const classification = moduleTypeClassifier.classifyModuleByModuleTypeOverrides(normalizedFileName); - let value = ''; - let sourceMap = ''; - let emitSkipped = true; - if (getOutput) { - // Must always call normal getOutput to throw typechecking errors - [value, sourceMap, emitSkipped] = getOutput(code, normalizedFileName); + } + mode = tracingMode; + typeCatalog.length = 0; + if (legendPath === void 0) { + legendPath = combinePaths(traceDir, "legend.json"); + } + if (!fs.existsSync(traceDir)) { + fs.mkdirSync(traceDir, { recursive: true }); + } + const countPart = mode === "build" ? `.${process.pid}-${++traceCount}` : mode === "server" ? `.${process.pid}` : ``; + const tracePath = combinePaths(traceDir, `trace${countPart}.json`); + const typesPath = combinePaths(traceDir, `types${countPart}.json`); + legend.push({ + configFilePath, + tracePath, + typesPath + }); + traceFd = fs.openSync(tracePath, "w"); + tracing = tracingEnabled2; + const meta = { cat: "__metadata", ph: "M", ts: 1e3 * timestamp(), pid: 1, tid: 1 }; + fs.writeSync( + traceFd, + "[\n" + [{ name: "process_name", args: { name: "tsc" }, ...meta }, { name: "thread_name", args: { name: "Main" }, ...meta }, { name: "TracingStartedInBrowser", ...meta, cat: "disabled-by-default-devtools.timeline" }].map((v) => JSON.stringify(v)).join(",\n") + ); } - // If module classification contradicts the above, call the relevant transpiler - if (classification.moduleType === 'cjs' && - (shouldOverwriteEmitWhenForcingCommonJS || emitSkipped)) { - [value, sourceMap] = getOutputForceCommonJS(code, normalizedFileName); + tracingEnabled2.startTracing = startTracing2; + function stopTracing() { + Debug.assert(tracing, "Tracing is not in progress"); + Debug.assert(!!typeCatalog.length === (mode !== "server")); + fs.writeSync(traceFd, ` +] +`); + fs.closeSync(traceFd); + tracing = void 0; + if (typeCatalog.length) { + dumpTypes(typeCatalog); + } else { + legend[legend.length - 1].typesPath = void 0; + } } - else if (classification.moduleType === 'esm' && - (shouldOverwriteEmitWhenForcingEsm || emitSkipped)) { - [value, sourceMap] = getOutputForceESM(code, normalizedFileName); + tracingEnabled2.stopTracing = stopTracing; + function recordType(type) { + if (mode !== "server") { + typeCatalog.push(type); + } } - else if (emitSkipped) { - // Happens when ts compiler skips emit or in transpileOnly mode - const classification = (0, node_module_type_classifier_1.classifyModule)(fileName, isNodeModuleType); - [value, sourceMap] = - classification === 'nodecjs' - ? getOutputForceNodeCommonJS(code, normalizedFileName) - : classification === 'nodeesm' - ? getOutputForceNodeESM(code, normalizedFileName) - : classification === 'cjs' - ? getOutputForceCommonJS(code, normalizedFileName) - : classification === 'esm' - ? getOutputForceESM(code, normalizedFileName) - : getOutputTranspileOnly(code, normalizedFileName); + tracingEnabled2.recordType = recordType; + let Phase; + ((Phase2) => { + Phase2["Parse"] = "parse"; + Phase2["Program"] = "program"; + Phase2["Bind"] = "bind"; + Phase2["Check"] = "check"; + Phase2["CheckTypes"] = "checkTypes"; + Phase2["Emit"] = "emit"; + Phase2["Session"] = "session"; + })(Phase = tracingEnabled2.Phase || (tracingEnabled2.Phase = {})); + function instant(phase, name, args) { + writeEvent("I", phase, name, args, `"s":"g"`); } - const output = updateOutput(value, normalizedFileName, sourceMap, getEmitExtension); - outputCache.set(normalizedFileName, { content: output }); - return output; - } - let active = true; - const enabled = (enabled) => enabled === undefined ? active : (active = !!enabled); - const ignored = (fileName) => { - if (!active) - return true; - const ext = (0, path_1.extname)(fileName); - if (extensions.compiled.includes(ext)) { - return !isScoped(fileName) || shouldIgnore(fileName); + tracingEnabled2.instant = instant; + const eventStack = []; + function push(phase, name, args, separateBeginAndEnd = false) { + if (separateBeginAndEnd) { + writeEvent("B", phase, name, args); + } + eventStack.push({ phase, name, args, time: 1e3 * timestamp(), separateBeginAndEnd }); } - return true; - }; - function addDiagnosticFilter(filter) { - diagnosticFilters.push({ - ...filter, - filenamesAbsolute: filter.filenamesAbsolute.map((f) => (0, util_1.normalizeSlashes)(f)), - }); - } - const getNodeEsmResolver = (0, util_1.once)(() => (__nccwpck_require__(83788).createResolve)({ - extensions, - preferTsExts: options.preferTsExts, - tsNodeExperimentalSpecifierResolution: options.experimentalSpecifierResolution, - })); - const getNodeEsmGetFormat = (0, util_1.once)(() => (__nccwpck_require__(77114).createGetFormat)(options.experimentalSpecifierResolution, getNodeEsmResolver())); - const getNodeCjsLoader = (0, util_1.once)(() => (__nccwpck_require__(11717).createCjsLoader)({ - extensions, - preferTsExts: options.preferTsExts, - nodeEsmResolver: getNodeEsmResolver(), - })); - return { - [TS_NODE_SERVICE_BRAND]: true, - ts, - compilerPath: compiler, - config, - compile, - getTypeInfo, - ignored, - enabled, - options, - configFilePath, - moduleTypeClassifier, - shouldReplAwait, - addDiagnosticFilter, - installSourceMapSupport, - enableExperimentalEsmLoaderInterop, - transpileOnly, - projectLocalResolveHelper, - getNodeEsmResolver, - getNodeEsmGetFormat, - getNodeCjsLoader, - extensions, - }; -} -exports.createFromPreloadedConfig = createFromPreloadedConfig; -/** - * Check if the filename should be ignored. - */ -function createIgnore(ignoreBaseDir, ignore) { - return (fileName) => { - const relname = (0, path_1.relative)(ignoreBaseDir, fileName); - const path = (0, util_1.normalizeSlashes)(relname); - return ignore.some((x) => x.test(path)); - }; -} -/** - * Register the extensions to support when importing files. - */ -function registerExtensions(preferTsExts, extensions, service, originalJsHandler) { - const exts = new Set(extensions); - // Can't add these extensions cuz would allow omitting file extension; node requires ext for .cjs and .mjs - // Unless they're already registered by something else (nyc does this): - // then we *must* hook them or else our transformer will not be called. - for (const cannotAdd of ['.mts', '.cts', '.mjs', '.cjs']) { - if (exts.has(cannotAdd) && !(0, util_1.hasOwnProperty)(require.extensions, cannotAdd)) { - // Unrecognized file exts can be transformed via the `.js` handler. - exts.add('.js'); - exts.delete(cannotAdd); + tracingEnabled2.push = push; + function pop(results) { + Debug.assert(eventStack.length > 0); + writeStackEvent(eventStack.length - 1, 1e3 * timestamp(), results); + eventStack.length--; } - } - // Register new extensions. - for (const ext of exts) { - registerExtension(ext, service, originalJsHandler); - } - if (preferTsExts) { - const preferredExtensions = new Set([ - ...exts, - ...Object.keys(require.extensions), - ]); - // Re-sort iteration order of Object.keys() - for (const ext of preferredExtensions) { - const old = Object.getOwnPropertyDescriptor(require.extensions, ext); - delete require.extensions[ext]; - Object.defineProperty(require.extensions, ext, old); + tracingEnabled2.pop = pop; + function popAll() { + const endTime = 1e3 * timestamp(); + for (let i = eventStack.length - 1; i >= 0; i--) { + writeStackEvent(i, endTime); + } + eventStack.length = 0; } - } -} -/** - * Register the extension for node. - */ -function registerExtension(ext, service, originalHandler) { - const old = require.extensions[ext] || originalHandler; - require.extensions[ext] = function (m, filename) { - if (service.ignored(filename)) - return old(m, filename); - assertScriptCanLoadAsCJS(service, m, filename); - const _compile = m._compile; - m._compile = function (code, fileName) { - (0, exports.debug)('module._compile', fileName); - const result = service.compile(code, fileName); - return _compile.call(this, result, fileName); - }; - return old(m, filename); - }; -} -/** - * Update the output remapping the source map. - */ -function updateOutput(outputText, fileName, sourceMap, getEmitExtension) { - const base64Map = Buffer.from(updateSourceMap(sourceMap, fileName), 'utf8').toString('base64'); - const sourceMapContent = `//# sourceMappingURL=data:application/json;charset=utf-8;base64,${base64Map}`; - // Expected form: `//# sourceMappingURL=foo bar.js.map` or `//# sourceMappingURL=foo%20bar.js.map` for input file "foo bar.tsx" - // Percent-encoding behavior added in TS 4.1.1: https://github.com/microsoft/TypeScript/issues/40951 - const prefix = '//# sourceMappingURL='; - const prefixLength = prefix.length; - const baseName = /*foo.tsx*/ (0, path_1.basename)(fileName); - const extName = /*.tsx*/ (0, path_1.extname)(fileName); - const extension = /*.js*/ getEmitExtension(fileName); - const sourcemapFilename = baseName.slice(0, -extName.length) + extension + '.map'; - const sourceMapLengthWithoutPercentEncoding = prefixLength + sourcemapFilename.length; - /* - * Only rewrite if existing directive exists at the location we expect, to support: - * a) compilers that do not append a sourcemap directive - * b) situations where we did the math wrong - * Not ideal, but appending our sourcemap *after* a pre-existing sourcemap still overrides, so the end-user is happy. - */ - if (outputText.substr(-sourceMapLengthWithoutPercentEncoding, prefixLength) === - prefix) { - return (outputText.slice(0, -sourceMapLengthWithoutPercentEncoding) + - sourceMapContent); - } - // If anyone asks why we're not using URL, the URL equivalent is: `u = new URL('http://d'); u.pathname = "/" + sourcemapFilename; return u.pathname.slice(1); - const sourceMapLengthWithPercentEncoding = prefixLength + encodeURI(sourcemapFilename).length; - if (outputText.substr(-sourceMapLengthWithPercentEncoding, prefixLength) === - prefix) { - return (outputText.slice(0, -sourceMapLengthWithPercentEncoding) + - sourceMapContent); - } - return `${outputText}\n${sourceMapContent}`; -} -/** - * Update the source map contents for improved output. - */ -function updateSourceMap(sourceMapText, fileName) { - const sourceMap = JSON.parse(sourceMapText); - sourceMap.file = fileName; - sourceMap.sources = [fileName]; - delete sourceMap.sourceRoot; - return JSON.stringify(sourceMap); -} -/** - * Filter diagnostics. - */ -function filterDiagnostics(diagnostics, filters) { - return diagnostics.filter((d) => filters.every((f) => { - var _a; - return (!f.appliesToAllFiles && - f.filenamesAbsolute.indexOf((_a = d.file) === null || _a === void 0 ? void 0 : _a.fileName) === -1) || - f.diagnosticsIgnored.indexOf(d.code) === -1; - })); -} -/** - * Get token at file position. - * - * Reference: https://github.com/microsoft/TypeScript/blob/fcd9334f57d85b73dd66ad2d21c02e84822f4841/src/services/utilities.ts#L705-L731 - */ -function getTokenAtPosition(ts, sourceFile, position) { - let current = sourceFile; - outer: while (true) { - for (const child of current.getChildren(sourceFile)) { - const start = child.getFullStart(); - if (start > position) - break; - const end = child.getEnd(); - if (position <= end) { - current = child; - continue outer; - } + tracingEnabled2.popAll = popAll; + const sampleInterval = 1e3 * 10; + function writeStackEvent(index, endTime, results) { + const { phase, name, args, time, separateBeginAndEnd } = eventStack[index]; + if (separateBeginAndEnd) { + Debug.assert(!results, "`results` are not supported for events with `separateBeginAndEnd`"); + writeEvent( + "E", + phase, + name, + args, + /*extras*/ + void 0, + endTime + ); + } else if (sampleInterval - time % sampleInterval <= endTime - time) { + writeEvent("X", phase, name, { ...args, results }, `"dur":${endTime - time}`, time); + } } - return current; - } -} -/** - * Create an implementation of node's ESM loader hooks. - * - * This may be useful if you - * want to wrap or compose the loader hooks to add additional functionality or - * combine with another loader. - * - * Node changed the hooks API, so there are two possible APIs. This function - * detects your node version and returns the appropriate API. - * - * @category ESM Loader - */ -const createEsmHooks = (tsNodeService) => (__nccwpck_require__(13108)/* .createEsmHooks */ .lT)(tsNodeService); -exports.createEsmHooks = createEsmHooks; -//# sourceMappingURL=index.js.map - -/***/ }), - -/***/ 26705: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { - -"use strict"; - -Object.defineProperty(exports, "__esModule", ({ value: true })); -exports.createModuleTypeClassifier = void 0; -const ts_internals_1 = __nccwpck_require__(37432); -const util_1 = __nccwpck_require__(81842); -/** - * @internal - * May receive non-normalized options -- basePath and patterns -- and will normalize them - * internally. - * However, calls to `classifyModule` must pass pre-normalized paths! - */ -function createModuleTypeClassifier(options) { - const { patterns, basePath: _basePath } = options; - const basePath = _basePath !== undefined - ? (0, util_1.normalizeSlashes)(_basePath).replace(/\/$/, '') - : undefined; - const patternTypePairs = Object.entries(patterns !== null && patterns !== void 0 ? patterns : []).map(([_pattern, type]) => { - const pattern = (0, util_1.normalizeSlashes)(_pattern); - return { pattern: parsePattern(basePath, pattern), type }; - }); - const classifications = { - package: { - moduleType: 'auto', - }, - cjs: { - moduleType: 'cjs', - }, - esm: { - moduleType: 'esm', - }, - }; - const auto = classifications.package; - // Passed path must be normalized! - function classifyModuleNonCached(path) { - const matched = matchPatterns(patternTypePairs, (_) => _.pattern, path); - if (matched) - return classifications[matched.type]; - return auto; - } - const classifyModule = (0, util_1.cachedLookup)(classifyModuleNonCached); - function classifyModuleAuto(path) { - return auto; - } - return { - classifyModuleByModuleTypeOverrides: patternTypePairs.length - ? classifyModule - : classifyModuleAuto, - }; -} -exports.createModuleTypeClassifier = createModuleTypeClassifier; -function parsePattern(basePath, patternString) { - const pattern = (0, ts_internals_1.getPatternFromSpec)(patternString, basePath); - return pattern !== undefined ? new RegExp(pattern) : /(?:)/; -} -function matchPatterns(objects, getPattern, candidate) { - for (let i = objects.length - 1; i >= 0; i--) { - const object = objects[i]; - const pattern = getPattern(object); - if (pattern === null || pattern === void 0 ? void 0 : pattern.test(candidate)) { - return object; + function writeEvent(eventType, phase, name, args, extras, time = 1e3 * timestamp()) { + if (mode === "server" && phase === "checkTypes" /* CheckTypes */) + return; + mark("beginTracing"); + fs.writeSync(traceFd, `, +{"pid":1,"tid":1,"ph":"${eventType}","cat":"${phase}","ts":${time},"name":"${name}"`); + if (extras) + fs.writeSync(traceFd, `,${extras}`); + if (args) + fs.writeSync(traceFd, `,"args":${JSON.stringify(args)}`); + fs.writeSync(traceFd, `}`); + mark("endTracing"); + measure("Tracing", "beginTracing", "endTracing"); } - } -} -//# sourceMappingURL=module-type-classifier.js.map - -/***/ }), - -/***/ 59503: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { - -"use strict"; - -Object.defineProperty(exports, "__esModule", ({ value: true })); -exports.classifyModule = void 0; -const node_internal_modules_cjs_loader_1 = __nccwpck_require__(11717); -/** - * Determine how to emit a module based on tsconfig "module" and package.json "type" - * - * Supports module=nodenext/node16 with transpileOnly, where we cannot ask the - * TS typechecker to tell us if a file is CJS or ESM. - * - * Return values indicate: - * - cjs - * - esm - * - nodecjs == node-flavored cjs where dynamic imports are *not* transformed into `require()` - * - undefined == emit according to tsconfig `module` config, whatever that is - * @internal - */ -function classifyModule(nativeFilename, isNodeModuleType) { - // [MUST_UPDATE_FOR_NEW_FILE_EXTENSIONS] - const lastDotIndex = nativeFilename.lastIndexOf('.'); - const ext = lastDotIndex >= 0 ? nativeFilename.slice(lastDotIndex) : ''; - switch (ext) { - case '.cjs': - case '.cts': - return isNodeModuleType ? 'nodecjs' : 'cjs'; - case '.mjs': - case '.mts': - return isNodeModuleType ? 'nodeesm' : 'esm'; - } - if (isNodeModuleType) { - const packageScope = (0, node_internal_modules_cjs_loader_1.readPackageScope)(nativeFilename); - if (packageScope && packageScope.data.type === 'module') - return 'nodeesm'; - return 'nodecjs'; - } - return undefined; -} -exports.classifyModule = classifyModule; -//# sourceMappingURL=node-module-type-classifier.js.map - -/***/ }), - -/***/ 45890: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { - -"use strict"; - -Object.defineProperty(exports, "__esModule", ({ value: true })); -exports.setupContext = exports.createEvalAwarePartialHost = exports.EvalState = exports.createRepl = exports.REPL_NAME = exports.REPL_FILENAME = exports.STDIN_NAME = exports.STDIN_FILENAME = exports.EVAL_NAME = exports.EVAL_FILENAME = void 0; -const os_1 = __nccwpck_require__(22037); -const path_1 = __nccwpck_require__(71017); -const repl_1 = __nccwpck_require__(38102); -const vm_1 = __nccwpck_require__(26144); -const index_1 = __nccwpck_require__(51351); -const fs_1 = __nccwpck_require__(57147); -const console_1 = __nccwpck_require__(96206); -const assert = __nccwpck_require__(39491); -const module_1 = __nccwpck_require__(98188); -// Lazy-loaded. -let _processTopLevelAwait; -function getProcessTopLevelAwait() { - if (_processTopLevelAwait === undefined) { - ({ - processTopLevelAwait: _processTopLevelAwait, - } = __nccwpck_require__(43803)); - } - return _processTopLevelAwait; -} -let diff; -function getDiffLines() { - if (diff === undefined) { - diff = __nccwpck_require__(45604); - } - return diff.diffLines; -} -/** @internal */ -exports.EVAL_FILENAME = `[eval].ts`; -/** @internal */ -exports.EVAL_NAME = `[eval]`; -/** @internal */ -exports.STDIN_FILENAME = `[stdin].ts`; -/** @internal */ -exports.STDIN_NAME = `[stdin]`; -/** @internal */ -exports.REPL_FILENAME = '.ts'; -/** @internal */ -exports.REPL_NAME = ''; -/** - * Create a ts-node REPL instance. - * - * Pay close attention to the example below. Today, the API requires a few lines - * of boilerplate to correctly bind the `ReplService` to the ts-node `Service` and - * vice-versa. - * - * Usage example: - * - * const repl = tsNode.createRepl(); - * const service = tsNode.create({...repl.evalAwarePartialHost}); - * repl.setService(service); - * repl.start(); - * - * @category REPL - */ -function createRepl(options = {}) { - var _a, _b, _c, _d, _e; - const { ignoreDiagnosticsThatAreAnnoyingInInteractiveRepl = true } = options; - let service = options.service; - let nodeReplServer; - // If `useGlobal` is not true, then REPL creates a context when started. - // This stores a reference to it or to `global`, whichever is used, after REPL has started. - let context; - const state = (_a = options.state) !== null && _a !== void 0 ? _a : new EvalState((0, path_1.join)(process.cwd(), exports.REPL_FILENAME)); - const evalAwarePartialHost = createEvalAwarePartialHost(state, options.composeWithEvalAwarePartialHost); - const stdin = (_b = options.stdin) !== null && _b !== void 0 ? _b : process.stdin; - const stdout = (_c = options.stdout) !== null && _c !== void 0 ? _c : process.stdout; - const stderr = (_d = options.stderr) !== null && _d !== void 0 ? _d : process.stderr; - const _console = stdout === process.stdout && stderr === process.stderr - ? console - : new console_1.Console(stdout, stderr); - const replService = { - state: (_e = options.state) !== null && _e !== void 0 ? _e : new EvalState((0, path_1.join)(process.cwd(), exports.EVAL_FILENAME)), - setService, - evalCode, - evalCodeInternal, - nodeEval, - evalAwarePartialHost, - start, - startInternal, - stdin, - stdout, - stderr, - console: _console, - }; - return replService; - function setService(_service) { - service = _service; - if (ignoreDiagnosticsThatAreAnnoyingInInteractiveRepl) { - service.addDiagnosticFilter({ - appliesToAllFiles: false, - filenamesAbsolute: [state.path], - diagnosticsIgnored: [ - 2393, - 6133, - 7027, - ...(service.shouldReplAwait ? topLevelAwaitDiagnosticCodes : []), - ], - }); - } - } - function evalCode(code) { - const result = appendCompileAndEvalInput({ - service: service, - state, - input: code, - context, - overrideIsCompletion: false, - }); - assert(result.containsTopLevelAwait === false); - return result.value; - } - function evalCodeInternal(options) { - const { code, enableTopLevelAwait, context } = options; - return appendCompileAndEvalInput({ - service: service, - state, - input: code, - enableTopLevelAwait, - context, - }); - } - function nodeEval(code, context, _filename, callback) { - // TODO: Figure out how to handle completion here. - if (code === '.scope') { - callback(null); - return; + function getLocation(node) { + const file = getSourceFileOfNode(node); + return !file ? void 0 : { + path: file.path, + start: indexFromOne(getLineAndCharacterOfPosition(file, node.pos)), + end: indexFromOne(getLineAndCharacterOfPosition(file, node.end)) + }; + function indexFromOne(lc) { + return { + line: lc.line + 1, + character: lc.character + 1 + }; + } } - try { - const evalResult = evalCodeInternal({ - code, - enableTopLevelAwait: true, - context, - }); - if (evalResult.containsTopLevelAwait) { - (async () => { - try { - callback(null, await evalResult.valuePromise); - } - catch (promiseError) { - handleError(promiseError); - } - })(); - } - else { - callback(null, evalResult.value); + function dumpTypes(types) { + var _a, _b, _c, _d, _e, _f, _g, _h, _i, _j, _k, _l, _m, _n, _o, _p, _q, _r, _s; + mark("beginDumpTypes"); + const typesPath = legend[legend.length - 1].typesPath; + const typesFd = fs.openSync(typesPath, "w"); + const recursionIdentityMap = /* @__PURE__ */ new Map(); + fs.writeSync(typesFd, "["); + const numTypes = types.length; + for (let i = 0; i < numTypes; i++) { + const type = types[i]; + const objectFlags = type.objectFlags; + const symbol = type.aliasSymbol ?? type.symbol; + let display; + if (objectFlags & 16 /* Anonymous */ | type.flags & 2944 /* Literal */) { + try { + display = (_a = type.checker) == null ? void 0 : _a.typeToString(type); + } catch { + display = void 0; + } } - } - catch (error) { - handleError(error); - } - // Log TSErrors, check if they're recoverable, log helpful hints for certain - // well-known errors, and invoke `callback()` - // TODO should evalCode API get the same error-handling benefits? - function handleError(error) { - var _a, _b; - // Don't show TLA hint if the user explicitly disabled repl top level await - const canLogTopLevelAwaitHint = service.options.experimentalReplAwait !== false && - !service.shouldReplAwait; - if (error instanceof index_1.TSError) { - // Support recoverable compilations using >= node 6. - if (repl_1.Recoverable && isRecoverable(error)) { - callback(new repl_1.Recoverable(error)); - return; - } - else { - _console.error(error); - if (canLogTopLevelAwaitHint && - error.diagnosticCodes.some((dC) => topLevelAwaitDiagnosticCodes.includes(dC))) { - _console.error(getTopLevelAwaitHint()); - } - callback(null); - } + let indexedAccessProperties = {}; + if (type.flags & 8388608 /* IndexedAccess */) { + const indexedAccessType = type; + indexedAccessProperties = { + indexedAccessObjectType: (_b = indexedAccessType.objectType) == null ? void 0 : _b.id, + indexedAccessIndexType: (_c = indexedAccessType.indexType) == null ? void 0 : _c.id + }; } - else { - let _error = error; - if (canLogTopLevelAwaitHint && - _error instanceof SyntaxError && - ((_a = _error.message) === null || _a === void 0 ? void 0 : _a.includes('await is only valid'))) { - try { - // Only way I know to make our hint appear after the error - _error.message += `\n\n${getTopLevelAwaitHint()}`; - _error.stack = (_b = _error.stack) === null || _b === void 0 ? void 0 : _b.replace(/(SyntaxError:.*)/, (_, $1) => `${$1}\n\n${getTopLevelAwaitHint()}`); - } - catch { } - } - callback(_error); + let referenceProperties = {}; + if (objectFlags & 4 /* Reference */) { + const referenceType = type; + referenceProperties = { + instantiatedType: (_d = referenceType.target) == null ? void 0 : _d.id, + typeArguments: (_e = referenceType.resolvedTypeArguments) == null ? void 0 : _e.map((t) => t.id), + referenceLocation: getLocation(referenceType.node) + }; } - } - function getTopLevelAwaitHint() { - return `Hint: REPL top-level await requires TypeScript version 3.8 or higher and target ES2018 or higher. You are using TypeScript ${service.ts.version} and target ${service.ts.ScriptTarget[service.config.options.target]}.`; - } - } - // Note: `code` argument is deprecated - function start(code) { - startInternal({ code }); - } - // Note: `code` argument is deprecated - function startInternal(options) { - const { code, forceToBeModule = true, ...optionsOverride } = options !== null && options !== void 0 ? options : {}; - // TODO assert that `service` is set; remove all `service!` non-null assertions - // Eval incoming code before the REPL starts. - // Note: deprecated - if (code) { - try { - evalCode(`${code}\n`); + let conditionalProperties = {}; + if (type.flags & 16777216 /* Conditional */) { + const conditionalType = type; + conditionalProperties = { + conditionalCheckType: (_f = conditionalType.checkType) == null ? void 0 : _f.id, + conditionalExtendsType: (_g = conditionalType.extendsType) == null ? void 0 : _g.id, + conditionalTrueType: ((_h = conditionalType.resolvedTrueType) == null ? void 0 : _h.id) ?? -1, + conditionalFalseType: ((_i = conditionalType.resolvedFalseType) == null ? void 0 : _i.id) ?? -1 + }; } - catch (err) { - _console.error(err); - // Note: should not be killing the process here, but this codepath is deprecated anyway - process.exit(1); + let substitutionProperties = {}; + if (type.flags & 33554432 /* Substitution */) { + const substitutionType = type; + substitutionProperties = { + substitutionBaseType: (_j = substitutionType.baseType) == null ? void 0 : _j.id, + constraintType: (_k = substitutionType.constraint) == null ? void 0 : _k.id + }; } - } - // In case the typescript compiler hasn't compiled anything yet, - // make it run though compilation at least one time before - // the REPL starts for a snappier user experience on startup. - service === null || service === void 0 ? void 0 : service.compile('', state.path); - const repl = (0, repl_1.start)({ - prompt: '> ', - input: replService.stdin, - output: replService.stdout, - // Mimicking node's REPL implementation: https://github.com/nodejs/node/blob/168b22ba073ee1cbf8d0bcb4ded7ff3099335d04/lib/internal/repl.js#L28-L30 - terminal: stdout.isTTY && - !parseInt(index_1.env.NODE_NO_READLINE, 10), - eval: nodeEval, - useGlobal: true, - ...optionsOverride, - }); - nodeReplServer = repl; - context = repl.context; - // Bookmark the point where we should reset the REPL state. - const resetEval = appendToEvalState(state, ''); - function reset() { - resetEval(); - // Hard fix for TypeScript forcing `Object.defineProperty(exports, ...)`. - runInContext('exports = module.exports', state.path, context); - if (forceToBeModule) { - state.input += 'export {};void 0;\n'; + let reverseMappedProperties = {}; + if (objectFlags & 1024 /* ReverseMapped */) { + const reverseMappedType = type; + reverseMappedProperties = { + reverseMappedSourceType: (_l = reverseMappedType.source) == null ? void 0 : _l.id, + reverseMappedMappedType: (_m = reverseMappedType.mappedType) == null ? void 0 : _m.id, + reverseMappedConstraintType: (_n = reverseMappedType.constraintType) == null ? void 0 : _n.id + }; } - // Declare node builtins. - // Skip the same builtins as `addBuiltinLibsToObject`: - // those starting with _ - // those containing / - // those that already exist as globals - // Intentionally suppress type errors in case @types/node does not declare any of them, and because - // `declare import` is technically invalid syntax. - // Avoid this when in transpileOnly, because third-party transpilers may not handle `declare import`. - if (!(service === null || service === void 0 ? void 0 : service.transpileOnly)) { - state.input += `// @ts-ignore\n${module_1.builtinModules - .filter((name) => !name.startsWith('_') && - !name.includes('/') && - !['console', 'module', 'process'].includes(name)) - .map((name) => `declare import ${name} = require('${name}')`) - .join(';')}\n`; + let evolvingArrayProperties = {}; + if (objectFlags & 256 /* EvolvingArray */) { + const evolvingArrayType = type; + evolvingArrayProperties = { + evolvingArrayElementType: evolvingArrayType.elementType.id, + evolvingArrayFinalType: (_o = evolvingArrayType.finalArrayType) == null ? void 0 : _o.id + }; } - } - reset(); - repl.on('reset', reset); - repl.defineCommand('type', { - help: 'Check the type of a TypeScript identifier', - action: function (identifier) { - if (!identifier) { - repl.displayPrompt(); - return; - } - const undo = appendToEvalState(state, identifier); - const { name, comment } = service.getTypeInfo(state.input, state.path, state.input.length); - undo(); - if (name) - repl.outputStream.write(`${name}\n`); - if (comment) - repl.outputStream.write(`${comment}\n`); - repl.displayPrompt(); - }, - }); - // Set up REPL history when available natively via node.js >= 11. - if (repl.setupHistory) { - const historyPath = index_1.env.TS_NODE_HISTORY || (0, path_1.join)((0, os_1.homedir)(), '.ts_node_repl_history'); - repl.setupHistory(historyPath, (err) => { - if (!err) - return; - _console.error(err); - process.exit(1); - }); - } - return repl; - } -} -exports.createRepl = createRepl; -/** - * Eval state management. Stores virtual `[eval].ts` file - */ -class EvalState { - constructor(path) { - this.path = path; - /** @internal */ - this.input = ''; - /** @internal */ - this.output = ''; - /** @internal */ - this.version = 0; - /** @internal */ - this.lines = 0; - } -} -exports.EvalState = EvalState; -function createEvalAwarePartialHost(state, composeWith) { - function readFile(path) { - if (path === state.path) - return state.input; - if (composeWith === null || composeWith === void 0 ? void 0 : composeWith.readFile) - return composeWith.readFile(path); - try { - return (0, fs_1.readFileSync)(path, 'utf8'); - } - catch (err) { - /* Ignore. */ - } - } - function fileExists(path) { - if (path === state.path) - return true; - if (composeWith === null || composeWith === void 0 ? void 0 : composeWith.fileExists) - return composeWith.fileExists(path); - try { - const stats = (0, fs_1.statSync)(path); - return stats.isFile() || stats.isFIFO(); - } - catch (err) { - return false; - } - } - return { readFile, fileExists }; -} -exports.createEvalAwarePartialHost = createEvalAwarePartialHost; -const sourcemapCommentRe = /\/\/# ?sourceMappingURL=\S+[\s\r\n]*$/; -/** - * Evaluate the code snippet. - * - * Append it to virtual .ts file, compile, handle compiler errors, compute a diff of the JS, and eval any code that - * appears as "added" in the diff. - */ -function appendCompileAndEvalInput(options) { - const { service, state, wrappedErr, enableTopLevelAwait = false, context, overrideIsCompletion, } = options; - let { input } = options; - // It's confusing for `{ a: 1 }` to be interpreted as a block statement - // rather than an object literal. So, we first try to wrap it in - // parentheses, so that it will be interpreted as an expression. - // Based on https://github.com/nodejs/node/blob/c2e6822153bad023ab7ebd30a6117dcc049e475c/lib/repl.js#L413-L422 - let wrappedCmd = false; - if (!wrappedErr && /^\s*{/.test(input) && !/;\s*$/.test(input)) { - input = `(${input.trim()})\n`; - wrappedCmd = true; - } - const lines = state.lines; - const isCompletion = overrideIsCompletion !== null && overrideIsCompletion !== void 0 ? overrideIsCompletion : !/\n$/.test(input); - const undo = appendToEvalState(state, input); - let output; - // Based on https://github.com/nodejs/node/blob/92573721c7cff104ccb82b6ed3e8aa69c4b27510/lib/repl.js#L457-L461 - function adjustUseStrict(code) { - // "void 0" keeps the repl from returning "use strict" as the result - // value for statements and declarations that don't return a value. - return code.replace(/^"use strict";/, '"use strict"; void 0;'); - } - try { - output = service.compile(state.input, state.path, -lines); - } - catch (err) { - undo(); - if (wrappedCmd) { - if (err instanceof index_1.TSError && err.diagnosticCodes[0] === 2339) { - // Ensure consistent and more sane behavior between { a: 1 }['b'] and ({ a: 1 }['b']) - throw err; + let recursionToken; + const recursionIdentity = type.checker.getRecursionIdentity(type); + if (recursionIdentity) { + recursionToken = recursionIdentityMap.get(recursionIdentity); + if (!recursionToken) { + recursionToken = recursionIdentityMap.size; + recursionIdentityMap.set(recursionIdentity, recursionToken); + } } - // Unwrap and try again - return appendCompileAndEvalInput({ - ...options, - wrappedErr: err, - }); - } - if (wrappedErr) - throw wrappedErr; - throw err; - } - output = adjustUseStrict(output); - // Note: REPL does not respect sourcemaps! - // To properly do that, we'd need to prefix the code we eval -- which comes - // from `diffLines` -- with newlines so that it's at the proper line numbers. - // Then we'd need to ensure each bit of eval-ed code, if there are multiples, - // has the sourcemap appended to it. - // We might also need to integrate with our sourcemap hooks' cache; I'm not sure. - const outputWithoutSourcemapComment = output.replace(sourcemapCommentRe, ''); - const oldOutputWithoutSourcemapComment = state.output.replace(sourcemapCommentRe, ''); - // Use `diff` to check for new JavaScript to execute. - const changes = getDiffLines()(oldOutputWithoutSourcemapComment, outputWithoutSourcemapComment); - if (isCompletion) { - undo(); - } - else { - state.output = output; - // Insert a semicolon to make sure that the code doesn't interact with the next line, - // for example to prevent `2\n+ 2` from producing 4. - // This is safe since the output will not change since we can only get here with successful inputs, - // and adding a semicolon to the end of a successful input won't ever change the output. - state.input = state.input.replace(/([^\n\s])([\n\s]*)$/, (all, lastChar, whitespace) => { - if (lastChar !== ';') - return `${lastChar};${whitespace}`; - return all; - }); - } - let commands = []; - let containsTopLevelAwait = false; - // Build a list of "commands": bits of JS code in the diff that must be executed. - for (const change of changes) { - if (change.added) { - if (enableTopLevelAwait && - service.shouldReplAwait && - change.value.indexOf('await') > -1) { - const processTopLevelAwait = getProcessTopLevelAwait(); - // Newline prevents comments to mess with wrapper - const wrappedResult = processTopLevelAwait(change.value + '\n'); - if (wrappedResult !== null) { - containsTopLevelAwait = true; - commands.push({ - mustAwait: true, - execCommand: () => runInContext(wrappedResult, state.path, context), - }); - continue; - } + const descriptor = { + id: type.id, + intrinsicName: type.intrinsicName, + symbolName: (symbol == null ? void 0 : symbol.escapedName) && unescapeLeadingUnderscores(symbol.escapedName), + recursionId: recursionToken, + isTuple: objectFlags & 8 /* Tuple */ ? true : void 0, + unionTypes: type.flags & 1048576 /* Union */ ? (_p = type.types) == null ? void 0 : _p.map((t) => t.id) : void 0, + intersectionTypes: type.flags & 2097152 /* Intersection */ ? type.types.map((t) => t.id) : void 0, + aliasTypeArguments: (_q = type.aliasTypeArguments) == null ? void 0 : _q.map((t) => t.id), + keyofType: type.flags & 4194304 /* Index */ ? (_r = type.type) == null ? void 0 : _r.id : void 0, + ...indexedAccessProperties, + ...referenceProperties, + ...conditionalProperties, + ...substitutionProperties, + ...reverseMappedProperties, + ...evolvingArrayProperties, + destructuringPattern: getLocation(type.pattern), + firstDeclaration: getLocation((_s = symbol == null ? void 0 : symbol.declarations) == null ? void 0 : _s[0]), + flags: Debug.formatTypeFlags(type.flags).split("|"), + display + }; + fs.writeSync(typesFd, JSON.stringify(descriptor)); + if (i < numTypes - 1) { + fs.writeSync(typesFd, ",\n"); } - commands.push({ - execCommand: () => runInContext(change.value, state.path, context), - }); - } - } - // Execute all commands asynchronously if necessary, returning the result or a - // promise of the result. - if (containsTopLevelAwait) { - return { - containsTopLevelAwait, - valuePromise: (async () => { - let value; - for (const command of commands) { - const r = command.execCommand(); - value = command.mustAwait ? await r : r; - } - return value; - })(), - }; - } - else { - return { - containsTopLevelAwait: false, - value: commands.reduce((_, c) => c.execCommand(), undefined), - }; - } -} -/** - * Low-level execution of JS code in context - */ -function runInContext(code, filename, context) { - const script = new vm_1.Script(code, { filename }); - if (context === undefined || context === global) { - return script.runInThisContext(); - } - else { - return script.runInContext(context); - } -} -/** - * Append to the eval instance and return an undo function. - */ -function appendToEvalState(state, input) { - const undoInput = state.input; - const undoVersion = state.version; - const undoOutput = state.output; - const undoLines = state.lines; - state.input += input; - state.lines += lineCount(input); - state.version++; - return function () { - state.input = undoInput; - state.output = undoOutput; - state.version = undoVersion; - state.lines = undoLines; - }; -} -/** - * Count the number of lines. - */ -function lineCount(value) { - let count = 0; - for (const char of value) { - if (char === '\n') { - count++; + } + fs.writeSync(typesFd, "]\n"); + fs.closeSync(typesFd); + mark("endDumpTypes"); + measure("Dump types", "beginDumpTypes", "endDumpTypes"); } - } - return count; -} -/** - * TS diagnostic codes which are recoverable, meaning that the user likely entered an incomplete line of code - * and should be prompted for the next. For example, starting a multi-line for() loop and not finishing it. - * null value means code is always recoverable. `Set` means code is only recoverable when occurring alongside at least one - * of the other codes. - */ -const RECOVERY_CODES = new Map([ - [1003, null], - [1005, null], - [1109, null], - [1126, null], - [ - 1136, - new Set([1005]), // happens when typing out an object literal or block scope across multiple lines: '{ foo: 123,' - ], - [1160, null], - [1161, null], - [2355, null], - [2391, null], - [ - 7010, - new Set([1005]), // happens when fn signature spread across multiple lines: 'function a(\nb: any\n) {' - ], -]); -/** - * Diagnostic codes raised when using top-level await. - * These are suppressed when top-level await is enabled. - * When it is *not* enabled, these trigger a helpful hint about enabling top-level await. - */ -const topLevelAwaitDiagnosticCodes = [ - 1375, - 1378, - 1431, - 1432, // Top-level 'for await' loops are only allowed when the 'module' option is set to 'esnext' or 'system', and the 'target' option is set to 'es2017' or higher. -]; -/** - * Check if a function can recover gracefully. - */ -function isRecoverable(error) { - return error.diagnosticCodes.every((code) => { - const deps = RECOVERY_CODES.get(code); - return (deps === null || - (deps && error.diagnosticCodes.some((code) => deps.has(code)))); - }); -} -/** - * @internal - * Set properties on `context` before eval-ing [stdin] or [eval] input. - */ -function setupContext(context, module, filenameAndDirname) { - if (filenameAndDirname) { - context.__dirname = '.'; - context.__filename = `[${filenameAndDirname}]`; - } - context.module = module; - context.exports = module.exports; - context.require = __nccwpck_require__(3833).bind(module); -} -exports.setupContext = setupContext; -//# sourceMappingURL=repl.js.map - -/***/ }), - -/***/ 59765: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { - -"use strict"; - -Object.defineProperty(exports, "__esModule", ({ value: true })); -exports.createResolverFunctions = void 0; -const path_1 = __nccwpck_require__(71017); -/** - * @internal - * In a factory because these are shared across both CompilerHost and LanguageService codepaths - */ -function createResolverFunctions(kwargs) { - const { host, ts, config, cwd, getCanonicalFileName, projectLocalResolveHelper, options, extensions, } = kwargs; - const moduleResolutionCache = ts.createModuleResolutionCache(cwd, getCanonicalFileName, config.options); - const knownInternalFilenames = new Set(); - /** "Buckets" (module directories) whose contents should be marked "internal" */ - const internalBuckets = new Set(); - // Get bucket for a source filename. Bucket is the containing `./node_modules/*/` directory - // For '/project/node_modules/foo/node_modules/bar/lib/index.js' bucket is '/project/node_modules/foo/node_modules/bar/' - // For '/project/node_modules/foo/node_modules/@scope/bar/lib/index.js' bucket is '/project/node_modules/foo/node_modules/@scope/bar/' - const moduleBucketRe = /.*\/node_modules\/(?:@[^\/]+\/)?[^\/]+\//; - function getModuleBucket(filename) { - const find = moduleBucketRe.exec(filename); - if (find) - return find[0]; - return ''; - } - // Mark that this file and all siblings in its bucket should be "internal" - function markBucketOfFilenameInternal(filename) { - internalBuckets.add(getModuleBucket(filename)); - } - function isFileInInternalBucket(filename) { - return internalBuckets.has(getModuleBucket(filename)); - } - function isFileKnownToBeInternal(filename) { - return knownInternalFilenames.has(filename); - } - /** - * If we need to emit JS for a file, force TS to consider it non-external - */ - const fixupResolvedModule = (resolvedModule) => { - const { resolvedFileName } = resolvedModule; - if (resolvedFileName === undefined) + function dumpLegend() { + if (!legendPath) { return; - // [MUST_UPDATE_FOR_NEW_FILE_EXTENSIONS] - // .ts,.mts,.cts is always switched to internal - // .js is switched on-demand - if (resolvedModule.isExternalLibraryImport && - ((resolvedFileName.endsWith('.ts') && - !resolvedFileName.endsWith('.d.ts')) || - (resolvedFileName.endsWith('.cts') && - !resolvedFileName.endsWith('.d.cts')) || - (resolvedFileName.endsWith('.mts') && - !resolvedFileName.endsWith('.d.mts')) || - isFileKnownToBeInternal(resolvedFileName) || - isFileInInternalBucket(resolvedFileName))) { - resolvedModule.isExternalLibraryImport = false; - } - if (!resolvedModule.isExternalLibraryImport) { - knownInternalFilenames.add(resolvedFileName); - } - }; - /* - * NOTE: - * Older ts versions do not pass `redirectedReference` nor `options`. - * We must pass `redirectedReference` to newer ts versions, but cannot rely on `options`, hence the weird argument name - */ - const resolveModuleNames = (moduleNames, containingFile, reusedNames, redirectedReference, optionsOnlyWithNewerTsVersions, containingSourceFile) => { - return moduleNames.map((moduleName, i) => { - var _a, _b; - const mode = containingSourceFile - ? (_b = (_a = ts).getModeForResolutionAtIndex) === null || _b === void 0 ? void 0 : _b.call(_a, containingSourceFile, i) - : undefined; - let { resolvedModule } = ts.resolveModuleName(moduleName, containingFile, config.options, host, moduleResolutionCache, redirectedReference, mode); - if (!resolvedModule && options.experimentalTsImportSpecifiers) { - const lastDotIndex = moduleName.lastIndexOf('.'); - const ext = lastDotIndex >= 0 ? moduleName.slice(lastDotIndex) : ''; - if (ext) { - const replacements = extensions.tsResolverEquivalents.get(ext); - for (const replacementExt of replacements !== null && replacements !== void 0 ? replacements : []) { - ({ resolvedModule } = ts.resolveModuleName(moduleName.slice(0, -ext.length) + replacementExt, containingFile, config.options, host, moduleResolutionCache, redirectedReference, mode)); - if (resolvedModule) - break; - } - } - } - if (resolvedModule) { - fixupResolvedModule(resolvedModule); - } - return resolvedModule; - }); - }; - // language service never calls this, but TS docs recommend that we implement it - const getResolvedModuleWithFailedLookupLocationsFromCache = (moduleName, containingFile, resolutionMode) => { - const ret = ts.resolveModuleNameFromCache(moduleName, containingFile, moduleResolutionCache, resolutionMode); - if (ret && ret.resolvedModule) { - fixupResolvedModule(ret.resolvedModule); - } - return ret; - }; - const resolveTypeReferenceDirectives = (typeDirectiveNames, containingFile, redirectedReference, options, containingFileMode // new impliedNodeFormat is accepted by compilerHost - ) => { - // Note: seems to be called with empty typeDirectiveNames array for all files. - // TODO consider using `ts.loadWithTypeDirectiveCache` - return typeDirectiveNames.map((typeDirectiveName) => { - // Copy-pasted from TS source: - const nameIsString = typeof typeDirectiveName === 'string'; - const mode = nameIsString - ? undefined - : ts.getModeForFileReference(typeDirectiveName, containingFileMode); - const strName = nameIsString - ? typeDirectiveName - : typeDirectiveName.fileName.toLowerCase(); - let { resolvedTypeReferenceDirective } = ts.resolveTypeReferenceDirective(strName, containingFile, config.options, host, redirectedReference, undefined, mode); - if (typeDirectiveName === 'node' && !resolvedTypeReferenceDirective) { - // Resolve @types/node relative to project first, then __dirname (copy logic from elsewhere / refactor into reusable function) - let typesNodePackageJsonPath; - try { - typesNodePackageJsonPath = projectLocalResolveHelper('@types/node/package.json', true); - } - catch { } // gracefully do nothing when @types/node is not installed for any reason - if (typesNodePackageJsonPath) { - const typeRoots = [(0, path_1.resolve)(typesNodePackageJsonPath, '../..')]; - ({ resolvedTypeReferenceDirective } = - ts.resolveTypeReferenceDirective(typeDirectiveName, containingFile, { - ...config.options, - typeRoots, - }, host, redirectedReference)); - } - } - if (resolvedTypeReferenceDirective) { - fixupResolvedModule(resolvedTypeReferenceDirective); - } - return resolvedTypeReferenceDirective; - }); - }; - return { - resolveModuleNames, - getResolvedModuleWithFailedLookupLocationsFromCache, - resolveTypeReferenceDirectives, - isFileKnownToBeInternal, - markBucketOfFilenameInternal, - }; -} -exports.createResolverFunctions = createResolverFunctions; -//# sourceMappingURL=resolver-functions.js.map - -/***/ }), - -/***/ 37432: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { - -"use strict"; - -Object.defineProperty(exports, "__esModule", ({ value: true })); -exports.getPatternFromSpec = exports.createTsInternals = void 0; -const path_1 = __nccwpck_require__(71017); -const util_1 = __nccwpck_require__(81842); -/** @internal */ -exports.createTsInternals = (0, util_1.cachedLookup)(createTsInternalsUncached); -/** - * Given a reference to the TS compiler, return some TS internal functions that we - * could not or did not want to grab off the `ts` object. - * These have been copy-pasted from TS's source and tweaked as necessary. - * - * NOTE: This factory returns *only* functions which need a reference to the TS - * compiler. Other functions do not need a reference to the TS compiler so are - * exported directly from this file. - */ -function createTsInternalsUncached(_ts) { - const ts = _ts; - /** - * Copied from: - * https://github.com/microsoft/TypeScript/blob/v4.3.2/src/compiler/commandLineParser.ts#L2821-L2846 - */ - function getExtendsConfigPath(extendedConfig, host, basePath, errors, createDiagnostic) { - extendedConfig = (0, util_1.normalizeSlashes)(extendedConfig); - if (isRootedDiskPath(extendedConfig) || - startsWith(extendedConfig, './') || - startsWith(extendedConfig, '../')) { - let extendedConfigPath = getNormalizedAbsolutePath(extendedConfig, basePath); - if (!host.fileExists(extendedConfigPath) && - !endsWith(extendedConfigPath, ts.Extension.Json)) { - extendedConfigPath = `${extendedConfigPath}.json`; - if (!host.fileExists(extendedConfigPath)) { - errors.push(createDiagnostic(ts.Diagnostics.File_0_not_found, extendedConfig)); - return undefined; - } - } - return extendedConfigPath; - } - // If the path isn't a rooted or relative path, resolve like a module - const resolved = ts.nodeModuleNameResolver(extendedConfig, combinePaths(basePath, 'tsconfig.json'), { moduleResolution: ts.ModuleResolutionKind.NodeJs }, host, - /*cache*/ undefined, - /*projectRefs*/ undefined, - /*lookupConfig*/ true); - if (resolved.resolvedModule) { - return resolved.resolvedModule.resolvedFileName; - } - errors.push(createDiagnostic(ts.Diagnostics.File_0_not_found, extendedConfig)); - return undefined; - } - return { getExtendsConfigPath }; -} -// These functions have alternative implementation to avoid copying too much from TS -function isRootedDiskPath(path) { - return (0, path_1.isAbsolute)(path); -} -function combinePaths(path, ...paths) { - return (0, util_1.normalizeSlashes)((0, path_1.resolve)(path, ...paths.filter((path) => path))); -} -function getNormalizedAbsolutePath(fileName, currentDirectory) { - return (0, util_1.normalizeSlashes)(currentDirectory != null - ? (0, path_1.resolve)(currentDirectory, fileName) - : (0, path_1.resolve)(fileName)); -} -function startsWith(str, prefix) { - return str.lastIndexOf(prefix, 0) === 0; -} -function endsWith(str, suffix) { - const expectedPos = str.length - suffix.length; - return expectedPos >= 0 && str.indexOf(suffix, expectedPos) === expectedPos; -} -// Reserved characters, forces escaping of any non-word (or digit), non-whitespace character. -// It may be inefficient (we could just match (/[-[\]{}()*+?.,\\^$|#\s]/g), but this is future -// proof. -const reservedCharacterPattern = /[^\w\s\/]/g; -/** - * @internal - * See also: getRegularExpressionForWildcard, which seems to do almost the same thing - */ -function getPatternFromSpec(spec, basePath) { - const pattern = spec && getSubPatternFromSpec(spec, basePath, excludeMatcher); - return pattern && `^(${pattern})${'($|/)'}`; -} -exports.getPatternFromSpec = getPatternFromSpec; -function getSubPatternFromSpec(spec, basePath, { singleAsteriskRegexFragment, doubleAsteriskRegexFragment, replaceWildcardCharacter, }) { - let subpattern = ''; - let hasWrittenComponent = false; - const components = getNormalizedPathComponents(spec, basePath); - const lastComponent = last(components); - // getNormalizedPathComponents includes the separator for the root component. - // We need to remove to create our regex correctly. - components[0] = removeTrailingDirectorySeparator(components[0]); - if (isImplicitGlob(lastComponent)) { - components.push('**', '*'); - } - let optionalCount = 0; - for (let component of components) { - if (component === '**') { - subpattern += doubleAsteriskRegexFragment; - } - else { - if (hasWrittenComponent) { - subpattern += directorySeparator; - } - subpattern += component.replace(reservedCharacterPattern, replaceWildcardCharacter); - } - hasWrittenComponent = true; - } - while (optionalCount > 0) { - subpattern += ')?'; - optionalCount--; - } - return subpattern; -} -const directoriesMatcher = { - singleAsteriskRegexFragment: '[^/]*', - /** - * Regex for the ** wildcard. Matches any num of subdirectories. When used for including - * files or directories, does not match subdirectories that start with a . character - */ - doubleAsteriskRegexFragment: `(/[^/.][^/]*)*?`, - replaceWildcardCharacter: (match) => replaceWildcardCharacter(match, directoriesMatcher.singleAsteriskRegexFragment), -}; -const excludeMatcher = { - singleAsteriskRegexFragment: '[^/]*', - doubleAsteriskRegexFragment: '(/.+?)?', - replaceWildcardCharacter: (match) => replaceWildcardCharacter(match, excludeMatcher.singleAsteriskRegexFragment), -}; -function getNormalizedPathComponents(path, currentDirectory) { - return reducePathComponents(getPathComponents(path, currentDirectory)); -} -function getPathComponents(path, currentDirectory = '') { - path = combinePaths(currentDirectory, path); - return pathComponents(path, getRootLength(path)); -} -function reducePathComponents(components) { - if (!some(components)) - return []; - const reduced = [components[0]]; - for (let i = 1; i < components.length; i++) { - const component = components[i]; - if (!component) - continue; - if (component === '.') - continue; - if (component === '..') { - if (reduced.length > 1) { - if (reduced[reduced.length - 1] !== '..') { - reduced.pop(); - continue; - } - } - else if (reduced[0]) - continue; + } + fs.writeFileSync(legendPath, JSON.stringify(legend)); } - reduced.push(component); - } - return reduced; -} -function getRootLength(path) { - const rootLength = getEncodedRootLength(path); - return rootLength < 0 ? ~rootLength : rootLength; -} -function getEncodedRootLength(path) { - if (!path) - return 0; - const ch0 = path.charCodeAt(0); - // POSIX or UNC - if (ch0 === 47 /* CharacterCodes.slash */ || ch0 === 92 /* CharacterCodes.backslash */) { - if (path.charCodeAt(1) !== ch0) - return 1; // POSIX: "/" (or non-normalized "\") - const p1 = path.indexOf(ch0 === 47 /* CharacterCodes.slash */ ? directorySeparator : altDirectorySeparator, 2); - if (p1 < 0) - return path.length; // UNC: "//server" or "\\server" - return p1 + 1; // UNC: "//server/" or "\\server\" + tracingEnabled2.dumpLegend = dumpLegend; + })(tracingEnabled || (tracingEnabled = {})); + startTracing = tracingEnabled.startTracing; + dumpTracingLegend = tracingEnabled.dumpLegend; } - // DOS - if (isVolumeCharacter(ch0) && path.charCodeAt(1) === 58 /* CharacterCodes.colon */) { - const ch2 = path.charCodeAt(2); - if (ch2 === 47 /* CharacterCodes.slash */ || ch2 === 92 /* CharacterCodes.backslash */) - return 3; // DOS: "c:/" or "c:\" - if (path.length === 2) - return 2; // DOS: "c:" (but not "c:d") - } - // URL - const schemeEnd = path.indexOf(urlSchemeSeparator); - if (schemeEnd !== -1) { - const authorityStart = schemeEnd + urlSchemeSeparator.length; - const authorityEnd = path.indexOf(directorySeparator, authorityStart); - if (authorityEnd !== -1) { - // URL: "file:///", "file://server/", "file://server/path" - // For local "file" URLs, include the leading DOS volume (if present). - // Per https://www.ietf.org/rfc/rfc1738.txt, a host of "" or "localhost" is a - // special case interpreted as "the machine from which the URL is being interpreted". - const scheme = path.slice(0, schemeEnd); - const authority = path.slice(authorityStart, authorityEnd); - if (scheme === 'file' && - (authority === '' || authority === 'localhost') && - isVolumeCharacter(path.charCodeAt(authorityEnd + 1))) { - const volumeSeparatorEnd = getFileUrlVolumeSeparatorEnd(path, authorityEnd + 2); - if (volumeSeparatorEnd !== -1) { - if (path.charCodeAt(volumeSeparatorEnd) === 47 /* CharacterCodes.slash */) { - // URL: "file:///c:/", "file://localhost/c:/", "file:///c%3a/", "file://localhost/c%3a/" - return ~(volumeSeparatorEnd + 1); - } - if (volumeSeparatorEnd === path.length) { - // URL: "file:///c:", "file://localhost/c:", "file:///c$3a", "file://localhost/c%3a" - // but not "file:///c:d" or "file:///c%3ad" - return ~volumeSeparatorEnd; - } - } - } - return ~(authorityEnd + 1); // URL: "file://server/", "http://server/" - } - return ~path.length; // URL: "file://server", "http://server" - } - // relative - return 0; -} -function ensureTrailingDirectorySeparator(path) { - if (!hasTrailingDirectorySeparator(path)) { - return path + directorySeparator; - } - return path; -} -function hasTrailingDirectorySeparator(path) { - return (path.length > 0 && isAnyDirectorySeparator(path.charCodeAt(path.length - 1))); -} -function isAnyDirectorySeparator(charCode) { - return (charCode === 47 /* CharacterCodes.slash */ || charCode === 92 /* CharacterCodes.backslash */); -} -function removeTrailingDirectorySeparator(path) { - if (hasTrailingDirectorySeparator(path)) { - return path.substr(0, path.length - 1); - } - return path; -} -const directorySeparator = '/'; -const altDirectorySeparator = '\\'; -const urlSchemeSeparator = '://'; -function isVolumeCharacter(charCode) { - return ((charCode >= 97 /* CharacterCodes.a */ && charCode <= 122 /* CharacterCodes.z */) || - (charCode >= 65 /* CharacterCodes.A */ && charCode <= 90 /* CharacterCodes.Z */)); -} -function getFileUrlVolumeSeparatorEnd(url, start) { - const ch0 = url.charCodeAt(start); - if (ch0 === 58 /* CharacterCodes.colon */) - return start + 1; - if (ch0 === 37 /* CharacterCodes.percent */ && - url.charCodeAt(start + 1) === 51 /* CharacterCodes._3 */) { - const ch2 = url.charCodeAt(start + 2); - if (ch2 === 97 /* CharacterCodes.a */ || ch2 === 65 /* CharacterCodes.A */) - return start + 3; - } - return -1; -} -function some(array, predicate) { - if (array) { - if (predicate) { - for (const v of array) { - if (predicate(v)) { - return true; - } - } - } - else { - return array.length > 0; - } - } - return false; -} -function pathComponents(path, rootLength) { - const root = path.substring(0, rootLength); - const rest = path.substring(rootLength).split(directorySeparator); - if (rest.length && !lastOrUndefined(rest)) - rest.pop(); - return [root, ...rest]; -} -function lastOrUndefined(array) { - return array.length === 0 ? undefined : array[array.length - 1]; -} -function last(array) { - // Debug.assert(array.length !== 0); - return array[array.length - 1]; -} -function replaceWildcardCharacter(match, singleAsteriskRegexFragment) { - return match === '*' - ? singleAsteriskRegexFragment - : match === '?' - ? '[^/]' - : '\\' + match; -} -/** - * An "includes" path "foo" is implicitly a glob "foo/** /*" (without the space) if its last component has no extension, - * and does not contain any glob characters itself. - */ -function isImplicitGlob(lastPathComponent) { - return !/[.*?]/.test(lastPathComponent); -} -//# sourceMappingURL=ts-internals.js.map - -/***/ }), - -/***/ 72598: -/***/ ((__unused_webpack_module, exports) => { - -"use strict"; - -Object.defineProperty(exports, "__esModule", ({ value: true })); -exports.createTsTranspileModule = void 0; -/** @internal */ -function createTsTranspileModule(ts, transpileOptions) { - const { createProgram, createSourceFile, getDefaultCompilerOptions, getImpliedNodeFormatForFile, fixupCompilerOptions, transpileOptionValueCompilerOptions, getNewLineCharacter, fileExtensionIs, normalizePath, Debug, toPath, getSetExternalModuleIndicator, getEntries, addRange, hasProperty, getEmitScriptTarget, getDirectoryPath, } = ts; - const compilerOptionsDiagnostics = []; - const options = transpileOptions.compilerOptions - ? fixupCompilerOptions(transpileOptions.compilerOptions, compilerOptionsDiagnostics) - : {}; - // mix in default options - const defaultOptions = getDefaultCompilerOptions(); - for (const key in defaultOptions) { - if (hasProperty(defaultOptions, key) && options[key] === undefined) { - options[key] = defaultOptions[key]; - } - } - for (const option of transpileOptionValueCompilerOptions) { - options[option.name] = option.transpileOptionValue; - } - // transpileModule does not write anything to disk so there is no need to verify that there are no conflicts between input and output paths. - options.suppressOutputPathCheck = true; - // Filename can be non-ts file. - options.allowNonTsExtensions = true; - const newLine = getNewLineCharacter(options); - // Create a compilerHost object to allow the compiler to read and write files - const compilerHost = { - getSourceFile: (fileName) => fileName === normalizePath(inputFileName) ? sourceFile : undefined, - writeFile: (name, text) => { - if (fileExtensionIs(name, '.map')) { - Debug.assertEqual(sourceMapText, undefined, 'Unexpected multiple source map outputs, file:', name); - sourceMapText = text; - } - else { - Debug.assertEqual(outputText, undefined, 'Unexpected multiple outputs, file:', name); - outputText = text; - } - }, - getDefaultLibFileName: () => 'lib.d.ts', - useCaseSensitiveFileNames: () => true, - getCanonicalFileName: (fileName) => fileName, - getCurrentDirectory: () => '', - getNewLine: () => newLine, - fileExists: (fileName) => fileName === inputFileName || fileName === packageJsonFileName, - readFile: (fileName) => fileName === packageJsonFileName ? `{"type": "${_packageJsonType}"}` : '', - directoryExists: () => true, - getDirectories: () => [], - }; - let inputFileName; - let packageJsonFileName; - let _packageJsonType; - let sourceFile; - let outputText; - let sourceMapText; - return transpileModule; - function transpileModule(input, transpileOptions2, packageJsonType = 'commonjs') { - // if jsx is specified then treat file as .tsx - inputFileName = - transpileOptions2.fileName || - (transpileOptions.compilerOptions && transpileOptions.compilerOptions.jsx - ? 'module.tsx' - : 'module.ts'); - packageJsonFileName = getDirectoryPath(inputFileName) + '/package.json'; - _packageJsonType = packageJsonType; - sourceFile = createSourceFile(inputFileName, input, { - languageVersion: getEmitScriptTarget(options), - impliedNodeFormat: getImpliedNodeFormatForFile(toPath(inputFileName, '', compilerHost.getCanonicalFileName), - /*cache*/ undefined, compilerHost, options), - setExternalModuleIndicator: getSetExternalModuleIndicator(options), - }); - if (transpileOptions2.moduleName) { - sourceFile.moduleName = transpileOptions2.moduleName; - } - if (transpileOptions2.renamedDependencies) { - sourceFile.renamedDependencies = new Map(getEntries(transpileOptions2.renamedDependencies)); - } - // Output - outputText = undefined; - sourceMapText = undefined; - const program = createProgram([inputFileName], options, compilerHost); - const diagnostics = compilerOptionsDiagnostics.slice(); - if (transpileOptions.reportDiagnostics) { - addRange( - /*to*/ diagnostics, - /*from*/ program.getSyntacticDiagnostics(sourceFile)); - addRange(/*to*/ diagnostics, /*from*/ program.getOptionsDiagnostics()); - } - // Emit - program.emit( - /*targetSourceFile*/ undefined, - /*writeFile*/ undefined, - /*cancellationToken*/ undefined, - /*emitOnlyDtsFiles*/ undefined, transpileOptions.transformers); - if (outputText === undefined) - return Debug.fail('Output generation failed'); - return { outputText, diagnostics, sourceMapText }; - } -} -exports.createTsTranspileModule = createTsTranspileModule; -//# sourceMappingURL=ts-transpile-module.js.map - -/***/ }), - -/***/ 7518: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { - -"use strict"; - -Object.defineProperty(exports, "__esModule", ({ value: true })); -exports.getDefaultTsconfigJsonForNodeVersion = void 0; -const nodeMajor = parseInt(process.versions.node.split('.')[0], 10); -/** - * return parsed JSON of the bundled @tsconfig/bases config appropriate for the - * running version of nodejs - * @internal - */ -function getDefaultTsconfigJsonForNodeVersion(ts) { - const tsInternal = ts; - if (nodeMajor >= 16) { - const config = __nccwpck_require__(39777); - if (configCompatible(config)) - return config; - } - if (nodeMajor >= 14) { - const config = __nccwpck_require__(83754); - if (configCompatible(config)) - return config; - } - if (nodeMajor >= 12) { - const config = __nccwpck_require__(56049); - if (configCompatible(config)) - return config; - } - return __nccwpck_require__(78250); - // Verify that tsconfig target and lib options are compatible with TypeScript compiler - function configCompatible(config) { - return (typeof ts.ScriptTarget[config.compilerOptions.target.toUpperCase()] === 'number' && - tsInternal.libs && - config.compilerOptions.lib.every((lib) => tsInternal.libs.includes(lib))); - } -} -exports.getDefaultTsconfigJsonForNodeVersion = getDefaultTsconfigJsonForNodeVersion; -//# sourceMappingURL=tsconfigs.js.map - -/***/ }), - -/***/ 81842: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { - -"use strict"; - -var _a; -Object.defineProperty(exports, "__esModule", ({ value: true })); -exports.versionGteLt = exports.once = exports.getBasePathForProjectLocalDependencyResolution = exports.createProjectLocalResolveHelper = exports.attemptRequireWithV8CompileCache = exports.cachedLookup = exports.hasOwnProperty = exports.normalizeSlashes = exports.parse = exports.split = exports.assign = exports.yn = exports.createRequire = void 0; -const module_1 = __nccwpck_require__(98188); -const ynModule = __nccwpck_require__(22287); -const path_1 = __nccwpck_require__(71017); -/** @internal */ -exports.createRequire = (_a = module_1.createRequire !== null && module_1.createRequire !== void 0 ? module_1.createRequire : module_1.createRequireFromPath) !== null && _a !== void 0 ? _a : __nccwpck_require__(6691); -/** - * Wrapper around yn module that returns `undefined` instead of `null`. - * This is implemented by yn v4, but we're staying on v3 to avoid v4's node 10 requirement. - * @internal - */ -function yn(value) { - var _a; - return (_a = ynModule(value)) !== null && _a !== void 0 ? _a : undefined; -} -exports.yn = yn; -/** - * Like `Object.assign`, but ignores `undefined` properties. - * - * @internal - */ -function assign(initialValue, ...sources) { - for (const source of sources) { - for (const key of Object.keys(source)) { - const value = source[key]; - if (value !== undefined) - initialValue[key] = value; - } - } - return initialValue; -} -exports.assign = assign; -/** - * Split a string array of values - * and remove empty strings from the resulting array. - * @internal - */ -function split(value) { - return typeof value === 'string' - ? value.split(/ *, */g).filter((v) => v !== '') - : undefined; -} -exports.split = split; -/** - * Parse a string as JSON. - * @internal - */ -function parse(value) { - return typeof value === 'string' ? JSON.parse(value) : undefined; -} -exports.parse = parse; -const directorySeparator = '/'; -const backslashRegExp = /\\/g; -/** - * Replace backslashes with forward slashes. - * @internal - */ -function normalizeSlashes(value) { - return value.replace(backslashRegExp, directorySeparator); -} -exports.normalizeSlashes = normalizeSlashes; -/** - * Safe `hasOwnProperty` - * @internal - */ -function hasOwnProperty(object, property) { - return Object.prototype.hasOwnProperty.call(object, property); -} -exports.hasOwnProperty = hasOwnProperty; -/** - * Cached fs operation wrapper. - */ -function cachedLookup(fn) { - const cache = new Map(); - return (arg) => { - if (!cache.has(arg)) { - const v = fn(arg); - cache.set(arg, v); - return v; - } - return cache.get(arg); - }; -} -exports.cachedLookup = cachedLookup; -/** - * @internal - * Require something with v8-compile-cache, which should make subsequent requires faster. - * Do lots of error-handling so that, worst case, we require without the cache, and users are not blocked. - */ -function attemptRequireWithV8CompileCache(requireFn, specifier) { - try { - const v8CC = (__nccwpck_require__(25476).install)(); - try { - return requireFn(specifier); - } - finally { - v8CC === null || v8CC === void 0 ? void 0 : v8CC.uninstall(); - } - } - catch (e) { - return requireFn(specifier); - } -} -exports.attemptRequireWithV8CompileCache = attemptRequireWithV8CompileCache; -/** - * Helper to discover dependencies relative to a user's project, optionally - * falling back to relative to ts-node. This supports global installations of - * ts-node, for example where someone does `#!/usr/bin/env -S ts-node --swc` and - * we need to fallback to a global install of @swc/core - * @internal - */ -function createProjectLocalResolveHelper(localDirectory) { - return function projectLocalResolveHelper(specifier, fallbackToTsNodeRelative) { - return require.resolve(specifier, { - paths: fallbackToTsNodeRelative - ? [localDirectory, __dirname] - : [localDirectory], - }); - }; -} -exports.createProjectLocalResolveHelper = createProjectLocalResolveHelper; -/** - * Used as a reminder of all the factors we must consider when finding project-local dependencies and when a config file - * on disk may or may not exist. - * @internal - */ -function getBasePathForProjectLocalDependencyResolution(configFilePath, projectSearchDirOption, projectOption, cwdOption) { - var _a; - if (configFilePath != null) - return (0, path_1.dirname)(configFilePath); - return (_a = projectSearchDirOption !== null && projectSearchDirOption !== void 0 ? projectSearchDirOption : projectOption) !== null && _a !== void 0 ? _a : cwdOption; - // TODO technically breaks if projectOption is path to a file, not a directory, - // and we attempt to resolve relative specifiers. By the time we resolve relative specifiers, - // should have configFilePath, so not reach this codepath. -} -exports.getBasePathForProjectLocalDependencyResolution = getBasePathForProjectLocalDependencyResolution; -/** @internal */ -function once(fn) { - let value; - let ran = false; - function onceFn(...args) { - if (ran) - return value; - value = fn(...args); - ran = true; - return value; - } - return onceFn; -} -exports.once = once; -/** @internal */ -function versionGteLt(version, gteRequirement, ltRequirement) { - const [major, minor, patch, extra] = parse(version); - const [gteMajor, gteMinor, gtePatch] = parse(gteRequirement); - const isGte = major > gteMajor || - (major === gteMajor && - (minor > gteMinor || (minor === gteMinor && patch >= gtePatch))); - let isLt = true; - if (ltRequirement) { - const [ltMajor, ltMinor, ltPatch] = parse(ltRequirement); - isLt = - major < ltMajor || - (major === ltMajor && - (minor < ltMinor || (minor === ltMinor && patch < ltPatch))); - } - return isGte && isLt; - function parse(requirement) { - return requirement.split(/[\.-]/).map((s) => parseInt(s, 10)); - } -} -exports.versionGteLt = versionGteLt; -//# sourceMappingURL=util.js.map - -/***/ }), - -/***/ 58145: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { - -"use strict"; - -Object.defineProperty(exports, "__esModule", ({ value: true })); -exports.configLoader = exports.loadConfig = void 0; -var TsConfigLoader2 = __nccwpck_require__(36968); -var path = __nccwpck_require__(71017); -function loadConfig(cwd) { - if (cwd === void 0) { cwd = process.cwd(); } - return configLoader({ cwd: cwd }); -} -exports.loadConfig = loadConfig; -function configLoader(_a) { - var cwd = _a.cwd, explicitParams = _a.explicitParams, _b = _a.tsConfigLoader, tsConfigLoader = _b === void 0 ? TsConfigLoader2.tsConfigLoader : _b; - if (explicitParams) { - var absoluteBaseUrl = path.isAbsolute(explicitParams.baseUrl) - ? explicitParams.baseUrl - : path.join(cwd, explicitParams.baseUrl); - return { - resultType: "success", - configFileAbsolutePath: "", - baseUrl: explicitParams.baseUrl, - absoluteBaseUrl: absoluteBaseUrl, - paths: explicitParams.paths, - mainFields: explicitParams.mainFields, - addMatchAll: explicitParams.addMatchAll, - }; - } - // Load tsconfig and create path matching function - var loadResult = tsConfigLoader({ - cwd: cwd, - getEnv: function (key) { return process.env[key]; }, - }); - if (!loadResult.tsConfigPath) { - return { - resultType: "failed", - message: "Couldn't find tsconfig.json", - }; - } - return { - resultType: "success", - configFileAbsolutePath: loadResult.tsConfigPath, - baseUrl: loadResult.baseUrl, - absoluteBaseUrl: path.resolve(path.dirname(loadResult.tsConfigPath), loadResult.baseUrl || ""), - paths: loadResult.paths || {}, - addMatchAll: loadResult.baseUrl !== undefined, - }; -} -exports.configLoader = configLoader; -//# sourceMappingURL=config-loader.js.map - -/***/ }), - -/***/ 30478: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { - -"use strict"; - -Object.defineProperty(exports, "__esModule", ({ value: true })); -exports.removeExtension = exports.fileExistsAsync = exports.readJsonFromDiskAsync = exports.readJsonFromDiskSync = exports.fileExistsSync = void 0; -var fs = __nccwpck_require__(57147); -function fileExistsSync(path) { - // If the file doesn't exist, avoid throwing an exception over the native barrier for every miss - if (!fs.existsSync(path)) { - return false; - } - try { - var stats = fs.statSync(path); - return stats.isFile(); - } - catch (err) { - // If error, assume file did not exist - return false; - } -} -exports.fileExistsSync = fileExistsSync; -/** - * Reads package.json from disk - * - * @param file Path to package.json - */ -// eslint-disable-next-line @typescript-eslint/no-explicit-any -function readJsonFromDiskSync(packageJsonPath) { - if (!fs.existsSync(packageJsonPath)) { - return undefined; - } - // eslint-disable-next-line @typescript-eslint/no-require-imports - return require(packageJsonPath); -} -exports.readJsonFromDiskSync = readJsonFromDiskSync; -function readJsonFromDiskAsync(path, -// eslint-disable-next-line @typescript-eslint/no-explicit-any -callback) { - fs.readFile(path, "utf8", function (err, result) { - // If error, assume file did not exist - if (err || !result) { - return callback(); - } - var json = JSON.parse(result); - return callback(undefined, json); - }); -} -exports.readJsonFromDiskAsync = readJsonFromDiskAsync; -function fileExistsAsync(path2, callback2) { - fs.stat(path2, function (err, stats) { - if (err) { - // If error assume file does not exist - return callback2(undefined, false); - } - callback2(undefined, stats ? stats.isFile() : false); - }); -} -exports.fileExistsAsync = fileExistsAsync; -function removeExtension(path) { - return path.substring(0, path.lastIndexOf(".")) || path; -} -exports.removeExtension = removeExtension; -//# sourceMappingURL=filesystem.js.map - -/***/ }), - -/***/ 10839: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { - -"use strict"; - -Object.defineProperty(exports, "__esModule", ({ value: true })); -exports.loadConfig = exports.register = exports.matchFromAbsolutePathsAsync = exports.createMatchPathAsync = exports.matchFromAbsolutePaths = exports.createMatchPath = void 0; -// register is used from register.js in root dir -var match_path_sync_1 = __nccwpck_require__(79232); -Object.defineProperty(exports, "createMatchPath", ({ enumerable: true, get: function () { return match_path_sync_1.createMatchPath; } })); -Object.defineProperty(exports, "matchFromAbsolutePaths", ({ enumerable: true, get: function () { return match_path_sync_1.matchFromAbsolutePaths; } })); -var match_path_async_1 = __nccwpck_require__(89114); -Object.defineProperty(exports, "createMatchPathAsync", ({ enumerable: true, get: function () { return match_path_async_1.createMatchPathAsync; } })); -Object.defineProperty(exports, "matchFromAbsolutePathsAsync", ({ enumerable: true, get: function () { return match_path_async_1.matchFromAbsolutePathsAsync; } })); -var register_1 = __nccwpck_require__(71994); -Object.defineProperty(exports, "register", ({ enumerable: true, get: function () { return register_1.register; } })); -var config_loader_1 = __nccwpck_require__(58145); -Object.defineProperty(exports, "loadConfig", ({ enumerable: true, get: function () { return config_loader_1.loadConfig; } })); -//# sourceMappingURL=index.js.map - -/***/ }), - -/***/ 1243: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { - -"use strict"; - -Object.defineProperty(exports, "__esModule", ({ value: true })); -exports.getAbsoluteMappingEntries = void 0; -var path = __nccwpck_require__(71017); -/** - * Converts an absolute baseUrl and paths to an array of absolute mapping entries. - * The array is sorted by longest prefix. - * Having an array with entries allows us to keep a sorting order rather than - * sort by keys each time we use the mappings. - * - * @param absoluteBaseUrl - * @param paths - * @param addMatchAll - */ -function getAbsoluteMappingEntries(absoluteBaseUrl, paths, addMatchAll) { - // Resolve all paths to absolute form once here, and sort them by - // longest prefix once here, this saves time on each request later. - // We need to put them in an array to preserve the sorting order. - var sortedKeys = sortByLongestPrefix(Object.keys(paths)); - var absolutePaths = []; - for (var _i = 0, sortedKeys_1 = sortedKeys; _i < sortedKeys_1.length; _i++) { - var key = sortedKeys_1[_i]; - absolutePaths.push({ - pattern: key, - paths: paths[key].map(function (pathToResolve) { - return path.resolve(absoluteBaseUrl, pathToResolve); - }), - }); - } - // If there is no match-all path specified in the paths section of tsconfig, then try to match - // all paths relative to baseUrl, this is how typescript works. - if (!paths["*"] && addMatchAll) { - absolutePaths.push({ - pattern: "*", - paths: ["".concat(absoluteBaseUrl.replace(/\/$/, ""), "/*")], - }); - } - return absolutePaths; -} -exports.getAbsoluteMappingEntries = getAbsoluteMappingEntries; -/** - * Sort path patterns. - * If a module name can be matched with multiple patterns then pattern with the longest prefix will be picked. - */ -function sortByLongestPrefix(arr) { - return arr - .concat() - .sort(function (a, b) { return getPrefixLength(b) - getPrefixLength(a); }); -} -function getPrefixLength(pattern) { - var prefixLength = pattern.indexOf("*"); - return pattern.substr(0, prefixLength).length; -} -//# sourceMappingURL=mapping-entry.js.map - -/***/ }), - -/***/ 89114: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { - -"use strict"; - -Object.defineProperty(exports, "__esModule", ({ value: true })); -exports.matchFromAbsolutePathsAsync = exports.createMatchPathAsync = void 0; -var path = __nccwpck_require__(71017); -var TryPath = __nccwpck_require__(29964); -var MappingEntry = __nccwpck_require__(1243); -var Filesystem = __nccwpck_require__(30478); -/** - * See the sync version for docs. - */ -function createMatchPathAsync(absoluteBaseUrl, paths, mainFields, addMatchAll) { - if (mainFields === void 0) { mainFields = ["main"]; } - if (addMatchAll === void 0) { addMatchAll = true; } - var absolutePaths = MappingEntry.getAbsoluteMappingEntries(absoluteBaseUrl, paths, addMatchAll); - return function (requestedModule, readJson, fileExists, extensions, callback) { - return matchFromAbsolutePathsAsync(absolutePaths, requestedModule, readJson, fileExists, extensions, callback, mainFields); - }; -} -exports.createMatchPathAsync = createMatchPathAsync; -/** - * See the sync version for docs. - */ -function matchFromAbsolutePathsAsync(absolutePathMappings, requestedModule, readJson, fileExists, extensions, callback, mainFields) { - if (readJson === void 0) { readJson = Filesystem.readJsonFromDiskAsync; } - if (fileExists === void 0) { fileExists = Filesystem.fileExistsAsync; } - if (extensions === void 0) { extensions = Object.keys(require.extensions); } - if (mainFields === void 0) { mainFields = ["main"]; } - var tryPaths = TryPath.getPathsToTry(extensions, absolutePathMappings, requestedModule); - if (!tryPaths) { - return callback(); - } - findFirstExistingPath(tryPaths, readJson, fileExists, callback, 0, mainFields); -} -exports.matchFromAbsolutePathsAsync = matchFromAbsolutePathsAsync; -function findFirstExistingMainFieldMappedFile(packageJson, mainFields, packageJsonPath, fileExistsAsync, doneCallback, index) { - if (index === void 0) { index = 0; } - if (index >= mainFields.length) { - return doneCallback(undefined, undefined); - } - var tryNext = function () { - return findFirstExistingMainFieldMappedFile(packageJson, mainFields, packageJsonPath, fileExistsAsync, doneCallback, index + 1); - }; - var mainFieldSelector = mainFields[index]; - var mainFieldMapping = typeof mainFieldSelector === "string" - ? packageJson[mainFieldSelector] - : mainFieldSelector.reduce(function (obj, key) { return obj[key]; }, packageJson); - if (typeof mainFieldMapping !== "string") { - // Skip mappings that are not pointers to replacement files - return tryNext(); - } - var mappedFilePath = path.join(path.dirname(packageJsonPath), mainFieldMapping); - fileExistsAsync(mappedFilePath, function (err, exists) { - if (err) { - return doneCallback(err); - } - if (exists) { - return doneCallback(undefined, mappedFilePath); - } - return tryNext(); - }); -} -// Recursive loop to probe for physical files -function findFirstExistingPath(tryPaths, readJson, fileExists, doneCallback, index, mainFields) { - if (index === void 0) { index = 0; } - if (mainFields === void 0) { mainFields = ["main"]; } - var tryPath = tryPaths[index]; - if (tryPath.type === "file" || - tryPath.type === "extension" || - tryPath.type === "index") { - fileExists(tryPath.path, function (err, exists) { - if (err) { - return doneCallback(err); - } - if (exists) { - return doneCallback(undefined, TryPath.getStrippedPath(tryPath)); - } - if (index === tryPaths.length - 1) { - return doneCallback(); - } - // Continue with the next path - return findFirstExistingPath(tryPaths, readJson, fileExists, doneCallback, index + 1, mainFields); - }); - } - else if (tryPath.type === "package") { - readJson(tryPath.path, function (err, packageJson) { - if (err) { - return doneCallback(err); - } - if (packageJson) { - return findFirstExistingMainFieldMappedFile(packageJson, mainFields, tryPath.path, fileExists, function (mainFieldErr, mainFieldMappedFile) { - if (mainFieldErr) { - return doneCallback(mainFieldErr); - } - if (mainFieldMappedFile) { - return doneCallback(undefined, mainFieldMappedFile); - } - // No field in package json was a valid option. Continue with the next path. - return findFirstExistingPath(tryPaths, readJson, fileExists, doneCallback, index + 1, mainFields); - }); - } - // This is async code, we need to return unconditionally, otherwise the code still falls - // through and keeps recursing. While this might work in general, libraries that use neo-async - // like Webpack will actually not allow you to call the same callback twice. - // - // An example of where this caused issues: - // https://github.com/dividab/tsconfig-paths-webpack-plugin/issues/11 - // - // Continue with the next path - return findFirstExistingPath(tryPaths, readJson, fileExists, doneCallback, index + 1, mainFields); - }); - } - else { - TryPath.exhaustiveTypeException(tryPath.type); - } -} -//# sourceMappingURL=match-path-async.js.map - -/***/ }), - -/***/ 79232: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { - -"use strict"; - -Object.defineProperty(exports, "__esModule", ({ value: true })); -exports.matchFromAbsolutePaths = exports.createMatchPath = void 0; -var path = __nccwpck_require__(71017); -var Filesystem = __nccwpck_require__(30478); -var MappingEntry = __nccwpck_require__(1243); -var TryPath = __nccwpck_require__(29964); -/** - * Creates a function that can resolve paths according to tsconfig paths property. - * - * @param absoluteBaseUrl Absolute version of baseUrl as specified in tsconfig. - * @param paths The paths as specified in tsconfig. - * @param mainFields A list of package.json field names to try when resolving module files. Select a nested field using an array of field names. - * @param addMatchAll Add a match-all "*" rule if none is present - * @returns a function that can resolve paths. - */ -function createMatchPath(absoluteBaseUrl, paths, mainFields, addMatchAll) { - if (mainFields === void 0) { mainFields = ["main"]; } - if (addMatchAll === void 0) { addMatchAll = true; } - var absolutePaths = MappingEntry.getAbsoluteMappingEntries(absoluteBaseUrl, paths, addMatchAll); - return function (requestedModule, readJson, fileExists, extensions) { - return matchFromAbsolutePaths(absolutePaths, requestedModule, readJson, fileExists, extensions, mainFields); - }; -} -exports.createMatchPath = createMatchPath; -/** - * Finds a path from tsconfig that matches a module load request. - * - * @param absolutePathMappings The paths to try as specified in tsconfig but resolved to absolute form. - * @param requestedModule The required module name. - * @param readJson Function that can read json from a path (useful for testing). - * @param fileExists Function that checks for existence of a file at a path (useful for testing). - * @param extensions File extensions to probe for (useful for testing). - * @param mainFields A list of package.json field names to try when resolving module files. Select a nested field using an array of field names. - * @returns the found path, or undefined if no path was found. - */ -function matchFromAbsolutePaths(absolutePathMappings, requestedModule, readJson, fileExists, extensions, mainFields) { - if (readJson === void 0) { readJson = Filesystem.readJsonFromDiskSync; } - if (fileExists === void 0) { fileExists = Filesystem.fileExistsSync; } - if (extensions === void 0) { extensions = Object.keys(require.extensions); } - if (mainFields === void 0) { mainFields = ["main"]; } - var tryPaths = TryPath.getPathsToTry(extensions, absolutePathMappings, requestedModule); - if (!tryPaths) { - return undefined; - } - return findFirstExistingPath(tryPaths, readJson, fileExists, mainFields); -} -exports.matchFromAbsolutePaths = matchFromAbsolutePaths; -function findFirstExistingMainFieldMappedFile(packageJson, mainFields, packageJsonPath, fileExists) { - for (var index = 0; index < mainFields.length; index++) { - var mainFieldSelector = mainFields[index]; - var candidateMapping = typeof mainFieldSelector === "string" - ? packageJson[mainFieldSelector] - : mainFieldSelector.reduce(function (obj, key) { return obj[key]; }, packageJson); - if (candidateMapping && typeof candidateMapping === "string") { - var candidateFilePath = path.join(path.dirname(packageJsonPath), candidateMapping); - if (fileExists(candidateFilePath)) { - return candidateFilePath; - } - } - } - return undefined; -} -function findFirstExistingPath(tryPaths, readJson, fileExists, mainFields) { - if (readJson === void 0) { readJson = Filesystem.readJsonFromDiskSync; } - if (mainFields === void 0) { mainFields = ["main"]; } - for (var _i = 0, tryPaths_1 = tryPaths; _i < tryPaths_1.length; _i++) { - var tryPath = tryPaths_1[_i]; - if (tryPath.type === "file" || - tryPath.type === "extension" || - tryPath.type === "index") { - if (fileExists(tryPath.path)) { - return TryPath.getStrippedPath(tryPath); - } - } - else if (tryPath.type === "package") { - var packageJson = readJson(tryPath.path); - if (packageJson) { - var mainFieldMappedFile = findFirstExistingMainFieldMappedFile(packageJson, mainFields, tryPath.path, fileExists); - if (mainFieldMappedFile) { - return mainFieldMappedFile; - } - } - } - else { - TryPath.exhaustiveTypeException(tryPath.type); - } - } - return undefined; -} -//# sourceMappingURL=match-path-sync.js.map - -/***/ }), - -/***/ 71994: -/***/ (function(__unused_webpack_module, exports, __nccwpck_require__) { - -"use strict"; - -var __spreadArray = (this && this.__spreadArray) || function (to, from, pack) { - if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) { - if (ar || !(i in from)) { - if (!ar) ar = Array.prototype.slice.call(from, 0, i); - ar[i] = from[i]; - } - } - return to.concat(ar || Array.prototype.slice.call(from)); -}; -Object.defineProperty(exports, "__esModule", ({ value: true })); -exports.register = void 0; -var match_path_sync_1 = __nccwpck_require__(79232); -var config_loader_1 = __nccwpck_require__(58145); -var noOp = function () { return void 0; }; -function getCoreModules(builtinModules) { - builtinModules = builtinModules || [ - "assert", - "buffer", - "child_process", - "cluster", - "crypto", - "dgram", - "dns", - "domain", - "events", - "fs", - "http", - "https", - "net", - "os", - "path", - "punycode", - "querystring", - "readline", - "stream", - "string_decoder", - "tls", - "tty", - "url", - "util", - "v8", - "vm", - "zlib", - ]; - var coreModules = {}; - for (var _i = 0, builtinModules_1 = builtinModules; _i < builtinModules_1.length; _i++) { - var module_1 = builtinModules_1[_i]; - coreModules[module_1] = true; - } - return coreModules; -} -/** - * Installs a custom module load function that can adhere to paths in tsconfig. - * Returns a function to undo paths registration. - */ -function register(params) { - var cwd; - var explicitParams; - if (params) { - cwd = params.cwd; - if (params.baseUrl || params.paths) { - explicitParams = params; - } - } - else { - // eslint-disable-next-line - var minimist = __nccwpck_require__(11474); - var argv = minimist(process.argv.slice(2), { - // eslint-disable-next-line id-denylist - string: ["project"], - alias: { - project: ["P"], - }, - }); - cwd = argv.project; - } - var configLoaderResult = (0, config_loader_1.configLoader)({ - cwd: cwd !== null && cwd !== void 0 ? cwd : process.cwd(), - explicitParams: explicitParams, - }); - if (configLoaderResult.resultType === "failed") { - console.warn("".concat(configLoaderResult.message, ". tsconfig-paths will be skipped")); - return noOp; - } - var matchPath = (0, match_path_sync_1.createMatchPath)(configLoaderResult.absoluteBaseUrl, configLoaderResult.paths, configLoaderResult.mainFields, configLoaderResult.addMatchAll); - // Patch node's module loading - // eslint-disable-next-line @typescript-eslint/no-require-imports,@typescript-eslint/no-var-requires - var Module = __nccwpck_require__(98188); - // eslint-disable-next-line no-underscore-dangle - var originalResolveFilename = Module._resolveFilename; - var coreModules = getCoreModules(Module.builtinModules); - // eslint-disable-next-line @typescript-eslint/no-explicit-any,no-underscore-dangle - Module._resolveFilename = function (request, _parent) { - var isCoreModule = coreModules.hasOwnProperty(request); - if (!isCoreModule) { - var found = matchPath(request); - if (found) { - var modifiedArguments = __spreadArray([found], [].slice.call(arguments, 1), true); // Passes all arguments. Even those that is not specified above. - return originalResolveFilename.apply(this, modifiedArguments); - } - } - return originalResolveFilename.apply(this, arguments); - }; - return function () { - // Return node's module loading to original state. - // eslint-disable-next-line no-underscore-dangle - Module._resolveFilename = originalResolveFilename; - }; -} -exports.register = register; -//# sourceMappingURL=register.js.map - -/***/ }), - -/***/ 29964: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { - -"use strict"; + }); -Object.defineProperty(exports, "__esModule", ({ value: true })); -exports.exhaustiveTypeException = exports.getStrippedPath = exports.getPathsToTry = void 0; -var path = __nccwpck_require__(71017); -var path_1 = __nccwpck_require__(71017); -var filesystem_1 = __nccwpck_require__(30478); -/** - * Builds a list of all physical paths to try by: - * 1. Check for file named exactly as request. - * 2. Check for files named as request ending in any of the extensions. - * 3. Check for file specified in package.json's main property. - * 4. Check for files named as request ending in "index" with any of the extensions. - */ -function getPathsToTry(extensions, absolutePathMappings, requestedModule) { - if (!absolutePathMappings || !requestedModule || requestedModule[0] === ".") { - return undefined; - } - var pathsToTry = []; - for (var _i = 0, absolutePathMappings_1 = absolutePathMappings; _i < absolutePathMappings_1.length; _i++) { - var entry = absolutePathMappings_1[_i]; - var starMatch = entry.pattern === requestedModule - ? "" - : matchStar(entry.pattern, requestedModule); - if (starMatch !== undefined) { - var _loop_1 = function (physicalPathPattern) { - var physicalPath = physicalPathPattern.replace("*", starMatch); - pathsToTry.push({ type: "file", path: physicalPath }); - pathsToTry.push.apply(pathsToTry, extensions.map(function (e) { return ({ type: "extension", path: physicalPath + e }); })); - pathsToTry.push({ - type: "package", - path: path.join(physicalPath, "/package.json"), - }); - var indexPath = path.join(physicalPath, "/index"); - pathsToTry.push.apply(pathsToTry, extensions.map(function (e) { return ({ type: "index", path: indexPath + e }); })); - }; - for (var _a = 0, _b = entry.paths; _a < _b.length; _a++) { - var physicalPathPattern = _b[_a]; - _loop_1(physicalPathPattern); - } - } - } - return pathsToTry.length === 0 ? undefined : pathsToTry; -} -exports.getPathsToTry = getPathsToTry; -// Not sure why we don't just return the full found path? -function getStrippedPath(tryPath) { - return tryPath.type === "index" - ? (0, path_1.dirname)(tryPath.path) - : tryPath.type === "file" - ? tryPath.path - : tryPath.type === "extension" - ? (0, filesystem_1.removeExtension)(tryPath.path) - : tryPath.type === "package" - ? tryPath.path - : exhaustiveTypeException(tryPath.type); -} -exports.getStrippedPath = getStrippedPath; -function exhaustiveTypeException(check) { - throw new Error("Unknown type ".concat(check)); -} -exports.exhaustiveTypeException = exhaustiveTypeException; -/** - * Matches pattern with a single star against search. - * Star must match at least one character to be considered a match. - * - * @param patttern for example "foo*" - * @param search for example "fooawesomebar" - * @returns the part of search that * matches, or undefined if no match. - */ -function matchStar(pattern, search) { - if (search.length < pattern.length) { - return undefined; - } - if (pattern === "*") { - return search; - } - var star = pattern.indexOf("*"); - if (star === -1) { - return undefined; - } - var part1 = pattern.substring(0, star); - var part2 = pattern.substring(star + 1); - if (search.substr(0, star) !== part1) { - return undefined; - } - if (search.substr(search.length - part2.length) !== part2) { - return undefined; - } - return search.substr(star, search.length - part2.length); -} -//# sourceMappingURL=try-path.js.map - -/***/ }), - -/***/ 36968: -/***/ (function(__unused_webpack_module, exports, __nccwpck_require__) { - -"use strict"; - -var __assign = (this && this.__assign) || function () { - __assign = Object.assign || function(t) { - for (var s, i = 1, n = arguments.length; i < n; i++) { - s = arguments[i]; - for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) - t[p] = s[p]; - } - return t; - }; - return __assign.apply(this, arguments); -}; -Object.defineProperty(exports, "__esModule", ({ value: true })); -exports.loadTsconfig = exports.walkForTsConfig = exports.tsConfigLoader = void 0; -var path = __nccwpck_require__(71017); -var fs = __nccwpck_require__(57147); -// eslint-disable-next-line @typescript-eslint/no-require-imports -var JSON5 = __nccwpck_require__(89501); -// eslint-disable-next-line @typescript-eslint/no-require-imports -var StripBom = __nccwpck_require__(22196); -function tsConfigLoader(_a) { - var getEnv = _a.getEnv, cwd = _a.cwd, _b = _a.loadSync, loadSync = _b === void 0 ? loadSyncDefault : _b; - var TS_NODE_PROJECT = getEnv("TS_NODE_PROJECT"); - var TS_NODE_BASEURL = getEnv("TS_NODE_BASEURL"); - // tsconfig.loadSync handles if TS_NODE_PROJECT is a file or directory - // and also overrides baseURL if TS_NODE_BASEURL is available. - var loadResult = loadSync(cwd, TS_NODE_PROJECT, TS_NODE_BASEURL); - return loadResult; -} -exports.tsConfigLoader = tsConfigLoader; -function loadSyncDefault(cwd, filename, baseUrl) { - // Tsconfig.loadSync uses path.resolve. This is why we can use an absolute path as filename - var configPath = resolveConfigPath(cwd, filename); - if (!configPath) { - return { - tsConfigPath: undefined, - baseUrl: undefined, - paths: undefined, - }; - } - var config = loadTsconfig(configPath); - return { - tsConfigPath: configPath, - baseUrl: baseUrl || - (config && config.compilerOptions && config.compilerOptions.baseUrl), - paths: config && config.compilerOptions && config.compilerOptions.paths, - }; -} -function resolveConfigPath(cwd, filename) { - if (filename) { - var absolutePath = fs.lstatSync(filename).isDirectory() - ? path.resolve(filename, "./tsconfig.json") - : path.resolve(cwd, filename); - return absolutePath; - } - if (fs.statSync(cwd).isFile()) { - return path.resolve(cwd); - } - var configAbsolutePath = walkForTsConfig(cwd); - return configAbsolutePath ? path.resolve(configAbsolutePath) : undefined; -} -function walkForTsConfig(directory, readdirSync) { - if (readdirSync === void 0) { readdirSync = fs.readdirSync; } - var files = readdirSync(directory); - var filesToCheck = ["tsconfig.json", "jsconfig.json"]; - for (var _i = 0, filesToCheck_1 = filesToCheck; _i < filesToCheck_1.length; _i++) { - var fileToCheck = filesToCheck_1[_i]; - if (files.indexOf(fileToCheck) !== -1) { - return path.join(directory, fileToCheck); - } - } - var parentDirectory = path.dirname(directory); - // If we reached the top - if (directory === parentDirectory) { - return undefined; - } - return walkForTsConfig(parentDirectory, readdirSync); -} -exports.walkForTsConfig = walkForTsConfig; -function loadTsconfig(configFilePath, -// eslint-disable-next-line no-shadow -existsSync, readFileSync) { - if (existsSync === void 0) { existsSync = fs.existsSync; } - if (readFileSync === void 0) { readFileSync = function (filename) { - return fs.readFileSync(filename, "utf8"); - }; } - if (!existsSync(configFilePath)) { - return undefined; - } - var configString = readFileSync(configFilePath); - var cleanedJson = StripBom(configString); - var config; - try { - config = JSON5.parse(cleanedJson); - } - catch (e) { - throw new Error("".concat(configFilePath, " is malformed ").concat(e.message)); - } - var extendedConfig = config.extends; - if (extendedConfig) { - if (typeof extendedConfig === "string" && - extendedConfig.indexOf(".json") === -1) { - extendedConfig += ".json"; - } - var currentDir = path.dirname(configFilePath); - var extendedConfigPath = path.join(currentDir, extendedConfig); - if (extendedConfig.indexOf("/") !== -1 && - extendedConfig.indexOf(".") !== -1 && - !existsSync(extendedConfigPath)) { - extendedConfigPath = path.join(currentDir, "node_modules", extendedConfig); - } - var base = loadTsconfig(extendedConfigPath, existsSync, readFileSync) || {}; - // baseUrl should be interpreted as relative to the base tsconfig, - // but we need to update it so it is relative to the original tsconfig being loaded - if (base.compilerOptions && base.compilerOptions.baseUrl) { - var extendsDir = path.dirname(extendedConfig); - base.compilerOptions.baseUrl = path.join(extendsDir, base.compilerOptions.baseUrl); - } - return __assign(__assign(__assign({}, base), config), { compilerOptions: __assign(__assign({}, base.compilerOptions), config.compilerOptions) }); - } - return config; -} -exports.loadTsconfig = loadTsconfig; -//# sourceMappingURL=tsconfig-loader.js.map - -/***/ }), - -/***/ 65315: -/***/ ((module) => { - -/****************************************************************************** -Copyright (c) Microsoft Corporation. - -Permission to use, copy, modify, and/or distribute this software for any -purpose with or without fee is hereby granted. - -THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH -REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY -AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, -INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM -LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR -OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR -PERFORMANCE OF THIS SOFTWARE. -***************************************************************************** */ -/* global global, define, Symbol, Reflect, Promise, SuppressedError */ -var __extends; -var __assign; -var __rest; -var __decorate; -var __param; -var __esDecorate; -var __runInitializers; -var __propKey; -var __setFunctionName; -var __metadata; -var __awaiter; -var __generator; -var __exportStar; -var __values; -var __read; -var __spread; -var __spreadArrays; -var __spreadArray; -var __await; -var __asyncGenerator; -var __asyncDelegator; -var __asyncValues; -var __makeTemplateObject; -var __importStar; -var __importDefault; -var __classPrivateFieldGet; -var __classPrivateFieldSet; -var __classPrivateFieldIn; -var __createBinding; -var __addDisposableResource; -var __disposeResources; -(function (factory) { - var root = typeof global === "object" ? global : typeof self === "object" ? self : typeof this === "object" ? this : {}; - if (typeof define === "function" && define.amd) { - define("tslib", ["exports"], function (exports) { factory(createExporter(root, createExporter(exports))); }); - } - else if ( true && typeof module.exports === "object") { - factory(createExporter(root, createExporter(module.exports))); - } - else { - factory(createExporter(root)); - } - function createExporter(exports, previous) { - if (exports !== root) { - if (typeof Object.create === "function") { - Object.defineProperty(exports, "__esModule", { value: true }); - } - else { - exports.__esModule = true; - } - } - return function (id, v) { return exports[id] = previous ? previous(id, v) : v; }; - } -}) -(function (exporter) { - var extendStatics = Object.setPrototypeOf || - ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || - function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; }; - - __extends = function (d, b) { - if (typeof b !== "function" && b !== null) - throw new TypeError("Class extends value " + String(b) + " is not a constructor or null"); - extendStatics(d, b); - function __() { this.constructor = d; } - d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); - }; - - __assign = Object.assign || function (t) { - for (var s, i = 1, n = arguments.length; i < n; i++) { - s = arguments[i]; - for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p]; - } - return t; - }; - - __rest = function (s, e) { - var t = {}; - for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0) - t[p] = s[p]; - if (s != null && typeof Object.getOwnPropertySymbols === "function") - for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) { - if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i])) - t[p[i]] = s[p[i]]; - } - return t; - }; - - __decorate = function (decorators, target, key, desc) { - var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; - if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); - else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; - return c > 3 && r && Object.defineProperty(target, key, r), r; - }; - - __param = function (paramIndex, decorator) { - return function (target, key) { decorator(target, key, paramIndex); } - }; - - __esDecorate = function (ctor, descriptorIn, decorators, contextIn, initializers, extraInitializers) { - function accept(f) { if (f !== void 0 && typeof f !== "function") throw new TypeError("Function expected"); return f; } - var kind = contextIn.kind, key = kind === "getter" ? "get" : kind === "setter" ? "set" : "value"; - var target = !descriptorIn && ctor ? contextIn["static"] ? ctor : ctor.prototype : null; - var descriptor = descriptorIn || (target ? Object.getOwnPropertyDescriptor(target, contextIn.name) : {}); - var _, done = false; - for (var i = decorators.length - 1; i >= 0; i--) { - var context = {}; - for (var p in contextIn) context[p] = p === "access" ? {} : contextIn[p]; - for (var p in contextIn.access) context.access[p] = contextIn.access[p]; - context.addInitializer = function (f) { if (done) throw new TypeError("Cannot add initializers after decoration has completed"); extraInitializers.push(accept(f || null)); }; - var result = (0, decorators[i])(kind === "accessor" ? { get: descriptor.get, set: descriptor.set } : descriptor[key], context); - if (kind === "accessor") { - if (result === void 0) continue; - if (result === null || typeof result !== "object") throw new TypeError("Object expected"); - if (_ = accept(result.get)) descriptor.get = _; - if (_ = accept(result.set)) descriptor.set = _; - if (_ = accept(result.init)) initializers.unshift(_); - } - else if (_ = accept(result)) { - if (kind === "field") initializers.unshift(_); - else descriptor[key] = _; - } - } - if (target) Object.defineProperty(target, contextIn.name, descriptor); - done = true; - }; - - __runInitializers = function (thisArg, initializers, value) { - var useValue = arguments.length > 2; - for (var i = 0; i < initializers.length; i++) { - value = useValue ? initializers[i].call(thisArg, value) : initializers[i].call(thisArg); - } - return useValue ? value : void 0; - }; - - __propKey = function (x) { - return typeof x === "symbol" ? x : "".concat(x); - }; - - __setFunctionName = function (f, name, prefix) { - if (typeof name === "symbol") name = name.description ? "[".concat(name.description, "]") : ""; - return Object.defineProperty(f, "name", { configurable: true, value: prefix ? "".concat(prefix, " ", name) : name }); - }; - - __metadata = function (metadataKey, metadataValue) { - if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(metadataKey, metadataValue); - }; - - __awaiter = function (thisArg, _arguments, P, generator) { - function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); } - return new (P || (P = Promise))(function (resolve, reject) { - function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } - function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } - function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); } - step((generator = generator.apply(thisArg, _arguments || [])).next()); - }); - }; - - __generator = function (thisArg, body) { - var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g; - return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g; - function verb(n) { return function (v) { return step([n, v]); }; } - function step(op) { - if (f) throw new TypeError("Generator is already executing."); - while (g && (g = 0, op[0] && (_ = 0)), _) try { - if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t; - if (y = 0, t) op = [op[0] & 2, t.value]; - switch (op[0]) { - case 0: case 1: t = op; break; - case 4: _.label++; return { value: op[1], done: false }; - case 5: _.label++; y = op[1]; op = [0]; continue; - case 7: op = _.ops.pop(); _.trys.pop(); continue; - default: - if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; } - if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; } - if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; } - if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; } - if (t[2]) _.ops.pop(); - _.trys.pop(); continue; - } - op = body.call(thisArg, _); - } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; } - if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true }; - } - }; - - __exportStar = function(m, o) { - for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(o, p)) __createBinding(o, m, p); - }; - - __createBinding = Object.create ? (function(o, m, k, k2) { - if (k2 === undefined) k2 = k; - var desc = Object.getOwnPropertyDescriptor(m, k); - if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) { - desc = { enumerable: true, get: function() { return m[k]; } }; - } - Object.defineProperty(o, k2, desc); - }) : (function(o, m, k, k2) { - if (k2 === undefined) k2 = k; - o[k2] = m[k]; - }); - - __values = function (o) { - var s = typeof Symbol === "function" && Symbol.iterator, m = s && o[s], i = 0; - if (m) return m.call(o); - if (o && typeof o.length === "number") return { - next: function () { - if (o && i >= o.length) o = void 0; - return { value: o && o[i++], done: !o }; - } - }; - throw new TypeError(s ? "Object is not iterable." : "Symbol.iterator is not defined."); - }; - - __read = function (o, n) { - var m = typeof Symbol === "function" && o[Symbol.iterator]; - if (!m) return o; - var i = m.call(o), r, ar = [], e; - try { - while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value); - } - catch (error) { e = { error: error }; } - finally { - try { - if (r && !r.done && (m = i["return"])) m.call(i); - } - finally { if (e) throw e.error; } - } - return ar; - }; - - /** @deprecated */ - __spread = function () { - for (var ar = [], i = 0; i < arguments.length; i++) - ar = ar.concat(__read(arguments[i])); - return ar; - }; - - /** @deprecated */ - __spreadArrays = function () { - for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length; - for (var r = Array(s), k = 0, i = 0; i < il; i++) - for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++) - r[k] = a[j]; - return r; - }; - - __spreadArray = function (to, from, pack) { - if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) { - if (ar || !(i in from)) { - if (!ar) ar = Array.prototype.slice.call(from, 0, i); - ar[i] = from[i]; - } - } - return to.concat(ar || Array.prototype.slice.call(from)); - }; - - __await = function (v) { - return this instanceof __await ? (this.v = v, this) : new __await(v); - }; - - __asyncGenerator = function (thisArg, _arguments, generator) { - if (!Symbol.asyncIterator) throw new TypeError("Symbol.asyncIterator is not defined."); - var g = generator.apply(thisArg, _arguments || []), i, q = []; - return i = {}, verb("next"), verb("throw"), verb("return"), i[Symbol.asyncIterator] = function () { return this; }, i; - function verb(n) { if (g[n]) i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; } - function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } } - function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); } - function fulfill(value) { resume("next", value); } - function reject(value) { resume("throw", value); } - function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); } - }; - - __asyncDelegator = function (o) { - var i, p; - return i = {}, verb("next"), verb("throw", function (e) { throw e; }), verb("return"), i[Symbol.iterator] = function () { return this; }, i; - function verb(n, f) { i[n] = o[n] ? function (v) { return (p = !p) ? { value: __await(o[n](v)), done: false } : f ? f(v) : v; } : f; } - }; - - __asyncValues = function (o) { - if (!Symbol.asyncIterator) throw new TypeError("Symbol.asyncIterator is not defined."); - var m = o[Symbol.asyncIterator], i; - return m ? m.call(o) : (o = typeof __values === "function" ? __values(o) : o[Symbol.iterator](), i = {}, verb("next"), verb("throw"), verb("return"), i[Symbol.asyncIterator] = function () { return this; }, i); - function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; } - function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); } - }; - - __makeTemplateObject = function (cooked, raw) { - if (Object.defineProperty) { Object.defineProperty(cooked, "raw", { value: raw }); } else { cooked.raw = raw; } - return cooked; - }; - - var __setModuleDefault = Object.create ? (function(o, v) { - Object.defineProperty(o, "default", { enumerable: true, value: v }); - }) : function(o, v) { - o["default"] = v; - }; - - __importStar = function (mod) { - if (mod && mod.__esModule) return mod; - var result = {}; - if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k); - __setModuleDefault(result, mod); - return result; - }; - - __importDefault = function (mod) { - return (mod && mod.__esModule) ? mod : { "default": mod }; - }; - - __classPrivateFieldGet = function (receiver, state, kind, f) { - if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a getter"); - if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot read private member from an object whose class did not declare it"); - return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver); - }; - - __classPrivateFieldSet = function (receiver, state, value, kind, f) { - if (kind === "m") throw new TypeError("Private method is not writable"); - if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a setter"); - if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot write private member to an object whose class did not declare it"); - return (kind === "a" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value; - }; - - __classPrivateFieldIn = function (state, receiver) { - if (receiver === null || (typeof receiver !== "object" && typeof receiver !== "function")) throw new TypeError("Cannot use 'in' operator on non-object"); - return typeof state === "function" ? receiver === state : state.has(receiver); - }; - - __addDisposableResource = function (env, value, async) { - if (value !== null && value !== void 0) { - if (typeof value !== "object" && typeof value !== "function") throw new TypeError("Object expected."); - var dispose; - if (async) { - if (!Symbol.asyncDispose) throw new TypeError("Symbol.asyncDispose is not defined."); - dispose = value[Symbol.asyncDispose]; - } - if (dispose === void 0) { - if (!Symbol.dispose) throw new TypeError("Symbol.dispose is not defined."); - dispose = value[Symbol.dispose]; - } - if (typeof dispose !== "function") throw new TypeError("Object not disposable."); - env.stack.push({ value: value, dispose: dispose, async: async }); - } - else if (async) { - env.stack.push({ async: true }); - } - return value; - }; - - var _SuppressedError = typeof SuppressedError === "function" ? SuppressedError : function (error, suppressed, message) { - var e = new Error(message); - return e.name = "SuppressedError", e.error = error, e.suppressed = suppressed, e; - }; - - __disposeResources = function (env) { - function fail(e) { - env.error = env.hasError ? new _SuppressedError(e, env.error, "An error was suppressed during disposal.") : e; - env.hasError = true; - } - function next() { - while (env.stack.length) { - var rec = env.stack.pop(); - try { - var result = rec.dispose && rec.dispose.call(rec.value); - if (rec.async) return Promise.resolve(result).then(next, function(e) { fail(e); return next(); }); - } - catch (e) { - fail(e); - } - } - if (env.hasError) throw env.error; - } - return next(); - }; - - exporter("__extends", __extends); - exporter("__assign", __assign); - exporter("__rest", __rest); - exporter("__decorate", __decorate); - exporter("__param", __param); - exporter("__esDecorate", __esDecorate); - exporter("__runInitializers", __runInitializers); - exporter("__propKey", __propKey); - exporter("__setFunctionName", __setFunctionName); - exporter("__metadata", __metadata); - exporter("__awaiter", __awaiter); - exporter("__generator", __generator); - exporter("__exportStar", __exportStar); - exporter("__createBinding", __createBinding); - exporter("__values", __values); - exporter("__read", __read); - exporter("__spread", __spread); - exporter("__spreadArrays", __spreadArrays); - exporter("__spreadArray", __spreadArray); - exporter("__await", __await); - exporter("__asyncGenerator", __asyncGenerator); - exporter("__asyncDelegator", __asyncDelegator); - exporter("__asyncValues", __asyncValues); - exporter("__makeTemplateObject", __makeTemplateObject); - exporter("__importStar", __importStar); - exporter("__importDefault", __importDefault); - exporter("__classPrivateFieldGet", __classPrivateFieldGet); - exporter("__classPrivateFieldSet", __classPrivateFieldSet); - exporter("__classPrivateFieldIn", __classPrivateFieldIn); - exporter("__addDisposableResource", __addDisposableResource); - exporter("__disposeResources", __disposeResources); -}); - - -/***/ }), - -/***/ 57383: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { - -module.exports = __nccwpck_require__(39161); - - -/***/ }), - -/***/ 39161: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { - -"use strict"; - - -var net = __nccwpck_require__(41808); -var tls = __nccwpck_require__(24404); -var http = __nccwpck_require__(13685); -var https = __nccwpck_require__(95687); -var events = __nccwpck_require__(82361); -var assert = __nccwpck_require__(39491); -var util = __nccwpck_require__(73837); - - -exports.httpOverHttp = httpOverHttp; -exports.httpsOverHttp = httpsOverHttp; -exports.httpOverHttps = httpOverHttps; -exports.httpsOverHttps = httpsOverHttps; - - -function httpOverHttp(options) { - var agent = new TunnelingAgent(options); - agent.request = http.request; - return agent; -} - -function httpsOverHttp(options) { - var agent = new TunnelingAgent(options); - agent.request = http.request; - agent.createSocket = createSecureSocket; - agent.defaultPort = 443; - return agent; -} - -function httpOverHttps(options) { - var agent = new TunnelingAgent(options); - agent.request = https.request; - return agent; -} - -function httpsOverHttps(options) { - var agent = new TunnelingAgent(options); - agent.request = https.request; - agent.createSocket = createSecureSocket; - agent.defaultPort = 443; - return agent; -} - - -function TunnelingAgent(options) { - var self = this; - self.options = options || {}; - self.proxyOptions = self.options.proxy || {}; - self.maxSockets = self.options.maxSockets || http.Agent.defaultMaxSockets; - self.requests = []; - self.sockets = []; - - self.on('free', function onFree(socket, host, port, localAddress) { - var options = toOptions(host, port, localAddress); - for (var i = 0, len = self.requests.length; i < len; ++i) { - var pending = self.requests[i]; - if (pending.host === options.host && pending.port === options.port) { - // Detect the request to connect same origin server, - // reuse the connection. - self.requests.splice(i, 1); - pending.request.onSocket(socket); - return; - } - } - socket.destroy(); - self.removeSocket(socket); - }); -} -util.inherits(TunnelingAgent, events.EventEmitter); - -TunnelingAgent.prototype.addRequest = function addRequest(req, host, port, localAddress) { - var self = this; - var options = mergeOptions({request: req}, self.options, toOptions(host, port, localAddress)); - - if (self.sockets.length >= this.maxSockets) { - // We are over limit so we'll add it to the queue. - self.requests.push(options); - return; - } - - // If we are under maxSockets create a new one. - self.createSocket(options, function(socket) { - socket.on('free', onFree); - socket.on('close', onCloseOrRemove); - socket.on('agentRemove', onCloseOrRemove); - req.onSocket(socket); - - function onFree() { - self.emit('free', socket, options); - } - - function onCloseOrRemove(err) { - self.removeSocket(socket); - socket.removeListener('free', onFree); - socket.removeListener('close', onCloseOrRemove); - socket.removeListener('agentRemove', onCloseOrRemove); - } - }); -}; - -TunnelingAgent.prototype.createSocket = function createSocket(options, cb) { - var self = this; - var placeholder = {}; - self.sockets.push(placeholder); - - var connectOptions = mergeOptions({}, self.proxyOptions, { - method: 'CONNECT', - path: options.host + ':' + options.port, - agent: false, - headers: { - host: options.host + ':' + options.port - } - }); - if (options.localAddress) { - connectOptions.localAddress = options.localAddress; - } - if (connectOptions.proxyAuth) { - connectOptions.headers = connectOptions.headers || {}; - connectOptions.headers['Proxy-Authorization'] = 'Basic ' + - new Buffer(connectOptions.proxyAuth).toString('base64'); - } - - debug('making CONNECT request'); - var connectReq = self.request(connectOptions); - connectReq.useChunkedEncodingByDefault = false; // for v0.6 - connectReq.once('response', onResponse); // for v0.6 - connectReq.once('upgrade', onUpgrade); // for v0.6 - connectReq.once('connect', onConnect); // for v0.7 or later - connectReq.once('error', onError); - connectReq.end(); - - function onResponse(res) { - // Very hacky. This is necessary to avoid http-parser leaks. - res.upgrade = true; - } - - function onUpgrade(res, socket, head) { - // Hacky. - process.nextTick(function() { - onConnect(res, socket, head); - }); - } - - function onConnect(res, socket, head) { - connectReq.removeAllListeners(); - socket.removeAllListeners(); - - if (res.statusCode !== 200) { - debug('tunneling socket could not be established, statusCode=%d', - res.statusCode); - socket.destroy(); - var error = new Error('tunneling socket could not be established, ' + - 'statusCode=' + res.statusCode); - error.code = 'ECONNRESET'; - options.request.emit('error', error); - self.removeSocket(placeholder); - return; - } - if (head.length > 0) { - debug('got illegal response body from proxy'); - socket.destroy(); - var error = new Error('got illegal response body from proxy'); - error.code = 'ECONNRESET'; - options.request.emit('error', error); - self.removeSocket(placeholder); - return; - } - debug('tunneling connection has established'); - self.sockets[self.sockets.indexOf(placeholder)] = socket; - return cb(socket); - } - - function onError(cause) { - connectReq.removeAllListeners(); - - debug('tunneling socket could not be established, cause=%s\n', - cause.message, cause.stack); - var error = new Error('tunneling socket could not be established, ' + - 'cause=' + cause.message); - error.code = 'ECONNRESET'; - options.request.emit('error', error); - self.removeSocket(placeholder); - } -}; - -TunnelingAgent.prototype.removeSocket = function removeSocket(socket) { - var pos = this.sockets.indexOf(socket) - if (pos === -1) { - return; - } - this.sockets.splice(pos, 1); - - var pending = this.requests.shift(); - if (pending) { - // If we have pending requests and a socket gets closed a new one - // needs to be created to take over in the pool for the one that closed. - this.createSocket(pending, function(socket) { - pending.request.onSocket(socket); - }); - } -}; - -function createSecureSocket(options, cb) { - var self = this; - TunnelingAgent.prototype.createSocket.call(self, options, function(socket) { - var hostHeader = options.request.getHeader('host'); - var tlsOptions = mergeOptions({}, self.options, { - socket: socket, - servername: hostHeader ? hostHeader.replace(/:.*$/, '') : options.host - }); - - // 0 is dummy port for v0.6 - var secureSocket = tls.connect(0, tlsOptions); - self.sockets[self.sockets.indexOf(socket)] = secureSocket; - cb(secureSocket); - }); -} - - -function toOptions(host, port, localAddress) { - if (typeof host === 'string') { // since v0.10 - return { - host: host, - port: port, - localAddress: localAddress - }; - } - return host; // for v0.11 or later -} - -function mergeOptions(target) { - for (var i = 1, len = arguments.length; i < len; ++i) { - var overrides = arguments[i]; - if (typeof overrides === 'object') { - var keys = Object.keys(overrides); - for (var j = 0, keyLen = keys.length; j < keyLen; ++j) { - var k = keys[j]; - if (overrides[k] !== undefined) { - target[k] = overrides[k]; - } - } - } - } - return target; -} - - -var debug; -if (process.env.NODE_DEBUG && /\btunnel\b/.test(process.env.NODE_DEBUG)) { - debug = function() { - var args = Array.prototype.slice.call(arguments); - if (typeof args[0] === 'string') { - args[0] = 'TUNNEL: ' + args[0]; - } else { - args.unshift('TUNNEL:'); - } - console.error.apply(console, args); + // src/compiler/types.ts + function diagnosticCategoryName(d, lowerCase = true) { + const name = DiagnosticCategory[d.category]; + return lowerCase ? name.toLowerCase() : name; } -} else { - debug = function() {}; -} -exports.debug = debug; // for test - - -/***/ }), - -/***/ 70048: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { - -"use strict"; -/*! ***************************************************************************** -Copyright (c) Microsoft Corporation. All rights reserved. -Licensed under the Apache License, Version 2.0 (the "License"); you may not use -this file except in compliance with the License. You may obtain a copy of the -License at http://www.apache.org/licenses/LICENSE-2.0 - -THIS CODE IS PROVIDED ON AN *AS IS* BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY -KIND, EITHER EXPRESS OR IMPLIED, INCLUDING WITHOUT LIMITATION ANY IMPLIED -WARRANTIES OR CONDITIONS OF TITLE, FITNESS FOR A PARTICULAR PURPOSE, -MERCHANTABLITY OR NON-INFRINGEMENT. - -See the Apache Version 2.0 License for specific language governing permissions -and limitations under the License. -***************************************************************************** */ - - - -var ts = (() => { - var __defProp = Object.defineProperty; - var __getOwnPropNames = Object.getOwnPropertyNames; - var __esm = (fn, res) => function __init() { - return fn && (res = (0, fn[__getOwnPropNames(fn)[0]])(fn = 0)), res; - }; - var __commonJS = (cb, mod) => function __require() { - return mod || (0, cb[__getOwnPropNames(cb)[0]])((mod = { exports: {} }).exports, mod), mod.exports; - }; - var __export = (target, all) => { - for (var name in all) - __defProp(target, name, { get: all[name], enumerable: true }); - }; - - // src/compiler/corePublic.ts - var versionMajorMinor, version, Comparison; - var init_corePublic = __esm({ - "src/compiler/corePublic.ts"() { - "use strict"; - versionMajorMinor = "5.1"; - version = "5.1.6"; - Comparison = /* @__PURE__ */ ((Comparison3) => { - Comparison3[Comparison3["LessThan"] = -1] = "LessThan"; - Comparison3[Comparison3["EqualTo"] = 0] = "EqualTo"; - Comparison3[Comparison3["GreaterThan"] = 1] = "GreaterThan"; - return Comparison3; - })(Comparison || {}); - } - }); - - // src/compiler/core.ts - function length(array) { - return array ? array.length : 0; - } - function forEach(array, callback) { - if (array) { - for (let i = 0; i < array.length; i++) { - const result = callback(array[i], i); - if (result) { - return result; - } - } - } - return void 0; - } - function forEachRight(array, callback) { - if (array) { - for (let i = array.length - 1; i >= 0; i--) { - const result = callback(array[i], i); - if (result) { - return result; - } - } - } - return void 0; - } - function firstDefined(array, callback) { - if (array === void 0) { - return void 0; - } - for (let i = 0; i < array.length; i++) { - const result = callback(array[i], i); - if (result !== void 0) { - return result; - } - } - return void 0; - } - function firstDefinedIterator(iter, callback) { - for (const value of iter) { - const result = callback(value); - if (result !== void 0) { - return result; - } - } - return void 0; - } - function reduceLeftIterator(iterator, f, initial) { - let result = initial; - if (iterator) { - let pos = 0; - for (const value of iterator) { - result = f(result, value, pos); - pos++; - } - } - return result; - } - function zipWith(arrayA, arrayB, callback) { - const result = []; - Debug.assertEqual(arrayA.length, arrayB.length); - for (let i = 0; i < arrayA.length; i++) { - result.push(callback(arrayA[i], arrayB[i], i)); - } - return result; - } - function intersperse(input, element) { - if (input.length <= 1) { - return input; - } - const result = []; - for (let i = 0, n = input.length; i < n; i++) { - if (i) - result.push(element); - result.push(input[i]); - } - return result; - } - function every(array, callback) { - if (array) { - for (let i = 0; i < array.length; i++) { - if (!callback(array[i], i)) { - return false; - } - } - } - return true; - } - function find(array, predicate, startIndex) { - if (array === void 0) - return void 0; - for (let i = startIndex ?? 0; i < array.length; i++) { - const value = array[i]; - if (predicate(value, i)) { - return value; - } - } - return void 0; - } - function findLast(array, predicate, startIndex) { - if (array === void 0) - return void 0; - for (let i = startIndex ?? array.length - 1; i >= 0; i--) { - const value = array[i]; - if (predicate(value, i)) { - return value; - } - } - return void 0; - } - function findIndex(array, predicate, startIndex) { - if (array === void 0) - return -1; - for (let i = startIndex ?? 0; i < array.length; i++) { - if (predicate(array[i], i)) { - return i; - } - } - return -1; - } - function findLastIndex(array, predicate, startIndex) { - if (array === void 0) - return -1; - for (let i = startIndex ?? array.length - 1; i >= 0; i--) { - if (predicate(array[i], i)) { - return i; - } - } - return -1; - } - function findMap(array, callback) { - for (let i = 0; i < array.length; i++) { - const result = callback(array[i], i); - if (result) { - return result; - } - } - return Debug.fail(); - } - function contains(array, value, equalityComparer = equateValues) { - if (array) { - for (const v of array) { - if (equalityComparer(v, value)) { - return true; - } - } - } - return false; - } - function arraysEqual(a, b, equalityComparer = equateValues) { - return a.length === b.length && a.every((x, i) => equalityComparer(x, b[i])); - } - function indexOfAnyCharCode(text, charCodes, start) { - for (let i = start || 0; i < text.length; i++) { - if (contains(charCodes, text.charCodeAt(i))) { - return i; - } - } - return -1; - } - function countWhere(array, predicate) { - let count = 0; - if (array) { - for (let i = 0; i < array.length; i++) { - const v = array[i]; - if (predicate(v, i)) { - count++; - } - } - } - return count; - } - function filter(array, f) { - if (array) { - const len = array.length; - let i = 0; - while (i < len && f(array[i])) - i++; - if (i < len) { - const result = array.slice(0, i); - i++; - while (i < len) { - const item = array[i]; - if (f(item)) { - result.push(item); - } - i++; - } - return result; - } - } - return array; - } - function filterMutate(array, f) { - let outIndex = 0; - for (let i = 0; i < array.length; i++) { - if (f(array[i], i, array)) { - array[outIndex] = array[i]; - outIndex++; - } - } - array.length = outIndex; - } - function clear(array) { - array.length = 0; - } - function map(array, f) { - let result; - if (array) { - result = []; - for (let i = 0; i < array.length; i++) { - result.push(f(array[i], i)); - } - } - return result; - } - function* mapIterator(iter, mapFn) { - for (const x of iter) { - yield mapFn(x); - } - } - function sameMap(array, f) { - if (array) { - for (let i = 0; i < array.length; i++) { - const item = array[i]; - const mapped = f(item, i); - if (item !== mapped) { - const result = array.slice(0, i); - result.push(mapped); - for (i++; i < array.length; i++) { - result.push(f(array[i], i)); - } - return result; - } - } - } - return array; - } - function flatten(array) { - const result = []; - for (const v of array) { - if (v) { - if (isArray(v)) { - addRange(result, v); - } else { - result.push(v); - } - } - } - return result; - } - function flatMap(array, mapfn) { - let result; - if (array) { - for (let i = 0; i < array.length; i++) { - const v = mapfn(array[i], i); - if (v) { - if (isArray(v)) { - result = addRange(result, v); - } else { - result = append(result, v); - } - } - } - } - return result || emptyArray; - } - function flatMapToMutable(array, mapfn) { - const result = []; - if (array) { - for (let i = 0; i < array.length; i++) { - const v = mapfn(array[i], i); - if (v) { - if (isArray(v)) { - addRange(result, v); - } else { - result.push(v); - } - } - } - } - return result; - } - function* flatMapIterator(iter, mapfn) { - for (const x of iter) { - const iter2 = mapfn(x); - if (!iter2) - continue; - yield* iter2; - } - } - function sameFlatMap(array, mapfn) { - let result; - if (array) { - for (let i = 0; i < array.length; i++) { - const item = array[i]; - const mapped = mapfn(item, i); - if (result || item !== mapped || isArray(mapped)) { - if (!result) { - result = array.slice(0, i); - } - if (isArray(mapped)) { - addRange(result, mapped); - } else { - result.push(mapped); - } - } - } - } - return result || array; - } - function mapAllOrFail(array, mapFn) { - const result = []; - for (let i = 0; i < array.length; i++) { - const mapped = mapFn(array[i], i); - if (mapped === void 0) { - return void 0; - } - result.push(mapped); - } - return result; - } - function mapDefined(array, mapFn) { - const result = []; - if (array) { - for (let i = 0; i < array.length; i++) { - const mapped = mapFn(array[i], i); - if (mapped !== void 0) { - result.push(mapped); - } - } - } - return result; - } - function* mapDefinedIterator(iter, mapFn) { - for (const x of iter) { - const value = mapFn(x); - if (value !== void 0) { - yield value; - } - } - } - function mapDefinedEntries(map2, f) { - if (!map2) { - return void 0; - } - const result = /* @__PURE__ */ new Map(); - map2.forEach((value, key) => { - const entry = f(key, value); - if (entry !== void 0) { - const [newKey, newValue] = entry; - if (newKey !== void 0 && newValue !== void 0) { - result.set(newKey, newValue); - } - } - }); - return result; - } - function getOrUpdate(map2, key, callback) { - if (map2.has(key)) { - return map2.get(key); - } - const value = callback(); - map2.set(key, value); - return value; - } - function tryAddToSet(set, value) { - if (!set.has(value)) { - set.add(value); - return true; - } - return false; - } - function* singleIterator(value) { - yield value; - } - function spanMap(array, keyfn, mapfn) { - let result; - if (array) { - result = []; - const len = array.length; - let previousKey; - let key; - let start = 0; - let pos = 0; - while (start < len) { - while (pos < len) { - const value = array[pos]; - key = keyfn(value, pos); - if (pos === 0) { - previousKey = key; - } else if (key !== previousKey) { - break; - } - pos++; - } - if (start < pos) { - const v = mapfn(array.slice(start, pos), previousKey, start, pos); - if (v) { - result.push(v); - } - start = pos; - } - previousKey = key; - pos++; - } - } - return result; - } - function mapEntries(map2, f) { - if (!map2) { - return void 0; - } - const result = /* @__PURE__ */ new Map(); - map2.forEach((value, key) => { - const [newKey, newValue] = f(key, value); - result.set(newKey, newValue); - }); - return result; - } - function some(array, predicate) { - if (array) { - if (predicate) { - for (const v of array) { - if (predicate(v)) { - return true; - } - } - } else { - return array.length > 0; - } - } - return false; - } - function getRangesWhere(arr, pred, cb) { - let start; - for (let i = 0; i < arr.length; i++) { - if (pred(arr[i])) { - start = start === void 0 ? i : start; - } else { - if (start !== void 0) { - cb(start, i); - start = void 0; - } - } - } - if (start !== void 0) - cb(start, arr.length); - } - function concatenate(array1, array2) { - if (!some(array2)) - return array1; - if (!some(array1)) - return array2; - return [...array1, ...array2]; - } - function selectIndex(_, i) { - return i; - } - function indicesOf(array) { - return array.map(selectIndex); - } - function deduplicateRelational(array, equalityComparer, comparer) { - const indices = indicesOf(array); - stableSortIndices(array, indices, comparer); - let last2 = array[indices[0]]; - const deduplicated = [indices[0]]; - for (let i = 1; i < indices.length; i++) { - const index = indices[i]; - const item = array[index]; - if (!equalityComparer(last2, item)) { - deduplicated.push(index); - last2 = item; - } - } - deduplicated.sort(); - return deduplicated.map((i) => array[i]); - } - function deduplicateEquality(array, equalityComparer) { - const result = []; - for (const item of array) { - pushIfUnique(result, item, equalityComparer); - } - return result; - } - function deduplicate(array, equalityComparer, comparer) { - return array.length === 0 ? [] : array.length === 1 ? array.slice() : comparer ? deduplicateRelational(array, equalityComparer, comparer) : deduplicateEquality(array, equalityComparer); - } - function deduplicateSorted(array, comparer) { - if (array.length === 0) - return emptyArray; - let last2 = array[0]; - const deduplicated = [last2]; - for (let i = 1; i < array.length; i++) { - const next = array[i]; - switch (comparer(next, last2)) { - case true: - case 0 /* EqualTo */: - continue; - case -1 /* LessThan */: - return Debug.fail("Array is unsorted."); - } - deduplicated.push(last2 = next); - } - return deduplicated; - } - function createSortedArray() { - return []; - } - function insertSorted(array, insert, compare, allowDuplicates) { - if (array.length === 0) { - array.push(insert); - return true; - } - const insertIndex = binarySearch(array, insert, identity, compare); - if (insertIndex < 0) { - array.splice(~insertIndex, 0, insert); - return true; - } - if (allowDuplicates) { - array.splice(insertIndex, 0, insert); - return true; - } - return false; - } - function sortAndDeduplicate(array, comparer, equalityComparer) { - return deduplicateSorted(sort(array, comparer), equalityComparer || comparer || compareStringsCaseSensitive); - } - function arrayIsSorted(array, comparer) { - if (array.length < 2) - return true; - for (let i = 1, len = array.length; i < len; i++) { - if (comparer(array[i - 1], array[i]) === 1 /* GreaterThan */) { - return false; - } - } - return true; - } - function detectSortCaseSensitivity(array, getString, compareStringsCaseSensitive2, compareStringsCaseInsensitive2) { - let kind = 3 /* Both */; - if (array.length < 2) - return kind; - let prevElement = getString(array[0]); - for (let i = 1, len = array.length; i < len && kind !== 0 /* None */; i++) { - const element = getString(array[i]); - if (kind & 1 /* CaseSensitive */ && compareStringsCaseSensitive2(prevElement, element) > 0) { - kind &= ~1 /* CaseSensitive */; - } - if (kind & 2 /* CaseInsensitive */ && compareStringsCaseInsensitive2(prevElement, element) > 0) { - kind &= ~2 /* CaseInsensitive */; - } - prevElement = element; - } - return kind; - } - function arrayIsEqualTo(array1, array2, equalityComparer = equateValues) { - if (!array1 || !array2) { - return array1 === array2; - } - if (array1.length !== array2.length) { - return false; - } - for (let i = 0; i < array1.length; i++) { - if (!equalityComparer(array1[i], array2[i], i)) { - return false; - } - } - return true; - } - function compact(array) { - let result; - if (array) { - for (let i = 0; i < array.length; i++) { - const v = array[i]; - if (result || !v) { - if (!result) { - result = array.slice(0, i); - } - if (v) { - result.push(v); - } - } - } - } - return result || array; - } - function relativeComplement(arrayA, arrayB, comparer) { - if (!arrayB || !arrayA || arrayB.length === 0 || arrayA.length === 0) - return arrayB; - const result = []; - loopB: - for (let offsetA = 0, offsetB = 0; offsetB < arrayB.length; offsetB++) { - if (offsetB > 0) { - Debug.assertGreaterThanOrEqual(comparer(arrayB[offsetB], arrayB[offsetB - 1]), 0 /* EqualTo */); - } - loopA: - for (const startA = offsetA; offsetA < arrayA.length; offsetA++) { - if (offsetA > startA) { - Debug.assertGreaterThanOrEqual(comparer(arrayA[offsetA], arrayA[offsetA - 1]), 0 /* EqualTo */); - } - switch (comparer(arrayB[offsetB], arrayA[offsetA])) { - case -1 /* LessThan */: - result.push(arrayB[offsetB]); - continue loopB; - case 0 /* EqualTo */: - continue loopB; - case 1 /* GreaterThan */: - continue loopA; - } - } - } - return result; - } - function append(to, value) { - if (value === void 0) - return to; - if (to === void 0) - return [value]; - to.push(value); - return to; - } - function combine(xs, ys) { - if (xs === void 0) - return ys; - if (ys === void 0) - return xs; - if (isArray(xs)) - return isArray(ys) ? concatenate(xs, ys) : append(xs, ys); - if (isArray(ys)) - return append(ys, xs); - return [xs, ys]; - } - function toOffset(array, offset) { - return offset < 0 ? array.length + offset : offset; - } - function addRange(to, from, start, end) { - if (from === void 0 || from.length === 0) - return to; - if (to === void 0) - return from.slice(start, end); - start = start === void 0 ? 0 : toOffset(from, start); - end = end === void 0 ? from.length : toOffset(from, end); - for (let i = start; i < end && i < from.length; i++) { - if (from[i] !== void 0) { - to.push(from[i]); - } - } - return to; - } - function pushIfUnique(array, toAdd, equalityComparer) { - if (contains(array, toAdd, equalityComparer)) { - return false; - } else { - array.push(toAdd); - return true; - } - } - function appendIfUnique(array, toAdd, equalityComparer) { - if (array) { - pushIfUnique(array, toAdd, equalityComparer); - return array; - } else { - return [toAdd]; - } - } - function stableSortIndices(array, indices, comparer) { - indices.sort((x, y) => comparer(array[x], array[y]) || compareValues(x, y)); - } - function sort(array, comparer) { - return array.length === 0 ? array : array.slice().sort(comparer); - } - function* arrayReverseIterator(array) { - for (let i = array.length - 1; i >= 0; i--) { - yield array[i]; - } - } - function stableSort(array, comparer) { - const indices = indicesOf(array); - stableSortIndices(array, indices, comparer); - return indices.map((i) => array[i]); - } - function rangeEquals(array1, array2, pos, end) { - while (pos < end) { - if (array1[pos] !== array2[pos]) { - return false; - } - pos++; - } - return true; - } - function firstOrUndefined(array) { - return array === void 0 || array.length === 0 ? void 0 : array[0]; - } - function firstOrUndefinedIterator(iter) { - if (iter) { - for (const value of iter) { - return value; - } - } - return void 0; - } - function first(array) { - Debug.assert(array.length !== 0); - return array[0]; - } - function firstIterator(iter) { - for (const value of iter) { - return value; - } - Debug.fail("iterator is empty"); - } - function lastOrUndefined(array) { - return array === void 0 || array.length === 0 ? void 0 : array[array.length - 1]; - } - function last(array) { - Debug.assert(array.length !== 0); - return array[array.length - 1]; - } - function singleOrUndefined(array) { - return array && array.length === 1 ? array[0] : void 0; - } - function single(array) { - return Debug.checkDefined(singleOrUndefined(array)); - } - function singleOrMany(array) { - return array && array.length === 1 ? array[0] : array; - } - function replaceElement(array, index, value) { - const result = array.slice(0); - result[index] = value; - return result; - } - function binarySearch(array, value, keySelector, keyComparer, offset) { - return binarySearchKey(array, keySelector(value), keySelector, keyComparer, offset); - } - function binarySearchKey(array, key, keySelector, keyComparer, offset) { - if (!some(array)) { - return -1; - } - let low = offset || 0; - let high = array.length - 1; - while (low <= high) { - const middle = low + (high - low >> 1); - const midKey = keySelector(array[middle], middle); - switch (keyComparer(midKey, key)) { - case -1 /* LessThan */: - low = middle + 1; - break; - case 0 /* EqualTo */: - return middle; - case 1 /* GreaterThan */: - high = middle - 1; - break; - } - } - return ~low; - } - function reduceLeft(array, f, initial, start, count) { - if (array && array.length > 0) { - const size = array.length; - if (size > 0) { - let pos = start === void 0 || start < 0 ? 0 : start; - const end = count === void 0 || pos + count > size - 1 ? size - 1 : pos + count; - let result; - if (arguments.length <= 2) { - result = array[pos]; - pos++; - } else { - result = initial; - } - while (pos <= end) { - result = f(result, array[pos], pos); - pos++; - } - return result; - } - } - return initial; - } - function hasProperty(map2, key) { - return hasOwnProperty.call(map2, key); - } - function getProperty(map2, key) { - return hasOwnProperty.call(map2, key) ? map2[key] : void 0; - } - function getOwnKeys(map2) { - const keys = []; - for (const key in map2) { - if (hasOwnProperty.call(map2, key)) { - keys.push(key); - } - } - return keys; - } - function getAllKeys(obj) { - const result = []; - do { - const names = Object.getOwnPropertyNames(obj); - for (const name of names) { - pushIfUnique(result, name); - } - } while (obj = Object.getPrototypeOf(obj)); - return result; - } - function getOwnValues(collection) { - const values = []; - for (const key in collection) { - if (hasOwnProperty.call(collection, key)) { - values.push(collection[key]); - } - } - return values; - } - function arrayOf(count, f) { - const result = new Array(count); - for (let i = 0; i < count; i++) { - result[i] = f(i); - } - return result; - } - function arrayFrom(iterator, map2) { - const result = []; - for (const value of iterator) { - result.push(map2 ? map2(value) : value); - } - return result; - } - function assign(t, ...args) { - for (const arg of args) { - if (arg === void 0) - continue; - for (const p in arg) { - if (hasProperty(arg, p)) { - t[p] = arg[p]; - } - } - } - return t; - } - function equalOwnProperties(left, right, equalityComparer = equateValues) { - if (left === right) - return true; - if (!left || !right) - return false; - for (const key in left) { - if (hasOwnProperty.call(left, key)) { - if (!hasOwnProperty.call(right, key)) - return false; - if (!equalityComparer(left[key], right[key])) - return false; - } - } - for (const key in right) { - if (hasOwnProperty.call(right, key)) { - if (!hasOwnProperty.call(left, key)) - return false; - } - } - return true; - } - function arrayToMap(array, makeKey, makeValue = identity) { - const result = /* @__PURE__ */ new Map(); - for (const value of array) { - const key = makeKey(value); - if (key !== void 0) - result.set(key, makeValue(value)); - } - return result; - } - function arrayToNumericMap(array, makeKey, makeValue = identity) { - const result = []; - for (const value of array) { - result[makeKey(value)] = makeValue(value); - } - return result; - } - function arrayToMultiMap(values, makeKey, makeValue = identity) { - const result = createMultiMap(); - for (const value of values) { - result.add(makeKey(value), makeValue(value)); - } - return result; - } - function group(values, getGroupId, resultSelector = identity) { - return arrayFrom(arrayToMultiMap(values, getGroupId).values(), resultSelector); - } - function groupBy(values, keySelector) { - const result = {}; - if (values) { - for (const value of values) { - const key = `${keySelector(value)}`; - const array = result[key] ?? (result[key] = []); - array.push(value); - } - } - return result; - } - function clone(object) { - const result = {}; - for (const id in object) { - if (hasOwnProperty.call(object, id)) { - result[id] = object[id]; - } - } - return result; - } - function extend(first2, second) { - const result = {}; - for (const id in second) { - if (hasOwnProperty.call(second, id)) { - result[id] = second[id]; - } - } - for (const id in first2) { - if (hasOwnProperty.call(first2, id)) { - result[id] = first2[id]; - } - } - return result; - } - function copyProperties(first2, second) { - for (const id in second) { - if (hasOwnProperty.call(second, id)) { - first2[id] = second[id]; - } - } - } - function maybeBind(obj, fn) { - return fn ? fn.bind(obj) : void 0; - } - function createMultiMap() { - const map2 = /* @__PURE__ */ new Map(); - map2.add = multiMapAdd; - map2.remove = multiMapRemove; - return map2; - } - function multiMapAdd(key, value) { - let values = this.get(key); - if (values) { - values.push(value); - } else { - this.set(key, values = [value]); - } - return values; - } - function multiMapRemove(key, value) { - const values = this.get(key); - if (values) { - unorderedRemoveItem(values, value); - if (!values.length) { - this.delete(key); - } - } - } - function createQueue(items) { - const elements = (items == null ? void 0 : items.slice()) || []; - let headIndex = 0; - function isEmpty() { - return headIndex === elements.length; - } - function enqueue(...items2) { - elements.push(...items2); - } - function dequeue() { - if (isEmpty()) { - throw new Error("Queue is empty"); - } - const result = elements[headIndex]; - elements[headIndex] = void 0; - headIndex++; - if (headIndex > 100 && headIndex > elements.length >> 1) { - const newLength = elements.length - headIndex; - elements.copyWithin( - /*target*/ - 0, - /*start*/ - headIndex - ); - elements.length = newLength; - headIndex = 0; - } - return result; - } - return { - enqueue, - dequeue, - isEmpty - }; - } - function createSet(getHashCode, equals) { - const multiMap = /* @__PURE__ */ new Map(); - let size = 0; - function* getElementIterator() { - for (const value of multiMap.values()) { - if (isArray(value)) { - yield* value; - } else { - yield value; - } - } - } - const set = { - has(element) { - const hash = getHashCode(element); - if (!multiMap.has(hash)) - return false; - const candidates = multiMap.get(hash); - if (!isArray(candidates)) - return equals(candidates, element); - for (const candidate of candidates) { - if (equals(candidate, element)) { - return true; - } - } - return false; - }, - add(element) { - const hash = getHashCode(element); - if (multiMap.has(hash)) { - const values = multiMap.get(hash); - if (isArray(values)) { - if (!contains(values, element, equals)) { - values.push(element); - size++; - } - } else { - const value = values; - if (!equals(value, element)) { - multiMap.set(hash, [value, element]); - size++; - } - } - } else { - multiMap.set(hash, element); - size++; - } - return this; - }, - delete(element) { - const hash = getHashCode(element); - if (!multiMap.has(hash)) - return false; - const candidates = multiMap.get(hash); - if (isArray(candidates)) { - for (let i = 0; i < candidates.length; i++) { - if (equals(candidates[i], element)) { - if (candidates.length === 1) { - multiMap.delete(hash); - } else if (candidates.length === 2) { - multiMap.set(hash, candidates[1 - i]); - } else { - unorderedRemoveItemAt(candidates, i); - } - size--; - return true; - } - } - } else { - const candidate = candidates; - if (equals(candidate, element)) { - multiMap.delete(hash); - size--; - return true; - } - } - return false; - }, - clear() { - multiMap.clear(); - size = 0; - }, - get size() { - return size; - }, - forEach(action) { - for (const elements of arrayFrom(multiMap.values())) { - if (isArray(elements)) { - for (const element of elements) { - action(element, element, set); - } - } else { - const element = elements; - action(element, element, set); - } - } - }, - keys() { - return getElementIterator(); - }, - values() { - return getElementIterator(); - }, - *entries() { - for (const value of getElementIterator()) { - yield [value, value]; - } - }, - [Symbol.iterator]: () => { - return getElementIterator(); - }, - [Symbol.toStringTag]: multiMap[Symbol.toStringTag] - }; - return set; - } - function isArray(value) { - return Array.isArray(value); - } - function toArray(value) { - return isArray(value) ? value : [value]; - } - function isString(text) { - return typeof text === "string"; - } - function isNumber(x) { - return typeof x === "number"; - } - function tryCast(value, test) { - return value !== void 0 && test(value) ? value : void 0; - } - function cast(value, test) { - if (value !== void 0 && test(value)) - return value; - return Debug.fail(`Invalid cast. The supplied value ${value} did not pass the test '${Debug.getFunctionName(test)}'.`); - } - function noop(_) { - } - function returnFalse() { - return false; - } - function returnTrue() { - return true; - } - function returnUndefined() { - return void 0; - } - function identity(x) { - return x; - } - function toLowerCase(x) { - return x.toLowerCase(); - } - function toFileNameLowerCase(x) { - return fileNameLowerCaseRegExp.test(x) ? x.replace(fileNameLowerCaseRegExp, toLowerCase) : x; - } - function notImplemented() { - throw new Error("Not implemented"); - } - function memoize(callback) { - let value; - return () => { - if (callback) { - value = callback(); - callback = void 0; - } - return value; - }; - } - function memoizeOne(callback) { - const map2 = /* @__PURE__ */ new Map(); - return (arg) => { - const key = `${typeof arg}:${arg}`; - let value = map2.get(key); - if (value === void 0 && !map2.has(key)) { - value = callback(arg); - map2.set(key, value); - } - return value; - }; - } - function memoizeWeak(callback) { - const map2 = /* @__PURE__ */ new WeakMap(); - return (arg) => { - let value = map2.get(arg); - if (value === void 0 && !map2.has(arg)) { - value = callback(arg); - map2.set(arg, value); - } - return value; - }; - } - function memoizeCached(callback, cache) { - return (...args) => { - let value = cache.get(args); - if (value === void 0 && !cache.has(args)) { - value = callback(...args); - cache.set(args, value); - } - return value; - }; - } - function compose(a, b, c, d, e) { - if (!!e) { - const args = []; - for (let i = 0; i < arguments.length; i++) { - args[i] = arguments[i]; - } - return (t) => reduceLeft(args, (u, f) => f(u), t); - } else if (d) { - return (t) => d(c(b(a(t)))); - } else if (c) { - return (t) => c(b(a(t))); - } else if (b) { - return (t) => b(a(t)); - } else if (a) { - return (t) => a(t); - } else { - return (t) => t; - } - } - function equateValues(a, b) { - return a === b; - } - function equateStringsCaseInsensitive(a, b) { - return a === b || a !== void 0 && b !== void 0 && a.toUpperCase() === b.toUpperCase(); - } - function equateStringsCaseSensitive(a, b) { - return equateValues(a, b); - } - function compareComparableValues(a, b) { - return a === b ? 0 /* EqualTo */ : a === void 0 ? -1 /* LessThan */ : b === void 0 ? 1 /* GreaterThan */ : a < b ? -1 /* LessThan */ : 1 /* GreaterThan */; - } - function compareValues(a, b) { - return compareComparableValues(a, b); - } - function compareTextSpans(a, b) { - return compareValues(a == null ? void 0 : a.start, b == null ? void 0 : b.start) || compareValues(a == null ? void 0 : a.length, b == null ? void 0 : b.length); - } - function min(items, compare) { - return reduceLeft(items, (x, y) => compare(x, y) === -1 /* LessThan */ ? x : y); - } - function compareStringsCaseInsensitive(a, b) { - if (a === b) - return 0 /* EqualTo */; - if (a === void 0) - return -1 /* LessThan */; - if (b === void 0) - return 1 /* GreaterThan */; - a = a.toUpperCase(); - b = b.toUpperCase(); - return a < b ? -1 /* LessThan */ : a > b ? 1 /* GreaterThan */ : 0 /* EqualTo */; - } - function compareStringsCaseInsensitiveEslintCompatible(a, b) { - if (a === b) - return 0 /* EqualTo */; - if (a === void 0) - return -1 /* LessThan */; - if (b === void 0) - return 1 /* GreaterThan */; - a = a.toLowerCase(); - b = b.toLowerCase(); - return a < b ? -1 /* LessThan */ : a > b ? 1 /* GreaterThan */ : 0 /* EqualTo */; - } - function compareStringsCaseSensitive(a, b) { - return compareComparableValues(a, b); - } - function getStringComparer(ignoreCase) { - return ignoreCase ? compareStringsCaseInsensitive : compareStringsCaseSensitive; - } - function getUILocale() { - return uiLocale; - } - function setUILocale(value) { - if (uiLocale !== value) { - uiLocale = value; - uiComparerCaseSensitive = void 0; - } - } - function compareStringsCaseSensitiveUI(a, b) { - const comparer = uiComparerCaseSensitive || (uiComparerCaseSensitive = createUIStringComparer(uiLocale)); - return comparer(a, b); - } - function compareProperties(a, b, key, comparer) { - return a === b ? 0 /* EqualTo */ : a === void 0 ? -1 /* LessThan */ : b === void 0 ? 1 /* GreaterThan */ : comparer(a[key], b[key]); - } - function compareBooleans(a, b) { - return compareValues(a ? 1 : 0, b ? 1 : 0); - } - function getSpellingSuggestion(name, candidates, getName) { - const maximumLengthDifference = Math.max(2, Math.floor(name.length * 0.34)); - let bestDistance = Math.floor(name.length * 0.4) + 1; - let bestCandidate; - for (const candidate of candidates) { - const candidateName = getName(candidate); - if (candidateName !== void 0 && Math.abs(candidateName.length - name.length) <= maximumLengthDifference) { - if (candidateName === name) { - continue; - } - if (candidateName.length < 3 && candidateName.toLowerCase() !== name.toLowerCase()) { - continue; - } - const distance = levenshteinWithMax(name, candidateName, bestDistance - 0.1); - if (distance === void 0) { - continue; - } - Debug.assert(distance < bestDistance); - bestDistance = distance; - bestCandidate = candidate; - } - } - return bestCandidate; - } - function levenshteinWithMax(s1, s2, max) { - let previous = new Array(s2.length + 1); - let current = new Array(s2.length + 1); - const big = max + 0.01; - for (let i = 0; i <= s2.length; i++) { - previous[i] = i; - } - for (let i = 1; i <= s1.length; i++) { - const c1 = s1.charCodeAt(i - 1); - const minJ = Math.ceil(i > max ? i - max : 1); - const maxJ = Math.floor(s2.length > max + i ? max + i : s2.length); - current[0] = i; - let colMin = i; - for (let j = 1; j < minJ; j++) { - current[j] = big; - } - for (let j = minJ; j <= maxJ; j++) { - const substitutionDistance = s1[i - 1].toLowerCase() === s2[j - 1].toLowerCase() ? previous[j - 1] + 0.1 : previous[j - 1] + 2; - const dist = c1 === s2.charCodeAt(j - 1) ? previous[j - 1] : Math.min( - /*delete*/ - previous[j] + 1, - /*insert*/ - current[j - 1] + 1, - /*substitute*/ - substitutionDistance - ); - current[j] = dist; - colMin = Math.min(colMin, dist); - } - for (let j = maxJ + 1; j <= s2.length; j++) { - current[j] = big; - } - if (colMin > max) { - return void 0; - } - const temp = previous; - previous = current; - current = temp; - } - const res = previous[s2.length]; - return res > max ? void 0 : res; - } - function endsWith(str, suffix) { - const expectedPos = str.length - suffix.length; - return expectedPos >= 0 && str.indexOf(suffix, expectedPos) === expectedPos; - } - function removeSuffix(str, suffix) { - return endsWith(str, suffix) ? str.slice(0, str.length - suffix.length) : str; - } - function tryRemoveSuffix(str, suffix) { - return endsWith(str, suffix) ? str.slice(0, str.length - suffix.length) : void 0; - } - function stringContains(str, substring) { - return str.indexOf(substring) !== -1; - } - function removeMinAndVersionNumbers(fileName) { - let end = fileName.length; - for (let pos = end - 1; pos > 0; pos--) { - let ch = fileName.charCodeAt(pos); - if (ch >= 48 /* _0 */ && ch <= 57 /* _9 */) { - do { - --pos; - ch = fileName.charCodeAt(pos); - } while (pos > 0 && ch >= 48 /* _0 */ && ch <= 57 /* _9 */); - } else if (pos > 4 && (ch === 110 /* n */ || ch === 78 /* N */)) { - --pos; - ch = fileName.charCodeAt(pos); - if (ch !== 105 /* i */ && ch !== 73 /* I */) { - break; - } - --pos; - ch = fileName.charCodeAt(pos); - if (ch !== 109 /* m */ && ch !== 77 /* M */) { - break; - } - --pos; - ch = fileName.charCodeAt(pos); - } else { - break; - } - if (ch !== 45 /* minus */ && ch !== 46 /* dot */) { - break; - } - end = pos; - } - return end === fileName.length ? fileName : fileName.slice(0, end); - } - function orderedRemoveItem(array, item) { - for (let i = 0; i < array.length; i++) { - if (array[i] === item) { - orderedRemoveItemAt(array, i); - return true; - } - } - return false; - } - function orderedRemoveItemAt(array, index) { - for (let i = index; i < array.length - 1; i++) { - array[i] = array[i + 1]; - } - array.pop(); - } - function unorderedRemoveItemAt(array, index) { - array[index] = array[array.length - 1]; - array.pop(); - } - function unorderedRemoveItem(array, item) { - return unorderedRemoveFirstItemWhere(array, (element) => element === item); - } - function unorderedRemoveFirstItemWhere(array, predicate) { - for (let i = 0; i < array.length; i++) { - if (predicate(array[i])) { - unorderedRemoveItemAt(array, i); - return true; - } - } - return false; - } - function createGetCanonicalFileName(useCaseSensitiveFileNames) { - return useCaseSensitiveFileNames ? identity : toFileNameLowerCase; - } - function patternText({ prefix, suffix }) { - return `${prefix}*${suffix}`; - } - function matchedText(pattern, candidate) { - Debug.assert(isPatternMatch(pattern, candidate)); - return candidate.substring(pattern.prefix.length, candidate.length - pattern.suffix.length); - } - function findBestPatternMatch(values, getPattern, candidate) { - let matchedValue; - let longestMatchPrefixLength = -1; - for (const v of values) { - const pattern = getPattern(v); - if (isPatternMatch(pattern, candidate) && pattern.prefix.length > longestMatchPrefixLength) { - longestMatchPrefixLength = pattern.prefix.length; - matchedValue = v; - } - } - return matchedValue; - } - function startsWith(str, prefix) { - return str.lastIndexOf(prefix, 0) === 0; - } - function removePrefix(str, prefix) { - return startsWith(str, prefix) ? str.substr(prefix.length) : str; - } - function tryRemovePrefix(str, prefix, getCanonicalFileName = identity) { - return startsWith(getCanonicalFileName(str), getCanonicalFileName(prefix)) ? str.substring(prefix.length) : void 0; - } - function isPatternMatch({ prefix, suffix }, candidate) { - return candidate.length >= prefix.length + suffix.length && startsWith(candidate, prefix) && endsWith(candidate, suffix); - } - function and(f, g) { - return (arg) => f(arg) && g(arg); - } - function or(...fs) { - return (...args) => { - let lastResult; - for (const f of fs) { - lastResult = f(...args); - if (lastResult) { - return lastResult; - } - } - return lastResult; - }; - } - function not(fn) { - return (...args) => !fn(...args); - } - function assertType(_) { - } - function singleElementArray(t) { - return t === void 0 ? void 0 : [t]; - } - function enumerateInsertsAndDeletes(newItems, oldItems, comparer, inserted, deleted, unchanged) { - unchanged = unchanged || noop; - let newIndex = 0; - let oldIndex = 0; - const newLen = newItems.length; - const oldLen = oldItems.length; - let hasChanges = false; - while (newIndex < newLen && oldIndex < oldLen) { - const newItem = newItems[newIndex]; - const oldItem = oldItems[oldIndex]; - const compareResult = comparer(newItem, oldItem); - if (compareResult === -1 /* LessThan */) { - inserted(newItem); - newIndex++; - hasChanges = true; - } else if (compareResult === 1 /* GreaterThan */) { - deleted(oldItem); - oldIndex++; - hasChanges = true; - } else { - unchanged(oldItem, newItem); - newIndex++; - oldIndex++; - } - } - while (newIndex < newLen) { - inserted(newItems[newIndex++]); - hasChanges = true; - } - while (oldIndex < oldLen) { - deleted(oldItems[oldIndex++]); - hasChanges = true; - } - return hasChanges; - } - function cartesianProduct(arrays) { - const result = []; - cartesianProductWorker( - arrays, - result, - /*outer*/ - void 0, - 0 - ); - return result; - } - function cartesianProductWorker(arrays, result, outer, index) { - for (const element of arrays[index]) { - let inner; - if (outer) { - inner = outer.slice(); - inner.push(element); - } else { - inner = [element]; - } - if (index === arrays.length - 1) { - result.push(inner); - } else { - cartesianProductWorker(arrays, result, inner, index + 1); - } - } - } - function padLeft(s, length2, padString = " ") { - return length2 <= s.length ? s : padString.repeat(length2 - s.length) + s; - } - function padRight(s, length2, padString = " ") { - return length2 <= s.length ? s : s + padString.repeat(length2 - s.length); - } - function takeWhile(array, predicate) { - if (array) { - const len = array.length; - let index = 0; - while (index < len && predicate(array[index])) { - index++; - } - return array.slice(0, index); - } - } - function skipWhile(array, predicate) { - if (array) { - const len = array.length; - let index = 0; - while (index < len && predicate(array[index])) { - index++; - } - return array.slice(index); - } - } - function trimEndImpl(s) { - let end = s.length - 1; - while (end >= 0) { - if (!isWhiteSpaceLike(s.charCodeAt(end))) - break; - end--; - } - return s.slice(0, end + 1); - } - function isNodeLikeSystem() { - return typeof process !== "undefined" && !!process.nextTick && !process.browser && "object" === "object"; - } - var emptyArray, emptyMap, emptySet, SortKind, elementAt, hasOwnProperty, fileNameLowerCaseRegExp, AssertionLevel, createUIStringComparer, uiComparerCaseSensitive, uiLocale, trimString, trimStringEnd, trimStringStart; - var init_core = __esm({ - "src/compiler/core.ts"() { - "use strict"; - init_ts2(); - emptyArray = []; - emptyMap = /* @__PURE__ */ new Map(); - emptySet = /* @__PURE__ */ new Set(); - SortKind = /* @__PURE__ */ ((SortKind2) => { - SortKind2[SortKind2["None"] = 0] = "None"; - SortKind2[SortKind2["CaseSensitive"] = 1] = "CaseSensitive"; - SortKind2[SortKind2["CaseInsensitive"] = 2] = "CaseInsensitive"; - SortKind2[SortKind2["Both"] = 3] = "Both"; - return SortKind2; - })(SortKind || {}); - elementAt = !!Array.prototype.at ? (array, offset) => array == null ? void 0 : array.at(offset) : (array, offset) => { - if (array) { - offset = toOffset(array, offset); - if (offset < array.length) { - return array[offset]; - } - } - return void 0; - }; - hasOwnProperty = Object.prototype.hasOwnProperty; - fileNameLowerCaseRegExp = /[^\u0130\u0131\u00DFa-z0-9\\/:\-_\. ]+/g; - AssertionLevel = /* @__PURE__ */ ((AssertionLevel2) => { - AssertionLevel2[AssertionLevel2["None"] = 0] = "None"; - AssertionLevel2[AssertionLevel2["Normal"] = 1] = "Normal"; - AssertionLevel2[AssertionLevel2["Aggressive"] = 2] = "Aggressive"; - AssertionLevel2[AssertionLevel2["VeryAggressive"] = 3] = "VeryAggressive"; - return AssertionLevel2; - })(AssertionLevel || {}); - createUIStringComparer = (() => { - let defaultComparer; - let enUSComparer; - const stringComparerFactory = getStringComparerFactory(); - return createStringComparer; - function compareWithCallback(a, b, comparer) { - if (a === b) - return 0 /* EqualTo */; - if (a === void 0) - return -1 /* LessThan */; - if (b === void 0) - return 1 /* GreaterThan */; - const value = comparer(a, b); - return value < 0 ? -1 /* LessThan */ : value > 0 ? 1 /* GreaterThan */ : 0 /* EqualTo */; - } - function createIntlCollatorStringComparer(locale) { - const comparer = new Intl.Collator(locale, { usage: "sort", sensitivity: "variant" }).compare; - return (a, b) => compareWithCallback(a, b, comparer); - } - function createLocaleCompareStringComparer(locale) { - if (locale !== void 0) - return createFallbackStringComparer(); - return (a, b) => compareWithCallback(a, b, compareStrings); - function compareStrings(a, b) { - return a.localeCompare(b); - } - } - function createFallbackStringComparer() { - return (a, b) => compareWithCallback(a, b, compareDictionaryOrder); - function compareDictionaryOrder(a, b) { - return compareStrings(a.toUpperCase(), b.toUpperCase()) || compareStrings(a, b); - } - function compareStrings(a, b) { - return a < b ? -1 /* LessThan */ : a > b ? 1 /* GreaterThan */ : 0 /* EqualTo */; - } - } - function getStringComparerFactory() { - if (typeof Intl === "object" && typeof Intl.Collator === "function") { - return createIntlCollatorStringComparer; - } - if (typeof String.prototype.localeCompare === "function" && typeof String.prototype.toLocaleUpperCase === "function" && "a".localeCompare("B") < 0) { - return createLocaleCompareStringComparer; - } - return createFallbackStringComparer; - } - function createStringComparer(locale) { - if (locale === void 0) { - return defaultComparer || (defaultComparer = stringComparerFactory(locale)); - } else if (locale === "en-US") { - return enUSComparer || (enUSComparer = stringComparerFactory(locale)); - } else { - return stringComparerFactory(locale); - } - } - })(); - trimString = !!String.prototype.trim ? (s) => s.trim() : (s) => trimStringEnd(trimStringStart(s)); - trimStringEnd = !!String.prototype.trimEnd ? (s) => s.trimEnd() : trimEndImpl; - trimStringStart = !!String.prototype.trimStart ? (s) => s.trimStart() : (s) => s.replace(/^\s+/g, ""); - } - }); - - // src/compiler/debug.ts - var LogLevel, Debug; - var init_debug = __esm({ - "src/compiler/debug.ts"() { - "use strict"; - init_ts2(); - init_ts2(); - LogLevel = /* @__PURE__ */ ((LogLevel2) => { - LogLevel2[LogLevel2["Off"] = 0] = "Off"; - LogLevel2[LogLevel2["Error"] = 1] = "Error"; - LogLevel2[LogLevel2["Warning"] = 2] = "Warning"; - LogLevel2[LogLevel2["Info"] = 3] = "Info"; - LogLevel2[LogLevel2["Verbose"] = 4] = "Verbose"; - return LogLevel2; - })(LogLevel || {}); - ((Debug2) => { - let currentAssertionLevel = 0 /* None */; - Debug2.currentLogLevel = 2 /* Warning */; - Debug2.isDebugging = false; - function shouldLog(level) { - return Debug2.currentLogLevel <= level; - } - Debug2.shouldLog = shouldLog; - function logMessage(level, s) { - if (Debug2.loggingHost && shouldLog(level)) { - Debug2.loggingHost.log(level, s); - } - } - function log(s) { - logMessage(3 /* Info */, s); - } - Debug2.log = log; - ((_log) => { - function error(s) { - logMessage(1 /* Error */, s); - } - _log.error = error; - function warn(s) { - logMessage(2 /* Warning */, s); - } - _log.warn = warn; - function log2(s) { - logMessage(3 /* Info */, s); - } - _log.log = log2; - function trace2(s) { - logMessage(4 /* Verbose */, s); - } - _log.trace = trace2; - })(log = Debug2.log || (Debug2.log = {})); - const assertionCache = {}; - function getAssertionLevel() { - return currentAssertionLevel; - } - Debug2.getAssertionLevel = getAssertionLevel; - function setAssertionLevel(level) { - const prevAssertionLevel = currentAssertionLevel; - currentAssertionLevel = level; - if (level > prevAssertionLevel) { - for (const key of getOwnKeys(assertionCache)) { - const cachedFunc = assertionCache[key]; - if (cachedFunc !== void 0 && Debug2[key] !== cachedFunc.assertion && level >= cachedFunc.level) { - Debug2[key] = cachedFunc; - assertionCache[key] = void 0; - } - } - } - } - Debug2.setAssertionLevel = setAssertionLevel; - function shouldAssert(level) { - return currentAssertionLevel >= level; - } - Debug2.shouldAssert = shouldAssert; - function shouldAssertFunction(level, name) { - if (!shouldAssert(level)) { - assertionCache[name] = { level, assertion: Debug2[name] }; - Debug2[name] = noop; - return false; - } - return true; - } - function fail(message, stackCrawlMark) { - debugger; - const e = new Error(message ? `Debug Failure. ${message}` : "Debug Failure."); - if (Error.captureStackTrace) { - Error.captureStackTrace(e, stackCrawlMark || fail); - } - throw e; - } - Debug2.fail = fail; - function failBadSyntaxKind(node, message, stackCrawlMark) { - return fail( - `${message || "Unexpected node."}\r -Node ${formatSyntaxKind(node.kind)} was unexpected.`, - stackCrawlMark || failBadSyntaxKind - ); - } - Debug2.failBadSyntaxKind = failBadSyntaxKind; - function assert(expression, message, verboseDebugInfo, stackCrawlMark) { - if (!expression) { - message = message ? `False expression: ${message}` : "False expression."; - if (verboseDebugInfo) { - message += "\r\nVerbose Debug Information: " + (typeof verboseDebugInfo === "string" ? verboseDebugInfo : verboseDebugInfo()); - } - fail(message, stackCrawlMark || assert); - } - } - Debug2.assert = assert; - function assertEqual(a, b, msg, msg2, stackCrawlMark) { - if (a !== b) { - const message = msg ? msg2 ? `${msg} ${msg2}` : msg : ""; - fail(`Expected ${a} === ${b}. ${message}`, stackCrawlMark || assertEqual); - } - } - Debug2.assertEqual = assertEqual; - function assertLessThan(a, b, msg, stackCrawlMark) { - if (a >= b) { - fail(`Expected ${a} < ${b}. ${msg || ""}`, stackCrawlMark || assertLessThan); - } - } - Debug2.assertLessThan = assertLessThan; - function assertLessThanOrEqual(a, b, stackCrawlMark) { - if (a > b) { - fail(`Expected ${a} <= ${b}`, stackCrawlMark || assertLessThanOrEqual); - } - } - Debug2.assertLessThanOrEqual = assertLessThanOrEqual; - function assertGreaterThanOrEqual(a, b, stackCrawlMark) { - if (a < b) { - fail(`Expected ${a} >= ${b}`, stackCrawlMark || assertGreaterThanOrEqual); - } - } - Debug2.assertGreaterThanOrEqual = assertGreaterThanOrEqual; - function assertIsDefined(value, message, stackCrawlMark) { - if (value === void 0 || value === null) { - fail(message, stackCrawlMark || assertIsDefined); - } - } - Debug2.assertIsDefined = assertIsDefined; - function checkDefined(value, message, stackCrawlMark) { - assertIsDefined(value, message, stackCrawlMark || checkDefined); - return value; - } - Debug2.checkDefined = checkDefined; - function assertEachIsDefined(value, message, stackCrawlMark) { - for (const v of value) { - assertIsDefined(v, message, stackCrawlMark || assertEachIsDefined); - } - } - Debug2.assertEachIsDefined = assertEachIsDefined; - function checkEachDefined(value, message, stackCrawlMark) { - assertEachIsDefined(value, message, stackCrawlMark || checkEachDefined); - return value; - } - Debug2.checkEachDefined = checkEachDefined; - function assertNever(member, message = "Illegal value:", stackCrawlMark) { - const detail = typeof member === "object" && hasProperty(member, "kind") && hasProperty(member, "pos") ? "SyntaxKind: " + formatSyntaxKind(member.kind) : JSON.stringify(member); - return fail(`${message} ${detail}`, stackCrawlMark || assertNever); - } - Debug2.assertNever = assertNever; - function assertEachNode(nodes, test, message, stackCrawlMark) { - if (shouldAssertFunction(1 /* Normal */, "assertEachNode")) { - assert( - test === void 0 || every(nodes, test), - message || "Unexpected node.", - () => `Node array did not pass test '${getFunctionName(test)}'.`, - stackCrawlMark || assertEachNode - ); - } - } - Debug2.assertEachNode = assertEachNode; - function assertNode(node, test, message, stackCrawlMark) { - if (shouldAssertFunction(1 /* Normal */, "assertNode")) { - assert( - node !== void 0 && (test === void 0 || test(node)), - message || "Unexpected node.", - () => `Node ${formatSyntaxKind(node == null ? void 0 : node.kind)} did not pass test '${getFunctionName(test)}'.`, - stackCrawlMark || assertNode - ); - } - } - Debug2.assertNode = assertNode; - function assertNotNode(node, test, message, stackCrawlMark) { - if (shouldAssertFunction(1 /* Normal */, "assertNotNode")) { - assert( - node === void 0 || test === void 0 || !test(node), - message || "Unexpected node.", - () => `Node ${formatSyntaxKind(node.kind)} should not have passed test '${getFunctionName(test)}'.`, - stackCrawlMark || assertNotNode - ); - } - } - Debug2.assertNotNode = assertNotNode; - function assertOptionalNode(node, test, message, stackCrawlMark) { - if (shouldAssertFunction(1 /* Normal */, "assertOptionalNode")) { - assert( - test === void 0 || node === void 0 || test(node), - message || "Unexpected node.", - () => `Node ${formatSyntaxKind(node == null ? void 0 : node.kind)} did not pass test '${getFunctionName(test)}'.`, - stackCrawlMark || assertOptionalNode - ); - } - } - Debug2.assertOptionalNode = assertOptionalNode; - function assertOptionalToken(node, kind, message, stackCrawlMark) { - if (shouldAssertFunction(1 /* Normal */, "assertOptionalToken")) { - assert( - kind === void 0 || node === void 0 || node.kind === kind, - message || "Unexpected node.", - () => `Node ${formatSyntaxKind(node == null ? void 0 : node.kind)} was not a '${formatSyntaxKind(kind)}' token.`, - stackCrawlMark || assertOptionalToken - ); - } - } - Debug2.assertOptionalToken = assertOptionalToken; - function assertMissingNode(node, message, stackCrawlMark) { - if (shouldAssertFunction(1 /* Normal */, "assertMissingNode")) { - assert( - node === void 0, - message || "Unexpected node.", - () => `Node ${formatSyntaxKind(node.kind)} was unexpected'.`, - stackCrawlMark || assertMissingNode - ); - } - } - Debug2.assertMissingNode = assertMissingNode; - function type(_value) { - } - Debug2.type = type; - function getFunctionName(func) { - if (typeof func !== "function") { - return ""; - } else if (hasProperty(func, "name")) { - return func.name; - } else { - const text = Function.prototype.toString.call(func); - const match = /^function\s+([\w\$]+)\s*\(/.exec(text); - return match ? match[1] : ""; - } - } - Debug2.getFunctionName = getFunctionName; - function formatSymbol(symbol) { - return `{ name: ${unescapeLeadingUnderscores(symbol.escapedName)}; flags: ${formatSymbolFlags(symbol.flags)}; declarations: ${map(symbol.declarations, (node) => formatSyntaxKind(node.kind))} }`; - } - Debug2.formatSymbol = formatSymbol; - function formatEnum(value = 0, enumObject, isFlags) { - const members = getEnumMembers(enumObject); - if (value === 0) { - return members.length > 0 && members[0][0] === 0 ? members[0][1] : "0"; - } - if (isFlags) { - const result = []; - let remainingFlags = value; - for (const [enumValue, enumName] of members) { - if (enumValue > value) { - break; - } - if (enumValue !== 0 && enumValue & value) { - result.push(enumName); - remainingFlags &= ~enumValue; - } - } - if (remainingFlags === 0) { - return result.join("|"); - } - } else { - for (const [enumValue, enumName] of members) { - if (enumValue === value) { - return enumName; - } - } - } - return value.toString(); - } - Debug2.formatEnum = formatEnum; - const enumMemberCache = /* @__PURE__ */ new Map(); - function getEnumMembers(enumObject) { - const existing = enumMemberCache.get(enumObject); - if (existing) { - return existing; - } - const result = []; - for (const name in enumObject) { - const value = enumObject[name]; - if (typeof value === "number") { - result.push([value, name]); - } - } - const sorted = stableSort(result, (x, y) => compareValues(x[0], y[0])); - enumMemberCache.set(enumObject, sorted); - return sorted; - } - function formatSyntaxKind(kind) { - return formatEnum( - kind, - SyntaxKind, - /*isFlags*/ - false - ); - } - Debug2.formatSyntaxKind = formatSyntaxKind; - function formatSnippetKind(kind) { - return formatEnum( - kind, - SnippetKind, - /*isFlags*/ - false - ); - } - Debug2.formatSnippetKind = formatSnippetKind; - function formatNodeFlags(flags) { - return formatEnum( - flags, - NodeFlags, - /*isFlags*/ - true - ); - } - Debug2.formatNodeFlags = formatNodeFlags; - function formatModifierFlags(flags) { - return formatEnum( - flags, - ModifierFlags, - /*isFlags*/ - true - ); - } - Debug2.formatModifierFlags = formatModifierFlags; - function formatTransformFlags(flags) { - return formatEnum( - flags, - TransformFlags, - /*isFlags*/ - true - ); - } - Debug2.formatTransformFlags = formatTransformFlags; - function formatEmitFlags(flags) { - return formatEnum( - flags, - EmitFlags, - /*isFlags*/ - true - ); - } - Debug2.formatEmitFlags = formatEmitFlags; - function formatSymbolFlags(flags) { - return formatEnum( - flags, - SymbolFlags, - /*isFlags*/ - true - ); - } - Debug2.formatSymbolFlags = formatSymbolFlags; - function formatTypeFlags(flags) { - return formatEnum( - flags, - TypeFlags, - /*isFlags*/ - true - ); - } - Debug2.formatTypeFlags = formatTypeFlags; - function formatSignatureFlags(flags) { - return formatEnum( - flags, - SignatureFlags, - /*isFlags*/ - true - ); - } - Debug2.formatSignatureFlags = formatSignatureFlags; - function formatObjectFlags(flags) { - return formatEnum( - flags, - ObjectFlags, - /*isFlags*/ - true - ); - } - Debug2.formatObjectFlags = formatObjectFlags; - function formatFlowFlags(flags) { - return formatEnum( - flags, - FlowFlags, - /*isFlags*/ - true - ); - } - Debug2.formatFlowFlags = formatFlowFlags; - function formatRelationComparisonResult(result) { - return formatEnum( - result, - RelationComparisonResult, - /*isFlags*/ - true - ); - } - Debug2.formatRelationComparisonResult = formatRelationComparisonResult; - function formatCheckMode(mode) { - return formatEnum( - mode, - CheckMode, - /*isFlags*/ - true - ); - } - Debug2.formatCheckMode = formatCheckMode; - function formatSignatureCheckMode(mode) { - return formatEnum( - mode, - SignatureCheckMode, - /*isFlags*/ - true - ); - } - Debug2.formatSignatureCheckMode = formatSignatureCheckMode; - function formatTypeFacts(facts) { - return formatEnum( - facts, - TypeFacts, - /*isFlags*/ - true - ); - } - Debug2.formatTypeFacts = formatTypeFacts; - let isDebugInfoEnabled = false; - let flowNodeProto; - function attachFlowNodeDebugInfoWorker(flowNode) { - if (!("__debugFlowFlags" in flowNode)) { - Object.defineProperties(flowNode, { - // for use with vscode-js-debug's new customDescriptionGenerator in launch.json - __tsDebuggerDisplay: { - value() { - const flowHeader = this.flags & 2 /* Start */ ? "FlowStart" : this.flags & 4 /* BranchLabel */ ? "FlowBranchLabel" : this.flags & 8 /* LoopLabel */ ? "FlowLoopLabel" : this.flags & 16 /* Assignment */ ? "FlowAssignment" : this.flags & 32 /* TrueCondition */ ? "FlowTrueCondition" : this.flags & 64 /* FalseCondition */ ? "FlowFalseCondition" : this.flags & 128 /* SwitchClause */ ? "FlowSwitchClause" : this.flags & 256 /* ArrayMutation */ ? "FlowArrayMutation" : this.flags & 512 /* Call */ ? "FlowCall" : this.flags & 1024 /* ReduceLabel */ ? "FlowReduceLabel" : this.flags & 1 /* Unreachable */ ? "FlowUnreachable" : "UnknownFlow"; - const remainingFlags = this.flags & ~(2048 /* Referenced */ - 1); - return `${flowHeader}${remainingFlags ? ` (${formatFlowFlags(remainingFlags)})` : ""}`; - } - }, - __debugFlowFlags: { get() { - return formatEnum( - this.flags, - FlowFlags, - /*isFlags*/ - true - ); - } }, - __debugToString: { value() { - return formatControlFlowGraph(this); - } } - }); - } - } - function attachFlowNodeDebugInfo(flowNode) { - if (isDebugInfoEnabled) { - if (typeof Object.setPrototypeOf === "function") { - if (!flowNodeProto) { - flowNodeProto = Object.create(Object.prototype); - attachFlowNodeDebugInfoWorker(flowNodeProto); - } - Object.setPrototypeOf(flowNode, flowNodeProto); - } else { - attachFlowNodeDebugInfoWorker(flowNode); - } - } - } - Debug2.attachFlowNodeDebugInfo = attachFlowNodeDebugInfo; - let nodeArrayProto; - function attachNodeArrayDebugInfoWorker(array) { - if (!("__tsDebuggerDisplay" in array)) { - Object.defineProperties(array, { - __tsDebuggerDisplay: { - value(defaultValue) { - defaultValue = String(defaultValue).replace(/(?:,[\s\w\d_]+:[^,]+)+\]$/, "]"); - return `NodeArray ${defaultValue}`; - } - } - }); - } - } - function attachNodeArrayDebugInfo(array) { - if (isDebugInfoEnabled) { - if (typeof Object.setPrototypeOf === "function") { - if (!nodeArrayProto) { - nodeArrayProto = Object.create(Array.prototype); - attachNodeArrayDebugInfoWorker(nodeArrayProto); - } - Object.setPrototypeOf(array, nodeArrayProto); - } else { - attachNodeArrayDebugInfoWorker(array); - } - } - } - Debug2.attachNodeArrayDebugInfo = attachNodeArrayDebugInfo; - function enableDebugInfo() { - if (isDebugInfoEnabled) - return; - const weakTypeTextMap = /* @__PURE__ */ new WeakMap(); - const weakNodeTextMap = /* @__PURE__ */ new WeakMap(); - Object.defineProperties(objectAllocator.getSymbolConstructor().prototype, { - // for use with vscode-js-debug's new customDescriptionGenerator in launch.json - __tsDebuggerDisplay: { - value() { - const symbolHeader = this.flags & 33554432 /* Transient */ ? "TransientSymbol" : "Symbol"; - const remainingSymbolFlags = this.flags & ~33554432 /* Transient */; - return `${symbolHeader} '${symbolName(this)}'${remainingSymbolFlags ? ` (${formatSymbolFlags(remainingSymbolFlags)})` : ""}`; - } - }, - __debugFlags: { get() { - return formatSymbolFlags(this.flags); - } } - }); - Object.defineProperties(objectAllocator.getTypeConstructor().prototype, { - // for use with vscode-js-debug's new customDescriptionGenerator in launch.json - __tsDebuggerDisplay: { - value() { - const typeHeader = this.flags & 98304 /* Nullable */ ? "NullableType" : this.flags & 384 /* StringOrNumberLiteral */ ? `LiteralType ${JSON.stringify(this.value)}` : this.flags & 2048 /* BigIntLiteral */ ? `LiteralType ${this.value.negative ? "-" : ""}${this.value.base10Value}n` : this.flags & 8192 /* UniqueESSymbol */ ? "UniqueESSymbolType" : this.flags & 32 /* Enum */ ? "EnumType" : this.flags & 67359327 /* Intrinsic */ ? `IntrinsicType ${this.intrinsicName}` : this.flags & 1048576 /* Union */ ? "UnionType" : this.flags & 2097152 /* Intersection */ ? "IntersectionType" : this.flags & 4194304 /* Index */ ? "IndexType" : this.flags & 8388608 /* IndexedAccess */ ? "IndexedAccessType" : this.flags & 16777216 /* Conditional */ ? "ConditionalType" : this.flags & 33554432 /* Substitution */ ? "SubstitutionType" : this.flags & 262144 /* TypeParameter */ ? "TypeParameter" : this.flags & 524288 /* Object */ ? this.objectFlags & 3 /* ClassOrInterface */ ? "InterfaceType" : this.objectFlags & 4 /* Reference */ ? "TypeReference" : this.objectFlags & 8 /* Tuple */ ? "TupleType" : this.objectFlags & 16 /* Anonymous */ ? "AnonymousType" : this.objectFlags & 32 /* Mapped */ ? "MappedType" : this.objectFlags & 1024 /* ReverseMapped */ ? "ReverseMappedType" : this.objectFlags & 256 /* EvolvingArray */ ? "EvolvingArrayType" : "ObjectType" : "Type"; - const remainingObjectFlags = this.flags & 524288 /* Object */ ? this.objectFlags & ~1343 /* ObjectTypeKindMask */ : 0; - return `${typeHeader}${this.symbol ? ` '${symbolName(this.symbol)}'` : ""}${remainingObjectFlags ? ` (${formatObjectFlags(remainingObjectFlags)})` : ""}`; - } - }, - __debugFlags: { get() { - return formatTypeFlags(this.flags); - } }, - __debugObjectFlags: { get() { - return this.flags & 524288 /* Object */ ? formatObjectFlags(this.objectFlags) : ""; - } }, - __debugTypeToString: { - value() { - let text = weakTypeTextMap.get(this); - if (text === void 0) { - text = this.checker.typeToString(this); - weakTypeTextMap.set(this, text); - } - return text; - } - } - }); - Object.defineProperties(objectAllocator.getSignatureConstructor().prototype, { - __debugFlags: { get() { - return formatSignatureFlags(this.flags); - } }, - __debugSignatureToString: { value() { - var _a; - return (_a = this.checker) == null ? void 0 : _a.signatureToString(this); - } } - }); - const nodeConstructors = [ - objectAllocator.getNodeConstructor(), - objectAllocator.getIdentifierConstructor(), - objectAllocator.getTokenConstructor(), - objectAllocator.getSourceFileConstructor() - ]; - for (const ctor of nodeConstructors) { - if (!hasProperty(ctor.prototype, "__debugKind")) { - Object.defineProperties(ctor.prototype, { - // for use with vscode-js-debug's new customDescriptionGenerator in launch.json - __tsDebuggerDisplay: { - value() { - const nodeHeader = isGeneratedIdentifier(this) ? "GeneratedIdentifier" : isIdentifier(this) ? `Identifier '${idText(this)}'` : isPrivateIdentifier(this) ? `PrivateIdentifier '${idText(this)}'` : isStringLiteral(this) ? `StringLiteral ${JSON.stringify(this.text.length < 10 ? this.text : this.text.slice(10) + "...")}` : isNumericLiteral(this) ? `NumericLiteral ${this.text}` : isBigIntLiteral(this) ? `BigIntLiteral ${this.text}n` : isTypeParameterDeclaration(this) ? "TypeParameterDeclaration" : isParameter(this) ? "ParameterDeclaration" : isConstructorDeclaration(this) ? "ConstructorDeclaration" : isGetAccessorDeclaration(this) ? "GetAccessorDeclaration" : isSetAccessorDeclaration(this) ? "SetAccessorDeclaration" : isCallSignatureDeclaration(this) ? "CallSignatureDeclaration" : isConstructSignatureDeclaration(this) ? "ConstructSignatureDeclaration" : isIndexSignatureDeclaration(this) ? "IndexSignatureDeclaration" : isTypePredicateNode(this) ? "TypePredicateNode" : isTypeReferenceNode(this) ? "TypeReferenceNode" : isFunctionTypeNode(this) ? "FunctionTypeNode" : isConstructorTypeNode(this) ? "ConstructorTypeNode" : isTypeQueryNode(this) ? "TypeQueryNode" : isTypeLiteralNode(this) ? "TypeLiteralNode" : isArrayTypeNode(this) ? "ArrayTypeNode" : isTupleTypeNode(this) ? "TupleTypeNode" : isOptionalTypeNode(this) ? "OptionalTypeNode" : isRestTypeNode(this) ? "RestTypeNode" : isUnionTypeNode(this) ? "UnionTypeNode" : isIntersectionTypeNode(this) ? "IntersectionTypeNode" : isConditionalTypeNode(this) ? "ConditionalTypeNode" : isInferTypeNode(this) ? "InferTypeNode" : isParenthesizedTypeNode(this) ? "ParenthesizedTypeNode" : isThisTypeNode(this) ? "ThisTypeNode" : isTypeOperatorNode(this) ? "TypeOperatorNode" : isIndexedAccessTypeNode(this) ? "IndexedAccessTypeNode" : isMappedTypeNode(this) ? "MappedTypeNode" : isLiteralTypeNode(this) ? "LiteralTypeNode" : isNamedTupleMember(this) ? "NamedTupleMember" : isImportTypeNode(this) ? "ImportTypeNode" : formatSyntaxKind(this.kind); - return `${nodeHeader}${this.flags ? ` (${formatNodeFlags(this.flags)})` : ""}`; - } - }, - __debugKind: { get() { - return formatSyntaxKind(this.kind); - } }, - __debugNodeFlags: { get() { - return formatNodeFlags(this.flags); - } }, - __debugModifierFlags: { get() { - return formatModifierFlags(getEffectiveModifierFlagsNoCache(this)); - } }, - __debugTransformFlags: { get() { - return formatTransformFlags(this.transformFlags); - } }, - __debugIsParseTreeNode: { get() { - return isParseTreeNode(this); - } }, - __debugEmitFlags: { get() { - return formatEmitFlags(getEmitFlags(this)); - } }, - __debugGetText: { - value(includeTrivia) { - if (nodeIsSynthesized(this)) - return ""; - let text = weakNodeTextMap.get(this); - if (text === void 0) { - const parseNode = getParseTreeNode(this); - const sourceFile = parseNode && getSourceFileOfNode(parseNode); - text = sourceFile ? getSourceTextOfNodeFromSourceFile(sourceFile, parseNode, includeTrivia) : ""; - weakNodeTextMap.set(this, text); - } - return text; - } - } - }); - } - } - isDebugInfoEnabled = true; - } - Debug2.enableDebugInfo = enableDebugInfo; - function formatVariance(varianceFlags) { - const variance = varianceFlags & 7 /* VarianceMask */; - let result = variance === 0 /* Invariant */ ? "in out" : variance === 3 /* Bivariant */ ? "[bivariant]" : variance === 2 /* Contravariant */ ? "in" : variance === 1 /* Covariant */ ? "out" : variance === 4 /* Independent */ ? "[independent]" : ""; - if (varianceFlags & 8 /* Unmeasurable */) { - result += " (unmeasurable)"; - } else if (varianceFlags & 16 /* Unreliable */) { - result += " (unreliable)"; - } - return result; - } - Debug2.formatVariance = formatVariance; - class DebugTypeMapper { - __debugToString() { - var _a; - type(this); - switch (this.kind) { - case 3 /* Function */: - return ((_a = this.debugInfo) == null ? void 0 : _a.call(this)) || "(function mapper)"; - case 0 /* Simple */: - return `${this.source.__debugTypeToString()} -> ${this.target.__debugTypeToString()}`; - case 1 /* Array */: - return zipWith( - this.sources, - this.targets || map(this.sources, () => "any"), - (s, t) => `${s.__debugTypeToString()} -> ${typeof t === "string" ? t : t.__debugTypeToString()}` - ).join(", "); - case 2 /* Deferred */: - return zipWith( - this.sources, - this.targets, - (s, t) => `${s.__debugTypeToString()} -> ${t().__debugTypeToString()}` - ).join(", "); - case 5 /* Merged */: - case 4 /* Composite */: - return `m1: ${this.mapper1.__debugToString().split("\n").join("\n ")} -m2: ${this.mapper2.__debugToString().split("\n").join("\n ")}`; - default: - return assertNever(this); - } - } - } - Debug2.DebugTypeMapper = DebugTypeMapper; - function attachDebugPrototypeIfDebug(mapper) { - if (Debug2.isDebugging) { - return Object.setPrototypeOf(mapper, DebugTypeMapper.prototype); - } - return mapper; - } - Debug2.attachDebugPrototypeIfDebug = attachDebugPrototypeIfDebug; - function printControlFlowGraph(flowNode) { - return console.log(formatControlFlowGraph(flowNode)); - } - Debug2.printControlFlowGraph = printControlFlowGraph; - function formatControlFlowGraph(flowNode) { - let nextDebugFlowId = -1; - function getDebugFlowNodeId(f) { - if (!f.id) { - f.id = nextDebugFlowId; - nextDebugFlowId--; - } - return f.id; - } - let BoxCharacter; - ((BoxCharacter2) => { - BoxCharacter2["lr"] = "\u2500"; - BoxCharacter2["ud"] = "\u2502"; - BoxCharacter2["dr"] = "\u256D"; - BoxCharacter2["dl"] = "\u256E"; - BoxCharacter2["ul"] = "\u256F"; - BoxCharacter2["ur"] = "\u2570"; - BoxCharacter2["udr"] = "\u251C"; - BoxCharacter2["udl"] = "\u2524"; - BoxCharacter2["dlr"] = "\u252C"; - BoxCharacter2["ulr"] = "\u2534"; - BoxCharacter2["udlr"] = "\u256B"; - })(BoxCharacter || (BoxCharacter = {})); - let Connection; - ((Connection2) => { - Connection2[Connection2["None"] = 0] = "None"; - Connection2[Connection2["Up"] = 1] = "Up"; - Connection2[Connection2["Down"] = 2] = "Down"; - Connection2[Connection2["Left"] = 4] = "Left"; - Connection2[Connection2["Right"] = 8] = "Right"; - Connection2[Connection2["UpDown"] = 3] = "UpDown"; - Connection2[Connection2["LeftRight"] = 12] = "LeftRight"; - Connection2[Connection2["UpLeft"] = 5] = "UpLeft"; - Connection2[Connection2["UpRight"] = 9] = "UpRight"; - Connection2[Connection2["DownLeft"] = 6] = "DownLeft"; - Connection2[Connection2["DownRight"] = 10] = "DownRight"; - Connection2[Connection2["UpDownLeft"] = 7] = "UpDownLeft"; - Connection2[Connection2["UpDownRight"] = 11] = "UpDownRight"; - Connection2[Connection2["UpLeftRight"] = 13] = "UpLeftRight"; - Connection2[Connection2["DownLeftRight"] = 14] = "DownLeftRight"; - Connection2[Connection2["UpDownLeftRight"] = 15] = "UpDownLeftRight"; - Connection2[Connection2["NoChildren"] = 16] = "NoChildren"; - })(Connection || (Connection = {})); - const hasAntecedentFlags = 16 /* Assignment */ | 96 /* Condition */ | 128 /* SwitchClause */ | 256 /* ArrayMutation */ | 512 /* Call */ | 1024 /* ReduceLabel */; - const hasNodeFlags = 2 /* Start */ | 16 /* Assignment */ | 512 /* Call */ | 96 /* Condition */ | 256 /* ArrayMutation */; - const links = /* @__PURE__ */ Object.create( - /*o*/ - null - ); - const nodes = []; - const edges = []; - const root = buildGraphNode(flowNode, /* @__PURE__ */ new Set()); - for (const node of nodes) { - node.text = renderFlowNode(node.flowNode, node.circular); - computeLevel(node); - } - const height = computeHeight(root); - const columnWidths = computeColumnWidths(height); - computeLanes(root, 0); - return renderGraph(); - function isFlowSwitchClause(f) { - return !!(f.flags & 128 /* SwitchClause */); - } - function hasAntecedents(f) { - return !!(f.flags & 12 /* Label */) && !!f.antecedents; - } - function hasAntecedent(f) { - return !!(f.flags & hasAntecedentFlags); - } - function hasNode(f) { - return !!(f.flags & hasNodeFlags); - } - function getChildren(node) { - const children = []; - for (const edge of node.edges) { - if (edge.source === node) { - children.push(edge.target); - } - } - return children; - } - function getParents(node) { - const parents = []; - for (const edge of node.edges) { - if (edge.target === node) { - parents.push(edge.source); - } - } - return parents; - } - function buildGraphNode(flowNode2, seen) { - const id = getDebugFlowNodeId(flowNode2); - let graphNode = links[id]; - if (graphNode && seen.has(flowNode2)) { - graphNode.circular = true; - graphNode = { - id: -1, - flowNode: flowNode2, - edges: [], - text: "", - lane: -1, - endLane: -1, - level: -1, - circular: "circularity" - }; - nodes.push(graphNode); - return graphNode; - } - seen.add(flowNode2); - if (!graphNode) { - links[id] = graphNode = { id, flowNode: flowNode2, edges: [], text: "", lane: -1, endLane: -1, level: -1, circular: false }; - nodes.push(graphNode); - if (hasAntecedents(flowNode2)) { - for (const antecedent of flowNode2.antecedents) { - buildGraphEdge(graphNode, antecedent, seen); - } - } else if (hasAntecedent(flowNode2)) { - buildGraphEdge(graphNode, flowNode2.antecedent, seen); - } - } - seen.delete(flowNode2); - return graphNode; - } - function buildGraphEdge(source, antecedent, seen) { - const target = buildGraphNode(antecedent, seen); - const edge = { source, target }; - edges.push(edge); - source.edges.push(edge); - target.edges.push(edge); - } - function computeLevel(node) { - if (node.level !== -1) { - return node.level; - } - let level = 0; - for (const parent2 of getParents(node)) { - level = Math.max(level, computeLevel(parent2) + 1); - } - return node.level = level; - } - function computeHeight(node) { - let height2 = 0; - for (const child of getChildren(node)) { - height2 = Math.max(height2, computeHeight(child)); - } - return height2 + 1; - } - function computeColumnWidths(height2) { - const columns = fill(Array(height2), 0); - for (const node of nodes) { - columns[node.level] = Math.max(columns[node.level], node.text.length); - } - return columns; - } - function computeLanes(node, lane) { - if (node.lane === -1) { - node.lane = lane; - node.endLane = lane; - const children = getChildren(node); - for (let i = 0; i < children.length; i++) { - if (i > 0) - lane++; - const child = children[i]; - computeLanes(child, lane); - if (child.endLane > node.endLane) { - lane = child.endLane; - } - } - node.endLane = lane; - } - } - function getHeader(flags) { - if (flags & 2 /* Start */) - return "Start"; - if (flags & 4 /* BranchLabel */) - return "Branch"; - if (flags & 8 /* LoopLabel */) - return "Loop"; - if (flags & 16 /* Assignment */) - return "Assignment"; - if (flags & 32 /* TrueCondition */) - return "True"; - if (flags & 64 /* FalseCondition */) - return "False"; - if (flags & 128 /* SwitchClause */) - return "SwitchClause"; - if (flags & 256 /* ArrayMutation */) - return "ArrayMutation"; - if (flags & 512 /* Call */) - return "Call"; - if (flags & 1024 /* ReduceLabel */) - return "ReduceLabel"; - if (flags & 1 /* Unreachable */) - return "Unreachable"; - throw new Error(); - } - function getNodeText(node) { - const sourceFile = getSourceFileOfNode(node); - return getSourceTextOfNodeFromSourceFile( - sourceFile, - node, - /*includeTrivia*/ - false - ); - } - function renderFlowNode(flowNode2, circular) { - let text = getHeader(flowNode2.flags); - if (circular) { - text = `${text}#${getDebugFlowNodeId(flowNode2)}`; - } - if (hasNode(flowNode2)) { - if (flowNode2.node) { - text += ` (${getNodeText(flowNode2.node)})`; - } - } else if (isFlowSwitchClause(flowNode2)) { - const clauses = []; - for (let i = flowNode2.clauseStart; i < flowNode2.clauseEnd; i++) { - const clause = flowNode2.switchStatement.caseBlock.clauses[i]; - if (isDefaultClause(clause)) { - clauses.push("default"); - } else { - clauses.push(getNodeText(clause.expression)); - } - } - text += ` (${clauses.join(", ")})`; - } - return circular === "circularity" ? `Circular(${text})` : text; - } - function renderGraph() { - const columnCount = columnWidths.length; - const laneCount = nodes.reduce((x, n) => Math.max(x, n.lane), 0) + 1; - const lanes = fill(Array(laneCount), ""); - const grid = columnWidths.map(() => Array(laneCount)); - const connectors = columnWidths.map(() => fill(Array(laneCount), 0)); - for (const node of nodes) { - grid[node.level][node.lane] = node; - const children = getChildren(node); - for (let i = 0; i < children.length; i++) { - const child = children[i]; - let connector = 8 /* Right */; - if (child.lane === node.lane) - connector |= 4 /* Left */; - if (i > 0) - connector |= 1 /* Up */; - if (i < children.length - 1) - connector |= 2 /* Down */; - connectors[node.level][child.lane] |= connector; - } - if (children.length === 0) { - connectors[node.level][node.lane] |= 16 /* NoChildren */; - } - const parents = getParents(node); - for (let i = 0; i < parents.length; i++) { - const parent2 = parents[i]; - let connector = 4 /* Left */; - if (i > 0) - connector |= 1 /* Up */; - if (i < parents.length - 1) - connector |= 2 /* Down */; - connectors[node.level - 1][parent2.lane] |= connector; - } - } - for (let column = 0; column < columnCount; column++) { - for (let lane = 0; lane < laneCount; lane++) { - const left = column > 0 ? connectors[column - 1][lane] : 0; - const above = lane > 0 ? connectors[column][lane - 1] : 0; - let connector = connectors[column][lane]; - if (!connector) { - if (left & 8 /* Right */) - connector |= 12 /* LeftRight */; - if (above & 2 /* Down */) - connector |= 3 /* UpDown */; - connectors[column][lane] = connector; - } - } - } - for (let column = 0; column < columnCount; column++) { - for (let lane = 0; lane < lanes.length; lane++) { - const connector = connectors[column][lane]; - const fill2 = connector & 4 /* Left */ ? "\u2500" /* lr */ : " "; - const node = grid[column][lane]; - if (!node) { - if (column < columnCount - 1) { - writeLane(lane, repeat(fill2, columnWidths[column] + 1)); - } - } else { - writeLane(lane, node.text); - if (column < columnCount - 1) { - writeLane(lane, " "); - writeLane(lane, repeat(fill2, columnWidths[column] - node.text.length)); - } - } - writeLane(lane, getBoxCharacter(connector)); - writeLane(lane, connector & 8 /* Right */ && column < columnCount - 1 && !grid[column + 1][lane] ? "\u2500" /* lr */ : " "); - } - } - return ` -${lanes.join("\n")} -`; - function writeLane(lane, text) { - lanes[lane] += text; - } - } - function getBoxCharacter(connector) { - switch (connector) { - case 3 /* UpDown */: - return "\u2502" /* ud */; - case 12 /* LeftRight */: - return "\u2500" /* lr */; - case 5 /* UpLeft */: - return "\u256F" /* ul */; - case 9 /* UpRight */: - return "\u2570" /* ur */; - case 6 /* DownLeft */: - return "\u256E" /* dl */; - case 10 /* DownRight */: - return "\u256D" /* dr */; - case 7 /* UpDownLeft */: - return "\u2524" /* udl */; - case 11 /* UpDownRight */: - return "\u251C" /* udr */; - case 13 /* UpLeftRight */: - return "\u2534" /* ulr */; - case 14 /* DownLeftRight */: - return "\u252C" /* dlr */; - case 15 /* UpDownLeftRight */: - return "\u256B" /* udlr */; - } - return " "; - } - function fill(array, value) { - if (array.fill) { - array.fill(value); - } else { - for (let i = 0; i < array.length; i++) { - array[i] = value; - } - } - return array; - } - function repeat(ch, length2) { - if (ch.repeat) { - return length2 > 0 ? ch.repeat(length2) : ""; - } - let s = ""; - while (s.length < length2) { - s += ch; - } - return s; - } - } - Debug2.formatControlFlowGraph = formatControlFlowGraph; - })(Debug || (Debug = {})); - } - }); - - // src/compiler/semver.ts - function tryParseComponents(text) { - const match = versionRegExp.exec(text); - if (!match) - return void 0; - const [, major, minor = "0", patch = "0", prerelease = "", build2 = ""] = match; - if (prerelease && !prereleaseRegExp.test(prerelease)) - return void 0; - if (build2 && !buildRegExp.test(build2)) - return void 0; - return { - major: parseInt(major, 10), - minor: parseInt(minor, 10), - patch: parseInt(patch, 10), - prerelease, - build: build2 - }; - } - function comparePrereleaseIdentifiers(left, right) { - if (left === right) - return 0 /* EqualTo */; - if (left.length === 0) - return right.length === 0 ? 0 /* EqualTo */ : 1 /* GreaterThan */; - if (right.length === 0) - return -1 /* LessThan */; - const length2 = Math.min(left.length, right.length); - for (let i = 0; i < length2; i++) { - const leftIdentifier = left[i]; - const rightIdentifier = right[i]; - if (leftIdentifier === rightIdentifier) - continue; - const leftIsNumeric = numericIdentifierRegExp.test(leftIdentifier); - const rightIsNumeric = numericIdentifierRegExp.test(rightIdentifier); - if (leftIsNumeric || rightIsNumeric) { - if (leftIsNumeric !== rightIsNumeric) - return leftIsNumeric ? -1 /* LessThan */ : 1 /* GreaterThan */; - const result = compareValues(+leftIdentifier, +rightIdentifier); - if (result) - return result; - } else { - const result = compareStringsCaseSensitive(leftIdentifier, rightIdentifier); - if (result) - return result; - } - } - return compareValues(left.length, right.length); - } - function parseRange(text) { - const alternatives = []; - for (let range of trimString(text).split(logicalOrRegExp)) { - if (!range) - continue; - const comparators = []; - range = trimString(range); - const match = hyphenRegExp.exec(range); - if (match) { - if (!parseHyphen(match[1], match[2], comparators)) - return void 0; - } else { - for (const simple of range.split(whitespaceRegExp)) { - const match2 = rangeRegExp.exec(trimString(simple)); - if (!match2 || !parseComparator(match2[1], match2[2], comparators)) - return void 0; - } - } - alternatives.push(comparators); - } - return alternatives; - } - function parsePartial(text) { - const match = partialRegExp.exec(text); - if (!match) - return void 0; - const [, major, minor = "*", patch = "*", prerelease, build2] = match; - const version2 = new Version( - isWildcard(major) ? 0 : parseInt(major, 10), - isWildcard(major) || isWildcard(minor) ? 0 : parseInt(minor, 10), - isWildcard(major) || isWildcard(minor) || isWildcard(patch) ? 0 : parseInt(patch, 10), - prerelease, - build2 - ); - return { version: version2, major, minor, patch }; - } - function parseHyphen(left, right, comparators) { - const leftResult = parsePartial(left); - if (!leftResult) - return false; - const rightResult = parsePartial(right); - if (!rightResult) - return false; - if (!isWildcard(leftResult.major)) { - comparators.push(createComparator(">=", leftResult.version)); - } - if (!isWildcard(rightResult.major)) { - comparators.push( - isWildcard(rightResult.minor) ? createComparator("<", rightResult.version.increment("major")) : isWildcard(rightResult.patch) ? createComparator("<", rightResult.version.increment("minor")) : createComparator("<=", rightResult.version) - ); - } - return true; - } - function parseComparator(operator, text, comparators) { - const result = parsePartial(text); - if (!result) - return false; - const { version: version2, major, minor, patch } = result; - if (!isWildcard(major)) { - switch (operator) { - case "~": - comparators.push(createComparator(">=", version2)); - comparators.push(createComparator("<", version2.increment( - isWildcard(minor) ? "major" : "minor" - ))); - break; - case "^": - comparators.push(createComparator(">=", version2)); - comparators.push(createComparator("<", version2.increment( - version2.major > 0 || isWildcard(minor) ? "major" : version2.minor > 0 || isWildcard(patch) ? "minor" : "patch" - ))); - break; - case "<": - case ">=": - comparators.push( - isWildcard(minor) || isWildcard(patch) ? createComparator(operator, version2.with({ prerelease: "0" })) : createComparator(operator, version2) - ); - break; - case "<=": - case ">": - comparators.push( - isWildcard(minor) ? createComparator(operator === "<=" ? "<" : ">=", version2.increment("major").with({ prerelease: "0" })) : isWildcard(patch) ? createComparator(operator === "<=" ? "<" : ">=", version2.increment("minor").with({ prerelease: "0" })) : createComparator(operator, version2) - ); - break; - case "=": - case void 0: - if (isWildcard(minor) || isWildcard(patch)) { - comparators.push(createComparator(">=", version2.with({ prerelease: "0" }))); - comparators.push(createComparator("<", version2.increment(isWildcard(minor) ? "major" : "minor").with({ prerelease: "0" }))); - } else { - comparators.push(createComparator("=", version2)); - } - break; - default: - return false; - } - } else if (operator === "<" || operator === ">") { - comparators.push(createComparator("<", Version.zero)); - } - return true; - } - function isWildcard(part) { - return part === "*" || part === "x" || part === "X"; - } - function createComparator(operator, operand) { - return { operator, operand }; - } - function testDisjunction(version2, alternatives) { - if (alternatives.length === 0) - return true; - for (const alternative of alternatives) { - if (testAlternative(version2, alternative)) - return true; - } - return false; - } - function testAlternative(version2, comparators) { - for (const comparator of comparators) { - if (!testComparator(version2, comparator.operator, comparator.operand)) - return false; - } - return true; - } - function testComparator(version2, operator, operand) { - const cmp = version2.compareTo(operand); - switch (operator) { - case "<": - return cmp < 0; - case "<=": - return cmp <= 0; - case ">": - return cmp > 0; - case ">=": - return cmp >= 0; - case "=": - return cmp === 0; - default: - return Debug.assertNever(operator); - } - } - function formatDisjunction(alternatives) { - return map(alternatives, formatAlternative).join(" || ") || "*"; - } - function formatAlternative(comparators) { - return map(comparators, formatComparator).join(" "); - } - function formatComparator(comparator) { - return `${comparator.operator}${comparator.operand}`; - } - var versionRegExp, prereleaseRegExp, prereleasePartRegExp, buildRegExp, buildPartRegExp, numericIdentifierRegExp, _Version, Version, VersionRange, logicalOrRegExp, whitespaceRegExp, partialRegExp, hyphenRegExp, rangeRegExp; - var init_semver = __esm({ - "src/compiler/semver.ts"() { - "use strict"; - init_ts2(); - versionRegExp = /^(0|[1-9]\d*)(?:\.(0|[1-9]\d*)(?:\.(0|[1-9]\d*)(?:\-([a-z0-9-.]+))?(?:\+([a-z0-9-.]+))?)?)?$/i; - prereleaseRegExp = /^(?:0|[1-9]\d*|[a-z-][a-z0-9-]*)(?:\.(?:0|[1-9]\d*|[a-z-][a-z0-9-]*))*$/i; - prereleasePartRegExp = /^(?:0|[1-9]\d*|[a-z-][a-z0-9-]*)$/i; - buildRegExp = /^[a-z0-9-]+(?:\.[a-z0-9-]+)*$/i; - buildPartRegExp = /^[a-z0-9-]+$/i; - numericIdentifierRegExp = /^(0|[1-9]\d*)$/; - _Version = class { - constructor(major, minor = 0, patch = 0, prerelease = "", build2 = "") { - if (typeof major === "string") { - const result = Debug.checkDefined(tryParseComponents(major), "Invalid version"); - ({ major, minor, patch, prerelease, build: build2 } = result); - } - Debug.assert(major >= 0, "Invalid argument: major"); - Debug.assert(minor >= 0, "Invalid argument: minor"); - Debug.assert(patch >= 0, "Invalid argument: patch"); - const prereleaseArray = prerelease ? isArray(prerelease) ? prerelease : prerelease.split(".") : emptyArray; - const buildArray = build2 ? isArray(build2) ? build2 : build2.split(".") : emptyArray; - Debug.assert(every(prereleaseArray, (s) => prereleasePartRegExp.test(s)), "Invalid argument: prerelease"); - Debug.assert(every(buildArray, (s) => buildPartRegExp.test(s)), "Invalid argument: build"); - this.major = major; - this.minor = minor; - this.patch = patch; - this.prerelease = prereleaseArray; - this.build = buildArray; - } - static tryParse(text) { - const result = tryParseComponents(text); - if (!result) - return void 0; - const { major, minor, patch, prerelease, build: build2 } = result; - return new _Version(major, minor, patch, prerelease, build2); - } - compareTo(other) { - if (this === other) - return 0 /* EqualTo */; - if (other === void 0) - return 1 /* GreaterThan */; - return compareValues(this.major, other.major) || compareValues(this.minor, other.minor) || compareValues(this.patch, other.patch) || comparePrereleaseIdentifiers(this.prerelease, other.prerelease); - } - increment(field) { - switch (field) { - case "major": - return new _Version(this.major + 1, 0, 0); - case "minor": - return new _Version(this.major, this.minor + 1, 0); - case "patch": - return new _Version(this.major, this.minor, this.patch + 1); - default: - return Debug.assertNever(field); - } - } - with(fields) { - const { - major = this.major, - minor = this.minor, - patch = this.patch, - prerelease = this.prerelease, - build: build2 = this.build - } = fields; - return new _Version(major, minor, patch, prerelease, build2); - } - toString() { - let result = `${this.major}.${this.minor}.${this.patch}`; - if (some(this.prerelease)) - result += `-${this.prerelease.join(".")}`; - if (some(this.build)) - result += `+${this.build.join(".")}`; - return result; - } - }; - Version = _Version; - Version.zero = new _Version(0, 0, 0, ["0"]); - VersionRange = class { - constructor(spec) { - this._alternatives = spec ? Debug.checkDefined(parseRange(spec), "Invalid range spec.") : emptyArray; - } - static tryParse(text) { - const sets = parseRange(text); - if (sets) { - const range = new VersionRange(""); - range._alternatives = sets; - return range; - } - return void 0; - } - /** - * Tests whether a version matches the range. This is equivalent to `satisfies(version, range, { includePrerelease: true })`. - * in `node-semver`. - */ - test(version2) { - if (typeof version2 === "string") - version2 = new Version(version2); - return testDisjunction(version2, this._alternatives); - } - toString() { - return formatDisjunction(this._alternatives); - } - }; - logicalOrRegExp = /\|\|/g; - whitespaceRegExp = /\s+/g; - partialRegExp = /^([xX*0]|[1-9]\d*)(?:\.([xX*0]|[1-9]\d*)(?:\.([xX*0]|[1-9]\d*)(?:-([a-z0-9-.]+))?(?:\+([a-z0-9-.]+))?)?)?$/i; - hyphenRegExp = /^\s*([a-z0-9-+.*]+)\s+-\s+([a-z0-9-+.*]+)\s*$/i; - rangeRegExp = /^(~|\^|<|<=|>|>=|=)?\s*([a-z0-9-+.*]+)$/i; - } - }); - - // src/compiler/performanceCore.ts - function hasRequiredAPI(performance2, PerformanceObserver2) { - return typeof performance2 === "object" && typeof performance2.timeOrigin === "number" && typeof performance2.mark === "function" && typeof performance2.measure === "function" && typeof performance2.now === "function" && typeof performance2.clearMarks === "function" && typeof performance2.clearMeasures === "function" && typeof PerformanceObserver2 === "function"; - } - function tryGetWebPerformanceHooks() { - if (typeof performance === "object" && typeof PerformanceObserver === "function" && hasRequiredAPI(performance, PerformanceObserver)) { - return { - // For now we always write native performance events when running in the browser. We may - // make this conditional in the future if we find that native web performance hooks - // in the browser also slow down compilation. - shouldWriteNativeEvents: true, - performance, - PerformanceObserver - }; - } - } - function tryGetNodePerformanceHooks() { - if (isNodeLikeSystem()) { - try { - const { performance: performance2, PerformanceObserver: PerformanceObserver2 } = __nccwpck_require__(4074); - if (hasRequiredAPI(performance2, PerformanceObserver2)) { - return { - // By default, only write native events when generating a cpu profile or using the v8 profiler. - shouldWriteNativeEvents: false, - performance: performance2, - PerformanceObserver: PerformanceObserver2 - }; - } - } catch { - } - } - } - function tryGetNativePerformanceHooks() { - return nativePerformanceHooks; - } - var nativePerformanceHooks, nativePerformance, timestamp; - var init_performanceCore = __esm({ - "src/compiler/performanceCore.ts"() { - "use strict"; - init_ts2(); - nativePerformanceHooks = tryGetWebPerformanceHooks() || tryGetNodePerformanceHooks(); - nativePerformance = nativePerformanceHooks == null ? void 0 : nativePerformanceHooks.performance; - timestamp = nativePerformance ? () => nativePerformance.now() : Date.now ? Date.now : () => +/* @__PURE__ */ new Date(); - } - }); - - // src/compiler/perfLogger.ts - var etwModule, perfLogger; - var init_perfLogger = __esm({ - "src/compiler/perfLogger.ts"() { - "use strict"; - try { - const etwModulePath = process.env.TS_ETW_MODULE_PATH ?? "./node_modules/@microsoft/typescript-etw"; - etwModule = require(etwModulePath); - } catch (e) { - etwModule = void 0; - } - perfLogger = (etwModule == null ? void 0 : etwModule.logEvent) ? etwModule : void 0; - } - }); - - // src/compiler/performance.ts - function createTimerIf(condition, measureName, startMarkName, endMarkName) { - return condition ? createTimer(measureName, startMarkName, endMarkName) : nullTimer; - } - function createTimer(measureName, startMarkName, endMarkName) { - let enterCount = 0; - return { - enter, - exit - }; - function enter() { - if (++enterCount === 1) { - mark(startMarkName); - } - } - function exit() { - if (--enterCount === 0) { - mark(endMarkName); - measure(measureName, startMarkName, endMarkName); - } else if (enterCount < 0) { - Debug.fail("enter/exit count does not match."); - } - } - } - function mark(markName) { - if (enabled) { - const count = counts.get(markName) ?? 0; - counts.set(markName, count + 1); - marks.set(markName, timestamp()); - performanceImpl == null ? void 0 : performanceImpl.mark(markName); - if (typeof onProfilerEvent === "function") { - onProfilerEvent(markName); - } - } - } - function measure(measureName, startMarkName, endMarkName) { - if (enabled) { - const end = (endMarkName !== void 0 ? marks.get(endMarkName) : void 0) ?? timestamp(); - const start = (startMarkName !== void 0 ? marks.get(startMarkName) : void 0) ?? timeorigin; - const previousDuration = durations.get(measureName) || 0; - durations.set(measureName, previousDuration + (end - start)); - performanceImpl == null ? void 0 : performanceImpl.measure(measureName, startMarkName, endMarkName); - } - } - function getCount(markName) { - return counts.get(markName) || 0; - } - function getDuration(measureName) { - return durations.get(measureName) || 0; - } - function forEachMeasure(cb) { - durations.forEach((duration, measureName) => cb(measureName, duration)); - } - function forEachMark(cb) { - marks.forEach((_time, markName) => cb(markName)); - } - function clearMeasures(name) { - if (name !== void 0) - durations.delete(name); - else - durations.clear(); - performanceImpl == null ? void 0 : performanceImpl.clearMeasures(name); - } - function clearMarks(name) { - if (name !== void 0) { - counts.delete(name); - marks.delete(name); - } else { - counts.clear(); - marks.clear(); - } - performanceImpl == null ? void 0 : performanceImpl.clearMarks(name); - } - function isEnabled() { - return enabled; - } - function enable(system = sys) { - var _a; - if (!enabled) { - enabled = true; - perfHooks || (perfHooks = tryGetNativePerformanceHooks()); - if (perfHooks) { - timeorigin = perfHooks.performance.timeOrigin; - if (perfHooks.shouldWriteNativeEvents || ((_a = system == null ? void 0 : system.cpuProfilingEnabled) == null ? void 0 : _a.call(system)) || (system == null ? void 0 : system.debugMode)) { - performanceImpl = perfHooks.performance; - } - } - } - return true; - } - function disable() { - if (enabled) { - marks.clear(); - counts.clear(); - durations.clear(); - performanceImpl = void 0; - enabled = false; - } - } - var perfHooks, performanceImpl, nullTimer, enabled, timeorigin, marks, counts, durations; - var init_performance = __esm({ - "src/compiler/performance.ts"() { - "use strict"; - init_ts2(); - nullTimer = { enter: noop, exit: noop }; - enabled = false; - timeorigin = timestamp(); - marks = /* @__PURE__ */ new Map(); - counts = /* @__PURE__ */ new Map(); - durations = /* @__PURE__ */ new Map(); - } - }); - - // src/compiler/_namespaces/ts.performance.ts - var ts_performance_exports = {}; - __export(ts_performance_exports, { - clearMarks: () => clearMarks, - clearMeasures: () => clearMeasures, - createTimer: () => createTimer, - createTimerIf: () => createTimerIf, - disable: () => disable, - enable: () => enable, - forEachMark: () => forEachMark, - forEachMeasure: () => forEachMeasure, - getCount: () => getCount, - getDuration: () => getDuration, - isEnabled: () => isEnabled, - mark: () => mark, - measure: () => measure, - nullTimer: () => nullTimer - }); - var init_ts_performance = __esm({ - "src/compiler/_namespaces/ts.performance.ts"() { - "use strict"; - init_performance(); - } - }); - - // src/compiler/tracing.ts - var tracing, tracingEnabled, startTracing, dumpTracingLegend; - var init_tracing = __esm({ - "src/compiler/tracing.ts"() { - "use strict"; - init_ts2(); - init_ts_performance(); - ((tracingEnabled2) => { - let fs; - let traceCount = 0; - let traceFd = 0; - let mode; - const typeCatalog = []; - let legendPath; - const legend = []; - function startTracing2(tracingMode, traceDir, configFilePath) { - Debug.assert(!tracing, "Tracing already started"); - if (fs === void 0) { - try { - fs = __nccwpck_require__(57147); - } catch (e) { - throw new Error(`tracing requires having fs -(original error: ${e.message || e})`); - } - } - mode = tracingMode; - typeCatalog.length = 0; - if (legendPath === void 0) { - legendPath = combinePaths(traceDir, "legend.json"); - } - if (!fs.existsSync(traceDir)) { - fs.mkdirSync(traceDir, { recursive: true }); - } - const countPart = mode === "build" ? `.${process.pid}-${++traceCount}` : mode === "server" ? `.${process.pid}` : ``; - const tracePath = combinePaths(traceDir, `trace${countPart}.json`); - const typesPath = combinePaths(traceDir, `types${countPart}.json`); - legend.push({ - configFilePath, - tracePath, - typesPath - }); - traceFd = fs.openSync(tracePath, "w"); - tracing = tracingEnabled2; - const meta = { cat: "__metadata", ph: "M", ts: 1e3 * timestamp(), pid: 1, tid: 1 }; - fs.writeSync( - traceFd, - "[\n" + [ - { name: "process_name", args: { name: "tsc" }, ...meta }, - { name: "thread_name", args: { name: "Main" }, ...meta }, - { name: "TracingStartedInBrowser", ...meta, cat: "disabled-by-default-devtools.timeline" } - ].map((v) => JSON.stringify(v)).join(",\n") - ); - } - tracingEnabled2.startTracing = startTracing2; - function stopTracing() { - Debug.assert(tracing, "Tracing is not in progress"); - Debug.assert(!!typeCatalog.length === (mode !== "server")); - fs.writeSync(traceFd, ` -] -`); - fs.closeSync(traceFd); - tracing = void 0; - if (typeCatalog.length) { - dumpTypes(typeCatalog); - } else { - legend[legend.length - 1].typesPath = void 0; - } - } - tracingEnabled2.stopTracing = stopTracing; - function recordType(type) { - if (mode !== "server") { - typeCatalog.push(type); - } - } - tracingEnabled2.recordType = recordType; - let Phase; - ((Phase2) => { - Phase2["Parse"] = "parse"; - Phase2["Program"] = "program"; - Phase2["Bind"] = "bind"; - Phase2["Check"] = "check"; - Phase2["CheckTypes"] = "checkTypes"; - Phase2["Emit"] = "emit"; - Phase2["Session"] = "session"; - })(Phase = tracingEnabled2.Phase || (tracingEnabled2.Phase = {})); - function instant(phase, name, args) { - writeEvent("I", phase, name, args, `"s":"g"`); - } - tracingEnabled2.instant = instant; - const eventStack = []; - function push(phase, name, args, separateBeginAndEnd = false) { - if (separateBeginAndEnd) { - writeEvent("B", phase, name, args); - } - eventStack.push({ phase, name, args, time: 1e3 * timestamp(), separateBeginAndEnd }); - } - tracingEnabled2.push = push; - function pop(results) { - Debug.assert(eventStack.length > 0); - writeStackEvent(eventStack.length - 1, 1e3 * timestamp(), results); - eventStack.length--; - } - tracingEnabled2.pop = pop; - function popAll() { - const endTime = 1e3 * timestamp(); - for (let i = eventStack.length - 1; i >= 0; i--) { - writeStackEvent(i, endTime); - } - eventStack.length = 0; - } - tracingEnabled2.popAll = popAll; - const sampleInterval = 1e3 * 10; - function writeStackEvent(index, endTime, results) { - const { phase, name, args, time, separateBeginAndEnd } = eventStack[index]; - if (separateBeginAndEnd) { - Debug.assert(!results, "`results` are not supported for events with `separateBeginAndEnd`"); - writeEvent( - "E", - phase, - name, - args, - /*extras*/ - void 0, - endTime - ); - } else if (sampleInterval - time % sampleInterval <= endTime - time) { - writeEvent("X", phase, name, { ...args, results }, `"dur":${endTime - time}`, time); - } - } - function writeEvent(eventType, phase, name, args, extras, time = 1e3 * timestamp()) { - if (mode === "server" && phase === "checkTypes" /* CheckTypes */) - return; - mark("beginTracing"); - fs.writeSync(traceFd, `, -{"pid":1,"tid":1,"ph":"${eventType}","cat":"${phase}","ts":${time},"name":"${name}"`); - if (extras) - fs.writeSync(traceFd, `,${extras}`); - if (args) - fs.writeSync(traceFd, `,"args":${JSON.stringify(args)}`); - fs.writeSync(traceFd, `}`); - mark("endTracing"); - measure("Tracing", "beginTracing", "endTracing"); - } - function getLocation(node) { - const file = getSourceFileOfNode(node); - return !file ? void 0 : { - path: file.path, - start: indexFromOne(getLineAndCharacterOfPosition(file, node.pos)), - end: indexFromOne(getLineAndCharacterOfPosition(file, node.end)) - }; - function indexFromOne(lc) { - return { - line: lc.line + 1, - character: lc.character + 1 - }; - } - } - function dumpTypes(types) { - var _a, _b, _c, _d, _e, _f, _g, _h, _i, _j, _k, _l, _m, _n, _o, _p, _q, _r, _s; - mark("beginDumpTypes"); - const typesPath = legend[legend.length - 1].typesPath; - const typesFd = fs.openSync(typesPath, "w"); - const recursionIdentityMap = /* @__PURE__ */ new Map(); - fs.writeSync(typesFd, "["); - const numTypes = types.length; - for (let i = 0; i < numTypes; i++) { - const type = types[i]; - const objectFlags = type.objectFlags; - const symbol = type.aliasSymbol ?? type.symbol; - let display; - if (objectFlags & 16 /* Anonymous */ | type.flags & 2944 /* Literal */) { - try { - display = (_a = type.checker) == null ? void 0 : _a.typeToString(type); - } catch { - display = void 0; - } - } - let indexedAccessProperties = {}; - if (type.flags & 8388608 /* IndexedAccess */) { - const indexedAccessType = type; - indexedAccessProperties = { - indexedAccessObjectType: (_b = indexedAccessType.objectType) == null ? void 0 : _b.id, - indexedAccessIndexType: (_c = indexedAccessType.indexType) == null ? void 0 : _c.id - }; - } - let referenceProperties = {}; - if (objectFlags & 4 /* Reference */) { - const referenceType = type; - referenceProperties = { - instantiatedType: (_d = referenceType.target) == null ? void 0 : _d.id, - typeArguments: (_e = referenceType.resolvedTypeArguments) == null ? void 0 : _e.map((t) => t.id), - referenceLocation: getLocation(referenceType.node) - }; - } - let conditionalProperties = {}; - if (type.flags & 16777216 /* Conditional */) { - const conditionalType = type; - conditionalProperties = { - conditionalCheckType: (_f = conditionalType.checkType) == null ? void 0 : _f.id, - conditionalExtendsType: (_g = conditionalType.extendsType) == null ? void 0 : _g.id, - conditionalTrueType: ((_h = conditionalType.resolvedTrueType) == null ? void 0 : _h.id) ?? -1, - conditionalFalseType: ((_i = conditionalType.resolvedFalseType) == null ? void 0 : _i.id) ?? -1 - }; - } - let substitutionProperties = {}; - if (type.flags & 33554432 /* Substitution */) { - const substitutionType = type; - substitutionProperties = { - substitutionBaseType: (_j = substitutionType.baseType) == null ? void 0 : _j.id, - constraintType: (_k = substitutionType.constraint) == null ? void 0 : _k.id - }; - } - let reverseMappedProperties = {}; - if (objectFlags & 1024 /* ReverseMapped */) { - const reverseMappedType = type; - reverseMappedProperties = { - reverseMappedSourceType: (_l = reverseMappedType.source) == null ? void 0 : _l.id, - reverseMappedMappedType: (_m = reverseMappedType.mappedType) == null ? void 0 : _m.id, - reverseMappedConstraintType: (_n = reverseMappedType.constraintType) == null ? void 0 : _n.id - }; - } - let evolvingArrayProperties = {}; - if (objectFlags & 256 /* EvolvingArray */) { - const evolvingArrayType = type; - evolvingArrayProperties = { - evolvingArrayElementType: evolvingArrayType.elementType.id, - evolvingArrayFinalType: (_o = evolvingArrayType.finalArrayType) == null ? void 0 : _o.id - }; - } - let recursionToken; - const recursionIdentity = type.checker.getRecursionIdentity(type); - if (recursionIdentity) { - recursionToken = recursionIdentityMap.get(recursionIdentity); - if (!recursionToken) { - recursionToken = recursionIdentityMap.size; - recursionIdentityMap.set(recursionIdentity, recursionToken); - } - } - const descriptor = { - id: type.id, - intrinsicName: type.intrinsicName, - symbolName: (symbol == null ? void 0 : symbol.escapedName) && unescapeLeadingUnderscores(symbol.escapedName), - recursionId: recursionToken, - isTuple: objectFlags & 8 /* Tuple */ ? true : void 0, - unionTypes: type.flags & 1048576 /* Union */ ? (_p = type.types) == null ? void 0 : _p.map((t) => t.id) : void 0, - intersectionTypes: type.flags & 2097152 /* Intersection */ ? type.types.map((t) => t.id) : void 0, - aliasTypeArguments: (_q = type.aliasTypeArguments) == null ? void 0 : _q.map((t) => t.id), - keyofType: type.flags & 4194304 /* Index */ ? (_r = type.type) == null ? void 0 : _r.id : void 0, - ...indexedAccessProperties, - ...referenceProperties, - ...conditionalProperties, - ...substitutionProperties, - ...reverseMappedProperties, - ...evolvingArrayProperties, - destructuringPattern: getLocation(type.pattern), - firstDeclaration: getLocation((_s = symbol == null ? void 0 : symbol.declarations) == null ? void 0 : _s[0]), - flags: Debug.formatTypeFlags(type.flags).split("|"), - display - }; - fs.writeSync(typesFd, JSON.stringify(descriptor)); - if (i < numTypes - 1) { - fs.writeSync(typesFd, ",\n"); - } - } - fs.writeSync(typesFd, "]\n"); - fs.closeSync(typesFd); - mark("endDumpTypes"); - measure("Dump types", "beginDumpTypes", "endDumpTypes"); - } - function dumpLegend() { - if (!legendPath) { - return; - } - fs.writeFileSync(legendPath, JSON.stringify(legend)); - } - tracingEnabled2.dumpLegend = dumpLegend; - })(tracingEnabled || (tracingEnabled = {})); - startTracing = tracingEnabled.startTracing; - dumpTracingLegend = tracingEnabled.dumpLegend; - } - }); - - // src/compiler/types.ts - function diagnosticCategoryName(d, lowerCase = true) { - const name = DiagnosticCategory[d.category]; - return lowerCase ? name.toLowerCase() : name; - } - var SyntaxKind, NodeFlags, ModifierFlags, JsxFlags, RelationComparisonResult, GeneratedIdentifierFlags, TokenFlags, FlowFlags, CommentDirectiveType, OperationCanceledException, FileIncludeKind, FilePreprocessingDiagnosticsKind, EmitOnly, StructureIsReused, ExitStatus, MemberOverrideStatus, UnionReduction, ContextFlags, NodeBuilderFlags, TypeFormatFlags, SymbolFormatFlags, SymbolAccessibility, SyntheticSymbolKind, TypePredicateKind, TypeReferenceSerializationKind, SymbolFlags, EnumKind, CheckFlags, InternalSymbolName, NodeCheckFlags, TypeFlags, ObjectFlags, VarianceFlags, ElementFlags, AccessFlags, IndexFlags, JsxReferenceKind, SignatureKind, SignatureFlags, IndexKind, TypeMapKind, InferencePriority, InferenceFlags, Ternary, AssignmentDeclarationKind, DiagnosticCategory, ModuleResolutionKind, ModuleDetectionKind, WatchFileKind, WatchDirectoryKind, PollingWatchKind, ModuleKind, JsxEmit, ImportsNotUsedAsValues, NewLineKind, ScriptKind, ScriptTarget, LanguageVariant, WatchDirectoryFlags, CharacterCodes, Extension, TransformFlags, SnippetKind, EmitFlags, InternalEmitFlags, ExternalEmitHelpers, EmitHint, OuterExpressionKinds, LexicalEnvironmentFlags, BundleFileSectionKind, ListFormat, PragmaKindFlags, commentPragmas; - var init_types = __esm({ - "src/compiler/types.ts"() { + var SyntaxKind, NodeFlags, ModifierFlags, JsxFlags, RelationComparisonResult, GeneratedIdentifierFlags, TokenFlags, FlowFlags, CommentDirectiveType, OperationCanceledException, FileIncludeKind, FilePreprocessingDiagnosticsKind, EmitOnly, StructureIsReused, ExitStatus, MemberOverrideStatus, UnionReduction, ContextFlags, NodeBuilderFlags, TypeFormatFlags, SymbolFormatFlags, SymbolAccessibility, SyntheticSymbolKind, TypePredicateKind, TypeReferenceSerializationKind, SymbolFlags, EnumKind, CheckFlags, InternalSymbolName, NodeCheckFlags, TypeFlags, ObjectFlags, VarianceFlags, ElementFlags, AccessFlags, IndexFlags, JsxReferenceKind, SignatureKind, SignatureFlags, IndexKind, TypeMapKind, InferencePriority, InferenceFlags, Ternary, AssignmentDeclarationKind, DiagnosticCategory, ModuleResolutionKind, ModuleDetectionKind, WatchFileKind, WatchDirectoryKind, PollingWatchKind, ModuleKind, JsxEmit, ImportsNotUsedAsValues, NewLineKind, ScriptKind, ScriptTarget, LanguageVariant, WatchDirectoryFlags, CharacterCodes, Extension, TransformFlags, SnippetKind, EmitFlags, InternalEmitFlags, ExternalEmitHelpers, EmitHint, OuterExpressionKinds, LexicalEnvironmentFlags, BundleFileSectionKind, ListFormat, PragmaKindFlags, commentPragmas, JSDocParsingMode; + var init_types = __esm({ + "src/compiler/types.ts"() { "use strict"; SyntaxKind = /* @__PURE__ */ ((SyntaxKind5) => { SyntaxKind5[SyntaxKind5["Unknown"] = 0] = "Unknown"; @@ -102740,210 +85334,213 @@ ${lanes.join("\n")} SyntaxKind5[SyntaxKind5["UndefinedKeyword"] = 157] = "UndefinedKeyword"; SyntaxKind5[SyntaxKind5["UniqueKeyword"] = 158] = "UniqueKeyword"; SyntaxKind5[SyntaxKind5["UnknownKeyword"] = 159] = "UnknownKeyword"; - SyntaxKind5[SyntaxKind5["FromKeyword"] = 160] = "FromKeyword"; - SyntaxKind5[SyntaxKind5["GlobalKeyword"] = 161] = "GlobalKeyword"; - SyntaxKind5[SyntaxKind5["BigIntKeyword"] = 162] = "BigIntKeyword"; - SyntaxKind5[SyntaxKind5["OverrideKeyword"] = 163] = "OverrideKeyword"; - SyntaxKind5[SyntaxKind5["OfKeyword"] = 164] = "OfKeyword"; - SyntaxKind5[SyntaxKind5["QualifiedName"] = 165] = "QualifiedName"; - SyntaxKind5[SyntaxKind5["ComputedPropertyName"] = 166] = "ComputedPropertyName"; - SyntaxKind5[SyntaxKind5["TypeParameter"] = 167] = "TypeParameter"; - SyntaxKind5[SyntaxKind5["Parameter"] = 168] = "Parameter"; - SyntaxKind5[SyntaxKind5["Decorator"] = 169] = "Decorator"; - SyntaxKind5[SyntaxKind5["PropertySignature"] = 170] = "PropertySignature"; - SyntaxKind5[SyntaxKind5["PropertyDeclaration"] = 171] = "PropertyDeclaration"; - SyntaxKind5[SyntaxKind5["MethodSignature"] = 172] = "MethodSignature"; - SyntaxKind5[SyntaxKind5["MethodDeclaration"] = 173] = "MethodDeclaration"; - SyntaxKind5[SyntaxKind5["ClassStaticBlockDeclaration"] = 174] = "ClassStaticBlockDeclaration"; - SyntaxKind5[SyntaxKind5["Constructor"] = 175] = "Constructor"; - SyntaxKind5[SyntaxKind5["GetAccessor"] = 176] = "GetAccessor"; - SyntaxKind5[SyntaxKind5["SetAccessor"] = 177] = "SetAccessor"; - SyntaxKind5[SyntaxKind5["CallSignature"] = 178] = "CallSignature"; - SyntaxKind5[SyntaxKind5["ConstructSignature"] = 179] = "ConstructSignature"; - SyntaxKind5[SyntaxKind5["IndexSignature"] = 180] = "IndexSignature"; - SyntaxKind5[SyntaxKind5["TypePredicate"] = 181] = "TypePredicate"; - SyntaxKind5[SyntaxKind5["TypeReference"] = 182] = "TypeReference"; - SyntaxKind5[SyntaxKind5["FunctionType"] = 183] = "FunctionType"; - SyntaxKind5[SyntaxKind5["ConstructorType"] = 184] = "ConstructorType"; - SyntaxKind5[SyntaxKind5["TypeQuery"] = 185] = "TypeQuery"; - SyntaxKind5[SyntaxKind5["TypeLiteral"] = 186] = "TypeLiteral"; - SyntaxKind5[SyntaxKind5["ArrayType"] = 187] = "ArrayType"; - SyntaxKind5[SyntaxKind5["TupleType"] = 188] = "TupleType"; - SyntaxKind5[SyntaxKind5["OptionalType"] = 189] = "OptionalType"; - SyntaxKind5[SyntaxKind5["RestType"] = 190] = "RestType"; - SyntaxKind5[SyntaxKind5["UnionType"] = 191] = "UnionType"; - SyntaxKind5[SyntaxKind5["IntersectionType"] = 192] = "IntersectionType"; - SyntaxKind5[SyntaxKind5["ConditionalType"] = 193] = "ConditionalType"; - SyntaxKind5[SyntaxKind5["InferType"] = 194] = "InferType"; - SyntaxKind5[SyntaxKind5["ParenthesizedType"] = 195] = "ParenthesizedType"; - SyntaxKind5[SyntaxKind5["ThisType"] = 196] = "ThisType"; - SyntaxKind5[SyntaxKind5["TypeOperator"] = 197] = "TypeOperator"; - SyntaxKind5[SyntaxKind5["IndexedAccessType"] = 198] = "IndexedAccessType"; - SyntaxKind5[SyntaxKind5["MappedType"] = 199] = "MappedType"; - SyntaxKind5[SyntaxKind5["LiteralType"] = 200] = "LiteralType"; - SyntaxKind5[SyntaxKind5["NamedTupleMember"] = 201] = "NamedTupleMember"; - SyntaxKind5[SyntaxKind5["TemplateLiteralType"] = 202] = "TemplateLiteralType"; - SyntaxKind5[SyntaxKind5["TemplateLiteralTypeSpan"] = 203] = "TemplateLiteralTypeSpan"; - SyntaxKind5[SyntaxKind5["ImportType"] = 204] = "ImportType"; - SyntaxKind5[SyntaxKind5["ObjectBindingPattern"] = 205] = "ObjectBindingPattern"; - SyntaxKind5[SyntaxKind5["ArrayBindingPattern"] = 206] = "ArrayBindingPattern"; - SyntaxKind5[SyntaxKind5["BindingElement"] = 207] = "BindingElement"; - SyntaxKind5[SyntaxKind5["ArrayLiteralExpression"] = 208] = "ArrayLiteralExpression"; - SyntaxKind5[SyntaxKind5["ObjectLiteralExpression"] = 209] = "ObjectLiteralExpression"; - SyntaxKind5[SyntaxKind5["PropertyAccessExpression"] = 210] = "PropertyAccessExpression"; - SyntaxKind5[SyntaxKind5["ElementAccessExpression"] = 211] = "ElementAccessExpression"; - SyntaxKind5[SyntaxKind5["CallExpression"] = 212] = "CallExpression"; - SyntaxKind5[SyntaxKind5["NewExpression"] = 213] = "NewExpression"; - SyntaxKind5[SyntaxKind5["TaggedTemplateExpression"] = 214] = "TaggedTemplateExpression"; - SyntaxKind5[SyntaxKind5["TypeAssertionExpression"] = 215] = "TypeAssertionExpression"; - SyntaxKind5[SyntaxKind5["ParenthesizedExpression"] = 216] = "ParenthesizedExpression"; - SyntaxKind5[SyntaxKind5["FunctionExpression"] = 217] = "FunctionExpression"; - SyntaxKind5[SyntaxKind5["ArrowFunction"] = 218] = "ArrowFunction"; - SyntaxKind5[SyntaxKind5["DeleteExpression"] = 219] = "DeleteExpression"; - SyntaxKind5[SyntaxKind5["TypeOfExpression"] = 220] = "TypeOfExpression"; - SyntaxKind5[SyntaxKind5["VoidExpression"] = 221] = "VoidExpression"; - SyntaxKind5[SyntaxKind5["AwaitExpression"] = 222] = "AwaitExpression"; - SyntaxKind5[SyntaxKind5["PrefixUnaryExpression"] = 223] = "PrefixUnaryExpression"; - SyntaxKind5[SyntaxKind5["PostfixUnaryExpression"] = 224] = "PostfixUnaryExpression"; - SyntaxKind5[SyntaxKind5["BinaryExpression"] = 225] = "BinaryExpression"; - SyntaxKind5[SyntaxKind5["ConditionalExpression"] = 226] = "ConditionalExpression"; - SyntaxKind5[SyntaxKind5["TemplateExpression"] = 227] = "TemplateExpression"; - SyntaxKind5[SyntaxKind5["YieldExpression"] = 228] = "YieldExpression"; - SyntaxKind5[SyntaxKind5["SpreadElement"] = 229] = "SpreadElement"; - SyntaxKind5[SyntaxKind5["ClassExpression"] = 230] = "ClassExpression"; - SyntaxKind5[SyntaxKind5["OmittedExpression"] = 231] = "OmittedExpression"; - SyntaxKind5[SyntaxKind5["ExpressionWithTypeArguments"] = 232] = "ExpressionWithTypeArguments"; - SyntaxKind5[SyntaxKind5["AsExpression"] = 233] = "AsExpression"; - SyntaxKind5[SyntaxKind5["NonNullExpression"] = 234] = "NonNullExpression"; - SyntaxKind5[SyntaxKind5["MetaProperty"] = 235] = "MetaProperty"; - SyntaxKind5[SyntaxKind5["SyntheticExpression"] = 236] = "SyntheticExpression"; - SyntaxKind5[SyntaxKind5["SatisfiesExpression"] = 237] = "SatisfiesExpression"; - SyntaxKind5[SyntaxKind5["TemplateSpan"] = 238] = "TemplateSpan"; - SyntaxKind5[SyntaxKind5["SemicolonClassElement"] = 239] = "SemicolonClassElement"; - SyntaxKind5[SyntaxKind5["Block"] = 240] = "Block"; - SyntaxKind5[SyntaxKind5["EmptyStatement"] = 241] = "EmptyStatement"; - SyntaxKind5[SyntaxKind5["VariableStatement"] = 242] = "VariableStatement"; - SyntaxKind5[SyntaxKind5["ExpressionStatement"] = 243] = "ExpressionStatement"; - SyntaxKind5[SyntaxKind5["IfStatement"] = 244] = "IfStatement"; - SyntaxKind5[SyntaxKind5["DoStatement"] = 245] = "DoStatement"; - SyntaxKind5[SyntaxKind5["WhileStatement"] = 246] = "WhileStatement"; - SyntaxKind5[SyntaxKind5["ForStatement"] = 247] = "ForStatement"; - SyntaxKind5[SyntaxKind5["ForInStatement"] = 248] = "ForInStatement"; - SyntaxKind5[SyntaxKind5["ForOfStatement"] = 249] = "ForOfStatement"; - SyntaxKind5[SyntaxKind5["ContinueStatement"] = 250] = "ContinueStatement"; - SyntaxKind5[SyntaxKind5["BreakStatement"] = 251] = "BreakStatement"; - SyntaxKind5[SyntaxKind5["ReturnStatement"] = 252] = "ReturnStatement"; - SyntaxKind5[SyntaxKind5["WithStatement"] = 253] = "WithStatement"; - SyntaxKind5[SyntaxKind5["SwitchStatement"] = 254] = "SwitchStatement"; - SyntaxKind5[SyntaxKind5["LabeledStatement"] = 255] = "LabeledStatement"; - SyntaxKind5[SyntaxKind5["ThrowStatement"] = 256] = "ThrowStatement"; - SyntaxKind5[SyntaxKind5["TryStatement"] = 257] = "TryStatement"; - SyntaxKind5[SyntaxKind5["DebuggerStatement"] = 258] = "DebuggerStatement"; - SyntaxKind5[SyntaxKind5["VariableDeclaration"] = 259] = "VariableDeclaration"; - SyntaxKind5[SyntaxKind5["VariableDeclarationList"] = 260] = "VariableDeclarationList"; - SyntaxKind5[SyntaxKind5["FunctionDeclaration"] = 261] = "FunctionDeclaration"; - SyntaxKind5[SyntaxKind5["ClassDeclaration"] = 262] = "ClassDeclaration"; - SyntaxKind5[SyntaxKind5["InterfaceDeclaration"] = 263] = "InterfaceDeclaration"; - SyntaxKind5[SyntaxKind5["TypeAliasDeclaration"] = 264] = "TypeAliasDeclaration"; - SyntaxKind5[SyntaxKind5["EnumDeclaration"] = 265] = "EnumDeclaration"; - SyntaxKind5[SyntaxKind5["ModuleDeclaration"] = 266] = "ModuleDeclaration"; - SyntaxKind5[SyntaxKind5["ModuleBlock"] = 267] = "ModuleBlock"; - SyntaxKind5[SyntaxKind5["CaseBlock"] = 268] = "CaseBlock"; - SyntaxKind5[SyntaxKind5["NamespaceExportDeclaration"] = 269] = "NamespaceExportDeclaration"; - SyntaxKind5[SyntaxKind5["ImportEqualsDeclaration"] = 270] = "ImportEqualsDeclaration"; - SyntaxKind5[SyntaxKind5["ImportDeclaration"] = 271] = "ImportDeclaration"; - SyntaxKind5[SyntaxKind5["ImportClause"] = 272] = "ImportClause"; - SyntaxKind5[SyntaxKind5["NamespaceImport"] = 273] = "NamespaceImport"; - SyntaxKind5[SyntaxKind5["NamedImports"] = 274] = "NamedImports"; - SyntaxKind5[SyntaxKind5["ImportSpecifier"] = 275] = "ImportSpecifier"; - SyntaxKind5[SyntaxKind5["ExportAssignment"] = 276] = "ExportAssignment"; - SyntaxKind5[SyntaxKind5["ExportDeclaration"] = 277] = "ExportDeclaration"; - SyntaxKind5[SyntaxKind5["NamedExports"] = 278] = "NamedExports"; - SyntaxKind5[SyntaxKind5["NamespaceExport"] = 279] = "NamespaceExport"; - SyntaxKind5[SyntaxKind5["ExportSpecifier"] = 280] = "ExportSpecifier"; - SyntaxKind5[SyntaxKind5["MissingDeclaration"] = 281] = "MissingDeclaration"; - SyntaxKind5[SyntaxKind5["ExternalModuleReference"] = 282] = "ExternalModuleReference"; - SyntaxKind5[SyntaxKind5["JsxElement"] = 283] = "JsxElement"; - SyntaxKind5[SyntaxKind5["JsxSelfClosingElement"] = 284] = "JsxSelfClosingElement"; - SyntaxKind5[SyntaxKind5["JsxOpeningElement"] = 285] = "JsxOpeningElement"; - SyntaxKind5[SyntaxKind5["JsxClosingElement"] = 286] = "JsxClosingElement"; - SyntaxKind5[SyntaxKind5["JsxFragment"] = 287] = "JsxFragment"; - SyntaxKind5[SyntaxKind5["JsxOpeningFragment"] = 288] = "JsxOpeningFragment"; - SyntaxKind5[SyntaxKind5["JsxClosingFragment"] = 289] = "JsxClosingFragment"; - SyntaxKind5[SyntaxKind5["JsxAttribute"] = 290] = "JsxAttribute"; - SyntaxKind5[SyntaxKind5["JsxAttributes"] = 291] = "JsxAttributes"; - SyntaxKind5[SyntaxKind5["JsxSpreadAttribute"] = 292] = "JsxSpreadAttribute"; - SyntaxKind5[SyntaxKind5["JsxExpression"] = 293] = "JsxExpression"; - SyntaxKind5[SyntaxKind5["JsxNamespacedName"] = 294] = "JsxNamespacedName"; - SyntaxKind5[SyntaxKind5["CaseClause"] = 295] = "CaseClause"; - SyntaxKind5[SyntaxKind5["DefaultClause"] = 296] = "DefaultClause"; - SyntaxKind5[SyntaxKind5["HeritageClause"] = 297] = "HeritageClause"; - SyntaxKind5[SyntaxKind5["CatchClause"] = 298] = "CatchClause"; - SyntaxKind5[SyntaxKind5["AssertClause"] = 299] = "AssertClause"; - SyntaxKind5[SyntaxKind5["AssertEntry"] = 300] = "AssertEntry"; - SyntaxKind5[SyntaxKind5["ImportTypeAssertionContainer"] = 301] = "ImportTypeAssertionContainer"; - SyntaxKind5[SyntaxKind5["PropertyAssignment"] = 302] = "PropertyAssignment"; - SyntaxKind5[SyntaxKind5["ShorthandPropertyAssignment"] = 303] = "ShorthandPropertyAssignment"; - SyntaxKind5[SyntaxKind5["SpreadAssignment"] = 304] = "SpreadAssignment"; - SyntaxKind5[SyntaxKind5["EnumMember"] = 305] = "EnumMember"; - SyntaxKind5[SyntaxKind5["UnparsedPrologue"] = 306] = "UnparsedPrologue"; - SyntaxKind5[SyntaxKind5["UnparsedPrepend"] = 307] = "UnparsedPrepend"; - SyntaxKind5[SyntaxKind5["UnparsedText"] = 308] = "UnparsedText"; - SyntaxKind5[SyntaxKind5["UnparsedInternalText"] = 309] = "UnparsedInternalText"; - SyntaxKind5[SyntaxKind5["UnparsedSyntheticReference"] = 310] = "UnparsedSyntheticReference"; - SyntaxKind5[SyntaxKind5["SourceFile"] = 311] = "SourceFile"; - SyntaxKind5[SyntaxKind5["Bundle"] = 312] = "Bundle"; - SyntaxKind5[SyntaxKind5["UnparsedSource"] = 313] = "UnparsedSource"; - SyntaxKind5[SyntaxKind5["InputFiles"] = 314] = "InputFiles"; - SyntaxKind5[SyntaxKind5["JSDocTypeExpression"] = 315] = "JSDocTypeExpression"; - SyntaxKind5[SyntaxKind5["JSDocNameReference"] = 316] = "JSDocNameReference"; - SyntaxKind5[SyntaxKind5["JSDocMemberName"] = 317] = "JSDocMemberName"; - SyntaxKind5[SyntaxKind5["JSDocAllType"] = 318] = "JSDocAllType"; - SyntaxKind5[SyntaxKind5["JSDocUnknownType"] = 319] = "JSDocUnknownType"; - SyntaxKind5[SyntaxKind5["JSDocNullableType"] = 320] = "JSDocNullableType"; - SyntaxKind5[SyntaxKind5["JSDocNonNullableType"] = 321] = "JSDocNonNullableType"; - SyntaxKind5[SyntaxKind5["JSDocOptionalType"] = 322] = "JSDocOptionalType"; - SyntaxKind5[SyntaxKind5["JSDocFunctionType"] = 323] = "JSDocFunctionType"; - SyntaxKind5[SyntaxKind5["JSDocVariadicType"] = 324] = "JSDocVariadicType"; - SyntaxKind5[SyntaxKind5["JSDocNamepathType"] = 325] = "JSDocNamepathType"; - SyntaxKind5[SyntaxKind5["JSDoc"] = 326] = "JSDoc"; - SyntaxKind5[SyntaxKind5["JSDocComment"] = 326 /* JSDoc */] = "JSDocComment"; - SyntaxKind5[SyntaxKind5["JSDocText"] = 327] = "JSDocText"; - SyntaxKind5[SyntaxKind5["JSDocTypeLiteral"] = 328] = "JSDocTypeLiteral"; - SyntaxKind5[SyntaxKind5["JSDocSignature"] = 329] = "JSDocSignature"; - SyntaxKind5[SyntaxKind5["JSDocLink"] = 330] = "JSDocLink"; - SyntaxKind5[SyntaxKind5["JSDocLinkCode"] = 331] = "JSDocLinkCode"; - SyntaxKind5[SyntaxKind5["JSDocLinkPlain"] = 332] = "JSDocLinkPlain"; - SyntaxKind5[SyntaxKind5["JSDocTag"] = 333] = "JSDocTag"; - SyntaxKind5[SyntaxKind5["JSDocAugmentsTag"] = 334] = "JSDocAugmentsTag"; - SyntaxKind5[SyntaxKind5["JSDocImplementsTag"] = 335] = "JSDocImplementsTag"; - SyntaxKind5[SyntaxKind5["JSDocAuthorTag"] = 336] = "JSDocAuthorTag"; - SyntaxKind5[SyntaxKind5["JSDocDeprecatedTag"] = 337] = "JSDocDeprecatedTag"; - SyntaxKind5[SyntaxKind5["JSDocClassTag"] = 338] = "JSDocClassTag"; - SyntaxKind5[SyntaxKind5["JSDocPublicTag"] = 339] = "JSDocPublicTag"; - SyntaxKind5[SyntaxKind5["JSDocPrivateTag"] = 340] = "JSDocPrivateTag"; - SyntaxKind5[SyntaxKind5["JSDocProtectedTag"] = 341] = "JSDocProtectedTag"; - SyntaxKind5[SyntaxKind5["JSDocReadonlyTag"] = 342] = "JSDocReadonlyTag"; - SyntaxKind5[SyntaxKind5["JSDocOverrideTag"] = 343] = "JSDocOverrideTag"; - SyntaxKind5[SyntaxKind5["JSDocCallbackTag"] = 344] = "JSDocCallbackTag"; - SyntaxKind5[SyntaxKind5["JSDocOverloadTag"] = 345] = "JSDocOverloadTag"; - SyntaxKind5[SyntaxKind5["JSDocEnumTag"] = 346] = "JSDocEnumTag"; - SyntaxKind5[SyntaxKind5["JSDocParameterTag"] = 347] = "JSDocParameterTag"; - SyntaxKind5[SyntaxKind5["JSDocReturnTag"] = 348] = "JSDocReturnTag"; - SyntaxKind5[SyntaxKind5["JSDocThisTag"] = 349] = "JSDocThisTag"; - SyntaxKind5[SyntaxKind5["JSDocTypeTag"] = 350] = "JSDocTypeTag"; - SyntaxKind5[SyntaxKind5["JSDocTemplateTag"] = 351] = "JSDocTemplateTag"; - SyntaxKind5[SyntaxKind5["JSDocTypedefTag"] = 352] = "JSDocTypedefTag"; - SyntaxKind5[SyntaxKind5["JSDocSeeTag"] = 353] = "JSDocSeeTag"; - SyntaxKind5[SyntaxKind5["JSDocPropertyTag"] = 354] = "JSDocPropertyTag"; - SyntaxKind5[SyntaxKind5["JSDocThrowsTag"] = 355] = "JSDocThrowsTag"; - SyntaxKind5[SyntaxKind5["JSDocSatisfiesTag"] = 356] = "JSDocSatisfiesTag"; - SyntaxKind5[SyntaxKind5["SyntaxList"] = 357] = "SyntaxList"; - SyntaxKind5[SyntaxKind5["NotEmittedStatement"] = 358] = "NotEmittedStatement"; - SyntaxKind5[SyntaxKind5["PartiallyEmittedExpression"] = 359] = "PartiallyEmittedExpression"; - SyntaxKind5[SyntaxKind5["CommaListExpression"] = 360] = "CommaListExpression"; - SyntaxKind5[SyntaxKind5["SyntheticReferenceExpression"] = 361] = "SyntheticReferenceExpression"; - SyntaxKind5[SyntaxKind5["Count"] = 362] = "Count"; + SyntaxKind5[SyntaxKind5["UsingKeyword"] = 160] = "UsingKeyword"; + SyntaxKind5[SyntaxKind5["FromKeyword"] = 161] = "FromKeyword"; + SyntaxKind5[SyntaxKind5["GlobalKeyword"] = 162] = "GlobalKeyword"; + SyntaxKind5[SyntaxKind5["BigIntKeyword"] = 163] = "BigIntKeyword"; + SyntaxKind5[SyntaxKind5["OverrideKeyword"] = 164] = "OverrideKeyword"; + SyntaxKind5[SyntaxKind5["OfKeyword"] = 165] = "OfKeyword"; + SyntaxKind5[SyntaxKind5["QualifiedName"] = 166] = "QualifiedName"; + SyntaxKind5[SyntaxKind5["ComputedPropertyName"] = 167] = "ComputedPropertyName"; + SyntaxKind5[SyntaxKind5["TypeParameter"] = 168] = "TypeParameter"; + SyntaxKind5[SyntaxKind5["Parameter"] = 169] = "Parameter"; + SyntaxKind5[SyntaxKind5["Decorator"] = 170] = "Decorator"; + SyntaxKind5[SyntaxKind5["PropertySignature"] = 171] = "PropertySignature"; + SyntaxKind5[SyntaxKind5["PropertyDeclaration"] = 172] = "PropertyDeclaration"; + SyntaxKind5[SyntaxKind5["MethodSignature"] = 173] = "MethodSignature"; + SyntaxKind5[SyntaxKind5["MethodDeclaration"] = 174] = "MethodDeclaration"; + SyntaxKind5[SyntaxKind5["ClassStaticBlockDeclaration"] = 175] = "ClassStaticBlockDeclaration"; + SyntaxKind5[SyntaxKind5["Constructor"] = 176] = "Constructor"; + SyntaxKind5[SyntaxKind5["GetAccessor"] = 177] = "GetAccessor"; + SyntaxKind5[SyntaxKind5["SetAccessor"] = 178] = "SetAccessor"; + SyntaxKind5[SyntaxKind5["CallSignature"] = 179] = "CallSignature"; + SyntaxKind5[SyntaxKind5["ConstructSignature"] = 180] = "ConstructSignature"; + SyntaxKind5[SyntaxKind5["IndexSignature"] = 181] = "IndexSignature"; + SyntaxKind5[SyntaxKind5["TypePredicate"] = 182] = "TypePredicate"; + SyntaxKind5[SyntaxKind5["TypeReference"] = 183] = "TypeReference"; + SyntaxKind5[SyntaxKind5["FunctionType"] = 184] = "FunctionType"; + SyntaxKind5[SyntaxKind5["ConstructorType"] = 185] = "ConstructorType"; + SyntaxKind5[SyntaxKind5["TypeQuery"] = 186] = "TypeQuery"; + SyntaxKind5[SyntaxKind5["TypeLiteral"] = 187] = "TypeLiteral"; + SyntaxKind5[SyntaxKind5["ArrayType"] = 188] = "ArrayType"; + SyntaxKind5[SyntaxKind5["TupleType"] = 189] = "TupleType"; + SyntaxKind5[SyntaxKind5["OptionalType"] = 190] = "OptionalType"; + SyntaxKind5[SyntaxKind5["RestType"] = 191] = "RestType"; + SyntaxKind5[SyntaxKind5["UnionType"] = 192] = "UnionType"; + SyntaxKind5[SyntaxKind5["IntersectionType"] = 193] = "IntersectionType"; + SyntaxKind5[SyntaxKind5["ConditionalType"] = 194] = "ConditionalType"; + SyntaxKind5[SyntaxKind5["InferType"] = 195] = "InferType"; + SyntaxKind5[SyntaxKind5["ParenthesizedType"] = 196] = "ParenthesizedType"; + SyntaxKind5[SyntaxKind5["ThisType"] = 197] = "ThisType"; + SyntaxKind5[SyntaxKind5["TypeOperator"] = 198] = "TypeOperator"; + SyntaxKind5[SyntaxKind5["IndexedAccessType"] = 199] = "IndexedAccessType"; + SyntaxKind5[SyntaxKind5["MappedType"] = 200] = "MappedType"; + SyntaxKind5[SyntaxKind5["LiteralType"] = 201] = "LiteralType"; + SyntaxKind5[SyntaxKind5["NamedTupleMember"] = 202] = "NamedTupleMember"; + SyntaxKind5[SyntaxKind5["TemplateLiteralType"] = 203] = "TemplateLiteralType"; + SyntaxKind5[SyntaxKind5["TemplateLiteralTypeSpan"] = 204] = "TemplateLiteralTypeSpan"; + SyntaxKind5[SyntaxKind5["ImportType"] = 205] = "ImportType"; + SyntaxKind5[SyntaxKind5["ObjectBindingPattern"] = 206] = "ObjectBindingPattern"; + SyntaxKind5[SyntaxKind5["ArrayBindingPattern"] = 207] = "ArrayBindingPattern"; + SyntaxKind5[SyntaxKind5["BindingElement"] = 208] = "BindingElement"; + SyntaxKind5[SyntaxKind5["ArrayLiteralExpression"] = 209] = "ArrayLiteralExpression"; + SyntaxKind5[SyntaxKind5["ObjectLiteralExpression"] = 210] = "ObjectLiteralExpression"; + SyntaxKind5[SyntaxKind5["PropertyAccessExpression"] = 211] = "PropertyAccessExpression"; + SyntaxKind5[SyntaxKind5["ElementAccessExpression"] = 212] = "ElementAccessExpression"; + SyntaxKind5[SyntaxKind5["CallExpression"] = 213] = "CallExpression"; + SyntaxKind5[SyntaxKind5["NewExpression"] = 214] = "NewExpression"; + SyntaxKind5[SyntaxKind5["TaggedTemplateExpression"] = 215] = "TaggedTemplateExpression"; + SyntaxKind5[SyntaxKind5["TypeAssertionExpression"] = 216] = "TypeAssertionExpression"; + SyntaxKind5[SyntaxKind5["ParenthesizedExpression"] = 217] = "ParenthesizedExpression"; + SyntaxKind5[SyntaxKind5["FunctionExpression"] = 218] = "FunctionExpression"; + SyntaxKind5[SyntaxKind5["ArrowFunction"] = 219] = "ArrowFunction"; + SyntaxKind5[SyntaxKind5["DeleteExpression"] = 220] = "DeleteExpression"; + SyntaxKind5[SyntaxKind5["TypeOfExpression"] = 221] = "TypeOfExpression"; + SyntaxKind5[SyntaxKind5["VoidExpression"] = 222] = "VoidExpression"; + SyntaxKind5[SyntaxKind5["AwaitExpression"] = 223] = "AwaitExpression"; + SyntaxKind5[SyntaxKind5["PrefixUnaryExpression"] = 224] = "PrefixUnaryExpression"; + SyntaxKind5[SyntaxKind5["PostfixUnaryExpression"] = 225] = "PostfixUnaryExpression"; + SyntaxKind5[SyntaxKind5["BinaryExpression"] = 226] = "BinaryExpression"; + SyntaxKind5[SyntaxKind5["ConditionalExpression"] = 227] = "ConditionalExpression"; + SyntaxKind5[SyntaxKind5["TemplateExpression"] = 228] = "TemplateExpression"; + SyntaxKind5[SyntaxKind5["YieldExpression"] = 229] = "YieldExpression"; + SyntaxKind5[SyntaxKind5["SpreadElement"] = 230] = "SpreadElement"; + SyntaxKind5[SyntaxKind5["ClassExpression"] = 231] = "ClassExpression"; + SyntaxKind5[SyntaxKind5["OmittedExpression"] = 232] = "OmittedExpression"; + SyntaxKind5[SyntaxKind5["ExpressionWithTypeArguments"] = 233] = "ExpressionWithTypeArguments"; + SyntaxKind5[SyntaxKind5["AsExpression"] = 234] = "AsExpression"; + SyntaxKind5[SyntaxKind5["NonNullExpression"] = 235] = "NonNullExpression"; + SyntaxKind5[SyntaxKind5["MetaProperty"] = 236] = "MetaProperty"; + SyntaxKind5[SyntaxKind5["SyntheticExpression"] = 237] = "SyntheticExpression"; + SyntaxKind5[SyntaxKind5["SatisfiesExpression"] = 238] = "SatisfiesExpression"; + SyntaxKind5[SyntaxKind5["TemplateSpan"] = 239] = "TemplateSpan"; + SyntaxKind5[SyntaxKind5["SemicolonClassElement"] = 240] = "SemicolonClassElement"; + SyntaxKind5[SyntaxKind5["Block"] = 241] = "Block"; + SyntaxKind5[SyntaxKind5["EmptyStatement"] = 242] = "EmptyStatement"; + SyntaxKind5[SyntaxKind5["VariableStatement"] = 243] = "VariableStatement"; + SyntaxKind5[SyntaxKind5["ExpressionStatement"] = 244] = "ExpressionStatement"; + SyntaxKind5[SyntaxKind5["IfStatement"] = 245] = "IfStatement"; + SyntaxKind5[SyntaxKind5["DoStatement"] = 246] = "DoStatement"; + SyntaxKind5[SyntaxKind5["WhileStatement"] = 247] = "WhileStatement"; + SyntaxKind5[SyntaxKind5["ForStatement"] = 248] = "ForStatement"; + SyntaxKind5[SyntaxKind5["ForInStatement"] = 249] = "ForInStatement"; + SyntaxKind5[SyntaxKind5["ForOfStatement"] = 250] = "ForOfStatement"; + SyntaxKind5[SyntaxKind5["ContinueStatement"] = 251] = "ContinueStatement"; + SyntaxKind5[SyntaxKind5["BreakStatement"] = 252] = "BreakStatement"; + SyntaxKind5[SyntaxKind5["ReturnStatement"] = 253] = "ReturnStatement"; + SyntaxKind5[SyntaxKind5["WithStatement"] = 254] = "WithStatement"; + SyntaxKind5[SyntaxKind5["SwitchStatement"] = 255] = "SwitchStatement"; + SyntaxKind5[SyntaxKind5["LabeledStatement"] = 256] = "LabeledStatement"; + SyntaxKind5[SyntaxKind5["ThrowStatement"] = 257] = "ThrowStatement"; + SyntaxKind5[SyntaxKind5["TryStatement"] = 258] = "TryStatement"; + SyntaxKind5[SyntaxKind5["DebuggerStatement"] = 259] = "DebuggerStatement"; + SyntaxKind5[SyntaxKind5["VariableDeclaration"] = 260] = "VariableDeclaration"; + SyntaxKind5[SyntaxKind5["VariableDeclarationList"] = 261] = "VariableDeclarationList"; + SyntaxKind5[SyntaxKind5["FunctionDeclaration"] = 262] = "FunctionDeclaration"; + SyntaxKind5[SyntaxKind5["ClassDeclaration"] = 263] = "ClassDeclaration"; + SyntaxKind5[SyntaxKind5["InterfaceDeclaration"] = 264] = "InterfaceDeclaration"; + SyntaxKind5[SyntaxKind5["TypeAliasDeclaration"] = 265] = "TypeAliasDeclaration"; + SyntaxKind5[SyntaxKind5["EnumDeclaration"] = 266] = "EnumDeclaration"; + SyntaxKind5[SyntaxKind5["ModuleDeclaration"] = 267] = "ModuleDeclaration"; + SyntaxKind5[SyntaxKind5["ModuleBlock"] = 268] = "ModuleBlock"; + SyntaxKind5[SyntaxKind5["CaseBlock"] = 269] = "CaseBlock"; + SyntaxKind5[SyntaxKind5["NamespaceExportDeclaration"] = 270] = "NamespaceExportDeclaration"; + SyntaxKind5[SyntaxKind5["ImportEqualsDeclaration"] = 271] = "ImportEqualsDeclaration"; + SyntaxKind5[SyntaxKind5["ImportDeclaration"] = 272] = "ImportDeclaration"; + SyntaxKind5[SyntaxKind5["ImportClause"] = 273] = "ImportClause"; + SyntaxKind5[SyntaxKind5["NamespaceImport"] = 274] = "NamespaceImport"; + SyntaxKind5[SyntaxKind5["NamedImports"] = 275] = "NamedImports"; + SyntaxKind5[SyntaxKind5["ImportSpecifier"] = 276] = "ImportSpecifier"; + SyntaxKind5[SyntaxKind5["ExportAssignment"] = 277] = "ExportAssignment"; + SyntaxKind5[SyntaxKind5["ExportDeclaration"] = 278] = "ExportDeclaration"; + SyntaxKind5[SyntaxKind5["NamedExports"] = 279] = "NamedExports"; + SyntaxKind5[SyntaxKind5["NamespaceExport"] = 280] = "NamespaceExport"; + SyntaxKind5[SyntaxKind5["ExportSpecifier"] = 281] = "ExportSpecifier"; + SyntaxKind5[SyntaxKind5["MissingDeclaration"] = 282] = "MissingDeclaration"; + SyntaxKind5[SyntaxKind5["ExternalModuleReference"] = 283] = "ExternalModuleReference"; + SyntaxKind5[SyntaxKind5["JsxElement"] = 284] = "JsxElement"; + SyntaxKind5[SyntaxKind5["JsxSelfClosingElement"] = 285] = "JsxSelfClosingElement"; + SyntaxKind5[SyntaxKind5["JsxOpeningElement"] = 286] = "JsxOpeningElement"; + SyntaxKind5[SyntaxKind5["JsxClosingElement"] = 287] = "JsxClosingElement"; + SyntaxKind5[SyntaxKind5["JsxFragment"] = 288] = "JsxFragment"; + SyntaxKind5[SyntaxKind5["JsxOpeningFragment"] = 289] = "JsxOpeningFragment"; + SyntaxKind5[SyntaxKind5["JsxClosingFragment"] = 290] = "JsxClosingFragment"; + SyntaxKind5[SyntaxKind5["JsxAttribute"] = 291] = "JsxAttribute"; + SyntaxKind5[SyntaxKind5["JsxAttributes"] = 292] = "JsxAttributes"; + SyntaxKind5[SyntaxKind5["JsxSpreadAttribute"] = 293] = "JsxSpreadAttribute"; + SyntaxKind5[SyntaxKind5["JsxExpression"] = 294] = "JsxExpression"; + SyntaxKind5[SyntaxKind5["JsxNamespacedName"] = 295] = "JsxNamespacedName"; + SyntaxKind5[SyntaxKind5["CaseClause"] = 296] = "CaseClause"; + SyntaxKind5[SyntaxKind5["DefaultClause"] = 297] = "DefaultClause"; + SyntaxKind5[SyntaxKind5["HeritageClause"] = 298] = "HeritageClause"; + SyntaxKind5[SyntaxKind5["CatchClause"] = 299] = "CatchClause"; + SyntaxKind5[SyntaxKind5["ImportAttributes"] = 300] = "ImportAttributes"; + SyntaxKind5[SyntaxKind5["ImportAttribute"] = 301] = "ImportAttribute"; + SyntaxKind5[SyntaxKind5["AssertClause"] = 300 /* ImportAttributes */] = "AssertClause"; + SyntaxKind5[SyntaxKind5["AssertEntry"] = 301 /* ImportAttribute */] = "AssertEntry"; + SyntaxKind5[SyntaxKind5["ImportTypeAssertionContainer"] = 302] = "ImportTypeAssertionContainer"; + SyntaxKind5[SyntaxKind5["PropertyAssignment"] = 303] = "PropertyAssignment"; + SyntaxKind5[SyntaxKind5["ShorthandPropertyAssignment"] = 304] = "ShorthandPropertyAssignment"; + SyntaxKind5[SyntaxKind5["SpreadAssignment"] = 305] = "SpreadAssignment"; + SyntaxKind5[SyntaxKind5["EnumMember"] = 306] = "EnumMember"; + SyntaxKind5[SyntaxKind5["UnparsedPrologue"] = 307] = "UnparsedPrologue"; + SyntaxKind5[SyntaxKind5["UnparsedPrepend"] = 308] = "UnparsedPrepend"; + SyntaxKind5[SyntaxKind5["UnparsedText"] = 309] = "UnparsedText"; + SyntaxKind5[SyntaxKind5["UnparsedInternalText"] = 310] = "UnparsedInternalText"; + SyntaxKind5[SyntaxKind5["UnparsedSyntheticReference"] = 311] = "UnparsedSyntheticReference"; + SyntaxKind5[SyntaxKind5["SourceFile"] = 312] = "SourceFile"; + SyntaxKind5[SyntaxKind5["Bundle"] = 313] = "Bundle"; + SyntaxKind5[SyntaxKind5["UnparsedSource"] = 314] = "UnparsedSource"; + SyntaxKind5[SyntaxKind5["InputFiles"] = 315] = "InputFiles"; + SyntaxKind5[SyntaxKind5["JSDocTypeExpression"] = 316] = "JSDocTypeExpression"; + SyntaxKind5[SyntaxKind5["JSDocNameReference"] = 317] = "JSDocNameReference"; + SyntaxKind5[SyntaxKind5["JSDocMemberName"] = 318] = "JSDocMemberName"; + SyntaxKind5[SyntaxKind5["JSDocAllType"] = 319] = "JSDocAllType"; + SyntaxKind5[SyntaxKind5["JSDocUnknownType"] = 320] = "JSDocUnknownType"; + SyntaxKind5[SyntaxKind5["JSDocNullableType"] = 321] = "JSDocNullableType"; + SyntaxKind5[SyntaxKind5["JSDocNonNullableType"] = 322] = "JSDocNonNullableType"; + SyntaxKind5[SyntaxKind5["JSDocOptionalType"] = 323] = "JSDocOptionalType"; + SyntaxKind5[SyntaxKind5["JSDocFunctionType"] = 324] = "JSDocFunctionType"; + SyntaxKind5[SyntaxKind5["JSDocVariadicType"] = 325] = "JSDocVariadicType"; + SyntaxKind5[SyntaxKind5["JSDocNamepathType"] = 326] = "JSDocNamepathType"; + SyntaxKind5[SyntaxKind5["JSDoc"] = 327] = "JSDoc"; + SyntaxKind5[SyntaxKind5["JSDocComment"] = 327 /* JSDoc */] = "JSDocComment"; + SyntaxKind5[SyntaxKind5["JSDocText"] = 328] = "JSDocText"; + SyntaxKind5[SyntaxKind5["JSDocTypeLiteral"] = 329] = "JSDocTypeLiteral"; + SyntaxKind5[SyntaxKind5["JSDocSignature"] = 330] = "JSDocSignature"; + SyntaxKind5[SyntaxKind5["JSDocLink"] = 331] = "JSDocLink"; + SyntaxKind5[SyntaxKind5["JSDocLinkCode"] = 332] = "JSDocLinkCode"; + SyntaxKind5[SyntaxKind5["JSDocLinkPlain"] = 333] = "JSDocLinkPlain"; + SyntaxKind5[SyntaxKind5["JSDocTag"] = 334] = "JSDocTag"; + SyntaxKind5[SyntaxKind5["JSDocAugmentsTag"] = 335] = "JSDocAugmentsTag"; + SyntaxKind5[SyntaxKind5["JSDocImplementsTag"] = 336] = "JSDocImplementsTag"; + SyntaxKind5[SyntaxKind5["JSDocAuthorTag"] = 337] = "JSDocAuthorTag"; + SyntaxKind5[SyntaxKind5["JSDocDeprecatedTag"] = 338] = "JSDocDeprecatedTag"; + SyntaxKind5[SyntaxKind5["JSDocClassTag"] = 339] = "JSDocClassTag"; + SyntaxKind5[SyntaxKind5["JSDocPublicTag"] = 340] = "JSDocPublicTag"; + SyntaxKind5[SyntaxKind5["JSDocPrivateTag"] = 341] = "JSDocPrivateTag"; + SyntaxKind5[SyntaxKind5["JSDocProtectedTag"] = 342] = "JSDocProtectedTag"; + SyntaxKind5[SyntaxKind5["JSDocReadonlyTag"] = 343] = "JSDocReadonlyTag"; + SyntaxKind5[SyntaxKind5["JSDocOverrideTag"] = 344] = "JSDocOverrideTag"; + SyntaxKind5[SyntaxKind5["JSDocCallbackTag"] = 345] = "JSDocCallbackTag"; + SyntaxKind5[SyntaxKind5["JSDocOverloadTag"] = 346] = "JSDocOverloadTag"; + SyntaxKind5[SyntaxKind5["JSDocEnumTag"] = 347] = "JSDocEnumTag"; + SyntaxKind5[SyntaxKind5["JSDocParameterTag"] = 348] = "JSDocParameterTag"; + SyntaxKind5[SyntaxKind5["JSDocReturnTag"] = 349] = "JSDocReturnTag"; + SyntaxKind5[SyntaxKind5["JSDocThisTag"] = 350] = "JSDocThisTag"; + SyntaxKind5[SyntaxKind5["JSDocTypeTag"] = 351] = "JSDocTypeTag"; + SyntaxKind5[SyntaxKind5["JSDocTemplateTag"] = 352] = "JSDocTemplateTag"; + SyntaxKind5[SyntaxKind5["JSDocTypedefTag"] = 353] = "JSDocTypedefTag"; + SyntaxKind5[SyntaxKind5["JSDocSeeTag"] = 354] = "JSDocSeeTag"; + SyntaxKind5[SyntaxKind5["JSDocPropertyTag"] = 355] = "JSDocPropertyTag"; + SyntaxKind5[SyntaxKind5["JSDocThrowsTag"] = 356] = "JSDocThrowsTag"; + SyntaxKind5[SyntaxKind5["JSDocSatisfiesTag"] = 357] = "JSDocSatisfiesTag"; + SyntaxKind5[SyntaxKind5["SyntaxList"] = 358] = "SyntaxList"; + SyntaxKind5[SyntaxKind5["NotEmittedStatement"] = 359] = "NotEmittedStatement"; + SyntaxKind5[SyntaxKind5["PartiallyEmittedExpression"] = 360] = "PartiallyEmittedExpression"; + SyntaxKind5[SyntaxKind5["CommaListExpression"] = 361] = "CommaListExpression"; + SyntaxKind5[SyntaxKind5["SyntheticReferenceExpression"] = 362] = "SyntheticReferenceExpression"; + SyntaxKind5[SyntaxKind5["Count"] = 363] = "Count"; SyntaxKind5[SyntaxKind5["FirstAssignment"] = 64 /* EqualsToken */] = "FirstAssignment"; SyntaxKind5[SyntaxKind5["LastAssignment"] = 79 /* CaretEqualsToken */] = "LastAssignment"; SyntaxKind5[SyntaxKind5["FirstCompoundAssignment"] = 65 /* PlusEqualsToken */] = "FirstCompoundAssignment"; @@ -102951,15 +85548,15 @@ ${lanes.join("\n")} SyntaxKind5[SyntaxKind5["FirstReservedWord"] = 83 /* BreakKeyword */] = "FirstReservedWord"; SyntaxKind5[SyntaxKind5["LastReservedWord"] = 118 /* WithKeyword */] = "LastReservedWord"; SyntaxKind5[SyntaxKind5["FirstKeyword"] = 83 /* BreakKeyword */] = "FirstKeyword"; - SyntaxKind5[SyntaxKind5["LastKeyword"] = 164 /* OfKeyword */] = "LastKeyword"; + SyntaxKind5[SyntaxKind5["LastKeyword"] = 165 /* OfKeyword */] = "LastKeyword"; SyntaxKind5[SyntaxKind5["FirstFutureReservedWord"] = 119 /* ImplementsKeyword */] = "FirstFutureReservedWord"; SyntaxKind5[SyntaxKind5["LastFutureReservedWord"] = 127 /* YieldKeyword */] = "LastFutureReservedWord"; - SyntaxKind5[SyntaxKind5["FirstTypeNode"] = 181 /* TypePredicate */] = "FirstTypeNode"; - SyntaxKind5[SyntaxKind5["LastTypeNode"] = 204 /* ImportType */] = "LastTypeNode"; + SyntaxKind5[SyntaxKind5["FirstTypeNode"] = 182 /* TypePredicate */] = "FirstTypeNode"; + SyntaxKind5[SyntaxKind5["LastTypeNode"] = 205 /* ImportType */] = "LastTypeNode"; SyntaxKind5[SyntaxKind5["FirstPunctuation"] = 19 /* OpenBraceToken */] = "FirstPunctuation"; SyntaxKind5[SyntaxKind5["LastPunctuation"] = 79 /* CaretEqualsToken */] = "LastPunctuation"; SyntaxKind5[SyntaxKind5["FirstToken"] = 0 /* Unknown */] = "FirstToken"; - SyntaxKind5[SyntaxKind5["LastToken"] = 164 /* LastKeyword */] = "LastToken"; + SyntaxKind5[SyntaxKind5["LastToken"] = 165 /* LastKeyword */] = "LastToken"; SyntaxKind5[SyntaxKind5["FirstTriviaToken"] = 2 /* SingleLineCommentTrivia */] = "FirstTriviaToken"; SyntaxKind5[SyntaxKind5["LastTriviaToken"] = 7 /* ConflictMarkerTrivia */] = "LastTriviaToken"; SyntaxKind5[SyntaxKind5["FirstLiteralToken"] = 9 /* NumericLiteral */] = "FirstLiteralToken"; @@ -102968,86 +85565,100 @@ ${lanes.join("\n")} SyntaxKind5[SyntaxKind5["LastTemplateToken"] = 18 /* TemplateTail */] = "LastTemplateToken"; SyntaxKind5[SyntaxKind5["FirstBinaryOperator"] = 30 /* LessThanToken */] = "FirstBinaryOperator"; SyntaxKind5[SyntaxKind5["LastBinaryOperator"] = 79 /* CaretEqualsToken */] = "LastBinaryOperator"; - SyntaxKind5[SyntaxKind5["FirstStatement"] = 242 /* VariableStatement */] = "FirstStatement"; - SyntaxKind5[SyntaxKind5["LastStatement"] = 258 /* DebuggerStatement */] = "LastStatement"; - SyntaxKind5[SyntaxKind5["FirstNode"] = 165 /* QualifiedName */] = "FirstNode"; - SyntaxKind5[SyntaxKind5["FirstJSDocNode"] = 315 /* JSDocTypeExpression */] = "FirstJSDocNode"; - SyntaxKind5[SyntaxKind5["LastJSDocNode"] = 356 /* JSDocSatisfiesTag */] = "LastJSDocNode"; - SyntaxKind5[SyntaxKind5["FirstJSDocTagNode"] = 333 /* JSDocTag */] = "FirstJSDocTagNode"; - SyntaxKind5[SyntaxKind5["LastJSDocTagNode"] = 356 /* JSDocSatisfiesTag */] = "LastJSDocTagNode"; + SyntaxKind5[SyntaxKind5["FirstStatement"] = 243 /* VariableStatement */] = "FirstStatement"; + SyntaxKind5[SyntaxKind5["LastStatement"] = 259 /* DebuggerStatement */] = "LastStatement"; + SyntaxKind5[SyntaxKind5["FirstNode"] = 166 /* QualifiedName */] = "FirstNode"; + SyntaxKind5[SyntaxKind5["FirstJSDocNode"] = 316 /* JSDocTypeExpression */] = "FirstJSDocNode"; + SyntaxKind5[SyntaxKind5["LastJSDocNode"] = 357 /* JSDocSatisfiesTag */] = "LastJSDocNode"; + SyntaxKind5[SyntaxKind5["FirstJSDocTagNode"] = 334 /* JSDocTag */] = "FirstJSDocTagNode"; + SyntaxKind5[SyntaxKind5["LastJSDocTagNode"] = 357 /* JSDocSatisfiesTag */] = "LastJSDocTagNode"; SyntaxKind5[SyntaxKind5["FirstContextualKeyword"] = 128 /* AbstractKeyword */] = "FirstContextualKeyword"; - SyntaxKind5[SyntaxKind5["LastContextualKeyword"] = 164 /* OfKeyword */] = "LastContextualKeyword"; + SyntaxKind5[SyntaxKind5["LastContextualKeyword"] = 165 /* OfKeyword */] = "LastContextualKeyword"; return SyntaxKind5; })(SyntaxKind || {}); NodeFlags = /* @__PURE__ */ ((NodeFlags3) => { NodeFlags3[NodeFlags3["None"] = 0] = "None"; NodeFlags3[NodeFlags3["Let"] = 1] = "Let"; NodeFlags3[NodeFlags3["Const"] = 2] = "Const"; - NodeFlags3[NodeFlags3["NestedNamespace"] = 4] = "NestedNamespace"; - NodeFlags3[NodeFlags3["Synthesized"] = 8] = "Synthesized"; - NodeFlags3[NodeFlags3["Namespace"] = 16] = "Namespace"; - NodeFlags3[NodeFlags3["OptionalChain"] = 32] = "OptionalChain"; - NodeFlags3[NodeFlags3["ExportContext"] = 64] = "ExportContext"; - NodeFlags3[NodeFlags3["ContainsThis"] = 128] = "ContainsThis"; - NodeFlags3[NodeFlags3["HasImplicitReturn"] = 256] = "HasImplicitReturn"; - NodeFlags3[NodeFlags3["HasExplicitReturn"] = 512] = "HasExplicitReturn"; - NodeFlags3[NodeFlags3["GlobalAugmentation"] = 1024] = "GlobalAugmentation"; - NodeFlags3[NodeFlags3["HasAsyncFunctions"] = 2048] = "HasAsyncFunctions"; - NodeFlags3[NodeFlags3["DisallowInContext"] = 4096] = "DisallowInContext"; - NodeFlags3[NodeFlags3["YieldContext"] = 8192] = "YieldContext"; - NodeFlags3[NodeFlags3["DecoratorContext"] = 16384] = "DecoratorContext"; - NodeFlags3[NodeFlags3["AwaitContext"] = 32768] = "AwaitContext"; - NodeFlags3[NodeFlags3["DisallowConditionalTypesContext"] = 65536] = "DisallowConditionalTypesContext"; - NodeFlags3[NodeFlags3["ThisNodeHasError"] = 131072] = "ThisNodeHasError"; - NodeFlags3[NodeFlags3["JavaScriptFile"] = 262144] = "JavaScriptFile"; - NodeFlags3[NodeFlags3["ThisNodeOrAnySubNodesHasError"] = 524288] = "ThisNodeOrAnySubNodesHasError"; - NodeFlags3[NodeFlags3["HasAggregatedChildData"] = 1048576] = "HasAggregatedChildData"; - NodeFlags3[NodeFlags3["PossiblyContainsDynamicImport"] = 2097152] = "PossiblyContainsDynamicImport"; - NodeFlags3[NodeFlags3["PossiblyContainsImportMeta"] = 4194304] = "PossiblyContainsImportMeta"; - NodeFlags3[NodeFlags3["JSDoc"] = 8388608] = "JSDoc"; - NodeFlags3[NodeFlags3["Ambient"] = 16777216] = "Ambient"; - NodeFlags3[NodeFlags3["InWithStatement"] = 33554432] = "InWithStatement"; - NodeFlags3[NodeFlags3["JsonFile"] = 67108864] = "JsonFile"; - NodeFlags3[NodeFlags3["TypeCached"] = 134217728] = "TypeCached"; - NodeFlags3[NodeFlags3["Deprecated"] = 268435456] = "Deprecated"; - NodeFlags3[NodeFlags3["BlockScoped"] = 3] = "BlockScoped"; - NodeFlags3[NodeFlags3["ReachabilityCheckFlags"] = 768] = "ReachabilityCheckFlags"; - NodeFlags3[NodeFlags3["ReachabilityAndEmitFlags"] = 2816] = "ReachabilityAndEmitFlags"; - NodeFlags3[NodeFlags3["ContextFlags"] = 50720768] = "ContextFlags"; - NodeFlags3[NodeFlags3["TypeExcludesFlags"] = 40960] = "TypeExcludesFlags"; - NodeFlags3[NodeFlags3["PermanentlySetIncrementalFlags"] = 6291456] = "PermanentlySetIncrementalFlags"; - NodeFlags3[NodeFlags3["IdentifierHasExtendedUnicodeEscape"] = 128 /* ContainsThis */] = "IdentifierHasExtendedUnicodeEscape"; - NodeFlags3[NodeFlags3["IdentifierIsInJSDocNamespace"] = 2048 /* HasAsyncFunctions */] = "IdentifierIsInJSDocNamespace"; + NodeFlags3[NodeFlags3["Using"] = 4] = "Using"; + NodeFlags3[NodeFlags3["AwaitUsing"] = 6] = "AwaitUsing"; + NodeFlags3[NodeFlags3["NestedNamespace"] = 8] = "NestedNamespace"; + NodeFlags3[NodeFlags3["Synthesized"] = 16] = "Synthesized"; + NodeFlags3[NodeFlags3["Namespace"] = 32] = "Namespace"; + NodeFlags3[NodeFlags3["OptionalChain"] = 64] = "OptionalChain"; + NodeFlags3[NodeFlags3["ExportContext"] = 128] = "ExportContext"; + NodeFlags3[NodeFlags3["ContainsThis"] = 256] = "ContainsThis"; + NodeFlags3[NodeFlags3["HasImplicitReturn"] = 512] = "HasImplicitReturn"; + NodeFlags3[NodeFlags3["HasExplicitReturn"] = 1024] = "HasExplicitReturn"; + NodeFlags3[NodeFlags3["GlobalAugmentation"] = 2048] = "GlobalAugmentation"; + NodeFlags3[NodeFlags3["HasAsyncFunctions"] = 4096] = "HasAsyncFunctions"; + NodeFlags3[NodeFlags3["DisallowInContext"] = 8192] = "DisallowInContext"; + NodeFlags3[NodeFlags3["YieldContext"] = 16384] = "YieldContext"; + NodeFlags3[NodeFlags3["DecoratorContext"] = 32768] = "DecoratorContext"; + NodeFlags3[NodeFlags3["AwaitContext"] = 65536] = "AwaitContext"; + NodeFlags3[NodeFlags3["DisallowConditionalTypesContext"] = 131072] = "DisallowConditionalTypesContext"; + NodeFlags3[NodeFlags3["ThisNodeHasError"] = 262144] = "ThisNodeHasError"; + NodeFlags3[NodeFlags3["JavaScriptFile"] = 524288] = "JavaScriptFile"; + NodeFlags3[NodeFlags3["ThisNodeOrAnySubNodesHasError"] = 1048576] = "ThisNodeOrAnySubNodesHasError"; + NodeFlags3[NodeFlags3["HasAggregatedChildData"] = 2097152] = "HasAggregatedChildData"; + NodeFlags3[NodeFlags3["PossiblyContainsDynamicImport"] = 4194304] = "PossiblyContainsDynamicImport"; + NodeFlags3[NodeFlags3["PossiblyContainsImportMeta"] = 8388608] = "PossiblyContainsImportMeta"; + NodeFlags3[NodeFlags3["JSDoc"] = 16777216] = "JSDoc"; + NodeFlags3[NodeFlags3["Ambient"] = 33554432] = "Ambient"; + NodeFlags3[NodeFlags3["InWithStatement"] = 67108864] = "InWithStatement"; + NodeFlags3[NodeFlags3["JsonFile"] = 134217728] = "JsonFile"; + NodeFlags3[NodeFlags3["TypeCached"] = 268435456] = "TypeCached"; + NodeFlags3[NodeFlags3["Deprecated"] = 536870912] = "Deprecated"; + NodeFlags3[NodeFlags3["BlockScoped"] = 7] = "BlockScoped"; + NodeFlags3[NodeFlags3["Constant"] = 6] = "Constant"; + NodeFlags3[NodeFlags3["ReachabilityCheckFlags"] = 1536] = "ReachabilityCheckFlags"; + NodeFlags3[NodeFlags3["ReachabilityAndEmitFlags"] = 5632] = "ReachabilityAndEmitFlags"; + NodeFlags3[NodeFlags3["ContextFlags"] = 101441536] = "ContextFlags"; + NodeFlags3[NodeFlags3["TypeExcludesFlags"] = 81920] = "TypeExcludesFlags"; + NodeFlags3[NodeFlags3["PermanentlySetIncrementalFlags"] = 12582912] = "PermanentlySetIncrementalFlags"; + NodeFlags3[NodeFlags3["IdentifierHasExtendedUnicodeEscape"] = 256 /* ContainsThis */] = "IdentifierHasExtendedUnicodeEscape"; + NodeFlags3[NodeFlags3["IdentifierIsInJSDocNamespace"] = 4096 /* HasAsyncFunctions */] = "IdentifierIsInJSDocNamespace"; return NodeFlags3; })(NodeFlags || {}); ModifierFlags = /* @__PURE__ */ ((ModifierFlags3) => { ModifierFlags3[ModifierFlags3["None"] = 0] = "None"; - ModifierFlags3[ModifierFlags3["Export"] = 1] = "Export"; - ModifierFlags3[ModifierFlags3["Ambient"] = 2] = "Ambient"; - ModifierFlags3[ModifierFlags3["Public"] = 4] = "Public"; - ModifierFlags3[ModifierFlags3["Private"] = 8] = "Private"; - ModifierFlags3[ModifierFlags3["Protected"] = 16] = "Protected"; - ModifierFlags3[ModifierFlags3["Static"] = 32] = "Static"; - ModifierFlags3[ModifierFlags3["Readonly"] = 64] = "Readonly"; - ModifierFlags3[ModifierFlags3["Accessor"] = 128] = "Accessor"; - ModifierFlags3[ModifierFlags3["Abstract"] = 256] = "Abstract"; - ModifierFlags3[ModifierFlags3["Async"] = 512] = "Async"; - ModifierFlags3[ModifierFlags3["Default"] = 1024] = "Default"; - ModifierFlags3[ModifierFlags3["Const"] = 2048] = "Const"; - ModifierFlags3[ModifierFlags3["HasComputedJSDocModifiers"] = 4096] = "HasComputedJSDocModifiers"; - ModifierFlags3[ModifierFlags3["Deprecated"] = 8192] = "Deprecated"; - ModifierFlags3[ModifierFlags3["Override"] = 16384] = "Override"; - ModifierFlags3[ModifierFlags3["In"] = 32768] = "In"; - ModifierFlags3[ModifierFlags3["Out"] = 65536] = "Out"; - ModifierFlags3[ModifierFlags3["Decorator"] = 131072] = "Decorator"; + ModifierFlags3[ModifierFlags3["Public"] = 1] = "Public"; + ModifierFlags3[ModifierFlags3["Private"] = 2] = "Private"; + ModifierFlags3[ModifierFlags3["Protected"] = 4] = "Protected"; + ModifierFlags3[ModifierFlags3["Readonly"] = 8] = "Readonly"; + ModifierFlags3[ModifierFlags3["Override"] = 16] = "Override"; + ModifierFlags3[ModifierFlags3["Export"] = 32] = "Export"; + ModifierFlags3[ModifierFlags3["Abstract"] = 64] = "Abstract"; + ModifierFlags3[ModifierFlags3["Ambient"] = 128] = "Ambient"; + ModifierFlags3[ModifierFlags3["Static"] = 256] = "Static"; + ModifierFlags3[ModifierFlags3["Accessor"] = 512] = "Accessor"; + ModifierFlags3[ModifierFlags3["Async"] = 1024] = "Async"; + ModifierFlags3[ModifierFlags3["Default"] = 2048] = "Default"; + ModifierFlags3[ModifierFlags3["Const"] = 4096] = "Const"; + ModifierFlags3[ModifierFlags3["In"] = 8192] = "In"; + ModifierFlags3[ModifierFlags3["Out"] = 16384] = "Out"; + ModifierFlags3[ModifierFlags3["Decorator"] = 32768] = "Decorator"; + ModifierFlags3[ModifierFlags3["Deprecated"] = 65536] = "Deprecated"; + ModifierFlags3[ModifierFlags3["JSDocPublic"] = 8388608] = "JSDocPublic"; + ModifierFlags3[ModifierFlags3["JSDocPrivate"] = 16777216] = "JSDocPrivate"; + ModifierFlags3[ModifierFlags3["JSDocProtected"] = 33554432] = "JSDocProtected"; + ModifierFlags3[ModifierFlags3["JSDocReadonly"] = 67108864] = "JSDocReadonly"; + ModifierFlags3[ModifierFlags3["JSDocOverride"] = 134217728] = "JSDocOverride"; + ModifierFlags3[ModifierFlags3["SyntacticOrJSDocModifiers"] = 31] = "SyntacticOrJSDocModifiers"; + ModifierFlags3[ModifierFlags3["SyntacticOnlyModifiers"] = 65504] = "SyntacticOnlyModifiers"; + ModifierFlags3[ModifierFlags3["SyntacticModifiers"] = 65535] = "SyntacticModifiers"; + ModifierFlags3[ModifierFlags3["JSDocCacheOnlyModifiers"] = 260046848] = "JSDocCacheOnlyModifiers"; + ModifierFlags3[ModifierFlags3["JSDocOnlyModifiers"] = 65536 /* Deprecated */] = "JSDocOnlyModifiers"; + ModifierFlags3[ModifierFlags3["NonCacheOnlyModifiers"] = 131071] = "NonCacheOnlyModifiers"; + ModifierFlags3[ModifierFlags3["HasComputedJSDocModifiers"] = 268435456] = "HasComputedJSDocModifiers"; ModifierFlags3[ModifierFlags3["HasComputedFlags"] = 536870912] = "HasComputedFlags"; - ModifierFlags3[ModifierFlags3["AccessibilityModifier"] = 28] = "AccessibilityModifier"; - ModifierFlags3[ModifierFlags3["ParameterPropertyModifier"] = 16476] = "ParameterPropertyModifier"; - ModifierFlags3[ModifierFlags3["NonPublicAccessibilityModifier"] = 24] = "NonPublicAccessibilityModifier"; - ModifierFlags3[ModifierFlags3["TypeScriptModifier"] = 117086] = "TypeScriptModifier"; - ModifierFlags3[ModifierFlags3["ExportDefault"] = 1025] = "ExportDefault"; - ModifierFlags3[ModifierFlags3["All"] = 258047] = "All"; - ModifierFlags3[ModifierFlags3["Modifier"] = 126975] = "Modifier"; + ModifierFlags3[ModifierFlags3["AccessibilityModifier"] = 7] = "AccessibilityModifier"; + ModifierFlags3[ModifierFlags3["ParameterPropertyModifier"] = 31] = "ParameterPropertyModifier"; + ModifierFlags3[ModifierFlags3["NonPublicAccessibilityModifier"] = 6] = "NonPublicAccessibilityModifier"; + ModifierFlags3[ModifierFlags3["TypeScriptModifier"] = 28895] = "TypeScriptModifier"; + ModifierFlags3[ModifierFlags3["ExportDefault"] = 2080] = "ExportDefault"; + ModifierFlags3[ModifierFlags3["All"] = 131071] = "All"; + ModifierFlags3[ModifierFlags3["Modifier"] = 98303] = "Modifier"; return ModifierFlags3; })(ModifierFlags || {}); JsxFlags = /* @__PURE__ */ ((JsxFlags2) => { @@ -103430,15 +86041,13 @@ ${lanes.join("\n")} NodeCheckFlags2[NodeCheckFlags2["ContainsCapturedBlockScopeBinding"] = 8192] = "ContainsCapturedBlockScopeBinding"; NodeCheckFlags2[NodeCheckFlags2["CapturedBlockScopedBinding"] = 16384] = "CapturedBlockScopedBinding"; NodeCheckFlags2[NodeCheckFlags2["BlockScopedBindingInLoop"] = 32768] = "BlockScopedBindingInLoop"; - NodeCheckFlags2[NodeCheckFlags2["ClassWithBodyScopedClassBinding"] = 65536] = "ClassWithBodyScopedClassBinding"; - NodeCheckFlags2[NodeCheckFlags2["BodyScopedClassBinding"] = 131072] = "BodyScopedClassBinding"; - NodeCheckFlags2[NodeCheckFlags2["NeedsLoopOutParameter"] = 262144] = "NeedsLoopOutParameter"; - NodeCheckFlags2[NodeCheckFlags2["AssignmentsMarked"] = 524288] = "AssignmentsMarked"; - NodeCheckFlags2[NodeCheckFlags2["ClassWithConstructorReference"] = 1048576] = "ClassWithConstructorReference"; - NodeCheckFlags2[NodeCheckFlags2["ConstructorReferenceInClass"] = 2097152] = "ConstructorReferenceInClass"; - NodeCheckFlags2[NodeCheckFlags2["ContainsClassWithPrivateIdentifiers"] = 4194304] = "ContainsClassWithPrivateIdentifiers"; - NodeCheckFlags2[NodeCheckFlags2["ContainsSuperPropertyInStaticInitializer"] = 8388608] = "ContainsSuperPropertyInStaticInitializer"; - NodeCheckFlags2[NodeCheckFlags2["InCheckIdentifier"] = 16777216] = "InCheckIdentifier"; + NodeCheckFlags2[NodeCheckFlags2["NeedsLoopOutParameter"] = 65536] = "NeedsLoopOutParameter"; + NodeCheckFlags2[NodeCheckFlags2["AssignmentsMarked"] = 131072] = "AssignmentsMarked"; + NodeCheckFlags2[NodeCheckFlags2["ContainsConstructorReference"] = 262144] = "ContainsConstructorReference"; + NodeCheckFlags2[NodeCheckFlags2["ConstructorReference"] = 536870912] = "ConstructorReference"; + NodeCheckFlags2[NodeCheckFlags2["ContainsClassWithPrivateIdentifiers"] = 1048576] = "ContainsClassWithPrivateIdentifiers"; + NodeCheckFlags2[NodeCheckFlags2["ContainsSuperPropertyInStaticInitializer"] = 2097152] = "ContainsSuperPropertyInStaticInitializer"; + NodeCheckFlags2[NodeCheckFlags2["InCheckIdentifier"] = 4194304] = "InCheckIdentifier"; return NodeCheckFlags2; })(NodeCheckFlags || {}); TypeFlags = /* @__PURE__ */ ((TypeFlags2) => { @@ -103498,7 +86107,7 @@ ${lanes.join("\n")} TypeFlags2[TypeFlags2["InstantiablePrimitive"] = 406847488] = "InstantiablePrimitive"; TypeFlags2[TypeFlags2["Instantiable"] = 465829888] = "Instantiable"; TypeFlags2[TypeFlags2["StructuredOrInstantiable"] = 469499904] = "StructuredOrInstantiable"; - TypeFlags2[TypeFlags2["ObjectFlagsType"] = 138117121] = "ObjectFlagsType"; + TypeFlags2[TypeFlags2["ObjectFlagsType"] = 3899393] = "ObjectFlagsType"; TypeFlags2[TypeFlags2["Simplifiable"] = 25165824] = "Simplifiable"; TypeFlags2[TypeFlags2["Singleton"] = 67358815] = "Singleton"; TypeFlags2[TypeFlags2["Narrowable"] = 536624127] = "Narrowable"; @@ -103537,6 +86146,7 @@ ${lanes.join("\n")} ObjectFlags3[ObjectFlags3["ClassOrInterface"] = 3] = "ClassOrInterface"; ObjectFlags3[ObjectFlags3["RequiresWidening"] = 196608] = "RequiresWidening"; ObjectFlags3[ObjectFlags3["PropagatingFlags"] = 458752] = "PropagatingFlags"; + ObjectFlags3[ObjectFlags3["InstantiatedMapped"] = 96] = "InstantiatedMapped"; ObjectFlags3[ObjectFlags3["ObjectTypeKindMask"] = 1343] = "ObjectTypeKindMask"; ObjectFlags3[ObjectFlags3["ContainsSpread"] = 2097152] = "ContainsSpread"; ObjectFlags3[ObjectFlags3["ObjectRestType"] = 4194304] = "ObjectRestType"; @@ -103619,7 +86229,8 @@ ${lanes.join("\n")} SignatureFlags5[SignatureFlags5["IsOuterCallChain"] = 16] = "IsOuterCallChain"; SignatureFlags5[SignatureFlags5["IsUntypedSignatureInJSFile"] = 32] = "IsUntypedSignatureInJSFile"; SignatureFlags5[SignatureFlags5["IsNonInferrable"] = 64] = "IsNonInferrable"; - SignatureFlags5[SignatureFlags5["PropagatingFlags"] = 39] = "PropagatingFlags"; + SignatureFlags5[SignatureFlags5["IsSignatureCandidateForOverloadFailure"] = 128] = "IsSignatureCandidateForOverloadFailure"; + SignatureFlags5[SignatureFlags5["PropagatingFlags"] = 167] = "PropagatingFlags"; SignatureFlags5[SignatureFlags5["CallChainFlags"] = 24] = "CallChainFlags"; return SignatureFlags5; })(SignatureFlags || {}); @@ -103689,14 +86300,14 @@ ${lanes.join("\n")} DiagnosticCategory2[DiagnosticCategory2["Message"] = 3] = "Message"; return DiagnosticCategory2; })(DiagnosticCategory || {}); - ModuleResolutionKind = /* @__PURE__ */ ((ModuleResolutionKind2) => { - ModuleResolutionKind2[ModuleResolutionKind2["Classic"] = 1] = "Classic"; - ModuleResolutionKind2[ModuleResolutionKind2["NodeJs"] = 2] = "NodeJs"; - ModuleResolutionKind2[ModuleResolutionKind2["Node10"] = 2] = "Node10"; - ModuleResolutionKind2[ModuleResolutionKind2["Node16"] = 3] = "Node16"; - ModuleResolutionKind2[ModuleResolutionKind2["NodeNext"] = 99] = "NodeNext"; - ModuleResolutionKind2[ModuleResolutionKind2["Bundler"] = 100] = "Bundler"; - return ModuleResolutionKind2; + ModuleResolutionKind = /* @__PURE__ */ ((ModuleResolutionKind3) => { + ModuleResolutionKind3[ModuleResolutionKind3["Classic"] = 1] = "Classic"; + ModuleResolutionKind3[ModuleResolutionKind3["NodeJs"] = 2] = "NodeJs"; + ModuleResolutionKind3[ModuleResolutionKind3["Node10"] = 2] = "Node10"; + ModuleResolutionKind3[ModuleResolutionKind3["Node16"] = 3] = "Node16"; + ModuleResolutionKind3[ModuleResolutionKind3["NodeNext"] = 99] = "NodeNext"; + ModuleResolutionKind3[ModuleResolutionKind3["Bundler"] = 100] = "Bundler"; + return ModuleResolutionKind3; })(ModuleResolutionKind || {}); ModuleDetectionKind = /* @__PURE__ */ ((ModuleDetectionKind2) => { ModuleDetectionKind2[ModuleDetectionKind2["Legacy"] = 1] = "Legacy"; @@ -103704,51 +86315,51 @@ ${lanes.join("\n")} ModuleDetectionKind2[ModuleDetectionKind2["Force"] = 3] = "Force"; return ModuleDetectionKind2; })(ModuleDetectionKind || {}); - WatchFileKind = /* @__PURE__ */ ((WatchFileKind2) => { - WatchFileKind2[WatchFileKind2["FixedPollingInterval"] = 0] = "FixedPollingInterval"; - WatchFileKind2[WatchFileKind2["PriorityPollingInterval"] = 1] = "PriorityPollingInterval"; - WatchFileKind2[WatchFileKind2["DynamicPriorityPolling"] = 2] = "DynamicPriorityPolling"; - WatchFileKind2[WatchFileKind2["FixedChunkSizePolling"] = 3] = "FixedChunkSizePolling"; - WatchFileKind2[WatchFileKind2["UseFsEvents"] = 4] = "UseFsEvents"; - WatchFileKind2[WatchFileKind2["UseFsEventsOnParentDirectory"] = 5] = "UseFsEventsOnParentDirectory"; - return WatchFileKind2; + WatchFileKind = /* @__PURE__ */ ((WatchFileKind3) => { + WatchFileKind3[WatchFileKind3["FixedPollingInterval"] = 0] = "FixedPollingInterval"; + WatchFileKind3[WatchFileKind3["PriorityPollingInterval"] = 1] = "PriorityPollingInterval"; + WatchFileKind3[WatchFileKind3["DynamicPriorityPolling"] = 2] = "DynamicPriorityPolling"; + WatchFileKind3[WatchFileKind3["FixedChunkSizePolling"] = 3] = "FixedChunkSizePolling"; + WatchFileKind3[WatchFileKind3["UseFsEvents"] = 4] = "UseFsEvents"; + WatchFileKind3[WatchFileKind3["UseFsEventsOnParentDirectory"] = 5] = "UseFsEventsOnParentDirectory"; + return WatchFileKind3; })(WatchFileKind || {}); - WatchDirectoryKind = /* @__PURE__ */ ((WatchDirectoryKind2) => { - WatchDirectoryKind2[WatchDirectoryKind2["UseFsEvents"] = 0] = "UseFsEvents"; - WatchDirectoryKind2[WatchDirectoryKind2["FixedPollingInterval"] = 1] = "FixedPollingInterval"; - WatchDirectoryKind2[WatchDirectoryKind2["DynamicPriorityPolling"] = 2] = "DynamicPriorityPolling"; - WatchDirectoryKind2[WatchDirectoryKind2["FixedChunkSizePolling"] = 3] = "FixedChunkSizePolling"; - return WatchDirectoryKind2; + WatchDirectoryKind = /* @__PURE__ */ ((WatchDirectoryKind3) => { + WatchDirectoryKind3[WatchDirectoryKind3["UseFsEvents"] = 0] = "UseFsEvents"; + WatchDirectoryKind3[WatchDirectoryKind3["FixedPollingInterval"] = 1] = "FixedPollingInterval"; + WatchDirectoryKind3[WatchDirectoryKind3["DynamicPriorityPolling"] = 2] = "DynamicPriorityPolling"; + WatchDirectoryKind3[WatchDirectoryKind3["FixedChunkSizePolling"] = 3] = "FixedChunkSizePolling"; + return WatchDirectoryKind3; })(WatchDirectoryKind || {}); - PollingWatchKind = /* @__PURE__ */ ((PollingWatchKind2) => { - PollingWatchKind2[PollingWatchKind2["FixedInterval"] = 0] = "FixedInterval"; - PollingWatchKind2[PollingWatchKind2["PriorityInterval"] = 1] = "PriorityInterval"; - PollingWatchKind2[PollingWatchKind2["DynamicPriority"] = 2] = "DynamicPriority"; - PollingWatchKind2[PollingWatchKind2["FixedChunkSize"] = 3] = "FixedChunkSize"; - return PollingWatchKind2; + PollingWatchKind = /* @__PURE__ */ ((PollingWatchKind3) => { + PollingWatchKind3[PollingWatchKind3["FixedInterval"] = 0] = "FixedInterval"; + PollingWatchKind3[PollingWatchKind3["PriorityInterval"] = 1] = "PriorityInterval"; + PollingWatchKind3[PollingWatchKind3["DynamicPriority"] = 2] = "DynamicPriority"; + PollingWatchKind3[PollingWatchKind3["FixedChunkSize"] = 3] = "FixedChunkSize"; + return PollingWatchKind3; })(PollingWatchKind || {}); - ModuleKind = /* @__PURE__ */ ((ModuleKind2) => { - ModuleKind2[ModuleKind2["None"] = 0] = "None"; - ModuleKind2[ModuleKind2["CommonJS"] = 1] = "CommonJS"; - ModuleKind2[ModuleKind2["AMD"] = 2] = "AMD"; - ModuleKind2[ModuleKind2["UMD"] = 3] = "UMD"; - ModuleKind2[ModuleKind2["System"] = 4] = "System"; - ModuleKind2[ModuleKind2["ES2015"] = 5] = "ES2015"; - ModuleKind2[ModuleKind2["ES2020"] = 6] = "ES2020"; - ModuleKind2[ModuleKind2["ES2022"] = 7] = "ES2022"; - ModuleKind2[ModuleKind2["ESNext"] = 99] = "ESNext"; - ModuleKind2[ModuleKind2["Node16"] = 100] = "Node16"; - ModuleKind2[ModuleKind2["NodeNext"] = 199] = "NodeNext"; - return ModuleKind2; + ModuleKind = /* @__PURE__ */ ((ModuleKind3) => { + ModuleKind3[ModuleKind3["None"] = 0] = "None"; + ModuleKind3[ModuleKind3["CommonJS"] = 1] = "CommonJS"; + ModuleKind3[ModuleKind3["AMD"] = 2] = "AMD"; + ModuleKind3[ModuleKind3["UMD"] = 3] = "UMD"; + ModuleKind3[ModuleKind3["System"] = 4] = "System"; + ModuleKind3[ModuleKind3["ES2015"] = 5] = "ES2015"; + ModuleKind3[ModuleKind3["ES2020"] = 6] = "ES2020"; + ModuleKind3[ModuleKind3["ES2022"] = 7] = "ES2022"; + ModuleKind3[ModuleKind3["ESNext"] = 99] = "ESNext"; + ModuleKind3[ModuleKind3["Node16"] = 100] = "Node16"; + ModuleKind3[ModuleKind3["NodeNext"] = 199] = "NodeNext"; + return ModuleKind3; })(ModuleKind || {}); - JsxEmit = /* @__PURE__ */ ((JsxEmit2) => { - JsxEmit2[JsxEmit2["None"] = 0] = "None"; - JsxEmit2[JsxEmit2["Preserve"] = 1] = "Preserve"; - JsxEmit2[JsxEmit2["React"] = 2] = "React"; - JsxEmit2[JsxEmit2["ReactNative"] = 3] = "ReactNative"; - JsxEmit2[JsxEmit2["ReactJSX"] = 4] = "ReactJSX"; - JsxEmit2[JsxEmit2["ReactJSXDev"] = 5] = "ReactJSXDev"; - return JsxEmit2; + JsxEmit = /* @__PURE__ */ ((JsxEmit3) => { + JsxEmit3[JsxEmit3["None"] = 0] = "None"; + JsxEmit3[JsxEmit3["Preserve"] = 1] = "Preserve"; + JsxEmit3[JsxEmit3["React"] = 2] = "React"; + JsxEmit3[JsxEmit3["ReactNative"] = 3] = "ReactNative"; + JsxEmit3[JsxEmit3["ReactJSX"] = 4] = "ReactJSX"; + JsxEmit3[JsxEmit3["ReactJSXDev"] = 5] = "ReactJSXDev"; + return JsxEmit3; })(JsxEmit || {}); ImportsNotUsedAsValues = /* @__PURE__ */ ((ImportsNotUsedAsValues2) => { ImportsNotUsedAsValues2[ImportsNotUsedAsValues2["Remove"] = 0] = "Remove"; @@ -103756,37 +86367,37 @@ ${lanes.join("\n")} ImportsNotUsedAsValues2[ImportsNotUsedAsValues2["Error"] = 2] = "Error"; return ImportsNotUsedAsValues2; })(ImportsNotUsedAsValues || {}); - NewLineKind = /* @__PURE__ */ ((NewLineKind2) => { - NewLineKind2[NewLineKind2["CarriageReturnLineFeed"] = 0] = "CarriageReturnLineFeed"; - NewLineKind2[NewLineKind2["LineFeed"] = 1] = "LineFeed"; - return NewLineKind2; + NewLineKind = /* @__PURE__ */ ((NewLineKind3) => { + NewLineKind3[NewLineKind3["CarriageReturnLineFeed"] = 0] = "CarriageReturnLineFeed"; + NewLineKind3[NewLineKind3["LineFeed"] = 1] = "LineFeed"; + return NewLineKind3; })(NewLineKind || {}); - ScriptKind = /* @__PURE__ */ ((ScriptKind5) => { - ScriptKind5[ScriptKind5["Unknown"] = 0] = "Unknown"; - ScriptKind5[ScriptKind5["JS"] = 1] = "JS"; - ScriptKind5[ScriptKind5["JSX"] = 2] = "JSX"; - ScriptKind5[ScriptKind5["TS"] = 3] = "TS"; - ScriptKind5[ScriptKind5["TSX"] = 4] = "TSX"; - ScriptKind5[ScriptKind5["External"] = 5] = "External"; - ScriptKind5[ScriptKind5["JSON"] = 6] = "JSON"; - ScriptKind5[ScriptKind5["Deferred"] = 7] = "Deferred"; - return ScriptKind5; + ScriptKind = /* @__PURE__ */ ((ScriptKind7) => { + ScriptKind7[ScriptKind7["Unknown"] = 0] = "Unknown"; + ScriptKind7[ScriptKind7["JS"] = 1] = "JS"; + ScriptKind7[ScriptKind7["JSX"] = 2] = "JSX"; + ScriptKind7[ScriptKind7["TS"] = 3] = "TS"; + ScriptKind7[ScriptKind7["TSX"] = 4] = "TSX"; + ScriptKind7[ScriptKind7["External"] = 5] = "External"; + ScriptKind7[ScriptKind7["JSON"] = 6] = "JSON"; + ScriptKind7[ScriptKind7["Deferred"] = 7] = "Deferred"; + return ScriptKind7; })(ScriptKind || {}); - ScriptTarget = /* @__PURE__ */ ((ScriptTarget10) => { - ScriptTarget10[ScriptTarget10["ES3"] = 0] = "ES3"; - ScriptTarget10[ScriptTarget10["ES5"] = 1] = "ES5"; - ScriptTarget10[ScriptTarget10["ES2015"] = 2] = "ES2015"; - ScriptTarget10[ScriptTarget10["ES2016"] = 3] = "ES2016"; - ScriptTarget10[ScriptTarget10["ES2017"] = 4] = "ES2017"; - ScriptTarget10[ScriptTarget10["ES2018"] = 5] = "ES2018"; - ScriptTarget10[ScriptTarget10["ES2019"] = 6] = "ES2019"; - ScriptTarget10[ScriptTarget10["ES2020"] = 7] = "ES2020"; - ScriptTarget10[ScriptTarget10["ES2021"] = 8] = "ES2021"; - ScriptTarget10[ScriptTarget10["ES2022"] = 9] = "ES2022"; - ScriptTarget10[ScriptTarget10["ESNext"] = 99] = "ESNext"; - ScriptTarget10[ScriptTarget10["JSON"] = 100] = "JSON"; - ScriptTarget10[ScriptTarget10["Latest"] = 99 /* ESNext */] = "Latest"; - return ScriptTarget10; + ScriptTarget = /* @__PURE__ */ ((ScriptTarget11) => { + ScriptTarget11[ScriptTarget11["ES3"] = 0] = "ES3"; + ScriptTarget11[ScriptTarget11["ES5"] = 1] = "ES5"; + ScriptTarget11[ScriptTarget11["ES2015"] = 2] = "ES2015"; + ScriptTarget11[ScriptTarget11["ES2016"] = 3] = "ES2016"; + ScriptTarget11[ScriptTarget11["ES2017"] = 4] = "ES2017"; + ScriptTarget11[ScriptTarget11["ES2018"] = 5] = "ES2018"; + ScriptTarget11[ScriptTarget11["ES2019"] = 6] = "ES2019"; + ScriptTarget11[ScriptTarget11["ES2020"] = 7] = "ES2020"; + ScriptTarget11[ScriptTarget11["ES2021"] = 8] = "ES2021"; + ScriptTarget11[ScriptTarget11["ES2022"] = 9] = "ES2022"; + ScriptTarget11[ScriptTarget11["ESNext"] = 99] = "ESNext"; + ScriptTarget11[ScriptTarget11["JSON"] = 100] = "JSON"; + ScriptTarget11[ScriptTarget11["Latest"] = 99 /* ESNext */] = "Latest"; + return ScriptTarget11; })(ScriptTarget || {}); LanguageVariant = /* @__PURE__ */ ((LanguageVariant4) => { LanguageVariant4[LanguageVariant4["Standard"] = 0] = "Standard"; @@ -104085,8 +86696,9 @@ ${lanes.join("\n")} ExternalEmitHelpers2[ExternalEmitHelpers2["CreateBinding"] = 4194304] = "CreateBinding"; ExternalEmitHelpers2[ExternalEmitHelpers2["SetFunctionName"] = 8388608] = "SetFunctionName"; ExternalEmitHelpers2[ExternalEmitHelpers2["PropKey"] = 16777216] = "PropKey"; + ExternalEmitHelpers2[ExternalEmitHelpers2["AddDisposableResourceAndDisposeResources"] = 33554432] = "AddDisposableResourceAndDisposeResources"; ExternalEmitHelpers2[ExternalEmitHelpers2["FirstEmitHelper"] = 1 /* Extends */] = "FirstEmitHelper"; - ExternalEmitHelpers2[ExternalEmitHelpers2["LastEmitHelper"] = 16777216 /* PropKey */] = "LastEmitHelper"; + ExternalEmitHelpers2[ExternalEmitHelpers2["LastEmitHelper"] = 33554432 /* AddDisposableResourceAndDisposeResources */] = "LastEmitHelper"; ExternalEmitHelpers2[ExternalEmitHelpers2["ForOfIncludes"] = 256 /* Values */] = "ForOfIncludes"; ExternalEmitHelpers2[ExternalEmitHelpers2["ForAwaitOfIncludes"] = 16384 /* AsyncValues */] = "ForAwaitOfIncludes"; ExternalEmitHelpers2[ExternalEmitHelpers2["AsyncGeneratorIncludes"] = 6144] = "AsyncGeneratorIncludes"; @@ -104175,7 +86787,8 @@ ${lanes.join("\n")} ListFormat2[ListFormat2["ObjectBindingPatternElements"] = 525136] = "ObjectBindingPatternElements"; ListFormat2[ListFormat2["ArrayBindingPatternElements"] = 524880] = "ArrayBindingPatternElements"; ListFormat2[ListFormat2["ObjectLiteralExpressionProperties"] = 526226] = "ObjectLiteralExpressionProperties"; - ListFormat2[ListFormat2["ImportClauseEntries"] = 526226] = "ImportClauseEntries"; + ListFormat2[ListFormat2["ImportAttributes"] = 526226] = "ImportAttributes"; + ListFormat2[ListFormat2["ImportClauseEntries"] = 526226 /* ImportAttributes */] = "ImportClauseEntries"; ListFormat2[ListFormat2["ArrayLiteralExpressionElements"] = 8914] = "ArrayLiteralExpressionElements"; ListFormat2[ListFormat2["CommaListElements"] = 528] = "CommaListElements"; ListFormat2[ListFormat2["CallExpressionArguments"] = 2576] = "CallExpressionArguments"; @@ -104256,6 +86869,13 @@ ${lanes.join("\n")} kind: 4 /* MultiLine */ } }; + JSDocParsingMode = /* @__PURE__ */ ((JSDocParsingMode6) => { + JSDocParsingMode6[JSDocParsingMode6["ParseAll"] = 0] = "ParseAll"; + JSDocParsingMode6[JSDocParsingMode6["ParseNone"] = 1] = "ParseNone"; + JSDocParsingMode6[JSDocParsingMode6["ParseForTypeErrors"] = 2] = "ParseForTypeErrors"; + JSDocParsingMode6[JSDocParsingMode6["ParseForTypeInfo"] = 3] = "ParseForTypeInfo"; + return JSDocParsingMode6; + })(JSDocParsingMode || {}); } }); @@ -104467,10 +87087,10 @@ ${lanes.join("\n")} pollingIntervalQueue(pollingInterval).pollScheduled = host.setTimeout(pollingInterval === 250 /* Low */ ? pollLowPollingIntervalQueue : pollPollingIntervalQueue, pollingInterval, pollingInterval === 250 /* Low */ ? "pollLowPollingIntervalQueue" : "pollPollingIntervalQueue", pollingIntervalQueue(pollingInterval)); } } - function createUseFsEventsOnParentDirectoryWatchFile(fsWatch, useCaseSensitiveFileNames) { + function createUseFsEventsOnParentDirectoryWatchFile(fsWatch, useCaseSensitiveFileNames2) { const fileWatcherCallbacks = createMultiMap(); const dirWatchers = /* @__PURE__ */ new Map(); - const toCanonicalName = createGetCanonicalFileName(useCaseSensitiveFileNames); + const toCanonicalName = createGetCanonicalFileName(useCaseSensitiveFileNames2); return nonPollingWatchFile; function nonPollingWatchFile(fileName, callback, _pollingInterval, fallbackOptions) { const filePath = toCanonicalName(fileName); @@ -104546,8 +87166,8 @@ ${lanes.join("\n")} pollScheduled = host.setTimeout(pollQueue, 2e3 /* High */, "pollQueue"); } } - function createSingleWatcherPerName(cache, useCaseSensitiveFileNames, name, callback, createWatcher) { - const toCanonicalFileName = createGetCanonicalFileName(useCaseSensitiveFileNames); + function createSingleWatcherPerName(cache, useCaseSensitiveFileNames2, name, callback, createWatcher) { + const toCanonicalFileName = createGetCanonicalFileName(useCaseSensitiveFileNames2); const path = toCanonicalFileName(name); const existing = cache.get(path); if (existing) { @@ -104597,7 +87217,7 @@ ${lanes.join("\n")} } function createDirectoryWatcherSupportingRecursive({ watchDirectory, - useCaseSensitiveFileNames, + useCaseSensitiveFileNames: useCaseSensitiveFileNames2, getCurrentDirectory, getAccessibleSortedChildDirectories, fileSystemEntryExists, @@ -104609,8 +87229,8 @@ ${lanes.join("\n")} const callbackCache = createMultiMap(); const cacheToUpdateChildWatches = /* @__PURE__ */ new Map(); let timerToUpdateChildWatches; - const filePathComparer = getStringComparer(!useCaseSensitiveFileNames); - const toCanonicalFilePath = createGetCanonicalFileName(useCaseSensitiveFileNames); + const filePathComparer = getStringComparer(!useCaseSensitiveFileNames2); + const toCanonicalFilePath = createGetCanonicalFileName(useCaseSensitiveFileNames2); return (dirName, callback, recursive, options) => recursive ? createDirectoryWatcher(dirName, options, callback) : watchDirectory(dirName, callback, recursive, options); function createDirectoryWatcher(dirName, options, callback) { const dirPath = toCanonicalFilePath(dirName); @@ -104777,14 +87397,14 @@ ${lanes.join("\n")} } } function isIgnoredPath(path, options) { - return some(ignoredPaths, (searchPath) => isInPath(path, searchPath)) || isIgnoredByWatchOptions(path, options, useCaseSensitiveFileNames, getCurrentDirectory); + return some(ignoredPaths, (searchPath) => isInPath(path, searchPath)) || isIgnoredByWatchOptions(path, options, useCaseSensitiveFileNames2, getCurrentDirectory); } function isInPath(path, searchPath) { - if (stringContains(path, searchPath)) + if (path.includes(searchPath)) return true; - if (useCaseSensitiveFileNames) + if (useCaseSensitiveFileNames2) return false; - return stringContains(toCanonicalFilePath(path), searchPath); + return toCanonicalFilePath(path).includes(searchPath); } } function createFileWatcherCallback(callback) { @@ -104800,14 +87420,14 @@ ${lanes.join("\n")} } }; } - function isIgnoredByWatchOptions(pathToCheck, options, useCaseSensitiveFileNames, getCurrentDirectory) { - return ((options == null ? void 0 : options.excludeDirectories) || (options == null ? void 0 : options.excludeFiles)) && (matchesExclude(pathToCheck, options == null ? void 0 : options.excludeFiles, useCaseSensitiveFileNames, getCurrentDirectory()) || matchesExclude(pathToCheck, options == null ? void 0 : options.excludeDirectories, useCaseSensitiveFileNames, getCurrentDirectory())); + function isIgnoredByWatchOptions(pathToCheck, options, useCaseSensitiveFileNames2, getCurrentDirectory) { + return ((options == null ? void 0 : options.excludeDirectories) || (options == null ? void 0 : options.excludeFiles)) && (matchesExclude(pathToCheck, options == null ? void 0 : options.excludeFiles, useCaseSensitiveFileNames2, getCurrentDirectory()) || matchesExclude(pathToCheck, options == null ? void 0 : options.excludeDirectories, useCaseSensitiveFileNames2, getCurrentDirectory())); } - function createFsWatchCallbackForDirectoryWatcherCallback(directoryName, callback, options, useCaseSensitiveFileNames, getCurrentDirectory) { + function createFsWatchCallbackForDirectoryWatcherCallback(directoryName, callback, options, useCaseSensitiveFileNames2, getCurrentDirectory) { return (eventName, relativeFileName) => { if (eventName === "rename") { const fileName = !relativeFileName ? directoryName : normalizePath(combinePaths(directoryName, relativeFileName)); - if (!relativeFileName || !isIgnoredByWatchOptions(fileName, options, useCaseSensitiveFileNames, getCurrentDirectory)) { + if (!relativeFileName || !isIgnoredByWatchOptions(fileName, options, useCaseSensitiveFileNames2, getCurrentDirectory)) { callback(fileName); } } @@ -104820,7 +87440,7 @@ ${lanes.join("\n")} clearTimeout: clearTimeout2, fsWatchWorker, fileSystemEntryExists, - useCaseSensitiveFileNames, + useCaseSensitiveFileNames: useCaseSensitiveFileNames2, getCurrentDirectory, fsSupportsRecursiveFsWatch, getAccessibleSortedChildDirectories, @@ -104892,7 +87512,7 @@ ${lanes.join("\n")} ); case 5 /* UseFsEventsOnParentDirectory */: if (!nonPollingWatchFile) { - nonPollingWatchFile = createUseFsEventsOnParentDirectoryWatchFile(fsWatch, useCaseSensitiveFileNames); + nonPollingWatchFile = createUseFsEventsOnParentDirectoryWatchFile(fsWatch, useCaseSensitiveFileNames2); } return nonPollingWatchFile(fileName, callback, pollingInterval, getFallbackOptions(options)); default: @@ -104941,7 +87561,7 @@ ${lanes.join("\n")} return fsWatch( directoryName, 1 /* Directory */, - createFsWatchCallbackForDirectoryWatcherCallback(directoryName, callback, options, useCaseSensitiveFileNames, getCurrentDirectory), + createFsWatchCallbackForDirectoryWatcherCallback(directoryName, callback, options, useCaseSensitiveFileNames2, getCurrentDirectory), recursive, 500 /* Medium */, getFallbackOptions(options) @@ -104949,7 +87569,7 @@ ${lanes.join("\n")} } if (!hostRecursiveDirectoryWatcher) { hostRecursiveDirectoryWatcher = createDirectoryWatcherSupportingRecursive({ - useCaseSensitiveFileNames, + useCaseSensitiveFileNames: useCaseSensitiveFileNames2, getCurrentDirectory, fileSystemEntryExists, getAccessibleSortedChildDirectories, @@ -104995,7 +87615,7 @@ ${lanes.join("\n")} return fsWatch( directoryName, 1 /* Directory */, - createFsWatchCallbackForDirectoryWatcherCallback(directoryName, callback, options, useCaseSensitiveFileNames, getCurrentDirectory), + createFsWatchCallbackForDirectoryWatcherCallback(directoryName, callback, options, useCaseSensitiveFileNames2, getCurrentDirectory), recursive, 500 /* Medium */, getFallbackOptions(watchDirectoryOptions) @@ -105023,7 +87643,7 @@ ${lanes.join("\n")} function pollingWatchFile(fileName, callback, pollingInterval, options) { return createSingleWatcherPerName( pollingWatches, - useCaseSensitiveFileNames, + useCaseSensitiveFileNames2, fileName, callback, (cb) => pollingWatchFileWorker(fileName, cb, pollingInterval, options) @@ -105032,7 +87652,7 @@ ${lanes.join("\n")} function fsWatch(fileOrDirectory, entryKind, callback, recursive, fallbackPollingInterval, fallbackOptions) { return createSingleWatcherPerName( recursive ? fsWatchesRecursive : fsWatches, - useCaseSensitiveFileNames, + useCaseSensitiveFileNames2, fileOrDirectory, callback, (cb) => fsWatchHandlingExistenceOnHost(fileOrDirectory, entryKind, cb, recursive, fallbackPollingInterval, fallbackOptions) @@ -105191,7 +87811,7 @@ ${lanes.join("\n")} const Buffer2 = (__nccwpck_require__(14300).Buffer); const isLinuxOrMacOs = process.platform === "linux" || process.platform === "darwin"; const platform = _os.platform(); - const useCaseSensitiveFileNames = isFileSystemCaseSensitive(); + const useCaseSensitiveFileNames2 = isFileSystemCaseSensitive(); const fsRealpath = !!_fs.realpathSync.native ? process.platform === "win32" ? fsRealPathHandlingLongPath : _fs.realpathSync.native : _fs.realpathSync; const executingFilePath = __filename.endsWith("sys.js") ? _path.join(_path.dirname(__dirname), "__fake__.js") : __filename; const fsSupportsRecursiveFsWatch = process.platform === "win32" || process.platform === "darwin"; @@ -105202,7 +87822,7 @@ ${lanes.join("\n")} setTimeout, clearTimeout, fsWatchWorker, - useCaseSensitiveFileNames, + useCaseSensitiveFileNames: useCaseSensitiveFileNames2, getCurrentDirectory, fileSystemEntryExists, // Node 4.0 `fs.watch` function supports the "recursive" option on both OSX and Windows @@ -105219,7 +87839,7 @@ ${lanes.join("\n")} const nodeSystem = { args: process.argv.slice(2), newLine: _os.EOL, - useCaseSensitiveFileNames, + useCaseSensitiveFileNames: useCaseSensitiveFileNames2, write(s) { process.stdout.write(s); }, @@ -105284,10 +87904,10 @@ ${lanes.join("\n")} disableCPUProfiler, cpuProfilingEnabled: () => !!activeSession || contains(process.execArgv, "--cpu-prof") || contains(process.execArgv, "--prof"), realpath, - debugMode: !!process.env.NODE_INSPECTOR_IPC || !!process.env.VSCODE_INSPECTOR_OPTIONS || some(process.execArgv, (arg) => /^--(inspect|debug)(-brk)?(=\d+)?$/i.test(arg)), + debugMode: !!process.env.NODE_INSPECTOR_IPC || !!process.env.VSCODE_INSPECTOR_OPTIONS || some(process.execArgv, (arg) => /^--(inspect|debug)(-brk)?(=\d+)?$/i.test(arg)) || !!process.recordreplay, tryEnableSourceMapsForHost() { try { - (__nccwpck_require__(42059).install)(); + (__nccwpck_require__(98841).install)(); } catch { } }, @@ -105310,8 +87930,8 @@ ${lanes.join("\n")} try { const modulePath = resolveJSModule(moduleName, baseDir, nodeSystem); return { module: require(modulePath), modulePath, error: void 0 }; - } catch (error) { - return { module: void 0, modulePath: void 0, error }; + } catch (error2) { + return { module: void 0, modulePath: void 0, error: error2 }; } } }; @@ -105348,12 +87968,12 @@ ${lanes.join("\n")} for (const node of profile.nodes) { if (node.callFrame.url) { const url = normalizeSlashes(node.callFrame.url); - if (containsPath(fileUrlRoot, url, useCaseSensitiveFileNames)) { + if (containsPath(fileUrlRoot, url, useCaseSensitiveFileNames2)) { node.callFrame.url = getRelativePathToDirectoryOrUrl( fileUrlRoot, url, fileUrlRoot, - createGetCanonicalFileName(useCaseSensitiveFileNames), + createGetCanonicalFileName(useCaseSensitiveFileNames2), /*isAbsolutePathAnUrl*/ true ); @@ -105398,6 +88018,9 @@ ${lanes.join("\n")} return Buffer2.from && Buffer2.from !== Int8Array.from ? Buffer2.from(input, encoding) : new Buffer2(input, encoding); } function isFileSystemCaseSensitive() { + if (typeof process.versions.pnp !== `undefined`) { + return true; + } if (platform === "win32" || platform === "win64") { return false; } @@ -105533,7 +88156,7 @@ ${lanes.join("\n")} } } function readDirectory(path, extensions, excludes, includes, depth) { - return matchFiles(path, extensions, excludes, includes, useCaseSensitiveFileNames, process.cwd(), depth, getAccessibleFileSystemEntries, realpath); + return matchFiles(path, extensions, excludes, includes, useCaseSensitiveFileNames2, process.cwd(), depth, getAccessibleFileSystemEntries, realpath); } function fileSystemEntryExists(path, entryKind) { const originalStackTraceLimit = Error.stackTraceLimit; @@ -105619,7 +88242,9 @@ ${lanes.join("\n")} })(); if (sys && sys.getEnvironmentVariable) { setCustomPollingValues(sys); - Debug.setAssertionLevel(/^development$/i.test(sys.getEnvironmentVariable("NODE_ENV")) ? 1 /* Normal */ : 0 /* None */); + Debug.setAssertionLevel( + /^development$/i.test(sys.getEnvironmentVariable("NODE_ENV")) ? 1 /* Normal */ : 0 /* None */ + ); } if (sys && sys.debugMode) { Debug.isDebugging = true; @@ -105651,7 +88276,7 @@ ${lanes.join("\n")} return !pathIsAbsolute(path) && !pathIsRelative(path); } function hasExtension(fileName) { - return stringContains(getBaseFileName(fileName), "."); + return getBaseFileName(fileName).includes("."); } function fileExtensionIs(path, extension) { return path.length > extension.length && endsWith(path, extension); @@ -105796,7 +88421,7 @@ ${lanes.join("\n")} return root + pathComponents2.slice(1, length2).join(directorySeparator); } function normalizeSlashes(path) { - return path.indexOf("\\") !== -1 ? path.replace(backslashRegExp, directorySeparator) : path; + return path.includes("\\") ? path.replace(backslashRegExp, directorySeparator) : path; } function reducePathComponents(components) { if (!some(components)) @@ -106109,6 +88734,7 @@ ${lanes.join("\n")} Type_is_referenced_directly_or_indirectly_in_the_fulfillment_callback_of_its_own_then_method: diag(1062, 1 /* Error */, "Type_is_referenced_directly_or_indirectly_in_the_fulfillment_callback_of_its_own_then_method_1062", "Type is referenced directly or indirectly in the fulfillment callback of its own 'then' method."), An_export_assignment_cannot_be_used_in_a_namespace: diag(1063, 1 /* Error */, "An_export_assignment_cannot_be_used_in_a_namespace_1063", "An export assignment cannot be used in a namespace."), The_return_type_of_an_async_function_or_method_must_be_the_global_Promise_T_type_Did_you_mean_to_write_Promise_0: diag(1064, 1 /* Error */, "The_return_type_of_an_async_function_or_method_must_be_the_global_Promise_T_type_Did_you_mean_to_wri_1064", "The return type of an async function or method must be the global Promise type. Did you mean to write 'Promise<{0}>'?"), + The_return_type_of_an_async_function_or_method_must_be_the_global_Promise_T_type: diag(1065, 1 /* Error */, "The_return_type_of_an_async_function_or_method_must_be_the_global_Promise_T_type_1065", "The return type of an async function or method must be the global Promise type."), In_ambient_enum_declarations_member_initializer_must_be_constant_expression: diag(1066, 1 /* Error */, "In_ambient_enum_declarations_member_initializer_must_be_constant_expression_1066", "In ambient enum declarations member initializer must be constant expression."), Unexpected_token_A_constructor_method_accessor_or_property_was_expected: diag(1068, 1 /* Error */, "Unexpected_token_A_constructor_method_accessor_or_property_was_expected_1068", "Unexpected token. A constructor, method, accessor, or property was expected."), Unexpected_token_A_type_parameter_name_was_expected_without_curly_braces: diag(1069, 1 /* Error */, "Unexpected_token_A_type_parameter_name_was_expected_without_curly_braces_1069", "Unexpected token. A type parameter name was expected without curly braces."), @@ -106138,6 +88764,7 @@ ${lanes.join("\n")} A_return_statement_can_only_be_used_within_a_function_body: diag(1108, 1 /* Error */, "A_return_statement_can_only_be_used_within_a_function_body_1108", "A 'return' statement can only be used within a function body."), Expression_expected: diag(1109, 1 /* Error */, "Expression_expected_1109", "Expression expected."), Type_expected: diag(1110, 1 /* Error */, "Type_expected_1110", "Type expected."), + Private_field_0_must_be_declared_in_an_enclosing_class: diag(1111, 1 /* Error */, "Private_field_0_must_be_declared_in_an_enclosing_class_1111", "Private field '{0}' must be declared in an enclosing class."), A_default_clause_cannot_appear_more_than_once_in_a_switch_statement: diag(1113, 1 /* Error */, "A_default_clause_cannot_appear_more_than_once_in_a_switch_statement_1113", "A 'default' clause cannot appear more than once in a 'switch' statement."), Duplicate_label_0: diag(1114, 1 /* Error */, "Duplicate_label_0_1114", "Duplicate label '{0}'."), A_continue_statement_can_only_jump_to_a_label_of_an_enclosing_iteration_statement: diag(1115, 1 /* Error */, "A_continue_statement_can_only_jump_to_a_label_of_an_enclosing_iteration_statement_1115", "A 'continue' statement can only jump to a label of an enclosing iteration statement."), @@ -106172,9 +88799,8 @@ ${lanes.join("\n")} Import_declarations_in_a_namespace_cannot_reference_a_module: diag(1147, 1 /* Error */, "Import_declarations_in_a_namespace_cannot_reference_a_module_1147", "Import declarations in a namespace cannot reference a module."), Cannot_use_imports_exports_or_module_augmentations_when_module_is_none: diag(1148, 1 /* Error */, "Cannot_use_imports_exports_or_module_augmentations_when_module_is_none_1148", "Cannot use imports, exports, or module augmentations when '--module' is 'none'."), File_name_0_differs_from_already_included_file_name_1_only_in_casing: diag(1149, 1 /* Error */, "File_name_0_differs_from_already_included_file_name_1_only_in_casing_1149", "File name '{0}' differs from already included file name '{1}' only in casing."), - const_declarations_must_be_initialized: diag(1155, 1 /* Error */, "const_declarations_must_be_initialized_1155", "'const' declarations must be initialized."), - const_declarations_can_only_be_declared_inside_a_block: diag(1156, 1 /* Error */, "const_declarations_can_only_be_declared_inside_a_block_1156", "'const' declarations can only be declared inside a block."), - let_declarations_can_only_be_declared_inside_a_block: diag(1157, 1 /* Error */, "let_declarations_can_only_be_declared_inside_a_block_1157", "'let' declarations can only be declared inside a block."), + _0_declarations_must_be_initialized: diag(1155, 1 /* Error */, "_0_declarations_must_be_initialized_1155", "'{0}' declarations must be initialized."), + _0_declarations_can_only_be_declared_inside_a_block: diag(1156, 1 /* Error */, "_0_declarations_can_only_be_declared_inside_a_block_1156", "'{0}' declarations can only be declared inside a block."), Unterminated_template_literal: diag(1160, 1 /* Error */, "Unterminated_template_literal_1160", "Unterminated template literal."), Unterminated_regular_expression_literal: diag(1161, 1 /* Error */, "Unterminated_regular_expression_literal_1161", "Unterminated regular expression literal."), An_object_member_cannot_be_declared_optional: diag(1162, 1 /* Error */, "An_object_member_cannot_be_declared_optional_1162", "An object member cannot be declared optional."), @@ -106356,8 +88982,6 @@ ${lanes.join("\n")} Class_constructor_may_not_be_a_generator: diag(1368, 1 /* Error */, "Class_constructor_may_not_be_a_generator_1368", "Class constructor may not be a generator."), Did_you_mean_0: diag(1369, 3 /* Message */, "Did_you_mean_0_1369", "Did you mean '{0}'?"), This_import_is_never_used_as_a_value_and_must_use_import_type_because_importsNotUsedAsValues_is_set_to_error: diag(1371, 1 /* Error */, "This_import_is_never_used_as_a_value_and_must_use_import_type_because_importsNotUsedAsValues_is_set__1371", "This import is never used as a value and must use 'import type' because 'importsNotUsedAsValues' is set to 'error'."), - Convert_to_type_only_import: diag(1373, 3 /* Message */, "Convert_to_type_only_import_1373", "Convert to type-only import"), - Convert_all_imports_not_used_as_a_value_to_type_only_imports: diag(1374, 3 /* Message */, "Convert_all_imports_not_used_as_a_value_to_type_only_imports_1374", "Convert all imports not used as a value to type-only imports"), await_expressions_are_only_allowed_at_the_top_level_of_a_file_when_that_file_is_a_module_but_this_file_has_no_imports_or_exports_Consider_adding_an_empty_export_to_make_this_file_a_module: diag(1375, 1 /* Error */, "await_expressions_are_only_allowed_at_the_top_level_of_a_file_when_that_file_is_a_module_but_this_fi_1375", "'await' expressions are only allowed at the top level of a file when that file is a module, but this file has no imports or exports. Consider adding an empty 'export {}' to make this file a module."), _0_was_imported_here: diag(1376, 3 /* Message */, "_0_was_imported_here_1376", "'{0}' was imported here."), _0_was_exported_here: diag(1377, 3 /* Message */, "_0_was_exported_here_1377", "'{0}' was exported here."), @@ -106428,9 +89052,8 @@ ${lanes.join("\n")} _0_resolves_to_a_type_only_declaration_and_must_be_imported_using_a_type_only_import_when_preserveValueImports_and_isolatedModules_are_both_enabled: diag(1446, 1 /* Error */, "_0_resolves_to_a_type_only_declaration_and_must_be_imported_using_a_type_only_import_when_preserveVa_1446", "'{0}' resolves to a type-only declaration and must be imported using a type-only import when 'preserveValueImports' and 'isolatedModules' are both enabled."), _0_resolves_to_a_type_only_declaration_and_must_be_re_exported_using_a_type_only_re_export_when_1_is_enabled: diag(1448, 1 /* Error */, "_0_resolves_to_a_type_only_declaration_and_must_be_re_exported_using_a_type_only_re_export_when_1_is_1448", "'{0}' resolves to a type-only declaration and must be re-exported using a type-only re-export when '{1}' is enabled."), Preserve_unused_imported_values_in_the_JavaScript_output_that_would_otherwise_be_removed: diag(1449, 3 /* Message */, "Preserve_unused_imported_values_in_the_JavaScript_output_that_would_otherwise_be_removed_1449", "Preserve unused imported values in the JavaScript output that would otherwise be removed."), - Dynamic_imports_can_only_accept_a_module_specifier_and_an_optional_assertion_as_arguments: diag(1450, 3 /* Message */, "Dynamic_imports_can_only_accept_a_module_specifier_and_an_optional_assertion_as_arguments_1450", "Dynamic imports can only accept a module specifier and an optional assertion as arguments"), + Dynamic_imports_can_only_accept_a_module_specifier_and_an_optional_set_of_attributes_as_arguments: diag(1450, 3 /* Message */, "Dynamic_imports_can_only_accept_a_module_specifier_and_an_optional_set_of_attributes_as_arguments_1450", "Dynamic imports can only accept a module specifier and an optional set of attributes as arguments"), Private_identifiers_are_only_allowed_in_class_bodies_and_may_only_be_used_as_part_of_a_class_member_declaration_property_access_or_on_the_left_hand_side_of_an_in_expression: diag(1451, 1 /* Error */, "Private_identifiers_are_only_allowed_in_class_bodies_and_may_only_be_used_as_part_of_a_class_member__1451", "Private identifiers are only allowed in class bodies and may only be used as part of a class member declaration, property access, or on the left-hand-side of an 'in' expression"), - resolution_mode_assertions_are_only_supported_when_moduleResolution_is_node16_or_nodenext: diag(1452, 1 /* Error */, "resolution_mode_assertions_are_only_supported_when_moduleResolution_is_node16_or_nodenext_1452", "'resolution-mode' assertions are only supported when `moduleResolution` is `node16` or `nodenext`."), resolution_mode_should_be_either_require_or_import: diag(1453, 1 /* Error */, "resolution_mode_should_be_either_require_or_import_1453", "`resolution-mode` should be either `require` or `import`."), resolution_mode_can_only_be_set_for_type_only_imports: diag(1454, 1 /* Error */, "resolution_mode_can_only_be_set_for_type_only_imports_1454", "`resolution-mode` can only be set for type-only imports."), resolution_mode_is_the_only_valid_key_for_type_import_assertions: diag(1455, 1 /* Error */, "resolution_mode_is_the_only_valid_key_for_type_import_assertions_1455", "`resolution-mode` is the only valid key for type import assertions."), @@ -106440,6 +89063,8 @@ ${lanes.join("\n")} File_is_CommonJS_module_because_0_has_field_type_whose_value_is_not_module: diag(1459, 3 /* Message */, "File_is_CommonJS_module_because_0_has_field_type_whose_value_is_not_module_1459", `File is CommonJS module because '{0}' has field "type" whose value is not "module"`), File_is_CommonJS_module_because_0_does_not_have_field_type: diag(1460, 3 /* Message */, "File_is_CommonJS_module_because_0_does_not_have_field_type_1460", `File is CommonJS module because '{0}' does not have field "type"`), File_is_CommonJS_module_because_package_json_was_not_found: diag(1461, 3 /* Message */, "File_is_CommonJS_module_because_package_json_was_not_found_1461", "File is CommonJS module because 'package.json' was not found"), + resolution_mode_is_the_only_valid_key_for_type_import_attributes: diag(1463, 1 /* Error */, "resolution_mode_is_the_only_valid_key_for_type_import_attributes_1463", "'resolution-mode' is the only valid key for type import attributes."), + Type_import_attributes_should_have_exactly_one_key_resolution_mode_with_value_import_or_require: diag(1464, 1 /* Error */, "Type_import_attributes_should_have_exactly_one_key_resolution_mode_with_value_import_or_require_1464", "Type import attributes should have exactly one key - 'resolution-mode' - with value 'import' or 'require'."), The_import_meta_meta_property_is_not_allowed_in_files_which_will_build_into_CommonJS_output: diag(1470, 1 /* Error */, "The_import_meta_meta_property_is_not_allowed_in_files_which_will_build_into_CommonJS_output_1470", "The 'import.meta' meta-property is not allowed in files which will build into CommonJS output."), Module_0_cannot_be_imported_using_this_construct_The_specifier_only_resolves_to_an_ES_module_which_cannot_be_imported_with_require_Use_an_ECMAScript_import_instead: diag(1471, 1 /* Error */, "Module_0_cannot_be_imported_using_this_construct_The_specifier_only_resolves_to_an_ES_module_which_c_1471", "Module '{0}' cannot be imported using this construct. The specifier only resolves to an ES module, which cannot be imported with 'require'. Use an ECMAScript import instead."), catch_or_finally_expected: diag(1472, 1 /* Error */, "catch_or_finally_expected_1472", "'catch' or 'finally' expected."), @@ -106461,6 +89086,12 @@ ${lanes.join("\n")} Escape_sequence_0_is_not_allowed: diag(1488, 1 /* Error */, "Escape_sequence_0_is_not_allowed_1488", "Escape sequence '{0}' is not allowed."), Decimals_with_leading_zeros_are_not_allowed: diag(1489, 1 /* Error */, "Decimals_with_leading_zeros_are_not_allowed_1489", "Decimals with leading zeros are not allowed."), File_appears_to_be_binary: diag(1490, 1 /* Error */, "File_appears_to_be_binary_1490", "File appears to be binary."), + _0_modifier_cannot_appear_on_a_using_declaration: diag(1491, 1 /* Error */, "_0_modifier_cannot_appear_on_a_using_declaration_1491", "'{0}' modifier cannot appear on a 'using' declaration."), + _0_declarations_may_not_have_binding_patterns: diag(1492, 1 /* Error */, "_0_declarations_may_not_have_binding_patterns_1492", "'{0}' declarations may not have binding patterns."), + The_left_hand_side_of_a_for_in_statement_cannot_be_a_using_declaration: diag(1493, 1 /* Error */, "The_left_hand_side_of_a_for_in_statement_cannot_be_a_using_declaration_1493", "The left-hand side of a 'for...in' statement cannot be a 'using' declaration."), + The_left_hand_side_of_a_for_in_statement_cannot_be_an_await_using_declaration: diag(1494, 1 /* Error */, "The_left_hand_side_of_a_for_in_statement_cannot_be_an_await_using_declaration_1494", "The left-hand side of a 'for...in' statement cannot be an 'await using' declaration."), + _0_modifier_cannot_appear_on_an_await_using_declaration: diag(1495, 1 /* Error */, "_0_modifier_cannot_appear_on_an_await_using_declaration_1495", "'{0}' modifier cannot appear on an 'await using' declaration."), + Identifier_string_literal_or_number_literal_expected: diag(1496, 1 /* Error */, "Identifier_string_literal_or_number_literal_expected_1496", "Identifier, string literal, or number literal expected."), The_types_of_0_are_incompatible_between_these_types: diag(2200, 1 /* Error */, "The_types_of_0_are_incompatible_between_these_types_2200", "The types of '{0}' are incompatible between these types."), The_types_returned_by_0_are_incompatible_between_these_types: diag(2201, 1 /* Error */, "The_types_returned_by_0_are_incompatible_between_these_types_2201", "The types returned by '{0}' are incompatible between these types."), Call_signature_return_types_0_and_1_are_incompatible: diag( @@ -106555,7 +89186,6 @@ ${lanes.join("\n")} This_syntax_requires_an_imported_helper_named_1_which_does_not_exist_in_0_Consider_upgrading_your_version_of_0: diag(2343, 1 /* Error */, "This_syntax_requires_an_imported_helper_named_1_which_does_not_exist_in_0_Consider_upgrading_your_ve_2343", "This syntax requires an imported helper named '{1}' which does not exist in '{0}'. Consider upgrading your version of '{0}'."), Type_0_does_not_satisfy_the_constraint_1: diag(2344, 1 /* Error */, "Type_0_does_not_satisfy_the_constraint_1_2344", "Type '{0}' does not satisfy the constraint '{1}'."), Argument_of_type_0_is_not_assignable_to_parameter_of_type_1: diag(2345, 1 /* Error */, "Argument_of_type_0_is_not_assignable_to_parameter_of_type_1_2345", "Argument of type '{0}' is not assignable to parameter of type '{1}'."), - Call_target_does_not_contain_any_signatures: diag(2346, 1 /* Error */, "Call_target_does_not_contain_any_signatures_2346", "Call target does not contain any signatures."), Untyped_function_calls_may_not_accept_type_arguments: diag(2347, 1 /* Error */, "Untyped_function_calls_may_not_accept_type_arguments_2347", "Untyped function calls may not accept type arguments."), Value_of_type_0_is_not_callable_Did_you_mean_to_include_new: diag(2348, 1 /* Error */, "Value_of_type_0_is_not_callable_Did_you_mean_to_include_new_2348", "Value of type '{0}' is not callable. Did you mean to include 'new'?"), This_expression_is_not_callable: diag(2349, 1 /* Error */, "This_expression_is_not_callable_2349", "This expression is not callable."), @@ -106568,7 +89198,7 @@ ${lanes.join("\n")} An_arithmetic_operand_must_be_of_type_any_number_bigint_or_an_enum_type: diag(2356, 1 /* Error */, "An_arithmetic_operand_must_be_of_type_any_number_bigint_or_an_enum_type_2356", "An arithmetic operand must be of type 'any', 'number', 'bigint' or an enum type."), The_operand_of_an_increment_or_decrement_operator_must_be_a_variable_or_a_property_access: diag(2357, 1 /* Error */, "The_operand_of_an_increment_or_decrement_operator_must_be_a_variable_or_a_property_access_2357", "The operand of an increment or decrement operator must be a variable or a property access."), The_left_hand_side_of_an_instanceof_expression_must_be_of_type_any_an_object_type_or_a_type_parameter: diag(2358, 1 /* Error */, "The_left_hand_side_of_an_instanceof_expression_must_be_of_type_any_an_object_type_or_a_type_paramete_2358", "The left-hand side of an 'instanceof' expression must be of type 'any', an object type or a type parameter."), - The_right_hand_side_of_an_instanceof_expression_must_be_of_type_any_or_of_a_type_assignable_to_the_Function_interface_type: diag(2359, 1 /* Error */, "The_right_hand_side_of_an_instanceof_expression_must_be_of_type_any_or_of_a_type_assignable_to_the_F_2359", "The right-hand side of an 'instanceof' expression must be of type 'any' or of a type assignable to the 'Function' interface type."), + The_right_hand_side_of_an_instanceof_expression_must_be_either_of_type_any_a_class_function_or_other_type_assignable_to_the_Function_interface_type_or_an_object_type_with_a_Symbol_hasInstance_method: diag(2359, 1 /* Error */, "The_right_hand_side_of_an_instanceof_expression_must_be_either_of_type_any_a_class_function_or_other_2359", "The right-hand side of an 'instanceof' expression must be either of type 'any', a class, function, or other type assignable to the 'Function' interface type, or an object type with a 'Symbol.hasInstance' method."), The_left_hand_side_of_an_arithmetic_operation_must_be_of_type_any_number_bigint_or_an_enum_type: diag(2362, 1 /* Error */, "The_left_hand_side_of_an_arithmetic_operation_must_be_of_type_any_number_bigint_or_an_enum_type_2362", "The left-hand side of an arithmetic operation must be of type 'any', 'number', 'bigint' or an enum type."), The_right_hand_side_of_an_arithmetic_operation_must_be_of_type_any_number_bigint_or_an_enum_type: diag(2363, 1 /* Error */, "The_right_hand_side_of_an_arithmetic_operation_must_be_of_type_any_number_bigint_or_an_enum_type_2363", "The right-hand side of an arithmetic operation must be of type 'any', 'number', 'bigint' or an enum type."), The_left_hand_side_of_an_assignment_expression_must_be_a_variable_or_a_property_access: diag(2364, 1 /* Error */, "The_left_hand_side_of_an_assignment_expression_must_be_a_variable_or_a_property_access_2364", "The left-hand side of an assignment expression must be a variable or a property access."), @@ -106991,15 +89621,15 @@ ${lanes.join("\n")} Type_0_is_not_assignable_to_type_1_Did_you_mean_2: diag(2820, 1 /* Error */, "Type_0_is_not_assignable_to_type_1_Did_you_mean_2_2820", "Type '{0}' is not assignable to type '{1}'. Did you mean '{2}'?"), Import_assertions_are_only_supported_when_the_module_option_is_set_to_esnext_or_nodenext: diag(2821, 1 /* Error */, "Import_assertions_are_only_supported_when_the_module_option_is_set_to_esnext_or_nodenext_2821", "Import assertions are only supported when the '--module' option is set to 'esnext' or 'nodenext'."), Import_assertions_cannot_be_used_with_type_only_imports_or_exports: diag(2822, 1 /* Error */, "Import_assertions_cannot_be_used_with_type_only_imports_or_exports_2822", "Import assertions cannot be used with type-only imports or exports."), + Import_attributes_are_only_supported_when_the_module_option_is_set_to_esnext_or_nodenext: diag(2823, 1 /* Error */, "Import_attributes_are_only_supported_when_the_module_option_is_set_to_esnext_or_nodenext_2823", "Import attributes are only supported when the '--module' option is set to 'esnext' or 'nodenext'."), Cannot_find_namespace_0_Did_you_mean_1: diag(2833, 1 /* Error */, "Cannot_find_namespace_0_Did_you_mean_1_2833", "Cannot find namespace '{0}'. Did you mean '{1}'?"), - Relative_import_paths_need_explicit_file_extensions_in_EcmaScript_imports_when_moduleResolution_is_node16_or_nodenext_Consider_adding_an_extension_to_the_import_path: diag(2834, 1 /* Error */, "Relative_import_paths_need_explicit_file_extensions_in_EcmaScript_imports_when_moduleResolution_is_n_2834", "Relative import paths need explicit file extensions in EcmaScript imports when '--moduleResolution' is 'node16' or 'nodenext'. Consider adding an extension to the import path."), - Relative_import_paths_need_explicit_file_extensions_in_EcmaScript_imports_when_moduleResolution_is_node16_or_nodenext_Did_you_mean_0: diag(2835, 1 /* Error */, "Relative_import_paths_need_explicit_file_extensions_in_EcmaScript_imports_when_moduleResolution_is_n_2835", "Relative import paths need explicit file extensions in EcmaScript imports when '--moduleResolution' is 'node16' or 'nodenext'. Did you mean '{0}'?"), - Import_assertions_are_not_allowed_on_statements_that_transpile_to_commonjs_require_calls: diag(2836, 1 /* Error */, "Import_assertions_are_not_allowed_on_statements_that_transpile_to_commonjs_require_calls_2836", "Import assertions are not allowed on statements that transpile to commonjs 'require' calls."), + Relative_import_paths_need_explicit_file_extensions_in_ECMAScript_imports_when_moduleResolution_is_node16_or_nodenext_Consider_adding_an_extension_to_the_import_path: diag(2834, 1 /* Error */, "Relative_import_paths_need_explicit_file_extensions_in_ECMAScript_imports_when_moduleResolution_is_n_2834", "Relative import paths need explicit file extensions in ECMAScript imports when '--moduleResolution' is 'node16' or 'nodenext'. Consider adding an extension to the import path."), + Relative_import_paths_need_explicit_file_extensions_in_ECMAScript_imports_when_moduleResolution_is_node16_or_nodenext_Did_you_mean_0: diag(2835, 1 /* Error */, "Relative_import_paths_need_explicit_file_extensions_in_ECMAScript_imports_when_moduleResolution_is_n_2835", "Relative import paths need explicit file extensions in ECMAScript imports when '--moduleResolution' is 'node16' or 'nodenext'. Did you mean '{0}'?"), + Import_assertions_are_not_allowed_on_statements_that_compile_to_CommonJS_require_calls: diag(2836, 1 /* Error */, "Import_assertions_are_not_allowed_on_statements_that_compile_to_CommonJS_require_calls_2836", "Import assertions are not allowed on statements that compile to CommonJS 'require' calls."), Import_assertion_values_must_be_string_literal_expressions: diag(2837, 1 /* Error */, "Import_assertion_values_must_be_string_literal_expressions_2837", "Import assertion values must be string literal expressions."), All_declarations_of_0_must_have_identical_constraints: diag(2838, 1 /* Error */, "All_declarations_of_0_must_have_identical_constraints_2838", "All declarations of '{0}' must have identical constraints."), This_condition_will_always_return_0_since_JavaScript_compares_objects_by_reference_not_value: diag(2839, 1 /* Error */, "This_condition_will_always_return_0_since_JavaScript_compares_objects_by_reference_not_value_2839", "This condition will always return '{0}' since JavaScript compares objects by reference, not value."), - An_interface_cannot_extend_a_primitive_type_like_0_an_interface_can_only_extend_named_types_and_classes: diag(2840, 1 /* Error */, "An_interface_cannot_extend_a_primitive_type_like_0_an_interface_can_only_extend_named_types_and_clas_2840", "An interface cannot extend a primitive type like '{0}'; an interface can only extend named types and classes"), - The_type_of_this_expression_cannot_be_named_without_a_resolution_mode_assertion_which_is_an_unstable_feature_Use_nightly_TypeScript_to_silence_this_error_Try_updating_with_npm_install_D_typescript_next: diag(2841, 1 /* Error */, "The_type_of_this_expression_cannot_be_named_without_a_resolution_mode_assertion_which_is_an_unstable_2841", "The type of this expression cannot be named without a 'resolution-mode' assertion, which is an unstable feature. Use nightly TypeScript to silence this error. Try updating with 'npm install -D typescript@next'."), + An_interface_cannot_extend_a_primitive_type_like_0_It_can_only_extend_other_named_object_types: diag(2840, 1 /* Error */, "An_interface_cannot_extend_a_primitive_type_like_0_It_can_only_extend_other_named_object_types_2840", "An interface cannot extend a primitive type like '{0}'. It can only extend other named object types."), _0_is_an_unused_renaming_of_1_Did_you_intend_to_use_it_as_a_type_annotation: diag(2842, 1 /* Error */, "_0_is_an_unused_renaming_of_1_Did_you_intend_to_use_it_as_a_type_annotation_2842", "'{0}' is an unused renaming of '{1}'. Did you intend to use it as a type annotation?"), We_can_only_write_a_type_for_0_by_adding_a_type_for_the_entire_parameter_here: diag(2843, 1 /* Error */, "We_can_only_write_a_type_for_0_by_adding_a_type_for_the_entire_parameter_here_2843", "We can only write a type for '{0}' by adding a type for the entire parameter here."), Type_of_instance_member_variable_0_cannot_reference_identifier_1_declared_in_the_constructor: diag(2844, 1 /* Error */, "Type_of_instance_member_variable_0_cannot_reference_identifier_1_declared_in_the_constructor_2844", "Type of instance member variable '{0}' cannot reference identifier '{1}' declared in the constructor."), @@ -107007,6 +89637,21 @@ ${lanes.join("\n")} A_declaration_file_cannot_be_imported_without_import_type_Did_you_mean_to_import_an_implementation_file_0_instead: diag(2846, 1 /* Error */, "A_declaration_file_cannot_be_imported_without_import_type_Did_you_mean_to_import_an_implementation_f_2846", "A declaration file cannot be imported without 'import type'. Did you mean to import an implementation file '{0}' instead?"), The_right_hand_side_of_an_instanceof_expression_must_not_be_an_instantiation_expression: diag(2848, 1 /* Error */, "The_right_hand_side_of_an_instanceof_expression_must_not_be_an_instantiation_expression_2848", "The right-hand side of an 'instanceof' expression must not be an instantiation expression."), Target_signature_provides_too_few_arguments_Expected_0_or_more_but_got_1: diag(2849, 1 /* Error */, "Target_signature_provides_too_few_arguments_Expected_0_or_more_but_got_1_2849", "Target signature provides too few arguments. Expected {0} or more, but got {1}."), + The_initializer_of_a_using_declaration_must_be_either_an_object_with_a_Symbol_dispose_method_or_be_null_or_undefined: diag(2850, 1 /* Error */, "The_initializer_of_a_using_declaration_must_be_either_an_object_with_a_Symbol_dispose_method_or_be_n_2850", "The initializer of a 'using' declaration must be either an object with a '[Symbol.dispose]()' method, or be 'null' or 'undefined'."), + The_initializer_of_an_await_using_declaration_must_be_either_an_object_with_a_Symbol_asyncDispose_or_Symbol_dispose_method_or_be_null_or_undefined: diag(2851, 1 /* Error */, "The_initializer_of_an_await_using_declaration_must_be_either_an_object_with_a_Symbol_asyncDispose_or_2851", "The initializer of an 'await using' declaration must be either an object with a '[Symbol.asyncDispose]()' or '[Symbol.dispose]()' method, or be 'null' or 'undefined'."), + await_using_statements_are_only_allowed_within_async_functions_and_at_the_top_levels_of_modules: diag(2852, 1 /* Error */, "await_using_statements_are_only_allowed_within_async_functions_and_at_the_top_levels_of_modules_2852", "'await using' statements are only allowed within async functions and at the top levels of modules."), + await_using_statements_are_only_allowed_at_the_top_level_of_a_file_when_that_file_is_a_module_but_this_file_has_no_imports_or_exports_Consider_adding_an_empty_export_to_make_this_file_a_module: diag(2853, 1 /* Error */, "await_using_statements_are_only_allowed_at_the_top_level_of_a_file_when_that_file_is_a_module_but_th_2853", "'await using' statements are only allowed at the top level of a file when that file is a module, but this file has no imports or exports. Consider adding an empty 'export {}' to make this file a module."), + Top_level_await_using_statements_are_only_allowed_when_the_module_option_is_set_to_es2022_esnext_system_node16_or_nodenext_and_the_target_option_is_set_to_es2017_or_higher: diag(2854, 1 /* Error */, "Top_level_await_using_statements_are_only_allowed_when_the_module_option_is_set_to_es2022_esnext_sys_2854", "Top-level 'await using' statements are only allowed when the 'module' option is set to 'es2022', 'esnext', 'system', 'node16', or 'nodenext', and the 'target' option is set to 'es2017' or higher."), + Class_field_0_defined_by_the_parent_class_is_not_accessible_in_the_child_class_via_super: diag(2855, 1 /* Error */, "Class_field_0_defined_by_the_parent_class_is_not_accessible_in_the_child_class_via_super_2855", "Class field '{0}' defined by the parent class is not accessible in the child class via super."), + Import_attributes_are_not_allowed_on_statements_that_compile_to_CommonJS_require_calls: diag(2856, 1 /* Error */, "Import_attributes_are_not_allowed_on_statements_that_compile_to_CommonJS_require_calls_2856", "Import attributes are not allowed on statements that compile to CommonJS 'require' calls."), + Import_attributes_cannot_be_used_with_type_only_imports_or_exports: diag(2857, 1 /* Error */, "Import_attributes_cannot_be_used_with_type_only_imports_or_exports_2857", "Import attributes cannot be used with type-only imports or exports."), + Import_attribute_values_must_be_string_literal_expressions: diag(2858, 1 /* Error */, "Import_attribute_values_must_be_string_literal_expressions_2858", "Import attribute values must be string literal expressions."), + Excessive_complexity_comparing_types_0_and_1: diag(2859, 1 /* Error */, "Excessive_complexity_comparing_types_0_and_1_2859", "Excessive complexity comparing types '{0}' and '{1}'."), + The_left_hand_side_of_an_instanceof_expression_must_be_assignable_to_the_first_argument_of_the_right_hand_side_s_Symbol_hasInstance_method: diag(2860, 1 /* Error */, "The_left_hand_side_of_an_instanceof_expression_must_be_assignable_to_the_first_argument_of_the_right_2860", "The left-hand side of an 'instanceof' expression must be assignable to the first argument of the right-hand side's '[Symbol.hasInstance]' method."), + An_object_s_Symbol_hasInstance_method_must_return_a_boolean_value_for_it_to_be_used_on_the_right_hand_side_of_an_instanceof_expression: diag(2861, 1 /* Error */, "An_object_s_Symbol_hasInstance_method_must_return_a_boolean_value_for_it_to_be_used_on_the_right_han_2861", "An object's '[Symbol.hasInstance]' method must return a boolean value for it to be used on the right-hand side of an 'instanceof' expression."), + Type_0_is_generic_and_can_only_be_indexed_for_reading: diag(2862, 1 /* Error */, "Type_0_is_generic_and_can_only_be_indexed_for_reading_2862", "Type '{0}' is generic and can only be indexed for reading."), + A_class_cannot_extend_a_primitive_type_like_0_Classes_can_only_extend_constructable_values: diag(2863, 1 /* Error */, "A_class_cannot_extend_a_primitive_type_like_0_Classes_can_only_extend_constructable_values_2863", "A class cannot extend a primitive type like '{0}'. Classes can only extend constructable values."), + A_class_cannot_implement_a_primitive_type_like_0_It_can_only_implement_other_named_object_types: diag(2864, 1 /* Error */, "A_class_cannot_implement_a_primitive_type_like_0_It_can_only_implement_other_named_object_types_2864", "A class cannot implement a primitive type like '{0}'. It can only implement other named object types."), Import_declaration_0_is_using_private_name_1: diag(4e3, 1 /* Error */, "Import_declaration_0_is_using_private_name_1_4000", "Import declaration '{0}' is using private name '{1}'."), Type_parameter_0_of_exported_class_has_or_is_using_private_name_1: diag(4002, 1 /* Error */, "Type_parameter_0_of_exported_class_has_or_is_using_private_name_1_4002", "Type parameter '{0}' of exported class has or is using private name '{1}'."), Type_parameter_0_of_exported_interface_has_or_is_using_private_name_1: diag(4004, 1 /* Error */, "Type_parameter_0_of_exported_interface_has_or_is_using_private_name_1_4004", "Type parameter '{0}' of exported interface has or is using private name '{1}'."), @@ -107115,7 +89760,6 @@ ${lanes.join("\n")} This_member_cannot_have_a_JSDoc_comment_with_an_override_tag_because_it_is_not_declared_in_the_base_class_0: diag(4122, 1 /* Error */, "This_member_cannot_have_a_JSDoc_comment_with_an_override_tag_because_it_is_not_declared_in_the_base__4122", "This member cannot have a JSDoc comment with an '@override' tag because it is not declared in the base class '{0}'."), This_member_cannot_have_a_JSDoc_comment_with_an_override_tag_because_it_is_not_declared_in_the_base_class_0_Did_you_mean_1: diag(4123, 1 /* Error */, "This_member_cannot_have_a_JSDoc_comment_with_an_override_tag_because_it_is_not_declared_in_the_base__4123", "This member cannot have a JSDoc comment with an 'override' tag because it is not declared in the base class '{0}'. Did you mean '{1}'?"), Compiler_option_0_of_value_1_is_unstable_Use_nightly_TypeScript_to_silence_this_error_Try_updating_with_npm_install_D_typescript_next: diag(4124, 1 /* Error */, "Compiler_option_0_of_value_1_is_unstable_Use_nightly_TypeScript_to_silence_this_error_Try_updating_w_4124", "Compiler option '{0}' of value '{1}' is unstable. Use nightly TypeScript to silence this error. Try updating with 'npm install -D typescript@next'."), - resolution_mode_assertions_are_unstable_Use_nightly_TypeScript_to_silence_this_error_Try_updating_with_npm_install_D_typescript_next: diag(4125, 1 /* Error */, "resolution_mode_assertions_are_unstable_Use_nightly_TypeScript_to_silence_this_error_Try_updating_wi_4125", "'resolution-mode' assertions are unstable. Use nightly TypeScript to silence this error. Try updating with 'npm install -D typescript@next'."), The_current_host_does_not_support_the_0_option: diag(5001, 1 /* Error */, "The_current_host_does_not_support_the_0_option_5001", "The current host does not support the '{0}' option."), Cannot_find_the_common_subdirectory_path_for_the_input_files: diag(5009, 1 /* Error */, "Cannot_find_the_common_subdirectory_path_for_the_input_files_5009", "Cannot find the common subdirectory path for the input files."), File_specification_cannot_end_in_a_recursive_directory_wildcard_Asterisk_Asterisk_Colon_0: diag(5010, 1 /* Error */, "File_specification_cannot_end_in_a_recursive_directory_wildcard_Asterisk_Asterisk_Colon_0_5010", "File specification cannot end in a recursive directory wildcard ('**'): '{0}'."), @@ -107160,7 +89804,6 @@ ${lanes.join("\n")} Cannot_find_a_tsconfig_json_file_at_the_current_directory_Colon_0: diag(5081, 1 /* Error */, "Cannot_find_a_tsconfig_json_file_at_the_current_directory_Colon_0_5081", "Cannot find a tsconfig.json file at the current directory: {0}."), _0_could_be_instantiated_with_an_arbitrary_type_which_could_be_unrelated_to_1: diag(5082, 1 /* Error */, "_0_could_be_instantiated_with_an_arbitrary_type_which_could_be_unrelated_to_1_5082", "'{0}' could be instantiated with an arbitrary type which could be unrelated to '{1}'."), Cannot_read_file_0: diag(5083, 1 /* Error */, "Cannot_read_file_0_5083", "Cannot read file '{0}'."), - Tuple_members_must_all_have_names_or_all_not_have_names: diag(5084, 1 /* Error */, "Tuple_members_must_all_have_names_or_all_not_have_names_5084", "Tuple members must all have names or all not have names."), A_tuple_member_cannot_be_both_optional_and_rest: diag(5085, 1 /* Error */, "A_tuple_member_cannot_be_both_optional_and_rest_5085", "A tuple member cannot be both optional and rest."), A_labeled_tuple_element_is_declared_as_optional_with_a_question_mark_after_the_name_and_before_the_colon_rather_than_after_the_type: diag(5086, 1 /* Error */, "A_labeled_tuple_element_is_declared_as_optional_with_a_question_mark_after_the_name_and_before_the_c_5086", "A labeled tuple element is declared as optional with a question mark after the name and before the colon, rather than after the type."), A_labeled_tuple_element_is_declared_as_rest_with_a_before_the_name_rather_than_before_the_type: diag(5087, 1 /* Error */, "A_labeled_tuple_element_is_declared_as_rest_with_a_before_the_name_rather_than_before_the_type_5087", "A labeled tuple element is declared as rest with a '...' before the name, rather than before the type."), @@ -107183,6 +89826,8 @@ ${lanes.join("\n")} Use_0_instead: diag(5106, 3 /* Message */, "Use_0_instead_5106", "Use '{0}' instead."), Option_0_1_is_deprecated_and_will_stop_functioning_in_TypeScript_2_Specify_compilerOption_ignoreDeprecations_Colon_3_to_silence_this_error: diag(5107, 1 /* Error */, "Option_0_1_is_deprecated_and_will_stop_functioning_in_TypeScript_2_Specify_compilerOption_ignoreDepr_5107", `Option '{0}={1}' is deprecated and will stop functioning in TypeScript {2}. Specify compilerOption '"ignoreDeprecations": "{3}"' to silence this error.`), Option_0_1_has_been_removed_Please_remove_it_from_your_configuration: diag(5108, 1 /* Error */, "Option_0_1_has_been_removed_Please_remove_it_from_your_configuration_5108", "Option '{0}={1}' has been removed. Please remove it from your configuration."), + Option_moduleResolution_must_be_set_to_0_or_left_unspecified_when_option_module_is_set_to_1: diag(5109, 1 /* Error */, "Option_moduleResolution_must_be_set_to_0_or_left_unspecified_when_option_module_is_set_to_1_5109", "Option 'moduleResolution' must be set to '{0}' (or left unspecified) when option 'module' is set to '{1}'."), + Option_module_must_be_set_to_0_when_option_moduleResolution_is_set_to_1: diag(5110, 1 /* Error */, "Option_module_must_be_set_to_0_when_option_moduleResolution_is_set_to_1_5110", "Option 'module' must be set to '{0}' when option 'moduleResolution' is set to '{1}'."), Generates_a_sourcemap_for_each_corresponding_d_ts_file: diag(6e3, 3 /* Message */, "Generates_a_sourcemap_for_each_corresponding_d_ts_file_6000", "Generates a sourcemap for each corresponding '.d.ts' file."), Concatenate_and_emit_output_to_single_file: diag(6001, 3 /* Message */, "Concatenate_and_emit_output_to_single_file_6001", "Concatenate and emit output to single file."), Generates_corresponding_d_ts_file: diag(6002, 3 /* Message */, "Generates_corresponding_d_ts_file_6002", "Generates corresponding '.d.ts' file."), @@ -107563,6 +90208,8 @@ ${lanes.join("\n")} Resolved_under_condition_0: diag(6414, 3 /* Message */, "Resolved_under_condition_0_6414", "Resolved under condition '{0}'."), Failed_to_resolve_under_condition_0: diag(6415, 3 /* Message */, "Failed_to_resolve_under_condition_0_6415", "Failed to resolve under condition '{0}'."), Exiting_conditional_exports: diag(6416, 3 /* Message */, "Exiting_conditional_exports_6416", "Exiting conditional exports."), + Searching_all_ancestor_node_modules_directories_for_preferred_extensions_Colon_0: diag(6417, 3 /* Message */, "Searching_all_ancestor_node_modules_directories_for_preferred_extensions_Colon_0_6417", "Searching all ancestor node_modules directories for preferred extensions: {0}."), + Searching_all_ancestor_node_modules_directories_for_fallback_extensions_Colon_0: diag(6418, 3 /* Message */, "Searching_all_ancestor_node_modules_directories_for_fallback_extensions_Colon_0_6418", "Searching all ancestor node_modules directories for fallback extensions: {0}."), The_expected_type_comes_from_property_0_which_is_declared_here_on_type_1: diag(6500, 3 /* Message */, "The_expected_type_comes_from_property_0_which_is_declared_here_on_type_1_6500", "The expected type comes from property '{0}' which is declared here on type '{1}'"), The_expected_type_comes_from_this_index_signature: diag(6501, 3 /* Message */, "The_expected_type_comes_from_this_index_signature_6501", "The expected type comes from this index signature."), The_expected_type_comes_from_the_return_type_of_this_signature: diag(6502, 3 /* Message */, "The_expected_type_comes_from_the_return_type_of_this_signature_6502", "The expected type comes from the return type of this signature."), @@ -107801,6 +90448,7 @@ ${lanes.join("\n")} Parameter_modifiers_can_only_be_used_in_TypeScript_files: diag(8012, 1 /* Error */, "Parameter_modifiers_can_only_be_used_in_TypeScript_files_8012", "Parameter modifiers can only be used in TypeScript files."), Non_null_assertions_can_only_be_used_in_TypeScript_files: diag(8013, 1 /* Error */, "Non_null_assertions_can_only_be_used_in_TypeScript_files_8013", "Non-null assertions can only be used in TypeScript files."), Type_assertion_expressions_can_only_be_used_in_TypeScript_files: diag(8016, 1 /* Error */, "Type_assertion_expressions_can_only_be_used_in_TypeScript_files_8016", "Type assertion expressions can only be used in TypeScript files."), + Signature_declarations_can_only_be_used_in_TypeScript_files: diag(8017, 1 /* Error */, "Signature_declarations_can_only_be_used_in_TypeScript_files_8017", "Signature declarations can only be used in TypeScript files."), Report_errors_in_js_files: diag(8019, 3 /* Message */, "Report_errors_in_js_files_8019", "Report errors in .js files."), JSDoc_types_can_only_be_used_inside_documentation_comments: diag(8020, 1 /* Error */, "JSDoc_types_can_only_be_used_inside_documentation_comments_8020", "JSDoc types can only be used inside documentation comments."), JSDoc_typedef_tag_should_either_have_a_type_annotation_or_be_followed_by_property_or_member_tags: diag(8021, 1 /* Error */, "JSDoc_typedef_tag_should_either_have_a_type_annotation_or_be_followed_by_property_or_member_tags_8021", "JSDoc '@typedef' tag should either have a type annotation or be followed by '@property' or '@member' tags."), @@ -107844,6 +90492,7 @@ ${lanes.join("\n")} Unknown_type_acquisition_option_0_Did_you_mean_1: diag(17018, 1 /* Error */, "Unknown_type_acquisition_option_0_Did_you_mean_1_17018", "Unknown type acquisition option '{0}'. Did you mean '{1}'?"), _0_at_the_end_of_a_type_is_not_valid_TypeScript_syntax_Did_you_mean_to_write_1: diag(17019, 1 /* Error */, "_0_at_the_end_of_a_type_is_not_valid_TypeScript_syntax_Did_you_mean_to_write_1_17019", "'{0}' at the end of a type is not valid TypeScript syntax. Did you mean to write '{1}'?"), _0_at_the_start_of_a_type_is_not_valid_TypeScript_syntax_Did_you_mean_to_write_1: diag(17020, 1 /* Error */, "_0_at_the_start_of_a_type_is_not_valid_TypeScript_syntax_Did_you_mean_to_write_1_17020", "'{0}' at the start of a type is not valid TypeScript syntax. Did you mean to write '{1}'?"), + Unicode_escape_sequence_cannot_appear_here: diag(17021, 1 /* Error */, "Unicode_escape_sequence_cannot_appear_here_17021", "Unicode escape sequence cannot appear here."), Circularity_detected_while_resolving_configuration_Colon_0: diag(18e3, 1 /* Error */, "Circularity_detected_while_resolving_configuration_Colon_0_18000", "Circularity detected while resolving configuration: {0}"), The_files_list_in_config_file_0_is_empty: diag(18002, 1 /* Error */, "The_files_list_in_config_file_0_is_empty_18002", "The 'files' list in config file '{0}' is empty."), No_inputs_were_found_in_config_file_0_Specified_include_paths_were_1_and_exclude_paths_were_2: diag(18003, 1 /* Error */, "No_inputs_were_found_in_config_file_0_Specified_include_paths_were_1_and_exclude_paths_were_2_18003", "No inputs were found in config file '{0}'. Specified 'include' paths were '{1}' and 'exclude' paths were '{2}'."), @@ -108049,7 +90698,7 @@ ${lanes.join("\n")} Could_not_convert_to_arrow_function: diag(95151, 3 /* Message */, "Could_not_convert_to_arrow_function_95151", "Could not convert to arrow function"), Could_not_convert_to_named_function: diag(95152, 3 /* Message */, "Could_not_convert_to_named_function_95152", "Could not convert to named function"), Could_not_convert_to_anonymous_function: diag(95153, 3 /* Message */, "Could_not_convert_to_anonymous_function_95153", "Could not convert to anonymous function"), - Can_only_convert_string_concatenation: diag(95154, 3 /* Message */, "Can_only_convert_string_concatenation_95154", "Can only convert string concatenation"), + Can_only_convert_string_concatenations_and_string_literals: diag(95154, 3 /* Message */, "Can_only_convert_string_concatenations_and_string_literals_95154", "Can only convert string concatenations and string literals"), Selection_is_not_a_valid_statement_or_statements: diag(95155, 3 /* Message */, "Selection_is_not_a_valid_statement_or_statements_95155", "Selection is not a valid statement or statements"), Add_missing_function_declaration_0: diag(95156, 3 /* Message */, "Add_missing_function_declaration_0_95156", "Add missing function declaration '{0}'"), Add_all_missing_function_declarations: diag(95157, 3 /* Message */, "Add_all_missing_function_declarations_95157", "Add all missing function declarations"), @@ -108075,6 +90724,14 @@ ${lanes.join("\n")} Convert_all_typedef_to_TypeScript_types: diag(95177, 3 /* Message */, "Convert_all_typedef_to_TypeScript_types_95177", "Convert all typedef to TypeScript types."), Move_to_file: diag(95178, 3 /* Message */, "Move_to_file_95178", "Move to file"), Cannot_move_to_file_selected_file_is_invalid: diag(95179, 3 /* Message */, "Cannot_move_to_file_selected_file_is_invalid_95179", "Cannot move to file, selected file is invalid"), + Use_import_type: diag(95180, 3 /* Message */, "Use_import_type_95180", "Use 'import type'"), + Use_type_0: diag(95181, 3 /* Message */, "Use_type_0_95181", "Use 'type {0}'"), + Fix_all_with_type_only_imports: diag(95182, 3 /* Message */, "Fix_all_with_type_only_imports_95182", "Fix all with type-only imports"), + Cannot_move_statements_to_the_selected_file: diag(95183, 3 /* Message */, "Cannot_move_statements_to_the_selected_file_95183", "Cannot move statements to the selected file"), + Inline_variable: diag(95184, 3 /* Message */, "Inline_variable_95184", "Inline variable"), + Could_not_find_variable_to_inline: diag(95185, 3 /* Message */, "Could_not_find_variable_to_inline_95185", "Could not find variable to inline."), + Variables_with_multiple_declarations_cannot_be_inlined: diag(95186, 3 /* Message */, "Variables_with_multiple_declarations_cannot_be_inlined_95186", "Variables with multiple declarations cannot be inlined."), + Add_missing_comma_for_object_member_completion_0: diag(95187, 3 /* Message */, "Add_missing_comma_for_object_member_completion_0_95187", "Add missing comma for object member completion '{0}'."), No_value_exists_in_scope_for_the_shorthand_property_0_Either_declare_one_or_provide_an_initializer: diag(18004, 1 /* Error */, "No_value_exists_in_scope_for_the_shorthand_property_0_Either_declare_one_or_provide_an_initializer_18004", "No value exists in scope for the shorthand property '{0}'. Either declare one or provide an initializer."), Classes_may_not_have_a_field_named_constructor: diag(18006, 1 /* Error */, "Classes_may_not_have_a_field_named_constructor_18006", "Classes may not have a field named 'constructor'."), JSX_expressions_may_not_use_the_comma_operator_Did_you_mean_to_write_an_array: diag(18007, 1 /* Error */, "JSX_expressions_may_not_use_the_comma_operator_Did_you_mean_to_write_an_array_18007", "JSX expressions may not use the comma operator. Did you mean to write an array?"), @@ -108101,8 +90758,8 @@ ${lanes.join("\n")} Specify_the_JSX_fragment_factory_function_to_use_when_targeting_react_JSX_emit_with_jsxFactory_compiler_option_is_specified_e_g_Fragment: diag(18034, 3 /* Message */, "Specify_the_JSX_fragment_factory_function_to_use_when_targeting_react_JSX_emit_with_jsxFactory_compi_18034", "Specify the JSX fragment factory function to use when targeting 'react' JSX emit with 'jsxFactory' compiler option is specified, e.g. 'Fragment'."), Invalid_value_for_jsxFragmentFactory_0_is_not_a_valid_identifier_or_qualified_name: diag(18035, 1 /* Error */, "Invalid_value_for_jsxFragmentFactory_0_is_not_a_valid_identifier_or_qualified_name_18035", "Invalid value for 'jsxFragmentFactory'. '{0}' is not a valid identifier or qualified-name."), Class_decorators_can_t_be_used_with_static_private_identifier_Consider_removing_the_experimental_decorator: diag(18036, 1 /* Error */, "Class_decorators_can_t_be_used_with_static_private_identifier_Consider_removing_the_experimental_dec_18036", "Class decorators can't be used with static private identifier. Consider removing the experimental decorator."), - Await_expression_cannot_be_used_inside_a_class_static_block: diag(18037, 1 /* Error */, "Await_expression_cannot_be_used_inside_a_class_static_block_18037", "Await expression cannot be used inside a class static block."), - For_await_loops_cannot_be_used_inside_a_class_static_block: diag(18038, 1 /* Error */, "For_await_loops_cannot_be_used_inside_a_class_static_block_18038", "'For await' loops cannot be used inside a class static block."), + await_expression_cannot_be_used_inside_a_class_static_block: diag(18037, 1 /* Error */, "await_expression_cannot_be_used_inside_a_class_static_block_18037", "'await' expression cannot be used inside a class static block."), + for_await_loops_cannot_be_used_inside_a_class_static_block: diag(18038, 1 /* Error */, "for_await_loops_cannot_be_used_inside_a_class_static_block_18038", "'for await' loops cannot be used inside a class static block."), Invalid_use_of_0_It_cannot_be_used_inside_a_class_static_block: diag(18039, 1 /* Error */, "Invalid_use_of_0_It_cannot_be_used_inside_a_class_static_block_18039", "Invalid use of '{0}'. It cannot be used inside a class static block."), A_return_statement_cannot_be_used_inside_a_class_static_block: diag(18041, 1 /* Error */, "A_return_statement_cannot_be_used_inside_a_class_static_block_18041", "A 'return' statement cannot be used inside a class static block."), _0_is_a_type_and_cannot_be_imported_in_JavaScript_files_Use_1_in_a_JSDoc_type_annotation: diag(18042, 1 /* Error */, "_0_is_a_type_and_cannot_be_imported_in_JavaScript_files_Use_1_in_a_JSDoc_type_annotation_18042", "'{0}' is a type and cannot be imported in JavaScript files. Use '{1}' in a JSDoc type annotation."), @@ -108116,7 +90773,8 @@ ${lanes.join("\n")} The_value_0_cannot_be_used_here: diag(18050, 1 /* Error */, "The_value_0_cannot_be_used_here_18050", "The value '{0}' cannot be used here."), Compiler_option_0_cannot_be_given_an_empty_string: diag(18051, 1 /* Error */, "Compiler_option_0_cannot_be_given_an_empty_string_18051", "Compiler option '{0}' cannot be given an empty string."), Non_abstract_class_0_does_not_implement_all_abstract_members_of_1: diag(18052, 1 /* Error */, "Non_abstract_class_0_does_not_implement_all_abstract_members_of_1_18052", "Non-abstract class '{0}' does not implement all abstract members of '{1}'"), - Its_type_0_is_not_a_valid_JSX_element_type: diag(18053, 1 /* Error */, "Its_type_0_is_not_a_valid_JSX_element_type_18053", "Its type '{0}' is not a valid JSX element type.") + Its_type_0_is_not_a_valid_JSX_element_type: diag(18053, 1 /* Error */, "Its_type_0_is_not_a_valid_JSX_element_type_18053", "Its type '{0}' is not a valid JSX element type."), + await_using_statements_cannot_be_used_inside_a_class_static_block: diag(18054, 1 /* Error */, "await_using_statements_cannot_be_used_inside_a_class_static_block_18054", "'await using' statements cannot be used inside a class static block.") }; } }); @@ -108393,9 +91051,9 @@ ${lanes.join("\n")} } return false; } - function scanConflictMarkerTrivia(text, pos, error) { - if (error) { - error(Diagnostics.Merge_conflict_marker_encountered, pos, mergeConflictMarkerLength); + function scanConflictMarkerTrivia(text, pos, error2) { + if (error2) { + error2(Diagnostics.Merge_conflict_marker_encountered, pos, mergeConflictMarkerLength); } const ch = text.charCodeAt(pos); const len = text.length; @@ -108631,6 +91289,8 @@ ${lanes.join("\n")} var tokenFlags; var commentDirectives; var inJSDocType = 0; + var scriptKind = 0 /* Unknown */; + var jsDocParsingMode = 0 /* ParseAll */; setText(text, start, length2); var scanner2 = { getTokenFullStart: () => fullStartPos, @@ -108674,6 +91334,8 @@ ${lanes.join("\n")} setText, setScriptTarget, setLanguageVariant, + setScriptKind, + setJSDocParsingMode, setOnError, resetTokenState, setTextPos: resetTokenState, @@ -108691,7 +91353,7 @@ ${lanes.join("\n")} }); } return scanner2; - function error(message, errPos = pos, length3, arg0) { + function error2(message, errPos = pos, length3, arg0) { if (onError) { const oldPos = pos; pos = errPos; @@ -108715,9 +91377,9 @@ ${lanes.join("\n")} } else { tokenFlags |= 16384 /* ContainsInvalidSeparator */; if (isPreviousTokenSeparator) { - error(Diagnostics.Multiple_consecutive_numeric_separators_are_not_permitted, pos, 1); + error2(Diagnostics.Multiple_consecutive_numeric_separators_are_not_permitted, pos, 1); } else { - error(Diagnostics.Numeric_separators_are_not_allowed_here, pos, 1); + error2(Diagnostics.Numeric_separators_are_not_allowed_here, pos, 1); } } pos++; @@ -108734,7 +91396,7 @@ ${lanes.join("\n")} } if (text.charCodeAt(pos - 1) === 95 /* _ */) { tokenFlags |= 16384 /* ContainsInvalidSeparator */; - error(Diagnostics.Numeric_separators_are_not_allowed_here, pos - 1, 1); + error2(Diagnostics.Numeric_separators_are_not_allowed_here, pos - 1, 1); } return result + text.substring(start2, pos); } @@ -108745,7 +91407,7 @@ ${lanes.join("\n")} pos++; if (text.charCodeAt(pos) === 95 /* _ */) { tokenFlags |= 512 /* ContainsSeparator */ | 16384 /* ContainsInvalidSeparator */; - error(Diagnostics.Numeric_separators_are_not_allowed_here, pos, 1); + error2(Diagnostics.Numeric_separators_are_not_allowed_here, pos, 1); pos--; mainFragment = scanNumberFragment(); } else if (!scanDigits()) { @@ -108760,8 +91422,8 @@ ${lanes.join("\n")} const literal = (withMinus ? "-" : "") + "0o" + (+tokenValue).toString(8); if (withMinus) start2--; - error(Diagnostics.Octal_literals_are_not_allowed_Use_the_syntax_0, start2, pos - start2, literal); - return { type: 9 /* NumericLiteral */, value: tokenValue }; + error2(Diagnostics.Octal_literals_are_not_allowed_Use_the_syntax_0, start2, pos - start2, literal); + return 9 /* NumericLiteral */; } } else { mainFragment = scanNumberFragment(); @@ -108781,7 +91443,7 @@ ${lanes.join("\n")} const preNumericPart = pos; const finalFragment = scanNumberFragment(); if (!finalFragment) { - error(Diagnostics.Digit_expected); + error2(Diagnostics.Digit_expected); } else { scientificFragment = text.substring(end2, preNumericPart) + finalFragment; end2 = pos; @@ -108800,21 +91462,19 @@ ${lanes.join("\n")} result = text.substring(start2, end2); } if (tokenFlags & 8192 /* ContainsLeadingZero */) { - error(Diagnostics.Decimals_with_leading_zeros_are_not_allowed, start2, end2 - start2); - return { type: 9 /* NumericLiteral */, value: "" + +result }; + error2(Diagnostics.Decimals_with_leading_zeros_are_not_allowed, start2, end2 - start2); + tokenValue = "" + +result; + return 9 /* NumericLiteral */; } if (decimalFragment !== void 0 || tokenFlags & 16 /* Scientific */) { checkForIdentifierStartAfterNumericLiteral(start2, decimalFragment === void 0 && !!(tokenFlags & 16 /* Scientific */)); - return { - type: 9 /* NumericLiteral */, - value: "" + +result - // if value is not an integer, it can be safely coerced to a number - }; + tokenValue = "" + +result; + return 9 /* NumericLiteral */; } else { tokenValue = result; const type = checkBigIntSuffix(); checkForIdentifierStartAfterNumericLiteral(start2); - return { type, value: tokenValue }; + return type; } } function checkForIdentifierStartAfterNumericLiteral(numericStart, isScientific) { @@ -108825,12 +91485,12 @@ ${lanes.join("\n")} const { length: length3 } = scanIdentifierParts(); if (length3 === 1 && text[identifierStart] === "n") { if (isScientific) { - error(Diagnostics.A_bigint_literal_cannot_use_exponential_notation, numericStart, identifierStart - numericStart + 1); + error2(Diagnostics.A_bigint_literal_cannot_use_exponential_notation, numericStart, identifierStart - numericStart + 1); } else { - error(Diagnostics.A_bigint_literal_must_be_an_integer, numericStart, identifierStart - numericStart + 1); + error2(Diagnostics.A_bigint_literal_must_be_an_integer, numericStart, identifierStart - numericStart + 1); } } else { - error(Diagnostics.An_identifier_or_keyword_cannot_immediately_follow_a_numeric_literal, identifierStart, length3); + error2(Diagnostics.An_identifier_or_keyword_cannot_immediately_follow_a_numeric_literal, identifierStart, length3); pos = identifierStart; } } @@ -108877,9 +91537,9 @@ ${lanes.join("\n")} allowSeparator = false; isPreviousTokenSeparator = true; } else if (isPreviousTokenSeparator) { - error(Diagnostics.Multiple_consecutive_numeric_separators_are_not_permitted, pos, 1); + error2(Diagnostics.Multiple_consecutive_numeric_separators_are_not_permitted, pos, 1); } else { - error(Diagnostics.Numeric_separators_are_not_allowed_here, pos, 1); + error2(Diagnostics.Numeric_separators_are_not_allowed_here, pos, 1); } pos++; continue; @@ -108898,7 +91558,7 @@ ${lanes.join("\n")} valueChars = []; } if (text.charCodeAt(pos - 1) === 95 /* _ */) { - error(Diagnostics.Numeric_separators_are_not_allowed_here, pos - 1, 1); + error2(Diagnostics.Numeric_separators_are_not_allowed_here, pos - 1, 1); } return String.fromCharCode(...valueChars); } @@ -108911,7 +91571,7 @@ ${lanes.join("\n")} if (pos >= end) { result += text.substring(start2, pos); tokenFlags |= 4 /* Unterminated */; - error(Diagnostics.Unterminated_string_literal); + error2(Diagnostics.Unterminated_string_literal); break; } const ch = text.charCodeAt(pos); @@ -108929,10 +91589,10 @@ ${lanes.join("\n")} start2 = pos; continue; } - if (isLineBreak(ch) && !jsxAttributeString) { + if ((ch === 10 /* lineFeed */ || ch === 13 /* carriageReturn */) && !jsxAttributeString) { result += text.substring(start2, pos); tokenFlags |= 4 /* Unterminated */; - error(Diagnostics.Unterminated_string_literal); + error2(Diagnostics.Unterminated_string_literal); break; } pos++; @@ -108949,7 +91609,7 @@ ${lanes.join("\n")} if (pos >= end) { contents += text.substring(start2, pos); tokenFlags |= 4 /* Unterminated */; - error(Diagnostics.Unterminated_template_literal); + error2(Diagnostics.Unterminated_template_literal); resultingToken = startedWithBacktick ? 15 /* NoSubstitutionTemplateLiteral */ : 18 /* TemplateTail */; break; } @@ -108992,7 +91652,7 @@ ${lanes.join("\n")} const start2 = pos; pos++; if (pos >= end) { - error(Diagnostics.Unexpected_end_of_text); + error2(Diagnostics.Unexpected_end_of_text); return ""; } const ch = text.charCodeAt(pos); @@ -109018,7 +91678,7 @@ ${lanes.join("\n")} tokenFlags |= 2048 /* ContainsInvalidEscape */; if (shouldEmitInvalidEscapeError) { const code = parseInt(text.substring(start2 + 1, pos), 8); - error(Diagnostics.Octal_escape_sequences_are_not_allowed_Use_the_syntax_0, start2, pos - start2, "\\x" + padLeft(code.toString(16), 2, "0")); + error2(Diagnostics.Octal_escape_sequences_are_not_allowed_Use_the_syntax_0, start2, pos - start2, "\\x" + code.toString(16).padStart(2, "0")); return String.fromCharCode(code); } return text.substring(start2, pos); @@ -109026,7 +91686,7 @@ ${lanes.join("\n")} case 57 /* _9 */: tokenFlags |= 2048 /* ContainsInvalidEscape */; if (shouldEmitInvalidEscapeError) { - error(Diagnostics.Escape_sequence_0_is_not_allowed, start2, pos - start2, text.substring(start2, pos)); + error2(Diagnostics.Escape_sequence_0_is_not_allowed, start2, pos - start2, text.substring(start2, pos)); return String.fromCharCode(ch); } return text.substring(start2, pos); @@ -109058,28 +91718,28 @@ ${lanes.join("\n")} if (escapedValue < 0) { tokenFlags |= 2048 /* ContainsInvalidEscape */; if (shouldEmitInvalidEscapeError) { - error(Diagnostics.Hexadecimal_digit_expected); + error2(Diagnostics.Hexadecimal_digit_expected); } return text.substring(start2, pos); } if (!isCodePoint(escapedValue)) { tokenFlags |= 2048 /* ContainsInvalidEscape */; if (shouldEmitInvalidEscapeError) { - error(Diagnostics.An_extended_Unicode_escape_value_must_be_between_0x0_and_0x10FFFF_inclusive); + error2(Diagnostics.An_extended_Unicode_escape_value_must_be_between_0x0_and_0x10FFFF_inclusive); } return text.substring(start2, pos); } if (pos >= end) { tokenFlags |= 2048 /* ContainsInvalidEscape */; if (shouldEmitInvalidEscapeError) { - error(Diagnostics.Unexpected_end_of_text); + error2(Diagnostics.Unexpected_end_of_text); } return text.substring(start2, pos); } if (text.charCodeAt(pos) !== 125 /* closeBrace */) { tokenFlags |= 2048 /* ContainsInvalidEscape */; if (shouldEmitInvalidEscapeError) { - error(Diagnostics.Unterminated_Unicode_escape_sequence); + error2(Diagnostics.Unterminated_Unicode_escape_sequence); } return text.substring(start2, pos); } @@ -109091,7 +91751,7 @@ ${lanes.join("\n")} if (!(pos < end && isHexDigit(text.charCodeAt(pos)))) { tokenFlags |= 2048 /* ContainsInvalidEscape */; if (shouldEmitInvalidEscapeError) { - error(Diagnostics.Hexadecimal_digit_expected); + error2(Diagnostics.Hexadecimal_digit_expected); } return text.substring(start2, pos); } @@ -109103,7 +91763,7 @@ ${lanes.join("\n")} if (!(pos < end && isHexDigit(text.charCodeAt(pos)))) { tokenFlags |= 2048 /* ContainsInvalidEscape */; if (shouldEmitInvalidEscapeError) { - error(Diagnostics.Hexadecimal_digit_expected); + error2(Diagnostics.Hexadecimal_digit_expected); } return text.substring(start2, pos); } @@ -109131,19 +91791,19 @@ ${lanes.join("\n")} const escapedValue = escapedValueString ? parseInt(escapedValueString, 16) : -1; let isInvalidExtendedEscape = false; if (escapedValue < 0) { - error(Diagnostics.Hexadecimal_digit_expected); + error2(Diagnostics.Hexadecimal_digit_expected); isInvalidExtendedEscape = true; } else if (escapedValue > 1114111) { - error(Diagnostics.An_extended_Unicode_escape_value_must_be_between_0x0_and_0x10FFFF_inclusive); + error2(Diagnostics.An_extended_Unicode_escape_value_must_be_between_0x0_and_0x10FFFF_inclusive); isInvalidExtendedEscape = true; } if (pos >= end) { - error(Diagnostics.Unexpected_end_of_text); + error2(Diagnostics.Unexpected_end_of_text); isInvalidExtendedEscape = true; } else if (text.charCodeAt(pos) === 125 /* closeBrace */) { pos++; } else { - error(Diagnostics.Unterminated_Unicode_escape_sequence); + error2(Diagnostics.Unterminated_Unicode_escape_sequence); isInvalidExtendedEscape = true; } if (isInvalidExtendedEscape) { @@ -109237,9 +91897,9 @@ ${lanes.join("\n")} separatorAllowed = false; isPreviousTokenSeparator = true; } else if (isPreviousTokenSeparator) { - error(Diagnostics.Multiple_consecutive_numeric_separators_are_not_permitted, pos, 1); + error2(Diagnostics.Multiple_consecutive_numeric_separators_are_not_permitted, pos, 1); } else { - error(Diagnostics.Numeric_separators_are_not_allowed_here, pos, 1); + error2(Diagnostics.Numeric_separators_are_not_allowed_here, pos, 1); } pos++; continue; @@ -109253,7 +91913,7 @@ ${lanes.join("\n")} isPreviousTokenSeparator = false; } if (text.charCodeAt(pos - 1) === 95 /* _ */) { - error(Diagnostics.Numeric_separators_are_not_allowed_here, pos - 1, 1); + error2(Diagnostics.Numeric_separators_are_not_allowed_here, pos - 1, 1); } return value; } @@ -109283,7 +91943,7 @@ ${lanes.join("\n")} const ch = codePointAt(text, pos); if (pos === 0) { if (ch === 65533 /* replacementCharacter */) { - error(Diagnostics.File_appears_to_be_binary); + error2(Diagnostics.File_appears_to_be_binary); pos = end; return token = 8 /* NonTextFileMarkerTrivia */; } @@ -109423,7 +92083,7 @@ ${lanes.join("\n")} return token = 41 /* MinusToken */; case 46 /* dot */: if (isDigit(text.charCodeAt(pos + 1))) { - tokenValue = scanNumber().value; + scanNumber(); return token = 9 /* NumericLiteral */; } if (text.charCodeAt(pos + 1) === 46 /* dot */ && text.charCodeAt(pos + 2) === 46 /* dot */) { @@ -109454,9 +92114,7 @@ ${lanes.join("\n")} } if (text.charCodeAt(pos + 1) === 42 /* asterisk */) { pos += 2; - if (text.charCodeAt(pos) === 42 /* asterisk */ && text.charCodeAt(pos + 1) !== 47 /* slash */) { - tokenFlags |= 2 /* PrecedingJSDocComment */; - } + const isJSDoc2 = text.charCodeAt(pos) === 42 /* asterisk */ && text.charCodeAt(pos + 1) !== 47 /* slash */; let commentClosed = false; let lastLineStart = tokenStart; while (pos < end) { @@ -109472,9 +92130,12 @@ ${lanes.join("\n")} tokenFlags |= 1 /* PrecedingLineBreak */; } } + if (isJSDoc2 && shouldParseJSDoc()) { + tokenFlags |= 2 /* PrecedingJSDocComment */; + } commentDirectives = appendIfCommentDirective(commentDirectives, text.slice(lastLineStart, pos), commentDirectiveRegExMultiLine, lastLineStart); if (!commentClosed) { - error(Diagnostics.Asterisk_Slash_expected); + error2(Diagnostics.Asterisk_Slash_expected); } if (skipTrivia2) { continue; @@ -109499,7 +92160,7 @@ ${lanes.join("\n")} true ); if (!tokenValue) { - error(Diagnostics.Hexadecimal_digit_expected); + error2(Diagnostics.Hexadecimal_digit_expected); tokenValue = "0"; } tokenValue = "0x" + tokenValue; @@ -109512,7 +92173,7 @@ ${lanes.join("\n")} 2 ); if (!tokenValue) { - error(Diagnostics.Binary_digit_expected); + error2(Diagnostics.Binary_digit_expected); tokenValue = "0"; } tokenValue = "0b" + tokenValue; @@ -109525,7 +92186,7 @@ ${lanes.join("\n")} 8 ); if (!tokenValue) { - error(Diagnostics.Octal_digit_expected); + error2(Diagnostics.Octal_digit_expected); tokenValue = "0"; } tokenValue = "0o" + tokenValue; @@ -109541,8 +92202,7 @@ ${lanes.join("\n")} case 55 /* _7 */: case 56 /* _8 */: case 57 /* _9 */: - ({ type: token, value: tokenValue } = scanNumber()); - return token; + return token = scanNumber(); case 58 /* colon */: pos++; return token = 59 /* ColonToken */; @@ -109551,7 +92211,7 @@ ${lanes.join("\n")} return token = 27 /* SemicolonToken */; case 60 /* lessThan */: if (isConflictMarkerTrivia(text, pos)) { - pos = scanConflictMarkerTrivia(text, pos, error); + pos = scanConflictMarkerTrivia(text, pos, error2); if (skipTrivia2) { continue; } else { @@ -109574,7 +92234,7 @@ ${lanes.join("\n")} return token = 30 /* LessThanToken */; case 61 /* equals */: if (isConflictMarkerTrivia(text, pos)) { - pos = scanConflictMarkerTrivia(text, pos, error); + pos = scanConflictMarkerTrivia(text, pos, error2); if (skipTrivia2) { continue; } else { @@ -109594,7 +92254,7 @@ ${lanes.join("\n")} return token = 64 /* EqualsToken */; case 62 /* greaterThan */: if (isConflictMarkerTrivia(text, pos)) { - pos = scanConflictMarkerTrivia(text, pos, error); + pos = scanConflictMarkerTrivia(text, pos, error2); if (skipTrivia2) { continue; } else { @@ -109632,7 +92292,7 @@ ${lanes.join("\n")} return token = 19 /* OpenBraceToken */; case 124 /* bar */: if (isConflictMarkerTrivia(text, pos)) { - pos = scanConflictMarkerTrivia(text, pos, error); + pos = scanConflictMarkerTrivia(text, pos, error2); if (skipTrivia2) { continue; } else { @@ -109674,12 +92334,12 @@ ${lanes.join("\n")} tokenValue = String.fromCharCode(cookedChar) + scanIdentifierParts(); return token = getIdentifierToken(); } - error(Diagnostics.Invalid_character); + error2(Diagnostics.Invalid_character); pos++; return token = 0 /* Unknown */; case 35 /* hash */: if (pos !== 0 && text[pos + 1] === "!") { - error(Diagnostics.can_only_be_used_at_the_start_of_a_file); + error2(Diagnostics.can_only_be_used_at_the_start_of_a_file); pos++; return token = 0 /* Unknown */; } @@ -109707,7 +92367,7 @@ ${lanes.join("\n")} scanIdentifier(charAfterHash, languageVersion); } else { tokenValue = "#"; - error(Diagnostics.Invalid_character, pos++, charSize(ch)); + error2(Diagnostics.Invalid_character, pos++, charSize(ch)); } return token = 81 /* PrivateIdentifier */; default: @@ -109723,12 +92383,27 @@ ${lanes.join("\n")} continue; } const size = charSize(ch); - error(Diagnostics.Invalid_character, pos, size); + error2(Diagnostics.Invalid_character, pos, size); pos += size; return token = 0 /* Unknown */; } } } + function shouldParseJSDoc() { + switch (jsDocParsingMode) { + case 0 /* ParseAll */: + return true; + case 1 /* ParseNone */: + return false; + } + if (scriptKind !== 3 /* TS */ && scriptKind !== 4 /* TSX */) { + return true; + } + if (jsDocParsingMode === 3 /* ParseForTypeInfo */) { + return false; + } + return jsDocSeeOrLink.test(text.slice(fullStartPos, pos)); + } function reScanInvalidIdentifier() { Debug.assert(token === 0 /* Unknown */, "'reScanInvalidIdentifier' should only be called when the current token is 'SyntaxKind.Unknown'."); pos = tokenStart = fullStartPos; @@ -109789,13 +92464,13 @@ ${lanes.join("\n")} while (true) { if (p >= end) { tokenFlags |= 4 /* Unterminated */; - error(Diagnostics.Unterminated_regular_expression_literal); + error2(Diagnostics.Unterminated_regular_expression_literal); break; } const ch = text.charCodeAt(p); if (isLineBreak(ch)) { tokenFlags |= 4 /* Unterminated */; - error(Diagnostics.Unterminated_regular_expression_literal); + error2(Diagnostics.Unterminated_regular_expression_literal); break; } if (inEscape) { @@ -109822,7 +92497,7 @@ ${lanes.join("\n")} return token; } function appendIfCommentDirective(commentDirectives2, text2, commentDirectiveRegEx, lineStart) { - const type = getDirectiveFromComment(trimStringStart(text2), commentDirectiveRegEx); + const type = getDirectiveFromComment(text2.trimStart(), commentDirectiveRegEx); if (type === void 0) { return commentDirectives2; } @@ -109907,16 +92582,16 @@ ${lanes.join("\n")} } if (char === 60 /* lessThan */) { if (isConflictMarkerTrivia(text, pos)) { - pos = scanConflictMarkerTrivia(text, pos, error); + pos = scanConflictMarkerTrivia(text, pos, error2); return token = 7 /* ConflictMarkerTrivia */; } break; } if (char === 62 /* greaterThan */) { - error(Diagnostics.Unexpected_token_Did_you_mean_or_gt, pos, 1); + error2(Diagnostics.Unexpected_token_Did_you_mean_or_gt, pos, 1); } if (char === 125 /* closeBrace */) { - error(Diagnostics.Unexpected_token_Did_you_mean_or_rbrace, pos, 1); + error2(Diagnostics.Unexpected_token_Did_you_mean_or_rbrace, pos, 1); } if (isLineBreak(char) && firstNonWhitespace === 0) { firstNonWhitespace = -1; @@ -110143,6 +92818,12 @@ ${lanes.join("\n")} function setLanguageVariant(variant) { languageVariant = variant; } + function setScriptKind(kind) { + scriptKind = kind; + } + function setJSDocParsingMode(kind) { + jsDocParsingMode = kind; + } function resetTokenState(position) { Debug.assert(position >= 0); pos = position; @@ -110156,6 +92837,9 @@ ${lanes.join("\n")} inJSDocType += inType ? 1 : -1; } } + function codePointAt(s, i) { + return s.codePointAt(i); + } function charSize(ch) { if (ch >= 65536) { return 2; @@ -110174,7 +92858,7 @@ ${lanes.join("\n")} function utf16EncodeAsString(codePoint) { return utf16EncodeAsStringWorker(codePoint); } - var textToKeywordObj, textToKeyword, textToToken, unicodeES3IdentifierStart, unicodeES3IdentifierPart, unicodeES5IdentifierStart, unicodeES5IdentifierPart, unicodeESNextIdentifierStart, unicodeESNextIdentifierPart, commentDirectiveRegExSingleLine, commentDirectiveRegExMultiLine, tokenStrings, mergeConflictMarkerLength, shebangTriviaRegex, codePointAt, utf16EncodeAsStringWorker; + var textToKeywordObj, textToKeyword, textToToken, unicodeES3IdentifierStart, unicodeES3IdentifierPart, unicodeES5IdentifierStart, unicodeES5IdentifierPart, unicodeESNextIdentifierStart, unicodeESNextIdentifierPart, commentDirectiveRegExSingleLine, commentDirectiveRegExMultiLine, jsDocSeeOrLink, tokenStrings, mergeConflictMarkerLength, shebangTriviaRegex, utf16EncodeAsStringWorker; var init_scanner = __esm({ "src/compiler/scanner.ts"() { "use strict"; @@ -110186,7 +92870,7 @@ ${lanes.join("\n")} as: 130 /* AsKeyword */, asserts: 131 /* AssertsKeyword */, assert: 132 /* AssertKeyword */, - bigint: 162 /* BigIntKeyword */, + bigint: 163 /* BigIntKeyword */, boolean: 136 /* BooleanKeyword */, break: 83 /* BreakKeyword */, case: 84 /* CaseKeyword */, @@ -110207,7 +92891,7 @@ ${lanes.join("\n")} false: 97 /* FalseKeyword */, finally: 98 /* FinallyKeyword */, for: 99 /* ForKeyword */, - from: 160 /* FromKeyword */, + from: 161 /* FromKeyword */, function: 100 /* FunctionKeyword */, get: 139 /* GetKeyword */, if: 101 /* IfKeyword */, @@ -110232,11 +92916,11 @@ ${lanes.join("\n")} private: 123 /* PrivateKeyword */, protected: 124 /* ProtectedKeyword */, public: 125 /* PublicKeyword */, - override: 163 /* OverrideKeyword */, + override: 164 /* OverrideKeyword */, out: 147 /* OutKeyword */, readonly: 148 /* ReadonlyKeyword */, require: 149 /* RequireKeyword */, - global: 161 /* GlobalKeyword */, + global: 162 /* GlobalKeyword */, return: 107 /* ReturnKeyword */, satisfies: 152 /* SatisfiesKeyword */, set: 153 /* SetKeyword */, @@ -110254,6 +92938,7 @@ ${lanes.join("\n")} undefined: 157 /* UndefinedKeyword */, unique: 158 /* UniqueKeyword */, unknown: 159 /* UnknownKeyword */, + using: 160 /* UsingKeyword */, var: 115 /* VarKeyword */, void: 116 /* VoidKeyword */, while: 117 /* WhileKeyword */, @@ -110261,7 +92946,7 @@ ${lanes.join("\n")} yield: 127 /* YieldKeyword */, async: 134 /* AsyncKeyword */, await: 135 /* AwaitKeyword */, - of: 164 /* OfKeyword */ + of: 165 /* OfKeyword */ }; textToKeyword = new Map(Object.entries(textToKeywordObj)); textToToken = new Map(Object.entries({ @@ -110336,23 +93021,10 @@ ${lanes.join("\n")} unicodeESNextIdentifierPart = [48, 57, 65, 90, 95, 95, 97, 122, 170, 170, 181, 181, 183, 183, 186, 186, 192, 214, 216, 246, 248, 705, 710, 721, 736, 740, 748, 748, 750, 750, 768, 884, 886, 887, 890, 893, 895, 895, 902, 906, 908, 908, 910, 929, 931, 1013, 1015, 1153, 1155, 1159, 1162, 1327, 1329, 1366, 1369, 1369, 1376, 1416, 1425, 1469, 1471, 1471, 1473, 1474, 1476, 1477, 1479, 1479, 1488, 1514, 1519, 1522, 1552, 1562, 1568, 1641, 1646, 1747, 1749, 1756, 1759, 1768, 1770, 1788, 1791, 1791, 1808, 1866, 1869, 1969, 1984, 2037, 2042, 2042, 2045, 2045, 2048, 2093, 2112, 2139, 2144, 2154, 2208, 2228, 2230, 2237, 2259, 2273, 2275, 2403, 2406, 2415, 2417, 2435, 2437, 2444, 2447, 2448, 2451, 2472, 2474, 2480, 2482, 2482, 2486, 2489, 2492, 2500, 2503, 2504, 2507, 2510, 2519, 2519, 2524, 2525, 2527, 2531, 2534, 2545, 2556, 2556, 2558, 2558, 2561, 2563, 2565, 2570, 2575, 2576, 2579, 2600, 2602, 2608, 2610, 2611, 2613, 2614, 2616, 2617, 2620, 2620, 2622, 2626, 2631, 2632, 2635, 2637, 2641, 2641, 2649, 2652, 2654, 2654, 2662, 2677, 2689, 2691, 2693, 2701, 2703, 2705, 2707, 2728, 2730, 2736, 2738, 2739, 2741, 2745, 2748, 2757, 2759, 2761, 2763, 2765, 2768, 2768, 2784, 2787, 2790, 2799, 2809, 2815, 2817, 2819, 2821, 2828, 2831, 2832, 2835, 2856, 2858, 2864, 2866, 2867, 2869, 2873, 2876, 2884, 2887, 2888, 2891, 2893, 2902, 2903, 2908, 2909, 2911, 2915, 2918, 2927, 2929, 2929, 2946, 2947, 2949, 2954, 2958, 2960, 2962, 2965, 2969, 2970, 2972, 2972, 2974, 2975, 2979, 2980, 2984, 2986, 2990, 3001, 3006, 3010, 3014, 3016, 3018, 3021, 3024, 3024, 3031, 3031, 3046, 3055, 3072, 3084, 3086, 3088, 3090, 3112, 3114, 3129, 3133, 3140, 3142, 3144, 3146, 3149, 3157, 3158, 3160, 3162, 3168, 3171, 3174, 3183, 3200, 3203, 3205, 3212, 3214, 3216, 3218, 3240, 3242, 3251, 3253, 3257, 3260, 3268, 3270, 3272, 3274, 3277, 3285, 3286, 3294, 3294, 3296, 3299, 3302, 3311, 3313, 3314, 3328, 3331, 3333, 3340, 3342, 3344, 3346, 3396, 3398, 3400, 3402, 3406, 3412, 3415, 3423, 3427, 3430, 3439, 3450, 3455, 3458, 3459, 3461, 3478, 3482, 3505, 3507, 3515, 3517, 3517, 3520, 3526, 3530, 3530, 3535, 3540, 3542, 3542, 3544, 3551, 3558, 3567, 3570, 3571, 3585, 3642, 3648, 3662, 3664, 3673, 3713, 3714, 3716, 3716, 3718, 3722, 3724, 3747, 3749, 3749, 3751, 3773, 3776, 3780, 3782, 3782, 3784, 3789, 3792, 3801, 3804, 3807, 3840, 3840, 3864, 3865, 3872, 3881, 3893, 3893, 3895, 3895, 3897, 3897, 3902, 3911, 3913, 3948, 3953, 3972, 3974, 3991, 3993, 4028, 4038, 4038, 4096, 4169, 4176, 4253, 4256, 4293, 4295, 4295, 4301, 4301, 4304, 4346, 4348, 4680, 4682, 4685, 4688, 4694, 4696, 4696, 4698, 4701, 4704, 4744, 4746, 4749, 4752, 4784, 4786, 4789, 4792, 4798, 4800, 4800, 4802, 4805, 4808, 4822, 4824, 4880, 4882, 4885, 4888, 4954, 4957, 4959, 4969, 4977, 4992, 5007, 5024, 5109, 5112, 5117, 5121, 5740, 5743, 5759, 5761, 5786, 5792, 5866, 5870, 5880, 5888, 5900, 5902, 5908, 5920, 5940, 5952, 5971, 5984, 5996, 5998, 6e3, 6002, 6003, 6016, 6099, 6103, 6103, 6108, 6109, 6112, 6121, 6155, 6157, 6160, 6169, 6176, 6264, 6272, 6314, 6320, 6389, 6400, 6430, 6432, 6443, 6448, 6459, 6470, 6509, 6512, 6516, 6528, 6571, 6576, 6601, 6608, 6618, 6656, 6683, 6688, 6750, 6752, 6780, 6783, 6793, 6800, 6809, 6823, 6823, 6832, 6845, 6912, 6987, 6992, 7001, 7019, 7027, 7040, 7155, 7168, 7223, 7232, 7241, 7245, 7293, 7296, 7304, 7312, 7354, 7357, 7359, 7376, 7378, 7380, 7418, 7424, 7673, 7675, 7957, 7960, 7965, 7968, 8005, 8008, 8013, 8016, 8023, 8025, 8025, 8027, 8027, 8029, 8029, 8031, 8061, 8064, 8116, 8118, 8124, 8126, 8126, 8130, 8132, 8134, 8140, 8144, 8147, 8150, 8155, 8160, 8172, 8178, 8180, 8182, 8188, 8255, 8256, 8276, 8276, 8305, 8305, 8319, 8319, 8336, 8348, 8400, 8412, 8417, 8417, 8421, 8432, 8450, 8450, 8455, 8455, 8458, 8467, 8469, 8469, 8472, 8477, 8484, 8484, 8486, 8486, 8488, 8488, 8490, 8505, 8508, 8511, 8517, 8521, 8526, 8526, 8544, 8584, 11264, 11310, 11312, 11358, 11360, 11492, 11499, 11507, 11520, 11557, 11559, 11559, 11565, 11565, 11568, 11623, 11631, 11631, 11647, 11670, 11680, 11686, 11688, 11694, 11696, 11702, 11704, 11710, 11712, 11718, 11720, 11726, 11728, 11734, 11736, 11742, 11744, 11775, 12293, 12295, 12321, 12335, 12337, 12341, 12344, 12348, 12353, 12438, 12441, 12447, 12449, 12538, 12540, 12543, 12549, 12591, 12593, 12686, 12704, 12730, 12784, 12799, 13312, 19893, 19968, 40943, 40960, 42124, 42192, 42237, 42240, 42508, 42512, 42539, 42560, 42607, 42612, 42621, 42623, 42737, 42775, 42783, 42786, 42888, 42891, 42943, 42946, 42950, 42999, 43047, 43072, 43123, 43136, 43205, 43216, 43225, 43232, 43255, 43259, 43259, 43261, 43309, 43312, 43347, 43360, 43388, 43392, 43456, 43471, 43481, 43488, 43518, 43520, 43574, 43584, 43597, 43600, 43609, 43616, 43638, 43642, 43714, 43739, 43741, 43744, 43759, 43762, 43766, 43777, 43782, 43785, 43790, 43793, 43798, 43808, 43814, 43816, 43822, 43824, 43866, 43868, 43879, 43888, 44010, 44012, 44013, 44016, 44025, 44032, 55203, 55216, 55238, 55243, 55291, 63744, 64109, 64112, 64217, 64256, 64262, 64275, 64279, 64285, 64296, 64298, 64310, 64312, 64316, 64318, 64318, 64320, 64321, 64323, 64324, 64326, 64433, 64467, 64829, 64848, 64911, 64914, 64967, 65008, 65019, 65024, 65039, 65056, 65071, 65075, 65076, 65101, 65103, 65136, 65140, 65142, 65276, 65296, 65305, 65313, 65338, 65343, 65343, 65345, 65370, 65382, 65470, 65474, 65479, 65482, 65487, 65490, 65495, 65498, 65500, 65536, 65547, 65549, 65574, 65576, 65594, 65596, 65597, 65599, 65613, 65616, 65629, 65664, 65786, 65856, 65908, 66045, 66045, 66176, 66204, 66208, 66256, 66272, 66272, 66304, 66335, 66349, 66378, 66384, 66426, 66432, 66461, 66464, 66499, 66504, 66511, 66513, 66517, 66560, 66717, 66720, 66729, 66736, 66771, 66776, 66811, 66816, 66855, 66864, 66915, 67072, 67382, 67392, 67413, 67424, 67431, 67584, 67589, 67592, 67592, 67594, 67637, 67639, 67640, 67644, 67644, 67647, 67669, 67680, 67702, 67712, 67742, 67808, 67826, 67828, 67829, 67840, 67861, 67872, 67897, 67968, 68023, 68030, 68031, 68096, 68099, 68101, 68102, 68108, 68115, 68117, 68119, 68121, 68149, 68152, 68154, 68159, 68159, 68192, 68220, 68224, 68252, 68288, 68295, 68297, 68326, 68352, 68405, 68416, 68437, 68448, 68466, 68480, 68497, 68608, 68680, 68736, 68786, 68800, 68850, 68864, 68903, 68912, 68921, 69376, 69404, 69415, 69415, 69424, 69456, 69600, 69622, 69632, 69702, 69734, 69743, 69759, 69818, 69840, 69864, 69872, 69881, 69888, 69940, 69942, 69951, 69956, 69958, 69968, 70003, 70006, 70006, 70016, 70084, 70089, 70092, 70096, 70106, 70108, 70108, 70144, 70161, 70163, 70199, 70206, 70206, 70272, 70278, 70280, 70280, 70282, 70285, 70287, 70301, 70303, 70312, 70320, 70378, 70384, 70393, 70400, 70403, 70405, 70412, 70415, 70416, 70419, 70440, 70442, 70448, 70450, 70451, 70453, 70457, 70459, 70468, 70471, 70472, 70475, 70477, 70480, 70480, 70487, 70487, 70493, 70499, 70502, 70508, 70512, 70516, 70656, 70730, 70736, 70745, 70750, 70751, 70784, 70853, 70855, 70855, 70864, 70873, 71040, 71093, 71096, 71104, 71128, 71133, 71168, 71232, 71236, 71236, 71248, 71257, 71296, 71352, 71360, 71369, 71424, 71450, 71453, 71467, 71472, 71481, 71680, 71738, 71840, 71913, 71935, 71935, 72096, 72103, 72106, 72151, 72154, 72161, 72163, 72164, 72192, 72254, 72263, 72263, 72272, 72345, 72349, 72349, 72384, 72440, 72704, 72712, 72714, 72758, 72760, 72768, 72784, 72793, 72818, 72847, 72850, 72871, 72873, 72886, 72960, 72966, 72968, 72969, 72971, 73014, 73018, 73018, 73020, 73021, 73023, 73031, 73040, 73049, 73056, 73061, 73063, 73064, 73066, 73102, 73104, 73105, 73107, 73112, 73120, 73129, 73440, 73462, 73728, 74649, 74752, 74862, 74880, 75075, 77824, 78894, 82944, 83526, 92160, 92728, 92736, 92766, 92768, 92777, 92880, 92909, 92912, 92916, 92928, 92982, 92992, 92995, 93008, 93017, 93027, 93047, 93053, 93071, 93760, 93823, 93952, 94026, 94031, 94087, 94095, 94111, 94176, 94177, 94179, 94179, 94208, 100343, 100352, 101106, 110592, 110878, 110928, 110930, 110948, 110951, 110960, 111355, 113664, 113770, 113776, 113788, 113792, 113800, 113808, 113817, 113821, 113822, 119141, 119145, 119149, 119154, 119163, 119170, 119173, 119179, 119210, 119213, 119362, 119364, 119808, 119892, 119894, 119964, 119966, 119967, 119970, 119970, 119973, 119974, 119977, 119980, 119982, 119993, 119995, 119995, 119997, 120003, 120005, 120069, 120071, 120074, 120077, 120084, 120086, 120092, 120094, 120121, 120123, 120126, 120128, 120132, 120134, 120134, 120138, 120144, 120146, 120485, 120488, 120512, 120514, 120538, 120540, 120570, 120572, 120596, 120598, 120628, 120630, 120654, 120656, 120686, 120688, 120712, 120714, 120744, 120746, 120770, 120772, 120779, 120782, 120831, 121344, 121398, 121403, 121452, 121461, 121461, 121476, 121476, 121499, 121503, 121505, 121519, 122880, 122886, 122888, 122904, 122907, 122913, 122915, 122916, 122918, 122922, 123136, 123180, 123184, 123197, 123200, 123209, 123214, 123214, 123584, 123641, 124928, 125124, 125136, 125142, 125184, 125259, 125264, 125273, 126464, 126467, 126469, 126495, 126497, 126498, 126500, 126500, 126503, 126503, 126505, 126514, 126516, 126519, 126521, 126521, 126523, 126523, 126530, 126530, 126535, 126535, 126537, 126537, 126539, 126539, 126541, 126543, 126545, 126546, 126548, 126548, 126551, 126551, 126553, 126553, 126555, 126555, 126557, 126557, 126559, 126559, 126561, 126562, 126564, 126564, 126567, 126570, 126572, 126578, 126580, 126583, 126585, 126588, 126590, 126590, 126592, 126601, 126603, 126619, 126625, 126627, 126629, 126633, 126635, 126651, 131072, 173782, 173824, 177972, 177984, 178205, 178208, 183969, 183984, 191456, 194560, 195101, 917760, 917999]; commentDirectiveRegExSingleLine = /^\/\/\/?\s*@(ts-expect-error|ts-ignore)/; commentDirectiveRegExMultiLine = /^(?:\/|\*)*\s*@(ts-expect-error|ts-ignore)/; + jsDocSeeOrLink = /@(?:see|link)/i; tokenStrings = makeReverseMap(textToToken); mergeConflictMarkerLength = "<<<<<<<".length; shebangTriviaRegex = /^#!.*/; - codePointAt = String.prototype.codePointAt ? (s, i) => s.codePointAt(i) : function codePointAt2(str, i) { - const size = str.length; - if (i < 0 || i >= size) { - return void 0; - } - const first2 = str.charCodeAt(i); - if (first2 >= 55296 && first2 <= 56319 && size > i + 1) { - const second = str.charCodeAt(i + 1); - if (second >= 56320 && second <= 57343) { - return (first2 - 55296) * 1024 + second - 56320 + 65536; - } - } - return first2; - }; utf16EncodeAsStringWorker = String.fromCodePoint ? (codePoint) => String.fromCodePoint(codePoint) : utf16EncodeAsStringFallback; } }); @@ -110483,16 +93155,16 @@ ${lanes.join("\n")} ); } function getTypeParameterOwner(d) { - if (d && d.kind === 167 /* TypeParameter */) { + if (d && d.kind === 168 /* TypeParameter */) { for (let current = d; current; current = current.parent) { - if (isFunctionLike(current) || isClassLike(current) || current.kind === 263 /* InterfaceDeclaration */) { + if (isFunctionLike(current) || isClassLike(current) || current.kind === 264 /* InterfaceDeclaration */) { return current; } } } } function isParameterPropertyDeclaration(node, parent2) { - return isParameter(node) && hasSyntacticModifier(node, 16476 /* ParameterPropertyModifier */) && parent2.kind === 175 /* Constructor */; + return isParameter(node) && hasSyntacticModifier(node, 31 /* ParameterPropertyModifier */) && parent2.kind === 176 /* Constructor */; } function isEmptyBindingPattern(node) { if (isBindingPattern(node)) { @@ -110518,14 +93190,14 @@ ${lanes.join("\n")} node = walkUpBindingElementsAndPatterns(node); } let flags = getFlags(node); - if (node.kind === 259 /* VariableDeclaration */) { + if (node.kind === 260 /* VariableDeclaration */) { node = node.parent; } - if (node && node.kind === 260 /* VariableDeclarationList */) { + if (node && node.kind === 261 /* VariableDeclarationList */) { flags |= getFlags(node); node = node.parent; } - if (node && node.kind === 242 /* VariableStatement */) { + if (node && node.kind === 243 /* VariableStatement */) { flags |= getFlags(node); } return flags; @@ -110537,11 +93209,14 @@ ${lanes.join("\n")} return getCombinedFlags(node, getEffectiveModifierFlagsAlwaysIncludeJSDoc); } function getCombinedNodeFlags(node) { - return getCombinedFlags(node, (n) => n.flags); + return getCombinedFlags(node, getNodeFlags); + } + function getNodeFlags(node) { + return node.flags; } function validateLocaleAndSetLanguage(locale, sys2, errors) { const lowerCaseLocale = locale.toLowerCase(); - const matchResult = /^([a-z]+)([_\-]([a-z]+))?$/.exec(lowerCaseLocale); + const matchResult = /^([a-z]+)([_-]([a-z]+))?$/.exec(lowerCaseLocale); if (!matchResult) { if (errors) { errors.push(createCompilerDiagnostic(Diagnostics.Locale_must_be_of_the_form_language_or_language_territory_For_example_0_or_1, "en", "ja-jp")); @@ -110614,7 +93289,7 @@ ${lanes.join("\n")} return void 0; } function isParseTreeNode(node) { - return (node.flags & 8 /* Synthesized */) === 0; + return (node.flags & 16 /* Synthesized */) === 0; } function getParseTreeNode(node, nodeTest) { if (node === void 0 || isParseTreeNode(node)) { @@ -110657,30 +93332,30 @@ ${lanes.join("\n")} return getDeclarationIdentifier(hostNode); } switch (hostNode.kind) { - case 242 /* VariableStatement */: + case 243 /* VariableStatement */: if (hostNode.declarationList && hostNode.declarationList.declarations[0]) { return getDeclarationIdentifier(hostNode.declarationList.declarations[0]); } break; - case 243 /* ExpressionStatement */: + case 244 /* ExpressionStatement */: let expr = hostNode.expression; - if (expr.kind === 225 /* BinaryExpression */ && expr.operatorToken.kind === 64 /* EqualsToken */) { + if (expr.kind === 226 /* BinaryExpression */ && expr.operatorToken.kind === 64 /* EqualsToken */) { expr = expr.left; } switch (expr.kind) { - case 210 /* PropertyAccessExpression */: + case 211 /* PropertyAccessExpression */: return expr.name; - case 211 /* ElementAccessExpression */: + case 212 /* ElementAccessExpression */: const arg = expr.argumentExpression; if (isIdentifier(arg)) { return arg; } } break; - case 216 /* ParenthesizedExpression */: { + case 217 /* ParenthesizedExpression */: { return getDeclarationIdentifier(hostNode.expression); } - case 255 /* LabeledStatement */: { + case 256 /* LabeledStatement */: { if (isDeclaration(hostNode.statement) || isExpression(hostNode.statement)) { return getDeclarationIdentifier(hostNode.statement); } @@ -110711,16 +93386,16 @@ ${lanes.join("\n")} switch (declaration.kind) { case 80 /* Identifier */: return declaration; - case 354 /* JSDocPropertyTag */: - case 347 /* JSDocParameterTag */: { + case 355 /* JSDocPropertyTag */: + case 348 /* JSDocParameterTag */: { const { name } = declaration; - if (name.kind === 165 /* QualifiedName */) { + if (name.kind === 166 /* QualifiedName */) { return name.right; } break; } - case 212 /* CallExpression */: - case 225 /* BinaryExpression */: { + case 213 /* CallExpression */: + case 226 /* BinaryExpression */: { const expr2 = declaration; switch (getAssignmentDeclarationKind(expr2)) { case 1 /* ExportsProperty */: @@ -110736,15 +93411,15 @@ ${lanes.join("\n")} return void 0; } } - case 352 /* JSDocTypedefTag */: + case 353 /* JSDocTypedefTag */: return getNameOfJSDocTypedef(declaration); - case 346 /* JSDocEnumTag */: + case 347 /* JSDocEnumTag */: return nameForNamelessJSDocTypedef(declaration); - case 276 /* ExportAssignment */: { + case 277 /* ExportAssignment */: { const { expression } = declaration; return isIdentifier(expression) ? expression : void 0; } - case 211 /* ElementAccessExpression */: + case 212 /* ElementAccessExpression */: const expr = declaration; if (isBindableStaticElementAccessExpression(expr)) { return expr.argumentExpression; @@ -110778,7 +93453,7 @@ ${lanes.join("\n")} } } function getModifiers(node) { - if (hasSyntacticModifier(node, 126975 /* Modifier */)) { + if (hasSyntacticModifier(node, 98303 /* Modifier */)) { return filter(node.modifiers, isModifier); } } @@ -110991,10 +93666,10 @@ ${lanes.join("\n")} return getJSDocTags(node).filter((doc) => doc.kind === kind); } function getTextOfJSDocComment(comment) { - return typeof comment === "string" ? comment : comment == null ? void 0 : comment.map((c) => c.kind === 327 /* JSDocText */ ? c.text : formatJSDocLink(c)).join(""); + return typeof comment === "string" ? comment : comment == null ? void 0 : comment.map((c) => c.kind === 328 /* JSDocText */ ? c.text : formatJSDocLink(c)).join(""); } function formatJSDocLink(link) { - const kind = link.kind === 330 /* JSDocLink */ ? "link" : link.kind === 331 /* JSDocLinkCode */ ? "linkcode" : "linkplain"; + const kind = link.kind === 331 /* JSDocLink */ ? "link" : link.kind === 332 /* JSDocLinkCode */ ? "linkcode" : "linkplain"; const name = link.name ? entityNameToString(link.name) : ""; const space = link.name && link.text.startsWith("://") ? "" : " "; return `{@${kind} ${name}${space}${link.text}}`; @@ -111010,7 +93685,7 @@ ${lanes.join("\n")} return emptyArray; } if (isJSDocTypeAlias(node)) { - Debug.assert(node.parent.kind === 326 /* JSDoc */); + Debug.assert(node.parent.kind === 327 /* JSDoc */); return flatMap(node.parent.tags, (tag) => isJSDocTemplateTag(tag) ? tag.typeParameters : void 0); } if (node.typeParameters) { @@ -111038,20 +93713,20 @@ ${lanes.join("\n")} return node.kind === 80 /* Identifier */ || node.kind === 81 /* PrivateIdentifier */; } function isGetOrSetAccessorDeclaration(node) { - return node.kind === 177 /* SetAccessor */ || node.kind === 176 /* GetAccessor */; + return node.kind === 178 /* SetAccessor */ || node.kind === 177 /* GetAccessor */; } function isPropertyAccessChain(node) { - return isPropertyAccessExpression(node) && !!(node.flags & 32 /* OptionalChain */); + return isPropertyAccessExpression(node) && !!(node.flags & 64 /* OptionalChain */); } function isElementAccessChain(node) { - return isElementAccessExpression(node) && !!(node.flags & 32 /* OptionalChain */); + return isElementAccessExpression(node) && !!(node.flags & 64 /* OptionalChain */); } function isCallChain(node) { - return isCallExpression(node) && !!(node.flags & 32 /* OptionalChain */); + return isCallExpression(node) && !!(node.flags & 64 /* OptionalChain */); } function isOptionalChain(node) { const kind = node.kind; - return !!(node.flags & 32 /* OptionalChain */) && (kind === 210 /* PropertyAccessExpression */ || kind === 211 /* ElementAccessExpression */ || kind === 212 /* CallExpression */ || kind === 234 /* NonNullExpression */); + return !!(node.flags & 64 /* OptionalChain */) && (kind === 211 /* PropertyAccessExpression */ || kind === 212 /* ElementAccessExpression */ || kind === 213 /* CallExpression */ || kind === 235 /* NonNullExpression */); } function isOptionalChainRoot(node) { return isOptionalChain(node) && !isNonNullExpression(node) && !!node.questionDotToken; @@ -111063,7 +93738,7 @@ ${lanes.join("\n")} return !isOptionalChain(node.parent) || isOptionalChainRoot(node.parent) || node !== node.parent.expression; } function isNullishCoalesce(node) { - return node.kind === 225 /* BinaryExpression */ && node.operatorToken.kind === 61 /* QuestionQuestionToken */; + return node.kind === 226 /* BinaryExpression */ && node.operatorToken.kind === 61 /* QuestionQuestionToken */; } function isConstTypeReference(node) { return isTypeReferenceNode(node) && isIdentifier(node.typeName) && node.typeName.escapedText === "const" && !node.typeArguments; @@ -111072,37 +93747,37 @@ ${lanes.join("\n")} return skipOuterExpressions(node, 8 /* PartiallyEmittedExpressions */); } function isNonNullChain(node) { - return isNonNullExpression(node) && !!(node.flags & 32 /* OptionalChain */); + return isNonNullExpression(node) && !!(node.flags & 64 /* OptionalChain */); } function isBreakOrContinueStatement(node) { - return node.kind === 251 /* BreakStatement */ || node.kind === 250 /* ContinueStatement */; + return node.kind === 252 /* BreakStatement */ || node.kind === 251 /* ContinueStatement */; } function isNamedExportBindings(node) { - return node.kind === 279 /* NamespaceExport */ || node.kind === 278 /* NamedExports */; + return node.kind === 280 /* NamespaceExport */ || node.kind === 279 /* NamedExports */; } function isUnparsedTextLike(node) { switch (node.kind) { - case 308 /* UnparsedText */: - case 309 /* UnparsedInternalText */: + case 309 /* UnparsedText */: + case 310 /* UnparsedInternalText */: return true; default: return false; } } function isUnparsedNode(node) { - return isUnparsedTextLike(node) || node.kind === 306 /* UnparsedPrologue */ || node.kind === 310 /* UnparsedSyntheticReference */; + return isUnparsedTextLike(node) || node.kind === 307 /* UnparsedPrologue */ || node.kind === 311 /* UnparsedSyntheticReference */; } function isJSDocPropertyLikeTag(node) { - return node.kind === 354 /* JSDocPropertyTag */ || node.kind === 347 /* JSDocParameterTag */; + return node.kind === 355 /* JSDocPropertyTag */ || node.kind === 348 /* JSDocParameterTag */; } function isNode(node) { return isNodeKind(node.kind); } function isNodeKind(kind) { - return kind >= 165 /* FirstNode */; + return kind >= 166 /* FirstNode */; } function isTokenKind(kind) { - return kind >= 0 /* FirstToken */ && kind <= 164 /* LastToken */; + return kind >= 0 /* FirstToken */ && kind <= 165 /* LastToken */; } function isToken(n) { return isTokenKind(n.kind); @@ -111118,11 +93793,11 @@ ${lanes.join("\n")} } function isLiteralExpressionOfObject(node) { switch (node.kind) { - case 209 /* ObjectLiteralExpression */: - case 208 /* ArrayLiteralExpression */: + case 210 /* ObjectLiteralExpression */: + case 209 /* ArrayLiteralExpression */: case 14 /* RegularExpressionLiteral */: - case 217 /* FunctionExpression */: - case 230 /* ClassExpression */: + case 218 /* FunctionExpression */: + case 231 /* ClassExpression */: return true; } return false; @@ -111142,23 +93817,23 @@ ${lanes.join("\n")} } function isTypeOnlyImportDeclaration(node) { switch (node.kind) { - case 275 /* ImportSpecifier */: + case 276 /* ImportSpecifier */: return node.isTypeOnly || node.parent.parent.isTypeOnly; - case 273 /* NamespaceImport */: + case 274 /* NamespaceImport */: return node.parent.isTypeOnly; - case 272 /* ImportClause */: - case 270 /* ImportEqualsDeclaration */: + case 273 /* ImportClause */: + case 271 /* ImportEqualsDeclaration */: return node.isTypeOnly; } return false; } function isTypeOnlyExportDeclaration(node) { switch (node.kind) { - case 280 /* ExportSpecifier */: + case 281 /* ExportSpecifier */: return node.isTypeOnly || node.parent.parent.isTypeOnly; - case 277 /* ExportDeclaration */: + case 278 /* ExportDeclaration */: return node.isTypeOnly && !!node.moduleSpecifier && !node.exportClause; - case 279 /* NamespaceExport */: + case 280 /* NamespaceExport */: return node.parent.isTypeOnly; } return false; @@ -111166,12 +93841,12 @@ ${lanes.join("\n")} function isTypeOnlyImportOrExportDeclaration(node) { return isTypeOnlyImportDeclaration(node) || isTypeOnlyExportDeclaration(node); } - function isAssertionKey(node) { - return isStringLiteral(node) || isIdentifier(node); - } function isStringTextContainingNode(node) { return node.kind === 11 /* StringLiteral */ || isTemplateLiteralKind(node.kind); } + function isImportAttributeName(node) { + return isStringLiteral(node) || isIdentifier(node); + } function isGeneratedIdentifier(node) { var _a; return isIdentifier(node) && ((_a = node.emitNode) == null ? void 0 : _a.autoGenerate) !== void 0; @@ -111180,6 +93855,10 @@ ${lanes.join("\n")} var _a; return isPrivateIdentifier(node) && ((_a = node.emitNode) == null ? void 0 : _a.autoGenerate) !== void 0; } + function isFileLevelReservedGeneratedIdentifier(node) { + const flags = node.emitNode.autoGenerate.flags; + return !!(flags & 32 /* FileLevel */) && !!(flags & 16 /* Optimistic */) && !!(flags & 8 /* ReservedInNestedScopes */); + } function isPrivateIdentifierClassElementDeclaration(node) { return (isPropertyDeclaration(node) || isMethodOrAccessor(node)) && isPrivateIdentifier(node.name); } @@ -111202,31 +93881,31 @@ ${lanes.join("\n")} case 148 /* ReadonlyKeyword */: case 126 /* StaticKeyword */: case 147 /* OutKeyword */: - case 163 /* OverrideKeyword */: + case 164 /* OverrideKeyword */: return true; } return false; } function isParameterPropertyModifier(kind) { - return !!(modifierToFlag(kind) & 16476 /* ParameterPropertyModifier */); + return !!(modifierToFlag(kind) & 31 /* ParameterPropertyModifier */); } function isClassMemberModifier(idToken) { - return isParameterPropertyModifier(idToken) || idToken === 126 /* StaticKeyword */ || idToken === 163 /* OverrideKeyword */ || idToken === 129 /* AccessorKeyword */; + return isParameterPropertyModifier(idToken) || idToken === 126 /* StaticKeyword */ || idToken === 164 /* OverrideKeyword */ || idToken === 129 /* AccessorKeyword */; } function isModifier(node) { return isModifierKind(node.kind); } function isEntityName(node) { const kind = node.kind; - return kind === 165 /* QualifiedName */ || kind === 80 /* Identifier */; + return kind === 166 /* QualifiedName */ || kind === 80 /* Identifier */; } function isPropertyName(node) { const kind = node.kind; - return kind === 80 /* Identifier */ || kind === 81 /* PrivateIdentifier */ || kind === 11 /* StringLiteral */ || kind === 9 /* NumericLiteral */ || kind === 166 /* ComputedPropertyName */; + return kind === 80 /* Identifier */ || kind === 81 /* PrivateIdentifier */ || kind === 11 /* StringLiteral */ || kind === 9 /* NumericLiteral */ || kind === 167 /* ComputedPropertyName */; } function isBindingName(node) { const kind = node.kind; - return kind === 80 /* Identifier */ || kind === 205 /* ObjectBindingPattern */ || kind === 206 /* ArrayBindingPattern */; + return kind === 80 /* Identifier */ || kind === 206 /* ObjectBindingPattern */ || kind === 207 /* ArrayBindingPattern */; } function isFunctionLike(node) { return !!node && isFunctionLikeKind(node.kind); @@ -111242,13 +93921,13 @@ ${lanes.join("\n")} } function isFunctionLikeDeclarationKind(kind) { switch (kind) { - case 261 /* FunctionDeclaration */: - case 173 /* MethodDeclaration */: - case 175 /* Constructor */: - case 176 /* GetAccessor */: - case 177 /* SetAccessor */: - case 217 /* FunctionExpression */: - case 218 /* ArrowFunction */: + case 262 /* FunctionDeclaration */: + case 174 /* MethodDeclaration */: + case 176 /* Constructor */: + case 177 /* GetAccessor */: + case 178 /* SetAccessor */: + case 218 /* FunctionExpression */: + case 219 /* ArrowFunction */: return true; default: return false; @@ -111256,14 +93935,14 @@ ${lanes.join("\n")} } function isFunctionLikeKind(kind) { switch (kind) { - case 172 /* MethodSignature */: - case 178 /* CallSignature */: - case 329 /* JSDocSignature */: - case 179 /* ConstructSignature */: - case 180 /* IndexSignature */: - case 183 /* FunctionType */: - case 323 /* JSDocFunctionType */: - case 184 /* ConstructorType */: + case 173 /* MethodSignature */: + case 179 /* CallSignature */: + case 330 /* JSDocSignature */: + case 180 /* ConstructSignature */: + case 181 /* IndexSignature */: + case 184 /* FunctionType */: + case 324 /* JSDocFunctionType */: + case 185 /* ConstructorType */: return true; default: return isFunctionLikeDeclarationKind(kind); @@ -111274,22 +93953,32 @@ ${lanes.join("\n")} } function isClassElement(node) { const kind = node.kind; - return kind === 175 /* Constructor */ || kind === 171 /* PropertyDeclaration */ || kind === 173 /* MethodDeclaration */ || kind === 176 /* GetAccessor */ || kind === 177 /* SetAccessor */ || kind === 180 /* IndexSignature */ || kind === 174 /* ClassStaticBlockDeclaration */ || kind === 239 /* SemicolonClassElement */; + return kind === 176 /* Constructor */ || kind === 172 /* PropertyDeclaration */ || kind === 174 /* MethodDeclaration */ || kind === 177 /* GetAccessor */ || kind === 178 /* SetAccessor */ || kind === 181 /* IndexSignature */ || kind === 175 /* ClassStaticBlockDeclaration */ || kind === 240 /* SemicolonClassElement */; } function isClassLike(node) { - return node && (node.kind === 262 /* ClassDeclaration */ || node.kind === 230 /* ClassExpression */); + return node && (node.kind === 263 /* ClassDeclaration */ || node.kind === 231 /* ClassExpression */); } function isAccessor(node) { - return node && (node.kind === 176 /* GetAccessor */ || node.kind === 177 /* SetAccessor */); + return node && (node.kind === 177 /* GetAccessor */ || node.kind === 178 /* SetAccessor */); } function isAutoAccessorPropertyDeclaration(node) { return isPropertyDeclaration(node) && hasAccessorModifier(node); } + function isClassInstanceProperty(node) { + if (isInJSFile(node) && isExpandoPropertyDeclaration(node)) { + return (!isBindableStaticAccessExpression(node) || !isPrototypeAccess(node.expression)) && !isBindableStaticNameExpression( + node, + /*excludeThisKeyword*/ + true + ); + } + return node.parent && isClassLike(node.parent) && isPropertyDeclaration(node) && !hasAccessorModifier(node); + } function isMethodOrAccessor(node) { switch (node.kind) { - case 173 /* MethodDeclaration */: - case 176 /* GetAccessor */: - case 177 /* SetAccessor */: + case 174 /* MethodDeclaration */: + case 177 /* GetAccessor */: + case 178 /* SetAccessor */: return true; default: return false; @@ -111297,10 +93986,10 @@ ${lanes.join("\n")} } function isNamedClassElement(node) { switch (node.kind) { - case 173 /* MethodDeclaration */: - case 176 /* GetAccessor */: - case 177 /* SetAccessor */: - case 171 /* PropertyDeclaration */: + case 174 /* MethodDeclaration */: + case 177 /* GetAccessor */: + case 178 /* SetAccessor */: + case 172 /* PropertyDeclaration */: return true; default: return false; @@ -111311,22 +94000,22 @@ ${lanes.join("\n")} } function isTypeElement(node) { const kind = node.kind; - return kind === 179 /* ConstructSignature */ || kind === 178 /* CallSignature */ || kind === 170 /* PropertySignature */ || kind === 172 /* MethodSignature */ || kind === 180 /* IndexSignature */ || kind === 176 /* GetAccessor */ || kind === 177 /* SetAccessor */; + return kind === 180 /* ConstructSignature */ || kind === 179 /* CallSignature */ || kind === 171 /* PropertySignature */ || kind === 173 /* MethodSignature */ || kind === 181 /* IndexSignature */ || kind === 177 /* GetAccessor */ || kind === 178 /* SetAccessor */; } function isClassOrTypeElement(node) { return isTypeElement(node) || isClassElement(node); } function isObjectLiteralElementLike(node) { const kind = node.kind; - return kind === 302 /* PropertyAssignment */ || kind === 303 /* ShorthandPropertyAssignment */ || kind === 304 /* SpreadAssignment */ || kind === 173 /* MethodDeclaration */ || kind === 176 /* GetAccessor */ || kind === 177 /* SetAccessor */; + return kind === 303 /* PropertyAssignment */ || kind === 304 /* ShorthandPropertyAssignment */ || kind === 305 /* SpreadAssignment */ || kind === 174 /* MethodDeclaration */ || kind === 177 /* GetAccessor */ || kind === 178 /* SetAccessor */; } function isTypeNode(node) { return isTypeNodeKind(node.kind); } function isFunctionOrConstructorTypeNode(node) { switch (node.kind) { - case 183 /* FunctionType */: - case 184 /* ConstructorType */: + case 184 /* FunctionType */: + case 185 /* ConstructorType */: return true; } return false; @@ -111334,23 +94023,23 @@ ${lanes.join("\n")} function isBindingPattern(node) { if (node) { const kind = node.kind; - return kind === 206 /* ArrayBindingPattern */ || kind === 205 /* ObjectBindingPattern */; + return kind === 207 /* ArrayBindingPattern */ || kind === 206 /* ObjectBindingPattern */; } return false; } function isAssignmentPattern(node) { const kind = node.kind; - return kind === 208 /* ArrayLiteralExpression */ || kind === 209 /* ObjectLiteralExpression */; + return kind === 209 /* ArrayLiteralExpression */ || kind === 210 /* ObjectLiteralExpression */; } function isArrayBindingElement(node) { const kind = node.kind; - return kind === 207 /* BindingElement */ || kind === 231 /* OmittedExpression */; + return kind === 208 /* BindingElement */ || kind === 232 /* OmittedExpression */; } function isDeclarationBindingElement(bindingElement) { switch (bindingElement.kind) { - case 259 /* VariableDeclaration */: - case 168 /* Parameter */: - case 207 /* BindingElement */: + case 260 /* VariableDeclaration */: + case 169 /* Parameter */: + case 208 /* BindingElement */: return true; } return false; @@ -111363,40 +94052,40 @@ ${lanes.join("\n")} } function isObjectBindingOrAssignmentPattern(node) { switch (node.kind) { - case 205 /* ObjectBindingPattern */: - case 209 /* ObjectLiteralExpression */: + case 206 /* ObjectBindingPattern */: + case 210 /* ObjectLiteralExpression */: return true; } return false; } function isObjectBindingOrAssignmentElement(node) { switch (node.kind) { - case 207 /* BindingElement */: - case 302 /* PropertyAssignment */: - case 303 /* ShorthandPropertyAssignment */: - case 304 /* SpreadAssignment */: + case 208 /* BindingElement */: + case 303 /* PropertyAssignment */: + case 304 /* ShorthandPropertyAssignment */: + case 305 /* SpreadAssignment */: return true; } return false; } function isArrayBindingOrAssignmentPattern(node) { switch (node.kind) { - case 206 /* ArrayBindingPattern */: - case 208 /* ArrayLiteralExpression */: + case 207 /* ArrayBindingPattern */: + case 209 /* ArrayLiteralExpression */: return true; } return false; } function isArrayBindingOrAssignmentElement(node) { switch (node.kind) { - case 207 /* BindingElement */: - case 231 /* OmittedExpression */: - case 229 /* SpreadElement */: - case 208 /* ArrayLiteralExpression */: - case 209 /* ObjectLiteralExpression */: + case 208 /* BindingElement */: + case 232 /* OmittedExpression */: + case 230 /* SpreadElement */: + case 209 /* ArrayLiteralExpression */: + case 210 /* ObjectLiteralExpression */: case 80 /* Identifier */: - case 210 /* PropertyAccessExpression */: - case 211 /* ElementAccessExpression */: + case 211 /* PropertyAccessExpression */: + case 212 /* ElementAccessExpression */: return true; } return isAssignmentExpression( @@ -111407,50 +94096,53 @@ ${lanes.join("\n")} } function isPropertyAccessOrQualifiedNameOrImportTypeNode(node) { const kind = node.kind; - return kind === 210 /* PropertyAccessExpression */ || kind === 165 /* QualifiedName */ || kind === 204 /* ImportType */; + return kind === 211 /* PropertyAccessExpression */ || kind === 166 /* QualifiedName */ || kind === 205 /* ImportType */; } function isPropertyAccessOrQualifiedName(node) { const kind = node.kind; - return kind === 210 /* PropertyAccessExpression */ || kind === 165 /* QualifiedName */; + return kind === 211 /* PropertyAccessExpression */ || kind === 166 /* QualifiedName */; + } + function isCallLikeOrFunctionLikeExpression(node) { + return isCallLikeExpression(node) || isFunctionExpressionOrArrowFunction(node); } function isCallLikeExpression(node) { switch (node.kind) { - case 285 /* JsxOpeningElement */: - case 284 /* JsxSelfClosingElement */: - case 212 /* CallExpression */: - case 213 /* NewExpression */: - case 214 /* TaggedTemplateExpression */: - case 169 /* Decorator */: + case 286 /* JsxOpeningElement */: + case 285 /* JsxSelfClosingElement */: + case 213 /* CallExpression */: + case 214 /* NewExpression */: + case 215 /* TaggedTemplateExpression */: + case 170 /* Decorator */: return true; default: return false; } } function isCallOrNewExpression(node) { - return node.kind === 212 /* CallExpression */ || node.kind === 213 /* NewExpression */; + return node.kind === 213 /* CallExpression */ || node.kind === 214 /* NewExpression */; } function isTemplateLiteral(node) { const kind = node.kind; - return kind === 227 /* TemplateExpression */ || kind === 15 /* NoSubstitutionTemplateLiteral */; + return kind === 228 /* TemplateExpression */ || kind === 15 /* NoSubstitutionTemplateLiteral */; } function isLeftHandSideExpression(node) { return isLeftHandSideExpressionKind(skipPartiallyEmittedExpressions(node).kind); } function isLeftHandSideExpressionKind(kind) { switch (kind) { - case 210 /* PropertyAccessExpression */: - case 211 /* ElementAccessExpression */: - case 213 /* NewExpression */: - case 212 /* CallExpression */: - case 283 /* JsxElement */: - case 284 /* JsxSelfClosingElement */: - case 287 /* JsxFragment */: - case 214 /* TaggedTemplateExpression */: - case 208 /* ArrayLiteralExpression */: - case 216 /* ParenthesizedExpression */: - case 209 /* ObjectLiteralExpression */: - case 230 /* ClassExpression */: - case 217 /* FunctionExpression */: + case 211 /* PropertyAccessExpression */: + case 212 /* ElementAccessExpression */: + case 214 /* NewExpression */: + case 213 /* CallExpression */: + case 284 /* JsxElement */: + case 285 /* JsxSelfClosingElement */: + case 288 /* JsxFragment */: + case 215 /* TaggedTemplateExpression */: + case 209 /* ArrayLiteralExpression */: + case 217 /* ParenthesizedExpression */: + case 210 /* ObjectLiteralExpression */: + case 231 /* ClassExpression */: + case 218 /* FunctionExpression */: case 80 /* Identifier */: case 81 /* PrivateIdentifier */: case 14 /* RegularExpressionLiteral */: @@ -111458,17 +94150,17 @@ ${lanes.join("\n")} case 10 /* BigIntLiteral */: case 11 /* StringLiteral */: case 15 /* NoSubstitutionTemplateLiteral */: - case 227 /* TemplateExpression */: + case 228 /* TemplateExpression */: case 97 /* FalseKeyword */: case 106 /* NullKeyword */: case 110 /* ThisKeyword */: case 112 /* TrueKeyword */: case 108 /* SuperKeyword */: - case 234 /* NonNullExpression */: - case 232 /* ExpressionWithTypeArguments */: - case 235 /* MetaProperty */: + case 235 /* NonNullExpression */: + case 233 /* ExpressionWithTypeArguments */: + case 236 /* MetaProperty */: case 102 /* ImportKeyword */: - case 281 /* MissingDeclaration */: + case 282 /* MissingDeclaration */: return true; default: return false; @@ -111479,13 +94171,13 @@ ${lanes.join("\n")} } function isUnaryExpressionKind(kind) { switch (kind) { - case 223 /* PrefixUnaryExpression */: - case 224 /* PostfixUnaryExpression */: - case 219 /* DeleteExpression */: - case 220 /* TypeOfExpression */: - case 221 /* VoidExpression */: - case 222 /* AwaitExpression */: - case 215 /* TypeAssertionExpression */: + case 224 /* PrefixUnaryExpression */: + case 225 /* PostfixUnaryExpression */: + case 220 /* DeleteExpression */: + case 221 /* TypeOfExpression */: + case 222 /* VoidExpression */: + case 223 /* AwaitExpression */: + case 216 /* TypeAssertionExpression */: return true; default: return isLeftHandSideExpressionKind(kind); @@ -111493,9 +94185,9 @@ ${lanes.join("\n")} } function isUnaryExpressionWithWrite(expr) { switch (expr.kind) { - case 224 /* PostfixUnaryExpression */: + case 225 /* PostfixUnaryExpression */: return true; - case 223 /* PrefixUnaryExpression */: + case 224 /* PrefixUnaryExpression */: return expr.operator === 46 /* PlusPlusToken */ || expr.operator === 47 /* MinusMinusToken */; default: return false; @@ -111506,7 +94198,7 @@ ${lanes.join("\n")} case 106 /* NullKeyword */: case 112 /* TrueKeyword */: case 97 /* FalseKeyword */: - case 223 /* PrefixUnaryExpression */: + case 224 /* PrefixUnaryExpression */: return true; default: return isLiteralExpression(node); @@ -111517,16 +94209,16 @@ ${lanes.join("\n")} } function isExpressionKind(kind) { switch (kind) { - case 226 /* ConditionalExpression */: - case 228 /* YieldExpression */: - case 218 /* ArrowFunction */: - case 225 /* BinaryExpression */: - case 229 /* SpreadElement */: - case 233 /* AsExpression */: - case 231 /* OmittedExpression */: - case 360 /* CommaListExpression */: - case 359 /* PartiallyEmittedExpression */: - case 237 /* SatisfiesExpression */: + case 227 /* ConditionalExpression */: + case 229 /* YieldExpression */: + case 219 /* ArrowFunction */: + case 226 /* BinaryExpression */: + case 230 /* SpreadElement */: + case 234 /* AsExpression */: + case 232 /* OmittedExpression */: + case 361 /* CommaListExpression */: + case 360 /* PartiallyEmittedExpression */: + case 238 /* SatisfiesExpression */: return true; default: return isUnaryExpressionKind(kind); @@ -111534,20 +94226,20 @@ ${lanes.join("\n")} } function isAssertionExpression(node) { const kind = node.kind; - return kind === 215 /* TypeAssertionExpression */ || kind === 233 /* AsExpression */; + return kind === 216 /* TypeAssertionExpression */ || kind === 234 /* AsExpression */; } function isNotEmittedOrPartiallyEmittedNode(node) { return isNotEmittedStatement(node) || isPartiallyEmittedExpression(node); } function isIterationStatement(node, lookInLabeledStatements) { switch (node.kind) { - case 247 /* ForStatement */: - case 248 /* ForInStatement */: - case 249 /* ForOfStatement */: - case 245 /* DoStatement */: - case 246 /* WhileStatement */: + case 248 /* ForStatement */: + case 249 /* ForInStatement */: + case 250 /* ForOfStatement */: + case 246 /* DoStatement */: + case 247 /* WhileStatement */: return true; - case 255 /* LabeledStatement */: + case 256 /* LabeledStatement */: return lookInLabeledStatements && isIterationStatement(node.statement, lookInLabeledStatements); } return false; @@ -111559,13 +94251,13 @@ ${lanes.join("\n")} return some(statements, isScopeMarker); } function needsScopeMarker(result) { - return !isAnyImportOrReExport(result) && !isExportAssignment(result) && !hasSyntacticModifier(result, 1 /* Export */) && !isAmbientModule(result); + return !isAnyImportOrReExport(result) && !isExportAssignment(result) && !hasSyntacticModifier(result, 32 /* Export */) && !isAmbientModule(result); } function isExternalModuleIndicator(result) { - return isAnyImportOrReExport(result) || isExportAssignment(result) || hasSyntacticModifier(result, 1 /* Export */); + return isAnyImportOrReExport(result) || isExportAssignment(result) || hasSyntacticModifier(result, 32 /* Export */); } function isForInOrOfStatement(node) { - return node.kind === 248 /* ForInStatement */ || node.kind === 249 /* ForOfStatement */; + return node.kind === 249 /* ForInStatement */ || node.kind === 250 /* ForOfStatement */; } function isConciseBody(node) { return isBlock(node) || isExpression(node); @@ -111578,89 +94270,89 @@ ${lanes.join("\n")} } function isModuleBody(node) { const kind = node.kind; - return kind === 267 /* ModuleBlock */ || kind === 266 /* ModuleDeclaration */ || kind === 80 /* Identifier */; + return kind === 268 /* ModuleBlock */ || kind === 267 /* ModuleDeclaration */ || kind === 80 /* Identifier */; } function isNamespaceBody(node) { const kind = node.kind; - return kind === 267 /* ModuleBlock */ || kind === 266 /* ModuleDeclaration */; + return kind === 268 /* ModuleBlock */ || kind === 267 /* ModuleDeclaration */; } function isJSDocNamespaceBody(node) { const kind = node.kind; - return kind === 80 /* Identifier */ || kind === 266 /* ModuleDeclaration */; + return kind === 80 /* Identifier */ || kind === 267 /* ModuleDeclaration */; } function isNamedImportBindings(node) { const kind = node.kind; - return kind === 274 /* NamedImports */ || kind === 273 /* NamespaceImport */; + return kind === 275 /* NamedImports */ || kind === 274 /* NamespaceImport */; } function isModuleOrEnumDeclaration(node) { - return node.kind === 266 /* ModuleDeclaration */ || node.kind === 265 /* EnumDeclaration */; + return node.kind === 267 /* ModuleDeclaration */ || node.kind === 266 /* EnumDeclaration */; } function canHaveSymbol(node) { switch (node.kind) { - case 218 /* ArrowFunction */: - case 225 /* BinaryExpression */: - case 207 /* BindingElement */: - case 212 /* CallExpression */: - case 178 /* CallSignature */: - case 262 /* ClassDeclaration */: - case 230 /* ClassExpression */: - case 174 /* ClassStaticBlockDeclaration */: - case 175 /* Constructor */: - case 184 /* ConstructorType */: - case 179 /* ConstructSignature */: - case 211 /* ElementAccessExpression */: - case 265 /* EnumDeclaration */: - case 305 /* EnumMember */: - case 276 /* ExportAssignment */: - case 277 /* ExportDeclaration */: - case 280 /* ExportSpecifier */: - case 261 /* FunctionDeclaration */: - case 217 /* FunctionExpression */: - case 183 /* FunctionType */: - case 176 /* GetAccessor */: + case 219 /* ArrowFunction */: + case 226 /* BinaryExpression */: + case 208 /* BindingElement */: + case 213 /* CallExpression */: + case 179 /* CallSignature */: + case 263 /* ClassDeclaration */: + case 231 /* ClassExpression */: + case 175 /* ClassStaticBlockDeclaration */: + case 176 /* Constructor */: + case 185 /* ConstructorType */: + case 180 /* ConstructSignature */: + case 212 /* ElementAccessExpression */: + case 266 /* EnumDeclaration */: + case 306 /* EnumMember */: + case 277 /* ExportAssignment */: + case 278 /* ExportDeclaration */: + case 281 /* ExportSpecifier */: + case 262 /* FunctionDeclaration */: + case 218 /* FunctionExpression */: + case 184 /* FunctionType */: + case 177 /* GetAccessor */: case 80 /* Identifier */: - case 272 /* ImportClause */: - case 270 /* ImportEqualsDeclaration */: - case 275 /* ImportSpecifier */: - case 180 /* IndexSignature */: - case 263 /* InterfaceDeclaration */: - case 344 /* JSDocCallbackTag */: - case 346 /* JSDocEnumTag */: - case 323 /* JSDocFunctionType */: - case 347 /* JSDocParameterTag */: - case 354 /* JSDocPropertyTag */: - case 329 /* JSDocSignature */: - case 352 /* JSDocTypedefTag */: - case 328 /* JSDocTypeLiteral */: - case 290 /* JsxAttribute */: - case 291 /* JsxAttributes */: - case 292 /* JsxSpreadAttribute */: - case 199 /* MappedType */: - case 173 /* MethodDeclaration */: - case 172 /* MethodSignature */: - case 266 /* ModuleDeclaration */: - case 201 /* NamedTupleMember */: - case 279 /* NamespaceExport */: - case 269 /* NamespaceExportDeclaration */: - case 273 /* NamespaceImport */: - case 213 /* NewExpression */: + case 273 /* ImportClause */: + case 271 /* ImportEqualsDeclaration */: + case 276 /* ImportSpecifier */: + case 181 /* IndexSignature */: + case 264 /* InterfaceDeclaration */: + case 345 /* JSDocCallbackTag */: + case 347 /* JSDocEnumTag */: + case 324 /* JSDocFunctionType */: + case 348 /* JSDocParameterTag */: + case 355 /* JSDocPropertyTag */: + case 330 /* JSDocSignature */: + case 353 /* JSDocTypedefTag */: + case 329 /* JSDocTypeLiteral */: + case 291 /* JsxAttribute */: + case 292 /* JsxAttributes */: + case 293 /* JsxSpreadAttribute */: + case 200 /* MappedType */: + case 174 /* MethodDeclaration */: + case 173 /* MethodSignature */: + case 267 /* ModuleDeclaration */: + case 202 /* NamedTupleMember */: + case 280 /* NamespaceExport */: + case 270 /* NamespaceExportDeclaration */: + case 274 /* NamespaceImport */: + case 214 /* NewExpression */: case 15 /* NoSubstitutionTemplateLiteral */: case 9 /* NumericLiteral */: - case 209 /* ObjectLiteralExpression */: - case 168 /* Parameter */: - case 210 /* PropertyAccessExpression */: - case 302 /* PropertyAssignment */: - case 171 /* PropertyDeclaration */: - case 170 /* PropertySignature */: - case 177 /* SetAccessor */: - case 303 /* ShorthandPropertyAssignment */: - case 311 /* SourceFile */: - case 304 /* SpreadAssignment */: + case 210 /* ObjectLiteralExpression */: + case 169 /* Parameter */: + case 211 /* PropertyAccessExpression */: + case 303 /* PropertyAssignment */: + case 172 /* PropertyDeclaration */: + case 171 /* PropertySignature */: + case 178 /* SetAccessor */: + case 304 /* ShorthandPropertyAssignment */: + case 312 /* SourceFile */: + case 305 /* SpreadAssignment */: case 11 /* StringLiteral */: - case 264 /* TypeAliasDeclaration */: - case 186 /* TypeLiteral */: - case 167 /* TypeParameter */: - case 259 /* VariableDeclaration */: + case 265 /* TypeAliasDeclaration */: + case 187 /* TypeLiteral */: + case 168 /* TypeParameter */: + case 260 /* VariableDeclaration */: return true; default: return false; @@ -111668,53 +94360,53 @@ ${lanes.join("\n")} } function canHaveLocals(node) { switch (node.kind) { - case 218 /* ArrowFunction */: - case 240 /* Block */: - case 178 /* CallSignature */: - case 268 /* CaseBlock */: - case 298 /* CatchClause */: - case 174 /* ClassStaticBlockDeclaration */: - case 193 /* ConditionalType */: - case 175 /* Constructor */: - case 184 /* ConstructorType */: - case 179 /* ConstructSignature */: - case 247 /* ForStatement */: - case 248 /* ForInStatement */: - case 249 /* ForOfStatement */: - case 261 /* FunctionDeclaration */: - case 217 /* FunctionExpression */: - case 183 /* FunctionType */: - case 176 /* GetAccessor */: - case 180 /* IndexSignature */: - case 344 /* JSDocCallbackTag */: - case 346 /* JSDocEnumTag */: - case 323 /* JSDocFunctionType */: - case 329 /* JSDocSignature */: - case 352 /* JSDocTypedefTag */: - case 199 /* MappedType */: - case 173 /* MethodDeclaration */: - case 172 /* MethodSignature */: - case 266 /* ModuleDeclaration */: - case 177 /* SetAccessor */: - case 311 /* SourceFile */: - case 264 /* TypeAliasDeclaration */: + case 219 /* ArrowFunction */: + case 241 /* Block */: + case 179 /* CallSignature */: + case 269 /* CaseBlock */: + case 299 /* CatchClause */: + case 175 /* ClassStaticBlockDeclaration */: + case 194 /* ConditionalType */: + case 176 /* Constructor */: + case 185 /* ConstructorType */: + case 180 /* ConstructSignature */: + case 248 /* ForStatement */: + case 249 /* ForInStatement */: + case 250 /* ForOfStatement */: + case 262 /* FunctionDeclaration */: + case 218 /* FunctionExpression */: + case 184 /* FunctionType */: + case 177 /* GetAccessor */: + case 181 /* IndexSignature */: + case 345 /* JSDocCallbackTag */: + case 347 /* JSDocEnumTag */: + case 324 /* JSDocFunctionType */: + case 330 /* JSDocSignature */: + case 353 /* JSDocTypedefTag */: + case 200 /* MappedType */: + case 174 /* MethodDeclaration */: + case 173 /* MethodSignature */: + case 267 /* ModuleDeclaration */: + case 178 /* SetAccessor */: + case 312 /* SourceFile */: + case 265 /* TypeAliasDeclaration */: return true; default: return false; } } function isDeclarationKind(kind) { - return kind === 218 /* ArrowFunction */ || kind === 207 /* BindingElement */ || kind === 262 /* ClassDeclaration */ || kind === 230 /* ClassExpression */ || kind === 174 /* ClassStaticBlockDeclaration */ || kind === 175 /* Constructor */ || kind === 265 /* EnumDeclaration */ || kind === 305 /* EnumMember */ || kind === 280 /* ExportSpecifier */ || kind === 261 /* FunctionDeclaration */ || kind === 217 /* FunctionExpression */ || kind === 176 /* GetAccessor */ || kind === 272 /* ImportClause */ || kind === 270 /* ImportEqualsDeclaration */ || kind === 275 /* ImportSpecifier */ || kind === 263 /* InterfaceDeclaration */ || kind === 290 /* JsxAttribute */ || kind === 173 /* MethodDeclaration */ || kind === 172 /* MethodSignature */ || kind === 266 /* ModuleDeclaration */ || kind === 269 /* NamespaceExportDeclaration */ || kind === 273 /* NamespaceImport */ || kind === 279 /* NamespaceExport */ || kind === 168 /* Parameter */ || kind === 302 /* PropertyAssignment */ || kind === 171 /* PropertyDeclaration */ || kind === 170 /* PropertySignature */ || kind === 177 /* SetAccessor */ || kind === 303 /* ShorthandPropertyAssignment */ || kind === 264 /* TypeAliasDeclaration */ || kind === 167 /* TypeParameter */ || kind === 259 /* VariableDeclaration */ || kind === 352 /* JSDocTypedefTag */ || kind === 344 /* JSDocCallbackTag */ || kind === 354 /* JSDocPropertyTag */; + return kind === 219 /* ArrowFunction */ || kind === 208 /* BindingElement */ || kind === 263 /* ClassDeclaration */ || kind === 231 /* ClassExpression */ || kind === 175 /* ClassStaticBlockDeclaration */ || kind === 176 /* Constructor */ || kind === 266 /* EnumDeclaration */ || kind === 306 /* EnumMember */ || kind === 281 /* ExportSpecifier */ || kind === 262 /* FunctionDeclaration */ || kind === 218 /* FunctionExpression */ || kind === 177 /* GetAccessor */ || kind === 273 /* ImportClause */ || kind === 271 /* ImportEqualsDeclaration */ || kind === 276 /* ImportSpecifier */ || kind === 264 /* InterfaceDeclaration */ || kind === 291 /* JsxAttribute */ || kind === 174 /* MethodDeclaration */ || kind === 173 /* MethodSignature */ || kind === 267 /* ModuleDeclaration */ || kind === 270 /* NamespaceExportDeclaration */ || kind === 274 /* NamespaceImport */ || kind === 280 /* NamespaceExport */ || kind === 169 /* Parameter */ || kind === 303 /* PropertyAssignment */ || kind === 172 /* PropertyDeclaration */ || kind === 171 /* PropertySignature */ || kind === 178 /* SetAccessor */ || kind === 304 /* ShorthandPropertyAssignment */ || kind === 265 /* TypeAliasDeclaration */ || kind === 168 /* TypeParameter */ || kind === 260 /* VariableDeclaration */ || kind === 353 /* JSDocTypedefTag */ || kind === 345 /* JSDocCallbackTag */ || kind === 355 /* JSDocPropertyTag */; } function isDeclarationStatementKind(kind) { - return kind === 261 /* FunctionDeclaration */ || kind === 281 /* MissingDeclaration */ || kind === 262 /* ClassDeclaration */ || kind === 263 /* InterfaceDeclaration */ || kind === 264 /* TypeAliasDeclaration */ || kind === 265 /* EnumDeclaration */ || kind === 266 /* ModuleDeclaration */ || kind === 271 /* ImportDeclaration */ || kind === 270 /* ImportEqualsDeclaration */ || kind === 277 /* ExportDeclaration */ || kind === 276 /* ExportAssignment */ || kind === 269 /* NamespaceExportDeclaration */; + return kind === 262 /* FunctionDeclaration */ || kind === 282 /* MissingDeclaration */ || kind === 263 /* ClassDeclaration */ || kind === 264 /* InterfaceDeclaration */ || kind === 265 /* TypeAliasDeclaration */ || kind === 266 /* EnumDeclaration */ || kind === 267 /* ModuleDeclaration */ || kind === 272 /* ImportDeclaration */ || kind === 271 /* ImportEqualsDeclaration */ || kind === 278 /* ExportDeclaration */ || kind === 277 /* ExportAssignment */ || kind === 270 /* NamespaceExportDeclaration */; } function isStatementKindButNotDeclarationKind(kind) { - return kind === 251 /* BreakStatement */ || kind === 250 /* ContinueStatement */ || kind === 258 /* DebuggerStatement */ || kind === 245 /* DoStatement */ || kind === 243 /* ExpressionStatement */ || kind === 241 /* EmptyStatement */ || kind === 248 /* ForInStatement */ || kind === 249 /* ForOfStatement */ || kind === 247 /* ForStatement */ || kind === 244 /* IfStatement */ || kind === 255 /* LabeledStatement */ || kind === 252 /* ReturnStatement */ || kind === 254 /* SwitchStatement */ || kind === 256 /* ThrowStatement */ || kind === 257 /* TryStatement */ || kind === 242 /* VariableStatement */ || kind === 246 /* WhileStatement */ || kind === 253 /* WithStatement */ || kind === 358 /* NotEmittedStatement */; + return kind === 252 /* BreakStatement */ || kind === 251 /* ContinueStatement */ || kind === 259 /* DebuggerStatement */ || kind === 246 /* DoStatement */ || kind === 244 /* ExpressionStatement */ || kind === 242 /* EmptyStatement */ || kind === 249 /* ForInStatement */ || kind === 250 /* ForOfStatement */ || kind === 248 /* ForStatement */ || kind === 245 /* IfStatement */ || kind === 256 /* LabeledStatement */ || kind === 253 /* ReturnStatement */ || kind === 255 /* SwitchStatement */ || kind === 257 /* ThrowStatement */ || kind === 258 /* TryStatement */ || kind === 243 /* VariableStatement */ || kind === 247 /* WhileStatement */ || kind === 254 /* WithStatement */ || kind === 359 /* NotEmittedStatement */; } function isDeclaration(node) { - if (node.kind === 167 /* TypeParameter */) { - return node.parent && node.parent.kind !== 351 /* JSDocTemplateTag */ || isInJSFile(node); + if (node.kind === 168 /* TypeParameter */) { + return node.parent && node.parent.kind !== 352 /* JSDocTemplateTag */ || isInJSFile(node); } return isDeclarationKind(node.kind); } @@ -111729,10 +94421,10 @@ ${lanes.join("\n")} return isStatementKindButNotDeclarationKind(kind) || isDeclarationStatementKind(kind) || isBlockStatement(node); } function isBlockStatement(node) { - if (node.kind !== 240 /* Block */) + if (node.kind !== 241 /* Block */) return false; if (node.parent !== void 0) { - if (node.parent.kind === 257 /* TryStatement */ || node.parent.kind === 298 /* CatchClause */) { + if (node.parent.kind === 258 /* TryStatement */ || node.parent.kind === 299 /* CatchClause */) { return false; } } @@ -111740,50 +94432,50 @@ ${lanes.join("\n")} } function isStatementOrBlock(node) { const kind = node.kind; - return isStatementKindButNotDeclarationKind(kind) || isDeclarationStatementKind(kind) || kind === 240 /* Block */; + return isStatementKindButNotDeclarationKind(kind) || isDeclarationStatementKind(kind) || kind === 241 /* Block */; } function isModuleReference(node) { const kind = node.kind; - return kind === 282 /* ExternalModuleReference */ || kind === 165 /* QualifiedName */ || kind === 80 /* Identifier */; + return kind === 283 /* ExternalModuleReference */ || kind === 166 /* QualifiedName */ || kind === 80 /* Identifier */; } function isJsxTagNameExpression(node) { const kind = node.kind; - return kind === 110 /* ThisKeyword */ || kind === 80 /* Identifier */ || kind === 210 /* PropertyAccessExpression */ || kind === 294 /* JsxNamespacedName */; + return kind === 110 /* ThisKeyword */ || kind === 80 /* Identifier */ || kind === 211 /* PropertyAccessExpression */ || kind === 295 /* JsxNamespacedName */; } function isJsxChild(node) { const kind = node.kind; - return kind === 283 /* JsxElement */ || kind === 293 /* JsxExpression */ || kind === 284 /* JsxSelfClosingElement */ || kind === 12 /* JsxText */ || kind === 287 /* JsxFragment */; + return kind === 284 /* JsxElement */ || kind === 294 /* JsxExpression */ || kind === 285 /* JsxSelfClosingElement */ || kind === 12 /* JsxText */ || kind === 288 /* JsxFragment */; } function isJsxAttributeLike(node) { const kind = node.kind; - return kind === 290 /* JsxAttribute */ || kind === 292 /* JsxSpreadAttribute */; + return kind === 291 /* JsxAttribute */ || kind === 293 /* JsxSpreadAttribute */; } function isStringLiteralOrJsxExpression(node) { const kind = node.kind; - return kind === 11 /* StringLiteral */ || kind === 293 /* JsxExpression */; + return kind === 11 /* StringLiteral */ || kind === 294 /* JsxExpression */; } function isJsxOpeningLikeElement(node) { const kind = node.kind; - return kind === 285 /* JsxOpeningElement */ || kind === 284 /* JsxSelfClosingElement */; + return kind === 286 /* JsxOpeningElement */ || kind === 285 /* JsxSelfClosingElement */; } function isCaseOrDefaultClause(node) { const kind = node.kind; - return kind === 295 /* CaseClause */ || kind === 296 /* DefaultClause */; + return kind === 296 /* CaseClause */ || kind === 297 /* DefaultClause */; } function isJSDocNode(node) { - return node.kind >= 315 /* FirstJSDocNode */ && node.kind <= 356 /* LastJSDocNode */; + return node.kind >= 316 /* FirstJSDocNode */ && node.kind <= 357 /* LastJSDocNode */; } function isJSDocCommentContainingNode(node) { - return node.kind === 326 /* JSDoc */ || node.kind === 325 /* JSDocNamepathType */ || node.kind === 327 /* JSDocText */ || isJSDocLinkLike(node) || isJSDocTag(node) || isJSDocTypeLiteral(node) || isJSDocSignature(node); + return node.kind === 327 /* JSDoc */ || node.kind === 326 /* JSDocNamepathType */ || node.kind === 328 /* JSDocText */ || isJSDocLinkLike(node) || isJSDocTag(node) || isJSDocTypeLiteral(node) || isJSDocSignature(node); } function isJSDocTag(node) { - return node.kind >= 333 /* FirstJSDocTagNode */ && node.kind <= 356 /* LastJSDocTagNode */; + return node.kind >= 334 /* FirstJSDocTagNode */ && node.kind <= 357 /* LastJSDocTagNode */; } function isSetAccessor(node) { - return node.kind === 177 /* SetAccessor */; + return node.kind === 178 /* SetAccessor */; } function isGetAccessor(node) { - return node.kind === 176 /* GetAccessor */; + return node.kind === 177 /* GetAccessor */; } function hasJSDocNodes(node) { if (!canHaveJSDoc(node)) @@ -111799,22 +94491,22 @@ ${lanes.join("\n")} } function hasOnlyExpressionInitializer(node) { switch (node.kind) { - case 259 /* VariableDeclaration */: - case 168 /* Parameter */: - case 207 /* BindingElement */: - case 171 /* PropertyDeclaration */: - case 302 /* PropertyAssignment */: - case 305 /* EnumMember */: + case 260 /* VariableDeclaration */: + case 169 /* Parameter */: + case 208 /* BindingElement */: + case 172 /* PropertyDeclaration */: + case 303 /* PropertyAssignment */: + case 306 /* EnumMember */: return true; default: return false; } } function isObjectLiteralElement(node) { - return node.kind === 290 /* JsxAttribute */ || node.kind === 292 /* JsxSpreadAttribute */ || isObjectLiteralElementLike(node); + return node.kind === 291 /* JsxAttribute */ || node.kind === 293 /* JsxSpreadAttribute */ || isObjectLiteralElementLike(node); } function isTypeReferenceType(node) { - return node.kind === 182 /* TypeReference */ || node.kind === 232 /* ExpressionWithTypeArguments */; + return node.kind === 183 /* TypeReference */ || node.kind === 233 /* ExpressionWithTypeArguments */; } function guessIndentation(lines) { let indentation = MAX_SMI_X86; @@ -111841,7 +94533,7 @@ ${lanes.join("\n")} return node.kind === 11 /* StringLiteral */ || node.kind === 15 /* NoSubstitutionTemplateLiteral */; } function isJSDocLinkLike(node) { - return node.kind === 330 /* JSDocLink */ || node.kind === 331 /* JSDocLinkCode */ || node.kind === 332 /* JSDocLinkPlain */; + return node.kind === 331 /* JSDocLink */ || node.kind === 332 /* JSDocLinkCode */ || node.kind === 333 /* JSDocLinkPlain */; } function hasRestParameter(s) { const last2 = lastOrUndefined(s.parameters); @@ -111849,7 +94541,7 @@ ${lanes.join("\n")} } function isRestParameter(node) { const type = isJSDocParameterTag(node) ? node.typeExpression && node.typeExpression.type : node.type; - return node.dotDotDotToken !== void 0 || !!type && type.kind === 324 /* JSDocVariadicType */; + return node.dotDotDotToken !== void 0 || !!type && type.kind === 325 /* JSDocVariadicType */; } var unchangedTextChangeRange, supportedLocaleDirectories, MAX_SMI_X86; var init_utilitiesPublic = __esm({ @@ -111984,26 +94676,6 @@ ${lanes.join("\n")} function getFullWidth(node) { return node.end - node.pos; } - function getResolvedModule(sourceFile, moduleNameText, mode) { - var _a, _b; - return (_b = (_a = sourceFile == null ? void 0 : sourceFile.resolvedModules) == null ? void 0 : _a.get(moduleNameText, mode)) == null ? void 0 : _b.resolvedModule; - } - function setResolvedModule(sourceFile, moduleNameText, resolvedModule, mode) { - if (!sourceFile.resolvedModules) { - sourceFile.resolvedModules = createModeAwareCache(); - } - sourceFile.resolvedModules.set(moduleNameText, mode, resolvedModule); - } - function setResolvedTypeReferenceDirective(sourceFile, typeReferenceDirectiveName, resolvedTypeReferenceDirective, mode) { - if (!sourceFile.resolvedTypeReferenceDirectiveNames) { - sourceFile.resolvedTypeReferenceDirectiveNames = createModeAwareCache(); - } - sourceFile.resolvedTypeReferenceDirectiveNames.set(typeReferenceDirectiveName, mode, resolvedTypeReferenceDirective); - } - function getResolvedTypeReferenceDirective(sourceFile, typeReferenceDirectiveName, mode) { - var _a, _b; - return (_b = (_a = sourceFile == null ? void 0 : sourceFile.resolvedTypeReferenceDirectiveNames) == null ? void 0 : _a.get(typeReferenceDirectiveName, mode)) == null ? void 0 : _b.resolvedTypeReferenceDirective; - } function projectReferenceIsEqualTo(oldRef, newRef) { return oldRef.path === newRef.path && !oldRef.prepend === !newRef.prepend && !oldRef.circular === !newRef.circular; } @@ -112011,14 +94683,14 @@ ${lanes.join("\n")} return oldResolution === newResolution || oldResolution.resolvedModule === newResolution.resolvedModule || !!oldResolution.resolvedModule && !!newResolution.resolvedModule && oldResolution.resolvedModule.isExternalLibraryImport === newResolution.resolvedModule.isExternalLibraryImport && oldResolution.resolvedModule.extension === newResolution.resolvedModule.extension && oldResolution.resolvedModule.resolvedFileName === newResolution.resolvedModule.resolvedFileName && oldResolution.resolvedModule.originalPath === newResolution.resolvedModule.originalPath && packageIdIsEqual(oldResolution.resolvedModule.packageId, newResolution.resolvedModule.packageId) && oldResolution.node10Result === newResolution.node10Result; } function createModuleNotFoundChain(sourceFile, host, moduleReference, mode, packageName) { - var _a, _b; - const node10Result = (_b = (_a = sourceFile.resolvedModules) == null ? void 0 : _a.get(moduleReference, mode)) == null ? void 0 : _b.node10Result; + var _a; + const node10Result = (_a = host.getResolvedModule(sourceFile, moduleReference, mode)) == null ? void 0 : _a.node10Result; const result = node10Result ? chainDiagnosticMessages( /*details*/ void 0, Diagnostics.There_are_types_at_0_but_this_result_could_not_be_resolved_when_respecting_package_json_exports_The_1_library_may_need_to_update_its_package_json_or_typings, node10Result, - node10Result.indexOf(nodeModulesPathPart + "@types/") > -1 ? `@types/${mangleScopedPackageName(packageName)}` : packageName + node10Result.includes(nodeModulesPathPart + "@types/") ? `@types/${mangleScopedPackageName(packageName)}` : packageName ) : host.typesPackageExists(packageName) ? chainDiagnosticMessages( /*details*/ void 0, @@ -112054,14 +94726,14 @@ ${lanes.join("\n")} function typeDirectiveIsEqualTo(oldResolution, newResolution) { return oldResolution === newResolution || oldResolution.resolvedTypeReferenceDirective === newResolution.resolvedTypeReferenceDirective || !!oldResolution.resolvedTypeReferenceDirective && !!newResolution.resolvedTypeReferenceDirective && oldResolution.resolvedTypeReferenceDirective.resolvedFileName === newResolution.resolvedTypeReferenceDirective.resolvedFileName && !!oldResolution.resolvedTypeReferenceDirective.primary === !!newResolution.resolvedTypeReferenceDirective.primary && oldResolution.resolvedTypeReferenceDirective.originalPath === newResolution.resolvedTypeReferenceDirective.originalPath; } - function hasChangesInResolutions(names, newSourceFile, newResolutions, oldResolutions, comparer, nameAndModeGetter) { + function hasChangesInResolutions(names, newSourceFile, newResolutions, getOldResolution, comparer, nameAndModeGetter) { Debug.assert(names.length === newResolutions.length); for (let i = 0; i < names.length; i++) { const newResolution = newResolutions[i]; const entry = names[i]; const name = nameAndModeGetter.getName(entry); const mode = nameAndModeGetter.getMode(entry, newSourceFile); - const oldResolution = oldResolutions && oldResolutions.get(name, mode); + const oldResolution = getOldResolution(name, mode); const changed = oldResolution ? !newResolution || !comparer(oldResolution, newResolution) : newResolution; if (changed) { return true; @@ -112071,19 +94743,19 @@ ${lanes.join("\n")} } function containsParseError(node) { aggregateChildData(node); - return (node.flags & 524288 /* ThisNodeOrAnySubNodesHasError */) !== 0; + return (node.flags & 1048576 /* ThisNodeOrAnySubNodesHasError */) !== 0; } function aggregateChildData(node) { - if (!(node.flags & 1048576 /* HasAggregatedChildData */)) { - const thisNodeOrAnySubNodesHasError = (node.flags & 131072 /* ThisNodeHasError */) !== 0 || forEachChild(node, containsParseError); + if (!(node.flags & 2097152 /* HasAggregatedChildData */)) { + const thisNodeOrAnySubNodesHasError = (node.flags & 262144 /* ThisNodeHasError */) !== 0 || forEachChild(node, containsParseError); if (thisNodeOrAnySubNodesHasError) { - node.flags |= 524288 /* ThisNodeOrAnySubNodesHasError */; + node.flags |= 1048576 /* ThisNodeOrAnySubNodesHasError */; } - node.flags |= 1048576 /* HasAggregatedChildData */; + node.flags |= 2097152 /* HasAggregatedChildData */; } } function getSourceFileOfNode(node) { - while (node && node.kind !== 311 /* SourceFile */) { + while (node && node.kind !== 312 /* SourceFile */) { node = node.parent; } return node; @@ -112096,11 +94768,11 @@ ${lanes.join("\n")} } function isStatementWithLocals(node) { switch (node.kind) { - case 240 /* Block */: - case 268 /* CaseBlock */: - case 247 /* ForStatement */: - case 248 /* ForInStatement */: - case 249 /* ForOfStatement */: + case 241 /* Block */: + case 269 /* CaseBlock */: + case 248 /* ForStatement */: + case 249 /* ForInStatement */: + case 250 /* ForOfStatement */: return true; } return false; @@ -112259,7 +94931,7 @@ ${lanes.join("\n")} if (includeJsDoc && hasJSDocNodes(node)) { return getTokenPosOfNode(node.jsDoc[0], sourceFile); } - if (node.kind === 357 /* SyntaxList */ && node._children.length > 0) { + if (node.kind === 358 /* SyntaxList */ && node._children.length > 0) { return getTokenPosOfNode(node._children[0], sourceFile, includeJsDoc); } return skipTrivia( @@ -112294,7 +94966,7 @@ ${lanes.join("\n")} } let text = sourceText.substring(includeTrivia ? node.pos : skipTrivia(sourceText, node.pos), node.end); if (isJSDocTypeExpressionOrChild(node)) { - text = text.split(/\r\n|\n|\r/).map((line) => trimStringStart(line.replace(/^\s*\*/, ""))).join("\n"); + text = text.split(/\r\n|\n|\r/).map((line) => line.replace(/^\s*\*/, "").trimStart()).join("\n"); } return text; } @@ -112315,402 +94987,6 @@ ${lanes.join("\n")} const emitNode = node.emitNode; return emitNode && emitNode.internalFlags || 0; } - function getScriptTargetFeatures() { - return new Map(Object.entries({ - Array: new Map(Object.entries({ - es2015: [ - "find", - "findIndex", - "fill", - "copyWithin", - "entries", - "keys", - "values" - ], - es2016: [ - "includes" - ], - es2019: [ - "flat", - "flatMap" - ], - es2022: [ - "at" - ], - es2023: [ - "findLastIndex", - "findLast" - ] - })), - Iterator: new Map(Object.entries({ - es2015: emptyArray - })), - AsyncIterator: new Map(Object.entries({ - es2015: emptyArray - })), - Atomics: new Map(Object.entries({ - es2017: emptyArray - })), - SharedArrayBuffer: new Map(Object.entries({ - es2017: emptyArray - })), - AsyncIterable: new Map(Object.entries({ - es2018: emptyArray - })), - AsyncIterableIterator: new Map(Object.entries({ - es2018: emptyArray - })), - AsyncGenerator: new Map(Object.entries({ - es2018: emptyArray - })), - AsyncGeneratorFunction: new Map(Object.entries({ - es2018: emptyArray - })), - RegExp: new Map(Object.entries({ - es2015: [ - "flags", - "sticky", - "unicode" - ], - es2018: [ - "dotAll" - ] - })), - Reflect: new Map(Object.entries({ - es2015: [ - "apply", - "construct", - "defineProperty", - "deleteProperty", - "get", - " getOwnPropertyDescriptor", - "getPrototypeOf", - "has", - "isExtensible", - "ownKeys", - "preventExtensions", - "set", - "setPrototypeOf" - ] - })), - ArrayConstructor: new Map(Object.entries({ - es2015: [ - "from", - "of" - ] - })), - ObjectConstructor: new Map(Object.entries({ - es2015: [ - "assign", - "getOwnPropertySymbols", - "keys", - "is", - "setPrototypeOf" - ], - es2017: [ - "values", - "entries", - "getOwnPropertyDescriptors" - ], - es2019: [ - "fromEntries" - ], - es2022: [ - "hasOwn" - ] - })), - NumberConstructor: new Map(Object.entries({ - es2015: [ - "isFinite", - "isInteger", - "isNaN", - "isSafeInteger", - "parseFloat", - "parseInt" - ] - })), - Math: new Map(Object.entries({ - es2015: [ - "clz32", - "imul", - "sign", - "log10", - "log2", - "log1p", - "expm1", - "cosh", - "sinh", - "tanh", - "acosh", - "asinh", - "atanh", - "hypot", - "trunc", - "fround", - "cbrt" - ] - })), - Map: new Map(Object.entries({ - es2015: [ - "entries", - "keys", - "values" - ] - })), - Set: new Map(Object.entries({ - es2015: [ - "entries", - "keys", - "values" - ] - })), - PromiseConstructor: new Map(Object.entries({ - es2015: [ - "all", - "race", - "reject", - "resolve" - ], - es2020: [ - "allSettled" - ], - es2021: [ - "any" - ] - })), - Symbol: new Map(Object.entries({ - es2015: [ - "for", - "keyFor" - ], - es2019: [ - "description" - ] - })), - WeakMap: new Map(Object.entries({ - es2015: [ - "entries", - "keys", - "values" - ] - })), - WeakSet: new Map(Object.entries({ - es2015: [ - "entries", - "keys", - "values" - ] - })), - String: new Map(Object.entries({ - es2015: [ - "codePointAt", - "includes", - "endsWith", - "normalize", - "repeat", - "startsWith", - "anchor", - "big", - "blink", - "bold", - "fixed", - "fontcolor", - "fontsize", - "italics", - "link", - "small", - "strike", - "sub", - "sup" - ], - es2017: [ - "padStart", - "padEnd" - ], - es2019: [ - "trimStart", - "trimEnd", - "trimLeft", - "trimRight" - ], - es2020: [ - "matchAll" - ], - es2021: [ - "replaceAll" - ], - es2022: [ - "at" - ] - })), - StringConstructor: new Map(Object.entries({ - es2015: [ - "fromCodePoint", - "raw" - ] - })), - DateTimeFormat: new Map(Object.entries({ - es2017: [ - "formatToParts" - ] - })), - Promise: new Map(Object.entries({ - es2015: emptyArray, - es2018: [ - "finally" - ] - })), - RegExpMatchArray: new Map(Object.entries({ - es2018: [ - "groups" - ] - })), - RegExpExecArray: new Map(Object.entries({ - es2018: [ - "groups" - ] - })), - Intl: new Map(Object.entries({ - es2018: [ - "PluralRules" - ] - })), - NumberFormat: new Map(Object.entries({ - es2018: [ - "formatToParts" - ] - })), - SymbolConstructor: new Map(Object.entries({ - es2020: [ - "matchAll" - ] - })), - DataView: new Map(Object.entries({ - es2020: [ - "setBigInt64", - "setBigUint64", - "getBigInt64", - "getBigUint64" - ] - })), - BigInt: new Map(Object.entries({ - es2020: emptyArray - })), - RelativeTimeFormat: new Map(Object.entries({ - es2020: [ - "format", - "formatToParts", - "resolvedOptions" - ] - })), - Int8Array: new Map(Object.entries({ - es2022: [ - "at" - ], - es2023: [ - "findLastIndex", - "findLast" - ] - })), - Uint8Array: new Map(Object.entries({ - es2022: [ - "at" - ], - es2023: [ - "findLastIndex", - "findLast" - ] - })), - Uint8ClampedArray: new Map(Object.entries({ - es2022: [ - "at" - ], - es2023: [ - "findLastIndex", - "findLast" - ] - })), - Int16Array: new Map(Object.entries({ - es2022: [ - "at" - ], - es2023: [ - "findLastIndex", - "findLast" - ] - })), - Uint16Array: new Map(Object.entries({ - es2022: [ - "at" - ], - es2023: [ - "findLastIndex", - "findLast" - ] - })), - Int32Array: new Map(Object.entries({ - es2022: [ - "at" - ], - es2023: [ - "findLastIndex", - "findLast" - ] - })), - Uint32Array: new Map(Object.entries({ - es2022: [ - "at" - ], - es2023: [ - "findLastIndex", - "findLast" - ] - })), - Float32Array: new Map(Object.entries({ - es2022: [ - "at" - ], - es2023: [ - "findLastIndex", - "findLast" - ] - })), - Float64Array: new Map(Object.entries({ - es2022: [ - "at" - ], - es2023: [ - "findLastIndex", - "findLast" - ] - })), - BigInt64Array: new Map(Object.entries({ - es2020: emptyArray, - es2022: [ - "at" - ], - es2023: [ - "findLastIndex", - "findLast" - ] - })), - BigUint64Array: new Map(Object.entries({ - es2020: emptyArray, - es2022: [ - "at" - ], - es2023: [ - "findLastIndex", - "findLast" - ] - })), - Error: new Map(Object.entries({ - es2022: [ - "cause" - ] - })) - })); - } function getLiteralText(node, sourceFile, flags) { if (sourceFile && canUseOriginalText(node, flags)) { return getSourceTextOfNodeFromSourceFile(sourceFile, node); @@ -112774,11 +95050,11 @@ ${lanes.join("\n")} return getBaseFileName(moduleName).replace(/^(\d)/, "_$1").replace(/\W/g, "_"); } function isBlockOrCatchScoped(declaration) { - return (getCombinedNodeFlags(declaration) & 3 /* BlockScoped */) !== 0 || isCatchClauseVariableDeclarationOrBindingElement(declaration); + return (getCombinedNodeFlags(declaration) & 7 /* BlockScoped */) !== 0 || isCatchClauseVariableDeclarationOrBindingElement(declaration); } function isCatchClauseVariableDeclarationOrBindingElement(declaration) { const node = getRootDeclaration(declaration); - return node.kind === 259 /* VariableDeclaration */ && node.parent.kind === 298 /* CatchClause */; + return node.kind === 260 /* VariableDeclaration */ && node.parent.kind === 299 /* CatchClause */; } function isAmbientModule(node) { return isModuleDeclaration(node) && (node.name.kind === 11 /* StringLiteral */ || isGlobalScopeAugmentation(node)); @@ -112796,22 +95072,22 @@ ${lanes.join("\n")} return isShorthandAmbientModule(moduleSymbol.valueDeclaration); } function isShorthandAmbientModule(node) { - return !!node && node.kind === 266 /* ModuleDeclaration */ && !node.body; + return !!node && node.kind === 267 /* ModuleDeclaration */ && !node.body; } function isBlockScopedContainerTopLevel(node) { - return node.kind === 311 /* SourceFile */ || node.kind === 266 /* ModuleDeclaration */ || isFunctionLikeOrClassStaticBlockDeclaration(node); + return node.kind === 312 /* SourceFile */ || node.kind === 267 /* ModuleDeclaration */ || isFunctionLikeOrClassStaticBlockDeclaration(node); } function isGlobalScopeAugmentation(module2) { - return !!(module2.flags & 1024 /* GlobalAugmentation */); + return !!(module2.flags & 2048 /* GlobalAugmentation */); } function isExternalModuleAugmentation(node) { return isAmbientModule(node) && isModuleAugmentationExternal(node); } function isModuleAugmentationExternal(node) { switch (node.parent.kind) { - case 311 /* SourceFile */: + case 312 /* SourceFile */: return isExternalModule(node.parent); - case 267 /* ModuleBlock */: + case 268 /* ModuleBlock */: return isAmbientModule(node.parent.parent) && isSourceFile(node.parent.parent.parent) && !isExternalModule(node.parent.parent.parent); } return false; @@ -112854,28 +95130,28 @@ ${lanes.join("\n")} return false; } function isAmbientPropertyDeclaration(node) { - return !!(node.flags & 16777216 /* Ambient */) || hasSyntacticModifier(node, 2 /* Ambient */); + return !!(node.flags & 33554432 /* Ambient */) || hasSyntacticModifier(node, 128 /* Ambient */); } function isBlockScope(node, parentNode) { switch (node.kind) { - case 311 /* SourceFile */: - case 268 /* CaseBlock */: - case 298 /* CatchClause */: - case 266 /* ModuleDeclaration */: - case 247 /* ForStatement */: - case 248 /* ForInStatement */: - case 249 /* ForOfStatement */: - case 175 /* Constructor */: - case 173 /* MethodDeclaration */: - case 176 /* GetAccessor */: - case 177 /* SetAccessor */: - case 261 /* FunctionDeclaration */: - case 217 /* FunctionExpression */: - case 218 /* ArrowFunction */: - case 171 /* PropertyDeclaration */: - case 174 /* ClassStaticBlockDeclaration */: + case 312 /* SourceFile */: + case 269 /* CaseBlock */: + case 299 /* CatchClause */: + case 267 /* ModuleDeclaration */: + case 248 /* ForStatement */: + case 249 /* ForInStatement */: + case 250 /* ForOfStatement */: + case 176 /* Constructor */: + case 174 /* MethodDeclaration */: + case 177 /* GetAccessor */: + case 178 /* SetAccessor */: + case 262 /* FunctionDeclaration */: + case 218 /* FunctionExpression */: + case 219 /* ArrowFunction */: + case 172 /* PropertyDeclaration */: + case 175 /* ClassStaticBlockDeclaration */: return true; - case 240 /* Block */: + case 241 /* Block */: return !isFunctionLikeOrClassStaticBlockDeclaration(parentNode); } return false; @@ -112883,9 +95159,9 @@ ${lanes.join("\n")} function isDeclarationWithTypeParameters(node) { Debug.type(node); switch (node.kind) { - case 344 /* JSDocCallbackTag */: - case 352 /* JSDocTypedefTag */: - case 329 /* JSDocSignature */: + case 345 /* JSDocCallbackTag */: + case 353 /* JSDocTypedefTag */: + case 330 /* JSDocSignature */: return true; default: assertType(node); @@ -112895,25 +95171,25 @@ ${lanes.join("\n")} function isDeclarationWithTypeParameterChildren(node) { Debug.type(node); switch (node.kind) { - case 178 /* CallSignature */: - case 179 /* ConstructSignature */: - case 172 /* MethodSignature */: - case 180 /* IndexSignature */: - case 183 /* FunctionType */: - case 184 /* ConstructorType */: - case 323 /* JSDocFunctionType */: - case 262 /* ClassDeclaration */: - case 230 /* ClassExpression */: - case 263 /* InterfaceDeclaration */: - case 264 /* TypeAliasDeclaration */: - case 351 /* JSDocTemplateTag */: - case 261 /* FunctionDeclaration */: - case 173 /* MethodDeclaration */: - case 175 /* Constructor */: - case 176 /* GetAccessor */: - case 177 /* SetAccessor */: - case 217 /* FunctionExpression */: - case 218 /* ArrowFunction */: + case 179 /* CallSignature */: + case 180 /* ConstructSignature */: + case 173 /* MethodSignature */: + case 181 /* IndexSignature */: + case 184 /* FunctionType */: + case 185 /* ConstructorType */: + case 324 /* JSDocFunctionType */: + case 263 /* ClassDeclaration */: + case 231 /* ClassExpression */: + case 264 /* InterfaceDeclaration */: + case 265 /* TypeAliasDeclaration */: + case 352 /* JSDocTemplateTag */: + case 262 /* FunctionDeclaration */: + case 174 /* MethodDeclaration */: + case 176 /* Constructor */: + case 177 /* GetAccessor */: + case 178 /* SetAccessor */: + case 218 /* FunctionExpression */: + case 219 /* ArrowFunction */: return true; default: assertType(node); @@ -112922,8 +95198,8 @@ ${lanes.join("\n")} } function isAnyImportSyntax(node) { switch (node.kind) { - case 271 /* ImportDeclaration */: - case 270 /* ImportEqualsDeclaration */: + case 272 /* ImportDeclaration */: + case 271 /* ImportEqualsDeclaration */: return true; default: return false; @@ -112934,15 +95210,15 @@ ${lanes.join("\n")} } function isLateVisibilityPaintedStatement(node) { switch (node.kind) { - case 271 /* ImportDeclaration */: - case 270 /* ImportEqualsDeclaration */: - case 242 /* VariableStatement */: - case 262 /* ClassDeclaration */: - case 261 /* FunctionDeclaration */: - case 266 /* ModuleDeclaration */: - case 264 /* TypeAliasDeclaration */: - case 263 /* InterfaceDeclaration */: - case 265 /* EnumDeclaration */: + case 272 /* ImportDeclaration */: + case 271 /* ImportEqualsDeclaration */: + case 243 /* VariableStatement */: + case 263 /* ClassDeclaration */: + case 262 /* FunctionDeclaration */: + case 267 /* ModuleDeclaration */: + case 265 /* TypeAliasDeclaration */: + case 264 /* InterfaceDeclaration */: + case 266 /* EnumDeclaration */: return true; default: return false; @@ -112954,6 +95230,9 @@ ${lanes.join("\n")} function isAnyImportOrReExport(node) { return isAnyImportSyntax(node) || isExportDeclaration(node); } + function getEnclosingContainer(node) { + return findAncestor(node.parent, (n) => !!(getContainerFlags(n) & 1 /* IsContainer */)); + } function getEnclosingBlockScopeContainer(node) { return findAncestor(node.parent, (current) => isBlockScope(current, current.parent)); } @@ -112971,7 +95250,7 @@ ${lanes.join("\n")} return info.declaration ? declarationNameToString(info.declaration.parameters[0].name) : void 0; } function isComputedNonLiteralName(name) { - return name.kind === 166 /* ComputedPropertyName */ && !isStringOrNumericLiteralLike(name.expression); + return name.kind === 167 /* ComputedPropertyName */ && !isStringOrNumericLiteralLike(name.expression); } function tryGetTextOfPropertyName(name) { var _a; @@ -112983,11 +95262,11 @@ ${lanes.join("\n")} case 9 /* NumericLiteral */: case 15 /* NoSubstitutionTemplateLiteral */: return escapeLeadingUnderscores(name.text); - case 166 /* ComputedPropertyName */: + case 167 /* ComputedPropertyName */: if (isStringOrNumericLiteralLike(name.expression)) return escapeLeadingUnderscores(name.expression.text); return void 0; - case 294 /* JsxNamespacedName */: + case 295 /* JsxNamespacedName */: return getEscapedTextOfJsxNamespacedName(name); default: return Debug.assertNever(name); @@ -113003,17 +95282,17 @@ ${lanes.join("\n")} case 81 /* PrivateIdentifier */: case 80 /* Identifier */: return getFullWidth(name) === 0 ? idText(name) : getTextOfNode(name); - case 165 /* QualifiedName */: + case 166 /* QualifiedName */: return entityNameToString(name.left) + "." + entityNameToString(name.right); - case 210 /* PropertyAccessExpression */: + case 211 /* PropertyAccessExpression */: if (isIdentifier(name.name) || isPrivateIdentifier(name.name)) { return entityNameToString(name.expression) + "." + entityNameToString(name.name); } else { return Debug.assertNever(name.name); } - case 317 /* JSDocMemberName */: + case 318 /* JSDocMemberName */: return entityNameToString(name.left) + entityNameToString(name.right); - case 294 /* JsxNamespacedName */: + case 295 /* JsxNamespacedName */: return entityNameToString(name.namespace) + ":" + entityNameToString(name.name); default: return Debug.assertNever(name); @@ -113039,16 +95318,14 @@ ${lanes.join("\n")} const start = skipTrivia(sourceFile.text, nodes.pos); return createFileDiagnosticFromMessageChain(sourceFile, start, nodes.end - start, messageChain, relatedInformation); } - function assertDiagnosticLocation(file, start, length2) { + function assertDiagnosticLocation(sourceText, start, length2) { Debug.assertGreaterThanOrEqual(start, 0); Debug.assertGreaterThanOrEqual(length2, 0); - if (file) { - Debug.assertLessThanOrEqual(start, file.text.length); - Debug.assertLessThanOrEqual(start + length2, file.text.length); - } + Debug.assertLessThanOrEqual(start, sourceText.length); + Debug.assertLessThanOrEqual(start + length2, sourceText.length); } function createFileDiagnosticFromMessageChain(file, start, length2, messageChain, relatedInformation) { - assertDiagnosticLocation(file, start, length2); + assertDiagnosticLocation(file.text, start, length2); return { file, start, @@ -113119,7 +95396,7 @@ ${lanes.join("\n")} } function getErrorSpanForArrowFunction(sourceFile, node) { const pos = skipTrivia(sourceFile.text, node.pos); - if (node.body && node.body.kind === 240 /* Block */) { + if (node.body && node.body.kind === 241 /* Block */) { const { line: startLine } = getLineAndCharacterOfPosition(sourceFile, node.body.pos); const { line: endLine } = getLineAndCharacterOfPosition(sourceFile, node.body.end); if (startLine < endLine) { @@ -113131,7 +95408,7 @@ ${lanes.join("\n")} function getErrorSpanForNode(sourceFile, node) { let errorNode = node; switch (node.kind) { - case 311 /* SourceFile */: { + case 312 /* SourceFile */: { const pos2 = skipTrivia( sourceFile.text, 0, @@ -113143,43 +95420,43 @@ ${lanes.join("\n")} } return getSpanOfTokenAtPosition(sourceFile, pos2); } - case 259 /* VariableDeclaration */: - case 207 /* BindingElement */: - case 262 /* ClassDeclaration */: - case 230 /* ClassExpression */: - case 263 /* InterfaceDeclaration */: - case 266 /* ModuleDeclaration */: - case 265 /* EnumDeclaration */: - case 305 /* EnumMember */: - case 261 /* FunctionDeclaration */: - case 217 /* FunctionExpression */: - case 173 /* MethodDeclaration */: - case 176 /* GetAccessor */: - case 177 /* SetAccessor */: - case 264 /* TypeAliasDeclaration */: - case 171 /* PropertyDeclaration */: - case 170 /* PropertySignature */: - case 273 /* NamespaceImport */: + case 260 /* VariableDeclaration */: + case 208 /* BindingElement */: + case 263 /* ClassDeclaration */: + case 231 /* ClassExpression */: + case 264 /* InterfaceDeclaration */: + case 267 /* ModuleDeclaration */: + case 266 /* EnumDeclaration */: + case 306 /* EnumMember */: + case 262 /* FunctionDeclaration */: + case 218 /* FunctionExpression */: + case 174 /* MethodDeclaration */: + case 177 /* GetAccessor */: + case 178 /* SetAccessor */: + case 265 /* TypeAliasDeclaration */: + case 172 /* PropertyDeclaration */: + case 171 /* PropertySignature */: + case 274 /* NamespaceImport */: errorNode = node.name; break; - case 218 /* ArrowFunction */: + case 219 /* ArrowFunction */: return getErrorSpanForArrowFunction(sourceFile, node); - case 295 /* CaseClause */: - case 296 /* DefaultClause */: { + case 296 /* CaseClause */: + case 297 /* DefaultClause */: { const start = skipTrivia(sourceFile.text, node.pos); const end = node.statements.length > 0 ? node.statements[0].pos : node.end; return createTextSpanFromBounds(start, end); } - case 252 /* ReturnStatement */: - case 228 /* YieldExpression */: { + case 253 /* ReturnStatement */: + case 229 /* YieldExpression */: { const pos2 = skipTrivia(sourceFile.text, node.pos); return getSpanOfTokenAtPosition(sourceFile, pos2); } - case 237 /* SatisfiesExpression */: { + case 238 /* SatisfiesExpression */: { const pos2 = skipTrivia(sourceFile.text, node.expression.end); return getSpanOfTokenAtPosition(sourceFile, pos2); } - case 356 /* JSDocSatisfiesTag */: { + case 357 /* JSDocSatisfiesTag */: { const pos2 = skipTrivia(sourceFile.text, node.tagName.pos); return getSpanOfTokenAtPosition(sourceFile, pos2); } @@ -113206,22 +95483,28 @@ ${lanes.join("\n")} return file.scriptKind === 6 /* JSON */; } function isEnumConst(node) { - return !!(getCombinedModifierFlags(node) & 2048 /* Const */); + return !!(getCombinedModifierFlags(node) & 4096 /* Const */); } function isDeclarationReadonly(declaration) { - return !!(getCombinedModifierFlags(declaration) & 64 /* Readonly */ && !isParameterPropertyDeclaration(declaration, declaration.parent)); + return !!(getCombinedModifierFlags(declaration) & 8 /* Readonly */ && !isParameterPropertyDeclaration(declaration, declaration.parent)); + } + function isVarAwaitUsing(node) { + return (getCombinedNodeFlags(node) & 7 /* BlockScoped */) === 6 /* AwaitUsing */; + } + function isVarUsing(node) { + return (getCombinedNodeFlags(node) & 7 /* BlockScoped */) === 4 /* Using */; } function isVarConst(node) { - return !!(getCombinedNodeFlags(node) & 2 /* Const */); + return (getCombinedNodeFlags(node) & 7 /* BlockScoped */) === 2 /* Const */; } function isLet(node) { - return !!(getCombinedNodeFlags(node) & 1 /* Let */); + return (getCombinedNodeFlags(node) & 7 /* BlockScoped */) === 1 /* Let */; } function isSuperCall(n) { - return n.kind === 212 /* CallExpression */ && n.expression.kind === 108 /* SuperKeyword */; + return n.kind === 213 /* CallExpression */ && n.expression.kind === 108 /* SuperKeyword */; } function isImportCall(n) { - return n.kind === 212 /* CallExpression */ && n.expression.kind === 102 /* ImportKeyword */; + return n.kind === 213 /* CallExpression */ && n.expression.kind === 102 /* ImportKeyword */; } function isImportMeta(n) { return isMetaProperty(n) && n.keywordToken === 102 /* ImportKeyword */ && n.name.escapedText === "meta"; @@ -113230,7 +95513,7 @@ ${lanes.join("\n")} return isImportTypeNode(n) && isLiteralTypeNode(n.argument) && isStringLiteral(n.argument.literal); } function isPrologueDirective(node) { - return node.kind === 243 /* ExpressionStatement */ && node.expression.kind === 11 /* StringLiteral */; + return node.kind === 244 /* ExpressionStatement */ && node.expression.kind === 11 /* StringLiteral */; } function isCustomPrologue(node) { return !!(getEmitFlags(node) & 2097152 /* CustomPrologue */); @@ -113248,18 +95531,18 @@ ${lanes.join("\n")} return node.kind !== 12 /* JsxText */ ? getLeadingCommentRanges(sourceFileOfNode.text, node.pos) : void 0; } function getJSDocCommentRanges(node, text) { - const commentRanges = node.kind === 168 /* Parameter */ || node.kind === 167 /* TypeParameter */ || node.kind === 217 /* FunctionExpression */ || node.kind === 218 /* ArrowFunction */ || node.kind === 216 /* ParenthesizedExpression */ || node.kind === 259 /* VariableDeclaration */ || node.kind === 280 /* ExportSpecifier */ ? concatenate(getTrailingCommentRanges(text, node.pos), getLeadingCommentRanges(text, node.pos)) : getLeadingCommentRanges(text, node.pos); + const commentRanges = node.kind === 169 /* Parameter */ || node.kind === 168 /* TypeParameter */ || node.kind === 218 /* FunctionExpression */ || node.kind === 219 /* ArrowFunction */ || node.kind === 217 /* ParenthesizedExpression */ || node.kind === 260 /* VariableDeclaration */ || node.kind === 281 /* ExportSpecifier */ ? concatenate(getTrailingCommentRanges(text, node.pos), getLeadingCommentRanges(text, node.pos)) : getLeadingCommentRanges(text, node.pos); return filter(commentRanges, (comment) => text.charCodeAt(comment.pos + 1) === 42 /* asterisk */ && text.charCodeAt(comment.pos + 2) === 42 /* asterisk */ && text.charCodeAt(comment.pos + 3) !== 47 /* slash */); } function isPartOfTypeNode(node) { - if (181 /* FirstTypeNode */ <= node.kind && node.kind <= 204 /* LastTypeNode */) { + if (182 /* FirstTypeNode */ <= node.kind && node.kind <= 205 /* LastTypeNode */) { return true; } switch (node.kind) { case 133 /* AnyKeyword */: case 159 /* UnknownKeyword */: case 150 /* NumberKeyword */: - case 162 /* BigIntKeyword */: + case 163 /* BigIntKeyword */: case 154 /* StringKeyword */: case 136 /* BooleanKeyword */: case 155 /* SymbolKeyword */: @@ -113269,64 +95552,61 @@ ${lanes.join("\n")} case 146 /* NeverKeyword */: return true; case 116 /* VoidKeyword */: - return node.parent.kind !== 221 /* VoidExpression */; - case 232 /* ExpressionWithTypeArguments */: + return node.parent.kind !== 222 /* VoidExpression */; + case 233 /* ExpressionWithTypeArguments */: return isHeritageClause(node.parent) && !isExpressionWithTypeArgumentsInClassExtendsClause(node); - case 167 /* TypeParameter */: - return node.parent.kind === 199 /* MappedType */ || node.parent.kind === 194 /* InferType */; + case 168 /* TypeParameter */: + return node.parent.kind === 200 /* MappedType */ || node.parent.kind === 195 /* InferType */; case 80 /* Identifier */: - if (node.parent.kind === 165 /* QualifiedName */ && node.parent.right === node) { + if (node.parent.kind === 166 /* QualifiedName */ && node.parent.right === node) { node = node.parent; - } else if (node.parent.kind === 210 /* PropertyAccessExpression */ && node.parent.name === node) { + } else if (node.parent.kind === 211 /* PropertyAccessExpression */ && node.parent.name === node) { node = node.parent; } - Debug.assert( - node.kind === 80 /* Identifier */ || node.kind === 165 /* QualifiedName */ || node.kind === 210 /* PropertyAccessExpression */, - "'node' was expected to be a qualified name, identifier or property access in 'isPartOfTypeNode'." - ); - case 165 /* QualifiedName */: - case 210 /* PropertyAccessExpression */: + Debug.assert(node.kind === 80 /* Identifier */ || node.kind === 166 /* QualifiedName */ || node.kind === 211 /* PropertyAccessExpression */, "'node' was expected to be a qualified name, identifier or property access in 'isPartOfTypeNode'."); + case 166 /* QualifiedName */: + case 211 /* PropertyAccessExpression */: case 110 /* ThisKeyword */: { const { parent: parent2 } = node; - if (parent2.kind === 185 /* TypeQuery */) { + if (parent2.kind === 186 /* TypeQuery */) { return false; } - if (parent2.kind === 204 /* ImportType */) { + if (parent2.kind === 205 /* ImportType */) { return !parent2.isTypeOf; } - if (181 /* FirstTypeNode */ <= parent2.kind && parent2.kind <= 204 /* LastTypeNode */) { + if (182 /* FirstTypeNode */ <= parent2.kind && parent2.kind <= 205 /* LastTypeNode */) { return true; } switch (parent2.kind) { - case 232 /* ExpressionWithTypeArguments */: + case 233 /* ExpressionWithTypeArguments */: return isHeritageClause(parent2.parent) && !isExpressionWithTypeArgumentsInClassExtendsClause(parent2); - case 167 /* TypeParameter */: + case 168 /* TypeParameter */: return node === parent2.constraint; - case 351 /* JSDocTemplateTag */: + case 352 /* JSDocTemplateTag */: return node === parent2.constraint; - case 171 /* PropertyDeclaration */: - case 170 /* PropertySignature */: - case 168 /* Parameter */: - case 259 /* VariableDeclaration */: + case 172 /* PropertyDeclaration */: + case 171 /* PropertySignature */: + case 169 /* Parameter */: + case 260 /* VariableDeclaration */: return node === parent2.type; - case 261 /* FunctionDeclaration */: - case 217 /* FunctionExpression */: - case 218 /* ArrowFunction */: - case 175 /* Constructor */: - case 173 /* MethodDeclaration */: - case 172 /* MethodSignature */: - case 176 /* GetAccessor */: - case 177 /* SetAccessor */: + case 262 /* FunctionDeclaration */: + case 218 /* FunctionExpression */: + case 219 /* ArrowFunction */: + case 176 /* Constructor */: + case 174 /* MethodDeclaration */: + case 173 /* MethodSignature */: + case 177 /* GetAccessor */: + case 178 /* SetAccessor */: return node === parent2.type; - case 178 /* CallSignature */: - case 179 /* ConstructSignature */: - case 180 /* IndexSignature */: + case 179 /* CallSignature */: + case 180 /* ConstructSignature */: + case 181 /* IndexSignature */: return node === parent2.type; - case 215 /* TypeAssertionExpression */: + case 216 /* TypeAssertionExpression */: return node === parent2.type; - case 212 /* CallExpression */: - case 213 /* NewExpression */: - case 214 /* TaggedTemplateExpression */: + case 213 /* CallExpression */: + case 214 /* NewExpression */: + case 215 /* TaggedTemplateExpression */: return contains(parent2.typeArguments, node); } } @@ -113346,23 +95626,23 @@ ${lanes.join("\n")} return traverse(body); function traverse(node) { switch (node.kind) { - case 252 /* ReturnStatement */: + case 253 /* ReturnStatement */: return visitor(node); - case 268 /* CaseBlock */: - case 240 /* Block */: - case 244 /* IfStatement */: - case 245 /* DoStatement */: - case 246 /* WhileStatement */: - case 247 /* ForStatement */: - case 248 /* ForInStatement */: - case 249 /* ForOfStatement */: - case 253 /* WithStatement */: - case 254 /* SwitchStatement */: - case 295 /* CaseClause */: - case 296 /* DefaultClause */: - case 255 /* LabeledStatement */: - case 257 /* TryStatement */: - case 298 /* CatchClause */: + case 269 /* CaseBlock */: + case 241 /* Block */: + case 245 /* IfStatement */: + case 246 /* DoStatement */: + case 247 /* WhileStatement */: + case 248 /* ForStatement */: + case 249 /* ForInStatement */: + case 250 /* ForOfStatement */: + case 254 /* WithStatement */: + case 255 /* SwitchStatement */: + case 296 /* CaseClause */: + case 297 /* DefaultClause */: + case 256 /* LabeledStatement */: + case 258 /* TryStatement */: + case 299 /* CatchClause */: return forEachChild(node, traverse); } } @@ -113371,21 +95651,21 @@ ${lanes.join("\n")} return traverse(body); function traverse(node) { switch (node.kind) { - case 228 /* YieldExpression */: + case 229 /* YieldExpression */: visitor(node); const operand = node.expression; if (operand) { traverse(operand); } return; - case 265 /* EnumDeclaration */: - case 263 /* InterfaceDeclaration */: - case 266 /* ModuleDeclaration */: - case 264 /* TypeAliasDeclaration */: + case 266 /* EnumDeclaration */: + case 264 /* InterfaceDeclaration */: + case 267 /* ModuleDeclaration */: + case 265 /* TypeAliasDeclaration */: return; default: if (isFunctionLike(node)) { - if (node.name && node.name.kind === 166 /* ComputedPropertyName */) { + if (node.name && node.name.kind === 167 /* ComputedPropertyName */) { traverse(node.name.expression); return; } @@ -113396,9 +95676,9 @@ ${lanes.join("\n")} } } function getRestParameterElementType(node) { - if (node && node.kind === 187 /* ArrayType */) { + if (node && node.kind === 188 /* ArrayType */) { return node.elementType; - } else if (node && node.kind === 182 /* TypeReference */) { + } else if (node && node.kind === 183 /* TypeReference */) { return singleOrUndefined(node.typeArguments); } else { return void 0; @@ -113406,26 +95686,26 @@ ${lanes.join("\n")} } function getMembersOfDeclaration(node) { switch (node.kind) { - case 263 /* InterfaceDeclaration */: - case 262 /* ClassDeclaration */: - case 230 /* ClassExpression */: - case 186 /* TypeLiteral */: + case 264 /* InterfaceDeclaration */: + case 263 /* ClassDeclaration */: + case 231 /* ClassExpression */: + case 187 /* TypeLiteral */: return node.members; - case 209 /* ObjectLiteralExpression */: + case 210 /* ObjectLiteralExpression */: return node.properties; } } function isVariableLike(node) { if (node) { switch (node.kind) { - case 207 /* BindingElement */: - case 305 /* EnumMember */: - case 168 /* Parameter */: - case 302 /* PropertyAssignment */: - case 171 /* PropertyDeclaration */: - case 170 /* PropertySignature */: - case 303 /* ShorthandPropertyAssignment */: - case 259 /* VariableDeclaration */: + case 208 /* BindingElement */: + case 306 /* EnumMember */: + case 169 /* Parameter */: + case 303 /* PropertyAssignment */: + case 172 /* PropertyDeclaration */: + case 171 /* PropertySignature */: + case 304 /* ShorthandPropertyAssignment */: + case 260 /* VariableDeclaration */: return true; } } @@ -113435,7 +95715,7 @@ ${lanes.join("\n")} return isVariableLike(node) || isAccessor(node); } function isVariableDeclarationInVariableStatement(node) { - return node.parent.kind === 260 /* VariableDeclarationList */ && node.parent.parent.kind === 242 /* VariableStatement */; + return node.parent.kind === 261 /* VariableDeclarationList */ && node.parent.parent.kind === 243 /* VariableStatement */; } function isCommonJsExportedExpression(node) { if (!isInJSFile(node)) @@ -113452,13 +95732,13 @@ ${lanes.join("\n")} } function introducesArgumentsExoticObject(node) { switch (node.kind) { - case 173 /* MethodDeclaration */: - case 172 /* MethodSignature */: - case 175 /* Constructor */: - case 176 /* GetAccessor */: - case 177 /* SetAccessor */: - case 261 /* FunctionDeclaration */: - case 217 /* FunctionExpression */: + case 174 /* MethodDeclaration */: + case 173 /* MethodSignature */: + case 176 /* Constructor */: + case 177 /* GetAccessor */: + case 178 /* SetAccessor */: + case 262 /* FunctionDeclaration */: + case 218 /* FunctionExpression */: return true; } return false; @@ -113468,20 +95748,20 @@ ${lanes.join("\n")} if (beforeUnwrapLabelCallback) { beforeUnwrapLabelCallback(node); } - if (node.statement.kind !== 255 /* LabeledStatement */) { + if (node.statement.kind !== 256 /* LabeledStatement */) { return node.statement; } node = node.statement; } } function isFunctionBlock(node) { - return node && node.kind === 240 /* Block */ && isFunctionLike(node.parent); + return node && node.kind === 241 /* Block */ && isFunctionLike(node.parent); } function isObjectLiteralMethod(node) { - return node && node.kind === 173 /* MethodDeclaration */ && node.parent.kind === 209 /* ObjectLiteralExpression */; + return node && node.kind === 174 /* MethodDeclaration */ && node.parent.kind === 210 /* ObjectLiteralExpression */; } function isObjectLiteralOrClassExpressionMethodOrAccessor(node) { - return (node.kind === 173 /* MethodDeclaration */ || node.kind === 176 /* GetAccessor */ || node.kind === 177 /* SetAccessor */) && (node.parent.kind === 209 /* ObjectLiteralExpression */ || node.parent.kind === 230 /* ClassExpression */); + return (node.kind === 174 /* MethodDeclaration */ || node.kind === 177 /* GetAccessor */ || node.kind === 178 /* SetAccessor */) && (node.parent.kind === 210 /* ObjectLiteralExpression */ || node.parent.kind === 231 /* ClassExpression */); } function isIdentifierTypePredicate(predicate) { return predicate && predicate.kind === 1 /* Identifier */; @@ -113498,11 +95778,7 @@ ${lanes.join("\n")} }); } function getPropertyArrayElementValue(objectLiteral, propKey, elementValue) { - return forEachPropertyAssignment( - objectLiteral, - propKey, - (property) => isArrayLiteralExpression(property.initializer) ? find(property.initializer.elements, (element) => isStringLiteral(element) && element.text === elementValue) : void 0 - ); + return forEachPropertyAssignment(objectLiteral, propKey, (property) => isArrayLiteralExpression(property.initializer) ? find(property.initializer.elements, (element) => isStringLiteral(element) && element.text === elementValue) : void 0); } function getTsConfigObjectLiteralExpression(tsConfigSourceFile) { if (tsConfigSourceFile && tsConfigSourceFile.statements.length) { @@ -113536,64 +95812,68 @@ ${lanes.join("\n")} function getContainingFunctionOrClassStaticBlock(node) { return findAncestor(node.parent, isFunctionLikeOrClassStaticBlockDeclaration); } + function getContainingClassExcludingClassDecorators(node) { + const decorator = findAncestor(node.parent, (n) => isClassLike(n) ? "quit" : isDecorator(n)); + return decorator && isClassLike(decorator.parent) ? getContainingClass(decorator.parent) : getContainingClass(decorator ?? node); + } function getThisContainer(node, includeArrowFunctions, includeClassComputedPropertyName) { - Debug.assert(node.kind !== 311 /* SourceFile */); + Debug.assert(node.kind !== 312 /* SourceFile */); while (true) { node = node.parent; if (!node) { return Debug.fail(); } switch (node.kind) { - case 166 /* ComputedPropertyName */: + case 167 /* ComputedPropertyName */: if (includeClassComputedPropertyName && isClassLike(node.parent.parent)) { return node; } node = node.parent.parent; break; - case 169 /* Decorator */: - if (node.parent.kind === 168 /* Parameter */ && isClassElement(node.parent.parent)) { + case 170 /* Decorator */: + if (node.parent.kind === 169 /* Parameter */ && isClassElement(node.parent.parent)) { node = node.parent.parent; } else if (isClassElement(node.parent)) { node = node.parent; } break; - case 218 /* ArrowFunction */: + case 219 /* ArrowFunction */: if (!includeArrowFunctions) { continue; } - case 261 /* FunctionDeclaration */: - case 217 /* FunctionExpression */: - case 266 /* ModuleDeclaration */: - case 174 /* ClassStaticBlockDeclaration */: - case 171 /* PropertyDeclaration */: - case 170 /* PropertySignature */: - case 173 /* MethodDeclaration */: - case 172 /* MethodSignature */: - case 175 /* Constructor */: - case 176 /* GetAccessor */: - case 177 /* SetAccessor */: - case 178 /* CallSignature */: - case 179 /* ConstructSignature */: - case 180 /* IndexSignature */: - case 265 /* EnumDeclaration */: - case 311 /* SourceFile */: + case 262 /* FunctionDeclaration */: + case 218 /* FunctionExpression */: + case 267 /* ModuleDeclaration */: + case 175 /* ClassStaticBlockDeclaration */: + case 172 /* PropertyDeclaration */: + case 171 /* PropertySignature */: + case 174 /* MethodDeclaration */: + case 173 /* MethodSignature */: + case 176 /* Constructor */: + case 177 /* GetAccessor */: + case 178 /* SetAccessor */: + case 179 /* CallSignature */: + case 180 /* ConstructSignature */: + case 181 /* IndexSignature */: + case 266 /* EnumDeclaration */: + case 312 /* SourceFile */: return node; } } } function isThisContainerOrFunctionBlock(node) { switch (node.kind) { - case 218 /* ArrowFunction */: - case 261 /* FunctionDeclaration */: - case 217 /* FunctionExpression */: - case 171 /* PropertyDeclaration */: + case 219 /* ArrowFunction */: + case 262 /* FunctionDeclaration */: + case 218 /* FunctionExpression */: + case 172 /* PropertyDeclaration */: return true; - case 240 /* Block */: + case 241 /* Block */: switch (node.parent.kind) { - case 175 /* Constructor */: - case 173 /* MethodDeclaration */: - case 176 /* GetAccessor */: - case 177 /* SetAccessor */: + case 176 /* Constructor */: + case 174 /* MethodDeclaration */: + case 177 /* GetAccessor */: + case 178 /* SetAccessor */: return true; default: return false; @@ -113625,9 +95905,9 @@ ${lanes.join("\n")} ); if (container) { switch (container.kind) { - case 175 /* Constructor */: - case 261 /* FunctionDeclaration */: - case 217 /* FunctionExpression */: + case 176 /* Constructor */: + case 262 /* FunctionDeclaration */: + case 218 /* FunctionExpression */: return container; } } @@ -113640,26 +95920,26 @@ ${lanes.join("\n")} return void 0; } switch (node.kind) { - case 166 /* ComputedPropertyName */: + case 167 /* ComputedPropertyName */: node = node.parent; break; - case 261 /* FunctionDeclaration */: - case 217 /* FunctionExpression */: - case 218 /* ArrowFunction */: + case 262 /* FunctionDeclaration */: + case 218 /* FunctionExpression */: + case 219 /* ArrowFunction */: if (!stopOnFunctions) { continue; } - case 171 /* PropertyDeclaration */: - case 170 /* PropertySignature */: - case 173 /* MethodDeclaration */: - case 172 /* MethodSignature */: - case 175 /* Constructor */: - case 176 /* GetAccessor */: - case 177 /* SetAccessor */: - case 174 /* ClassStaticBlockDeclaration */: + case 172 /* PropertyDeclaration */: + case 171 /* PropertySignature */: + case 174 /* MethodDeclaration */: + case 173 /* MethodSignature */: + case 176 /* Constructor */: + case 177 /* GetAccessor */: + case 178 /* SetAccessor */: + case 175 /* ClassStaticBlockDeclaration */: return node; - case 169 /* Decorator */: - if (node.parent.kind === 168 /* Parameter */ && isClassElement(node.parent.parent)) { + case 170 /* Decorator */: + if (node.parent.kind === 169 /* Parameter */ && isClassElement(node.parent.parent)) { node = node.parent.parent; } else if (isClassElement(node.parent)) { node = node.parent; @@ -113669,14 +95949,14 @@ ${lanes.join("\n")} } } function getImmediatelyInvokedFunctionExpression(func) { - if (func.kind === 217 /* FunctionExpression */ || func.kind === 218 /* ArrowFunction */) { + if (func.kind === 218 /* FunctionExpression */ || func.kind === 219 /* ArrowFunction */) { let prev = func; let parent2 = func.parent; - while (parent2.kind === 216 /* ParenthesizedExpression */) { + while (parent2.kind === 217 /* ParenthesizedExpression */) { prev = parent2; parent2 = parent2.parent; } - if (parent2.kind === 212 /* CallExpression */ && parent2.expression === prev) { + if (parent2.kind === 213 /* CallExpression */ && parent2.expression === prev) { return parent2; } } @@ -113686,11 +95966,11 @@ ${lanes.join("\n")} } function isSuperProperty(node) { const kind = node.kind; - return (kind === 210 /* PropertyAccessExpression */ || kind === 211 /* ElementAccessExpression */) && node.expression.kind === 108 /* SuperKeyword */; + return (kind === 211 /* PropertyAccessExpression */ || kind === 212 /* ElementAccessExpression */) && node.expression.kind === 108 /* SuperKeyword */; } function isThisProperty(node) { const kind = node.kind; - return (kind === 210 /* PropertyAccessExpression */ || kind === 211 /* ElementAccessExpression */) && node.expression.kind === 110 /* ThisKeyword */; + return (kind === 211 /* PropertyAccessExpression */ || kind === 212 /* ElementAccessExpression */) && node.expression.kind === 110 /* ThisKeyword */; } function isThisInitializedDeclaration(node) { var _a; @@ -113701,23 +95981,25 @@ ${lanes.join("\n")} } function getEntityNameFromTypeNode(node) { switch (node.kind) { - case 182 /* TypeReference */: + case 183 /* TypeReference */: return node.typeName; - case 232 /* ExpressionWithTypeArguments */: + case 233 /* ExpressionWithTypeArguments */: return isEntityNameExpression(node.expression) ? node.expression : void 0; case 80 /* Identifier */: - case 165 /* QualifiedName */: + case 166 /* QualifiedName */: return node; } return void 0; } function getInvokedExpression(node) { switch (node.kind) { - case 214 /* TaggedTemplateExpression */: + case 215 /* TaggedTemplateExpression */: return node.tag; - case 285 /* JsxOpeningElement */: - case 284 /* JsxSelfClosingElement */: + case 286 /* JsxOpeningElement */: + case 285 /* JsxSelfClosingElement */: return node.tagName; + case 226 /* BinaryExpression */: + return node.right; default: return node.expression; } @@ -113727,20 +96009,20 @@ ${lanes.join("\n")} return false; } switch (node.kind) { - case 262 /* ClassDeclaration */: + case 263 /* ClassDeclaration */: return true; - case 230 /* ClassExpression */: + case 231 /* ClassExpression */: return !useLegacyDecorators; - case 171 /* PropertyDeclaration */: + case 172 /* PropertyDeclaration */: return parent2 !== void 0 && (useLegacyDecorators ? isClassDeclaration(parent2) : isClassLike(parent2) && !hasAbstractModifier(node) && !hasAmbientModifier(node)); - case 176 /* GetAccessor */: - case 177 /* SetAccessor */: - case 173 /* MethodDeclaration */: + case 177 /* GetAccessor */: + case 178 /* SetAccessor */: + case 174 /* MethodDeclaration */: return node.body !== void 0 && parent2 !== void 0 && (useLegacyDecorators ? isClassDeclaration(parent2) : isClassLike(parent2)); - case 168 /* Parameter */: + case 169 /* Parameter */: if (!useLegacyDecorators) return false; - return parent2 !== void 0 && parent2.body !== void 0 && (parent2.kind === 175 /* Constructor */ || parent2.kind === 173 /* MethodDeclaration */ || parent2.kind === 177 /* SetAccessor */) && getThisParameter(parent2) !== node && grandparent !== void 0 && grandparent.kind === 262 /* ClassDeclaration */; + return parent2 !== void 0 && parent2.body !== void 0 && (parent2.kind === 176 /* Constructor */ || parent2.kind === 174 /* MethodDeclaration */ || parent2.kind === 178 /* SetAccessor */) && getThisParameter(parent2) !== node && grandparent !== void 0 && grandparent.kind === 263 /* ClassDeclaration */; } return false; } @@ -113752,13 +96034,13 @@ ${lanes.join("\n")} } function childIsDecorated(useLegacyDecorators, node, parent2) { switch (node.kind) { - case 262 /* ClassDeclaration */: + case 263 /* ClassDeclaration */: return some(node.members, (m) => nodeOrChildIsDecorated(useLegacyDecorators, m, node, parent2)); - case 230 /* ClassExpression */: + case 231 /* ClassExpression */: return !useLegacyDecorators && some(node.members, (m) => nodeOrChildIsDecorated(useLegacyDecorators, m, node, parent2)); - case 173 /* MethodDeclaration */: - case 177 /* SetAccessor */: - case 175 /* Constructor */: + case 174 /* MethodDeclaration */: + case 178 /* SetAccessor */: + case 176 /* Constructor */: return some(node.parameters, (p) => nodeIsDecorated(useLegacyDecorators, p, node, parent2)); default: return false; @@ -113809,7 +96091,7 @@ ${lanes.join("\n")} } function isJSXTagName(node) { const { parent: parent2 } = node; - if (parent2.kind === 285 /* JsxOpeningElement */ || parent2.kind === 284 /* JsxSelfClosingElement */ || parent2.kind === 286 /* JsxClosingElement */) { + if (parent2.kind === 286 /* JsxOpeningElement */ || parent2.kind === 285 /* JsxSelfClosingElement */ || parent2.kind === 287 /* JsxClosingElement */) { return parent2.tagName === node; } return false; @@ -113821,54 +96103,54 @@ ${lanes.join("\n")} case 112 /* TrueKeyword */: case 97 /* FalseKeyword */: case 14 /* RegularExpressionLiteral */: - case 208 /* ArrayLiteralExpression */: - case 209 /* ObjectLiteralExpression */: - case 210 /* PropertyAccessExpression */: - case 211 /* ElementAccessExpression */: - case 212 /* CallExpression */: - case 213 /* NewExpression */: - case 214 /* TaggedTemplateExpression */: - case 233 /* AsExpression */: - case 215 /* TypeAssertionExpression */: - case 237 /* SatisfiesExpression */: - case 234 /* NonNullExpression */: - case 216 /* ParenthesizedExpression */: - case 217 /* FunctionExpression */: - case 230 /* ClassExpression */: - case 218 /* ArrowFunction */: - case 221 /* VoidExpression */: - case 219 /* DeleteExpression */: - case 220 /* TypeOfExpression */: - case 223 /* PrefixUnaryExpression */: - case 224 /* PostfixUnaryExpression */: - case 225 /* BinaryExpression */: - case 226 /* ConditionalExpression */: - case 229 /* SpreadElement */: - case 227 /* TemplateExpression */: - case 231 /* OmittedExpression */: - case 283 /* JsxElement */: - case 284 /* JsxSelfClosingElement */: - case 287 /* JsxFragment */: - case 228 /* YieldExpression */: - case 222 /* AwaitExpression */: - case 235 /* MetaProperty */: + case 209 /* ArrayLiteralExpression */: + case 210 /* ObjectLiteralExpression */: + case 211 /* PropertyAccessExpression */: + case 212 /* ElementAccessExpression */: + case 213 /* CallExpression */: + case 214 /* NewExpression */: + case 215 /* TaggedTemplateExpression */: + case 234 /* AsExpression */: + case 216 /* TypeAssertionExpression */: + case 238 /* SatisfiesExpression */: + case 235 /* NonNullExpression */: + case 217 /* ParenthesizedExpression */: + case 218 /* FunctionExpression */: + case 231 /* ClassExpression */: + case 219 /* ArrowFunction */: + case 222 /* VoidExpression */: + case 220 /* DeleteExpression */: + case 221 /* TypeOfExpression */: + case 224 /* PrefixUnaryExpression */: + case 225 /* PostfixUnaryExpression */: + case 226 /* BinaryExpression */: + case 227 /* ConditionalExpression */: + case 230 /* SpreadElement */: + case 228 /* TemplateExpression */: + case 232 /* OmittedExpression */: + case 284 /* JsxElement */: + case 285 /* JsxSelfClosingElement */: + case 288 /* JsxFragment */: + case 229 /* YieldExpression */: + case 223 /* AwaitExpression */: + case 236 /* MetaProperty */: return true; - case 232 /* ExpressionWithTypeArguments */: + case 233 /* ExpressionWithTypeArguments */: return !isHeritageClause(node.parent) && !isJSDocAugmentsTag(node.parent); - case 165 /* QualifiedName */: - while (node.parent.kind === 165 /* QualifiedName */) { + case 166 /* QualifiedName */: + while (node.parent.kind === 166 /* QualifiedName */) { node = node.parent; } - return node.parent.kind === 185 /* TypeQuery */ || isJSDocLinkLike(node.parent) || isJSDocNameReference(node.parent) || isJSDocMemberName(node.parent) || isJSXTagName(node); - case 317 /* JSDocMemberName */: + return node.parent.kind === 186 /* TypeQuery */ || isJSDocLinkLike(node.parent) || isJSDocNameReference(node.parent) || isJSDocMemberName(node.parent) || isJSXTagName(node); + case 318 /* JSDocMemberName */: while (isJSDocMemberName(node.parent)) { node = node.parent; } - return node.parent.kind === 185 /* TypeQuery */ || isJSDocLinkLike(node.parent) || isJSDocNameReference(node.parent) || isJSDocMemberName(node.parent) || isJSXTagName(node); + return node.parent.kind === 186 /* TypeQuery */ || isJSDocLinkLike(node.parent) || isJSDocNameReference(node.parent) || isJSDocMemberName(node.parent) || isJSXTagName(node); case 81 /* PrivateIdentifier */: return isBinaryExpression(node.parent) && node.parent.left === node && node.parent.operatorToken.kind === 103 /* InKeyword */; case 80 /* Identifier */: - if (node.parent.kind === 185 /* TypeQuery */ || isJSDocLinkLike(node.parent) || isJSDocNameReference(node.parent) || isJSDocMemberName(node.parent) || isJSXTagName(node)) { + if (node.parent.kind === 186 /* TypeQuery */ || isJSDocLinkLike(node.parent) || isJSDocNameReference(node.parent) || isJSDocMemberName(node.parent) || isJSXTagName(node)) { return true; } case 9 /* NumericLiteral */: @@ -113884,64 +96166,64 @@ ${lanes.join("\n")} function isInExpressionContext(node) { const { parent: parent2 } = node; switch (parent2.kind) { - case 259 /* VariableDeclaration */: - case 168 /* Parameter */: - case 171 /* PropertyDeclaration */: - case 170 /* PropertySignature */: - case 305 /* EnumMember */: - case 302 /* PropertyAssignment */: - case 207 /* BindingElement */: + case 260 /* VariableDeclaration */: + case 169 /* Parameter */: + case 172 /* PropertyDeclaration */: + case 171 /* PropertySignature */: + case 306 /* EnumMember */: + case 303 /* PropertyAssignment */: + case 208 /* BindingElement */: return parent2.initializer === node; - case 243 /* ExpressionStatement */: - case 244 /* IfStatement */: - case 245 /* DoStatement */: - case 246 /* WhileStatement */: - case 252 /* ReturnStatement */: - case 253 /* WithStatement */: - case 254 /* SwitchStatement */: - case 295 /* CaseClause */: - case 256 /* ThrowStatement */: + case 244 /* ExpressionStatement */: + case 245 /* IfStatement */: + case 246 /* DoStatement */: + case 247 /* WhileStatement */: + case 253 /* ReturnStatement */: + case 254 /* WithStatement */: + case 255 /* SwitchStatement */: + case 296 /* CaseClause */: + case 257 /* ThrowStatement */: return parent2.expression === node; - case 247 /* ForStatement */: + case 248 /* ForStatement */: const forStatement = parent2; - return forStatement.initializer === node && forStatement.initializer.kind !== 260 /* VariableDeclarationList */ || forStatement.condition === node || forStatement.incrementor === node; - case 248 /* ForInStatement */: - case 249 /* ForOfStatement */: - const forInStatement = parent2; - return forInStatement.initializer === node && forInStatement.initializer.kind !== 260 /* VariableDeclarationList */ || forInStatement.expression === node; - case 215 /* TypeAssertionExpression */: - case 233 /* AsExpression */: + return forStatement.initializer === node && forStatement.initializer.kind !== 261 /* VariableDeclarationList */ || forStatement.condition === node || forStatement.incrementor === node; + case 249 /* ForInStatement */: + case 250 /* ForOfStatement */: + const forInOrOfStatement = parent2; + return forInOrOfStatement.initializer === node && forInOrOfStatement.initializer.kind !== 261 /* VariableDeclarationList */ || forInOrOfStatement.expression === node; + case 216 /* TypeAssertionExpression */: + case 234 /* AsExpression */: return node === parent2.expression; - case 238 /* TemplateSpan */: + case 239 /* TemplateSpan */: return node === parent2.expression; - case 166 /* ComputedPropertyName */: + case 167 /* ComputedPropertyName */: return node === parent2.expression; - case 169 /* Decorator */: - case 293 /* JsxExpression */: - case 292 /* JsxSpreadAttribute */: - case 304 /* SpreadAssignment */: + case 170 /* Decorator */: + case 294 /* JsxExpression */: + case 293 /* JsxSpreadAttribute */: + case 305 /* SpreadAssignment */: return true; - case 232 /* ExpressionWithTypeArguments */: + case 233 /* ExpressionWithTypeArguments */: return parent2.expression === node && !isPartOfTypeNode(parent2); - case 303 /* ShorthandPropertyAssignment */: + case 304 /* ShorthandPropertyAssignment */: return parent2.objectAssignmentInitializer === node; - case 237 /* SatisfiesExpression */: + case 238 /* SatisfiesExpression */: return node === parent2.expression; default: return isExpressionNode(parent2); } } function isPartOfTypeQuery(node) { - while (node.kind === 165 /* QualifiedName */ || node.kind === 80 /* Identifier */) { + while (node.kind === 166 /* QualifiedName */ || node.kind === 80 /* Identifier */) { node = node.parent; } - return node.kind === 185 /* TypeQuery */; + return node.kind === 186 /* TypeQuery */; } function isNamespaceReexportDeclaration(node) { return isNamespaceExport(node) && !!node.parent.moduleSpecifier; } function isExternalModuleImportEqualsDeclaration(node) { - return node.kind === 270 /* ImportEqualsDeclaration */ && node.moduleReference.kind === 282 /* ExternalModuleReference */; + return node.kind === 271 /* ImportEqualsDeclaration */ && node.moduleReference.kind === 283 /* ExternalModuleReference */; } function getExternalModuleImportEqualsDeclarationExpression(node) { Debug.assert(isExternalModuleImportEqualsDeclaration(node)); @@ -113951,7 +96233,7 @@ ${lanes.join("\n")} return isVariableDeclarationInitializedToBareOrAccessedRequire(node) && getLeftmostAccessExpression(node.initializer).arguments[0]; } function isInternalModuleImportEqualsDeclaration(node) { - return node.kind === 270 /* ImportEqualsDeclaration */ && node.moduleReference.kind !== 282 /* ExternalModuleReference */; + return node.kind === 271 /* ImportEqualsDeclaration */ && node.moduleReference.kind !== 283 /* ExternalModuleReference */; } function isSourceFileJS(file) { return isInJSFile(file); @@ -113960,22 +96242,22 @@ ${lanes.join("\n")} return !isInJSFile(file); } function isInJSFile(node) { - return !!node && !!(node.flags & 262144 /* JavaScriptFile */); + return !!node && !!(node.flags & 524288 /* JavaScriptFile */); } function isInJsonFile(node) { - return !!node && !!(node.flags & 67108864 /* JsonFile */); + return !!node && !!(node.flags & 134217728 /* JsonFile */); } function isSourceFileNotJson(file) { return !isJsonSourceFile(file); } function isInJSDoc(node) { - return !!node && !!(node.flags & 8388608 /* JSDoc */); + return !!node && !!(node.flags & 16777216 /* JSDoc */); } function isJSDocIndexSignature(node) { return isTypeReferenceNode(node) && isIdentifier(node.typeName) && node.typeName.escapedText === "Object" && node.typeArguments && node.typeArguments.length === 2 && (node.typeArguments[0].kind === 154 /* StringKeyword */ || node.typeArguments[0].kind === 150 /* NumberKeyword */); } function isRequireCall(callExpression, requireStringLiteralLikeArgument) { - if (callExpression.kind !== 212 /* CallExpression */) { + if (callExpression.kind !== 213 /* CallExpression */) { return false; } const { expression, arguments: args } = callExpression; @@ -114052,9 +96334,9 @@ ${lanes.join("\n")} function getExpandoInitializer(initializer, isPrototypeAssignment) { if (isCallExpression(initializer)) { const e = skipParentheses(initializer.expression); - return e.kind === 217 /* FunctionExpression */ || e.kind === 218 /* ArrowFunction */ ? initializer : void 0; + return e.kind === 218 /* FunctionExpression */ || e.kind === 219 /* ArrowFunction */ ? initializer : void 0; } - if (initializer.kind === 217 /* FunctionExpression */ || initializer.kind === 230 /* ClassExpression */ || initializer.kind === 218 /* ArrowFunction */) { + if (initializer.kind === 218 /* FunctionExpression */ || initializer.kind === 231 /* ClassExpression */ || initializer.kind === 219 /* ArrowFunction */) { return initializer; } if (isObjectLiteralExpression(initializer) && (initializer.properties.length === 0 || isPrototypeAssignment)) { @@ -114245,11 +96527,11 @@ ${lanes.join("\n")} return isBinaryExpression(node) && getAssignmentDeclarationKind(node) === 3 /* PrototypeProperty */; } function isSpecialPropertyDeclaration(expr) { - return isInJSFile(expr) && expr.parent && expr.parent.kind === 243 /* ExpressionStatement */ && (!isElementAccessExpression(expr) || isLiteralLikeElementAccess(expr)) && !!getJSDocTypeTag(expr.parent); + return isInJSFile(expr) && expr.parent && expr.parent.kind === 244 /* ExpressionStatement */ && (!isElementAccessExpression(expr) || isLiteralLikeElementAccess(expr)) && !!getJSDocTypeTag(expr.parent); } function setValueDeclaration(symbol, node) { const { valueDeclaration } = symbol; - if (!valueDeclaration || !(node.flags & 16777216 /* Ambient */ && !isInJSFile(node) && !(valueDeclaration.flags & 16777216 /* Ambient */)) && (isAssignmentDeclaration(valueDeclaration) && !isAssignmentDeclaration(node)) || valueDeclaration.kind !== node.kind && isEffectiveModuleDeclaration(valueDeclaration)) { + if (!valueDeclaration || !(node.flags & 33554432 /* Ambient */ && !isInJSFile(node) && !(valueDeclaration.flags & 33554432 /* Ambient */)) && (isAssignmentDeclaration(valueDeclaration) && !isAssignmentDeclaration(node)) || valueDeclaration.kind !== node.kind && isEffectiveModuleDeclaration(valueDeclaration)) { symbol.valueDeclaration = node; } } @@ -114258,30 +96540,33 @@ ${lanes.join("\n")} return false; } const decl = symbol.valueDeclaration; - return decl.kind === 261 /* FunctionDeclaration */ || isVariableDeclaration(decl) && decl.initializer && isFunctionLike(decl.initializer); + return decl.kind === 262 /* FunctionDeclaration */ || isVariableDeclaration(decl) && decl.initializer && isFunctionLike(decl.initializer); } function tryGetModuleSpecifierFromDeclaration(node) { var _a, _b; switch (node.kind) { - case 259 /* VariableDeclaration */: - case 207 /* BindingElement */: + case 260 /* VariableDeclaration */: + case 208 /* BindingElement */: return (_a = findAncestor(node.initializer, (node2) => isRequireCall( node2, /*requireStringLiteralLikeArgument*/ true ))) == null ? void 0 : _a.arguments[0]; - case 271 /* ImportDeclaration */: + case 272 /* ImportDeclaration */: + case 278 /* ExportDeclaration */: return tryCast(node.moduleSpecifier, isStringLiteralLike); - case 270 /* ImportEqualsDeclaration */: + case 271 /* ImportEqualsDeclaration */: return tryCast((_b = tryCast(node.moduleReference, isExternalModuleReference)) == null ? void 0 : _b.expression, isStringLiteralLike); - case 272 /* ImportClause */: - case 279 /* NamespaceExport */: + case 273 /* ImportClause */: + case 280 /* NamespaceExport */: return tryCast(node.parent.moduleSpecifier, isStringLiteralLike); - case 273 /* NamespaceImport */: - case 280 /* ExportSpecifier */: + case 274 /* NamespaceImport */: + case 281 /* ExportSpecifier */: return tryCast(node.parent.parent.moduleSpecifier, isStringLiteralLike); - case 275 /* ImportSpecifier */: + case 276 /* ImportSpecifier */: return tryCast(node.parent.parent.parent.moduleSpecifier, isStringLiteralLike); + case 205 /* ImportType */: + return isLiteralImportTypeNode(node) ? node.argument.literal : void 0; default: Debug.assertNever(node); } @@ -114291,18 +96576,18 @@ ${lanes.join("\n")} } function tryGetImportFromModuleSpecifier(node) { switch (node.parent.kind) { - case 271 /* ImportDeclaration */: - case 277 /* ExportDeclaration */: + case 272 /* ImportDeclaration */: + case 278 /* ExportDeclaration */: return node.parent; - case 282 /* ExternalModuleReference */: + case 283 /* ExternalModuleReference */: return node.parent.parent; - case 212 /* CallExpression */: + case 213 /* CallExpression */: return isImportCall(node.parent) || isRequireCall( node.parent, /*requireStringLiteralLikeArgument*/ false ) ? node.parent : void 0; - case 200 /* LiteralType */: + case 201 /* LiteralType */: Debug.assert(isStringLiteral(node)); return tryCast(node.parent.parent, isImportTypeNode); default: @@ -114311,16 +96596,16 @@ ${lanes.join("\n")} } function getExternalModuleName(node) { switch (node.kind) { - case 271 /* ImportDeclaration */: - case 277 /* ExportDeclaration */: + case 272 /* ImportDeclaration */: + case 278 /* ExportDeclaration */: return node.moduleSpecifier; - case 270 /* ImportEqualsDeclaration */: - return node.moduleReference.kind === 282 /* ExternalModuleReference */ ? node.moduleReference.expression : void 0; - case 204 /* ImportType */: + case 271 /* ImportEqualsDeclaration */: + return node.moduleReference.kind === 283 /* ExternalModuleReference */ ? node.moduleReference.expression : void 0; + case 205 /* ImportType */: return isLiteralImportTypeNode(node) ? node.argument.literal : void 0; - case 212 /* CallExpression */: + case 213 /* CallExpression */: return node.arguments[0]; - case 266 /* ModuleDeclaration */: + case 267 /* ModuleDeclaration */: return node.name.kind === 11 /* StringLiteral */ ? node.name : void 0; default: return Debug.assertNever(node); @@ -114328,18 +96613,18 @@ ${lanes.join("\n")} } function getNamespaceDeclarationNode(node) { switch (node.kind) { - case 271 /* ImportDeclaration */: + case 272 /* ImportDeclaration */: return node.importClause && tryCast(node.importClause.namedBindings, isNamespaceImport); - case 270 /* ImportEqualsDeclaration */: + case 271 /* ImportEqualsDeclaration */: return node; - case 277 /* ExportDeclaration */: + case 278 /* ExportDeclaration */: return node.exportClause && tryCast(node.exportClause, isNamespaceExport); default: return Debug.assertNever(node); } } function isDefaultImport(node) { - return node.kind === 271 /* ImportDeclaration */ && !!node.importClause && !!node.importClause.name; + return node.kind === 272 /* ImportDeclaration */ && !!node.importClause && !!node.importClause.name; } function forEachImportClauseDeclaration(node, action) { if (node.name) { @@ -114356,13 +96641,13 @@ ${lanes.join("\n")} function hasQuestionToken(node) { if (node) { switch (node.kind) { - case 168 /* Parameter */: - case 173 /* MethodDeclaration */: - case 172 /* MethodSignature */: - case 303 /* ShorthandPropertyAssignment */: - case 302 /* PropertyAssignment */: - case 171 /* PropertyDeclaration */: - case 170 /* PropertySignature */: + case 169 /* Parameter */: + case 174 /* MethodDeclaration */: + case 173 /* MethodSignature */: + case 304 /* ShorthandPropertyAssignment */: + case 303 /* PropertyAssignment */: + case 172 /* PropertyDeclaration */: + case 171 /* PropertySignature */: return node.questionToken !== void 0; } } @@ -114374,7 +96659,7 @@ ${lanes.join("\n")} return !!name && name.escapedText === "new"; } function isJSDocTypeAlias(node) { - return node.kind === 352 /* JSDocTypedefTag */ || node.kind === 344 /* JSDocCallbackTag */ || node.kind === 346 /* JSDocEnumTag */; + return node.kind === 353 /* JSDocTypedefTag */ || node.kind === 345 /* JSDocCallbackTag */ || node.kind === 347 /* JSDocEnumTag */; } function isTypeAlias(node) { return isJSDocTypeAlias(node) || isTypeAliasDeclaration(node); @@ -114387,12 +96672,12 @@ ${lanes.join("\n")} } function getSingleInitializerOfVariableStatementOrPropertyDeclaration(node) { switch (node.kind) { - case 242 /* VariableStatement */: + case 243 /* VariableStatement */: const v = getSingleVariableOfVariableStatement(node); return v && v.initializer; - case 171 /* PropertyDeclaration */: + case 172 /* PropertyDeclaration */: return node.initializer; - case 302 /* PropertyAssignment */: + case 303 /* PropertyAssignment */: return node.initializer; } } @@ -114400,26 +96685,26 @@ ${lanes.join("\n")} return isVariableStatement(node) ? firstOrUndefined(node.declarationList.declarations) : void 0; } function getNestedModuleDeclaration(node) { - return isModuleDeclaration(node) && node.body && node.body.kind === 266 /* ModuleDeclaration */ ? node.body : void 0; + return isModuleDeclaration(node) && node.body && node.body.kind === 267 /* ModuleDeclaration */ ? node.body : void 0; } function canHaveFlowNode(node) { - if (node.kind >= 242 /* FirstStatement */ && node.kind <= 258 /* LastStatement */) { + if (node.kind >= 243 /* FirstStatement */ && node.kind <= 259 /* LastStatement */) { return true; } switch (node.kind) { case 80 /* Identifier */: case 110 /* ThisKeyword */: case 108 /* SuperKeyword */: - case 165 /* QualifiedName */: - case 235 /* MetaProperty */: - case 211 /* ElementAccessExpression */: - case 210 /* PropertyAccessExpression */: - case 207 /* BindingElement */: - case 217 /* FunctionExpression */: - case 218 /* ArrowFunction */: - case 173 /* MethodDeclaration */: - case 176 /* GetAccessor */: - case 177 /* SetAccessor */: + case 166 /* QualifiedName */: + case 236 /* MetaProperty */: + case 212 /* ElementAccessExpression */: + case 211 /* PropertyAccessExpression */: + case 208 /* BindingElement */: + case 218 /* FunctionExpression */: + case 219 /* ArrowFunction */: + case 174 /* MethodDeclaration */: + case 177 /* GetAccessor */: + case 178 /* SetAccessor */: return true; default: return false; @@ -114427,72 +96712,72 @@ ${lanes.join("\n")} } function canHaveJSDoc(node) { switch (node.kind) { - case 218 /* ArrowFunction */: - case 225 /* BinaryExpression */: - case 240 /* Block */: - case 251 /* BreakStatement */: - case 178 /* CallSignature */: - case 295 /* CaseClause */: - case 262 /* ClassDeclaration */: - case 230 /* ClassExpression */: - case 174 /* ClassStaticBlockDeclaration */: - case 175 /* Constructor */: - case 184 /* ConstructorType */: - case 179 /* ConstructSignature */: - case 250 /* ContinueStatement */: - case 258 /* DebuggerStatement */: - case 245 /* DoStatement */: - case 211 /* ElementAccessExpression */: - case 241 /* EmptyStatement */: + case 219 /* ArrowFunction */: + case 226 /* BinaryExpression */: + case 241 /* Block */: + case 252 /* BreakStatement */: + case 179 /* CallSignature */: + case 296 /* CaseClause */: + case 263 /* ClassDeclaration */: + case 231 /* ClassExpression */: + case 175 /* ClassStaticBlockDeclaration */: + case 176 /* Constructor */: + case 185 /* ConstructorType */: + case 180 /* ConstructSignature */: + case 251 /* ContinueStatement */: + case 259 /* DebuggerStatement */: + case 246 /* DoStatement */: + case 212 /* ElementAccessExpression */: + case 242 /* EmptyStatement */: case 1 /* EndOfFileToken */: - case 265 /* EnumDeclaration */: - case 305 /* EnumMember */: - case 276 /* ExportAssignment */: - case 277 /* ExportDeclaration */: - case 280 /* ExportSpecifier */: - case 243 /* ExpressionStatement */: - case 248 /* ForInStatement */: - case 249 /* ForOfStatement */: - case 247 /* ForStatement */: - case 261 /* FunctionDeclaration */: - case 217 /* FunctionExpression */: - case 183 /* FunctionType */: - case 176 /* GetAccessor */: + case 266 /* EnumDeclaration */: + case 306 /* EnumMember */: + case 277 /* ExportAssignment */: + case 278 /* ExportDeclaration */: + case 281 /* ExportSpecifier */: + case 244 /* ExpressionStatement */: + case 249 /* ForInStatement */: + case 250 /* ForOfStatement */: + case 248 /* ForStatement */: + case 262 /* FunctionDeclaration */: + case 218 /* FunctionExpression */: + case 184 /* FunctionType */: + case 177 /* GetAccessor */: case 80 /* Identifier */: - case 244 /* IfStatement */: - case 271 /* ImportDeclaration */: - case 270 /* ImportEqualsDeclaration */: - case 180 /* IndexSignature */: - case 263 /* InterfaceDeclaration */: - case 323 /* JSDocFunctionType */: - case 329 /* JSDocSignature */: - case 255 /* LabeledStatement */: - case 173 /* MethodDeclaration */: - case 172 /* MethodSignature */: - case 266 /* ModuleDeclaration */: - case 201 /* NamedTupleMember */: - case 269 /* NamespaceExportDeclaration */: - case 209 /* ObjectLiteralExpression */: - case 168 /* Parameter */: - case 216 /* ParenthesizedExpression */: - case 210 /* PropertyAccessExpression */: - case 302 /* PropertyAssignment */: - case 171 /* PropertyDeclaration */: - case 170 /* PropertySignature */: - case 252 /* ReturnStatement */: - case 239 /* SemicolonClassElement */: - case 177 /* SetAccessor */: - case 303 /* ShorthandPropertyAssignment */: - case 304 /* SpreadAssignment */: - case 254 /* SwitchStatement */: - case 256 /* ThrowStatement */: - case 257 /* TryStatement */: - case 264 /* TypeAliasDeclaration */: - case 167 /* TypeParameter */: - case 259 /* VariableDeclaration */: - case 242 /* VariableStatement */: - case 246 /* WhileStatement */: - case 253 /* WithStatement */: + case 245 /* IfStatement */: + case 272 /* ImportDeclaration */: + case 271 /* ImportEqualsDeclaration */: + case 181 /* IndexSignature */: + case 264 /* InterfaceDeclaration */: + case 324 /* JSDocFunctionType */: + case 330 /* JSDocSignature */: + case 256 /* LabeledStatement */: + case 174 /* MethodDeclaration */: + case 173 /* MethodSignature */: + case 267 /* ModuleDeclaration */: + case 202 /* NamedTupleMember */: + case 270 /* NamespaceExportDeclaration */: + case 210 /* ObjectLiteralExpression */: + case 169 /* Parameter */: + case 217 /* ParenthesizedExpression */: + case 211 /* PropertyAccessExpression */: + case 303 /* PropertyAssignment */: + case 172 /* PropertyDeclaration */: + case 171 /* PropertySignature */: + case 253 /* ReturnStatement */: + case 240 /* SemicolonClassElement */: + case 178 /* SetAccessor */: + case 304 /* ShorthandPropertyAssignment */: + case 305 /* SpreadAssignment */: + case 255 /* SwitchStatement */: + case 257 /* ThrowStatement */: + case 258 /* TryStatement */: + case 265 /* TypeAliasDeclaration */: + case 168 /* TypeParameter */: + case 260 /* VariableDeclaration */: + case 243 /* VariableStatement */: + case 247 /* WhileStatement */: + case 254 /* WithStatement */: return true; default: return false; @@ -114508,11 +96793,11 @@ ${lanes.join("\n")} if (hasJSDocNodes(node)) { result = addRange(result, filterOwnedJSDocTags(hostNode, last(node.jsDoc))); } - if (node.kind === 168 /* Parameter */) { + if (node.kind === 169 /* Parameter */) { result = addRange(result, (noCache ? getJSDocParameterTagsNoCache : getJSDocParameterTags)(node)); break; } - if (node.kind === 167 /* TypeParameter */) { + if (node.kind === 168 /* TypeParameter */) { result = addRange(result, (noCache ? getJSDocTypeParameterTagsNoCache : getJSDocTypeParameterTags)(node)); break; } @@ -114532,9 +96817,9 @@ ${lanes.join("\n")} } function getNextJSDocCommentLocation(node) { const parent2 = node.parent; - if (parent2.kind === 302 /* PropertyAssignment */ || parent2.kind === 276 /* ExportAssignment */ || parent2.kind === 171 /* PropertyDeclaration */ || parent2.kind === 243 /* ExpressionStatement */ && node.kind === 210 /* PropertyAccessExpression */ || parent2.kind === 252 /* ReturnStatement */ || getNestedModuleDeclaration(parent2) || isBinaryExpression(node) && node.operatorToken.kind === 64 /* EqualsToken */) { + if (parent2.kind === 303 /* PropertyAssignment */ || parent2.kind === 277 /* ExportAssignment */ || parent2.kind === 172 /* PropertyDeclaration */ || parent2.kind === 244 /* ExpressionStatement */ && node.kind === 211 /* PropertyAccessExpression */ || parent2.kind === 253 /* ReturnStatement */ || getNestedModuleDeclaration(parent2) || isAssignmentExpression(node)) { return parent2; - } else if (parent2.parent && (getSingleVariableOfVariableStatement(parent2.parent) === node || isBinaryExpression(parent2) && parent2.operatorToken.kind === 64 /* EqualsToken */)) { + } else if (parent2.parent && (getSingleVariableOfVariableStatement(parent2.parent) === node || isAssignmentExpression(parent2))) { return parent2.parent; } else if (parent2.parent && parent2.parent.parent && (getSingleVariableOfVariableStatement(parent2.parent.parent) || getSingleInitializerOfVariableStatementOrPropertyDeclaration(parent2.parent.parent) === node || getSourceOfDefaultedAssignment(parent2.parent.parent))) { return parent2.parent.parent; @@ -114598,68 +96883,100 @@ ${lanes.join("\n")} function hasTypeArguments(node) { return !!node.typeArguments; } - function getAssignmentTargetKind(node) { + function getAssignmentTarget(node) { let parent2 = node.parent; while (true) { switch (parent2.kind) { - case 225 /* BinaryExpression */: - const binaryOperator = parent2.operatorToken.kind; - return isAssignmentOperator(binaryOperator) && parent2.left === node ? binaryOperator === 64 /* EqualsToken */ || isLogicalOrCoalescingAssignmentOperator(binaryOperator) ? 1 /* Definite */ : 2 /* Compound */ : 0 /* None */; - case 223 /* PrefixUnaryExpression */: - case 224 /* PostfixUnaryExpression */: - const unaryOperator = parent2.operator; - return unaryOperator === 46 /* PlusPlusToken */ || unaryOperator === 47 /* MinusMinusToken */ ? 2 /* Compound */ : 0 /* None */; - case 248 /* ForInStatement */: - case 249 /* ForOfStatement */: - return parent2.initializer === node ? 1 /* Definite */ : 0 /* None */; - case 216 /* ParenthesizedExpression */: - case 208 /* ArrayLiteralExpression */: - case 229 /* SpreadElement */: - case 234 /* NonNullExpression */: + case 226 /* BinaryExpression */: + const binaryExpression = parent2; + const binaryOperator = binaryExpression.operatorToken.kind; + return isAssignmentOperator(binaryOperator) && binaryExpression.left === node ? binaryExpression : void 0; + case 224 /* PrefixUnaryExpression */: + case 225 /* PostfixUnaryExpression */: + const unaryExpression = parent2; + const unaryOperator = unaryExpression.operator; + return unaryOperator === 46 /* PlusPlusToken */ || unaryOperator === 47 /* MinusMinusToken */ ? unaryExpression : void 0; + case 249 /* ForInStatement */: + case 250 /* ForOfStatement */: + const forInOrOfStatement = parent2; + return forInOrOfStatement.initializer === node ? forInOrOfStatement : void 0; + case 217 /* ParenthesizedExpression */: + case 209 /* ArrayLiteralExpression */: + case 230 /* SpreadElement */: + case 235 /* NonNullExpression */: node = parent2; break; - case 304 /* SpreadAssignment */: + case 305 /* SpreadAssignment */: node = parent2.parent; break; - case 303 /* ShorthandPropertyAssignment */: + case 304 /* ShorthandPropertyAssignment */: if (parent2.name !== node) { - return 0 /* None */; + return void 0; } node = parent2.parent; break; - case 302 /* PropertyAssignment */: + case 303 /* PropertyAssignment */: if (parent2.name === node) { - return 0 /* None */; + return void 0; } node = parent2.parent; break; default: - return 0 /* None */; + return void 0; } parent2 = node.parent; } } + function getAssignmentTargetKind(node) { + const target = getAssignmentTarget(node); + if (!target) { + return 0 /* None */; + } + switch (target.kind) { + case 226 /* BinaryExpression */: + const binaryOperator = target.operatorToken.kind; + return binaryOperator === 64 /* EqualsToken */ || isLogicalOrCoalescingAssignmentOperator(binaryOperator) ? 1 /* Definite */ : 2 /* Compound */; + case 224 /* PrefixUnaryExpression */: + case 225 /* PostfixUnaryExpression */: + return 2 /* Compound */; + case 249 /* ForInStatement */: + case 250 /* ForOfStatement */: + return 1 /* Definite */; + } + } function isAssignmentTarget(node) { - return getAssignmentTargetKind(node) !== 0 /* None */; + return !!getAssignmentTarget(node); + } + function isCompoundLikeAssignment(assignment) { + const right = skipParentheses(assignment.right); + return right.kind === 226 /* BinaryExpression */ && isShiftOperatorOrHigher(right.operatorToken.kind); + } + function isInCompoundLikeAssignment(node) { + const target = getAssignmentTarget(node); + return !!target && isAssignmentExpression( + target, + /*excludeCompoundAssignment*/ + true + ) && isCompoundLikeAssignment(target); } function isNodeWithPossibleHoistedDeclaration(node) { switch (node.kind) { - case 240 /* Block */: - case 242 /* VariableStatement */: - case 253 /* WithStatement */: - case 244 /* IfStatement */: - case 254 /* SwitchStatement */: - case 268 /* CaseBlock */: - case 295 /* CaseClause */: - case 296 /* DefaultClause */: - case 255 /* LabeledStatement */: - case 247 /* ForStatement */: - case 248 /* ForInStatement */: - case 249 /* ForOfStatement */: - case 245 /* DoStatement */: - case 246 /* WhileStatement */: - case 257 /* TryStatement */: - case 298 /* CatchClause */: + case 241 /* Block */: + case 243 /* VariableStatement */: + case 254 /* WithStatement */: + case 245 /* IfStatement */: + case 255 /* SwitchStatement */: + case 269 /* CaseBlock */: + case 296 /* CaseClause */: + case 297 /* DefaultClause */: + case 256 /* LabeledStatement */: + case 248 /* ForStatement */: + case 249 /* ForInStatement */: + case 250 /* ForOfStatement */: + case 246 /* DoStatement */: + case 247 /* WhileStatement */: + case 258 /* TryStatement */: + case 299 /* CatchClause */: return true; } return false; @@ -114674,14 +96991,14 @@ ${lanes.join("\n")} return node; } function walkUpParenthesizedTypes(node) { - return walkUp(node, 195 /* ParenthesizedType */); + return walkUp(node, 196 /* ParenthesizedType */); } function walkUpParenthesizedExpressions(node) { - return walkUp(node, 216 /* ParenthesizedExpression */); + return walkUp(node, 217 /* ParenthesizedExpression */); } function walkUpParenthesizedTypesAndGetParentAndChild(node) { let child; - while (node && node.kind === 195 /* ParenthesizedType */) { + while (node && node.kind === 196 /* ParenthesizedType */) { child = node; node = node.parent; } @@ -114697,11 +97014,11 @@ ${lanes.join("\n")} return skipOuterExpressions(node, flags); } function isDeleteTarget(node) { - if (node.kind !== 210 /* PropertyAccessExpression */ && node.kind !== 211 /* ElementAccessExpression */) { + if (node.kind !== 211 /* PropertyAccessExpression */ && node.kind !== 212 /* ElementAccessExpression */) { return false; } node = walkUpParenthesizedExpressions(node.parent); - return node && node.kind === 219 /* DeleteExpression */; + return node && node.kind === 220 /* DeleteExpression */; } function isNodeDescendantOf(node, ancestor) { while (node) { @@ -114739,55 +97056,55 @@ ${lanes.join("\n")} } } function isLiteralComputedPropertyDeclarationName(node) { - return isStringOrNumericLiteralLike(node) && node.parent.kind === 166 /* ComputedPropertyName */ && isDeclaration(node.parent.parent); + return isStringOrNumericLiteralLike(node) && node.parent.kind === 167 /* ComputedPropertyName */ && isDeclaration(node.parent.parent); } function isIdentifierName(node) { const parent2 = node.parent; switch (parent2.kind) { - case 171 /* PropertyDeclaration */: - case 170 /* PropertySignature */: - case 173 /* MethodDeclaration */: - case 172 /* MethodSignature */: - case 176 /* GetAccessor */: - case 177 /* SetAccessor */: - case 305 /* EnumMember */: - case 302 /* PropertyAssignment */: - case 210 /* PropertyAccessExpression */: + case 172 /* PropertyDeclaration */: + case 171 /* PropertySignature */: + case 174 /* MethodDeclaration */: + case 173 /* MethodSignature */: + case 177 /* GetAccessor */: + case 178 /* SetAccessor */: + case 306 /* EnumMember */: + case 303 /* PropertyAssignment */: + case 211 /* PropertyAccessExpression */: return parent2.name === node; - case 165 /* QualifiedName */: + case 166 /* QualifiedName */: return parent2.right === node; - case 207 /* BindingElement */: - case 275 /* ImportSpecifier */: + case 208 /* BindingElement */: + case 276 /* ImportSpecifier */: return parent2.propertyName === node; - case 280 /* ExportSpecifier */: - case 290 /* JsxAttribute */: - case 284 /* JsxSelfClosingElement */: - case 285 /* JsxOpeningElement */: - case 286 /* JsxClosingElement */: + case 281 /* ExportSpecifier */: + case 291 /* JsxAttribute */: + case 285 /* JsxSelfClosingElement */: + case 286 /* JsxOpeningElement */: + case 287 /* JsxClosingElement */: return true; } return false; } function isAliasSymbolDeclaration(node) { - if (node.kind === 270 /* ImportEqualsDeclaration */ || node.kind === 269 /* NamespaceExportDeclaration */ || node.kind === 272 /* ImportClause */ && !!node.name || node.kind === 273 /* NamespaceImport */ || node.kind === 279 /* NamespaceExport */ || node.kind === 275 /* ImportSpecifier */ || node.kind === 280 /* ExportSpecifier */ || node.kind === 276 /* ExportAssignment */ && exportAssignmentIsAlias(node)) { + if (node.kind === 271 /* ImportEqualsDeclaration */ || node.kind === 270 /* NamespaceExportDeclaration */ || node.kind === 273 /* ImportClause */ && !!node.name || node.kind === 274 /* NamespaceImport */ || node.kind === 280 /* NamespaceExport */ || node.kind === 276 /* ImportSpecifier */ || node.kind === 281 /* ExportSpecifier */ || node.kind === 277 /* ExportAssignment */ && exportAssignmentIsAlias(node)) { return true; } return isInJSFile(node) && (isBinaryExpression(node) && getAssignmentDeclarationKind(node) === 2 /* ModuleExports */ && exportAssignmentIsAlias(node) || isPropertyAccessExpression(node) && isBinaryExpression(node.parent) && node.parent.left === node && node.parent.operatorToken.kind === 64 /* EqualsToken */ && isAliasableExpression(node.parent.right)); } function getAliasDeclarationFromName(node) { switch (node.parent.kind) { - case 272 /* ImportClause */: - case 275 /* ImportSpecifier */: - case 273 /* NamespaceImport */: - case 280 /* ExportSpecifier */: - case 276 /* ExportAssignment */: - case 270 /* ImportEqualsDeclaration */: - case 279 /* NamespaceExport */: + case 273 /* ImportClause */: + case 276 /* ImportSpecifier */: + case 274 /* NamespaceImport */: + case 281 /* ExportSpecifier */: + case 277 /* ExportAssignment */: + case 271 /* ImportEqualsDeclaration */: + case 280 /* NamespaceExport */: return node.parent; - case 165 /* QualifiedName */: + case 166 /* QualifiedName */: do { node = node.parent; - } while (node.parent.kind === 165 /* QualifiedName */); + } while (node.parent.kind === 166 /* QualifiedName */); return getAliasDeclarationFromName(node); } } @@ -114802,7 +97119,7 @@ ${lanes.join("\n")} return isExportAssignment(node) ? node.expression : node.right; } function getPropertyAssignmentAliasLikeExpression(node) { - return node.kind === 303 /* ShorthandPropertyAssignment */ ? node.name : node.kind === 302 /* PropertyAssignment */ ? node.initializer : node.parent.right; + return node.kind === 304 /* ShorthandPropertyAssignment */ ? node.name : node.kind === 303 /* PropertyAssignment */ ? node.initializer : node.parent.right; } function getEffectiveBaseTypeNode(node) { const baseType = getClassExtendsHeritageElement(node); @@ -114853,7 +97170,7 @@ ${lanes.join("\n")} return void 0; } function isKeyword(token) { - return 83 /* FirstKeyword */ <= token && token <= 164 /* LastKeyword */; + return 83 /* FirstKeyword */ <= token && token <= 165 /* LastKeyword */; } function isPunctuation(token) { return 19 /* FirstPunctuation */ <= token && token <= 79 /* LastPunctuation */; @@ -114862,7 +97179,7 @@ ${lanes.join("\n")} return isKeyword(token) || isPunctuation(token); } function isContextualKeyword(token) { - return 128 /* FirstContextualKeyword */ <= token && token <= 164 /* LastContextualKeyword */; + return 128 /* FirstContextualKeyword */ <= token && token <= 165 /* LastContextualKeyword */; } function isNonContextualKeyword(token) { return isKeyword(token) && !isContextualKeyword(token); @@ -114891,14 +97208,14 @@ ${lanes.join("\n")} } let flags = 0 /* Normal */; switch (node.kind) { - case 261 /* FunctionDeclaration */: - case 217 /* FunctionExpression */: - case 173 /* MethodDeclaration */: + case 262 /* FunctionDeclaration */: + case 218 /* FunctionExpression */: + case 174 /* MethodDeclaration */: if (node.asteriskToken) { flags |= 1 /* Generator */; } - case 218 /* ArrowFunction */: - if (hasSyntacticModifier(node, 512 /* Async */)) { + case 219 /* ArrowFunction */: + if (hasSyntacticModifier(node, 1024 /* Async */)) { flags |= 2 /* Async */; } break; @@ -114910,11 +97227,11 @@ ${lanes.join("\n")} } function isAsyncFunction(node) { switch (node.kind) { - case 261 /* FunctionDeclaration */: - case 217 /* FunctionExpression */: - case 218 /* ArrowFunction */: - case 173 /* MethodDeclaration */: - return node.body !== void 0 && node.asteriskToken === void 0 && hasSyntacticModifier(node, 512 /* Async */); + case 262 /* FunctionDeclaration */: + case 218 /* FunctionExpression */: + case 219 /* ArrowFunction */: + case 174 /* MethodDeclaration */: + return node.body !== void 0 && node.asteriskToken === void 0 && hasSyntacticModifier(node, 1024 /* Async */); } return false; } @@ -114929,7 +97246,7 @@ ${lanes.join("\n")} return !!name && isDynamicName(name); } function isDynamicName(name) { - if (!(name.kind === 166 /* ComputedPropertyName */ || name.kind === 211 /* ElementAccessExpression */)) { + if (!(name.kind === 167 /* ComputedPropertyName */ || name.kind === 212 /* ElementAccessExpression */)) { return false; } const expr = isElementAccessExpression(name) ? skipParentheses(name.argumentExpression) : name.expression; @@ -114941,9 +97258,10 @@ ${lanes.join("\n")} case 81 /* PrivateIdentifier */: return name.escapedText; case 11 /* StringLiteral */: + case 15 /* NoSubstitutionTemplateLiteral */: case 9 /* NumericLiteral */: return escapeLeadingUnderscores(name.text); - case 166 /* ComputedPropertyName */: + case 167 /* ComputedPropertyName */: const nameExpression = name.expression; if (isStringOrNumericLiteralLike(nameExpression)) { return escapeLeadingUnderscores(nameExpression.text); @@ -114954,7 +97272,7 @@ ${lanes.join("\n")} return nameExpression.operand.text; } return void 0; - case 294 /* JsxNamespacedName */: + case 295 /* JsxNamespacedName */: return getEscapedTextOfJsxNamespacedName(name); default: return Debug.assertNever(name); @@ -114998,13 +97316,17 @@ ${lanes.join("\n")} function isAnonymousFunctionDefinition(node, cb) { node = skipOuterExpressions(node); switch (node.kind) { - case 230 /* ClassExpression */: - case 217 /* FunctionExpression */: + case 231 /* ClassExpression */: + if (classHasDeclaredOrExplicitlyAssignedName(node)) { + return false; + } + break; + case 218 /* FunctionExpression */: if (node.name) { return false; } break; - case 218 /* ArrowFunction */: + case 219 /* ArrowFunction */: break; default: return false; @@ -115013,19 +97335,19 @@ ${lanes.join("\n")} } function isNamedEvaluationSource(node) { switch (node.kind) { - case 302 /* PropertyAssignment */: + case 303 /* PropertyAssignment */: return !isProtoSetter(node.name); - case 303 /* ShorthandPropertyAssignment */: + case 304 /* ShorthandPropertyAssignment */: return !!node.objectAssignmentInitializer; - case 259 /* VariableDeclaration */: + case 260 /* VariableDeclaration */: return isIdentifier(node.name) && !!node.initializer; - case 168 /* Parameter */: + case 169 /* Parameter */: return isIdentifier(node.name) && !!node.initializer && !node.dotDotDotToken; - case 207 /* BindingElement */: + case 208 /* BindingElement */: return isIdentifier(node.name) && !!node.initializer && !node.dotDotDotToken; - case 171 /* PropertyDeclaration */: + case 172 /* PropertyDeclaration */: return !!node.initializer; - case 225 /* BinaryExpression */: + case 226 /* BinaryExpression */: switch (node.operatorToken.kind) { case 64 /* EqualsToken */: case 77 /* AmpersandAmpersandEqualsToken */: @@ -115034,7 +97356,7 @@ ${lanes.join("\n")} return isIdentifier(node.left); } break; - case 276 /* ExportAssignment */: + case 277 /* ExportAssignment */: return true; } return false; @@ -115043,18 +97365,18 @@ ${lanes.join("\n")} if (!isNamedEvaluationSource(node)) return false; switch (node.kind) { - case 302 /* PropertyAssignment */: + case 303 /* PropertyAssignment */: return isAnonymousFunctionDefinition(node.initializer, cb); - case 303 /* ShorthandPropertyAssignment */: + case 304 /* ShorthandPropertyAssignment */: return isAnonymousFunctionDefinition(node.objectAssignmentInitializer, cb); - case 259 /* VariableDeclaration */: - case 168 /* Parameter */: - case 207 /* BindingElement */: - case 171 /* PropertyDeclaration */: + case 260 /* VariableDeclaration */: + case 169 /* Parameter */: + case 208 /* BindingElement */: + case 172 /* PropertyDeclaration */: return isAnonymousFunctionDefinition(node.initializer, cb); - case 225 /* BinaryExpression */: + case 226 /* BinaryExpression */: return isAnonymousFunctionDefinition(node.right, cb); - case 276 /* ExportAssignment */: + case 277 /* ExportAssignment */: return isAnonymousFunctionDefinition(node.expression, cb); } } @@ -115063,17 +97385,17 @@ ${lanes.join("\n")} } function isParameterDeclaration(node) { const root = getRootDeclaration(node); - return root.kind === 168 /* Parameter */; + return root.kind === 169 /* Parameter */; } function getRootDeclaration(node) { - while (node.kind === 207 /* BindingElement */) { + while (node.kind === 208 /* BindingElement */) { node = node.parent.parent; } return node; } function nodeStartsNewLexicalEnvironment(node) { const kind = node.kind; - return kind === 175 /* Constructor */ || kind === 217 /* FunctionExpression */ || kind === 261 /* FunctionDeclaration */ || kind === 218 /* ArrowFunction */ || kind === 173 /* MethodDeclaration */ || kind === 176 /* GetAccessor */ || kind === 177 /* SetAccessor */ || kind === 266 /* ModuleDeclaration */ || kind === 311 /* SourceFile */; + return kind === 176 /* Constructor */ || kind === 218 /* FunctionExpression */ || kind === 262 /* FunctionDeclaration */ || kind === 219 /* ArrowFunction */ || kind === 174 /* MethodDeclaration */ || kind === 177 /* GetAccessor */ || kind === 178 /* SetAccessor */ || kind === 267 /* ModuleDeclaration */ || kind === 312 /* SourceFile */; } function nodeIsSynthesized(range) { return positionIsSynthesized(range.pos) || positionIsSynthesized(range.end); @@ -115083,22 +97405,22 @@ ${lanes.join("\n")} } function getExpressionAssociativity(expression) { const operator = getOperator(expression); - const hasArguments = expression.kind === 213 /* NewExpression */ && expression.arguments !== void 0; + const hasArguments = expression.kind === 214 /* NewExpression */ && expression.arguments !== void 0; return getOperatorAssociativity(expression.kind, operator, hasArguments); } function getOperatorAssociativity(kind, operator, hasArguments) { switch (kind) { - case 213 /* NewExpression */: + case 214 /* NewExpression */: return hasArguments ? 0 /* Left */ : 1 /* Right */; - case 223 /* PrefixUnaryExpression */: - case 220 /* TypeOfExpression */: - case 221 /* VoidExpression */: - case 219 /* DeleteExpression */: - case 222 /* AwaitExpression */: - case 226 /* ConditionalExpression */: - case 228 /* YieldExpression */: + case 224 /* PrefixUnaryExpression */: + case 221 /* TypeOfExpression */: + case 222 /* VoidExpression */: + case 220 /* DeleteExpression */: + case 223 /* AwaitExpression */: + case 227 /* ConditionalExpression */: + case 229 /* YieldExpression */: return 1 /* Right */; - case 225 /* BinaryExpression */: + case 226 /* BinaryExpression */: switch (operator) { case 43 /* AsteriskAsteriskToken */: case 64 /* EqualsToken */: @@ -115124,13 +97446,13 @@ ${lanes.join("\n")} } function getExpressionPrecedence(expression) { const operator = getOperator(expression); - const hasArguments = expression.kind === 213 /* NewExpression */ && expression.arguments !== void 0; + const hasArguments = expression.kind === 214 /* NewExpression */ && expression.arguments !== void 0; return getOperatorPrecedence(expression.kind, operator, hasArguments); } function getOperator(expression) { - if (expression.kind === 225 /* BinaryExpression */) { + if (expression.kind === 226 /* BinaryExpression */) { return expression.operatorToken.kind; - } else if (expression.kind === 223 /* PrefixUnaryExpression */ || expression.kind === 224 /* PostfixUnaryExpression */) { + } else if (expression.kind === 224 /* PrefixUnaryExpression */ || expression.kind === 225 /* PostfixUnaryExpression */) { return expression.operator; } else { return expression.kind; @@ -115138,15 +97460,15 @@ ${lanes.join("\n")} } function getOperatorPrecedence(nodeKind, operatorKind, hasArguments) { switch (nodeKind) { - case 360 /* CommaListExpression */: + case 361 /* CommaListExpression */: return 0 /* Comma */; - case 229 /* SpreadElement */: + case 230 /* SpreadElement */: return 1 /* Spread */; - case 228 /* YieldExpression */: + case 229 /* YieldExpression */: return 2 /* Yield */; - case 226 /* ConditionalExpression */: + case 227 /* ConditionalExpression */: return 4 /* Conditional */; - case 225 /* BinaryExpression */: + case 226 /* BinaryExpression */: switch (operatorKind) { case 28 /* CommaToken */: return 0 /* Comma */; @@ -115170,27 +97492,27 @@ ${lanes.join("\n")} default: return getBinaryOperatorPrecedence(operatorKind); } - case 215 /* TypeAssertionExpression */: - case 234 /* NonNullExpression */: - case 223 /* PrefixUnaryExpression */: - case 220 /* TypeOfExpression */: - case 221 /* VoidExpression */: - case 219 /* DeleteExpression */: - case 222 /* AwaitExpression */: + case 216 /* TypeAssertionExpression */: + case 235 /* NonNullExpression */: + case 224 /* PrefixUnaryExpression */: + case 221 /* TypeOfExpression */: + case 222 /* VoidExpression */: + case 220 /* DeleteExpression */: + case 223 /* AwaitExpression */: return 16 /* Unary */; - case 224 /* PostfixUnaryExpression */: + case 225 /* PostfixUnaryExpression */: return 17 /* Update */; - case 212 /* CallExpression */: + case 213 /* CallExpression */: return 18 /* LeftHandSide */; - case 213 /* NewExpression */: + case 214 /* NewExpression */: return hasArguments ? 19 /* Member */ : 18 /* LeftHandSide */; - case 214 /* TaggedTemplateExpression */: - case 210 /* PropertyAccessExpression */: - case 211 /* ElementAccessExpression */: - case 235 /* MetaProperty */: + case 215 /* TaggedTemplateExpression */: + case 211 /* PropertyAccessExpression */: + case 212 /* ElementAccessExpression */: + case 236 /* MetaProperty */: return 19 /* Member */; - case 233 /* AsExpression */: - case 237 /* SatisfiesExpression */: + case 234 /* AsExpression */: + case 238 /* SatisfiesExpression */: return 11 /* Relational */; case 110 /* ThisKeyword */: case 108 /* SuperKeyword */: @@ -115202,19 +97524,19 @@ ${lanes.join("\n")} case 9 /* NumericLiteral */: case 10 /* BigIntLiteral */: case 11 /* StringLiteral */: - case 208 /* ArrayLiteralExpression */: - case 209 /* ObjectLiteralExpression */: - case 217 /* FunctionExpression */: - case 218 /* ArrowFunction */: - case 230 /* ClassExpression */: + case 209 /* ArrayLiteralExpression */: + case 210 /* ObjectLiteralExpression */: + case 218 /* FunctionExpression */: + case 219 /* ArrowFunction */: + case 231 /* ClassExpression */: case 14 /* RegularExpressionLiteral */: case 15 /* NoSubstitutionTemplateLiteral */: - case 227 /* TemplateExpression */: - case 216 /* ParenthesizedExpression */: - case 231 /* OmittedExpression */: - case 283 /* JsxElement */: - case 284 /* JsxSelfClosingElement */: - case 287 /* JsxFragment */: + case 228 /* TemplateExpression */: + case 217 /* ParenthesizedExpression */: + case 232 /* OmittedExpression */: + case 284 /* JsxElement */: + case 285 /* JsxSelfClosingElement */: + case 288 /* JsxFragment */: return 20 /* Primary */; default: return -1 /* Invalid */; @@ -115267,7 +97589,7 @@ ${lanes.join("\n")} function getSemanticJsxChildren(children) { return filter(children, (i) => { switch (i.kind) { - case 293 /* JsxExpression */: + case 294 /* JsxExpression */: return !!i.expression; case 12 /* JsxText */: return !i.containsOnlyTriviaWhiteSpaces; @@ -115340,8 +97662,11 @@ ${lanes.join("\n")} function escapeTemplateSubstitution(str) { return str.replace(templateSubstitutionRegExp, "\\${"); } + function containsInvalidEscapeFlag(node) { + return !!((node.templateFlags || 0) & 2048 /* ContainsInvalidEscape */); + } function hasInvalidEscape(template) { - return template && !!(isNoSubstitutionTemplateLiteral(template) ? template.templateFlags : template.head.templateFlags || some(template.templateSpans, (span) => !!span.literal.templateFlags)); + return template && !!(isNoSubstitutionTemplateLiteral(template) ? containsInvalidEscapeFlag(template) : containsInvalidEscapeFlag(template.head) || some(template.templateSpans, (span) => containsInvalidEscapeFlag(span.literal))); } function encodeUtf16EscapeSequence(charCode) { const hexCharCode = charCode.toString(16).toUpperCase(); @@ -115392,7 +97717,7 @@ ${lanes.join("\n")} } function isIntrinsicJsxName(name) { const ch = name.charCodeAt(0); - return ch >= 97 /* a */ && ch <= 122 /* z */ || stringContains(name, "-"); + return ch >= 97 /* a */ && ch <= 122 /* z */ || name.includes("-"); } function getIndentString(level) { const singleLevel = indentStrings[1]; @@ -115404,12 +97729,9 @@ ${lanes.join("\n")} function getIndentSize() { return indentStrings[1].length; } - function isNightly() { - return stringContains(version, "-dev") || stringContains(version, "-insiders"); - } function createTextWriter(newLine) { var output; - var indent2; + var indent3; var lineStart; var lineCount; var linePos; @@ -115427,7 +97749,7 @@ ${lanes.join("\n")} function writeText(s) { if (s && s.length) { if (lineStart) { - s = getIndentString(indent2) + s; + s = getIndentString(indent3) + s; lineStart = false; } output += s; @@ -115446,7 +97768,7 @@ ${lanes.join("\n")} } function reset2() { output = ""; - indent2 = 0; + indent3 = 0; lineStart = true; lineCount = 0; linePos = 0; @@ -115483,15 +97805,15 @@ ${lanes.join("\n")} writeLiteral, writeLine, increaseIndent: () => { - indent2++; + indent3++; }, decreaseIndent: () => { - indent2--; + indent3--; }, - getIndent: () => indent2, + getIndent: () => indent3, getTextPos: () => output.length, getLine: () => lineCount, - getColumn: () => lineStart ? indent2 * getIndentSize() : output.length - linePos, + getColumn: () => lineStart ? indent3 * getIndentSize() : output.length - linePos, getText: () => output, isAtStartOfLine: () => lineStart, hasTrailingComment: () => hasTrailingComment, @@ -115595,7 +97917,7 @@ ${lanes.join("\n")} return void 0; } const specifier = getExternalModuleName(declaration); - if (specifier && isStringLiteralLike(specifier) && !pathIsRelative(specifier.text) && getCanonicalAbsolutePath(host, file.path).indexOf(getCanonicalAbsolutePath(host, ensureTrailingDirectorySeparator(host.getCommonSourceDirectory()))) === -1) { + if (specifier && isStringLiteralLike(specifier) && !pathIsRelative(specifier.text) && !getCanonicalAbsolutePath(host, file.path).includes(getCanonicalAbsolutePath(host, ensureTrailingDirectorySeparator(host.getCommonSourceDirectory())))) { return void 0; } return getResolvedExternalModuleName(host, file); @@ -115671,7 +97993,31 @@ ${lanes.join("\n")} } function sourceFileMayBeEmitted(sourceFile, host, forceDtsEmit) { const options = host.getCompilerOptions(); - return !(options.noEmitForJsFiles && isSourceFileJS(sourceFile)) && !sourceFile.isDeclarationFile && !host.isSourceFileFromExternalLibrary(sourceFile) && (forceDtsEmit || !(isJsonSourceFile(sourceFile) && host.getResolvedProjectReferenceToRedirect(sourceFile.fileName)) && !host.isSourceOfProjectReferenceRedirect(sourceFile.fileName)); + if (options.noEmitForJsFiles && isSourceFileJS(sourceFile)) + return false; + if (sourceFile.isDeclarationFile) + return false; + if (host.isSourceFileFromExternalLibrary(sourceFile)) + return false; + if (forceDtsEmit) + return true; + if (host.isSourceOfProjectReferenceRedirect(sourceFile.fileName)) + return false; + if (!isJsonSourceFile(sourceFile)) + return true; + if (host.getResolvedProjectReferenceToRedirect(sourceFile.fileName)) + return false; + if (outFile(options)) + return true; + if (!options.outDir) + return false; + if (options.rootDir || options.composite && options.configFilePath) { + const commonDir = getNormalizedAbsolutePath(getCommonSourceDirectory(options, () => [], host.getCurrentDirectory(), host.getCanonicalFileName), host.getCurrentDirectory()); + const outputPath = getSourceFilePathInNewDirWorker(sourceFile.fileName, options.outDir, host.getCurrentDirectory(), commonDir, host.getCanonicalFileName); + if (comparePaths(sourceFile.fileName, outputPath, host.getCurrentDirectory(), !host.useCaseSensitiveFileNames()) === 0 /* EqualTo */) + return false; + } + return true; } function getSourceFilePathInNewDir(fileName, host, newDirPath) { return getSourceFilePathInNewDirWorker(fileName, newDirPath, host.getCurrentDirectory(), host.getCommonSourceDirectory(), (f) => host.getCanonicalFileName(f)); @@ -115683,9 +98029,16 @@ ${lanes.join("\n")} return combinePaths(newDirPath, sourceFilePath); } function writeFile(host, diagnostics, fileName, text, writeByteOrderMark, sourceFiles, data) { - host.writeFile(fileName, text, writeByteOrderMark, (hostErrorMessage) => { - diagnostics.add(createCompilerDiagnostic(Diagnostics.Could_not_write_file_0_Colon_1, fileName, hostErrorMessage)); - }, sourceFiles, data); + host.writeFile( + fileName, + text, + writeByteOrderMark, + (hostErrorMessage) => { + diagnostics.add(createCompilerDiagnostic(Diagnostics.Could_not_write_file_0_Colon_1, fileName, hostErrorMessage)); + }, + sourceFiles, + data + ); } function ensureDirectoriesExist(directoryPath, createDirectory, directoryExists) { if (directoryPath.length > getRootLength(directoryPath) && !directoryExists(directoryPath)) { @@ -115736,6 +98089,12 @@ ${lanes.join("\n")} function isThisIdentifier(node) { return !!node && node.kind === 80 /* Identifier */ && identifierIsThisKeyword(node); } + function isInTypeQuery(node) { + return !!findAncestor( + node, + (n) => n.kind === 186 /* TypeQuery */ ? true : n.kind === 80 /* Identifier */ || n.kind === 166 /* QualifiedName */ ? false : "quit" + ); + } function isThisInTypeQuery(node) { if (!isThisIdentifier(node)) { return false; @@ -115743,7 +98102,7 @@ ${lanes.join("\n")} while (isQualifiedName(node.parent) && node.parent.left === node) { node = node.parent; } - return node.parent.kind === 185 /* TypeQuery */; + return node.parent.kind === 186 /* TypeQuery */; } function identifierIsThisKeyword(id) { return id.escapedText === "this"; @@ -115755,9 +98114,9 @@ ${lanes.join("\n")} let setAccessor; if (hasDynamicName(accessor)) { firstAccessor = accessor; - if (accessor.kind === 176 /* GetAccessor */) { + if (accessor.kind === 177 /* GetAccessor */) { getAccessor = accessor; - } else if (accessor.kind === 177 /* SetAccessor */) { + } else if (accessor.kind === 178 /* SetAccessor */) { setAccessor = accessor; } else { Debug.fail("Accessor has wrong kind"); @@ -115773,10 +98132,10 @@ ${lanes.join("\n")} } else if (!secondAccessor) { secondAccessor = member; } - if (member.kind === 176 /* GetAccessor */ && !getAccessor) { + if (member.kind === 177 /* GetAccessor */ && !getAccessor) { getAccessor = member; } - if (member.kind === 177 /* SetAccessor */ && !setAccessor) { + if (member.kind === 178 /* SetAccessor */ && !setAccessor) { setAccessor = member; } } @@ -115808,7 +98167,7 @@ ${lanes.join("\n")} return flatMap(getJSDocTags(node), (tag) => isNonTypeAliasTemplate(tag) ? tag.typeParameters : void 0); } function isNonTypeAliasTemplate(tag) { - return isJSDocTemplateTag(tag) && !(tag.parent.kind === 326 /* JSDoc */ && (tag.parent.tags.some(isJSDocTypeAlias) || tag.parent.tags.some(isJSDocOverloadTag))); + return isJSDocTemplateTag(tag) && !(tag.parent.kind === 327 /* JSDoc */ && (tag.parent.tags.some(isJSDocTypeAlias) || tag.parent.tags.some(isJSDocOverloadTag))); } function getEffectiveSetAccessorTypeAnnotationNode(node) { const parameter = getSetAccessorValueParameter(node); @@ -115934,7 +98293,7 @@ ${lanes.join("\n")} } function writeTrimmedCurrentLine(text, commentEnd, writer, newLine, pos, nextLineStart) { const end = Math.min(commentEnd, nextLineStart - 1); - const currentLineText = trimString(text.substring(pos, end)); + const currentLineText = text.substring(pos, end).trim(); if (currentLineText) { writer.writeComment(currentLineText); if (end !== commentEnd) { @@ -115971,25 +98330,25 @@ ${lanes.join("\n")} return isClassElement(node) && hasStaticModifier(node) || isClassStaticBlockDeclaration(node); } function hasStaticModifier(node) { - return hasSyntacticModifier(node, 32 /* Static */); + return hasSyntacticModifier(node, 256 /* Static */); } function hasOverrideModifier(node) { - return hasEffectiveModifier(node, 16384 /* Override */); + return hasEffectiveModifier(node, 16 /* Override */); } function hasAbstractModifier(node) { - return hasSyntacticModifier(node, 256 /* Abstract */); + return hasSyntacticModifier(node, 64 /* Abstract */); } function hasAmbientModifier(node) { - return hasSyntacticModifier(node, 2 /* Ambient */); + return hasSyntacticModifier(node, 128 /* Ambient */); } function hasAccessorModifier(node) { - return hasSyntacticModifier(node, 128 /* Accessor */); + return hasSyntacticModifier(node, 512 /* Accessor */); } function hasEffectiveReadonlyModifier(node) { - return hasEffectiveModifier(node, 64 /* Readonly */); + return hasEffectiveModifier(node, 8 /* Readonly */); } function hasDecorators(node) { - return hasSyntacticModifier(node, 131072 /* Decorator */); + return hasSyntacticModifier(node, 32768 /* Decorator */); } function getSelectedEffectiveModifierFlags(node, flags) { return getEffectiveModifierFlags(node) & flags; @@ -115998,16 +98357,19 @@ ${lanes.join("\n")} return getSyntacticModifierFlags(node) & flags; } function getModifierFlagsWorker(node, includeJSDoc, alwaysIncludeJSDoc) { - if (node.kind >= 0 /* FirstToken */ && node.kind <= 164 /* LastToken */) { + if (node.kind >= 0 /* FirstToken */ && node.kind <= 165 /* LastToken */) { return 0 /* None */; } if (!(node.modifierFlagsCache & 536870912 /* HasComputedFlags */)) { node.modifierFlagsCache = getSyntacticModifierFlagsNoCache(node) | 536870912 /* HasComputedFlags */; } - if (includeJSDoc && !(node.modifierFlagsCache & 4096 /* HasComputedJSDocModifiers */) && (alwaysIncludeJSDoc || isInJSFile(node)) && node.parent) { - node.modifierFlagsCache |= getJSDocModifierFlagsNoCache(node) | 4096 /* HasComputedJSDocModifiers */; + if (alwaysIncludeJSDoc || includeJSDoc && isInJSFile(node)) { + if (!(node.modifierFlagsCache & 268435456 /* HasComputedJSDocModifiers */) && node.parent) { + node.modifierFlagsCache |= getRawJSDocModifierFlagsNoCache(node) | 268435456 /* HasComputedJSDocModifiers */; + } + return selectEffectiveModifierFlags(node.modifierFlagsCache); } - return node.modifierFlagsCache & ~(536870912 /* HasComputedFlags */ | 4096 /* HasComputedJSDocModifiers */); + return selectSyntacticModifierFlags(node.modifierFlagsCache); } function getEffectiveModifierFlags(node) { return getModifierFlagsWorker( @@ -116032,33 +98394,42 @@ ${lanes.join("\n")} false ); } - function getJSDocModifierFlagsNoCache(node) { + function getRawJSDocModifierFlagsNoCache(node) { let flags = 0 /* None */; if (!!node.parent && !isParameter(node)) { if (isInJSFile(node)) { if (getJSDocPublicTagNoCache(node)) - flags |= 4 /* Public */; + flags |= 8388608 /* JSDocPublic */; if (getJSDocPrivateTagNoCache(node)) - flags |= 8 /* Private */; + flags |= 16777216 /* JSDocPrivate */; if (getJSDocProtectedTagNoCache(node)) - flags |= 16 /* Protected */; + flags |= 33554432 /* JSDocProtected */; if (getJSDocReadonlyTagNoCache(node)) - flags |= 64 /* Readonly */; + flags |= 67108864 /* JSDocReadonly */; if (getJSDocOverrideTagNoCache(node)) - flags |= 16384 /* Override */; + flags |= 134217728 /* JSDocOverride */; } if (getJSDocDeprecatedTagNoCache(node)) - flags |= 8192 /* Deprecated */; + flags |= 65536 /* Deprecated */; } return flags; } + function selectSyntacticModifierFlags(flags) { + return flags & 65535 /* SyntacticModifiers */; + } + function selectEffectiveModifierFlags(flags) { + return flags & 131071 /* NonCacheOnlyModifiers */ | (flags & 260046848 /* JSDocCacheOnlyModifiers */) >>> 23; + } + function getJSDocModifierFlagsNoCache(node) { + return selectEffectiveModifierFlags(getRawJSDocModifierFlagsNoCache(node)); + } function getEffectiveModifierFlagsNoCache(node) { return getSyntacticModifierFlagsNoCache(node) | getJSDocModifierFlagsNoCache(node); } function getSyntacticModifierFlagsNoCache(node) { let flags = canHaveModifiers(node) ? modifiersToFlags(node.modifiers) : 0 /* None */; - if (node.flags & 4 /* NestedNamespace */ || node.kind === 80 /* Identifier */ && node.flags & 2048 /* IdentifierIsInJSDocNamespace */) { - flags |= 1 /* Export */; + if (node.flags & 8 /* NestedNamespace */ || node.kind === 80 /* Identifier */ && node.flags & 4096 /* IdentifierIsInJSDocNamespace */) { + flags |= 32 /* Export */; } return flags; } @@ -116074,37 +98445,37 @@ ${lanes.join("\n")} function modifierToFlag(token) { switch (token) { case 126 /* StaticKeyword */: - return 32 /* Static */; + return 256 /* Static */; case 125 /* PublicKeyword */: - return 4 /* Public */; + return 1 /* Public */; case 124 /* ProtectedKeyword */: - return 16 /* Protected */; + return 4 /* Protected */; case 123 /* PrivateKeyword */: - return 8 /* Private */; + return 2 /* Private */; case 128 /* AbstractKeyword */: - return 256 /* Abstract */; + return 64 /* Abstract */; case 129 /* AccessorKeyword */: - return 128 /* Accessor */; + return 512 /* Accessor */; case 95 /* ExportKeyword */: - return 1 /* Export */; + return 32 /* Export */; case 138 /* DeclareKeyword */: - return 2 /* Ambient */; + return 128 /* Ambient */; case 87 /* ConstKeyword */: - return 2048 /* Const */; + return 4096 /* Const */; case 90 /* DefaultKeyword */: - return 1024 /* Default */; + return 2048 /* Default */; case 134 /* AsyncKeyword */: - return 512 /* Async */; + return 1024 /* Async */; case 148 /* ReadonlyKeyword */: - return 64 /* Readonly */; - case 163 /* OverrideKeyword */: - return 16384 /* Override */; + return 8 /* Readonly */; + case 164 /* OverrideKeyword */: + return 16 /* Override */; case 103 /* InKeyword */: - return 32768 /* In */; + return 8192 /* In */; case 147 /* OutKeyword */: - return 65536 /* Out */; - case 169 /* Decorator */: - return 131072 /* Decorator */; + return 16384 /* Out */; + case 170 /* Decorator */: + return 32768 /* Decorator */; } return 0 /* None */; } @@ -116160,7 +98531,7 @@ ${lanes.join("\n")} true )) { const kind = node.left.kind; - return kind === 209 /* ObjectLiteralExpression */ || kind === 208 /* ArrayLiteralExpression */; + return kind === 210 /* ObjectLiteralExpression */ || kind === 209 /* ArrayLiteralExpression */; } return false; } @@ -116174,12 +98545,12 @@ ${lanes.join("\n")} switch (node.kind) { case 80 /* Identifier */: return node; - case 165 /* QualifiedName */: + case 166 /* QualifiedName */: do { node = node.left; } while (node.kind !== 80 /* Identifier */); return node; - case 210 /* PropertyAccessExpression */: + case 211 /* PropertyAccessExpression */: do { node = node.expression; } while (node.kind !== 80 /* Identifier */); @@ -116187,7 +98558,7 @@ ${lanes.join("\n")} } } function isDottedName(node) { - return node.kind === 80 /* Identifier */ || node.kind === 110 /* ThisKeyword */ || node.kind === 108 /* SuperKeyword */ || node.kind === 235 /* MetaProperty */ || node.kind === 210 /* PropertyAccessExpression */ && isDottedName(node.expression) || node.kind === 216 /* ParenthesizedExpression */ && isDottedName(node.expression); + return node.kind === 80 /* Identifier */ || node.kind === 110 /* ThisKeyword */ || node.kind === 108 /* SuperKeyword */ || node.kind === 236 /* MetaProperty */ || node.kind === 211 /* PropertyAccessExpression */ && isDottedName(node.expression) || node.kind === 217 /* ParenthesizedExpression */ && isDottedName(node.expression); } function isPropertyAccessEntityNameExpression(node) { return isPropertyAccessExpression(node) && isIdentifier(node.name) && isEntityNameExpression(node.expression); @@ -116214,19 +98585,25 @@ ${lanes.join("\n")} return isBindableStaticAccessExpression(node) && getElementOrPropertyAccessName(node) === "prototype"; } function isRightSideOfQualifiedNameOrPropertyAccess(node) { - return node.parent.kind === 165 /* QualifiedName */ && node.parent.right === node || node.parent.kind === 210 /* PropertyAccessExpression */ && node.parent.name === node; + return node.parent.kind === 166 /* QualifiedName */ && node.parent.right === node || node.parent.kind === 211 /* PropertyAccessExpression */ && node.parent.name === node || node.parent.kind === 236 /* MetaProperty */ && node.parent.name === node; } function isRightSideOfAccessExpression(node) { - return isPropertyAccessExpression(node.parent) && node.parent.name === node || isElementAccessExpression(node.parent) && node.parent.argumentExpression === node; + return !!node.parent && (isPropertyAccessExpression(node.parent) && node.parent.name === node || isElementAccessExpression(node.parent) && node.parent.argumentExpression === node); } function isRightSideOfQualifiedNameOrPropertyAccessOrJSDocMemberName(node) { return isQualifiedName(node.parent) && node.parent.right === node || isPropertyAccessExpression(node.parent) && node.parent.name === node || isJSDocMemberName(node.parent) && node.parent.right === node; } + function isInstanceOfExpression(node) { + return isBinaryExpression(node) && node.operatorToken.kind === 104 /* InstanceOfKeyword */; + } + function isRightSideOfInstanceofExpression(node) { + return isInstanceOfExpression(node.parent) && node === node.parent.right; + } function isEmptyObjectLiteral(expression) { - return expression.kind === 209 /* ObjectLiteralExpression */ && expression.properties.length === 0; + return expression.kind === 210 /* ObjectLiteralExpression */ && expression.properties.length === 0; } function isEmptyArrayLiteral(expression) { - return expression.kind === 208 /* ArrayLiteralExpression */ && expression.elements.length === 0; + return expression.kind === 209 /* ArrayLiteralExpression */ && expression.elements.length === 0; } function getLocalSymbolForExportDefault(symbol) { if (!isExportDefaultSymbol(symbol) || !symbol.declarations) @@ -116238,7 +98615,7 @@ ${lanes.join("\n")} return void 0; } function isExportDefaultSymbol(symbol) { - return symbol && length(symbol.declarations) > 0 && hasSyntacticModifier(symbol.declarations[0], 1024 /* Default */); + return symbol && length(symbol.declarations) > 0 && hasSyntacticModifier(symbol.declarations[0], 2048 /* Default */); } function tryExtractTSExtension(fileName) { return find(supportedTSExtensionsForExtractExtension, (extension) => fileExtensionIs(fileName, extension)); @@ -116492,8 +98869,8 @@ ${lanes.join("\n")} const parseNode = getParseTreeNode(node); if (parseNode) { switch (parseNode.parent.kind) { - case 265 /* EnumDeclaration */: - case 266 /* ModuleDeclaration */: + case 266 /* EnumDeclaration */: + case 267 /* ModuleDeclaration */: return parseNode === parseNode.parent.name; } } @@ -116518,16 +98895,16 @@ ${lanes.join("\n")} if (s.valueDeclaration) { const declaration = isWrite && s.declarations && find(s.declarations, isSetAccessorDeclaration) || s.flags & 32768 /* GetAccessor */ && find(s.declarations, isGetAccessorDeclaration) || s.valueDeclaration; const flags = getCombinedModifierFlags(declaration); - return s.parent && s.parent.flags & 32 /* Class */ ? flags : flags & ~28 /* AccessibilityModifier */; + return s.parent && s.parent.flags & 32 /* Class */ ? flags : flags & ~7 /* AccessibilityModifier */; } if (getCheckFlags(s) & 6 /* Synthetic */) { const checkFlags = s.links.checkFlags; - const accessModifier = checkFlags & 1024 /* ContainsPrivate */ ? 8 /* Private */ : checkFlags & 256 /* ContainsPublic */ ? 4 /* Public */ : 16 /* Protected */; - const staticModifier = checkFlags & 2048 /* ContainsStatic */ ? 32 /* Static */ : 0; + const accessModifier = checkFlags & 1024 /* ContainsPrivate */ ? 2 /* Private */ : checkFlags & 256 /* ContainsPublic */ ? 1 /* Public */ : 4 /* Protected */; + const staticModifier = checkFlags & 2048 /* ContainsStatic */ ? 256 /* Static */ : 0; return accessModifier | staticModifier; } if (s.flags & 4194304 /* Prototype */) { - return 4 /* Public */ | 32 /* Static */; + return 1 /* Public */ | 256 /* Static */; } return 0; } @@ -116546,24 +98923,24 @@ ${lanes.join("\n")} function accessKind(node) { const { parent: parent2 } = node; switch (parent2 == null ? void 0 : parent2.kind) { - case 216 /* ParenthesizedExpression */: + case 217 /* ParenthesizedExpression */: return accessKind(parent2); - case 224 /* PostfixUnaryExpression */: - case 223 /* PrefixUnaryExpression */: + case 225 /* PostfixUnaryExpression */: + case 224 /* PrefixUnaryExpression */: const { operator } = parent2; return operator === 46 /* PlusPlusToken */ || operator === 47 /* MinusMinusToken */ ? 2 /* ReadWrite */ : 0 /* Read */; - case 225 /* BinaryExpression */: + case 226 /* BinaryExpression */: const { left, operatorToken } = parent2; return left === node && isAssignmentOperator(operatorToken.kind) ? operatorToken.kind === 64 /* EqualsToken */ ? 1 /* Write */ : 2 /* ReadWrite */ : 0 /* Read */; - case 210 /* PropertyAccessExpression */: + case 211 /* PropertyAccessExpression */: return parent2.name !== node ? 0 /* Read */ : accessKind(parent2); - case 302 /* PropertyAssignment */: { + case 303 /* PropertyAssignment */: { const parentAccess = accessKind(parent2.parent); return node === parent2.name ? reverseAccessKind(parentAccess) : parentAccess; } - case 303 /* ShorthandPropertyAssignment */: + case 304 /* ShorthandPropertyAssignment */: return node === parent2.objectAssignmentInitializer ? 0 /* Read */ : accessKind(parent2.parent); - case 208 /* ArrayLiteralExpression */: + case 209 /* ArrayLiteralExpression */: return accessKind(parent2); default: return 0 /* Read */; @@ -116626,7 +99003,7 @@ ${lanes.join("\n")} function isAbstractConstructorSymbol(symbol) { if (symbol.flags & 32 /* Class */) { const declaration = getClassLikeDeclarationOfSymbol(symbol); - return !!declaration && hasSyntacticModifier(declaration, 256 /* Abstract */); + return !!declaration && hasSyntacticModifier(declaration, 64 /* Abstract */); } return false; } @@ -116635,7 +99012,7 @@ ${lanes.join("\n")} return (_a = symbol.declarations) == null ? void 0 : _a.find(isClassLike); } function getObjectFlags(type) { - return type.flags & 138117121 /* ObjectFlagsType */ ? type.objectFlags : 0; + return type.flags & 3899393 /* ObjectFlagsType */ ? type.objectFlags : 0; } function forSomeAncestorDirectory(directory, callback) { return !!forEachAncestorDirectory(directory, (d) => callback(d) ? true : void 0); @@ -116648,21 +99025,17 @@ ${lanes.join("\n")} } function getLastChild(node) { let lastChild; - forEachChild( - node, - (child) => { - if (nodeIsPresent(child)) - lastChild = child; - }, - (children) => { - for (let i = children.length - 1; i >= 0; i--) { - if (nodeIsPresent(children[i])) { - lastChild = children[i]; - break; - } + forEachChild(node, (child) => { + if (nodeIsPresent(child)) + lastChild = child; + }, (children) => { + for (let i = children.length - 1; i >= 0; i--) { + if (nodeIsPresent(children[i])) { + lastChild = children[i]; + break; } } - ); + }); return lastChild; } function addToSeen(seen, key, value = true) { @@ -116676,16 +99049,16 @@ ${lanes.join("\n")} return isClassLike(node) || isInterfaceDeclaration(node) || isTypeLiteralNode(node); } function isTypeNodeKind(kind) { - return kind >= 181 /* FirstTypeNode */ && kind <= 204 /* LastTypeNode */ || kind === 133 /* AnyKeyword */ || kind === 159 /* UnknownKeyword */ || kind === 150 /* NumberKeyword */ || kind === 162 /* BigIntKeyword */ || kind === 151 /* ObjectKeyword */ || kind === 136 /* BooleanKeyword */ || kind === 154 /* StringKeyword */ || kind === 155 /* SymbolKeyword */ || kind === 116 /* VoidKeyword */ || kind === 157 /* UndefinedKeyword */ || kind === 146 /* NeverKeyword */ || kind === 141 /* IntrinsicKeyword */ || kind === 232 /* ExpressionWithTypeArguments */ || kind === 318 /* JSDocAllType */ || kind === 319 /* JSDocUnknownType */ || kind === 320 /* JSDocNullableType */ || kind === 321 /* JSDocNonNullableType */ || kind === 322 /* JSDocOptionalType */ || kind === 323 /* JSDocFunctionType */ || kind === 324 /* JSDocVariadicType */; + return kind >= 182 /* FirstTypeNode */ && kind <= 205 /* LastTypeNode */ || kind === 133 /* AnyKeyword */ || kind === 159 /* UnknownKeyword */ || kind === 150 /* NumberKeyword */ || kind === 163 /* BigIntKeyword */ || kind === 151 /* ObjectKeyword */ || kind === 136 /* BooleanKeyword */ || kind === 154 /* StringKeyword */ || kind === 155 /* SymbolKeyword */ || kind === 116 /* VoidKeyword */ || kind === 157 /* UndefinedKeyword */ || kind === 146 /* NeverKeyword */ || kind === 141 /* IntrinsicKeyword */ || kind === 233 /* ExpressionWithTypeArguments */ || kind === 319 /* JSDocAllType */ || kind === 320 /* JSDocUnknownType */ || kind === 321 /* JSDocNullableType */ || kind === 322 /* JSDocNonNullableType */ || kind === 323 /* JSDocOptionalType */ || kind === 324 /* JSDocFunctionType */ || kind === 325 /* JSDocVariadicType */; } function isAccessExpression(node) { - return node.kind === 210 /* PropertyAccessExpression */ || node.kind === 211 /* ElementAccessExpression */; + return node.kind === 211 /* PropertyAccessExpression */ || node.kind === 212 /* ElementAccessExpression */; } function getNameOfAccessExpression(node) { - if (node.kind === 210 /* PropertyAccessExpression */) { + if (node.kind === 211 /* PropertyAccessExpression */) { return node.name; } - Debug.assert(node.kind === 211 /* ElementAccessExpression */); + Debug.assert(node.kind === 212 /* ElementAccessExpression */); return node.argumentExpression; } function isBundleFileTextLike(section) { @@ -116698,7 +99071,7 @@ ${lanes.join("\n")} } } function isNamedImportsOrExports(node) { - return node.kind === 274 /* NamedImports */ || node.kind === 278 /* NamedExports */; + return node.kind === 275 /* NamedImports */ || node.kind === 279 /* NamedExports */; } function getLeftmostAccessExpression(expr) { while (isAccessExpression(expr)) { @@ -116711,12 +99084,12 @@ ${lanes.join("\n")} return walkAccessExpression(name.parent); } function walkAccessExpression(access) { - if (access.kind === 210 /* PropertyAccessExpression */) { + if (access.kind === 211 /* PropertyAccessExpression */) { const res = action(access.name); if (res !== void 0) { return res; } - } else if (access.kind === 211 /* ElementAccessExpression */) { + } else if (access.kind === 212 /* ElementAccessExpression */) { if (isIdentifier(access.argumentExpression) || isStringLiteralLike(access.argumentExpression)) { const res = action(access.argumentExpression); if (res !== void 0) { @@ -116738,28 +99111,28 @@ ${lanes.join("\n")} function getLeftmostExpression(node, stopAtCallExpressions) { while (true) { switch (node.kind) { - case 224 /* PostfixUnaryExpression */: + case 225 /* PostfixUnaryExpression */: node = node.operand; continue; - case 225 /* BinaryExpression */: + case 226 /* BinaryExpression */: node = node.left; continue; - case 226 /* ConditionalExpression */: + case 227 /* ConditionalExpression */: node = node.condition; continue; - case 214 /* TaggedTemplateExpression */: + case 215 /* TaggedTemplateExpression */: node = node.tag; continue; - case 212 /* CallExpression */: + case 213 /* CallExpression */: if (stopAtCallExpressions) { return node; } - case 233 /* AsExpression */: - case 211 /* ElementAccessExpression */: - case 210 /* PropertyAccessExpression */: - case 234 /* NonNullExpression */: - case 359 /* PartiallyEmittedExpression */: - case 237 /* SatisfiesExpression */: + case 234 /* AsExpression */: + case 212 /* ElementAccessExpression */: + case 211 /* PropertyAccessExpression */: + case 235 /* NonNullExpression */: + case 360 /* PartiallyEmittedExpression */: + case 238 /* SatisfiesExpression */: node = node.expression; continue; } @@ -116840,8 +99213,8 @@ ${lanes.join("\n")} Object.assign(objectAllocator, alloc); forEach(objectAllocatorPatchers, (fn) => fn(objectAllocator)); } - function formatStringFromArgs(text, args, baseIndex = 0) { - return text.replace(/{(\d+)}/g, (_match, index) => "" + Debug.checkDefined(args[+index + baseIndex])); + function formatStringFromArgs(text, args) { + return text.replace(/{(\d+)}/g, (_match, index) => "" + Debug.checkDefined(args[+index])); } function setLocalizedDiagnosticMessages(messages) { localizedDiagnosticMessages = messages; @@ -116854,16 +99227,14 @@ ${lanes.join("\n")} function getLocaleSpecificMessage(message) { return localizedDiagnosticMessages && localizedDiagnosticMessages[message.key] || message.message; } - function createDetachedDiagnostic(fileName, start, length2, message) { - assertDiagnosticLocation( - /*file*/ - void 0, - start, - length2 - ); + function createDetachedDiagnostic(fileName, sourceText, start, length2, message, ...args) { + if (start + length2 > sourceText.length) { + length2 = sourceText.length - start; + } + assertDiagnosticLocation(sourceText, start, length2); let text = getLocaleSpecificMessage(message); - if (arguments.length > 4) { - text = formatStringFromArgs(text, arguments, 4); + if (some(args)) { + text = formatStringFromArgs(text, args); } return { file: void 0, @@ -116915,11 +99286,11 @@ ${lanes.join("\n")} } return diagnosticsWithLocation; } - function createFileDiagnostic(file, start, length2, message) { - assertDiagnosticLocation(file, start, length2); + function createFileDiagnostic(file, start, length2, message, ...args) { + assertDiagnosticLocation(file.text, start, length2); let text = getLocaleSpecificMessage(message); - if (arguments.length > 4) { - text = formatStringFromArgs(text, arguments, 4); + if (some(args)) { + text = formatStringFromArgs(text, args); } return { file, @@ -116932,17 +99303,17 @@ ${lanes.join("\n")} reportsDeprecated: message.reportsDeprecated }; } - function formatMessage(_dummy, message) { + function formatMessage(message, ...args) { let text = getLocaleSpecificMessage(message); - if (arguments.length > 2) { - text = formatStringFromArgs(text, arguments, 2); + if (some(args)) { + text = formatStringFromArgs(text, args); } return text; } - function createCompilerDiagnostic(message) { + function createCompilerDiagnostic(message, ...args) { let text = getLocaleSpecificMessage(message); - if (arguments.length > 1) { - text = formatStringFromArgs(text, arguments, 1); + if (some(args)) { + text = formatStringFromArgs(text, args); } return { file: void 0, @@ -116966,10 +99337,10 @@ ${lanes.join("\n")} relatedInformation }; } - function chainDiagnosticMessages(details, message) { + function chainDiagnosticMessages(details, message, ...args) { let text = getLocaleSpecificMessage(message); - if (arguments.length > 2) { - text = formatStringFromArgs(text, arguments, 2); + if (some(args)) { + text = formatStringFromArgs(text, args); } return { messageText: text, @@ -117217,6 +99588,9 @@ ${lanes.join("\n")} function getUseDefineForClassFields(compilerOptions) { return compilerOptions.useDefineForClassFields === void 0 ? getEmitScriptTarget(compilerOptions) >= 9 /* ES2022 */ : compilerOptions.useDefineForClassFields; } + function getEmitStandardClassFields(compilerOptions) { + return compilerOptions.useDefineForClassFields !== false && getEmitScriptTarget(compilerOptions) >= 9 /* ES2022 */; + } function compilerOptionsAffectSemanticDiagnostics(newOptions, oldOptions) { return optionsHaveChanges(oldOptions, newOptions, semanticDiagnosticsOptionDeclarations); } @@ -117227,7 +99601,7 @@ ${lanes.join("\n")} return optionsHaveChanges(oldOptions, newOptions, affectsDeclarationPathOptionDeclarations); } function getCompilerOptionValue(options, option) { - return option.strictFlag ? getStrictOptionValue(options, option.name) : options[option.name]; + return option.strictFlag ? getStrictOptionValue(options, option.name) : option.allowJsFlag ? getAllowJSCompilerOption(options) : options[option.name]; } function getJSXTransformEnabled(options) { const jsx = options.jsx; @@ -117269,19 +99643,16 @@ ${lanes.join("\n")} if (!containsIgnoredPath(symlinkPath)) { symlinkPath = ensureTrailingDirectorySeparator(symlinkPath); if (real !== false && !(symlinkedDirectories == null ? void 0 : symlinkedDirectories.has(symlinkPath))) { - (symlinkedDirectoriesByRealpath || (symlinkedDirectoriesByRealpath = createMultiMap())).add(ensureTrailingDirectorySeparator(real.realPath), symlink); + (symlinkedDirectoriesByRealpath || (symlinkedDirectoriesByRealpath = createMultiMap())).add(real.realPath, symlink); } (symlinkedDirectories || (symlinkedDirectories = /* @__PURE__ */ new Map())).set(symlinkPath, real); } }, - setSymlinksFromResolutions(files, typeReferenceDirectives) { - var _a, _b; + setSymlinksFromResolutions(forEachResolvedModule, forEachResolvedTypeReferenceDirective, typeReferenceDirectives) { Debug.assert(!hasProcessedResolutions); hasProcessedResolutions = true; - for (const file of files) { - (_a = file.resolvedModules) == null ? void 0 : _a.forEach((resolution) => processResolution(this, resolution.resolvedModule)); - (_b = file.resolvedTypeReferenceDirectiveNames) == null ? void 0 : _b.forEach((resolution) => processResolution(this, resolution.resolvedTypeReferenceDirective)); - } + forEachResolvedModule((resolution) => processResolution(this, resolution.resolvedModule)); + forEachResolvedTypeReferenceDirective((resolution) => processResolution(this, resolution.resolvedTypeReferenceDirective)); typeReferenceDirectives.forEach((resolution) => processResolution(this, resolution.resolvedTypeReferenceDirective)); }, hasProcessedResolutions: () => hasProcessedResolutions @@ -117295,7 +99666,10 @@ ${lanes.join("\n")} if (commonResolved && commonOriginal) { cache.setSymlinkedDirectory( commonOriginal, - { real: commonResolved, realPath: toPath(commonResolved, cwd, getCanonicalFileName) } + { + real: ensureTrailingDirectorySeparator(commonResolved), + realPath: ensureTrailingDirectorySeparator(toPath(commonResolved, cwd, getCanonicalFileName)) + } ); } } @@ -117402,7 +99776,7 @@ ${lanes.join("\n")} function replaceWildcardCharacter(match, singleAsteriskRegexFragment) { return match === "*" ? singleAsteriskRegexFragment : match === "?" ? "[^/]" : "\\" + match; } - function getFileMatcherPatterns(path, excludes, includes, useCaseSensitiveFileNames, currentDirectory) { + function getFileMatcherPatterns(path, excludes, includes, useCaseSensitiveFileNames2, currentDirectory) { path = normalizePath(path); currentDirectory = normalizePath(currentDirectory); const absolutePath = combinePaths(currentDirectory, path); @@ -117411,22 +99785,22 @@ ${lanes.join("\n")} includeFilePattern: getRegularExpressionForWildcard(includes, absolutePath, "files"), includeDirectoryPattern: getRegularExpressionForWildcard(includes, absolutePath, "directories"), excludePattern: getRegularExpressionForWildcard(excludes, absolutePath, "exclude"), - basePaths: getBasePaths(path, includes, useCaseSensitiveFileNames) + basePaths: getBasePaths(path, includes, useCaseSensitiveFileNames2) }; } - function getRegexFromPattern(pattern, useCaseSensitiveFileNames) { - return new RegExp(pattern, useCaseSensitiveFileNames ? "" : "i"); + function getRegexFromPattern(pattern, useCaseSensitiveFileNames2) { + return new RegExp(pattern, useCaseSensitiveFileNames2 ? "" : "i"); } - function matchFiles(path, extensions, excludes, includes, useCaseSensitiveFileNames, currentDirectory, depth, getFileSystemEntries, realpath) { + function matchFiles(path, extensions, excludes, includes, useCaseSensitiveFileNames2, currentDirectory, depth, getFileSystemEntries, realpath) { path = normalizePath(path); currentDirectory = normalizePath(currentDirectory); - const patterns = getFileMatcherPatterns(path, excludes, includes, useCaseSensitiveFileNames, currentDirectory); - const includeFileRegexes = patterns.includeFilePatterns && patterns.includeFilePatterns.map((pattern) => getRegexFromPattern(pattern, useCaseSensitiveFileNames)); - const includeDirectoryRegex = patterns.includeDirectoryPattern && getRegexFromPattern(patterns.includeDirectoryPattern, useCaseSensitiveFileNames); - const excludeRegex = patterns.excludePattern && getRegexFromPattern(patterns.excludePattern, useCaseSensitiveFileNames); + const patterns = getFileMatcherPatterns(path, excludes, includes, useCaseSensitiveFileNames2, currentDirectory); + const includeFileRegexes = patterns.includeFilePatterns && patterns.includeFilePatterns.map((pattern) => getRegexFromPattern(pattern, useCaseSensitiveFileNames2)); + const includeDirectoryRegex = patterns.includeDirectoryPattern && getRegexFromPattern(patterns.includeDirectoryPattern, useCaseSensitiveFileNames2); + const excludeRegex = patterns.excludePattern && getRegexFromPattern(patterns.excludePattern, useCaseSensitiveFileNames2); const results = includeFileRegexes ? includeFileRegexes.map(() => []) : [[]]; const visited = /* @__PURE__ */ new Map(); - const toCanonical = createGetCanonicalFileName(useCaseSensitiveFileNames); + const toCanonical = createGetCanonicalFileName(useCaseSensitiveFileNames2); for (const basePath of patterns.basePaths) { visitDirectory(basePath, combinePaths(currentDirectory, basePath), depth); } @@ -117468,7 +99842,7 @@ ${lanes.join("\n")} } } } - function getBasePaths(path, includes, useCaseSensitiveFileNames) { + function getBasePaths(path, includes, useCaseSensitiveFileNames2) { const basePaths = [path]; if (includes) { const includeBasePaths = []; @@ -117476,9 +99850,9 @@ ${lanes.join("\n")} const absolute = isRootedDiskPath(include) ? include : normalizePath(combinePaths(path, include)); includeBasePaths.push(getIncludeBasePath(absolute)); } - includeBasePaths.sort(getStringComparer(!useCaseSensitiveFileNames)); + includeBasePaths.sort(getStringComparer(!useCaseSensitiveFileNames2)); for (const includeBasePath of includeBasePaths) { - if (every(basePaths, (basePath) => !containsPath(basePath, includeBasePath, path, !useCaseSensitiveFileNames))) { + if (every(basePaths, (basePath) => !containsPath(basePath, includeBasePath, path, !useCaseSensitiveFileNames2))) { basePaths.push(includeBasePath); } } @@ -117525,7 +99899,7 @@ ${lanes.join("\n")} const flatBuiltins = flatten(builtins); const extensions = [ ...builtins, - ...mapDefined(extraFileExtensions, (x) => x.scriptKind === 7 /* Deferred */ || needJsExtensions && isJSLike(x.scriptKind) && flatBuiltins.indexOf(x.extension) === -1 ? [x.extension] : void 0) + ...mapDefined(extraFileExtensions, (x) => x.scriptKind === 7 /* Deferred */ || needJsExtensions && isJSLike(x.scriptKind) && !flatBuiltins.includes(x.extension) ? [x.extension] : void 0) ]; return extensions; } @@ -117837,39 +100211,39 @@ ${lanes.join("\n")} return success && result === 10 /* BigIntLiteral */ && scanner2.getTokenEnd() === s.length + 1 && !(flags & 512 /* ContainsSeparator */) && (!roundTripOnly || s === pseudoBigIntToString({ negative, base10Value: parsePseudoBigInt(scanner2.getTokenValue()) })); } function isValidTypeOnlyAliasUseSite(useSite) { - return !!(useSite.flags & 16777216 /* Ambient */) || isPartOfTypeQuery(useSite) || isIdentifierInNonEmittingHeritageClause(useSite) || isPartOfPossiblyValidTypeOrAbstractComputedPropertyName(useSite) || !(isExpressionNode(useSite) || isShorthandPropertyNameUseSite(useSite)); + return !!(useSite.flags & 33554432 /* Ambient */) || isPartOfTypeQuery(useSite) || isIdentifierInNonEmittingHeritageClause(useSite) || isPartOfPossiblyValidTypeOrAbstractComputedPropertyName(useSite) || !(isExpressionNode(useSite) || isShorthandPropertyNameUseSite(useSite)); } function isShorthandPropertyNameUseSite(useSite) { return isIdentifier(useSite) && isShorthandPropertyAssignment(useSite.parent) && useSite.parent.name === useSite; } function isPartOfPossiblyValidTypeOrAbstractComputedPropertyName(node) { - while (node.kind === 80 /* Identifier */ || node.kind === 210 /* PropertyAccessExpression */) { + while (node.kind === 80 /* Identifier */ || node.kind === 211 /* PropertyAccessExpression */) { node = node.parent; } - if (node.kind !== 166 /* ComputedPropertyName */) { + if (node.kind !== 167 /* ComputedPropertyName */) { return false; } - if (hasSyntacticModifier(node.parent, 256 /* Abstract */)) { + if (hasSyntacticModifier(node.parent, 64 /* Abstract */)) { return true; } const containerKind = node.parent.parent.kind; - return containerKind === 263 /* InterfaceDeclaration */ || containerKind === 186 /* TypeLiteral */; + return containerKind === 264 /* InterfaceDeclaration */ || containerKind === 187 /* TypeLiteral */; } function isIdentifierInNonEmittingHeritageClause(node) { if (node.kind !== 80 /* Identifier */) return false; const heritageClause = findAncestor(node.parent, (parent2) => { switch (parent2.kind) { - case 297 /* HeritageClause */: + case 298 /* HeritageClause */: return true; - case 210 /* PropertyAccessExpression */: - case 232 /* ExpressionWithTypeArguments */: + case 211 /* PropertyAccessExpression */: + case 233 /* ExpressionWithTypeArguments */: return false; default: return "quit"; } }); - return (heritageClause == null ? void 0 : heritageClause.token) === 119 /* ImplementsKeyword */ || (heritageClause == null ? void 0 : heritageClause.parent.kind) === 263 /* InterfaceDeclaration */; + return (heritageClause == null ? void 0 : heritageClause.token) === 119 /* ImplementsKeyword */ || (heritageClause == null ? void 0 : heritageClause.parent.kind) === 264 /* InterfaceDeclaration */; } function isIdentifierTypeReference(node) { return isTypeReferenceNode(node) && isIdentifier(node.typeName); @@ -117975,26 +100349,26 @@ ${lanes.join("\n")} } } function containsIgnoredPath(path) { - return some(ignoredPaths, (p) => stringContains(path, p)); + return some(ignoredPaths, (p) => path.includes(p)); } function getContainingNodeArray(node) { if (!node.parent) return void 0; switch (node.kind) { - case 167 /* TypeParameter */: + case 168 /* TypeParameter */: const { parent: parent3 } = node; - return parent3.kind === 194 /* InferType */ ? void 0 : parent3.typeParameters; - case 168 /* Parameter */: + return parent3.kind === 195 /* InferType */ ? void 0 : parent3.typeParameters; + case 169 /* Parameter */: return node.parent.parameters; - case 203 /* TemplateLiteralTypeSpan */: + case 204 /* TemplateLiteralTypeSpan */: return node.parent.templateSpans; - case 238 /* TemplateSpan */: + case 239 /* TemplateSpan */: return node.parent.templateSpans; - case 169 /* Decorator */: { + case 170 /* Decorator */: { const { parent: parent4 } = node; return canHaveDecorators(parent4) ? parent4.modifiers : void 0; } - case 297 /* HeritageClause */: + case 298 /* HeritageClause */: return node.parent.heritageClauses; } const { parent: parent2 } = node; @@ -118002,43 +100376,43 @@ ${lanes.join("\n")} return isJSDocTypeLiteral(node.parent) ? void 0 : node.parent.tags; } switch (parent2.kind) { - case 186 /* TypeLiteral */: - case 263 /* InterfaceDeclaration */: + case 187 /* TypeLiteral */: + case 264 /* InterfaceDeclaration */: return isTypeElement(node) ? parent2.members : void 0; - case 191 /* UnionType */: - case 192 /* IntersectionType */: + case 192 /* UnionType */: + case 193 /* IntersectionType */: return parent2.types; - case 188 /* TupleType */: - case 208 /* ArrayLiteralExpression */: - case 360 /* CommaListExpression */: - case 274 /* NamedImports */: - case 278 /* NamedExports */: + case 189 /* TupleType */: + case 209 /* ArrayLiteralExpression */: + case 361 /* CommaListExpression */: + case 275 /* NamedImports */: + case 279 /* NamedExports */: return parent2.elements; - case 209 /* ObjectLiteralExpression */: - case 291 /* JsxAttributes */: + case 210 /* ObjectLiteralExpression */: + case 292 /* JsxAttributes */: return parent2.properties; - case 212 /* CallExpression */: - case 213 /* NewExpression */: + case 213 /* CallExpression */: + case 214 /* NewExpression */: return isTypeNode(node) ? parent2.typeArguments : parent2.expression === node ? void 0 : parent2.arguments; - case 283 /* JsxElement */: - case 287 /* JsxFragment */: + case 284 /* JsxElement */: + case 288 /* JsxFragment */: return isJsxChild(node) ? parent2.children : void 0; - case 285 /* JsxOpeningElement */: - case 284 /* JsxSelfClosingElement */: + case 286 /* JsxOpeningElement */: + case 285 /* JsxSelfClosingElement */: return isTypeNode(node) ? parent2.typeArguments : void 0; - case 240 /* Block */: - case 295 /* CaseClause */: - case 296 /* DefaultClause */: - case 267 /* ModuleBlock */: + case 241 /* Block */: + case 296 /* CaseClause */: + case 297 /* DefaultClause */: + case 268 /* ModuleBlock */: return parent2.statements; - case 268 /* CaseBlock */: + case 269 /* CaseBlock */: return parent2.clauses; - case 262 /* ClassDeclaration */: - case 230 /* ClassExpression */: + case 263 /* ClassDeclaration */: + case 231 /* ClassExpression */: return isClassElement(node) ? parent2.members : void 0; - case 265 /* EnumDeclaration */: + case 266 /* EnumDeclaration */: return isEnumMember(node) ? parent2.members : void 0; - case 311 /* SourceFile */: + case 312 /* SourceFile */: return parent2.statements; } } @@ -118047,7 +100421,7 @@ ${lanes.join("\n")} if (some(node.parameters, (p) => !getEffectiveTypeAnnotationNode(p))) { return true; } - if (node.kind !== 218 /* ArrowFunction */) { + if (node.kind !== 219 /* ArrowFunction */) { const parameter = firstOrUndefined(node.parameters); if (!(parameter && parameterIsThisKeyword(parameter))) { return true; @@ -118060,14 +100434,14 @@ ${lanes.join("\n")} return name === "Infinity" || name === "-Infinity" || name === "NaN"; } function isCatchClauseVariableDeclaration(node) { - return node.kind === 259 /* VariableDeclaration */ && node.parent.kind === 298 /* CatchClause */; + return node.kind === 260 /* VariableDeclaration */ && node.parent.kind === 299 /* CatchClause */; } function isParameterOrCatchClauseVariable(symbol) { const declaration = symbol.valueDeclaration && getRootDeclaration(symbol.valueDeclaration); return !!declaration && (isParameter(declaration) || isCatchClauseVariableDeclaration(declaration)); } function isFunctionExpressionOrArrowFunction(node) { - return node.kind === 217 /* FunctionExpression */ || node.kind === 218 /* ArrowFunction */; + return node.kind === 218 /* FunctionExpression */ || node.kind === 219 /* ArrowFunction */; } function escapeSnippetText(text) { return text.replace(/\$/gm, () => "\\$"); @@ -118075,8 +100449,9 @@ ${lanes.join("\n")} function isNumericLiteralName(name) { return (+name).toString() === name; } - function createPropertyNameNodeForIdentifierOrLiteral(name, target, singleQuote, stringNamed) { - return isIdentifierText(name, target) ? factory.createIdentifier(name) : !stringNamed && isNumericLiteralName(name) && +name >= 0 ? factory.createNumericLiteral(+name) : factory.createStringLiteral(name, !!singleQuote); + function createPropertyNameNodeForIdentifierOrLiteral(name, target, singleQuote, stringNamed, isMethod) { + const isMethodNamedNew = isMethod && name === "new"; + return !isMethodNamedNew && isIdentifierText(name, target) ? factory.createIdentifier(name) : !stringNamed && !isMethodNamedNew && isNumericLiteralName(name) && +name >= 0 ? factory.createNumericLiteral(+name) : factory.createStringLiteral(name, !!singleQuote); } function isThisTypeParameter(type) { return !!(type.flags & 262144 /* TypeParameter */ && type.isThisType); @@ -118130,23 +100505,23 @@ ${lanes.join("\n")} } function getParameterTypeNode(parameter) { var _a; - return parameter.kind === 347 /* JSDocParameterTag */ ? (_a = parameter.typeExpression) == null ? void 0 : _a.type : parameter.type; + return parameter.kind === 348 /* JSDocParameterTag */ ? (_a = parameter.typeExpression) == null ? void 0 : _a.type : parameter.type; } function isTypeDeclaration(node) { switch (node.kind) { - case 167 /* TypeParameter */: - case 262 /* ClassDeclaration */: - case 263 /* InterfaceDeclaration */: - case 264 /* TypeAliasDeclaration */: - case 265 /* EnumDeclaration */: - case 352 /* JSDocTypedefTag */: - case 344 /* JSDocCallbackTag */: - case 346 /* JSDocEnumTag */: + case 168 /* TypeParameter */: + case 263 /* ClassDeclaration */: + case 264 /* InterfaceDeclaration */: + case 265 /* TypeAliasDeclaration */: + case 266 /* EnumDeclaration */: + case 353 /* JSDocTypedefTag */: + case 345 /* JSDocCallbackTag */: + case 347 /* JSDocEnumTag */: return true; - case 272 /* ImportClause */: + case 273 /* ImportClause */: return node.isTypeOnly; - case 275 /* ImportSpecifier */: - case 280 /* ExportSpecifier */: + case 276 /* ImportSpecifier */: + case 281 /* ExportSpecifier */: return node.parent.parent.isTypeOnly; default: return false; @@ -118160,7 +100535,7 @@ ${lanes.join("\n")} return false; } const { isBracketed, typeExpression } = node; - return isBracketed || !!typeExpression && typeExpression.type.kind === 322 /* JSDocOptionalType */; + return isBracketed || !!typeExpression && typeExpression.type.kind === 323 /* JSDocOptionalType */; } function canUsePropertyAccess(name, languageVersion) { if (name.length === 0) { @@ -118175,17 +100550,17 @@ ${lanes.join("\n")} } function isJSDocOptionalParameter(node) { return isInJSFile(node) && // node.type should only be a JSDocOptionalType when node is a parameter of a JSDocFunctionType - (node.type && node.type.kind === 322 /* JSDocOptionalType */ || getJSDocParameterTags(node).some(({ isBracketed, typeExpression }) => isBracketed || !!typeExpression && typeExpression.type.kind === 322 /* JSDocOptionalType */)); + (node.type && node.type.kind === 323 /* JSDocOptionalType */ || getJSDocParameterTags(node).some(({ isBracketed, typeExpression }) => isBracketed || !!typeExpression && typeExpression.type.kind === 323 /* JSDocOptionalType */)); } function isOptionalDeclaration(declaration) { switch (declaration.kind) { - case 171 /* PropertyDeclaration */: - case 170 /* PropertySignature */: + case 172 /* PropertyDeclaration */: + case 171 /* PropertySignature */: return !!declaration.questionToken; - case 168 /* Parameter */: + case 169 /* Parameter */: return !!declaration.questionToken || isJSDocOptionalParameter(declaration); - case 354 /* JSDocPropertyTag */: - case 347 /* JSDocParameterTag */: + case 355 /* JSDocPropertyTag */: + case 348 /* JSDocParameterTag */: return isOptionalJSDocPropertyLikeTag(declaration); default: return false; @@ -118193,7 +100568,7 @@ ${lanes.join("\n")} } function isNonNullAccess(node) { const kind = node.kind; - return (kind === 210 /* PropertyAccessExpression */ || kind === 211 /* ElementAccessExpression */) && isNonNullExpression(node.expression); + return (kind === 211 /* PropertyAccessExpression */ || kind === 212 /* ElementAccessExpression */) && isNonNullExpression(node.expression); } function isJSDocSatisfiesExpression(node) { return isInJSFile(node) && isParenthesizedExpression(node) && hasJSDocNodes(node) && !!getJSDocSatisfiesTag(node); @@ -118213,7 +100588,7 @@ ${lanes.join("\n")} } function isJsxAttributeName(node) { const kind = node.kind; - return kind === 80 /* Identifier */ || kind === 294 /* JsxNamespacedName */; + return kind === 80 /* Identifier */ || kind === 295 /* JsxNamespacedName */; } function getEscapedTextOfJsxNamespacedName(node) { return `${node.namespace.escapedText}:${idText(node.name)}`; @@ -118224,7 +100599,28 @@ ${lanes.join("\n")} function intrinsicTagNameToString(node) { return isIdentifier(node) ? idText(node) : getTextOfJsxNamespacedName(node); } - var resolvingEmptyArray, externalHelpersModuleNameText, defaultMaximumTruncationLength, noTruncationMaximumTruncationLength, stringWriter, GetLiteralTextFlags, fullTripleSlashReferencePathRegEx, fullTripleSlashReferenceTypeReferenceDirectiveRegEx, fullTripleSlashLibReferenceRegEx, fullTripleSlashAMDReferencePathRegEx, fullTripleSlashAMDModuleRegEx, defaultLibReferenceRegEx, AssignmentKind, FunctionFlags, Associativity, OperatorPrecedence, templateSubstitutionRegExp, doubleQuoteEscapedCharsRegExp, singleQuoteEscapedCharsRegExp, backtickQuoteEscapedCharsRegExp, escapedCharsMap, nonAsciiCharacters, jsxDoubleQuoteEscapedCharsRegExp, jsxSingleQuoteEscapedCharsRegExp, jsxEscapedCharsMap, indentStrings, base64Digits, carriageReturnLineFeed, lineFeed, objectAllocator, objectAllocatorPatchers, localizedDiagnosticMessages, reservedCharacterPattern, wildcardCharCodes, commonPackageFolders, implicitExcludePathRegexPattern, filesMatcher, directoriesMatcher, excludeMatcher, wildcardMatchers, supportedTSExtensions, supportedTSExtensionsFlat, supportedTSExtensionsWithJson, supportedTSExtensionsForExtractExtension, supportedJSExtensions, supportedJSExtensionsFlat, allSupportedExtensions, allSupportedExtensionsWithJson, supportedDeclarationExtensions, supportedTSImplementationExtensions, extensionsNotSupportingExtensionlessResolution, ModuleSpecifierEnding, extensionsToRemove, emptyFileSystemEntries; + function isTypeUsableAsPropertyName(type) { + return !!(type.flags & 8576 /* StringOrNumberLiteralOrUnique */); + } + function getPropertyNameFromType(type) { + if (type.flags & 8192 /* UniqueESSymbol */) { + return type.escapedName; + } + if (type.flags & (128 /* StringLiteral */ | 256 /* NumberLiteral */)) { + return escapeLeadingUnderscores("" + type.value); + } + return Debug.fail(); + } + function isExpandoPropertyDeclaration(declaration) { + return !!declaration && (isPropertyAccessExpression(declaration) || isElementAccessExpression(declaration) || isBinaryExpression(declaration)); + } + function hasResolutionModeOverride(node) { + if (node === void 0) { + return false; + } + return !!getResolutionModeOverride(node.attributes); + } + var resolvingEmptyArray, externalHelpersModuleNameText, defaultMaximumTruncationLength, noTruncationMaximumTruncationLength, stringWriter, getScriptTargetFeatures, GetLiteralTextFlags, fullTripleSlashReferencePathRegEx, fullTripleSlashReferenceTypeReferenceDirectiveRegEx, fullTripleSlashLibReferenceRegEx, fullTripleSlashAMDReferencePathRegEx, fullTripleSlashAMDModuleRegEx, defaultLibReferenceRegEx, AssignmentKind, FunctionFlags, Associativity, OperatorPrecedence, templateSubstitutionRegExp, doubleQuoteEscapedCharsRegExp, singleQuoteEscapedCharsRegExp, backtickQuoteEscapedCharsRegExp, escapedCharsMap, nonAsciiCharacters, jsxDoubleQuoteEscapedCharsRegExp, jsxSingleQuoteEscapedCharsRegExp, jsxEscapedCharsMap, indentStrings, base64Digits, carriageReturnLineFeed, lineFeed, objectAllocator, objectAllocatorPatchers, localizedDiagnosticMessages, reservedCharacterPattern, wildcardCharCodes, commonPackageFolders, implicitExcludePathRegexPattern, filesMatcher, directoriesMatcher, excludeMatcher, wildcardMatchers, supportedTSExtensions, supportedTSExtensionsFlat, supportedTSExtensionsWithJson, supportedTSExtensionsForExtractExtension, supportedJSExtensions, supportedJSExtensionsFlat, allSupportedExtensions, allSupportedExtensionsWithJson, supportedDeclarationExtensions, supportedTSImplementationExtensions, extensionsNotSupportingExtensionlessResolution, ModuleSpecifierEnding, extensionsToRemove, emptyFileSystemEntries; var init_utilities = __esm({ "src/compiler/utilities.ts"() { "use strict"; @@ -118234,6 +100630,402 @@ ${lanes.join("\n")} defaultMaximumTruncationLength = 160; noTruncationMaximumTruncationLength = 1e6; stringWriter = createSingleLineStringWriter(); + getScriptTargetFeatures = /* @__PURE__ */ memoize( + () => new Map(Object.entries({ + Array: new Map(Object.entries({ + es2015: [ + "find", + "findIndex", + "fill", + "copyWithin", + "entries", + "keys", + "values" + ], + es2016: [ + "includes" + ], + es2019: [ + "flat", + "flatMap" + ], + es2022: [ + "at" + ], + es2023: [ + "findLastIndex", + "findLast" + ] + })), + Iterator: new Map(Object.entries({ + es2015: emptyArray + })), + AsyncIterator: new Map(Object.entries({ + es2015: emptyArray + })), + Atomics: new Map(Object.entries({ + es2017: emptyArray + })), + SharedArrayBuffer: new Map(Object.entries({ + es2017: emptyArray + })), + AsyncIterable: new Map(Object.entries({ + es2018: emptyArray + })), + AsyncIterableIterator: new Map(Object.entries({ + es2018: emptyArray + })), + AsyncGenerator: new Map(Object.entries({ + es2018: emptyArray + })), + AsyncGeneratorFunction: new Map(Object.entries({ + es2018: emptyArray + })), + RegExp: new Map(Object.entries({ + es2015: [ + "flags", + "sticky", + "unicode" + ], + es2018: [ + "dotAll" + ] + })), + Reflect: new Map(Object.entries({ + es2015: [ + "apply", + "construct", + "defineProperty", + "deleteProperty", + "get", + "getOwnPropertyDescriptor", + "getPrototypeOf", + "has", + "isExtensible", + "ownKeys", + "preventExtensions", + "set", + "setPrototypeOf" + ] + })), + ArrayConstructor: new Map(Object.entries({ + es2015: [ + "from", + "of" + ] + })), + ObjectConstructor: new Map(Object.entries({ + es2015: [ + "assign", + "getOwnPropertySymbols", + "keys", + "is", + "setPrototypeOf" + ], + es2017: [ + "values", + "entries", + "getOwnPropertyDescriptors" + ], + es2019: [ + "fromEntries" + ], + es2022: [ + "hasOwn" + ] + })), + NumberConstructor: new Map(Object.entries({ + es2015: [ + "isFinite", + "isInteger", + "isNaN", + "isSafeInteger", + "parseFloat", + "parseInt" + ] + })), + Math: new Map(Object.entries({ + es2015: [ + "clz32", + "imul", + "sign", + "log10", + "log2", + "log1p", + "expm1", + "cosh", + "sinh", + "tanh", + "acosh", + "asinh", + "atanh", + "hypot", + "trunc", + "fround", + "cbrt" + ] + })), + Map: new Map(Object.entries({ + es2015: [ + "entries", + "keys", + "values" + ] + })), + Set: new Map(Object.entries({ + es2015: [ + "entries", + "keys", + "values" + ] + })), + PromiseConstructor: new Map(Object.entries({ + es2015: [ + "all", + "race", + "reject", + "resolve" + ], + es2020: [ + "allSettled" + ], + es2021: [ + "any" + ] + })), + Symbol: new Map(Object.entries({ + es2015: [ + "for", + "keyFor" + ], + es2019: [ + "description" + ] + })), + WeakMap: new Map(Object.entries({ + es2015: [ + "entries", + "keys", + "values" + ] + })), + WeakSet: new Map(Object.entries({ + es2015: [ + "entries", + "keys", + "values" + ] + })), + String: new Map(Object.entries({ + es2015: [ + "codePointAt", + "includes", + "endsWith", + "normalize", + "repeat", + "startsWith", + "anchor", + "big", + "blink", + "bold", + "fixed", + "fontcolor", + "fontsize", + "italics", + "link", + "small", + "strike", + "sub", + "sup" + ], + es2017: [ + "padStart", + "padEnd" + ], + es2019: [ + "trimStart", + "trimEnd", + "trimLeft", + "trimRight" + ], + es2020: [ + "matchAll" + ], + es2021: [ + "replaceAll" + ], + es2022: [ + "at" + ] + })), + StringConstructor: new Map(Object.entries({ + es2015: [ + "fromCodePoint", + "raw" + ] + })), + DateTimeFormat: new Map(Object.entries({ + es2017: [ + "formatToParts" + ] + })), + Promise: new Map(Object.entries({ + es2015: emptyArray, + es2018: [ + "finally" + ] + })), + RegExpMatchArray: new Map(Object.entries({ + es2018: [ + "groups" + ] + })), + RegExpExecArray: new Map(Object.entries({ + es2018: [ + "groups" + ] + })), + Intl: new Map(Object.entries({ + es2018: [ + "PluralRules" + ] + })), + NumberFormat: new Map(Object.entries({ + es2018: [ + "formatToParts" + ] + })), + SymbolConstructor: new Map(Object.entries({ + es2020: [ + "matchAll" + ] + })), + DataView: new Map(Object.entries({ + es2020: [ + "setBigInt64", + "setBigUint64", + "getBigInt64", + "getBigUint64" + ] + })), + BigInt: new Map(Object.entries({ + es2020: emptyArray + })), + RelativeTimeFormat: new Map(Object.entries({ + es2020: [ + "format", + "formatToParts", + "resolvedOptions" + ] + })), + Int8Array: new Map(Object.entries({ + es2022: [ + "at" + ], + es2023: [ + "findLastIndex", + "findLast" + ] + })), + Uint8Array: new Map(Object.entries({ + es2022: [ + "at" + ], + es2023: [ + "findLastIndex", + "findLast" + ] + })), + Uint8ClampedArray: new Map(Object.entries({ + es2022: [ + "at" + ], + es2023: [ + "findLastIndex", + "findLast" + ] + })), + Int16Array: new Map(Object.entries({ + es2022: [ + "at" + ], + es2023: [ + "findLastIndex", + "findLast" + ] + })), + Uint16Array: new Map(Object.entries({ + es2022: [ + "at" + ], + es2023: [ + "findLastIndex", + "findLast" + ] + })), + Int32Array: new Map(Object.entries({ + es2022: [ + "at" + ], + es2023: [ + "findLastIndex", + "findLast" + ] + })), + Uint32Array: new Map(Object.entries({ + es2022: [ + "at" + ], + es2023: [ + "findLastIndex", + "findLast" + ] + })), + Float32Array: new Map(Object.entries({ + es2022: [ + "at" + ], + es2023: [ + "findLastIndex", + "findLast" + ] + })), + Float64Array: new Map(Object.entries({ + es2022: [ + "at" + ], + es2023: [ + "findLastIndex", + "findLast" + ] + })), + BigInt64Array: new Map(Object.entries({ + es2020: emptyArray, + es2022: [ + "at" + ], + es2023: [ + "findLastIndex", + "findLast" + ] + })), + BigUint64Array: new Map(Object.entries({ + es2020: emptyArray, + es2022: [ + "at" + ], + es2023: [ + "findLastIndex", + "findLast" + ] + })), + Error: new Map(Object.entries({ + es2022: [ + "cause" + ] + })) + })) + ); GetLiteralTextFlags = /* @__PURE__ */ ((GetLiteralTextFlags2) => { GetLiteralTextFlags2[GetLiteralTextFlags2["None"] = 0] = "None"; GetLiteralTextFlags2[GetLiteralTextFlags2["NeverAsciiEscape"] = 1] = "NeverAsciiEscape"; @@ -118296,9 +101088,9 @@ ${lanes.join("\n")} return OperatorPrecedence2; })(OperatorPrecedence || {}); templateSubstitutionRegExp = /\$\{/g; - doubleQuoteEscapedCharsRegExp = /[\\\"\u0000-\u001f\t\v\f\b\r\n\u2028\u2029\u0085]/g; - singleQuoteEscapedCharsRegExp = /[\\\'\u0000-\u001f\t\v\f\b\r\n\u2028\u2029\u0085]/g; - backtickQuoteEscapedCharsRegExp = /\r\n|[\\\`\u0000-\u001f\t\v\f\b\r\u2028\u2029\u0085]/g; + doubleQuoteEscapedCharsRegExp = /[\\"\u0000-\u001f\t\v\f\b\r\n\u2028\u2029\u0085]/g; + singleQuoteEscapedCharsRegExp = /[\\'\u0000-\u001f\t\v\f\b\r\n\u2028\u2029\u0085]/g; + backtickQuoteEscapedCharsRegExp = /\r\n|[\\`\u0000-\u001f\t\v\f\b\r\u2028\u2029\u0085]/g; escapedCharsMap = new Map(Object.entries({ " ": "\\t", "\v": "\\v", @@ -118320,8 +101112,8 @@ ${lanes.join("\n")} // special case for CRLFs in backticks })); nonAsciiCharacters = /[^\u0000-\u007F]/g; - jsxDoubleQuoteEscapedCharsRegExp = /[\"\u0000-\u001f\u2028\u2029\u0085]/g; - jsxSingleQuoteEscapedCharsRegExp = /[\'\u0000-\u001f\u2028\u2029\u0085]/g; + jsxDoubleQuoteEscapedCharsRegExp = /["\u0000-\u001f\u2028\u2029\u0085]/g; + jsxSingleQuoteEscapedCharsRegExp = /['\u0000-\u001f\u2028\u2029\u0085]/g; jsxEscapedCharsMap = new Map(Object.entries({ '"': """, "'": "'" @@ -118342,7 +101134,7 @@ ${lanes.join("\n")} getSourceMapSourceConstructor: () => SourceMapSource }; objectAllocatorPatchers = []; - reservedCharacterPattern = /[^\w\s\/]/g; + reservedCharacterPattern = /[^\w\s/]/g; wildcardCharCodes = [42 /* asterisk */, 63 /* question */]; commonPackageFolders = ["node_modules", "bower_components", "jspm_packages"]; implicitExcludePathRegexPattern = `(?!(${commonPackageFolders.join("|")})(/|$))`; @@ -118533,16 +101325,16 @@ ${lanes.join("\n")} return parenthesizerRule; } function binaryOperandNeedsParentheses(binaryOperator, operand, isLeftSideOfBinary, leftOperand) { - const binaryOperatorPrecedence = getOperatorPrecedence(225 /* BinaryExpression */, binaryOperator); - const binaryOperatorAssociativity = getOperatorAssociativity(225 /* BinaryExpression */, binaryOperator); + const binaryOperatorPrecedence = getOperatorPrecedence(226 /* BinaryExpression */, binaryOperator); + const binaryOperatorAssociativity = getOperatorAssociativity(226 /* BinaryExpression */, binaryOperator); const emittedOperand = skipPartiallyEmittedExpressions(operand); - if (!isLeftSideOfBinary && operand.kind === 218 /* ArrowFunction */ && binaryOperatorPrecedence > 3 /* Assignment */) { + if (!isLeftSideOfBinary && operand.kind === 219 /* ArrowFunction */ && binaryOperatorPrecedence > 3 /* Assignment */) { return true; } const operandPrecedence = getExpressionPrecedence(emittedOperand); switch (compareValues(operandPrecedence, binaryOperatorPrecedence)) { case -1 /* LessThan */: - if (!isLeftSideOfBinary && binaryOperatorAssociativity === 1 /* Right */ && operand.kind === 228 /* YieldExpression */) { + if (!isLeftSideOfBinary && binaryOperatorAssociativity === 1 /* Right */ && operand.kind === 229 /* YieldExpression */) { return false; } return true; @@ -118576,7 +101368,7 @@ ${lanes.join("\n")} if (isLiteralKind(node.kind)) { return node.kind; } - if (node.kind === 225 /* BinaryExpression */ && node.operatorToken.kind === 40 /* PlusToken */) { + if (node.kind === 226 /* BinaryExpression */ && node.operatorToken.kind === 40 /* PlusToken */) { if (node.cachedLiteralKind !== void 0) { return node.cachedLiteralKind; } @@ -118589,7 +101381,7 @@ ${lanes.join("\n")} } function parenthesizeBinaryOperand(binaryOperator, operand, isLeftSideOfBinary, leftOperand) { const skipped = skipPartiallyEmittedExpressions(operand); - if (skipped.kind === 216 /* ParenthesizedExpression */) { + if (skipped.kind === 217 /* ParenthesizedExpression */) { return operand; } return binaryOperandNeedsParentheses(binaryOperator, operand, isLeftSideOfBinary, leftOperand) ? factory2.createParenthesizedExpression(operand) : operand; @@ -118615,7 +101407,7 @@ ${lanes.join("\n")} return isCommaSequence(expression) ? factory2.createParenthesizedExpression(expression) : expression; } function parenthesizeConditionOfConditionalExpression(condition) { - const conditionalPrecedence = getOperatorPrecedence(226 /* ConditionalExpression */, 58 /* QuestionToken */); + const conditionalPrecedence = getOperatorPrecedence(227 /* ConditionalExpression */, 58 /* QuestionToken */); const emittedCondition = skipPartiallyEmittedExpressions(condition); const conditionPrecedence = getExpressionPrecedence(emittedCondition); if (compareValues(conditionPrecedence, conditionalPrecedence) !== 1 /* GreaterThan */) { @@ -118636,8 +101428,8 @@ ${lanes.join("\n")} /*stopAtCallExpressions*/ false ).kind) { - case 230 /* ClassExpression */: - case 217 /* FunctionExpression */: + case 231 /* ClassExpression */: + case 218 /* FunctionExpression */: needsParens = true; } } @@ -118650,16 +101442,16 @@ ${lanes.join("\n")} true ); switch (leftmostExpr.kind) { - case 212 /* CallExpression */: + case 213 /* CallExpression */: return factory2.createParenthesizedExpression(expression); - case 213 /* NewExpression */: + case 214 /* NewExpression */: return !leftmostExpr.arguments ? factory2.createParenthesizedExpression(expression) : expression; } return parenthesizeLeftSideOfAccess(expression); } function parenthesizeLeftSideOfAccess(expression, optionalChain) { const emittedExpression = skipPartiallyEmittedExpressions(expression); - if (isLeftHandSideExpression(emittedExpression) && (emittedExpression.kind !== 213 /* NewExpression */ || emittedExpression.arguments) && (optionalChain || !isOptionalChain(emittedExpression))) { + if (isLeftHandSideExpression(emittedExpression) && (emittedExpression.kind !== 214 /* NewExpression */ || emittedExpression.arguments) && (optionalChain || !isOptionalChain(emittedExpression))) { return expression; } return setTextRange(factory2.createParenthesizedExpression(expression), expression); @@ -118677,7 +101469,7 @@ ${lanes.join("\n")} function parenthesizeExpressionForDisallowedComma(expression) { const emittedExpression = skipPartiallyEmittedExpressions(expression); const expressionPrecedence = getExpressionPrecedence(emittedExpression); - const commaPrecedence = getOperatorPrecedence(225 /* BinaryExpression */, 28 /* CommaToken */); + const commaPrecedence = getOperatorPrecedence(226 /* BinaryExpression */, 28 /* CommaToken */); return expressionPrecedence > commaPrecedence ? expression : setTextRange(factory2.createParenthesizedExpression(expression), expression); } function parenthesizeExpressionOfExpressionStatement(expression) { @@ -118685,7 +101477,7 @@ ${lanes.join("\n")} if (isCallExpression(emittedExpression)) { const callee = emittedExpression.expression; const kind = skipPartiallyEmittedExpressions(callee).kind; - if (kind === 217 /* FunctionExpression */ || kind === 218 /* ArrowFunction */) { + if (kind === 218 /* FunctionExpression */ || kind === 219 /* ArrowFunction */) { const updated = factory2.updateCallExpression( emittedExpression, setTextRange(factory2.createParenthesizedExpression(callee), callee), @@ -118700,7 +101492,7 @@ ${lanes.join("\n")} /*stopAtCallExpressions*/ false ).kind; - if (leftmostExpressionKind === 209 /* ObjectLiteralExpression */ || leftmostExpressionKind === 217 /* FunctionExpression */) { + if (leftmostExpressionKind === 210 /* ObjectLiteralExpression */ || leftmostExpressionKind === 218 /* FunctionExpression */) { return setTextRange(factory2.createParenthesizedExpression(expression), expression); } return expression; @@ -118710,31 +101502,31 @@ ${lanes.join("\n")} body, /*stopAtCallExpressions*/ false - ).kind === 209 /* ObjectLiteralExpression */)) { + ).kind === 210 /* ObjectLiteralExpression */)) { return setTextRange(factory2.createParenthesizedExpression(body), body); } return body; } function parenthesizeCheckTypeOfConditionalType(checkType) { switch (checkType.kind) { - case 183 /* FunctionType */: - case 184 /* ConstructorType */: - case 193 /* ConditionalType */: + case 184 /* FunctionType */: + case 185 /* ConstructorType */: + case 194 /* ConditionalType */: return factory2.createParenthesizedType(checkType); } return checkType; } function parenthesizeExtendsTypeOfConditionalType(extendsType) { switch (extendsType.kind) { - case 193 /* ConditionalType */: + case 194 /* ConditionalType */: return factory2.createParenthesizedType(extendsType); } return extendsType; } function parenthesizeConstituentTypeOfUnionType(type) { switch (type.kind) { - case 191 /* UnionType */: - case 192 /* IntersectionType */: + case 192 /* UnionType */: + case 193 /* IntersectionType */: return factory2.createParenthesizedType(type); } return parenthesizeCheckTypeOfConditionalType(type); @@ -118744,8 +101536,8 @@ ${lanes.join("\n")} } function parenthesizeConstituentTypeOfIntersectionType(type) { switch (type.kind) { - case 191 /* UnionType */: - case 192 /* IntersectionType */: + case 192 /* UnionType */: + case 193 /* IntersectionType */: return factory2.createParenthesizedType(type); } return parenthesizeConstituentTypeOfUnionType(type); @@ -118755,23 +101547,23 @@ ${lanes.join("\n")} } function parenthesizeOperandOfTypeOperator(type) { switch (type.kind) { - case 192 /* IntersectionType */: + case 193 /* IntersectionType */: return factory2.createParenthesizedType(type); } return parenthesizeConstituentTypeOfIntersectionType(type); } function parenthesizeOperandOfReadonlyTypeOperator(type) { switch (type.kind) { - case 197 /* TypeOperator */: + case 198 /* TypeOperator */: return factory2.createParenthesizedType(type); } return parenthesizeOperandOfTypeOperator(type); } function parenthesizeNonArrayTypeOfPostfixType(type) { switch (type.kind) { - case 194 /* InferType */: - case 197 /* TypeOperator */: - case 185 /* TypeQuery */: + case 195 /* InferType */: + case 198 /* TypeOperator */: + case 186 /* TypeQuery */: return factory2.createParenthesizedType(type); } return parenthesizeOperandOfTypeOperator(type); @@ -118863,6 +101655,7 @@ ${lanes.join("\n")} return { convertToFunctionBlock, convertToFunctionExpression, + convertToClassExpression, convertToArrayAssignmentElement, convertToObjectAssignmentElement, convertToAssignmentPattern, @@ -118880,10 +101673,11 @@ ${lanes.join("\n")} return body; } function convertToFunctionExpression(node) { + var _a; if (!node.body) return Debug.fail(`Cannot convert a FunctionDeclaration without a body`); const updated = factory2.createFunctionExpression( - getModifiers(node), + (_a = getModifiers(node)) == null ? void 0 : _a.filter((modifier) => !isExportModifier(modifier) && !isDefaultModifier(modifier)), node.asteriskToken, node.name, node.typeParameters, @@ -118902,6 +101696,26 @@ ${lanes.join("\n")} } return updated; } + function convertToClassExpression(node) { + var _a; + const updated = factory2.createClassExpression( + (_a = node.modifiers) == null ? void 0 : _a.filter((modifier) => !isExportModifier(modifier) && !isDefaultModifier(modifier)), + node.name, + node.typeParameters, + node.heritageClauses, + node.members + ); + setOriginalNode(updated, node); + setTextRange(updated, node); + if (getStartsOnNewLine(node)) { + setStartsOnNewLine( + updated, + /*newLine*/ + true + ); + } + return updated; + } function convertToArrayAssignmentElement(element) { if (isBindingElement(element)) { if (element.dotDotDotToken) { @@ -118936,11 +101750,11 @@ ${lanes.join("\n")} } function convertToAssignmentPattern(node) { switch (node.kind) { - case 206 /* ArrayBindingPattern */: - case 208 /* ArrayLiteralExpression */: + case 207 /* ArrayBindingPattern */: + case 209 /* ArrayLiteralExpression */: return convertToArrayAssignmentPattern(node); - case 205 /* ObjectBindingPattern */: - case 209 /* ObjectLiteralExpression */: + case 206 /* ObjectBindingPattern */: + case 210 /* ObjectLiteralExpression */: return convertToObjectAssignmentPattern(node); } } @@ -118983,6 +101797,7 @@ ${lanes.join("\n")} nullNodeConverters = { convertToFunctionBlock: notImplemented, convertToFunctionExpression: notImplemented, + convertToClassExpression: notImplemented, convertToArrayAssignmentElement: notImplemented, convertToObjectAssignmentElement: notImplemented, convertToAssignmentPattern: notImplemented, @@ -119274,6 +102089,10 @@ ${lanes.join("\n")} updateAssertEntry, createImportTypeAssertionContainer, updateImportTypeAssertionContainer, + createImportAttributes, + updateImportAttributes, + createImportAttribute, + updateImportAttribute, createNamespaceImport, updateNamespaceImport, createNamespaceExport, @@ -119295,40 +102114,40 @@ ${lanes.join("\n")} updateExternalModuleReference, // lazily load factory members for JSDoc types with similar structure get createJSDocAllType() { - return getJSDocPrimaryTypeCreateFunction(318 /* JSDocAllType */); + return getJSDocPrimaryTypeCreateFunction(319 /* JSDocAllType */); }, get createJSDocUnknownType() { - return getJSDocPrimaryTypeCreateFunction(319 /* JSDocUnknownType */); + return getJSDocPrimaryTypeCreateFunction(320 /* JSDocUnknownType */); }, get createJSDocNonNullableType() { - return getJSDocPrePostfixUnaryTypeCreateFunction(321 /* JSDocNonNullableType */); + return getJSDocPrePostfixUnaryTypeCreateFunction(322 /* JSDocNonNullableType */); }, get updateJSDocNonNullableType() { - return getJSDocPrePostfixUnaryTypeUpdateFunction(321 /* JSDocNonNullableType */); + return getJSDocPrePostfixUnaryTypeUpdateFunction(322 /* JSDocNonNullableType */); }, get createJSDocNullableType() { - return getJSDocPrePostfixUnaryTypeCreateFunction(320 /* JSDocNullableType */); + return getJSDocPrePostfixUnaryTypeCreateFunction(321 /* JSDocNullableType */); }, get updateJSDocNullableType() { - return getJSDocPrePostfixUnaryTypeUpdateFunction(320 /* JSDocNullableType */); + return getJSDocPrePostfixUnaryTypeUpdateFunction(321 /* JSDocNullableType */); }, get createJSDocOptionalType() { - return getJSDocUnaryTypeCreateFunction(322 /* JSDocOptionalType */); + return getJSDocUnaryTypeCreateFunction(323 /* JSDocOptionalType */); }, get updateJSDocOptionalType() { - return getJSDocUnaryTypeUpdateFunction(322 /* JSDocOptionalType */); + return getJSDocUnaryTypeUpdateFunction(323 /* JSDocOptionalType */); }, get createJSDocVariadicType() { - return getJSDocUnaryTypeCreateFunction(324 /* JSDocVariadicType */); + return getJSDocUnaryTypeCreateFunction(325 /* JSDocVariadicType */); }, get updateJSDocVariadicType() { - return getJSDocUnaryTypeUpdateFunction(324 /* JSDocVariadicType */); + return getJSDocUnaryTypeUpdateFunction(325 /* JSDocVariadicType */); }, get createJSDocNamepathType() { - return getJSDocUnaryTypeCreateFunction(325 /* JSDocNamepathType */); + return getJSDocUnaryTypeCreateFunction(326 /* JSDocNamepathType */); }, get updateJSDocNamepathType() { - return getJSDocUnaryTypeUpdateFunction(325 /* JSDocNamepathType */); + return getJSDocUnaryTypeUpdateFunction(326 /* JSDocNamepathType */); }, createJSDocFunctionType, updateJSDocFunctionType, @@ -119368,82 +102187,82 @@ ${lanes.join("\n")} updateJSDocLinkPlain, // lazily load factory members for JSDoc tags with similar structure get createJSDocTypeTag() { - return getJSDocTypeLikeTagCreateFunction(350 /* JSDocTypeTag */); + return getJSDocTypeLikeTagCreateFunction(351 /* JSDocTypeTag */); }, get updateJSDocTypeTag() { - return getJSDocTypeLikeTagUpdateFunction(350 /* JSDocTypeTag */); + return getJSDocTypeLikeTagUpdateFunction(351 /* JSDocTypeTag */); }, get createJSDocReturnTag() { - return getJSDocTypeLikeTagCreateFunction(348 /* JSDocReturnTag */); + return getJSDocTypeLikeTagCreateFunction(349 /* JSDocReturnTag */); }, get updateJSDocReturnTag() { - return getJSDocTypeLikeTagUpdateFunction(348 /* JSDocReturnTag */); + return getJSDocTypeLikeTagUpdateFunction(349 /* JSDocReturnTag */); }, get createJSDocThisTag() { - return getJSDocTypeLikeTagCreateFunction(349 /* JSDocThisTag */); + return getJSDocTypeLikeTagCreateFunction(350 /* JSDocThisTag */); }, get updateJSDocThisTag() { - return getJSDocTypeLikeTagUpdateFunction(349 /* JSDocThisTag */); + return getJSDocTypeLikeTagUpdateFunction(350 /* JSDocThisTag */); }, get createJSDocAuthorTag() { - return getJSDocSimpleTagCreateFunction(336 /* JSDocAuthorTag */); + return getJSDocSimpleTagCreateFunction(337 /* JSDocAuthorTag */); }, get updateJSDocAuthorTag() { - return getJSDocSimpleTagUpdateFunction(336 /* JSDocAuthorTag */); + return getJSDocSimpleTagUpdateFunction(337 /* JSDocAuthorTag */); }, get createJSDocClassTag() { - return getJSDocSimpleTagCreateFunction(338 /* JSDocClassTag */); + return getJSDocSimpleTagCreateFunction(339 /* JSDocClassTag */); }, get updateJSDocClassTag() { - return getJSDocSimpleTagUpdateFunction(338 /* JSDocClassTag */); + return getJSDocSimpleTagUpdateFunction(339 /* JSDocClassTag */); }, get createJSDocPublicTag() { - return getJSDocSimpleTagCreateFunction(339 /* JSDocPublicTag */); + return getJSDocSimpleTagCreateFunction(340 /* JSDocPublicTag */); }, get updateJSDocPublicTag() { - return getJSDocSimpleTagUpdateFunction(339 /* JSDocPublicTag */); + return getJSDocSimpleTagUpdateFunction(340 /* JSDocPublicTag */); }, get createJSDocPrivateTag() { - return getJSDocSimpleTagCreateFunction(340 /* JSDocPrivateTag */); + return getJSDocSimpleTagCreateFunction(341 /* JSDocPrivateTag */); }, get updateJSDocPrivateTag() { - return getJSDocSimpleTagUpdateFunction(340 /* JSDocPrivateTag */); + return getJSDocSimpleTagUpdateFunction(341 /* JSDocPrivateTag */); }, get createJSDocProtectedTag() { - return getJSDocSimpleTagCreateFunction(341 /* JSDocProtectedTag */); + return getJSDocSimpleTagCreateFunction(342 /* JSDocProtectedTag */); }, get updateJSDocProtectedTag() { - return getJSDocSimpleTagUpdateFunction(341 /* JSDocProtectedTag */); + return getJSDocSimpleTagUpdateFunction(342 /* JSDocProtectedTag */); }, get createJSDocReadonlyTag() { - return getJSDocSimpleTagCreateFunction(342 /* JSDocReadonlyTag */); + return getJSDocSimpleTagCreateFunction(343 /* JSDocReadonlyTag */); }, get updateJSDocReadonlyTag() { - return getJSDocSimpleTagUpdateFunction(342 /* JSDocReadonlyTag */); + return getJSDocSimpleTagUpdateFunction(343 /* JSDocReadonlyTag */); }, get createJSDocOverrideTag() { - return getJSDocSimpleTagCreateFunction(343 /* JSDocOverrideTag */); + return getJSDocSimpleTagCreateFunction(344 /* JSDocOverrideTag */); }, get updateJSDocOverrideTag() { - return getJSDocSimpleTagUpdateFunction(343 /* JSDocOverrideTag */); + return getJSDocSimpleTagUpdateFunction(344 /* JSDocOverrideTag */); }, get createJSDocDeprecatedTag() { - return getJSDocSimpleTagCreateFunction(337 /* JSDocDeprecatedTag */); + return getJSDocSimpleTagCreateFunction(338 /* JSDocDeprecatedTag */); }, get updateJSDocDeprecatedTag() { - return getJSDocSimpleTagUpdateFunction(337 /* JSDocDeprecatedTag */); + return getJSDocSimpleTagUpdateFunction(338 /* JSDocDeprecatedTag */); }, get createJSDocThrowsTag() { - return getJSDocTypeLikeTagCreateFunction(355 /* JSDocThrowsTag */); + return getJSDocTypeLikeTagCreateFunction(356 /* JSDocThrowsTag */); }, get updateJSDocThrowsTag() { - return getJSDocTypeLikeTagUpdateFunction(355 /* JSDocThrowsTag */); + return getJSDocTypeLikeTagUpdateFunction(356 /* JSDocThrowsTag */); }, get createJSDocSatisfiesTag() { - return getJSDocTypeLikeTagCreateFunction(356 /* JSDocSatisfiesTag */); + return getJSDocTypeLikeTagCreateFunction(357 /* JSDocSatisfiesTag */); }, get updateJSDocSatisfiesTag() { - return getJSDocTypeLikeTagUpdateFunction(356 /* JSDocSatisfiesTag */); + return getJSDocTypeLikeTagUpdateFunction(357 /* JSDocSatisfiesTag */); }, createJSDocEnumTag, updateJSDocEnumTag, @@ -119618,6 +102437,7 @@ ${lanes.join("\n")} createExportDefault, createExternalModuleExport, createTypeCheck, + createIsNotTypeCheck, createMethodCall, createGlobalMethodCall, createFunctionBindCall, @@ -119649,7 +102469,9 @@ ${lanes.join("\n")} ensureUseStrict, liftToBlock, mergeLexicalEnvironment, - updateModifiers + replaceModifiers, + replaceDecoratorsAndModifiers, + replacePropertyName }; forEach(nodeFactoryPatchers, (fn) => fn(factory2)); return factory2; @@ -119807,11 +102629,11 @@ ${lanes.join("\n")} } const node = createBaseIdentifier(escapeLeadingUnderscores(text)); if (hasExtendedUnicodeEscape) - node.flags |= 128 /* IdentifierHasExtendedUnicodeEscape */; + node.flags |= 256 /* IdentifierHasExtendedUnicodeEscape */; if (node.escapedText === "await") { node.transformFlags |= 67108864 /* ContainsPossibleTopLevelAwait */; } - if (node.flags & 128 /* IdentifierHasExtendedUnicodeEscape */) { + if (node.flags & 256 /* IdentifierHasExtendedUnicodeEscape */) { node.transformFlags |= 1024 /* ContainsES2015 */; } return node; @@ -119906,7 +102728,7 @@ ${lanes.join("\n")} return baseFactory2.createBaseTokenNode(kind); } function createToken(token) { - Debug.assert(token >= 0 /* FirstToken */ && token <= 164 /* LastToken */, "Invalid token"); + Debug.assert(token >= 0 /* FirstToken */ && token <= 165 /* LastToken */, "Invalid token"); Debug.assert(token <= 15 /* FirstTemplateToken */ || token >= 18 /* LastTemplateToken */, "Invalid token. Use 'createTemplateLiteralLikeNode' to create template literals."); Debug.assert(token <= 9 /* FirstLiteralToken */ || token >= 15 /* LastLiteralToken */, "Invalid token. Use 'createLiteralLikeNode' to create literals."); Debug.assert(token !== 80 /* Identifier */, "Invalid token. Use 'createIdentifier' to create identifiers"); @@ -119916,6 +102738,9 @@ ${lanes.join("\n")} case 134 /* AsyncKeyword */: transformFlags = 256 /* ContainsES2017 */ | 128 /* ContainsES2018 */; break; + case 160 /* UsingKeyword */: + transformFlags = 4 /* ContainsESNext */; + break; case 125 /* PublicKeyword */: case 123 /* PrivateKeyword */: case 124 /* ProtectedKeyword */: @@ -119925,12 +102750,12 @@ ${lanes.join("\n")} case 87 /* ConstKeyword */: case 133 /* AnyKeyword */: case 150 /* NumberKeyword */: - case 162 /* BigIntKeyword */: + case 163 /* BigIntKeyword */: case 146 /* NeverKeyword */: case 151 /* ObjectKeyword */: case 103 /* InKeyword */: case 147 /* OutKeyword */: - case 163 /* OverrideKeyword */: + case 164 /* OverrideKeyword */: case 154 /* StringKeyword */: case 136 /* BooleanKeyword */: case 155 /* SymbolKeyword */: @@ -119979,40 +102804,40 @@ ${lanes.join("\n")} } function createModifiersFromModifierFlags(flags2) { const result = []; - if (flags2 & 1 /* Export */) + if (flags2 & 32 /* Export */) result.push(createModifier(95 /* ExportKeyword */)); - if (flags2 & 2 /* Ambient */) + if (flags2 & 128 /* Ambient */) result.push(createModifier(138 /* DeclareKeyword */)); - if (flags2 & 1024 /* Default */) + if (flags2 & 2048 /* Default */) result.push(createModifier(90 /* DefaultKeyword */)); - if (flags2 & 2048 /* Const */) + if (flags2 & 4096 /* Const */) result.push(createModifier(87 /* ConstKeyword */)); - if (flags2 & 4 /* Public */) + if (flags2 & 1 /* Public */) result.push(createModifier(125 /* PublicKeyword */)); - if (flags2 & 8 /* Private */) + if (flags2 & 2 /* Private */) result.push(createModifier(123 /* PrivateKeyword */)); - if (flags2 & 16 /* Protected */) + if (flags2 & 4 /* Protected */) result.push(createModifier(124 /* ProtectedKeyword */)); - if (flags2 & 256 /* Abstract */) + if (flags2 & 64 /* Abstract */) result.push(createModifier(128 /* AbstractKeyword */)); - if (flags2 & 32 /* Static */) + if (flags2 & 256 /* Static */) result.push(createModifier(126 /* StaticKeyword */)); - if (flags2 & 16384 /* Override */) - result.push(createModifier(163 /* OverrideKeyword */)); - if (flags2 & 64 /* Readonly */) + if (flags2 & 16 /* Override */) + result.push(createModifier(164 /* OverrideKeyword */)); + if (flags2 & 8 /* Readonly */) result.push(createModifier(148 /* ReadonlyKeyword */)); - if (flags2 & 128 /* Accessor */) + if (flags2 & 512 /* Accessor */) result.push(createModifier(129 /* AccessorKeyword */)); - if (flags2 & 512 /* Async */) + if (flags2 & 1024 /* Async */) result.push(createModifier(134 /* AsyncKeyword */)); - if (flags2 & 32768 /* In */) + if (flags2 & 8192 /* In */) result.push(createModifier(103 /* InKeyword */)); - if (flags2 & 65536 /* Out */) + if (flags2 & 16384 /* Out */) result.push(createModifier(147 /* OutKeyword */)); return result.length ? result : void 0; } function createQualifiedName(left, right) { - const node = createBaseNode(165 /* QualifiedName */); + const node = createBaseNode(166 /* QualifiedName */); node.left = left; node.right = asName(right); node.transformFlags |= propagateChildFlags(node.left) | propagateIdentifierNameFlags(node.right); @@ -120023,7 +102848,7 @@ ${lanes.join("\n")} return node.left !== left || node.right !== right ? update(createQualifiedName(left, right), node) : node; } function createComputedPropertyName(expression) { - const node = createBaseNode(166 /* ComputedPropertyName */); + const node = createBaseNode(167 /* ComputedPropertyName */); node.expression = parenthesizerRules().parenthesizeExpressionOfComputedPropertyName(expression); node.transformFlags |= propagateChildFlags(node.expression) | 1024 /* ContainsES2015 */ | 131072 /* ContainsComputedPropertyName */; return node; @@ -120032,7 +102857,7 @@ ${lanes.join("\n")} return node.expression !== expression ? update(createComputedPropertyName(expression), node) : node; } function createTypeParameterDeclaration(modifiers, name, constraint, defaultType) { - const node = createBaseDeclaration(167 /* TypeParameter */); + const node = createBaseDeclaration(168 /* TypeParameter */); node.modifiers = asNodeArray(modifiers); node.name = asName(name); node.constraint = constraint; @@ -120046,7 +102871,7 @@ ${lanes.join("\n")} return node.modifiers !== modifiers || node.name !== name || node.constraint !== constraint || node.default !== defaultType ? update(createTypeParameterDeclaration(modifiers, name, constraint, defaultType), node) : node; } function createParameterDeclaration(modifiers, dotDotDotToken, name, questionToken, type, initializer) { - const node = createBaseDeclaration(168 /* Parameter */); + const node = createBaseDeclaration(169 /* Parameter */); node.modifiers = asNodeArray(modifiers); node.dotDotDotToken = dotDotDotToken; node.name = asName(name); @@ -120056,7 +102881,7 @@ ${lanes.join("\n")} if (isThisIdentifier(node.name)) { node.transformFlags = 1 /* ContainsTypeScript */; } else { - node.transformFlags = propagateChildrenFlags(node.modifiers) | propagateChildFlags(node.dotDotDotToken) | propagateNameFlags(node.name) | propagateChildFlags(node.questionToken) | propagateChildFlags(node.initializer) | (node.questionToken ?? node.type ? 1 /* ContainsTypeScript */ : 0 /* None */) | (node.dotDotDotToken ?? node.initializer ? 1024 /* ContainsES2015 */ : 0 /* None */) | (modifiersToFlags(node.modifiers) & 16476 /* ParameterPropertyModifier */ ? 8192 /* ContainsTypeScriptClassSyntax */ : 0 /* None */); + node.transformFlags = propagateChildrenFlags(node.modifiers) | propagateChildFlags(node.dotDotDotToken) | propagateNameFlags(node.name) | propagateChildFlags(node.questionToken) | propagateChildFlags(node.initializer) | (node.questionToken ?? node.type ? 1 /* ContainsTypeScript */ : 0 /* None */) | (node.dotDotDotToken ?? node.initializer ? 1024 /* ContainsES2015 */ : 0 /* None */) | (modifiersToFlags(node.modifiers) & 31 /* ParameterPropertyModifier */ ? 8192 /* ContainsTypeScriptClassSyntax */ : 0 /* None */); } node.jsDoc = void 0; return node; @@ -120065,7 +102890,7 @@ ${lanes.join("\n")} return node.modifiers !== modifiers || node.dotDotDotToken !== dotDotDotToken || node.name !== name || node.questionToken !== questionToken || node.type !== type || node.initializer !== initializer ? update(createParameterDeclaration(modifiers, dotDotDotToken, name, questionToken, type, initializer), node) : node; } function createDecorator(expression) { - const node = createBaseNode(169 /* Decorator */); + const node = createBaseNode(170 /* Decorator */); node.expression = parenthesizerRules().parenthesizeLeftSideOfAccess( expression, /*optionalChain*/ @@ -120078,7 +102903,7 @@ ${lanes.join("\n")} return node.expression !== expression ? update(createDecorator(expression), node) : node; } function createPropertySignature(modifiers, name, questionToken, type) { - const node = createBaseDeclaration(170 /* PropertySignature */); + const node = createBaseDeclaration(171 /* PropertySignature */); node.modifiers = asNodeArray(modifiers); node.name = asName(name); node.type = type; @@ -120098,15 +102923,15 @@ ${lanes.join("\n")} return update(updated, original); } function createPropertyDeclaration(modifiers, name, questionOrExclamationToken, type, initializer) { - const node = createBaseDeclaration(171 /* PropertyDeclaration */); + const node = createBaseDeclaration(172 /* PropertyDeclaration */); node.modifiers = asNodeArray(modifiers); node.name = asName(name); node.questionToken = questionOrExclamationToken && isQuestionToken(questionOrExclamationToken) ? questionOrExclamationToken : void 0; node.exclamationToken = questionOrExclamationToken && isExclamationToken(questionOrExclamationToken) ? questionOrExclamationToken : void 0; node.type = type; node.initializer = asInitializer(initializer); - const isAmbient = node.flags & 16777216 /* Ambient */ || modifiersToFlags(node.modifiers) & 2 /* Ambient */; - node.transformFlags = propagateChildrenFlags(node.modifiers) | propagateNameFlags(node.name) | propagateChildFlags(node.initializer) | (isAmbient || node.questionToken || node.exclamationToken || node.type ? 1 /* ContainsTypeScript */ : 0 /* None */) | (isComputedPropertyName(node.name) || modifiersToFlags(node.modifiers) & 32 /* Static */ && node.initializer ? 8192 /* ContainsTypeScriptClassSyntax */ : 0 /* None */) | 16777216 /* ContainsClassFields */; + const isAmbient = node.flags & 33554432 /* Ambient */ || modifiersToFlags(node.modifiers) & 128 /* Ambient */; + node.transformFlags = propagateChildrenFlags(node.modifiers) | propagateNameFlags(node.name) | propagateChildFlags(node.initializer) | (isAmbient || node.questionToken || node.exclamationToken || node.type ? 1 /* ContainsTypeScript */ : 0 /* None */) | (isComputedPropertyName(node.name) || modifiersToFlags(node.modifiers) & 256 /* Static */ && node.initializer ? 8192 /* ContainsTypeScriptClassSyntax */ : 0 /* None */) | 16777216 /* ContainsClassFields */; node.jsDoc = void 0; return node; } @@ -120114,7 +102939,7 @@ ${lanes.join("\n")} return node.modifiers !== modifiers || node.name !== name || node.questionToken !== (questionOrExclamationToken !== void 0 && isQuestionToken(questionOrExclamationToken) ? questionOrExclamationToken : void 0) || node.exclamationToken !== (questionOrExclamationToken !== void 0 && isExclamationToken(questionOrExclamationToken) ? questionOrExclamationToken : void 0) || node.type !== type || node.initializer !== initializer ? update(createPropertyDeclaration(modifiers, name, questionOrExclamationToken, type, initializer), node) : node; } function createMethodSignature(modifiers, name, questionToken, typeParameters, parameters, type) { - const node = createBaseDeclaration(172 /* MethodSignature */); + const node = createBaseDeclaration(173 /* MethodSignature */); node.modifiers = asNodeArray(modifiers); node.name = asName(name); node.questionToken = questionToken; @@ -120132,7 +102957,7 @@ ${lanes.join("\n")} return node.modifiers !== modifiers || node.name !== name || node.questionToken !== questionToken || node.typeParameters !== typeParameters || node.parameters !== parameters || node.type !== type ? finishUpdateBaseSignatureDeclaration(createMethodSignature(modifiers, name, questionToken, typeParameters, parameters, type), node) : node; } function createMethodDeclaration(modifiers, asteriskToken, name, questionToken, typeParameters, parameters, type, body) { - const node = createBaseDeclaration(173 /* MethodDeclaration */); + const node = createBaseDeclaration(174 /* MethodDeclaration */); node.modifiers = asNodeArray(modifiers); node.asteriskToken = asteriskToken; node.name = asName(name); @@ -120145,7 +102970,7 @@ ${lanes.join("\n")} if (!node.body) { node.transformFlags = 1 /* ContainsTypeScript */; } else { - const isAsync = modifiersToFlags(node.modifiers) & 512 /* Async */; + const isAsync = modifiersToFlags(node.modifiers) & 1024 /* Async */; const isGenerator = !!node.asteriskToken; const isAsyncGenerator = isAsync && isGenerator; node.transformFlags = propagateChildrenFlags(node.modifiers) | propagateChildFlags(node.asteriskToken) | propagateNameFlags(node.name) | propagateChildFlags(node.questionToken) | propagateChildrenFlags(node.typeParameters) | propagateChildrenFlags(node.parameters) | propagateChildFlags(node.type) | propagateChildFlags(node.body) & ~67108864 /* ContainsPossibleTopLevelAwait */ | (isAsyncGenerator ? 128 /* ContainsES2018 */ : isAsync ? 256 /* ContainsES2017 */ : isGenerator ? 2048 /* ContainsGenerator */ : 0 /* None */) | (node.questionToken || node.typeParameters || node.type ? 1 /* ContainsTypeScript */ : 0 /* None */) | 1024 /* ContainsES2015 */; @@ -120169,7 +102994,7 @@ ${lanes.join("\n")} return update(updated, original); } function createClassStaticBlockDeclaration(body) { - const node = createBaseDeclaration(174 /* ClassStaticBlockDeclaration */); + const node = createBaseDeclaration(175 /* ClassStaticBlockDeclaration */); node.body = body; node.transformFlags = propagateChildFlags(body) | 16777216 /* ContainsClassFields */; node.modifiers = void 0; @@ -120190,7 +103015,7 @@ ${lanes.join("\n")} return update(updated, original); } function createConstructorDeclaration(modifiers, parameters, body) { - const node = createBaseDeclaration(175 /* Constructor */); + const node = createBaseDeclaration(176 /* Constructor */); node.modifiers = asNodeArray(modifiers); node.parameters = createNodeArray(parameters); node.body = body; @@ -120216,7 +103041,7 @@ ${lanes.join("\n")} return finishUpdateBaseSignatureDeclaration(updated, original); } function createGetAccessorDeclaration(modifiers, name, parameters, type, body) { - const node = createBaseDeclaration(176 /* GetAccessor */); + const node = createBaseDeclaration(177 /* GetAccessor */); node.modifiers = asNodeArray(modifiers); node.name = asName(name); node.parameters = createNodeArray(parameters); @@ -120247,7 +103072,7 @@ ${lanes.join("\n")} return finishUpdateBaseSignatureDeclaration(updated, original); } function createSetAccessorDeclaration(modifiers, name, parameters, body) { - const node = createBaseDeclaration(177 /* SetAccessor */); + const node = createBaseDeclaration(178 /* SetAccessor */); node.modifiers = asNodeArray(modifiers); node.name = asName(name); node.parameters = createNodeArray(parameters); @@ -120279,7 +103104,7 @@ ${lanes.join("\n")} return finishUpdateBaseSignatureDeclaration(updated, original); } function createCallSignature(typeParameters, parameters, type) { - const node = createBaseDeclaration(178 /* CallSignature */); + const node = createBaseDeclaration(179 /* CallSignature */); node.typeParameters = asNodeArray(typeParameters); node.parameters = asNodeArray(parameters); node.type = type; @@ -120294,7 +103119,7 @@ ${lanes.join("\n")} return node.typeParameters !== typeParameters || node.parameters !== parameters || node.type !== type ? finishUpdateBaseSignatureDeclaration(createCallSignature(typeParameters, parameters, type), node) : node; } function createConstructSignature(typeParameters, parameters, type) { - const node = createBaseDeclaration(179 /* ConstructSignature */); + const node = createBaseDeclaration(180 /* ConstructSignature */); node.typeParameters = asNodeArray(typeParameters); node.parameters = asNodeArray(parameters); node.type = type; @@ -120309,7 +103134,7 @@ ${lanes.join("\n")} return node.typeParameters !== typeParameters || node.parameters !== parameters || node.type !== type ? finishUpdateBaseSignatureDeclaration(createConstructSignature(typeParameters, parameters, type), node) : node; } function createIndexSignature(modifiers, parameters, type) { - const node = createBaseDeclaration(180 /* IndexSignature */); + const node = createBaseDeclaration(181 /* IndexSignature */); node.modifiers = asNodeArray(modifiers); node.parameters = asNodeArray(parameters); node.type = type; @@ -120324,7 +103149,7 @@ ${lanes.join("\n")} return node.parameters !== parameters || node.type !== type || node.modifiers !== modifiers ? finishUpdateBaseSignatureDeclaration(createIndexSignature(modifiers, parameters, type), node) : node; } function createTemplateLiteralTypeSpan(type, literal) { - const node = createBaseNode(203 /* TemplateLiteralTypeSpan */); + const node = createBaseNode(204 /* TemplateLiteralTypeSpan */); node.type = type; node.literal = literal; node.transformFlags = 1 /* ContainsTypeScript */; @@ -120337,7 +103162,7 @@ ${lanes.join("\n")} return createToken(kind); } function createTypePredicateNode(assertsModifier, parameterName, type) { - const node = createBaseNode(181 /* TypePredicate */); + const node = createBaseNode(182 /* TypePredicate */); node.assertsModifier = assertsModifier; node.parameterName = asName(parameterName); node.type = type; @@ -120348,7 +103173,7 @@ ${lanes.join("\n")} return node.assertsModifier !== assertsModifier || node.parameterName !== parameterName || node.type !== type ? update(createTypePredicateNode(assertsModifier, parameterName, type), node) : node; } function createTypeReferenceNode(typeName, typeArguments) { - const node = createBaseNode(182 /* TypeReference */); + const node = createBaseNode(183 /* TypeReference */); node.typeName = asName(typeName); node.typeArguments = typeArguments && parenthesizerRules().parenthesizeTypeArguments(createNodeArray(typeArguments)); node.transformFlags = 1 /* ContainsTypeScript */; @@ -120358,7 +103183,7 @@ ${lanes.join("\n")} return node.typeName !== typeName || node.typeArguments !== typeArguments ? update(createTypeReferenceNode(typeName, typeArguments), node) : node; } function createFunctionTypeNode(typeParameters, parameters, type) { - const node = createBaseDeclaration(183 /* FunctionType */); + const node = createBaseDeclaration(184 /* FunctionType */); node.typeParameters = asNodeArray(typeParameters); node.parameters = asNodeArray(parameters); node.type = type; @@ -120383,7 +103208,7 @@ ${lanes.join("\n")} return args.length === 4 ? createConstructorTypeNode1(...args) : args.length === 3 ? createConstructorTypeNode2(...args) : Debug.fail("Incorrect number of arguments specified."); } function createConstructorTypeNode1(modifiers, typeParameters, parameters, type) { - const node = createBaseDeclaration(184 /* ConstructorType */); + const node = createBaseDeclaration(185 /* ConstructorType */); node.modifiers = asNodeArray(modifiers); node.typeParameters = asNodeArray(typeParameters); node.parameters = asNodeArray(parameters); @@ -120414,7 +103239,7 @@ ${lanes.join("\n")} return updateConstructorTypeNode1(node, node.modifiers, typeParameters, parameters, type); } function createTypeQueryNode(exprName, typeArguments) { - const node = createBaseNode(185 /* TypeQuery */); + const node = createBaseNode(186 /* TypeQuery */); node.exprName = exprName; node.typeArguments = typeArguments && parenthesizerRules().parenthesizeTypeArguments(typeArguments); node.transformFlags = 1 /* ContainsTypeScript */; @@ -120424,7 +103249,7 @@ ${lanes.join("\n")} return node.exprName !== exprName || node.typeArguments !== typeArguments ? update(createTypeQueryNode(exprName, typeArguments), node) : node; } function createTypeLiteralNode(members) { - const node = createBaseDeclaration(186 /* TypeLiteral */); + const node = createBaseDeclaration(187 /* TypeLiteral */); node.members = createNodeArray(members); node.transformFlags = 1 /* ContainsTypeScript */; return node; @@ -120433,7 +103258,7 @@ ${lanes.join("\n")} return node.members !== members ? update(createTypeLiteralNode(members), node) : node; } function createArrayTypeNode(elementType) { - const node = createBaseNode(187 /* ArrayType */); + const node = createBaseNode(188 /* ArrayType */); node.elementType = parenthesizerRules().parenthesizeNonArrayTypeOfPostfixType(elementType); node.transformFlags = 1 /* ContainsTypeScript */; return node; @@ -120442,7 +103267,7 @@ ${lanes.join("\n")} return node.elementType !== elementType ? update(createArrayTypeNode(elementType), node) : node; } function createTupleTypeNode(elements) { - const node = createBaseNode(188 /* TupleType */); + const node = createBaseNode(189 /* TupleType */); node.elements = createNodeArray(parenthesizerRules().parenthesizeElementTypesOfTupleType(elements)); node.transformFlags = 1 /* ContainsTypeScript */; return node; @@ -120451,7 +103276,7 @@ ${lanes.join("\n")} return node.elements !== elements ? update(createTupleTypeNode(elements), node) : node; } function createNamedTupleMember(dotDotDotToken, name, questionToken, type) { - const node = createBaseDeclaration(201 /* NamedTupleMember */); + const node = createBaseDeclaration(202 /* NamedTupleMember */); node.dotDotDotToken = dotDotDotToken; node.name = name; node.questionToken = questionToken; @@ -120464,7 +103289,7 @@ ${lanes.join("\n")} return node.dotDotDotToken !== dotDotDotToken || node.name !== name || node.questionToken !== questionToken || node.type !== type ? update(createNamedTupleMember(dotDotDotToken, name, questionToken, type), node) : node; } function createOptionalTypeNode(type) { - const node = createBaseNode(189 /* OptionalType */); + const node = createBaseNode(190 /* OptionalType */); node.type = parenthesizerRules().parenthesizeTypeOfOptionalType(type); node.transformFlags = 1 /* ContainsTypeScript */; return node; @@ -120473,7 +103298,7 @@ ${lanes.join("\n")} return node.type !== type ? update(createOptionalTypeNode(type), node) : node; } function createRestTypeNode(type) { - const node = createBaseNode(190 /* RestType */); + const node = createBaseNode(191 /* RestType */); node.type = type; node.transformFlags = 1 /* ContainsTypeScript */; return node; @@ -120491,19 +103316,19 @@ ${lanes.join("\n")} return node.types !== types ? update(createUnionOrIntersectionTypeNode(node.kind, types, parenthesize), node) : node; } function createUnionTypeNode(types) { - return createUnionOrIntersectionTypeNode(191 /* UnionType */, types, parenthesizerRules().parenthesizeConstituentTypesOfUnionType); + return createUnionOrIntersectionTypeNode(192 /* UnionType */, types, parenthesizerRules().parenthesizeConstituentTypesOfUnionType); } function updateUnionTypeNode(node, types) { return updateUnionOrIntersectionTypeNode(node, types, parenthesizerRules().parenthesizeConstituentTypesOfUnionType); } function createIntersectionTypeNode(types) { - return createUnionOrIntersectionTypeNode(192 /* IntersectionType */, types, parenthesizerRules().parenthesizeConstituentTypesOfIntersectionType); + return createUnionOrIntersectionTypeNode(193 /* IntersectionType */, types, parenthesizerRules().parenthesizeConstituentTypesOfIntersectionType); } function updateIntersectionTypeNode(node, types) { return updateUnionOrIntersectionTypeNode(node, types, parenthesizerRules().parenthesizeConstituentTypesOfIntersectionType); } function createConditionalTypeNode(checkType, extendsType, trueType, falseType) { - const node = createBaseNode(193 /* ConditionalType */); + const node = createBaseNode(194 /* ConditionalType */); node.checkType = parenthesizerRules().parenthesizeCheckTypeOfConditionalType(checkType); node.extendsType = parenthesizerRules().parenthesizeExtendsTypeOfConditionalType(extendsType); node.trueType = trueType; @@ -120517,7 +103342,7 @@ ${lanes.join("\n")} return node.checkType !== checkType || node.extendsType !== extendsType || node.trueType !== trueType || node.falseType !== falseType ? update(createConditionalTypeNode(checkType, extendsType, trueType, falseType), node) : node; } function createInferTypeNode(typeParameter) { - const node = createBaseNode(194 /* InferType */); + const node = createBaseNode(195 /* InferType */); node.typeParameter = typeParameter; node.transformFlags = 1 /* ContainsTypeScript */; return node; @@ -120526,7 +103351,7 @@ ${lanes.join("\n")} return node.typeParameter !== typeParameter ? update(createInferTypeNode(typeParameter), node) : node; } function createTemplateLiteralType(head, templateSpans) { - const node = createBaseNode(202 /* TemplateLiteralType */); + const node = createBaseNode(203 /* TemplateLiteralType */); node.head = head; node.templateSpans = createNodeArray(templateSpans); node.transformFlags = 1 /* ContainsTypeScript */; @@ -120535,21 +103360,24 @@ ${lanes.join("\n")} function updateTemplateLiteralType(node, head, templateSpans) { return node.head !== head || node.templateSpans !== templateSpans ? update(createTemplateLiteralType(head, templateSpans), node) : node; } - function createImportTypeNode(argument, assertions, qualifier, typeArguments, isTypeOf = false) { - const node = createBaseNode(204 /* ImportType */); + function createImportTypeNode(argument, attributes, qualifier, typeArguments, isTypeOf = false) { + const node = createBaseNode(205 /* ImportType */); node.argument = argument; - node.assertions = assertions; + node.attributes = attributes; + if (node.assertions && node.assertions.assertClause && node.attributes) { + node.assertions.assertClause = node.attributes; + } node.qualifier = qualifier; node.typeArguments = typeArguments && parenthesizerRules().parenthesizeTypeArguments(typeArguments); node.isTypeOf = isTypeOf; node.transformFlags = 1 /* ContainsTypeScript */; return node; } - function updateImportTypeNode(node, argument, assertions, qualifier, typeArguments, isTypeOf = node.isTypeOf) { - return node.argument !== argument || node.assertions !== assertions || node.qualifier !== qualifier || node.typeArguments !== typeArguments || node.isTypeOf !== isTypeOf ? update(createImportTypeNode(argument, assertions, qualifier, typeArguments, isTypeOf), node) : node; + function updateImportTypeNode(node, argument, attributes, qualifier, typeArguments, isTypeOf = node.isTypeOf) { + return node.argument !== argument || node.attributes !== attributes || node.qualifier !== qualifier || node.typeArguments !== typeArguments || node.isTypeOf !== isTypeOf ? update(createImportTypeNode(argument, attributes, qualifier, typeArguments, isTypeOf), node) : node; } function createParenthesizedType(type) { - const node = createBaseNode(195 /* ParenthesizedType */); + const node = createBaseNode(196 /* ParenthesizedType */); node.type = type; node.transformFlags = 1 /* ContainsTypeScript */; return node; @@ -120558,12 +103386,12 @@ ${lanes.join("\n")} return node.type !== type ? update(createParenthesizedType(type), node) : node; } function createThisTypeNode() { - const node = createBaseNode(196 /* ThisType */); + const node = createBaseNode(197 /* ThisType */); node.transformFlags = 1 /* ContainsTypeScript */; return node; } function createTypeOperatorNode(operator, type) { - const node = createBaseNode(197 /* TypeOperator */); + const node = createBaseNode(198 /* TypeOperator */); node.operator = operator; node.type = operator === 148 /* ReadonlyKeyword */ ? parenthesizerRules().parenthesizeOperandOfReadonlyTypeOperator(type) : parenthesizerRules().parenthesizeOperandOfTypeOperator(type); node.transformFlags = 1 /* ContainsTypeScript */; @@ -120573,7 +103401,7 @@ ${lanes.join("\n")} return node.type !== type ? update(createTypeOperatorNode(node.operator, type), node) : node; } function createIndexedAccessTypeNode(objectType, indexType) { - const node = createBaseNode(198 /* IndexedAccessType */); + const node = createBaseNode(199 /* IndexedAccessType */); node.objectType = parenthesizerRules().parenthesizeNonArrayTypeOfPostfixType(objectType); node.indexType = indexType; node.transformFlags = 1 /* ContainsTypeScript */; @@ -120583,7 +103411,7 @@ ${lanes.join("\n")} return node.objectType !== objectType || node.indexType !== indexType ? update(createIndexedAccessTypeNode(objectType, indexType), node) : node; } function createMappedTypeNode(readonlyToken, typeParameter, nameType, questionToken, type, members) { - const node = createBaseDeclaration(199 /* MappedType */); + const node = createBaseDeclaration(200 /* MappedType */); node.readonlyToken = readonlyToken; node.typeParameter = typeParameter; node.nameType = nameType; @@ -120599,7 +103427,7 @@ ${lanes.join("\n")} return node.readonlyToken !== readonlyToken || node.typeParameter !== typeParameter || node.nameType !== nameType || node.questionToken !== questionToken || node.type !== type || node.members !== members ? update(createMappedTypeNode(readonlyToken, typeParameter, nameType, questionToken, type, members), node) : node; } function createLiteralTypeNode(literal) { - const node = createBaseNode(200 /* LiteralType */); + const node = createBaseNode(201 /* LiteralType */); node.literal = literal; node.transformFlags = 1 /* ContainsTypeScript */; return node; @@ -120608,7 +103436,7 @@ ${lanes.join("\n")} return node.literal !== literal ? update(createLiteralTypeNode(literal), node) : node; } function createObjectBindingPattern(elements) { - const node = createBaseNode(205 /* ObjectBindingPattern */); + const node = createBaseNode(206 /* ObjectBindingPattern */); node.elements = createNodeArray(elements); node.transformFlags |= propagateChildrenFlags(node.elements) | 1024 /* ContainsES2015 */ | 524288 /* ContainsBindingPattern */; if (node.transformFlags & 32768 /* ContainsRestOrSpread */) { @@ -120620,7 +103448,7 @@ ${lanes.join("\n")} return node.elements !== elements ? update(createObjectBindingPattern(elements), node) : node; } function createArrayBindingPattern(elements) { - const node = createBaseNode(206 /* ArrayBindingPattern */); + const node = createBaseNode(207 /* ArrayBindingPattern */); node.elements = createNodeArray(elements); node.transformFlags |= propagateChildrenFlags(node.elements) | 1024 /* ContainsES2015 */ | 524288 /* ContainsBindingPattern */; return node; @@ -120629,7 +103457,7 @@ ${lanes.join("\n")} return node.elements !== elements ? update(createArrayBindingPattern(elements), node) : node; } function createBindingElement(dotDotDotToken, propertyName, name, initializer) { - const node = createBaseDeclaration(207 /* BindingElement */); + const node = createBaseDeclaration(208 /* BindingElement */); node.dotDotDotToken = dotDotDotToken; node.propertyName = asName(propertyName); node.name = asName(name); @@ -120642,7 +103470,7 @@ ${lanes.join("\n")} return node.propertyName !== propertyName || node.dotDotDotToken !== dotDotDotToken || node.name !== name || node.initializer !== initializer ? update(createBindingElement(dotDotDotToken, propertyName, name, initializer), node) : node; } function createArrayLiteralExpression(elements, multiLine) { - const node = createBaseNode(208 /* ArrayLiteralExpression */); + const node = createBaseNode(209 /* ArrayLiteralExpression */); const lastElement = elements && lastOrUndefined(elements); const elementsArray = createNodeArray(elements, lastElement && isOmittedExpression(lastElement) ? true : void 0); node.elements = parenthesizerRules().parenthesizeExpressionsOfCommaDelimitedList(elementsArray); @@ -120654,7 +103482,7 @@ ${lanes.join("\n")} return node.elements !== elements ? update(createArrayLiteralExpression(elements, node.multiLine), node) : node; } function createObjectLiteralExpression(properties, multiLine) { - const node = createBaseDeclaration(209 /* ObjectLiteralExpression */); + const node = createBaseDeclaration(210 /* ObjectLiteralExpression */); node.properties = createNodeArray(properties); node.multiLine = multiLine; node.transformFlags |= propagateChildrenFlags(node.properties); @@ -120665,7 +103493,7 @@ ${lanes.join("\n")} return node.properties !== properties ? update(createObjectLiteralExpression(properties, node.multiLine), node) : node; } function createBasePropertyAccessExpression(expression, questionDotToken, name) { - const node = createBaseDeclaration(210 /* PropertyAccessExpression */); + const node = createBaseDeclaration(211 /* PropertyAccessExpression */); node.expression = expression; node.questionDotToken = questionDotToken; node.name = name; @@ -120706,16 +103534,16 @@ ${lanes.join("\n")} questionDotToken, asName(name) ); - node.flags |= 32 /* OptionalChain */; + node.flags |= 64 /* OptionalChain */; node.transformFlags |= 32 /* ContainsES2020 */; return node; } function updatePropertyAccessChain(node, expression, questionDotToken, name) { - Debug.assert(!!(node.flags & 32 /* OptionalChain */), "Cannot update a PropertyAccessExpression using updatePropertyAccessChain. Use updatePropertyAccess instead."); + Debug.assert(!!(node.flags & 64 /* OptionalChain */), "Cannot update a PropertyAccessExpression using updatePropertyAccessChain. Use updatePropertyAccess instead."); return node.expression !== expression || node.questionDotToken !== questionDotToken || node.name !== name ? update(createPropertyAccessChain(expression, questionDotToken, name), node) : node; } function createBaseElementAccessExpression(expression, questionDotToken, argumentExpression) { - const node = createBaseDeclaration(211 /* ElementAccessExpression */); + const node = createBaseDeclaration(212 /* ElementAccessExpression */); node.expression = expression; node.questionDotToken = questionDotToken; node.argumentExpression = argumentExpression; @@ -120756,16 +103584,16 @@ ${lanes.join("\n")} questionDotToken, asExpression(index) ); - node.flags |= 32 /* OptionalChain */; + node.flags |= 64 /* OptionalChain */; node.transformFlags |= 32 /* ContainsES2020 */; return node; } function updateElementAccessChain(node, expression, questionDotToken, argumentExpression) { - Debug.assert(!!(node.flags & 32 /* OptionalChain */), "Cannot update a ElementAccessExpression using updateElementAccessChain. Use updateElementAccess instead."); + Debug.assert(!!(node.flags & 64 /* OptionalChain */), "Cannot update a ElementAccessExpression using updateElementAccessChain. Use updateElementAccess instead."); return node.expression !== expression || node.questionDotToken !== questionDotToken || node.argumentExpression !== argumentExpression ? update(createElementAccessChain(expression, questionDotToken, argumentExpression), node) : node; } function createBaseCallExpression(expression, questionDotToken, typeArguments, argumentsArray) { - const node = createBaseDeclaration(212 /* CallExpression */); + const node = createBaseDeclaration(213 /* CallExpression */); node.expression = expression; node.questionDotToken = questionDotToken; node.typeArguments = typeArguments; @@ -120813,16 +103641,16 @@ ${lanes.join("\n")} asNodeArray(typeArguments), parenthesizerRules().parenthesizeExpressionsOfCommaDelimitedList(createNodeArray(argumentsArray)) ); - node.flags |= 32 /* OptionalChain */; + node.flags |= 64 /* OptionalChain */; node.transformFlags |= 32 /* ContainsES2020 */; return node; } function updateCallChain(node, expression, questionDotToken, typeArguments, argumentsArray) { - Debug.assert(!!(node.flags & 32 /* OptionalChain */), "Cannot update a CallExpression using updateCallChain. Use updateCall instead."); + Debug.assert(!!(node.flags & 64 /* OptionalChain */), "Cannot update a CallExpression using updateCallChain. Use updateCall instead."); return node.expression !== expression || node.questionDotToken !== questionDotToken || node.typeArguments !== typeArguments || node.arguments !== argumentsArray ? update(createCallChain(expression, questionDotToken, typeArguments, argumentsArray), node) : node; } function createNewExpression(expression, typeArguments, argumentsArray) { - const node = createBaseDeclaration(213 /* NewExpression */); + const node = createBaseDeclaration(214 /* NewExpression */); node.expression = parenthesizerRules().parenthesizeExpressionOfNew(expression); node.typeArguments = asNodeArray(typeArguments); node.arguments = argumentsArray ? parenthesizerRules().parenthesizeExpressionsOfCommaDelimitedList(argumentsArray) : void 0; @@ -120836,7 +103664,7 @@ ${lanes.join("\n")} return node.expression !== expression || node.typeArguments !== typeArguments || node.arguments !== argumentsArray ? update(createNewExpression(expression, typeArguments, argumentsArray), node) : node; } function createTaggedTemplateExpression(tag, typeArguments, template) { - const node = createBaseNode(214 /* TaggedTemplateExpression */); + const node = createBaseNode(215 /* TaggedTemplateExpression */); node.tag = parenthesizerRules().parenthesizeLeftSideOfAccess( tag, /*optionalChain*/ @@ -120857,7 +103685,7 @@ ${lanes.join("\n")} return node.tag !== tag || node.typeArguments !== typeArguments || node.template !== template ? update(createTaggedTemplateExpression(tag, typeArguments, template), node) : node; } function createTypeAssertion(type, expression) { - const node = createBaseNode(215 /* TypeAssertionExpression */); + const node = createBaseNode(216 /* TypeAssertionExpression */); node.expression = parenthesizerRules().parenthesizeOperandOfPrefixUnary(expression); node.type = type; node.transformFlags |= propagateChildFlags(node.expression) | propagateChildFlags(node.type) | 1 /* ContainsTypeScript */; @@ -120867,7 +103695,7 @@ ${lanes.join("\n")} return node.type !== type || node.expression !== expression ? update(createTypeAssertion(type, expression), node) : node; } function createParenthesizedExpression(expression) { - const node = createBaseNode(216 /* ParenthesizedExpression */); + const node = createBaseNode(217 /* ParenthesizedExpression */); node.expression = expression; node.transformFlags = propagateChildFlags(node.expression); node.jsDoc = void 0; @@ -120877,7 +103705,7 @@ ${lanes.join("\n")} return node.expression !== expression ? update(createParenthesizedExpression(expression), node) : node; } function createFunctionExpression(modifiers, asteriskToken, name, typeParameters, parameters, type, body) { - const node = createBaseDeclaration(217 /* FunctionExpression */); + const node = createBaseDeclaration(218 /* FunctionExpression */); node.modifiers = asNodeArray(modifiers); node.asteriskToken = asteriskToken; node.name = asName(name); @@ -120885,7 +103713,7 @@ ${lanes.join("\n")} node.parameters = createNodeArray(parameters); node.type = type; node.body = body; - const isAsync = modifiersToFlags(node.modifiers) & 512 /* Async */; + const isAsync = modifiersToFlags(node.modifiers) & 1024 /* Async */; const isGenerator = !!node.asteriskToken; const isAsyncGenerator = isAsync && isGenerator; node.transformFlags = propagateChildrenFlags(node.modifiers) | propagateChildFlags(node.asteriskToken) | propagateNameFlags(node.name) | propagateChildrenFlags(node.typeParameters) | propagateChildrenFlags(node.parameters) | propagateChildFlags(node.type) | propagateChildFlags(node.body) & ~67108864 /* ContainsPossibleTopLevelAwait */ | (isAsyncGenerator ? 128 /* ContainsES2018 */ : isAsync ? 256 /* ContainsES2017 */ : isGenerator ? 2048 /* ContainsGenerator */ : 0 /* None */) | (node.typeParameters || node.type ? 1 /* ContainsTypeScript */ : 0 /* None */) | 4194304 /* ContainsHoistedDeclarationOrCompletion */; @@ -120902,14 +103730,14 @@ ${lanes.join("\n")} return node.name !== name || node.modifiers !== modifiers || node.asteriskToken !== asteriskToken || node.typeParameters !== typeParameters || node.parameters !== parameters || node.type !== type || node.body !== body ? finishUpdateBaseSignatureDeclaration(createFunctionExpression(modifiers, asteriskToken, name, typeParameters, parameters, type, body), node) : node; } function createArrowFunction(modifiers, typeParameters, parameters, type, equalsGreaterThanToken, body) { - const node = createBaseDeclaration(218 /* ArrowFunction */); + const node = createBaseDeclaration(219 /* ArrowFunction */); node.modifiers = asNodeArray(modifiers); node.typeParameters = asNodeArray(typeParameters); node.parameters = createNodeArray(parameters); node.type = type; node.equalsGreaterThanToken = equalsGreaterThanToken ?? createToken(39 /* EqualsGreaterThanToken */); node.body = parenthesizerRules().parenthesizeConciseBodyOfArrowFunction(body); - const isAsync = modifiersToFlags(node.modifiers) & 512 /* Async */; + const isAsync = modifiersToFlags(node.modifiers) & 1024 /* Async */; node.transformFlags = propagateChildrenFlags(node.modifiers) | propagateChildrenFlags(node.typeParameters) | propagateChildrenFlags(node.parameters) | propagateChildFlags(node.type) | propagateChildFlags(node.equalsGreaterThanToken) | propagateChildFlags(node.body) & ~67108864 /* ContainsPossibleTopLevelAwait */ | (node.typeParameters || node.type ? 1 /* ContainsTypeScript */ : 0 /* None */) | (isAsync ? 256 /* ContainsES2017 */ | 16384 /* ContainsLexicalThis */ : 0 /* None */) | 1024 /* ContainsES2015 */; node.typeArguments = void 0; node.jsDoc = void 0; @@ -120924,7 +103752,7 @@ ${lanes.join("\n")} return node.modifiers !== modifiers || node.typeParameters !== typeParameters || node.parameters !== parameters || node.type !== type || node.equalsGreaterThanToken !== equalsGreaterThanToken || node.body !== body ? finishUpdateBaseSignatureDeclaration(createArrowFunction(modifiers, typeParameters, parameters, type, equalsGreaterThanToken, body), node) : node; } function createDeleteExpression(expression) { - const node = createBaseNode(219 /* DeleteExpression */); + const node = createBaseNode(220 /* DeleteExpression */); node.expression = parenthesizerRules().parenthesizeOperandOfPrefixUnary(expression); node.transformFlags |= propagateChildFlags(node.expression); return node; @@ -120933,7 +103761,7 @@ ${lanes.join("\n")} return node.expression !== expression ? update(createDeleteExpression(expression), node) : node; } function createTypeOfExpression(expression) { - const node = createBaseNode(220 /* TypeOfExpression */); + const node = createBaseNode(221 /* TypeOfExpression */); node.expression = parenthesizerRules().parenthesizeOperandOfPrefixUnary(expression); node.transformFlags |= propagateChildFlags(node.expression); return node; @@ -120942,7 +103770,7 @@ ${lanes.join("\n")} return node.expression !== expression ? update(createTypeOfExpression(expression), node) : node; } function createVoidExpression(expression) { - const node = createBaseNode(221 /* VoidExpression */); + const node = createBaseNode(222 /* VoidExpression */); node.expression = parenthesizerRules().parenthesizeOperandOfPrefixUnary(expression); node.transformFlags |= propagateChildFlags(node.expression); return node; @@ -120951,7 +103779,7 @@ ${lanes.join("\n")} return node.expression !== expression ? update(createVoidExpression(expression), node) : node; } function createAwaitExpression(expression) { - const node = createBaseNode(222 /* AwaitExpression */); + const node = createBaseNode(223 /* AwaitExpression */); node.expression = parenthesizerRules().parenthesizeOperandOfPrefixUnary(expression); node.transformFlags |= propagateChildFlags(node.expression) | 256 /* ContainsES2017 */ | 128 /* ContainsES2018 */ | 2097152 /* ContainsAwait */; return node; @@ -120960,7 +103788,7 @@ ${lanes.join("\n")} return node.expression !== expression ? update(createAwaitExpression(expression), node) : node; } function createPrefixUnaryExpression(operator, operand) { - const node = createBaseNode(223 /* PrefixUnaryExpression */); + const node = createBaseNode(224 /* PrefixUnaryExpression */); node.operator = operator; node.operand = parenthesizerRules().parenthesizeOperandOfPrefixUnary(operand); node.transformFlags |= propagateChildFlags(node.operand); @@ -120973,7 +103801,7 @@ ${lanes.join("\n")} return node.operand !== operand ? update(createPrefixUnaryExpression(node.operator, operand), node) : node; } function createPostfixUnaryExpression(operand, operator) { - const node = createBaseNode(224 /* PostfixUnaryExpression */); + const node = createBaseNode(225 /* PostfixUnaryExpression */); node.operator = operator; node.operand = parenthesizerRules().parenthesizeOperandOfPostfixUnary(operand); node.transformFlags |= propagateChildFlags(node.operand); @@ -120986,7 +103814,7 @@ ${lanes.join("\n")} return node.operand !== operand ? update(createPostfixUnaryExpression(operand, node.operator), node) : node; } function createBinaryExpression(left, operator, right) { - const node = createBaseDeclaration(225 /* BinaryExpression */); + const node = createBaseDeclaration(226 /* BinaryExpression */); const operatorToken = asToken(operator); const operatorKind = operatorToken.kind; node.left = parenthesizerRules().parenthesizeLeftSideOfBinary(operatorKind, left); @@ -121019,7 +103847,7 @@ ${lanes.join("\n")} return node.left !== left || node.operatorToken !== operator || node.right !== right ? update(createBinaryExpression(left, operator, right), node) : node; } function createConditionalExpression(condition, questionToken, whenTrue, colonToken, whenFalse) { - const node = createBaseNode(226 /* ConditionalExpression */); + const node = createBaseNode(227 /* ConditionalExpression */); node.condition = parenthesizerRules().parenthesizeConditionOfConditionalExpression(condition); node.questionToken = questionToken ?? createToken(58 /* QuestionToken */); node.whenTrue = parenthesizerRules().parenthesizeBranchOfConditionalExpression(whenTrue); @@ -121032,7 +103860,7 @@ ${lanes.join("\n")} return node.condition !== condition || node.questionToken !== questionToken || node.whenTrue !== whenTrue || node.colonToken !== colonToken || node.whenFalse !== whenFalse ? update(createConditionalExpression(condition, questionToken, whenTrue, colonToken, whenFalse), node) : node; } function createTemplateExpression(head, templateSpans) { - const node = createBaseNode(227 /* TemplateExpression */); + const node = createBaseNode(228 /* TemplateExpression */); node.head = head; node.templateSpans = createNodeArray(templateSpans); node.transformFlags |= propagateChildFlags(node.head) | propagateChildrenFlags(node.templateSpans) | 1024 /* ContainsES2015 */; @@ -121107,7 +103935,7 @@ ${lanes.join("\n")} } function createYieldExpression(asteriskToken, expression) { Debug.assert(!asteriskToken || !!expression, "A `YieldExpression` with an asteriskToken must have an expression."); - const node = createBaseNode(228 /* YieldExpression */); + const node = createBaseNode(229 /* YieldExpression */); node.expression = expression && parenthesizerRules().parenthesizeExpressionForDisallowedComma(expression); node.asteriskToken = asteriskToken; node.transformFlags |= propagateChildFlags(node.expression) | propagateChildFlags(node.asteriskToken) | 1024 /* ContainsES2015 */ | 128 /* ContainsES2018 */ | 1048576 /* ContainsYield */; @@ -121117,7 +103945,7 @@ ${lanes.join("\n")} return node.expression !== expression || node.asteriskToken !== asteriskToken ? update(createYieldExpression(asteriskToken, expression), node) : node; } function createSpreadElement(expression) { - const node = createBaseNode(229 /* SpreadElement */); + const node = createBaseNode(230 /* SpreadElement */); node.expression = parenthesizerRules().parenthesizeExpressionForDisallowedComma(expression); node.transformFlags |= propagateChildFlags(node.expression) | 1024 /* ContainsES2015 */ | 32768 /* ContainsRestOrSpread */; return node; @@ -121126,7 +103954,7 @@ ${lanes.join("\n")} return node.expression !== expression ? update(createSpreadElement(expression), node) : node; } function createClassExpression(modifiers, name, typeParameters, heritageClauses, members) { - const node = createBaseDeclaration(230 /* ClassExpression */); + const node = createBaseDeclaration(231 /* ClassExpression */); node.modifiers = asNodeArray(modifiers); node.name = asName(name); node.typeParameters = asNodeArray(typeParameters); @@ -121140,10 +103968,10 @@ ${lanes.join("\n")} return node.modifiers !== modifiers || node.name !== name || node.typeParameters !== typeParameters || node.heritageClauses !== heritageClauses || node.members !== members ? update(createClassExpression(modifiers, name, typeParameters, heritageClauses, members), node) : node; } function createOmittedExpression() { - return createBaseNode(231 /* OmittedExpression */); + return createBaseNode(232 /* OmittedExpression */); } function createExpressionWithTypeArguments(expression, typeArguments) { - const node = createBaseNode(232 /* ExpressionWithTypeArguments */); + const node = createBaseNode(233 /* ExpressionWithTypeArguments */); node.expression = parenthesizerRules().parenthesizeLeftSideOfAccess( expression, /*optionalChain*/ @@ -121157,7 +103985,7 @@ ${lanes.join("\n")} return node.expression !== expression || node.typeArguments !== typeArguments ? update(createExpressionWithTypeArguments(expression, typeArguments), node) : node; } function createAsExpression(expression, type) { - const node = createBaseNode(233 /* AsExpression */); + const node = createBaseNode(234 /* AsExpression */); node.expression = expression; node.type = type; node.transformFlags |= propagateChildFlags(node.expression) | propagateChildFlags(node.type) | 1 /* ContainsTypeScript */; @@ -121167,7 +103995,7 @@ ${lanes.join("\n")} return node.expression !== expression || node.type !== type ? update(createAsExpression(expression, type), node) : node; } function createNonNullExpression(expression) { - const node = createBaseNode(234 /* NonNullExpression */); + const node = createBaseNode(235 /* NonNullExpression */); node.expression = parenthesizerRules().parenthesizeLeftSideOfAccess( expression, /*optionalChain*/ @@ -121183,7 +104011,7 @@ ${lanes.join("\n")} return node.expression !== expression ? update(createNonNullExpression(expression), node) : node; } function createSatisfiesExpression(expression, type) { - const node = createBaseNode(237 /* SatisfiesExpression */); + const node = createBaseNode(238 /* SatisfiesExpression */); node.expression = expression; node.type = type; node.transformFlags |= propagateChildFlags(node.expression) | propagateChildFlags(node.type) | 1 /* ContainsTypeScript */; @@ -121193,8 +104021,8 @@ ${lanes.join("\n")} return node.expression !== expression || node.type !== type ? update(createSatisfiesExpression(expression, type), node) : node; } function createNonNullChain(expression) { - const node = createBaseNode(234 /* NonNullExpression */); - node.flags |= 32 /* OptionalChain */; + const node = createBaseNode(235 /* NonNullExpression */); + node.flags |= 64 /* OptionalChain */; node.expression = parenthesizerRules().parenthesizeLeftSideOfAccess( expression, /*optionalChain*/ @@ -121204,11 +104032,11 @@ ${lanes.join("\n")} return node; } function updateNonNullChain(node, expression) { - Debug.assert(!!(node.flags & 32 /* OptionalChain */), "Cannot update a NonNullExpression using updateNonNullChain. Use updateNonNullExpression instead."); + Debug.assert(!!(node.flags & 64 /* OptionalChain */), "Cannot update a NonNullExpression using updateNonNullChain. Use updateNonNullExpression instead."); return node.expression !== expression ? update(createNonNullChain(expression), node) : node; } function createMetaProperty(keywordToken, name) { - const node = createBaseNode(235 /* MetaProperty */); + const node = createBaseNode(236 /* MetaProperty */); node.keywordToken = keywordToken; node.name = name; node.transformFlags |= propagateChildFlags(node.name); @@ -121229,7 +104057,7 @@ ${lanes.join("\n")} return node.name !== name ? update(createMetaProperty(node.keywordToken, name), node) : node; } function createTemplateSpan(expression, literal) { - const node = createBaseNode(238 /* TemplateSpan */); + const node = createBaseNode(239 /* TemplateSpan */); node.expression = expression; node.literal = literal; node.transformFlags |= propagateChildFlags(node.expression) | propagateChildFlags(node.literal) | 1024 /* ContainsES2015 */; @@ -121239,12 +104067,12 @@ ${lanes.join("\n")} return node.expression !== expression || node.literal !== literal ? update(createTemplateSpan(expression, literal), node) : node; } function createSemicolonClassElement() { - const node = createBaseNode(239 /* SemicolonClassElement */); + const node = createBaseNode(240 /* SemicolonClassElement */); node.transformFlags |= 1024 /* ContainsES2015 */; return node; } function createBlock(statements, multiLine) { - const node = createBaseNode(240 /* Block */); + const node = createBaseNode(241 /* Block */); node.statements = createNodeArray(statements); node.multiLine = multiLine; node.transformFlags |= propagateChildrenFlags(node.statements); @@ -121257,11 +104085,11 @@ ${lanes.join("\n")} return node.statements !== statements ? update(createBlock(statements, node.multiLine), node) : node; } function createVariableStatement(modifiers, declarationList) { - const node = createBaseNode(242 /* VariableStatement */); + const node = createBaseNode(243 /* VariableStatement */); node.modifiers = asNodeArray(modifiers); node.declarationList = isArray(declarationList) ? createVariableDeclarationList(declarationList) : declarationList; node.transformFlags |= propagateChildrenFlags(node.modifiers) | propagateChildFlags(node.declarationList); - if (modifiersToFlags(node.modifiers) & 2 /* Ambient */) { + if (modifiersToFlags(node.modifiers) & 128 /* Ambient */) { node.transformFlags = 1 /* ContainsTypeScript */; } node.jsDoc = void 0; @@ -121272,12 +104100,12 @@ ${lanes.join("\n")} return node.modifiers !== modifiers || node.declarationList !== declarationList ? update(createVariableStatement(modifiers, declarationList), node) : node; } function createEmptyStatement() { - const node = createBaseNode(241 /* EmptyStatement */); + const node = createBaseNode(242 /* EmptyStatement */); node.jsDoc = void 0; return node; } function createExpressionStatement(expression) { - const node = createBaseNode(243 /* ExpressionStatement */); + const node = createBaseNode(244 /* ExpressionStatement */); node.expression = parenthesizerRules().parenthesizeExpressionOfExpressionStatement(expression); node.transformFlags |= propagateChildFlags(node.expression); node.jsDoc = void 0; @@ -121288,7 +104116,7 @@ ${lanes.join("\n")} return node.expression !== expression ? update(createExpressionStatement(expression), node) : node; } function createIfStatement(expression, thenStatement, elseStatement) { - const node = createBaseNode(244 /* IfStatement */); + const node = createBaseNode(245 /* IfStatement */); node.expression = expression; node.thenStatement = asEmbeddedStatement(thenStatement); node.elseStatement = asEmbeddedStatement(elseStatement); @@ -121301,7 +104129,7 @@ ${lanes.join("\n")} return node.expression !== expression || node.thenStatement !== thenStatement || node.elseStatement !== elseStatement ? update(createIfStatement(expression, thenStatement, elseStatement), node) : node; } function createDoStatement(statement, expression) { - const node = createBaseNode(245 /* DoStatement */); + const node = createBaseNode(246 /* DoStatement */); node.statement = asEmbeddedStatement(statement); node.expression = expression; node.transformFlags |= propagateChildFlags(node.statement) | propagateChildFlags(node.expression); @@ -121313,7 +104141,7 @@ ${lanes.join("\n")} return node.statement !== statement || node.expression !== expression ? update(createDoStatement(statement, expression), node) : node; } function createWhileStatement(expression, statement) { - const node = createBaseNode(246 /* WhileStatement */); + const node = createBaseNode(247 /* WhileStatement */); node.expression = expression; node.statement = asEmbeddedStatement(statement); node.transformFlags |= propagateChildFlags(node.expression) | propagateChildFlags(node.statement); @@ -121325,7 +104153,7 @@ ${lanes.join("\n")} return node.expression !== expression || node.statement !== statement ? update(createWhileStatement(expression, statement), node) : node; } function createForStatement(initializer, condition, incrementor, statement) { - const node = createBaseNode(247 /* ForStatement */); + const node = createBaseNode(248 /* ForStatement */); node.initializer = initializer; node.condition = condition; node.incrementor = incrementor; @@ -121341,7 +104169,7 @@ ${lanes.join("\n")} return node.initializer !== initializer || node.condition !== condition || node.incrementor !== incrementor || node.statement !== statement ? update(createForStatement(initializer, condition, incrementor, statement), node) : node; } function createForInStatement(initializer, expression, statement) { - const node = createBaseNode(248 /* ForInStatement */); + const node = createBaseNode(249 /* ForInStatement */); node.initializer = initializer; node.expression = expression; node.statement = asEmbeddedStatement(statement); @@ -121356,7 +104184,7 @@ ${lanes.join("\n")} return node.initializer !== initializer || node.expression !== expression || node.statement !== statement ? update(createForInStatement(initializer, expression, statement), node) : node; } function createForOfStatement(awaitModifier, initializer, expression, statement) { - const node = createBaseNode(249 /* ForOfStatement */); + const node = createBaseNode(250 /* ForOfStatement */); node.awaitModifier = awaitModifier; node.initializer = initializer; node.expression = parenthesizerRules().parenthesizeExpressionForDisallowedComma(expression); @@ -121374,7 +104202,7 @@ ${lanes.join("\n")} return node.awaitModifier !== awaitModifier || node.initializer !== initializer || node.expression !== expression || node.statement !== statement ? update(createForOfStatement(awaitModifier, initializer, expression, statement), node) : node; } function createContinueStatement(label) { - const node = createBaseNode(250 /* ContinueStatement */); + const node = createBaseNode(251 /* ContinueStatement */); node.label = asName(label); node.transformFlags |= propagateChildFlags(node.label) | 4194304 /* ContainsHoistedDeclarationOrCompletion */; node.jsDoc = void 0; @@ -121385,7 +104213,7 @@ ${lanes.join("\n")} return node.label !== label ? update(createContinueStatement(label), node) : node; } function createBreakStatement(label) { - const node = createBaseNode(251 /* BreakStatement */); + const node = createBaseNode(252 /* BreakStatement */); node.label = asName(label); node.transformFlags |= propagateChildFlags(node.label) | 4194304 /* ContainsHoistedDeclarationOrCompletion */; node.jsDoc = void 0; @@ -121396,7 +104224,7 @@ ${lanes.join("\n")} return node.label !== label ? update(createBreakStatement(label), node) : node; } function createReturnStatement(expression) { - const node = createBaseNode(252 /* ReturnStatement */); + const node = createBaseNode(253 /* ReturnStatement */); node.expression = expression; node.transformFlags |= propagateChildFlags(node.expression) | 128 /* ContainsES2018 */ | 4194304 /* ContainsHoistedDeclarationOrCompletion */; node.jsDoc = void 0; @@ -121407,7 +104235,7 @@ ${lanes.join("\n")} return node.expression !== expression ? update(createReturnStatement(expression), node) : node; } function createWithStatement(expression, statement) { - const node = createBaseNode(253 /* WithStatement */); + const node = createBaseNode(254 /* WithStatement */); node.expression = expression; node.statement = asEmbeddedStatement(statement); node.transformFlags |= propagateChildFlags(node.expression) | propagateChildFlags(node.statement); @@ -121419,7 +104247,7 @@ ${lanes.join("\n")} return node.expression !== expression || node.statement !== statement ? update(createWithStatement(expression, statement), node) : node; } function createSwitchStatement(expression, caseBlock) { - const node = createBaseNode(254 /* SwitchStatement */); + const node = createBaseNode(255 /* SwitchStatement */); node.expression = parenthesizerRules().parenthesizeExpressionForDisallowedComma(expression); node.caseBlock = caseBlock; node.transformFlags |= propagateChildFlags(node.expression) | propagateChildFlags(node.caseBlock); @@ -121432,7 +104260,7 @@ ${lanes.join("\n")} return node.expression !== expression || node.caseBlock !== caseBlock ? update(createSwitchStatement(expression, caseBlock), node) : node; } function createLabeledStatement(label, statement) { - const node = createBaseNode(255 /* LabeledStatement */); + const node = createBaseNode(256 /* LabeledStatement */); node.label = asName(label); node.statement = asEmbeddedStatement(statement); node.transformFlags |= propagateChildFlags(node.label) | propagateChildFlags(node.statement); @@ -121444,7 +104272,7 @@ ${lanes.join("\n")} return node.label !== label || node.statement !== statement ? update(createLabeledStatement(label, statement), node) : node; } function createThrowStatement(expression) { - const node = createBaseNode(256 /* ThrowStatement */); + const node = createBaseNode(257 /* ThrowStatement */); node.expression = expression; node.transformFlags |= propagateChildFlags(node.expression); node.jsDoc = void 0; @@ -121455,7 +104283,7 @@ ${lanes.join("\n")} return node.expression !== expression ? update(createThrowStatement(expression), node) : node; } function createTryStatement(tryBlock, catchClause, finallyBlock) { - const node = createBaseNode(257 /* TryStatement */); + const node = createBaseNode(258 /* TryStatement */); node.tryBlock = tryBlock; node.catchClause = catchClause; node.finallyBlock = finallyBlock; @@ -121468,13 +104296,13 @@ ${lanes.join("\n")} return node.tryBlock !== tryBlock || node.catchClause !== catchClause || node.finallyBlock !== finallyBlock ? update(createTryStatement(tryBlock, catchClause, finallyBlock), node) : node; } function createDebuggerStatement() { - const node = createBaseNode(258 /* DebuggerStatement */); + const node = createBaseNode(259 /* DebuggerStatement */); node.jsDoc = void 0; node.flowNode = void 0; return node; } function createVariableDeclaration(name, exclamationToken, type, initializer) { - const node = createBaseDeclaration(259 /* VariableDeclaration */); + const node = createBaseDeclaration(260 /* VariableDeclaration */); node.name = asName(name); node.exclamationToken = exclamationToken; node.type = type; @@ -121487,20 +104315,23 @@ ${lanes.join("\n")} return node.name !== name || node.type !== type || node.exclamationToken !== exclamationToken || node.initializer !== initializer ? update(createVariableDeclaration(name, exclamationToken, type, initializer), node) : node; } function createVariableDeclarationList(declarations, flags2 = 0 /* None */) { - const node = createBaseNode(260 /* VariableDeclarationList */); - node.flags |= flags2 & 3 /* BlockScoped */; + const node = createBaseNode(261 /* VariableDeclarationList */); + node.flags |= flags2 & 7 /* BlockScoped */; node.declarations = createNodeArray(declarations); node.transformFlags |= propagateChildrenFlags(node.declarations) | 4194304 /* ContainsHoistedDeclarationOrCompletion */; - if (flags2 & 3 /* BlockScoped */) { + if (flags2 & 7 /* BlockScoped */) { node.transformFlags |= 1024 /* ContainsES2015 */ | 262144 /* ContainsBlockScopedBinding */; } + if (flags2 & 4 /* Using */) { + node.transformFlags |= 4 /* ContainsESNext */; + } return node; } function updateVariableDeclarationList(node, declarations) { return node.declarations !== declarations ? update(createVariableDeclarationList(declarations, node.flags), node) : node; } function createFunctionDeclaration(modifiers, asteriskToken, name, typeParameters, parameters, type, body) { - const node = createBaseDeclaration(261 /* FunctionDeclaration */); + const node = createBaseDeclaration(262 /* FunctionDeclaration */); node.modifiers = asNodeArray(modifiers); node.asteriskToken = asteriskToken; node.name = asName(name); @@ -121508,10 +104339,10 @@ ${lanes.join("\n")} node.parameters = createNodeArray(parameters); node.type = type; node.body = body; - if (!node.body || modifiersToFlags(node.modifiers) & 2 /* Ambient */) { + if (!node.body || modifiersToFlags(node.modifiers) & 128 /* Ambient */) { node.transformFlags = 1 /* ContainsTypeScript */; } else { - const isAsync = modifiersToFlags(node.modifiers) & 512 /* Async */; + const isAsync = modifiersToFlags(node.modifiers) & 1024 /* Async */; const isGenerator = !!node.asteriskToken; const isAsyncGenerator = isAsync && isGenerator; node.transformFlags = propagateChildrenFlags(node.modifiers) | propagateChildFlags(node.asteriskToken) | propagateNameFlags(node.name) | propagateChildrenFlags(node.typeParameters) | propagateChildrenFlags(node.parameters) | propagateChildFlags(node.type) | propagateChildFlags(node.body) & ~67108864 /* ContainsPossibleTopLevelAwait */ | (isAsyncGenerator ? 128 /* ContainsES2018 */ : isAsync ? 256 /* ContainsES2017 */ : isGenerator ? 2048 /* ContainsGenerator */ : 0 /* None */) | (node.typeParameters || node.type ? 1 /* ContainsTypeScript */ : 0 /* None */) | 4194304 /* ContainsHoistedDeclarationOrCompletion */; @@ -121536,13 +104367,13 @@ ${lanes.join("\n")} return finishUpdateBaseSignatureDeclaration(updated, original); } function createClassDeclaration(modifiers, name, typeParameters, heritageClauses, members) { - const node = createBaseDeclaration(262 /* ClassDeclaration */); + const node = createBaseDeclaration(263 /* ClassDeclaration */); node.modifiers = asNodeArray(modifiers); node.name = asName(name); node.typeParameters = asNodeArray(typeParameters); node.heritageClauses = asNodeArray(heritageClauses); node.members = createNodeArray(members); - if (modifiersToFlags(node.modifiers) & 2 /* Ambient */) { + if (modifiersToFlags(node.modifiers) & 128 /* Ambient */) { node.transformFlags = 1 /* ContainsTypeScript */; } else { node.transformFlags |= propagateChildrenFlags(node.modifiers) | propagateNameFlags(node.name) | propagateChildrenFlags(node.typeParameters) | propagateChildrenFlags(node.heritageClauses) | propagateChildrenFlags(node.members) | (node.typeParameters ? 1 /* ContainsTypeScript */ : 0 /* None */) | 1024 /* ContainsES2015 */; @@ -121557,7 +104388,7 @@ ${lanes.join("\n")} return node.modifiers !== modifiers || node.name !== name || node.typeParameters !== typeParameters || node.heritageClauses !== heritageClauses || node.members !== members ? update(createClassDeclaration(modifiers, name, typeParameters, heritageClauses, members), node) : node; } function createInterfaceDeclaration(modifiers, name, typeParameters, heritageClauses, members) { - const node = createBaseDeclaration(263 /* InterfaceDeclaration */); + const node = createBaseDeclaration(264 /* InterfaceDeclaration */); node.modifiers = asNodeArray(modifiers); node.name = asName(name); node.typeParameters = asNodeArray(typeParameters); @@ -121571,7 +104402,7 @@ ${lanes.join("\n")} return node.modifiers !== modifiers || node.name !== name || node.typeParameters !== typeParameters || node.heritageClauses !== heritageClauses || node.members !== members ? update(createInterfaceDeclaration(modifiers, name, typeParameters, heritageClauses, members), node) : node; } function createTypeAliasDeclaration(modifiers, name, typeParameters, type) { - const node = createBaseDeclaration(264 /* TypeAliasDeclaration */); + const node = createBaseDeclaration(265 /* TypeAliasDeclaration */); node.modifiers = asNodeArray(modifiers); node.name = asName(name); node.typeParameters = asNodeArray(typeParameters); @@ -121586,7 +104417,7 @@ ${lanes.join("\n")} return node.modifiers !== modifiers || node.name !== name || node.typeParameters !== typeParameters || node.type !== type ? update(createTypeAliasDeclaration(modifiers, name, typeParameters, type), node) : node; } function createEnumDeclaration(modifiers, name, members) { - const node = createBaseDeclaration(265 /* EnumDeclaration */); + const node = createBaseDeclaration(266 /* EnumDeclaration */); node.modifiers = asNodeArray(modifiers); node.name = asName(name); node.members = createNodeArray(members); @@ -121599,12 +104430,12 @@ ${lanes.join("\n")} return node.modifiers !== modifiers || node.name !== name || node.members !== members ? update(createEnumDeclaration(modifiers, name, members), node) : node; } function createModuleDeclaration(modifiers, name, body, flags2 = 0 /* None */) { - const node = createBaseDeclaration(266 /* ModuleDeclaration */); + const node = createBaseDeclaration(267 /* ModuleDeclaration */); node.modifiers = asNodeArray(modifiers); - node.flags |= flags2 & (16 /* Namespace */ | 4 /* NestedNamespace */ | 1024 /* GlobalAugmentation */); + node.flags |= flags2 & (32 /* Namespace */ | 8 /* NestedNamespace */ | 2048 /* GlobalAugmentation */); node.name = name; node.body = body; - if (modifiersToFlags(node.modifiers) & 2 /* Ambient */) { + if (modifiersToFlags(node.modifiers) & 128 /* Ambient */) { node.transformFlags = 1 /* ContainsTypeScript */; } else { node.transformFlags |= propagateChildrenFlags(node.modifiers) | propagateChildFlags(node.name) | propagateChildFlags(node.body) | 1 /* ContainsTypeScript */; @@ -121619,7 +104450,7 @@ ${lanes.join("\n")} return node.modifiers !== modifiers || node.name !== name || node.body !== body ? update(createModuleDeclaration(modifiers, name, body, node.flags), node) : node; } function createModuleBlock(statements) { - const node = createBaseNode(267 /* ModuleBlock */); + const node = createBaseNode(268 /* ModuleBlock */); node.statements = createNodeArray(statements); node.transformFlags |= propagateChildrenFlags(node.statements); node.jsDoc = void 0; @@ -121629,7 +104460,7 @@ ${lanes.join("\n")} return node.statements !== statements ? update(createModuleBlock(statements), node) : node; } function createCaseBlock(clauses) { - const node = createBaseNode(268 /* CaseBlock */); + const node = createBaseNode(269 /* CaseBlock */); node.clauses = createNodeArray(clauses); node.transformFlags |= propagateChildrenFlags(node.clauses); node.locals = void 0; @@ -121640,7 +104471,7 @@ ${lanes.join("\n")} return node.clauses !== clauses ? update(createCaseBlock(clauses), node) : node; } function createNamespaceExportDeclaration(name) { - const node = createBaseDeclaration(269 /* NamespaceExportDeclaration */); + const node = createBaseDeclaration(270 /* NamespaceExportDeclaration */); node.name = asName(name); node.transformFlags |= propagateIdentifierNameFlags(node.name) | 1 /* ContainsTypeScript */; node.modifiers = void 0; @@ -121657,7 +104488,7 @@ ${lanes.join("\n")} return update(updated, original); } function createImportEqualsDeclaration(modifiers, isTypeOnly, name, moduleReference) { - const node = createBaseDeclaration(270 /* ImportEqualsDeclaration */); + const node = createBaseDeclaration(271 /* ImportEqualsDeclaration */); node.modifiers = asNodeArray(modifiers); node.name = asName(name); node.isTypeOnly = isTypeOnly; @@ -121673,22 +104504,22 @@ ${lanes.join("\n")} function updateImportEqualsDeclaration(node, modifiers, isTypeOnly, name, moduleReference) { return node.modifiers !== modifiers || node.isTypeOnly !== isTypeOnly || node.name !== name || node.moduleReference !== moduleReference ? update(createImportEqualsDeclaration(modifiers, isTypeOnly, name, moduleReference), node) : node; } - function createImportDeclaration(modifiers, importClause, moduleSpecifier, assertClause) { - const node = createBaseNode(271 /* ImportDeclaration */); + function createImportDeclaration(modifiers, importClause, moduleSpecifier, attributes) { + const node = createBaseNode(272 /* ImportDeclaration */); node.modifiers = asNodeArray(modifiers); node.importClause = importClause; node.moduleSpecifier = moduleSpecifier; - node.assertClause = assertClause; + node.attributes = node.assertClause = attributes; node.transformFlags |= propagateChildFlags(node.importClause) | propagateChildFlags(node.moduleSpecifier); node.transformFlags &= ~67108864 /* ContainsPossibleTopLevelAwait */; node.jsDoc = void 0; return node; } - function updateImportDeclaration(node, modifiers, importClause, moduleSpecifier, assertClause) { - return node.modifiers !== modifiers || node.importClause !== importClause || node.moduleSpecifier !== moduleSpecifier || node.assertClause !== assertClause ? update(createImportDeclaration(modifiers, importClause, moduleSpecifier, assertClause), node) : node; + function updateImportDeclaration(node, modifiers, importClause, moduleSpecifier, attributes) { + return node.modifiers !== modifiers || node.importClause !== importClause || node.moduleSpecifier !== moduleSpecifier || node.attributes !== attributes ? update(createImportDeclaration(modifiers, importClause, moduleSpecifier, attributes), node) : node; } function createImportClause(isTypeOnly, name, namedBindings) { - const node = createBaseDeclaration(272 /* ImportClause */); + const node = createBaseDeclaration(273 /* ImportClause */); node.isTypeOnly = isTypeOnly; node.name = name; node.namedBindings = namedBindings; @@ -121703,9 +104534,10 @@ ${lanes.join("\n")} return node.isTypeOnly !== isTypeOnly || node.name !== name || node.namedBindings !== namedBindings ? update(createImportClause(isTypeOnly, name, namedBindings), node) : node; } function createAssertClause(elements, multiLine) { - const node = createBaseNode(299 /* AssertClause */); + const node = createBaseNode(300 /* AssertClause */); node.elements = createNodeArray(elements); node.multiLine = multiLine; + node.token = 132 /* AssertKeyword */; node.transformFlags |= 4 /* ContainsESNext */; return node; } @@ -121713,7 +104545,7 @@ ${lanes.join("\n")} return node.elements !== elements || node.multiLine !== multiLine ? update(createAssertClause(elements, multiLine), node) : node; } function createAssertEntry(name, value) { - const node = createBaseNode(300 /* AssertEntry */); + const node = createBaseNode(301 /* AssertEntry */); node.name = name; node.value = value; node.transformFlags |= 4 /* ContainsESNext */; @@ -121723,7 +104555,7 @@ ${lanes.join("\n")} return node.name !== name || node.value !== value ? update(createAssertEntry(name, value), node) : node; } function createImportTypeAssertionContainer(clause, multiLine) { - const node = createBaseNode(301 /* ImportTypeAssertionContainer */); + const node = createBaseNode(302 /* ImportTypeAssertionContainer */); node.assertClause = clause; node.multiLine = multiLine; return node; @@ -121731,8 +104563,29 @@ ${lanes.join("\n")} function updateImportTypeAssertionContainer(node, clause, multiLine) { return node.assertClause !== clause || node.multiLine !== multiLine ? update(createImportTypeAssertionContainer(clause, multiLine), node) : node; } + function createImportAttributes(elements, multiLine, token) { + const node = createBaseNode(300 /* ImportAttributes */); + node.token = token ?? 118 /* WithKeyword */; + node.elements = createNodeArray(elements); + node.multiLine = multiLine; + node.transformFlags |= 4 /* ContainsESNext */; + return node; + } + function updateImportAttributes(node, elements, multiLine) { + return node.elements !== elements || node.multiLine !== multiLine ? update(createImportAttributes(elements, multiLine, node.token), node) : node; + } + function createImportAttribute(name, value) { + const node = createBaseNode(301 /* ImportAttribute */); + node.name = name; + node.value = value; + node.transformFlags |= 4 /* ContainsESNext */; + return node; + } + function updateImportAttribute(node, name, value) { + return node.name !== name || node.value !== value ? update(createImportAttribute(name, value), node) : node; + } function createNamespaceImport(name) { - const node = createBaseDeclaration(273 /* NamespaceImport */); + const node = createBaseDeclaration(274 /* NamespaceImport */); node.name = name; node.transformFlags |= propagateChildFlags(node.name); node.transformFlags &= ~67108864 /* ContainsPossibleTopLevelAwait */; @@ -121742,7 +104595,7 @@ ${lanes.join("\n")} return node.name !== name ? update(createNamespaceImport(name), node) : node; } function createNamespaceExport(name) { - const node = createBaseDeclaration(279 /* NamespaceExport */); + const node = createBaseDeclaration(280 /* NamespaceExport */); node.name = name; node.transformFlags |= propagateChildFlags(node.name) | 32 /* ContainsES2020 */; node.transformFlags &= ~67108864 /* ContainsPossibleTopLevelAwait */; @@ -121752,7 +104605,7 @@ ${lanes.join("\n")} return node.name !== name ? update(createNamespaceExport(name), node) : node; } function createNamedImports(elements) { - const node = createBaseNode(274 /* NamedImports */); + const node = createBaseNode(275 /* NamedImports */); node.elements = createNodeArray(elements); node.transformFlags |= propagateChildrenFlags(node.elements); node.transformFlags &= ~67108864 /* ContainsPossibleTopLevelAwait */; @@ -121762,7 +104615,7 @@ ${lanes.join("\n")} return node.elements !== elements ? update(createNamedImports(elements), node) : node; } function createImportSpecifier(isTypeOnly, propertyName, name) { - const node = createBaseDeclaration(275 /* ImportSpecifier */); + const node = createBaseDeclaration(276 /* ImportSpecifier */); node.isTypeOnly = isTypeOnly; node.propertyName = propertyName; node.name = name; @@ -121774,7 +104627,7 @@ ${lanes.join("\n")} return node.isTypeOnly !== isTypeOnly || node.propertyName !== propertyName || node.name !== name ? update(createImportSpecifier(isTypeOnly, propertyName, name), node) : node; } function createExportAssignment2(modifiers, isExportEquals, expression) { - const node = createBaseDeclaration(276 /* ExportAssignment */); + const node = createBaseDeclaration(277 /* ExportAssignment */); node.modifiers = asNodeArray(modifiers); node.isExportEquals = isExportEquals; node.expression = isExportEquals ? parenthesizerRules().parenthesizeRightSideOfBinary( @@ -121791,20 +104644,20 @@ ${lanes.join("\n")} function updateExportAssignment(node, modifiers, expression) { return node.modifiers !== modifiers || node.expression !== expression ? update(createExportAssignment2(modifiers, node.isExportEquals, expression), node) : node; } - function createExportDeclaration(modifiers, isTypeOnly, exportClause, moduleSpecifier, assertClause) { - const node = createBaseDeclaration(277 /* ExportDeclaration */); + function createExportDeclaration(modifiers, isTypeOnly, exportClause, moduleSpecifier, attributes) { + const node = createBaseDeclaration(278 /* ExportDeclaration */); node.modifiers = asNodeArray(modifiers); node.isTypeOnly = isTypeOnly; node.exportClause = exportClause; node.moduleSpecifier = moduleSpecifier; - node.assertClause = assertClause; + node.attributes = node.assertClause = attributes; node.transformFlags |= propagateChildrenFlags(node.modifiers) | propagateChildFlags(node.exportClause) | propagateChildFlags(node.moduleSpecifier); node.transformFlags &= ~67108864 /* ContainsPossibleTopLevelAwait */; node.jsDoc = void 0; return node; } - function updateExportDeclaration(node, modifiers, isTypeOnly, exportClause, moduleSpecifier, assertClause) { - return node.modifiers !== modifiers || node.isTypeOnly !== isTypeOnly || node.exportClause !== exportClause || node.moduleSpecifier !== moduleSpecifier || node.assertClause !== assertClause ? finishUpdateExportDeclaration(createExportDeclaration(modifiers, isTypeOnly, exportClause, moduleSpecifier, assertClause), node) : node; + function updateExportDeclaration(node, modifiers, isTypeOnly, exportClause, moduleSpecifier, attributes) { + return node.modifiers !== modifiers || node.isTypeOnly !== isTypeOnly || node.exportClause !== exportClause || node.moduleSpecifier !== moduleSpecifier || node.attributes !== attributes ? finishUpdateExportDeclaration(createExportDeclaration(modifiers, isTypeOnly, exportClause, moduleSpecifier, attributes), node) : node; } function finishUpdateExportDeclaration(updated, original) { if (updated !== original) { @@ -121815,7 +104668,7 @@ ${lanes.join("\n")} return update(updated, original); } function createNamedExports(elements) { - const node = createBaseNode(278 /* NamedExports */); + const node = createBaseNode(279 /* NamedExports */); node.elements = createNodeArray(elements); node.transformFlags |= propagateChildrenFlags(node.elements); node.transformFlags &= ~67108864 /* ContainsPossibleTopLevelAwait */; @@ -121825,7 +104678,7 @@ ${lanes.join("\n")} return node.elements !== elements ? update(createNamedExports(elements), node) : node; } function createExportSpecifier(isTypeOnly, propertyName, name) { - const node = createBaseNode(280 /* ExportSpecifier */); + const node = createBaseNode(281 /* ExportSpecifier */); node.isTypeOnly = isTypeOnly; node.propertyName = asName(propertyName); node.name = asName(name); @@ -121838,12 +104691,12 @@ ${lanes.join("\n")} return node.isTypeOnly !== isTypeOnly || node.propertyName !== propertyName || node.name !== name ? update(createExportSpecifier(isTypeOnly, propertyName, name), node) : node; } function createMissingDeclaration() { - const node = createBaseDeclaration(281 /* MissingDeclaration */); + const node = createBaseDeclaration(282 /* MissingDeclaration */); node.jsDoc = void 0; return node; } function createExternalModuleReference(expression) { - const node = createBaseNode(282 /* ExternalModuleReference */); + const node = createBaseNode(283 /* ExternalModuleReference */); node.expression = expression; node.transformFlags |= propagateChildFlags(node.expression); node.transformFlags &= ~67108864 /* ContainsPossibleTopLevelAwait */; @@ -121875,7 +104728,7 @@ ${lanes.join("\n")} return node.type !== type ? update(createJSDocUnaryTypeWorker(kind, type), node) : node; } function createJSDocFunctionType(parameters, type) { - const node = createBaseDeclaration(323 /* JSDocFunctionType */); + const node = createBaseDeclaration(324 /* JSDocFunctionType */); node.parameters = asNodeArray(parameters); node.type = type; node.transformFlags = propagateChildrenFlags(node.parameters) | (node.type ? 1 /* ContainsTypeScript */ : 0 /* None */); @@ -121889,7 +104742,7 @@ ${lanes.join("\n")} return node.parameters !== parameters || node.type !== type ? update(createJSDocFunctionType(parameters, type), node) : node; } function createJSDocTypeLiteral(propertyTags, isArrayType = false) { - const node = createBaseDeclaration(328 /* JSDocTypeLiteral */); + const node = createBaseDeclaration(329 /* JSDocTypeLiteral */); node.jsDocPropertyTags = asNodeArray(propertyTags); node.isArrayType = isArrayType; return node; @@ -121898,7 +104751,7 @@ ${lanes.join("\n")} return node.jsDocPropertyTags !== propertyTags || node.isArrayType !== isArrayType ? update(createJSDocTypeLiteral(propertyTags, isArrayType), node) : node; } function createJSDocTypeExpression(type) { - const node = createBaseNode(315 /* JSDocTypeExpression */); + const node = createBaseNode(316 /* JSDocTypeExpression */); node.type = type; return node; } @@ -121906,7 +104759,7 @@ ${lanes.join("\n")} return node.type !== type ? update(createJSDocTypeExpression(type), node) : node; } function createJSDocSignature(typeParameters, parameters, type) { - const node = createBaseDeclaration(329 /* JSDocSignature */); + const node = createBaseDeclaration(330 /* JSDocSignature */); node.typeParameters = asNodeArray(typeParameters); node.parameters = createNodeArray(parameters); node.type = type; @@ -121935,7 +104788,7 @@ ${lanes.join("\n")} return node; } function createJSDocTemplateTag(tagName, constraint, typeParameters, comment) { - const node = createBaseJSDocTag(351 /* JSDocTemplateTag */, tagName ?? createIdentifier("template"), comment); + const node = createBaseJSDocTag(352 /* JSDocTemplateTag */, tagName ?? createIdentifier("template"), comment); node.constraint = constraint; node.typeParameters = createNodeArray(typeParameters); return node; @@ -121944,7 +104797,7 @@ ${lanes.join("\n")} return node.tagName !== tagName || node.constraint !== constraint || node.typeParameters !== typeParameters || node.comment !== comment ? update(createJSDocTemplateTag(tagName, constraint, typeParameters, comment), node) : node; } function createJSDocTypedefTag(tagName, typeExpression, fullName, comment) { - const node = createBaseJSDocTagDeclaration(352 /* JSDocTypedefTag */, tagName ?? createIdentifier("typedef"), comment); + const node = createBaseJSDocTagDeclaration(353 /* JSDocTypedefTag */, tagName ?? createIdentifier("typedef"), comment); node.typeExpression = typeExpression; node.fullName = fullName; node.name = getJSDocTypeAliasName(fullName); @@ -121956,7 +104809,7 @@ ${lanes.join("\n")} return node.tagName !== tagName || node.typeExpression !== typeExpression || node.fullName !== fullName || node.comment !== comment ? update(createJSDocTypedefTag(tagName, typeExpression, fullName, comment), node) : node; } function createJSDocParameterTag(tagName, name, isBracketed, typeExpression, isNameFirst, comment) { - const node = createBaseJSDocTagDeclaration(347 /* JSDocParameterTag */, tagName ?? createIdentifier("param"), comment); + const node = createBaseJSDocTagDeclaration(348 /* JSDocParameterTag */, tagName ?? createIdentifier("param"), comment); node.typeExpression = typeExpression; node.name = name; node.isNameFirst = !!isNameFirst; @@ -121967,7 +104820,7 @@ ${lanes.join("\n")} return node.tagName !== tagName || node.name !== name || node.isBracketed !== isBracketed || node.typeExpression !== typeExpression || node.isNameFirst !== isNameFirst || node.comment !== comment ? update(createJSDocParameterTag(tagName, name, isBracketed, typeExpression, isNameFirst, comment), node) : node; } function createJSDocPropertyTag(tagName, name, isBracketed, typeExpression, isNameFirst, comment) { - const node = createBaseJSDocTagDeclaration(354 /* JSDocPropertyTag */, tagName ?? createIdentifier("prop"), comment); + const node = createBaseJSDocTagDeclaration(355 /* JSDocPropertyTag */, tagName ?? createIdentifier("prop"), comment); node.typeExpression = typeExpression; node.name = name; node.isNameFirst = !!isNameFirst; @@ -121978,7 +104831,7 @@ ${lanes.join("\n")} return node.tagName !== tagName || node.name !== name || node.isBracketed !== isBracketed || node.typeExpression !== typeExpression || node.isNameFirst !== isNameFirst || node.comment !== comment ? update(createJSDocPropertyTag(tagName, name, isBracketed, typeExpression, isNameFirst, comment), node) : node; } function createJSDocCallbackTag(tagName, typeExpression, fullName, comment) { - const node = createBaseJSDocTagDeclaration(344 /* JSDocCallbackTag */, tagName ?? createIdentifier("callback"), comment); + const node = createBaseJSDocTagDeclaration(345 /* JSDocCallbackTag */, tagName ?? createIdentifier("callback"), comment); node.typeExpression = typeExpression; node.fullName = fullName; node.name = getJSDocTypeAliasName(fullName); @@ -121990,7 +104843,7 @@ ${lanes.join("\n")} return node.tagName !== tagName || node.typeExpression !== typeExpression || node.fullName !== fullName || node.comment !== comment ? update(createJSDocCallbackTag(tagName, typeExpression, fullName, comment), node) : node; } function createJSDocOverloadTag(tagName, typeExpression, comment) { - const node = createBaseJSDocTag(345 /* JSDocOverloadTag */, tagName ?? createIdentifier("overload"), comment); + const node = createBaseJSDocTag(346 /* JSDocOverloadTag */, tagName ?? createIdentifier("overload"), comment); node.typeExpression = typeExpression; return node; } @@ -121998,7 +104851,7 @@ ${lanes.join("\n")} return node.tagName !== tagName || node.typeExpression !== typeExpression || node.comment !== comment ? update(createJSDocOverloadTag(tagName, typeExpression, comment), node) : node; } function createJSDocAugmentsTag(tagName, className, comment) { - const node = createBaseJSDocTag(334 /* JSDocAugmentsTag */, tagName ?? createIdentifier("augments"), comment); + const node = createBaseJSDocTag(335 /* JSDocAugmentsTag */, tagName ?? createIdentifier("augments"), comment); node.class = className; return node; } @@ -122006,12 +104859,12 @@ ${lanes.join("\n")} return node.tagName !== tagName || node.class !== className || node.comment !== comment ? update(createJSDocAugmentsTag(tagName, className, comment), node) : node; } function createJSDocImplementsTag(tagName, className, comment) { - const node = createBaseJSDocTag(335 /* JSDocImplementsTag */, tagName ?? createIdentifier("implements"), comment); + const node = createBaseJSDocTag(336 /* JSDocImplementsTag */, tagName ?? createIdentifier("implements"), comment); node.class = className; return node; } function createJSDocSeeTag(tagName, name, comment) { - const node = createBaseJSDocTag(353 /* JSDocSeeTag */, tagName ?? createIdentifier("see"), comment); + const node = createBaseJSDocTag(354 /* JSDocSeeTag */, tagName ?? createIdentifier("see"), comment); node.name = name; return node; } @@ -122019,7 +104872,7 @@ ${lanes.join("\n")} return node.tagName !== tagName || node.name !== name || node.comment !== comment ? update(createJSDocSeeTag(tagName, name, comment), node) : node; } function createJSDocNameReference(name) { - const node = createBaseNode(316 /* JSDocNameReference */); + const node = createBaseNode(317 /* JSDocNameReference */); node.name = name; return node; } @@ -122027,7 +104880,7 @@ ${lanes.join("\n")} return node.name !== name ? update(createJSDocNameReference(name), node) : node; } function createJSDocMemberName(left, right) { - const node = createBaseNode(317 /* JSDocMemberName */); + const node = createBaseNode(318 /* JSDocMemberName */); node.left = left; node.right = right; node.transformFlags |= propagateChildFlags(node.left) | propagateChildFlags(node.right); @@ -122037,7 +104890,7 @@ ${lanes.join("\n")} return node.left !== left || node.right !== right ? update(createJSDocMemberName(left, right), node) : node; } function createJSDocLink(name, text) { - const node = createBaseNode(330 /* JSDocLink */); + const node = createBaseNode(331 /* JSDocLink */); node.name = name; node.text = text; return node; @@ -122046,7 +104899,7 @@ ${lanes.join("\n")} return node.name !== name ? update(createJSDocLink(name, text), node) : node; } function createJSDocLinkCode(name, text) { - const node = createBaseNode(331 /* JSDocLinkCode */); + const node = createBaseNode(332 /* JSDocLinkCode */); node.name = name; node.text = text; return node; @@ -122055,7 +104908,7 @@ ${lanes.join("\n")} return node.name !== name ? update(createJSDocLinkCode(name, text), node) : node; } function createJSDocLinkPlain(name, text) { - const node = createBaseNode(332 /* JSDocLinkPlain */); + const node = createBaseNode(333 /* JSDocLinkPlain */); node.name = name; node.text = text; return node; @@ -122082,14 +104935,14 @@ ${lanes.join("\n")} return node.tagName !== tagName || node.typeExpression !== typeExpression || node.comment !== comment ? update(createJSDocTypeLikeTagWorker(kind, tagName, typeExpression, comment), node) : node; } function createJSDocUnknownTag(tagName, comment) { - const node = createBaseJSDocTag(333 /* JSDocTag */, tagName, comment); + const node = createBaseJSDocTag(334 /* JSDocTag */, tagName, comment); return node; } function updateJSDocUnknownTag(node, tagName, comment) { return node.tagName !== tagName || node.comment !== comment ? update(createJSDocUnknownTag(tagName, comment), node) : node; } function createJSDocEnumTag(tagName, typeExpression, comment) { - const node = createBaseJSDocTagDeclaration(346 /* JSDocEnumTag */, tagName ?? createIdentifier(getDefaultTagNameForKind(346 /* JSDocEnumTag */)), comment); + const node = createBaseJSDocTagDeclaration(347 /* JSDocEnumTag */, tagName ?? createIdentifier(getDefaultTagNameForKind(347 /* JSDocEnumTag */)), comment); node.typeExpression = typeExpression; node.locals = void 0; node.nextContainer = void 0; @@ -122099,7 +104952,7 @@ ${lanes.join("\n")} return node.tagName !== tagName || node.typeExpression !== typeExpression || node.comment !== comment ? update(createJSDocEnumTag(tagName, typeExpression, comment), node) : node; } function createJSDocText(text) { - const node = createBaseNode(327 /* JSDocText */); + const node = createBaseNode(328 /* JSDocText */); node.text = text; return node; } @@ -122107,7 +104960,7 @@ ${lanes.join("\n")} return node.text !== text ? update(createJSDocText(text), node) : node; } function createJSDocComment(comment, tags) { - const node = createBaseNode(326 /* JSDoc */); + const node = createBaseNode(327 /* JSDoc */); node.comment = comment; node.tags = asNodeArray(tags); return node; @@ -122116,7 +104969,7 @@ ${lanes.join("\n")} return node.comment !== comment || node.tags !== tags ? update(createJSDocComment(comment, tags), node) : node; } function createJsxElement(openingElement, children, closingElement) { - const node = createBaseNode(283 /* JsxElement */); + const node = createBaseNode(284 /* JsxElement */); node.openingElement = openingElement; node.children = createNodeArray(children); node.closingElement = closingElement; @@ -122127,7 +104980,7 @@ ${lanes.join("\n")} return node.openingElement !== openingElement || node.children !== children || node.closingElement !== closingElement ? update(createJsxElement(openingElement, children, closingElement), node) : node; } function createJsxSelfClosingElement(tagName, typeArguments, attributes) { - const node = createBaseNode(284 /* JsxSelfClosingElement */); + const node = createBaseNode(285 /* JsxSelfClosingElement */); node.tagName = tagName; node.typeArguments = asNodeArray(typeArguments); node.attributes = attributes; @@ -122141,7 +104994,7 @@ ${lanes.join("\n")} return node.tagName !== tagName || node.typeArguments !== typeArguments || node.attributes !== attributes ? update(createJsxSelfClosingElement(tagName, typeArguments, attributes), node) : node; } function createJsxOpeningElement(tagName, typeArguments, attributes) { - const node = createBaseNode(285 /* JsxOpeningElement */); + const node = createBaseNode(286 /* JsxOpeningElement */); node.tagName = tagName; node.typeArguments = asNodeArray(typeArguments); node.attributes = attributes; @@ -122155,7 +105008,7 @@ ${lanes.join("\n")} return node.tagName !== tagName || node.typeArguments !== typeArguments || node.attributes !== attributes ? update(createJsxOpeningElement(tagName, typeArguments, attributes), node) : node; } function createJsxClosingElement(tagName) { - const node = createBaseNode(286 /* JsxClosingElement */); + const node = createBaseNode(287 /* JsxClosingElement */); node.tagName = tagName; node.transformFlags |= propagateChildFlags(node.tagName) | 2 /* ContainsJsx */; return node; @@ -122164,7 +105017,7 @@ ${lanes.join("\n")} return node.tagName !== tagName ? update(createJsxClosingElement(tagName), node) : node; } function createJsxFragment(openingFragment, children, closingFragment) { - const node = createBaseNode(287 /* JsxFragment */); + const node = createBaseNode(288 /* JsxFragment */); node.openingFragment = openingFragment; node.children = createNodeArray(children); node.closingFragment = closingFragment; @@ -122185,17 +105038,17 @@ ${lanes.join("\n")} return node.text !== text || node.containsOnlyTriviaWhiteSpaces !== containsOnlyTriviaWhiteSpaces ? update(createJsxText(text, containsOnlyTriviaWhiteSpaces), node) : node; } function createJsxOpeningFragment() { - const node = createBaseNode(288 /* JsxOpeningFragment */); + const node = createBaseNode(289 /* JsxOpeningFragment */); node.transformFlags |= 2 /* ContainsJsx */; return node; } function createJsxJsxClosingFragment() { - const node = createBaseNode(289 /* JsxClosingFragment */); + const node = createBaseNode(290 /* JsxClosingFragment */); node.transformFlags |= 2 /* ContainsJsx */; return node; } function createJsxAttribute(name, initializer) { - const node = createBaseDeclaration(290 /* JsxAttribute */); + const node = createBaseDeclaration(291 /* JsxAttribute */); node.name = name; node.initializer = initializer; node.transformFlags |= propagateChildFlags(node.name) | propagateChildFlags(node.initializer) | 2 /* ContainsJsx */; @@ -122205,7 +105058,7 @@ ${lanes.join("\n")} return node.name !== name || node.initializer !== initializer ? update(createJsxAttribute(name, initializer), node) : node; } function createJsxAttributes(properties) { - const node = createBaseDeclaration(291 /* JsxAttributes */); + const node = createBaseDeclaration(292 /* JsxAttributes */); node.properties = createNodeArray(properties); node.transformFlags |= propagateChildrenFlags(node.properties) | 2 /* ContainsJsx */; return node; @@ -122214,7 +105067,7 @@ ${lanes.join("\n")} return node.properties !== properties ? update(createJsxAttributes(properties), node) : node; } function createJsxSpreadAttribute(expression) { - const node = createBaseNode(292 /* JsxSpreadAttribute */); + const node = createBaseNode(293 /* JsxSpreadAttribute */); node.expression = expression; node.transformFlags |= propagateChildFlags(node.expression) | 2 /* ContainsJsx */; return node; @@ -122223,7 +105076,7 @@ ${lanes.join("\n")} return node.expression !== expression ? update(createJsxSpreadAttribute(expression), node) : node; } function createJsxExpression(dotDotDotToken, expression) { - const node = createBaseNode(293 /* JsxExpression */); + const node = createBaseNode(294 /* JsxExpression */); node.dotDotDotToken = dotDotDotToken; node.expression = expression; node.transformFlags |= propagateChildFlags(node.dotDotDotToken) | propagateChildFlags(node.expression) | 2 /* ContainsJsx */; @@ -122233,7 +105086,7 @@ ${lanes.join("\n")} return node.expression !== expression ? update(createJsxExpression(node.dotDotDotToken, expression), node) : node; } function createJsxNamespacedName(namespace, name) { - const node = createBaseNode(294 /* JsxNamespacedName */); + const node = createBaseNode(295 /* JsxNamespacedName */); node.namespace = namespace; node.name = name; node.transformFlags |= propagateChildFlags(node.namespace) | propagateChildFlags(node.name) | 2 /* ContainsJsx */; @@ -122243,7 +105096,7 @@ ${lanes.join("\n")} return node.namespace !== namespace || node.name !== name ? update(createJsxNamespacedName(namespace, name), node) : node; } function createCaseClause(expression, statements) { - const node = createBaseNode(295 /* CaseClause */); + const node = createBaseNode(296 /* CaseClause */); node.expression = parenthesizerRules().parenthesizeExpressionForDisallowedComma(expression); node.statements = createNodeArray(statements); node.transformFlags |= propagateChildFlags(node.expression) | propagateChildrenFlags(node.statements); @@ -122254,7 +105107,7 @@ ${lanes.join("\n")} return node.expression !== expression || node.statements !== statements ? update(createCaseClause(expression, statements), node) : node; } function createDefaultClause(statements) { - const node = createBaseNode(296 /* DefaultClause */); + const node = createBaseNode(297 /* DefaultClause */); node.statements = createNodeArray(statements); node.transformFlags = propagateChildrenFlags(node.statements); return node; @@ -122263,7 +105116,7 @@ ${lanes.join("\n")} return node.statements !== statements ? update(createDefaultClause(statements), node) : node; } function createHeritageClause(token, types) { - const node = createBaseNode(297 /* HeritageClause */); + const node = createBaseNode(298 /* HeritageClause */); node.token = token; node.types = createNodeArray(types); node.transformFlags |= propagateChildrenFlags(node.types); @@ -122283,7 +105136,7 @@ ${lanes.join("\n")} return node.types !== types ? update(createHeritageClause(node.token, types), node) : node; } function createCatchClause(variableDeclaration, block) { - const node = createBaseNode(298 /* CatchClause */); + const node = createBaseNode(299 /* CatchClause */); node.variableDeclaration = asVariableDeclaration(variableDeclaration); node.block = block; node.transformFlags |= propagateChildFlags(node.variableDeclaration) | propagateChildFlags(node.block) | (!variableDeclaration ? 64 /* ContainsES2019 */ : 0 /* None */); @@ -122295,7 +105148,7 @@ ${lanes.join("\n")} return node.variableDeclaration !== variableDeclaration || node.block !== block ? update(createCatchClause(variableDeclaration, block), node) : node; } function createPropertyAssignment(name, initializer) { - const node = createBaseDeclaration(302 /* PropertyAssignment */); + const node = createBaseDeclaration(303 /* PropertyAssignment */); node.name = asName(name); node.initializer = parenthesizerRules().parenthesizeExpressionForDisallowedComma(initializer); node.transformFlags |= propagateNameFlags(node.name) | propagateChildFlags(node.initializer); @@ -122317,7 +105170,7 @@ ${lanes.join("\n")} return update(updated, original); } function createShorthandPropertyAssignment(name, objectAssignmentInitializer) { - const node = createBaseDeclaration(303 /* ShorthandPropertyAssignment */); + const node = createBaseDeclaration(304 /* ShorthandPropertyAssignment */); node.name = asName(name); node.objectAssignmentInitializer = objectAssignmentInitializer && parenthesizerRules().parenthesizeExpressionForDisallowedComma(objectAssignmentInitializer); node.transformFlags |= propagateIdentifierNameFlags(node.name) | propagateChildFlags(node.objectAssignmentInitializer) | 1024 /* ContainsES2015 */; @@ -122341,7 +105194,7 @@ ${lanes.join("\n")} return update(updated, original); } function createSpreadAssignment(expression) { - const node = createBaseDeclaration(304 /* SpreadAssignment */); + const node = createBaseDeclaration(305 /* SpreadAssignment */); node.expression = parenthesizerRules().parenthesizeExpressionForDisallowedComma(expression); node.transformFlags |= propagateChildFlags(node.expression) | 128 /* ContainsES2018 */ | 65536 /* ContainsObjectRestOrSpread */; node.jsDoc = void 0; @@ -122351,7 +105204,7 @@ ${lanes.join("\n")} return node.expression !== expression ? update(createSpreadAssignment(expression), node) : node; } function createEnumMember(name, initializer) { - const node = createBaseDeclaration(305 /* EnumMember */); + const node = createBaseDeclaration(306 /* EnumMember */); node.name = asName(name); node.initializer = initializer && parenthesizerRules().parenthesizeExpressionForDisallowedComma(initializer); node.transformFlags |= propagateChildFlags(node.name) | propagateChildFlags(node.initializer) | 1 /* ContainsTypeScript */; @@ -122362,7 +105215,7 @@ ${lanes.join("\n")} return node.name !== name || node.initializer !== initializer ? update(createEnumMember(name, initializer), node) : node; } function createSourceFile2(statements, endOfFileToken, flags2) { - const node = baseFactory2.createBaseSourceFileNode(311 /* SourceFile */); + const node = baseFactory2.createBaseSourceFileNode(312 /* SourceFile */); node.statements = createNodeArray(statements); node.endOfFileToken = endOfFileToken; node.flags |= flags2; @@ -122402,7 +105255,6 @@ ${lanes.join("\n")} node.imports = void 0; node.moduleAugmentations = void 0; node.ambientModuleNames = void 0; - node.resolvedModules = void 0; node.classifiableNames = void 0; node.impliedNodeFormat = void 0; return node; @@ -122432,7 +105284,7 @@ ${lanes.join("\n")} } function cloneRedirectedSourceFile(source) { const node = createRedirectedSourceFile(source.redirectInfo); - node.flags |= source.flags & ~8 /* Synthesized */; + node.flags |= source.flags & ~16 /* Synthesized */; node.fileName = source.fileName; node.path = source.path; node.resolvedPath = source.resolvedPath; @@ -122443,8 +105295,8 @@ ${lanes.join("\n")} return node; } function cloneSourceFileWorker(source) { - const node = baseFactory2.createBaseSourceFileNode(311 /* SourceFile */); - node.flags |= source.flags & ~8 /* Synthesized */; + const node = baseFactory2.createBaseSourceFileNode(312 /* SourceFile */); + node.flags |= source.flags & ~16 /* Synthesized */; for (const p in source) { if (hasProperty(node, p) || !hasProperty(source, p)) { continue; @@ -122477,7 +105329,7 @@ ${lanes.join("\n")} return node.statements !== statements || node.isDeclarationFile !== isDeclarationFile || node.referencedFiles !== referencedFiles || node.typeReferenceDirectives !== typeReferenceDirectives || node.hasNoDefaultLib !== hasNoDefaultLib || node.libReferenceDirectives !== libReferenceDirectives ? update(cloneSourceFileWithChanges(node, statements, isDeclarationFile, referencedFiles, typeReferenceDirectives, hasNoDefaultLib, libReferenceDirectives), node) : node; } function createBundle(sourceFiles, prepends = emptyArray) { - const node = createBaseNode(312 /* Bundle */); + const node = createBaseNode(313 /* Bundle */); node.prepends = prepends; node.sourceFiles = sourceFiles; node.syntheticFileReferences = void 0; @@ -122490,7 +105342,7 @@ ${lanes.join("\n")} return node.sourceFiles !== sourceFiles || node.prepends !== prepends ? update(createBundle(sourceFiles, prepends), node) : node; } function createUnparsedSource(prologues, syntheticReferences, texts) { - const node = createBaseNode(313 /* UnparsedSource */); + const node = createBaseNode(314 /* UnparsedSource */); node.prologues = prologues; node.syntheticReferences = syntheticReferences; node.texts = texts; @@ -122507,48 +105359,48 @@ ${lanes.join("\n")} return node; } function createUnparsedPrologue(data) { - return createBaseUnparsedNode(306 /* UnparsedPrologue */, data); + return createBaseUnparsedNode(307 /* UnparsedPrologue */, data); } function createUnparsedPrepend(data, texts) { - const node = createBaseUnparsedNode(307 /* UnparsedPrepend */, data); + const node = createBaseUnparsedNode(308 /* UnparsedPrepend */, data); node.texts = texts; return node; } function createUnparsedTextLike(data, internal) { - return createBaseUnparsedNode(internal ? 309 /* UnparsedInternalText */ : 308 /* UnparsedText */, data); + return createBaseUnparsedNode(internal ? 310 /* UnparsedInternalText */ : 309 /* UnparsedText */, data); } function createUnparsedSyntheticReference(section) { - const node = createBaseNode(310 /* UnparsedSyntheticReference */); + const node = createBaseNode(311 /* UnparsedSyntheticReference */); node.data = section.data; node.section = section; return node; } function createInputFiles2() { - const node = createBaseNode(314 /* InputFiles */); + const node = createBaseNode(315 /* InputFiles */); node.javascriptText = ""; node.declarationText = ""; return node; } function createSyntheticExpression(type, isSpread = false, tupleNameSource) { - const node = createBaseNode(236 /* SyntheticExpression */); + const node = createBaseNode(237 /* SyntheticExpression */); node.type = type; node.isSpread = isSpread; node.tupleNameSource = tupleNameSource; return node; } function createSyntaxList3(children) { - const node = createBaseNode(357 /* SyntaxList */); + const node = createBaseNode(358 /* SyntaxList */); node._children = children; return node; } function createNotEmittedStatement(original) { - const node = createBaseNode(358 /* NotEmittedStatement */); + const node = createBaseNode(359 /* NotEmittedStatement */); node.original = original; setTextRange(node, original); return node; } function createPartiallyEmittedExpression(expression, original) { - const node = createBaseNode(359 /* PartiallyEmittedExpression */); + const node = createBaseNode(360 /* PartiallyEmittedExpression */); node.expression = expression; node.original = original; node.transformFlags |= propagateChildFlags(node.expression) | 1 /* ContainsTypeScript */; @@ -122570,7 +105422,7 @@ ${lanes.join("\n")} return node; } function createCommaListExpression(elements) { - const node = createBaseNode(360 /* CommaListExpression */); + const node = createBaseNode(361 /* CommaListExpression */); node.elements = createNodeArray(sameFlatMap(elements, flattenCommaElements)); node.transformFlags |= propagateChildrenFlags(node.elements); return node; @@ -122579,7 +105431,7 @@ ${lanes.join("\n")} return node.elements !== elements ? update(createCommaListExpression(elements), node) : node; } function createSyntheticReferenceExpression(expression, thisArg) { - const node = createBaseNode(361 /* SyntheticReferenceExpression */); + const node = createBaseNode(362 /* SyntheticReferenceExpression */); node.expression = expression; node.thisArg = thisArg; node.transformFlags |= propagateChildFlags(node.expression) | propagateChildFlags(node.thisArg); @@ -122590,7 +105442,7 @@ ${lanes.join("\n")} } function cloneGeneratedIdentifier(node) { const clone2 = createBaseIdentifier(node.escapedText); - clone2.flags |= node.flags & ~8 /* Synthesized */; + clone2.flags |= node.flags & ~16 /* Synthesized */; clone2.transformFlags = node.transformFlags; setOriginalNode(clone2, node); setIdentifierAutoGenerate(clone2, { ...node.emitNode.autoGenerate }); @@ -122598,7 +105450,7 @@ ${lanes.join("\n")} } function cloneIdentifier(node) { const clone2 = createBaseIdentifier(node.escapedText); - clone2.flags |= node.flags & ~8 /* Synthesized */; + clone2.flags |= node.flags & ~16 /* Synthesized */; clone2.jsDoc = node.jsDoc; clone2.flowNode = node.flowNode; clone2.symbol = node.symbol; @@ -122611,7 +105463,7 @@ ${lanes.join("\n")} } function cloneGeneratedPrivateIdentifier(node) { const clone2 = createBasePrivateIdentifier(node.escapedText); - clone2.flags |= node.flags & ~8 /* Synthesized */; + clone2.flags |= node.flags & ~16 /* Synthesized */; clone2.transformFlags = node.transformFlags; setOriginalNode(clone2, node); setIdentifierAutoGenerate(clone2, { ...node.emitNode.autoGenerate }); @@ -122619,7 +105471,7 @@ ${lanes.join("\n")} } function clonePrivateIdentifier(node) { const clone2 = createBasePrivateIdentifier(node.escapedText); - clone2.flags |= node.flags & ~8 /* Synthesized */; + clone2.flags |= node.flags & ~16 /* Synthesized */; clone2.transformFlags = node.transformFlags; setOriginalNode(clone2, node); return clone2; @@ -122644,7 +105496,7 @@ ${lanes.join("\n")} return clonePrivateIdentifier(node); } const clone2 = !isNodeKind(node.kind) ? baseFactory2.createBaseTokenNode(node.kind) : baseFactory2.createBaseNode(node.kind); - clone2.flags |= node.flags & ~8 /* Synthesized */; + clone2.flags |= node.flags & ~16 /* Synthesized */; clone2.transformFlags = node.transformFlags; setOriginalNode(clone2, node); for (const key in node) { @@ -122737,7 +105589,10 @@ ${lanes.join("\n")} ); } function createTypeCheck(value, tag) { - return tag === "undefined" ? factory2.createStrictEquality(value, createVoidZero()) : factory2.createStrictEquality(createTypeOfExpression(value), createStringLiteral(tag)); + return tag === "null" ? factory2.createStrictEquality(value, createNull()) : tag === "undefined" ? factory2.createStrictEquality(value, createVoidZero()) : factory2.createStrictEquality(createTypeOfExpression(value), createStringLiteral(tag)); + } + function createIsNotTypeCheck(value, tag) { + return tag === "null" ? factory2.createStrictInequality(value, createNull()) : tag === "undefined" ? factory2.createStrictInequality(value, createVoidZero()) : factory2.createStrictInequality(createTypeOfExpression(value), createStringLiteral(tag)); } function createMethodCall(object, methodName, argumentsList) { if (isCallChain(object)) { @@ -122812,17 +105667,17 @@ ${lanes.join("\n")} } function updateOuterExpression(outerExpression, expression) { switch (outerExpression.kind) { - case 216 /* ParenthesizedExpression */: + case 217 /* ParenthesizedExpression */: return updateParenthesizedExpression(outerExpression, expression); - case 215 /* TypeAssertionExpression */: + case 216 /* TypeAssertionExpression */: return updateTypeAssertion(outerExpression, outerExpression.type, expression); - case 233 /* AsExpression */: + case 234 /* AsExpression */: return updateAsExpression(outerExpression, expression, outerExpression.type); - case 237 /* SatisfiesExpression */: + case 238 /* SatisfiesExpression */: return updateSatisfiesExpression(outerExpression, expression, outerExpression.type); - case 234 /* NonNullExpression */: + case 235 /* NonNullExpression */: return updateNonNullExpression(outerExpression, expression); - case 359 /* PartiallyEmittedExpression */: + case 360 /* PartiallyEmittedExpression */: return updatePartiallyEmittedExpression(outerExpression, expression); } } @@ -122862,13 +105717,13 @@ ${lanes.join("\n")} case 10 /* BigIntLiteral */: case 11 /* StringLiteral */: return false; - case 208 /* ArrayLiteralExpression */: + case 209 /* ArrayLiteralExpression */: const elements = target.elements; if (elements.length === 0) { return false; } return true; - case 209 /* ObjectLiteralExpression */: + case 210 /* ObjectLiteralExpression */: return target.properties.length > 0; default: return true; @@ -123011,7 +105866,7 @@ ${lanes.join("\n")} return qualifiedName; } function getExternalModuleOrNamespaceExportName(ns, node, allowComments, allowSourceMaps) { - if (ns && hasSyntacticModifier(node, 1 /* Export */)) { + if (ns && hasSyntacticModifier(node, 32 /* Export */)) { return getNamespaceMemberName(ns, getName(node), allowComments, allowSourceMaps); } return getExportName(node, allowComments, allowSourceMaps); @@ -123122,14 +105977,35 @@ ${lanes.join("\n")} } return statements; } - function updateModifiers(node, modifiers) { + function replaceModifiers(node, modifiers) { let modifierArray; if (typeof modifiers === "number") { modifierArray = createModifiersFromModifierFlags(modifiers); } else { modifierArray = modifiers; } - return isTypeParameterDeclaration(node) ? updateTypeParameterDeclaration(node, modifierArray, node.name, node.constraint, node.default) : isParameter(node) ? updateParameterDeclaration(node, modifierArray, node.dotDotDotToken, node.name, node.questionToken, node.type, node.initializer) : isConstructorTypeNode(node) ? updateConstructorTypeNode1(node, modifierArray, node.typeParameters, node.parameters, node.type) : isPropertySignature(node) ? updatePropertySignature(node, modifierArray, node.name, node.questionToken, node.type) : isPropertyDeclaration(node) ? updatePropertyDeclaration2(node, modifierArray, node.name, node.questionToken ?? node.exclamationToken, node.type, node.initializer) : isMethodSignature(node) ? updateMethodSignature(node, modifierArray, node.name, node.questionToken, node.typeParameters, node.parameters, node.type) : isMethodDeclaration(node) ? updateMethodDeclaration(node, modifierArray, node.asteriskToken, node.name, node.questionToken, node.typeParameters, node.parameters, node.type, node.body) : isConstructorDeclaration(node) ? updateConstructorDeclaration(node, modifierArray, node.parameters, node.body) : isGetAccessorDeclaration(node) ? updateGetAccessorDeclaration(node, modifierArray, node.name, node.parameters, node.type, node.body) : isSetAccessorDeclaration(node) ? updateSetAccessorDeclaration(node, modifierArray, node.name, node.parameters, node.body) : isIndexSignatureDeclaration(node) ? updateIndexSignature(node, modifierArray, node.parameters, node.type) : isFunctionExpression(node) ? updateFunctionExpression(node, modifierArray, node.asteriskToken, node.name, node.typeParameters, node.parameters, node.type, node.body) : isArrowFunction(node) ? updateArrowFunction(node, modifierArray, node.typeParameters, node.parameters, node.type, node.equalsGreaterThanToken, node.body) : isClassExpression(node) ? updateClassExpression(node, modifierArray, node.name, node.typeParameters, node.heritageClauses, node.members) : isVariableStatement(node) ? updateVariableStatement(node, modifierArray, node.declarationList) : isFunctionDeclaration(node) ? updateFunctionDeclaration(node, modifierArray, node.asteriskToken, node.name, node.typeParameters, node.parameters, node.type, node.body) : isClassDeclaration(node) ? updateClassDeclaration(node, modifierArray, node.name, node.typeParameters, node.heritageClauses, node.members) : isInterfaceDeclaration(node) ? updateInterfaceDeclaration(node, modifierArray, node.name, node.typeParameters, node.heritageClauses, node.members) : isTypeAliasDeclaration(node) ? updateTypeAliasDeclaration(node, modifierArray, node.name, node.typeParameters, node.type) : isEnumDeclaration(node) ? updateEnumDeclaration(node, modifierArray, node.name, node.members) : isModuleDeclaration(node) ? updateModuleDeclaration(node, modifierArray, node.name, node.body) : isImportEqualsDeclaration(node) ? updateImportEqualsDeclaration(node, modifierArray, node.isTypeOnly, node.name, node.moduleReference) : isImportDeclaration(node) ? updateImportDeclaration(node, modifierArray, node.importClause, node.moduleSpecifier, node.assertClause) : isExportAssignment(node) ? updateExportAssignment(node, modifierArray, node.expression) : isExportDeclaration(node) ? updateExportDeclaration(node, modifierArray, node.isTypeOnly, node.exportClause, node.moduleSpecifier, node.assertClause) : Debug.assertNever(node); + return isTypeParameterDeclaration(node) ? updateTypeParameterDeclaration(node, modifierArray, node.name, node.constraint, node.default) : isParameter(node) ? updateParameterDeclaration(node, modifierArray, node.dotDotDotToken, node.name, node.questionToken, node.type, node.initializer) : isConstructorTypeNode(node) ? updateConstructorTypeNode1(node, modifierArray, node.typeParameters, node.parameters, node.type) : isPropertySignature(node) ? updatePropertySignature(node, modifierArray, node.name, node.questionToken, node.type) : isPropertyDeclaration(node) ? updatePropertyDeclaration2(node, modifierArray, node.name, node.questionToken ?? node.exclamationToken, node.type, node.initializer) : isMethodSignature(node) ? updateMethodSignature(node, modifierArray, node.name, node.questionToken, node.typeParameters, node.parameters, node.type) : isMethodDeclaration(node) ? updateMethodDeclaration(node, modifierArray, node.asteriskToken, node.name, node.questionToken, node.typeParameters, node.parameters, node.type, node.body) : isConstructorDeclaration(node) ? updateConstructorDeclaration(node, modifierArray, node.parameters, node.body) : isGetAccessorDeclaration(node) ? updateGetAccessorDeclaration(node, modifierArray, node.name, node.parameters, node.type, node.body) : isSetAccessorDeclaration(node) ? updateSetAccessorDeclaration(node, modifierArray, node.name, node.parameters, node.body) : isIndexSignatureDeclaration(node) ? updateIndexSignature(node, modifierArray, node.parameters, node.type) : isFunctionExpression(node) ? updateFunctionExpression(node, modifierArray, node.asteriskToken, node.name, node.typeParameters, node.parameters, node.type, node.body) : isArrowFunction(node) ? updateArrowFunction(node, modifierArray, node.typeParameters, node.parameters, node.type, node.equalsGreaterThanToken, node.body) : isClassExpression(node) ? updateClassExpression(node, modifierArray, node.name, node.typeParameters, node.heritageClauses, node.members) : isVariableStatement(node) ? updateVariableStatement(node, modifierArray, node.declarationList) : isFunctionDeclaration(node) ? updateFunctionDeclaration(node, modifierArray, node.asteriskToken, node.name, node.typeParameters, node.parameters, node.type, node.body) : isClassDeclaration(node) ? updateClassDeclaration(node, modifierArray, node.name, node.typeParameters, node.heritageClauses, node.members) : isInterfaceDeclaration(node) ? updateInterfaceDeclaration(node, modifierArray, node.name, node.typeParameters, node.heritageClauses, node.members) : isTypeAliasDeclaration(node) ? updateTypeAliasDeclaration(node, modifierArray, node.name, node.typeParameters, node.type) : isEnumDeclaration(node) ? updateEnumDeclaration(node, modifierArray, node.name, node.members) : isModuleDeclaration(node) ? updateModuleDeclaration(node, modifierArray, node.name, node.body) : isImportEqualsDeclaration(node) ? updateImportEqualsDeclaration(node, modifierArray, node.isTypeOnly, node.name, node.moduleReference) : isImportDeclaration(node) ? updateImportDeclaration(node, modifierArray, node.importClause, node.moduleSpecifier, node.attributes) : isExportAssignment(node) ? updateExportAssignment(node, modifierArray, node.expression) : isExportDeclaration(node) ? updateExportDeclaration(node, modifierArray, node.isTypeOnly, node.exportClause, node.moduleSpecifier, node.attributes) : Debug.assertNever(node); + } + function replaceDecoratorsAndModifiers(node, modifierArray) { + return isParameter(node) ? updateParameterDeclaration(node, modifierArray, node.dotDotDotToken, node.name, node.questionToken, node.type, node.initializer) : isPropertyDeclaration(node) ? updatePropertyDeclaration2(node, modifierArray, node.name, node.questionToken ?? node.exclamationToken, node.type, node.initializer) : isMethodDeclaration(node) ? updateMethodDeclaration(node, modifierArray, node.asteriskToken, node.name, node.questionToken, node.typeParameters, node.parameters, node.type, node.body) : isGetAccessorDeclaration(node) ? updateGetAccessorDeclaration(node, modifierArray, node.name, node.parameters, node.type, node.body) : isSetAccessorDeclaration(node) ? updateSetAccessorDeclaration(node, modifierArray, node.name, node.parameters, node.body) : isClassExpression(node) ? updateClassExpression(node, modifierArray, node.name, node.typeParameters, node.heritageClauses, node.members) : isClassDeclaration(node) ? updateClassDeclaration(node, modifierArray, node.name, node.typeParameters, node.heritageClauses, node.members) : Debug.assertNever(node); + } + function replacePropertyName(node, name) { + switch (node.kind) { + case 177 /* GetAccessor */: + return updateGetAccessorDeclaration(node, node.modifiers, name, node.parameters, node.type, node.body); + case 178 /* SetAccessor */: + return updateSetAccessorDeclaration(node, node.modifiers, name, node.parameters, node.body); + case 174 /* MethodDeclaration */: + return updateMethodDeclaration(node, node.modifiers, node.asteriskToken, name, node.questionToken, node.typeParameters, node.parameters, node.type, node.body); + case 173 /* MethodSignature */: + return updateMethodSignature(node, node.modifiers, name, node.questionToken, node.typeParameters, node.parameters, node.type); + case 172 /* PropertyDeclaration */: + return updatePropertyDeclaration2(node, node.modifiers, name, node.questionToken ?? node.exclamationToken, node.type, node.initializer); + case 171 /* PropertySignature */: + return updatePropertySignature(node, node.modifiers, name, node.questionToken, node.type); + case 303 /* PropertyAssignment */: + return updatePropertyAssignment(node, name, node.initializer); + } } function asNodeArray(array) { return array ? createNodeArray(array) : void 0; @@ -123179,43 +106055,43 @@ ${lanes.join("\n")} } function getDefaultTagNameForKind(kind) { switch (kind) { - case 350 /* JSDocTypeTag */: + case 351 /* JSDocTypeTag */: return "type"; - case 348 /* JSDocReturnTag */: + case 349 /* JSDocReturnTag */: return "returns"; - case 349 /* JSDocThisTag */: + case 350 /* JSDocThisTag */: return "this"; - case 346 /* JSDocEnumTag */: + case 347 /* JSDocEnumTag */: return "enum"; - case 336 /* JSDocAuthorTag */: + case 337 /* JSDocAuthorTag */: return "author"; - case 338 /* JSDocClassTag */: + case 339 /* JSDocClassTag */: return "class"; - case 339 /* JSDocPublicTag */: + case 340 /* JSDocPublicTag */: return "public"; - case 340 /* JSDocPrivateTag */: + case 341 /* JSDocPrivateTag */: return "private"; - case 341 /* JSDocProtectedTag */: + case 342 /* JSDocProtectedTag */: return "protected"; - case 342 /* JSDocReadonlyTag */: + case 343 /* JSDocReadonlyTag */: return "readonly"; - case 343 /* JSDocOverrideTag */: + case 344 /* JSDocOverrideTag */: return "override"; - case 351 /* JSDocTemplateTag */: + case 352 /* JSDocTemplateTag */: return "template"; - case 352 /* JSDocTypedefTag */: + case 353 /* JSDocTypedefTag */: return "typedef"; - case 347 /* JSDocParameterTag */: + case 348 /* JSDocParameterTag */: return "param"; - case 354 /* JSDocPropertyTag */: + case 355 /* JSDocPropertyTag */: return "prop"; - case 344 /* JSDocCallbackTag */: + case 345 /* JSDocCallbackTag */: return "callback"; - case 345 /* JSDocOverloadTag */: + case 346 /* JSDocOverloadTag */: return "overload"; - case 334 /* JSDocAugmentsTag */: + case 335 /* JSDocAugmentsTag */: return "augments"; - case 335 /* JSDocImplementsTag */: + case 336 /* JSDocImplementsTag */: return "implements"; default: return Debug.fail(`Unsupported kind: ${Debug.formatSyntaxKind(kind)}`); @@ -123297,77 +106173,77 @@ ${lanes.join("\n")} children.transformFlags = subtreeFlags; } function getTransformFlagsSubtreeExclusions(kind) { - if (kind >= 181 /* FirstTypeNode */ && kind <= 204 /* LastTypeNode */) { + if (kind >= 182 /* FirstTypeNode */ && kind <= 205 /* LastTypeNode */) { return -2 /* TypeExcludes */; } switch (kind) { - case 212 /* CallExpression */: - case 213 /* NewExpression */: - case 208 /* ArrayLiteralExpression */: + case 213 /* CallExpression */: + case 214 /* NewExpression */: + case 209 /* ArrayLiteralExpression */: return -2147450880 /* ArrayLiteralOrCallOrNewExcludes */; - case 266 /* ModuleDeclaration */: + case 267 /* ModuleDeclaration */: return -1941676032 /* ModuleExcludes */; - case 168 /* Parameter */: + case 169 /* Parameter */: return -2147483648 /* ParameterExcludes */; - case 218 /* ArrowFunction */: + case 219 /* ArrowFunction */: return -2072174592 /* ArrowFunctionExcludes */; - case 217 /* FunctionExpression */: - case 261 /* FunctionDeclaration */: + case 218 /* FunctionExpression */: + case 262 /* FunctionDeclaration */: return -1937940480 /* FunctionExcludes */; - case 260 /* VariableDeclarationList */: + case 261 /* VariableDeclarationList */: return -2146893824 /* VariableDeclarationListExcludes */; - case 262 /* ClassDeclaration */: - case 230 /* ClassExpression */: + case 263 /* ClassDeclaration */: + case 231 /* ClassExpression */: return -2147344384 /* ClassExcludes */; - case 175 /* Constructor */: + case 176 /* Constructor */: return -1937948672 /* ConstructorExcludes */; - case 171 /* PropertyDeclaration */: + case 172 /* PropertyDeclaration */: return -2013249536 /* PropertyExcludes */; - case 173 /* MethodDeclaration */: - case 176 /* GetAccessor */: - case 177 /* SetAccessor */: + case 174 /* MethodDeclaration */: + case 177 /* GetAccessor */: + case 178 /* SetAccessor */: return -2005057536 /* MethodOrAccessorExcludes */; case 133 /* AnyKeyword */: case 150 /* NumberKeyword */: - case 162 /* BigIntKeyword */: + case 163 /* BigIntKeyword */: case 146 /* NeverKeyword */: case 154 /* StringKeyword */: case 151 /* ObjectKeyword */: case 136 /* BooleanKeyword */: case 155 /* SymbolKeyword */: case 116 /* VoidKeyword */: - case 167 /* TypeParameter */: - case 170 /* PropertySignature */: - case 172 /* MethodSignature */: - case 178 /* CallSignature */: - case 179 /* ConstructSignature */: - case 180 /* IndexSignature */: - case 263 /* InterfaceDeclaration */: - case 264 /* TypeAliasDeclaration */: + case 168 /* TypeParameter */: + case 171 /* PropertySignature */: + case 173 /* MethodSignature */: + case 179 /* CallSignature */: + case 180 /* ConstructSignature */: + case 181 /* IndexSignature */: + case 264 /* InterfaceDeclaration */: + case 265 /* TypeAliasDeclaration */: return -2 /* TypeExcludes */; - case 209 /* ObjectLiteralExpression */: + case 210 /* ObjectLiteralExpression */: return -2147278848 /* ObjectLiteralExcludes */; - case 298 /* CatchClause */: + case 299 /* CatchClause */: return -2147418112 /* CatchClauseExcludes */; - case 205 /* ObjectBindingPattern */: - case 206 /* ArrayBindingPattern */: + case 206 /* ObjectBindingPattern */: + case 207 /* ArrayBindingPattern */: return -2147450880 /* BindingPatternExcludes */; - case 215 /* TypeAssertionExpression */: - case 237 /* SatisfiesExpression */: - case 233 /* AsExpression */: - case 359 /* PartiallyEmittedExpression */: - case 216 /* ParenthesizedExpression */: + case 216 /* TypeAssertionExpression */: + case 238 /* SatisfiesExpression */: + case 234 /* AsExpression */: + case 360 /* PartiallyEmittedExpression */: + case 217 /* ParenthesizedExpression */: case 108 /* SuperKeyword */: return -2147483648 /* OuterExpressionExcludes */; - case 210 /* PropertyAccessExpression */: - case 211 /* ElementAccessExpression */: + case 211 /* PropertyAccessExpression */: + case 212 /* ElementAccessExpression */: return -2147483648 /* PropertyAccessExcludes */; default: return -2147483648 /* NodeExcludes */; } } function makeSynthetic(node) { - node.flags |= 8 /* Synthesized */; + node.flags |= 16 /* Synthesized */; return node; } function createUnparsedSourceFile(textOrInputFiles, mapPathOrType, mapTextOrStripInternal) { @@ -123616,11 +106492,13 @@ ${lanes.join("\n")} return new (SourceMapSource2 || (SourceMapSource2 = objectAllocator.getSourceMapSourceConstructor()))(fileName, text, skipTrivia2); } function setOriginalNode(node, original) { - node.original = original; - if (original) { - const emitNode = original.emitNode; - if (emitNode) - node.emitNode = mergeEmitNode(emitNode, node.emitNode); + if (node.original !== original) { + node.original = original; + if (original) { + const emitNode = original.emitNode; + if (emitNode) + node.emitNode = mergeEmitNode(emitNode, node.emitNode); + } } return node; } @@ -123636,35 +106514,53 @@ ${lanes.join("\n")} constantValue, helpers, startsOnNewLine, - snippetElement + snippetElement, + classThis, + assignedName } = sourceEmitNode; if (!destEmitNode) destEmitNode = {}; - if (leadingComments) - destEmitNode.leadingComments = addRange(leadingComments.slice(), destEmitNode.leadingComments); - if (trailingComments) - destEmitNode.trailingComments = addRange(trailingComments.slice(), destEmitNode.trailingComments); - if (flags) + if (flags) { destEmitNode.flags = flags; - if (internalFlags) + } + if (internalFlags) { destEmitNode.internalFlags = internalFlags & ~8 /* Immutable */; - if (commentRange) + } + if (leadingComments) { + destEmitNode.leadingComments = addRange(leadingComments.slice(), destEmitNode.leadingComments); + } + if (trailingComments) { + destEmitNode.trailingComments = addRange(trailingComments.slice(), destEmitNode.trailingComments); + } + if (commentRange) { destEmitNode.commentRange = commentRange; - if (sourceMapRange) + } + if (sourceMapRange) { destEmitNode.sourceMapRange = sourceMapRange; - if (tokenSourceMapRanges) + } + if (tokenSourceMapRanges) { destEmitNode.tokenSourceMapRanges = mergeTokenSourceMapRanges(tokenSourceMapRanges, destEmitNode.tokenSourceMapRanges); - if (constantValue !== void 0) + } + if (constantValue !== void 0) { destEmitNode.constantValue = constantValue; + } if (helpers) { for (const helper of helpers) { destEmitNode.helpers = appendIfUnique(destEmitNode.helpers, helper); } } - if (startsOnNewLine !== void 0) + if (startsOnNewLine !== void 0) { destEmitNode.startsOnNewLine = startsOnNewLine; - if (snippetElement !== void 0) + } + if (snippetElement !== void 0) { destEmitNode.snippetElement = snippetElement; + } + if (classThis) { + destEmitNode.classThis = classThis; + } + if (assignedName) { + destEmitNode.assignedName = assignedName; + } return destEmitNode; } function mergeTokenSourceMapRanges(sourceRanges, destRanges) { @@ -123707,7 +106603,7 @@ ${lanes.join("\n")} function getOrCreateEmitNode(node) { if (!node.emitNode) { if (isParseTreeNode(node)) { - if (node.kind === 311 /* SourceFile */) { + if (node.kind === 312 /* SourceFile */) { return node.emitNode = { annotatedNodes: [node] }; } const sourceFile = getSourceFileOfNode(getParseTreeNode(getSourceFileOfNode(node))) ?? Debug.fail("Could not determine parsed source file."); @@ -123969,7 +106865,10 @@ ${lanes.join("\n")} // Class Fields Helpers createClassPrivateFieldGetHelper, createClassPrivateFieldSetHelper, - createClassPrivateFieldInHelper + createClassPrivateFieldInHelper, + // 'using' helpers + createAddDisposableResourceHelper, + createDisposeResourcesHelper }; function getUnscopedHelperName(name) { return setEmitFlags(factory2.createIdentifier(name), 8192 /* HelperName */ | 4 /* AdviseOnEmitNode */); @@ -124024,10 +106923,12 @@ ${lanes.join("\n")} ); } function createESDecorateClassContextObject(contextIn) { - return factory2.createObjectLiteralExpression([ + const properties = [ factory2.createPropertyAssignment(factory2.createIdentifier("kind"), factory2.createStringLiteral("class")), - factory2.createPropertyAssignment(factory2.createIdentifier("name"), contextIn.name) - ]); + factory2.createPropertyAssignment(factory2.createIdentifier("name"), contextIn.name), + factory2.createPropertyAssignment(factory2.createIdentifier("metadata"), contextIn.metadata) + ]; + return factory2.createObjectLiteralExpression(properties); } function createESDecorateClassElementAccessGetMethod(elementName) { const accessor = elementName.computed ? factory2.createElementAccessExpression(factory2.createIdentifier("obj"), elementName.name) : factory2.createPropertyAccessExpression(factory2.createIdentifier("obj"), elementName.name); @@ -124131,13 +107032,15 @@ ${lanes.join("\n")} return factory2.createObjectLiteralExpression(properties); } function createESDecorateClassElementContextObject(contextIn) { - return factory2.createObjectLiteralExpression([ + const properties = [ factory2.createPropertyAssignment(factory2.createIdentifier("kind"), factory2.createStringLiteral(contextIn.kind)), factory2.createPropertyAssignment(factory2.createIdentifier("name"), contextIn.name.computed ? contextIn.name.name : factory2.createStringLiteralFromNode(contextIn.name.name)), factory2.createPropertyAssignment(factory2.createIdentifier("static"), contextIn.static ? factory2.createTrue() : factory2.createFalse()), factory2.createPropertyAssignment(factory2.createIdentifier("private"), contextIn.private ? factory2.createTrue() : factory2.createFalse()), - factory2.createPropertyAssignment(factory2.createIdentifier("access"), createESDecorateClassElementAccessObject(contextIn.name, contextIn.access)) - ]); + factory2.createPropertyAssignment(factory2.createIdentifier("access"), createESDecorateClassElementAccessObject(contextIn.name, contextIn.access)), + factory2.createPropertyAssignment(factory2.createIdentifier("metadata"), contextIn.metadata) + ]; + return factory2.createObjectLiteralExpression(properties); } function createESDecorateContextObject(contextIn) { return contextIn.kind === "class" ? createESDecorateClassContextObject(contextIn) : createESDecorateClassElementContextObject(contextIn); @@ -124448,6 +107351,24 @@ ${lanes.join("\n")} [state, receiver] ); } + function createAddDisposableResourceHelper(envBinding, value, async) { + context.requestEmitHelper(addDisposableResourceHelper); + return factory2.createCallExpression( + getUnscopedHelperName("__addDisposableResource"), + /*typeArguments*/ + void 0, + [envBinding, value, async ? factory2.createTrue() : factory2.createFalse()] + ); + } + function createDisposeResourcesHelper(envBinding) { + context.requestEmitHelper(disposeResourcesHelper); + return factory2.createCallExpression( + getUnscopedHelperName("__disposeResources"), + /*typeArguments*/ + void 0, + [envBinding] + ); + } } function compareEmitHelpers(x, y) { if (x === y) @@ -124500,13 +107421,15 @@ ${lanes.join("\n")} classPrivateFieldSetHelper, classPrivateFieldInHelper, createBindingHelper, - setModuleDefaultHelper + setModuleDefaultHelper, + addDisposableResourceHelper, + disposeResourcesHelper ], (helper) => helper.name)); } function isCallToHelper(firstSegment, helperName) { return isCallExpression(firstSegment) && isIdentifier(firstSegment.expression) && (getEmitFlags(firstSegment.expression) & 8192 /* HelperName */) !== 0 && firstSegment.expression.escapedText === helperName; } - var PrivateIdentifierKind, decorateHelper, metadataHelper, paramHelper, esDecorateHelper, runInitializersHelper, assignHelper, awaitHelper, asyncGeneratorHelper, asyncDelegator, asyncValues, restHelper, awaiterHelper, extendsHelper, templateObjectHelper, readHelper, spreadArrayHelper, propKeyHelper, setFunctionNameHelper, valuesHelper, generatorHelper, createBindingHelper, setModuleDefaultHelper, importStarHelper, importDefaultHelper, exportStarHelper, classPrivateFieldGetHelper, classPrivateFieldSetHelper, classPrivateFieldInHelper, allUnscopedEmitHelpers, asyncSuperHelper, advancedAsyncSuperHelper; + var PrivateIdentifierKind, decorateHelper, metadataHelper, paramHelper, esDecorateHelper, runInitializersHelper, assignHelper, awaitHelper, asyncGeneratorHelper, asyncDelegator, asyncValues, restHelper, awaiterHelper, extendsHelper, templateObjectHelper, readHelper, spreadArrayHelper, propKeyHelper, setFunctionNameHelper, valuesHelper, generatorHelper, createBindingHelper, setModuleDefaultHelper, importStarHelper, importDefaultHelper, exportStarHelper, classPrivateFieldGetHelper, classPrivateFieldSetHelper, classPrivateFieldInHelper, addDisposableResourceHelper, disposeResourcesHelper, allUnscopedEmitHelpers, asyncSuperHelper, advancedAsyncSuperHelper; var init_emitHelpers = __esm({ "src/compiler/factory/emitHelpers.ts"() { "use strict"; @@ -124629,17 +107552,18 @@ ${lanes.join("\n")} scoped: false, dependencies: [awaitHelper], text: ` - var __asyncGenerator = (this && this.__asyncGenerator) || function (thisArg, _arguments, generator) { - if (!Symbol.asyncIterator) throw new TypeError("Symbol.asyncIterator is not defined."); - var g = generator.apply(thisArg, _arguments || []), i, q = []; - return i = {}, verb("next"), verb("throw"), verb("return"), i[Symbol.asyncIterator] = function () { return this; }, i; - function verb(n) { if (g[n]) i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; } - function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } } - function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); } - function fulfill(value) { resume("next", value); } - function reject(value) { resume("throw", value); } - function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); } - };` + var __asyncGenerator = (this && this.__asyncGenerator) || function (thisArg, _arguments, generator) { + if (!Symbol.asyncIterator) throw new TypeError("Symbol.asyncIterator is not defined."); + var g = generator.apply(thisArg, _arguments || []), i, q = []; + return i = {}, verb("next"), verb("throw"), verb("return", awaitReturn), i[Symbol.asyncIterator] = function () { return this; }, i; + function awaitReturn(f) { return function (v) { return Promise.resolve(v).then(f, reject); }; } + function verb(n, f) { if (g[n]) { i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; if (f) i[n] = f(i[n]); } } + function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } } + function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); } + function fulfill(value) { resume("next", value); } + function reject(value) { resume("throw", value); } + function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); } + };` }; asyncDelegator = { name: "typescript:asyncDelegator", @@ -124938,6 +107862,63 @@ ${lanes.join("\n")} return typeof state === "function" ? receiver === state : state.has(receiver); };` }; + addDisposableResourceHelper = { + name: "typescript:addDisposableResource", + importName: "__addDisposableResource", + scoped: false, + text: ` + var __addDisposableResource = (this && this.__addDisposableResource) || function (env, value, async) { + if (value !== null && value !== void 0) { + if (typeof value !== "object" && typeof value !== "function") throw new TypeError("Object expected."); + var dispose; + if (async) { + if (!Symbol.asyncDispose) throw new TypeError("Symbol.asyncDispose is not defined."); + dispose = value[Symbol.asyncDispose]; + } + if (dispose === void 0) { + if (!Symbol.dispose) throw new TypeError("Symbol.dispose is not defined."); + dispose = value[Symbol.dispose]; + } + if (typeof dispose !== "function") throw new TypeError("Object not disposable."); + env.stack.push({ value: value, dispose: dispose, async: async }); + } + else if (async) { + env.stack.push({ async: true }); + } + return value; + };` + }; + disposeResourcesHelper = { + name: "typescript:disposeResources", + importName: "__disposeResources", + scoped: false, + text: ` + var __disposeResources = (this && this.__disposeResources) || (function (SuppressedError) { + return function (env) { + function fail(e) { + env.error = env.hasError ? new SuppressedError(e, env.error, "An error was suppressed during disposal.") : e; + env.hasError = true; + } + function next() { + while (env.stack.length) { + var rec = env.stack.pop(); + try { + var result = rec.dispose && rec.dispose.call(rec.value); + if (rec.async) return Promise.resolve(result).then(next, function(e) { fail(e); return next(); }); + } + catch (e) { + fail(e); + } + } + if (env.hasError) throw env.error; + } + return next(); + }; + })(typeof SuppressedError === "function" ? SuppressedError : function (error, suppressed, message) { + var e = new Error(message); + return e.name = "SuppressedError", e.error = error, e.suppressed = suppressed, e; + });` + }; asyncSuperHelper = { name: "typescript:async-super", scoped: true, @@ -125045,7 +108026,7 @@ ${lanes.join("\n")} return node.kind === 128 /* AbstractKeyword */; } function isOverrideModifier(node) { - return node.kind === 163 /* OverrideKeyword */; + return node.kind === 164 /* OverrideKeyword */; } function isAccessorModifier(node) { return node.kind === 129 /* AccessorKeyword */; @@ -125060,577 +108041,583 @@ ${lanes.join("\n")} return node.kind === 84 /* CaseKeyword */; } function isQualifiedName(node) { - return node.kind === 165 /* QualifiedName */; + return node.kind === 166 /* QualifiedName */; } function isComputedPropertyName(node) { - return node.kind === 166 /* ComputedPropertyName */; + return node.kind === 167 /* ComputedPropertyName */; } function isTypeParameterDeclaration(node) { - return node.kind === 167 /* TypeParameter */; + return node.kind === 168 /* TypeParameter */; } function isParameter(node) { - return node.kind === 168 /* Parameter */; + return node.kind === 169 /* Parameter */; } function isDecorator(node) { - return node.kind === 169 /* Decorator */; + return node.kind === 170 /* Decorator */; } function isPropertySignature(node) { - return node.kind === 170 /* PropertySignature */; + return node.kind === 171 /* PropertySignature */; } function isPropertyDeclaration(node) { - return node.kind === 171 /* PropertyDeclaration */; + return node.kind === 172 /* PropertyDeclaration */; } function isMethodSignature(node) { - return node.kind === 172 /* MethodSignature */; + return node.kind === 173 /* MethodSignature */; } function isMethodDeclaration(node) { - return node.kind === 173 /* MethodDeclaration */; + return node.kind === 174 /* MethodDeclaration */; } function isClassStaticBlockDeclaration(node) { - return node.kind === 174 /* ClassStaticBlockDeclaration */; + return node.kind === 175 /* ClassStaticBlockDeclaration */; } function isConstructorDeclaration(node) { - return node.kind === 175 /* Constructor */; + return node.kind === 176 /* Constructor */; } function isGetAccessorDeclaration(node) { - return node.kind === 176 /* GetAccessor */; + return node.kind === 177 /* GetAccessor */; } function isSetAccessorDeclaration(node) { - return node.kind === 177 /* SetAccessor */; + return node.kind === 178 /* SetAccessor */; } function isCallSignatureDeclaration(node) { - return node.kind === 178 /* CallSignature */; + return node.kind === 179 /* CallSignature */; } function isConstructSignatureDeclaration(node) { - return node.kind === 179 /* ConstructSignature */; + return node.kind === 180 /* ConstructSignature */; } function isIndexSignatureDeclaration(node) { - return node.kind === 180 /* IndexSignature */; + return node.kind === 181 /* IndexSignature */; } function isTypePredicateNode(node) { - return node.kind === 181 /* TypePredicate */; + return node.kind === 182 /* TypePredicate */; } function isTypeReferenceNode(node) { - return node.kind === 182 /* TypeReference */; + return node.kind === 183 /* TypeReference */; } function isFunctionTypeNode(node) { - return node.kind === 183 /* FunctionType */; + return node.kind === 184 /* FunctionType */; } function isConstructorTypeNode(node) { - return node.kind === 184 /* ConstructorType */; + return node.kind === 185 /* ConstructorType */; } function isTypeQueryNode(node) { - return node.kind === 185 /* TypeQuery */; + return node.kind === 186 /* TypeQuery */; } function isTypeLiteralNode(node) { - return node.kind === 186 /* TypeLiteral */; + return node.kind === 187 /* TypeLiteral */; } function isArrayTypeNode(node) { - return node.kind === 187 /* ArrayType */; + return node.kind === 188 /* ArrayType */; } function isTupleTypeNode(node) { - return node.kind === 188 /* TupleType */; + return node.kind === 189 /* TupleType */; } function isNamedTupleMember(node) { - return node.kind === 201 /* NamedTupleMember */; + return node.kind === 202 /* NamedTupleMember */; } function isOptionalTypeNode(node) { - return node.kind === 189 /* OptionalType */; + return node.kind === 190 /* OptionalType */; } function isRestTypeNode(node) { - return node.kind === 190 /* RestType */; + return node.kind === 191 /* RestType */; } function isUnionTypeNode(node) { - return node.kind === 191 /* UnionType */; + return node.kind === 192 /* UnionType */; } function isIntersectionTypeNode(node) { - return node.kind === 192 /* IntersectionType */; + return node.kind === 193 /* IntersectionType */; } function isConditionalTypeNode(node) { - return node.kind === 193 /* ConditionalType */; + return node.kind === 194 /* ConditionalType */; } function isInferTypeNode(node) { - return node.kind === 194 /* InferType */; + return node.kind === 195 /* InferType */; } function isParenthesizedTypeNode(node) { - return node.kind === 195 /* ParenthesizedType */; + return node.kind === 196 /* ParenthesizedType */; } function isThisTypeNode(node) { - return node.kind === 196 /* ThisType */; + return node.kind === 197 /* ThisType */; } function isTypeOperatorNode(node) { - return node.kind === 197 /* TypeOperator */; + return node.kind === 198 /* TypeOperator */; } function isIndexedAccessTypeNode(node) { - return node.kind === 198 /* IndexedAccessType */; + return node.kind === 199 /* IndexedAccessType */; } function isMappedTypeNode(node) { - return node.kind === 199 /* MappedType */; + return node.kind === 200 /* MappedType */; } function isLiteralTypeNode(node) { - return node.kind === 200 /* LiteralType */; + return node.kind === 201 /* LiteralType */; } function isImportTypeNode(node) { - return node.kind === 204 /* ImportType */; + return node.kind === 205 /* ImportType */; } function isTemplateLiteralTypeSpan(node) { - return node.kind === 203 /* TemplateLiteralTypeSpan */; + return node.kind === 204 /* TemplateLiteralTypeSpan */; } function isTemplateLiteralTypeNode(node) { - return node.kind === 202 /* TemplateLiteralType */; + return node.kind === 203 /* TemplateLiteralType */; } function isObjectBindingPattern(node) { - return node.kind === 205 /* ObjectBindingPattern */; + return node.kind === 206 /* ObjectBindingPattern */; } function isArrayBindingPattern(node) { - return node.kind === 206 /* ArrayBindingPattern */; + return node.kind === 207 /* ArrayBindingPattern */; } function isBindingElement(node) { - return node.kind === 207 /* BindingElement */; + return node.kind === 208 /* BindingElement */; } function isArrayLiteralExpression(node) { - return node.kind === 208 /* ArrayLiteralExpression */; + return node.kind === 209 /* ArrayLiteralExpression */; } function isObjectLiteralExpression(node) { - return node.kind === 209 /* ObjectLiteralExpression */; + return node.kind === 210 /* ObjectLiteralExpression */; } function isPropertyAccessExpression(node) { - return node.kind === 210 /* PropertyAccessExpression */; + return node.kind === 211 /* PropertyAccessExpression */; } function isElementAccessExpression(node) { - return node.kind === 211 /* ElementAccessExpression */; + return node.kind === 212 /* ElementAccessExpression */; } function isCallExpression(node) { - return node.kind === 212 /* CallExpression */; + return node.kind === 213 /* CallExpression */; } function isNewExpression(node) { - return node.kind === 213 /* NewExpression */; + return node.kind === 214 /* NewExpression */; } function isTaggedTemplateExpression(node) { - return node.kind === 214 /* TaggedTemplateExpression */; + return node.kind === 215 /* TaggedTemplateExpression */; } function isTypeAssertionExpression(node) { - return node.kind === 215 /* TypeAssertionExpression */; + return node.kind === 216 /* TypeAssertionExpression */; } function isParenthesizedExpression(node) { - return node.kind === 216 /* ParenthesizedExpression */; + return node.kind === 217 /* ParenthesizedExpression */; } function isFunctionExpression(node) { - return node.kind === 217 /* FunctionExpression */; + return node.kind === 218 /* FunctionExpression */; } function isArrowFunction(node) { - return node.kind === 218 /* ArrowFunction */; + return node.kind === 219 /* ArrowFunction */; } function isDeleteExpression(node) { - return node.kind === 219 /* DeleteExpression */; + return node.kind === 220 /* DeleteExpression */; } function isTypeOfExpression(node) { - return node.kind === 220 /* TypeOfExpression */; + return node.kind === 221 /* TypeOfExpression */; } function isVoidExpression(node) { - return node.kind === 221 /* VoidExpression */; + return node.kind === 222 /* VoidExpression */; } function isAwaitExpression(node) { - return node.kind === 222 /* AwaitExpression */; + return node.kind === 223 /* AwaitExpression */; } function isPrefixUnaryExpression(node) { - return node.kind === 223 /* PrefixUnaryExpression */; + return node.kind === 224 /* PrefixUnaryExpression */; } function isPostfixUnaryExpression(node) { - return node.kind === 224 /* PostfixUnaryExpression */; + return node.kind === 225 /* PostfixUnaryExpression */; } function isBinaryExpression(node) { - return node.kind === 225 /* BinaryExpression */; + return node.kind === 226 /* BinaryExpression */; } function isConditionalExpression(node) { - return node.kind === 226 /* ConditionalExpression */; + return node.kind === 227 /* ConditionalExpression */; } function isTemplateExpression(node) { - return node.kind === 227 /* TemplateExpression */; + return node.kind === 228 /* TemplateExpression */; } function isYieldExpression(node) { - return node.kind === 228 /* YieldExpression */; + return node.kind === 229 /* YieldExpression */; } function isSpreadElement(node) { - return node.kind === 229 /* SpreadElement */; + return node.kind === 230 /* SpreadElement */; } function isClassExpression(node) { - return node.kind === 230 /* ClassExpression */; + return node.kind === 231 /* ClassExpression */; } function isOmittedExpression(node) { - return node.kind === 231 /* OmittedExpression */; + return node.kind === 232 /* OmittedExpression */; } function isExpressionWithTypeArguments(node) { - return node.kind === 232 /* ExpressionWithTypeArguments */; + return node.kind === 233 /* ExpressionWithTypeArguments */; } function isAsExpression(node) { - return node.kind === 233 /* AsExpression */; + return node.kind === 234 /* AsExpression */; } function isSatisfiesExpression(node) { - return node.kind === 237 /* SatisfiesExpression */; + return node.kind === 238 /* SatisfiesExpression */; } function isNonNullExpression(node) { - return node.kind === 234 /* NonNullExpression */; + return node.kind === 235 /* NonNullExpression */; } function isMetaProperty(node) { - return node.kind === 235 /* MetaProperty */; + return node.kind === 236 /* MetaProperty */; } function isSyntheticExpression(node) { - return node.kind === 236 /* SyntheticExpression */; + return node.kind === 237 /* SyntheticExpression */; } function isPartiallyEmittedExpression(node) { - return node.kind === 359 /* PartiallyEmittedExpression */; + return node.kind === 360 /* PartiallyEmittedExpression */; } function isCommaListExpression(node) { - return node.kind === 360 /* CommaListExpression */; + return node.kind === 361 /* CommaListExpression */; } function isTemplateSpan(node) { - return node.kind === 238 /* TemplateSpan */; + return node.kind === 239 /* TemplateSpan */; } function isSemicolonClassElement(node) { - return node.kind === 239 /* SemicolonClassElement */; + return node.kind === 240 /* SemicolonClassElement */; } function isBlock(node) { - return node.kind === 240 /* Block */; + return node.kind === 241 /* Block */; } function isVariableStatement(node) { - return node.kind === 242 /* VariableStatement */; + return node.kind === 243 /* VariableStatement */; } function isEmptyStatement(node) { - return node.kind === 241 /* EmptyStatement */; + return node.kind === 242 /* EmptyStatement */; } function isExpressionStatement(node) { - return node.kind === 243 /* ExpressionStatement */; + return node.kind === 244 /* ExpressionStatement */; } function isIfStatement(node) { - return node.kind === 244 /* IfStatement */; + return node.kind === 245 /* IfStatement */; } function isDoStatement(node) { - return node.kind === 245 /* DoStatement */; + return node.kind === 246 /* DoStatement */; } function isWhileStatement(node) { - return node.kind === 246 /* WhileStatement */; + return node.kind === 247 /* WhileStatement */; } function isForStatement(node) { - return node.kind === 247 /* ForStatement */; + return node.kind === 248 /* ForStatement */; } function isForInStatement(node) { - return node.kind === 248 /* ForInStatement */; + return node.kind === 249 /* ForInStatement */; } function isForOfStatement(node) { - return node.kind === 249 /* ForOfStatement */; + return node.kind === 250 /* ForOfStatement */; } function isContinueStatement(node) { - return node.kind === 250 /* ContinueStatement */; + return node.kind === 251 /* ContinueStatement */; } function isBreakStatement(node) { - return node.kind === 251 /* BreakStatement */; + return node.kind === 252 /* BreakStatement */; } function isReturnStatement(node) { - return node.kind === 252 /* ReturnStatement */; + return node.kind === 253 /* ReturnStatement */; } function isWithStatement(node) { - return node.kind === 253 /* WithStatement */; + return node.kind === 254 /* WithStatement */; } function isSwitchStatement(node) { - return node.kind === 254 /* SwitchStatement */; + return node.kind === 255 /* SwitchStatement */; } function isLabeledStatement(node) { - return node.kind === 255 /* LabeledStatement */; + return node.kind === 256 /* LabeledStatement */; } function isThrowStatement(node) { - return node.kind === 256 /* ThrowStatement */; + return node.kind === 257 /* ThrowStatement */; } function isTryStatement(node) { - return node.kind === 257 /* TryStatement */; + return node.kind === 258 /* TryStatement */; } function isDebuggerStatement(node) { - return node.kind === 258 /* DebuggerStatement */; + return node.kind === 259 /* DebuggerStatement */; } function isVariableDeclaration(node) { - return node.kind === 259 /* VariableDeclaration */; + return node.kind === 260 /* VariableDeclaration */; } function isVariableDeclarationList(node) { - return node.kind === 260 /* VariableDeclarationList */; + return node.kind === 261 /* VariableDeclarationList */; } function isFunctionDeclaration(node) { - return node.kind === 261 /* FunctionDeclaration */; + return node.kind === 262 /* FunctionDeclaration */; } function isClassDeclaration(node) { - return node.kind === 262 /* ClassDeclaration */; + return node.kind === 263 /* ClassDeclaration */; } function isInterfaceDeclaration(node) { - return node.kind === 263 /* InterfaceDeclaration */; + return node.kind === 264 /* InterfaceDeclaration */; } function isTypeAliasDeclaration(node) { - return node.kind === 264 /* TypeAliasDeclaration */; + return node.kind === 265 /* TypeAliasDeclaration */; } function isEnumDeclaration(node) { - return node.kind === 265 /* EnumDeclaration */; + return node.kind === 266 /* EnumDeclaration */; } function isModuleDeclaration(node) { - return node.kind === 266 /* ModuleDeclaration */; + return node.kind === 267 /* ModuleDeclaration */; } function isModuleBlock(node) { - return node.kind === 267 /* ModuleBlock */; + return node.kind === 268 /* ModuleBlock */; } function isCaseBlock(node) { - return node.kind === 268 /* CaseBlock */; + return node.kind === 269 /* CaseBlock */; } function isNamespaceExportDeclaration(node) { - return node.kind === 269 /* NamespaceExportDeclaration */; + return node.kind === 270 /* NamespaceExportDeclaration */; } function isImportEqualsDeclaration(node) { - return node.kind === 270 /* ImportEqualsDeclaration */; + return node.kind === 271 /* ImportEqualsDeclaration */; } function isImportDeclaration(node) { - return node.kind === 271 /* ImportDeclaration */; + return node.kind === 272 /* ImportDeclaration */; } function isImportClause(node) { - return node.kind === 272 /* ImportClause */; + return node.kind === 273 /* ImportClause */; } function isImportTypeAssertionContainer(node) { - return node.kind === 301 /* ImportTypeAssertionContainer */; + return node.kind === 302 /* ImportTypeAssertionContainer */; } function isAssertClause(node) { - return node.kind === 299 /* AssertClause */; + return node.kind === 300 /* AssertClause */; } function isAssertEntry(node) { - return node.kind === 300 /* AssertEntry */; + return node.kind === 301 /* AssertEntry */; + } + function isImportAttributes(node) { + return node.kind === 300 /* ImportAttributes */; + } + function isImportAttribute(node) { + return node.kind === 301 /* ImportAttribute */; } function isNamespaceImport(node) { - return node.kind === 273 /* NamespaceImport */; + return node.kind === 274 /* NamespaceImport */; } function isNamespaceExport(node) { - return node.kind === 279 /* NamespaceExport */; + return node.kind === 280 /* NamespaceExport */; } function isNamedImports(node) { - return node.kind === 274 /* NamedImports */; + return node.kind === 275 /* NamedImports */; } function isImportSpecifier(node) { - return node.kind === 275 /* ImportSpecifier */; + return node.kind === 276 /* ImportSpecifier */; } function isExportAssignment(node) { - return node.kind === 276 /* ExportAssignment */; + return node.kind === 277 /* ExportAssignment */; } function isExportDeclaration(node) { - return node.kind === 277 /* ExportDeclaration */; + return node.kind === 278 /* ExportDeclaration */; } function isNamedExports(node) { - return node.kind === 278 /* NamedExports */; + return node.kind === 279 /* NamedExports */; } function isExportSpecifier(node) { - return node.kind === 280 /* ExportSpecifier */; + return node.kind === 281 /* ExportSpecifier */; } function isMissingDeclaration(node) { - return node.kind === 281 /* MissingDeclaration */; + return node.kind === 282 /* MissingDeclaration */; } function isNotEmittedStatement(node) { - return node.kind === 358 /* NotEmittedStatement */; + return node.kind === 359 /* NotEmittedStatement */; } function isSyntheticReference(node) { - return node.kind === 361 /* SyntheticReferenceExpression */; + return node.kind === 362 /* SyntheticReferenceExpression */; } function isExternalModuleReference(node) { - return node.kind === 282 /* ExternalModuleReference */; + return node.kind === 283 /* ExternalModuleReference */; } function isJsxElement(node) { - return node.kind === 283 /* JsxElement */; + return node.kind === 284 /* JsxElement */; } function isJsxSelfClosingElement(node) { - return node.kind === 284 /* JsxSelfClosingElement */; + return node.kind === 285 /* JsxSelfClosingElement */; } function isJsxOpeningElement(node) { - return node.kind === 285 /* JsxOpeningElement */; + return node.kind === 286 /* JsxOpeningElement */; } function isJsxClosingElement(node) { - return node.kind === 286 /* JsxClosingElement */; + return node.kind === 287 /* JsxClosingElement */; } function isJsxFragment(node) { - return node.kind === 287 /* JsxFragment */; + return node.kind === 288 /* JsxFragment */; } function isJsxOpeningFragment(node) { - return node.kind === 288 /* JsxOpeningFragment */; + return node.kind === 289 /* JsxOpeningFragment */; } function isJsxClosingFragment(node) { - return node.kind === 289 /* JsxClosingFragment */; + return node.kind === 290 /* JsxClosingFragment */; } function isJsxAttribute(node) { - return node.kind === 290 /* JsxAttribute */; + return node.kind === 291 /* JsxAttribute */; } function isJsxAttributes(node) { - return node.kind === 291 /* JsxAttributes */; + return node.kind === 292 /* JsxAttributes */; } function isJsxSpreadAttribute(node) { - return node.kind === 292 /* JsxSpreadAttribute */; + return node.kind === 293 /* JsxSpreadAttribute */; } function isJsxExpression(node) { - return node.kind === 293 /* JsxExpression */; + return node.kind === 294 /* JsxExpression */; } function isJsxNamespacedName(node) { - return node.kind === 294 /* JsxNamespacedName */; + return node.kind === 295 /* JsxNamespacedName */; } function isCaseClause(node) { - return node.kind === 295 /* CaseClause */; + return node.kind === 296 /* CaseClause */; } function isDefaultClause(node) { - return node.kind === 296 /* DefaultClause */; + return node.kind === 297 /* DefaultClause */; } function isHeritageClause(node) { - return node.kind === 297 /* HeritageClause */; + return node.kind === 298 /* HeritageClause */; } function isCatchClause(node) { - return node.kind === 298 /* CatchClause */; + return node.kind === 299 /* CatchClause */; } function isPropertyAssignment(node) { - return node.kind === 302 /* PropertyAssignment */; + return node.kind === 303 /* PropertyAssignment */; } function isShorthandPropertyAssignment(node) { - return node.kind === 303 /* ShorthandPropertyAssignment */; + return node.kind === 304 /* ShorthandPropertyAssignment */; } function isSpreadAssignment(node) { - return node.kind === 304 /* SpreadAssignment */; + return node.kind === 305 /* SpreadAssignment */; } function isEnumMember(node) { - return node.kind === 305 /* EnumMember */; + return node.kind === 306 /* EnumMember */; } function isUnparsedPrepend(node) { - return node.kind === 307 /* UnparsedPrepend */; + return node.kind === 308 /* UnparsedPrepend */; } function isSourceFile(node) { - return node.kind === 311 /* SourceFile */; + return node.kind === 312 /* SourceFile */; } function isBundle(node) { - return node.kind === 312 /* Bundle */; + return node.kind === 313 /* Bundle */; } function isUnparsedSource(node) { - return node.kind === 313 /* UnparsedSource */; + return node.kind === 314 /* UnparsedSource */; } function isJSDocTypeExpression(node) { - return node.kind === 315 /* JSDocTypeExpression */; + return node.kind === 316 /* JSDocTypeExpression */; } function isJSDocNameReference(node) { - return node.kind === 316 /* JSDocNameReference */; + return node.kind === 317 /* JSDocNameReference */; } function isJSDocMemberName(node) { - return node.kind === 317 /* JSDocMemberName */; + return node.kind === 318 /* JSDocMemberName */; } function isJSDocLink(node) { - return node.kind === 330 /* JSDocLink */; + return node.kind === 331 /* JSDocLink */; } function isJSDocLinkCode(node) { - return node.kind === 331 /* JSDocLinkCode */; + return node.kind === 332 /* JSDocLinkCode */; } function isJSDocLinkPlain(node) { - return node.kind === 332 /* JSDocLinkPlain */; + return node.kind === 333 /* JSDocLinkPlain */; } function isJSDocAllType(node) { - return node.kind === 318 /* JSDocAllType */; + return node.kind === 319 /* JSDocAllType */; } function isJSDocUnknownType(node) { - return node.kind === 319 /* JSDocUnknownType */; + return node.kind === 320 /* JSDocUnknownType */; } function isJSDocNullableType(node) { - return node.kind === 320 /* JSDocNullableType */; + return node.kind === 321 /* JSDocNullableType */; } function isJSDocNonNullableType(node) { - return node.kind === 321 /* JSDocNonNullableType */; + return node.kind === 322 /* JSDocNonNullableType */; } function isJSDocOptionalType(node) { - return node.kind === 322 /* JSDocOptionalType */; + return node.kind === 323 /* JSDocOptionalType */; } function isJSDocFunctionType(node) { - return node.kind === 323 /* JSDocFunctionType */; + return node.kind === 324 /* JSDocFunctionType */; } function isJSDocVariadicType(node) { - return node.kind === 324 /* JSDocVariadicType */; + return node.kind === 325 /* JSDocVariadicType */; } function isJSDocNamepathType(node) { - return node.kind === 325 /* JSDocNamepathType */; + return node.kind === 326 /* JSDocNamepathType */; } function isJSDoc(node) { - return node.kind === 326 /* JSDoc */; + return node.kind === 327 /* JSDoc */; } function isJSDocTypeLiteral(node) { - return node.kind === 328 /* JSDocTypeLiteral */; + return node.kind === 329 /* JSDocTypeLiteral */; } function isJSDocSignature(node) { - return node.kind === 329 /* JSDocSignature */; + return node.kind === 330 /* JSDocSignature */; } function isJSDocAugmentsTag(node) { - return node.kind === 334 /* JSDocAugmentsTag */; + return node.kind === 335 /* JSDocAugmentsTag */; } function isJSDocAuthorTag(node) { - return node.kind === 336 /* JSDocAuthorTag */; + return node.kind === 337 /* JSDocAuthorTag */; } function isJSDocClassTag(node) { - return node.kind === 338 /* JSDocClassTag */; + return node.kind === 339 /* JSDocClassTag */; } function isJSDocCallbackTag(node) { - return node.kind === 344 /* JSDocCallbackTag */; + return node.kind === 345 /* JSDocCallbackTag */; } function isJSDocPublicTag(node) { - return node.kind === 339 /* JSDocPublicTag */; + return node.kind === 340 /* JSDocPublicTag */; } function isJSDocPrivateTag(node) { - return node.kind === 340 /* JSDocPrivateTag */; + return node.kind === 341 /* JSDocPrivateTag */; } function isJSDocProtectedTag(node) { - return node.kind === 341 /* JSDocProtectedTag */; + return node.kind === 342 /* JSDocProtectedTag */; } function isJSDocReadonlyTag(node) { - return node.kind === 342 /* JSDocReadonlyTag */; + return node.kind === 343 /* JSDocReadonlyTag */; } function isJSDocOverrideTag(node) { - return node.kind === 343 /* JSDocOverrideTag */; + return node.kind === 344 /* JSDocOverrideTag */; } function isJSDocOverloadTag(node) { - return node.kind === 345 /* JSDocOverloadTag */; + return node.kind === 346 /* JSDocOverloadTag */; } function isJSDocDeprecatedTag(node) { - return node.kind === 337 /* JSDocDeprecatedTag */; + return node.kind === 338 /* JSDocDeprecatedTag */; } function isJSDocSeeTag(node) { - return node.kind === 353 /* JSDocSeeTag */; + return node.kind === 354 /* JSDocSeeTag */; } function isJSDocEnumTag(node) { - return node.kind === 346 /* JSDocEnumTag */; + return node.kind === 347 /* JSDocEnumTag */; } function isJSDocParameterTag(node) { - return node.kind === 347 /* JSDocParameterTag */; + return node.kind === 348 /* JSDocParameterTag */; } function isJSDocReturnTag(node) { - return node.kind === 348 /* JSDocReturnTag */; + return node.kind === 349 /* JSDocReturnTag */; } function isJSDocThisTag(node) { - return node.kind === 349 /* JSDocThisTag */; + return node.kind === 350 /* JSDocThisTag */; } function isJSDocTypeTag(node) { - return node.kind === 350 /* JSDocTypeTag */; + return node.kind === 351 /* JSDocTypeTag */; } function isJSDocTemplateTag(node) { - return node.kind === 351 /* JSDocTemplateTag */; + return node.kind === 352 /* JSDocTemplateTag */; } function isJSDocTypedefTag(node) { - return node.kind === 352 /* JSDocTypedefTag */; + return node.kind === 353 /* JSDocTypedefTag */; } function isJSDocUnknownTag(node) { - return node.kind === 333 /* JSDocTag */; + return node.kind === 334 /* JSDocTag */; } function isJSDocPropertyTag(node) { - return node.kind === 354 /* JSDocPropertyTag */; + return node.kind === 355 /* JSDocPropertyTag */; } function isJSDocImplementsTag(node) { - return node.kind === 335 /* JSDocImplementsTag */; + return node.kind === 336 /* JSDocImplementsTag */; } function isJSDocSatisfiesTag(node) { - return node.kind === 356 /* JSDocSatisfiesTag */; + return node.kind === 357 /* JSDocSatisfiesTag */; } function isJSDocThrowsTag(node) { - return node.kind === 355 /* JSDocThrowsTag */; + return node.kind === 356 /* JSDocThrowsTag */; } function isSyntaxList(n) { - return n.kind === 357 /* SyntaxList */; + return n.kind === 358 /* SyntaxList */; } var init_nodeTests = __esm({ "src/compiler/factory/nodeTests.ts"() { @@ -125944,14 +108931,14 @@ ${lanes.join("\n")} Debug.failBadSyntaxKind(property.name, "Private identifiers are not allowed in object literals."); } switch (property.kind) { - case 176 /* GetAccessor */: - case 177 /* SetAccessor */: + case 177 /* GetAccessor */: + case 178 /* SetAccessor */: return createExpressionForAccessorDeclaration(factory2, node.properties, property, receiver, !!node.multiLine); - case 302 /* PropertyAssignment */: + case 303 /* PropertyAssignment */: return createExpressionForPropertyAssignment(factory2, property, receiver); - case 303 /* ShorthandPropertyAssignment */: + case 304 /* ShorthandPropertyAssignment */: return createExpressionForShorthandPropertyAssignment(factory2, property, receiver); - case 173 /* MethodDeclaration */: + case 174 /* MethodDeclaration */: return createExpressionForMethodDeclaration(factory2, property, receiver); } } @@ -126004,7 +108991,7 @@ ${lanes.join("\n")} return firstStatement !== void 0 && isPrologueDirective(firstStatement) && isUseStrictPrologue(firstStatement); } function isCommaExpression(node) { - return node.kind === 225 /* BinaryExpression */ && node.operatorToken.kind === 28 /* CommaToken */; + return node.kind === 226 /* BinaryExpression */ && node.operatorToken.kind === 28 /* CommaToken */; } function isCommaSequence(node) { return isCommaExpression(node) || isCommaListExpression(node); @@ -126019,19 +109006,19 @@ ${lanes.join("\n")} } function isOuterExpression(node, kinds = 15 /* All */) { switch (node.kind) { - case 216 /* ParenthesizedExpression */: + case 217 /* ParenthesizedExpression */: if (kinds & 16 /* ExcludeJSDocTypeAssertion */ && isJSDocTypeAssertion(node)) { return false; } return (kinds & 1 /* Parentheses */) !== 0; - case 215 /* TypeAssertionExpression */: - case 233 /* AsExpression */: - case 232 /* ExpressionWithTypeArguments */: - case 237 /* SatisfiesExpression */: + case 216 /* TypeAssertionExpression */: + case 234 /* AsExpression */: + case 233 /* ExpressionWithTypeArguments */: + case 238 /* SatisfiesExpression */: return (kinds & 2 /* TypeAssertions */) !== 0; - case 234 /* NonNullExpression */: + case 235 /* NonNullExpression */: return (kinds & 4 /* NonNullAssertions */) !== 0; - case 359 /* PartiallyEmittedExpression */: + case 360 /* PartiallyEmittedExpression */: return (kinds & 8 /* PartiallyEmittedExpressions */) !== 0; } return false; @@ -126089,21 +109076,18 @@ ${lanes.join("\n")} if (some(helperNames)) { helperNames.sort(compareStringsCaseSensitive); namedBindings = nodeFactory.createNamedImports( - map( - helperNames, - (name) => isFileLevelUniqueName(sourceFile, name) ? nodeFactory.createImportSpecifier( - /*isTypeOnly*/ - false, - /*propertyName*/ - void 0, - nodeFactory.createIdentifier(name) - ) : nodeFactory.createImportSpecifier( - /*isTypeOnly*/ - false, - nodeFactory.createIdentifier(name), - helperFactory.getUnscopedHelperName(name) - ) - ) + map(helperNames, (name) => isFileLevelUniqueName(sourceFile, name) ? nodeFactory.createImportSpecifier( + /*isTypeOnly*/ + false, + /*propertyName*/ + void 0, + nodeFactory.createIdentifier(name) + ) : nodeFactory.createImportSpecifier( + /*isTypeOnly*/ + false, + nodeFactory.createIdentifier(name), + helperFactory.getUnscopedHelperName(name) + )) ); const parseNode = getOriginalNode(sourceFile, isSourceFile); const emitNode = getOrCreateEmitNode(parseNode); @@ -126128,7 +109112,7 @@ ${lanes.join("\n")} namedBindings ), nodeFactory.createStringLiteral(externalHelpersModuleNameText), - /*assertClause*/ + /*attributes*/ void 0 ); addInternalEmitFlags(externalHelpersImportDeclaration, 2 /* NeverApplyImportHelper */); @@ -126168,10 +109152,10 @@ ${lanes.join("\n")} const name = namespaceDeclaration.name; return isGeneratedIdentifier(name) ? name : factory2.createIdentifier(getSourceTextOfNodeFromSourceFile(sourceFile, name) || idText(name)); } - if (node.kind === 271 /* ImportDeclaration */ && node.importClause) { + if (node.kind === 272 /* ImportDeclaration */ && node.importClause) { return factory2.getGeneratedNameForNode(node); } - if (node.kind === 277 /* ExportDeclaration */ && node.moduleSpecifier) { + if (node.kind === 278 /* ExportDeclaration */ && node.moduleSpecifier) { return factory2.getGeneratedNameForNode(node); } return void 0; @@ -126234,11 +109218,11 @@ ${lanes.join("\n")} } if (isObjectLiteralElementLike(bindingElement)) { switch (bindingElement.kind) { - case 302 /* PropertyAssignment */: + case 303 /* PropertyAssignment */: return getTargetOfBindingOrAssignmentElement(bindingElement.initializer); - case 303 /* ShorthandPropertyAssignment */: + case 304 /* ShorthandPropertyAssignment */: return bindingElement.name; - case 304 /* SpreadAssignment */: + case 305 /* SpreadAssignment */: return getTargetOfBindingOrAssignmentElement(bindingElement.expression); } return void 0; @@ -126257,11 +109241,11 @@ ${lanes.join("\n")} } function getRestIndicatorOfBindingOrAssignmentElement(bindingElement) { switch (bindingElement.kind) { - case 168 /* Parameter */: - case 207 /* BindingElement */: + case 169 /* Parameter */: + case 208 /* BindingElement */: return bindingElement.dotDotDotToken; - case 229 /* SpreadElement */: - case 304 /* SpreadAssignment */: + case 230 /* SpreadElement */: + case 305 /* SpreadAssignment */: return bindingElement; } return void 0; @@ -126273,7 +109257,7 @@ ${lanes.join("\n")} } function tryGetPropertyNameOfBindingOrAssignmentElement(bindingElement) { switch (bindingElement.kind) { - case 207 /* BindingElement */: + case 208 /* BindingElement */: if (bindingElement.propertyName) { const propertyName = bindingElement.propertyName; if (isPrivateIdentifier(propertyName)) { @@ -126282,7 +109266,7 @@ ${lanes.join("\n")} return isComputedPropertyName(propertyName) && isStringOrNumericLiteral(propertyName.expression) ? propertyName.expression : propertyName; } break; - case 302 /* PropertyAssignment */: + case 303 /* PropertyAssignment */: if (bindingElement.name) { const propertyName = bindingElement.name; if (isPrivateIdentifier(propertyName)) { @@ -126291,7 +109275,7 @@ ${lanes.join("\n")} return isComputedPropertyName(propertyName) && isStringOrNumericLiteral(propertyName.expression) ? propertyName.expression : propertyName; } break; - case 304 /* SpreadAssignment */: + case 305 /* SpreadAssignment */: if (bindingElement.name && isPrivateIdentifier(bindingElement.name)) { return Debug.failBadSyntaxKind(bindingElement.name); } @@ -126308,11 +109292,11 @@ ${lanes.join("\n")} } function getElementsOfBindingOrAssignmentPattern(name) { switch (name.kind) { - case 205 /* ObjectBindingPattern */: - case 206 /* ArrayBindingPattern */: - case 208 /* ArrayLiteralExpression */: + case 206 /* ObjectBindingPattern */: + case 207 /* ArrayBindingPattern */: + case 209 /* ArrayLiteralExpression */: return name.elements; - case 209 /* ObjectLiteralExpression */: + case 210 /* ObjectLiteralExpression */: return name.properties; } } @@ -126329,19 +109313,19 @@ ${lanes.join("\n")} } function canHaveIllegalType(node) { const kind = node.kind; - return kind === 175 /* Constructor */ || kind === 177 /* SetAccessor */; + return kind === 176 /* Constructor */ || kind === 178 /* SetAccessor */; } function canHaveIllegalTypeParameters(node) { const kind = node.kind; - return kind === 175 /* Constructor */ || kind === 176 /* GetAccessor */ || kind === 177 /* SetAccessor */; + return kind === 176 /* Constructor */ || kind === 177 /* GetAccessor */ || kind === 178 /* SetAccessor */; } function canHaveIllegalDecorators(node) { const kind = node.kind; - return kind === 302 /* PropertyAssignment */ || kind === 303 /* ShorthandPropertyAssignment */ || kind === 261 /* FunctionDeclaration */ || kind === 175 /* Constructor */ || kind === 180 /* IndexSignature */ || kind === 174 /* ClassStaticBlockDeclaration */ || kind === 281 /* MissingDeclaration */ || kind === 242 /* VariableStatement */ || kind === 263 /* InterfaceDeclaration */ || kind === 264 /* TypeAliasDeclaration */ || kind === 265 /* EnumDeclaration */ || kind === 266 /* ModuleDeclaration */ || kind === 270 /* ImportEqualsDeclaration */ || kind === 271 /* ImportDeclaration */ || kind === 269 /* NamespaceExportDeclaration */ || kind === 277 /* ExportDeclaration */ || kind === 276 /* ExportAssignment */; + return kind === 303 /* PropertyAssignment */ || kind === 304 /* ShorthandPropertyAssignment */ || kind === 262 /* FunctionDeclaration */ || kind === 176 /* Constructor */ || kind === 181 /* IndexSignature */ || kind === 175 /* ClassStaticBlockDeclaration */ || kind === 282 /* MissingDeclaration */ || kind === 243 /* VariableStatement */ || kind === 264 /* InterfaceDeclaration */ || kind === 265 /* TypeAliasDeclaration */ || kind === 266 /* EnumDeclaration */ || kind === 267 /* ModuleDeclaration */ || kind === 271 /* ImportEqualsDeclaration */ || kind === 272 /* ImportDeclaration */ || kind === 270 /* NamespaceExportDeclaration */ || kind === 278 /* ExportDeclaration */ || kind === 277 /* ExportAssignment */; } function canHaveIllegalModifiers(node) { const kind = node.kind; - return kind === 174 /* ClassStaticBlockDeclaration */ || kind === 302 /* PropertyAssignment */ || kind === 303 /* ShorthandPropertyAssignment */ || kind === 281 /* MissingDeclaration */ || kind === 269 /* NamespaceExportDeclaration */; + return kind === 175 /* ClassStaticBlockDeclaration */ || kind === 303 /* PropertyAssignment */ || kind === 304 /* ShorthandPropertyAssignment */ || kind === 282 /* MissingDeclaration */ || kind === 270 /* NamespaceExportDeclaration */; } function isQuestionOrExclamationToken(node) { return isQuestionToken(node) || isExclamationToken(node); @@ -126508,7 +109492,7 @@ ${lanes.join("\n")} initializer ); } - function createAccessorPropertyGetRedirector(factory2, node, modifiers, name) { + function createAccessorPropertyGetRedirector(factory2, node, modifiers, name, receiver = factory2.createThis()) { return factory2.createGetAccessorDeclaration( modifiers, name, @@ -126518,7 +109502,7 @@ ${lanes.join("\n")} factory2.createBlock([ factory2.createReturnStatement( factory2.createPropertyAccessExpression( - factory2.createThis(), + receiver, factory2.getGeneratedPrivateNameForNode( node.name, /*prefix*/ @@ -126530,7 +109514,7 @@ ${lanes.join("\n")} ]) ); } - function createAccessorPropertySetRedirector(factory2, node, modifiers, name) { + function createAccessorPropertySetRedirector(factory2, node, modifiers, name, receiver = factory2.createThis()) { return factory2.createSetAccessorDeclaration( modifiers, name, @@ -126545,7 +109529,7 @@ ${lanes.join("\n")} factory2.createExpressionStatement( factory2.createAssignment( factory2.createPropertyAccessExpression( - factory2.createThis(), + receiver, factory2.getGeneratedPrivateNameForNode( node.name, /*prefix*/ @@ -126746,11 +109730,11 @@ ${lanes.join("\n")} } function canHaveModifiers(node) { const kind = node.kind; - return kind === 167 /* TypeParameter */ || kind === 168 /* Parameter */ || kind === 170 /* PropertySignature */ || kind === 171 /* PropertyDeclaration */ || kind === 172 /* MethodSignature */ || kind === 173 /* MethodDeclaration */ || kind === 175 /* Constructor */ || kind === 176 /* GetAccessor */ || kind === 177 /* SetAccessor */ || kind === 180 /* IndexSignature */ || kind === 184 /* ConstructorType */ || kind === 217 /* FunctionExpression */ || kind === 218 /* ArrowFunction */ || kind === 230 /* ClassExpression */ || kind === 242 /* VariableStatement */ || kind === 261 /* FunctionDeclaration */ || kind === 262 /* ClassDeclaration */ || kind === 263 /* InterfaceDeclaration */ || kind === 264 /* TypeAliasDeclaration */ || kind === 265 /* EnumDeclaration */ || kind === 266 /* ModuleDeclaration */ || kind === 270 /* ImportEqualsDeclaration */ || kind === 271 /* ImportDeclaration */ || kind === 276 /* ExportAssignment */ || kind === 277 /* ExportDeclaration */; + return kind === 168 /* TypeParameter */ || kind === 169 /* Parameter */ || kind === 171 /* PropertySignature */ || kind === 172 /* PropertyDeclaration */ || kind === 173 /* MethodSignature */ || kind === 174 /* MethodDeclaration */ || kind === 176 /* Constructor */ || kind === 177 /* GetAccessor */ || kind === 178 /* SetAccessor */ || kind === 181 /* IndexSignature */ || kind === 185 /* ConstructorType */ || kind === 218 /* FunctionExpression */ || kind === 219 /* ArrowFunction */ || kind === 231 /* ClassExpression */ || kind === 243 /* VariableStatement */ || kind === 262 /* FunctionDeclaration */ || kind === 263 /* ClassDeclaration */ || kind === 264 /* InterfaceDeclaration */ || kind === 265 /* TypeAliasDeclaration */ || kind === 266 /* EnumDeclaration */ || kind === 267 /* ModuleDeclaration */ || kind === 271 /* ImportEqualsDeclaration */ || kind === 272 /* ImportDeclaration */ || kind === 277 /* ExportAssignment */ || kind === 278 /* ExportDeclaration */; } function canHaveDecorators(node) { const kind = node.kind; - return kind === 168 /* Parameter */ || kind === 171 /* PropertyDeclaration */ || kind === 173 /* MethodDeclaration */ || kind === 176 /* GetAccessor */ || kind === 177 /* SetAccessor */ || kind === 230 /* ClassExpression */ || kind === 262 /* ClassDeclaration */; + return kind === 169 /* Parameter */ || kind === 172 /* PropertyDeclaration */ || kind === 174 /* MethodDeclaration */ || kind === 177 /* GetAccessor */ || kind === 178 /* SetAccessor */ || kind === 231 /* ClassExpression */ || kind === 263 /* ClassDeclaration */; } var init_utilitiesPublic2 = __esm({ "src/compiler/factory/utilitiesPublic.ts"() { @@ -126786,7 +109770,7 @@ ${lanes.join("\n")} return canHaveModifiers(node) && hasModifierOfKind(node, 95 /* ExportKeyword */) || isImportEqualsDeclaration(node) && isExternalModuleReference(node.moduleReference) || isImportDeclaration(node) || isExportAssignment(node) || isExportDeclaration(node) ? node : void 0; } function getImportMetaIfNecessary(sourceFile) { - return sourceFile.flags & 4194304 /* PossiblyContainsImportMeta */ ? walkTreeForImportMeta(sourceFile) : void 0; + return sourceFile.flags & 8388608 /* PossiblyContainsImportMeta */ ? walkTreeForImportMeta(sourceFile) : void 0; } function walkTreeForImportMeta(node) { return isImportMeta2(node) ? node : forEachChild(node, walkTreeForImportMeta); @@ -126850,7 +109834,7 @@ ${lanes.join("\n")} return visitNode2(cbNode, node.expression); } function forEachChild(node, cbNode, cbNodes) { - if (node === void 0 || node.kind <= 164 /* LastToken */) { + if (node === void 0 || node.kind <= 165 /* LastToken */) { return; } const fn = forEachChildTable[node.kind]; @@ -126885,7 +109869,7 @@ ${lanes.join("\n")} continue; return res; } - if (current.kind >= 165 /* FirstNode */) { + if (current.kind >= 166 /* FirstNode */) { for (const child of gatherPossibleChildren(current)) { queue.push(child); parents.push(current); @@ -126920,7 +109904,8 @@ ${lanes.join("\n")} const { languageVersion, setExternalModuleIndicator: overrideSetExternalModuleIndicator, - impliedNodeFormat: format + impliedNodeFormat: format, + jsDocParsingMode } = typeof languageVersionOrOptions === "object" ? languageVersionOrOptions : { languageVersion: languageVersionOrOptions }; if (languageVersion === 100 /* JSON */) { result = Parser.parseSourceFile( @@ -126931,7 +109916,8 @@ ${lanes.join("\n")} void 0, setParentNodes, 6 /* JSON */, - noop + noop, + jsDocParsingMode ); } else { const setIndicator = format === void 0 ? overrideSetExternalModuleIndicator : (file) => { @@ -126946,7 +109932,8 @@ ${lanes.join("\n")} void 0, setParentNodes, scriptKind, - setIndicator + setIndicator, + jsDocParsingMode ); } (_c = perfLogger) == null ? void 0 : _c.logStopParseSourceFile(); @@ -126966,7 +109953,7 @@ ${lanes.join("\n")} } function updateSourceFile(sourceFile, newText, textChangeRange, aggressiveChecks = false) { const newSourceFile = IncrementalParser.updateSourceFile(sourceFile, newText, textChangeRange, aggressiveChecks); - newSourceFile.flags |= sourceFile.flags & 6291456 /* PermanentlySetIncrementalFlags */; + newSourceFile.flags |= sourceFile.flags & 12582912 /* PermanentlySetIncrementalFlags */; return newSourceFile; } function parseIsolatedJSDocComment(content, start, length2) { @@ -126980,7 +109967,7 @@ ${lanes.join("\n")} return Parser.JSDocParser.parseJSDocTypeExpressionForTests(content, start, length2); } function isDeclarationFileName(fileName) { - return fileExtensionIsOneOf(fileName, supportedDeclarationExtensions) || fileExtensionIs(fileName, ".ts" /* Ts */) && stringContains(getBaseFileName(fileName), ".d."); + return fileExtensionIsOneOf(fileName, supportedDeclarationExtensions) || fileExtensionIs(fileName, ".ts" /* Ts */) && getBaseFileName(fileName).includes(".d."); } function parseResolutionMode(mode, pos, end, reportDiagnostic) { if (!mode) { @@ -127163,7 +110150,7 @@ ${lanes.join("\n")} return {}; if (!pragma.args) return {}; - const args = trimString(text).split(/\s+/); + const args = text.trim().split(/\s+/); const argMap = {}; for (let i = 0; i < pragma.args.length; i++) { const argument = pragma.args[i]; @@ -127187,7 +110174,7 @@ ${lanes.join("\n")} if (lhs.kind === 110 /* ThisKeyword */) { return true; } - if (lhs.kind === 294 /* JsxNamespacedName */) { + if (lhs.kind === 295 /* JsxNamespacedName */) { return lhs.namespace.escapedText === rhs.namespace.escapedText && lhs.name.escapedText === rhs.name.escapedText; } return lhs.name.escapedText === rhs.name.escapedText && tagNamesAreEquivalent(lhs.expression, rhs.expression); @@ -127207,428 +110194,428 @@ ${lanes.join("\n")} }; parseNodeFactory = createNodeFactory(1 /* NoParenthesizerRules */, parseBaseNodeFactory); forEachChildTable = { - [165 /* QualifiedName */]: function forEachChildInQualifiedName(node, cbNode, _cbNodes) { + [166 /* QualifiedName */]: function forEachChildInQualifiedName(node, cbNode, _cbNodes) { return visitNode2(cbNode, node.left) || visitNode2(cbNode, node.right); }, - [167 /* TypeParameter */]: function forEachChildInTypeParameter(node, cbNode, cbNodes) { + [168 /* TypeParameter */]: function forEachChildInTypeParameter(node, cbNode, cbNodes) { return visitNodes(cbNode, cbNodes, node.modifiers) || visitNode2(cbNode, node.name) || visitNode2(cbNode, node.constraint) || visitNode2(cbNode, node.default) || visitNode2(cbNode, node.expression); }, - [303 /* ShorthandPropertyAssignment */]: function forEachChildInShorthandPropertyAssignment(node, cbNode, cbNodes) { + [304 /* ShorthandPropertyAssignment */]: function forEachChildInShorthandPropertyAssignment(node, cbNode, cbNodes) { return visitNodes(cbNode, cbNodes, node.modifiers) || visitNode2(cbNode, node.name) || visitNode2(cbNode, node.questionToken) || visitNode2(cbNode, node.exclamationToken) || visitNode2(cbNode, node.equalsToken) || visitNode2(cbNode, node.objectAssignmentInitializer); }, - [304 /* SpreadAssignment */]: function forEachChildInSpreadAssignment(node, cbNode, _cbNodes) { + [305 /* SpreadAssignment */]: function forEachChildInSpreadAssignment(node, cbNode, _cbNodes) { return visitNode2(cbNode, node.expression); }, - [168 /* Parameter */]: function forEachChildInParameter(node, cbNode, cbNodes) { + [169 /* Parameter */]: function forEachChildInParameter(node, cbNode, cbNodes) { return visitNodes(cbNode, cbNodes, node.modifiers) || visitNode2(cbNode, node.dotDotDotToken) || visitNode2(cbNode, node.name) || visitNode2(cbNode, node.questionToken) || visitNode2(cbNode, node.type) || visitNode2(cbNode, node.initializer); }, - [171 /* PropertyDeclaration */]: function forEachChildInPropertyDeclaration(node, cbNode, cbNodes) { + [172 /* PropertyDeclaration */]: function forEachChildInPropertyDeclaration(node, cbNode, cbNodes) { return visitNodes(cbNode, cbNodes, node.modifiers) || visitNode2(cbNode, node.name) || visitNode2(cbNode, node.questionToken) || visitNode2(cbNode, node.exclamationToken) || visitNode2(cbNode, node.type) || visitNode2(cbNode, node.initializer); }, - [170 /* PropertySignature */]: function forEachChildInPropertySignature(node, cbNode, cbNodes) { + [171 /* PropertySignature */]: function forEachChildInPropertySignature(node, cbNode, cbNodes) { return visitNodes(cbNode, cbNodes, node.modifiers) || visitNode2(cbNode, node.name) || visitNode2(cbNode, node.questionToken) || visitNode2(cbNode, node.type) || visitNode2(cbNode, node.initializer); }, - [302 /* PropertyAssignment */]: function forEachChildInPropertyAssignment(node, cbNode, cbNodes) { + [303 /* PropertyAssignment */]: function forEachChildInPropertyAssignment(node, cbNode, cbNodes) { return visitNodes(cbNode, cbNodes, node.modifiers) || visitNode2(cbNode, node.name) || visitNode2(cbNode, node.questionToken) || visitNode2(cbNode, node.exclamationToken) || visitNode2(cbNode, node.initializer); }, - [259 /* VariableDeclaration */]: function forEachChildInVariableDeclaration(node, cbNode, _cbNodes) { + [260 /* VariableDeclaration */]: function forEachChildInVariableDeclaration(node, cbNode, _cbNodes) { return visitNode2(cbNode, node.name) || visitNode2(cbNode, node.exclamationToken) || visitNode2(cbNode, node.type) || visitNode2(cbNode, node.initializer); }, - [207 /* BindingElement */]: function forEachChildInBindingElement(node, cbNode, _cbNodes) { + [208 /* BindingElement */]: function forEachChildInBindingElement(node, cbNode, _cbNodes) { return visitNode2(cbNode, node.dotDotDotToken) || visitNode2(cbNode, node.propertyName) || visitNode2(cbNode, node.name) || visitNode2(cbNode, node.initializer); }, - [180 /* IndexSignature */]: function forEachChildInIndexSignature(node, cbNode, cbNodes) { + [181 /* IndexSignature */]: function forEachChildInIndexSignature(node, cbNode, cbNodes) { return visitNodes(cbNode, cbNodes, node.modifiers) || visitNodes(cbNode, cbNodes, node.typeParameters) || visitNodes(cbNode, cbNodes, node.parameters) || visitNode2(cbNode, node.type); }, - [184 /* ConstructorType */]: function forEachChildInConstructorType(node, cbNode, cbNodes) { + [185 /* ConstructorType */]: function forEachChildInConstructorType(node, cbNode, cbNodes) { return visitNodes(cbNode, cbNodes, node.modifiers) || visitNodes(cbNode, cbNodes, node.typeParameters) || visitNodes(cbNode, cbNodes, node.parameters) || visitNode2(cbNode, node.type); }, - [183 /* FunctionType */]: function forEachChildInFunctionType(node, cbNode, cbNodes) { + [184 /* FunctionType */]: function forEachChildInFunctionType(node, cbNode, cbNodes) { return visitNodes(cbNode, cbNodes, node.modifiers) || visitNodes(cbNode, cbNodes, node.typeParameters) || visitNodes(cbNode, cbNodes, node.parameters) || visitNode2(cbNode, node.type); }, - [178 /* CallSignature */]: forEachChildInCallOrConstructSignature, - [179 /* ConstructSignature */]: forEachChildInCallOrConstructSignature, - [173 /* MethodDeclaration */]: function forEachChildInMethodDeclaration(node, cbNode, cbNodes) { + [179 /* CallSignature */]: forEachChildInCallOrConstructSignature, + [180 /* ConstructSignature */]: forEachChildInCallOrConstructSignature, + [174 /* MethodDeclaration */]: function forEachChildInMethodDeclaration(node, cbNode, cbNodes) { return visitNodes(cbNode, cbNodes, node.modifiers) || visitNode2(cbNode, node.asteriskToken) || visitNode2(cbNode, node.name) || visitNode2(cbNode, node.questionToken) || visitNode2(cbNode, node.exclamationToken) || visitNodes(cbNode, cbNodes, node.typeParameters) || visitNodes(cbNode, cbNodes, node.parameters) || visitNode2(cbNode, node.type) || visitNode2(cbNode, node.body); }, - [172 /* MethodSignature */]: function forEachChildInMethodSignature(node, cbNode, cbNodes) { + [173 /* MethodSignature */]: function forEachChildInMethodSignature(node, cbNode, cbNodes) { return visitNodes(cbNode, cbNodes, node.modifiers) || visitNode2(cbNode, node.name) || visitNode2(cbNode, node.questionToken) || visitNodes(cbNode, cbNodes, node.typeParameters) || visitNodes(cbNode, cbNodes, node.parameters) || visitNode2(cbNode, node.type); }, - [175 /* Constructor */]: function forEachChildInConstructor(node, cbNode, cbNodes) { + [176 /* Constructor */]: function forEachChildInConstructor(node, cbNode, cbNodes) { return visitNodes(cbNode, cbNodes, node.modifiers) || visitNode2(cbNode, node.name) || visitNodes(cbNode, cbNodes, node.typeParameters) || visitNodes(cbNode, cbNodes, node.parameters) || visitNode2(cbNode, node.type) || visitNode2(cbNode, node.body); }, - [176 /* GetAccessor */]: function forEachChildInGetAccessor(node, cbNode, cbNodes) { + [177 /* GetAccessor */]: function forEachChildInGetAccessor(node, cbNode, cbNodes) { return visitNodes(cbNode, cbNodes, node.modifiers) || visitNode2(cbNode, node.name) || visitNodes(cbNode, cbNodes, node.typeParameters) || visitNodes(cbNode, cbNodes, node.parameters) || visitNode2(cbNode, node.type) || visitNode2(cbNode, node.body); }, - [177 /* SetAccessor */]: function forEachChildInSetAccessor(node, cbNode, cbNodes) { + [178 /* SetAccessor */]: function forEachChildInSetAccessor(node, cbNode, cbNodes) { return visitNodes(cbNode, cbNodes, node.modifiers) || visitNode2(cbNode, node.name) || visitNodes(cbNode, cbNodes, node.typeParameters) || visitNodes(cbNode, cbNodes, node.parameters) || visitNode2(cbNode, node.type) || visitNode2(cbNode, node.body); }, - [261 /* FunctionDeclaration */]: function forEachChildInFunctionDeclaration(node, cbNode, cbNodes) { + [262 /* FunctionDeclaration */]: function forEachChildInFunctionDeclaration(node, cbNode, cbNodes) { return visitNodes(cbNode, cbNodes, node.modifiers) || visitNode2(cbNode, node.asteriskToken) || visitNode2(cbNode, node.name) || visitNodes(cbNode, cbNodes, node.typeParameters) || visitNodes(cbNode, cbNodes, node.parameters) || visitNode2(cbNode, node.type) || visitNode2(cbNode, node.body); }, - [217 /* FunctionExpression */]: function forEachChildInFunctionExpression(node, cbNode, cbNodes) { + [218 /* FunctionExpression */]: function forEachChildInFunctionExpression(node, cbNode, cbNodes) { return visitNodes(cbNode, cbNodes, node.modifiers) || visitNode2(cbNode, node.asteriskToken) || visitNode2(cbNode, node.name) || visitNodes(cbNode, cbNodes, node.typeParameters) || visitNodes(cbNode, cbNodes, node.parameters) || visitNode2(cbNode, node.type) || visitNode2(cbNode, node.body); }, - [218 /* ArrowFunction */]: function forEachChildInArrowFunction(node, cbNode, cbNodes) { + [219 /* ArrowFunction */]: function forEachChildInArrowFunction(node, cbNode, cbNodes) { return visitNodes(cbNode, cbNodes, node.modifiers) || visitNodes(cbNode, cbNodes, node.typeParameters) || visitNodes(cbNode, cbNodes, node.parameters) || visitNode2(cbNode, node.type) || visitNode2(cbNode, node.equalsGreaterThanToken) || visitNode2(cbNode, node.body); }, - [174 /* ClassStaticBlockDeclaration */]: function forEachChildInClassStaticBlockDeclaration(node, cbNode, cbNodes) { + [175 /* ClassStaticBlockDeclaration */]: function forEachChildInClassStaticBlockDeclaration(node, cbNode, cbNodes) { return visitNodes(cbNode, cbNodes, node.modifiers) || visitNode2(cbNode, node.body); }, - [182 /* TypeReference */]: function forEachChildInTypeReference(node, cbNode, cbNodes) { + [183 /* TypeReference */]: function forEachChildInTypeReference(node, cbNode, cbNodes) { return visitNode2(cbNode, node.typeName) || visitNodes(cbNode, cbNodes, node.typeArguments); }, - [181 /* TypePredicate */]: function forEachChildInTypePredicate(node, cbNode, _cbNodes) { + [182 /* TypePredicate */]: function forEachChildInTypePredicate(node, cbNode, _cbNodes) { return visitNode2(cbNode, node.assertsModifier) || visitNode2(cbNode, node.parameterName) || visitNode2(cbNode, node.type); }, - [185 /* TypeQuery */]: function forEachChildInTypeQuery(node, cbNode, cbNodes) { + [186 /* TypeQuery */]: function forEachChildInTypeQuery(node, cbNode, cbNodes) { return visitNode2(cbNode, node.exprName) || visitNodes(cbNode, cbNodes, node.typeArguments); }, - [186 /* TypeLiteral */]: function forEachChildInTypeLiteral(node, cbNode, cbNodes) { + [187 /* TypeLiteral */]: function forEachChildInTypeLiteral(node, cbNode, cbNodes) { return visitNodes(cbNode, cbNodes, node.members); }, - [187 /* ArrayType */]: function forEachChildInArrayType(node, cbNode, _cbNodes) { + [188 /* ArrayType */]: function forEachChildInArrayType(node, cbNode, _cbNodes) { return visitNode2(cbNode, node.elementType); }, - [188 /* TupleType */]: function forEachChildInTupleType(node, cbNode, cbNodes) { + [189 /* TupleType */]: function forEachChildInTupleType(node, cbNode, cbNodes) { return visitNodes(cbNode, cbNodes, node.elements); }, - [191 /* UnionType */]: forEachChildInUnionOrIntersectionType, - [192 /* IntersectionType */]: forEachChildInUnionOrIntersectionType, - [193 /* ConditionalType */]: function forEachChildInConditionalType(node, cbNode, _cbNodes) { + [192 /* UnionType */]: forEachChildInUnionOrIntersectionType, + [193 /* IntersectionType */]: forEachChildInUnionOrIntersectionType, + [194 /* ConditionalType */]: function forEachChildInConditionalType(node, cbNode, _cbNodes) { return visitNode2(cbNode, node.checkType) || visitNode2(cbNode, node.extendsType) || visitNode2(cbNode, node.trueType) || visitNode2(cbNode, node.falseType); }, - [194 /* InferType */]: function forEachChildInInferType(node, cbNode, _cbNodes) { + [195 /* InferType */]: function forEachChildInInferType(node, cbNode, _cbNodes) { return visitNode2(cbNode, node.typeParameter); }, - [204 /* ImportType */]: function forEachChildInImportType(node, cbNode, cbNodes) { - return visitNode2(cbNode, node.argument) || visitNode2(cbNode, node.assertions) || visitNode2(cbNode, node.qualifier) || visitNodes(cbNode, cbNodes, node.typeArguments); + [205 /* ImportType */]: function forEachChildInImportType(node, cbNode, cbNodes) { + return visitNode2(cbNode, node.argument) || visitNode2(cbNode, node.attributes) || visitNode2(cbNode, node.qualifier) || visitNodes(cbNode, cbNodes, node.typeArguments); }, - [301 /* ImportTypeAssertionContainer */]: function forEachChildInImportTypeAssertionContainer(node, cbNode, _cbNodes) { + [302 /* ImportTypeAssertionContainer */]: function forEachChildInImportTypeAssertionContainer(node, cbNode, _cbNodes) { return visitNode2(cbNode, node.assertClause); }, - [195 /* ParenthesizedType */]: forEachChildInParenthesizedTypeOrTypeOperator, - [197 /* TypeOperator */]: forEachChildInParenthesizedTypeOrTypeOperator, - [198 /* IndexedAccessType */]: function forEachChildInIndexedAccessType(node, cbNode, _cbNodes) { + [196 /* ParenthesizedType */]: forEachChildInParenthesizedTypeOrTypeOperator, + [198 /* TypeOperator */]: forEachChildInParenthesizedTypeOrTypeOperator, + [199 /* IndexedAccessType */]: function forEachChildInIndexedAccessType(node, cbNode, _cbNodes) { return visitNode2(cbNode, node.objectType) || visitNode2(cbNode, node.indexType); }, - [199 /* MappedType */]: function forEachChildInMappedType(node, cbNode, cbNodes) { + [200 /* MappedType */]: function forEachChildInMappedType(node, cbNode, cbNodes) { return visitNode2(cbNode, node.readonlyToken) || visitNode2(cbNode, node.typeParameter) || visitNode2(cbNode, node.nameType) || visitNode2(cbNode, node.questionToken) || visitNode2(cbNode, node.type) || visitNodes(cbNode, cbNodes, node.members); }, - [200 /* LiteralType */]: function forEachChildInLiteralType(node, cbNode, _cbNodes) { + [201 /* LiteralType */]: function forEachChildInLiteralType(node, cbNode, _cbNodes) { return visitNode2(cbNode, node.literal); }, - [201 /* NamedTupleMember */]: function forEachChildInNamedTupleMember(node, cbNode, _cbNodes) { + [202 /* NamedTupleMember */]: function forEachChildInNamedTupleMember(node, cbNode, _cbNodes) { return visitNode2(cbNode, node.dotDotDotToken) || visitNode2(cbNode, node.name) || visitNode2(cbNode, node.questionToken) || visitNode2(cbNode, node.type); }, - [205 /* ObjectBindingPattern */]: forEachChildInObjectOrArrayBindingPattern, - [206 /* ArrayBindingPattern */]: forEachChildInObjectOrArrayBindingPattern, - [208 /* ArrayLiteralExpression */]: function forEachChildInArrayLiteralExpression(node, cbNode, cbNodes) { + [206 /* ObjectBindingPattern */]: forEachChildInObjectOrArrayBindingPattern, + [207 /* ArrayBindingPattern */]: forEachChildInObjectOrArrayBindingPattern, + [209 /* ArrayLiteralExpression */]: function forEachChildInArrayLiteralExpression(node, cbNode, cbNodes) { return visitNodes(cbNode, cbNodes, node.elements); }, - [209 /* ObjectLiteralExpression */]: function forEachChildInObjectLiteralExpression(node, cbNode, cbNodes) { + [210 /* ObjectLiteralExpression */]: function forEachChildInObjectLiteralExpression(node, cbNode, cbNodes) { return visitNodes(cbNode, cbNodes, node.properties); }, - [210 /* PropertyAccessExpression */]: function forEachChildInPropertyAccessExpression(node, cbNode, _cbNodes) { + [211 /* PropertyAccessExpression */]: function forEachChildInPropertyAccessExpression(node, cbNode, _cbNodes) { return visitNode2(cbNode, node.expression) || visitNode2(cbNode, node.questionDotToken) || visitNode2(cbNode, node.name); }, - [211 /* ElementAccessExpression */]: function forEachChildInElementAccessExpression(node, cbNode, _cbNodes) { + [212 /* ElementAccessExpression */]: function forEachChildInElementAccessExpression(node, cbNode, _cbNodes) { return visitNode2(cbNode, node.expression) || visitNode2(cbNode, node.questionDotToken) || visitNode2(cbNode, node.argumentExpression); }, - [212 /* CallExpression */]: forEachChildInCallOrNewExpression, - [213 /* NewExpression */]: forEachChildInCallOrNewExpression, - [214 /* TaggedTemplateExpression */]: function forEachChildInTaggedTemplateExpression(node, cbNode, cbNodes) { + [213 /* CallExpression */]: forEachChildInCallOrNewExpression, + [214 /* NewExpression */]: forEachChildInCallOrNewExpression, + [215 /* TaggedTemplateExpression */]: function forEachChildInTaggedTemplateExpression(node, cbNode, cbNodes) { return visitNode2(cbNode, node.tag) || visitNode2(cbNode, node.questionDotToken) || visitNodes(cbNode, cbNodes, node.typeArguments) || visitNode2(cbNode, node.template); }, - [215 /* TypeAssertionExpression */]: function forEachChildInTypeAssertionExpression(node, cbNode, _cbNodes) { + [216 /* TypeAssertionExpression */]: function forEachChildInTypeAssertionExpression(node, cbNode, _cbNodes) { return visitNode2(cbNode, node.type) || visitNode2(cbNode, node.expression); }, - [216 /* ParenthesizedExpression */]: function forEachChildInParenthesizedExpression(node, cbNode, _cbNodes) { + [217 /* ParenthesizedExpression */]: function forEachChildInParenthesizedExpression(node, cbNode, _cbNodes) { return visitNode2(cbNode, node.expression); }, - [219 /* DeleteExpression */]: function forEachChildInDeleteExpression(node, cbNode, _cbNodes) { + [220 /* DeleteExpression */]: function forEachChildInDeleteExpression(node, cbNode, _cbNodes) { return visitNode2(cbNode, node.expression); }, - [220 /* TypeOfExpression */]: function forEachChildInTypeOfExpression(node, cbNode, _cbNodes) { + [221 /* TypeOfExpression */]: function forEachChildInTypeOfExpression(node, cbNode, _cbNodes) { return visitNode2(cbNode, node.expression); }, - [221 /* VoidExpression */]: function forEachChildInVoidExpression(node, cbNode, _cbNodes) { + [222 /* VoidExpression */]: function forEachChildInVoidExpression(node, cbNode, _cbNodes) { return visitNode2(cbNode, node.expression); }, - [223 /* PrefixUnaryExpression */]: function forEachChildInPrefixUnaryExpression(node, cbNode, _cbNodes) { + [224 /* PrefixUnaryExpression */]: function forEachChildInPrefixUnaryExpression(node, cbNode, _cbNodes) { return visitNode2(cbNode, node.operand); }, - [228 /* YieldExpression */]: function forEachChildInYieldExpression(node, cbNode, _cbNodes) { + [229 /* YieldExpression */]: function forEachChildInYieldExpression(node, cbNode, _cbNodes) { return visitNode2(cbNode, node.asteriskToken) || visitNode2(cbNode, node.expression); }, - [222 /* AwaitExpression */]: function forEachChildInAwaitExpression(node, cbNode, _cbNodes) { + [223 /* AwaitExpression */]: function forEachChildInAwaitExpression(node, cbNode, _cbNodes) { return visitNode2(cbNode, node.expression); }, - [224 /* PostfixUnaryExpression */]: function forEachChildInPostfixUnaryExpression(node, cbNode, _cbNodes) { + [225 /* PostfixUnaryExpression */]: function forEachChildInPostfixUnaryExpression(node, cbNode, _cbNodes) { return visitNode2(cbNode, node.operand); }, - [225 /* BinaryExpression */]: function forEachChildInBinaryExpression(node, cbNode, _cbNodes) { + [226 /* BinaryExpression */]: function forEachChildInBinaryExpression(node, cbNode, _cbNodes) { return visitNode2(cbNode, node.left) || visitNode2(cbNode, node.operatorToken) || visitNode2(cbNode, node.right); }, - [233 /* AsExpression */]: function forEachChildInAsExpression(node, cbNode, _cbNodes) { + [234 /* AsExpression */]: function forEachChildInAsExpression(node, cbNode, _cbNodes) { return visitNode2(cbNode, node.expression) || visitNode2(cbNode, node.type); }, - [234 /* NonNullExpression */]: function forEachChildInNonNullExpression(node, cbNode, _cbNodes) { + [235 /* NonNullExpression */]: function forEachChildInNonNullExpression(node, cbNode, _cbNodes) { return visitNode2(cbNode, node.expression); }, - [237 /* SatisfiesExpression */]: function forEachChildInSatisfiesExpression(node, cbNode, _cbNodes) { + [238 /* SatisfiesExpression */]: function forEachChildInSatisfiesExpression(node, cbNode, _cbNodes) { return visitNode2(cbNode, node.expression) || visitNode2(cbNode, node.type); }, - [235 /* MetaProperty */]: function forEachChildInMetaProperty(node, cbNode, _cbNodes) { + [236 /* MetaProperty */]: function forEachChildInMetaProperty(node, cbNode, _cbNodes) { return visitNode2(cbNode, node.name); }, - [226 /* ConditionalExpression */]: function forEachChildInConditionalExpression(node, cbNode, _cbNodes) { + [227 /* ConditionalExpression */]: function forEachChildInConditionalExpression(node, cbNode, _cbNodes) { return visitNode2(cbNode, node.condition) || visitNode2(cbNode, node.questionToken) || visitNode2(cbNode, node.whenTrue) || visitNode2(cbNode, node.colonToken) || visitNode2(cbNode, node.whenFalse); }, - [229 /* SpreadElement */]: function forEachChildInSpreadElement(node, cbNode, _cbNodes) { + [230 /* SpreadElement */]: function forEachChildInSpreadElement(node, cbNode, _cbNodes) { return visitNode2(cbNode, node.expression); }, - [240 /* Block */]: forEachChildInBlock, - [267 /* ModuleBlock */]: forEachChildInBlock, - [311 /* SourceFile */]: function forEachChildInSourceFile(node, cbNode, cbNodes) { + [241 /* Block */]: forEachChildInBlock, + [268 /* ModuleBlock */]: forEachChildInBlock, + [312 /* SourceFile */]: function forEachChildInSourceFile(node, cbNode, cbNodes) { return visitNodes(cbNode, cbNodes, node.statements) || visitNode2(cbNode, node.endOfFileToken); }, - [242 /* VariableStatement */]: function forEachChildInVariableStatement(node, cbNode, cbNodes) { + [243 /* VariableStatement */]: function forEachChildInVariableStatement(node, cbNode, cbNodes) { return visitNodes(cbNode, cbNodes, node.modifiers) || visitNode2(cbNode, node.declarationList); }, - [260 /* VariableDeclarationList */]: function forEachChildInVariableDeclarationList(node, cbNode, cbNodes) { + [261 /* VariableDeclarationList */]: function forEachChildInVariableDeclarationList(node, cbNode, cbNodes) { return visitNodes(cbNode, cbNodes, node.declarations); }, - [243 /* ExpressionStatement */]: function forEachChildInExpressionStatement(node, cbNode, _cbNodes) { + [244 /* ExpressionStatement */]: function forEachChildInExpressionStatement(node, cbNode, _cbNodes) { return visitNode2(cbNode, node.expression); }, - [244 /* IfStatement */]: function forEachChildInIfStatement(node, cbNode, _cbNodes) { + [245 /* IfStatement */]: function forEachChildInIfStatement(node, cbNode, _cbNodes) { return visitNode2(cbNode, node.expression) || visitNode2(cbNode, node.thenStatement) || visitNode2(cbNode, node.elseStatement); }, - [245 /* DoStatement */]: function forEachChildInDoStatement(node, cbNode, _cbNodes) { + [246 /* DoStatement */]: function forEachChildInDoStatement(node, cbNode, _cbNodes) { return visitNode2(cbNode, node.statement) || visitNode2(cbNode, node.expression); }, - [246 /* WhileStatement */]: function forEachChildInWhileStatement(node, cbNode, _cbNodes) { + [247 /* WhileStatement */]: function forEachChildInWhileStatement(node, cbNode, _cbNodes) { return visitNode2(cbNode, node.expression) || visitNode2(cbNode, node.statement); }, - [247 /* ForStatement */]: function forEachChildInForStatement(node, cbNode, _cbNodes) { + [248 /* ForStatement */]: function forEachChildInForStatement(node, cbNode, _cbNodes) { return visitNode2(cbNode, node.initializer) || visitNode2(cbNode, node.condition) || visitNode2(cbNode, node.incrementor) || visitNode2(cbNode, node.statement); }, - [248 /* ForInStatement */]: function forEachChildInForInStatement(node, cbNode, _cbNodes) { + [249 /* ForInStatement */]: function forEachChildInForInStatement(node, cbNode, _cbNodes) { return visitNode2(cbNode, node.initializer) || visitNode2(cbNode, node.expression) || visitNode2(cbNode, node.statement); }, - [249 /* ForOfStatement */]: function forEachChildInForOfStatement(node, cbNode, _cbNodes) { + [250 /* ForOfStatement */]: function forEachChildInForOfStatement(node, cbNode, _cbNodes) { return visitNode2(cbNode, node.awaitModifier) || visitNode2(cbNode, node.initializer) || visitNode2(cbNode, node.expression) || visitNode2(cbNode, node.statement); }, - [250 /* ContinueStatement */]: forEachChildInContinueOrBreakStatement, - [251 /* BreakStatement */]: forEachChildInContinueOrBreakStatement, - [252 /* ReturnStatement */]: function forEachChildInReturnStatement(node, cbNode, _cbNodes) { + [251 /* ContinueStatement */]: forEachChildInContinueOrBreakStatement, + [252 /* BreakStatement */]: forEachChildInContinueOrBreakStatement, + [253 /* ReturnStatement */]: function forEachChildInReturnStatement(node, cbNode, _cbNodes) { return visitNode2(cbNode, node.expression); }, - [253 /* WithStatement */]: function forEachChildInWithStatement(node, cbNode, _cbNodes) { + [254 /* WithStatement */]: function forEachChildInWithStatement(node, cbNode, _cbNodes) { return visitNode2(cbNode, node.expression) || visitNode2(cbNode, node.statement); }, - [254 /* SwitchStatement */]: function forEachChildInSwitchStatement(node, cbNode, _cbNodes) { + [255 /* SwitchStatement */]: function forEachChildInSwitchStatement(node, cbNode, _cbNodes) { return visitNode2(cbNode, node.expression) || visitNode2(cbNode, node.caseBlock); }, - [268 /* CaseBlock */]: function forEachChildInCaseBlock(node, cbNode, cbNodes) { + [269 /* CaseBlock */]: function forEachChildInCaseBlock(node, cbNode, cbNodes) { return visitNodes(cbNode, cbNodes, node.clauses); }, - [295 /* CaseClause */]: function forEachChildInCaseClause(node, cbNode, cbNodes) { + [296 /* CaseClause */]: function forEachChildInCaseClause(node, cbNode, cbNodes) { return visitNode2(cbNode, node.expression) || visitNodes(cbNode, cbNodes, node.statements); }, - [296 /* DefaultClause */]: function forEachChildInDefaultClause(node, cbNode, cbNodes) { + [297 /* DefaultClause */]: function forEachChildInDefaultClause(node, cbNode, cbNodes) { return visitNodes(cbNode, cbNodes, node.statements); }, - [255 /* LabeledStatement */]: function forEachChildInLabeledStatement(node, cbNode, _cbNodes) { + [256 /* LabeledStatement */]: function forEachChildInLabeledStatement(node, cbNode, _cbNodes) { return visitNode2(cbNode, node.label) || visitNode2(cbNode, node.statement); }, - [256 /* ThrowStatement */]: function forEachChildInThrowStatement(node, cbNode, _cbNodes) { + [257 /* ThrowStatement */]: function forEachChildInThrowStatement(node, cbNode, _cbNodes) { return visitNode2(cbNode, node.expression); }, - [257 /* TryStatement */]: function forEachChildInTryStatement(node, cbNode, _cbNodes) { + [258 /* TryStatement */]: function forEachChildInTryStatement(node, cbNode, _cbNodes) { return visitNode2(cbNode, node.tryBlock) || visitNode2(cbNode, node.catchClause) || visitNode2(cbNode, node.finallyBlock); }, - [298 /* CatchClause */]: function forEachChildInCatchClause(node, cbNode, _cbNodes) { + [299 /* CatchClause */]: function forEachChildInCatchClause(node, cbNode, _cbNodes) { return visitNode2(cbNode, node.variableDeclaration) || visitNode2(cbNode, node.block); }, - [169 /* Decorator */]: function forEachChildInDecorator(node, cbNode, _cbNodes) { + [170 /* Decorator */]: function forEachChildInDecorator(node, cbNode, _cbNodes) { return visitNode2(cbNode, node.expression); }, - [262 /* ClassDeclaration */]: forEachChildInClassDeclarationOrExpression, - [230 /* ClassExpression */]: forEachChildInClassDeclarationOrExpression, - [263 /* InterfaceDeclaration */]: function forEachChildInInterfaceDeclaration(node, cbNode, cbNodes) { + [263 /* ClassDeclaration */]: forEachChildInClassDeclarationOrExpression, + [231 /* ClassExpression */]: forEachChildInClassDeclarationOrExpression, + [264 /* InterfaceDeclaration */]: function forEachChildInInterfaceDeclaration(node, cbNode, cbNodes) { return visitNodes(cbNode, cbNodes, node.modifiers) || visitNode2(cbNode, node.name) || visitNodes(cbNode, cbNodes, node.typeParameters) || visitNodes(cbNode, cbNodes, node.heritageClauses) || visitNodes(cbNode, cbNodes, node.members); }, - [264 /* TypeAliasDeclaration */]: function forEachChildInTypeAliasDeclaration(node, cbNode, cbNodes) { + [265 /* TypeAliasDeclaration */]: function forEachChildInTypeAliasDeclaration(node, cbNode, cbNodes) { return visitNodes(cbNode, cbNodes, node.modifiers) || visitNode2(cbNode, node.name) || visitNodes(cbNode, cbNodes, node.typeParameters) || visitNode2(cbNode, node.type); }, - [265 /* EnumDeclaration */]: function forEachChildInEnumDeclaration(node, cbNode, cbNodes) { + [266 /* EnumDeclaration */]: function forEachChildInEnumDeclaration(node, cbNode, cbNodes) { return visitNodes(cbNode, cbNodes, node.modifiers) || visitNode2(cbNode, node.name) || visitNodes(cbNode, cbNodes, node.members); }, - [305 /* EnumMember */]: function forEachChildInEnumMember(node, cbNode, _cbNodes) { + [306 /* EnumMember */]: function forEachChildInEnumMember(node, cbNode, _cbNodes) { return visitNode2(cbNode, node.name) || visitNode2(cbNode, node.initializer); }, - [266 /* ModuleDeclaration */]: function forEachChildInModuleDeclaration(node, cbNode, cbNodes) { + [267 /* ModuleDeclaration */]: function forEachChildInModuleDeclaration(node, cbNode, cbNodes) { return visitNodes(cbNode, cbNodes, node.modifiers) || visitNode2(cbNode, node.name) || visitNode2(cbNode, node.body); }, - [270 /* ImportEqualsDeclaration */]: function forEachChildInImportEqualsDeclaration(node, cbNode, cbNodes) { + [271 /* ImportEqualsDeclaration */]: function forEachChildInImportEqualsDeclaration(node, cbNode, cbNodes) { return visitNodes(cbNode, cbNodes, node.modifiers) || visitNode2(cbNode, node.name) || visitNode2(cbNode, node.moduleReference); }, - [271 /* ImportDeclaration */]: function forEachChildInImportDeclaration(node, cbNode, cbNodes) { - return visitNodes(cbNode, cbNodes, node.modifiers) || visitNode2(cbNode, node.importClause) || visitNode2(cbNode, node.moduleSpecifier) || visitNode2(cbNode, node.assertClause); + [272 /* ImportDeclaration */]: function forEachChildInImportDeclaration(node, cbNode, cbNodes) { + return visitNodes(cbNode, cbNodes, node.modifiers) || visitNode2(cbNode, node.importClause) || visitNode2(cbNode, node.moduleSpecifier) || visitNode2(cbNode, node.attributes); }, - [272 /* ImportClause */]: function forEachChildInImportClause(node, cbNode, _cbNodes) { + [273 /* ImportClause */]: function forEachChildInImportClause(node, cbNode, _cbNodes) { return visitNode2(cbNode, node.name) || visitNode2(cbNode, node.namedBindings); }, - [299 /* AssertClause */]: function forEachChildInAssertClause(node, cbNode, cbNodes) { + [300 /* ImportAttributes */]: function forEachChildInImportAttributes(node, cbNode, cbNodes) { return visitNodes(cbNode, cbNodes, node.elements); }, - [300 /* AssertEntry */]: function forEachChildInAssertEntry(node, cbNode, _cbNodes) { + [301 /* ImportAttribute */]: function forEachChildInImportAttribute(node, cbNode, _cbNodes) { return visitNode2(cbNode, node.name) || visitNode2(cbNode, node.value); }, - [269 /* NamespaceExportDeclaration */]: function forEachChildInNamespaceExportDeclaration(node, cbNode, cbNodes) { + [270 /* NamespaceExportDeclaration */]: function forEachChildInNamespaceExportDeclaration(node, cbNode, cbNodes) { return visitNodes(cbNode, cbNodes, node.modifiers) || visitNode2(cbNode, node.name); }, - [273 /* NamespaceImport */]: function forEachChildInNamespaceImport(node, cbNode, _cbNodes) { + [274 /* NamespaceImport */]: function forEachChildInNamespaceImport(node, cbNode, _cbNodes) { return visitNode2(cbNode, node.name); }, - [279 /* NamespaceExport */]: function forEachChildInNamespaceExport(node, cbNode, _cbNodes) { + [280 /* NamespaceExport */]: function forEachChildInNamespaceExport(node, cbNode, _cbNodes) { return visitNode2(cbNode, node.name); }, - [274 /* NamedImports */]: forEachChildInNamedImportsOrExports, - [278 /* NamedExports */]: forEachChildInNamedImportsOrExports, - [277 /* ExportDeclaration */]: function forEachChildInExportDeclaration(node, cbNode, cbNodes) { - return visitNodes(cbNode, cbNodes, node.modifiers) || visitNode2(cbNode, node.exportClause) || visitNode2(cbNode, node.moduleSpecifier) || visitNode2(cbNode, node.assertClause); + [275 /* NamedImports */]: forEachChildInNamedImportsOrExports, + [279 /* NamedExports */]: forEachChildInNamedImportsOrExports, + [278 /* ExportDeclaration */]: function forEachChildInExportDeclaration(node, cbNode, cbNodes) { + return visitNodes(cbNode, cbNodes, node.modifiers) || visitNode2(cbNode, node.exportClause) || visitNode2(cbNode, node.moduleSpecifier) || visitNode2(cbNode, node.attributes); }, - [275 /* ImportSpecifier */]: forEachChildInImportOrExportSpecifier, - [280 /* ExportSpecifier */]: forEachChildInImportOrExportSpecifier, - [276 /* ExportAssignment */]: function forEachChildInExportAssignment(node, cbNode, cbNodes) { + [276 /* ImportSpecifier */]: forEachChildInImportOrExportSpecifier, + [281 /* ExportSpecifier */]: forEachChildInImportOrExportSpecifier, + [277 /* ExportAssignment */]: function forEachChildInExportAssignment(node, cbNode, cbNodes) { return visitNodes(cbNode, cbNodes, node.modifiers) || visitNode2(cbNode, node.expression); }, - [227 /* TemplateExpression */]: function forEachChildInTemplateExpression(node, cbNode, cbNodes) { + [228 /* TemplateExpression */]: function forEachChildInTemplateExpression(node, cbNode, cbNodes) { return visitNode2(cbNode, node.head) || visitNodes(cbNode, cbNodes, node.templateSpans); }, - [238 /* TemplateSpan */]: function forEachChildInTemplateSpan(node, cbNode, _cbNodes) { + [239 /* TemplateSpan */]: function forEachChildInTemplateSpan(node, cbNode, _cbNodes) { return visitNode2(cbNode, node.expression) || visitNode2(cbNode, node.literal); }, - [202 /* TemplateLiteralType */]: function forEachChildInTemplateLiteralType(node, cbNode, cbNodes) { + [203 /* TemplateLiteralType */]: function forEachChildInTemplateLiteralType(node, cbNode, cbNodes) { return visitNode2(cbNode, node.head) || visitNodes(cbNode, cbNodes, node.templateSpans); }, - [203 /* TemplateLiteralTypeSpan */]: function forEachChildInTemplateLiteralTypeSpan(node, cbNode, _cbNodes) { + [204 /* TemplateLiteralTypeSpan */]: function forEachChildInTemplateLiteralTypeSpan(node, cbNode, _cbNodes) { return visitNode2(cbNode, node.type) || visitNode2(cbNode, node.literal); }, - [166 /* ComputedPropertyName */]: function forEachChildInComputedPropertyName(node, cbNode, _cbNodes) { + [167 /* ComputedPropertyName */]: function forEachChildInComputedPropertyName(node, cbNode, _cbNodes) { return visitNode2(cbNode, node.expression); }, - [297 /* HeritageClause */]: function forEachChildInHeritageClause(node, cbNode, cbNodes) { + [298 /* HeritageClause */]: function forEachChildInHeritageClause(node, cbNode, cbNodes) { return visitNodes(cbNode, cbNodes, node.types); }, - [232 /* ExpressionWithTypeArguments */]: function forEachChildInExpressionWithTypeArguments(node, cbNode, cbNodes) { + [233 /* ExpressionWithTypeArguments */]: function forEachChildInExpressionWithTypeArguments(node, cbNode, cbNodes) { return visitNode2(cbNode, node.expression) || visitNodes(cbNode, cbNodes, node.typeArguments); }, - [282 /* ExternalModuleReference */]: function forEachChildInExternalModuleReference(node, cbNode, _cbNodes) { + [283 /* ExternalModuleReference */]: function forEachChildInExternalModuleReference(node, cbNode, _cbNodes) { return visitNode2(cbNode, node.expression); }, - [281 /* MissingDeclaration */]: function forEachChildInMissingDeclaration(node, cbNode, cbNodes) { + [282 /* MissingDeclaration */]: function forEachChildInMissingDeclaration(node, cbNode, cbNodes) { return visitNodes(cbNode, cbNodes, node.modifiers); }, - [360 /* CommaListExpression */]: function forEachChildInCommaListExpression(node, cbNode, cbNodes) { + [361 /* CommaListExpression */]: function forEachChildInCommaListExpression(node, cbNode, cbNodes) { return visitNodes(cbNode, cbNodes, node.elements); }, - [283 /* JsxElement */]: function forEachChildInJsxElement(node, cbNode, cbNodes) { + [284 /* JsxElement */]: function forEachChildInJsxElement(node, cbNode, cbNodes) { return visitNode2(cbNode, node.openingElement) || visitNodes(cbNode, cbNodes, node.children) || visitNode2(cbNode, node.closingElement); }, - [287 /* JsxFragment */]: function forEachChildInJsxFragment(node, cbNode, cbNodes) { + [288 /* JsxFragment */]: function forEachChildInJsxFragment(node, cbNode, cbNodes) { return visitNode2(cbNode, node.openingFragment) || visitNodes(cbNode, cbNodes, node.children) || visitNode2(cbNode, node.closingFragment); }, - [284 /* JsxSelfClosingElement */]: forEachChildInJsxOpeningOrSelfClosingElement, - [285 /* JsxOpeningElement */]: forEachChildInJsxOpeningOrSelfClosingElement, - [291 /* JsxAttributes */]: function forEachChildInJsxAttributes(node, cbNode, cbNodes) { + [285 /* JsxSelfClosingElement */]: forEachChildInJsxOpeningOrSelfClosingElement, + [286 /* JsxOpeningElement */]: forEachChildInJsxOpeningOrSelfClosingElement, + [292 /* JsxAttributes */]: function forEachChildInJsxAttributes(node, cbNode, cbNodes) { return visitNodes(cbNode, cbNodes, node.properties); }, - [290 /* JsxAttribute */]: function forEachChildInJsxAttribute(node, cbNode, _cbNodes) { + [291 /* JsxAttribute */]: function forEachChildInJsxAttribute(node, cbNode, _cbNodes) { return visitNode2(cbNode, node.name) || visitNode2(cbNode, node.initializer); }, - [292 /* JsxSpreadAttribute */]: function forEachChildInJsxSpreadAttribute(node, cbNode, _cbNodes) { + [293 /* JsxSpreadAttribute */]: function forEachChildInJsxSpreadAttribute(node, cbNode, _cbNodes) { return visitNode2(cbNode, node.expression); }, - [293 /* JsxExpression */]: function forEachChildInJsxExpression(node, cbNode, _cbNodes) { + [294 /* JsxExpression */]: function forEachChildInJsxExpression(node, cbNode, _cbNodes) { return visitNode2(cbNode, node.dotDotDotToken) || visitNode2(cbNode, node.expression); }, - [286 /* JsxClosingElement */]: function forEachChildInJsxClosingElement(node, cbNode, _cbNodes) { + [287 /* JsxClosingElement */]: function forEachChildInJsxClosingElement(node, cbNode, _cbNodes) { return visitNode2(cbNode, node.tagName); }, - [294 /* JsxNamespacedName */]: function forEachChildInJsxNamespacedName(node, cbNode, _cbNodes) { + [295 /* JsxNamespacedName */]: function forEachChildInJsxNamespacedName(node, cbNode, _cbNodes) { return visitNode2(cbNode, node.namespace) || visitNode2(cbNode, node.name); }, - [189 /* OptionalType */]: forEachChildInOptionalRestOrJSDocParameterModifier, - [190 /* RestType */]: forEachChildInOptionalRestOrJSDocParameterModifier, - [315 /* JSDocTypeExpression */]: forEachChildInOptionalRestOrJSDocParameterModifier, - [321 /* JSDocNonNullableType */]: forEachChildInOptionalRestOrJSDocParameterModifier, - [320 /* JSDocNullableType */]: forEachChildInOptionalRestOrJSDocParameterModifier, - [322 /* JSDocOptionalType */]: forEachChildInOptionalRestOrJSDocParameterModifier, - [324 /* JSDocVariadicType */]: forEachChildInOptionalRestOrJSDocParameterModifier, - [323 /* JSDocFunctionType */]: function forEachChildInJSDocFunctionType(node, cbNode, cbNodes) { + [190 /* OptionalType */]: forEachChildInOptionalRestOrJSDocParameterModifier, + [191 /* RestType */]: forEachChildInOptionalRestOrJSDocParameterModifier, + [316 /* JSDocTypeExpression */]: forEachChildInOptionalRestOrJSDocParameterModifier, + [322 /* JSDocNonNullableType */]: forEachChildInOptionalRestOrJSDocParameterModifier, + [321 /* JSDocNullableType */]: forEachChildInOptionalRestOrJSDocParameterModifier, + [323 /* JSDocOptionalType */]: forEachChildInOptionalRestOrJSDocParameterModifier, + [325 /* JSDocVariadicType */]: forEachChildInOptionalRestOrJSDocParameterModifier, + [324 /* JSDocFunctionType */]: function forEachChildInJSDocFunctionType(node, cbNode, cbNodes) { return visitNodes(cbNode, cbNodes, node.parameters) || visitNode2(cbNode, node.type); }, - [326 /* JSDoc */]: function forEachChildInJSDoc(node, cbNode, cbNodes) { + [327 /* JSDoc */]: function forEachChildInJSDoc(node, cbNode, cbNodes) { return (typeof node.comment === "string" ? void 0 : visitNodes(cbNode, cbNodes, node.comment)) || visitNodes(cbNode, cbNodes, node.tags); }, - [353 /* JSDocSeeTag */]: function forEachChildInJSDocSeeTag(node, cbNode, cbNodes) { + [354 /* JSDocSeeTag */]: function forEachChildInJSDocSeeTag(node, cbNode, cbNodes) { return visitNode2(cbNode, node.tagName) || visitNode2(cbNode, node.name) || (typeof node.comment === "string" ? void 0 : visitNodes(cbNode, cbNodes, node.comment)); }, - [316 /* JSDocNameReference */]: function forEachChildInJSDocNameReference(node, cbNode, _cbNodes) { + [317 /* JSDocNameReference */]: function forEachChildInJSDocNameReference(node, cbNode, _cbNodes) { return visitNode2(cbNode, node.name); }, - [317 /* JSDocMemberName */]: function forEachChildInJSDocMemberName(node, cbNode, _cbNodes) { + [318 /* JSDocMemberName */]: function forEachChildInJSDocMemberName(node, cbNode, _cbNodes) { return visitNode2(cbNode, node.left) || visitNode2(cbNode, node.right); }, - [347 /* JSDocParameterTag */]: forEachChildInJSDocParameterOrPropertyTag, - [354 /* JSDocPropertyTag */]: forEachChildInJSDocParameterOrPropertyTag, - [336 /* JSDocAuthorTag */]: function forEachChildInJSDocAuthorTag(node, cbNode, cbNodes) { + [348 /* JSDocParameterTag */]: forEachChildInJSDocParameterOrPropertyTag, + [355 /* JSDocPropertyTag */]: forEachChildInJSDocParameterOrPropertyTag, + [337 /* JSDocAuthorTag */]: function forEachChildInJSDocAuthorTag(node, cbNode, cbNodes) { return visitNode2(cbNode, node.tagName) || (typeof node.comment === "string" ? void 0 : visitNodes(cbNode, cbNodes, node.comment)); }, - [335 /* JSDocImplementsTag */]: function forEachChildInJSDocImplementsTag(node, cbNode, cbNodes) { + [336 /* JSDocImplementsTag */]: function forEachChildInJSDocImplementsTag(node, cbNode, cbNodes) { return visitNode2(cbNode, node.tagName) || visitNode2(cbNode, node.class) || (typeof node.comment === "string" ? void 0 : visitNodes(cbNode, cbNodes, node.comment)); }, - [334 /* JSDocAugmentsTag */]: function forEachChildInJSDocAugmentsTag(node, cbNode, cbNodes) { + [335 /* JSDocAugmentsTag */]: function forEachChildInJSDocAugmentsTag(node, cbNode, cbNodes) { return visitNode2(cbNode, node.tagName) || visitNode2(cbNode, node.class) || (typeof node.comment === "string" ? void 0 : visitNodes(cbNode, cbNodes, node.comment)); }, - [351 /* JSDocTemplateTag */]: function forEachChildInJSDocTemplateTag(node, cbNode, cbNodes) { + [352 /* JSDocTemplateTag */]: function forEachChildInJSDocTemplateTag(node, cbNode, cbNodes) { return visitNode2(cbNode, node.tagName) || visitNode2(cbNode, node.constraint) || visitNodes(cbNode, cbNodes, node.typeParameters) || (typeof node.comment === "string" ? void 0 : visitNodes(cbNode, cbNodes, node.comment)); }, - [352 /* JSDocTypedefTag */]: function forEachChildInJSDocTypedefTag(node, cbNode, cbNodes) { - return visitNode2(cbNode, node.tagName) || (node.typeExpression && node.typeExpression.kind === 315 /* JSDocTypeExpression */ ? visitNode2(cbNode, node.typeExpression) || visitNode2(cbNode, node.fullName) || (typeof node.comment === "string" ? void 0 : visitNodes(cbNode, cbNodes, node.comment)) : visitNode2(cbNode, node.fullName) || visitNode2(cbNode, node.typeExpression) || (typeof node.comment === "string" ? void 0 : visitNodes(cbNode, cbNodes, node.comment))); + [353 /* JSDocTypedefTag */]: function forEachChildInJSDocTypedefTag(node, cbNode, cbNodes) { + return visitNode2(cbNode, node.tagName) || (node.typeExpression && node.typeExpression.kind === 316 /* JSDocTypeExpression */ ? visitNode2(cbNode, node.typeExpression) || visitNode2(cbNode, node.fullName) || (typeof node.comment === "string" ? void 0 : visitNodes(cbNode, cbNodes, node.comment)) : visitNode2(cbNode, node.fullName) || visitNode2(cbNode, node.typeExpression) || (typeof node.comment === "string" ? void 0 : visitNodes(cbNode, cbNodes, node.comment))); }, - [344 /* JSDocCallbackTag */]: function forEachChildInJSDocCallbackTag(node, cbNode, cbNodes) { + [345 /* JSDocCallbackTag */]: function forEachChildInJSDocCallbackTag(node, cbNode, cbNodes) { return visitNode2(cbNode, node.tagName) || visitNode2(cbNode, node.fullName) || visitNode2(cbNode, node.typeExpression) || (typeof node.comment === "string" ? void 0 : visitNodes(cbNode, cbNodes, node.comment)); }, - [348 /* JSDocReturnTag */]: forEachChildInJSDocTypeLikeTag, - [350 /* JSDocTypeTag */]: forEachChildInJSDocTypeLikeTag, - [349 /* JSDocThisTag */]: forEachChildInJSDocTypeLikeTag, - [346 /* JSDocEnumTag */]: forEachChildInJSDocTypeLikeTag, - [356 /* JSDocSatisfiesTag */]: forEachChildInJSDocTypeLikeTag, - [355 /* JSDocThrowsTag */]: forEachChildInJSDocTypeLikeTag, - [345 /* JSDocOverloadTag */]: forEachChildInJSDocTypeLikeTag, - [329 /* JSDocSignature */]: function forEachChildInJSDocSignature(node, cbNode, _cbNodes) { + [349 /* JSDocReturnTag */]: forEachChildInJSDocTypeLikeTag, + [351 /* JSDocTypeTag */]: forEachChildInJSDocTypeLikeTag, + [350 /* JSDocThisTag */]: forEachChildInJSDocTypeLikeTag, + [347 /* JSDocEnumTag */]: forEachChildInJSDocTypeLikeTag, + [357 /* JSDocSatisfiesTag */]: forEachChildInJSDocTypeLikeTag, + [356 /* JSDocThrowsTag */]: forEachChildInJSDocTypeLikeTag, + [346 /* JSDocOverloadTag */]: forEachChildInJSDocTypeLikeTag, + [330 /* JSDocSignature */]: function forEachChildInJSDocSignature(node, cbNode, _cbNodes) { return forEach(node.typeParameters, cbNode) || forEach(node.parameters, cbNode) || visitNode2(cbNode, node.type); }, - [330 /* JSDocLink */]: forEachChildInJSDocLinkCodeOrPlain, - [331 /* JSDocLinkCode */]: forEachChildInJSDocLinkCodeOrPlain, - [332 /* JSDocLinkPlain */]: forEachChildInJSDocLinkCodeOrPlain, - [328 /* JSDocTypeLiteral */]: function forEachChildInJSDocTypeLiteral(node, cbNode, _cbNodes) { + [331 /* JSDocLink */]: forEachChildInJSDocLinkCodeOrPlain, + [332 /* JSDocLinkCode */]: forEachChildInJSDocLinkCodeOrPlain, + [333 /* JSDocLinkPlain */]: forEachChildInJSDocLinkCodeOrPlain, + [329 /* JSDocTypeLiteral */]: function forEachChildInJSDocTypeLiteral(node, cbNode, _cbNodes) { return forEach(node.jsDocPropertyTags, cbNode); }, - [333 /* JSDocTag */]: forEachChildInJSDocTag, - [338 /* JSDocClassTag */]: forEachChildInJSDocTag, - [339 /* JSDocPublicTag */]: forEachChildInJSDocTag, - [340 /* JSDocPrivateTag */]: forEachChildInJSDocTag, - [341 /* JSDocProtectedTag */]: forEachChildInJSDocTag, - [342 /* JSDocReadonlyTag */]: forEachChildInJSDocTag, - [337 /* JSDocDeprecatedTag */]: forEachChildInJSDocTag, - [343 /* JSDocOverrideTag */]: forEachChildInJSDocTag, - [359 /* PartiallyEmittedExpression */]: forEachChildInPartiallyEmittedExpression + [334 /* JSDocTag */]: forEachChildInJSDocTag, + [339 /* JSDocClassTag */]: forEachChildInJSDocTag, + [340 /* JSDocPublicTag */]: forEachChildInJSDocTag, + [341 /* JSDocPrivateTag */]: forEachChildInJSDocTag, + [342 /* JSDocProtectedTag */]: forEachChildInJSDocTag, + [343 /* JSDocReadonlyTag */]: forEachChildInJSDocTag, + [338 /* JSDocDeprecatedTag */]: forEachChildInJSDocTag, + [344 /* JSDocOverrideTag */]: forEachChildInJSDocTag, + [360 /* PartiallyEmittedExpression */]: forEachChildInPartiallyEmittedExpression }; ((Parser2) => { var scanner2 = createScanner( @@ -127636,7 +110623,7 @@ ${lanes.join("\n")} /*skipTrivia*/ true ); - var disallowInAndDecoratorContext = 4096 /* DisallowInContext */ | 16384 /* DecoratorContext */; + var disallowInAndDecoratorContext = 8192 /* DisallowInContext */ | 32768 /* DecoratorContext */; var NodeConstructor2; var TokenConstructor2; var IdentifierConstructor2; @@ -127730,7 +110717,7 @@ ${lanes.join("\n")} var contextFlags; var topLevel = true; var parseErrorBeforeNextFinishedNode = false; - function parseSourceFile(fileName2, sourceText2, languageVersion2, syntaxCursor2, setParentNodes = false, scriptKind2, setExternalModuleIndicatorOverride) { + function parseSourceFile(fileName2, sourceText2, languageVersion2, syntaxCursor2, setParentNodes = false, scriptKind2, setExternalModuleIndicatorOverride, jsDocParsingMode = 0 /* ParseAll */) { var _a; scriptKind2 = ensureScriptKind(fileName2, scriptKind2); if (scriptKind2 === 6 /* JSON */) { @@ -127752,8 +110739,8 @@ ${lanes.join("\n")} result2.pragmas = emptyMap; return result2; } - initializeState(fileName2, sourceText2, languageVersion2, syntaxCursor2, scriptKind2); - const result = parseSourceFileWorker(languageVersion2, setParentNodes, scriptKind2, setExternalModuleIndicatorOverride || setExternalModuleIndicator); + initializeState(fileName2, sourceText2, languageVersion2, syntaxCursor2, scriptKind2, jsDocParsingMode); + const result = parseSourceFileWorker(languageVersion2, setParentNodes, scriptKind2, setExternalModuleIndicatorOverride || setExternalModuleIndicator, jsDocParsingMode); clearState(); return result; } @@ -127765,20 +110752,21 @@ ${lanes.join("\n")} languageVersion2, /*syntaxCursor*/ void 0, - 1 /* JS */ + 1 /* JS */, + 0 /* ParseAll */ ); nextToken(); const entityName = parseEntityName( /*allowReservedWords*/ true ); - const isInvalid = token() === 1 /* EndOfFileToken */ && !parseDiagnostics.length; + const isValid = token() === 1 /* EndOfFileToken */ && !parseDiagnostics.length; clearState(); - return isInvalid ? entityName : void 0; + return isValid ? entityName : void 0; } Parser2.parseIsolatedEntityName = parseIsolatedEntityName2; function parseJsonText2(fileName2, sourceText2, languageVersion2 = 2 /* ES2015 */, syntaxCursor2, setParentNodes = false) { - initializeState(fileName2, sourceText2, languageVersion2, syntaxCursor2, 6 /* JSON */); + initializeState(fileName2, sourceText2, languageVersion2, syntaxCursor2, 6 /* JSON */, 0 /* ParseAll */); sourceFlags = contextFlags; nextToken(); const pos = getNodePos(); @@ -127859,7 +110847,7 @@ ${lanes.join("\n")} return result; } Parser2.parseJsonText = parseJsonText2; - function initializeState(_fileName, _sourceText, _languageVersion, _syntaxCursor, _scriptKind) { + function initializeState(_fileName, _sourceText, _languageVersion, _syntaxCursor, _scriptKind, _jsDocParsingMode) { NodeConstructor2 = objectAllocator.getNodeConstructor(); TokenConstructor2 = objectAllocator.getTokenConstructor(); IdentifierConstructor2 = objectAllocator.getIdentifierConstructor(); @@ -127881,10 +110869,10 @@ ${lanes.join("\n")} switch (scriptKind) { case 1 /* JS */: case 2 /* JSX */: - contextFlags = 262144 /* JavaScriptFile */; + contextFlags = 524288 /* JavaScriptFile */; break; case 6 /* JSON */: - contextFlags = 262144 /* JavaScriptFile */ | 67108864 /* JsonFile */; + contextFlags = 524288 /* JavaScriptFile */ | 134217728 /* JsonFile */; break; default: contextFlags = 0 /* None */; @@ -127895,11 +110883,15 @@ ${lanes.join("\n")} scanner2.setOnError(scanError); scanner2.setScriptTarget(languageVersion); scanner2.setLanguageVariant(languageVariant); + scanner2.setScriptKind(scriptKind); + scanner2.setJSDocParsingMode(_jsDocParsingMode); } function clearState() { scanner2.clearCommentDirectives(); scanner2.setText(""); scanner2.setOnError(void 0); + scanner2.setScriptKind(0 /* Unknown */); + scanner2.setJSDocParsingMode(0 /* ParseAll */); sourceText = void 0; languageVersion = void 0; syntaxCursor = void 0; @@ -127913,16 +110905,17 @@ ${lanes.join("\n")} notParenthesizedArrow = void 0; topLevel = true; } - function parseSourceFileWorker(languageVersion2, setParentNodes, scriptKind2, setExternalModuleIndicator2) { + function parseSourceFileWorker(languageVersion2, setParentNodes, scriptKind2, setExternalModuleIndicator2, jsDocParsingMode) { const isDeclarationFile = isDeclarationFileName(fileName); if (isDeclarationFile) { - contextFlags |= 16777216 /* Ambient */; + contextFlags |= 33554432 /* Ambient */; } sourceFlags = contextFlags; nextToken(); const statements = parseList(0 /* SourceElements */, parseStatement); Debug.assert(token() === 1 /* EndOfFileToken */); - const endOfFileToken = addJSDocComment(parseTokenNode()); + const endHasJSDoc = hasPrecedingJSDocComment(); + const endOfFileToken = withJSDoc(parseTokenNode(), endHasJSDoc); const sourceFile = createSourceFile2(fileName, languageVersion2, scriptKind2, isDeclarationFile, statements, endOfFileToken, sourceFlags, setExternalModuleIndicator2); processCommentPragmas(sourceFile, sourceText); processPragmasIntoFields(sourceFile, reportPragmaDiagnostic); @@ -127931,6 +110924,7 @@ ${lanes.join("\n")} sourceFile.identifierCount = identifierCount; sourceFile.identifiers = identifiers; sourceFile.parseDiagnostics = attachFileToDiagnostics(parseDiagnostics, sourceFile); + sourceFile.jsDocParsingMode = jsDocParsingMode; if (jsDocDiagnostics) { sourceFile.jsDocDiagnostics = attachFileToDiagnostics(jsDocDiagnostics, sourceFile); } @@ -127939,21 +110933,21 @@ ${lanes.join("\n")} } return sourceFile; function reportPragmaDiagnostic(pos, end, diagnostic) { - parseDiagnostics.push(createDetachedDiagnostic(fileName, pos, end, diagnostic)); + parseDiagnostics.push(createDetachedDiagnostic(fileName, sourceText, pos, end, diagnostic)); } } - function withJSDoc(node, hasJSDoc) { - return hasJSDoc ? addJSDocComment(node) : node; - } let hasDeprecatedTag = false; - function addJSDocComment(node) { + function withJSDoc(node, hasJSDoc) { + if (!hasJSDoc) { + return node; + } Debug.assert(!node.jsDoc); const jsDoc = mapDefined(getJSDocCommentRanges(node, sourceText), (comment) => JSDocParser.parseJSDocComment(node, comment.pos, comment.end - comment.pos)); if (jsDoc.length) node.jsDoc = jsDoc; if (hasDeprecatedTag) { hasDeprecatedTag = false; - node.flags |= 268435456 /* Deprecated */; + node.flags |= 536870912 /* Deprecated */; } return node; } @@ -127978,7 +110972,7 @@ ${lanes.join("\n")} } speculationHelper(() => { const savedContextFlags = contextFlags; - contextFlags |= 32768 /* AwaitContext */; + contextFlags |= 65536 /* AwaitContext */; scanner2.resetTokenState(nextStatement.pos); nextToken(); while (token() !== 1 /* EndOfFileToken */) { @@ -128013,7 +111007,7 @@ ${lanes.join("\n")} syntaxCursor = savedSyntaxCursor; return factory2.updateSourceFile(sourceFile, setTextRange(factoryCreateNodeArray(statements), sourceFile.statements)); function containsPossibleTopLevelAwait(node) { - return !(node.flags & 32768 /* AwaitContext */) && !!(node.transformFlags & 67108864 /* ContainsPossibleTopLevelAwait */); + return !(node.flags & 65536 /* AwaitContext */) && !!(node.transformFlags & 67108864 /* ContainsPossibleTopLevelAwait */); } function findNextStatementWithAwait(statements2, start2) { for (let i = start2; i < statements2.length; i++) { @@ -128077,16 +111071,16 @@ ${lanes.join("\n")} } } function setDisallowInContext(val) { - setContextFlag(val, 4096 /* DisallowInContext */); + setContextFlag(val, 8192 /* DisallowInContext */); } function setYieldContext(val) { - setContextFlag(val, 8192 /* YieldContext */); + setContextFlag(val, 16384 /* YieldContext */); } function setDecoratorContext(val) { - setContextFlag(val, 16384 /* DecoratorContext */); + setContextFlag(val, 32768 /* DecoratorContext */); } function setAwaitContext(val) { - setContextFlag(val, 32768 /* AwaitContext */); + setContextFlag(val, 65536 /* AwaitContext */); } function doOutsideOfContext(context, func) { const contextFlagsToClear = context & contextFlags; @@ -128125,52 +111119,52 @@ ${lanes.join("\n")} return func(); } function allowInAnd(func) { - return doOutsideOfContext(4096 /* DisallowInContext */, func); + return doOutsideOfContext(8192 /* DisallowInContext */, func); } function disallowInAnd(func) { - return doInsideOfContext(4096 /* DisallowInContext */, func); + return doInsideOfContext(8192 /* DisallowInContext */, func); } function allowConditionalTypesAnd(func) { - return doOutsideOfContext(65536 /* DisallowConditionalTypesContext */, func); + return doOutsideOfContext(131072 /* DisallowConditionalTypesContext */, func); } function disallowConditionalTypesAnd(func) { - return doInsideOfContext(65536 /* DisallowConditionalTypesContext */, func); + return doInsideOfContext(131072 /* DisallowConditionalTypesContext */, func); } function doInYieldContext(func) { - return doInsideOfContext(8192 /* YieldContext */, func); + return doInsideOfContext(16384 /* YieldContext */, func); } function doInDecoratorContext(func) { - return doInsideOfContext(16384 /* DecoratorContext */, func); + return doInsideOfContext(32768 /* DecoratorContext */, func); } function doInAwaitContext(func) { - return doInsideOfContext(32768 /* AwaitContext */, func); + return doInsideOfContext(65536 /* AwaitContext */, func); } function doOutsideOfAwaitContext(func) { - return doOutsideOfContext(32768 /* AwaitContext */, func); + return doOutsideOfContext(65536 /* AwaitContext */, func); } function doInYieldAndAwaitContext(func) { - return doInsideOfContext(8192 /* YieldContext */ | 32768 /* AwaitContext */, func); + return doInsideOfContext(16384 /* YieldContext */ | 65536 /* AwaitContext */, func); } function doOutsideOfYieldAndAwaitContext(func) { - return doOutsideOfContext(8192 /* YieldContext */ | 32768 /* AwaitContext */, func); + return doOutsideOfContext(16384 /* YieldContext */ | 65536 /* AwaitContext */, func); } function inContext(flags) { return (contextFlags & flags) !== 0; } function inYieldContext() { - return inContext(8192 /* YieldContext */); + return inContext(16384 /* YieldContext */); } function inDisallowInContext() { - return inContext(4096 /* DisallowInContext */); + return inContext(8192 /* DisallowInContext */); } function inDisallowConditionalTypesContext() { - return inContext(65536 /* DisallowConditionalTypesContext */); + return inContext(131072 /* DisallowConditionalTypesContext */); } function inDecoratorContext() { - return inContext(16384 /* DecoratorContext */); + return inContext(32768 /* DecoratorContext */); } function inAwaitContext() { - return inContext(32768 /* AwaitContext */); + return inContext(65536 /* AwaitContext */); } function parseErrorAtCurrentToken(message, ...args) { return parseErrorAt(scanner2.getTokenStart(), scanner2.getTokenEnd(), message, ...args); @@ -128179,7 +111173,7 @@ ${lanes.join("\n")} const lastError = lastOrUndefined(parseDiagnostics); let result; if (!lastError || start !== lastError.start) { - result = createDetachedDiagnostic(fileName, start, length2, message, ...args); + result = createDetachedDiagnostic(fileName, sourceText, start, length2, message, ...args); parseDiagnostics.push(result); } parseErrorBeforeNextFinishedNode = true; @@ -128407,7 +111401,7 @@ ${lanes.join("\n")} if (lastError) { addRelatedInfo( lastError, - createDetachedDiagnostic(fileName, openPosition, 1, Diagnostics.The_parser_expected_to_find_a_1_to_match_the_0_token_here, tokenToString(openKind), tokenToString(closeKind)) + createDetachedDiagnostic(fileName, sourceText, openPosition, 1, Diagnostics.The_parser_expected_to_find_a_1_to_match_the_0_token_here, tokenToString(openKind), tokenToString(closeKind)) ); } } @@ -128494,7 +111488,7 @@ ${lanes.join("\n")} } if (parseErrorBeforeNextFinishedNode) { parseErrorBeforeNextFinishedNode = false; - node.flags |= 131072 /* ThisNodeHasError */; + node.flags |= 262144 /* ThisNodeHasError */; } return node; } @@ -128523,7 +111517,7 @@ ${lanes.join("\n")} "", /*isSingleQuote*/ void 0 - ) : kind === 281 /* MissingDeclaration */ ? factory2.createMissingDeclaration() : factoryCreateToken(kind); + ) : kind === 282 /* MissingDeclaration */ ? factory2.createMissingDeclaration() : factoryCreateToken(kind); return finishNode(result, pos); } function internIdentifier(text) { @@ -128577,10 +111571,16 @@ ${lanes.join("\n")} function parseIdentifierName(diagnosticMessage) { return createIdentifier(tokenIsIdentifierOrKeyword(token()), diagnosticMessage); } + function parseIdentifierNameErrorOnUnicodeEscapeSequence() { + if (scanner2.hasUnicodeEscape() || scanner2.hasExtendedUnicodeEscape()) { + parseErrorAtCurrentToken(Diagnostics.Unicode_escape_sequence_cannot_appear_here); + } + return createIdentifier(tokenIsIdentifierOrKeyword(token())); + } function isLiteralPropertyName() { return tokenIsIdentifierOrKeyword(token()) || token() === 11 /* StringLiteral */ || token() === 9 /* NumericLiteral */; } - function isAssertionKey2() { + function isImportAttributeName2() { return tokenIsIdentifierOrKeyword(token()) || token() === 11 /* StringLiteral */; } function parsePropertyNameWorker(allowComputedPropertyNames) { @@ -128699,8 +111699,8 @@ ${lanes.join("\n")} return isLiteralPropertyName(); case 9 /* ObjectBindingElements */: return token() === 23 /* OpenBracketToken */ || token() === 26 /* DotDotDotToken */ || isLiteralPropertyName(); - case 24 /* AssertEntries */: - return isAssertionKey2(); + case 24 /* ImportAttributes */: + return isImportAttributeName2(); case 7 /* HeritageClauseElement */: if (token() === 19 /* OpenBraceToken */) { return lookAhead(isValidHeritageClauseObjectLiteral); @@ -128740,6 +111740,9 @@ ${lanes.join("\n")} case 22 /* HeritageClauses */: return isHeritageClause2(); case 23 /* ImportOrExportSpecifiers */: + if (token() === 161 /* FromKeyword */ && lookAhead(nextTokenIsStringLiteral)) { + return false; + } return tokenIsIdentifierOrKeyword(token()); case 13 /* JsxAttributes */: return tokenIsIdentifierOrKeyword(token()) || token() === 19 /* OpenBraceToken */; @@ -128800,7 +111803,7 @@ ${lanes.join("\n")} case 12 /* ObjectLiteralMembers */: case 9 /* ObjectBindingElements */: case 23 /* ImportOrExportSpecifiers */: - case 24 /* AssertEntries */: + case 24 /* ImportAttributes */: return token() === 20 /* CloseBraceToken */; case 3 /* SwitchClauseStatements */: return token() === 20 /* CloseBraceToken */ || token() === 84 /* CaseKeyword */ || token() === 90 /* DefaultKeyword */; @@ -128896,7 +111899,7 @@ ${lanes.join("\n")} if (nodeIsMissing(node) || node.intersectsChange || containsParseError(node)) { return void 0; } - const nodeContextFlags = node.flags & 50720768 /* ContextFlags */; + const nodeContextFlags = node.flags & 101441536 /* ContextFlags */; if (nodeContextFlags !== contextFlags) { return void 0; } @@ -128954,14 +111957,14 @@ ${lanes.join("\n")} function isReusableClassMember(node) { if (node) { switch (node.kind) { - case 175 /* Constructor */: - case 180 /* IndexSignature */: - case 176 /* GetAccessor */: - case 177 /* SetAccessor */: - case 171 /* PropertyDeclaration */: - case 239 /* SemicolonClassElement */: + case 176 /* Constructor */: + case 181 /* IndexSignature */: + case 177 /* GetAccessor */: + case 178 /* SetAccessor */: + case 172 /* PropertyDeclaration */: + case 240 /* SemicolonClassElement */: return true; - case 173 /* MethodDeclaration */: + case 174 /* MethodDeclaration */: const methodDeclaration = node; const nameIsConstructor = methodDeclaration.name.kind === 80 /* Identifier */ && methodDeclaration.name.escapedText === "constructor"; return !nameIsConstructor; @@ -128972,8 +111975,8 @@ ${lanes.join("\n")} function isReusableSwitchClause(node) { if (node) { switch (node.kind) { - case 295 /* CaseClause */: - case 296 /* DefaultClause */: + case 296 /* CaseClause */: + case 297 /* DefaultClause */: return true; } } @@ -128982,65 +111985,65 @@ ${lanes.join("\n")} function isReusableStatement(node) { if (node) { switch (node.kind) { - case 261 /* FunctionDeclaration */: - case 242 /* VariableStatement */: - case 240 /* Block */: - case 244 /* IfStatement */: - case 243 /* ExpressionStatement */: - case 256 /* ThrowStatement */: - case 252 /* ReturnStatement */: - case 254 /* SwitchStatement */: - case 251 /* BreakStatement */: - case 250 /* ContinueStatement */: - case 248 /* ForInStatement */: - case 249 /* ForOfStatement */: - case 247 /* ForStatement */: - case 246 /* WhileStatement */: - case 253 /* WithStatement */: - case 241 /* EmptyStatement */: - case 257 /* TryStatement */: - case 255 /* LabeledStatement */: - case 245 /* DoStatement */: - case 258 /* DebuggerStatement */: - case 271 /* ImportDeclaration */: - case 270 /* ImportEqualsDeclaration */: - case 277 /* ExportDeclaration */: - case 276 /* ExportAssignment */: - case 266 /* ModuleDeclaration */: - case 262 /* ClassDeclaration */: - case 263 /* InterfaceDeclaration */: - case 265 /* EnumDeclaration */: - case 264 /* TypeAliasDeclaration */: + case 262 /* FunctionDeclaration */: + case 243 /* VariableStatement */: + case 241 /* Block */: + case 245 /* IfStatement */: + case 244 /* ExpressionStatement */: + case 257 /* ThrowStatement */: + case 253 /* ReturnStatement */: + case 255 /* SwitchStatement */: + case 252 /* BreakStatement */: + case 251 /* ContinueStatement */: + case 249 /* ForInStatement */: + case 250 /* ForOfStatement */: + case 248 /* ForStatement */: + case 247 /* WhileStatement */: + case 254 /* WithStatement */: + case 242 /* EmptyStatement */: + case 258 /* TryStatement */: + case 256 /* LabeledStatement */: + case 246 /* DoStatement */: + case 259 /* DebuggerStatement */: + case 272 /* ImportDeclaration */: + case 271 /* ImportEqualsDeclaration */: + case 278 /* ExportDeclaration */: + case 277 /* ExportAssignment */: + case 267 /* ModuleDeclaration */: + case 263 /* ClassDeclaration */: + case 264 /* InterfaceDeclaration */: + case 266 /* EnumDeclaration */: + case 265 /* TypeAliasDeclaration */: return true; } } return false; } function isReusableEnumMember(node) { - return node.kind === 305 /* EnumMember */; + return node.kind === 306 /* EnumMember */; } function isReusableTypeMember(node) { if (node) { switch (node.kind) { - case 179 /* ConstructSignature */: - case 172 /* MethodSignature */: - case 180 /* IndexSignature */: - case 170 /* PropertySignature */: - case 178 /* CallSignature */: + case 180 /* ConstructSignature */: + case 173 /* MethodSignature */: + case 181 /* IndexSignature */: + case 171 /* PropertySignature */: + case 179 /* CallSignature */: return true; } } return false; } function isReusableVariableDeclaration(node) { - if (node.kind !== 259 /* VariableDeclaration */) { + if (node.kind !== 260 /* VariableDeclaration */) { return false; } const variableDeclarator = node; return variableDeclarator.initializer === void 0; } function isReusableParameter(node) { - if (node.kind !== 168 /* Parameter */) { + if (node.kind !== 169 /* Parameter */) { return false; } const parameter = node; @@ -129098,12 +112101,15 @@ ${lanes.join("\n")} case 22 /* HeritageClauses */: return parseErrorAtCurrentToken(Diagnostics.Unexpected_token_expected); case 23 /* ImportOrExportSpecifiers */: + if (token() === 161 /* FromKeyword */) { + return parseErrorAtCurrentToken(Diagnostics._0_expected, "}"); + } return parseErrorAtCurrentToken(Diagnostics.Identifier_expected); case 13 /* JsxAttributes */: return parseErrorAtCurrentToken(Diagnostics.Identifier_expected); case 14 /* JsxChildren */: return parseErrorAtCurrentToken(Diagnostics.Identifier_expected); - case 24 /* AssertEntries */: + case 24 /* ImportAttributes */: return parseErrorAtCurrentToken(Diagnostics.Identifier_or_string_literal_expected); case 25 /* JSDocComment */: return parseErrorAtCurrentToken(Diagnostics.Identifier_expected); @@ -129197,7 +112203,9 @@ ${lanes.join("\n")} parseRightSideOfDot( allowReservedWords, /*allowPrivateIdentifiers*/ - false + false, + /*allowUnicodeEscapeSequenceInIdentifierName*/ + true ) ), pos @@ -129208,7 +112216,7 @@ ${lanes.join("\n")} function createQualifiedName(entity, name) { return finishNode(factory2.createQualifiedName(entity, name), entity.pos); } - function parseRightSideOfDot(allowIdentifierNames, allowPrivateIdentifiers) { + function parseRightSideOfDot(allowIdentifierNames, allowPrivateIdentifiers, allowUnicodeEscapeSequenceInIdentifierName) { if (scanner2.hasPrecedingLineBreak() && tokenIsIdentifierOrKeyword(token())) { const matchesPattern = lookAhead(nextTokenIsIdentifierOrKeywordOnSameLine); if (matchesPattern) { @@ -129229,7 +112237,10 @@ ${lanes.join("\n")} Diagnostics.Identifier_expected ); } - return allowIdentifierNames ? parseIdentifierName() : parseIdentifier(); + if (allowIdentifierNames) { + return allowUnicodeEscapeSequenceInIdentifierName ? parseIdentifierName() : parseIdentifierNameErrorOnUnicodeEscapeSequence(); + } + return parseIdentifier(); } function parseTemplateSpans(isTaggedTemplate) { const pos = getNodePos(); @@ -129377,14 +112388,14 @@ ${lanes.join("\n")} } function typeHasArrowFunctionBlockingParseError(node) { switch (node.kind) { - case 182 /* TypeReference */: + case 183 /* TypeReference */: return nodeIsMissing(node.typeName); - case 183 /* FunctionType */: - case 184 /* ConstructorType */: { + case 184 /* FunctionType */: + case 185 /* ConstructorType */: { const { parameters, type } = node; return isMissingList(parameters) || typeHasArrowFunctionBlockingParseError(type); } - case 195 /* ParenthesizedType */: + case 196 /* ParenthesizedType */: return typeHasArrowFunctionBlockingParseError(node.type); default: return false; @@ -129676,7 +112687,7 @@ ${lanes.join("\n")} function parseSignatureMember(kind) { const pos = getNodePos(); const hasJSDoc = hasPrecedingJSDocComment(); - if (kind === 179 /* ConstructSignature */) { + if (kind === 180 /* ConstructSignature */) { parseExpected(105 /* NewKeyword */); } const typeParameters = parseTypeParameters(); @@ -129687,7 +112698,7 @@ ${lanes.join("\n")} true ); parseTypeMemberSemicolon(); - const node = kind === 178 /* CallSignature */ ? factory2.createCallSignature(typeParameters, parameters, type) : factory2.createConstructSignature(typeParameters, parameters, type); + const node = kind === 179 /* CallSignature */ ? factory2.createCallSignature(typeParameters, parameters, type) : factory2.createConstructSignature(typeParameters, parameters, type); return withJSDoc(finishNode(node, pos), hasJSDoc); } function isIndexSignature() { @@ -129772,10 +112783,10 @@ ${lanes.join("\n")} } function parseTypeMember() { if (token() === 21 /* OpenParenToken */ || token() === 30 /* LessThanToken */) { - return parseSignatureMember(178 /* CallSignature */); + return parseSignatureMember(179 /* CallSignature */); } if (token() === 105 /* NewKeyword */ && lookAhead(nextTokenIsOpenParenOrLessThan)) { - return parseSignatureMember(179 /* ConstructSignature */); + return parseSignatureMember(180 /* ConstructSignature */); } const pos = getNodePos(); const hasJSDoc = hasPrecedingJSDocComment(); @@ -129784,10 +112795,10 @@ ${lanes.join("\n")} false ); if (parseContextualModifier(139 /* GetKeyword */)) { - return parseAccessorDeclaration(pos, hasJSDoc, modifiers, 176 /* GetAccessor */, 4 /* Type */); + return parseAccessorDeclaration(pos, hasJSDoc, modifiers, 177 /* GetAccessor */, 4 /* Type */); } if (parseContextualModifier(153 /* SetKeyword */)) { - return parseAccessorDeclaration(pos, hasJSDoc, modifiers, 177 /* SetAccessor */, 4 /* Type */); + return parseAccessorDeclaration(pos, hasJSDoc, modifiers, 178 /* SetAccessor */, 4 /* Type */); } if (isIndexSignature()) { return parseIndexSignatureDeclaration(pos, hasJSDoc, modifiers); @@ -129973,43 +112984,43 @@ ${lanes.join("\n")} nextToken(); return token() === 102 /* ImportKeyword */; } - function parseImportTypeAssertions() { - const pos = getNodePos(); - const openBracePosition = scanner2.getTokenStart(); - parseExpected(19 /* OpenBraceToken */); - const multiLine = scanner2.hasPrecedingLineBreak(); - parseExpected(132 /* AssertKeyword */); - parseExpected(59 /* ColonToken */); - const clause = parseAssertClause( - /*skipAssertKeyword*/ - true - ); - if (!parseExpected(20 /* CloseBraceToken */)) { - const lastError = lastOrUndefined(parseDiagnostics); - if (lastError && lastError.code === Diagnostics._0_expected.code) { - addRelatedInfo( - lastError, - createDetachedDiagnostic(fileName, openBracePosition, 1, Diagnostics.The_parser_expected_to_find_a_1_to_match_the_0_token_here, "{", "}") - ); - } - } - return finishNode(factory2.createImportTypeAssertionContainer(clause, multiLine), pos); - } function parseImportType() { - sourceFlags |= 2097152 /* PossiblyContainsDynamicImport */; + sourceFlags |= 4194304 /* PossiblyContainsDynamicImport */; const pos = getNodePos(); const isTypeOf = parseOptional(114 /* TypeOfKeyword */); parseExpected(102 /* ImportKeyword */); parseExpected(21 /* OpenParenToken */); const type = parseType(); - let assertions; + let attributes; if (parseOptional(28 /* CommaToken */)) { - assertions = parseImportTypeAssertions(); + const openBracePosition = scanner2.getTokenStart(); + parseExpected(19 /* OpenBraceToken */); + const currentToken2 = token(); + if (currentToken2 === 118 /* WithKeyword */ || currentToken2 === 132 /* AssertKeyword */) { + nextToken(); + } else { + parseErrorAtCurrentToken(Diagnostics._0_expected, tokenToString(118 /* WithKeyword */)); + } + parseExpected(59 /* ColonToken */); + attributes = parseImportAttributes( + currentToken2, + /*skipKeyword*/ + true + ); + if (!parseExpected(20 /* CloseBraceToken */)) { + const lastError = lastOrUndefined(parseDiagnostics); + if (lastError && lastError.code === Diagnostics._0_expected.code) { + addRelatedInfo( + lastError, + createDetachedDiagnostic(fileName, sourceText, openBracePosition, 1, Diagnostics.The_parser_expected_to_find_a_1_to_match_the_0_token_here, "{", "}") + ); + } + } } parseExpected(22 /* CloseParenToken */); const qualifier = parseOptional(25 /* DotToken */) ? parseEntityNameOfTypeReference() : void 0; const typeArguments = parseTypeArgumentsOfTypeReference(); - return finishNode(factory2.createImportTypeNode(type, assertions, qualifier, typeArguments, isTypeOf), pos); + return finishNode(factory2.createImportTypeNode(type, attributes, qualifier, typeArguments, isTypeOf), pos); } function nextTokenIsNumericOrBigIntLiteral() { nextToken(); @@ -130021,7 +113032,7 @@ ${lanes.join("\n")} case 159 /* UnknownKeyword */: case 154 /* StringKeyword */: case 150 /* NumberKeyword */: - case 162 /* BigIntKeyword */: + case 163 /* BigIntKeyword */: case 155 /* SymbolKeyword */: case 136 /* BooleanKeyword */: case 157 /* UndefinedKeyword */: @@ -130087,7 +113098,7 @@ ${lanes.join("\n")} case 159 /* UnknownKeyword */: case 154 /* StringKeyword */: case 150 /* NumberKeyword */: - case 162 /* BigIntKeyword */: + case 163 /* BigIntKeyword */: case 136 /* BooleanKeyword */: case 148 /* ReadonlyKeyword */: case 155 /* SymbolKeyword */: @@ -130333,8 +113344,8 @@ ${lanes.join("\n")} return finishNode(factory2.createTypePredicateNode(assertsModifier, parameterName, type), pos); } function parseType() { - if (contextFlags & 40960 /* TypeExcludesFlags */) { - return doOutsideOfContext(40960 /* TypeExcludesFlags */, parseType); + if (contextFlags & 81920 /* TypeExcludesFlags */) { + return doOutsideOfContext(81920 /* TypeExcludesFlags */, parseType); } if (isStartOfFunctionTypeOrConstructorType()) { return parseFunctionOrConstructorType(); @@ -130455,12 +113466,14 @@ ${lanes.join("\n")} return arrowExpression; } const pos = getNodePos(); + const hasJSDoc = hasPrecedingJSDocComment(); const expr = parseBinaryExpressionOrHigher(0 /* Lowest */); if (expr.kind === 80 /* Identifier */ && token() === 39 /* EqualsGreaterThanToken */) { return parseSimpleArrowFunctionExpression( pos, expr, allowReturnTypeInArrowFunction, + hasJSDoc, /*asyncModifier*/ void 0 ); @@ -130506,7 +113519,7 @@ ${lanes.join("\n")} ), pos); } } - function parseSimpleArrowFunctionExpression(pos, identifier, allowReturnTypeInArrowFunction, asyncModifier) { + function parseSimpleArrowFunctionExpression(pos, identifier, allowReturnTypeInArrowFunction, hasJSDoc, asyncModifier) { Debug.assert(token() === 39 /* EqualsGreaterThanToken */, "parseSimpleArrowFunctionExpression should only have been called if we had a =>"); const parameter = factory2.createParameterDeclaration( /*modifiers*/ @@ -130539,7 +113552,7 @@ ${lanes.join("\n")} equalsGreaterThanToken, body ); - return addJSDocComment(finishNode(node, pos)); + return withJSDoc(finishNode(node, pos), hasJSDoc); } function tryParseParenthesizedArrowFunctionExpression(allowReturnTypeInArrowFunction) { const triState = isParenthesizedArrowFunctionExpression(); @@ -130667,9 +113680,10 @@ ${lanes.join("\n")} if (token() === 134 /* AsyncKeyword */) { if (lookAhead(isUnParenthesizedAsyncArrowFunctionWorker) === 1 /* True */) { const pos = getNodePos(); + const hasJSDoc = hasPrecedingJSDocComment(); const asyncModifier = parseModifiersForArrowFunction(); const expr = parseBinaryExpressionOrHigher(0 /* Lowest */); - return parseSimpleArrowFunctionExpression(pos, expr, allowReturnTypeInArrowFunction, asyncModifier); + return parseSimpleArrowFunctionExpression(pos, expr, allowReturnTypeInArrowFunction, hasJSDoc, asyncModifier); } } return void 0; @@ -130723,7 +113737,7 @@ ${lanes.join("\n")} return void 0; } let unwrappedType = type; - while ((unwrappedType == null ? void 0 : unwrappedType.kind) === 195 /* ParenthesizedType */) { + while ((unwrappedType == null ? void 0 : unwrappedType.kind) === 196 /* ParenthesizedType */) { unwrappedType = unwrappedType.type; } const hasJSDocFunctionType = unwrappedType && isJSDocFunctionType(unwrappedType); @@ -130786,7 +113800,7 @@ ${lanes.join("\n")} return parseBinaryExpressionRest(precedence, leftOperand, pos); } function isInOrOfKeyword(t) { - return t === 103 /* InKeyword */ || t === 164 /* OfKeyword */; + return t === 103 /* InKeyword */ || t === 165 /* OfKeyword */; } function parseBinaryExpressionRest(precedence, leftOperand, pos) { while (true) { @@ -130868,7 +113882,7 @@ ${lanes.join("\n")} if (token() === 43 /* AsteriskAsteriskToken */) { const pos = skipTrivia(sourceText, simpleUnaryExpression.pos); const { end } = simpleUnaryExpression; - if (simpleUnaryExpression.kind === 215 /* TypeAssertionExpression */) { + if (simpleUnaryExpression.kind === 216 /* TypeAssertionExpression */) { parseErrorAt(pos, end, Diagnostics.A_type_assertion_expression_is_not_allowed_in_the_left_hand_side_of_an_exponentiation_expression_Consider_enclosing_the_expression_in_parentheses); } else { Debug.assert(isKeywordOrPunctuation(unaryOperator)); @@ -130955,13 +113969,13 @@ ${lanes.join("\n")} let expression; if (token() === 102 /* ImportKeyword */) { if (lookAhead(nextTokenIsOpenParenOrLessThan)) { - sourceFlags |= 2097152 /* PossiblyContainsDynamicImport */; + sourceFlags |= 4194304 /* PossiblyContainsDynamicImport */; expression = parseTokenNode(); } else if (lookAhead(nextTokenIsDot)) { nextToken(); nextToken(); expression = finishNode(factory2.createMetaProperty(102 /* ImportKeyword */, parseIdentifierName()), pos); - sourceFlags |= 4194304 /* PossiblyContainsImportMeta */; + sourceFlags |= 8388608 /* PossiblyContainsImportMeta */; } else { expression = parseMemberExpressionOrHigher(); } @@ -131001,6 +114015,8 @@ ${lanes.join("\n")} /*allowIdentifierNames*/ true, /*allowPrivateIdentifiers*/ + true, + /*allowUnicodeEscapeSequenceInIdentifierName*/ true )), pos); } @@ -131008,11 +114024,11 @@ ${lanes.join("\n")} const pos = getNodePos(); const opening = parseJsxOpeningOrSelfClosingElementOrOpeningFragment(inExpressionContext); let result; - if (opening.kind === 285 /* JsxOpeningElement */) { + if (opening.kind === 286 /* JsxOpeningElement */) { let children = parseJsxChildren(opening); let closingElement; const lastChild = children[children.length - 1]; - if ((lastChild == null ? void 0 : lastChild.kind) === 283 /* JsxElement */ && !tagNamesAreEquivalent(lastChild.openingElement.tagName, lastChild.closingElement.tagName) && tagNamesAreEquivalent(opening.tagName, lastChild.closingElement.tagName)) { + if ((lastChild == null ? void 0 : lastChild.kind) === 284 /* JsxElement */ && !tagNamesAreEquivalent(lastChild.openingElement.tagName, lastChild.closingElement.tagName) && tagNamesAreEquivalent(opening.tagName, lastChild.closingElement.tagName)) { const end = lastChild.children.end; const newLast = finishNode( factory2.createJsxElement( @@ -131036,10 +114052,10 @@ ${lanes.join("\n")} } } result = finishNode(factory2.createJsxElement(opening, children, closingElement), pos); - } else if (opening.kind === 288 /* JsxOpeningFragment */) { + } else if (opening.kind === 289 /* JsxOpeningFragment */) { result = finishNode(factory2.createJsxFragment(opening, parseJsxChildren(opening), parseJsxClosingFragment(inExpressionContext)), pos); } else { - Debug.assert(opening.kind === 284 /* JsxSelfClosingElement */); + Debug.assert(opening.kind === 285 /* JsxSelfClosingElement */); result = opening; } if (!mustBeUnary && inExpressionContext && token() === 30 /* LessThanToken */) { @@ -131112,7 +114128,7 @@ ${lanes.join("\n")} if (!child) break; list.push(child); - if (isJsxOpeningElement(openingTag) && (child == null ? void 0 : child.kind) === 283 /* JsxElement */ && !tagNamesAreEquivalent(child.openingElement.tagName, child.closingElement.tagName) && tagNamesAreEquivalent(openingTag.tagName, child.closingElement.tagName)) { + if (isJsxOpeningElement(openingTag) && (child == null ? void 0 : child.kind) === 284 /* JsxElement */ && !tagNamesAreEquivalent(child.openingElement.tagName, child.closingElement.tagName) && tagNamesAreEquivalent(openingTag.tagName, child.closingElement.tagName)) { break; } } @@ -131131,7 +114147,7 @@ ${lanes.join("\n")} return finishNode(factory2.createJsxOpeningFragment(), pos); } const tagName = parseJsxElementName(); - const typeArguments = (contextFlags & 262144 /* JavaScriptFile */) === 0 ? tryParseTypeArguments() : void 0; + const typeArguments = (contextFlags & 524288 /* JavaScriptFile */) === 0 ? tryParseTypeArguments() : void 0; const attributes = parseJsxAttributes(); let node; if (token() === 32 /* GreaterThanToken */) { @@ -131168,6 +114184,8 @@ ${lanes.join("\n")} /*allowIdentifierNames*/ true, /*allowPrivateIdentifiers*/ + false, + /*allowUnicodeEscapeSequenceInIdentifierName*/ false )), pos); } @@ -131177,10 +114195,10 @@ ${lanes.join("\n")} const pos = getNodePos(); scanJsxIdentifier(); const isThis2 = token() === 110 /* ThisKeyword */; - const tagName = parseIdentifierName(); + const tagName = parseIdentifierNameErrorOnUnicodeEscapeSequence(); if (parseOptional(59 /* ColonToken */)) { scanJsxIdentifier(); - return finishNode(factory2.createJsxNamespacedName(tagName, parseIdentifierName()), pos); + return finishNode(factory2.createJsxNamespacedName(tagName, parseIdentifierNameErrorOnUnicodeEscapeSequence()), pos); } return isThis2 ? finishNode(factory2.createToken(110 /* ThisKeyword */), pos) : tagName; } @@ -131192,7 +114210,9 @@ ${lanes.join("\n")} let dotDotDotToken; let expression; if (token() !== 20 /* CloseBraceToken */) { - dotDotDotToken = parseOptionalToken(26 /* DotDotDotToken */); + if (!inExpressionContext) { + dotDotDotToken = parseOptionalToken(26 /* DotDotDotToken */); + } expression = parseExpression(); } if (inExpressionContext) { @@ -131241,10 +114261,10 @@ ${lanes.join("\n")} function parseJsxAttributeName() { const pos = getNodePos(); scanJsxIdentifier(); - const attrName = parseIdentifierName(); + const attrName = parseIdentifierNameErrorOnUnicodeEscapeSequence(); if (parseOptional(59 /* ColonToken */)) { scanJsxIdentifier(); - return finishNode(factory2.createJsxNamespacedName(attrName, parseIdentifierName()), pos); + return finishNode(factory2.createJsxNamespacedName(attrName, parseIdentifierNameErrorOnUnicodeEscapeSequence()), pos); } return attrName; } @@ -131309,17 +114329,17 @@ ${lanes.join("\n")} return token() === 29 /* QuestionDotToken */ && lookAhead(nextTokenIsIdentifierOrKeywordOrOpenBracketOrTemplate); } function tryReparseOptionalChain(node) { - if (node.flags & 32 /* OptionalChain */) { + if (node.flags & 64 /* OptionalChain */) { return true; } if (isNonNullExpression(node)) { let expr = node.expression; - while (isNonNullExpression(expr) && !(expr.flags & 32 /* OptionalChain */)) { + while (isNonNullExpression(expr) && !(expr.flags & 64 /* OptionalChain */)) { expr = expr.expression; } - if (expr.flags & 32 /* OptionalChain */) { + if (expr.flags & 64 /* OptionalChain */) { while (isNonNullExpression(node)) { - node.flags |= 32 /* OptionalChain */; + node.flags |= 64 /* OptionalChain */; node = node.expression; } return true; @@ -131332,6 +114352,8 @@ ${lanes.join("\n")} /*allowIdentifierNames*/ true, /*allowPrivateIdentifiers*/ + true, + /*allowUnicodeEscapeSequenceInIdentifierName*/ true ); const isOptionalChain2 = questionDotToken || tryReparseOptionalChain(expression); @@ -131385,7 +114407,7 @@ ${lanes.join("\n")} continue; } if (isTemplateStartOfTaggedTemplate()) { - expression = !questionDotToken && expression.kind === 232 /* ExpressionWithTypeArguments */ ? parseTaggedTemplateRest(pos, expression.expression, questionDotToken, expression.typeArguments) : parseTaggedTemplateRest( + expression = !questionDotToken && expression.kind === 233 /* ExpressionWithTypeArguments */ ? parseTaggedTemplateRest(pos, expression.expression, questionDotToken, expression.typeArguments) : parseTaggedTemplateRest( pos, expression, questionDotToken, @@ -131424,8 +114446,8 @@ ${lanes.join("\n")} true ) ); - if (questionDotToken || tag.flags & 32 /* OptionalChain */) { - tagExpression.flags |= 32 /* OptionalChain */; + if (questionDotToken || tag.flags & 64 /* OptionalChain */) { + tagExpression.flags |= 64 /* OptionalChain */; } tagExpression.questionDotToken = questionDotToken; return finishNode(tagExpression, pos); @@ -131448,7 +114470,7 @@ ${lanes.join("\n")} } } if (typeArguments || token() === 21 /* OpenParenToken */) { - if (!questionDotToken && expression.kind === 232 /* ExpressionWithTypeArguments */) { + if (!questionDotToken && expression.kind === 233 /* ExpressionWithTypeArguments */) { typeArguments = expression.typeArguments; expression = expression.expression; } @@ -131477,7 +114499,7 @@ ${lanes.join("\n")} return result; } function parseTypeArgumentsInExpression() { - if ((contextFlags & 262144 /* JavaScriptFile */) !== 0) { + if ((contextFlags & 524288 /* JavaScriptFile */) !== 0) { return void 0; } if (reScanLessThanToken() !== 30 /* LessThanToken */) { @@ -131609,10 +114631,10 @@ ${lanes.join("\n")} true ); if (parseContextualModifier(139 /* GetKeyword */)) { - return parseAccessorDeclaration(pos, hasJSDoc, modifiers, 176 /* GetAccessor */, 0 /* None */); + return parseAccessorDeclaration(pos, hasJSDoc, modifiers, 177 /* GetAccessor */, 0 /* None */); } if (parseContextualModifier(153 /* SetKeyword */)) { - return parseAccessorDeclaration(pos, hasJSDoc, modifiers, 177 /* SetAccessor */, 0 /* None */); + return parseAccessorDeclaration(pos, hasJSDoc, modifiers, 178 /* SetAccessor */, 0 /* None */); } const asteriskToken = parseOptionalToken(42 /* AsteriskToken */); const tokenIsIdentifier = isIdentifier2(); @@ -131706,7 +114728,7 @@ ${lanes.join("\n")} false ); let typeArguments; - if (expression.kind === 232 /* ExpressionWithTypeArguments */) { + if (expression.kind === 233 /* ExpressionWithTypeArguments */) { typeArguments = expression.typeArguments; expression = expression.expression; } @@ -131816,7 +114838,8 @@ ${lanes.join("\n")} parseExpected(21 /* OpenParenToken */); let initializer; if (token() !== 27 /* SemicolonToken */) { - if (token() === 115 /* VarKeyword */ || token() === 121 /* LetKeyword */ || token() === 87 /* ConstKeyword */) { + if (token() === 115 /* VarKeyword */ || token() === 121 /* LetKeyword */ || token() === 87 /* ConstKeyword */ || token() === 160 /* UsingKeyword */ && lookAhead(nextTokenIsBindingIdentifierOrStartOfDestructuringOnSameLineDisallowOf) || // this one is meant to allow of + token() === 135 /* AwaitKeyword */ && lookAhead(nextTokenIsUsingKeywordThenBindingIdentifierOrStartOfObjectDestructuringOnSameLine)) { initializer = parseVariableDeclarationList( /*inForStatementInitializer*/ true @@ -131826,7 +114849,7 @@ ${lanes.join("\n")} } } let node; - if (awaitToken ? parseExpected(164 /* OfKeyword */) : parseOptional(164 /* OfKeyword */)) { + if (awaitToken ? parseExpected(165 /* OfKeyword */) : parseOptional(165 /* OfKeyword */)) { const expression = allowInAnd(() => parseAssignmentExpressionOrHigher( /*allowReturnTypeInArrowFunction*/ true @@ -131850,10 +114873,10 @@ ${lanes.join("\n")} function parseBreakOrContinueStatement(kind) { const pos = getNodePos(); const hasJSDoc = hasPrecedingJSDocComment(); - parseExpected(kind === 251 /* BreakStatement */ ? 83 /* BreakKeyword */ : 88 /* ContinueKeyword */); + parseExpected(kind === 252 /* BreakStatement */ ? 83 /* BreakKeyword */ : 88 /* ContinueKeyword */); const label = canParseSemicolon() ? void 0 : parseIdentifier(); parseSemicolon(); - const node = kind === 251 /* BreakStatement */ ? factory2.createBreakStatement(label) : factory2.createContinueStatement(label); + const node = kind === 252 /* BreakStatement */ ? factory2.createBreakStatement(label) : factory2.createContinueStatement(label); return withJSDoc(finishNode(node, pos), hasJSDoc); } function parseReturnStatement() { @@ -131872,7 +114895,7 @@ ${lanes.join("\n")} const openParenParsed = parseExpected(21 /* OpenParenToken */); const expression = allowInAnd(parseExpression); parseExpectedMatchingBrackets(21 /* OpenParenToken */, 22 /* CloseParenToken */, openParenParsed, openParenPosition); - const statement = doInsideOfContext(33554432 /* InWithStatement */, parseStatement); + const statement = doInsideOfContext(67108864 /* InWithStatement */, parseStatement); return withJSDoc(finishNode(factory2.createWithStatement(expression, statement), pos), hasJSDoc); } function parseCaseClause() { @@ -132012,6 +115035,10 @@ ${lanes.join("\n")} case 86 /* ClassKeyword */: case 94 /* EnumKeyword */: return true; + case 160 /* UsingKeyword */: + return isUsingDeclaration(); + case 135 /* AwaitKeyword */: + return isAwaitUsingDeclaration(); case 120 /* InterfaceKeyword */: case 156 /* TypeKeyword */: return nextTokenIsIdentifierOnSameLine(); @@ -132026,12 +115053,16 @@ ${lanes.join("\n")} case 124 /* ProtectedKeyword */: case 125 /* PublicKeyword */: case 148 /* ReadonlyKeyword */: + const previousToken = token(); nextToken(); if (scanner2.hasPrecedingLineBreak()) { return false; } + if (previousToken === 138 /* DeclareKeyword */ && token() === 156 /* TypeKeyword */) { + return true; + } continue; - case 161 /* GlobalKeyword */: + case 162 /* GlobalKeyword */: nextToken(); return token() === 19 /* OpenBraceToken */ || token() === 80 /* Identifier */ || token() === 95 /* ExportKeyword */; case 102 /* ImportKeyword */: @@ -132064,6 +115095,7 @@ ${lanes.join("\n")} case 19 /* OpenBraceToken */: case 115 /* VarKeyword */: case 121 /* LetKeyword */: + case 160 /* UsingKeyword */: case 100 /* FunctionKeyword */: case 86 /* ClassKeyword */: case 94 /* EnumKeyword */: @@ -132093,7 +115125,7 @@ ${lanes.join("\n")} case 144 /* ModuleKeyword */: case 145 /* NamespaceKeyword */: case 156 /* TypeKeyword */: - case 161 /* GlobalKeyword */: + case 162 /* GlobalKeyword */: return true; case 129 /* AccessorKeyword */: case 125 /* PublicKeyword */: @@ -132113,6 +115145,30 @@ ${lanes.join("\n")} function isLetDeclaration() { return lookAhead(nextTokenIsBindingIdentifierOrStartOfDestructuring); } + function nextTokenIsBindingIdentifierOrStartOfDestructuringOnSameLineDisallowOf() { + return nextTokenIsBindingIdentifierOrStartOfDestructuringOnSameLine( + /*disallowOf*/ + true + ); + } + function nextTokenIsBindingIdentifierOrStartOfDestructuringOnSameLine(disallowOf) { + nextToken(); + if (disallowOf && token() === 165 /* OfKeyword */) + return false; + return (isBindingIdentifier() || token() === 19 /* OpenBraceToken */) && !scanner2.hasPrecedingLineBreak(); + } + function isUsingDeclaration() { + return lookAhead(nextTokenIsBindingIdentifierOrStartOfDestructuringOnSameLine); + } + function nextTokenIsUsingKeywordThenBindingIdentifierOrStartOfObjectDestructuringOnSameLine(disallowOf) { + if (nextToken() === 160 /* UsingKeyword */) { + return nextTokenIsBindingIdentifierOrStartOfDestructuringOnSameLine(disallowOf); + } + return false; + } + function isAwaitUsingDeclaration() { + return lookAhead(nextTokenIsUsingKeywordThenBindingIdentifierOrStartOfObjectDestructuringOnSameLine); + } function parseStatement() { switch (token()) { case 27 /* SemicolonToken */: @@ -132139,6 +115195,26 @@ ${lanes.join("\n")} ); } break; + case 135 /* AwaitKeyword */: + if (isAwaitUsingDeclaration()) { + return parseVariableStatement( + getNodePos(), + hasPrecedingJSDocComment(), + /*modifiers*/ + void 0 + ); + } + break; + case 160 /* UsingKeyword */: + if (isUsingDeclaration()) { + return parseVariableStatement( + getNodePos(), + hasPrecedingJSDocComment(), + /*modifiers*/ + void 0 + ); + } + break; case 100 /* FunctionKeyword */: return parseFunctionDeclaration( getNodePos(), @@ -132162,9 +115238,9 @@ ${lanes.join("\n")} case 99 /* ForKeyword */: return parseForOrForInOrForOfStatement(); case 88 /* ContinueKeyword */: - return parseBreakOrContinueStatement(250 /* ContinueStatement */); + return parseBreakOrContinueStatement(251 /* ContinueStatement */); case 83 /* BreakKeyword */: - return parseBreakOrContinueStatement(251 /* BreakStatement */); + return parseBreakOrContinueStatement(252 /* BreakStatement */); case 107 /* ReturnKeyword */: return parseReturnStatement(); case 118 /* WithKeyword */: @@ -132198,7 +115274,7 @@ ${lanes.join("\n")} case 129 /* AccessorKeyword */: case 126 /* StaticKeyword */: case 148 /* ReadonlyKeyword */: - case 161 /* GlobalKeyword */: + case 162 /* GlobalKeyword */: if (isStartOfDeclaration()) { return parseDeclaration(); } @@ -132223,15 +115299,15 @@ ${lanes.join("\n")} return node; } for (const m of modifiers) { - m.flags |= 16777216 /* Ambient */; + m.flags |= 33554432 /* Ambient */; } - return doInsideOfContext(16777216 /* Ambient */, () => parseDeclarationWorker(pos, hasJSDoc, modifiers)); + return doInsideOfContext(33554432 /* Ambient */, () => parseDeclarationWorker(pos, hasJSDoc, modifiers)); } else { return parseDeclarationWorker(pos, hasJSDoc, modifiers); } } function tryReuseAmbientDeclaration(pos) { - return doInsideOfContext(16777216 /* Ambient */, () => { + return doInsideOfContext(33554432 /* Ambient */, () => { const node = currentNode(parsingContext, pos); if (node) { return consumeNode(node); @@ -132243,6 +115319,8 @@ ${lanes.join("\n")} case 115 /* VarKeyword */: case 121 /* LetKeyword */: case 87 /* ConstKeyword */: + case 160 /* UsingKeyword */: + case 135 /* AwaitKeyword */: return parseVariableStatement(pos, hasJSDoc, modifiersIn); case 100 /* FunctionKeyword */: return parseFunctionDeclaration(pos, hasJSDoc, modifiersIn); @@ -132254,7 +115332,7 @@ ${lanes.join("\n")} return parseTypeAliasDeclaration(pos, hasJSDoc, modifiersIn); case 94 /* EnumKeyword */: return parseEnumDeclaration(pos, hasJSDoc, modifiersIn); - case 161 /* GlobalKeyword */: + case 162 /* GlobalKeyword */: case 144 /* ModuleKeyword */: case 145 /* NamespaceKeyword */: return parseModuleDeclaration(pos, hasJSDoc, modifiersIn); @@ -132274,7 +115352,7 @@ ${lanes.join("\n")} default: if (modifiersIn) { const missing = createMissingNode( - 281 /* MissingDeclaration */, + 282 /* MissingDeclaration */, /*reportAtCurrentPosition*/ true, Diagnostics.Declaration_expected @@ -132286,6 +115364,9 @@ ${lanes.join("\n")} return void 0; } } + function nextTokenIsStringLiteral() { + return nextToken() === 11 /* StringLiteral */; + } function nextTokenIsIdentifierOrStringLiteralOnSameLine() { nextToken(); return !scanner2.hasPrecedingLineBreak() && (isIdentifier2() || token() === 11 /* StringLiteral */); @@ -132338,14 +115419,14 @@ ${lanes.join("\n")} function parseObjectBindingPattern() { const pos = getNodePos(); parseExpected(19 /* OpenBraceToken */); - const elements = parseDelimitedList(9 /* ObjectBindingElements */, parseObjectBindingElement); + const elements = allowInAnd(() => parseDelimitedList(9 /* ObjectBindingElements */, parseObjectBindingElement)); parseExpected(20 /* CloseBraceToken */); return finishNode(factory2.createObjectBindingPattern(elements), pos); } function parseArrayBindingPattern() { const pos = getNodePos(); parseExpected(23 /* OpenBracketToken */); - const elements = parseDelimitedList(10 /* ArrayBindingElements */, parseArrayBindingElement); + const elements = allowInAnd(() => parseDelimitedList(10 /* ArrayBindingElements */, parseArrayBindingElement)); parseExpected(24 /* CloseBracketToken */); return finishNode(factory2.createArrayBindingPattern(elements), pos); } @@ -132392,12 +115473,20 @@ ${lanes.join("\n")} case 87 /* ConstKeyword */: flags |= 2 /* Const */; break; + case 160 /* UsingKeyword */: + flags |= 4 /* Using */; + break; + case 135 /* AwaitKeyword */: + Debug.assert(isAwaitUsingDeclaration()); + flags |= 6 /* AwaitUsing */; + nextToken(); + break; default: Debug.fail(); } nextToken(); let declarations; - if (token() === 164 /* OfKeyword */ && lookAhead(canFollowContextualOfKeyword)) { + if (token() === 165 /* OfKeyword */ && lookAhead(canFollowContextualOfKeyword)) { declarations = createMissingList(); } else { const savedDisallowIn = inDisallowInContext(); @@ -132427,11 +115516,11 @@ ${lanes.join("\n")} const modifierFlags = modifiersToFlags(modifiers); parseExpected(100 /* FunctionKeyword */); const asteriskToken = parseOptionalToken(42 /* AsteriskToken */); - const name = modifierFlags & 1024 /* Default */ ? parseOptionalBindingIdentifier() : parseBindingIdentifier(); + const name = modifierFlags & 2048 /* Default */ ? parseOptionalBindingIdentifier() : parseBindingIdentifier(); const isGenerator = asteriskToken ? 1 /* Yield */ : 0 /* None */; - const isAsync = modifierFlags & 512 /* Async */ ? 2 /* Await */ : 0 /* None */; + const isAsync = modifierFlags & 1024 /* Async */ ? 2 /* Await */ : 0 /* None */; const typeParameters = parseTypeParameters(); - if (modifierFlags & 1 /* Export */) + if (modifierFlags & 32 /* Export */) setAwaitContext( /*value*/ true @@ -132503,7 +115592,7 @@ ${lanes.join("\n")} function parsePropertyDeclaration(pos, hasJSDoc, modifiers, name, questionToken) { const exclamationToken = !questionToken && !scanner2.hasPrecedingLineBreak() ? parseOptionalToken(54 /* ExclamationToken */) : void 0; const type = parseTypeAnnotation(); - const initializer = doOutsideOfContext(8192 /* YieldContext */ | 32768 /* AwaitContext */ | 4096 /* DisallowInContext */, parseInitializer); + const initializer = doOutsideOfContext(16384 /* YieldContext */ | 65536 /* AwaitContext */ | 8192 /* DisallowInContext */, parseInitializer); parseSemicolonAfterPropertyName(name, type, initializer); const node = factory2.createPropertyDeclaration( modifiers, @@ -132543,7 +115632,7 @@ ${lanes.join("\n")} false ); const body = parseFunctionBlockOrSemicolon(flags); - const node = kind === 176 /* GetAccessor */ ? factory2.createGetAccessorDeclaration(modifiers, name, parameters, type, body) : factory2.createSetAccessorDeclaration(modifiers, name, parameters, body); + const node = kind === 177 /* GetAccessor */ ? factory2.createGetAccessorDeclaration(modifiers, name, parameters, type, body) : factory2.createSetAccessorDeclaration(modifiers, name, parameters, body); node.typeParameters = typeParameters; if (isSetAccessorDeclaration(node)) node.type = type; @@ -132709,10 +115798,10 @@ ${lanes.join("\n")} return parseClassStaticBlockDeclaration(pos, hasJSDoc, modifiers); } if (parseContextualModifier(139 /* GetKeyword */)) { - return parseAccessorDeclaration(pos, hasJSDoc, modifiers, 176 /* GetAccessor */, 0 /* None */); + return parseAccessorDeclaration(pos, hasJSDoc, modifiers, 177 /* GetAccessor */, 0 /* None */); } if (parseContextualModifier(153 /* SetKeyword */)) { - return parseAccessorDeclaration(pos, hasJSDoc, modifiers, 177 /* SetAccessor */, 0 /* None */); + return parseAccessorDeclaration(pos, hasJSDoc, modifiers, 178 /* SetAccessor */, 0 /* None */); } if (token() === 137 /* ConstructorKeyword */ || token() === 11 /* StringLiteral */) { const constructorDeclaration = tryParseConstructorDeclaration(pos, hasJSDoc, modifiers); @@ -132727,9 +115816,9 @@ ${lanes.join("\n")} const isAmbient = some(modifiers, isDeclareModifier); if (isAmbient) { for (const m of modifiers) { - m.flags |= 16777216 /* Ambient */; + m.flags |= 33554432 /* Ambient */; } - return doInsideOfContext(16777216 /* Ambient */, () => parsePropertyOrMethodDeclaration(pos, hasJSDoc, modifiers)); + return doInsideOfContext(33554432 /* Ambient */, () => parsePropertyOrMethodDeclaration(pos, hasJSDoc, modifiers)); } else { return parsePropertyOrMethodDeclaration(pos, hasJSDoc, modifiers); } @@ -132760,10 +115849,10 @@ ${lanes.join("\n")} true ); if (token() === 86 /* ClassKeyword */) { - return parseClassDeclarationOrExpression(pos, hasJSDoc, modifiers, 230 /* ClassExpression */); + return parseClassDeclarationOrExpression(pos, hasJSDoc, modifiers, 231 /* ClassExpression */); } const missing = createMissingNode( - 281 /* MissingDeclaration */, + 282 /* MissingDeclaration */, /*reportAtCurrentPosition*/ true, Diagnostics.Expression_expected @@ -132778,11 +115867,11 @@ ${lanes.join("\n")} hasPrecedingJSDocComment(), /*modifiers*/ void 0, - 230 /* ClassExpression */ + 231 /* ClassExpression */ ); } function parseClassDeclaration(pos, hasJSDoc, modifiers) { - return parseClassDeclarationOrExpression(pos, hasJSDoc, modifiers, 262 /* ClassDeclaration */); + return parseClassDeclarationOrExpression(pos, hasJSDoc, modifiers, 263 /* ClassDeclaration */); } function parseClassDeclarationOrExpression(pos, hasJSDoc, modifiers, kind) { const savedAwaitContext = inAwaitContext(); @@ -132803,7 +115892,7 @@ ${lanes.join("\n")} members = createMissingList(); } setAwaitContext(savedAwaitContext); - const node = kind === 262 /* ClassDeclaration */ ? factory2.createClassDeclaration(modifiers, name, typeParameters, heritageClauses, members) : factory2.createClassExpression(modifiers, name, typeParameters, heritageClauses, members); + const node = kind === 263 /* ClassDeclaration */ ? factory2.createClassDeclaration(modifiers, name, typeParameters, heritageClauses, members) : factory2.createClassExpression(modifiers, name, typeParameters, heritageClauses, members); return withJSDoc(finishNode(node, pos), hasJSDoc); } function parseNameOfClassDeclarationOrExpression() { @@ -132829,7 +115918,7 @@ ${lanes.join("\n")} function parseExpressionWithTypeArguments() { const pos = getNodePos(); const expression = parseLeftHandSideExpressionOrHigher(); - if (expression.kind === 232 /* ExpressionWithTypeArguments */) { + if (expression.kind === 233 /* ExpressionWithTypeArguments */) { return expression; } const typeArguments = tryParseTypeArguments(); @@ -132855,6 +115944,9 @@ ${lanes.join("\n")} } function parseTypeAliasDeclaration(pos, hasJSDoc, modifiers) { parseExpected(156 /* TypeKeyword */); + if (scanner2.hasPrecedingLineBreak()) { + parseErrorAtCurrentToken(Diagnostics.Line_break_not_permitted_here); + } const name = parseIdentifier(); const typeParameters = parseTypeParameters(); parseExpected(64 /* EqualsToken */); @@ -132895,15 +115987,15 @@ ${lanes.join("\n")} return finishNode(factory2.createModuleBlock(statements), pos); } function parseModuleOrNamespaceDeclaration(pos, hasJSDoc, modifiers, flags) { - const namespaceFlag = flags & 16 /* Namespace */; - const name = parseIdentifier(); + const namespaceFlag = flags & 32 /* Namespace */; + const name = flags & 8 /* NestedNamespace */ ? parseIdentifierName() : parseIdentifier(); const body = parseOptional(25 /* DotToken */) ? parseModuleOrNamespaceDeclaration( getNodePos(), /*hasJSDoc*/ false, /*modifiers*/ void 0, - 4 /* NestedNamespace */ | namespaceFlag + 8 /* NestedNamespace */ | namespaceFlag ) : parseModuleBlock(); const node = factory2.createModuleDeclaration(modifiers, name, body, flags); return withJSDoc(finishNode(node, pos), hasJSDoc); @@ -132911,9 +116003,9 @@ ${lanes.join("\n")} function parseAmbientExternalModuleDeclaration(pos, hasJSDoc, modifiersIn) { let flags = 0; let name; - if (token() === 161 /* GlobalKeyword */) { + if (token() === 162 /* GlobalKeyword */) { name = parseIdentifier(); - flags |= 1024 /* GlobalAugmentation */; + flags |= 2048 /* GlobalAugmentation */; } else { name = parseLiteralNode(); name.text = internIdentifier(name.text); @@ -132929,10 +116021,10 @@ ${lanes.join("\n")} } function parseModuleDeclaration(pos, hasJSDoc, modifiersIn) { let flags = 0; - if (token() === 161 /* GlobalKeyword */) { + if (token() === 162 /* GlobalKeyword */) { return parseAmbientExternalModuleDeclaration(pos, hasJSDoc, modifiersIn); } else if (parseOptional(145 /* NamespaceKeyword */)) { - flags |= 16 /* Namespace */; + flags |= 32 /* Namespace */; } else { parseExpected(144 /* ModuleKeyword */); if (token() === 11 /* StringLiteral */) { @@ -132970,7 +116062,7 @@ ${lanes.join("\n")} identifier = parseIdentifier(); } let isTypeOnly = false; - if (token() !== 160 /* FromKeyword */ && (identifier == null ? void 0 : identifier.escapedText) === "type" && (isIdentifier2() || tokenAfterImportDefinitelyProducesImportDeclaration())) { + if (token() !== 161 /* FromKeyword */ && (identifier == null ? void 0 : identifier.escapedText) === "type" && (isIdentifier2() || tokenAfterImportDefinitelyProducesImportDeclaration())) { isTypeOnly = true; identifier = isIdentifier2() ? parseIdentifier() : void 0; } @@ -132982,18 +116074,19 @@ ${lanes.join("\n")} token() === 42 /* AsteriskToken */ || // import * token() === 19 /* OpenBraceToken */) { importClause = parseImportClause(identifier, afterImportPos, isTypeOnly); - parseExpected(160 /* FromKeyword */); + parseExpected(161 /* FromKeyword */); } const moduleSpecifier = parseModuleSpecifier(); - let assertClause; - if (token() === 132 /* AssertKeyword */ && !scanner2.hasPrecedingLineBreak()) { - assertClause = parseAssertClause(); + const currentToken2 = token(); + let attributes; + if ((currentToken2 === 118 /* WithKeyword */ || currentToken2 === 132 /* AssertKeyword */) && !scanner2.hasPrecedingLineBreak()) { + attributes = parseImportAttributes(currentToken2); } parseSemicolon(); - const node = factory2.createImportDeclaration(modifiers, importClause, moduleSpecifier, assertClause); + const node = factory2.createImportDeclaration(modifiers, importClause, moduleSpecifier, attributes); return withJSDoc(finishNode(node, pos), hasJSDoc); } - function parseAssertEntry() { + function parseImportAttribute() { const pos = getNodePos(); const name = tokenIsIdentifierOrKeyword(token()) ? parseIdentifierName() : parseLiteralLikeNode(11 /* StringLiteral */); parseExpected(59 /* ColonToken */); @@ -133001,19 +116094,19 @@ ${lanes.join("\n")} /*allowReturnTypeInArrowFunction*/ true ); - return finishNode(factory2.createAssertEntry(name, value), pos); + return finishNode(factory2.createImportAttribute(name, value), pos); } - function parseAssertClause(skipAssertKeyword) { + function parseImportAttributes(token2, skipKeyword) { const pos = getNodePos(); - if (!skipAssertKeyword) { - parseExpected(132 /* AssertKeyword */); + if (!skipKeyword) { + parseExpected(token2); } const openBracePosition = scanner2.getTokenStart(); if (parseExpected(19 /* OpenBraceToken */)) { const multiLine = scanner2.hasPrecedingLineBreak(); const elements = parseDelimitedList( - 24 /* AssertEntries */, - parseAssertEntry, + 24 /* ImportAttributes */, + parseImportAttribute, /*considerSemicolonAsDelimiter*/ true ); @@ -133022,11 +116115,11 @@ ${lanes.join("\n")} if (lastError && lastError.code === Diagnostics._0_expected.code) { addRelatedInfo( lastError, - createDetachedDiagnostic(fileName, openBracePosition, 1, Diagnostics.The_parser_expected_to_find_a_1_to_match_the_0_token_here, "{", "}") + createDetachedDiagnostic(fileName, sourceText, openBracePosition, 1, Diagnostics.The_parser_expected_to_find_a_1_to_match_the_0_token_here, "{", "}") ); } } - return finishNode(factory2.createAssertClause(elements, multiLine), pos); + return finishNode(factory2.createImportAttributes(elements, multiLine, token2), pos); } else { const elements = createNodeArray( [], @@ -133036,10 +116129,11 @@ ${lanes.join("\n")} /*hasTrailingComma*/ false ); - return finishNode(factory2.createAssertClause( + return finishNode(factory2.createImportAttributes( elements, /*multiLine*/ - false + false, + token2 ), pos); } } @@ -133047,7 +116141,7 @@ ${lanes.join("\n")} return token() === 42 /* AsteriskToken */ || token() === 19 /* OpenBraceToken */; } function tokenAfterImportedIdentifierDefinitelyProducesImportDeclaration() { - return token() === 28 /* CommaToken */ || token() === 160 /* FromKeyword */; + return token() === 28 /* CommaToken */ || token() === 161 /* FromKeyword */; } function parseImportEqualsDeclaration(pos, hasJSDoc, modifiers, identifier, isTypeOnly) { parseExpected(64 /* EqualsToken */); @@ -133060,7 +116154,7 @@ ${lanes.join("\n")} function parseImportClause(identifier, pos, isTypeOnly) { let namedBindings; if (!identifier || parseOptional(28 /* CommaToken */)) { - namedBindings = token() === 42 /* AsteriskToken */ ? parseNamespaceImport() : parseNamedImportsOrExports(274 /* NamedImports */); + namedBindings = token() === 42 /* AsteriskToken */ ? parseNamespaceImport() : parseNamedImportsOrExports(275 /* NamedImports */); } return finishNode(factory2.createImportClause(isTypeOnly, identifier, namedBindings), pos); } @@ -133096,15 +116190,15 @@ ${lanes.join("\n")} } function parseNamedImportsOrExports(kind) { const pos = getNodePos(); - const node = kind === 274 /* NamedImports */ ? factory2.createNamedImports(parseBracketedList(23 /* ImportOrExportSpecifiers */, parseImportSpecifier, 19 /* OpenBraceToken */, 20 /* CloseBraceToken */)) : factory2.createNamedExports(parseBracketedList(23 /* ImportOrExportSpecifiers */, parseExportSpecifier, 19 /* OpenBraceToken */, 20 /* CloseBraceToken */)); + const node = kind === 275 /* NamedImports */ ? factory2.createNamedImports(parseBracketedList(23 /* ImportOrExportSpecifiers */, parseImportSpecifier, 19 /* OpenBraceToken */, 20 /* CloseBraceToken */)) : factory2.createNamedExports(parseBracketedList(23 /* ImportOrExportSpecifiers */, parseExportSpecifier, 19 /* OpenBraceToken */, 20 /* CloseBraceToken */)); return finishNode(node, pos); } function parseExportSpecifier() { const hasJSDoc = hasPrecedingJSDocComment(); - return withJSDoc(parseImportOrExportSpecifier(280 /* ExportSpecifier */), hasJSDoc); + return withJSDoc(parseImportOrExportSpecifier(281 /* ExportSpecifier */), hasJSDoc); } function parseImportSpecifier() { - return parseImportOrExportSpecifier(275 /* ImportSpecifier */); + return parseImportOrExportSpecifier(276 /* ImportSpecifier */); } function parseImportOrExportSpecifier(kind) { const pos = getNodePos(); @@ -133148,10 +116242,10 @@ ${lanes.join("\n")} parseExpected(130 /* AsKeyword */); name = parseNameWithKeywordCheck(); } - if (kind === 275 /* ImportSpecifier */ && checkIdentifierIsKeyword) { + if (kind === 276 /* ImportSpecifier */ && checkIdentifierIsKeyword) { parseErrorAt(checkIdentifierStart, checkIdentifierEnd, Diagnostics.Identifier_expected); } - const node = kind === 275 /* ImportSpecifier */ ? factory2.createImportSpecifier(isTypeOnly, propertyName, name) : factory2.createExportSpecifier(isTypeOnly, propertyName, name); + const node = kind === 276 /* ImportSpecifier */ ? factory2.createImportSpecifier(isTypeOnly, propertyName, name) : factory2.createExportSpecifier(isTypeOnly, propertyName, name); return finishNode(node, pos); function parseNameWithKeywordCheck() { checkIdentifierIsKeyword = isKeyword(token()) && !isIdentifier2(); @@ -133171,28 +116265,29 @@ ${lanes.join("\n")} ); let exportClause; let moduleSpecifier; - let assertClause; + let attributes; const isTypeOnly = parseOptional(156 /* TypeKeyword */); const namespaceExportPos = getNodePos(); if (parseOptional(42 /* AsteriskToken */)) { if (parseOptional(130 /* AsKeyword */)) { exportClause = parseNamespaceExport(namespaceExportPos); } - parseExpected(160 /* FromKeyword */); + parseExpected(161 /* FromKeyword */); moduleSpecifier = parseModuleSpecifier(); } else { - exportClause = parseNamedImportsOrExports(278 /* NamedExports */); - if (token() === 160 /* FromKeyword */ || token() === 11 /* StringLiteral */ && !scanner2.hasPrecedingLineBreak()) { - parseExpected(160 /* FromKeyword */); + exportClause = parseNamedImportsOrExports(279 /* NamedExports */); + if (token() === 161 /* FromKeyword */ || token() === 11 /* StringLiteral */ && !scanner2.hasPrecedingLineBreak()) { + parseExpected(161 /* FromKeyword */); moduleSpecifier = parseModuleSpecifier(); } } - if (moduleSpecifier && token() === 132 /* AssertKeyword */ && !scanner2.hasPrecedingLineBreak()) { - assertClause = parseAssertClause(); + const currentToken2 = token(); + if (moduleSpecifier && (currentToken2 === 118 /* WithKeyword */ || currentToken2 === 132 /* AssertKeyword */) && !scanner2.hasPrecedingLineBreak()) { + attributes = parseImportAttributes(currentToken2); } parseSemicolon(); setAwaitContext(savedAwaitContext); - const node = factory2.createExportDeclaration(modifiers, isTypeOnly, exportClause, moduleSpecifier, assertClause); + const node = factory2.createExportDeclaration(modifiers, isTypeOnly, exportClause, moduleSpecifier, attributes); return withJSDoc(finishNode(node, pos), hasJSDoc); } function parseExportAssignment(pos, hasJSDoc, modifiers) { @@ -133242,7 +116337,7 @@ ${lanes.join("\n")} ParsingContext2[ParsingContext2["TupleElementTypes"] = 21] = "TupleElementTypes"; ParsingContext2[ParsingContext2["HeritageClauses"] = 22] = "HeritageClauses"; ParsingContext2[ParsingContext2["ImportOrExportSpecifiers"] = 23] = "ImportOrExportSpecifiers"; - ParsingContext2[ParsingContext2["AssertEntries"] = 24] = "AssertEntries"; + ParsingContext2[ParsingContext2["ImportAttributes"] = 24] = "ImportAttributes"; ParsingContext2[ParsingContext2["JSDocComment"] = 25] = "JSDocComment"; ParsingContext2[ParsingContext2["Count"] = 26] = "Count"; })(ParsingContext || (ParsingContext = {})); @@ -133261,7 +116356,8 @@ ${lanes.join("\n")} 99 /* Latest */, /*syntaxCursor*/ void 0, - 1 /* JS */ + 1 /* JS */, + 0 /* ParseAll */ ); scanner2.setText(content, start, length2); currentToken = scanner2.scan(); @@ -133288,7 +116384,7 @@ ${lanes.join("\n")} function parseJSDocTypeExpression(mayOmitBraces) { const pos = getNodePos(); const hasBrace = (mayOmitBraces ? parseOptional : parseExpected)(19 /* OpenBraceToken */); - const type = doInsideOfContext(8388608 /* JSDoc */, parseJSDocType); + const type = doInsideOfContext(16777216 /* JSDoc */, parseJSDocType); if (!mayOmitBraces || hasBrace) { parseExpectedJSDoc(20 /* CloseBraceToken */); } @@ -133325,9 +116421,10 @@ ${lanes.join("\n")} 99 /* Latest */, /*syntaxCursor*/ void 0, - 1 /* JS */ + 1 /* JS */, + 0 /* ParseAll */ ); - const jsDoc = doInsideOfContext(8388608 /* JSDoc */, () => parseJSDocCommentWorker(start, length2)); + const jsDoc = doInsideOfContext(16777216 /* JSDoc */, () => parseJSDocCommentWorker(start, length2)); const sourceFile = { languageVariant: 0 /* Standard */, text: content }; const diagnostics = attachFileToDiagnostics(parseDiagnostics, sourceFile); clearState(); @@ -133338,9 +116435,9 @@ ${lanes.join("\n")} const saveToken = currentToken; const saveParseDiagnosticsLength = parseDiagnostics.length; const saveParseErrorBeforeNextFinishedNode = parseErrorBeforeNextFinishedNode; - const comment = doInsideOfContext(8388608 /* JSDoc */, () => parseJSDocCommentWorker(start, length2)); + const comment = doInsideOfContext(16777216 /* JSDoc */, () => parseJSDocCommentWorker(start, length2)); setParent(comment, parent2); - if (contextFlags & 262144 /* JavaScriptFile */) { + if (contextFlags & 524288 /* JavaScriptFile */) { if (!jsDocDiagnostics) { jsDocDiagnostics = []; } @@ -133366,8 +116463,6 @@ ${lanes.join("\n")} PropertyLikeParse2[PropertyLikeParse2["CallbackParameter"] = 4] = "CallbackParameter"; })(PropertyLikeParse || (PropertyLikeParse = {})); function parseJSDocCommentWorker(start = 0, length2) { - const saveParsingContext = parsingContext; - parsingContext |= 1 << 25 /* JSDocComment */; const content = sourceText; const end = length2 === void 0 ? content.length : start + length2; length2 = end - start; @@ -133384,26 +116479,28 @@ ${lanes.join("\n")} let commentsPos; let comments = []; const parts = []; + const saveParsingContext = parsingContext; + parsingContext |= 1 << 25 /* JSDocComment */; const result = scanner2.scanRange(start + 3, length2 - 5, doJSDocScan); parsingContext = saveParsingContext; return result; function doJSDocScan() { let state = 1 /* SawAsterisk */; let margin; - let indent2 = start - (content.lastIndexOf("\n", start) + 1) + 4; + let indent3 = start - (content.lastIndexOf("\n", start) + 1) + 4; function pushComment(text) { if (!margin) { - margin = indent2; + margin = indent3; } comments.push(text); - indent2 += text.length; + indent3 += text.length; } nextTokenJSDoc(); while (parseOptionalJsdoc(5 /* WhitespaceTrivia */)) ; if (parseOptionalJsdoc(4 /* NewLineTrivia */)) { state = 0 /* BeginningOfLine */; - indent2 = 0; + indent3 = 0; } loop: while (true) { @@ -133412,14 +116509,14 @@ ${lanes.join("\n")} removeTrailingWhitespace(comments); if (!commentsPos) commentsPos = getNodePos(); - addTag(parseTag(indent2)); + addTag(parseTag(indent3)); state = 0 /* BeginningOfLine */; margin = void 0; break; case 4 /* NewLineTrivia */: comments.push(scanner2.getTokenText()); state = 0 /* BeginningOfLine */; - indent2 = 0; + indent3 = 0; break; case 42 /* AsteriskToken */: const asterisk = scanner2.getTokenText(); @@ -133429,16 +116526,16 @@ ${lanes.join("\n")} } else { Debug.assert(state === 0 /* BeginningOfLine */); state = 1 /* SawAsterisk */; - indent2 += asterisk.length; + indent3 += asterisk.length; } break; case 5 /* WhitespaceTrivia */: Debug.assert(state !== 2 /* SavingComments */, "whitespace shouldn't come from the scanner while saving top-level comment text"); const whitespace = scanner2.getTokenText(); - if (margin !== void 0 && indent2 + whitespace.length > margin) { - comments.push(whitespace.slice(margin - indent2)); + if (margin !== void 0 && indent3 + whitespace.length > margin) { + comments.push(whitespace.slice(margin - indent3)); } - indent2 += whitespace.length; + indent3 += whitespace.length; break; case 1 /* EndOfFileToken */: break loop; @@ -133475,7 +116572,7 @@ ${lanes.join("\n")} nextTokenJSDoc(); } } - const trimmedComments = trimStringEnd(comments.join("")); + const trimmedComments = comments.join("").trimEnd(); if (parts.length && trimmedComments.length) { parts.push(finishNode(factory2.createJSDocText(trimmedComments), linkEnd ?? start, commentsPos)); } @@ -133491,7 +116588,7 @@ ${lanes.join("\n")} } function removeTrailingWhitespace(comments2) { while (comments2.length) { - const trimmed = trimStringEnd(comments2[comments2.length - 1]); + const trimmed = comments2[comments2.length - 1].trimEnd(); if (trimmed === "") { comments2.pop(); } else if (trimmed.length < comments2[comments2.length - 1].length) { @@ -133640,7 +116737,7 @@ ${lanes.join("\n")} } return parseTagComments(margin, indentText.slice(margin)); } - function parseTagComments(indent2, initialMargin) { + function parseTagComments(indent3, initialMargin) { const commentsPos2 = getNodePos(); let comments2 = []; const parts2 = []; @@ -133649,10 +116746,10 @@ ${lanes.join("\n")} let margin; function pushComment(text) { if (!margin) { - margin = indent2; + margin = indent3; } comments2.push(text); - indent2 += text.length; + indent3 += text.length; } if (initialMargin !== void 0) { if (initialMargin !== "") { @@ -133667,7 +116764,7 @@ ${lanes.join("\n")} case 4 /* NewLineTrivia */: state = 0 /* BeginningOfLine */; comments2.push(scanner2.getTokenText()); - indent2 = 0; + indent3 = 0; break; case 60 /* AtToken */: scanner2.resetTokenState(scanner2.getTokenEnd() - 1); @@ -133677,11 +116774,11 @@ ${lanes.join("\n")} case 5 /* WhitespaceTrivia */: Debug.assert(state !== 2 /* SavingComments */ && state !== 3 /* SavingBackticks */, "whitespace shouldn't come from the scanner while saving comment text"); const whitespace = scanner2.getTokenText(); - if (margin !== void 0 && indent2 + whitespace.length > margin) { - comments2.push(whitespace.slice(margin - indent2)); + if (margin !== void 0 && indent3 + whitespace.length > margin) { + comments2.push(whitespace.slice(margin - indent3)); state = 2 /* SavingComments */; } - indent2 += whitespace.length; + indent3 += whitespace.length; break; case 19 /* OpenBraceToken */: state = 2 /* SavingComments */; @@ -133714,7 +116811,7 @@ ${lanes.join("\n")} case 42 /* AsteriskToken */: if (state === 0 /* BeginningOfLine */) { state = 1 /* SawAsterisk */; - indent2 += 1; + indent3 += 1; break; } default: @@ -133731,7 +116828,7 @@ ${lanes.join("\n")} } } removeLeadingNewlines(comments2); - const trimmedComments = trimStringEnd(comments2.join("")); + const trimmedComments = comments2.join("").trimEnd(); if (parts2.length) { if (trimmedComments.length) { parts2.push(finishNode(factory2.createJSDocText(trimmedComments), linkEnd2 ?? commentsPos2)); @@ -133779,8 +116876,8 @@ ${lanes.join("\n")} function isJSDocLinkTag(kind) { return kind === "link" || kind === "linkcode" || kind === "linkplain"; } - function parseUnknownTag(start2, tagName, indent2, indentText) { - return finishNode(factory2.createJSDocUnknownTag(tagName, parseTrailingTagComments(start2, getNodePos(), indent2, indentText)), start2); + function parseUnknownTag(start2, tagName, indent3, indentText) { + return finishNode(factory2.createJSDocUnknownTag(tagName, parseTrailingTagComments(start2, getNodePos(), indent3, indentText)), start2); } function addTag(tag) { if (!tag) { @@ -133821,13 +116918,13 @@ ${lanes.join("\n")} switch (node.kind) { case 151 /* ObjectKeyword */: return true; - case 187 /* ArrayType */: + case 188 /* ArrayType */: return isObjectOrObjectArrayTypeReference(node.elementType); default: return isTypeReferenceNode(node) && isIdentifier(node.typeName) && node.typeName.escapedText === "Object" && !node.typeArguments; } } - function parseParameterOrPropertyTag(start2, tagName, target, indent2) { + function parseParameterOrPropertyTag(start2, tagName, target, indent3) { let typeExpression = tryParseTypeExpression(); let isNameFirst = !typeExpression; skipWhitespaceOrAsterisk(); @@ -133836,8 +116933,8 @@ ${lanes.join("\n")} if (isNameFirst && !lookAhead(parseJSDocLinkPrefix)) { typeExpression = tryParseTypeExpression(); } - const comment = parseTrailingTagComments(start2, getNodePos(), indent2, indentText); - const nestedTypeLiteral = target !== 4 /* CallbackParameter */ && parseNestedTypeLiteral(typeExpression, name, target, indent2); + const comment = parseTrailingTagComments(start2, getNodePos(), indent3, indentText); + const nestedTypeLiteral = parseNestedTypeLiteral(typeExpression, name, target, indent3); if (nestedTypeLiteral) { typeExpression = nestedTypeLiteral; isNameFirst = true; @@ -133845,32 +116942,32 @@ ${lanes.join("\n")} const result2 = target === 1 /* Property */ ? factory2.createJSDocPropertyTag(tagName, name, isBracketed, typeExpression, isNameFirst, comment) : factory2.createJSDocParameterTag(tagName, name, isBracketed, typeExpression, isNameFirst, comment); return finishNode(result2, start2); } - function parseNestedTypeLiteral(typeExpression, name, target, indent2) { + function parseNestedTypeLiteral(typeExpression, name, target, indent3) { if (typeExpression && isObjectOrObjectArrayTypeReference(typeExpression.type)) { const pos = getNodePos(); let child; let children; - while (child = tryParse(() => parseChildParameterOrPropertyTag(target, indent2, name))) { - if (child.kind === 347 /* JSDocParameterTag */ || child.kind === 354 /* JSDocPropertyTag */) { + while (child = tryParse(() => parseChildParameterOrPropertyTag(target, indent3, name))) { + if (child.kind === 348 /* JSDocParameterTag */ || child.kind === 355 /* JSDocPropertyTag */) { children = append(children, child); - } else if (child.kind === 351 /* JSDocTemplateTag */) { + } else if (child.kind === 352 /* JSDocTemplateTag */) { parseErrorAtRange(child.tagName, Diagnostics.A_JSDoc_template_tag_may_not_follow_a_typedef_callback_or_overload_tag); } } if (children) { - const literal = finishNode(factory2.createJSDocTypeLiteral(children, typeExpression.type.kind === 187 /* ArrayType */), pos); + const literal = finishNode(factory2.createJSDocTypeLiteral(children, typeExpression.type.kind === 188 /* ArrayType */), pos); return finishNode(factory2.createJSDocTypeExpression(literal), pos); } } } - function parseReturnTag(start2, tagName, indent2, indentText) { + function parseReturnTag(start2, tagName, indent3, indentText) { if (some(tags, isJSDocReturnTag)) { parseErrorAt(tagName.pos, scanner2.getTokenStart(), Diagnostics._0_tag_already_specified, unescapeLeadingUnderscores(tagName.escapedText)); } const typeExpression = tryParseTypeExpression(); - return finishNode(factory2.createJSDocReturnTag(tagName, typeExpression, parseTrailingTagComments(start2, getNodePos(), indent2, indentText)), start2); + return finishNode(factory2.createJSDocReturnTag(tagName, typeExpression, parseTrailingTagComments(start2, getNodePos(), indent3, indentText)), start2); } - function parseTypeTag(start2, tagName, indent2, indentText) { + function parseTypeTag(start2, tagName, indent3, indentText) { if (some(tags, isJSDocTypeTag)) { parseErrorAt(tagName.pos, scanner2.getTokenStart(), Diagnostics._0_tag_already_specified, unescapeLeadingUnderscores(tagName.escapedText)); } @@ -133878,25 +116975,25 @@ ${lanes.join("\n")} /*mayOmitBraces*/ true ); - const comments2 = indent2 !== void 0 && indentText !== void 0 ? parseTrailingTagComments(start2, getNodePos(), indent2, indentText) : void 0; + const comments2 = indent3 !== void 0 && indentText !== void 0 ? parseTrailingTagComments(start2, getNodePos(), indent3, indentText) : void 0; return finishNode(factory2.createJSDocTypeTag(tagName, typeExpression, comments2), start2); } - function parseSeeTag(start2, tagName, indent2, indentText) { + function parseSeeTag(start2, tagName, indent3, indentText) { const isMarkdownOrJSDocLink = token() === 23 /* OpenBracketToken */ || lookAhead(() => nextTokenJSDoc() === 60 /* AtToken */ && tokenIsIdentifierOrKeyword(nextTokenJSDoc()) && isJSDocLinkTag(scanner2.getTokenValue())); const nameExpression = isMarkdownOrJSDocLink ? void 0 : parseJSDocNameReference(); - const comments2 = indent2 !== void 0 && indentText !== void 0 ? parseTrailingTagComments(start2, getNodePos(), indent2, indentText) : void 0; + const comments2 = indent3 !== void 0 && indentText !== void 0 ? parseTrailingTagComments(start2, getNodePos(), indent3, indentText) : void 0; return finishNode(factory2.createJSDocSeeTag(tagName, nameExpression, comments2), start2); } - function parseThrowsTag(start2, tagName, indent2, indentText) { + function parseThrowsTag(start2, tagName, indent3, indentText) { const typeExpression = tryParseTypeExpression(); - const comment = parseTrailingTagComments(start2, getNodePos(), indent2, indentText); + const comment = parseTrailingTagComments(start2, getNodePos(), indent3, indentText); return finishNode(factory2.createJSDocThrowsTag(tagName, typeExpression, comment), start2); } - function parseAuthorTag(start2, tagName, indent2, indentText) { + function parseAuthorTag(start2, tagName, indent3, indentText) { const commentStart = getNodePos(); const textOnly = parseAuthorNameAndEmail(); let commentEnd = scanner2.getTokenFullStart(); - const comments2 = parseTrailingTagComments(start2, commentEnd, indent2, indentText); + const comments2 = parseTrailingTagComments(start2, commentEnd, indent3, indentText); if (!comments2) { commentEnd = scanner2.getTokenFullStart(); } @@ -133980,28 +117077,28 @@ ${lanes.join("\n")} skipWhitespace(); return finishNode(factory2.createJSDocEnumTag(tagName, typeExpression, parseTrailingTagComments(start2, getNodePos(), margin, indentText)), start2); } - function parseTypedefTag(start2, tagName, indent2, indentText) { + function parseTypedefTag(start2, tagName, indent3, indentText) { let typeExpression = tryParseTypeExpression(); skipWhitespaceOrAsterisk(); const fullName = parseJSDocTypeNameWithNamespace(); skipWhitespace(); - let comment = parseTagComments(indent2); + let comment = parseTagComments(indent3); let end2; if (!typeExpression || isObjectOrObjectArrayTypeReference(typeExpression.type)) { let child; let childTypeTag; let jsDocPropertyTags; let hasChildren = false; - while (child = tryParse(() => parseChildPropertyTag(indent2))) { - if (child.kind === 351 /* JSDocTemplateTag */) { + while (child = tryParse(() => parseChildPropertyTag(indent3))) { + if (child.kind === 352 /* JSDocTemplateTag */) { break; } hasChildren = true; - if (child.kind === 350 /* JSDocTypeTag */) { + if (child.kind === 351 /* JSDocTypeTag */) { if (childTypeTag) { const lastError = parseErrorAtCurrentToken(Diagnostics.A_JSDoc_typedef_comment_may_not_contain_multiple_type_tags); if (lastError) { - addRelatedInfo(lastError, createDetachedDiagnostic(fileName, 0, 0, Diagnostics.The_tag_was_first_specified_here)); + addRelatedInfo(lastError, createDetachedDiagnostic(fileName, sourceText, 0, 0, Diagnostics.The_tag_was_first_specified_here)); } break; } else { @@ -134012,7 +117109,7 @@ ${lanes.join("\n")} } } if (hasChildren) { - const isArrayType = typeExpression && typeExpression.type.kind === 187 /* ArrayType */; + const isArrayType = typeExpression && typeExpression.type.kind === 188 /* ArrayType */; const jsdocTypeLiteral = factory2.createJSDocTypeLiteral(jsDocPropertyTags, isArrayType); typeExpression = childTypeTag && childTypeTag.typeExpression && !isObjectOrObjectArrayTypeReference(childTypeTag.typeExpression.type) ? childTypeTag.typeExpression : finishNode(jsdocTypeLiteral, start2); end2 = typeExpression.end; @@ -134020,7 +117117,7 @@ ${lanes.join("\n")} } end2 = end2 || comment !== void 0 ? getNodePos() : (fullName ?? typeExpression ?? tagName).end; if (!comment) { - comment = parseTrailingTagComments(start2, end2, indent2, indentText); + comment = parseTrailingTagComments(start2, end2, indent3, indentText); } const typedefTag = factory2.createJSDocTypedefTag(tagName, typeExpression, fullName, comment); return finishNode(typedefTag, start2, end2); @@ -134041,21 +117138,21 @@ ${lanes.join("\n")} void 0, typeNameOrNamespaceName, body, - nested ? 4 /* NestedNamespace */ : void 0 + nested ? 8 /* NestedNamespace */ : void 0 ); return finishNode(jsDocNamespaceNode, start2); } if (nested) { - typeNameOrNamespaceName.flags |= 2048 /* IdentifierIsInJSDocNamespace */; + typeNameOrNamespaceName.flags |= 4096 /* IdentifierIsInJSDocNamespace */; } return typeNameOrNamespaceName; } - function parseCallbackTagParameters(indent2) { + function parseCallbackTagParameters(indent3) { const pos = getNodePos(); let child; let parameters; - while (child = tryParse(() => parseChildParameterOrPropertyTag(4 /* CallbackParameter */, indent2))) { - if (child.kind === 351 /* JSDocTemplateTag */) { + while (child = tryParse(() => parseChildParameterOrPropertyTag(4 /* CallbackParameter */, indent3))) { + if (child.kind === 352 /* JSDocTemplateTag */) { parseErrorAtRange(child.tagName, Diagnostics.A_JSDoc_template_tag_may_not_follow_a_typedef_callback_or_overload_tag); break; } @@ -134063,12 +117160,12 @@ ${lanes.join("\n")} } return createNodeArray(parameters || [], pos); } - function parseJSDocSignature(start2, indent2) { - const parameters = parseCallbackTagParameters(indent2); + function parseJSDocSignature(start2, indent3) { + const parameters = parseCallbackTagParameters(indent3); const returnTag = tryParse(() => { if (parseOptionalJsdoc(60 /* AtToken */)) { - const tag = parseTag(indent2); - if (tag && tag.kind === 348 /* JSDocReturnTag */) { + const tag = parseTag(indent3); + if (tag && tag.kind === 349 /* JSDocReturnTag */) { return tag; } } @@ -134080,23 +117177,23 @@ ${lanes.join("\n")} returnTag ), start2); } - function parseCallbackTag(start2, tagName, indent2, indentText) { + function parseCallbackTag(start2, tagName, indent3, indentText) { const fullName = parseJSDocTypeNameWithNamespace(); skipWhitespace(); - let comment = parseTagComments(indent2); - const typeExpression = parseJSDocSignature(start2, indent2); + let comment = parseTagComments(indent3); + const typeExpression = parseJSDocSignature(start2, indent3); if (!comment) { - comment = parseTrailingTagComments(start2, getNodePos(), indent2, indentText); + comment = parseTrailingTagComments(start2, getNodePos(), indent3, indentText); } const end2 = comment !== void 0 ? getNodePos() : typeExpression.end; return finishNode(factory2.createJSDocCallbackTag(tagName, typeExpression, fullName, comment), start2, end2); } - function parseOverloadTag(start2, tagName, indent2, indentText) { + function parseOverloadTag(start2, tagName, indent3, indentText) { skipWhitespace(); - let comment = parseTagComments(indent2); - const typeExpression = parseJSDocSignature(start2, indent2); + let comment = parseTagComments(indent3); + const typeExpression = parseJSDocSignature(start2, indent3); if (!comment) { - comment = parseTrailingTagComments(start2, getNodePos(), indent2, indentText); + comment = parseTrailingTagComments(start2, getNodePos(), indent3, indentText); } const end2 = comment !== void 0 ? getNodePos() : typeExpression.end; return finishNode(factory2.createJSDocOverloadTag(tagName, typeExpression, comment), start2, end2); @@ -134112,18 +117209,18 @@ ${lanes.join("\n")} } return a.escapedText === b.escapedText; } - function parseChildPropertyTag(indent2) { - return parseChildParameterOrPropertyTag(1 /* Property */, indent2); + function parseChildPropertyTag(indent3) { + return parseChildParameterOrPropertyTag(1 /* Property */, indent3); } - function parseChildParameterOrPropertyTag(target, indent2, name) { + function parseChildParameterOrPropertyTag(target, indent3, name) { let canParseTag = true; let seenAsterisk = false; while (true) { switch (nextTokenJSDoc()) { case 60 /* AtToken */: if (canParseTag) { - const child = tryParseChildTag(target, indent2); - if (child && (child.kind === 347 /* JSDocParameterTag */ || child.kind === 354 /* JSDocPropertyTag */) && target !== 4 /* CallbackParameter */ && name && (isIdentifier(child.name) || !escapedTextsEqual(name, child.name.left))) { + const child = tryParseChildTag(target, indent3); + if (child && (child.kind === 348 /* JSDocParameterTag */ || child.kind === 355 /* JSDocPropertyTag */) && name && (isIdentifier(child.name) || !escapedTextsEqual(name, child.name.left))) { return false; } return child; @@ -134148,7 +117245,7 @@ ${lanes.join("\n")} } } } - function tryParseChildTag(target, indent2) { + function tryParseChildTag(target, indent3) { Debug.assert(token() === 60 /* AtToken */); const start2 = scanner2.getTokenFullStart(); nextTokenJSDoc(); @@ -134168,14 +117265,14 @@ ${lanes.join("\n")} t = 2 /* Parameter */ | 4 /* CallbackParameter */; break; case "template": - return parseTemplateTag(start2, tagName, indent2, indentText); + return parseTemplateTag(start2, tagName, indent3, indentText); default: return false; } if (!(target & t)) { return false; } - return parseParameterOrPropertyTag(start2, tagName, target, indent2); + return parseParameterOrPropertyTag(start2, tagName, target, indent3); } function parseTemplateTagTypeParameter() { const typeParameterPos = getNodePos(); @@ -134188,7 +117285,7 @@ ${lanes.join("\n")} if (isBracketed) { skipWhitespace(); parseExpected(64 /* EqualsToken */); - defaultType = doInsideOfContext(8388608 /* JSDoc */, parseJSDocType); + defaultType = doInsideOfContext(16777216 /* JSDoc */, parseJSDocType); parseExpected(24 /* CloseBracketToken */); } if (nodeIsMissing(name)) { @@ -134216,10 +117313,10 @@ ${lanes.join("\n")} } while (parseOptionalJsdoc(28 /* CommaToken */)); return createNodeArray(typeParameters, pos); } - function parseTemplateTag(start2, tagName, indent2, indentText) { + function parseTemplateTag(start2, tagName, indent3, indentText) { const constraint = token() === 19 /* OpenBraceToken */ ? parseJSDocTypeExpression() : void 0; const typeParameters = parseTemplateTagTypeParameters(); - return finishNode(factory2.createJSDocTemplateTag(tagName, constraint, typeParameters, parseTrailingTagComments(start2, getNodePos(), indent2, indentText)), start2); + return finishNode(factory2.createJSDocTemplateTag(tagName, constraint, typeParameters, parseTrailingTagComments(start2, getNodePos(), indent3, indentText)), start2); } function parseOptionalJsdoc(t) { if (token() === t) { @@ -134280,7 +117377,8 @@ ${lanes.join("\n")} /*setParentNodes*/ true, sourceFile.scriptKind, - sourceFile.setExternalModuleIndicator + sourceFile.setExternalModuleIndicator, + sourceFile.jsDocParsingMode ); } const incrementalSourceFile = sourceFile; @@ -134295,16 +117393,7 @@ ${lanes.join("\n")} Debug.assert(textSpanEnd(changeRange.span) === textSpanEnd(textChangeRange.span)); Debug.assert(textSpanEnd(textChangeRangeNewSpan(changeRange)) === textSpanEnd(textChangeRangeNewSpan(textChangeRange))); const delta = textChangeRangeNewSpan(changeRange).length - changeRange.span.length; - updateTokenPositionsAndMarkElements( - incrementalSourceFile, - changeRange.span.start, - textSpanEnd(changeRange.span), - textSpanEnd(textChangeRangeNewSpan(changeRange)), - delta, - oldText, - newText, - aggressiveChecks - ); + updateTokenPositionsAndMarkElements(incrementalSourceFile, changeRange.span.start, textSpanEnd(changeRange.span), textSpanEnd(textChangeRangeNewSpan(changeRange)), delta, oldText, newText, aggressiveChecks); const result = Parser.parseSourceFile( sourceFile.fileName, newText, @@ -134313,7 +117402,8 @@ ${lanes.join("\n")} /*setParentNodes*/ true, sourceFile.scriptKind, - sourceFile.setExternalModuleIndicator + sourceFile.setExternalModuleIndicator, + sourceFile.jsDocParsingMode ); result.commentDirectives = getNewCommentDirectives( sourceFile.commentDirectives, @@ -134638,7 +117728,7 @@ ${lanes.join("\n")} })(IncrementalParser || (IncrementalParser = {})); namedArgRegExCache = /* @__PURE__ */ new Map(); tripleSlashXMLCommentStartRegEx = /^\/\/\/\s*<(\S+)\s.*?\/>/im; - singleLinePragmaRegEx = /^\/\/\/?\s*@(\S+)\s*(.*)\s*$/im; + singleLinePragmaRegEx = /^\/\/\/?\s*@([^\s:]+)(.*)\s*$/im; } }); @@ -134666,14 +117756,14 @@ ${lanes.join("\n")} return createDiagnostic(Diagnostics.Argument_for_0_option_must_be_Colon_1, `--${opt.name}`, stringNames); } function parseCustomTypeOption(opt, value, errors) { - return convertJsonOptionOfCustomType(opt, trimString(value || ""), errors); + return convertJsonOptionOfCustomType(opt, (value ?? "").trim(), errors); } function parseListTypeOption(opt, value = "", errors) { - value = trimString(value); + value = value.trim(); if (startsWith(value, "-")) { return void 0; } - if (opt.type === "listOrElement" && !stringContains(value, ",")) { + if (opt.type === "listOrElement" && !value.includes(",")) { return validateJsonOptionValue(opt, value, errors); } if (value === "") { @@ -134894,9 +117984,8 @@ ${lanes.join("\n")} } return { buildOptions, watchOptions, projects, errors }; } - function getDiagnosticText(_message, ..._args) { - const diagnostic = createCompilerDiagnostic.apply(void 0, arguments); - return diagnostic.messageText; + function getDiagnosticText(message, ...args) { + return cast(createCompilerDiagnostic(message, ...args).messageText, isString); } function getParsedCommandLineOfConfigFile(configFileName, optionsToExtend, host, extendedConfigCache, watchOptionsToExtend, extraFileExtensions) { const configFileText = tryReadFile(configFileName, (fileName) => host.readFile(fileName)); @@ -135024,7 +118113,7 @@ ${lanes.join("\n")} function convertConfigFileToObject(sourceFile, errors, jsonConversionNotifier) { var _a; const rootExpression = (_a = sourceFile.statements[0]) == null ? void 0 : _a.expression; - if (rootExpression && rootExpression.kind !== 209 /* ObjectLiteralExpression */) { + if (rootExpression && rootExpression.kind !== 210 /* ObjectLiteralExpression */) { errors.push(createDiagnosticForNodeInSourceFile( sourceFile, rootExpression, @@ -135076,7 +118165,7 @@ ${lanes.join("\n")} var _a; const result = returnValue ? {} : void 0; for (const element of node.properties) { - if (element.kind !== 302 /* PropertyAssignment */) { + if (element.kind !== 303 /* PropertyAssignment */) { errors.push(createDiagnosticForNodeInSourceFile(sourceFile, element, Diagnostics.Property_assignment_expected)); continue; } @@ -135121,15 +118210,15 @@ ${lanes.join("\n")} return valueExpression.text; case 9 /* NumericLiteral */: return Number(valueExpression.text); - case 223 /* PrefixUnaryExpression */: + case 224 /* PrefixUnaryExpression */: if (valueExpression.operator !== 41 /* MinusToken */ || valueExpression.operand.kind !== 9 /* NumericLiteral */) { break; } return -Number(valueExpression.operand.text); - case 209 /* ObjectLiteralExpression */: + case 210 /* ObjectLiteralExpression */: const objectLiteralExpression = valueExpression; return convertObjectLiteralExpressionToJson(objectLiteralExpression, option); - case 208 /* ArrayLiteralExpression */: + case 209 /* ArrayLiteralExpression */: return convertArrayLiteralExpressionToJson( valueExpression.elements, option && option.element @@ -135512,8 +118601,8 @@ ${lanes.join("\n")} const fileName = configFileName || "tsconfig.json"; const diagnosticMessage = Diagnostics.The_files_list_in_config_file_0_is_empty; const nodeValue = forEachTsConfigPropArray(sourceFile, "files", (property) => property.initializer); - const error = createDiagnosticForNodeInSourceFileOrCompilerDiagnostic(sourceFile, nodeValue, diagnosticMessage, fileName); - errors.push(error); + const error2 = createDiagnosticForNodeInSourceFileOrCompilerDiagnostic(sourceFile, nodeValue, diagnosticMessage, fileName); + errors.push(error2); } else { createCompilerDiagnosticOnlyIfJson(Diagnostics.The_files_list_in_config_file_0_is_empty, configFileName || "tsconfig.json"); } @@ -135620,8 +118709,8 @@ ${lanes.join("\n")} } } } - function isErrorNoInputFiles(error) { - return error.code === Diagnostics.No_inputs_were_found_in_config_file_0_Specified_include_paths_were_1_and_exclude_paths_were_2.code; + function isErrorNoInputFiles(error2) { + return error2.code === Diagnostics.No_inputs_were_found_in_config_file_0_Specified_include_paths_were_1_and_exclude_paths_were_2.code; } function getErrorForNoInputFiles({ includeSpecs, excludeSpecs }, configFileName) { return createCompilerDiagnostic( @@ -135642,7 +118731,7 @@ ${lanes.join("\n")} if (shouldReportNoInputFiles(fileNames, canJsonReportNoInutFiles)) { configParseDiagnostics.push(getErrorForNoInputFiles(configFileSpecs, configFileName)); } else { - filterMutate(configParseDiagnostics, (error) => !isErrorNoInputFiles(error)); + filterMutate(configParseDiagnostics, (error2) => !isErrorNoInputFiles(error2)); } return existingErrors !== configParseDiagnostics.length; } @@ -135653,7 +118742,7 @@ ${lanes.join("\n")} var _a; basePath = normalizeSlashes(basePath); const resolvedPath = getNormalizedAbsolutePath(configFileName || "", basePath); - if (resolutionStack.indexOf(resolvedPath) >= 0) { + if (resolutionStack.includes(resolvedPath)) { errors.push(createCompilerDiagnostic(Diagnostics.Circularity_detected_while_resolving_configuration_Colon_0, [...resolutionStack, resolvedPath].join(" -> "))); return { raw: json || convertToObject(sourceFile, errors) }; } @@ -135735,14 +118824,17 @@ ${lanes.join("\n")} for (let index = 0; index < value.length; index++) { const fileName = value[index]; if (isString(fileName)) { - extendedConfigPath = append(extendedConfigPath, getExtendsConfigPath( - fileName, - host, - newBase, - errors, - valueExpression == null ? void 0 : valueExpression.elements[index], - sourceFile - )); + extendedConfigPath = append( + extendedConfigPath, + getExtendsConfigPath( + fileName, + host, + newBase, + errors, + valueExpression == null ? void 0 : valueExpression.elements[index], + sourceFile + ) + ); } else { convertJsonOption(extendsOptionDeclaration.element, value, basePath, errors, propertyAssignment, valueExpression == null ? void 0 : valueExpression.elements[index], sourceFile); } @@ -136050,19 +119142,19 @@ ${lanes.join("\n")} const wildcardFiles = arrayFrom(wildcardFileMap.values()); return literalFiles.concat(wildcardFiles, arrayFrom(wildCardJsonFileMap.values())); } - function isExcludedFile(pathToCheck, spec, basePath, useCaseSensitiveFileNames, currentDirectory) { + function isExcludedFile(pathToCheck, spec, basePath, useCaseSensitiveFileNames2, currentDirectory) { const { validatedFilesSpec, validatedIncludeSpecs, validatedExcludeSpecs } = spec; if (!length(validatedIncludeSpecs) || !length(validatedExcludeSpecs)) return false; basePath = normalizePath(basePath); - const keyMapper = createGetCanonicalFileName(useCaseSensitiveFileNames); + const keyMapper = createGetCanonicalFileName(useCaseSensitiveFileNames2); if (validatedFilesSpec) { for (const fileName of validatedFilesSpec) { if (keyMapper(getNormalizedAbsolutePath(fileName, basePath)) === pathToCheck) return false; } } - return matchesExcludeWorker(pathToCheck, validatedExcludeSpecs, useCaseSensitiveFileNames, currentDirectory, basePath); + return matchesExcludeWorker(pathToCheck, validatedExcludeSpecs, useCaseSensitiveFileNames2, currentDirectory, basePath); } function invalidDotDotAfterRecursiveWildcard(s) { const wildcardIndex = startsWith(s, "**/") ? 0 : s.indexOf("/**/"); @@ -136072,17 +119164,17 @@ ${lanes.join("\n")} const lastDotIndex = endsWith(s, "/..") ? s.length : s.lastIndexOf("/../"); return lastDotIndex > wildcardIndex; } - function matchesExclude(pathToCheck, excludeSpecs, useCaseSensitiveFileNames, currentDirectory) { + function matchesExclude(pathToCheck, excludeSpecs, useCaseSensitiveFileNames2, currentDirectory) { return matchesExcludeWorker( pathToCheck, filter(excludeSpecs, (spec) => !invalidDotDotAfterRecursiveWildcard(spec)), - useCaseSensitiveFileNames, + useCaseSensitiveFileNames2, currentDirectory ); } - function matchesExcludeWorker(pathToCheck, excludeSpecs, useCaseSensitiveFileNames, currentDirectory, basePath) { + function matchesExcludeWorker(pathToCheck, excludeSpecs, useCaseSensitiveFileNames2, currentDirectory, basePath) { const excludePattern = getRegularExpressionForWildcard(excludeSpecs, combinePaths(normalizePath(currentDirectory), basePath), "exclude"); - const excludeRegex = excludePattern && getRegexFromPattern(excludePattern, useCaseSensitiveFileNames); + const excludeRegex = excludePattern && getRegexFromPattern(excludePattern, useCaseSensitiveFileNames2); if (!excludeRegex) return false; if (excludeRegex.test(pathToCheck)) @@ -136112,9 +119204,9 @@ ${lanes.join("\n")} return [Diagnostics.File_specification_cannot_contain_a_parent_directory_that_appears_after_a_recursive_directory_wildcard_Asterisk_Asterisk_Colon_0, spec]; } } - function getWildcardDirectories({ validatedIncludeSpecs: include, validatedExcludeSpecs: exclude }, path, useCaseSensitiveFileNames) { + function getWildcardDirectories({ validatedIncludeSpecs: include, validatedExcludeSpecs: exclude }, path, useCaseSensitiveFileNames2) { const rawExcludeRegex = getRegularExpressionForWildcard(exclude, path, "exclude"); - const excludeRegex = rawExcludeRegex && new RegExp(rawExcludeRegex, useCaseSensitiveFileNames ? "" : "i"); + const excludeRegex = rawExcludeRegex && new RegExp(rawExcludeRegex, useCaseSensitiveFileNames2 ? "" : "i"); const wildcardDirectories = {}; if (include !== void 0) { const recursiveKeys = []; @@ -136123,7 +119215,7 @@ ${lanes.join("\n")} if (excludeRegex && excludeRegex.test(spec)) { continue; } - const match = getWildcardDirectoryFromSpec(spec, useCaseSensitiveFileNames); + const match = getWildcardDirectoryFromSpec(spec, useCaseSensitiveFileNames2); if (match) { const { key, flags } = match; const existingFlags = wildcardDirectories[key]; @@ -136138,7 +119230,7 @@ ${lanes.join("\n")} for (const key in wildcardDirectories) { if (hasProperty(wildcardDirectories, key)) { for (const recursiveKey of recursiveKeys) { - if (key !== recursiveKey && containsPath(recursiveKey, key, path, !useCaseSensitiveFileNames)) { + if (key !== recursiveKey && containsPath(recursiveKey, key, path, !useCaseSensitiveFileNames2)) { delete wildcardDirectories[key]; } } @@ -136147,20 +119239,20 @@ ${lanes.join("\n")} } return wildcardDirectories; } - function getWildcardDirectoryFromSpec(spec, useCaseSensitiveFileNames) { + function getWildcardDirectoryFromSpec(spec, useCaseSensitiveFileNames2) { const match = wildcardDirectoryPattern.exec(spec); if (match) { const questionWildcardIndex = spec.indexOf("?"); const starWildcardIndex = spec.indexOf("*"); const lastDirectorySeperatorIndex = spec.lastIndexOf(directorySeparator); return { - key: useCaseSensitiveFileNames ? match[0] : toFileNameLowerCase(match[0]), + key: useCaseSensitiveFileNames2 ? match[0] : toFileNameLowerCase(match[0]), flags: questionWildcardIndex !== -1 && questionWildcardIndex < lastDirectorySeperatorIndex || starWildcardIndex !== -1 && starWildcardIndex < lastDirectorySeperatorIndex ? 1 /* Recursive */ : 0 /* None */ }; } if (isImplicitGlob(spec.substring(spec.lastIndexOf(directorySeparator) + 1))) { return { - key: removeTrailingDirectorySeparator(useCaseSensitiveFileNames ? spec : toFileNameLowerCase(spec)), + key: removeTrailingDirectorySeparator(useCaseSensitiveFileNames2 ? spec : toFileNameLowerCase(spec)), flags: 1 /* Recursive */ }; } @@ -136172,7 +119264,7 @@ ${lanes.join("\n")} return false; } for (const ext of extensionGroup) { - if (fileExtensionIs(file, ext)) { + if (fileExtensionIs(file, ext) && (ext !== ".ts" /* Ts */ || !fileExtensionIs(file, ".d.ts" /* Dts */))) { return false; } const higherPriorityPath = keyMapper(changeExtension(file, ext)); @@ -136310,6 +119402,7 @@ ${lanes.join("\n")} ["es2015.symbol", "lib.es2015.symbol.d.ts"], ["es2015.symbol.wellknown", "lib.es2015.symbol.wellknown.d.ts"], ["es2016.array.include", "lib.es2016.array.include.d.ts"], + ["es2017.date", "lib.es2017.date.d.ts"], ["es2017.object", "lib.es2017.object.d.ts"], ["es2017.sharedmemory", "lib.es2017.sharedmemory.d.ts"], ["es2017.string", "lib.es2017.string.d.ts"], @@ -136345,14 +119438,18 @@ ${lanes.join("\n")} ["es2022.string", "lib.es2022.string.d.ts"], ["es2022.regexp", "lib.es2022.regexp.d.ts"], ["es2023.array", "lib.es2023.array.d.ts"], + ["es2023.collection", "lib.es2023.collection.d.ts"], ["esnext.array", "lib.es2023.array.d.ts"], + ["esnext.collection", "lib.es2023.collection.d.ts"], ["esnext.symbol", "lib.es2019.symbol.d.ts"], ["esnext.asynciterable", "lib.es2018.asynciterable.d.ts"], ["esnext.intl", "lib.esnext.intl.d.ts"], + ["esnext.disposable", "lib.esnext.disposable.d.ts"], ["esnext.bigint", "lib.es2020.bigint.d.ts"], ["esnext.string", "lib.es2022.string.d.ts"], ["esnext.promise", "lib.es2021.promise.d.ts"], ["esnext.weakref", "lib.es2021.weakref.d.ts"], + ["esnext.decorators", "lib.esnext.decorators.d.ts"], ["decorators", "lib.decorators.d.ts"], ["decorators.legacy", "lib.decorators.legacy.d.ts"] ]; @@ -136659,6 +119756,7 @@ ${lanes.join("\n")} node16: 100 /* Node16 */, nodenext: 199 /* NodeNext */ })), + affectsSourceFile: true, affectsModuleResolution: true, affectsEmit: true, affectsBuildInfo: true, @@ -136751,7 +119849,8 @@ ${lanes.join("\n")} { name: "allowJs", type: "boolean", - affectsModuleResolution: true, + allowJsFlag: true, + affectsBuildInfo: true, showInSimplifiedHelpView: true, category: Diagnostics.JavaScript_Support, description: Diagnostics.Allow_JavaScript_files_to_be_a_part_of_your_program_Use_the_checkJS_option_to_get_errors_from_these_files, @@ -136760,6 +119859,9 @@ ${lanes.join("\n")} { name: "checkJs", type: "boolean", + affectsModuleResolution: true, + affectsSemanticDiagnostics: true, + affectsBuildInfo: true, showInSimplifiedHelpView: true, category: Diagnostics.JavaScript_Support, description: Diagnostics.Enable_error_reporting_in_type_checked_JavaScript_files, @@ -136772,6 +119874,10 @@ ${lanes.join("\n")} affectsEmit: true, affectsBuildInfo: true, affectsModuleResolution: true, + // The checker emits an error when it sees JSX but this option is not set in compilerOptions. + // This is effectively a semantic error, so mark this option as affecting semantic diagnostics + // so we know to refresh errors when this option is changed. + affectsSemanticDiagnostics: true, paramType: Diagnostics.KIND, showInSimplifiedHelpView: true, category: Diagnostics.Language_and_Environment, @@ -136986,7 +120092,7 @@ ${lanes.join("\n")} strictFlag: true, category: Diagnostics.Type_Checking, description: Diagnostics.Default_catch_clause_variables_as_unknown_instead_of_any, - defaultValueDescription: false + defaultValueDescription: Diagnostics.false_unless_strict_is_set }, { name: "alwaysStrict", @@ -137087,6 +120193,7 @@ ${lanes.join("\n")} bundler: 100 /* Bundler */ })), deprecatedKeys: /* @__PURE__ */ new Set(["node"]), + affectsSourceFile: true, affectsModuleResolution: true, paramType: Diagnostics.STRATEGY, category: Diagnostics.Modules, @@ -137337,7 +120444,7 @@ ${lanes.join("\n")} affectsBuildInfo: true, affectsDeclarationPath: true, isFilePath: false, - // This is intentionally broken to support compatability with existing tsconfig files + // This is intentionally broken to support compatibility with existing tsconfig files // for correct behaviour, please use outFile category: Diagnostics.Backwards_Compatibility, paramType: Diagnostics.FILE, @@ -137629,6 +120736,7 @@ ${lanes.join("\n")} legacy: 1 /* Legacy */, force: 3 /* Force */ })), + affectsSourceFile: true, affectsModuleResolution: true, description: Diagnostics.Control_what_method_is_used_to_detect_module_format_JS_files, category: Diagnostics.Language_and_Environment, @@ -137648,7 +120756,7 @@ ${lanes.join("\n")} affectsEmitOptionDeclarations = optionDeclarations.filter((option) => !!option.affectsEmit); affectsDeclarationPathOptionDeclarations = optionDeclarations.filter((option) => !!option.affectsDeclarationPath); moduleResolutionOptionDeclarations = optionDeclarations.filter((option) => !!option.affectsModuleResolution); - sourceFileAffectingCompilerOptions = optionDeclarations.filter((option) => !!option.affectsSourceFile || !!option.affectsModuleResolution || !!option.affectsBindDiagnostics); + sourceFileAffectingCompilerOptions = optionDeclarations.filter((option) => !!option.affectsSourceFile || !!option.affectsBindDiagnostics); optionsAffectingProgramStructure = optionDeclarations.filter((option) => !!option.affectsProgramStructure); transpileOptionValueCompilerOptions = optionDeclarations.filter((option) => hasProperty(option, "transpileOptionValue")); optionsForBuild = [ @@ -137794,9 +120902,76 @@ ${lanes.join("\n")} } }); + // src/compiler/pnp.ts + function getPnpApi(path) { + if (typeof process.versions.pnp === "undefined") { + return; + } + const { findPnpApi } = __nccwpck_require__(98188); + if (findPnpApi) { + return findPnpApi(`${path}/`); + } + } + function getPnpApiPath(path) { + var _a; + return (_a = getPnpApi(path)) == null ? void 0 : _a.resolveRequest( + "pnpapi", + /*issuer*/ + null + ); + } + function getPnpTypeRoots(currentDirectory) { + const pnpApi = getPnpApi(currentDirectory); + if (!pnpApi) { + return []; + } + currentDirectory = resolvePath(currentDirectory); + const currentPackage = pnpApi.findPackageLocator(`${currentDirectory}/`); + if (!currentPackage) { + return []; + } + const { packageDependencies } = pnpApi.getPackageInformation(currentPackage); + const typeRoots = []; + for (const [name, referencish] of Array.from(packageDependencies.entries())) { + if (name.startsWith(`@types/`) && referencish !== null) { + const dependencyLocator = pnpApi.getLocator(name, referencish); + const { packageLocation } = pnpApi.getPackageInformation(dependencyLocator); + typeRoots.push(getDirectoryPath(packageLocation)); + } + } + return typeRoots; + } + function isImportablePathPnp(fromPath, toPath3) { + const pnpApi = getPnpApi(fromPath); + const fromLocator = pnpApi.findPackageLocator(fromPath); + const toLocator = pnpApi.findPackageLocator(toPath3); + if (toLocator === null) { + return false; + } + const fromInfo = pnpApi.getPackageInformation(fromLocator); + const toReference = fromInfo.packageDependencies.get(toLocator.name); + if (toReference) { + return toReference === toLocator.reference; + } + for (const reference of fromInfo.packageDependencies.values()) { + if (Array.isArray(reference)) { + if (reference[0] === toLocator.name && reference[1] === toLocator.reference) { + return true; + } + } + } + return false; + } + var init_pnp = __esm({ + "src/compiler/pnp.ts"() { + "use strict"; + init_path(); + } + }); + // src/compiler/moduleNameResolver.ts - function trace(host) { - host.trace(formatMessage.apply(void 0, arguments)); + function trace(host, message, ...args) { + host.trace(formatMessage(message, ...args)); } function isTraceEnabled(compilerOptions, host) { return !!compilerOptions.traceResolution && host.trace !== void 0; @@ -137840,6 +121015,18 @@ ${lanes.join("\n")} result.push("JSON"); return result.join(", "); } + function extensionsToExtensionsArray(extensions) { + const result = []; + if (extensions & 1 /* TypeScript */) + result.push(...supportedTSImplementationExtensions); + if (extensions & 2 /* JavaScript */) + result.push(...supportedJSExtensionsFlat); + if (extensions & 4 /* Declaration */) + result.push(...supportedDeclarationExtensions); + if (extensions & 8 /* Json */) + result.push(".json" /* Json */); + return result; + } function resolvedTypeScriptOnly(resolved) { if (!resolved) { return void 0; @@ -137847,7 +121034,7 @@ ${lanes.join("\n")} Debug.assert(extensionIsTS(resolved.extension)); return { fileName: resolved.path, packageId: resolved.packageId }; } - function createResolvedModuleWithFailedLookupLocationsHandlingSymlink(moduleName, resolved, isExternalLibraryImport, failedLookupLocations, affectingLocations, diagnostics, state, legacyResult) { + function createResolvedModuleWithFailedLookupLocationsHandlingSymlink(moduleName, resolved, isExternalLibraryImport, failedLookupLocations, affectingLocations, diagnostics, state, cache, legacyResult) { if (!state.resultFromCache && !state.compilerOptions.preserveSymlinks && resolved && isExternalLibraryImport && !resolved.originalPath && !isExternalModuleNameRelative(moduleName)) { const { resolvedFileName, originalPath } = getOriginalAndResolvedFileName(resolved.path, state.host, state.traceEnabled); if (originalPath) @@ -137860,15 +121047,25 @@ ${lanes.join("\n")} affectingLocations, diagnostics, state.resultFromCache, + cache, legacyResult ); } - function createResolvedModuleWithFailedLookupLocations(resolved, isExternalLibraryImport, failedLookupLocations, affectingLocations, diagnostics, resultFromCache, legacyResult) { + function createResolvedModuleWithFailedLookupLocations(resolved, isExternalLibraryImport, failedLookupLocations, affectingLocations, diagnostics, resultFromCache, cache, legacyResult) { if (resultFromCache) { - resultFromCache.failedLookupLocations = updateResolutionField(resultFromCache.failedLookupLocations, failedLookupLocations); - resultFromCache.affectingLocations = updateResolutionField(resultFromCache.affectingLocations, affectingLocations); - resultFromCache.resolutionDiagnostics = updateResolutionField(resultFromCache.resolutionDiagnostics, diagnostics); - return resultFromCache; + if (!(cache == null ? void 0 : cache.isReadonly)) { + resultFromCache.failedLookupLocations = updateResolutionField(resultFromCache.failedLookupLocations, failedLookupLocations); + resultFromCache.affectingLocations = updateResolutionField(resultFromCache.affectingLocations, affectingLocations); + resultFromCache.resolutionDiagnostics = updateResolutionField(resultFromCache.resolutionDiagnostics, diagnostics); + return resultFromCache; + } else { + return { + ...resultFromCache, + failedLookupLocations: initializeResolutionFieldForReadonlyCache(resultFromCache.failedLookupLocations, failedLookupLocations), + affectingLocations: initializeResolutionFieldForReadonlyCache(resultFromCache.affectingLocations, affectingLocations), + resolutionDiagnostics: initializeResolutionFieldForReadonlyCache(resultFromCache.resolutionDiagnostics, diagnostics) + }; + } } return { resolvedModule: resolved && { @@ -137896,6 +121093,13 @@ ${lanes.join("\n")} to.push(...value); return to; } + function initializeResolutionFieldForReadonlyCache(fromCache, value) { + if (!(fromCache == null ? void 0 : fromCache.length)) + return initializeResolutionField(value); + if (!value.length) + return fromCache.slice(); + return [...fromCache, ...value]; + } function readPackageJsonField(jsonContent, fieldName, typeOfTag, state) { if (!hasProperty(jsonContent, fieldName)) { if (state.traceEnabled) { @@ -138003,7 +121207,7 @@ ${lanes.join("\n")} return getDefaultTypeRoots(currentDirectory); } } - function getDefaultTypeRoots(currentDirectory) { + function getNodeModulesTypeRoots(currentDirectory) { let typeRoots; forEachAncestorDirectory(normalizePath(currentDirectory), (directory) => { const atTypes = combinePaths(directory, nodeModulesAtTypes); @@ -138012,8 +121216,17 @@ ${lanes.join("\n")} return typeRoots; } function arePathsEqual(path1, path2, host) { - const useCaseSensitiveFileNames = typeof host.useCaseSensitiveFileNames === "function" ? host.useCaseSensitiveFileNames() : host.useCaseSensitiveFileNames; - return comparePaths(path1, path2, !useCaseSensitiveFileNames) === 0 /* EqualTo */; + const useCaseSensitiveFileNames2 = typeof host.useCaseSensitiveFileNames === "function" ? host.useCaseSensitiveFileNames() : host.useCaseSensitiveFileNames; + return comparePaths(path1, path2, !useCaseSensitiveFileNames2) === 0 /* EqualTo */; + } + function getDefaultTypeRoots(currentDirectory) { + const nmTypes = getNodeModulesTypeRoots(currentDirectory); + const pnpTypes = getPnpTypeRoots(currentDirectory); + if (nmTypes == null ? void 0 : nmTypes.length) { + return [...nmTypes, ...pnpTypes]; + } else if (pnpTypes.length) { + return pnpTypes; + } } function getOriginalAndResolvedFileName(fileName, host, traceEnabled) { const resolvedFileName = realPath(fileName, host, traceEnabled); @@ -138071,10 +121284,14 @@ ${lanes.join("\n")} const failedLookupLocations = []; const affectingLocations = []; let features = getNodeResolutionFeatures(options); - if (resolutionMode === 99 /* ESNext */ && (getEmitModuleResolutionKind(options) === 3 /* Node16 */ || getEmitModuleResolutionKind(options) === 99 /* NodeNext */)) { + if (resolutionMode !== void 0) { + features |= 30 /* AllFeatures */; + } + const moduleResolution = getEmitModuleResolutionKind(options); + if (resolutionMode === 99 /* ESNext */ && (3 /* Node16 */ <= moduleResolution && moduleResolution <= 99 /* NodeNext */)) { features |= 32 /* EsmMode */; } - const conditions = features & 8 /* Exports */ ? getConditions(options, !!(features & 32 /* EsmMode */)) : []; + const conditions = features & 8 /* Exports */ ? getConditions(options, resolutionMode) : []; const diagnostics = []; const moduleResolutionState = { compilerOptions: options, @@ -138116,15 +121333,15 @@ ${lanes.join("\n")} affectingLocations: initializeResolutionField(affectingLocations), resolutionDiagnostics: initializeResolutionField(diagnostics) }; - if (containingDirectory) { - cache == null ? void 0 : cache.getOrCreateCacheForDirectory(containingDirectory, redirectedReference).set( + if (containingDirectory && cache && !cache.isReadonly) { + cache.getOrCreateCacheForDirectory(containingDirectory, redirectedReference).set( typeReferenceDirectiveName, /*mode*/ resolutionMode, result ); if (!isExternalModuleNameRelative(typeReferenceDirectiveName)) { - cache == null ? void 0 : cache.getOrCreateCacheForNonRelativeName(typeReferenceDirectiveName, resolutionMode, redirectedReference).set(containingDirectory, result); + cache.getOrCreateCacheForNonRelativeName(typeReferenceDirectiveName, resolutionMode, redirectedReference).set(containingDirectory, result); } } if (traceEnabled) @@ -138165,12 +121382,7 @@ ${lanes.join("\n")} } } return resolvedTypeScriptOnly( - loadNodeModuleFromDirectory( - 4 /* Declaration */, - candidate, - !directoryExists, - moduleResolutionState - ) + loadNodeModuleFromDirectory(4 /* Declaration */, candidate, !directoryExists, moduleResolutionState) ); }); } else { @@ -138247,18 +121459,41 @@ ${lanes.join("\n")} } return features; } - function getConditions(options, esmMode) { - const conditions = esmMode || getEmitModuleResolutionKind(options) === 100 /* Bundler */ ? ["import"] : ["require"]; + function getConditions(options, resolutionMode) { + const moduleResolution = getEmitModuleResolutionKind(options); + if (resolutionMode === void 0) { + if (moduleResolution === 100 /* Bundler */) { + resolutionMode = 99 /* ESNext */; + } else if (moduleResolution === 2 /* Node10 */) { + return []; + } + } + const conditions = resolutionMode === 99 /* ESNext */ ? ["import"] : ["require"]; if (!options.noDtsResolution) { conditions.push("types"); } - if (getEmitModuleResolutionKind(options) !== 100 /* Bundler */) { + if (moduleResolution !== 100 /* Bundler */) { conditions.push("node"); } return concatenate(conditions, options.customConditions); } function resolvePackageNameToPackageJson(packageName, containingDirectory, options, host, cache) { const moduleResolutionState = getTemporaryModuleResolutionState(cache == null ? void 0 : cache.getPackageJsonInfoCache(), host, options); + const pnpapi = getPnpApi(containingDirectory); + if (pnpapi) { + try { + const resolution = pnpapi.resolveToUnqualified(packageName, `${containingDirectory}/`, { considerBuiltins: false }); + const candidate = normalizeSlashes(resolution).replace(/\/$/, ""); + return getPackageJsonInfo( + candidate, + /*onlyRecordFailures*/ + false, + moduleResolutionState + ); + } catch { + return; + } + } return forEachAncestorDirectory(containingDirectory, (ancestorDirectory) => { if (getBaseFileName(ancestorDirectory) !== "node_modules") { const nodeModulesFolder = combinePaths(ancestorDirectory, "node_modules"); @@ -138316,11 +121551,10 @@ ${lanes.join("\n")} return str + "}"; } function getKeyForCompilerOptions(options, affectingOptionDeclarations) { - return affectingOptionDeclarations.map((option) => compilerOptionValueToString(getCompilerOptionValue(options, option))).join("|") + (options.pathsBasePath ? `|${options.pathsBasePath}` : void 0); + return affectingOptionDeclarations.map((option) => compilerOptionValueToString(getCompilerOptionValue(options, option))).join("|") + `|${options.pathsBasePath}`; } - function createCacheWithRedirects(ownOptions) { + function createCacheWithRedirects(ownOptions, optionsToRedirectsKey) { const redirectsMap = /* @__PURE__ */ new Map(); - const optionsToRedirectsKey = /* @__PURE__ */ new Map(); const redirectsKeyToMap = /* @__PURE__ */ new Map(); let ownMap = /* @__PURE__ */ new Map(); if (ownOptions) @@ -138329,7 +121563,8 @@ ${lanes.join("\n")} getMapOfCacheRedirects, getOrCreateMapOfCacheRedirects, update, - clear: clear2 + clear: clear2, + getOwnMap: () => ownMap }; function getMapOfCacheRedirects(redirectedReference) { return redirectedReference ? getOrCreateMap( @@ -138430,13 +121665,14 @@ ${lanes.join("\n")} } return result; } - function createPerDirectoryResolutionCache(currentDirectory, getCanonicalFileName, options) { - const directoryToModuleNameMap = createCacheWithRedirects(options); + function createPerDirectoryResolutionCache(currentDirectory, getCanonicalFileName, options, optionsToRedirectsKey) { + const directoryToModuleNameMap = createCacheWithRedirects(options, optionsToRedirectsKey); return { getFromDirectoryCache, getOrCreateCacheForDirectory, clear: clear2, - update + update, + directoryToModuleNameMap }; function clear2() { directoryToModuleNameMap.clear(); @@ -138492,23 +121728,14 @@ ${lanes.join("\n")} return result; } } - function zipToModeAwareCache(file, keys, values, nameAndModeGetter) { - Debug.assert(keys.length === values.length); - const map2 = createModeAwareCache(); - for (let i = 0; i < keys.length; ++i) { - const entry = keys[i]; - map2.set(nameAndModeGetter.getName(entry), nameAndModeGetter.getMode(entry, file), values[i]); - } - return map2; - } function getOriginalOrResolvedModuleFileName(result) { return result.resolvedModule && (result.resolvedModule.originalPath || result.resolvedModule.resolvedFileName); } function getOriginalOrResolvedTypeReferenceFileName(result) { return result.resolvedTypeReferenceDirective && (result.resolvedTypeReferenceDirective.originalPath || result.resolvedTypeReferenceDirective.resolvedFileName); } - function createNonRelativeNameResolutionCache(currentDirectory, getCanonicalFileName, options, getResolvedFileName) { - const moduleNameToDirectoryMap = createCacheWithRedirects(options); + function createNonRelativeNameResolutionCache(currentDirectory, getCanonicalFileName, options, getResolvedFileName, optionsToRedirectsKey) { + const moduleNameToDirectoryMap = createCacheWithRedirects(options, optionsToRedirectsKey); return { getFromNonRelativeNameCache, getOrCreateCacheForNonRelativeName, @@ -138576,13 +121803,20 @@ ${lanes.join("\n")} } } } - function createModuleOrTypeReferenceResolutionCache(currentDirectory, getCanonicalFileName, options, packageJsonInfoCache, getResolvedFileName) { - const perDirectoryResolutionCache = createPerDirectoryResolutionCache(currentDirectory, getCanonicalFileName, options); + function createModuleOrTypeReferenceResolutionCache(currentDirectory, getCanonicalFileName, options, packageJsonInfoCache, getResolvedFileName, optionsToRedirectsKey) { + optionsToRedirectsKey ?? (optionsToRedirectsKey = /* @__PURE__ */ new Map()); + const perDirectoryResolutionCache = createPerDirectoryResolutionCache( + currentDirectory, + getCanonicalFileName, + options, + optionsToRedirectsKey + ); const nonRelativeNameResolutionCache = createNonRelativeNameResolutionCache( currentDirectory, getCanonicalFileName, options, - getResolvedFileName + getResolvedFileName, + optionsToRedirectsKey ); packageJsonInfoCache ?? (packageJsonInfoCache = createPackageJsonInfoCache(currentDirectory, getCanonicalFileName)); return { @@ -138592,7 +121826,8 @@ ${lanes.join("\n")} clear: clear2, update, getPackageJsonInfoCache: () => packageJsonInfoCache, - clearAllExceptPackageJsonInfoCache + clearAllExceptPackageJsonInfoCache, + optionsToRedirectsKey }; function clear2() { clearAllExceptPackageJsonInfoCache(); @@ -138607,24 +121842,26 @@ ${lanes.join("\n")} nonRelativeNameResolutionCache.update(options2); } } - function createModuleResolutionCache(currentDirectory, getCanonicalFileName, options, packageJsonInfoCache) { + function createModuleResolutionCache(currentDirectory, getCanonicalFileName, options, packageJsonInfoCache, optionsToRedirectsKey) { const result = createModuleOrTypeReferenceResolutionCache( currentDirectory, getCanonicalFileName, options, packageJsonInfoCache, - getOriginalOrResolvedModuleFileName + getOriginalOrResolvedModuleFileName, + optionsToRedirectsKey ); result.getOrCreateCacheForModuleName = (nonRelativeName, mode, redirectedReference) => result.getOrCreateCacheForNonRelativeName(nonRelativeName, mode, redirectedReference); return result; } - function createTypeReferenceDirectiveResolutionCache(currentDirectory, getCanonicalFileName, options, packageJsonInfoCache) { + function createTypeReferenceDirectiveResolutionCache(currentDirectory, getCanonicalFileName, options, packageJsonInfoCache, optionsToRedirectsKey) { return createModuleOrTypeReferenceResolutionCache( currentDirectory, getCanonicalFileName, options, packageJsonInfoCache, - getOriginalOrResolvedTypeReferenceFileName + getOriginalOrResolvedTypeReferenceFileName, + optionsToRedirectsKey ); } function getOptionsForLibraryResolution(options) { @@ -138695,13 +121932,13 @@ ${lanes.join("\n")} result = nodeNextModuleNameResolver(moduleName, containingFile, compilerOptions, host, cache, redirectedReference, resolutionMode); break; case 2 /* Node10 */: - result = nodeModuleNameResolver(moduleName, containingFile, compilerOptions, host, cache, redirectedReference); + result = nodeModuleNameResolver(moduleName, containingFile, compilerOptions, host, cache, redirectedReference, resolutionMode ? getConditions(compilerOptions, resolutionMode) : void 0); break; case 1 /* Classic */: result = classicNameResolver(moduleName, containingFile, compilerOptions, host, cache, redirectedReference); break; case 100 /* Bundler */: - result = bundlerModuleNameResolver(moduleName, containingFile, compilerOptions, host, cache, redirectedReference); + result = bundlerModuleNameResolver(moduleName, containingFile, compilerOptions, host, cache, redirectedReference, resolutionMode ? getConditions(compilerOptions, resolutionMode) : void 0); break; default: return Debug.fail(`Unexpected moduleResolution: ${moduleResolution}`); @@ -138709,9 +121946,11 @@ ${lanes.join("\n")} if (result && result.resolvedModule) (_b = perfLogger) == null ? void 0 : _b.logInfoEvent(`Module "${moduleName}" resolved to "${result.resolvedModule.resolvedFileName}"`); (_c = perfLogger) == null ? void 0 : _c.logStopResolveModule(result && result.resolvedModule ? "" + result.resolvedModule.resolvedFileName : "null"); - cache == null ? void 0 : cache.getOrCreateCacheForDirectory(containingDirectory, redirectedReference).set(moduleName, resolutionMode, result); - if (!isExternalModuleNameRelative(moduleName)) { - cache == null ? void 0 : cache.getOrCreateCacheForNonRelativeName(moduleName, resolutionMode, redirectedReference).set(containingDirectory, result); + if (cache && !cache.isReadonly) { + cache.getOrCreateCacheForDirectory(containingDirectory, redirectedReference).set(moduleName, resolutionMode, result); + if (!isExternalModuleNameRelative(moduleName)) { + cache.getOrCreateCacheForNonRelativeName(moduleName, resolutionMode, redirectedReference).set(containingDirectory, result); + } } } if (traceEnabled) { @@ -138866,7 +122105,7 @@ ${lanes.join("\n")} resolutionMode ); } - function nodeNextModuleNameResolverWorker(features, moduleName, containingFile, compilerOptions, host, cache, redirectedReference, resolutionMode) { + function nodeNextModuleNameResolverWorker(features, moduleName, containingFile, compilerOptions, host, cache, redirectedReference, resolutionMode, conditions) { const containingDirectory = getDirectoryPath(containingFile); const esmMode = resolutionMode === 99 /* ESNext */ ? 32 /* EsmMode */ : 0; let extensions = compilerOptions.noDtsResolution ? 3 /* ImplementationFiles */ : 1 /* TypeScript */ | 2 /* JavaScript */ | 4 /* Declaration */; @@ -138883,7 +122122,8 @@ ${lanes.join("\n")} extensions, /*isConfigLookup*/ false, - redirectedReference + redirectedReference, + conditions ); } function tryResolveJSModuleWorker(moduleName, initialDir, host) { @@ -138899,10 +122139,12 @@ ${lanes.join("\n")} /*isConfigLookup*/ false, /*redirectedReference*/ + void 0, + /*conditions*/ void 0 ); } - function bundlerModuleNameResolver(moduleName, containingFile, compilerOptions, host, cache, redirectedReference) { + function bundlerModuleNameResolver(moduleName, containingFile, compilerOptions, host, cache, redirectedReference, conditions) { const containingDirectory = getDirectoryPath(containingFile); let extensions = compilerOptions.noDtsResolution ? 3 /* ImplementationFiles */ : 1 /* TypeScript */ | 2 /* JavaScript */ | 4 /* Declaration */; if (getResolveJsonModule(compilerOptions)) { @@ -138918,10 +122160,11 @@ ${lanes.join("\n")} extensions, /*isConfigLookup*/ false, - redirectedReference + redirectedReference, + conditions ); } - function nodeModuleNameResolver(moduleName, containingFile, compilerOptions, host, cache, redirectedReference, isConfigLookup) { + function nodeModuleNameResolver(moduleName, containingFile, compilerOptions, host, cache, redirectedReference, conditions, isConfigLookup) { let extensions; if (isConfigLookup) { extensions = 8 /* Json */; @@ -138932,7 +122175,7 @@ ${lanes.join("\n")} } else { extensions = getResolveJsonModule(compilerOptions) ? 1 /* TypeScript */ | 2 /* JavaScript */ | 4 /* Declaration */ | 8 /* Json */ : 1 /* TypeScript */ | 2 /* JavaScript */ | 4 /* Declaration */; } - return nodeModuleNameResolverWorker(0 /* None */, moduleName, getDirectoryPath(containingFile), compilerOptions, host, cache, extensions, !!isConfigLookup, redirectedReference); + return nodeModuleNameResolverWorker(conditions ? 30 /* AllFeatures */ : 0 /* None */, moduleName, getDirectoryPath(containingFile), compilerOptions, host, cache, extensions, !!isConfigLookup, redirectedReference, conditions); } function nodeNextJsonConfigResolver(moduleName, containingFile, host) { return nodeModuleNameResolverWorker( @@ -138947,15 +122190,21 @@ ${lanes.join("\n")} /*isConfigLookup*/ true, /*redirectedReference*/ + void 0, + /*conditions*/ void 0 ); } - function nodeModuleNameResolverWorker(features, moduleName, containingDirectory, compilerOptions, host, cache, extensions, isConfigLookup, redirectedReference) { + function nodeModuleNameResolverWorker(features, moduleName, containingDirectory, compilerOptions, host, cache, extensions, isConfigLookup, redirectedReference, conditions) { var _a, _b, _c, _d; const traceEnabled = isTraceEnabled(compilerOptions, host); const failedLookupLocations = []; const affectingLocations = []; - const conditions = getConditions(compilerOptions, !!(features & 32 /* EsmMode */)); + const moduleResolution = getEmitModuleResolutionKind(compilerOptions); + conditions ?? (conditions = getConditions( + compilerOptions, + moduleResolution === 100 /* Bundler */ || moduleResolution === 2 /* Node10 */ ? void 0 : features & 32 /* EsmMode */ ? 99 /* ESNext */ : 1 /* CommonJS */ + )); const diagnostics = []; const state = { compilerOptions, @@ -138965,17 +122214,17 @@ ${lanes.join("\n")} affectingLocations, packageJsonInfoCache: cache, features, - conditions, + conditions: conditions ?? emptyArray, requestContainingDirectory: containingDirectory, reportDiagnostic: (diag2) => void diagnostics.push(diag2), isConfigLookup, candidateIsFromPackageJsonField: false }; - if (traceEnabled && moduleResolutionSupportsPackageJsonExportsAndImports(getEmitModuleResolutionKind(compilerOptions))) { - trace(host, Diagnostics.Resolving_in_0_mode_with_conditions_1, features & 32 /* EsmMode */ ? "ESM" : "CJS", conditions.map((c) => `'${c}'`).join(", ")); + if (traceEnabled && moduleResolutionSupportsPackageJsonExportsAndImports(moduleResolution)) { + trace(host, Diagnostics.Resolving_in_0_mode_with_conditions_1, features & 32 /* EsmMode */ ? "ESM" : "CJS", state.conditions.map((c) => `'${c}'`).join(", ")); } let result; - if (getEmitModuleResolutionKind(compilerOptions) === 2 /* Node10 */) { + if (moduleResolution === 2 /* Node10 */) { const priorityExtensions = extensions & (1 /* TypeScript */ | 4 /* Declaration */); const secondaryExtensions = extensions & ~(1 /* TypeScript */ | 4 /* Declaration */); result = priorityExtensions && tryResolve(priorityExtensions, state) || secondaryExtensions && tryResolve(secondaryExtensions, state) || void 0; @@ -138983,7 +122232,7 @@ ${lanes.join("\n")} result = tryResolve(extensions, state); } let legacyResult; - if (((_a = result == null ? void 0 : result.value) == null ? void 0 : _a.isExternalLibraryImport) && !isConfigLookup && extensions & (1 /* TypeScript */ | 4 /* Declaration */) && features & 8 /* Exports */ && !isExternalModuleNameRelative(moduleName) && !extensionIsOk(1 /* TypeScript */ | 4 /* Declaration */, result.value.resolved.extension) && conditions.indexOf("import") > -1) { + if (((_a = result == null ? void 0 : result.value) == null ? void 0 : _a.isExternalLibraryImport) && !isConfigLookup && extensions & (1 /* TypeScript */ | 4 /* Declaration */) && features & 8 /* Exports */ && !isExternalModuleNameRelative(moduleName) && !extensionIsOk(1 /* TypeScript */ | 4 /* Declaration */, result.value.resolved.extension) && (conditions == null ? void 0 : conditions.includes("import"))) { traceIfEnabled(state, Diagnostics.Resolution_of_non_relative_name_failed_trying_with_modern_Node_resolution_features_disabled_to_see_if_npm_library_needs_configuration_update); const diagnosticState = { ...state, @@ -139003,6 +122252,7 @@ ${lanes.join("\n")} affectingLocations, diagnostics, state, + cache, legacyResult ); function tryResolve(extensions2, state2) { @@ -139027,7 +122277,7 @@ ${lanes.join("\n")} resolved2 = loadModuleFromSelfNameReference(extensions2, moduleName, containingDirectory, state2, cache, redirectedReference); } if (!resolved2) { - if (moduleName.indexOf(":") > -1) { + if (moduleName.includes(":")) { if (traceEnabled) { trace(host, Diagnostics.Skipping_module_0_that_looks_like_an_absolute_URI_target_file_types_Colon_1, moduleName, formatExtensions(extensions2)); } @@ -139072,7 +122322,6 @@ ${lanes.join("\n")} if (traceEnabled) { trace(host, Diagnostics.Resolving_real_path_for_0_result_1, path, real); } - Debug.assert(host.fileExists(real), `${path} linked to nonexistent file ${real}`); return real; } function nodeLoadModuleByRelativeName(extensions, candidate, onlyRecordFailures, state, considerPackageJson) { @@ -139116,7 +122365,7 @@ ${lanes.join("\n")} return void 0; } function pathContainsNodeModules(path) { - return stringContains(path, nodeModulesPathPart); + return path.includes(nodeModulesPathPart); } function parseNodeModuleFromPath(resolved, isFolder) { const path = normalizePath(resolved); @@ -139152,7 +122401,7 @@ ${lanes.join("\n")} } function loadModuleFromFileNoImplicitExtensions(extensions, candidate, onlyRecordFailures, state) { const filename = getBaseFileName(candidate); - if (filename.indexOf(".") === -1) { + if (!filename.includes(".")) { return void 0; } let extensionless = removeFileExtension(candidate); @@ -139264,19 +122513,11 @@ ${lanes.join("\n")} entrypoints = append(entrypoints, mainResolution == null ? void 0 : mainResolution.path); if (features & 8 /* Exports */ && packageJsonInfo.contents.packageJsonContent.exports) { const conditionSets = deduplicate( - [getConditions( - options, - /*esmMode*/ - true - ), getConditions( - options, - /*esmMode*/ - false - )], + [getConditions(options, 99 /* ESNext */), getConditions(options, 1 /* CommonJS */)], arrayIsEqualTo ); for (const conditions of conditionSets) { - const loadPackageJsonExportsState = { ...loadPackageJsonMainState, failedLookupLocations: [], conditions }; + const loadPackageJsonExportsState = { ...loadPackageJsonMainState, failedLookupLocations: [], conditions, host }; const exportResolutions = loadEntrypointsFromExportMap( packageJsonInfo, packageJsonInfo.contents.packageJsonContent.exports, @@ -139308,23 +122549,44 @@ ${lanes.join("\n")} return entrypoints; function loadEntrypointsFromTargetExports(target) { var _a, _b; - if (typeof target === "string" && startsWith(target, "./") && target.indexOf("*") === -1) { - const partsAfterFirst = getPathComponents(target).slice(2); - if (partsAfterFirst.indexOf("..") >= 0 || partsAfterFirst.indexOf(".") >= 0 || partsAfterFirst.indexOf("node_modules") >= 0) { - return false; - } - const resolvedTarget = combinePaths(scope.packageDirectory, target); - const finalPath = getNormalizedAbsolutePath(resolvedTarget, (_b = (_a = state.host).getCurrentDirectory) == null ? void 0 : _b.call(_a)); - const result = loadFileNameFromPackageJsonField( - extensions, - finalPath, - /*onlyRecordFailures*/ - false, - state - ); - if (result) { - entrypoints = appendIfUnique(entrypoints, result, (a, b) => a.path === b.path); - return true; + if (typeof target === "string" && startsWith(target, "./")) { + if (target.includes("*") && state.host.readDirectory) { + if (target.indexOf("*") !== target.lastIndexOf("*")) { + return false; + } + state.host.readDirectory( + scope.packageDirectory, + extensionsToExtensionsArray(extensions), + /*excludes*/ + void 0, + [ + isDeclarationFileName(target) ? target.replace("*", "**/*") : changeAnyExtension(target.replace("*", "**/*"), getDeclarationEmitExtensionForPath(target)) + ] + ).forEach((entry) => { + entrypoints = appendIfUnique(entrypoints, { + path: entry, + ext: getAnyExtensionFromPath(entry), + resolvedUsingTsExtension: void 0 + }); + }); + } else { + const partsAfterFirst = getPathComponents(target).slice(2); + if (partsAfterFirst.includes("..") || partsAfterFirst.includes(".") || partsAfterFirst.includes("node_modules")) { + return false; + } + const resolvedTarget = combinePaths(scope.packageDirectory, target); + const finalPath = getNormalizedAbsolutePath(resolvedTarget, (_b = (_a = state.host).getCurrentDirectory) == null ? void 0 : _b.call(_a)); + const result = loadFileNameFromPackageJsonField( + extensions, + finalPath, + /*onlyRecordFailures*/ + false, + state + ); + if (result) { + entrypoints = appendIfUnique(entrypoints, result, (a, b) => a.path === b.path); + return true; + } } } else if (Array.isArray(target)) { for (const t of target) { @@ -139383,7 +122645,7 @@ ${lanes.join("\n")} return packageJsonInfo.contents.versionPaths || void 0; } function getPackageJsonInfo(packageDirectory, onlyRecordFailures, state) { - var _a, _b, _c, _d, _e, _f, _g, _h; + var _a, _b, _c, _d, _e, _f; const { host, traceEnabled } = state; const packageJsonPath = combinePaths(packageDirectory, "package.json"); if (onlyRecordFailures) { @@ -139411,15 +122673,17 @@ ${lanes.join("\n")} trace(host, Diagnostics.Found_package_json_at_0, packageJsonPath); } const result = { packageDirectory, contents: { packageJsonContent, versionPaths: void 0, resolvedEntrypoints: void 0 } }; - (_e = state.packageJsonInfoCache) == null ? void 0 : _e.setPackageJsonInfo(packageJsonPath, result); - (_f = state.affectingLocations) == null ? void 0 : _f.push(packageJsonPath); + if (state.packageJsonInfoCache && !state.packageJsonInfoCache.isReadonly) + state.packageJsonInfoCache.setPackageJsonInfo(packageJsonPath, result); + (_e = state.affectingLocations) == null ? void 0 : _e.push(packageJsonPath); return result; } else { if (directoryExists && traceEnabled) { trace(host, Diagnostics.File_0_does_not_exist, packageJsonPath); } - (_g = state.packageJsonInfoCache) == null ? void 0 : _g.setPackageJsonInfo(packageJsonPath, directoryExists); - (_h = state.failedLookupLocations) == null ? void 0 : _h.push(packageJsonPath); + if (state.packageJsonInfoCache && !state.packageJsonInfoCache.isReadonly) + state.packageJsonInfoCache.setPackageJsonInfo(packageJsonPath, directoryExists); + (_f = state.failedLookupLocations) == null ? void 0 : _f.push(packageJsonPath); } } function loadNodeModuleFromDirectoryWorker(extensions, candidate, onlyRecordFailures, state, jsonContent, versionPaths) { @@ -139533,6 +122797,9 @@ ${lanes.join("\n")} } const trailingParts = parts.slice(nameParts.length); const subpath = !length(trailingParts) ? "." : `.${directorySeparator}${trailingParts.join(directorySeparator)}`; + if (getAllowJSCompilerOption(state.compilerOptions) && !pathContainsNodeModules(directory)) { + return loadModuleFromExports(scope, extensions, subpath, state, cache, redirectedReference); + } const priorityExtensions = extensions & (1 /* TypeScript */ | 4 /* Declaration */); const secondaryExtensions = extensions & ~(1 /* TypeScript */ | 4 /* Declaration */); return loadModuleFromExports(scope, priorityExtensions, subpath, state, cache, redirectedReference) || loadModuleFromExports(scope, secondaryExtensions, subpath, state, cache, redirectedReference); @@ -139674,7 +122941,7 @@ ${lanes.join("\n")} } function loadModuleFromImportsOrExports(extensions, state, cache, redirectedReference, moduleName, lookupTable, scope, isImports) { const loadModuleFromTargetImportOrExport = getLoadModuleFromTargetImportOrExport(extensions, state, cache, redirectedReference, moduleName, scope, isImports); - if (!endsWith(moduleName, directorySeparator) && moduleName.indexOf("*") === -1 && hasProperty(lookupTable, moduleName)) { + if (!endsWith(moduleName, directorySeparator) && !moduleName.includes("*") && hasProperty(lookupTable, moduleName)) { const target = lookupTable[moduleName]; return loadModuleFromTargetImportOrExport( target, @@ -139685,7 +122952,7 @@ ${lanes.join("\n")} moduleName ); } - const expandingKeys = sort(filter(getOwnKeys(lookupTable), (k) => k.indexOf("*") !== -1 || endsWith(k, "/")), comparePatternKeys); + const expandingKeys = sort(filter(getOwnKeys(lookupTable), (k) => k.includes("*") || endsWith(k, "/")), comparePatternKeys); for (const potentialTarget of expandingKeys) { if (state.features & 16 /* ExportsPatternTrailers */ && matchesPatternWithTrailer(potentialTarget, moduleName)) { const target = lookupTable[potentialTarget]; @@ -139757,15 +123024,18 @@ ${lanes.join("\n")} extensions, /*isConfigLookup*/ false, - redirectedReference + redirectedReference, + state.conditions + ); + return toSearchResult( + result.resolvedModule ? { + path: result.resolvedModule.resolvedFileName, + extension: result.resolvedModule.extension, + packageId: result.resolvedModule.packageId, + originalPath: result.resolvedModule.originalPath, + resolvedUsingTsExtension: result.resolvedModule.resolvedUsingTsExtension + } : void 0 ); - return toSearchResult(result.resolvedModule ? { - path: result.resolvedModule.resolvedFileName, - extension: result.resolvedModule.extension, - packageId: result.resolvedModule.packageId, - originalPath: result.resolvedModule.originalPath, - resolvedUsingTsExtension: result.resolvedModule.resolvedUsingTsExtension - } : void 0); } if (state.traceEnabled) { trace(state.host, Diagnostics.package_json_scope_0_has_invalid_type_for_target_of_specifier_1, scope.packageDirectory, moduleName); @@ -139777,7 +123047,7 @@ ${lanes.join("\n")} } const parts = pathIsRelative(target) ? getPathComponents(target).slice(1) : getPathComponents(target); const partsAfterFirst = parts.slice(1); - if (partsAfterFirst.indexOf("..") >= 0 || partsAfterFirst.indexOf(".") >= 0 || partsAfterFirst.indexOf("node_modules") >= 0) { + if (partsAfterFirst.includes("..") || partsAfterFirst.includes(".") || partsAfterFirst.includes("node_modules")) { if (state.traceEnabled) { trace(state.host, Diagnostics.package_json_scope_0_has_invalid_type_for_target_of_specifier_1, scope.packageDirectory, moduleName); } @@ -139788,7 +123058,7 @@ ${lanes.join("\n")} } const resolvedTarget = combinePaths(scope.packageDirectory, target); const subpathParts = getPathComponents(subpath); - if (subpathParts.indexOf("..") >= 0 || subpathParts.indexOf(".") >= 0 || subpathParts.indexOf("node_modules") >= 0) { + if (subpathParts.includes("..") || subpathParts.includes(".") || subpathParts.includes("node_modules")) { if (state.traceEnabled) { trace(state.host, Diagnostics.package_json_scope_0_has_invalid_type_for_target_of_specifier_1, scope.packageDirectory, moduleName); } @@ -139798,13 +123068,7 @@ ${lanes.join("\n")} ); } if (state.traceEnabled) { - trace( - state.host, - Diagnostics.Using_0_subpath_1_with_target_2, - isImports ? "imports" : "exports", - key, - pattern ? target.replace(/\*/g, subpath) : target + subpath - ); + trace(state.host, Diagnostics.Using_0_subpath_1_with_target_2, isImports ? "imports" : "exports", key, pattern ? target.replace(/\*/g, subpath) : target + subpath); } const finalPath = toAbsolutePath(pattern ? resolvedTarget.replace(/\*/g, subpath) : resolvedTarget + subpath); const inputLink = tryLoadInputFileForPath(finalPath, subpath, combinePaths(scope.packageDirectory, "package.json"), isImports); @@ -139821,7 +123085,7 @@ ${lanes.join("\n")} if (!Array.isArray(target)) { traceIfEnabled(state, Diagnostics.Entering_conditional_exports); for (const condition of getOwnKeys(target)) { - if (condition === "default" || state.conditions.indexOf(condition) >= 0 || isApplicableVersionedTypesKey(state.conditions, condition)) { + if (condition === "default" || state.conditions.includes(condition) || isApplicableVersionedTypesKey(state.conditions, condition)) { traceIfEnabled(state, Diagnostics.Matched_0_condition_1, isImports ? "imports" : "exports", condition); const subTarget = target[condition]; const result = loadModuleFromTargetImportOrExport(subTarget, subpath, pattern, key); @@ -139880,13 +123144,10 @@ ${lanes.join("\n")} function combineDirectoryPath(root, dir) { return ensureTrailingDirectorySeparator(combinePaths(root, dir)); } - function useCaseSensitiveFileNames() { - return !state.host.useCaseSensitiveFileNames ? true : typeof state.host.useCaseSensitiveFileNames === "boolean" ? state.host.useCaseSensitiveFileNames : state.host.useCaseSensitiveFileNames(); - } function tryLoadInputFileForPath(finalPath, entry, packagePath, isImports2) { var _a, _b, _c, _d; - if (!state.isConfigLookup && (state.compilerOptions.declarationDir || state.compilerOptions.outDir) && finalPath.indexOf("/node_modules/") === -1 && (state.compilerOptions.configFile ? containsPath(scope.packageDirectory, toAbsolutePath(state.compilerOptions.configFile.fileName), !useCaseSensitiveFileNames()) : true)) { - const getCanonicalFileName = hostGetCanonicalFileName({ useCaseSensitiveFileNames }); + if (!state.isConfigLookup && (state.compilerOptions.declarationDir || state.compilerOptions.outDir) && !finalPath.includes("/node_modules/") && (state.compilerOptions.configFile ? containsPath(scope.packageDirectory, toAbsolutePath(state.compilerOptions.configFile.fileName), !useCaseSensitiveFileNames(state)) : true)) { + const getCanonicalFileName = hostGetCanonicalFileName({ useCaseSensitiveFileNames: () => useCaseSensitiveFileNames(state) }); const commonSourceDirGuesses = []; if (state.compilerOptions.rootDir || state.compilerOptions.composite && state.compilerOptions.configFilePath) { const commonDir = toAbsolutePath(getCommonSourceDirectory(state.compilerOptions, () => [], ((_b = (_a = state.host).getCurrentDirectory) == null ? void 0 : _b.call(_a)) || "", getCanonicalFileName)); @@ -139915,7 +123176,7 @@ ${lanes.join("\n")} for (const commonSourceDirGuess of commonSourceDirGuesses) { const candidateDirectories = getOutputDirectoriesForBaseDirectory(commonSourceDirGuess); for (const candidateDir of candidateDirectories) { - if (containsPath(candidateDir, finalPath, !useCaseSensitiveFileNames())) { + if (containsPath(candidateDir, finalPath, !useCaseSensitiveFileNames(state))) { const pathFragment = finalPath.slice(candidateDir.length + 1); const possibleInputBase = combinePaths(commonSourceDirGuess, pathFragment); const jsAndDtsExtensions = [".mjs" /* Mjs */, ".cjs" /* Cjs */, ".js" /* Js */, ".json" /* Json */, ".d.mts" /* Dmts */, ".d.cts" /* Dcts */, ".d.ts" /* Dts */]; @@ -139925,7 +123186,7 @@ ${lanes.join("\n")} for (const possibleExt of inputExts) { if (!extensionIsOk(extensions, possibleExt)) continue; - const possibleInputWithInputExtension = changeAnyExtension(possibleInputBase, possibleExt, ext, !useCaseSensitiveFileNames()); + const possibleInputWithInputExtension = changeAnyExtension(possibleInputBase, possibleExt, ext, !useCaseSensitiveFileNames(state)); if (state.host.fileExists(possibleInputWithInputExtension)) { return toSearchResult(withPackageId(scope, loadFileNameFromPackageJsonField( extensions, @@ -139959,7 +123220,7 @@ ${lanes.join("\n")} } } function isApplicableVersionedTypesKey(conditions, key) { - if (conditions.indexOf("types") === -1) + if (!conditions.includes("types")) return false; if (!startsWith(key, "types@")) return false; @@ -139999,15 +123260,25 @@ ${lanes.join("\n")} const priorityExtensions = extensions & (1 /* TypeScript */ | 4 /* Declaration */); const secondaryExtensions = extensions & ~(1 /* TypeScript */ | 4 /* Declaration */); if (priorityExtensions) { + traceIfEnabled(state, Diagnostics.Searching_all_ancestor_node_modules_directories_for_preferred_extensions_Colon_0, formatExtensions(priorityExtensions)); const result = lookup(priorityExtensions); if (result) return result; } if (secondaryExtensions && !typesScopeOnly) { + traceIfEnabled(state, Diagnostics.Searching_all_ancestor_node_modules_directories_for_fallback_extensions_Colon_0, formatExtensions(secondaryExtensions)); return lookup(secondaryExtensions); } function lookup(extensions2) { - return forEachAncestorDirectory(normalizeSlashes(directory), (ancestorDirectory) => { + const issuer = normalizeSlashes(directory); + if (getPnpApi(issuer)) { + const resolutionFromCache = tryFindNonRelativeModuleNameInCache(cache, moduleName, mode, issuer, redirectedReference, state); + if (resolutionFromCache) { + return resolutionFromCache; + } + return toSearchResult(loadModuleFromImmediateNodeModulesDirectoryPnP(extensions2, moduleName, issuer, state, typesScopeOnly, cache, redirectedReference)); + } + return forEachAncestorDirectory(issuer, (ancestorDirectory) => { if (getBaseFileName(ancestorDirectory) !== "node_modules") { const resolutionFromCache = tryFindNonRelativeModuleNameInCache(cache, moduleName, mode, ancestorDirectory, redirectedReference, state); if (resolutionFromCache) { @@ -140042,11 +123313,40 @@ ${lanes.join("\n")} return loadModuleFromSpecificNodeModulesDirectory(4 /* Declaration */, mangleScopedPackageNameWithTrace(moduleName, state), nodeModulesAtTypes2, nodeModulesAtTypesExists, state, cache, redirectedReference); } } + function loadModuleFromImmediateNodeModulesDirectoryPnP(extensions, moduleName, directory, state, typesScopeOnly, cache, redirectedReference) { + const issuer = normalizeSlashes(directory); + if (!typesScopeOnly) { + const packageResult = tryLoadModuleUsingPnpResolution(extensions, moduleName, issuer, state, cache, redirectedReference); + if (packageResult) { + return packageResult; + } + } + if (extensions & 4 /* Declaration */) { + return tryLoadModuleUsingPnpResolution(4 /* Declaration */, `@types/${mangleScopedPackageNameWithTrace(moduleName, state)}`, issuer, state, cache, redirectedReference); + } + } function loadModuleFromSpecificNodeModulesDirectory(extensions, moduleName, nodeModulesDirectory, nodeModulesDirectoryExists, state, cache, redirectedReference) { - var _a, _b; const candidate = normalizePath(combinePaths(nodeModulesDirectory, moduleName)); const { packageName, rest } = parsePackageName(moduleName); const packageDirectory = combinePaths(nodeModulesDirectory, packageName); + return loadModuleFromSpecificNodeModulesDirectoryImpl(extensions, nodeModulesDirectoryExists, state, cache, redirectedReference, candidate, rest, packageDirectory); + } + function loadModuleFromPnpResolution(extensions, packageDirectory, rest, state, cache, redirectedReference) { + const candidate = normalizePath(combinePaths(packageDirectory, rest)); + return loadModuleFromSpecificNodeModulesDirectoryImpl( + extensions, + /*nodeModulesDirectoryExists*/ + true, + state, + cache, + redirectedReference, + candidate, + rest, + packageDirectory + ); + } + function loadModuleFromSpecificNodeModulesDirectoryImpl(extensions, nodeModulesDirectoryExists, state, cache, redirectedReference, candidate, rest, packageDirectory) { + var _a, _b; let rootPackageInfo; let packageInfo = getPackageJsonInfo(candidate, !nodeModulesDirectoryExists, state); if (rest !== "" && packageInfo && (!(state.features & 8 /* Exports */) || !hasProperty(((_a = rootPackageInfo = getPackageJsonInfo(packageDirectory, !nodeModulesDirectoryExists, state)) == null ? void 0 : _a.contents.packageJsonContent) ?? emptyArray, "exports"))) { @@ -140161,7 +123461,7 @@ ${lanes.join("\n")} return mangledName; } function unmangleScopedPackageName(typesPackageName) { - return stringContains(typesPackageName, mangledScopedPackageSeparator) ? "@" + typesPackageName.replace(mangledScopedPackageSeparator, directorySeparator) : typesPackageName; + return typesPackageName.includes(mangledScopedPackageSeparator) ? "@" + typesPackageName.replace(mangledScopedPackageSeparator, directorySeparator) : typesPackageName; } function tryFindNonRelativeModuleNameInCache(cache, moduleName, mode, containingDirectory, redirectedReference, state) { const result = cache && cache.getFromNonRelativeNameCache(moduleName, mode, containingDirectory, redirectedReference); @@ -140209,7 +123509,8 @@ ${lanes.join("\n")} failedLookupLocations, affectingLocations, diagnostics, - state + state, + cache ); function tryResolve(extensions) { const resolvedUsingSettings = tryLoadModuleUsingOptionalResolutionSettings(extensions, moduleName, containingDirectory, loadModuleFromFileNoPackageId, state); @@ -140328,7 +123629,9 @@ ${lanes.join("\n")} failedLookupLocations, affectingLocations, diagnostics, - state.resultFromCache + state.resultFromCache, + /*cache*/ + void 0 ); } function toSearchResult(value) { @@ -140339,11 +123642,27 @@ ${lanes.join("\n")} trace(state.host, diagnostic, ...args); } } + function useCaseSensitiveFileNames(state) { + return !state.host.useCaseSensitiveFileNames ? true : typeof state.host.useCaseSensitiveFileNames === "boolean" ? state.host.useCaseSensitiveFileNames : state.host.useCaseSensitiveFileNames(); + } + function loadPnpPackageResolution(packageName, containingDirectory) { + try { + const resolution = getPnpApi(containingDirectory).resolveToUnqualified(packageName, `${containingDirectory}/`, { considerBuiltins: false }); + return normalizeSlashes(resolution).replace(/\/$/, ""); + } catch { + } + } + function tryLoadModuleUsingPnpResolution(extensions, moduleName, containingDirectory, state, cache, redirectedReference) { + const { packageName, rest } = parsePackageName(moduleName); + const packageResolution = loadPnpPackageResolution(packageName, containingDirectory); + return packageResolution ? loadModuleFromPnpResolution(extensions, packageResolution, rest, state, cache, redirectedReference) : void 0; + } var typeScriptVersion, nodeModulesAtTypes, NodeResolutionFeatures, nodeModulesPathPart, mangledScopedPackageSeparator; var init_moduleNameResolver = __esm({ "src/compiler/moduleNameResolver.ts"() { "use strict"; init_ts2(); + init_pnp(); nodeModulesAtTypes = combinePaths("node_modules", "@types"); NodeResolutionFeatures = /* @__PURE__ */ ((NodeResolutionFeatures2) => { NodeResolutionFeatures2[NodeResolutionFeatures2["None"] = 0] = "None"; @@ -140387,23 +123706,23 @@ ${lanes.join("\n")} } function getModuleInstanceStateWorker(node, visited) { switch (node.kind) { - case 263 /* InterfaceDeclaration */: - case 264 /* TypeAliasDeclaration */: + case 264 /* InterfaceDeclaration */: + case 265 /* TypeAliasDeclaration */: return 0 /* NonInstantiated */; - case 265 /* EnumDeclaration */: + case 266 /* EnumDeclaration */: if (isEnumConst(node)) { return 2 /* ConstEnumOnly */; } break; - case 271 /* ImportDeclaration */: - case 270 /* ImportEqualsDeclaration */: - if (!hasSyntacticModifier(node, 1 /* Export */)) { + case 272 /* ImportDeclaration */: + case 271 /* ImportEqualsDeclaration */: + if (!hasSyntacticModifier(node, 32 /* Export */)) { return 0 /* NonInstantiated */; } break; - case 277 /* ExportDeclaration */: + case 278 /* ExportDeclaration */: const exportDeclaration = node; - if (!exportDeclaration.moduleSpecifier && exportDeclaration.exportClause && exportDeclaration.exportClause.kind === 278 /* NamedExports */) { + if (!exportDeclaration.moduleSpecifier && exportDeclaration.exportClause && exportDeclaration.exportClause.kind === 279 /* NamedExports */) { let state = 0 /* NonInstantiated */; for (const specifier of exportDeclaration.exportClause.elements) { const specifierState = getModuleInstanceStateForAliasTarget(specifier, visited); @@ -140417,7 +123736,7 @@ ${lanes.join("\n")} return state; } break; - case 267 /* ModuleBlock */: { + case 268 /* ModuleBlock */: { let state = 0 /* NonInstantiated */; forEachChild(node, (n) => { const childState = getModuleInstanceStateCached(n, visited); @@ -140436,10 +123755,10 @@ ${lanes.join("\n")} }); return state; } - case 266 /* ModuleDeclaration */: + case 267 /* ModuleDeclaration */: return getModuleInstanceState(node, visited); case 80 /* Identifier */: - if (node.flags & 2048 /* IdentifierIsInJSDocNamespace */) { + if (node.flags & 4096 /* IdentifierIsInJSDocNamespace */) { return 0 /* NonInstantiated */; } } @@ -140469,6 +123788,9 @@ ${lanes.join("\n")} if (found === 1 /* Instantiated */) { return found; } + if (statement.kind === 271 /* ImportEqualsDeclaration */) { + found = 1 /* Instantiated */; + } } } if (found !== void 0) { @@ -140602,7 +123924,7 @@ ${lanes.join("\n")} } } function getDeclarationName(node) { - if (node.kind === 276 /* ExportAssignment */) { + if (node.kind === 277 /* ExportAssignment */) { return node.isExportEquals ? "export=" /* ExportEquals */ : "default" /* Default */; } const name = getNameOfDeclaration(node); @@ -140611,7 +123933,7 @@ ${lanes.join("\n")} const moduleName = getTextOfIdentifierOrLiteral(name); return isGlobalScopeAugmentation(node) ? "__global" : `"${moduleName}"`; } - if (name.kind === 166 /* ComputedPropertyName */) { + if (name.kind === 167 /* ComputedPropertyName */) { const nameExpression = name.expression; if (isStringOrNumericLiteralLike(nameExpression)) { return escapeLeadingUnderscores(nameExpression.text); @@ -140636,31 +123958,31 @@ ${lanes.join("\n")} return isPropertyNameLiteral(name) ? getEscapedTextOfIdentifierOrLiteral(name) : void 0; } switch (node.kind) { - case 175 /* Constructor */: + case 176 /* Constructor */: return "__constructor" /* Constructor */; - case 183 /* FunctionType */: - case 178 /* CallSignature */: - case 329 /* JSDocSignature */: + case 184 /* FunctionType */: + case 179 /* CallSignature */: + case 330 /* JSDocSignature */: return "__call" /* Call */; - case 184 /* ConstructorType */: - case 179 /* ConstructSignature */: + case 185 /* ConstructorType */: + case 180 /* ConstructSignature */: return "__new" /* New */; - case 180 /* IndexSignature */: + case 181 /* IndexSignature */: return "__index" /* Index */; - case 277 /* ExportDeclaration */: + case 278 /* ExportDeclaration */: return "__export" /* ExportStar */; - case 311 /* SourceFile */: + case 312 /* SourceFile */: return "export=" /* ExportEquals */; - case 225 /* BinaryExpression */: + case 226 /* BinaryExpression */: if (getAssignmentDeclarationKind(node) === 2 /* ModuleExports */) { return "export=" /* ExportEquals */; } Debug.fail("Unknown binary declaration kind"); break; - case 323 /* JSDocFunctionType */: + case 324 /* JSDocFunctionType */: return isJSDocConstructSignature(node) ? "__new" /* New */ : "__call" /* Call */; - case 168 /* Parameter */: - Debug.assert(node.parent.kind === 323 /* JSDocFunctionType */, "Impossible parameter parent kind", () => `parent is: ${Debug.formatSyntaxKind(node.parent.kind)}, expected JSDocFunctionType`); + case 169 /* Parameter */: + Debug.assert(node.parent.kind === 324 /* JSDocFunctionType */, "Impossible parameter parent kind", () => `parent is: ${Debug.formatSyntaxKind(node.parent.kind)}, expected JSDocFunctionType`); const functionType = node.parent; const index = functionType.parameters.indexOf(node); return "arg" + index; @@ -140671,7 +123993,7 @@ ${lanes.join("\n")} } function declareSymbol(symbolTable, parent3, node, includes, excludes, isReplaceableByMethod, isComputedName) { Debug.assert(isComputedName || !hasDynamicName(node)); - const isDefaultExport = hasSyntacticModifier(node, 1024 /* Default */) || isExportSpecifier(node) && node.name.escapedText === "default"; + const isDefaultExport = hasSyntacticModifier(node, 2048 /* Default */) || isExportSpecifier(node) && node.name.escapedText === "default"; const name = isComputedName ? "__computed" /* Computed */ : isDefaultExport && parent3 ? "default" /* Default */ : getDeclarationName(node); let symbol; if (name === void 0) { @@ -140707,7 +124029,7 @@ ${lanes.join("\n")} messageNeedsName = false; multipleDefaultExports = true; } else { - if (symbol.declarations && symbol.declarations.length && (node.kind === 276 /* ExportAssignment */ && !node.isExportEquals)) { + if (symbol.declarations && symbol.declarations.length && (node.kind === 277 /* ExportAssignment */ && !node.isExportEquals)) { message = Diagnostics.A_module_cannot_have_multiple_default_exports; messageNeedsName = false; multipleDefaultExports = true; @@ -140715,7 +124037,7 @@ ${lanes.join("\n")} } } const relatedInformation = []; - if (isTypeAliasDeclaration(node) && nodeIsMissing(node.type) && hasSyntacticModifier(node, 1 /* Export */) && symbol.flags & (2097152 /* Alias */ | 788968 /* Type */ | 1920 /* Namespace */)) { + if (isTypeAliasDeclaration(node) && nodeIsMissing(node.type) && hasSyntacticModifier(node, 32 /* Export */) && symbol.flags & (2097152 /* Alias */ | 788968 /* Type */ | 1920 /* Namespace */)) { relatedInformation.push(createDiagnosticForNode2(node, Diagnostics.Did_you_mean_0, `export type { ${unescapeLeadingUnderscores(node.name.escapedText)} }`)); } const declarationName = getNameOfDeclaration(node) || node; @@ -140744,9 +124066,9 @@ ${lanes.join("\n")} return symbol; } function declareModuleMember(node, symbolFlags, symbolExcludes) { - const hasExportModifier = !!(getCombinedModifierFlags(node) & 1 /* Export */) || jsdocTreatAsExported(node); + const hasExportModifier = !!(getCombinedModifierFlags(node) & 32 /* Export */) || jsdocTreatAsExported(node); if (symbolFlags & 2097152 /* Alias */) { - if (node.kind === 280 /* ExportSpecifier */ || node.kind === 270 /* ImportEqualsDeclaration */ && hasExportModifier) { + if (node.kind === 281 /* ExportSpecifier */ || node.kind === 271 /* ImportEqualsDeclaration */ && hasExportModifier) { return declareSymbol(container.symbol.exports, container.symbol, node, symbolFlags, symbolExcludes); } else { Debug.assertNode(container, canHaveLocals); @@ -140762,8 +124084,8 @@ ${lanes.join("\n")} } else { if (isJSDocTypeAlias(node)) Debug.assert(isInJSFile(node)); - if (!isAmbientModule(node) && (hasExportModifier || container.flags & 64 /* ExportContext */)) { - if (!canHaveLocals(container) || !container.locals || hasSyntacticModifier(node, 1024 /* Default */) && !getDeclarationName(node)) { + if (!isAmbientModule(node) && (hasExportModifier || container.flags & 128 /* ExportContext */)) { + if (!canHaveLocals(container) || !container.locals || hasSyntacticModifier(node, 2048 /* Default */) && !getDeclarationName(node)) { return declareSymbol(container.symbol.exports, container.symbol, node, symbolFlags, symbolExcludes); } const exportKind = symbolFlags & 111551 /* Value */ ? 1048576 /* ExportValue */ : 0; @@ -140804,7 +124126,7 @@ ${lanes.join("\n")} return false; if (isPropertyAccessEntityNameExpression(declName.parent) && isTopLevelNamespaceAssignment(declName.parent)) return true; - if (isDeclaration(declName.parent) && getCombinedModifierFlags(declName.parent) & 1 /* Export */) + if (isDeclaration(declName.parent) && getCombinedModifierFlags(declName.parent) & 32 /* Export */) return true; return false; } @@ -140813,7 +124135,7 @@ ${lanes.join("\n")} const saveThisParentContainer = thisParentContainer; const savedBlockScopeContainer = blockScopeContainer; if (containerFlags & 1 /* IsContainer */) { - if (node.kind !== 218 /* ArrowFunction */) { + if (node.kind !== 219 /* ArrowFunction */) { thisParentContainer = container; } container = blockScopeContainer = node; @@ -140835,35 +124157,35 @@ ${lanes.join("\n")} const saveExceptionTarget = currentExceptionTarget; const saveActiveLabelList = activeLabelList; const saveHasExplicitReturn = hasExplicitReturn; - const isImmediatelyInvoked = containerFlags & 16 /* IsFunctionExpression */ && !hasSyntacticModifier(node, 512 /* Async */) && !node.asteriskToken && !!getImmediatelyInvokedFunctionExpression(node) || node.kind === 174 /* ClassStaticBlockDeclaration */; + const isImmediatelyInvoked = containerFlags & 16 /* IsFunctionExpression */ && !hasSyntacticModifier(node, 1024 /* Async */) && !node.asteriskToken && !!getImmediatelyInvokedFunctionExpression(node) || node.kind === 175 /* ClassStaticBlockDeclaration */; if (!isImmediatelyInvoked) { currentFlow = initFlowNode({ flags: 2 /* Start */ }); if (containerFlags & (16 /* IsFunctionExpression */ | 128 /* IsObjectLiteralOrClassExpressionMethodOrAccessor */)) { currentFlow.node = node; } } - currentReturnTarget = isImmediatelyInvoked || node.kind === 175 /* Constructor */ || isInJSFile(node) && (node.kind === 261 /* FunctionDeclaration */ || node.kind === 217 /* FunctionExpression */) ? createBranchLabel() : void 0; + currentReturnTarget = isImmediatelyInvoked || node.kind === 176 /* Constructor */ || isInJSFile(node) && (node.kind === 262 /* FunctionDeclaration */ || node.kind === 218 /* FunctionExpression */) ? createBranchLabel() : void 0; currentExceptionTarget = void 0; currentBreakTarget = void 0; currentContinueTarget = void 0; activeLabelList = void 0; hasExplicitReturn = false; bindChildren(node); - node.flags &= ~2816 /* ReachabilityAndEmitFlags */; + node.flags &= ~5632 /* ReachabilityAndEmitFlags */; if (!(currentFlow.flags & 1 /* Unreachable */) && containerFlags & 8 /* IsFunctionLike */ && nodeIsPresent(node.body)) { - node.flags |= 256 /* HasImplicitReturn */; + node.flags |= 512 /* HasImplicitReturn */; if (hasExplicitReturn) - node.flags |= 512 /* HasExplicitReturn */; + node.flags |= 1024 /* HasExplicitReturn */; node.endFlowNode = currentFlow; } - if (node.kind === 311 /* SourceFile */) { + if (node.kind === 312 /* SourceFile */) { node.flags |= emitFlags; node.endFlowNode = currentFlow; } if (currentReturnTarget) { addAntecedent(currentReturnTarget, currentFlow); currentFlow = finishFlowLabel(currentReturnTarget); - if (node.kind === 175 /* Constructor */ || node.kind === 174 /* ClassStaticBlockDeclaration */ || isInJSFile(node) && (node.kind === 261 /* FunctionDeclaration */ || node.kind === 217 /* FunctionExpression */)) { + if (node.kind === 176 /* Constructor */ || node.kind === 175 /* ClassStaticBlockDeclaration */ || isInJSFile(node) && (node.kind === 262 /* FunctionDeclaration */ || node.kind === 218 /* FunctionExpression */)) { node.returnFlowNode = currentFlow; } } @@ -140880,7 +124202,7 @@ ${lanes.join("\n")} seenThisKeyword = false; bindChildren(node); Debug.assertNotNode(node, isIdentifier); - node.flags = seenThisKeyword ? node.flags | 128 /* ContainsThis */ : node.flags & ~128 /* ContainsThis */; + node.flags = seenThisKeyword ? node.flags | 256 /* ContainsThis */ : node.flags & ~256 /* ContainsThis */; } else { bindChildren(node); } @@ -140889,8 +124211,8 @@ ${lanes.join("\n")} blockScopeContainer = savedBlockScopeContainer; } function bindEachFunctionsFirst(nodes) { - bindEach(nodes, (n) => n.kind === 261 /* FunctionDeclaration */ ? bind(n) : void 0); - bindEach(nodes, (n) => n.kind !== 261 /* FunctionDeclaration */ ? bind(n) : void 0); + bindEach(nodes, (n) => n.kind === 262 /* FunctionDeclaration */ ? bind(n) : void 0); + bindEach(nodes, (n) => n.kind !== 262 /* FunctionDeclaration */ ? bind(n) : void 0); } function bindEach(nodes, bindFunction = bind) { if (nodes === void 0) { @@ -140910,59 +124232,59 @@ ${lanes.join("\n")} inAssignmentPattern = saveInAssignmentPattern; return; } - if (node.kind >= 242 /* FirstStatement */ && node.kind <= 258 /* LastStatement */ && !options.allowUnreachableCode) { + if (node.kind >= 243 /* FirstStatement */ && node.kind <= 259 /* LastStatement */ && !options.allowUnreachableCode) { node.flowNode = currentFlow; } switch (node.kind) { - case 246 /* WhileStatement */: + case 247 /* WhileStatement */: bindWhileStatement(node); break; - case 245 /* DoStatement */: + case 246 /* DoStatement */: bindDoStatement(node); break; - case 247 /* ForStatement */: + case 248 /* ForStatement */: bindForStatement(node); break; - case 248 /* ForInStatement */: - case 249 /* ForOfStatement */: + case 249 /* ForInStatement */: + case 250 /* ForOfStatement */: bindForInOrForOfStatement(node); break; - case 244 /* IfStatement */: + case 245 /* IfStatement */: bindIfStatement(node); break; - case 252 /* ReturnStatement */: - case 256 /* ThrowStatement */: + case 253 /* ReturnStatement */: + case 257 /* ThrowStatement */: bindReturnOrThrow(node); break; - case 251 /* BreakStatement */: - case 250 /* ContinueStatement */: + case 252 /* BreakStatement */: + case 251 /* ContinueStatement */: bindBreakOrContinueStatement(node); break; - case 257 /* TryStatement */: + case 258 /* TryStatement */: bindTryStatement(node); break; - case 254 /* SwitchStatement */: + case 255 /* SwitchStatement */: bindSwitchStatement(node); break; - case 268 /* CaseBlock */: + case 269 /* CaseBlock */: bindCaseBlock(node); break; - case 295 /* CaseClause */: + case 296 /* CaseClause */: bindCaseClause(node); break; - case 243 /* ExpressionStatement */: + case 244 /* ExpressionStatement */: bindExpressionStatement(node); break; - case 255 /* LabeledStatement */: + case 256 /* LabeledStatement */: bindLabeledStatement(node); break; - case 223 /* PrefixUnaryExpression */: + case 224 /* PrefixUnaryExpression */: bindPrefixUnaryExpressionFlow(node); break; - case 224 /* PostfixUnaryExpression */: + case 225 /* PostfixUnaryExpression */: bindPostfixUnaryExpressionFlow(node); break; - case 225 /* BinaryExpression */: + case 226 /* BinaryExpression */: if (isDestructuringAssignment(node)) { inAssignmentPattern = saveInAssignmentPattern; bindDestructuringAssignmentFlow(node); @@ -140970,49 +124292,49 @@ ${lanes.join("\n")} } bindBinaryExpressionFlow(node); break; - case 219 /* DeleteExpression */: + case 220 /* DeleteExpression */: bindDeleteExpressionFlow(node); break; - case 226 /* ConditionalExpression */: + case 227 /* ConditionalExpression */: bindConditionalExpressionFlow(node); break; - case 259 /* VariableDeclaration */: + case 260 /* VariableDeclaration */: bindVariableDeclarationFlow(node); break; - case 210 /* PropertyAccessExpression */: - case 211 /* ElementAccessExpression */: + case 211 /* PropertyAccessExpression */: + case 212 /* ElementAccessExpression */: bindAccessExpressionFlow(node); break; - case 212 /* CallExpression */: + case 213 /* CallExpression */: bindCallExpressionFlow(node); break; - case 234 /* NonNullExpression */: + case 235 /* NonNullExpression */: bindNonNullExpressionFlow(node); break; - case 352 /* JSDocTypedefTag */: - case 344 /* JSDocCallbackTag */: - case 346 /* JSDocEnumTag */: + case 353 /* JSDocTypedefTag */: + case 345 /* JSDocCallbackTag */: + case 347 /* JSDocEnumTag */: bindJSDocTypeAlias(node); break; - case 311 /* SourceFile */: { + case 312 /* SourceFile */: { bindEachFunctionsFirst(node.statements); bind(node.endOfFileToken); break; } - case 240 /* Block */: - case 267 /* ModuleBlock */: + case 241 /* Block */: + case 268 /* ModuleBlock */: bindEachFunctionsFirst(node.statements); break; - case 207 /* BindingElement */: + case 208 /* BindingElement */: bindBindingElementFlow(node); break; - case 168 /* Parameter */: + case 169 /* Parameter */: bindParameterFlow(node); break; - case 209 /* ObjectLiteralExpression */: - case 208 /* ArrayLiteralExpression */: - case 302 /* PropertyAssignment */: - case 229 /* SpreadElement */: + case 210 /* ObjectLiteralExpression */: + case 209 /* ArrayLiteralExpression */: + case 303 /* PropertyAssignment */: + case 230 /* SpreadElement */: inAssignmentPattern = saveInAssignmentPattern; default: bindEachChild(node); @@ -141026,19 +124348,19 @@ ${lanes.join("\n")} case 80 /* Identifier */: case 81 /* PrivateIdentifier */: case 110 /* ThisKeyword */: - case 210 /* PropertyAccessExpression */: - case 211 /* ElementAccessExpression */: + case 211 /* PropertyAccessExpression */: + case 212 /* ElementAccessExpression */: return containsNarrowableReference(expr); - case 212 /* CallExpression */: + case 213 /* CallExpression */: return hasNarrowableArgument(expr); - case 216 /* ParenthesizedExpression */: - case 234 /* NonNullExpression */: + case 217 /* ParenthesizedExpression */: + case 235 /* NonNullExpression */: return isNarrowingExpression(expr.expression); - case 225 /* BinaryExpression */: + case 226 /* BinaryExpression */: return isNarrowingBinaryExpression(expr); - case 223 /* PrefixUnaryExpression */: + case 224 /* PrefixUnaryExpression */: return expr.operator === 54 /* ExclamationToken */ && isNarrowingExpression(expr.operand); - case 220 /* TypeOfExpression */: + case 221 /* TypeOfExpression */: return isNarrowingExpression(expr.expression); } return false; @@ -141057,7 +124379,7 @@ ${lanes.join("\n")} } } } - if (expr.expression.kind === 210 /* PropertyAccessExpression */ && containsNarrowableReference(expr.expression.expression)) { + if (expr.expression.kind === 211 /* PropertyAccessExpression */ && containsNarrowableReference(expr.expression.expression)) { return true; } return false; @@ -141076,7 +124398,7 @@ ${lanes.join("\n")} case 36 /* ExclamationEqualsToken */: case 37 /* EqualsEqualsEqualsToken */: case 38 /* ExclamationEqualsEqualsToken */: - return isNarrowableOperand(expr.left) || isNarrowableOperand(expr.right) || isNarrowingTypeofOperands(expr.right, expr.left) || isNarrowingTypeofOperands(expr.left, expr.right); + return isNarrowableOperand(expr.left) || isNarrowableOperand(expr.right) || isNarrowingTypeofOperands(expr.right, expr.left) || isNarrowingTypeofOperands(expr.left, expr.right) || (isBooleanLiteral(expr.right) && isNarrowingExpression(expr.left) || isBooleanLiteral(expr.left) && isNarrowingExpression(expr.right)); case 104 /* InstanceOfKeyword */: return isNarrowableOperand(expr.left); case 103 /* InKeyword */: @@ -141088,9 +124410,9 @@ ${lanes.join("\n")} } function isNarrowableOperand(expr) { switch (expr.kind) { - case 216 /* ParenthesizedExpression */: + case 217 /* ParenthesizedExpression */: return isNarrowableOperand(expr.expression); - case 225 /* BinaryExpression */: + case 226 /* BinaryExpression */: switch (expr.operatorToken.kind) { case 64 /* EqualsToken */: return isNarrowableOperand(expr.left); @@ -141163,21 +124485,21 @@ ${lanes.join("\n")} function isStatementCondition(node) { const parent3 = node.parent; switch (parent3.kind) { - case 244 /* IfStatement */: - case 246 /* WhileStatement */: - case 245 /* DoStatement */: + case 245 /* IfStatement */: + case 247 /* WhileStatement */: + case 246 /* DoStatement */: return parent3.expression === node; - case 247 /* ForStatement */: - case 226 /* ConditionalExpression */: + case 248 /* ForStatement */: + case 227 /* ConditionalExpression */: return parent3.condition === node; } return false; } function isLogicalExpression(node) { while (true) { - if (node.kind === 216 /* ParenthesizedExpression */) { + if (node.kind === 217 /* ParenthesizedExpression */) { node = node.expression; - } else if (node.kind === 223 /* PrefixUnaryExpression */ && node.operator === 54 /* ExclamationToken */) { + } else if (node.kind === 224 /* PrefixUnaryExpression */ && node.operator === 54 /* ExclamationToken */) { node = node.operand; } else { return isLogicalOrCoalescingBinaryExpression(node); @@ -141220,7 +124542,7 @@ ${lanes.join("\n")} } function setContinueTarget(node, target) { let label = activeLabelList; - while (label && node.parent.kind === 255 /* LabeledStatement */) { + while (label && node.parent.kind === 256 /* LabeledStatement */) { label.continueTarget = target; label = label.next; node = node.parent; @@ -141271,12 +124593,12 @@ ${lanes.join("\n")} bind(node.expression); addAntecedent(preLoopLabel, currentFlow); currentFlow = preLoopLabel; - if (node.kind === 249 /* ForOfStatement */) { + if (node.kind === 250 /* ForOfStatement */) { bind(node.awaitModifier); } addAntecedent(postLoopLabel, currentFlow); bind(node.initializer); - if (node.initializer.kind !== 260 /* VariableDeclarationList */) { + if (node.initializer.kind !== 261 /* VariableDeclarationList */) { bindAssignmentTargetFlow(node.initializer); } bindIterativeStatement(node.statement, postLoopLabel, preLoopLabel); @@ -141298,7 +124620,7 @@ ${lanes.join("\n")} } function bindReturnOrThrow(node) { bind(node.expression); - if (node.kind === 252 /* ReturnStatement */) { + if (node.kind === 253 /* ReturnStatement */) { hasExplicitReturn = true; if (currentReturnTarget) { addAntecedent(currentReturnTarget, currentFlow); @@ -141315,7 +124637,7 @@ ${lanes.join("\n")} return void 0; } function bindBreakOrContinueFlow(node, breakTarget, continueTarget) { - const flowLabel = node.kind === 251 /* BreakStatement */ ? breakTarget : continueTarget; + const flowLabel = node.kind === 252 /* BreakStatement */ ? breakTarget : continueTarget; if (flowLabel) { addAntecedent(flowLabel, currentFlow); currentFlow = unreachableFlow; @@ -141385,7 +124707,7 @@ ${lanes.join("\n")} preSwitchCaseFlow = currentFlow; bind(node.caseBlock); addAntecedent(postSwitchLabel, currentFlow); - const hasDefault = forEach(node.caseBlock.clauses, (c) => c.kind === 296 /* DefaultClause */); + const hasDefault = forEach(node.caseBlock.clauses, (c) => c.kind === 297 /* DefaultClause */); node.possiblyExhaustive = !hasDefault && !postSwitchLabel.antecedents; if (!hasDefault) { addAntecedent(postSwitchLabel, createFlowSwitchClause(preSwitchCaseFlow, node, 0, 0)); @@ -141396,7 +124718,7 @@ ${lanes.join("\n")} } function bindCaseBlock(node) { const clauses = node.clauses; - const isNarrowingSwitch = isNarrowingExpression(node.parent.expression); + const isNarrowingSwitch = node.parent.expression.kind === 112 /* TrueKeyword */ || isNarrowingExpression(node.parent.expression); let fallthroughFlow = unreachableFlow; for (let i = 0; i < clauses.length; i++) { const clauseStart = i; @@ -141428,7 +124750,7 @@ ${lanes.join("\n")} maybeBindExpressionFlowIfCall(node.expression); } function maybeBindExpressionFlowIfCall(node) { - if (node.kind === 212 /* CallExpression */) { + if (node.kind === 213 /* CallExpression */) { const call = node; if (call.expression.kind !== 108 /* SuperKeyword */ && isDottedName(call.expression)) { currentFlow = createFlowCall(currentFlow, call); @@ -141454,7 +124776,7 @@ ${lanes.join("\n")} currentFlow = finishFlowLabel(postStatementLabel); } function bindDestructuringTargetFlow(node) { - if (node.kind === 225 /* BinaryExpression */ && node.operatorToken.kind === 64 /* EqualsToken */) { + if (node.kind === 226 /* BinaryExpression */ && node.operatorToken.kind === 64 /* EqualsToken */) { bindAssignmentTargetFlow(node.left); } else { bindAssignmentTargetFlow(node); @@ -141463,21 +124785,21 @@ ${lanes.join("\n")} function bindAssignmentTargetFlow(node) { if (isNarrowableReference(node)) { currentFlow = createFlowMutation(16 /* Assignment */, currentFlow, node); - } else if (node.kind === 208 /* ArrayLiteralExpression */) { + } else if (node.kind === 209 /* ArrayLiteralExpression */) { for (const e of node.elements) { - if (e.kind === 229 /* SpreadElement */) { + if (e.kind === 230 /* SpreadElement */) { bindAssignmentTargetFlow(e.expression); } else { bindDestructuringTargetFlow(e); } } - } else if (node.kind === 209 /* ObjectLiteralExpression */) { + } else if (node.kind === 210 /* ObjectLiteralExpression */) { for (const p of node.properties) { - if (p.kind === 302 /* PropertyAssignment */) { + if (p.kind === 303 /* PropertyAssignment */) { bindDestructuringTargetFlow(p.initializer); - } else if (p.kind === 303 /* ShorthandPropertyAssignment */) { + } else if (p.kind === 304 /* ShorthandPropertyAssignment */) { bindAssignmentTargetFlow(p.name); - } else if (p.kind === 304 /* SpreadAssignment */) { + } else if (p.kind === 305 /* SpreadAssignment */) { bindAssignmentTargetFlow(p.expression); } } @@ -141608,7 +124930,7 @@ ${lanes.join("\n")} const operator = node.operatorToken.kind; if (isAssignmentOperator(operator) && !isAssignmentTarget(node)) { bindAssignmentTargetFlow(node.left); - if (operator === 64 /* EqualsToken */ && node.left.kind === 211 /* ElementAccessExpression */) { + if (operator === 64 /* EqualsToken */ && node.left.kind === 212 /* ElementAccessExpression */) { const elementAccess = node.left; if (isNarrowableOperand(elementAccess.expression)) { currentFlow = createFlowMutation(256 /* ArrayMutation */, currentFlow, node); @@ -141636,7 +124958,7 @@ ${lanes.join("\n")} } function bindDeleteExpressionFlow(node) { bindEachChild(node); - if (node.expression.kind === 210 /* PropertyAccessExpression */) { + if (node.expression.kind === 211 /* PropertyAccessExpression */) { bindAssignmentTargetFlow(node.expression); } } @@ -141701,7 +125023,7 @@ ${lanes.join("\n")} } function bindJSDocTypeAlias(node) { bind(node.tagName); - if (node.kind !== 346 /* JSDocEnumTag */ && node.fullName) { + if (node.kind !== 347 /* JSDocEnumTag */ && node.fullName) { setParent(node.fullName, node); setParentRecursive( node.fullName, @@ -141716,7 +125038,7 @@ ${lanes.join("\n")} function bindJSDocClassTag(node) { bindEachChild(node); const host = getHostSignatureFromJSDoc(node); - if (host && host.kind !== 173 /* MethodDeclaration */) { + if (host && host.kind !== 174 /* MethodDeclaration */) { addDeclarationToSymbol(host.symbol, host, 32 /* Class */); } } @@ -141729,15 +125051,15 @@ ${lanes.join("\n")} } function bindOptionalChainRest(node) { switch (node.kind) { - case 210 /* PropertyAccessExpression */: + case 211 /* PropertyAccessExpression */: bind(node.questionDotToken); bind(node.name); break; - case 211 /* ElementAccessExpression */: + case 212 /* ElementAccessExpression */: bind(node.questionDotToken); bind(node.argumentExpression); break; - case 212 /* CallExpression */: + case 213 /* CallExpression */: bind(node.questionDotToken); bindEach(node.typeArguments); bindEach(node.arguments); @@ -141784,7 +125106,7 @@ ${lanes.join("\n")} bindOptionalChainFlow(node); } else { const expr = skipParentheses(node.expression); - if (expr.kind === 217 /* FunctionExpression */ || expr.kind === 218 /* ArrowFunction */) { + if (expr.kind === 218 /* FunctionExpression */ || expr.kind === 219 /* ArrowFunction */) { bindEach(node.typeArguments); bindEach(node.arguments); bind(node.expression); @@ -141795,7 +125117,7 @@ ${lanes.join("\n")} } } } - if (node.expression.kind === 210 /* PropertyAccessExpression */) { + if (node.expression.kind === 211 /* PropertyAccessExpression */) { const propertyAccess = node.expression; if (isIdentifier(propertyAccess.name) && isNarrowableOperand(propertyAccess.expression) && isPushOrUnshiftIdentifier(propertyAccess.name)) { currentFlow = createFlowMutation(256 /* ArrayMutation */, currentFlow, node); @@ -141810,39 +125132,39 @@ ${lanes.join("\n")} } function declareSymbolAndAddToSymbolTable(node, symbolFlags, symbolExcludes) { switch (container.kind) { - case 266 /* ModuleDeclaration */: + case 267 /* ModuleDeclaration */: return declareModuleMember(node, symbolFlags, symbolExcludes); - case 311 /* SourceFile */: + case 312 /* SourceFile */: return declareSourceFileMember(node, symbolFlags, symbolExcludes); - case 230 /* ClassExpression */: - case 262 /* ClassDeclaration */: + case 231 /* ClassExpression */: + case 263 /* ClassDeclaration */: return declareClassMember(node, symbolFlags, symbolExcludes); - case 265 /* EnumDeclaration */: + case 266 /* EnumDeclaration */: return declareSymbol(container.symbol.exports, container.symbol, node, symbolFlags, symbolExcludes); - case 186 /* TypeLiteral */: - case 328 /* JSDocTypeLiteral */: - case 209 /* ObjectLiteralExpression */: - case 263 /* InterfaceDeclaration */: - case 291 /* JsxAttributes */: + case 187 /* TypeLiteral */: + case 329 /* JSDocTypeLiteral */: + case 210 /* ObjectLiteralExpression */: + case 264 /* InterfaceDeclaration */: + case 292 /* JsxAttributes */: return declareSymbol(container.symbol.members, container.symbol, node, symbolFlags, symbolExcludes); - case 183 /* FunctionType */: - case 184 /* ConstructorType */: - case 178 /* CallSignature */: - case 179 /* ConstructSignature */: - case 329 /* JSDocSignature */: - case 180 /* IndexSignature */: - case 173 /* MethodDeclaration */: - case 172 /* MethodSignature */: - case 175 /* Constructor */: - case 176 /* GetAccessor */: - case 177 /* SetAccessor */: - case 261 /* FunctionDeclaration */: - case 217 /* FunctionExpression */: - case 218 /* ArrowFunction */: - case 323 /* JSDocFunctionType */: - case 174 /* ClassStaticBlockDeclaration */: - case 264 /* TypeAliasDeclaration */: - case 199 /* MappedType */: + case 184 /* FunctionType */: + case 185 /* ConstructorType */: + case 179 /* CallSignature */: + case 180 /* ConstructSignature */: + case 330 /* JSDocSignature */: + case 181 /* IndexSignature */: + case 174 /* MethodDeclaration */: + case 173 /* MethodSignature */: + case 176 /* Constructor */: + case 177 /* GetAccessor */: + case 178 /* SetAccessor */: + case 262 /* FunctionDeclaration */: + case 218 /* FunctionExpression */: + case 219 /* ArrowFunction */: + case 324 /* JSDocFunctionType */: + case 175 /* ClassStaticBlockDeclaration */: + case 265 /* TypeAliasDeclaration */: + case 200 /* MappedType */: if (container.locals) Debug.assertNode(container, canHaveLocals); return declareSymbol( @@ -141873,16 +125195,16 @@ ${lanes.join("\n")} return !!body && body.statements.some((s) => isExportDeclaration(s) || isExportAssignment(s)); } function setExportContextFlag(node) { - if (node.flags & 16777216 /* Ambient */ && !hasExportDeclarations(node)) { - node.flags |= 64 /* ExportContext */; + if (node.flags & 33554432 /* Ambient */ && !hasExportDeclarations(node)) { + node.flags |= 128 /* ExportContext */; } else { - node.flags &= ~64 /* ExportContext */; + node.flags &= ~128 /* ExportContext */; } } function bindModuleDeclaration(node) { setExportContextFlag(node); if (isAmbientModule(node)) { - if (hasSyntacticModifier(node, 1 /* Export */)) { + if (hasSyntacticModifier(node, 32 /* Export */)) { errorOnFirstToken(node, Diagnostics.export_modifier_cannot_be_applied_to_ambient_modules_and_module_augmentations_since_they_are_always_visible); } if (isModuleAugmentationExternal(node)) { @@ -141944,10 +125266,10 @@ ${lanes.join("\n")} } function bindBlockScopedDeclaration(node, symbolFlags, symbolExcludes) { switch (blockScopeContainer.kind) { - case 266 /* ModuleDeclaration */: + case 267 /* ModuleDeclaration */: declareModuleMember(node, symbolFlags, symbolExcludes); break; - case 311 /* SourceFile */: + case 312 /* SourceFile */: if (isExternalOrCommonJsModule(container)) { declareModuleMember(node, symbolFlags, symbolExcludes); break; @@ -141979,7 +125301,7 @@ ${lanes.join("\n")} const saveCurrentFlow = currentFlow; for (const typeAlias of delayedTypeAliases) { const host = typeAlias.parent.parent; - container = findAncestor(host.parent, (n) => !!(getContainerFlags(n) & 1 /* IsContainer */)) || file; + container = getEnclosingContainer(host) || file; blockScopeContainer = getEnclosingBlockScopeContainer(host) || file; currentFlow = initFlowNode({ flags: 2 /* Start */ }); parent2 = typeAlias; @@ -142037,37 +125359,21 @@ ${lanes.join("\n")} currentFlow = saveCurrentFlow; } function checkContextualIdentifier(node) { - if (!file.parseDiagnostics.length && !(node.flags & 16777216 /* Ambient */) && !(node.flags & 8388608 /* JSDoc */) && !isIdentifierName(node)) { + if (!file.parseDiagnostics.length && !(node.flags & 33554432 /* Ambient */) && !(node.flags & 16777216 /* JSDoc */) && !isIdentifierName(node)) { const originalKeywordKind = identifierToKeywordKind(node); if (originalKeywordKind === void 0) { return; } if (inStrictMode && originalKeywordKind >= 119 /* FirstFutureReservedWord */ && originalKeywordKind <= 127 /* LastFutureReservedWord */) { - file.bindDiagnostics.push(createDiagnosticForNode2( - node, - getStrictModeIdentifierMessage(node), - declarationNameToString(node) - )); + file.bindDiagnostics.push(createDiagnosticForNode2(node, getStrictModeIdentifierMessage(node), declarationNameToString(node))); } else if (originalKeywordKind === 135 /* AwaitKeyword */) { if (isExternalModule(file) && isInTopLevelContext(node)) { - file.bindDiagnostics.push(createDiagnosticForNode2( - node, - Diagnostics.Identifier_expected_0_is_a_reserved_word_at_the_top_level_of_a_module, - declarationNameToString(node) - )); - } else if (node.flags & 32768 /* AwaitContext */) { - file.bindDiagnostics.push(createDiagnosticForNode2( - node, - Diagnostics.Identifier_expected_0_is_a_reserved_word_that_cannot_be_used_here, - declarationNameToString(node) - )); + file.bindDiagnostics.push(createDiagnosticForNode2(node, Diagnostics.Identifier_expected_0_is_a_reserved_word_at_the_top_level_of_a_module, declarationNameToString(node))); + } else if (node.flags & 65536 /* AwaitContext */) { + file.bindDiagnostics.push(createDiagnosticForNode2(node, Diagnostics.Identifier_expected_0_is_a_reserved_word_that_cannot_be_used_here, declarationNameToString(node))); } - } else if (originalKeywordKind === 127 /* YieldKeyword */ && node.flags & 8192 /* YieldContext */) { - file.bindDiagnostics.push(createDiagnosticForNode2( - node, - Diagnostics.Identifier_expected_0_is_a_reserved_word_that_cannot_be_used_here, - declarationNameToString(node) - )); + } else if (originalKeywordKind === 127 /* YieldKeyword */ && node.flags & 16384 /* YieldContext */) { + file.bindDiagnostics.push(createDiagnosticForNode2(node, Diagnostics.Identifier_expected_0_is_a_reserved_word_that_cannot_be_used_here, declarationNameToString(node))); } } } @@ -142083,11 +125389,7 @@ ${lanes.join("\n")} function checkPrivateIdentifier(node) { if (node.escapedText === "#constructor") { if (!file.parseDiagnostics.length) { - file.bindDiagnostics.push(createDiagnosticForNode2( - node, - Diagnostics.constructor_is_a_reserved_word, - declarationNameToString(node) - )); + file.bindDiagnostics.push(createDiagnosticForNode2(node, Diagnostics.constructor_is_a_reserved_word, declarationNameToString(node))); } } } @@ -142115,13 +125417,7 @@ ${lanes.join("\n")} const identifier = name; if (isEvalOrArgumentsIdentifier(identifier)) { const span = getErrorSpanForNode(file, name); - file.bindDiagnostics.push(createFileDiagnostic( - file, - span.start, - span.length, - getStrictModeEvalOrArgumentsMessage(contextNode), - idText(identifier) - )); + file.bindDiagnostics.push(createFileDiagnostic(file, span.start, span.length, getStrictModeEvalOrArgumentsMessage(contextNode), idText(identifier))); } } } @@ -142150,14 +125446,9 @@ ${lanes.join("\n")} } function checkStrictModeFunctionDeclaration(node) { if (languageVersion < 2 /* ES2015 */) { - if (blockScopeContainer.kind !== 311 /* SourceFile */ && blockScopeContainer.kind !== 266 /* ModuleDeclaration */ && !isFunctionLikeOrClassStaticBlockDeclaration(blockScopeContainer)) { + if (blockScopeContainer.kind !== 312 /* SourceFile */ && blockScopeContainer.kind !== 267 /* ModuleDeclaration */ && !isFunctionLikeOrClassStaticBlockDeclaration(blockScopeContainer)) { const errorSpan = getErrorSpanForNode(file, node); - file.bindDiagnostics.push(createFileDiagnostic( - file, - errorSpan.start, - errorSpan.length, - getStrictModeBlockScopeFunctionDeclarationMessage(node) - )); + file.bindDiagnostics.push(createFileDiagnostic(file, errorSpan.start, errorSpan.length, getStrictModeBlockScopeFunctionDeclarationMessage(node))); } } } @@ -142212,7 +125503,7 @@ ${lanes.join("\n")} node.tracingPath = file.path; const saveInStrictMode = inStrictMode; bindWorker(node); - if (node.kind > 164 /* LastToken */) { + if (node.kind > 165 /* LastToken */) { const saveParent = parent2; parent2 = node; const containerFlags = getContainerFlags(node); @@ -142269,7 +125560,7 @@ ${lanes.join("\n")} function bindWorker(node) { switch (node.kind) { case 80 /* Identifier */: - if (node.flags & 2048 /* IdentifierIsInJSDocNamespace */) { + if (node.flags & 4096 /* IdentifierIsInJSDocNamespace */) { let parentNode = node.parent; while (parentNode && !isJSDocTypeAlias(parentNode)) { parentNode = parentNode.parent; @@ -142278,23 +125569,23 @@ ${lanes.join("\n")} break; } case 110 /* ThisKeyword */: - if (currentFlow && (isExpression(node) || parent2.kind === 303 /* ShorthandPropertyAssignment */)) { + if (currentFlow && (isExpression(node) || parent2.kind === 304 /* ShorthandPropertyAssignment */)) { node.flowNode = currentFlow; } return checkContextualIdentifier(node); - case 165 /* QualifiedName */: + case 166 /* QualifiedName */: if (currentFlow && isPartOfTypeQuery(node)) { node.flowNode = currentFlow; } break; - case 235 /* MetaProperty */: + case 236 /* MetaProperty */: case 108 /* SuperKeyword */: node.flowNode = currentFlow; break; case 81 /* PrivateIdentifier */: return checkPrivateIdentifier(node); - case 210 /* PropertyAccessExpression */: - case 211 /* ElementAccessExpression */: + case 211 /* PropertyAccessExpression */: + case 212 /* ElementAccessExpression */: const expr = node; if (currentFlow && isNarrowableReference(expr)) { expr.flowNode = currentFlow; @@ -142313,7 +125604,7 @@ ${lanes.join("\n")} ); } break; - case 225 /* BinaryExpression */: + case 226 /* BinaryExpression */: const specialKind = getAssignmentDeclarationKind(node); switch (specialKind) { case 1 /* ExportsProperty */: @@ -142348,81 +125639,77 @@ ${lanes.join("\n")} Debug.fail("Unknown binary expression special property assignment kind"); } return checkStrictModeBinaryExpression(node); - case 298 /* CatchClause */: + case 299 /* CatchClause */: return checkStrictModeCatchClause(node); - case 219 /* DeleteExpression */: + case 220 /* DeleteExpression */: return checkStrictModeDeleteExpression(node); - case 224 /* PostfixUnaryExpression */: + case 225 /* PostfixUnaryExpression */: return checkStrictModePostfixUnaryExpression(node); - case 223 /* PrefixUnaryExpression */: + case 224 /* PrefixUnaryExpression */: return checkStrictModePrefixUnaryExpression(node); - case 253 /* WithStatement */: + case 254 /* WithStatement */: return checkStrictModeWithStatement(node); - case 255 /* LabeledStatement */: + case 256 /* LabeledStatement */: return checkStrictModeLabeledStatement(node); - case 196 /* ThisType */: + case 197 /* ThisType */: seenThisKeyword = true; return; - case 181 /* TypePredicate */: + case 182 /* TypePredicate */: break; - case 167 /* TypeParameter */: + case 168 /* TypeParameter */: return bindTypeParameter(node); - case 168 /* Parameter */: + case 169 /* Parameter */: return bindParameter(node); - case 259 /* VariableDeclaration */: + case 260 /* VariableDeclaration */: return bindVariableDeclarationOrBindingElement(node); - case 207 /* BindingElement */: + case 208 /* BindingElement */: node.flowNode = currentFlow; return bindVariableDeclarationOrBindingElement(node); - case 171 /* PropertyDeclaration */: - case 170 /* PropertySignature */: + case 172 /* PropertyDeclaration */: + case 171 /* PropertySignature */: return bindPropertyWorker(node); - case 302 /* PropertyAssignment */: - case 303 /* ShorthandPropertyAssignment */: + case 303 /* PropertyAssignment */: + case 304 /* ShorthandPropertyAssignment */: return bindPropertyOrMethodOrAccessor(node, 4 /* Property */, 0 /* PropertyExcludes */); - case 305 /* EnumMember */: + case 306 /* EnumMember */: return bindPropertyOrMethodOrAccessor(node, 8 /* EnumMember */, 900095 /* EnumMemberExcludes */); - case 178 /* CallSignature */: - case 179 /* ConstructSignature */: - case 180 /* IndexSignature */: + case 179 /* CallSignature */: + case 180 /* ConstructSignature */: + case 181 /* IndexSignature */: return declareSymbolAndAddToSymbolTable(node, 131072 /* Signature */, 0 /* None */); - case 173 /* MethodDeclaration */: - case 172 /* MethodSignature */: - return bindPropertyOrMethodOrAccessor( - node, - 8192 /* Method */ | (node.questionToken ? 16777216 /* Optional */ : 0 /* None */), - isObjectLiteralMethod(node) ? 0 /* PropertyExcludes */ : 103359 /* MethodExcludes */ - ); - case 261 /* FunctionDeclaration */: + case 174 /* MethodDeclaration */: + case 173 /* MethodSignature */: + return bindPropertyOrMethodOrAccessor(node, 8192 /* Method */ | (node.questionToken ? 16777216 /* Optional */ : 0 /* None */), isObjectLiteralMethod(node) ? 0 /* PropertyExcludes */ : 103359 /* MethodExcludes */); + case 262 /* FunctionDeclaration */: return bindFunctionDeclaration(node); - case 175 /* Constructor */: + case 176 /* Constructor */: return declareSymbolAndAddToSymbolTable( node, 16384 /* Constructor */, /*symbolExcludes:*/ 0 /* None */ ); - case 176 /* GetAccessor */: + case 177 /* GetAccessor */: return bindPropertyOrMethodOrAccessor(node, 32768 /* GetAccessor */, 46015 /* GetAccessorExcludes */); - case 177 /* SetAccessor */: + case 178 /* SetAccessor */: return bindPropertyOrMethodOrAccessor(node, 65536 /* SetAccessor */, 78783 /* SetAccessorExcludes */); - case 183 /* FunctionType */: - case 323 /* JSDocFunctionType */: - case 329 /* JSDocSignature */: - case 184 /* ConstructorType */: + case 184 /* FunctionType */: + case 324 /* JSDocFunctionType */: + case 330 /* JSDocSignature */: + case 185 /* ConstructorType */: return bindFunctionOrConstructorType(node); - case 186 /* TypeLiteral */: - case 328 /* JSDocTypeLiteral */: - case 199 /* MappedType */: + case 187 /* TypeLiteral */: + case 329 /* JSDocTypeLiteral */: + case 200 /* MappedType */: return bindAnonymousTypeWorker(node); - case 338 /* JSDocClassTag */: + case 339 /* JSDocClassTag */: return bindJSDocClassTag(node); - case 209 /* ObjectLiteralExpression */: + case 210 /* ObjectLiteralExpression */: return bindObjectLiteralExpression(node); - case 217 /* FunctionExpression */: - case 218 /* ArrowFunction */: + case 218 /* FunctionExpression */: + case 219 /* ArrowFunction */: return bindFunctionExpression(node); - case 212 /* CallExpression */: + case 213 /* CallExpression */: const assignmentKind = getAssignmentDeclarationKind(node); switch (assignmentKind) { case 7 /* ObjectDefinePropertyValue */: @@ -142440,60 +125727,60 @@ ${lanes.join("\n")} bindCallExpression(node); } break; - case 230 /* ClassExpression */: - case 262 /* ClassDeclaration */: + case 231 /* ClassExpression */: + case 263 /* ClassDeclaration */: inStrictMode = true; return bindClassLikeDeclaration(node); - case 263 /* InterfaceDeclaration */: + case 264 /* InterfaceDeclaration */: return bindBlockScopedDeclaration(node, 64 /* Interface */, 788872 /* InterfaceExcludes */); - case 264 /* TypeAliasDeclaration */: + case 265 /* TypeAliasDeclaration */: return bindBlockScopedDeclaration(node, 524288 /* TypeAlias */, 788968 /* TypeAliasExcludes */); - case 265 /* EnumDeclaration */: + case 266 /* EnumDeclaration */: return bindEnumDeclaration(node); - case 266 /* ModuleDeclaration */: + case 267 /* ModuleDeclaration */: return bindModuleDeclaration(node); - case 291 /* JsxAttributes */: + case 292 /* JsxAttributes */: return bindJsxAttributes(node); - case 290 /* JsxAttribute */: + case 291 /* JsxAttribute */: return bindJsxAttribute(node, 4 /* Property */, 0 /* PropertyExcludes */); - case 270 /* ImportEqualsDeclaration */: - case 273 /* NamespaceImport */: - case 275 /* ImportSpecifier */: - case 280 /* ExportSpecifier */: + case 271 /* ImportEqualsDeclaration */: + case 274 /* NamespaceImport */: + case 276 /* ImportSpecifier */: + case 281 /* ExportSpecifier */: return declareSymbolAndAddToSymbolTable(node, 2097152 /* Alias */, 2097152 /* AliasExcludes */); - case 269 /* NamespaceExportDeclaration */: + case 270 /* NamespaceExportDeclaration */: return bindNamespaceExportDeclaration(node); - case 272 /* ImportClause */: + case 273 /* ImportClause */: return bindImportClause(node); - case 277 /* ExportDeclaration */: + case 278 /* ExportDeclaration */: return bindExportDeclaration(node); - case 276 /* ExportAssignment */: + case 277 /* ExportAssignment */: return bindExportAssignment(node); - case 311 /* SourceFile */: + case 312 /* SourceFile */: updateStrictModeStatementList(node.statements); return bindSourceFileIfExternalModule(); - case 240 /* Block */: + case 241 /* Block */: if (!isFunctionLikeOrClassStaticBlockDeclaration(node.parent)) { return; } - case 267 /* ModuleBlock */: + case 268 /* ModuleBlock */: return updateStrictModeStatementList(node.statements); - case 347 /* JSDocParameterTag */: - if (node.parent.kind === 329 /* JSDocSignature */) { + case 348 /* JSDocParameterTag */: + if (node.parent.kind === 330 /* JSDocSignature */) { return bindParameter(node); } - if (node.parent.kind !== 328 /* JSDocTypeLiteral */) { + if (node.parent.kind !== 329 /* JSDocTypeLiteral */) { break; } - case 354 /* JSDocPropertyTag */: + case 355 /* JSDocPropertyTag */: const propTag = node; - const flags = propTag.isBracketed || propTag.typeExpression && propTag.typeExpression.type.kind === 322 /* JSDocOptionalType */ ? 4 /* Property */ | 16777216 /* Optional */ : 4 /* Property */; + const flags = propTag.isBracketed || propTag.typeExpression && propTag.typeExpression.type.kind === 323 /* JSDocOptionalType */ ? 4 /* Property */ | 16777216 /* Optional */ : 4 /* Property */; return declareSymbolAndAddToSymbolTable(propTag, flags, 0 /* PropertyExcludes */); - case 352 /* JSDocTypedefTag */: - case 344 /* JSDocCallbackTag */: - case 346 /* JSDocEnumTag */: + case 353 /* JSDocTypedefTag */: + case 345 /* JSDocCallbackTag */: + case 347 /* JSDocEnumTag */: return (delayedTypeAliases || (delayedTypeAliases = [])).push(node); - case 345 /* JSDocOverloadTag */: + case 346 /* JSDocOverloadTag */: return bind(node.typeExpression); } } @@ -142645,8 +125932,8 @@ ${lanes.join("\n")} false ); switch (thisContainer.kind) { - case 261 /* FunctionDeclaration */: - case 217 /* FunctionExpression */: + case 262 /* FunctionDeclaration */: + case 218 /* FunctionExpression */: let constructorSymbol = thisContainer.symbol; if (isBinaryExpression(thisContainer.parent) && thisContainer.parent.operatorToken.kind === 64 /* EqualsToken */) { const l = thisContainer.parent.left; @@ -142664,12 +125951,12 @@ ${lanes.join("\n")} addDeclarationToSymbol(constructorSymbol, constructorSymbol.valueDeclaration, 32 /* Class */); } break; - case 175 /* Constructor */: - case 171 /* PropertyDeclaration */: - case 173 /* MethodDeclaration */: - case 176 /* GetAccessor */: - case 177 /* SetAccessor */: - case 174 /* ClassStaticBlockDeclaration */: + case 176 /* Constructor */: + case 172 /* PropertyDeclaration */: + case 174 /* MethodDeclaration */: + case 177 /* GetAccessor */: + case 178 /* SetAccessor */: + case 175 /* ClassStaticBlockDeclaration */: const containingClass = thisContainer.parent; const symbolTable = isStatic(thisContainer) ? containingClass.symbol.exports : containingClass.symbol.members; if (hasDynamicName(node)) { @@ -142686,7 +125973,7 @@ ${lanes.join("\n")} ); } break; - case 311 /* SourceFile */: + case 312 /* SourceFile */: if (hasDynamicName(node)) { break; } else if (thisContainer.commonJsModuleIndicator) { @@ -142695,7 +125982,7 @@ ${lanes.join("\n")} declareSymbolAndAddToSymbolTable(node, 1 /* FunctionScopedVariable */, 111550 /* FunctionScopedVariableExcludes */); } break; - case 266 /* ModuleDeclaration */: + case 267 /* ModuleDeclaration */: break; default: Debug.failBadSyntaxKind(thisContainer); @@ -142723,7 +126010,7 @@ ${lanes.join("\n")} function bindSpecialPropertyDeclaration(node) { if (node.expression.kind === 110 /* ThisKeyword */) { bindThisPropertyAssignment(node); - } else if (isBindableStaticAccessExpression(node) && node.parent.parent.kind === 311 /* SourceFile */) { + } else if (isBindableStaticAccessExpression(node) && node.parent.parent.kind === 312 /* SourceFile */) { if (isPrototypeAccess(node.expression)) { bindPrototypePropertyAssignment(node, node.parent); } else { @@ -142772,7 +126059,7 @@ ${lanes.join("\n")} } function bindObjectDefinePropertyAssignment(node) { let namespaceSymbol = lookupSymbolForPropertyAccess(node.arguments[0]); - const isToplevel = node.parent.parent.kind === 311 /* SourceFile */; + const isToplevel = node.parent.parent.kind === 312 /* SourceFile */; namespaceSymbol = bindPotentiallyMissingNamespaces( namespaceSymbol, node.arguments[0], @@ -142886,7 +126173,7 @@ ${lanes.join("\n")} declareSymbol(symbolTable, namespaceSymbol, declaration, includes | 67108864 /* Assignment */, excludes & ~67108864 /* Assignment */); } function isTopLevelNamespaceAssignment(propertyAccess) { - return isBinaryExpression(propertyAccess.parent) ? getParentOfBinaryExpression(propertyAccess.parent).parent.kind === 311 /* SourceFile */ : propertyAccess.parent.parent.kind === 311 /* SourceFile */; + return isBinaryExpression(propertyAccess.parent) ? getParentOfBinaryExpression(propertyAccess.parent).parent.kind === 312 /* SourceFile */ : propertyAccess.parent.parent.kind === 312 /* SourceFile */; } function bindPropertyAssignment(name, propertyAccess, isPrototypeProperty, containerIsClass) { let namespaceSymbol = lookupSymbolForPropertyAccess(name, container) || lookupSymbolForPropertyAccess(name, blockScopeContainer); @@ -142948,7 +126235,7 @@ ${lanes.join("\n")} } } function bindClassLikeDeclaration(node) { - if (node.kind === 262 /* ClassDeclaration */) { + if (node.kind === 263 /* ClassDeclaration */) { bindBlockScopedDeclaration(node, 32 /* Class */, 899503 /* ClassExcludes */); } else { const bindingName = node.name ? node.name.escapedText : "__class" /* Class */; @@ -142977,8 +126264,8 @@ ${lanes.join("\n")} checkStrictModeEvalOrArguments(node, node.name); } if (!isBindingPattern(node.name)) { - const possibleVariableDecl = node.kind === 259 /* VariableDeclaration */ ? node : node.parent.parent; - if (isInJSFile(node) && shouldResolveJsRequire(options) && isVariableDeclarationInitializedToBareOrAccessedRequire(possibleVariableDecl) && !getJSDocTypeTag(node) && !(getCombinedModifierFlags(node) & 1 /* Export */)) { + const possibleVariableDecl = node.kind === 260 /* VariableDeclaration */ ? node : node.parent.parent; + if (isInJSFile(node) && shouldResolveJsRequire(options) && isVariableDeclarationInitializedToBareOrAccessedRequire(possibleVariableDecl) && !getJSDocTypeTag(node) && !(getCombinedModifierFlags(node) & 32 /* Export */)) { declareSymbolAndAddToSymbolTable(node, 2097152 /* Alias */, 2097152 /* AliasExcludes */); } else if (isBlockOrCatchScoped(node)) { bindBlockScopedDeclaration(node, 2 /* BlockScopedVariable */, 111551 /* BlockScopedVariableExcludes */); @@ -142990,10 +126277,10 @@ ${lanes.join("\n")} } } function bindParameter(node) { - if (node.kind === 347 /* JSDocParameterTag */ && container.kind !== 329 /* JSDocSignature */) { + if (node.kind === 348 /* JSDocParameterTag */ && container.kind !== 330 /* JSDocSignature */) { return; } - if (inStrictMode && !(node.flags & 16777216 /* Ambient */)) { + if (inStrictMode && !(node.flags & 33554432 /* Ambient */)) { checkStrictModeEvalOrArguments(node, node.name); } if (isBindingPattern(node.name)) { @@ -143007,9 +126294,9 @@ ${lanes.join("\n")} } } function bindFunctionDeclaration(node) { - if (!file.isDeclarationFile && !(node.flags & 16777216 /* Ambient */)) { + if (!file.isDeclarationFile && !(node.flags & 33554432 /* Ambient */)) { if (isAsyncFunction(node)) { - emitFlags |= 2048 /* HasAsyncFunctions */; + emitFlags |= 4096 /* HasAsyncFunctions */; } } checkStrictModeFunctionName(node); @@ -143021,9 +126308,9 @@ ${lanes.join("\n")} } } function bindFunctionExpression(node) { - if (!file.isDeclarationFile && !(node.flags & 16777216 /* Ambient */)) { + if (!file.isDeclarationFile && !(node.flags & 33554432 /* Ambient */)) { if (isAsyncFunction(node)) { - emitFlags |= 2048 /* HasAsyncFunctions */; + emitFlags |= 4096 /* HasAsyncFunctions */; } } if (currentFlow) { @@ -143034,8 +126321,8 @@ ${lanes.join("\n")} return bindAnonymousDeclaration(node, 16 /* Function */, bindingName); } function bindPropertyOrMethodOrAccessor(node, symbolFlags, symbolExcludes) { - if (!file.isDeclarationFile && !(node.flags & 16777216 /* Ambient */) && isAsyncFunction(node)) { - emitFlags |= 2048 /* HasAsyncFunctions */; + if (!file.isDeclarationFile && !(node.flags & 33554432 /* Ambient */) && isAsyncFunction(node)) { + emitFlags |= 4096 /* HasAsyncFunctions */; } if (currentFlow && isObjectLiteralOrClassExpressionMethodOrAccessor(node)) { node.flowNode = currentFlow; @@ -143063,7 +126350,7 @@ ${lanes.join("\n")} } else { declareSymbolAndAddToSymbolTable(node, 262144 /* TypeParameter */, 526824 /* TypeParameterExcludes */); } - } else if (node.parent.kind === 194 /* InferType */) { + } else if (node.parent.kind === 195 /* InferType */) { const container2 = getInferTypeContainer(node.parent); if (container2) { Debug.assertNode(container2, canHaveLocals); @@ -143094,14 +126381,14 @@ ${lanes.join("\n")} if (currentFlow === unreachableFlow) { const reportError = ( // report error on all statements except empty ones - isStatementButNotDeclaration(node) && node.kind !== 241 /* EmptyStatement */ || // report error on class declarations - node.kind === 262 /* ClassDeclaration */ || // report error on instantiated modules or const-enums only modules if preserveConstEnums is set - node.kind === 266 /* ModuleDeclaration */ && shouldReportErrorOnModuleDeclaration(node) + isStatementButNotDeclaration(node) && node.kind !== 242 /* EmptyStatement */ || // report error on class declarations + node.kind === 263 /* ClassDeclaration */ || // report error on instantiated modules or const-enums only modules if preserveConstEnums is set + node.kind === 267 /* ModuleDeclaration */ && shouldReportErrorOnModuleDeclaration(node) ); if (reportError) { currentFlow = reportedUnreachableFlow; if (!options.allowUnreachableCode) { - const isError = unreachableCodeIsError(options) && !(node.flags & 16777216 /* Ambient */) && (!isVariableStatement(node) || !!(getCombinedNodeFlags(node.declarationList) & 3 /* BlockScoped */) || node.declarationList.declarations.some((d) => !!d.initializer)); + const isError = unreachableCodeIsError(options) && !(node.flags & 33554432 /* Ambient */) && (!isVariableStatement(node) || !!(getCombinedNodeFlags(node.declarationList) & 7 /* BlockScoped */) || node.declarationList.declarations.some((d) => !!d.initializer)); eachUnreachableRange(node, (start, end) => errorOrSuggestionOnRange(isError, start, end, Diagnostics.Unreachable_code_detected)); } } @@ -143120,17 +126407,17 @@ ${lanes.join("\n")} } function isExecutableStatement(s) { return !isFunctionDeclaration(s) && !isPurelyTypeDeclaration(s) && !isEnumDeclaration(s) && // `var x;` may declare a variable used above - !(isVariableStatement(s) && !(getCombinedNodeFlags(s) & (1 /* Let */ | 2 /* Const */)) && s.declarationList.declarations.some((d) => !d.initializer)); + !(isVariableStatement(s) && !(getCombinedNodeFlags(s) & 7 /* BlockScoped */) && s.declarationList.declarations.some((d) => !d.initializer)); } function isPurelyTypeDeclaration(s) { switch (s.kind) { - case 263 /* InterfaceDeclaration */: - case 264 /* TypeAliasDeclaration */: + case 264 /* InterfaceDeclaration */: + case 265 /* TypeAliasDeclaration */: return true; - case 266 /* ModuleDeclaration */: + case 267 /* ModuleDeclaration */: return getModuleInstanceState(s) !== 1 /* Instantiated */; - case 265 /* EnumDeclaration */: - return hasSyntacticModifier(s, 2048 /* Const */); + case 266 /* EnumDeclaration */: + return hasSyntacticModifier(s, 4096 /* Const */); default: return false; } @@ -143164,54 +126451,54 @@ ${lanes.join("\n")} } function getContainerFlags(node) { switch (node.kind) { - case 230 /* ClassExpression */: - case 262 /* ClassDeclaration */: - case 265 /* EnumDeclaration */: - case 209 /* ObjectLiteralExpression */: - case 186 /* TypeLiteral */: - case 328 /* JSDocTypeLiteral */: - case 291 /* JsxAttributes */: + case 231 /* ClassExpression */: + case 263 /* ClassDeclaration */: + case 266 /* EnumDeclaration */: + case 210 /* ObjectLiteralExpression */: + case 187 /* TypeLiteral */: + case 329 /* JSDocTypeLiteral */: + case 292 /* JsxAttributes */: return 1 /* IsContainer */; - case 263 /* InterfaceDeclaration */: + case 264 /* InterfaceDeclaration */: return 1 /* IsContainer */ | 64 /* IsInterface */; - case 266 /* ModuleDeclaration */: - case 264 /* TypeAliasDeclaration */: - case 199 /* MappedType */: - case 180 /* IndexSignature */: + case 267 /* ModuleDeclaration */: + case 265 /* TypeAliasDeclaration */: + case 200 /* MappedType */: + case 181 /* IndexSignature */: return 1 /* IsContainer */ | 32 /* HasLocals */; - case 311 /* SourceFile */: + case 312 /* SourceFile */: return 1 /* IsContainer */ | 4 /* IsControlFlowContainer */ | 32 /* HasLocals */; - case 176 /* GetAccessor */: - case 177 /* SetAccessor */: - case 173 /* MethodDeclaration */: + case 177 /* GetAccessor */: + case 178 /* SetAccessor */: + case 174 /* MethodDeclaration */: if (isObjectLiteralOrClassExpressionMethodOrAccessor(node)) { return 1 /* IsContainer */ | 4 /* IsControlFlowContainer */ | 32 /* HasLocals */ | 8 /* IsFunctionLike */ | 128 /* IsObjectLiteralOrClassExpressionMethodOrAccessor */; } - case 175 /* Constructor */: - case 261 /* FunctionDeclaration */: - case 172 /* MethodSignature */: - case 178 /* CallSignature */: - case 329 /* JSDocSignature */: - case 323 /* JSDocFunctionType */: - case 183 /* FunctionType */: - case 179 /* ConstructSignature */: - case 184 /* ConstructorType */: - case 174 /* ClassStaticBlockDeclaration */: + case 176 /* Constructor */: + case 262 /* FunctionDeclaration */: + case 173 /* MethodSignature */: + case 179 /* CallSignature */: + case 330 /* JSDocSignature */: + case 324 /* JSDocFunctionType */: + case 184 /* FunctionType */: + case 180 /* ConstructSignature */: + case 185 /* ConstructorType */: + case 175 /* ClassStaticBlockDeclaration */: return 1 /* IsContainer */ | 4 /* IsControlFlowContainer */ | 32 /* HasLocals */ | 8 /* IsFunctionLike */; - case 217 /* FunctionExpression */: - case 218 /* ArrowFunction */: + case 218 /* FunctionExpression */: + case 219 /* ArrowFunction */: return 1 /* IsContainer */ | 4 /* IsControlFlowContainer */ | 32 /* HasLocals */ | 8 /* IsFunctionLike */ | 16 /* IsFunctionExpression */; - case 267 /* ModuleBlock */: + case 268 /* ModuleBlock */: return 4 /* IsControlFlowContainer */; - case 171 /* PropertyDeclaration */: + case 172 /* PropertyDeclaration */: return node.initializer ? 4 /* IsControlFlowContainer */ : 0; - case 298 /* CatchClause */: - case 247 /* ForStatement */: - case 248 /* ForInStatement */: - case 249 /* ForOfStatement */: - case 268 /* CaseBlock */: + case 299 /* CatchClause */: + case 248 /* ForStatement */: + case 249 /* ForInStatement */: + case 250 /* ForOfStatement */: + case 269 /* CaseBlock */: return 2 /* IsBlockScopedContainer */ | 32 /* HasLocals */; - case 240 /* Block */: + case 241 /* Block */: return isFunctionLike(node.parent) || isClassStaticBlockDeclaration(node.parent) ? 0 /* None */ : 2 /* IsBlockScopedContainer */ | 32 /* HasLocals */; } return 0 /* None */; @@ -143229,7 +126516,7 @@ ${lanes.join("\n")} return (_d = (_c = container.symbol) == null ? void 0 : _c.exports) == null ? void 0 : _d.get(name); } } - var ModuleInstanceState, binder; + var ModuleInstanceState, ContainerFlags, binder; var init_binder = __esm({ "src/compiler/binder.ts"() { "use strict"; @@ -143241,6 +126528,18 @@ ${lanes.join("\n")} ModuleInstanceState2[ModuleInstanceState2["ConstEnumOnly"] = 2] = "ConstEnumOnly"; return ModuleInstanceState2; })(ModuleInstanceState || {}); + ContainerFlags = /* @__PURE__ */ ((ContainerFlags2) => { + ContainerFlags2[ContainerFlags2["None"] = 0] = "None"; + ContainerFlags2[ContainerFlags2["IsContainer"] = 1] = "IsContainer"; + ContainerFlags2[ContainerFlags2["IsBlockScopedContainer"] = 2] = "IsBlockScopedContainer"; + ContainerFlags2[ContainerFlags2["IsControlFlowContainer"] = 4] = "IsControlFlowContainer"; + ContainerFlags2[ContainerFlags2["IsFunctionLike"] = 8] = "IsFunctionLike"; + ContainerFlags2[ContainerFlags2["IsFunctionExpression"] = 16] = "IsFunctionExpression"; + ContainerFlags2[ContainerFlags2["HasLocals"] = 32] = "HasLocals"; + ContainerFlags2[ContainerFlags2["IsInterface"] = 64] = "IsInterface"; + ContainerFlags2[ContainerFlags2["IsObjectLiteralOrClassExpressionMethodOrAccessor"] = 128] = "IsObjectLiteralOrClassExpressionMethodOrAccessor"; + return ContainerFlags2; + })(ContainerFlags || {}); binder = /* @__PURE__ */ createBinder(); } }); @@ -143387,7 +126686,7 @@ ${lanes.join("\n")} symbol.exports.forEach(visitSymbol); } forEach(symbol.declarations, (d) => { - if (d.type && d.type.kind === 185 /* TypeQuery */) { + if (d.type && d.type.kind === 186 /* TypeQuery */) { const query = d.type; const entity = getResolvedSymbol(getFirstIdentifier2(query.exprName)); visitSymbol(entity); @@ -143461,20 +126760,17 @@ ${lanes.join("\n")} function getNodeModulesPackageName(compilerOptions, importingSourceFile, nodeModulesFileName, host, preferences, options = {}) { const info = getInfo(importingSourceFile.path, host); const modulePaths = getAllModulePaths(importingSourceFile.path, nodeModulesFileName, host, preferences, options); - return firstDefined( - modulePaths, - (modulePath) => tryGetModuleNameAsNodeModule( - modulePath, - info, - importingSourceFile, - host, - compilerOptions, - preferences, - /*packageNameOnly*/ - true, - options.overrideImportMode - ) - ); + return firstDefined(modulePaths, (modulePath) => tryGetModuleNameAsNodeModule( + modulePath, + info, + importingSourceFile, + host, + compilerOptions, + preferences, + /*packageNameOnly*/ + true, + options.overrideImportMode + )); } function getModuleSpecifierWorker(compilerOptions, importingSourceFile, importingSourceFileName, toFileName2, host, preferences, userPreferences, options = {}) { const info = getInfo(importingSourceFileName, host); @@ -143518,10 +126814,12 @@ ${lanes.join("\n")} importingSourceFile, host, userPreferences, - options + options, + /*forAutoImport*/ + false ).moduleSpecifiers; } - function getModuleSpecifiersWithCacheInfo(moduleSymbol, checker, compilerOptions, importingSourceFile, host, userPreferences, options = {}) { + function getModuleSpecifiersWithCacheInfo(moduleSymbol, checker, compilerOptions, importingSourceFile, host, userPreferences, options = {}, forAutoImport) { let computedWithoutCache = false; const ambient = tryGetModuleNameFromAmbientModule(moduleSymbol, checker); if (ambient) @@ -143539,11 +126837,19 @@ ${lanes.join("\n")} return { moduleSpecifiers: emptyArray, computedWithoutCache }; computedWithoutCache = true; modulePaths || (modulePaths = getAllModulePathsWorker(importingSourceFile.path, moduleSourceFile.originalFileName, host)); - const result = computeModuleSpecifiers(modulePaths, compilerOptions, importingSourceFile, host, userPreferences, options); + const result = computeModuleSpecifiers( + modulePaths, + compilerOptions, + importingSourceFile, + host, + userPreferences, + options, + forAutoImport + ); cache == null ? void 0 : cache.set(importingSourceFile.path, moduleSourceFile.path, userPreferences, options, modulePaths, result); return { moduleSpecifiers: result, computedWithoutCache }; } - function computeModuleSpecifiers(modulePaths, compilerOptions, importingSourceFile, host, userPreferences, options = {}) { + function computeModuleSpecifiers(modulePaths, compilerOptions, importingSourceFile, host, userPreferences, options = {}, forAutoImport) { const info = getInfo(importingSourceFile.path, host); const preferences = getPreferences(userPreferences, compilerOptions, importingSourceFile); const existingSpecifier = forEach(modulePaths, (modulePath) => forEach( @@ -143600,7 +126906,7 @@ ${lanes.join("\n")} redirectPathsSpecifiers = append(redirectPathsSpecifiers, local); } else if (pathIsBareSpecifier(local)) { pathsSpecifiers = append(pathsSpecifiers, local); - } else if (!importedFileIsInNodeModules || modulePath.isInNodeModules) { + } else if (forAutoImport || !importedFileIsInNodeModules || modulePath.isInNodeModules) { relativeSpecifiers = append(relativeSpecifiers, local); } } @@ -143741,7 +127047,15 @@ ${lanes.join("\n")} /*preferSymlinks*/ true, (path, isRedirect) => { - const isInNodeModules = pathContainsNodeModules(path); + let isInNodeModules = pathContainsNodeModules(path); + const pnpapi = getPnpApi(path); + if (!isInNodeModules && pnpapi) { + const fromLocator = pnpapi.findPackageLocator(importingFileName); + const toLocator = pnpapi.findPackageLocator(path); + if (fromLocator && toLocator && fromLocator !== toLocator) { + isInNodeModules = true; + } + } allFileNames.set(path, { path: getCanonicalFileName(path), isRedirect, isInNodeModules }); importedFileFromNodeModules = importedFileFromNodeModules || isInNodeModules; } @@ -143783,32 +127097,29 @@ ${lanes.join("\n")} if (decl) { return decl.name.text; } - const ambientModuleDeclareCandidates = mapDefined( - moduleSymbol.declarations, - (d) => { - var _a2, _b, _c, _d; - if (!isModuleDeclaration(d)) - return; - const topNamespace = getTopNamespace(d); - if (!(((_a2 = topNamespace == null ? void 0 : topNamespace.parent) == null ? void 0 : _a2.parent) && isModuleBlock(topNamespace.parent) && isAmbientModule(topNamespace.parent.parent) && isSourceFile(topNamespace.parent.parent.parent))) - return; - const exportAssignment = (_d = (_c = (_b = topNamespace.parent.parent.symbol.exports) == null ? void 0 : _b.get("export=")) == null ? void 0 : _c.valueDeclaration) == null ? void 0 : _d.expression; - if (!exportAssignment) - return; - const exportSymbol = checker.getSymbolAtLocation(exportAssignment); - if (!exportSymbol) - return; - const originalExportSymbol = (exportSymbol == null ? void 0 : exportSymbol.flags) & 2097152 /* Alias */ ? checker.getAliasedSymbol(exportSymbol) : exportSymbol; - if (originalExportSymbol === d.symbol) - return topNamespace.parent.parent; - function getTopNamespace(namespaceDeclaration) { - while (namespaceDeclaration.flags & 4 /* NestedNamespace */) { - namespaceDeclaration = namespaceDeclaration.parent; - } - return namespaceDeclaration; + const ambientModuleDeclareCandidates = mapDefined(moduleSymbol.declarations, (d) => { + var _a2, _b, _c, _d; + if (!isModuleDeclaration(d)) + return; + const topNamespace = getTopNamespace(d); + if (!(((_a2 = topNamespace == null ? void 0 : topNamespace.parent) == null ? void 0 : _a2.parent) && isModuleBlock(topNamespace.parent) && isAmbientModule(topNamespace.parent.parent) && isSourceFile(topNamespace.parent.parent.parent))) + return; + const exportAssignment = (_d = (_c = (_b = topNamespace.parent.parent.symbol.exports) == null ? void 0 : _b.get("export=")) == null ? void 0 : _c.valueDeclaration) == null ? void 0 : _d.expression; + if (!exportAssignment) + return; + const exportSymbol = checker.getSymbolAtLocation(exportAssignment); + if (!exportSymbol) + return; + const originalExportSymbol = (exportSymbol == null ? void 0 : exportSymbol.flags) & 2097152 /* Alias */ ? checker.getAliasedSymbol(exportSymbol) : exportSymbol; + if (originalExportSymbol === d.symbol) + return topNamespace.parent.parent; + function getTopNamespace(namespaceDeclaration) { + while (namespaceDeclaration.flags & 8 /* NestedNamespace */) { + namespaceDeclaration = namespaceDeclaration.parent; } + return namespaceDeclaration; } - ); + }); const ambientModuleDeclare = ambientModuleDeclareCandidates[0]; if (ambientModuleDeclare) { return ambientModuleDeclare.name.text; @@ -143832,7 +127143,9 @@ ${lanes.join("\n")} for (const { ending, value } of candidates) { if (value.length >= prefix.length + suffix.length && startsWith(value, prefix) && endsWith(value, suffix) && validateEnding({ ending, value })) { const matchedStar = value.substring(prefix.length, value.length - suffix.length); - return pathIsRelative(matchedStar) ? void 0 : key.replace("*", matchedStar); + if (!pathIsRelative(matchedStar)) { + return key.replace("*", matchedStar); + } } } } else if (some(candidates, (c) => c.ending !== 0 /* Minimal */ && pattern === c.value) || some(candidates, (c) => c.ending === 0 /* Minimal */ && pattern === c.value && validateEnding(c))) { @@ -143897,14 +127210,14 @@ ${lanes.join("\n")} /*currentDirectory*/ void 0 ); - const mode2 = endsWith(k, "/") ? 1 /* Directory */ : stringContains(k, "*") ? 2 /* Pattern */ : 0 /* Exact */; + const mode2 = endsWith(k, "/") ? 1 /* Directory */ : k.includes("*") ? 2 /* Pattern */ : 0 /* Exact */; return tryGetModuleNameFromExports(options, targetFilePath, packageDirectory, subPackageName, exports[k], conditions, mode2); }); } else { for (const key of getOwnKeys(exports)) { - if (key === "default" || conditions.indexOf(key) >= 0 || isApplicableVersionedTypesKey(conditions, key)) { + if (key === "default" || conditions.includes(key) || isApplicableVersionedTypesKey(conditions, key)) { const subTarget = exports[key]; - const result = tryGetModuleNameFromExports(options, targetFilePath, packageDirectory, packageName, subTarget, conditions); + const result = tryGetModuleNameFromExports(options, targetFilePath, packageDirectory, packageName, subTarget, conditions, mode); if (result) { return result; } @@ -143933,7 +127246,41 @@ ${lanes.join("\n")} if (!host.fileExists || !host.readFile) { return void 0; } - const parts = getNodeModulePathParts(path); + let parts = getNodeModulePathParts(path); + let pnpPackageName; + const pnpApi = getPnpApi(path); + if (pnpApi) { + const fromLocator = pnpApi.findPackageLocator(importingSourceFile.fileName); + const toLocator = pnpApi.findPackageLocator(path); + if (fromLocator === toLocator) { + return void 0; + } + if (fromLocator && toLocator) { + const fromInfo = pnpApi.getPackageInformation(fromLocator); + if (toLocator.reference === fromInfo.packageDependencies.get(toLocator.name)) { + pnpPackageName = toLocator.name; + } else { + for (const [name, reference] of fromInfo.packageDependencies) { + if (Array.isArray(reference)) { + if (reference[0] === toLocator.name && reference[1] === toLocator.reference) { + pnpPackageName = name; + break; + } + } + } + } + if (!parts) { + const toInfo = pnpApi.getPackageInformation(toLocator); + parts = { + topLevelNodeModulesIndex: void 0, + topLevelPackageNameIndex: void 0, + // The last character from packageLocation is the trailing "/", we want to point to it + packageRootIndex: toInfo.packageLocation.length - 1, + fileNameIndex: path.lastIndexOf(`/`) + }; + } + } + } if (!parts) { return void 0; } @@ -143971,14 +127318,16 @@ ${lanes.join("\n")} if (isRedirect && !isPackageRootPath) { return void 0; } - const globalTypingsCacheLocation = host.getGlobalTypingsCacheLocation && host.getGlobalTypingsCacheLocation(); - const pathToTopLevelNodeModules = getCanonicalFileName(moduleSpecifier.substring(0, parts.topLevelNodeModulesIndex)); - if (!(startsWith(sourceDirectory, pathToTopLevelNodeModules) || globalTypingsCacheLocation && startsWith(getCanonicalFileName(globalTypingsCacheLocation), pathToTopLevelNodeModules))) { - return void 0; + if (typeof process.versions.pnp === "undefined") { + const globalTypingsCacheLocation = host.getGlobalTypingsCacheLocation && host.getGlobalTypingsCacheLocation(); + const pathToTopLevelNodeModules = getCanonicalFileName(moduleSpecifier.substring(0, parts.topLevelNodeModulesIndex)); + if (!(startsWith(sourceDirectory, pathToTopLevelNodeModules) || globalTypingsCacheLocation && startsWith(getCanonicalFileName(globalTypingsCacheLocation), pathToTopLevelNodeModules))) { + return void 0; + } } - const nodeModulesDirectoryName = moduleSpecifier.substring(parts.topLevelPackageNameIndex + 1); - const packageName = getPackageNameFromTypesPackageName(nodeModulesDirectoryName); - return getEmitModuleResolutionKind(options) === 1 /* Classic */ && packageName === nodeModulesDirectoryName ? void 0 : packageName; + const nodeModulesDirectoryName = typeof pnpPackageName !== "undefined" ? pnpPackageName + moduleSpecifier.substring(parts.packageRootIndex) : moduleSpecifier.substring(parts.topLevelPackageNameIndex + 1); + const packageNameFromPath = getPackageNameFromTypesPackageName(nodeModulesDirectoryName); + return getEmitModuleResolutionKind(options) === 1 /* Classic */ && packageNameFromPath === nodeModulesDirectoryName ? void 0 : packageNameFromPath; function tryDirectoryWithPackageJson(packageRootIndex) { var _a, _b; const packageRootPath = path.substring(0, packageRootIndex); @@ -143991,9 +127340,9 @@ ${lanes.join("\n")} const importMode = overrideMode || importingSourceFile.impliedNodeFormat; if (getResolvePackageJsonExports(options)) { const nodeModulesDirectoryName2 = packageRootPath.substring(parts.topLevelPackageNameIndex + 1); - const packageName2 = getPackageNameFromTypesPackageName(nodeModulesDirectoryName2); - const conditions = getConditions(options, importMode === 99 /* ESNext */); - const fromExports = packageJsonContent.exports ? tryGetModuleNameFromExports(options, path, packageRootPath, packageName2, packageJsonContent.exports, conditions) : void 0; + const packageName = getPackageNameFromTypesPackageName(pnpPackageName ? pnpPackageName : nodeModulesDirectoryName2); + const conditions = getConditions(options, importMode); + const fromExports = packageJsonContent.exports ? tryGetModuleNameFromExports(options, path, packageRootPath, packageName, packageJsonContent.exports, conditions) : void 0; if (fromExports) { const withJsExtension = !hasTSFileExtension(fromExports.moduleFileToTry) ? fromExports : { moduleFileToTry: removeFileExtension(fromExports.moduleFileToTry) + tryGetJSExtensionForFile(fromExports.moduleFileToTry, options) }; return { ...withJsExtension, verbatimFromExports: true }; @@ -144068,7 +127417,7 @@ ${lanes.join("\n")} return fileName; } else if (fileExtensionIsOneOf(fileName, [".d.mts" /* Dmts */, ".mts" /* Mts */, ".d.cts" /* Dcts */, ".cts" /* Cts */])) { return noExtension + getJSExtensionForFile(fileName, options); - } else if (!fileExtensionIsOneOf(fileName, [".d.ts" /* Dts */]) && fileExtensionIsOneOf(fileName, [".ts" /* Ts */]) && stringContains(fileName, ".d.")) { + } else if (!fileExtensionIsOneOf(fileName, [".d.ts" /* Dts */]) && fileExtensionIsOneOf(fileName, [".ts" /* Ts */]) && fileName.includes(".d.")) { return tryGetRealFileNameForNonJsDeclarationFileName(fileName); } switch (allowedEndings[0]) { @@ -144094,7 +127443,7 @@ ${lanes.join("\n")} } function tryGetRealFileNameForNonJsDeclarationFileName(fileName) { const baseName = getBaseFileName(fileName); - if (!endsWith(fileName, ".ts" /* Ts */) || !stringContains(baseName, ".d.") || fileExtensionIsOneOf(baseName, [".d.ts" /* Dts */])) + if (!endsWith(fileName, ".ts" /* Ts */) || !baseName.includes(".d.") || fileExtensionIsOneOf(baseName, [".d.ts" /* Dts */])) return void 0; const noExtension = removeExtension(fileName, ".ts" /* Ts */); const ext = noExtension.substring(noExtension.lastIndexOf(".")); @@ -144145,6 +127494,7 @@ ${lanes.join("\n")} "src/compiler/moduleSpecifiers.ts"() { "use strict"; init_ts2(); + init_pnp(); } }); @@ -144202,7 +127552,7 @@ ${lanes.join("\n")} var externalHelpersModule; var Symbol47 = objectAllocator.getSymbolConstructor(); var Type27 = objectAllocator.getTypeConstructor(); - var Signature15 = objectAllocator.getSignatureConstructor(); + var Signature14 = objectAllocator.getSignatureConstructor(); var typeCount = 0; var symbolCount = 0; var totalInstantiationCount = 0; @@ -144219,6 +127569,7 @@ ${lanes.join("\n")} var moduleKind = getEmitModuleKind(compilerOptions); var legacyDecorators = !!compilerOptions.experimentalDecorators; var useDefineForClassFields = getUseDefineForClassFields(compilerOptions); + var emitStandardClassFields = getEmitStandardClassFields(compilerOptions); var allowSyntheticDefaultImports = getAllowSyntheticDefaultImports(compilerOptions); var strictNullChecks = getStrictOptionValue(compilerOptions, "strictNullChecks"); var strictFunctionTypes = getStrictOptionValue(compilerOptions, "strictFunctionTypes"); @@ -144246,6 +127597,10 @@ ${lanes.join("\n")} var isolatedModulesLikeFlagName = compilerOptions.verbatimModuleSyntax ? "verbatimModuleSyntax" : "isolatedModules"; var canCollectSymbolAliasAccessabilityData = !compilerOptions.verbatimModuleSyntax || !!compilerOptions.importsNotUsedAsValues; var apparentArgumentCount; + var lastGetCombinedNodeFlagsNode; + var lastGetCombinedNodeFlagsResult = 0 /* None */; + var lastGetCombinedModifierFlagsNode; + var lastGetCombinedModifierFlagsResult = 0 /* None */; const checker = { getNodeCount: () => reduceLeft(host.getSourceFiles(), (n, s) => n + s.nodeCount, 0), getIdentifierCount: () => reduceLeft(host.getSourceFiles(), (n, s) => n + s.identifierCount, 0), @@ -144305,7 +127660,7 @@ ${lanes.join("\n")} return node ? getTypeFromTypeNode(node) : errorType; }, getParameterType: getTypeAtPosition, - getParameterIdentifierNameAtPosition, + getParameterIdentifierInfoAtPosition, getPromisedTypeOfPromise, getAwaitedType: (type) => getAwaitedType(type), getReturnTypeOfSignature, @@ -144423,13 +127778,7 @@ ${lanes.join("\n")} getTypeOfPropertyOfContextualType, getFullyQualifiedName, getResolvedSignature: (node, candidatesOutArray, argumentCount) => getResolvedSignatureWorker(node, candidatesOutArray, argumentCount, 0 /* Normal */), - getResolvedSignatureForStringLiteralCompletions: (call, editingArgument, candidatesOutArray) => runWithInferenceBlockedFromSourceNode(editingArgument, () => getResolvedSignatureWorker( - call, - candidatesOutArray, - /*argumentCount*/ - void 0, - 32 /* IsForStringLiteralArgumentCompletions */ - )), + getCandidateSignaturesForStringLiteralCompletions, getResolvedSignatureForSignatureHelp: (node, candidatesOutArray, argumentCount) => runWithoutResolvedSignatureCaching(node, () => getResolvedSignatureWorker(node, candidatesOutArray, argumentCount, 16 /* IsForSignatureHelp */)), getExpandedParameters, hasEffectiveRestParameter, @@ -144603,7 +127952,7 @@ ${lanes.join("\n")} Debug.assert(!!(getNodeLinks(file).flags & 1 /* TypeChecked */)); diagnostics2 = addRange(diagnostics2, suggestionDiagnostics.getDiagnostics(file.fileName)); checkUnusedIdentifiers(getPotentiallyUnusedIdentifiers(file), (containingNode, kind, diag2) => { - if (!containsParseError(containingNode) && !unusedIsError(kind, !!(containingNode.flags & 16777216 /* Ambient */))) { + if (!containsParseError(containingNode) && !unusedIsError(kind, !!(containingNode.flags & 33554432 /* Ambient */))) { (diagnostics2 || (diagnostics2 = [])).push({ ...diag2, category: 2 /* Suggestion */ }); } }); @@ -144628,17 +127977,59 @@ ${lanes.join("\n")} isTypeParameterPossiblyReferenced, typeHasCallOrConstructSignatures }; - function runWithoutResolvedSignatureCaching(node, fn) { - const containingCall = findAncestor(node, isCallLikeExpression); - const containingCallResolvedSignature = containingCall && getNodeLinks(containingCall).resolvedSignature; - if (containingCall) { - getNodeLinks(containingCall).resolvedSignature = void 0; + function getCandidateSignaturesForStringLiteralCompletions(call, editingArgument) { + const candidatesSet = /* @__PURE__ */ new Set(); + const candidates = []; + runWithInferenceBlockedFromSourceNode(editingArgument, () => getResolvedSignatureWorker( + call, + candidates, + /*argumentCount*/ + void 0, + 0 /* Normal */ + )); + for (const candidate of candidates) { + candidatesSet.add(candidate); } - const result = fn(); - if (containingCall) { - getNodeLinks(containingCall).resolvedSignature = containingCallResolvedSignature; + candidates.length = 0; + runWithoutResolvedSignatureCaching(editingArgument, () => getResolvedSignatureWorker( + call, + candidates, + /*argumentCount*/ + void 0, + 0 /* Normal */ + )); + for (const candidate of candidates) { + candidatesSet.add(candidate); } - return result; + return arrayFrom(candidatesSet); + } + function runWithoutResolvedSignatureCaching(node, fn) { + node = findAncestor(node, isCallLikeOrFunctionLikeExpression); + if (node) { + const cachedResolvedSignatures = []; + const cachedTypes2 = []; + while (node) { + const nodeLinks2 = getNodeLinks(node); + cachedResolvedSignatures.push([nodeLinks2, nodeLinks2.resolvedSignature]); + nodeLinks2.resolvedSignature = void 0; + if (isFunctionExpressionOrArrowFunction(node)) { + const symbolLinks2 = getSymbolLinks(getSymbolOfDeclaration(node)); + const type = symbolLinks2.type; + cachedTypes2.push([symbolLinks2, type]); + symbolLinks2.type = void 0; + } + node = findAncestor(node.parent, isCallLikeOrFunctionLikeExpression); + } + const result = fn(); + for (const [nodeLinks2, resolvedSignature] of cachedResolvedSignatures) { + nodeLinks2.resolvedSignature = resolvedSignature; + } + for (const [symbolLinks2, type] of cachedTypes2) { + symbolLinks2.type = type; + } + return result; + } + return fn(); } function runWithInferenceBlockedFromSourceNode(node, fn) { const containingCall = findAncestor(node, isCallLikeExpression); @@ -144690,28 +128081,72 @@ ${lanes.join("\n")} var resolvingSymbol = createSymbol(0, "__resolving__" /* Resolving */); var unresolvedSymbols = /* @__PURE__ */ new Map(); var errorTypes = /* @__PURE__ */ new Map(); + var seenIntrinsicNames = /* @__PURE__ */ new Set(); var anyType = createIntrinsicType(1 /* Any */, "any"); - var autoType = createIntrinsicType(1 /* Any */, "any", 262144 /* NonInferrableType */); - var wildcardType = createIntrinsicType(1 /* Any */, "any"); + var autoType = createIntrinsicType(1 /* Any */, "any", 262144 /* NonInferrableType */, "auto"); + var wildcardType = createIntrinsicType( + 1 /* Any */, + "any", + /*objectFlags*/ + void 0, + "wildcard" + ); + var blockedStringType = createIntrinsicType( + 1 /* Any */, + "any", + /*objectFlags*/ + void 0, + "blocked string" + ); var errorType = createIntrinsicType(1 /* Any */, "error"); var unresolvedType = createIntrinsicType(1 /* Any */, "unresolved"); - var nonInferrableAnyType = createIntrinsicType(1 /* Any */, "any", 65536 /* ContainsWideningType */); + var nonInferrableAnyType = createIntrinsicType(1 /* Any */, "any", 65536 /* ContainsWideningType */, "non-inferrable"); var intrinsicMarkerType = createIntrinsicType(1 /* Any */, "intrinsic"); var unknownType = createIntrinsicType(2 /* Unknown */, "unknown"); - var nonNullUnknownType = createIntrinsicType(2 /* Unknown */, "unknown"); + var nonNullUnknownType = createIntrinsicType( + 2 /* Unknown */, + "unknown", + /*objectFlags*/ + void 0, + "non-null" + ); var undefinedType = createIntrinsicType(32768 /* Undefined */, "undefined"); - var undefinedWideningType = strictNullChecks ? undefinedType : createIntrinsicType(32768 /* Undefined */, "undefined", 65536 /* ContainsWideningType */); - var missingType = createIntrinsicType(32768 /* Undefined */, "undefined"); + var undefinedWideningType = strictNullChecks ? undefinedType : createIntrinsicType(32768 /* Undefined */, "undefined", 65536 /* ContainsWideningType */, "widening"); + var missingType = createIntrinsicType( + 32768 /* Undefined */, + "undefined", + /*objectFlags*/ + void 0, + "missing" + ); var undefinedOrMissingType = exactOptionalPropertyTypes ? missingType : undefinedType; - var optionalType = createIntrinsicType(32768 /* Undefined */, "undefined"); + var optionalType = createIntrinsicType( + 32768 /* Undefined */, + "undefined", + /*objectFlags*/ + void 0, + "optional" + ); var nullType = createIntrinsicType(65536 /* Null */, "null"); - var nullWideningType = strictNullChecks ? nullType : createIntrinsicType(65536 /* Null */, "null", 65536 /* ContainsWideningType */); + var nullWideningType = strictNullChecks ? nullType : createIntrinsicType(65536 /* Null */, "null", 65536 /* ContainsWideningType */, "widening"); var stringType = createIntrinsicType(4 /* String */, "string"); var numberType = createIntrinsicType(8 /* Number */, "number"); var bigintType = createIntrinsicType(64 /* BigInt */, "bigint"); - var falseType = createIntrinsicType(512 /* BooleanLiteral */, "false"); + var falseType = createIntrinsicType( + 512 /* BooleanLiteral */, + "false", + /*objectFlags*/ + void 0, + "fresh" + ); var regularFalseType = createIntrinsicType(512 /* BooleanLiteral */, "false"); - var trueType = createIntrinsicType(512 /* BooleanLiteral */, "true"); + var trueType = createIntrinsicType( + 512 /* BooleanLiteral */, + "true", + /*objectFlags*/ + void 0, + "fresh" + ); var regularTrueType = createIntrinsicType(512 /* BooleanLiteral */, "true"); trueType.regularType = regularTrueType; trueType.freshType = trueType; @@ -144725,9 +128160,21 @@ ${lanes.join("\n")} var esSymbolType = createIntrinsicType(4096 /* ESSymbol */, "symbol"); var voidType = createIntrinsicType(16384 /* Void */, "void"); var neverType = createIntrinsicType(131072 /* Never */, "never"); - var silentNeverType = createIntrinsicType(131072 /* Never */, "never", 262144 /* NonInferrableType */); - var implicitNeverType = createIntrinsicType(131072 /* Never */, "never"); - var unreachableNeverType = createIntrinsicType(131072 /* Never */, "never"); + var silentNeverType = createIntrinsicType(131072 /* Never */, "never", 262144 /* NonInferrableType */, "silent"); + var implicitNeverType = createIntrinsicType( + 131072 /* Never */, + "never", + /*objectFlags*/ + void 0, + "implicit" + ); + var unreachableNeverType = createIntrinsicType( + 131072 /* Never */, + "never", + /*objectFlags*/ + void 0, + "unreachable" + ); var nonPrimitiveType = createIntrinsicType(67108864 /* NonPrimitive */, "object"); var stringOrNumberType = getUnionType([stringType, numberType]); var stringNumberSymbolType = getUnionType([stringType, numberType, esSymbolType]); @@ -144737,7 +128184,13 @@ ${lanes.join("\n")} var numericStringType = getTemplateLiteralType(["", ""], [numberType]); var restrictiveMapper = makeFunctionTypeMapper((t) => t.flags & 262144 /* TypeParameter */ ? getRestrictiveTypeParameter(t) : t, () => "(restrictive mapper)"); var permissiveMapper = makeFunctionTypeMapper((t) => t.flags & 262144 /* TypeParameter */ ? wildcardType : t, () => "(permissive mapper)"); - var uniqueLiteralType = createIntrinsicType(131072 /* Never */, "never"); + var uniqueLiteralType = createIntrinsicType( + 131072 /* Never */, + "never", + /*objectFlags*/ + void 0, + "unique literal" + ); var uniqueLiteralMapper = makeFunctionTypeMapper((t) => t.flags & 262144 /* TypeParameter */ ? uniqueLiteralType : t, () => "(unique literal mapper)"); var outofbandVarianceMarkerHandler; var reportUnreliableMapper = makeFunctionTypeMapper((t) => { @@ -144942,7 +128395,7 @@ ${lanes.join("\n")} }; var amalgamatedDuplicates; var reverseMappedCache = /* @__PURE__ */ new Map(); - var inInferTypeForHomomorphicMappedType = false; + var homomorphicMappedTypeInferenceStack = []; var ambientModulesCache; var patternAmbientModules; var patternAmbientModuleAugmentations; @@ -144983,6 +128436,8 @@ ${lanes.join("\n")} var deferredGlobalImportMetaType; var deferredGlobalImportMetaExpressionType; var deferredGlobalImportCallOptionsType; + var deferredGlobalDisposableType; + var deferredGlobalAsyncDisposableType; var deferredGlobalExtractSymbol; var deferredGlobalOmitSymbol; var deferredGlobalAwaitedSymbol; @@ -145154,14 +128609,14 @@ ${lanes.join("\n")} } } function errorSkippedOn(key, location, message, ...args) { - const diagnostic = error(location, message, ...args); + const diagnostic = error2(location, message, ...args); diagnostic.skippedOn = key; return diagnostic; } function createError(location, message, ...args) { return location ? createDiagnosticForNode(location, message, ...args) : createCompilerDiagnostic(message, ...args); } - function error(location, message, ...args) { + function error2(location, message, ...args) { const diagnostic = createError(location, message, ...args); diagnostics.add(diagnostic); return diagnostic; @@ -145185,7 +128640,7 @@ ${lanes.join("\n")} addErrorOrSuggestion(isError, "message" in message ? createDiagnosticForNode(location, message, ...args) : createDiagnosticForNodeFromMessageChain(getSourceFileOfNode(location), location, message)); } function errorAndMaybeSuggestAwait(location, maybeMissingAwait, message, ...args) { - const diagnostic = error(location, message, ...args); + const diagnostic = error2(location, message, ...args); if (maybeMissingAwait) { const related = createDiagnosticForNode(location, Diagnostics.Did_you_forget_to_use_await); addRelatedInfo(diagnostic, related); @@ -145211,7 +128666,7 @@ ${lanes.join("\n")} return !!symbol.valueDeclaration && isDeprecatedDeclaration2(symbol.valueDeclaration) || length(symbol.declarations) && every(symbol.declarations, isDeprecatedDeclaration2); } function isDeprecatedDeclaration2(declaration) { - return !!(getCombinedNodeFlags(declaration) & 268435456 /* Deprecated */); + return !!(getCombinedNodeFlagsCached(declaration) & 536870912 /* Deprecated */); } function addDeprecatedSuggestion(location, declarations, deprecatedEntity) { const diagnostic = createDiagnosticForNode(location, Diagnostics._0_is_deprecated, deprecatedEntity); @@ -145331,7 +128786,7 @@ ${lanes.join("\n")} } } else if (target.flags & 1024 /* NamespaceModule */) { if (target !== globalThisSymbol) { - error( + error2( source.declarations && getNameOfDeclaration(source.declarations[0]), Diagnostics.Cannot_augment_module_0_with_value_exports_because_it_resolves_to_a_non_module_entity, symbolToString(target) @@ -145425,7 +128880,7 @@ ${lanes.join("\n")} if (isGlobalScopeAugmentation(moduleAugmentation)) { mergeSymbolTable(globals, moduleAugmentation.symbol.exports); } else { - const moduleNotFoundError = !(moduleName.parent.parent.flags & 16777216 /* Ambient */) ? Diagnostics.Invalid_module_name_in_augmentation_module_0_cannot_be_found : void 0; + const moduleNotFoundError = !(moduleName.parent.parent.flags & 33554432 /* Ambient */) ? Diagnostics.Invalid_module_name_in_augmentation_module_0_cannot_be_found : void 0; let mainModule = resolveExternalModuleNameWorker( moduleName, moduleName, @@ -145461,7 +128916,7 @@ ${lanes.join("\n")} mergeSymbol(mainModule, moduleAugmentation.symbol); } } else { - error(moduleName, Diagnostics.Cannot_augment_module_0_because_it_resolves_to_a_non_module_entity, moduleName.text); + error2(moduleName, Diagnostics.Cannot_augment_module_0_because_it_resolves_to_a_non_module_entity, moduleName.text); } } } @@ -145489,7 +128944,7 @@ ${lanes.join("\n")} return nodeLinks[nodeId] || (nodeLinks[nodeId] = new NodeLinks()); } function isGlobalSourceFile(node) { - return node.kind === 311 /* SourceFile */ && !isExternalOrCommonJsModule(node); + return node.kind === 312 /* SourceFile */ && !isExternalOrCommonJsModule(node); } function getSymbol2(symbols, name, meaning) { if (meaning) { @@ -145500,7 +128955,7 @@ ${lanes.join("\n")} return symbol; } if (symbol.flags & 2097152 /* Alias */) { - const targetFlags = getAllSymbolFlags(symbol); + const targetFlags = getSymbolFlags(symbol); if (targetFlags & meaning) { return symbol; } @@ -145523,7 +128978,7 @@ ${lanes.join("\n")} const useFile = getSourceFileOfNode(usage); const declContainer = getEnclosingBlockScopeContainer(declaration); if (declarationFile !== useFile) { - if (moduleKind && (declarationFile.externalModuleIndicator || useFile.externalModuleIndicator) || !outFile(compilerOptions) || isInTypeQuery(usage) || declaration.flags & 16777216 /* Ambient */) { + if (moduleKind && (declarationFile.externalModuleIndicator || useFile.externalModuleIndicator) || !outFile(compilerOptions) || isInTypeQuery(usage) || declaration.flags & 33554432 /* Ambient */) { return true; } if (isUsedInFunctionOrInstanceProperty(usage, declaration)) { @@ -145532,14 +128987,17 @@ ${lanes.join("\n")} const sourceFiles = host.getSourceFiles(); return sourceFiles.indexOf(declarationFile) <= sourceFiles.indexOf(useFile); } + if (!!(usage.flags & 16777216 /* JSDoc */) || isInTypeQuery(usage) || isInAmbientOrTypeNode(usage)) { + return true; + } if (declaration.pos <= usage.pos && !(isPropertyDeclaration(declaration) && isThisProperty(usage.parent) && !declaration.initializer && !declaration.exclamationToken)) { - if (declaration.kind === 207 /* BindingElement */) { - const errorBindingElement = getAncestor(usage, 207 /* BindingElement */); + if (declaration.kind === 208 /* BindingElement */) { + const errorBindingElement = getAncestor(usage, 208 /* BindingElement */); if (errorBindingElement) { return findAncestor(errorBindingElement, isBindingElement) !== findAncestor(declaration, isBindingElement) || declaration.pos < errorBindingElement.pos; } - return isBlockScopedNameDeclaredBeforeUse(getAncestor(declaration, 259 /* VariableDeclaration */), usage); - } else if (declaration.kind === 259 /* VariableDeclaration */) { + return isBlockScopedNameDeclaredBeforeUse(getAncestor(declaration, 260 /* VariableDeclaration */), usage); + } else if (declaration.kind === 260 /* VariableDeclaration */) { return !isImmediatelyUsedInInitializerOfBlockScopedVariable(declaration, usage); } else if (isClassDeclaration(declaration)) { return !findAncestor(usage, (n) => isComputedPropertyName(n) && n.parent.parent === declaration); @@ -145551,21 +129009,18 @@ ${lanes.join("\n")} false ); } else if (isParameterPropertyDeclaration(declaration, declaration.parent)) { - return !(getEmitScriptTarget(compilerOptions) === 99 /* ESNext */ && useDefineForClassFields && getContainingClass(declaration) === getContainingClass(usage) && isUsedInFunctionOrInstanceProperty(usage, declaration)); + return !(emitStandardClassFields && getContainingClass(declaration) === getContainingClass(usage) && isUsedInFunctionOrInstanceProperty(usage, declaration)); } return true; } - if (usage.parent.kind === 280 /* ExportSpecifier */ || usage.parent.kind === 276 /* ExportAssignment */ && usage.parent.isExportEquals) { + if (usage.parent.kind === 281 /* ExportSpecifier */ || usage.parent.kind === 277 /* ExportAssignment */ && usage.parent.isExportEquals) { return true; } - if (usage.kind === 276 /* ExportAssignment */ && usage.isExportEquals) { - return true; - } - if (!!(usage.flags & 8388608 /* JSDoc */) || isInTypeQuery(usage) || isInAmbientOrTypeNode(usage)) { + if (usage.kind === 277 /* ExportAssignment */ && usage.isExportEquals) { return true; } if (isUsedInFunctionOrInstanceProperty(usage, declaration)) { - if (getEmitScriptTarget(compilerOptions) >= 9 /* ES2022 */ && useDefineForClassFields && getContainingClass(declaration) && (isPropertyDeclaration(declaration) || isParameterPropertyDeclaration(declaration, declaration.parent))) { + if (emitStandardClassFields && getContainingClass(declaration) && (isPropertyDeclaration(declaration) || isParameterPropertyDeclaration(declaration, declaration.parent))) { return !isPropertyImmediatelyReferencedWithinDeclaration( declaration, usage, @@ -145579,9 +129034,9 @@ ${lanes.join("\n")} return false; function isImmediatelyUsedInInitializerOfBlockScopedVariable(declaration2, usage2) { switch (declaration2.parent.parent.kind) { - case 242 /* VariableStatement */: - case 247 /* ForStatement */: - case 249 /* ForOfStatement */: + case 243 /* VariableStatement */: + case 248 /* ForStatement */: + case 250 /* ForOfStatement */: if (isSameScopeDescendentOf(usage2, declaration2, declContainer)) { return true; } @@ -145606,7 +129061,7 @@ ${lanes.join("\n")} const initializerOfProperty = propertyDeclaration.initializer === current; if (initializerOfProperty) { if (isStatic(current.parent)) { - if (declaration2.kind === 173 /* MethodDeclaration */) { + if (declaration2.kind === 174 /* MethodDeclaration */) { return true; } if (isPropertyDeclaration(declaration2) && getContainingClass(usage2) === getContainingClass(declaration2)) { @@ -145620,7 +129075,7 @@ ${lanes.join("\n")} } } } else { - const isDeclarationInstanceProperty = declaration2.kind === 171 /* PropertyDeclaration */ && !isStatic(declaration2); + const isDeclarationInstanceProperty = declaration2.kind === 172 /* PropertyDeclaration */ && !isStatic(declaration2); if (!isDeclarationInstanceProperty || getContainingClass(usage2) !== getContainingClass(declaration2)) { return true; } @@ -145639,15 +129094,15 @@ ${lanes.join("\n")} return "quit"; } switch (node.kind) { - case 218 /* ArrowFunction */: + case 219 /* ArrowFunction */: return true; - case 171 /* PropertyDeclaration */: + case 172 /* PropertyDeclaration */: return stopAtAnyPropertyDeclaration && (isPropertyDeclaration(declaration2) && node.parent === declaration2.parent || isParameterPropertyDeclaration(declaration2, declaration2.parent) && node.parent === declaration2.parent.parent) ? "quit" : true; - case 240 /* Block */: + case 241 /* Block */: switch (node.parent.kind) { - case 176 /* GetAccessor */: - case 173 /* MethodDeclaration */: - case 177 /* SetAccessor */: + case 177 /* GetAccessor */: + case 174 /* MethodDeclaration */: + case 178 /* SetAccessor */: return true; default: return false; @@ -145677,19 +129132,19 @@ ${lanes.join("\n")} } function requiresScopeChangeWorker(node) { switch (node.kind) { - case 218 /* ArrowFunction */: - case 217 /* FunctionExpression */: - case 261 /* FunctionDeclaration */: - case 175 /* Constructor */: + case 219 /* ArrowFunction */: + case 218 /* FunctionExpression */: + case 262 /* FunctionDeclaration */: + case 176 /* Constructor */: return false; - case 173 /* MethodDeclaration */: - case 176 /* GetAccessor */: - case 177 /* SetAccessor */: - case 302 /* PropertyAssignment */: + case 174 /* MethodDeclaration */: + case 177 /* GetAccessor */: + case 178 /* SetAccessor */: + case 303 /* PropertyAssignment */: return requiresScopeChangeWorker(node.name); - case 171 /* PropertyDeclaration */: + case 172 /* PropertyDeclaration */: if (hasStaticModifier(node)) { - return target < 99 /* ESNext */ || !useDefineForClassFields; + return !emitStandardClassFields; } return requiresScopeChangeWorker(node.name); default: @@ -145728,7 +129183,7 @@ ${lanes.join("\n")} if (name === "const" && isConstAssertion(location)) { return void 0; } - if (isModuleDeclaration(location) && lastLocation && location.name === lastLocation) { + if (isModuleOrEnumDeclaration(location) && lastLocation && location.name === lastLocation) { lastLocation = location; location = location.parent; } @@ -145736,17 +129191,17 @@ ${lanes.join("\n")} if (result = lookup(location.locals, name, meaning)) { let useResult = true; if (isFunctionLike(location) && lastLocation && lastLocation !== location.body) { - if (meaning & result.flags & 788968 /* Type */ && lastLocation.kind !== 326 /* JSDoc */) { - useResult = result.flags & 262144 /* TypeParameter */ ? lastLocation === location.type || lastLocation.kind === 168 /* Parameter */ || lastLocation.kind === 347 /* JSDocParameterTag */ || lastLocation.kind === 348 /* JSDocReturnTag */ || lastLocation.kind === 167 /* TypeParameter */ : false; + if (meaning & result.flags & 788968 /* Type */ && lastLocation.kind !== 327 /* JSDoc */) { + useResult = result.flags & 262144 /* TypeParameter */ ? lastLocation === location.type || lastLocation.kind === 169 /* Parameter */ || lastLocation.kind === 348 /* JSDocParameterTag */ || lastLocation.kind === 349 /* JSDocReturnTag */ || lastLocation.kind === 168 /* TypeParameter */ : false; } if (meaning & result.flags & 3 /* Variable */) { if (useOuterVariableScopeInParameter(result, location, lastLocation)) { useResult = false; } else if (result.flags & 1 /* FunctionScopedVariable */) { - useResult = lastLocation.kind === 168 /* Parameter */ || lastLocation === location.type && !!findAncestor(result.valueDeclaration, isParameter); + useResult = lastLocation.kind === 169 /* Parameter */ || lastLocation === location.type && !!findAncestor(result.valueDeclaration, isParameter); } } - } else if (location.kind === 193 /* ConditionalType */) { + } else if (location.kind === 194 /* ConditionalType */) { useResult = lastLocation === location.trueType; } if (useResult) { @@ -145758,13 +129213,13 @@ ${lanes.join("\n")} } withinDeferredContext = withinDeferredContext || getIsDeferredContext(location, lastLocation); switch (location.kind) { - case 311 /* SourceFile */: + case 312 /* SourceFile */: if (!isExternalOrCommonJsModule(location)) break; isInExternalModule = true; - case 266 /* ModuleDeclaration */: + case 267 /* ModuleDeclaration */: const moduleExports = ((_a = getSymbolOfDeclaration(location)) == null ? void 0 : _a.exports) || emptySymbols; - if (location.kind === 311 /* SourceFile */ || isModuleDeclaration(location) && location.flags & 16777216 /* Ambient */ && !isGlobalScopeAugmentation(location)) { + if (location.kind === 312 /* SourceFile */ || isModuleDeclaration(location) && location.flags & 33554432 /* Ambient */ && !isGlobalScopeAugmentation(location)) { if (result = moduleExports.get("default" /* Default */)) { const localSymbol = getLocalSymbolForExportDefault(result); if (localSymbol && result.flags & meaning && localSymbol.escapedName === name) { @@ -145773,7 +129228,7 @@ ${lanes.join("\n")} result = void 0; } const moduleExport = moduleExports.get(name); - if (moduleExport && moduleExport.flags === 2097152 /* Alias */ && (getDeclarationOfKind(moduleExport, 280 /* ExportSpecifier */) || getDeclarationOfKind(moduleExport, 279 /* NamespaceExport */))) { + if (moduleExport && moduleExport.flags === 2097152 /* Alias */ && (getDeclarationOfKind(moduleExport, 281 /* ExportSpecifier */) || getDeclarationOfKind(moduleExport, 280 /* NamespaceExport */))) { break; } } @@ -145785,10 +129240,10 @@ ${lanes.join("\n")} } } break; - case 265 /* EnumDeclaration */: + case 266 /* EnumDeclaration */: if (result = lookup(((_c = getSymbolOfDeclaration(location)) == null ? void 0 : _c.exports) || emptySymbols, name, meaning & 8 /* EnumMember */)) { - if (nameNotFoundMessage && getIsolatedModules(compilerOptions) && !(location.flags & 16777216 /* Ambient */) && getSourceFileOfNode(location) !== getSourceFileOfNode(result.valueDeclaration)) { - error( + if (nameNotFoundMessage && getIsolatedModules(compilerOptions) && !(location.flags & 33554432 /* Ambient */) && getSourceFileOfNode(location) !== getSourceFileOfNode(result.valueDeclaration)) { + error2( errorLocation, Diagnostics.Cannot_access_0_from_another_file_without_qualification_when_1_is_enabled_Use_2_instead, unescapeLeadingUnderscores(name), @@ -145799,7 +129254,7 @@ ${lanes.join("\n")} break loop; } break; - case 171 /* PropertyDeclaration */: + case 172 /* PropertyDeclaration */: if (!isStatic(location)) { const ctor = findConstructorDeclaration(location.parent); if (ctor && ctor.locals) { @@ -145810,9 +129265,9 @@ ${lanes.join("\n")} } } break; - case 262 /* ClassDeclaration */: - case 230 /* ClassExpression */: - case 263 /* InterfaceDeclaration */: + case 263 /* ClassDeclaration */: + case 231 /* ClassExpression */: + case 264 /* InterfaceDeclaration */: if (result = lookup(getSymbolOfDeclaration(location).members || emptySymbols, name, meaning & 788968 /* Type */)) { if (!isTypeParameterSymbolDeclaredInContainer(result, location)) { result = void 0; @@ -145820,7 +129275,7 @@ ${lanes.join("\n")} } if (lastLocation && isStatic(lastLocation)) { if (nameNotFoundMessage) { - error(errorLocation, Diagnostics.Static_members_cannot_reference_class_type_parameters); + error2(errorLocation, Diagnostics.Static_members_cannot_reference_class_type_parameters); } return void 0; } @@ -145834,43 +129289,43 @@ ${lanes.join("\n")} } } break; - case 232 /* ExpressionWithTypeArguments */: + case 233 /* ExpressionWithTypeArguments */: if (lastLocation === location.expression && location.parent.token === 96 /* ExtendsKeyword */) { const container = location.parent.parent; if (isClassLike(container) && (result = lookup(getSymbolOfDeclaration(container).members, name, meaning & 788968 /* Type */))) { if (nameNotFoundMessage) { - error(errorLocation, Diagnostics.Base_class_expressions_cannot_reference_class_type_parameters); + error2(errorLocation, Diagnostics.Base_class_expressions_cannot_reference_class_type_parameters); } return void 0; } } break; - case 166 /* ComputedPropertyName */: + case 167 /* ComputedPropertyName */: grandparent = location.parent.parent; - if (isClassLike(grandparent) || grandparent.kind === 263 /* InterfaceDeclaration */) { + if (isClassLike(grandparent) || grandparent.kind === 264 /* InterfaceDeclaration */) { if (result = lookup(getSymbolOfDeclaration(grandparent).members, name, meaning & 788968 /* Type */)) { if (nameNotFoundMessage) { - error(errorLocation, Diagnostics.A_computed_property_name_cannot_reference_a_type_parameter_from_its_containing_type); + error2(errorLocation, Diagnostics.A_computed_property_name_cannot_reference_a_type_parameter_from_its_containing_type); } return void 0; } } break; - case 218 /* ArrowFunction */: + case 219 /* ArrowFunction */: if (getEmitScriptTarget(compilerOptions) >= 2 /* ES2015 */) { break; } - case 173 /* MethodDeclaration */: - case 175 /* Constructor */: - case 176 /* GetAccessor */: - case 177 /* SetAccessor */: - case 261 /* FunctionDeclaration */: + case 174 /* MethodDeclaration */: + case 176 /* Constructor */: + case 177 /* GetAccessor */: + case 178 /* SetAccessor */: + case 262 /* FunctionDeclaration */: if (meaning & 3 /* Variable */ && name === "arguments") { result = argumentsSymbol; break loop; } break; - case 217 /* FunctionExpression */: + case 218 /* FunctionExpression */: if (meaning & 3 /* Variable */ && name === "arguments") { result = argumentsSymbol; break loop; @@ -145883,37 +129338,37 @@ ${lanes.join("\n")} } } break; - case 169 /* Decorator */: - if (location.parent && location.parent.kind === 168 /* Parameter */) { + case 170 /* Decorator */: + if (location.parent && location.parent.kind === 169 /* Parameter */) { location = location.parent; } - if (location.parent && (isClassElement(location.parent) || location.parent.kind === 262 /* ClassDeclaration */)) { + if (location.parent && (isClassElement(location.parent) || location.parent.kind === 263 /* ClassDeclaration */)) { location = location.parent; } break; - case 352 /* JSDocTypedefTag */: - case 344 /* JSDocCallbackTag */: - case 346 /* JSDocEnumTag */: + case 353 /* JSDocTypedefTag */: + case 345 /* JSDocCallbackTag */: + case 347 /* JSDocEnumTag */: const root = getJSDocRoot(location); if (root) { location = root.parent; } break; - case 168 /* Parameter */: + case 169 /* Parameter */: if (lastLocation && (lastLocation === location.initializer || lastLocation === location.name && isBindingPattern(lastLocation))) { if (!associatedDeclarationForContainingInitializerOrBindingName) { associatedDeclarationForContainingInitializerOrBindingName = location; } } break; - case 207 /* BindingElement */: + case 208 /* BindingElement */: if (lastLocation && (lastLocation === location.initializer || lastLocation === location.name && isBindingPattern(lastLocation))) { if (isParameterDeclaration(location) && !associatedDeclarationForContainingInitializerOrBindingName) { associatedDeclarationForContainingInitializerOrBindingName = location; } } break; - case 194 /* InferType */: + case 195 /* InferType */: if (meaning & 262144 /* TypeParameter */) { const parameterName = location.typeParameter.name; if (parameterName && name === parameterName.escapedText) { @@ -145922,7 +129377,7 @@ ${lanes.join("\n")} } } break; - case 280 /* ExportSpecifier */: + case 281 /* ExportSpecifier */: if (lastLocation && lastLocation === location.propertyName && location.parent.parent.moduleSpecifier) { location = location.parent.parent.parent; } @@ -145960,8 +129415,8 @@ ${lanes.join("\n")} } } function checkAndReportErrorForInvalidInitializer() { - if (propertyWithInvalidInitializer && !(useDefineForClassFields && getEmitScriptTarget(compilerOptions) >= 9 /* ES2022 */)) { - error( + if (propertyWithInvalidInitializer && !emitStandardClassFields) { + error2( errorLocation, errorLocation && propertyWithInvalidInitializer.type && textRangeContainsPositionInclusive(propertyWithInvalidInitializer.type, errorLocation.pos) ? Diagnostics.Type_of_instance_member_variable_0_cannot_reference_identifier_1_declared_in_the_constructor : Diagnostics.Initializer_of_instance_member_variable_0_cannot_reference_identifier_1_declared_in_the_constructor, declarationNameToString(propertyWithInvalidInitializer.name), @@ -145974,14 +129429,14 @@ ${lanes.join("\n")} if (!result) { if (nameNotFoundMessage) { addLazyDiagnostic(() => { - if (!errorLocation || errorLocation.parent.kind !== 330 /* JSDocLink */ && !checkAndReportErrorForMissingPrefix(errorLocation, name, nameArg) && // TODO: GH#18217 + if (!errorLocation || errorLocation.parent.kind !== 331 /* JSDocLink */ && !checkAndReportErrorForMissingPrefix(errorLocation, name, nameArg) && // TODO: GH#18217 !checkAndReportErrorForInvalidInitializer() && !checkAndReportErrorForExtendingInterface(errorLocation) && !checkAndReportErrorForUsingTypeAsNamespace(errorLocation, name, meaning) && !checkAndReportErrorForExportingPrimitiveType(errorLocation, name) && !checkAndReportErrorForUsingNamespaceAsTypeOrValue(errorLocation, name, meaning) && !checkAndReportErrorForUsingTypeAsValue(errorLocation, name, meaning) && !checkAndReportErrorForUsingValueAsType(errorLocation, name, meaning)) { let suggestion; let suggestedLib; if (nameArg) { suggestedLib = getSuggestedLibForNonExistentName(nameArg); if (suggestedLib) { - error(errorLocation, nameNotFoundMessage, diagnosticName(nameArg), suggestedLib); + error2(errorLocation, nameNotFoundMessage, diagnosticName(nameArg), suggestedLib); } } if (!suggestedLib && getSpellingSuggestions && suggestionCount < maximumSuggestionCount) { @@ -146010,7 +129465,7 @@ ${lanes.join("\n")} } } if (!suggestion && !suggestedLib && nameArg) { - error(errorLocation, nameNotFoundMessage, diagnosticName(nameArg)); + error2(errorLocation, nameNotFoundMessage, diagnosticName(nameArg)); } suggestionCount++; } @@ -146028,7 +129483,7 @@ ${lanes.join("\n")} checkResolvedBlockScopedVariable(exportOrLocalSymbol, errorLocation); } } - if (result && isInExternalModule && (meaning & 111551 /* Value */) === 111551 /* Value */ && !(originalLocation.flags & 8388608 /* JSDoc */)) { + if (result && isInExternalModule && (meaning & 111551 /* Value */) === 111551 /* Value */ && !(originalLocation.flags & 16777216 /* JSDoc */)) { const merged = getMergedSymbol(result); if (length(merged.declarations) && every(merged.declarations, (d) => isNamespaceExportDeclaration(d) || isSourceFile(d) && !!d.symbol.globalExports)) { errorOrSuggestion(!compilerOptions.allowUmdGlobalAccess, errorLocation, Diagnostics._0_refers_to_a_UMD_global_but_the_current_file_is_a_module_Consider_adding_an_import_instead, unescapeLeadingUnderscores(name)); @@ -146038,18 +129493,18 @@ ${lanes.join("\n")} const candidate = getMergedSymbol(getLateBoundSymbol(result)); const root = getRootDeclaration(associatedDeclarationForContainingInitializerOrBindingName); if (candidate === getSymbolOfDeclaration(associatedDeclarationForContainingInitializerOrBindingName)) { - error(errorLocation, Diagnostics.Parameter_0_cannot_reference_itself, declarationNameToString(associatedDeclarationForContainingInitializerOrBindingName.name)); + error2(errorLocation, Diagnostics.Parameter_0_cannot_reference_itself, declarationNameToString(associatedDeclarationForContainingInitializerOrBindingName.name)); } else if (candidate.valueDeclaration && candidate.valueDeclaration.pos > associatedDeclarationForContainingInitializerOrBindingName.pos && root.parent.locals && lookup(root.parent.locals, candidate.escapedName, meaning) === candidate) { - error(errorLocation, Diagnostics.Parameter_0_cannot_reference_identifier_1_declared_after_it, declarationNameToString(associatedDeclarationForContainingInitializerOrBindingName.name), declarationNameToString(errorLocation)); + error2(errorLocation, Diagnostics.Parameter_0_cannot_reference_identifier_1_declared_after_it, declarationNameToString(associatedDeclarationForContainingInitializerOrBindingName.name), declarationNameToString(errorLocation)); } } if (result && errorLocation && meaning & 111551 /* Value */ && result.flags & 2097152 /* Alias */ && !(result.flags & 111551 /* Value */) && !isValidTypeOnlyAliasUseSite(errorLocation)) { const typeOnlyDeclaration = getTypeOnlyAliasDeclaration(result, 111551 /* Value */); if (typeOnlyDeclaration) { - const message = typeOnlyDeclaration.kind === 280 /* ExportSpecifier */ || typeOnlyDeclaration.kind === 277 /* ExportDeclaration */ || typeOnlyDeclaration.kind === 279 /* NamespaceExport */ ? Diagnostics._0_cannot_be_used_as_a_value_because_it_was_exported_using_export_type : Diagnostics._0_cannot_be_used_as_a_value_because_it_was_imported_using_import_type; + const message = typeOnlyDeclaration.kind === 281 /* ExportSpecifier */ || typeOnlyDeclaration.kind === 278 /* ExportDeclaration */ || typeOnlyDeclaration.kind === 280 /* NamespaceExport */ ? Diagnostics._0_cannot_be_used_as_a_value_because_it_was_exported_using_export_type : Diagnostics._0_cannot_be_used_as_a_value_because_it_was_imported_using_import_type; const unescapedName = unescapeLeadingUnderscores(name); addTypeOnlyDeclarationRelatedInfo( - error(errorLocation, message, unescapedName), + error2(errorLocation, message, unescapedName), typeOnlyDeclaration, unescapedName ); @@ -146066,31 +129521,31 @@ ${lanes.join("\n")} diagnostic, createDiagnosticForNode( typeOnlyDeclaration, - typeOnlyDeclaration.kind === 280 /* ExportSpecifier */ || typeOnlyDeclaration.kind === 277 /* ExportDeclaration */ || typeOnlyDeclaration.kind === 279 /* NamespaceExport */ ? Diagnostics._0_was_exported_here : Diagnostics._0_was_imported_here, + typeOnlyDeclaration.kind === 281 /* ExportSpecifier */ || typeOnlyDeclaration.kind === 278 /* ExportDeclaration */ || typeOnlyDeclaration.kind === 280 /* NamespaceExport */ ? Diagnostics._0_was_exported_here : Diagnostics._0_was_imported_here, unescapedName ) ); } function getIsDeferredContext(location, lastLocation) { - if (location.kind !== 218 /* ArrowFunction */ && location.kind !== 217 /* FunctionExpression */) { - return isTypeQueryNode(location) || (isFunctionLikeDeclaration(location) || location.kind === 171 /* PropertyDeclaration */ && !isStatic(location)) && (!lastLocation || lastLocation !== location.name); + if (location.kind !== 219 /* ArrowFunction */ && location.kind !== 218 /* FunctionExpression */) { + return isTypeQueryNode(location) || (isFunctionLikeDeclaration(location) || location.kind === 172 /* PropertyDeclaration */ && !isStatic(location)) && (!lastLocation || lastLocation !== location.name); } if (lastLocation && lastLocation === location.name) { return false; } - if (location.asteriskToken || hasSyntacticModifier(location, 512 /* Async */)) { + if (location.asteriskToken || hasSyntacticModifier(location, 1024 /* Async */)) { return true; } return !getImmediatelyInvokedFunctionExpression(location); } function isSelfReferenceLocation(node) { switch (node.kind) { - case 261 /* FunctionDeclaration */: - case 262 /* ClassDeclaration */: - case 263 /* InterfaceDeclaration */: - case 265 /* EnumDeclaration */: - case 264 /* TypeAliasDeclaration */: - case 266 /* ModuleDeclaration */: + case 262 /* FunctionDeclaration */: + case 263 /* ClassDeclaration */: + case 264 /* InterfaceDeclaration */: + case 266 /* EnumDeclaration */: + case 265 /* TypeAliasDeclaration */: + case 267 /* ModuleDeclaration */: return true; default: return false; @@ -146102,7 +129557,7 @@ ${lanes.join("\n")} function isTypeParameterSymbolDeclaredInContainer(symbol, container) { if (symbol.declarations) { for (const decl of symbol.declarations) { - if (decl.kind === 167 /* TypeParameter */) { + if (decl.kind === 168 /* TypeParameter */) { const parent2 = isJSDocTemplateTag(decl.parent) ? getJSDocHost(decl.parent) : decl.parent; if (parent2 === container) { return !(isJSDocTemplateTag(decl.parent) && find(decl.parent.parent.tags, isJSDocTypeAlias)); @@ -146132,13 +129587,13 @@ ${lanes.join("\n")} } const constructorType = getTypeOfSymbol(classSymbol); if (getPropertyOfType(constructorType, name)) { - error(errorLocation, Diagnostics.Cannot_find_name_0_Did_you_mean_the_static_member_1_0, diagnosticName(nameArg), symbolToString(classSymbol)); + error2(errorLocation, Diagnostics.Cannot_find_name_0_Did_you_mean_the_static_member_1_0, diagnosticName(nameArg), symbolToString(classSymbol)); return true; } if (location === container && !isStatic(location)) { const instanceType = getDeclaredTypeOfSymbol(classSymbol).thisType; if (getPropertyOfType(instanceType, name)) { - error(errorLocation, Diagnostics.Cannot_find_name_0_Did_you_mean_the_instance_member_this_0, diagnosticName(nameArg)); + error2(errorLocation, Diagnostics.Cannot_find_name_0_Did_you_mean_the_instance_member_this_0, diagnosticName(nameArg)); return true; } } @@ -146155,7 +129610,7 @@ ${lanes.join("\n")} /*ignoreErrors*/ true )) { - error(errorLocation, Diagnostics.Cannot_extend_an_interface_0_Did_you_mean_implements, getTextOfNode(expression)); + error2(errorLocation, Diagnostics.Cannot_extend_an_interface_0_Did_you_mean_implements, getTextOfNode(expression)); return true; } return false; @@ -146163,9 +129618,9 @@ ${lanes.join("\n")} function getEntityNameForExtendingInterface(node) { switch (node.kind) { case 80 /* Identifier */: - case 210 /* PropertyAccessExpression */: + case 211 /* PropertyAccessExpression */: return node.parent ? getEntityNameForExtendingInterface(node.parent) : void 0; - case 232 /* ExpressionWithTypeArguments */: + case 233 /* ExpressionWithTypeArguments */: if (isEntityNameExpression(node.expression)) { return node.expression; } @@ -146194,7 +129649,7 @@ ${lanes.join("\n")} const propName = parent2.right.escapedText; const propType = getPropertyOfType(getDeclaredTypeOfSymbol(symbol), propName); if (propType) { - error( + error2( parent2, Diagnostics.Cannot_access_0_1_because_0_is_a_type_but_not_a_namespace_Did_you_mean_to_retrieve_the_type_of_the_property_1_in_0_with_0_1, unescapeLeadingUnderscores(name), @@ -146203,7 +129658,7 @@ ${lanes.join("\n")} return true; } } - error(errorLocation, Diagnostics._0_only_refers_to_a_type_but_is_being_used_as_a_namespace_here, unescapeLeadingUnderscores(name)); + error2(errorLocation, Diagnostics._0_only_refers_to_a_type_but_is_being_used_as_a_namespace_here, unescapeLeadingUnderscores(name)); return true; } } @@ -146223,7 +129678,7 @@ ${lanes.join("\n")} false )); if (symbol && !(symbol.flags & 1920 /* Namespace */)) { - error(errorLocation, Diagnostics._0_refers_to_a_value_but_is_being_used_as_a_type_here_Did_you_mean_typeof_0, unescapeLeadingUnderscores(name)); + error2(errorLocation, Diagnostics._0_refers_to_a_value_but_is_being_used_as_a_type_here_Did_you_mean_typeof_0, unescapeLeadingUnderscores(name)); return true; } } @@ -146233,8 +129688,8 @@ ${lanes.join("\n")} return name === "any" || name === "string" || name === "number" || name === "boolean" || name === "never" || name === "unknown"; } function checkAndReportErrorForExportingPrimitiveType(errorLocation, name) { - if (isPrimitiveTypeName(name) && errorLocation.parent.kind === 280 /* ExportSpecifier */) { - error(errorLocation, Diagnostics.Cannot_export_0_Only_local_declarations_can_be_exported_from_a_module, name); + if (isPrimitiveTypeName(name) && errorLocation.parent.kind === 281 /* ExportSpecifier */) { + error2(errorLocation, Diagnostics.Cannot_export_0_Only_local_declarations_can_be_exported_from_a_module, name); return true; } return false; @@ -146242,10 +129697,19 @@ ${lanes.join("\n")} function checkAndReportErrorForUsingTypeAsValue(errorLocation, name, meaning) { if (meaning & 111551 /* Value */) { if (isPrimitiveTypeName(name)) { - if (isExtendedByInterface(errorLocation)) { - error(errorLocation, Diagnostics.An_interface_cannot_extend_a_primitive_type_like_0_an_interface_can_only_extend_named_types_and_classes, unescapeLeadingUnderscores(name)); + const grandparent = errorLocation.parent.parent; + if (grandparent && grandparent.parent && isHeritageClause(grandparent)) { + const heritageKind = grandparent.token; + const containerKind = grandparent.parent.kind; + if (containerKind === 264 /* InterfaceDeclaration */ && heritageKind === 96 /* ExtendsKeyword */) { + error2(errorLocation, Diagnostics.An_interface_cannot_extend_a_primitive_type_like_0_It_can_only_extend_other_named_object_types, unescapeLeadingUnderscores(name)); + } else if (containerKind === 263 /* ClassDeclaration */ && heritageKind === 96 /* ExtendsKeyword */) { + error2(errorLocation, Diagnostics.A_class_cannot_extend_a_primitive_type_like_0_Classes_can_only_extend_constructable_values, unescapeLeadingUnderscores(name)); + } else if (containerKind === 263 /* ClassDeclaration */ && heritageKind === 119 /* ImplementsKeyword */) { + error2(errorLocation, Diagnostics.A_class_cannot_implement_a_primitive_type_like_0_It_can_only_implement_other_named_object_types, unescapeLeadingUnderscores(name)); + } } else { - error(errorLocation, Diagnostics._0_only_refers_to_a_type_but_is_being_used_as_a_value_here, unescapeLeadingUnderscores(name)); + error2(errorLocation, Diagnostics._0_only_refers_to_a_type_but_is_being_used_as_a_value_here, unescapeLeadingUnderscores(name)); } return true; } @@ -146260,31 +129724,21 @@ ${lanes.join("\n")} /*isUse*/ false )); - const allFlags = symbol && getAllSymbolFlags(symbol); + const allFlags = symbol && getSymbolFlags(symbol); if (symbol && allFlags !== void 0 && !(allFlags & 111551 /* Value */)) { const rawName = unescapeLeadingUnderscores(name); if (isES2015OrLaterConstructorName(name)) { - error(errorLocation, Diagnostics._0_only_refers_to_a_type_but_is_being_used_as_a_value_here_Do_you_need_to_change_your_target_library_Try_changing_the_lib_compiler_option_to_es2015_or_later, rawName); + error2(errorLocation, Diagnostics._0_only_refers_to_a_type_but_is_being_used_as_a_value_here_Do_you_need_to_change_your_target_library_Try_changing_the_lib_compiler_option_to_es2015_or_later, rawName); } else if (maybeMappedType(errorLocation, symbol)) { - error(errorLocation, Diagnostics._0_only_refers_to_a_type_but_is_being_used_as_a_value_here_Did_you_mean_to_use_1_in_0, rawName, rawName === "K" ? "P" : "K"); + error2(errorLocation, Diagnostics._0_only_refers_to_a_type_but_is_being_used_as_a_value_here_Did_you_mean_to_use_1_in_0, rawName, rawName === "K" ? "P" : "K"); } else { - error(errorLocation, Diagnostics._0_only_refers_to_a_type_but_is_being_used_as_a_value_here, rawName); + error2(errorLocation, Diagnostics._0_only_refers_to_a_type_but_is_being_used_as_a_value_here, rawName); } return true; } } return false; } - function isExtendedByInterface(node) { - const grandparent = node.parent.parent; - const parentOfGrandparent = grandparent.parent; - if (grandparent && parentOfGrandparent) { - const isExtending = isHeritageClause(grandparent) && grandparent.token === 96 /* ExtendsKeyword */; - const isInterface = isInterfaceDeclaration(parentOfGrandparent); - return isExtending && isInterface; - } - return false; - } function maybeMappedType(node, symbol) { const container = findAncestor(node.parent, (n) => isComputedPropertyName(n) || isPropertySignature(n) ? false : isTypeLiteralNode(n) || "quit"); if (container && container.members.length === 1) { @@ -146324,7 +129778,7 @@ ${lanes.join("\n")} false )); if (symbol) { - error( + error2( errorLocation, Diagnostics.Cannot_use_namespace_0_as_a_value, unescapeLeadingUnderscores(name) @@ -146344,7 +129798,7 @@ ${lanes.join("\n")} false )); if (symbol) { - error(errorLocation, Diagnostics.Cannot_use_namespace_0_as_a_type, unescapeLeadingUnderscores(name)); + error2(errorLocation, Diagnostics.Cannot_use_namespace_0_as_a_type, unescapeLeadingUnderscores(name)); return true; } } @@ -146357,40 +129811,37 @@ ${lanes.join("\n")} return; } const declaration = (_a = result.declarations) == null ? void 0 : _a.find( - (d) => isBlockOrCatchScoped(d) || isClassLike(d) || d.kind === 265 /* EnumDeclaration */ + (d) => isBlockOrCatchScoped(d) || isClassLike(d) || d.kind === 266 /* EnumDeclaration */ ); if (declaration === void 0) return Debug.fail("checkResolvedBlockScopedVariable could not find block-scoped declaration"); - if (!(declaration.flags & 16777216 /* Ambient */) && !isBlockScopedNameDeclaredBeforeUse(declaration, errorLocation)) { + if (!(declaration.flags & 33554432 /* Ambient */) && !isBlockScopedNameDeclaredBeforeUse(declaration, errorLocation)) { let diagnosticMessage; const declarationName = declarationNameToString(getNameOfDeclaration(declaration)); if (result.flags & 2 /* BlockScopedVariable */) { - diagnosticMessage = error(errorLocation, Diagnostics.Block_scoped_variable_0_used_before_its_declaration, declarationName); + diagnosticMessage = error2(errorLocation, Diagnostics.Block_scoped_variable_0_used_before_its_declaration, declarationName); } else if (result.flags & 32 /* Class */) { - diagnosticMessage = error(errorLocation, Diagnostics.Class_0_used_before_its_declaration, declarationName); + diagnosticMessage = error2(errorLocation, Diagnostics.Class_0_used_before_its_declaration, declarationName); } else if (result.flags & 256 /* RegularEnum */) { - diagnosticMessage = error(errorLocation, Diagnostics.Enum_0_used_before_its_declaration, declarationName); + diagnosticMessage = error2(errorLocation, Diagnostics.Enum_0_used_before_its_declaration, declarationName); } if (diagnosticMessage) { - addRelatedInfo( - diagnosticMessage, - createDiagnosticForNode(declaration, Diagnostics._0_is_declared_here, declarationName) - ); + addRelatedInfo(diagnosticMessage, createDiagnosticForNode(declaration, Diagnostics._0_is_declared_here, declarationName)); } } } function isSameScopeDescendentOf(initial, parent2, stopAt) { - return !!parent2 && !!findAncestor(initial, (n) => n === parent2 || (n === stopAt || isFunctionLike(n) && (!getImmediatelyInvokedFunctionExpression(n) || isAsyncFunction(n)) ? "quit" : false)); + return !!parent2 && !!findAncestor(initial, (n) => n === parent2 || (n === stopAt || isFunctionLike(n) && (!getImmediatelyInvokedFunctionExpression(n) || getFunctionFlags(n) & 3 /* AsyncGenerator */) ? "quit" : false)); } function getAnyImportSyntax(node) { switch (node.kind) { - case 270 /* ImportEqualsDeclaration */: + case 271 /* ImportEqualsDeclaration */: return node; - case 272 /* ImportClause */: + case 273 /* ImportClause */: return node.parent; - case 273 /* NamespaceImport */: + case 274 /* NamespaceImport */: return node.parent.parent; - case 275 /* ImportSpecifier */: + case 276 /* ImportSpecifier */: return node.parent.parent.parent; default: return void 0; @@ -146400,7 +129851,7 @@ ${lanes.join("\n")} return symbol.declarations && findLast(symbol.declarations, isAliasSymbolDeclaration2); } function isAliasSymbolDeclaration2(node) { - return node.kind === 270 /* ImportEqualsDeclaration */ || node.kind === 269 /* NamespaceExportDeclaration */ || node.kind === 272 /* ImportClause */ && !!node.name || node.kind === 273 /* NamespaceImport */ || node.kind === 279 /* NamespaceExport */ || node.kind === 275 /* ImportSpecifier */ || node.kind === 280 /* ExportSpecifier */ || node.kind === 276 /* ExportAssignment */ && exportAssignmentIsAlias(node) || isBinaryExpression(node) && getAssignmentDeclarationKind(node) === 2 /* ModuleExports */ && exportAssignmentIsAlias(node) || isAccessExpression(node) && isBinaryExpression(node.parent) && node.parent.left === node && node.parent.operatorToken.kind === 64 /* EqualsToken */ && isAliasableOrJsExpression(node.parent.right) || node.kind === 303 /* ShorthandPropertyAssignment */ || node.kind === 302 /* PropertyAssignment */ && isAliasableOrJsExpression(node.initializer) || node.kind === 259 /* VariableDeclaration */ && isVariableDeclarationInitializedToBareOrAccessedRequire(node) || node.kind === 207 /* BindingElement */ && isVariableDeclarationInitializedToBareOrAccessedRequire(node.parent.parent); + return node.kind === 271 /* ImportEqualsDeclaration */ || node.kind === 270 /* NamespaceExportDeclaration */ || node.kind === 273 /* ImportClause */ && !!node.name || node.kind === 274 /* NamespaceImport */ || node.kind === 280 /* NamespaceExport */ || node.kind === 276 /* ImportSpecifier */ || node.kind === 281 /* ExportSpecifier */ || node.kind === 277 /* ExportAssignment */ && exportAssignmentIsAlias(node) || isBinaryExpression(node) && getAssignmentDeclarationKind(node) === 2 /* ModuleExports */ && exportAssignmentIsAlias(node) || isAccessExpression(node) && isBinaryExpression(node.parent) && node.parent.left === node && node.parent.operatorToken.kind === 64 /* EqualsToken */ && isAliasableOrJsExpression(node.parent.right) || node.kind === 304 /* ShorthandPropertyAssignment */ || node.kind === 303 /* PropertyAssignment */ && isAliasableOrJsExpression(node.initializer) || node.kind === 260 /* VariableDeclaration */ && isVariableDeclarationInitializedToBareOrAccessedRequire(node) || node.kind === 208 /* BindingElement */ && isVariableDeclarationInitializedToBareOrAccessedRequire(node.parent.parent); } function isAliasableOrJsExpression(e) { return isAliasableExpression(e) || isFunctionExpression(e) && isJSConstructor(e); @@ -146411,7 +129862,7 @@ ${lanes.join("\n")} const name = getLeftmostAccessExpression(commonJSPropertyAccess.expression).arguments[0]; return isIdentifier(commonJSPropertyAccess.name) ? resolveSymbol(getPropertyOfType(resolveExternalModuleTypeByLiteral(name), commonJSPropertyAccess.name.escapedText)) : void 0; } - if (isVariableDeclaration(node) || node.moduleReference.kind === 282 /* ExternalModuleReference */) { + if (isVariableDeclaration(node) || node.moduleReference.kind === 283 /* ExternalModuleReference */) { const immediate = resolveExternalModuleName( node, getExternalModuleRequireArgument(node) || getExternalModuleImportEqualsDeclarationExpression(node) @@ -146440,11 +129891,11 @@ ${lanes.join("\n")} false ) && !node.isTypeOnly) { const typeOnlyDeclaration = getTypeOnlyAliasDeclaration(getSymbolOfDeclaration(node)); - const isExport = typeOnlyDeclaration.kind === 280 /* ExportSpecifier */ || typeOnlyDeclaration.kind === 277 /* ExportDeclaration */; + const isExport = typeOnlyDeclaration.kind === 281 /* ExportSpecifier */ || typeOnlyDeclaration.kind === 278 /* ExportDeclaration */; const message = isExport ? Diagnostics.An_import_alias_cannot_reference_a_declaration_that_was_exported_using_export_type : Diagnostics.An_import_alias_cannot_reference_a_declaration_that_was_imported_using_import_type; const relatedMessage = isExport ? Diagnostics._0_was_exported_here : Diagnostics._0_was_imported_here; - const name = typeOnlyDeclaration.kind === 277 /* ExportDeclaration */ ? "*" : unescapeLeadingUnderscores(typeOnlyDeclaration.name.escapedText); - addRelatedInfo(error(node.moduleReference, message), createDiagnosticForNode(typeOnlyDeclaration, relatedMessage, name)); + const name = typeOnlyDeclaration.kind === 278 /* ExportDeclaration */ ? "*" : unescapeLeadingUnderscores(typeOnlyDeclaration.name.escapedText); + addRelatedInfo(error2(node.moduleReference, message), createDiagnosticForNode(typeOnlyDeclaration, relatedMessage, name)); } } function resolveExportByName(moduleSymbol, name, sourceNode, dontResolveAlias) { @@ -146466,7 +129917,7 @@ ${lanes.join("\n")} return resolved; } function isSyntacticDefault(node) { - return isExportAssignment(node) && !node.isExportEquals || hasSyntacticModifier(node, 1024 /* Default */) || isExportSpecifier(node); + return isExportAssignment(node) && !node.isExportEquals || hasSyntacticModifier(node, 2048 /* Default */) || isExportSpecifier(node) || isNamespaceExport(node); } function getUsageModeForExpression(usage) { return isStringLiteralLike(usage) ? getModeForUsageLocation(getSourceFileOfNode(usage), usage) : void 0; @@ -146549,13 +130000,16 @@ ${lanes.join("\n")} const compilerOptionName = moduleKind >= 5 /* ES2015 */ ? "allowSyntheticDefaultImports" : "esModuleInterop"; const exportEqualsSymbol = moduleSymbol.exports.get("export=" /* ExportEquals */); const exportAssignment = exportEqualsSymbol.valueDeclaration; - const err = error(node.name, Diagnostics.Module_0_can_only_be_default_imported_using_the_1_flag, symbolToString(moduleSymbol), compilerOptionName); + const err = error2(node.name, Diagnostics.Module_0_can_only_be_default_imported_using_the_1_flag, symbolToString(moduleSymbol), compilerOptionName); if (exportAssignment) { - addRelatedInfo(err, createDiagnosticForNode( - exportAssignment, - Diagnostics.This_module_is_declared_with_export_and_can_only_be_used_with_a_default_import_when_using_the_0_flag, - compilerOptionName - )); + addRelatedInfo( + err, + createDiagnosticForNode( + exportAssignment, + Diagnostics.This_module_is_declared_with_export_and_can_only_be_used_with_a_default_import_when_using_the_0_flag, + compilerOptionName + ) + ); } } else if (isImportClause(node)) { reportNonDefaultExport(moduleSymbol, node); @@ -146585,15 +130039,15 @@ ${lanes.join("\n")} } function getModuleSpecifierForImportOrExport(node) { switch (node.kind) { - case 272 /* ImportClause */: + case 273 /* ImportClause */: return node.parent.moduleSpecifier; - case 270 /* ImportEqualsDeclaration */: + case 271 /* ImportEqualsDeclaration */: return isExternalModuleReference(node.moduleReference) ? node.moduleReference.expression : void 0; - case 273 /* NamespaceImport */: + case 274 /* NamespaceImport */: return node.parent.parent.moduleSpecifier; - case 275 /* ImportSpecifier */: + case 276 /* ImportSpecifier */: return node.parent.parent.parent.moduleSpecifier; - case 280 /* ExportSpecifier */: + case 281 /* ExportSpecifier */: return node.parent.parent.moduleSpecifier; default: return Debug.assertNever(node); @@ -146602,20 +130056,22 @@ ${lanes.join("\n")} function reportNonDefaultExport(moduleSymbol, node) { var _a, _b, _c; if ((_a = moduleSymbol.exports) == null ? void 0 : _a.has(node.symbol.escapedName)) { - error( + error2( node.name, Diagnostics.Module_0_has_no_default_export_Did_you_mean_to_use_import_1_from_0_instead, symbolToString(moduleSymbol), symbolToString(node.symbol) ); } else { - const diagnostic = error(node.name, Diagnostics.Module_0_has_no_default_export, symbolToString(moduleSymbol)); + const diagnostic = error2(node.name, Diagnostics.Module_0_has_no_default_export, symbolToString(moduleSymbol)); const exportStar = (_b = moduleSymbol.exports) == null ? void 0 : _b.get("__export" /* ExportStar */); if (exportStar) { - const defaultExport = (_c = exportStar.declarations) == null ? void 0 : _c.find((decl) => { - var _a2, _b2; - return !!(isExportDeclaration(decl) && decl.moduleSpecifier && ((_b2 = (_a2 = resolveExternalModuleName(decl, decl.moduleSpecifier)) == null ? void 0 : _a2.exports) == null ? void 0 : _b2.has("default" /* Default */))); - }); + const defaultExport = (_c = exportStar.declarations) == null ? void 0 : _c.find( + (decl) => { + var _a2, _b2; + return !!(isExportDeclaration(decl) && decl.moduleSpecifier && ((_b2 = (_a2 = resolveExternalModuleName(decl, decl.moduleSpecifier)) == null ? void 0 : _a2.exports) == null ? void 0 : _b2.has("default" /* Default */))); + } + ); if (defaultExport) { addRelatedInfo(diagnostic, createDiagnosticForNode(defaultExport, Diagnostics.export_Asterisk_does_not_re_export_a_default)); } @@ -146760,16 +130216,13 @@ ${lanes.join("\n")} const suggestion = getSuggestedSymbolForNonexistentModule(name, targetSymbol); if (suggestion !== void 0) { const suggestionName = symbolToString(suggestion); - const diagnostic = error(name, Diagnostics._0_has_no_exported_member_named_1_Did_you_mean_2, moduleName, declarationName, suggestionName); + const diagnostic = error2(name, Diagnostics._0_has_no_exported_member_named_1_Did_you_mean_2, moduleName, declarationName, suggestionName); if (suggestion.valueDeclaration) { - addRelatedInfo( - diagnostic, - createDiagnosticForNode(suggestion.valueDeclaration, Diagnostics._0_is_declared_here, suggestionName) - ); + addRelatedInfo(diagnostic, createDiagnosticForNode(suggestion.valueDeclaration, Diagnostics._0_is_declared_here, suggestionName)); } } else { if ((_a = moduleSymbol.exports) == null ? void 0 : _a.has("default" /* Default */)) { - error( + error2( name, Diagnostics.Module_0_has_no_exported_member_1_Did_you_mean_to_use_import_1_from_0_instead, moduleName, @@ -146787,32 +130240,29 @@ ${lanes.join("\n")} if (localSymbol) { const exportedEqualsSymbol = exports == null ? void 0 : exports.get("export=" /* ExportEquals */); if (exportedEqualsSymbol) { - getSymbolIfSameReference(exportedEqualsSymbol, localSymbol) ? reportInvalidImportEqualsExportMember(node, name, declarationName, moduleName) : error(name, Diagnostics.Module_0_has_no_exported_member_1, moduleName, declarationName); + getSymbolIfSameReference(exportedEqualsSymbol, localSymbol) ? reportInvalidImportEqualsExportMember(node, name, declarationName, moduleName) : error2(name, Diagnostics.Module_0_has_no_exported_member_1, moduleName, declarationName); } else { const exportedSymbol = exports ? find(symbolsToArray(exports), (symbol) => !!getSymbolIfSameReference(symbol, localSymbol)) : void 0; - const diagnostic = exportedSymbol ? error(name, Diagnostics.Module_0_declares_1_locally_but_it_is_exported_as_2, moduleName, declarationName, symbolToString(exportedSymbol)) : error(name, Diagnostics.Module_0_declares_1_locally_but_it_is_not_exported, moduleName, declarationName); + const diagnostic = exportedSymbol ? error2(name, Diagnostics.Module_0_declares_1_locally_but_it_is_exported_as_2, moduleName, declarationName, symbolToString(exportedSymbol)) : error2(name, Diagnostics.Module_0_declares_1_locally_but_it_is_not_exported, moduleName, declarationName); if (localSymbol.declarations) { - addRelatedInfo( - diagnostic, - ...map(localSymbol.declarations, (decl, index) => createDiagnosticForNode(decl, index === 0 ? Diagnostics._0_is_declared_here : Diagnostics.and_here, declarationName)) - ); + addRelatedInfo(diagnostic, ...map(localSymbol.declarations, (decl, index) => createDiagnosticForNode(decl, index === 0 ? Diagnostics._0_is_declared_here : Diagnostics.and_here, declarationName))); } } } else { - error(name, Diagnostics.Module_0_has_no_exported_member_1, moduleName, declarationName); + error2(name, Diagnostics.Module_0_has_no_exported_member_1, moduleName, declarationName); } } function reportInvalidImportEqualsExportMember(node, name, declarationName, moduleName) { if (moduleKind >= 5 /* ES2015 */) { const message = getESModuleInterop(compilerOptions) ? Diagnostics._0_can_only_be_imported_by_using_a_default_import : Diagnostics._0_can_only_be_imported_by_turning_on_the_esModuleInterop_flag_and_using_a_default_import; - error(name, message, declarationName); + error2(name, message, declarationName); } else { if (isInJSFile(node)) { const message = getESModuleInterop(compilerOptions) ? Diagnostics._0_can_only_be_imported_by_using_a_require_call_or_by_using_a_default_import : Diagnostics._0_can_only_be_imported_by_using_a_require_call_or_by_turning_on_the_esModuleInterop_flag_and_using_a_default_import; - error(name, message, declarationName); + error2(name, message, declarationName); } else { const message = getESModuleInterop(compilerOptions) ? Diagnostics._0_can_only_be_imported_by_using_import_1_require_2_or_a_default_import : Diagnostics._0_can_only_be_imported_by_using_import_1_require_2_or_by_turning_on_the_esModuleInterop_flag_and_using_a_default_import; - error(name, message, declarationName, declarationName, moduleName); + error2(name, message, declarationName, declarationName, moduleName); } } } @@ -146926,26 +130376,26 @@ ${lanes.join("\n")} } function getTargetOfAliasDeclaration(node, dontRecursivelyResolve = false) { switch (node.kind) { - case 270 /* ImportEqualsDeclaration */: - case 259 /* VariableDeclaration */: + case 271 /* ImportEqualsDeclaration */: + case 260 /* VariableDeclaration */: return getTargetOfImportEqualsDeclaration(node, dontRecursivelyResolve); - case 272 /* ImportClause */: + case 273 /* ImportClause */: return getTargetOfImportClause(node, dontRecursivelyResolve); - case 273 /* NamespaceImport */: + case 274 /* NamespaceImport */: return getTargetOfNamespaceImport(node, dontRecursivelyResolve); - case 279 /* NamespaceExport */: + case 280 /* NamespaceExport */: return getTargetOfNamespaceExport(node, dontRecursivelyResolve); - case 275 /* ImportSpecifier */: - case 207 /* BindingElement */: + case 276 /* ImportSpecifier */: + case 208 /* BindingElement */: return getTargetOfImportSpecifier(node, dontRecursivelyResolve); - case 280 /* ExportSpecifier */: + case 281 /* ExportSpecifier */: return getTargetOfExportSpecifier(node, 111551 /* Value */ | 788968 /* Type */ | 1920 /* Namespace */, dontRecursivelyResolve); - case 276 /* ExportAssignment */: - case 225 /* BinaryExpression */: + case 277 /* ExportAssignment */: + case 226 /* BinaryExpression */: return getTargetOfExportAssignment(node, dontRecursivelyResolve); - case 269 /* NamespaceExportDeclaration */: + case 270 /* NamespaceExportDeclaration */: return getTargetOfNamespaceExportDeclaration(node, dontRecursivelyResolve); - case 303 /* ShorthandPropertyAssignment */: + case 304 /* ShorthandPropertyAssignment */: return resolveEntityName( node.name, 111551 /* Value */ | 788968 /* Type */ | 1920 /* Namespace */, @@ -146953,10 +130403,10 @@ ${lanes.join("\n")} true, dontRecursivelyResolve ); - case 302 /* PropertyAssignment */: + case 303 /* PropertyAssignment */: return getTargetOfAliasLikeExpression(node.initializer, dontRecursivelyResolve); - case 211 /* ElementAccessExpression */: - case 210 /* PropertyAccessExpression */: + case 212 /* ElementAccessExpression */: + case 211 /* PropertyAccessExpression */: return getTargetOfAccessExpression(node, dontRecursivelyResolve); default: return Debug.fail(); @@ -146982,7 +130432,7 @@ ${lanes.join("\n")} if (links.aliasTarget === resolvingSymbol) { links.aliasTarget = target || unknownSymbol; } else { - error(node, Diagnostics.Circular_definition_of_import_alias_0, symbolToString(symbol)); + error2(node, Diagnostics.Circular_definition_of_import_alias_0, symbolToString(symbol)); } } else if (links.aliasTarget === resolvingSymbol) { links.aliasTarget = unknownSymbol; @@ -146996,11 +130446,23 @@ ${lanes.join("\n")} } return void 0; } - function getAllSymbolFlags(symbol) { - let flags = symbol.flags; + function getSymbolFlags(symbol, excludeTypeOnlyMeanings, excludeLocalMeanings) { + const typeOnlyDeclaration = excludeTypeOnlyMeanings && getTypeOnlyAliasDeclaration(symbol); + const typeOnlyDeclarationIsExportStar = typeOnlyDeclaration && isExportDeclaration(typeOnlyDeclaration); + const typeOnlyResolution = typeOnlyDeclaration && (typeOnlyDeclarationIsExportStar ? resolveExternalModuleName( + typeOnlyDeclaration.moduleSpecifier, + typeOnlyDeclaration.moduleSpecifier, + /*ignoreErrors*/ + true + ) : resolveAlias(typeOnlyDeclaration.symbol)); + const typeOnlyExportStarTargets = typeOnlyDeclarationIsExportStar && typeOnlyResolution ? getExportsOfModule(typeOnlyResolution) : void 0; + let flags = excludeLocalMeanings ? 0 /* None */ : symbol.flags; let seenSymbols; while (symbol.flags & 2097152 /* Alias */) { - const target = resolveAlias(symbol); + const target = getExportSymbolOfValueSymbolIfExported(resolveAlias(symbol)); + if (!typeOnlyDeclarationIsExportStar && target === typeOnlyResolution || (typeOnlyExportStarTargets == null ? void 0 : typeOnlyExportStarTargets.get(target.escapedName)) === target) { + break; + } if (target === unknownSymbol) { return 67108863 /* All */; } @@ -147057,8 +130519,8 @@ ${lanes.join("\n")} return links.typeOnlyDeclaration || void 0; } if (links.typeOnlyDeclaration) { - const resolved = links.typeOnlyDeclaration.kind === 277 /* ExportDeclaration */ ? resolveSymbol(getExportsOfModule(links.typeOnlyDeclaration.symbol.parent).get(links.typeOnlyExportStarName || symbol.escapedName)) : resolveAlias(links.typeOnlyDeclaration.symbol); - return getAllSymbolFlags(resolved) & include ? links.typeOnlyDeclaration : void 0; + const resolved = links.typeOnlyDeclaration.kind === 278 /* ExportDeclaration */ ? resolveSymbol(getExportsOfModule(links.typeOnlyDeclaration.symbol.parent).get(links.typeOnlyExportStarName || symbol.escapedName)) : resolveAlias(links.typeOnlyDeclaration.symbol); + return getSymbolFlags(resolved) & include ? links.typeOnlyDeclaration : void 0; } return void 0; } @@ -147069,7 +130531,11 @@ ${lanes.join("\n")} const symbol = getSymbolOfDeclaration(node); const target = resolveAlias(symbol); if (target) { - const markAlias = target === unknownSymbol || getAllSymbolFlags(target) & 111551 /* Value */ && !isConstEnumOrConstEnumOnlyModule(target) && !getTypeOnlyAliasDeclaration(symbol, 111551 /* Value */); + const markAlias = target === unknownSymbol || getSymbolFlags( + symbol, + /*excludeTypeOnlyMeanings*/ + true + ) & 111551 /* Value */ && !isConstEnumOrConstEnumOnlyModule(target); if (markAlias) { markAliasSymbolAsReferenced(symbol); } @@ -147084,7 +130550,7 @@ ${lanes.join("\n")} if (!node) return Debug.fail(); if (isInternalModuleImportEqualsDeclaration(node)) { - if (getAllSymbolFlags(resolveSymbol(symbol)) & 111551 /* Value */) { + if (getSymbolFlags(resolveSymbol(symbol)) & 111551 /* Value */) { checkExpressionCached(node.moduleReference); } } @@ -147100,7 +130566,7 @@ ${lanes.join("\n")} if (entityName.kind === 80 /* Identifier */ && isRightSideOfQualifiedNameOrPropertyAccess(entityName)) { entityName = entityName.parent; } - if (entityName.kind === 80 /* Identifier */ || entityName.parent.kind === 165 /* QualifiedName */) { + if (entityName.kind === 80 /* Identifier */ || entityName.parent.kind === 166 /* QualifiedName */) { return resolveEntityName( entityName, 1920 /* Namespace */, @@ -147109,7 +130575,7 @@ ${lanes.join("\n")} dontResolveAlias ); } else { - Debug.assert(entityName.parent.kind === 270 /* ImportEqualsDeclaration */); + Debug.assert(entityName.parent.kind === 271 /* ImportEqualsDeclaration */); return resolveEntityName( entityName, 111551 /* Value */ | 788968 /* Type */ | 1920 /* Namespace */, @@ -147182,9 +130648,9 @@ ${lanes.join("\n")} if (!symbol) { return getMergedSymbol(symbolFromJSPrototype); } - } else if (name.kind === 165 /* QualifiedName */ || name.kind === 210 /* PropertyAccessExpression */) { - const left = name.kind === 165 /* QualifiedName */ ? name.left : name.expression; - const right = name.kind === 165 /* QualifiedName */ ? name.right : name.name; + } else if (name.kind === 166 /* QualifiedName */ || name.kind === 211 /* PropertyAccessExpression */) { + const left = name.kind === 166 /* QualifiedName */ ? name.left : name.expression; + const right = name.kind === 166 /* QualifiedName */ ? name.right : name.name; let namespace = resolveEntityName( left, namespaceMeaning, @@ -147218,13 +130684,13 @@ ${lanes.join("\n")} const declarationName = declarationNameToString(right); const suggestionForNonexistentModule = getSuggestedSymbolForNonexistentModule(right, namespace); if (suggestionForNonexistentModule) { - error(right, Diagnostics._0_has_no_exported_member_named_1_Did_you_mean_2, namespaceName, declarationName, symbolToString(suggestionForNonexistentModule)); + error2(right, Diagnostics._0_has_no_exported_member_named_1_Did_you_mean_2, namespaceName, declarationName, symbolToString(suggestionForNonexistentModule)); return void 0; } const containingQualifiedName = isQualifiedName(name) && getContainingQualifiedNameNode(name); const canSuggestTypeof = globalObjectType && meaning & 788968 /* Type */ && containingQualifiedName && !isTypeOfExpression(containingQualifiedName.parent) && tryGetQualifiedNameAsValue(containingQualifiedName); if (canSuggestTypeof) { - error( + error2( containingQualifiedName, Diagnostics._0_refers_to_a_value_but_is_being_used_as_a_type_here_Did_you_mean_typeof_0, entityNameToString(containingQualifiedName) @@ -147234,7 +130700,7 @@ ${lanes.join("\n")} if (meaning & 1920 /* Namespace */ && isQualifiedName(name.parent)) { const exportedTypeSymbol = getMergedSymbol(getSymbol2(getExportsOfSymbol(namespace), right.escapedText, 788968 /* Type */)); if (exportedTypeSymbol) { - error( + error2( name.parent.right, Diagnostics.Cannot_access_0_1_because_0_is_a_type_but_not_a_namespace_Did_you_mean_to_retrieve_the_type_of_the_property_1_in_0_with_0_1, symbolToString(exportedTypeSymbol), @@ -147243,7 +130709,7 @@ ${lanes.join("\n")} return void 0; } } - error(right, Diagnostics.Namespace_0_has_no_exported_member_1, namespaceName, declarationName); + error2(right, Diagnostics.Namespace_0_has_no_exported_member_1, namespaceName, declarationName); } return void 0; } @@ -147251,7 +130717,7 @@ ${lanes.join("\n")} Debug.assertNever(name, "Unknown entity name kind."); } Debug.assert((getCheckFlags(symbol) & 1 /* Instantiated */) === 0, "Should never get an instantiated symbol here."); - if (!nodeIsSynthesized(name) && isEntityName(name) && (symbol.flags & 2097152 /* Alias */ || name.parent.kind === 276 /* ExportAssignment */)) { + if (!nodeIsSynthesized(name) && isEntityName(name) && (symbol.flags & 2097152 /* Alias */ || name.parent.kind === 277 /* ExportAssignment */)) { markSymbolOfAliasDeclarationIfTypeOnly( getAliasDeclarationFromName(name), symbol, @@ -147281,7 +130747,7 @@ ${lanes.join("\n")} } } function getAssignmentDeclarationLocation(node) { - const typeAlias = findAncestor(node, (node2) => !(isJSDocNode(node2) || node2.flags & 8388608 /* JSDoc */) ? "quit" : isJSDocTypeAlias(node2)); + const typeAlias = findAncestor(node, (node2) => !(isJSDocNode(node2) || node2.flags & 16777216 /* JSDoc */) ? "quit" : isJSDocTypeAlias(node2)); if (typeAlias) { return; } @@ -147344,11 +130810,11 @@ ${lanes.join("\n")} return isStringLiteralLike(moduleReferenceExpression) ? resolveExternalModule(location, moduleReferenceExpression.text, moduleNotFoundError, moduleReferenceExpression, isForAugmentation) : void 0; } function resolveExternalModule(location, moduleReference, moduleNotFoundError, errorNode, isForAugmentation = false) { - var _a, _b, _c, _d, _e, _f, _g, _h, _i; + var _a, _b, _c, _d, _e, _f, _g, _h, _i, _j; if (startsWith(moduleReference, "@types/")) { const diag2 = Diagnostics.Cannot_import_type_declaration_files_Consider_importing_0_instead_of_1; const withoutAtTypePrefix = removePrefix(moduleReference, "@types/"); - error(errorNode, diag2, withoutAtTypePrefix, moduleReference); + error2(errorNode, diag2, withoutAtTypePrefix, moduleReference); } const ambientModule = tryFindAmbientModule( moduleReference, @@ -147362,25 +130828,28 @@ ${lanes.join("\n")} const contextSpecifier = isStringLiteralLike(location) ? location : ((_a = findAncestor(location, isImportCall)) == null ? void 0 : _a.arguments[0]) || ((_b = findAncestor(location, isImportDeclaration)) == null ? void 0 : _b.moduleSpecifier) || ((_c = findAncestor(location, isExternalModuleImportEqualsDeclaration)) == null ? void 0 : _c.moduleReference.expression) || ((_d = findAncestor(location, isExportDeclaration)) == null ? void 0 : _d.moduleSpecifier) || ((_e = isModuleDeclaration(location) ? location : location.parent && isModuleDeclaration(location.parent) && location.parent.name === location ? location.parent : void 0) == null ? void 0 : _e.name) || ((_f = isLiteralImportTypeNode(location) ? location : void 0) == null ? void 0 : _f.argument.literal); const mode = contextSpecifier && isStringLiteralLike(contextSpecifier) ? getModeForUsageLocation(currentSourceFile, contextSpecifier) : currentSourceFile.impliedNodeFormat; const moduleResolutionKind = getEmitModuleResolutionKind(compilerOptions); - const resolvedModule = getResolvedModule(currentSourceFile, moduleReference, mode); + const resolvedModule = (_g = host.getResolvedModule(currentSourceFile, moduleReference, mode)) == null ? void 0 : _g.resolvedModule; const resolutionDiagnostic = resolvedModule && getResolutionDiagnostic(compilerOptions, resolvedModule, currentSourceFile); const sourceFile = resolvedModule && (!resolutionDiagnostic || resolutionDiagnostic === Diagnostics.Module_0_was_resolved_to_1_but_jsx_is_not_set) && host.getSourceFile(resolvedModule.resolvedFileName); if (sourceFile) { if (resolutionDiagnostic) { - error(errorNode, resolutionDiagnostic, moduleReference, resolvedModule.resolvedFileName); + error2(errorNode, resolutionDiagnostic, moduleReference, resolvedModule.resolvedFileName); } if (resolvedModule.resolvedUsingTsExtension && isDeclarationFileName(moduleReference)) { - const importOrExport = ((_g = findAncestor(location, isImportDeclaration)) == null ? void 0 : _g.importClause) || findAncestor(location, or(isImportEqualsDeclaration, isExportDeclaration)); + const importOrExport = ((_h = findAncestor(location, isImportDeclaration)) == null ? void 0 : _h.importClause) || findAncestor(location, or(isImportEqualsDeclaration, isExportDeclaration)); if (importOrExport && !importOrExport.isTypeOnly || findAncestor(location, isImportCall)) { - error( + error2( errorNode, Diagnostics.A_declaration_file_cannot_be_imported_without_import_type_Did_you_mean_to_import_an_implementation_file_0_instead, getSuggestedImportSource(Debug.checkDefined(tryExtractTSExtension(moduleReference))) ); } } else if (resolvedModule.resolvedUsingTsExtension && !shouldAllowImportingTsExtension(compilerOptions, currentSourceFile.fileName)) { - const tsExtension = Debug.checkDefined(tryExtractTSExtension(moduleReference)); - error(errorNode, Diagnostics.An_import_path_can_only_end_with_a_0_extension_when_allowImportingTsExtensions_is_enabled, tsExtension); + const importOrExport = ((_i = findAncestor(location, isImportDeclaration)) == null ? void 0 : _i.importClause) || findAncestor(location, or(isImportEqualsDeclaration, isExportDeclaration)); + if (!((importOrExport == null ? void 0 : importOrExport.isTypeOnly) || findAncestor(location, isImportTypeNode))) { + const tsExtension = Debug.checkDefined(tryExtractTSExtension(moduleReference)); + error2(errorNode, Diagnostics.An_import_path_can_only_end_with_a_0_extension_when_allowImportingTsExtensions_is_enabled, tsExtension); + } } if (sourceFile.symbol) { if (resolvedModule.isExternalLibraryImport && !resolutionExtensionIsTSOrJson(resolvedModule.extension)) { @@ -147396,11 +130865,10 @@ ${lanes.join("\n")} } if (moduleResolutionKind === 3 /* Node16 */ || moduleResolutionKind === 99 /* NodeNext */) { const isSyncImport = currentSourceFile.impliedNodeFormat === 1 /* CommonJS */ && !findAncestor(location, isImportCall) || !!findAncestor(location, isImportEqualsDeclaration); - const overrideClauseHost = findAncestor(location, (l) => isImportTypeNode(l) || isExportDeclaration(l) || isImportDeclaration(l)); - const overrideClause = overrideClauseHost && isImportTypeNode(overrideClauseHost) ? (_h = overrideClauseHost.assertions) == null ? void 0 : _h.assertClause : overrideClauseHost == null ? void 0 : overrideClauseHost.assertClause; - if (isSyncImport && sourceFile.impliedNodeFormat === 99 /* ESNext */ && !getResolutionModeOverrideForClause(overrideClause)) { + const overrideHost = findAncestor(location, (l) => isImportTypeNode(l) || isExportDeclaration(l) || isImportDeclaration(l)); + if (isSyncImport && sourceFile.impliedNodeFormat === 99 /* ESNext */ && !hasResolutionModeOverride(overrideHost)) { if (findAncestor(location, isImportEqualsDeclaration)) { - error(errorNode, Diagnostics.Module_0_cannot_be_imported_using_this_construct_The_specifier_only_resolves_to_an_ES_module_which_cannot_be_imported_with_require_Use_an_ECMAScript_import_instead, moduleReference); + error2(errorNode, Diagnostics.Module_0_cannot_be_imported_using_this_construct_The_specifier_only_resolves_to_an_ES_module_which_cannot_be_imported_with_require_Use_an_ECMAScript_import_instead, moduleReference); } else { let diagnosticDetails; const ext = tryGetExtensionFromPath2(currentSourceFile.fileName); @@ -147441,18 +130909,22 @@ ${lanes.join("\n")} } } } - diagnostics.add(createDiagnosticForNodeFromMessageChain(getSourceFileOfNode(errorNode), errorNode, chainDiagnosticMessages( - diagnosticDetails, - Diagnostics.The_current_file_is_a_CommonJS_module_whose_imports_will_produce_require_calls_however_the_referenced_file_is_an_ECMAScript_module_and_cannot_be_imported_with_require_Consider_writing_a_dynamic_import_0_call_instead, - moduleReference - ))); + diagnostics.add(createDiagnosticForNodeFromMessageChain( + getSourceFileOfNode(errorNode), + errorNode, + chainDiagnosticMessages( + diagnosticDetails, + Diagnostics.The_current_file_is_a_CommonJS_module_whose_imports_will_produce_require_calls_however_the_referenced_file_is_an_ECMAScript_module_and_cannot_be_imported_with_require_Consider_writing_a_dynamic_import_0_call_instead, + moduleReference + ) + )); } } } return getMergedSymbol(sourceFile.symbol); } if (moduleNotFoundError) { - error(errorNode, Diagnostics.File_0_is_not_a_module, sourceFile.fileName); + error2(errorNode, Diagnostics.File_0_is_not_a_module, sourceFile.fileName); } return void 0; } @@ -147469,7 +130941,7 @@ ${lanes.join("\n")} if (resolvedModule && !resolutionExtensionIsTSOrJson(resolvedModule.extension) && resolutionDiagnostic === void 0 || resolutionDiagnostic === Diagnostics.Could_not_find_a_declaration_file_for_module_0_1_implicitly_has_an_any_type) { if (isForAugmentation) { const diag2 = Diagnostics.Invalid_module_name_in_augmentation_Module_0_resolves_to_an_untyped_module_at_1_which_cannot_be_augmented; - error(errorNode, diag2, moduleReference, resolvedModule.resolvedFileName); + error2(errorNode, diag2, moduleReference, resolvedModule.resolvedFileName); } else { errorOnImplicitAnyModule( /*isError*/ @@ -147487,31 +130959,27 @@ ${lanes.join("\n")} if (resolvedModule) { const redirect = host.getProjectReferenceRedirect(resolvedModule.resolvedFileName); if (redirect) { - error(errorNode, Diagnostics.Output_file_0_has_not_been_built_from_source_file_1, redirect, resolvedModule.resolvedFileName); + error2(errorNode, Diagnostics.Output_file_0_has_not_been_built_from_source_file_1, redirect, resolvedModule.resolvedFileName); return void 0; } } if (resolutionDiagnostic) { - error(errorNode, resolutionDiagnostic, moduleReference, resolvedModule.resolvedFileName); + error2(errorNode, resolutionDiagnostic, moduleReference, resolvedModule.resolvedFileName); } else { const isExtensionlessRelativePathImport = pathIsRelative(moduleReference) && !hasExtension(moduleReference); const resolutionIsNode16OrNext = moduleResolutionKind === 3 /* Node16 */ || moduleResolutionKind === 99 /* NodeNext */; if (!getResolveJsonModule(compilerOptions) && fileExtensionIs(moduleReference, ".json" /* Json */) && moduleResolutionKind !== 1 /* Classic */ && hasJsonModuleEmitEnabled(compilerOptions)) { - error(errorNode, Diagnostics.Cannot_find_module_0_Consider_using_resolveJsonModule_to_import_module_with_json_extension, moduleReference); + error2(errorNode, Diagnostics.Cannot_find_module_0_Consider_using_resolveJsonModule_to_import_module_with_json_extension, moduleReference); } else if (mode === 99 /* ESNext */ && resolutionIsNode16OrNext && isExtensionlessRelativePathImport) { const absoluteRef = getNormalizedAbsolutePath(moduleReference, getDirectoryPath(currentSourceFile.path)); - const suggestedExt = (_i = suggestedExtensions.find(([actualExt, _importExt]) => host.fileExists(absoluteRef + actualExt))) == null ? void 0 : _i[1]; + const suggestedExt = (_j = suggestedExtensions.find(([actualExt, _importExt]) => host.fileExists(absoluteRef + actualExt))) == null ? void 0 : _j[1]; if (suggestedExt) { - error( - errorNode, - Diagnostics.Relative_import_paths_need_explicit_file_extensions_in_EcmaScript_imports_when_moduleResolution_is_node16_or_nodenext_Did_you_mean_0, - moduleReference + suggestedExt - ); + error2(errorNode, Diagnostics.Relative_import_paths_need_explicit_file_extensions_in_ECMAScript_imports_when_moduleResolution_is_node16_or_nodenext_Did_you_mean_0, moduleReference + suggestedExt); } else { - error(errorNode, Diagnostics.Relative_import_paths_need_explicit_file_extensions_in_EcmaScript_imports_when_moduleResolution_is_node16_or_nodenext_Consider_adding_an_extension_to_the_import_path); + error2(errorNode, Diagnostics.Relative_import_paths_need_explicit_file_extensions_in_ECMAScript_imports_when_moduleResolution_is_node16_or_nodenext_Consider_adding_an_extension_to_the_import_path); } } else { - error(errorNode, moduleNotFoundError, moduleReference); + error2(errorNode, moduleNotFoundError, moduleReference); } } } @@ -147531,12 +130999,16 @@ ${lanes.join("\n")} if (!isExternalModuleNameRelative(moduleReference) && packageId) { errorInfo = createModuleNotFoundChain(sourceFile, host, moduleReference, mode, packageId.name); } - errorOrSuggestion(isError, errorNode, chainDiagnosticMessages( - errorInfo, - Diagnostics.Could_not_find_a_declaration_file_for_module_0_1_implicitly_has_an_any_type, - moduleReference, - resolvedFileName - )); + errorOrSuggestion( + isError, + errorNode, + chainDiagnosticMessages( + errorInfo, + Diagnostics.Could_not_find_a_declaration_file_for_module_0_1_implicitly_has_an_any_type, + moduleReference, + resolvedFileName + ) + ); } function resolveExternalModuleSymbol(moduleSymbol, dontResolveAlias) { if (moduleSymbol == null ? void 0 : moduleSymbol.exports) { @@ -147575,9 +131047,9 @@ ${lanes.join("\n")} var _a; const symbol = resolveExternalModuleSymbol(moduleSymbol, dontResolveAlias); if (!dontResolveAlias && symbol) { - if (!suppressInteropError && !(symbol.flags & (1536 /* Module */ | 3 /* Variable */)) && !getDeclarationOfKind(symbol, 311 /* SourceFile */)) { + if (!suppressInteropError && !(symbol.flags & (1536 /* Module */ | 3 /* Variable */)) && !getDeclarationOfKind(symbol, 312 /* SourceFile */)) { const compilerOptionName = moduleKind >= 5 /* ES2015 */ ? "allowSyntheticDefaultImports" : "esModuleInterop"; - error(referencingLocation, Diagnostics.This_module_can_only_be_referenced_with_ECMAScript_imports_Slashexports_by_turning_on_the_0_flag_and_referencing_its_default_export, compilerOptionName); + error2(referencingLocation, Diagnostics.This_module_can_only_be_referenced_with_ECMAScript_imports_Slashexports_by_turning_on_the_0_flag_and_referencing_its_default_export, compilerOptionName); return symbol; } const referenceParent = referencingLocation.parent; @@ -147773,10 +131245,12 @@ ${lanes.join("\n")} } if (exportStar == null ? void 0 : exportStar.isTypeOnly) { typeOnlyExportStarMap ?? (typeOnlyExportStarMap = /* @__PURE__ */ new Map()); - symbols.forEach((_, escapedName) => typeOnlyExportStarMap.set( - escapedName, - exportStar - )); + symbols.forEach( + (_, escapedName) => typeOnlyExportStarMap.set( + escapedName, + exportStar + ) + ); } return symbols; } @@ -147932,12 +131406,12 @@ ${lanes.join("\n")} return getMergedSymbol(symbol && (symbol.flags & 1048576 /* ExportValue */) !== 0 && symbol.exportSymbol || symbol); } function symbolIsValue(symbol, includeTypeOnlyMembers) { - return !!(symbol.flags & 111551 /* Value */ || symbol.flags & 2097152 /* Alias */ && getAllSymbolFlags(symbol) & 111551 /* Value */ && (includeTypeOnlyMembers || !getTypeOnlyAliasDeclaration(symbol))); + return !!(symbol.flags & 111551 /* Value */ || symbol.flags & 2097152 /* Alias */ && getSymbolFlags(symbol, !includeTypeOnlyMembers) & 111551 /* Value */); } function findConstructorDeclaration(node) { const members = node.members; for (const member of members) { - if (member.kind === 175 /* Constructor */ && nodeIsPresent(member.body)) { + if (member.kind === 176 /* Constructor */ && nodeIsPresent(member.body)) { return member; } } @@ -147958,12 +131432,21 @@ ${lanes.join("\n")} function createOriginType(flags) { return new Type27(checker, flags); } - function createIntrinsicType(kind, intrinsicName, objectFlags = 0 /* None */) { + function createIntrinsicType(kind, intrinsicName, objectFlags = 0 /* None */, debugIntrinsicName) { + checkIntrinsicName(intrinsicName, debugIntrinsicName); const type = createType(kind); type.intrinsicName = intrinsicName; - type.objectFlags = objectFlags; + type.debugIntrinsicName = debugIntrinsicName; + type.objectFlags = objectFlags | 524288 /* CouldContainTypeVariablesComputed */ | 2097152 /* IsGenericTypeComputed */ | 33554432 /* IsUnknownLikeUnionComputed */ | 16777216 /* IsNeverIntersectionComputed */; return type; } + function checkIntrinsicName(name, debug) { + const key = `${name},${debug ?? ""}`; + if (seenIntrinsicNames.has(key)) { + Debug.fail(`Duplicate intrinsic type name ${name}${debug ? ` (${debug})` : ""}; you may need to pass a name to createIntrinsicType.`); + } + seenIntrinsicNames.add(key); + } function createObjectType(objectFlags, symbol) { const type = createTypeWithSymbol(524288 /* Object */, symbol); type.objectFlags = objectFlags; @@ -148012,13 +131495,7 @@ ${lanes.join("\n")} return resolved; } function createAnonymousType(symbol, members, callSignatures, constructSignatures, indexInfos) { - return setStructuredTypeMembers( - createObjectType(16 /* Anonymous */, symbol), - members, - callSignatures, - constructSignatures, - indexInfos - ); + return setStructuredTypeMembers(createObjectType(16 /* Anonymous */, symbol), members, callSignatures, constructSignatures, indexInfos); } function getResolvedTypeWithoutAbstractConstructSignatures(type) { if (type.constructSignatures.length === 0) @@ -148055,11 +131532,11 @@ ${lanes.join("\n")} } } switch (location.kind) { - case 311 /* SourceFile */: + case 312 /* SourceFile */: if (!isExternalOrCommonJsModule(location)) { break; } - case 266 /* ModuleDeclaration */: + case 267 /* ModuleDeclaration */: const sym = getSymbolOfDeclaration(location); if (result = callback( (sym == null ? void 0 : sym.exports) || emptySymbols, @@ -148072,9 +131549,9 @@ ${lanes.join("\n")} return result; } break; - case 262 /* ClassDeclaration */: - case 230 /* ClassExpression */: - case 263 /* InterfaceDeclaration */: + case 263 /* ClassDeclaration */: + case 231 /* ClassExpression */: + case 264 /* InterfaceDeclaration */: let table; (getSymbolOfDeclaration(location).members || emptySymbols).forEach((memberSymbol, key) => { if (memberSymbol.flags & (788968 /* Type */ & ~67108864 /* Assignment */)) { @@ -148152,7 +131629,7 @@ ${lanes.join("\n")} return [symbol]; } const result2 = forEachEntry(symbols, (symbolFromSymbolTable) => { - if (symbolFromSymbolTable.flags & 2097152 /* Alias */ && symbolFromSymbolTable.escapedName !== "export=" /* ExportEquals */ && symbolFromSymbolTable.escapedName !== "default" /* Default */ && !(isUMDExportSymbol(symbolFromSymbolTable) && enclosingDeclaration && isExternalModule(getSourceFileOfNode(enclosingDeclaration))) && (!useOnlyExternalAliasing || some(symbolFromSymbolTable.declarations, isExternalModuleImportEqualsDeclaration)) && (isLocalNameLookup ? !some(symbolFromSymbolTable.declarations, isNamespaceReexportDeclaration) : true) && (ignoreQualification || !getDeclarationOfKind(symbolFromSymbolTable, 280 /* ExportSpecifier */))) { + if (symbolFromSymbolTable.flags & 2097152 /* Alias */ && symbolFromSymbolTable.escapedName !== "export=" /* ExportEquals */ && symbolFromSymbolTable.escapedName !== "default" /* Default */ && !(isUMDExportSymbol(symbolFromSymbolTable) && enclosingDeclaration && isExternalModule(getSourceFileOfNode(enclosingDeclaration))) && (!useOnlyExternalAliasing || some(symbolFromSymbolTable.declarations, isExternalModuleImportEqualsDeclaration)) && (isLocalNameLookup ? !some(symbolFromSymbolTable.declarations, isNamespaceReexportDeclaration) : true) && (ignoreQualification || !getDeclarationOfKind(symbolFromSymbolTable, 281 /* ExportSpecifier */))) { const resolvedImportedSymbol = resolveAlias(symbolFromSymbolTable); const candidate = getCandidateListForSymbol(symbolFromSymbolTable, resolvedImportedSymbol, ignoreQualification); if (candidate) { @@ -148197,9 +131674,9 @@ ${lanes.join("\n")} if (symbolFromSymbolTable === symbol) { return true; } - const shouldResolveAlias = symbolFromSymbolTable.flags & 2097152 /* Alias */ && !getDeclarationOfKind(symbolFromSymbolTable, 280 /* ExportSpecifier */); + const shouldResolveAlias = symbolFromSymbolTable.flags & 2097152 /* Alias */ && !getDeclarationOfKind(symbolFromSymbolTable, 281 /* ExportSpecifier */); symbolFromSymbolTable = shouldResolveAlias ? resolveAlias(symbolFromSymbolTable) : symbolFromSymbolTable; - const flags = shouldResolveAlias ? getAllSymbolFlags(symbolFromSymbolTable) : symbolFromSymbolTable.flags; + const flags = shouldResolveAlias ? getSymbolFlags(symbolFromSymbolTable) : symbolFromSymbolTable.flags; if (flags & meaning) { qualify = true; return true; @@ -148212,10 +131689,10 @@ ${lanes.join("\n")} if (symbol.declarations && symbol.declarations.length) { for (const declaration of symbol.declarations) { switch (declaration.kind) { - case 171 /* PropertyDeclaration */: - case 173 /* MethodDeclaration */: - case 176 /* GetAccessor */: - case 177 /* SetAccessor */: + case 172 /* PropertyDeclaration */: + case 174 /* MethodDeclaration */: + case 177 /* GetAccessor */: + case 178 /* SetAccessor */: continue; default: return false; @@ -148351,10 +131828,10 @@ ${lanes.join("\n")} return node && getSymbolOfDeclaration(node); } function hasExternalModuleSymbol(declaration) { - return isAmbientModule(declaration) || declaration.kind === 311 /* SourceFile */ && isExternalOrCommonJsModule(declaration); + return isAmbientModule(declaration) || declaration.kind === 312 /* SourceFile */ && isExternalOrCommonJsModule(declaration); } function hasNonGlobalAugmentationExternalModuleSymbol(declaration) { - return isModuleWithStringLiteralName(declaration) || declaration.kind === 311 /* SourceFile */ && isExternalOrCommonJsModule(declaration); + return isModuleWithStringLiteralName(declaration) || declaration.kind === 312 /* SourceFile */ && isExternalOrCommonJsModule(declaration); } function hasVisibleDeclarations(symbol, shouldComputeAliasToMakeVisible) { let aliasesToMakeVisible; @@ -148366,20 +131843,20 @@ ${lanes.join("\n")} var _a, _b; if (!isDeclarationVisible(declaration)) { const anyImportSyntax = getAnyImportSyntax(declaration); - if (anyImportSyntax && !hasSyntacticModifier(anyImportSyntax, 1 /* Export */) && // import clause without export + if (anyImportSyntax && !hasSyntacticModifier(anyImportSyntax, 32 /* Export */) && // import clause without export isDeclarationVisible(anyImportSyntax.parent)) { return addVisibleAlias(declaration, anyImportSyntax); - } else if (isVariableDeclaration(declaration) && isVariableStatement(declaration.parent.parent) && !hasSyntacticModifier(declaration.parent.parent, 1 /* Export */) && // unexported variable statement + } else if (isVariableDeclaration(declaration) && isVariableStatement(declaration.parent.parent) && !hasSyntacticModifier(declaration.parent.parent, 32 /* Export */) && // unexported variable statement isDeclarationVisible(declaration.parent.parent.parent)) { return addVisibleAlias(declaration, declaration.parent.parent); - } else if (isLateVisibilityPaintedStatement(declaration) && !hasSyntacticModifier(declaration, 1 /* Export */) && isDeclarationVisible(declaration.parent)) { + } else if (isLateVisibilityPaintedStatement(declaration) && !hasSyntacticModifier(declaration, 32 /* Export */) && isDeclarationVisible(declaration.parent)) { return addVisibleAlias(declaration, declaration); } else if (isBindingElement(declaration)) { - if (symbol.flags & 2097152 /* Alias */ && isInJSFile(declaration) && ((_a = declaration.parent) == null ? void 0 : _a.parent) && isVariableDeclaration(declaration.parent.parent) && ((_b = declaration.parent.parent.parent) == null ? void 0 : _b.parent) && isVariableStatement(declaration.parent.parent.parent.parent) && !hasSyntacticModifier(declaration.parent.parent.parent.parent, 1 /* Export */) && declaration.parent.parent.parent.parent.parent && isDeclarationVisible(declaration.parent.parent.parent.parent.parent)) { + if (symbol.flags & 2097152 /* Alias */ && isInJSFile(declaration) && ((_a = declaration.parent) == null ? void 0 : _a.parent) && isVariableDeclaration(declaration.parent.parent) && ((_b = declaration.parent.parent.parent) == null ? void 0 : _b.parent) && isVariableStatement(declaration.parent.parent.parent.parent) && !hasSyntacticModifier(declaration.parent.parent.parent.parent, 32 /* Export */) && declaration.parent.parent.parent.parent.parent && isDeclarationVisible(declaration.parent.parent.parent.parent.parent)) { return addVisibleAlias(declaration, declaration.parent.parent.parent.parent); } else if (symbol.flags & 2 /* BlockScopedVariable */) { const variableStatement = findAncestor(declaration, isVariableStatement); - if (hasSyntacticModifier(variableStatement, 1 /* Export */)) { + if (hasSyntacticModifier(variableStatement, 32 /* Export */)) { return true; } if (!isDeclarationVisible(variableStatement.parent)) { @@ -148402,9 +131879,9 @@ ${lanes.join("\n")} } function isEntityNameVisible(entityName, enclosingDeclaration) { let meaning; - if (entityName.parent.kind === 185 /* TypeQuery */ || entityName.parent.kind === 232 /* ExpressionWithTypeArguments */ && !isPartOfTypeNode(entityName.parent) || entityName.parent.kind === 166 /* ComputedPropertyName */) { + if (entityName.parent.kind === 186 /* TypeQuery */ || entityName.parent.kind === 233 /* ExpressionWithTypeArguments */ && !isPartOfTypeNode(entityName.parent) || entityName.parent.kind === 167 /* ComputedPropertyName */) { meaning = 111551 /* Value */ | 1048576 /* ExportValue */; - } else if (entityName.kind === 165 /* QualifiedName */ || entityName.kind === 210 /* PropertyAccessExpression */ || entityName.parent.kind === 270 /* ImportEqualsDeclaration */) { + } else if (entityName.kind === 166 /* QualifiedName */ || entityName.kind === 211 /* PropertyAccessExpression */ || entityName.parent.kind === 271 /* ImportEqualsDeclaration */) { meaning = 1920 /* Namespace */; } else { meaning = 788968 /* Type */; @@ -148470,7 +131947,7 @@ ${lanes.join("\n")} return writer ? symbolToStringWorker(writer).getText() : usingSingleLineStringWriter(symbolToStringWorker); function symbolToStringWorker(writer2) { const entity = builder(symbol, meaning, enclosingDeclaration, nodeFlags); - const printer = (enclosingDeclaration == null ? void 0 : enclosingDeclaration.kind) === 311 /* SourceFile */ ? createPrinterWithRemoveCommentsNeverAsciiEscape() : createPrinterWithRemoveComments(); + const printer = (enclosingDeclaration == null ? void 0 : enclosingDeclaration.kind) === 312 /* SourceFile */ ? createPrinterWithRemoveCommentsNeverAsciiEscape() : createPrinterWithRemoveComments(); const sourceFile = enclosingDeclaration && getSourceFileOfNode(enclosingDeclaration); printer.writeNode( 4 /* Unspecified */, @@ -148487,9 +131964,9 @@ ${lanes.join("\n")} function signatureToStringWorker(writer2) { let sigOutput; if (flags & 262144 /* WriteArrowStyleSignature */) { - sigOutput = kind === 1 /* Construct */ ? 184 /* ConstructorType */ : 183 /* FunctionType */; + sigOutput = kind === 1 /* Construct */ ? 185 /* ConstructorType */ : 184 /* FunctionType */; } else { - sigOutput = kind === 1 /* Construct */ ? 179 /* ConstructSignature */ : 178 /* CallSignature */; + sigOutput = kind === 1 /* Construct */ ? 180 /* ConstructSignature */ : 179 /* CallSignature */; } const sig = nodeBuilder.signatureToSignatureDeclaration(signature, sigOutput, enclosingDeclaration, toNodeBuilderFlags(flags) | 70221824 /* IgnoreErrors */ | 512 /* WriteTypeParametersInQualifiedName */); const printer = createPrinterWithRemoveCommentsOmitTrailingSemicolon(); @@ -148591,7 +132068,7 @@ ${lanes.join("\n")} return symbolToExpression(symbol, context, meaning); } function withContext(enclosingDeclaration, flags, tracker, cb) { - Debug.assert(enclosingDeclaration === void 0 || (enclosingDeclaration.flags & 8 /* Synthesized */) === 0); + Debug.assert(enclosingDeclaration === void 0 || (enclosingDeclaration.flags & 16 /* Synthesized */) === 0); const moduleResolverHost = (tracker == null ? void 0 : tracker.trackSymbol) ? tracker.moduleResolverHost : flags & 134217728 /* DoNotIncludeSymbolChain */ ? createBasicNodeBuilderModuleSpecifierResolutionHost(host) : void 0; const context = { enclosingDeclaration, @@ -148602,7 +132079,8 @@ ${lanes.join("\n")} visitedTypes: void 0, symbolDepth: void 0, inferTypeParameters: void 0, - approximateLength: 0 + approximateLength: 0, + trackedSymbols: void 0 }; context.tracker = new SymbolTrackerImpl(context, tracker, moduleResolverHost); const resultingNode = cb(context); @@ -148663,7 +132141,7 @@ ${lanes.join("\n")} } if (type.flags & 64 /* BigInt */) { context.approximateLength += 6; - return factory.createKeywordTypeNode(162 /* BigIntKeyword */); + return factory.createKeywordTypeNode(163 /* BigIntKeyword */); } if (type.flags & 16 /* Boolean */ && !type.aliasSymbol) { context.approximateLength += 7; @@ -148936,11 +132414,13 @@ ${lanes.join("\n")} return !!type2.target && isMappedTypeHomomorphic(type2.target) && !isMappedTypeHomomorphic(type2); } function createMappedTypeNodeFromType(type2) { + var _a2; Debug.assert(!!(type2.flags & 524288 /* Object */)); const readonlyToken = type2.declaration.readonlyToken ? factory.createToken(type2.declaration.readonlyToken.kind) : void 0; const questionToken = type2.declaration.questionToken ? factory.createToken(type2.declaration.questionToken.kind) : void 0; let appropriateConstraintTypeNode; let newTypeVariable; + const needsModifierPreservingWrapper = !isMappedTypeWithKeyofConstraintDeclaration(type2) && !(getModifiersTypeFromMappedType(type2).flags & 2 /* Unknown */) && context.flags & 4 /* GenerateNamesForShadowedTypeParams */ && !(getConstraintTypeFromMappedType(type2).flags & 262144 /* TypeParameter */ && ((_a2 = getConstraintOfTypeParameter(getConstraintTypeFromMappedType(type2))) == null ? void 0 : _a2.flags) & 4194304 /* Index */); if (isMappedTypeWithKeyofConstraintDeclaration(type2)) { if (isHomomorphicMappedTypeWithNonHomomorphicInstantiation(type2) && context.flags & 4 /* GenerateNamesForShadowedTypeParams */) { const newParam = createTypeParameter(createSymbol(262144 /* TypeParameter */, "T")); @@ -148948,6 +132428,11 @@ ${lanes.join("\n")} newTypeVariable = factory.createTypeReferenceNode(name); } appropriateConstraintTypeNode = factory.createTypeOperatorNode(143 /* KeyOfKeyword */, newTypeVariable || typeToTypeNodeHelper(getModifiersTypeFromMappedType(type2), context)); + } else if (needsModifierPreservingWrapper) { + const newParam = createTypeParameter(createSymbol(262144 /* TypeParameter */, "T")); + const name = typeParameterToName(newParam, context); + newTypeVariable = factory.createTypeReferenceNode(name); + appropriateConstraintTypeNode = newTypeVariable; } else { appropriateConstraintTypeNode = typeToTypeNodeHelper(getConstraintTypeFromMappedType(type2), context); } @@ -148978,6 +132463,18 @@ ${lanes.join("\n")} result, factory.createKeywordTypeNode(146 /* NeverKeyword */) ); + } else if (needsModifierPreservingWrapper) { + return factory.createConditionalTypeNode( + typeToTypeNodeHelper(getConstraintTypeFromMappedType(type2), context), + factory.createInferTypeNode(factory.createTypeParameterDeclaration( + /*modifiers*/ + void 0, + factory.cloneNode(newTypeVariable.typeName), + factory.createTypeOperatorNode(143 /* KeyOfKeyword */, typeToTypeNodeHelper(getModifiersTypeFromMappedType(type2), context)) + )), + result, + factory.createKeywordTypeNode(146 /* NeverKeyword */) + ); } return result; } @@ -149029,7 +132526,7 @@ ${lanes.join("\n")} const isStaticMethodSymbol = !!(symbol.flags & 8192 /* Method */) && // typeof static method some(symbol.declarations, (declaration) => isStatic(declaration)); const isNonLocalFunctionSymbol = !!(symbol.flags & 16 /* Function */) && (symbol.parent || // is exported function symbol - forEach(symbol.declarations, (declaration) => declaration.parent.kind === 311 /* SourceFile */ || declaration.parent.kind === 267 /* ModuleBlock */)); + forEach(symbol.declarations, (declaration) => declaration.parent.kind === 312 /* SourceFile */ || declaration.parent.kind === 268 /* ModuleBlock */)); if (isStaticMethodSymbol || isNonLocalFunctionSymbol) { return (!!(context.flags & 4096 /* UseTypeOfFunction */) || ((_a3 = context.visitedTypes) == null ? void 0 : _a3.has(typeId))) && // it is type of the symbol uses itself recursively (!(context.flags & 8 /* UseStructuralFallback */) || isValueSymbolAccessible(symbol, context.enclosingDeclaration)); @@ -149037,7 +132534,7 @@ ${lanes.join("\n")} } } function visitAndTransformType(type2, transform2) { - var _a2, _b2; + var _a2, _b2, _c; const typeId = type2.id; const isConstructorObject = getObjectFlags(type2) & 16 /* Anonymous */ && type2.symbol && type2.symbol.flags & 32 /* Class */; const id = getObjectFlags(type2) & 4 /* Reference */ && type2.node ? "N" + getNodeId(type2.node) : type2.flags & 16777216 /* Conditional */ ? "N" + getNodeId(type2.root.node) : type2.symbol ? (isConstructorObject ? "+" : "") + getSymbolId(type2.symbol) : void 0; @@ -149054,6 +132551,13 @@ ${lanes.join("\n")} } const cachedResult = (_a2 = links == null ? void 0 : links.serializedTypes) == null ? void 0 : _a2.get(key); if (cachedResult) { + (_b2 = cachedResult.trackedSymbols) == null ? void 0 : _b2.forEach( + ([symbol, enclosingDeclaration, meaning]) => context.tracker.trackSymbol( + symbol, + enclosingDeclaration, + meaning + ) + ); if (cachedResult.truncating) { context.truncating = true; } @@ -149069,16 +132573,24 @@ ${lanes.join("\n")} context.symbolDepth.set(id, depth + 1); } context.visitedTypes.add(typeId); + const prevTrackedSymbols = context.trackedSymbols; + context.trackedSymbols = void 0; const startLength = context.approximateLength; const result = transform2(type2); const addedLength = context.approximateLength - startLength; if (!context.reportedDiagnostic && !context.encounteredError) { - (_b2 = links == null ? void 0 : links.serializedTypes) == null ? void 0 : _b2.set(key, { node: result, truncating: context.truncating, addedLength }); + (_c = links == null ? void 0 : links.serializedTypes) == null ? void 0 : _c.set(key, { + node: result, + truncating: context.truncating, + addedLength, + trackedSymbols: context.trackedSymbols + }); } context.visitedTypes.delete(typeId); if (id) { context.symbolDepth.set(id, depth); } + context.trackedSymbols = prevTrackedSymbols; return result; function deepCloneOrReuseNode(node) { if (!nodeIsSynthesized(node) && getParseTreeNode(node) === node) { @@ -149112,12 +132624,12 @@ ${lanes.join("\n")} } if (resolved.callSignatures.length === 1 && !resolved.constructSignatures.length) { const signature = resolved.callSignatures[0]; - const signatureNode = signatureToSignatureDeclarationHelper(signature, 183 /* FunctionType */, context); + const signatureNode = signatureToSignatureDeclarationHelper(signature, 184 /* FunctionType */, context); return signatureNode; } if (resolved.constructSignatures.length === 1 && !resolved.callSignatures.length) { const signature = resolved.constructSignatures[0]; - const signatureNode = signatureToSignatureDeclarationHelper(signature, 184 /* ConstructorType */, context); + const signatureNode = signatureToSignatureDeclarationHelper(signature, 185 /* ConstructorType */, context); return signatureNode; } } @@ -149157,19 +132669,18 @@ ${lanes.join("\n")} const arity = getTypeReferenceArity(type2); const tupleConstituentNodes = mapToTypeNodes(typeArguments.slice(0, arity), context); if (tupleConstituentNodes) { - if (type2.target.labeledElementDeclarations) { - for (let i = 0; i < tupleConstituentNodes.length; i++) { - const flags = type2.target.elementFlags[i]; + const { labeledElementDeclarations } = type2.target; + for (let i = 0; i < tupleConstituentNodes.length; i++) { + const flags = type2.target.elementFlags[i]; + const labeledElementDeclaration = labeledElementDeclarations == null ? void 0 : labeledElementDeclarations[i]; + if (labeledElementDeclaration) { tupleConstituentNodes[i] = factory.createNamedTupleMember( flags & 12 /* Variable */ ? factory.createToken(26 /* DotDotDotToken */) : void 0, - factory.createIdentifier(unescapeLeadingUnderscores(getTupleElementLabel(type2.target.labeledElementDeclarations[i]))), + factory.createIdentifier(unescapeLeadingUnderscores(getTupleElementLabel(labeledElementDeclaration))), flags & 2 /* Optional */ ? factory.createToken(58 /* QuestionToken */) : void 0, flags & 4 /* Rest */ ? factory.createArrayTypeNode(tupleConstituentNodes[i]) : tupleConstituentNodes[i] ); - } - } else { - for (let i = 0; i < Math.min(arity, tupleConstituentNodes.length); i++) { - const flags = type2.target.elementFlags[i]; + } else { tupleConstituentNodes[i] = flags & 12 /* Variable */ ? factory.createRestTypeNode(flags & 4 /* Rest */ ? factory.createArrayTypeNode(tupleConstituentNodes[i]) : tupleConstituentNodes[i]) : flags & 2 /* Optional */ ? factory.createOptionalTypeNode(tupleConstituentNodes[i]) : tupleConstituentNodes[i]; } } @@ -149230,11 +132741,7 @@ ${lanes.join("\n")} } } else { if (typeArguments !== getIdentifierTypeArguments(qualifier.right)) { - qualifier = factory.updateQualifiedName( - qualifier, - qualifier.left, - setIdentifierTypeArguments(factory.cloneNode(qualifier.right), typeArguments) - ); + qualifier = factory.updateQualifiedName(qualifier, qualifier.left, setIdentifierTypeArguments(factory.cloneNode(qualifier.right), typeArguments)); } } } @@ -149246,7 +132753,7 @@ ${lanes.join("\n")} return factory.updateImportTypeNode( root, root.argument, - root.assertions, + root.attributes, qualifier, typeArguments, root.isTypeOf @@ -149260,11 +132767,7 @@ ${lanes.join("\n")} } } else { if (typeArguments !== getIdentifierTypeArguments(typeName.right)) { - typeName = factory.updateQualifiedName( - typeName, - typeName.left, - setIdentifierTypeArguments(factory.cloneNode(typeName.right), typeArguments) - ); + typeName = factory.updateQualifiedName(typeName, typeName.left, setIdentifierTypeArguments(factory.cloneNode(typeName.right), typeArguments)); } } typeArguments = ref.typeArguments; @@ -149303,12 +132806,12 @@ ${lanes.join("\n")} } const typeElements = []; for (const signature of resolvedType.callSignatures) { - typeElements.push(signatureToSignatureDeclarationHelper(signature, 178 /* CallSignature */, context)); + typeElements.push(signatureToSignatureDeclarationHelper(signature, 179 /* CallSignature */, context)); } for (const signature of resolvedType.constructSignatures) { if (signature.flags & 4 /* Abstract */) continue; - typeElements.push(signatureToSignatureDeclarationHelper(signature, 179 /* ConstructSignature */, context)); + typeElements.push(signatureToSignatureDeclarationHelper(signature, 180 /* ConstructSignature */, context)); } for (const info of resolvedType.indexInfos) { typeElements.push(indexInfoToIndexSignatureDeclarationHelper(info, context, resolvedType.objectFlags & 1024 /* ReverseMapped */ ? createElidedInformationPlaceholder(context) : void 0)); @@ -149324,7 +132827,7 @@ ${lanes.join("\n")} if (propertySymbol.flags & 4194304 /* Prototype */) { continue; } - if (getDeclarationModifierFlagsFromSymbol(propertySymbol) & (8 /* Private */ | 16 /* Protected */) && context.tracker.reportPrivateInBaseOfClassExpression) { + if (getDeclarationModifierFlagsFromSymbol(propertySymbol) & (2 /* Private */ | 4 /* Protected */) && context.tracker.reportPrivateInBaseOfClassExpression) { context.tracker.reportPrivateInBaseOfClassExpression(unescapeLeadingUnderscores(propertySymbol.escapedName)); } } @@ -149388,44 +132891,68 @@ ${lanes.join("\n")} const propertyName = getPropertyNameNodeForSymbol(propertySymbol, context); context.enclosingDeclaration = saveEnclosingDeclaration; context.approximateLength += symbolName(propertySymbol).length + 1; + if (propertySymbol.flags & 98304 /* Accessor */) { + const writeType = getWriteTypeOfSymbol(propertySymbol); + if (propertyType !== writeType && !isErrorType(propertyType) && !isErrorType(writeType)) { + const getterDeclaration = getDeclarationOfKind(propertySymbol, 177 /* GetAccessor */); + const getterSignature = getSignatureFromDeclaration(getterDeclaration); + typeElements.push( + setCommentRange( + signatureToSignatureDeclarationHelper(getterSignature, 177 /* GetAccessor */, context, { name: propertyName }), + getterDeclaration + ) + ); + const setterDeclaration = getDeclarationOfKind(propertySymbol, 178 /* SetAccessor */); + const setterSignature = getSignatureFromDeclaration(setterDeclaration); + typeElements.push( + setCommentRange( + signatureToSignatureDeclarationHelper(setterSignature, 178 /* SetAccessor */, context, { name: propertyName }), + setterDeclaration + ) + ); + return; + } + } const optionalToken = propertySymbol.flags & 16777216 /* Optional */ ? factory.createToken(58 /* QuestionToken */) : void 0; if (propertySymbol.flags & (16 /* Function */ | 8192 /* Method */) && !getPropertiesOfObjectType(propertyType).length && !isReadonlySymbol(propertySymbol)) { const signatures = getSignaturesOfType(filterType(propertyType, (t) => !(t.flags & 32768 /* Undefined */)), 0 /* Call */); for (const signature of signatures) { - const methodDeclaration = signatureToSignatureDeclarationHelper(signature, 172 /* MethodSignature */, context, { name: propertyName, questionToken: optionalToken }); + const methodDeclaration = signatureToSignatureDeclarationHelper(signature, 173 /* MethodSignature */, context, { name: propertyName, questionToken: optionalToken }); typeElements.push(preserveCommentsOn(methodDeclaration)); } + if (signatures.length || !optionalToken) { + return; + } + } + let propertyTypeNode; + if (shouldUsePlaceholderForProperty(propertySymbol, context)) { + propertyTypeNode = createElidedInformationPlaceholder(context); } else { - let propertyTypeNode; - if (shouldUsePlaceholderForProperty(propertySymbol, context)) { - propertyTypeNode = createElidedInformationPlaceholder(context); - } else { - if (propertyIsReverseMapped) { - context.reverseMappedStack || (context.reverseMappedStack = []); - context.reverseMappedStack.push(propertySymbol); - } - propertyTypeNode = propertyType ? serializeTypeForDeclaration(context, propertyType, propertySymbol, saveEnclosingDeclaration) : factory.createKeywordTypeNode(133 /* AnyKeyword */); - if (propertyIsReverseMapped) { - context.reverseMappedStack.pop(); - } + if (propertyIsReverseMapped) { + context.reverseMappedStack || (context.reverseMappedStack = []); + context.reverseMappedStack.push(propertySymbol); } - const modifiers = isReadonlySymbol(propertySymbol) ? [factory.createToken(148 /* ReadonlyKeyword */)] : void 0; - if (modifiers) { - context.approximateLength += 9; + propertyTypeNode = propertyType ? serializeTypeForDeclaration(context, propertyType, propertySymbol, saveEnclosingDeclaration) : factory.createKeywordTypeNode(133 /* AnyKeyword */); + if (propertyIsReverseMapped) { + context.reverseMappedStack.pop(); } - const propertySignature = factory.createPropertySignature( - modifiers, - propertyName, - optionalToken, - propertyTypeNode - ); - typeElements.push(preserveCommentsOn(propertySignature)); } + const modifiers = isReadonlySymbol(propertySymbol) ? [factory.createToken(148 /* ReadonlyKeyword */)] : void 0; + if (modifiers) { + context.approximateLength += 9; + } + const propertySignature = factory.createPropertySignature( + modifiers, + propertyName, + optionalToken, + propertyTypeNode + ); + typeElements.push(preserveCommentsOn(propertySignature)); function preserveCommentsOn(node) { var _a2; - if (some(propertySymbol.declarations, (d) => d.kind === 354 /* JSDocPropertyTag */)) { - const d = (_a2 = propertySymbol.declarations) == null ? void 0 : _a2.find((d2) => d2.kind === 354 /* JSDocPropertyTag */); - const commentText = getTextOfJSDocComment(d.comment); + const jsdocPropertyTag = (_a2 = propertySymbol.declarations) == null ? void 0 : _a2.find((d) => d.kind === 355 /* JSDocPropertyTag */); + if (jsdocPropertyTag) { + const commentText = getTextOfJSDocComment(jsdocPropertyTag.comment); if (commentText) { setSyntheticLeadingComments(node, [{ kind: 3 /* MultiLineCommentTrivia */, text: "*\n * " + commentText.replace(/\n/g, "\n * ") + "\n ", pos: -1, end: -1, hasTrailingNewLine: true }]); } @@ -149530,6 +133057,7 @@ ${lanes.join("\n")} ); } function signatureToSignatureDeclarationHelper(signature, kind, context, options) { + var _a; const suppressAny = context.flags & 256 /* SuppressAnyReturnType */; if (suppressAny) context.flags &= ~256 /* SuppressAnyReturnType */; @@ -149579,7 +133107,7 @@ ${lanes.join("\n")} } } } - const parameters = (some(expandedParams, (p) => p !== expandedParams[expandedParams.length - 1] && !!(getCheckFlags(p) & 32768 /* RestParameter */)) ? signature.parameters : expandedParams).map((parameter) => symbolToParameterDeclaration(parameter, context, kind === 175 /* Constructor */, options == null ? void 0 : options.privateSymbolVisitor, options == null ? void 0 : options.bundledImports)); + const parameters = (some(expandedParams, (p) => p !== expandedParams[expandedParams.length - 1] && !!(getCheckFlags(p) & 32768 /* RestParameter */)) ? signature.parameters : expandedParams).map((parameter) => symbolToParameterDeclaration(parameter, context, kind === 176 /* Constructor */, options == null ? void 0 : options.privateSymbolVisitor, options == null ? void 0 : options.bundledImports)); const thisParameter = context.flags & 33554432 /* OmitThisParameter */ ? void 0 : tryGetThisParameterDeclaration(signature, context); if (thisParameter) { parameters.unshift(thisParameter); @@ -149600,11 +133128,11 @@ ${lanes.join("\n")} } } let modifiers = options == null ? void 0 : options.modifiers; - if (kind === 184 /* ConstructorType */ && signature.flags & 4 /* Abstract */) { + if (kind === 185 /* ConstructorType */ && signature.flags & 4 /* Abstract */) { const flags = modifiersToFlags(modifiers); - modifiers = factory.createModifiersFromModifierFlags(flags | 256 /* Abstract */); + modifiers = factory.createModifiersFromModifierFlags(flags | 64 /* Abstract */); } - const node = kind === 178 /* CallSignature */ ? factory.createCallSignature(typeParameters, parameters, returnTypeNode) : kind === 179 /* ConstructSignature */ ? factory.createConstructSignature(typeParameters, parameters, returnTypeNode) : kind === 172 /* MethodSignature */ ? factory.createMethodSignature(modifiers, (options == null ? void 0 : options.name) ?? factory.createIdentifier(""), options == null ? void 0 : options.questionToken, typeParameters, parameters, returnTypeNode) : kind === 173 /* MethodDeclaration */ ? factory.createMethodDeclaration( + const node = kind === 179 /* CallSignature */ ? factory.createCallSignature(typeParameters, parameters, returnTypeNode) : kind === 180 /* ConstructSignature */ ? factory.createConstructSignature(typeParameters, parameters, returnTypeNode) : kind === 173 /* MethodSignature */ ? factory.createMethodSignature(modifiers, (options == null ? void 0 : options.name) ?? factory.createIdentifier(""), options == null ? void 0 : options.questionToken, typeParameters, parameters, returnTypeNode) : kind === 174 /* MethodDeclaration */ ? factory.createMethodDeclaration( modifiers, /*asteriskToken*/ void 0, @@ -149616,25 +133144,25 @@ ${lanes.join("\n")} returnTypeNode, /*body*/ void 0 - ) : kind === 175 /* Constructor */ ? factory.createConstructorDeclaration( + ) : kind === 176 /* Constructor */ ? factory.createConstructorDeclaration( modifiers, parameters, /*body*/ void 0 - ) : kind === 176 /* GetAccessor */ ? factory.createGetAccessorDeclaration( + ) : kind === 177 /* GetAccessor */ ? factory.createGetAccessorDeclaration( modifiers, (options == null ? void 0 : options.name) ?? factory.createIdentifier(""), parameters, returnTypeNode, /*body*/ void 0 - ) : kind === 177 /* SetAccessor */ ? factory.createSetAccessorDeclaration( + ) : kind === 178 /* SetAccessor */ ? factory.createSetAccessorDeclaration( modifiers, (options == null ? void 0 : options.name) ?? factory.createIdentifier(""), parameters, /*body*/ void 0 - ) : kind === 180 /* IndexSignature */ ? factory.createIndexSignature(modifiers, parameters, returnTypeNode) : kind === 323 /* JSDocFunctionType */ ? factory.createJSDocFunctionType(parameters, returnTypeNode) : kind === 183 /* FunctionType */ ? factory.createFunctionTypeNode(typeParameters, parameters, returnTypeNode ?? factory.createTypeReferenceNode(factory.createIdentifier(""))) : kind === 184 /* ConstructorType */ ? factory.createConstructorTypeNode(modifiers, typeParameters, parameters, returnTypeNode ?? factory.createTypeReferenceNode(factory.createIdentifier(""))) : kind === 261 /* FunctionDeclaration */ ? factory.createFunctionDeclaration( + ) : kind === 181 /* IndexSignature */ ? factory.createIndexSignature(modifiers, parameters, returnTypeNode) : kind === 324 /* JSDocFunctionType */ ? factory.createJSDocFunctionType(parameters, returnTypeNode) : kind === 184 /* FunctionType */ ? factory.createFunctionTypeNode(typeParameters, parameters, returnTypeNode ?? factory.createTypeReferenceNode(factory.createIdentifier(""))) : kind === 185 /* ConstructorType */ ? factory.createConstructorTypeNode(modifiers, typeParameters, parameters, returnTypeNode ?? factory.createTypeReferenceNode(factory.createIdentifier(""))) : kind === 262 /* FunctionDeclaration */ ? factory.createFunctionDeclaration( modifiers, /*asteriskToken*/ void 0, @@ -149644,7 +133172,7 @@ ${lanes.join("\n")} returnTypeNode, /*body*/ void 0 - ) : kind === 217 /* FunctionExpression */ ? factory.createFunctionExpression( + ) : kind === 218 /* FunctionExpression */ ? factory.createFunctionExpression( modifiers, /*asteriskToken*/ void 0, @@ -149653,7 +133181,7 @@ ${lanes.join("\n")} parameters, returnTypeNode, factory.createBlock([]) - ) : kind === 218 /* ArrowFunction */ ? factory.createArrowFunction( + ) : kind === 219 /* ArrowFunction */ ? factory.createArrowFunction( modifiers, typeParameters, parameters, @@ -149665,6 +133193,20 @@ ${lanes.join("\n")} if (typeArguments) { node.typeArguments = factory.createNodeArray(typeArguments); } + if (((_a = signature.declaration) == null ? void 0 : _a.kind) === 330 /* JSDocSignature */ && signature.declaration.parent.kind === 346 /* JSDocOverloadTag */) { + const comment = getTextOfNode( + signature.declaration.parent.parent, + /*includeTrivia*/ + true + ).slice(2, -2).split(/\r\n|\n|\r/).map((line) => line.replace(/^\s+/, " ")).join("\n"); + addSyntheticLeadingComment( + node, + 3 /* MultiLineCommentTrivia */, + comment, + /*hasTrailingNewLine*/ + true + ); + } cleanup == null ? void 0 : cleanup(); return node; } @@ -149702,11 +133244,17 @@ ${lanes.join("\n")} const constraintNode = constraint && typeToTypeNodeHelper(constraint, context); return typeParameterToDeclarationWithConstraint(type, context, constraintNode); } - function symbolToParameterDeclaration(parameterSymbol, context, preserveModifierFlags, privateSymbolVisitor, bundledImports) { - let parameterDeclaration = getDeclarationOfKind(parameterSymbol, 168 /* Parameter */); - if (!parameterDeclaration && !isTransientSymbol(parameterSymbol)) { - parameterDeclaration = getDeclarationOfKind(parameterSymbol, 347 /* JSDocParameterTag */); + function getEffectiveParameterDeclaration(parameterSymbol) { + const parameterDeclaration = getDeclarationOfKind(parameterSymbol, 169 /* Parameter */); + if (parameterDeclaration) { + return parameterDeclaration; + } + if (!isTransientSymbol(parameterSymbol)) { + return getDeclarationOfKind(parameterSymbol, 348 /* JSDocParameterTag */); } + } + function symbolToParameterDeclaration(parameterSymbol, context, preserveModifierFlags, privateSymbolVisitor, bundledImports) { + const parameterDeclaration = getEffectiveParameterDeclaration(parameterSymbol); let parameterType = getTypeOfSymbol(parameterSymbol); if (parameterDeclaration && isRequiredInitializedParameter(parameterDeclaration)) { parameterType = getOptionalType(parameterType); @@ -149715,7 +133263,7 @@ ${lanes.join("\n")} const modifiers = !(context.flags & 8192 /* OmitParameterModifiers */) && preserveModifierFlags && parameterDeclaration && canHaveModifiers(parameterDeclaration) ? map(getModifiers(parameterDeclaration), factory.cloneNode) : void 0; const isRest = parameterDeclaration && isRestParameter(parameterDeclaration) || getCheckFlags(parameterSymbol) & 32768 /* RestParameter */; const dotDotDotToken = isRest ? factory.createToken(26 /* DotDotDotToken */) : void 0; - const name = parameterDeclaration ? parameterDeclaration.name ? parameterDeclaration.name.kind === 80 /* Identifier */ ? setEmitFlags(factory.cloneNode(parameterDeclaration.name), 16777216 /* NoAsciiEscaping */) : parameterDeclaration.name.kind === 165 /* QualifiedName */ ? setEmitFlags(factory.cloneNode(parameterDeclaration.name.right), 16777216 /* NoAsciiEscaping */) : cloneBindingName(parameterDeclaration.name) : symbolName(parameterSymbol) : symbolName(parameterSymbol); + const name = parameterToParameterDeclarationName(parameterSymbol, parameterDeclaration, context); const isOptional = parameterDeclaration && isOptionalParameter(parameterDeclaration) || getCheckFlags(parameterSymbol) & 16384 /* OptionalParameter */; const questionToken = isOptional ? factory.createToken(58 /* QuestionToken */) : void 0; const parameterNode = factory.createParameterDeclaration( @@ -149729,6 +133277,9 @@ ${lanes.join("\n")} ); context.approximateLength += symbolName(parameterSymbol).length + 3; return parameterNode; + } + function parameterToParameterDeclarationName(parameterSymbol, parameterDeclaration, context) { + return parameterDeclaration ? parameterDeclaration.name ? parameterDeclaration.name.kind === 80 /* Identifier */ ? setEmitFlags(factory.cloneNode(parameterDeclaration.name), 16777216 /* NoAsciiEscaping */) : parameterDeclaration.name.kind === 166 /* QualifiedName */ ? setEmitFlags(factory.cloneNode(parameterDeclaration.name.right), 16777216 /* NoAsciiEscaping */) : cloneBindingName(parameterDeclaration.name) : symbolName(parameterSymbol) : symbolName(parameterSymbol); function cloneBindingName(node) { return elideInitializerAndSetEmitFlags(node); function elideInitializerAndSetEmitFlags(node2) { @@ -149804,7 +133355,9 @@ ${lanes.join("\n")} if (!accessibleSymbolChain || needsQualification(accessibleSymbolChain[0], context.enclosingDeclaration, accessibleSymbolChain.length === 1 ? meaning2 : getQualifiedLeftMeaning(meaning2))) { const parents = getContainersOfSymbol(accessibleSymbolChain ? accessibleSymbolChain[0] : symbol2, context.enclosingDeclaration, meaning2); if (length(parents)) { - parentSpecifiers = parents.map((symbol3) => some(symbol3.declarations, hasNonGlobalAugmentationExternalModuleSymbol) ? getSpecifierForModuleSymbol(symbol3, context) : void 0); + parentSpecifiers = parents.map( + (symbol3) => some(symbol3.declarations, hasNonGlobalAugmentationExternalModuleSymbol) ? getSpecifierForModuleSymbol(symbol3, context) : void 0 + ); const indices = parents.map((_, i) => i); indices.sort(sortByBestName); const sortedParents = indices.map((i) => parents[i]); @@ -149895,11 +133448,11 @@ ${lanes.join("\n")} return top; } function getSpecifierForModuleSymbol(symbol, context, overrideImportMode) { - let file = getDeclarationOfKind(symbol, 311 /* SourceFile */); + let file = getDeclarationOfKind(symbol, 312 /* SourceFile */); if (!file) { const equivalentFileSymbol = firstDefined(symbol.declarations, (d) => getFileSymbolIfFileSymbolExportEqualsContainer(d, symbol)); if (equivalentFileSymbol) { - file = getDeclarationOfKind(equivalentFileSymbol, 311 /* SourceFile */); + file = getDeclarationOfKind(equivalentFileSymbol, 312 /* SourceFile */); } } if (file && file.moduleName !== void 0) { @@ -149955,7 +133508,6 @@ ${lanes.join("\n")} return symbol.parent ? factory.createQualifiedName(symbolToEntityNameNode(symbol.parent), identifier) : identifier; } function symbolToTypeNode(symbol, context, meaning, overrideTypeArguments) { - var _a, _b, _c, _d; const chain = lookupSymbolChain(symbol, context, meaning, !(context.flags & 16384 /* UseAliasDefinedOutsideCurrentScope */)); const isTypeOf = meaning === 111551 /* Value */; if (some(chain[0].declarations, hasNonGlobalAugmentationExternalModuleSymbol)) { @@ -149964,40 +133516,42 @@ ${lanes.join("\n")} const contextFile = getSourceFileOfNode(getOriginalNode(context.enclosingDeclaration)); const targetFile = getSourceFileOfModule(chain[0]); let specifier; - let assertion; + let attributes; if (getEmitModuleResolutionKind(compilerOptions) === 3 /* Node16 */ || getEmitModuleResolutionKind(compilerOptions) === 99 /* NodeNext */) { if ((targetFile == null ? void 0 : targetFile.impliedNodeFormat) === 99 /* ESNext */ && targetFile.impliedNodeFormat !== (contextFile == null ? void 0 : contextFile.impliedNodeFormat)) { specifier = getSpecifierForModuleSymbol(chain[0], context, 99 /* ESNext */); - assertion = factory.createImportTypeAssertionContainer(factory.createAssertClause(factory.createNodeArray([ - factory.createAssertEntry( - factory.createStringLiteral("resolution-mode"), - factory.createStringLiteral("import") - ) - ]))); - (_b = (_a = context.tracker).reportImportTypeNodeResolutionModeOverride) == null ? void 0 : _b.call(_a); + attributes = factory.createImportAttributes( + factory.createNodeArray([ + factory.createImportAttribute( + factory.createStringLiteral("resolution-mode"), + factory.createStringLiteral("import") + ) + ]) + ); } } if (!specifier) { specifier = getSpecifierForModuleSymbol(chain[0], context); } - if (!(context.flags & 67108864 /* AllowNodeModulesRelativePaths */) && getEmitModuleResolutionKind(compilerOptions) !== 1 /* Classic */ && specifier.indexOf("/node_modules/") >= 0) { + if (!(context.flags & 67108864 /* AllowNodeModulesRelativePaths */) && getEmitModuleResolutionKind(compilerOptions) !== 1 /* Classic */ && specifier.includes("/node_modules/")) { const oldSpecifier = specifier; if (getEmitModuleResolutionKind(compilerOptions) === 3 /* Node16 */ || getEmitModuleResolutionKind(compilerOptions) === 99 /* NodeNext */) { const swappedMode = (contextFile == null ? void 0 : contextFile.impliedNodeFormat) === 99 /* ESNext */ ? 1 /* CommonJS */ : 99 /* ESNext */; specifier = getSpecifierForModuleSymbol(chain[0], context, swappedMode); - if (specifier.indexOf("/node_modules/") >= 0) { + if (specifier.includes("/node_modules/")) { specifier = oldSpecifier; } else { - assertion = factory.createImportTypeAssertionContainer(factory.createAssertClause(factory.createNodeArray([ - factory.createAssertEntry( - factory.createStringLiteral("resolution-mode"), - factory.createStringLiteral(swappedMode === 99 /* ESNext */ ? "import" : "require") - ) - ]))); - (_d = (_c = context.tracker).reportImportTypeNodeResolutionModeOverride) == null ? void 0 : _d.call(_c); + attributes = factory.createImportAttributes( + factory.createNodeArray([ + factory.createImportAttribute( + factory.createStringLiteral("resolution-mode"), + factory.createStringLiteral(swappedMode === 99 /* ESNext */ ? "import" : "require") + ) + ]) + ); } } - if (!assertion) { + if (!attributes) { context.encounteredError = true; if (context.tracker.reportLikelyUnsafeImportRequiredError) { context.tracker.reportLikelyUnsafeImportRequiredError(oldSpecifier); @@ -150017,11 +133571,11 @@ ${lanes.join("\n")} void 0 ); } - return factory.createImportTypeNode(lit, assertion, nonRootParts, typeParameterNodes, isTypeOf); + return factory.createImportTypeNode(lit, attributes, nonRootParts, typeParameterNodes, isTypeOf); } else { const splitNode = getTopmostIndexedAccessType(nonRootParts); const qualifier = splitNode.objectType.typeName; - return factory.createIndexedAccessTypeNode(factory.createImportTypeNode(lit, assertion, qualifier, typeParameterNodes, isTypeOf), splitNode.indexType); + return factory.createIndexedAccessTypeNode(factory.createImportTypeNode(lit, attributes, qualifier, typeParameterNodes, isTypeOf), splitNode.indexType); } } const entityName = createAccessFromSymbolChain(chain, chain.length - 1, 0); @@ -150221,7 +133775,18 @@ ${lanes.join("\n")} } function isStringNamed(d) { const name = getNameOfDeclaration(d); - return !!name && isStringLiteral(name); + if (!name) { + return false; + } + if (isComputedPropertyName(name)) { + const type = checkExpression(name.expression); + return !!(type.flags & 402653316 /* StringLike */); + } + if (isElementAccessExpression(name)) { + const type = checkExpression(name.argumentExpression); + return !!(type.flags & 402653316 /* StringLike */); + } + return isStringLiteral(name); } function isSingleQuotedStringNamed(d) { const name = getNameOfDeclaration(d); @@ -150234,14 +133799,15 @@ ${lanes.join("\n")} function getPropertyNameNodeForSymbol(symbol, context) { const stringNamed = !!length(symbol.declarations) && every(symbol.declarations, isStringNamed); const singleQuote = !!length(symbol.declarations) && every(symbol.declarations, isSingleQuotedStringNamed); - const fromNameType = getPropertyNameNodeForSymbolFromNameType(symbol, context, singleQuote, stringNamed); + const isMethod = !!(symbol.flags & 8192 /* Method */); + const fromNameType = getPropertyNameNodeForSymbolFromNameType(symbol, context, singleQuote, stringNamed, isMethod); if (fromNameType) { return fromNameType; } const rawName = unescapeLeadingUnderscores(symbol.escapedName); - return createPropertyNameNodeForIdentifierOrLiteral(rawName, getEmitScriptTarget(compilerOptions), singleQuote, stringNamed); + return createPropertyNameNodeForIdentifierOrLiteral(rawName, getEmitScriptTarget(compilerOptions), singleQuote, stringNamed, isMethod); } - function getPropertyNameNodeForSymbolFromNameType(symbol, context, singleQuote, stringNamed) { + function getPropertyNameNodeForSymbolFromNameType(symbol, context, singleQuote, stringNamed, isMethod) { const nameType = getSymbolLinks(symbol).nameType; if (nameType) { if (nameType.flags & 384 /* StringOrNumberLiteral */) { @@ -150252,7 +133818,7 @@ ${lanes.join("\n")} if (isNumericLiteralName(name) && startsWith(name, "-")) { return factory.createComputedPropertyName(factory.createNumericLiteral(+name)); } - return createPropertyNameNodeForIdentifierOrLiteral(name, getEmitScriptTarget(compilerOptions)); + return createPropertyNameNodeForIdentifierOrLiteral(name, getEmitScriptTarget(compilerOptions), singleQuote, stringNamed, isMethod); } if (nameType.flags & 8192 /* UniqueESSymbol */) { return factory.createComputedPropertyName(symbolToExpression(nameType.symbol, context, 111551 /* Value */)); @@ -150379,7 +133945,7 @@ ${lanes.join("\n")} } return transformed === existing ? setTextRange(factory.cloneNode(existing), existing) : transformed; function visitExistingNodeTreeSymbols(node) { - if (isJSDocAllType(node) || node.kind === 325 /* JSDocNamepathType */) { + if (isJSDocAllType(node) || node.kind === 326 /* JSDocNamepathType */) { return factory.createKeywordTypeNode(133 /* AnyKeyword */); } if (isJSDocUnknownType(node)) { @@ -150485,7 +134051,7 @@ ${lanes.join("\n")} return factory.updateImportTypeNode( node, factory.updateLiteralTypeNode(node.argument, rewriteModuleSpecifier(node, node.argument.literal)), - node.assertions, + node.attributes, node.qualifier, visitNodes2(node.typeArguments, visitExistingNodeTreeSymbols, isTypeNode), node.isTypeOf @@ -150541,15 +134107,16 @@ ${lanes.join("\n")} } } function symbolTableToDeclarationStatements(symbolTable, context, bundled) { + var _a; const serializePropertySymbolForClass = makeSerializePropertySymbol( factory.createPropertyDeclaration, - 173 /* MethodDeclaration */, + 174 /* MethodDeclaration */, /*useAccessors*/ true ); const serializePropertySymbolForInterfaceWorker = makeSerializePropertySymbol( (mods, name, question, type) => factory.createPropertySignature(mods, name, question, type), - 172 /* MethodSignature */, + 173 /* MethodSignature */, /*useAccessors*/ false ); @@ -150562,12 +134129,15 @@ ${lanes.join("\n")} ...oldcontext, usedSymbolNames: new Set(oldcontext.usedSymbolNames), remappedSymbolNames: /* @__PURE__ */ new Map(), + remappedSymbolReferences: new Map((_a = oldcontext.remappedSymbolReferences) == null ? void 0 : _a.entries()), tracker: void 0 }; const tracker = { ...oldcontext.tracker.inner, trackSymbol: (sym, decl, meaning) => { - var _a; + var _a2, _b; + if ((_a2 = context.remappedSymbolNames) == null ? void 0 : _a2.has(getSymbolId(sym))) + return false; const accessibleResult = isSymbolAccessible( sym, decl, @@ -150578,9 +134148,13 @@ ${lanes.join("\n")} if (accessibleResult.accessibility === 0 /* Accessible */) { const chain = lookupSymbolChainWorker(sym, context, meaning); if (!(sym.flags & 4 /* Property */)) { - includePrivateSymbol(chain[0]); + const root = chain[0]; + const contextFile = getSourceFileOfNode(oldcontext.enclosingDeclaration); + if (some(root.declarations, (d) => getSourceFileOfNode(d) === contextFile)) { + includePrivateSymbol(root); + } } - } else if ((_a = oldcontext.tracker.inner) == null ? void 0 : _a.trackSymbol) { + } else if ((_b = oldcontext.tracker.inner) == null ? void 0 : _b.trackSymbol) { return oldcontext.tracker.inner.trackSymbol(sym, decl, meaning); } return false; @@ -150613,7 +134187,7 @@ ${lanes.join("\n")} const nsIndex = findIndex(statements, isModuleDeclaration); let ns = nsIndex !== -1 ? statements[nsIndex] : void 0; if (ns && exportAssignment && exportAssignment.isExportEquals && isIdentifier(exportAssignment.expression) && isIdentifier(ns.name) && idText(ns.name) === idText(exportAssignment.expression) && ns.body && isModuleBlock(ns.body)) { - const excessExports = filter(statements, (s) => !!(getEffectiveModifierFlags(s) & 1 /* Export */)); + const excessExports = filter(statements, (s) => !!(getEffectiveModifierFlags(s) & 32 /* Export */)); const name = ns.name; let body = ns.body; if (length(excessExports)) { @@ -150623,30 +134197,33 @@ ${lanes.join("\n")} ns.name, body = factory.updateModuleBlock( body, - factory.createNodeArray([...ns.body.statements, factory.createExportDeclaration( - /*modifiers*/ - void 0, - /*isTypeOnly*/ - false, - factory.createNamedExports(map(flatMap(excessExports, (e) => getNamesOfDeclaration(e)), (id) => factory.createExportSpecifier( + factory.createNodeArray([ + ...ns.body.statements, + factory.createExportDeclaration( + /*modifiers*/ + void 0, /*isTypeOnly*/ false, - /*propertyName*/ - void 0, - id - ))), - /*moduleSpecifier*/ - void 0 - )]) + factory.createNamedExports(map(flatMap(excessExports, (e) => getNamesOfDeclaration(e)), (id) => factory.createExportSpecifier( + /*isTypeOnly*/ + false, + /*propertyName*/ + void 0, + id + ))), + /*moduleSpecifier*/ + void 0 + ) + ]) ) ); statements = [...statements.slice(0, nsIndex), ns, ...statements.slice(nsIndex + 1)]; } if (!find(statements, (s) => s !== ns && nodeHasName(s, name))) { results = []; - const mixinExportFlag = !some(body.statements, (s) => hasSyntacticModifier(s, 1 /* Export */) || isExportAssignment(s) || isExportDeclaration(s)); + const mixinExportFlag = !some(body.statements, (s) => hasSyntacticModifier(s, 32 /* Export */) || isExportAssignment(s) || isExportDeclaration(s)); forEach(body.statements, (s) => { - addResult(s, mixinExportFlag ? 1 /* Export */ : 0 /* None */); + addResult(s, mixinExportFlag ? 32 /* Export */ : 0 /* None */); }); statements = [...filter(statements, (s) => s !== ns && s !== exportAssignment), ...results]; } @@ -150657,15 +134234,18 @@ ${lanes.join("\n")} const exports = filter(statements, (d) => isExportDeclaration(d) && !d.moduleSpecifier && !!d.exportClause && isNamedExports(d.exportClause)); if (length(exports) > 1) { const nonExports = filter(statements, (d) => !isExportDeclaration(d) || !!d.moduleSpecifier || !d.exportClause); - statements = [...nonExports, factory.createExportDeclaration( - /*modifiers*/ - void 0, - /*isTypeOnly*/ - false, - factory.createNamedExports(flatMap(exports, (e) => cast(e.exportClause, isNamedExports).elements)), - /*moduleSpecifier*/ - void 0 - )]; + statements = [ + ...nonExports, + factory.createExportDeclaration( + /*modifiers*/ + void 0, + /*isTypeOnly*/ + false, + factory.createNamedExports(flatMap(exports, (e) => cast(e.exportClause, isNamedExports).elements)), + /*moduleSpecifier*/ + void 0 + ) + ]; } const reexports = filter(statements, (d) => isExportDeclaration(d) && !!d.moduleSpecifier && !!d.exportClause && isNamedExports(d.exportClause)); if (length(reexports) > 1) { @@ -150674,7 +134254,7 @@ ${lanes.join("\n")} for (const group2 of groups) { if (group2.length > 1) { statements = [ - ...filter(statements, (s) => group2.indexOf(s) === -1), + ...filter(statements, (s) => !group2.includes(s)), factory.createExportDeclaration( /*modifiers*/ void 0, @@ -150691,7 +134271,7 @@ ${lanes.join("\n")} return statements; } function inlineExportModifiers(statements) { - const index = findIndex(statements, (d) => isExportDeclaration(d) && !d.moduleSpecifier && !d.assertClause && !!d.exportClause && isNamedExports(d.exportClause)); + const index = findIndex(statements, (d) => isExportDeclaration(d) && !d.moduleSpecifier && !d.attributes && !!d.exportClause && isNamedExports(d.exportClause)); if (index >= 0) { const exportDecl = statements[index]; const replacements = mapDefined(exportDecl.exportClause.elements, (e) => { @@ -150719,7 +134299,7 @@ ${lanes.join("\n")} replacements ), exportDecl.moduleSpecifier, - exportDecl.assertClause + exportDecl.attributes ); } } @@ -150735,12 +134315,12 @@ ${lanes.join("\n")} return statements; } function addExportModifier(node) { - const flags = (getEffectiveModifierFlags(node) | 1 /* Export */) & ~2 /* Ambient */; - return factory.updateModifiers(node, flags); + const flags = (getEffectiveModifierFlags(node) | 32 /* Export */) & ~128 /* Ambient */; + return factory.replaceModifiers(node, flags); } function removeExportModifier(node) { - const flags = getEffectiveModifierFlags(node) & ~1 /* Export */; - return factory.updateModifiers(node, flags); + const flags = getEffectiveModifierFlags(node) & ~32 /* Export */; + return factory.replaceModifiers(node, flags); } function visitSymbolTable(symbolTable2, suppressNewPrivateContext, propertyAsAlias) { if (!suppressNewPrivateContext) { @@ -150780,13 +134360,19 @@ ${lanes.join("\n")} if (context.reportedDiagnostic) { oldcontext.reportedDiagnostic = context.reportedDiagnostic; } + if (context.trackedSymbols) { + if (!oldContext.trackedSymbols) + oldContext.trackedSymbols = context.trackedSymbols; + else + Debug.assert(context.trackedSymbols === oldContext.trackedSymbols); + } context = oldContext; } } - function serializeSymbolWorker(symbol, isPrivate, propertyAsAlias) { - var _a, _b, _c, _d; - const symbolName2 = unescapeLeadingUnderscores(symbol.escapedName); - const isDefault = symbol.escapedName === "default" /* Default */; + function serializeSymbolWorker(symbol, isPrivate, propertyAsAlias, escapedSymbolName = symbol.escapedName) { + var _a2, _b, _c, _d, _e, _f; + const symbolName2 = unescapeLeadingUnderscores(escapedSymbolName); + const isDefault = escapedSymbolName === "default" /* Default */; if (isPrivate && !(context.flags & 131072 /* AllowAnonymousIdentifier */) && isStringANonContextualKeyword(symbolName2) && !isDefault) { context.encounteredError = true; return; @@ -150796,8 +134382,8 @@ ${lanes.join("\n")} if (needsPostExportDefault || needsExportDeclaration) { isPrivate = true; } - const modifierFlags = (!isPrivate ? 1 /* Export */ : 0) | (isDefault && !needsPostExportDefault ? 1024 /* Default */ : 0); - const isConstMergedWithNS = symbol.flags & 1536 /* Module */ && symbol.flags & (2 /* BlockScopedVariable */ | 1 /* FunctionScopedVariable */ | 4 /* Property */) && symbol.escapedName !== "export=" /* ExportEquals */; + const modifierFlags = (!isPrivate ? 32 /* Export */ : 0) | (isDefault && !needsPostExportDefault ? 2048 /* Default */ : 0); + const isConstMergedWithNS = symbol.flags & 1536 /* Module */ && symbol.flags & (2 /* BlockScopedVariable */ | 1 /* FunctionScopedVariable */ | 4 /* Property */) && escapedSymbolName !== "export=" /* ExportEquals */; const isConstMergedWithNSPrintableAsSignatureMerge = isConstMergedWithNS && isTypeRepresentableAsFunctionNamespaceMerge(getTypeOfSymbol(symbol), symbol); if (symbol.flags & (16 /* Function */ | 8192 /* Method */) || isConstMergedWithNSPrintableAsSignatureMerge) { serializeAsFunctionNamespaceMerge(getTypeOfSymbol(symbol), symbol, getInternalSymbolName(symbol, symbolName2), modifierFlags); @@ -150805,7 +134391,7 @@ ${lanes.join("\n")} if (symbol.flags & 524288 /* TypeAlias */) { serializeTypeAlias(symbol, symbolName2, modifierFlags); } - if (symbol.flags & (2 /* BlockScopedVariable */ | 1 /* FunctionScopedVariable */ | 4 /* Property */ | 98304 /* Accessor */) && symbol.escapedName !== "export=" /* ExportEquals */ && !(symbol.flags & 4194304 /* Prototype */) && !(symbol.flags & 32 /* Class */) && !(symbol.flags & 8192 /* Method */) && !isConstMergedWithNSPrintableAsSignatureMerge) { + if (symbol.flags & (2 /* BlockScopedVariable */ | 1 /* FunctionScopedVariable */ | 4 /* Property */ | 98304 /* Accessor */) && escapedSymbolName !== "export=" /* ExportEquals */ && !(symbol.flags & 4194304 /* Prototype */) && !(symbol.flags & 32 /* Class */) && !(symbol.flags & 8192 /* Method */) && !isConstMergedWithNSPrintableAsSignatureMerge) { if (propertyAsAlias) { const createdExport = serializeMaybeAliasAssignment(symbol); if (createdExport) { @@ -150815,17 +134401,24 @@ ${lanes.join("\n")} } else { const type = getTypeOfSymbol(symbol); const localName = getInternalSymbolName(symbol, symbolName2); - if (!(symbol.flags & 16 /* Function */) && isTypeRepresentableAsFunctionNamespaceMerge(type, symbol)) { + if (type.symbol && type.symbol !== symbol && type.symbol.flags & 16 /* Function */ && some(type.symbol.declarations, isFunctionExpressionOrArrowFunction) && (((_a2 = type.symbol.members) == null ? void 0 : _a2.size) || ((_b = type.symbol.exports) == null ? void 0 : _b.size))) { + if (!context.remappedSymbolReferences) { + context.remappedSymbolReferences = /* @__PURE__ */ new Map(); + } + context.remappedSymbolReferences.set(getSymbolId(type.symbol), symbol); + serializeSymbolWorker(type.symbol, isPrivate, propertyAsAlias, escapedSymbolName); + context.remappedSymbolReferences.delete(getSymbolId(type.symbol)); + } else if (!(symbol.flags & 16 /* Function */) && isTypeRepresentableAsFunctionNamespaceMerge(type, symbol)) { serializeAsFunctionNamespaceMerge(type, symbol, localName, modifierFlags); } else { - const flags = !(symbol.flags & 2 /* BlockScopedVariable */) ? ((_a = symbol.parent) == null ? void 0 : _a.valueDeclaration) && isSourceFile((_b = symbol.parent) == null ? void 0 : _b.valueDeclaration) ? 2 /* Const */ : void 0 : isConstVariable(symbol) ? 2 /* Const */ : 1 /* Let */; + const flags = !(symbol.flags & 2 /* BlockScopedVariable */) ? ((_c = symbol.parent) == null ? void 0 : _c.valueDeclaration) && isSourceFile((_d = symbol.parent) == null ? void 0 : _d.valueDeclaration) ? 2 /* Const */ : void 0 : isConstantVariable(symbol) ? 2 /* Const */ : 1 /* Let */; const name = needsPostExportDefault || !(symbol.flags & 4 /* Property */) ? localName : getUnusedName(localName, symbol); let textRange = symbol.declarations && find(symbol.declarations, (d) => isVariableDeclaration(d)); if (textRange && isVariableDeclarationList(textRange.parent) && textRange.parent.declarations.length === 1) { textRange = textRange.parent.parent; } - const propertyAccessRequire = (_c = symbol.declarations) == null ? void 0 : _c.find(isPropertyAccessExpression); - if (propertyAccessRequire && isBinaryExpression(propertyAccessRequire.parent) && isIdentifier(propertyAccessRequire.parent.right) && ((_d = type.symbol) == null ? void 0 : _d.valueDeclaration) && isSourceFile(type.symbol.valueDeclaration)) { + const propertyAccessRequire = (_e = symbol.declarations) == null ? void 0 : _e.find(isPropertyAccessExpression); + if (propertyAccessRequire && isBinaryExpression(propertyAccessRequire.parent) && isIdentifier(propertyAccessRequire.parent.right) && ((_f = type.symbol) == null ? void 0 : _f.valueDeclaration) && isSourceFile(type.symbol.valueDeclaration)) { const alias = localName === propertyAccessRequire.parent.right.escapedText ? void 0 : propertyAccessRequire.parent.right; addResult( factory.createExportDeclaration( @@ -150844,19 +134437,22 @@ ${lanes.join("\n")} ); context.tracker.trackSymbol(type.symbol, context.enclosingDeclaration, 111551 /* Value */); } else { - const statement = setTextRange(factory.createVariableStatement( - /*modifiers*/ - void 0, - factory.createVariableDeclarationList([ - factory.createVariableDeclaration( - name, - /*exclamationToken*/ - void 0, - serializeTypeForDeclaration(context, type, symbol, enclosingDeclaration, includePrivateSymbol, bundled) - ) - ], flags) - ), textRange); - addResult(statement, name !== localName ? modifierFlags & ~1 /* Export */ : modifierFlags); + const statement = setTextRange( + factory.createVariableStatement( + /*modifiers*/ + void 0, + factory.createVariableDeclarationList([ + factory.createVariableDeclaration( + name, + /*exclamationToken*/ + void 0, + serializeTypeForDeclaration(context, type, symbol, enclosingDeclaration, includePrivateSymbol, bundled) + ) + ], flags) + ), + textRange + ); + addResult(statement, name !== localName ? modifierFlags & ~32 /* Export */ : modifierFlags); if (name !== localName && !isPrivate) { addResult( factory.createExportDeclaration( @@ -150929,18 +134525,21 @@ ${lanes.join("\n")} factory.createIdentifier(getInternalSymbolName(symbol, symbolName2)) ), 0 /* None */); } else if (needsExportDeclaration) { - addResult(factory.createExportDeclaration( - /*modifiers*/ - void 0, - /*isTypeOnly*/ - false, - factory.createNamedExports([factory.createExportSpecifier( + addResult( + factory.createExportDeclaration( + /*modifiers*/ + void 0, /*isTypeOnly*/ false, - getInternalSymbolName(symbol, symbolName2), - symbolName2 - )]) - ), 0 /* None */); + factory.createNamedExports([factory.createExportSpecifier( + /*isTypeOnly*/ + false, + getInternalSymbolName(symbol, symbolName2), + symbolName2 + )]) + ), + 0 /* None */ + ); } } function includePrivateSymbol(symbol) { @@ -150948,10 +134547,7 @@ ${lanes.join("\n")} return; Debug.assertIsDefined(deferredPrivatesStack[deferredPrivatesStack.length - 1]); getUnusedName(unescapeLeadingUnderscores(symbol.escapedName), symbol); - const isExternalImportAlias = !!(symbol.flags & 2097152 /* Alias */) && !some( - symbol.declarations, - (d) => !!findAncestor(d, isExportDeclaration) || isNamespaceExport(d) || isImportEqualsDeclaration(d) && !isExternalModuleReference(d.moduleReference) - ); + const isExternalImportAlias = !!(symbol.flags & 2097152 /* Alias */) && !some(symbol.declarations, (d) => !!findAncestor(d, isExportDeclaration) || isNamespaceExport(d) || isImportEqualsDeclaration(d) && !isExternalModuleReference(d.moduleReference)); deferredPrivatesStack[isExternalImportAlias ? 0 : deferredPrivatesStack.length - 1].set(getSymbolId(symbol), symbol); } function isExportingScope(enclosingDeclaration2) { @@ -150961,43 +134557,46 @@ ${lanes.join("\n")} if (canHaveModifiers(node)) { let newModifierFlags = 0 /* None */; const enclosingDeclaration2 = context.enclosingDeclaration && (isJSDocTypeAlias(context.enclosingDeclaration) ? getSourceFileOfNode(context.enclosingDeclaration) : context.enclosingDeclaration); - if (additionalModifierFlags & 1 /* Export */ && enclosingDeclaration2 && (isExportingScope(enclosingDeclaration2) || isModuleDeclaration(enclosingDeclaration2)) && canHaveExportModifier(node)) { - newModifierFlags |= 1 /* Export */; + if (additionalModifierFlags & 32 /* Export */ && enclosingDeclaration2 && (isExportingScope(enclosingDeclaration2) || isModuleDeclaration(enclosingDeclaration2)) && canHaveExportModifier(node)) { + newModifierFlags |= 32 /* Export */; } - if (addingDeclare && !(newModifierFlags & 1 /* Export */) && (!enclosingDeclaration2 || !(enclosingDeclaration2.flags & 16777216 /* Ambient */)) && (isEnumDeclaration(node) || isVariableStatement(node) || isFunctionDeclaration(node) || isClassDeclaration(node) || isModuleDeclaration(node))) { - newModifierFlags |= 2 /* Ambient */; + if (addingDeclare && !(newModifierFlags & 32 /* Export */) && (!enclosingDeclaration2 || !(enclosingDeclaration2.flags & 33554432 /* Ambient */)) && (isEnumDeclaration(node) || isVariableStatement(node) || isFunctionDeclaration(node) || isClassDeclaration(node) || isModuleDeclaration(node))) { + newModifierFlags |= 128 /* Ambient */; } - if (additionalModifierFlags & 1024 /* Default */ && (isClassDeclaration(node) || isInterfaceDeclaration(node) || isFunctionDeclaration(node))) { - newModifierFlags |= 1024 /* Default */; + if (additionalModifierFlags & 2048 /* Default */ && (isClassDeclaration(node) || isInterfaceDeclaration(node) || isFunctionDeclaration(node))) { + newModifierFlags |= 2048 /* Default */; } if (newModifierFlags) { - node = factory.updateModifiers(node, newModifierFlags | getEffectiveModifierFlags(node)); + node = factory.replaceModifiers(node, newModifierFlags | getEffectiveModifierFlags(node)); } } results.push(node); } function serializeTypeAlias(symbol, symbolName2, modifierFlags) { - var _a; + var _a2; const aliasType = getDeclaredTypeOfTypeAlias(symbol); const typeParams = getSymbolLinks(symbol).typeParameters; const typeParamDecls = map(typeParams, (p) => typeParameterToDeclaration(p, context)); - const jsdocAliasDecl = (_a = symbol.declarations) == null ? void 0 : _a.find(isJSDocTypeAlias); + const jsdocAliasDecl = (_a2 = symbol.declarations) == null ? void 0 : _a2.find(isJSDocTypeAlias); const commentText = getTextOfJSDocComment(jsdocAliasDecl ? jsdocAliasDecl.comment || jsdocAliasDecl.parent.comment : void 0); const oldFlags = context.flags; context.flags |= 8388608 /* InTypeAlias */; const oldEnclosingDecl = context.enclosingDeclaration; context.enclosingDeclaration = jsdocAliasDecl; const typeNode = jsdocAliasDecl && jsdocAliasDecl.typeExpression && isJSDocTypeExpression(jsdocAliasDecl.typeExpression) && serializeExistingTypeNode(context, jsdocAliasDecl.typeExpression.type, includePrivateSymbol, bundled) || typeToTypeNodeHelper(aliasType, context); - addResult(setSyntheticLeadingComments( - factory.createTypeAliasDeclaration( - /*modifiers*/ - void 0, - getInternalSymbolName(symbol, symbolName2), - typeParamDecls, - typeNode + addResult( + setSyntheticLeadingComments( + factory.createTypeAliasDeclaration( + /*modifiers*/ + void 0, + getInternalSymbolName(symbol, symbolName2), + typeParamDecls, + typeNode + ), + !commentText ? [] : [{ kind: 3 /* MultiLineCommentTrivia */, text: "*\n * " + commentText.replace(/\n/g, "\n * ") + "\n ", pos: -1, end: -1, hasTrailingNewLine: true }] ), - !commentText ? [] : [{ kind: 3 /* MultiLineCommentTrivia */, text: "*\n * " + commentText.replace(/\n/g, "\n * ") + "\n ", pos: -1, end: -1, hasTrailingNewLine: true }] - ), modifierFlags); + modifierFlags + ); context.flags = oldFlags; context.enclosingDeclaration = oldEnclosingDecl; } @@ -151008,25 +134607,28 @@ ${lanes.join("\n")} const baseTypes = getBaseTypes(interfaceType); const baseType = length(baseTypes) ? getIntersectionType(baseTypes) : void 0; const members = flatMap(getPropertiesOfType(interfaceType), (p) => serializePropertySymbolForInterface(p, baseType)); - const callSignatures = serializeSignatures(0 /* Call */, interfaceType, baseType, 178 /* CallSignature */); - const constructSignatures = serializeSignatures(1 /* Construct */, interfaceType, baseType, 179 /* ConstructSignature */); + const callSignatures = serializeSignatures(0 /* Call */, interfaceType, baseType, 179 /* CallSignature */); + const constructSignatures = serializeSignatures(1 /* Construct */, interfaceType, baseType, 180 /* ConstructSignature */); const indexSignatures = serializeIndexSignatures(interfaceType, baseType); const heritageClauses = !length(baseTypes) ? void 0 : [factory.createHeritageClause(96 /* ExtendsKeyword */, mapDefined(baseTypes, (b) => trySerializeAsTypeReference(b, 111551 /* Value */)))]; - addResult(factory.createInterfaceDeclaration( - /*modifiers*/ - void 0, - getInternalSymbolName(symbol, symbolName2), - typeParamDecls, - heritageClauses, - [...indexSignatures, ...constructSignatures, ...callSignatures, ...members] - ), modifierFlags); + addResult( + factory.createInterfaceDeclaration( + /*modifiers*/ + void 0, + getInternalSymbolName(symbol, symbolName2), + typeParamDecls, + heritageClauses, + [...indexSignatures, ...constructSignatures, ...callSignatures, ...members] + ), + modifierFlags + ); } function getNamespaceMembersForSerialization(symbol) { const exports = getExportsOfSymbol(symbol); return !exports ? [] : filter(arrayFrom(exports.values()), (m) => isNamespaceMember(m) && isIdentifierText(m.escapedName, 99 /* ESNext */)); } function isTypeOnlyNamespace(symbol) { - return every(getNamespaceMembersForSerialization(symbol), (m) => !(getAllSymbolFlags(resolveSymbol(m)) & 111551 /* Value */)); + return every(getNamespaceMembersForSerialization(symbol), (m) => !(getSymbolFlags(resolveSymbol(m)) & 111551 /* Value */)); } function serializeModule(symbol, symbolName2, modifierFlags) { const members = getNamespaceMembersForSerialization(symbol); @@ -151046,12 +134648,12 @@ ${lanes.join("\n")} /*isTypeOnly*/ false, factory.createNamedExports(mapDefined(filter(mergedMembers, (n) => n.escapedName !== "export=" /* ExportEquals */), (s) => { - var _a, _b; + var _a2, _b; const name = unescapeLeadingUnderscores(s.escapedName); const localName2 = getInternalSymbolName(s, name); const aliasDecl = s.declarations && getDeclarationOfAliasSymbol(s); if (containingFile && (aliasDecl ? containingFile !== getSourceFileOfNode(aliasDecl) : !some(s.declarations, (d) => getSourceFileOfNode(d) === containingFile))) { - (_b = (_a = context.tracker) == null ? void 0 : _a.reportNonlocalAugmentation) == null ? void 0 : _b.call(_a, containingFile, symbol, s); + (_b = (_a2 = context.tracker) == null ? void 0 : _a2.reportNonlocalAugmentation) == null ? void 0 : _b.call(_a2, containingFile, symbol, s); return void 0; } const target = aliasDecl && getTargetOfAliasDeclaration( @@ -151069,29 +134671,38 @@ ${lanes.join("\n")} ); })) )]); - addResult(factory.createModuleDeclaration( - /*modifiers*/ - void 0, - factory.createIdentifier(localName), - nsBody, - 16 /* Namespace */ - ), 0 /* None */); + addResult( + factory.createModuleDeclaration( + /*modifiers*/ + void 0, + factory.createIdentifier(localName), + nsBody, + 32 /* Namespace */ + ), + 0 /* None */ + ); } } function serializeEnum(symbol, symbolName2, modifierFlags) { - addResult(factory.createEnumDeclaration( - factory.createModifiersFromModifierFlags(isConstEnumSymbol(symbol) ? 2048 /* Const */ : 0), - getInternalSymbolName(symbol, symbolName2), - map(filter(getPropertiesOfType(getTypeOfSymbol(symbol)), (p) => !!(p.flags & 8 /* EnumMember */)), (p) => { - const initializedValue = p.declarations && p.declarations[0] && isEnumMember(p.declarations[0]) ? getConstantValue2(p.declarations[0]) : void 0; - return factory.createEnumMember(unescapeLeadingUnderscores(p.escapedName), initializedValue === void 0 ? void 0 : typeof initializedValue === "string" ? factory.createStringLiteral(initializedValue) : factory.createNumericLiteral(initializedValue)); - }) - ), modifierFlags); + addResult( + factory.createEnumDeclaration( + factory.createModifiersFromModifierFlags(isConstEnumSymbol(symbol) ? 4096 /* Const */ : 0), + getInternalSymbolName(symbol, symbolName2), + map(filter(getPropertiesOfType(getTypeOfSymbol(symbol)), (p) => !!(p.flags & 8 /* EnumMember */)), (p) => { + const initializedValue = p.declarations && p.declarations[0] && isEnumMember(p.declarations[0]) ? getConstantValue2(p.declarations[0]) : void 0; + return factory.createEnumMember( + unescapeLeadingUnderscores(p.escapedName), + initializedValue === void 0 ? void 0 : typeof initializedValue === "string" ? factory.createStringLiteral(initializedValue) : factory.createNumericLiteral(initializedValue) + ); + }) + ), + modifierFlags + ); } function serializeAsFunctionNamespaceMerge(type, symbol, localName, modifierFlags) { const signatures = getSignaturesOfType(type, 0 /* Call */); for (const sig of signatures) { - const decl = signatureToSignatureDeclarationHelper(sig, 261 /* FunctionDeclaration */, context, { name: factory.createIdentifier(localName), privateSymbolVisitor: includePrivateSymbol, bundledImports: bundled }); + const decl = signatureToSignatureDeclarationHelper(sig, 262 /* FunctionDeclaration */, context, { name: factory.createIdentifier(localName), privateSymbolVisitor: includePrivateSymbol, bundledImports: bundled }); addResult(setTextRange(decl, getSignatureTextRangeLocation(sig)), modifierFlags); } if (!(symbol.flags & (512 /* ValueModule */ | 1024 /* NamespaceModule */) && !!symbol.exports && !!symbol.exports.size)) { @@ -151118,20 +134729,14 @@ ${lanes.join("\n")} } function serializeAsNamespaceDeclaration(props, localName, modifierFlags, suppressNewPrivateContext) { if (length(props)) { - const localVsRemoteMap = arrayToMultiMap( - props, - (p) => !length(p.declarations) || some( - p.declarations, - (d) => getSourceFileOfNode(d) === getSourceFileOfNode(context.enclosingDeclaration) - ) ? "local" : "remote" - ); + const localVsRemoteMap = arrayToMultiMap(props, (p) => !length(p.declarations) || some(p.declarations, (d) => getSourceFileOfNode(d) === getSourceFileOfNode(context.enclosingDeclaration)) ? "local" : "remote"); const localProps = localVsRemoteMap.get("local") || emptyArray; let fakespace = parseNodeFactory.createModuleDeclaration( /*modifiers*/ void 0, factory.createIdentifier(localName), factory.createModuleBlock([]), - 16 /* Namespace */ + 32 /* Namespace */ ); setParent(fakespace, enclosingDeclaration); fakespace.locals = createSymbolTable(props); @@ -151165,7 +134770,7 @@ ${lanes.join("\n")} factory.createIdentifier("default" /* Default */) )]) ) : d); - const exportModifierStripped = every(defaultReplaced, (d) => hasSyntacticModifier(d, 1 /* Export */)) ? map(defaultReplaced, removeExportModifier) : defaultReplaced; + const exportModifierStripped = every(defaultReplaced, (d) => hasSyntacticModifier(d, 32 /* Export */)) ? map(defaultReplaced, removeExportModifier) : defaultReplaced; fakespace = factory.updateModuleDeclaration( fakespace, fakespace.modifiers, @@ -151201,10 +134806,7 @@ ${lanes.join("\n")} } return cleanup(factory.createExpressionWithTypeArguments( expr, - map( - e.typeArguments, - (a) => serializeExistingTypeNode(context, a, includePrivateSymbol, bundled) || typeToTypeNodeHelper(getTypeFromTypeNode(a), context) - ) + map(e.typeArguments, (a) => serializeExistingTypeNode(context, a, includePrivateSymbol, bundled) || typeToTypeNodeHelper(getTypeFromTypeNode(a), context)) )); function cleanup(result2) { context.enclosingDeclaration = oldEnclosing; @@ -151217,8 +134819,8 @@ ${lanes.join("\n")} return void 0; } function serializeAsClass(symbol, localName, modifierFlags) { - var _a, _b; - const originalDecl = (_a = symbol.declarations) == null ? void 0 : _a.find(isClassLike); + var _a2, _b; + const originalDecl = (_a2 = symbol.declarations) == null ? void 0 : _a2.find(isClassLike); const oldEnclosing = context.enclosingDeclaration; context.enclosingDeclaration = originalDecl || oldEnclosing; const localParams = getLocalTypeParametersOfClassOrInterfaceOrTypeAlias(symbol); @@ -151271,21 +134873,27 @@ ${lanes.join("\n")} ); const isNonConstructableClassLikeInJsFile = !isClass && !!symbol.valueDeclaration && isInJSFile(symbol.valueDeclaration) && !some(getSignaturesOfType(staticType, 1 /* Construct */)); const constructors = isNonConstructableClassLikeInJsFile ? [factory.createConstructorDeclaration( - factory.createModifiersFromModifierFlags(8 /* Private */), + factory.createModifiersFromModifierFlags(2 /* Private */), [], /*body*/ void 0 - )] : serializeSignatures(1 /* Construct */, staticType, staticBaseType, 175 /* Constructor */); + )] : serializeSignatures(1 /* Construct */, staticType, staticBaseType, 176 /* Constructor */); const indexSignatures = serializeIndexSignatures(classType, baseTypes[0]); context.enclosingDeclaration = oldEnclosing; - addResult(setTextRange(factory.createClassDeclaration( - /*modifiers*/ - void 0, - localName, - typeParamDecls, - heritageClauses, - [...indexSignatures, ...staticMembers, ...constructors, ...publicProperties, ...privateProperties] - ), symbol.declarations && filter(symbol.declarations, (d) => isClassDeclaration(d) || isClassExpression(d))[0]), modifierFlags); + addResult( + setTextRange( + factory.createClassDeclaration( + /*modifiers*/ + void 0, + localName, + typeParamDecls, + heritageClauses, + [...indexSignatures, ...staticMembers, ...constructors, ...publicProperties, ...privateProperties] + ), + symbol.declarations && filter(symbol.declarations, (d) => isClassDeclaration(d) || isClassExpression(d))[0] + ), + modifierFlags + ); } function getSomeTargetNameFromDeclarations(declarations) { return firstDefined(declarations, (d) => { @@ -151308,7 +134916,7 @@ ${lanes.join("\n")} }); } function serializeAsAlias(symbol, localName, modifierFlags) { - var _a, _b, _c, _d, _e; + var _a2, _b, _c, _d, _e; const node = getDeclarationOfAliasSymbol(symbol); if (!node) return Debug.fail(); @@ -151327,160 +134935,184 @@ ${lanes.join("\n")} const targetName = getInternalSymbolName(target, verbatimTargetName); includePrivateSymbol(target); switch (node.kind) { - case 207 /* BindingElement */: - if (((_b = (_a = node.parent) == null ? void 0 : _a.parent) == null ? void 0 : _b.kind) === 259 /* VariableDeclaration */) { + case 208 /* BindingElement */: + if (((_b = (_a2 = node.parent) == null ? void 0 : _a2.parent) == null ? void 0 : _b.kind) === 260 /* VariableDeclaration */) { const specifier2 = getSpecifierForModuleSymbol(target.parent || target, context); const { propertyName } = node; - addResult(factory.createImportDeclaration( - /*modifiers*/ - void 0, - factory.createImportClause( - /*isTypeOnly*/ - false, - /*name*/ + addResult( + factory.createImportDeclaration( + /*modifiers*/ void 0, - factory.createNamedImports([factory.createImportSpecifier( + factory.createImportClause( /*isTypeOnly*/ false, - propertyName && isIdentifier(propertyName) ? factory.createIdentifier(idText(propertyName)) : void 0, - factory.createIdentifier(localName) - )]) + /*name*/ + void 0, + factory.createNamedImports([factory.createImportSpecifier( + /*isTypeOnly*/ + false, + propertyName && isIdentifier(propertyName) ? factory.createIdentifier(idText(propertyName)) : void 0, + factory.createIdentifier(localName) + )]) + ), + factory.createStringLiteral(specifier2), + /*attributes*/ + void 0 ), - factory.createStringLiteral(specifier2), - /*assertClause*/ - void 0 - ), 0 /* None */); + 0 /* None */ + ); break; } Debug.failBadSyntaxKind(((_c = node.parent) == null ? void 0 : _c.parent) || node, "Unhandled binding element grandparent kind in declaration serialization"); break; - case 303 /* ShorthandPropertyAssignment */: - if (((_e = (_d = node.parent) == null ? void 0 : _d.parent) == null ? void 0 : _e.kind) === 225 /* BinaryExpression */) { + case 304 /* ShorthandPropertyAssignment */: + if (((_e = (_d = node.parent) == null ? void 0 : _d.parent) == null ? void 0 : _e.kind) === 226 /* BinaryExpression */) { serializeExportSpecifier( unescapeLeadingUnderscores(symbol.escapedName), targetName ); } break; - case 259 /* VariableDeclaration */: + case 260 /* VariableDeclaration */: if (isPropertyAccessExpression(node.initializer)) { const initializer = node.initializer; const uniqueName = factory.createUniqueName(localName); const specifier2 = getSpecifierForModuleSymbol(target.parent || target, context); - addResult(factory.createImportEqualsDeclaration( - /*modifiers*/ - void 0, - /*isTypeOnly*/ - false, - uniqueName, - factory.createExternalModuleReference(factory.createStringLiteral(specifier2)) - ), 0 /* None */); - addResult(factory.createImportEqualsDeclaration( - /*modifiers*/ - void 0, - /*isTypeOnly*/ - false, - factory.createIdentifier(localName), - factory.createQualifiedName(uniqueName, initializer.name) - ), modifierFlags); + addResult( + factory.createImportEqualsDeclaration( + /*modifiers*/ + void 0, + /*isTypeOnly*/ + false, + uniqueName, + factory.createExternalModuleReference(factory.createStringLiteral(specifier2)) + ), + 0 /* None */ + ); + addResult( + factory.createImportEqualsDeclaration( + /*modifiers*/ + void 0, + /*isTypeOnly*/ + false, + factory.createIdentifier(localName), + factory.createQualifiedName(uniqueName, initializer.name) + ), + modifierFlags + ); break; } - case 270 /* ImportEqualsDeclaration */: + case 271 /* ImportEqualsDeclaration */: if (target.escapedName === "export=" /* ExportEquals */ && some(target.declarations, (d) => isSourceFile(d) && isJsonSourceFile(d))) { serializeMaybeAliasAssignment(symbol); break; } const isLocalImport = !(target.flags & 512 /* ValueModule */) && !isVariableDeclaration(node); - addResult(factory.createImportEqualsDeclaration( - /*modifiers*/ - void 0, - /*isTypeOnly*/ - false, - factory.createIdentifier(localName), - isLocalImport ? symbolToName( - target, - context, - 67108863 /* All */, - /*expectsIdentifier*/ - false - ) : factory.createExternalModuleReference(factory.createStringLiteral(getSpecifierForModuleSymbol(target, context))) - ), isLocalImport ? modifierFlags : 0 /* None */); + addResult( + factory.createImportEqualsDeclaration( + /*modifiers*/ + void 0, + /*isTypeOnly*/ + false, + factory.createIdentifier(localName), + isLocalImport ? symbolToName( + target, + context, + 67108863 /* All */, + /*expectsIdentifier*/ + false + ) : factory.createExternalModuleReference(factory.createStringLiteral(getSpecifierForModuleSymbol(target, context))) + ), + isLocalImport ? modifierFlags : 0 /* None */ + ); break; - case 269 /* NamespaceExportDeclaration */: + case 270 /* NamespaceExportDeclaration */: addResult(factory.createNamespaceExportDeclaration(idText(node.name)), 0 /* None */); break; - case 272 /* ImportClause */: { + case 273 /* ImportClause */: { const generatedSpecifier = getSpecifierForModuleSymbol(target.parent || target, context); const specifier2 = bundled ? factory.createStringLiteral(generatedSpecifier) : node.parent.moduleSpecifier; - addResult(factory.createImportDeclaration( - /*modifiers*/ - void 0, - factory.createImportClause( - /*isTypeOnly*/ - false, - factory.createIdentifier(localName), - /*namedBindings*/ - void 0 + addResult( + factory.createImportDeclaration( + /*modifiers*/ + void 0, + factory.createImportClause( + /*isTypeOnly*/ + false, + factory.createIdentifier(localName), + /*namedBindings*/ + void 0 + ), + specifier2, + node.parent.attributes ), - specifier2, - node.parent.assertClause - ), 0 /* None */); + 0 /* None */ + ); break; } - case 273 /* NamespaceImport */: { + case 274 /* NamespaceImport */: { const generatedSpecifier = getSpecifierForModuleSymbol(target.parent || target, context); const specifier2 = bundled ? factory.createStringLiteral(generatedSpecifier) : node.parent.parent.moduleSpecifier; - addResult(factory.createImportDeclaration( - /*modifiers*/ - void 0, - factory.createImportClause( - /*isTypeOnly*/ - false, - /*name*/ + addResult( + factory.createImportDeclaration( + /*modifiers*/ void 0, - factory.createNamespaceImport(factory.createIdentifier(localName)) + factory.createImportClause( + /*isTypeOnly*/ + false, + /*name*/ + void 0, + factory.createNamespaceImport(factory.createIdentifier(localName)) + ), + specifier2, + node.parent.attributes ), - specifier2, - node.parent.parent.assertClause - ), 0 /* None */); + 0 /* None */ + ); break; } - case 279 /* NamespaceExport */: - addResult(factory.createExportDeclaration( - /*modifiers*/ - void 0, - /*isTypeOnly*/ - false, - factory.createNamespaceExport(factory.createIdentifier(localName)), - factory.createStringLiteral(getSpecifierForModuleSymbol(target, context)) - ), 0 /* None */); + case 280 /* NamespaceExport */: + addResult( + factory.createExportDeclaration( + /*modifiers*/ + void 0, + /*isTypeOnly*/ + false, + factory.createNamespaceExport(factory.createIdentifier(localName)), + factory.createStringLiteral(getSpecifierForModuleSymbol(target, context)) + ), + 0 /* None */ + ); break; - case 275 /* ImportSpecifier */: { + case 276 /* ImportSpecifier */: { const generatedSpecifier = getSpecifierForModuleSymbol(target.parent || target, context); const specifier2 = bundled ? factory.createStringLiteral(generatedSpecifier) : node.parent.parent.parent.moduleSpecifier; - addResult(factory.createImportDeclaration( - /*modifiers*/ - void 0, - factory.createImportClause( - /*isTypeOnly*/ - false, - /*name*/ + addResult( + factory.createImportDeclaration( + /*modifiers*/ void 0, - factory.createNamedImports([ - factory.createImportSpecifier( - /*isTypeOnly*/ - false, - localName !== verbatimTargetName ? factory.createIdentifier(verbatimTargetName) : void 0, - factory.createIdentifier(localName) - ) - ]) + factory.createImportClause( + /*isTypeOnly*/ + false, + /*name*/ + void 0, + factory.createNamedImports([ + factory.createImportSpecifier( + /*isTypeOnly*/ + false, + localName !== verbatimTargetName ? factory.createIdentifier(verbatimTargetName) : void 0, + factory.createIdentifier(localName) + ) + ]) + ), + specifier2, + node.parent.parent.parent.attributes ), - specifier2, - node.parent.parent.parent.assertClause - ), 0 /* None */); + 0 /* None */ + ); break; } - case 280 /* ExportSpecifier */: + case 281 /* ExportSpecifier */: const specifier = node.parent.parent.moduleSpecifier; serializeExportSpecifier( unescapeLeadingUnderscores(symbol.escapedName), @@ -151488,12 +135120,12 @@ ${lanes.join("\n")} specifier && isStringLiteralLike(specifier) ? factory.createStringLiteral(specifier.text) : void 0 ); break; - case 276 /* ExportAssignment */: + case 277 /* ExportAssignment */: serializeMaybeAliasAssignment(symbol); break; - case 225 /* BinaryExpression */: - case 210 /* PropertyAccessExpression */: - case 211 /* ElementAccessExpression */: + case 226 /* BinaryExpression */: + case 211 /* PropertyAccessExpression */: + case 212 /* ElementAccessExpression */: if (symbol.escapedName === "default" /* Default */ || symbol.escapedName === "export=" /* ExportEquals */) { serializeMaybeAliasAssignment(symbol); } else { @@ -151505,22 +135137,25 @@ ${lanes.join("\n")} } } function serializeExportSpecifier(localName, targetName, specifier) { - addResult(factory.createExportDeclaration( - /*modifiers*/ - void 0, - /*isTypeOnly*/ - false, - factory.createNamedExports([factory.createExportSpecifier( + addResult( + factory.createExportDeclaration( + /*modifiers*/ + void 0, /*isTypeOnly*/ false, - localName !== targetName ? targetName : void 0, - localName - )]), - specifier - ), 0 /* None */); + factory.createNamedExports([factory.createExportSpecifier( + /*isTypeOnly*/ + false, + localName !== targetName ? targetName : void 0, + localName + )]), + specifier + ), + 0 /* None */ + ); } function serializeMaybeAliasAssignment(symbol) { - var _a; + var _a2; if (symbol.flags & 4194304 /* Prototype */) { return false; } @@ -151565,20 +135200,23 @@ ${lanes.join("\n")} serializeExportSpecifier(name, getInternalSymbolName(target, symbolName(target))); } else { const varName = getUnusedName(name, symbol); - addResult(factory.createImportEqualsDeclaration( - /*modifiers*/ - void 0, - /*isTypeOnly*/ - false, - factory.createIdentifier(varName), - symbolToName( - target, - context, - 67108863 /* All */, - /*expectsIdentifier*/ - false - ) - ), 0 /* None */); + addResult( + factory.createImportEqualsDeclaration( + /*modifiers*/ + void 0, + /*isTypeOnly*/ + false, + factory.createIdentifier(varName), + symbolToName( + target, + context, + 67108863 /* All */, + /*expectsIdentifier*/ + false + ) + ), + 0 /* None */ + ); serializeExportSpecifier(name, varName); } } @@ -151588,8 +135226,9 @@ ${lanes.join("\n")} const varName = getUnusedName(name, symbol); const typeToSerialize = getWidenedType(getTypeOfSymbol(getMergedSymbol(symbol))); if (isTypeRepresentableAsFunctionNamespaceMerge(typeToSerialize, symbol)) { - serializeAsFunctionNamespaceMerge(typeToSerialize, symbol, varName, isExportAssignmentCompatibleSymbolName ? 0 /* None */ : 1 /* Export */); + serializeAsFunctionNamespaceMerge(typeToSerialize, symbol, varName, isExportAssignmentCompatibleSymbolName ? 0 /* None */ : 32 /* Export */); } else { + const flags = ((_a2 = context.enclosingDeclaration) == null ? void 0 : _a2.kind) === 267 /* ModuleDeclaration */ && (!(symbol.flags & 98304 /* Accessor */) || symbol.flags & 65536 /* SetAccessor */) ? 1 /* Let */ : 2 /* Const */; const statement = factory.createVariableStatement( /*modifiers*/ void 0, @@ -151600,11 +135239,11 @@ ${lanes.join("\n")} void 0, serializeTypeForDeclaration(context, typeToSerialize, symbol, enclosingDeclaration, includePrivateSymbol, bundled) ) - ], ((_a = context.enclosingDeclaration) == null ? void 0 : _a.kind) === 266 /* ModuleDeclaration */ ? 1 /* Let */ : 2 /* Const */) + ], flags) ); addResult( statement, - target && target.flags & 4 /* Property */ && target.escapedName === "export=" /* ExportEquals */ ? 2 /* Ambient */ : name === varName ? 1 /* Export */ : 0 /* None */ + target && target.flags & 4 /* Property */ && target.escapedName === "export=" /* ExportEquals */ ? 128 /* Ambient */ : name === varName ? 32 /* Export */ : 0 /* None */ ); } if (isExportAssignmentCompatibleSymbolName) { @@ -151626,79 +135265,114 @@ ${lanes.join("\n")} const ctxSrc = getSourceFileOfNode(context.enclosingDeclaration); return getObjectFlags(typeToSerialize) & (16 /* Anonymous */ | 32 /* Mapped */) && !length(getIndexInfosOfType(typeToSerialize)) && !isClassInstanceSide(typeToSerialize) && // While a class instance is potentially representable as a NS, prefer printing a reference to the instance type and serializing the class !!(length(filter(getPropertiesOfType(typeToSerialize), isNamespaceMember)) || length(getSignaturesOfType(typeToSerialize, 0 /* Call */))) && !length(getSignaturesOfType(typeToSerialize, 1 /* Construct */)) && // TODO: could probably serialize as function + ns + class, now that that's OK - !getDeclarationWithTypeAnnotation(hostSymbol, enclosingDeclaration) && !(typeToSerialize.symbol && some(typeToSerialize.symbol.declarations, (d) => getSourceFileOfNode(d) !== ctxSrc)) && !some(getPropertiesOfType(typeToSerialize), (p) => isLateBoundName(p.escapedName)) && !some(getPropertiesOfType(typeToSerialize), (p) => some(p.declarations, (d) => getSourceFileOfNode(d) !== ctxSrc)) && every(getPropertiesOfType(typeToSerialize), (p) => isIdentifierText(symbolName(p), languageVersion)); + !getDeclarationWithTypeAnnotation(hostSymbol, enclosingDeclaration) && !(typeToSerialize.symbol && some(typeToSerialize.symbol.declarations, (d) => getSourceFileOfNode(d) !== ctxSrc)) && !some(getPropertiesOfType(typeToSerialize), (p) => isLateBoundName(p.escapedName)) && !some(getPropertiesOfType(typeToSerialize), (p) => some(p.declarations, (d) => getSourceFileOfNode(d) !== ctxSrc)) && every(getPropertiesOfType(typeToSerialize), (p) => { + if (!isIdentifierText(symbolName(p), languageVersion)) { + return false; + } + if (!(p.flags & 98304 /* Accessor */)) { + return true; + } + return getNonMissingTypeOfSymbol(p) === getWriteTypeOfSymbol(p); + }); } function makeSerializePropertySymbol(createProperty2, methodKind, useAccessors) { return function serializePropertySymbol(p, isStatic2, baseType) { - var _a, _b, _c, _d, _e; + var _a2, _b, _c, _d, _e; const modifierFlags = getDeclarationModifierFlagsFromSymbol(p); - const isPrivate = !!(modifierFlags & 8 /* Private */); + const isPrivate = !!(modifierFlags & 2 /* Private */); if (isStatic2 && p.flags & (788968 /* Type */ | 1920 /* Namespace */ | 2097152 /* Alias */)) { return []; } if (p.flags & 4194304 /* Prototype */ || p.escapedName === "constructor" || baseType && getPropertyOfType(baseType, p.escapedName) && isReadonlySymbol(getPropertyOfType(baseType, p.escapedName)) === isReadonlySymbol(p) && (p.flags & 16777216 /* Optional */) === (getPropertyOfType(baseType, p.escapedName).flags & 16777216 /* Optional */) && isTypeIdenticalTo(getTypeOfSymbol(p), getTypeOfPropertyOfType(baseType, p.escapedName))) { return []; } - const flag = modifierFlags & ~512 /* Async */ | (isStatic2 ? 32 /* Static */ : 0); + const flag = modifierFlags & ~1024 /* Async */ | (isStatic2 ? 256 /* Static */ : 0); const name = getPropertyNameNodeForSymbol(p, context); - const firstPropertyLikeDecl = (_a = p.declarations) == null ? void 0 : _a.find(or(isPropertyDeclaration, isAccessor, isVariableDeclaration, isPropertySignature, isBinaryExpression, isPropertyAccessExpression)); + const firstPropertyLikeDecl = (_a2 = p.declarations) == null ? void 0 : _a2.find(or(isPropertyDeclaration, isAccessor, isVariableDeclaration, isPropertySignature, isBinaryExpression, isPropertyAccessExpression)); if (p.flags & 98304 /* Accessor */ && useAccessors) { const result = []; if (p.flags & 65536 /* SetAccessor */) { - result.push(setTextRange(factory.createSetAccessorDeclaration( - factory.createModifiersFromModifierFlags(flag), - name, - [factory.createParameterDeclaration( - /*modifiers*/ - void 0, - /*dotDotDotToken*/ - void 0, - "arg", - /*questionToken*/ - void 0, - isPrivate ? void 0 : serializeTypeForDeclaration(context, getTypeOfSymbol(p), p, enclosingDeclaration, includePrivateSymbol, bundled) - )], - /*body*/ - void 0 - ), ((_b = p.declarations) == null ? void 0 : _b.find(isSetAccessor)) || firstPropertyLikeDecl)); + const setter = p.declarations && forEach(p.declarations, (d) => { + if (d.kind === 178 /* SetAccessor */) { + return d; + } + if (isCallExpression(d) && isBindableObjectDefinePropertyCall(d)) { + return forEach(d.arguments[2].properties, (propDecl) => { + const id = getNameOfDeclaration(propDecl); + if (!!id && isIdentifier(id) && idText(id) === "set") { + return propDecl; + } + }); + } + }); + Debug.assert(!!setter); + const paramSymbol = isFunctionLikeDeclaration(setter) ? getSignatureFromDeclaration(setter).parameters[0] : void 0; + result.push(setTextRange( + factory.createSetAccessorDeclaration( + factory.createModifiersFromModifierFlags(flag), + name, + [factory.createParameterDeclaration( + /*modifiers*/ + void 0, + /*dotDotDotToken*/ + void 0, + paramSymbol ? parameterToParameterDeclarationName(paramSymbol, getEffectiveParameterDeclaration(paramSymbol), context) : "value", + /*questionToken*/ + void 0, + isPrivate ? void 0 : serializeTypeForDeclaration(context, getTypeOfSymbol(p), p, enclosingDeclaration, includePrivateSymbol, bundled) + )], + /*body*/ + void 0 + ), + ((_b = p.declarations) == null ? void 0 : _b.find(isSetAccessor)) || firstPropertyLikeDecl + )); } if (p.flags & 32768 /* GetAccessor */) { - const isPrivate2 = modifierFlags & 8 /* Private */; - result.push(setTextRange(factory.createGetAccessorDeclaration( - factory.createModifiersFromModifierFlags(flag), - name, - [], - isPrivate2 ? void 0 : serializeTypeForDeclaration(context, getTypeOfSymbol(p), p, enclosingDeclaration, includePrivateSymbol, bundled), - /*body*/ - void 0 - ), ((_c = p.declarations) == null ? void 0 : _c.find(isGetAccessor)) || firstPropertyLikeDecl)); + const isPrivate2 = modifierFlags & 2 /* Private */; + result.push(setTextRange( + factory.createGetAccessorDeclaration( + factory.createModifiersFromModifierFlags(flag), + name, + [], + isPrivate2 ? void 0 : serializeTypeForDeclaration(context, getTypeOfSymbol(p), p, enclosingDeclaration, includePrivateSymbol, bundled), + /*body*/ + void 0 + ), + ((_c = p.declarations) == null ? void 0 : _c.find(isGetAccessor)) || firstPropertyLikeDecl + )); } return result; } else if (p.flags & (4 /* Property */ | 3 /* Variable */ | 98304 /* Accessor */)) { - return setTextRange(createProperty2( - factory.createModifiersFromModifierFlags((isReadonlySymbol(p) ? 64 /* Readonly */ : 0) | flag), - name, - p.flags & 16777216 /* Optional */ ? factory.createToken(58 /* QuestionToken */) : void 0, - isPrivate ? void 0 : serializeTypeForDeclaration(context, getWriteTypeOfSymbol(p), p, enclosingDeclaration, includePrivateSymbol, bundled), - // TODO: https://github.com/microsoft/TypeScript/pull/32372#discussion_r328386357 - // interface members can't have initializers, however class members _can_ - /*initializer*/ - void 0 - ), ((_d = p.declarations) == null ? void 0 : _d.find(or(isPropertyDeclaration, isVariableDeclaration))) || firstPropertyLikeDecl); - } - if (p.flags & (8192 /* Method */ | 16 /* Function */)) { - const type = getTypeOfSymbol(p); - const signatures = getSignaturesOfType(type, 0 /* Call */); - if (flag & 8 /* Private */) { - return setTextRange(createProperty2( - factory.createModifiersFromModifierFlags((isReadonlySymbol(p) ? 64 /* Readonly */ : 0) | flag), + return setTextRange( + createProperty2( + factory.createModifiersFromModifierFlags((isReadonlySymbol(p) ? 8 /* Readonly */ : 0) | flag), name, p.flags & 16777216 /* Optional */ ? factory.createToken(58 /* QuestionToken */) : void 0, - /*type*/ - void 0, + isPrivate ? void 0 : serializeTypeForDeclaration(context, getWriteTypeOfSymbol(p), p, enclosingDeclaration, includePrivateSymbol, bundled), + // TODO: https://github.com/microsoft/TypeScript/pull/32372#discussion_r328386357 + // interface members can't have initializers, however class members _can_ /*initializer*/ void 0 - ), ((_e = p.declarations) == null ? void 0 : _e.find(isFunctionLikeDeclaration)) || signatures[0] && signatures[0].declaration || p.declarations && p.declarations[0]); + ), + ((_d = p.declarations) == null ? void 0 : _d.find(or(isPropertyDeclaration, isVariableDeclaration))) || firstPropertyLikeDecl + ); + } + if (p.flags & (8192 /* Method */ | 16 /* Function */)) { + const type = getTypeOfSymbol(p); + const signatures = getSignaturesOfType(type, 0 /* Call */); + if (flag & 2 /* Private */) { + return setTextRange( + createProperty2( + factory.createModifiersFromModifierFlags((isReadonlySymbol(p) ? 8 /* Readonly */ : 0) | flag), + name, + p.flags & 16777216 /* Optional */ ? factory.createToken(58 /* QuestionToken */) : void 0, + /*type*/ + void 0, + /*initializer*/ + void 0 + ), + ((_e = p.declarations) == null ? void 0 : _e.find(isFunctionLikeDeclaration)) || signatures[0] && signatures[0].declaration || p.declarations && p.declarations[0] + ); } const results2 = []; for (const sig of signatures) { @@ -151765,17 +135439,20 @@ ${lanes.join("\n")} let privateProtected = 0; for (const s of signatures) { if (s.declaration) { - privateProtected |= getSelectedEffectiveModifierFlags(s.declaration, 8 /* Private */ | 16 /* Protected */); + privateProtected |= getSelectedEffectiveModifierFlags(s.declaration, 2 /* Private */ | 4 /* Protected */); } } if (privateProtected) { - return [setTextRange(factory.createConstructorDeclaration( - factory.createModifiersFromModifierFlags(privateProtected), - /*parameters*/ - [], - /*body*/ - void 0 - ), signatures[0].declaration)]; + return [setTextRange( + factory.createConstructorDeclaration( + factory.createModifiersFromModifierFlags(privateProtected), + /*parameters*/ + [], + /*body*/ + void 0 + ), + signatures[0].declaration + )]; } } const results2 = []; @@ -151857,7 +135534,7 @@ ${lanes.join("\n")} } } function getUnusedName(input, symbol) { - var _a, _b; + var _a2, _b; const id = symbol ? getSymbolId(symbol) : void 0; if (id) { if (context.remappedSymbolNames.has(id)) { @@ -151869,7 +135546,7 @@ ${lanes.join("\n")} } let i = 0; const original = input; - while ((_a = context.usedSymbolNames) == null ? void 0 : _a.has(input)) { + while ((_a2 = context.usedSymbolNames) == null ? void 0 : _a2.has(input)) { i++; input = `${original}_${i}`; } @@ -151955,10 +135632,10 @@ ${lanes.join("\n")} return result || types; } function visibilityToString(flags) { - if (flags === 8 /* Private */) { + if (flags === 2 /* Private */) { return "private"; } - if (flags === 16 /* Protected */) { + if (flags === 4 /* Protected */) { return "protected"; } return "public"; @@ -151973,10 +135650,10 @@ ${lanes.join("\n")} return void 0; } function isTopLevelInExternalModuleAugmentation(node) { - return node && node.parent && node.parent.kind === 267 /* ModuleBlock */ && isExternalModuleAugmentation(node.parent.parent); + return node && node.parent && node.parent.kind === 268 /* ModuleBlock */ && isExternalModuleAugmentation(node.parent.parent); } function isDefaultBindingContext(location) { - return location.kind === 311 /* SourceFile */ || isAmbientModule(location); + return location.kind === 312 /* SourceFile */ || isAmbientModule(location); } function getNameOfSymbolFromNameType(symbol, context) { const nameType = getSymbolLinks(symbol).nameType; @@ -151997,6 +135674,10 @@ ${lanes.join("\n")} } } function getNameOfSymbolAsWritten(symbol, context) { + var _a; + if ((_a = context == null ? void 0 : context.remappedSymbolReferences) == null ? void 0 : _a.has(getSymbolId(symbol))) { + symbol = context.remappedSymbolReferences.get(getSymbolId(symbol)); + } if (context && symbol.escapedName === "default" /* Default */ && !(context.flags & 16384 /* UseAliasDefinedOutsideCurrentScope */) && // If it's not the first part of an entity name, it must print as `default` (!(context.flags & 16777216 /* InInitialEntityName */) || // if the symbol is synthesized, it will only be referenced externally it must print as `default` !symbol.declarations || // if not in the same binding context (source file, module declaration), it must print as `default` @@ -152024,17 +135705,17 @@ ${lanes.join("\n")} if (!declaration) { declaration = symbol.declarations[0]; } - if (declaration.parent && declaration.parent.kind === 259 /* VariableDeclaration */) { + if (declaration.parent && declaration.parent.kind === 260 /* VariableDeclaration */) { return declarationNameToString(declaration.parent.name); } switch (declaration.kind) { - case 230 /* ClassExpression */: - case 217 /* FunctionExpression */: - case 218 /* ArrowFunction */: + case 231 /* ClassExpression */: + case 218 /* FunctionExpression */: + case 219 /* ArrowFunction */: if (context && !context.encounteredError && !(context.flags & 131072 /* AllowAnonymousIdentifier */)) { context.encounteredError = true; } - return declaration.kind === 230 /* ClassExpression */ ? "(Anonymous class)" : "(Anonymous function)"; + return declaration.kind === 231 /* ClassExpression */ ? "(Anonymous class)" : "(Anonymous function)"; } } const name = getNameOfSymbolFromNameType(symbol, context); @@ -152051,66 +135732,66 @@ ${lanes.join("\n")} return false; function determineIfDeclarationIsVisible() { switch (node.kind) { - case 344 /* JSDocCallbackTag */: - case 352 /* JSDocTypedefTag */: - case 346 /* JSDocEnumTag */: + case 345 /* JSDocCallbackTag */: + case 353 /* JSDocTypedefTag */: + case 347 /* JSDocEnumTag */: return !!(node.parent && node.parent.parent && node.parent.parent.parent && isSourceFile(node.parent.parent.parent)); - case 207 /* BindingElement */: + case 208 /* BindingElement */: return isDeclarationVisible(node.parent.parent); - case 259 /* VariableDeclaration */: + case 260 /* VariableDeclaration */: if (isBindingPattern(node.name) && !node.name.elements.length) { return false; } - case 266 /* ModuleDeclaration */: - case 262 /* ClassDeclaration */: - case 263 /* InterfaceDeclaration */: - case 264 /* TypeAliasDeclaration */: - case 261 /* FunctionDeclaration */: - case 265 /* EnumDeclaration */: - case 270 /* ImportEqualsDeclaration */: + case 267 /* ModuleDeclaration */: + case 263 /* ClassDeclaration */: + case 264 /* InterfaceDeclaration */: + case 265 /* TypeAliasDeclaration */: + case 262 /* FunctionDeclaration */: + case 266 /* EnumDeclaration */: + case 271 /* ImportEqualsDeclaration */: if (isExternalModuleAugmentation(node)) { return true; } const parent2 = getDeclarationContainer(node); - if (!(getCombinedModifierFlags(node) & 1 /* Export */) && !(node.kind !== 270 /* ImportEqualsDeclaration */ && parent2.kind !== 311 /* SourceFile */ && parent2.flags & 16777216 /* Ambient */)) { + if (!(getCombinedModifierFlagsCached(node) & 32 /* Export */) && !(node.kind !== 271 /* ImportEqualsDeclaration */ && parent2.kind !== 312 /* SourceFile */ && parent2.flags & 33554432 /* Ambient */)) { return isGlobalSourceFile(parent2); } return isDeclarationVisible(parent2); - case 171 /* PropertyDeclaration */: - case 170 /* PropertySignature */: - case 176 /* GetAccessor */: - case 177 /* SetAccessor */: - case 173 /* MethodDeclaration */: - case 172 /* MethodSignature */: - if (hasEffectiveModifier(node, 8 /* Private */ | 16 /* Protected */)) { + case 172 /* PropertyDeclaration */: + case 171 /* PropertySignature */: + case 177 /* GetAccessor */: + case 178 /* SetAccessor */: + case 174 /* MethodDeclaration */: + case 173 /* MethodSignature */: + if (hasEffectiveModifier(node, 2 /* Private */ | 4 /* Protected */)) { return false; } - case 175 /* Constructor */: - case 179 /* ConstructSignature */: - case 178 /* CallSignature */: - case 180 /* IndexSignature */: - case 168 /* Parameter */: - case 267 /* ModuleBlock */: - case 183 /* FunctionType */: - case 184 /* ConstructorType */: - case 186 /* TypeLiteral */: - case 182 /* TypeReference */: - case 187 /* ArrayType */: - case 188 /* TupleType */: - case 191 /* UnionType */: - case 192 /* IntersectionType */: - case 195 /* ParenthesizedType */: - case 201 /* NamedTupleMember */: + case 176 /* Constructor */: + case 180 /* ConstructSignature */: + case 179 /* CallSignature */: + case 181 /* IndexSignature */: + case 169 /* Parameter */: + case 268 /* ModuleBlock */: + case 184 /* FunctionType */: + case 185 /* ConstructorType */: + case 187 /* TypeLiteral */: + case 183 /* TypeReference */: + case 188 /* ArrayType */: + case 189 /* TupleType */: + case 192 /* UnionType */: + case 193 /* IntersectionType */: + case 196 /* ParenthesizedType */: + case 202 /* NamedTupleMember */: return isDeclarationVisible(node.parent); - case 272 /* ImportClause */: - case 273 /* NamespaceImport */: - case 275 /* ImportSpecifier */: + case 273 /* ImportClause */: + case 274 /* NamespaceImport */: + case 276 /* ImportSpecifier */: return false; - case 167 /* TypeParameter */: - case 311 /* SourceFile */: - case 269 /* NamespaceExportDeclaration */: + case 168 /* TypeParameter */: + case 312 /* SourceFile */: + case 270 /* NamespaceExportDeclaration */: return true; - case 276 /* ExportAssignment */: + case 277 /* ExportAssignment */: return false; default: return false; @@ -152119,7 +135800,7 @@ ${lanes.join("\n")} } function collectLinkedAliases(node, setVisibility) { let exportSymbol; - if (node.parent && node.parent.kind === 276 /* ExportAssignment */) { + if (node.parent && node.parent.kind === 277 /* ExportAssignment */) { exportSymbol = resolveName( node, node.escapedText, @@ -152130,7 +135811,7 @@ ${lanes.join("\n")} /*isUse*/ false ); - } else if (node.parent.kind === 280 /* ExportSpecifier */) { + } else if (node.parent.kind === 281 /* ExportSpecifier */) { exportSymbol = getTargetOfExportSpecifier(node.parent, 111551 /* Value */ | 788968 /* Type */ | 1920 /* Namespace */ | 2097152 /* Alias */); } let result; @@ -152234,12 +135915,12 @@ ${lanes.join("\n")} function getDeclarationContainer(node) { return findAncestor(getRootDeclaration(node), (node2) => { switch (node2.kind) { - case 259 /* VariableDeclaration */: - case 260 /* VariableDeclarationList */: - case 275 /* ImportSpecifier */: - case 274 /* NamedImports */: - case 273 /* NamespaceImport */: - case 272 /* ImportClause */: + case 260 /* VariableDeclaration */: + case 261 /* VariableDeclarationList */: + case 276 /* ImportSpecifier */: + case 275 /* NamedImports */: + case 274 /* NamespaceImport */: + case 273 /* ImportClause */: return false; default: return true; @@ -152254,9 +135935,16 @@ ${lanes.join("\n")} const prop = getPropertyOfType(type, name); return prop ? getTypeOfSymbol(prop) : void 0; } - function getTypeOfPropertyOrIndexSignature(type, name) { + function getTypeOfPropertyOrIndexSignatureOfType(type, name) { var _a; - return getTypeOfPropertyOfType(type, name) || ((_a = getApplicableIndexInfoForName(type, name)) == null ? void 0 : _a.type) || unknownType; + let propType; + return getTypeOfPropertyOfType(type, name) || (propType = (_a = getApplicableIndexInfoForName(type, name)) == null ? void 0 : _a.type) && addOptionality( + propType, + /*isProperty*/ + true, + /*isOptional*/ + true + ); } function isTypeAny(type) { return type && (type.flags & 1 /* Any */) !== 0; @@ -152294,7 +135982,7 @@ ${lanes.join("\n")} const unspreadableToRestKeys = []; for (const prop of getPropertiesOfType(source)) { const literalTypeFromProperty = getLiteralTypeFromProperty(prop, 8576 /* StringOrNumberLiteralOrUnique */); - if (!isTypeAssignableTo(literalTypeFromProperty, omitKeyType) && !(getDeclarationModifierFlagsFromSymbol(prop) & (8 /* Private */ | 16 /* Protected */)) && isSpreadableProperty(prop)) { + if (!isTypeAssignableTo(literalTypeFromProperty, omitKeyType) && !(getDeclarationModifierFlagsFromSymbol(prop) & (2 /* Private */ | 4 /* Protected */)) && isSpreadableProperty(prop)) { spreadableProperties.push(prop); } else { unspreadableToRestKeys.push(literalTypeFromProperty); @@ -152357,23 +136045,23 @@ ${lanes.join("\n")} function getParentElementAccess(node) { const ancestor = node.parent.parent; switch (ancestor.kind) { - case 207 /* BindingElement */: - case 302 /* PropertyAssignment */: + case 208 /* BindingElement */: + case 303 /* PropertyAssignment */: return getSyntheticElementAccess(ancestor); - case 208 /* ArrayLiteralExpression */: + case 209 /* ArrayLiteralExpression */: return getSyntheticElementAccess(node.parent); - case 259 /* VariableDeclaration */: + case 260 /* VariableDeclaration */: return ancestor.initializer; - case 225 /* BinaryExpression */: + case 226 /* BinaryExpression */: return ancestor.right; } } function getDestructuringPropertyName(node) { const parent2 = node.parent; - if (node.kind === 207 /* BindingElement */ && parent2.kind === 205 /* ObjectBindingPattern */) { + if (node.kind === 208 /* BindingElement */ && parent2.kind === 206 /* ObjectBindingPattern */) { return getLiteralPropertyNameText(node.propertyName || node.name); } - if (node.kind === 302 /* PropertyAssignment */ || node.kind === 303 /* ShorthandPropertyAssignment */) { + if (node.kind === 303 /* PropertyAssignment */ || node.kind === 304 /* ShorthandPropertyAssignment */) { return getLiteralPropertyNameText(node.name); } return "" + parent2.elements.indexOf(node); @@ -152383,26 +136071,31 @@ ${lanes.join("\n")} return type.flags & (128 /* StringLiteral */ | 256 /* NumberLiteral */) ? "" + type.value : void 0; } function getTypeForBindingElement(declaration) { - const checkMode = declaration.dotDotDotToken ? 64 /* RestBindingElement */ : 0 /* Normal */; + const checkMode = declaration.dotDotDotToken ? 32 /* RestBindingElement */ : 0 /* Normal */; const parentType = getTypeForBindingElementParent(declaration.parent.parent, checkMode); - return parentType && getBindingElementTypeFromParentType(declaration, parentType); + return parentType && getBindingElementTypeFromParentType( + declaration, + parentType, + /*noTupleBoundsCheck*/ + false + ); } - function getBindingElementTypeFromParentType(declaration, parentType) { + function getBindingElementTypeFromParentType(declaration, parentType, noTupleBoundsCheck) { if (isTypeAny(parentType)) { return parentType; } const pattern = declaration.parent; - if (strictNullChecks && declaration.flags & 16777216 /* Ambient */ && isParameterDeclaration(declaration)) { + if (strictNullChecks && declaration.flags & 33554432 /* Ambient */ && isParameterDeclaration(declaration)) { parentType = getNonNullableType(parentType); - } else if (strictNullChecks && pattern.parent.initializer && !(getTypeFacts(getTypeOfInitializer(pattern.parent.initializer)) & 65536 /* EQUndefined */)) { + } else if (strictNullChecks && pattern.parent.initializer && !hasTypeFacts(getTypeOfInitializer(pattern.parent.initializer), 65536 /* EQUndefined */)) { parentType = getTypeWithFacts(parentType, 524288 /* NEUndefined */); } let type; - if (pattern.kind === 205 /* ObjectBindingPattern */) { + if (pattern.kind === 206 /* ObjectBindingPattern */) { if (declaration.dotDotDotToken) { parentType = getReducedType(parentType); if (parentType.flags & 2 /* Unknown */ || !isValidSpreadType(parentType)) { - error(declaration, Diagnostics.Rest_types_may_only_be_created_from_object_types); + error2(declaration, Diagnostics.Rest_types_may_only_be_created_from_object_types); return errorType; } const literalMembers = []; @@ -152426,7 +136119,7 @@ ${lanes.join("\n")} type = everyType(baseConstraint, isTupleType) ? mapType(baseConstraint, (t) => sliceTupleType(t, index)) : createArrayType(elementType); } else if (isArrayLikeType(parentType)) { const indexType = getNumberLiteralType(index); - const accessFlags = 32 /* ExpressionPosition */ | (hasDefaultValue(declaration) ? 16 /* NoTupleBoundsCheck */ : 0); + const accessFlags = 32 /* ExpressionPosition */ | (noTupleBoundsCheck || hasDefaultValue(declaration) ? 16 /* NoTupleBoundsCheck */ : 0); const declaredType = getIndexedAccessTypeOrUndefined(parentType, indexType, accessFlags, declaration.name) || errorType; type = getFlowTypeOfDestructuring(declaration, declaredType); } else { @@ -152437,7 +136130,7 @@ ${lanes.join("\n")} return type; } if (getEffectiveTypeAnnotationNode(walkUpBindingElementsAndPatterns(declaration))) { - return strictNullChecks && !(getTypeFacts(checkDeclarationInitializer(declaration, 0 /* Normal */)) & 16777216 /* IsUndefined */) ? getNonUndefinedType(type) : type; + return strictNullChecks && !hasTypeFacts(checkDeclarationInitializer(declaration, 0 /* Normal */), 16777216 /* IsUndefined */) ? getNonUndefinedType(type) : type; } return widenTypeInferredFromInitializer(declaration, getUnionType([getNonUndefinedType(type), checkDeclarationInitializer(declaration, 0 /* Normal */)], 2 /* Subtype */)); } @@ -152462,13 +136155,13 @@ ${lanes.join("\n")} /*excludeJSDocTypeAssertions*/ true ); - return expr.kind === 208 /* ArrayLiteralExpression */ && expr.elements.length === 0; + return expr.kind === 209 /* ArrayLiteralExpression */ && expr.elements.length === 0; } function addOptionality(type, isProperty = false, isOptional = true) { return strictNullChecks && isOptional ? getOptionalType(type, isProperty) : type; } function getTypeForVariableLikeDeclaration(declaration, includeOptionality, checkMode) { - if (isVariableDeclaration(declaration) && declaration.parent.parent.kind === 248 /* ForInStatement */) { + if (isVariableDeclaration(declaration) && declaration.parent.parent.kind === 249 /* ForInStatement */) { const indexType = getIndexType(getNonNullableTypeIfNeeded(checkExpression( declaration.parent.parent.expression, /*checkMode*/ @@ -152476,7 +136169,7 @@ ${lanes.join("\n")} ))); return indexType.flags & (262144 /* TypeParameter */ | 4194304 /* Index */) ? getExtractStringType(indexType) : stringType; } - if (isVariableDeclaration(declaration) && declaration.parent.parent.kind === 249 /* ForOfStatement */) { + if (isVariableDeclaration(declaration) && declaration.parent.parent.kind === 250 /* ForOfStatement */) { const forOfStatement = declaration.parent.parent; return checkRightHandSideOfForOf(forOfStatement) || anyType; } @@ -152495,8 +136188,8 @@ ${lanes.join("\n")} if (declaredType) { return addOptionality(declaredType, isProperty, isOptional); } - if ((noImplicitAny || isInJSFile(declaration)) && isVariableDeclaration(declaration) && !isBindingPattern(declaration.name) && !(getCombinedModifierFlags(declaration) & 1 /* Export */) && !(declaration.flags & 16777216 /* Ambient */)) { - if (!(getCombinedNodeFlags(declaration) & 2 /* Const */) && (!declaration.initializer || isNullOrUndefined3(declaration.initializer))) { + if ((noImplicitAny || isInJSFile(declaration)) && isVariableDeclaration(declaration) && !isBindingPattern(declaration.name) && !(getCombinedModifierFlagsCached(declaration) & 32 /* Export */) && !(declaration.flags & 33554432 /* Ambient */)) { + if (!(getCombinedNodeFlagsCached(declaration) & 6 /* Constant */) && (!declaration.initializer || isNullOrUndefined3(declaration.initializer))) { return autoType; } if (declaration.initializer && isEmptyArrayLiteral2(declaration.initializer)) { @@ -152505,8 +136198,8 @@ ${lanes.join("\n")} } if (isParameter(declaration)) { const func = declaration.parent; - if (func.kind === 177 /* SetAccessor */ && hasBindableName(func)) { - const getter = getDeclarationOfKind(getSymbolOfDeclaration(declaration.parent), 176 /* GetAccessor */); + if (func.kind === 178 /* SetAccessor */ && hasBindableName(func)) { + const getter = getDeclarationOfKind(getSymbolOfDeclaration(declaration.parent), 177 /* GetAccessor */); if (getter) { const getterSignature = getSignatureFromDeclaration(getter); const thisParameter = getAccessorThisParameter(func); @@ -152543,7 +136236,7 @@ ${lanes.join("\n")} if (isPropertyDeclaration(declaration) && (noImplicitAny || isInJSFile(declaration))) { if (!hasStaticModifier(declaration)) { const constructor = findConstructorDeclaration(declaration.parent); - const type = constructor ? getFlowTypeInConstructor(declaration.symbol, constructor) : getEffectiveModifierFlags(declaration) & 2 /* Ambient */ ? getTypeOfPropertyInBaseClass(declaration.symbol) : void 0; + const type = constructor ? getFlowTypeInConstructor(declaration.symbol, constructor) : getEffectiveModifierFlags(declaration) & 128 /* Ambient */ ? getTypeOfPropertyInBaseClass(declaration.symbol) : void 0; return type && addOptionality( type, /*isProperty*/ @@ -152552,7 +136245,7 @@ ${lanes.join("\n")} ); } else { const staticBlocks = filter(declaration.parent.members, isClassStaticBlockDeclaration); - const type = staticBlocks.length ? getFlowTypeInStaticBlocks(declaration.symbol, staticBlocks) : getEffectiveModifierFlags(declaration) & 2 /* Ambient */ ? getTypeOfPropertyInBaseClass(declaration.symbol) : void 0; + const type = staticBlocks.length ? getFlowTypeInStaticBlocks(declaration.symbol, staticBlocks) : getEffectiveModifierFlags(declaration) & 128 /* Ambient */ ? getTypeOfPropertyInBaseClass(declaration.symbol) : void 0; return type && addOptionality( type, /*isProperty*/ @@ -152580,7 +136273,7 @@ ${lanes.join("\n")} const links = getSymbolLinks(symbol); if (links.isConstructorDeclaredProperty === void 0) { links.isConstructorDeclaredProperty = false; - links.isConstructorDeclaredProperty = !!getDeclaringConstructor(symbol) && every(symbol.declarations, (declaration) => isBinaryExpression(declaration) && isPossiblyAliasedThisProperty(declaration) && (declaration.left.kind !== 211 /* ElementAccessExpression */ || isStringOrNumericLiteralLike(declaration.left.argumentExpression)) && !getAnnotatedTypeForAssignmentDeclaration( + links.isConstructorDeclaredProperty = !!getDeclaringConstructor(symbol) && every(symbol.declarations, (declaration) => isBinaryExpression(declaration) && isPossiblyAliasedThisProperty(declaration) && (declaration.left.kind !== 212 /* ElementAccessExpression */ || isStringOrNumericLiteralLike(declaration.left.argumentExpression)) && !getAnnotatedTypeForAssignmentDeclaration( /*declaredType*/ void 0, declaration, @@ -152608,7 +136301,7 @@ ${lanes.join("\n")} /*includeClassComputedPropertyName*/ false ); - if (container && (container.kind === 175 /* Constructor */ || isJSConstructor(container))) { + if (container && (container.kind === 176 /* Constructor */ || isJSConstructor(container))) { return container; } } @@ -152635,7 +136328,7 @@ ${lanes.join("\n")} reference.flowNode = staticBlock.returnFlowNode; const flowType = getFlowTypeOfProperty(reference, symbol); if (noImplicitAny && (flowType === autoType || flowType === autoArrayType)) { - error(symbol.valueDeclaration, Diagnostics.Member_0_implicitly_has_an_1_type, symbolToString(symbol), typeToString(flowType)); + error2(symbol.valueDeclaration, Diagnostics.Member_0_implicitly_has_an_1_type, symbolToString(symbol), typeToString(flowType)); } if (everyType(flowType, isNullableType)) { continue; @@ -152651,12 +136344,12 @@ ${lanes.join("\n")} reference.flowNode = constructor.returnFlowNode; const flowType = getFlowTypeOfProperty(reference, symbol); if (noImplicitAny && (flowType === autoType || flowType === autoArrayType)) { - error(symbol.valueDeclaration, Diagnostics.Member_0_implicitly_has_an_1_type, symbolToString(symbol), typeToString(flowType)); + error2(symbol.valueDeclaration, Diagnostics.Member_0_implicitly_has_an_1_type, symbolToString(symbol), typeToString(flowType)); } return everyType(flowType, isNullableType) ? void 0 : convertAutoToAny(flowType); } function getFlowTypeOfProperty(reference, prop) { - const initialType = (prop == null ? void 0 : prop.valueDeclaration) && (!isAutoTypedProperty(prop) || getEffectiveModifierFlags(prop.valueDeclaration) & 2 /* Ambient */) && getTypeOfPropertyInBaseClass(prop) || undefinedType; + const initialType = (prop == null ? void 0 : prop.valueDeclaration) && (!isAutoTypedProperty(prop) || getEffectiveModifierFlags(prop.valueDeclaration) & 128 /* Ambient */) && getTypeOfPropertyInBaseClass(prop) || undefinedType; return getFlowTypeOfReference(reference, autoType, initialType); } function getWidenedTypeForAssignmentDeclaration(symbol, resolvedSymbol) { @@ -152723,7 +136416,7 @@ ${lanes.join("\n")} false, definedInMethod && !definedInConstructor )); - if (symbol.valueDeclaration && filterType(widened, (t) => !!(t.flags & ~98304 /* Nullable */)) === neverType) { + if (symbol.valueDeclaration && isInJSFile(symbol.valueDeclaration) && filterType(widened, (t) => !!(t.flags & ~98304 /* Nullable */)) === neverType) { reportImplicitAny(symbol.valueDeclaration, anyType); return anyType; } @@ -152826,11 +136519,11 @@ ${lanes.join("\n")} const unescapedName = unescapeLeadingUnderscores(s.escapedName); const exportedMemberName = ((_a = tryCast(exportedMember.valueDeclaration, isNamedDeclaration)) == null ? void 0 : _a.name) || exportedMember.valueDeclaration; addRelatedInfo( - error(s.valueDeclaration, Diagnostics.Duplicate_identifier_0, unescapedName), + error2(s.valueDeclaration, Diagnostics.Duplicate_identifier_0, unescapedName), createDiagnosticForNode(exportedMemberName, Diagnostics._0_was_also_declared_here, unescapedName) ); addRelatedInfo( - error(exportedMemberName, Diagnostics.Duplicate_identifier_0, unescapedName), + error2(exportedMemberName, Diagnostics.Duplicate_identifier_0, unescapedName), createDiagnosticForNode(s.valueDeclaration, Diagnostics._0_was_also_declared_here, unescapedName) ); } @@ -152888,7 +136581,7 @@ ${lanes.join("\n")} /*includeClassComputedPropertyName*/ false ); - return thisContainer.kind === 175 /* Constructor */ || thisContainer.kind === 261 /* FunctionDeclaration */ || thisContainer.kind === 217 /* FunctionExpression */ && !isPrototypePropertyAssignment(thisContainer.parent); + return thisContainer.kind === 176 /* Constructor */ || thisContainer.kind === 262 /* FunctionDeclaration */ || thisContainer.kind === 218 /* FunctionExpression */ && !isPrototypePropertyAssignment(thisContainer.parent); } function getConstructorDefinedThisAssignmentTypes(types, declarations) { Debug.assert(types.length === declarations.length); @@ -152962,7 +136655,7 @@ ${lanes.join("\n")} function getTypeFromArrayBindingPattern(pattern, includePatternInType, reportErrors2) { const elements = pattern.elements; const lastElement = lastOrUndefined(elements); - const restElement = lastElement && lastElement.kind === 207 /* BindingElement */ && lastElement.dotDotDotToken ? lastElement : void 0; + const restElement = lastElement && lastElement.kind === 208 /* BindingElement */ && lastElement.dotDotDotToken ? lastElement : void 0; if (elements.length === 0 || elements.length === 1 && restElement) { return languageVersion >= 2 /* ES2015 */ ? createIterableType(anyType) : anyArrayType; } @@ -152978,7 +136671,7 @@ ${lanes.join("\n")} return result; } function getTypeFromBindingPattern(pattern, includePatternInType = false, reportErrors2 = false) { - return pattern.kind === 205 /* ObjectBindingPattern */ ? getTypeFromObjectBindingPattern(pattern, includePatternInType, reportErrors2) : getTypeFromArrayBindingPattern(pattern, includePatternInType, reportErrors2); + return pattern.kind === 206 /* ObjectBindingPattern */ ? getTypeFromObjectBindingPattern(pattern, includePatternInType, reportErrors2) : getTypeFromArrayBindingPattern(pattern, includePatternInType, reportErrors2); } function getWidenedTypeForVariableLikeDeclaration(declaration, reportErrors2) { return widenTypeForVariableLikeDeclaration(getTypeForVariableLikeDeclaration( @@ -153019,7 +136712,7 @@ ${lanes.join("\n")} } function declarationBelongsToPrivateAmbientMember(declaration) { const root = getRootDeclaration(declaration); - const memberDeclaration = root.kind === 168 /* Parameter */ ? root.parent : root; + const memberDeclaration = root.kind === 169 /* Parameter */ ? root.parent : root; return isPrivateWithinAmbient(memberDeclaration); } function tryGetTypeFromEffectiveTypeNode(node) { @@ -153093,7 +136786,7 @@ ${lanes.join("\n")} return reportCircularityError(symbol); } let type; - if (declaration.kind === 276 /* ExportAssignment */) { + if (declaration.kind === 277 /* ExportAssignment */) { type = widenTypeForVariableLikeDeclaration(tryGetTypeFromEffectiveTypeNode(declaration) || checkExpressionCached(declaration.expression), declaration); } else if (isBinaryExpression(declaration) || isInJSFile(declaration) && (isCallExpression(declaration) || (isPropertyAccessExpression(declaration) || isBindableStaticElementAccessExpression(declaration)) && isBinaryExpression(declaration.parent))) { type = getWidenedTypeForAssignmentDeclaration(symbol); @@ -153134,13 +136827,13 @@ ${lanes.join("\n")} function getAnnotatedAccessorTypeNode(accessor) { if (accessor) { switch (accessor.kind) { - case 176 /* GetAccessor */: + case 177 /* GetAccessor */: const getterTypeAnnotation = getEffectiveReturnTypeNode(accessor); return getterTypeAnnotation; - case 177 /* SetAccessor */: + case 178 /* SetAccessor */: const setterTypeAnnotation = getEffectiveSetAccessorTypeAnnotationNode(accessor); return setterTypeAnnotation; - case 171 /* PropertyDeclaration */: + case 172 /* PropertyDeclaration */: Debug.assert(hasAccessorModifier(accessor)); const accessorTypeAnnotation = getEffectiveTypeAnnotationNode(accessor); return accessorTypeAnnotation; @@ -153165,9 +136858,9 @@ ${lanes.join("\n")} if (!pushTypeResolution(symbol, 0 /* Type */)) { return errorType; } - const getter = getDeclarationOfKind(symbol, 176 /* GetAccessor */); - const setter = getDeclarationOfKind(symbol, 177 /* SetAccessor */); - const accessor = tryCast(getDeclarationOfKind(symbol, 171 /* PropertyDeclaration */), isAutoAccessorPropertyDeclaration); + const getter = getDeclarationOfKind(symbol, 177 /* GetAccessor */); + const setter = getDeclarationOfKind(symbol, 178 /* SetAccessor */); + const accessor = tryCast(getDeclarationOfKind(symbol, 172 /* PropertyDeclaration */), isAutoAccessorPropertyDeclaration); let type = getter && isInJSFile(getter) && getTypeForDeclarationFromJSDocComment(getter) || getAnnotatedAccessorType(getter) || getAnnotatedAccessorType(setter) || getAnnotatedAccessorType(accessor) || getter && getter.body && getReturnTypeFromBody(getter) || accessor && accessor.initializer && getWidenedTypeForVariableLikeDeclaration( accessor, /*reportErrors*/ @@ -153185,13 +136878,13 @@ ${lanes.join("\n")} } if (!popTypeResolution()) { if (getAnnotatedAccessorTypeNode(getter)) { - error(getter, Diagnostics._0_is_referenced_directly_or_indirectly_in_its_own_type_annotation, symbolToString(symbol)); + error2(getter, Diagnostics._0_is_referenced_directly_or_indirectly_in_its_own_type_annotation, symbolToString(symbol)); } else if (getAnnotatedAccessorTypeNode(setter)) { - error(setter, Diagnostics._0_is_referenced_directly_or_indirectly_in_its_own_type_annotation, symbolToString(symbol)); + error2(setter, Diagnostics._0_is_referenced_directly_or_indirectly_in_its_own_type_annotation, symbolToString(symbol)); } else if (getAnnotatedAccessorTypeNode(accessor)) { - error(setter, Diagnostics._0_is_referenced_directly_or_indirectly_in_its_own_type_annotation, symbolToString(symbol)); + error2(setter, Diagnostics._0_is_referenced_directly_or_indirectly_in_its_own_type_annotation, symbolToString(symbol)); } else if (getter && noImplicitAny) { - error(getter, Diagnostics._0_implicitly_has_return_type_any_because_it_does_not_have_a_return_type_annotation_and_is_referenced_directly_or_indirectly_in_one_of_its_return_expressions, symbolToString(symbol)); + error2(getter, Diagnostics._0_implicitly_has_return_type_any_because_it_does_not_have_a_return_type_annotation_and_is_referenced_directly_or_indirectly_in_one_of_its_return_expressions, symbolToString(symbol)); } type = anyType; } @@ -153205,11 +136898,11 @@ ${lanes.join("\n")} if (!pushTypeResolution(symbol, 8 /* WriteType */)) { return errorType; } - const setter = getDeclarationOfKind(symbol, 177 /* SetAccessor */) ?? tryCast(getDeclarationOfKind(symbol, 171 /* PropertyDeclaration */), isAutoAccessorPropertyDeclaration); + const setter = getDeclarationOfKind(symbol, 178 /* SetAccessor */) ?? tryCast(getDeclarationOfKind(symbol, 172 /* PropertyDeclaration */), isAutoAccessorPropertyDeclaration); let writeType = getAnnotatedAccessorType(setter); if (!popTypeResolution()) { if (getAnnotatedAccessorTypeNode(setter)) { - error(setter, Diagnostics._0_is_referenced_directly_or_indirectly_in_its_own_type_annotation, symbolToString(symbol)); + error2(setter, Diagnostics._0_is_referenced_directly_or_indirectly_in_its_own_type_annotation, symbolToString(symbol)); } writeType = anyType; } @@ -153245,7 +136938,7 @@ ${lanes.join("\n")} const declaration = symbol.valueDeclaration; if (symbol.flags & 1536 /* Module */ && isShorthandAmbientModuleSymbol(symbol)) { return anyType; - } else if (declaration && (declaration.kind === 225 /* BinaryExpression */ || isAccessExpression(declaration) && declaration.parent.kind === 225 /* BinaryExpression */)) { + } else if (declaration && (declaration.kind === 226 /* BinaryExpression */ || isAccessExpression(declaration) && declaration.parent.kind === 226 /* BinaryExpression */)) { return getWidenedTypeForAssignmentDeclaration(symbol); } else if (symbol.flags & 512 /* ValueModule */ && declaration && isSourceFile(declaration) && declaration.commonJsModuleIndicator) { const resolvedModule = resolveExternalModuleSymbol(symbol); @@ -153280,6 +136973,9 @@ ${lanes.join("\n")} function getTypeOfAlias(symbol) { const links = getSymbolLinks(symbol); if (!links.type) { + if (!pushTypeResolution(symbol, 0 /* Type */)) { + return errorType; + } const targetSymbol = resolveAlias(symbol); const exportSymbol = symbol.declarations && getTargetOfAliasDeclaration( getDeclarationOfAliasSymbol(symbol), @@ -153287,7 +136983,11 @@ ${lanes.join("\n")} true ); const declaredType = firstDefined(exportSymbol == null ? void 0 : exportSymbol.declarations, (d) => isExportAssignment(d) ? tryGetTypeFromEffectiveTypeNode(d) : void 0); - links.type = (exportSymbol == null ? void 0 : exportSymbol.declarations) && isDuplicatedCommonJSExport(exportSymbol.declarations) && symbol.declarations.length ? getFlowTypeFromCommonJSExport(exportSymbol) : isDuplicatedCommonJSExport(symbol.declarations) ? autoType : declaredType ? declaredType : getAllSymbolFlags(targetSymbol) & 111551 /* Value */ ? getTypeOfSymbol(targetSymbol) : errorType; + links.type = (exportSymbol == null ? void 0 : exportSymbol.declarations) && isDuplicatedCommonJSExport(exportSymbol.declarations) && symbol.declarations.length ? getFlowTypeFromCommonJSExport(exportSymbol) : isDuplicatedCommonJSExport(symbol.declarations) ? autoType : declaredType ? declaredType : getSymbolFlags(targetSymbol) & 111551 /* Value */ ? getTypeOfSymbol(targetSymbol) : errorType; + if (!popTypeResolution()) { + reportCircularityError(exportSymbol ?? symbol); + return links.type = errorType; + } } return links.type; } @@ -153301,20 +137001,19 @@ ${lanes.join("\n")} } function reportCircularityError(symbol) { const declaration = symbol.valueDeclaration; - if (getEffectiveTypeAnnotationNode(declaration)) { - error( - symbol.valueDeclaration, - Diagnostics._0_is_referenced_directly_or_indirectly_in_its_own_type_annotation, - symbolToString(symbol) - ); - return errorType; - } - if (noImplicitAny && (declaration.kind !== 168 /* Parameter */ || declaration.initializer)) { - error( - symbol.valueDeclaration, - Diagnostics._0_implicitly_has_type_any_because_it_does_not_have_a_type_annotation_and_is_referenced_directly_or_indirectly_in_its_own_initializer, - symbolToString(symbol) - ); + if (declaration) { + if (getEffectiveTypeAnnotationNode(declaration)) { + error2(symbol.valueDeclaration, Diagnostics._0_is_referenced_directly_or_indirectly_in_its_own_type_annotation, symbolToString(symbol)); + return errorType; + } + if (noImplicitAny && (declaration.kind !== 169 /* Parameter */ || declaration.initializer)) { + error2(symbol.valueDeclaration, Diagnostics._0_implicitly_has_type_any_because_it_does_not_have_a_type_annotation_and_is_referenced_directly_or_indirectly_in_its_own_initializer, symbolToString(symbol)); + } + } else if (symbol.flags & 2097152 /* Alias */) { + const node = getDeclarationOfAliasSymbol(symbol); + if (node) { + error2(node, Diagnostics.Circular_definition_of_import_alias_0, symbolToString(symbol)); + } } return anyType; } @@ -153342,7 +137041,7 @@ ${lanes.join("\n")} return checkFlags & 2 /* SyntheticProperty */ ? checkFlags & 65536 /* DeferredType */ ? getWriteTypeOfSymbolWithDeferredType(symbol) || getTypeOfSymbolWithDeferredType(symbol) : ( // NOTE: cast to TransientSymbol should be safe because only TransientSymbols can have CheckFlags.SyntheticProperty symbol.links.writeType || symbol.links.type - ) : getTypeOfSymbol(symbol); + ) : removeMissingType(getTypeOfSymbol(symbol), !!(symbol.flags & 16777216 /* Optional */)); } if (symbol.flags & 98304 /* Accessor */) { return checkFlags & 1 /* Instantiated */ ? getWriteTypeOfInstantiatedSymbol(symbol) : getWriteTypeOfAccessors(symbol); @@ -153423,43 +137122,43 @@ ${lanes.join("\n")} return void 0; } switch (node.kind) { - case 262 /* ClassDeclaration */: - case 230 /* ClassExpression */: - case 263 /* InterfaceDeclaration */: - case 178 /* CallSignature */: - case 179 /* ConstructSignature */: - case 172 /* MethodSignature */: - case 183 /* FunctionType */: - case 184 /* ConstructorType */: - case 323 /* JSDocFunctionType */: - case 261 /* FunctionDeclaration */: - case 173 /* MethodDeclaration */: - case 217 /* FunctionExpression */: - case 218 /* ArrowFunction */: - case 264 /* TypeAliasDeclaration */: - case 351 /* JSDocTemplateTag */: - case 352 /* JSDocTypedefTag */: - case 346 /* JSDocEnumTag */: - case 344 /* JSDocCallbackTag */: - case 199 /* MappedType */: - case 193 /* ConditionalType */: { + case 263 /* ClassDeclaration */: + case 231 /* ClassExpression */: + case 264 /* InterfaceDeclaration */: + case 179 /* CallSignature */: + case 180 /* ConstructSignature */: + case 173 /* MethodSignature */: + case 184 /* FunctionType */: + case 185 /* ConstructorType */: + case 324 /* JSDocFunctionType */: + case 262 /* FunctionDeclaration */: + case 174 /* MethodDeclaration */: + case 218 /* FunctionExpression */: + case 219 /* ArrowFunction */: + case 265 /* TypeAliasDeclaration */: + case 352 /* JSDocTemplateTag */: + case 353 /* JSDocTypedefTag */: + case 347 /* JSDocEnumTag */: + case 345 /* JSDocCallbackTag */: + case 200 /* MappedType */: + case 194 /* ConditionalType */: { const outerTypeParameters = getOuterTypeParameters(node, includeThisTypes); - if (node.kind === 199 /* MappedType */) { + if (node.kind === 200 /* MappedType */) { return append(outerTypeParameters, getDeclaredTypeOfTypeParameter(getSymbolOfDeclaration(node.typeParameter))); - } else if (node.kind === 193 /* ConditionalType */) { + } else if (node.kind === 194 /* ConditionalType */) { return concatenate(outerTypeParameters, getInferTypeParameters(node)); } const outerAndOwnTypeParameters = appendTypeParameters(outerTypeParameters, getEffectiveTypeParameterDeclarations(node)); - const thisType = includeThisTypes && (node.kind === 262 /* ClassDeclaration */ || node.kind === 230 /* ClassExpression */ || node.kind === 263 /* InterfaceDeclaration */ || isJSConstructor(node)) && getDeclaredTypeOfClassOrInterface(getSymbolOfDeclaration(node)).thisType; + const thisType = includeThisTypes && (node.kind === 263 /* ClassDeclaration */ || node.kind === 231 /* ClassExpression */ || node.kind === 264 /* InterfaceDeclaration */ || isJSConstructor(node)) && getDeclaredTypeOfClassOrInterface(getSymbolOfDeclaration(node)).thisType; return thisType ? append(outerAndOwnTypeParameters, thisType) : outerAndOwnTypeParameters; } - case 347 /* JSDocParameterTag */: + case 348 /* JSDocParameterTag */: const paramSymbol = getParameterSymbolFromJSDoc(node); if (paramSymbol) { node = paramSymbol.valueDeclaration; } break; - case 326 /* JSDoc */: { + case 327 /* JSDoc */: { const outerTypeParameters = getOuterTypeParameters(node, includeThisTypes); return node.tags ? appendTypeParameters(outerTypeParameters, flatMap(node.tags, (t) => isJSDocTemplateTag(t) ? t.typeParameters : void 0)) : outerTypeParameters; } @@ -153469,14 +137168,14 @@ ${lanes.join("\n")} function getOuterTypeParametersOfClassOrInterface(symbol) { var _a; const declaration = symbol.flags & 32 /* Class */ || symbol.flags & 16 /* Function */ ? symbol.valueDeclaration : (_a = symbol.declarations) == null ? void 0 : _a.find((decl) => { - if (decl.kind === 263 /* InterfaceDeclaration */) { + if (decl.kind === 264 /* InterfaceDeclaration */) { return true; } - if (decl.kind !== 259 /* VariableDeclaration */) { + if (decl.kind !== 260 /* VariableDeclaration */) { return false; } const initializer = decl.initializer; - return !!initializer && (initializer.kind === 217 /* FunctionExpression */ || initializer.kind === 218 /* ArrowFunction */); + return !!initializer && (initializer.kind === 218 /* FunctionExpression */ || initializer.kind === 219 /* ArrowFunction */); }); Debug.assert(!!declaration, "Class was missing valueDeclaration -OR- non-class had no interface declarations"); return getOuterTypeParameters(declaration); @@ -153487,7 +137186,7 @@ ${lanes.join("\n")} } let result; for (const node of symbol.declarations) { - if (node.kind === 263 /* InterfaceDeclaration */ || node.kind === 262 /* ClassDeclaration */ || node.kind === 230 /* ClassExpression */ || isJSConstructor(node) || isTypeAlias(node)) { + if (node.kind === 264 /* InterfaceDeclaration */ || node.kind === 263 /* ClassDeclaration */ || node.kind === 231 /* ClassExpression */ || isJSConstructor(node) || isTypeAlias(node)) { const declaration = node; result = appendTypeParameters(result, getEffectiveTypeParameterDeclarations(declaration)); } @@ -153525,10 +137224,7 @@ ${lanes.join("\n")} function getConstructorsForTypeArguments(type, typeArgumentNodes, location) { const typeArgCount = length(typeArgumentNodes); const isJavascript = isInJSFile(location); - return filter( - getSignaturesOfType(type, 1 /* Construct */), - (sig) => (isJavascript || typeArgCount >= getMinTypeArgumentCount(sig.typeParameters)) && typeArgCount <= length(sig.typeParameters) - ); + return filter(getSignaturesOfType(type, 1 /* Construct */), (sig) => (isJavascript || typeArgCount >= getMinTypeArgumentCount(sig.typeParameters)) && typeArgCount <= length(sig.typeParameters)); } function getInstantiatedConstructorsForTypeArguments(type, typeArgumentNodes, location) { const signatures = getConstructorsForTypeArguments(type, typeArgumentNodes, location); @@ -153555,11 +137251,11 @@ ${lanes.join("\n")} resolveStructuredTypeMembers(baseConstructorType); } if (!popTypeResolution()) { - error(type.symbol.valueDeclaration, Diagnostics._0_is_referenced_directly_or_indirectly_in_its_own_base_expression, symbolToString(type.symbol)); + error2(type.symbol.valueDeclaration, Diagnostics._0_is_referenced_directly_or_indirectly_in_its_own_base_expression, symbolToString(type.symbol)); return type.resolvedBaseConstructorType = errorType; } if (!(baseConstructorType.flags & 1 /* Any */) && baseConstructorType !== nullWideningType && !isConstructorType(baseConstructorType)) { - const err = error(baseTypeNode.expression, Diagnostics.Type_0_is_not_a_constructor_function_type, typeToString(baseConstructorType)); + const err = error2(baseTypeNode.expression, Diagnostics.Type_0_is_not_a_constructor_function_type, typeToString(baseConstructorType)); if (baseConstructorType.flags & 262144 /* TypeParameter */) { const constraint = getConstraintFromTypeParameter(baseConstructorType); let ctorReturn = unknownType; @@ -153601,7 +137297,7 @@ ${lanes.join("\n")} return resolvedImplementsTypes; } function reportCircularBaseType(node, type) { - error(node, Diagnostics.Type_0_recursively_references_itself_as_a_base_type, typeToString( + error2(node, Diagnostics.Type_0_recursively_references_itself_as_a_base_type, typeToString( type, /*enclosingDeclaration*/ void 0, @@ -153625,7 +137321,7 @@ ${lanes.join("\n")} } if (!popTypeResolution() && type.symbol.declarations) { for (const declaration of type.symbol.declarations) { - if (declaration.kind === 262 /* ClassDeclaration */ || declaration.kind === 263 /* InterfaceDeclaration */) { + if (declaration.kind === 263 /* ClassDeclaration */ || declaration.kind === 264 /* InterfaceDeclaration */) { reportCircularBaseType(declaration, type); } } @@ -153655,7 +137351,7 @@ ${lanes.join("\n")} } else { const constructors = getInstantiatedConstructorsForTypeArguments(baseConstructorType, baseTypeNode.typeArguments, baseTypeNode); if (!constructors.length) { - error(baseTypeNode.expression, Diagnostics.No_base_constructor_has_the_specified_number_of_type_arguments); + error2(baseTypeNode.expression, Diagnostics.No_base_constructor_has_the_specified_number_of_type_arguments); return type.resolvedBaseTypes = emptyArray; } baseType = getReturnTypeOfSignature(constructors[0]); @@ -153675,16 +137371,12 @@ ${lanes.join("\n")} return type.resolvedBaseTypes = emptyArray; } if (type === reducedBaseType || hasBaseType(reducedBaseType, type)) { - error( - type.symbol.valueDeclaration, - Diagnostics.Type_0_recursively_references_itself_as_a_base_type, - typeToString( - type, - /*enclosingDeclaration*/ - void 0, - 2 /* WriteArrayAsGenericType */ - ) - ); + error2(type.symbol.valueDeclaration, Diagnostics.Type_0_recursively_references_itself_as_a_base_type, typeToString( + type, + /*enclosingDeclaration*/ + void 0, + 2 /* WriteArrayAsGenericType */ + )); return type.resolvedBaseTypes = emptyArray; } if (type.resolvedBaseTypes === resolvingEmptyArray) { @@ -153714,7 +137406,7 @@ ${lanes.join("\n")} type.resolvedBaseTypes = type.resolvedBaseTypes || emptyArray; if (type.symbol.declarations) { for (const declaration of type.symbol.declarations) { - if (declaration.kind === 263 /* InterfaceDeclaration */ && getInterfaceBaseTypeNodes(declaration)) { + if (declaration.kind === 264 /* InterfaceDeclaration */ && getInterfaceBaseTypeNodes(declaration)) { for (const node of getInterfaceBaseTypeNodes(declaration)) { const baseType = getReducedType(getTypeFromTypeNode(node)); if (!isErrorType(baseType)) { @@ -153729,7 +137421,7 @@ ${lanes.join("\n")} reportCircularBaseType(declaration, type); } } else { - error(node, Diagnostics.An_interface_can_only_extend_an_object_type_or_intersection_of_object_types_with_statically_known_members); + error2(node, Diagnostics.An_interface_can_only_extend_an_object_type_or_intersection_of_object_types_with_statically_known_members); } } } @@ -153742,8 +137434,8 @@ ${lanes.join("\n")} return true; } for (const declaration of symbol.declarations) { - if (declaration.kind === 263 /* InterfaceDeclaration */) { - if (declaration.flags & 128 /* ContainsThis */) { + if (declaration.kind === 264 /* InterfaceDeclaration */) { + if (declaration.flags & 256 /* ContainsThis */) { return false; } const baseTypeNodes = getInterfaceBaseTypeNodes(declaration); @@ -153814,10 +137506,10 @@ ${lanes.join("\n")} } } else { type = errorType; - if (declaration.kind === 346 /* JSDocEnumTag */) { - error(declaration.typeExpression.type, Diagnostics.Type_alias_0_circularly_references_itself, symbolToString(symbol)); + if (declaration.kind === 347 /* JSDocEnumTag */) { + error2(declaration.typeExpression.type, Diagnostics.Type_alias_0_circularly_references_itself, symbolToString(symbol)); } else { - error(isNamedDeclaration(declaration) ? declaration.name || declaration : declaration, Diagnostics.Type_alias_0_circularly_references_itself, symbolToString(symbol)); + error2(isNamedDeclaration(declaration) ? declaration.name || declaration : declaration, Diagnostics.Type_alias_0_circularly_references_itself, symbolToString(symbol)); } } links.declaredType = type; @@ -153833,12 +137525,14 @@ ${lanes.join("\n")} const memberTypeList = []; if (symbol.declarations) { for (const declaration of symbol.declarations) { - if (declaration.kind === 265 /* EnumDeclaration */) { + if (declaration.kind === 266 /* EnumDeclaration */) { for (const member of declaration.members) { if (hasBindableName(member)) { const memberSymbol = getSymbolOfDeclaration(member); const value = getEnumMemberValue(member); - const memberType = getFreshTypeOfLiteralType(value !== void 0 ? getEnumLiteralType(value, getSymbolId(symbol), memberSymbol) : createComputedEnumType(memberSymbol)); + const memberType = getFreshTypeOfLiteralType( + value !== void 0 ? getEnumLiteralType(value, getSymbolId(symbol), memberSymbol) : createComputedEnumType(memberSymbol) + ); getSymbolLinks(memberSymbol).declaredType = memberType; memberTypeList.push(getRegularTypeOfLiteralType(memberType)); } @@ -153918,18 +137612,18 @@ ${lanes.join("\n")} case 159 /* UnknownKeyword */: case 154 /* StringKeyword */: case 150 /* NumberKeyword */: - case 162 /* BigIntKeyword */: + case 163 /* BigIntKeyword */: case 136 /* BooleanKeyword */: case 155 /* SymbolKeyword */: case 151 /* ObjectKeyword */: case 116 /* VoidKeyword */: case 157 /* UndefinedKeyword */: case 146 /* NeverKeyword */: - case 200 /* LiteralType */: + case 201 /* LiteralType */: return true; - case 187 /* ArrayType */: + case 188 /* ArrayType */: return isThislessType(node.elementType); - case 182 /* TypeReference */: + case 183 /* TypeReference */: return !node.typeArguments || node.typeArguments.every(isThislessType); } return false; @@ -153945,21 +137639,21 @@ ${lanes.join("\n")} function isThislessFunctionLikeDeclaration(node) { const returnType = getEffectiveReturnTypeNode(node); const typeParameters = getEffectiveTypeParameterDeclarations(node); - return (node.kind === 175 /* Constructor */ || !!returnType && isThislessType(returnType)) && node.parameters.every(isThislessVariableLikeDeclaration) && typeParameters.every(isThislessTypeParameter); + return (node.kind === 176 /* Constructor */ || !!returnType && isThislessType(returnType)) && node.parameters.every(isThislessVariableLikeDeclaration) && typeParameters.every(isThislessTypeParameter); } function isThisless(symbol) { if (symbol.declarations && symbol.declarations.length === 1) { const declaration = symbol.declarations[0]; if (declaration) { switch (declaration.kind) { - case 171 /* PropertyDeclaration */: - case 170 /* PropertySignature */: + case 172 /* PropertyDeclaration */: + case 171 /* PropertySignature */: return isThislessVariableLikeDeclaration(declaration); - case 173 /* MethodDeclaration */: - case 172 /* MethodSignature */: - case 175 /* Constructor */: - case 176 /* GetAccessor */: - case 177 /* SetAccessor */: + case 174 /* MethodDeclaration */: + case 173 /* MethodSignature */: + case 176 /* Constructor */: + case 177 /* GetAccessor */: + case 178 /* SetAccessor */: return isThislessFunctionLikeDeclaration(declaration); } } @@ -154002,9 +137696,6 @@ ${lanes.join("\n")} } return type; } - function isTypeUsableAsPropertyName(type) { - return !!(type.flags & 8576 /* StringOrNumberLiteralOrUnique */); - } function isLateBindableName(node) { if (!isComputedPropertyName(node) && !isElementAccessExpression(node)) { return false; @@ -154025,15 +137716,6 @@ ${lanes.join("\n")} function isNonBindableDynamicName(node) { return isDynamicName(node) && !isLateBindableName(node); } - function getPropertyNameFromType(type) { - if (type.flags & 8192 /* UniqueESSymbol */) { - return type.escapedName; - } - if (type.flags & (128 /* StringLiteral */ | 256 /* NumberLiteral */)) { - return escapeLeadingUnderscores("" + type.value); - } - return Debug.fail(); - } function addDeclarationToLateBoundSymbol(symbol, member, symbolFlags) { Debug.assert(!!(getCheckFlags(symbol) & 4096 /* Late */), "Expected a late-bound symbol."); symbol.flags |= symbolFlags; @@ -154063,11 +137745,11 @@ ${lanes.join("\n")} if (!lateSymbol) lateSymbols.set(memberName, lateSymbol = createSymbol(0 /* None */, memberName, 4096 /* Late */)); const earlySymbol = earlySymbols && earlySymbols.get(memberName); - if (lateSymbol.flags & getExcludedSymbolFlags(symbolFlags) || earlySymbol) { + if (!(parent2.flags & 32 /* Class */) && (lateSymbol.flags & getExcludedSymbolFlags(symbolFlags) || earlySymbol)) { const declarations = earlySymbol ? concatenate(earlySymbol.declarations, lateSymbol.declarations) : lateSymbol.declarations; const name = !(type.flags & 8192 /* UniqueESSymbol */) && unescapeLeadingUnderscores(memberName) || declarationNameToString(declName); - forEach(declarations, (declaration) => error(getNameOfDeclaration(declaration) || declaration, Diagnostics.Property_0_was_also_declared_here, name)); - error(declName || decl, Diagnostics.Duplicate_property_0, name); + forEach(declarations, (declaration) => error2(getNameOfDeclaration(declaration) || declaration, Diagnostics.Property_0_was_also_declared_here, name)); + error2(declName || decl, Diagnostics.Duplicate_property_0, name); lateSymbol = createSymbol(0 /* None */, memberName, 4096 /* Late */); } lateSymbol.links.nameType = type; @@ -154083,6 +137765,7 @@ ${lanes.join("\n")} return links.resolvedSymbol; } function getResolvedMembersOrExportsOfSymbol(symbol, resolutionKind) { + var _a, _b, _c; const links = getSymbolLinks(symbol); if (!links[resolutionKind]) { const isStatic2 = resolutionKind === "resolvedExports" /* resolvedExports */; @@ -154101,7 +137784,7 @@ ${lanes.join("\n")} } } } - const assignments = symbol.assignmentDeclarationMembers; + const assignments = (((_a = symbol.valueDeclaration) == null ? void 0 : _a.kind) === 219 /* ArrowFunction */ || ((_b = symbol.valueDeclaration) == null ? void 0 : _b.kind) === 218 /* FunctionExpression */) && ((_c = getSymbolOfNode(symbol.valueDeclaration.parent)) == null ? void 0 : _c.assignmentDeclarationMembers) || symbol.assignmentDeclarationMembers; if (assignments) { const decls = arrayFrom(assignments.values()); for (const member of decls) { @@ -154114,7 +137797,28 @@ ${lanes.join("\n")} } } } - links[resolutionKind] = combineSymbolTables(earlySymbols, lateSymbols) || emptySymbols; + let resolved = combineSymbolTables(earlySymbols, lateSymbols); + if (symbol.flags & 33554432 /* Transient */ && links.cjsExportMerged && symbol.declarations) { + for (const decl of symbol.declarations) { + const original = getSymbolLinks(decl.symbol)[resolutionKind]; + if (!resolved) { + resolved = original; + continue; + } + if (!original) + continue; + original.forEach((s, name) => { + const existing = resolved.get(name); + if (!existing) + resolved.set(name, s); + else if (existing === s) + return; + else + resolved.set(name, mergeSymbol(existing, s)); + }); + } + } + links[resolutionKind] = resolved || emptySymbols; } return links[resolutionKind]; } @@ -154173,7 +137877,13 @@ ${lanes.join("\n")} const baseTypes = getBaseTypes(source); if (baseTypes.length) { if (source.symbol && members === getMembersOfSymbol(source.symbol)) { - members = createSymbolTable(source.declaredProperties); + const symbolTable = createSymbolTable(); + for (const symbol of members.values()) { + if (!(symbol.flags & 262144 /* TypeParameter */)) { + symbolTable.set(symbol.escapedName, symbol); + } + } + members = symbolTable; } setStructuredTypeMembers(type, members, callSignatures, constructSignatures, indexInfos); const thisArgument = lastOrUndefined(typeArguments); @@ -154204,7 +137914,7 @@ ${lanes.join("\n")} resolveObjectTypeMembers(type, source, typeParameters, paddedTypeArguments); } function createSignature(declaration, typeParameters, thisParameter, parameters, resolvedReturnType, resolvedTypePredicate, minArgumentCount, flags) { - const sig = new Signature15(checker, flags); + const sig = new Signature14(checker, flags); sig.declaration = declaration; sig.typeParameters = typeParameters; sig.parameters = parameters; @@ -154230,7 +137940,7 @@ ${lanes.join("\n")} /*resolvedTypePredicate*/ void 0, sig.minArgumentCount, - sig.flags & 39 /* PropagatingFlags */ + sig.flags & 167 /* PropagatingFlags */ ); result.target = sig.target; result.mapper = sig.mapper; @@ -154257,10 +137967,7 @@ ${lanes.join("\n")} return signature.optionalCallSignatureCache[key] || (signature.optionalCallSignatureCache[key] = createOptionalCallSignature(signature, callChainFlags)); } function createOptionalCallSignature(signature, callChainFlags) { - Debug.assert( - callChainFlags === 8 /* IsInnerCallChain */ || callChainFlags === 16 /* IsOuterCallChain */, - "An optional call signature can either be for an inner call chain or an outer call chain, but not both." - ); + Debug.assert(callChainFlags === 8 /* IsInnerCallChain */ || callChainFlags === 16 /* IsOuterCallChain */, "An optional call signature can either be for an inner call chain or an outer call chain, but not both."); const result = cloneSignature(signature); result.flags |= callChainFlags; return result; @@ -154268,17 +137975,18 @@ ${lanes.join("\n")} function getExpandedParameters(sig, skipUnionExpanding) { if (signatureHasRestParameter(sig)) { const restIndex = sig.parameters.length - 1; + const restName = sig.parameters[restIndex].escapedName; const restType = getTypeOfSymbol(sig.parameters[restIndex]); if (isTupleType(restType)) { - return [expandSignatureParametersWithTupleMembers(restType, restIndex)]; + return [expandSignatureParametersWithTupleMembers(restType, restIndex, restName)]; } else if (!skipUnionExpanding && restType.flags & 1048576 /* Union */ && every(restType.types, isTupleType)) { - return map(restType.types, (t) => expandSignatureParametersWithTupleMembers(t, restIndex)); + return map(restType.types, (t) => expandSignatureParametersWithTupleMembers(t, restIndex, restName)); } } return [sig.parameters]; - function expandSignatureParametersWithTupleMembers(restType, restIndex) { - const elementTypes = getElementTypes(restType); - const associatedNames = getUniqAssociatedNamesFromTupleType(restType); + function expandSignatureParametersWithTupleMembers(restType, restIndex, restName) { + const elementTypes = getTypeArguments(restType); + const associatedNames = getUniqAssociatedNamesFromTupleType(restType, restName); const restParams = map(elementTypes, (t, i) => { const name = associatedNames && associatedNames[i] ? associatedNames[i] : getParameterNameAtPosition(sig, restIndex + i, restType); const flags = restType.target.elementFlags[i]; @@ -154289,10 +137997,10 @@ ${lanes.join("\n")} }); return concatenate(sig.parameters.slice(0, restIndex), restParams); } - function getUniqAssociatedNamesFromTupleType(type) { + function getUniqAssociatedNamesFromTupleType(type, restName) { const associatedNamesMap = /* @__PURE__ */ new Map(); - return map(type.target.labeledElementDeclarations, (labeledElement) => { - const name = getTupleElementLabel(labeledElement); + return map(type.target.labeledElementDeclarations, (labeledElement, i) => { + const name = getTupleElementLabel(labeledElement, i, restName); const prevCounter = associatedNamesMap.get(name); if (prevCounter === void 0) { associatedNamesMap.set(name, 1); @@ -154308,7 +138016,7 @@ ${lanes.join("\n")} const baseConstructorType = getBaseConstructorTypeOfClass(classType); const baseSignatures = getSignaturesOfType(baseConstructorType, 1 /* Construct */); const declaration = getClassLikeDeclarationOfSymbol(classType.symbol); - const isAbstract = !!declaration && hasSyntacticModifier(declaration, 256 /* Abstract */); + const isAbstract = !!declaration && hasSyntacticModifier(declaration, 64 /* Abstract */); if (baseSignatures.length === 0) { return [createSignature( /*declaration*/ @@ -154495,13 +138203,14 @@ ${lanes.join("\n")} const paramName = leftName === rightName ? leftName : !leftName ? rightName : !rightName ? leftName : void 0; const paramSymbol = createSymbol( 1 /* FunctionScopedVariable */ | (isOptional && !isRestParam ? 16777216 /* Optional */ : 0), - paramName || `arg${i}` + paramName || `arg${i}`, + isRestParam ? 32768 /* RestParameter */ : isOptional ? 16384 /* OptionalParameter */ : 0 ); paramSymbol.links.type = isRestParam ? createArrayType(unionParamType) : unionParamType; params[i] = paramSymbol; } if (needsExtraRestElement) { - const restParamSymbol = createSymbol(1 /* FunctionScopedVariable */, "args"); + const restParamSymbol = createSymbol(1 /* FunctionScopedVariable */, "args", 32768 /* RestParameter */); restParamSymbol.links.type = createArrayType(getTypeAtPosition(shorter, longestCount)); if (shorter === right) { restParamSymbol.links.type = instantiateType(restParamSymbol.links.type, mapper); @@ -154530,7 +138239,7 @@ ${lanes.join("\n")} /*resolvedTypePredicate*/ void 0, minArgCount, - (left.flags | right.flags) & 39 /* PropagatingFlags */ + (left.flags | right.flags) & 167 /* PropagatingFlags */ ); result.compositeKind = 1048576 /* Union */; result.compositeSignatures = concatenate(left.compositeKind !== 2097152 /* Intersection */ && left.compositeSignatures || [left], [right]); @@ -154546,11 +138255,7 @@ ${lanes.join("\n")} for (const info of sourceInfos) { const indexType = info.keyType; if (every(types, (t) => !!getIndexInfoOfType(t, indexType))) { - result.push(createIndexInfo( - indexType, - getUnionType(map(types, (t) => getIndexTypeOfType(t, indexType))), - some(types, (t) => getIndexInfoOfType(t, indexType).isReadonly) - )); + result.push(createIndexInfo(indexType, getUnionType(map(types, (t) => getIndexTypeOfType(t, indexType))), some(types, (t) => getIndexInfoOfType(t, indexType).isReadonly))); } } return result; @@ -154642,11 +138347,7 @@ ${lanes.join("\n")} for (let i = 0; i < indexInfos.length; i++) { const info = indexInfos[i]; if (info.keyType === newInfo.keyType) { - indexInfos[i] = createIndexInfo( - info.keyType, - union ? getUnionType([info.type, newInfo.type]) : getIntersectionType([info.type, newInfo.type]), - union ? info.isReadonly || newInfo.isReadonly : info.isReadonly && newInfo.isReadonly - ); + indexInfos[i] = createIndexInfo(info.keyType, union ? getUnionType([info.type, newInfo.type]) : getIntersectionType([info.type, newInfo.type]), union ? info.isReadonly || newInfo.isReadonly : info.isReadonly && newInfo.isReadonly); return indexInfos; } } @@ -154678,20 +138379,17 @@ ${lanes.join("\n")} setStructuredTypeMembers(type, members2, callSignatures, constructSignatures, indexInfos2); return; } - let members = emptySymbols; + let members = getExportsOfSymbol(symbol); let indexInfos; - if (symbol.exports) { - members = getExportsOfSymbol(symbol); - if (symbol === globalThisSymbol) { - const varsOnly = /* @__PURE__ */ new Map(); - members.forEach((p) => { - var _a; - if (!(p.flags & 418 /* BlockScoped */) && !(p.flags & 512 /* ValueModule */ && ((_a = p.declarations) == null ? void 0 : _a.length) && every(p.declarations, isAmbientModule))) { - varsOnly.set(p.escapedName, p); - } - }); - members = varsOnly; - } + if (symbol === globalThisSymbol) { + const varsOnly = /* @__PURE__ */ new Map(); + members.forEach((p) => { + var _a; + if (!(p.flags & 418 /* BlockScoped */) && !(p.flags & 512 /* ValueModule */ && ((_a = p.declarations) == null ? void 0 : _a.length) && every(p.declarations, isAmbientModule))) { + varsOnly.set(p.escapedName, p); + } + }); + members = varsOnly; } let baseConstructorIndexInfo; setStructuredTypeMembers(type, members, emptyArray, emptyArray, emptyArray); @@ -154729,20 +138427,23 @@ ${lanes.join("\n")} const classType = getDeclaredTypeOfClassOrInterface(symbol); let constructSignatures = symbol.members ? getSignaturesOfSymbol(symbol.members.get("__constructor" /* Constructor */)) : emptyArray; if (symbol.flags & 16 /* Function */) { - constructSignatures = addRange(constructSignatures.slice(), mapDefined( - type.callSignatures, - (sig) => isJSConstructor(sig.declaration) ? createSignature( - sig.declaration, - sig.typeParameters, - sig.thisParameter, - sig.parameters, - classType, - /*resolvedTypePredicate*/ - void 0, - sig.minArgumentCount, - sig.flags & 39 /* PropagatingFlags */ - ) : void 0 - )); + constructSignatures = addRange( + constructSignatures.slice(), + mapDefined( + type.callSignatures, + (sig) => isJSConstructor(sig.declaration) ? createSignature( + sig.declaration, + sig.typeParameters, + sig.thisParameter, + sig.parameters, + classType, + /*resolvedTypePredicate*/ + void 0, + sig.minArgumentCount, + sig.flags & 167 /* PropagatingFlags */ + ) : void 0 + ) + ); } if (!constructSignatures.length) { constructSignatures = getDefaultConstructSignatures(classType); @@ -154864,11 +138565,7 @@ ${lanes.join("\n")} const isReadonly = !!(templateModifiers & 1 /* IncludeReadonly */ || !(templateModifiers & 2 /* ExcludeReadonly */) && modifiersProp && isReadonlySymbol(modifiersProp)); const stripOptional = strictNullChecks && !isOptional && modifiersProp && modifiersProp.flags & 16777216 /* Optional */; const lateFlag = modifiersProp ? getIsLateCheckFlag(modifiersProp) : 0; - const prop = createSymbol( - 4 /* Property */ | (isOptional ? 16777216 /* Optional */ : 0), - propName, - lateFlag | 262144 /* Mapped */ | (isReadonly ? 8 /* Readonly */ : 0) | (stripOptional ? 524288 /* StripOptional */ : 0) - ); + const prop = createSymbol(4 /* Property */ | (isOptional ? 16777216 /* Optional */ : 0), propName, lateFlag | 262144 /* Mapped */ | (isReadonly ? 8 /* Readonly */ : 0) | (stripOptional ? 524288 /* StripOptional */ : 0)); prop.links.mappedType = type; prop.links.nameType = propNameType; prop.links.keyType = keyType; @@ -154881,7 +138578,9 @@ ${lanes.join("\n")} } else if (isValidIndexKeyType(propNameType) || propNameType.flags & (1 /* Any */ | 32 /* Enum */)) { const indexKeyType = propNameType.flags & (1 /* Any */ | 4 /* String */) ? stringType : propNameType.flags & (8 /* Number */ | 32 /* Enum */) ? numberType : propNameType; const propType = instantiateType(templateType, appendTypeMapping(type.mapper, typeParameter, keyType)); - const indexInfo = createIndexInfo(indexKeyType, propType, !!(templateModifiers & 1 /* IncludeReadonly */)); + const modifiersIndexInfo = getApplicableIndexInfo(modifiersType, propNameType); + const isReadonly = !!(templateModifiers & 1 /* IncludeReadonly */ || !(templateModifiers & 2 /* ExcludeReadonly */) && (modifiersIndexInfo == null ? void 0 : modifiersIndexInfo.isReadonly)); + const indexInfo = createIndexInfo(indexKeyType, propType, isReadonly); indexInfos = appendIndexInfo( indexInfos, indexInfo, @@ -154907,7 +138606,7 @@ ${lanes.join("\n")} true ) : symbol.links.checkFlags & 524288 /* StripOptional */ ? removeMissingOrUndefinedType(propType) : propType; if (!popTypeResolution()) { - error(currentNode, Diagnostics.Type_of_property_0_circularly_references_itself_in_mapped_type_1, symbolToString(symbol), typeToString(mappedType)); + error2(currentNode, Diagnostics.Type_of_property_0_circularly_references_itself_in_mapped_type_1, symbolToString(symbol), typeToString(mappedType)); type = errorType; } symbol.links.type = type; @@ -154936,7 +138635,7 @@ ${lanes.join("\n")} } function isMappedTypeWithKeyofConstraintDeclaration(type) { const constraintDeclaration = getConstraintDeclarationForMappedType(type); - return constraintDeclaration.kind === 197 /* TypeOperator */ && constraintDeclaration.operator === 143 /* KeyOfKeyword */; + return constraintDeclaration.kind === 198 /* TypeOperator */ && constraintDeclaration.operator === 143 /* KeyOfKeyword */; } function getModifiersTypeFromMappedType(type) { if (!type.modifiersType) { @@ -155091,9 +138790,9 @@ ${lanes.join("\n")} function getConstraintOfTypeParameter(typeParameter) { return hasNonCircularBaseConstraint(typeParameter) ? getConstraintFromTypeParameter(typeParameter) : void 0; } - function isConstTypeVariable(type) { + function isConstTypeVariable(type, depth = 0) { var _a; - return !!(type && (type.flags & 262144 /* TypeParameter */ && some((_a = type.symbol) == null ? void 0 : _a.declarations, (d) => hasSyntacticModifier(d, 2048 /* Const */)) || type.flags & 1048576 /* Union */ && some(type.types, isConstTypeVariable) || type.flags & 8388608 /* IndexedAccess */ && isConstTypeVariable(type.objectType) || type.flags & 16777216 /* Conditional */ && isConstTypeVariable(getConstraintOfConditionalType(type)) || type.flags & 33554432 /* Substitution */ && isConstTypeVariable(type.baseType) || isGenericTupleType(type) && findIndex(getElementTypes(type), (t, i) => !!(type.target.elementFlags[i] & 8 /* Variadic */) && isConstTypeVariable(t)) >= 0)); + return depth < 5 && !!(type && (type.flags & 262144 /* TypeParameter */ && some((_a = type.symbol) == null ? void 0 : _a.declarations, (d) => hasSyntacticModifier(d, 4096 /* Const */)) || type.flags & 3145728 /* UnionOrIntersection */ && some(type.types, (t) => isConstTypeVariable(t, depth)) || type.flags & 8388608 /* IndexedAccess */ && isConstTypeVariable(type.objectType, depth + 1) || type.flags & 16777216 /* Conditional */ && isConstTypeVariable(getConstraintOfConditionalType(type), depth + 1) || type.flags & 33554432 /* Substitution */ && isConstTypeVariable(type.baseType, depth) || isGenericTupleType(type) && findIndex(getElementTypes(type), (t, i) => !!(type.target.elementFlags[i] & 8 /* Variadic */) && isConstTypeVariable(t, depth)) >= 0)); } function getConstraintOfIndexedAccess(type) { return hasNonCircularBaseConstraint(type) ? getConstraintFromIndexedAccess(type) : void 0; @@ -155233,7 +138932,7 @@ ${lanes.join("\n")} if (t.flags & 262144 /* TypeParameter */) { const errorNode = getConstraintDeclaration(t); if (errorNode) { - const diagnostic = error(errorNode, Diagnostics.Type_parameter_0_has_a_circular_constraint, typeToString(t)); + const diagnostic = error2(errorNode, Diagnostics.Type_parameter_0_has_a_circular_constraint, typeToString(t)); if (currentNode && !isNodeDescendantOf(errorNode, currentNode) && !isNodeDescendantOf(currentNode, errorNode)) { addRelatedInfo(diagnostic, createDiagnosticForNode(currentNode, Diagnostics.Circularity_originates_in_type_at_this_location)); } @@ -155419,7 +139118,7 @@ ${lanes.join("\n")} } else if (!isUnion && !isReadonlySymbol(prop)) { checkFlags &= ~8 /* Readonly */; } - checkFlags |= (!(modifiers & 24 /* NonPublicAccessibilityModifier */) ? 256 /* ContainsPublic */ : 0) | (modifiers & 16 /* Protected */ ? 512 /* ContainsProtected */ : 0) | (modifiers & 8 /* Private */ ? 1024 /* ContainsPrivate */ : 0) | (modifiers & 32 /* Static */ ? 2048 /* ContainsStatic */ : 0); + checkFlags |= (!(modifiers & 6 /* NonPublicAccessibilityModifier */) ? 256 /* ContainsPublic */ : 0) | (modifiers & 4 /* Protected */ ? 512 /* ContainsProtected */ : 0) | (modifiers & 2 /* Private */ ? 1024 /* ContainsPrivate */ : 0) | (modifiers & 256 /* Static */ ? 2048 /* ContainsStatic */ : 0); if (!isPrototypeProperty(prop)) { syntheticFlag = 2 /* SyntheticProperty */; } @@ -155475,7 +139174,8 @@ ${lanes.join("\n")} const writeType = getWriteTypeOfSymbol(prop); if (writeTypes || writeType !== type) { writeTypes = append(!writeTypes ? propTypes.slice() : writeTypes, writeType); - } else if (type !== firstType) { + } + if (type !== firstType) { checkFlags |= 64 /* HasNonUniformType */; } if (isLiteralType(type) || isPatternLiteralType(type)) { @@ -155589,31 +139289,21 @@ ${lanes.join("\n")} if (type.flags & 2097152 /* Intersection */ && getObjectFlags(type) & 33554432 /* IsNeverIntersection */) { const neverProp = find(getPropertiesOfUnionOrIntersectionType(type), isDiscriminantWithNeverType); if (neverProp) { - return chainDiagnosticMessages( - errorInfo, - Diagnostics.The_intersection_0_was_reduced_to_never_because_property_1_has_conflicting_types_in_some_constituents, - typeToString( - type, - /*enclosingDeclaration*/ - void 0, - 536870912 /* NoTypeReduction */ - ), - symbolToString(neverProp) - ); + return chainDiagnosticMessages(errorInfo, Diagnostics.The_intersection_0_was_reduced_to_never_because_property_1_has_conflicting_types_in_some_constituents, typeToString( + type, + /*enclosingDeclaration*/ + void 0, + 536870912 /* NoTypeReduction */ + ), symbolToString(neverProp)); } const privateProp = find(getPropertiesOfUnionOrIntersectionType(type), isConflictingPrivateProperty); if (privateProp) { - return chainDiagnosticMessages( - errorInfo, - Diagnostics.The_intersection_0_was_reduced_to_never_because_property_1_exists_in_multiple_constituents_and_is_private_in_some, - typeToString( - type, - /*enclosingDeclaration*/ - void 0, - 536870912 /* NoTypeReduction */ - ), - symbolToString(privateProp) - ); + return chainDiagnosticMessages(errorInfo, Diagnostics.The_intersection_0_was_reduced_to_never_because_property_1_exists_in_multiple_constituents_and_is_private_in_some, typeToString( + type, + /*enclosingDeclaration*/ + void 0, + 536870912 /* NoTypeReduction */ + ), symbolToString(privateProp)); } } return errorInfo; @@ -155650,7 +139340,35 @@ ${lanes.join("\n")} return emptyArray; } function getSignaturesOfType(type, kind) { - return getSignaturesOfStructuredType(getReducedApparentType(type), kind); + const result = getSignaturesOfStructuredType(getReducedApparentType(type), kind); + if (kind === 0 /* Call */ && !length(result) && type.flags & 1048576 /* Union */) { + if (type.arrayFallbackSignatures) { + return type.arrayFallbackSignatures; + } + let memberName; + if (everyType(type, (t) => { + var _a; + return !!((_a = t.symbol) == null ? void 0 : _a.parent) && isArrayOrTupleSymbol(t.symbol.parent) && (!memberName ? (memberName = t.symbol.escapedName, true) : memberName === t.symbol.escapedName); + })) { + const arrayArg = mapType(type, (t) => getMappedType((isReadonlyArraySymbol(t.symbol.parent) ? globalReadonlyArrayType : globalArrayType).typeParameters[0], t.mapper)); + const arrayType = createArrayType(arrayArg, someType(type, (t) => isReadonlyArraySymbol(t.symbol.parent))); + return type.arrayFallbackSignatures = getSignaturesOfType(getTypeOfPropertyOfType(arrayType, memberName), kind); + } + type.arrayFallbackSignatures = result; + } + return result; + } + function isArrayOrTupleSymbol(symbol) { + if (!symbol || !globalArrayType.symbol || !globalReadonlyArrayType.symbol) { + return false; + } + return !!getSymbolIfSameReference(symbol, globalArrayType.symbol) || !!getSymbolIfSameReference(symbol, globalReadonlyArrayType.symbol); + } + function isReadonlyArraySymbol(symbol) { + if (!symbol || !globalReadonlyArrayType.symbol) { + return false; + } + return !!getSymbolIfSameReference(symbol, globalReadonlyArrayType.symbol); } function findIndexInfo(indexInfos, keyType) { return find(indexInfos, (info) => info.keyType === keyType); @@ -155670,16 +139388,12 @@ ${lanes.join("\n")} } } } - return applicableInfos ? createIndexInfo( - unknownType, - getIntersectionType(map(applicableInfos, (info) => info.type)), - reduceLeft( - applicableInfos, - (isReadonly, info) => isReadonly && info.isReadonly, - /*initial*/ - true - ) - ) : applicableInfo ? applicableInfo : stringIndexInfo && isApplicableIndexType(keyType, stringType) ? stringIndexInfo : void 0; + return applicableInfos ? createIndexInfo(unknownType, getIntersectionType(map(applicableInfos, (info) => info.type)), reduceLeft( + applicableInfos, + (isReadonly, info) => isReadonly && info.isReadonly, + /*initial*/ + true + )) : applicableInfo ? applicableInfo : stringIndexInfo && isApplicableIndexType(keyType, stringType) ? stringIndexInfo : void 0; } function isApplicableIndexType(source, target) { return isTypeAssignableTo(source, target) || target === stringType && isTypeAssignableTo(source, numberType) || target === numberType && (source === numericStringType || !!(source.flags & 128 /* StringLiteral */) && isNumericLiteralName(source.value)); @@ -155746,7 +139460,7 @@ ${lanes.join("\n")} } const iife = getImmediatelyInvokedFunctionExpression(node.parent); if (iife) { - return !node.type && !node.dotDotDotToken && node.parent.parameters.indexOf(node) >= iife.arguments.length; + return !node.type && !node.dotDotDotToken && node.parent.parameters.indexOf(node) >= getEffectiveCallArguments(iife).length; } return false; } @@ -155829,7 +139543,7 @@ ${lanes.join("\n")} } else { parameters.push(paramSymbol); } - if (type && type.kind === 200 /* LiteralType */) { + if (type && type.kind === 201 /* LiteralType */) { flags |= 2 /* HasLiteralTypes */; } const isOptionalParameter2 = isOptionalJSDocPropertyLikeTag(param) || param.initializer || param.questionToken || isRestParameter(param) || iife && parameters.length > iife.arguments.length && !type || isJSDocOptionalParameter(param); @@ -155837,8 +139551,8 @@ ${lanes.join("\n")} minArgumentCount = parameters.length; } } - if ((declaration.kind === 176 /* GetAccessor */ || declaration.kind === 177 /* SetAccessor */) && hasBindableName(declaration) && (!hasThisParameter2 || !thisParameter)) { - const otherKind = declaration.kind === 176 /* GetAccessor */ ? 177 /* SetAccessor */ : 176 /* GetAccessor */; + if ((declaration.kind === 177 /* GetAccessor */ || declaration.kind === 178 /* SetAccessor */) && hasBindableName(declaration) && (!hasThisParameter2 || !thisParameter)) { + const otherKind = declaration.kind === 177 /* GetAccessor */ ? 178 /* SetAccessor */ : 177 /* GetAccessor */; const other = getDeclarationOfKind(getSymbolOfDeclaration(declaration), otherKind); if (other) { thisParameter = getAnnotatedAccessorThisParameter(other); @@ -155856,7 +139570,7 @@ ${lanes.join("\n")} if (hasRestParameter(declaration) || isInJSFile(declaration) && maybeAddJsSyntheticRestParameter(declaration, parameters)) { flags |= 1 /* HasRestParameter */; } - if (isConstructorTypeNode(declaration) && hasSyntacticModifier(declaration, 256 /* Abstract */) || isConstructorDeclaration(declaration) && hasSyntacticModifier(declaration.parent, 256 /* Abstract */)) { + if (isConstructorTypeNode(declaration) && hasSyntacticModifier(declaration, 64 /* Abstract */) || isConstructorDeclaration(declaration) && hasSyntacticModifier(declaration.parent, 64 /* Abstract */)) { flags |= 4 /* Abstract */; } links.resolvedSignature = createSignature( @@ -155929,15 +139643,15 @@ ${lanes.join("\n")} switch (node.kind) { case 80 /* Identifier */: return node.escapedText === argumentsSymbol.escapedName && getReferencedValueSymbol(node) === argumentsSymbol; - case 171 /* PropertyDeclaration */: - case 173 /* MethodDeclaration */: - case 176 /* GetAccessor */: - case 177 /* SetAccessor */: - return node.name.kind === 166 /* ComputedPropertyName */ && traverse(node.name); - case 210 /* PropertyAccessExpression */: - case 211 /* ElementAccessExpression */: + case 172 /* PropertyDeclaration */: + case 174 /* MethodDeclaration */: + case 177 /* GetAccessor */: + case 178 /* SetAccessor */: + return node.name.kind === 167 /* ComputedPropertyName */ && traverse(node.name); + case 211 /* PropertyAccessExpression */: + case 212 /* ElementAccessExpression */: return traverse(node.expression); - case 302 /* PropertyAssignment */: + case 303 /* PropertyAssignment */: return traverse(node.initializer); default: return !nodeStartsNewLexicalEnvironment(node) && !isPartOfTypeNode(node) && !!forEachChild(node, traverse); @@ -156024,19 +139738,14 @@ ${lanes.join("\n")} function createTypePredicateFromTypePredicateNode(node, signature) { const parameterName = node.parameterName; const type = node.type && getTypeFromTypeNode(node.type); - return parameterName.kind === 196 /* ThisType */ ? createTypePredicate( + return parameterName.kind === 197 /* ThisType */ ? createTypePredicate( node.assertsModifier ? 2 /* AssertsThis */ : 0 /* This */, /*parameterName*/ void 0, /*parameterIndex*/ void 0, type - ) : createTypePredicate( - node.assertsModifier ? 3 /* AssertsIdentifier */ : 1 /* Identifier */, - parameterName.escapedText, - findIndex(signature.parameters, (p) => p.escapedName === parameterName.escapedText), - type - ); + ) : createTypePredicate(node.assertsModifier ? 3 /* AssertsIdentifier */ : 1 /* Identifier */, parameterName.escapedText, findIndex(signature.parameters, (p) => p.escapedName === parameterName.escapedText), type); } function getUnionOrIntersectionType(types, kind, unionReduction) { return kind !== 2097152 /* Intersection */ ? getUnionType(types, unionReduction) : getIntersectionType(types); @@ -156056,14 +139765,14 @@ ${lanes.join("\n")} if (signature.declaration) { const typeNode = getEffectiveReturnTypeNode(signature.declaration); if (typeNode) { - error(typeNode, Diagnostics.Return_type_annotation_circularly_references_itself); + error2(typeNode, Diagnostics.Return_type_annotation_circularly_references_itself); } else if (noImplicitAny) { const declaration = signature.declaration; const name = getNameOfDeclaration(declaration); if (name) { - error(name, Diagnostics._0_implicitly_has_return_type_any_because_it_does_not_have_a_return_type_annotation_and_is_referenced_directly_or_indirectly_in_one_of_its_return_expressions, declarationNameToString(name)); + error2(name, Diagnostics._0_implicitly_has_return_type_any_because_it_does_not_have_a_return_type_annotation_and_is_referenced_directly_or_indirectly_in_one_of_its_return_expressions, declarationNameToString(name)); } else { - error(declaration, Diagnostics.Function_implicitly_has_return_type_any_because_it_does_not_have_a_return_type_annotation_and_is_referenced_directly_or_indirectly_in_one_of_its_return_expressions); + error2(declaration, Diagnostics.Function_implicitly_has_return_type_any_because_it_does_not_have_a_return_type_annotation_and_is_referenced_directly_or_indirectly_in_one_of_its_return_expressions); } } } @@ -156074,7 +139783,7 @@ ${lanes.join("\n")} return signature.resolvedReturnType; } function getReturnTypeFromAnnotation(declaration) { - if (declaration.kind === 175 /* Constructor */) { + if (declaration.kind === 176 /* Constructor */) { return getDeclaredTypeOfClassOrInterface(getMergedSymbol(declaration.parent.symbol)); } const typeNode = getEffectiveReturnTypeNode(declaration); @@ -156090,12 +139799,12 @@ ${lanes.join("\n")} if (typeNode) { return getTypeFromTypeNode(typeNode); } - if (declaration.kind === 176 /* GetAccessor */ && hasBindableName(declaration)) { + if (declaration.kind === 177 /* GetAccessor */ && hasBindableName(declaration)) { const jsDocType = isInJSFile(declaration) && getTypeForDeclarationFromJSDocComment(declaration); if (jsDocType) { return jsDocType; } - const setter = getDeclarationOfKind(getSymbolOfDeclaration(declaration), 177 /* SetAccessor */); + const setter = getDeclarationOfKind(getSymbolOfDeclaration(declaration), 178 /* SetAccessor */); const setterType = getAnnotatedAccessorType(setter); if (setterType) { return setterType; @@ -156104,7 +139813,7 @@ ${lanes.join("\n")} return getReturnTypeOfTypeTag(declaration); } function isResolvingReturnTypeOfSignature(signature) { - return !signature.resolvedReturnType && findResolutionCycleStartIndex(signature, 3 /* ResolvedReturnType */) >= 0; + return signature.compositeSignatures && some(signature.compositeSignatures, isResolvingReturnTypeOfSignature) || !signature.resolvedReturnType && findResolutionCycleStartIndex(signature, 3 /* ResolvedReturnType */) >= 0; } function getRestTypeOfSignature(signature) { return tryGetRestTypeOfSignature(signature) || anyType; @@ -156198,7 +139907,7 @@ ${lanes.join("\n")} var _a; if (!signature.isolatedSignatureType) { const kind = (_a = signature.declaration) == null ? void 0 : _a.kind; - const isConstructor = kind === void 0 || kind === 175 /* Constructor */ || kind === 179 /* ConstructSignature */ || kind === 184 /* ConstructorType */; + const isConstructor = kind === void 0 || kind === 176 /* Constructor */ || kind === 180 /* ConstructSignature */ || kind === 185 /* ConstructorType */; const type = createObjectType(16 /* Anonymous */); type.members = emptySymbols; type.properties = emptyArray; @@ -156231,12 +139940,7 @@ ${lanes.join("\n")} if (parameter.type) { forEachType(getTypeFromTypeNode(parameter.type), (keyType) => { if (isValidIndexKeyType(keyType) && !findIndexInfo(indexInfos, keyType)) { - indexInfos.push(createIndexInfo( - keyType, - declaration.type ? getTypeFromTypeNode(declaration.type) : anyType, - hasEffectiveModifier(declaration, 64 /* Readonly */), - declaration - )); + indexInfos.push(createIndexInfo(keyType, declaration.type ? getTypeFromTypeNode(declaration.type) : anyType, hasEffectiveModifier(declaration, 8 /* Readonly */), declaration)); } }); } @@ -156257,9 +139961,9 @@ ${lanes.join("\n")} let inferences; if ((_a = typeParameter.symbol) == null ? void 0 : _a.declarations) { for (const declaration of typeParameter.symbol.declarations) { - if (declaration.parent.kind === 194 /* InferType */) { + if (declaration.parent.kind === 195 /* InferType */) { const [childTypeParameter = declaration.parent, grandParent] = walkUpParenthesizedTypesAndGetParentAndChild(declaration.parent.parent); - if (grandParent.kind === 182 /* TypeReference */ && !omitTypeReferences) { + if (grandParent.kind === 183 /* TypeReference */ && !omitTypeReferences) { const typeReference = grandParent; const typeParameters = getTypeParametersForTypeReferenceOrImport(typeReference); if (typeParameters) { @@ -156267,9 +139971,12 @@ ${lanes.join("\n")} if (index < typeParameters.length) { const declaredConstraint = getConstraintOfTypeParameter(typeParameters[index]); if (declaredConstraint) { - const mapper = makeDeferredTypeMapper(typeParameters, typeParameters.map((_, index2) => () => { - return getEffectiveTypeArgumentAtIndex(typeReference, typeParameters, index2); - })); + const mapper = makeDeferredTypeMapper( + typeParameters, + typeParameters.map((_, index2) => () => { + return getEffectiveTypeArgumentAtIndex(typeReference, typeParameters, index2); + }) + ); const constraint = instantiateType(declaredConstraint, mapper); if (constraint !== typeParameter) { inferences = append(inferences, constraint); @@ -156277,19 +139984,16 @@ ${lanes.join("\n")} } } } - } else if (grandParent.kind === 168 /* Parameter */ && grandParent.dotDotDotToken || grandParent.kind === 190 /* RestType */ || grandParent.kind === 201 /* NamedTupleMember */ && grandParent.dotDotDotToken) { + } else if (grandParent.kind === 169 /* Parameter */ && grandParent.dotDotDotToken || grandParent.kind === 191 /* RestType */ || grandParent.kind === 202 /* NamedTupleMember */ && grandParent.dotDotDotToken) { inferences = append(inferences, createArrayType(unknownType)); - } else if (grandParent.kind === 203 /* TemplateLiteralTypeSpan */) { + } else if (grandParent.kind === 204 /* TemplateLiteralTypeSpan */) { inferences = append(inferences, stringType); - } else if (grandParent.kind === 167 /* TypeParameter */ && grandParent.parent.kind === 199 /* MappedType */) { + } else if (grandParent.kind === 168 /* TypeParameter */ && grandParent.parent.kind === 200 /* MappedType */) { inferences = append(inferences, keyofConstraintType); - } else if (grandParent.kind === 199 /* MappedType */ && grandParent.type && skipParentheses(grandParent.type) === declaration.parent && grandParent.parent.kind === 193 /* ConditionalType */ && grandParent.parent.extendsType === grandParent && grandParent.parent.checkType.kind === 199 /* MappedType */ && grandParent.parent.checkType.type) { + } else if (grandParent.kind === 200 /* MappedType */ && grandParent.type && skipParentheses(grandParent.type) === declaration.parent && grandParent.parent.kind === 194 /* ConditionalType */ && grandParent.parent.extendsType === grandParent && grandParent.parent.checkType.kind === 200 /* MappedType */ && grandParent.parent.checkType.type) { const checkMappedType2 = grandParent.parent.checkType; const nodeType = getTypeFromTypeNode(checkMappedType2.type); - inferences = append(inferences, instantiateType( - nodeType, - makeUnaryTypeMapper(getDeclaredTypeOfTypeParameter(getSymbolOfDeclaration(checkMappedType2.typeParameter)), checkMappedType2.typeParameter.constraint ? getTypeFromTypeNode(checkMappedType2.typeParameter.constraint) : keyofConstraintType) - )); + inferences = append(inferences, instantiateType(nodeType, makeUnaryTypeMapper(getDeclaredTypeOfTypeParameter(getSymbolOfDeclaration(checkMappedType2.typeParameter)), checkMappedType2.typeParameter.constraint ? getTypeFromTypeNode(checkMappedType2.typeParameter.constraint) : keyofConstraintType))); } } } @@ -156308,7 +140012,7 @@ ${lanes.join("\n")} } else { let type = getTypeFromTypeNode(constraintDeclaration); if (type.flags & 1 /* Any */ && !isErrorType(type)) { - type = constraintDeclaration.parent.parent.kind === 199 /* MappedType */ ? keyofConstraintType : unknownType; + type = constraintDeclaration.parent.parent.kind === 200 /* MappedType */ ? keyofConstraintType : unknownType; } typeParameter.constraint = type; } @@ -156317,7 +140021,7 @@ ${lanes.join("\n")} return typeParameter.constraint === noConstraintType ? void 0 : typeParameter.constraint; } function getParentSymbolOfTypeParameter(typeParameter) { - const tp = getDeclarationOfKind(typeParameter.symbol, 167 /* TypeParameter */); + const tp = getDeclarationOfKind(typeParameter.symbol, 168 /* TypeParameter */); const host2 = isJSDocTemplateTag(tp.parent) ? getEffectiveContainerForJSDocTemplateTag(tp.parent) : tp.parent; return host2 && getSymbolOfNode(host2); } @@ -156402,12 +140106,12 @@ ${lanes.join("\n")} return ((_a = type.target.localTypeParameters) == null ? void 0 : _a.map(() => errorType)) || emptyArray; } const node = type.node; - const typeArguments = !node ? emptyArray : node.kind === 182 /* TypeReference */ ? concatenate(type.target.outerTypeParameters, getEffectiveTypeArguments2(node, type.target.localTypeParameters)) : node.kind === 187 /* ArrayType */ ? [getTypeFromTypeNode(node.elementType)] : map(node.elements, getTypeFromTypeNode); + const typeArguments = !node ? emptyArray : node.kind === 183 /* TypeReference */ ? concatenate(type.target.outerTypeParameters, getEffectiveTypeArguments2(node, type.target.localTypeParameters)) : node.kind === 188 /* ArrayType */ ? [getTypeFromTypeNode(node.elementType)] : map(node.elements, getTypeFromTypeNode); if (popTypeResolution()) { type.resolvedTypeArguments = type.mapper ? instantiateTypes(typeArguments, type.mapper) : typeArguments; } else { type.resolvedTypeArguments = ((_b = type.target.localTypeParameters) == null ? void 0 : _b.map(() => errorType)) || emptyArray; - error( + error2( type.node || currentNode, type.target.symbol ? Diagnostics.Type_arguments_for_0_circularly_reference_themselves : Diagnostics.Tuple_type_arguments_circularly_reference_themselves, type.target.symbol && symbolToString(type.target.symbol) @@ -156436,12 +140140,12 @@ ${lanes.join("\n")} void 0, 2 /* WriteArrayAsGenericType */ ); - error(node, diag2, typeStr, minTypeArgumentCount, typeParameters.length); + error2(node, diag2, typeStr, minTypeArgumentCount, typeParameters.length); if (!isJs) { return errorType; } } - if (node.kind === 182 /* TypeReference */ && isDeferredTypeReferenceNode(node, length(node.typeArguments) !== typeParameters.length)) { + if (node.kind === 183 /* TypeReference */ && isDeferredTypeReferenceNode(node, length(node.typeArguments) !== typeParameters.length)) { return createDeferredTypeReference( type, node, @@ -156464,12 +140168,7 @@ ${lanes.join("\n")} const id = getTypeListId(typeArguments) + getAliasId(aliasSymbol, aliasTypeArguments); let instantiation = links.instantiations.get(id); if (!instantiation) { - links.instantiations.set(id, instantiation = instantiateTypeWithAlias( - type, - createTypeMapper(typeParameters, fillMissingTypeArguments(typeArguments, typeParameters, getMinTypeArgumentCount(typeParameters), isInJSFile(symbol.valueDeclaration))), - aliasSymbol, - aliasTypeArguments - )); + links.instantiations.set(id, instantiation = instantiateTypeWithAlias(type, createTypeMapper(typeParameters, fillMissingTypeArguments(typeArguments, typeParameters, getMinTypeArgumentCount(typeParameters), isInJSFile(symbol.valueDeclaration))), aliasSymbol, aliasTypeArguments)); } return instantiation; } @@ -156479,7 +140178,13 @@ ${lanes.join("\n")} const id = getAliasId(symbol, typeArguments); let errorType2 = errorTypes.get(id); if (!errorType2) { - errorType2 = createIntrinsicType(1 /* Any */, "error"); + errorType2 = createIntrinsicType( + 1 /* Any */, + "error", + /*objectFlags*/ + void 0, + `alias ${id}` + ); errorType2.aliasSymbol = symbol; errorType2.aliasTypeArguments = typeArguments; errorTypes.set(id, errorType2); @@ -156492,7 +140197,7 @@ ${lanes.join("\n")} const numTypeArguments = length(node.typeArguments); const minTypeArgumentCount = getMinTypeArgumentCount(typeParameters); if (numTypeArguments < minTypeArgumentCount || numTypeArguments > typeParameters.length) { - error( + error2( node, minTypeArgumentCount === typeParameters.length ? Diagnostics.Generic_type_0_requires_1_type_argument_s : Diagnostics.Generic_type_0_requires_between_1_and_2_type_arguments, symbolToString(symbol), @@ -156532,9 +140237,9 @@ ${lanes.join("\n")} } function getTypeReferenceName(node) { switch (node.kind) { - case 182 /* TypeReference */: + case 183 /* TypeReference */: return node.typeName; - case 232 /* ExpressionWithTypeArguments */: + case 233 /* ExpressionWithTypeArguments */: const expr = node.expression; if (isEntityNameExpression(expr)) { return expr; @@ -156546,10 +140251,10 @@ ${lanes.join("\n")} return symbol.parent ? `${getSymbolPath(symbol.parent)}.${symbol.escapedName}` : symbol.escapedName; } function getUnresolvedSymbolForEntityName(name) { - const identifier = name.kind === 165 /* QualifiedName */ ? name.right : name.kind === 210 /* PropertyAccessExpression */ ? name.name : name; + const identifier = name.kind === 166 /* QualifiedName */ ? name.right : name.kind === 211 /* PropertyAccessExpression */ ? name.name : name; const text = identifier.escapedText; if (text) { - const parentSymbol = name.kind === 165 /* QualifiedName */ ? getUnresolvedSymbolForEntityName(name.left) : name.kind === 210 /* PropertyAccessExpression */ ? getUnresolvedSymbolForEntityName(name.expression) : void 0; + const parentSymbol = name.kind === 166 /* QualifiedName */ ? getUnresolvedSymbolForEntityName(name.left) : name.kind === 211 /* PropertyAccessExpression */ ? getUnresolvedSymbolForEntityName(name.expression) : void 0; const path = parentSymbol ? `${getSymbolPath(parentSymbol)}.${text}` : text; let result = unresolvedSymbols.get(path); if (!result) { @@ -156601,7 +140306,7 @@ ${lanes.join("\n")} const valueType = getTypeOfSymbol(symbol); let typeType = valueType; if (symbol.valueDeclaration) { - const isImportTypeWithQualifier = node.kind === 204 /* ImportType */ && node.qualifier; + const isImportTypeWithQualifier = node.kind === 205 /* ImportType */ && node.qualifier; if (valueType.symbol && valueType.symbol !== symbol && isImportTypeWithQualifier) { typeType = getTypeReferenceType(node, valueType.symbol); } @@ -156629,7 +140334,7 @@ ${lanes.join("\n")} return getIntersectionType([substitutionType.constraint, substitutionType.baseType]); } function isUnaryTupleTypeNode(node) { - return node.kind === 188 /* TupleType */ && node.elements.length === 1; + return node.kind === 189 /* TupleType */ && node.elements.length === 1; } function getImpliedConstraint(type, checkNode, extendsNode) { return isUnaryTupleTypeNode(checkNode) && isUnaryTupleTypeNode(extendsNode) ? getImpliedConstraint(type, checkNode.elements[0], extendsNode.elements[0]) : getActualTypeVariable(getTypeFromTypeNode(checkNode)) === getActualTypeVariable(type) ? getTypeFromTypeNode(extendsNode) : void 0; @@ -156637,17 +140342,17 @@ ${lanes.join("\n")} function getConditionalFlowTypeOfType(type, node) { let constraints; let covariant = true; - while (node && !isStatement(node) && node.kind !== 326 /* JSDoc */) { + while (node && !isStatement(node) && node.kind !== 327 /* JSDoc */) { const parent2 = node.parent; - if (parent2.kind === 168 /* Parameter */) { + if (parent2.kind === 169 /* Parameter */) { covariant = !covariant; } - if ((covariant || type.flags & 8650752 /* TypeVariable */) && parent2.kind === 193 /* ConditionalType */ && node === parent2.trueType) { + if ((covariant || type.flags & 8650752 /* TypeVariable */) && parent2.kind === 194 /* ConditionalType */ && node === parent2.trueType) { const constraint = getImpliedConstraint(type, parent2.checkType, parent2.extendsType); if (constraint) { constraints = append(constraints, constraint); } - } else if (type.flags & 262144 /* TypeParameter */ && parent2.kind === 199 /* MappedType */ && node === parent2.type) { + } else if (type.flags & 262144 /* TypeParameter */ && parent2.kind === 200 /* MappedType */ && node === parent2.type) { const mappedType = getTypeFromTypeNode(parent2); if (getTypeParameterFromMappedType(mappedType) === getActualTypeVariable(type)) { const typeParameter = getHomomorphicTypeVariable(mappedType); @@ -156664,11 +140369,11 @@ ${lanes.join("\n")} return constraints ? getSubstitutionType(type, getIntersectionType(constraints)) : type; } function isJSDocTypeReference(node) { - return !!(node.flags & 8388608 /* JSDoc */) && (node.kind === 182 /* TypeReference */ || node.kind === 204 /* ImportType */); + return !!(node.flags & 16777216 /* JSDoc */) && (node.kind === 183 /* TypeReference */ || node.kind === 205 /* ImportType */); } function checkNoTypeArguments(node, symbol) { if (node.typeArguments) { - error(node, Diagnostics.Type_0_is_not_generic, symbol ? symbolToString(symbol) : node.typeName ? declarationNameToString(node.typeName) : anon); + error2(node, Diagnostics.Type_0_is_not_generic, symbol ? symbolToString(symbol) : node.typeName ? declarationNameToString(node.typeName) : anon); return false; } return true; @@ -156787,9 +140492,9 @@ ${lanes.join("\n")} if (declarations) { for (const declaration of declarations) { switch (declaration.kind) { - case 262 /* ClassDeclaration */: - case 263 /* InterfaceDeclaration */: - case 265 /* EnumDeclaration */: + case 263 /* ClassDeclaration */: + case 264 /* InterfaceDeclaration */: + case 266 /* EnumDeclaration */: return declaration; } } @@ -156800,11 +140505,11 @@ ${lanes.join("\n")} } const type = getDeclaredTypeOfSymbol(symbol); if (!(type.flags & 524288 /* Object */)) { - error(getTypeDeclaration(symbol), Diagnostics.Global_type_0_must_be_a_class_or_interface_type, symbolName(symbol)); + error2(getTypeDeclaration(symbol), Diagnostics.Global_type_0_must_be_a_class_or_interface_type, symbolName(symbol)); return arity ? emptyGenericType : emptyObjectType; } if (length(type.typeParameters) !== arity) { - error(getTypeDeclaration(symbol), Diagnostics.Global_type_0_must_have_1_type_parameter_s, symbolName(symbol), arity); + error2(getTypeDeclaration(symbol), Diagnostics.Global_type_0_must_have_1_type_parameter_s, symbolName(symbol), arity); return arity ? emptyGenericType : emptyObjectType; } return type; @@ -156821,7 +140526,7 @@ ${lanes.join("\n")} getDeclaredTypeOfSymbol(symbol); if (length(getSymbolLinks(symbol).typeParameters) !== arity) { const decl = symbol.declarations && find(symbol.declarations, isTypeAliasDeclaration); - error(decl, Diagnostics.Global_type_0_must_have_1_type_parameter_s, symbolName(symbol), arity); + error2(decl, Diagnostics.Global_type_0_must_have_1_type_parameter_s, symbolName(symbol), arity); return void 0; } } @@ -157017,6 +140722,22 @@ ${lanes.join("\n")} reportErrors2 )) || emptyGenericType; } + function getGlobalDisposableType(reportErrors2) { + return deferredGlobalDisposableType || (deferredGlobalDisposableType = getGlobalType( + "Disposable", + /*arity*/ + 0, + reportErrors2 + )) || emptyObjectType; + } + function getGlobalAsyncDisposableType(reportErrors2) { + return deferredGlobalAsyncDisposableType || (deferredGlobalAsyncDisposableType = getGlobalType( + "AsyncDisposable", + /*arity*/ + 0, + reportErrors2 + )) || emptyObjectType; + } function getGlobalTypeOrUndefined(name, arity = 0) { const symbol = getGlobalSymbol( name, @@ -157162,11 +140883,11 @@ ${lanes.join("\n")} } function getTupleElementFlags(node) { switch (node.kind) { - case 189 /* OptionalType */: + case 190 /* OptionalType */: return 2 /* Optional */; - case 190 /* RestType */: + case 191 /* RestType */: return getRestTypeElementFlags(node); - case 201 /* NamedTupleMember */: + case 202 /* NamedTupleMember */: return node.questionToken ? 2 /* Optional */ : node.dotDotDotToken ? getRestTypeElementFlags(node) : 1 /* Required */; default: return 1 /* Required */; @@ -157182,60 +140903,57 @@ ${lanes.join("\n")} return readonly ? globalReadonlyArrayType : globalArrayType; } const elementFlags = map(node.elements, getTupleElementFlags); - const missingName = some(node.elements, (e) => e.kind !== 201 /* NamedTupleMember */); - return getTupleTargetType( - elementFlags, - readonly, - /*associatedNames*/ - missingName ? void 0 : node.elements - ); + return getTupleTargetType(elementFlags, readonly, map(node.elements, memberIfLabeledElementDeclaration)); + } + function memberIfLabeledElementDeclaration(member) { + return isNamedTupleMember(member) || isParameter(member) ? member : void 0; } function isDeferredTypeReferenceNode(node, hasDefaultTypeArguments) { - return !!getAliasSymbolForTypeNode(node) || isResolvedByTypeAlias(node) && (node.kind === 187 /* ArrayType */ ? mayResolveTypeAlias(node.elementType) : node.kind === 188 /* TupleType */ ? some(node.elements, mayResolveTypeAlias) : hasDefaultTypeArguments || some(node.typeArguments, mayResolveTypeAlias)); + return !!getAliasSymbolForTypeNode(node) || isResolvedByTypeAlias(node) && (node.kind === 188 /* ArrayType */ ? mayResolveTypeAlias(node.elementType) : node.kind === 189 /* TupleType */ ? some(node.elements, mayResolveTypeAlias) : hasDefaultTypeArguments || some(node.typeArguments, mayResolveTypeAlias)); } function isResolvedByTypeAlias(node) { const parent2 = node.parent; switch (parent2.kind) { - case 195 /* ParenthesizedType */: - case 201 /* NamedTupleMember */: - case 182 /* TypeReference */: - case 191 /* UnionType */: - case 192 /* IntersectionType */: - case 198 /* IndexedAccessType */: - case 193 /* ConditionalType */: - case 197 /* TypeOperator */: - case 187 /* ArrayType */: - case 188 /* TupleType */: + case 196 /* ParenthesizedType */: + case 202 /* NamedTupleMember */: + case 183 /* TypeReference */: + case 192 /* UnionType */: + case 193 /* IntersectionType */: + case 199 /* IndexedAccessType */: + case 194 /* ConditionalType */: + case 198 /* TypeOperator */: + case 188 /* ArrayType */: + case 189 /* TupleType */: return isResolvedByTypeAlias(parent2); - case 264 /* TypeAliasDeclaration */: + case 265 /* TypeAliasDeclaration */: return true; } return false; } function mayResolveTypeAlias(node) { switch (node.kind) { - case 182 /* TypeReference */: + case 183 /* TypeReference */: return isJSDocTypeReference(node) || !!(resolveTypeReferenceName(node, 788968 /* Type */).flags & 524288 /* TypeAlias */); - case 185 /* TypeQuery */: + case 186 /* TypeQuery */: return true; - case 197 /* TypeOperator */: + case 198 /* TypeOperator */: return node.operator !== 158 /* UniqueKeyword */ && mayResolveTypeAlias(node.type); - case 195 /* ParenthesizedType */: - case 189 /* OptionalType */: - case 201 /* NamedTupleMember */: - case 322 /* JSDocOptionalType */: - case 320 /* JSDocNullableType */: - case 321 /* JSDocNonNullableType */: - case 315 /* JSDocTypeExpression */: + case 196 /* ParenthesizedType */: + case 190 /* OptionalType */: + case 202 /* NamedTupleMember */: + case 323 /* JSDocOptionalType */: + case 321 /* JSDocNullableType */: + case 322 /* JSDocNonNullableType */: + case 316 /* JSDocTypeExpression */: return mayResolveTypeAlias(node.type); - case 190 /* RestType */: - return node.type.kind !== 187 /* ArrayType */ || mayResolveTypeAlias(node.type.elementType); - case 191 /* UnionType */: - case 192 /* IntersectionType */: + case 191 /* RestType */: + return node.type.kind !== 188 /* ArrayType */ || mayResolveTypeAlias(node.type.elementType); + case 192 /* UnionType */: + case 193 /* IntersectionType */: return some(node.types, mayResolveTypeAlias); - case 198 /* IndexedAccessType */: + case 199 /* IndexedAccessType */: return mayResolveTypeAlias(node.objectType) || mayResolveTypeAlias(node.indexType); - case 193 /* ConditionalType */: + case 194 /* ConditionalType */: return mayResolveTypeAlias(node.checkType) || mayResolveTypeAlias(node.extendsType) || mayResolveTypeAlias(node.trueType) || mayResolveTypeAlias(node.falseType); } return false; @@ -157246,15 +140964,15 @@ ${lanes.join("\n")} const target = getArrayOrTupleTargetType(node); if (target === emptyGenericType) { links.resolvedType = emptyObjectType; - } else if (!(node.kind === 188 /* TupleType */ && some(node.elements, (e) => !!(getTupleElementFlags(e) & 8 /* Variadic */))) && isDeferredTypeReferenceNode(node)) { - links.resolvedType = node.kind === 188 /* TupleType */ && node.elements.length === 0 ? target : createDeferredTypeReference( + } else if (!(node.kind === 189 /* TupleType */ && some(node.elements, (e) => !!(getTupleElementFlags(e) & 8 /* Variadic */))) && isDeferredTypeReferenceNode(node)) { + links.resolvedType = node.kind === 189 /* TupleType */ && node.elements.length === 0 ? target : createDeferredTypeReference( target, node, /*mapper*/ void 0 ); } else { - const elementTypes = node.kind === 187 /* ArrayType */ ? [getTypeFromTypeNode(node.elementType)] : map(node.elements, getTypeFromTypeNode); + const elementTypes = node.kind === 188 /* ArrayType */ ? [getTypeFromTypeNode(node.elementType)] : map(node.elements, getTypeFromTypeNode); links.resolvedType = createNormalizedTypeReference(target, elementTypes); } } @@ -157263,7 +140981,7 @@ ${lanes.join("\n")} function isReadonlyTypeOperator(node) { return isTypeOperatorNode(node) && node.operator === 148 /* ReadonlyKeyword */; } - function createTupleType(elementTypes, elementFlags, readonly = false, namedMemberDeclarations) { + function createTupleType(elementTypes, elementFlags, readonly = false, namedMemberDeclarations = []) { const tupleTarget = getTupleTargetType(elementFlags || map(elementTypes, (_) => 1 /* Required */), readonly, namedMemberDeclarations); return tupleTarget === emptyGenericType ? emptyObjectType : elementTypes.length ? createNormalizedTypeReference(tupleTarget, elementTypes) : tupleTarget; } @@ -157271,7 +140989,7 @@ ${lanes.join("\n")} if (elementFlags.length === 1 && elementFlags[0] & 4 /* Rest */) { return readonly ? globalReadonlyArrayType : globalArrayType; } - const key = map(elementFlags, (f) => f & 1 /* Required */ ? "#" : f & 2 /* Optional */ ? "?" : f & 4 /* Rest */ ? "." : "*").join() + (readonly ? "R" : "") + (namedMemberDeclarations && namedMemberDeclarations.length ? "," + map(namedMemberDeclarations, getNodeId).join(",") : ""); + const key = map(elementFlags, (f) => f & 1 /* Required */ ? "#" : f & 2 /* Optional */ ? "?" : f & 4 /* Rest */ ? "." : "*").join() + (readonly ? "R" : "") + (some(namedMemberDeclarations, (node) => !!node) ? "," + map(namedMemberDeclarations, (node) => node ? getNodeId(node) : "_").join(",") : ""); let type = tupleTypes.get(key); if (!type) { tupleTypes.set(key, type = createTupleTargetType(elementFlags, readonly, namedMemberDeclarations)); @@ -157291,11 +141009,7 @@ ${lanes.join("\n")} const flags = elementFlags[i]; combinedFlags |= flags; if (!(combinedFlags & 12 /* Variable */)) { - const property = createSymbol( - 4 /* Property */ | (flags & 2 /* Optional */ ? 16777216 /* Optional */ : 0), - "" + i, - readonly ? 8 /* Readonly */ : 0 - ); + const property = createSymbol(4 /* Property */ | (flags & 2 /* Optional */ ? 16777216 /* Optional */ : 0), "" + i, readonly ? 8 /* Readonly */ : 0); property.links.tupleLabelDeclaration = namedMemberDeclarations == null ? void 0 : namedMemberDeclarations[i]; property.links.type = typeParameter; properties.push(property); @@ -157353,7 +141067,7 @@ ${lanes.join("\n")} } const expandedTypes = []; const expandedFlags = []; - let expandedDeclarations = []; + const expandedDeclarations = []; let lastRequiredIndex = -1; let firstRestIndex = -1; let lastOptionalOrRestIndex = -1; @@ -157366,7 +141080,10 @@ ${lanes.join("\n")} } else if (isTupleType(type)) { const elements = getElementTypes(type); if (elements.length + expandedTypes.length >= 1e4) { - error(currentNode, isPartOfTypeNode(currentNode) ? Diagnostics.Type_produces_a_tuple_type_that_is_too_large_to_represent : Diagnostics.Expression_produces_a_tuple_type_that_is_too_large_to_represent); + error2( + currentNode, + isPartOfTypeNode(currentNode) ? Diagnostics.Type_produces_a_tuple_type_that_is_too_large_to_represent : Diagnostics.Expression_produces_a_tuple_type_that_is_too_large_to_represent + ); return errorType; } forEach(elements, (t, n) => { @@ -157385,13 +141102,10 @@ ${lanes.join("\n")} expandedFlags[i] = 1 /* Required */; } if (firstRestIndex >= 0 && firstRestIndex < lastOptionalOrRestIndex) { - expandedTypes[firstRestIndex] = getUnionType(sameMap( - expandedTypes.slice(firstRestIndex, lastOptionalOrRestIndex + 1), - (t, i) => expandedFlags[firstRestIndex + i] & 8 /* Variadic */ ? getIndexedAccessType(t, numberType) : t - )); + expandedTypes[firstRestIndex] = getUnionType(sameMap(expandedTypes.slice(firstRestIndex, lastOptionalOrRestIndex + 1), (t, i) => expandedFlags[firstRestIndex + i] & 8 /* Variadic */ ? getIndexedAccessType(t, numberType) : t)); expandedTypes.splice(firstRestIndex + 1, lastOptionalOrRestIndex - firstRestIndex); expandedFlags.splice(firstRestIndex + 1, lastOptionalOrRestIndex - firstRestIndex); - expandedDeclarations == null ? void 0 : expandedDeclarations.splice(firstRestIndex + 1, lastOptionalOrRestIndex - firstRestIndex); + expandedDeclarations.splice(firstRestIndex + 1, lastOptionalOrRestIndex - firstRestIndex); } const tupleTarget = getTupleTargetType(expandedFlags, target.readonly, expandedDeclarations); return tupleTarget === emptyGenericType ? emptyObjectType : expandedFlags.length ? createTypeReference(tupleTarget, expandedTypes) : tupleTarget; @@ -157411,11 +141125,7 @@ ${lanes.join("\n")} true ) : type); expandedFlags.push(flags); - if (expandedDeclarations && declaration) { - expandedDeclarations.push(declaration); - } else { - expandedDeclarations = void 0; - } + expandedDeclarations.push(declaration); } } function sliceTupleType(type, index, endSkipCount = 0) { @@ -157430,10 +141140,7 @@ ${lanes.join("\n")} ); } function getKnownKeysOfTupleType(type) { - return getUnionType(append( - arrayOf(type.target.fixedLength, (i) => getStringLiteralType("" + i)), - getIndexType(type.target.readonly ? globalReadonlyArrayType : globalArrayType) - )); + return getUnionType(append(arrayOf(type.target.fixedLength, (i) => getStringLiteralType("" + i)), getIndexType(type.target.readonly ? globalReadonlyArrayType : globalArrayType))); } function getStartElementCount(type, flags) { const index = findIndex(type.elementFlags, (f) => !(f & flags)); @@ -157442,6 +141149,9 @@ ${lanes.join("\n")} function getEndElementCount(type, flags) { return type.elementFlags.length - findLastIndex(type.elementFlags, (f) => !(f & flags)) - 1; } + function getTotalFixedElementCount(type) { + return type.fixedLength + getEndElementCount(type, 3 /* Fixed */); + } function getElementTypes(type) { const typeArguments = getTypeArguments(type); const arity = getTypeReferenceArity(type); @@ -157531,7 +141241,7 @@ ${lanes.join("\n")} const estimatedCount = count / (len - i) * len; if (estimatedCount > 1e6) { (_a = tracing) == null ? void 0 : _a.instant(tracing.Phase.CheckTypes, "removeSubtypes_DepthLimit", { typeIds: types.map((t) => t.id) }); - error(currentNode, Diagnostics.Expression_produces_a_union_type_that_is_too_complex_to_represent); + error2(currentNode, Diagnostics.Expression_produces_a_union_type_that_is_too_complex_to_represent); return void 0; } } @@ -157736,12 +141446,7 @@ ${lanes.join("\n")} const links = getNodeLinks(node); if (!links.resolvedType) { const aliasSymbol = getAliasSymbolForTypeNode(node); - links.resolvedType = getUnionType( - map(node.types, getTypeFromTypeNode), - 1 /* Literal */, - aliasSymbol, - getTypeArgumentsForAliasSymbol(aliasSymbol) - ); + links.resolvedType = getUnionType(map(node.types, getTypeFromTypeNode), 1 /* Literal */, aliasSymbol, getTypeArgumentsForAliasSymbol(aliasSymbol)); } return links.resolvedType; } @@ -157940,7 +141645,7 @@ ${lanes.join("\n")} const size = getCrossProductUnionSize(types); if (size >= 1e5) { (_a = tracing) == null ? void 0 : _a.instant(tracing.Phase.CheckTypes, "checkCrossProductUnion_DepthLimit", { typeIds: types.map((t) => t.id), size }); - error(currentNode, Diagnostics.Expression_produces_a_union_type_that_is_too_complex_to_represent); + error2(currentNode, Diagnostics.Expression_produces_a_union_type_that_is_too_complex_to_represent); return false; } return true; @@ -157971,15 +141676,14 @@ ${lanes.join("\n")} function getConstituentCountOfTypes(types) { return reduceLeft(types, (n, t) => n + getConstituentCount(t), 0); } - function areIntersectedTypesAvoidingPrimitiveReduction(t1, t2) { - return !!(t1.flags & (4 /* String */ | 8 /* Number */ | 64 /* BigInt */)) && t2 === emptyTypeLiteralType; - } function getTypeFromIntersectionTypeNode(node) { const links = getNodeLinks(node); if (!links.resolvedType) { const aliasSymbol = getAliasSymbolForTypeNode(node); const types = map(node.types, getTypeFromTypeNode); - const noSupertypeReduction = types.length === 2 && (areIntersectedTypesAvoidingPrimitiveReduction(types[0], types[1]) || areIntersectedTypesAvoidingPrimitiveReduction(types[1], types[0])); + const emptyIndex = types.length === 2 ? types.indexOf(emptyTypeLiteralType) : -1; + const t = emptyIndex >= 0 ? types[1 - emptyIndex] : unknownType; + const noSupertypeReduction = !!(t.flags & (4 /* String */ | 8 /* Number */ | 64 /* BigInt */) || t.flags & 134217728 /* TemplateLiteral */ && isPatternLiteralType(t)); links.resolvedType = getIntersectionType(types, aliasSymbol, getTypeArgumentsForAliasSymbol(aliasSymbol), noSupertypeReduction); } return links.resolvedType; @@ -158056,7 +141760,7 @@ ${lanes.join("\n")} return neverType; } function getLiteralTypeFromProperty(prop, include, includeNonPublic) { - if (includeNonPublic || !(getDeclarationModifierFlagsFromSymbol(prop) & 24 /* NonPublicAccessibilityModifier */)) { + if (includeNonPublic || !(getDeclarationModifierFlagsFromSymbol(prop) & 6 /* NonPublicAccessibilityModifier */)) { let type = getSymbolLinks(getLateBoundSymbol(prop)).nameType; if (!type) { const name = getNameOfDeclaration(prop.valueDeclaration); @@ -158090,11 +141794,7 @@ ${lanes.join("\n")} } function getIndexType(type, indexFlags = defaultIndexFlags) { type = getReducedType(type); - return shouldDeferIndexType(type, indexFlags) ? getIndexTypeForGenericType(type, indexFlags) : type.flags & 1048576 /* Union */ ? getIntersectionType(map(type.types, (t) => getIndexType(t, indexFlags))) : type.flags & 2097152 /* Intersection */ ? getUnionType(map(type.types, (t) => getIndexType(t, indexFlags))) : getObjectFlags(type) & 32 /* Mapped */ ? getIndexTypeForMappedType(type, indexFlags) : type === wildcardType ? wildcardType : type.flags & 2 /* Unknown */ ? neverType : type.flags & (1 /* Any */ | 131072 /* Never */) ? keyofConstraintType : getLiteralTypeFromProperties( - type, - (indexFlags & 2 /* NoIndexSignatures */ ? 128 /* StringLiteral */ : 402653316 /* StringLike */) | (indexFlags & 1 /* StringsOnly */ ? 0 : 296 /* NumberLike */ | 12288 /* ESSymbolLike */), - indexFlags === defaultIndexFlags - ); + return shouldDeferIndexType(type, indexFlags) ? getIndexTypeForGenericType(type, indexFlags) : type.flags & 1048576 /* Union */ ? getIntersectionType(map(type.types, (t) => getIndexType(t, indexFlags))) : type.flags & 2097152 /* Intersection */ ? getUnionType(map(type.types, (t) => getIndexType(t, indexFlags))) : getObjectFlags(type) & 32 /* Mapped */ ? getIndexTypeForMappedType(type, indexFlags) : type === wildcardType ? wildcardType : type.flags & 2 /* Unknown */ ? neverType : type.flags & (1 /* Any */ | 131072 /* Never */) ? keyofConstraintType : getLiteralTypeFromProperties(type, (indexFlags & 2 /* NoIndexSignatures */ ? 128 /* StringLiteral */ : 402653316 /* StringLike */) | (indexFlags & 1 /* StringsOnly */ ? 0 : 296 /* NumberLike */ | 12288 /* ESSymbolLike */), indexFlags === defaultIndexFlags); } function getExtractStringType(type) { if (keyofStringsOnly) { @@ -158195,11 +141895,6 @@ ${lanes.join("\n")} } function createTemplateLiteralType(texts, types) { const type = createType(134217728 /* TemplateLiteral */); - type.objectFlags = getPropagatingFlagsOfTypes( - types, - /*excludeKinds*/ - 98304 /* Nullable */ - ); type.texts = texts; type.types = types; return type; @@ -158292,12 +141987,12 @@ ${lanes.join("\n")} if (isCallLikeExpression(parent2)) { return isCallOrNewExpression(parent2) && isIdentifier(node) && hasMatchingArgument(parent2, node); } - return every(symbol.declarations, (d) => !isFunctionLike(d) || !!(getCombinedNodeFlags(d) & 268435456 /* Deprecated */)); + return every(symbol.declarations, (d) => !isFunctionLike(d) || isDeprecatedDeclaration2(d)); } return true; } function getPropertyTypeForIndexType(originalObjectType, objectType, indexType, fullIndexType, accessNode, accessFlags) { - const accessExpression = accessNode && accessNode.kind === 211 /* ElementAccessExpression */ ? accessNode : void 0; + const accessExpression = accessNode && accessNode.kind === 212 /* ElementAccessExpression */ ? accessNode : void 0; const propName = accessNode && isPrivateIdentifier(accessNode) ? void 0 : getPropertyNameFromIndex(indexType, accessNode); if (propName !== void 0) { if (accessFlags & 256 /* Contextual */) { @@ -158312,7 +142007,7 @@ ${lanes.join("\n")} if (accessExpression) { markPropertyAsReferenced(prop, accessExpression, isSelfTypeAccess(accessExpression.expression, objectType.symbol)); if (isAssignmentToReadonlyEntity(accessExpression, prop, getAssignmentTargetKind(accessExpression))) { - error(accessExpression.argumentExpression, Diagnostics.Cannot_assign_to_0_because_it_is_a_read_only_property, symbolToString(prop)); + error2(accessExpression.argumentExpression, Diagnostics.Cannot_assign_to_0_because_it_is_a_read_only_property, symbolToString(prop)); return void 0; } if (accessFlags & 8 /* CacheSymbol */) { @@ -158322,7 +142017,7 @@ ${lanes.join("\n")} return autoType; } } - const propType = getTypeOfSymbol(prop); + const propType = accessFlags & 4 /* Writing */ ? getWriteTypeOfSymbol(prop) : getTypeOfSymbol(prop); return accessExpression && getAssignmentTargetKind(accessExpression) !== 1 /* Definite */ ? getFlowTypeOfReference(accessExpression, propType) : accessNode && isIndexedAccessTypeNode(accessNode) && containsMissingType(propType) ? getUnionType([propType, undefinedType]) : propType; } if (everyType(objectType, isTupleType) && isNumericLiteralName(propName)) { @@ -158331,26 +142026,17 @@ ${lanes.join("\n")} const indexNode = getIndexNodeForAccessExpression(accessNode); if (isTupleType(objectType)) { if (index < 0) { - error(indexNode, Diagnostics.A_tuple_type_cannot_be_indexed_with_a_negative_value); + error2(indexNode, Diagnostics.A_tuple_type_cannot_be_indexed_with_a_negative_value); return undefinedType; } - error( - indexNode, - Diagnostics.Tuple_type_0_of_length_1_has_no_element_at_index_2, - typeToString(objectType), - getTypeReferenceArity(objectType), - unescapeLeadingUnderscores(propName) - ); + error2(indexNode, Diagnostics.Tuple_type_0_of_length_1_has_no_element_at_index_2, typeToString(objectType), getTypeReferenceArity(objectType), unescapeLeadingUnderscores(propName)); } else { - error(indexNode, Diagnostics.Property_0_does_not_exist_on_type_1, unescapeLeadingUnderscores(propName), typeToString(objectType)); + error2(indexNode, Diagnostics.Property_0_does_not_exist_on_type_1, unescapeLeadingUnderscores(propName), typeToString(objectType)); } } if (index >= 0) { errorIfWritingToReadonlyIndex(getIndexInfoOfType(objectType, numberType)); - return mapType(objectType, (t) => { - const restType = getRestTypeOfTupleType(t) || undefinedType; - return accessFlags & 1 /* IncludeUndefined */ ? getUnionType([restType, missingType]) : restType; - }); + return getTupleElementTypeOutOfStartCount(objectType, index, accessFlags & 1 /* IncludeUndefined */ ? missingType : void 0); } } } @@ -158362,13 +142048,17 @@ ${lanes.join("\n")} if (indexInfo) { if (accessFlags & 2 /* NoIndexSignatures */ && indexInfo.keyType !== numberType) { if (accessExpression) { - error(accessExpression, Diagnostics.Type_0_cannot_be_used_to_index_type_1, typeToString(indexType), typeToString(originalObjectType)); + if (accessFlags & 4 /* Writing */) { + error2(accessExpression, Diagnostics.Type_0_is_generic_and_can_only_be_indexed_for_reading, typeToString(originalObjectType)); + } else { + error2(accessExpression, Diagnostics.Type_0_cannot_be_used_to_index_type_1, typeToString(indexType), typeToString(originalObjectType)); + } } return void 0; } if (accessNode && indexInfo.keyType === stringType && !isTypeAssignableToKind(indexType, 4 /* String */ | 8 /* Number */)) { const indexNode = getIndexNodeForAccessExpression(accessNode); - error(indexNode, Diagnostics.Type_0_cannot_be_used_as_an_index_type, typeToString(indexType)); + error2(indexNode, Diagnostics.Type_0_cannot_be_used_as_an_index_type, typeToString(indexType)); return accessFlags & 1 /* IncludeUndefined */ ? getUnionType([indexInfo.type, missingType]) : indexInfo.type; } errorIfWritingToReadonlyIndex(indexInfo); @@ -158396,23 +142086,23 @@ ${lanes.join("\n")} } } if (objectType.symbol === globalThisSymbol && propName !== void 0 && globalThisSymbol.exports.has(propName) && globalThisSymbol.exports.get(propName).flags & 418 /* BlockScoped */) { - error(accessExpression, Diagnostics.Property_0_does_not_exist_on_type_1, unescapeLeadingUnderscores(propName), typeToString(objectType)); + error2(accessExpression, Diagnostics.Property_0_does_not_exist_on_type_1, unescapeLeadingUnderscores(propName), typeToString(objectType)); } else if (noImplicitAny && !compilerOptions.suppressImplicitAnyIndexErrors && !(accessFlags & 128 /* SuppressNoImplicitAnyError */)) { if (propName !== void 0 && typeHasStaticProperty(propName, objectType)) { const typeName = typeToString(objectType); - error(accessExpression, Diagnostics.Property_0_does_not_exist_on_type_1_Did_you_mean_to_access_the_static_member_2_instead, propName, typeName, typeName + "[" + getTextOfNode(accessExpression.argumentExpression) + "]"); + error2(accessExpression, Diagnostics.Property_0_does_not_exist_on_type_1_Did_you_mean_to_access_the_static_member_2_instead, propName, typeName, typeName + "[" + getTextOfNode(accessExpression.argumentExpression) + "]"); } else if (getIndexTypeOfType(objectType, numberType)) { - error(accessExpression.argumentExpression, Diagnostics.Element_implicitly_has_an_any_type_because_index_expression_is_not_of_type_number); + error2(accessExpression.argumentExpression, Diagnostics.Element_implicitly_has_an_any_type_because_index_expression_is_not_of_type_number); } else { let suggestion; if (propName !== void 0 && (suggestion = getSuggestionForNonexistentProperty(propName, objectType))) { if (suggestion !== void 0) { - error(accessExpression.argumentExpression, Diagnostics.Property_0_does_not_exist_on_type_1_Did_you_mean_2, propName, typeToString(objectType), suggestion); + error2(accessExpression.argumentExpression, Diagnostics.Property_0_does_not_exist_on_type_1_Did_you_mean_2, propName, typeToString(objectType), suggestion); } } else { const suggestion2 = getSuggestionForNonexistentIndexSignature(objectType, accessExpression, indexType); if (suggestion2 !== void 0) { - error(accessExpression, Diagnostics.Element_implicitly_has_an_any_type_because_type_0_has_no_index_signature_Did_you_mean_to_call_1, typeToString(objectType), suggestion2); + error2(accessExpression, Diagnostics.Element_implicitly_has_an_any_type_because_type_0_has_no_index_signature_Did_you_mean_to_call_1, typeToString(objectType), suggestion2); } else { let errorInfo; if (indexType.flags & 1024 /* EnumLiteral */) { @@ -158477,11 +142167,11 @@ ${lanes.join("\n")} if (accessNode) { const indexNode = getIndexNodeForAccessExpression(accessNode); if (indexType.flags & (128 /* StringLiteral */ | 256 /* NumberLiteral */)) { - error(indexNode, Diagnostics.Property_0_does_not_exist_on_type_1, "" + indexType.value, typeToString(objectType)); + error2(indexNode, Diagnostics.Property_0_does_not_exist_on_type_1, "" + indexType.value, typeToString(objectType)); } else if (indexType.flags & (4 /* String */ | 8 /* Number */)) { - error(indexNode, Diagnostics.Type_0_has_no_matching_index_signature_for_type_1, typeToString(objectType), typeToString(indexType)); + error2(indexNode, Diagnostics.Type_0_has_no_matching_index_signature_for_type_1, typeToString(objectType), typeToString(indexType)); } else { - error(indexNode, Diagnostics.Type_0_cannot_be_used_as_an_index_type, typeToString(indexType)); + error2(indexNode, Diagnostics.Type_0_cannot_be_used_as_an_index_type, typeToString(indexType)); } } if (isTypeAny(indexType)) { @@ -158490,16 +142180,24 @@ ${lanes.join("\n")} return void 0; function errorIfWritingToReadonlyIndex(indexInfo) { if (indexInfo && indexInfo.isReadonly && accessExpression && (isAssignmentTarget(accessExpression) || isDeleteTarget(accessExpression))) { - error(accessExpression, Diagnostics.Index_signature_in_type_0_only_permits_reading, typeToString(objectType)); + error2(accessExpression, Diagnostics.Index_signature_in_type_0_only_permits_reading, typeToString(objectType)); } } } function getIndexNodeForAccessExpression(accessNode) { - return accessNode.kind === 211 /* ElementAccessExpression */ ? accessNode.argumentExpression : accessNode.kind === 198 /* IndexedAccessType */ ? accessNode.indexType : accessNode.kind === 166 /* ComputedPropertyName */ ? accessNode.expression : accessNode; + return accessNode.kind === 212 /* ElementAccessExpression */ ? accessNode.argumentExpression : accessNode.kind === 199 /* IndexedAccessType */ ? accessNode.indexType : accessNode.kind === 167 /* ComputedPropertyName */ ? accessNode.expression : accessNode; } function isPatternLiteralPlaceholderType(type) { if (type.flags & 2097152 /* Intersection */) { - return some(type.types, (t) => !!(t.flags & (2944 /* Literal */ | 65536 /* Null */ | 32768 /* Undefined */)) || isPatternLiteralPlaceholderType(t)); + let seenPlaceholder = false; + for (const t of type.types) { + if (t.flags & (2944 /* Literal */ | 98304 /* Nullable */) || isPatternLiteralPlaceholderType(t)) { + seenPlaceholder = true; + } else if (!(t.flags & 524288 /* Object */)) { + return false; + } + } + return seenPlaceholder; } return !!(type.flags & (1 /* Any */ | 4 /* String */ | 8 /* Number */ | 64 /* BigInt */)) || isPatternLiteralType(type); } @@ -158516,7 +142214,7 @@ ${lanes.join("\n")} return !!(getGenericObjectFlags(type) & 8388608 /* IsGenericIndexType */); } function getGenericObjectFlags(type) { - if (type.flags & (3145728 /* UnionOrIntersection */ | 134217728 /* TemplateLiteral */)) { + if (type.flags & 3145728 /* UnionOrIntersection */) { if (!(type.objectFlags & 2097152 /* IsGenericTypeComputed */)) { type.objectFlags |= 2097152 /* IsGenericTypeComputed */ | reduceLeft(type.types, (flags, t) => flags | getGenericObjectFlags(t), 0); } @@ -158528,7 +142226,7 @@ ${lanes.join("\n")} } return type.objectFlags & 12582912 /* IsGenericType */; } - return (type.flags & 58982400 /* InstantiableNonPrimitive */ || isGenericMappedType(type) || isGenericTupleType(type) ? 4194304 /* IsGenericObjectType */ : 0) | (type.flags & (58982400 /* InstantiableNonPrimitive */ | 4194304 /* Index */ | 268435456 /* StringMapping */) && !isPatternLiteralType(type) ? 8388608 /* IsGenericIndexType */ : 0); + return (type.flags & 58982400 /* InstantiableNonPrimitive */ || isGenericMappedType(type) || isGenericTupleType(type) ? 4194304 /* IsGenericObjectType */ : 0) | (type.flags & (58982400 /* InstantiableNonPrimitive */ | 4194304 /* Index */ | 134217728 /* TemplateLiteral */ | 268435456 /* StringMapping */) && !isPatternLiteralType(type) ? 8388608 /* IsGenericIndexType */ : 0); } function getSimplifiedType(type, writing) { return type.flags & 8388608 /* IndexedAccess */ ? getSimplifiedIndexedAccessType(type, writing) : type.flags & 16777216 /* Conditional */ ? getSimplifiedConditionalType(type, writing) : type; @@ -158635,7 +142333,7 @@ ${lanes.join("\n")} } if (compilerOptions.noUncheckedIndexedAccess && accessFlags & 32 /* ExpressionPosition */) accessFlags |= 1 /* IncludeUndefined */; - if (isGenericIndexType(indexType) || (accessNode && accessNode.kind !== 198 /* IndexedAccessType */ ? isGenericTupleType(objectType) && !indexTypeLessThan(indexType, objectType.target.fixedLength) : isGenericObjectType(objectType) && !(isTupleType(objectType) && indexTypeLessThan(indexType, objectType.target.fixedLength)) || isGenericReducibleType(objectType))) { + if (isGenericIndexType(indexType) || (accessNode && accessNode.kind !== 199 /* IndexedAccessType */ ? isGenericTupleType(objectType) && !indexTypeLessThan(indexType, getTotalFixedElementCount(objectType.target)) : isGenericObjectType(objectType) && !(isTupleType(objectType) && indexTypeLessThan(indexType, getTotalFixedElementCount(objectType.target))) || isGenericReducibleType(objectType))) { if (objectType.flags & 3 /* AnyOrUnknown */) { return objectType; } @@ -158715,7 +142413,7 @@ ${lanes.join("\n")} let tailCount = 0; while (true) { if (tailCount === 1e3) { - error(currentNode, Diagnostics.Type_instantiation_is_excessively_deep_and_possibly_infinite); + error2(currentNode, Diagnostics.Type_instantiation_is_excessively_deep_and_possibly_infinite); return errorType; } const checkType = instantiateType(getActualTypeVariable(root.checkType), mapper); @@ -158740,9 +142438,9 @@ ${lanes.join("\n")} ); if (freshMapper) { const freshCombinedMapper = combineTypeMappers(mapper, freshMapper); - for (const p of freshParams) { - if (root.inferTypeParameters.indexOf(p) === -1) { - p.mapper = freshCombinedMapper; + for (let i = 0; i < freshParams.length; i++) { + if (freshParams[i] !== root.inferTypeParameters[i]) { + freshParams[i].mapper = freshCombinedMapper; } } } @@ -158893,11 +142591,11 @@ ${lanes.join("\n")} const links = getNodeLinks(node); if (!links.resolvedType) { if (!isLiteralImportTypeNode(node)) { - error(node.argument, Diagnostics.String_literal_expected); + error2(node.argument, Diagnostics.String_literal_expected); links.resolvedSymbol = unknownSymbol; return links.resolvedType = errorType; } - const targetMeaning = node.isTypeOf ? 111551 /* Value */ : node.flags & 8388608 /* JSDoc */ ? 111551 /* Value */ | 788968 /* Type */ : 788968 /* Type */; + const targetMeaning = node.isTypeOf ? 111551 /* Value */ : node.flags & 16777216 /* JSDoc */ ? 111551 /* Value */ | 788968 /* Type */ : 788968 /* Type */; const innerModuleSymbol = resolveExternalModuleName(node, node.argument.literal); if (!innerModuleSymbol) { links.resolvedSymbol = unknownSymbol; @@ -158927,7 +142625,7 @@ ${lanes.join("\n")} const symbolFromModule = node.isTypeOf ? void 0 : getSymbol2(getExportsOfSymbol(mergedResolvedSymbol), current.escapedText, meaning); const next = symbolFromModule ?? symbolFromVariable; if (!next) { - error(current, Diagnostics.Namespace_0_has_no_exported_member_1, getFullyQualifiedName(currentNamespace), declarationNameToString(current)); + error2(current, Diagnostics.Namespace_0_has_no_exported_member_1, getFullyQualifiedName(currentNamespace), declarationNameToString(current)); return links.resolvedType = errorType; } getNodeLinks(current).resolvedSymbol = next; @@ -158940,7 +142638,7 @@ ${lanes.join("\n")} links.resolvedType = resolveImportSymbolType(node, links, moduleSymbol, targetMeaning); } else { const errorMessage = targetMeaning === 111551 /* Value */ ? Diagnostics.Module_0_does_not_refer_to_a_value_but_is_used_as_a_value_here : Diagnostics.Module_0_does_not_refer_to_a_type_but_is_used_as_a_type_here_Did_you_mean_typeof_import_0; - error(node, errorMessage, node.argument.literal.text); + error2(node, errorMessage, node.argument.literal.text); links.resolvedSymbol = unknownSymbol; links.resolvedType = errorType; } @@ -159010,7 +142708,7 @@ ${lanes.join("\n")} function getAnonymousPartialType(type2) { const members = createSymbolTable(); for (const prop of getPropertiesOfType(type2)) { - if (getDeclarationModifierFlagsFromSymbol(prop) & (8 /* Private */ | 16 /* Protected */)) { + if (getDeclarationModifierFlagsFromSymbol(prop) & (2 /* Private */ | 4 /* Protected */)) { } else if (isSpreadableProperty(prop)) { const isSetonlyAccessor = prop.flags & 65536 /* SetAccessor */ && !(prop.flags & 32768 /* GetAccessor */); const flags = 4 /* Property */ | 16777216 /* Optional */; @@ -159072,7 +142770,7 @@ ${lanes.join("\n")} const skippedPrivateMembers = /* @__PURE__ */ new Set(); const indexInfos = left === emptyObjectType ? getIndexInfosOfType(right) : getUnionIndexInfos([left, right]); for (const rightProp of getPropertiesOfType(right)) { - if (getDeclarationModifierFlagsFromSymbol(rightProp) & (8 /* Private */ | 16 /* Protected */)) { + if (getDeclarationModifierFlagsFromSymbol(rightProp) & (2 /* Private */ | 4 /* Protected */)) { skippedPrivateMembers.add(rightProp.escapedName); } else if (isSpreadableProperty(rightProp)) { members.set(rightProp.escapedName, getSpreadSymbol(rightProp, readonly)); @@ -159203,7 +142901,7 @@ ${lanes.join("\n")} false ); const parent2 = container && container.parent; - if (parent2 && (isClassLike(parent2) || parent2.kind === 263 /* InterfaceDeclaration */)) { + if (parent2 && (isClassLike(parent2) || parent2.kind === 264 /* InterfaceDeclaration */)) { if (!isStatic(container) && (!isConstructorDeclaration(container) || isNodeDescendantOf(node, container.body))) { return getDeclaredTypeOfClassOrInterface(getSymbolOfDeclaration(parent2)).thisType; } @@ -159211,14 +142909,14 @@ ${lanes.join("\n")} if (parent2 && isObjectLiteralExpression(parent2) && isBinaryExpression(parent2.parent) && getAssignmentDeclarationKind(parent2.parent) === 6 /* Prototype */) { return getDeclaredTypeOfClassOrInterface(getSymbolOfNode(parent2.parent.left).parent).thisType; } - const host2 = node.flags & 8388608 /* JSDoc */ ? getHostSignatureFromJSDoc(node) : void 0; + const host2 = node.flags & 16777216 /* JSDoc */ ? getHostSignatureFromJSDoc(node) : void 0; if (host2 && isFunctionExpression(host2) && isBinaryExpression(host2.parent) && getAssignmentDeclarationKind(host2.parent) === 3 /* PrototypeProperty */) { return getDeclaredTypeOfClassOrInterface(getSymbolOfNode(host2.parent.left).parent).thisType; } if (isJSConstructor(container) && isNodeDescendantOf(node, container.body)) { return getDeclaredTypeOfClassOrInterface(getSymbolOfDeclaration(container)).thisType; } - error(node, Diagnostics.A_this_type_is_available_only_in_a_non_static_member_of_a_class_or_interface); + error2(node, Diagnostics.A_this_type_is_available_only_in_a_non_static_member_of_a_class_or_interface); return errorType; } function getTypeFromThisTypeNode(node) { @@ -159233,17 +142931,17 @@ ${lanes.join("\n")} } function getArrayElementTypeNode(node) { switch (node.kind) { - case 195 /* ParenthesizedType */: + case 196 /* ParenthesizedType */: return getArrayElementTypeNode(node.type); - case 188 /* TupleType */: + case 189 /* TupleType */: if (node.elements.length === 1) { node = node.elements[0]; - if (node.kind === 190 /* RestType */ || node.kind === 201 /* NamedTupleMember */ && node.dotDotDotToken) { + if (node.kind === 191 /* RestType */ || node.kind === 202 /* NamedTupleMember */ && node.dotDotDotToken) { return getArrayElementTypeNode(node.type); } } break; - case 187 /* ArrayType */: + case 188 /* ArrayType */: return node.elementType; } return void 0; @@ -159263,8 +142961,8 @@ ${lanes.join("\n")} function getTypeFromTypeNodeWorker(node) { switch (node.kind) { case 133 /* AnyKeyword */: - case 318 /* JSDocAllType */: - case 319 /* JSDocUnknownType */: + case 319 /* JSDocAllType */: + case 320 /* JSDocUnknownType */: return anyType; case 159 /* UnknownKeyword */: return unknownType; @@ -159272,7 +142970,7 @@ ${lanes.join("\n")} return stringType; case 150 /* NumberKeyword */: return numberType; - case 162 /* BigIntKeyword */: + case 163 /* BigIntKeyword */: return bigintType; case 136 /* BooleanKeyword */: return booleanType; @@ -159287,69 +142985,69 @@ ${lanes.join("\n")} case 146 /* NeverKeyword */: return neverType; case 151 /* ObjectKeyword */: - return node.flags & 262144 /* JavaScriptFile */ && !noImplicitAny ? anyType : nonPrimitiveType; + return node.flags & 524288 /* JavaScriptFile */ && !noImplicitAny ? anyType : nonPrimitiveType; case 141 /* IntrinsicKeyword */: return intrinsicMarkerType; - case 196 /* ThisType */: + case 197 /* ThisType */: case 110 /* ThisKeyword */: return getTypeFromThisTypeNode(node); - case 200 /* LiteralType */: + case 201 /* LiteralType */: return getTypeFromLiteralTypeNode(node); - case 182 /* TypeReference */: + case 183 /* TypeReference */: return getTypeFromTypeReference(node); - case 181 /* TypePredicate */: + case 182 /* TypePredicate */: return node.assertsModifier ? voidType : booleanType; - case 232 /* ExpressionWithTypeArguments */: + case 233 /* ExpressionWithTypeArguments */: return getTypeFromTypeReference(node); - case 185 /* TypeQuery */: + case 186 /* TypeQuery */: return getTypeFromTypeQueryNode(node); - case 187 /* ArrayType */: - case 188 /* TupleType */: + case 188 /* ArrayType */: + case 189 /* TupleType */: return getTypeFromArrayOrTupleTypeNode(node); - case 189 /* OptionalType */: + case 190 /* OptionalType */: return getTypeFromOptionalTypeNode(node); - case 191 /* UnionType */: + case 192 /* UnionType */: return getTypeFromUnionTypeNode(node); - case 192 /* IntersectionType */: + case 193 /* IntersectionType */: return getTypeFromIntersectionTypeNode(node); - case 320 /* JSDocNullableType */: + case 321 /* JSDocNullableType */: return getTypeFromJSDocNullableTypeNode(node); - case 322 /* JSDocOptionalType */: + case 323 /* JSDocOptionalType */: return addOptionality(getTypeFromTypeNode(node.type)); - case 201 /* NamedTupleMember */: + case 202 /* NamedTupleMember */: return getTypeFromNamedTupleTypeNode(node); - case 195 /* ParenthesizedType */: - case 321 /* JSDocNonNullableType */: - case 315 /* JSDocTypeExpression */: + case 196 /* ParenthesizedType */: + case 322 /* JSDocNonNullableType */: + case 316 /* JSDocTypeExpression */: return getTypeFromTypeNode(node.type); - case 190 /* RestType */: + case 191 /* RestType */: return getTypeFromRestTypeNode(node); - case 324 /* JSDocVariadicType */: + case 325 /* JSDocVariadicType */: return getTypeFromJSDocVariadicType(node); - case 183 /* FunctionType */: - case 184 /* ConstructorType */: - case 186 /* TypeLiteral */: - case 328 /* JSDocTypeLiteral */: - case 323 /* JSDocFunctionType */: - case 329 /* JSDocSignature */: + case 184 /* FunctionType */: + case 185 /* ConstructorType */: + case 187 /* TypeLiteral */: + case 329 /* JSDocTypeLiteral */: + case 324 /* JSDocFunctionType */: + case 330 /* JSDocSignature */: return getTypeFromTypeLiteralOrFunctionOrConstructorTypeNode(node); - case 197 /* TypeOperator */: + case 198 /* TypeOperator */: return getTypeFromTypeOperatorNode(node); - case 198 /* IndexedAccessType */: + case 199 /* IndexedAccessType */: return getTypeFromIndexedAccessTypeNode(node); - case 199 /* MappedType */: + case 200 /* MappedType */: return getTypeFromMappedTypeNode(node); - case 193 /* ConditionalType */: + case 194 /* ConditionalType */: return getTypeFromConditionalTypeNode(node); - case 194 /* InferType */: + case 195 /* InferType */: return getTypeFromInferTypeNode(node); - case 202 /* TemplateLiteralType */: + case 203 /* TemplateLiteralType */: return getTypeFromTemplateTypeNode(node); - case 204 /* ImportType */: + case 205 /* ImportType */: return getTypeFromImportTypeNode(node); case 80 /* Identifier */: - case 165 /* QualifiedName */: - case 210 /* PropertyAccessExpression */: + case 166 /* QualifiedName */: + case 211 /* PropertyAccessExpression */: const symbol = getSymbolAtLocation(node); return symbol ? getDeclaredTypeOfSymbol(symbol) : errorType; default: @@ -159485,7 +143183,7 @@ ${lanes.join("\n")} /*resolvedTypePredicate*/ void 0, signature.minArgumentCount, - signature.flags & 39 /* PropagatingFlags */ + signature.flags & 167 /* PropagatingFlags */ ); result.target = signature; result.mapper = mapper; @@ -159494,7 +143192,12 @@ ${lanes.join("\n")} function instantiateSymbol(symbol, mapper) { const links = getSymbolLinks(symbol); if (links.type && !couldContainTypeVariables(links.type)) { - return symbol; + if (!(symbol.flags & 65536 /* SetAccessor */)) { + return symbol; + } + if (links.writeType && !couldContainTypeVariables(links.writeType)) { + return symbol; + } } if (getCheckFlags(symbol) & 1 /* Instantiated */) { symbol = links.target; @@ -159547,26 +143250,31 @@ ${lanes.join("\n")} if (!result) { const newMapper = createTypeMapper(typeParameters, typeArguments); result = target.objectFlags & 4 /* Reference */ ? createDeferredTypeReference(type.target, type.node, newMapper, newAliasSymbol, newAliasTypeArguments) : target.objectFlags & 32 /* Mapped */ ? instantiateMappedType(target, newMapper, newAliasSymbol, newAliasTypeArguments) : instantiateAnonymousType(target, newMapper, newAliasSymbol, newAliasTypeArguments); - if (result.flags & 138117121 /* ObjectFlagsType */ && !(result.objectFlags & 524288 /* CouldContainTypeVariablesComputed */)) { + target.instantiations.set(id, result); + const resultObjectFlags = getObjectFlags(result); + if (result.flags & 3899393 /* ObjectFlagsType */ && !(resultObjectFlags & 524288 /* CouldContainTypeVariablesComputed */)) { const resultCouldContainTypeVariables = some(typeArguments, couldContainTypeVariables); - if (!(result.objectFlags & 524288 /* CouldContainTypeVariablesComputed */)) { - result.objectFlags |= 524288 /* CouldContainTypeVariablesComputed */ | (resultCouldContainTypeVariables ? 1048576 /* CouldContainTypeVariables */ : 0); + if (!(getObjectFlags(result) & 524288 /* CouldContainTypeVariablesComputed */)) { + if (resultObjectFlags & (32 /* Mapped */ | 16 /* Anonymous */ | 4 /* Reference */)) { + result.objectFlags |= 524288 /* CouldContainTypeVariablesComputed */ | (resultCouldContainTypeVariables ? 1048576 /* CouldContainTypeVariables */ : 0); + } else { + result.objectFlags |= !resultCouldContainTypeVariables ? 524288 /* CouldContainTypeVariablesComputed */ : 0; + } } } - target.instantiations.set(id, result); } return result; } return type; } function maybeTypeParameterReference(node) { - return !(node.parent.kind === 182 /* TypeReference */ && node.parent.typeArguments && node === node.parent.typeName || node.parent.kind === 204 /* ImportType */ && node.parent.typeArguments && node === node.parent.qualifier); + return !(node.parent.kind === 183 /* TypeReference */ && node.parent.typeArguments && node === node.parent.typeName || node.parent.kind === 205 /* ImportType */ && node.parent.typeArguments && node === node.parent.qualifier); } function isTypeParameterPossiblyReferenced(tp, node) { if (tp.symbol && tp.symbol.declarations && tp.symbol.declarations.length === 1) { const container = tp.symbol.declarations[0].parent; for (let n = node; n !== container; n = n.parent) { - if (!n || n.kind === 240 /* Block */ || n.kind === 193 /* ConditionalType */ && forEachChild(n.extendsType, containsReference)) { + if (!n || n.kind === 241 /* Block */ || n.kind === 194 /* ConditionalType */ && forEachChild(n.extendsType, containsReference)) { return true; } } @@ -159575,17 +143283,17 @@ ${lanes.join("\n")} return true; function containsReference(node2) { switch (node2.kind) { - case 196 /* ThisType */: + case 197 /* ThisType */: return !!tp.isThisType; case 80 /* Identifier */: return !tp.isThisType && isPartOfTypeNode(node2) && maybeTypeParameterReference(node2) && getTypeFromTypeNodeWorker(node2) === tp; - case 185 /* TypeQuery */: + case 186 /* TypeQuery */: const entityName = node2.exprName; const firstIdentifier = getFirstIdentifier(entityName); if (!isThisIdentifier(firstIdentifier)) { const firstIdentifierSymbol = getResolvedSymbol(firstIdentifier); const tpDeclaration = tp.symbol.declarations[0]; - const tpScope = tpDeclaration.kind === 167 /* TypeParameter */ ? tpDeclaration.parent : ( + const tpScope = tpDeclaration.kind === 168 /* TypeParameter */ ? tpDeclaration.parent : ( // Type parameter is a regular type parameter, e.g. foo tp.isThisType ? tpDeclaration : ( // Type parameter is the this type, and its declaration is the class declaration. @@ -159597,8 +143305,8 @@ ${lanes.join("\n")} } } return true; - case 173 /* MethodDeclaration */: - case 172 /* MethodSignature */: + case 174 /* MethodDeclaration */: + case 173 /* MethodSignature */: return !node2.type && !!node2.body || some(node2.typeParameters, containsReference) || some(node2.parameters, containsReference) || !!node2.type && containsReference(node2.type); } return !!forEachChild(node2, containsReference); @@ -159619,24 +143327,29 @@ ${lanes.join("\n")} if (typeVariable) { const mappedTypeVariable = instantiateType(typeVariable, mapper); if (typeVariable !== mappedTypeVariable) { - return mapTypeWithAlias(getReducedType(mappedTypeVariable), (t) => { - if (t.flags & (3 /* AnyOrUnknown */ | 58982400 /* InstantiableNonPrimitive */ | 524288 /* Object */ | 2097152 /* Intersection */) && t !== wildcardType && !isErrorType(t)) { - if (!type.declaration.nameType) { - let constraint; - if (isArrayType(t) || t.flags & 1 /* Any */ && findResolutionCycleStartIndex(typeVariable, 4 /* ImmediateBaseConstraint */) < 0 && (constraint = getConstraintOfTypeParameter(typeVariable)) && everyType(constraint, isArrayOrTupleType)) { - return instantiateMappedArrayType(t, type, prependTypeMapping(typeVariable, t, mapper)); - } - if (isGenericTupleType(t)) { - return instantiateMappedGenericTupleType(t, type, typeVariable, mapper); - } - if (isTupleType(t)) { - return instantiateMappedTupleType(t, type, prependTypeMapping(typeVariable, t, mapper)); + return mapTypeWithAlias( + getReducedType(mappedTypeVariable), + (t) => { + if (t.flags & (3 /* AnyOrUnknown */ | 58982400 /* InstantiableNonPrimitive */ | 524288 /* Object */ | 2097152 /* Intersection */) && t !== wildcardType && !isErrorType(t)) { + if (!type.declaration.nameType) { + let constraint; + if (isArrayType(t) || t.flags & 1 /* Any */ && findResolutionCycleStartIndex(typeVariable, 4 /* ImmediateBaseConstraint */) < 0 && (constraint = getConstraintOfTypeParameter(typeVariable)) && everyType(constraint, isArrayOrTupleType)) { + return instantiateMappedArrayType(t, type, prependTypeMapping(typeVariable, t, mapper)); + } + if (isGenericTupleType(t)) { + return instantiateMappedGenericTupleType(t, type, typeVariable, mapper); + } + if (isTupleType(t)) { + return instantiateMappedTupleType(t, type, prependTypeMapping(typeVariable, t, mapper)); + } } + return instantiateAnonymousType(type, prependTypeMapping(typeVariable, t, mapper)); } - return instantiateAnonymousType(type, prependTypeMapping(typeVariable, t, mapper)); - } - return t; - }, aliasSymbol, aliasTypeArguments); + return t; + }, + aliasSymbol, + aliasTypeArguments + ); } } return instantiateType(getConstraintTypeFromMappedType(type), mapper) === wildcardType ? wildcardType : instantiateAnonymousType(type, mapper, aliasSymbol, aliasTypeArguments); @@ -159648,6 +143361,9 @@ ${lanes.join("\n")} const elementFlags = tupleType.target.elementFlags; const elementTypes = map(getElementTypes(tupleType), (t, i) => { const singleton = elementFlags[i] & 8 /* Variadic */ ? t : elementFlags[i] & 4 /* Rest */ ? createArrayType(t) : createTupleType([t], [elementFlags[i]]); + if (singleton === typeVariable) { + return mappedType; + } return instantiateMappedType(mappedType, prependTypeMapping(typeVariable, singleton, mapper)); }); const newReadonly = getModifiedReadonlyState(tupleType.target.readonly, getMappedTypeModifiers(mappedType)); @@ -159735,7 +143451,7 @@ ${lanes.join("\n")} } if (instantiationDepth === 100 || instantiationCount >= 5e6) { (_a = tracing) == null ? void 0 : _a.instant(tracing.Phase.CheckTypes, "instantiateType_DepthLimit", { typeId: type.id, instantiationDepth, instantiationCount }); - error(currentNode, Diagnostics.Type_instantiation_is_excessively_deep_and_possibly_infinite); + error2(currentNode, Diagnostics.Type_instantiation_is_excessively_deep_and_possibly_infinite); return errorType; } totalInstantiationCount++; @@ -159851,32 +143567,32 @@ ${lanes.join("\n")} return createIndexInfo(info.keyType, instantiateType(info.type, mapper), info.isReadonly, info.declaration); } function isContextSensitive(node) { - Debug.assert(node.kind !== 173 /* MethodDeclaration */ || isObjectLiteralMethod(node)); + Debug.assert(node.kind !== 174 /* MethodDeclaration */ || isObjectLiteralMethod(node)); switch (node.kind) { - case 217 /* FunctionExpression */: - case 218 /* ArrowFunction */: - case 173 /* MethodDeclaration */: - case 261 /* FunctionDeclaration */: + case 218 /* FunctionExpression */: + case 219 /* ArrowFunction */: + case 174 /* MethodDeclaration */: + case 262 /* FunctionDeclaration */: return isContextSensitiveFunctionLikeDeclaration(node); - case 209 /* ObjectLiteralExpression */: + case 210 /* ObjectLiteralExpression */: return some(node.properties, isContextSensitive); - case 208 /* ArrayLiteralExpression */: + case 209 /* ArrayLiteralExpression */: return some(node.elements, isContextSensitive); - case 226 /* ConditionalExpression */: + case 227 /* ConditionalExpression */: return isContextSensitive(node.whenTrue) || isContextSensitive(node.whenFalse); - case 225 /* BinaryExpression */: + case 226 /* BinaryExpression */: return (node.operatorToken.kind === 57 /* BarBarToken */ || node.operatorToken.kind === 61 /* QuestionQuestionToken */) && (isContextSensitive(node.left) || isContextSensitive(node.right)); - case 302 /* PropertyAssignment */: + case 303 /* PropertyAssignment */: return isContextSensitive(node.initializer); - case 216 /* ParenthesizedExpression */: + case 217 /* ParenthesizedExpression */: return isContextSensitive(node.expression); - case 291 /* JsxAttributes */: + case 292 /* JsxAttributes */: return some(node.properties, isContextSensitive) || isJsxOpeningElement(node.parent) && some(node.parent.parent.children, isContextSensitive); - case 290 /* JsxAttribute */: { + case 291 /* JsxAttribute */: { const { initializer } = node; return !!initializer && isContextSensitive(initializer); } - case 293 /* JsxExpression */: { + case 294 /* JsxExpression */: { const { expression } = node; return !!expression && isContextSensitive(expression); } @@ -159890,7 +143606,7 @@ ${lanes.join("\n")} if (node.typeParameters || getEffectiveReturnTypeNode(node) || !node.body) { return false; } - if (node.body.kind !== 240 /* Block */) { + if (node.body.kind !== 241 /* Block */) { return isContextSensitive(node.body); } return !!forEachReturnStatement(node.body, (statement) => !!statement.expression && isContextSensitive(statement.expression)); @@ -159985,23 +143701,27 @@ ${lanes.join("\n")} return true; } switch (node.kind) { - case 293 /* JsxExpression */: - case 216 /* ParenthesizedExpression */: + case 234 /* AsExpression */: + if (!isConstAssertion(node)) { + break; + } + case 294 /* JsxExpression */: + case 217 /* ParenthesizedExpression */: return elaborateError(node.expression, source, target, relation, headMessage, containingMessageChain, errorOutputContainer); - case 225 /* BinaryExpression */: + case 226 /* BinaryExpression */: switch (node.operatorToken.kind) { case 64 /* EqualsToken */: case 28 /* CommaToken */: return elaborateError(node.right, source, target, relation, headMessage, containingMessageChain, errorOutputContainer); } break; - case 209 /* ObjectLiteralExpression */: + case 210 /* ObjectLiteralExpression */: return elaborateObjectLiteral(node, source, target, relation, containingMessageChain, errorOutputContainer); - case 208 /* ArrayLiteralExpression */: + case 209 /* ArrayLiteralExpression */: return elaborateArrayLiteral(node, source, target, relation, containingMessageChain, errorOutputContainer); - case 291 /* JsxAttributes */: + case 292 /* JsxAttributes */: return elaborateJsxComponents(node, source, target, relation, containingMessageChain, errorOutputContainer); - case 218 /* ArrowFunction */: + case 219 /* ArrowFunction */: return elaborateArrowFunction(node, source, target, relation, containingMessageChain, errorOutputContainer); } return false; @@ -160023,10 +143743,13 @@ ${lanes.join("\n")} const resultObj = errorOutputContainer || {}; checkTypeAssignableTo(source, target, node, headMessage, containingMessageChain, resultObj); const diagnostic = resultObj.errors[resultObj.errors.length - 1]; - addRelatedInfo(diagnostic, createDiagnosticForNode( - node, - signatures === constructSignatures ? Diagnostics.Did_you_mean_to_use_new_with_this_expression : Diagnostics.Did_you_mean_to_call_this_expression - )); + addRelatedInfo( + diagnostic, + createDiagnosticForNode( + node, + signatures === constructSignatures ? Diagnostics.Did_you_mean_to_use_new_with_this_expression : Diagnostics.Did_you_mean_to_call_this_expression + ) + ); return true; } } @@ -160083,10 +143806,13 @@ ${lanes.join("\n")} ); if (resultObj.errors) { if (target.symbol && length(target.symbol.declarations)) { - addRelatedInfo(resultObj.errors[resultObj.errors.length - 1], createDiagnosticForNode( - target.symbol.declarations[0], - Diagnostics.The_expected_type_comes_from_the_return_type_of_this_signature - )); + addRelatedInfo( + resultObj.errors[resultObj.errors.length - 1], + createDiagnosticForNode( + target.symbol.declarations[0], + Diagnostics.The_expected_type_comes_from_the_return_type_of_this_signature + ) + ); } if ((getFunctionFlags(node) & 2 /* Async */) === 0 && !getTypeOfPropertyOfType(sourceReturn, "then") && checkTypeRelatedTo( createPromiseType(sourceReturn), @@ -160095,10 +143821,13 @@ ${lanes.join("\n")} /*errorNode*/ void 0 )) { - addRelatedInfo(resultObj.errors[resultObj.errors.length - 1], createDiagnosticForNode( - node, - Diagnostics.Did_you_mean_to_mark_this_function_as_async - )); + addRelatedInfo( + resultObj.errors[resultObj.errors.length - 1], + createDiagnosticForNode( + node, + Diagnostics.Did_you_mean_to_mark_this_function_as_async + ) + ); } return true; } @@ -160193,12 +143922,15 @@ ${lanes.join("\n")} if (!issuedElaboration && (targetProp && length(targetProp.declarations) || target.symbol && length(target.symbol.declarations))) { const targetNode = targetProp && length(targetProp.declarations) ? targetProp.declarations[0] : target.symbol.declarations[0]; if (!getSourceFileOfNode(targetNode).hasNoDefaultLib) { - addRelatedInfo(reportedDiag, createDiagnosticForNode( - targetNode, - Diagnostics.The_expected_type_comes_from_property_0_which_is_declared_here_on_type_1, - propertyName && !(nameType.flags & 8192 /* UniqueESSymbol */) ? unescapeLeadingUnderscores(propertyName) : typeToString(nameType), - typeToString(target) - )); + addRelatedInfo( + reportedDiag, + createDiagnosticForNode( + targetNode, + Diagnostics.The_expected_type_comes_from_property_0_which_is_declared_here_on_type_1, + propertyName && !(nameType.flags & 8192 /* UniqueESSymbol */) ? unescapeLeadingUnderscores(propertyName) : typeToString(nameType), + typeToString(target) + ) + ); } } } @@ -160301,16 +144033,16 @@ ${lanes.join("\n")} } function getElaborationElementForJsxChild(child, nameType, getInvalidTextDiagnostic) { switch (child.kind) { - case 293 /* JsxExpression */: + case 294 /* JsxExpression */: return { errorNode: child, innerExpression: child.expression, nameType }; case 12 /* JsxText */: if (child.containsOnlyTriviaWhiteSpaces) { break; } return { errorNode: child, innerExpression: void 0, nameType, errorMessage: getInvalidTextDiagnostic() }; - case 283 /* JsxElement */: - case 284 /* JsxSelfClosingElement */: - case 287 /* JsxFragment */: + case 284 /* JsxElement */: + case 285 /* JsxSelfClosingElement */: + case 288 /* JsxFragment */: return { errorNode: child, innerExpression: child, nameType }; default: return Debug.assertNever(child, "Found invalid jsx child"); @@ -160351,7 +144083,7 @@ ${lanes.join("\n")} result = elaborateIterableOrArrayLikeTargetElementwise(children, realSource, arrayLikeTargetParts, relation, containingMessageChain, errorOutputContainer) || result; } else if (!isTypeRelatedTo(getIndexedAccessType(source, childrenNameType), childrenTargetType, relation)) { result = true; - const diag2 = error( + const diag2 = error2( containingElement.openingElement.tagName, Diagnostics.This_JSX_tag_s_0_prop_expects_a_single_child_of_type_1_but_multiple_children_were_provided, childrenPropName, @@ -160379,7 +144111,7 @@ ${lanes.join("\n")} } } else if (!isTypeRelatedTo(getIndexedAccessType(source, childrenNameType), childrenTargetType, relation)) { result = true; - const diag2 = error( + const diag2 = error2( containingElement.openingElement.tagName, Diagnostics.This_JSX_tag_s_0_prop_expects_type_1_which_requires_multiple_children_but_only_a_single_child_was_provided, childrenPropName, @@ -160399,14 +144131,7 @@ ${lanes.join("\n")} const childrenPropName = childPropName === void 0 ? "children" : unescapeLeadingUnderscores(childPropName); const childrenTargetType = getIndexedAccessType(target, getStringLiteralType(childrenPropName)); const diagnostic = Diagnostics._0_components_don_t_accept_text_as_child_elements_Text_in_JSX_has_the_type_string_but_the_expected_type_of_1_is_2; - invalidTextDiagnostic = { ...diagnostic, key: "!!ALREADY FORMATTED!!", message: formatMessage( - /*dummy*/ - void 0, - diagnostic, - tagNameText, - childrenPropName, - typeToString(childrenTargetType) - ) }; + invalidTextDiagnostic = { ...diagnostic, key: "!!ALREADY FORMATTED!!", message: formatMessage(diagnostic, tagNameText, childrenPropName, typeToString(childrenTargetType)) }; } return invalidTextDiagnostic; } @@ -160460,13 +144185,13 @@ ${lanes.join("\n")} continue; } switch (prop.kind) { - case 177 /* SetAccessor */: - case 176 /* GetAccessor */: - case 173 /* MethodDeclaration */: - case 303 /* ShorthandPropertyAssignment */: + case 178 /* SetAccessor */: + case 177 /* GetAccessor */: + case 174 /* MethodDeclaration */: + case 304 /* ShorthandPropertyAssignment */: yield { errorNode: prop.name, innerExpression: void 0, nameType: type }; break; - case 302 /* PropertyAssignment */: + case 303 /* PropertyAssignment */: yield { errorNode: prop.name, innerExpression: prop.initializer, nameType: type, errorMessage: isComputedNonLiteralName(prop.name) ? Diagnostics.Type_of_computed_property_s_value_is_0_which_is_not_assignable_to_type_1 : void 0 }; break; default: @@ -160541,7 +144266,7 @@ ${lanes.join("\n")} void instantiateType(sourceRestType || targetRestType, reportUnreliableMarkers); } const kind = target.declaration ? target.declaration.kind : 0 /* Unknown */; - const strictVariance = !(checkMode & 3 /* Callback */) && strictFunctionTypes && kind !== 173 /* MethodDeclaration */ && kind !== 172 /* MethodSignature */ && kind !== 175 /* Constructor */; + const strictVariance = !(checkMode & 3 /* Callback */) && strictFunctionTypes && kind !== 174 /* MethodDeclaration */ && kind !== 173 /* MethodSignature */ && kind !== 176 /* Constructor */; let result = -1 /* True */; const sourceThisType = getThisTypeOfSignature(source); if (sourceThisType && sourceThisType !== voidType) { @@ -160570,7 +144295,7 @@ ${lanes.join("\n")} if (sourceType && targetType) { const sourceSig = checkMode & 3 /* Callback */ ? void 0 : getSingleCallSignature(getNonNullableType(sourceType)); const targetSig = checkMode & 3 /* Callback */ ? void 0 : getSingleCallSignature(getNonNullableType(targetType)); - const callbacks = sourceSig && targetSig && !getTypePredicateOfSignature(sourceSig) && !getTypePredicateOfSignature(targetSig) && (getTypeFacts(sourceType) & 50331648 /* IsUndefinedOrNull */) === (getTypeFacts(targetType) & 50331648 /* IsUndefinedOrNull */); + const callbacks = sourceSig && targetSig && !getTypePredicateOfSignature(sourceSig) && !getTypePredicateOfSignature(targetSig) && getTypeFacts(sourceType, 50331648 /* IsUndefinedOrNull */) === getTypeFacts(targetType, 50331648 /* IsUndefinedOrNull */); let related = callbacks ? compareSignaturesRelated(targetSig, sourceSig, checkMode & 8 /* StrictArity */ | (strictVariance ? 2 /* StrictCallback */ : 1 /* BivariantCallback */), reportErrors2, errorReporter, incompatibleErrorReporter, compareTypes, reportUnreliableMarkers) : !(checkMode & 3 /* Callback */) && !strictVariance && compareTypes( sourceType, targetType, @@ -160587,11 +144312,7 @@ ${lanes.join("\n")} } if (!related) { if (reportErrors2) { - errorReporter( - Diagnostics.Types_of_parameters_0_and_1_are_incompatible, - unescapeLeadingUnderscores(getParameterNameAtPosition(source, i)), - unescapeLeadingUnderscores(getParameterNameAtPosition(target, i)) - ); + errorReporter(Diagnostics.Types_of_parameters_0_and_1_are_incompatible, unescapeLeadingUnderscores(getParameterNameAtPosition(source, i)), unescapeLeadingUnderscores(getParameterNameAtPosition(target, i))); } return 0 /* False */; } @@ -160712,16 +144433,12 @@ ${lanes.join("\n")} const targetProperty = getPropertyOfType(targetEnumType, property.escapedName); if (!targetProperty || !(targetProperty.flags & 8 /* EnumMember */)) { if (errorReporter) { - errorReporter( - Diagnostics.Property_0_is_missing_in_type_1, - symbolName(property), - typeToString( - getDeclaredTypeOfSymbol(targetSymbol), - /*enclosingDeclaration*/ - void 0, - 64 /* UseFullyQualifiedType */ - ) - ); + errorReporter(Diagnostics.Property_0_is_missing_in_type_1, symbolName(property), typeToString( + getDeclaredTypeOfSymbol(targetSymbol), + /*enclosingDeclaration*/ + void 0, + 64 /* UseFullyQualifiedType */ + )); enumRelation.set(id, 2 /* Failed */ | 4 /* Reported */); } else { enumRelation.set(id, 2 /* Failed */); @@ -160860,6 +144577,7 @@ ${lanes.join("\n")} let errorInfo; let relatedInfo; let maybeKeys; + let maybeKeysSet; let sourceStack; let targetStack; let maybeCount = 0; @@ -160868,8 +144586,10 @@ ${lanes.join("\n")} let expandingFlags = 0 /* None */; let overflow = false; let overrideNextErrorInfo = 0; + let skipParentCounter = 0; let lastSkippedInfo; let incompatibleStack; + let relationCount = 16e6 - relation.size >> 3; Debug.assert(relation !== identityRelation || !errorNode, "no error reporting in identity checking"); const result = isRelatedTo( source, @@ -160883,8 +144603,19 @@ ${lanes.join("\n")} reportIncompatibleStack(); } if (overflow) { + const id = getRelationKey( + source, + target, + /*intersectionState*/ + 0 /* None */, + relation, + /*ignoreConstraints*/ + false + ); + relation.set(id, 4 /* Reported */ | 2 /* Failed */); (_a = tracing) == null ? void 0 : _a.instant(tracing.Phase.CheckTypes, "checkTypeRelatedTo_DepthLimit", { sourceId: source.id, targetId: target.id, depth: sourceDepth, targetDepth }); - const diag2 = error(errorNode || currentNode, Diagnostics.Excessive_stack_depth_comparing_types_0_and_1, typeToString(source), typeToString(target)); + const message = relationCount <= 0 ? Diagnostics.Excessive_complexity_comparing_types_0_and_1 : Diagnostics.Excessive_stack_depth_comparing_types_0_and_1; + const diag2 = error2(errorNode || currentNode, message, typeToString(source), typeToString(target)); if (errorOutputContainer) { (errorOutputContainer.errors || (errorOutputContainer.errors = [])).push(diag2); } @@ -160933,6 +144664,7 @@ ${lanes.join("\n")} lastSkippedInfo = saved.lastSkippedInfo; incompatibleStack = saved.incompatibleStack; overrideNextErrorInfo = saved.overrideNextErrorInfo; + skipParentCounter = saved.skipParentCounter; relatedInfo = saved.relatedInfo; } function captureErrorCalculationState() { @@ -160941,6 +144673,7 @@ ${lanes.join("\n")} lastSkippedInfo, incompatibleStack: incompatibleStack == null ? void 0 : incompatibleStack.slice(), overrideNextErrorInfo, + skipParentCounter, relatedInfo: relatedInfo == null ? void 0 : relatedInfo.slice() }; } @@ -161045,7 +144778,15 @@ ${lanes.join("\n")} reportIncompatibleStack(); if (message.elidedInCompatabilityPyramid) return; - errorInfo = chainDiagnosticMessages(errorInfo, message, ...args); + if (skipParentCounter === 0) { + errorInfo = chainDiagnosticMessages(errorInfo, message, ...args); + } else { + skipParentCounter--; + } + } + function reportParentSkippedError(message, ...args) { + reportError(message, ...args); + skipParentCounter++; } function associateRelatedInfo(info) { Debug.assert(!!errorInfo); @@ -161382,18 +145123,9 @@ ${lanes.join("\n")} } } if (suggestion !== void 0) { - reportError( - Diagnostics.Object_literal_may_only_specify_known_properties_but_0_does_not_exist_in_type_1_Did_you_mean_to_write_2, - symbolToString(prop), - typeToString(errorTarget), - suggestion - ); + reportParentSkippedError(Diagnostics.Object_literal_may_only_specify_known_properties_but_0_does_not_exist_in_type_1_Did_you_mean_to_write_2, symbolToString(prop), typeToString(errorTarget), suggestion); } else { - reportError( - Diagnostics.Object_literal_may_only_specify_known_properties_and_0_does_not_exist_in_type_1, - symbolToString(prop), - typeToString(errorTarget) - ); + reportParentSkippedError(Diagnostics.Object_literal_may_only_specify_known_properties_and_0_does_not_exist_in_type_1, symbolToString(prop), typeToString(errorTarget)); } } } @@ -161414,6 +145146,16 @@ ${lanes.join("\n")} } function unionOrIntersectionRelatedTo(source2, target2, reportErrors2, intersectionState) { if (source2.flags & 1048576 /* Union */) { + if (target2.flags & 1048576 /* Union */) { + const sourceOrigin = source2.origin; + if (sourceOrigin && sourceOrigin.flags & 2097152 /* Intersection */ && target2.aliasSymbol && contains(sourceOrigin.types, target2)) { + return -1 /* True */; + } + const targetOrigin = target2.origin; + if (targetOrigin && targetOrigin.flags & 1048576 /* Union */ && source2.aliasSymbol && contains(targetOrigin.types, source2)) { + return -1 /* True */; + } + } return relation === comparableRelation ? someTypeRelatedToType(source2, target2, reportErrors2 && !(source2.flags & 402784252 /* Primitive */), intersectionState) : eachTypeRelatedToType(source2, target2, reportErrors2 && !(source2.flags & 402784252 /* Primitive */), intersectionState); } if (target2.flags & 1048576 /* Union */) { @@ -161727,11 +145469,19 @@ ${lanes.join("\n")} return entry & 1 /* Succeeded */ ? -1 /* True */ : 0 /* False */; } } + if (relationCount <= 0) { + overflow = true; + return 0 /* False */; + } if (!maybeKeys) { maybeKeys = []; + maybeKeysSet = /* @__PURE__ */ new Set(); sourceStack = []; targetStack = []; } else { + if (maybeKeysSet.has(id)) { + return 3 /* Maybe */; + } const broadestEquivalentId = id.startsWith("*") ? getRelationKey( source2, target2, @@ -161740,10 +145490,8 @@ ${lanes.join("\n")} /*ignoreConstraints*/ true ) : void 0; - for (let i = 0; i < maybeCount; i++) { - if (id === maybeKeys[i] || broadestEquivalentId && broadestEquivalentId === maybeKeys[i]) { - return 3 /* Maybe */; - } + if (broadestEquivalentId && maybeKeysSet.has(broadestEquivalentId)) { + return 3 /* Maybe */; } if (sourceDepth === 100 || targetDepth === 100) { overflow = true; @@ -161752,6 +145500,7 @@ ${lanes.join("\n")} } const maybeStart = maybeCount; maybeKeys[maybeCount] = id; + maybeKeysSet.add(id); maybeCount++; const saveExpandingFlags = expandingFlags; if (recursionFlags & 1 /* Source */) { @@ -161804,17 +145553,36 @@ ${lanes.join("\n")} if (result2) { if (result2 === -1 /* True */ || sourceDepth === 0 && targetDepth === 0) { if (result2 === -1 /* True */ || result2 === 3 /* Maybe */) { - for (let i = maybeStart; i < maybeCount; i++) { - relation.set(maybeKeys[i], 1 /* Succeeded */ | propagatingVarianceFlags); - } + resetMaybeStack( + /*markAllAsSucceeded*/ + true + ); + } else { + resetMaybeStack( + /*markAllAsSucceeded*/ + false + ); } - maybeCount = maybeStart; } } else { relation.set(id, (reportErrors2 ? 4 /* Reported */ : 0) | 2 /* Failed */ | propagatingVarianceFlags); - maybeCount = maybeStart; + relationCount--; + resetMaybeStack( + /*markAllAsSucceeded*/ + false + ); } return result2; + function resetMaybeStack(markAllAsSucceeded) { + for (let i = maybeStart; i < maybeCount; i++) { + maybeKeysSet.delete(maybeKeys[i]); + if (markAllAsSucceeded) { + relation.set(maybeKeys[i], 1 /* Succeeded */ | propagatingVarianceFlags); + relationCount--; + } + } + maybeCount = maybeStart; + } } function structuredTypeRelatedTo(source2, target2, reportErrors2, intersectionState) { const saveErrorInfo = captureErrorCalculationState(); @@ -162226,26 +145994,6 @@ ${lanes.join("\n")} )) { return result2; } - if (sourceFlags & 8388608 /* IndexedAccess */) { - const indexType = source2.indexType; - if (indexType.flags & 4194304 /* Index */) { - const unresolvedIndexConstraint = getBaseConstraintOfType(indexType.type); - const indexConstraint = unresolvedIndexConstraint && unresolvedIndexConstraint !== noConstraintType ? getIndexType(unresolvedIndexConstraint) : keyofConstraintType; - const constraint2 = getIndexedAccessType(source2.objectType, indexConstraint); - if (result2 = isRelatedTo( - constraint2, - target2, - 1 /* Source */, - /*reportErrors*/ - false, - /*headMessage*/ - void 0, - intersectionState - )) { - return result2; - } - } - } if (isMappedTypeGenericIndexedAccess(source2)) { const indexConstraint = getConstraintOfType(source2.indexType); if (indexConstraint) { @@ -162589,42 +146337,27 @@ ${lanes.join("\n")} function propertyRelatedTo(source2, target2, sourceProp, targetProp, getTypeOfSourceProperty, reportErrors2, intersectionState, skipOptional) { const sourcePropFlags = getDeclarationModifierFlagsFromSymbol(sourceProp); const targetPropFlags = getDeclarationModifierFlagsFromSymbol(targetProp); - if (sourcePropFlags & 8 /* Private */ || targetPropFlags & 8 /* Private */) { + if (sourcePropFlags & 2 /* Private */ || targetPropFlags & 2 /* Private */) { if (sourceProp.valueDeclaration !== targetProp.valueDeclaration) { if (reportErrors2) { - if (sourcePropFlags & 8 /* Private */ && targetPropFlags & 8 /* Private */) { + if (sourcePropFlags & 2 /* Private */ && targetPropFlags & 2 /* Private */) { reportError(Diagnostics.Types_have_separate_declarations_of_a_private_property_0, symbolToString(targetProp)); } else { - reportError( - Diagnostics.Property_0_is_private_in_type_1_but_not_in_type_2, - symbolToString(targetProp), - typeToString(sourcePropFlags & 8 /* Private */ ? source2 : target2), - typeToString(sourcePropFlags & 8 /* Private */ ? target2 : source2) - ); + reportError(Diagnostics.Property_0_is_private_in_type_1_but_not_in_type_2, symbolToString(targetProp), typeToString(sourcePropFlags & 2 /* Private */ ? source2 : target2), typeToString(sourcePropFlags & 2 /* Private */ ? target2 : source2)); } } return 0 /* False */; } - } else if (targetPropFlags & 16 /* Protected */) { + } else if (targetPropFlags & 4 /* Protected */) { if (!isValidOverrideOf(sourceProp, targetProp)) { if (reportErrors2) { - reportError( - Diagnostics.Property_0_is_protected_but_type_1_is_not_a_class_derived_from_2, - symbolToString(targetProp), - typeToString(getDeclaringClass(sourceProp) || source2), - typeToString(getDeclaringClass(targetProp) || target2) - ); + reportError(Diagnostics.Property_0_is_protected_but_type_1_is_not_a_class_derived_from_2, symbolToString(targetProp), typeToString(getDeclaringClass(sourceProp) || source2), typeToString(getDeclaringClass(targetProp) || target2)); } return 0 /* False */; } - } else if (sourcePropFlags & 16 /* Protected */) { + } else if (sourcePropFlags & 4 /* Protected */) { if (reportErrors2) { - reportError( - Diagnostics.Property_0_is_protected_in_type_1_but_public_in_type_2, - symbolToString(targetProp), - typeToString(source2), - typeToString(target2) - ); + reportError(Diagnostics.Property_0_is_protected_in_type_1_but_public_in_type_2, symbolToString(targetProp), typeToString(source2), typeToString(target2)); } return 0 /* False */; } @@ -162640,12 +146373,7 @@ ${lanes.join("\n")} } if (!skipOptional && sourceProp.flags & 16777216 /* Optional */ && targetProp.flags & 106500 /* ClassMember */ && !(targetProp.flags & 16777216 /* Optional */)) { if (reportErrors2) { - reportError( - Diagnostics.Property_0_is_optional_in_type_1_but_required_in_type_2, - symbolToString(targetProp), - typeToString(source2), - typeToString(target2) - ); + reportError(Diagnostics.Property_0_is_optional_in_type_1_but_required_in_type_2, symbolToString(targetProp), typeToString(source2), typeToString(target2)); } return 0 /* False */; } @@ -162891,8 +146619,14 @@ ${lanes.join("\n")} } const sourceIsJSConstructor = source2.symbol && isJSConstructor(source2.symbol.valueDeclaration); const targetIsJSConstructor = target2.symbol && isJSConstructor(target2.symbol.valueDeclaration); - const sourceSignatures = getSignaturesOfType(source2, sourceIsJSConstructor && kind === 1 /* Construct */ ? 0 /* Call */ : kind); - const targetSignatures = getSignaturesOfType(target2, targetIsJSConstructor && kind === 1 /* Construct */ ? 0 /* Call */ : kind); + const sourceSignatures = getSignaturesOfType( + source2, + sourceIsJSConstructor && kind === 1 /* Construct */ ? 0 /* Call */ : kind + ); + const targetSignatures = getSignaturesOfType( + target2, + targetIsJSConstructor && kind === 1 /* Construct */ ? 0 /* Call */ : kind + ); if (kind === 1 /* Construct */ && sourceSignatures.length && targetSignatures.length) { const sourceIsAbstract = !!(sourceSignatures[0].flags & 4 /* Abstract */); const targetIsAbstract = !!(targetSignatures[0].flags & 4 /* Abstract */); @@ -162931,7 +146665,7 @@ ${lanes.join("\n")} const sourceSignature = first(sourceSignatures); const targetSignature = first(targetSignatures); result2 = signatureRelatedTo(sourceSignature, targetSignature, eraseGenerics, reportErrors2, intersectionState, incompatibleReporter(sourceSignature, targetSignature)); - if (!result2 && reportErrors2 && kind === 1 /* Construct */ && sourceObjectFlags & targetObjectFlags && (((_a2 = targetSignature.declaration) == null ? void 0 : _a2.kind) === 175 /* Constructor */ || ((_b = sourceSignature.declaration) == null ? void 0 : _b.kind) === 175 /* Constructor */)) { + if (!result2 && reportErrors2 && kind === 1 /* Construct */ && sourceObjectFlags & targetObjectFlags && (((_a2 = targetSignature.declaration) == null ? void 0 : _a2.kind) === 176 /* Constructor */ || ((_b = sourceSignature.declaration) == null ? void 0 : _b.kind) === 176 /* Constructor */)) { const constructSignatureToString = (signature) => signatureToString( signature, /*enclosingDeclaration*/ @@ -162966,18 +146700,14 @@ ${lanes.join("\n")} shouldElaborateErrors = false; } if (shouldElaborateErrors) { - reportError( - Diagnostics.Type_0_provides_no_match_for_the_signature_1, - typeToString(source2), - signatureToString( - t, - /*enclosingDeclaration*/ - void 0, - /*flags*/ - void 0, - kind - ) - ); + reportError(Diagnostics.Type_0_provides_no_match_for_the_signature_1, typeToString(source2), signatureToString( + t, + /*enclosingDeclaration*/ + void 0, + /*flags*/ + void 0, + kind + )); } return 0 /* False */; } @@ -163010,16 +146740,7 @@ ${lanes.join("\n")} } function signatureRelatedTo(source2, target2, erase, reportErrors2, intersectionState, incompatibleReporter) { const checkMode = relation === subtypeRelation ? 16 /* StrictTopSignature */ : relation === strictSubtypeRelation ? 16 /* StrictTopSignature */ | 8 /* StrictArity */ : 0 /* None */; - return compareSignaturesRelated( - erase ? getErasedSignature(source2) : source2, - erase ? getErasedSignature(target2) : target2, - checkMode, - reportErrors2, - reportError, - incompatibleReporter, - isRelatedToWorker2, - reportUnreliableMapper - ); + return compareSignaturesRelated(erase ? getErasedSignature(source2) : source2, erase ? getErasedSignature(target2) : target2, checkMode, reportErrors2, reportError, incompatibleReporter, isRelatedToWorker2, reportUnreliableMapper); function isRelatedToWorker2(source3, target3, reportErrors3) { return isRelatedTo( source3, @@ -163164,15 +146885,15 @@ ${lanes.join("\n")} if (!sourceSignature.declaration || !targetSignature.declaration) { return true; } - const sourceAccessibility = getSelectedEffectiveModifierFlags(sourceSignature.declaration, 24 /* NonPublicAccessibilityModifier */); - const targetAccessibility = getSelectedEffectiveModifierFlags(targetSignature.declaration, 24 /* NonPublicAccessibilityModifier */); - if (targetAccessibility === 8 /* Private */) { + const sourceAccessibility = getSelectedEffectiveModifierFlags(sourceSignature.declaration, 6 /* NonPublicAccessibilityModifier */); + const targetAccessibility = getSelectedEffectiveModifierFlags(targetSignature.declaration, 6 /* NonPublicAccessibilityModifier */); + if (targetAccessibility === 2 /* Private */) { return true; } - if (targetAccessibility === 16 /* Protected */ && sourceAccessibility !== 8 /* Private */) { + if (targetAccessibility === 4 /* Protected */ && sourceAccessibility !== 2 /* Private */) { return true; } - if (targetAccessibility !== 16 /* Protected */ && !sourceAccessibility) { + if (targetAccessibility !== 4 /* Protected */ && !sourceAccessibility) { return true; } if (reportErrors2) { @@ -163217,7 +146938,7 @@ ${lanes.join("\n")} let matched = false; for (let i = 0; i < types.length; i++) { if (include[i]) { - const targetType = getTypeOfPropertyOfType(types[i], propertyName); + const targetType = getTypeOfPropertyOrIndexSignatureOfType(types[i], propertyName); if (targetType && related(getDiscriminatingType(), targetType)) { matched = true; } else { @@ -163231,7 +146952,7 @@ ${lanes.join("\n")} } } } - const filtered = contains(include, 0 /* False */) ? getUnionType(types.filter((_, i) => include[i])) : target; + const filtered = contains(include, 0 /* False */) ? getUnionType(types.filter((_, i) => include[i]), 0 /* None */) : target; return filtered.flags & 131072 /* Never */ ? target : filtered; } function isWeakType(type) { @@ -163272,7 +146993,7 @@ ${lanes.join("\n")} const variances = []; for (const tp of typeParameters) { const modifiers = getTypeParameterModifiers(tp); - let variance = modifiers & 65536 /* Out */ ? modifiers & 32768 /* In */ ? 0 /* Invariant */ : 1 /* Covariant */ : modifiers & 32768 /* In */ ? 2 /* Contravariant */ : void 0; + let variance = modifiers & 16384 /* Out */ ? modifiers & 8192 /* In */ ? 0 /* Invariant */ : 1 /* Covariant */ : modifiers & 8192 /* In */ ? 2 /* Contravariant */ : void 0; if (variance === void 0) { let unmeasurable = false; let unreliable = false; @@ -163320,7 +147041,7 @@ ${lanes.join("\n")} } function getTypeParameterModifiers(tp) { var _a; - return reduceLeft((_a = tp.symbol) == null ? void 0 : _a.declarations, (modifiers, d) => modifiers | getEffectiveModifierFlags(d), 0 /* None */) & (32768 /* In */ | 65536 /* Out */ | 2048 /* Const */); + return reduceLeft((_a = tp.symbol) == null ? void 0 : _a.declarations, (modifiers, d) => modifiers | getEffectiveModifierFlags(d), 0 /* None */) & (8192 /* In */ | 16384 /* Out */ | 4096 /* Const */); } function hasCovariantVoidArgument(typeArguments, variances) { for (let i = 0; i < variances.length; i++) { @@ -163405,13 +147126,16 @@ ${lanes.join("\n")} }); } function isValidOverrideOf(sourceProp, targetProp) { - return !forEachProperty2(targetProp, (tp) => getDeclarationModifierFlagsFromSymbol(tp) & 16 /* Protected */ ? !isPropertyInClassDerivedFrom(sourceProp, getDeclaringClass(tp)) : false); + return !forEachProperty2(targetProp, (tp) => getDeclarationModifierFlagsFromSymbol(tp) & 4 /* Protected */ ? !isPropertyInClassDerivedFrom(sourceProp, getDeclaringClass(tp)) : false); } function isClassDerivedFromDeclaringClasses(checkClass, prop, writing) { - return forEachProperty2(prop, (p) => getDeclarationModifierFlagsFromSymbol(p, writing) & 16 /* Protected */ ? !hasBaseType(checkClass, getDeclaringClass(p)) : false) ? void 0 : checkClass; + return forEachProperty2(prop, (p) => getDeclarationModifierFlagsFromSymbol(p, writing) & 4 /* Protected */ ? !hasBaseType(checkClass, getDeclaringClass(p)) : false) ? void 0 : checkClass; } function isDeeplyNestedType(type, stack, depth, maxDepth = 3) { if (depth >= maxDepth) { + if ((getObjectFlags(type) & 96 /* InstantiatedMapped */) === 96 /* InstantiatedMapped */) { + type = getMappedTargetWithSymbol(type); + } if (type.flags & 2097152 /* Intersection */) { return some(type.types, (t) => isDeeplyNestedType(t, stack, depth, maxDepth)); } @@ -163420,7 +147144,7 @@ ${lanes.join("\n")} let lastTypeId = 0; for (let i = 0; i < depth; i++) { const t = stack[i]; - if (t.flags & 2097152 /* Intersection */ ? some(t.types, (u) => getRecursionIdentity(u) === identity2) : getRecursionIdentity(t) === identity2) { + if (hasMatchingRecursionIdentity(t, identity2)) { if (t.id >= lastTypeId) { count++; if (count >= maxDepth) { @@ -163433,9 +147157,25 @@ ${lanes.join("\n")} } return false; } + function getMappedTargetWithSymbol(type) { + let target; + while ((getObjectFlags(type) & 96 /* InstantiatedMapped */) === 96 /* InstantiatedMapped */ && (target = getModifiersTypeFromMappedType(type)) && (target.symbol || target.flags & 2097152 /* Intersection */ && some(target.types, (t) => !!t.symbol))) { + type = target; + } + return type; + } + function hasMatchingRecursionIdentity(type, identity2) { + if ((getObjectFlags(type) & 96 /* InstantiatedMapped */) === 96 /* InstantiatedMapped */) { + type = getMappedTargetWithSymbol(type); + } + if (type.flags & 2097152 /* Intersection */) { + return some(type.types, (t) => hasMatchingRecursionIdentity(t, identity2)); + } + return getRecursionIdentity(type) === identity2; + } function getRecursionIdentity(type) { if (type.flags & 524288 /* Object */ && !isObjectOrArrayLiteralType(type)) { - if (getObjectFlags(type) && 4 /* Reference */ && type.node) { + if (getObjectFlags(type) & 4 /* Reference */ && type.node) { return type.node; } if (type.symbol && !(getObjectFlags(type) & 16 /* Anonymous */ && type.symbol.flags & 32 /* Class */)) { @@ -163466,8 +147206,8 @@ ${lanes.join("\n")} if (sourceProp === targetProp) { return -1 /* True */; } - const sourcePropAccessibility = getDeclarationModifierFlagsFromSymbol(sourceProp) & 24 /* NonPublicAccessibilityModifier */; - const targetPropAccessibility = getDeclarationModifierFlagsFromSymbol(targetProp) & 24 /* NonPublicAccessibilityModifier */; + const sourcePropAccessibility = getDeclarationModifierFlagsFromSymbol(sourceProp) & 6 /* NonPublicAccessibilityModifier */; + const targetPropAccessibility = getDeclarationModifierFlagsFromSymbol(targetProp) & 6 /* NonPublicAccessibilityModifier */; if (sourcePropAccessibility !== targetPropAccessibility) { return 0 /* False */; } @@ -163605,6 +147345,9 @@ ${lanes.join("\n")} function isArrayLikeType(type) { return isArrayType(type) || !(type.flags & 98304 /* Nullable */) && isTypeAssignableTo(type, anyReadonlyArrayType); } + function isMutableArrayLikeType(type) { + return isMutableArrayOrTuple(type) || !(type.flags & (1 /* Any */ | 98304 /* Nullable */)) && isTypeAssignableTo(type, anyArrayType); + } function getSingleBaseForNonAugmentingSubtype(type) { if (!(getObjectFlags(type) & 4 /* Reference */) || !(getObjectFlags(type.target) & 3 /* ClassOrInterface */)) { return void 0; @@ -163616,7 +147359,7 @@ ${lanes.join("\n")} const target = type.target; if (getObjectFlags(target) & 1 /* Class */) { const baseTypeNode = getBaseTypeNodeOfClass(target); - if (baseTypeNode && baseTypeNode.expression.kind !== 80 /* Identifier */ && baseTypeNode.expression.kind !== 210 /* PropertyAccessExpression */) { + if (baseTypeNode && baseTypeNode.expression.kind !== 80 /* Identifier */ && baseTypeNode.expression.kind !== 211 /* PropertyAccessExpression */) { return void 0; } } @@ -163642,7 +147385,8 @@ ${lanes.join("\n")} return !!elementType && isEmptyLiteralType(elementType); } function isTupleLikeType(type) { - return isTupleType(type) || !!getPropertyOfType(type, "0"); + let lengthType; + return isTupleType(type) || !!getPropertyOfType(type, "0") || isArrayLikeType(type) && !!(lengthType = getTypeOfPropertyOfType(type, "length")) && everyType(lengthType, (t) => !!(t.flags & 256 /* NumberLiteral */)); } function isArrayOrTupleLikeType(type) { return isArrayLikeType(type) || isTupleLikeType(type); @@ -163653,17 +147397,7 @@ ${lanes.join("\n")} return propType; } if (everyType(type, isTupleType)) { - return mapType(type, (t) => { - const tupleType = t; - const restType = getRestTypeOfTupleType(tupleType); - if (!restType) { - return undefinedType; - } - if (compilerOptions.noUncheckedIndexedAccess && index >= tupleType.target.fixedLength + getEndElementCount(tupleType.target, 3 /* Fixed */)) { - return getUnionType([restType, undefinedType]); - } - return restType; - }); + return getTupleElementTypeOutOfStartCount(type, index, compilerOptions.noUncheckedIndexedAccess ? undefinedType : void 0); } return void 0; } @@ -163731,6 +147465,19 @@ ${lanes.join("\n")} function getRestTypeOfTupleType(type) { return getElementTypeOfSliceOfTupleType(type, type.target.fixedLength); } + function getTupleElementTypeOutOfStartCount(type, index, undefinedOrMissingType2) { + return mapType(type, (t) => { + const tupleType = t; + const restType = getRestTypeOfTupleType(tupleType); + if (!restType) { + return undefinedType; + } + if (undefinedOrMissingType2 && index >= getTotalFixedElementCount(tupleType.target)) { + return getUnionType([restType, undefinedOrMissingType2]); + } + return restType; + }); + } function getRestArrayTypeOfTupleType(type) { const restType = getRestTypeOfTupleType(type); return restType && createArrayType(restType); @@ -163755,7 +147502,7 @@ ${lanes.join("\n")} return value.base10Value === "0"; } function removeDefinitelyFalsyTypes(type) { - return filterType(type, (t) => !!(getTypeFacts(t) & 4194304 /* Truthy */)); + return filterType(type, (t) => hasTypeFacts(t, 4194304 /* Truthy */)); } function extractDefinitelyFalsyTypes(type) { return mapType(type, getDefinitelyFalsyPartOfType); @@ -163924,13 +147671,7 @@ ${lanes.join("\n")} } } } - const result = createAnonymousType( - type.symbol, - members, - emptyArray, - emptyArray, - sameMap(getIndexInfosOfType(type), (info) => createIndexInfo(info.keyType, getWidenedType(info.type), info.isReadonly)) - ); + const result = createAnonymousType(type.symbol, members, emptyArray, emptyArray, sameMap(getIndexInfosOfType(type), (info) => createIndexInfo(info.keyType, getWidenedType(info.type), info.isReadonly))); result.objectFlags |= getObjectFlags(type) & (4096 /* JSLiteral */ | 262144 /* NonInferrableType */); return result; } @@ -163999,7 +147740,7 @@ ${lanes.join("\n")} const t = getTypeOfSymbol(p); if (getObjectFlags(t) & 65536 /* ContainsWideningType */) { if (!reportWideningErrorsInType(t)) { - error(p.valueDeclaration, Diagnostics.Object_literal_s_property_0_implicitly_has_an_1_type, symbolToString(p), typeToString(getWidenedType(t))); + error2(p.valueDeclaration, Diagnostics.Object_literal_s_property_0_implicitly_has_an_1_type, symbolToString(p), typeToString(getWidenedType(t))); } errorReported = true; } @@ -164015,16 +147756,16 @@ ${lanes.join("\n")} } let diagnostic; switch (declaration.kind) { - case 225 /* BinaryExpression */: - case 171 /* PropertyDeclaration */: - case 170 /* PropertySignature */: + case 226 /* BinaryExpression */: + case 172 /* PropertyDeclaration */: + case 171 /* PropertySignature */: diagnostic = noImplicitAny ? Diagnostics.Member_0_implicitly_has_an_1_type : Diagnostics.Member_0_implicitly_has_an_1_type_but_a_better_type_may_be_inferred_from_usage; break; - case 168 /* Parameter */: + case 169 /* Parameter */: const param = declaration; if (isIdentifier(param.name)) { const originalKeywordKind = identifierToKeywordKind(param.name); - if ((isCallSignatureDeclaration(param.parent) || isMethodSignature(param.parent) || isFunctionTypeNode(param.parent)) && param.parent.parameters.indexOf(param) > -1 && (resolveName( + if ((isCallSignatureDeclaration(param.parent) || isMethodSignature(param.parent) || isFunctionTypeNode(param.parent)) && param.parent.parameters.includes(param) && (resolveName( param, param.name.escapedText, 788968 /* Type */, @@ -164042,40 +147783,40 @@ ${lanes.join("\n")} } diagnostic = declaration.dotDotDotToken ? noImplicitAny ? Diagnostics.Rest_parameter_0_implicitly_has_an_any_type : Diagnostics.Rest_parameter_0_implicitly_has_an_any_type_but_a_better_type_may_be_inferred_from_usage : noImplicitAny ? Diagnostics.Parameter_0_implicitly_has_an_1_type : Diagnostics.Parameter_0_implicitly_has_an_1_type_but_a_better_type_may_be_inferred_from_usage; break; - case 207 /* BindingElement */: + case 208 /* BindingElement */: diagnostic = Diagnostics.Binding_element_0_implicitly_has_an_1_type; if (!noImplicitAny) { return; } break; - case 323 /* JSDocFunctionType */: - error(declaration, Diagnostics.Function_type_which_lacks_return_type_annotation_implicitly_has_an_0_return_type, typeAsString); + case 324 /* JSDocFunctionType */: + error2(declaration, Diagnostics.Function_type_which_lacks_return_type_annotation_implicitly_has_an_0_return_type, typeAsString); return; - case 329 /* JSDocSignature */: + case 330 /* JSDocSignature */: if (noImplicitAny && isJSDocOverloadTag(declaration.parent)) { - error(declaration.parent.tagName, Diagnostics.This_overload_implicitly_returns_the_type_0_because_it_lacks_a_return_type_annotation, typeAsString); + error2(declaration.parent.tagName, Diagnostics.This_overload_implicitly_returns_the_type_0_because_it_lacks_a_return_type_annotation, typeAsString); } return; - case 261 /* FunctionDeclaration */: - case 173 /* MethodDeclaration */: - case 172 /* MethodSignature */: - case 176 /* GetAccessor */: - case 177 /* SetAccessor */: - case 217 /* FunctionExpression */: - case 218 /* ArrowFunction */: + case 262 /* FunctionDeclaration */: + case 174 /* MethodDeclaration */: + case 173 /* MethodSignature */: + case 177 /* GetAccessor */: + case 178 /* SetAccessor */: + case 218 /* FunctionExpression */: + case 219 /* ArrowFunction */: if (noImplicitAny && !declaration.name) { if (wideningKind === 3 /* GeneratorYield */) { - error(declaration, Diagnostics.Generator_implicitly_has_yield_type_0_because_it_does_not_yield_any_values_Consider_supplying_a_return_type_annotation, typeAsString); + error2(declaration, Diagnostics.Generator_implicitly_has_yield_type_0_because_it_does_not_yield_any_values_Consider_supplying_a_return_type_annotation, typeAsString); } else { - error(declaration, Diagnostics.Function_expression_which_lacks_return_type_annotation_implicitly_has_an_0_return_type, typeAsString); + error2(declaration, Diagnostics.Function_expression_which_lacks_return_type_annotation_implicitly_has_an_0_return_type, typeAsString); } return; } diagnostic = !noImplicitAny ? Diagnostics._0_implicitly_has_an_1_return_type_but_a_better_type_may_be_inferred_from_usage : wideningKind === 3 /* GeneratorYield */ ? Diagnostics._0_which_lacks_return_type_annotation_implicitly_has_an_1_yield_type : Diagnostics._0_which_lacks_return_type_annotation_implicitly_has_an_1_return_type; break; - case 199 /* MappedType */: + case 200 /* MappedType */: if (noImplicitAny) { - error(declaration, Diagnostics.Mapped_object_type_implicitly_has_an_any_template_type); + error2(declaration, Diagnostics.Mapped_object_type_implicitly_has_an_any_template_type); } return; default: @@ -164110,7 +147851,12 @@ ${lanes.join("\n")} callback(getTypeAtPosition(source, i), getTypeAtPosition(target, i)); } if (targetRestType) { - callback(getRestTypeAtPosition(source, paramCount), targetRestType); + callback(getRestTypeAtPosition( + source, + paramCount, + /*readonly*/ + isConstTypeVariable(targetRestType) && !someType(targetRestType, isMutableArrayLikeType) + ), targetRestType); } } function applyToReturnTypes(source, target, callback) { @@ -164143,19 +147889,25 @@ ${lanes.join("\n")} return context; } function makeFixingMapperForContext(context) { - return makeDeferredTypeMapper(map(context.inferences, (i) => i.typeParameter), map(context.inferences, (inference, i) => () => { - if (!inference.isFixed) { - inferFromIntraExpressionSites(context); - clearCachedInferences(context.inferences); - inference.isFixed = true; - } - return getInferredType(context, i); - })); + return makeDeferredTypeMapper( + map(context.inferences, (i) => i.typeParameter), + map(context.inferences, (inference, i) => () => { + if (!inference.isFixed) { + inferFromIntraExpressionSites(context); + clearCachedInferences(context.inferences); + inference.isFixed = true; + } + return getInferredType(context, i); + }) + ); } function makeNonFixingMapperForContext(context) { - return makeDeferredTypeMapper(map(context.inferences, (i) => i.typeParameter), map(context.inferences, (_, i) => () => { - return getInferredType(context, i); - })); + return makeDeferredTypeMapper( + map(context.inferences, (i) => i.typeParameter), + map(context.inferences, (_, i) => () => { + return getInferredType(context, i); + }) + ); } function clearCachedInferences(inferences) { for (const inference of inferences) { @@ -164170,7 +147922,7 @@ ${lanes.join("\n")} function inferFromIntraExpressionSites(context) { if (context.intraExpressionInferenceSites) { for (const { node, type } of context.intraExpressionInferenceSites) { - const contextualType = node.kind === 173 /* MethodDeclaration */ ? getContextualTypeForObjectLiteralMethod(node, 2 /* NoConstraints */) : getContextualType2(node, 2 /* NoConstraints */); + const contextualType = node.kind === 174 /* MethodDeclaration */ ? getContextualTypeForObjectLiteralMethod(node, 2 /* NoConstraints */) : getContextualType2(node, 2 /* NoConstraints */); if (contextualType) { inferTypes(context.inferences, type, contextualType); } @@ -164214,16 +147966,16 @@ ${lanes.join("\n")} if (objectFlags & 524288 /* CouldContainTypeVariablesComputed */) { return !!(objectFlags & 1048576 /* CouldContainTypeVariables */); } - const result = !!(type.flags & 465829888 /* Instantiable */ || type.flags & 524288 /* Object */ && !isNonGenericTopLevelType(type) && (objectFlags & 4 /* Reference */ && (type.node || some(getTypeArguments(type), couldContainTypeVariables)) || objectFlags & 16 /* Anonymous */ && type.symbol && type.symbol.flags & (16 /* Function */ | 8192 /* Method */ | 32 /* Class */ | 2048 /* TypeLiteral */ | 4096 /* ObjectLiteral */) && type.symbol.declarations || objectFlags & (32 /* Mapped */ | 1024 /* ReverseMapped */ | 4194304 /* ObjectRestType */ | 8388608 /* InstantiationExpressionType */)) || type.flags & (3145728 /* UnionOrIntersection */ | 134217728 /* TemplateLiteral */) && !(type.flags & 1024 /* EnumLiteral */) && !isNonGenericTopLevelType(type) && some(type.types, couldContainTypeVariables)); - if (type.flags & 138117121 /* ObjectFlagsType */) { + const result = !!(type.flags & 465829888 /* Instantiable */ || type.flags & 524288 /* Object */ && !isNonGenericTopLevelType(type) && (objectFlags & 4 /* Reference */ && (type.node || some(getTypeArguments(type), couldContainTypeVariables)) || objectFlags & 16 /* Anonymous */ && type.symbol && type.symbol.flags & (16 /* Function */ | 8192 /* Method */ | 32 /* Class */ | 2048 /* TypeLiteral */ | 4096 /* ObjectLiteral */) && type.symbol.declarations || objectFlags & (32 /* Mapped */ | 1024 /* ReverseMapped */ | 4194304 /* ObjectRestType */ | 8388608 /* InstantiationExpressionType */)) || type.flags & 3145728 /* UnionOrIntersection */ && !(type.flags & 1024 /* EnumLiteral */) && !isNonGenericTopLevelType(type) && some(type.types, couldContainTypeVariables)); + if (type.flags & 3899393 /* ObjectFlagsType */) { type.objectFlags |= 524288 /* CouldContainTypeVariablesComputed */ | (result ? 1048576 /* CouldContainTypeVariables */ : 0); } return result; } function isNonGenericTopLevelType(type) { if (type.aliasSymbol && !type.aliasTypeArguments) { - const declaration = getDeclarationOfKind(type.aliasSymbol, 264 /* TypeAliasDeclaration */); - return !!(declaration && findAncestor(declaration.parent, (n) => n.kind === 311 /* SourceFile */ ? true : n.kind === 266 /* ModuleDeclaration */ ? false : "quit")); + const declaration = getDeclarationOfKind(type.aliasSymbol, 265 /* TypeAliasDeclaration */); + return !!(declaration && findAncestor(declaration.parent, (n) => n.kind === 312 /* SourceFile */ ? true : n.kind === 267 /* ModuleDeclaration */ ? false : "quit")); } return false; } @@ -164265,17 +148017,18 @@ ${lanes.join("\n")} ); } function inferTypeForHomomorphicMappedType(source, target, constraint) { - if (inInferTypeForHomomorphicMappedType) { - return void 0; + const cacheKey = source.id + "," + target.id + "," + constraint.id; + if (reverseMappedCache.has(cacheKey)) { + return reverseMappedCache.get(cacheKey); } - const key = source.id + "," + target.id + "," + constraint.id; - if (reverseMappedCache.has(key)) { - return reverseMappedCache.get(key); + const recursionKey = source.id + "," + (target.target || target).id; + if (contains(homomorphicMappedTypeInferenceStack, recursionKey)) { + return void 0; } - inInferTypeForHomomorphicMappedType = true; + homomorphicMappedTypeInferenceStack.push(recursionKey); const type = createReverseMappedType(source, target, constraint); - inInferTypeForHomomorphicMappedType = false; - reverseMappedCache.set(key, type); + homomorphicMappedTypeInferenceStack.pop(); + reverseMappedCache.set(cacheKey, type); return type; } function isPartiallyInferableType(type) { @@ -164411,6 +148164,9 @@ ${lanes.join("\n")} if (source === target || target.flags & (1 /* Any */ | 4 /* String */)) { return true; } + if (target.flags & 2097152 /* Intersection */) { + return every(target.types, (t) => t === emptyTypeLiteralType || isValidTypeForTemplateLiteralPlaceholder(source, t)); + } if (source.flags & 128 /* StringLiteral */) { const value = source.value; return !!(target.flags & 8 /* Number */ && isValidNumberString( @@ -164421,7 +148177,7 @@ ${lanes.join("\n")} value, /*roundTripOnly*/ false - ) || target.flags & (512 /* BooleanLiteral */ | 98304 /* Nullable */) && value === target.intrinsicName || target.flags & 268435456 /* StringMapping */ && isMemberOfStringMapping(getStringLiteralType(value), target)); + ) || target.flags & (512 /* BooleanLiteral */ | 98304 /* Nullable */) && value === target.intrinsicName || target.flags & 268435456 /* StringMapping */ && isMemberOfStringMapping(getStringLiteralType(value), target) || target.flags & 134217728 /* TemplateLiteral */ && isTypeMatchedByTemplateLiteralType(source, target)); } if (source.flags & 134217728 /* TemplateLiteral */) { const texts = source.texts; @@ -164496,7 +148252,6 @@ ${lanes.join("\n")} let bivariant = false; let propagationType; let inferencePriority = 2048 /* MaxValue */; - let allowComplexConstraintInference = true; let visited; let sourceStack; let targetStack; @@ -164506,7 +148261,7 @@ ${lanes.join("\n")} if (!couldContainTypeVariables(target)) { return; } - if (source === wildcardType) { + if (source === wildcardType || source === blockedStringType) { const savePropagationType = propagationType; propagationType = source; inferFromTypes(target, target); @@ -164563,6 +148318,10 @@ ${lanes.join("\n")} return; } if (!inference.isFixed) { + const candidate = propagationType || source; + if (candidate === blockedStringType) { + return; + } if (inference.priority === void 0 || priority < inference.priority) { inference.candidates = void 0; inference.contraCandidates = void 0; @@ -164570,7 +148329,6 @@ ${lanes.join("\n")} inference.priority = priority; } if (priority === inference.priority) { - const candidate = propagationType || source; if (contravariant && !bivariant) { if (!contains(inference.contraCandidates, candidate)) { inference.contraCandidates = append(inference.contraCandidates, candidate); @@ -164651,8 +148409,7 @@ ${lanes.join("\n")} source = getReducedType(source); if (!(priority & 512 /* NoConstraints */ && source.flags & (2097152 /* Intersection */ | 465829888 /* Instantiable */))) { const apparentSource = getApparentType(source); - if (apparentSource !== source && allowComplexConstraintInference && !(apparentSource.flags & (524288 /* Object */ | 2097152 /* Intersection */))) { - allowComplexConstraintInference = false; + if (apparentSource !== source && !(apparentSource.flags & (524288 /* Object */ | 2097152 /* Intersection */))) { return inferFromTypes(apparentSource, target); } source = apparentSource; @@ -164901,11 +148658,7 @@ ${lanes.join("\n")} )) { allTypeFlags &= ~2112 /* BigIntLike */; } - const matchingType = reduceLeft( - constraintTypes, - (left, right) => !(right.flags & allTypeFlags) ? left : left.flags & 4 /* String */ ? left : right.flags & 4 /* String */ ? source2 : left.flags & 134217728 /* TemplateLiteral */ ? left : right.flags & 134217728 /* TemplateLiteral */ && isTypeMatchedByTemplateLiteralType(source2, right) ? source2 : left.flags & 268435456 /* StringMapping */ ? left : right.flags & 268435456 /* StringMapping */ && str === applyStringMapping(right.symbol, str) ? source2 : left.flags & 128 /* StringLiteral */ ? left : right.flags & 128 /* StringLiteral */ && right.value === str ? right : left.flags & 8 /* Number */ ? left : right.flags & 8 /* Number */ ? getNumberLiteralType(+str) : left.flags & 32 /* Enum */ ? left : right.flags & 32 /* Enum */ ? getNumberLiteralType(+str) : left.flags & 256 /* NumberLiteral */ ? left : right.flags & 256 /* NumberLiteral */ && right.value === +str ? right : left.flags & 64 /* BigInt */ ? left : right.flags & 64 /* BigInt */ ? parseBigIntLiteralType(str) : left.flags & 2048 /* BigIntLiteral */ ? left : right.flags & 2048 /* BigIntLiteral */ && pseudoBigIntToString(right.value) === str ? right : left.flags & 16 /* Boolean */ ? left : right.flags & 16 /* Boolean */ ? str === "true" ? trueType : str === "false" ? falseType : booleanType : left.flags & 512 /* BooleanLiteral */ ? left : right.flags & 512 /* BooleanLiteral */ && right.intrinsicName === str ? right : left.flags & 32768 /* Undefined */ ? left : right.flags & 32768 /* Undefined */ && right.intrinsicName === str ? right : left.flags & 65536 /* Null */ ? left : right.flags & 65536 /* Null */ && right.intrinsicName === str ? right : left, - neverType - ); + const matchingType = reduceLeft(constraintTypes, (left, right) => !(right.flags & allTypeFlags) ? left : left.flags & 4 /* String */ ? left : right.flags & 4 /* String */ ? source2 : left.flags & 134217728 /* TemplateLiteral */ ? left : right.flags & 134217728 /* TemplateLiteral */ && isTypeMatchedByTemplateLiteralType(source2, right) ? source2 : left.flags & 268435456 /* StringMapping */ ? left : right.flags & 268435456 /* StringMapping */ && str === applyStringMapping(right.symbol, str) ? source2 : left.flags & 128 /* StringLiteral */ ? left : right.flags & 128 /* StringLiteral */ && right.value === str ? right : left.flags & 8 /* Number */ ? left : right.flags & 8 /* Number */ ? getNumberLiteralType(+str) : left.flags & 32 /* Enum */ ? left : right.flags & 32 /* Enum */ ? getNumberLiteralType(+str) : left.flags & 256 /* NumberLiteral */ ? left : right.flags & 256 /* NumberLiteral */ && right.value === +str ? right : left.flags & 64 /* BigInt */ ? left : right.flags & 64 /* BigInt */ ? parseBigIntLiteralType(str) : left.flags & 2048 /* BigIntLiteral */ ? left : right.flags & 2048 /* BigIntLiteral */ && pseudoBigIntToString(right.value) === str ? right : left.flags & 16 /* Boolean */ ? left : right.flags & 16 /* Boolean */ ? str === "true" ? trueType : str === "false" ? falseType : booleanType : left.flags & 512 /* BooleanLiteral */ ? left : right.flags & 512 /* BooleanLiteral */ && right.intrinsicName === str ? right : left.flags & 32768 /* Undefined */ ? left : right.flags & 32768 /* Undefined */ && right.intrinsicName === str ? right : left.flags & 65536 /* Null */ ? left : right.flags & 65536 /* Null */ && right.intrinsicName === str ? right : left, neverType); if (!(matchingType.flags & 131072 /* Never */)) { inferFromTypes(matchingType, target2); continue; @@ -164951,10 +148704,7 @@ ${lanes.join("\n")} return; } const startLength = isTupleType(source) ? Math.min(source.target.fixedLength, target.target.fixedLength) : 0; - const endLength = Math.min( - isTupleType(source) ? getEndElementCount(source.target, 3 /* Fixed */) : 0, - target.target.hasRestElement ? getEndElementCount(target.target, 3 /* Fixed */) : 0 - ); + const endLength = Math.min(isTupleType(source) ? getEndElementCount(source.target, 3 /* Fixed */) : 0, target.target.hasRestElement ? getEndElementCount(target.target, 3 /* Fixed */) : 0); for (let i = 0; i < startLength; i++) { inferFromTypes(getTypeArguments(source)[i], elementTypes[i]); } @@ -165036,19 +148786,21 @@ ${lanes.join("\n")} } function inferFromSignatures(source, target, kind) { const sourceSignatures = getSignaturesOfType(source, kind); - const targetSignatures = getSignaturesOfType(target, kind); const sourceLen = sourceSignatures.length; - const targetLen = targetSignatures.length; - const len = sourceLen < targetLen ? sourceLen : targetLen; - for (let i = 0; i < len; i++) { - inferFromSignature(getBaseSignature(sourceSignatures[sourceLen - len + i]), getErasedSignature(targetSignatures[targetLen - len + i])); + if (sourceLen > 0) { + const targetSignatures = getSignaturesOfType(target, kind); + const targetLen = targetSignatures.length; + for (let i = 0; i < targetLen; i++) { + const sourceIndex = Math.max(sourceLen - targetLen + i, 0); + inferFromSignature(getBaseSignature(sourceSignatures[sourceIndex]), getErasedSignature(targetSignatures[i])); + } } } function inferFromSignature(source, target) { if (!(source.flags & 64 /* IsNonInferrable */)) { const saveBivariant = bivariant; const kind = target.declaration ? target.declaration.kind : 0 /* Unknown */; - bivariant = bivariant || kind === 173 /* MethodDeclaration */ || kind === 172 /* MethodSignature */ || kind === 175 /* Constructor */; + bivariant = bivariant || kind === 174 /* MethodDeclaration */ || kind === 173 /* MethodSignature */ || kind === 176 /* Constructor */; applyToParameterTypes(source, target, inferFromContravariantTypesIfStrictFunctionTypes); bivariant = saveBivariant; } @@ -165206,7 +148958,7 @@ ${lanes.join("\n")} return Diagnostics.Cannot_find_name_0_Did_you_mean_to_write_this_in_an_async_function; } default: - if (node.parent.kind === 303 /* ShorthandPropertyAssignment */) { + if (node.parent.kind === 304 /* ShorthandPropertyAssignment */) { return Diagnostics.No_value_exists_in_scope_for_the_shorthand_property_0_Either_declare_one_or_provide_an_initializer; } else { return Diagnostics.Cannot_find_name_0; @@ -165229,14 +148981,8 @@ ${lanes.join("\n")} } return links.resolvedSymbol; } - function isInTypeQuery(node) { - return !!findAncestor( - node, - (n) => n.kind === 185 /* TypeQuery */ ? true : n.kind === 80 /* Identifier */ || n.kind === 165 /* QualifiedName */ ? false : "quit" - ); - } function isInAmbientOrTypeNode(node) { - return !!(node.flags & 16777216 /* Ambient */ || findAncestor(node, (n) => isInterfaceDeclaration(n) || isTypeAliasDeclaration(n) || isTypeLiteralNode(n))); + return !!(node.flags & 33554432 /* Ambient */ || findAncestor(node, (n) => isInterfaceDeclaration(n) || isTypeAliasDeclaration(n) || isTypeLiteralNode(n))); } function getFlowCacheKey(node, declaredType, initialType, flowContainer) { switch (node.kind) { @@ -165247,41 +148993,41 @@ ${lanes.join("\n")} } case 110 /* ThisKeyword */: return `0|${flowContainer ? getNodeId(flowContainer) : "-1"}|${getTypeId(declaredType)}|${getTypeId(initialType)}`; - case 234 /* NonNullExpression */: - case 216 /* ParenthesizedExpression */: + case 235 /* NonNullExpression */: + case 217 /* ParenthesizedExpression */: return getFlowCacheKey(node.expression, declaredType, initialType, flowContainer); - case 165 /* QualifiedName */: + case 166 /* QualifiedName */: const left = getFlowCacheKey(node.left, declaredType, initialType, flowContainer); return left && left + "." + node.right.escapedText; - case 210 /* PropertyAccessExpression */: - case 211 /* ElementAccessExpression */: + case 211 /* PropertyAccessExpression */: + case 212 /* ElementAccessExpression */: const propName = getAccessedPropertyName(node); if (propName !== void 0) { const key = getFlowCacheKey(node.expression, declaredType, initialType, flowContainer); return key && key + "." + propName; } break; - case 205 /* ObjectBindingPattern */: - case 206 /* ArrayBindingPattern */: - case 261 /* FunctionDeclaration */: - case 217 /* FunctionExpression */: - case 218 /* ArrowFunction */: - case 173 /* MethodDeclaration */: + case 206 /* ObjectBindingPattern */: + case 207 /* ArrayBindingPattern */: + case 262 /* FunctionDeclaration */: + case 218 /* FunctionExpression */: + case 219 /* ArrowFunction */: + case 174 /* MethodDeclaration */: return `${getNodeId(node)}#${getTypeId(declaredType)}`; } return void 0; } function isMatchingReference(source, target) { switch (target.kind) { - case 216 /* ParenthesizedExpression */: - case 234 /* NonNullExpression */: + case 217 /* ParenthesizedExpression */: + case 235 /* NonNullExpression */: return isMatchingReference(source, target.expression); - case 225 /* BinaryExpression */: + case 226 /* BinaryExpression */: return isAssignmentExpression(target) && isMatchingReference(source, target.left) || isBinaryExpression(target) && target.operatorToken.kind === 28 /* CommaToken */ && isMatchingReference(source, target.right); } switch (source.kind) { - case 235 /* MetaProperty */: - return target.kind === 235 /* MetaProperty */ && source.keywordToken === target.keywordToken && source.name.escapedText === target.name.escapedText; + case 236 /* MetaProperty */: + return target.kind === 236 /* MetaProperty */ && source.keywordToken === target.keywordToken && source.name.escapedText === target.name.escapedText; case 80 /* Identifier */: case 81 /* PrivateIdentifier */: return isThisInTypeQuery(source) ? target.kind === 110 /* ThisKeyword */ : target.kind === 80 /* Identifier */ && getResolvedSymbol(source) === getResolvedSymbol(target) || (isVariableDeclaration(target) || isBindingElement(target)) && getExportSymbolOfValueSymbolIfExported(getResolvedSymbol(source)) === getSymbolOfDeclaration(target); @@ -165289,17 +149035,17 @@ ${lanes.join("\n")} return target.kind === 110 /* ThisKeyword */; case 108 /* SuperKeyword */: return target.kind === 108 /* SuperKeyword */; - case 234 /* NonNullExpression */: - case 216 /* ParenthesizedExpression */: + case 235 /* NonNullExpression */: + case 217 /* ParenthesizedExpression */: return isMatchingReference(source.expression, target); - case 210 /* PropertyAccessExpression */: - case 211 /* ElementAccessExpression */: + case 211 /* PropertyAccessExpression */: + case 212 /* ElementAccessExpression */: const sourcePropertyName = getAccessedPropertyName(source); const targetPropertyName = isAccessExpression(target) ? getAccessedPropertyName(target) : void 0; return sourcePropertyName !== void 0 && targetPropertyName !== void 0 && targetPropertyName === sourcePropertyName && isMatchingReference(source.expression, target.expression); - case 165 /* QualifiedName */: + case 166 /* QualifiedName */: return isAccessExpression(target) && source.right.escapedText === getAccessedPropertyName(target) && isMatchingReference(source.left, target.expression); - case 225 /* BinaryExpression */: + case 226 /* BinaryExpression */: return isBinaryExpression(source) && source.operatorToken.kind === 28 /* CommaToken */ && isMatchingReference(source.right, target); } return false; @@ -165333,7 +149079,7 @@ ${lanes.join("\n")} /*ignoreErrors*/ true ); - if (!symbol || !(isConstVariable(symbol) || symbol.flags & 8 /* EnumMember */)) + if (!symbol || !(isConstantVariable(symbol) || symbol.flags & 8 /* EnumMember */)) return void 0; const declaration = symbol.valueDeclaration; if (declaration === void 0) @@ -165452,7 +149198,7 @@ ${lanes.join("\n")} } function getMatchingUnionConstituentForObjectLiteral(unionType, node) { const keyPropertyName = getKeyPropertyName(unionType); - const propNode = keyPropertyName && find(node.properties, (p) => p.symbol && p.kind === 302 /* PropertyAssignment */ && p.symbol.escapedName === keyPropertyName && isPossiblyDiscriminantValue(p.initializer)); + const propNode = keyPropertyName && find(node.properties, (p) => p.symbol && p.kind === 303 /* PropertyAssignment */ && p.symbol.escapedName === keyPropertyName && isPossiblyDiscriminantValue(p.initializer)); const propType = propNode && getContextFreeTypeOfExpression(propNode.initializer); return propType && getConstituentTypeForKeyType(unionType, propType); } @@ -165462,12 +149208,12 @@ ${lanes.join("\n")} function hasMatchingArgument(expression, reference) { if (expression.arguments) { for (const argument of expression.arguments) { - if (isOrContainsMatchingReference(reference, argument)) { + if (isOrContainsMatchingReference(reference, argument) || optionalChainContainsReference(argument, reference)) { return true; } } } - if (expression.expression.kind === 210 /* PropertyAccessExpression */ && isOrContainsMatchingReference(reference, expression.expression.expression)) { + if (expression.expression.kind === 211 /* PropertyAccessExpression */ && isOrContainsMatchingReference(reference, expression.expression.expression)) { return true; } return false; @@ -165509,7 +149255,13 @@ ${lanes.join("\n")} const resolved = resolveStructuredTypeMembers(type); return !!(resolved.callSignatures.length || resolved.constructSignatures.length || resolved.members.get("bind") && isTypeSubtypeOf(type, globalFunctionType)); } - function getTypeFacts(type) { + function getTypeFacts(type, mask2) { + return getTypeFactsWorker(type, mask2) & mask2; + } + function hasTypeFacts(type, mask2) { + return getTypeFacts(type, mask2) !== 0; + } + function getTypeFactsWorker(type, callerOnlyNeeds) { if (type.flags & (2097152 /* Intersection */ | 465829888 /* Instantiable */)) { type = getBaseConstraintOfType(type) || unknownType; } @@ -165542,6 +149294,10 @@ ${lanes.join("\n")} return strictNullChecks ? type === falseType || type === regularFalseType ? 12121864 /* FalseStrictFacts */ : 7927560 /* TrueStrictFacts */ : type === falseType || type === regularFalseType ? 12580616 /* FalseFacts */ : 16774920 /* TrueFacts */; } if (flags & 524288 /* Object */) { + const possibleFacts = strictNullChecks ? 83427327 /* EmptyObjectStrictFacts */ | 7880640 /* FunctionStrictFacts */ | 7888800 /* ObjectStrictFacts */ : 83886079 /* EmptyObjectFacts */ | 16728e3 /* FunctionFacts */ | 16736160 /* ObjectFacts */; + if ((callerOnlyNeeds & possibleFacts) === 0) { + return 0; + } return getObjectFlags(type) & 16 /* Anonymous */ && isEmptyObjectType(type) ? strictNullChecks ? 83427327 /* EmptyObjectStrictFacts */ : 83886079 /* EmptyObjectFacts */ : isFunctionObjectType(type) ? strictNullChecks ? 7880640 /* FunctionStrictFacts */ : 16728e3 /* FunctionFacts */ : strictNullChecks ? 7888800 /* ObjectStrictFacts */ : 16736160 /* ObjectFacts */; } if (flags & 16384 /* Void */) { @@ -165563,20 +149319,20 @@ ${lanes.join("\n")} return 0 /* None */; } if (flags & 1048576 /* Union */) { - return reduceLeft(type.types, (facts, t) => facts | getTypeFacts(t), 0 /* None */); + return reduceLeft(type.types, (facts, t) => facts | getTypeFactsWorker(t, callerOnlyNeeds), 0 /* None */); } if (flags & 2097152 /* Intersection */) { - return getIntersectionTypeFacts(type); + return getIntersectionTypeFacts(type, callerOnlyNeeds); } return 83886079 /* UnknownFacts */; } - function getIntersectionTypeFacts(type) { + function getIntersectionTypeFacts(type, callerOnlyNeeds) { const ignoreObjects = maybeTypeOfKind(type, 402784252 /* Primitive */); let oredFacts = 0 /* None */; let andedFacts = 134217727 /* All */; for (const t of type.types) { if (!(ignoreObjects && t.flags & 524288 /* Object */)) { - const f = getTypeFacts(t); + const f = getTypeFactsWorker(t, callerOnlyNeeds); oredFacts |= f; andedFacts &= f; } @@ -165584,19 +149340,19 @@ ${lanes.join("\n")} return oredFacts & 8256 /* OrFactsMask */ | andedFacts & 134209471 /* AndFactsMask */; } function getTypeWithFacts(type, include) { - return filterType(type, (t) => (getTypeFacts(t) & include) !== 0); + return filterType(type, (t) => hasTypeFacts(t, include)); } function getAdjustedTypeWithFacts(type, facts) { const reduced = recombineUnknownType(getTypeWithFacts(strictNullChecks && type.flags & 2 /* Unknown */ ? unknownUnionType : type, facts)); if (strictNullChecks) { switch (facts) { case 524288 /* NEUndefined */: - return mapType(reduced, (t) => getTypeFacts(t) & 65536 /* EQUndefined */ ? getIntersectionType([t, getTypeFacts(t) & 131072 /* EQNull */ && !maybeTypeOfKind(reduced, 65536 /* Null */) ? getUnionType([emptyObjectType, nullType]) : emptyObjectType]) : t); + return mapType(reduced, (t) => hasTypeFacts(t, 65536 /* EQUndefined */) ? getIntersectionType([t, hasTypeFacts(t, 131072 /* EQNull */) && !maybeTypeOfKind(reduced, 65536 /* Null */) ? getUnionType([emptyObjectType, nullType]) : emptyObjectType]) : t); case 1048576 /* NENull */: - return mapType(reduced, (t) => getTypeFacts(t) & 131072 /* EQNull */ ? getIntersectionType([t, getTypeFacts(t) & 65536 /* EQUndefined */ && !maybeTypeOfKind(reduced, 32768 /* Undefined */) ? getUnionType([emptyObjectType, undefinedType]) : emptyObjectType]) : t); + return mapType(reduced, (t) => hasTypeFacts(t, 131072 /* EQNull */) ? getIntersectionType([t, hasTypeFacts(t, 65536 /* EQUndefined */) && !maybeTypeOfKind(reduced, 32768 /* Undefined */) ? getUnionType([emptyObjectType, undefinedType]) : emptyObjectType]) : t); case 2097152 /* NEUndefinedOrNull */: case 4194304 /* Truthy */: - return mapType(reduced, (t) => getTypeFacts(t) & 262144 /* EQUndefinedOrNull */ ? getGlobalNonNullableTypeInstantiation(t) : t); + return mapType(reduced, (t) => hasTypeFacts(t, 262144 /* EQUndefinedOrNull */) ? getGlobalNonNullableTypeInstantiation(t) : t); } } return reduced; @@ -165639,11 +149395,11 @@ ${lanes.join("\n")} ) || errorType); } function getAssignedTypeOfBinaryExpression(node) { - const isDestructuringDefaultAssignment = node.parent.kind === 208 /* ArrayLiteralExpression */ && isDestructuringAssignmentTarget(node.parent) || node.parent.kind === 302 /* PropertyAssignment */ && isDestructuringAssignmentTarget(node.parent.parent); + const isDestructuringDefaultAssignment = node.parent.kind === 209 /* ArrayLiteralExpression */ && isDestructuringAssignmentTarget(node.parent) || node.parent.kind === 303 /* PropertyAssignment */ && isDestructuringAssignmentTarget(node.parent.parent); return isDestructuringDefaultAssignment ? getTypeWithDefault(getAssignedType(node), node.right) : getTypeOfExpression(node.right); } function isDestructuringAssignmentTarget(parent2) { - return parent2.parent.kind === 225 /* BinaryExpression */ && parent2.parent.left === parent2 || parent2.parent.kind === 249 /* ForOfStatement */ && parent2.parent.initializer === parent2; + return parent2.parent.kind === 226 /* BinaryExpression */ && parent2.parent.left === parent2 || parent2.parent.kind === 250 /* ForOfStatement */ && parent2.parent.initializer === parent2; } function getAssignedTypeOfArrayLiteralElement(node, element) { return getTypeOfDestructuredArrayElement(getAssignedType(node), node.elements.indexOf(element)); @@ -165660,21 +149416,21 @@ ${lanes.join("\n")} function getAssignedType(node) { const { parent: parent2 } = node; switch (parent2.kind) { - case 248 /* ForInStatement */: + case 249 /* ForInStatement */: return stringType; - case 249 /* ForOfStatement */: + case 250 /* ForOfStatement */: return checkRightHandSideOfForOf(parent2) || errorType; - case 225 /* BinaryExpression */: + case 226 /* BinaryExpression */: return getAssignedTypeOfBinaryExpression(parent2); - case 219 /* DeleteExpression */: + case 220 /* DeleteExpression */: return undefinedType; - case 208 /* ArrayLiteralExpression */: + case 209 /* ArrayLiteralExpression */: return getAssignedTypeOfArrayLiteralElement(parent2, node); - case 229 /* SpreadElement */: + case 230 /* SpreadElement */: return getAssignedTypeOfSpreadExpression(parent2); - case 302 /* PropertyAssignment */: + case 303 /* PropertyAssignment */: return getAssignedTypeOfPropertyAssignment(parent2); - case 303 /* ShorthandPropertyAssignment */: + case 304 /* ShorthandPropertyAssignment */: return getAssignedTypeOfShorthandPropertyAssignment(parent2); } return errorType; @@ -165682,7 +149438,7 @@ ${lanes.join("\n")} function getInitialTypeOfBindingElement(node) { const pattern = node.parent; const parentType = getInitialType(pattern.parent); - const type = pattern.kind === 205 /* ObjectBindingPattern */ ? getTypeOfDestructuredProperty(parentType, node.propertyName || node.name) : !node.dotDotDotToken ? getTypeOfDestructuredArrayElement(parentType, pattern.elements.indexOf(node)) : getTypeOfDestructuredSpreadExpression(parentType); + const type = pattern.kind === 206 /* ObjectBindingPattern */ ? getTypeOfDestructuredProperty(parentType, node.propertyName || node.name) : !node.dotDotDotToken ? getTypeOfDestructuredArrayElement(parentType, pattern.elements.indexOf(node)) : getTypeOfDestructuredSpreadExpression(parentType); return getTypeWithDefault(type, node.initializer); } function getTypeOfInitializer(node) { @@ -165693,25 +149449,25 @@ ${lanes.join("\n")} if (node.initializer) { return getTypeOfInitializer(node.initializer); } - if (node.parent.parent.kind === 248 /* ForInStatement */) { + if (node.parent.parent.kind === 249 /* ForInStatement */) { return stringType; } - if (node.parent.parent.kind === 249 /* ForOfStatement */) { + if (node.parent.parent.kind === 250 /* ForOfStatement */) { return checkRightHandSideOfForOf(node.parent.parent) || errorType; } return errorType; } function getInitialType(node) { - return node.kind === 259 /* VariableDeclaration */ ? getInitialTypeOfVariableDeclaration(node) : getInitialTypeOfBindingElement(node); + return node.kind === 260 /* VariableDeclaration */ ? getInitialTypeOfVariableDeclaration(node) : getInitialTypeOfBindingElement(node); } function isEmptyArrayAssignment(node) { - return node.kind === 259 /* VariableDeclaration */ && node.initializer && isEmptyArrayLiteral2(node.initializer) || node.kind !== 207 /* BindingElement */ && node.parent.kind === 225 /* BinaryExpression */ && isEmptyArrayLiteral2(node.parent.right); + return node.kind === 260 /* VariableDeclaration */ && node.initializer && isEmptyArrayLiteral2(node.initializer) || node.kind !== 208 /* BindingElement */ && node.parent.kind === 226 /* BinaryExpression */ && isEmptyArrayLiteral2(node.parent.right); } function getReferenceCandidate(node) { switch (node.kind) { - case 216 /* ParenthesizedExpression */: + case 217 /* ParenthesizedExpression */: return getReferenceCandidate(node.expression); - case 225 /* BinaryExpression */: + case 226 /* BinaryExpression */: switch (node.operatorToken.kind) { case 64 /* EqualsToken */: case 76 /* BarBarEqualsToken */: @@ -165726,10 +149482,10 @@ ${lanes.join("\n")} } function getReferenceRoot(node) { const { parent: parent2 } = node; - return parent2.kind === 216 /* ParenthesizedExpression */ || parent2.kind === 225 /* BinaryExpression */ && parent2.operatorToken.kind === 64 /* EqualsToken */ && parent2.left === node || parent2.kind === 225 /* BinaryExpression */ && parent2.operatorToken.kind === 28 /* CommaToken */ && parent2.right === node ? getReferenceRoot(parent2) : node; + return parent2.kind === 217 /* ParenthesizedExpression */ || parent2.kind === 226 /* BinaryExpression */ && parent2.operatorToken.kind === 64 /* EqualsToken */ && parent2.left === node || parent2.kind === 226 /* BinaryExpression */ && parent2.operatorToken.kind === 28 /* CommaToken */ && parent2.right === node ? getReferenceRoot(parent2) : node; } function getTypeOfSwitchClause(clause) { - if (clause.kind === 295 /* CaseClause */) { + if (clause.kind === 296 /* CaseClause */) { return getRegularTypeOfLiteralType(getTypeOfExpression(clause.expression)); } return neverType; @@ -165745,12 +149501,12 @@ ${lanes.join("\n")} return links.switchTypes; } function getSwitchClauseTypeOfWitnesses(switchStatement) { - if (some(switchStatement.caseBlock.clauses, (clause) => clause.kind === 295 /* CaseClause */ && !isStringLiteralLike(clause.expression))) { + if (some(switchStatement.caseBlock.clauses, (clause) => clause.kind === 296 /* CaseClause */ && !isStringLiteralLike(clause.expression))) { return void 0; } const witnesses = []; for (const clause of switchStatement.caseBlock.clauses) { - const text = clause.kind === 295 /* CaseClause */ ? clause.expression.text : void 0; + const text = clause.kind === 296 /* CaseClause */ ? clause.expression.text : void 0; witnesses.push(text && !contains(witnesses, text) ? text : void 0); } return witnesses; @@ -165882,7 +149638,9 @@ ${lanes.join("\n")} return isTypeSubsetOf(elementType, evolvingArrayType.elementType) ? evolvingArrayType : getEvolvingArrayType(getUnionType([evolvingArrayType.elementType, elementType])); } function createFinalArrayType(elementType) { - return elementType.flags & 131072 /* Never */ ? autoArrayType : createArrayType(elementType.flags & 1048576 /* Union */ ? getUnionType(elementType.types, 2 /* Subtype */) : elementType); + return elementType.flags & 131072 /* Never */ ? autoArrayType : createArrayType( + elementType.flags & 1048576 /* Union */ ? getUnionType(elementType.types, 2 /* Subtype */) : elementType + ); } function getFinalArrayType(evolvingArrayType) { return evolvingArrayType.finalArrayType || (evolvingArrayType.finalArrayType = createFinalArrayType(evolvingArrayType.elementType)); @@ -165908,8 +149666,8 @@ ${lanes.join("\n")} function isEvolvingArrayOperationTarget(node) { const root = getReferenceRoot(node); const parent2 = root.parent; - const isLengthPushOrUnshift = isPropertyAccessExpression(parent2) && (parent2.name.escapedText === "length" || parent2.parent.kind === 212 /* CallExpression */ && isIdentifier(parent2.name) && isPushOrUnshiftIdentifier(parent2.name)); - const isElementAssignment = parent2.kind === 211 /* ElementAccessExpression */ && parent2.expression === root && parent2.parent.kind === 225 /* BinaryExpression */ && parent2.parent.operatorToken.kind === 64 /* EqualsToken */ && parent2.parent.left === parent2 && !isAssignmentTarget(parent2.parent) && isTypeAssignableToKind(getTypeOfExpression(parent2.argumentExpression), 296 /* NumberLike */); + const isLengthPushOrUnshift = isPropertyAccessExpression(parent2) && (parent2.name.escapedText === "length" || parent2.parent.kind === 213 /* CallExpression */ && isIdentifier(parent2.name) && isPushOrUnshiftIdentifier(parent2.name)); + const isElementAssignment = parent2.kind === 212 /* ElementAccessExpression */ && parent2.expression === root && parent2.parent.kind === 226 /* BinaryExpression */ && parent2.parent.operatorToken.kind === 64 /* EqualsToken */ && parent2.parent.left === parent2 && !isAssignmentTarget(parent2.parent) && isTypeAssignableToKind(getTypeOfExpression(parent2.argumentExpression), 296 /* NumberLike */); return isLengthPushOrUnshift || isElementAssignment; } function isDeclarationWithExplicitTypeAnnotation(node) { @@ -165932,7 +149690,7 @@ ${lanes.join("\n")} if (isDeclarationWithExplicitTypeAnnotation(declaration)) { return getTypeOfSymbol(symbol); } - if (isVariableDeclaration(declaration) && declaration.parent.parent.kind === 249 /* ForOfStatement */) { + if (isVariableDeclaration(declaration) && declaration.parent.parent.kind === 250 /* ForOfStatement */) { const statement = declaration.parent.parent; const expressionType = getTypeOfDottedName( statement.expression, @@ -165957,7 +149715,7 @@ ${lanes.join("\n")} } } function getTypeOfDottedName(node, diagnostic) { - if (!(node.flags & 33554432 /* InWithStatement */)) { + if (!(node.flags & 67108864 /* InWithStatement */)) { switch (node.kind) { case 80 /* Identifier */: const symbol = getExportSymbolOfValueSymbolIfExported(getResolvedSymbol(node)); @@ -165966,7 +149724,7 @@ ${lanes.join("\n")} return getExplicitThisType(node); case 108 /* SuperKeyword */: return checkSuperExpression(node); - case 210 /* PropertyAccessExpression */: { + case 211 /* PropertyAccessExpression */: { const type = getTypeOfDottedName(node.expression, diagnostic); if (type) { const name = node.name; @@ -165983,7 +149741,7 @@ ${lanes.join("\n")} } return void 0; } - case 216 /* ParenthesizedExpression */: + case 217 /* ParenthesizedExpression */: return getTypeOfDottedName(node.expression, diagnostic); } } @@ -165993,7 +149751,10 @@ ${lanes.join("\n")} let signature = links.effectsSignature; if (signature === void 0) { let funcType; - if (node.parent.kind === 243 /* ExpressionStatement */) { + if (isBinaryExpression(node)) { + const rightType = checkNonNullExpression(node.right); + funcType = getSymbolHasInstanceMethodOfObjectType(rightType); + } else if (node.parent.kind === 244 /* ExpressionStatement */) { funcType = getTypeOfDottedName( node.expression, /*diagnostic*/ @@ -166047,7 +149808,7 @@ ${lanes.join("\n")} /*excludeJSDocTypeAssertions*/ true ); - return node.kind === 97 /* FalseKeyword */ || node.kind === 225 /* BinaryExpression */ && (node.operatorToken.kind === 56 /* AmpersandAmpersandToken */ && (isFalseExpression(node.left) || isFalseExpression(node.right)) || node.operatorToken.kind === 57 /* BarBarToken */ && isFalseExpression(node.left) && isFalseExpression(node.right)); + return node.kind === 97 /* FalseKeyword */ || node.kind === 226 /* BinaryExpression */ && (node.operatorToken.kind === 56 /* AmpersandAmpersandToken */ && (isFalseExpression(node.left) || isFalseExpression(node.right)) || node.operatorToken.kind === 57 /* BarBarToken */ && isFalseExpression(node.left) && isFalseExpression(node.right)); } function isReachableFlowNodeWorker(flow, noCacheCheck) { while (true) { @@ -166166,14 +149927,16 @@ ${lanes.join("\n")} } function isConstantReference(node) { switch (node.kind) { + case 110 /* ThisKeyword */: + return true; case 80 /* Identifier */: if (!isThisInTypeQuery(node)) { const symbol = getResolvedSymbol(node); - return isConstVariable(symbol) || isParameterOrCatchClauseVariable(symbol) && !isSymbolAssigned(symbol); + return isConstantVariable(symbol) || isParameterOrCatchClauseVariable(symbol) && !isSymbolAssigned(symbol); } break; - case 210 /* PropertyAccessExpression */: - case 211 /* ElementAccessExpression */: + case 211 /* PropertyAccessExpression */: + case 212 /* ElementAccessExpression */: return isConstantReference(node.expression) && isReadonlySymbol(getNodeLinks(node).resolvedSymbol || unknownSymbol); } return false; @@ -166193,7 +149956,7 @@ ${lanes.join("\n")} const evolvedType = getTypeFromFlowType(getTypeAtFlowNode(flowNode)); sharedFlowCount = sharedFlowStart; const resultType = getObjectFlags(evolvedType) & 256 /* EvolvingArray */ && isEvolvingArrayOperationTarget(reference) ? autoArrayType : finalizeEvolvingArrayType(evolvedType); - if (resultType === unreachableNeverType || reference.parent && reference.parent.kind === 234 /* NonNullExpression */ && !(resultType.flags & 131072 /* Never */) && getTypeWithFacts(resultType, 2097152 /* NEUndefinedOrNull */).flags & 131072 /* Never */) { + if (resultType === unreachableNeverType || reference.parent && reference.parent.kind === 235 /* NonNullExpression */ && !(resultType.flags & 131072 /* Never */) && getTypeWithFacts(resultType, 2097152 /* NEUndefinedOrNull */).flags & 131072 /* Never */) { return declaredType; } return resultType === nonNullUnknownType ? unknownType : resultType; @@ -166262,7 +150025,7 @@ ${lanes.join("\n")} target.antecedents = saveAntecedents; } else if (flags & 2 /* Start */) { const container = flow.node; - if (container && container !== flowContainer && reference.kind !== 210 /* PropertyAccessExpression */ && reference.kind !== 211 /* ElementAccessExpression */ && reference.kind !== 110 /* ThisKeyword */) { + if (container && container !== flowContainer && reference.kind !== 211 /* PropertyAccessExpression */ && reference.kind !== 212 /* ElementAccessExpression */ && !(reference.kind === 110 /* ThisKeyword */ && container.kind !== 219 /* ArrowFunction */)) { flow = container.flowNode; continue; } @@ -166281,7 +150044,10 @@ ${lanes.join("\n")} } function getInitialOrAssignedType(flow) { const node = flow.node; - return getNarrowableTypeForReference(node.kind === 259 /* VariableDeclaration */ || node.kind === 207 /* BindingElement */ ? getInitialType(node) : getAssignedType(node), reference); + return getNarrowableTypeForReference( + node.kind === 260 /* VariableDeclaration */ || node.kind === 208 /* BindingElement */ ? getInitialType(node) : getAssignedType(node), + reference + ); } function getTypeAtFlowAssignment(flow) { const node = flow.node; @@ -166300,24 +150066,25 @@ ${lanes.join("\n")} const assignedType = getWidenedLiteralType(getInitialOrAssignedType(flow)); return isTypeAssignableTo(assignedType, declaredType) ? assignedType : anyArrayType; } - if (declaredType.flags & 1048576 /* Union */) { - return getAssignmentReducedType(declaredType, getInitialOrAssignedType(flow)); + const t = isInCompoundLikeAssignment(node) ? getBaseTypeOfLiteralType(declaredType) : declaredType; + if (t.flags & 1048576 /* Union */) { + return getAssignmentReducedType(t, getInitialOrAssignedType(flow)); } - return declaredType; + return t; } if (containsMatchingReference(reference, node)) { if (!isReachableFlowNode(flow)) { return unreachableNeverType; } - if (isVariableDeclaration(node) && (isInJSFile(node) || isVarConst(node))) { + if (isVariableDeclaration(node) && (isInJSFile(node) || isVarConstLike(node))) { const init = getDeclaredExpandoInitializer(node); - if (init && (init.kind === 217 /* FunctionExpression */ || init.kind === 218 /* ArrowFunction */)) { + if (init && (init.kind === 218 /* FunctionExpression */ || init.kind === 219 /* ArrowFunction */)) { return getTypeAtFlowNode(flow.antecedent); } } return declaredType; } - if (isVariableDeclaration(node) && node.parent.parent.kind === 248 /* ForInStatement */ && (isMatchingReference(reference, node.parent.parent.expression) || optionalChainContainsReference(node.parent.parent.expression, reference))) { + if (isVariableDeclaration(node) && node.parent.parent.kind === 249 /* ForInStatement */ && (isMatchingReference(reference, node.parent.parent.expression) || optionalChainContainsReference(node.parent.parent.expression, reference))) { return getNonNullableTypeIfNeeded(finalizeEvolvingArrayType(getTypeFromFlowType(getTypeAtFlowNode(flow.antecedent)))); } return void 0; @@ -166331,7 +150098,7 @@ ${lanes.join("\n")} if (node.kind === 97 /* FalseKeyword */) { return unreachableNeverType; } - if (node.kind === 225 /* BinaryExpression */) { + if (node.kind === 226 /* BinaryExpression */) { if (node.operatorToken.kind === 56 /* AmpersandAmpersandToken */) { return narrowTypeByAssertion(narrowTypeByAssertion(type, node.left), node.right); } @@ -166371,13 +150138,13 @@ ${lanes.join("\n")} function getTypeAtFlowArrayMutation(flow) { if (declaredType === autoType || declaredType === autoArrayType) { const node = flow.node; - const expr = node.kind === 212 /* CallExpression */ ? node.expression.expression : node.left.expression; + const expr = node.kind === 213 /* CallExpression */ ? node.expression.expression : node.left.expression; if (isMatchingReference(reference, getReferenceCandidate(expr))) { const flowType = getTypeAtFlowNode(flow.antecedent); const type = getTypeFromFlowType(flowType); if (getObjectFlags(type) & 256 /* EvolvingArray */) { let evolvedType2 = type; - if (node.kind === 212 /* CallExpression */) { + if (node.kind === 213 /* CallExpression */) { for (const arg of node.arguments) { evolvedType2 = addEvolvingArrayElementType(evolvedType2, arg); } @@ -166409,31 +150176,21 @@ ${lanes.join("\n")} return createFlowType(narrowedType, isIncomplete(flowType)); } function getTypeAtSwitchClause(flow) { - const expr = flow.switchStatement.expression; + const expr = skipParentheses(flow.switchStatement.expression); const flowType = getTypeAtFlowNode(flow.antecedent); let type = getTypeFromFlowType(flowType); if (isMatchingReference(reference, expr)) { type = narrowTypeBySwitchOnDiscriminant(type, flow.switchStatement, flow.clauseStart, flow.clauseEnd); - } else if (expr.kind === 220 /* TypeOfExpression */ && isMatchingReference(reference, expr.expression)) { + } else if (expr.kind === 221 /* TypeOfExpression */ && isMatchingReference(reference, expr.expression)) { type = narrowTypeBySwitchOnTypeOf(type, flow.switchStatement, flow.clauseStart, flow.clauseEnd); + } else if (expr.kind === 112 /* TrueKeyword */) { + type = narrowTypeBySwitchOnTrue(type, flow.switchStatement, flow.clauseStart, flow.clauseEnd); } else { if (strictNullChecks) { if (optionalChainContainsReference(expr, reference)) { - type = narrowTypeBySwitchOptionalChainContainment( - type, - flow.switchStatement, - flow.clauseStart, - flow.clauseEnd, - (t) => !(t.flags & (32768 /* Undefined */ | 131072 /* Never */)) - ); - } else if (expr.kind === 220 /* TypeOfExpression */ && optionalChainContainsReference(expr.expression, reference)) { - type = narrowTypeBySwitchOptionalChainContainment( - type, - flow.switchStatement, - flow.clauseStart, - flow.clauseEnd, - (t) => !(t.flags & 131072 /* Never */ || t.flags & 128 /* StringLiteral */ && t.value === "undefined") - ); + type = narrowTypeBySwitchOptionalChainContainment(type, flow.switchStatement, flow.clauseStart, flow.clauseEnd, (t) => !(t.flags & (32768 /* Undefined */ | 131072 /* Never */))); + } else if (expr.kind === 221 /* TypeOfExpression */ && optionalChainContainsReference(expr.expression, reference)) { + type = narrowTypeBySwitchOptionalChainContainment(type, flow.switchStatement, flow.clauseStart, flow.clauseEnd, (t) => !(t.flags & 131072 /* Never */ || t.flags & 128 /* StringLiteral */ && t.value === "undefined")); } } const access = getDiscriminantPropertyAccess(expr, type); @@ -166571,7 +150328,7 @@ ${lanes.join("\n")} } } else if (isIdentifier(expr)) { const symbol = getResolvedSymbol(expr); - if (isConstVariable(symbol)) { + if (isConstantVariable(symbol)) { const declaration = symbol.valueDeclaration; if (isVariableDeclaration(declaration) && !declaration.type && declaration.initializer && isAccessExpression(declaration.initializer) && isMatchingReference(reference, declaration.initializer.expression)) { return declaration.initializer; @@ -166587,13 +150344,15 @@ ${lanes.join("\n")} return void 0; } function getDiscriminantPropertyAccess(expr, computedType) { - const type = declaredType.flags & 1048576 /* Union */ ? declaredType : computedType; - if (type.flags & 1048576 /* Union */) { + if (declaredType.flags & 1048576 /* Union */ || computedType.flags & 1048576 /* Union */) { const access = getCandidateDiscriminantPropertyAccess(expr); if (access) { const name = getAccessedPropertyName(access); - if (name && isDiscriminantProperty(type, name)) { - return access; + if (name) { + const type = declaredType.flags & 1048576 /* Union */ && isTypeSubsetOf(computedType, declaredType) ? declaredType : computedType; + if (isDiscriminantProperty(type, name)) { + return access; + } } } } @@ -166613,7 +150372,7 @@ ${lanes.join("\n")} propType = removeNullable && optionalChain ? getOptionalType(propType) : propType; const narrowedPropType = narrowType2(propType); return filterType(type, (t) => { - const discriminantType = getTypeOfPropertyOrIndexSignature(t, propName); + const discriminantType = getTypeOfPropertyOrIndexSignatureOfType(t, propName) || unknownType; return !(discriminantType.flags & 131072 /* Never */) && !(narrowedPropType.flags & 131072 /* Never */) && areTypesComparable(narrowedPropType, discriminantType); }); } @@ -166675,6 +150434,10 @@ ${lanes.join("\n")} } return type; } + function narrowTypeByBooleanComparison(type, expr, bool, operator, assumeTrue) { + assumeTrue = assumeTrue !== (bool.kind === 112 /* TrueKeyword */) !== (operator !== 38 /* ExclamationEqualsEqualsToken */ && operator !== 36 /* ExclamationEqualsToken */); + return narrowType(type, expr, assumeTrue); + } function narrowTypeByBinaryExpression(type, expr, assumeTrue) { switch (expr.operatorToken.kind) { case 64 /* EqualsToken */: @@ -166689,10 +150452,10 @@ ${lanes.join("\n")} const operator = expr.operatorToken.kind; const left = getReferenceCandidate(expr.left); const right = getReferenceCandidate(expr.right); - if (left.kind === 220 /* TypeOfExpression */ && isStringLiteralLike(right)) { + if (left.kind === 221 /* TypeOfExpression */ && isStringLiteralLike(right)) { return narrowTypeByTypeof(type, left, operator, right, assumeTrue); } - if (right.kind === 220 /* TypeOfExpression */ && isStringLiteralLike(left)) { + if (right.kind === 221 /* TypeOfExpression */ && isStringLiteralLike(left)) { return narrowTypeByTypeof(type, right, operator, left, assumeTrue); } if (isMatchingReference(reference, left)) { @@ -166722,6 +150485,12 @@ ${lanes.join("\n")} if (isMatchingConstructorReference(right)) { return narrowTypeByConstructor(type, operator, left, assumeTrue); } + if (isBooleanLiteral(right) && !isAccessExpression(left)) { + return narrowTypeByBooleanComparison(type, left, right, operator, assumeTrue); + } + if (isBooleanLiteral(left) && !isAccessExpression(right)) { + return narrowTypeByBooleanComparison(type, right, left, operator, assumeTrue); + } break; case 104 /* InstanceOfKeyword */: return narrowTypeByInstanceof(type, expr, assumeTrue); @@ -166730,12 +150499,15 @@ ${lanes.join("\n")} return narrowTypeByPrivateIdentifierInInExpression(type, expr, assumeTrue); } const target = getReferenceCandidate(expr.right); - const leftType = getTypeOfExpression(expr.left); - if (leftType.flags & 8576 /* StringOrNumberLiteralOrUnique */) { - if (containsMissingType(type) && isAccessExpression(reference) && isMatchingReference(reference.expression, target) && getAccessedPropertyName(reference) === getPropertyNameFromType(leftType)) { + if (containsMissingType(type) && isAccessExpression(reference) && isMatchingReference(reference.expression, target)) { + const leftType = getTypeOfExpression(expr.left); + if (isTypeUsableAsPropertyName(leftType) && getAccessedPropertyName(reference) === getPropertyNameFromType(leftType)) { return getTypeWithFacts(type, assumeTrue ? 524288 /* NEUndefined */ : 65536 /* EQUndefined */); } - if (isMatchingReference(reference, target)) { + } + if (isMatchingReference(reference, target)) { + const leftType = getTypeOfExpression(expr.left); + if (isTypeUsableAsPropertyName(leftType)) { return narrowTypeByInKeyword(type, leftType, assumeTrue); } } @@ -166934,14 +150706,14 @@ ${lanes.join("\n")} // the constituent based on its type facts. We use the strict subtype relation because it treats `object` // as a subtype of `{}`, and we need the type facts check because function types are subtypes of `object`, // but are classified as "function" according to `typeof`. - isTypeRelatedTo(t, impliedType, strictSubtypeRelation) ? getTypeFacts(t) & facts ? t : neverType : ( + isTypeRelatedTo(t, impliedType, strictSubtypeRelation) ? hasTypeFacts(t, facts) ? t : neverType : ( // We next check if the consituent is a supertype of the implied type. If so, we substitute the implied // type. This handles top types like `unknown` and `{}`, and supertypes like `{ toString(): string }`. isTypeSubtypeOf(impliedType, t) ? impliedType : ( // Neither the constituent nor the implied type is a subtype of the other, however their domains may still // overlap. For example, an unconstrained type parameter and type `string`. If the type facts indicate // possible overlap, we form an intersection. Otherwise, we eliminate the constituent. - getTypeFacts(t) & facts ? getIntersectionType([t, impliedType]) : neverType + hasTypeFacts(t, facts) ? getIntersectionType([t, impliedType]) : neverType ) ) )); @@ -166951,15 +150723,51 @@ ${lanes.join("\n")} if (!witnesses) { return type; } - const defaultIndex = findIndex(switchStatement.caseBlock.clauses, (clause) => clause.kind === 296 /* DefaultClause */); + const defaultIndex = findIndex(switchStatement.caseBlock.clauses, (clause) => clause.kind === 297 /* DefaultClause */); const hasDefaultClause = clauseStart === clauseEnd || defaultIndex >= clauseStart && defaultIndex < clauseEnd; if (hasDefaultClause) { const notEqualFacts = getNotEqualFactsFromTypeofSwitch(clauseStart, clauseEnd, witnesses); - return filterType(type, (t) => (getTypeFacts(t) & notEqualFacts) === notEqualFacts); + return filterType(type, (t) => getTypeFacts(t, notEqualFacts) === notEqualFacts); } const clauseWitnesses = witnesses.slice(clauseStart, clauseEnd); return getUnionType(map(clauseWitnesses, (text) => text ? narrowTypeByTypeName(type, text) : neverType)); } + function narrowTypeBySwitchOnTrue(type, switchStatement, clauseStart, clauseEnd) { + const defaultIndex = findIndex(switchStatement.caseBlock.clauses, (clause) => clause.kind === 297 /* DefaultClause */); + const hasDefaultClause = clauseStart === clauseEnd || defaultIndex >= clauseStart && defaultIndex < clauseEnd; + for (let i = 0; i < clauseStart; i++) { + const clause = switchStatement.caseBlock.clauses[i]; + if (clause.kind === 296 /* CaseClause */) { + type = narrowType( + type, + clause.expression, + /*assumeTrue*/ + false + ); + } + } + if (hasDefaultClause) { + for (let i = clauseEnd; i < switchStatement.caseBlock.clauses.length; i++) { + const clause = switchStatement.caseBlock.clauses[i]; + if (clause.kind === 296 /* CaseClause */) { + type = narrowType( + type, + clause.expression, + /*assumeTrue*/ + false + ); + } + } + return type; + } + const clauses = switchStatement.caseBlock.clauses.slice(clauseStart, clauseEnd); + return getUnionType(map(clauses, (clause) => clause.kind === 296 /* CaseClause */ ? narrowType( + type, + clause.expression, + /*assumeTrue*/ + true + ) : neverType)); + } function isMatchingConstructorReference(expr) { return (isPropertyAccessExpression(expr) && idText(expr.name) === "constructor" || isElementAccessExpression(expr) && isStringLiteralLike(expr.argumentExpression) && expr.argumentExpression.text === "constructor") && isMatchingReference(reference, expr.expression); } @@ -166999,7 +150807,22 @@ ${lanes.join("\n")} } return type; } - const rightType = getTypeOfExpression(expr.right); + const right = expr.right; + const rightType = getTypeOfExpression(right); + if (!isTypeDerivedFrom(rightType, globalObjectType)) { + return type; + } + const signature = getEffectsSignature(expr); + const predicate = signature && getTypePredicateOfSignature(signature); + if (predicate && predicate.kind === 1 /* Identifier */ && predicate.parameterIndex === 0) { + return getNarrowedType( + type, + predicate.type, + assumeTrue, + /*checkDerived*/ + true + ); + } if (!isTypeDerivedFrom(rightType, globalFunctionType)) { return type; } @@ -167053,7 +150876,10 @@ ${lanes.join("\n")} const narrowedType = mapType(candidate, (c) => { const discriminant = keyPropertyName && getTypeOfPropertyOfType(c, keyPropertyName); const matching = discriminant && getConstituentTypeForKeyType(type, discriminant); - const directlyRelated = mapType(matching || type, checkDerived ? (t) => isTypeDerivedFrom(t, c) ? t : isTypeDerivedFrom(c, t) ? c : neverType : (t) => isTypeStrictSubtypeOf(t, c) ? t : isTypeStrictSubtypeOf(c, t) ? c : isTypeSubtypeOf(t, c) ? t : isTypeSubtypeOf(c, t) ? c : neverType); + const directlyRelated = mapType( + matching || type, + checkDerived ? (t) => isTypeDerivedFrom(t, c) ? t : isTypeDerivedFrom(c, t) ? c : neverType : (t) => isTypeStrictSubtypeOf(t, c) ? t : isTypeStrictSubtypeOf(c, t) ? c : isTypeSubtypeOf(t, c) ? t : isTypeSubtypeOf(c, t) ? c : neverType + ); return directlyRelated.flags & 131072 /* Never */ ? mapType(type, (t) => maybeTypeOfKind(t, 465829888 /* Instantiable */) && isRelated(c, getBaseConstraintOfType(t) || unknownType) ? getIntersectionType([t, c]) : neverType) : directlyRelated; }); return !(narrowedType.flags & 131072 /* Never */) ? narrowedType : isTypeSubtypeOf(candidate, type) ? candidate : isTypeAssignableTo(type, candidate) ? type : isTypeAssignableTo(candidate, type) ? candidate : getIntersectionType([type, candidate]); @@ -167090,7 +150916,7 @@ ${lanes.join("\n")} false ); } - if (strictNullChecks && assumeTrue && optionalChainContainsReference(predicateArgument, reference) && !(getTypeFacts(predicate.type) & 65536 /* EQUndefined */)) { + if (strictNullChecks && optionalChainContainsReference(predicateArgument, reference) && (assumeTrue && !hasTypeFacts(predicate.type, 65536 /* EQUndefined */) || !assumeTrue && everyType(predicate.type, isNullableType))) { type = getAdjustedTypeWithFacts(type, 2097152 /* NEUndefinedOrNull */); } const access = getDiscriminantPropertyAccess(predicateArgument, type); @@ -167115,7 +150941,7 @@ ${lanes.join("\n")} case 80 /* Identifier */: if (!isMatchingReference(reference, expr) && inlineLevel < 5) { const symbol = getResolvedSymbol(expr); - if (isConstVariable(symbol)) { + if (isConstantVariable(symbol)) { const declaration = symbol.valueDeclaration; if (declaration && isVariableDeclaration(declaration) && !declaration.type && declaration.initializer && isConstantReference(reference)) { inlineLevel++; @@ -167127,17 +150953,17 @@ ${lanes.join("\n")} } case 110 /* ThisKeyword */: case 108 /* SuperKeyword */: - case 210 /* PropertyAccessExpression */: - case 211 /* ElementAccessExpression */: + case 211 /* PropertyAccessExpression */: + case 212 /* ElementAccessExpression */: return narrowTypeByTruthiness(type, expr, assumeTrue); - case 212 /* CallExpression */: + case 213 /* CallExpression */: return narrowTypeByCallExpression(type, expr, assumeTrue); - case 216 /* ParenthesizedExpression */: - case 234 /* NonNullExpression */: + case 217 /* ParenthesizedExpression */: + case 235 /* NonNullExpression */: return narrowType(type, expr.expression, assumeTrue); - case 225 /* BinaryExpression */: + case 226 /* BinaryExpression */: return narrowTypeByBinaryExpression(type, expr, assumeTrue); - case 223 /* PrefixUnaryExpression */: + case 224 /* PrefixUnaryExpression */: if (expr.operator === 54 /* ExclamationToken */) { return narrowType(type, expr.operand, !assumeTrue); } @@ -167163,7 +150989,15 @@ ${lanes.join("\n")} location = location.parent; } if (isExpressionNode(location) && (!isAssignmentTarget(location) || isWriteAccess(location))) { - const type = getTypeOfExpression(location); + const type = removeOptionalTypeMarker( + isWriteAccess(location) && location.kind === 211 /* PropertyAccessExpression */ ? checkPropertyAccessExpression( + location, + /*checkMode*/ + void 0, + /*writeOnly*/ + true + ) : getTypeOfExpression(location) + ); if (getExportSymbolOfValueSymbolIfExported(getNodeLinks(location).resolvedSymbol) === symbol) { return type; } @@ -167172,10 +151006,10 @@ ${lanes.join("\n")} if (isDeclarationName(location) && isSetAccessor(location.parent) && getAnnotatedAccessorTypeNode(location.parent)) { return getWriteTypeOfAccessors(location.parent.symbol); } - return getNonMissingTypeOfSymbol(symbol); + return isRightSideOfAccessExpression(location) && isWriteAccess(location.parent) ? getWriteTypeOfSymbol(symbol) : getNonMissingTypeOfSymbol(symbol); } function getControlFlowContainer(node) { - return findAncestor(node.parent, (node2) => isFunctionLike(node2) && !getImmediatelyInvokedFunctionExpression(node2) || node2.kind === 267 /* ModuleBlock */ || node2.kind === 311 /* SourceFile */ || node2.kind === 171 /* PropertyDeclaration */); + return findAncestor(node.parent, (node2) => isFunctionLike(node2) && !getImmediatelyInvokedFunctionExpression(node2) || node2.kind === 268 /* ModuleBlock */ || node2.kind === 312 /* SourceFile */ || node2.kind === 172 /* PropertyDeclaration */); } function isSymbolAssigned(symbol) { if (!symbol.valueDeclaration) { @@ -167183,8 +151017,8 @@ ${lanes.join("\n")} } const parent2 = getRootDeclaration(symbol.valueDeclaration).parent; const links = getNodeLinks(parent2); - if (!(links.flags & 524288 /* AssignmentsMarked */)) { - links.flags |= 524288 /* AssignmentsMarked */; + if (!(links.flags & 131072 /* AssignmentsMarked */)) { + links.flags |= 131072 /* AssignmentsMarked */; if (!hasParentWithAssignmentsMarked(parent2)) { markNodeAssignments(parent2); } @@ -167192,7 +151026,7 @@ ${lanes.join("\n")} return symbol.isAssigned || false; } function hasParentWithAssignmentsMarked(node) { - return !!findAncestor(node.parent, (node2) => (isFunctionLike(node2) || isCatchClause(node2)) && !!(getNodeLinks(node2).flags & 524288 /* AssignmentsMarked */)); + return !!findAncestor(node.parent, (node2) => (isFunctionLike(node2) || isCatchClause(node2)) && !!(getNodeLinks(node2).flags & 131072 /* AssignmentsMarked */)); } function markNodeAssignments(node) { if (node.kind === 80 /* Identifier */) { @@ -167206,8 +151040,8 @@ ${lanes.join("\n")} forEachChild(node, markNodeAssignments); } } - function isConstVariable(symbol) { - return symbol.flags & 3 /* Variable */ && (getDeclarationNodeFlagsFromSymbol(symbol) & 2 /* Const */) !== 0; + function isConstantVariable(symbol) { + return symbol.flags & 3 /* Variable */ && (getDeclarationNodeFlagsFromSymbol(symbol) & 6 /* Constant */) !== 0; } function parameterInitializerContainsUndefined(declaration) { const links = getNodeLinks(declaration); @@ -167216,7 +151050,7 @@ ${lanes.join("\n")} reportCircularityError(declaration.symbol); return true; } - const containsUndefined = !!(getTypeFacts(checkDeclarationInitializer(declaration, 0 /* Normal */)) & 16777216 /* IsUndefined */); + const containsUndefined = !!hasTypeFacts(checkDeclarationInitializer(declaration, 0 /* Normal */), 16777216 /* IsUndefined */); if (!popTypeResolution()) { reportCircularityError(declaration.symbol); return true; @@ -167226,12 +151060,12 @@ ${lanes.join("\n")} return links.parameterInitializerContainsUndefined; } function removeOptionalityFromDeclaredType(declaredType, declaration) { - const removeUndefined = strictNullChecks && declaration.kind === 168 /* Parameter */ && declaration.initializer && getTypeFacts(declaredType) & 16777216 /* IsUndefined */ && !parameterInitializerContainsUndefined(declaration); + const removeUndefined = strictNullChecks && declaration.kind === 169 /* Parameter */ && declaration.initializer && hasTypeFacts(declaredType, 16777216 /* IsUndefined */) && !parameterInitializerContainsUndefined(declaration); return removeUndefined ? getTypeWithFacts(declaredType, 524288 /* NEUndefined */) : declaredType; } function isConstraintPosition(type, node) { const parent2 = node.parent; - return parent2.kind === 210 /* PropertyAccessExpression */ || parent2.kind === 165 /* QualifiedName */ || parent2.kind === 212 /* CallExpression */ && parent2.expression === node || parent2.kind === 211 /* ElementAccessExpression */ && parent2.expression === node && !(someType(type, isGenericTypeWithoutNullableConstraint) && isGenericIndexType(getTypeOfExpression(parent2.argumentExpression))); + return parent2.kind === 211 /* PropertyAccessExpression */ || parent2.kind === 166 /* QualifiedName */ || parent2.kind === 213 /* CallExpression */ && parent2.expression === node || parent2.kind === 212 /* ElementAccessExpression */ && parent2.expression === node && !(someType(type, isGenericTypeWithoutNullableConstraint) && isGenericIndexType(getTypeOfExpression(parent2.argumentExpression))); } function isGenericTypeWithUnionConstraint(type) { return type.flags & 2097152 /* Intersection */ ? some(type.types, isGenericTypeWithUnionConstraint) : !!(type.flags & 465829888 /* Instantiable */ && getBaseConstraintOrType(type).flags & (98304 /* Nullable */ | 1048576 /* Union */)); @@ -167240,7 +151074,7 @@ ${lanes.join("\n")} return type.flags & 2097152 /* Intersection */ ? some(type.types, isGenericTypeWithoutNullableConstraint) : !!(type.flags & 465829888 /* Instantiable */ && !maybeTypeOfKind(getBaseConstraintOrType(type), 98304 /* Nullable */)); } function hasContextualTypeWithNoGenericTypes(node, checkMode) { - const contextualType = (isIdentifier(node) || isPropertyAccessExpression(node) || isElementAccessExpression(node)) && !((isJsxOpeningElement(node.parent) || isJsxSelfClosingElement(node.parent)) && node.parent.tagName === node) && (checkMode && checkMode & 64 /* RestBindingElement */ ? getContextualType2(node, 8 /* SkipBindingPatterns */) : getContextualType2( + const contextualType = (isIdentifier(node) || isPropertyAccessExpression(node) || isElementAccessExpression(node)) && !((isJsxOpeningElement(node.parent) || isJsxSelfClosingElement(node.parent)) && node.parent.tagName === node) && (checkMode && checkMode & 32 /* RestBindingElement */ ? getContextualType2(node, 8 /* SkipBindingPatterns */) : getContextualType2( node, /*contextFlags*/ void 0 @@ -167274,9 +151108,13 @@ ${lanes.join("\n")} symbol, /*excludes*/ 111551 /* Value */ - ) && !isInTypeQuery(location) && !getTypeOnlyAliasDeclaration(symbol, 111551 /* Value */)) { + ) && !isInTypeQuery(location)) { const target = resolveAlias(symbol); - if (getAllSymbolFlags(target) & (111551 /* Value */ | 1048576 /* ExportValue */)) { + if (getSymbolFlags( + symbol, + /*excludeTypeOnlyMeanings*/ + true + ) & (111551 /* Value */ | 1048576 /* ExportValue */)) { if (getIsolatedModules(compilerOptions) || shouldPreserveConstEnums(compilerOptions) && isExportOrExportExpression(location) || !isConstEnumOrConstEnumOnlyModule(getExportSymbolOfValueSymbolIfExported(target))) { markAliasSymbolAsReferenced(symbol); } else { @@ -167292,14 +151130,14 @@ ${lanes.join("\n")} if (declaration) { if (isBindingElement(declaration) && !declaration.initializer && !declaration.dotDotDotToken && declaration.parent.elements.length >= 2) { const parent2 = declaration.parent.parent; - if (parent2.kind === 259 /* VariableDeclaration */ && getCombinedNodeFlags(declaration) & 2 /* Const */ || parent2.kind === 168 /* Parameter */) { + if (parent2.kind === 260 /* VariableDeclaration */ && getCombinedNodeFlagsCached(declaration) & 6 /* Constant */ || parent2.kind === 169 /* Parameter */) { const links = getNodeLinks(parent2); - if (!(links.flags & 16777216 /* InCheckIdentifier */)) { - links.flags |= 16777216 /* InCheckIdentifier */; + if (!(links.flags & 4194304 /* InCheckIdentifier */)) { + links.flags |= 4194304 /* InCheckIdentifier */; const parentType = getTypeForBindingElementParent(parent2, 0 /* Normal */); const parentTypeConstraint = parentType && mapType(parentType, getBaseConstraintOrType); - links.flags &= ~16777216 /* InCheckIdentifier */; - if (parentTypeConstraint && parentTypeConstraint.flags & 1048576 /* Union */ && !(parent2.kind === 168 /* Parameter */ && isSymbolAssigned(symbol))) { + links.flags &= ~4194304 /* InCheckIdentifier */; + if (parentTypeConstraint && parentTypeConstraint.flags & 1048576 /* Union */ && !(parent2.kind === 169 /* Parameter */ && isSymbolAssigned(symbol))) { const pattern = declaration.parent; const narrowedType = getFlowTypeOfReference( pattern, @@ -167312,7 +151150,12 @@ ${lanes.join("\n")} if (narrowedType.flags & 131072 /* Never */) { return neverType; } - return getBindingElementTypeFromParentType(declaration, narrowedType); + return getBindingElementTypeFromParentType( + declaration, + narrowedType, + /*noTupleBoundsCheck*/ + true + ); } } } @@ -167351,15 +151194,15 @@ ${lanes.join("\n")} } if (symbol === argumentsSymbol) { if (isInPropertyInitializerOrClassStaticBlock(node)) { - error(node, Diagnostics.arguments_cannot_be_referenced_in_property_initializers); + error2(node, Diagnostics.arguments_cannot_be_referenced_in_property_initializers); return errorType; } const container = getContainingFunction(node); if (languageVersion < 2 /* ES2015 */) { - if (container.kind === 218 /* ArrowFunction */) { - error(node, Diagnostics.The_arguments_object_cannot_be_referenced_in_an_arrow_function_in_ES3_and_ES5_Consider_using_a_standard_function_expression); - } else if (hasSyntacticModifier(container, 512 /* Async */)) { - error(node, Diagnostics.The_arguments_object_cannot_be_referenced_in_an_async_function_or_method_in_ES3_and_ES5_Consider_using_a_standard_function_or_method); + if (container.kind === 219 /* ArrowFunction */) { + error2(node, Diagnostics.The_arguments_object_cannot_be_referenced_in_an_arrow_function_in_ES3_and_ES5_Consider_using_a_standard_function_expression); + } else if (hasSyntacticModifier(container, 1024 /* Async */)) { + error2(node, Diagnostics.The_arguments_object_cannot_be_referenced_in_an_async_function_or_method_in_ES3_and_ES5_Consider_using_a_standard_function_or_method); } } getNodeLinks(container).flags |= 512 /* CaptureArguments */; @@ -167375,17 +151218,7 @@ ${lanes.join("\n")} } let declaration = localOrExportSymbol.valueDeclaration; if (declaration && localOrExportSymbol.flags & 32 /* Class */) { - if (declaration.kind === 262 /* ClassDeclaration */ && nodeIsDecorated(legacyDecorators, declaration)) { - let container = getContainingClass(node); - while (container !== void 0) { - if (container === declaration && container.name !== node) { - getNodeLinks(declaration).flags |= 1048576 /* ClassWithConstructorReference */; - getNodeLinks(node).flags |= 2097152 /* ConstructorReferenceInClass */; - break; - } - container = getContainingClass(container); - } - } else if (declaration.kind === 230 /* ClassExpression */) { + if (isClassLike(declaration) && declaration.name !== node) { let container = getThisContainer( node, /*includeArrowFunctions*/ @@ -167393,14 +151226,7 @@ ${lanes.join("\n")} /*includeClassComputedPropertyName*/ false ); - while (container.kind !== 311 /* SourceFile */) { - if (container.parent === declaration) { - if (isPropertyDeclaration(container) && isStatic(container) || isClassStaticBlockDeclaration(container)) { - getNodeLinks(declaration).flags |= 1048576 /* ClassWithConstructorReference */; - getNodeLinks(node).flags |= 2097152 /* ConstructorReferenceInClass */; - } - break; - } + while (container.kind !== 312 /* SourceFile */ && container.parent !== declaration) { container = getThisContainer( container, /*includeArrowFunctions*/ @@ -167409,6 +151235,11 @@ ${lanes.join("\n")} false ); } + if (container.kind !== 312 /* SourceFile */) { + getNodeLinks(declaration).flags |= 262144 /* ContainsConstructorReference */; + getNodeLinks(container).flags |= 262144 /* ContainsConstructorReference */; + getNodeLinks(node).flags |= 536870912 /* ConstructorReference */; + } } } checkNestedBlockScopedBinding(node, symbol); @@ -167417,14 +151248,14 @@ ${lanes.join("\n")} if (assignmentKind) { if (!(localOrExportSymbol.flags & 3 /* Variable */) && !(isInJSFile(node) && localOrExportSymbol.flags & 512 /* ValueModule */)) { const assignmentError = localOrExportSymbol.flags & 384 /* Enum */ ? Diagnostics.Cannot_assign_to_0_because_it_is_an_enum : localOrExportSymbol.flags & 32 /* Class */ ? Diagnostics.Cannot_assign_to_0_because_it_is_a_class : localOrExportSymbol.flags & 1536 /* Module */ ? Diagnostics.Cannot_assign_to_0_because_it_is_a_namespace : localOrExportSymbol.flags & 16 /* Function */ ? Diagnostics.Cannot_assign_to_0_because_it_is_a_function : localOrExportSymbol.flags & 2097152 /* Alias */ ? Diagnostics.Cannot_assign_to_0_because_it_is_an_import : Diagnostics.Cannot_assign_to_0_because_it_is_not_a_variable; - error(node, assignmentError, symbolToString(symbol)); + error2(node, assignmentError, symbolToString(symbol)); return errorType; } if (isReadonlySymbol(localOrExportSymbol)) { if (localOrExportSymbol.flags & 3 /* Variable */) { - error(node, Diagnostics.Cannot_assign_to_0_because_it_is_a_constant, symbolToString(symbol)); + error2(node, Diagnostics.Cannot_assign_to_0_because_it_is_a_constant, symbolToString(symbol)); } else { - error(node, Diagnostics.Cannot_assign_to_0_because_it_is_a_read_only_property, symbolToString(symbol)); + error2(node, Diagnostics.Cannot_assign_to_0_because_it_is_a_read_only_property, symbolToString(symbol)); } return errorType; } @@ -167432,7 +151263,7 @@ ${lanes.join("\n")} const isAlias = localOrExportSymbol.flags & 2097152 /* Alias */; if (localOrExportSymbol.flags & 3 /* Variable */) { if (assignmentKind === 1 /* Definite */) { - return type; + return isInCompoundLikeAssignment(node) ? getBaseTypeOfLiteralType(type) : type; } } else if (isAlias) { declaration = getDeclarationOfAliasSymbol(symbol); @@ -167443,30 +151274,30 @@ ${lanes.join("\n")} return type; } type = getNarrowableTypeForReference(type, node, checkMode); - const isParameter2 = getRootDeclaration(declaration).kind === 168 /* Parameter */; + const isParameter2 = getRootDeclaration(declaration).kind === 169 /* Parameter */; const declarationContainer = getControlFlowContainer(declaration); let flowContainer = getControlFlowContainer(node); const isOuterVariable = flowContainer !== declarationContainer; const isSpreadDestructuringAssignmentTarget = node.parent && node.parent.parent && isSpreadAssignment(node.parent) && isDestructuringAssignmentTarget(node.parent.parent); const isModuleExports = symbol.flags & 134217728 /* ModuleExports */; const typeIsAutomatic = type === autoType || type === autoArrayType; - const isAutomaticTypeInNonNull = typeIsAutomatic && node.parent.kind === 234 /* NonNullExpression */; - while (flowContainer !== declarationContainer && (flowContainer.kind === 217 /* FunctionExpression */ || flowContainer.kind === 218 /* ArrowFunction */ || isObjectLiteralOrClassExpressionMethodOrAccessor(flowContainer)) && (isConstVariable(localOrExportSymbol) && type !== autoArrayType || isParameter2 && !isSymbolAssigned(localOrExportSymbol))) { + const isAutomaticTypeInNonNull = typeIsAutomatic && node.parent.kind === 235 /* NonNullExpression */; + while (flowContainer !== declarationContainer && (flowContainer.kind === 218 /* FunctionExpression */ || flowContainer.kind === 219 /* ArrowFunction */ || isObjectLiteralOrClassExpressionMethodOrAccessor(flowContainer)) && (isConstantVariable(localOrExportSymbol) && type !== autoArrayType || isParameter2 && !isSymbolAssigned(localOrExportSymbol))) { flowContainer = getControlFlowContainer(flowContainer); } - const assumeInitialized = isParameter2 || isAlias || isOuterVariable || isSpreadDestructuringAssignmentTarget || isModuleExports || isSameScopedBindingElement(node, declaration) || type !== autoType && type !== autoArrayType && (!strictNullChecks || (type.flags & (3 /* AnyOrUnknown */ | 16384 /* Void */)) !== 0 || isInTypeQuery(node) || isInAmbientOrTypeNode(node) || node.parent.kind === 280 /* ExportSpecifier */) || node.parent.kind === 234 /* NonNullExpression */ || declaration.kind === 259 /* VariableDeclaration */ && declaration.exclamationToken || declaration.flags & 16777216 /* Ambient */; + const assumeInitialized = isParameter2 || isAlias || isOuterVariable || isSpreadDestructuringAssignmentTarget || isModuleExports || isSameScopedBindingElement(node, declaration) || type !== autoType && type !== autoArrayType && (!strictNullChecks || (type.flags & (3 /* AnyOrUnknown */ | 16384 /* Void */)) !== 0 || isInTypeQuery(node) || isInAmbientOrTypeNode(node) || node.parent.kind === 281 /* ExportSpecifier */) || node.parent.kind === 235 /* NonNullExpression */ || declaration.kind === 260 /* VariableDeclaration */ && declaration.exclamationToken || declaration.flags & 33554432 /* Ambient */; const initialType = isAutomaticTypeInNonNull ? undefinedType : assumeInitialized ? isParameter2 ? removeOptionalityFromDeclaredType(type, declaration) : type : typeIsAutomatic ? undefinedType : getOptionalType(type); const flowType = isAutomaticTypeInNonNull ? getNonNullableType(getFlowTypeOfReference(node, type, initialType, flowContainer)) : getFlowTypeOfReference(node, type, initialType, flowContainer); if (!isEvolvingArrayOperationTarget(node) && (type === autoType || type === autoArrayType)) { if (flowType === autoType || flowType === autoArrayType) { if (noImplicitAny) { - error(getNameOfDeclaration(declaration), Diagnostics.Variable_0_implicitly_has_type_1_in_some_locations_where_its_type_cannot_be_determined, symbolToString(symbol), typeToString(flowType)); - error(node, Diagnostics.Variable_0_implicitly_has_an_1_type, symbolToString(symbol), typeToString(flowType)); + error2(getNameOfDeclaration(declaration), Diagnostics.Variable_0_implicitly_has_type_1_in_some_locations_where_its_type_cannot_be_determined, symbolToString(symbol), typeToString(flowType)); + error2(node, Diagnostics.Variable_0_implicitly_has_an_1_type, symbolToString(symbol), typeToString(flowType)); } return convertAutoToAny(flowType); } } else if (!assumeInitialized && !containsUndefinedType(type) && containsUndefinedType(flowType)) { - error(node, Diagnostics.Variable_0_is_used_before_being_assigned, symbolToString(symbol)); + error2(node, Diagnostics.Variable_0_is_used_before_being_assigned, symbolToString(symbol)); return type; } return assignmentKind ? getBaseTypeOfLiteralType(flowType) : flowType; @@ -167508,7 +151339,7 @@ ${lanes.join("\n")} )); } function checkNestedBlockScopedBinding(node, symbol) { - if (languageVersion >= 2 /* ES2015 */ || (symbol.flags & (2 /* BlockScopedVariable */ | 32 /* Class */)) === 0 || !symbol.valueDeclaration || isSourceFile(symbol.valueDeclaration) || symbol.valueDeclaration.parent.kind === 298 /* CatchClause */) { + if (languageVersion >= 2 /* ES2015 */ || (symbol.flags & (2 /* BlockScopedVariable */ | 32 /* Class */)) === 0 || !symbol.valueDeclaration || isSourceFile(symbol.valueDeclaration) || symbol.valueDeclaration.parent.kind === 299 /* CatchClause */) { return; } const container = getEnclosingBlockScopeContainer(symbol.valueDeclaration); @@ -167518,7 +151349,7 @@ ${lanes.join("\n")} if (isCaptured) { let capturesBlockScopeBindingInLoopBody = true; if (isForStatement(container)) { - const varDeclList = getAncestor(symbol.valueDeclaration, 260 /* VariableDeclarationList */); + const varDeclList = getAncestor(symbol.valueDeclaration, 261 /* VariableDeclarationList */); if (varDeclList && varDeclList.parent === container) { const part = getPartOfForStatementContainingNode(node.parent, container); if (part) { @@ -167537,9 +151368,9 @@ ${lanes.join("\n")} } } if (isForStatement(container)) { - const varDeclList = getAncestor(symbol.valueDeclaration, 260 /* VariableDeclarationList */); + const varDeclList = getAncestor(symbol.valueDeclaration, 261 /* VariableDeclarationList */); if (varDeclList && varDeclList.parent === container && isAssignedInBodyOfForStatement(node, container)) { - getNodeLinks(symbol.valueDeclaration).flags |= 262144 /* NeedsLoopOutParameter */; + getNodeLinks(symbol.valueDeclaration).flags |= 65536 /* NeedsLoopOutParameter */; } } getNodeLinks(symbol.valueDeclaration).flags |= 32768 /* BlockScopedBindingInLoop */; @@ -167554,13 +151385,13 @@ ${lanes.join("\n")} } function isAssignedInBodyOfForStatement(node, container) { let current = node; - while (current.parent.kind === 216 /* ParenthesizedExpression */) { + while (current.parent.kind === 217 /* ParenthesizedExpression */) { current = current.parent; } let isAssigned = false; if (isAssignmentTarget(current)) { isAssigned = true; - } else if (current.parent.kind === 223 /* PrefixUnaryExpression */ || current.parent.kind === 224 /* PostfixUnaryExpression */) { + } else if (current.parent.kind === 224 /* PrefixUnaryExpression */ || current.parent.kind === 225 /* PostfixUnaryExpression */) { const expr = current.parent; isAssigned = expr.operator === 46 /* PlusPlusToken */ || expr.operator === 47 /* MinusMinusToken */; } @@ -167571,7 +151402,7 @@ ${lanes.join("\n")} } function captureLexicalThis(node, container) { getNodeLinks(node).flags |= 2 /* LexicalThis */; - if (container.kind === 171 /* PropertyDeclaration */ || container.kind === 175 /* Constructor */) { + if (container.kind === 172 /* PropertyDeclaration */ || container.kind === 176 /* Constructor */) { const classNode = container.parent; getNodeLinks(classNode).flags |= 4 /* CaptureThis */; } else { @@ -167596,13 +151427,13 @@ ${lanes.join("\n")} /*noCacheCheck*/ false )) { - error(node, diagnosticMessage); + error2(node, diagnosticMessage); } } } function checkThisInStaticClassFieldInitializerInDecoratedClass(thisExpression, container) { if (isPropertyDeclaration(container) && hasStaticModifier(container) && legacyDecorators && container.initializer && textRangeContainsPositionInclusive(container.initializer, thisExpression.pos) && hasDecorators(container.parent)) { - error(thisExpression, Diagnostics.Cannot_use_this_in_a_static_property_initializer_of_a_decorated_class); + error2(thisExpression, Diagnostics.Cannot_use_this_in_a_static_property_initializer_of_a_decorated_class); } } function checkThisExpression(node) { @@ -167616,11 +151447,11 @@ ${lanes.join("\n")} ); let capturedByArrowFunction = false; let thisInComputedPropertyName = false; - if (container.kind === 175 /* Constructor */) { + if (container.kind === 176 /* Constructor */) { checkThisBeforeSuper(node, container, Diagnostics.super_must_be_called_before_accessing_this_in_the_constructor_of_a_derived_class); } while (true) { - if (container.kind === 218 /* ArrowFunction */) { + if (container.kind === 219 /* ArrowFunction */) { container = getThisContainer( container, /*includeArrowFunctions*/ @@ -167629,7 +151460,7 @@ ${lanes.join("\n")} ); capturedByArrowFunction = true; } - if (container.kind === 166 /* ComputedPropertyName */) { + if (container.kind === 167 /* ComputedPropertyName */) { container = getThisContainer( container, !capturedByArrowFunction, @@ -167643,18 +151474,18 @@ ${lanes.join("\n")} } checkThisInStaticClassFieldInitializerInDecoratedClass(node, container); if (thisInComputedPropertyName) { - error(node, Diagnostics.this_cannot_be_referenced_in_a_computed_property_name); + error2(node, Diagnostics.this_cannot_be_referenced_in_a_computed_property_name); } else { switch (container.kind) { - case 266 /* ModuleDeclaration */: - error(node, Diagnostics.this_cannot_be_referenced_in_a_module_or_namespace_body); + case 267 /* ModuleDeclaration */: + error2(node, Diagnostics.this_cannot_be_referenced_in_a_module_or_namespace_body); break; - case 265 /* EnumDeclaration */: - error(node, Diagnostics.this_cannot_be_referenced_in_current_location); + case 266 /* EnumDeclaration */: + error2(node, Diagnostics.this_cannot_be_referenced_in_current_location); break; - case 175 /* Constructor */: + case 176 /* Constructor */: if (isInConstructorArgumentInitializer(node, container)) { - error(node, Diagnostics.this_cannot_be_referenced_in_constructor_arguments); + error2(node, Diagnostics.this_cannot_be_referenced_in_constructor_arguments); } break; } @@ -167671,9 +151502,9 @@ ${lanes.join("\n")} if (noImplicitThis) { const globalThisType2 = getTypeOfSymbol(globalThisSymbol); if (type === globalThisType2 && capturedByArrowFunction) { - error(node, Diagnostics.The_containing_arrow_function_captures_the_global_value_of_this); + error2(node, Diagnostics.The_containing_arrow_function_captures_the_global_value_of_this); } else if (!type) { - const diag2 = error(node, Diagnostics.this_implicitly_has_type_any_because_it_does_not_have_a_type_annotation); + const diag2 = error2(node, Diagnostics.this_implicitly_has_type_any_because_it_does_not_have_a_type_annotation); if (!isSourceFile(container)) { const outsideThis = tryGetThisTypeAt(container); if (outsideThis && outsideThis !== globalThisType2) { @@ -167746,36 +151577,33 @@ ${lanes.join("\n")} } } function getClassNameFromPrototypeMethod(container) { - if (container.kind === 217 /* FunctionExpression */ && isBinaryExpression(container.parent) && getAssignmentDeclarationKind(container.parent) === 3 /* PrototypeProperty */) { + if (container.kind === 218 /* FunctionExpression */ && isBinaryExpression(container.parent) && getAssignmentDeclarationKind(container.parent) === 3 /* PrototypeProperty */) { return container.parent.left.expression.expression; - } else if (container.kind === 173 /* MethodDeclaration */ && container.parent.kind === 209 /* ObjectLiteralExpression */ && isBinaryExpression(container.parent.parent) && getAssignmentDeclarationKind(container.parent.parent) === 6 /* Prototype */) { + } else if (container.kind === 174 /* MethodDeclaration */ && container.parent.kind === 210 /* ObjectLiteralExpression */ && isBinaryExpression(container.parent.parent) && getAssignmentDeclarationKind(container.parent.parent) === 6 /* Prototype */) { return container.parent.parent.left.expression; - } else if (container.kind === 217 /* FunctionExpression */ && container.parent.kind === 302 /* PropertyAssignment */ && container.parent.parent.kind === 209 /* ObjectLiteralExpression */ && isBinaryExpression(container.parent.parent.parent) && getAssignmentDeclarationKind(container.parent.parent.parent) === 6 /* Prototype */) { + } else if (container.kind === 218 /* FunctionExpression */ && container.parent.kind === 303 /* PropertyAssignment */ && container.parent.parent.kind === 210 /* ObjectLiteralExpression */ && isBinaryExpression(container.parent.parent.parent) && getAssignmentDeclarationKind(container.parent.parent.parent) === 6 /* Prototype */) { return container.parent.parent.parent.left.expression; - } else if (container.kind === 217 /* FunctionExpression */ && isPropertyAssignment(container.parent) && isIdentifier(container.parent.name) && (container.parent.name.escapedText === "value" || container.parent.name.escapedText === "get" || container.parent.name.escapedText === "set") && isObjectLiteralExpression(container.parent.parent) && isCallExpression(container.parent.parent.parent) && container.parent.parent.parent.arguments[2] === container.parent.parent && getAssignmentDeclarationKind(container.parent.parent.parent) === 9 /* ObjectDefinePrototypeProperty */) { + } else if (container.kind === 218 /* FunctionExpression */ && isPropertyAssignment(container.parent) && isIdentifier(container.parent.name) && (container.parent.name.escapedText === "value" || container.parent.name.escapedText === "get" || container.parent.name.escapedText === "set") && isObjectLiteralExpression(container.parent.parent) && isCallExpression(container.parent.parent.parent) && container.parent.parent.parent.arguments[2] === container.parent.parent && getAssignmentDeclarationKind(container.parent.parent.parent) === 9 /* ObjectDefinePrototypeProperty */) { return container.parent.parent.parent.arguments[0].expression; } else if (isMethodDeclaration(container) && isIdentifier(container.name) && (container.name.escapedText === "value" || container.name.escapedText === "get" || container.name.escapedText === "set") && isObjectLiteralExpression(container.parent) && isCallExpression(container.parent.parent) && container.parent.parent.arguments[2] === container.parent && getAssignmentDeclarationKind(container.parent.parent) === 9 /* ObjectDefinePrototypeProperty */) { return container.parent.parent.arguments[0].expression; } } function getTypeForThisExpressionFromJSDoc(node) { - const jsdocType = getJSDocType(node); - if (jsdocType && jsdocType.kind === 323 /* JSDocFunctionType */) { - const jsDocFunctionType = jsdocType; - if (jsDocFunctionType.parameters.length > 0 && jsDocFunctionType.parameters[0].name && jsDocFunctionType.parameters[0].name.escapedText === "this" /* This */) { - return getTypeFromTypeNode(jsDocFunctionType.parameters[0].type); - } - } const thisTag = getJSDocThisTag(node); if (thisTag && thisTag.typeExpression) { return getTypeFromTypeNode(thisTag.typeExpression); } + const signature = getSignatureOfTypeTag(node); + if (signature) { + return getThisTypeOfSignature(signature); + } } function isInConstructorArgumentInitializer(node, constructorDecl) { - return !!findAncestor(node, (n) => isFunctionLikeDeclaration(n) ? "quit" : n.kind === 168 /* Parameter */ && n.parent === constructorDecl); + return !!findAncestor(node, (n) => isFunctionLikeDeclaration(n) ? "quit" : n.kind === 169 /* Parameter */ && n.parent === constructorDecl); } function checkSuperExpression(node) { - const isCallExpression2 = node.parent.kind === 212 /* CallExpression */ && node.parent.expression === node; + const isCallExpression2 = node.parent.kind === 213 /* CallExpression */ && node.parent.expression === node; const immediateContainer = getSuperContainer( node, /*stopOnFunctions*/ @@ -167785,8 +151613,8 @@ ${lanes.join("\n")} let needToCaptureLexicalThis = false; let inAsyncFunction = false; if (!isCallExpression2) { - while (container && container.kind === 218 /* ArrowFunction */) { - if (hasSyntacticModifier(container, 512 /* Async */)) + while (container && container.kind === 219 /* ArrowFunction */) { + if (hasSyntacticModifier(container, 1024 /* Async */)) inAsyncFunction = true; container = getSuperContainer( container, @@ -167795,24 +151623,24 @@ ${lanes.join("\n")} ); needToCaptureLexicalThis = languageVersion < 2 /* ES2015 */; } - if (container && hasSyntacticModifier(container, 512 /* Async */)) + if (container && hasSyntacticModifier(container, 1024 /* Async */)) inAsyncFunction = true; } let nodeCheckFlag = 0; if (!container || !isLegalUsageOfSuperExpression(container)) { - const current = findAncestor(node, (n) => n === container ? "quit" : n.kind === 166 /* ComputedPropertyName */); - if (current && current.kind === 166 /* ComputedPropertyName */) { - error(node, Diagnostics.super_cannot_be_referenced_in_a_computed_property_name); + const current = findAncestor(node, (n) => n === container ? "quit" : n.kind === 167 /* ComputedPropertyName */); + if (current && current.kind === 167 /* ComputedPropertyName */) { + error2(node, Diagnostics.super_cannot_be_referenced_in_a_computed_property_name); } else if (isCallExpression2) { - error(node, Diagnostics.Super_calls_are_not_permitted_outside_constructors_or_in_nested_functions_inside_constructors); - } else if (!container || !container.parent || !(isClassLike(container.parent) || container.parent.kind === 209 /* ObjectLiteralExpression */)) { - error(node, Diagnostics.super_can_only_be_referenced_in_members_of_derived_classes_or_object_literal_expressions); + error2(node, Diagnostics.Super_calls_are_not_permitted_outside_constructors_or_in_nested_functions_inside_constructors); + } else if (!container || !container.parent || !(isClassLike(container.parent) || container.parent.kind === 210 /* ObjectLiteralExpression */)) { + error2(node, Diagnostics.super_can_only_be_referenced_in_members_of_derived_classes_or_object_literal_expressions); } else { - error(node, Diagnostics.super_property_access_is_permitted_only_in_a_constructor_member_function_or_member_accessor_of_a_derived_class); + error2(node, Diagnostics.super_property_access_is_permitted_only_in_a_constructor_member_function_or_member_accessor_of_a_derived_class); } return errorType; } - if (!isCallExpression2 && immediateContainer.kind === 175 /* Constructor */) { + if (!isCallExpression2 && immediateContainer.kind === 176 /* Constructor */) { checkThisBeforeSuper(node, container, Diagnostics.super_must_be_called_before_accessing_a_property_of_super_in_the_constructor_of_a_derived_class); } if (isStatic(container) || isCallExpression2) { @@ -167820,7 +151648,7 @@ ${lanes.join("\n")} if (!isCallExpression2 && languageVersion >= 2 /* ES2015 */ && languageVersion <= 8 /* ES2021 */ && (isPropertyDeclaration(container) || isClassStaticBlockDeclaration(container))) { forEachEnclosingBlockScopeContainer(node.parent, (current) => { if (!isSourceFile(current) || isExternalOrCommonJsModule(current)) { - getNodeLinks(current).flags |= 8388608 /* ContainsSuperPropertyInStaticInitializer */; + getNodeLinks(current).flags |= 2097152 /* ContainsSuperPropertyInStaticInitializer */; } }); } @@ -167828,7 +151656,7 @@ ${lanes.join("\n")} nodeCheckFlag = 16 /* SuperInstance */; } getNodeLinks(node).flags |= nodeCheckFlag; - if (container.kind === 173 /* MethodDeclaration */ && inAsyncFunction) { + if (container.kind === 174 /* MethodDeclaration */ && inAsyncFunction) { if (isSuperProperty(node.parent) && isAssignmentTarget(node.parent)) { getNodeLinks(container).flags |= 256 /* MethodWithSuperPropertyAssignmentInAsync */; } else { @@ -167838,9 +151666,9 @@ ${lanes.join("\n")} if (needToCaptureLexicalThis) { captureLexicalThis(node.parent, container); } - if (container.parent.kind === 209 /* ObjectLiteralExpression */) { + if (container.parent.kind === 210 /* ObjectLiteralExpression */) { if (languageVersion < 2 /* ES2015 */) { - error(node, Diagnostics.super_is_only_allowed_in_members_of_object_literal_expressions_when_option_target_is_ES2015_or_higher); + error2(node, Diagnostics.super_is_only_allowed_in_members_of_object_literal_expressions_when_option_target_is_ES2015_or_higher); return errorType; } else { return anyType; @@ -167848,28 +151676,31 @@ ${lanes.join("\n")} } const classLikeDeclaration = container.parent; if (!getClassExtendsHeritageElement(classLikeDeclaration)) { - error(node, Diagnostics.super_can_only_be_referenced_in_a_derived_class); + error2(node, Diagnostics.super_can_only_be_referenced_in_a_derived_class); return errorType; } + if (classDeclarationExtendsNull(classLikeDeclaration)) { + return isCallExpression2 ? errorType : nullWideningType; + } const classType = getDeclaredTypeOfSymbol(getSymbolOfDeclaration(classLikeDeclaration)); const baseClassType = classType && getBaseTypes(classType)[0]; if (!baseClassType) { return errorType; } - if (container.kind === 175 /* Constructor */ && isInConstructorArgumentInitializer(node, container)) { - error(node, Diagnostics.super_cannot_be_referenced_in_constructor_arguments); + if (container.kind === 176 /* Constructor */ && isInConstructorArgumentInitializer(node, container)) { + error2(node, Diagnostics.super_cannot_be_referenced_in_constructor_arguments); return errorType; } return nodeCheckFlag === 32 /* SuperStatic */ ? getBaseConstructorTypeOfClass(classType) : getTypeWithThisArgument(baseClassType, classType.thisType); function isLegalUsageOfSuperExpression(container2) { if (isCallExpression2) { - return container2.kind === 175 /* Constructor */; + return container2.kind === 176 /* Constructor */; } else { - if (isClassLike(container2.parent) || container2.parent.kind === 209 /* ObjectLiteralExpression */) { + if (isClassLike(container2.parent) || container2.parent.kind === 210 /* ObjectLiteralExpression */) { if (isStatic(container2)) { - return container2.kind === 173 /* MethodDeclaration */ || container2.kind === 172 /* MethodSignature */ || container2.kind === 176 /* GetAccessor */ || container2.kind === 177 /* SetAccessor */ || container2.kind === 171 /* PropertyDeclaration */ || container2.kind === 174 /* ClassStaticBlockDeclaration */; + return container2.kind === 174 /* MethodDeclaration */ || container2.kind === 173 /* MethodSignature */ || container2.kind === 177 /* GetAccessor */ || container2.kind === 178 /* SetAccessor */ || container2.kind === 172 /* PropertyDeclaration */ || container2.kind === 175 /* ClassStaticBlockDeclaration */; } else { - return container2.kind === 173 /* MethodDeclaration */ || container2.kind === 172 /* MethodSignature */ || container2.kind === 176 /* GetAccessor */ || container2.kind === 177 /* SetAccessor */ || container2.kind === 171 /* PropertyDeclaration */ || container2.kind === 170 /* PropertySignature */ || container2.kind === 175 /* Constructor */; + return container2.kind === 174 /* MethodDeclaration */ || container2.kind === 173 /* MethodSignature */ || container2.kind === 177 /* GetAccessor */ || container2.kind === 178 /* SetAccessor */ || container2.kind === 172 /* PropertyDeclaration */ || container2.kind === 171 /* PropertySignature */ || container2.kind === 176 /* Constructor */; } } } @@ -167877,7 +151708,7 @@ ${lanes.join("\n")} } } function getContainingObjectLiteral(func) { - return (func.kind === 173 /* MethodDeclaration */ || func.kind === 176 /* GetAccessor */ || func.kind === 177 /* SetAccessor */) && func.parent.kind === 209 /* ObjectLiteralExpression */ ? func.parent : func.kind === 217 /* FunctionExpression */ && func.parent.kind === 302 /* PropertyAssignment */ ? func.parent.parent : void 0; + return (func.kind === 174 /* MethodDeclaration */ || func.kind === 177 /* GetAccessor */ || func.kind === 178 /* SetAccessor */) && func.parent.kind === 210 /* ObjectLiteralExpression */ ? func.parent : func.kind === 218 /* FunctionExpression */ && func.parent.kind === 303 /* PropertyAssignment */ ? func.parent.parent : void 0; } function getThisTypeArgument(type) { return getObjectFlags(type) & 4 /* Reference */ && type.target === globalThisType ? getTypeArguments(type)[0] : void 0; @@ -167887,8 +151718,27 @@ ${lanes.join("\n")} return t.flags & 2097152 /* Intersection */ ? forEach(t.types, getThisTypeArgument) : getThisTypeArgument(t); }); } + function getThisTypeOfObjectLiteralFromContextualType(containingLiteral, contextualType) { + let literal = containingLiteral; + let type = contextualType; + while (type) { + const thisType = getThisTypeFromContextualType(type); + if (thisType) { + return thisType; + } + if (literal.parent.kind !== 303 /* PropertyAssignment */) { + break; + } + literal = literal.parent.parent; + type = getApparentTypeOfContextualType( + literal, + /*contextFlags*/ + void 0 + ); + } + } function getContextualThisParameterType(func) { - if (func.kind === 218 /* ArrowFunction */) { + if (func.kind === 219 /* ArrowFunction */) { return void 0; } if (isContextSensitiveFunctionOrObjectLiteralMethod(func)) { @@ -167909,27 +151759,14 @@ ${lanes.join("\n")} /*contextFlags*/ void 0 ); - let literal = containingLiteral; - let type = contextualType; - while (type) { - const thisType = getThisTypeFromContextualType(type); - if (thisType) { - return instantiateType(thisType, getMapperFromContext(getInferenceContext(containingLiteral))); - } - if (literal.parent.kind !== 302 /* PropertyAssignment */) { - break; - } - literal = literal.parent.parent; - type = getApparentTypeOfContextualType( - literal, - /*contextFlags*/ - void 0 - ); + const thisType = getThisTypeOfObjectLiteralFromContextualType(containingLiteral, contextualType); + if (thisType) { + return instantiateType(thisType, getMapperFromContext(getInferenceContext(containingLiteral))); } return getWidenedType(contextualType ? getNonNullableType(contextualType) : checkExpressionCached(containingLiteral)); } const parent2 = walkUpParenthesizedExpressions(func.parent); - if (parent2.kind === 225 /* BinaryExpression */ && parent2.operatorToken.kind === 64 /* EqualsToken */) { + if (isAssignmentExpression(parent2)) { const target = parent2.left; if (isAccessExpression(target)) { const { expression } = target; @@ -167984,11 +151821,11 @@ ${lanes.join("\n")} return getTypeFromTypeNode(typeNode); } switch (declaration.kind) { - case 168 /* Parameter */: + case 169 /* Parameter */: return getContextuallyTypedParameterType(declaration); - case 207 /* BindingElement */: + case 208 /* BindingElement */: return getContextualTypeForBindingElement(declaration, contextFlags); - case 171 /* PropertyDeclaration */: + case 172 /* PropertyDeclaration */: if (isStatic(declaration)) { return getContextualTypeForStaticPropertyDeclaration(declaration, contextFlags); } @@ -167997,10 +151834,10 @@ ${lanes.join("\n")} function getContextualTypeForBindingElement(declaration, contextFlags) { const parent2 = declaration.parent.parent; const name = declaration.propertyName || declaration.name; - const parentType = getContextualTypeForVariableLikeDeclaration(parent2, contextFlags) || parent2.kind !== 207 /* BindingElement */ && parent2.initializer && checkDeclarationInitializer(parent2, declaration.dotDotDotToken ? 64 /* RestBindingElement */ : 0 /* Normal */); + const parentType = getContextualTypeForVariableLikeDeclaration(parent2, contextFlags) || parent2.kind !== 208 /* BindingElement */ && parent2.initializer && checkDeclarationInitializer(parent2, declaration.dotDotDotToken ? 32 /* RestBindingElement */ : 0 /* Normal */); if (!parentType || isBindingPattern(name) || isComputedNonLiteralName(name)) return void 0; - if (parent2.name.kind === 206 /* ArrayBindingPattern */) { + if (parent2.name.kind === 207 /* ArrayBindingPattern */) { const index = indexOfNode(declaration.parent.elements, declaration); if (index < 0) return void 0; @@ -168118,7 +151955,24 @@ ${lanes.join("\n")} } const signature = getContextualSignatureForFunctionLikeDeclaration(functionDecl); if (signature && !isResolvingReturnTypeOfSignature(signature)) { - return getReturnTypeOfSignature(signature); + const returnType2 = getReturnTypeOfSignature(signature); + const functionFlags = getFunctionFlags(functionDecl); + if (functionFlags & 1 /* Generator */) { + return filterType(returnType2, (t) => { + return !!(t.flags & (3 /* AnyOrUnknown */ | 16384 /* Void */ | 58982400 /* InstantiableNonPrimitive */)) || checkGeneratorInstantiationAssignabilityToReturnType( + t, + functionFlags, + /*errorNode*/ + void 0 + ); + }); + } + if (functionFlags & 2 /* Async */) { + return filterType(returnType2, (t) => { + return !!(t.flags & (3 /* AnyOrUnknown */ | 16384 /* Void */ | 58982400 /* InstantiableNonPrimitive */)) || !!getAwaitedTypeOfPromise(t); + }); + } + return returnType2; } const iife = getImmediatelyInvokedFunctionExpression(functionDecl); if (iife) { @@ -168150,7 +152004,7 @@ ${lanes.join("\n")} return signature ? getOrCreateTypeFromSignature(signature) : void 0; } function getContextualTypeForSubstitutionExpression(template, substitutionExpression) { - if (template.parent.kind === 214 /* TaggedTemplateExpression */) { + if (template.parent.kind === 215 /* TaggedTemplateExpression */) { return getContextualTypeForArgument(template.parent, substitutionExpression); } return void 0; @@ -168341,7 +152195,7 @@ ${lanes.join("\n")} } else if (t.flags & 3670016 /* StructuredType */) { const prop = getPropertyOfType(t, name); if (prop) { - return isCircularMappedProperty(prop) ? void 0 : getTypeOfSymbol(prop); + return isCircularMappedProperty(prop) ? void 0 : removeMissingType(getTypeOfSymbol(prop), !!(prop && prop.flags & 16777216 /* Optional */)); } if (isTupleType(t) && isNumericLiteralName(name) && +name >= 0) { const restType = getElementTypeOfSliceOfTupleType( @@ -168368,7 +152222,7 @@ ${lanes.join("\n")} } function getContextualTypeForObjectLiteralMethod(node, contextFlags) { Debug.assert(isObjectLiteralMethod(node)); - if (node.flags & 33554432 /* InWithStatement */) { + if (node.flags & 67108864 /* InWithStatement */) { return void 0; } return getContextualTypeForObjectLiteralElement(node, contextFlags); @@ -168426,7 +152280,7 @@ ${lanes.join("\n")} (t) => { if (isTupleType(t)) { if ((firstSpreadIndex === void 0 || index < firstSpreadIndex) && index < t.target.fixedLength) { - return getTypeArguments(t)[index]; + return removeMissingType(getTypeArguments(t)[index], !!(t.target.elementFlags[index] && 2 /* Optional */)); } const offset = length2 !== void 0 && (lastSpreadIndex === void 0 || index > lastSpreadIndex) ? length2 - index : 0; const fixedEndLength = offset > 0 && t.target.hasRestElement ? getEndElementCount(t.target, 3 /* Fixed */) : 0; @@ -168504,16 +152358,17 @@ ${lanes.join("\n")} case 9 /* NumericLiteral */: case 10 /* BigIntLiteral */: case 15 /* NoSubstitutionTemplateLiteral */: + case 228 /* TemplateExpression */: case 112 /* TrueKeyword */: case 97 /* FalseKeyword */: case 106 /* NullKeyword */: case 80 /* Identifier */: case 157 /* UndefinedKeyword */: return true; - case 210 /* PropertyAccessExpression */: - case 216 /* ParenthesizedExpression */: + case 211 /* PropertyAccessExpression */: + case 217 /* ParenthesizedExpression */: return isPossiblyDiscriminantValue(node.expression); - case 293 /* JsxExpression */: + case 294 /* JsxExpression */: return !node.expression || isPossiblyDiscriminantValue(node.expression); } return false; @@ -168523,8 +152378,19 @@ ${lanes.join("\n")} contextualType, concatenate( map( - filter(node.properties, (p) => !!p.symbol && p.kind === 302 /* PropertyAssignment */ && isPossiblyDiscriminantValue(p.initializer) && isDiscriminantProperty(contextualType, p.symbol.escapedName)), - (prop) => [() => getContextFreeTypeOfExpression(prop.initializer), prop.symbol.escapedName] + filter(node.properties, (p) => { + if (!p.symbol) { + return false; + } + if (p.kind === 303 /* PropertyAssignment */) { + return isPossiblyDiscriminantValue(p.initializer) && isDiscriminantProperty(contextualType, p.symbol.escapedName); + } + if (p.kind === 304 /* ShorthandPropertyAssignment */) { + return isDiscriminantProperty(contextualType, p.symbol.escapedName); + } + return false; + }), + (prop) => [() => getContextFreeTypeOfExpression(prop.kind === 303 /* PropertyAssignment */ ? prop.initializer : prop.name), prop.symbol.escapedName] ), map( filter(getPropertiesOfType(contextualType), (s) => { @@ -168543,7 +152409,7 @@ ${lanes.join("\n")} contextualType, concatenate( map( - filter(node.properties, (p) => !!p.symbol && p.kind === 290 /* JsxAttribute */ && isDiscriminantProperty(contextualType, p.symbol.escapedName) && (!p.initializer || isPossiblyDiscriminantValue(p.initializer))), + filter(node.properties, (p) => !!p.symbol && p.kind === 291 /* JsxAttribute */ && isDiscriminantProperty(contextualType, p.symbol.escapedName) && (!p.initializer || isPossiblyDiscriminantValue(p.initializer))), (prop) => [!prop.initializer ? () => trueType : () => getContextFreeTypeOfExpression(prop.initializer), prop.symbol.escapedName] ), map( @@ -168608,7 +152474,7 @@ ${lanes.join("\n")} } function getContextualType2(node, contextFlags) { var _a; - if (node.flags & 33554432 /* InWithStatement */) { + if (node.flags & 67108864 /* InWithStatement */) { return void 0; } const index = findContextualNode( @@ -168621,47 +152487,47 @@ ${lanes.join("\n")} } const { parent: parent2 } = node; switch (parent2.kind) { - case 259 /* VariableDeclaration */: - case 168 /* Parameter */: - case 171 /* PropertyDeclaration */: - case 170 /* PropertySignature */: - case 207 /* BindingElement */: + case 260 /* VariableDeclaration */: + case 169 /* Parameter */: + case 172 /* PropertyDeclaration */: + case 171 /* PropertySignature */: + case 208 /* BindingElement */: return getContextualTypeForInitializerExpression(node, contextFlags); - case 218 /* ArrowFunction */: - case 252 /* ReturnStatement */: + case 219 /* ArrowFunction */: + case 253 /* ReturnStatement */: return getContextualTypeForReturnExpression(node, contextFlags); - case 228 /* YieldExpression */: + case 229 /* YieldExpression */: return getContextualTypeForYieldOperand(parent2, contextFlags); - case 222 /* AwaitExpression */: + case 223 /* AwaitExpression */: return getContextualTypeForAwaitOperand(parent2, contextFlags); - case 212 /* CallExpression */: - case 213 /* NewExpression */: + case 213 /* CallExpression */: + case 214 /* NewExpression */: return getContextualTypeForArgument(parent2, node); - case 169 /* Decorator */: + case 170 /* Decorator */: return getContextualTypeForDecorator(parent2); - case 215 /* TypeAssertionExpression */: - case 233 /* AsExpression */: + case 216 /* TypeAssertionExpression */: + case 234 /* AsExpression */: return isConstTypeReference(parent2.type) ? getContextualType2(parent2, contextFlags) : getTypeFromTypeNode(parent2.type); - case 225 /* BinaryExpression */: + case 226 /* BinaryExpression */: return getContextualTypeForBinaryOperand(node, contextFlags); - case 302 /* PropertyAssignment */: - case 303 /* ShorthandPropertyAssignment */: + case 303 /* PropertyAssignment */: + case 304 /* ShorthandPropertyAssignment */: return getContextualTypeForObjectLiteralElement(parent2, contextFlags); - case 304 /* SpreadAssignment */: + case 305 /* SpreadAssignment */: return getContextualType2(parent2.parent, contextFlags); - case 208 /* ArrayLiteralExpression */: { + case 209 /* ArrayLiteralExpression */: { const arrayLiteral = parent2; const type = getApparentTypeOfContextualType(arrayLiteral, contextFlags); const elementIndex = indexOfNode(arrayLiteral.elements, node); const spreadIndices = (_a = getNodeLinks(arrayLiteral)).spreadIndices ?? (_a.spreadIndices = getSpreadIndices(arrayLiteral.elements)); return getContextualTypeForElementExpression(type, elementIndex, arrayLiteral.elements.length, spreadIndices.first, spreadIndices.last); } - case 226 /* ConditionalExpression */: + case 227 /* ConditionalExpression */: return getContextualTypeForConditionalOperand(node, contextFlags); - case 238 /* TemplateSpan */: - Debug.assert(parent2.parent.kind === 227 /* TemplateExpression */); + case 239 /* TemplateSpan */: + Debug.assert(parent2.parent.kind === 228 /* TemplateExpression */); return getContextualTypeForSubstitutionExpression(parent2.parent, node); - case 216 /* ParenthesizedExpression */: { + case 217 /* ParenthesizedExpression */: { if (isInJSFile(parent2)) { if (isJSDocSatisfiesExpression(parent2)) { return getTypeFromTypeNode(getJSDocSatisfiesExpressionType(parent2)); @@ -168673,19 +152539,19 @@ ${lanes.join("\n")} } return getContextualType2(parent2, contextFlags); } - case 234 /* NonNullExpression */: + case 235 /* NonNullExpression */: return getContextualType2(parent2, contextFlags); - case 237 /* SatisfiesExpression */: + case 238 /* SatisfiesExpression */: return getTypeFromTypeNode(parent2.type); - case 276 /* ExportAssignment */: + case 277 /* ExportAssignment */: return tryGetTypeFromEffectiveTypeNode(parent2); - case 293 /* JsxExpression */: + case 294 /* JsxExpression */: return getContextualTypeForJsxExpression(parent2, contextFlags); - case 290 /* JsxAttribute */: - case 292 /* JsxSpreadAttribute */: + case 291 /* JsxAttribute */: + case 293 /* JsxSpreadAttribute */: return getContextualTypeForJsxAttribute(parent2, contextFlags); - case 285 /* JsxOpeningElement */: - case 284 /* JsxSelfClosingElement */: + case 286 /* JsxOpeningElement */: + case 285 /* JsxSelfClosingElement */: return getContextualJsxElementAttributesType(parent2, contextFlags); } return void 0; @@ -168812,7 +152678,7 @@ ${lanes.join("\n")} let attributesType = forcedLookupLocation === void 0 ? getTypeOfFirstParameterOfSignatureWithFallback(sig, unknownType) : forcedLookupLocation === "" ? getReturnTypeOfSignature(sig) : getJsxPropsTypeForSignatureFromMember(sig, forcedLookupLocation); if (!attributesType) { if (!!forcedLookupLocation && !!length(context.attributes.properties)) { - error(context, Diagnostics.JSX_element_class_does_not_support_attributes_because_it_does_not_have_a_0_property, unescapeLeadingUnderscores(forcedLookupLocation)); + error2(context, Diagnostics.JSX_element_class_does_not_support_attributes_because_it_does_not_have_a_0_property, unescapeLeadingUnderscores(forcedLookupLocation)); } return unknownType; } @@ -168914,7 +152780,7 @@ ${lanes.join("\n")} /*resolvedTypePredicate*/ void 0, minArgCount, - (left.flags | right.flags) & 39 /* PropagatingFlags */ + (left.flags | right.flags) & 167 /* PropagatingFlags */ ); result.compositeKind = 2097152 /* Intersection */; result.compositeSignatures = concatenate(left.compositeKind === 2097152 /* Intersection */ && left.compositeSignatures || [left], [right]); @@ -168945,7 +152811,7 @@ ${lanes.join("\n")} return isFunctionExpressionOrArrowFunction(node) || isObjectLiteralMethod(node) ? getContextualSignature(node) : void 0; } function getContextualSignature(node) { - Debug.assert(node.kind !== 173 /* MethodDeclaration */ || isObjectLiteralMethod(node)); + Debug.assert(node.kind !== 174 /* MethodDeclaration */ || isObjectLiteralMethod(node)); const typeTagSignature = getSignatureOfTypeTag(node); if (typeTagSignature) { return typeTagSignature; @@ -168996,7 +152862,11 @@ ${lanes.join("\n")} return node.isSpread ? getIndexedAccessType(node.type, numberType) : node.type; } function hasDefaultValue(node) { - return node.kind === 207 /* BindingElement */ && !!node.initializer || node.kind === 225 /* BinaryExpression */ && node.operatorToken.kind === 64 /* EqualsToken */; + return node.kind === 208 /* BindingElement */ && !!node.initializer || node.kind === 226 /* BinaryExpression */ && node.operatorToken.kind === 64 /* EqualsToken */; + } + function isSpreadIntoCallOrNew(node) { + const parent2 = walkUpParenthesizedExpressions(node.parent); + return isSpreadElement(parent2) && isCallOrNewExpression(parent2.parent); } function checkArrayLiteral(node, checkMode, forceTuple) { const elements = node.elements; @@ -169005,18 +152875,17 @@ ${lanes.join("\n")} const elementFlags = []; pushCachedContextualType(node); const inDestructuringPattern = isAssignmentTarget(node); - const isSpreadIntoCallOrNew = isSpreadElement(node.parent) && isCallOrNewExpression(node.parent.parent); - const inConstContext = isSpreadIntoCallOrNew || isConstContext(node); + const inConstContext = isConstContext(node); const contextualType = getApparentTypeOfContextualType( node, /*contextFlags*/ void 0 ); - const inTupleContext = isSpreadIntoCallOrNew || !!contextualType && someType(contextualType, isTupleLikeType); + const inTupleContext = isSpreadIntoCallOrNew(node) || !!contextualType && someType(contextualType, isTupleLikeType); let hasOmittedExpression = false; for (let i = 0; i < elementCount; i++) { const e = elements[i]; - if (e.kind === 229 /* SpreadElement */) { + if (e.kind === 230 /* SpreadElement */) { if (languageVersion < 2 /* ES2015 */) { checkExternalEmitHelpers(e, compilerOptions.downlevelIteration ? 1536 /* SpreadIncludes */ : 1024 /* SpreadArray */); } @@ -169040,7 +152909,7 @@ ${lanes.join("\n")} elementTypes.push(checkIteratedTypeOrElementType(33 /* Spread */, spreadType, undefinedType, e.expression)); elementFlags.push(4 /* Rest */); } - } else if (exactOptionalPropertyTypes && e.kind === 231 /* OmittedExpression */) { + } else if (exactOptionalPropertyTypes && e.kind === 232 /* OmittedExpression */) { hasOmittedExpression = true; elementTypes.push(undefinedOrMissingType); elementFlags.push(2 /* Optional */); @@ -169069,10 +152938,13 @@ ${lanes.join("\n")} elementTypes, elementFlags, /*readonly*/ - inConstContext + inConstContext && !(contextualType && someType(contextualType, isMutableArrayLikeType)) )); } - return createArrayLiteralType(createArrayType(elementTypes.length ? getUnionType(sameMap(elementTypes, (t, i) => elementFlags[i] & 8 /* Variadic */ ? getIndexedAccessTypeOrUndefined(t, numberType) || anyType : t), 2 /* Subtype */) : strictNullChecks ? implicitNeverType : undefinedWideningType, inConstContext)); + return createArrayLiteralType(createArrayType( + elementTypes.length ? getUnionType(sameMap(elementTypes, (t, i) => elementFlags[i] & 8 /* Variadic */ ? getIndexedAccessTypeOrUndefined(t, numberType) || anyType : t), 2 /* Subtype */) : strictNullChecks ? implicitNeverType : undefinedWideningType, + inConstContext + )); } function createArrayLiteralType(type) { if (!(getObjectFlags(type) & 4 /* Reference */)) { @@ -169087,7 +152959,7 @@ ${lanes.join("\n")} } function isNumericName(name) { switch (name.kind) { - case 166 /* ComputedPropertyName */: + case 167 /* ComputedPropertyName */: return isNumericComputedName(name); case 80 /* Identifier */: return isNumericLiteralName(name.escapedText); @@ -169104,7 +152976,7 @@ ${lanes.join("\n")} function checkComputedPropertyName(node) { const links = getNodeLinks(node.expression); if (!links.resolvedType) { - if ((isTypeLiteralNode(node.parent.parent) || isClassLike(node.parent.parent) || isInterfaceDeclaration(node.parent.parent)) && isBinaryExpression(node.expression) && node.expression.operatorToken.kind === 103 /* InKeyword */ && node.parent.kind !== 176 /* GetAccessor */ && node.parent.kind !== 177 /* SetAccessor */) { + if ((isTypeLiteralNode(node.parent.parent) || isClassLike(node.parent.parent) || isInterfaceDeclaration(node.parent.parent)) && isBinaryExpression(node.expression) && node.expression.operatorToken.kind === 103 /* InKeyword */ && node.parent.kind !== 177 /* GetAccessor */ && node.parent.kind !== 178 /* SetAccessor */) { return links.resolvedType = errorType; } links.resolvedType = checkExpression(node.expression); @@ -169118,7 +152990,7 @@ ${lanes.join("\n")} } } if (links.resolvedType.flags & 98304 /* Nullable */ || !isTypeAssignableToKind(links.resolvedType, 402653316 /* StringLike */ | 296 /* NumberLike */ | 12288 /* ESSymbolLike */) && !isTypeAssignableTo(links.resolvedType, stringNumberSymbolType)) { - error(node, Diagnostics.A_computed_property_name_must_be_of_type_string_number_symbol_or_any); + error2(node, Diagnostics.A_computed_property_name_must_be_of_type_string_number_symbol_or_any); } } return links.resolvedType; @@ -169173,7 +153045,7 @@ ${lanes.join("\n")} /*contextFlags*/ void 0 ); - const contextualTypeHasPattern = contextualType && contextualType.pattern && (contextualType.pattern.kind === 205 /* ObjectBindingPattern */ || contextualType.pattern.kind === 209 /* ObjectLiteralExpression */); + const contextualTypeHasPattern = contextualType && contextualType.pattern && (contextualType.pattern.kind === 206 /* ObjectBindingPattern */ || contextualType.pattern.kind === 210 /* ObjectLiteralExpression */); const inConstContext = isConstContext(node); const checkFlags = inConstContext ? 8 /* Readonly */ : 0; const isInJavascript = isInJSFile(node) && !isInJsonFile(node); @@ -169192,13 +153064,13 @@ ${lanes.join("\n")} let offset = 0; for (const memberDecl of node.properties) { let member = getSymbolOfDeclaration(memberDecl); - const computedNameType = memberDecl.name && memberDecl.name.kind === 166 /* ComputedPropertyName */ ? checkComputedPropertyName(memberDecl.name) : void 0; - if (memberDecl.kind === 302 /* PropertyAssignment */ || memberDecl.kind === 303 /* ShorthandPropertyAssignment */ || isObjectLiteralMethod(memberDecl)) { - let type = memberDecl.kind === 302 /* PropertyAssignment */ ? checkPropertyAssignment(memberDecl, checkMode) : ( + const computedNameType = memberDecl.name && memberDecl.name.kind === 167 /* ComputedPropertyName */ ? checkComputedPropertyName(memberDecl.name) : void 0; + if (memberDecl.kind === 303 /* PropertyAssignment */ || memberDecl.kind === 304 /* ShorthandPropertyAssignment */ || isObjectLiteralMethod(memberDecl)) { + let type = memberDecl.kind === 303 /* PropertyAssignment */ ? checkPropertyAssignment(memberDecl, checkMode) : ( // avoid resolving the left side of the ShorthandPropertyAssignment outside of the destructuring // for error recovery purposes. For example, if a user wrote `{ a = 100 }` instead of `{ a: 100 }`. // we don't want to say "could not find 'a'". - memberDecl.kind === 303 /* ShorthandPropertyAssignment */ ? checkExpressionForMutableLocation(!inDestructuringPattern && memberDecl.objectAssignmentInitializer ? memberDecl.objectAssignmentInitializer : memberDecl.name, checkMode) : checkObjectLiteralMethod(memberDecl, checkMode) + memberDecl.kind === 304 /* ShorthandPropertyAssignment */ ? checkExpressionForMutableLocation(!inDestructuringPattern && memberDecl.objectAssignmentInitializer ? memberDecl.objectAssignmentInitializer : memberDecl.name, checkMode) : checkObjectLiteralMethod(memberDecl, checkMode) ); if (isInJavascript) { const jsDocType = getTypeForDeclarationFromJSDocComment(memberDecl); @@ -169216,7 +153088,7 @@ ${lanes.join("\n")} prop.links.nameType = nameType; } if (inDestructuringPattern) { - const isOptional = memberDecl.kind === 302 /* PropertyAssignment */ && hasDefaultValue(memberDecl.initializer) || memberDecl.kind === 303 /* ShorthandPropertyAssignment */ && memberDecl.objectAssignmentInitializer; + const isOptional = memberDecl.kind === 303 /* PropertyAssignment */ && hasDefaultValue(memberDecl.initializer) || memberDecl.kind === 304 /* ShorthandPropertyAssignment */ && memberDecl.objectAssignmentInitializer; if (isOptional) { prop.flags |= 16777216 /* Optional */; } @@ -169225,12 +153097,7 @@ ${lanes.join("\n")} if (impliedProp) { prop.flags |= impliedProp.flags & 16777216 /* Optional */; } else if (!compilerOptions.suppressExcessPropertyErrors && !getIndexInfoOfType(contextualType, stringType)) { - error( - memberDecl.name, - Diagnostics.Object_literal_may_only_specify_known_properties_and_0_does_not_exist_in_type_1, - symbolToString(member), - typeToString(contextualType) - ); + error2(memberDecl.name, Diagnostics.Object_literal_may_only_specify_known_properties_and_0_does_not_exist_in_type_1, symbolToString(member), typeToString(contextualType)); } } prop.declarations = member.declarations; @@ -169242,13 +153109,13 @@ ${lanes.join("\n")} prop.links.target = member; member = prop; allPropertiesTable == null ? void 0 : allPropertiesTable.set(prop.escapedName, prop); - if (contextualType && checkMode & 2 /* Inferential */ && !(checkMode & 4 /* SkipContextSensitive */) && (memberDecl.kind === 302 /* PropertyAssignment */ || memberDecl.kind === 173 /* MethodDeclaration */) && isContextSensitive(memberDecl)) { + if (contextualType && checkMode & 2 /* Inferential */ && !(checkMode & 4 /* SkipContextSensitive */) && (memberDecl.kind === 303 /* PropertyAssignment */ || memberDecl.kind === 174 /* MethodDeclaration */) && isContextSensitive(memberDecl)) { const inferenceContext = getInferenceContext(node); Debug.assert(inferenceContext); - const inferenceNode = memberDecl.kind === 302 /* PropertyAssignment */ ? memberDecl.initializer : memberDecl; + const inferenceNode = memberDecl.kind === 303 /* PropertyAssignment */ ? memberDecl.initializer : memberDecl; addIntraExpressionInferenceSite(inferenceContext, inferenceNode, type); } - } else if (memberDecl.kind === 304 /* SpreadAssignment */) { + } else if (memberDecl.kind === 305 /* SpreadAssignment */) { if (languageVersion < 2 /* ES2015 */) { checkExternalEmitHelpers(memberDecl, 2 /* Assign */); } @@ -169272,12 +153139,12 @@ ${lanes.join("\n")} } spread = getSpreadType(spread, mergedType, node.symbol, objectFlags, inConstContext); } else { - error(memberDecl, Diagnostics.Spread_types_may_only_be_created_from_object_types); + error2(memberDecl, Diagnostics.Spread_types_may_only_be_created_from_object_types); spread = errorType; } continue; } else { - Debug.assert(memberDecl.kind === 176 /* GetAccessor */ || memberDecl.kind === 177 /* SetAccessor */); + Debug.assert(memberDecl.kind === 177 /* GetAccessor */ || memberDecl.kind === 178 /* SetAccessor */); checkNodeDeferred(memberDecl); } if (computedNameType && !(computedNameType.flags & 8576 /* StringOrNumberLiteralOrUnique */)) { @@ -169300,22 +153167,13 @@ ${lanes.join("\n")} } popContextualType(); if (contextualTypeHasPattern) { - const rootPatternParent = findAncestor( - contextualType.pattern.parent, - (n) => n.kind === 259 /* VariableDeclaration */ || n.kind === 225 /* BinaryExpression */ || n.kind === 168 /* Parameter */ - ); - const spreadOrOutsideRootObject = findAncestor( - node, - (n) => n === rootPatternParent || n.kind === 304 /* SpreadAssignment */ - ); - if (spreadOrOutsideRootObject.kind !== 304 /* SpreadAssignment */) { + const rootPatternParent = findAncestor(contextualType.pattern.parent, (n) => n.kind === 260 /* VariableDeclaration */ || n.kind === 226 /* BinaryExpression */ || n.kind === 169 /* Parameter */); + const spreadOrOutsideRootObject = findAncestor(node, (n) => n === rootPatternParent || n.kind === 305 /* SpreadAssignment */); + if (spreadOrOutsideRootObject.kind !== 305 /* SpreadAssignment */) { for (const prop of getPropertiesOfType(contextualType)) { if (!propertiesTable.get(prop.escapedName) && !getPropertyOfType(spread, prop.escapedName)) { if (!(prop.flags & 16777216 /* Optional */)) { - error( - prop.valueDeclaration || ((_a = tryCast(prop, isTransientSymbol)) == null ? void 0 : _a.links.bindingElement), - Diagnostics.Initializer_provides_no_value_for_this_binding_element_and_the_binding_element_has_no_default_value - ); + error2(prop.valueDeclaration || ((_a = tryCast(prop, isTransientSymbol)) == null ? void 0 : _a.links.bindingElement), Diagnostics.Initializer_provides_no_value_for_this_binding_element_and_the_binding_element_has_no_default_value); } propertiesTable.set(prop.escapedName, prop); propertiesArray.push(prop); @@ -169387,13 +153245,16 @@ ${lanes.join("\n")} checkJsxOpeningLikeElementOrOpeningFragment(node.openingFragment); const nodeSourceFile = getSourceFileOfNode(node); if (getJSXTransformEnabled(compilerOptions) && (compilerOptions.jsxFactory || nodeSourceFile.pragmas.has("jsx")) && !compilerOptions.jsxFragmentFactory && !nodeSourceFile.pragmas.has("jsxfrag")) { - error(node, compilerOptions.jsxFactory ? Diagnostics.The_jsxFragmentFactory_compiler_option_must_be_provided_to_use_JSX_fragments_with_the_jsxFactory_compiler_option : Diagnostics.An_jsxFrag_pragma_is_required_when_using_an_jsx_pragma_with_JSX_fragments); + error2( + node, + compilerOptions.jsxFactory ? Diagnostics.The_jsxFragmentFactory_compiler_option_must_be_provided_to_use_JSX_fragments_with_the_jsxFactory_compiler_option : Diagnostics.An_jsxFrag_pragma_is_required_when_using_an_jsx_pragma_with_JSX_fragments + ); } checkJsxChildren(node); return getJsxElementTypeAt(node) || anyType; } function isHyphenatedJsxName(name) { - return stringContains(name, "-"); + return name.includes("-"); } function isJsxIntrinsicTagName(tagName) { return isIdentifier(tagName) && isIntrinsicJsxName(tagName.escapedText) || isJsxNamespacedName(tagName); @@ -169443,7 +153304,7 @@ ${lanes.join("\n")} addIntraExpressionInferenceSite(inferenceContext, inferenceNode, exprType); } } else { - Debug.assert(attributeDecl.kind === 292 /* JsxSpreadAttribute */); + Debug.assert(attributeDecl.kind === 293 /* JsxSpreadAttribute */); if (attributesTable.size > 0) { spread = getSpreadType( spread, @@ -169472,7 +153333,7 @@ ${lanes.join("\n")} checkSpreadPropOverrides(exprType, allAttributesTable, attributeDecl); } } else { - error(attributeDecl.expression, Diagnostics.Spread_types_may_only_be_created_from_object_types); + error2(attributeDecl.expression, Diagnostics.Spread_types_may_only_be_created_from_object_types); typeToIntersect = typeToIntersect ? getIntersectionType([typeToIntersect, exprType]) : exprType; } } @@ -169489,12 +153350,12 @@ ${lanes.join("\n")} ); } } - const parent2 = openingLikeElement.parent.kind === 283 /* JsxElement */ ? openingLikeElement.parent : void 0; - if (parent2 && parent2.openingElement === openingLikeElement && parent2.children.length > 0) { + const parent2 = openingLikeElement.parent.kind === 284 /* JsxElement */ ? openingLikeElement.parent : void 0; + if (parent2 && parent2.openingElement === openingLikeElement && getSemanticJsxChildren(parent2.children).length > 0) { const childrenTypes = checkJsxChildren(parent2, checkMode); if (!hasSpreadAnyType && jsxChildrenPropertyName && jsxChildrenPropertyName !== "") { if (explicitlySpecifyChildrenAttribute) { - error(attributes, Diagnostics._0_are_specified_twice_The_attribute_named_0_will_be_overwritten, unescapeLeadingUnderscores(jsxChildrenPropertyName)); + error2(attributes, Diagnostics._0_are_specified_twice_The_attribute_named_0_will_be_overwritten, unescapeLeadingUnderscores(jsxChildrenPropertyName)); } const contextualType2 = getApparentTypeOfContextualType( openingLikeElement.attributes, @@ -169548,7 +153409,7 @@ ${lanes.join("\n")} if (!child.containsOnlyTriviaWhiteSpaces) { childrenTypes.push(stringType); } - } else if (child.kind === 293 /* JsxExpression */ && !child.expression) { + } else if (child.kind === 294 /* JsxExpression */ && !child.expression) { continue; } else { childrenTypes.push(checkExpressionForMutableLocation(child, checkMode)); @@ -169561,7 +153422,7 @@ ${lanes.join("\n")} if (!(right.flags & 16777216 /* Optional */)) { const left = props.get(right.escapedName); if (left) { - const diagnostic = error(left.valueDeclaration, Diagnostics._0_is_specified_more_than_once_so_this_usage_will_be_overwritten, unescapeLeadingUnderscores(left.escapedName)); + const diagnostic = error2(left.valueDeclaration, Diagnostics._0_is_specified_more_than_once_so_this_usage_will_be_overwritten, unescapeLeadingUnderscores(left.escapedName)); addRelatedInfo(diagnostic, createDiagnosticForNode(spread, Diagnostics.This_spread_always_overwrites_this_property)); } } @@ -169583,21 +153444,26 @@ ${lanes.join("\n")} if (!isErrorType(intrinsicElementsType)) { if (!isIdentifier(node.tagName) && !isJsxNamespacedName(node.tagName)) return Debug.fail(); - const intrinsicProp = getPropertyOfType(intrinsicElementsType, isJsxNamespacedName(node.tagName) ? getEscapedTextOfJsxNamespacedName(node.tagName) : node.tagName.escapedText); + const propName = isJsxNamespacedName(node.tagName) ? getEscapedTextOfJsxNamespacedName(node.tagName) : node.tagName.escapedText; + const intrinsicProp = getPropertyOfType(intrinsicElementsType, propName); if (intrinsicProp) { links.jsxFlags |= 1 /* IntrinsicNamedElement */; return links.resolvedSymbol = intrinsicProp; } - const indexSignatureType = getIndexTypeOfType(intrinsicElementsType, stringType); - if (indexSignatureType) { + const indexSymbol = getApplicableIndexSymbol(intrinsicElementsType, getStringLiteralType(unescapeLeadingUnderscores(propName))); + if (indexSymbol) { + links.jsxFlags |= 2 /* IntrinsicIndexedElement */; + return links.resolvedSymbol = indexSymbol; + } + if (getTypeOfPropertyOrIndexSignatureOfType(intrinsicElementsType, propName)) { links.jsxFlags |= 2 /* IntrinsicIndexedElement */; return links.resolvedSymbol = intrinsicElementsType.symbol; } - error(node, Diagnostics.Property_0_does_not_exist_on_type_1, intrinsicTagNameToString(node.tagName), "JSX." + JsxNames.IntrinsicElements); + error2(node, Diagnostics.Property_0_does_not_exist_on_type_1, intrinsicTagNameToString(node.tagName), "JSX." + JsxNames.IntrinsicElements); return links.resolvedSymbol = unknownSymbol; } else { if (noImplicitAny) { - error(node, Diagnostics.JSX_element_implicitly_has_type_any_because_no_interface_JSX_0_exists, unescapeLeadingUnderscores(JsxNames.IntrinsicElements)); + error2(node, Diagnostics.JSX_element_implicitly_has_type_any_because_no_interface_JSX_0_exists, unescapeLeadingUnderscores(JsxNames.IntrinsicElements)); } return links.resolvedSymbol = unknownSymbol; } @@ -169680,7 +153546,7 @@ ${lanes.join("\n")} } else if (propertiesOfJsxElementAttribPropInterface.length === 1) { return propertiesOfJsxElementAttribPropInterface[0].escapedName; } else if (propertiesOfJsxElementAttribPropInterface.length > 1 && jsxElementAttribPropInterfaceSym.declarations) { - error(jsxElementAttribPropInterfaceSym.declarations[0], Diagnostics.The_global_type_JSX_0_may_not_have_more_than_one_property, unescapeLeadingUnderscores(nameOfAttribPropContainer)); + error2(jsxElementAttribPropInterfaceSym.declarations[0], Diagnostics.The_global_type_JSX_0_may_not_have_more_than_one_property, unescapeLeadingUnderscores(nameOfAttribPropContainer)); } } return void 0; @@ -169703,7 +153569,7 @@ ${lanes.join("\n")} } else if (elementType.flags & 128 /* StringLiteral */) { const intrinsicType = getIntrinsicAttributesTypeFromStringLiteralType(elementType, caller); if (!intrinsicType) { - error(caller, Diagnostics.Property_0_does_not_exist_on_type_1, elementType.value, "JSX." + JsxNames.IntrinsicElements); + error2(caller, Diagnostics.Property_0_does_not_exist_on_type_1, elementType.value, "JSX." + JsxNames.IntrinsicElements); return emptyArray; } else { const fakeSignature = createSignatureForJSXIntrinsic(caller, intrinsicType); @@ -169767,6 +153633,7 @@ ${lanes.join("\n")} } } function getIntrinsicAttributesTypeFromJsxOpeningLikeElement(node) { + var _a; Debug.assert(isJsxIntrinsicTagName(node.tagName)); const links = getNodeLinks(node); if (!links.resolvedJsxElementAttributesType) { @@ -169774,7 +153641,8 @@ ${lanes.join("\n")} if (links.jsxFlags & 1 /* IntrinsicNamedElement */) { return links.resolvedJsxElementAttributesType = getTypeOfSymbol(symbol) || errorType; } else if (links.jsxFlags & 2 /* IntrinsicIndexedElement */) { - return links.resolvedJsxElementAttributesType = getIndexTypeOfType(getJsxType(JsxNames.IntrinsicElements, node), stringType) || errorType; + const propName = isJsxNamespacedName(node.tagName) ? getEscapedTextOfJsxNamespacedName(node.tagName) : node.tagName.escapedText; + return links.resolvedJsxElementAttributesType = ((_a = getApplicableIndexInfoForName(getJsxType(JsxNames.IntrinsicElements, node), propName)) == null ? void 0 : _a.type) || errorType; } else { return links.resolvedJsxElementAttributesType = errorType; } @@ -169829,11 +153697,11 @@ ${lanes.join("\n")} } function checkJsxPreconditions(errorNode) { if ((compilerOptions.jsx || 0 /* None */) === 0 /* None */) { - error(errorNode, Diagnostics.Cannot_use_JSX_unless_the_jsx_flag_is_provided); + error2(errorNode, Diagnostics.Cannot_use_JSX_unless_the_jsx_flag_is_provided); } if (getJsxElementTypeAt(errorNode) === void 0) { if (noImplicitAny) { - error(errorNode, Diagnostics.JSX_element_implicitly_has_type_any_because_the_global_type_JSX_Element_does_not_exist); + error2(errorNode, Diagnostics.JSX_element_implicitly_has_type_any_because_the_global_type_JSX_Element_does_not_exist); } } } @@ -169925,7 +153793,7 @@ ${lanes.join("\n")} if (node.expression) { const type = checkExpression(node.expression, checkMode); if (node.dotDotDotToken && type !== anyType && !isArrayType(type)) { - error(node, Diagnostics.JSX_spread_child_must_be_an_array_type); + error2(node, Diagnostics.JSX_spread_child_must_be_an_array_type); } return type; } else { @@ -169933,7 +153801,7 @@ ${lanes.join("\n")} } } function getDeclarationNodeFlagsFromSymbol(s) { - return s.valueDeclaration ? getCombinedNodeFlags(s.valueDeclaration) : 0; + return s.valueDeclaration ? getCombinedNodeFlagsCached(s.valueDeclaration) : 0; } function isPrototypeProperty(symbol) { if (symbol.flags & 8192 /* Method */ || getCheckFlags(symbol) & 4 /* SyntheticMethod */) { @@ -169945,59 +153813,51 @@ ${lanes.join("\n")} } } function checkPropertyAccessibility(node, isSuper, writing, type, prop, reportError = true) { - const errorNode = !reportError ? void 0 : node.kind === 165 /* QualifiedName */ ? node.right : node.kind === 204 /* ImportType */ ? node : node.kind === 207 /* BindingElement */ && node.propertyName ? node.propertyName : node.name; + const errorNode = !reportError ? void 0 : node.kind === 166 /* QualifiedName */ ? node.right : node.kind === 205 /* ImportType */ ? node : node.kind === 208 /* BindingElement */ && node.propertyName ? node.propertyName : node.name; return checkPropertyAccessibilityAtLocation(node, isSuper, writing, type, prop, errorNode); } function checkPropertyAccessibilityAtLocation(location, isSuper, writing, containingType, prop, errorNode) { + var _a; const flags = getDeclarationModifierFlagsFromSymbol(prop, writing); if (isSuper) { if (languageVersion < 2 /* ES2015 */) { if (symbolHasNonMethodDeclaration(prop)) { if (errorNode) { - error(errorNode, Diagnostics.Only_public_and_protected_methods_of_the_base_class_are_accessible_via_the_super_keyword); + error2(errorNode, Diagnostics.Only_public_and_protected_methods_of_the_base_class_are_accessible_via_the_super_keyword); } return false; } } - if (flags & 256 /* Abstract */) { + if (flags & 64 /* Abstract */) { if (errorNode) { - error( - errorNode, - Diagnostics.Abstract_method_0_in_class_1_cannot_be_accessed_via_super_expression, - symbolToString(prop), - typeToString(getDeclaringClass(prop)) - ); + error2(errorNode, Diagnostics.Abstract_method_0_in_class_1_cannot_be_accessed_via_super_expression, symbolToString(prop), typeToString(getDeclaringClass(prop))); + } + return false; + } + if (!(flags & 256 /* Static */) && ((_a = prop.declarations) == null ? void 0 : _a.some(isClassInstanceProperty))) { + if (errorNode) { + error2(errorNode, Diagnostics.Class_field_0_defined_by_the_parent_class_is_not_accessible_in_the_child_class_via_super, symbolToString(prop)); } return false; } } - if (flags & 256 /* Abstract */ && symbolHasNonMethodDeclaration(prop) && (isThisProperty(location) || isThisInitializedObjectBindingExpression(location) || isObjectBindingPattern(location.parent) && isThisInitializedDeclaration(location.parent.parent))) { + if (flags & 64 /* Abstract */ && symbolHasNonMethodDeclaration(prop) && (isThisProperty(location) || isThisInitializedObjectBindingExpression(location) || isObjectBindingPattern(location.parent) && isThisInitializedDeclaration(location.parent.parent))) { const declaringClassDeclaration = getClassLikeDeclarationOfSymbol(getParentOfSymbol(prop)); if (declaringClassDeclaration && isNodeUsedDuringClassInitialization(location)) { if (errorNode) { - error( - errorNode, - Diagnostics.Abstract_property_0_in_class_1_cannot_be_accessed_in_the_constructor, - symbolToString(prop), - getTextOfIdentifierOrLiteral(declaringClassDeclaration.name) - ); + error2(errorNode, Diagnostics.Abstract_property_0_in_class_1_cannot_be_accessed_in_the_constructor, symbolToString(prop), getTextOfIdentifierOrLiteral(declaringClassDeclaration.name)); } return false; } } - if (!(flags & 24 /* NonPublicAccessibilityModifier */)) { + if (!(flags & 6 /* NonPublicAccessibilityModifier */)) { return true; } - if (flags & 8 /* Private */) { + if (flags & 2 /* Private */) { const declaringClassDeclaration = getClassLikeDeclarationOfSymbol(getParentOfSymbol(prop)); if (!isNodeWithinClass(location, declaringClassDeclaration)) { if (errorNode) { - error( - errorNode, - Diagnostics.Property_0_is_private_and_only_accessible_within_class_1, - symbolToString(prop), - typeToString(getDeclaringClass(prop)) - ); + error2(errorNode, Diagnostics.Property_0_is_private_and_only_accessible_within_class_1, symbolToString(prop), typeToString(getDeclaringClass(prop))); } return false; } @@ -170013,19 +153873,14 @@ ${lanes.join("\n")} if (!enclosingClass) { enclosingClass = getEnclosingClassFromThisParameter(location); enclosingClass = enclosingClass && isClassDerivedFromDeclaringClasses(enclosingClass, prop, writing); - if (flags & 32 /* Static */ || !enclosingClass) { + if (flags & 256 /* Static */ || !enclosingClass) { if (errorNode) { - error( - errorNode, - Diagnostics.Property_0_is_protected_and_only_accessible_within_class_1_and_its_subclasses, - symbolToString(prop), - typeToString(getDeclaringClass(prop) || containingType) - ); + error2(errorNode, Diagnostics.Property_0_is_protected_and_only_accessible_within_class_1_and_its_subclasses, symbolToString(prop), typeToString(getDeclaringClass(prop) || containingType)); } return false; } } - if (flags & 32 /* Static */) { + if (flags & 256 /* Static */) { return true; } if (containingType.flags & 262144 /* TypeParameter */) { @@ -170033,13 +153888,7 @@ ${lanes.join("\n")} } if (!containingType || !hasBaseType(containingType, enclosingClass)) { if (errorNode) { - error( - errorNode, - Diagnostics.Property_0_is_protected_and_only_accessible_through_an_instance_of_class_1_This_is_an_instance_of_class_2, - symbolToString(prop), - typeToString(enclosingClass), - typeToString(containingType) - ); + error2(errorNode, Diagnostics.Property_0_is_protected_and_only_accessible_through_an_instance_of_class_1_This_is_an_instance_of_class_2, symbolToString(prop), typeToString(enclosingClass), typeToString(containingType)); } return false; } @@ -170073,7 +153922,7 @@ ${lanes.join("\n")} return checkNonNullType(checkExpression(node), node); } function isNullableType(type) { - return !!(getTypeFacts(type) & 50331648 /* IsUndefinedOrNull */); + return hasTypeFacts(type, 50331648 /* IsUndefinedOrNull */); } function getNonNullableTypeIfNeeded(type) { return isNullableType(type) ? getNonNullableType(type) : type; @@ -170081,28 +153930,28 @@ ${lanes.join("\n")} function reportObjectPossiblyNullOrUndefinedError(node, facts) { const nodeText2 = isEntityNameExpression(node) ? entityNameToString(node) : void 0; if (node.kind === 106 /* NullKeyword */) { - error(node, Diagnostics.The_value_0_cannot_be_used_here, "null"); + error2(node, Diagnostics.The_value_0_cannot_be_used_here, "null"); return; } if (nodeText2 !== void 0 && nodeText2.length < 100) { if (isIdentifier(node) && nodeText2 === "undefined") { - error(node, Diagnostics.The_value_0_cannot_be_used_here, "undefined"); + error2(node, Diagnostics.The_value_0_cannot_be_used_here, "undefined"); return; } - error( + error2( node, facts & 16777216 /* IsUndefined */ ? facts & 33554432 /* IsNull */ ? Diagnostics._0_is_possibly_null_or_undefined : Diagnostics._0_is_possibly_undefined : Diagnostics._0_is_possibly_null, nodeText2 ); } else { - error( + error2( node, facts & 16777216 /* IsUndefined */ ? facts & 33554432 /* IsNull */ ? Diagnostics.Object_is_possibly_null_or_undefined : Diagnostics.Object_is_possibly_undefined : Diagnostics.Object_is_possibly_null ); } } function reportCannotInvokePossiblyNullOrUndefinedError(node, facts) { - error( + error2( node, facts & 16777216 /* IsUndefined */ ? facts & 33554432 /* IsNull */ ? Diagnostics.Cannot_invoke_an_object_which_is_possibly_null_or_undefined : Diagnostics.Cannot_invoke_an_object_which_is_possibly_undefined : Diagnostics.Cannot_invoke_an_object_which_is_possibly_null ); @@ -170112,14 +153961,14 @@ ${lanes.join("\n")} if (isEntityNameExpression(node)) { const nodeText2 = entityNameToString(node); if (nodeText2.length < 100) { - error(node, Diagnostics._0_is_of_type_unknown, nodeText2); + error2(node, Diagnostics._0_is_of_type_unknown, nodeText2); return errorType; } } - error(node, Diagnostics.Object_is_of_type_unknown); + error2(node, Diagnostics.Object_is_of_type_unknown); return errorType; } - const facts = getTypeFacts(type); + const facts = getTypeFacts(type, 50331648 /* IsUndefinedOrNull */); if (facts & 50331648 /* IsUndefinedOrNull */) { reportError(node, facts); const t = getNonNullableType(type); @@ -170136,20 +153985,20 @@ ${lanes.join("\n")} if (isEntityNameExpression(node)) { const nodeText2 = entityNameToString(node); if (isIdentifier(node) && nodeText2 === "undefined") { - error(node, Diagnostics.The_value_0_cannot_be_used_here, nodeText2); + error2(node, Diagnostics.The_value_0_cannot_be_used_here, nodeText2); return nonNullType; } if (nodeText2.length < 100) { - error(node, Diagnostics._0_is_possibly_undefined, nodeText2); + error2(node, Diagnostics._0_is_possibly_undefined, nodeText2); return nonNullType; } } - error(node, Diagnostics.Object_is_possibly_undefined); + error2(node, Diagnostics.Object_is_possibly_undefined); } return nonNullType; } function checkPropertyAccessExpression(node, checkMode, writeOnly) { - return node.flags & 32 /* OptionalChain */ ? checkPropertyAccessChain(node, checkMode) : checkPropertyAccessExpressionOrQualifiedName(node, node.expression, checkNonNullExpression(node.expression), node.name, checkMode, writeOnly); + return node.flags & 64 /* OptionalChain */ ? checkPropertyAccessChain(node, checkMode) : checkPropertyAccessExpressionOrQualifiedName(node, node.expression, checkNonNullExpression(node.expression), node.name, checkMode, writeOnly); } function checkPropertyAccessChain(node, checkMode) { const leftType = checkExpression(node.expression); @@ -170161,13 +154010,13 @@ ${lanes.join("\n")} return checkPropertyAccessExpressionOrQualifiedName(node, node.left, leftType, node.right, checkMode); } function isMethodAccessForCall(node) { - while (node.parent.kind === 216 /* ParenthesizedExpression */) { + while (node.parent.kind === 217 /* ParenthesizedExpression */) { node = node.parent; } return isCallOrNewExpression(node.parent) && node.parent.expression === node; } function lookupSymbolForPrivateIdentifierDeclaration(propName, location) { - for (let containingClass = getContainingClass(location); !!containingClass; containingClass = getContainingClass(containingClass)) { + for (let containingClass = getContainingClassExcludingClassDecorators(location); !!containingClass; containingClass = getContainingClass(containingClass)) { const { symbol } = containingClass; const name = getSymbolNameForPrivateIdentifier(symbol, propName); const prop = symbol.members && symbol.members.get(name) || symbol.exports && symbol.exports.get(name); @@ -170239,7 +154088,7 @@ ${lanes.join("\n")} const lexicalClass = getContainingClass(lexicalValueDecl); Debug.assert(!!lexicalClass); if (findAncestor(lexicalClass, (n) => typeClass === n)) { - const diagnostic = error( + const diagnostic = error2( right, Diagnostics.The_property_0_cannot_be_accessed_on_type_1_within_this_class_because_it_is_shadowed_by_another_private_identifier_with_the_same_spelling, diagName, @@ -170261,7 +154110,7 @@ ${lanes.join("\n")} return true; } } - error( + error2( right, Diagnostics.Property_0_is_not_accessible_outside_class_1_because_it_has_a_private_identifier, diagName, @@ -170303,18 +154152,24 @@ ${lanes.join("\n")} if (lexicallyScopedSymbol) { return isErrorType(apparentType) ? errorType : apparentType; } - if (!getContainingClass(right)) { + if (getContainingClassExcludingClassDecorators(right) === void 0) { grammarErrorOnNode(right, Diagnostics.Private_identifiers_are_not_allowed_outside_class_bodies); return anyType; } } - prop = lexicallyScopedSymbol ? getPrivateIdentifierPropertyOfType(leftType, lexicallyScopedSymbol) : void 0; - if (!prop && checkPrivateIdentifierPropertyAccess(leftType, right, lexicallyScopedSymbol)) { - return errorType; + prop = lexicallyScopedSymbol && getPrivateIdentifierPropertyOfType(leftType, lexicallyScopedSymbol); + if (prop === void 0) { + if (checkPrivateIdentifierPropertyAccess(leftType, right, lexicallyScopedSymbol)) { + return errorType; + } + const containingClass = getContainingClassExcludingClassDecorators(right); + if (containingClass && isPlainJsFile(getSourceFileOfNode(containingClass), compilerOptions.checkJs)) { + grammarErrorOnNode(right, Diagnostics.Private_field_0_must_be_declared_in_an_enclosing_class, idText(right)); + } } else { - const isSetonlyAccessor = prop && prop.flags & 65536 /* SetAccessor */ && !(prop.flags & 32768 /* GetAccessor */); + const isSetonlyAccessor = prop.flags & 65536 /* SetAccessor */ && !(prop.flags & 32768 /* GetAccessor */); if (isSetonlyAccessor && assignmentKind !== 1 /* Definite */) { - error(node, Diagnostics.Private_accessor_was_defined_without_a_getter); + error2(node, Diagnostics.Private_accessor_was_defined_without_a_getter); } } } else { @@ -170328,12 +154183,12 @@ ${lanes.join("\n")} apparentType, right.escapedText, /*skipObjectFunctionPropertyAugment*/ - false, + isConstEnumObjectType(apparentType), /*includeTypeOnlyMembers*/ - node.kind === 165 /* QualifiedName */ + node.kind === 166 /* QualifiedName */ ); } - if (isIdentifier(left) && parentSymbol && (getIsolatedModules(compilerOptions) || !(prop && (isConstEnumOrConstEnumOnlyModule(prop) || prop.flags & 8 /* EnumMember */ && node.parent.kind === 305 /* EnumMember */)) || shouldPreserveConstEnums(compilerOptions) && isExportOrExportExpression(node))) { + if (isIdentifier(left) && parentSymbol && (getIsolatedModules(compilerOptions) || !(prop && (isConstEnumOrConstEnumOnlyModule(prop) || prop.flags & 8 /* EnumMember */ && node.parent.kind === 306 /* EnumMember */)) || shouldPreserveConstEnums(compilerOptions) && isExportOrExportExpression(node))) { markAliasReferenced(parentSymbol, node); } let propType; @@ -170351,9 +154206,9 @@ ${lanes.join("\n")} } if (leftType.symbol === globalThisSymbol) { if (globalThisSymbol.exports.has(right.escapedText) && globalThisSymbol.exports.get(right.escapedText).flags & 418 /* BlockScoped */) { - error(right, Diagnostics.Property_0_does_not_exist_on_type_1, unescapeLeadingUnderscores(right.escapedText), typeToString(leftType)); + error2(right, Diagnostics.Property_0_does_not_exist_on_type_1, unescapeLeadingUnderscores(right.escapedText), typeToString(leftType)); } else if (noImplicitAny) { - error(right, Diagnostics.Element_implicitly_has_an_any_type_because_type_0_has_no_index_signature, typeToString(leftType)); + error2(right, Diagnostics.Element_implicitly_has_an_any_type_because_type_0_has_no_index_signature, typeToString(leftType)); } return anyType; } @@ -170363,13 +154218,13 @@ ${lanes.join("\n")} return errorType; } if (indexInfo.isReadonly && (isAssignmentTarget(node) || isDeleteTarget(node))) { - error(node, Diagnostics.Index_signature_in_type_0_only_permits_reading, typeToString(apparentType)); + error2(node, Diagnostics.Index_signature_in_type_0_only_permits_reading, typeToString(apparentType)); } propType = compilerOptions.noUncheckedIndexedAccess && !isAssignmentTarget(node) ? getUnionType([indexInfo.type, missingType]) : indexInfo.type; if (compilerOptions.noPropertyAccessFromIndexSignature && isPropertyAccessExpression(node)) { - error(right, Diagnostics.Property_0_comes_from_an_index_signature_so_it_must_be_accessed_with_0, unescapeLeadingUnderscores(right.escapedText)); + error2(right, Diagnostics.Property_0_comes_from_an_index_signature_so_it_must_be_accessed_with_0, unescapeLeadingUnderscores(right.escapedText)); } - if (indexInfo.declaration && getCombinedNodeFlags(indexInfo.declaration) & 268435456 /* Deprecated */) { + if (indexInfo.declaration && isDeprecatedDeclaration2(indexInfo.declaration)) { addDeprecatedSuggestion(right, [indexInfo.declaration], right.escapedText); } } else { @@ -170382,7 +154237,7 @@ ${lanes.join("\n")} getNodeLinks(node).resolvedSymbol = prop; checkPropertyAccessibility(node, left.kind === 108 /* SuperKeyword */, isWriteAccess(node), apparentType, prop); if (isAssignmentToReadonlyEntity(node, prop, assignmentKind)) { - error(right, Diagnostics.Cannot_assign_to_0_because_it_is_a_read_only_property, idText(right)); + error2(right, Diagnostics.Cannot_assign_to_0_because_it_is_a_read_only_property, idText(right)); return errorType; } propType = isThisPropertyAccessInConstructor(node, prop) ? autoType : writeOnly || isWriteOnlyAccess(node) ? getWriteTypeOfSymbol(prop) : getTypeOfSymbol(prop); @@ -170390,11 +154245,17 @@ ${lanes.join("\n")} return getFlowTypeOfAccessExpression(node, prop, propType, right, checkMode); } function isUncheckedJSSuggestion(node, suggestion, excludeClasses) { + var _a; const file = getSourceFileOfNode(node); if (file) { if (compilerOptions.checkJs === void 0 && file.checkJsDirective === void 0 && (file.scriptKind === 1 /* JS */ || file.scriptKind === 2 /* JSX */)) { const declarationFile = forEach(suggestion == null ? void 0 : suggestion.declarations, getSourceFileOfNode); - return !(file !== declarationFile && !!declarationFile && isGlobalSourceFile(declarationFile)) && !(excludeClasses && suggestion && suggestion.flags & 32 /* Class */) && !(!!node && excludeClasses && isPropertyAccessExpression(node) && node.expression.kind === 110 /* ThisKeyword */); + const suggestionHasNoExtendsOrDecorators = !(suggestion == null ? void 0 : suggestion.valueDeclaration) || !isClassLike(suggestion.valueDeclaration) || ((_a = suggestion.valueDeclaration.heritageClauses) == null ? void 0 : _a.length) || classOrConstructorParameterIsDecorated( + /*useLegacyDecorators*/ + false, + suggestion.valueDeclaration + ); + return !(file !== declarationFile && !!declarationFile && isGlobalSourceFile(declarationFile)) && !(excludeClasses && suggestion && suggestion.flags & 32 /* Class */ && suggestionHasNoExtendsOrDecorators) && !(!!node && excludeClasses && isPropertyAccessExpression(node) && node.expression.kind === 110 /* ThisKeyword */ && suggestionHasNoExtendsOrDecorators); } } return false; @@ -170417,7 +154278,7 @@ ${lanes.join("\n")} if (declaration && isPropertyWithoutInitializer(declaration)) { if (!isStatic(declaration)) { const flowContainer = getControlFlowContainer(node); - if (flowContainer.kind === 175 /* Constructor */ && flowContainer.parent === declaration.parent && !(declaration.flags & 16777216 /* Ambient */)) { + if (flowContainer.kind === 176 /* Constructor */ && flowContainer.parent === declaration.parent && !(declaration.flags & 33554432 /* Ambient */)) { assumeUninitialized = true; } } @@ -170427,7 +154288,7 @@ ${lanes.join("\n")} } const flowType = getFlowTypeOfReference(node, propType, assumeUninitialized ? getOptionalType(propType) : propType); if (assumeUninitialized && !containsUndefinedType(propType) && containsUndefinedType(flowType)) { - error(errorNode, Diagnostics.Property_0_is_used_before_being_assigned, symbolToString(prop)); + error2(errorNode, Diagnostics.Property_0_is_used_before_being_assigned, symbolToString(prop)); return propType; } return assignmentKind ? getBaseTypeOfLiteralType(flowType) : flowType; @@ -170439,40 +154300,37 @@ ${lanes.join("\n")} } let diagnosticMessage; const declarationName = idText(right); - if (isInPropertyInitializerOrClassStaticBlock(node) && !isOptionalPropertyDeclaration(valueDeclaration) && !(isAccessExpression(node) && isAccessExpression(node.expression)) && !isBlockScopedNameDeclaredBeforeUse(valueDeclaration, right) && !(isMethodDeclaration(valueDeclaration) && getCombinedModifierFlags(valueDeclaration) & 32 /* Static */) && (compilerOptions.useDefineForClassFields || !isPropertyDeclaredInAncestorClass(prop))) { - diagnosticMessage = error(right, Diagnostics.Property_0_is_used_before_its_initialization, declarationName); - } else if (valueDeclaration.kind === 262 /* ClassDeclaration */ && node.parent.kind !== 182 /* TypeReference */ && !(valueDeclaration.flags & 16777216 /* Ambient */) && !isBlockScopedNameDeclaredBeforeUse(valueDeclaration, right)) { - diagnosticMessage = error(right, Diagnostics.Class_0_used_before_its_declaration, declarationName); + if (isInPropertyInitializerOrClassStaticBlock(node) && !isOptionalPropertyDeclaration(valueDeclaration) && !(isAccessExpression(node) && isAccessExpression(node.expression)) && !isBlockScopedNameDeclaredBeforeUse(valueDeclaration, right) && !(isMethodDeclaration(valueDeclaration) && getCombinedModifierFlagsCached(valueDeclaration) & 256 /* Static */) && (useDefineForClassFields || !isPropertyDeclaredInAncestorClass(prop))) { + diagnosticMessage = error2(right, Diagnostics.Property_0_is_used_before_its_initialization, declarationName); + } else if (valueDeclaration.kind === 263 /* ClassDeclaration */ && node.parent.kind !== 183 /* TypeReference */ && !(valueDeclaration.flags & 33554432 /* Ambient */) && !isBlockScopedNameDeclaredBeforeUse(valueDeclaration, right)) { + diagnosticMessage = error2(right, Diagnostics.Class_0_used_before_its_declaration, declarationName); } if (diagnosticMessage) { - addRelatedInfo( - diagnosticMessage, - createDiagnosticForNode(valueDeclaration, Diagnostics._0_is_declared_here, declarationName) - ); + addRelatedInfo(diagnosticMessage, createDiagnosticForNode(valueDeclaration, Diagnostics._0_is_declared_here, declarationName)); } } function isInPropertyInitializerOrClassStaticBlock(node) { return !!findAncestor(node, (node2) => { switch (node2.kind) { - case 171 /* PropertyDeclaration */: + case 172 /* PropertyDeclaration */: return true; - case 302 /* PropertyAssignment */: - case 173 /* MethodDeclaration */: - case 176 /* GetAccessor */: - case 177 /* SetAccessor */: - case 304 /* SpreadAssignment */: - case 166 /* ComputedPropertyName */: - case 238 /* TemplateSpan */: - case 293 /* JsxExpression */: - case 290 /* JsxAttribute */: - case 291 /* JsxAttributes */: - case 292 /* JsxSpreadAttribute */: - case 285 /* JsxOpeningElement */: - case 232 /* ExpressionWithTypeArguments */: - case 297 /* HeritageClause */: + case 303 /* PropertyAssignment */: + case 174 /* MethodDeclaration */: + case 177 /* GetAccessor */: + case 178 /* SetAccessor */: + case 305 /* SpreadAssignment */: + case 167 /* ComputedPropertyName */: + case 239 /* TemplateSpan */: + case 294 /* JsxExpression */: + case 291 /* JsxAttribute */: + case 292 /* JsxAttributes */: + case 293 /* JsxSpreadAttribute */: + case 286 /* JsxOpeningElement */: + case 233 /* ExpressionWithTypeArguments */: + case 298 /* HeritageClause */: return false; - case 218 /* ArrowFunction */: - case 243 /* ExpressionStatement */: + case 219 /* ArrowFunction */: + case 244 /* ExpressionStatement */: return isBlock(node2.parent) && isClassStaticBlockDeclaration(node2.parent.parent) ? true : "quit"; default: return isExpressionNode(node2) ? false : "quit"; @@ -170696,7 +154554,7 @@ ${lanes.join("\n")} if (!valueDeclaration) { return; } - const hasPrivateModifier = hasEffectiveModifier(valueDeclaration, 8 /* Private */); + const hasPrivateModifier = hasEffectiveModifier(valueDeclaration, 2 /* Private */); const hasPrivateIdentifier = prop.valueDeclaration && isNamedDeclaration(prop.valueDeclaration) && isPrivateIdentifier(prop.valueDeclaration.name); if (!hasPrivateModifier && !hasPrivateIdentifier) { return; @@ -170717,9 +154575,9 @@ ${lanes.join("\n")} } function isValidPropertyAccess(node, propertyName) { switch (node.kind) { - case 210 /* PropertyAccessExpression */: + case 211 /* PropertyAccessExpression */: return isValidPropertyAccessWithType(node, node.expression.kind === 108 /* SuperKeyword */, propertyName, getWidenedType(checkExpression(node.expression))); - case 165 /* QualifiedName */: + case 166 /* QualifiedName */: return isValidPropertyAccessWithType( node, /*isSuper*/ @@ -170727,7 +154585,7 @@ ${lanes.join("\n")} propertyName, getWidenedType(checkExpression(node.left)) ); - case 204 /* ImportType */: + case 205 /* ImportType */: return isValidPropertyAccessWithType( node, /*isSuper*/ @@ -170740,7 +154598,7 @@ ${lanes.join("\n")} function isValidPropertyAccessForCompletions(node, type, property) { return isPropertyAccessible( node, - node.kind === 210 /* PropertyAccessExpression */ && node.expression.kind === 108 /* SuperKeyword */, + node.kind === 211 /* PropertyAccessExpression */ && node.expression.kind === 108 /* SuperKeyword */, /*isWrite*/ false, type, @@ -170773,7 +154631,7 @@ ${lanes.join("\n")} } function getForInVariableSymbol(node) { const initializer = node.initializer; - if (initializer.kind === 260 /* VariableDeclarationList */) { + if (initializer.kind === 261 /* VariableDeclarationList */) { const variable = initializer.declarations[0]; if (variable && !isBindingPattern(variable.name)) { return getSymbolOfDeclaration(variable); @@ -170794,7 +154652,7 @@ ${lanes.join("\n")} let child = expr; let node = expr.parent; while (node) { - if (node.kind === 248 /* ForInStatement */ && child === node.statement && getForInVariableSymbol(node) === symbol && hasNumericPropertyNames(getTypeOfExpression(node.expression))) { + if (node.kind === 249 /* ForInStatement */ && child === node.statement && getForInVariableSymbol(node) === symbol && hasNumericPropertyNames(getTypeOfExpression(node.expression))) { return true; } child = node; @@ -170805,7 +154663,7 @@ ${lanes.join("\n")} return false; } function checkIndexedAccess(node, checkMode) { - return node.flags & 32 /* OptionalChain */ ? checkElementAccessChain(node, checkMode) : checkElementAccessExpression(node, checkNonNullExpression(node.expression), checkMode); + return node.flags & 64 /* OptionalChain */ ? checkElementAccessChain(node, checkMode) : checkElementAccessExpression(node, checkNonNullExpression(node.expression), checkMode); } function checkElementAccessChain(node, checkMode) { const exprType = checkExpression(node.expression); @@ -170820,7 +154678,7 @@ ${lanes.join("\n")} return objectType; } if (isConstEnumObjectType(objectType) && !isStringLiteralLike(indexExpression)) { - error(indexExpression, Diagnostics.A_const_enum_member_can_only_be_accessed_using_a_string_literal); + error2(indexExpression, Diagnostics.A_const_enum_member_can_only_be_accessed_using_a_string_literal); return errorType; } const effectiveIndexType = isForInVariableForNumericPropertyNames(indexExpression) ? numberType : indexType; @@ -170835,11 +154693,13 @@ ${lanes.join("\n")} if (callLikeExpressionMayHaveTypeArguments(node)) { forEach(node.typeArguments, checkSourceElement); } - if (node.kind === 214 /* TaggedTemplateExpression */) { + if (node.kind === 215 /* TaggedTemplateExpression */) { checkExpression(node.template); } else if (isJsxOpeningLikeElement(node)) { checkExpression(node.attributes); - } else if (node.kind !== 169 /* Decorator */) { + } else if (isBinaryExpression(node)) { + checkExpression(node.left); + } else if (isCallOrNewExpression(node)) { forEach(node.arguments, (argument) => { checkExpression(argument); }); @@ -170884,7 +154744,7 @@ ${lanes.join("\n")} } } function isSpreadArgument(arg) { - return !!arg && (arg.kind === 229 /* SpreadElement */ || arg.kind === 236 /* SyntheticExpression */ && arg.isSpread); + return !!arg && (arg.kind === 230 /* SpreadElement */ || arg.kind === 237 /* SyntheticExpression */ && arg.isSpread); } function getSpreadArgumentIndex(args) { return findIndex(args, isSpreadArgument); @@ -170900,9 +154760,9 @@ ${lanes.join("\n")} let callIsIncomplete = false; let effectiveParameterCount = getParameterCount(signature); let effectiveMinimumArguments = getMinArgumentCount(signature); - if (node.kind === 214 /* TaggedTemplateExpression */) { + if (node.kind === 215 /* TaggedTemplateExpression */) { argCount = args.length; - if (node.template.kind === 227 /* TemplateExpression */) { + if (node.template.kind === 228 /* TemplateExpression */) { const lastSpan = last(node.template.templateSpans); callIsIncomplete = nodeIsMissing(lastSpan.literal) || !!lastSpan.literal.isUnterminated; } else { @@ -170910,8 +154770,10 @@ ${lanes.join("\n")} Debug.assert(templateLiteral.kind === 15 /* NoSubstitutionTemplateLiteral */); callIsIncomplete = !!templateLiteral.isUnterminated; } - } else if (node.kind === 169 /* Decorator */) { + } else if (node.kind === 170 /* Decorator */) { argCount = getDecoratorArgumentCount(node, signature); + } else if (node.kind === 226 /* BinaryExpression */) { + argCount = 1; } else if (isJsxOpeningLikeElement(node)) { callIsIncomplete = node.attributes.end === node.end; if (callIsIncomplete) { @@ -170921,7 +154783,7 @@ ${lanes.join("\n")} effectiveParameterCount = args.length === 0 ? effectiveParameterCount : 1; effectiveMinimumArguments = Math.min(effectiveMinimumArguments, 1); } else if (!node.arguments) { - Debug.assert(node.kind === 213 /* NewExpression */); + Debug.assert(node.kind === 214 /* NewExpression */); return getMinArgumentCount(signature) === 0; } else { argCount = signatureHelpTrailingComma ? args.length + 1 : args.length; @@ -171011,13 +154873,13 @@ ${lanes.join("\n")} return voidType; } const thisArgumentType = checkExpression(thisArgumentNode); - return isOptionalChainRoot(thisArgumentNode.parent) ? getNonNullableType(thisArgumentType) : isOptionalChain(thisArgumentNode.parent) ? removeOptionalTypeMarker(thisArgumentType) : thisArgumentType; + return isRightSideOfInstanceofExpression(thisArgumentNode) ? thisArgumentType : isOptionalChainRoot(thisArgumentNode.parent) ? getNonNullableType(thisArgumentType) : isOptionalChain(thisArgumentNode.parent) ? removeOptionalTypeMarker(thisArgumentType) : thisArgumentType; } function inferTypeArguments(node, signature, args, checkMode, context) { if (isJsxOpeningLikeElement(node)) { return inferJsxTypeArguments(node, signature, checkMode, context); } - if (node.kind !== 169 /* Decorator */) { + if (node.kind !== 170 /* Decorator */ && node.kind !== 226 /* BinaryExpression */) { const skipBindingPatterns = every(signature.typeParameters, (p) => !!getDefaultFromTypeParameter(p)); const contextualType = getContextualType2(node, skipBindingPatterns ? 8 /* SkipBindingPatterns */ : 0 /* None */); if (contextualType) { @@ -171054,7 +154916,7 @@ ${lanes.join("\n")} } for (let i = 0; i < argCount; i++) { const arg = args[i]; - if (arg.kind !== 231 /* OmittedExpression */ && !(checkMode & 32 /* IsForStringLiteralArgumentCompletions */ && hasSkipDirectInferenceFlag(arg))) { + if (arg.kind !== 232 /* OmittedExpression */) { const paramType = getTypeAtPosition(signature, i); if (couldContainTypeVariables(paramType)) { const argType = checkExpressionWithContextualType(arg, paramType, context, checkMode); @@ -171082,11 +154944,11 @@ ${lanes.join("\n")} if (index >= argCount - 1) { const arg = args[argCount - 1]; if (isSpreadArgument(arg)) { - const spreadType = arg.kind === 236 /* SyntheticExpression */ ? arg.type : checkExpressionWithContextualType(arg.expression, restType, context, checkMode); + const spreadType = arg.kind === 237 /* SyntheticExpression */ ? arg.type : checkExpressionWithContextualType(arg.expression, restType, context, checkMode); if (isArrayLikeType(spreadType)) { return getMutableArrayOrTupleType(spreadType); } - return createArrayType(checkIteratedTypeOrElementType(33 /* Spread */, spreadType, undefinedType, arg.kind === 229 /* SpreadElement */ ? arg.expression : arg), inConstContext); + return createArrayType(checkIteratedTypeOrElementType(33 /* Spread */, spreadType, undefinedType, arg.kind === 230 /* SpreadElement */ ? arg.expression : arg), inConstContext); } } const types = []; @@ -171095,12 +154957,12 @@ ${lanes.join("\n")} for (let i = index; i < argCount; i++) { const arg = args[i]; if (isSpreadArgument(arg)) { - const spreadType = arg.kind === 236 /* SyntheticExpression */ ? arg.type : checkExpression(arg.expression); + const spreadType = arg.kind === 237 /* SyntheticExpression */ ? arg.type : checkExpression(arg.expression); if (isArrayLikeType(spreadType)) { types.push(spreadType); flags.push(8 /* Variadic */); } else { - types.push(checkIteratedTypeOrElementType(33 /* Spread */, spreadType, undefinedType, arg.kind === 229 /* SpreadElement */ ? arg.expression : arg)); + types.push(checkIteratedTypeOrElementType(33 /* Spread */, spreadType, undefinedType, arg.kind === 230 /* SpreadElement */ ? arg.expression : arg)); flags.push(4 /* Rest */); } } else { @@ -171110,11 +154972,13 @@ ${lanes.join("\n")} types.push(hasPrimitiveContextualType ? getRegularTypeOfLiteralType(argType) : getWidenedLiteralType(argType)); flags.push(1 /* Required */); } - if (arg.kind === 236 /* SyntheticExpression */ && arg.tupleNameSource) { + if (arg.kind === 237 /* SyntheticExpression */ && arg.tupleNameSource) { names.push(arg.tupleNameSource); + } else { + names.push(void 0); } } - return createTupleType(types, flags, inConstContext, length(names) === length(types) ? names : void 0); + return createTupleType(types, flags, inConstContext && !someType(restType, isMutableArrayLikeType), names); } function checkTypeArguments(signature, typeArgumentNodes, reportErrors2, headMessage) { const isJavascript = isInJSFile(signature.declaration); @@ -171170,8 +155034,9 @@ ${lanes.join("\n")} void 0, checkMode ); + const checkAttributesType = checkMode & 4 /* SkipContextSensitive */ ? getRegularTypeOfObjectLiteral(attributesType) : attributesType; return checkTagNameDoesNotExpectTooManyArguments() && checkTypeRelatedToAndOptionallyElaborate( - attributesType, + checkAttributesType, paramType, relation, reportErrors2 ? node.tagName : void 0, @@ -171287,7 +155152,7 @@ ${lanes.join("\n")} const argCount = restType ? Math.min(getParameterCount(signature) - 1, args.length) : args.length; for (let i = 0; i < argCount; i++) { const arg = args[i]; - if (arg.kind !== 231 /* OmittedExpression */) { + if (arg.kind !== 232 /* OmittedExpression */) { const paramType = getTypeAtPosition(signature, i); const argType = checkExpressionWithContextualType( arg, @@ -171345,7 +155210,10 @@ ${lanes.join("\n")} } } function getThisArgumentOfCall(node) { - const expression = node.kind === 212 /* CallExpression */ ? node.expression : node.kind === 214 /* TaggedTemplateExpression */ ? node.tag : void 0; + if (node.kind === 226 /* BinaryExpression */) { + return node.right; + } + const expression = node.kind === 213 /* CallExpression */ ? node.expression : node.kind === 215 /* TaggedTemplateExpression */ ? node.tag : node.kind === 170 /* Decorator */ && !legacyDecorators ? node.expression : void 0; if (expression) { const callee = skipOuterExpressions(expression); if (isAccessExpression(callee)) { @@ -171360,19 +155228,22 @@ ${lanes.join("\n")} return result; } function getEffectiveCallArguments(node) { - if (node.kind === 214 /* TaggedTemplateExpression */) { + if (node.kind === 215 /* TaggedTemplateExpression */) { const template = node.template; const args2 = [createSyntheticExpression(template, getGlobalTemplateStringsArrayType())]; - if (template.kind === 227 /* TemplateExpression */) { + if (template.kind === 228 /* TemplateExpression */) { forEach(template.templateSpans, (span) => { args2.push(span.expression); }); } return args2; } - if (node.kind === 169 /* Decorator */) { + if (node.kind === 170 /* Decorator */) { return getEffectiveDecoratorArguments(node); } + if (node.kind === 226 /* BinaryExpression */) { + return [node.left]; + } if (isJsxOpeningLikeElement(node)) { return node.attributes.properties.length > 0 || isJsxOpeningElement(node) && node.parent.children.length > 0 ? [node.attributes] : emptyArray; } @@ -171382,17 +155253,12 @@ ${lanes.join("\n")} const effectiveArgs = args.slice(0, spreadIndex); for (let i = spreadIndex; i < args.length; i++) { const arg = args[i]; - const spreadType = arg.kind === 229 /* SpreadElement */ && (flowLoopCount ? checkExpression(arg.expression) : checkExpressionCached(arg.expression)); + const spreadType = arg.kind === 230 /* SpreadElement */ && (flowLoopCount ? checkExpression(arg.expression) : checkExpressionCached(arg.expression)); if (spreadType && isTupleType(spreadType)) { forEach(getElementTypes(spreadType), (t, i2) => { var _a; const flags = spreadType.target.elementFlags[i2]; - const syntheticArg = createSyntheticExpression( - arg, - flags & 4 /* Rest */ ? createArrayType(t) : t, - !!(flags & 12 /* Variable */), - (_a = spreadType.target.labeledElementDeclarations) == null ? void 0 : _a[i2] - ); + const syntheticArg = createSyntheticExpression(arg, flags & 4 /* Rest */ ? createArrayType(t) : t, !!(flags & 12 /* Variable */), (_a = spreadType.target.labeledElementDeclarations) == null ? void 0 : _a[i2]); effectiveArgs.push(syntheticArg); }); } else { @@ -171421,16 +155287,16 @@ ${lanes.join("\n")} } function getLegacyDecoratorArgumentCount(node, signature) { switch (node.parent.kind) { - case 262 /* ClassDeclaration */: - case 230 /* ClassExpression */: + case 263 /* ClassDeclaration */: + case 231 /* ClassExpression */: return 1; - case 171 /* PropertyDeclaration */: + case 172 /* PropertyDeclaration */: return hasAccessorModifier(node.parent) ? 3 : 2; - case 173 /* MethodDeclaration */: - case 176 /* GetAccessor */: - case 177 /* SetAccessor */: + case 174 /* MethodDeclaration */: + case 177 /* GetAccessor */: + case 178 /* SetAccessor */: return languageVersion === 0 /* ES3 */ || signature.parameters.length <= 2 ? 2 : 3; - case 168 /* Parameter */: + case 169 /* Parameter */: return 3; default: return Debug.fail(); @@ -171526,7 +155392,7 @@ ${lanes.join("\n")} if (isVoidPromiseError && isInJSFile(node)) { return getDiagnosticForCallNode(node, Diagnostics.Expected_1_argument_but_got_0_new_Promise_needs_a_JSDoc_hint_to_produce_a_resolve_that_can_be_called_without_arguments); } - const error2 = isDecorator(node) ? hasRestParameter2 ? Diagnostics.The_runtime_will_invoke_the_decorator_with_1_arguments_but_the_decorator_expects_at_least_0 : Diagnostics.The_runtime_will_invoke_the_decorator_with_1_arguments_but_the_decorator_expects_0 : hasRestParameter2 ? Diagnostics.Expected_at_least_0_arguments_but_got_1 : isVoidPromiseError ? Diagnostics.Expected_0_arguments_but_got_1_Did_you_forget_to_include_void_in_your_type_argument_to_Promise : Diagnostics.Expected_0_arguments_but_got_1; + const error3 = isDecorator(node) ? hasRestParameter2 ? Diagnostics.The_runtime_will_invoke_the_decorator_with_1_arguments_but_the_decorator_expects_at_least_0 : Diagnostics.The_runtime_will_invoke_the_decorator_with_1_arguments_but_the_decorator_expects_0 : hasRestParameter2 ? Diagnostics.Expected_at_least_0_arguments_but_got_1 : isVoidPromiseError ? Diagnostics.Expected_0_arguments_but_got_1_Did_you_forget_to_include_void_in_your_type_argument_to_Promise : Diagnostics.Expected_0_arguments_but_got_1; if (min2 < args.length && args.length < max) { if (headMessage) { let chain = chainDiagnosticMessages( @@ -171547,14 +155413,14 @@ ${lanes.join("\n")} let chain = chainDiagnosticMessages( /*details*/ void 0, - error2, + error3, parameterRange, args.length ); chain = chainDiagnosticMessages(chain, headMessage); diagnostic = getDiagnosticForCallNode(node, chain); } else { - diagnostic = getDiagnosticForCallNode(node, error2, parameterRange, args.length); + diagnostic = getDiagnosticForCallNode(node, error3, parameterRange, args.length); } const parameter = (_a = closestSignature == null ? void 0 : closestSignature.declaration) == null ? void 0 : _a.parameters[closestSignature.thisParameter ? args.length + 1 : args.length]; if (parameter) { @@ -171575,14 +155441,14 @@ ${lanes.join("\n")} let chain = chainDiagnosticMessages( /*details*/ void 0, - error2, + error3, parameterRange, args.length ); chain = chainDiagnosticMessages(chain, headMessage); return createDiagnosticForNodeArrayFromMessageChain(getSourceFileOfNode(node), errorSpan, chain); } - return createDiagnosticForNodeArray(getSourceFileOfNode(node), errorSpan, error2, parameterRange, args.length); + return createDiagnosticForNodeArray(getSourceFileOfNode(node), errorSpan, error3, parameterRange, args.length); } } function getTypeArgumentArityError(node, signatures, typeArguments, headMessage) { @@ -171644,12 +155510,13 @@ ${lanes.join("\n")} return createDiagnosticForNodeArray(getSourceFileOfNode(node), typeArguments, Diagnostics.Expected_0_type_arguments_but_got_1, belowArgCount === -Infinity ? aboveArgCount : belowArgCount, argCount); } function resolveCall(node, signatures, candidatesOutArray, checkMode, callChainFlags, headMessage) { - const isTaggedTemplate = node.kind === 214 /* TaggedTemplateExpression */; - const isDecorator2 = node.kind === 169 /* Decorator */; + const isTaggedTemplate = node.kind === 215 /* TaggedTemplateExpression */; + const isDecorator2 = node.kind === 170 /* Decorator */; const isJsxOpeningOrSelfClosingElement = isJsxOpeningLikeElement(node); + const isInstanceof = node.kind === 226 /* BinaryExpression */; const reportErrors2 = !isInferencePartiallyBlocked && !candidatesOutArray; let typeArguments; - if (!isDecorator2 && !isSuperCall(node)) { + if (!isDecorator2 && !isInstanceof && !isSuperCall(node)) { typeArguments = node.typeArguments; if (isTaggedTemplate || isJsxOpeningOrSelfClosingElement || node.expression.kind !== 108 /* SuperKeyword */) { forEach(typeArguments, checkSourceElement); @@ -171657,21 +155524,15 @@ ${lanes.join("\n")} } const candidates = candidatesOutArray || []; reorderCandidates(signatures, candidates, callChainFlags); - if (!candidates.length) { - if (reportErrors2) { - diagnostics.add(getDiagnosticForCallNode(node, Diagnostics.Call_target_does_not_contain_any_signatures)); - } - return resolveErrorCall(node); - } + Debug.assert(candidates.length, "Revert #54442 and add a testcase with whatever triggered this"); const args = getEffectiveCallArguments(node); const isSingleNonGenericCandidate = candidates.length === 1 && !candidates[0].typeParameters; let argCheckMode = !isDecorator2 && !isSingleNonGenericCandidate && some(args, isContextSensitive) ? 4 /* SkipContextSensitive */ : 0 /* Normal */; - argCheckMode |= checkMode & 32 /* IsForStringLiteralArgumentCompletions */; let candidatesForArgumentError; let candidateForArgumentArityError; let candidateForTypeArgumentError; let result; - const signatureHelpTrailingComma = !!(checkMode & 16 /* IsForSignatureHelp */) && node.kind === 212 /* CallExpression */ && node.arguments.hasTrailingComma; + const signatureHelpTrailingComma = !!(checkMode & 16 /* IsForSignatureHelp */) && node.kind === 213 /* CallExpression */ && node.arguments.hasTrailingComma; if (candidates.length > 1) { result = chooseOverload(candidates, subtypeRelation, isSingleNonGenericCandidate, signatureHelpTrailingComma); } @@ -171684,6 +155545,9 @@ ${lanes.join("\n")} result = getCandidateForOverloadFailure(node, candidates, args, !!candidatesOutArray, checkMode); getNodeLinks(node).resolvedSignature = result; if (reportErrors2) { + if (!headMessage && isInstanceof) { + headMessage = Diagnostics.The_left_hand_side_of_an_instanceof_expression_must_be_assignable_to_the_first_argument_of_the_right_hand_side_s_Symbol_hasInstance_method; + } if (candidatesForArgumentError) { if (candidatesForArgumentError.length === 1 || candidatesForArgumentError.length > 3) { const last2 = candidatesForArgumentError[candidatesForArgumentError.length - 1]; @@ -171890,7 +155754,7 @@ ${lanes.join("\n")} continue; } if (argCheckMode) { - argCheckMode = checkMode & 32 /* IsForStringLiteralArgumentCompletions */; + argCheckMode = 0 /* Normal */; if (inferenceContext) { const typeArgumentTypes = inferTypeArguments(node, candidate, args, argCheckMode, inferenceContext); checkCandidate = getSignatureInstantiation(candidate, typeArgumentTypes, isInJSFile(candidate.declaration), inferenceContext.inferredTypeParameters); @@ -171939,7 +155803,7 @@ ${lanes.join("\n")} parameters.push(createCombinedSymbolFromTypes(symbols, mapDefined(candidates, (candidate) => tryGetTypeAtPosition(candidate, i)))); } const restParameterSymbols = mapDefined(candidates, (c) => signatureHasRestParameter(c) ? last(c.parameters) : void 0); - let flags = 0 /* None */; + let flags = 128 /* IsSignatureCandidateForOverloadFailure */; if (restParameterSymbols.length !== 0) { const type = createArrayType(getUnionType(mapDefined(candidates, tryGetRestTypeOfSignature), 2 /* Subtype */)); parameters.push(createCombinedSymbolForOverloadFailure(restParameterSymbols, type)); @@ -172064,13 +155928,13 @@ ${lanes.join("\n")} const numConstructSignatures = getSignaturesOfType(apparentType, 1 /* Construct */).length; if (isUntypedFunctionCall(funcType, apparentType, callSignatures.length, numConstructSignatures)) { if (!isErrorType(funcType) && node.typeArguments) { - error(node, Diagnostics.Untyped_function_calls_may_not_accept_type_arguments); + error2(node, Diagnostics.Untyped_function_calls_may_not_accept_type_arguments); } return resolveUntypedCall(node); } if (!callSignatures.length) { if (numConstructSignatures) { - error(node, Diagnostics.Value_of_type_0_is_not_callable_Did_you_mean_to_include_new, typeToString(funcType)); + error2(node, Diagnostics.Value_of_type_0_is_not_callable_Did_you_mean_to_include_new, typeToString(funcType)); } else { let relatedInformation; if (node.arguments.length === 1) { @@ -172093,7 +155957,7 @@ ${lanes.join("\n")} return resolvingSignature; } if (callSignatures.some((sig) => isInJSFile(sig.declaration) && !!getJSDocClassTag(sig.declaration))) { - error(node, Diagnostics.Value_of_type_0_is_not_callable_Did_you_mean_to_include_new, typeToString(funcType)); + error2(node, Diagnostics.Value_of_type_0_is_not_callable_Did_you_mean_to_include_new, typeToString(funcType)); return resolveErrorCall(node); } return resolveCall(node, callSignatures, candidatesOutArray, checkMode, callChainFlags); @@ -172108,7 +155972,7 @@ ${lanes.join("\n")} if (node.arguments && languageVersion < 1 /* ES5 */) { const spreadIndex = getSpreadArgumentIndex(node.arguments); if (spreadIndex >= 0) { - error(node.arguments[spreadIndex], Diagnostics.Spread_operator_in_new_expressions_is_only_available_when_targeting_ECMAScript_5_and_higher); + error2(node.arguments[spreadIndex], Diagnostics.Spread_operator_in_new_expressions_is_only_available_when_targeting_ECMAScript_5_and_higher); } } let expressionType = checkNonNullExpression(node.expression); @@ -172121,7 +155985,7 @@ ${lanes.join("\n")} } if (isTypeAny(expressionType)) { if (node.typeArguments) { - error(node, Diagnostics.Untyped_function_calls_may_not_accept_type_arguments); + error2(node, Diagnostics.Untyped_function_calls_may_not_accept_type_arguments); } return resolveUntypedCall(node); } @@ -172131,12 +155995,12 @@ ${lanes.join("\n")} return resolveErrorCall(node); } if (someSignature(constructSignatures, (signature) => !!(signature.flags & 4 /* Abstract */))) { - error(node, Diagnostics.Cannot_create_an_instance_of_an_abstract_class); + error2(node, Diagnostics.Cannot_create_an_instance_of_an_abstract_class); return resolveErrorCall(node); } const valueDecl = expressionType.symbol && getClassLikeDeclarationOfSymbol(expressionType.symbol); - if (valueDecl && hasSyntacticModifier(valueDecl, 256 /* Abstract */)) { - error(node, Diagnostics.Cannot_create_an_instance_of_an_abstract_class); + if (valueDecl && hasSyntacticModifier(valueDecl, 64 /* Abstract */)) { + error2(node, Diagnostics.Cannot_create_an_instance_of_an_abstract_class); return resolveErrorCall(node); } return resolveCall(node, constructSignatures, candidatesOutArray, checkMode, 0 /* None */); @@ -172146,10 +156010,10 @@ ${lanes.join("\n")} const signature = resolveCall(node, callSignatures, candidatesOutArray, checkMode, 0 /* None */); if (!noImplicitAny) { if (signature.declaration && !isJSConstructor(signature.declaration) && getReturnTypeOfSignature(signature) !== voidType) { - error(node, Diagnostics.Only_a_void_function_can_be_called_with_the_new_keyword); + error2(node, Diagnostics.Only_a_void_function_can_be_called_with_the_new_keyword); } if (getThisTypeOfSignature(signature) === voidType) { - error(node, Diagnostics.A_function_that_is_called_with_the_new_keyword_cannot_have_a_this_type_that_is_void); + error2(node, Diagnostics.A_function_that_is_called_with_the_new_keyword_cannot_have_a_this_type_that_is_void); } } return signature; @@ -172198,25 +156062,25 @@ ${lanes.join("\n")} return true; } const declaration = signature.declaration; - const modifiers = getSelectedEffectiveModifierFlags(declaration, 24 /* NonPublicAccessibilityModifier */); - if (!modifiers || declaration.kind !== 175 /* Constructor */) { + const modifiers = getSelectedEffectiveModifierFlags(declaration, 6 /* NonPublicAccessibilityModifier */); + if (!modifiers || declaration.kind !== 176 /* Constructor */) { return true; } const declaringClassDeclaration = getClassLikeDeclarationOfSymbol(declaration.parent.symbol); const declaringClass = getDeclaredTypeOfSymbol(declaration.parent.symbol); if (!isNodeWithinClass(node, declaringClassDeclaration)) { const containingClass = getContainingClass(node); - if (containingClass && modifiers & 16 /* Protected */) { + if (containingClass && modifiers & 4 /* Protected */) { const containingType = getTypeOfNode(containingClass); if (typeHasProtectedAccessibleBase(declaration.parent.symbol, containingType)) { return true; } } - if (modifiers & 8 /* Private */) { - error(node, Diagnostics.Constructor_of_class_0_is_private_and_only_accessible_within_the_class_declaration, typeToString(declaringClass)); + if (modifiers & 2 /* Private */) { + error2(node, Diagnostics.Constructor_of_class_0_is_private_and_only_accessible_within_the_class_declaration, typeToString(declaringClass)); } - if (modifiers & 16 /* Protected */) { - error(node, Diagnostics.Constructor_of_class_0_is_protected_and_only_accessible_within_the_class_declaration, typeToString(declaringClass)); + if (modifiers & 4 /* Protected */) { + error2(node, Diagnostics.Constructor_of_class_0_is_protected_and_only_accessible_within_the_class_declaration, typeToString(declaringClass)); } return false; } @@ -172316,10 +156180,7 @@ ${lanes.join("\n")} const sigs = getSignaturesOfType(getTypeOfSymbol(getSymbolLinks(apparentType.symbol).target), kind); if (!sigs || !sigs.length) return; - addRelatedInfo( - diagnostic, - createDiagnosticForNode(importNode, Diagnostics.Type_originates_at_this_import_A_namespace_style_import_cannot_be_called_or_constructed_and_will_cause_a_failure_at_runtime_Consider_using_a_default_import_or_import_require_here_instead) - ); + addRelatedInfo(diagnostic, createDiagnosticForNode(importNode, Diagnostics.Type_originates_at_this_import_A_namespace_style_import_cannot_be_called_or_constructed_and_will_cause_a_failure_at_runtime_Consider_using_a_default_import_or_import_require_here_instead)); } } function resolveTaggedTemplateExpression(node, candidatesOutArray, checkMode) { @@ -172346,16 +156207,16 @@ ${lanes.join("\n")} } function getDiagnosticHeadMessageForDecoratorResolution(node) { switch (node.parent.kind) { - case 262 /* ClassDeclaration */: - case 230 /* ClassExpression */: + case 263 /* ClassDeclaration */: + case 231 /* ClassExpression */: return Diagnostics.Unable_to_resolve_signature_of_class_decorator_when_called_as_an_expression; - case 168 /* Parameter */: + case 169 /* Parameter */: return Diagnostics.Unable_to_resolve_signature_of_parameter_decorator_when_called_as_an_expression; - case 171 /* PropertyDeclaration */: + case 172 /* PropertyDeclaration */: return Diagnostics.Unable_to_resolve_signature_of_property_decorator_when_called_as_an_expression; - case 173 /* MethodDeclaration */: - case 176 /* GetAccessor */: - case 177 /* SetAccessor */: + case 174 /* MethodDeclaration */: + case 177 /* GetAccessor */: + case 178 /* SetAccessor */: return Diagnostics.Unable_to_resolve_signature_of_method_decorator_when_called_as_an_expression; default: return Debug.fail(); @@ -172378,7 +156239,7 @@ ${lanes.join("\n")} /*includeTrivia*/ false ); - error(node, Diagnostics._0_accepts_too_few_arguments_to_be_used_as_a_decorator_here_Did_you_mean_to_call_it_first_and_write_0, nodeStr); + error2(node, Diagnostics._0_accepts_too_few_arguments_to_be_used_as_a_decorator_here_Did_you_mean_to_call_it_first_and_write_0, nodeStr); return resolveErrorCall(node); } const headMessage = getDiagnosticHeadMessageForDecoratorResolution(node); @@ -172468,27 +156329,53 @@ ${lanes.join("\n")} return resolveUntypedCall(node); } if (signatures.length === 0) { - error(node.tagName, Diagnostics.JSX_element_type_0_does_not_have_any_construct_or_call_signatures, getTextOfNode(node.tagName)); + error2(node.tagName, Diagnostics.JSX_element_type_0_does_not_have_any_construct_or_call_signatures, getTextOfNode(node.tagName)); return resolveErrorCall(node); } return resolveCall(node, signatures, candidatesOutArray, checkMode, 0 /* None */); } + function resolveInstanceofExpression(node, candidatesOutArray, checkMode) { + const rightType = checkExpression(node.right); + if (!isTypeAny(rightType)) { + const hasInstanceMethodType = getSymbolHasInstanceMethodOfObjectType(rightType); + if (hasInstanceMethodType) { + const apparentType = getApparentType(hasInstanceMethodType); + if (isErrorType(apparentType)) { + return resolveErrorCall(node); + } + const callSignatures = getSignaturesOfType(apparentType, 0 /* Call */); + const constructSignatures = getSignaturesOfType(apparentType, 1 /* Construct */); + if (isUntypedFunctionCall(hasInstanceMethodType, apparentType, callSignatures.length, constructSignatures.length)) { + return resolveUntypedCall(node); + } + if (callSignatures.length) { + return resolveCall(node, callSignatures, candidatesOutArray, checkMode, 0 /* None */); + } + } else if (!(typeHasCallOrConstructSignatures(rightType) || isTypeSubtypeOf(rightType, globalFunctionType))) { + error2(node.right, Diagnostics.The_right_hand_side_of_an_instanceof_expression_must_be_either_of_type_any_a_class_function_or_other_type_assignable_to_the_Function_interface_type_or_an_object_type_with_a_Symbol_hasInstance_method); + return resolveErrorCall(node); + } + } + return anySignature; + } function isPotentiallyUncalledDecorator(decorator, signatures) { return signatures.length && every(signatures, (signature) => signature.minArgumentCount === 0 && !signatureHasRestParameter(signature) && signature.parameters.length < getDecoratorArgumentCount(decorator, signature)); } function resolveSignature(node, candidatesOutArray, checkMode) { switch (node.kind) { - case 212 /* CallExpression */: + case 213 /* CallExpression */: return resolveCallExpression(node, candidatesOutArray, checkMode); - case 213 /* NewExpression */: + case 214 /* NewExpression */: return resolveNewExpression(node, candidatesOutArray, checkMode); - case 214 /* TaggedTemplateExpression */: + case 215 /* TaggedTemplateExpression */: return resolveTaggedTemplateExpression(node, candidatesOutArray, checkMode); - case 169 /* Decorator */: + case 170 /* Decorator */: return resolveDecorator(node, candidatesOutArray, checkMode); - case 285 /* JsxOpeningElement */: - case 284 /* JsxSelfClosingElement */: + case 286 /* JsxOpeningElement */: + case 285 /* JsxSelfClosingElement */: return resolveJsxOpeningLikeElement(node, candidatesOutArray, checkMode); + case 226 /* BinaryExpression */: + return resolveInstanceofExpression(node, candidatesOutArray, checkMode); } Debug.assertNever(node, "Branch in 'resolveSignature' should be unreachable."); } @@ -172563,7 +156450,7 @@ ${lanes.join("\n")} let name; let decl; if (isVariableDeclaration(node.parent) && node.parent.initializer === node) { - if (!isInJSFile(node) && !(isVarConst(node.parent) && isFunctionLikeDeclaration(node))) { + if (!isInJSFile(node) && !(isVarConstLike(node.parent) && isFunctionLikeDeclaration(node))) { return void 0; } name = node.parent.name; @@ -172600,7 +156487,7 @@ ${lanes.join("\n")} return false; } let parent2 = node.parent; - while (parent2 && parent2.kind === 210 /* PropertyAccessExpression */) { + while (parent2 && parent2.kind === 211 /* PropertyAccessExpression */) { parent2 = parent2.parent; } if (parent2 && isBinaryExpression(parent2) && isPrototypeAccess(parent2.left) && parent2.operatorToken.kind === 64 /* EqualsToken */) { @@ -172624,11 +156511,11 @@ ${lanes.join("\n")} if (node.expression.kind === 108 /* SuperKeyword */) { return voidType; } - if (node.kind === 213 /* NewExpression */) { + if (node.kind === 214 /* NewExpression */) { const declaration = signature.declaration; - if (declaration && declaration.kind !== 175 /* Constructor */ && declaration.kind !== 179 /* ConstructSignature */ && declaration.kind !== 184 /* ConstructorType */ && !(isJSDocSignature(declaration) && ((_b = (_a = getJSDocRoot(declaration)) == null ? void 0 : _a.parent) == null ? void 0 : _b.kind) === 175 /* Constructor */) && !isJSDocConstructSignature(declaration) && !isJSConstructor(declaration)) { + if (declaration && declaration.kind !== 176 /* Constructor */ && declaration.kind !== 180 /* ConstructSignature */ && declaration.kind !== 185 /* ConstructorType */ && !(isJSDocSignature(declaration) && ((_b = (_a = getJSDocRoot(declaration)) == null ? void 0 : _a.parent) == null ? void 0 : _b.kind) === 176 /* Constructor */) && !isJSDocConstructSignature(declaration) && !isJSConstructor(declaration)) { if (noImplicitAny) { - error(node, Diagnostics.new_expression_whose_target_lacks_a_construct_signature_implicitly_has_an_any_type); + error2(node, Diagnostics.new_expression_whose_target_lacks_a_construct_signature_implicitly_has_an_any_type); } return anyType; } @@ -172640,11 +156527,11 @@ ${lanes.join("\n")} if (returnType.flags & 12288 /* ESSymbolLike */ && isSymbolOrSymbolForCall(node)) { return getESSymbolLikeTypeForNode(walkUpParenthesizedExpressions(node.parent)); } - if (node.kind === 212 /* CallExpression */ && !node.questionDotToken && node.parent.kind === 243 /* ExpressionStatement */ && returnType.flags & 16384 /* Void */ && getTypePredicateOfSignature(signature)) { + if (node.kind === 213 /* CallExpression */ && !node.questionDotToken && node.parent.kind === 244 /* ExpressionStatement */ && returnType.flags & 16384 /* Void */ && getTypePredicateOfSignature(signature)) { if (!isDottedName(node.expression)) { - error(node.expression, Diagnostics.Assertions_require_the_call_target_to_be_an_identifier_or_qualified_name); + error2(node.expression, Diagnostics.Assertions_require_the_call_target_to_be_an_identifier_or_qualified_name); } else if (!getEffectsSignature(node)) { - const diagnostic = error(node.expression, Diagnostics.Assertions_require_every_name_in_the_call_target_to_be_declared_with_an_explicit_type_annotation); + const diagnostic = error2(node.expression, Diagnostics.Assertions_require_every_name_in_the_call_target_to_be_declared_with_an_explicit_type_annotation); getTypeOfDottedName(node.expression, diagnostic); } } @@ -172663,7 +156550,9 @@ ${lanes.join("\n")} return returnType; } function checkDeprecatedSignature(signature, node) { - if (signature.declaration && signature.declaration.flags & 268435456 /* Deprecated */) { + if (signature.flags & 128 /* IsSignatureCandidateForOverloadFailure */) + return; + if (signature.declaration && signature.declaration.flags & 536870912 /* Deprecated */) { const suggestionNode = getDeprecatedSuggestionNode(node); const name = tryGetPropertyAccessOrIdentifierToString(getInvokedExpression(node)); addDeprecatedSuggestionWithSignature(suggestionNode, signature.declaration, name, signatureToString(signature)); @@ -172672,20 +156561,20 @@ ${lanes.join("\n")} function getDeprecatedSuggestionNode(node) { node = skipParentheses(node); switch (node.kind) { - case 212 /* CallExpression */: - case 169 /* Decorator */: - case 213 /* NewExpression */: + case 213 /* CallExpression */: + case 170 /* Decorator */: + case 214 /* NewExpression */: return getDeprecatedSuggestionNode(node.expression); - case 214 /* TaggedTemplateExpression */: + case 215 /* TaggedTemplateExpression */: return getDeprecatedSuggestionNode(node.tag); - case 285 /* JsxOpeningElement */: - case 284 /* JsxSelfClosingElement */: + case 286 /* JsxOpeningElement */: + case 285 /* JsxSelfClosingElement */: return getDeprecatedSuggestionNode(node.tagName); - case 211 /* ElementAccessExpression */: + case 212 /* ElementAccessExpression */: return node.argumentExpression; - case 210 /* PropertyAccessExpression */: + case 211 /* PropertyAccessExpression */: return node.name; - case 182 /* TypeReference */: + case 183 /* TypeReference */: const typeReference = node; return isQualifiedName(typeReference.typeName) ? typeReference.typeName.right : typeReference; default: @@ -172733,7 +156622,7 @@ ${lanes.join("\n")} checkExpressionCached(node.arguments[i]); } if (specifierType.flags & 32768 /* Undefined */ || specifierType.flags & 65536 /* Null */ || !isTypeAssignableTo(specifierType, stringType)) { - error(specifier, Diagnostics.Dynamic_import_s_specifier_must_be_of_type_string_but_here_has_type_0, typeToString(specifierType)); + error2(specifier, Diagnostics.Dynamic_import_s_specifier_must_be_of_type_string_but_here_has_type_0, typeToString(specifierType)); } if (optionsType) { const importCallOptionsType = getGlobalImportCallOptionsType( @@ -172845,10 +156734,10 @@ ${lanes.join("\n")} if (resolvedRequire.flags & 2097152 /* Alias */) { return false; } - const targetDeclarationKind = resolvedRequire.flags & 16 /* Function */ ? 261 /* FunctionDeclaration */ : resolvedRequire.flags & 3 /* Variable */ ? 259 /* VariableDeclaration */ : 0 /* Unknown */; + const targetDeclarationKind = resolvedRequire.flags & 16 /* Function */ ? 262 /* FunctionDeclaration */ : resolvedRequire.flags & 3 /* Variable */ ? 260 /* VariableDeclaration */ : 0 /* Unknown */; if (targetDeclarationKind !== 0 /* Unknown */) { const decl = getDeclarationOfKind(resolvedRequire, targetDeclarationKind); - return !!decl && !!(decl.flags & 16777216 /* Ambient */); + return !!decl && !!(decl.flags & 33554432 /* Ambient */); } return false; } @@ -172863,7 +156752,7 @@ ${lanes.join("\n")} return getReturnTypeOfSignature(signature); } function checkAssertion(node, checkMode) { - if (node.kind === 215 /* TypeAssertionExpression */) { + if (node.kind === 216 /* TypeAssertionExpression */) { const file = getSourceFileOfNode(node); if (file && fileExtensionIsOneOf(file.fileName, [".cts" /* Cts */, ".mts" /* Mts */])) { grammarErrorOnNode(node, Diagnostics.This_syntax_is_reserved_in_files_with_the_mts_or_cts_extension_Use_an_as_expression_instead); @@ -172879,18 +156768,18 @@ ${lanes.join("\n")} case 10 /* BigIntLiteral */: case 112 /* TrueKeyword */: case 97 /* FalseKeyword */: - case 208 /* ArrayLiteralExpression */: - case 209 /* ObjectLiteralExpression */: - case 227 /* TemplateExpression */: + case 209 /* ArrayLiteralExpression */: + case 210 /* ObjectLiteralExpression */: + case 228 /* TemplateExpression */: return true; - case 216 /* ParenthesizedExpression */: + case 217 /* ParenthesizedExpression */: return isValidConstAssertionArgument(node.expression); - case 223 /* PrefixUnaryExpression */: + case 224 /* PrefixUnaryExpression */: const op = node.operator; const arg = node.operand; return op === 41 /* MinusToken */ && (arg.kind === 9 /* NumericLiteral */ || arg.kind === 10 /* BigIntLiteral */) || op === 40 /* PlusToken */ && arg.kind === 9 /* NumericLiteral */; - case 210 /* PropertyAccessExpression */: - case 211 /* ElementAccessExpression */: + case 211 /* PropertyAccessExpression */: + case 212 /* ElementAccessExpression */: const expr = skipParentheses(node.expression); const symbol = isEntityNameExpression(expr) ? resolveEntityName( expr, @@ -172907,7 +156796,7 @@ ${lanes.join("\n")} const exprType = checkExpression(expression, checkMode); if (isConstTypeReference(type)) { if (!isValidConstAssertionArgument(expression)) { - error(expression, Diagnostics.A_const_assertions_can_only_be_applied_to_references_to_enum_members_or_string_number_boolean_array_or_object_literals); + error2(expression, Diagnostics.A_const_assertions_can_only_be_applied_to_references_to_enum_members_or_string_number_boolean_array_or_object_literals); } return getRegularTypeOfLiteralType(exprType); } @@ -172921,12 +156810,12 @@ ${lanes.join("\n")} let type; let expression; switch (node.kind) { - case 233 /* AsExpression */: - case 215 /* TypeAssertionExpression */: + case 234 /* AsExpression */: + case 216 /* TypeAssertionExpression */: type = node.type; expression = node.expression; break; - case 216 /* ParenthesizedExpression */: + case 217 /* ParenthesizedExpression */: type = getJSDocTypeAssertionType(node); expression = node.expression; break; @@ -172944,12 +156833,7 @@ ${lanes.join("\n")} addLazyDiagnostic(() => { const widenedType = getWidenedType(exprType); if (!isTypeComparableTo(targetType, widenedType)) { - checkTypeComparableTo( - exprType, - targetType, - errNode, - Diagnostics.Conversion_of_type_0_to_type_1_may_be_a_mistake_because_neither_type_sufficiently_overlaps_with_the_other_If_this_was_intentional_convert_the_expression_to_unknown_first - ); + checkTypeComparableTo(exprType, targetType, errNode, Diagnostics.Conversion_of_type_0_to_type_1_may_be_a_mistake_because_neither_type_sufficiently_overlaps_with_the_other_If_this_was_intentional_convert_the_expression_to_unknown_first); } }); } @@ -172960,18 +156844,18 @@ ${lanes.join("\n")} return propagateOptionalTypeMarker(getNonNullableType(nonOptionalType), node, nonOptionalType !== leftType); } function checkNonNullAssertion(node) { - return node.flags & 32 /* OptionalChain */ ? checkNonNullChain(node) : getNonNullableType(checkExpression(node.expression)); + return node.flags & 64 /* OptionalChain */ ? checkNonNullChain(node) : getNonNullableType(checkExpression(node.expression)); } function checkExpressionWithTypeArguments(node) { checkGrammarExpressionWithTypeArguments(node); forEach(node.typeArguments, checkSourceElement); - if (node.kind === 232 /* ExpressionWithTypeArguments */) { + if (node.kind === 233 /* ExpressionWithTypeArguments */) { const parent2 = walkUpParenthesizedExpressions(node.parent); - if (parent2.kind === 225 /* BinaryExpression */ && parent2.operatorToken.kind === 104 /* InstanceOfKeyword */ && isNodeDescendantOf(node, parent2.right)) { - error(node, Diagnostics.The_right_hand_side_of_an_instanceof_expression_must_not_be_an_instantiation_expression); + if (parent2.kind === 226 /* BinaryExpression */ && parent2.operatorToken.kind === 104 /* InstanceOfKeyword */ && isNodeDescendantOf(node, parent2.right)) { + error2(node, Diagnostics.The_right_hand_side_of_an_instanceof_expression_must_not_be_an_instantiation_expression); } } - const exprType = node.kind === 232 /* ExpressionWithTypeArguments */ ? checkExpression(node.expression) : isThisIdentifier(node.exprName) ? checkThisExpression(node.exprName) : checkExpression(node.exprName); + const exprType = node.kind === 233 /* ExpressionWithTypeArguments */ ? checkExpression(node.expression) : isThisIdentifier(node.exprName) ? checkThisExpression(node.exprName) : checkExpression(node.exprName); return getInstantiationExpressionType(exprType, node); } function getInstantiationExpressionType(exprType, node) { @@ -173055,7 +156939,7 @@ ${lanes.join("\n")} if (isErrorType(targetType)) { return targetType; } - const errorNode = findAncestor(target.parent, (n) => n.kind === 237 /* SatisfiesExpression */ || n.kind === 356 /* JSDocSatisfiesTag */); + const errorNode = findAncestor(target.parent, (n) => n.kind === 238 /* SatisfiesExpression */ || n.kind === 357 /* JSDocSatisfiesTag */); checkTypeAssignableToAndOptionallyElaborate(exprType, targetType, errorNode, expression, Diagnostics.Type_0_does_not_satisfy_the_expected_type_1); return exprType; } @@ -173083,9 +156967,9 @@ ${lanes.join("\n")} function checkNewTargetMetaProperty(node) { const container = getNewTargetContainer(node); if (!container) { - error(node, Diagnostics.Meta_property_0_is_only_allowed_in_the_body_of_a_function_declaration_function_expression_or_constructor, "new.target"); + error2(node, Diagnostics.Meta_property_0_is_only_allowed_in_the_body_of_a_function_declaration_function_expression_or_constructor, "new.target"); return errorType; - } else if (container.kind === 175 /* Constructor */) { + } else if (container.kind === 176 /* Constructor */) { const symbol = getSymbolOfDeclaration(container.parent); return getTypeOfSymbol(symbol); } else { @@ -173096,26 +156980,29 @@ ${lanes.join("\n")} function checkImportMetaProperty(node) { if (moduleKind === 100 /* Node16 */ || moduleKind === 199 /* NodeNext */) { if (getSourceFileOfNode(node).impliedNodeFormat !== 99 /* ESNext */) { - error(node, Diagnostics.The_import_meta_meta_property_is_not_allowed_in_files_which_will_build_into_CommonJS_output); + error2(node, Diagnostics.The_import_meta_meta_property_is_not_allowed_in_files_which_will_build_into_CommonJS_output); } } else if (moduleKind < 6 /* ES2020 */ && moduleKind !== 4 /* System */) { - error(node, Diagnostics.The_import_meta_meta_property_is_only_allowed_when_the_module_option_is_es2020_es2022_esnext_system_node16_or_nodenext); + error2(node, Diagnostics.The_import_meta_meta_property_is_only_allowed_when_the_module_option_is_es2020_es2022_esnext_system_node16_or_nodenext); } const file = getSourceFileOfNode(node); - Debug.assert(!!(file.flags & 4194304 /* PossiblyContainsImportMeta */), "Containing file is missing import meta node flag."); + Debug.assert(!!(file.flags & 8388608 /* PossiblyContainsImportMeta */), "Containing file is missing import meta node flag."); return node.name.escapedText === "meta" ? getGlobalImportMetaType() : errorType; } function getTypeOfParameter(symbol) { - const type = getTypeOfSymbol(symbol); - if (strictNullChecks) { - const declaration = symbol.valueDeclaration; - if (declaration && hasInitializer(declaration)) { - return getOptionalType(type); - } - } - return type; + const declaration = symbol.valueDeclaration; + return addOptionality( + getTypeOfSymbol(symbol), + /*isProperty*/ + false, + /*isOptional*/ + !!declaration && (hasInitializer(declaration) || isOptionalDeclaration(declaration)) + ); } - function getTupleElementLabel(d) { + function getTupleElementLabel(d, index, restParameterName = "arg") { + if (!d) { + return `${restParameterName}_${index}`; + } Debug.assert(isIdentifier(d.name)); return d.name.escapedText; } @@ -173129,22 +157016,28 @@ ${lanes.join("\n")} if (isTupleType(restType)) { const associatedNames = restType.target.labeledElementDeclarations; const index = pos - paramCount; - return associatedNames && getTupleElementLabel(associatedNames[index]) || restParameter.escapedName + "_" + index; + return getTupleElementLabel(associatedNames == null ? void 0 : associatedNames[index], index, restParameter.escapedName); } return restParameter.escapedName; } - function getParameterIdentifierNameAtPosition(signature, pos) { + function getParameterIdentifierInfoAtPosition(signature, pos) { var _a; - if (((_a = signature.declaration) == null ? void 0 : _a.kind) === 323 /* JSDocFunctionType */) { + if (((_a = signature.declaration) == null ? void 0 : _a.kind) === 324 /* JSDocFunctionType */) { return void 0; } const paramCount = signature.parameters.length - (signatureHasRestParameter(signature) ? 1 : 0); if (pos < paramCount) { const param = signature.parameters[pos]; - return isParameterDeclarationWithIdentifierName(param) ? [param.escapedName, false] : void 0; + const paramIdent = getParameterDeclarationIdentifier(param); + return paramIdent ? { + parameter: paramIdent, + parameterName: param.escapedName, + isRestParameter: false + } : void 0; } const restParameter = signature.parameters[paramCount] || unknownSymbol; - if (!isParameterDeclarationWithIdentifierName(restParameter)) { + const restIdent = getParameterDeclarationIdentifier(restParameter); + if (!restIdent) { return void 0; } const restType = getTypeOfSymbol(restParameter); @@ -173153,21 +157046,22 @@ ${lanes.join("\n")} const index = pos - paramCount; const associatedName = associatedNames == null ? void 0 : associatedNames[index]; const isRestTupleElement = !!(associatedName == null ? void 0 : associatedName.dotDotDotToken); - return associatedName ? [ - getTupleElementLabel(associatedName), - isRestTupleElement - ] : void 0; + if (associatedName) { + Debug.assert(isIdentifier(associatedName.name)); + return { parameter: associatedName.name, parameterName: associatedName.name.escapedText, isRestParameter: isRestTupleElement }; + } + return void 0; } if (pos === paramCount) { - return [restParameter.escapedName, true]; + return { parameter: restIdent, parameterName: restParameter.escapedName, isRestParameter: true }; } return void 0; } - function isParameterDeclarationWithIdentifierName(symbol) { - return symbol.valueDeclaration && isParameter(symbol.valueDeclaration) && isIdentifier(symbol.valueDeclaration.name); + function getParameterDeclarationIdentifier(symbol) { + return symbol.valueDeclaration && isParameter(symbol.valueDeclaration) && isIdentifier(symbol.valueDeclaration.name) && symbol.valueDeclaration.name; } function isValidDeclarationForTupleLabel(d) { - return d.kind === 201 /* NamedTupleMember */ || isParameter(d) && d.name && isIdentifier(d.name); + return d.kind === 202 /* NamedTupleMember */ || isParameter(d) && d.name && isIdentifier(d.name); } function getNameableDeclarationAtPosition(signature, pos) { const paramCount = signature.parameters.length - (signatureHasRestParameter(signature) ? 1 : 0); @@ -173201,7 +157095,7 @@ ${lanes.join("\n")} } return void 0; } - function getRestTypeAtPosition(source, pos) { + function getRestTypeAtPosition(source, pos, readonly) { const parameterCount = getParameterCount(source); const minArgumentCount = getMinArgumentCount(source); const restType = getEffectiveRestType(source); @@ -173219,18 +157113,9 @@ ${lanes.join("\n")} types.push(restType); flags.push(8 /* Variadic */); } - const name = getNameableDeclarationAtPosition(source, i); - if (name) { - names.push(name); - } + names.push(getNameableDeclarationAtPosition(source, i)); } - return createTupleType( - types, - flags, - /*readonly*/ - false, - length(names) === length(types) ? names : void 0 - ); + return createTupleType(types, flags, readonly, names); } function getParameterCount(signature) { const length2 = signature.parameters.length; @@ -173310,11 +157195,16 @@ ${lanes.join("\n")} const len = signature.parameters.length - (signatureHasRestParameter(signature) ? 1 : 0); for (let i = 0; i < len; i++) { const declaration = signature.parameters[i].valueDeclaration; - if (declaration.type) { - const typeNode = getEffectiveTypeAnnotationNode(declaration); - if (typeNode) { - inferTypes(inferenceContext.inferences, getTypeFromTypeNode(typeNode), getTypeAtPosition(context, i)); - } + const typeNode = getEffectiveTypeAnnotationNode(declaration); + if (typeNode) { + const source = addOptionality( + getTypeFromTypeNode(typeNode), + /*isProperty*/ + false, + isOptionalDeclaration(declaration) + ); + const target = getTypeAtPosition(context, i); + inferTypes(inferenceContext.inferences, source, target); } } } @@ -173363,29 +157253,40 @@ ${lanes.join("\n")} assignParameterType(parameter); } } - function assignParameterType(parameter, type) { + function assignParameterType(parameter, contextualType) { const links = getSymbolLinks(parameter); if (!links.type) { const declaration = parameter.valueDeclaration; - links.type = type || (declaration ? getWidenedTypeForVariableLikeDeclaration( - declaration, - /*reportErrors*/ - true - ) : getTypeOfSymbol(parameter)); + links.type = addOptionality( + contextualType || (declaration ? getWidenedTypeForVariableLikeDeclaration( + declaration, + /*reportErrors*/ + true + ) : getTypeOfSymbol(parameter)), + /*isProperty*/ + false, + /*isOptional*/ + !!declaration && !declaration.initializer && isOptionalDeclaration(declaration) + ); if (declaration && declaration.name.kind !== 80 /* Identifier */) { if (links.type === unknownType) { links.type = getTypeFromBindingPattern(declaration.name); } assignBindingElementTypes(declaration.name, links.type); } - } else if (type) { - Debug.assertEqual(links.type, type, "Parameter symbol already has a cached type which differs from newly assigned type"); + } else if (contextualType) { + Debug.assertEqual(links.type, contextualType, "Parameter symbol already has a cached type which differs from newly assigned type"); } } function assignBindingElementTypes(pattern, parentType) { for (const element of pattern.elements) { if (!isOmittedExpression(element)) { - const type = getBindingElementTypeFromParentType(element, parentType); + const type = getBindingElementTypeFromParentType( + element, + parentType, + /*noTupleBoundsCheck*/ + false + ); if (element.name.kind === 80 /* Identifier */) { getSymbolLinks(getSymbolOfDeclaration(element)).type = type; } else { @@ -173503,17 +157404,17 @@ ${lanes.join("\n")} if (!links.decoratorSignature) { links.decoratorSignature = anySignature; switch (parent2.kind) { - case 262 /* ClassDeclaration */: - case 230 /* ClassExpression */: { + case 263 /* ClassDeclaration */: + case 231 /* ClassExpression */: { const node = parent2; const targetType = getTypeOfSymbol(getSymbolOfDeclaration(node)); const contextType = createClassDecoratorContextType(targetType); links.decoratorSignature = createESDecoratorCallSignature(targetType, contextType, targetType); break; } - case 173 /* MethodDeclaration */: - case 176 /* GetAccessor */: - case 177 /* SetAccessor */: { + case 174 /* MethodDeclaration */: + case 177 /* GetAccessor */: + case 178 /* SetAccessor */: { const node = parent2; if (!isClassLike(node.parent)) break; @@ -173525,7 +157426,7 @@ ${lanes.join("\n")} links.decoratorSignature = createESDecoratorCallSignature(targetType, contextType, returnType); break; } - case 171 /* PropertyDeclaration */: { + case 172 /* PropertyDeclaration */: { const node = parent2; if (!isClassLike(node.parent)) break; @@ -173547,8 +157448,8 @@ ${lanes.join("\n")} if (!links.decoratorSignature) { links.decoratorSignature = anySignature; switch (parent2.kind) { - case 262 /* ClassDeclaration */: - case 230 /* ClassExpression */: { + case 263 /* ClassDeclaration */: + case 231 /* ClassExpression */: { const node = parent2; const targetType = getTypeOfSymbol(getSymbolOfDeclaration(node)); const targetParam = createParameter("target", targetType); @@ -173562,7 +157463,7 @@ ${lanes.join("\n")} ); break; } - case 168 /* Parameter */: { + case 169 /* Parameter */: { const node = parent2; if (!isConstructorDeclaration(node.parent) && !(isMethodDeclaration(node.parent) || isSetAccessorDeclaration(node.parent) && isClassLike(node.parent.parent))) { break; @@ -173588,10 +157489,10 @@ ${lanes.join("\n")} ); break; } - case 173 /* MethodDeclaration */: - case 176 /* GetAccessor */: - case 177 /* SetAccessor */: - case 171 /* PropertyDeclaration */: { + case 174 /* MethodDeclaration */: + case 177 /* GetAccessor */: + case 178 /* SetAccessor */: + case 172 /* PropertyDeclaration */: { const node = parent2; if (!isClassLike(node.parent)) break; @@ -173656,13 +157557,19 @@ ${lanes.join("\n")} function createPromiseReturnType(func, promisedType) { const promiseType = createPromiseType(promisedType); if (promiseType === unknownType) { - error(func, isImportCall(func) ? Diagnostics.A_dynamic_import_call_returns_a_Promise_Make_sure_you_have_a_declaration_for_Promise_or_include_ES2015_in_your_lib_option : Diagnostics.An_async_function_or_method_must_return_a_Promise_Make_sure_you_have_a_declaration_for_Promise_or_include_ES2015_in_your_lib_option); + error2( + func, + isImportCall(func) ? Diagnostics.A_dynamic_import_call_returns_a_Promise_Make_sure_you_have_a_declaration_for_Promise_or_include_ES2015_in_your_lib_option : Diagnostics.An_async_function_or_method_must_return_a_Promise_Make_sure_you_have_a_declaration_for_Promise_or_include_ES2015_in_your_lib_option + ); return errorType; } else if (!getGlobalPromiseConstructorSymbol( /*reportErrors*/ true )) { - error(func, isImportCall(func) ? Diagnostics.A_dynamic_import_call_in_ES5_SlashES3_requires_the_Promise_constructor_Make_sure_you_have_a_declaration_for_the_Promise_constructor_or_include_ES2015_in_your_lib_option : Diagnostics.An_async_function_or_method_in_ES5_SlashES3_requires_the_Promise_constructor_Make_sure_you_have_a_declaration_for_the_Promise_constructor_or_include_ES2015_in_your_lib_option); + error2( + func, + isImportCall(func) ? Diagnostics.A_dynamic_import_call_in_ES5_SlashES3_requires_the_Promise_constructor_Make_sure_you_have_a_declaration_for_the_Promise_constructor_or_include_ES2015_in_your_lib_option : Diagnostics.An_async_function_or_method_in_ES5_SlashES3_requires_the_Promise_constructor_Make_sure_you_have_a_declaration_for_the_Promise_constructor_or_include_ES2015_in_your_lib_option + ); } return promiseType; } @@ -173686,7 +157593,7 @@ ${lanes.join("\n")} let yieldType; let nextType; let fallbackReturnType = voidType; - if (func.body.kind !== 240 /* Block */) { + if (func.body.kind !== 241 /* Block */) { returnType = checkExpressionCached(func.body, checkMode && checkMode & ~8 /* SkipGenericFunctions */); if (isAsync) { returnType = unwrapAwaitedType(checkAwaitedType( @@ -173845,7 +157752,11 @@ ${lanes.join("\n")} function getYieldedTypeOfYieldExpression(node, expressionType, sentType, isAsync) { const errorNode = node.expression || node; const yieldedType = node.asteriskToken ? checkIteratedTypeOrElementType(isAsync ? 19 /* AsyncYieldStar */ : 17 /* YieldStar */, expressionType, sentType, errorNode) : expressionType; - return !isAsync ? yieldedType : getAwaitedType(yieldedType, errorNode, node.asteriskToken ? Diagnostics.Type_of_iterated_elements_of_a_yield_Asterisk_operand_must_either_be_a_valid_promise_or_must_not_contain_a_callable_then_member : Diagnostics.Type_of_yield_operand_in_an_async_generator_must_either_be_a_valid_promise_or_must_not_contain_a_callable_then_member); + return !isAsync ? yieldedType : getAwaitedType( + yieldedType, + errorNode, + node.asteriskToken ? Diagnostics.Type_of_iterated_elements_of_a_yield_Asterisk_operand_must_either_be_a_valid_promise_or_must_not_contain_a_callable_then_member : Diagnostics.Type_of_yield_operand_in_an_async_generator_must_either_be_a_valid_promise_or_must_not_contain_a_callable_then_member + ); } function getNotEqualFactsFromTypeofSwitch(start, end, witnesses) { let facts = 0 /* None */; @@ -173869,7 +157780,7 @@ ${lanes.join("\n")} return links.isExhaustive; } function computeExhaustiveSwitchStatement(node) { - if (node.expression.kind === 220 /* TypeOfExpression */) { + if (node.expression.kind === 221 /* TypeOfExpression */) { const witnesses = getSwitchClauseTypeOfWitnesses(node); if (!witnesses) { return false; @@ -173879,7 +157790,7 @@ ${lanes.join("\n")} if (operandConstraint.flags & 3 /* AnyOrUnknown */) { return (556800 /* AllTypeofNE */ & notEqualFacts) === 556800 /* AllTypeofNE */; } - return !someType(operandConstraint, (t) => (getTypeFacts(t) & notEqualFacts) === notEqualFacts); + return !someType(operandConstraint, (t) => getTypeFacts(t, notEqualFacts) === notEqualFacts); } const type = checkExpressionCached(node.expression); if (!isLiteralType(type)) { @@ -173900,9 +157811,21 @@ ${lanes.join("\n")} let hasReturnWithNoExpression = functionHasImplicitReturn(func); let hasReturnOfTypeNever = false; forEachReturnStatement(func.body, (returnStatement) => { - const expr = returnStatement.expression; + let expr = returnStatement.expression; if (expr) { - if (expr.kind === 212 /* CallExpression */ && expr.expression.kind === 80 /* Identifier */ && checkExpressionCached(expr.expression).symbol === func.symbol) { + expr = skipParentheses( + expr, + /*excludeJSDocTypeAssertions*/ + true + ); + if (functionFlags & 2 /* Async */ && expr.kind === 223 /* AwaitExpression */) { + expr = skipParentheses( + expr.expression, + /*excludeJSDocTypeAssertions*/ + true + ); + } + if (expr.kind === 213 /* CallExpression */ && expr.expression.kind === 80 /* Identifier */ && checkExpressionCached(expr.expression).symbol === func.symbol) { hasReturnOfTypeNever = true; return; } @@ -173934,11 +157857,11 @@ ${lanes.join("\n")} } function mayReturnNever(func) { switch (func.kind) { - case 217 /* FunctionExpression */: - case 218 /* ArrowFunction */: + case 218 /* FunctionExpression */: + case 219 /* ArrowFunction */: return true; - case 173 /* MethodDeclaration */: - return func.parent.kind === 209 /* ObjectLiteralExpression */; + case 174 /* MethodDeclaration */: + return func.parent.kind === 210 /* ObjectLiteralExpression */; default: return false; } @@ -173952,17 +157875,17 @@ ${lanes.join("\n")} if (type && (maybeTypeOfKind(type, 16384 /* Void */) || type.flags & (1 /* Any */ | 32768 /* Undefined */))) { return; } - if (func.kind === 172 /* MethodSignature */ || nodeIsMissing(func.body) || func.body.kind !== 240 /* Block */ || !functionHasImplicitReturn(func)) { + if (func.kind === 173 /* MethodSignature */ || nodeIsMissing(func.body) || func.body.kind !== 241 /* Block */ || !functionHasImplicitReturn(func)) { return; } - const hasExplicitReturn = func.flags & 512 /* HasExplicitReturn */; + const hasExplicitReturn = func.flags & 1024 /* HasExplicitReturn */; const errorNode = getEffectiveReturnTypeNode(func) || func; if (type && type.flags & 131072 /* Never */) { - error(errorNode, Diagnostics.A_function_returning_never_cannot_have_a_reachable_end_point); + error2(errorNode, Diagnostics.A_function_returning_never_cannot_have_a_reachable_end_point); } else if (type && !hasExplicitReturn) { - error(errorNode, Diagnostics.A_function_whose_declared_type_is_neither_undefined_void_nor_any_must_return_a_value); + error2(errorNode, Diagnostics.A_function_whose_declared_type_is_neither_undefined_void_nor_any_must_return_a_value); } else if (type && strictNullChecks && !isTypeAssignableTo(undefinedType, type)) { - error(errorNode, Diagnostics.Function_lacks_ending_return_statement_and_return_type_does_not_include_undefined); + error2(errorNode, Diagnostics.Function_lacks_ending_return_statement_and_return_type_does_not_include_undefined); } else if (compilerOptions.noImplicitReturns) { if (!type) { if (!hasExplicitReturn) { @@ -173973,12 +157896,12 @@ ${lanes.join("\n")} return; } } - error(errorNode, Diagnostics.Not_all_code_paths_return_a_value); + error2(errorNode, Diagnostics.Not_all_code_paths_return_a_value); } } } function checkFunctionExpressionOrObjectLiteralMethod(node, checkMode) { - Debug.assert(node.kind !== 173 /* MethodDeclaration */ || isObjectLiteralMethod(node)); + Debug.assert(node.kind !== 174 /* MethodDeclaration */ || isObjectLiteralMethod(node)); checkNodeDeferred(node); if (isFunctionExpression(node)) { checkCollisionsForDeclarationName(node, node.name); @@ -174014,7 +157937,7 @@ ${lanes.join("\n")} return anyFunctionType; } const hasGrammarError = checkGrammarFunctionLikeDeclaration(node); - if (!hasGrammarError && node.kind === 217 /* FunctionExpression */) { + if (!hasGrammarError && node.kind === 218 /* FunctionExpression */) { checkGrammarForGenerator(node); } contextuallyCheckFunctionExpressionOrObjectLiteralMethod(node, checkMode); @@ -174063,7 +157986,7 @@ ${lanes.join("\n")} } } function checkFunctionExpressionOrObjectLiteralMethodDeferred(node) { - Debug.assert(node.kind !== 173 /* MethodDeclaration */ || isObjectLiteralMethod(node)); + Debug.assert(node.kind !== 174 /* MethodDeclaration */ || isObjectLiteralMethod(node)); const functionFlags = getFunctionFlags(node); const returnType = getReturnTypeFromAnnotation(node); checkAllCodePathsInNonVoidFunctionReturnOrThrow(node, returnType); @@ -174071,7 +157994,7 @@ ${lanes.join("\n")} if (!getEffectiveReturnTypeNode(node)) { getReturnTypeOfSignature(getSignatureFromDeclaration(node)); } - if (node.body.kind === 240 /* Block */) { + if (node.body.kind === 241 /* Block */) { checkSourceElement(node.body); } else { const exprType = checkExpression(node.body); @@ -174133,7 +158056,7 @@ ${lanes.join("\n")} return !setProp; } function isReadonlySymbol(symbol) { - return !!(getCheckFlags(symbol) & 8 /* Readonly */ || symbol.flags & 4 /* Property */ && getDeclarationModifierFlagsFromSymbol(symbol) & 64 /* Readonly */ || symbol.flags & 3 /* Variable */ && getDeclarationNodeFlagsFromSymbol(symbol) & 2 /* Const */ || symbol.flags & 98304 /* Accessor */ && !(symbol.flags & 65536 /* SetAccessor */) || symbol.flags & 8 /* EnumMember */ || some(symbol.declarations, isReadonlyAssignmentDeclaration)); + return !!(getCheckFlags(symbol) & 8 /* Readonly */ || symbol.flags & 4 /* Property */ && getDeclarationModifierFlagsFromSymbol(symbol) & 8 /* Readonly */ || symbol.flags & 3 /* Variable */ && getDeclarationNodeFlagsFromSymbol(symbol) & 6 /* Constant */ || symbol.flags & 98304 /* Accessor */ && !(symbol.flags & 65536 /* SetAccessor */) || symbol.flags & 8 /* EnumMember */ || some(symbol.declarations, isReadonlyAssignmentDeclaration)); } function isAssignmentToReadonlyEntity(expr, symbol, assignmentKind) { var _a, _b; @@ -174143,7 +158066,7 @@ ${lanes.join("\n")} if (isReadonlySymbol(symbol)) { if (symbol.flags & 4 /* Property */ && isAccessExpression(expr) && expr.expression.kind === 110 /* ThisKeyword */) { const ctor = getContainingFunction(expr); - if (!(ctor && (ctor.kind === 175 /* Constructor */ || isJSConstructor(ctor)))) { + if (!(ctor && (ctor.kind === 176 /* Constructor */ || isJSConstructor(ctor)))) { return true; } if (symbol.valueDeclaration) { @@ -174164,7 +158087,7 @@ ${lanes.join("\n")} const symbol2 = getNodeLinks(node).resolvedSymbol; if (symbol2.flags & 2097152 /* Alias */) { const declaration = getDeclarationOfAliasSymbol(symbol2); - return !!declaration && declaration.kind === 273 /* NamespaceImport */; + return !!declaration && declaration.kind === 274 /* NamespaceImport */; } } } @@ -174173,11 +158096,11 @@ ${lanes.join("\n")} function checkReferenceExpression(expr, invalidReferenceMessage, invalidOptionalChainMessage) { const node = skipOuterExpressions(expr, 6 /* Assertions */ | 1 /* Parentheses */); if (node.kind !== 80 /* Identifier */ && !isAccessExpression(node)) { - error(expr, invalidReferenceMessage); + error2(expr, invalidReferenceMessage); return false; } - if (node.flags & 32 /* OptionalChain */) { - error(expr, invalidOptionalChainMessage); + if (node.flags & 64 /* OptionalChain */) { + error2(expr, invalidOptionalChainMessage); return false; } return true; @@ -174186,26 +158109,27 @@ ${lanes.join("\n")} checkExpression(node.expression); const expr = skipParentheses(node.expression); if (!isAccessExpression(expr)) { - error(expr, Diagnostics.The_operand_of_a_delete_operator_must_be_a_property_reference); + error2(expr, Diagnostics.The_operand_of_a_delete_operator_must_be_a_property_reference); return booleanType; } if (isPropertyAccessExpression(expr) && isPrivateIdentifier(expr.name)) { - error(expr, Diagnostics.The_operand_of_a_delete_operator_cannot_be_a_private_identifier); + error2(expr, Diagnostics.The_operand_of_a_delete_operator_cannot_be_a_private_identifier); } const links = getNodeLinks(expr); const symbol = getExportSymbolOfValueSymbolIfExported(links.resolvedSymbol); if (symbol) { if (isReadonlySymbol(symbol)) { - error(expr, Diagnostics.The_operand_of_a_delete_operator_cannot_be_a_read_only_property); + error2(expr, Diagnostics.The_operand_of_a_delete_operator_cannot_be_a_read_only_property); + } else { + checkDeleteExpressionMustBeOptional(expr, symbol); } - checkDeleteExpressionMustBeOptional(expr, symbol); } return booleanType; } function checkDeleteExpressionMustBeOptional(expr, symbol) { const type = getTypeOfSymbol(symbol); - if (strictNullChecks && !(type.flags & (3 /* AnyOrUnknown */ | 131072 /* Never */)) && !(exactOptionalPropertyTypes ? symbol.flags & 16777216 /* Optional */ : getTypeFacts(type) & 16777216 /* IsUndefined */)) { - error(expr, Diagnostics.The_operand_of_a_delete_operator_must_be_optional); + if (strictNullChecks && !(type.flags & (3 /* AnyOrUnknown */ | 131072 /* Never */)) && !(exactOptionalPropertyTypes ? symbol.flags & 16777216 /* Optional */ : hasTypeFacts(type, 16777216 /* IsUndefined */))) { + error2(expr, Diagnostics.The_operand_of_a_delete_operator_must_be_optional); } } function checkTypeOfExpression(node) { @@ -174213,27 +158137,27 @@ ${lanes.join("\n")} return typeofType; } function checkVoidExpression(node) { - checkExpression(node.expression); + checkNodeDeferred(node); return undefinedWideningType; } - function checkAwaitExpressionGrammar(node) { + function checkAwaitGrammar(node) { + let hasError = false; const container = getContainingFunctionOrClassStaticBlock(node); if (container && isClassStaticBlockDeclaration(container)) { - error(node, Diagnostics.Await_expression_cannot_be_used_inside_a_class_static_block); - } else if (!(node.flags & 32768 /* AwaitContext */)) { + const message = isAwaitExpression(node) ? Diagnostics.await_expression_cannot_be_used_inside_a_class_static_block : Diagnostics.await_using_statements_cannot_be_used_inside_a_class_static_block; + error2(node, message); + hasError = true; + } else if (!(node.flags & 65536 /* AwaitContext */)) { if (isInTopLevelContext(node)) { const sourceFile = getSourceFileOfNode(node); if (!hasParseDiagnostics(sourceFile)) { let span; if (!isEffectiveExternalModule(sourceFile, compilerOptions)) { span ?? (span = getSpanOfTokenAtPosition(sourceFile, node.pos)); - const diagnostic = createFileDiagnostic( - sourceFile, - span.start, - span.length, - Diagnostics.await_expressions_are_only_allowed_at_the_top_level_of_a_file_when_that_file_is_a_module_but_this_file_has_no_imports_or_exports_Consider_adding_an_empty_export_to_make_this_file_a_module - ); + const message = isAwaitExpression(node) ? Diagnostics.await_expressions_are_only_allowed_at_the_top_level_of_a_file_when_that_file_is_a_module_but_this_file_has_no_imports_or_exports_Consider_adding_an_empty_export_to_make_this_file_a_module : Diagnostics.await_using_statements_are_only_allowed_at_the_top_level_of_a_file_when_that_file_is_a_module_but_this_file_has_no_imports_or_exports_Consider_adding_an_empty_export_to_make_this_file_a_module; + const diagnostic = createFileDiagnostic(sourceFile, span.start, span.length, message); diagnostics.add(diagnostic); + hasError = true; } switch (moduleKind) { case 100 /* Node16 */: @@ -174243,6 +158167,7 @@ ${lanes.join("\n")} diagnostics.add( createFileDiagnostic(sourceFile, span.start, span.length, Diagnostics.The_current_file_is_a_CommonJS_module_and_cannot_use_await_at_the_top_level) ); + hasError = true; break; } case 7 /* ES2022 */: @@ -174253,14 +158178,9 @@ ${lanes.join("\n")} } default: span ?? (span = getSpanOfTokenAtPosition(sourceFile, node.pos)); - diagnostics.add( - createFileDiagnostic( - sourceFile, - span.start, - span.length, - Diagnostics.Top_level_await_expressions_are_only_allowed_when_the_module_option_is_set_to_es2022_esnext_system_node16_or_nodenext_and_the_target_option_is_set_to_es2017_or_higher - ) - ); + const message = isAwaitExpression(node) ? Diagnostics.Top_level_await_expressions_are_only_allowed_when_the_module_option_is_set_to_es2022_esnext_system_node16_or_nodenext_and_the_target_option_is_set_to_es2017_or_higher : Diagnostics.Top_level_await_using_statements_are_only_allowed_when_the_module_option_is_set_to_es2022_esnext_system_node16_or_nodenext_and_the_target_option_is_set_to_es2017_or_higher; + diagnostics.add(createFileDiagnostic(sourceFile, span.start, span.length, message)); + hasError = true; break; } } @@ -174268,21 +158188,25 @@ ${lanes.join("\n")} const sourceFile = getSourceFileOfNode(node); if (!hasParseDiagnostics(sourceFile)) { const span = getSpanOfTokenAtPosition(sourceFile, node.pos); - const diagnostic = createFileDiagnostic(sourceFile, span.start, span.length, Diagnostics.await_expressions_are_only_allowed_within_async_functions_and_at_the_top_levels_of_modules); - if (container && container.kind !== 175 /* Constructor */ && (getFunctionFlags(container) & 2 /* Async */) === 0) { + const message = isAwaitExpression(node) ? Diagnostics.await_expressions_are_only_allowed_within_async_functions_and_at_the_top_levels_of_modules : Diagnostics.await_using_statements_are_only_allowed_within_async_functions_and_at_the_top_levels_of_modules; + const diagnostic = createFileDiagnostic(sourceFile, span.start, span.length, message); + if (container && container.kind !== 176 /* Constructor */ && (getFunctionFlags(container) & 2 /* Async */) === 0) { const relatedInfo = createDiagnosticForNode(container, Diagnostics.Did_you_mean_to_mark_this_function_as_async); addRelatedInfo(diagnostic, relatedInfo); } diagnostics.add(diagnostic); + hasError = true; } } } - if (isInParameterInitializerBeforeContainingFunction(node)) { - error(node, Diagnostics.await_expressions_cannot_be_used_in_a_parameter_initializer); + if (isAwaitExpression(node) && isInParameterInitializerBeforeContainingFunction(node)) { + error2(node, Diagnostics.await_expressions_cannot_be_used_in_a_parameter_initializer); + hasError = true; } + return hasError; } function checkAwaitExpression(node) { - addLazyDiagnostic(() => checkAwaitExpressionGrammar(node)); + addLazyDiagnostic(() => checkAwaitGrammar(node)); const operandType = checkExpression(node.expression); const awaitedType = checkAwaitedType( operandType, @@ -174328,26 +158252,22 @@ ${lanes.join("\n")} case 55 /* TildeToken */: checkNonNullType(operandType, node.operand); if (maybeTypeOfKindConsideringBaseConstraint(operandType, 12288 /* ESSymbolLike */)) { - error(node.operand, Diagnostics.The_0_operator_cannot_be_applied_to_type_symbol, tokenToString(node.operator)); + error2(node.operand, Diagnostics.The_0_operator_cannot_be_applied_to_type_symbol, tokenToString(node.operator)); } if (node.operator === 40 /* PlusToken */) { if (maybeTypeOfKindConsideringBaseConstraint(operandType, 2112 /* BigIntLike */)) { - error(node.operand, Diagnostics.Operator_0_cannot_be_applied_to_type_1, tokenToString(node.operator), typeToString(getBaseTypeOfLiteralType(operandType))); + error2(node.operand, Diagnostics.Operator_0_cannot_be_applied_to_type_1, tokenToString(node.operator), typeToString(getBaseTypeOfLiteralType(operandType))); } return numberType; } return getUnaryResultType(operandType); case 54 /* ExclamationToken */: checkTruthinessOfType(operandType, node.operand); - const facts = getTypeFacts(operandType) & (4194304 /* Truthy */ | 8388608 /* Falsy */); + const facts = getTypeFacts(operandType, 4194304 /* Truthy */ | 8388608 /* Falsy */); return facts === 4194304 /* Truthy */ ? falseType : facts === 8388608 /* Falsy */ ? trueType : booleanType; case 46 /* PlusPlusToken */: case 47 /* MinusMinusToken */: - const ok = checkArithmeticOperandType( - node.operand, - checkNonNullType(operandType, node.operand), - Diagnostics.An_arithmetic_operand_must_be_of_type_any_number_bigint_or_an_enum_type - ); + const ok = checkArithmeticOperandType(node.operand, checkNonNullType(operandType, node.operand), Diagnostics.An_arithmetic_operand_must_be_of_type_any_number_bigint_or_an_enum_type); if (ok) { checkReferenceExpression( node.operand, @@ -174423,16 +158343,35 @@ ${lanes.join("\n")} function isConstEnumSymbol(symbol) { return (symbol.flags & 128 /* ConstEnum */) !== 0; } - function checkInstanceOfExpression(left, right, leftType, rightType) { + function getSymbolHasInstanceMethodOfObjectType(type) { + const hasInstancePropertyName = getPropertyNameForKnownSymbolName("hasInstance"); + const hasInstanceProperty = getPropertyOfObjectType(type, hasInstancePropertyName); + if (hasInstanceProperty) { + const hasInstancePropertyType = getTypeOfSymbol(hasInstanceProperty); + if (hasInstancePropertyType && getSignaturesOfType(hasInstancePropertyType, 0 /* Call */).length !== 0) { + return hasInstancePropertyType; + } + } + } + function checkInstanceOfExpression(left, right, leftType, rightType, checkMode) { if (leftType === silentNeverType || rightType === silentNeverType) { return silentNeverType; } if (!isTypeAny(leftType) && allTypesAssignableToKind(leftType, 402784252 /* Primitive */)) { - error(left, Diagnostics.The_left_hand_side_of_an_instanceof_expression_must_be_of_type_any_an_object_type_or_a_type_parameter); + error2(left, Diagnostics.The_left_hand_side_of_an_instanceof_expression_must_be_of_type_any_an_object_type_or_a_type_parameter); } - if (!(isTypeAny(rightType) || typeHasCallOrConstructSignatures(rightType) || isTypeSubtypeOf(rightType, globalFunctionType))) { - error(right, Diagnostics.The_right_hand_side_of_an_instanceof_expression_must_be_of_type_any_or_of_a_type_assignable_to_the_Function_interface_type); + Debug.assert(isInstanceOfExpression(left.parent)); + const signature = getResolvedSignature( + left.parent, + /*candidatesOutArray*/ + void 0, + checkMode + ); + if (signature === resolvingSignature) { + return silentNeverType; } + const returnType = getReturnTypeOfSignature(signature); + checkTypeAssignableTo(returnType, booleanType, right, Diagnostics.An_object_s_Symbol_hasInstance_method_must_return_a_boolean_value_for_it_to_be_used_on_the_right_hand_side_of_an_instanceof_expression); return booleanType; } function hasEmptyObjectIntersection(type) { @@ -174460,7 +158399,7 @@ ${lanes.join("\n")} } if (checkTypeAssignableTo(checkNonNullType(rightType, right), nonPrimitiveType, right)) { if (hasEmptyObjectIntersection(rightType)) { - error(right, Diagnostics.Type_0_may_represent_a_primitive_value_which_is_not_permitted_as_the_right_operand_of_the_in_operator, typeToString(rightType)); + error2(right, Diagnostics.Type_0_may_represent_a_primitive_value_which_is_not_permitted_as_the_right_operand_of_the_in_operator, typeToString(rightType)); } } return booleanType; @@ -174478,7 +158417,7 @@ ${lanes.join("\n")} function checkObjectLiteralDestructuringPropertyAssignment(node, objectLiteralType, propertyIndex, allProperties, rightIsThis = false) { const properties = node.properties; const property = properties[propertyIndex]; - if (property.kind === 302 /* PropertyAssignment */ || property.kind === 303 /* ShorthandPropertyAssignment */) { + if (property.kind === 303 /* PropertyAssignment */ || property.kind === 304 /* ShorthandPropertyAssignment */) { const name = property.name; const exprType = getLiteralTypeFromPropertyName(name); if (isTypeUsableAsPropertyName(exprType)) { @@ -174499,10 +158438,10 @@ ${lanes.join("\n")} } const elementType = getIndexedAccessType(objectLiteralType, exprType, 32 /* ExpressionPosition */, name); const type = getFlowTypeOfDestructuring(property, elementType); - return checkDestructuringAssignment(property.kind === 303 /* ShorthandPropertyAssignment */ ? property : property.initializer, type); - } else if (property.kind === 304 /* SpreadAssignment */) { + return checkDestructuringAssignment(property.kind === 304 /* ShorthandPropertyAssignment */ ? property : property.initializer, type); + } else if (property.kind === 305 /* SpreadAssignment */) { if (propertyIndex < properties.length - 1) { - error(property, Diagnostics.A_rest_element_must_be_last_in_a_destructuring_pattern); + error2(property, Diagnostics.A_rest_element_must_be_last_in_a_destructuring_pattern); } else { if (languageVersion < 99 /* ESNext */) { checkExternalEmitHelpers(property, 4 /* Rest */); @@ -174520,7 +158459,7 @@ ${lanes.join("\n")} return checkDestructuringAssignment(property.expression, type); } } else { - error(property, Diagnostics.Property_assignment_expected); + error2(property, Diagnostics.Property_assignment_expected); } } function checkArrayLiteralAssignment(node, sourceType, checkMode) { @@ -174532,7 +158471,7 @@ ${lanes.join("\n")} let inBoundsType = compilerOptions.noUncheckedIndexedAccess ? void 0 : possiblyOutOfBoundsType; for (let i = 0; i < elements.length; i++) { let type = possiblyOutOfBoundsType; - if (node.elements[i].kind === 229 /* SpreadElement */) { + if (node.elements[i].kind === 230 /* SpreadElement */) { type = inBoundsType = inBoundsType ?? (checkIteratedTypeOrElementType(65 /* Destructuring */, sourceType, undefinedType, node) || errorType); } checkArrayLiteralDestructuringElementAssignment(node, sourceType, i, type, checkMode); @@ -174542,8 +158481,8 @@ ${lanes.join("\n")} function checkArrayLiteralDestructuringElementAssignment(node, sourceType, elementIndex, elementType, checkMode) { const elements = node.elements; const element = elements[elementIndex]; - if (element.kind !== 231 /* OmittedExpression */) { - if (element.kind !== 229 /* SpreadElement */) { + if (element.kind !== 232 /* OmittedExpression */) { + if (element.kind !== 230 /* SpreadElement */) { const indexType = getNumberLiteralType(elementIndex); if (isArrayLikeType(sourceType)) { const accessFlags = 32 /* ExpressionPosition */ | (hasDefaultValue(element) ? 16 /* NoTupleBoundsCheck */ : 0); @@ -174555,11 +158494,11 @@ ${lanes.join("\n")} return checkDestructuringAssignment(element, elementType, checkMode); } if (elementIndex < elements.length - 1) { - error(element, Diagnostics.A_rest_element_must_be_last_in_a_destructuring_pattern); + error2(element, Diagnostics.A_rest_element_must_be_last_in_a_destructuring_pattern); } else { const restExpression = element.expression; - if (restExpression.kind === 225 /* BinaryExpression */ && restExpression.operatorToken.kind === 64 /* EqualsToken */) { - error(restExpression.operatorToken, Diagnostics.A_rest_element_cannot_have_an_initializer); + if (restExpression.kind === 226 /* BinaryExpression */ && restExpression.operatorToken.kind === 64 /* EqualsToken */) { + error2(restExpression.operatorToken, Diagnostics.A_rest_element_cannot_have_an_initializer); } else { checkGrammarForDisallowedTrailingComma(node.elements, Diagnostics.A_rest_parameter_or_binding_pattern_may_not_have_a_trailing_comma); const type = everyType(sourceType, isTupleType) ? mapType(sourceType, (t) => sliceTupleType(t, elementIndex)) : createArrayType(elementType); @@ -174571,10 +158510,10 @@ ${lanes.join("\n")} } function checkDestructuringAssignment(exprOrAssignment, sourceType, checkMode, rightIsThis) { let target; - if (exprOrAssignment.kind === 303 /* ShorthandPropertyAssignment */) { + if (exprOrAssignment.kind === 304 /* ShorthandPropertyAssignment */) { const prop = exprOrAssignment; if (prop.objectAssignmentInitializer) { - if (strictNullChecks && !(getTypeFacts(checkExpression(prop.objectAssignmentInitializer)) & 16777216 /* IsUndefined */)) { + if (strictNullChecks && !hasTypeFacts(checkExpression(prop.objectAssignmentInitializer), 16777216 /* IsUndefined */)) { sourceType = getTypeWithFacts(sourceType, 524288 /* NEUndefined */); } checkBinaryLikeExpression(prop.name, prop.equalsToken, prop.objectAssignmentInitializer, checkMode); @@ -174583,26 +158522,26 @@ ${lanes.join("\n")} } else { target = exprOrAssignment; } - if (target.kind === 225 /* BinaryExpression */ && target.operatorToken.kind === 64 /* EqualsToken */) { + if (target.kind === 226 /* BinaryExpression */ && target.operatorToken.kind === 64 /* EqualsToken */) { checkBinaryExpression(target, checkMode); target = target.left; if (strictNullChecks) { sourceType = getTypeWithFacts(sourceType, 524288 /* NEUndefined */); } } - if (target.kind === 209 /* ObjectLiteralExpression */) { + if (target.kind === 210 /* ObjectLiteralExpression */) { return checkObjectLiteralAssignment(target, sourceType, rightIsThis); } - if (target.kind === 208 /* ArrayLiteralExpression */) { + if (target.kind === 209 /* ArrayLiteralExpression */) { return checkArrayLiteralAssignment(target, sourceType, checkMode); } return checkReferenceAssignment(target, sourceType, checkMode); } function checkReferenceAssignment(target, sourceType, checkMode) { const targetType = checkExpression(target, checkMode); - const error2 = target.parent.kind === 304 /* SpreadAssignment */ ? Diagnostics.The_target_of_an_object_rest_assignment_must_be_a_variable_or_a_property_access : Diagnostics.The_left_hand_side_of_an_assignment_expression_must_be_a_variable_or_a_property_access; - const optionalError = target.parent.kind === 304 /* SpreadAssignment */ ? Diagnostics.The_target_of_an_object_rest_assignment_may_not_be_an_optional_property_access : Diagnostics.The_left_hand_side_of_an_assignment_expression_may_not_be_an_optional_property_access; - if (checkReferenceExpression(target, error2, optionalError)) { + const error3 = target.parent.kind === 305 /* SpreadAssignment */ ? Diagnostics.The_target_of_an_object_rest_assignment_must_be_a_variable_or_a_property_access : Diagnostics.The_left_hand_side_of_an_assignment_expression_must_be_a_variable_or_a_property_access; + const optionalError = target.parent.kind === 305 /* SpreadAssignment */ ? Diagnostics.The_target_of_an_object_rest_assignment_may_not_be_an_optional_property_access : Diagnostics.The_left_hand_side_of_an_assignment_expression_may_not_be_an_optional_property_access; + if (checkReferenceExpression(target, error3, optionalError)) { checkTypeAssignableToAndOptionallyElaborate(sourceType, targetType, target, target); } if (isPrivateIdentifierPropertyAccessExpression(target)) { @@ -174616,8 +158555,8 @@ ${lanes.join("\n")} case 80 /* Identifier */: case 11 /* StringLiteral */: case 14 /* RegularExpressionLiteral */: - case 214 /* TaggedTemplateExpression */: - case 227 /* TemplateExpression */: + case 215 /* TaggedTemplateExpression */: + case 228 /* TemplateExpression */: case 15 /* NoSubstitutionTemplateLiteral */: case 9 /* NumericLiteral */: case 10 /* BigIntLiteral */: @@ -174625,25 +158564,25 @@ ${lanes.join("\n")} case 97 /* FalseKeyword */: case 106 /* NullKeyword */: case 157 /* UndefinedKeyword */: - case 217 /* FunctionExpression */: - case 230 /* ClassExpression */: - case 218 /* ArrowFunction */: - case 208 /* ArrayLiteralExpression */: - case 209 /* ObjectLiteralExpression */: - case 220 /* TypeOfExpression */: - case 234 /* NonNullExpression */: - case 284 /* JsxSelfClosingElement */: - case 283 /* JsxElement */: + case 218 /* FunctionExpression */: + case 231 /* ClassExpression */: + case 219 /* ArrowFunction */: + case 209 /* ArrayLiteralExpression */: + case 210 /* ObjectLiteralExpression */: + case 221 /* TypeOfExpression */: + case 235 /* NonNullExpression */: + case 285 /* JsxSelfClosingElement */: + case 284 /* JsxElement */: return true; - case 226 /* ConditionalExpression */: + case 227 /* ConditionalExpression */: return isSideEffectFree(node.whenTrue) && isSideEffectFree(node.whenFalse); - case 225 /* BinaryExpression */: + case 226 /* BinaryExpression */: if (isAssignmentOperator(node.operatorToken.kind)) { return false; } return isSideEffectFree(node.left) && isSideEffectFree(node.right); - case 223 /* PrefixUnaryExpression */: - case 224 /* PostfixUnaryExpression */: + case 224 /* PrefixUnaryExpression */: + case 225 /* PostfixUnaryExpression */: switch (node.operator) { case 54 /* ExclamationToken */: case 40 /* PlusToken */: @@ -174652,9 +158591,9 @@ ${lanes.join("\n")} return true; } return false; - case 221 /* VoidExpression */: - case 215 /* TypeAssertionExpression */: - case 233 /* AsExpression */: + case 222 /* VoidExpression */: + case 216 /* TypeAssertionExpression */: + case 234 /* AsExpression */: default: return false; } @@ -174698,7 +158637,7 @@ ${lanes.join("\n")} } checkGrammarNullishCoalesceWithLogicalExpression(node); const operator = node.operatorToken.kind; - if (operator === 64 /* EqualsToken */ && (node.left.kind === 209 /* ObjectLiteralExpression */ || node.left.kind === 208 /* ArrayLiteralExpression */)) { + if (operator === 64 /* EqualsToken */ && (node.left.kind === 210 /* ObjectLiteralExpression */ || node.left.kind === 209 /* ArrayLiteralExpression */)) { state.skip = true; setLastResult(state, checkDestructuringAssignment(node.left, checkExpression(node.right, checkMode), checkMode, node.right.kind === 110 /* ThisKeyword */)); return state; @@ -174723,7 +158662,7 @@ ${lanes.join("\n")} const operator = operatorToken.kind; if (isLogicalOrCoalescingBinaryOperator(operator)) { let parent2 = node.parent; - while (parent2.kind === 216 /* ParenthesizedExpression */ || isLogicalOrCoalescingBinaryExpression(parent2)) { + while (parent2.kind === 217 /* ParenthesizedExpression */ || isLogicalOrCoalescingBinaryExpression(parent2)) { parent2 = parent2.parent; } if (operator === 56 /* AmpersandAmpersandToken */ || isIfStatement(parent2)) { @@ -174747,7 +158686,7 @@ ${lanes.join("\n")} Debug.assertIsDefined(leftType); const rightType = getLastResult(state); Debug.assertIsDefined(rightType); - result = checkBinaryLikeExpressionWorker(node.left, node.operatorToken, node.right, leftType, rightType, node); + result = checkBinaryLikeExpressionWorker(node.left, node.operatorToken, node.right, leftType, rightType, state.checkMode, node); } state.skip = false; setLeftType( @@ -174799,7 +158738,7 @@ ${lanes.join("\n")} } function checkBinaryLikeExpression(left, operatorToken, right, checkMode, errorNode) { const operator = operatorToken.kind; - if (operator === 64 /* EqualsToken */ && (left.kind === 209 /* ObjectLiteralExpression */ || left.kind === 208 /* ArrayLiteralExpression */)) { + if (operator === 64 /* EqualsToken */ && (left.kind === 210 /* ObjectLiteralExpression */ || left.kind === 209 /* ArrayLiteralExpression */)) { return checkDestructuringAssignment(left, checkExpression(right, checkMode), checkMode, right.kind === 110 /* ThisKeyword */); } let leftType; @@ -174809,9 +158748,9 @@ ${lanes.join("\n")} leftType = checkExpression(left, checkMode); } const rightType = checkExpression(right, checkMode); - return checkBinaryLikeExpressionWorker(left, operatorToken, right, leftType, rightType, errorNode); + return checkBinaryLikeExpressionWorker(left, operatorToken, right, leftType, rightType, checkMode, errorNode); } - function checkBinaryLikeExpressionWorker(left, operatorToken, right, leftType, rightType, errorNode) { + function checkBinaryLikeExpressionWorker(left, operatorToken, right, leftType, rightType, checkMode, errorNode) { const operator = operatorToken.kind; switch (operator) { case 42 /* AsteriskToken */: @@ -174843,7 +158782,7 @@ ${lanes.join("\n")} rightType = checkNonNullType(rightType, right); let suggestedOperator; if (leftType.flags & 528 /* BooleanLike */ && rightType.flags & 528 /* BooleanLike */ && (suggestedOperator = getSuggestedBooleanOperator(operatorToken.kind)) !== void 0) { - error(errorNode || operatorToken, Diagnostics.The_0_operator_is_not_allowed_for_boolean_types_Consider_using_1_instead, tokenToString(operatorToken.kind), tokenToString(suggestedOperator)); + error2(errorNode || operatorToken, Diagnostics.The_0_operator_is_not_allowed_for_boolean_types_Consider_using_1_instead, tokenToString(operatorToken.kind), tokenToString(suggestedOperator)); return numberType; } else { const leftOk = checkArithmeticOperandType( @@ -174873,7 +158812,7 @@ ${lanes.join("\n")} case 43 /* AsteriskAsteriskToken */: case 68 /* AsteriskAsteriskEqualsToken */: if (languageVersion < 3 /* ES2016 */) { - error(errorNode, Diagnostics.Exponentiation_cannot_be_performed_on_bigint_values_unless_the_target_option_is_set_to_es2016_or_later); + error2(errorNode, Diagnostics.Exponentiation_cannot_be_performed_on_bigint_values_unless_the_target_option_is_set_to_es2016_or_later); } } resultType2 = bigintType; @@ -174940,7 +158879,9 @@ ${lanes.join("\n")} } if (!resultType) { const closeEnoughKind = 296 /* NumberLike */ | 2112 /* BigIntLike */ | 402653316 /* StringLike */ | 3 /* AnyOrUnknown */; - reportOperatorError((left2, right2) => isTypeAssignableToKind(left2, closeEnoughKind) && isTypeAssignableToKind(right2, closeEnoughKind)); + reportOperatorError( + (left2, right2) => isTypeAssignableToKind(left2, closeEnoughKind) && isTypeAssignableToKind(right2, closeEnoughKind) + ); return anyType; } if (operator === 65 /* PlusEqualsToken */) { @@ -174968,20 +158909,23 @@ ${lanes.join("\n")} case 36 /* ExclamationEqualsToken */: case 37 /* EqualsEqualsEqualsToken */: case 38 /* ExclamationEqualsEqualsToken */: - if (isLiteralExpressionOfObject(left) || isLiteralExpressionOfObject(right)) { - const eqType = operator === 35 /* EqualsEqualsToken */ || operator === 37 /* EqualsEqualsEqualsToken */; - error(errorNode, Diagnostics.This_condition_will_always_return_0_since_JavaScript_compares_objects_by_reference_not_value, eqType ? "false" : "true"); + if (!(checkMode && checkMode & 64 /* TypeOnly */)) { + if ((isLiteralExpressionOfObject(left) || isLiteralExpressionOfObject(right)) && // only report for === and !== in JS, not == or != + (!isInJSFile(left) || (operator === 37 /* EqualsEqualsEqualsToken */ || operator === 38 /* ExclamationEqualsEqualsToken */))) { + const eqType = operator === 35 /* EqualsEqualsToken */ || operator === 37 /* EqualsEqualsEqualsToken */; + error2(errorNode, Diagnostics.This_condition_will_always_return_0_since_JavaScript_compares_objects_by_reference_not_value, eqType ? "false" : "true"); + } + checkNaNEquality(errorNode, operator, left, right); + reportOperatorErrorUnless((left2, right2) => isTypeEqualityComparableTo(left2, right2) || isTypeEqualityComparableTo(right2, left2)); } - checkNaNEquality(errorNode, operator, left, right); - reportOperatorErrorUnless((left2, right2) => isTypeEqualityComparableTo(left2, right2) || isTypeEqualityComparableTo(right2, left2)); return booleanType; case 104 /* InstanceOfKeyword */: - return checkInstanceOfExpression(left, right, leftType, rightType); + return checkInstanceOfExpression(left, right, leftType, rightType, checkMode); case 103 /* InKeyword */: return checkInExpression(left, right, leftType, rightType); case 56 /* AmpersandAmpersandToken */: case 77 /* AmpersandAmpersandEqualsToken */: { - const resultType2 = getTypeFacts(leftType) & 4194304 /* Truthy */ ? getUnionType([extractDefinitelyFalsyTypes(strictNullChecks ? leftType : getBaseTypeOfLiteralType(rightType)), rightType]) : leftType; + const resultType2 = hasTypeFacts(leftType, 4194304 /* Truthy */) ? getUnionType([extractDefinitelyFalsyTypes(strictNullChecks ? leftType : getBaseTypeOfLiteralType(rightType)), rightType]) : leftType; if (operator === 77 /* AmpersandAmpersandEqualsToken */) { checkAssignmentOperator(rightType); } @@ -174989,7 +158933,7 @@ ${lanes.join("\n")} } case 57 /* BarBarToken */: case 76 /* BarBarEqualsToken */: { - const resultType2 = getTypeFacts(leftType) & 8388608 /* Falsy */ ? getUnionType([getNonNullableType(removeDefinitelyFalsyTypes(leftType)), rightType], 2 /* Subtype */) : leftType; + const resultType2 = hasTypeFacts(leftType, 8388608 /* Falsy */) ? getUnionType([getNonNullableType(removeDefinitelyFalsyTypes(leftType)), rightType], 2 /* Subtype */) : leftType; if (operator === 76 /* BarBarEqualsToken */) { checkAssignmentOperator(rightType); } @@ -174997,7 +158941,7 @@ ${lanes.join("\n")} } case 61 /* QuestionQuestionToken */: case 78 /* QuestionQuestionEqualsToken */: { - const resultType2 = getTypeFacts(leftType) & 262144 /* EQUndefinedOrNull */ ? getUnionType([getNonNullableType(leftType), rightType], 2 /* Subtype */) : leftType; + const resultType2 = hasTypeFacts(leftType, 262144 /* EQUndefinedOrNull */) ? getUnionType([getNonNullableType(leftType), rightType], 2 /* Subtype */) : leftType; if (operator === 78 /* QuestionQuestionEqualsToken */) { checkAssignmentOperator(rightType); } @@ -175026,7 +158970,7 @@ ${lanes.join("\n")} return textSpanContainsPosition(diag2, start); }); if (!isInDiag2657) - error(left, Diagnostics.Left_side_of_comma_operator_is_unused_and_has_no_side_effects); + error2(left, Diagnostics.Left_side_of_comma_operator_is_unused_and_has_no_side_effects); } return rightType; default: @@ -175060,13 +159004,13 @@ ${lanes.join("\n")} } } function isIndirectCall(node) { - return node.parent.kind === 216 /* ParenthesizedExpression */ && isNumericLiteral(node.left) && node.left.text === "0" && (isCallExpression(node.parent.parent) && node.parent.parent.expression === node.parent || node.parent.parent.kind === 214 /* TaggedTemplateExpression */) && // special-case for "eval" because it's the only non-access case where an indirect call actually affects behavior. + return node.parent.kind === 217 /* ParenthesizedExpression */ && isNumericLiteral(node.left) && node.left.text === "0" && (isCallExpression(node.parent.parent) && node.parent.parent.expression === node.parent || node.parent.parent.kind === 215 /* TaggedTemplateExpression */) && // special-case for "eval" because it's the only non-access case where an indirect call actually affects behavior. (isAccessExpression(node.right) || isIdentifier(node.right) && node.right.escapedText === "eval"); } function checkForDisallowedESSymbolOperand(operator2) { const offendingSymbolOperand = maybeTypeOfKindConsideringBaseConstraint(leftType, 12288 /* ESSymbolLike */) ? left : maybeTypeOfKindConsideringBaseConstraint(rightType, 12288 /* ESSymbolLike */) ? right : void 0; if (offendingSymbolOperand) { - error(offendingSymbolOperand, Diagnostics.The_0_operator_cannot_be_applied_to_type_symbol, tokenToString(operator2)); + error2(offendingSymbolOperand, Diagnostics.The_0_operator_cannot_be_applied_to_type_symbol, tokenToString(operator2)); return false; } return true; @@ -175092,7 +159036,7 @@ ${lanes.join("\n")} } function checkAssignmentOperatorWorker() { let assigneeType = leftType; - if (isCompoundAssignment(operatorToken.kind) && left.kind === 210 /* PropertyAccessExpression */) { + if (isCompoundAssignment(operatorToken.kind) && left.kind === 211 /* PropertyAccessExpression */) { assigneeType = checkPropertyAccessExpression( left, /*checkMode*/ @@ -175101,11 +159045,7 @@ ${lanes.join("\n")} true ); } - if (checkReferenceExpression( - left, - Diagnostics.The_left_hand_side_of_an_assignment_expression_must_be_a_variable_or_a_property_access, - Diagnostics.The_left_hand_side_of_an_assignment_expression_may_not_be_an_optional_property_access - )) { + if (checkReferenceExpression(left, Diagnostics.The_left_hand_side_of_an_assignment_expression_must_be_a_variable_or_a_property_access, Diagnostics.The_left_hand_side_of_an_assignment_expression_may_not_be_an_optional_property_access)) { let headMessage; if (exactOptionalPropertyTypes && isPropertyAccessExpression(left) && maybeTypeOfKind(valueType, 32768 /* Undefined */)) { const target = getTypeOfPropertyOfType(getTypeOfExpression(left.expression), left.name.escapedText); @@ -175187,21 +159127,13 @@ ${lanes.join("\n")} const isLeftNaN = isGlobalNaN(skipParentheses(left2)); const isRightNaN = isGlobalNaN(skipParentheses(right2)); if (isLeftNaN || isRightNaN) { - const err = error( - errorNode2, - Diagnostics.This_condition_will_always_return_0, - tokenToString(operator2 === 37 /* EqualsEqualsEqualsToken */ || operator2 === 35 /* EqualsEqualsToken */ ? 97 /* FalseKeyword */ : 112 /* TrueKeyword */) - ); + const err = error2(errorNode2, Diagnostics.This_condition_will_always_return_0, tokenToString(operator2 === 37 /* EqualsEqualsEqualsToken */ || operator2 === 35 /* EqualsEqualsToken */ ? 97 /* FalseKeyword */ : 112 /* TrueKeyword */)); if (isLeftNaN && isRightNaN) return; const operatorString = operator2 === 38 /* ExclamationEqualsEqualsToken */ || operator2 === 36 /* ExclamationEqualsToken */ ? tokenToString(54 /* ExclamationToken */) : ""; const location = isLeftNaN ? right2 : left2; const expression = skipParentheses(location); - addRelatedInfo(err, createDiagnosticForNode( - location, - Diagnostics.Did_you_mean_0, - `${operatorString}Number.isNaN(${isEntityNameExpression(expression) ? entityNameToString(expression) : "..."})` - )); + addRelatedInfo(err, createDiagnosticForNode(location, Diagnostics.Did_you_mean_0, `${operatorString}Number.isNaN(${isEntityNameExpression(expression) ? entityNameToString(expression) : "..."})`)); } } function isGlobalNaN(expr) { @@ -175241,7 +159173,15 @@ ${lanes.join("\n")} checkExternalEmitHelpers(node, 256 /* Values */); } } - const returnType = getReturnTypeFromAnnotation(func); + let returnType = getReturnTypeFromAnnotation(func); + if (returnType && returnType.flags & 1048576 /* Union */) { + returnType = filterType(returnType, (t) => checkGeneratorInstantiationAssignabilityToReturnType( + t, + functionFlags, + /*errorNode*/ + void 0 + )); + } const iterationTypes = returnType && getIterationTypesOfGeneratorFunctionReturnType(returnType, isAsync); const signatureYieldType = iterationTypes && iterationTypes.yieldType || anyType; const signatureNextType = iterationTypes && iterationTypes.nextType || anyType; @@ -175268,23 +159208,23 @@ ${lanes.join("\n")} void 0 ); if (!contextualType || isTypeAny(contextualType)) { - error(node, Diagnostics.yield_expression_implicitly_results_in_an_any_type_because_its_containing_generator_lacks_a_return_type_annotation); + error2(node, Diagnostics.yield_expression_implicitly_results_in_an_any_type_because_its_containing_generator_lacks_a_return_type_annotation); } } }); } return type; function checkYieldExpressionGrammar() { - if (!(node.flags & 8192 /* YieldContext */)) { + if (!(node.flags & 16384 /* YieldContext */)) { grammarErrorOnFirstToken(node, Diagnostics.A_yield_expression_is_only_allowed_in_a_generator_body); } if (isInParameterInitializerBeforeContainingFunction(node)) { - error(node, Diagnostics.yield_expressions_cannot_be_used_in_a_parameter_initializer); + error2(node, Diagnostics.yield_expressions_cannot_be_used_in_a_parameter_initializer); } } } function checkConditionalExpression(node, checkMode) { - const type = checkTruthinessExpression(node.condition); + const type = checkTruthinessExpression(node.condition, checkMode); checkTestingKnownTruthyCallableOrAwaitableType(node.condition, type, node.whenTrue); const type1 = checkExpression(node.whenTrue, checkMode); const type2 = checkExpression(node.whenFalse, checkMode); @@ -175300,16 +159240,20 @@ ${lanes.join("\n")} for (const span of node.templateSpans) { const type = checkExpression(span.expression); if (maybeTypeOfKindConsideringBaseConstraint(type, 12288 /* ESSymbolLike */)) { - error(span.expression, Diagnostics.Implicit_conversion_of_a_symbol_to_a_string_will_fail_at_runtime_Consider_wrapping_this_expression_in_String); + error2(span.expression, Diagnostics.Implicit_conversion_of_a_symbol_to_a_string_will_fail_at_runtime_Consider_wrapping_this_expression_in_String); } texts.push(span.literal.text); types.push(isTypeAssignableTo(type, templateConstraintType) ? type : stringType); } - return isConstContext(node) || isTemplateLiteralContext(node) || someType(getContextualType2( + if (isConstContext(node) || isTemplateLiteralContext(node) || someType(getContextualType2( node, /*contextFlags*/ void 0 - ) || unknownType, isTemplateLiteralContextualType) ? getTemplateLiteralType(texts, types) : stringType; + ) || unknownType, isTemplateLiteralContextualType)) { + return getTemplateLiteralType(texts, types); + } + const evaluated = node.parent.kind !== 215 /* TaggedTemplateExpression */ && evaluateTemplateExpression(node); + return evaluated ? getFreshTypeOfLiteralType(getStringLiteralType(evaluated)) : stringType; } function isTemplateLiteralContextualType(type) { return !!(type.flags & (128 /* StringLiteral */ | 134217728 /* TemplateLiteral */) || type.flags & 58982400 /* InstantiableNonPrimitive */ && maybeTypeOfKind(getBaseConstraintOfType(type) || unknownType, 402653316 /* StringLike */)); @@ -175365,7 +159309,7 @@ ${lanes.join("\n")} /*excludeJSDocTypeAssertions*/ true ); - return node.kind === 215 /* TypeAssertionExpression */ || node.kind === 233 /* AsExpression */ || isJSDocTypeAssertion(node); + return node.kind === 216 /* TypeAssertionExpression */ || node.kind === 234 /* AsExpression */ || isJSDocTypeAssertion(node); } function checkDeclarationInitializer(declaration, checkMode, contextualType) { const initializer = getEffectiveInitializer(declaration); @@ -175382,7 +159326,7 @@ ${lanes.join("\n")} void 0, checkMode || 0 /* Normal */ ) : checkExpressionCached(initializer, checkMode)); - return isParameter(declaration) && declaration.name.kind === 206 /* ArrayBindingPattern */ && isTupleType(type) && !type.target.hasRestElement && getTypeReferenceArity(type) < declaration.name.elements.length ? padTupleType(type, declaration.name) : type; + return isParameter(declaration) && declaration.name.kind === 207 /* ArrayBindingPattern */ && isTupleType(type) && !type.target.hasRestElement && getTypeReferenceArity(type) < declaration.name.elements.length ? padTupleType(type, declaration.name) : type; } function padTupleType(type, pattern) { const patternElements = pattern.elements; @@ -175390,7 +159334,7 @@ ${lanes.join("\n")} const elementFlags = type.target.elementFlags.slice(); for (let i = getTypeReferenceArity(type); i < patternElements.length; i++) { const e = patternElements[i]; - if (i < patternElements.length - 1 || !(e.kind === 207 /* BindingElement */ && e.dotDotDotToken)) { + if (i < patternElements.length - 1 || !(e.kind === 208 /* BindingElement */ && e.dotDotDotToken)) { elementTypes.push(!isOmittedExpression(e) && hasDefaultValue(e) ? getTypeFromBindingElement( e, /*includePatternInType*/ @@ -175407,7 +159351,7 @@ ${lanes.join("\n")} return createTupleType(elementTypes, elementFlags, type.target.readonly); } function widenTypeInferredFromInitializer(declaration, type) { - const widened = getCombinedNodeFlags(declaration) & 2 /* Const */ || isDeclarationReadonly(declaration) ? type : getWidenedLiteralType(type); + const widened = getCombinedNodeFlagsCached(declaration) & 6 /* Constant */ || isDeclarationReadonly(declaration) ? type : getWidenedLiteralType(type); if (isInJSFile(declaration)) { if (isEmptyLiteralType(widened)) { reportImplicitAny(declaration, anyType); @@ -175451,14 +159395,14 @@ ${lanes.join("\n")} )); } function checkPropertyAssignment(node, checkMode) { - if (node.name.kind === 166 /* ComputedPropertyName */) { + if (node.name.kind === 167 /* ComputedPropertyName */) { checkComputedPropertyName(node.name); } return checkExpressionForMutableLocation(node.initializer, checkMode); } function checkObjectLiteralMethod(node, checkMode) { checkGrammarMethod(node); - if (node.name.kind === 166 /* ComputedPropertyName */) { + if (node.name.kind === 167 /* ComputedPropertyName */) { checkComputedPropertyName(node.name); } const uninstantiatedType = checkFunctionExpressionOrObjectLiteralMethod(node, checkMode); @@ -175614,18 +159558,18 @@ ${lanes.join("\n")} if (quickType) { return quickType; } - if (node.flags & 134217728 /* TypeCached */ && flowTypeCache) { + if (node.flags & 268435456 /* TypeCached */ && flowTypeCache) { const cachedType = flowTypeCache[getNodeId(node)]; if (cachedType) { return cachedType; } } const startInvocationCount = flowInvocationCount; - const type = checkExpression(node); + const type = checkExpression(node, 64 /* TypeOnly */); if (flowInvocationCount !== startInvocationCount) { const cache = flowTypeCache || (flowTypeCache = []); cache[getNodeId(node)] = type; - setNodeFlags(node, node.flags | 134217728 /* TypeCached */); + setNodeFlags(node, node.flags | 268435456 /* TypeCached */); } return type; } @@ -175690,15 +159634,15 @@ ${lanes.join("\n")} return type; } function checkConstEnumAccess(node, type) { - const ok = node.parent.kind === 210 /* PropertyAccessExpression */ && node.parent.expression === node || node.parent.kind === 211 /* ElementAccessExpression */ && node.parent.expression === node || ((node.kind === 80 /* Identifier */ || node.kind === 165 /* QualifiedName */) && isInRightSideOfImportOrExportAssignment(node) || node.parent.kind === 185 /* TypeQuery */ && node.parent.exprName === node) || node.parent.kind === 280 /* ExportSpecifier */; + const ok = node.parent.kind === 211 /* PropertyAccessExpression */ && node.parent.expression === node || node.parent.kind === 212 /* ElementAccessExpression */ && node.parent.expression === node || ((node.kind === 80 /* Identifier */ || node.kind === 166 /* QualifiedName */) && isInRightSideOfImportOrExportAssignment(node) || node.parent.kind === 186 /* TypeQuery */ && node.parent.exprName === node) || node.parent.kind === 281 /* ExportSpecifier */; if (!ok) { - error(node, Diagnostics.const_enums_can_only_be_used_in_property_or_index_access_expressions_or_the_right_hand_side_of_an_import_declaration_or_export_assignment_or_type_query); + error2(node, Diagnostics.const_enums_can_only_be_used_in_property_or_index_access_expressions_or_the_right_hand_side_of_an_import_declaration_or_export_assignment_or_type_query); } if (getIsolatedModules(compilerOptions)) { Debug.assert(!!(type.symbol.flags & 128 /* ConstEnum */)); const constEnumDeclaration = type.symbol.valueDeclaration; - if (constEnumDeclaration.flags & 16777216 /* Ambient */) { - error(node, Diagnostics.Cannot_access_ambient_const_enums_when_0_is_enabled, isolatedModulesLikeFlagName); + if (constEnumDeclaration.flags & 33554432 /* Ambient */ && !isValidTypeOnlyAliasUseSite(node)) { + error2(node, Diagnostics.Cannot_access_ambient_const_enums_when_0_is_enabled, isolatedModulesLikeFlagName); } } } @@ -175717,9 +159661,9 @@ ${lanes.join("\n")} const kind = node.kind; if (cancellationToken) { switch (kind) { - case 230 /* ClassExpression */: - case 217 /* FunctionExpression */: - case 218 /* ArrowFunction */: + case 231 /* ClassExpression */: + case 218 /* FunctionExpression */: + case 219 /* ArrowFunction */: cancellationToken.throwIfCancellationRequested(); } } @@ -175736,7 +159680,7 @@ ${lanes.join("\n")} return nullWideningType; case 15 /* NoSubstitutionTemplateLiteral */: case 11 /* StringLiteral */: - return hasSkipDirectInferenceFlag(node) ? anyType : getFreshTypeOfLiteralType(getStringLiteralType(node.text)); + return hasSkipDirectInferenceFlag(node) ? blockedStringType : getFreshTypeOfLiteralType(getStringLiteralType(node.text)); case 9 /* NumericLiteral */: checkGrammarNumericLiteral(node); return getFreshTypeOfLiteralType(getNumberLiteralType(+node.text)); @@ -175750,81 +159694,81 @@ ${lanes.join("\n")} return trueType; case 97 /* FalseKeyword */: return falseType; - case 227 /* TemplateExpression */: + case 228 /* TemplateExpression */: return checkTemplateExpression(node); case 14 /* RegularExpressionLiteral */: return globalRegExpType; - case 208 /* ArrayLiteralExpression */: + case 209 /* ArrayLiteralExpression */: return checkArrayLiteral(node, checkMode, forceTuple); - case 209 /* ObjectLiteralExpression */: + case 210 /* ObjectLiteralExpression */: return checkObjectLiteral(node, checkMode); - case 210 /* PropertyAccessExpression */: + case 211 /* PropertyAccessExpression */: return checkPropertyAccessExpression(node, checkMode); - case 165 /* QualifiedName */: + case 166 /* QualifiedName */: return checkQualifiedName(node, checkMode); - case 211 /* ElementAccessExpression */: + case 212 /* ElementAccessExpression */: return checkIndexedAccess(node, checkMode); - case 212 /* CallExpression */: + case 213 /* CallExpression */: if (node.expression.kind === 102 /* ImportKeyword */) { return checkImportCallExpression(node); } - case 213 /* NewExpression */: + case 214 /* NewExpression */: return checkCallExpression(node, checkMode); - case 214 /* TaggedTemplateExpression */: + case 215 /* TaggedTemplateExpression */: return checkTaggedTemplateExpression(node); - case 216 /* ParenthesizedExpression */: + case 217 /* ParenthesizedExpression */: return checkParenthesizedExpression(node, checkMode); - case 230 /* ClassExpression */: + case 231 /* ClassExpression */: return checkClassExpression(node); - case 217 /* FunctionExpression */: - case 218 /* ArrowFunction */: + case 218 /* FunctionExpression */: + case 219 /* ArrowFunction */: return checkFunctionExpressionOrObjectLiteralMethod(node, checkMode); - case 220 /* TypeOfExpression */: + case 221 /* TypeOfExpression */: return checkTypeOfExpression(node); - case 215 /* TypeAssertionExpression */: - case 233 /* AsExpression */: + case 216 /* TypeAssertionExpression */: + case 234 /* AsExpression */: return checkAssertion(node, checkMode); - case 234 /* NonNullExpression */: + case 235 /* NonNullExpression */: return checkNonNullAssertion(node); - case 232 /* ExpressionWithTypeArguments */: + case 233 /* ExpressionWithTypeArguments */: return checkExpressionWithTypeArguments(node); - case 237 /* SatisfiesExpression */: + case 238 /* SatisfiesExpression */: return checkSatisfiesExpression(node); - case 235 /* MetaProperty */: + case 236 /* MetaProperty */: return checkMetaProperty(node); - case 219 /* DeleteExpression */: + case 220 /* DeleteExpression */: return checkDeleteExpression(node); - case 221 /* VoidExpression */: + case 222 /* VoidExpression */: return checkVoidExpression(node); - case 222 /* AwaitExpression */: + case 223 /* AwaitExpression */: return checkAwaitExpression(node); - case 223 /* PrefixUnaryExpression */: + case 224 /* PrefixUnaryExpression */: return checkPrefixUnaryExpression(node); - case 224 /* PostfixUnaryExpression */: + case 225 /* PostfixUnaryExpression */: return checkPostfixUnaryExpression(node); - case 225 /* BinaryExpression */: + case 226 /* BinaryExpression */: return checkBinaryExpression(node, checkMode); - case 226 /* ConditionalExpression */: + case 227 /* ConditionalExpression */: return checkConditionalExpression(node, checkMode); - case 229 /* SpreadElement */: + case 230 /* SpreadElement */: return checkSpreadExpression(node, checkMode); - case 231 /* OmittedExpression */: + case 232 /* OmittedExpression */: return undefinedWideningType; - case 228 /* YieldExpression */: + case 229 /* YieldExpression */: return checkYieldExpression(node); - case 236 /* SyntheticExpression */: + case 237 /* SyntheticExpression */: return checkSyntheticExpression(node); - case 293 /* JsxExpression */: + case 294 /* JsxExpression */: return checkJsxExpression(node, checkMode); - case 283 /* JsxElement */: + case 284 /* JsxElement */: return checkJsxElement(node, checkMode); - case 284 /* JsxSelfClosingElement */: + case 285 /* JsxSelfClosingElement */: return checkJsxSelfClosingElement(node, checkMode); - case 287 /* JsxFragment */: + case 288 /* JsxFragment */: return checkJsxFragment(node); - case 291 /* JsxAttributes */: + case 292 /* JsxAttributes */: return checkJsxAttributes(node, checkMode); - case 285 /* JsxOpeningElement */: + case 286 /* JsxOpeningElement */: Debug.fail("Shouldn't ever directly check a JsxOpeningElement"); } return errorType; @@ -175839,7 +159783,7 @@ ${lanes.join("\n")} const typeParameter = getDeclaredTypeOfTypeParameter(getSymbolOfDeclaration(node)); getBaseConstraintOfType(typeParameter); if (!hasNonCircularTypeParameterDefault(typeParameter)) { - error(node.default, Diagnostics.Type_parameter_0_has_a_circular_default, typeToString(typeParameter)); + error2(node.default, Diagnostics.Type_parameter_0_has_a_circular_default, typeToString(typeParameter)); } const constraintType = getConstraintOfTypeParameter(typeParameter); const defaultType = getDefaultFromTypeParameter(typeParameter); @@ -175853,15 +159797,15 @@ ${lanes.join("\n")} var _a, _b; if (isInterfaceDeclaration(node.parent) || isClassLike(node.parent) || isTypeAliasDeclaration(node.parent)) { const typeParameter = getDeclaredTypeOfTypeParameter(getSymbolOfDeclaration(node)); - const modifiers = getTypeParameterModifiers(typeParameter) & (32768 /* In */ | 65536 /* Out */); + const modifiers = getTypeParameterModifiers(typeParameter) & (8192 /* In */ | 16384 /* Out */); if (modifiers) { const symbol = getSymbolOfDeclaration(node.parent); if (isTypeAliasDeclaration(node.parent) && !(getObjectFlags(getDeclaredTypeOfSymbol(symbol)) & (16 /* Anonymous */ | 32 /* Mapped */))) { - error(node, Diagnostics.Variance_annotations_are_only_supported_in_type_aliases_for_object_function_constructor_and_mapped_types); - } else if (modifiers === 32768 /* In */ || modifiers === 65536 /* Out */) { + error2(node, Diagnostics.Variance_annotations_are_only_supported_in_type_aliases_for_object_function_constructor_and_mapped_types); + } else if (modifiers === 8192 /* In */ || modifiers === 16384 /* Out */) { (_a = tracing) == null ? void 0 : _a.push(tracing.Phase.CheckTypes, "checkTypeParameterDeferred", { parent: getTypeId(getDeclaredTypeOfSymbol(symbol)), id: getTypeId(typeParameter) }); - const source = createMarkerType(symbol, typeParameter, modifiers === 65536 /* Out */ ? markerSubTypeForCheck : markerSuperTypeForCheck); - const target = createMarkerType(symbol, typeParameter, modifiers === 65536 /* Out */ ? markerSuperTypeForCheck : markerSubTypeForCheck); + const source = createMarkerType(symbol, typeParameter, modifiers === 16384 /* Out */ ? markerSubTypeForCheck : markerSuperTypeForCheck); + const target = createMarkerType(symbol, typeParameter, modifiers === 16384 /* Out */ ? markerSuperTypeForCheck : markerSubTypeForCheck); const saveVarianceTypeParameter = typeParameter; varianceTypeParameter = typeParameter; checkTypeAssignableTo(source, target, node, Diagnostics.Type_0_is_not_assignable_to_type_1_as_implied_by_variance_annotation); @@ -175875,39 +159819,39 @@ ${lanes.join("\n")} checkGrammarModifiers(node); checkVariableLikeDeclaration(node); const func = getContainingFunction(node); - if (hasSyntacticModifier(node, 16476 /* ParameterPropertyModifier */)) { - if (!(func.kind === 175 /* Constructor */ && nodeIsPresent(func.body))) { - error(node, Diagnostics.A_parameter_property_is_only_allowed_in_a_constructor_implementation); + if (hasSyntacticModifier(node, 31 /* ParameterPropertyModifier */)) { + if (!(func.kind === 176 /* Constructor */ && nodeIsPresent(func.body))) { + error2(node, Diagnostics.A_parameter_property_is_only_allowed_in_a_constructor_implementation); } - if (func.kind === 175 /* Constructor */ && isIdentifier(node.name) && node.name.escapedText === "constructor") { - error(node.name, Diagnostics.constructor_cannot_be_used_as_a_parameter_property_name); + if (func.kind === 176 /* Constructor */ && isIdentifier(node.name) && node.name.escapedText === "constructor") { + error2(node.name, Diagnostics.constructor_cannot_be_used_as_a_parameter_property_name); } } if (!node.initializer && isOptionalDeclaration(node) && isBindingPattern(node.name) && func.body) { - error(node, Diagnostics.A_binding_pattern_parameter_cannot_be_optional_in_an_implementation_signature); + error2(node, Diagnostics.A_binding_pattern_parameter_cannot_be_optional_in_an_implementation_signature); } if (node.name && isIdentifier(node.name) && (node.name.escapedText === "this" || node.name.escapedText === "new")) { if (func.parameters.indexOf(node) !== 0) { - error(node, Diagnostics.A_0_parameter_must_be_the_first_parameter, node.name.escapedText); + error2(node, Diagnostics.A_0_parameter_must_be_the_first_parameter, node.name.escapedText); } - if (func.kind === 175 /* Constructor */ || func.kind === 179 /* ConstructSignature */ || func.kind === 184 /* ConstructorType */) { - error(node, Diagnostics.A_constructor_cannot_have_a_this_parameter); + if (func.kind === 176 /* Constructor */ || func.kind === 180 /* ConstructSignature */ || func.kind === 185 /* ConstructorType */) { + error2(node, Diagnostics.A_constructor_cannot_have_a_this_parameter); } - if (func.kind === 218 /* ArrowFunction */) { - error(node, Diagnostics.An_arrow_function_cannot_have_a_this_parameter); + if (func.kind === 219 /* ArrowFunction */) { + error2(node, Diagnostics.An_arrow_function_cannot_have_a_this_parameter); } - if (func.kind === 176 /* GetAccessor */ || func.kind === 177 /* SetAccessor */) { - error(node, Diagnostics.get_and_set_accessors_cannot_declare_this_parameters); + if (func.kind === 177 /* GetAccessor */ || func.kind === 178 /* SetAccessor */) { + error2(node, Diagnostics.get_and_set_accessors_cannot_declare_this_parameters); } } if (node.dotDotDotToken && !isBindingPattern(node.name) && !isTypeAssignableTo(getReducedType(getTypeOfSymbol(node.symbol)), anyReadonlyArrayType)) { - error(node, Diagnostics.A_rest_parameter_must_be_of_an_array_type); + error2(node, Diagnostics.A_rest_parameter_must_be_of_an_array_type); } } function checkTypePredicate(node) { const parent2 = getTypePredicateParent(node); if (!parent2) { - error(node, Diagnostics.A_type_predicate_is_only_allowed_in_return_type_position_for_functions_and_methods); + error2(node, Diagnostics.A_type_predicate_is_only_allowed_in_return_type_position_for_functions_and_methods); return; } const signature = getSignatureFromDeclaration(parent2); @@ -175922,7 +159866,7 @@ ${lanes.join("\n")} } else { if (typePredicate.parameterIndex >= 0) { if (signatureHasRestParameter(signature) && typePredicate.parameterIndex === signature.parameters.length - 1) { - error(parameterName, Diagnostics.A_type_predicate_cannot_reference_a_rest_parameter); + error2(parameterName, Diagnostics.A_type_predicate_cannot_reference_a_rest_parameter); } else { if (typePredicate.type) { const leadingError = () => chainDiagnosticMessages( @@ -175949,20 +159893,20 @@ ${lanes.join("\n")} } } if (!hasReportedError) { - error(node.parameterName, Diagnostics.Cannot_find_parameter_0, typePredicate.parameterName); + error2(node.parameterName, Diagnostics.Cannot_find_parameter_0, typePredicate.parameterName); } } } } function getTypePredicateParent(node) { switch (node.parent.kind) { - case 218 /* ArrowFunction */: - case 178 /* CallSignature */: - case 261 /* FunctionDeclaration */: - case 217 /* FunctionExpression */: - case 183 /* FunctionType */: - case 173 /* MethodDeclaration */: - case 172 /* MethodSignature */: + case 219 /* ArrowFunction */: + case 179 /* CallSignature */: + case 262 /* FunctionDeclaration */: + case 218 /* FunctionExpression */: + case 184 /* FunctionType */: + case 174 /* MethodDeclaration */: + case 173 /* MethodSignature */: const parent2 = node.parent; if (node === parent2.type) { return parent2; @@ -175976,13 +159920,9 @@ ${lanes.join("\n")} } const name = element.name; if (name.kind === 80 /* Identifier */ && name.escapedText === predicateVariableName) { - error( - predicateVariableNode, - Diagnostics.A_type_predicate_cannot_reference_element_0_in_a_binding_pattern, - predicateVariableName - ); + error2(predicateVariableNode, Diagnostics.A_type_predicate_cannot_reference_element_0_in_a_binding_pattern, predicateVariableName); return true; - } else if (name.kind === 206 /* ArrayBindingPattern */ || name.kind === 205 /* ObjectBindingPattern */) { + } else if (name.kind === 207 /* ArrayBindingPattern */ || name.kind === 206 /* ObjectBindingPattern */) { if (checkIfTypePredicateVariableIsDeclaredInBindingPattern( name, predicateVariableNode, @@ -175994,9 +159934,9 @@ ${lanes.join("\n")} } } function checkSignatureDeclaration(node) { - if (node.kind === 180 /* IndexSignature */) { + if (node.kind === 181 /* IndexSignature */) { checkGrammarIndexSignature(node); - } else if (node.kind === 183 /* FunctionType */ || node.kind === 261 /* FunctionDeclaration */ || node.kind === 184 /* ConstructorType */ || node.kind === 178 /* CallSignature */ || node.kind === 175 /* Constructor */ || node.kind === 179 /* ConstructSignature */) { + } else if (node.kind === 184 /* FunctionType */ || node.kind === 262 /* FunctionDeclaration */ || node.kind === 185 /* ConstructorType */ || node.kind === 179 /* CallSignature */ || node.kind === 176 /* Constructor */ || node.kind === 180 /* ConstructSignature */) { checkGrammarFunctionLikeDeclaration(node); } const functionFlags = getFunctionFlags(node); @@ -176020,45 +159960,59 @@ ${lanes.join("\n")} addLazyDiagnostic(checkSignatureDeclarationDiagnostics); function checkSignatureDeclarationDiagnostics() { checkCollisionWithArgumentsInGeneratedCode(node); - const returnTypeNode = getEffectiveReturnTypeNode(node); + let returnTypeNode = getEffectiveReturnTypeNode(node); + let returnTypeErrorLocation = returnTypeNode; + if (isInJSFile(node)) { + const typeTag = getJSDocTypeTag(node); + if (typeTag && typeTag.typeExpression && isTypeReferenceNode(typeTag.typeExpression.type)) { + const signature = getSingleCallSignature(getTypeFromTypeNode(typeTag.typeExpression)); + if (signature && signature.declaration) { + returnTypeNode = getEffectiveReturnTypeNode(signature.declaration); + returnTypeErrorLocation = typeTag.typeExpression.type; + } + } + } if (noImplicitAny && !returnTypeNode) { switch (node.kind) { - case 179 /* ConstructSignature */: - error(node, Diagnostics.Construct_signature_which_lacks_return_type_annotation_implicitly_has_an_any_return_type); + case 180 /* ConstructSignature */: + error2(node, Diagnostics.Construct_signature_which_lacks_return_type_annotation_implicitly_has_an_any_return_type); break; - case 178 /* CallSignature */: - error(node, Diagnostics.Call_signature_which_lacks_return_type_annotation_implicitly_has_an_any_return_type); + case 179 /* CallSignature */: + error2(node, Diagnostics.Call_signature_which_lacks_return_type_annotation_implicitly_has_an_any_return_type); break; } } - if (returnTypeNode) { + if (returnTypeNode && returnTypeErrorLocation) { const functionFlags2 = getFunctionFlags(node); if ((functionFlags2 & (4 /* Invalid */ | 1 /* Generator */)) === 1 /* Generator */) { const returnType = getTypeFromTypeNode(returnTypeNode); if (returnType === voidType) { - error(returnTypeNode, Diagnostics.A_generator_cannot_have_a_void_type_annotation); + error2(returnTypeErrorLocation, Diagnostics.A_generator_cannot_have_a_void_type_annotation); } else { - const generatorYieldType = getIterationTypeOfGeneratorFunctionReturnType(0 /* Yield */, returnType, (functionFlags2 & 2 /* Async */) !== 0) || anyType; - const generatorReturnType = getIterationTypeOfGeneratorFunctionReturnType(1 /* Return */, returnType, (functionFlags2 & 2 /* Async */) !== 0) || generatorYieldType; - const generatorNextType = getIterationTypeOfGeneratorFunctionReturnType(2 /* Next */, returnType, (functionFlags2 & 2 /* Async */) !== 0) || unknownType; - const generatorInstantiation = createGeneratorReturnType(generatorYieldType, generatorReturnType, generatorNextType, !!(functionFlags2 & 2 /* Async */)); - checkTypeAssignableTo(generatorInstantiation, returnType, returnTypeNode); + checkGeneratorInstantiationAssignabilityToReturnType(returnType, functionFlags2, returnTypeErrorLocation); } } else if ((functionFlags2 & 3 /* AsyncGenerator */) === 2 /* Async */) { - checkAsyncFunctionReturnType(node, returnTypeNode); + checkAsyncFunctionReturnType(node, returnTypeNode, returnTypeErrorLocation); } } - if (node.kind !== 180 /* IndexSignature */ && node.kind !== 323 /* JSDocFunctionType */) { + if (node.kind !== 181 /* IndexSignature */ && node.kind !== 324 /* JSDocFunctionType */) { registerForUnusedIdentifiersCheck(node); } } } + function checkGeneratorInstantiationAssignabilityToReturnType(returnType, functionFlags, errorNode) { + const generatorYieldType = getIterationTypeOfGeneratorFunctionReturnType(0 /* Yield */, returnType, (functionFlags & 2 /* Async */) !== 0) || anyType; + const generatorReturnType = getIterationTypeOfGeneratorFunctionReturnType(1 /* Return */, returnType, (functionFlags & 2 /* Async */) !== 0) || generatorYieldType; + const generatorNextType = getIterationTypeOfGeneratorFunctionReturnType(2 /* Next */, returnType, (functionFlags & 2 /* Async */) !== 0) || unknownType; + const generatorInstantiation = createGeneratorReturnType(generatorYieldType, generatorReturnType, generatorNextType, !!(functionFlags & 2 /* Async */)); + return checkTypeAssignableTo(generatorInstantiation, returnType, errorNode); + } function checkClassForDuplicateDeclarations(node) { const instanceNames = /* @__PURE__ */ new Map(); const staticNames = /* @__PURE__ */ new Map(); const privateIdentifiers = /* @__PURE__ */ new Map(); for (const member of node.members) { - if (member.kind === 175 /* Constructor */) { + if (member.kind === 176 /* Constructor */) { for (const param of member.parameters) { if (isParameterPropertyDeclaration(param, member) && !isBindingPattern(param.name)) { addName(instanceNames, param.name, param.name.escapedText, 3 /* GetOrSetAccessor */); @@ -176073,19 +160027,19 @@ ${lanes.join("\n")} const isPrivate = isPrivateIdentifier(name); const privateStaticFlags = isPrivate && isStaticMember ? 16 /* PrivateStatic */ : 0; const names = isPrivate ? privateIdentifiers : isStaticMember ? staticNames : instanceNames; - const memberName = name && getPropertyNameForPropertyNameNode(name); + const memberName = name && getEffectivePropertyNameForPropertyNameNode(name); if (memberName) { switch (member.kind) { - case 176 /* GetAccessor */: + case 177 /* GetAccessor */: addName(names, name, memberName, 1 /* GetAccessor */ | privateStaticFlags); break; - case 177 /* SetAccessor */: + case 178 /* SetAccessor */: addName(names, name, memberName, 2 /* SetAccessor */ | privateStaticFlags); break; - case 171 /* PropertyDeclaration */: + case 172 /* PropertyDeclaration */: addName(names, name, memberName, 3 /* GetOrSetAccessor */ | privateStaticFlags); break; - case 173 /* MethodDeclaration */: + case 174 /* MethodDeclaration */: addName(names, name, memberName, 8 /* Method */ | privateStaticFlags); break; } @@ -176096,16 +160050,16 @@ ${lanes.join("\n")} const prev = names.get(name); if (prev) { if ((prev & 16 /* PrivateStatic */) !== (meaning & 16 /* PrivateStatic */)) { - error(location, Diagnostics.Duplicate_identifier_0_Static_and_instance_elements_cannot_share_the_same_private_name, getTextOfNode(location)); + error2(location, Diagnostics.Duplicate_identifier_0_Static_and_instance_elements_cannot_share_the_same_private_name, getTextOfNode(location)); } else { const prevIsMethod = !!(prev & 8 /* Method */); const isMethod = !!(meaning & 8 /* Method */); if (prevIsMethod || isMethod) { if (prevIsMethod !== isMethod) { - error(location, Diagnostics.Duplicate_identifier_0, getTextOfNode(location)); + error2(location, Diagnostics.Duplicate_identifier_0, getTextOfNode(location)); } } else if (prev & meaning & ~16 /* PrivateStatic */) { - error(location, Diagnostics.Duplicate_identifier_0, getTextOfNode(location)); + error2(location, Diagnostics.Duplicate_identifier_0, getTextOfNode(location)); } else { names.set(name, prev | meaning); } @@ -176120,16 +160074,19 @@ ${lanes.join("\n")} const memberNameNode = member.name; const isStaticMember = isStatic(member); if (isStaticMember && memberNameNode) { - const memberName = getPropertyNameForPropertyNameNode(memberNameNode); + const memberName = getEffectivePropertyNameForPropertyNameNode(memberNameNode); switch (memberName) { case "name": case "length": case "caller": case "arguments": + if (useDefineForClassFields) { + break; + } case "prototype": const message = Diagnostics.Static_property_0_conflicts_with_built_in_property_Function_0_of_constructor_function_1; const className = getNameOfSymbolAsWritten(getSymbolOfDeclaration(node)); - error(memberNameNode, message, memberName, className); + error2(memberNameNode, message, memberName, className); break; } } @@ -176138,7 +160095,7 @@ ${lanes.join("\n")} function checkObjectTypeForDuplicateDeclarations(node) { const names = /* @__PURE__ */ new Map(); for (const member of node.members) { - if (member.kind === 170 /* PropertySignature */) { + if (member.kind === 171 /* PropertySignature */) { let memberName; const name = member.name; switch (name.kind) { @@ -176153,8 +160110,8 @@ ${lanes.join("\n")} continue; } if (names.get(memberName)) { - error(getNameOfDeclaration(member.symbol.valueDeclaration), Diagnostics.Duplicate_identifier_0, memberName); - error(member.name, Diagnostics.Duplicate_identifier_0, memberName); + error2(getNameOfDeclaration(member.symbol.valueDeclaration), Diagnostics.Duplicate_identifier_0, memberName); + error2(member.name, Diagnostics.Duplicate_identifier_0, memberName); } else { names.set(memberName, true); } @@ -176162,7 +160119,7 @@ ${lanes.join("\n")} } } function checkTypeForDuplicateIndexSignatures(node) { - if (node.kind === 263 /* InterfaceDeclaration */) { + if (node.kind === 264 /* InterfaceDeclaration */) { const nodeSymbol = getSymbolOfDeclaration(node); if (nodeSymbol.declarations && nodeSymbol.declarations.length > 0 && nodeSymbol.declarations[0] !== node) { return; @@ -176186,7 +160143,7 @@ ${lanes.join("\n")} indexSignatureMap.forEach((entry) => { if (entry.declarations.length > 1) { for (const declaration of entry.declarations) { - error(declaration, Diagnostics.Duplicate_index_signature_for_type_0, typeToString(entry.type)); + error2(declaration, Diagnostics.Duplicate_index_signature_for_type_0, typeToString(entry.type)); } } }); @@ -176197,13 +160154,13 @@ ${lanes.join("\n")} checkGrammarComputedPropertyName(node.name); checkVariableLikeDeclaration(node); setNodeLinksForPrivateIdentifierScope(node); - if (hasSyntacticModifier(node, 256 /* Abstract */) && node.kind === 171 /* PropertyDeclaration */ && node.initializer) { - error(node, Diagnostics.Property_0_cannot_have_an_initializer_because_it_is_marked_abstract, declarationNameToString(node.name)); + if (hasSyntacticModifier(node, 64 /* Abstract */) && node.kind === 172 /* PropertyDeclaration */ && node.initializer) { + error2(node, Diagnostics.Property_0_cannot_have_an_initializer_because_it_is_marked_abstract, declarationNameToString(node.name)); } } function checkPropertySignature(node) { if (isPrivateIdentifier(node.name)) { - error(node, Diagnostics.Private_identifiers_are_not_allowed_outside_class_bodies); + error2(node, Diagnostics.Private_identifiers_are_not_allowed_outside_class_bodies); } return checkPropertyDeclaration(node); } @@ -176211,21 +160168,21 @@ ${lanes.join("\n")} if (!checkGrammarMethod(node)) checkGrammarComputedPropertyName(node.name); if (isMethodDeclaration(node) && node.asteriskToken && isIdentifier(node.name) && idText(node.name) === "constructor") { - error(node.name, Diagnostics.Class_constructor_may_not_be_a_generator); + error2(node.name, Diagnostics.Class_constructor_may_not_be_a_generator); } checkFunctionOrMethodDeclaration(node); - if (hasSyntacticModifier(node, 256 /* Abstract */) && node.kind === 173 /* MethodDeclaration */ && node.body) { - error(node, Diagnostics.Method_0_cannot_have_an_implementation_because_it_is_marked_abstract, declarationNameToString(node.name)); + if (hasSyntacticModifier(node, 64 /* Abstract */) && node.kind === 174 /* MethodDeclaration */ && node.body) { + error2(node, Diagnostics.Method_0_cannot_have_an_implementation_because_it_is_marked_abstract, declarationNameToString(node.name)); } if (isPrivateIdentifier(node.name) && !getContainingClass(node)) { - error(node, Diagnostics.Private_identifiers_are_not_allowed_outside_class_bodies); + error2(node, Diagnostics.Private_identifiers_are_not_allowed_outside_class_bodies); } setNodeLinksForPrivateIdentifierScope(node); } function setNodeLinksForPrivateIdentifierScope(node) { if (isPrivateIdentifier(node.name) && languageVersion < 99 /* ESNext */) { for (let lexicalScope = getEnclosingBlockScopeContainer(node); !!lexicalScope; lexicalScope = getEnclosingBlockScopeContainer(lexicalScope)) { - getNodeLinks(lexicalScope).flags |= 4194304 /* ContainsClassWithPrivateIdentifiers */; + getNodeLinks(lexicalScope).flags |= 1048576 /* ContainsClassWithPrivateIdentifiers */; } if (isClassExpression(node.parent)) { const enclosingIterationStatement = getEnclosingIterationStatement(node.parent); @@ -176259,7 +160216,7 @@ ${lanes.join("\n")} if (isPrivateIdentifierClassElementDeclaration(n)) { return true; } - return n.kind === 171 /* PropertyDeclaration */ && !isStatic(n) && !!n.initializer; + return n.kind === 172 /* PropertyDeclaration */ && !isStatic(n) && !!n.initializer; } function checkConstructorDeclarationDiagnostics() { const containingClassDecl = node.parent; @@ -176269,12 +160226,12 @@ ${lanes.join("\n")} const superCall = findFirstSuperCall(node.body); if (superCall) { if (classExtendsNull) { - error(superCall, Diagnostics.A_constructor_cannot_contain_a_super_call_when_its_class_extends_null); + error2(superCall, Diagnostics.A_constructor_cannot_contain_a_super_call_when_its_class_extends_null); } - const superCallShouldBeRootLevel = (getEmitScriptTarget(compilerOptions) !== 99 /* ESNext */ || !useDefineForClassFields) && (some(node.parent.members, isInstancePropertyWithInitializerOrPrivateIdentifierProperty) || some(node.parameters, (p) => hasSyntacticModifier(p, 16476 /* ParameterPropertyModifier */))); + const superCallShouldBeRootLevel = !emitStandardClassFields && (some(node.parent.members, isInstancePropertyWithInitializerOrPrivateIdentifierProperty) || some(node.parameters, (p) => hasSyntacticModifier(p, 31 /* ParameterPropertyModifier */))); if (superCallShouldBeRootLevel) { if (!superCallIsRootLevelInConstructor(superCall, node.body)) { - error(superCall, Diagnostics.A_super_call_must_be_a_root_level_statement_within_a_constructor_of_a_derived_class_that_contains_initialized_properties_parameter_properties_or_private_identifiers); + error2(superCall, Diagnostics.A_super_call_must_be_a_root_level_statement_within_a_constructor_of_a_derived_class_that_contains_initialized_properties_parameter_properties_or_private_identifiers); } else { let superCallStatement; for (const statement of node.body.statements) { @@ -176287,12 +160244,12 @@ ${lanes.join("\n")} } } if (superCallStatement === void 0) { - error(node, Diagnostics.A_super_call_must_be_the_first_statement_in_the_constructor_to_refer_to_super_or_this_when_a_derived_class_contains_initialized_properties_parameter_properties_or_private_identifiers); + error2(node, Diagnostics.A_super_call_must_be_the_first_statement_in_the_constructor_to_refer_to_super_or_this_when_a_derived_class_contains_initialized_properties_parameter_properties_or_private_identifiers); } } } } else if (!classExtendsNull) { - error(node, Diagnostics.Constructors_for_derived_classes_must_contain_a_super_call); + error2(node, Diagnostics.Constructors_for_derived_classes_must_contain_a_super_call); } } } @@ -176312,7 +160269,7 @@ ${lanes.join("\n")} } function checkAccessorDeclaration(node) { if (isIdentifier(node.name) && idText(node.name) === "constructor" && isClassLike(node.parent)) { - error(node.name, Diagnostics.Class_constructor_may_not_be_an_accessor); + error2(node.name, Diagnostics.Class_constructor_may_not_be_an_accessor); } addLazyDiagnostic(checkAccessorDeclarationDiagnostics); checkSourceElement(node.body); @@ -176322,36 +160279,36 @@ ${lanes.join("\n")} checkGrammarComputedPropertyName(node.name); checkDecorators(node); checkSignatureDeclaration(node); - if (node.kind === 176 /* GetAccessor */) { - if (!(node.flags & 16777216 /* Ambient */) && nodeIsPresent(node.body) && node.flags & 256 /* HasImplicitReturn */) { - if (!(node.flags & 512 /* HasExplicitReturn */)) { - error(node.name, Diagnostics.A_get_accessor_must_return_a_value); + if (node.kind === 177 /* GetAccessor */) { + if (!(node.flags & 33554432 /* Ambient */) && nodeIsPresent(node.body) && node.flags & 512 /* HasImplicitReturn */) { + if (!(node.flags & 1024 /* HasExplicitReturn */)) { + error2(node.name, Diagnostics.A_get_accessor_must_return_a_value); } } } - if (node.name.kind === 166 /* ComputedPropertyName */) { + if (node.name.kind === 167 /* ComputedPropertyName */) { checkComputedPropertyName(node.name); } if (hasBindableName(node)) { const symbol = getSymbolOfDeclaration(node); - const getter = getDeclarationOfKind(symbol, 176 /* GetAccessor */); - const setter = getDeclarationOfKind(symbol, 177 /* SetAccessor */); + const getter = getDeclarationOfKind(symbol, 177 /* GetAccessor */); + const setter = getDeclarationOfKind(symbol, 178 /* SetAccessor */); if (getter && setter && !(getNodeCheckFlags(getter) & 1 /* TypeChecked */)) { getNodeLinks(getter).flags |= 1 /* TypeChecked */; const getterFlags = getEffectiveModifierFlags(getter); const setterFlags = getEffectiveModifierFlags(setter); - if ((getterFlags & 256 /* Abstract */) !== (setterFlags & 256 /* Abstract */)) { - error(getter.name, Diagnostics.Accessors_must_both_be_abstract_or_non_abstract); - error(setter.name, Diagnostics.Accessors_must_both_be_abstract_or_non_abstract); + if ((getterFlags & 64 /* Abstract */) !== (setterFlags & 64 /* Abstract */)) { + error2(getter.name, Diagnostics.Accessors_must_both_be_abstract_or_non_abstract); + error2(setter.name, Diagnostics.Accessors_must_both_be_abstract_or_non_abstract); } - if (getterFlags & 16 /* Protected */ && !(setterFlags & (16 /* Protected */ | 8 /* Private */)) || getterFlags & 8 /* Private */ && !(setterFlags & 8 /* Private */)) { - error(getter.name, Diagnostics.A_get_accessor_must_be_at_least_as_accessible_as_the_setter); - error(setter.name, Diagnostics.A_get_accessor_must_be_at_least_as_accessible_as_the_setter); + if (getterFlags & 4 /* Protected */ && !(setterFlags & (4 /* Protected */ | 2 /* Private */)) || getterFlags & 2 /* Private */ && !(setterFlags & 2 /* Private */)) { + error2(getter.name, Diagnostics.A_get_accessor_must_be_at_least_as_accessible_as_the_setter); + error2(setter.name, Diagnostics.A_get_accessor_must_be_at_least_as_accessible_as_the_setter); } } } const returnType = getTypeOfAccessors(getSymbolOfDeclaration(node)); - if (node.kind === 176 /* GetAccessor */) { + if (node.kind === 177 /* GetAccessor */) { checkAllCodePathsInNonVoidFunctionReturnOrThrow(node, returnType); } } @@ -176366,12 +160323,7 @@ ${lanes.join("\n")} return getEffectiveTypeArguments2(node, typeParameters)[index]; } function getEffectiveTypeArguments2(node, typeParameters) { - return fillMissingTypeArguments( - map(node.typeArguments, getTypeFromTypeNode), - typeParameters, - getMinTypeArgumentCount(typeParameters), - isInJSFile(node) - ); + return fillMissingTypeArguments(map(node.typeArguments, getTypeFromTypeNode), typeParameters, getMinTypeArgumentCount(typeParameters), isInJSFile(node)); } function checkTypeArgumentConstraints(node, typeParameters) { let typeArguments; @@ -176412,7 +160364,7 @@ ${lanes.join("\n")} } function checkTypeReferenceNode(node) { checkGrammarTypeArguments(node, node.typeArguments); - if (node.kind === 182 /* TypeReference */ && !isInJSFile(node) && !isInJSDoc(node) && node.typeArguments && node.typeName.end !== node.typeArguments.pos) { + if (node.kind === 183 /* TypeReference */ && !isInJSFile(node) && !isInJSDoc(node) && node.typeArguments && node.typeName.end !== node.typeArguments.pos) { const sourceFile = getSourceFileOfNode(node); if (scanTokenAtPosition(sourceFile, node.typeName.end) === 25 /* DotToken */) { grammarErrorAtPos(node, skipTrivia(sourceFile.text, node.typeName.end), 1, Diagnostics.JSDoc_types_can_only_be_used_inside_documentation_comments); @@ -176434,7 +160386,7 @@ ${lanes.join("\n")} } const symbol = getNodeLinks(node).resolvedSymbol; if (symbol) { - if (some(symbol.declarations, (d) => isTypeDeclaration(d) && !!(d.flags & 268435456 /* Deprecated */))) { + if (some(symbol.declarations, (d) => isTypeDeclaration(d) && !!(d.flags & 536870912 /* Deprecated */))) { addDeprecatedSuggestion( getDeprecatedSuggestionNode(node), symbol.declarations, @@ -176474,17 +160426,12 @@ ${lanes.join("\n")} const elementTypes = node.elements; let seenOptionalElement = false; let seenRestElement = false; - const hasNamedElement = some(elementTypes, isNamedTupleMember); for (const e of elementTypes) { - if (e.kind !== 201 /* NamedTupleMember */ && hasNamedElement) { - grammarErrorOnNode(e, Diagnostics.Tuple_members_must_all_have_names_or_all_not_have_names); - break; - } const flags = getTupleElementFlags(e); if (flags & 8 /* Variadic */) { const type = getTypeFromTypeNode(e.type); if (!isArrayLikeType(type)) { - error(e, Diagnostics.A_rest_element_type_must_be_an_array_type); + error2(e, Diagnostics.A_rest_element_type_must_be_an_array_type); break; } if (isArrayType(type) || isTupleType(type) && type.target.combinedFlags & 4 /* Rest */) { @@ -176521,8 +160468,8 @@ ${lanes.join("\n")} const objectType = type.objectType; const indexType = type.indexType; if (isTypeAssignableTo(indexType, getIndexType(objectType, 0 /* None */))) { - if (accessNode.kind === 211 /* ElementAccessExpression */ && isAssignmentTarget(accessNode) && getObjectFlags(objectType) & 32 /* Mapped */ && getMappedTypeModifiers(objectType) & 1 /* IncludeReadonly */) { - error(accessNode, Diagnostics.Index_signature_in_type_0_only_permits_reading, typeToString(objectType)); + if (accessNode.kind === 212 /* ElementAccessExpression */ && isAssignmentTarget(accessNode) && getObjectFlags(objectType) & 32 /* Mapped */ && getMappedTypeModifiers(objectType) & 1 /* IncludeReadonly */) { + error2(accessNode, Diagnostics.Index_signature_in_type_0_only_permits_reading, typeToString(objectType)); } return type; } @@ -176534,13 +160481,13 @@ ${lanes.join("\n")} const propertyName = getPropertyNameFromIndex(indexType, accessNode); if (propertyName) { const propertySymbol = forEachType(apparentObjectType, (t) => getPropertyOfType(t, propertyName)); - if (propertySymbol && getDeclarationModifierFlagsFromSymbol(propertySymbol) & 24 /* NonPublicAccessibilityModifier */) { - error(accessNode, Diagnostics.Private_or_protected_member_0_cannot_be_accessed_on_a_type_parameter, unescapeLeadingUnderscores(propertyName)); + if (propertySymbol && getDeclarationModifierFlagsFromSymbol(propertySymbol) & 6 /* NonPublicAccessibilityModifier */) { + error2(accessNode, Diagnostics.Private_or_protected_member_0_cannot_be_accessed_on_a_type_parameter, unescapeLeadingUnderscores(propertyName)); return errorType; } } } - error(accessNode, Diagnostics.Type_0_cannot_be_used_to_index_type_1, typeToString(indexType), typeToString(objectType)); + error2(accessNode, Diagnostics.Type_0_cannot_be_used_to_index_type_1, typeToString(indexType), typeToString(objectType)); return errorType; } function checkIndexedAccessType(node) { @@ -176582,7 +160529,7 @@ ${lanes.join("\n")} forEachChild(node, checkSourceElement); } function checkInferType(node) { - if (!findAncestor(node, (n) => n.parent && n.parent.kind === 193 /* ConditionalType */ && n.parent.extendsType === n)) { + if (!findAncestor(node, (n) => n.parent && n.parent.kind === 194 /* ConditionalType */ && n.parent.extendsType === n)) { grammarErrorOnNode(node, Diagnostics.infer_declarations_are_only_permitted_in_the_extends_clause_of_a_conditional_type); } checkSourceElement(node.typeParameter); @@ -176592,11 +160539,11 @@ ${lanes.join("\n")} if (!links.typeParametersChecked) { links.typeParametersChecked = true; const typeParameter = getDeclaredTypeOfTypeParameter(symbol); - const declarations = getDeclarationsOfKind(symbol, 167 /* TypeParameter */); + const declarations = getDeclarationsOfKind(symbol, 168 /* TypeParameter */); if (!areTypeParametersIdentical(declarations, [typeParameter], (decl) => [decl])) { const name = symbolToString(symbol); for (const declaration of declarations) { - error(declaration.name, Diagnostics.All_declarations_of_0_must_have_identical_constraints, name); + error2(declaration.name, Diagnostics.All_declarations_of_0_must_have_identical_constraints, name); } } } @@ -176613,16 +160560,8 @@ ${lanes.join("\n")} } function checkImportType(node) { checkSourceElement(node.argument); - if (node.assertions) { - const override = getResolutionModeOverrideForClause(node.assertions.assertClause, grammarErrorOnNode); - if (override) { - if (!isNightly()) { - grammarErrorOnNode(node.assertions.assertClause, Diagnostics.resolution_mode_assertions_are_unstable_Use_nightly_TypeScript_to_silence_this_error_Try_updating_with_npm_install_D_typescript_next); - } - if (getEmitModuleResolutionKind(compilerOptions) !== 3 /* Node16 */ && getEmitModuleResolutionKind(compilerOptions) !== 99 /* NodeNext */) { - grammarErrorOnNode(node.assertions.assertClause, Diagnostics.resolution_mode_assertions_are_only_supported_when_moduleResolution_is_node16_or_nodenext); - } - } + if (node.attributes) { + getResolutionModeOverride(node.attributes, grammarErrorOnNode); } checkTypeReferenceOrImport(node); } @@ -176630,25 +160569,26 @@ ${lanes.join("\n")} if (node.dotDotDotToken && node.questionToken) { grammarErrorOnNode(node, Diagnostics.A_tuple_member_cannot_be_both_optional_and_rest); } - if (node.type.kind === 189 /* OptionalType */) { + if (node.type.kind === 190 /* OptionalType */) { grammarErrorOnNode(node.type, Diagnostics.A_labeled_tuple_element_is_declared_as_optional_with_a_question_mark_after_the_name_and_before_the_colon_rather_than_after_the_type); } - if (node.type.kind === 190 /* RestType */) { + if (node.type.kind === 191 /* RestType */) { grammarErrorOnNode(node.type, Diagnostics.A_labeled_tuple_element_is_declared_as_rest_with_a_before_the_name_rather_than_before_the_type); } checkSourceElement(node.type); getTypeFromTypeNode(node); } function isPrivateWithinAmbient(node) { - return (hasEffectiveModifier(node, 8 /* Private */) || isPrivateIdentifierClassElementDeclaration(node)) && !!(node.flags & 16777216 /* Ambient */); + return (hasEffectiveModifier(node, 2 /* Private */) || isPrivateIdentifierClassElementDeclaration(node)) && !!(node.flags & 33554432 /* Ambient */); } function getEffectiveDeclarationFlags(n, flagsToCheck) { - let flags = getCombinedModifierFlags(n); - if (n.parent.kind !== 263 /* InterfaceDeclaration */ && n.parent.kind !== 262 /* ClassDeclaration */ && n.parent.kind !== 230 /* ClassExpression */ && n.flags & 16777216 /* Ambient */) { - if (!(flags & 2 /* Ambient */) && !(isModuleBlock(n.parent) && isModuleDeclaration(n.parent.parent) && isGlobalScopeAugmentation(n.parent.parent))) { - flags |= 1 /* Export */; + let flags = getCombinedModifierFlagsCached(n); + if (n.parent.kind !== 264 /* InterfaceDeclaration */ && n.parent.kind !== 263 /* ClassDeclaration */ && n.parent.kind !== 231 /* ClassExpression */ && n.flags & 33554432 /* Ambient */) { + const container = getEnclosingContainer(n); + if (container && container.flags & 128 /* ExportContext */ && !(flags & 128 /* Ambient */) && !(isModuleBlock(n.parent) && isModuleDeclaration(n.parent.parent) && isGlobalScopeAugmentation(n.parent.parent))) { + flags |= 32 /* Export */; } - flags |= 2 /* Ambient */; + flags |= 128 /* Ambient */; } return flags & flagsToCheck; } @@ -176666,14 +160606,14 @@ ${lanes.join("\n")} const canonicalFlags = getEffectiveDeclarationFlags(getCanonicalOverload(overloads, implementation), flagsToCheck2); forEach(overloads, (o) => { const deviation = getEffectiveDeclarationFlags(o, flagsToCheck2) ^ canonicalFlags; - if (deviation & 1 /* Export */) { - error(getNameOfDeclaration(o), Diagnostics.Overload_signatures_must_all_be_exported_or_non_exported); - } else if (deviation & 2 /* Ambient */) { - error(getNameOfDeclaration(o), Diagnostics.Overload_signatures_must_all_be_ambient_or_non_ambient); - } else if (deviation & (8 /* Private */ | 16 /* Protected */)) { - error(getNameOfDeclaration(o) || o, Diagnostics.Overload_signatures_must_all_be_public_private_or_protected); - } else if (deviation & 256 /* Abstract */) { - error(getNameOfDeclaration(o), Diagnostics.Overload_signatures_must_all_be_abstract_or_non_abstract); + if (deviation & 32 /* Export */) { + error2(getNameOfDeclaration(o), Diagnostics.Overload_signatures_must_all_be_exported_or_non_exported); + } else if (deviation & 128 /* Ambient */) { + error2(getNameOfDeclaration(o), Diagnostics.Overload_signatures_must_all_be_ambient_or_non_ambient); + } else if (deviation & (2 /* Private */ | 4 /* Protected */)) { + error2(getNameOfDeclaration(o) || o, Diagnostics.Overload_signatures_must_all_be_public_private_or_protected); + } else if (deviation & 64 /* Abstract */) { + error2(getNameOfDeclaration(o), Diagnostics.Overload_signatures_must_all_be_abstract_or_non_abstract); } }); } @@ -176684,12 +160624,12 @@ ${lanes.join("\n")} forEach(overloads, (o) => { const deviation = hasQuestionToken(o) !== canonicalHasQuestionToken; if (deviation) { - error(getNameOfDeclaration(o), Diagnostics.Overload_signatures_must_all_be_optional_or_required); + error2(getNameOfDeclaration(o), Diagnostics.Overload_signatures_must_all_be_optional_or_required); } }); } } - const flagsToCheck = 1 /* Export */ | 2 /* Ambient */ | 8 /* Private */ | 16 /* Protected */ | 256 /* Abstract */; + const flagsToCheck = 32 /* Export */ | 128 /* Ambient */ | 2 /* Private */ | 4 /* Protected */ | 64 /* Abstract */; let someNodeFlags = 0 /* None */; let allNodeFlags = flagsToCheck; let someHaveQuestionToken = false; @@ -176720,27 +160660,27 @@ ${lanes.join("\n")} (isPrivateIdentifier(node.name) && isPrivateIdentifier(subsequentName) && node.name.escapedText === subsequentName.escapedText || // Both are computed property names isComputedPropertyName(node.name) && isComputedPropertyName(subsequentName) && isTypeIdenticalTo(checkComputedPropertyName(node.name), checkComputedPropertyName(subsequentName)) || // Both are literal property names that are the same. isPropertyNameLiteral(node.name) && isPropertyNameLiteral(subsequentName) && getEscapedTextOfIdentifierOrLiteral(node.name) === getEscapedTextOfIdentifierOrLiteral(subsequentName))) { - const reportError = (node.kind === 173 /* MethodDeclaration */ || node.kind === 172 /* MethodSignature */) && isStatic(node) !== isStatic(subsequentNode); + const reportError = (node.kind === 174 /* MethodDeclaration */ || node.kind === 173 /* MethodSignature */) && isStatic(node) !== isStatic(subsequentNode); if (reportError) { const diagnostic = isStatic(node) ? Diagnostics.Function_overload_must_be_static : Diagnostics.Function_overload_must_not_be_static; - error(errorNode2, diagnostic); + error2(errorNode2, diagnostic); } return; } if (nodeIsPresent(subsequentNode.body)) { - error(errorNode2, Diagnostics.Function_implementation_name_must_be_0, declarationNameToString(node.name)); + error2(errorNode2, Diagnostics.Function_implementation_name_must_be_0, declarationNameToString(node.name)); return; } } } const errorNode = node.name || node; if (isConstructor) { - error(errorNode, Diagnostics.Constructor_implementation_is_missing); + error2(errorNode, Diagnostics.Constructor_implementation_is_missing); } else { - if (hasSyntacticModifier(node, 256 /* Abstract */)) { - error(errorNode, Diagnostics.All_declarations_of_an_abstract_method_must_be_consecutive); + if (hasSyntacticModifier(node, 64 /* Abstract */)) { + error2(errorNode, Diagnostics.All_declarations_of_an_abstract_method_must_be_consecutive); } else { - error(errorNode, Diagnostics.Function_implementation_is_missing_or_not_immediately_following_the_declaration); + error2(errorNode, Diagnostics.Function_implementation_is_missing_or_not_immediately_following_the_declaration); } } } @@ -176751,15 +160691,15 @@ ${lanes.join("\n")} if (declarations) { for (const current of declarations) { const node = current; - const inAmbientContext = node.flags & 16777216 /* Ambient */; - const inAmbientContextOrInterface = node.parent && (node.parent.kind === 263 /* InterfaceDeclaration */ || node.parent.kind === 186 /* TypeLiteral */) || inAmbientContext; + const inAmbientContext = node.flags & 33554432 /* Ambient */; + const inAmbientContextOrInterface = node.parent && (node.parent.kind === 264 /* InterfaceDeclaration */ || node.parent.kind === 187 /* TypeLiteral */) || inAmbientContext; if (inAmbientContextOrInterface) { previousDeclaration = void 0; } - if ((node.kind === 262 /* ClassDeclaration */ || node.kind === 230 /* ClassExpression */) && !inAmbientContext) { + if ((node.kind === 263 /* ClassDeclaration */ || node.kind === 231 /* ClassExpression */) && !inAmbientContext) { hasNonAmbientClass = true; } - if (node.kind === 261 /* FunctionDeclaration */ || node.kind === 173 /* MethodDeclaration */ || node.kind === 172 /* MethodSignature */ || node.kind === 175 /* Constructor */) { + if (node.kind === 262 /* FunctionDeclaration */ || node.kind === 174 /* MethodDeclaration */ || node.kind === 173 /* MethodSignature */ || node.kind === 176 /* Constructor */) { functionDeclarations.push(node); const currentNodeFlags = getEffectiveDeclarationFlags(node, flagsToCheck); someNodeFlags |= currentNodeFlags; @@ -176803,27 +160743,27 @@ ${lanes.join("\n")} } if (multipleConstructorImplementation) { forEach(functionDeclarations, (declaration) => { - error(declaration, Diagnostics.Multiple_constructor_implementations_are_not_allowed); + error2(declaration, Diagnostics.Multiple_constructor_implementations_are_not_allowed); }); } if (duplicateFunctionDeclaration) { forEach(functionDeclarations, (declaration) => { - error(getNameOfDeclaration(declaration) || declaration, Diagnostics.Duplicate_function_implementation); + error2(getNameOfDeclaration(declaration) || declaration, Diagnostics.Duplicate_function_implementation); }); } if (hasNonAmbientClass && !isConstructor && symbol.flags & 16 /* Function */ && declarations) { - const relatedDiagnostics = filter(declarations, (d) => d.kind === 262 /* ClassDeclaration */).map((d) => createDiagnosticForNode(d, Diagnostics.Consider_adding_a_declare_modifier_to_this_class)); + const relatedDiagnostics = filter(declarations, (d) => d.kind === 263 /* ClassDeclaration */).map((d) => createDiagnosticForNode(d, Diagnostics.Consider_adding_a_declare_modifier_to_this_class)); forEach(declarations, (declaration) => { - const diagnostic = declaration.kind === 262 /* ClassDeclaration */ ? Diagnostics.Class_declaration_cannot_implement_overload_list_for_0 : declaration.kind === 261 /* FunctionDeclaration */ ? Diagnostics.Function_with_bodies_can_only_merge_with_classes_that_are_ambient : void 0; + const diagnostic = declaration.kind === 263 /* ClassDeclaration */ ? Diagnostics.Class_declaration_cannot_implement_overload_list_for_0 : declaration.kind === 262 /* FunctionDeclaration */ ? Diagnostics.Function_with_bodies_can_only_merge_with_classes_that_are_ambient : void 0; if (diagnostic) { addRelatedInfo( - error(getNameOfDeclaration(declaration) || declaration, diagnostic, symbolName(symbol)), + error2(getNameOfDeclaration(declaration) || declaration, diagnostic, symbolName(symbol)), ...relatedDiagnostics ); } }); } - if (lastSeenNonAmbientDeclaration && !lastSeenNonAmbientDeclaration.body && !hasSyntacticModifier(lastSeenNonAmbientDeclaration, 256 /* Abstract */) && !lastSeenNonAmbientDeclaration.questionToken) { + if (lastSeenNonAmbientDeclaration && !lastSeenNonAmbientDeclaration.body && !hasSyntacticModifier(lastSeenNonAmbientDeclaration, 64 /* Abstract */) && !lastSeenNonAmbientDeclaration.questionToken) { reportImplementationExpectedError(lastSeenNonAmbientDeclaration); } if (hasOverloads) { @@ -176838,7 +160778,7 @@ ${lanes.join("\n")} if (!isImplementationCompatibleWithOverload(bodySignature, signature)) { const errorNode = signature.declaration && isJSDocSignature(signature.declaration) ? signature.declaration.parent.tagName : signature.declaration; addRelatedInfo( - error(errorNode, Diagnostics.This_overload_signature_is_not_compatible_with_its_implementation_signature), + error2(errorNode, Diagnostics.This_overload_signature_is_not_compatible_with_its_implementation_signature), createDiagnosticForNode(bodyDeclaration, Diagnostics.The_implementation_signature_is_declared_here) ); break; @@ -176866,9 +160806,9 @@ ${lanes.join("\n")} let defaultExportedDeclarationSpaces = 0 /* None */; for (const d of symbol.declarations) { const declarationSpaces = getDeclarationSpaces(d); - const effectiveDeclarationFlags = getEffectiveDeclarationFlags(d, 1 /* Export */ | 1024 /* Default */); - if (effectiveDeclarationFlags & 1 /* Export */) { - if (effectiveDeclarationFlags & 1024 /* Default */) { + const effectiveDeclarationFlags = getEffectiveDeclarationFlags(d, 32 /* Export */ | 2048 /* Default */); + if (effectiveDeclarationFlags & 32 /* Export */) { + if (effectiveDeclarationFlags & 2048 /* Default */) { defaultExportedDeclarationSpaces |= declarationSpaces; } else { exportedDeclarationSpaces |= declarationSpaces; @@ -176885,54 +160825,54 @@ ${lanes.join("\n")} const declarationSpaces = getDeclarationSpaces(d); const name = getNameOfDeclaration(d); if (declarationSpaces & commonDeclarationSpacesForDefaultAndNonDefault) { - error(name, Diagnostics.Merged_declaration_0_cannot_include_a_default_export_declaration_Consider_adding_a_separate_export_default_0_declaration_instead, declarationNameToString(name)); + error2(name, Diagnostics.Merged_declaration_0_cannot_include_a_default_export_declaration_Consider_adding_a_separate_export_default_0_declaration_instead, declarationNameToString(name)); } else if (declarationSpaces & commonDeclarationSpacesForExportsAndLocals) { - error(name, Diagnostics.Individual_declarations_in_merged_declaration_0_must_be_all_exported_or_all_local, declarationNameToString(name)); + error2(name, Diagnostics.Individual_declarations_in_merged_declaration_0_must_be_all_exported_or_all_local, declarationNameToString(name)); } } } function getDeclarationSpaces(decl) { let d = decl; switch (d.kind) { - case 263 /* InterfaceDeclaration */: - case 264 /* TypeAliasDeclaration */: - case 352 /* JSDocTypedefTag */: - case 344 /* JSDocCallbackTag */: - case 346 /* JSDocEnumTag */: + case 264 /* InterfaceDeclaration */: + case 265 /* TypeAliasDeclaration */: + case 353 /* JSDocTypedefTag */: + case 345 /* JSDocCallbackTag */: + case 347 /* JSDocEnumTag */: return 2 /* ExportType */; - case 266 /* ModuleDeclaration */: + case 267 /* ModuleDeclaration */: return isAmbientModule(d) || getModuleInstanceState(d) !== 0 /* NonInstantiated */ ? 4 /* ExportNamespace */ | 1 /* ExportValue */ : 4 /* ExportNamespace */; - case 262 /* ClassDeclaration */: - case 265 /* EnumDeclaration */: - case 305 /* EnumMember */: + case 263 /* ClassDeclaration */: + case 266 /* EnumDeclaration */: + case 306 /* EnumMember */: return 2 /* ExportType */ | 1 /* ExportValue */; - case 311 /* SourceFile */: + case 312 /* SourceFile */: return 2 /* ExportType */ | 1 /* ExportValue */ | 4 /* ExportNamespace */; - case 276 /* ExportAssignment */: - case 225 /* BinaryExpression */: + case 277 /* ExportAssignment */: + case 226 /* BinaryExpression */: const node2 = d; const expression = isExportAssignment(node2) ? node2.expression : node2.right; if (!isEntityNameExpression(expression)) { return 1 /* ExportValue */; } d = expression; - case 270 /* ImportEqualsDeclaration */: - case 273 /* NamespaceImport */: - case 272 /* ImportClause */: + case 271 /* ImportEqualsDeclaration */: + case 274 /* NamespaceImport */: + case 273 /* ImportClause */: let result = 0 /* None */; const target = resolveAlias(getSymbolOfDeclaration(d)); forEach(target.declarations, (d2) => { result |= getDeclarationSpaces(d2); }); return result; - case 259 /* VariableDeclaration */: - case 207 /* BindingElement */: - case 261 /* FunctionDeclaration */: - case 275 /* ImportSpecifier */: + case 260 /* VariableDeclaration */: + case 208 /* BindingElement */: + case 262 /* FunctionDeclaration */: + case 276 /* ImportSpecifier */: case 80 /* Identifier */: return 1 /* ExportValue */; - case 172 /* MethodSignature */: - case 170 /* PropertySignature */: + case 173 /* MethodSignature */: + case 171 /* PropertySignature */: return 2 /* ExportType */; default: return Debug.failBadSyntaxKind(d); @@ -176967,7 +160907,7 @@ ${lanes.join("\n")} const thenSignatures = thenFunction ? getSignaturesOfType(thenFunction, 0 /* Call */) : emptyArray; if (thenSignatures.length === 0) { if (errorNode) { - error(errorNode, Diagnostics.A_promise_must_have_a_then_method); + error2(errorNode, Diagnostics.A_promise_must_have_a_then_method); } return void 0; } @@ -176987,7 +160927,7 @@ ${lanes.join("\n")} thisTypeForErrorOut.value = thisTypeForError; } if (errorNode) { - error(errorNode, Diagnostics.The_this_context_of_type_0_is_not_assignable_to_method_s_this_of_type_1, typeToString(type), typeToString(thisTypeForError)); + error2(errorNode, Diagnostics.The_this_context_of_type_0_is_not_assignable_to_method_s_this_of_type_1, typeToString(type), typeToString(thisTypeForError)); } return void 0; } @@ -176998,7 +160938,7 @@ ${lanes.join("\n")} const onfulfilledParameterSignatures = getSignaturesOfType(onfulfilledParameterType, 0 /* Call */); if (onfulfilledParameterSignatures.length === 0) { if (errorNode) { - error(errorNode, Diagnostics.The_first_parameter_of_the_then_method_of_a_promise_must_be_a_callback); + error2(errorNode, Diagnostics.The_first_parameter_of_the_then_method_of_a_promise_must_be_a_callback); } return void 0; } @@ -177079,7 +161019,7 @@ ${lanes.join("\n")} if (type.flags & 1048576 /* Union */) { if (awaitedTypeStack.lastIndexOf(type.id) >= 0) { if (errorNode) { - error(errorNode, Diagnostics.Type_is_referenced_directly_or_indirectly_in_the_fulfillment_callback_of_its_own_then_method); + error2(errorNode, Diagnostics.Type_is_referenced_directly_or_indirectly_in_the_fulfillment_callback_of_its_own_then_method); } return void 0; } @@ -177102,7 +161042,7 @@ ${lanes.join("\n")} if (promisedType) { if (type.id === promisedType.id || awaitedTypeStack.lastIndexOf(promisedType.id) >= 0) { if (errorNode) { - error(errorNode, Diagnostics.Type_is_referenced_directly_or_indirectly_in_the_fulfillment_callback_of_its_own_then_method); + error2(errorNode, Diagnostics.Type_is_referenced_directly_or_indirectly_in_the_fulfillment_callback_of_its_own_then_method); } return void 0; } @@ -177128,7 +161068,7 @@ ${lanes.join("\n")} } return typeAsAwaitable.awaitedTypeOfType = type; } - function checkAsyncFunctionReturnType(node, returnTypeNode) { + function checkAsyncFunctionReturnType(node, returnTypeNode, returnTypeErrorLocation) { const returnType = getTypeFromTypeNode(returnTypeNode); if (languageVersion >= 2 /* ES2015 */) { if (isErrorType(returnType)) { @@ -177139,7 +161079,7 @@ ${lanes.join("\n")} true ); if (globalPromiseType !== emptyGenericType && !isReferenceToType2(returnType, globalPromiseType)) { - error(returnTypeNode, Diagnostics.The_return_type_of_an_async_function_or_method_must_be_the_global_Promise_T_type_Did_you_mean_to_write_Promise_0, typeToString(getAwaitedTypeNoAlias(returnType) || voidType)); + reportErrorForInvalidReturnType(Diagnostics.The_return_type_of_an_async_function_or_method_must_be_the_global_Promise_T_type_Did_you_mean_to_write_Promise_0, returnTypeNode, returnTypeErrorLocation, typeToString(getAwaitedTypeNoAlias(returnType) || voidType)); return; } } else { @@ -177149,7 +161089,7 @@ ${lanes.join("\n")} } const promiseConstructorName = getEntityNameFromTypeNode(returnTypeNode); if (promiseConstructorName === void 0) { - error(returnTypeNode, Diagnostics.Type_0_is_not_a_valid_async_function_return_type_in_ES5_SlashES3_because_it_does_not_refer_to_a_Promise_compatible_constructor_value, typeToString(returnType)); + reportErrorForInvalidReturnType(Diagnostics.Type_0_is_not_a_valid_async_function_return_type_in_ES5_SlashES3_because_it_does_not_refer_to_a_Promise_compatible_constructor_value, returnTypeNode, returnTypeErrorLocation, typeToString(returnType)); return; } const promiseConstructorSymbol = resolveEntityName( @@ -177164,9 +161104,9 @@ ${lanes.join("\n")} /*reportErrors*/ false )) { - error(returnTypeNode, Diagnostics.An_async_function_or_method_in_ES5_SlashES3_requires_the_Promise_constructor_Make_sure_you_have_a_declaration_for_the_Promise_constructor_or_include_ES2015_in_your_lib_option); + error2(returnTypeErrorLocation, Diagnostics.An_async_function_or_method_in_ES5_SlashES3_requires_the_Promise_constructor_Make_sure_you_have_a_declaration_for_the_Promise_constructor_or_include_ES2015_in_your_lib_option); } else { - error(returnTypeNode, Diagnostics.Type_0_is_not_a_valid_async_function_return_type_in_ES5_SlashES3_because_it_does_not_refer_to_a_Promise_compatible_constructor_value, entityNameToString(promiseConstructorName)); + reportErrorForInvalidReturnType(Diagnostics.Type_0_is_not_a_valid_async_function_return_type_in_ES5_SlashES3_because_it_does_not_refer_to_a_Promise_compatible_constructor_value, returnTypeNode, returnTypeErrorLocation, entityNameToString(promiseConstructorName)); } return; } @@ -177175,26 +161115,22 @@ ${lanes.join("\n")} true ); if (globalPromiseConstructorLikeType === emptyObjectType) { - error(returnTypeNode, Diagnostics.Type_0_is_not_a_valid_async_function_return_type_in_ES5_SlashES3_because_it_does_not_refer_to_a_Promise_compatible_constructor_value, entityNameToString(promiseConstructorName)); + reportErrorForInvalidReturnType(Diagnostics.Type_0_is_not_a_valid_async_function_return_type_in_ES5_SlashES3_because_it_does_not_refer_to_a_Promise_compatible_constructor_value, returnTypeNode, returnTypeErrorLocation, entityNameToString(promiseConstructorName)); return; } - if (!checkTypeAssignableTo( - promiseConstructorType, - globalPromiseConstructorLikeType, - returnTypeNode, - Diagnostics.Type_0_is_not_a_valid_async_function_return_type_in_ES5_SlashES3_because_it_does_not_refer_to_a_Promise_compatible_constructor_value - )) { + const headMessage = Diagnostics.Type_0_is_not_a_valid_async_function_return_type_in_ES5_SlashES3_because_it_does_not_refer_to_a_Promise_compatible_constructor_value; + const errorInfo = () => returnTypeNode === returnTypeErrorLocation ? void 0 : chainDiagnosticMessages( + /*details*/ + void 0, + Diagnostics.The_return_type_of_an_async_function_or_method_must_be_the_global_Promise_T_type + ); + if (!checkTypeAssignableTo(promiseConstructorType, globalPromiseConstructorLikeType, returnTypeErrorLocation, headMessage, errorInfo)) { return; } const rootName = promiseConstructorName && getFirstIdentifier(promiseConstructorName); const collidingSymbol = getSymbol2(node.locals, rootName.escapedText, 111551 /* Value */); if (collidingSymbol) { - error( - collidingSymbol.valueDeclaration, - Diagnostics.Duplicate_identifier_0_Compiler_uses_declaration_1_to_support_async_functions, - idText(rootName), - entityNameToString(promiseConstructorName) - ); + error2(collidingSymbol.valueDeclaration, Diagnostics.Duplicate_identifier_0_Compiler_uses_declaration_1_to_support_async_functions, idText(rootName), entityNameToString(promiseConstructorName)); return; } } @@ -177205,6 +161141,14 @@ ${lanes.join("\n")} node, Diagnostics.The_return_type_of_an_async_function_must_either_be_a_valid_promise_or_must_not_contain_a_callable_then_member ); + function reportErrorForInvalidReturnType(message, returnTypeNode2, returnTypeErrorLocation2, typeName) { + if (returnTypeNode2 === returnTypeErrorLocation2) { + error2(returnTypeErrorLocation2, message, typeName); + } else { + const diag2 = error2(returnTypeErrorLocation2, Diagnostics.The_return_type_of_an_async_function_or_method_must_be_the_global_Promise_T_type); + addRelatedInfo(diag2, createDiagnosticForNode(returnTypeNode2, message, typeName)); + } + } } function checkDecorator(node) { const signature = getResolvedSignature(node); @@ -177219,21 +161163,21 @@ ${lanes.join("\n")} let headMessage; const expectedReturnType = decoratorSignature.resolvedReturnType; switch (node.parent.kind) { - case 262 /* ClassDeclaration */: - case 230 /* ClassExpression */: + case 263 /* ClassDeclaration */: + case 231 /* ClassExpression */: headMessage = Diagnostics.Decorator_function_return_type_0_is_not_assignable_to_type_1; break; - case 171 /* PropertyDeclaration */: + case 172 /* PropertyDeclaration */: if (!legacyDecorators) { headMessage = Diagnostics.Decorator_function_return_type_0_is_not_assignable_to_type_1; break; } - case 168 /* Parameter */: + case 169 /* Parameter */: headMessage = Diagnostics.Decorator_function_return_type_is_0_but_is_expected_to_be_void_or_any; break; - case 173 /* MethodDeclaration */: - case 176 /* GetAccessor */: - case 177 /* SetAccessor */: + case 174 /* MethodDeclaration */: + case 177 /* GetAccessor */: + case 178 /* SetAccessor */: headMessage = Diagnostics.Decorator_function_return_type_0_is_not_assignable_to_type_1; break; default: @@ -177302,7 +161246,7 @@ ${lanes.join("\n")} if (canCollectSymbolAliasAccessabilityData && symbolIsValue(rootSymbol) && !isConstEnumOrConstEnumOnlyModule(resolveAlias(rootSymbol)) && !getTypeOnlyAliasDeclaration(rootSymbol)) { markAliasSymbolAsReferenced(rootSymbol); } else if (forDecoratorMetadata && getIsolatedModules(compilerOptions) && getEmitModuleKind(compilerOptions) >= 5 /* ES2015 */ && !symbolIsValue(rootSymbol) && !some(rootSymbol.declarations, isTypeOnlyImportOrExportDeclaration)) { - const diag2 = error(typeName, Diagnostics.A_type_referenced_in_a_decorated_signature_must_be_imported_with_import_type_or_a_namespace_import_when_isolatedModules_and_emitDecoratorMetadata_are_enabled); + const diag2 = error2(typeName, Diagnostics.A_type_referenced_in_a_decorated_signature_must_be_imported_with_import_type_or_a_namespace_import_when_isolatedModules_and_emitDecoratorMetadata_are_enabled); const aliasDeclaration = find(rootSymbol.declarations || emptyArray, isAliasSymbolDeclaration2); if (aliasDeclaration) { addRelatedInfo(diag2, createDiagnosticForNode(aliasDeclaration, Diagnostics._0_was_imported_here, idText(rootName))); @@ -177323,15 +161267,15 @@ ${lanes.join("\n")} function getEntityNameForDecoratorMetadata(node) { if (node) { switch (node.kind) { - case 192 /* IntersectionType */: - case 191 /* UnionType */: + case 193 /* IntersectionType */: + case 192 /* UnionType */: return getEntityNameForDecoratorMetadataFromTypeList(node.types); - case 193 /* ConditionalType */: + case 194 /* ConditionalType */: return getEntityNameForDecoratorMetadataFromTypeList([node.trueType, node.falseType]); - case 195 /* ParenthesizedType */: - case 201 /* NamedTupleMember */: + case 196 /* ParenthesizedType */: + case 202 /* NamedTupleMember */: return getEntityNameForDecoratorMetadata(node.type); - case 182 /* TypeReference */: + case 183 /* TypeReference */: return node.typeName; } } @@ -177339,13 +161283,13 @@ ${lanes.join("\n")} function getEntityNameForDecoratorMetadataFromTypeList(types) { let commonEntityName; for (let typeNode of types) { - while (typeNode.kind === 195 /* ParenthesizedType */ || typeNode.kind === 201 /* NamedTupleMember */) { + while (typeNode.kind === 196 /* ParenthesizedType */ || typeNode.kind === 202 /* NamedTupleMember */) { typeNode = typeNode.type; } if (typeNode.kind === 146 /* NeverKeyword */) { continue; } - if (!strictNullChecks && (typeNode.kind === 200 /* LiteralType */ && typeNode.literal.kind === 106 /* NullKeyword */ || typeNode.kind === 157 /* UndefinedKeyword */)) { + if (!strictNullChecks && (typeNode.kind === 201 /* LiteralType */ && typeNode.literal.kind === 106 /* NullKeyword */ || typeNode.kind === 157 /* UndefinedKeyword */)) { continue; } const individualEntityName = getEntityNameForDecoratorMetadata(typeNode); @@ -177376,7 +161320,7 @@ ${lanes.join("\n")} } if (legacyDecorators) { checkExternalEmitHelpers(firstDecorator, 8 /* Decorate */); - if (node.kind === 168 /* Parameter */) { + if (node.kind === 169 /* Parameter */) { checkExternalEmitHelpers(firstDecorator, 32 /* Param */); } } else if (languageVersion < 99 /* ESNext */) { @@ -177402,7 +161346,7 @@ ${lanes.join("\n")} if (compilerOptions.emitDecoratorMetadata) { checkExternalEmitHelpers(firstDecorator, 16 /* Metadata */); switch (node.kind) { - case 262 /* ClassDeclaration */: + case 263 /* ClassDeclaration */: const constructor = getFirstConstructorWithBody(node); if (constructor) { for (const parameter of constructor.parameters) { @@ -177410,27 +161354,28 @@ ${lanes.join("\n")} } } break; - case 176 /* GetAccessor */: - case 177 /* SetAccessor */: - const otherKind = node.kind === 176 /* GetAccessor */ ? 177 /* SetAccessor */ : 176 /* GetAccessor */; + case 177 /* GetAccessor */: + case 178 /* SetAccessor */: + const otherKind = node.kind === 177 /* GetAccessor */ ? 178 /* SetAccessor */ : 177 /* GetAccessor */; const otherAccessor = getDeclarationOfKind(getSymbolOfDeclaration(node), otherKind); markDecoratorMedataDataTypeNodeAsReferenced(getAnnotatedAccessorTypeNode(node) || otherAccessor && getAnnotatedAccessorTypeNode(otherAccessor)); break; - case 173 /* MethodDeclaration */: + case 174 /* MethodDeclaration */: for (const parameter of node.parameters) { markDecoratorMedataDataTypeNodeAsReferenced(getParameterTypeNodeForDecoratorCheck(parameter)); } markDecoratorMedataDataTypeNodeAsReferenced(getEffectiveReturnTypeNode(node)); break; - case 171 /* PropertyDeclaration */: + case 172 /* PropertyDeclaration */: markDecoratorMedataDataTypeNodeAsReferenced(getEffectiveTypeAnnotationNode(node)); break; - case 168 /* Parameter */: + case 169 /* Parameter */: markDecoratorMedataDataTypeNodeAsReferenced(getParameterTypeNodeForDecoratorCheck(node)); const containingSignature = node.parent; for (const parameter of containingSignature.parameters) { markDecoratorMedataDataTypeNodeAsReferenced(getParameterTypeNodeForDecoratorCheck(parameter)); } + markDecoratorMedataDataTypeNodeAsReferenced(getEffectiveReturnTypeNode(containingSignature)); break; } } @@ -177450,7 +161395,7 @@ ${lanes.join("\n")} } function checkJSDocTypeAliasTag(node) { if (!node.typeExpression) { - error(node.name, Diagnostics.JSDoc_typedef_tag_should_either_have_a_type_annotation_or_be_followed_by_property_or_member_tags); + error2(node.name, Diagnostics.JSDoc_typedef_tag_should_either_have_a_type_annotation_or_be_followed_by_property_or_member_tags); } if (node.name) { checkTypeNameIsReserved(node.name, Diagnostics.Type_alias_name_cannot_be_0); @@ -177475,7 +161420,7 @@ ${lanes.join("\n")} if (length(tags) > 1) { for (let i = 1; i < length(tags); i++) { const tagName = tags[i].tagName; - error(tagName, Diagnostics._0_tag_already_specified, idText(tagName)); + error2(tagName, Diagnostics._0_tag_already_specified, idText(tagName)); } } } @@ -177504,43 +161449,49 @@ ${lanes.join("\n")} } } } + function checkJSDocThisTag(node) { + const host2 = getEffectiveJSDocHost(node); + if (host2 && isArrowFunction(host2)) { + error2(node.tagName, Diagnostics.An_arrow_function_cannot_have_a_this_parameter); + } + } function checkJSDocImplementsTag(node) { const classLike = getEffectiveJSDocHost(node); if (!classLike || !isClassDeclaration(classLike) && !isClassExpression(classLike)) { - error(classLike, Diagnostics.JSDoc_0_is_not_attached_to_a_class, idText(node.tagName)); + error2(classLike, Diagnostics.JSDoc_0_is_not_attached_to_a_class, idText(node.tagName)); } } function checkJSDocAugmentsTag(node) { const classLike = getEffectiveJSDocHost(node); if (!classLike || !isClassDeclaration(classLike) && !isClassExpression(classLike)) { - error(classLike, Diagnostics.JSDoc_0_is_not_attached_to_a_class, idText(node.tagName)); + error2(classLike, Diagnostics.JSDoc_0_is_not_attached_to_a_class, idText(node.tagName)); return; } const augmentsTags = getJSDocTags(classLike).filter(isJSDocAugmentsTag); Debug.assert(augmentsTags.length > 0); if (augmentsTags.length > 1) { - error(augmentsTags[1], Diagnostics.Class_declarations_cannot_have_more_than_one_augments_or_extends_tag); + error2(augmentsTags[1], Diagnostics.Class_declarations_cannot_have_more_than_one_augments_or_extends_tag); } const name = getIdentifierFromEntityNameExpression(node.class.expression); const extend2 = getClassExtendsHeritageElement(classLike); if (extend2) { const className = getIdentifierFromEntityNameExpression(extend2.expression); if (className && name.escapedText !== className.escapedText) { - error(name, Diagnostics.JSDoc_0_1_does_not_match_the_extends_2_clause, idText(node.tagName), idText(name), idText(className)); + error2(name, Diagnostics.JSDoc_0_1_does_not_match_the_extends_2_clause, idText(node.tagName), idText(name), idText(className)); } } } function checkJSDocAccessibilityModifiers(node) { const host2 = getJSDocHost(node); if (host2 && isPrivateIdentifierClassElementDeclaration(host2)) { - error(node, Diagnostics.An_accessibility_modifier_cannot_be_used_with_a_private_identifier); + error2(node, Diagnostics.An_accessibility_modifier_cannot_be_used_with_a_private_identifier); } } function getIdentifierFromEntityNameExpression(node) { switch (node.kind) { case 80 /* Identifier */: return node; - case 210 /* PropertyAccessExpression */: + case 211 /* PropertyAccessExpression */: return node.name; default: return void 0; @@ -177551,7 +161502,7 @@ ${lanes.join("\n")} checkDecorators(node); checkSignatureDeclaration(node); const functionFlags = getFunctionFlags(node); - if (node.name && node.name.kind === 166 /* ComputedPropertyName */) { + if (node.name && node.name.kind === 167 /* ComputedPropertyName */) { checkComputedPropertyName(node.name); } if (hasBindableName(node)) { @@ -177559,7 +161510,7 @@ ${lanes.join("\n")} const localSymbol = node.localSymbol || symbol; const firstDeclaration = (_a = localSymbol.declarations) == null ? void 0 : _a.find( // Get first non javascript function declaration - (declaration) => declaration.kind === node.kind && !(declaration.flags & 262144 /* JavaScriptFile */) + (declaration) => declaration.kind === node.kind && !(declaration.flags & 524288 /* JavaScriptFile */) ); if (node === firstDeclaration) { checkFunctionOrConstructorSymbol(localSymbol); @@ -177568,14 +161519,14 @@ ${lanes.join("\n")} checkFunctionOrConstructorSymbol(symbol); } } - const body = node.kind === 172 /* MethodSignature */ ? void 0 : node.body; + const body = node.kind === 173 /* MethodSignature */ ? void 0 : node.body; checkSourceElement(body); checkAllCodePathsInNonVoidFunctionReturnOrThrow(node, getReturnTypeFromAnnotation(node)); addLazyDiagnostic(checkFunctionOrMethodDeclarationDiagnostics); if (isInJSFile(node)) { const typeTag = getJSDocTypeTag(node); if (typeTag && typeTag.typeExpression && !getContextualCallSignature(getTypeFromTypeNode(typeTag.typeExpression), node)) { - error(typeTag.typeExpression.type, Diagnostics.The_type_of_a_function_declaration_must_match_the_function_s_signature); + error2(typeTag.typeExpression.type, Diagnostics.The_type_of_a_function_declaration_must_match_the_function_s_signature); } } function checkFunctionOrMethodDeclarationDiagnostics() { @@ -177604,42 +161555,42 @@ ${lanes.join("\n")} function checkUnusedIdentifiers(potentiallyUnusedIdentifiers, addDiagnostic) { for (const node of potentiallyUnusedIdentifiers) { switch (node.kind) { - case 262 /* ClassDeclaration */: - case 230 /* ClassExpression */: + case 263 /* ClassDeclaration */: + case 231 /* ClassExpression */: checkUnusedClassMembers(node, addDiagnostic); checkUnusedTypeParameters(node, addDiagnostic); break; - case 311 /* SourceFile */: - case 266 /* ModuleDeclaration */: - case 240 /* Block */: - case 268 /* CaseBlock */: - case 247 /* ForStatement */: - case 248 /* ForInStatement */: - case 249 /* ForOfStatement */: + case 312 /* SourceFile */: + case 267 /* ModuleDeclaration */: + case 241 /* Block */: + case 269 /* CaseBlock */: + case 248 /* ForStatement */: + case 249 /* ForInStatement */: + case 250 /* ForOfStatement */: checkUnusedLocalsAndParameters(node, addDiagnostic); break; - case 175 /* Constructor */: - case 217 /* FunctionExpression */: - case 261 /* FunctionDeclaration */: - case 218 /* ArrowFunction */: - case 173 /* MethodDeclaration */: - case 176 /* GetAccessor */: - case 177 /* SetAccessor */: + case 176 /* Constructor */: + case 218 /* FunctionExpression */: + case 262 /* FunctionDeclaration */: + case 219 /* ArrowFunction */: + case 174 /* MethodDeclaration */: + case 177 /* GetAccessor */: + case 178 /* SetAccessor */: if (node.body) { checkUnusedLocalsAndParameters(node, addDiagnostic); } checkUnusedTypeParameters(node, addDiagnostic); break; - case 172 /* MethodSignature */: - case 178 /* CallSignature */: - case 179 /* ConstructSignature */: - case 183 /* FunctionType */: - case 184 /* ConstructorType */: - case 264 /* TypeAliasDeclaration */: - case 263 /* InterfaceDeclaration */: + case 173 /* MethodSignature */: + case 179 /* CallSignature */: + case 180 /* ConstructSignature */: + case 184 /* FunctionType */: + case 185 /* ConstructorType */: + case 265 /* TypeAliasDeclaration */: + case 264 /* InterfaceDeclaration */: checkUnusedTypeParameters(node, addDiagnostic); break; - case 194 /* InferType */: + case 195 /* InferType */: checkUnusedInferTypeParameter(node, addDiagnostic); break; default: @@ -177658,28 +161609,28 @@ ${lanes.join("\n")} function checkUnusedClassMembers(node, addDiagnostic) { for (const member of node.members) { switch (member.kind) { - case 173 /* MethodDeclaration */: - case 171 /* PropertyDeclaration */: - case 176 /* GetAccessor */: - case 177 /* SetAccessor */: - if (member.kind === 177 /* SetAccessor */ && member.symbol.flags & 32768 /* GetAccessor */) { + case 174 /* MethodDeclaration */: + case 172 /* PropertyDeclaration */: + case 177 /* GetAccessor */: + case 178 /* SetAccessor */: + if (member.kind === 178 /* SetAccessor */ && member.symbol.flags & 32768 /* GetAccessor */) { break; } const symbol = getSymbolOfDeclaration(member); - if (!symbol.isReferenced && (hasEffectiveModifier(member, 8 /* Private */) || isNamedDeclaration(member) && isPrivateIdentifier(member.name)) && !(member.flags & 16777216 /* Ambient */)) { + if (!symbol.isReferenced && (hasEffectiveModifier(member, 2 /* Private */) || isNamedDeclaration(member) && isPrivateIdentifier(member.name)) && !(member.flags & 33554432 /* Ambient */)) { addDiagnostic(member, 0 /* Local */, createDiagnosticForNode(member.name, Diagnostics._0_is_declared_but_its_value_is_never_read, symbolToString(symbol))); } break; - case 175 /* Constructor */: + case 176 /* Constructor */: for (const parameter of member.parameters) { - if (!parameter.symbol.isReferenced && hasSyntacticModifier(parameter, 8 /* Private */)) { + if (!parameter.symbol.isReferenced && hasSyntacticModifier(parameter, 2 /* Private */)) { addDiagnostic(parameter, 0 /* Local */, createDiagnosticForNode(parameter.name, Diagnostics.Property_0_is_declared_but_its_value_is_never_read, symbolName(parameter.symbol))); } } break; - case 180 /* IndexSignature */: - case 239 /* SemicolonClassElement */: - case 174 /* ClassStaticBlockDeclaration */: + case 181 /* IndexSignature */: + case 240 /* SemicolonClassElement */: + case 175 /* ClassStaticBlockDeclaration */: break; default: Debug.fail("Unexpected class member"); @@ -177703,7 +161654,7 @@ ${lanes.join("\n")} continue; const name = idText(typeParameter.name); const { parent: parent2 } = typeParameter; - if (parent2.kind !== 194 /* InferType */ && parent2.typeParameters.every(isTypeParameterUnused)) { + if (parent2.kind !== 195 /* InferType */ && parent2.typeParameters.every(isTypeParameterUnused)) { if (tryAddToSet(seenParentsWithEveryUnused, parent2)) { const sourceFile = getSourceFileOfNode(parent2); const range = isJSDocTemplateTag(parent2) ? rangeOfNode(parent2) : rangeOfTypeParameters(sourceFile, parent2.typeParameters); @@ -177761,7 +161712,11 @@ ${lanes.join("\n")} addToGroup(unusedDestructures, declaration.parent, declaration, getNodeId); } } else if (isVariableDeclaration(declaration)) { - addToGroup(unusedVariables, declaration.parent, declaration, getNodeId); + const blockScopeKind = getCombinedNodeFlagsCached(declaration) & 7 /* BlockScoped */; + const name = getNameOfDeclaration(declaration); + if (blockScopeKind !== 4 /* Using */ && blockScopeKind !== 6 /* AwaitUsing */ || !name || !isIdentifierThatStartsWithUnderscore(name)) { + addToGroup(unusedVariables, declaration.parent, declaration, getNodeId); + } } else { const parameter = local.valueDeclaration && tryGetRootParameterDeclaration(local.valueDeclaration); const name = local.valueDeclaration && getNameOfDeclaration(local.valueDeclaration); @@ -177782,9 +161737,13 @@ ${lanes.join("\n")} }); unusedImports.forEach(([importClause, unuseds]) => { const importDecl = importClause.parent; - const nDeclarations = (importClause.name ? 1 : 0) + (importClause.namedBindings ? importClause.namedBindings.kind === 273 /* NamespaceImport */ ? 1 : importClause.namedBindings.elements.length : 0); + const nDeclarations = (importClause.name ? 1 : 0) + (importClause.namedBindings ? importClause.namedBindings.kind === 274 /* NamespaceImport */ ? 1 : importClause.namedBindings.elements.length : 0); if (nDeclarations === unuseds.length) { - addDiagnostic(importDecl, 0 /* Local */, unuseds.length === 1 ? createDiagnosticForNode(importDecl, Diagnostics._0_is_declared_but_its_value_is_never_read, idText(first(unuseds).name)) : createDiagnosticForNode(importDecl, Diagnostics.All_imports_in_import_declaration_are_unused)); + addDiagnostic( + importDecl, + 0 /* Local */, + unuseds.length === 1 ? createDiagnosticForNode(importDecl, Diagnostics._0_is_declared_but_its_value_is_never_read, idText(first(unuseds).name)) : createDiagnosticForNode(importDecl, Diagnostics.All_imports_in_import_declaration_are_unused) + ); } else { for (const unused of unuseds) errorUnusedLocal(unused, idText(unused.name), addDiagnostic); @@ -177793,10 +161752,14 @@ ${lanes.join("\n")} unusedDestructures.forEach(([bindingPattern, bindingElements]) => { const kind = tryGetRootParameterDeclaration(bindingPattern.parent) ? 1 /* Parameter */ : 0 /* Local */; if (bindingPattern.elements.length === bindingElements.length) { - if (bindingElements.length === 1 && bindingPattern.parent.kind === 259 /* VariableDeclaration */ && bindingPattern.parent.parent.kind === 260 /* VariableDeclarationList */) { + if (bindingElements.length === 1 && bindingPattern.parent.kind === 260 /* VariableDeclaration */ && bindingPattern.parent.parent.kind === 261 /* VariableDeclarationList */) { addToGroup(unusedVariables, bindingPattern.parent.parent, bindingPattern.parent, getNodeId); } else { - addDiagnostic(bindingPattern, kind, bindingElements.length === 1 ? createDiagnosticForNode(bindingPattern, Diagnostics._0_is_declared_but_its_value_is_never_read, bindingNameText(first(bindingElements).name)) : createDiagnosticForNode(bindingPattern, Diagnostics.All_destructured_elements_are_unused)); + addDiagnostic( + bindingPattern, + kind, + bindingElements.length === 1 ? createDiagnosticForNode(bindingPattern, Diagnostics._0_is_declared_but_its_value_is_never_read, bindingNameText(first(bindingElements).name)) : createDiagnosticForNode(bindingPattern, Diagnostics.All_destructured_elements_are_unused) + ); } } else { for (const e of bindingElements) { @@ -177806,7 +161769,11 @@ ${lanes.join("\n")} }); unusedVariables.forEach(([declarationList, declarations]) => { if (declarationList.declarations.length === declarations.length) { - addDiagnostic(declarationList, 0 /* Local */, declarations.length === 1 ? createDiagnosticForNode(first(declarations).name, Diagnostics._0_is_declared_but_its_value_is_never_read, bindingNameText(first(declarations).name)) : createDiagnosticForNode(declarationList.parent.kind === 242 /* VariableStatement */ ? declarationList.parent : declarationList, Diagnostics.All_variables_are_unused)); + addDiagnostic( + declarationList, + 0 /* Local */, + declarations.length === 1 ? createDiagnosticForNode(first(declarations).name, Diagnostics._0_is_declared_but_its_value_is_never_read, bindingNameText(first(declarations).name)) : createDiagnosticForNode(declarationList.parent.kind === 243 /* VariableStatement */ ? declarationList.parent : declarationList, Diagnostics.All_variables_are_unused) + ); } else { for (const decl of declarations) { addDiagnostic(decl, 0 /* Local */, createDiagnosticForNode(decl, Diagnostics._0_is_declared_but_its_value_is_never_read, bindingNameText(decl.name))); @@ -177835,21 +161802,21 @@ ${lanes.join("\n")} switch (name.kind) { case 80 /* Identifier */: return idText(name); - case 206 /* ArrayBindingPattern */: - case 205 /* ObjectBindingPattern */: + case 207 /* ArrayBindingPattern */: + case 206 /* ObjectBindingPattern */: return bindingNameText(cast(first(name.elements), isBindingElement).name); default: return Debug.assertNever(name); } } function isImportedDeclaration(node) { - return node.kind === 272 /* ImportClause */ || node.kind === 275 /* ImportSpecifier */ || node.kind === 273 /* NamespaceImport */; + return node.kind === 273 /* ImportClause */ || node.kind === 276 /* ImportSpecifier */ || node.kind === 274 /* NamespaceImport */; } function importClauseFromImported(decl) { - return decl.kind === 272 /* ImportClause */ ? decl : decl.kind === 273 /* NamespaceImport */ ? decl.parent : decl.parent.parent; + return decl.kind === 273 /* ImportClause */ ? decl : decl.kind === 274 /* NamespaceImport */ ? decl.parent : decl.parent.parent; } function checkBlock(node) { - if (node.kind === 240 /* Block */) { + if (node.kind === 241 /* Block */) { checkGrammarStatementInAmbientContext(node); } if (isFunctionOrModuleBlock(node)) { @@ -177864,7 +161831,7 @@ ${lanes.join("\n")} } } function checkCollisionWithArgumentsInGeneratedCode(node) { - if (languageVersion >= 2 /* ES2015 */ || !hasRestParameter(node) || node.flags & 16777216 /* Ambient */ || nodeIsMissing(node.body)) { + if (languageVersion >= 2 /* ES2015 */ || !hasRestParameter(node) || node.flags & 33554432 /* Ambient */ || nodeIsMissing(node.body)) { return; } forEach(node.parameters, (p) => { @@ -177877,10 +161844,10 @@ ${lanes.join("\n")} if ((identifier == null ? void 0 : identifier.escapedText) !== name) { return false; } - if (node.kind === 171 /* PropertyDeclaration */ || node.kind === 170 /* PropertySignature */ || node.kind === 173 /* MethodDeclaration */ || node.kind === 172 /* MethodSignature */ || node.kind === 176 /* GetAccessor */ || node.kind === 177 /* SetAccessor */ || node.kind === 302 /* PropertyAssignment */) { + if (node.kind === 172 /* PropertyDeclaration */ || node.kind === 171 /* PropertySignature */ || node.kind === 174 /* MethodDeclaration */ || node.kind === 173 /* MethodSignature */ || node.kind === 177 /* GetAccessor */ || node.kind === 178 /* SetAccessor */ || node.kind === 303 /* PropertyAssignment */) { return false; } - if (node.flags & 16777216 /* Ambient */) { + if (node.flags & 33554432 /* Ambient */) { return false; } if (isImportClause(node) || isImportEqualsDeclaration(node) || isImportSpecifier(node)) { @@ -177899,9 +161866,9 @@ ${lanes.join("\n")} if (getNodeCheckFlags(current) & 4 /* CaptureThis */) { const isDeclaration2 = node.kind !== 80 /* Identifier */; if (isDeclaration2) { - error(getNameOfDeclaration(node), Diagnostics.Duplicate_identifier_this_Compiler_uses_variable_declaration_this_to_capture_this_reference); + error2(getNameOfDeclaration(node), Diagnostics.Duplicate_identifier_this_Compiler_uses_variable_declaration_this_to_capture_this_reference); } else { - error(node, Diagnostics.Expression_resolves_to_variable_declaration_this_that_compiler_uses_to_capture_this_reference); + error2(node, Diagnostics.Expression_resolves_to_variable_declaration_this_that_compiler_uses_to_capture_this_reference); } return true; } @@ -177913,9 +161880,9 @@ ${lanes.join("\n")} if (getNodeCheckFlags(current) & 8 /* CaptureNewTarget */) { const isDeclaration2 = node.kind !== 80 /* Identifier */; if (isDeclaration2) { - error(getNameOfDeclaration(node), Diagnostics.Duplicate_identifier_newTarget_Compiler_uses_variable_declaration_newTarget_to_capture_new_target_meta_property_reference); + error2(getNameOfDeclaration(node), Diagnostics.Duplicate_identifier_newTarget_Compiler_uses_variable_declaration_newTarget_to_capture_new_target_meta_property_reference); } else { - error(node, Diagnostics.Expression_resolves_to_variable_declaration_newTarget_that_compiler_uses_to_capture_new_target_meta_property_reference); + error2(node, Diagnostics.Expression_resolves_to_variable_declaration_newTarget_that_compiler_uses_to_capture_new_target_meta_property_reference); } return true; } @@ -177933,14 +161900,8 @@ ${lanes.join("\n")} return; } const parent2 = getDeclarationContainer(node); - if (parent2.kind === 311 /* SourceFile */ && isExternalOrCommonJsModule(parent2)) { - errorSkippedOn( - "noEmit", - name, - Diagnostics.Duplicate_identifier_0_Compiler_reserves_name_1_in_top_level_scope_of_a_module, - declarationNameToString(name), - declarationNameToString(name) - ); + if (parent2.kind === 312 /* SourceFile */ && isExternalOrCommonJsModule(parent2)) { + errorSkippedOn("noEmit", name, Diagnostics.Duplicate_identifier_0_Compiler_reserves_name_1_in_top_level_scope_of_a_module, declarationNameToString(name), declarationNameToString(name)); } } function checkCollisionWithGlobalPromiseInGeneratedCode(node, name) { @@ -177951,14 +161912,8 @@ ${lanes.join("\n")} return; } const parent2 = getDeclarationContainer(node); - if (parent2.kind === 311 /* SourceFile */ && isExternalOrCommonJsModule(parent2) && parent2.flags & 2048 /* HasAsyncFunctions */) { - errorSkippedOn( - "noEmit", - name, - Diagnostics.Duplicate_identifier_0_Compiler_reserves_name_1_in_top_level_scope_of_a_module_containing_async_functions, - declarationNameToString(name), - declarationNameToString(name) - ); + if (parent2.kind === 312 /* SourceFile */ && isExternalOrCommonJsModule(parent2) && parent2.flags & 4096 /* HasAsyncFunctions */) { + errorSkippedOn("noEmit", name, Diagnostics.Duplicate_identifier_0_Compiler_reserves_name_1_in_top_level_scope_of_a_module_containing_async_functions, declarationNameToString(name), declarationNameToString(name)); } } function recordPotentialCollisionWithWeakMapSetInGeneratedCode(node, name) { @@ -177968,7 +161923,7 @@ ${lanes.join("\n")} } function checkWeakMapSetCollision(node) { const enclosingBlockScope = getEnclosingBlockScopeContainer(node); - if (getNodeCheckFlags(enclosingBlockScope) & 4194304 /* ContainsClassWithPrivateIdentifiers */) { + if (getNodeCheckFlags(enclosingBlockScope) & 1048576 /* ContainsClassWithPrivateIdentifiers */) { Debug.assert(isNamedDeclaration(node) && isIdentifier(node.name) && typeof node.name.escapedText === "string", "The target of a WeakMap/WeakSet collision check should be an identifier"); errorSkippedOn("noEmit", node, Diagnostics.Compiler_reserves_name_0_when_emitting_private_identifier_downlevel, node.name.escapedText); } @@ -177982,30 +161937,24 @@ ${lanes.join("\n")} let hasCollision = false; if (isClassExpression(node)) { for (const member of node.members) { - if (getNodeCheckFlags(member) & 8388608 /* ContainsSuperPropertyInStaticInitializer */) { + if (getNodeCheckFlags(member) & 2097152 /* ContainsSuperPropertyInStaticInitializer */) { hasCollision = true; break; } } } else if (isFunctionExpression(node)) { - if (getNodeCheckFlags(node) & 8388608 /* ContainsSuperPropertyInStaticInitializer */) { + if (getNodeCheckFlags(node) & 2097152 /* ContainsSuperPropertyInStaticInitializer */) { hasCollision = true; } } else { const container = getEnclosingBlockScopeContainer(node); - if (container && getNodeCheckFlags(container) & 8388608 /* ContainsSuperPropertyInStaticInitializer */) { + if (container && getNodeCheckFlags(container) & 2097152 /* ContainsSuperPropertyInStaticInitializer */) { hasCollision = true; } } if (hasCollision) { Debug.assert(isNamedDeclaration(node) && isIdentifier(node.name), "The target of a Reflect collision check should be an identifier"); - errorSkippedOn( - "noEmit", - node, - Diagnostics.Duplicate_identifier_0_Compiler_reserves_name_1_when_emitting_super_references_in_static_initializers, - declarationNameToString(node.name), - "Reflect" - ); + errorSkippedOn("noEmit", node, Diagnostics.Duplicate_identifier_0_Compiler_reserves_name_1_when_emitting_super_references_in_static_initializers, declarationNameToString(node.name), "Reflect"); } } function checkCollisionsForDeclarationName(node, name) { @@ -178017,7 +161966,7 @@ ${lanes.join("\n")} recordPotentialCollisionWithReflectInGeneratedCode(node, name); if (isClassLike(node)) { checkTypeNameIsReserved(name, Diagnostics.Class_name_cannot_be_0); - if (!(node.flags & 16777216 /* Ambient */)) { + if (!(node.flags & 33554432 /* Ambient */)) { checkClassNameCollisionWithObject(name); } } else if (isEnumDeclaration(node)) { @@ -178025,10 +161974,7 @@ ${lanes.join("\n")} } } function checkVarDeclaredNamesNotShadowed(node) { - if ((getCombinedNodeFlags(node) & 3 /* BlockScoped */) !== 0 || isParameterDeclaration(node)) { - return; - } - if (node.kind === 259 /* VariableDeclaration */ && !node.initializer) { + if ((getCombinedNodeFlagsCached(node) & 7 /* BlockScoped */) !== 0 || isParameterDeclaration(node)) { return; } const symbol = getSymbolOfDeclaration(node); @@ -178047,13 +161993,13 @@ ${lanes.join("\n")} false ); if (localDeclarationSymbol && localDeclarationSymbol !== symbol && localDeclarationSymbol.flags & 2 /* BlockScopedVariable */) { - if (getDeclarationNodeFlagsFromSymbol(localDeclarationSymbol) & 3 /* BlockScoped */) { - const varDeclList = getAncestor(localDeclarationSymbol.valueDeclaration, 260 /* VariableDeclarationList */); - const container = varDeclList.parent.kind === 242 /* VariableStatement */ && varDeclList.parent.parent ? varDeclList.parent.parent : void 0; - const namesShareScope = container && (container.kind === 240 /* Block */ && isFunctionLike(container.parent) || container.kind === 267 /* ModuleBlock */ || container.kind === 266 /* ModuleDeclaration */ || container.kind === 311 /* SourceFile */); + if (getDeclarationNodeFlagsFromSymbol(localDeclarationSymbol) & 7 /* BlockScoped */) { + const varDeclList = getAncestor(localDeclarationSymbol.valueDeclaration, 261 /* VariableDeclarationList */); + const container = varDeclList.parent.kind === 243 /* VariableStatement */ && varDeclList.parent.parent ? varDeclList.parent.parent : void 0; + const namesShareScope = container && (container.kind === 241 /* Block */ && isFunctionLike(container.parent) || container.kind === 268 /* ModuleBlock */ || container.kind === 267 /* ModuleDeclaration */ || container.kind === 312 /* SourceFile */); if (!namesShareScope) { const name = symbolToString(localDeclarationSymbol); - error(node, Diagnostics.Cannot_initialize_outer_scoped_variable_0_in_the_same_scope_as_block_scoped_declaration_1, name, name); + error2(node, Diagnostics.Cannot_initialize_outer_scoped_variable_0_in_the_same_scope_as_block_scoped_declaration_1, name, name); } } } @@ -178071,7 +162017,7 @@ ${lanes.join("\n")} if (!node.name) { return; } - if (node.name.kind === 166 /* ComputedPropertyName */) { + if (node.name.kind === 167 /* ComputedPropertyName */) { checkComputedPropertyName(node.name); if (hasOnlyExpressionInitializer(node) && node.initializer) { checkExpressionCached(node.initializer); @@ -178085,11 +162031,11 @@ ${lanes.join("\n")} if (isObjectBindingPattern(node.parent) && node.dotDotDotToken && languageVersion < 5 /* ES2018 */) { checkExternalEmitHelpers(node, 4 /* Rest */); } - if (node.propertyName && node.propertyName.kind === 166 /* ComputedPropertyName */) { + if (node.propertyName && node.propertyName.kind === 167 /* ComputedPropertyName */) { checkComputedPropertyName(node.propertyName); } const parent2 = node.parent.parent; - const parentCheckMode = node.dotDotDotToken ? 64 /* RestBindingElement */ : 0 /* Normal */; + const parentCheckMode = node.dotDotDotToken ? 32 /* RestBindingElement */ : 0 /* Normal */; const parentType = getTypeForBindingElementParent(parent2, parentCheckMode); const name = node.propertyName || node.name; if (parentType && !isBindingPattern(name)) { @@ -178118,20 +162064,20 @@ ${lanes.join("\n")} } } if (isBindingPattern(node.name)) { - if (node.name.kind === 206 /* ArrayBindingPattern */ && languageVersion < 2 /* ES2015 */ && compilerOptions.downlevelIteration) { + if (node.name.kind === 207 /* ArrayBindingPattern */ && languageVersion < 2 /* ES2015 */ && compilerOptions.downlevelIteration) { checkExternalEmitHelpers(node, 512 /* Read */); } forEach(node.name.elements, checkSourceElement); } - if (isParameter(node) && node.initializer && nodeIsMissing(getContainingFunction(node).body)) { - error(node, Diagnostics.A_parameter_initializer_is_only_allowed_in_a_function_or_constructor_implementation); + if (node.initializer && isParameterDeclaration(node) && nodeIsMissing(getContainingFunction(node).body)) { + error2(node, Diagnostics.A_parameter_initializer_is_only_allowed_in_a_function_or_constructor_implementation); return; } if (isBindingPattern(node.name)) { if (isInAmbientOrTypeNode(node)) { return; } - const needCheckInitializer = hasOnlyExpressionInitializer(node) && node.initializer && node.parent.parent.kind !== 248 /* ForInStatement */; + const needCheckInitializer = hasOnlyExpressionInitializer(node) && node.initializer && node.parent.parent.kind !== 249 /* ForInStatement */; const needCheckWidenedType = !some(node.name.elements, not(isOmittedExpression)); if (needCheckInitializer || needCheckWidenedType) { const widenedType = getWidenedTypeForVariableLikeDeclaration(node); @@ -178163,20 +162109,45 @@ ${lanes.join("\n")} const initializer = hasOnlyExpressionInitializer(node) && getEffectiveInitializer(node); if (initializer) { const isJSObjectLiteralInitializer = isInJSFile(node) && isObjectLiteralExpression(initializer) && (initializer.properties.length === 0 || isPrototypeAccess(node.name)) && !!((_a = symbol.exports) == null ? void 0 : _a.size); - if (!isJSObjectLiteralInitializer && node.parent.parent.kind !== 248 /* ForInStatement */) { + if (!isJSObjectLiteralInitializer && node.parent.parent.kind !== 249 /* ForInStatement */) { + const initializerType = checkExpressionCached(initializer); checkTypeAssignableToAndOptionallyElaborate( - checkExpressionCached(initializer), + initializerType, type, node, initializer, /*headMessage*/ void 0 ); + const blockScopeKind = getCombinedNodeFlagsCached(node) & 7 /* BlockScoped */; + if (blockScopeKind === 6 /* AwaitUsing */) { + const globalAsyncDisposableType = getGlobalAsyncDisposableType( + /*reportErrors*/ + true + ); + const globalDisposableType = getGlobalDisposableType( + /*reportErrors*/ + true + ); + if (globalAsyncDisposableType !== emptyObjectType && globalDisposableType !== emptyObjectType) { + const optionalDisposableType = getUnionType([globalAsyncDisposableType, globalDisposableType, nullType, undefinedType]); + checkTypeAssignableTo(initializerType, optionalDisposableType, initializer, Diagnostics.The_initializer_of_an_await_using_declaration_must_be_either_an_object_with_a_Symbol_asyncDispose_or_Symbol_dispose_method_or_be_null_or_undefined); + } + } else if (blockScopeKind === 4 /* Using */) { + const globalDisposableType = getGlobalDisposableType( + /*reportErrors*/ + true + ); + if (globalDisposableType !== emptyObjectType) { + const optionalDisposableType = getUnionType([globalDisposableType, nullType, undefinedType]); + checkTypeAssignableTo(initializerType, optionalDisposableType, initializer, Diagnostics.The_initializer_of_a_using_declaration_must_be_either_an_object_with_a_Symbol_dispose_method_or_be_null_or_undefined); + } + } } } if (symbol.declarations && symbol.declarations.length > 1) { if (some(symbol.declarations, (d) => d !== node && isVariableLike(d) && !areDeclarationFlagsIdentical(d, node))) { - error(node.name, Diagnostics.All_declarations_of_0_must_have_identical_modifiers, declarationNameToString(node.name)); + error2(node.name, Diagnostics.All_declarations_of_0_must_have_identical_modifiers, declarationNameToString(node.name)); } } } else { @@ -178195,12 +162166,12 @@ ${lanes.join("\n")} ); } if (symbol.valueDeclaration && !areDeclarationFlagsIdentical(node, symbol.valueDeclaration)) { - error(node.name, Diagnostics.All_declarations_of_0_must_have_identical_modifiers, declarationNameToString(node.name)); + error2(node.name, Diagnostics.All_declarations_of_0_must_have_identical_modifiers, declarationNameToString(node.name)); } } - if (node.kind !== 171 /* PropertyDeclaration */ && node.kind !== 170 /* PropertySignature */) { + if (node.kind !== 172 /* PropertyDeclaration */ && node.kind !== 171 /* PropertySignature */) { checkExportsOnMergedDeclarations(node); - if (node.kind === 259 /* VariableDeclaration */ || node.kind === 207 /* BindingElement */) { + if (node.kind === 260 /* VariableDeclaration */ || node.kind === 208 /* BindingElement */) { checkVarDeclaredNamesNotShadowed(node); } checkCollisionsForDeclarationName(node, node.name); @@ -178208,9 +162179,9 @@ ${lanes.join("\n")} } function errorNextVariableOrPropertyDeclarationMustHaveSameType(firstDeclaration, firstType, nextDeclaration, nextType) { const nextDeclarationName = getNameOfDeclaration(nextDeclaration); - const message = nextDeclaration.kind === 171 /* PropertyDeclaration */ || nextDeclaration.kind === 170 /* PropertySignature */ ? Diagnostics.Subsequent_property_declarations_must_have_the_same_type_Property_0_must_be_of_type_1_but_here_has_type_2 : Diagnostics.Subsequent_variable_declarations_must_have_the_same_type_Variable_0_must_be_of_type_1_but_here_has_type_2; + const message = nextDeclaration.kind === 172 /* PropertyDeclaration */ || nextDeclaration.kind === 171 /* PropertySignature */ ? Diagnostics.Subsequent_property_declarations_must_have_the_same_type_Property_0_must_be_of_type_1_but_here_has_type_2 : Diagnostics.Subsequent_variable_declarations_must_have_the_same_type_Variable_0_must_be_of_type_1_but_here_has_type_2; const declName = declarationNameToString(nextDeclarationName); - const err = error( + const err = error2( nextDeclarationName, message, declName, @@ -178218,20 +162189,17 @@ ${lanes.join("\n")} typeToString(nextType) ); if (firstDeclaration) { - addRelatedInfo( - err, - createDiagnosticForNode(firstDeclaration, Diagnostics._0_was_also_declared_here, declName) - ); + addRelatedInfo(err, createDiagnosticForNode(firstDeclaration, Diagnostics._0_was_also_declared_here, declName)); } } function areDeclarationFlagsIdentical(left, right) { - if (left.kind === 168 /* Parameter */ && right.kind === 259 /* VariableDeclaration */ || left.kind === 259 /* VariableDeclaration */ && right.kind === 168 /* Parameter */) { + if (left.kind === 169 /* Parameter */ && right.kind === 260 /* VariableDeclaration */ || left.kind === 260 /* VariableDeclaration */ && right.kind === 169 /* Parameter */) { return true; } if (hasQuestionToken(left) !== hasQuestionToken(right)) { return false; } - const interestingFlags = 8 /* Private */ | 16 /* Protected */ | 512 /* Async */ | 256 /* Abstract */ | 64 /* Readonly */ | 32 /* Static */; + const interestingFlags = 2 /* Private */ | 4 /* Protected */ | 1024 /* Async */ | 64 /* Abstract */ | 8 /* Readonly */ | 256 /* Static */; return getSelectedEffectiveModifierFlags(left, interestingFlags) === getSelectedEffectiveModifierFlags(right, interestingFlags); } function checkVariableDeclaration(node) { @@ -178245,10 +162213,17 @@ ${lanes.join("\n")} checkGrammarBindingElement(node); return checkVariableLikeDeclaration(node); } + function checkVariableDeclarationList(node) { + const blockScopeKind = getCombinedNodeFlags(node) & 7 /* BlockScoped */; + if (blockScopeKind === 4 /* Using */ || blockScopeKind === 6 /* AwaitUsing */) { + checkExternalEmitHelpers(node, 33554432 /* AddDisposableResourceAndDisposeResources */); + } + forEach(node.declarations, checkSourceElement); + } function checkVariableStatement(node) { if (!checkGrammarModifiers(node) && !checkGrammarVariableDeclarationList(node.declarationList)) - checkGrammarForDisallowedLetOrConstStatement(node); - forEach(node.declarationList.declarations, checkSourceElement); + checkGrammarForDisallowedBlockScopedVariableStatement(node); + checkVariableDeclarationList(node.declarationList); } function checkExpressionStatement(node) { checkGrammarStatementInAmbientContext(node); @@ -178259,8 +162234,8 @@ ${lanes.join("\n")} const type = checkTruthinessExpression(node.expression); checkTestingKnownTruthyCallableOrAwaitableType(node.expression, type, node.thenStatement); checkSourceElement(node.thenStatement); - if (node.thenStatement.kind === 241 /* EmptyStatement */) { - error(node.thenStatement, Diagnostics.The_body_of_an_if_statement_cannot_be_the_empty_statement); + if (node.thenStatement.kind === 242 /* EmptyStatement */) { + error2(node.thenStatement, Diagnostics.The_body_of_an_if_statement_cannot_be_the_empty_statement); } checkSourceElement(node.elseStatement); } @@ -178287,7 +162262,7 @@ ${lanes.join("\n")} } const type = location === condExpr2 ? condType : checkTruthinessExpression(location); const isPropertyExpressionCast = isPropertyAccessExpression(location) && isTypeAssertion(location.expression); - if (!(getTypeFacts(type) & 4194304 /* Truthy */) || isPropertyExpressionCast) + if (!hasTypeFacts(type, 4194304 /* Truthy */) || isPropertyExpressionCast) return; const callSignatures = getSignaturesOfType(type, 0 /* Call */); const isPromise = !!getAwaitedTypeOfPromise(type); @@ -178310,7 +162285,7 @@ ${lanes.join("\n")} getTypeNameForErrorDisplay(type) ); } else { - error(location, Diagnostics.This_condition_will_always_return_true_since_this_function_is_always_defined_Did_you_mean_to_call_it_instead); + error2(location, Diagnostics.This_condition_will_always_return_true_since_this_function_is_always_defined_Did_you_mean_to_call_it_instead); } } } @@ -178376,7 +162351,7 @@ ${lanes.join("\n")} } function checkTruthinessOfType(type, node) { if (type.flags & 16384 /* Void */) { - error(node, Diagnostics.An_expression_of_type_void_cannot_be_tested_for_truthiness); + error2(node, Diagnostics.An_expression_of_type_void_cannot_be_tested_for_truthiness); } return type; } @@ -178385,13 +162360,13 @@ ${lanes.join("\n")} } function checkForStatement(node) { if (!checkGrammarStatementInAmbientContext(node)) { - if (node.initializer && node.initializer.kind === 260 /* VariableDeclarationList */) { + if (node.initializer && node.initializer.kind === 261 /* VariableDeclarationList */) { checkGrammarVariableDeclarationList(node.initializer); } } if (node.initializer) { - if (node.initializer.kind === 260 /* VariableDeclarationList */) { - forEach(node.initializer.declarations, checkVariableDeclaration); + if (node.initializer.kind === 261 /* VariableDeclarationList */) { + checkVariableDeclarationList(node.initializer); } else { checkExpression(node.initializer); } @@ -178410,7 +162385,7 @@ ${lanes.join("\n")} const container = getContainingFunctionOrClassStaticBlock(node); if (node.awaitModifier) { if (container && isClassStaticBlockDeclaration(container)) { - grammarErrorOnNode(node.awaitModifier, Diagnostics.For_await_loops_cannot_be_used_inside_a_class_static_block); + grammarErrorOnNode(node.awaitModifier, Diagnostics.for_await_loops_cannot_be_used_inside_a_class_static_block); } else { const functionFlags = getFunctionFlags(container); if ((functionFlags & (4 /* Invalid */ | 2 /* Async */)) === 2 /* Async */ && languageVersion < 99 /* ESNext */) { @@ -178420,12 +162395,12 @@ ${lanes.join("\n")} } else if (compilerOptions.downlevelIteration && languageVersion < 2 /* ES2015 */) { checkExternalEmitHelpers(node, 256 /* ForOfIncludes */); } - if (node.initializer.kind === 260 /* VariableDeclarationList */) { - checkForInOrForOfVariableDeclaration(node); + if (node.initializer.kind === 261 /* VariableDeclarationList */) { + checkVariableDeclarationList(node.initializer); } else { const varExpr = node.initializer; const iteratedType = checkRightHandSideOfForOf(node); - if (varExpr.kind === 208 /* ArrayLiteralExpression */ || varExpr.kind === 209 /* ObjectLiteralExpression */) { + if (varExpr.kind === 209 /* ArrayLiteralExpression */ || varExpr.kind === 210 /* ObjectLiteralExpression */) { checkDestructuringAssignment(varExpr, iteratedType || errorType); } else { const leftType = checkExpression(varExpr); @@ -178447,19 +162422,19 @@ ${lanes.join("\n")} function checkForInStatement(node) { checkGrammarForInOrForOfStatement(node); const rightType = getNonNullableTypeIfNeeded(checkExpression(node.expression)); - if (node.initializer.kind === 260 /* VariableDeclarationList */) { + if (node.initializer.kind === 261 /* VariableDeclarationList */) { const variable = node.initializer.declarations[0]; if (variable && isBindingPattern(variable.name)) { - error(variable.name, Diagnostics.The_left_hand_side_of_a_for_in_statement_cannot_be_a_destructuring_pattern); + error2(variable.name, Diagnostics.The_left_hand_side_of_a_for_in_statement_cannot_be_a_destructuring_pattern); } - checkForInOrForOfVariableDeclaration(node); + checkVariableDeclarationList(node.initializer); } else { const varExpr = node.initializer; const leftType = checkExpression(varExpr); - if (varExpr.kind === 208 /* ArrayLiteralExpression */ || varExpr.kind === 209 /* ObjectLiteralExpression */) { - error(varExpr, Diagnostics.The_left_hand_side_of_a_for_in_statement_cannot_be_a_destructuring_pattern); + if (varExpr.kind === 209 /* ArrayLiteralExpression */ || varExpr.kind === 210 /* ObjectLiteralExpression */) { + error2(varExpr, Diagnostics.The_left_hand_side_of_a_for_in_statement_cannot_be_a_destructuring_pattern); } else if (!isTypeAssignableTo(getIndexTypeOrString(rightType), leftType)) { - error(varExpr, Diagnostics.The_left_hand_side_of_a_for_in_statement_must_be_of_type_string_or_any); + error2(varExpr, Diagnostics.The_left_hand_side_of_a_for_in_statement_must_be_of_type_string_or_any); } else { checkReferenceExpression( varExpr, @@ -178469,20 +162444,13 @@ ${lanes.join("\n")} } } if (rightType === neverType || !isTypeAssignableToKind(rightType, 67108864 /* NonPrimitive */ | 58982400 /* InstantiableNonPrimitive */)) { - error(node.expression, Diagnostics.The_right_hand_side_of_a_for_in_statement_must_be_of_type_any_an_object_type_or_a_type_parameter_but_here_has_type_0, typeToString(rightType)); + error2(node.expression, Diagnostics.The_right_hand_side_of_a_for_in_statement_must_be_of_type_any_an_object_type_or_a_type_parameter_but_here_has_type_0, typeToString(rightType)); } checkSourceElement(node.statement); if (node.locals) { registerForUnusedIdentifiersCheck(node); } } - function checkForInOrForOfVariableDeclaration(iterationStatement) { - const variableDeclarationList = iterationStatement.initializer; - if (variableDeclarationList.declarations.length >= 1) { - const decl = variableDeclarationList.declarations[0]; - checkVariableDeclaration(decl); - } - } function checkRightHandSideOfForOf(statement) { const use = statement.awaitModifier ? 15 /* ForAwaitOf */ : 13 /* ForOf */; return checkIteratedTypeOrElementType(use, checkNonNullExpression(statement.expression), undefinedType, statement.expression); @@ -178540,7 +162508,7 @@ ${lanes.join("\n")} if (hasStringConstituent) { if (languageVersion < 1 /* ES5 */) { if (errorNode) { - error(errorNode, Diagnostics.Using_a_string_in_a_for_of_statement_is_only_supported_in_ECMAScript_5_and_higher); + error2(errorNode, Diagnostics.Using_a_string_in_a_for_of_statement_is_only_supported_in_ECMAScript_5_and_higher); reportedError = true; } } @@ -178858,13 +162826,10 @@ ${lanes.join("\n")} !!getAwaitedTypeOfPromise(type) || !allowAsyncIterables && isForOfStatement(errorNode.parent) && errorNode.parent.expression === errorNode && getGlobalAsyncIterableType( /*reportErrors*/ false - ) !== emptyGenericType && isTypeAssignableTo( - type, - getGlobalAsyncIterableType( - /*reportErrors*/ - false - ) - ) + ) !== emptyGenericType && isTypeAssignableTo(type, getGlobalAsyncIterableType( + /*reportErrors*/ + false + )) ); return errorAndMaybeSuggestAwait(errorNode, suggestAwait, message, typeToString(type)); } @@ -179000,7 +162965,7 @@ ${lanes.join("\n")} errorOutputContainer.errors ?? (errorOutputContainer.errors = []); errorOutputContainer.errors.push(createDiagnosticForNode(errorNode, diagnostic, methodName)); } else { - error(errorNode, diagnostic, methodName); + error2(errorNode, diagnostic, methodName); } } return methodName === "next" ? noIterationTypes : void 0; @@ -179055,7 +163020,7 @@ ${lanes.join("\n")} errorOutputContainer.errors ?? (errorOutputContainer.errors = []); errorOutputContainer.errors.push(createDiagnosticForNode(errorNode, resolver.mustHaveAValueDiagnostic, methodName)); } else { - error(errorNode, resolver.mustHaveAValueDiagnostic, methodName); + error2(errorNode, resolver.mustHaveAValueDiagnostic, methodName); } } yieldType = anyType; @@ -179139,13 +163104,13 @@ ${lanes.join("\n")} const functionFlags = getFunctionFlags(container); if (strictNullChecks || node.expression || returnType.flags & 131072 /* Never */) { const exprType = node.expression ? checkExpressionCached(node.expression) : undefinedType; - if (container.kind === 177 /* SetAccessor */) { + if (container.kind === 178 /* SetAccessor */) { if (node.expression) { - error(node, Diagnostics.Setters_cannot_return_a_value); + error2(node, Diagnostics.Setters_cannot_return_a_value); } - } else if (container.kind === 175 /* Constructor */) { + } else if (container.kind === 176 /* Constructor */) { if (node.expression && !checkTypeAssignableToAndOptionallyElaborate(exprType, returnType, node, node.expression)) { - error(node, Diagnostics.Return_type_of_constructor_signature_must_be_assignable_to_the_instance_type_of_the_class); + error2(node, Diagnostics.Return_type_of_constructor_signature_must_be_assignable_to_the_instance_type_of_the_class); } } else if (getReturnTypeFromAnnotation(container)) { const unwrappedReturnType = unwrapReturnType(returnType, functionFlags) ?? returnType; @@ -179160,13 +163125,13 @@ ${lanes.join("\n")} checkTypeAssignableToAndOptionallyElaborate(unwrappedExprType, unwrappedReturnType, node, node.expression); } } - } else if (container.kind !== 175 /* Constructor */ && compilerOptions.noImplicitReturns && !isUnwrappedReturnTypeUndefinedVoidOrAny(container, returnType)) { - error(node, Diagnostics.Not_all_code_paths_return_a_value); + } else if (container.kind !== 176 /* Constructor */ && compilerOptions.noImplicitReturns && !isUnwrappedReturnTypeUndefinedVoidOrAny(container, returnType)) { + error2(node, Diagnostics.Not_all_code_paths_return_a_value); } } function checkWithStatement(node) { if (!checkGrammarStatementInAmbientContext(node)) { - if (node.flags & 32768 /* AwaitContext */) { + if (node.flags & 65536 /* AwaitContext */) { grammarErrorOnFirstToken(node, Diagnostics.with_statements_are_not_allowed_in_an_async_function_block); } } @@ -179184,7 +163149,7 @@ ${lanes.join("\n")} let hasDuplicateDefaultClause = false; const expressionType = checkExpression(node.expression); forEach(node.caseBlock.clauses, (clause) => { - if (clause.kind === 296 /* DefaultClause */ && !hasDuplicateDefaultClause) { + if (clause.kind === 297 /* DefaultClause */ && !hasDuplicateDefaultClause) { if (firstDefaultClause === void 0) { firstDefaultClause = clause; } else { @@ -179192,12 +163157,12 @@ ${lanes.join("\n")} hasDuplicateDefaultClause = true; } } - if (clause.kind === 295 /* CaseClause */) { + if (clause.kind === 296 /* CaseClause */) { addLazyDiagnostic(createLazyCaseClauseDiagnostics(clause)); } forEach(clause.statements, checkSourceElement); if (compilerOptions.noFallthroughCasesInSwitch && clause.fallthroughFlowNode && isReachableFlowNode(clause.fallthroughFlowNode)) { - error(clause, Diagnostics.Fallthrough_case_in_switch); + error2(clause, Diagnostics.Fallthrough_case_in_switch); } function createLazyCaseClauseDiagnostics(clause2) { return () => { @@ -179224,7 +163189,7 @@ ${lanes.join("\n")} if (isFunctionLike(current)) { return "quit"; } - if (current.kind === 255 /* LabeledStatement */ && current.label.escapedText === node.label.escapedText) { + if (current.kind === 256 /* LabeledStatement */ && current.label.escapedText === node.label.escapedText) { grammarErrorOnNode(node.label, Diagnostics.Duplicate_label_0, getTextOfNode(node.label)); return true; } @@ -179314,21 +163279,14 @@ ${lanes.join("\n")} return; } const indexInfos = getApplicableIndexInfos(type, propNameType); - const interfaceDeclaration = getObjectFlags(type) & 2 /* Interface */ ? getDeclarationOfKind(type.symbol, 263 /* InterfaceDeclaration */) : void 0; - const propDeclaration = declaration && declaration.kind === 225 /* BinaryExpression */ || name && name.kind === 166 /* ComputedPropertyName */ ? declaration : void 0; + const interfaceDeclaration = getObjectFlags(type) & 2 /* Interface */ ? getDeclarationOfKind(type.symbol, 264 /* InterfaceDeclaration */) : void 0; + const propDeclaration = declaration && declaration.kind === 226 /* BinaryExpression */ || name && name.kind === 167 /* ComputedPropertyName */ ? declaration : void 0; const localPropDeclaration = getParentOfSymbol(prop) === type.symbol ? declaration : void 0; for (const info of indexInfos) { const localIndexDeclaration = info.declaration && getParentOfSymbol(getSymbolOfDeclaration(info.declaration)) === type.symbol ? info.declaration : void 0; const errorNode = localPropDeclaration || localIndexDeclaration || (interfaceDeclaration && !some(getBaseTypes(type), (base) => !!getPropertyOfObjectType(base, prop.escapedName) && !!getIndexTypeOfType(base, info.keyType)) ? interfaceDeclaration : void 0); if (errorNode && !isTypeAssignableTo(propType, info.type)) { - const diagnostic = createError( - errorNode, - Diagnostics.Property_0_of_type_1_is_not_assignable_to_2_index_type_3, - symbolToString(prop), - typeToString(propType), - typeToString(info.keyType), - typeToString(info.type) - ); + const diagnostic = createError(errorNode, Diagnostics.Property_0_of_type_1_is_not_assignable_to_2_index_type_3, symbolToString(prop), typeToString(propType), typeToString(info.keyType), typeToString(info.type)); if (propDeclaration && errorNode !== propDeclaration) { addRelatedInfo(diagnostic, createDiagnosticForNode(propDeclaration, Diagnostics._0_is_declared_here, symbolToString(prop))); } @@ -179339,7 +163297,7 @@ ${lanes.join("\n")} function checkIndexConstraintForIndexSignature(type, checkInfo) { const declaration = checkInfo.declaration; const indexInfos = getApplicableIndexInfos(type, checkInfo.keyType); - const interfaceDeclaration = getObjectFlags(type) & 2 /* Interface */ ? getDeclarationOfKind(type.symbol, 263 /* InterfaceDeclaration */) : void 0; + const interfaceDeclaration = getObjectFlags(type) & 2 /* Interface */ ? getDeclarationOfKind(type.symbol, 264 /* InterfaceDeclaration */) : void 0; const localCheckDeclaration = declaration && getParentOfSymbol(getSymbolOfDeclaration(declaration)) === type.symbol ? declaration : void 0; for (const info of indexInfos) { if (info === checkInfo) @@ -179347,14 +163305,7 @@ ${lanes.join("\n")} const localIndexDeclaration = info.declaration && getParentOfSymbol(getSymbolOfDeclaration(info.declaration)) === type.symbol ? info.declaration : void 0; const errorNode = localCheckDeclaration || localIndexDeclaration || (interfaceDeclaration && !some(getBaseTypes(type), (base) => !!getIndexInfoOfType(base, checkInfo.keyType) && !!getIndexTypeOfType(base, info.keyType)) ? interfaceDeclaration : void 0); if (errorNode && !isTypeAssignableTo(checkInfo.type, info.type)) { - error( - errorNode, - Diagnostics._0_index_type_1_is_not_assignable_to_2_index_type_3, - typeToString(checkInfo.keyType), - typeToString(checkInfo.type), - typeToString(info.keyType), - typeToString(info.type) - ); + error2(errorNode, Diagnostics._0_index_type_1_is_not_assignable_to_2_index_type_3, typeToString(checkInfo.keyType), typeToString(checkInfo.type), typeToString(info.keyType), typeToString(info.type)); } } } @@ -179370,12 +163321,12 @@ ${lanes.join("\n")} case "symbol": case "void": case "object": - error(name, message, name.escapedText); + error2(name, message, name.escapedText); } } function checkClassNameCollisionWithObject(name) { if (languageVersion >= 1 /* ES5 */ && name.escapedText === "Object" && (moduleKind < 5 /* ES2015 */ || getSourceFileOfNode(name).impliedNodeFormat === 1 /* CommonJS */)) { - error(name, Diagnostics.Class_name_cannot_be_Object_when_targeting_ES5_with_module_0, ModuleKind[moduleKind]); + error2(name, Diagnostics.Class_name_cannot_be_Object_when_targeting_ES5_with_module_0, ModuleKind[moduleKind]); } } function checkUnmatchedJSDocParameters(node) { @@ -179398,7 +163349,7 @@ ${lanes.join("\n")} const lastJSDocParamIndex = jsdocParameters.length - 1; const lastJSDocParam = jsdocParameters[lastJSDocParamIndex]; if (isJs && lastJSDocParam && isIdentifier(lastJSDocParam.name) && lastJSDocParam.typeExpression && lastJSDocParam.typeExpression.type && !parameters.has(lastJSDocParam.name.escapedText) && !excludedParameters.has(lastJSDocParamIndex) && !isArrayType(getTypeFromTypeNode(lastJSDocParam.typeExpression.type))) { - error(lastJSDocParam.name, Diagnostics.JSDoc_param_tag_has_name_0_but_there_is_no_parameter_with_that_name_It_would_match_arguments_if_it_had_an_array_type, idText(lastJSDocParam.name)); + error2(lastJSDocParam.name, Diagnostics.JSDoc_param_tag_has_name_0_but_there_is_no_parameter_with_that_name_It_would_match_arguments_if_it_had_an_array_type, idText(lastJSDocParam.name)); } } else { forEach(jsdocParameters, ({ name, isNameFirst }, index) => { @@ -179407,7 +163358,7 @@ ${lanes.join("\n")} } if (isQualifiedName(name)) { if (isJs) { - error(name, Diagnostics.Qualified_name_0_is_not_allowed_without_a_leading_param_object_1, entityNameToString(name), entityNameToString(name.left)); + error2(name, Diagnostics.Qualified_name_0_is_not_allowed_without_a_leading_param_object_1, entityNameToString(name), entityNameToString(name.left)); } } else { if (!isNameFirst) { @@ -179432,11 +163383,11 @@ ${lanes.join("\n")} seenDefault = true; checkTypeParametersNotReferenced(node.default, typeParameterDeclarations, i); } else if (seenDefault) { - error(node, Diagnostics.Required_type_parameters_may_not_follow_optional_type_parameters); + error2(node, Diagnostics.Required_type_parameters_may_not_follow_optional_type_parameters); } for (let j = 0; j < i; j++) { if (typeParameterDeclarations[j].symbol === node.symbol) { - error(node.name, Diagnostics.Duplicate_identifier_0, declarationNameToString(node.name)); + error2(node.name, Diagnostics.Duplicate_identifier_0, declarationNameToString(node.name)); } } }; @@ -179445,12 +163396,12 @@ ${lanes.join("\n")} function checkTypeParametersNotReferenced(root, typeParameters, index) { visit(root); function visit(node) { - if (node.kind === 182 /* TypeReference */) { + if (node.kind === 183 /* TypeReference */) { const type = getTypeFromTypeReference(node); if (type.flags & 262144 /* TypeParameter */) { for (let i = index; i < typeParameters.length; i++) { if (type.symbol === getSymbolOfDeclaration(typeParameters[i])) { - error(node, Diagnostics.Type_parameter_defaults_can_only_reference_previously_declared_type_parameters); + error2(node, Diagnostics.Type_parameter_defaults_can_only_reference_previously_declared_type_parameters); } } } @@ -179473,7 +163424,7 @@ ${lanes.join("\n")} if (!areTypeParametersIdentical(declarations, type.localTypeParameters, getEffectiveTypeParameterDeclarations)) { const name = symbolToString(symbol); for (const declaration of declarations) { - error(declaration.name, Diagnostics.All_declarations_of_0_must_have_identical_type_parameters, name); + error2(declaration.name, Diagnostics.All_declarations_of_0_must_have_identical_type_parameters, name); } } } @@ -179515,7 +163466,7 @@ ${lanes.join("\n")} node ); const willTransformPrivateElementsOrClassStaticBlocks = languageVersion <= 9 /* ES2022 */; - const willTransformInitializers = !useDefineForClassFields || languageVersion < 9 /* ES2022 */; + const willTransformInitializers = !emitStandardClassFields; if (willTransformStaticElementsOfDecoratedClass || willTransformPrivateElementsOrClassStaticBlocks) { for (const member of node.members) { if (willTransformStaticElementsOfDecoratedClass && classElementOrClassElementParameterIsDecorated( @@ -179576,7 +163527,7 @@ ${lanes.join("\n")} if (legacyDecorators && firstDecorator && some(node.members, (p) => hasStaticModifier(p) && isPrivateIdentifierClassElementDeclaration(p))) { grammarErrorOnNode(firstDecorator, Diagnostics.Class_decorators_can_t_be_used_with_static_private_identifier_Consider_removing_the_experimental_decorator); } - if (!node.name && !hasSyntacticModifier(node, 1024 /* Default */)) { + if (!node.name && !hasSyntacticModifier(node, 2048 /* Default */)) { grammarErrorOnFirstToken(node, Diagnostics.A_class_declaration_without_the_default_modifier_must_have_a_name); } checkClassLikeDeclaration(node); @@ -179596,7 +163547,7 @@ ${lanes.join("\n")} checkTypeParameterListsIdentical(symbol); checkFunctionOrConstructorSymbol(symbol); checkClassForDuplicateDeclarations(node); - const nodeInAmbientContext = !!(node.flags & 16777216 /* Ambient */); + const nodeInAmbientContext = !!(node.flags & 33554432 /* Ambient */); if (!nodeInAmbientContext) { checkClassForStaticPropertyNameConflicts(node); } @@ -179635,27 +163586,22 @@ ${lanes.join("\n")} )) { issueMemberSpecificError(node, typeWithThis, baseWithThis, Diagnostics.Class_0_incorrectly_extends_base_class_1); } else { - checkTypeAssignableTo( - staticType, - getTypeWithoutSignatures(staticBaseType), - node.name || node, - Diagnostics.Class_static_side_0_incorrectly_extends_base_class_static_side_1 - ); + checkTypeAssignableTo(staticType, getTypeWithoutSignatures(staticBaseType), node.name || node, Diagnostics.Class_static_side_0_incorrectly_extends_base_class_static_side_1); } if (baseConstructorType.flags & 8650752 /* TypeVariable */) { if (!isMixinConstructorType(staticType)) { - error(node.name || node, Diagnostics.A_mixin_class_must_have_a_constructor_with_a_single_rest_parameter_of_type_any); + error2(node.name || node, Diagnostics.A_mixin_class_must_have_a_constructor_with_a_single_rest_parameter_of_type_any); } else { const constructSignatures = getSignaturesOfType(baseConstructorType, 1 /* Construct */); - if (constructSignatures.some((signature) => signature.flags & 4 /* Abstract */) && !hasSyntacticModifier(node, 256 /* Abstract */)) { - error(node.name || node, Diagnostics.A_mixin_class_that_extends_from_a_type_variable_containing_an_abstract_construct_signature_must_also_be_declared_abstract); + if (constructSignatures.some((signature) => signature.flags & 4 /* Abstract */) && !hasSyntacticModifier(node, 64 /* Abstract */)) { + error2(node.name || node, Diagnostics.A_mixin_class_that_extends_from_a_type_variable_containing_an_abstract_construct_signature_must_also_be_declared_abstract); } } } if (!(staticBaseType.symbol && staticBaseType.symbol.flags & 32 /* Class */) && !(baseConstructorType.flags & 8650752 /* TypeVariable */)) { const constructors = getInstantiatedConstructorsForTypeArguments(staticBaseType, baseTypeNode.typeArguments, baseTypeNode); if (forEach(constructors, (sig) => !isJSConstructor(sig.declaration) && !isTypeIdenticalTo(getReturnTypeOfSignature(sig), baseType))) { - error(baseTypeNode.expression, Diagnostics.Base_constructors_must_all_have_the_same_return_type); + error2(baseTypeNode.expression, Diagnostics.Base_constructors_must_all_have_the_same_return_type); } } checkKindsOfPropertyMemberOverrides(type, baseType); @@ -179667,7 +163613,7 @@ ${lanes.join("\n")} if (implementedTypeNodes) { for (const typeRefNode of implementedTypeNodes) { if (!isEntityNameExpression(typeRefNode.expression) || isOptionalChain(typeRefNode.expression)) { - error(typeRefNode.expression, Diagnostics.A_class_can_only_implement_an_identifier_Slashqualified_name_with_optional_type_arguments); + error2(typeRefNode.expression, Diagnostics.A_class_can_only_implement_an_identifier_Slashqualified_name_with_optional_type_arguments); } checkTypeReferenceNode(typeRefNode); addLazyDiagnostic(createImplementsDiagnostics(typeRefNode)); @@ -179700,7 +163646,7 @@ ${lanes.join("\n")} issueMemberSpecificError(node, typeWithThis, baseWithThis, genericDiag); } } else { - error(typeRefNode, Diagnostics.A_class_can_only_implement_an_object_type_or_intersection_of_object_types_with_statically_known_members); + error2(typeRefNode, Diagnostics.A_class_can_only_implement_an_object_type_or_intersection_of_object_types_with_statically_known_members); } } }; @@ -179767,7 +163713,7 @@ ${lanes.join("\n")} } function checkMemberForOverrideModifier(node, staticType, baseStaticType, baseWithThis, type, typeWithThis, memberHasOverrideModifier, memberHasAbstractModifier, memberIsStatic, memberIsParameterProperty, memberName, errorNode) { const isJs = isInJSFile(node); - const nodeInAmbientContext = !!(node.flags & 16777216 /* Ambient */); + const nodeInAmbientContext = !!(node.flags & 33554432 /* Ambient */); if (baseWithThis && (memberHasOverrideModifier || compilerOptions.noImplicitOverride)) { const memberEscapedName = escapeLeadingUnderscores(memberName); const thisType = memberIsStatic ? staticType : typeWithThis; @@ -179778,12 +163724,12 @@ ${lanes.join("\n")} if (prop && !baseProp && memberHasOverrideModifier) { if (errorNode) { const suggestion = getSuggestedSymbolForNonexistentClassMember(memberName, baseType); - suggestion ? error( + suggestion ? error2( errorNode, isJs ? Diagnostics.This_member_cannot_have_a_JSDoc_comment_with_an_override_tag_because_it_is_not_declared_in_the_base_class_0_Did_you_mean_1 : Diagnostics.This_member_cannot_have_an_override_modifier_because_it_is_not_declared_in_the_base_class_0_Did_you_mean_1, baseClassName, symbolToString(suggestion) - ) : error( + ) : error2( errorNode, isJs ? Diagnostics.This_member_cannot_have_a_JSDoc_comment_with_an_override_tag_because_it_is_not_declared_in_the_base_class_0 : Diagnostics.This_member_cannot_have_an_override_modifier_because_it_is_not_declared_in_the_base_class_0, baseClassName @@ -179798,12 +163744,12 @@ ${lanes.join("\n")} if (!baseHasAbstract) { if (errorNode) { const diag2 = memberIsParameterProperty ? isJs ? Diagnostics.This_parameter_property_must_have_a_JSDoc_comment_with_an_override_tag_because_it_overrides_a_member_in_the_base_class_0 : Diagnostics.This_parameter_property_must_have_an_override_modifier_because_it_overrides_a_member_in_base_class_0 : isJs ? Diagnostics.This_member_must_have_a_JSDoc_comment_with_an_override_tag_because_it_overrides_a_member_in_the_base_class_0 : Diagnostics.This_member_must_have_an_override_modifier_because_it_overrides_a_member_in_the_base_class_0; - error(errorNode, diag2, baseClassName); + error2(errorNode, diag2, baseClassName); } return 1 /* NeedsOverride */; } else if (memberHasAbstractModifier && baseHasAbstract) { if (errorNode) { - error(errorNode, Diagnostics.This_member_must_have_an_override_modifier_because_it_overrides_an_abstract_method_that_is_declared_in_the_base_class_0, baseClassName); + error2(errorNode, Diagnostics.This_member_must_have_an_override_modifier_because_it_overrides_an_abstract_method_that_is_declared_in_the_base_class_0, baseClassName); } return 1 /* NeedsOverride */; } @@ -179811,7 +163757,7 @@ ${lanes.join("\n")} } else if (memberHasOverrideModifier) { if (errorNode) { const className = typeToString(type); - error( + error2( errorNode, isJs ? Diagnostics.This_member_cannot_have_a_JSDoc_comment_with_an_override_tag_because_its_containing_class_0_does_not_extend_another_class : Diagnostics.This_member_cannot_have_an_override_modifier_because_its_containing_class_0_does_not_extend_another_class, className @@ -179861,10 +163807,10 @@ ${lanes.join("\n")} const signatures = getSignaturesOfType(type, 1 /* Construct */); if (signatures.length) { const declaration = signatures[0].declaration; - if (declaration && hasEffectiveModifier(declaration, 8 /* Private */)) { + if (declaration && hasEffectiveModifier(declaration, 2 /* Private */)) { const typeClassDeclaration = getClassLikeDeclarationOfSymbol(type.symbol); if (!isNodeWithinClass(node, typeClassDeclaration)) { - error(node, Diagnostics.Cannot_extend_a_class_0_Class_constructor_is_marked_as_private, getFullyQualifiedName(type.symbol)); + error2(node, Diagnostics.Cannot_extend_a_class_0_Class_constructor_is_marked_as_private, getFullyQualifiedName(type.symbol)); } } } @@ -179881,7 +163827,7 @@ ${lanes.join("\n")} const baseTypes = baseTypeNode && getBaseTypes(type); const baseWithThis = (baseTypes == null ? void 0 : baseTypes.length) ? getTypeWithThisArgument(first(baseTypes), type.thisType) : void 0; const baseStaticType = getBaseConstructorTypeOfClass(type); - const memberHasOverrideModifier = member.parent ? hasOverrideModifier(member) : hasSyntacticModifier(member, 16384 /* Override */); + const memberHasOverrideModifier = member.parent ? hasOverrideModifier(member) : hasSyntacticModifier(member, 16 /* Override */); return checkMemberForOverrideModifier( node, staticType, @@ -179901,7 +163847,7 @@ ${lanes.join("\n")} return getCheckFlags(s) & 1 /* Instantiated */ ? s.links.target : s; } function getClassOrInterfaceDeclarationsOfSymbol(symbol) { - return filter(symbol.declarations, (d) => d.kind === 262 /* ClassDeclaration */ || d.kind === 263 /* InterfaceDeclaration */); + return filter(symbol.declarations, (d) => d.kind === 263 /* ClassDeclaration */ || d.kind === 264 /* InterfaceDeclaration */); } function checkKindsOfPropertyMemberOverrides(type, baseType) { var _a, _b, _c, _d; @@ -179922,7 +163868,7 @@ ${lanes.join("\n")} Debug.assert(!!derived, "derived should point to something, even if it is the base class' declaration."); if (derived === base) { const derivedClassDecl = getClassLikeDeclarationOfSymbol(type.symbol); - if (baseDeclarationFlags & 256 /* Abstract */ && (!derivedClassDecl || !hasSyntacticModifier(derivedClassDecl, 256 /* Abstract */))) { + if (baseDeclarationFlags & 64 /* Abstract */ && (!derivedClassDecl || !hasSyntacticModifier(derivedClassDecl, 64 /* Abstract */))) { for (const otherBaseType of getBaseTypes(type)) { if (otherBaseType === baseType) continue; @@ -179933,14 +163879,14 @@ ${lanes.join("\n")} } } if (!inheritedAbstractMemberNotImplementedError) { - inheritedAbstractMemberNotImplementedError = error( + inheritedAbstractMemberNotImplementedError = error2( derivedClassDecl, Diagnostics.Non_abstract_class_0_does_not_implement_all_abstract_members_of_1, typeToString(type), typeToString(baseType) ); } - if (derivedClassDecl.kind === 230 /* ClassExpression */) { + if (derivedClassDecl.kind === 231 /* ClassExpression */) { addRelatedInfo( inheritedAbstractMemberNotImplementedError, createDiagnosticForNode( @@ -179965,7 +163911,7 @@ ${lanes.join("\n")} } } else { const derivedDeclarationFlags = getDeclarationModifierFlagsFromSymbol(derived); - if (baseDeclarationFlags & 8 /* Private */ || derivedDeclarationFlags & 8 /* Private */) { + if (baseDeclarationFlags & 2 /* Private */ || derivedDeclarationFlags & 2 /* Private */) { continue; } let errorMessage; @@ -179979,15 +163925,15 @@ ${lanes.join("\n")} const overriddenInstanceAccessor = basePropertyFlags === 4 /* Property */ && derivedPropertyFlags !== 4 /* Property */; if (overriddenInstanceProperty || overriddenInstanceAccessor) { const errorMessage2 = overriddenInstanceProperty ? Diagnostics._0_is_defined_as_an_accessor_in_class_1_but_is_overridden_here_in_2_as_an_instance_property : Diagnostics._0_is_defined_as_a_property_in_class_1_but_is_overridden_here_in_2_as_an_accessor; - error(getNameOfDeclaration(derived.valueDeclaration) || derived.valueDeclaration, errorMessage2, symbolToString(base), typeToString(baseType), typeToString(type)); + error2(getNameOfDeclaration(derived.valueDeclaration) || derived.valueDeclaration, errorMessage2, symbolToString(base), typeToString(baseType), typeToString(type)); } else if (useDefineForClassFields) { - const uninitialized = (_c = derived.declarations) == null ? void 0 : _c.find((d) => d.kind === 171 /* PropertyDeclaration */ && !d.initializer); - if (uninitialized && !(derived.flags & 33554432 /* Transient */) && !(baseDeclarationFlags & 256 /* Abstract */) && !(derivedDeclarationFlags & 256 /* Abstract */) && !((_d = derived.declarations) == null ? void 0 : _d.some((d) => !!(d.flags & 16777216 /* Ambient */)))) { + const uninitialized = (_c = derived.declarations) == null ? void 0 : _c.find((d) => d.kind === 172 /* PropertyDeclaration */ && !d.initializer); + if (uninitialized && !(derived.flags & 33554432 /* Transient */) && !(baseDeclarationFlags & 64 /* Abstract */) && !(derivedDeclarationFlags & 64 /* Abstract */) && !((_d = derived.declarations) == null ? void 0 : _d.some((d) => !!(d.flags & 33554432 /* Ambient */)))) { const constructor = findConstructorDeclaration(getClassLikeDeclarationOfSymbol(type.symbol)); const propName = uninitialized.name; if (uninitialized.exclamationToken || !constructor || !isIdentifier(propName) || !strictNullChecks || !isPropertyInitializedInConstructor(propName, type, constructor)) { const errorMessage2 = Diagnostics.Property_0_will_overwrite_the_base_property_in_1_If_this_is_intentional_add_an_initializer_Otherwise_add_a_declare_modifier_or_remove_the_redundant_declaration; - error(getNameOfDeclaration(derived.valueDeclaration) || derived.valueDeclaration, errorMessage2, symbolToString(base), typeToString(baseType)); + error2(getNameOfDeclaration(derived.valueDeclaration) || derived.valueDeclaration, errorMessage2, symbolToString(base), typeToString(baseType)); } } } @@ -180004,12 +163950,12 @@ ${lanes.join("\n")} } else { errorMessage = Diagnostics.Class_0_defines_instance_member_property_1_but_extended_class_2_defines_it_as_instance_member_function; } - error(getNameOfDeclaration(derived.valueDeclaration) || derived.valueDeclaration, errorMessage, typeToString(baseType), symbolToString(base), typeToString(type)); + error2(getNameOfDeclaration(derived.valueDeclaration) || derived.valueDeclaration, errorMessage, typeToString(baseType), symbolToString(base), typeToString(type)); } } } function isPropertyAbstractOrInterface(declaration, baseDeclarationFlags) { - return baseDeclarationFlags & 256 /* Abstract */ && (!isPropertyDeclaration(declaration) || !declaration.initializer) || isInterfaceDeclaration(declaration.parent); + return baseDeclarationFlags & 64 /* Abstract */ && (!isPropertyDeclaration(declaration) || !declaration.initializer) || isInterfaceDeclaration(declaration.parent); } function getNonInheritedProperties(type, baseTypes, properties) { if (!length(baseTypes)) { @@ -180069,12 +164015,12 @@ ${lanes.join("\n")} return ok; } function checkPropertyInitialization(node) { - if (!strictNullChecks || !strictPropertyInitialization || node.flags & 16777216 /* Ambient */) { + if (!strictNullChecks || !strictPropertyInitialization || node.flags & 33554432 /* Ambient */) { return; } const constructor = findConstructorDeclaration(node); for (const member of node.members) { - if (getEffectiveModifierFlags(member) & 2 /* Ambient */) { + if (getEffectiveModifierFlags(member) & 128 /* Ambient */) { continue; } if (!isStatic(member) && isPropertyWithoutInitializer(member)) { @@ -180083,7 +164029,7 @@ ${lanes.join("\n")} const type = getTypeOfSymbol(getSymbolOfDeclaration(member)); if (!(type.flags & 3 /* AnyOrUnknown */ || containsUndefinedType(type))) { if (!constructor || !isPropertyInitializedInConstructor(propName, type, constructor)) { - error(member.name, Diagnostics.Property_0_has_no_initializer_and_is_not_definitely_assigned_in_the_constructor, declarationNameToString(propName)); + error2(member.name, Diagnostics.Property_0_has_no_initializer_and_is_not_definitely_assigned_in_the_constructor, declarationNameToString(propName)); } } } @@ -180091,7 +164037,7 @@ ${lanes.join("\n")} } } function isPropertyWithoutInitializer(node) { - return node.kind === 171 /* PropertyDeclaration */ && !hasAbstractModifier(node) && !node.exclamationToken && !node.initializer; + return node.kind === 172 /* PropertyDeclaration */ && !hasAbstractModifier(node) && !node.exclamationToken && !node.initializer; } function isPropertyInitializedInStaticBlocks(propName, propType, staticBlocks, startPos, endPos) { for (const staticBlock of staticBlocks) { @@ -180125,7 +164071,7 @@ ${lanes.join("\n")} checkExportsOnMergedDeclarations(node); const symbol = getSymbolOfDeclaration(node); checkTypeParameterListsIdentical(symbol); - const firstInterfaceDecl = getDeclarationOfKind(symbol, 263 /* InterfaceDeclaration */); + const firstInterfaceDecl = getDeclarationOfKind(symbol, 264 /* InterfaceDeclaration */); if (node === firstInterfaceDecl) { const type = getDeclaredTypeOfSymbol(symbol); const typeWithThis = getTypeWithThisArgument(type); @@ -180140,7 +164086,7 @@ ${lanes.join("\n")} }); forEach(getInterfaceBaseTypeNodes(node), (heritageElement) => { if (!isEntityNameExpression(heritageElement.expression) || isOptionalChain(heritageElement.expression)) { - error(heritageElement.expression, Diagnostics.An_interface_can_only_extend_an_identifier_Slashqualified_name_with_optional_type_arguments); + error2(heritageElement.expression, Diagnostics.An_interface_can_only_extend_an_identifier_Slashqualified_name_with_optional_type_arguments); } checkTypeReferenceNode(heritageElement); }); @@ -180157,7 +164103,7 @@ ${lanes.join("\n")} checkTypeParameters(node.typeParameters); if (node.type.kind === 141 /* IntrinsicKeyword */) { if (!intrinsicTypeKinds.has(node.name.escapedText) || length(node.typeParameters) !== 1) { - error(node.type, Diagnostics.The_intrinsic_keyword_can_only_be_used_to_declare_compiler_provided_intrinsic_types); + error2(node.type, Diagnostics.The_intrinsic_keyword_can_only_be_used_to_declare_compiler_provided_intrinsic_types); } } else { checkSourceElement(node.type); @@ -180178,23 +164124,23 @@ ${lanes.join("\n")} } function computeMemberValue(member, autoValue) { if (isComputedNonLiteralName(member.name)) { - error(member.name, Diagnostics.Computed_property_names_are_not_allowed_in_enums); + error2(member.name, Diagnostics.Computed_property_names_are_not_allowed_in_enums); } else { const text = getTextOfPropertyName(member.name); if (isNumericLiteralName(text) && !isInfinityOrNaNString(text)) { - error(member.name, Diagnostics.An_enum_member_cannot_have_a_numeric_name); + error2(member.name, Diagnostics.An_enum_member_cannot_have_a_numeric_name); } } if (member.initializer) { return computeConstantValue(member); } - if (member.parent.flags & 16777216 /* Ambient */ && !isEnumConst(member.parent)) { + if (member.parent.flags & 33554432 /* Ambient */ && !isEnumConst(member.parent)) { return void 0; } if (autoValue !== void 0) { return autoValue; } - error(member.name, Diagnostics.Enum_member_must_have_initializer); + error2(member.name, Diagnostics.Enum_member_must_have_initializer); return void 0; } function computeConstantValue(member) { @@ -180203,12 +164149,15 @@ ${lanes.join("\n")} const value = evaluate(initializer, member); if (value !== void 0) { if (isConstEnum && typeof value === "number" && !isFinite(value)) { - error(initializer, isNaN(value) ? Diagnostics.const_enum_member_initializer_was_evaluated_to_disallowed_value_NaN : Diagnostics.const_enum_member_initializer_was_evaluated_to_a_non_finite_value); + error2( + initializer, + isNaN(value) ? Diagnostics.const_enum_member_initializer_was_evaluated_to_disallowed_value_NaN : Diagnostics.const_enum_member_initializer_was_evaluated_to_a_non_finite_value + ); } } else if (isConstEnum) { - error(initializer, Diagnostics.const_enum_member_initializers_must_be_constant_expressions); - } else if (member.parent.flags & 16777216 /* Ambient */) { - error(initializer, Diagnostics.In_ambient_enum_declarations_member_initializer_must_be_constant_expression); + error2(initializer, Diagnostics.const_enum_member_initializers_must_be_constant_expressions); + } else if (member.parent.flags & 33554432 /* Ambient */) { + error2(initializer, Diagnostics.In_ambient_enum_declarations_member_initializer_must_be_constant_expression); } else { checkTypeAssignableTo(checkExpression(initializer), numberType, initializer, Diagnostics.Type_0_is_not_assignable_to_type_1_as_required_for_computed_enum_member_values); } @@ -180216,7 +164165,7 @@ ${lanes.join("\n")} } function evaluate(expr, location) { switch (expr.kind) { - case 223 /* PrefixUnaryExpression */: + case 224 /* PrefixUnaryExpression */: const value = evaluate(expr.operand, location); if (typeof value === "number") { switch (expr.operator) { @@ -180229,7 +164178,7 @@ ${lanes.join("\n")} } } break; - case 225 /* BinaryExpression */: + case 226 /* BinaryExpression */: const left = evaluate(expr.left, location); const right = evaluate(expr.right, location); if (typeof left === "number" && typeof right === "number") { @@ -180266,18 +164215,30 @@ ${lanes.join("\n")} case 11 /* StringLiteral */: case 15 /* NoSubstitutionTemplateLiteral */: return expr.text; - case 227 /* TemplateExpression */: + case 228 /* TemplateExpression */: return evaluateTemplateExpression(expr, location); case 9 /* NumericLiteral */: checkGrammarNumericLiteral(expr); return +expr.text; - case 216 /* ParenthesizedExpression */: + case 217 /* ParenthesizedExpression */: return evaluate(expr.expression, location); - case 80 /* Identifier */: - if (isInfinityOrNaNString(expr.escapedText)) { - return +expr.escapedText; + case 80 /* Identifier */: { + const identifier = expr; + if (isInfinityOrNaNString(identifier.escapedText) && resolveEntityName( + identifier, + 111551 /* Value */, + /*ignoreErrors*/ + true + ) === getGlobalSymbol( + identifier.escapedText, + 111551 /* Value */, + /*diagnostic*/ + void 0 + )) { + return +identifier.escapedText; } - case 210 /* PropertyAccessExpression */: + } + case 211 /* PropertyAccessExpression */: if (isEntityNameExpression(expr)) { const symbol = resolveEntityName( expr, @@ -180287,18 +164248,18 @@ ${lanes.join("\n")} ); if (symbol) { if (symbol.flags & 8 /* EnumMember */) { - return evaluateEnumMember(expr, symbol, location); + return location ? evaluateEnumMember(expr, symbol, location) : getEnumMemberValue(symbol.valueDeclaration); } - if (isConstVariable(symbol)) { + if (isConstantVariable(symbol)) { const declaration = symbol.valueDeclaration; - if (declaration && !declaration.type && declaration.initializer && declaration !== location && isBlockScopedNameDeclaredBeforeUse(declaration, location)) { + if (declaration && isVariableDeclaration(declaration) && !declaration.type && declaration.initializer && (!location || declaration !== location && isBlockScopedNameDeclaredBeforeUse(declaration, location))) { return evaluate(declaration.initializer, declaration); } } } } break; - case 211 /* ElementAccessExpression */: + case 212 /* ElementAccessExpression */: const root = expr.expression; if (isEntityNameExpression(root) && isStringLiteralLike(expr.argumentExpression)) { const rootSymbol = resolveEntityName( @@ -180311,7 +164272,7 @@ ${lanes.join("\n")} const name = escapeLeadingUnderscores(expr.argumentExpression.text); const member = rootSymbol.exports.get(name); if (member) { - return evaluateEnumMember(expr, member, location); + return location ? evaluateEnumMember(expr, member, location) : getEnumMemberValue(member.valueDeclaration); } } } @@ -180322,11 +164283,11 @@ ${lanes.join("\n")} function evaluateEnumMember(expr, symbol, location) { const declaration = symbol.valueDeclaration; if (!declaration || declaration === location) { - error(expr, Diagnostics.Property_0_is_used_before_being_assigned, symbolToString(symbol)); + error2(expr, Diagnostics.Property_0_is_used_before_being_assigned, symbolToString(symbol)); return void 0; } if (!isBlockScopedNameDeclaredBeforeUse(declaration, location)) { - error(expr, Diagnostics.A_member_initializer_in_a_enum_declaration_cannot_reference_members_declared_after_it_including_members_defined_in_other_enums); + error2(expr, Diagnostics.A_member_initializer_in_a_enum_declaration_cannot_reference_members_declared_after_it_including_members_defined_in_other_enums); return 0; } return getEnumMemberValue(declaration); @@ -180359,13 +164320,13 @@ ${lanes.join("\n")} const enumIsConst = isEnumConst(node); forEach(enumSymbol.declarations, (decl) => { if (isEnumDeclaration(decl) && isEnumConst(decl) !== enumIsConst) { - error(getNameOfDeclaration(decl), Diagnostics.Enum_declarations_must_all_be_const_or_non_const); + error2(getNameOfDeclaration(decl), Diagnostics.Enum_declarations_must_all_be_const_or_non_const); } }); } let seenEnumMissingInitialInitializer = false; forEach(enumSymbol.declarations, (declaration) => { - if (declaration.kind !== 265 /* EnumDeclaration */) { + if (declaration.kind !== 266 /* EnumDeclaration */) { return false; } const enumDeclaration = declaration; @@ -180375,7 +164336,7 @@ ${lanes.join("\n")} const firstEnumMember = enumDeclaration.members[0]; if (!firstEnumMember.initializer) { if (seenEnumMissingInitialInitializer) { - error(firstEnumMember.name, Diagnostics.In_an_enum_with_multiple_declarations_only_one_declaration_can_omit_an_initializer_for_its_first_enum_element); + error2(firstEnumMember.name, Diagnostics.In_an_enum_with_multiple_declarations_only_one_declaration_can_omit_an_initializer_for_its_first_enum_element); } else { seenEnumMissingInitialInitializer = true; } @@ -180385,7 +164346,7 @@ ${lanes.join("\n")} } function checkEnumMember(node) { if (isPrivateIdentifier(node.name)) { - error(node, Diagnostics.An_enum_member_cannot_be_named_with_a_private_identifier); + error2(node, Diagnostics.An_enum_member_cannot_be_named_with_a_private_identifier); } if (node.initializer) { checkExpression(node.initializer); @@ -180395,7 +164356,7 @@ ${lanes.join("\n")} const declarations = symbol.declarations; if (declarations) { for (const declaration of declarations) { - if ((declaration.kind === 262 /* ClassDeclaration */ || declaration.kind === 261 /* FunctionDeclaration */ && nodeIsPresent(declaration.body)) && !(declaration.flags & 16777216 /* Ambient */)) { + if ((declaration.kind === 263 /* ClassDeclaration */ || declaration.kind === 262 /* FunctionDeclaration */ && nodeIsPresent(declaration.body)) && !(declaration.flags & 33554432 /* Ambient */)) { return declaration; } } @@ -180424,9 +164385,9 @@ ${lanes.join("\n")} function checkModuleDeclarationDiagnostics() { var _a, _b; const isGlobalAugmentation = isGlobalScopeAugmentation(node); - const inAmbientContext = node.flags & 16777216 /* Ambient */; + const inAmbientContext = node.flags & 33554432 /* Ambient */; if (isGlobalAugmentation && !inAmbientContext) { - error(node.name, Diagnostics.Augmentations_for_the_global_scope_should_have_declare_modifier_unless_they_appear_in_already_ambient_context); + error2(node.name, Diagnostics.Augmentations_for_the_global_scope_should_have_declare_modifier_unless_they_appear_in_already_ambient_context); } const isAmbientExternalModule = isAmbientModule(node); const contextErrorMessage = isAmbientExternalModule ? Diagnostics.An_ambient_module_declaration_is_only_allowed_at_the_top_level_in_a_file : Diagnostics.A_namespace_declaration_is_only_allowed_at_the_top_level_of_a_namespace_or_module; @@ -180445,26 +164406,26 @@ ${lanes.join("\n")} const symbol = getSymbolOfDeclaration(node); if (symbol.flags & 512 /* ValueModule */ && !inAmbientContext && isInstantiatedModule(node, shouldPreserveConstEnums(compilerOptions))) { if (getIsolatedModules(compilerOptions) && !getSourceFileOfNode(node).externalModuleIndicator) { - error(node.name, Diagnostics.Namespaces_are_not_allowed_in_global_script_files_when_0_is_enabled_If_this_file_is_not_intended_to_be_a_global_script_set_moduleDetection_to_force_or_add_an_empty_export_statement, isolatedModulesLikeFlagName); + error2(node.name, Diagnostics.Namespaces_are_not_allowed_in_global_script_files_when_0_is_enabled_If_this_file_is_not_intended_to_be_a_global_script_set_moduleDetection_to_force_or_add_an_empty_export_statement, isolatedModulesLikeFlagName); } if (((_a = symbol.declarations) == null ? void 0 : _a.length) > 1) { const firstNonAmbientClassOrFunc = getFirstNonAmbientClassOrFunctionDeclaration(symbol); if (firstNonAmbientClassOrFunc) { if (getSourceFileOfNode(node) !== getSourceFileOfNode(firstNonAmbientClassOrFunc)) { - error(node.name, Diagnostics.A_namespace_declaration_cannot_be_in_a_different_file_from_a_class_or_function_with_which_it_is_merged); + error2(node.name, Diagnostics.A_namespace_declaration_cannot_be_in_a_different_file_from_a_class_or_function_with_which_it_is_merged); } else if (node.pos < firstNonAmbientClassOrFunc.pos) { - error(node.name, Diagnostics.A_namespace_declaration_cannot_be_located_prior_to_a_class_or_function_with_which_it_is_merged); + error2(node.name, Diagnostics.A_namespace_declaration_cannot_be_located_prior_to_a_class_or_function_with_which_it_is_merged); } } - const mergedClass = getDeclarationOfKind(symbol, 262 /* ClassDeclaration */); + const mergedClass = getDeclarationOfKind(symbol, 263 /* ClassDeclaration */); if (mergedClass && inSameLexicalScope(node, mergedClass)) { getNodeLinks(node).flags |= 2048 /* LexicalModuleMergesWithClass */; } } - if (compilerOptions.verbatimModuleSyntax && node.parent.kind === 311 /* SourceFile */ && (moduleKind === 1 /* CommonJS */ || node.parent.impliedNodeFormat === 1 /* CommonJS */)) { + if (compilerOptions.verbatimModuleSyntax && node.parent.kind === 312 /* SourceFile */ && (moduleKind === 1 /* CommonJS */ || node.parent.impliedNodeFormat === 1 /* CommonJS */)) { const exportModifier = (_b = node.modifiers) == null ? void 0 : _b.find((m) => m.kind === 95 /* ExportKeyword */); if (exportModifier) { - error(exportModifier, Diagnostics.A_top_level_export_modifier_cannot_be_used_on_value_declarations_in_a_CommonJS_module_when_verbatimModuleSyntax_is_enabled); + error2(exportModifier, Diagnostics.A_top_level_export_modifier_cannot_be_used_on_value_declarations_in_a_CommonJS_module_when_verbatimModuleSyntax_is_enabled); } } } @@ -180478,15 +164439,15 @@ ${lanes.join("\n")} } } else if (isGlobalSourceFile(node.parent)) { if (isGlobalAugmentation) { - error(node.name, Diagnostics.Augmentations_for_the_global_scope_can_only_be_directly_nested_in_external_modules_or_ambient_module_declarations); + error2(node.name, Diagnostics.Augmentations_for_the_global_scope_can_only_be_directly_nested_in_external_modules_or_ambient_module_declarations); } else if (isExternalModuleNameRelative(getTextOfIdentifierOrLiteral(node.name))) { - error(node.name, Diagnostics.Ambient_module_declaration_cannot_specify_relative_module_name); + error2(node.name, Diagnostics.Ambient_module_declaration_cannot_specify_relative_module_name); } } else { if (isGlobalAugmentation) { - error(node.name, Diagnostics.Augmentations_for_the_global_scope_can_only_be_directly_nested_in_external_modules_or_ambient_module_declarations); + error2(node.name, Diagnostics.Augmentations_for_the_global_scope_can_only_be_directly_nested_in_external_modules_or_ambient_module_declarations); } else { - error(node.name, Diagnostics.Ambient_modules_cannot_be_nested_in_other_modules_or_namespaces); + error2(node.name, Diagnostics.Ambient_modules_cannot_be_nested_in_other_modules_or_namespaces); } } } @@ -180494,21 +164455,21 @@ ${lanes.join("\n")} } function checkModuleAugmentationElement(node, isGlobalAugmentation) { switch (node.kind) { - case 242 /* VariableStatement */: + case 243 /* VariableStatement */: for (const decl of node.declarationList.declarations) { checkModuleAugmentationElement(decl, isGlobalAugmentation); } break; - case 276 /* ExportAssignment */: - case 277 /* ExportDeclaration */: + case 277 /* ExportAssignment */: + case 278 /* ExportDeclaration */: grammarErrorOnFirstToken(node, Diagnostics.Exports_and_export_assignments_are_not_permitted_in_module_augmentations); break; - case 270 /* ImportEqualsDeclaration */: - case 271 /* ImportDeclaration */: + case 271 /* ImportEqualsDeclaration */: + case 272 /* ImportDeclaration */: grammarErrorOnFirstToken(node, Diagnostics.Imports_are_not_permitted_in_module_augmentations_Consider_moving_them_to_the_enclosing_external_module); break; - case 207 /* BindingElement */: - case 259 /* VariableDeclaration */: + case 208 /* BindingElement */: + case 260 /* VariableDeclaration */: const name = node.name; if (isBindingPattern(name)) { for (const el of name.elements) { @@ -180516,12 +164477,12 @@ ${lanes.join("\n")} } break; } - case 262 /* ClassDeclaration */: - case 265 /* EnumDeclaration */: - case 261 /* FunctionDeclaration */: - case 263 /* InterfaceDeclaration */: - case 266 /* ModuleDeclaration */: - case 264 /* TypeAliasDeclaration */: + case 263 /* ClassDeclaration */: + case 266 /* EnumDeclaration */: + case 262 /* FunctionDeclaration */: + case 264 /* InterfaceDeclaration */: + case 267 /* ModuleDeclaration */: + case 265 /* TypeAliasDeclaration */: if (isGlobalAugmentation) { return; } @@ -180532,12 +164493,12 @@ ${lanes.join("\n")} switch (node.kind) { case 80 /* Identifier */: return node; - case 165 /* QualifiedName */: + case 166 /* QualifiedName */: do { node = node.left; } while (node.kind !== 80 /* Identifier */); return node; - case 210 /* PropertyAccessExpression */: + case 211 /* PropertyAccessExpression */: do { if (isModuleExportsAccessExpression(node.expression) && !isPrivateIdentifier(node.name)) { return node.name; @@ -180553,26 +164514,30 @@ ${lanes.join("\n")} return false; } if (!isStringLiteral(moduleName)) { - error(moduleName, Diagnostics.String_literal_expected); + error2(moduleName, Diagnostics.String_literal_expected); return false; } - const inAmbientExternalModule = node.parent.kind === 267 /* ModuleBlock */ && isAmbientModule(node.parent.parent); - if (node.parent.kind !== 311 /* SourceFile */ && !inAmbientExternalModule) { - error(moduleName, node.kind === 277 /* ExportDeclaration */ ? Diagnostics.Export_declarations_are_not_permitted_in_a_namespace : Diagnostics.Import_declarations_in_a_namespace_cannot_reference_a_module); + const inAmbientExternalModule = node.parent.kind === 268 /* ModuleBlock */ && isAmbientModule(node.parent.parent); + if (node.parent.kind !== 312 /* SourceFile */ && !inAmbientExternalModule) { + error2( + moduleName, + node.kind === 278 /* ExportDeclaration */ ? Diagnostics.Export_declarations_are_not_permitted_in_a_namespace : Diagnostics.Import_declarations_in_a_namespace_cannot_reference_a_module + ); return false; } if (inAmbientExternalModule && isExternalModuleNameRelative(moduleName.text)) { if (!isTopLevelInExternalModuleAugmentation(node)) { - error(node, Diagnostics.Import_or_export_declaration_in_an_ambient_module_declaration_cannot_reference_module_through_relative_module_name); + error2(node, Diagnostics.Import_or_export_declaration_in_an_ambient_module_declaration_cannot_reference_module_through_relative_module_name); return false; } } - if (!isImportEqualsDeclaration(node) && node.assertClause) { + if (!isImportEqualsDeclaration(node) && node.attributes) { + const diagnostic = node.attributes.token === 118 /* WithKeyword */ ? Diagnostics.Import_attribute_values_must_be_string_literal_expressions : Diagnostics.Import_assertion_values_must_be_string_literal_expressions; let hasError = false; - for (const clause of node.assertClause.elements) { - if (!isStringLiteral(clause.value)) { + for (const attr of node.attributes.elements) { + if (!isStringLiteral(attr.value)) { hasError = true; - error(clause.value, Diagnostics.Import_assertion_values_must_be_string_literal_expressions); + error2(attr.value, diagnostic); } } return !hasError; @@ -180587,26 +164552,29 @@ ${lanes.join("\n")} symbol = getMergedSymbol(symbol.exportSymbol || symbol); if (isInJSFile(node) && !(target.flags & 111551 /* Value */) && !isTypeOnlyImportOrExportDeclaration(node)) { const errorNode = isImportOrExportSpecifier(node) ? node.propertyName || node.name : isNamedDeclaration(node) ? node.name : node; - Debug.assert(node.kind !== 279 /* NamespaceExport */); - if (node.kind === 280 /* ExportSpecifier */) { - const diag2 = error(errorNode, Diagnostics.Types_cannot_appear_in_export_declarations_in_JavaScript_files); + Debug.assert(node.kind !== 280 /* NamespaceExport */); + if (node.kind === 281 /* ExportSpecifier */) { + const diag2 = error2(errorNode, Diagnostics.Types_cannot_appear_in_export_declarations_in_JavaScript_files); const alreadyExportedSymbol = (_b = (_a = getSourceFileOfNode(node).symbol) == null ? void 0 : _a.exports) == null ? void 0 : _b.get((node.propertyName || node.name).escapedText); if (alreadyExportedSymbol === target) { const exportingDeclaration = (_c = alreadyExportedSymbol.declarations) == null ? void 0 : _c.find(isJSDocNode); if (exportingDeclaration) { - addRelatedInfo(diag2, createDiagnosticForNode( - exportingDeclaration, - Diagnostics._0_is_automatically_exported_here, - unescapeLeadingUnderscores(alreadyExportedSymbol.escapedName) - )); + addRelatedInfo( + diag2, + createDiagnosticForNode( + exportingDeclaration, + Diagnostics._0_is_automatically_exported_here, + unescapeLeadingUnderscores(alreadyExportedSymbol.escapedName) + ) + ); } } } else { - Debug.assert(node.kind !== 259 /* VariableDeclaration */); + Debug.assert(node.kind !== 260 /* VariableDeclaration */); const importDeclaration = findAncestor(node, or(isImportDeclaration, isImportEqualsDeclaration)); const moduleSpecifier = (importDeclaration && ((_d = tryGetModuleSpecifierFromDeclaration(importDeclaration)) == null ? void 0 : _d.text)) ?? "..."; const importedIdentifier = unescapeLeadingUnderscores(isIdentifier(errorNode) ? errorNode.escapedText : symbol.escapedName); - error( + error2( errorNode, Diagnostics._0_is_a_type_and_cannot_be_imported_in_JavaScript_files_Use_1_in_a_JSDoc_type_annotation, importedIdentifier, @@ -180615,47 +164583,47 @@ ${lanes.join("\n")} } return; } - const targetFlags = getAllSymbolFlags(target); + const targetFlags = getSymbolFlags(target); const excludedMeanings = (symbol.flags & (111551 /* Value */ | 1048576 /* ExportValue */) ? 111551 /* Value */ : 0) | (symbol.flags & 788968 /* Type */ ? 788968 /* Type */ : 0) | (symbol.flags & 1920 /* Namespace */ ? 1920 /* Namespace */ : 0); if (targetFlags & excludedMeanings) { - const message = node.kind === 280 /* ExportSpecifier */ ? Diagnostics.Export_declaration_conflicts_with_exported_declaration_of_0 : Diagnostics.Import_declaration_conflicts_with_local_declaration_of_0; - error(node, message, symbolToString(symbol)); + const message = node.kind === 281 /* ExportSpecifier */ ? Diagnostics.Export_declaration_conflicts_with_exported_declaration_of_0 : Diagnostics.Import_declaration_conflicts_with_local_declaration_of_0; + error2(node, message, symbolToString(symbol)); } - if (getIsolatedModules(compilerOptions) && !isTypeOnlyImportOrExportDeclaration(node) && !(node.flags & 16777216 /* Ambient */)) { + if (getIsolatedModules(compilerOptions) && !isTypeOnlyImportOrExportDeclaration(node) && !(node.flags & 33554432 /* Ambient */)) { const typeOnlyAlias = getTypeOnlyAliasDeclaration(symbol); const isType = !(targetFlags & 111551 /* Value */); if (isType || typeOnlyAlias) { switch (node.kind) { - case 272 /* ImportClause */: - case 275 /* ImportSpecifier */: - case 270 /* ImportEqualsDeclaration */: { + case 273 /* ImportClause */: + case 276 /* ImportSpecifier */: + case 271 /* ImportEqualsDeclaration */: { if (compilerOptions.preserveValueImports || compilerOptions.verbatimModuleSyntax) { Debug.assertIsDefined(node.name, "An ImportClause with a symbol should have a name"); const message = compilerOptions.verbatimModuleSyntax && isInternalModuleImportEqualsDeclaration(node) ? Diagnostics.An_import_alias_cannot_resolve_to_a_type_or_type_only_declaration_when_verbatimModuleSyntax_is_enabled : isType ? compilerOptions.verbatimModuleSyntax ? Diagnostics._0_is_a_type_and_must_be_imported_using_a_type_only_import_when_verbatimModuleSyntax_is_enabled : Diagnostics._0_is_a_type_and_must_be_imported_using_a_type_only_import_when_preserveValueImports_and_isolatedModules_are_both_enabled : compilerOptions.verbatimModuleSyntax ? Diagnostics._0_resolves_to_a_type_only_declaration_and_must_be_imported_using_a_type_only_import_when_verbatimModuleSyntax_is_enabled : Diagnostics._0_resolves_to_a_type_only_declaration_and_must_be_imported_using_a_type_only_import_when_preserveValueImports_and_isolatedModules_are_both_enabled; - const name = idText(node.kind === 275 /* ImportSpecifier */ ? node.propertyName || node.name : node.name); + const name = idText(node.kind === 276 /* ImportSpecifier */ ? node.propertyName || node.name : node.name); addTypeOnlyDeclarationRelatedInfo( - error(node, message, name), + error2(node, message, name), isType ? void 0 : typeOnlyAlias, name ); } - if (isType && node.kind === 270 /* ImportEqualsDeclaration */ && hasEffectiveModifier(node, 1 /* Export */)) { - error(node, Diagnostics.Cannot_use_export_import_on_a_type_or_type_only_namespace_when_0_is_enabled, isolatedModulesLikeFlagName); + if (isType && node.kind === 271 /* ImportEqualsDeclaration */ && hasEffectiveModifier(node, 32 /* Export */)) { + error2(node, Diagnostics.Cannot_use_export_import_on_a_type_or_type_only_namespace_when_0_is_enabled, isolatedModulesLikeFlagName); } break; } - case 280 /* ExportSpecifier */: { + case 281 /* ExportSpecifier */: { if (compilerOptions.verbatimModuleSyntax || getSourceFileOfNode(typeOnlyAlias) !== getSourceFileOfNode(node)) { const name = idText(node.propertyName || node.name); - const diagnostic = isType ? error(node, Diagnostics.Re_exporting_a_type_when_0_is_enabled_requires_using_export_type, isolatedModulesLikeFlagName) : error(node, Diagnostics._0_resolves_to_a_type_only_declaration_and_must_be_re_exported_using_a_type_only_re_export_when_1_is_enabled, name, isolatedModulesLikeFlagName); + const diagnostic = isType ? error2(node, Diagnostics.Re_exporting_a_type_when_0_is_enabled_requires_using_export_type, isolatedModulesLikeFlagName) : error2(node, Diagnostics._0_resolves_to_a_type_only_declaration_and_must_be_re_exported_using_a_type_only_re_export_when_1_is_enabled, name, isolatedModulesLikeFlagName); addTypeOnlyDeclarationRelatedInfo(diagnostic, isType ? void 0 : typeOnlyAlias, name); break; } } } } - if (compilerOptions.verbatimModuleSyntax && node.kind !== 270 /* ImportEqualsDeclaration */ && !isInJSFile(node) && (moduleKind === 1 /* CommonJS */ || getSourceFileOfNode(node).impliedNodeFormat === 1 /* CommonJS */)) { - error(node, Diagnostics.ESM_syntax_is_not_allowed_in_a_CommonJS_module_when_verbatimModuleSyntax_is_enabled); + if (compilerOptions.verbatimModuleSyntax && node.kind !== 271 /* ImportEqualsDeclaration */ && !isInJSFile(node) && (moduleKind === 1 /* CommonJS */ || getSourceFileOfNode(node).impliedNodeFormat === 1 /* CommonJS */)) { + error2(node, Diagnostics.ESM_syntax_is_not_allowed_in_a_CommonJS_module_when_verbatimModuleSyntax_is_enabled); } } if (isImportSpecifier(node)) { @@ -180697,36 +164665,30 @@ ${lanes.join("\n")} function checkImportBinding(node) { checkCollisionsForDeclarationName(node, node.name); checkAliasSymbol(node); - if (node.kind === 275 /* ImportSpecifier */ && idText(node.propertyName || node.name) === "default" && getESModuleInterop(compilerOptions) && moduleKind !== 4 /* System */ && (moduleKind < 5 /* ES2015 */ || getSourceFileOfNode(node).impliedNodeFormat === 1 /* CommonJS */)) { + if (node.kind === 276 /* ImportSpecifier */ && idText(node.propertyName || node.name) === "default" && getESModuleInterop(compilerOptions) && moduleKind !== 4 /* System */ && (moduleKind < 5 /* ES2015 */ || getSourceFileOfNode(node).impliedNodeFormat === 1 /* CommonJS */)) { checkExternalEmitHelpers(node, 131072 /* ImportDefault */); } } - function checkAssertClause(declaration) { + function checkImportAttributes(declaration) { var _a; - if (declaration.assertClause) { - const validForTypeAssertions = isExclusivelyTypeOnlyImportOrExport(declaration); - const override = getResolutionModeOverrideForClause(declaration.assertClause, validForTypeAssertions ? grammarErrorOnNode : void 0); - if (validForTypeAssertions && override) { - if (!isNightly()) { - grammarErrorOnNode(declaration.assertClause, Diagnostics.resolution_mode_assertions_are_unstable_Use_nightly_TypeScript_to_silence_this_error_Try_updating_with_npm_install_D_typescript_next); - } - if (getEmitModuleResolutionKind(compilerOptions) !== 3 /* Node16 */ && getEmitModuleResolutionKind(compilerOptions) !== 99 /* NodeNext */) { - return grammarErrorOnNode(declaration.assertClause, Diagnostics.resolution_mode_assertions_are_only_supported_when_moduleResolution_is_node16_or_nodenext); - } + const node = declaration.attributes; + if (node) { + const validForTypeAttributes = isExclusivelyTypeOnlyImportOrExport(declaration); + const override = getResolutionModeOverride(node, validForTypeAttributes ? grammarErrorOnNode : void 0); + const isImportAttributes2 = declaration.attributes.token === 118 /* WithKeyword */; + if (validForTypeAttributes && override) { return; } const mode = moduleKind === 199 /* NodeNext */ && declaration.moduleSpecifier && getUsageModeForExpression(declaration.moduleSpecifier); if (mode !== 99 /* ESNext */ && moduleKind !== 99 /* ESNext */) { - return grammarErrorOnNode( - declaration.assertClause, - moduleKind === 199 /* NodeNext */ ? Diagnostics.Import_assertions_are_not_allowed_on_statements_that_transpile_to_commonjs_require_calls : Diagnostics.Import_assertions_are_only_supported_when_the_module_option_is_set_to_esnext_or_nodenext - ); + const message = isImportAttributes2 ? moduleKind === 199 /* NodeNext */ ? Diagnostics.Import_attributes_are_not_allowed_on_statements_that_compile_to_CommonJS_require_calls : Diagnostics.Import_attributes_are_only_supported_when_the_module_option_is_set_to_esnext_or_nodenext : moduleKind === 199 /* NodeNext */ ? Diagnostics.Import_assertions_are_not_allowed_on_statements_that_compile_to_CommonJS_require_calls : Diagnostics.Import_assertions_are_only_supported_when_the_module_option_is_set_to_esnext_or_nodenext; + return grammarErrorOnNode(node, message); } if (isImportDeclaration(declaration) ? (_a = declaration.importClause) == null ? void 0 : _a.isTypeOnly : declaration.isTypeOnly) { - return grammarErrorOnNode(declaration.assertClause, Diagnostics.Import_assertions_cannot_be_used_with_type_only_imports_or_exports); + return grammarErrorOnNode(node, isImportAttributes2 ? Diagnostics.Import_attributes_cannot_be_used_with_type_only_imports_or_exports : Diagnostics.Import_assertions_cannot_be_used_with_type_only_imports_or_exports); } if (override) { - return grammarErrorOnNode(declaration.assertClause, Diagnostics.resolution_mode_can_only_be_set_for_type_only_imports); + return grammarErrorOnNode(node, Diagnostics.resolution_mode_can_only_be_set_for_type_only_imports); } } } @@ -180744,7 +164706,7 @@ ${lanes.join("\n")} checkImportBinding(importClause); } if (importClause.namedBindings) { - if (importClause.namedBindings.kind === 273 /* NamespaceImport */) { + if (importClause.namedBindings.kind === 274 /* NamespaceImport */) { checkImportBinding(importClause.namedBindings); if (moduleKind !== 4 /* System */ && (moduleKind < 5 /* ES2015 */ || getSourceFileOfNode(node).impliedNodeFormat === 1 /* CommonJS */) && getESModuleInterop(compilerOptions)) { checkExternalEmitHelpers(node, 65536 /* ImportStar */); @@ -180758,7 +164720,7 @@ ${lanes.join("\n")} } } } - checkAssertClause(node); + checkImportAttributes(node); } function checkImportEqualsDeclaration(node) { if (checkGrammarModuleElementContext(node, isInJSFile(node) ? Diagnostics.An_import_declaration_can_only_be_used_at_the_top_level_of_a_module : Diagnostics.An_import_declaration_can_only_be_used_at_the_top_level_of_a_namespace_or_module)) { @@ -180767,17 +164729,17 @@ ${lanes.join("\n")} checkGrammarModifiers(node); if (isInternalModuleImportEqualsDeclaration(node) || checkExternalImportOrExportDeclaration(node)) { checkImportBinding(node); - if (hasSyntacticModifier(node, 1 /* Export */)) { + if (hasSyntacticModifier(node, 32 /* Export */)) { markExportAsReferenced(node); } - if (node.moduleReference.kind !== 282 /* ExternalModuleReference */) { + if (node.moduleReference.kind !== 283 /* ExternalModuleReference */) { const target = resolveAlias(getSymbolOfDeclaration(node)); if (target !== unknownSymbol) { - const targetFlags = getAllSymbolFlags(target); + const targetFlags = getSymbolFlags(target); if (targetFlags & 111551 /* Value */) { const moduleName = getFirstIdentifier(node.moduleReference); if (!(resolveEntityName(moduleName, 111551 /* Value */ | 1920 /* Namespace */).flags & 1920 /* Namespace */)) { - error(moduleName, Diagnostics.Module_0_is_hidden_by_a_local_declaration_with_the_same_name, declarationNameToString(moduleName)); + error2(moduleName, Diagnostics.Module_0_is_hidden_by_a_local_declaration_with_the_same_name, declarationNameToString(moduleName)); } } if (targetFlags & 788968 /* Type */) { @@ -180788,7 +164750,7 @@ ${lanes.join("\n")} grammarErrorOnNode(node, Diagnostics.An_import_alias_cannot_use_import_type); } } else { - if (moduleKind >= 5 /* ES2015 */ && getSourceFileOfNode(node).impliedNodeFormat === void 0 && !node.isTypeOnly && !(node.flags & 16777216 /* Ambient */)) { + if (moduleKind >= 5 /* ES2015 */ && getSourceFileOfNode(node).impliedNodeFormat === void 0 && !node.isTypeOnly && !(node.flags & 33554432 /* Ambient */)) { grammarErrorOnNode(node, Diagnostics.Import_assignment_cannot_be_used_when_targeting_ECMAScript_modules_Consider_using_import_Asterisk_as_ns_from_mod_import_a_from_mod_import_d_from_mod_or_another_module_format_instead); } } @@ -180808,15 +164770,15 @@ ${lanes.join("\n")} if (!node.moduleSpecifier || checkExternalImportOrExportDeclaration(node)) { if (node.exportClause && !isNamespaceExport(node.exportClause)) { forEach(node.exportClause.elements, checkExportSpecifier); - const inAmbientExternalModule = node.parent.kind === 267 /* ModuleBlock */ && isAmbientModule(node.parent.parent); - const inAmbientNamespaceDeclaration = !inAmbientExternalModule && node.parent.kind === 267 /* ModuleBlock */ && !node.moduleSpecifier && node.flags & 16777216 /* Ambient */; - if (node.parent.kind !== 311 /* SourceFile */ && !inAmbientExternalModule && !inAmbientNamespaceDeclaration) { - error(node, Diagnostics.Export_declarations_are_not_permitted_in_a_namespace); + const inAmbientExternalModule = node.parent.kind === 268 /* ModuleBlock */ && isAmbientModule(node.parent.parent); + const inAmbientNamespaceDeclaration = !inAmbientExternalModule && node.parent.kind === 268 /* ModuleBlock */ && !node.moduleSpecifier && node.flags & 33554432 /* Ambient */; + if (node.parent.kind !== 312 /* SourceFile */ && !inAmbientExternalModule && !inAmbientNamespaceDeclaration) { + error2(node, Diagnostics.Export_declarations_are_not_permitted_in_a_namespace); } } else { const moduleSymbol = resolveExternalModuleName(node, node.moduleSpecifier); if (moduleSymbol && hasExportAssignmentSymbol(moduleSymbol)) { - error(node.moduleSpecifier, Diagnostics.Module_0_uses_export_and_cannot_be_used_with_export_Asterisk, symbolToString(moduleSymbol)); + error2(node.moduleSpecifier, Diagnostics.Module_0_uses_export_and_cannot_be_used_with_export_Asterisk, symbolToString(moduleSymbol)); } else if (node.exportClause) { checkAliasSymbol(node.exportClause); } @@ -180831,17 +164793,17 @@ ${lanes.join("\n")} } } } - checkAssertClause(node); + checkImportAttributes(node); } function checkGrammarExportDeclaration(node) { var _a; - if (node.isTypeOnly && ((_a = node.exportClause) == null ? void 0 : _a.kind) === 278 /* NamedExports */) { + if (node.isTypeOnly && ((_a = node.exportClause) == null ? void 0 : _a.kind) === 279 /* NamedExports */) { return checkGrammarNamedImportsOrExports(node.exportClause); } return false; } function checkGrammarModuleElementContext(node, errorMessage) { - const isInAppropriateContext = node.parent.kind === 311 /* SourceFile */ || node.parent.kind === 267 /* ModuleBlock */ || node.parent.kind === 266 /* ModuleDeclaration */; + const isInAppropriateContext = node.parent.kind === 312 /* SourceFile */ || node.parent.kind === 268 /* ModuleBlock */ || node.parent.kind === 267 /* ModuleDeclaration */; if (!isInAppropriateContext) { grammarErrorOnFirstToken(node, errorMessage); } @@ -180877,7 +164839,7 @@ ${lanes.join("\n")} } for (const statement of sourceFile.statements) { if (canConvertImportDeclarationToTypeOnly(statement) || canConvertImportEqualsDeclarationToTypeOnly(statement)) { - error( + error2( statement, Diagnostics.This_import_is_never_used_as_a_value_and_must_use_import_type_because_importsNotUsedAsValues_is_set_to_error ); @@ -180907,13 +164869,13 @@ ${lanes.join("\n")} true ); if (symbol && (symbol === undefinedSymbol || symbol === globalThisSymbol || symbol.declarations && isGlobalSourceFile(getDeclarationContainer(symbol.declarations[0])))) { - error(exportedName, Diagnostics.Cannot_export_0_Only_local_declarations_can_be_exported_from_a_module, idText(exportedName)); + error2(exportedName, Diagnostics.Cannot_export_0_Only_local_declarations_can_be_exported_from_a_module, idText(exportedName)); } else { if (!node.isTypeOnly && !node.parent.parent.isTypeOnly) { markExportAsReferenced(node); } const target = symbol && (symbol.flags & 2097152 /* Alias */ ? resolveAlias(symbol) : symbol); - if (!target || getAllSymbolFlags(target) & 111551 /* Value */) { + if (!target || getSymbolFlags(target) & 111551 /* Value */) { checkExpressionCached(node.propertyName || node.name); } } @@ -180928,12 +164890,12 @@ ${lanes.join("\n")} if (checkGrammarModuleElementContext(node, illegalContextMessage)) { return; } - const container = node.parent.kind === 311 /* SourceFile */ ? node.parent : node.parent.parent; - if (container.kind === 266 /* ModuleDeclaration */ && !isAmbientModule(container)) { + const container = node.parent.kind === 312 /* SourceFile */ ? node.parent : node.parent.parent; + if (container.kind === 267 /* ModuleDeclaration */ && !isAmbientModule(container)) { if (node.isExportEquals) { - error(node, Diagnostics.An_export_assignment_cannot_be_used_in_a_namespace); + error2(node, Diagnostics.An_export_assignment_cannot_be_used_in_a_namespace); } else { - error(node, Diagnostics.A_default_export_can_only_be_used_in_an_ECMAScript_style_module); + error2(node, Diagnostics.A_default_export_can_only_be_used_in_an_ECMAScript_style_module); } return; } @@ -180944,7 +164906,7 @@ ${lanes.join("\n")} if (typeAnnotationNode) { checkTypeAssignableTo(checkExpressionCached(node.expression), getTypeFromTypeNode(typeAnnotationNode), node.expression); } - const isIllegalExportDefaultInCJS = !node.isExportEquals && !(node.flags & 16777216 /* Ambient */) && compilerOptions.verbatimModuleSyntax && (moduleKind === 1 /* CommonJS */ || getSourceFileOfNode(node).impliedNodeFormat === 1 /* CommonJS */); + const isIllegalExportDefaultInCJS = !node.isExportEquals && !(node.flags & 33554432 /* Ambient */) && compilerOptions.verbatimModuleSyntax && (moduleKind === 1 /* CommonJS */ || getSourceFileOfNode(node).impliedNodeFormat === 1 /* CommonJS */); if (node.expression.kind === 80 /* Identifier */) { const id = node.expression; const sym = getExportSymbolOfValueSymbolIfExported(resolveEntityName( @@ -180958,17 +164920,17 @@ ${lanes.join("\n")} )); if (sym) { markAliasReferenced(sym, id); - if (getAllSymbolFlags(sym) & 111551 /* Value */) { + if (getSymbolFlags(sym) & 111551 /* Value */) { checkExpressionCached(id); - if (!isIllegalExportDefaultInCJS && !(node.flags & 16777216 /* Ambient */) && compilerOptions.verbatimModuleSyntax && getTypeOnlyAliasDeclaration(sym, 111551 /* Value */)) { - error( + if (!isIllegalExportDefaultInCJS && !(node.flags & 33554432 /* Ambient */) && compilerOptions.verbatimModuleSyntax && getTypeOnlyAliasDeclaration(sym, 111551 /* Value */)) { + error2( id, node.isExportEquals ? Diagnostics.An_export_declaration_must_reference_a_real_value_when_verbatimModuleSyntax_is_enabled_but_0_resolves_to_a_type_only_declaration : Diagnostics.An_export_default_must_reference_a_real_value_when_verbatimModuleSyntax_is_enabled_but_0_resolves_to_a_type_only_declaration, idText(id) ); } - } else if (!isIllegalExportDefaultInCJS && !(node.flags & 16777216 /* Ambient */) && compilerOptions.verbatimModuleSyntax) { - error( + } else if (!isIllegalExportDefaultInCJS && !(node.flags & 33554432 /* Ambient */) && compilerOptions.verbatimModuleSyntax) { + error2( id, node.isExportEquals ? Diagnostics.An_export_declaration_must_reference_a_value_when_verbatimModuleSyntax_is_enabled_but_0_only_refers_to_a_type : Diagnostics.An_export_default_must_reference_a_value_when_verbatimModuleSyntax_is_enabled_but_0_only_refers_to_a_type, idText(id) @@ -180988,16 +164950,16 @@ ${lanes.join("\n")} checkExpressionCached(node.expression); } if (isIllegalExportDefaultInCJS) { - error(node, Diagnostics.ESM_syntax_is_not_allowed_in_a_CommonJS_module_when_verbatimModuleSyntax_is_enabled); + error2(node, Diagnostics.ESM_syntax_is_not_allowed_in_a_CommonJS_module_when_verbatimModuleSyntax_is_enabled); } checkExternalModuleExports(container); - if (node.flags & 16777216 /* Ambient */ && !isEntityNameExpression(node.expression)) { + if (node.flags & 33554432 /* Ambient */ && !isEntityNameExpression(node.expression)) { grammarErrorOnNode(node.expression, Diagnostics.The_expression_of_an_export_assignment_must_be_an_identifier_or_qualified_name_in_an_ambient_context); } if (node.isExportEquals) { - if (moduleKind >= 5 /* ES2015 */ && (node.flags & 16777216 /* Ambient */ && getSourceFileOfNode(node).impliedNodeFormat === 99 /* ESNext */ || !(node.flags & 16777216 /* Ambient */) && getSourceFileOfNode(node).impliedNodeFormat !== 1 /* CommonJS */)) { + if (moduleKind >= 5 /* ES2015 */ && (node.flags & 33554432 /* Ambient */ && getSourceFileOfNode(node).impliedNodeFormat === 99 /* ESNext */ || !(node.flags & 33554432 /* Ambient */) && getSourceFileOfNode(node).impliedNodeFormat !== 1 /* CommonJS */)) { grammarErrorOnNode(node, Diagnostics.Export_assignment_cannot_be_used_when_targeting_ECMAScript_modules_Consider_using_export_default_or_another_module_format_instead); - } else if (moduleKind === 4 /* System */ && !(node.flags & 16777216 /* Ambient */)) { + } else if (moduleKind === 4 /* System */ && !(node.flags & 33554432 /* Ambient */)) { grammarErrorOnNode(node, Diagnostics.Export_assignment_is_not_supported_when_module_flag_is_system); } } @@ -181013,7 +164975,7 @@ ${lanes.join("\n")} if (exportEqualsSymbol && hasExportedMembers(moduleSymbol)) { const declaration = getDeclarationOfAliasSymbol(exportEqualsSymbol) || exportEqualsSymbol.valueDeclaration; if (declaration && !isTopLevelInExternalModuleAugmentation(declaration) && !isInJSFile(declaration)) { - error(declaration, Diagnostics.An_export_assignment_cannot_be_used_in_a_module_with_other_exported_elements); + error2(declaration, Diagnostics.An_export_assignment_cannot_be_used_in_a_module_with_other_exported_elements); } } const exports = getExportsOfModule(moduleSymbol); @@ -181070,182 +165032,184 @@ ${lanes.join("\n")} const kind = node.kind; if (cancellationToken) { switch (kind) { - case 266 /* ModuleDeclaration */: - case 262 /* ClassDeclaration */: - case 263 /* InterfaceDeclaration */: - case 261 /* FunctionDeclaration */: + case 267 /* ModuleDeclaration */: + case 263 /* ClassDeclaration */: + case 264 /* InterfaceDeclaration */: + case 262 /* FunctionDeclaration */: cancellationToken.throwIfCancellationRequested(); } } - if (kind >= 242 /* FirstStatement */ && kind <= 258 /* LastStatement */ && canHaveFlowNode(node) && node.flowNode && !isReachableFlowNode(node.flowNode)) { + if (kind >= 243 /* FirstStatement */ && kind <= 259 /* LastStatement */ && canHaveFlowNode(node) && node.flowNode && !isReachableFlowNode(node.flowNode)) { errorOrSuggestion(compilerOptions.allowUnreachableCode === false, node, Diagnostics.Unreachable_code_detected); } switch (kind) { - case 167 /* TypeParameter */: + case 168 /* TypeParameter */: return checkTypeParameter(node); - case 168 /* Parameter */: + case 169 /* Parameter */: return checkParameter(node); - case 171 /* PropertyDeclaration */: + case 172 /* PropertyDeclaration */: return checkPropertyDeclaration(node); - case 170 /* PropertySignature */: + case 171 /* PropertySignature */: return checkPropertySignature(node); - case 184 /* ConstructorType */: - case 183 /* FunctionType */: - case 178 /* CallSignature */: - case 179 /* ConstructSignature */: - case 180 /* IndexSignature */: + case 185 /* ConstructorType */: + case 184 /* FunctionType */: + case 179 /* CallSignature */: + case 180 /* ConstructSignature */: + case 181 /* IndexSignature */: return checkSignatureDeclaration(node); - case 173 /* MethodDeclaration */: - case 172 /* MethodSignature */: + case 174 /* MethodDeclaration */: + case 173 /* MethodSignature */: return checkMethodDeclaration(node); - case 174 /* ClassStaticBlockDeclaration */: + case 175 /* ClassStaticBlockDeclaration */: return checkClassStaticBlockDeclaration(node); - case 175 /* Constructor */: + case 176 /* Constructor */: return checkConstructorDeclaration(node); - case 176 /* GetAccessor */: - case 177 /* SetAccessor */: + case 177 /* GetAccessor */: + case 178 /* SetAccessor */: return checkAccessorDeclaration(node); - case 182 /* TypeReference */: + case 183 /* TypeReference */: return checkTypeReferenceNode(node); - case 181 /* TypePredicate */: + case 182 /* TypePredicate */: return checkTypePredicate(node); - case 185 /* TypeQuery */: + case 186 /* TypeQuery */: return checkTypeQuery(node); - case 186 /* TypeLiteral */: + case 187 /* TypeLiteral */: return checkTypeLiteral(node); - case 187 /* ArrayType */: + case 188 /* ArrayType */: return checkArrayType(node); - case 188 /* TupleType */: + case 189 /* TupleType */: return checkTupleType(node); - case 191 /* UnionType */: - case 192 /* IntersectionType */: + case 192 /* UnionType */: + case 193 /* IntersectionType */: return checkUnionOrIntersectionType(node); - case 195 /* ParenthesizedType */: - case 189 /* OptionalType */: - case 190 /* RestType */: + case 196 /* ParenthesizedType */: + case 190 /* OptionalType */: + case 191 /* RestType */: return checkSourceElement(node.type); - case 196 /* ThisType */: + case 197 /* ThisType */: return checkThisType(node); - case 197 /* TypeOperator */: + case 198 /* TypeOperator */: return checkTypeOperator(node); - case 193 /* ConditionalType */: + case 194 /* ConditionalType */: return checkConditionalType(node); - case 194 /* InferType */: + case 195 /* InferType */: return checkInferType(node); - case 202 /* TemplateLiteralType */: + case 203 /* TemplateLiteralType */: return checkTemplateLiteralType(node); - case 204 /* ImportType */: + case 205 /* ImportType */: return checkImportType(node); - case 201 /* NamedTupleMember */: + case 202 /* NamedTupleMember */: return checkNamedTupleMember(node); - case 334 /* JSDocAugmentsTag */: + case 335 /* JSDocAugmentsTag */: return checkJSDocAugmentsTag(node); - case 335 /* JSDocImplementsTag */: + case 336 /* JSDocImplementsTag */: return checkJSDocImplementsTag(node); - case 352 /* JSDocTypedefTag */: - case 344 /* JSDocCallbackTag */: - case 346 /* JSDocEnumTag */: + case 353 /* JSDocTypedefTag */: + case 345 /* JSDocCallbackTag */: + case 347 /* JSDocEnumTag */: return checkJSDocTypeAliasTag(node); - case 351 /* JSDocTemplateTag */: + case 352 /* JSDocTemplateTag */: return checkJSDocTemplateTag(node); - case 350 /* JSDocTypeTag */: + case 351 /* JSDocTypeTag */: return checkJSDocTypeTag(node); - case 330 /* JSDocLink */: - case 331 /* JSDocLinkCode */: - case 332 /* JSDocLinkPlain */: + case 331 /* JSDocLink */: + case 332 /* JSDocLinkCode */: + case 333 /* JSDocLinkPlain */: return checkJSDocLinkLikeTag(node); - case 347 /* JSDocParameterTag */: + case 348 /* JSDocParameterTag */: return checkJSDocParameterTag(node); - case 354 /* JSDocPropertyTag */: + case 355 /* JSDocPropertyTag */: return checkJSDocPropertyTag(node); - case 323 /* JSDocFunctionType */: + case 324 /* JSDocFunctionType */: checkJSDocFunctionType(node); - case 321 /* JSDocNonNullableType */: - case 320 /* JSDocNullableType */: - case 318 /* JSDocAllType */: - case 319 /* JSDocUnknownType */: - case 328 /* JSDocTypeLiteral */: + case 322 /* JSDocNonNullableType */: + case 321 /* JSDocNullableType */: + case 319 /* JSDocAllType */: + case 320 /* JSDocUnknownType */: + case 329 /* JSDocTypeLiteral */: checkJSDocTypeIsInJsFile(node); forEachChild(node, checkSourceElement); return; - case 324 /* JSDocVariadicType */: + case 325 /* JSDocVariadicType */: checkJSDocVariadicType(node); return; - case 315 /* JSDocTypeExpression */: + case 316 /* JSDocTypeExpression */: return checkSourceElement(node.type); - case 339 /* JSDocPublicTag */: - case 341 /* JSDocProtectedTag */: - case 340 /* JSDocPrivateTag */: + case 340 /* JSDocPublicTag */: + case 342 /* JSDocProtectedTag */: + case 341 /* JSDocPrivateTag */: return checkJSDocAccessibilityModifiers(node); - case 356 /* JSDocSatisfiesTag */: + case 357 /* JSDocSatisfiesTag */: return checkJSDocSatisfiesTag(node); - case 198 /* IndexedAccessType */: + case 350 /* JSDocThisTag */: + return checkJSDocThisTag(node); + case 199 /* IndexedAccessType */: return checkIndexedAccessType(node); - case 199 /* MappedType */: + case 200 /* MappedType */: return checkMappedType(node); - case 261 /* FunctionDeclaration */: + case 262 /* FunctionDeclaration */: return checkFunctionDeclaration(node); - case 240 /* Block */: - case 267 /* ModuleBlock */: + case 241 /* Block */: + case 268 /* ModuleBlock */: return checkBlock(node); - case 242 /* VariableStatement */: + case 243 /* VariableStatement */: return checkVariableStatement(node); - case 243 /* ExpressionStatement */: + case 244 /* ExpressionStatement */: return checkExpressionStatement(node); - case 244 /* IfStatement */: + case 245 /* IfStatement */: return checkIfStatement(node); - case 245 /* DoStatement */: + case 246 /* DoStatement */: return checkDoStatement(node); - case 246 /* WhileStatement */: + case 247 /* WhileStatement */: return checkWhileStatement(node); - case 247 /* ForStatement */: + case 248 /* ForStatement */: return checkForStatement(node); - case 248 /* ForInStatement */: + case 249 /* ForInStatement */: return checkForInStatement(node); - case 249 /* ForOfStatement */: + case 250 /* ForOfStatement */: return checkForOfStatement(node); - case 250 /* ContinueStatement */: - case 251 /* BreakStatement */: + case 251 /* ContinueStatement */: + case 252 /* BreakStatement */: return checkBreakOrContinueStatement(node); - case 252 /* ReturnStatement */: + case 253 /* ReturnStatement */: return checkReturnStatement(node); - case 253 /* WithStatement */: + case 254 /* WithStatement */: return checkWithStatement(node); - case 254 /* SwitchStatement */: + case 255 /* SwitchStatement */: return checkSwitchStatement(node); - case 255 /* LabeledStatement */: + case 256 /* LabeledStatement */: return checkLabeledStatement(node); - case 256 /* ThrowStatement */: + case 257 /* ThrowStatement */: return checkThrowStatement(node); - case 257 /* TryStatement */: + case 258 /* TryStatement */: return checkTryStatement(node); - case 259 /* VariableDeclaration */: + case 260 /* VariableDeclaration */: return checkVariableDeclaration(node); - case 207 /* BindingElement */: + case 208 /* BindingElement */: return checkBindingElement(node); - case 262 /* ClassDeclaration */: + case 263 /* ClassDeclaration */: return checkClassDeclaration(node); - case 263 /* InterfaceDeclaration */: + case 264 /* InterfaceDeclaration */: return checkInterfaceDeclaration(node); - case 264 /* TypeAliasDeclaration */: + case 265 /* TypeAliasDeclaration */: return checkTypeAliasDeclaration(node); - case 265 /* EnumDeclaration */: + case 266 /* EnumDeclaration */: return checkEnumDeclaration(node); - case 266 /* ModuleDeclaration */: + case 267 /* ModuleDeclaration */: return checkModuleDeclaration(node); - case 271 /* ImportDeclaration */: + case 272 /* ImportDeclaration */: return checkImportDeclaration(node); - case 270 /* ImportEqualsDeclaration */: + case 271 /* ImportEqualsDeclaration */: return checkImportEqualsDeclaration(node); - case 277 /* ExportDeclaration */: + case 278 /* ExportDeclaration */: return checkExportDeclaration(node); - case 276 /* ExportAssignment */: + case 277 /* ExportAssignment */: return checkExportAssignment(node); - case 241 /* EmptyStatement */: - case 258 /* DebuggerStatement */: + case 242 /* EmptyStatement */: + case 259 /* DebuggerStatement */: checkGrammarStatementInAmbientContext(node); return; - case 281 /* MissingDeclaration */: + case 282 /* MissingDeclaration */: return checkMissingDeclaration(node); } } @@ -181265,9 +165229,14 @@ ${lanes.join("\n")} const diagnostic = node.postfix ? Diagnostics._0_at_the_end_of_a_type_is_not_valid_TypeScript_syntax_Did_you_mean_to_write_1 : Diagnostics._0_at_the_start_of_a_type_is_not_valid_TypeScript_syntax_Did_you_mean_to_write_1; const typeNode = node.type; const type = getTypeFromTypeNode(typeNode); - grammarErrorOnNode(node, diagnostic, token, typeToString( - isJSDocNullableType(node) && !(type === neverType || type === voidType) ? getUnionType(append([type, undefinedType], node.postfix ? void 0 : nullType)) : type - )); + grammarErrorOnNode( + node, + diagnostic, + token, + typeToString( + isJSDocNullableType(node) && !(type === neverType || type === voidType) ? getUnionType(append([type, undefinedType], node.postfix ? void 0 : nullType)) : type + ) + ); } else { grammarErrorOnNode(node, Diagnostics.JSDoc_types_can_only_be_used_inside_documentation_comments); } @@ -181279,16 +165248,16 @@ ${lanes.join("\n")} const { parent: parent2 } = node; if (isParameter(parent2) && isJSDocFunctionType(parent2.parent)) { if (last(parent2.parent.parameters) !== parent2) { - error(node, Diagnostics.A_rest_parameter_must_be_last_in_a_parameter_list); + error2(node, Diagnostics.A_rest_parameter_must_be_last_in_a_parameter_list); } return; } if (!isJSDocTypeExpression(parent2)) { - error(node, Diagnostics.JSDoc_may_only_appear_in_the_last_parameter_of_a_signature); + error2(node, Diagnostics.JSDoc_may_only_appear_in_the_last_parameter_of_a_signature); } const paramTag = node.parent.parent; if (!isJSDocParameterTag(paramTag)) { - error(node, Diagnostics.JSDoc_may_only_appear_in_the_last_parameter_of_a_signature); + error2(node, Diagnostics.JSDoc_may_only_appear_in_the_last_parameter_of_a_signature); return; } const param = getParameterSymbolFromJSDoc(paramTag); @@ -181297,7 +165266,7 @@ ${lanes.join("\n")} } const host2 = getHostSignatureFromJSDoc(paramTag); if (!host2 || last(host2.parameters).symbol !== param) { - error(node, Diagnostics.A_rest_parameter_must_be_last_in_a_parameter_list); + error2(node, Diagnostics.A_rest_parameter_must_be_last_in_a_parameter_list); } } function getTypeFromJSDocVariadicType(node) { @@ -181344,39 +165313,48 @@ ${lanes.join("\n")} currentNode = node; instantiationCount = 0; switch (node.kind) { - case 212 /* CallExpression */: - case 213 /* NewExpression */: - case 214 /* TaggedTemplateExpression */: - case 169 /* Decorator */: - case 285 /* JsxOpeningElement */: + case 213 /* CallExpression */: + case 214 /* NewExpression */: + case 215 /* TaggedTemplateExpression */: + case 170 /* Decorator */: + case 286 /* JsxOpeningElement */: resolveUntypedCall(node); break; - case 217 /* FunctionExpression */: - case 218 /* ArrowFunction */: - case 173 /* MethodDeclaration */: - case 172 /* MethodSignature */: + case 218 /* FunctionExpression */: + case 219 /* ArrowFunction */: + case 174 /* MethodDeclaration */: + case 173 /* MethodSignature */: checkFunctionExpressionOrObjectLiteralMethodDeferred(node); break; - case 176 /* GetAccessor */: - case 177 /* SetAccessor */: + case 177 /* GetAccessor */: + case 178 /* SetAccessor */: checkAccessorDeclaration(node); break; - case 230 /* ClassExpression */: + case 231 /* ClassExpression */: checkClassExpressionDeferred(node); break; - case 167 /* TypeParameter */: + case 168 /* TypeParameter */: checkTypeParameterDeferred(node); break; - case 284 /* JsxSelfClosingElement */: + case 285 /* JsxSelfClosingElement */: checkJsxSelfClosingElementDeferred(node); break; - case 283 /* JsxElement */: + case 284 /* JsxElement */: checkJsxElementDeferred(node); break; - case 215 /* TypeAssertionExpression */: - case 233 /* AsExpression */: - case 216 /* ParenthesizedExpression */: + case 216 /* TypeAssertionExpression */: + case 234 /* AsExpression */: + case 217 /* ParenthesizedExpression */: checkAssertionDeferred(node); + break; + case 222 /* VoidExpression */: + checkExpression(node.expression); + break; + case 226 /* BinaryExpression */: + if (isInstanceOfExpression(node)) { + resolveUntypedCall(node); + } + break; } currentNode = saveCurrentNode; (_b = tracing) == null ? void 0 : _b.pop(); @@ -181433,7 +165411,7 @@ ${lanes.join("\n")} addLazyDiagnostic(() => { if (!node.isDeclarationFile && (compilerOptions.noUnusedLocals || compilerOptions.noUnusedParameters)) { checkUnusedIdentifiers(getPotentiallyUnusedIdentifiers(node), (containingNode, kind, diag2) => { - if (!containsParseError(containingNode) && unusedIsError(kind, !!(containingNode.flags & 16777216 /* Ambient */))) { + if (!containsParseError(containingNode) && unusedIsError(kind, !!(containingNode.flags & 33554432 /* Ambient */))) { diagnostics.add(diag2); } }); @@ -181512,7 +165490,7 @@ ${lanes.join("\n")} return diagnostics.getGlobalDiagnostics(); } function getSymbolsInScope(location, meaning) { - if (location.flags & 33554432 /* InWithStatement */) { + if (location.flags & 67108864 /* InWithStatement */) { return []; } const symbols = createSymbolTable(); @@ -181526,27 +165504,27 @@ ${lanes.join("\n")} copySymbols(location.locals, meaning); } switch (location.kind) { - case 311 /* SourceFile */: + case 312 /* SourceFile */: if (!isExternalModule(location)) break; - case 266 /* ModuleDeclaration */: + case 267 /* ModuleDeclaration */: copyLocallyVisibleExportSymbols(getSymbolOfDeclaration(location).exports, meaning & 2623475 /* ModuleMember */); break; - case 265 /* EnumDeclaration */: + case 266 /* EnumDeclaration */: copySymbols(getSymbolOfDeclaration(location).exports, meaning & 8 /* EnumMember */); break; - case 230 /* ClassExpression */: + case 231 /* ClassExpression */: const className = location.name; if (className) { copySymbol(location.symbol, meaning); } - case 262 /* ClassDeclaration */: - case 263 /* InterfaceDeclaration */: + case 263 /* ClassDeclaration */: + case 264 /* InterfaceDeclaration */: if (!isStaticSymbol) { copySymbols(getMembersOfSymbol(getSymbolOfDeclaration(location)), meaning & 788968 /* Type */); } break; - case 217 /* FunctionExpression */: + case 218 /* FunctionExpression */: const funcName = location.name; if (funcName) { copySymbol(location.symbol, meaning); @@ -181579,7 +165557,7 @@ ${lanes.join("\n")} function copyLocallyVisibleExportSymbols(source, meaning2) { if (meaning2) { source.forEach((symbol) => { - if (!getDeclarationOfKind(symbol, 280 /* ExportSpecifier */) && !getDeclarationOfKind(symbol, 279 /* NamespaceExport */)) { + if (!getDeclarationOfKind(symbol, 281 /* ExportSpecifier */) && !getDeclarationOfKind(symbol, 280 /* NamespaceExport */) && symbol.escapedName !== "default" /* Default */) { copySymbol(symbol, meaning2); } }); @@ -181590,16 +165568,16 @@ ${lanes.join("\n")} return name.kind === 80 /* Identifier */ && isTypeDeclaration(name.parent) && getNameOfDeclaration(name.parent) === name; } function isTypeReferenceIdentifier(node) { - while (node.parent.kind === 165 /* QualifiedName */) { + while (node.parent.kind === 166 /* QualifiedName */) { node = node.parent; } - return node.parent.kind === 182 /* TypeReference */; + return node.parent.kind === 183 /* TypeReference */; } function isInNameOfExpressionWithTypeArguments(node) { - while (node.parent.kind === 210 /* PropertyAccessExpression */) { + while (node.parent.kind === 211 /* PropertyAccessExpression */) { node = node.parent; } - return node.parent.kind === 232 /* ExpressionWithTypeArguments */; + return node.parent.kind === 233 /* ExpressionWithTypeArguments */; } function forEachEnclosingClass(node, callback) { let result; @@ -181625,13 +165603,13 @@ ${lanes.join("\n")} return !!forEachEnclosingClass(node, (n) => n === classDeclaration); } function getLeftSideOfImportEqualsOrExportAssignment(nodeOnRightSide) { - while (nodeOnRightSide.parent.kind === 165 /* QualifiedName */) { + while (nodeOnRightSide.parent.kind === 166 /* QualifiedName */) { nodeOnRightSide = nodeOnRightSide.parent; } - if (nodeOnRightSide.parent.kind === 270 /* ImportEqualsDeclaration */) { + if (nodeOnRightSide.parent.kind === 271 /* ImportEqualsDeclaration */) { return nodeOnRightSide.parent.moduleReference === nodeOnRightSide ? nodeOnRightSide.parent : void 0; } - if (nodeOnRightSide.parent.kind === 276 /* ExportAssignment */) { + if (nodeOnRightSide.parent.kind === 277 /* ExportAssignment */) { return nodeOnRightSide.parent.expression === nodeOnRightSide ? nodeOnRightSide.parent : void 0; } return void 0; @@ -181657,7 +165635,7 @@ ${lanes.join("\n")} node = parent2; parent2 = parent2.parent; } - if (parent2 && parent2.kind === 204 /* ImportType */ && parent2.qualifier === node) { + if (parent2 && parent2.kind === 205 /* ImportType */ && parent2.qualifier === node) { return parent2; } return void 0; @@ -181679,7 +165657,7 @@ ${lanes.join("\n")} /*contextFlags*/ void 0 ); - const type = contextualType && getThisTypeFromContextualType(contextualType); + const type = getThisTypeOfObjectLiteralFromContextualType(containingLiteral, contextualType); return type && !isTypeAny(type); } } @@ -181689,7 +165667,7 @@ ${lanes.join("\n")} if (isDeclarationName(name)) { return getSymbolOfNode(name.parent); } - if (isInJSFile(name) && name.parent.kind === 210 /* PropertyAccessExpression */ && name.parent === name.parent.parent.left) { + if (isInJSFile(name) && name.parent.kind === 211 /* PropertyAccessExpression */ && name.parent === name.parent.parent.left) { if (!isPrivateIdentifier(name) && !isJSDocMemberName(name) && !isThisPropertyAndThisTyped(name.parent)) { const specialPropertyAssignmentSymbol = getSpecialPropertyAssignmentSymbolFromEntityName(name); if (specialPropertyAssignmentSymbol) { @@ -181697,7 +165675,7 @@ ${lanes.join("\n")} } } } - if (name.parent.kind === 276 /* ExportAssignment */ && isEntityNameExpression(name)) { + if (name.parent.kind === 277 /* ExportAssignment */ && isEntityNameExpression(name)) { const success = resolveEntityName( name, /*all meanings*/ @@ -181709,7 +165687,7 @@ ${lanes.join("\n")} return success; } } else if (isEntityName(name) && isInRightSideOfImportOrExportAssignment(name)) { - const importEqualsDeclaration = getAncestor(name, 270 /* ImportEqualsDeclaration */); + const importEqualsDeclaration = getAncestor(name, 271 /* ImportEqualsDeclaration */); Debug.assert(importEqualsDeclaration !== void 0); return getSymbolOfPartOfRightHandSideOfImportEquals( name, @@ -181730,7 +165708,7 @@ ${lanes.join("\n")} } if (isInNameOfExpressionWithTypeArguments(name)) { let meaning = 0 /* None */; - if (name.parent.kind === 232 /* ExpressionWithTypeArguments */) { + if (name.parent.kind === 233 /* ExpressionWithTypeArguments */) { meaning = isPartOfTypeNode(name) ? 788968 /* Type */ : 111551 /* Value */; if (isExpressionWithTypeArgumentsInClassExtendsClause(name.parent)) { meaning |= 111551 /* Value */; @@ -181749,10 +165727,10 @@ ${lanes.join("\n")} return entityNameSymbol; } } - if (name.parent.kind === 347 /* JSDocParameterTag */) { + if (name.parent.kind === 348 /* JSDocParameterTag */) { return getParameterSymbolFromJSDoc(name.parent); } - if (name.parent.kind === 167 /* TypeParameter */ && name.parent.parent.kind === 351 /* JSDocTemplateTag */) { + if (name.parent.kind === 168 /* TypeParameter */ && name.parent.parent.kind === 352 /* JSDocTemplateTag */) { Debug.assert(!isInJSFile(name)); const typeParameter = getTypeParameterFromJsDoc(name.parent); return typeParameter && typeParameter.symbol; @@ -181805,39 +165783,15 @@ ${lanes.join("\n")} return result; } else if (isPrivateIdentifier(name)) { return getSymbolForPrivateIdentifierExpression(name); - } else if (name.kind === 210 /* PropertyAccessExpression */ || name.kind === 165 /* QualifiedName */) { + } else if (name.kind === 211 /* PropertyAccessExpression */ || name.kind === 166 /* QualifiedName */) { const links = getNodeLinks(name); if (links.resolvedSymbol) { return links.resolvedSymbol; } - if (name.kind === 210 /* PropertyAccessExpression */) { + if (name.kind === 211 /* PropertyAccessExpression */) { checkPropertyAccessExpression(name, 0 /* Normal */); if (!links.resolvedSymbol) { - const expressionType = checkExpressionCached(name.expression); - const infos = getApplicableIndexInfos(expressionType, getLiteralTypeFromPropertyName(name.name)); - if (infos.length && expressionType.members) { - const resolved = resolveStructuredTypeMembers(expressionType); - const symbol = resolved.members.get("__index" /* Index */); - if (infos === getIndexInfosOfType(expressionType)) { - links.resolvedSymbol = symbol; - } else if (symbol) { - const symbolLinks2 = getSymbolLinks(symbol); - const declarationList = mapDefined(infos, (i) => i.declaration); - const nodeListId = map(declarationList, getNodeId).join(","); - if (!symbolLinks2.filteredIndexSymbolCache) { - symbolLinks2.filteredIndexSymbolCache = /* @__PURE__ */ new Map(); - } - if (symbolLinks2.filteredIndexSymbolCache.has(nodeListId)) { - links.resolvedSymbol = symbolLinks2.filteredIndexSymbolCache.get(nodeListId); - } else { - const copy = createSymbol(131072 /* Signature */, "__index" /* Index */); - copy.declarations = mapDefined(infos, (i) => i.declaration); - copy.parent = expressionType.aliasSymbol ? expressionType.aliasSymbol : expressionType.symbol ? expressionType.symbol : getSymbolAtLocation(copy.declarations[0].parent); - symbolLinks2.filteredIndexSymbolCache.set(nodeListId, copy); - links.resolvedSymbol = symbolLinks2.filteredIndexSymbolCache.get(nodeListId); - } - } - } + links.resolvedSymbol = getApplicableIndexSymbol(checkExpressionCached(name.expression), getLiteralTypeFromPropertyName(name.name)); } } else { checkQualifiedName(name, 0 /* Normal */); @@ -181850,7 +165804,7 @@ ${lanes.join("\n")} return resolveJSDocMemberName(name); } } else if (isTypeReferenceIdentifier(name)) { - const meaning = name.parent.kind === 182 /* TypeReference */ ? 788968 /* Type */ : 1920 /* Namespace */; + const meaning = name.parent.kind === 183 /* TypeReference */ ? 788968 /* Type */ : 1920 /* Namespace */; const symbol = resolveEntityName( name, meaning, @@ -181861,7 +165815,7 @@ ${lanes.join("\n")} ); return symbol && symbol !== unknownSymbol ? symbol : getUnresolvedSymbolForEntityName(name); } - if (name.parent.kind === 181 /* TypePredicate */) { + if (name.parent.kind === 182 /* TypePredicate */) { return resolveEntityName( name, /*meaning*/ @@ -181870,6 +165824,31 @@ ${lanes.join("\n")} } return void 0; } + function getApplicableIndexSymbol(type, keyType) { + const infos = getApplicableIndexInfos(type, keyType); + if (infos.length && type.members) { + const symbol = getIndexSymbolFromSymbolTable(resolveStructuredTypeMembers(type).members); + if (infos === getIndexInfosOfType(type)) { + return symbol; + } else if (symbol) { + const symbolLinks2 = getSymbolLinks(symbol); + const declarationList = mapDefined(infos, (i) => i.declaration); + const nodeListId = map(declarationList, getNodeId).join(","); + if (!symbolLinks2.filteredIndexSymbolCache) { + symbolLinks2.filteredIndexSymbolCache = /* @__PURE__ */ new Map(); + } + if (symbolLinks2.filteredIndexSymbolCache.has(nodeListId)) { + return symbolLinks2.filteredIndexSymbolCache.get(nodeListId); + } else { + const copy = createSymbol(131072 /* Signature */, "__index" /* Index */); + copy.declarations = mapDefined(infos, (i) => i.declaration); + copy.parent = type.aliasSymbol ? type.aliasSymbol : type.symbol ? type.symbol : getSymbolAtLocation(copy.declarations[0].parent); + symbolLinks2.filteredIndexSymbolCache.set(nodeListId, copy); + return copy; + } + } + } + } function resolveJSDocMemberName(name, ignoreErrors, container) { if (isEntityName(name)) { const meaning = 788968 /* Type */ | 1920 /* Namespace */ | 111551 /* Value */; @@ -181902,7 +165881,7 @@ ${lanes.join("\n")} } const { parent: parent2 } = node; const grandParent = parent2.parent; - if (node.flags & 33554432 /* InWithStatement */) { + if (node.flags & 67108864 /* InWithStatement */) { return void 0; } if (isDeclarationNameOrImportPropertyName(node)) { @@ -181914,7 +165893,7 @@ ${lanes.join("\n")} if (node.kind === 80 /* Identifier */) { if (isInRightSideOfImportOrExportAssignment(node)) { return getSymbolOfNameOrPropertyAccessExpression(node); - } else if (parent2.kind === 207 /* BindingElement */ && grandParent.kind === 205 /* ObjectBindingPattern */ && node === parent2.propertyName) { + } else if (parent2.kind === 208 /* BindingElement */ && grandParent.kind === 206 /* ObjectBindingPattern */ && node === parent2.propertyName) { const typeOfPattern = getTypeOfNode(grandParent); const propertyDeclaration = getPropertyOfType(typeOfPattern, node.escapedText); if (propertyDeclaration) { @@ -181933,8 +165912,8 @@ ${lanes.join("\n")} switch (node.kind) { case 80 /* Identifier */: case 81 /* PrivateIdentifier */: - case 210 /* PropertyAccessExpression */: - case 165 /* QualifiedName */: + case 211 /* PropertyAccessExpression */: + case 166 /* QualifiedName */: if (!isThisInTypeQuery(node)) { return getSymbolOfNameOrPropertyAccessExpression(node); } @@ -181955,19 +165934,19 @@ ${lanes.join("\n")} if (isInExpressionContext(node)) { return checkExpression(node).symbol; } - case 196 /* ThisType */: + case 197 /* ThisType */: return getTypeFromThisTypeNode(node).symbol; case 108 /* SuperKeyword */: return checkExpression(node).symbol; case 137 /* ConstructorKeyword */: const constructorDeclaration = node.parent; - if (constructorDeclaration && constructorDeclaration.kind === 175 /* Constructor */) { + if (constructorDeclaration && constructorDeclaration.kind === 176 /* Constructor */) { return constructorDeclaration.parent.symbol; } return void 0; case 11 /* StringLiteral */: case 15 /* NoSubstitutionTemplateLiteral */: - if (isExternalModuleImportEqualsDeclaration(node.parent.parent) && getExternalModuleImportEqualsDeclarationExpression(node.parent.parent) === node || (node.parent.kind === 271 /* ImportDeclaration */ || node.parent.kind === 277 /* ExportDeclaration */) && node.parent.moduleSpecifier === node || (isInJSFile(node) && getEmitModuleResolutionKind(compilerOptions) !== 100 /* Bundler */ && isRequireCall( + if (isExternalModuleImportEqualsDeclaration(node.parent.parent) && getExternalModuleImportEqualsDeclarationExpression(node.parent.parent) === node || (node.parent.kind === 272 /* ImportDeclaration */ || node.parent.kind === 278 /* ExportDeclaration */) && node.parent.moduleSpecifier === node || (isInJSFile(node) && getEmitModuleResolutionKind(compilerOptions) !== 100 /* Bundler */ && isRequireCall( node.parent, /*requireStringLiteralLikeArgument*/ false @@ -181985,16 +165964,23 @@ ${lanes.join("\n")} case 39 /* EqualsGreaterThanToken */: case 86 /* ClassKeyword */: return getSymbolOfNode(node.parent); - case 204 /* ImportType */: + case 205 /* ImportType */: return isLiteralImportTypeNode(node) ? getSymbolAtLocation(node.argument.literal, ignoreErrors) : void 0; case 95 /* ExportKeyword */: return isExportAssignment(node.parent) ? Debug.checkDefined(node.parent.symbol) : void 0; case 102 /* ImportKeyword */: case 105 /* NewKeyword */: return isMetaProperty(node.parent) ? checkMetaPropertyKeyword(node.parent).symbol : void 0; - case 235 /* MetaProperty */: + case 104 /* InstanceOfKeyword */: + if (isBinaryExpression(node.parent)) { + const type = getTypeOfExpression(node.parent.right); + const hasInstanceMethodType = getSymbolHasInstanceMethodOfObjectType(type); + return (hasInstanceMethodType == null ? void 0 : hasInstanceMethodType.symbol) ?? type.symbol; + } + return void 0; + case 236 /* MetaProperty */: return checkExpression(node).symbol; - case 294 /* JsxNamespacedName */: + case 295 /* JsxNamespacedName */: if (isJSXTagName(node) && isJsxIntrinsicTagName(node)) { const symbol = getIntrinsicTagSymbol(node.parent); return symbol === unknownSymbol ? void 0 : symbol; @@ -182013,7 +165999,7 @@ ${lanes.join("\n")} return void 0; } function getShorthandAssignmentValueSymbol(location) { - if (location && location.kind === 303 /* ShorthandPropertyAssignment */) { + if (location && location.kind === 304 /* ShorthandPropertyAssignment */) { return resolveEntityName(location.name, 111551 /* Value */ | 2097152 /* Alias */); } return void 0; @@ -182029,7 +166015,7 @@ ${lanes.join("\n")} if (isSourceFile(node) && !isExternalModule(node)) { return errorType; } - if (node.flags & 33554432 /* InWithStatement */) { + if (node.flags & 67108864 /* InWithStatement */) { return errorType; } const classDecl = tryGetClassImplementingOrExtendingExpressionWithTypeArguments(node); @@ -182093,16 +166079,16 @@ ${lanes.join("\n")} return errorType; } function getTypeOfAssignmentPattern(expr) { - Debug.assert(expr.kind === 209 /* ObjectLiteralExpression */ || expr.kind === 208 /* ArrayLiteralExpression */); - if (expr.parent.kind === 249 /* ForOfStatement */) { + Debug.assert(expr.kind === 210 /* ObjectLiteralExpression */ || expr.kind === 209 /* ArrayLiteralExpression */); + if (expr.parent.kind === 250 /* ForOfStatement */) { const iteratedType = checkRightHandSideOfForOf(expr.parent); return checkDestructuringAssignment(expr, iteratedType || errorType); } - if (expr.parent.kind === 225 /* BinaryExpression */) { + if (expr.parent.kind === 226 /* BinaryExpression */) { const iteratedType = getTypeOfExpression(expr.parent.right); return checkDestructuringAssignment(expr, iteratedType || errorType); } - if (expr.parent.kind === 302 /* PropertyAssignment */) { + if (expr.parent.kind === 303 /* PropertyAssignment */) { const node2 = cast(expr.parent.parent, isObjectLiteralExpression); const typeOfParentObjectLiteral = getTypeOfAssignmentPattern(node2) || errorType; const propertyIndex = indexOfNode(node2.properties, expr.parent); @@ -182135,7 +166121,7 @@ ${lanes.join("\n")} case 9 /* NumericLiteral */: case 11 /* StringLiteral */: return getStringLiteralType(name.text); - case 166 /* ComputedPropertyName */: + case 167 /* ComputedPropertyName */: const nameType = checkComputedPropertyName(name); return isTypeAssignableToKind(nameType, 12288 /* ESSymbolLike */) ? nameType : stringType; default: @@ -182205,7 +166191,7 @@ ${lanes.join("\n")} return symbolLinks2.exportsSomeValue; function isValue(s) { s = resolveSymbol(s); - return s && !!(getAllSymbolFlags(s) & 111551 /* Value */); + return s && !!(getSymbolFlags(s) & 111551 /* Value */); } } function isNameOfModuleOrEnumDeclaration(node) { @@ -182230,7 +166216,7 @@ ${lanes.join("\n")} } const parentSymbol = getParentOfSymbol(symbol); if (parentSymbol) { - if (parentSymbol.flags & 512 /* ValueModule */ && ((_a = parentSymbol.valueDeclaration) == null ? void 0 : _a.kind) === 311 /* SourceFile */) { + if (parentSymbol.flags & 512 /* ValueModule */ && ((_a = parentSymbol.valueDeclaration) == null ? void 0 : _a.kind) === 312 /* SourceFile */) { const symbolFile = parentSymbol.valueDeclaration; const referenceFile = getSourceFileOfNode(node); const symbolIsUmdExport = symbolFile !== referenceFile; @@ -182260,7 +166246,7 @@ ${lanes.join("\n")} return void 0; } function isSymbolOfDestructuredElementOfCatchBinding(symbol) { - return symbol.valueDeclaration && isBindingElement(symbol.valueDeclaration) && walkUpBindingElementsAndPatterns(symbol.valueDeclaration).parent.kind === 298 /* CatchClause */; + return symbol.valueDeclaration && isBindingElement(symbol.valueDeclaration) && walkUpBindingElementsAndPatterns(symbol.valueDeclaration).parent.kind === 299 /* CatchClause */; } function isSymbolOfDeclarationWithCollidingName(symbol) { if (symbol.flags & 418 /* BlockScoped */ && symbol.valueDeclaration && !isSourceFile(symbol.valueDeclaration)) { @@ -182288,7 +166274,7 @@ ${lanes.join("\n")} /*lookInLabeledStatements*/ false ); - const inLoopBodyBlock = container.kind === 240 /* Block */ && isIterationStatement( + const inLoopBodyBlock = container.kind === 241 /* Block */ && isIterationStatement( container.parent, /*lookInLabeledStatements*/ false @@ -182328,39 +166314,48 @@ ${lanes.join("\n")} function isValueAliasDeclaration(node) { Debug.assert(canCollectSymbolAliasAccessabilityData); switch (node.kind) { - case 270 /* ImportEqualsDeclaration */: + case 271 /* ImportEqualsDeclaration */: return isAliasResolvedToValue(getSymbolOfDeclaration(node)); - case 272 /* ImportClause */: - case 273 /* NamespaceImport */: - case 275 /* ImportSpecifier */: - case 280 /* ExportSpecifier */: + case 273 /* ImportClause */: + case 274 /* NamespaceImport */: + case 276 /* ImportSpecifier */: + case 281 /* ExportSpecifier */: const symbol = getSymbolOfDeclaration(node); - return !!symbol && isAliasResolvedToValue(symbol) && !getTypeOnlyAliasDeclaration(symbol, 111551 /* Value */); - case 277 /* ExportDeclaration */: + return !!symbol && isAliasResolvedToValue( + symbol, + /*excludeTypeOnlyValues*/ + true + ); + case 278 /* ExportDeclaration */: const exportClause = node.exportClause; return !!exportClause && (isNamespaceExport(exportClause) || some(exportClause.elements, isValueAliasDeclaration)); - case 276 /* ExportAssignment */: + case 277 /* ExportAssignment */: return node.expression && node.expression.kind === 80 /* Identifier */ ? isAliasResolvedToValue(getSymbolOfDeclaration(node)) : true; } return false; } function isTopLevelValueImportEqualsWithEntityName(nodeIn) { const node = getParseTreeNode(nodeIn, isImportEqualsDeclaration); - if (node === void 0 || node.parent.kind !== 311 /* SourceFile */ || !isInternalModuleImportEqualsDeclaration(node)) { + if (node === void 0 || node.parent.kind !== 312 /* SourceFile */ || !isInternalModuleImportEqualsDeclaration(node)) { return false; } const isValue = isAliasResolvedToValue(getSymbolOfDeclaration(node)); return isValue && node.moduleReference && !nodeIsMissing(node.moduleReference); } - function isAliasResolvedToValue(symbol) { + function isAliasResolvedToValue(symbol, excludeTypeOnlyValues) { if (!symbol) { return false; } const target = getExportSymbolOfValueSymbolIfExported(resolveAlias(symbol)); if (target === unknownSymbol) { - return true; + return !excludeTypeOnlyValues || !getTypeOnlyAliasDeclaration(symbol); } - return !!((getAllSymbolFlags(target) ?? -1) & 111551 /* Value */) && (shouldPreserveConstEnums(compilerOptions) || !isConstEnumOrConstEnumOnlyModule(target)); + return !!(getSymbolFlags( + symbol, + excludeTypeOnlyValues, + /*excludeLocalMeanings*/ + true + ) & 111551 /* Value */) && (shouldPreserveConstEnums(compilerOptions) || !isConstEnumOrConstEnumOnlyModule(target)); } function isConstEnumOrConstEnumOnlyModule(s) { return isConstEnumSymbol(s) || !!s.constEnumOnlyModule; @@ -182374,7 +166369,7 @@ ${lanes.join("\n")} return true; } const target = getSymbolLinks(symbol).aliasTarget; - if (target && getEffectiveModifierFlags(node) & 1 /* Export */ && getAllSymbolFlags(target) & 111551 /* Value */ && (shouldPreserveConstEnums(compilerOptions) || !isConstEnumOrConstEnumOnlyModule(target))) { + if (target && getEffectiveModifierFlags(node) & 32 /* Export */ && getSymbolFlags(target) & 111551 /* Value */ && (shouldPreserveConstEnums(compilerOptions) || !isConstEnumOrConstEnumOnlyModule(target))) { return true; } } @@ -182399,10 +166394,10 @@ ${lanes.join("\n")} return false; } function isRequiredInitializedParameter(parameter) { - return !!strictNullChecks && !isOptionalParameter(parameter) && !isJSDocParameterTag(parameter) && !!parameter.initializer && !hasSyntacticModifier(parameter, 16476 /* ParameterPropertyModifier */); + return !!strictNullChecks && !isOptionalParameter(parameter) && !isJSDocParameterTag(parameter) && !!parameter.initializer && !hasSyntacticModifier(parameter, 31 /* ParameterPropertyModifier */); } function isOptionalUninitializedParameterProperty(parameter) { - return strictNullChecks && isOptionalParameter(parameter) && !parameter.initializer && hasSyntacticModifier(parameter, 16476 /* ParameterPropertyModifier */); + return strictNullChecks && isOptionalParameter(parameter) && !parameter.initializer && hasSyntacticModifier(parameter, 31 /* ParameterPropertyModifier */); } function isExpandoFunctionDeclaration(node) { const declaration = getParseTreeNode(node, isFunctionDeclaration); @@ -182413,7 +166408,7 @@ ${lanes.join("\n")} if (!symbol || !(symbol.flags & 16 /* Function */)) { return false; } - return !!forEachEntry(getExportsOfSymbol(symbol), (p) => p.flags & 111551 /* Value */ && p.valueDeclaration && isPropertyAccessExpression(p.valueDeclaration)); + return !!forEachEntry(getExportsOfSymbol(symbol), (p) => p.flags & 111551 /* Value */ && isExpandoPropertyDeclaration(p.valueDeclaration)); } function getPropertiesOfContainerFunction(node) { const declaration = getParseTreeNode(node, isFunctionDeclaration); @@ -182436,15 +166431,15 @@ ${lanes.join("\n")} } function canHaveConstantValue(node) { switch (node.kind) { - case 305 /* EnumMember */: - case 210 /* PropertyAccessExpression */: - case 211 /* ElementAccessExpression */: + case 306 /* EnumMember */: + case 211 /* PropertyAccessExpression */: + case 212 /* ElementAccessExpression */: return true; } return false; } function getConstantValue2(node) { - if (node.kind === 305 /* EnumMember */) { + if (node.kind === 306 /* EnumMember */) { return getEnumMemberValue(node); } const symbol = getNodeLinks(node).resolvedSymbol; @@ -182644,24 +166639,24 @@ ${lanes.join("\n")} if (symbol) { return filter(getExportSymbolOfValueSymbolIfExported(symbol).declarations, (declaration) => { switch (declaration.kind) { - case 259 /* VariableDeclaration */: - case 168 /* Parameter */: - case 207 /* BindingElement */: - case 171 /* PropertyDeclaration */: - case 302 /* PropertyAssignment */: - case 303 /* ShorthandPropertyAssignment */: - case 305 /* EnumMember */: - case 209 /* ObjectLiteralExpression */: - case 261 /* FunctionDeclaration */: - case 217 /* FunctionExpression */: - case 218 /* ArrowFunction */: - case 262 /* ClassDeclaration */: - case 230 /* ClassExpression */: - case 265 /* EnumDeclaration */: - case 173 /* MethodDeclaration */: - case 176 /* GetAccessor */: - case 177 /* SetAccessor */: - case 266 /* ModuleDeclaration */: + case 260 /* VariableDeclaration */: + case 169 /* Parameter */: + case 208 /* BindingElement */: + case 172 /* PropertyDeclaration */: + case 303 /* PropertyAssignment */: + case 304 /* ShorthandPropertyAssignment */: + case 306 /* EnumMember */: + case 210 /* ObjectLiteralExpression */: + case 262 /* FunctionDeclaration */: + case 218 /* FunctionExpression */: + case 219 /* ArrowFunction */: + case 263 /* ClassDeclaration */: + case 231 /* ClassExpression */: + case 266 /* EnumDeclaration */: + case 174 /* MethodDeclaration */: + case 177 /* GetAccessor */: + case 178 /* SetAccessor */: + case 267 /* ModuleDeclaration */: return true; } return false; @@ -182672,7 +166667,7 @@ ${lanes.join("\n")} return void 0; } function isLiteralConstDeclaration(node) { - if (isDeclarationReadonly(node) || isVariableDeclaration(node) && isVarConst(node)) { + if (isDeclarationReadonly(node) || isVariableDeclaration(node) && isVarConstLike(node)) { return isFreshLiteralType(getTypeOfSymbol(getSymbolOfDeclaration(node))); } return false; @@ -182790,12 +166785,12 @@ ${lanes.join("\n")} getJsxFragmentFactoryEntity, getAllAccessorDeclarations(accessor) { accessor = getParseTreeNode(accessor, isGetOrSetAccessorDeclaration); - const otherKind = accessor.kind === 177 /* SetAccessor */ ? 176 /* GetAccessor */ : 177 /* SetAccessor */; + const otherKind = accessor.kind === 178 /* SetAccessor */ ? 177 /* GetAccessor */ : 178 /* SetAccessor */; const otherAccessor = getDeclarationOfKind(getSymbolOfDeclaration(accessor), otherKind); const firstAccessor = otherAccessor && otherAccessor.pos < accessor.pos ? otherAccessor : accessor; const secondAccessor = otherAccessor && otherAccessor.pos < accessor.pos ? accessor : otherAccessor; - const setAccessor = accessor.kind === 177 /* SetAccessor */ ? accessor : otherAccessor; - const getAccessor = accessor.kind === 176 /* GetAccessor */ ? accessor : otherAccessor; + const setAccessor = accessor.kind === 178 /* SetAccessor */ ? accessor : otherAccessor; + const getAccessor = accessor.kind === 177 /* GetAccessor */ ? accessor : otherAccessor; return { firstAccessor, secondAccessor, @@ -182816,14 +166811,23 @@ ${lanes.join("\n")} }, getDeclarationStatementsForSourceFile: (node, flags, tracker, bundled) => { const n = getParseTreeNode(node); - Debug.assert(n && n.kind === 311 /* SourceFile */, "Non-sourcefile node passed into getDeclarationsForSourceFile"); + Debug.assert(n && n.kind === 312 /* SourceFile */, "Non-sourcefile node passed into getDeclarationsForSourceFile"); const sym = getSymbolOfDeclaration(node); if (!sym) { return !node.locals ? [] : nodeBuilder.symbolTableToDeclarationStatements(node.locals, node, flags, tracker, bundled); } return !sym.exports ? [] : nodeBuilder.symbolTableToDeclarationStatements(sym.exports, node, flags, tracker, bundled); }, - isImportRequiredByAugmentation + isImportRequiredByAugmentation, + tryFindAmbientModule: (moduleReferenceExpression) => { + const node = getParseTreeNode(moduleReferenceExpression); + const moduleSpecifier = node && isStringLiteralLike(node) ? node.text : void 0; + return moduleSpecifier !== void 0 ? tryFindAmbientModule( + moduleSpecifier, + /*withAugmentations*/ + true + ) : void 0; + } }; function isImportRequiredByAugmentation(node) { const file = getSourceFileOfNode(node); @@ -182851,18 +166855,18 @@ ${lanes.join("\n")} return false; } function isInHeritageClause(node) { - return node.parent && node.parent.kind === 232 /* ExpressionWithTypeArguments */ && node.parent.parent && node.parent.parent.kind === 297 /* HeritageClause */; + return node.parent && node.parent.kind === 233 /* ExpressionWithTypeArguments */ && node.parent.parent && node.parent.parent.kind === 298 /* HeritageClause */; } function getTypeReferenceDirectivesForEntityName(node) { if (!fileToDirective) { return void 0; } let meaning; - if (node.parent.kind === 166 /* ComputedPropertyName */) { + if (node.parent.kind === 167 /* ComputedPropertyName */) { meaning = 111551 /* Value */ | 1048576 /* ExportValue */; } else { meaning = 788968 /* Type */ | 1920 /* Namespace */; - if (node.kind === 80 /* Identifier */ && isInTypeQuery(node) || node.kind === 210 /* PropertyAccessExpression */ && !isInHeritageClause(node)) { + if (node.kind === 80 /* Identifier */ && isInTypeQuery(node) || node.kind === 211 /* PropertyAccessExpression */ && !isInHeritageClause(node)) { meaning = 111551 /* Value */ | 1048576 /* ExportValue */; } } @@ -182905,7 +166909,7 @@ ${lanes.join("\n")} break; } } - if (current.valueDeclaration && current.valueDeclaration.kind === 311 /* SourceFile */ && current.flags & 512 /* ValueModule */) { + if (current.valueDeclaration && current.valueDeclaration.kind === 312 /* SourceFile */ && current.flags & 512 /* ValueModule */) { return false; } for (const decl of symbol.declarations) { @@ -182920,17 +166924,17 @@ ${lanes.join("\n")} if (fileToDirective.has(file.path)) return; fileToDirective.set(file.path, [key, mode]); - for (const { fileName, resolutionMode } of file.referencedFiles) { + for (const { fileName } of file.referencedFiles) { const resolvedFile = resolveTripleslashReference(fileName, file.fileName); const referencedFile = host.getSourceFile(resolvedFile); if (referencedFile) { - addReferencedFilesToTypeDirective(referencedFile, key, resolutionMode || file.impliedNodeFormat); + addReferencedFilesToTypeDirective(referencedFile, key, mode || file.impliedNodeFormat); } } } } function getExternalModuleFileFromDeclaration(declaration) { - const specifier = declaration.kind === 266 /* ModuleDeclaration */ ? tryCast(declaration.name, isStringLiteral) : getExternalModuleName(declaration); + const specifier = declaration.kind === 267 /* ModuleDeclaration */ ? tryCast(declaration.name, isStringLiteral) : getExternalModuleName(declaration); const moduleSymbol = resolveExternalModuleNameWorker( specifier, specifier, @@ -182940,7 +166944,7 @@ ${lanes.join("\n")} if (!moduleSymbol) { return void 0; } - return getDeclarationOfKind(moduleSymbol, 311 /* SourceFile */); + return getDeclarationOfKind(moduleSymbol, 312 /* SourceFile */); } function initializeTypeChecker() { for (const file of host.getSourceFiles()) { @@ -183122,11 +167126,11 @@ ${lanes.join("\n")} function checkExternalEmitHelpers(location, helpers) { if ((requestedExternalEmitHelpers & helpers) !== helpers && compilerOptions.importHelpers) { const sourceFile = getSourceFileOfNode(location); - if (isEffectiveExternalModule(sourceFile, compilerOptions) && !(location.flags & 16777216 /* Ambient */)) { + if (isEffectiveExternalModule(sourceFile, compilerOptions) && !(location.flags & 33554432 /* Ambient */)) { const helpersModule = resolveHelpersModule(sourceFile, location); if (helpersModule !== unknownSymbol) { const uncheckedHelpers = helpers & ~requestedExternalEmitHelpers; - for (let helper = 1 /* FirstEmitHelper */; helper <= 16777216 /* LastEmitHelper */; helper <<= 1) { + for (let helper = 1 /* FirstEmitHelper */; helper <= 33554432 /* LastEmitHelper */; helper <<= 1) { if (uncheckedHelpers & helper) { for (const name of getHelperNames(helper)) { if (requestedExternalEmitHelperNames.has(name)) @@ -183134,18 +167138,18 @@ ${lanes.join("\n")} requestedExternalEmitHelperNames.add(name); const symbol = resolveSymbol(getSymbol2(getExportsOfModule(helpersModule), escapeLeadingUnderscores(name), 111551 /* Value */)); if (!symbol) { - error(location, Diagnostics.This_syntax_requires_an_imported_helper_named_1_which_does_not_exist_in_0_Consider_upgrading_your_version_of_0, externalHelpersModuleNameText, name); + error2(location, Diagnostics.This_syntax_requires_an_imported_helper_named_1_which_does_not_exist_in_0_Consider_upgrading_your_version_of_0, externalHelpersModuleNameText, name); } else if (helper & 524288 /* ClassPrivateFieldGet */) { if (!some(getSignaturesOfSymbol(symbol), (signature) => getParameterCount(signature) > 3)) { - error(location, Diagnostics.This_syntax_requires_an_imported_helper_named_1_with_2_parameters_which_is_not_compatible_with_the_one_in_0_Consider_upgrading_your_version_of_0, externalHelpersModuleNameText, name, 4); + error2(location, Diagnostics.This_syntax_requires_an_imported_helper_named_1_with_2_parameters_which_is_not_compatible_with_the_one_in_0_Consider_upgrading_your_version_of_0, externalHelpersModuleNameText, name, 4); } } else if (helper & 1048576 /* ClassPrivateFieldSet */) { if (!some(getSignaturesOfSymbol(symbol), (signature) => getParameterCount(signature) > 4)) { - error(location, Diagnostics.This_syntax_requires_an_imported_helper_named_1_with_2_parameters_which_is_not_compatible_with_the_one_in_0_Consider_upgrading_your_version_of_0, externalHelpersModuleNameText, name, 5); + error2(location, Diagnostics.This_syntax_requires_an_imported_helper_named_1_with_2_parameters_which_is_not_compatible_with_the_one_in_0_Consider_upgrading_your_version_of_0, externalHelpersModuleNameText, name, 5); } } else if (helper & 1024 /* SpreadArray */) { if (!some(getSignaturesOfSymbol(symbol), (signature) => getParameterCount(signature) > 2)) { - error(location, Diagnostics.This_syntax_requires_an_imported_helper_named_1_with_2_parameters_which_is_not_compatible_with_the_one_in_0_Consider_upgrading_your_version_of_0, externalHelpersModuleNameText, name, 3); + error2(location, Diagnostics.This_syntax_requires_an_imported_helper_named_1_with_2_parameters_which_is_not_compatible_with_the_one_in_0_Consider_upgrading_your_version_of_0, externalHelpersModuleNameText, name, 3); } } } @@ -183208,6 +167212,8 @@ ${lanes.join("\n")} return ["__setFunctionName"]; case 16777216 /* PropKey */: return ["__propKey"]; + case 33554432 /* AddDisposableResourceAndDisposeResources */: + return ["__addDisposableResource", "__disposeResources"]; default: return Debug.fail("Unrecognized helper"); } @@ -183226,6 +167232,7 @@ ${lanes.join("\n")} if (isParameter(node) && parameterIsThisKeyword(node)) { return grammarErrorOnFirstToken(node, Diagnostics.Neither_decorators_nor_modifiers_may_be_applied_to_this_parameters); } + const blockScopeKind = isVariableStatement(node) ? node.declarationList.flags & 7 /* BlockScoped */ : 0 /* None */; let lastStatic, lastDeclare, lastAsync, lastOverride, firstDecorator; let flags = 0 /* None */; let sawExportBeforeDecorators = false; @@ -183233,97 +167240,97 @@ ${lanes.join("\n")} for (const modifier of node.modifiers) { if (isDecorator(modifier)) { if (!nodeCanBeDecorated(legacyDecorators, node, node.parent, node.parent.parent)) { - if (node.kind === 173 /* MethodDeclaration */ && !nodeIsPresent(node.body)) { + if (node.kind === 174 /* MethodDeclaration */ && !nodeIsPresent(node.body)) { return grammarErrorOnFirstToken(node, Diagnostics.A_decorator_can_only_decorate_a_method_implementation_not_an_overload); } else { return grammarErrorOnFirstToken(node, Diagnostics.Decorators_are_not_valid_here); } - } else if (legacyDecorators && (node.kind === 176 /* GetAccessor */ || node.kind === 177 /* SetAccessor */)) { + } else if (legacyDecorators && (node.kind === 177 /* GetAccessor */ || node.kind === 178 /* SetAccessor */)) { const accessors = getAllAccessorDeclarations(node.parent.members, node); if (hasDecorators(accessors.firstAccessor) && node === accessors.secondAccessor) { return grammarErrorOnFirstToken(node, Diagnostics.Decorators_cannot_be_applied_to_multiple_get_Slashset_accessors_of_the_same_name); } } - if (flags & ~(1025 /* ExportDefault */ | 131072 /* Decorator */)) { + if (flags & ~(2080 /* ExportDefault */ | 32768 /* Decorator */)) { return grammarErrorOnNode(modifier, Diagnostics.Decorators_are_not_valid_here); } - if (hasLeadingDecorators && flags & 126975 /* Modifier */) { + if (hasLeadingDecorators && flags & 98303 /* Modifier */) { Debug.assertIsDefined(firstDecorator); const sourceFile = getSourceFileOfNode(modifier); if (!hasParseDiagnostics(sourceFile)) { addRelatedInfo( - error(modifier, Diagnostics.Decorators_may_not_appear_after_export_or_export_default_if_they_also_appear_before_export), + error2(modifier, Diagnostics.Decorators_may_not_appear_after_export_or_export_default_if_they_also_appear_before_export), createDiagnosticForNode(firstDecorator, Diagnostics.Decorator_used_before_export_here) ); return true; } return false; } - flags |= 131072 /* Decorator */; - if (!(flags & 126975 /* Modifier */)) { + flags |= 32768 /* Decorator */; + if (!(flags & 98303 /* Modifier */)) { hasLeadingDecorators = true; - } else if (flags & 1 /* Export */) { + } else if (flags & 32 /* Export */) { sawExportBeforeDecorators = true; } firstDecorator ?? (firstDecorator = modifier); } else { if (modifier.kind !== 148 /* ReadonlyKeyword */) { - if (node.kind === 170 /* PropertySignature */ || node.kind === 172 /* MethodSignature */) { + if (node.kind === 171 /* PropertySignature */ || node.kind === 173 /* MethodSignature */) { return grammarErrorOnNode(modifier, Diagnostics._0_modifier_cannot_appear_on_a_type_member, tokenToString(modifier.kind)); } - if (node.kind === 180 /* IndexSignature */ && (modifier.kind !== 126 /* StaticKeyword */ || !isClassLike(node.parent))) { + if (node.kind === 181 /* IndexSignature */ && (modifier.kind !== 126 /* StaticKeyword */ || !isClassLike(node.parent))) { return grammarErrorOnNode(modifier, Diagnostics._0_modifier_cannot_appear_on_an_index_signature, tokenToString(modifier.kind)); } } if (modifier.kind !== 103 /* InKeyword */ && modifier.kind !== 147 /* OutKeyword */ && modifier.kind !== 87 /* ConstKeyword */) { - if (node.kind === 167 /* TypeParameter */) { + if (node.kind === 168 /* TypeParameter */) { return grammarErrorOnNode(modifier, Diagnostics._0_modifier_cannot_appear_on_a_type_parameter, tokenToString(modifier.kind)); } } switch (modifier.kind) { case 87 /* ConstKeyword */: - if (node.kind !== 265 /* EnumDeclaration */ && node.kind !== 167 /* TypeParameter */) { + if (node.kind !== 266 /* EnumDeclaration */ && node.kind !== 168 /* TypeParameter */) { return grammarErrorOnNode(node, Diagnostics.A_class_member_cannot_have_the_0_keyword, tokenToString(87 /* ConstKeyword */)); } const parent2 = node.parent; - if (node.kind === 167 /* TypeParameter */ && !(isFunctionLikeDeclaration(parent2) || isClassLike(parent2) || isFunctionTypeNode(parent2) || isConstructorTypeNode(parent2) || isCallSignatureDeclaration(parent2) || isConstructSignatureDeclaration(parent2) || isMethodSignature(parent2))) { + if (node.kind === 168 /* TypeParameter */ && !(isFunctionLikeDeclaration(parent2) || isClassLike(parent2) || isFunctionTypeNode(parent2) || isConstructorTypeNode(parent2) || isCallSignatureDeclaration(parent2) || isConstructSignatureDeclaration(parent2) || isMethodSignature(parent2))) { return grammarErrorOnNode(modifier, Diagnostics._0_modifier_can_only_appear_on_a_type_parameter_of_a_function_method_or_class, tokenToString(modifier.kind)); } break; - case 163 /* OverrideKeyword */: - if (flags & 16384 /* Override */) { + case 164 /* OverrideKeyword */: + if (flags & 16 /* Override */) { return grammarErrorOnNode(modifier, Diagnostics._0_modifier_already_seen, "override"); - } else if (flags & 2 /* Ambient */) { + } else if (flags & 128 /* Ambient */) { return grammarErrorOnNode(modifier, Diagnostics._0_modifier_cannot_be_used_with_1_modifier, "override", "declare"); - } else if (flags & 64 /* Readonly */) { + } else if (flags & 8 /* Readonly */) { return grammarErrorOnNode(modifier, Diagnostics._0_modifier_must_precede_1_modifier, "override", "readonly"); - } else if (flags & 128 /* Accessor */) { + } else if (flags & 512 /* Accessor */) { return grammarErrorOnNode(modifier, Diagnostics._0_modifier_must_precede_1_modifier, "override", "accessor"); - } else if (flags & 512 /* Async */) { + } else if (flags & 1024 /* Async */) { return grammarErrorOnNode(modifier, Diagnostics._0_modifier_must_precede_1_modifier, "override", "async"); } - flags |= 16384 /* Override */; + flags |= 16 /* Override */; lastOverride = modifier; break; case 125 /* PublicKeyword */: case 124 /* ProtectedKeyword */: case 123 /* PrivateKeyword */: const text = visibilityToString(modifierToFlag(modifier.kind)); - if (flags & 28 /* AccessibilityModifier */) { + if (flags & 7 /* AccessibilityModifier */) { return grammarErrorOnNode(modifier, Diagnostics.Accessibility_modifier_already_seen); - } else if (flags & 16384 /* Override */) { + } else if (flags & 16 /* Override */) { return grammarErrorOnNode(modifier, Diagnostics._0_modifier_must_precede_1_modifier, text, "override"); - } else if (flags & 32 /* Static */) { + } else if (flags & 256 /* Static */) { return grammarErrorOnNode(modifier, Diagnostics._0_modifier_must_precede_1_modifier, text, "static"); - } else if (flags & 128 /* Accessor */) { + } else if (flags & 512 /* Accessor */) { return grammarErrorOnNode(modifier, Diagnostics._0_modifier_must_precede_1_modifier, text, "accessor"); - } else if (flags & 64 /* Readonly */) { + } else if (flags & 8 /* Readonly */) { return grammarErrorOnNode(modifier, Diagnostics._0_modifier_must_precede_1_modifier, text, "readonly"); - } else if (flags & 512 /* Async */) { + } else if (flags & 1024 /* Async */) { return grammarErrorOnNode(modifier, Diagnostics._0_modifier_must_precede_1_modifier, text, "async"); - } else if (node.parent.kind === 267 /* ModuleBlock */ || node.parent.kind === 311 /* SourceFile */) { + } else if (node.parent.kind === 268 /* ModuleBlock */ || node.parent.kind === 312 /* SourceFile */) { return grammarErrorOnNode(modifier, Diagnostics._0_modifier_cannot_appear_on_a_module_or_namespace_element, text); - } else if (flags & 256 /* Abstract */) { + } else if (flags & 64 /* Abstract */) { if (modifier.kind === 123 /* PrivateKeyword */) { return grammarErrorOnNode(modifier, Diagnostics._0_modifier_cannot_be_used_with_1_modifier, text, "abstract"); } else { @@ -183335,158 +167342,170 @@ ${lanes.join("\n")} flags |= modifierToFlag(modifier.kind); break; case 126 /* StaticKeyword */: - if (flags & 32 /* Static */) { + if (flags & 256 /* Static */) { return grammarErrorOnNode(modifier, Diagnostics._0_modifier_already_seen, "static"); - } else if (flags & 64 /* Readonly */) { + } else if (flags & 8 /* Readonly */) { return grammarErrorOnNode(modifier, Diagnostics._0_modifier_must_precede_1_modifier, "static", "readonly"); - } else if (flags & 512 /* Async */) { + } else if (flags & 1024 /* Async */) { return grammarErrorOnNode(modifier, Diagnostics._0_modifier_must_precede_1_modifier, "static", "async"); - } else if (flags & 128 /* Accessor */) { + } else if (flags & 512 /* Accessor */) { return grammarErrorOnNode(modifier, Diagnostics._0_modifier_must_precede_1_modifier, "static", "accessor"); - } else if (node.parent.kind === 267 /* ModuleBlock */ || node.parent.kind === 311 /* SourceFile */) { + } else if (node.parent.kind === 268 /* ModuleBlock */ || node.parent.kind === 312 /* SourceFile */) { return grammarErrorOnNode(modifier, Diagnostics._0_modifier_cannot_appear_on_a_module_or_namespace_element, "static"); - } else if (node.kind === 168 /* Parameter */) { + } else if (node.kind === 169 /* Parameter */) { return grammarErrorOnNode(modifier, Diagnostics._0_modifier_cannot_appear_on_a_parameter, "static"); - } else if (flags & 256 /* Abstract */) { + } else if (flags & 64 /* Abstract */) { return grammarErrorOnNode(modifier, Diagnostics._0_modifier_cannot_be_used_with_1_modifier, "static", "abstract"); - } else if (flags & 16384 /* Override */) { + } else if (flags & 16 /* Override */) { return grammarErrorOnNode(modifier, Diagnostics._0_modifier_must_precede_1_modifier, "static", "override"); } - flags |= 32 /* Static */; + flags |= 256 /* Static */; lastStatic = modifier; break; case 129 /* AccessorKeyword */: - if (flags & 128 /* Accessor */) { + if (flags & 512 /* Accessor */) { return grammarErrorOnNode(modifier, Diagnostics._0_modifier_already_seen, "accessor"); - } else if (flags & 64 /* Readonly */) { + } else if (flags & 8 /* Readonly */) { return grammarErrorOnNode(modifier, Diagnostics._0_modifier_cannot_be_used_with_1_modifier, "accessor", "readonly"); - } else if (flags & 2 /* Ambient */) { + } else if (flags & 128 /* Ambient */) { return grammarErrorOnNode(modifier, Diagnostics._0_modifier_cannot_be_used_with_1_modifier, "accessor", "declare"); - } else if (node.kind !== 171 /* PropertyDeclaration */) { + } else if (node.kind !== 172 /* PropertyDeclaration */) { return grammarErrorOnNode(modifier, Diagnostics.accessor_modifier_can_only_appear_on_a_property_declaration); } - flags |= 128 /* Accessor */; + flags |= 512 /* Accessor */; break; case 148 /* ReadonlyKeyword */: - if (flags & 64 /* Readonly */) { + if (flags & 8 /* Readonly */) { return grammarErrorOnNode(modifier, Diagnostics._0_modifier_already_seen, "readonly"); - } else if (node.kind !== 171 /* PropertyDeclaration */ && node.kind !== 170 /* PropertySignature */ && node.kind !== 180 /* IndexSignature */ && node.kind !== 168 /* Parameter */) { + } else if (node.kind !== 172 /* PropertyDeclaration */ && node.kind !== 171 /* PropertySignature */ && node.kind !== 181 /* IndexSignature */ && node.kind !== 169 /* Parameter */) { return grammarErrorOnNode(modifier, Diagnostics.readonly_modifier_can_only_appear_on_a_property_declaration_or_index_signature); - } else if (flags & 128 /* Accessor */) { + } else if (flags & 512 /* Accessor */) { return grammarErrorOnNode(modifier, Diagnostics._0_modifier_cannot_be_used_with_1_modifier, "readonly", "accessor"); } - flags |= 64 /* Readonly */; + flags |= 8 /* Readonly */; break; case 95 /* ExportKeyword */: - if (compilerOptions.verbatimModuleSyntax && !(node.flags & 16777216 /* Ambient */) && node.kind !== 264 /* TypeAliasDeclaration */ && node.kind !== 263 /* InterfaceDeclaration */ && // ModuleDeclaration needs to be checked that it is uninstantiated later - node.kind !== 266 /* ModuleDeclaration */ && node.parent.kind === 311 /* SourceFile */ && (moduleKind === 1 /* CommonJS */ || getSourceFileOfNode(node).impliedNodeFormat === 1 /* CommonJS */)) { + if (compilerOptions.verbatimModuleSyntax && !(node.flags & 33554432 /* Ambient */) && node.kind !== 265 /* TypeAliasDeclaration */ && node.kind !== 264 /* InterfaceDeclaration */ && // ModuleDeclaration needs to be checked that it is uninstantiated later + node.kind !== 267 /* ModuleDeclaration */ && node.parent.kind === 312 /* SourceFile */ && (moduleKind === 1 /* CommonJS */ || getSourceFileOfNode(node).impliedNodeFormat === 1 /* CommonJS */)) { return grammarErrorOnNode(modifier, Diagnostics.A_top_level_export_modifier_cannot_be_used_on_value_declarations_in_a_CommonJS_module_when_verbatimModuleSyntax_is_enabled); } - if (flags & 1 /* Export */) { + if (flags & 32 /* Export */) { return grammarErrorOnNode(modifier, Diagnostics._0_modifier_already_seen, "export"); - } else if (flags & 2 /* Ambient */) { + } else if (flags & 128 /* Ambient */) { return grammarErrorOnNode(modifier, Diagnostics._0_modifier_must_precede_1_modifier, "export", "declare"); - } else if (flags & 256 /* Abstract */) { + } else if (flags & 64 /* Abstract */) { return grammarErrorOnNode(modifier, Diagnostics._0_modifier_must_precede_1_modifier, "export", "abstract"); - } else if (flags & 512 /* Async */) { + } else if (flags & 1024 /* Async */) { return grammarErrorOnNode(modifier, Diagnostics._0_modifier_must_precede_1_modifier, "export", "async"); } else if (isClassLike(node.parent)) { return grammarErrorOnNode(modifier, Diagnostics._0_modifier_cannot_appear_on_class_elements_of_this_kind, "export"); - } else if (node.kind === 168 /* Parameter */) { + } else if (node.kind === 169 /* Parameter */) { return grammarErrorOnNode(modifier, Diagnostics._0_modifier_cannot_appear_on_a_parameter, "export"); + } else if (blockScopeKind === 4 /* Using */) { + return grammarErrorOnNode(modifier, Diagnostics._0_modifier_cannot_appear_on_a_using_declaration, "export"); + } else if (blockScopeKind === 6 /* AwaitUsing */) { + return grammarErrorOnNode(modifier, Diagnostics._0_modifier_cannot_appear_on_an_await_using_declaration, "export"); } - flags |= 1 /* Export */; + flags |= 32 /* Export */; break; case 90 /* DefaultKeyword */: - const container = node.parent.kind === 311 /* SourceFile */ ? node.parent : node.parent.parent; - if (container.kind === 266 /* ModuleDeclaration */ && !isAmbientModule(container)) { + const container = node.parent.kind === 312 /* SourceFile */ ? node.parent : node.parent.parent; + if (container.kind === 267 /* ModuleDeclaration */ && !isAmbientModule(container)) { return grammarErrorOnNode(modifier, Diagnostics.A_default_export_can_only_be_used_in_an_ECMAScript_style_module); - } else if (!(flags & 1 /* Export */)) { + } else if (blockScopeKind === 4 /* Using */) { + return grammarErrorOnNode(modifier, Diagnostics._0_modifier_cannot_appear_on_a_using_declaration, "default"); + } else if (blockScopeKind === 6 /* AwaitUsing */) { + return grammarErrorOnNode(modifier, Diagnostics._0_modifier_cannot_appear_on_an_await_using_declaration, "default"); + } else if (!(flags & 32 /* Export */)) { return grammarErrorOnNode(modifier, Diagnostics._0_modifier_must_precede_1_modifier, "export", "default"); } else if (sawExportBeforeDecorators) { return grammarErrorOnNode(firstDecorator, Diagnostics.Decorators_are_not_valid_here); } - flags |= 1024 /* Default */; + flags |= 2048 /* Default */; break; case 138 /* DeclareKeyword */: - if (flags & 2 /* Ambient */) { + if (flags & 128 /* Ambient */) { return grammarErrorOnNode(modifier, Diagnostics._0_modifier_already_seen, "declare"); - } else if (flags & 512 /* Async */) { + } else if (flags & 1024 /* Async */) { return grammarErrorOnNode(modifier, Diagnostics._0_modifier_cannot_be_used_in_an_ambient_context, "async"); - } else if (flags & 16384 /* Override */) { + } else if (flags & 16 /* Override */) { return grammarErrorOnNode(modifier, Diagnostics._0_modifier_cannot_be_used_in_an_ambient_context, "override"); } else if (isClassLike(node.parent) && !isPropertyDeclaration(node)) { return grammarErrorOnNode(modifier, Diagnostics._0_modifier_cannot_appear_on_class_elements_of_this_kind, "declare"); - } else if (node.kind === 168 /* Parameter */) { + } else if (node.kind === 169 /* Parameter */) { return grammarErrorOnNode(modifier, Diagnostics._0_modifier_cannot_appear_on_a_parameter, "declare"); - } else if (node.parent.flags & 16777216 /* Ambient */ && node.parent.kind === 267 /* ModuleBlock */) { + } else if (blockScopeKind === 4 /* Using */) { + return grammarErrorOnNode(modifier, Diagnostics._0_modifier_cannot_appear_on_a_using_declaration, "declare"); + } else if (blockScopeKind === 6 /* AwaitUsing */) { + return grammarErrorOnNode(modifier, Diagnostics._0_modifier_cannot_appear_on_an_await_using_declaration, "declare"); + } else if (node.parent.flags & 33554432 /* Ambient */ && node.parent.kind === 268 /* ModuleBlock */) { return grammarErrorOnNode(modifier, Diagnostics.A_declare_modifier_cannot_be_used_in_an_already_ambient_context); } else if (isPrivateIdentifierClassElementDeclaration(node)) { return grammarErrorOnNode(modifier, Diagnostics._0_modifier_cannot_be_used_with_a_private_identifier, "declare"); - } else if (flags & 128 /* Accessor */) { + } else if (flags & 512 /* Accessor */) { return grammarErrorOnNode(modifier, Diagnostics._0_modifier_cannot_be_used_with_1_modifier, "declare", "accessor"); } - flags |= 2 /* Ambient */; + flags |= 128 /* Ambient */; lastDeclare = modifier; break; case 128 /* AbstractKeyword */: - if (flags & 256 /* Abstract */) { + if (flags & 64 /* Abstract */) { return grammarErrorOnNode(modifier, Diagnostics._0_modifier_already_seen, "abstract"); } - if (node.kind !== 262 /* ClassDeclaration */ && node.kind !== 184 /* ConstructorType */) { - if (node.kind !== 173 /* MethodDeclaration */ && node.kind !== 171 /* PropertyDeclaration */ && node.kind !== 176 /* GetAccessor */ && node.kind !== 177 /* SetAccessor */) { + if (node.kind !== 263 /* ClassDeclaration */ && node.kind !== 185 /* ConstructorType */) { + if (node.kind !== 174 /* MethodDeclaration */ && node.kind !== 172 /* PropertyDeclaration */ && node.kind !== 177 /* GetAccessor */ && node.kind !== 178 /* SetAccessor */) { return grammarErrorOnNode(modifier, Diagnostics.abstract_modifier_can_only_appear_on_a_class_method_or_property_declaration); } - if (!(node.parent.kind === 262 /* ClassDeclaration */ && hasSyntacticModifier(node.parent, 256 /* Abstract */))) { - const message = node.kind === 171 /* PropertyDeclaration */ ? Diagnostics.Abstract_properties_can_only_appear_within_an_abstract_class : Diagnostics.Abstract_methods_can_only_appear_within_an_abstract_class; + if (!(node.parent.kind === 263 /* ClassDeclaration */ && hasSyntacticModifier(node.parent, 64 /* Abstract */))) { + const message = node.kind === 172 /* PropertyDeclaration */ ? Diagnostics.Abstract_properties_can_only_appear_within_an_abstract_class : Diagnostics.Abstract_methods_can_only_appear_within_an_abstract_class; return grammarErrorOnNode(modifier, message); } - if (flags & 32 /* Static */) { + if (flags & 256 /* Static */) { return grammarErrorOnNode(modifier, Diagnostics._0_modifier_cannot_be_used_with_1_modifier, "static", "abstract"); } - if (flags & 8 /* Private */) { + if (flags & 2 /* Private */) { return grammarErrorOnNode(modifier, Diagnostics._0_modifier_cannot_be_used_with_1_modifier, "private", "abstract"); } - if (flags & 512 /* Async */ && lastAsync) { + if (flags & 1024 /* Async */ && lastAsync) { return grammarErrorOnNode(lastAsync, Diagnostics._0_modifier_cannot_be_used_with_1_modifier, "async", "abstract"); } - if (flags & 16384 /* Override */) { + if (flags & 16 /* Override */) { return grammarErrorOnNode(modifier, Diagnostics._0_modifier_must_precede_1_modifier, "abstract", "override"); } - if (flags & 128 /* Accessor */) { + if (flags & 512 /* Accessor */) { return grammarErrorOnNode(modifier, Diagnostics._0_modifier_must_precede_1_modifier, "abstract", "accessor"); } } if (isNamedDeclaration(node) && node.name.kind === 81 /* PrivateIdentifier */) { return grammarErrorOnNode(modifier, Diagnostics._0_modifier_cannot_be_used_with_a_private_identifier, "abstract"); } - flags |= 256 /* Abstract */; + flags |= 64 /* Abstract */; break; case 134 /* AsyncKeyword */: - if (flags & 512 /* Async */) { + if (flags & 1024 /* Async */) { return grammarErrorOnNode(modifier, Diagnostics._0_modifier_already_seen, "async"); - } else if (flags & 2 /* Ambient */ || node.parent.flags & 16777216 /* Ambient */) { + } else if (flags & 128 /* Ambient */ || node.parent.flags & 33554432 /* Ambient */) { return grammarErrorOnNode(modifier, Diagnostics._0_modifier_cannot_be_used_in_an_ambient_context, "async"); - } else if (node.kind === 168 /* Parameter */) { + } else if (node.kind === 169 /* Parameter */) { return grammarErrorOnNode(modifier, Diagnostics._0_modifier_cannot_appear_on_a_parameter, "async"); } - if (flags & 256 /* Abstract */) { + if (flags & 64 /* Abstract */) { return grammarErrorOnNode(modifier, Diagnostics._0_modifier_cannot_be_used_with_1_modifier, "async", "abstract"); } - flags |= 512 /* Async */; + flags |= 1024 /* Async */; lastAsync = modifier; break; case 103 /* InKeyword */: case 147 /* OutKeyword */: - const inOutFlag = modifier.kind === 103 /* InKeyword */ ? 32768 /* In */ : 65536 /* Out */; + const inOutFlag = modifier.kind === 103 /* InKeyword */ ? 8192 /* In */ : 16384 /* Out */; const inOutText = modifier.kind === 103 /* InKeyword */ ? "in" : "out"; - if (node.kind !== 167 /* TypeParameter */ || !(isInterfaceDeclaration(node.parent) || isClassLike(node.parent) || isTypeAliasDeclaration(node.parent))) { + if (node.kind !== 168 /* TypeParameter */ || !(isInterfaceDeclaration(node.parent) || isClassLike(node.parent) || isTypeAliasDeclaration(node.parent))) { return grammarErrorOnNode(modifier, Diagnostics._0_modifier_can_only_appear_on_a_type_parameter_of_a_class_interface_or_type_alias, inOutText); } if (flags & inOutFlag) { return grammarErrorOnNode(modifier, Diagnostics._0_modifier_already_seen, inOutText); } - if (inOutFlag & 32768 /* In */ && flags & 65536 /* Out */) { + if (inOutFlag & 8192 /* In */ && flags & 16384 /* Out */) { return grammarErrorOnNode(modifier, Diagnostics._0_modifier_must_precede_1_modifier, "in", "out"); } flags |= inOutFlag; @@ -183494,25 +167513,25 @@ ${lanes.join("\n")} } } } - if (node.kind === 175 /* Constructor */) { - if (flags & 32 /* Static */) { + if (node.kind === 176 /* Constructor */) { + if (flags & 256 /* Static */) { return grammarErrorOnNode(lastStatic, Diagnostics._0_modifier_cannot_appear_on_a_constructor_declaration, "static"); } - if (flags & 16384 /* Override */) { + if (flags & 16 /* Override */) { return grammarErrorOnNode(lastOverride, Diagnostics._0_modifier_cannot_appear_on_a_constructor_declaration, "override"); } - if (flags & 512 /* Async */) { + if (flags & 1024 /* Async */) { return grammarErrorOnNode(lastAsync, Diagnostics._0_modifier_cannot_appear_on_a_constructor_declaration, "async"); } return false; - } else if ((node.kind === 271 /* ImportDeclaration */ || node.kind === 270 /* ImportEqualsDeclaration */) && flags & 2 /* Ambient */) { + } else if ((node.kind === 272 /* ImportDeclaration */ || node.kind === 271 /* ImportEqualsDeclaration */) && flags & 128 /* Ambient */) { return grammarErrorOnNode(lastDeclare, Diagnostics.A_0_modifier_cannot_be_used_with_an_import_declaration, "declare"); - } else if (node.kind === 168 /* Parameter */ && flags & 16476 /* ParameterPropertyModifier */ && isBindingPattern(node.name)) { + } else if (node.kind === 169 /* Parameter */ && flags & 31 /* ParameterPropertyModifier */ && isBindingPattern(node.name)) { return grammarErrorOnNode(node, Diagnostics.A_parameter_property_may_not_be_declared_using_a_binding_pattern); - } else if (node.kind === 168 /* Parameter */ && flags & 16476 /* ParameterPropertyModifier */ && node.dotDotDotToken) { + } else if (node.kind === 169 /* Parameter */ && flags & 31 /* ParameterPropertyModifier */ && node.dotDotDotToken) { return grammarErrorOnNode(node, Diagnostics.A_parameter_property_cannot_be_declared_using_a_rest_parameter); } - if (flags & 512 /* Async */) { + if (flags & 1024 /* Async */) { return checkGrammarAsyncModifier(node, lastAsync); } return false; @@ -183529,46 +167548,47 @@ ${lanes.join("\n")} } function findFirstIllegalModifier(node) { switch (node.kind) { - case 176 /* GetAccessor */: - case 177 /* SetAccessor */: - case 175 /* Constructor */: - case 171 /* PropertyDeclaration */: - case 170 /* PropertySignature */: - case 173 /* MethodDeclaration */: - case 172 /* MethodSignature */: - case 180 /* IndexSignature */: - case 266 /* ModuleDeclaration */: - case 271 /* ImportDeclaration */: - case 270 /* ImportEqualsDeclaration */: - case 277 /* ExportDeclaration */: - case 276 /* ExportAssignment */: - case 217 /* FunctionExpression */: - case 218 /* ArrowFunction */: - case 168 /* Parameter */: - case 167 /* TypeParameter */: + case 177 /* GetAccessor */: + case 178 /* SetAccessor */: + case 176 /* Constructor */: + case 172 /* PropertyDeclaration */: + case 171 /* PropertySignature */: + case 174 /* MethodDeclaration */: + case 173 /* MethodSignature */: + case 181 /* IndexSignature */: + case 267 /* ModuleDeclaration */: + case 272 /* ImportDeclaration */: + case 271 /* ImportEqualsDeclaration */: + case 278 /* ExportDeclaration */: + case 277 /* ExportAssignment */: + case 218 /* FunctionExpression */: + case 219 /* ArrowFunction */: + case 169 /* Parameter */: + case 168 /* TypeParameter */: return void 0; - case 174 /* ClassStaticBlockDeclaration */: - case 302 /* PropertyAssignment */: - case 303 /* ShorthandPropertyAssignment */: - case 269 /* NamespaceExportDeclaration */: - case 281 /* MissingDeclaration */: + case 175 /* ClassStaticBlockDeclaration */: + case 303 /* PropertyAssignment */: + case 304 /* ShorthandPropertyAssignment */: + case 270 /* NamespaceExportDeclaration */: + case 282 /* MissingDeclaration */: return find(node.modifiers, isModifier); default: - if (node.parent.kind === 267 /* ModuleBlock */ || node.parent.kind === 311 /* SourceFile */) { + if (node.parent.kind === 268 /* ModuleBlock */ || node.parent.kind === 312 /* SourceFile */) { return void 0; } switch (node.kind) { - case 261 /* FunctionDeclaration */: + case 262 /* FunctionDeclaration */: return findFirstModifierExcept(node, 134 /* AsyncKeyword */); - case 262 /* ClassDeclaration */: - case 184 /* ConstructorType */: + case 263 /* ClassDeclaration */: + case 185 /* ConstructorType */: return findFirstModifierExcept(node, 128 /* AbstractKeyword */); - case 230 /* ClassExpression */: - case 263 /* InterfaceDeclaration */: - case 242 /* VariableStatement */: - case 264 /* TypeAliasDeclaration */: + case 231 /* ClassExpression */: + case 264 /* InterfaceDeclaration */: + case 265 /* TypeAliasDeclaration */: return find(node.modifiers, isModifier); - case 265 /* EnumDeclaration */: + case 243 /* VariableStatement */: + return node.declarationList.flags & 4 /* Using */ ? findFirstModifierExcept(node, 135 /* AwaitKeyword */) : find(node.modifiers, isModifier); + case 266 /* EnumDeclaration */: return findFirstModifierExcept(node, 87 /* ConstKeyword */); default: Debug.assertNever(node); @@ -183584,10 +167604,10 @@ ${lanes.join("\n")} } function checkGrammarAsyncModifier(node, asyncModifier) { switch (node.kind) { - case 173 /* MethodDeclaration */: - case 261 /* FunctionDeclaration */: - case 217 /* FunctionExpression */: - case 218 /* ArrowFunction */: + case 174 /* MethodDeclaration */: + case 262 /* FunctionDeclaration */: + case 218 /* FunctionExpression */: + case 219 /* ArrowFunction */: return false; } return grammarErrorOnNode(asyncModifier, Diagnostics._0_modifier_cannot_be_used_here, "async"); @@ -183615,7 +167635,7 @@ ${lanes.join("\n")} if (i !== parameterCount - 1) { return grammarErrorOnNode(parameter.dotDotDotToken, Diagnostics.A_rest_parameter_must_be_last_in_a_parameter_list); } - if (!(parameter.flags & 16777216 /* Ambient */)) { + if (!(parameter.flags & 33554432 /* Ambient */)) { checkGrammarForDisallowedTrailingComma(parameters, Diagnostics.A_rest_parameter_or_binding_pattern_may_not_have_a_trailing_comma); } if (parameter.questionToken) { @@ -183645,12 +167665,12 @@ ${lanes.join("\n")} if (length(nonSimpleParameters)) { forEach(nonSimpleParameters, (parameter) => { addRelatedInfo( - error(parameter, Diagnostics.This_parameter_is_not_allowed_with_use_strict_directive), + error2(parameter, Diagnostics.This_parameter_is_not_allowed_with_use_strict_directive), createDiagnosticForNode(useStrictDirective, Diagnostics.use_strict_directive_used_here) ); }); const diagnostics2 = nonSimpleParameters.map((parameter, index) => index === 0 ? createDiagnosticForNode(parameter, Diagnostics.Non_simple_parameter_declared_here) : createDiagnosticForNode(parameter, Diagnostics.and_here)); - addRelatedInfo(error(useStrictDirective, Diagnostics.use_strict_directive_cannot_be_used_with_non_simple_parameter_list), ...diagnostics2); + addRelatedInfo(error2(useStrictDirective, Diagnostics.use_strict_directive_cannot_be_used_with_non_simple_parameter_list), ...diagnostics2); return true; } } @@ -183732,7 +167752,7 @@ ${lanes.join("\n")} return checkGrammarForDisallowedTrailingComma(typeArguments) || checkGrammarForAtLeastOneTypeArgument(node, typeArguments); } function checkGrammarTaggedTemplateChain(node) { - if (node.questionDotToken || node.flags & 32 /* OptionalChain */) { + if (node.questionDotToken || node.flags & 64 /* OptionalChain */) { return grammarErrorOnNode(node.template, Diagnostics.Tagged_template_expressions_are_not_permitted_in_an_optional_chain); } return false; @@ -183800,11 +167820,11 @@ ${lanes.join("\n")} return false; } function checkGrammarComputedPropertyName(node) { - if (node.kind !== 166 /* ComputedPropertyName */) { + if (node.kind !== 167 /* ComputedPropertyName */) { return false; } const computedPropertyName = node; - if (computedPropertyName.expression.kind === 225 /* BinaryExpression */ && computedPropertyName.expression.operatorToken.kind === 28 /* CommaToken */) { + if (computedPropertyName.expression.kind === 226 /* BinaryExpression */ && computedPropertyName.expression.operatorToken.kind === 28 /* CommaToken */) { return grammarErrorOnNode(computedPropertyName.expression, Diagnostics.A_comma_expression_is_not_allowed_in_a_computed_property_name); } return false; @@ -183812,9 +167832,9 @@ ${lanes.join("\n")} function checkGrammarForGenerator(node) { if (node.asteriskToken) { Debug.assert( - node.kind === 261 /* FunctionDeclaration */ || node.kind === 217 /* FunctionExpression */ || node.kind === 173 /* MethodDeclaration */ + node.kind === 262 /* FunctionDeclaration */ || node.kind === 218 /* FunctionExpression */ || node.kind === 174 /* MethodDeclaration */ ); - if (node.flags & 16777216 /* Ambient */) { + if (node.flags & 33554432 /* Ambient */) { return grammarErrorOnNode(node.asteriskToken, Diagnostics.Generators_are_not_allowed_in_an_ambient_context); } if (!node.body) { @@ -183831,7 +167851,7 @@ ${lanes.join("\n")} function checkGrammarObjectLiteralExpression(node, inDestructuring) { const seen = /* @__PURE__ */ new Map(); for (const prop of node.properties) { - if (prop.kind === 304 /* SpreadAssignment */) { + if (prop.kind === 305 /* SpreadAssignment */) { if (inDestructuring) { const expression = skipParentheses(prop.expression); if (isArrayLiteralExpression(expression) || isObjectLiteralExpression(expression)) { @@ -183841,10 +167861,10 @@ ${lanes.join("\n")} continue; } const name = prop.name; - if (name.kind === 166 /* ComputedPropertyName */) { + if (name.kind === 167 /* ComputedPropertyName */) { checkGrammarComputedPropertyName(name); } - if (prop.kind === 303 /* ShorthandPropertyAssignment */ && !inDestructuring && prop.objectAssignmentInitializer) { + if (prop.kind === 304 /* ShorthandPropertyAssignment */ && !inDestructuring && prop.objectAssignmentInitializer) { grammarErrorOnNode(prop.equalsToken, Diagnostics.Did_you_mean_to_use_a_Colon_An_can_only_follow_a_property_name_when_the_containing_object_literal_is_part_of_a_destructuring_pattern); } if (name.kind === 81 /* PrivateIdentifier */) { @@ -183852,7 +167872,7 @@ ${lanes.join("\n")} } if (canHaveModifiers(prop) && prop.modifiers) { for (const mod of prop.modifiers) { - if (isModifier(mod) && (mod.kind !== 134 /* AsyncKeyword */ || prop.kind !== 173 /* MethodDeclaration */)) { + if (isModifier(mod) && (mod.kind !== 134 /* AsyncKeyword */ || prop.kind !== 174 /* MethodDeclaration */)) { grammarErrorOnNode(mod, Diagnostics._0_modifier_cannot_be_used_here, getTextOfNode(mod)); } } @@ -183865,8 +167885,8 @@ ${lanes.join("\n")} } let currentKind; switch (prop.kind) { - case 303 /* ShorthandPropertyAssignment */: - case 302 /* PropertyAssignment */: + case 304 /* ShorthandPropertyAssignment */: + case 303 /* PropertyAssignment */: checkGrammarForInvalidExclamationToken(prop.exclamationToken, Diagnostics.A_definite_assignment_assertion_is_not_permitted_in_this_context); checkGrammarForInvalidQuestionMark(prop.questionToken, Diagnostics.An_object_member_cannot_be_declared_optional); if (name.kind === 9 /* NumericLiteral */) { @@ -183874,13 +167894,13 @@ ${lanes.join("\n")} } currentKind = 4 /* PropertyAssignment */; break; - case 173 /* MethodDeclaration */: + case 174 /* MethodDeclaration */: currentKind = 8 /* Method */; break; - case 176 /* GetAccessor */: + case 177 /* GetAccessor */: currentKind = 1 /* GetAccessor */; break; - case 177 /* SetAccessor */: + case 178 /* SetAccessor */: currentKind = 2 /* SetAccessor */; break; default: @@ -183917,7 +167937,7 @@ ${lanes.join("\n")} checkGrammarTypeArguments(node, node.typeArguments); const seen = /* @__PURE__ */ new Map(); for (const attr of node.attributes.properties) { - if (attr.kind === 292 /* JsxSpreadAttribute */) { + if (attr.kind === 293 /* JsxSpreadAttribute */) { continue; } const { name, initializer } = attr; @@ -183927,7 +167947,7 @@ ${lanes.join("\n")} } else { return grammarErrorOnNode(name, Diagnostics.JSX_elements_cannot_have_multiple_attributes_with_the_same_name); } - if (initializer && initializer.kind === 293 /* JsxExpression */ && !initializer.expression) { + if (initializer && initializer.kind === 294 /* JsxExpression */ && !initializer.expression) { return grammarErrorOnNode(initializer, Diagnostics.JSX_attributes_must_only_be_assigned_a_non_empty_expression); } } @@ -183949,16 +167969,13 @@ ${lanes.join("\n")} if (checkGrammarStatementInAmbientContext(forInOrOfStatement)) { return true; } - if (forInOrOfStatement.kind === 249 /* ForOfStatement */ && forInOrOfStatement.awaitModifier) { - if (!(forInOrOfStatement.flags & 32768 /* AwaitContext */)) { + if (forInOrOfStatement.kind === 250 /* ForOfStatement */ && forInOrOfStatement.awaitModifier) { + if (!(forInOrOfStatement.flags & 65536 /* AwaitContext */)) { const sourceFile = getSourceFileOfNode(forInOrOfStatement); if (isInTopLevelContext(forInOrOfStatement)) { if (!hasParseDiagnostics(sourceFile)) { if (!isEffectiveExternalModule(sourceFile, compilerOptions)) { - diagnostics.add(createDiagnosticForNode( - forInOrOfStatement.awaitModifier, - Diagnostics.for_await_loops_are_only_allowed_at_the_top_level_of_a_file_when_that_file_is_a_module_but_this_file_has_no_imports_or_exports_Consider_adding_an_empty_export_to_make_this_file_a_module - )); + diagnostics.add(createDiagnosticForNode(forInOrOfStatement.awaitModifier, Diagnostics.for_await_loops_are_only_allowed_at_the_top_level_of_a_file_when_that_file_is_a_module_but_this_file_has_no_imports_or_exports_Consider_adding_an_empty_export_to_make_this_file_a_module)); } switch (moduleKind) { case 100 /* Node16 */: @@ -183977,10 +167994,7 @@ ${lanes.join("\n")} } default: diagnostics.add( - createDiagnosticForNode( - forInOrOfStatement.awaitModifier, - Diagnostics.Top_level_for_await_loops_are_only_allowed_when_the_module_option_is_set_to_es2022_esnext_system_node16_or_nodenext_and_the_target_option_is_set_to_es2017_or_higher - ) + createDiagnosticForNode(forInOrOfStatement.awaitModifier, Diagnostics.Top_level_for_await_loops_are_only_allowed_when_the_module_option_is_set_to_es2022_esnext_system_node16_or_nodenext_and_the_target_option_is_set_to_es2017_or_higher) ); break; } @@ -183989,7 +168003,7 @@ ${lanes.join("\n")} if (!hasParseDiagnostics(sourceFile)) { const diagnostic = createDiagnosticForNode(forInOrOfStatement.awaitModifier, Diagnostics.for_await_loops_are_only_allowed_within_async_functions_and_at_the_top_levels_of_modules); const func = getContainingFunction(forInOrOfStatement); - if (func && func.kind !== 175 /* Constructor */) { + if (func && func.kind !== 176 /* Constructor */) { Debug.assert((getFunctionFlags(func) & 2 /* Async */) === 0, "Enclosing function should never be an async function."); const relatedInfo = createDiagnosticForNode(func, Diagnostics.Did_you_mean_to_mark_this_function_as_async); addRelatedInfo(diagnostic, relatedInfo); @@ -184001,11 +168015,11 @@ ${lanes.join("\n")} return false; } } - if (isForOfStatement(forInOrOfStatement) && !(forInOrOfStatement.flags & 32768 /* AwaitContext */) && isIdentifier(forInOrOfStatement.initializer) && forInOrOfStatement.initializer.escapedText === "async") { + if (isForOfStatement(forInOrOfStatement) && !(forInOrOfStatement.flags & 65536 /* AwaitContext */) && isIdentifier(forInOrOfStatement.initializer) && forInOrOfStatement.initializer.escapedText === "async") { grammarErrorOnNode(forInOrOfStatement.initializer, Diagnostics.The_left_hand_side_of_a_for_of_statement_may_not_be_async); return false; } - if (forInOrOfStatement.initializer.kind === 260 /* VariableDeclarationList */) { + if (forInOrOfStatement.initializer.kind === 261 /* VariableDeclarationList */) { const variableList = forInOrOfStatement.initializer; if (!checkGrammarVariableDeclarationList(variableList)) { const declarations = variableList.declarations; @@ -184013,16 +168027,16 @@ ${lanes.join("\n")} return false; } if (declarations.length > 1) { - const diagnostic = forInOrOfStatement.kind === 248 /* ForInStatement */ ? Diagnostics.Only_a_single_variable_declaration_is_allowed_in_a_for_in_statement : Diagnostics.Only_a_single_variable_declaration_is_allowed_in_a_for_of_statement; + const diagnostic = forInOrOfStatement.kind === 249 /* ForInStatement */ ? Diagnostics.Only_a_single_variable_declaration_is_allowed_in_a_for_in_statement : Diagnostics.Only_a_single_variable_declaration_is_allowed_in_a_for_of_statement; return grammarErrorOnFirstToken(variableList.declarations[1], diagnostic); } const firstDeclaration = declarations[0]; if (firstDeclaration.initializer) { - const diagnostic = forInOrOfStatement.kind === 248 /* ForInStatement */ ? Diagnostics.The_variable_declaration_of_a_for_in_statement_cannot_have_an_initializer : Diagnostics.The_variable_declaration_of_a_for_of_statement_cannot_have_an_initializer; + const diagnostic = forInOrOfStatement.kind === 249 /* ForInStatement */ ? Diagnostics.The_variable_declaration_of_a_for_in_statement_cannot_have_an_initializer : Diagnostics.The_variable_declaration_of_a_for_of_statement_cannot_have_an_initializer; return grammarErrorOnNode(firstDeclaration.name, diagnostic); } if (firstDeclaration.type) { - const diagnostic = forInOrOfStatement.kind === 248 /* ForInStatement */ ? Diagnostics.The_left_hand_side_of_a_for_in_statement_cannot_use_a_type_annotation : Diagnostics.The_left_hand_side_of_a_for_of_statement_cannot_use_a_type_annotation; + const diagnostic = forInOrOfStatement.kind === 249 /* ForInStatement */ ? Diagnostics.The_left_hand_side_of_a_for_in_statement_cannot_use_a_type_annotation : Diagnostics.The_left_hand_side_of_a_for_of_statement_cannot_use_a_type_annotation; return grammarErrorOnNode(firstDeclaration, diagnostic); } } @@ -184030,22 +168044,22 @@ ${lanes.join("\n")} return false; } function checkGrammarAccessor(accessor) { - if (!(accessor.flags & 16777216 /* Ambient */) && accessor.parent.kind !== 186 /* TypeLiteral */ && accessor.parent.kind !== 263 /* InterfaceDeclaration */) { + if (!(accessor.flags & 33554432 /* Ambient */) && accessor.parent.kind !== 187 /* TypeLiteral */ && accessor.parent.kind !== 264 /* InterfaceDeclaration */) { if (languageVersion < 1 /* ES5 */) { return grammarErrorOnNode(accessor.name, Diagnostics.Accessors_are_only_available_when_targeting_ECMAScript_5_and_higher); } if (languageVersion < 2 /* ES2015 */ && isPrivateIdentifier(accessor.name)) { return grammarErrorOnNode(accessor.name, Diagnostics.Private_identifiers_are_only_available_when_targeting_ECMAScript_2015_and_higher); } - if (accessor.body === void 0 && !hasSyntacticModifier(accessor, 256 /* Abstract */)) { + if (accessor.body === void 0 && !hasSyntacticModifier(accessor, 64 /* Abstract */)) { return grammarErrorAtPos(accessor, accessor.end - 1, ";".length, Diagnostics._0_expected, "{"); } } if (accessor.body) { - if (hasSyntacticModifier(accessor, 256 /* Abstract */)) { + if (hasSyntacticModifier(accessor, 64 /* Abstract */)) { return grammarErrorOnNode(accessor, Diagnostics.An_abstract_accessor_cannot_have_an_implementation); } - if (accessor.parent.kind === 186 /* TypeLiteral */ || accessor.parent.kind === 263 /* InterfaceDeclaration */) { + if (accessor.parent.kind === 187 /* TypeLiteral */ || accessor.parent.kind === 264 /* InterfaceDeclaration */) { return grammarErrorOnNode(accessor.body, Diagnostics.An_implementation_cannot_be_declared_in_ambient_contexts); } } @@ -184055,10 +168069,10 @@ ${lanes.join("\n")} if (!doesAccessorHaveCorrectParameterCount(accessor)) { return grammarErrorOnNode( accessor.name, - accessor.kind === 176 /* GetAccessor */ ? Diagnostics.A_get_accessor_cannot_have_parameters : Diagnostics.A_set_accessor_must_have_exactly_one_parameter + accessor.kind === 177 /* GetAccessor */ ? Diagnostics.A_get_accessor_cannot_have_parameters : Diagnostics.A_set_accessor_must_have_exactly_one_parameter ); } - if (accessor.kind === 177 /* SetAccessor */) { + if (accessor.kind === 178 /* SetAccessor */) { if (accessor.type) { return grammarErrorOnNode(accessor.name, Diagnostics.A_set_accessor_cannot_have_a_return_type_annotation); } @@ -184076,10 +168090,10 @@ ${lanes.join("\n")} return false; } function doesAccessorHaveCorrectParameterCount(accessor) { - return getAccessorThisParameter(accessor) || accessor.parameters.length === (accessor.kind === 176 /* GetAccessor */ ? 0 : 1); + return getAccessorThisParameter(accessor) || accessor.parameters.length === (accessor.kind === 177 /* GetAccessor */ ? 0 : 1); } function getAccessorThisParameter(accessor) { - if (accessor.parameters.length === (accessor.kind === 176 /* GetAccessor */ ? 1 : 2)) { + if (accessor.parameters.length === (accessor.kind === 177 /* GetAccessor */ ? 1 : 2)) { return getThisParameter(accessor); } } @@ -184096,7 +168110,7 @@ ${lanes.join("\n")} } } switch (parent2.kind) { - case 259 /* VariableDeclaration */: + case 260 /* VariableDeclaration */: const decl = parent2; if (decl.name.kind !== 80 /* Identifier */) { return grammarErrorOnNode(node, Diagnostics.unique_symbol_types_may_not_be_used_on_a_variable_declaration_with_a_binding_name); @@ -184108,13 +168122,13 @@ ${lanes.join("\n")} return grammarErrorOnNode(parent2.name, Diagnostics.A_variable_whose_type_is_a_unique_symbol_type_must_be_const); } break; - case 171 /* PropertyDeclaration */: + case 172 /* PropertyDeclaration */: if (!isStatic(parent2) || !hasEffectiveReadonlyModifier(parent2)) { return grammarErrorOnNode(parent2.name, Diagnostics.A_property_of_a_class_whose_type_is_a_unique_symbol_type_must_be_both_static_and_readonly); } break; - case 170 /* PropertySignature */: - if (!hasSyntacticModifier(parent2, 64 /* Readonly */)) { + case 171 /* PropertySignature */: + if (!hasSyntacticModifier(parent2, 8 /* Readonly */)) { return grammarErrorOnNode(parent2.name, Diagnostics.A_property_of_an_interface_or_type_literal_whose_type_is_a_unique_symbol_type_must_be_readonly); } break; @@ -184122,7 +168136,7 @@ ${lanes.join("\n")} return grammarErrorOnNode(node, Diagnostics.unique_symbol_types_are_not_allowed_here); } } else if (node.operator === 148 /* ReadonlyKeyword */) { - if (node.type.kind !== 187 /* ArrayType */ && node.type.kind !== 188 /* TupleType */) { + if (node.type.kind !== 188 /* ArrayType */ && node.type.kind !== 189 /* TupleType */) { return grammarErrorOnFirstToken(node, Diagnostics.readonly_type_modifier_is_only_permitted_on_array_and_tuple_literal_types, tokenToString(155 /* SymbolKeyword */)); } } @@ -184136,8 +168150,8 @@ ${lanes.join("\n")} if (checkGrammarFunctionLikeDeclaration(node)) { return true; } - if (node.kind === 173 /* MethodDeclaration */) { - if (node.parent.kind === 209 /* ObjectLiteralExpression */) { + if (node.kind === 174 /* MethodDeclaration */) { + if (node.parent.kind === 210 /* ObjectLiteralExpression */) { if (node.modifiers && !(node.modifiers.length === 1 && first(node.modifiers).kind === 134 /* AsyncKeyword */)) { return grammarErrorOnFirstToken(node, Diagnostics.Modifiers_cannot_appear_here); } else if (checkGrammarForInvalidQuestionMark(node.questionToken, Diagnostics.An_object_member_cannot_be_declared_optional)) { @@ -184156,14 +168170,14 @@ ${lanes.join("\n")} if (languageVersion < 2 /* ES2015 */ && isPrivateIdentifier(node.name)) { return grammarErrorOnNode(node.name, Diagnostics.Private_identifiers_are_only_available_when_targeting_ECMAScript_2015_and_higher); } - if (node.flags & 16777216 /* Ambient */) { + if (node.flags & 33554432 /* Ambient */) { return checkGrammarForInvalidDynamicName(node.name, Diagnostics.A_computed_property_name_in_an_ambient_context_must_refer_to_an_expression_whose_type_is_a_literal_type_or_a_unique_symbol_type); - } else if (node.kind === 173 /* MethodDeclaration */ && !node.body) { + } else if (node.kind === 174 /* MethodDeclaration */ && !node.body) { return checkGrammarForInvalidDynamicName(node.name, Diagnostics.A_computed_property_name_in_a_method_overload_must_refer_to_an_expression_whose_type_is_a_literal_type_or_a_unique_symbol_type); } - } else if (node.parent.kind === 263 /* InterfaceDeclaration */) { + } else if (node.parent.kind === 264 /* InterfaceDeclaration */) { return checkGrammarForInvalidDynamicName(node.name, Diagnostics.A_computed_property_name_in_an_interface_must_refer_to_an_expression_whose_type_is_a_literal_type_or_a_unique_symbol_type); - } else if (node.parent.kind === 186 /* TypeLiteral */) { + } else if (node.parent.kind === 187 /* TypeLiteral */) { return checkGrammarForInvalidDynamicName(node.name, Diagnostics.A_computed_property_name_in_a_type_literal_must_refer_to_an_expression_whose_type_is_a_literal_type_or_a_unique_symbol_type); } } @@ -184174,9 +168188,9 @@ ${lanes.join("\n")} return grammarErrorOnNode(node, Diagnostics.Jump_target_cannot_cross_function_boundary); } switch (current.kind) { - case 255 /* LabeledStatement */: + case 256 /* LabeledStatement */: if (node.label && current.label.escapedText === node.label.escapedText) { - const isMisplacedContinueLabel = node.kind === 250 /* ContinueStatement */ && !isIterationStatement( + const isMisplacedContinueLabel = node.kind === 251 /* ContinueStatement */ && !isIterationStatement( current.statement, /*lookInLabeledStatements*/ true @@ -184187,8 +168201,8 @@ ${lanes.join("\n")} return false; } break; - case 254 /* SwitchStatement */: - if (node.kind === 251 /* BreakStatement */ && !node.label) { + case 255 /* SwitchStatement */: + if (node.kind === 252 /* BreakStatement */ && !node.label) { return false; } break; @@ -184205,10 +168219,10 @@ ${lanes.join("\n")} current = current.parent; } if (node.label) { - const message = node.kind === 251 /* BreakStatement */ ? Diagnostics.A_break_statement_can_only_jump_to_a_label_of_an_enclosing_statement : Diagnostics.A_continue_statement_can_only_jump_to_a_label_of_an_enclosing_iteration_statement; + const message = node.kind === 252 /* BreakStatement */ ? Diagnostics.A_break_statement_can_only_jump_to_a_label_of_an_enclosing_statement : Diagnostics.A_continue_statement_can_only_jump_to_a_label_of_an_enclosing_iteration_statement; return grammarErrorOnNode(node, message); } else { - const message = node.kind === 251 /* BreakStatement */ ? Diagnostics.A_break_statement_can_only_be_used_within_an_enclosing_iteration_or_switch_statement : Diagnostics.A_continue_statement_can_only_be_used_within_an_enclosing_iteration_statement; + const message = node.kind === 252 /* BreakStatement */ ? Diagnostics.A_break_statement_can_only_be_used_within_an_enclosing_iteration_or_switch_statement : Diagnostics.A_continue_statement_can_only_be_used_within_an_enclosing_iteration_statement; return grammarErrorOnNode(node, message); } } @@ -184228,10 +168242,10 @@ ${lanes.join("\n")} } } function isStringOrNumberLiteralExpression(expr) { - return isStringOrNumericLiteralLike(expr) || expr.kind === 223 /* PrefixUnaryExpression */ && expr.operator === 41 /* MinusToken */ && expr.operand.kind === 9 /* NumericLiteral */; + return isStringOrNumericLiteralLike(expr) || expr.kind === 224 /* PrefixUnaryExpression */ && expr.operator === 41 /* MinusToken */ && expr.operand.kind === 9 /* NumericLiteral */; } function isBigIntLiteralExpression(expr) { - return expr.kind === 10 /* BigIntLiteral */ || expr.kind === 223 /* PrefixUnaryExpression */ && expr.operator === 41 /* MinusToken */ && expr.operand.kind === 10 /* BigIntLiteral */; + return expr.kind === 10 /* BigIntLiteral */ || expr.kind === 224 /* PrefixUnaryExpression */ && expr.operator === 41 /* MinusToken */ && expr.operand.kind === 10 /* BigIntLiteral */; } function isSimpleLiteralEnumReference(expr) { if ((isPropertyAccessExpression(expr) || isElementAccessExpression(expr) && isStringOrNumberLiteralExpression(expr.argumentExpression)) && isEntityNameExpression(expr.expression)) { @@ -184242,7 +168256,7 @@ ${lanes.join("\n")} const initializer = node.initializer; if (initializer) { const isInvalidInitializer = !(isStringOrNumberLiteralExpression(initializer) || isSimpleLiteralEnumReference(initializer) || initializer.kind === 112 /* TrueKeyword */ || initializer.kind === 97 /* FalseKeyword */ || isBigIntLiteralExpression(initializer)); - const isConstOrReadonly = isDeclarationReadonly(node) || isVariableDeclaration(node) && isVarConst(node); + const isConstOrReadonly = isDeclarationReadonly(node) || isVariableDeclaration(node) && isVarConstLike(node); if (isConstOrReadonly && !node.type) { if (isInvalidInitializer) { return grammarErrorOnNode(initializer, Diagnostics.A_const_initializer_in_an_ambient_context_must_be_a_string_or_numeric_literal_or_literal_enum_reference); @@ -184253,27 +168267,41 @@ ${lanes.join("\n")} } } function checkGrammarVariableDeclaration(node) { - if (node.parent.parent.kind !== 248 /* ForInStatement */ && node.parent.parent.kind !== 249 /* ForOfStatement */) { - if (node.flags & 16777216 /* Ambient */) { + const nodeFlags = getCombinedNodeFlagsCached(node); + const blockScopeKind = nodeFlags & 7 /* BlockScoped */; + if (isBindingPattern(node.name)) { + switch (blockScopeKind) { + case 6 /* AwaitUsing */: + return grammarErrorOnNode(node, Diagnostics._0_declarations_may_not_have_binding_patterns, "await using"); + case 4 /* Using */: + return grammarErrorOnNode(node, Diagnostics._0_declarations_may_not_have_binding_patterns, "using"); + } + } + if (node.parent.parent.kind !== 249 /* ForInStatement */ && node.parent.parent.kind !== 250 /* ForOfStatement */) { + if (nodeFlags & 33554432 /* Ambient */) { checkAmbientInitializer(node); } else if (!node.initializer) { if (isBindingPattern(node.name) && !isBindingPattern(node.parent)) { return grammarErrorOnNode(node, Diagnostics.A_destructuring_declaration_must_have_an_initializer); } - if (isVarConst(node)) { - return grammarErrorOnNode(node, Diagnostics.const_declarations_must_be_initialized); + switch (blockScopeKind) { + case 6 /* AwaitUsing */: + return grammarErrorOnNode(node, Diagnostics._0_declarations_must_be_initialized, "await using"); + case 4 /* Using */: + return grammarErrorOnNode(node, Diagnostics._0_declarations_must_be_initialized, "using"); + case 2 /* Const */: + return grammarErrorOnNode(node, Diagnostics._0_declarations_must_be_initialized, "const"); } } } - if (node.exclamationToken && (node.parent.parent.kind !== 242 /* VariableStatement */ || !node.type || node.initializer || node.flags & 16777216 /* Ambient */)) { + if (node.exclamationToken && (node.parent.parent.kind !== 243 /* VariableStatement */ || !node.type || node.initializer || nodeFlags & 33554432 /* Ambient */)) { const message = node.initializer ? Diagnostics.Declarations_with_initializers_cannot_also_have_definite_assignment_assertions : !node.type ? Diagnostics.Declarations_with_definite_assignment_assertions_must_also_have_type_annotations : Diagnostics.A_definite_assignment_assertion_is_not_permitted_in_this_context; return grammarErrorOnNode(node.exclamationToken, message); } - if ((moduleKind < 5 /* ES2015 */ || getSourceFileOfNode(node).impliedNodeFormat === 1 /* CommonJS */) && moduleKind !== 4 /* System */ && !(node.parent.parent.flags & 16777216 /* Ambient */) && hasSyntacticModifier(node.parent.parent, 1 /* Export */)) { + if ((moduleKind < 5 /* ES2015 */ || getSourceFileOfNode(node).impliedNodeFormat === 1 /* CommonJS */) && moduleKind !== 4 /* System */ && !(node.parent.parent.flags & 33554432 /* Ambient */) && hasSyntacticModifier(node.parent.parent, 32 /* Export */)) { checkESModuleMarker(node.name); } - const checkLetConstNames = isLet(node) || isVarConst(node); - return checkLetConstNames && checkGrammarNameInLetOrConstDeclarations(node.name); + return !!blockScopeKind && checkGrammarNameInLetOrConstDeclarations(node.name); } function checkESModuleMarker(name) { if (name.kind === 80 /* Identifier */) { @@ -184313,29 +168341,39 @@ ${lanes.join("\n")} if (!declarationList.declarations.length) { return grammarErrorAtPos(declarationList, declarations.pos, declarations.end - declarations.pos, Diagnostics.Variable_declaration_list_cannot_be_empty); } + const blockScopeFlags = declarationList.flags & 7 /* BlockScoped */; + if ((blockScopeFlags === 4 /* Using */ || blockScopeFlags === 6 /* AwaitUsing */) && isForInStatement(declarationList.parent)) { + return grammarErrorOnNode( + declarationList, + blockScopeFlags === 4 /* Using */ ? Diagnostics.The_left_hand_side_of_a_for_in_statement_cannot_be_a_using_declaration : Diagnostics.The_left_hand_side_of_a_for_in_statement_cannot_be_an_await_using_declaration + ); + } + if (blockScopeFlags === 6 /* AwaitUsing */) { + return checkAwaitGrammar(declarationList); + } return false; } function allowLetAndConstDeclarations(parent2) { switch (parent2.kind) { - case 244 /* IfStatement */: - case 245 /* DoStatement */: - case 246 /* WhileStatement */: - case 253 /* WithStatement */: - case 247 /* ForStatement */: - case 248 /* ForInStatement */: - case 249 /* ForOfStatement */: + case 245 /* IfStatement */: + case 246 /* DoStatement */: + case 247 /* WhileStatement */: + case 254 /* WithStatement */: + case 248 /* ForStatement */: + case 249 /* ForInStatement */: + case 250 /* ForOfStatement */: return false; - case 255 /* LabeledStatement */: + case 256 /* LabeledStatement */: return allowLetAndConstDeclarations(parent2.parent); } return true; } - function checkGrammarForDisallowedLetOrConstStatement(node) { + function checkGrammarForDisallowedBlockScopedVariableStatement(node) { if (!allowLetAndConstDeclarations(node.parent)) { - if (isLet(node.declarationList)) { - return grammarErrorOnNode(node, Diagnostics.let_declarations_can_only_be_declared_inside_a_block); - } else if (isVarConst(node.declarationList)) { - return grammarErrorOnNode(node, Diagnostics.const_declarations_can_only_be_declared_inside_a_block); + const blockScopeKind = getCombinedNodeFlagsCached(node.declarationList) & 7 /* BlockScoped */; + if (blockScopeKind) { + const keyword = blockScopeKind === 1 /* Let */ ? "let" : blockScopeKind === 2 /* Const */ ? "const" : blockScopeKind === 4 /* Using */ ? "using" : blockScopeKind === 6 /* AwaitUsing */ ? "await using" : Debug.fail("Unknown BlockScope flag"); + return grammarErrorOnNode(node, Diagnostics._0_declarations_can_only_be_declared_inside_a_block, keyword); } } } @@ -184424,7 +168462,7 @@ ${lanes.join("\n")} if (isAutoAccessorPropertyDeclaration(node) && checkGrammarForInvalidQuestionMark(node.questionToken, Diagnostics.An_accessor_property_cannot_be_declared_optional)) { return true; } - } else if (node.parent.kind === 263 /* InterfaceDeclaration */) { + } else if (node.parent.kind === 264 /* InterfaceDeclaration */) { if (checkGrammarForInvalidDynamicName(node.name, Diagnostics.A_computed_property_name_in_an_interface_must_refer_to_an_expression_whose_type_is_a_literal_type_or_a_unique_symbol_type)) { return true; } @@ -184441,23 +168479,23 @@ ${lanes.join("\n")} return grammarErrorOnNode(node.initializer, Diagnostics.A_type_literal_property_cannot_have_an_initializer); } } - if (node.flags & 16777216 /* Ambient */) { + if (node.flags & 33554432 /* Ambient */) { checkAmbientInitializer(node); } - if (isPropertyDeclaration(node) && node.exclamationToken && (!isClassLike(node.parent) || !node.type || node.initializer || node.flags & 16777216 /* Ambient */ || isStatic(node) || hasAbstractModifier(node))) { + if (isPropertyDeclaration(node) && node.exclamationToken && (!isClassLike(node.parent) || !node.type || node.initializer || node.flags & 33554432 /* Ambient */ || isStatic(node) || hasAbstractModifier(node))) { const message = node.initializer ? Diagnostics.Declarations_with_initializers_cannot_also_have_definite_assignment_assertions : !node.type ? Diagnostics.Declarations_with_definite_assignment_assertions_must_also_have_type_annotations : Diagnostics.A_definite_assignment_assertion_is_not_permitted_in_this_context; return grammarErrorOnNode(node.exclamationToken, message); } } function checkGrammarTopLevelElementForRequiredDeclareModifier(node) { - if (node.kind === 263 /* InterfaceDeclaration */ || node.kind === 264 /* TypeAliasDeclaration */ || node.kind === 271 /* ImportDeclaration */ || node.kind === 270 /* ImportEqualsDeclaration */ || node.kind === 277 /* ExportDeclaration */ || node.kind === 276 /* ExportAssignment */ || node.kind === 269 /* NamespaceExportDeclaration */ || hasSyntacticModifier(node, 2 /* Ambient */ | 1 /* Export */ | 1024 /* Default */)) { + if (node.kind === 264 /* InterfaceDeclaration */ || node.kind === 265 /* TypeAliasDeclaration */ || node.kind === 272 /* ImportDeclaration */ || node.kind === 271 /* ImportEqualsDeclaration */ || node.kind === 278 /* ExportDeclaration */ || node.kind === 277 /* ExportAssignment */ || node.kind === 270 /* NamespaceExportDeclaration */ || hasSyntacticModifier(node, 128 /* Ambient */ | 32 /* Export */ | 2048 /* Default */)) { return false; } return grammarErrorOnFirstToken(node, Diagnostics.Top_level_declarations_in_d_ts_files_must_start_with_either_a_declare_or_export_modifier); } function checkGrammarTopLevelElementsForRequiredDeclareModifier(file) { for (const decl of file.statements) { - if (isDeclaration(decl) || decl.kind === 242 /* VariableStatement */) { + if (isDeclaration(decl) || decl.kind === 243 /* VariableStatement */) { if (checkGrammarTopLevelElementForRequiredDeclareModifier(decl)) { return true; } @@ -184466,15 +168504,15 @@ ${lanes.join("\n")} return false; } function checkGrammarSourceFile(node) { - return !!(node.flags & 16777216 /* Ambient */) && checkGrammarTopLevelElementsForRequiredDeclareModifier(node); + return !!(node.flags & 33554432 /* Ambient */) && checkGrammarTopLevelElementsForRequiredDeclareModifier(node); } function checkGrammarStatementInAmbientContext(node) { - if (node.flags & 16777216 /* Ambient */) { + if (node.flags & 33554432 /* Ambient */) { const links = getNodeLinks(node); if (!links.hasReportedStatementInAmbientContext && (isFunctionLike(node.parent) || isAccessor(node.parent))) { return getNodeLinks(node).hasReportedStatementInAmbientContext = grammarErrorOnFirstToken(node, Diagnostics.An_implementation_cannot_be_declared_in_ambient_contexts); } - if (node.parent.kind === 240 /* Block */ || node.parent.kind === 267 /* ModuleBlock */ || node.parent.kind === 311 /* SourceFile */) { + if (node.parent.kind === 241 /* Block */ || node.parent.kind === 268 /* ModuleBlock */ || node.parent.kind === 312 /* SourceFile */) { const links2 = getNodeLinks(node.parent); if (!links2.hasReportedStatementInAmbientContext) { return links2.hasReportedStatementInAmbientContext = grammarErrorOnFirstToken(node, Diagnostics.Statements_are_not_allowed_in_ambient_contexts); @@ -184485,7 +168523,7 @@ ${lanes.join("\n")} return false; } function checkGrammarNumericLiteral(node) { - const isFractional = getTextOfNode(node).indexOf(".") !== -1; + const isFractional = getTextOfNode(node).includes("."); const isScientific = node.numericLiteralFlags & 16 /* Scientific */; if (isFractional || isScientific) { return; @@ -184543,7 +168581,7 @@ ${lanes.join("\n")} if (node.isTypeOnly && node.name && node.namedBindings) { return grammarErrorOnNode(node, Diagnostics.A_type_only_import_can_specify_a_default_import_or_named_bindings_but_not_both); } - if (node.isTypeOnly && ((_a = node.namedBindings) == null ? void 0 : _a.kind) === 274 /* NamedImports */) { + if (node.isTypeOnly && ((_a = node.namedBindings) == null ? void 0 : _a.kind) === 275 /* NamedImports */) { return checkGrammarNamedImportsOrExports(node.namedBindings); } return false; @@ -184553,7 +168591,7 @@ ${lanes.join("\n")} if (specifier.isTypeOnly) { return grammarErrorOnFirstToken( specifier, - specifier.kind === 275 /* ImportSpecifier */ ? Diagnostics.The_type_modifier_cannot_be_used_on_a_named_import_when_import_type_is_used_on_its_import_statement : Diagnostics.The_type_modifier_cannot_be_used_on_a_named_export_when_export_type_is_used_on_its_export_statement + specifier.kind === 276 /* ImportSpecifier */ ? Diagnostics.The_type_modifier_cannot_be_used_on_a_named_import_when_import_type_is_used_on_its_import_statement : Diagnostics.The_type_modifier_cannot_be_used_on_a_named_export_when_export_type_is_used_on_its_export_statement ); } }); @@ -184572,12 +168610,12 @@ ${lanes.join("\n")} if (moduleKind !== 99 /* ESNext */ && moduleKind !== 199 /* NodeNext */ && moduleKind !== 100 /* Node16 */) { checkGrammarForDisallowedTrailingComma(nodeArguments); if (nodeArguments.length > 1) { - const assertionArgument = nodeArguments[1]; - return grammarErrorOnNode(assertionArgument, Diagnostics.Dynamic_imports_only_support_a_second_argument_when_the_module_option_is_set_to_esnext_node16_or_nodenext); + const importAttributesArgument = nodeArguments[1]; + return grammarErrorOnNode(importAttributesArgument, Diagnostics.Dynamic_imports_only_support_a_second_argument_when_the_module_option_is_set_to_esnext_node16_or_nodenext); } } if (nodeArguments.length === 0 || nodeArguments.length > 2) { - return grammarErrorOnNode(node, Diagnostics.Dynamic_imports_can_only_accept_a_module_specifier_and_an_optional_assertion_as_arguments); + return grammarErrorOnNode(node, Diagnostics.Dynamic_imports_can_only_accept_a_module_specifier_and_an_optional_set_of_attributes_as_arguments); } const spreadElement = find(nodeArguments, isSpreadElement); if (spreadElement) { @@ -184665,19 +168703,39 @@ ${lanes.join("\n")} } function getEffectivePropertyNameForPropertyNameNode(node) { const name = getPropertyNameForPropertyNameNode(node); - return name ? name : isComputedPropertyName(node) && isEntityNameExpression(node.expression) ? tryGetNameFromEntityNameExpression(node.expression) : void 0; + return name ? name : isComputedPropertyName(node) ? tryGetNameFromType(getTypeOfExpression(node.expression)) : void 0; + } + function getCombinedModifierFlagsCached(node) { + if (lastGetCombinedModifierFlagsNode === node) { + return lastGetCombinedModifierFlagsResult; + } + lastGetCombinedModifierFlagsNode = node; + lastGetCombinedModifierFlagsResult = getCombinedModifierFlags(node); + return lastGetCombinedModifierFlagsResult; + } + function getCombinedNodeFlagsCached(node) { + if (lastGetCombinedNodeFlagsNode === node) { + return lastGetCombinedNodeFlagsResult; + } + lastGetCombinedNodeFlagsNode = node; + lastGetCombinedNodeFlagsResult = getCombinedNodeFlags(node); + return lastGetCombinedNodeFlagsResult; + } + function isVarConstLike(node) { + const blockScopeKind = getCombinedNodeFlagsCached(node) & 7 /* BlockScoped */; + return blockScopeKind === 2 /* Const */ || blockScopeKind === 4 /* Using */ || blockScopeKind === 6 /* AwaitUsing */; } } function isNotAccessor(declaration) { return !isAccessor(declaration); } function isNotOverload(declaration) { - return declaration.kind !== 261 /* FunctionDeclaration */ && declaration.kind !== 173 /* MethodDeclaration */ || !!declaration.body; + return declaration.kind !== 262 /* FunctionDeclaration */ && declaration.kind !== 174 /* MethodDeclaration */ || !!declaration.body; } function isDeclarationNameOrImportPropertyName(name) { switch (name.parent.kind) { - case 275 /* ImportSpecifier */: - case 280 /* ExportSpecifier */: + case 276 /* ImportSpecifier */: + case 281 /* ExportSpecifier */: return isIdentifier(name); default: return isDeclarationName(name); @@ -184826,8 +168884,8 @@ ${lanes.join("\n")} CheckMode3[CheckMode3["SkipContextSensitive"] = 4] = "SkipContextSensitive"; CheckMode3[CheckMode3["SkipGenericFunctions"] = 8] = "SkipGenericFunctions"; CheckMode3[CheckMode3["IsForSignatureHelp"] = 16] = "IsForSignatureHelp"; - CheckMode3[CheckMode3["IsForStringLiteralArgumentCompletions"] = 32] = "IsForStringLiteralArgumentCompletions"; - CheckMode3[CheckMode3["RestBindingElement"] = 64] = "RestBindingElement"; + CheckMode3[CheckMode3["RestBindingElement"] = 32] = "RestBindingElement"; + CheckMode3[CheckMode3["TypeOnly"] = 64] = "TypeOnly"; return CheckMode3; })(CheckMode || {}); SignatureCheckMode = /* @__PURE__ */ ((SignatureCheckMode3) => { @@ -184861,13 +168919,13 @@ ${lanes.join("\n")} JsxNames2.IntrinsicClassAttributes = "IntrinsicClassAttributes"; JsxNames2.LibraryManagedAttributes = "LibraryManagedAttributes"; })(JsxNames || (JsxNames = {})); - SymbolTrackerImpl = class { + SymbolTrackerImpl = class _SymbolTrackerImpl { constructor(context, tracker, moduleResolverHost) { this.moduleResolverHost = void 0; this.inner = void 0; this.disableTrackSymbol = false; var _a; - while (tracker instanceof SymbolTrackerImpl) { + while (tracker instanceof _SymbolTrackerImpl) { tracker = tracker.inner; } this.inner = tracker; @@ -184876,12 +168934,14 @@ ${lanes.join("\n")} this.canTrackSymbol = !!((_a = this.inner) == null ? void 0 : _a.trackSymbol); } trackSymbol(symbol, enclosingDeclaration, meaning) { - var _a; + var _a, _b; if (((_a = this.inner) == null ? void 0 : _a.trackSymbol) && !this.disableTrackSymbol) { if (this.inner.trackSymbol(symbol, enclosingDeclaration, meaning)) { this.onDiagnosticReported(); return true; } + if (!(symbol.flags & 262144 /* TypeParameter */)) + ((_b = this.context).trackedSymbols ?? (_b.trackedSymbols = [])).push([symbol, enclosingDeclaration, meaning]); } return false; } @@ -184955,13 +169015,6 @@ ${lanes.join("\n")} this.inner.reportNonSerializableProperty(propertyName); } } - reportImportTypeNodeResolutionModeOverride() { - var _a; - if ((_a = this.inner) == null ? void 0 : _a.reportImportTypeNodeResolutionModeOverride) { - this.onDiagnosticReported(); - this.inner.reportImportTypeNodeResolutionModeOverride(); - } - } onDiagnosticReported() { this.context.reportedDiagnostic = true; } @@ -185236,21 +169289,21 @@ ${lanes.join("\n")} "use strict"; init_ts2(); visitEachChildTable = { - [165 /* QualifiedName */]: function visitEachChildOfQualifiedName(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { + [166 /* QualifiedName */]: function visitEachChildOfQualifiedName(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { return context.factory.updateQualifiedName( node, Debug.checkDefined(nodeVisitor(node.left, visitor, isEntityName)), Debug.checkDefined(nodeVisitor(node.right, visitor, isIdentifier)) ); }, - [166 /* ComputedPropertyName */]: function visitEachChildOfComputedPropertyName(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { + [167 /* ComputedPropertyName */]: function visitEachChildOfComputedPropertyName(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { return context.factory.updateComputedPropertyName( node, Debug.checkDefined(nodeVisitor(node.expression, visitor, isExpression)) ); }, // Signature elements - [167 /* TypeParameter */]: function visitEachChildOfTypeParameterDeclaration(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) { + [168 /* TypeParameter */]: function visitEachChildOfTypeParameterDeclaration(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) { return context.factory.updateTypeParameterDeclaration( node, nodesVisitor(node.modifiers, visitor, isModifier), @@ -185259,7 +169312,7 @@ ${lanes.join("\n")} nodeVisitor(node.default, visitor, isTypeNode) ); }, - [168 /* Parameter */]: function visitEachChildOfParameterDeclaration(node, visitor, context, nodesVisitor, nodeVisitor, tokenVisitor) { + [169 /* Parameter */]: function visitEachChildOfParameterDeclaration(node, visitor, context, nodesVisitor, nodeVisitor, tokenVisitor) { return context.factory.updateParameterDeclaration( node, nodesVisitor(node.modifiers, visitor, isModifierLike), @@ -185270,14 +169323,14 @@ ${lanes.join("\n")} nodeVisitor(node.initializer, visitor, isExpression) ); }, - [169 /* Decorator */]: function visitEachChildOfDecorator(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { + [170 /* Decorator */]: function visitEachChildOfDecorator(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { return context.factory.updateDecorator( node, Debug.checkDefined(nodeVisitor(node.expression, visitor, isExpression)) ); }, // Type elements - [170 /* PropertySignature */]: function visitEachChildOfPropertySignature(node, visitor, context, nodesVisitor, nodeVisitor, tokenVisitor) { + [171 /* PropertySignature */]: function visitEachChildOfPropertySignature(node, visitor, context, nodesVisitor, nodeVisitor, tokenVisitor) { return context.factory.updatePropertySignature( node, nodesVisitor(node.modifiers, visitor, isModifier), @@ -185286,7 +169339,7 @@ ${lanes.join("\n")} nodeVisitor(node.type, visitor, isTypeNode) ); }, - [171 /* PropertyDeclaration */]: function visitEachChildOfPropertyDeclaration(node, visitor, context, nodesVisitor, nodeVisitor, tokenVisitor) { + [172 /* PropertyDeclaration */]: function visitEachChildOfPropertyDeclaration(node, visitor, context, nodesVisitor, nodeVisitor, tokenVisitor) { return context.factory.updatePropertyDeclaration( node, nodesVisitor(node.modifiers, visitor, isModifierLike), @@ -185297,7 +169350,7 @@ ${lanes.join("\n")} nodeVisitor(node.initializer, visitor, isExpression) ); }, - [172 /* MethodSignature */]: function visitEachChildOfMethodSignature(node, visitor, context, nodesVisitor, nodeVisitor, tokenVisitor) { + [173 /* MethodSignature */]: function visitEachChildOfMethodSignature(node, visitor, context, nodesVisitor, nodeVisitor, tokenVisitor) { return context.factory.updateMethodSignature( node, nodesVisitor(node.modifiers, visitor, isModifier), @@ -185308,7 +169361,7 @@ ${lanes.join("\n")} nodeVisitor(node.type, visitor, isTypeNode) ); }, - [173 /* MethodDeclaration */]: function visitEachChildOfMethodDeclaration(node, visitor, context, nodesVisitor, nodeVisitor, tokenVisitor) { + [174 /* MethodDeclaration */]: function visitEachChildOfMethodDeclaration(node, visitor, context, nodesVisitor, nodeVisitor, tokenVisitor) { return context.factory.updateMethodDeclaration( node, nodesVisitor(node.modifiers, visitor, isModifierLike), @@ -185321,7 +169374,7 @@ ${lanes.join("\n")} visitFunctionBody(node.body, visitor, context, nodeVisitor) ); }, - [175 /* Constructor */]: function visitEachChildOfConstructorDeclaration(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) { + [176 /* Constructor */]: function visitEachChildOfConstructorDeclaration(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) { return context.factory.updateConstructorDeclaration( node, nodesVisitor(node.modifiers, visitor, isModifierLike), @@ -185329,7 +169382,7 @@ ${lanes.join("\n")} visitFunctionBody(node.body, visitor, context, nodeVisitor) ); }, - [176 /* GetAccessor */]: function visitEachChildOfGetAccessorDeclaration(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) { + [177 /* GetAccessor */]: function visitEachChildOfGetAccessorDeclaration(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) { return context.factory.updateGetAccessorDeclaration( node, nodesVisitor(node.modifiers, visitor, isModifierLike), @@ -185339,7 +169392,7 @@ ${lanes.join("\n")} visitFunctionBody(node.body, visitor, context, nodeVisitor) ); }, - [177 /* SetAccessor */]: function visitEachChildOfSetAccessorDeclaration(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) { + [178 /* SetAccessor */]: function visitEachChildOfSetAccessorDeclaration(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) { return context.factory.updateSetAccessorDeclaration( node, nodesVisitor(node.modifiers, visitor, isModifierLike), @@ -185348,7 +169401,7 @@ ${lanes.join("\n")} visitFunctionBody(node.body, visitor, context, nodeVisitor) ); }, - [174 /* ClassStaticBlockDeclaration */]: function visitEachChildOfClassStaticBlockDeclaration(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { + [175 /* ClassStaticBlockDeclaration */]: function visitEachChildOfClassStaticBlockDeclaration(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { context.startLexicalEnvironment(); context.suspendLexicalEnvironment(); return context.factory.updateClassStaticBlockDeclaration( @@ -185356,7 +169409,7 @@ ${lanes.join("\n")} visitFunctionBody(node.body, visitor, context, nodeVisitor) ); }, - [178 /* CallSignature */]: function visitEachChildOfCallSignatureDeclaration(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) { + [179 /* CallSignature */]: function visitEachChildOfCallSignatureDeclaration(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) { return context.factory.updateCallSignature( node, nodesVisitor(node.typeParameters, visitor, isTypeParameterDeclaration), @@ -185364,7 +169417,7 @@ ${lanes.join("\n")} nodeVisitor(node.type, visitor, isTypeNode) ); }, - [179 /* ConstructSignature */]: function visitEachChildOfConstructSignatureDeclaration(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) { + [180 /* ConstructSignature */]: function visitEachChildOfConstructSignatureDeclaration(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) { return context.factory.updateConstructSignature( node, nodesVisitor(node.typeParameters, visitor, isTypeParameterDeclaration), @@ -185372,7 +169425,7 @@ ${lanes.join("\n")} nodeVisitor(node.type, visitor, isTypeNode) ); }, - [180 /* IndexSignature */]: function visitEachChildOfIndexSignatureDeclaration(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) { + [181 /* IndexSignature */]: function visitEachChildOfIndexSignatureDeclaration(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) { return context.factory.updateIndexSignature( node, nodesVisitor(node.modifiers, visitor, isModifierLike), @@ -185381,7 +169434,7 @@ ${lanes.join("\n")} ); }, // Types - [181 /* TypePredicate */]: function visitEachChildOfTypePredicateNode(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { + [182 /* TypePredicate */]: function visitEachChildOfTypePredicateNode(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { return context.factory.updateTypePredicateNode( node, nodeVisitor(node.assertsModifier, visitor, isAssertsKeyword), @@ -185389,14 +169442,14 @@ ${lanes.join("\n")} nodeVisitor(node.type, visitor, isTypeNode) ); }, - [182 /* TypeReference */]: function visitEachChildOfTypeReferenceNode(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) { + [183 /* TypeReference */]: function visitEachChildOfTypeReferenceNode(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) { return context.factory.updateTypeReferenceNode( node, Debug.checkDefined(nodeVisitor(node.typeName, visitor, isEntityName)), nodesVisitor(node.typeArguments, visitor, isTypeNode) ); }, - [183 /* FunctionType */]: function visitEachChildOfFunctionTypeNode(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) { + [184 /* FunctionType */]: function visitEachChildOfFunctionTypeNode(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) { return context.factory.updateFunctionTypeNode( node, nodesVisitor(node.typeParameters, visitor, isTypeParameterDeclaration), @@ -185404,7 +169457,7 @@ ${lanes.join("\n")} Debug.checkDefined(nodeVisitor(node.type, visitor, isTypeNode)) ); }, - [184 /* ConstructorType */]: function visitEachChildOfConstructorTypeNode(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) { + [185 /* ConstructorType */]: function visitEachChildOfConstructorTypeNode(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) { return context.factory.updateConstructorTypeNode( node, nodesVisitor(node.modifiers, visitor, isModifier), @@ -185413,56 +169466,56 @@ ${lanes.join("\n")} Debug.checkDefined(nodeVisitor(node.type, visitor, isTypeNode)) ); }, - [185 /* TypeQuery */]: function visitEachChildOfTypeQueryNode(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) { + [186 /* TypeQuery */]: function visitEachChildOfTypeQueryNode(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) { return context.factory.updateTypeQueryNode( node, Debug.checkDefined(nodeVisitor(node.exprName, visitor, isEntityName)), nodesVisitor(node.typeArguments, visitor, isTypeNode) ); }, - [186 /* TypeLiteral */]: function visitEachChildOfTypeLiteralNode(node, visitor, context, nodesVisitor, _nodeVisitor, _tokenVisitor) { + [187 /* TypeLiteral */]: function visitEachChildOfTypeLiteralNode(node, visitor, context, nodesVisitor, _nodeVisitor, _tokenVisitor) { return context.factory.updateTypeLiteralNode( node, nodesVisitor(node.members, visitor, isTypeElement) ); }, - [187 /* ArrayType */]: function visitEachChildOfArrayTypeNode(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { + [188 /* ArrayType */]: function visitEachChildOfArrayTypeNode(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { return context.factory.updateArrayTypeNode( node, Debug.checkDefined(nodeVisitor(node.elementType, visitor, isTypeNode)) ); }, - [188 /* TupleType */]: function visitEachChildOfTupleTypeNode(node, visitor, context, nodesVisitor, _nodeVisitor, _tokenVisitor) { + [189 /* TupleType */]: function visitEachChildOfTupleTypeNode(node, visitor, context, nodesVisitor, _nodeVisitor, _tokenVisitor) { return context.factory.updateTupleTypeNode( node, nodesVisitor(node.elements, visitor, isTypeNode) ); }, - [189 /* OptionalType */]: function visitEachChildOfOptionalTypeNode(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { + [190 /* OptionalType */]: function visitEachChildOfOptionalTypeNode(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { return context.factory.updateOptionalTypeNode( node, Debug.checkDefined(nodeVisitor(node.type, visitor, isTypeNode)) ); }, - [190 /* RestType */]: function visitEachChildOfRestTypeNode(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { + [191 /* RestType */]: function visitEachChildOfRestTypeNode(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { return context.factory.updateRestTypeNode( node, Debug.checkDefined(nodeVisitor(node.type, visitor, isTypeNode)) ); }, - [191 /* UnionType */]: function visitEachChildOfUnionTypeNode(node, visitor, context, nodesVisitor, _nodeVisitor, _tokenVisitor) { + [192 /* UnionType */]: function visitEachChildOfUnionTypeNode(node, visitor, context, nodesVisitor, _nodeVisitor, _tokenVisitor) { return context.factory.updateUnionTypeNode( node, nodesVisitor(node.types, visitor, isTypeNode) ); }, - [192 /* IntersectionType */]: function visitEachChildOfIntersectionTypeNode(node, visitor, context, nodesVisitor, _nodeVisitor, _tokenVisitor) { + [193 /* IntersectionType */]: function visitEachChildOfIntersectionTypeNode(node, visitor, context, nodesVisitor, _nodeVisitor, _tokenVisitor) { return context.factory.updateIntersectionTypeNode( node, nodesVisitor(node.types, visitor, isTypeNode) ); }, - [193 /* ConditionalType */]: function visitEachChildOfConditionalTypeNode(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { + [194 /* ConditionalType */]: function visitEachChildOfConditionalTypeNode(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { return context.factory.updateConditionalTypeNode( node, Debug.checkDefined(nodeVisitor(node.checkType, visitor, isTypeNode)), @@ -185471,30 +169524,30 @@ ${lanes.join("\n")} Debug.checkDefined(nodeVisitor(node.falseType, visitor, isTypeNode)) ); }, - [194 /* InferType */]: function visitEachChildOfInferTypeNode(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { + [195 /* InferType */]: function visitEachChildOfInferTypeNode(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { return context.factory.updateInferTypeNode( node, Debug.checkDefined(nodeVisitor(node.typeParameter, visitor, isTypeParameterDeclaration)) ); }, - [204 /* ImportType */]: function visitEachChildOfImportTypeNode(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) { + [205 /* ImportType */]: function visitEachChildOfImportTypeNode(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) { return context.factory.updateImportTypeNode( node, Debug.checkDefined(nodeVisitor(node.argument, visitor, isTypeNode)), - nodeVisitor(node.assertions, visitor, isImportTypeAssertionContainer), + nodeVisitor(node.attributes, visitor, isImportAttributes), nodeVisitor(node.qualifier, visitor, isEntityName), nodesVisitor(node.typeArguments, visitor, isTypeNode), node.isTypeOf ); }, - [301 /* ImportTypeAssertionContainer */]: function visitEachChildOfImportTypeAssertionContainer(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { + [302 /* ImportTypeAssertionContainer */]: function visitEachChildOfImportTypeAssertionContainer(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { return context.factory.updateImportTypeAssertionContainer( node, Debug.checkDefined(nodeVisitor(node.assertClause, visitor, isAssertClause)), node.multiLine ); }, - [201 /* NamedTupleMember */]: function visitEachChildOfNamedTupleMember(node, visitor, context, _nodesVisitor, nodeVisitor, tokenVisitor) { + [202 /* NamedTupleMember */]: function visitEachChildOfNamedTupleMember(node, visitor, context, _nodesVisitor, nodeVisitor, tokenVisitor) { return context.factory.updateNamedTupleMember( node, tokenVisitor ? nodeVisitor(node.dotDotDotToken, tokenVisitor, isDotDotDotToken) : node.dotDotDotToken, @@ -185503,26 +169556,26 @@ ${lanes.join("\n")} Debug.checkDefined(nodeVisitor(node.type, visitor, isTypeNode)) ); }, - [195 /* ParenthesizedType */]: function visitEachChildOfParenthesizedType(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { + [196 /* ParenthesizedType */]: function visitEachChildOfParenthesizedType(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { return context.factory.updateParenthesizedType( node, Debug.checkDefined(nodeVisitor(node.type, visitor, isTypeNode)) ); }, - [197 /* TypeOperator */]: function visitEachChildOfTypeOperatorNode(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { + [198 /* TypeOperator */]: function visitEachChildOfTypeOperatorNode(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { return context.factory.updateTypeOperatorNode( node, Debug.checkDefined(nodeVisitor(node.type, visitor, isTypeNode)) ); }, - [198 /* IndexedAccessType */]: function visitEachChildOfIndexedAccessType(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { + [199 /* IndexedAccessType */]: function visitEachChildOfIndexedAccessType(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { return context.factory.updateIndexedAccessTypeNode( node, Debug.checkDefined(nodeVisitor(node.objectType, visitor, isTypeNode)), Debug.checkDefined(nodeVisitor(node.indexType, visitor, isTypeNode)) ); }, - [199 /* MappedType */]: function visitEachChildOfMappedType(node, visitor, context, nodesVisitor, nodeVisitor, tokenVisitor) { + [200 /* MappedType */]: function visitEachChildOfMappedType(node, visitor, context, nodesVisitor, nodeVisitor, tokenVisitor) { return context.factory.updateMappedTypeNode( node, tokenVisitor ? nodeVisitor(node.readonlyToken, tokenVisitor, isReadonlyKeywordOrPlusOrMinusToken) : node.readonlyToken, @@ -185533,20 +169586,20 @@ ${lanes.join("\n")} nodesVisitor(node.members, visitor, isTypeElement) ); }, - [200 /* LiteralType */]: function visitEachChildOfLiteralTypeNode(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { + [201 /* LiteralType */]: function visitEachChildOfLiteralTypeNode(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { return context.factory.updateLiteralTypeNode( node, Debug.checkDefined(nodeVisitor(node.literal, visitor, isLiteralTypeLiteral)) ); }, - [202 /* TemplateLiteralType */]: function visitEachChildOfTemplateLiteralType(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) { + [203 /* TemplateLiteralType */]: function visitEachChildOfTemplateLiteralType(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) { return context.factory.updateTemplateLiteralType( node, Debug.checkDefined(nodeVisitor(node.head, visitor, isTemplateHead)), nodesVisitor(node.templateSpans, visitor, isTemplateLiteralTypeSpan) ); }, - [203 /* TemplateLiteralTypeSpan */]: function visitEachChildOfTemplateLiteralTypeSpan(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { + [204 /* TemplateLiteralTypeSpan */]: function visitEachChildOfTemplateLiteralTypeSpan(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { return context.factory.updateTemplateLiteralTypeSpan( node, Debug.checkDefined(nodeVisitor(node.type, visitor, isTypeNode)), @@ -185554,19 +169607,19 @@ ${lanes.join("\n")} ); }, // Binding patterns - [205 /* ObjectBindingPattern */]: function visitEachChildOfObjectBindingPattern(node, visitor, context, nodesVisitor, _nodeVisitor, _tokenVisitor) { + [206 /* ObjectBindingPattern */]: function visitEachChildOfObjectBindingPattern(node, visitor, context, nodesVisitor, _nodeVisitor, _tokenVisitor) { return context.factory.updateObjectBindingPattern( node, nodesVisitor(node.elements, visitor, isBindingElement) ); }, - [206 /* ArrayBindingPattern */]: function visitEachChildOfArrayBindingPattern(node, visitor, context, nodesVisitor, _nodeVisitor, _tokenVisitor) { + [207 /* ArrayBindingPattern */]: function visitEachChildOfArrayBindingPattern(node, visitor, context, nodesVisitor, _nodeVisitor, _tokenVisitor) { return context.factory.updateArrayBindingPattern( node, nodesVisitor(node.elements, visitor, isArrayBindingElement) ); }, - [207 /* BindingElement */]: function visitEachChildOfBindingElement(node, visitor, context, _nodesVisitor, nodeVisitor, tokenVisitor) { + [208 /* BindingElement */]: function visitEachChildOfBindingElement(node, visitor, context, _nodesVisitor, nodeVisitor, tokenVisitor) { return context.factory.updateBindingElement( node, tokenVisitor ? nodeVisitor(node.dotDotDotToken, tokenVisitor, isDotDotDotToken) : node.dotDotDotToken, @@ -185576,19 +169629,19 @@ ${lanes.join("\n")} ); }, // Expression - [208 /* ArrayLiteralExpression */]: function visitEachChildOfArrayLiteralExpression(node, visitor, context, nodesVisitor, _nodeVisitor, _tokenVisitor) { + [209 /* ArrayLiteralExpression */]: function visitEachChildOfArrayLiteralExpression(node, visitor, context, nodesVisitor, _nodeVisitor, _tokenVisitor) { return context.factory.updateArrayLiteralExpression( node, nodesVisitor(node.elements, visitor, isExpression) ); }, - [209 /* ObjectLiteralExpression */]: function visitEachChildOfObjectLiteralExpression(node, visitor, context, nodesVisitor, _nodeVisitor, _tokenVisitor) { + [210 /* ObjectLiteralExpression */]: function visitEachChildOfObjectLiteralExpression(node, visitor, context, nodesVisitor, _nodeVisitor, _tokenVisitor) { return context.factory.updateObjectLiteralExpression( node, nodesVisitor(node.properties, visitor, isObjectLiteralElementLike) ); }, - [210 /* PropertyAccessExpression */]: function visitEachChildOfPropertyAccessExpression(node, visitor, context, _nodesVisitor, nodeVisitor, tokenVisitor) { + [211 /* PropertyAccessExpression */]: function visitEachChildOfPropertyAccessExpression(node, visitor, context, _nodesVisitor, nodeVisitor, tokenVisitor) { return isPropertyAccessChain(node) ? context.factory.updatePropertyAccessChain( node, Debug.checkDefined(nodeVisitor(node.expression, visitor, isExpression)), @@ -185600,7 +169653,7 @@ ${lanes.join("\n")} Debug.checkDefined(nodeVisitor(node.name, visitor, isMemberName)) ); }, - [211 /* ElementAccessExpression */]: function visitEachChildOfElementAccessExpression(node, visitor, context, _nodesVisitor, nodeVisitor, tokenVisitor) { + [212 /* ElementAccessExpression */]: function visitEachChildOfElementAccessExpression(node, visitor, context, _nodesVisitor, nodeVisitor, tokenVisitor) { return isElementAccessChain(node) ? context.factory.updateElementAccessChain( node, Debug.checkDefined(nodeVisitor(node.expression, visitor, isExpression)), @@ -185612,7 +169665,7 @@ ${lanes.join("\n")} Debug.checkDefined(nodeVisitor(node.argumentExpression, visitor, isExpression)) ); }, - [212 /* CallExpression */]: function visitEachChildOfCallExpression(node, visitor, context, nodesVisitor, nodeVisitor, tokenVisitor) { + [213 /* CallExpression */]: function visitEachChildOfCallExpression(node, visitor, context, nodesVisitor, nodeVisitor, tokenVisitor) { return isCallChain(node) ? context.factory.updateCallChain( node, Debug.checkDefined(nodeVisitor(node.expression, visitor, isExpression)), @@ -185626,7 +169679,7 @@ ${lanes.join("\n")} nodesVisitor(node.arguments, visitor, isExpression) ); }, - [213 /* NewExpression */]: function visitEachChildOfNewExpression(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) { + [214 /* NewExpression */]: function visitEachChildOfNewExpression(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) { return context.factory.updateNewExpression( node, Debug.checkDefined(nodeVisitor(node.expression, visitor, isExpression)), @@ -185634,7 +169687,7 @@ ${lanes.join("\n")} nodesVisitor(node.arguments, visitor, isExpression) ); }, - [214 /* TaggedTemplateExpression */]: function visitEachChildOfTaggedTemplateExpression(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) { + [215 /* TaggedTemplateExpression */]: function visitEachChildOfTaggedTemplateExpression(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) { return context.factory.updateTaggedTemplateExpression( node, Debug.checkDefined(nodeVisitor(node.tag, visitor, isExpression)), @@ -185642,20 +169695,20 @@ ${lanes.join("\n")} Debug.checkDefined(nodeVisitor(node.template, visitor, isTemplateLiteral)) ); }, - [215 /* TypeAssertionExpression */]: function visitEachChildOfTypeAssertionExpression(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { + [216 /* TypeAssertionExpression */]: function visitEachChildOfTypeAssertionExpression(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { return context.factory.updateTypeAssertion( node, Debug.checkDefined(nodeVisitor(node.type, visitor, isTypeNode)), Debug.checkDefined(nodeVisitor(node.expression, visitor, isExpression)) ); }, - [216 /* ParenthesizedExpression */]: function visitEachChildOfParenthesizedExpression(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { + [217 /* ParenthesizedExpression */]: function visitEachChildOfParenthesizedExpression(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { return context.factory.updateParenthesizedExpression( node, Debug.checkDefined(nodeVisitor(node.expression, visitor, isExpression)) ); }, - [217 /* FunctionExpression */]: function visitEachChildOfFunctionExpression(node, visitor, context, nodesVisitor, nodeVisitor, tokenVisitor) { + [218 /* FunctionExpression */]: function visitEachChildOfFunctionExpression(node, visitor, context, nodesVisitor, nodeVisitor, tokenVisitor) { return context.factory.updateFunctionExpression( node, nodesVisitor(node.modifiers, visitor, isModifier), @@ -185667,7 +169720,7 @@ ${lanes.join("\n")} visitFunctionBody(node.body, visitor, context, nodeVisitor) ); }, - [218 /* ArrowFunction */]: function visitEachChildOfArrowFunction(node, visitor, context, nodesVisitor, nodeVisitor, tokenVisitor) { + [219 /* ArrowFunction */]: function visitEachChildOfArrowFunction(node, visitor, context, nodesVisitor, nodeVisitor, tokenVisitor) { return context.factory.updateArrowFunction( node, nodesVisitor(node.modifiers, visitor, isModifier), @@ -185678,43 +169731,43 @@ ${lanes.join("\n")} visitFunctionBody(node.body, visitor, context, nodeVisitor) ); }, - [219 /* DeleteExpression */]: function visitEachChildOfDeleteExpression(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { + [220 /* DeleteExpression */]: function visitEachChildOfDeleteExpression(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { return context.factory.updateDeleteExpression( node, Debug.checkDefined(nodeVisitor(node.expression, visitor, isExpression)) ); }, - [220 /* TypeOfExpression */]: function visitEachChildOfTypeOfExpression(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { + [221 /* TypeOfExpression */]: function visitEachChildOfTypeOfExpression(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { return context.factory.updateTypeOfExpression( node, Debug.checkDefined(nodeVisitor(node.expression, visitor, isExpression)) ); }, - [221 /* VoidExpression */]: function visitEachChildOfVoidExpression(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { + [222 /* VoidExpression */]: function visitEachChildOfVoidExpression(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { return context.factory.updateVoidExpression( node, Debug.checkDefined(nodeVisitor(node.expression, visitor, isExpression)) ); }, - [222 /* AwaitExpression */]: function visitEachChildOfAwaitExpression(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { + [223 /* AwaitExpression */]: function visitEachChildOfAwaitExpression(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { return context.factory.updateAwaitExpression( node, Debug.checkDefined(nodeVisitor(node.expression, visitor, isExpression)) ); }, - [223 /* PrefixUnaryExpression */]: function visitEachChildOfPrefixUnaryExpression(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { + [224 /* PrefixUnaryExpression */]: function visitEachChildOfPrefixUnaryExpression(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { return context.factory.updatePrefixUnaryExpression( node, Debug.checkDefined(nodeVisitor(node.operand, visitor, isExpression)) ); }, - [224 /* PostfixUnaryExpression */]: function visitEachChildOfPostfixUnaryExpression(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { + [225 /* PostfixUnaryExpression */]: function visitEachChildOfPostfixUnaryExpression(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { return context.factory.updatePostfixUnaryExpression( node, Debug.checkDefined(nodeVisitor(node.operand, visitor, isExpression)) ); }, - [225 /* BinaryExpression */]: function visitEachChildOfBinaryExpression(node, visitor, context, _nodesVisitor, nodeVisitor, tokenVisitor) { + [226 /* BinaryExpression */]: function visitEachChildOfBinaryExpression(node, visitor, context, _nodesVisitor, nodeVisitor, tokenVisitor) { return context.factory.updateBinaryExpression( node, Debug.checkDefined(nodeVisitor(node.left, visitor, isExpression)), @@ -185722,7 +169775,7 @@ ${lanes.join("\n")} Debug.checkDefined(nodeVisitor(node.right, visitor, isExpression)) ); }, - [226 /* ConditionalExpression */]: function visitEachChildOfConditionalExpression(node, visitor, context, _nodesVisitor, nodeVisitor, tokenVisitor) { + [227 /* ConditionalExpression */]: function visitEachChildOfConditionalExpression(node, visitor, context, _nodesVisitor, nodeVisitor, tokenVisitor) { return context.factory.updateConditionalExpression( node, Debug.checkDefined(nodeVisitor(node.condition, visitor, isExpression)), @@ -185732,27 +169785,27 @@ ${lanes.join("\n")} Debug.checkDefined(nodeVisitor(node.whenFalse, visitor, isExpression)) ); }, - [227 /* TemplateExpression */]: function visitEachChildOfTemplateExpression(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) { + [228 /* TemplateExpression */]: function visitEachChildOfTemplateExpression(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) { return context.factory.updateTemplateExpression( node, Debug.checkDefined(nodeVisitor(node.head, visitor, isTemplateHead)), nodesVisitor(node.templateSpans, visitor, isTemplateSpan) ); }, - [228 /* YieldExpression */]: function visitEachChildOfYieldExpression(node, visitor, context, _nodesVisitor, nodeVisitor, tokenVisitor) { + [229 /* YieldExpression */]: function visitEachChildOfYieldExpression(node, visitor, context, _nodesVisitor, nodeVisitor, tokenVisitor) { return context.factory.updateYieldExpression( node, tokenVisitor ? nodeVisitor(node.asteriskToken, tokenVisitor, isAsteriskToken) : node.asteriskToken, nodeVisitor(node.expression, visitor, isExpression) ); }, - [229 /* SpreadElement */]: function visitEachChildOfSpreadElement(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { + [230 /* SpreadElement */]: function visitEachChildOfSpreadElement(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { return context.factory.updateSpreadElement( node, Debug.checkDefined(nodeVisitor(node.expression, visitor, isExpression)) ); }, - [230 /* ClassExpression */]: function visitEachChildOfClassExpression(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) { + [231 /* ClassExpression */]: function visitEachChildOfClassExpression(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) { return context.factory.updateClassExpression( node, nodesVisitor(node.modifiers, visitor, isModifierLike), @@ -185762,28 +169815,28 @@ ${lanes.join("\n")} nodesVisitor(node.members, visitor, isClassElement) ); }, - [232 /* ExpressionWithTypeArguments */]: function visitEachChildOfExpressionWithTypeArguments(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) { + [233 /* ExpressionWithTypeArguments */]: function visitEachChildOfExpressionWithTypeArguments(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) { return context.factory.updateExpressionWithTypeArguments( node, Debug.checkDefined(nodeVisitor(node.expression, visitor, isExpression)), nodesVisitor(node.typeArguments, visitor, isTypeNode) ); }, - [233 /* AsExpression */]: function visitEachChildOfAsExpression(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { + [234 /* AsExpression */]: function visitEachChildOfAsExpression(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { return context.factory.updateAsExpression( node, Debug.checkDefined(nodeVisitor(node.expression, visitor, isExpression)), Debug.checkDefined(nodeVisitor(node.type, visitor, isTypeNode)) ); }, - [237 /* SatisfiesExpression */]: function visitEachChildOfSatisfiesExpression(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { + [238 /* SatisfiesExpression */]: function visitEachChildOfSatisfiesExpression(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { return context.factory.updateSatisfiesExpression( node, Debug.checkDefined(nodeVisitor(node.expression, visitor, isExpression)), Debug.checkDefined(nodeVisitor(node.type, visitor, isTypeNode)) ); }, - [234 /* NonNullExpression */]: function visitEachChildOfNonNullExpression(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { + [235 /* NonNullExpression */]: function visitEachChildOfNonNullExpression(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { return isOptionalChain(node) ? context.factory.updateNonNullChain( node, Debug.checkDefined(nodeVisitor(node.expression, visitor, isExpression)) @@ -185792,14 +169845,14 @@ ${lanes.join("\n")} Debug.checkDefined(nodeVisitor(node.expression, visitor, isExpression)) ); }, - [235 /* MetaProperty */]: function visitEachChildOfMetaProperty(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { + [236 /* MetaProperty */]: function visitEachChildOfMetaProperty(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { return context.factory.updateMetaProperty( node, Debug.checkDefined(nodeVisitor(node.name, visitor, isIdentifier)) ); }, // Misc - [238 /* TemplateSpan */]: function visitEachChildOfTemplateSpan(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { + [239 /* TemplateSpan */]: function visitEachChildOfTemplateSpan(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { return context.factory.updateTemplateSpan( node, Debug.checkDefined(nodeVisitor(node.expression, visitor, isExpression)), @@ -185807,26 +169860,26 @@ ${lanes.join("\n")} ); }, // Element - [240 /* Block */]: function visitEachChildOfBlock(node, visitor, context, nodesVisitor, _nodeVisitor, _tokenVisitor) { + [241 /* Block */]: function visitEachChildOfBlock(node, visitor, context, nodesVisitor, _nodeVisitor, _tokenVisitor) { return context.factory.updateBlock( node, nodesVisitor(node.statements, visitor, isStatement) ); }, - [242 /* VariableStatement */]: function visitEachChildOfVariableStatement(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) { + [243 /* VariableStatement */]: function visitEachChildOfVariableStatement(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) { return context.factory.updateVariableStatement( node, nodesVisitor(node.modifiers, visitor, isModifierLike), Debug.checkDefined(nodeVisitor(node.declarationList, visitor, isVariableDeclarationList)) ); }, - [243 /* ExpressionStatement */]: function visitEachChildOfExpressionStatement(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { + [244 /* ExpressionStatement */]: function visitEachChildOfExpressionStatement(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { return context.factory.updateExpressionStatement( node, Debug.checkDefined(nodeVisitor(node.expression, visitor, isExpression)) ); }, - [244 /* IfStatement */]: function visitEachChildOfIfStatement(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { + [245 /* IfStatement */]: function visitEachChildOfIfStatement(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { return context.factory.updateIfStatement( node, Debug.checkDefined(nodeVisitor(node.expression, visitor, isExpression)), @@ -185834,21 +169887,21 @@ ${lanes.join("\n")} nodeVisitor(node.elseStatement, visitor, isStatement, context.factory.liftToBlock) ); }, - [245 /* DoStatement */]: function visitEachChildOfDoStatement(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { + [246 /* DoStatement */]: function visitEachChildOfDoStatement(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { return context.factory.updateDoStatement( node, visitIterationBody(node.statement, visitor, context, nodeVisitor), Debug.checkDefined(nodeVisitor(node.expression, visitor, isExpression)) ); }, - [246 /* WhileStatement */]: function visitEachChildOfWhileStatement(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { + [247 /* WhileStatement */]: function visitEachChildOfWhileStatement(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { return context.factory.updateWhileStatement( node, Debug.checkDefined(nodeVisitor(node.expression, visitor, isExpression)), visitIterationBody(node.statement, visitor, context, nodeVisitor) ); }, - [247 /* ForStatement */]: function visitEachChildOfForStatement(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { + [248 /* ForStatement */]: function visitEachChildOfForStatement(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { return context.factory.updateForStatement( node, nodeVisitor(node.initializer, visitor, isForInitializer), @@ -185857,7 +169910,7 @@ ${lanes.join("\n")} visitIterationBody(node.statement, visitor, context, nodeVisitor) ); }, - [248 /* ForInStatement */]: function visitEachChildOfForInStatement(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { + [249 /* ForInStatement */]: function visitEachChildOfForInStatement(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { return context.factory.updateForInStatement( node, Debug.checkDefined(nodeVisitor(node.initializer, visitor, isForInitializer)), @@ -185865,7 +169918,7 @@ ${lanes.join("\n")} visitIterationBody(node.statement, visitor, context, nodeVisitor) ); }, - [249 /* ForOfStatement */]: function visitEachChildOfForOfStatement(node, visitor, context, _nodesVisitor, nodeVisitor, tokenVisitor) { + [250 /* ForOfStatement */]: function visitEachChildOfForOfStatement(node, visitor, context, _nodesVisitor, nodeVisitor, tokenVisitor) { return context.factory.updateForOfStatement( node, tokenVisitor ? nodeVisitor(node.awaitModifier, tokenVisitor, isAwaitKeyword) : node.awaitModifier, @@ -185874,52 +169927,52 @@ ${lanes.join("\n")} visitIterationBody(node.statement, visitor, context, nodeVisitor) ); }, - [250 /* ContinueStatement */]: function visitEachChildOfContinueStatement(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { + [251 /* ContinueStatement */]: function visitEachChildOfContinueStatement(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { return context.factory.updateContinueStatement( node, nodeVisitor(node.label, visitor, isIdentifier) ); }, - [251 /* BreakStatement */]: function visitEachChildOfBreakStatement(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { + [252 /* BreakStatement */]: function visitEachChildOfBreakStatement(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { return context.factory.updateBreakStatement( node, nodeVisitor(node.label, visitor, isIdentifier) ); }, - [252 /* ReturnStatement */]: function visitEachChildOfReturnStatement(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { + [253 /* ReturnStatement */]: function visitEachChildOfReturnStatement(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { return context.factory.updateReturnStatement( node, nodeVisitor(node.expression, visitor, isExpression) ); }, - [253 /* WithStatement */]: function visitEachChildOfWithStatement(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { + [254 /* WithStatement */]: function visitEachChildOfWithStatement(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { return context.factory.updateWithStatement( node, Debug.checkDefined(nodeVisitor(node.expression, visitor, isExpression)), Debug.checkDefined(nodeVisitor(node.statement, visitor, isStatement, context.factory.liftToBlock)) ); }, - [254 /* SwitchStatement */]: function visitEachChildOfSwitchStatement(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { + [255 /* SwitchStatement */]: function visitEachChildOfSwitchStatement(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { return context.factory.updateSwitchStatement( node, Debug.checkDefined(nodeVisitor(node.expression, visitor, isExpression)), Debug.checkDefined(nodeVisitor(node.caseBlock, visitor, isCaseBlock)) ); }, - [255 /* LabeledStatement */]: function visitEachChildOfLabeledStatement(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { + [256 /* LabeledStatement */]: function visitEachChildOfLabeledStatement(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { return context.factory.updateLabeledStatement( node, Debug.checkDefined(nodeVisitor(node.label, visitor, isIdentifier)), Debug.checkDefined(nodeVisitor(node.statement, visitor, isStatement, context.factory.liftToBlock)) ); }, - [256 /* ThrowStatement */]: function visitEachChildOfThrowStatement(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { + [257 /* ThrowStatement */]: function visitEachChildOfThrowStatement(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { return context.factory.updateThrowStatement( node, Debug.checkDefined(nodeVisitor(node.expression, visitor, isExpression)) ); }, - [257 /* TryStatement */]: function visitEachChildOfTryStatement(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { + [258 /* TryStatement */]: function visitEachChildOfTryStatement(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { return context.factory.updateTryStatement( node, Debug.checkDefined(nodeVisitor(node.tryBlock, visitor, isBlock)), @@ -185927,7 +169980,7 @@ ${lanes.join("\n")} nodeVisitor(node.finallyBlock, visitor, isBlock) ); }, - [259 /* VariableDeclaration */]: function visitEachChildOfVariableDeclaration(node, visitor, context, _nodesVisitor, nodeVisitor, tokenVisitor) { + [260 /* VariableDeclaration */]: function visitEachChildOfVariableDeclaration(node, visitor, context, _nodesVisitor, nodeVisitor, tokenVisitor) { return context.factory.updateVariableDeclaration( node, Debug.checkDefined(nodeVisitor(node.name, visitor, isBindingName)), @@ -185936,13 +169989,13 @@ ${lanes.join("\n")} nodeVisitor(node.initializer, visitor, isExpression) ); }, - [260 /* VariableDeclarationList */]: function visitEachChildOfVariableDeclarationList(node, visitor, context, nodesVisitor, _nodeVisitor, _tokenVisitor) { + [261 /* VariableDeclarationList */]: function visitEachChildOfVariableDeclarationList(node, visitor, context, nodesVisitor, _nodeVisitor, _tokenVisitor) { return context.factory.updateVariableDeclarationList( node, nodesVisitor(node.declarations, visitor, isVariableDeclaration) ); }, - [261 /* FunctionDeclaration */]: function visitEachChildOfFunctionDeclaration(node, visitor, context, nodesVisitor, nodeVisitor, tokenVisitor) { + [262 /* FunctionDeclaration */]: function visitEachChildOfFunctionDeclaration(node, visitor, context, nodesVisitor, nodeVisitor, tokenVisitor) { return context.factory.updateFunctionDeclaration( node, nodesVisitor(node.modifiers, visitor, isModifier), @@ -185954,7 +170007,7 @@ ${lanes.join("\n")} visitFunctionBody(node.body, visitor, context, nodeVisitor) ); }, - [262 /* ClassDeclaration */]: function visitEachChildOfClassDeclaration(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) { + [263 /* ClassDeclaration */]: function visitEachChildOfClassDeclaration(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) { return context.factory.updateClassDeclaration( node, nodesVisitor(node.modifiers, visitor, isModifierLike), @@ -185964,7 +170017,7 @@ ${lanes.join("\n")} nodesVisitor(node.members, visitor, isClassElement) ); }, - [263 /* InterfaceDeclaration */]: function visitEachChildOfInterfaceDeclaration(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) { + [264 /* InterfaceDeclaration */]: function visitEachChildOfInterfaceDeclaration(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) { return context.factory.updateInterfaceDeclaration( node, nodesVisitor(node.modifiers, visitor, isModifierLike), @@ -185974,7 +170027,7 @@ ${lanes.join("\n")} nodesVisitor(node.members, visitor, isTypeElement) ); }, - [264 /* TypeAliasDeclaration */]: function visitEachChildOfTypeAliasDeclaration(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) { + [265 /* TypeAliasDeclaration */]: function visitEachChildOfTypeAliasDeclaration(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) { return context.factory.updateTypeAliasDeclaration( node, nodesVisitor(node.modifiers, visitor, isModifierLike), @@ -185983,7 +170036,7 @@ ${lanes.join("\n")} Debug.checkDefined(nodeVisitor(node.type, visitor, isTypeNode)) ); }, - [265 /* EnumDeclaration */]: function visitEachChildOfEnumDeclaration(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) { + [266 /* EnumDeclaration */]: function visitEachChildOfEnumDeclaration(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) { return context.factory.updateEnumDeclaration( node, nodesVisitor(node.modifiers, visitor, isModifierLike), @@ -185991,7 +170044,7 @@ ${lanes.join("\n")} nodesVisitor(node.members, visitor, isEnumMember) ); }, - [266 /* ModuleDeclaration */]: function visitEachChildOfModuleDeclaration(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) { + [267 /* ModuleDeclaration */]: function visitEachChildOfModuleDeclaration(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) { return context.factory.updateModuleDeclaration( node, nodesVisitor(node.modifiers, visitor, isModifierLike), @@ -185999,25 +170052,25 @@ ${lanes.join("\n")} nodeVisitor(node.body, visitor, isModuleBody) ); }, - [267 /* ModuleBlock */]: function visitEachChildOfModuleBlock(node, visitor, context, nodesVisitor, _nodeVisitor, _tokenVisitor) { + [268 /* ModuleBlock */]: function visitEachChildOfModuleBlock(node, visitor, context, nodesVisitor, _nodeVisitor, _tokenVisitor) { return context.factory.updateModuleBlock( node, nodesVisitor(node.statements, visitor, isStatement) ); }, - [268 /* CaseBlock */]: function visitEachChildOfCaseBlock(node, visitor, context, nodesVisitor, _nodeVisitor, _tokenVisitor) { + [269 /* CaseBlock */]: function visitEachChildOfCaseBlock(node, visitor, context, nodesVisitor, _nodeVisitor, _tokenVisitor) { return context.factory.updateCaseBlock( node, nodesVisitor(node.clauses, visitor, isCaseOrDefaultClause) ); }, - [269 /* NamespaceExportDeclaration */]: function visitEachChildOfNamespaceExportDeclaration(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { + [270 /* NamespaceExportDeclaration */]: function visitEachChildOfNamespaceExportDeclaration(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { return context.factory.updateNamespaceExportDeclaration( node, Debug.checkDefined(nodeVisitor(node.name, visitor, isIdentifier)) ); }, - [270 /* ImportEqualsDeclaration */]: function visitEachChildOfImportEqualsDeclaration(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) { + [271 /* ImportEqualsDeclaration */]: function visitEachChildOfImportEqualsDeclaration(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) { return context.factory.updateImportEqualsDeclaration( node, nodesVisitor(node.modifiers, visitor, isModifierLike), @@ -186026,30 +170079,30 @@ ${lanes.join("\n")} Debug.checkDefined(nodeVisitor(node.moduleReference, visitor, isModuleReference)) ); }, - [271 /* ImportDeclaration */]: function visitEachChildOfImportDeclaration(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) { + [272 /* ImportDeclaration */]: function visitEachChildOfImportDeclaration(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) { return context.factory.updateImportDeclaration( node, nodesVisitor(node.modifiers, visitor, isModifierLike), nodeVisitor(node.importClause, visitor, isImportClause), Debug.checkDefined(nodeVisitor(node.moduleSpecifier, visitor, isExpression)), - nodeVisitor(node.assertClause, visitor, isAssertClause) + nodeVisitor(node.attributes, visitor, isImportAttributes) ); }, - [299 /* AssertClause */]: function visitEachChildOfAssertClause(node, visitor, context, nodesVisitor, _nodeVisitor, _tokenVisitor) { - return context.factory.updateAssertClause( + [300 /* ImportAttributes */]: function visitEachChildOfImportAttributes(node, visitor, context, nodesVisitor, _nodeVisitor, _tokenVisitor) { + return context.factory.updateImportAttributes( node, - nodesVisitor(node.elements, visitor, isAssertEntry), + nodesVisitor(node.elements, visitor, isImportAttribute), node.multiLine ); }, - [300 /* AssertEntry */]: function visitEachChildOfAssertEntry(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { - return context.factory.updateAssertEntry( + [301 /* ImportAttribute */]: function visitEachChildOfImportAttribute(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { + return context.factory.updateImportAttribute( node, - Debug.checkDefined(nodeVisitor(node.name, visitor, isAssertionKey)), + Debug.checkDefined(nodeVisitor(node.name, visitor, isImportAttributeName)), Debug.checkDefined(nodeVisitor(node.value, visitor, isExpression)) ); }, - [272 /* ImportClause */]: function visitEachChildOfImportClause(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { + [273 /* ImportClause */]: function visitEachChildOfImportClause(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { return context.factory.updateImportClause( node, node.isTypeOnly, @@ -186057,25 +170110,25 @@ ${lanes.join("\n")} nodeVisitor(node.namedBindings, visitor, isNamedImportBindings) ); }, - [273 /* NamespaceImport */]: function visitEachChildOfNamespaceImport(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { + [274 /* NamespaceImport */]: function visitEachChildOfNamespaceImport(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { return context.factory.updateNamespaceImport( node, Debug.checkDefined(nodeVisitor(node.name, visitor, isIdentifier)) ); }, - [279 /* NamespaceExport */]: function visitEachChildOfNamespaceExport(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { + [280 /* NamespaceExport */]: function visitEachChildOfNamespaceExport(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { return context.factory.updateNamespaceExport( node, Debug.checkDefined(nodeVisitor(node.name, visitor, isIdentifier)) ); }, - [274 /* NamedImports */]: function visitEachChildOfNamedImports(node, visitor, context, nodesVisitor, _nodeVisitor, _tokenVisitor) { + [275 /* NamedImports */]: function visitEachChildOfNamedImports(node, visitor, context, nodesVisitor, _nodeVisitor, _tokenVisitor) { return context.factory.updateNamedImports( node, nodesVisitor(node.elements, visitor, isImportSpecifier) ); }, - [275 /* ImportSpecifier */]: function visitEachChildOfImportSpecifier(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { + [276 /* ImportSpecifier */]: function visitEachChildOfImportSpecifier(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { return context.factory.updateImportSpecifier( node, node.isTypeOnly, @@ -186083,30 +170136,30 @@ ${lanes.join("\n")} Debug.checkDefined(nodeVisitor(node.name, visitor, isIdentifier)) ); }, - [276 /* ExportAssignment */]: function visitEachChildOfExportAssignment(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) { + [277 /* ExportAssignment */]: function visitEachChildOfExportAssignment(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) { return context.factory.updateExportAssignment( node, nodesVisitor(node.modifiers, visitor, isModifierLike), Debug.checkDefined(nodeVisitor(node.expression, visitor, isExpression)) ); }, - [277 /* ExportDeclaration */]: function visitEachChildOfExportDeclaration(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) { + [278 /* ExportDeclaration */]: function visitEachChildOfExportDeclaration(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) { return context.factory.updateExportDeclaration( node, nodesVisitor(node.modifiers, visitor, isModifierLike), node.isTypeOnly, nodeVisitor(node.exportClause, visitor, isNamedExportBindings), nodeVisitor(node.moduleSpecifier, visitor, isExpression), - nodeVisitor(node.assertClause, visitor, isAssertClause) + nodeVisitor(node.attributes, visitor, isImportAttributes) ); }, - [278 /* NamedExports */]: function visitEachChildOfNamedExports(node, visitor, context, nodesVisitor, _nodeVisitor, _tokenVisitor) { + [279 /* NamedExports */]: function visitEachChildOfNamedExports(node, visitor, context, nodesVisitor, _nodeVisitor, _tokenVisitor) { return context.factory.updateNamedExports( node, nodesVisitor(node.elements, visitor, isExportSpecifier) ); }, - [280 /* ExportSpecifier */]: function visitEachChildOfExportSpecifier(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { + [281 /* ExportSpecifier */]: function visitEachChildOfExportSpecifier(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { return context.factory.updateExportSpecifier( node, node.isTypeOnly, @@ -186115,14 +170168,14 @@ ${lanes.join("\n")} ); }, // Module references - [282 /* ExternalModuleReference */]: function visitEachChildOfExternalModuleReference(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { + [283 /* ExternalModuleReference */]: function visitEachChildOfExternalModuleReference(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { return context.factory.updateExternalModuleReference( node, Debug.checkDefined(nodeVisitor(node.expression, visitor, isExpression)) ); }, // JSX - [283 /* JsxElement */]: function visitEachChildOfJsxElement(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) { + [284 /* JsxElement */]: function visitEachChildOfJsxElement(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) { return context.factory.updateJsxElement( node, Debug.checkDefined(nodeVisitor(node.openingElement, visitor, isJsxOpeningElement)), @@ -186130,7 +170183,7 @@ ${lanes.join("\n")} Debug.checkDefined(nodeVisitor(node.closingElement, visitor, isJsxClosingElement)) ); }, - [284 /* JsxSelfClosingElement */]: function visitEachChildOfJsxSelfClosingElement(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) { + [285 /* JsxSelfClosingElement */]: function visitEachChildOfJsxSelfClosingElement(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) { return context.factory.updateJsxSelfClosingElement( node, Debug.checkDefined(nodeVisitor(node.tagName, visitor, isJsxTagNameExpression)), @@ -186138,7 +170191,7 @@ ${lanes.join("\n")} Debug.checkDefined(nodeVisitor(node.attributes, visitor, isJsxAttributes)) ); }, - [285 /* JsxOpeningElement */]: function visitEachChildOfJsxOpeningElement(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) { + [286 /* JsxOpeningElement */]: function visitEachChildOfJsxOpeningElement(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) { return context.factory.updateJsxOpeningElement( node, Debug.checkDefined(nodeVisitor(node.tagName, visitor, isJsxTagNameExpression)), @@ -186146,20 +170199,20 @@ ${lanes.join("\n")} Debug.checkDefined(nodeVisitor(node.attributes, visitor, isJsxAttributes)) ); }, - [286 /* JsxClosingElement */]: function visitEachChildOfJsxClosingElement(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { + [287 /* JsxClosingElement */]: function visitEachChildOfJsxClosingElement(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { return context.factory.updateJsxClosingElement( node, Debug.checkDefined(nodeVisitor(node.tagName, visitor, isJsxTagNameExpression)) ); }, - [294 /* JsxNamespacedName */]: function forEachChildInJsxNamespacedName2(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { + [295 /* JsxNamespacedName */]: function forEachChildInJsxNamespacedName2(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { return context.factory.updateJsxNamespacedName( node, Debug.checkDefined(nodeVisitor(node.namespace, visitor, isIdentifier)), Debug.checkDefined(nodeVisitor(node.name, visitor, isIdentifier)) ); }, - [287 /* JsxFragment */]: function visitEachChildOfJsxFragment(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) { + [288 /* JsxFragment */]: function visitEachChildOfJsxFragment(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) { return context.factory.updateJsxFragment( node, Debug.checkDefined(nodeVisitor(node.openingFragment, visitor, isJsxOpeningFragment)), @@ -186167,52 +170220,52 @@ ${lanes.join("\n")} Debug.checkDefined(nodeVisitor(node.closingFragment, visitor, isJsxClosingFragment)) ); }, - [290 /* JsxAttribute */]: function visitEachChildOfJsxAttribute(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { + [291 /* JsxAttribute */]: function visitEachChildOfJsxAttribute(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { return context.factory.updateJsxAttribute( node, Debug.checkDefined(nodeVisitor(node.name, visitor, isJsxAttributeName)), nodeVisitor(node.initializer, visitor, isStringLiteralOrJsxExpression) ); }, - [291 /* JsxAttributes */]: function visitEachChildOfJsxAttributes(node, visitor, context, nodesVisitor, _nodeVisitor, _tokenVisitor) { + [292 /* JsxAttributes */]: function visitEachChildOfJsxAttributes(node, visitor, context, nodesVisitor, _nodeVisitor, _tokenVisitor) { return context.factory.updateJsxAttributes( node, nodesVisitor(node.properties, visitor, isJsxAttributeLike) ); }, - [292 /* JsxSpreadAttribute */]: function visitEachChildOfJsxSpreadAttribute(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { + [293 /* JsxSpreadAttribute */]: function visitEachChildOfJsxSpreadAttribute(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { return context.factory.updateJsxSpreadAttribute( node, Debug.checkDefined(nodeVisitor(node.expression, visitor, isExpression)) ); }, - [293 /* JsxExpression */]: function visitEachChildOfJsxExpression(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { + [294 /* JsxExpression */]: function visitEachChildOfJsxExpression(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { return context.factory.updateJsxExpression( node, nodeVisitor(node.expression, visitor, isExpression) ); }, // Clauses - [295 /* CaseClause */]: function visitEachChildOfCaseClause(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) { + [296 /* CaseClause */]: function visitEachChildOfCaseClause(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) { return context.factory.updateCaseClause( node, Debug.checkDefined(nodeVisitor(node.expression, visitor, isExpression)), nodesVisitor(node.statements, visitor, isStatement) ); }, - [296 /* DefaultClause */]: function visitEachChildOfDefaultClause(node, visitor, context, nodesVisitor, _nodeVisitor, _tokenVisitor) { + [297 /* DefaultClause */]: function visitEachChildOfDefaultClause(node, visitor, context, nodesVisitor, _nodeVisitor, _tokenVisitor) { return context.factory.updateDefaultClause( node, nodesVisitor(node.statements, visitor, isStatement) ); }, - [297 /* HeritageClause */]: function visitEachChildOfHeritageClause(node, visitor, context, nodesVisitor, _nodeVisitor, _tokenVisitor) { + [298 /* HeritageClause */]: function visitEachChildOfHeritageClause(node, visitor, context, nodesVisitor, _nodeVisitor, _tokenVisitor) { return context.factory.updateHeritageClause( node, nodesVisitor(node.types, visitor, isExpressionWithTypeArguments) ); }, - [298 /* CatchClause */]: function visitEachChildOfCatchClause(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { + [299 /* CatchClause */]: function visitEachChildOfCatchClause(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { return context.factory.updateCatchClause( node, nodeVisitor(node.variableDeclaration, visitor, isVariableDeclaration), @@ -186220,28 +170273,28 @@ ${lanes.join("\n")} ); }, // Property assignments - [302 /* PropertyAssignment */]: function visitEachChildOfPropertyAssignment(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { + [303 /* PropertyAssignment */]: function visitEachChildOfPropertyAssignment(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { return context.factory.updatePropertyAssignment( node, Debug.checkDefined(nodeVisitor(node.name, visitor, isPropertyName)), Debug.checkDefined(nodeVisitor(node.initializer, visitor, isExpression)) ); }, - [303 /* ShorthandPropertyAssignment */]: function visitEachChildOfShorthandPropertyAssignment(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { + [304 /* ShorthandPropertyAssignment */]: function visitEachChildOfShorthandPropertyAssignment(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { return context.factory.updateShorthandPropertyAssignment( node, Debug.checkDefined(nodeVisitor(node.name, visitor, isIdentifier)), nodeVisitor(node.objectAssignmentInitializer, visitor, isExpression) ); }, - [304 /* SpreadAssignment */]: function visitEachChildOfSpreadAssignment(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { + [305 /* SpreadAssignment */]: function visitEachChildOfSpreadAssignment(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { return context.factory.updateSpreadAssignment( node, Debug.checkDefined(nodeVisitor(node.expression, visitor, isExpression)) ); }, // Enum - [305 /* EnumMember */]: function visitEachChildOfEnumMember(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { + [306 /* EnumMember */]: function visitEachChildOfEnumMember(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { return context.factory.updateEnumMember( node, Debug.checkDefined(nodeVisitor(node.name, visitor, isPropertyName)), @@ -186249,20 +170302,20 @@ ${lanes.join("\n")} ); }, // Top-level nodes - [311 /* SourceFile */]: function visitEachChildOfSourceFile(node, visitor, context, _nodesVisitor, _nodeVisitor, _tokenVisitor) { + [312 /* SourceFile */]: function visitEachChildOfSourceFile(node, visitor, context, _nodesVisitor, _nodeVisitor, _tokenVisitor) { return context.factory.updateSourceFile( node, visitLexicalEnvironment(node.statements, visitor, context) ); }, // Transformation nodes - [359 /* PartiallyEmittedExpression */]: function visitEachChildOfPartiallyEmittedExpression(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { + [360 /* PartiallyEmittedExpression */]: function visitEachChildOfPartiallyEmittedExpression(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) { return context.factory.updatePartiallyEmittedExpression( node, Debug.checkDefined(nodeVisitor(node.expression, visitor, isExpression)) ); }, - [360 /* CommaListExpression */]: function visitEachChildOfCommaListExpression(node, visitor, context, nodesVisitor, _nodeVisitor, _tokenVisitor) { + [361 /* CommaListExpression */]: function visitEachChildOfCommaListExpression(node, visitor, context, nodesVisitor, _nodeVisitor, _tokenVisitor) { return context.factory.updateCommaListExpression( node, nodesVisitor(node.elements, visitor, isExpression) @@ -186524,7 +170577,7 @@ ${lanes.join("\n")} const line = lineInfo.getLineText(index); const comment = sourceMapCommentRegExp.exec(line); if (comment) { - return trimStringEnd(comment[1]); + return comment[1].trimEnd(); } else if (!line.match(whitespaceOrMapCommentRegExp)) { break; } @@ -186555,13 +170608,13 @@ ${lanes.join("\n")} let sourceLine = 0; let sourceCharacter = 0; let nameIndex = 0; - let error; + let error2; return { get pos() { return pos; }, get error() { - return error; + return error2; }, get state() { return captureMapping( @@ -186646,8 +170699,8 @@ ${lanes.join("\n")} return { value: void 0, done: true }; } function setError(message) { - if (error === void 0) { - error = message; + if (error2 === void 0) { + error2 = message; } } function setErrorAndStopIterating(message) { @@ -186655,7 +170708,7 @@ ${lanes.join("\n")} return stopIterating(); } function hasReportedError() { - return error !== void 0; + return error2 !== void 0; } function isSourceMappingSegmentEnd() { return pos === mappings.length || mappings.charCodeAt(pos) === 44 /* comma */ || mappings.charCodeAt(pos) === 59 /* semicolon */; @@ -186863,7 +170916,7 @@ ${lanes.join("\n")} function chainBundle(context, transformSourceFile) { return transformSourceFileOrBundle; function transformSourceFileOrBundle(node) { - return node.kind === 311 /* SourceFile */ ? transformSourceFile(node) : transformBundle(node); + return node.kind === 312 /* SourceFile */ ? transformSourceFile(node) : transformBundle(node); } function transformBundle(node) { return context.factory.createBundle(map(node.sourceFiles, transformSourceFile), node.prepends); @@ -186893,9 +170946,11 @@ ${lanes.join("\n")} function getImportNeedsImportDefaultHelper(node) { return !getImportNeedsImportStarHelper(node) && (isDefaultImport(node) || !!node.importClause && isNamedImports(node.importClause.namedBindings) && containsDefaultReference(node.importClause.namedBindings)); } - function collectExternalModuleInfo(context, sourceFile, resolver, compilerOptions) { + function collectExternalModuleInfo(context, sourceFile) { + const resolver = context.getEmitResolver(); + const compilerOptions = context.getCompilerOptions(); const externalImports = []; - const exportSpecifiers = createMultiMap(); + const exportSpecifiers = new IdentifierNameMultiMap(); const exportedBindings = []; const uniqueExports = /* @__PURE__ */ new Map(); let exportedNames; @@ -186906,7 +170961,7 @@ ${lanes.join("\n")} let hasImportDefault = false; for (const node of sourceFile.statements) { switch (node.kind) { - case 271 /* ImportDeclaration */: + case 272 /* ImportDeclaration */: externalImports.push(node); if (!hasImportStar && getImportNeedsImportStarHelper(node)) { hasImportStar = true; @@ -186915,12 +170970,12 @@ ${lanes.join("\n")} hasImportDefault = true; } break; - case 270 /* ImportEqualsDeclaration */: - if (node.moduleReference.kind === 282 /* ExternalModuleReference */) { + case 271 /* ImportEqualsDeclaration */: + if (node.moduleReference.kind === 283 /* ExternalModuleReference */) { externalImports.push(node); } break; - case 277 /* ExportDeclaration */: + case 278 /* ExportDeclaration */: if (node.moduleSpecifier) { if (!node.exportClause) { externalImports.push(node); @@ -186943,21 +170998,21 @@ ${lanes.join("\n")} addExportedNamesForExportDeclaration(node); } break; - case 276 /* ExportAssignment */: + case 277 /* ExportAssignment */: if (node.isExportEquals && !exportEquals) { exportEquals = node; } break; - case 242 /* VariableStatement */: - if (hasSyntacticModifier(node, 1 /* Export */)) { + case 243 /* VariableStatement */: + if (hasSyntacticModifier(node, 32 /* Export */)) { for (const decl of node.declarationList.declarations) { exportedNames = collectExportedVariableInfo(decl, uniqueExports, exportedNames, exportedBindings); } } break; - case 261 /* FunctionDeclaration */: - if (hasSyntacticModifier(node, 1 /* Export */)) { - if (hasSyntacticModifier(node, 1024 /* Default */)) { + case 262 /* FunctionDeclaration */: + if (hasSyntacticModifier(node, 32 /* Export */)) { + if (hasSyntacticModifier(node, 2048 /* Default */)) { if (!hasExportDefault) { multiMapSparseArrayAdd(exportedBindings, getOriginalNodeId(node), context.factory.getDeclarationName(node)); hasExportDefault = true; @@ -186972,9 +171027,9 @@ ${lanes.join("\n")} } } break; - case 262 /* ClassDeclaration */: - if (hasSyntacticModifier(node, 1 /* Export */)) { - if (hasSyntacticModifier(node, 1024 /* Default */)) { + case 263 /* ClassDeclaration */: + if (hasSyntacticModifier(node, 32 /* Export */)) { + if (hasSyntacticModifier(node, 2048 /* Default */)) { if (!hasExportDefault) { multiMapSparseArrayAdd(exportedBindings, getOriginalNodeId(node), context.factory.getDeclarationName(node)); hasExportDefault = true; @@ -187001,7 +171056,7 @@ ${lanes.join("\n")} if (!uniqueExports.get(idText(specifier.name))) { const name = specifier.propertyName || specifier.name; if (!node.moduleSpecifier) { - exportSpecifiers.add(idText(name), specifier); + exportSpecifiers.add(name, specifier); } const decl = resolver.getReferencedImportDeclaration(name) || resolver.getReferencedValueDeclaration(name); if (decl) { @@ -187091,14 +171146,23 @@ ${lanes.join("\n")} const expression = skipParentheses(statement.expression); return isSuperCall(expression) ? expression : void 0; } - function findSuperStatementIndex(statements, indexAfterLastPrologueStatement) { - for (let i = indexAfterLastPrologueStatement; i < statements.length; i += 1) { + function findSuperStatementIndexPathWorker(statements, start, indices) { + for (let i = start; i < statements.length; i += 1) { const statement = statements[i]; if (getSuperCallFromStatement(statement)) { - return i; + indices.unshift(i); + return true; + } else if (isTryStatement(statement) && findSuperStatementIndexPathWorker(statement.tryBlock.statements, 0, indices)) { + indices.unshift(i); + return true; } } - return -1; + return false; + } + function findSuperStatementIndexPath(statements, start) { + const indices = []; + findSuperStatementIndexPathWorker(statements, start, indices); + return indices; } function getProperties(node, requireInitializer, isStatic2) { return filter(node.members, (m) => isInitializedOrStaticProperty(m, requireInitializer, isStatic2)); @@ -187116,7 +171180,7 @@ ${lanes.join("\n")} return isPropertyDeclaration(member) && hasStaticModifier(member); } function isInitializedProperty(member) { - return member.kind === 171 /* PropertyDeclaration */ && member.initializer !== void 0; + return member.kind === 172 /* PropertyDeclaration */ && member.initializer !== void 0; } function isNonStaticMethodOrAccessorWithPrivateName(member) { return !isStatic(member) && (isMethodOrAccessor(member) || isAutoAccessorPropertyDeclaration(member)) && isPrivateIdentifier(member.name); @@ -187153,15 +171217,15 @@ ${lanes.join("\n")} } function getAllDecoratorsOfClassElement(member, parent2, useLegacyDecorators) { switch (member.kind) { - case 176 /* GetAccessor */: - case 177 /* SetAccessor */: + case 177 /* GetAccessor */: + case 178 /* SetAccessor */: if (!useLegacyDecorators) { return getAllDecoratorsOfMethod(member); } return getAllDecoratorsOfAccessors(member, parent2); - case 173 /* MethodDeclaration */: + case 174 /* MethodDeclaration */: return getAllDecoratorsOfMethod(member); - case 171 /* PropertyDeclaration */: + case 172 /* PropertyDeclaration */: return getAllDecoratorsOfProperty(member); default: return void 0; @@ -187233,10 +171297,90 @@ ${lanes.join("\n")} function accessPrivateIdentifier(env, name) { return walkUpLexicalEnvironments(env, (env2) => getPrivateIdentifier(env2.privateEnv, name)); } + var IdentifierNameMap, IdentifierNameMultiMap; var init_utilities3 = __esm({ "src/compiler/transformers/utilities.ts"() { "use strict"; init_ts2(); + IdentifierNameMap = class _IdentifierNameMap { + constructor() { + this._map = /* @__PURE__ */ new Map(); + } + get size() { + return this._map.size; + } + has(key) { + return this._map.has(_IdentifierNameMap.toKey(key)); + } + get(key) { + return this._map.get(_IdentifierNameMap.toKey(key)); + } + set(key, value) { + this._map.set(_IdentifierNameMap.toKey(key), value); + return this; + } + delete(key) { + var _a; + return ((_a = this._map) == null ? void 0 : _a.delete(_IdentifierNameMap.toKey(key))) ?? false; + } + clear() { + this._map.clear(); + } + values() { + return this._map.values(); + } + static toKey(name) { + if (isGeneratedPrivateIdentifier(name) || isGeneratedIdentifier(name)) { + const autoGenerate = name.emitNode.autoGenerate; + if ((autoGenerate.flags & 7 /* KindMask */) === 4 /* Node */) { + const node = getNodeForGeneratedName(name); + const baseName = isMemberName(node) && node !== name ? _IdentifierNameMap.toKey(node) : `(generated@${getNodeId(node)})`; + return formatGeneratedName( + /*privateName*/ + false, + autoGenerate.prefix, + baseName, + autoGenerate.suffix, + _IdentifierNameMap.toKey + ); + } else { + const baseName = `(auto@${autoGenerate.id})`; + return formatGeneratedName( + /*privateName*/ + false, + autoGenerate.prefix, + baseName, + autoGenerate.suffix, + _IdentifierNameMap.toKey + ); + } + } + if (isPrivateIdentifier(name)) { + return idText(name).slice(1); + } + return idText(name); + } + }; + IdentifierNameMultiMap = class extends IdentifierNameMap { + add(key, value) { + let values = this.get(key); + if (values) { + values.push(value); + } else { + this.set(key, values = [value]); + } + return values; + } + remove(key, value) { + const values = this.get(key); + if (values) { + unorderedRemoveItem(values, value); + if (!values.length) { + this.delete(key); + } + } + } + }; } }); @@ -187708,6 +171852,287 @@ ${lanes.join("\n")} } }); + // src/compiler/transformers/classThis.ts + function createClassThisAssignmentBlock(factory2, classThis, thisExpression = factory2.createThis()) { + const expression = factory2.createAssignment(classThis, thisExpression); + const statement = factory2.createExpressionStatement(expression); + const body = factory2.createBlock( + [statement], + /*multiLine*/ + false + ); + const block = factory2.createClassStaticBlockDeclaration(body); + getOrCreateEmitNode(block).classThis = classThis; + return block; + } + function isClassThisAssignmentBlock(node) { + var _a; + if (!isClassStaticBlockDeclaration(node) || node.body.statements.length !== 1) { + return false; + } + const statement = node.body.statements[0]; + return isExpressionStatement(statement) && isAssignmentExpression( + statement.expression, + /*excludeCompoundAssignment*/ + true + ) && isIdentifier(statement.expression.left) && ((_a = node.emitNode) == null ? void 0 : _a.classThis) === statement.expression.left && statement.expression.right.kind === 110 /* ThisKeyword */; + } + function classHasClassThisAssignment(node) { + var _a; + return !!((_a = node.emitNode) == null ? void 0 : _a.classThis) && some(node.members, isClassThisAssignmentBlock); + } + function injectClassThisAssignmentIfMissing(factory2, node, classThis, thisExpression) { + if (classHasClassThisAssignment(node)) { + return node; + } + const staticBlock = createClassThisAssignmentBlock(factory2, classThis, thisExpression); + if (node.name) { + setSourceMapRange(staticBlock.body.statements[0], node.name); + } + const members = factory2.createNodeArray([staticBlock, ...node.members]); + setTextRange(members, node.members); + const updatedNode = isClassDeclaration(node) ? factory2.updateClassDeclaration( + node, + node.modifiers, + node.name, + node.typeParameters, + node.heritageClauses, + members + ) : factory2.updateClassExpression( + node, + node.modifiers, + node.name, + node.typeParameters, + node.heritageClauses, + members + ); + getOrCreateEmitNode(updatedNode).classThis = classThis; + return updatedNode; + } + var init_classThis = __esm({ + "src/compiler/transformers/classThis.ts"() { + "use strict"; + init_ts2(); + } + }); + + // src/compiler/transformers/namedEvaluation.ts + function getAssignedNameOfIdentifier(factory2, name, expression) { + const original = getOriginalNode(skipOuterExpressions(expression)); + if ((isClassDeclaration(original) || isFunctionDeclaration(original)) && !original.name && hasSyntacticModifier(original, 2048 /* Default */)) { + return factory2.createStringLiteral("default"); + } + return factory2.createStringLiteralFromNode(name); + } + function getAssignedNameOfPropertyName(context, name, assignedNameText) { + const { factory: factory2 } = context; + if (assignedNameText !== void 0) { + const assignedName2 = factory2.createStringLiteral(assignedNameText); + return { assignedName: assignedName2, name }; + } + if (isPropertyNameLiteral(name) || isPrivateIdentifier(name)) { + const assignedName2 = factory2.createStringLiteralFromNode(name); + return { assignedName: assignedName2, name }; + } + if (isPropertyNameLiteral(name.expression) && !isIdentifier(name.expression)) { + const assignedName2 = factory2.createStringLiteralFromNode(name.expression); + return { assignedName: assignedName2, name }; + } + const assignedName = factory2.getGeneratedNameForNode(name); + context.hoistVariableDeclaration(assignedName); + const key = context.getEmitHelperFactory().createPropKeyHelper(name.expression); + const assignment = factory2.createAssignment(assignedName, key); + const updatedName = factory2.updateComputedPropertyName(name, assignment); + return { assignedName, name: updatedName }; + } + function createClassNamedEvaluationHelperBlock(context, assignedName, thisExpression = context.factory.createThis()) { + const { factory: factory2 } = context; + const expression = context.getEmitHelperFactory().createSetFunctionNameHelper(thisExpression, assignedName); + const statement = factory2.createExpressionStatement(expression); + const body = factory2.createBlock( + [statement], + /*multiLine*/ + false + ); + const block = factory2.createClassStaticBlockDeclaration(body); + getOrCreateEmitNode(block).assignedName = assignedName; + return block; + } + function isClassNamedEvaluationHelperBlock(node) { + var _a; + if (!isClassStaticBlockDeclaration(node) || node.body.statements.length !== 1) { + return false; + } + const statement = node.body.statements[0]; + return isExpressionStatement(statement) && isCallToHelper(statement.expression, "___setFunctionName") && statement.expression.arguments.length >= 2 && statement.expression.arguments[1] === ((_a = node.emitNode) == null ? void 0 : _a.assignedName); + } + function classHasExplicitlyAssignedName(node) { + var _a; + return !!((_a = node.emitNode) == null ? void 0 : _a.assignedName) && some(node.members, isClassNamedEvaluationHelperBlock); + } + function classHasDeclaredOrExplicitlyAssignedName(node) { + return !!node.name || classHasExplicitlyAssignedName(node); + } + function injectClassNamedEvaluationHelperBlockIfMissing(context, node, assignedName, thisExpression) { + if (classHasExplicitlyAssignedName(node)) { + return node; + } + const { factory: factory2 } = context; + const namedEvaluationBlock = createClassNamedEvaluationHelperBlock(context, assignedName, thisExpression); + if (node.name) { + setSourceMapRange(namedEvaluationBlock.body.statements[0], node.name); + } + const insertionIndex = findIndex(node.members, isClassThisAssignmentBlock) + 1; + const leading = node.members.slice(0, insertionIndex); + const trailing = node.members.slice(insertionIndex); + const members = factory2.createNodeArray([...leading, namedEvaluationBlock, ...trailing]); + setTextRange(members, node.members); + node = isClassDeclaration(node) ? factory2.updateClassDeclaration( + node, + node.modifiers, + node.name, + node.typeParameters, + node.heritageClauses, + members + ) : factory2.updateClassExpression( + node, + node.modifiers, + node.name, + node.typeParameters, + node.heritageClauses, + members + ); + getOrCreateEmitNode(node).assignedName = assignedName; + return node; + } + function finishTransformNamedEvaluation(context, expression, assignedName, ignoreEmptyStringLiteral) { + if (ignoreEmptyStringLiteral && isStringLiteral(assignedName) && isEmptyStringLiteral(assignedName)) { + return expression; + } + const { factory: factory2 } = context; + const innerExpression = skipOuterExpressions(expression); + const updatedExpression = isClassExpression(innerExpression) ? cast(injectClassNamedEvaluationHelperBlockIfMissing(context, innerExpression, assignedName), isClassExpression) : context.getEmitHelperFactory().createSetFunctionNameHelper(innerExpression, assignedName); + return factory2.restoreOuterExpressions(expression, updatedExpression); + } + function transformNamedEvaluationOfPropertyAssignment(context, node, ignoreEmptyStringLiteral, assignedNameText) { + const { factory: factory2 } = context; + const { assignedName, name } = getAssignedNameOfPropertyName(context, node.name, assignedNameText); + const initializer = finishTransformNamedEvaluation(context, node.initializer, assignedName, ignoreEmptyStringLiteral); + return factory2.updatePropertyAssignment( + node, + name, + initializer + ); + } + function transformNamedEvaluationOfShorthandAssignmentProperty(context, node, ignoreEmptyStringLiteral, assignedNameText) { + const { factory: factory2 } = context; + const assignedName = assignedNameText !== void 0 ? factory2.createStringLiteral(assignedNameText) : getAssignedNameOfIdentifier(factory2, node.name, node.objectAssignmentInitializer); + const objectAssignmentInitializer = finishTransformNamedEvaluation(context, node.objectAssignmentInitializer, assignedName, ignoreEmptyStringLiteral); + return factory2.updateShorthandPropertyAssignment( + node, + node.name, + objectAssignmentInitializer + ); + } + function transformNamedEvaluationOfVariableDeclaration(context, node, ignoreEmptyStringLiteral, assignedNameText) { + const { factory: factory2 } = context; + const assignedName = assignedNameText !== void 0 ? factory2.createStringLiteral(assignedNameText) : getAssignedNameOfIdentifier(factory2, node.name, node.initializer); + const initializer = finishTransformNamedEvaluation(context, node.initializer, assignedName, ignoreEmptyStringLiteral); + return factory2.updateVariableDeclaration( + node, + node.name, + node.exclamationToken, + node.type, + initializer + ); + } + function transformNamedEvaluationOfParameterDeclaration(context, node, ignoreEmptyStringLiteral, assignedNameText) { + const { factory: factory2 } = context; + const assignedName = assignedNameText !== void 0 ? factory2.createStringLiteral(assignedNameText) : getAssignedNameOfIdentifier(factory2, node.name, node.initializer); + const initializer = finishTransformNamedEvaluation(context, node.initializer, assignedName, ignoreEmptyStringLiteral); + return factory2.updateParameterDeclaration( + node, + node.modifiers, + node.dotDotDotToken, + node.name, + node.questionToken, + node.type, + initializer + ); + } + function transformNamedEvaluationOfBindingElement(context, node, ignoreEmptyStringLiteral, assignedNameText) { + const { factory: factory2 } = context; + const assignedName = assignedNameText !== void 0 ? factory2.createStringLiteral(assignedNameText) : getAssignedNameOfIdentifier(factory2, node.name, node.initializer); + const initializer = finishTransformNamedEvaluation(context, node.initializer, assignedName, ignoreEmptyStringLiteral); + return factory2.updateBindingElement( + node, + node.dotDotDotToken, + node.propertyName, + node.name, + initializer + ); + } + function transformNamedEvaluationOfPropertyDeclaration(context, node, ignoreEmptyStringLiteral, assignedNameText) { + const { factory: factory2 } = context; + const { assignedName, name } = getAssignedNameOfPropertyName(context, node.name, assignedNameText); + const initializer = finishTransformNamedEvaluation(context, node.initializer, assignedName, ignoreEmptyStringLiteral); + return factory2.updatePropertyDeclaration( + node, + node.modifiers, + name, + node.questionToken ?? node.exclamationToken, + node.type, + initializer + ); + } + function transformNamedEvaluationOfAssignmentExpression(context, node, ignoreEmptyStringLiteral, assignedNameText) { + const { factory: factory2 } = context; + const assignedName = assignedNameText !== void 0 ? factory2.createStringLiteral(assignedNameText) : getAssignedNameOfIdentifier(factory2, node.left, node.right); + const right = finishTransformNamedEvaluation(context, node.right, assignedName, ignoreEmptyStringLiteral); + return factory2.updateBinaryExpression( + node, + node.left, + node.operatorToken, + right + ); + } + function transformNamedEvaluationOfExportAssignment(context, node, ignoreEmptyStringLiteral, assignedNameText) { + const { factory: factory2 } = context; + const assignedName = assignedNameText !== void 0 ? factory2.createStringLiteral(assignedNameText) : factory2.createStringLiteral(node.isExportEquals ? "" : "default"); + const expression = finishTransformNamedEvaluation(context, node.expression, assignedName, ignoreEmptyStringLiteral); + return factory2.updateExportAssignment( + node, + node.modifiers, + expression + ); + } + function transformNamedEvaluation(context, node, ignoreEmptyStringLiteral, assignedName) { + switch (node.kind) { + case 303 /* PropertyAssignment */: + return transformNamedEvaluationOfPropertyAssignment(context, node, ignoreEmptyStringLiteral, assignedName); + case 304 /* ShorthandPropertyAssignment */: + return transformNamedEvaluationOfShorthandAssignmentProperty(context, node, ignoreEmptyStringLiteral, assignedName); + case 260 /* VariableDeclaration */: + return transformNamedEvaluationOfVariableDeclaration(context, node, ignoreEmptyStringLiteral, assignedName); + case 169 /* Parameter */: + return transformNamedEvaluationOfParameterDeclaration(context, node, ignoreEmptyStringLiteral, assignedName); + case 208 /* BindingElement */: + return transformNamedEvaluationOfBindingElement(context, node, ignoreEmptyStringLiteral, assignedName); + case 172 /* PropertyDeclaration */: + return transformNamedEvaluationOfPropertyDeclaration(context, node, ignoreEmptyStringLiteral, assignedName); + case 226 /* BinaryExpression */: + return transformNamedEvaluationOfAssignmentExpression(context, node, ignoreEmptyStringLiteral, assignedName); + case 277 /* ExportAssignment */: + return transformNamedEvaluationOfExportAssignment(context, node, ignoreEmptyStringLiteral, assignedName); + } + } + var init_namedEvaluation = __esm({ + "src/compiler/transformers/namedEvaluation.ts"() { + "use strict"; + init_ts2(); + } + }); + // src/compiler/transformers/taggedTemplate.ts function processTaggedTemplateExpression(context, node, visitor, currentSourceFile, recordTaggedTemplateString, level) { const tag = visitNode(node.tag, visitor, isExpression); @@ -187762,10 +172187,7 @@ ${lanes.join("\n")} function getRawLiteral(factory2, node, currentSourceFile) { let text = node.rawText; if (text === void 0) { - Debug.assertIsDefined( - currentSourceFile, - "Template literal node is missing 'rawText' and does not have a source file. Possibly bad transform." - ); + Debug.assertIsDefined(currentSourceFile, "Template literal node is missing 'rawText' and does not have a source file. Possibly bad transform."); text = getSourceTextOfNodeFromSourceFile(currentSourceFile, node); const isLast = node.kind === 15 /* NoSubstitutionTemplateLiteral */ || node.kind === 18 /* TemplateTail */; text = text.substring(1, text.length - (isLast ? 1 : 2)); @@ -187806,8 +172228,8 @@ ${lanes.join("\n")} const previousOnSubstituteNode = context.onSubstituteNode; context.onEmitNode = onEmitNode; context.onSubstituteNode = onSubstituteNode; - context.enableSubstitution(210 /* PropertyAccessExpression */); - context.enableSubstitution(211 /* ElementAccessExpression */); + context.enableSubstitution(211 /* PropertyAccessExpression */); + context.enableSubstitution(212 /* ElementAccessExpression */); let currentSourceFile; let currentNamespace; let currentNamespaceContainerName; @@ -187818,18 +172240,21 @@ ${lanes.join("\n")} let applicableSubstitutions; return transformSourceFileOrBundle; function transformSourceFileOrBundle(node) { - if (node.kind === 312 /* Bundle */) { + if (node.kind === 313 /* Bundle */) { return transformBundle(node); } return transformSourceFile(node); } function transformBundle(node) { - return factory2.createBundle(node.sourceFiles.map(transformSourceFile), mapDefined(node.prepends, (prepend) => { - if (prepend.kind === 314 /* InputFiles */) { - return createUnparsedSourceFile(prepend, "js"); - } - return prepend; - })); + return factory2.createBundle( + node.sourceFiles.map(transformSourceFile), + mapDefined(node.prepends, (prepend) => { + if (prepend.kind === 315 /* InputFiles */) { + return createUnparsedSourceFile(prepend, "js"); + } + return prepend; + }) + ); } function transformSourceFile(node) { if (node.isDeclarationFile) { @@ -187856,22 +172281,22 @@ ${lanes.join("\n")} } function onBeforeVisitNode(node) { switch (node.kind) { - case 311 /* SourceFile */: - case 268 /* CaseBlock */: - case 267 /* ModuleBlock */: - case 240 /* Block */: + case 312 /* SourceFile */: + case 269 /* CaseBlock */: + case 268 /* ModuleBlock */: + case 241 /* Block */: currentLexicalScope = node; currentScopeFirstDeclarationsOfName = void 0; break; - case 262 /* ClassDeclaration */: - case 261 /* FunctionDeclaration */: - if (hasSyntacticModifier(node, 2 /* Ambient */)) { + case 263 /* ClassDeclaration */: + case 262 /* FunctionDeclaration */: + if (hasSyntacticModifier(node, 128 /* Ambient */)) { break; } if (node.name) { recordEmittedDeclarationInScope(node); } else { - Debug.assert(node.kind === 262 /* ClassDeclaration */ || hasSyntacticModifier(node, 1024 /* Default */)); + Debug.assert(node.kind === 263 /* ClassDeclaration */ || hasSyntacticModifier(node, 2048 /* Default */)); } break; } @@ -187890,10 +172315,10 @@ ${lanes.join("\n")} } function sourceElementVisitorWorker(node) { switch (node.kind) { - case 271 /* ImportDeclaration */: - case 270 /* ImportEqualsDeclaration */: - case 276 /* ExportAssignment */: - case 277 /* ExportDeclaration */: + case 272 /* ImportDeclaration */: + case 271 /* ImportEqualsDeclaration */: + case 277 /* ExportAssignment */: + case 278 /* ExportDeclaration */: return visitElidableStatement(node); default: return visitorWorker(node); @@ -187908,13 +172333,13 @@ ${lanes.join("\n")} return node; } switch (node.kind) { - case 271 /* ImportDeclaration */: + case 272 /* ImportDeclaration */: return visitImportDeclaration(node); - case 270 /* ImportEqualsDeclaration */: + case 271 /* ImportEqualsDeclaration */: return visitImportEqualsDeclaration(node); - case 276 /* ExportAssignment */: + case 277 /* ExportAssignment */: return visitExportAssignment(node); - case 277 /* ExportDeclaration */: + case 278 /* ExportDeclaration */: return visitExportDeclaration(node); default: Debug.fail("Unhandled ellided statement"); @@ -187924,9 +172349,9 @@ ${lanes.join("\n")} return saveStateAndInvoke(node, namespaceElementVisitorWorker); } function namespaceElementVisitorWorker(node) { - if (node.kind === 277 /* ExportDeclaration */ || node.kind === 271 /* ImportDeclaration */ || node.kind === 272 /* ImportClause */ || node.kind === 270 /* ImportEqualsDeclaration */ && node.moduleReference.kind === 282 /* ExternalModuleReference */) { + if (node.kind === 278 /* ExportDeclaration */ || node.kind === 272 /* ImportDeclaration */ || node.kind === 273 /* ImportClause */ || node.kind === 271 /* ImportEqualsDeclaration */ && node.moduleReference.kind === 283 /* ExternalModuleReference */) { return void 0; - } else if (node.transformFlags & 1 /* ContainsTypeScript */ || hasSyntacticModifier(node, 1 /* Export */)) { + } else if (node.transformFlags & 1 /* ContainsTypeScript */ || hasSyntacticModifier(node, 32 /* Export */)) { return visitTypeScript(node); } return node; @@ -187936,21 +172361,21 @@ ${lanes.join("\n")} } function classElementVisitorWorker(node, parent2) { switch (node.kind) { - case 175 /* Constructor */: + case 176 /* Constructor */: return visitConstructor(node); - case 171 /* PropertyDeclaration */: + case 172 /* PropertyDeclaration */: return visitPropertyDeclaration(node, parent2); - case 176 /* GetAccessor */: + case 177 /* GetAccessor */: return visitGetAccessor(node, parent2); - case 177 /* SetAccessor */: + case 178 /* SetAccessor */: return visitSetAccessor(node, parent2); - case 173 /* MethodDeclaration */: + case 174 /* MethodDeclaration */: return visitMethodDeclaration(node, parent2); - case 174 /* ClassStaticBlockDeclaration */: + case 175 /* ClassStaticBlockDeclaration */: return visitEachChild(node, visitor, context); - case 239 /* SemicolonClassElement */: + case 240 /* SemicolonClassElement */: return node; - case 180 /* IndexSignature */: + case 181 /* IndexSignature */: return; default: return Debug.failBadSyntaxKind(node); @@ -187961,15 +172386,15 @@ ${lanes.join("\n")} } function objectLiteralElementVisitorWorker(node, parent2) { switch (node.kind) { - case 302 /* PropertyAssignment */: - case 303 /* ShorthandPropertyAssignment */: - case 304 /* SpreadAssignment */: + case 303 /* PropertyAssignment */: + case 304 /* ShorthandPropertyAssignment */: + case 305 /* SpreadAssignment */: return visitor(node); - case 176 /* GetAccessor */: + case 177 /* GetAccessor */: return visitGetAccessor(node, parent2); - case 177 /* SetAccessor */: + case 178 /* SetAccessor */: return visitSetAccessor(node, parent2); - case 173 /* MethodDeclaration */: + case 174 /* MethodDeclaration */: return visitMethodDeclaration(node, parent2); default: return Debug.failBadSyntaxKind(node); @@ -187984,7 +172409,7 @@ ${lanes.join("\n")} function modifierVisitor(node) { if (isDecorator(node)) return void 0; - if (modifierToFlag(node.kind) & 117086 /* TypeScriptModifier */) { + if (modifierToFlag(node.kind) & 28895 /* TypeScriptModifier */) { return void 0; } else if (currentNamespace && node.kind === 95 /* ExportKeyword */) { return void 0; @@ -187992,7 +172417,7 @@ ${lanes.join("\n")} return node; } function visitTypeScript(node) { - if (isStatement(node) && hasSyntacticModifier(node, 2 /* Ambient */)) { + if (isStatement(node) && hasSyntacticModifier(node, 128 /* Ambient */)) { return factory2.createNotEmittedStatement(node); } switch (node.kind) { @@ -188003,19 +172428,19 @@ ${lanes.join("\n")} case 123 /* PrivateKeyword */: case 124 /* ProtectedKeyword */: case 128 /* AbstractKeyword */: - case 163 /* OverrideKeyword */: + case 164 /* OverrideKeyword */: case 87 /* ConstKeyword */: case 138 /* DeclareKeyword */: case 148 /* ReadonlyKeyword */: case 103 /* InKeyword */: case 147 /* OutKeyword */: - case 187 /* ArrayType */: - case 188 /* TupleType */: - case 189 /* OptionalType */: - case 190 /* RestType */: - case 186 /* TypeLiteral */: - case 181 /* TypePredicate */: - case 167 /* TypeParameter */: + case 188 /* ArrayType */: + case 189 /* TupleType */: + case 190 /* OptionalType */: + case 191 /* RestType */: + case 187 /* TypeLiteral */: + case 182 /* TypePredicate */: + case 168 /* TypeParameter */: case 133 /* AnyKeyword */: case 159 /* UnknownKeyword */: case 136 /* BooleanKeyword */: @@ -188024,80 +172449,80 @@ ${lanes.join("\n")} case 146 /* NeverKeyword */: case 116 /* VoidKeyword */: case 155 /* SymbolKeyword */: - case 184 /* ConstructorType */: - case 183 /* FunctionType */: - case 185 /* TypeQuery */: - case 182 /* TypeReference */: - case 191 /* UnionType */: - case 192 /* IntersectionType */: - case 193 /* ConditionalType */: - case 195 /* ParenthesizedType */: - case 196 /* ThisType */: - case 197 /* TypeOperator */: - case 198 /* IndexedAccessType */: - case 199 /* MappedType */: - case 200 /* LiteralType */: - case 180 /* IndexSignature */: + case 185 /* ConstructorType */: + case 184 /* FunctionType */: + case 186 /* TypeQuery */: + case 183 /* TypeReference */: + case 192 /* UnionType */: + case 193 /* IntersectionType */: + case 194 /* ConditionalType */: + case 196 /* ParenthesizedType */: + case 197 /* ThisType */: + case 198 /* TypeOperator */: + case 199 /* IndexedAccessType */: + case 200 /* MappedType */: + case 201 /* LiteralType */: + case 181 /* IndexSignature */: return void 0; - case 264 /* TypeAliasDeclaration */: + case 265 /* TypeAliasDeclaration */: return factory2.createNotEmittedStatement(node); - case 269 /* NamespaceExportDeclaration */: + case 270 /* NamespaceExportDeclaration */: return void 0; - case 263 /* InterfaceDeclaration */: + case 264 /* InterfaceDeclaration */: return factory2.createNotEmittedStatement(node); - case 262 /* ClassDeclaration */: + case 263 /* ClassDeclaration */: return visitClassDeclaration(node); - case 230 /* ClassExpression */: + case 231 /* ClassExpression */: return visitClassExpression(node); - case 297 /* HeritageClause */: + case 298 /* HeritageClause */: return visitHeritageClause(node); - case 232 /* ExpressionWithTypeArguments */: + case 233 /* ExpressionWithTypeArguments */: return visitExpressionWithTypeArguments(node); - case 209 /* ObjectLiteralExpression */: + case 210 /* ObjectLiteralExpression */: return visitObjectLiteralExpression(node); - case 175 /* Constructor */: - case 171 /* PropertyDeclaration */: - case 173 /* MethodDeclaration */: - case 176 /* GetAccessor */: - case 177 /* SetAccessor */: - case 174 /* ClassStaticBlockDeclaration */: + case 176 /* Constructor */: + case 172 /* PropertyDeclaration */: + case 174 /* MethodDeclaration */: + case 177 /* GetAccessor */: + case 178 /* SetAccessor */: + case 175 /* ClassStaticBlockDeclaration */: return Debug.fail("Class and object literal elements must be visited with their respective visitors"); - case 261 /* FunctionDeclaration */: + case 262 /* FunctionDeclaration */: return visitFunctionDeclaration(node); - case 217 /* FunctionExpression */: + case 218 /* FunctionExpression */: return visitFunctionExpression(node); - case 218 /* ArrowFunction */: + case 219 /* ArrowFunction */: return visitArrowFunction(node); - case 168 /* Parameter */: + case 169 /* Parameter */: return visitParameter(node); - case 216 /* ParenthesizedExpression */: + case 217 /* ParenthesizedExpression */: return visitParenthesizedExpression(node); - case 215 /* TypeAssertionExpression */: - case 233 /* AsExpression */: + case 216 /* TypeAssertionExpression */: + case 234 /* AsExpression */: return visitAssertionExpression(node); - case 237 /* SatisfiesExpression */: + case 238 /* SatisfiesExpression */: return visitSatisfiesExpression(node); - case 212 /* CallExpression */: + case 213 /* CallExpression */: return visitCallExpression(node); - case 213 /* NewExpression */: + case 214 /* NewExpression */: return visitNewExpression(node); - case 214 /* TaggedTemplateExpression */: + case 215 /* TaggedTemplateExpression */: return visitTaggedTemplateExpression(node); - case 234 /* NonNullExpression */: + case 235 /* NonNullExpression */: return visitNonNullExpression(node); - case 265 /* EnumDeclaration */: + case 266 /* EnumDeclaration */: return visitEnumDeclaration(node); - case 242 /* VariableStatement */: + case 243 /* VariableStatement */: return visitVariableStatement(node); - case 259 /* VariableDeclaration */: + case 260 /* VariableDeclaration */: return visitVariableDeclaration(node); - case 266 /* ModuleDeclaration */: + case 267 /* ModuleDeclaration */: return visitModuleDeclaration(node); - case 270 /* ImportEqualsDeclaration */: + case 271 /* ImportEqualsDeclaration */: return visitImportEqualsDeclaration(node); - case 284 /* JsxSelfClosingElement */: + case 285 /* JsxSelfClosingElement */: return visitJsxSelfClosingElement(node); - case 285 /* JsxOpeningElement */: + case 286 /* JsxOpeningElement */: return visitJsxJsxOpeningElement(node); default: return visitEachChild(node, visitor, context); @@ -188207,25 +172632,25 @@ ${lanes.join("\n")} insertStatementsAfterStandardPrologue(statements, context.endLexicalEnvironment()); const iife = factory2.createImmediatelyInvokedArrowFunction(statements); setInternalEmitFlags(iife, 1 /* TypeScriptClassWrapper */); - const modifiers2 = facts & 16 /* IsNamedExternalExport */ ? factory2.createModifiersFromModifierFlags(1 /* Export */) : void 0; + const varDecl = factory2.createVariableDeclaration( + factory2.getLocalName( + node, + /*allowComments*/ + false, + /*allowSourceMaps*/ + false + ), + /*exclamationToken*/ + void 0, + /*type*/ + void 0, + iife + ); + setOriginalNode(varDecl, node); const varStatement = factory2.createVariableStatement( - modifiers2, - factory2.createVariableDeclarationList([ - factory2.createVariableDeclaration( - factory2.getLocalName( - node, - /*allowComments*/ - false, - /*allowSourceMaps*/ - false - ), - /*exclamationToken*/ - void 0, - /*type*/ - void 0, - iife - ) - ], 1 /* Let */) + /*modifiers*/ + void 0, + factory2.createVariableDeclarationList([varDecl], 1 /* Let */) ); setOriginalNode(varStatement, node); setCommentRange(varStatement, node); @@ -188254,10 +172679,10 @@ ${lanes.join("\n")} )) ]; } - if (facts & 16 /* IsNamedExternalExport */ && !promoteToIIFE) { + if (facts & 16 /* IsNamedExternalExport */) { return [ statement, - factory2.createExternalModuleExport(factory2.getLocalName( + factory2.createExternalModuleExport(factory2.getDeclarationName( node, /*allowComments*/ false, @@ -188421,19 +172846,19 @@ ${lanes.join("\n")} } function shouldAddTypeMetadata(node) { const kind = node.kind; - return kind === 173 /* MethodDeclaration */ || kind === 176 /* GetAccessor */ || kind === 177 /* SetAccessor */ || kind === 171 /* PropertyDeclaration */; + return kind === 174 /* MethodDeclaration */ || kind === 177 /* GetAccessor */ || kind === 178 /* SetAccessor */ || kind === 172 /* PropertyDeclaration */; } function shouldAddReturnTypeMetadata(node) { - return node.kind === 173 /* MethodDeclaration */; + return node.kind === 174 /* MethodDeclaration */; } function shouldAddParamTypesMetadata(node) { switch (node.kind) { - case 262 /* ClassDeclaration */: - case 230 /* ClassExpression */: + case 263 /* ClassDeclaration */: + case 231 /* ClassExpression */: return getFirstConstructorWithBody(node) !== void 0; - case 173 /* MethodDeclaration */: - case 176 /* GetAccessor */: - case 177 /* SetAccessor */: + case 174 /* MethodDeclaration */: + case 177 /* GetAccessor */: + case 178 /* SetAccessor */: return true; } return false; @@ -188482,7 +172907,7 @@ ${lanes.join("\n")} return !nodeIsMissing(node.body); } function visitPropertyDeclaration(node, parent2) { - const isAmbient = node.flags & 16777216 /* Ambient */ || hasSyntacticModifier(node, 256 /* Abstract */); + const isAmbient = node.flags & 33554432 /* Ambient */ || hasSyntacticModifier(node, 64 /* Abstract */); if (isAmbient && !(legacyDecorators && hasDecorators(node))) { return void 0; } @@ -188491,7 +172916,7 @@ ${lanes.join("\n")} if (isAmbient) { return factory2.updatePropertyDeclaration( node, - concatenate(modifiers, factory2.createModifiersFromModifierFlags(2 /* Ambient */)), + concatenate(modifiers, factory2.createModifiersFromModifierFlags(128 /* Ambient */)), Debug.checkDefined(visitNode(node.name, visitor, isPropertyName)), /*questionOrExclamationToken*/ void 0, @@ -188524,6 +172949,35 @@ ${lanes.join("\n")} transformConstructorBody(node.body, node) ); } + function transformConstructorBodyWorker(statementsOut, statementsIn, statementOffset, superPath, superPathDepth, initializerStatements) { + const superStatementIndex = superPath[superPathDepth]; + const superStatement = statementsIn[superStatementIndex]; + addRange(statementsOut, visitNodes2(statementsIn, visitor, isStatement, statementOffset, superStatementIndex - statementOffset)); + if (isTryStatement(superStatement)) { + const tryBlockStatements = []; + transformConstructorBodyWorker( + tryBlockStatements, + superStatement.tryBlock.statements, + /*statementOffset*/ + 0, + superPath, + superPathDepth + 1, + initializerStatements + ); + const tryBlockStatementsArray = factory2.createNodeArray(tryBlockStatements); + setTextRange(tryBlockStatementsArray, superStatement.tryBlock.statements); + statementsOut.push(factory2.updateTryStatement( + superStatement, + factory2.updateBlock(superStatement.tryBlock, tryBlockStatements), + visitNode(superStatement.catchClause, visitor, isCatchClause), + visitNode(superStatement.finallyBlock, visitor, isBlock) + )); + } else { + addRange(statementsOut, visitNodes2(statementsIn, visitor, isStatement, superStatementIndex, 1)); + addRange(statementsOut, initializerStatements); + } + addRange(statementsOut, visitNodes2(statementsIn, visitor, isStatement, superStatementIndex + 1)); + } function transformConstructorBody(body, constructor) { const parametersWithPropertyAssignments = constructor && filter(constructor.parameters, (p) => isParameterPropertyDeclaration(p, constructor)); if (!some(parametersWithPropertyAssignments)) { @@ -188538,25 +172992,22 @@ ${lanes.join("\n")} false, visitor ); - const superStatementIndex = findSuperStatementIndex(body.statements, prologueStatementCount); - if (superStatementIndex >= 0) { - addRange( + const superPath = findSuperStatementIndexPath(body.statements, prologueStatementCount); + const parameterPropertyAssignments = mapDefined(parametersWithPropertyAssignments, transformParameterWithPropertyAssignment); + if (superPath.length) { + transformConstructorBodyWorker( statements, - visitNodes2(body.statements, visitor, isStatement, prologueStatementCount, superStatementIndex + 1 - prologueStatementCount) + body.statements, + prologueStatementCount, + superPath, + /*superPathDepth*/ + 0, + parameterPropertyAssignments ); - } - const parameterPropertyAssignments = mapDefined(parametersWithPropertyAssignments, transformParameterWithPropertyAssignment); - if (superStatementIndex >= 0) { - addRange(statements, parameterPropertyAssignments); } else { - statements = [ - ...statements.slice(0, prologueStatementCount), - ...parameterPropertyAssignments, - ...statements.slice(prologueStatementCount) - ]; + addRange(statements, parameterPropertyAssignments); + addRange(statements, visitNodes2(body.statements, visitor, isStatement, prologueStatementCount)); } - const start = superStatementIndex >= 0 ? superStatementIndex + 1 : prologueStatementCount; - addRange(statements, visitNodes2(body.statements, visitor, isStatement, start)); statements = factory2.mergeLexicalEnvironment(statements, endLexicalEnvironment()); const block = factory2.createBlock( setTextRange(factory2.createNodeArray(statements), body.statements), @@ -188628,7 +173079,7 @@ ${lanes.join("\n")} ); } function shouldEmitAccessorDeclaration(node) { - return !(nodeIsMissing(node.body) && hasSyntacticModifier(node, 256 /* Abstract */)); + return !(nodeIsMissing(node.body) && hasSyntacticModifier(node, 64 /* Abstract */)); } function visitGetAccessor(node, parent2) { if (!(node.transformFlags & 1 /* ContainsTypeScript */)) { @@ -189052,7 +173503,7 @@ ${lanes.join("\n")} /*allowSourceMaps*/ true )); - const varFlags = currentLexicalScope.kind === 311 /* SourceFile */ ? 0 /* None */ : 1 /* Let */; + const varFlags = currentLexicalScope.kind === 312 /* SourceFile */ ? 0 /* None */ : 1 /* Let */; const statement = factory2.createVariableStatement( visitNodes2(node.modifiers, modifierVisitor, isModifier), factory2.createVariableDeclarationList([varDecl], varFlags) @@ -189063,7 +173514,7 @@ ${lanes.join("\n")} setOriginalNode(statement, node); recordEmittedDeclarationInScope(node); if (isFirstEmittedDeclarationInScope(node)) { - if (node.kind === 265 /* EnumDeclaration */) { + if (node.kind === 266 /* EnumDeclaration */) { setSourceMapRange(statement.declarationList, node); } else { setSourceMapRange(statement, node); @@ -189171,7 +173622,7 @@ ${lanes.join("\n")} let statementsLocation; let blockLocation; if (node.body) { - if (node.body.kind === 267 /* ModuleBlock */) { + if (node.body.kind === 268 /* ModuleBlock */) { saveStateAndInvoke(node.body, (body) => addRange(statements, visitNodes2(body.statements, namespaceElementVisitor, isStatement))); statementsLocation = node.body.statements; blockLocation = node.body; @@ -189202,13 +173653,13 @@ ${lanes.join("\n")} true ); setTextRange(block, blockLocation); - if (!node.body || node.body.kind !== 267 /* ModuleBlock */) { + if (!node.body || node.body.kind !== 268 /* ModuleBlock */) { setEmitFlags(block, getEmitFlags(block) | 3072 /* NoComments */); } return block; } function getInnerMostModuleDeclarationFromDottedModule(moduleDeclaration) { - if (moduleDeclaration.body.kind === 266 /* ModuleDeclaration */) { + if (moduleDeclaration.body.kind === 267 /* ModuleDeclaration */) { const recursiveInnerModule = getInnerMostModuleDeclarationFromDottedModule(moduleDeclaration.body); return recursiveInnerModule || moduleDeclaration.body; } @@ -189227,7 +173678,7 @@ ${lanes.join("\n")} void 0, importClause, node.moduleSpecifier, - node.assertClause + node.attributes ) : void 0; } function visitImportClause(node) { @@ -189243,7 +173694,7 @@ ${lanes.join("\n")} ) : void 0; } function visitNamedImportBindings(node) { - if (node.kind === 273 /* NamespaceImport */) { + if (node.kind === 274 /* NamespaceImport */) { return shouldEmitAliasDeclaration(node) ? node : void 0; } else { const allowEmpty = compilerOptions.verbatimModuleSyntax || compilerOptions.preserveValueImports && (compilerOptions.importsNotUsedAsValues === 1 /* Preserve */ || compilerOptions.importsNotUsedAsValues === 2 /* Error */); @@ -189277,7 +173728,7 @@ ${lanes.join("\n")} node.isTypeOnly, exportClause, node.moduleSpecifier, - node.assertClause + node.attributes ) : void 0; } function visitNamedExports(node, allowEmpty) { @@ -189311,7 +173762,7 @@ ${lanes.join("\n")} /*importClause*/ void 0, node.moduleReference.expression, - /*assertClause*/ + /*attributes*/ void 0 ), node @@ -189361,16 +173812,16 @@ ${lanes.join("\n")} } } function isExportOfNamespace(node) { - return currentNamespace !== void 0 && hasSyntacticModifier(node, 1 /* Export */); + return currentNamespace !== void 0 && hasSyntacticModifier(node, 32 /* Export */); } function isExternalModuleExport(node) { - return currentNamespace === void 0 && hasSyntacticModifier(node, 1 /* Export */); + return currentNamespace === void 0 && hasSyntacticModifier(node, 32 /* Export */); } function isNamedExternalModuleExport(node) { - return isExternalModuleExport(node) && !hasSyntacticModifier(node, 1024 /* Default */); + return isExternalModuleExport(node) && !hasSyntacticModifier(node, 2048 /* Default */); } function isDefaultExternalModuleExport(node) { - return isExternalModuleExport(node) && hasSyntacticModifier(node, 1024 /* Default */); + return isExternalModuleExport(node) && hasSyntacticModifier(node, 2048 /* Default */); } function createExportMemberAssignmentStatement(node) { const expression = factory2.createAssignment( @@ -189441,15 +173892,15 @@ ${lanes.join("\n")} if ((enabledSubstitutions & 2 /* NamespaceExports */) === 0) { enabledSubstitutions |= 2 /* NamespaceExports */; context.enableSubstitution(80 /* Identifier */); - context.enableSubstitution(303 /* ShorthandPropertyAssignment */); - context.enableEmitNotification(266 /* ModuleDeclaration */); + context.enableSubstitution(304 /* ShorthandPropertyAssignment */); + context.enableEmitNotification(267 /* ModuleDeclaration */); } } function isTransformedModuleDeclaration(node) { - return getOriginalNode(node).kind === 266 /* ModuleDeclaration */; + return getOriginalNode(node).kind === 267 /* ModuleDeclaration */; } function isTransformedEnumDeclaration(node) { - return getOriginalNode(node).kind === 265 /* EnumDeclaration */; + return getOriginalNode(node).kind === 266 /* EnumDeclaration */; } function onEmitNode(hint, node, emitCallback) { const savedApplicableSubstitutions = applicableSubstitutions; @@ -189494,9 +173945,9 @@ ${lanes.join("\n")} switch (node.kind) { case 80 /* Identifier */: return substituteExpressionIdentifier(node); - case 210 /* PropertyAccessExpression */: + case 211 /* PropertyAccessExpression */: return substitutePropertyAccessExpression(node); - case 211 /* ElementAccessExpression */: + case 212 /* ElementAccessExpression */: return substituteElementAccessExpression(node); } return node; @@ -189511,8 +173962,8 @@ ${lanes.join("\n")} /*prefixLocals*/ false ); - if (container && container.kind !== 311 /* SourceFile */) { - const substitute = applicableSubstitutions & 2 /* NamespaceExports */ && container.kind === 266 /* ModuleDeclaration */ || applicableSubstitutions & 8 /* NonQualifiedEnumMembers */ && container.kind === 265 /* EnumDeclaration */; + if (container && container.kind !== 312 /* SourceFile */) { + const substitute = applicableSubstitutions & 2 /* NamespaceExports */ && container.kind === 267 /* ModuleDeclaration */ || applicableSubstitutions & 8 /* NonQualifiedEnumMembers */ && container.kind === 266 /* EnumDeclaration */; if (substitute) { return setTextRange( factory2.createPropertyAccessExpression(factory2.getGeneratedNameForNode(container), node), @@ -189537,7 +173988,7 @@ ${lanes.join("\n")} const constantValue = tryGetConstEnumValue(node); if (constantValue !== void 0) { setConstantValue(node, constantValue); - const substitute = typeof constantValue === "string" ? factory2.createStringLiteral(constantValue) : factory2.createNumericLiteral(constantValue); + const substitute = typeof constantValue === "string" ? factory2.createStringLiteral(constantValue) : constantValue < 0 ? factory2.createPrefixUnaryExpression(41 /* MinusToken */, factory2.createNumericLiteral(Math.abs(constantValue))) : factory2.createNumericLiteral(constantValue); if (!compilerOptions.removeComments) { const originalNode = getOriginalNode(node, isAccessExpression); addSyntheticTrailingComment(substitute, 3 /* MultiLineCommentTrivia */, ` ${safeMultiLineComment(getTextOfNode(originalNode))} `); @@ -189600,8 +174051,9 @@ ${lanes.join("\n")} let pendingStatements; let lexicalEnvironment; const lexicalEnvironmentMap = /* @__PURE__ */ new Map(); + const noSubstitution = /* @__PURE__ */ new Set(); let currentClassContainer; - let currentStaticPropertyDeclarationOrStaticBlock; + let currentClassElement; let shouldSubstituteThisWithClassThis = false; let previousShouldSubstituteThisWithClassThis = false; return chainBundle(context, transformSourceFile); @@ -189633,76 +174085,77 @@ ${lanes.join("\n")} switch (node.kind) { case 129 /* AccessorKeyword */: return Debug.fail("Use `modifierVisitor` instead."); - case 262 /* ClassDeclaration */: + case 263 /* ClassDeclaration */: return visitClassDeclaration(node); - case 230 /* ClassExpression */: - return visitClassExpression( - node, - /*referencedName*/ - void 0 - ); - case 174 /* ClassStaticBlockDeclaration */: - case 171 /* PropertyDeclaration */: + case 231 /* ClassExpression */: + return visitClassExpression(node); + case 175 /* ClassStaticBlockDeclaration */: + case 172 /* PropertyDeclaration */: return Debug.fail("Use `classElementVisitor` instead."); - case 302 /* PropertyAssignment */: + case 303 /* PropertyAssignment */: return visitPropertyAssignment(node); - case 242 /* VariableStatement */: + case 243 /* VariableStatement */: return visitVariableStatement(node); - case 259 /* VariableDeclaration */: + case 260 /* VariableDeclaration */: return visitVariableDeclaration(node); - case 168 /* Parameter */: + case 169 /* Parameter */: return visitParameterDeclaration(node); - case 207 /* BindingElement */: + case 208 /* BindingElement */: return visitBindingElement(node); - case 276 /* ExportAssignment */: + case 277 /* ExportAssignment */: return visitExportAssignment(node); case 81 /* PrivateIdentifier */: return visitPrivateIdentifier(node); - case 210 /* PropertyAccessExpression */: + case 211 /* PropertyAccessExpression */: return visitPropertyAccessExpression(node); - case 211 /* ElementAccessExpression */: + case 212 /* ElementAccessExpression */: return visitElementAccessExpression(node); - case 223 /* PrefixUnaryExpression */: - case 224 /* PostfixUnaryExpression */: + case 224 /* PrefixUnaryExpression */: + case 225 /* PostfixUnaryExpression */: return visitPreOrPostfixUnaryExpression( node, /*discarded*/ false ); - case 225 /* BinaryExpression */: + case 226 /* BinaryExpression */: return visitBinaryExpression( node, /*discarded*/ false ); - case 216 /* ParenthesizedExpression */: + case 217 /* ParenthesizedExpression */: return visitParenthesizedExpression( node, /*discarded*/ - false, - /*referencedName*/ - void 0 + false ); - case 212 /* CallExpression */: + case 213 /* CallExpression */: return visitCallExpression(node); - case 243 /* ExpressionStatement */: + case 244 /* ExpressionStatement */: return visitExpressionStatement(node); - case 214 /* TaggedTemplateExpression */: + case 215 /* TaggedTemplateExpression */: return visitTaggedTemplateExpression(node); - case 247 /* ForStatement */: + case 248 /* ForStatement */: return visitForStatement(node); - case 261 /* FunctionDeclaration */: - case 217 /* FunctionExpression */: - case 175 /* Constructor */: - case 173 /* MethodDeclaration */: - case 176 /* GetAccessor */: - case 177 /* SetAccessor */: { - return setCurrentStaticPropertyDeclarationOrStaticBlockAnd( - /*current*/ + case 110 /* ThisKeyword */: + return visitThisExpression(node); + case 262 /* FunctionDeclaration */: + case 218 /* FunctionExpression */: + return setCurrentClassElementAnd( + /*classElement*/ void 0, fallbackVisitor, node ); + case 176 /* Constructor */: + case 174 /* MethodDeclaration */: + case 177 /* GetAccessor */: + case 178 /* SetAccessor */: { + return setCurrentClassElementAnd( + node, + fallbackVisitor, + node + ); } default: return fallbackVisitor(node); @@ -189711,56 +174164,32 @@ ${lanes.join("\n")} function fallbackVisitor(node) { return visitEachChild(node, visitor, context); } - function namedEvaluationVisitor(node, referencedName) { - switch (node.kind) { - case 359 /* PartiallyEmittedExpression */: - return visitPartiallyEmittedExpression( - node, - /*discarded*/ - false, - referencedName - ); - case 216 /* ParenthesizedExpression */: - return visitParenthesizedExpression( - node, - /*discarded*/ - false, - referencedName - ); - case 230 /* ClassExpression */: - return visitClassExpression(node, referencedName); - default: - return visitor(node); - } - } function discardedValueVisitor(node) { switch (node.kind) { - case 223 /* PrefixUnaryExpression */: - case 224 /* PostfixUnaryExpression */: + case 224 /* PrefixUnaryExpression */: + case 225 /* PostfixUnaryExpression */: return visitPreOrPostfixUnaryExpression( node, /*discarded*/ true ); - case 225 /* BinaryExpression */: + case 226 /* BinaryExpression */: return visitBinaryExpression( node, /*discarded*/ true ); - case 360 /* CommaListExpression */: + case 361 /* CommaListExpression */: return visitCommaListExpression( node, /*discarded*/ true ); - case 216 /* ParenthesizedExpression */: + case 217 /* ParenthesizedExpression */: return visitParenthesizedExpression( node, /*discarded*/ - true, - /*referencedName*/ - void 0 + true ); default: return visitor(node); @@ -189768,9 +174197,9 @@ ${lanes.join("\n")} } function heritageClauseVisitor(node) { switch (node.kind) { - case 297 /* HeritageClause */: + case 298 /* HeritageClause */: return visitEachChild(node, heritageClauseVisitor, context); - case 232 /* ExpressionWithTypeArguments */: + case 233 /* ExpressionWithTypeArguments */: return visitExpressionWithTypeArgumentsInHeritageClause(node); default: return visitor(node); @@ -189778,8 +174207,8 @@ ${lanes.join("\n")} } function assignmentTargetVisitor(node) { switch (node.kind) { - case 209 /* ObjectLiteralExpression */: - case 208 /* ArrayLiteralExpression */: + case 210 /* ObjectLiteralExpression */: + case 209 /* ArrayLiteralExpression */: return visitAssignmentPattern(node); default: return visitor(node); @@ -189787,29 +174216,35 @@ ${lanes.join("\n")} } function classElementVisitor(node) { switch (node.kind) { - case 175 /* Constructor */: - return visitConstructorDeclaration(node); - case 176 /* GetAccessor */: - case 177 /* SetAccessor */: - case 173 /* MethodDeclaration */: - return setCurrentStaticPropertyDeclarationOrStaticBlockAnd( - /*current*/ - void 0, + case 176 /* Constructor */: + return setCurrentClassElementAnd( + node, + visitConstructorDeclaration, + node + ); + case 177 /* GetAccessor */: + case 178 /* SetAccessor */: + case 174 /* MethodDeclaration */: + return setCurrentClassElementAnd( + node, visitMethodOrAccessorDeclaration, node ); - case 171 /* PropertyDeclaration */: - return setCurrentStaticPropertyDeclarationOrStaticBlockAnd( - /*current*/ - void 0, + case 172 /* PropertyDeclaration */: + return setCurrentClassElementAnd( + node, visitPropertyDeclaration, node ); - case 174 /* ClassStaticBlockDeclaration */: - return visitClassStaticBlockDeclaration(node); - case 166 /* ComputedPropertyName */: + case 175 /* ClassStaticBlockDeclaration */: + return setCurrentClassElementAnd( + node, + visitClassStaticBlockDeclaration, + node + ); + case 167 /* ComputedPropertyName */: return visitComputedPropertyName(node); - case 239 /* SemicolonClassElement */: + case 240 /* SemicolonClassElement */: return node; default: return isModifierLike(node) ? modifierVisitor(node) : visitor(node); @@ -189817,7 +174252,7 @@ ${lanes.join("\n")} } function propertyNameVisitor(node) { switch (node.kind) { - case 166 /* ComputedPropertyName */: + case 167 /* ComputedPropertyName */: return visitComputedPropertyName(node); default: return visitor(node); @@ -189825,10 +174260,10 @@ ${lanes.join("\n")} } function accessorFieldResultVisitor(node) { switch (node.kind) { - case 171 /* PropertyDeclaration */: + case 172 /* PropertyDeclaration */: return transformFieldInitializer(node); - case 176 /* GetAccessor */: - case 177 /* SetAccessor */: + case 177 /* GetAccessor */: + case 178 /* SetAccessor */: return classElementVisitor(node); default: Debug.assertMissingNode(node, "Expected node to either be a PropertyDeclaration, GetAccessorDeclaration, or SetAccessorDeclaration"); @@ -189857,9 +174292,7 @@ ${lanes.join("\n")} } function visitPropertyAssignment(node) { if (isNamedEvaluation(node, isAnonymousClassNeedingAssignedName)) { - const { referencedName, name } = visitReferencedPropertyName(node.name); - const initializer = visitNode(node.initializer, (node2) => namedEvaluationVisitor(node2, referencedName), isExpression); - return factory2.updatePropertyAssignment(node, name, initializer); + node = transformNamedEvaluation(context, node); } return visitEachChild(node, visitor, context); } @@ -189871,71 +174304,33 @@ ${lanes.join("\n")} pendingStatements = savedPendingStatements; return statement; } - function getAssignedNameOfIdentifier(name, initializer) { - const originalClass = getOriginalNode(initializer, isClassLike); - return originalClass && !originalClass.name && hasSyntacticModifier(originalClass, 1024 /* Default */) ? factory2.createStringLiteral("default") : factory2.createStringLiteralFromNode(name); - } function visitVariableDeclaration(node) { if (isNamedEvaluation(node, isAnonymousClassNeedingAssignedName)) { - const assignedName = getAssignedNameOfIdentifier(node.name, node.initializer); - const name = visitNode(node.name, visitor, isBindingName); - const initializer = visitNode(node.initializer, (node2) => namedEvaluationVisitor(node2, assignedName), isExpression); - return factory2.updateVariableDeclaration( - node, - name, - /*exclamationToken*/ - void 0, - /*type*/ - void 0, - initializer - ); + node = transformNamedEvaluation(context, node); } return visitEachChild(node, visitor, context); } function visitParameterDeclaration(node) { if (isNamedEvaluation(node, isAnonymousClassNeedingAssignedName)) { - const assignedName = getAssignedNameOfIdentifier(node.name, node.initializer); - const name = visitNode(node.name, visitor, isBindingName); - const initializer = visitNode(node.initializer, (node2) => namedEvaluationVisitor(node2, assignedName), isExpression); - return factory2.updateParameterDeclaration( - node, - /*modifiers*/ - void 0, - /*dotDotDotToken*/ - void 0, - name, - /*questionToken*/ - void 0, - /*type*/ - void 0, - initializer - ); + node = transformNamedEvaluation(context, node); } return visitEachChild(node, visitor, context); } function visitBindingElement(node) { if (isNamedEvaluation(node, isAnonymousClassNeedingAssignedName)) { - const assignedName = getAssignedNameOfIdentifier(node.name, node.initializer); - const propertyName = visitNode(node.propertyName, visitor, isPropertyName); - const name = visitNode(node.name, visitor, isBindingName); - const initializer = visitNode(node.initializer, (node2) => namedEvaluationVisitor(node2, assignedName), isExpression); - return factory2.updateBindingElement( - node, - /*dotDotDotToken*/ - void 0, - propertyName, - name, - initializer - ); + node = transformNamedEvaluation(context, node); } return visitEachChild(node, visitor, context); } function visitExportAssignment(node) { if (isNamedEvaluation(node, isAnonymousClassNeedingAssignedName)) { - const assignedName = factory2.createStringLiteral(node.isExportEquals ? "" : "default"); - const modifiers = visitNodes2(node.modifiers, modifierVisitor, isModifier); - const expression = visitNode(node.expression, (node2) => namedEvaluationVisitor(node2, assignedName), isExpression); - return factory2.updateExportAssignment(node, modifiers, expression); + node = transformNamedEvaluation( + context, + node, + /*ignoreEmptyStringLiteral*/ + true, + node.isExportEquals ? "" : "default" + ); } return visitEachChild(node, visitor, context); } @@ -190000,12 +174395,15 @@ ${lanes.join("\n")} } return void 0; } - function setCurrentStaticPropertyDeclarationOrStaticBlockAnd(current, visitor2, arg) { - const savedCurrentStaticPropertyDeclarationOrStaticBlock = currentStaticPropertyDeclarationOrStaticBlock; - currentStaticPropertyDeclarationOrStaticBlock = current; - const result = visitor2(arg); - currentStaticPropertyDeclarationOrStaticBlock = savedCurrentStaticPropertyDeclarationOrStaticBlock; - return result; + function setCurrentClassElementAnd(classElement, visitor2, arg) { + if (classElement !== currentClassElement) { + const savedCurrentClassElement = currentClassElement; + currentClassElement = classElement; + const result = visitor2(arg); + currentClassElement = savedCurrentClassElement; + return result; + } + return visitor2(arg); } function getHoistedFunctionName(node) { Debug.assert(isPrivateIdentifier(node.name)); @@ -190023,6 +174421,11 @@ ${lanes.join("\n")} } } } + function getClassThis() { + const lex = getClassLexicalEnvironment(); + const classThis = lex.classThis ?? lex.classConstructor ?? (currentClassContainer == null ? void 0 : currentClassContainer.name); + return Debug.checkDefined(classThis); + } function transformAutoAccessor(node) { const commentRange = getCommentRange(node); const sourceMapRange = getSourceMapRange(node); @@ -190049,11 +174452,13 @@ ${lanes.join("\n")} setOriginalNode(backingField, node); setEmitFlags(backingField, 3072 /* NoComments */); setSourceMapRange(backingField, sourceMapRange); - const getter = createAccessorPropertyGetRedirector(factory2, node, modifiers, getterName); + const receiver = isStatic(node) ? getClassThis() : factory2.createThis(); + const getter = createAccessorPropertyGetRedirector(factory2, node, modifiers, getterName, receiver); setOriginalNode(getter, node); setCommentRange(getter, commentRange); setSourceMapRange(getter, sourceMapRange); - const setter = createAccessorPropertySetRedirector(factory2, node, modifiers, setterName); + const setterModifiers = factory2.createModifiersFromModifierFlags(modifiersToFlags(modifiers)); + const setter = createAccessorPropertySetRedirector(factory2, node, setterModifiers, setterName, receiver); setOriginalNode(setter, node); setEmitFlags(setter, 3072 /* NoComments */); setSourceMapRange(setter, sourceMapRange); @@ -190092,17 +174497,7 @@ ${lanes.join("\n")} ); } if (isNamedEvaluation(node, isAnonymousClassNeedingAssignedName)) { - const { referencedName, name } = visitReferencedPropertyName(node.name); - return factory2.updatePropertyDeclaration( - node, - visitNodes2(node.modifiers, modifierVisitor, isModifier), - name, - /*questionOrExclamationToken*/ - void 0, - /*type*/ - void 0, - visitNode(node.initializer, (child) => namedEvaluationVisitor(child, referencedName), isExpression) - ); + node = transformNamedEvaluation(context, node); } return factory2.updatePropertyDeclaration( node, @@ -190120,9 +174515,7 @@ ${lanes.join("\n")} const expr = getPropertyNameExpressionIfNeeded( node.name, /*shouldHoist*/ - !!node.initializer || useDefineForClassFields, - /*captureReferencedName*/ - isNamedEvaluation(node, isAnonymousClassNeedingAssignedName) + !!node.initializer || useDefineForClassFields ); if (expr) { getPendingExpressions().push(...flattenCommaList(expr)); @@ -190167,8 +174560,21 @@ ${lanes.join("\n")} } return transformFieldInitializer(node); } + function shouldForceDynamicThis() { + return !!currentClassElement && hasStaticModifier(currentClassElement) && isAccessor(currentClassElement) && isAutoAccessorPropertyDeclaration(getOriginalNode(currentClassElement)); + } + function ensureDynamicThisIfNeeded(node) { + if (shouldForceDynamicThis()) { + const innerExpression = skipOuterExpressions(node); + if (innerExpression.kind === 110 /* ThisKeyword */) { + noSubstitution.add(innerExpression); + } + } + } function createPrivateIdentifierAccess(info, receiver) { - return createPrivateIdentifierAccessHelper(info, visitNode(receiver, visitor, isExpression)); + receiver = visitNode(receiver, visitor, isExpression); + ensureDynamicThisIfNeeded(receiver); + return createPrivateIdentifierAccessHelper(info, receiver); } function createPrivateIdentifierAccessHelper(info, receiver) { setCommentRange(receiver, moveRangePos(receiver, -1)); @@ -190213,7 +174619,7 @@ ${lanes.join("\n")} ); } } - if (shouldTransformSuperInStaticInitializers && isSuperProperty(node) && isIdentifier(node.name) && currentStaticPropertyDeclarationOrStaticBlock && (lexicalEnvironment == null ? void 0 : lexicalEnvironment.data)) { + if (shouldTransformSuperInStaticInitializers && currentClassElement && isSuperProperty(node) && isIdentifier(node.name) && isStaticPropertyDeclarationOrClassStaticBlock(currentClassElement) && (lexicalEnvironment == null ? void 0 : lexicalEnvironment.data)) { const { classConstructor, superClassReference, facts } = lexicalEnvironment.data; if (facts & 1 /* ClassWasDecorated */) { return visitInvalidSuperProperty(node); @@ -190232,7 +174638,7 @@ ${lanes.join("\n")} return visitEachChild(node, visitor, context); } function visitElementAccessExpression(node) { - if (shouldTransformSuperInStaticInitializers && isSuperProperty(node) && currentStaticPropertyDeclarationOrStaticBlock && (lexicalEnvironment == null ? void 0 : lexicalEnvironment.data)) { + if (shouldTransformSuperInStaticInitializers && currentClassElement && isSuperProperty(node) && isStaticPropertyDeclarationOrClassStaticBlock(currentClassElement) && (lexicalEnvironment == null ? void 0 : lexicalEnvironment.data)) { const { classConstructor, superClassReference, facts } = lexicalEnvironment.data; if (facts & 1 /* ClassWasDecorated */) { return visitInvalidSuperProperty(node); @@ -190257,6 +174663,7 @@ ${lanes.join("\n")} let info; if (info = accessPrivateIdentifier2(operand.name)) { const receiver = visitNode(operand.expression, visitor, isExpression); + ensureDynamicThisIfNeeded(receiver); const { readExpression, initializeExpression } = createCopiableReceiverExpr(receiver); let expression = createPrivateIdentifierAccess(info, readExpression); const temp = isPrefixUnaryExpression(node) || discarded ? void 0 : factory2.createTempVariable(hoistVariableDeclaration); @@ -190275,7 +174682,7 @@ ${lanes.join("\n")} } return expression; } - } else if (shouldTransformSuperInStaticInitializers && isSuperProperty(operand) && currentStaticPropertyDeclarationOrStaticBlock && (lexicalEnvironment == null ? void 0 : lexicalEnvironment.data)) { + } else if (shouldTransformSuperInStaticInitializers && currentClassElement && isSuperProperty(operand) && isStaticPropertyDeclarationOrClassStaticBlock(currentClassElement) && (lexicalEnvironment == null ? void 0 : lexicalEnvironment.data)) { const { classConstructor, superClassReference, facts } = lexicalEnvironment.data; if (facts & 1 /* ClassWasDecorated */) { const expression = visitInvalidSuperProperty(operand); @@ -190332,6 +174739,9 @@ ${lanes.join("\n")} } function createCopiableReceiverExpr(receiver) { const clone2 = nodeIsSynthesized(receiver) ? receiver : factory2.cloneNode(receiver); + if (receiver.kind === 110 /* ThisKeyword */ && noSubstitution.has(receiver)) { + noSubstitution.add(clone2); + } if (isSimpleInlineableExpression(receiver)) { return { readExpression: clone2, initializeExpression: void 0 }; } @@ -190362,7 +174772,7 @@ ${lanes.join("\n")} [visitNode(thisArg, visitor, isExpression), ...visitNodes2(node.arguments, visitor, isExpression)] ); } - if (shouldTransformSuperInStaticInitializers && isSuperProperty(node.expression) && currentStaticPropertyDeclarationOrStaticBlock && ((_a = lexicalEnvironment == null ? void 0 : lexicalEnvironment.data) == null ? void 0 : _a.classConstructor)) { + if (shouldTransformSuperInStaticInitializers && currentClassElement && isSuperProperty(node.expression) && isStaticPropertyDeclarationOrClassStaticBlock(currentClassElement) && ((_a = lexicalEnvironment == null ? void 0 : lexicalEnvironment.data) == null ? void 0 : _a.classConstructor)) { const invocation = factory2.createFunctionCallCall( visitNode(node.expression, visitor, isExpression), lexicalEnvironment.data.classConstructor, @@ -190391,7 +174801,7 @@ ${lanes.join("\n")} visitNode(node.template, visitor, isTemplateLiteral) ); } - if (shouldTransformSuperInStaticInitializers && isSuperProperty(node.tag) && currentStaticPropertyDeclarationOrStaticBlock && ((_a = lexicalEnvironment == null ? void 0 : lexicalEnvironment.data) == null ? void 0 : _a.classConstructor)) { + if (shouldTransformSuperInStaticInitializers && currentClassElement && isSuperProperty(node.tag) && isStaticPropertyDeclarationOrClassStaticBlock(currentClassElement) && ((_a = lexicalEnvironment == null ? void 0 : lexicalEnvironment.data) == null ? void 0 : _a.classConstructor)) { const invocation = factory2.createFunctionBindCall( visitNode(node.tag, visitor, isExpression), lexicalEnvironment.data.classConstructor, @@ -190414,30 +174824,40 @@ ${lanes.join("\n")} lexicalEnvironmentMap.set(getOriginalNode(node), lexicalEnvironment); } if (shouldTransformPrivateElementsOrClassStaticBlocks) { + if (isClassThisAssignmentBlock(node)) { + const result = visitNode(node.body.statements[0].expression, visitor, isExpression); + if (isAssignmentExpression( + result, + /*excludeCompoundAssignment*/ + true + ) && result.left === result.right) { + return void 0; + } + return result; + } + if (isClassNamedEvaluationHelperBlock(node)) { + return visitNode(node.body.statements[0].expression, visitor, isExpression); + } startLexicalEnvironment(); - let statements = setCurrentStaticPropertyDeclarationOrStaticBlockAnd( + let statements = setCurrentClassElementAnd( node, (statements2) => visitNodes2(statements2, visitor, isStatement), node.body.statements ); statements = factory2.mergeLexicalEnvironment(statements, endLexicalEnvironment()); const iife = factory2.createImmediatelyInvokedArrowFunction(statements); + setOriginalNode(skipParentheses(iife.expression), node); + addEmitFlags(skipParentheses(iife.expression), 4 /* AdviseOnEmitNode */); setOriginalNode(iife, node); setTextRange(iife, node); - addEmitFlags(iife, 4 /* AdviseOnEmitNode */); return iife; } } function isAnonymousClassNeedingAssignedName(node) { if (isClassExpression(node) && !node.name) { const staticPropertiesOrClassStaticBlocks = getStaticPropertiesAndClassStaticBlock(node); - const classStaticBlock = find(staticPropertiesOrClassStaticBlocks, isClassStaticBlockDeclaration); - if (classStaticBlock) { - for (const statement of classStaticBlock.body.statements) { - if (isExpressionStatement(statement) && isCallToHelper(statement.expression, "___setFunctionName")) { - return false; - } - } + if (some(staticPropertiesOrClassStaticBlocks, isClassNamedEvaluationHelperBlock)) { + return false; } const hasTransformableStatics = (shouldTransformPrivateElementsOrClassStaticBlocks || !!(getInternalEmitFlags(node) && 32 /* TransformPrivateStaticElements */)) && some(staticPropertiesOrClassStaticBlocks, (node2) => isClassStaticBlockDeclaration(node2) || isPrivateIdentifierClassElementDeclaration(node2) || shouldTransformInitializers && isInitializedProperty(node2)); return hasTransformableStatics; @@ -190460,10 +174880,8 @@ ${lanes.join("\n")} } if (isAssignmentExpression(node)) { if (isNamedEvaluation(node, isAnonymousClassNeedingAssignedName)) { - const assignedName = getAssignedNameOfIdentifier(node.left, node.right); - const left2 = visitNode(node.left, visitor, isExpression); - const right = visitNode(node.right, (node2) => namedEvaluationVisitor(node2, assignedName), isExpression); - return factory2.updateBinaryExpression(node, left2, node.operatorToken, right); + node = transformNamedEvaluation(context, node); + Debug.assertNode(node, isAssignmentExpression); } const left = skipOuterExpressions(node.left, 8 /* PartiallyEmittedExpressions */ | 1 /* Parentheses */); if (isPrivateIdentifierPropertyAccessExpression(left)) { @@ -190477,7 +174895,7 @@ ${lanes.join("\n")} node ); } - } else if (shouldTransformSuperInStaticInitializers && isSuperProperty(node.left) && currentStaticPropertyDeclarationOrStaticBlock && (lexicalEnvironment == null ? void 0 : lexicalEnvironment.data)) { + } else if (shouldTransformSuperInStaticInitializers && currentClassElement && isSuperProperty(node.left) && isStaticPropertyDeclarationOrClassStaticBlock(currentClassElement) && (lexicalEnvironment == null ? void 0 : lexicalEnvironment.data)) { const { classConstructor, superClassReference, facts } = lexicalEnvironment.data; if (facts & 1 /* ClassWasDecorated */) { return factory2.updateBinaryExpression( @@ -190542,36 +174960,15 @@ ${lanes.join("\n")} const elements = discarded ? visitCommaListElements(node.elements, discardedValueVisitor) : visitCommaListElements(node.elements, visitor, discardedValueVisitor); return factory2.updateCommaListExpression(node, elements); } - function visitParenthesizedExpression(node, discarded, referencedName) { - const visitorFunc = discarded ? discardedValueVisitor : referencedName ? (node2) => namedEvaluationVisitor(node2, referencedName) : visitor; + function visitParenthesizedExpression(node, discarded) { + const visitorFunc = discarded ? discardedValueVisitor : visitor; const expression = visitNode(node.expression, visitorFunc, isExpression); return factory2.updateParenthesizedExpression(node, expression); } - function visitPartiallyEmittedExpression(node, discarded, referencedName) { - const visitorFunc = discarded ? discardedValueVisitor : referencedName ? (node2) => namedEvaluationVisitor(node2, referencedName) : visitor; - const expression = visitNode(node.expression, visitorFunc, isExpression); - return factory2.updatePartiallyEmittedExpression(node, expression); - } - function visitReferencedPropertyName(node) { - if (isPropertyNameLiteral(node) || isPrivateIdentifier(node)) { - const referencedName2 = factory2.createStringLiteralFromNode(node); - const name2 = visitNode(node, visitor, isPropertyName); - return { referencedName: referencedName2, name: name2 }; - } - if (isPropertyNameLiteral(node.expression) && !isIdentifier(node.expression)) { - const referencedName2 = factory2.createStringLiteralFromNode(node.expression); - const name2 = visitNode(node, visitor, isPropertyName); - return { referencedName: referencedName2, name: name2 }; - } - const referencedName = factory2.createTempVariable(hoistVariableDeclaration); - const key = emitHelpers().createPropKeyHelper(visitNode(node.expression, visitor, isExpression)); - const assignment = factory2.createAssignment(referencedName, key); - const name = factory2.updateComputedPropertyName(node, injectPendingExpressions(assignment)); - return { referencedName, name }; - } function createPrivateIdentifierAssignment(info, receiver, right, operator) { receiver = visitNode(receiver, visitor, isExpression); right = visitNode(right, visitor, isExpression); + ensureDynamicThisIfNeeded(receiver); if (isCompoundAssignment(operator)) { const { readExpression, initializeExpression } = createCopiableReceiverExpr(receiver); receiver = initializeExpression || readExpression; @@ -190618,11 +175015,15 @@ ${lanes.join("\n")} return filter(node.members, isNonStaticMethodOrAccessorWithPrivateName); } function getClassFacts(node) { + var _a; let facts = 0 /* None */; const original = getOriginalNode(node); if (isClassDeclaration(original) && classOrConstructorParameterIsDecorated(legacyDecorators, original)) { facts |= 1 /* ClassWasDecorated */; } + if (shouldTransformPrivateElementsOrClassStaticBlocks && (classHasClassThisAssignment(node) || classHasExplicitlyAssignedName(node))) { + facts |= 2 /* NeedsClassConstructorReference */; + } let containsPublicInstanceFields = false; let containsInitializedPublicInstanceFields = false; let containsInstancePrivateElements = false; @@ -190631,6 +175032,8 @@ ${lanes.join("\n")} if (isStatic(member)) { if (member.name && (isPrivateIdentifier(member.name) || isAutoAccessorPropertyDeclaration(member)) && shouldTransformPrivateElementsOrClassStaticBlocks) { facts |= 2 /* NeedsClassConstructorReference */; + } else if (isAutoAccessorPropertyDeclaration(member) && shouldTransformAutoAccessors === -1 /* True */ && !node.name && !((_a = node.emitNode) == null ? void 0 : _a.classThis)) { + facts |= 2 /* NeedsClassConstructorReference */; } if (isPropertyDeclaration(member) || isClassStaticBlockDeclaration(member)) { if (shouldTransformThisInStaticInitializers && member.transformFlags & 16384 /* ContainsLexicalThis */) { @@ -190651,6 +175054,9 @@ ${lanes.join("\n")} containsInstancePrivateElements || (containsInstancePrivateElements = isPrivateIdentifierClassElementDeclaration(member)); } else if (isPrivateIdentifierClassElementDeclaration(member)) { containsInstancePrivateElements = true; + if (resolver.getNodeCheckFlags(member) & 262144 /* ContainsConstructorReference */) { + facts |= 2 /* NeedsClassConstructorReference */; + } } else if (isPropertyDeclaration(member)) { containsPublicInstanceFields = true; containsInitializedPublicInstanceFields || (containsInitializedPublicInstanceFields = !!member.initializer); @@ -190685,7 +175091,8 @@ ${lanes.join("\n")} } return visitEachChild(node, visitor, context); } - function visitInNewClassLexicalEnvironment(node, referencedName, visitor2) { + function visitInNewClassLexicalEnvironment(node, visitor2) { + var _a; const savedCurrentClassContainer = currentClassContainer; const savedPendingExpressions = pendingExpressions; const savedLexicalEnvironment = lexicalEnvironment; @@ -190697,6 +175104,15 @@ ${lanes.join("\n")} const name = getNameOfDeclaration(node); if (name && isIdentifier(name)) { getPrivateIdentifierEnvironment().data.className = name; + } else if ((_a = node.emitNode) == null ? void 0 : _a.assignedName) { + if (isStringLiteral(node.emitNode.assignedName)) { + if (node.emitNode.assignedName.textSourceNode && isIdentifier(node.emitNode.assignedName.textSourceNode)) { + getPrivateIdentifierEnvironment().data.className = node.emitNode.assignedName.textSourceNode; + } else if (isIdentifierText(node.emitNode.assignedName.text, languageVersion)) { + const prefixName = factory2.createIdentifier(node.emitNode.assignedName.text); + getPrivateIdentifierEnvironment().data.className = prefixName; + } + } } } if (shouldTransformPrivateElementsOrClassStaticBlocks) { @@ -190715,7 +175131,7 @@ ${lanes.join("\n")} if (facts & 8 /* NeedsSubstitutionForThisInClassStaticField */) { enableSubstitutionForClassStaticThisOrSuperReference(); } - const result = visitor2(node, facts, referencedName); + const result = visitor2(node, facts); endClassLexicalEnvironment(); Debug.assert(lexicalEnvironment === savedLexicalEnvironment); currentClassContainer = savedCurrentClassContainer; @@ -190723,12 +175139,7 @@ ${lanes.join("\n")} return result; } function visitClassDeclaration(node) { - return visitInNewClassLexicalEnvironment( - node, - /*referencedName*/ - void 0, - visitClassDeclarationInNewClassLexicalEnvironment - ); + return visitInNewClassLexicalEnvironment(node, visitClassDeclarationInNewClassLexicalEnvironment); } function visitClassDeclarationInNewClassLexicalEnvironment(node, facts) { var _a, _b; @@ -190746,12 +175157,13 @@ ${lanes.join("\n")} getClassLexicalEnvironment().classConstructor = factory2.cloneNode(temp); pendingClassReferenceAssignment = factory2.createAssignment(temp, factory2.getInternalName(node)); } - if ((_b = node.emitNode) == null ? void 0 : _b.classThis) { - getClassLexicalEnvironment().classThis = node.emitNode.classThis; - } } - const isExport = hasSyntacticModifier(node, 1 /* Export */); - const isDefault = hasSyntacticModifier(node, 1024 /* Default */); + if ((_b = node.emitNode) == null ? void 0 : _b.classThis) { + getClassLexicalEnvironment().classThis = node.emitNode.classThis; + } + const isClassWithConstructorReference = resolver.getNodeCheckFlags(node) & 262144 /* ContainsConstructorReference */; + const isExport = hasSyntacticModifier(node, 32 /* Export */); + const isDefault = hasSyntacticModifier(node, 2048 /* Default */); let modifiers = visitNodes2(node.modifiers, modifierVisitor, isModifier); const heritageClauses = visitNodes2(node.heritageClauses, heritageClauseVisitor, isHeritageClause); const { members, prologue } = transformClassMembers(node); @@ -190784,6 +175196,11 @@ ${lanes.join("\n")} ) )); } + const alias = getClassLexicalEnvironment().classConstructor; + if (isClassWithConstructorReference && alias) { + enableSubstitutionForClassAliases(); + classAliases[getOriginalNodeId(node)] = alias; + } const classDecl = factory2.updateClassDeclaration( node, modifiers, @@ -190799,24 +175216,27 @@ ${lanes.join("\n")} } return statements; } - function visitClassExpression(node, referencedName) { - return visitInNewClassLexicalEnvironment(node, referencedName, visitClassExpressionInNewClassLexicalEnvironment); + function visitClassExpression(node) { + return visitInNewClassLexicalEnvironment(node, visitClassExpressionInNewClassLexicalEnvironment); } - function visitClassExpressionInNewClassLexicalEnvironment(node, facts, referencedName) { - var _a, _b, _c, _d; + function visitClassExpressionInNewClassLexicalEnvironment(node, facts) { + var _a, _b, _c; const isDecoratedClassDeclaration = !!(facts & 1 /* ClassWasDecorated */); const staticPropertiesOrClassStaticBlocks = getStaticPropertiesAndClassStaticBlock(node); - const isClassWithConstructorReference = resolver.getNodeCheckFlags(node) & 1048576 /* ClassWithConstructorReference */; + const classCheckFlags = resolver.getNodeCheckFlags(node); + const isClassWithConstructorReference = classCheckFlags & 262144 /* ContainsConstructorReference */; let temp; function createClassTempVar() { var _a2; if (shouldTransformPrivateElementsOrClassStaticBlocks && ((_a2 = node.emitNode) == null ? void 0 : _a2.classThis)) { return getClassLexicalEnvironment().classConstructor = node.emitNode.classThis; } - const classCheckFlags = resolver.getNodeCheckFlags(node); - const isClassWithConstructorReference2 = classCheckFlags & 1048576 /* ClassWithConstructorReference */; const requiresBlockScopedVar = classCheckFlags & 32768 /* BlockScopedBindingInLoop */; - const temp2 = factory2.createTempVariable(requiresBlockScopedVar ? addBlockScopedVariable : hoistVariableDeclaration, !!isClassWithConstructorReference2); + const temp2 = factory2.createTempVariable( + requiresBlockScopedVar ? addBlockScopedVariable : hoistVariableDeclaration, + /*reservedInNestedScopes*/ + true + ); getClassLexicalEnvironment().classConstructor = factory2.cloneNode(temp2); return temp2; } @@ -190829,7 +175249,7 @@ ${lanes.join("\n")} const modifiers = visitNodes2(node.modifiers, modifierVisitor, isModifier); const heritageClauses = visitNodes2(node.heritageClauses, heritageClauseVisitor, isHeritageClause); const { members, prologue } = transformClassMembers(node); - let classExpression = factory2.updateClassExpression( + const classExpression = factory2.updateClassExpression( node, modifiers, node.name, @@ -190843,41 +175263,18 @@ ${lanes.join("\n")} expressions.push(prologue); } const hasTransformableStatics = (shouldTransformPrivateElementsOrClassStaticBlocks || getInternalEmitFlags(node) & 32 /* TransformPrivateStaticElements */) && some(staticPropertiesOrClassStaticBlocks, (node2) => isClassStaticBlockDeclaration(node2) || isPrivateIdentifierClassElementDeclaration(node2) || shouldTransformInitializers && isInitializedProperty(node2)); - if (hasTransformableStatics || some(pendingExpressions) || referencedName) { + if (hasTransformableStatics || some(pendingExpressions)) { if (isDecoratedClassDeclaration) { Debug.assertIsDefined(pendingStatements, "Decorated classes transformed by TypeScript are expected to be within a variable declaration."); if (some(pendingExpressions)) { addRange(pendingStatements, map(pendingExpressions, factory2.createExpressionStatement)); } - if (referencedName) { - if (shouldTransformPrivateElementsOrClassStaticBlocks) { - const setNameExpression = emitHelpers().createSetFunctionNameHelper(temp ?? ((_b = node.emitNode) == null ? void 0 : _b.classThis) ?? factory2.getInternalName(node), referencedName); - pendingStatements.push(factory2.createExpressionStatement(setNameExpression)); - } else { - const setNameExpression = emitHelpers().createSetFunctionNameHelper(factory2.createThis(), referencedName); - classExpression = factory2.updateClassExpression( - classExpression, - classExpression.modifiers, - classExpression.name, - classExpression.typeParameters, - classExpression.heritageClauses, - [ - factory2.createClassStaticBlockDeclaration( - factory2.createBlock([ - factory2.createExpressionStatement(setNameExpression) - ]) - ), - ...classExpression.members - ] - ); - } - } if (some(staticPropertiesOrClassStaticBlocks)) { - addPropertyOrClassStaticBlockStatements(pendingStatements, staticPropertiesOrClassStaticBlocks, ((_c = node.emitNode) == null ? void 0 : _c.classThis) ?? factory2.getInternalName(node)); + addPropertyOrClassStaticBlockStatements(pendingStatements, staticPropertiesOrClassStaticBlocks, ((_b = node.emitNode) == null ? void 0 : _b.classThis) ?? factory2.getInternalName(node)); } if (temp) { expressions.push(factory2.createAssignment(temp, classExpression)); - } else if (shouldTransformPrivateElementsOrClassStaticBlocks && ((_d = node.emitNode) == null ? void 0 : _d.classThis)) { + } else if (shouldTransformPrivateElementsOrClassStaticBlocks && ((_c = node.emitNode) == null ? void 0 : _c.classThis)) { expressions.push(factory2.createAssignment(node.emitNode.classThis, classExpression)); } else { expressions.push(classExpression); @@ -190892,9 +175289,6 @@ ${lanes.join("\n")} } expressions.push(factory2.createAssignment(temp, classExpression)); addRange(expressions, pendingExpressions); - if (referencedName) { - expressions.push(emitHelpers().createSetFunctionNameHelper(temp, referencedName)); - } addRange(expressions, generateInitializedPropertyExpressionsOrClassStaticBlock(staticPropertiesOrClassStaticBlocks, temp)); expressions.push(factory2.cloneNode(temp)); } @@ -190913,6 +175307,13 @@ ${lanes.join("\n")} } return void 0; } + function visitThisExpression(node) { + if (shouldTransformThisInStaticInitializers && currentClassElement && isClassStaticBlockDeclaration(currentClassElement) && (lexicalEnvironment == null ? void 0 : lexicalEnvironment.data)) { + const { classThis, classConstructor } = lexicalEnvironment.data; + return classThis ?? classConstructor ?? node; + } + return node; + } function transformClassMembers(node) { const shouldTransformPrivateStaticElementsInClass = !!(getInternalEmitFlags(node) & 32 /* TransformPrivateStaticElements */); if (shouldTransformPrivateElementsOrClassStaticBlocks || shouldTransformPrivateStaticElementsInFile) { @@ -190992,9 +175393,14 @@ ${lanes.join("\n")} } if (syntheticConstructor || syntheticStaticBlock) { let membersArray; + const classThisAssignmentBlock = find(members, isClassThisAssignmentBlock); + const classNamedEvaluationHelperBlock = find(members, isClassNamedEvaluationHelperBlock); + membersArray = append(membersArray, classThisAssignmentBlock); + membersArray = append(membersArray, classNamedEvaluationHelperBlock); membersArray = append(membersArray, syntheticConstructor); membersArray = append(membersArray, syntheticStaticBlock); - membersArray = addRange(membersArray, members); + const remainingMembers = classThisAssignmentBlock || classNamedEvaluationHelperBlock ? filter(members, (member) => member !== classThisAssignmentBlock && member !== classNamedEvaluationHelperBlock) : members; + membersArray = addRange(membersArray, remainingMembers); members = setTextRange( factory2.createNodeArray(membersArray), /*location*/ @@ -191055,8 +175461,46 @@ ${lanes.join("\n")} ) ); } + function transformConstructorBodyWorker(statementsOut, statementsIn, statementOffset, superPath, superPathDepth, initializerStatements, constructor) { + const superStatementIndex = superPath[superPathDepth]; + const superStatement = statementsIn[superStatementIndex]; + addRange(statementsOut, visitNodes2(statementsIn, visitor, isStatement, statementOffset, superStatementIndex - statementOffset)); + statementOffset = superStatementIndex + 1; + if (isTryStatement(superStatement)) { + const tryBlockStatements = []; + transformConstructorBodyWorker( + tryBlockStatements, + superStatement.tryBlock.statements, + /*statementOffset*/ + 0, + superPath, + superPathDepth + 1, + initializerStatements, + constructor + ); + const tryBlockStatementsArray = factory2.createNodeArray(tryBlockStatements); + setTextRange(tryBlockStatementsArray, superStatement.tryBlock.statements); + statementsOut.push(factory2.updateTryStatement( + superStatement, + factory2.updateBlock(superStatement.tryBlock, tryBlockStatements), + visitNode(superStatement.catchClause, visitor, isCatchClause), + visitNode(superStatement.finallyBlock, visitor, isBlock) + )); + } else { + addRange(statementsOut, visitNodes2(statementsIn, visitor, isStatement, superStatementIndex, 1)); + while (statementOffset < statementsIn.length) { + const statement = statementsIn[statementOffset]; + if (isParameterPropertyDeclaration(getOriginalNode(statement), constructor)) { + statementOffset++; + } else { + break; + } + } + addRange(statementsOut, initializerStatements); + } + addRange(statementsOut, visitNodes2(statementsIn, visitor, isStatement, statementOffset)); + } function transformConstructorBody(node, constructor, isDerivedClass) { - var _a; const instanceProperties = getProperties( node, /*requireInitializer*/ @@ -191080,68 +175524,65 @@ ${lanes.join("\n")} } resumeLexicalEnvironment(); const needsSyntheticConstructor = !constructor && isDerivedClass; - let indexOfFirstStatementAfterSuperAndPrologue = 0; - let prologueStatementCount = 0; - let superStatementIndex = -1; + let statementOffset = 0; let statements = []; - if ((_a = constructor == null ? void 0 : constructor.body) == null ? void 0 : _a.statements) { - prologueStatementCount = factory2.copyPrologue( + const initializerStatements = []; + const receiver = factory2.createThis(); + addInstanceMethodStatements(initializerStatements, privateMethodsAndAccessors, receiver); + if (constructor) { + const parameterProperties = filter(instanceProperties, (prop) => isParameterPropertyDeclaration(getOriginalNode(prop), constructor)); + const nonParameterProperties = filter(properties, (prop) => !isParameterPropertyDeclaration(getOriginalNode(prop), constructor)); + addPropertyOrClassStaticBlockStatements(initializerStatements, parameterProperties, receiver); + addPropertyOrClassStaticBlockStatements(initializerStatements, nonParameterProperties, receiver); + } else { + addPropertyOrClassStaticBlockStatements(initializerStatements, properties, receiver); + } + if (constructor == null ? void 0 : constructor.body) { + statementOffset = factory2.copyPrologue( constructor.body.statements, statements, /*ensureUseStrict*/ false, visitor ); - superStatementIndex = findSuperStatementIndex(constructor.body.statements, prologueStatementCount); - if (superStatementIndex >= 0) { - indexOfFirstStatementAfterSuperAndPrologue = superStatementIndex + 1; - statements = [ - ...statements.slice(0, prologueStatementCount), - ...visitNodes2(constructor.body.statements, visitor, isStatement, prologueStatementCount, indexOfFirstStatementAfterSuperAndPrologue - prologueStatementCount), - ...statements.slice(prologueStatementCount) - ]; - } else if (prologueStatementCount >= 0) { - indexOfFirstStatementAfterSuperAndPrologue = prologueStatementCount; - } - } - if (needsSyntheticConstructor) { - statements.push( - factory2.createExpressionStatement( - factory2.createCallExpression( - factory2.createSuper(), - /*typeArguments*/ - void 0, - [factory2.createSpreadElement(factory2.createIdentifier("arguments"))] - ) - ) - ); - } - let parameterPropertyDeclarationCount = 0; - if (constructor == null ? void 0 : constructor.body) { - for (let i = indexOfFirstStatementAfterSuperAndPrologue; i < constructor.body.statements.length; i++) { - const statement = constructor.body.statements[i]; - if (isParameterPropertyDeclaration(getOriginalNode(statement), constructor)) { - parameterPropertyDeclarationCount++; - } else { - break; + const superStatementIndices = findSuperStatementIndexPath(constructor.body.statements, statementOffset); + if (superStatementIndices.length) { + transformConstructorBodyWorker( + statements, + constructor.body.statements, + statementOffset, + superStatementIndices, + /*superPathDepth*/ + 0, + initializerStatements, + constructor + ); + } else { + while (statementOffset < constructor.body.statements.length) { + const statement = constructor.body.statements[statementOffset]; + if (isParameterPropertyDeclaration(getOriginalNode(statement), constructor)) { + statementOffset++; + } else { + break; + } } + addRange(statements, initializerStatements); + addRange(statements, visitNodes2(constructor.body.statements, visitor, isStatement, statementOffset)); } - if (parameterPropertyDeclarationCount > 0) { - indexOfFirstStatementAfterSuperAndPrologue += parameterPropertyDeclarationCount; - } - } - const receiver = factory2.createThis(); - addInstanceMethodStatements(statements, privateMethodsAndAccessors, receiver); - if (constructor) { - const parameterProperties = filter(instanceProperties, (prop) => isParameterPropertyDeclaration(getOriginalNode(prop), constructor)); - const nonParameterProperties = filter(properties, (prop) => !isParameterPropertyDeclaration(getOriginalNode(prop), constructor)); - addPropertyOrClassStaticBlockStatements(statements, parameterProperties, receiver); - addPropertyOrClassStaticBlockStatements(statements, nonParameterProperties, receiver); } else { - addPropertyOrClassStaticBlockStatements(statements, properties, receiver); - } - if (constructor) { - addRange(statements, visitNodes2(constructor.body.statements, visitor, isStatement, indexOfFirstStatementAfterSuperAndPrologue)); + if (needsSyntheticConstructor) { + statements.push( + factory2.createExpressionStatement( + factory2.createCallExpression( + factory2.createSuper(), + /*typeArguments*/ + void 0, + [factory2.createSpreadElement(factory2.createIdentifier("arguments"))] + ) + ) + ); + } + addRange(statements, initializerStatements); } statements = factory2.mergeLexicalEnvironment(statements, endLexicalEnvironment()); if (statements.length === 0 && !constructor) { @@ -191174,7 +175615,7 @@ ${lanes.join("\n")} } } function transformPropertyOrClassStaticBlock(property, receiver) { - const expression = isClassStaticBlockDeclaration(property) ? transformClassStaticBlockDeclaration(property) : transformProperty(property, receiver); + const expression = isClassStaticBlockDeclaration(property) ? setCurrentClassElementAnd(property, transformClassStaticBlockDeclaration, property) : transformProperty(property, receiver); if (!expression) { return void 0; } @@ -191199,7 +175640,12 @@ ${lanes.join("\n")} function generateInitializedPropertyExpressionsOrClassStaticBlock(propertiesOrClassStaticBlocks, receiver) { const expressions = []; for (const property of propertiesOrClassStaticBlocks) { - const expression = isClassStaticBlockDeclaration(property) ? transformClassStaticBlockDeclaration(property) : transformProperty(property, receiver); + const expression = isClassStaticBlockDeclaration(property) ? setCurrentClassElementAnd(property, transformClassStaticBlockDeclaration, property) : setCurrentClassElementAnd( + property, + () => transformProperty(property, receiver), + /*arg*/ + void 0 + ); if (!expression) { continue; } @@ -191214,7 +175660,7 @@ ${lanes.join("\n")} } function transformProperty(property, receiver) { var _a; - const savedCurrentStaticPropertyDeclarationOrStaticBlock = currentStaticPropertyDeclarationOrStaticBlock; + const savedCurrentClassElement = currentClassElement; const transformed = transformPropertyWorker(property, receiver); if (transformed && hasStaticModifier(property) && ((_a = lexicalEnvironment == null ? void 0 : lexicalEnvironment.data) == null ? void 0 : _a.facts)) { setOriginalNode(transformed, property); @@ -191222,26 +175668,18 @@ ${lanes.join("\n")} setSourceMapRange(transformed, getSourceMapRange(property.name)); lexicalEnvironmentMap.set(getOriginalNode(property), lexicalEnvironment); } - currentStaticPropertyDeclarationOrStaticBlock = savedCurrentStaticPropertyDeclarationOrStaticBlock; + currentClassElement = savedCurrentClassElement; return transformed; } function transformPropertyWorker(property, receiver) { const emitAssignment = !useDefineForClassFields; - let referencedName; if (isNamedEvaluation(property, isAnonymousClassNeedingAssignedName)) { - if (isPropertyNameLiteral(property.name) || isPrivateIdentifier(property.name)) { - referencedName = factory2.createStringLiteralFromNode(property.name); - } else if (isPropertyNameLiteral(property.name.expression) && !isIdentifier(property.name.expression)) { - referencedName = factory2.createStringLiteralFromNode(property.name.expression); - } else { - referencedName = factory2.getGeneratedNameForNode(property.name); - } + property = transformNamedEvaluation(context, property); } const propertyName = hasAccessorModifier(property) ? factory2.getGeneratedPrivateNameForNode(property.name) : isComputedPropertyName(property.name) && !isSimpleInlineableExpression(property.name.expression) ? factory2.updateComputedPropertyName(property.name, factory2.getGeneratedNameForNode(property.name)) : property.name; if (hasStaticModifier(property)) { - currentStaticPropertyDeclarationOrStaticBlock = property; + currentClassElement = property; } - const initializerVisitor = referencedName ? (child) => namedEvaluationVisitor(child, referencedName) : visitor; if (isPrivateIdentifier(propertyName) && shouldTransformClassElementToWeakMap(property)) { const privateIdentifierInfo = accessPrivateIdentifier2(propertyName); if (privateIdentifierInfo) { @@ -191250,14 +175688,14 @@ ${lanes.join("\n")} return createPrivateInstanceFieldInitializer( factory2, receiver, - visitNode(property.initializer, initializerVisitor, isExpression), + visitNode(property.initializer, visitor, isExpression), privateIdentifierInfo.brandCheckIdentifier ); } else { return createPrivateStaticFieldInitializer( factory2, privateIdentifierInfo.variableName, - visitNode(property.initializer, initializerVisitor, isExpression) + visitNode(property.initializer, visitor, isExpression) ); } } else { @@ -191271,10 +175709,10 @@ ${lanes.join("\n")} return void 0; } const propertyOriginalNode = getOriginalNode(property); - if (hasSyntacticModifier(propertyOriginalNode, 256 /* Abstract */)) { + if (hasSyntacticModifier(propertyOriginalNode, 64 /* Abstract */)) { return void 0; } - let initializer = visitNode(property.initializer, initializerVisitor, isExpression); + let initializer = visitNode(property.initializer, visitor, isExpression); if (isParameterPropertyDeclaration(propertyOriginalNode, propertyOriginalNode.parent) && isIdentifier(propertyName)) { const localName = factory2.cloneNode(propertyName); if (initializer) { @@ -191319,14 +175757,14 @@ ${lanes.join("\n")} if ((enabledSubstitutions & 2 /* ClassStaticThisOrSuperReference */) === 0) { enabledSubstitutions |= 2 /* ClassStaticThisOrSuperReference */; context.enableSubstitution(110 /* ThisKeyword */); - context.enableEmitNotification(261 /* FunctionDeclaration */); - context.enableEmitNotification(217 /* FunctionExpression */); - context.enableEmitNotification(175 /* Constructor */); - context.enableEmitNotification(176 /* GetAccessor */); - context.enableEmitNotification(177 /* SetAccessor */); - context.enableEmitNotification(173 /* MethodDeclaration */); - context.enableEmitNotification(171 /* PropertyDeclaration */); - context.enableEmitNotification(166 /* ComputedPropertyName */); + context.enableEmitNotification(262 /* FunctionDeclaration */); + context.enableEmitNotification(218 /* FunctionExpression */); + context.enableEmitNotification(176 /* Constructor */); + context.enableEmitNotification(177 /* GetAccessor */); + context.enableEmitNotification(178 /* SetAccessor */); + context.enableEmitNotification(174 /* MethodDeclaration */); + context.enableEmitNotification(172 /* PropertyDeclaration */); + context.enableEmitNotification(167 /* ComputedPropertyName */); } } function addInstanceMethodStatements(statements, methods, receiver) { @@ -191352,10 +175790,10 @@ ${lanes.join("\n")} visitNode(node.argumentExpression, visitor, isExpression) ); } - function getPropertyNameExpressionIfNeeded(name, shouldHoist, captureReferencedName) { + function getPropertyNameExpressionIfNeeded(name, shouldHoist) { if (isComputedPropertyName(name)) { const cacheAssignment = findComputedPropertyNameCacheAssignment(name); - let expression = visitNode(name.expression, visitor, isExpression); + const expression = visitNode(name.expression, visitor, isExpression); const innerExpression = skipPartiallyEmittedExpressions(expression); const inlinable = isSimpleInlineableExpression(innerExpression); const alreadyTransformed = !!cacheAssignment || isAssignmentExpression(innerExpression) && isGeneratedIdentifier(innerExpression.left); @@ -191366,9 +175804,6 @@ ${lanes.join("\n")} } else { hoistVariableDeclaration(generatedName); } - if (captureReferencedName) { - expression = emitHelpers().createPropKeyHelper(expression); - } return factory2.createAssignment(generatedName, expression); } return inlinable || isIdentifier(innerExpression) ? void 0 : expression; @@ -191564,7 +175999,7 @@ ${lanes.join("\n")} } if (isPrivateIdentifierPropertyAccessExpression(node)) { return wrapPrivateIdentifierForDestructuringTarget(node); - } else if (shouldTransformSuperInStaticInitializers && isSuperProperty(node) && currentStaticPropertyDeclarationOrStaticBlock && (lexicalEnvironment == null ? void 0 : lexicalEnvironment.data)) { + } else if (shouldTransformSuperInStaticInitializers && currentClassElement && isSuperProperty(node) && isStaticPropertyDeclarationOrClassStaticBlock(currentClassElement) && (lexicalEnvironment == null ? void 0 : lexicalEnvironment.data)) { const { classConstructor, superClassReference, facts } = lexicalEnvironment.data; if (facts & 1 /* ClassWasDecorated */) { return visitInvalidSuperProperty(node); @@ -191591,10 +176026,7 @@ ${lanes.join("\n")} } function visitAssignmentElement(node) { if (isNamedEvaluation(node, isAnonymousClassNeedingAssignedName)) { - const left = visitDestructuringAssignmentTarget(node.left); - const assignedName = getAssignedNameOfIdentifier(node.left, node.right); - const right = visitNode(node.right, (node2) => namedEvaluationVisitor(node2, assignedName), isExpression); - return factory2.updateBinaryExpression(node, left, node.operatorToken, right); + node = transformNamedEvaluation(context, node); } if (isAssignmentExpression( node, @@ -191641,9 +176073,7 @@ ${lanes.join("\n")} } function visitShorthandAssignmentProperty(node) { if (isNamedEvaluation(node, isAnonymousClassNeedingAssignedName)) { - const assignedName = getAssignedNameOfIdentifier(node.name, node.objectAssignmentInitializer); - const objectAssignmentInitializer = visitNode(node.objectAssignmentInitializer, (node2) => namedEvaluationVisitor(node2, assignedName), isExpression); - return factory2.updateShorthandPropertyAssignment(node, node.name, objectAssignmentInitializer); + node = transformNamedEvaluation(context, node); } return visitEachChild(node, visitor, context); } @@ -191693,16 +176123,16 @@ ${lanes.join("\n")} return; } switch (node.kind) { - case 217 /* FunctionExpression */: + case 218 /* FunctionExpression */: if (isArrowFunction(original) || getEmitFlags(node) & 524288 /* AsyncFunctionBody */) { break; } - case 261 /* FunctionDeclaration */: - case 175 /* Constructor */: - case 176 /* GetAccessor */: - case 177 /* SetAccessor */: - case 173 /* MethodDeclaration */: - case 171 /* PropertyDeclaration */: { + case 262 /* FunctionDeclaration */: + case 176 /* Constructor */: + case 177 /* GetAccessor */: + case 178 /* SetAccessor */: + case 174 /* MethodDeclaration */: + case 172 /* PropertyDeclaration */: { const savedLexicalEnvironment = lexicalEnvironment; const savedPreviousShouldSubstituteThisWithClassThis = previousShouldSubstituteThisWithClassThis; lexicalEnvironment = void 0; @@ -191714,7 +176144,7 @@ ${lanes.join("\n")} lexicalEnvironment = savedLexicalEnvironment; return; } - case 166 /* ComputedPropertyName */: { + case 167 /* ComputedPropertyName */: { const savedLexicalEnvironment = lexicalEnvironment; const savedShouldSubstituteThisWithClassThis = shouldSubstituteThisWithClassThis; lexicalEnvironment = lexicalEnvironment == null ? void 0 : lexicalEnvironment.previous; @@ -191744,11 +176174,8 @@ ${lanes.join("\n")} return node; } function substituteThisExpression(node) { - if (enabledSubstitutions & 2 /* ClassStaticThisOrSuperReference */ && (lexicalEnvironment == null ? void 0 : lexicalEnvironment.data)) { + if (enabledSubstitutions & 2 /* ClassStaticThisOrSuperReference */ && (lexicalEnvironment == null ? void 0 : lexicalEnvironment.data) && !noSubstitution.has(node)) { const { facts, classConstructor, classThis } = lexicalEnvironment.data; - if (facts & 1 /* ClassWasDecorated */ && legacyDecorators) { - return factory2.createParenthesizedExpression(factory2.createVoidZero()); - } const substituteThis = shouldSubstituteThisWithClassThis ? classThis ?? classConstructor : classConstructor; if (substituteThis) { return setTextRange( @@ -191759,6 +176186,9 @@ ${lanes.join("\n")} node ); } + if (facts & 1 /* ClassWasDecorated */ && legacyDecorators) { + return factory2.createParenthesizedExpression(factory2.createVoidZero()); + } } return node; } @@ -191767,7 +176197,7 @@ ${lanes.join("\n")} } function trySubstituteClassAlias(node) { if (enabledSubstitutions & 1 /* ClassAliases */) { - if (resolver.getNodeCheckFlags(node) & 2097152 /* ConstructorReferenceInClass */) { + if (resolver.getNodeCheckFlags(node) & 536870912 /* ConstructorReference */) { const declaration = resolver.getReferencedValueDeclaration(node); if (declaration) { const classAlias = classAliases[declaration.id]; @@ -191813,6 +176243,12 @@ ${lanes.join("\n")} function isPrivateIdentifierInExpression(node) { return isPrivateIdentifier(node.left) && node.operatorToken.kind === 103 /* InKeyword */; } + function isStaticPropertyDeclaration2(node) { + return isPropertyDeclaration(node) && hasStaticModifier(node); + } + function isStaticPropertyDeclarationOrClassStaticBlock(node) { + return isClassStaticBlockDeclaration(node) || isStaticPropertyDeclaration2(node); + } var init_classFields = __esm({ "src/compiler/transformers/classFields.ts"() { "use strict"; @@ -191854,15 +176290,15 @@ ${lanes.join("\n")} } function serializeTypeOfNode(node) { switch (node.kind) { - case 171 /* PropertyDeclaration */: - case 168 /* Parameter */: + case 172 /* PropertyDeclaration */: + case 169 /* Parameter */: return serializeTypeNode(node.type); - case 177 /* SetAccessor */: - case 176 /* GetAccessor */: + case 178 /* SetAccessor */: + case 177 /* GetAccessor */: return serializeTypeNode(getAccessorTypeNode(node)); - case 262 /* ClassDeclaration */: - case 230 /* ClassExpression */: - case 173 /* MethodDeclaration */: + case 263 /* ClassDeclaration */: + case 231 /* ClassExpression */: + case 174 /* MethodDeclaration */: return factory2.createIdentifier("Function"); default: return factory2.createVoidZero(); @@ -191889,7 +176325,7 @@ ${lanes.join("\n")} return factory2.createArrayLiteralExpression(expressions); } function getParametersOfDecoratedDeclaration(node, container) { - if (container && node.kind === 176 /* GetAccessor */) { + if (container && node.kind === 177 /* GetAccessor */) { const { setAccessor } = getAllAccessorDeclarations(container.members, node); if (setAccessor) { return setAccessor.parameters; @@ -191915,72 +176351,72 @@ ${lanes.join("\n")} case 157 /* UndefinedKeyword */: case 146 /* NeverKeyword */: return factory2.createVoidZero(); - case 183 /* FunctionType */: - case 184 /* ConstructorType */: + case 184 /* FunctionType */: + case 185 /* ConstructorType */: return factory2.createIdentifier("Function"); - case 187 /* ArrayType */: - case 188 /* TupleType */: + case 188 /* ArrayType */: + case 189 /* TupleType */: return factory2.createIdentifier("Array"); - case 181 /* TypePredicate */: + case 182 /* TypePredicate */: return node.assertsModifier ? factory2.createVoidZero() : factory2.createIdentifier("Boolean"); case 136 /* BooleanKeyword */: return factory2.createIdentifier("Boolean"); - case 202 /* TemplateLiteralType */: + case 203 /* TemplateLiteralType */: case 154 /* StringKeyword */: return factory2.createIdentifier("String"); case 151 /* ObjectKeyword */: return factory2.createIdentifier("Object"); - case 200 /* LiteralType */: + case 201 /* LiteralType */: return serializeLiteralOfLiteralTypeNode(node.literal); case 150 /* NumberKeyword */: return factory2.createIdentifier("Number"); - case 162 /* BigIntKeyword */: + case 163 /* BigIntKeyword */: return getGlobalConstructor("BigInt", 7 /* ES2020 */); case 155 /* SymbolKeyword */: return getGlobalConstructor("Symbol", 2 /* ES2015 */); - case 182 /* TypeReference */: + case 183 /* TypeReference */: return serializeTypeReferenceNode(node); - case 192 /* IntersectionType */: + case 193 /* IntersectionType */: return serializeUnionOrIntersectionConstituents( node.types, /*isIntersection*/ true ); - case 191 /* UnionType */: + case 192 /* UnionType */: return serializeUnionOrIntersectionConstituents( node.types, /*isIntersection*/ false ); - case 193 /* ConditionalType */: + case 194 /* ConditionalType */: return serializeUnionOrIntersectionConstituents( [node.trueType, node.falseType], /*isIntersection*/ false ); - case 197 /* TypeOperator */: + case 198 /* TypeOperator */: if (node.operator === 148 /* ReadonlyKeyword */) { return serializeTypeNode(node.type); } break; - case 185 /* TypeQuery */: - case 198 /* IndexedAccessType */: - case 199 /* MappedType */: - case 186 /* TypeLiteral */: + case 186 /* TypeQuery */: + case 199 /* IndexedAccessType */: + case 200 /* MappedType */: + case 187 /* TypeLiteral */: case 133 /* AnyKeyword */: case 159 /* UnknownKeyword */: - case 196 /* ThisType */: - case 204 /* ImportType */: + case 197 /* ThisType */: + case 205 /* ImportType */: break; - case 318 /* JSDocAllType */: - case 319 /* JSDocUnknownType */: - case 323 /* JSDocFunctionType */: - case 324 /* JSDocVariadicType */: - case 325 /* JSDocNamepathType */: + case 319 /* JSDocAllType */: + case 320 /* JSDocUnknownType */: + case 324 /* JSDocFunctionType */: + case 325 /* JSDocVariadicType */: + case 326 /* JSDocNamepathType */: break; - case 320 /* JSDocNullableType */: - case 321 /* JSDocNonNullableType */: - case 322 /* JSDocOptionalType */: + case 321 /* JSDocNullableType */: + case 322 /* JSDocNonNullableType */: + case 323 /* JSDocOptionalType */: return serializeTypeNode(node.type); default: return Debug.failBadSyntaxKind(node); @@ -191992,7 +176428,7 @@ ${lanes.join("\n")} case 11 /* StringLiteral */: case 15 /* NoSubstitutionTemplateLiteral */: return factory2.createIdentifier("String"); - case 223 /* PrefixUnaryExpression */: { + case 224 /* PrefixUnaryExpression */: { const operand = node.operand; switch (operand.kind) { case 9 /* NumericLiteral */: @@ -192151,7 +176587,7 @@ ${lanes.join("\n")} name.original = void 0; setParent(name, getParseTreeNode(currentLexicalScope)); return name; - case 165 /* QualifiedName */: + case 166 /* QualifiedName */: return serializeQualifiedNameAsExpression(node); } } @@ -192207,23 +176643,23 @@ ${lanes.join("\n")} return node; } switch (node.kind) { - case 169 /* Decorator */: + case 170 /* Decorator */: return void 0; - case 262 /* ClassDeclaration */: + case 263 /* ClassDeclaration */: return visitClassDeclaration(node); - case 230 /* ClassExpression */: + case 231 /* ClassExpression */: return visitClassExpression(node); - case 175 /* Constructor */: + case 176 /* Constructor */: return visitConstructorDeclaration(node); - case 173 /* MethodDeclaration */: + case 174 /* MethodDeclaration */: return visitMethodDeclaration(node); - case 177 /* SetAccessor */: + case 178 /* SetAccessor */: return visitSetAccessorDeclaration(node); - case 176 /* GetAccessor */: + case 177 /* GetAccessor */: return visitGetAccessorDeclaration(node); - case 171 /* PropertyDeclaration */: + case 172 /* PropertyDeclaration */: return visitPropertyDeclaration(node); - case 168 /* Parameter */: + case 169 /* Parameter */: return visitParameterDeclaration(node); default: return visitEachChild(node, visitor, context); @@ -192286,16 +176722,19 @@ ${lanes.join("\n")} true ); if (hasClassElementWithDecoratorContainingPrivateIdentifierInExpression(node)) { - members = setTextRange(factory2.createNodeArray([ - ...members, - factory2.createClassStaticBlockDeclaration( - factory2.createBlock( - decorationStatements, - /*multiLine*/ - true + members = setTextRange( + factory2.createNodeArray([ + ...members, + factory2.createClassStaticBlockDeclaration( + factory2.createBlock( + decorationStatements, + /*multiLine*/ + true + ) ) - ) - ]), members); + ]), + members + ); decorationStatements = void 0; } return { decorationStatements, members }; @@ -192318,8 +176757,8 @@ ${lanes.join("\n")} return addRange([updated], decorationStatements); } function transformClassDeclarationWithClassDecorators(node, name) { - const isExport = hasSyntacticModifier(node, 1 /* Export */); - const isDefault = hasSyntacticModifier(node, 1024 /* Default */); + const isExport = hasSyntacticModifier(node, 32 /* Export */); + const isDefault = hasSyntacticModifier(node, 2048 /* Default */); const modifiers = visitNodes2(node.modifiers, (node2) => isExportOrDefaultModifier(node2) || isDecorator(node2) ? void 0 : node2, isModifierLike); const location = moveRangePastModifiers(node); const classAlias = getClassAliasIfNeeded(node); @@ -192340,18 +176779,21 @@ ${lanes.join("\n")} let members = visitNodes2(node.members, visitor, isClassElement); let decorationStatements = []; ({ members, decorationStatements } = transformDecoratorsOfClassElements(node, members)); - const assignClassAliasInStaticBlock = languageVersion >= 9 /* ES2022 */ && !!classAlias && some(members, (member) => isPropertyDeclaration(member) && hasSyntacticModifier(member, 32 /* Static */) || isClassStaticBlockDeclaration(member)); + const assignClassAliasInStaticBlock = languageVersion >= 9 /* ES2022 */ && !!classAlias && some(members, (member) => isPropertyDeclaration(member) && hasSyntacticModifier(member, 256 /* Static */) || isClassStaticBlockDeclaration(member)); if (assignClassAliasInStaticBlock) { - members = setTextRange(factory2.createNodeArray([ - factory2.createClassStaticBlockDeclaration( - factory2.createBlock([ - factory2.createExpressionStatement( - factory2.createAssignment(classAlias, factory2.createThis()) - ) - ]) - ), - ...members - ]), members); + members = setTextRange( + factory2.createNodeArray([ + factory2.createClassStaticBlockDeclaration( + factory2.createBlock([ + factory2.createExpressionStatement( + factory2.createAssignment(classAlias, factory2.createThis()) + ) + ]) + ), + ...members + ]), + members + ); } const classExpression = factory2.createClassExpression( modifiers, @@ -192363,39 +176805,36 @@ ${lanes.join("\n")} ); setOriginalNode(classExpression, node); setTextRange(classExpression, location); + const varInitializer = classAlias && !assignClassAliasInStaticBlock ? factory2.createAssignment(classAlias, classExpression) : classExpression; const varDecl = factory2.createVariableDeclaration( declName, /*exclamationToken*/ void 0, /*type*/ void 0, - classAlias && !assignClassAliasInStaticBlock ? factory2.createAssignment(classAlias, classExpression) : classExpression + varInitializer ); setOriginalNode(varDecl, node); - let varModifiers; - if (isExport && !isDefault) { - varModifiers = factory2.createModifiersFromModifierFlags(1 /* Export */); - } - const statement = factory2.createVariableStatement( - varModifiers, - factory2.createVariableDeclarationList([ - varDecl - ], 1 /* Let */) + const varDeclList = factory2.createVariableDeclarationList([varDecl], 1 /* Let */); + const varStatement = factory2.createVariableStatement( + /*modifiers*/ + void 0, + varDeclList ); - setOriginalNode(statement, node); - setTextRange(statement, location); - setCommentRange(statement, node); - const statements = [statement]; + setOriginalNode(varStatement, node); + setTextRange(varStatement, location); + setCommentRange(varStatement, node); + const statements = [varStatement]; addRange(statements, decorationStatements); addConstructorDecorationStatement(statements, node); - if (isExport && isDefault) { - statements.push(factory2.createExportAssignment( - /*modifiers*/ - void 0, - /*isExportEquals*/ - false, - declName - )); + if (isExport) { + if (isDefault) { + const exportStatement = factory2.createExportDefault(declName); + statements.push(exportStatement); + } else { + const exportStatement = factory2.createExternalModuleExport(factory2.getDeclarationName(node)); + statements.push(exportStatement); + } } return statements; } @@ -192426,55 +176865,67 @@ ${lanes.join("\n")} return updated; } function visitMethodDeclaration(node) { - return finishClassElement(factory2.updateMethodDeclaration( - node, - visitNodes2(node.modifiers, modifierVisitor, isModifier), - node.asteriskToken, - Debug.checkDefined(visitNode(node.name, visitor, isPropertyName)), - /*questionToken*/ - void 0, - /*typeParameters*/ - void 0, - visitNodes2(node.parameters, visitor, isParameter), - /*type*/ - void 0, - visitNode(node.body, visitor, isBlock) - ), node); + return finishClassElement( + factory2.updateMethodDeclaration( + node, + visitNodes2(node.modifiers, modifierVisitor, isModifier), + node.asteriskToken, + Debug.checkDefined(visitNode(node.name, visitor, isPropertyName)), + /*questionToken*/ + void 0, + /*typeParameters*/ + void 0, + visitNodes2(node.parameters, visitor, isParameter), + /*type*/ + void 0, + visitNode(node.body, visitor, isBlock) + ), + node + ); } function visitGetAccessorDeclaration(node) { - return finishClassElement(factory2.updateGetAccessorDeclaration( - node, - visitNodes2(node.modifiers, modifierVisitor, isModifier), - Debug.checkDefined(visitNode(node.name, visitor, isPropertyName)), - visitNodes2(node.parameters, visitor, isParameter), - /*type*/ - void 0, - visitNode(node.body, visitor, isBlock) - ), node); + return finishClassElement( + factory2.updateGetAccessorDeclaration( + node, + visitNodes2(node.modifiers, modifierVisitor, isModifier), + Debug.checkDefined(visitNode(node.name, visitor, isPropertyName)), + visitNodes2(node.parameters, visitor, isParameter), + /*type*/ + void 0, + visitNode(node.body, visitor, isBlock) + ), + node + ); } function visitSetAccessorDeclaration(node) { - return finishClassElement(factory2.updateSetAccessorDeclaration( - node, - visitNodes2(node.modifiers, modifierVisitor, isModifier), - Debug.checkDefined(visitNode(node.name, visitor, isPropertyName)), - visitNodes2(node.parameters, visitor, isParameter), - visitNode(node.body, visitor, isBlock) - ), node); + return finishClassElement( + factory2.updateSetAccessorDeclaration( + node, + visitNodes2(node.modifiers, modifierVisitor, isModifier), + Debug.checkDefined(visitNode(node.name, visitor, isPropertyName)), + visitNodes2(node.parameters, visitor, isParameter), + visitNode(node.body, visitor, isBlock) + ), + node + ); } function visitPropertyDeclaration(node) { - if (node.flags & 16777216 /* Ambient */ || hasSyntacticModifier(node, 2 /* Ambient */)) { + if (node.flags & 33554432 /* Ambient */ || hasSyntacticModifier(node, 128 /* Ambient */)) { return void 0; } - return finishClassElement(factory2.updatePropertyDeclaration( - node, - visitNodes2(node.modifiers, modifierVisitor, isModifier), - Debug.checkDefined(visitNode(node.name, visitor, isPropertyName)), - /*questionOrExclamationToken*/ - void 0, - /*type*/ - void 0, - visitNode(node.initializer, visitor, isExpression) - ), node); + return finishClassElement( + factory2.updatePropertyDeclaration( + node, + visitNodes2(node.modifiers, modifierVisitor, isModifier), + Debug.checkDefined(visitNode(node.name, visitor, isPropertyName)), + /*questionOrExclamationToken*/ + void 0, + /*type*/ + void 0, + visitNode(node.initializer, visitor, isExpression) + ), + node + ); } function visitParameterDeclaration(node) { const updated = factory2.updateParameterDeclaration( @@ -192547,7 +176998,7 @@ ${lanes.join("\n")} const memberName = getExpressionForPropertyName( member, /*generateNameForComputedPropertyName*/ - !hasSyntacticModifier(member, 2 /* Ambient */) + !hasSyntacticModifier(member, 128 /* Ambient */) ); const descriptor = languageVersion > 0 /* ES3 */ ? isPropertyDeclaration(member) && !hasAccessorModifier(member) ? factory2.createVoidZero() : factory2.createNull() : void 0; const helper = emitHelpers().createDecorateHelper( @@ -192630,7 +177081,7 @@ ${lanes.join("\n")} } } function getClassAliasIfNeeded(node) { - if (resolver.getNodeCheckFlags(node) & 1048576 /* ClassWithConstructorReference */) { + if (resolver.getNodeCheckFlags(node) & 262144 /* ContainsConstructorReference */) { enableSubstitutionForClassAliases(); const classAlias = factory2.createUniqueName(node.name && !isGeneratedIdentifier(node.name) ? idText(node.name) : "default"); classAliases[getOriginalNodeId(node)] = classAlias; @@ -192663,7 +177114,7 @@ ${lanes.join("\n")} } function trySubstituteClassAlias(node) { if (classAliases) { - if (resolver.getNodeCheckFlags(node) & 2097152 /* ConstructorReferenceInClass */) { + if (resolver.getNodeCheckFlags(node) & 536870912 /* ConstructorReference */) { const declaration = resolver.getReferencedValueDeclaration(node); if (declaration) { const classAlias = classAliases[declaration.id]; @@ -192695,8 +177146,7 @@ ${lanes.join("\n")} endLexicalEnvironment, hoistVariableDeclaration } = context; - const compilerOptions = context.getCompilerOptions(); - const languageVersion = getEmitScriptTarget(compilerOptions); + const languageVersion = getEmitScriptTarget(context.getCompilerOptions()); let top; let classInfo; let classThis; @@ -192808,86 +177258,78 @@ ${lanes.join("\n")} return node; } switch (node.kind) { - case 169 /* Decorator */: + case 170 /* Decorator */: return Debug.fail("Use `modifierVisitor` instead."); - case 262 /* ClassDeclaration */: + case 263 /* ClassDeclaration */: return visitClassDeclaration(node); - case 230 /* ClassExpression */: - return visitClassExpression( - node, - /*referencedName*/ - void 0 - ); - case 175 /* Constructor */: - case 171 /* PropertyDeclaration */: - case 174 /* ClassStaticBlockDeclaration */: + case 231 /* ClassExpression */: + return visitClassExpression(node); + case 176 /* Constructor */: + case 172 /* PropertyDeclaration */: + case 175 /* ClassStaticBlockDeclaration */: return Debug.fail("Not supported outside of a class. Use 'classElementVisitor' instead."); - case 168 /* Parameter */: + case 169 /* Parameter */: return visitParameterDeclaration(node); - case 225 /* BinaryExpression */: + case 226 /* BinaryExpression */: return visitBinaryExpression( node, /*discarded*/ false ); - case 302 /* PropertyAssignment */: + case 303 /* PropertyAssignment */: return visitPropertyAssignment(node); - case 259 /* VariableDeclaration */: + case 260 /* VariableDeclaration */: return visitVariableDeclaration(node); - case 207 /* BindingElement */: + case 208 /* BindingElement */: return visitBindingElement(node); - case 276 /* ExportAssignment */: + case 277 /* ExportAssignment */: return visitExportAssignment(node); case 110 /* ThisKeyword */: return visitThisExpression(node); - case 247 /* ForStatement */: + case 248 /* ForStatement */: return visitForStatement(node); - case 243 /* ExpressionStatement */: + case 244 /* ExpressionStatement */: return visitExpressionStatement(node); - case 360 /* CommaListExpression */: + case 361 /* CommaListExpression */: return visitCommaListExpression( node, /*discarded*/ false ); - case 216 /* ParenthesizedExpression */: + case 217 /* ParenthesizedExpression */: return visitParenthesizedExpression( node, /*discarded*/ - false, - /*referencedName*/ - void 0 + false ); - case 359 /* PartiallyEmittedExpression */: + case 360 /* PartiallyEmittedExpression */: return visitPartiallyEmittedExpression( node, /*discarded*/ - false, - /*referencedName*/ - void 0 + false ); - case 212 /* CallExpression */: + case 213 /* CallExpression */: return visitCallExpression(node); - case 214 /* TaggedTemplateExpression */: + case 215 /* TaggedTemplateExpression */: return visitTaggedTemplateExpression(node); - case 223 /* PrefixUnaryExpression */: - case 224 /* PostfixUnaryExpression */: + case 224 /* PrefixUnaryExpression */: + case 225 /* PostfixUnaryExpression */: return visitPreOrPostfixUnaryExpression( node, /*discarded*/ false ); - case 210 /* PropertyAccessExpression */: + case 211 /* PropertyAccessExpression */: return visitPropertyAccessExpression(node); - case 211 /* ElementAccessExpression */: + case 212 /* ElementAccessExpression */: return visitElementAccessExpression(node); - case 166 /* ComputedPropertyName */: + case 167 /* ComputedPropertyName */: return visitComputedPropertyName(node); - case 173 /* MethodDeclaration */: - case 177 /* SetAccessor */: - case 176 /* GetAccessor */: - case 217 /* FunctionExpression */: - case 261 /* FunctionDeclaration */: { + case 174 /* MethodDeclaration */: + case 178 /* SetAccessor */: + case 177 /* GetAccessor */: + case 218 /* FunctionExpression */: + case 262 /* FunctionDeclaration */: { enterOther(); const result = visitEachChild(node, fallbackVisitor, context); exitOther(); @@ -192899,7 +177341,7 @@ ${lanes.join("\n")} } function fallbackVisitor(node) { switch (node.kind) { - case 169 /* Decorator */: + case 170 /* Decorator */: return void 0; default: return visitor(node); @@ -192907,7 +177349,7 @@ ${lanes.join("\n")} } function modifierVisitor(node) { switch (node.kind) { - case 169 /* Decorator */: + case 170 /* Decorator */: return void 0; default: return node; @@ -192915,72 +177357,48 @@ ${lanes.join("\n")} } function classElementVisitor(node) { switch (node.kind) { - case 175 /* Constructor */: + case 176 /* Constructor */: return visitConstructorDeclaration(node); - case 173 /* MethodDeclaration */: + case 174 /* MethodDeclaration */: return visitMethodDeclaration(node); - case 176 /* GetAccessor */: + case 177 /* GetAccessor */: return visitGetAccessorDeclaration(node); - case 177 /* SetAccessor */: + case 178 /* SetAccessor */: return visitSetAccessorDeclaration(node); - case 171 /* PropertyDeclaration */: + case 172 /* PropertyDeclaration */: return visitPropertyDeclaration(node); - case 174 /* ClassStaticBlockDeclaration */: + case 175 /* ClassStaticBlockDeclaration */: return visitClassStaticBlockDeclaration(node); default: return visitor(node); } } - function namedEvaluationVisitor(node, referencedName) { - switch (node.kind) { - case 359 /* PartiallyEmittedExpression */: - return visitPartiallyEmittedExpression( - node, - /*discarded*/ - false, - referencedName - ); - case 216 /* ParenthesizedExpression */: - return visitParenthesizedExpression( - node, - /*discarded*/ - false, - referencedName - ); - case 230 /* ClassExpression */: - return visitClassExpression(node, referencedName); - default: - return visitor(node); - } - } function discardedValueVisitor(node) { switch (node.kind) { - case 223 /* PrefixUnaryExpression */: - case 224 /* PostfixUnaryExpression */: + case 224 /* PrefixUnaryExpression */: + case 225 /* PostfixUnaryExpression */: return visitPreOrPostfixUnaryExpression( node, /*discarded*/ true ); - case 225 /* BinaryExpression */: + case 226 /* BinaryExpression */: return visitBinaryExpression( node, /*discarded*/ true ); - case 360 /* CommaListExpression */: + case 361 /* CommaListExpression */: return visitCommaListExpression( node, /*discarded*/ true ); - case 216 /* ParenthesizedExpression */: + case 217 /* ParenthesizedExpression */: return visitParenthesizedExpression( node, /*discarded*/ - true, - /*referencedName*/ - void 0 + true ); default: return visitor(node); @@ -193018,6 +177436,7 @@ ${lanes.join("\n")} ); } function createClassInfo(node) { + const metadataReference = factory2.createUniqueName("_metadata", 16 /* Optimistic */ | 32 /* FileLevel */); let instanceExtraInitializersName; let staticExtraInitializersName; let hasStaticInitializers = false; @@ -193031,13 +177450,15 @@ ${lanes.join("\n")} node )) { if (hasStaticModifier(member)) { - staticExtraInitializersName ?? (staticExtraInitializersName = factory2.createUniqueName("_staticExtraInitializers", 16 /* Optimistic */)); + staticExtraInitializersName ?? (staticExtraInitializersName = factory2.createUniqueName("_staticExtraInitializers", 16 /* Optimistic */ | 32 /* FileLevel */)); } else { - instanceExtraInitializersName ?? (instanceExtraInitializersName = factory2.createUniqueName("_instanceExtraInitializers", 16 /* Optimistic */)); + instanceExtraInitializersName ?? (instanceExtraInitializersName = factory2.createUniqueName("_instanceExtraInitializers", 16 /* Optimistic */ | 32 /* FileLevel */)); } } if (isClassStaticBlockDeclaration(member)) { - hasStaticInitializers = true; + if (!isClassNamedEvaluationHelperBlock(member)) { + hasStaticInitializers = true; + } } else if (isPropertyDeclaration(member)) { if (hasStaticModifier(member)) { hasStaticInitializers || (hasStaticInitializers = !!member.initializer || hasDecorators(member)); @@ -193054,6 +177475,7 @@ ${lanes.join("\n")} } return { class: node, + metadataReference, instanceExtraInitializersName, staticExtraInitializersName, hasStaticInitializers, @@ -193061,19 +177483,15 @@ ${lanes.join("\n")} hasStaticPrivateClassElements }; } - function containsLexicalSuperInStaticInitializer(node) { - for (const member of node.members) { - if (isClassStaticBlockDeclaration(member) || isPropertyDeclaration(member) && hasStaticModifier(member)) { - if (member.transformFlags & 134217728 /* ContainsLexicalSuper */) { - return true; - } - } - } - return false; - } - function transformClassLike(node, className) { - var _a; + function transformClassLike(node) { startLexicalEnvironment(); + if (!classHasDeclaredOrExplicitlyAssignedName(node) && classOrConstructorParameterIsDecorated( + /*useLegacyDecorators*/ + false, + node + )) { + node = injectClassNamedEvaluationHelperBlockIfMissing(context, node, factory2.createStringLiteral("")); + } const classReference = factory2.getLocalName( node, /*allowComments*/ @@ -193092,10 +177510,14 @@ ${lanes.join("\n")} let shouldTransformPrivateStaticElementsInClass = false; const classDecorators = transformAllDecoratorsOfDeclaration(getAllDecoratorsOfClass(node)); if (classDecorators) { - classInfo2.classDecoratorsName = factory2.createUniqueName("_classDecorators", 16 /* Optimistic */); - classInfo2.classDescriptorName = factory2.createUniqueName("_classDescriptor", 16 /* Optimistic */); - classInfo2.classExtraInitializersName = factory2.createUniqueName("_classExtraInitializers", 16 /* Optimistic */); - classInfo2.classThis = factory2.createUniqueName("_classThis", 16 /* Optimistic */); + classInfo2.classDecoratorsName = factory2.createUniqueName("_classDecorators", 16 /* Optimistic */ | 32 /* FileLevel */); + classInfo2.classDescriptorName = factory2.createUniqueName("_classDescriptor", 16 /* Optimistic */ | 32 /* FileLevel */); + classInfo2.classExtraInitializersName = factory2.createUniqueName("_classExtraInitializers", 16 /* Optimistic */ | 32 /* FileLevel */); + const needsUniqueClassThis = some(node.members, (member) => (isPrivateIdentifierClassElementDeclaration(member) || isAutoAccessorPropertyDeclaration(member)) && hasStaticModifier(member)); + classInfo2.classThis = factory2.createUniqueName( + "_classThis", + needsUniqueClassThis ? 16 /* Optimistic */ | 8 /* ReservedInNestedScopes */ : 16 /* Optimistic */ | 32 /* FileLevel */ + ); classDefinitionStatements.push( createLet(classInfo2.classDecoratorsName, factory2.createArrayLiteralExpression(classDecorators)), createLet(classInfo2.classDescriptorName), @@ -193107,34 +177529,26 @@ ${lanes.join("\n")} shouldTransformPrivateStaticElementsInFile = true; } } - if (classDecorators && containsLexicalSuperInStaticInitializer(node)) { - const extendsClause = getHeritageClause(node.heritageClauses, 96 /* ExtendsKeyword */); - const extendsElement = extendsClause && firstOrUndefined(extendsClause.types); - const extendsExpression = extendsElement && visitNode(extendsElement.expression, visitor, isExpression); - if (extendsExpression) { - classInfo2.classSuper = factory2.createUniqueName("_classSuper", 16 /* Optimistic */); - const unwrapped = skipOuterExpressions(extendsExpression); - const safeExtendsExpression = isClassExpression(unwrapped) && !unwrapped.name || isFunctionExpression(unwrapped) && !unwrapped.name || isArrowFunction(unwrapped) ? factory2.createComma(factory2.createNumericLiteral(0), extendsExpression) : extendsExpression; - classDefinitionStatements.push(createLet(classInfo2.classSuper, safeExtendsExpression)); - const updatedExtendsElement = factory2.updateExpressionWithTypeArguments( - extendsElement, - classInfo2.classSuper, - /*typeArguments*/ - void 0 - ); - const updatedExtendsClause = factory2.updateHeritageClause(extendsClause, [updatedExtendsElement]); - heritageClauses = factory2.createNodeArray([updatedExtendsClause]); - } - } else { - heritageClauses = visitNodes2(node.heritageClauses, visitor, isHeritageClause); + const extendsClause = getHeritageClause(node.heritageClauses, 96 /* ExtendsKeyword */); + const extendsElement = extendsClause && firstOrUndefined(extendsClause.types); + const extendsExpression = extendsElement && visitNode(extendsElement.expression, visitor, isExpression); + if (extendsExpression) { + classInfo2.classSuper = factory2.createUniqueName("_classSuper", 16 /* Optimistic */ | 32 /* FileLevel */); + const unwrapped = skipOuterExpressions(extendsExpression); + const safeExtendsExpression = isClassExpression(unwrapped) && !unwrapped.name || isFunctionExpression(unwrapped) && !unwrapped.name || isArrowFunction(unwrapped) ? factory2.createComma(factory2.createNumericLiteral(0), extendsExpression) : extendsExpression; + classDefinitionStatements.push(createLet(classInfo2.classSuper, safeExtendsExpression)); + const updatedExtendsElement = factory2.updateExpressionWithTypeArguments( + extendsElement, + classInfo2.classSuper, + /*typeArguments*/ + void 0 + ); + const updatedExtendsClause = factory2.updateHeritageClause(extendsClause, [updatedExtendsElement]); + heritageClauses = factory2.createNodeArray([updatedExtendsClause]); } const renamedClassThis = classInfo2.classThis ?? factory2.createThis(); - const needsSetNameHelper = !((_a = getOriginalNode(node, isClassLike)) == null ? void 0 : _a.name) && (classDecorators || !isStringLiteral(className) || !isEmptyStringLiteral(className)); - if (needsSetNameHelper) { - const setNameExpr = emitHelpers().createSetFunctionNameHelper(factory2.createThis(), className); - leadingBlockStatements = append(leadingBlockStatements, factory2.createExpressionStatement(setNameExpr)); - } enterClass(classInfo2); + leadingBlockStatements = append(leadingBlockStatements, createMetadata(classInfo2.metadataReference, classInfo2.classSuper)); let members = visitNodes2(node.members, classElementVisitor, isClassElement); if (pendingExpressions) { let outerThis; @@ -193232,15 +177646,15 @@ ${lanes.join("\n")} leadingBlockStatements = addRange(leadingBlockStatements, classInfo2.nonStaticFieldDecorationStatements); if (classInfo2.classDescriptorName && classInfo2.classDecoratorsName && classInfo2.classExtraInitializersName && classInfo2.classThis) { leadingBlockStatements ?? (leadingBlockStatements = []); - const valueProperty = factory2.createPropertyAssignment("value", factory2.createThis()); + const valueProperty = factory2.createPropertyAssignment("value", renamedClassThis); const classDescriptor = factory2.createObjectLiteralExpression([valueProperty]); const classDescriptorAssignment = factory2.createAssignment(classInfo2.classDescriptorName, classDescriptor); - const classNameReference = factory2.createPropertyAccessExpression(factory2.createThis(), "name"); + const classNameReference = factory2.createPropertyAccessExpression(renamedClassThis, "name"); const esDecorateHelper2 = emitHelpers().createESDecorateHelper( factory2.createNull(), classDescriptorAssignment, classInfo2.classDecoratorsName, - { kind: "class", name: classNameReference }, + { kind: "class", name: classNameReference, metadata: classInfo2.metadataReference }, factory2.createNull(), classInfo2.classExtraInitializersName ); @@ -193252,6 +177666,7 @@ ${lanes.join("\n")} const classReferenceAssignment = factory2.createAssignment(classReference, classThisAssignment); leadingBlockStatements.push(factory2.createExpressionStatement(classReferenceAssignment)); } + leadingBlockStatements.push(createSymbolMetadata(renamedClassThis, classInfo2.metadataReference)); if (classInfo2.staticExtraInitializersName) { const runStaticInitializersHelper = emitHelpers().createRunInitializersHelper(renamedClassThis, classInfo2.staticExtraInitializersName); const runStaticInitializersStatement = factory2.createExpressionStatement(runStaticInitializersHelper); @@ -193268,32 +177683,35 @@ ${lanes.join("\n")} addRange(leadingBlockStatements, trailingBlockStatements); trailingBlockStatements = void 0; } - let newMembers = members; - if (leadingBlockStatements) { - const leadingStaticBlockBody = factory2.createBlock( - leadingBlockStatements, - /*multiLine*/ - true - ); - const leadingStaticBlock = factory2.createClassStaticBlockDeclaration(leadingStaticBlockBody); - if (shouldTransformPrivateStaticElementsInClass) { - setInternalEmitFlags(leadingStaticBlock, 32 /* TransformPrivateStaticElements */); - } - newMembers = [leadingStaticBlock, ...newMembers]; - } - if (syntheticConstructor) { - newMembers = [...newMembers, syntheticConstructor]; - } - if (trailingBlockStatements) { - const trailingStaticBlockBody = factory2.createBlock( - trailingBlockStatements, - /*multiLine*/ - true - ); - const trailingStaticBlock = factory2.createClassStaticBlockDeclaration(trailingStaticBlockBody); - newMembers = [...newMembers, trailingStaticBlock]; + const leadingStaticBlock = leadingBlockStatements && factory2.createClassStaticBlockDeclaration(factory2.createBlock( + leadingBlockStatements, + /*multiLine*/ + true + )); + if (leadingStaticBlock && shouldTransformPrivateStaticElementsInClass) { + setInternalEmitFlags(leadingStaticBlock, 32 /* TransformPrivateStaticElements */); } - if (newMembers !== members) { + const trailingStaticBlock = trailingBlockStatements && factory2.createClassStaticBlockDeclaration(factory2.createBlock( + trailingBlockStatements, + /*multiLine*/ + true + )); + if (leadingStaticBlock || syntheticConstructor || trailingStaticBlock) { + const newMembers = []; + const existingNamedEvaluationHelperBlockIndex = members.findIndex(isClassNamedEvaluationHelperBlock); + if (leadingStaticBlock) { + addRange(newMembers, members, 0, existingNamedEvaluationHelperBlockIndex + 1); + newMembers.push(leadingStaticBlock); + addRange(newMembers, members, existingNamedEvaluationHelperBlockIndex + 1); + } else { + addRange(newMembers, members); + } + if (syntheticConstructor) { + newMembers.push(syntheticConstructor); + } + if (trailingStaticBlock) { + newMembers.push(trailingStaticBlock); + } members = setTextRange(factory2.createNodeArray(newMembers), members); } const lexicalEnvironment = endLexicalEnvironment(); @@ -193309,6 +177727,9 @@ ${lanes.join("\n")} heritageClauses, members ); + if (classInfo2.classThis) { + classExpression = injectClassThisAssignmentIfMissing(factory2, classExpression, classInfo2.classThis); + } const classReferenceDeclaration = factory2.createVariableDeclaration( classReference, /*exclamationToken*/ @@ -193348,7 +177769,6 @@ ${lanes.join("\n")} } } setOriginalNode(classExpression, node); - getOrCreateEmitNode(classExpression).classThis = classInfo2.classThis; return factory2.createImmediatelyInvokedArrowFunction(factory2.mergeLexicalEnvironment(classDefinitionStatements, lexicalEnvironment)); } function isDecoratedClassLike(node) { @@ -193364,26 +177784,51 @@ ${lanes.join("\n")} } function visitClassDeclaration(node) { if (isDecoratedClassLike(node)) { - if (hasSyntacticModifier(node, 1 /* Export */) && hasSyntacticModifier(node, 1024 /* Default */)) { - const originalClass = getOriginalNode(node, isClassLike) ?? node; - const className = originalClass.name ? factory2.createStringLiteralFromNode(originalClass.name) : factory2.createStringLiteral("default"); - const iife = transformClassLike(node, className); - const statement = factory2.createExportDefault(iife); - setOriginalNode(statement, node); - setCommentRange(statement, getCommentRange(node)); - setSourceMapRange(statement, moveRangePastDecorators(node)); - return statement; + const statements = []; + const originalClass = getOriginalNode(node, isClassLike) ?? node; + const className = originalClass.name ? factory2.createStringLiteralFromNode(originalClass.name) : factory2.createStringLiteral("default"); + const isExport = hasSyntacticModifier(node, 32 /* Export */); + const isDefault = hasSyntacticModifier(node, 2048 /* Default */); + if (!node.name) { + node = injectClassNamedEvaluationHelperBlockIfMissing(context, node, className); + } + if (isExport && isDefault) { + const iife = transformClassLike(node); + if (node.name) { + const varDecl = factory2.createVariableDeclaration( + factory2.getLocalName(node), + /*exclamationToken*/ + void 0, + /*type*/ + void 0, + iife + ); + setOriginalNode(varDecl, node); + const varDecls = factory2.createVariableDeclarationList([varDecl], 1 /* Let */); + const varStatement = factory2.createVariableStatement( + /*modifiers*/ + void 0, + varDecls + ); + statements.push(varStatement); + const exportStatement = factory2.createExportDefault(factory2.getDeclarationName(node)); + setOriginalNode(exportStatement, node); + setCommentRange(exportStatement, getCommentRange(node)); + setSourceMapRange(exportStatement, moveRangePastDecorators(node)); + statements.push(exportStatement); + } else { + const exportStatement = factory2.createExportDefault(iife); + setOriginalNode(exportStatement, node); + setCommentRange(exportStatement, getCommentRange(node)); + setSourceMapRange(exportStatement, moveRangePastDecorators(node)); + statements.push(exportStatement); + } } else { Debug.assertIsDefined(node.name, "A class declaration that is not a default export must have a name."); - const iife = transformClassLike(node, factory2.createStringLiteralFromNode(node.name)); - const modifiers = visitNodes2(node.modifiers, modifierVisitor, isModifier); - const declName = languageVersion <= 2 /* ES2015 */ ? factory2.getInternalName( - node, - /*allowComments*/ - false, - /*allowSourceMaps*/ - true - ) : factory2.getLocalName( + const iife = transformClassLike(node); + const modifierVisitorNoExport = isExport ? (node2) => isExportModifier(node2) ? void 0 : modifierVisitor(node2) : modifierVisitor; + const modifiers = visitNodes2(node.modifiers, modifierVisitorNoExport, isModifier); + const declName = factory2.getLocalName( node, /*allowComments*/ false, @@ -193400,11 +177845,17 @@ ${lanes.join("\n")} ); setOriginalNode(varDecl, node); const varDecls = factory2.createVariableDeclarationList([varDecl], 1 /* Let */); - const statement = factory2.createVariableStatement(modifiers, varDecls); - setOriginalNode(statement, node); - setCommentRange(statement, getCommentRange(node)); - return statement; + const varStatement = factory2.createVariableStatement(modifiers, varDecls); + setOriginalNode(varStatement, node); + setCommentRange(varStatement, getCommentRange(node)); + statements.push(varStatement); + if (isExport) { + const exportStatement = factory2.createExternalModuleExport(declName); + setOriginalNode(exportStatement, node); + statements.push(exportStatement); + } } + return singleOrMany(statements); } else { const modifiers = visitNodes2(node.modifiers, modifierVisitor, isModifier); const heritageClauses = visitNodes2(node.heritageClauses, visitor, isHeritageClause); @@ -193425,10 +177876,9 @@ ${lanes.join("\n")} ); } } - function visitClassExpression(node, referencedName) { + function visitClassExpression(node) { if (isDecoratedClassLike(node)) { - const className = node.name ? factory2.createStringLiteralFromNode(node.name) : referencedName ?? factory2.createStringLiteral(""); - const iife = transformClassLike(node, className); + const iife = transformClassLike(node); setOriginalNode(iife, node); return iife; } else { @@ -193465,6 +177915,35 @@ ${lanes.join("\n")} return statements; } } + function transformConstructorBodyWorker(statementsOut, statementsIn, statementOffset, superPath, superPathDepth, initializerStatements) { + const superStatementIndex = superPath[superPathDepth]; + const superStatement = statementsIn[superStatementIndex]; + addRange(statementsOut, visitNodes2(statementsIn, visitor, isStatement, statementOffset, superStatementIndex - statementOffset)); + if (isTryStatement(superStatement)) { + const tryBlockStatements = []; + transformConstructorBodyWorker( + tryBlockStatements, + superStatement.tryBlock.statements, + /*statementOffset*/ + 0, + superPath, + superPathDepth + 1, + initializerStatements + ); + const tryBlockStatementsArray = factory2.createNodeArray(tryBlockStatements); + setTextRange(tryBlockStatementsArray, superStatement.tryBlock.statements); + statementsOut.push(factory2.updateTryStatement( + superStatement, + factory2.updateBlock(superStatement.tryBlock, tryBlockStatements), + visitNode(superStatement.catchClause, visitor, isCatchClause), + visitNode(superStatement.finallyBlock, visitor, isBlock) + )); + } else { + addRange(statementsOut, visitNodes2(statementsIn, visitor, isStatement, superStatementIndex, 1)); + addRange(statementsOut, initializerStatements); + } + addRange(statementsOut, visitNodes2(statementsIn, visitor, isStatement, superStatementIndex + 1)); + } function visitConstructorDeclaration(node) { enterClassElement(node); const modifiers = visitNodes2(node.modifiers, modifierVisitor, isModifier); @@ -193481,11 +177960,9 @@ ${lanes.join("\n")} false, visitor ); - const superStatementIndex = findSuperStatementIndex(node.body.statements, nonPrologueStart); - if (superStatementIndex >= 0) { - addRange(statements, visitNodes2(node.body.statements, visitor, isStatement, nonPrologueStart, superStatementIndex + 1 - nonPrologueStart)); - addRange(statements, initializerStatements); - addRange(statements, visitNodes2(node.body.statements, visitor, isStatement, superStatementIndex + 1)); + const superStatementIndices = findSuperStatementIndexPath(node.body.statements, nonPrologueStart); + if (superStatementIndices.length > 0) { + transformConstructorBodyWorker(statements, node.body.statements, nonPrologueStart, superStatementIndices, 0, initializerStatements); } else { addRange(statements, initializerStatements); addRange(statements, visitNodes2(node.body.statements, visitor, isStatement)); @@ -193510,7 +177987,7 @@ ${lanes.join("\n")} } return updated; } - function partialTransformClassElement(member, useNamedEvaluation, classInfo2, createDescriptor) { + function partialTransformClassElement(member, classInfo2, createDescriptor) { let referencedName; let name; let initializersName; @@ -193519,11 +177996,7 @@ ${lanes.join("\n")} if (!classInfo2) { const modifiers2 = visitNodes2(member.modifiers, modifierVisitor, isModifier); enterName(); - if (useNamedEvaluation) { - ({ referencedName, name } = visitReferencedPropertyName(member.name)); - } else { - name = visitPropertyName(member.name); - } + name = visitPropertyName(member.name); exitName(); return { modifiers: modifiers2, referencedName, name, initializersName, descriptorName, thisArg }; } @@ -193572,9 +178045,10 @@ ${lanes.join("\n")} get: isPropertyDeclaration(member) || isGetAccessorDeclaration(member) || isMethodDeclaration(member), // 3. If _kind_ is ~field~, ~accessor~, or ~setter~, then ... set: isPropertyDeclaration(member) || isSetAccessorDeclaration(member) - } + }, + metadata: classInfo2.metadataReference }; - const extraInitializers = isStatic(member) ? classInfo2.staticExtraInitializersName ?? (classInfo2.staticExtraInitializersName = factory2.createUniqueName("_staticExtraInitializers", 16 /* Optimistic */)) : classInfo2.instanceExtraInitializersName ?? (classInfo2.instanceExtraInitializersName = factory2.createUniqueName("_instanceExtraInitializers", 16 /* Optimistic */)); + const extraInitializers = isStatic(member) ? classInfo2.staticExtraInitializersName ?? (classInfo2.staticExtraInitializersName = factory2.createUniqueName("_staticExtraInitializers", 16 /* Optimistic */ | 32 /* FileLevel */)) : classInfo2.instanceExtraInitializersName ?? (classInfo2.instanceExtraInitializersName = factory2.createUniqueName("_instanceExtraInitializers", 16 /* Optimistic */ | 32 /* FileLevel */)); if (isMethodOrAccessor(member)) { let descriptor; if (isPrivateIdentifierClassElementDeclaration(member) && createDescriptor) { @@ -193616,11 +178090,7 @@ ${lanes.join("\n")} } if (name === void 0) { enterName(); - if (useNamedEvaluation) { - ({ referencedName, name } = visitReferencedPropertyName(member.name)); - } else { - name = visitPropertyName(member.name); - } + name = visitPropertyName(member.name); exitName(); } if (!some(modifiers) && (isMethodDeclaration(member) || isPropertyDeclaration(member))) { @@ -193630,13 +178100,7 @@ ${lanes.join("\n")} } function visitMethodDeclaration(node) { enterClassElement(node); - const { modifiers, name, descriptorName } = partialTransformClassElement( - node, - /*useNamedEvaluation*/ - false, - classInfo, - createMethodDescriptorObject - ); + const { modifiers, name, descriptorName } = partialTransformClassElement(node, classInfo, createMethodDescriptorObject); if (descriptorName) { exitClassElement(); return finishClassElement(createMethodDescriptorForwarder(modifiers, name, descriptorName), node); @@ -193662,13 +178126,7 @@ ${lanes.join("\n")} } function visitGetAccessorDeclaration(node) { enterClassElement(node); - const { modifiers, name, descriptorName } = partialTransformClassElement( - node, - /*useNamedEvaluation*/ - false, - classInfo, - createGetAccessorDescriptorObject - ); + const { modifiers, name, descriptorName } = partialTransformClassElement(node, classInfo, createGetAccessorDescriptorObject); if (descriptorName) { exitClassElement(); return finishClassElement(createGetAccessorDescriptorForwarder(modifiers, name, descriptorName), node); @@ -193689,13 +178147,7 @@ ${lanes.join("\n")} } function visitSetAccessorDeclaration(node) { enterClassElement(node); - const { modifiers, name, descriptorName } = partialTransformClassElement( - node, - /*useNamedEvaluation*/ - false, - classInfo, - createSetAccessorDescriptorObject - ); + const { modifiers, name, descriptorName } = partialTransformClassElement(node, classInfo, createSetAccessorDescriptorObject); if (descriptorName) { exitClassElement(); return finishClassElement(createSetAccessorDescriptorForwarder(modifiers, name, descriptorName), node); @@ -193708,19 +178160,31 @@ ${lanes.join("\n")} } function visitClassStaticBlockDeclaration(node) { enterClassElement(node); - if (classInfo) - classInfo.hasStaticInitializers = true; - const result = visitEachChild(node, visitor, context); + let result; + if (isClassNamedEvaluationHelperBlock(node)) { + result = visitEachChild(node, visitor, context); + } else if (isClassThisAssignmentBlock(node)) { + const savedClassThis = classThis; + classThis = void 0; + result = visitEachChild(node, visitor, context); + classThis = savedClassThis; + } else { + if (classInfo) + classInfo.hasStaticInitializers = true; + result = visitEachChild(node, visitor, context); + } exitClassElement(); return result; } function visitPropertyDeclaration(node) { + if (isNamedEvaluation(node, isAnonymousClassNeedingAssignedName)) { + node = transformNamedEvaluation(context, node, canIgnoreEmptyStringLiteralInAssignedName(node.initializer)); + } enterClassElement(node); Debug.assert(!isAmbientPropertyDeclaration(node), "Not yet implemented."); - const useNamedEvaluation = isNamedEvaluation(node, isAnonymousClassNeedingAssignedName); - const { modifiers, name, referencedName, initializersName, descriptorName, thisArg } = partialTransformClassElement(node, useNamedEvaluation, classInfo, hasAccessorModifier(node) ? createAccessorPropertyDescriptorObject : void 0); + const { modifiers, name, initializersName, descriptorName, thisArg } = partialTransformClassElement(node, classInfo, hasAccessorModifier(node) ? createAccessorPropertyDescriptorObject : void 0); startLexicalEnvironment(); - let initializer = referencedName ? visitNode(node.initializer, (node2) => namedEvaluationVisitor(node2, referencedName), isExpression) : visitNode(node.initializer, visitor, isExpression); + let initializer = visitNode(node.initializer, visitor, isExpression); if (initializersName) { initializer = emitHelpers().createRunInitializersHelper( thisArg ?? factory2.createThis(), @@ -193850,38 +178314,21 @@ ${lanes.join("\n")} return visitEachChild(node, visitor, context); } function visitParameterDeclaration(node) { - let updated; if (isNamedEvaluation(node, isAnonymousClassNeedingAssignedName)) { - const assignedName = getAssignedNameOfIdentifier(node.name, node.initializer); - const name = visitNode(node.name, visitor, isBindingName); - const initializer = visitNode(node.initializer, (node2) => namedEvaluationVisitor(node2, assignedName), isExpression); - updated = factory2.updateParameterDeclaration( - node, - /*modifiers*/ - void 0, - /*dotDotDotToken*/ - void 0, - name, - /*questionToken*/ - void 0, - /*type*/ - void 0, - initializer - ); - } else { - updated = factory2.updateParameterDeclaration( - node, - /*modifiers*/ - void 0, - node.dotDotDotToken, - visitNode(node.name, visitor, isBindingName), - /*questionToken*/ - void 0, - /*type*/ - void 0, - visitNode(node.initializer, visitor, isExpression) - ); + node = transformNamedEvaluation(context, node, canIgnoreEmptyStringLiteralInAssignedName(node.initializer)); } + const updated = factory2.updateParameterDeclaration( + node, + /*modifiers*/ + void 0, + node.dotDotDotToken, + visitNode(node.name, visitor, isBindingName), + /*questionToken*/ + void 0, + /*type*/ + void 0, + visitNode(node.initializer, visitor, isExpression) + ); if (updated !== node) { setCommentRange(updated, node); setTextRange(updated, moveRangePastModifiers(node)); @@ -193893,6 +178340,14 @@ ${lanes.join("\n")} function isAnonymousClassNeedingAssignedName(node) { return isClassExpression(node) && !node.name && isDecoratedClassLike(node); } + function canIgnoreEmptyStringLiteralInAssignedName(node) { + const innerExpression = skipOuterExpressions(node); + return isClassExpression(innerExpression) && !innerExpression.name && !classOrConstructorParameterIsDecorated( + /*useLegacyDecorators*/ + false, + innerExpression + ); + } function visitForStatement(node) { return factory2.updateForStatement( node, @@ -193913,10 +178368,8 @@ ${lanes.join("\n")} } if (isAssignmentExpression(node)) { if (isNamedEvaluation(node, isAnonymousClassNeedingAssignedName)) { - const assignedName = getAssignedNameOfIdentifier(node.left, node.right); - const left = visitNode(node.left, visitor, isExpression); - const right = visitNode(node.right, (node2) => namedEvaluationVisitor(node2, assignedName), isExpression); - return factory2.updateBinaryExpression(node, left, node.operatorToken, right); + node = transformNamedEvaluation(context, node, canIgnoreEmptyStringLiteralInAssignedName(node.right)); + return visitEachChild(node, visitor, context); } if (isSuperProperty(node.left) && classThis && classSuper) { let setterName = isElementAccessExpression(node.left) ? visitNode(node.left.argumentExpression, visitor, isExpression) : isIdentifier(node.left.name) ? factory2.createStringLiteralFromNode(node.left.name) : void 0; @@ -194036,43 +178489,19 @@ ${lanes.join("\n")} } function visitPropertyAssignment(node) { if (isNamedEvaluation(node, isAnonymousClassNeedingAssignedName)) { - const { referencedName, name } = visitReferencedPropertyName(node.name); - const initializer = visitNode(node.initializer, (node2) => namedEvaluationVisitor(node2, referencedName), isExpression); - return factory2.updatePropertyAssignment(node, name, initializer); + node = transformNamedEvaluation(context, node, canIgnoreEmptyStringLiteralInAssignedName(node.initializer)); } return visitEachChild(node, visitor, context); } function visitVariableDeclaration(node) { if (isNamedEvaluation(node, isAnonymousClassNeedingAssignedName)) { - const assignedName = getAssignedNameOfIdentifier(node.name, node.initializer); - const name = visitNode(node.name, visitor, isBindingName); - const initializer = visitNode(node.initializer, (node2) => namedEvaluationVisitor(node2, assignedName), isExpression); - return factory2.updateVariableDeclaration( - node, - name, - /*exclamationToken*/ - void 0, - /*type*/ - void 0, - initializer - ); + node = transformNamedEvaluation(context, node, canIgnoreEmptyStringLiteralInAssignedName(node.initializer)); } return visitEachChild(node, visitor, context); } function visitBindingElement(node) { if (isNamedEvaluation(node, isAnonymousClassNeedingAssignedName)) { - const assignedName = getAssignedNameOfIdentifier(node.name, node.initializer); - const propertyName = visitNode(node.propertyName, visitor, isPropertyName); - const name = visitNode(node.name, visitor, isBindingName); - const initializer = visitNode(node.initializer, (node2) => namedEvaluationVisitor(node2, assignedName), isExpression); - return factory2.updateBindingElement( - node, - /*dotDotDotToken*/ - void 0, - propertyName, - name, - initializer - ); + node = transformNamedEvaluation(context, node, canIgnoreEmptyStringLiteralInAssignedName(node.initializer)); } return visitEachChild(node, visitor, context); } @@ -194109,14 +178538,11 @@ ${lanes.join("\n")} /*excludeCompoundAssignment*/ true )) { - const assignmentTarget = visitDestructuringAssignmentTarget(node.left); - let initializer; if (isNamedEvaluation(node, isAnonymousClassNeedingAssignedName)) { - const assignedName = getAssignedNameOfIdentifier(node.left, node.right); - initializer = visitNode(node.right, (node2) => namedEvaluationVisitor(node2, assignedName), isExpression); - } else { - initializer = visitNode(node.right, visitor, isExpression); + node = transformNamedEvaluation(context, node, canIgnoreEmptyStringLiteralInAssignedName(node.right)); } + const assignmentTarget = visitDestructuringAssignmentTarget(node.left); + const initializer = visitNode(node.right, visitor, isExpression); return factory2.updateBinaryExpression(node, assignmentTarget, node.operatorToken, initializer); } else { return visitDestructuringAssignmentTarget(node); @@ -194155,10 +178581,7 @@ ${lanes.join("\n")} } function visitShorthandAssignmentProperty(node) { if (isNamedEvaluation(node, isAnonymousClassNeedingAssignedName)) { - const assignedName = getAssignedNameOfIdentifier(node.name, node.objectAssignmentInitializer); - const name = visitNode(node.name, visitor, isIdentifier); - const objectAssignmentInitializer = visitNode(node.objectAssignmentInitializer, (node2) => namedEvaluationVisitor(node2, assignedName), isExpression); - return factory2.updateShorthandPropertyAssignment(node, name, objectAssignmentInitializer); + node = transformNamedEvaluation(context, node, canIgnoreEmptyStringLiteralInAssignedName(node.objectAssignmentInitializer)); } return visitEachChild(node, visitor, context); } @@ -194190,20 +178613,17 @@ ${lanes.join("\n")} } function visitExportAssignment(node) { if (isNamedEvaluation(node, isAnonymousClassNeedingAssignedName)) { - const referencedName = factory2.createStringLiteral(node.isExportEquals ? "" : "default"); - const modifiers = visitNodes2(node.modifiers, modifierVisitor, isModifier); - const expression = visitNode(node.expression, (node2) => namedEvaluationVisitor(node2, referencedName), isExpression); - return factory2.updateExportAssignment(node, modifiers, expression); + node = transformNamedEvaluation(context, node, canIgnoreEmptyStringLiteralInAssignedName(node.expression)); } return visitEachChild(node, visitor, context); } - function visitParenthesizedExpression(node, discarded, referencedName) { - const visitorFunc = discarded ? discardedValueVisitor : referencedName ? (node2) => namedEvaluationVisitor(node2, referencedName) : visitor; + function visitParenthesizedExpression(node, discarded) { + const visitorFunc = discarded ? discardedValueVisitor : visitor; const expression = visitNode(node.expression, visitorFunc, isExpression); return factory2.updateParenthesizedExpression(node, expression); } - function visitPartiallyEmittedExpression(node, discarded, referencedName) { - const visitorFunc = discarded ? discardedValueVisitor : referencedName ? (node2) => namedEvaluationVisitor(node2, referencedName) : visitor; + function visitPartiallyEmittedExpression(node, discarded) { + const visitorFunc = discarded ? discardedValueVisitor : visitor; const expression = visitNode(node.expression, visitorFunc, isExpression); return factory2.updatePartiallyEmittedExpression(node, expression); } @@ -194231,6 +178651,17 @@ ${lanes.join("\n")} function transformDecorator(decorator) { const expression = visitNode(decorator.expression, visitor, isExpression); setEmitFlags(expression, 3072 /* NoComments */); + const innerExpression = skipOuterExpressions(expression); + if (isAccessExpression(innerExpression)) { + const { target, thisArg } = factory2.createCallBinding( + expression, + hoistVariableDeclaration, + languageVersion, + /*cacheIdentifiers*/ + true + ); + return factory2.restoreOuterExpressions(expression, factory2.createFunctionBindCall(target, thisArg, [])); + } return expression; } function createDescriptorMethod(original, name, modifiers, asteriskToken, kind, parameters, body) { @@ -194416,9 +178847,59 @@ ${lanes.join("\n")} ]) ); } - function getAssignedNameOfIdentifier(name, initializer) { - const originalClass = getOriginalNode(initializer, isClassLike); - return originalClass && !originalClass.name && hasSyntacticModifier(originalClass, 1024 /* Default */) ? factory2.createStringLiteral("default") : factory2.createStringLiteralFromNode(name); + function createMetadata(name, classSuper2) { + const varDecl = factory2.createVariableDeclaration( + name, + /*exclamationToken*/ + void 0, + /*type*/ + void 0, + factory2.createConditionalExpression( + factory2.createLogicalAnd( + factory2.createTypeCheck(factory2.createIdentifier("Symbol"), "function"), + factory2.createPropertyAccessExpression(factory2.createIdentifier("Symbol"), "metadata") + ), + factory2.createToken(58 /* QuestionToken */), + factory2.createCallExpression( + factory2.createPropertyAccessExpression(factory2.createIdentifier("Object"), "create"), + /*typeArguments*/ + void 0, + [classSuper2 ? createSymbolMetadataReference(classSuper2) : factory2.createNull()] + ), + factory2.createToken(59 /* ColonToken */), + factory2.createVoidZero() + ) + ); + return factory2.createVariableStatement( + /*modifiers*/ + void 0, + factory2.createVariableDeclarationList([varDecl], 2 /* Const */) + ); + } + function createSymbolMetadata(target, value) { + const defineProperty = factory2.createObjectDefinePropertyCall( + target, + factory2.createPropertyAccessExpression(factory2.createIdentifier("Symbol"), "metadata"), + factory2.createPropertyDescriptor( + { configurable: true, writable: true, enumerable: true, value }, + /*singleLine*/ + true + ) + ); + return setEmitFlags( + factory2.createIfStatement(value, factory2.createExpressionStatement(defineProperty)), + 1 /* SingleLine */ + ); + } + function createSymbolMetadataReference(classSuper2) { + return factory2.createBinaryExpression( + factory2.createElementAccessExpression( + classSuper2, + factory2.createPropertyAccessExpression(factory2.createIdentifier("Symbol"), "metadata") + ), + 61 /* QuestionQuestionToken */, + factory2.createNull() + ); } } var init_esDecorators = __esm({ @@ -194502,34 +178983,34 @@ ${lanes.join("\n")} switch (node.kind) { case 134 /* AsyncKeyword */: return void 0; - case 222 /* AwaitExpression */: + case 223 /* AwaitExpression */: return visitAwaitExpression(node); - case 173 /* MethodDeclaration */: + case 174 /* MethodDeclaration */: return doWithContext(1 /* NonTopLevel */ | 2 /* HasLexicalThis */, visitMethodDeclaration, node); - case 261 /* FunctionDeclaration */: + case 262 /* FunctionDeclaration */: return doWithContext(1 /* NonTopLevel */ | 2 /* HasLexicalThis */, visitFunctionDeclaration, node); - case 217 /* FunctionExpression */: + case 218 /* FunctionExpression */: return doWithContext(1 /* NonTopLevel */ | 2 /* HasLexicalThis */, visitFunctionExpression, node); - case 218 /* ArrowFunction */: + case 219 /* ArrowFunction */: return doWithContext(1 /* NonTopLevel */, visitArrowFunction, node); - case 210 /* PropertyAccessExpression */: + case 211 /* PropertyAccessExpression */: if (capturedSuperProperties && isPropertyAccessExpression(node) && node.expression.kind === 108 /* SuperKeyword */) { capturedSuperProperties.add(node.name.escapedText); } return visitEachChild(node, visitor, context); - case 211 /* ElementAccessExpression */: + case 212 /* ElementAccessExpression */: if (capturedSuperProperties && node.expression.kind === 108 /* SuperKeyword */) { hasSuperElementAccess = true; } return visitEachChild(node, visitor, context); - case 176 /* GetAccessor */: + case 177 /* GetAccessor */: return doWithContext(1 /* NonTopLevel */ | 2 /* HasLexicalThis */, visitGetAccessorDeclaration, node); - case 177 /* SetAccessor */: + case 178 /* SetAccessor */: return doWithContext(1 /* NonTopLevel */ | 2 /* HasLexicalThis */, visitSetAccessorDeclaration, node); - case 175 /* Constructor */: + case 176 /* Constructor */: return doWithContext(1 /* NonTopLevel */ | 2 /* HasLexicalThis */, visitConstructorDeclaration, node); - case 262 /* ClassDeclaration */: - case 230 /* ClassExpression */: + case 263 /* ClassDeclaration */: + case 231 /* ClassExpression */: return doWithContext(1 /* NonTopLevel */ | 2 /* HasLexicalThis */, visitDefault, node); default: return visitEachChild(node, visitor, context); @@ -194538,27 +179019,27 @@ ${lanes.join("\n")} function asyncBodyVisitor(node) { if (isNodeWithPossibleHoistedDeclaration(node)) { switch (node.kind) { - case 242 /* VariableStatement */: + case 243 /* VariableStatement */: return visitVariableStatementInAsyncBody(node); - case 247 /* ForStatement */: + case 248 /* ForStatement */: return visitForStatementInAsyncBody(node); - case 248 /* ForInStatement */: + case 249 /* ForInStatement */: return visitForInStatementInAsyncBody(node); - case 249 /* ForOfStatement */: + case 250 /* ForOfStatement */: return visitForOfStatementInAsyncBody(node); - case 298 /* CatchClause */: + case 299 /* CatchClause */: return visitCatchClauseInAsyncBody(node); - case 240 /* Block */: - case 254 /* SwitchStatement */: - case 268 /* CaseBlock */: - case 295 /* CaseClause */: - case 296 /* DefaultClause */: - case 257 /* TryStatement */: - case 245 /* DoStatement */: - case 246 /* WhileStatement */: - case 244 /* IfStatement */: - case 253 /* WithStatement */: - case 255 /* LabeledStatement */: + case 241 /* Block */: + case 255 /* SwitchStatement */: + case 269 /* CaseBlock */: + case 296 /* CaseClause */: + case 297 /* DefaultClause */: + case 258 /* TryStatement */: + case 246 /* DoStatement */: + case 247 /* WhileStatement */: + case 245 /* IfStatement */: + case 254 /* WithStatement */: + case 256 /* LabeledStatement */: return visitEachChild(node, asyncBodyVisitor, context); default: return Debug.assertNever(node, "Unhandled node."); @@ -194751,7 +179232,7 @@ ${lanes.join("\n")} } } function isVariableDeclarationListWithCollidingName(node) { - return !!node && isVariableDeclarationList(node) && !(node.flags & 3 /* BlockScoped */) && node.declarations.some(collidesWithParameterName); + return !!node && isVariableDeclarationList(node) && !(node.flags & 7 /* BlockScoped */) && node.declarations.some(collidesWithParameterName); } function visitVariableDeclarationListWithCollidingNames(node, hasReceiver) { hoistVariableDeclarationList(node); @@ -194835,7 +179316,7 @@ ${lanes.join("\n")} const original = getOriginalNode(node, isFunctionLike); const nodeType = original.type; const promiseConstructor = languageVersion < 2 /* ES2015 */ ? getPromiseConstructor(nodeType) : void 0; - const isArrowFunction2 = node.kind === 218 /* ArrowFunction */; + const isArrowFunction2 = node.kind === 219 /* ArrowFunction */; const hasLexicalArguments = (resolver.getNodeCheckFlags(node) & 512 /* CaptureArguments */) !== 0; const savedEnclosingFunctionParameterNames = enclosingFunctionParameterNames; enclosingFunctionParameterNames = /* @__PURE__ */ new Set(); @@ -194934,15 +179415,15 @@ ${lanes.join("\n")} function enableSubstitutionForAsyncMethodsWithSuper() { if ((enabledSubstitutions & 1 /* AsyncMethodsWithSuper */) === 0) { enabledSubstitutions |= 1 /* AsyncMethodsWithSuper */; - context.enableSubstitution(212 /* CallExpression */); - context.enableSubstitution(210 /* PropertyAccessExpression */); - context.enableSubstitution(211 /* ElementAccessExpression */); - context.enableEmitNotification(262 /* ClassDeclaration */); - context.enableEmitNotification(173 /* MethodDeclaration */); - context.enableEmitNotification(176 /* GetAccessor */); - context.enableEmitNotification(177 /* SetAccessor */); - context.enableEmitNotification(175 /* Constructor */); - context.enableEmitNotification(242 /* VariableStatement */); + context.enableSubstitution(213 /* CallExpression */); + context.enableSubstitution(211 /* PropertyAccessExpression */); + context.enableSubstitution(212 /* ElementAccessExpression */); + context.enableEmitNotification(263 /* ClassDeclaration */); + context.enableEmitNotification(174 /* MethodDeclaration */); + context.enableEmitNotification(177 /* GetAccessor */); + context.enableEmitNotification(178 /* SetAccessor */); + context.enableEmitNotification(176 /* Constructor */); + context.enableEmitNotification(243 /* VariableStatement */); } } function onEmitNode(hint, node, emitCallback) { @@ -194973,11 +179454,11 @@ ${lanes.join("\n")} } function substituteExpression(node) { switch (node.kind) { - case 210 /* PropertyAccessExpression */: + case 211 /* PropertyAccessExpression */: return substitutePropertyAccessExpression(node); - case 211 /* ElementAccessExpression */: + case 212 /* ElementAccessExpression */: return substituteElementAccessExpression(node); - case 212 /* CallExpression */: + case 213 /* CallExpression */: return substituteCallExpression(node); } return node; @@ -195021,7 +179502,7 @@ ${lanes.join("\n")} } function isSuperContainer(node) { const kind = node.kind; - return kind === 262 /* ClassDeclaration */ || kind === 175 /* Constructor */ || kind === 173 /* MethodDeclaration */ || kind === 176 /* GetAccessor */ || kind === 177 /* SetAccessor */; + return kind === 263 /* ClassDeclaration */ || kind === 176 /* Constructor */ || kind === 174 /* MethodDeclaration */ || kind === 177 /* GetAccessor */ || kind === 178 /* SetAccessor */; } function createSuperElementAccessInAsyncMethod(argumentExpression, location) { if (enclosingSuperContainerFlags & 256 /* MethodWithSuperPropertyAssignmentInAsync */) { @@ -195267,119 +179748,119 @@ ${lanes.join("\n")} return node; } switch (node.kind) { - case 222 /* AwaitExpression */: + case 223 /* AwaitExpression */: return visitAwaitExpression(node); - case 228 /* YieldExpression */: + case 229 /* YieldExpression */: return visitYieldExpression(node); - case 252 /* ReturnStatement */: + case 253 /* ReturnStatement */: return visitReturnStatement(node); - case 255 /* LabeledStatement */: + case 256 /* LabeledStatement */: return visitLabeledStatement(node); - case 209 /* ObjectLiteralExpression */: + case 210 /* ObjectLiteralExpression */: return visitObjectLiteralExpression(node); - case 225 /* BinaryExpression */: + case 226 /* BinaryExpression */: return visitBinaryExpression(node, expressionResultIsUnused2); - case 360 /* CommaListExpression */: + case 361 /* CommaListExpression */: return visitCommaListExpression(node, expressionResultIsUnused2); - case 298 /* CatchClause */: + case 299 /* CatchClause */: return visitCatchClause(node); - case 242 /* VariableStatement */: + case 243 /* VariableStatement */: return visitVariableStatement(node); - case 259 /* VariableDeclaration */: + case 260 /* VariableDeclaration */: return visitVariableDeclaration(node); - case 245 /* DoStatement */: - case 246 /* WhileStatement */: - case 248 /* ForInStatement */: + case 246 /* DoStatement */: + case 247 /* WhileStatement */: + case 249 /* ForInStatement */: return doWithHierarchyFacts( visitDefault, node, 0 /* IterationStatementExcludes */, 2 /* IterationStatementIncludes */ ); - case 249 /* ForOfStatement */: + case 250 /* ForOfStatement */: return visitForOfStatement( node, /*outermostLabeledStatement*/ void 0 ); - case 247 /* ForStatement */: + case 248 /* ForStatement */: return doWithHierarchyFacts( visitForStatement, node, 0 /* IterationStatementExcludes */, 2 /* IterationStatementIncludes */ ); - case 221 /* VoidExpression */: + case 222 /* VoidExpression */: return visitVoidExpression(node); - case 175 /* Constructor */: + case 176 /* Constructor */: return doWithHierarchyFacts( visitConstructorDeclaration, node, 2 /* ClassOrFunctionExcludes */, 1 /* ClassOrFunctionIncludes */ ); - case 173 /* MethodDeclaration */: + case 174 /* MethodDeclaration */: return doWithHierarchyFacts( visitMethodDeclaration, node, 2 /* ClassOrFunctionExcludes */, 1 /* ClassOrFunctionIncludes */ ); - case 176 /* GetAccessor */: + case 177 /* GetAccessor */: return doWithHierarchyFacts( visitGetAccessorDeclaration, node, 2 /* ClassOrFunctionExcludes */, 1 /* ClassOrFunctionIncludes */ ); - case 177 /* SetAccessor */: + case 178 /* SetAccessor */: return doWithHierarchyFacts( visitSetAccessorDeclaration, node, 2 /* ClassOrFunctionExcludes */, 1 /* ClassOrFunctionIncludes */ ); - case 261 /* FunctionDeclaration */: + case 262 /* FunctionDeclaration */: return doWithHierarchyFacts( visitFunctionDeclaration, node, 2 /* ClassOrFunctionExcludes */, 1 /* ClassOrFunctionIncludes */ ); - case 217 /* FunctionExpression */: + case 218 /* FunctionExpression */: return doWithHierarchyFacts( visitFunctionExpression, node, 2 /* ClassOrFunctionExcludes */, 1 /* ClassOrFunctionIncludes */ ); - case 218 /* ArrowFunction */: + case 219 /* ArrowFunction */: return doWithHierarchyFacts( visitArrowFunction, node, 2 /* ArrowFunctionExcludes */, 0 /* ArrowFunctionIncludes */ ); - case 168 /* Parameter */: + case 169 /* Parameter */: return visitParameter(node); - case 243 /* ExpressionStatement */: + case 244 /* ExpressionStatement */: return visitExpressionStatement(node); - case 216 /* ParenthesizedExpression */: + case 217 /* ParenthesizedExpression */: return visitParenthesizedExpression(node, expressionResultIsUnused2); - case 214 /* TaggedTemplateExpression */: + case 215 /* TaggedTemplateExpression */: return visitTaggedTemplateExpression(node); - case 210 /* PropertyAccessExpression */: + case 211 /* PropertyAccessExpression */: if (capturedSuperProperties && isPropertyAccessExpression(node) && node.expression.kind === 108 /* SuperKeyword */) { capturedSuperProperties.add(node.name.escapedText); } return visitEachChild(node, visitor, context); - case 211 /* ElementAccessExpression */: + case 212 /* ElementAccessExpression */: if (capturedSuperProperties && node.expression.kind === 108 /* SuperKeyword */) { hasSuperElementAccess = true; } return visitEachChild(node, visitor, context); - case 262 /* ClassDeclaration */: - case 230 /* ClassExpression */: + case 263 /* ClassDeclaration */: + case 231 /* ClassExpression */: return doWithHierarchyFacts( visitDefault, node, @@ -195455,16 +179936,19 @@ ${lanes.join("\n")} } function visitReturnStatement(node) { if (enclosingFunctionFlags & 2 /* Async */ && enclosingFunctionFlags & 1 /* Generator */) { - return factory2.updateReturnStatement(node, createDownlevelAwait( - node.expression ? visitNode(node.expression, visitor, isExpression) : factory2.createVoidZero() - )); + return factory2.updateReturnStatement( + node, + createDownlevelAwait( + node.expression ? visitNode(node.expression, visitor, isExpression) : factory2.createVoidZero() + ) + ); } return visitEachChild(node, visitor, context); } function visitLabeledStatement(node) { if (enclosingFunctionFlags & 2 /* Async */) { const statement = unwrapInnermostStatementOfLabel(node); - if (statement.kind === 249 /* ForOfStatement */ && statement.awaitModifier) { + if (statement.kind === 250 /* ForOfStatement */ && statement.awaitModifier) { return visitForOfStatement(statement, node); } return factory2.restoreEnclosingLabel(visitNode(statement, visitor, isStatement, factory2.liftToBlock), node); @@ -195475,7 +179959,7 @@ ${lanes.join("\n")} let chunkObject; const objects = []; for (const e of elements) { - if (e.kind === 304 /* SpreadAssignment */) { + if (e.kind === 305 /* SpreadAssignment */) { if (chunkObject) { objects.push(factory2.createObjectLiteralExpression(chunkObject)); chunkObject = void 0; @@ -195483,7 +179967,10 @@ ${lanes.join("\n")} const target = e.expression; objects.push(visitNode(target, visitor, isExpression)); } else { - chunkObject = append(chunkObject, e.kind === 302 /* PropertyAssignment */ ? factory2.createPropertyAssignment(e.name, visitNode(e.initializer, visitor, isExpression)) : visitNode(e, visitor, isObjectLiteralElementLike)); + chunkObject = append( + chunkObject, + e.kind === 303 /* PropertyAssignment */ ? factory2.createPropertyAssignment(e.name, visitNode(e.initializer, visitor, isExpression)) : visitNode(e, visitor, isObjectLiteralElementLike) + ); } } if (chunkObject) { @@ -195494,7 +179981,7 @@ ${lanes.join("\n")} function visitObjectLiteralExpression(node) { if (node.transformFlags & 65536 /* ContainsObjectRestOrSpread */) { const objects = chunkObjectLiteralElements(node.properties); - if (objects.length && objects[0].kind !== 209 /* ObjectLiteralExpression */) { + if (objects.length && objects[0].kind !== 210 /* ObjectLiteralExpression */) { objects.unshift(factory2.createObjectLiteralExpression()); } let expression = objects[0]; @@ -195522,13 +180009,16 @@ ${lanes.join("\n")} ); exportedVariableStatement = false; const visited = visitEachChild(node, visitor, context); - const statement = concatenate(visited.statements, taggedTemplateStringDeclarations && [ - factory2.createVariableStatement( - /*modifiers*/ - void 0, - factory2.createVariableDeclarationList(taggedTemplateStringDeclarations) - ) - ]); + const statement = concatenate( + visited.statements, + taggedTemplateStringDeclarations && [ + factory2.createVariableStatement( + /*modifiers*/ + void 0, + factory2.createVariableDeclarationList(taggedTemplateStringDeclarations) + ) + ] + ); const result = factory2.updateSourceFile(visited, setTextRange(factory2.createNodeArray(statement), node.statements)); exitSubtree(ancestorFacts); return result; @@ -195621,7 +180111,7 @@ ${lanes.join("\n")} return visitEachChild(node, visitor, context); } function visitVariableStatement(node) { - if (hasSyntacticModifier(node, 1 /* Export */)) { + if (hasSyntacticModifier(node, 32 /* Export */)) { const savedExportedVariableStatement = exportedVariableStatement; exportedVariableStatement = true; const visited = visitEachChild(node, visitor, context); @@ -196263,15 +180753,15 @@ ${lanes.join("\n")} function enableSubstitutionForAsyncMethodsWithSuper() { if ((enabledSubstitutions & 1 /* AsyncMethodsWithSuper */) === 0) { enabledSubstitutions |= 1 /* AsyncMethodsWithSuper */; - context.enableSubstitution(212 /* CallExpression */); - context.enableSubstitution(210 /* PropertyAccessExpression */); - context.enableSubstitution(211 /* ElementAccessExpression */); - context.enableEmitNotification(262 /* ClassDeclaration */); - context.enableEmitNotification(173 /* MethodDeclaration */); - context.enableEmitNotification(176 /* GetAccessor */); - context.enableEmitNotification(177 /* SetAccessor */); - context.enableEmitNotification(175 /* Constructor */); - context.enableEmitNotification(242 /* VariableStatement */); + context.enableSubstitution(213 /* CallExpression */); + context.enableSubstitution(211 /* PropertyAccessExpression */); + context.enableSubstitution(212 /* ElementAccessExpression */); + context.enableEmitNotification(263 /* ClassDeclaration */); + context.enableEmitNotification(174 /* MethodDeclaration */); + context.enableEmitNotification(177 /* GetAccessor */); + context.enableEmitNotification(178 /* SetAccessor */); + context.enableEmitNotification(176 /* Constructor */); + context.enableEmitNotification(243 /* VariableStatement */); } } function onEmitNode(hint, node, emitCallback) { @@ -196302,11 +180792,11 @@ ${lanes.join("\n")} } function substituteExpression(node) { switch (node.kind) { - case 210 /* PropertyAccessExpression */: + case 211 /* PropertyAccessExpression */: return substitutePropertyAccessExpression(node); - case 211 /* ElementAccessExpression */: + case 212 /* ElementAccessExpression */: return substituteElementAccessExpression(node); - case 212 /* CallExpression */: + case 213 /* CallExpression */: return substituteCallExpression(node); } return node; @@ -196350,7 +180840,7 @@ ${lanes.join("\n")} } function isSuperContainer(node) { const kind = node.kind; - return kind === 262 /* ClassDeclaration */ || kind === 175 /* Constructor */ || kind === 173 /* MethodDeclaration */ || kind === 176 /* GetAccessor */ || kind === 177 /* SetAccessor */; + return kind === 263 /* ClassDeclaration */ || kind === 176 /* Constructor */ || kind === 174 /* MethodDeclaration */ || kind === 177 /* GetAccessor */ || kind === 178 /* SetAccessor */; } function createSuperElementAccessInAsyncMethod(argumentExpression, location) { if (enclosingSuperContainerFlags & 256 /* MethodWithSuperPropertyAssignmentInAsync */) { @@ -196401,7 +180891,7 @@ ${lanes.join("\n")} return node; } switch (node.kind) { - case 298 /* CatchClause */: + case 299 /* CatchClause */: return visitCatchClause(node); default: return visitEachChild(node, visitor, context); @@ -196446,7 +180936,7 @@ ${lanes.join("\n")} return node; } switch (node.kind) { - case 212 /* CallExpression */: { + case 213 /* CallExpression */: { const updated = visitNonOptionalCallExpression( node, /*captureThisArg*/ @@ -196455,8 +180945,8 @@ ${lanes.join("\n")} Debug.assertNotNode(updated, isSyntheticReference); return updated; } - case 210 /* PropertyAccessExpression */: - case 211 /* ElementAccessExpression */: + case 211 /* PropertyAccessExpression */: + case 212 /* ElementAccessExpression */: if (isOptionalChain(node)) { const updated = visitOptionalExpression( node, @@ -196469,12 +180959,12 @@ ${lanes.join("\n")} return updated; } return visitEachChild(node, visitor, context); - case 225 /* BinaryExpression */: + case 226 /* BinaryExpression */: if (node.operatorToken.kind === 61 /* QuestionQuestionToken */) { return transformNullishCoalescingExpression(node); } return visitEachChild(node, visitor, context); - case 219 /* DeleteExpression */: + case 220 /* DeleteExpression */: return visitDeleteExpression(node); default: return visitEachChild(node, visitor, context); @@ -196512,7 +181002,7 @@ ${lanes.join("\n")} thisArg = expression; } } - expression = node.kind === 210 /* PropertyAccessExpression */ ? factory2.updatePropertyAccessExpression(node, expression, visitNode(node.name, visitor, isIdentifier)) : factory2.updateElementAccessExpression(node, expression, visitNode(node.argumentExpression, visitor, isExpression)); + expression = node.kind === 211 /* PropertyAccessExpression */ ? factory2.updatePropertyAccessExpression(node, expression, visitNode(node.name, visitor, isIdentifier)) : factory2.updateElementAccessExpression(node, expression, visitNode(node.argumentExpression, visitor, isExpression)); return thisArg ? factory2.createSyntheticReferenceExpression(expression, thisArg) : expression; } function visitNonOptionalCallExpression(node, captureThisArg) { @@ -196548,12 +181038,12 @@ ${lanes.join("\n")} } function visitNonOptionalExpression(node, captureThisArg, isDelete) { switch (node.kind) { - case 216 /* ParenthesizedExpression */: + case 217 /* ParenthesizedExpression */: return visitNonOptionalParenthesizedExpression(node, captureThisArg, isDelete); - case 210 /* PropertyAccessExpression */: - case 211 /* ElementAccessExpression */: + case 211 /* PropertyAccessExpression */: + case 212 /* ElementAccessExpression */: return visitNonOptionalPropertyOrElementAccessExpression(node, captureThisArg, isDelete); - case 212 /* CallExpression */: + case 213 /* CallExpression */: return visitNonOptionalCallExpression(node, captureThisArg); default: return visitNode(node, visitor, isExpression); @@ -196579,8 +181069,8 @@ ${lanes.join("\n")} for (let i = 0; i < chain.length; i++) { const segment = chain[i]; switch (segment.kind) { - case 210 /* PropertyAccessExpression */: - case 211 /* ElementAccessExpression */: + case 211 /* PropertyAccessExpression */: + case 212 /* ElementAccessExpression */: if (i === chain.length - 1 && captureThisArg) { if (!isSimpleCopiableExpression(rightExpression)) { thisArg = factory2.createTempVariable(hoistVariableDeclaration); @@ -196589,9 +181079,9 @@ ${lanes.join("\n")} thisArg = rightExpression; } } - rightExpression = segment.kind === 210 /* PropertyAccessExpression */ ? factory2.createPropertyAccessExpression(rightExpression, visitNode(segment.name, visitor, isIdentifier)) : factory2.createElementAccessExpression(rightExpression, visitNode(segment.argumentExpression, visitor, isExpression)); + rightExpression = segment.kind === 211 /* PropertyAccessExpression */ ? factory2.createPropertyAccessExpression(rightExpression, visitNode(segment.name, visitor, isIdentifier)) : factory2.createElementAccessExpression(rightExpression, visitNode(segment.argumentExpression, visitor, isExpression)); break; - case 212 /* CallExpression */: + case 213 /* CallExpression */: if (i === 0 && leftThisArg) { if (!isGeneratedIdentifier(leftThisArg)) { leftThisArg = factory2.cloneNode(leftThisArg); @@ -196666,15 +181156,18 @@ ${lanes.join("\n")} right = factory2.createTempVariable(hoistVariableDeclaration); left = factory2.createAssignment(right, left); } - return setTextRange(factory2.createConditionalExpression( - createNotNullCondition(left, right), - /*questionToken*/ - void 0, - right, - /*colonToken*/ - void 0, - visitNode(node.right, visitor, isExpression) - ), node); + return setTextRange( + factory2.createConditionalExpression( + createNotNullCondition(left, right), + /*questionToken*/ + void 0, + right, + /*colonToken*/ + void 0, + visitNode(node.right, visitor, isExpression) + ), + node + ); } function visitDeleteExpression(node) { return isOptionalChain(skipParentheses(node.expression)) ? setOriginalNode(visitNonOptionalExpression( @@ -196774,22 +181267,639 @@ ${lanes.join("\n")} // src/compiler/transformers/esnext.ts function transformESNext(context) { + const { + factory: factory2, + getEmitHelperFactory: emitHelpers, + hoistVariableDeclaration, + startLexicalEnvironment, + endLexicalEnvironment + } = context; + let exportBindings; + let exportVars; + let defaultExportBinding; + let exportEqualsBinding; return chainBundle(context, transformSourceFile); function transformSourceFile(node) { if (node.isDeclarationFile) { return node; } - return visitEachChild(node, visitor, context); + const visited = visitNode(node, visitor, isSourceFile); + addEmitHelpers(visited, context.readEmitHelpers()); + exportVars = void 0; + exportBindings = void 0; + defaultExportBinding = void 0; + return visited; } function visitor(node) { if ((node.transformFlags & 4 /* ContainsESNext */) === 0) { return node; } switch (node.kind) { + case 312 /* SourceFile */: + return visitSourceFile(node); + case 241 /* Block */: + return visitBlock(node); + case 248 /* ForStatement */: + return visitForStatement(node); + case 250 /* ForOfStatement */: + return visitForOfStatement(node); + case 255 /* SwitchStatement */: + return visitSwitchStatement(node); default: return visitEachChild(node, visitor, context); } } + function visitSourceFile(node) { + const usingKind = getUsingKindOfStatements(node.statements); + if (usingKind) { + startLexicalEnvironment(); + exportBindings = new IdentifierNameMap(); + exportVars = []; + const prologueCount = countPrologueStatements(node.statements); + const topLevelStatements = []; + addRange(topLevelStatements, visitArray(node.statements, visitor, isStatement, 0, prologueCount)); + let pos = prologueCount; + while (pos < node.statements.length) { + const statement = node.statements[pos]; + if (getUsingKind(statement) !== 0 /* None */) { + if (pos > prologueCount) { + addRange(topLevelStatements, visitNodes2(node.statements, visitor, isStatement, prologueCount, pos - prologueCount)); + } + break; + } + pos++; + } + Debug.assert(pos < node.statements.length, "Should have encountered at least one 'using' statement."); + const envBinding = createEnvBinding(); + const bodyStatements = transformUsingDeclarations(node.statements, pos, node.statements.length, envBinding, topLevelStatements); + if (exportBindings.size) { + append( + topLevelStatements, + factory2.createExportDeclaration( + /*modifiers*/ + void 0, + /*isTypeOnly*/ + false, + factory2.createNamedExports(arrayFrom(exportBindings.values())) + ) + ); + } + addRange(topLevelStatements, endLexicalEnvironment()); + if (exportVars.length) { + topLevelStatements.push(factory2.createVariableStatement( + factory2.createModifiersFromModifierFlags(32 /* Export */), + factory2.createVariableDeclarationList( + exportVars, + 1 /* Let */ + ) + )); + } + addRange(topLevelStatements, createDownlevelUsingStatements(bodyStatements, envBinding, usingKind === 2 /* Async */)); + if (exportEqualsBinding) { + topLevelStatements.push(factory2.createExportAssignment( + /*modifiers*/ + void 0, + /*isExportEquals*/ + true, + exportEqualsBinding + )); + } + return factory2.updateSourceFile(node, topLevelStatements); + } + return visitEachChild(node, visitor, context); + } + function visitBlock(node) { + const usingKind = getUsingKindOfStatements(node.statements); + if (usingKind) { + const prologueCount = countPrologueStatements(node.statements); + const envBinding = createEnvBinding(); + return factory2.updateBlock( + node, + [ + ...visitArray(node.statements, visitor, isStatement, 0, prologueCount), + ...createDownlevelUsingStatements( + transformUsingDeclarations( + node.statements, + prologueCount, + node.statements.length, + envBinding, + /*topLevelStatements*/ + void 0 + ), + envBinding, + usingKind === 2 /* Async */ + ) + ] + ); + } + return visitEachChild(node, visitor, context); + } + function visitForStatement(node) { + if (node.initializer && isUsingVariableDeclarationList(node.initializer)) { + return visitNode( + factory2.createBlock([ + factory2.createVariableStatement( + /*modifiers*/ + void 0, + node.initializer + ), + factory2.updateForStatement( + node, + /*initializer*/ + void 0, + node.condition, + node.incrementor, + node.statement + ) + ]), + visitor, + isStatement + ); + } + return visitEachChild(node, visitor, context); + } + function visitForOfStatement(node) { + if (isUsingVariableDeclarationList(node.initializer)) { + const forInitializer = node.initializer; + Debug.assertNode(forInitializer, isUsingVariableDeclarationList); + Debug.assert(forInitializer.declarations.length === 1, "ForInitializer may only have one declaration"); + const forDecl = forInitializer.declarations[0]; + Debug.assert(!forDecl.initializer, "ForInitializer may not have an initializer"); + const isAwaitUsing = getUsingKindOfVariableDeclarationList(forInitializer) === 2 /* Async */; + const temp = factory2.getGeneratedNameForNode(forDecl.name); + const usingVar = factory2.updateVariableDeclaration( + forDecl, + forDecl.name, + /*exclamationToken*/ + void 0, + /*type*/ + void 0, + temp + ); + const usingVarList = factory2.createVariableDeclarationList([usingVar], isAwaitUsing ? 6 /* AwaitUsing */ : 4 /* Using */); + const usingVarStatement = factory2.createVariableStatement( + /*modifiers*/ + void 0, + usingVarList + ); + return visitNode( + factory2.updateForOfStatement( + node, + node.awaitModifier, + factory2.createVariableDeclarationList([ + factory2.createVariableDeclaration(temp) + ], 2 /* Const */), + node.expression, + isBlock(node.statement) ? factory2.updateBlock(node.statement, [ + usingVarStatement, + ...node.statement.statements + ]) : factory2.createBlock( + [ + usingVarStatement, + node.statement + ], + /*multiLine*/ + true + ) + ), + visitor, + isStatement + ); + } + return visitEachChild(node, visitor, context); + } + function visitCaseOrDefaultClause(node, envBinding) { + if (getUsingKindOfStatements(node.statements) !== 0 /* None */) { + if (isCaseClause(node)) { + return factory2.updateCaseClause( + node, + visitNode(node.expression, visitor, isExpression), + transformUsingDeclarations( + node.statements, + /*start*/ + 0, + node.statements.length, + envBinding, + /*topLevelStatements*/ + void 0 + ) + ); + } else { + return factory2.updateDefaultClause( + node, + transformUsingDeclarations( + node.statements, + /*start*/ + 0, + node.statements.length, + envBinding, + /*topLevelStatements*/ + void 0 + ) + ); + } + } + return visitEachChild(node, visitor, context); + } + function visitSwitchStatement(node) { + const usingKind = getUsingKindOfCaseOrDefaultClauses(node.caseBlock.clauses); + if (usingKind) { + const envBinding = createEnvBinding(); + return createDownlevelUsingStatements( + [ + factory2.updateSwitchStatement( + node, + visitNode(node.expression, visitor, isExpression), + factory2.updateCaseBlock( + node.caseBlock, + node.caseBlock.clauses.map((clause) => visitCaseOrDefaultClause(clause, envBinding)) + ) + ) + ], + envBinding, + usingKind === 2 /* Async */ + ); + } + return visitEachChild(node, visitor, context); + } + function transformUsingDeclarations(statementsIn, start, end, envBinding, topLevelStatements) { + const statements = []; + for (let i = start; i < end; i++) { + const statement = statementsIn[i]; + const usingKind = getUsingKind(statement); + if (usingKind) { + Debug.assertNode(statement, isVariableStatement); + const declarations = []; + for (let declaration of statement.declarationList.declarations) { + if (!isIdentifier(declaration.name)) { + declarations.length = 0; + break; + } + if (isNamedEvaluation(declaration)) { + declaration = transformNamedEvaluation(context, declaration); + } + const initializer = visitNode(declaration.initializer, visitor, isExpression) ?? factory2.createVoidZero(); + declarations.push(factory2.updateVariableDeclaration( + declaration, + declaration.name, + /*exclamationToken*/ + void 0, + /*type*/ + void 0, + emitHelpers().createAddDisposableResourceHelper( + envBinding, + initializer, + usingKind === 2 /* Async */ + ) + )); + } + if (declarations.length) { + const varList = factory2.createVariableDeclarationList(declarations, 2 /* Const */); + setOriginalNode(varList, statement.declarationList); + setTextRange(varList, statement.declarationList); + hoistOrAppendNode(factory2.updateVariableStatement( + statement, + /*modifiers*/ + void 0, + varList + )); + continue; + } + } + const result = visitor(statement); + if (isArray(result)) { + result.forEach(hoistOrAppendNode); + } else if (result) { + hoistOrAppendNode(result); + } + } + return statements; + function hoistOrAppendNode(node) { + Debug.assertNode(node, isStatement); + append(statements, hoist(node)); + } + function hoist(node) { + if (!topLevelStatements) + return node; + switch (node.kind) { + case 272 /* ImportDeclaration */: + case 271 /* ImportEqualsDeclaration */: + case 278 /* ExportDeclaration */: + case 262 /* FunctionDeclaration */: + return hoistImportOrExportOrHoistedDeclaration(node, topLevelStatements); + case 277 /* ExportAssignment */: + return hoistExportAssignment(node); + case 263 /* ClassDeclaration */: + return hoistClassDeclaration(node); + case 243 /* VariableStatement */: + return hoistVariableStatement(node); + } + return node; + } + } + function hoistImportOrExportOrHoistedDeclaration(node, topLevelStatements) { + topLevelStatements.push(node); + return void 0; + } + function hoistExportAssignment(node) { + return node.isExportEquals ? hoistExportEquals(node) : hoistExportDefault(node); + } + function hoistExportDefault(node) { + if (defaultExportBinding) { + return node; + } + defaultExportBinding = factory2.createUniqueName("_default", 8 /* ReservedInNestedScopes */ | 32 /* FileLevel */ | 16 /* Optimistic */); + hoistBindingIdentifier( + defaultExportBinding, + /*isExport*/ + true, + "default", + node + ); + let expression = node.expression; + let innerExpression = skipOuterExpressions(expression); + if (isNamedEvaluation(innerExpression)) { + innerExpression = transformNamedEvaluation( + context, + innerExpression, + /*ignoreEmptyStringLiteral*/ + false, + "default" + ); + expression = factory2.restoreOuterExpressions(expression, innerExpression); + } + const assignment = factory2.createAssignment(defaultExportBinding, expression); + return factory2.createExpressionStatement(assignment); + } + function hoistExportEquals(node) { + if (exportEqualsBinding) { + return node; + } + exportEqualsBinding = factory2.createUniqueName("_default", 8 /* ReservedInNestedScopes */ | 32 /* FileLevel */ | 16 /* Optimistic */); + hoistVariableDeclaration(exportEqualsBinding); + const assignment = factory2.createAssignment(exportEqualsBinding, node.expression); + return factory2.createExpressionStatement(assignment); + } + function hoistClassDeclaration(node) { + if (!node.name && defaultExportBinding) { + return node; + } + const isExported2 = hasSyntacticModifier(node, 32 /* Export */); + const isDefault = hasSyntacticModifier(node, 2048 /* Default */); + let expression = factory2.converters.convertToClassExpression(node); + if (node.name) { + hoistBindingIdentifier( + factory2.getLocalName(node), + isExported2 && !isDefault, + /*exportAlias*/ + void 0, + node + ); + expression = factory2.createAssignment(factory2.getDeclarationName(node), expression); + if (isNamedEvaluation(expression)) { + expression = transformNamedEvaluation( + context, + expression, + /*ignoreEmptyStringLiteral*/ + false + ); + } + setOriginalNode(expression, node); + setSourceMapRange(expression, node); + setCommentRange(expression, node); + } + if (isDefault && !defaultExportBinding) { + defaultExportBinding = factory2.createUniqueName("_default", 8 /* ReservedInNestedScopes */ | 32 /* FileLevel */ | 16 /* Optimistic */); + hoistBindingIdentifier( + defaultExportBinding, + /*isExport*/ + true, + "default", + node + ); + expression = factory2.createAssignment(defaultExportBinding, expression); + if (isNamedEvaluation(expression)) { + expression = transformNamedEvaluation( + context, + expression, + /*ignoreEmptyStringLiteral*/ + false, + "default" + ); + } + setOriginalNode(expression, node); + } + return factory2.createExpressionStatement(expression); + } + function hoistVariableStatement(node) { + let expressions; + const isExported2 = hasSyntacticModifier(node, 32 /* Export */); + for (const variable of node.declarationList.declarations) { + hoistBindingElement(variable, isExported2, variable); + if (variable.initializer) { + expressions = append(expressions, hoistInitializedVariable(variable)); + } + } + if (expressions) { + const statement = factory2.createExpressionStatement(factory2.inlineExpressions(expressions)); + setOriginalNode(statement, node); + setCommentRange(statement, node); + setSourceMapRange(statement, node); + return statement; + } + return void 0; + } + function hoistInitializedVariable(node) { + Debug.assertIsDefined(node.initializer); + let target; + if (isIdentifier(node.name)) { + target = factory2.cloneNode(node.name); + setEmitFlags(target, getEmitFlags(target) & ~(32768 /* LocalName */ | 16384 /* ExportName */ | 65536 /* InternalName */)); + } else { + target = factory2.converters.convertToAssignmentPattern(node.name); + } + const assignment = factory2.createAssignment(target, node.initializer); + setOriginalNode(assignment, node); + setCommentRange(assignment, node); + setSourceMapRange(assignment, node); + return assignment; + } + function hoistBindingElement(node, isExportedDeclaration, original) { + if (isBindingPattern(node.name)) { + for (const element of node.name.elements) { + if (!isOmittedExpression(element)) { + hoistBindingElement(element, isExportedDeclaration, original); + } + } + } else { + hoistBindingIdentifier( + node.name, + isExportedDeclaration, + /*exportAlias*/ + void 0, + original + ); + } + } + function hoistBindingIdentifier(node, isExport, exportAlias, original) { + const name = isGeneratedIdentifier(node) ? node : factory2.cloneNode(node); + if (isExport) { + if (exportAlias === void 0 && !isLocalName(name)) { + const varDecl = factory2.createVariableDeclaration(name); + if (original) { + setOriginalNode(varDecl, original); + } + exportVars.push(varDecl); + return; + } + const localName = exportAlias !== void 0 ? name : void 0; + const exportName = exportAlias !== void 0 ? exportAlias : name; + const specifier = factory2.createExportSpecifier( + /*isTypeOnly*/ + false, + localName, + exportName + ); + if (original) { + setOriginalNode(specifier, original); + } + exportBindings.set(name, specifier); + } + hoistVariableDeclaration(name); + } + function createEnvBinding() { + return factory2.createUniqueName("env"); + } + function createDownlevelUsingStatements(bodyStatements, envBinding, async) { + const statements = []; + const envObject = factory2.createObjectLiteralExpression([ + factory2.createPropertyAssignment("stack", factory2.createArrayLiteralExpression()), + factory2.createPropertyAssignment("error", factory2.createVoidZero()), + factory2.createPropertyAssignment("hasError", factory2.createFalse()) + ]); + const envVar = factory2.createVariableDeclaration( + envBinding, + /*exclamationToken*/ + void 0, + /*type*/ + void 0, + envObject + ); + const envVarList = factory2.createVariableDeclarationList([envVar], 2 /* Const */); + const envVarStatement = factory2.createVariableStatement( + /*modifiers*/ + void 0, + envVarList + ); + statements.push(envVarStatement); + const tryBlock = factory2.createBlock( + bodyStatements, + /*multiLine*/ + true + ); + const bodyCatchBinding = factory2.createUniqueName("e"); + const catchClause = factory2.createCatchClause( + bodyCatchBinding, + factory2.createBlock( + [ + factory2.createExpressionStatement( + factory2.createAssignment( + factory2.createPropertyAccessExpression(envBinding, "error"), + bodyCatchBinding + ) + ), + factory2.createExpressionStatement( + factory2.createAssignment( + factory2.createPropertyAccessExpression(envBinding, "hasError"), + factory2.createTrue() + ) + ) + ], + /*multiLine*/ + true + ) + ); + let finallyBlock; + if (async) { + const result = factory2.createUniqueName("result"); + finallyBlock = factory2.createBlock( + [ + factory2.createVariableStatement( + /*modifiers*/ + void 0, + factory2.createVariableDeclarationList([ + factory2.createVariableDeclaration( + result, + /*exclamationToken*/ + void 0, + /*type*/ + void 0, + emitHelpers().createDisposeResourcesHelper(envBinding) + ) + ], 2 /* Const */) + ), + factory2.createIfStatement(result, factory2.createExpressionStatement(factory2.createAwaitExpression(result))) + ], + /*multiLine*/ + true + ); + } else { + finallyBlock = factory2.createBlock( + [ + factory2.createExpressionStatement( + emitHelpers().createDisposeResourcesHelper(envBinding) + ) + ], + /*multiLine*/ + true + ); + } + const tryStatement = factory2.createTryStatement(tryBlock, catchClause, finallyBlock); + statements.push(tryStatement); + return statements; + } + } + function countPrologueStatements(statements) { + for (let i = 0; i < statements.length; i++) { + if (!isPrologueDirective(statements[i]) && !isCustomPrologue(statements[i])) { + return i; + } + } + return 0; + } + function isUsingVariableDeclarationList(node) { + return isVariableDeclarationList(node) && getUsingKindOfVariableDeclarationList(node) !== 0 /* None */; + } + function getUsingKindOfVariableDeclarationList(node) { + return (node.flags & 7 /* BlockScoped */) === 6 /* AwaitUsing */ ? 2 /* Async */ : (node.flags & 7 /* BlockScoped */) === 4 /* Using */ ? 1 /* Sync */ : 0 /* None */; + } + function getUsingKindOfVariableStatement(node) { + return getUsingKindOfVariableDeclarationList(node.declarationList); + } + function getUsingKind(statement) { + return isVariableStatement(statement) ? getUsingKindOfVariableStatement(statement) : 0 /* None */; + } + function getUsingKindOfStatements(statements) { + let result = 0 /* None */; + for (const statement of statements) { + const usingKind = getUsingKind(statement); + if (usingKind === 2 /* Async */) + return 2 /* Async */; + if (usingKind > result) + result = usingKind; + } + return result; + } + function getUsingKindOfCaseOrDefaultClauses(clauses) { + let result = 0 /* None */; + for (const clause of clauses) { + const usingKind = getUsingKindOfStatements(clause.statements); + if (usingKind === 2 /* Async */) + return 2 /* Async */; + if (usingKind > result) + result = usingKind; + } + return result; } var init_esnext = __esm({ "src/compiler/transformers/esnext.ts"() { @@ -196890,7 +182000,7 @@ ${lanes.join("\n")} factory2.createNamedImports(arrayFrom(importSpecifiersMap.values())) ), factory2.createStringLiteral(importSource), - /*assertClause*/ + /*attributes*/ void 0 ); setParentRecursive( @@ -196949,25 +182059,25 @@ ${lanes.join("\n")} } function visitorWorker(node) { switch (node.kind) { - case 283 /* JsxElement */: + case 284 /* JsxElement */: return visitJsxElement( node, /*isChild*/ false ); - case 284 /* JsxSelfClosingElement */: + case 285 /* JsxSelfClosingElement */: return visitJsxSelfClosingElement( node, /*isChild*/ false ); - case 287 /* JsxFragment */: + case 288 /* JsxFragment */: return visitJsxFragment( node, /*isChild*/ false ); - case 293 /* JsxExpression */: + case 294 /* JsxExpression */: return visitJsxExpression(node); default: return visitEachChild(node, visitor, context); @@ -196977,21 +182087,21 @@ ${lanes.join("\n")} switch (node.kind) { case 12 /* JsxText */: return visitJsxText(node); - case 293 /* JsxExpression */: + case 294 /* JsxExpression */: return visitJsxExpression(node); - case 283 /* JsxElement */: + case 284 /* JsxElement */: return visitJsxElement( node, /*isChild*/ true ); - case 284 /* JsxSelfClosingElement */: + case 285 /* JsxSelfClosingElement */: return visitJsxSelfClosingElement( node, /*isChild*/ true ); - case 287 /* JsxFragment */: + case 288 /* JsxFragment */: return visitJsxFragment( node, /*isChild*/ @@ -197002,7 +182112,9 @@ ${lanes.join("\n")} } } function hasProto(obj) { - return obj.properties.some((p) => isPropertyAssignment(p) && (isIdentifier(p.name) && idText(p.name) === "__proto__" || isStringLiteral(p.name) && p.name.text === "__proto__")); + return obj.properties.some( + (p) => isPropertyAssignment(p) && (isIdentifier(p.name) && idText(p.name) === "__proto__" || isStringLiteral(p.name) && p.name.text === "__proto__") + ); } function hasKeyAfterPropsSpread(node) { let spread = false; @@ -197175,7 +182287,7 @@ ${lanes.join("\n")} } function transformJsxSpreadAttributeToProps(node) { if (isObjectLiteralExpression(node.expression) && !hasProto(node.expression)) { - return node.expression.properties; + return sameMap(node.expression.properties, (p) => Debug.checkDefined(visitNode(p, visitor, isObjectLiteralElementLike))); } return factory2.createSpreadAssignment(Debug.checkDefined(visitNode(node.expression, visitor, isExpression))); } @@ -197199,10 +182311,10 @@ ${lanes.join("\n")} for (const prop of attr.expression.properties) { if (isSpreadAssignment(prop)) { finishObjectLiteralIfNeeded(); - expressions.push(prop.expression); + expressions.push(Debug.checkDefined(visitNode(prop.expression, visitor, isExpression))); continue; } - properties.push(prop); + properties.push(Debug.checkDefined(visitNode(prop, visitor))); } continue; } @@ -197241,7 +182353,7 @@ ${lanes.join("\n")} const literal = factory2.createStringLiteral(tryDecodeEntities(node.text) || node.text, singleQuote); return setTextRange(literal, node); } - if (node.kind === 293 /* JsxExpression */) { + if (node.kind === 294 /* JsxExpression */) { if (node.expression === void 0) { return factory2.createTrue(); } @@ -197315,7 +182427,7 @@ ${lanes.join("\n")} return decoded === text ? void 0 : decoded; } function getTagName(node) { - if (node.kind === 283 /* JsxElement */) { + if (node.kind === 284 /* JsxElement */) { return getTagName(node.openingElement); } else { const tagName = node.tagName; @@ -197622,7 +182734,7 @@ ${lanes.join("\n")} return node; } switch (node.kind) { - case 225 /* BinaryExpression */: + case 226 /* BinaryExpression */: return visitBinaryExpression(node); default: return visitEachChild(node, visitor, context); @@ -197756,7 +182868,7 @@ ${lanes.join("\n")} hierarchyFacts = (hierarchyFacts & ~excludeFacts | includeFacts) & -32768 /* SubtreeFactsMask */ | ancestorFacts; } function isReturnVoidStatementInConstructorWithCapturedSuper(node) { - return (hierarchyFacts & 8192 /* ConstructorWithCapturedSuper */) !== 0 && node.kind === 252 /* ReturnStatement */ && !node.expression; + return (hierarchyFacts & 8192 /* ConstructorWithSuperCall */) !== 0 && node.kind === 253 /* ReturnStatement */ && !node.expression; } function isOrMayContainReturnCompletion(node) { return node.transformFlags & 4194304 /* ContainsHoistedDeclarationOrCompletion */ && (isReturnStatement(node) || isIfStatement(node) || isWithStatement(node) || isSwitchStatement(node) || isCaseBlock(node) || isCaseClause(node) || isDefaultClause(node) || isTryStatement(node) || isCatchClause(node) || isLabeledStatement(node) || isIterationStatement( @@ -197766,7 +182878,7 @@ ${lanes.join("\n")} ) || isBlock(node)); } function shouldVisitNode(node) { - return (node.transformFlags & 1024 /* ContainsES2015 */) !== 0 || convertedLoopState !== void 0 || hierarchyFacts & 8192 /* ConstructorWithCapturedSuper */ && isOrMayContainReturnCompletion(node) || isIterationStatement( + return (node.transformFlags & 1024 /* ContainsES2015 */) !== 0 || convertedLoopState !== void 0 || hierarchyFacts & 8192 /* ConstructorWithSuperCall */ && isOrMayContainReturnCompletion(node) || isIterationStatement( node, /*lookInLabeledStatements*/ false @@ -197799,7 +182911,7 @@ ${lanes.join("\n")} /*expressionResultIsUnused*/ false ); - exitSubtree(ancestorFacts, 98304 /* FunctionSubtreeExcludes */, 0 /* None */); + exitSubtree(ancestorFacts, 229376 /* FunctionSubtreeExcludes */, 0 /* None */); return result; } return visitorWorker( @@ -197813,6 +182925,7 @@ ${lanes.join("\n")} function callExpressionVisitor(node) { if (node.kind === 108 /* SuperKeyword */) { return visitSuperKeyword( + node, /*isExpressionOfCall*/ true ); @@ -197823,85 +182936,85 @@ ${lanes.join("\n")} switch (node.kind) { case 126 /* StaticKeyword */: return void 0; - case 262 /* ClassDeclaration */: + case 263 /* ClassDeclaration */: return visitClassDeclaration(node); - case 230 /* ClassExpression */: + case 231 /* ClassExpression */: return visitClassExpression(node); - case 168 /* Parameter */: + case 169 /* Parameter */: return visitParameter(node); - case 261 /* FunctionDeclaration */: + case 262 /* FunctionDeclaration */: return visitFunctionDeclaration(node); - case 218 /* ArrowFunction */: + case 219 /* ArrowFunction */: return visitArrowFunction(node); - case 217 /* FunctionExpression */: + case 218 /* FunctionExpression */: return visitFunctionExpression(node); - case 259 /* VariableDeclaration */: + case 260 /* VariableDeclaration */: return visitVariableDeclaration(node); case 80 /* Identifier */: return visitIdentifier(node); - case 260 /* VariableDeclarationList */: + case 261 /* VariableDeclarationList */: return visitVariableDeclarationList(node); - case 254 /* SwitchStatement */: + case 255 /* SwitchStatement */: return visitSwitchStatement(node); - case 268 /* CaseBlock */: + case 269 /* CaseBlock */: return visitCaseBlock(node); - case 240 /* Block */: + case 241 /* Block */: return visitBlock( node, /*isFunctionBody*/ false ); - case 251 /* BreakStatement */: - case 250 /* ContinueStatement */: + case 252 /* BreakStatement */: + case 251 /* ContinueStatement */: return visitBreakOrContinueStatement(node); - case 255 /* LabeledStatement */: + case 256 /* LabeledStatement */: return visitLabeledStatement(node); - case 245 /* DoStatement */: - case 246 /* WhileStatement */: + case 246 /* DoStatement */: + case 247 /* WhileStatement */: return visitDoOrWhileStatement( node, /*outermostLabeledStatement*/ void 0 ); - case 247 /* ForStatement */: + case 248 /* ForStatement */: return visitForStatement( node, /*outermostLabeledStatement*/ void 0 ); - case 248 /* ForInStatement */: + case 249 /* ForInStatement */: return visitForInStatement( node, /*outermostLabeledStatement*/ void 0 ); - case 249 /* ForOfStatement */: + case 250 /* ForOfStatement */: return visitForOfStatement( node, /*outermostLabeledStatement*/ void 0 ); - case 243 /* ExpressionStatement */: + case 244 /* ExpressionStatement */: return visitExpressionStatement(node); - case 209 /* ObjectLiteralExpression */: + case 210 /* ObjectLiteralExpression */: return visitObjectLiteralExpression(node); - case 298 /* CatchClause */: + case 299 /* CatchClause */: return visitCatchClause(node); - case 303 /* ShorthandPropertyAssignment */: + case 304 /* ShorthandPropertyAssignment */: return visitShorthandPropertyAssignment(node); - case 166 /* ComputedPropertyName */: + case 167 /* ComputedPropertyName */: return visitComputedPropertyName(node); - case 208 /* ArrayLiteralExpression */: + case 209 /* ArrayLiteralExpression */: return visitArrayLiteralExpression(node); - case 212 /* CallExpression */: + case 213 /* CallExpression */: return visitCallExpression(node); - case 213 /* NewExpression */: + case 214 /* NewExpression */: return visitNewExpression(node); - case 216 /* ParenthesizedExpression */: + case 217 /* ParenthesizedExpression */: return visitParenthesizedExpression(node, expressionResultIsUnused2); - case 225 /* BinaryExpression */: + case 226 /* BinaryExpression */: return visitBinaryExpression(node, expressionResultIsUnused2); - case 360 /* CommaListExpression */: + case 361 /* CommaListExpression */: return visitCommaListExpression(node, expressionResultIsUnused2); case 15 /* NoSubstitutionTemplateLiteral */: case 16 /* TemplateHead */: @@ -197912,33 +183025,34 @@ ${lanes.join("\n")} return visitStringLiteral(node); case 9 /* NumericLiteral */: return visitNumericLiteral(node); - case 214 /* TaggedTemplateExpression */: + case 215 /* TaggedTemplateExpression */: return visitTaggedTemplateExpression(node); - case 227 /* TemplateExpression */: + case 228 /* TemplateExpression */: return visitTemplateExpression(node); - case 228 /* YieldExpression */: + case 229 /* YieldExpression */: return visitYieldExpression(node); - case 229 /* SpreadElement */: + case 230 /* SpreadElement */: return visitSpreadElement(node); case 108 /* SuperKeyword */: return visitSuperKeyword( + node, /*isExpressionOfCall*/ false ); case 110 /* ThisKeyword */: return visitThisKeyword(node); - case 235 /* MetaProperty */: + case 236 /* MetaProperty */: return visitMetaProperty(node); - case 173 /* MethodDeclaration */: + case 174 /* MethodDeclaration */: return visitMethodDeclaration(node); - case 176 /* GetAccessor */: - case 177 /* SetAccessor */: + case 177 /* GetAccessor */: + case 178 /* SetAccessor */: return visitAccessorDeclaration(node); - case 242 /* VariableStatement */: + case 243 /* VariableStatement */: return visitVariableStatement(node); - case 252 /* ReturnStatement */: + case 253 /* ReturnStatement */: return visitReturnStatement(node); - case 221 /* VoidExpression */: + case 222 /* VoidExpression */: return visitVoidExpression(node); default: return visitEachChild(node, visitor, context); @@ -197991,7 +183105,10 @@ ${lanes.join("\n")} return updated; } function returnCapturedThis(node) { - return setOriginalNode(factory2.createReturnStatement(factory2.createUniqueName("_this", 16 /* Optimistic */ | 32 /* FileLevel */)), node); + return setOriginalNode(factory2.createReturnStatement(createCapturedThis()), node); + } + function createCapturedThis() { + return factory2.createUniqueName("_this", 16 /* Optimistic */ | 32 /* FileLevel */); } function visitReturnStatement(node) { if (convertedLoopState) { @@ -198015,8 +183132,9 @@ ${lanes.join("\n")} return visitEachChild(node, visitor, context); } function visitThisKeyword(node) { + hierarchyFacts |= 65536 /* LexicalThis */; if (hierarchyFacts & 2 /* ArrowFunction */ && !(hierarchyFacts & 16384 /* StaticInitializer */)) { - hierarchyFacts |= 65536 /* CapturedLexicalThis */; + hierarchyFacts |= 131072 /* CapturedLexicalThis */; } if (convertedLoopState) { if (hierarchyFacts & 2 /* ArrowFunction */) { @@ -198036,23 +183154,26 @@ ${lanes.join("\n")} return convertedLoopState.argumentsName || (convertedLoopState.argumentsName = factory2.createUniqueName("arguments")); } } - if (node.flags & 128 /* IdentifierHasExtendedUnicodeEscape */) { - return setOriginalNode(setTextRange( - factory2.createIdentifier(unescapeLeadingUnderscores(node.escapedText)), + if (node.flags & 256 /* IdentifierHasExtendedUnicodeEscape */) { + return setOriginalNode( + setTextRange( + factory2.createIdentifier(unescapeLeadingUnderscores(node.escapedText)), + node + ), node - ), node); + ); } return node; } function visitBreakOrContinueStatement(node) { if (convertedLoopState) { - const jump = node.kind === 251 /* BreakStatement */ ? 2 /* Break */ : 4 /* Continue */; + const jump = node.kind === 252 /* BreakStatement */ ? 2 /* Break */ : 4 /* Continue */; const canUseBreakOrContinue = node.label && convertedLoopState.labels && convertedLoopState.labels.get(idText(node.label)) || !node.label && convertedLoopState.allowedNonLabeledJumps & jump; if (!canUseBreakOrContinue) { let labelMarker; const label = node.label; if (!label) { - if (node.kind === 251 /* BreakStatement */) { + if (node.kind === 252 /* BreakStatement */) { convertedLoopState.nonLocalJumps |= 2 /* Break */; labelMarker = "break"; } else { @@ -198060,7 +183181,7 @@ ${lanes.join("\n")} labelMarker = "continue"; } } else { - if (node.kind === 251 /* BreakStatement */) { + if (node.kind === 252 /* BreakStatement */) { labelMarker = `break-${label.escapedText}`; setLabeledJump( convertedLoopState, @@ -198123,8 +183244,8 @@ ${lanes.join("\n")} setTextRange(statement, node); startOnNewLine(statement); statements.push(statement); - if (hasSyntacticModifier(node, 1 /* Export */)) { - const exportStatement = hasSyntacticModifier(node, 1024 /* Default */) ? factory2.createExportDefault(factory2.getLocalName(node)) : factory2.createExternalModuleExport(factory2.getLocalName(node)); + if (hasSyntacticModifier(node, 32 /* Export */)) { + const exportStatement = hasSyntacticModifier(node, 2048 /* Default */) ? factory2.createExportDefault(factory2.getLocalName(node)) : factory2.createExternalModuleExport(factory2.getLocalName(node)); setOriginalNode(exportStatement, statement); statements.push(exportStatement); } @@ -198152,7 +183273,7 @@ ${lanes.join("\n")} void 0, /*dotDotDotToken*/ void 0, - factory2.createUniqueName("_super", 16 /* Optimistic */ | 32 /* FileLevel */) + createSyntheticSuper() )] : [], /*type*/ void 0, @@ -198242,7 +183363,7 @@ ${lanes.join("\n")} setEmitFlags(constructorFunction, 16 /* CapturesThis */); } statements.push(constructorFunction); - exitSubtree(ancestorFacts, 98304 /* FunctionSubtreeExcludes */, 0 /* None */); + exitSubtree(ancestorFacts, 229376 /* FunctionSubtreeExcludes */, 0 /* None */); convertedLoopState = savedConvertedLoopState; } function transformConstructorParameters(constructor, hasSynthesizedSuper) { @@ -198266,6 +183387,36 @@ ${lanes.join("\n")} setEmitFlags(block, 3072 /* NoComments */); return block; } + function isUninitializedVariableStatement(node) { + return isVariableStatement(node) && every(node.declarationList.declarations, (decl) => isIdentifier(decl.name) && !decl.initializer); + } + function containsSuperCall(node) { + if (isSuperCall(node)) { + return true; + } + if (!(node.transformFlags & 134217728 /* ContainsLexicalSuper */)) { + return false; + } + switch (node.kind) { + case 219 /* ArrowFunction */: + case 218 /* FunctionExpression */: + case 262 /* FunctionDeclaration */: + case 176 /* Constructor */: + case 175 /* ClassStaticBlockDeclaration */: + return false; + case 177 /* GetAccessor */: + case 178 /* SetAccessor */: + case 174 /* MethodDeclaration */: + case 172 /* PropertyDeclaration */: { + const named = node; + if (isComputedPropertyName(named.name)) { + return !!forEachChild(named.name, containsSuperCall); + } + return false; + } + } + return !!forEachChild(node, containsSuperCall); + } function transformConstructorBody(constructor, node, extendsClauseElement, hasSynthesizedSuper) { const isDerivedClass = !!extendsClauseElement && skipOuterExpressions(extendsClauseElement.expression).kind !== 106 /* NullKeyword */; if (!constructor) @@ -198273,82 +183424,34 @@ ${lanes.join("\n")} const prologue = []; const statements = []; resumeLexicalEnvironment(); - const existingPrologue = takeWhile(constructor.body.statements, isPrologueDirective); - const { superCall, superStatementIndex } = findSuperCallAndStatementIndex(constructor.body.statements, existingPrologue); - const postSuperStatementsStart = superStatementIndex === -1 ? existingPrologue.length : superStatementIndex + 1; - let statementOffset = postSuperStatementsStart; - if (!hasSynthesizedSuper) - statementOffset = factory2.copyStandardPrologue( - constructor.body.statements, - prologue, - statementOffset, - /*ensureUseStrict*/ - false - ); - if (!hasSynthesizedSuper) - statementOffset = factory2.copyCustomPrologue( - constructor.body.statements, - statements, - statementOffset, - visitor, - /*filter*/ - void 0 - ); - let superCallExpression; - if (hasSynthesizedSuper) { - superCallExpression = createDefaultSuperCallOrThis(); - } else if (superCall) { - superCallExpression = visitSuperCallInBody(superCall); - } - if (superCallExpression) { - hierarchyFacts |= 8192 /* ConstructorWithCapturedSuper */; - } - addDefaultValueAssignmentsIfNeeded2(prologue, constructor); - addRestParameterIfNeeded(prologue, constructor, hasSynthesizedSuper); - addRange(statements, visitNodes2( + const standardPrologueEnd = factory2.copyStandardPrologue( constructor.body.statements, - visitor, - isStatement, - /*start*/ - statementOffset - )); - factory2.mergeLexicalEnvironment(prologue, endLexicalEnvironment()); - insertCaptureNewTargetIfNeeded( prologue, - constructor, - /*copyOnWrite*/ - false + /*statementOffset*/ + 0 ); - if (isDerivedClass || superCallExpression) { - if (superCallExpression && postSuperStatementsStart === constructor.body.statements.length && !(constructor.body.transformFlags & 16384 /* ContainsLexicalThis */)) { - const superCall2 = cast(cast(superCallExpression, isBinaryExpression).left, isCallExpression); - const returnStatement = factory2.createReturnStatement(superCallExpression); - setCommentRange(returnStatement, getCommentRange(superCall2)); - setEmitFlags(superCall2, 3072 /* NoComments */); - statements.push(returnStatement); - } else { - if (superStatementIndex <= existingPrologue.length) { - insertCaptureThisForNode(statements, constructor, superCallExpression || createActualThis()); - } else { - insertCaptureThisForNode(prologue, constructor, createActualThis()); - if (superCallExpression) { - insertSuperThisCaptureThisForNode(statements, superCallExpression); - } - } - if (!isSufficientlyCoveredByReturnStatements(constructor.body)) { - statements.push(factory2.createReturnStatement(factory2.createUniqueName("_this", 16 /* Optimistic */ | 32 /* FileLevel */))); - } - } + if (hasSynthesizedSuper || containsSuperCall(constructor.body)) { + hierarchyFacts |= 8192 /* ConstructorWithSuperCall */; + } + addRange(statements, visitNodes2(constructor.body.statements, visitor, isStatement, standardPrologueEnd)); + const mayReplaceThis = isDerivedClass || hierarchyFacts & 8192 /* ConstructorWithSuperCall */; + addDefaultValueAssignmentsIfNeeded2(prologue, constructor); + addRestParameterIfNeeded(prologue, constructor, hasSynthesizedSuper); + insertCaptureNewTargetIfNeeded(prologue, constructor); + if (mayReplaceThis) { + insertCaptureThisForNode(prologue, constructor, createActualThis()); } else { insertCaptureThisForNodeIfNeeded(prologue, constructor); } + factory2.mergeLexicalEnvironment(prologue, endLexicalEnvironment()); + if (mayReplaceThis && !isSufficientlyCoveredByReturnStatements(constructor.body)) { + statements.push(factory2.createReturnStatement(createCapturedThis())); + } const body = factory2.createBlock( setTextRange( factory2.createNodeArray( [ - ...existingPrologue, ...prologue, - ...superStatementIndex <= existingPrologue.length ? emptyArray : visitNodes2(constructor.body.statements, visitor, isStatement, existingPrologue.length, superStatementIndex - existingPrologue.length), ...statements ] ), @@ -198359,31 +183462,241 @@ ${lanes.join("\n")} true ); setTextRange(body, constructor.body); + return simplifyConstructor(body, constructor.body, hasSynthesizedSuper); + } + function isCapturedThis(node) { + return isGeneratedIdentifier(node) && idText(node) === "_this"; + } + function isSyntheticSuper(node) { + return isGeneratedIdentifier(node) && idText(node) === "_super"; + } + function isThisCapturingVariableStatement(node) { + return isVariableStatement(node) && node.declarationList.declarations.length === 1 && isThisCapturingVariableDeclaration(node.declarationList.declarations[0]); + } + function isThisCapturingVariableDeclaration(node) { + return isVariableDeclaration(node) && isCapturedThis(node.name) && !!node.initializer; + } + function isThisCapturingAssignment(node) { + return isAssignmentExpression( + node, + /*excludeCompoundAssignment*/ + true + ) && isCapturedThis(node.left); + } + function isTransformedSuperCall(node) { + return isCallExpression(node) && isPropertyAccessExpression(node.expression) && isSyntheticSuper(node.expression.expression) && isIdentifier(node.expression.name) && (idText(node.expression.name) === "call" || idText(node.expression.name) === "apply") && node.arguments.length >= 1 && node.arguments[0].kind === 110 /* ThisKeyword */; + } + function isTransformedSuperCallWithFallback(node) { + return isBinaryExpression(node) && node.operatorToken.kind === 57 /* BarBarToken */ && node.right.kind === 110 /* ThisKeyword */ && isTransformedSuperCall(node.left); + } + function isImplicitSuperCall(node) { + return isBinaryExpression(node) && node.operatorToken.kind === 56 /* AmpersandAmpersandToken */ && isBinaryExpression(node.left) && node.left.operatorToken.kind === 38 /* ExclamationEqualsEqualsToken */ && isSyntheticSuper(node.left.left) && node.left.right.kind === 106 /* NullKeyword */ && isTransformedSuperCall(node.right) && idText(node.right.expression.name) === "apply"; + } + function isImplicitSuperCallWithFallback(node) { + return isBinaryExpression(node) && node.operatorToken.kind === 57 /* BarBarToken */ && node.right.kind === 110 /* ThisKeyword */ && isImplicitSuperCall(node.left); + } + function isThisCapturingTransformedSuperCallWithFallback(node) { + return isThisCapturingAssignment(node) && isTransformedSuperCallWithFallback(node.right); + } + function isThisCapturingImplicitSuperCallWithFallback(node) { + return isThisCapturingAssignment(node) && isImplicitSuperCallWithFallback(node.right); + } + function isTransformedSuperCallLike(node) { + return isTransformedSuperCall(node) || isTransformedSuperCallWithFallback(node) || isThisCapturingTransformedSuperCallWithFallback(node) || isImplicitSuperCall(node) || isImplicitSuperCallWithFallback(node) || isThisCapturingImplicitSuperCallWithFallback(node); + } + function simplifyConstructorInlineSuperInThisCaptureVariable(body) { + for (let i = 0; i < body.statements.length - 1; i++) { + const statement = body.statements[i]; + if (!isThisCapturingVariableStatement(statement)) { + continue; + } + const varDecl = statement.declarationList.declarations[0]; + if (varDecl.initializer.kind !== 110 /* ThisKeyword */) { + continue; + } + const thisCaptureStatementIndex = i; + let superCallIndex = i + 1; + while (superCallIndex < body.statements.length) { + const statement2 = body.statements[superCallIndex]; + if (isExpressionStatement(statement2)) { + if (isTransformedSuperCallLike(skipOuterExpressions(statement2.expression))) { + break; + } + } + if (isUninitializedVariableStatement(statement2)) { + superCallIndex++; + continue; + } + return body; + } + const following = body.statements[superCallIndex]; + let expression = following.expression; + if (isThisCapturingAssignment(expression)) { + expression = expression.right; + } + const newVarDecl = factory2.updateVariableDeclaration( + varDecl, + varDecl.name, + /*exclamationToken*/ + void 0, + /*type*/ + void 0, + expression + ); + const newDeclList = factory2.updateVariableDeclarationList(statement.declarationList, [newVarDecl]); + const newVarStatement = factory2.createVariableStatement(statement.modifiers, newDeclList); + setOriginalNode(newVarStatement, following); + setTextRange(newVarStatement, following); + const newStatements = factory2.createNodeArray([ + ...body.statements.slice(0, thisCaptureStatementIndex), + // copy statements preceding to `var _this` + ...body.statements.slice(thisCaptureStatementIndex + 1, superCallIndex), + // copy intervening temp variables + newVarStatement, + ...body.statements.slice(superCallIndex + 1) + // copy statements following `super.call(this, ...)` + ]); + setTextRange(newStatements, body.statements); + return factory2.updateBlock(body, newStatements); + } return body; } - function findSuperCallAndStatementIndex(originalBodyStatements, existingPrologue) { - for (let i = existingPrologue.length; i < originalBodyStatements.length; i += 1) { - const superCall = getSuperCallFromStatement(originalBodyStatements[i]); - if (superCall) { - return { - superCall, - superStatementIndex: i - }; + function simplifyConstructorInlineSuperReturn(body, original) { + for (const statement of original.statements) { + if (statement.transformFlags & 134217728 /* ContainsLexicalSuper */ && !getSuperCallFromStatement(statement)) { + return body; } } - return { - superStatementIndex: -1 - }; + const canElideThisCapturingVariable = !(original.transformFlags & 16384 /* ContainsLexicalThis */) && !(hierarchyFacts & 65536 /* LexicalThis */) && !(hierarchyFacts & 131072 /* CapturedLexicalThis */); + for (let i = body.statements.length - 1; i > 0; i--) { + const statement = body.statements[i]; + if (isReturnStatement(statement) && statement.expression && isCapturedThis(statement.expression)) { + const preceding = body.statements[i - 1]; + let expression; + if (isExpressionStatement(preceding) && isThisCapturingTransformedSuperCallWithFallback(skipOuterExpressions(preceding.expression))) { + expression = preceding.expression; + } else if (canElideThisCapturingVariable && isThisCapturingVariableStatement(preceding)) { + const varDecl = preceding.declarationList.declarations[0]; + if (isTransformedSuperCallLike(skipOuterExpressions(varDecl.initializer))) { + expression = factory2.createAssignment( + createCapturedThis(), + varDecl.initializer + ); + } + } + if (!expression) { + break; + } + const newReturnStatement = factory2.createReturnStatement(expression); + setOriginalNode(newReturnStatement, preceding); + setTextRange(newReturnStatement, preceding); + const newStatements = factory2.createNodeArray([ + ...body.statements.slice(0, i - 1), + // copy all statements preceding `_super.call(this, ...)` + newReturnStatement, + ...body.statements.slice(i + 1) + // copy all statements following `return _this;` + ]); + setTextRange(newStatements, body.statements); + return factory2.updateBlock(body, newStatements); + } + } + return body; + } + function elideUnusedThisCaptureWorker(node) { + if (isThisCapturingVariableStatement(node)) { + const varDecl = node.declarationList.declarations[0]; + if (varDecl.initializer.kind === 110 /* ThisKeyword */) { + return void 0; + } + } else if (isThisCapturingAssignment(node)) { + return factory2.createPartiallyEmittedExpression(node.right, node); + } + switch (node.kind) { + case 219 /* ArrowFunction */: + case 218 /* FunctionExpression */: + case 262 /* FunctionDeclaration */: + case 176 /* Constructor */: + case 175 /* ClassStaticBlockDeclaration */: + return node; + case 177 /* GetAccessor */: + case 178 /* SetAccessor */: + case 174 /* MethodDeclaration */: + case 172 /* PropertyDeclaration */: { + const named = node; + if (isComputedPropertyName(named.name)) { + return factory2.replacePropertyName(named, visitEachChild(named.name, elideUnusedThisCaptureWorker, nullTransformationContext)); + } + return node; + } + } + return visitEachChild(node, elideUnusedThisCaptureWorker, nullTransformationContext); + } + function simplifyConstructorElideUnusedThisCapture(body, original) { + if (original.transformFlags & 16384 /* ContainsLexicalThis */ || hierarchyFacts & 65536 /* LexicalThis */ || hierarchyFacts & 131072 /* CapturedLexicalThis */) { + return body; + } + for (const statement of original.statements) { + if (statement.transformFlags & 134217728 /* ContainsLexicalSuper */ && !getSuperCallFromStatement(statement)) { + return body; + } + } + return factory2.updateBlock(body, visitNodes2(body.statements, elideUnusedThisCaptureWorker, isStatement)); + } + function injectSuperPresenceCheckWorker(node) { + if (isTransformedSuperCall(node) && node.arguments.length === 2 && isIdentifier(node.arguments[1]) && idText(node.arguments[1]) === "arguments") { + return factory2.createLogicalAnd( + factory2.createStrictInequality( + createSyntheticSuper(), + factory2.createNull() + ), + node + ); + } + switch (node.kind) { + case 219 /* ArrowFunction */: + case 218 /* FunctionExpression */: + case 262 /* FunctionDeclaration */: + case 176 /* Constructor */: + case 175 /* ClassStaticBlockDeclaration */: + return node; + case 177 /* GetAccessor */: + case 178 /* SetAccessor */: + case 174 /* MethodDeclaration */: + case 172 /* PropertyDeclaration */: { + const named = node; + if (isComputedPropertyName(named.name)) { + return factory2.replacePropertyName(named, visitEachChild(named.name, injectSuperPresenceCheckWorker, nullTransformationContext)); + } + return node; + } + } + return visitEachChild(node, injectSuperPresenceCheckWorker, nullTransformationContext); + } + function complicateConstructorInjectSuperPresenceCheck(body) { + return factory2.updateBlock(body, visitNodes2(body.statements, injectSuperPresenceCheckWorker, isStatement)); + } + function simplifyConstructor(body, original, hasSynthesizedSuper) { + const inputBody = body; + body = simplifyConstructorInlineSuperInThisCaptureVariable(body); + body = simplifyConstructorInlineSuperReturn(body, original); + if (body !== inputBody) { + body = simplifyConstructorElideUnusedThisCapture(body, original); + } + if (hasSynthesizedSuper) { + body = complicateConstructorInjectSuperPresenceCheck(body); + } + return body; } function isSufficientlyCoveredByReturnStatements(statement) { - if (statement.kind === 252 /* ReturnStatement */) { + if (statement.kind === 253 /* ReturnStatement */) { return true; - } else if (statement.kind === 244 /* IfStatement */) { + } else if (statement.kind === 245 /* IfStatement */) { const ifStatement = statement; if (ifStatement.elseStatement) { return isSufficientlyCoveredByReturnStatements(ifStatement.thenStatement) && isSufficientlyCoveredByReturnStatements(ifStatement.elseStatement); } - } else if (statement.kind === 240 /* Block */) { + } else if (statement.kind === 241 /* Block */) { const lastStatement = lastOrUndefined(statement.statements); if (lastStatement && isSufficientlyCoveredByReturnStatements(lastStatement)) { return true; @@ -198398,11 +183711,11 @@ ${lanes.join("\n")} return factory2.createLogicalOr( factory2.createLogicalAnd( factory2.createStrictInequality( - factory2.createUniqueName("_super", 16 /* Optimistic */ | 32 /* FileLevel */), + createSyntheticSuper(), factory2.createNull() ), factory2.createFunctionApplyCall( - factory2.createUniqueName("_super", 16 /* Optimistic */ | 32 /* FileLevel */), + createSyntheticSuper(), createActualThis(), factory2.createIdentifier("arguments") ) @@ -198657,24 +183970,12 @@ ${lanes.join("\n")} return true; } function insertCaptureThisForNodeIfNeeded(statements, node) { - if (hierarchyFacts & 65536 /* CapturedLexicalThis */ && node.kind !== 218 /* ArrowFunction */) { + if (hierarchyFacts & 131072 /* CapturedLexicalThis */ && node.kind !== 219 /* ArrowFunction */) { insertCaptureThisForNode(statements, node, factory2.createThis()); return true; } return false; } - function insertSuperThisCaptureThisForNode(statements, superExpression) { - enableSubstitutionsForCapturedThis(); - const assignSuperExpression = factory2.createExpressionStatement( - factory2.createBinaryExpression( - factory2.createThis(), - 64 /* EqualsToken */, - superExpression - ) - ); - insertStatementAfterCustomPrologue(statements, assignSuperExpression); - setCommentRange(assignSuperExpression, getOriginalNode(superExpression).parent); - } function insertCaptureThisForNode(statements, node, initializer) { enableSubstitutionsForCapturedThis(); const captureThisStatement = factory2.createVariableStatement( @@ -198682,7 +183983,7 @@ ${lanes.join("\n")} void 0, factory2.createVariableDeclarationList([ factory2.createVariableDeclaration( - factory2.createUniqueName("_this", 16 /* Optimistic */ | 32 /* FileLevel */), + createCapturedThis(), /*exclamationToken*/ void 0, /*type*/ @@ -198695,25 +183996,25 @@ ${lanes.join("\n")} setSourceMapRange(captureThisStatement, node); insertStatementAfterCustomPrologue(statements, captureThisStatement); } - function insertCaptureNewTargetIfNeeded(statements, node, copyOnWrite) { + function insertCaptureNewTargetIfNeeded(statements, node) { if (hierarchyFacts & 32768 /* NewTarget */) { let newTarget; switch (node.kind) { - case 218 /* ArrowFunction */: + case 219 /* ArrowFunction */: return statements; - case 173 /* MethodDeclaration */: - case 176 /* GetAccessor */: - case 177 /* SetAccessor */: + case 174 /* MethodDeclaration */: + case 177 /* GetAccessor */: + case 178 /* SetAccessor */: newTarget = factory2.createVoidZero(); break; - case 175 /* Constructor */: + case 176 /* Constructor */: newTarget = factory2.createPropertyAccessExpression( setEmitFlags(factory2.createThis(), 8 /* NoSubstitution */), "constructor" ); break; - case 261 /* FunctionDeclaration */: - case 217 /* FunctionExpression */: + case 262 /* FunctionDeclaration */: + case 218 /* FunctionExpression */: newTarget = factory2.createConditionalExpression( factory2.createLogicalAnd( setEmitFlags(factory2.createThis(), 8 /* NoSubstitution */), @@ -198752,9 +184053,6 @@ ${lanes.join("\n")} ]) ); setEmitFlags(captureNewTargetStatement, 3072 /* NoComments */ | 2097152 /* CustomPrologue */); - if (copyOnWrite) { - statements = statements.slice(); - } insertStatementAfterCustomPrologue(statements, captureNewTargetStatement); } return statements; @@ -198762,21 +184060,21 @@ ${lanes.join("\n")} function addClassMembers(statements, node) { for (const member of node.members) { switch (member.kind) { - case 239 /* SemicolonClassElement */: + case 240 /* SemicolonClassElement */: statements.push(transformSemicolonClassElementToStatement(member)); break; - case 173 /* MethodDeclaration */: + case 174 /* MethodDeclaration */: statements.push(transformClassMethodDeclarationToStatement(getClassMemberPrefix(node, member), member, node)); break; - case 176 /* GetAccessor */: - case 177 /* SetAccessor */: + case 177 /* GetAccessor */: + case 178 /* SetAccessor */: const accessors = getAllAccessorDeclarations(node.members, member); if (member === accessors.firstAccessor) { statements.push(transformAccessorsToStatement(getClassMemberPrefix(node, member), accessors, node)); } break; - case 175 /* Constructor */: - case 174 /* ClassStaticBlockDeclaration */: + case 176 /* Constructor */: + case 175 /* ClassStaticBlockDeclaration */: break; default: Debug.failBadSyntaxKind(member, currentSourceFile && currentSourceFile.fileName); @@ -198906,7 +184204,7 @@ ${lanes.join("\n")} } function visitArrowFunction(node) { if (node.transformFlags & 16384 /* ContainsLexicalThis */ && !(hierarchyFacts & 16384 /* StaticInitializer */)) { - hierarchyFacts |= 65536 /* CapturedLexicalThis */; + hierarchyFacts |= 131072 /* CapturedLexicalThis */; } const savedConvertedLoopState = convertedLoopState; convertedLoopState = void 0; @@ -198939,7 +184237,7 @@ ${lanes.join("\n")} const parameters = visitParameterList(node.parameters, visitor, context); const body = transformFunctionBody2(node); const name = hierarchyFacts & 32768 /* NewTarget */ ? factory2.getLocalName(node) : node.name; - exitSubtree(ancestorFacts, 98304 /* FunctionSubtreeExcludes */, 0 /* None */); + exitSubtree(ancestorFacts, 229376 /* FunctionSubtreeExcludes */, 0 /* None */); convertedLoopState = savedConvertedLoopState; return factory2.updateFunctionExpression( node, @@ -198962,7 +184260,7 @@ ${lanes.join("\n")} const parameters = visitParameterList(node.parameters, visitor, context); const body = transformFunctionBody2(node); const name = hierarchyFacts & 32768 /* NewTarget */ ? factory2.getLocalName(node) : node.name; - exitSubtree(ancestorFacts, 98304 /* FunctionSubtreeExcludes */, 0 /* None */); + exitSubtree(ancestorFacts, 229376 /* FunctionSubtreeExcludes */, 0 /* None */); convertedLoopState = savedConvertedLoopState; return factory2.updateFunctionDeclaration( node, @@ -198983,10 +184281,10 @@ ${lanes.join("\n")} const ancestorFacts = container && isClassLike(container) && !isStatic(node) ? enterSubtree(32670 /* FunctionExcludes */, 65 /* FunctionIncludes */ | 8 /* NonStaticClassElement */) : enterSubtree(32670 /* FunctionExcludes */, 65 /* FunctionIncludes */); const parameters = visitParameterList(node.parameters, visitor, context); const body = transformFunctionBody2(node); - if (hierarchyFacts & 32768 /* NewTarget */ && !name && (node.kind === 261 /* FunctionDeclaration */ || node.kind === 217 /* FunctionExpression */)) { + if (hierarchyFacts & 32768 /* NewTarget */ && !name && (node.kind === 262 /* FunctionDeclaration */ || node.kind === 218 /* FunctionExpression */)) { name = factory2.getGeneratedNameForNode(node); } - exitSubtree(ancestorFacts, 98304 /* FunctionSubtreeExcludes */, 0 /* None */); + exitSubtree(ancestorFacts, 229376 /* FunctionSubtreeExcludes */, 0 /* None */); convertedLoopState = savedConvertedLoopState; return setOriginalNode( setTextRange( @@ -199044,7 +184342,7 @@ ${lanes.join("\n")} multiLine = true; } } else { - Debug.assert(node.kind === 218 /* ArrowFunction */); + Debug.assert(node.kind === 219 /* ArrowFunction */); statementsLocation = moveRangeEnd(body, -1); const equalsGreaterThanToken = node.equalsGreaterThanToken; if (!nodeIsSynthesized(equalsGreaterThanToken) && !nodeIsSynthesized(body)) { @@ -199063,12 +184361,7 @@ ${lanes.join("\n")} closeBraceLocation = body; } factory2.mergeLexicalEnvironment(prologue, endLexicalEnvironment()); - insertCaptureNewTargetIfNeeded( - prologue, - node, - /*copyOnWrite*/ - false - ); + insertCaptureNewTargetIfNeeded(prologue, node); insertCaptureThisForNodeIfNeeded(prologue, node); if (some(prologue)) { multiLine = true; @@ -199144,9 +184437,9 @@ ${lanes.join("\n")} return node.declarationList.declarations.length === 1 && !!node.declarationList.declarations[0].initializer && !!(getInternalEmitFlags(node.declarationList.declarations[0].initializer) & 1 /* TypeScriptClassWrapper */); } function visitVariableStatement(node) { - const ancestorFacts = enterSubtree(0 /* None */, hasSyntacticModifier(node, 1 /* Export */) ? 32 /* ExportedVariableStatement */ : 0 /* None */); + const ancestorFacts = enterSubtree(0 /* None */, hasSyntacticModifier(node, 32 /* Export */) ? 32 /* ExportedVariableStatement */ : 0 /* None */); let updated; - if (convertedLoopState && (node.declarationList.flags & 3 /* BlockScoped */) === 0 && !isVariableStatementOfTypeScriptClassWrapper(node)) { + if (convertedLoopState && (node.declarationList.flags & 7 /* BlockScoped */) === 0 && !isVariableStatementOfTypeScriptClassWrapper(node)) { let assignments; for (const decl of node.declarationList.declarations) { hoistVariableDeclarationDeclaredInConvertedLoop(convertedLoopState, decl); @@ -199178,11 +184471,15 @@ ${lanes.join("\n")} return updated; } function visitVariableDeclarationList(node) { - if (node.flags & 3 /* BlockScoped */ || node.transformFlags & 524288 /* ContainsBindingPattern */) { - if (node.flags & 3 /* BlockScoped */) { + if (node.flags & 7 /* BlockScoped */ || node.transformFlags & 524288 /* ContainsBindingPattern */) { + if (node.flags & 7 /* BlockScoped */) { enableSubstitutionsForBlockScopedBindings(); } - const declarations = visitNodes2(node.declarations, node.flags & 1 /* Let */ ? visitVariableDeclarationInLetDeclarationList : visitVariableDeclaration, isVariableDeclaration); + const declarations = visitNodes2( + node.declarations, + node.flags & 1 /* Let */ ? visitVariableDeclarationInLetDeclarationList : visitVariableDeclaration, + isVariableDeclaration + ); const declarationList = factory2.createVariableDeclarationList(declarations); setOriginalNode(declarationList, node); setTextRange(declarationList, node); @@ -199270,14 +184567,14 @@ ${lanes.join("\n")} } function visitIterationStatement(node, outermostLabeledStatement) { switch (node.kind) { - case 245 /* DoStatement */: - case 246 /* WhileStatement */: + case 246 /* DoStatement */: + case 247 /* WhileStatement */: return visitDoOrWhileStatement(node, outermostLabeledStatement); - case 247 /* ForStatement */: + case 248 /* ForStatement */: return visitForStatement(node, outermostLabeledStatement); - case 248 /* ForInStatement */: + case 249 /* ForInStatement */: return visitForInStatement(node, outermostLabeledStatement); - case 249 /* ForOfStatement */: + case 250 /* ForOfStatement */: return visitForOfStatement(node, outermostLabeledStatement); } } @@ -199333,7 +184630,7 @@ ${lanes.join("\n")} const statements = []; const initializer = node.initializer; if (isVariableDeclarationList(initializer)) { - if (node.initializer.flags & 3 /* BlockScoped */) { + if (node.initializer.flags & 7 /* BlockScoped */) { enableSubstitutionsForBlockScopedBindings(); } const firstOriginalDeclaration = firstOrUndefined(initializer.declarations); @@ -199627,7 +184924,7 @@ ${lanes.join("\n")} let numInitialProperties = -1, hasComputed = false; for (let i = 0; i < properties.length; i++) { const property = properties[i]; - if (property.transformFlags & 1048576 /* ContainsYield */ && hierarchyFacts & 4 /* AsyncFunctionBody */ || (hasComputed = Debug.checkDefined(property.name).kind === 166 /* ComputedPropertyName */)) { + if (property.transformFlags & 1048576 /* ContainsYield */ && hierarchyFacts & 4 /* AsyncFunctionBody */ || (hasComputed = Debug.checkDefined(property.name).kind === 167 /* ComputedPropertyName */)) { numInitialProperties = i; break; } @@ -199749,15 +185046,15 @@ ${lanes.join("\n")} } function convertIterationStatementCore(node, initializerFunction, convertedLoopBody) { switch (node.kind) { - case 247 /* ForStatement */: + case 248 /* ForStatement */: return convertForStatement(node, initializerFunction, convertedLoopBody); - case 248 /* ForInStatement */: + case 249 /* ForInStatement */: return convertForInStatement(node, convertedLoopBody); - case 249 /* ForOfStatement */: + case 250 /* ForOfStatement */: return convertForOfStatement(node, convertedLoopBody); - case 245 /* DoStatement */: + case 246 /* DoStatement */: return convertDoStatement(node, convertedLoopBody); - case 246 /* WhileStatement */: + case 247 /* WhileStatement */: return convertWhileStatement(node, convertedLoopBody); default: return Debug.failBadSyntaxKind(node, "IterationStatement expected"); @@ -199809,18 +185106,18 @@ ${lanes.join("\n")} function createConvertedLoopState(node) { let loopInitializer; switch (node.kind) { - case 247 /* ForStatement */: - case 248 /* ForInStatement */: - case 249 /* ForOfStatement */: + case 248 /* ForStatement */: + case 249 /* ForInStatement */: + case 250 /* ForOfStatement */: const initializer = node.initializer; - if (initializer && initializer.kind === 260 /* VariableDeclarationList */) { + if (initializer && initializer.kind === 261 /* VariableDeclarationList */) { loopInitializer = initializer; } break; } const loopParameters = []; const loopOutParameters = []; - if (loopInitializer && getCombinedNodeFlags(loopInitializer) & 3 /* BlockScoped */) { + if (loopInitializer && getCombinedNodeFlags(loopInitializer) & 7 /* BlockScoped */) { const hasCapturedBindingsInForHead = shouldConvertInitializerOfForStatement(node) || shouldConvertConditionOfForStatement(node) || shouldConvertIncrementorOfForStatement(node); for (const decl of loopInitializer.declarations) { processLoopVariableDeclaration(node, decl, loopParameters, loopOutParameters, hasCapturedBindingsInForHead); @@ -200228,10 +185525,10 @@ ${lanes.join("\n")} name )); const checkFlags = resolver.getNodeCheckFlags(decl); - if (checkFlags & 262144 /* NeedsLoopOutParameter */ || hasCapturedBindingsInForHead) { + if (checkFlags & 65536 /* NeedsLoopOutParameter */ || hasCapturedBindingsInForHead) { const outParamName = factory2.createUniqueName("out_" + idText(name)); let flags = 0 /* None */; - if (checkFlags & 262144 /* NeedsLoopOutParameter */) { + if (checkFlags & 65536 /* NeedsLoopOutParameter */) { flags |= 1 /* Body */; } if (isForStatement(container)) { @@ -200252,20 +185549,20 @@ ${lanes.join("\n")} for (let i = start; i < numProperties; i++) { const property = properties[i]; switch (property.kind) { - case 176 /* GetAccessor */: - case 177 /* SetAccessor */: + case 177 /* GetAccessor */: + case 178 /* SetAccessor */: const accessors = getAllAccessorDeclarations(node.properties, property); if (property === accessors.firstAccessor) { expressions.push(transformAccessorsToExpression(receiver, accessors, node, !!node.multiLine)); } break; - case 173 /* MethodDeclaration */: + case 174 /* MethodDeclaration */: expressions.push(transformObjectLiteralMethodDeclarationToExpression(property, receiver, node, node.multiLine)); break; - case 302 /* PropertyAssignment */: + case 303 /* PropertyAssignment */: expressions.push(transformPropertyAssignmentToExpression(property, receiver, node.multiLine)); break; - case 303 /* ShorthandPropertyAssignment */: + case 304 /* ShorthandPropertyAssignment */: expressions.push(transformShorthandPropertyAssignmentToExpression(property, receiver, node.multiLine)); break; default: @@ -200391,12 +185688,12 @@ ${lanes.join("\n")} let updated; const parameters = visitParameterList(node.parameters, visitor, context); const body = transformFunctionBody2(node); - if (node.kind === 176 /* GetAccessor */) { + if (node.kind === 177 /* GetAccessor */) { updated = factory2.updateGetAccessorDeclaration(node, node.modifiers, node.name, parameters, node.type, body); } else { updated = factory2.updateSetAccessorDeclaration(node, node.modifiers, node.name, parameters, body); } - exitSubtree(ancestorFacts, 98304 /* FunctionSubtreeExcludes */, 0 /* None */); + exitSubtree(ancestorFacts, 229376 /* FunctionSubtreeExcludes */, 0 /* None */); convertedLoopState = savedConvertedLoopState; return updated; } @@ -200546,13 +185843,6 @@ ${lanes.join("\n")} ) ); } - function visitSuperCallInBody(node) { - return visitCallExpressionWithPotentialCapturedThisAssignment( - node, - /*assignToCapturedThis*/ - false - ); - } function visitCallExpressionWithPotentialCapturedThisAssignment(node, assignToCapturedThis) { if (node.transformFlags & 32768 /* ContainsRestOrSpread */ || node.expression.kind === 108 /* SuperKeyword */ || isSuperProperty(skipOuterExpressions(node.expression))) { const { target, thisArg } = factory2.createCallBinding(node.expression, hoistVariableDeclaration); @@ -200589,10 +185879,13 @@ ${lanes.join("\n")} resultingCall, createActualThis() ); - resultingCall = assignToCapturedThis ? factory2.createAssignment(factory2.createUniqueName("_this", 16 /* Optimistic */ | 32 /* FileLevel */), initializer) : initializer; + resultingCall = assignToCapturedThis ? factory2.createAssignment(createCapturedThis(), initializer) : initializer; } return setOriginalNode(resultingCall, node); } + if (isSuperCall(node)) { + hierarchyFacts |= 131072 /* CapturedLexicalThis */; + } return visitEachChild(node, visitor, context); } function visitNewExpression(node) { @@ -200625,11 +185918,7 @@ ${lanes.join("\n")} // As we visit each element, we return one of two functions to use as the "key": // - `visitSpanOfSpreads` for one or more contiguous `...` spread expressions, i.e. `...a, ...b` in `[1, 2, ...a, ...b]` // - `visitSpanOfNonSpreads` for one or more contiguous non-spread elements, i.e. `1, 2`, in `[1, 2, ...a, ...b]` - spanMap( - elements, - partitionSpread, - (partition, visitPartition, _start, end) => visitPartition(partition, multiLine, hasTrailingComma && end === numElements) - ) + spanMap(elements, partitionSpread, (partition, visitPartition, _start, end) => visitPartition(partition, multiLine, hasTrailingComma && end === numElements)) ); if (segments.length === 1) { const firstSegment = segments[0]; @@ -200723,8 +186012,15 @@ ${lanes.join("\n")} } return setTextRange(expression, node); } - function visitSuperKeyword(isExpressionOfCall) { - return hierarchyFacts & 8 /* NonStaticClassElement */ && !isExpressionOfCall ? factory2.createPropertyAccessExpression(factory2.createUniqueName("_super", 16 /* Optimistic */ | 32 /* FileLevel */), "prototype") : factory2.createUniqueName("_super", 16 /* Optimistic */ | 32 /* FileLevel */); + function createSyntheticSuper() { + return factory2.createUniqueName("_super", 16 /* Optimistic */ | 32 /* FileLevel */); + } + function visitSuperKeyword(node, isExpressionOfCall) { + const expression = hierarchyFacts & 8 /* NonStaticClassElement */ && !isExpressionOfCall ? factory2.createPropertyAccessExpression(setOriginalNode(createSyntheticSuper(), node), "prototype") : createSyntheticSuper(); + setOriginalNode(expression, node); + setCommentRange(expression, node); + setSourceMapRange(expression, node); + return expression; } function visitMetaProperty(node) { if (node.keywordToken === 105 /* NewKeyword */ && node.name.escapedText === "target") { @@ -200755,13 +186051,13 @@ ${lanes.join("\n")} if ((enabledSubstitutions & 1 /* CapturedThis */) === 0) { enabledSubstitutions |= 1 /* CapturedThis */; context.enableSubstitution(110 /* ThisKeyword */); - context.enableEmitNotification(175 /* Constructor */); - context.enableEmitNotification(173 /* MethodDeclaration */); - context.enableEmitNotification(176 /* GetAccessor */); - context.enableEmitNotification(177 /* SetAccessor */); - context.enableEmitNotification(218 /* ArrowFunction */); - context.enableEmitNotification(217 /* FunctionExpression */); - context.enableEmitNotification(261 /* FunctionDeclaration */); + context.enableEmitNotification(176 /* Constructor */); + context.enableEmitNotification(174 /* MethodDeclaration */); + context.enableEmitNotification(177 /* GetAccessor */); + context.enableEmitNotification(178 /* SetAccessor */); + context.enableEmitNotification(219 /* ArrowFunction */); + context.enableEmitNotification(218 /* FunctionExpression */); + context.enableEmitNotification(262 /* FunctionDeclaration */); } } function onSubstituteNode(hint, node) { @@ -200785,10 +186081,10 @@ ${lanes.join("\n")} } function isNameOfDeclarationWithCollidingName(node) { switch (node.parent.kind) { - case 207 /* BindingElement */: - case 262 /* ClassDeclaration */: - case 265 /* EnumDeclaration */: - case 259 /* VariableDeclaration */: + case 208 /* BindingElement */: + case 263 /* ClassDeclaration */: + case 266 /* EnumDeclaration */: + case 260 /* VariableDeclaration */: return node.parent.name === node && resolver.isDeclarationWithCollidingName(node.parent); } return false; @@ -200830,7 +186126,7 @@ ${lanes.join("\n")} } function substituteThisKeyword(node) { if (enabledSubstitutions & 1 /* CapturedThis */ && hierarchyFacts & 16 /* CapturesThis */) { - return setTextRange(factory2.createUniqueName("_this", 16 /* Optimistic */ | 32 /* FileLevel */), node); + return setTextRange(createCapturedThis(), node); } return node; } @@ -200845,11 +186141,11 @@ ${lanes.join("\n")} return false; } const statement = firstOrUndefined(constructor.body.statements); - if (!statement || !nodeIsSynthesized(statement) || statement.kind !== 243 /* ExpressionStatement */) { + if (!statement || !nodeIsSynthesized(statement) || statement.kind !== 244 /* ExpressionStatement */) { return false; } const statementExpression = statement.expression; - if (!nodeIsSynthesized(statementExpression) || statementExpression.kind !== 212 /* CallExpression */) { + if (!nodeIsSynthesized(statementExpression) || statementExpression.kind !== 213 /* CallExpression */) { return false; } const callTarget = statementExpression.expression; @@ -200857,7 +186153,7 @@ ${lanes.join("\n")} return false; } const callArgument = singleOrUndefined(statementExpression.arguments); - if (!callArgument || !nodeIsSynthesized(callArgument) || callArgument.kind !== 229 /* SpreadElement */) { + if (!callArgument || !nodeIsSynthesized(callArgument) || callArgument.kind !== 230 /* SpreadElement */) { return false; } const expression = callArgument.expression; @@ -200880,24 +186176,24 @@ ${lanes.join("\n")} if (compilerOptions.jsx === 1 /* Preserve */ || compilerOptions.jsx === 3 /* ReactNative */) { previousOnEmitNode = context.onEmitNode; context.onEmitNode = onEmitNode; - context.enableEmitNotification(285 /* JsxOpeningElement */); - context.enableEmitNotification(286 /* JsxClosingElement */); - context.enableEmitNotification(284 /* JsxSelfClosingElement */); + context.enableEmitNotification(286 /* JsxOpeningElement */); + context.enableEmitNotification(287 /* JsxClosingElement */); + context.enableEmitNotification(285 /* JsxSelfClosingElement */); noSubstitution = []; } const previousOnSubstituteNode = context.onSubstituteNode; context.onSubstituteNode = onSubstituteNode; - context.enableSubstitution(210 /* PropertyAccessExpression */); - context.enableSubstitution(302 /* PropertyAssignment */); + context.enableSubstitution(211 /* PropertyAccessExpression */); + context.enableSubstitution(303 /* PropertyAssignment */); return chainBundle(context, transformSourceFile); function transformSourceFile(node) { return node; } function onEmitNode(hint, node, emitCallback) { switch (node.kind) { - case 285 /* JsxOpeningElement */: - case 286 /* JsxClosingElement */: - case 284 /* JsxSelfClosingElement */: + case 286 /* JsxOpeningElement */: + case 287 /* JsxClosingElement */: + case 285 /* JsxSelfClosingElement */: const tagName = node.tagName; noSubstitution[getOriginalNodeId(tagName)] = true; break; @@ -201029,13 +186325,13 @@ ${lanes.join("\n")} } function visitJavaScriptInStatementContainingYield(node) { switch (node.kind) { - case 245 /* DoStatement */: + case 246 /* DoStatement */: return visitDoStatement(node); - case 246 /* WhileStatement */: + case 247 /* WhileStatement */: return visitWhileStatement(node); - case 254 /* SwitchStatement */: + case 255 /* SwitchStatement */: return visitSwitchStatement(node); - case 255 /* LabeledStatement */: + case 256 /* LabeledStatement */: return visitLabeledStatement(node); default: return visitJavaScriptInGeneratorFunctionBody(node); @@ -201043,24 +186339,24 @@ ${lanes.join("\n")} } function visitJavaScriptInGeneratorFunctionBody(node) { switch (node.kind) { - case 261 /* FunctionDeclaration */: + case 262 /* FunctionDeclaration */: return visitFunctionDeclaration(node); - case 217 /* FunctionExpression */: + case 218 /* FunctionExpression */: return visitFunctionExpression(node); - case 176 /* GetAccessor */: - case 177 /* SetAccessor */: + case 177 /* GetAccessor */: + case 178 /* SetAccessor */: return visitAccessorDeclaration(node); - case 242 /* VariableStatement */: + case 243 /* VariableStatement */: return visitVariableStatement(node); - case 247 /* ForStatement */: + case 248 /* ForStatement */: return visitForStatement(node); - case 248 /* ForInStatement */: + case 249 /* ForInStatement */: return visitForInStatement(node); - case 251 /* BreakStatement */: + case 252 /* BreakStatement */: return visitBreakStatement(node); - case 250 /* ContinueStatement */: + case 251 /* ContinueStatement */: return visitContinueStatement(node); - case 252 /* ReturnStatement */: + case 253 /* ReturnStatement */: return visitReturnStatement(node); default: if (node.transformFlags & 1048576 /* ContainsYield */) { @@ -201074,23 +186370,23 @@ ${lanes.join("\n")} } function visitJavaScriptContainingYield(node) { switch (node.kind) { - case 225 /* BinaryExpression */: + case 226 /* BinaryExpression */: return visitBinaryExpression(node); - case 360 /* CommaListExpression */: + case 361 /* CommaListExpression */: return visitCommaListExpression(node); - case 226 /* ConditionalExpression */: + case 227 /* ConditionalExpression */: return visitConditionalExpression(node); - case 228 /* YieldExpression */: + case 229 /* YieldExpression */: return visitYieldExpression(node); - case 208 /* ArrayLiteralExpression */: + case 209 /* ArrayLiteralExpression */: return visitArrayLiteralExpression(node); - case 209 /* ObjectLiteralExpression */: + case 210 /* ObjectLiteralExpression */: return visitObjectLiteralExpression(node); - case 211 /* ElementAccessExpression */: + case 212 /* ElementAccessExpression */: return visitElementAccessExpression(node); - case 212 /* CallExpression */: + case 213 /* CallExpression */: return visitCallExpression(node); - case 213 /* NewExpression */: + case 214 /* NewExpression */: return visitNewExpression(node); default: return visitEachChild(node, visitor, context); @@ -201098,9 +186394,9 @@ ${lanes.join("\n")} } function visitGenerator(node) { switch (node.kind) { - case 261 /* FunctionDeclaration */: + case 262 /* FunctionDeclaration */: return visitFunctionDeclaration(node); - case 217 /* FunctionExpression */: + case 218 /* FunctionExpression */: return visitFunctionExpression(node); default: return Debug.failBadSyntaxKind(node); @@ -201285,19 +186581,15 @@ ${lanes.join("\n")} if (containsYield(right)) { let target; switch (left.kind) { - case 210 /* PropertyAccessExpression */: + case 211 /* PropertyAccessExpression */: target = factory2.updatePropertyAccessExpression( left, cacheExpression(Debug.checkDefined(visitNode(left.expression, visitor, isLeftHandSideExpression))), left.name ); break; - case 211 /* ElementAccessExpression */: - target = factory2.updateElementAccessExpression( - left, - cacheExpression(Debug.checkDefined(visitNode(left.expression, visitor, isLeftHandSideExpression))), - cacheExpression(Debug.checkDefined(visitNode(left.argumentExpression, visitor, isExpression))) - ); + case 212 /* ElementAccessExpression */: + target = factory2.updateElementAccessExpression(left, cacheExpression(Debug.checkDefined(visitNode(left.expression, visitor, isLeftHandSideExpression))), cacheExpression(Debug.checkDefined(visitNode(left.argumentExpression, visitor, isExpression)))); break; default: target = Debug.checkDefined(visitNode(left, visitor, isExpression)); @@ -201332,12 +186624,7 @@ ${lanes.join("\n")} } else if (node.operatorToken.kind === 28 /* CommaToken */) { return visitCommaExpression(node); } - return factory2.updateBinaryExpression( - node, - cacheExpression(Debug.checkDefined(visitNode(node.left, visitor, isExpression))), - node.operatorToken, - Debug.checkDefined(visitNode(node.right, visitor, isExpression)) - ); + return factory2.updateBinaryExpression(node, cacheExpression(Debug.checkDefined(visitNode(node.left, visitor, isExpression))), node.operatorToken, Debug.checkDefined(visitNode(node.right, visitor, isExpression))); } return visitEachChild(node, visitor, context); } @@ -201545,11 +186832,7 @@ ${lanes.join("\n")} } function visitElementAccessExpression(node) { if (containsYield(node.argumentExpression)) { - return factory2.updateElementAccessExpression( - node, - cacheExpression(Debug.checkDefined(visitNode(node.expression, visitor, isLeftHandSideExpression))), - Debug.checkDefined(visitNode(node.argumentExpression, visitor, isExpression)) - ); + return factory2.updateElementAccessExpression(node, cacheExpression(Debug.checkDefined(visitNode(node.expression, visitor, isLeftHandSideExpression))), Debug.checkDefined(visitNode(node.argumentExpression, visitor, isExpression))); } return visitEachChild(node, visitor, context); } @@ -201625,35 +186908,35 @@ ${lanes.join("\n")} } function transformAndEmitStatementWorker(node) { switch (node.kind) { - case 240 /* Block */: + case 241 /* Block */: return transformAndEmitBlock(node); - case 243 /* ExpressionStatement */: + case 244 /* ExpressionStatement */: return transformAndEmitExpressionStatement(node); - case 244 /* IfStatement */: + case 245 /* IfStatement */: return transformAndEmitIfStatement(node); - case 245 /* DoStatement */: + case 246 /* DoStatement */: return transformAndEmitDoStatement(node); - case 246 /* WhileStatement */: + case 247 /* WhileStatement */: return transformAndEmitWhileStatement(node); - case 247 /* ForStatement */: + case 248 /* ForStatement */: return transformAndEmitForStatement(node); - case 248 /* ForInStatement */: + case 249 /* ForInStatement */: return transformAndEmitForInStatement(node); - case 250 /* ContinueStatement */: + case 251 /* ContinueStatement */: return transformAndEmitContinueStatement(node); - case 251 /* BreakStatement */: + case 252 /* BreakStatement */: return transformAndEmitBreakStatement(node); - case 252 /* ReturnStatement */: + case 253 /* ReturnStatement */: return transformAndEmitReturnStatement(node); - case 253 /* WithStatement */: + case 254 /* WithStatement */: return transformAndEmitWithStatement(node); - case 254 /* SwitchStatement */: + case 255 /* SwitchStatement */: return transformAndEmitSwitchStatement(node); - case 255 /* LabeledStatement */: + case 256 /* LabeledStatement */: return transformAndEmitLabeledStatement(node); - case 256 /* ThrowStatement */: + case 257 /* ThrowStatement */: return transformAndEmitThrowStatement(node); - case 257 /* TryStatement */: + case 258 /* TryStatement */: return transformAndEmitTryStatement(node); default: return emitStatement(visitNode(node, visitor, isStatement)); @@ -201907,12 +187190,7 @@ ${lanes.join("\n")} for (const variable of initializer.declarations) { hoistVariableDeclaration(variable.name); } - node = factory2.updateForInStatement( - node, - initializer.declarations[0].name, - Debug.checkDefined(visitNode(node.expression, visitor, isExpression)), - Debug.checkDefined(visitNode(node.statement, visitor, isStatement, factory2.liftToBlock)) - ); + node = factory2.updateForInStatement(node, initializer.declarations[0].name, Debug.checkDefined(visitNode(node.expression, visitor, isExpression)), Debug.checkDefined(visitNode(node.statement, visitor, isStatement, factory2.liftToBlock))); } else { node = visitEachChild(node, visitor, context); } @@ -202005,7 +187283,7 @@ ${lanes.join("\n")} for (let i = 0; i < numClauses; i++) { const clause = caseBlock.clauses[i]; clauseLabels.push(defineLabel()); - if (clause.kind === 296 /* DefaultClause */ && defaultClauseIndex === -1) { + if (clause.kind === 297 /* DefaultClause */ && defaultClauseIndex === -1) { defaultClauseIndex = i; } } @@ -202015,7 +187293,7 @@ ${lanes.join("\n")} let defaultClausesSkipped = 0; for (let i = clausesWritten; i < numClauses; i++) { const clause = caseBlock.clauses[i]; - if (clause.kind === 295 /* CaseClause */) { + if (clause.kind === 296 /* CaseClause */) { if (containsYield(clause.expression) && pendingClauses.length > 0) { break; } @@ -202988,12 +188266,12 @@ ${lanes.join("\n")} const previousOnEmitNode = context.onEmitNode; context.onSubstituteNode = onSubstituteNode; context.onEmitNode = onEmitNode; - context.enableSubstitution(212 /* CallExpression */); - context.enableSubstitution(214 /* TaggedTemplateExpression */); + context.enableSubstitution(213 /* CallExpression */); + context.enableSubstitution(215 /* TaggedTemplateExpression */); context.enableSubstitution(80 /* Identifier */); - context.enableSubstitution(225 /* BinaryExpression */); - context.enableSubstitution(303 /* ShorthandPropertyAssignment */); - context.enableEmitNotification(311 /* SourceFile */); + context.enableSubstitution(226 /* BinaryExpression */); + context.enableSubstitution(304 /* ShorthandPropertyAssignment */); + context.enableEmitNotification(312 /* SourceFile */); const moduleInfoMap = []; let currentSourceFile; let currentModuleInfo; @@ -203005,7 +188283,7 @@ ${lanes.join("\n")} return node; } currentSourceFile = node; - currentModuleInfo = collectExternalModuleInfo(context, node, resolver, compilerOptions); + currentModuleInfo = collectExternalModuleInfo(context, node); moduleInfoMap[getOriginalNodeId(node)] = currentModuleInfo; const transformModule2 = getTransformModuleDelegate(moduleKind); const updated = transformModule2(node); @@ -203079,12 +188357,14 @@ ${lanes.join("\n")} // Add the dependency array argument: // // ["require", "exports", module1", "module2", ...] - factory2.createArrayLiteralExpression(jsonSourceFile ? emptyArray : [ - factory2.createStringLiteral("require"), - factory2.createStringLiteral("exports"), - ...aliasedModuleNames, - ...unaliasedModuleNames - ]), + factory2.createArrayLiteralExpression( + jsonSourceFile ? emptyArray : [ + factory2.createStringLiteral("require"), + factory2.createStringLiteral("exports"), + ...aliasedModuleNames, + ...unaliasedModuleNames + ] + ), // Add the module body function argument: // // function (require, exports, module1, module2) ... @@ -203405,63 +188685,59 @@ ${lanes.join("\n")} } function topLevelVisitor(node) { switch (node.kind) { - case 271 /* ImportDeclaration */: - return visitImportDeclaration(node); - case 270 /* ImportEqualsDeclaration */: - return visitImportEqualsDeclaration(node); - case 277 /* ExportDeclaration */: - return visitExportDeclaration(node); - case 276 /* ExportAssignment */: - return visitExportAssignment(node); - case 261 /* FunctionDeclaration */: - return visitFunctionDeclaration(node); - case 262 /* ClassDeclaration */: - return visitClassDeclaration(node); + case 272 /* ImportDeclaration */: + return visitTopLevelImportDeclaration(node); + case 271 /* ImportEqualsDeclaration */: + return visitTopLevelImportEqualsDeclaration(node); + case 278 /* ExportDeclaration */: + return visitTopLevelExportDeclaration(node); + case 277 /* ExportAssignment */: + return visitTopLevelExportAssignment(node); default: return topLevelNestedVisitor(node); } } function topLevelNestedVisitor(node) { switch (node.kind) { - case 242 /* VariableStatement */: + case 243 /* VariableStatement */: return visitVariableStatement(node); - case 261 /* FunctionDeclaration */: + case 262 /* FunctionDeclaration */: return visitFunctionDeclaration(node); - case 262 /* ClassDeclaration */: + case 263 /* ClassDeclaration */: return visitClassDeclaration(node); - case 247 /* ForStatement */: + case 248 /* ForStatement */: return visitForStatement( node, /*isTopLevel*/ true ); - case 248 /* ForInStatement */: + case 249 /* ForInStatement */: return visitForInStatement(node); - case 249 /* ForOfStatement */: + case 250 /* ForOfStatement */: return visitForOfStatement(node); - case 245 /* DoStatement */: + case 246 /* DoStatement */: return visitDoStatement(node); - case 246 /* WhileStatement */: + case 247 /* WhileStatement */: return visitWhileStatement(node); - case 255 /* LabeledStatement */: + case 256 /* LabeledStatement */: return visitLabeledStatement(node); - case 253 /* WithStatement */: + case 254 /* WithStatement */: return visitWithStatement(node); - case 244 /* IfStatement */: + case 245 /* IfStatement */: return visitIfStatement(node); - case 254 /* SwitchStatement */: + case 255 /* SwitchStatement */: return visitSwitchStatement(node); - case 268 /* CaseBlock */: + case 269 /* CaseBlock */: return visitCaseBlock(node); - case 295 /* CaseClause */: + case 296 /* CaseClause */: return visitCaseClause(node); - case 296 /* DefaultClause */: + case 297 /* DefaultClause */: return visitDefaultClause(node); - case 257 /* TryStatement */: + case 258 /* TryStatement */: return visitTryStatement(node); - case 298 /* CatchClause */: + case 299 /* CatchClause */: return visitCatchClause(node); - case 240 /* Block */: + case 241 /* Block */: return visitBlock(node); default: return visitor(node); @@ -203472,30 +188748,30 @@ ${lanes.join("\n")} return node; } switch (node.kind) { - case 247 /* ForStatement */: + case 248 /* ForStatement */: return visitForStatement( node, /*isTopLevel*/ false ); - case 243 /* ExpressionStatement */: + case 244 /* ExpressionStatement */: return visitExpressionStatement(node); - case 216 /* ParenthesizedExpression */: + case 217 /* ParenthesizedExpression */: return visitParenthesizedExpression(node, valueIsDiscarded); - case 359 /* PartiallyEmittedExpression */: + case 360 /* PartiallyEmittedExpression */: return visitPartiallyEmittedExpression(node, valueIsDiscarded); - case 212 /* CallExpression */: + case 213 /* CallExpression */: if (isImportCall(node) && currentSourceFile.impliedNodeFormat === void 0) { return visitImportCallExpression(node); } break; - case 225 /* BinaryExpression */: + case 226 /* BinaryExpression */: if (isDestructuringAssignment(node)) { return visitDestructuringAssignment(node, valueIsDiscarded); } break; - case 223 /* PrefixUnaryExpression */: - case 224 /* PostfixUnaryExpression */: + case 224 /* PrefixUnaryExpression */: + case 225 /* PostfixUnaryExpression */: return visitPreOrPostfixUnaryExpression(node, valueIsDiscarded); } return visitEachChild(node, visitor, context); @@ -203518,24 +188794,24 @@ ${lanes.join("\n")} if (isObjectLiteralExpression(node)) { for (const elem of node.properties) { switch (elem.kind) { - case 302 /* PropertyAssignment */: + case 303 /* PropertyAssignment */: if (destructuringNeedsFlattening(elem.initializer)) { return true; } break; - case 303 /* ShorthandPropertyAssignment */: + case 304 /* ShorthandPropertyAssignment */: if (destructuringNeedsFlattening(elem.name)) { return true; } break; - case 304 /* SpreadAssignment */: + case 305 /* SpreadAssignment */: if (destructuringNeedsFlattening(elem.expression)) { return true; } break; - case 173 /* MethodDeclaration */: - case 176 /* GetAccessor */: - case 177 /* SetAccessor */: + case 174 /* MethodDeclaration */: + case 177 /* GetAccessor */: + case 178 /* SetAccessor */: return false; default: Debug.assertNever(elem, "Unhandled object member kind"); @@ -203563,7 +188839,7 @@ ${lanes.join("\n")} return visitEachChild(node, visitor, context); } function visitForStatement(node, isTopLevel) { - if (isTopLevel && node.initializer && isVariableDeclarationList(node.initializer) && !(node.initializer.flags & 3 /* BlockScoped */)) { + if (isTopLevel && node.initializer && isVariableDeclarationList(node.initializer) && !(node.initializer.flags & 7 /* BlockScoped */)) { const exportStatements = appendExportsOfVariableDeclarationList( /*statements*/ void 0, @@ -203604,7 +188880,7 @@ ${lanes.join("\n")} ); } function visitForInStatement(node) { - if (isVariableDeclarationList(node.initializer) && !(node.initializer.flags & 3 /* BlockScoped */)) { + if (isVariableDeclarationList(node.initializer) && !(node.initializer.flags & 7 /* BlockScoped */)) { const exportStatements = appendExportsOfVariableDeclarationList( /*statements*/ void 0, @@ -203632,7 +188908,7 @@ ${lanes.join("\n")} ); } function visitForOfStatement(node) { - if (isVariableDeclarationList(node.initializer) && !(node.initializer.flags & 3 /* BlockScoped */)) { + if (isVariableDeclarationList(node.initializer) && !(node.initializer.flags & 7 /* BlockScoped */)) { const exportStatements = appendExportsOfVariableDeclarationList( /*statements*/ void 0, @@ -203814,22 +189090,25 @@ ${lanes.join("\n")} ); } else { const temp = factory2.createTempVariable(hoistVariableDeclaration); - return factory2.createComma(factory2.createAssignment(temp, arg), factory2.createConditionalExpression( - /*condition*/ - factory2.createIdentifier("__syncRequire"), - /*questionToken*/ - void 0, - /*whenTrue*/ - createImportCallExpressionCommonJS( - temp, - /*isInlineable*/ - true - ), - /*colonToken*/ - void 0, - /*whenFalse*/ - createImportCallExpressionAMD(temp, containsLexicalThis) - )); + return factory2.createComma( + factory2.createAssignment(temp, arg), + factory2.createConditionalExpression( + /*condition*/ + factory2.createIdentifier("__syncRequire"), + /*questionToken*/ + void 0, + /*whenTrue*/ + createImportCallExpressionCommonJS( + temp, + /*isInlineable*/ + true + ), + /*colonToken*/ + void 0, + /*whenFalse*/ + createImportCallExpressionAMD(temp, containsLexicalThis) + ) + ); } } function createImportCallExpressionAMD(arg, containsLexicalThis) { @@ -204012,7 +189291,7 @@ ${lanes.join("\n")} } return innerExpr; } - function visitImportDeclaration(node) { + function visitTopLevelImportDeclaration(node) { let statements; const namespaceDeclaration = getNamespaceDeclarationNode(node); if (moduleKind !== 2 /* AMD */) { @@ -204121,11 +189400,11 @@ ${lanes.join("\n")} args ); } - function visitImportEqualsDeclaration(node) { + function visitTopLevelImportEqualsDeclaration(node) { Debug.assert(isExternalModuleImportEqualsDeclaration(node), "import= for internal module references should be handled in an earlier transformer."); let statements; if (moduleKind !== 2 /* AMD */) { - if (hasSyntacticModifier(node, 1 /* Export */)) { + if (hasSyntacticModifier(node, 32 /* Export */)) { statements = append( statements, setOriginalNode( @@ -204171,7 +189450,7 @@ ${lanes.join("\n")} ); } } else { - if (hasSyntacticModifier(node, 1 /* Export */)) { + if (hasSyntacticModifier(node, 32 /* Export */)) { statements = append( statements, setOriginalNode( @@ -204189,7 +189468,7 @@ ${lanes.join("\n")} statements = appendExportsOfImportEqualsDeclaration(statements, node); return singleOrMany(statements); } - function visitExportDeclaration(node) { + function visitTopLevelExportDeclaration(node) { if (!node.moduleSpecifier) { return void 0; } @@ -204270,7 +189549,10 @@ ${lanes.join("\n")} factory2.createExpressionStatement( createExportExpression( factory2.cloneNode(node.exportClause.name), - getHelperExpressionForExport(node, moduleKind !== 2 /* AMD */ ? createRequireCall2(node) : isExportNamespaceAsDefaultDeclaration(node) ? generatedName : factory2.createIdentifier(idText(node.exportClause.name))) + getHelperExpressionForExport( + node, + moduleKind !== 2 /* AMD */ ? createRequireCall2(node) : isExportNamespaceAsDefaultDeclaration(node) ? generatedName : factory2.createIdentifier(idText(node.exportClause.name)) + ) ) ), node @@ -204291,7 +189573,7 @@ ${lanes.join("\n")} ); } } - function visitExportAssignment(node) { + function visitTopLevelExportAssignment(node) { if (node.isExportEquals) { return void 0; } @@ -204306,7 +189588,7 @@ ${lanes.join("\n")} } function visitFunctionDeclaration(node) { let statements; - if (hasSyntacticModifier(node, 1 /* Export */)) { + if (hasSyntacticModifier(node, 32 /* Export */)) { statements = append( statements, setOriginalNode( @@ -204343,7 +189625,7 @@ ${lanes.join("\n")} } function visitClassDeclaration(node) { let statements; - if (hasSyntacticModifier(node, 1 /* Export */)) { + if (hasSyntacticModifier(node, 32 /* Export */)) { statements = append( statements, setOriginalNode( @@ -204377,7 +189659,7 @@ ${lanes.join("\n")} let statements; let variables; let expressions; - if (hasSyntacticModifier(node, 1 /* Export */)) { + if (hasSyntacticModifier(node, 32 /* Export */)) { let modifiers; let removeCommentsOnExpressions = false; for (const variable of node.declarationList.declarations) { @@ -204495,19 +189777,21 @@ ${lanes.join("\n")} if (!importClause) { return statements; } + const seen = new IdentifierNameMap(); if (importClause.name) { - statements = appendExportsOfDeclaration(statements, importClause); + statements = appendExportsOfDeclaration(statements, seen, importClause); } const namedBindings = importClause.namedBindings; if (namedBindings) { switch (namedBindings.kind) { - case 273 /* NamespaceImport */: - statements = appendExportsOfDeclaration(statements, namedBindings); + case 274 /* NamespaceImport */: + statements = appendExportsOfDeclaration(statements, seen, namedBindings); break; - case 274 /* NamedImports */: + case 275 /* NamedImports */: for (const importBinding of namedBindings.elements) { statements = appendExportsOfDeclaration( statements, + seen, importBinding, /*liveBinding*/ true @@ -204522,7 +189806,7 @@ ${lanes.join("\n")} if (currentModuleInfo.exportEquals) { return statements; } - return appendExportsOfDeclaration(statements, decl); + return appendExportsOfDeclaration(statements, new IdentifierNameMap(), decl); } function appendExportsOfVariableStatement(statements, node) { return appendExportsOfVariableDeclarationList( @@ -204552,7 +189836,7 @@ ${lanes.join("\n")} } } } else if (!isGeneratedIdentifier(decl.name) && (!isVariableDeclaration(decl) || decl.initializer || isForInOrOfInitializer)) { - statements = appendExportsOfDeclaration(statements, decl); + statements = appendExportsOfDeclaration(statements, new IdentifierNameMap(), decl); } return statements; } @@ -204560,10 +189844,12 @@ ${lanes.join("\n")} if (currentModuleInfo.exportEquals) { return statements; } - if (hasSyntacticModifier(decl, 1 /* Export */)) { - const exportName = hasSyntacticModifier(decl, 1024 /* Default */) ? factory2.createIdentifier("default") : factory2.getDeclarationName(decl); + const seen = new IdentifierNameMap(); + if (hasSyntacticModifier(decl, 32 /* Export */)) { + const exportName = hasSyntacticModifier(decl, 2048 /* Default */) ? factory2.createIdentifier("default") : factory2.getDeclarationName(decl); statements = appendExportStatement( statements, + seen, exportName, factory2.getLocalName(decl), /*location*/ @@ -204571,17 +189857,18 @@ ${lanes.join("\n")} ); } if (decl.name) { - statements = appendExportsOfDeclaration(statements, decl); + statements = appendExportsOfDeclaration(statements, seen, decl); } return statements; } - function appendExportsOfDeclaration(statements, decl, liveBinding) { + function appendExportsOfDeclaration(statements, seen, decl, liveBinding) { const name = factory2.getDeclarationName(decl); - const exportSpecifiers = currentModuleInfo.exportSpecifiers.get(idText(name)); + const exportSpecifiers = currentModuleInfo.exportSpecifiers.get(name); if (exportSpecifiers) { for (const exportSpecifier of exportSpecifiers) { statements = appendExportStatement( statements, + seen, exportSpecifier.name, name, /*location*/ @@ -204594,8 +189881,11 @@ ${lanes.join("\n")} } return statements; } - function appendExportStatement(statements, exportName, expression, location, allowComments, liveBinding) { - statements = append(statements, createExportStatement(exportName, expression, location, allowComments, liveBinding)); + function appendExportStatement(statements, seen, exportName, expression, location, allowComments, liveBinding) { + if (!seen.has(exportName)) { + seen.set(exportName, true); + statements = append(statements, createExportStatement(exportName, expression, location, allowComments, liveBinding)); + } return statements; } function createUnderscoreUnderscoreESModule() { @@ -204654,21 +189944,24 @@ ${lanes.join("\n")} factory2.createStringLiteralFromNode(name), factory2.createObjectLiteralExpression([ factory2.createPropertyAssignment("enumerable", factory2.createTrue()), - factory2.createPropertyAssignment("get", factory2.createFunctionExpression( - /*modifiers*/ - void 0, - /*asteriskToken*/ - void 0, - /*name*/ - void 0, - /*typeParameters*/ - void 0, - /*parameters*/ - [], - /*type*/ - void 0, - factory2.createBlock([factory2.createReturnStatement(value)]) - )) + factory2.createPropertyAssignment( + "get", + factory2.createFunctionExpression( + /*modifiers*/ + void 0, + /*asteriskToken*/ + void 0, + /*name*/ + void 0, + /*typeParameters*/ + void 0, + /*parameters*/ + [], + /*type*/ + void 0, + factory2.createBlock([factory2.createReturnStatement(value)]) + ) + ) ]) ] ) : factory2.createAssignment( @@ -204690,7 +189983,7 @@ ${lanes.join("\n")} return node; } function onEmitNode(hint, node, emitCallback) { - if (node.kind === 311 /* SourceFile */) { + if (node.kind === 312 /* SourceFile */) { currentSourceFile = node; currentModuleInfo = moduleInfoMap[getOriginalNodeId(currentSourceFile)]; previousOnEmitNode(hint, node, emitCallback); @@ -204728,11 +190021,11 @@ ${lanes.join("\n")} switch (node.kind) { case 80 /* Identifier */: return substituteExpressionIdentifier(node); - case 212 /* CallExpression */: + case 213 /* CallExpression */: return substituteCallExpression(node); - case 214 /* TaggedTemplateExpression */: + case 215 /* TaggedTemplateExpression */: return substituteTaggedTemplateExpression(node); - case 225 /* BinaryExpression */: + case 226 /* BinaryExpression */: return substituteBinaryExpression(node); } return node; @@ -204785,7 +190078,7 @@ ${lanes.join("\n")} return node; } else if (!(isGeneratedIdentifier(node) && !(node.emitNode.autoGenerate.flags & 64 /* AllowNameSubstitution */)) && !isLocalName(node)) { const exportContainer = resolver.getReferencedExportContainer(node, isExportName(node)); - if (exportContainer && exportContainer.kind === 311 /* SourceFile */) { + if (exportContainer && exportContainer.kind === 312 /* SourceFile */) { return setTextRange( factory2.createPropertyAccessExpression( factory2.createIdentifier("exports"), @@ -204822,7 +190115,7 @@ ${lanes.join("\n")} return node; } function substituteBinaryExpression(node) { - if (isAssignmentOperator(node.operatorToken.kind) && isIdentifier(node.left) && !isGeneratedIdentifier(node.left) && !isLocalName(node.left)) { + if (isAssignmentOperator(node.operatorToken.kind) && isIdentifier(node.left) && (!isGeneratedIdentifier(node.left) || isFileLevelReservedGeneratedIdentifier(node.left)) && !isLocalName(node.left)) { const exportedNames = getExports(node.left); if (exportedNames) { let expression = node; @@ -204861,6 +190154,15 @@ ${lanes.join("\n")} return arrayFrom(bindingsSet); } } + } else if (isFileLevelReservedGeneratedIdentifier(name)) { + const exportSpecifiers = currentModuleInfo == null ? void 0 : currentModuleInfo.exportSpecifiers.get(name); + if (exportSpecifiers) { + const exportedNames = []; + for (const exportSpecifier of exportSpecifiers) { + exportedNames.push(exportSpecifier.name); + } + return exportedNames; + } } } } @@ -204894,10 +190196,10 @@ ${lanes.join("\n")} context.onSubstituteNode = onSubstituteNode; context.onEmitNode = onEmitNode; context.enableSubstitution(80 /* Identifier */); - context.enableSubstitution(303 /* ShorthandPropertyAssignment */); - context.enableSubstitution(225 /* BinaryExpression */); - context.enableSubstitution(235 /* MetaProperty */); - context.enableEmitNotification(311 /* SourceFile */); + context.enableSubstitution(304 /* ShorthandPropertyAssignment */); + context.enableSubstitution(226 /* BinaryExpression */); + context.enableSubstitution(236 /* MetaProperty */); + context.enableEmitNotification(312 /* SourceFile */); const moduleInfoMap = []; const exportFunctionsMap = []; const noSubstitutionMap = []; @@ -204917,7 +190219,7 @@ ${lanes.join("\n")} const id = getOriginalNodeId(node); currentSourceFile = node; enclosingBlockScopedContainer = node; - moduleInfo = moduleInfoMap[id] = collectExternalModuleInfo(context, node, resolver, compilerOptions); + moduleInfo = moduleInfoMap[id] = collectExternalModuleInfo(context, node); exportFunction = factory2.createUniqueName("exports"); exportFunctionsMap[id] = exportFunction; contextObject = contextObjectMap[id] = factory2.createUniqueName("context"); @@ -205038,13 +190340,10 @@ ${lanes.join("\n")} addRange(statements, hoistedStatements); insertStatementsAfterStandardPrologue(statements, endLexicalEnvironment()); const exportStarFunction = addExportStarIfNeeded(statements); - const modifiers = node.transformFlags & 2097152 /* ContainsAwait */ ? factory2.createModifiersFromModifierFlags(512 /* Async */) : void 0; + const modifiers = node.transformFlags & 2097152 /* ContainsAwait */ ? factory2.createModifiersFromModifierFlags(1024 /* Async */) : void 0; const moduleObject = factory2.createObjectLiteralExpression( [ - factory2.createPropertyAssignment( - "setters", - createSettersArray(exportStarFunction, dependencyGroups) - ), + factory2.createPropertyAssignment("setters", createSettersArray(exportStarFunction, dependencyGroups)), factory2.createPropertyAssignment( "execute", factory2.createFunctionExpression( @@ -205084,7 +190383,7 @@ ${lanes.join("\n")} if (!moduleInfo.exportedNames && moduleInfo.exportSpecifiers.size === 0) { let hasExportDeclarationWithExportClause = false; for (const externalImport of moduleInfo.externalImports) { - if (externalImport.kind === 277 /* ExportDeclaration */ && externalImport.exportClause) { + if (externalImport.kind === 278 /* ExportDeclaration */ && externalImport.exportClause) { hasExportDeclarationWithExportClause = true; break; } @@ -205232,18 +190531,18 @@ ${lanes.join("\n")} for (const entry of group2.externalImports) { const importVariableName = getLocalNameForExternalImport(factory2, entry, currentSourceFile); switch (entry.kind) { - case 271 /* ImportDeclaration */: + case 272 /* ImportDeclaration */: if (!entry.importClause) { break; } - case 270 /* ImportEqualsDeclaration */: + case 271 /* ImportEqualsDeclaration */: Debug.assert(importVariableName !== void 0); statements.push( factory2.createExpressionStatement( factory2.createAssignment(importVariableName, parameterName) ) ); - if (hasSyntacticModifier(entry, 1 /* Export */)) { + if (hasSyntacticModifier(entry, 32 /* Export */)) { statements.push( factory2.createExpressionStatement( factory2.createCallExpression( @@ -205259,7 +190558,7 @@ ${lanes.join("\n")} ); } break; - case 277 /* ExportDeclaration */: + case 278 /* ExportDeclaration */: Debug.assert(importVariableName !== void 0); if (entry.exportClause) { if (isNamedExports(entry.exportClause)) { @@ -205354,13 +190653,13 @@ ${lanes.join("\n")} } function topLevelVisitor(node) { switch (node.kind) { - case 271 /* ImportDeclaration */: + case 272 /* ImportDeclaration */: return visitImportDeclaration(node); - case 270 /* ImportEqualsDeclaration */: + case 271 /* ImportEqualsDeclaration */: return visitImportEqualsDeclaration(node); - case 277 /* ExportDeclaration */: + case 278 /* ExportDeclaration */: return visitExportDeclaration(node); - case 276 /* ExportAssignment */: + case 277 /* ExportAssignment */: return visitExportAssignment(node); default: return topLevelNestedVisitor(node); @@ -205396,7 +190695,7 @@ ${lanes.join("\n")} ); } function visitFunctionDeclaration(node) { - if (hasSyntacticModifier(node, 1 /* Export */)) { + if (hasSyntacticModifier(node, 32 /* Export */)) { hoistedStatements = append( hoistedStatements, factory2.updateFunctionDeclaration( @@ -205457,18 +190756,43 @@ ${lanes.join("\n")} if (!shouldHoistVariableDeclarationList(node.declarationList)) { return visitNode(node, visitor, isStatement); } - let expressions; - const isExportedDeclaration = hasSyntacticModifier(node, 1 /* Export */); - for (const variable of node.declarationList.declarations) { - if (variable.initializer) { - expressions = append(expressions, transformInitializedVariable(variable, isExportedDeclaration)); - } else { - hoistBindingElement(variable); - } - } let statements; - if (expressions) { - statements = append(statements, setTextRange(factory2.createExpressionStatement(factory2.inlineExpressions(expressions)), node)); + if (isVarUsing(node.declarationList) || isVarAwaitUsing(node.declarationList)) { + const modifiers = visitNodes2(node.modifiers, modifierVisitor, isModifierLike); + const declarations = []; + for (const variable of node.declarationList.declarations) { + declarations.push(factory2.updateVariableDeclaration( + variable, + factory2.getGeneratedNameForNode(variable.name), + /*exclamationToken*/ + void 0, + /*type*/ + void 0, + transformInitializedVariable( + variable, + /*isExportedDeclaration*/ + false + ) + )); + } + const declarationList = factory2.updateVariableDeclarationList( + node.declarationList, + declarations + ); + statements = append(statements, factory2.updateVariableStatement(node, modifiers, declarationList)); + } else { + let expressions; + const isExportedDeclaration = hasSyntacticModifier(node, 32 /* Export */); + for (const variable of node.declarationList.declarations) { + if (variable.initializer) { + expressions = append(expressions, transformInitializedVariable(variable, isExportedDeclaration)); + } else { + hoistBindingElement(variable); + } + } + if (expressions) { + statements = append(statements, setTextRange(factory2.createExpressionStatement(factory2.inlineExpressions(expressions)), node)); + } } statements = appendExportsOfVariableStatement( statements, @@ -205490,7 +190814,7 @@ ${lanes.join("\n")} } } function shouldHoistVariableDeclarationList(node) { - return (getEmitFlags(node) & 4194304 /* NoHoisting */) === 0 && (enclosingBlockScopedContainer.kind === 311 /* SourceFile */ || (getOriginalNode(node).flags & 3 /* BlockScoped */) === 0); + return (getEmitFlags(node) & 4194304 /* NoHoisting */) === 0 && (enclosingBlockScopedContainer.kind === 312 /* SourceFile */ || (getOriginalNode(node).flags & 7 /* BlockScoped */) === 0); } function transformInitializedVariable(node, isExportedDeclaration) { const createAssignment = isExportedDeclaration ? createExportedVariableAssignment : createNonExportedVariableAssignment; @@ -205540,10 +190864,10 @@ ${lanes.join("\n")} const namedBindings = importClause.namedBindings; if (namedBindings) { switch (namedBindings.kind) { - case 273 /* NamespaceImport */: + case 274 /* NamespaceImport */: statements = appendExportsOfDeclaration(statements, namedBindings); break; - case 274 /* NamedImports */: + case 275 /* NamedImports */: for (const importBinding of namedBindings.elements) { statements = appendExportsOfDeclaration(statements, importBinding); } @@ -205594,8 +190918,8 @@ ${lanes.join("\n")} return statements; } let excludeName; - if (hasSyntacticModifier(decl, 1 /* Export */)) { - const exportName = hasSyntacticModifier(decl, 1024 /* Default */) ? factory2.createStringLiteral("default") : decl.name; + if (hasSyntacticModifier(decl, 32 /* Export */)) { + const exportName = hasSyntacticModifier(decl, 2048 /* Default */) ? factory2.createStringLiteral("default") : decl.name; statements = appendExportStatement(statements, exportName, factory2.getLocalName(decl)); excludeName = getTextOfIdentifierOrLiteral(exportName); } @@ -205609,7 +190933,7 @@ ${lanes.join("\n")} return statements; } const name = factory2.getDeclarationName(decl); - const exportSpecifiers = moduleInfo.exportSpecifiers.get(idText(name)); + const exportSpecifiers = moduleInfo.exportSpecifiers.get(name); if (exportSpecifiers) { for (const exportSpecifier of exportSpecifiers) { if (exportSpecifier.name.escapedText !== excludeName) { @@ -205643,45 +190967,45 @@ ${lanes.join("\n")} } function topLevelNestedVisitor(node) { switch (node.kind) { - case 242 /* VariableStatement */: + case 243 /* VariableStatement */: return visitVariableStatement(node); - case 261 /* FunctionDeclaration */: + case 262 /* FunctionDeclaration */: return visitFunctionDeclaration(node); - case 262 /* ClassDeclaration */: + case 263 /* ClassDeclaration */: return visitClassDeclaration(node); - case 247 /* ForStatement */: + case 248 /* ForStatement */: return visitForStatement( node, /*isTopLevel*/ true ); - case 248 /* ForInStatement */: + case 249 /* ForInStatement */: return visitForInStatement(node); - case 249 /* ForOfStatement */: + case 250 /* ForOfStatement */: return visitForOfStatement(node); - case 245 /* DoStatement */: + case 246 /* DoStatement */: return visitDoStatement(node); - case 246 /* WhileStatement */: + case 247 /* WhileStatement */: return visitWhileStatement(node); - case 255 /* LabeledStatement */: + case 256 /* LabeledStatement */: return visitLabeledStatement(node); - case 253 /* WithStatement */: + case 254 /* WithStatement */: return visitWithStatement(node); - case 244 /* IfStatement */: + case 245 /* IfStatement */: return visitIfStatement(node); - case 254 /* SwitchStatement */: + case 255 /* SwitchStatement */: return visitSwitchStatement(node); - case 268 /* CaseBlock */: + case 269 /* CaseBlock */: return visitCaseBlock(node); - case 295 /* CaseClause */: + case 296 /* CaseClause */: return visitCaseClause(node); - case 296 /* DefaultClause */: + case 297 /* DefaultClause */: return visitDefaultClause(node); - case 257 /* TryStatement */: + case 258 /* TryStatement */: return visitTryStatement(node); - case 298 /* CatchClause */: + case 299 /* CatchClause */: return visitCatchClause(node); - case 240 /* Block */: + case 241 /* Block */: return visitBlock(node); default: return visitor(node); @@ -205835,30 +191159,30 @@ ${lanes.join("\n")} return node; } switch (node.kind) { - case 247 /* ForStatement */: + case 248 /* ForStatement */: return visitForStatement( node, /*isTopLevel*/ false ); - case 243 /* ExpressionStatement */: + case 244 /* ExpressionStatement */: return visitExpressionStatement(node); - case 216 /* ParenthesizedExpression */: + case 217 /* ParenthesizedExpression */: return visitParenthesizedExpression(node, valueIsDiscarded); - case 359 /* PartiallyEmittedExpression */: + case 360 /* PartiallyEmittedExpression */: return visitPartiallyEmittedExpression(node, valueIsDiscarded); - case 225 /* BinaryExpression */: + case 226 /* BinaryExpression */: if (isDestructuringAssignment(node)) { return visitDestructuringAssignment(node, valueIsDiscarded); } break; - case 212 /* CallExpression */: + case 213 /* CallExpression */: if (isImportCall(node)) { return visitImportCallExpression(node); } break; - case 223 /* PrefixUnaryExpression */: - case 224 /* PostfixUnaryExpression */: + case 224 /* PrefixUnaryExpression */: + case 225 /* PostfixUnaryExpression */: return visitPrefixOrPostfixUnaryExpression(node, valueIsDiscarded); } return visitEachChild(node, visitor, context); @@ -205931,7 +191255,7 @@ ${lanes.join("\n")} return hasExportedReferenceInDestructuringTarget(node.initializer); } else if (isIdentifier(node)) { const container = resolver.getReferencedExportContainer(node); - return container !== void 0 && container.kind === 311 /* SourceFile */; + return container !== void 0 && container.kind === 312 /* SourceFile */; } else { return false; } @@ -205975,7 +191299,7 @@ ${lanes.join("\n")} return node; } function onEmitNode(hint, node, emitCallback) { - if (node.kind === 311 /* SourceFile */) { + if (node.kind === 312 /* SourceFile */) { const id = getOriginalNodeId(node); currentSourceFile = node; moduleInfo = moduleInfoMap[id]; @@ -206009,7 +191333,7 @@ ${lanes.join("\n")} } function substituteUnspecified(node) { switch (node.kind) { - case 303 /* ShorthandPropertyAssignment */: + case 304 /* ShorthandPropertyAssignment */: return substituteShorthandPropertyAssignment(node); } return node; @@ -206053,9 +191377,9 @@ ${lanes.join("\n")} switch (node.kind) { case 80 /* Identifier */: return substituteExpressionIdentifier(node); - case 225 /* BinaryExpression */: + case 226 /* BinaryExpression */: return substituteBinaryExpression(node); - case 235 /* MetaProperty */: + case 236 /* MetaProperty */: return substituteMetaProperty(node); } return node; @@ -206096,7 +191420,7 @@ ${lanes.join("\n")} return node; } function substituteBinaryExpression(node) { - if (isAssignmentOperator(node.operatorToken.kind) && isIdentifier(node.left) && !isGeneratedIdentifier(node.left) && !isLocalName(node.left)) { + if (isAssignmentOperator(node.operatorToken.kind) && isIdentifier(node.left) && (!isGeneratedIdentifier(node.left) || isFileLevelReservedGeneratedIdentifier(node.left)) && !isLocalName(node.left)) { const exportedNames = getExports(node.left); if (exportedNames) { let expression = node; @@ -206123,10 +191447,19 @@ ${lanes.join("\n")} /*prefixLocals*/ false ); - if (exportContainer && exportContainer.kind === 311 /* SourceFile */) { + if (exportContainer && exportContainer.kind === 312 /* SourceFile */) { exportedNames = append(exportedNames, factory2.getDeclarationName(valueDeclaration)); } exportedNames = addRange(exportedNames, moduleInfo == null ? void 0 : moduleInfo.exportedBindings[getOriginalNodeId(valueDeclaration)]); + } else if (isGeneratedIdentifier(name) && isFileLevelReservedGeneratedIdentifier(name)) { + const exportSpecifiers = moduleInfo == null ? void 0 : moduleInfo.exportSpecifiers.get(name); + if (exportSpecifiers) { + const exportedNames2 = []; + for (const exportSpecifier of exportSpecifiers) { + exportedNames2.push(exportSpecifier.name); + } + return exportedNames2; + } } return exportedNames; } @@ -206179,7 +191512,7 @@ ${lanes.join("\n")} const previousOnSubstituteNode = context.onSubstituteNode; context.onEmitNode = onEmitNode; context.onSubstituteNode = onSubstituteNode; - context.enableEmitNotification(311 /* SourceFile */); + context.enableEmitNotification(312 /* SourceFile */); context.enableSubstitution(80 /* Identifier */); let helperNameSubstitutions; let currentSourceFile; @@ -206227,11 +191560,11 @@ ${lanes.join("\n")} } function visitor(node) { switch (node.kind) { - case 270 /* ImportEqualsDeclaration */: + case 271 /* ImportEqualsDeclaration */: return getEmitModuleKind(compilerOptions) >= 100 /* Node16 */ ? visitImportEqualsDeclaration(node) : void 0; - case 276 /* ExportAssignment */: + case 277 /* ExportAssignment */: return visitExportAssignment(node); - case 277 /* ExportDeclaration */: + case 278 /* ExportDeclaration */: const exportDecl = node; return visitExportDeclaration(exportDecl); } @@ -206262,7 +191595,9 @@ ${lanes.join("\n")} ) ]) ), - factory2.createStringLiteral("module") + factory2.createStringLiteral("module"), + /*attributes*/ + void 0 ); const requireHelperName = factory2.createUniqueName("__require", 16 /* Optimistic */ | 32 /* FileLevel */); const requireStatement = factory2.createVariableStatement( @@ -206335,19 +191670,22 @@ ${lanes.join("\n")} return singleOrMany(statements); } function appendExportsOfImportEqualsDeclaration(statements, node) { - if (hasSyntacticModifier(node, 1 /* Export */)) { - statements = append(statements, factory2.createExportDeclaration( - /*modifiers*/ - void 0, - node.isTypeOnly, - factory2.createNamedExports([factory2.createExportSpecifier( - /*isTypeOnly*/ - false, - /*propertyName*/ + if (hasSyntacticModifier(node, 32 /* Export */)) { + statements = append( + statements, + factory2.createExportDeclaration( + /*modifiers*/ void 0, - idText(node.name) - )]) - )); + node.isTypeOnly, + factory2.createNamedExports([factory2.createExportSpecifier( + /*isTypeOnly*/ + false, + /*propertyName*/ + void 0, + idText(node.name) + )]) + ) + ); } return statements; } @@ -206376,7 +191714,7 @@ ${lanes.join("\n")} ) ), node.moduleSpecifier, - node.assertClause + node.attributes ); setOriginalNode(importDecl, node.exportClause); const exportDecl = isExportNamespaceAsDefaultDeclaration(node) ? factory2.createExportDefault(synthName) : factory2.createExportDeclaration( @@ -206442,8 +191780,8 @@ ${lanes.join("\n")} const cjsOnEmitNode = context.onEmitNode; context.onSubstituteNode = onSubstituteNode; context.onEmitNode = onEmitNode; - context.enableSubstitution(311 /* SourceFile */); - context.enableEmitNotification(311 /* SourceFile */); + context.enableSubstitution(312 /* SourceFile */); + context.enableEmitNotification(312 /* SourceFile */); let currentSourceFile; return transformSourceFileOrBundle; function onSubstituteNode(hint, node) { @@ -206486,7 +191824,7 @@ ${lanes.join("\n")} return result; } function transformSourceFileOrBundle(node) { - return node.kind === 311 /* SourceFile */ ? transformSourceFile(node) : transformBundle(node); + return node.kind === 312 /* SourceFile */ ? transformSourceFile(node) : transformBundle(node); } function transformBundle(node) { return context.factory.createBundle(map(node.sourceFiles, transformSourceFile), node.prepends); @@ -206522,7 +191860,7 @@ ${lanes.join("\n")} function getAccessorNameVisibilityDiagnosticMessage(symbolAccessibilityResult) { if (isStatic(node)) { return symbolAccessibilityResult.errorModuleName ? symbolAccessibilityResult.accessibility === 2 /* CannotBeNamed */ ? Diagnostics.Public_static_property_0_of_exported_class_has_or_is_using_name_1_from_external_module_2_but_cannot_be_named : Diagnostics.Public_static_property_0_of_exported_class_has_or_is_using_name_1_from_private_module_2 : Diagnostics.Public_static_property_0_of_exported_class_has_or_is_using_private_name_1; - } else if (node.parent.kind === 262 /* ClassDeclaration */) { + } else if (node.parent.kind === 263 /* ClassDeclaration */) { return symbolAccessibilityResult.errorModuleName ? symbolAccessibilityResult.accessibility === 2 /* CannotBeNamed */ ? Diagnostics.Public_property_0_of_exported_class_has_or_is_using_name_1_from_external_module_2_but_cannot_be_named : Diagnostics.Public_property_0_of_exported_class_has_or_is_using_name_1_from_private_module_2 : Diagnostics.Public_property_0_of_exported_class_has_or_is_using_private_name_1; } else { return symbolAccessibilityResult.errorModuleName ? Diagnostics.Property_0_of_exported_interface_has_or_is_using_name_1_from_private_module_2 : Diagnostics.Property_0_of_exported_interface_has_or_is_using_private_name_1; @@ -206539,7 +191877,7 @@ ${lanes.join("\n")} function getMethodNameVisibilityDiagnosticMessage(symbolAccessibilityResult) { if (isStatic(node)) { return symbolAccessibilityResult.errorModuleName ? symbolAccessibilityResult.accessibility === 2 /* CannotBeNamed */ ? Diagnostics.Public_static_method_0_of_exported_class_has_or_is_using_name_1_from_external_module_2_but_cannot_be_named : Diagnostics.Public_static_method_0_of_exported_class_has_or_is_using_name_1_from_private_module_2 : Diagnostics.Public_static_method_0_of_exported_class_has_or_is_using_private_name_1; - } else if (node.parent.kind === 262 /* ClassDeclaration */) { + } else if (node.parent.kind === 263 /* ClassDeclaration */) { return symbolAccessibilityResult.errorModuleName ? symbolAccessibilityResult.accessibility === 2 /* CannotBeNamed */ ? Diagnostics.Public_method_0_of_exported_class_has_or_is_using_name_1_from_external_module_2_but_cannot_be_named : Diagnostics.Public_method_0_of_exported_class_has_or_is_using_name_1_from_private_module_2 : Diagnostics.Public_method_0_of_exported_class_has_or_is_using_private_name_1; } else { return symbolAccessibilityResult.errorModuleName ? Diagnostics.Method_0_of_exported_interface_has_or_is_using_name_1_from_private_module_2 : Diagnostics.Method_0_of_exported_interface_has_or_is_using_private_name_1; @@ -206554,7 +191892,7 @@ ${lanes.join("\n")} } else if (isConstructSignatureDeclaration(node) || isCallSignatureDeclaration(node) || isMethodDeclaration(node) || isMethodSignature(node) || isFunctionDeclaration(node) || isIndexSignatureDeclaration(node)) { return getReturnTypeVisibilityError; } else if (isParameter(node)) { - if (isParameterPropertyDeclaration(node, node.parent) && hasSyntacticModifier(node.parent, 8 /* Private */)) { + if (isParameterPropertyDeclaration(node, node.parent) && hasSyntacticModifier(node.parent, 2 /* Private */)) { return getVariableDeclarationTypeVisibilityError; } return getParameterDeclarationTypeVisibilityError; @@ -206570,12 +191908,12 @@ ${lanes.join("\n")} return Debug.assertNever(node, `Attempted to set a declaration diagnostic context for unhandled node kind: ${Debug.formatSyntaxKind(node.kind)}`); } function getVariableDeclarationTypeVisibilityDiagnosticMessage(symbolAccessibilityResult) { - if (node.kind === 259 /* VariableDeclaration */ || node.kind === 207 /* BindingElement */) { + if (node.kind === 260 /* VariableDeclaration */ || node.kind === 208 /* BindingElement */) { return symbolAccessibilityResult.errorModuleName ? symbolAccessibilityResult.accessibility === 2 /* CannotBeNamed */ ? Diagnostics.Exported_variable_0_has_or_is_using_name_1_from_external_module_2_but_cannot_be_named : Diagnostics.Exported_variable_0_has_or_is_using_name_1_from_private_module_2 : Diagnostics.Exported_variable_0_has_or_is_using_private_name_1; - } else if (node.kind === 171 /* PropertyDeclaration */ || node.kind === 210 /* PropertyAccessExpression */ || node.kind === 211 /* ElementAccessExpression */ || node.kind === 225 /* BinaryExpression */ || node.kind === 170 /* PropertySignature */ || node.kind === 168 /* Parameter */ && hasSyntacticModifier(node.parent, 8 /* Private */)) { + } else if (node.kind === 172 /* PropertyDeclaration */ || node.kind === 211 /* PropertyAccessExpression */ || node.kind === 212 /* ElementAccessExpression */ || node.kind === 226 /* BinaryExpression */ || node.kind === 171 /* PropertySignature */ || node.kind === 169 /* Parameter */ && hasSyntacticModifier(node.parent, 2 /* Private */)) { if (isStatic(node)) { return symbolAccessibilityResult.errorModuleName ? symbolAccessibilityResult.accessibility === 2 /* CannotBeNamed */ ? Diagnostics.Public_static_property_0_of_exported_class_has_or_is_using_name_1_from_external_module_2_but_cannot_be_named : Diagnostics.Public_static_property_0_of_exported_class_has_or_is_using_name_1_from_private_module_2 : Diagnostics.Public_static_property_0_of_exported_class_has_or_is_using_private_name_1; - } else if (node.parent.kind === 262 /* ClassDeclaration */ || node.kind === 168 /* Parameter */) { + } else if (node.parent.kind === 263 /* ClassDeclaration */ || node.kind === 169 /* Parameter */) { return symbolAccessibilityResult.errorModuleName ? symbolAccessibilityResult.accessibility === 2 /* CannotBeNamed */ ? Diagnostics.Public_property_0_of_exported_class_has_or_is_using_name_1_from_external_module_2_but_cannot_be_named : Diagnostics.Public_property_0_of_exported_class_has_or_is_using_name_1_from_private_module_2 : Diagnostics.Public_property_0_of_exported_class_has_or_is_using_private_name_1; } else { return symbolAccessibilityResult.errorModuleName ? Diagnostics.Property_0_of_exported_interface_has_or_is_using_name_1_from_private_module_2 : Diagnostics.Property_0_of_exported_interface_has_or_is_using_private_name_1; @@ -206592,7 +191930,7 @@ ${lanes.join("\n")} } function getAccessorDeclarationTypeVisibilityError(symbolAccessibilityResult) { let diagnosticMessage; - if (node.kind === 177 /* SetAccessor */) { + if (node.kind === 178 /* SetAccessor */) { if (isStatic(node)) { diagnosticMessage = symbolAccessibilityResult.errorModuleName ? Diagnostics.Parameter_type_of_public_static_setter_0_from_exported_class_has_or_is_using_name_1_from_private_module_2 : Diagnostics.Parameter_type_of_public_static_setter_0_from_exported_class_has_or_is_using_private_name_1; } else { @@ -206614,26 +191952,26 @@ ${lanes.join("\n")} function getReturnTypeVisibilityError(symbolAccessibilityResult) { let diagnosticMessage; switch (node.kind) { - case 179 /* ConstructSignature */: + case 180 /* ConstructSignature */: diagnosticMessage = symbolAccessibilityResult.errorModuleName ? Diagnostics.Return_type_of_constructor_signature_from_exported_interface_has_or_is_using_name_0_from_private_module_1 : Diagnostics.Return_type_of_constructor_signature_from_exported_interface_has_or_is_using_private_name_0; break; - case 178 /* CallSignature */: + case 179 /* CallSignature */: diagnosticMessage = symbolAccessibilityResult.errorModuleName ? Diagnostics.Return_type_of_call_signature_from_exported_interface_has_or_is_using_name_0_from_private_module_1 : Diagnostics.Return_type_of_call_signature_from_exported_interface_has_or_is_using_private_name_0; break; - case 180 /* IndexSignature */: + case 181 /* IndexSignature */: diagnosticMessage = symbolAccessibilityResult.errorModuleName ? Diagnostics.Return_type_of_index_signature_from_exported_interface_has_or_is_using_name_0_from_private_module_1 : Diagnostics.Return_type_of_index_signature_from_exported_interface_has_or_is_using_private_name_0; break; - case 173 /* MethodDeclaration */: - case 172 /* MethodSignature */: + case 174 /* MethodDeclaration */: + case 173 /* MethodSignature */: if (isStatic(node)) { diagnosticMessage = symbolAccessibilityResult.errorModuleName ? symbolAccessibilityResult.accessibility === 2 /* CannotBeNamed */ ? Diagnostics.Return_type_of_public_static_method_from_exported_class_has_or_is_using_name_0_from_external_module_1_but_cannot_be_named : Diagnostics.Return_type_of_public_static_method_from_exported_class_has_or_is_using_name_0_from_private_module_1 : Diagnostics.Return_type_of_public_static_method_from_exported_class_has_or_is_using_private_name_0; - } else if (node.parent.kind === 262 /* ClassDeclaration */) { + } else if (node.parent.kind === 263 /* ClassDeclaration */) { diagnosticMessage = symbolAccessibilityResult.errorModuleName ? symbolAccessibilityResult.accessibility === 2 /* CannotBeNamed */ ? Diagnostics.Return_type_of_public_method_from_exported_class_has_or_is_using_name_0_from_external_module_1_but_cannot_be_named : Diagnostics.Return_type_of_public_method_from_exported_class_has_or_is_using_name_0_from_private_module_1 : Diagnostics.Return_type_of_public_method_from_exported_class_has_or_is_using_private_name_0; } else { diagnosticMessage = symbolAccessibilityResult.errorModuleName ? Diagnostics.Return_type_of_method_from_exported_interface_has_or_is_using_name_0_from_private_module_1 : Diagnostics.Return_type_of_method_from_exported_interface_has_or_is_using_private_name_0; } break; - case 261 /* FunctionDeclaration */: + case 262 /* FunctionDeclaration */: diagnosticMessage = symbolAccessibilityResult.errorModuleName ? symbolAccessibilityResult.accessibility === 2 /* CannotBeNamed */ ? Diagnostics.Return_type_of_exported_function_has_or_is_using_name_0_from_external_module_1_but_cannot_be_named : Diagnostics.Return_type_of_exported_function_has_or_is_using_name_0_from_private_module_1 : Diagnostics.Return_type_of_exported_function_has_or_is_using_private_name_0; break; default: @@ -206654,29 +191992,29 @@ ${lanes.join("\n")} } function getParameterDeclarationTypeVisibilityDiagnosticMessage(symbolAccessibilityResult) { switch (node.parent.kind) { - case 175 /* Constructor */: + case 176 /* Constructor */: return symbolAccessibilityResult.errorModuleName ? symbolAccessibilityResult.accessibility === 2 /* CannotBeNamed */ ? Diagnostics.Parameter_0_of_constructor_from_exported_class_has_or_is_using_name_1_from_external_module_2_but_cannot_be_named : Diagnostics.Parameter_0_of_constructor_from_exported_class_has_or_is_using_name_1_from_private_module_2 : Diagnostics.Parameter_0_of_constructor_from_exported_class_has_or_is_using_private_name_1; - case 179 /* ConstructSignature */: - case 184 /* ConstructorType */: + case 180 /* ConstructSignature */: + case 185 /* ConstructorType */: return symbolAccessibilityResult.errorModuleName ? Diagnostics.Parameter_0_of_constructor_signature_from_exported_interface_has_or_is_using_name_1_from_private_module_2 : Diagnostics.Parameter_0_of_constructor_signature_from_exported_interface_has_or_is_using_private_name_1; - case 178 /* CallSignature */: + case 179 /* CallSignature */: return symbolAccessibilityResult.errorModuleName ? Diagnostics.Parameter_0_of_call_signature_from_exported_interface_has_or_is_using_name_1_from_private_module_2 : Diagnostics.Parameter_0_of_call_signature_from_exported_interface_has_or_is_using_private_name_1; - case 180 /* IndexSignature */: + case 181 /* IndexSignature */: return symbolAccessibilityResult.errorModuleName ? Diagnostics.Parameter_0_of_index_signature_from_exported_interface_has_or_is_using_name_1_from_private_module_2 : Diagnostics.Parameter_0_of_index_signature_from_exported_interface_has_or_is_using_private_name_1; - case 173 /* MethodDeclaration */: - case 172 /* MethodSignature */: + case 174 /* MethodDeclaration */: + case 173 /* MethodSignature */: if (isStatic(node.parent)) { return symbolAccessibilityResult.errorModuleName ? symbolAccessibilityResult.accessibility === 2 /* CannotBeNamed */ ? Diagnostics.Parameter_0_of_public_static_method_from_exported_class_has_or_is_using_name_1_from_external_module_2_but_cannot_be_named : Diagnostics.Parameter_0_of_public_static_method_from_exported_class_has_or_is_using_name_1_from_private_module_2 : Diagnostics.Parameter_0_of_public_static_method_from_exported_class_has_or_is_using_private_name_1; - } else if (node.parent.parent.kind === 262 /* ClassDeclaration */) { + } else if (node.parent.parent.kind === 263 /* ClassDeclaration */) { return symbolAccessibilityResult.errorModuleName ? symbolAccessibilityResult.accessibility === 2 /* CannotBeNamed */ ? Diagnostics.Parameter_0_of_public_method_from_exported_class_has_or_is_using_name_1_from_external_module_2_but_cannot_be_named : Diagnostics.Parameter_0_of_public_method_from_exported_class_has_or_is_using_name_1_from_private_module_2 : Diagnostics.Parameter_0_of_public_method_from_exported_class_has_or_is_using_private_name_1; } else { return symbolAccessibilityResult.errorModuleName ? Diagnostics.Parameter_0_of_method_from_exported_interface_has_or_is_using_name_1_from_private_module_2 : Diagnostics.Parameter_0_of_method_from_exported_interface_has_or_is_using_private_name_1; } - case 261 /* FunctionDeclaration */: - case 183 /* FunctionType */: + case 262 /* FunctionDeclaration */: + case 184 /* FunctionType */: return symbolAccessibilityResult.errorModuleName ? symbolAccessibilityResult.accessibility === 2 /* CannotBeNamed */ ? Diagnostics.Parameter_0_of_exported_function_has_or_is_using_name_1_from_external_module_2_but_cannot_be_named : Diagnostics.Parameter_0_of_exported_function_has_or_is_using_name_1_from_private_module_2 : Diagnostics.Parameter_0_of_exported_function_has_or_is_using_private_name_1; - case 177 /* SetAccessor */: - case 176 /* GetAccessor */: + case 178 /* SetAccessor */: + case 177 /* GetAccessor */: return symbolAccessibilityResult.errorModuleName ? symbolAccessibilityResult.accessibility === 2 /* CannotBeNamed */ ? Diagnostics.Parameter_0_of_accessor_has_or_is_using_name_1_from_external_module_2_but_cannot_be_named : Diagnostics.Parameter_0_of_accessor_has_or_is_using_name_1_from_private_module_2 : Diagnostics.Parameter_0_of_accessor_has_or_is_using_private_name_1; default: return Debug.fail(`Unknown parent for parameter: ${Debug.formatSyntaxKind(node.parent.kind)}`); @@ -206685,40 +192023,40 @@ ${lanes.join("\n")} function getTypeParameterConstraintVisibilityError() { let diagnosticMessage; switch (node.parent.kind) { - case 262 /* ClassDeclaration */: + case 263 /* ClassDeclaration */: diagnosticMessage = Diagnostics.Type_parameter_0_of_exported_class_has_or_is_using_private_name_1; break; - case 263 /* InterfaceDeclaration */: + case 264 /* InterfaceDeclaration */: diagnosticMessage = Diagnostics.Type_parameter_0_of_exported_interface_has_or_is_using_private_name_1; break; - case 199 /* MappedType */: + case 200 /* MappedType */: diagnosticMessage = Diagnostics.Type_parameter_0_of_exported_mapped_object_type_is_using_private_name_1; break; - case 184 /* ConstructorType */: - case 179 /* ConstructSignature */: + case 185 /* ConstructorType */: + case 180 /* ConstructSignature */: diagnosticMessage = Diagnostics.Type_parameter_0_of_constructor_signature_from_exported_interface_has_or_is_using_private_name_1; break; - case 178 /* CallSignature */: + case 179 /* CallSignature */: diagnosticMessage = Diagnostics.Type_parameter_0_of_call_signature_from_exported_interface_has_or_is_using_private_name_1; break; - case 173 /* MethodDeclaration */: - case 172 /* MethodSignature */: + case 174 /* MethodDeclaration */: + case 173 /* MethodSignature */: if (isStatic(node.parent)) { diagnosticMessage = Diagnostics.Type_parameter_0_of_public_static_method_from_exported_class_has_or_is_using_private_name_1; - } else if (node.parent.parent.kind === 262 /* ClassDeclaration */) { + } else if (node.parent.parent.kind === 263 /* ClassDeclaration */) { diagnosticMessage = Diagnostics.Type_parameter_0_of_public_method_from_exported_class_has_or_is_using_private_name_1; } else { diagnosticMessage = Diagnostics.Type_parameter_0_of_method_from_exported_interface_has_or_is_using_private_name_1; } break; - case 183 /* FunctionType */: - case 261 /* FunctionDeclaration */: + case 184 /* FunctionType */: + case 262 /* FunctionDeclaration */: diagnosticMessage = Diagnostics.Type_parameter_0_of_exported_function_has_or_is_using_private_name_1; break; - case 194 /* InferType */: + case 195 /* InferType */: diagnosticMessage = Diagnostics.Extends_clause_for_inferred_type_0_has_or_is_using_private_name_1; break; - case 264 /* TypeAliasDeclaration */: + case 265 /* TypeAliasDeclaration */: diagnosticMessage = Diagnostics.Type_parameter_0_of_exported_type_alias_has_or_is_using_private_name_1; break; default: @@ -206782,11 +192120,11 @@ ${lanes.join("\n")} } function hasInternalAnnotation(range, currentSourceFile) { const comment = currentSourceFile.text.substring(range.pos, range.end); - return stringContains(comment, "@internal"); + return comment.includes("@internal"); } function isInternalDeclaration(node, currentSourceFile) { const parseTreeNode = getParseTreeNode(node); - if (parseTreeNode && parseTreeNode.kind === 168 /* Parameter */) { + if (parseTreeNode && parseTreeNode.kind === 169 /* Parameter */) { const paramIdx = parseTreeNode.parent.parameters.indexOf(parseTreeNode); const previousSibling = paramIdx > 0 ? parseTreeNode.parent.parameters[paramIdx - 1] : void 0; const text = currentSourceFile.text; @@ -206846,8 +192184,7 @@ ${lanes.join("\n")} trackReferencedAmbientModule, trackExternalModuleSymbolOfImportTypeNode, reportNonlocalAugmentation, - reportNonSerializableProperty, - reportImportTypeNodeResolutionModeOverride + reportNonSerializableProperty }; let errorNameNode; let errorFallbackNode; @@ -206876,6 +192213,17 @@ ${lanes.join("\n")} const container = getSourceFileOfNode(node); refs.set(getOriginalNodeId(container), container); } + function trackReferencedAmbientModuleFromImport(node) { + const moduleSpecifier = tryGetModuleSpecifierFromDeclaration(node); + const symbol = moduleSpecifier && resolver.tryFindAmbientModule(moduleSpecifier); + if (symbol == null ? void 0 : symbol.declarations) { + for (const decl of symbol.declarations) { + if (isAmbientModule(decl) && getSourceFileOfNode(decl) !== currentSourceFile) { + trackReferencedAmbientModule(decl, symbol); + } + } + } + } function handleSymbolAccessibilityError(symbolAccessibilityResult) { if (symbolAccessibilityResult.accessibility === 0 /* Accessible */) { if (symbolAccessibilityResult && symbolAccessibilityResult.aliasesToMakeVisible) { @@ -206891,20 +192239,9 @@ ${lanes.join("\n")} const errorInfo = getSymbolAccessibilityDiagnostic(symbolAccessibilityResult); if (errorInfo) { if (errorInfo.typeName) { - context.addDiagnostic(createDiagnosticForNode( - symbolAccessibilityResult.errorNode || errorInfo.errorNode, - errorInfo.diagnosticMessage, - getTextOfNode(errorInfo.typeName), - symbolAccessibilityResult.errorSymbolName, - symbolAccessibilityResult.errorModuleName - )); + context.addDiagnostic(createDiagnosticForNode(symbolAccessibilityResult.errorNode || errorInfo.errorNode, errorInfo.diagnosticMessage, getTextOfNode(errorInfo.typeName), symbolAccessibilityResult.errorSymbolName, symbolAccessibilityResult.errorModuleName)); } else { - context.addDiagnostic(createDiagnosticForNode( - symbolAccessibilityResult.errorNode || errorInfo.errorNode, - errorInfo.diagnosticMessage, - symbolAccessibilityResult.errorSymbolName, - symbolAccessibilityResult.errorModuleName - )); + context.addDiagnostic(createDiagnosticForNode(symbolAccessibilityResult.errorNode || errorInfo.errorNode, errorInfo.diagnosticMessage, symbolAccessibilityResult.errorSymbolName, symbolAccessibilityResult.errorModuleName)); } return true; } @@ -206941,41 +192278,22 @@ ${lanes.join("\n")} } function reportInaccessibleUniqueSymbolError() { if (errorNameNode || errorFallbackNode) { - context.addDiagnostic(createDiagnosticForNode( - errorNameNode || errorFallbackNode, - Diagnostics.The_inferred_type_of_0_references_an_inaccessible_1_type_A_type_annotation_is_necessary, - errorDeclarationNameWithFallback(), - "unique symbol" - )); + context.addDiagnostic(createDiagnosticForNode(errorNameNode || errorFallbackNode, Diagnostics.The_inferred_type_of_0_references_an_inaccessible_1_type_A_type_annotation_is_necessary, errorDeclarationNameWithFallback(), "unique symbol")); } } function reportCyclicStructureError() { if (errorNameNode || errorFallbackNode) { - context.addDiagnostic(createDiagnosticForNode( - errorNameNode || errorFallbackNode, - Diagnostics.The_inferred_type_of_0_references_a_type_with_a_cyclic_structure_which_cannot_be_trivially_serialized_A_type_annotation_is_necessary, - errorDeclarationNameWithFallback() - )); + context.addDiagnostic(createDiagnosticForNode(errorNameNode || errorFallbackNode, Diagnostics.The_inferred_type_of_0_references_a_type_with_a_cyclic_structure_which_cannot_be_trivially_serialized_A_type_annotation_is_necessary, errorDeclarationNameWithFallback())); } } function reportInaccessibleThisError() { if (errorNameNode || errorFallbackNode) { - context.addDiagnostic(createDiagnosticForNode( - errorNameNode || errorFallbackNode, - Diagnostics.The_inferred_type_of_0_references_an_inaccessible_1_type_A_type_annotation_is_necessary, - errorDeclarationNameWithFallback(), - "this" - )); + context.addDiagnostic(createDiagnosticForNode(errorNameNode || errorFallbackNode, Diagnostics.The_inferred_type_of_0_references_an_inaccessible_1_type_A_type_annotation_is_necessary, errorDeclarationNameWithFallback(), "this")); } } function reportLikelyUnsafeImportRequiredError(specifier) { if (errorNameNode || errorFallbackNode) { - context.addDiagnostic(createDiagnosticForNode( - errorNameNode || errorFallbackNode, - Diagnostics.The_inferred_type_of_0_cannot_be_named_without_a_reference_to_1_This_is_likely_not_portable_A_type_annotation_is_necessary, - errorDeclarationNameWithFallback(), - specifier - )); + context.addDiagnostic(createDiagnosticForNode(errorNameNode || errorFallbackNode, Diagnostics.The_inferred_type_of_0_cannot_be_named_without_a_reference_to_1_This_is_likely_not_portable_A_type_annotation_is_necessary, errorDeclarationNameWithFallback(), specifier)); } } function reportTruncationError() { @@ -207001,11 +192319,6 @@ ${lanes.join("\n")} context.addDiagnostic(createDiagnosticForNode(errorNameNode || errorFallbackNode, Diagnostics.The_type_of_this_node_cannot_be_serialized_because_its_property_0_cannot_be_serialized, propertyName)); } } - function reportImportTypeNodeResolutionModeOverride() { - if (!isNightly() && (errorNameNode || errorFallbackNode)) { - context.addDiagnostic(createDiagnosticForNode(errorNameNode || errorFallbackNode, Diagnostics.The_type_of_this_expression_cannot_be_named_without_a_resolution_mode_assertion_which_is_an_unstable_feature_Use_nightly_TypeScript_to_silence_this_error_Try_updating_with_npm_install_D_typescript_next)); - } - } function transformDeclarationsForJS(sourceFile, bundled) { const oldDiag = getSymbolAccessibilityDiagnostic; getSymbolAccessibilityDiagnostic = (s) => s.errorNode && canProduceDiagnostics(s.errorNode) ? createGetSymbolAccessibilityDiagnosticForNode(s.errorNode)(s) : { @@ -207017,17 +192330,16 @@ ${lanes.join("\n")} return result; } function transformRoot(node) { - if (node.kind === 311 /* SourceFile */ && node.isDeclarationFile) { + if (node.kind === 312 /* SourceFile */ && node.isDeclarationFile) { return node; } - if (node.kind === 312 /* Bundle */) { + if (node.kind === 313 /* Bundle */) { isBundledEmit = true; refs = /* @__PURE__ */ new Map(); libs2 = /* @__PURE__ */ new Map(); let hasNoDefaultLib = false; - const bundle = factory2.createBundle(map( - node.sourceFiles, - (sourceFile) => { + const bundle = factory2.createBundle( + map(node.sourceFiles, (sourceFile) => { if (sourceFile.isDeclarationFile) return void 0; hasNoDefaultLib = hasNoDefaultLib || sourceFile.hasNoDefaultLib; @@ -207085,18 +192397,19 @@ ${lanes.join("\n")} /*libReferences*/ [] ); - } - ), mapDefined(node.prepends, (prepend) => { - if (prepend.kind === 314 /* InputFiles */) { - const sourceFile = createUnparsedSourceFile(prepend, "dts", stripInternal); - hasNoDefaultLib = hasNoDefaultLib || !!sourceFile.hasNoDefaultLib; - collectReferences(sourceFile, refs); - recordTypeReferenceDirectivesIfNecessary(map(sourceFile.typeReferenceDirectives, (ref) => [ref.fileName, ref.resolutionMode])); - collectLibs(sourceFile, libs2); - return sourceFile; - } - return prepend; - })); + }), + mapDefined(node.prepends, (prepend) => { + if (prepend.kind === 315 /* InputFiles */) { + const sourceFile = createUnparsedSourceFile(prepend, "dts", stripInternal); + hasNoDefaultLib = hasNoDefaultLib || !!sourceFile.hasNoDefaultLib; + collectReferences(sourceFile, refs); + recordTypeReferenceDirectivesIfNecessary(map(sourceFile.typeReferenceDirectives, (ref) => [ref.fileName, ref.resolutionMode])); + collectLibs(sourceFile, libs2); + return sourceFile; + } + return prepend; + }) + ); bundle.syntheticFileReferences = []; bundle.syntheticTypeReferences = getFileReferencesForUsedTypeReferences(); bundle.syntheticLibReferences = getLibReferences(); @@ -207255,16 +192568,19 @@ ${lanes.join("\n")} if (name.kind === 80 /* Identifier */) { return name; } else { - if (name.kind === 206 /* ArrayBindingPattern */) { + if (name.kind === 207 /* ArrayBindingPattern */) { return factory2.updateArrayBindingPattern(name, visitNodes2(name.elements, visitBindingElement, isArrayBindingElement)); } else { return factory2.updateObjectBindingPattern(name, visitNodes2(name.elements, visitBindingElement, isBindingElement)); } } function visitBindingElement(elem) { - if (elem.kind === 231 /* OmittedExpression */) { + if (elem.kind === 232 /* OmittedExpression */) { return elem; } + if (elem.propertyName && isComputedPropertyName(elem.propertyName) && isEntityNameExpression(elem.propertyName.expression)) { + checkEntityNameVisibility(elem.propertyName.expression, enclosingDeclaration); + } if (elem.propertyName && isIdentifier(elem.propertyName) && isIdentifier(elem.name) && !elem.symbol.isReferenced && !isIdentifierANonContextualKeyword(elem.propertyName)) { return factory2.updateBindingElement( elem, @@ -207320,20 +192636,20 @@ ${lanes.join("\n")} return void 0; } function ensureType(node, type, ignorePrivate) { - if (!ignorePrivate && hasEffectiveModifier(node, 8 /* Private */)) { + if (!ignorePrivate && hasEffectiveModifier(node, 2 /* Private */)) { return; } if (shouldPrintWithInitializer(node)) { return; } - const shouldUseResolverType = node.kind === 168 /* Parameter */ && (resolver.isRequiredInitializedParameter(node) || resolver.isOptionalUninitializedParameterProperty(node)); + const shouldUseResolverType = node.kind === 169 /* Parameter */ && (resolver.isRequiredInitializedParameter(node) || resolver.isOptionalUninitializedParameterProperty(node)); if (type && !shouldUseResolverType) { return visitNode(type, visitDeclarationSubtree, isTypeNode); } if (!getParseTreeNode(node)) { return type ? visitNode(type, visitDeclarationSubtree, isTypeNode) : factory2.createKeywordTypeNode(133 /* AnyKeyword */); } - if (node.kind === 177 /* SetAccessor */) { + if (node.kind === 178 /* SetAccessor */) { return factory2.createKeywordTypeNode(133 /* AnyKeyword */); } errorNameNode = node.name; @@ -207342,10 +192658,10 @@ ${lanes.join("\n")} oldDiag = getSymbolAccessibilityDiagnostic; getSymbolAccessibilityDiagnostic = createGetSymbolAccessibilityDiagnosticForNode(node); } - if (node.kind === 259 /* VariableDeclaration */ || node.kind === 207 /* BindingElement */) { + if (node.kind === 260 /* VariableDeclaration */ || node.kind === 208 /* BindingElement */) { return cleanup(resolver.createTypeOfDeclaration(node, enclosingDeclaration, declarationEmitNodeBuilderFlags, symbolTracker)); } - if (node.kind === 168 /* Parameter */ || node.kind === 171 /* PropertyDeclaration */ || node.kind === 170 /* PropertySignature */) { + if (node.kind === 169 /* Parameter */ || node.kind === 172 /* PropertyDeclaration */ || node.kind === 171 /* PropertySignature */) { if (isPropertySignature(node) || !node.initializer) return cleanup(resolver.createTypeOfDeclaration(node, enclosingDeclaration, declarationEmitNodeBuilderFlags, symbolTracker, shouldUseResolverType)); return cleanup(resolver.createTypeOfDeclaration(node, enclosingDeclaration, declarationEmitNodeBuilderFlags, symbolTracker, shouldUseResolverType) || resolver.createTypeOfExpression(node.initializer, enclosingDeclaration, declarationEmitNodeBuilderFlags, symbolTracker)); @@ -207362,21 +192678,21 @@ ${lanes.join("\n")} function isDeclarationAndNotVisible(node) { node = getParseTreeNode(node); switch (node.kind) { - case 261 /* FunctionDeclaration */: - case 266 /* ModuleDeclaration */: - case 263 /* InterfaceDeclaration */: - case 262 /* ClassDeclaration */: - case 264 /* TypeAliasDeclaration */: - case 265 /* EnumDeclaration */: + case 262 /* FunctionDeclaration */: + case 267 /* ModuleDeclaration */: + case 264 /* InterfaceDeclaration */: + case 263 /* ClassDeclaration */: + case 265 /* TypeAliasDeclaration */: + case 266 /* EnumDeclaration */: return !resolver.isDeclarationVisible(node); - case 259 /* VariableDeclaration */: + case 260 /* VariableDeclaration */: return !getBindingNameVisible(node); - case 270 /* ImportEqualsDeclaration */: - case 271 /* ImportDeclaration */: - case 277 /* ExportDeclaration */: - case 276 /* ExportAssignment */: + case 271 /* ImportEqualsDeclaration */: + case 272 /* ImportDeclaration */: + case 278 /* ExportDeclaration */: + case 277 /* ExportAssignment */: return false; - case 174 /* ClassStaticBlockDeclaration */: + case 175 /* ClassStaticBlockDeclaration */: return true; } return false; @@ -207400,7 +192716,7 @@ ${lanes.join("\n")} } } function updateParamsList(node, params, modifierMask) { - if (hasEffectiveModifier(node, 8 /* Private */)) { + if (hasEffectiveModifier(node, 2 /* Private */)) { return factory2.createNodeArray(); } const newParams = map(params, (p) => ensureParameter(p, modifierMask)); @@ -207445,7 +192761,7 @@ ${lanes.join("\n")} return factory2.createNodeArray(newParams || emptyArray); } function ensureTypeParams(node, params) { - return hasEffectiveModifier(node, 8 /* Private */) ? void 0 : visitNodes2(params, visitDeclarationSubtree, isTypeParameterDeclaration); + return hasEffectiveModifier(node, 2 /* Private */) ? void 0 : visitNodes2(params, visitDeclarationSubtree, isTypeParameterDeclaration); } function isEnclosingDeclaration(node) { return isSourceFile(node) || isTypeAliasDeclaration(node) || isModuleDeclaration(node) || isClassDeclaration(node) || isInterfaceDeclaration(node) || isFunctionLike(node) || isIndexSignatureDeclaration(node) || isMappedTypeNode(node); @@ -207464,7 +192780,7 @@ ${lanes.join("\n")} function rewriteModuleSpecifier(parent2, input) { if (!input) return void 0; - resultHasExternalModuleIndicator = resultHasExternalModuleIndicator || parent2.kind !== 266 /* ModuleDeclaration */ && parent2.kind !== 204 /* ImportType */; + resultHasExternalModuleIndicator = resultHasExternalModuleIndicator || parent2.kind !== 267 /* ModuleDeclaration */ && parent2.kind !== 205 /* ImportType */; if (isStringLiteralLike(input)) { if (isBundledEmit) { const newName = getExternalModuleNameFromDeclaration(context.getEmitHost(), resolver, parent2); @@ -207483,7 +192799,7 @@ ${lanes.join("\n")} function transformImportEqualsDeclaration(decl) { if (!resolver.isDeclarationVisible(decl)) return; - if (decl.moduleReference.kind === 282 /* ExternalModuleReference */) { + if (decl.moduleReference.kind === 283 /* ExternalModuleReference */) { const specifier = getExternalModuleImportEqualsDeclarationExpression(decl); return factory2.updateImportEqualsDeclaration( decl, @@ -207507,30 +192823,42 @@ ${lanes.join("\n")} decl.modifiers, decl.importClause, rewriteModuleSpecifier(decl, decl.moduleSpecifier), - getResolutionModeOverrideForClauseInNightly(decl.assertClause) + tryGetResolutionModeOverride(decl.attributes) ); } const visibleDefaultBinding = decl.importClause && decl.importClause.name && resolver.isDeclarationVisible(decl.importClause) ? decl.importClause.name : void 0; if (!decl.importClause.namedBindings) { - return visibleDefaultBinding && factory2.updateImportDeclaration(decl, decl.modifiers, factory2.updateImportClause( - decl.importClause, - decl.importClause.isTypeOnly, - visibleDefaultBinding, - /*namedBindings*/ - void 0 - ), rewriteModuleSpecifier(decl, decl.moduleSpecifier), getResolutionModeOverrideForClauseInNightly(decl.assertClause)); + return visibleDefaultBinding && factory2.updateImportDeclaration( + decl, + decl.modifiers, + factory2.updateImportClause( + decl.importClause, + decl.importClause.isTypeOnly, + visibleDefaultBinding, + /*namedBindings*/ + void 0 + ), + rewriteModuleSpecifier(decl, decl.moduleSpecifier), + tryGetResolutionModeOverride(decl.attributes) + ); } - if (decl.importClause.namedBindings.kind === 273 /* NamespaceImport */) { + if (decl.importClause.namedBindings.kind === 274 /* NamespaceImport */) { const namedBindings = resolver.isDeclarationVisible(decl.importClause.namedBindings) ? decl.importClause.namedBindings : ( /*namedBindings*/ void 0 ); - return visibleDefaultBinding || namedBindings ? factory2.updateImportDeclaration(decl, decl.modifiers, factory2.updateImportClause( - decl.importClause, - decl.importClause.isTypeOnly, - visibleDefaultBinding, - namedBindings - ), rewriteModuleSpecifier(decl, decl.moduleSpecifier), getResolutionModeOverrideForClauseInNightly(decl.assertClause)) : void 0; + return visibleDefaultBinding || namedBindings ? factory2.updateImportDeclaration( + decl, + decl.modifiers, + factory2.updateImportClause( + decl.importClause, + decl.importClause.isTypeOnly, + visibleDefaultBinding, + namedBindings + ), + rewriteModuleSpecifier(decl, decl.moduleSpecifier), + tryGetResolutionModeOverride(decl.attributes) + ) : void 0; } const bindingList = mapDefined(decl.importClause.namedBindings.elements, (b) => resolver.isDeclarationVisible(b) ? b : void 0); if (bindingList && bindingList.length || visibleDefaultBinding) { @@ -207544,7 +192872,7 @@ ${lanes.join("\n")} bindingList && bindingList.length ? factory2.updateNamedImports(decl.importClause.namedBindings, bindingList) : void 0 ), rewriteModuleSpecifier(decl, decl.moduleSpecifier), - getResolutionModeOverrideForClauseInNightly(decl.assertClause) + tryGetResolutionModeOverride(decl.attributes) ); } if (resolver.isImportRequiredByAugmentation(decl)) { @@ -207554,19 +192882,13 @@ ${lanes.join("\n")} /*importClause*/ void 0, rewriteModuleSpecifier(decl, decl.moduleSpecifier), - getResolutionModeOverrideForClauseInNightly(decl.assertClause) + tryGetResolutionModeOverride(decl.attributes) ); } } - function getResolutionModeOverrideForClauseInNightly(assertClause) { - const mode = getResolutionModeOverrideForClause(assertClause); - if (mode !== void 0) { - if (!isNightly()) { - context.addDiagnostic(createDiagnosticForNode(assertClause, Diagnostics.resolution_mode_assertions_are_unstable_Use_nightly_TypeScript_to_silence_this_error_Try_updating_with_npm_install_D_typescript_next)); - } - return assertClause; - } - return void 0; + function tryGetResolutionModeOverride(node) { + const mode = getResolutionModeOverride(node); + return node && mode !== void 0 ? node : void 0; } function transformAndReplaceLatePaintedStatements(statements) { while (length(lateMarkedStatements)) { @@ -207623,9 +192945,9 @@ ${lanes.join("\n")} const oldDiag = getSymbolAccessibilityDiagnostic; const canProduceDiagnostic = canProduceDiagnostics(input); const oldWithinObjectLiteralType = suppressNewDiagnosticContexts; - let shouldEnterSuppressNewDiagnosticsContextContext = (input.kind === 186 /* TypeLiteral */ || input.kind === 199 /* MappedType */) && input.parent.kind !== 264 /* TypeAliasDeclaration */; + let shouldEnterSuppressNewDiagnosticsContextContext = (input.kind === 187 /* TypeLiteral */ || input.kind === 200 /* MappedType */) && input.parent.kind !== 265 /* TypeAliasDeclaration */; if (isMethodDeclaration(input) || isMethodSignature(input)) { - if (hasEffectiveModifier(input, 8 /* Private */)) { + if (hasEffectiveModifier(input, 2 /* Private */)) { if (input.symbol && input.symbol.declarations && input.symbol.declarations[0] !== input) return; return cleanup(factory2.createPropertyDeclaration( @@ -207651,26 +192973,26 @@ ${lanes.join("\n")} } if (isProcessedComponent(input)) { switch (input.kind) { - case 232 /* ExpressionWithTypeArguments */: { + case 233 /* ExpressionWithTypeArguments */: { if (isEntityName(input.expression) || isEntityNameExpression(input.expression)) { checkEntityNameVisibility(input.expression, enclosingDeclaration); } const node = visitEachChild(input, visitDeclarationSubtree, context); return cleanup(factory2.updateExpressionWithTypeArguments(node, node.expression, node.typeArguments)); } - case 182 /* TypeReference */: { + case 183 /* TypeReference */: { checkEntityNameVisibility(input.typeName, enclosingDeclaration); const node = visitEachChild(input, visitDeclarationSubtree, context); return cleanup(factory2.updateTypeReferenceNode(node, node.typeName, node.typeArguments)); } - case 179 /* ConstructSignature */: + case 180 /* ConstructSignature */: return cleanup(factory2.updateConstructSignature( input, ensureTypeParams(input, input.typeParameters), updateParamsList(input, input.parameters), ensureType(input, input.type) )); - case 175 /* Constructor */: { + case 176 /* Constructor */: { const ctor = factory2.createConstructorDeclaration( /*modifiers*/ ensureModifiers(input), @@ -207680,7 +193002,7 @@ ${lanes.join("\n")} ); return cleanup(ctor); } - case 173 /* MethodDeclaration */: { + case 174 /* MethodDeclaration */: { if (isPrivateIdentifier(input.name)) { return cleanup( /*returnValue*/ @@ -207701,7 +193023,7 @@ ${lanes.join("\n")} ); return cleanup(sig); } - case 176 /* GetAccessor */: { + case 177 /* GetAccessor */: { if (isPrivateIdentifier(input.name)) { return cleanup( /*returnValue*/ @@ -207713,13 +193035,13 @@ ${lanes.join("\n")} input, ensureModifiers(input), input.name, - updateAccessorParamsList(input, hasEffectiveModifier(input, 8 /* Private */)), + updateAccessorParamsList(input, hasEffectiveModifier(input, 2 /* Private */)), ensureType(input, accessorType), /*body*/ void 0 )); } - case 177 /* SetAccessor */: { + case 178 /* SetAccessor */: { if (isPrivateIdentifier(input.name)) { return cleanup( /*returnValue*/ @@ -207730,12 +193052,12 @@ ${lanes.join("\n")} input, ensureModifiers(input), input.name, - updateAccessorParamsList(input, hasEffectiveModifier(input, 8 /* Private */)), + updateAccessorParamsList(input, hasEffectiveModifier(input, 2 /* Private */)), /*body*/ void 0 )); } - case 171 /* PropertyDeclaration */: + case 172 /* PropertyDeclaration */: if (isPrivateIdentifier(input.name)) { return cleanup( /*returnValue*/ @@ -207750,7 +193072,7 @@ ${lanes.join("\n")} ensureType(input, input.type), ensureNoInitializer(input) )); - case 170 /* PropertySignature */: + case 171 /* PropertySignature */: if (isPrivateIdentifier(input.name)) { return cleanup( /*returnValue*/ @@ -207764,7 +193086,7 @@ ${lanes.join("\n")} input.questionToken, ensureType(input, input.type) )); - case 172 /* MethodSignature */: { + case 173 /* MethodSignature */: { if (isPrivateIdentifier(input.name)) { return cleanup( /*returnValue*/ @@ -207781,7 +193103,7 @@ ${lanes.join("\n")} ensureType(input, input.type) )); } - case 178 /* CallSignature */: { + case 179 /* CallSignature */: { return cleanup(factory2.updateCallSignature( input, ensureTypeParams(input, input.typeParameters), @@ -207789,7 +193111,7 @@ ${lanes.join("\n")} ensureType(input, input.type) )); } - case 180 /* IndexSignature */: { + case 181 /* IndexSignature */: { return cleanup(factory2.updateIndexSignature( input, ensureModifiers(input), @@ -207797,7 +193119,7 @@ ${lanes.join("\n")} visitNode(input.type, visitDeclarationSubtree, isTypeNode) || factory2.createKeywordTypeNode(133 /* AnyKeyword */) )); } - case 259 /* VariableDeclaration */: { + case 260 /* VariableDeclaration */: { if (isBindingPattern(input.name)) { return recreateBindingPattern(input.name); } @@ -207812,7 +193134,7 @@ ${lanes.join("\n")} ensureNoInitializer(input) )); } - case 167 /* TypeParameter */: { + case 168 /* TypeParameter */: { if (isPrivateMethodTypeParameter(input) && (input.default || input.constraint)) { return cleanup(factory2.updateTypeParameterDeclaration( input, @@ -207826,7 +193148,7 @@ ${lanes.join("\n")} } return cleanup(visitEachChild(input, visitDeclarationSubtree, context)); } - case 193 /* ConditionalType */: { + case 194 /* ConditionalType */: { const checkType = visitNode(input.checkType, visitDeclarationSubtree, isTypeNode); const extendsType = visitNode(input.extendsType, visitDeclarationSubtree, isTypeNode); const oldEnclosingDecl = enclosingDeclaration; @@ -207840,19 +193162,20 @@ ${lanes.join("\n")} Debug.assert(falseType); return cleanup(factory2.updateConditionalTypeNode(input, checkType, extendsType, trueType, falseType)); } - case 183 /* FunctionType */: { + case 184 /* FunctionType */: { return cleanup(factory2.updateFunctionTypeNode(input, visitNodes2(input.typeParameters, visitDeclarationSubtree, isTypeParameterDeclaration), updateParamsList(input, input.parameters), Debug.checkDefined(visitNode(input.type, visitDeclarationSubtree, isTypeNode)))); } - case 184 /* ConstructorType */: { + case 185 /* ConstructorType */: { return cleanup(factory2.updateConstructorTypeNode(input, ensureModifiers(input), visitNodes2(input.typeParameters, visitDeclarationSubtree, isTypeParameterDeclaration), updateParamsList(input, input.parameters), Debug.checkDefined(visitNode(input.type, visitDeclarationSubtree, isTypeNode)))); } - case 204 /* ImportType */: { + case 205 /* ImportType */: { if (!isLiteralImportTypeNode(input)) return cleanup(input); + trackReferencedAmbientModuleFromImport(input); return cleanup(factory2.updateImportTypeNode( input, factory2.updateLiteralTypeNode(input.argument, rewriteModuleSpecifier(input, input.argument.literal)), - input.assertions, + input.attributes, input.qualifier, visitNodes2(input.typeArguments, visitDeclarationSubtree, isTypeNode), input.isTypeOf @@ -207886,7 +193209,7 @@ ${lanes.join("\n")} } } function isPrivateMethodTypeParameter(node) { - return node.parent.kind === 173 /* MethodDeclaration */ && hasEffectiveModifier(node.parent, 8 /* Private */); + return node.parent.kind === 174 /* MethodDeclaration */ && hasEffectiveModifier(node.parent, 2 /* Private */); } function visitDeclarationStatements(input) { if (!isPreservedDeclarationStatement(input)) { @@ -207895,21 +193218,22 @@ ${lanes.join("\n")} if (shouldStripInternal(input)) return; switch (input.kind) { - case 277 /* ExportDeclaration */: { + case 278 /* ExportDeclaration */: { if (isSourceFile(input.parent)) { resultHasExternalModuleIndicator = true; } resultHasScopeMarker = true; + trackReferencedAmbientModuleFromImport(input); return factory2.updateExportDeclaration( input, input.modifiers, input.isTypeOnly, input.exportClause, rewriteModuleSpecifier(input, input.moduleSpecifier), - getResolutionModeOverrideForClause(input.assertClause) ? input.assertClause : void 0 + tryGetResolutionModeOverride(input.attributes) ); } - case 276 /* ExportAssignment */: { + case 277 /* ExportAssignment */: { if (isSourceFile(input.parent)) { resultHasExternalModuleIndicator = true; } @@ -207944,11 +193268,26 @@ ${lanes.join("\n")} return input; } function stripExportModifiers(statement) { - if (isImportEqualsDeclaration(statement) || hasEffectiveModifier(statement, 1024 /* Default */) || !canHaveModifiers(statement)) { + if (isImportEqualsDeclaration(statement) || hasEffectiveModifier(statement, 2048 /* Default */) || !canHaveModifiers(statement)) { return statement; } - const modifiers = factory2.createModifiersFromModifierFlags(getEffectiveModifierFlags(statement) & (258047 /* All */ ^ 1 /* Export */)); - return factory2.updateModifiers(statement, modifiers); + const modifiers = factory2.createModifiersFromModifierFlags(getEffectiveModifierFlags(statement) & (131071 /* All */ ^ 32 /* Export */)); + return factory2.replaceModifiers(statement, modifiers); + } + function updateModuleDeclarationAndKeyword(node, modifiers, name, body) { + const updated = factory2.updateModuleDeclaration(node, modifiers, name, body); + if (isAmbientModule(updated) || updated.flags & 32 /* Namespace */) { + return updated; + } + const fixed = factory2.createModuleDeclaration( + updated.modifiers, + updated.name, + updated.body, + updated.flags | 32 /* Namespace */ + ); + setOriginalNode(fixed, updated); + setTextRange(fixed, updated); + return fixed; } function transformTopLevelDeclaration(input) { if (lateMarkedStatements) { @@ -207958,11 +193297,19 @@ ${lanes.join("\n")} if (shouldStripInternal(input)) return; switch (input.kind) { - case 270 /* ImportEqualsDeclaration */: { - return transformImportEqualsDeclaration(input); + case 271 /* ImportEqualsDeclaration */: { + const transformed = transformImportEqualsDeclaration(input); + if (transformed) { + trackReferencedAmbientModuleFromImport(input); + } + return transformed; } - case 271 /* ImportDeclaration */: { - return transformImportDeclaration(input); + case 272 /* ImportDeclaration */: { + const transformed = transformImportDeclaration(input); + if (transformed) { + trackReferencedAmbientModuleFromImport(input); + } + return transformed; } } if (isDeclaration(input) && isDeclarationAndNotVisible(input)) @@ -207981,7 +193328,7 @@ ${lanes.join("\n")} } const previousNeedsDeclare = needsDeclare; switch (input.kind) { - case 264 /* TypeAliasDeclaration */: { + case 265 /* TypeAliasDeclaration */: { needsDeclare = false; const clean2 = cleanup(factory2.updateTypeAliasDeclaration( input, @@ -207993,7 +193340,7 @@ ${lanes.join("\n")} needsDeclare = previousNeedsDeclare; return clean2; } - case 263 /* InterfaceDeclaration */: { + case 264 /* InterfaceDeclaration */: { return cleanup(factory2.updateInterfaceDeclaration( input, ensureModifiers(input), @@ -208003,7 +193350,7 @@ ${lanes.join("\n")} visitNodes2(input.members, visitDeclarationSubtree, isTypeElement) )); } - case 261 /* FunctionDeclaration */: { + case 262 /* FunctionDeclaration */: { const clean2 = cleanup(factory2.updateFunctionDeclaration( input, ensureModifiers(input), @@ -208023,14 +193370,14 @@ ${lanes.join("\n")} void 0, clean2.name || factory2.createIdentifier("_default"), factory2.createModuleBlock([]), - 16 /* Namespace */ + 32 /* Namespace */ ); setParent(fakespace, enclosingDeclaration); fakespace.locals = createSymbolTable(props); fakespace.symbol = props[0].parent; const exportMappings = []; let declarations = mapDefined(props, (p) => { - if (!p.valueDeclaration || !(isPropertyAccessExpression(p.valueDeclaration) || isElementAccessExpression(p.valueDeclaration) || isBinaryExpression(p.valueDeclaration))) { + if (!isExpandoPropertyDeclaration(p.valueDeclaration)) { return void 0; } const nameStr = unescapeLeadingUnderscores(p.escapedName); @@ -208056,7 +193403,7 @@ ${lanes.join("\n")} return factory2.createVariableStatement(isNonContextualKeywordName ? void 0 : [factory2.createToken(95 /* ExportKeyword */)], factory2.createVariableDeclarationList([varDecl])); }); if (!exportMappings.length) { - declarations = mapDefined(declarations, (declaration) => factory2.updateModifiers(declaration, 0 /* None */)); + declarations = mapDefined(declarations, (declaration) => factory2.replaceModifiers(declaration, 0 /* None */)); } else { declarations.push(factory2.createExportDeclaration( /*modifiers*/ @@ -208073,11 +193420,11 @@ ${lanes.join("\n")} })) )); } - const namespaceDecl = factory2.createModuleDeclaration(ensureModifiers(input), input.name, factory2.createModuleBlock(declarations), 16 /* Namespace */); - if (!hasEffectiveModifier(clean2, 1024 /* Default */)) { + const namespaceDecl = factory2.createModuleDeclaration(ensureModifiers(input), input.name, factory2.createModuleBlock(declarations), 32 /* Namespace */); + if (!hasEffectiveModifier(clean2, 2048 /* Default */)) { return [clean2, namespaceDecl]; } - const modifiers = factory2.createModifiersFromModifierFlags(getEffectiveModifierFlags(clean2) & ~1025 /* ExportDefault */ | 2 /* Ambient */); + const modifiers = factory2.createModifiersFromModifierFlags(getEffectiveModifierFlags(clean2) & ~2080 /* ExportDefault */ | 128 /* Ambient */); const cleanDeclaration = factory2.updateFunctionDeclaration( clean2, modifiers, @@ -208112,17 +193459,17 @@ ${lanes.join("\n")} return clean2; } } - case 266 /* ModuleDeclaration */: { + case 267 /* ModuleDeclaration */: { needsDeclare = false; const inner = input.body; - if (inner && inner.kind === 267 /* ModuleBlock */) { + if (inner && inner.kind === 268 /* ModuleBlock */) { const oldNeedsScopeFix = needsScopeFixMarker; const oldHasScopeFix = resultHasScopeMarker; resultHasScopeMarker = false; needsScopeFixMarker = false; const statements = visitNodes2(inner.statements, visitDeclarationStatements, isStatement); let lateStatements = transformAndReplaceLatePaintedStatements(statements); - if (input.flags & 16777216 /* Ambient */) { + if (input.flags & 33554432 /* Ambient */) { needsScopeFixMarker = false; } if (!isGlobalScopeAugmentation(input) && !hasScopeMarker2(lateStatements) && !resultHasScopeMarker) { @@ -208137,7 +193484,7 @@ ${lanes.join("\n")} needsScopeFixMarker = oldNeedsScopeFix; resultHasScopeMarker = oldHasScopeFix; const mods = ensureModifiers(input); - return cleanup(factory2.updateModuleDeclaration( + return cleanup(updateModuleDeclarationAndKeyword( input, mods, isExternalModuleAugmentation(input) ? rewriteModuleSpecifier(input, input.name) : input.name, @@ -208151,7 +193498,7 @@ ${lanes.join("\n")} const id = getOriginalNodeId(inner); const body = lateStatementReplacementMap.get(id); lateStatementReplacementMap.delete(id); - return cleanup(factory2.updateModuleDeclaration( + return cleanup(updateModuleDeclarationAndKeyword( input, mods, input.name, @@ -208159,7 +193506,7 @@ ${lanes.join("\n")} )); } } - case 262 /* ClassDeclaration */: { + case 263 /* ClassDeclaration */: { errorNameNode = input.name; errorFallbackNode = input; const modifiers = factory2.createNodeArray(ensureModifiers(input)); @@ -208169,17 +193516,20 @@ ${lanes.join("\n")} if (ctor) { const oldDiag2 = getSymbolAccessibilityDiagnostic; parameterProperties = compact(flatMap(ctor.parameters, (param) => { - if (!hasSyntacticModifier(param, 16476 /* ParameterPropertyModifier */) || shouldStripInternal(param)) + if (!hasSyntacticModifier(param, 31 /* ParameterPropertyModifier */) || shouldStripInternal(param)) return; getSymbolAccessibilityDiagnostic = createGetSymbolAccessibilityDiagnosticForNode(param); if (param.name.kind === 80 /* Identifier */) { - return preserveJsDoc(factory2.createPropertyDeclaration( - ensureModifiers(param), - param.name, - param.questionToken, - ensureType(param, param.type), - ensureNoInitializer(param) - ), param); + return preserveJsDoc( + factory2.createPropertyDeclaration( + ensureModifiers(param), + param.name, + param.questionToken, + ensureType(param, param.type), + ensureNoInitializer(param) + ), + param + ); } else { return walkBindingPattern(param.name); } @@ -208255,14 +193605,17 @@ ${lanes.join("\n")} } return factory2.updateHeritageClause(clause, visitNodes2(factory2.createNodeArray(filter(clause.types, (t) => isEntityNameExpression(t.expression) || t.expression.kind === 106 /* NullKeyword */)), visitDeclarationSubtree, isExpressionWithTypeArguments)); })); - return [statement, cleanup(factory2.updateClassDeclaration( - input, - modifiers, - input.name, - typeParameters, - heritageClauses, - members - ))]; + return [ + statement, + cleanup(factory2.updateClassDeclaration( + input, + modifiers, + input.name, + typeParameters, + heritageClauses, + members + )) + ]; } else { const heritageClauses = transformHeritageClauses(input.heritageClauses); return cleanup(factory2.updateClassDeclaration( @@ -208275,16 +193628,21 @@ ${lanes.join("\n")} )); } } - case 242 /* VariableStatement */: { + case 243 /* VariableStatement */: { return cleanup(transformVariableStatement(input)); } - case 265 /* EnumDeclaration */: { - return cleanup(factory2.updateEnumDeclaration(input, factory2.createNodeArray(ensureModifiers(input)), input.name, factory2.createNodeArray(mapDefined(input.members, (m) => { - if (shouldStripInternal(m)) - return; - const constValue = resolver.getConstantValue(m); - return preserveJsDoc(factory2.updateEnumMember(m, m.name, constValue !== void 0 ? typeof constValue === "string" ? factory2.createStringLiteral(constValue) : factory2.createNumericLiteral(constValue) : void 0), m); - })))); + case 266 /* EnumDeclaration */: { + return cleanup(factory2.updateEnumDeclaration( + input, + factory2.createNodeArray(ensureModifiers(input)), + input.name, + factory2.createNodeArray(mapDefined(input.members, (m) => { + if (shouldStripInternal(m)) + return; + const constValue = resolver.getConstantValue(m); + return preserveJsDoc(factory2.updateEnumMember(m, m.name, constValue !== void 0 ? typeof constValue === "string" ? factory2.createStringLiteral(constValue) : factory2.createNumericLiteral(constValue) : void 0), m); + })) + )); } } return Debug.assertNever(input, `Unhandled top-level node in declaration emit: ${Debug.formatSyntaxKind(input.kind)}`); @@ -208295,7 +193653,7 @@ ${lanes.join("\n")} if (canProdiceDiagnostic) { getSymbolAccessibilityDiagnostic = oldDiag; } - if (input.kind === 266 /* ModuleDeclaration */) { + if (input.kind === 267 /* ModuleDeclaration */) { needsDeclare = previousNeedsDeclare; } if (node === input) { @@ -208312,13 +193670,23 @@ ${lanes.join("\n")} const nodes = visitNodes2(input.declarationList.declarations, visitDeclarationSubtree, isVariableDeclaration); if (!length(nodes)) return; - return factory2.updateVariableStatement(input, factory2.createNodeArray(ensureModifiers(input)), factory2.updateVariableDeclarationList(input.declarationList, nodes)); + const modifiers = factory2.createNodeArray(ensureModifiers(input)); + let declList; + if (isVarUsing(input.declarationList) || isVarAwaitUsing(input.declarationList)) { + declList = factory2.createVariableDeclarationList(nodes, 2 /* Const */); + setOriginalNode(declList, input.declarationList); + setTextRange(declList, input.declarationList); + setCommentRange(declList, input.declarationList); + } else { + declList = factory2.updateVariableDeclarationList(input.declarationList, nodes); + } + return factory2.updateVariableStatement(input, modifiers, declList); } function recreateBindingPattern(d) { return flatten(mapDefined(d.elements, (e) => recreateBindingElement(e))); } function recreateBindingElement(e) { - if (e.kind === 231 /* OmittedExpression */) { + if (e.kind === 232 /* OmittedExpression */) { return; } if (e.name) { @@ -208376,11 +193744,11 @@ ${lanes.join("\n")} return factory2.createModifiersFromModifierFlags(newFlags); } function ensureModifierFlags(node) { - let mask2 = 258047 /* All */ ^ (4 /* Public */ | 512 /* Async */ | 16384 /* Override */); - let additions = needsDeclare && !isAlwaysType(node) ? 2 /* Ambient */ : 0 /* None */; - const parentIsFile = node.parent.kind === 311 /* SourceFile */; + let mask2 = 131071 /* All */ ^ (1 /* Public */ | 1024 /* Async */ | 16 /* Override */); + let additions = needsDeclare && !isAlwaysType(node) ? 128 /* Ambient */ : 0 /* None */; + const parentIsFile = node.parent.kind === 312 /* SourceFile */; if (!parentIsFile || isBundledEmit && parentIsFile && isExternalModule(node.parent)) { - mask2 ^= 2 /* Ambient */; + mask2 ^= 128 /* Ambient */; additions = 0 /* None */; } return maskModifierFlags(node, mask2, additions); @@ -208398,13 +193766,23 @@ ${lanes.join("\n")} return accessorType; } function transformHeritageClauses(nodes) { - return factory2.createNodeArray(filter(map(nodes, (clause) => factory2.updateHeritageClause(clause, visitNodes2(factory2.createNodeArray(filter(clause.types, (t) => { - return isEntityNameExpression(t.expression) || clause.token === 96 /* ExtendsKeyword */ && t.expression.kind === 106 /* NullKeyword */; - })), visitDeclarationSubtree, isExpressionWithTypeArguments))), (clause) => clause.types && !!clause.types.length)); + return factory2.createNodeArray(filter( + map(nodes, (clause) => factory2.updateHeritageClause( + clause, + visitNodes2( + factory2.createNodeArray(filter(clause.types, (t) => { + return isEntityNameExpression(t.expression) || clause.token === 96 /* ExtendsKeyword */ && t.expression.kind === 106 /* NullKeyword */; + })), + visitDeclarationSubtree, + isExpressionWithTypeArguments + ) + )), + (clause) => clause.types && !!clause.types.length + )); } } function isAlwaysType(node) { - if (node.kind === 263 /* InterfaceDeclaration */) { + if (node.kind === 264 /* InterfaceDeclaration */) { return true; } return false; @@ -208412,69 +193790,69 @@ ${lanes.join("\n")} function maskModifiers(factory2, node, modifierMask, modifierAdditions) { return factory2.createModifiersFromModifierFlags(maskModifierFlags(node, modifierMask, modifierAdditions)); } - function maskModifierFlags(node, modifierMask = 258047 /* All */ ^ 4 /* Public */, modifierAdditions = 0 /* None */) { + function maskModifierFlags(node, modifierMask = 131071 /* All */ ^ 1 /* Public */, modifierAdditions = 0 /* None */) { let flags = getEffectiveModifierFlags(node) & modifierMask | modifierAdditions; - if (flags & 1024 /* Default */ && !(flags & 1 /* Export */)) { - flags ^= 1 /* Export */; + if (flags & 2048 /* Default */ && !(flags & 32 /* Export */)) { + flags ^= 32 /* Export */; } - if (flags & 1024 /* Default */ && flags & 2 /* Ambient */) { - flags ^= 2 /* Ambient */; + if (flags & 2048 /* Default */ && flags & 128 /* Ambient */) { + flags ^= 128 /* Ambient */; } return flags; } function getTypeAnnotationFromAccessor(accessor) { if (accessor) { - return accessor.kind === 176 /* GetAccessor */ ? accessor.type : accessor.parameters.length > 0 ? accessor.parameters[0].type : void 0; + return accessor.kind === 177 /* GetAccessor */ ? accessor.type : accessor.parameters.length > 0 ? accessor.parameters[0].type : void 0; } } function canHaveLiteralInitializer(node) { switch (node.kind) { - case 171 /* PropertyDeclaration */: - case 170 /* PropertySignature */: - return !hasEffectiveModifier(node, 8 /* Private */); - case 168 /* Parameter */: - case 259 /* VariableDeclaration */: + case 172 /* PropertyDeclaration */: + case 171 /* PropertySignature */: + return !hasEffectiveModifier(node, 2 /* Private */); + case 169 /* Parameter */: + case 260 /* VariableDeclaration */: return true; } return false; } function isPreservedDeclarationStatement(node) { switch (node.kind) { - case 261 /* FunctionDeclaration */: - case 266 /* ModuleDeclaration */: - case 270 /* ImportEqualsDeclaration */: - case 263 /* InterfaceDeclaration */: - case 262 /* ClassDeclaration */: - case 264 /* TypeAliasDeclaration */: - case 265 /* EnumDeclaration */: - case 242 /* VariableStatement */: - case 271 /* ImportDeclaration */: - case 277 /* ExportDeclaration */: - case 276 /* ExportAssignment */: + case 262 /* FunctionDeclaration */: + case 267 /* ModuleDeclaration */: + case 271 /* ImportEqualsDeclaration */: + case 264 /* InterfaceDeclaration */: + case 263 /* ClassDeclaration */: + case 265 /* TypeAliasDeclaration */: + case 266 /* EnumDeclaration */: + case 243 /* VariableStatement */: + case 272 /* ImportDeclaration */: + case 278 /* ExportDeclaration */: + case 277 /* ExportAssignment */: return true; } return false; } function isProcessedComponent(node) { switch (node.kind) { - case 179 /* ConstructSignature */: - case 175 /* Constructor */: - case 173 /* MethodDeclaration */: - case 176 /* GetAccessor */: - case 177 /* SetAccessor */: - case 171 /* PropertyDeclaration */: - case 170 /* PropertySignature */: - case 172 /* MethodSignature */: - case 178 /* CallSignature */: - case 180 /* IndexSignature */: - case 259 /* VariableDeclaration */: - case 167 /* TypeParameter */: - case 232 /* ExpressionWithTypeArguments */: - case 182 /* TypeReference */: - case 193 /* ConditionalType */: - case 183 /* FunctionType */: - case 184 /* ConstructorType */: - case 204 /* ImportType */: + case 180 /* ConstructSignature */: + case 176 /* Constructor */: + case 174 /* MethodDeclaration */: + case 177 /* GetAccessor */: + case 178 /* SetAccessor */: + case 172 /* PropertyDeclaration */: + case 171 /* PropertySignature */: + case 173 /* MethodSignature */: + case 179 /* CallSignature */: + case 181 /* IndexSignature */: + case 260 /* VariableDeclaration */: + case 168 /* TypeParameter */: + case 233 /* ExpressionWithTypeArguments */: + case 183 /* TypeReference */: + case 194 /* ConditionalType */: + case 184 /* FunctionType */: + case 185 /* ConstructorType */: + case 205 /* ImportType */: return true; } return false; @@ -208523,16 +193901,17 @@ ${lanes.join("\n")} transformers.push(transformTypeScript); if (compilerOptions.experimentalDecorators) { transformers.push(transformLegacyDecorators); - } else if (languageVersion < 99 /* ESNext */ || !useDefineForClassFields) { - transformers.push(transformESDecorators); } - transformers.push(transformClassFields); if (getJSXTransformEnabled(compilerOptions)) { transformers.push(transformJsx); } if (languageVersion < 99 /* ESNext */) { transformers.push(transformESNext); } + if (!compilerOptions.experimentalDecorators && (languageVersion < 99 /* ESNext */ || !useDefineForClassFields)) { + transformers.push(transformESDecorators); + } + transformers.push(transformClassFields); if (languageVersion < 8 /* ES2021 */) { transformers.push(transformES2021); } @@ -208591,7 +193970,7 @@ ${lanes.join("\n")} } function transformNodes(resolver, host, factory2, options, nodes, transformers, allowDtsFiles) { var _a, _b; - const enabledSyntaxKindFeatures = new Array(362 /* Count */); + const enabledSyntaxKindFeatures = new Array(363 /* Count */); let lexicalEnvironmentVariableDeclarations; let lexicalEnvironmentFunctionDeclarations; let lexicalEnvironmentStatements; @@ -208670,7 +194049,7 @@ ${lanes.join("\n")} state = 1 /* Initialized */; const transformed = []; for (const node of nodes) { - (_a = tracing) == null ? void 0 : _a.push(tracing.Phase.Emit, "transformNodes", node.kind === 311 /* SourceFile */ ? { path: node.path } : { kind: node.kind, pos: node.pos, end: node.end }); + (_a = tracing) == null ? void 0 : _a.push(tracing.Phase.Emit, "transformNodes", node.kind === 312 /* SourceFile */ ? { path: node.path } : { kind: node.kind, pos: node.pos, end: node.end }); transformed.push((allowDtsFiles ? transformation : transformRoot)(node)); (_b = tracing) == null ? void 0 : _b.pop(); } @@ -208998,7 +194377,7 @@ ${lanes.join("\n")} } function getOutputPathsFor(sourceFile, host, forceDtsPaths) { const options = host.getCompilerOptions(); - if (sourceFile.kind === 312 /* Bundle */) { + if (sourceFile.kind === 313 /* Bundle */) { return getOutputPathsForBundle(options, forceDtsPaths); } else { const ownOutputFilePath = getOwnEmitOutputFilePath(sourceFile.fileName, host, getOutputExtension(sourceFile.fileName, options)); @@ -209334,6 +194713,7 @@ ${lanes.join("\n")} inlineSourceMap: compilerOptions.inlineSourceMap, extendedDiagnostics: compilerOptions.extendedDiagnostics, onlyPrintJsDocStyle: true, + omitBraceSourceMapPositions: true, writeBundleFileInfo: !!bundleBuildInfo, recordInternalSection: !!bundleBuildInfo, relativeToBuildInfo @@ -209390,8 +194770,8 @@ ${lanes.join("\n")} } function printSourceFileOrBundle(jsFilePath, sourceMapFilePath, transform2, printer, mapOptions) { const sourceFileOrBundle = transform2.transformed[0]; - const bundle = sourceFileOrBundle.kind === 312 /* Bundle */ ? sourceFileOrBundle : void 0; - const sourceFile = sourceFileOrBundle.kind === 311 /* SourceFile */ ? sourceFileOrBundle : void 0; + const bundle = sourceFileOrBundle.kind === 313 /* Bundle */ ? sourceFileOrBundle : void 0; + const sourceFile = sourceFileOrBundle.kind === 312 /* SourceFile */ ? sourceFileOrBundle : void 0; const sourceFiles = bundle ? bundle.sourceFiles : [sourceFile]; let sourceMapGenerator; if (shouldEmitSourceMaps(mapOptions, sourceFileOrBundle)) { @@ -209453,7 +194833,7 @@ ${lanes.join("\n")} writer.clear(); } function shouldEmitSourceMaps(mapOptions, sourceFileOrBundle) { - return (mapOptions.sourceMap || mapOptions.inlineSourceMap) && (sourceFileOrBundle.kind !== 311 /* SourceFile */ || !fileExtensionIs(sourceFileOrBundle.fileName, ".json" /* Json */)); + return (mapOptions.sourceMap || mapOptions.inlineSourceMap) && (sourceFileOrBundle.kind !== 312 /* SourceFile */ || !fileExtensionIs(sourceFileOrBundle.fileName, ".json" /* Json */)); } function getSourceRoot(mapOptions) { const sourceRoot = normalizeSlashes(mapOptions.sourceRoot || ""); @@ -209696,6 +195076,7 @@ ${lanes.join("\n")} onAfterEmitToken } = handlers; var extendedDiagnostics = !!printerOptions.extendedDiagnostics; + var omitBraceSourcePositions = !!printerOptions.omitBraceSourceMapPositions; var newLine = getNewLineCharacter(printerOptions); var moduleKind = getEmitModuleKind(printerOptions); var bundledHelpers = /* @__PURE__ */ new Map(); @@ -209773,11 +195154,11 @@ ${lanes.join("\n")} break; } switch (node.kind) { - case 311 /* SourceFile */: + case 312 /* SourceFile */: return printFile(node); - case 312 /* Bundle */: + case 313 /* Bundle */: return printBundle(node); - case 313 /* UnparsedSource */: + case 314 /* UnparsedSource */: return printUnparsedSource(node); } writeNode(hint, node, sourceFile, beginPrint()); @@ -210156,301 +195537,301 @@ ${lanes.join("\n")} return emitIdentifier(node); case 81 /* PrivateIdentifier */: return emitPrivateIdentifier(node); - case 165 /* QualifiedName */: + case 166 /* QualifiedName */: return emitQualifiedName(node); - case 166 /* ComputedPropertyName */: + case 167 /* ComputedPropertyName */: return emitComputedPropertyName(node); - case 167 /* TypeParameter */: + case 168 /* TypeParameter */: return emitTypeParameter(node); - case 168 /* Parameter */: + case 169 /* Parameter */: return emitParameter(node); - case 169 /* Decorator */: + case 170 /* Decorator */: return emitDecorator(node); - case 170 /* PropertySignature */: + case 171 /* PropertySignature */: return emitPropertySignature(node); - case 171 /* PropertyDeclaration */: + case 172 /* PropertyDeclaration */: return emitPropertyDeclaration(node); - case 172 /* MethodSignature */: + case 173 /* MethodSignature */: return emitMethodSignature(node); - case 173 /* MethodDeclaration */: + case 174 /* MethodDeclaration */: return emitMethodDeclaration(node); - case 174 /* ClassStaticBlockDeclaration */: + case 175 /* ClassStaticBlockDeclaration */: return emitClassStaticBlockDeclaration(node); - case 175 /* Constructor */: + case 176 /* Constructor */: return emitConstructor(node); - case 176 /* GetAccessor */: - case 177 /* SetAccessor */: + case 177 /* GetAccessor */: + case 178 /* SetAccessor */: return emitAccessorDeclaration(node); - case 178 /* CallSignature */: + case 179 /* CallSignature */: return emitCallSignature(node); - case 179 /* ConstructSignature */: + case 180 /* ConstructSignature */: return emitConstructSignature(node); - case 180 /* IndexSignature */: + case 181 /* IndexSignature */: return emitIndexSignature(node); - case 181 /* TypePredicate */: + case 182 /* TypePredicate */: return emitTypePredicate(node); - case 182 /* TypeReference */: + case 183 /* TypeReference */: return emitTypeReference(node); - case 183 /* FunctionType */: + case 184 /* FunctionType */: return emitFunctionType(node); - case 184 /* ConstructorType */: + case 185 /* ConstructorType */: return emitConstructorType(node); - case 185 /* TypeQuery */: + case 186 /* TypeQuery */: return emitTypeQuery(node); - case 186 /* TypeLiteral */: + case 187 /* TypeLiteral */: return emitTypeLiteral(node); - case 187 /* ArrayType */: + case 188 /* ArrayType */: return emitArrayType(node); - case 188 /* TupleType */: + case 189 /* TupleType */: return emitTupleType(node); - case 189 /* OptionalType */: + case 190 /* OptionalType */: return emitOptionalType(node); - case 191 /* UnionType */: + case 192 /* UnionType */: return emitUnionType(node); - case 192 /* IntersectionType */: + case 193 /* IntersectionType */: return emitIntersectionType(node); - case 193 /* ConditionalType */: + case 194 /* ConditionalType */: return emitConditionalType(node); - case 194 /* InferType */: + case 195 /* InferType */: return emitInferType(node); - case 195 /* ParenthesizedType */: + case 196 /* ParenthesizedType */: return emitParenthesizedType(node); - case 232 /* ExpressionWithTypeArguments */: + case 233 /* ExpressionWithTypeArguments */: return emitExpressionWithTypeArguments(node); - case 196 /* ThisType */: + case 197 /* ThisType */: return emitThisType(); - case 197 /* TypeOperator */: + case 198 /* TypeOperator */: return emitTypeOperator(node); - case 198 /* IndexedAccessType */: + case 199 /* IndexedAccessType */: return emitIndexedAccessType(node); - case 199 /* MappedType */: + case 200 /* MappedType */: return emitMappedType(node); - case 200 /* LiteralType */: + case 201 /* LiteralType */: return emitLiteralType(node); - case 201 /* NamedTupleMember */: + case 202 /* NamedTupleMember */: return emitNamedTupleMember(node); - case 202 /* TemplateLiteralType */: + case 203 /* TemplateLiteralType */: return emitTemplateType(node); - case 203 /* TemplateLiteralTypeSpan */: + case 204 /* TemplateLiteralTypeSpan */: return emitTemplateTypeSpan(node); - case 204 /* ImportType */: + case 205 /* ImportType */: return emitImportTypeNode(node); - case 205 /* ObjectBindingPattern */: + case 206 /* ObjectBindingPattern */: return emitObjectBindingPattern(node); - case 206 /* ArrayBindingPattern */: + case 207 /* ArrayBindingPattern */: return emitArrayBindingPattern(node); - case 207 /* BindingElement */: + case 208 /* BindingElement */: return emitBindingElement(node); - case 238 /* TemplateSpan */: + case 239 /* TemplateSpan */: return emitTemplateSpan(node); - case 239 /* SemicolonClassElement */: + case 240 /* SemicolonClassElement */: return emitSemicolonClassElement(); - case 240 /* Block */: + case 241 /* Block */: return emitBlock(node); - case 242 /* VariableStatement */: + case 243 /* VariableStatement */: return emitVariableStatement(node); - case 241 /* EmptyStatement */: + case 242 /* EmptyStatement */: return emitEmptyStatement( /*isEmbeddedStatement*/ false ); - case 243 /* ExpressionStatement */: + case 244 /* ExpressionStatement */: return emitExpressionStatement(node); - case 244 /* IfStatement */: + case 245 /* IfStatement */: return emitIfStatement(node); - case 245 /* DoStatement */: + case 246 /* DoStatement */: return emitDoStatement(node); - case 246 /* WhileStatement */: + case 247 /* WhileStatement */: return emitWhileStatement(node); - case 247 /* ForStatement */: + case 248 /* ForStatement */: return emitForStatement(node); - case 248 /* ForInStatement */: + case 249 /* ForInStatement */: return emitForInStatement(node); - case 249 /* ForOfStatement */: + case 250 /* ForOfStatement */: return emitForOfStatement(node); - case 250 /* ContinueStatement */: + case 251 /* ContinueStatement */: return emitContinueStatement(node); - case 251 /* BreakStatement */: + case 252 /* BreakStatement */: return emitBreakStatement(node); - case 252 /* ReturnStatement */: + case 253 /* ReturnStatement */: return emitReturnStatement(node); - case 253 /* WithStatement */: + case 254 /* WithStatement */: return emitWithStatement(node); - case 254 /* SwitchStatement */: + case 255 /* SwitchStatement */: return emitSwitchStatement(node); - case 255 /* LabeledStatement */: + case 256 /* LabeledStatement */: return emitLabeledStatement(node); - case 256 /* ThrowStatement */: + case 257 /* ThrowStatement */: return emitThrowStatement(node); - case 257 /* TryStatement */: + case 258 /* TryStatement */: return emitTryStatement(node); - case 258 /* DebuggerStatement */: + case 259 /* DebuggerStatement */: return emitDebuggerStatement(node); - case 259 /* VariableDeclaration */: + case 260 /* VariableDeclaration */: return emitVariableDeclaration(node); - case 260 /* VariableDeclarationList */: + case 261 /* VariableDeclarationList */: return emitVariableDeclarationList(node); - case 261 /* FunctionDeclaration */: + case 262 /* FunctionDeclaration */: return emitFunctionDeclaration(node); - case 262 /* ClassDeclaration */: + case 263 /* ClassDeclaration */: return emitClassDeclaration(node); - case 263 /* InterfaceDeclaration */: + case 264 /* InterfaceDeclaration */: return emitInterfaceDeclaration(node); - case 264 /* TypeAliasDeclaration */: + case 265 /* TypeAliasDeclaration */: return emitTypeAliasDeclaration(node); - case 265 /* EnumDeclaration */: + case 266 /* EnumDeclaration */: return emitEnumDeclaration(node); - case 266 /* ModuleDeclaration */: + case 267 /* ModuleDeclaration */: return emitModuleDeclaration(node); - case 267 /* ModuleBlock */: + case 268 /* ModuleBlock */: return emitModuleBlock(node); - case 268 /* CaseBlock */: + case 269 /* CaseBlock */: return emitCaseBlock(node); - case 269 /* NamespaceExportDeclaration */: + case 270 /* NamespaceExportDeclaration */: return emitNamespaceExportDeclaration(node); - case 270 /* ImportEqualsDeclaration */: + case 271 /* ImportEqualsDeclaration */: return emitImportEqualsDeclaration(node); - case 271 /* ImportDeclaration */: + case 272 /* ImportDeclaration */: return emitImportDeclaration(node); - case 272 /* ImportClause */: + case 273 /* ImportClause */: return emitImportClause(node); - case 273 /* NamespaceImport */: + case 274 /* NamespaceImport */: return emitNamespaceImport(node); - case 279 /* NamespaceExport */: + case 280 /* NamespaceExport */: return emitNamespaceExport(node); - case 274 /* NamedImports */: + case 275 /* NamedImports */: return emitNamedImports(node); - case 275 /* ImportSpecifier */: + case 276 /* ImportSpecifier */: return emitImportSpecifier(node); - case 276 /* ExportAssignment */: + case 277 /* ExportAssignment */: return emitExportAssignment(node); - case 277 /* ExportDeclaration */: + case 278 /* ExportDeclaration */: return emitExportDeclaration(node); - case 278 /* NamedExports */: + case 279 /* NamedExports */: return emitNamedExports(node); - case 280 /* ExportSpecifier */: + case 281 /* ExportSpecifier */: return emitExportSpecifier(node); - case 299 /* AssertClause */: - return emitAssertClause(node); - case 300 /* AssertEntry */: - return emitAssertEntry(node); - case 281 /* MissingDeclaration */: + case 300 /* ImportAttributes */: + return emitImportAttributes(node); + case 301 /* ImportAttribute */: + return emitImportAttribute(node); + case 282 /* MissingDeclaration */: return; - case 282 /* ExternalModuleReference */: + case 283 /* ExternalModuleReference */: return emitExternalModuleReference(node); case 12 /* JsxText */: return emitJsxText(node); - case 285 /* JsxOpeningElement */: - case 288 /* JsxOpeningFragment */: + case 286 /* JsxOpeningElement */: + case 289 /* JsxOpeningFragment */: return emitJsxOpeningElementOrFragment(node); - case 286 /* JsxClosingElement */: - case 289 /* JsxClosingFragment */: + case 287 /* JsxClosingElement */: + case 290 /* JsxClosingFragment */: return emitJsxClosingElementOrFragment(node); - case 290 /* JsxAttribute */: + case 291 /* JsxAttribute */: return emitJsxAttribute(node); - case 291 /* JsxAttributes */: + case 292 /* JsxAttributes */: return emitJsxAttributes(node); - case 292 /* JsxSpreadAttribute */: + case 293 /* JsxSpreadAttribute */: return emitJsxSpreadAttribute(node); - case 293 /* JsxExpression */: + case 294 /* JsxExpression */: return emitJsxExpression(node); - case 294 /* JsxNamespacedName */: + case 295 /* JsxNamespacedName */: return emitJsxNamespacedName(node); - case 295 /* CaseClause */: + case 296 /* CaseClause */: return emitCaseClause(node); - case 296 /* DefaultClause */: + case 297 /* DefaultClause */: return emitDefaultClause(node); - case 297 /* HeritageClause */: + case 298 /* HeritageClause */: return emitHeritageClause(node); - case 298 /* CatchClause */: + case 299 /* CatchClause */: return emitCatchClause(node); - case 302 /* PropertyAssignment */: + case 303 /* PropertyAssignment */: return emitPropertyAssignment(node); - case 303 /* ShorthandPropertyAssignment */: + case 304 /* ShorthandPropertyAssignment */: return emitShorthandPropertyAssignment(node); - case 304 /* SpreadAssignment */: + case 305 /* SpreadAssignment */: return emitSpreadAssignment(node); - case 305 /* EnumMember */: + case 306 /* EnumMember */: return emitEnumMember(node); - case 306 /* UnparsedPrologue */: + case 307 /* UnparsedPrologue */: return writeUnparsedNode(node); - case 313 /* UnparsedSource */: - case 307 /* UnparsedPrepend */: + case 314 /* UnparsedSource */: + case 308 /* UnparsedPrepend */: return emitUnparsedSourceOrPrepend(node); - case 308 /* UnparsedText */: - case 309 /* UnparsedInternalText */: + case 309 /* UnparsedText */: + case 310 /* UnparsedInternalText */: return emitUnparsedTextLike(node); - case 310 /* UnparsedSyntheticReference */: + case 311 /* UnparsedSyntheticReference */: return emitUnparsedSyntheticReference(node); - case 311 /* SourceFile */: + case 312 /* SourceFile */: return emitSourceFile(node); - case 312 /* Bundle */: + case 313 /* Bundle */: return Debug.fail("Bundles should be printed using printBundle"); - case 314 /* InputFiles */: + case 315 /* InputFiles */: return Debug.fail("InputFiles should not be printed"); - case 315 /* JSDocTypeExpression */: + case 316 /* JSDocTypeExpression */: return emitJSDocTypeExpression(node); - case 316 /* JSDocNameReference */: + case 317 /* JSDocNameReference */: return emitJSDocNameReference(node); - case 318 /* JSDocAllType */: + case 319 /* JSDocAllType */: return writePunctuation("*"); - case 319 /* JSDocUnknownType */: + case 320 /* JSDocUnknownType */: return writePunctuation("?"); - case 320 /* JSDocNullableType */: + case 321 /* JSDocNullableType */: return emitJSDocNullableType(node); - case 321 /* JSDocNonNullableType */: + case 322 /* JSDocNonNullableType */: return emitJSDocNonNullableType(node); - case 322 /* JSDocOptionalType */: + case 323 /* JSDocOptionalType */: return emitJSDocOptionalType(node); - case 323 /* JSDocFunctionType */: + case 324 /* JSDocFunctionType */: return emitJSDocFunctionType(node); - case 190 /* RestType */: - case 324 /* JSDocVariadicType */: + case 191 /* RestType */: + case 325 /* JSDocVariadicType */: return emitRestOrJSDocVariadicType(node); - case 325 /* JSDocNamepathType */: + case 326 /* JSDocNamepathType */: return; - case 326 /* JSDoc */: + case 327 /* JSDoc */: return emitJSDoc(node); - case 328 /* JSDocTypeLiteral */: + case 329 /* JSDocTypeLiteral */: return emitJSDocTypeLiteral(node); - case 329 /* JSDocSignature */: + case 330 /* JSDocSignature */: return emitJSDocSignature(node); - case 333 /* JSDocTag */: - case 338 /* JSDocClassTag */: - case 343 /* JSDocOverrideTag */: + case 334 /* JSDocTag */: + case 339 /* JSDocClassTag */: + case 344 /* JSDocOverrideTag */: return emitJSDocSimpleTag(node); - case 334 /* JSDocAugmentsTag */: - case 335 /* JSDocImplementsTag */: + case 335 /* JSDocAugmentsTag */: + case 336 /* JSDocImplementsTag */: return emitJSDocHeritageTag(node); - case 336 /* JSDocAuthorTag */: - case 337 /* JSDocDeprecatedTag */: + case 337 /* JSDocAuthorTag */: + case 338 /* JSDocDeprecatedTag */: return; - case 339 /* JSDocPublicTag */: - case 340 /* JSDocPrivateTag */: - case 341 /* JSDocProtectedTag */: - case 342 /* JSDocReadonlyTag */: + case 340 /* JSDocPublicTag */: + case 341 /* JSDocPrivateTag */: + case 342 /* JSDocProtectedTag */: + case 343 /* JSDocReadonlyTag */: return; - case 344 /* JSDocCallbackTag */: + case 345 /* JSDocCallbackTag */: return emitJSDocCallbackTag(node); - case 345 /* JSDocOverloadTag */: + case 346 /* JSDocOverloadTag */: return emitJSDocOverloadTag(node); - case 347 /* JSDocParameterTag */: - case 354 /* JSDocPropertyTag */: + case 348 /* JSDocParameterTag */: + case 355 /* JSDocPropertyTag */: return emitJSDocPropertyLikeTag(node); - case 346 /* JSDocEnumTag */: - case 348 /* JSDocReturnTag */: - case 349 /* JSDocThisTag */: - case 350 /* JSDocTypeTag */: - case 355 /* JSDocThrowsTag */: - case 356 /* JSDocSatisfiesTag */: + case 347 /* JSDocEnumTag */: + case 349 /* JSDocReturnTag */: + case 350 /* JSDocThisTag */: + case 351 /* JSDocTypeTag */: + case 356 /* JSDocThrowsTag */: + case 357 /* JSDocSatisfiesTag */: return emitJSDocSimpleTypedTag(node); - case 351 /* JSDocTemplateTag */: + case 352 /* JSDocTemplateTag */: return emitJSDocTemplateTag(node); - case 352 /* JSDocTypedefTag */: + case 353 /* JSDocTypedefTag */: return emitJSDocTypedefTag(node); - case 353 /* JSDocSeeTag */: + case 354 /* JSDocSeeTag */: return emitJSDocSeeTag(node); - case 358 /* NotEmittedStatement */: + case 359 /* NotEmittedStatement */: return; } if (isExpression(node)) { @@ -210483,83 +195864,83 @@ ${lanes.join("\n")} return emitIdentifier(node); case 81 /* PrivateIdentifier */: return emitPrivateIdentifier(node); - case 208 /* ArrayLiteralExpression */: + case 209 /* ArrayLiteralExpression */: return emitArrayLiteralExpression(node); - case 209 /* ObjectLiteralExpression */: + case 210 /* ObjectLiteralExpression */: return emitObjectLiteralExpression(node); - case 210 /* PropertyAccessExpression */: + case 211 /* PropertyAccessExpression */: return emitPropertyAccessExpression(node); - case 211 /* ElementAccessExpression */: + case 212 /* ElementAccessExpression */: return emitElementAccessExpression(node); - case 212 /* CallExpression */: + case 213 /* CallExpression */: return emitCallExpression(node); - case 213 /* NewExpression */: + case 214 /* NewExpression */: return emitNewExpression(node); - case 214 /* TaggedTemplateExpression */: + case 215 /* TaggedTemplateExpression */: return emitTaggedTemplateExpression(node); - case 215 /* TypeAssertionExpression */: + case 216 /* TypeAssertionExpression */: return emitTypeAssertionExpression(node); - case 216 /* ParenthesizedExpression */: + case 217 /* ParenthesizedExpression */: return emitParenthesizedExpression(node); - case 217 /* FunctionExpression */: + case 218 /* FunctionExpression */: return emitFunctionExpression(node); - case 218 /* ArrowFunction */: + case 219 /* ArrowFunction */: return emitArrowFunction(node); - case 219 /* DeleteExpression */: + case 220 /* DeleteExpression */: return emitDeleteExpression(node); - case 220 /* TypeOfExpression */: + case 221 /* TypeOfExpression */: return emitTypeOfExpression(node); - case 221 /* VoidExpression */: + case 222 /* VoidExpression */: return emitVoidExpression(node); - case 222 /* AwaitExpression */: + case 223 /* AwaitExpression */: return emitAwaitExpression(node); - case 223 /* PrefixUnaryExpression */: + case 224 /* PrefixUnaryExpression */: return emitPrefixUnaryExpression(node); - case 224 /* PostfixUnaryExpression */: + case 225 /* PostfixUnaryExpression */: return emitPostfixUnaryExpression(node); - case 225 /* BinaryExpression */: + case 226 /* BinaryExpression */: return emitBinaryExpression(node); - case 226 /* ConditionalExpression */: + case 227 /* ConditionalExpression */: return emitConditionalExpression(node); - case 227 /* TemplateExpression */: + case 228 /* TemplateExpression */: return emitTemplateExpression(node); - case 228 /* YieldExpression */: + case 229 /* YieldExpression */: return emitYieldExpression(node); - case 229 /* SpreadElement */: + case 230 /* SpreadElement */: return emitSpreadElement(node); - case 230 /* ClassExpression */: + case 231 /* ClassExpression */: return emitClassExpression(node); - case 231 /* OmittedExpression */: + case 232 /* OmittedExpression */: return; - case 233 /* AsExpression */: + case 234 /* AsExpression */: return emitAsExpression(node); - case 234 /* NonNullExpression */: + case 235 /* NonNullExpression */: return emitNonNullExpression(node); - case 232 /* ExpressionWithTypeArguments */: + case 233 /* ExpressionWithTypeArguments */: return emitExpressionWithTypeArguments(node); - case 237 /* SatisfiesExpression */: + case 238 /* SatisfiesExpression */: return emitSatisfiesExpression(node); - case 235 /* MetaProperty */: + case 236 /* MetaProperty */: return emitMetaProperty(node); - case 236 /* SyntheticExpression */: + case 237 /* SyntheticExpression */: return Debug.fail("SyntheticExpression should never be printed."); - case 281 /* MissingDeclaration */: + case 282 /* MissingDeclaration */: return; - case 283 /* JsxElement */: + case 284 /* JsxElement */: return emitJsxElement(node); - case 284 /* JsxSelfClosingElement */: + case 285 /* JsxSelfClosingElement */: return emitJsxSelfClosingElement(node); - case 287 /* JsxFragment */: + case 288 /* JsxFragment */: return emitJsxFragment(node); - case 357 /* SyntaxList */: + case 358 /* SyntaxList */: return Debug.fail("SyntaxList should not be printed"); - case 358 /* NotEmittedStatement */: + case 359 /* NotEmittedStatement */: return; - case 359 /* PartiallyEmittedExpression */: + case 360 /* PartiallyEmittedExpression */: return emitPartiallyEmittedExpression(node); - case 360 /* CommaListExpression */: + case 361 /* CommaListExpression */: return emitCommaList(node); - case 361 /* SyntheticReferenceExpression */: + case 362 /* SyntheticReferenceExpression */: return Debug.fail("SyntheticReferenceExpression should not be printed"); } } @@ -210605,7 +195986,7 @@ ${lanes.join("\n")} } function emitHelpers(node) { let helpersEmitted = false; - const bundle = node.kind === 312 /* Bundle */ ? node : void 0; + const bundle = node.kind === 313 /* Bundle */ ? node : void 0; if (bundle && moduleKind === 0 /* None */) { return; } @@ -210680,7 +196061,7 @@ ${lanes.join("\n")} updateOrPushBundleFileTextLike( pos, writer.getTextPos(), - unparsed.kind === 308 /* UnparsedText */ ? "text" /* Text */ : "internal" /* Internal */ + unparsed.kind === 309 /* UnparsedText */ ? "text" /* Text */ : "internal" /* Internal */ ); } } @@ -210715,14 +196096,8 @@ ${lanes.join("\n")} nonEscapingWrite(`}`); } function emitTabStop(hint, node, snippet) { - Debug.assert( - node.kind === 241 /* EmptyStatement */, - `A tab stop cannot be attached to a node of kind ${Debug.formatSyntaxKind(node.kind)}.` - ); - Debug.assert( - hint !== 5 /* EmbeddedStatement */, - `A tab stop cannot be attached to an embedded statement.` - ); + Debug.assert(node.kind === 242 /* EmptyStatement */, `A tab stop cannot be attached to a node of kind ${Debug.formatSyntaxKind(node.kind)}.`); + Debug.assert(hint !== 5 /* EmbeddedStatement */, `A tab stop cannot be attached to an embedded statement.`); nonEscapingWrite(`$${snippet.order}`); } function emitIdentifier(node) { @@ -210788,7 +196163,7 @@ ${lanes.join("\n")} emit(node.dotDotDotToken); emitNodeWithWriter(node.name, writeParameter); emit(node.questionToken); - if (node.parent && node.parent.kind === 323 /* JSDocFunctionType */ && !node.name) { + if (node.parent && node.parent.kind === 324 /* JSDocFunctionType */ && !node.name) { emit(node.type); } else { emitTypeAnnotation(node.type); @@ -210864,7 +196239,7 @@ ${lanes.join("\n")} /*allowDecorators*/ true ); - const token = node.kind === 176 /* GetAccessor */ ? 139 /* GetKeyword */ : 153 /* SetKeyword */; + const token = node.kind === 177 /* GetAccessor */ ? 139 /* GetKeyword */ : 153 /* SetKeyword */; emitTokenWithComment(token, pos, writeKeyword, node); writeSpace(); emit(node.name); @@ -211114,16 +196489,16 @@ ${lanes.join("\n")} writeKeyword("import"); writePunctuation("("); emit(node.argument); - if (node.assertions) { + if (node.attributes) { writePunctuation(","); writeSpace(); writePunctuation("{"); writeSpace(); - writeKeyword("assert"); + writeKeyword(node.attributes.token === 132 /* AssertKeyword */ ? "assert" : "with"); writePunctuation(":"); writeSpace(); - const elements = node.assertions.assertClause.elements; - emitList(node.assertions.assertClause, elements, 526226 /* ImportClauseEntries */); + const elements = node.attributes.elements; + emitList(node.attributes, elements, 526226 /* ImportAttributes */); writeSpace(); writePunctuation("}"); } @@ -211215,10 +196590,10 @@ ${lanes.join("\n")} /*jsxAttributeEscape*/ false ); - return !(expression.numericLiteralFlags & 448 /* WithSpecifier */) && !stringContains(text, tokenToString(25 /* DotToken */)) && !stringContains(text, String.fromCharCode(69 /* E */)) && !stringContains(text, String.fromCharCode(101 /* e */)); + return !(expression.numericLiteralFlags & 448 /* WithSpecifier */) && !text.includes(tokenToString(25 /* DotToken */)) && !text.includes(String.fromCharCode(69 /* E */)) && !text.includes(String.fromCharCode(101 /* e */)); } else if (isAccessExpression(expression)) { const constantValue = getConstantValue(expression); - return typeof constantValue === "number" && isFinite(constantValue) && Math.floor(constantValue) === constantValue; + return typeof constantValue === "number" && isFinite(constantValue) && constantValue >= 0 && Math.floor(constantValue) === constantValue; } } function emitElementAccessExpression(node) { @@ -211329,7 +196704,7 @@ ${lanes.join("\n")} } function shouldEmitWhitespaceBeforeOperand(node) { const operand = node.operand; - return operand.kind === 223 /* PrefixUnaryExpression */ && (node.operator === 40 /* PlusToken */ && (operand.operator === 40 /* PlusToken */ || operand.operator === 46 /* PlusPlusToken */) || node.operator === 41 /* MinusToken */ && (operand.operator === 41 /* MinusToken */ || operand.operator === 47 /* MinusMinusToken */)); + return operand.kind === 224 /* PrefixUnaryExpression */ && (node.operator === 40 /* PlusToken */ && (operand.operator === 40 /* PlusToken */ || operand.operator === 46 /* PlusPlusToken */) || node.operator === 41 /* MinusToken */ && (operand.operator === 41 /* MinusToken */ || operand.operator === 47 /* MinusMinusToken */)); } function emitPostfixUnaryExpression(node) { emitExpression(node.operand, parenthesizer.parenthesizeOperandOfPostfixUnary); @@ -211588,7 +196963,7 @@ ${lanes.join("\n")} if (node.elseStatement) { writeLineOrSpace(node, node.thenStatement, node.elseStatement); emitTokenWithComment(93 /* ElseKeyword */, node.thenStatement.end, writeKeyword, node); - if (node.elseStatement.kind === 244 /* IfStatement */) { + if (node.elseStatement.kind === 245 /* IfStatement */) { writeSpace(); emit(node.elseStatement); } else { @@ -211655,7 +197030,7 @@ ${lanes.join("\n")} emitTokenWithComment(21 /* OpenParenToken */, openParenPos, writePunctuation, node); emitForBinding(node.initializer); writeSpace(); - emitTokenWithComment(164 /* OfKeyword */, node.initializer.end, writeKeyword, node); + emitTokenWithComment(165 /* OfKeyword */, node.initializer.end, writeKeyword, node); writeSpace(); emitExpression(node.expression); emitTokenWithComment(22 /* CloseParenToken */, node.expression.end, writePunctuation, node); @@ -211663,7 +197038,7 @@ ${lanes.join("\n")} } function emitForBinding(node) { if (node !== void 0) { - if (node.kind === 260 /* VariableDeclarationList */) { + if (node.kind === 261 /* VariableDeclarationList */) { emit(node); } else { emitExpression(node); @@ -211697,9 +197072,13 @@ ${lanes.join("\n")} decreaseIndent(); } } - pos = writeTokenText(token, writer2, pos); + if (!omitBraceSourcePositions && (token === 19 /* OpenBraceToken */ || token === 20 /* CloseBraceToken */)) { + pos = writeToken(token, pos, writer2, contextNode); + } else { + pos = writeTokenText(token, writer2, pos); + } if (isSimilarNode && contextNode.end !== pos) { - const isJsxExprContext = contextNode.kind === 293 /* JsxExpression */; + const isJsxExprContext = contextNode.kind === 294 /* JsxExpression */; emitTrailingCommentsOfPosition( pos, /*prefixSpace*/ @@ -211811,7 +197190,14 @@ ${lanes.join("\n")} emitInitializer(node.initializer, ((_a = node.type) == null ? void 0 : _a.end) ?? ((_c = (_b = node.name.emitNode) == null ? void 0 : _b.typeNode) == null ? void 0 : _c.end) ?? node.name.end, node, parenthesizer.parenthesizeExpressionForDisallowedComma); } function emitVariableDeclarationList(node) { - writeKeyword(isLet(node) ? "let" : isVarConst(node) ? "const" : "var"); + if (isVarAwaitUsing(node)) { + writeKeyword("await"); + writeSpace(); + writeKeyword("using"); + } else { + const head = isLet(node) ? "let" : isVarConst(node) ? "const" : isVarUsing(node) ? "using" : "var"; + writeKeyword(head); + } writeSpace(); emitList(node, node.declarations, 528 /* VariableDeclarationList */); } @@ -212020,8 +197406,8 @@ ${lanes.join("\n")} /*allowDecorators*/ false ); - if (~node.flags & 1024 /* GlobalAugmentation */) { - writeKeyword(node.flags & 16 /* Namespace */ ? "namespace" : "module"); + if (~node.flags & 2048 /* GlobalAugmentation */) { + writeKeyword(node.flags & 32 /* Namespace */ ? "namespace" : "module"); writeSpace(); } emit(node.name); @@ -212097,12 +197483,12 @@ ${lanes.join("\n")} if (node.importClause) { emit(node.importClause); writeSpace(); - emitTokenWithComment(160 /* FromKeyword */, node.importClause.end, writeKeyword, node); + emitTokenWithComment(161 /* FromKeyword */, node.importClause.end, writeKeyword, node); writeSpace(); } emitExpression(node.moduleSpecifier); - if (node.assertClause) { - emitWithLeadingSpace(node.assertClause); + if (node.attributes) { + emitWithLeadingSpace(node.attributes); } writeTrailingSemicolon(); } @@ -212140,7 +197526,10 @@ ${lanes.join("\n")} emitTokenWithComment(90 /* DefaultKeyword */, nextPos, writeKeyword, node); } writeSpace(); - emitExpression(node.expression, node.isExportEquals ? parenthesizer.getParenthesizeRightSideOfBinaryForOperator(64 /* EqualsToken */) : parenthesizer.parenthesizeExpressionOfExportDefault); + emitExpression( + node.expression, + node.isExportEquals ? parenthesizer.getParenthesizeRightSideOfBinaryForOperator(64 /* EqualsToken */) : parenthesizer.parenthesizeExpressionOfExportDefault + ); writeTrailingSemicolon(); } function emitExportDeclaration(node) { @@ -212164,22 +197553,22 @@ ${lanes.join("\n")} if (node.moduleSpecifier) { writeSpace(); const fromPos = node.exportClause ? node.exportClause.end : nextPos; - emitTokenWithComment(160 /* FromKeyword */, fromPos, writeKeyword, node); + emitTokenWithComment(161 /* FromKeyword */, fromPos, writeKeyword, node); writeSpace(); emitExpression(node.moduleSpecifier); } - if (node.assertClause) { - emitWithLeadingSpace(node.assertClause); + if (node.attributes) { + emitWithLeadingSpace(node.attributes); } writeTrailingSemicolon(); } - function emitAssertClause(node) { - emitTokenWithComment(132 /* AssertKeyword */, node.pos, writeKeyword, node); + function emitImportAttributes(node) { + emitTokenWithComment(node.token, node.pos, writeKeyword, node); writeSpace(); const elements = node.elements; - emitList(node, elements, 526226 /* ImportClauseEntries */); + emitList(node, elements, 526226 /* ImportAttributes */); } - function emitAssertEntry(node) { + function emitImportAttribute(node) { emit(node.name); writePunctuation(":"); writeSpace(); @@ -212419,7 +197808,7 @@ ${lanes.join("\n")} } } if (node.tags) { - if (node.tags.length === 1 && node.tags[0].kind === 350 /* JSDocTypeTag */ && !node.comment) { + if (node.tags.length === 1 && node.tags[0].kind === 351 /* JSDocTypeTag */ && !node.comment) { writeSpace(); emit(node.tags[0]); } else { @@ -212463,7 +197852,7 @@ ${lanes.join("\n")} function emitJSDocTypedefTag(tag) { emitJSDocTagName(tag.tagName); if (tag.typeExpression) { - if (tag.typeExpression.kind === 315 /* JSDocTypeExpression */) { + if (tag.typeExpression.kind === 316 /* JSDocTypeExpression */) { emitJSDocTypeExpression(tag.typeExpression); } else { writeSpace(); @@ -212481,7 +197870,7 @@ ${lanes.join("\n")} emit(tag.fullName); } emitJSDocComment(tag.comment); - if (tag.typeExpression && tag.typeExpression.kind === 328 /* JSDocTypeLiteral */) { + if (tag.typeExpression && tag.typeExpression.kind === 329 /* JSDocTypeLiteral */) { emitJSDocTypeLiteral(tag.typeExpression); } } @@ -213038,6 +198427,16 @@ ${lanes.join("\n")} increaseIndent(); shouldDecreaseIndentAfterEmit = true; } + if (shouldEmitInterveningComments && format & 60 /* DelimitersMask */ && !positionIsSynthesized(child.pos)) { + const commentRange = getCommentRange(child); + emitTrailingCommentsOfPosition( + commentRange.pos, + /*prefixSpace*/ + !!(format & 512 /* SpaceBetweenSiblings */), + /*forceNoNewline*/ + true + ); + } writeLine(separatingLineTerminatorCount); shouldEmitInterveningComments = false; } else if (previousSibling && format & 512 /* SpaceBetweenSiblings */) { @@ -213364,7 +198763,7 @@ ${lanes.join("\n")} return block.statements.length === 0 && (!currentSourceFile || rangeEndIsOnSameLineAsRangeStart(block, block, currentSourceFile)); } function skipSynthesizedParentheses(node) { - while (node.kind === 216 /* ParenthesizedExpression */ && nodeIsSynthesized(node)) { + while (node.kind === 217 /* ParenthesizedExpression */ && nodeIsSynthesized(node)) { node = node.expression; } return node; @@ -213451,84 +198850,84 @@ ${lanes.join("\n")} if (!node) return; switch (node.kind) { - case 240 /* Block */: + case 241 /* Block */: forEach(node.statements, generateNames); break; - case 255 /* LabeledStatement */: - case 253 /* WithStatement */: - case 245 /* DoStatement */: - case 246 /* WhileStatement */: + case 256 /* LabeledStatement */: + case 254 /* WithStatement */: + case 246 /* DoStatement */: + case 247 /* WhileStatement */: generateNames(node.statement); break; - case 244 /* IfStatement */: + case 245 /* IfStatement */: generateNames(node.thenStatement); generateNames(node.elseStatement); break; - case 247 /* ForStatement */: - case 249 /* ForOfStatement */: - case 248 /* ForInStatement */: + case 248 /* ForStatement */: + case 250 /* ForOfStatement */: + case 249 /* ForInStatement */: generateNames(node.initializer); generateNames(node.statement); break; - case 254 /* SwitchStatement */: + case 255 /* SwitchStatement */: generateNames(node.caseBlock); break; - case 268 /* CaseBlock */: + case 269 /* CaseBlock */: forEach(node.clauses, generateNames); break; - case 295 /* CaseClause */: - case 296 /* DefaultClause */: + case 296 /* CaseClause */: + case 297 /* DefaultClause */: forEach(node.statements, generateNames); break; - case 257 /* TryStatement */: + case 258 /* TryStatement */: generateNames(node.tryBlock); generateNames(node.catchClause); generateNames(node.finallyBlock); break; - case 298 /* CatchClause */: + case 299 /* CatchClause */: generateNames(node.variableDeclaration); generateNames(node.block); break; - case 242 /* VariableStatement */: + case 243 /* VariableStatement */: generateNames(node.declarationList); break; - case 260 /* VariableDeclarationList */: + case 261 /* VariableDeclarationList */: forEach(node.declarations, generateNames); break; - case 259 /* VariableDeclaration */: - case 168 /* Parameter */: - case 207 /* BindingElement */: - case 262 /* ClassDeclaration */: + case 260 /* VariableDeclaration */: + case 169 /* Parameter */: + case 208 /* BindingElement */: + case 263 /* ClassDeclaration */: generateNameIfNeeded(node.name); break; - case 261 /* FunctionDeclaration */: + case 262 /* FunctionDeclaration */: generateNameIfNeeded(node.name); if (getEmitFlags(node) & 1048576 /* ReuseTempVariableScope */) { forEach(node.parameters, generateNames); generateNames(node.body); } break; - case 205 /* ObjectBindingPattern */: - case 206 /* ArrayBindingPattern */: + case 206 /* ObjectBindingPattern */: + case 207 /* ArrayBindingPattern */: forEach(node.elements, generateNames); break; - case 271 /* ImportDeclaration */: + case 272 /* ImportDeclaration */: generateNames(node.importClause); break; - case 272 /* ImportClause */: + case 273 /* ImportClause */: generateNameIfNeeded(node.name); generateNames(node.namedBindings); break; - case 273 /* NamespaceImport */: + case 274 /* NamespaceImport */: generateNameIfNeeded(node.name); break; - case 279 /* NamespaceExport */: + case 280 /* NamespaceExport */: generateNameIfNeeded(node.name); break; - case 274 /* NamedImports */: + case 275 /* NamedImports */: forEach(node.elements, generateNames); break; - case 275 /* ImportSpecifier */: + case 276 /* ImportSpecifier */: generateNameIfNeeded(node.propertyName || node.name); break; } @@ -213537,12 +198936,12 @@ ${lanes.join("\n")} if (!node) return; switch (node.kind) { - case 302 /* PropertyAssignment */: - case 303 /* ShorthandPropertyAssignment */: - case 171 /* PropertyDeclaration */: - case 173 /* MethodDeclaration */: - case 176 /* GetAccessor */: - case 177 /* SetAccessor */: + case 303 /* PropertyAssignment */: + case 304 /* ShorthandPropertyAssignment */: + case 172 /* PropertyDeclaration */: + case 174 /* MethodDeclaration */: + case 177 /* GetAccessor */: + case 178 /* SetAccessor */: generateNameIfNeeded(node.name); break; } @@ -213800,16 +199199,16 @@ ${lanes.join("\n")} prefix, suffix ); - case 266 /* ModuleDeclaration */: - case 265 /* EnumDeclaration */: + case 267 /* ModuleDeclaration */: + case 266 /* EnumDeclaration */: Debug.assert(!prefix && !suffix && !privateName); return generateNameForModuleOrEnum(node); - case 271 /* ImportDeclaration */: - case 277 /* ExportDeclaration */: + case 272 /* ImportDeclaration */: + case 278 /* ExportDeclaration */: Debug.assert(!prefix && !suffix && !privateName); return generateNameForImportOrExportDeclaration(node); - case 261 /* FunctionDeclaration */: - case 262 /* ClassDeclaration */: { + case 262 /* FunctionDeclaration */: + case 263 /* ClassDeclaration */: { Debug.assert(!prefix && !suffix && !privateName); const name = node.name; if (name && !isGeneratedIdentifier(name)) { @@ -213824,17 +199223,17 @@ ${lanes.join("\n")} } return generateNameForExportDefault(); } - case 276 /* ExportAssignment */: + case 277 /* ExportAssignment */: Debug.assert(!prefix && !suffix && !privateName); return generateNameForExportDefault(); - case 230 /* ClassExpression */: + case 231 /* ClassExpression */: Debug.assert(!prefix && !suffix && !privateName); return generateNameForClassExpression(); - case 173 /* MethodDeclaration */: - case 176 /* GetAccessor */: - case 177 /* SetAccessor */: + case 174 /* MethodDeclaration */: + case 177 /* GetAccessor */: + case 178 /* SetAccessor */: return generateNameForMethodOrAccessor(node, privateName, prefix, suffix); - case 166 /* ComputedPropertyName */: + case 167 /* ComputedPropertyName */: return makeTempVariableName( 0 /* Auto */, /*reservedInNestedScopes*/ @@ -213928,7 +199327,7 @@ ${lanes.join("\n")} emitLeadingComments( pos, /*isEmittedNode*/ - node.kind !== 358 /* NotEmittedStatement */ + node.kind !== 359 /* NotEmittedStatement */ ); } if (!skipLeadingComments || pos >= 0 && (emitFlags & 1024 /* NoLeadingComments */) !== 0) { @@ -213936,7 +199335,7 @@ ${lanes.join("\n")} } if (!skipTrailingComments || end >= 0 && (emitFlags & 2048 /* NoTrailingComments */) !== 0) { containerEnd = end; - if (node.kind === 260 /* VariableDeclarationList */) { + if (node.kind === 261 /* VariableDeclarationList */) { declarationListContainerEnd = end; } } @@ -213952,7 +199351,7 @@ ${lanes.join("\n")} containerPos = savedContainerPos; containerEnd = savedContainerEnd; declarationListContainerEnd = savedDeclarationListContainerEnd; - if (!skipTrailingComments && node.kind !== 358 /* NotEmittedStatement */) { + if (!skipTrailingComments && node.kind !== 359 /* NotEmittedStatement */) { emitTrailingComments(end); } } @@ -214224,7 +199623,7 @@ ${lanes.join("\n")} } } else { const source = sourceMapRange.source || sourceMapSource; - if (node.kind !== 358 /* NotEmittedStatement */ && (emitFlags & 32 /* NoLeadingSourceMap */) === 0 && sourceMapRange.pos >= 0) { + if (node.kind !== 359 /* NotEmittedStatement */ && (emitFlags & 32 /* NoLeadingSourceMap */) === 0 && sourceMapRange.pos >= 0) { emitSourcePos(sourceMapRange.source || sourceMapSource, skipSourceTrivia(source, sourceMapRange.pos)); } if (emitFlags & 128 /* NoNestedSourceMaps */) { @@ -214239,7 +199638,7 @@ ${lanes.join("\n")} if (emitFlags & 128 /* NoNestedSourceMaps */) { sourceMapsDisabled = false; } - if (node.kind !== 358 /* NotEmittedStatement */ && (emitFlags & 64 /* NoTrailingSourceMap */) === 0 && sourceMapRange.end >= 0) { + if (node.kind !== 359 /* NotEmittedStatement */ && (emitFlags & 64 /* NoTrailingSourceMap */) === 0 && sourceMapRange.end >= 0) { emitSourcePos(sourceMapRange.source || sourceMapSource, sourceMapRange.end); } } @@ -214396,7 +199795,8 @@ ${lanes.join("\n")} getSymbolOfExternalModuleSpecifier: notImplemented, isBindingCapturedByNode: notImplemented, getDeclarationStatementsForSourceFile: notImplemented, - isImportRequiredByAugmentation: notImplemented + isImportRequiredByAugmentation: notImplemented, + tryFindAmbientModule: notImplemented }; createPrinterWithDefaults = /* @__PURE__ */ memoize(() => createPrinter({})); createPrinterWithRemoveComments = /* @__PURE__ */ memoize(() => createPrinter({ removeComments: true })); @@ -214406,14 +199806,14 @@ ${lanes.join("\n")} }); // src/compiler/watchUtilities.ts - function createCachedDirectoryStructureHost(host, currentDirectory, useCaseSensitiveFileNames) { + function createCachedDirectoryStructureHost(host, currentDirectory, useCaseSensitiveFileNames2) { if (!host.getDirectories || !host.readDirectory) { return void 0; } const cachedReadDirectoryResult = /* @__PURE__ */ new Map(); - const getCanonicalFileName = createGetCanonicalFileName(useCaseSensitiveFileNames); + const getCanonicalFileName = createGetCanonicalFileName(useCaseSensitiveFileNames2); return { - useCaseSensitiveFileNames, + useCaseSensitiveFileNames: useCaseSensitiveFileNames2, fileExists, readFile: (path, encoding) => host.readFile(path, encoding), directoryExists: host.directoryExists && directoryExists, @@ -214535,7 +199935,7 @@ ${lanes.join("\n")} const rootResult = tryReadDirectory2(rootDir, rootDirPath); let rootSymLinkResult; if (rootResult !== void 0) { - return matchFiles(rootDir, extensions, excludes, includes, useCaseSensitiveFileNames, currentDirectory, depth, getFileSystemEntries, realpath); + return matchFiles(rootDir, extensions, excludes, includes, useCaseSensitiveFileNames2, currentDirectory, depth, getFileSystemEntries, realpath); } return host.readDirectory(rootDir, extensions, excludes, includes, depth); function getFileSystemEntries(dir) { @@ -214730,9 +200130,10 @@ ${lanes.join("\n")} program, extraFileExtensions, currentDirectory, - useCaseSensitiveFileNames, + useCaseSensitiveFileNames: useCaseSensitiveFileNames2, writeLog, - toPath: toPath3 + toPath: toPath3, + getScriptKind: getScriptKind2 }) { const newPath = removeIgnoredPath(fileOrDirectoryPath); if (!newPath) { @@ -214742,11 +200143,11 @@ ${lanes.join("\n")} fileOrDirectoryPath = newPath; if (fileOrDirectoryPath === watchedDirPath) return false; - if (hasExtension(fileOrDirectoryPath) && !isSupportedSourceFileName(fileOrDirectory, options, extraFileExtensions)) { + if (hasExtension(fileOrDirectoryPath) && !(isSupportedSourceFileName(fileOrDirectory, options, extraFileExtensions) || isSupportedScriptKind())) { writeLog(`Project: ${configFileName} Detected file add/remove of non supported extension: ${fileOrDirectory}`); return true; } - if (isExcludedFile(fileOrDirectory, options.configFile.configFileSpecs, getNormalizedAbsolutePath(getDirectoryPath(configFileName), currentDirectory), useCaseSensitiveFileNames, currentDirectory)) { + if (isExcludedFile(fileOrDirectory, options.configFile.configFileSpecs, getNormalizedAbsolutePath(getDirectoryPath(configFileName), currentDirectory), useCaseSensitiveFileNames2, currentDirectory)) { writeLog(`Project: ${configFileName} Detected excluded file: ${fileOrDirectory}`); return true; } @@ -214771,6 +200172,25 @@ ${lanes.join("\n")} function hasSourceFile(file) { return realProgram ? !!realProgram.getSourceFileByPath(file) : builderProgram ? builderProgram.getState().fileInfos.has(file) : !!find(program, (rootFile) => toPath3(rootFile) === file); } + function isSupportedScriptKind() { + if (!getScriptKind2) + return false; + const scriptKind = getScriptKind2(fileOrDirectory); + switch (scriptKind) { + case 3 /* TS */: + case 4 /* TSX */: + case 7 /* Deferred */: + case 5 /* External */: + return true; + case 1 /* JS */: + case 2 /* JSX */: + return getAllowJSCompilerOption(options); + case 6 /* JSON */: + return getResolveJsonModule(options); + case 0 /* Unknown */: + return false; + } + } } function isBuilderProgram(program) { return !!program.getState; @@ -214781,7 +200201,7 @@ ${lanes.join("\n")} } return program.isEmittedFile(file); } - function getWatchFactory(host, watchLogLevel, log, getDetailWatchInfo) { + function getWatchFactory(host, watchLogLevel, log, getDetailWatchInfo2) { setSysLog(watchLogLevel === 2 /* Verbose */ ? log : noop); const plainInvokeFactory = { watchFile: (file, callback, pollingInterval, options) => host.watchFile(file, callback, pollingInterval, options), @@ -214803,7 +200223,7 @@ ${lanes.join("\n")} function createExcludeHandlingAddWatch(key) { return (file, cb, flags, options, detailInfo1, detailInfo2) => { var _a; - return !matchesExclude(file, key === "watchFile" ? options == null ? void 0 : options.excludeFiles : options == null ? void 0 : options.excludeDirectories, useCaseSensitiveFileNames(), ((_a = host.getCurrentDirectory) == null ? void 0 : _a.call(host)) || "") ? factory2[key].call( + return !matchesExclude(file, key === "watchFile" ? options == null ? void 0 : options.excludeFiles : options == null ? void 0 : options.excludeDirectories, useCaseSensitiveFileNames2(), ((_a = host.getCurrentDirectory) == null ? void 0 : _a.call(host)) || "") ? factory2[key].call( /*thisArgs*/ void 0, file, @@ -214815,27 +200235,27 @@ ${lanes.join("\n")} ) : excludeWatcherFactory(file, flags, options, detailInfo1, detailInfo2); }; } - function useCaseSensitiveFileNames() { + function useCaseSensitiveFileNames2() { return typeof host.useCaseSensitiveFileNames === "boolean" ? host.useCaseSensitiveFileNames : host.useCaseSensitiveFileNames(); } function createExcludeWatcherWithLogging(file, flags, options, detailInfo1, detailInfo2) { - log(`ExcludeWatcher:: Added:: ${getWatchInfo(file, flags, options, detailInfo1, detailInfo2, getDetailWatchInfo)}`); + log(`ExcludeWatcher:: Added:: ${getWatchInfo(file, flags, options, detailInfo1, detailInfo2, getDetailWatchInfo2)}`); return { - close: () => log(`ExcludeWatcher:: Close:: ${getWatchInfo(file, flags, options, detailInfo1, detailInfo2, getDetailWatchInfo)}`) + close: () => log(`ExcludeWatcher:: Close:: ${getWatchInfo(file, flags, options, detailInfo1, detailInfo2, getDetailWatchInfo2)}`) }; } function createFileWatcherWithLogging(file, cb, flags, options, detailInfo1, detailInfo2) { - log(`FileWatcher:: Added:: ${getWatchInfo(file, flags, options, detailInfo1, detailInfo2, getDetailWatchInfo)}`); + log(`FileWatcher:: Added:: ${getWatchInfo(file, flags, options, detailInfo1, detailInfo2, getDetailWatchInfo2)}`); const watcher = triggerInvokingFactory.watchFile(file, cb, flags, options, detailInfo1, detailInfo2); return { close: () => { - log(`FileWatcher:: Close:: ${getWatchInfo(file, flags, options, detailInfo1, detailInfo2, getDetailWatchInfo)}`); + log(`FileWatcher:: Close:: ${getWatchInfo(file, flags, options, detailInfo1, detailInfo2, getDetailWatchInfo2)}`); watcher.close(); } }; } function createDirectoryWatcherWithLogging(file, cb, flags, options, detailInfo1, detailInfo2) { - const watchInfo = `DirectoryWatcher:: Added:: ${getWatchInfo(file, flags, options, detailInfo1, detailInfo2, getDetailWatchInfo)}`; + const watchInfo = `DirectoryWatcher:: Added:: ${getWatchInfo(file, flags, options, detailInfo1, detailInfo2, getDetailWatchInfo2)}`; log(watchInfo); const start = timestamp(); const watcher = triggerInvokingFactory.watchDirectory(file, cb, flags, options, detailInfo1, detailInfo2); @@ -214843,7 +200263,7 @@ ${lanes.join("\n")} log(`Elapsed:: ${elapsed}ms ${watchInfo}`); return { close: () => { - const watchInfo2 = `DirectoryWatcher:: Close:: ${getWatchInfo(file, flags, options, detailInfo1, detailInfo2, getDetailWatchInfo)}`; + const watchInfo2 = `DirectoryWatcher:: Close:: ${getWatchInfo(file, flags, options, detailInfo1, detailInfo2, getDetailWatchInfo2)}`; log(watchInfo2); const start2 = timestamp(); watcher.close(); @@ -214858,7 +200278,7 @@ ${lanes.join("\n")} void 0, file, (...args) => { - const triggerredInfo = `${key === "watchFile" ? "FileWatcher" : "DirectoryWatcher"}:: Triggered with ${args[0]} ${args[1] !== void 0 ? args[1] : ""}:: ${getWatchInfo(file, flags, options, detailInfo1, detailInfo2, getDetailWatchInfo)}`; + const triggerredInfo = `${key === "watchFile" ? "FileWatcher" : "DirectoryWatcher"}:: Triggered with ${args[0]} ${args[1] !== void 0 ? args[1] : ""}:: ${getWatchInfo(file, flags, options, detailInfo1, detailInfo2, getDetailWatchInfo2)}`; log(triggerredInfo); const start = timestamp(); cb.call( @@ -214875,8 +200295,8 @@ ${lanes.join("\n")} detailInfo2 ); } - function getWatchInfo(file, flags, options, detailInfo1, detailInfo2, getDetailWatchInfo2) { - return `WatchInfo: ${file} ${flags} ${JSON.stringify(options)} ${getDetailWatchInfo2 ? getDetailWatchInfo2(detailInfo1, detailInfo2) : detailInfo2 === void 0 ? detailInfo1 : `${detailInfo1} ${detailInfo2}`}`; + function getWatchInfo(file, flags, options, detailInfo1, detailInfo2, getDetailWatchInfo3) { + return `WatchInfo: ${file} ${flags} ${JSON.stringify(options)} ${getDetailWatchInfo3 ? getDetailWatchInfo3(detailInfo1, detailInfo2) : detailInfo2 === void 0 ? detailInfo1 : `${detailInfo1} ${detailInfo2}`}`; } } function getFallbackOptions(options) { @@ -214888,17 +200308,18 @@ ${lanes.join("\n")} function closeFileWatcherOf(objWithWatcher) { objWithWatcher.watcher.close(); } - var ConfigFileProgramReloadLevel, WatchLogLevel; + var ProgramUpdateLevel, WatchLogLevel; var init_watchUtilities = __esm({ "src/compiler/watchUtilities.ts"() { "use strict"; init_ts2(); - ConfigFileProgramReloadLevel = /* @__PURE__ */ ((ConfigFileProgramReloadLevel2) => { - ConfigFileProgramReloadLevel2[ConfigFileProgramReloadLevel2["None"] = 0] = "None"; - ConfigFileProgramReloadLevel2[ConfigFileProgramReloadLevel2["Partial"] = 1] = "Partial"; - ConfigFileProgramReloadLevel2[ConfigFileProgramReloadLevel2["Full"] = 2] = "Full"; - return ConfigFileProgramReloadLevel2; - })(ConfigFileProgramReloadLevel || {}); + ProgramUpdateLevel = /* @__PURE__ */ ((ProgramUpdateLevel2) => { + ProgramUpdateLevel2[ProgramUpdateLevel2["Update"] = 0] = "Update"; + ProgramUpdateLevel2[ProgramUpdateLevel2["RootNamesAndUpdate"] = 1] = "RootNamesAndUpdate"; + ProgramUpdateLevel2[ProgramUpdateLevel2["Full"] = 2] = "Full"; + ProgramUpdateLevel2[ProgramUpdateLevel2["Resolutions"] = 3] = "Resolutions"; + return ProgramUpdateLevel2; + })(ProgramUpdateLevel || {}); WatchLogLevel = /* @__PURE__ */ ((WatchLogLevel2) => { WatchLogLevel2[WatchLogLevel2["None"] = 0] = "None"; WatchLogLevel2[WatchLogLevel2["TriggerOnly"] = 1] = "TriggerOnly"; @@ -215181,7 +200602,7 @@ ${lanes.join("\n")} function formatColorAndReset(text, formatStyle) { return formatStyle + text + resetEscapeSequence; } - function formatCodeSpan(file, start, length2, indent2, squiggleColor, host) { + function formatCodeSpan(file, start, length2, indent3, squiggleColor, host) { const { line: firstLine, character: firstLineChar } = getLineAndCharacterOfPosition(file, start); const { line: lastLine, character: lastLineChar } = getLineAndCharacterOfPosition(file, start + length2); const lastLineInFile = getLineAndCharacterOfPosition(file, file.text.length).line; @@ -215194,17 +200615,17 @@ ${lanes.join("\n")} for (let i = firstLine; i <= lastLine; i++) { context += host.getNewLine(); if (hasMoreThanFiveLines && firstLine + 1 < i && i < lastLine - 1) { - context += indent2 + formatColorAndReset(padLeft(ellipsis, gutterWidth), gutterStyleSequence) + gutterSeparator + host.getNewLine(); + context += indent3 + formatColorAndReset(ellipsis.padStart(gutterWidth), gutterStyleSequence) + gutterSeparator + host.getNewLine(); i = lastLine - 1; } const lineStart = getPositionOfLineAndCharacter(file, i, 0); const lineEnd = i < lastLineInFile ? getPositionOfLineAndCharacter(file, i + 1, 0) : file.text.length; let lineContent = file.text.slice(lineStart, lineEnd); - lineContent = trimStringEnd(lineContent); + lineContent = lineContent.trimEnd(); lineContent = lineContent.replace(/\t/g, " "); - context += indent2 + formatColorAndReset(padLeft(i + 1 + "", gutterWidth), gutterStyleSequence) + gutterSeparator; + context += indent3 + formatColorAndReset((i + 1 + "").padStart(gutterWidth), gutterStyleSequence) + gutterSeparator; context += lineContent + host.getNewLine(); - context += indent2 + formatColorAndReset(padLeft("", gutterWidth), gutterStyleSequence) + gutterSeparator; + context += indent3 + formatColorAndReset("".padStart(gutterWidth), gutterStyleSequence) + gutterSeparator; context += squiggleColor; if (i === firstLine) { const lastCharForLine = i === lastLine ? lastLineChar : void 0; @@ -215261,24 +200682,24 @@ ${lanes.join("\n")} } return output; } - function flattenDiagnosticMessageText(diag2, newLine, indent2 = 0) { + function flattenDiagnosticMessageText(diag2, newLine, indent3 = 0) { if (isString(diag2)) { return diag2; } else if (diag2 === void 0) { return ""; } let result = ""; - if (indent2) { + if (indent3) { result += newLine; - for (let i = 0; i < indent2; i++) { + for (let i = 0; i < indent3; i++) { result += " "; } } result += diag2.messageText; - indent2++; + indent3++; if (diag2.next) { for (const kid of diag2.next) { - result += flattenDiagnosticMessageText(kid, newLine, indent2); + result += flattenDiagnosticMessageText(kid, newLine, indent3); } } return result; @@ -215287,8 +200708,6 @@ ${lanes.join("\n")} return (isString(ref) ? containingFileMode : ref.resolutionMode) || containingFileMode; } function getModeForResolutionAtIndex(file, index) { - if (file.impliedNodeFormat === void 0) - return void 0; return getModeForUsageLocation(file, getModuleNameStringLiteralAt(file, index)); } function isExclusivelyTypeOnlyImportOrExport(decl) { @@ -215302,42 +200721,48 @@ ${lanes.join("\n")} return false; } function getModeForUsageLocation(file, usage) { - var _a, _b; - if (file.impliedNodeFormat === void 0) - return void 0; + var _a; if (isImportDeclaration(usage.parent) || isExportDeclaration(usage.parent)) { const isTypeOnly = isExclusivelyTypeOnlyImportOrExport(usage.parent); if (isTypeOnly) { - const override = getResolutionModeOverrideForClause(usage.parent.assertClause); + const override = getResolutionModeOverride(usage.parent.attributes); if (override) { return override; } } } if (usage.parent.parent && isImportTypeNode(usage.parent.parent)) { - const override = getResolutionModeOverrideForClause((_a = usage.parent.parent.assertions) == null ? void 0 : _a.assertClause); + const override = getResolutionModeOverride(usage.parent.parent.attributes); if (override) { return override; } } + if (file.impliedNodeFormat === void 0) + return void 0; if (file.impliedNodeFormat !== 99 /* ESNext */) { return isImportCall(walkUpParenthesizedExpressions(usage.parent)) ? 99 /* ESNext */ : 1 /* CommonJS */; } - const exprParentParent = (_b = walkUpParenthesizedExpressions(usage.parent)) == null ? void 0 : _b.parent; + const exprParentParent = (_a = walkUpParenthesizedExpressions(usage.parent)) == null ? void 0 : _a.parent; return exprParentParent && isImportEqualsDeclaration(exprParentParent) ? 1 /* CommonJS */ : 99 /* ESNext */; } - function getResolutionModeOverrideForClause(clause, grammarErrorOnNode) { - if (!clause) + function getResolutionModeOverride(node, grammarErrorOnNode) { + if (!node) return void 0; - if (length(clause.elements) !== 1) { - grammarErrorOnNode == null ? void 0 : grammarErrorOnNode(clause, Diagnostics.Type_import_assertions_should_have_exactly_one_key_resolution_mode_with_value_import_or_require); + if (length(node.elements) !== 1) { + grammarErrorOnNode == null ? void 0 : grammarErrorOnNode( + node, + node.token === 118 /* WithKeyword */ ? Diagnostics.Type_import_attributes_should_have_exactly_one_key_resolution_mode_with_value_import_or_require : Diagnostics.Type_import_assertions_should_have_exactly_one_key_resolution_mode_with_value_import_or_require + ); return void 0; } - const elem = clause.elements[0]; + const elem = node.elements[0]; if (!isStringLiteralLike(elem.name)) return void 0; if (elem.name.text !== "resolution-mode") { - grammarErrorOnNode == null ? void 0 : grammarErrorOnNode(elem.name, Diagnostics.resolution_mode_is_the_only_valid_key_for_type_import_assertions); + grammarErrorOnNode == null ? void 0 : grammarErrorOnNode( + elem.name, + node.token === 118 /* WithKeyword */ ? Diagnostics.resolution_mode_is_the_only_valid_key_for_type_import_attributes : Diagnostics.resolution_mode_is_the_only_valid_key_for_type_import_assertions + ); return void 0; } if (!isStringLiteralLike(elem.value)) @@ -215467,15 +200892,15 @@ ${lanes.join("\n")} function isReferenceFileLocation(location) { return location.pos !== void 0; } - function getReferencedFileLocation(getSourceFileByPath, ref) { - var _a, _b, _c, _d, _e, _f; - const file = Debug.checkDefined(getSourceFileByPath(ref.file)); + function getReferencedFileLocation(program, ref) { + var _a, _b, _c, _d; + const file = Debug.checkDefined(program.getSourceFileByPath(ref.file)); const { kind, index } = ref; let pos, end, packageId, resolutionMode; switch (kind) { case 3 /* Import */: const importLiteral = getModuleNameStringLiteralAt(file, index); - packageId = (_c = (_b = (_a = file.resolvedModules) == null ? void 0 : _a.get(importLiteral.text, getModeForResolutionAtIndex(file, index))) == null ? void 0 : _b.resolvedModule) == null ? void 0 : _c.packageId; + packageId = (_b = (_a = program.getResolvedModule(file, importLiteral.text, getModeForResolutionAtIndex(file, index))) == null ? void 0 : _a.resolvedModule) == null ? void 0 : _b.packageId; if (importLiteral.pos === -1) return { file, packageId, text: importLiteral.text }; pos = skipTrivia(file.text, importLiteral.pos); @@ -215486,7 +200911,7 @@ ${lanes.join("\n")} break; case 5 /* TypeReferenceDirective */: ({ pos, end, resolutionMode } = file.typeReferenceDirectives[index]); - packageId = (_f = (_e = (_d = file.resolvedTypeReferenceDirectiveNames) == null ? void 0 : _d.get(toFileNameLowerCase(file.typeReferenceDirectives[index].fileName), resolutionMode || file.impliedNodeFormat)) == null ? void 0 : _e.resolvedTypeReferenceDirective) == null ? void 0 : _f.packageId; + packageId = (_d = (_c = program.getResolvedTypeReferenceDirective(file, toFileNameLowerCase(file.typeReferenceDirectives[index].fileName), resolutionMode || file.impliedNodeFormat)) == null ? void 0 : _c.resolvedTypeReferenceDirective) == null ? void 0 : _d.packageId; break; case 7 /* LibReferenceDirective */: ({ pos, end } = file.libReferenceDirectives[index]); @@ -215607,6 +201032,10 @@ ${lanes.join("\n")} let automaticTypeDirectiveResolutions; let resolvedLibReferences; let resolvedLibProcessing; + let resolvedModules; + let resolvedModulesProcessing; + let resolvedTypeReferenceDirectiveNames; + let resolvedTypeReferenceDirectiveNamesProcessing; let packageMap; const maxNodeModuleJsDepth = typeof options.maxNodeModuleJsDepth === "number" ? options.maxNodeModuleJsDepth : 0; let currentNodeModulesDepth = 0; @@ -215682,7 +201111,8 @@ ${lanes.join("\n")} getCanonicalFileName, /*options*/ void 0, - moduleResolutionCache == null ? void 0 : moduleResolutionCache.getPackageJsonInfoCache() + moduleResolutionCache == null ? void 0 : moduleResolutionCache.getPackageJsonInfoCache(), + moduleResolutionCache == null ? void 0 : moduleResolutionCache.optionsToRedirectsKey ); actualResolveTypeReferenceDirectiveNamesWorker = (typeDirectiveNames, containingFile, redirectedReference, options2, containingSourceFile) => loadWithModeAwareCache( typeDirectiveNames, @@ -215870,6 +201300,8 @@ ${lanes.join("\n")} } oldProgram = void 0; resolvedLibProcessing = void 0; + resolvedModulesProcessing = void 0; + resolvedTypeReferenceDirectiveNamesProcessing = void 0; const program = { getRootFileNames: () => rootNames, getSourceFile, @@ -215911,7 +201343,13 @@ ${lanes.join("\n")} sourceFileToPackageName, redirectTargetsMap, usesUriStyleNodeCoreModules, + resolvedModules, + resolvedTypeReferenceDirectiveNames, resolvedLibReferences, + getResolvedModule, + getResolvedTypeReferenceDirective, + forEachResolvedModule, + forEachResolvedTypeReferenceDirective, getCurrentPackagesMap: () => packageMap, typesPackageExists, packageBundlesTypes, @@ -215942,7 +201380,7 @@ ${lanes.join("\n")} case 1 /* FilePreprocessingFileExplainingDiagnostic */: return programDiagnostics.add(createDiagnosticExplainingFile(diagnostic.file && getSourceFileByPath(diagnostic.file), diagnostic.fileProcessingReason, diagnostic.diagnostic, diagnostic.args || emptyArray)); case 0 /* FilePreprocessingReferencedDiagnostic */: - const { file, pos, end } = getReferencedFileLocation(getSourceFileByPath, diagnostic.reason); + const { file, pos, end } = getReferencedFileLocation(program, diagnostic.reason); return programDiagnostics.add(createFileDiagnostic(file, Debug.checkDefined(pos), Debug.checkDefined(end) - pos, diagnostic.diagnostic, ...diagnostic.args || emptyArray)); case 2 /* ResolutionDiagnostics */: return diagnostic.diagnostics.forEach((d) => programDiagnostics.add(d)); @@ -215955,17 +201393,34 @@ ${lanes.join("\n")} measure("Program", "beforeProgram", "afterProgram"); (_p = tracing) == null ? void 0 : _p.pop(); return program; + function getResolvedModule(file, moduleName, mode) { + var _a2; + return (_a2 = resolvedModules == null ? void 0 : resolvedModules.get(file.path)) == null ? void 0 : _a2.get(moduleName, mode); + } + function getResolvedTypeReferenceDirective(file, typeDirectiveName, mode) { + var _a2; + return (_a2 = resolvedTypeReferenceDirectiveNames == null ? void 0 : resolvedTypeReferenceDirectiveNames.get(file.path)) == null ? void 0 : _a2.get(typeDirectiveName, mode); + } + function forEachResolvedModule(callback, file) { + forEachResolution(resolvedModules, callback, file); + } + function forEachResolvedTypeReferenceDirective(callback, file) { + forEachResolution(resolvedTypeReferenceDirectiveNames, callback, file); + } + function forEachResolution(resolutionCache, callback, file) { + var _a2; + if (file) + (_a2 = resolutionCache == null ? void 0 : resolutionCache.get(file.path)) == null ? void 0 : _a2.forEach((resolution, name, mode) => callback(resolution, name, mode, file.path)); + else + resolutionCache == null ? void 0 : resolutionCache.forEach((resolutions, filePath) => resolutions.forEach((resolution, name, mode) => callback(resolution, name, mode, filePath))); + } function getPackagesMap() { if (packageMap) return packageMap; packageMap = /* @__PURE__ */ new Map(); - files.forEach((sf) => { - if (!sf.resolvedModules) - return; - sf.resolvedModules.forEach(({ resolvedModule }) => { - if (resolvedModule == null ? void 0 : resolvedModule.packageId) - packageMap.set(resolvedModule.packageId.name, resolvedModule.extension === ".d.ts" /* Dts */ || !!packageMap.get(resolvedModule.packageId.name)); - }); + forEachResolvedModule(({ resolvedModule }) => { + if (resolvedModule == null ? void 0 : resolvedModule.packageId) + packageMap.set(resolvedModule.packageId.name, resolvedModule.extension === ".d.ts" /* Dts */ || !!packageMap.get(resolvedModule.packageId.name)); }); return packageMap; } @@ -216032,7 +201487,7 @@ ${lanes.join("\n")} const resultFromDts = getRedirectReferenceForResolutionFromSourceOfProject(file.path); if (resultFromDts) return resultFromDts; - if (!host.realpath || !options.preserveSymlinks || !stringContains(file.originalFileName, nodeModulesPathPart)) + if (!host.realpath || !options.preserveSymlinks || !file.originalFileName.includes(nodeModulesPathPart)) return void 0; const realDeclarationPath = toPath3(host.realpath(file.originalFileName)); return realDeclarationPath === file.path ? void 0 : getRedirectReferenceForResolutionFromSourceOfProject(realDeclarationPath); @@ -216098,7 +201553,6 @@ ${lanes.join("\n")} return classifiableNames; } function resolveModuleNamesReusingOldState(moduleNames, file) { - var _a2; if (structureIsReused === 0 /* Not */ && !file.ambientModuleNames.length) { return resolveModuleNamesWorker( moduleNames, @@ -216107,24 +201561,16 @@ ${lanes.join("\n")} void 0 ); } - const oldSourceFile = oldProgram && oldProgram.getSourceFile(file.fileName); - if (oldSourceFile !== file && file.resolvedModules) { - const result2 = []; - for (const moduleName of moduleNames) { - const resolvedModule = file.resolvedModules.get(moduleName.text, getModeForUsageLocation(file, moduleName)); - result2.push(resolvedModule); - } - return result2; - } let unknownModuleNames; let result; let reusedNames; const predictedToResolveToAmbientModuleMarker = emptyResolution; + const oldSourceFile = oldProgram && oldProgram.getSourceFile(file.fileName); for (let i = 0; i < moduleNames.length; i++) { const moduleName = moduleNames[i]; - if (file === oldSourceFile && !hasInvalidatedResolutions(oldSourceFile.path)) { + if (file === oldSourceFile && !hasInvalidatedResolutions(file.path)) { const mode = getModeForUsageLocation(file, moduleName); - const oldResolution = (_a2 = oldSourceFile.resolvedModules) == null ? void 0 : _a2.get(moduleName.text, mode); + const oldResolution = oldProgram == null ? void 0 : oldProgram.getResolvedModule(file, moduleName.text, mode); if (oldResolution == null ? void 0 : oldResolution.resolvedModule) { if (isTraceEnabled(options, host)) { trace( @@ -216171,7 +201617,8 @@ ${lanes.join("\n")} Debug.assert(j === resolutions.length); return result; function moduleNameResolvesToAmbientModuleInNonModifiedFile(moduleName) { - const resolutionToFile = getResolvedModule(oldSourceFile, moduleName.text, getModeForUsageLocation(file, moduleName)); + var _a2; + const resolutionToFile = (_a2 = oldProgram == null ? void 0 : oldProgram.getResolvedModule(file, moduleName.text, getModeForUsageLocation(file, moduleName))) == null ? void 0 : _a2.resolvedModule; const resolvedFile = resolutionToFile && oldProgram.getSourceFile(resolutionToFile.resolvedFileName); if (resolutionToFile && resolvedFile) { return false; @@ -216196,28 +201643,18 @@ ${lanes.join("\n")} void 0 ); } - const oldSourceFile = !isString(containingFile) ? oldProgram && oldProgram.getSourceFile(containingFile.fileName) : void 0; - if (!isString(containingFile)) { - if (oldSourceFile !== containingFile && containingFile.resolvedTypeReferenceDirectiveNames) { - const result2 = []; - for (const typeDirectiveName of typeDirectiveNames) { - const resolvedTypeReferenceDirective = containingFile.resolvedTypeReferenceDirectiveNames.get(getTypeReferenceResolutionName(typeDirectiveName), getModeForFileReference(typeDirectiveName, containingFile.impliedNodeFormat)); - result2.push(resolvedTypeReferenceDirective); - } - return result2; - } - } let unknownTypeReferenceDirectiveNames; let result; let reusedNames; const containingSourceFile = !isString(containingFile) ? containingFile : void 0; - const canReuseResolutions = !isString(containingFile) ? containingFile === oldSourceFile && !hasInvalidatedResolutions(oldSourceFile.path) : !hasInvalidatedResolutions(toPath3(containingFile)); + const oldSourceFile = !isString(containingFile) ? oldProgram && oldProgram.getSourceFile(containingFile.fileName) : void 0; + const canReuseResolutions = !isString(containingFile) ? containingFile === oldSourceFile && !hasInvalidatedResolutions(containingFile.path) : !hasInvalidatedResolutions(toPath3(containingFile)); for (let i = 0; i < typeDirectiveNames.length; i++) { const entry = typeDirectiveNames[i]; if (canReuseResolutions) { const typeDirectiveName = getTypeReferenceResolutionName(entry); const mode = getModeForFileReference(entry, containingSourceFile == null ? void 0 : containingSourceFile.impliedNodeFormat); - const oldResolution = (_a2 = !isString(containingFile) ? oldSourceFile == null ? void 0 : oldSourceFile.resolvedTypeReferenceDirectiveNames : oldProgram == null ? void 0 : oldProgram.getAutomaticTypeDirectiveResolutions()) == null ? void 0 : _a2.get(typeDirectiveName, mode); + const oldResolution = !isString(containingFile) ? oldProgram == null ? void 0 : oldProgram.getResolvedTypeReferenceDirective(containingFile, typeDirectiveName, mode) : (_a2 = oldProgram == null ? void 0 : oldProgram.getAutomaticTypeDirectiveResolutions()) == null ? void 0 : _a2.get(typeDirectiveName, mode); if (oldResolution == null ? void 0 : oldResolution.resolvedTypeReferenceDirective) { if (isTraceEnabled(options, host)) { trace( @@ -216316,13 +201753,13 @@ ${lanes.join("\n")} sourceFileOptions, /*onError*/ void 0, - shouldCreateNewSourceFile || sourceFileOptions.impliedNodeFormat !== oldSourceFile.impliedNodeFormat + shouldCreateNewSourceFile ) : host.getSourceFile( oldSourceFile.fileName, sourceFileOptions, /*onError*/ void 0, - shouldCreateNewSourceFile || sourceFileOptions.impliedNodeFormat !== oldSourceFile.impliedNodeFormat + shouldCreateNewSourceFile ); if (!newSourceFile) { return 0 /* Not */; @@ -216373,49 +201810,53 @@ ${lanes.join("\n")} structureIsReused = 1 /* SafeModules */; } else if (!arrayIsEqualTo(oldSourceFile.moduleAugmentations, newSourceFile.moduleAugmentations, moduleNameIsEqualTo)) { structureIsReused = 1 /* SafeModules */; - } else if ((oldSourceFile.flags & 6291456 /* PermanentlySetIncrementalFlags */) !== (newSourceFile.flags & 6291456 /* PermanentlySetIncrementalFlags */)) { + } else if ((oldSourceFile.flags & 12582912 /* PermanentlySetIncrementalFlags */) !== (newSourceFile.flags & 12582912 /* PermanentlySetIncrementalFlags */)) { structureIsReused = 1 /* SafeModules */; } else if (!arrayIsEqualTo(oldSourceFile.typeReferenceDirectives, newSourceFile.typeReferenceDirectives, fileReferenceIsEqualTo)) { structureIsReused = 1 /* SafeModules */; } } - modifiedSourceFiles.push({ oldFile: oldSourceFile, newFile: newSourceFile }); + modifiedSourceFiles.push(newSourceFile); } else if (hasInvalidatedResolutions(oldSourceFile.path)) { structureIsReused = 1 /* SafeModules */; - modifiedSourceFiles.push({ oldFile: oldSourceFile, newFile: newSourceFile }); + modifiedSourceFiles.push(newSourceFile); + } else { + for (const moduleName of oldSourceFile.ambientModuleNames) { + ambientModuleNameToUnmodifiedFileName.set(moduleName, oldSourceFile.fileName); + } } newSourceFiles.push(newSourceFile); } if (structureIsReused !== 2 /* Completely */) { return structureIsReused; } - const modifiedFiles = modifiedSourceFiles.map((f) => f.oldFile); - for (const oldFile of oldSourceFiles) { - if (!contains(modifiedFiles, oldFile)) { - for (const moduleName of oldFile.ambientModuleNames) { - ambientModuleNameToUnmodifiedFileName.set(moduleName, oldFile.fileName); - } - } - } - for (const { oldFile: oldSourceFile, newFile: newSourceFile } of modifiedSourceFiles) { + for (const newSourceFile of modifiedSourceFiles) { const moduleNames = getModuleNames(newSourceFile); const resolutions = resolveModuleNamesReusingOldState(moduleNames, newSourceFile); - const resolutionsChanged = hasChangesInResolutions(moduleNames, newSourceFile, resolutions, oldSourceFile.resolvedModules, moduleResolutionIsEqualTo, moduleResolutionNameAndModeGetter); - if (resolutionsChanged) { + (resolvedModulesProcessing ?? (resolvedModulesProcessing = /* @__PURE__ */ new Map())).set(newSourceFile.path, resolutions); + const resolutionsChanged = hasChangesInResolutions( + moduleNames, + newSourceFile, + resolutions, + (name, mode) => oldProgram.getResolvedModule(newSourceFile, name, mode), + moduleResolutionIsEqualTo, + moduleResolutionNameAndModeGetter + ); + if (resolutionsChanged) structureIsReused = 1 /* SafeModules */; - newSourceFile.resolvedModules = zipToModeAwareCache(newSourceFile, moduleNames, resolutions, moduleResolutionNameAndModeGetter); - } else { - newSourceFile.resolvedModules = oldSourceFile.resolvedModules; - } const typesReferenceDirectives = newSourceFile.typeReferenceDirectives; const typeReferenceResolutions = resolveTypeReferenceDirectiveNamesReusingOldState(typesReferenceDirectives, newSourceFile); - const typeReferenceResolutionsChanged = hasChangesInResolutions(typesReferenceDirectives, newSourceFile, typeReferenceResolutions, oldSourceFile.resolvedTypeReferenceDirectiveNames, typeDirectiveIsEqualTo, typeReferenceResolutionNameAndModeGetter); - if (typeReferenceResolutionsChanged) { + (resolvedTypeReferenceDirectiveNamesProcessing ?? (resolvedTypeReferenceDirectiveNamesProcessing = /* @__PURE__ */ new Map())).set(newSourceFile.path, typeReferenceResolutions); + const typeReferenceResolutionsChanged = hasChangesInResolutions( + typesReferenceDirectives, + newSourceFile, + typeReferenceResolutions, + (name, mode) => oldProgram == null ? void 0 : oldProgram.getResolvedTypeReferenceDirective(newSourceFile, name, mode), + typeDirectiveIsEqualTo, + typeReferenceResolutionNameAndModeGetter + ); + if (typeReferenceResolutionsChanged) structureIsReused = 1 /* SafeModules */; - newSourceFile.resolvedTypeReferenceDirectiveNames = zipToModeAwareCache(newSourceFile, typesReferenceDirectives, typeReferenceResolutions, typeReferenceResolutionNameAndModeGetter); - } else { - newSourceFile.resolvedTypeReferenceDirectiveNames = oldSourceFile.resolvedTypeReferenceDirectiveNames; - } } if (structureIsReused !== 2 /* Completely */) { return structureIsReused; @@ -216462,6 +201903,8 @@ ${lanes.join("\n")} sourceFileToPackageName = oldProgram.sourceFileToPackageName; redirectTargetsMap = oldProgram.redirectTargetsMap; usesUriStyleNodeCoreModules = oldProgram.usesUriStyleNodeCoreModules; + resolvedModules = oldProgram.resolvedModules; + resolvedTypeReferenceDirectiveNames = oldProgram.resolvedTypeReferenceDirectiveNames; resolvedLibReferences = oldProgram.resolvedLibReferences; packageMap = oldProgram.getCurrentPackagesMap(); return 2 /* Completely */; @@ -216764,89 +202207,97 @@ ${lanes.join("\n")} return diagnostics; function walk(node, parent2) { switch (parent2.kind) { - case 168 /* Parameter */: - case 171 /* PropertyDeclaration */: - case 173 /* MethodDeclaration */: + case 169 /* Parameter */: + case 172 /* PropertyDeclaration */: + case 174 /* MethodDeclaration */: if (parent2.questionToken === node) { diagnostics.push(createDiagnosticForNode2(node, Diagnostics.The_0_modifier_can_only_be_used_in_TypeScript_files, "?")); return "skip"; } - case 172 /* MethodSignature */: - case 175 /* Constructor */: - case 176 /* GetAccessor */: - case 177 /* SetAccessor */: - case 217 /* FunctionExpression */: - case 261 /* FunctionDeclaration */: - case 218 /* ArrowFunction */: - case 259 /* VariableDeclaration */: + case 173 /* MethodSignature */: + case 176 /* Constructor */: + case 177 /* GetAccessor */: + case 178 /* SetAccessor */: + case 218 /* FunctionExpression */: + case 262 /* FunctionDeclaration */: + case 219 /* ArrowFunction */: + case 260 /* VariableDeclaration */: if (parent2.type === node) { diagnostics.push(createDiagnosticForNode2(node, Diagnostics.Type_annotations_can_only_be_used_in_TypeScript_files)); return "skip"; } } switch (node.kind) { - case 272 /* ImportClause */: + case 273 /* ImportClause */: if (node.isTypeOnly) { diagnostics.push(createDiagnosticForNode2(parent2, Diagnostics._0_declarations_can_only_be_used_in_TypeScript_files, "import type")); return "skip"; } break; - case 277 /* ExportDeclaration */: + case 278 /* ExportDeclaration */: if (node.isTypeOnly) { diagnostics.push(createDiagnosticForNode2(node, Diagnostics._0_declarations_can_only_be_used_in_TypeScript_files, "export type")); return "skip"; } break; - case 275 /* ImportSpecifier */: - case 280 /* ExportSpecifier */: + case 276 /* ImportSpecifier */: + case 281 /* ExportSpecifier */: if (node.isTypeOnly) { diagnostics.push(createDiagnosticForNode2(node, Diagnostics._0_declarations_can_only_be_used_in_TypeScript_files, isImportSpecifier(node) ? "import...type" : "export...type")); return "skip"; } break; - case 270 /* ImportEqualsDeclaration */: + case 271 /* ImportEqualsDeclaration */: diagnostics.push(createDiagnosticForNode2(node, Diagnostics.import_can_only_be_used_in_TypeScript_files)); return "skip"; - case 276 /* ExportAssignment */: + case 277 /* ExportAssignment */: if (node.isExportEquals) { diagnostics.push(createDiagnosticForNode2(node, Diagnostics.export_can_only_be_used_in_TypeScript_files)); return "skip"; } break; - case 297 /* HeritageClause */: + case 298 /* HeritageClause */: const heritageClause = node; if (heritageClause.token === 119 /* ImplementsKeyword */) { diagnostics.push(createDiagnosticForNode2(node, Diagnostics.implements_clauses_can_only_be_used_in_TypeScript_files)); return "skip"; } break; - case 263 /* InterfaceDeclaration */: + case 264 /* InterfaceDeclaration */: const interfaceKeyword = tokenToString(120 /* InterfaceKeyword */); Debug.assertIsDefined(interfaceKeyword); diagnostics.push(createDiagnosticForNode2(node, Diagnostics._0_declarations_can_only_be_used_in_TypeScript_files, interfaceKeyword)); return "skip"; - case 266 /* ModuleDeclaration */: - const moduleKeyword = node.flags & 16 /* Namespace */ ? tokenToString(145 /* NamespaceKeyword */) : tokenToString(144 /* ModuleKeyword */); + case 267 /* ModuleDeclaration */: + const moduleKeyword = node.flags & 32 /* Namespace */ ? tokenToString(145 /* NamespaceKeyword */) : tokenToString(144 /* ModuleKeyword */); Debug.assertIsDefined(moduleKeyword); diagnostics.push(createDiagnosticForNode2(node, Diagnostics._0_declarations_can_only_be_used_in_TypeScript_files, moduleKeyword)); return "skip"; - case 264 /* TypeAliasDeclaration */: + case 265 /* TypeAliasDeclaration */: diagnostics.push(createDiagnosticForNode2(node, Diagnostics.Type_aliases_can_only_be_used_in_TypeScript_files)); return "skip"; - case 265 /* EnumDeclaration */: + case 176 /* Constructor */: + case 174 /* MethodDeclaration */: + case 262 /* FunctionDeclaration */: + if (!node.body) { + diagnostics.push(createDiagnosticForNode2(node, Diagnostics.Signature_declarations_can_only_be_used_in_TypeScript_files)); + return "skip"; + } + return; + case 266 /* EnumDeclaration */: const enumKeyword = Debug.checkDefined(tokenToString(94 /* EnumKeyword */)); diagnostics.push(createDiagnosticForNode2(node, Diagnostics._0_declarations_can_only_be_used_in_TypeScript_files, enumKeyword)); return "skip"; - case 234 /* NonNullExpression */: + case 235 /* NonNullExpression */: diagnostics.push(createDiagnosticForNode2(node, Diagnostics.Non_null_assertions_can_only_be_used_in_TypeScript_files)); return "skip"; - case 233 /* AsExpression */: + case 234 /* AsExpression */: diagnostics.push(createDiagnosticForNode2(node.type, Diagnostics.Type_assertion_expressions_can_only_be_used_in_TypeScript_files)); return "skip"; - case 237 /* SatisfiesExpression */: + case 238 /* SatisfiesExpression */: diagnostics.push(createDiagnosticForNode2(node.type, Diagnostics.Type_satisfaction_expressions_can_only_be_used_in_TypeScript_files)); return "skip"; - case 215 /* TypeAssertionExpression */: + case 216 /* TypeAssertionExpression */: Debug.fail(); } } @@ -216881,26 +202332,26 @@ ${lanes.join("\n")} } } switch (parent2.kind) { - case 262 /* ClassDeclaration */: - case 230 /* ClassExpression */: - case 173 /* MethodDeclaration */: - case 175 /* Constructor */: - case 176 /* GetAccessor */: - case 177 /* SetAccessor */: - case 217 /* FunctionExpression */: - case 261 /* FunctionDeclaration */: - case 218 /* ArrowFunction */: + case 263 /* ClassDeclaration */: + case 231 /* ClassExpression */: + case 174 /* MethodDeclaration */: + case 176 /* Constructor */: + case 177 /* GetAccessor */: + case 178 /* SetAccessor */: + case 218 /* FunctionExpression */: + case 262 /* FunctionDeclaration */: + case 219 /* ArrowFunction */: if (nodes === parent2.typeParameters) { diagnostics.push(createDiagnosticForNodeArray2(nodes, Diagnostics.Type_parameter_declarations_can_only_be_used_in_TypeScript_files)); return "skip"; } - case 242 /* VariableStatement */: + case 243 /* VariableStatement */: if (nodes === parent2.modifiers) { - checkModifiers(parent2.modifiers, parent2.kind === 242 /* VariableStatement */); + checkModifiers(parent2.modifiers, parent2.kind === 243 /* VariableStatement */); return "skip"; } break; - case 171 /* PropertyDeclaration */: + case 172 /* PropertyDeclaration */: if (nodes === parent2.modifiers) { for (const modifier of nodes) { if (isModifier(modifier) && modifier.kind !== 126 /* StaticKeyword */ && modifier.kind !== 129 /* AccessorKeyword */) { @@ -216910,18 +202361,18 @@ ${lanes.join("\n")} return "skip"; } break; - case 168 /* Parameter */: + case 169 /* Parameter */: if (nodes === parent2.modifiers && some(nodes, isModifier)) { diagnostics.push(createDiagnosticForNodeArray2(nodes, Diagnostics.Parameter_modifiers_can_only_be_used_in_TypeScript_files)); return "skip"; } break; - case 212 /* CallExpression */: - case 213 /* NewExpression */: - case 232 /* ExpressionWithTypeArguments */: - case 284 /* JsxSelfClosingElement */: - case 285 /* JsxOpeningElement */: - case 214 /* TaggedTemplateExpression */: + case 213 /* CallExpression */: + case 214 /* NewExpression */: + case 233 /* ExpressionWithTypeArguments */: + case 285 /* JsxSelfClosingElement */: + case 286 /* JsxOpeningElement */: + case 215 /* TaggedTemplateExpression */: if (nodes === parent2.typeArguments) { diagnostics.push(createDiagnosticForNodeArray2(nodes, Diagnostics.Type_arguments_can_only_be_used_in_TypeScript_files)); return "skip"; @@ -216942,7 +202393,7 @@ ${lanes.join("\n")} case 148 /* ReadonlyKeyword */: case 138 /* DeclareKeyword */: case 128 /* AbstractKeyword */: - case 163 /* OverrideKeyword */: + case 164 /* OverrideKeyword */: case 103 /* InKeyword */: case 147 /* OutKeyword */: diagnostics.push(createDiagnosticForNode2(modifier, Diagnostics.The_0_modifier_can_only_be_used_in_TypeScript_files, tokenToString(modifier.kind))); @@ -217034,14 +202485,14 @@ ${lanes.join("\n")} /*importClause*/ void 0, externalHelpersModuleReference, - /*assertClause*/ + /*attributes*/ void 0 ); addInternalEmitFlags(importDecl, 2 /* NeverApplyImportHelper */); setParent(externalHelpersModuleReference, importDecl); setParent(importDecl, file); - externalHelpersModuleReference.flags &= ~8 /* Synthesized */; - importDecl.flags &= ~8 /* Synthesized */; + externalHelpersModuleReference.flags &= ~16 /* Synthesized */; + importDecl.flags &= ~16 /* Synthesized */; return externalHelpersModuleReference; } function collectExternalModuleReferences(file) { @@ -217070,7 +202521,7 @@ ${lanes.join("\n")} ); } const shouldProcessRequires = isJavaScriptFile && shouldResolveJsRequire(options); - if (file.flags & 2097152 /* PossiblyContainsDynamicImport */ || shouldProcessRequires) { + if (file.flags & 4194304 /* PossiblyContainsDynamicImport */ || shouldProcessRequires) { collectDynamicImportOrRequireCalls(file); } file.imports = imports || emptyArray; @@ -217092,7 +202543,7 @@ ${lanes.join("\n")} } } } else if (isModuleDeclaration(node)) { - if (isAmbientModule(node) && (inAmbientModule || hasSyntacticModifier(node, 2 /* Ambient */) || file.isDeclarationFile)) { + if (isAmbientModule(node) && (inAmbientModule || hasSyntacticModifier(node, 128 /* Ambient */) || file.isDeclarationFile)) { node.name.parent = node; const nameText = getTextOfIdentifierOrLiteral(node.name); if (isExternalModuleFile || inAmbientModule && !isExternalModuleNameRelative(nameText)) { @@ -217275,14 +202726,14 @@ ${lanes.join("\n")} const result = getImpliedNodeFormatForFileWorker(getNormalizedAbsolutePath(fileName, currentDirectory), moduleResolutionCache2 == null ? void 0 : moduleResolutionCache2.getPackageJsonInfoCache(), host2, options2); const languageVersion = getEmitScriptTarget(options2); const setExternalModuleIndicator2 = getSetExternalModuleIndicator(options2); - return typeof result === "object" ? { ...result, languageVersion, setExternalModuleIndicator: setExternalModuleIndicator2 } : { languageVersion, impliedNodeFormat: result, setExternalModuleIndicator: setExternalModuleIndicator2 }; + return typeof result === "object" ? { ...result, languageVersion, setExternalModuleIndicator: setExternalModuleIndicator2, jsDocParsingMode: host2.jsDocParsingMode } : { languageVersion, impliedNodeFormat: result, setExternalModuleIndicator: setExternalModuleIndicator2, jsDocParsingMode: host2.jsDocParsingMode }; } function findSourceFileWorker(fileName, isDefaultLib, ignoreNoDefaultLib, reason, packageId) { - var _a2, _b2; + var _a2; const path = toPath3(fileName); if (useSourceOfProjectReferenceRedirect) { let source = getSourceOfProjectReferenceRedirect(path); - if (!source && host.realpath && options.preserveSymlinks && isDeclarationFileName(fileName) && stringContains(fileName, nodeModulesPathPart)) { + if (!source && host.realpath && options.preserveSymlinks && isDeclarationFileName(fileName) && fileName.includes(nodeModulesPathPart)) { const realPath2 = toPath3(host.realpath(fileName)); if (realPath2 !== path) source = getSourceOfProjectReferenceRedirect(realPath2); @@ -217357,7 +202808,7 @@ ${lanes.join("\n")} Diagnostics.Cannot_read_file_0_Colon_1, [fileName, hostErrorMessage] ), - shouldCreateNewSourceFile || ((_a2 = oldProgram == null ? void 0 : oldProgram.getSourceFileByPath(toPath3(fileName))) == null ? void 0 : _a2.impliedNodeFormat) !== sourceFileOptions.impliedNodeFormat + shouldCreateNewSourceFile ); if (packageId) { const packageIdKey = packageIdToString(packageId); @@ -217382,7 +202833,7 @@ ${lanes.join("\n")} file.path = path; file.resolvedPath = toPath3(fileName); file.originalFileName = originalFileName; - file.packageJsonLocations = ((_b2 = sourceFileOptions.packageJsonLocations) == null ? void 0 : _b2.length) ? sourceFileOptions.packageJsonLocations : void 0; + file.packageJsonLocations = ((_a2 = sourceFileOptions.packageJsonLocations) == null ? void 0 : _a2.length) ? sourceFileOptions.packageJsonLocations : void 0; file.packageJsonScope = sourceFileOptions.packageJsonScope; addFileIncludeReason(file, reason); if (host.useCaseSensitiveFileNames()) { @@ -217499,25 +202950,17 @@ ${lanes.join("\n")} } function processTypeReferenceDirectives(file) { const typeDirectives = file.typeReferenceDirectives; - if (!typeDirectives.length) { - file.resolvedTypeReferenceDirectiveNames = void 0; + if (!typeDirectives.length) return; - } - const resolutions = resolveTypeReferenceDirectiveNamesReusingOldState(typeDirectives, file); + const resolutions = (resolvedTypeReferenceDirectiveNamesProcessing == null ? void 0 : resolvedTypeReferenceDirectiveNamesProcessing.get(file.path)) || resolveTypeReferenceDirectiveNamesReusingOldState(typeDirectives, file); + const resolutionsInFile = createModeAwareCache(); + (resolvedTypeReferenceDirectiveNames ?? (resolvedTypeReferenceDirectiveNames = /* @__PURE__ */ new Map())).set(file.path, resolutionsInFile); for (let index = 0; index < typeDirectives.length; index++) { const ref = file.typeReferenceDirectives[index]; const resolvedTypeReferenceDirective = resolutions[index]; const fileName = toFileNameLowerCase(ref.fileName); - setResolvedTypeReferenceDirective(file, fileName, resolvedTypeReferenceDirective, getModeForFileReference(ref, file.impliedNodeFormat)); + resolutionsInFile.set(fileName, getModeForFileReference(ref, file.impliedNodeFormat), resolvedTypeReferenceDirective); const mode = ref.resolutionMode || file.impliedNodeFormat; - if (mode && getEmitModuleResolutionKind(options) !== 3 /* Node16 */ && getEmitModuleResolutionKind(options) !== 99 /* NodeNext */) { - (fileProcessingDiagnostics ?? (fileProcessingDiagnostics = [])).push({ - kind: 2 /* ResolutionDiagnostics */, - diagnostics: [ - createDiagnosticForRange(file, ref, Diagnostics.resolution_mode_assertions_are_only_supported_when_moduleResolution_is_node16_or_nodenext) - ] - }); - } processTypeReferenceDirective(fileName, mode, resolvedTypeReferenceDirective, { kind: 5 /* TypeReferenceDirective */, file: file.path, index }); } } @@ -217672,14 +203115,16 @@ ${lanes.join("\n")} collectExternalModuleReferences(file); if (file.imports.length || file.moduleAugmentations.length) { const moduleNames = getModuleNames(file); - const resolutions = resolveModuleNamesReusingOldState(moduleNames, file); + const resolutions = (resolvedModulesProcessing == null ? void 0 : resolvedModulesProcessing.get(file.path)) || resolveModuleNamesReusingOldState(moduleNames, file); Debug.assert(resolutions.length === moduleNames.length); const optionsForFile = (useSourceOfProjectReferenceRedirect ? (_a2 = getRedirectReferenceForResolution(file)) == null ? void 0 : _a2.commandLine.options : void 0) || options; + const resolutionsInFile = createModeAwareCache(); + (resolvedModules ?? (resolvedModules = /* @__PURE__ */ new Map())).set(file.path, resolutionsInFile); for (let index = 0; index < moduleNames.length; index++) { const resolution = resolutions[index].resolvedModule; const moduleName = moduleNames[index].text; const mode = getModeForUsageLocation(file, moduleNames[index]); - setResolvedModule(file, moduleName, resolutions[index], mode); + resolutionsInFile.set(moduleName, mode, resolutions[index]); addResolutionDiagnosticsFromResolutionOrCache(file, moduleName, resolutions[index], mode); if (!resolution) { continue; @@ -217692,7 +203137,7 @@ ${lanes.join("\n")} currentNodeModulesDepth++; } const elideImport = isJsFileFromNodeModules && currentNodeModulesDepth > maxNodeModuleJsDepth; - const shouldAddFile = resolvedFileName && !getResolutionDiagnostic(optionsForFile, resolution, file) && !optionsForFile.noResolve && index < file.imports.length && !elideImport && !(isJsFile && !getAllowJSCompilerOption(optionsForFile)) && (isInJSFile(file.imports[index]) || !(file.imports[index].flags & 8388608 /* JSDoc */)); + const shouldAddFile = resolvedFileName && !getResolutionDiagnostic(optionsForFile, resolution, file) && !optionsForFile.noResolve && index < file.imports.length && !elideImport && !(isJsFile && !getAllowJSCompilerOption(optionsForFile)) && (isInJSFile(file.imports[index]) || !(file.imports[index].flags & 16777216 /* JSDoc */)); if (elideImport) { modulesWithElidedImports.set(file.path, true); } else if (shouldAddFile) { @@ -217710,8 +203155,6 @@ ${lanes.join("\n")} currentNodeModulesDepth--; } } - } else { - file.resolvedModules = void 0; } } function checkSourceFilesBelongToPath(sourceFiles, rootDirectory) { @@ -218051,6 +203494,13 @@ ${lanes.join("\n")} if (moduleResolution === 100 /* Bundler */ && !emitModuleKindIsNonNodeESM(moduleKind)) { createOptionValueDiagnostic("moduleResolution", Diagnostics.Option_0_can_only_be_used_when_module_is_set_to_es2015_or_later, "bundler"); } + if (ModuleKind[moduleKind] && (100 /* Node16 */ <= moduleKind && moduleKind <= 199 /* NodeNext */) && !(3 /* Node16 */ <= moduleResolution && moduleResolution <= 99 /* NodeNext */)) { + const moduleKindName = ModuleKind[moduleKind]; + createOptionValueDiagnostic("moduleResolution", Diagnostics.Option_moduleResolution_must_be_set_to_0_or_left_unspecified_when_option_module_is_set_to_1, moduleKindName, moduleKindName); + } else if (ModuleResolutionKind[moduleResolution] && (3 /* Node16 */ <= moduleResolution && moduleResolution <= 99 /* NodeNext */) && !(100 /* Node16 */ <= moduleKind && moduleKind <= 199 /* NodeNext */)) { + const moduleResolutionName = ModuleResolutionKind[moduleResolution]; + createOptionValueDiagnostic("module", Diagnostics.Option_module_must_be_set_to_0_when_option_moduleResolution_is_set_to_1, moduleResolutionName, moduleResolutionName); + } if (!options.noEmit && !options.suppressOutputPathCheck) { const emitHost = getEmitHost(); const emitFilesSeen = /* @__PURE__ */ new Set(); @@ -218219,7 +203669,7 @@ ${lanes.join("\n")} processReason(fileProcessingReason); if (locationReason && (fileIncludeReasons == null ? void 0 : fileIncludeReasons.length) === 1) fileIncludeReasons = void 0; - const location = locationReason && getReferencedFileLocation(getSourceFileByPath, locationReason); + const location = locationReason && getReferencedFileLocation(program, locationReason); const fileIncludeReasonDetails = fileIncludeReasons && chainDiagnosticMessages(fileIncludeReasons, Diagnostics.The_file_is_in_the_program_because_Colon); const redirectInfo = file && explainIfFileIsRedirectAndImpliedFormat(file); const chain = chainDiagnosticMessages(redirectInfo ? fileIncludeReasonDetails ? [fileIncludeReasonDetails, ...redirectInfo] : redirectInfo : fileIncludeReasonDetails, diagnostic, ...args || emptyArray); @@ -218255,7 +203705,7 @@ ${lanes.join("\n")} } function fileIncludeReasonToRelatedInformation(reason) { if (isReferencedFile(reason)) { - const referenceLocation = getReferencedFileLocation(getSourceFileByPath, reason); + const referenceLocation = getReferencedFileLocation(program, reason); let message2; switch (reason.kind) { case 3 /* Import */: @@ -218304,19 +203754,11 @@ ${lanes.join("\n")} case 1 /* SourceFromProjectReference */: case 2 /* OutputFromProjectReference */: const referencedResolvedRef = Debug.checkDefined(resolvedProjectReferences == null ? void 0 : resolvedProjectReferences[reason.index]); - const referenceInfo = forEachProjectReference( - projectReferences, - resolvedProjectReferences, - (resolvedRef, parent2, index2) => resolvedRef === referencedResolvedRef ? { sourceFile: (parent2 == null ? void 0 : parent2.sourceFile) || options.configFile, index: index2 } : void 0 - ); + const referenceInfo = forEachProjectReference(projectReferences, resolvedProjectReferences, (resolvedRef, parent2, index2) => resolvedRef === referencedResolvedRef ? { sourceFile: (parent2 == null ? void 0 : parent2.sourceFile) || options.configFile, index: index2 } : void 0); if (!referenceInfo) return void 0; const { sourceFile, index } = referenceInfo; - const referencesSyntax = forEachTsConfigPropArray( - sourceFile, - "references", - (property) => isArrayLiteralExpression(property.initializer) ? property.initializer : void 0 - ); + const referencesSyntax = forEachTsConfigPropArray(sourceFile, "references", (property) => isArrayLiteralExpression(property.initializer) ? property.initializer : void 0); return referencesSyntax && referencesSyntax.elements.length > index ? createDiagnosticForNodeInSourceFile( sourceFile, referencesSyntax.elements[index], @@ -218456,11 +203898,7 @@ ${lanes.join("\n")} ); } function createDiagnosticForReference(sourceFile, index, message, ...args) { - const referencesSyntax = forEachTsConfigPropArray( - sourceFile || options.configFile, - "references", - (property) => isArrayLiteralExpression(property.initializer) ? property.initializer : void 0 - ); + const referencesSyntax = forEachTsConfigPropArray(sourceFile || options.configFile, "references", (property) => isArrayLiteralExpression(property.initializer) ? property.initializer : void 0); if (referencesSyntax && referencesSyntax.elements.length > index) { programDiagnostics.add(createDiagnosticForNodeInSourceFile(sourceFile || options.configFile, referencesSyntax.elements[index], message, ...args)); } else { @@ -218556,8 +203994,8 @@ ${lanes.join("\n")} if (!symlinks) { symlinks = createSymlinkCache(currentDirectory, getCanonicalFileName); } - if (files && automaticTypeDirectiveResolutions && !symlinks.hasProcessedResolutions()) { - symlinks.setSymlinksFromResolutions(files, automaticTypeDirectiveResolutions); + if (files && !symlinks.hasProcessedResolutions()) { + symlinks.setSymlinksFromResolutions(forEachResolvedModule, forEachResolvedTypeReferenceDirective, automaticTypeDirectiveResolutions); } return symlinks; } @@ -218647,7 +204085,7 @@ ${lanes.join("\n")} var _a; if (!host.getResolvedProjectReferences() || containsIgnoredPath(directory)) return; - if (!originalRealpath || !stringContains(directory, nodeModulesPathPart)) + if (!originalRealpath || !directory.includes(nodeModulesPathPart)) return; const symlinkCache = host.getSymlinkCache(); const directoryPath = ensureTrailingDirectorySeparator(host.toPath(directory)); @@ -218675,7 +204113,7 @@ ${lanes.join("\n")} if (!symlinkedDirectories) return false; const fileOrDirectoryPath = host.toPath(fileOrDirectory); - if (!stringContains(fileOrDirectoryPath, nodeModulesPathPart)) + if (!fileOrDirectoryPath.includes(nodeModulesPathPart)) return false; if (isFile && ((_a = symlinkCache.getSymlinkedFiles()) == null ? void 0 : _a.has(fileOrDirectoryPath))) return true; @@ -218740,6 +204178,9 @@ ${lanes.join("\n")} return directoryStructureHost.readDirectory(root, extensions, excludes, includes, depth); }, readFile: (f) => directoryStructureHost.readFile(f), + directoryExists: maybeBind(directoryStructureHost, directoryStructureHost.directoryExists), + getDirectories: maybeBind(directoryStructureHost, directoryStructureHost.getDirectories), + realpath: maybeBind(directoryStructureHost, directoryStructureHost.realpath), useCaseSensitiveFileNames: host.useCaseSensitiveFileNames(), getCurrentDirectory: () => host.getCurrentDirectory(), onUnRecoverableConfigFileDiagnostic: host.onUnRecoverableConfigFileDiagnostic || returnUndefined, @@ -218915,8 +204356,8 @@ ${lanes.join("\n")} Diagnostics.Classes_may_not_have_a_field_named_constructor.code, Diagnostics.Did_you_mean_to_use_a_Colon_An_can_only_follow_a_property_name_when_the_containing_object_literal_is_part_of_a_destructuring_pattern.code, Diagnostics.Duplicate_label_0.code, - Diagnostics.Dynamic_imports_can_only_accept_a_module_specifier_and_an_optional_assertion_as_arguments.code, - Diagnostics.For_await_loops_cannot_be_used_inside_a_class_static_block.code, + Diagnostics.Dynamic_imports_can_only_accept_a_module_specifier_and_an_optional_set_of_attributes_as_arguments.code, + Diagnostics.for_await_loops_cannot_be_used_inside_a_class_static_block.code, Diagnostics.JSX_attributes_must_only_be_assigned_a_non_empty_expression.code, Diagnostics.JSX_elements_cannot_have_multiple_attributes_with_the_same_name.code, Diagnostics.JSX_expressions_may_not_use_the_comma_operator_Did_you_mean_to_write_an_array.code, @@ -218946,14 +204387,17 @@ ${lanes.join("\n")} Diagnostics._0_modifier_cannot_appear_on_class_elements_of_this_kind.code, Diagnostics._0_modifier_cannot_be_used_here.code, Diagnostics._0_modifier_must_precede_1_modifier.code, - Diagnostics.const_declarations_can_only_be_declared_inside_a_block.code, - Diagnostics.const_declarations_must_be_initialized.code, + Diagnostics._0_declarations_can_only_be_declared_inside_a_block.code, + Diagnostics._0_declarations_must_be_initialized.code, Diagnostics.extends_clause_already_seen.code, - Diagnostics.let_declarations_can_only_be_declared_inside_a_block.code, Diagnostics.let_is_not_allowed_to_be_used_as_a_name_in_let_or_const_declarations.code, Diagnostics.Class_constructor_may_not_be_a_generator.code, Diagnostics.Class_constructor_may_not_be_an_accessor.code, - Diagnostics.await_expressions_are_only_allowed_within_async_functions_and_at_the_top_levels_of_modules.code + Diagnostics.await_expressions_are_only_allowed_within_async_functions_and_at_the_top_levels_of_modules.code, + Diagnostics.await_using_statements_are_only_allowed_within_async_functions_and_at_the_top_levels_of_modules.code, + Diagnostics.Private_field_0_must_be_declared_in_an_enclosing_class.code, + // Type errors + Diagnostics.This_condition_will_always_return_0_since_JavaScript_compares_objects_by_reference_not_value.code ]); emitSkippedWithNoDiagnostics = { diagnostics: emptyArray, sourceMaps: void 0, emittedFiles: void 0, emitSkipped: true }; } @@ -219071,16 +204515,14 @@ ${lanes.join("\n")} addReferencedFile(referencedPath); } } - if (sourceFile.resolvedTypeReferenceDirectiveNames) { - sourceFile.resolvedTypeReferenceDirectiveNames.forEach(({ resolvedTypeReferenceDirective }) => { - if (!resolvedTypeReferenceDirective) { - return; - } - const fileName = resolvedTypeReferenceDirective.resolvedFileName; - const typeFilePath = getReferencedFileFromFileName(program, fileName, sourceFileDirectory, getCanonicalFileName); - addReferencedFile(typeFilePath); - }); - } + program.forEachResolvedTypeReferenceDirective(({ resolvedTypeReferenceDirective }) => { + if (!resolvedTypeReferenceDirective) { + return; + } + const fileName = resolvedTypeReferenceDirective.resolvedFileName; + const typeFilePath = getReferencedFileFromFileName(program, fileName, sourceFileDirectory, getCanonicalFileName); + addReferencedFile(typeFilePath); + }, sourceFile); if (sourceFile.moduleAugmentations.length) { const checker = program.getTypeChecker(); for (const moduleName of sourceFile.moduleAugmentations) { @@ -219199,13 +204641,16 @@ ${lanes.join("\n")} sourceFile, (fileName, text, _writeByteOrderMark, _onError, sourceFiles, data) => { Debug.assert(isDeclarationFileName(fileName), `File extension for signature expected to be dts: Got:: ${fileName}`); - onNewSignature(computeSignatureWithDiagnostics( - programOfThisState, - sourceFile, - text, - host, - data - ), sourceFiles); + onNewSignature( + computeSignatureWithDiagnostics( + programOfThisState, + sourceFile, + text, + host, + data + ), + sourceFiles + ); }, cancellationToken, /*emitOnly*/ @@ -219261,29460 +204706,32734 @@ ${lanes.join("\n")} state.exportedModulesMap.deleteKey(sourceFile.resolvedPath); } } - BuilderState2.updateExportedModules = updateExportedModules; - function getExportedModules(exportedModulesFromDeclarationEmit) { - let exportedModules; - exportedModulesFromDeclarationEmit == null ? void 0 : exportedModulesFromDeclarationEmit.forEach( - (symbol) => getReferencedFilesFromImportedModuleSymbol(symbol).forEach( - (path) => (exportedModules ?? (exportedModules = /* @__PURE__ */ new Set())).add(path) + BuilderState2.updateExportedModules = updateExportedModules; + function getExportedModules(exportedModulesFromDeclarationEmit) { + let exportedModules; + exportedModulesFromDeclarationEmit == null ? void 0 : exportedModulesFromDeclarationEmit.forEach( + (symbol) => getReferencedFilesFromImportedModuleSymbol(symbol).forEach( + (path) => (exportedModules ?? (exportedModules = /* @__PURE__ */ new Set())).add(path) + ) + ); + return exportedModules; + } + BuilderState2.getExportedModules = getExportedModules; + function getAllDependencies(state, programOfThisState, sourceFile) { + const compilerOptions = programOfThisState.getCompilerOptions(); + if (outFile(compilerOptions)) { + return getAllFileNames(state, programOfThisState); + } + if (!state.referencedMap || isFileAffectingGlobalScope(sourceFile)) { + return getAllFileNames(state, programOfThisState); + } + const seenMap = /* @__PURE__ */ new Set(); + const queue = [sourceFile.resolvedPath]; + while (queue.length) { + const path = queue.pop(); + if (!seenMap.has(path)) { + seenMap.add(path); + const references = state.referencedMap.getValues(path); + if (references) { + for (const key of references.keys()) { + queue.push(key); + } + } + } + } + return arrayFrom(mapDefinedIterator(seenMap.keys(), (path) => { + var _a; + return ((_a = programOfThisState.getSourceFileByPath(path)) == null ? void 0 : _a.fileName) ?? path; + })); + } + BuilderState2.getAllDependencies = getAllDependencies; + function getAllFileNames(state, programOfThisState) { + if (!state.allFileNames) { + const sourceFiles = programOfThisState.getSourceFiles(); + state.allFileNames = sourceFiles === emptyArray ? emptyArray : sourceFiles.map((file) => file.fileName); + } + return state.allFileNames; + } + function getReferencedByPaths(state, referencedFilePath) { + const keys = state.referencedMap.getKeys(referencedFilePath); + return keys ? arrayFrom(keys.keys()) : []; + } + BuilderState2.getReferencedByPaths = getReferencedByPaths; + function containsOnlyAmbientModules(sourceFile) { + for (const statement of sourceFile.statements) { + if (!isModuleWithStringLiteralName(statement)) { + return false; + } + } + return true; + } + function containsGlobalScopeAugmentation(sourceFile) { + return some(sourceFile.moduleAugmentations, (augmentation) => isGlobalScopeAugmentation(augmentation.parent)); + } + function isFileAffectingGlobalScope(sourceFile) { + return containsGlobalScopeAugmentation(sourceFile) || !isExternalOrCommonJsModule(sourceFile) && !isJsonSourceFile(sourceFile) && !containsOnlyAmbientModules(sourceFile); + } + function getAllFilesExcludingDefaultLibraryFile(state, programOfThisState, firstSourceFile) { + if (state.allFilesExcludingDefaultLibraryFile) { + return state.allFilesExcludingDefaultLibraryFile; + } + let result; + if (firstSourceFile) + addSourceFile(firstSourceFile); + for (const sourceFile of programOfThisState.getSourceFiles()) { + if (sourceFile !== firstSourceFile) { + addSourceFile(sourceFile); + } + } + state.allFilesExcludingDefaultLibraryFile = result || emptyArray; + return state.allFilesExcludingDefaultLibraryFile; + function addSourceFile(sourceFile) { + if (!programOfThisState.isSourceFileDefaultLibrary(sourceFile)) { + (result || (result = [])).push(sourceFile); + } + } + } + BuilderState2.getAllFilesExcludingDefaultLibraryFile = getAllFilesExcludingDefaultLibraryFile; + function getFilesAffectedByUpdatedShapeWhenNonModuleEmit(state, programOfThisState, sourceFileWithUpdatedShape) { + const compilerOptions = programOfThisState.getCompilerOptions(); + if (compilerOptions && outFile(compilerOptions)) { + return [sourceFileWithUpdatedShape]; + } + return getAllFilesExcludingDefaultLibraryFile(state, programOfThisState, sourceFileWithUpdatedShape); + } + function getFilesAffectedByUpdatedShapeWhenModuleEmit(state, programOfThisState, sourceFileWithUpdatedShape, cancellationToken, host) { + if (isFileAffectingGlobalScope(sourceFileWithUpdatedShape)) { + return getAllFilesExcludingDefaultLibraryFile(state, programOfThisState, sourceFileWithUpdatedShape); + } + const compilerOptions = programOfThisState.getCompilerOptions(); + if (compilerOptions && (getIsolatedModules(compilerOptions) || outFile(compilerOptions))) { + return [sourceFileWithUpdatedShape]; + } + const seenFileNamesMap = /* @__PURE__ */ new Map(); + seenFileNamesMap.set(sourceFileWithUpdatedShape.resolvedPath, sourceFileWithUpdatedShape); + const queue = getReferencedByPaths(state, sourceFileWithUpdatedShape.resolvedPath); + while (queue.length > 0) { + const currentPath = queue.pop(); + if (!seenFileNamesMap.has(currentPath)) { + const currentSourceFile = programOfThisState.getSourceFileByPath(currentPath); + seenFileNamesMap.set(currentPath, currentSourceFile); + if (currentSourceFile && updateShapeSignature(state, programOfThisState, currentSourceFile, cancellationToken, host)) { + queue.push(...getReferencedByPaths(state, currentSourceFile.resolvedPath)); + } + } + } + return arrayFrom(mapDefinedIterator(seenFileNamesMap.values(), (value) => value)); + } + })(BuilderState || (BuilderState = {})); + } + }); + + // src/compiler/builder.ts + function getBuilderFileEmit(options) { + let result = 1 /* Js */; + if (options.sourceMap) + result = result | 2 /* JsMap */; + if (options.inlineSourceMap) + result = result | 4 /* JsInlineMap */; + if (getEmitDeclarations(options)) + result = result | 8 /* Dts */; + if (options.declarationMap) + result = result | 16 /* DtsMap */; + if (options.emitDeclarationOnly) + result = result & 24 /* AllDts */; + return result; + } + function getPendingEmitKind(optionsOrEmitKind, oldOptionsOrEmitKind) { + const oldEmitKind = oldOptionsOrEmitKind && (isNumber(oldOptionsOrEmitKind) ? oldOptionsOrEmitKind : getBuilderFileEmit(oldOptionsOrEmitKind)); + const emitKind = isNumber(optionsOrEmitKind) ? optionsOrEmitKind : getBuilderFileEmit(optionsOrEmitKind); + if (oldEmitKind === emitKind) + return 0 /* None */; + if (!oldEmitKind || !emitKind) + return emitKind; + const diff = oldEmitKind ^ emitKind; + let result = 0 /* None */; + if (diff & 7 /* AllJs */) + result = emitKind & 7 /* AllJs */; + if (diff & 24 /* AllDts */) + result = result | emitKind & 24 /* AllDts */; + return result; + } + function hasSameKeys(map1, map2) { + return map1 === map2 || map1 !== void 0 && map2 !== void 0 && map1.size === map2.size && !forEachKey(map1, (key) => !map2.has(key)); + } + function createBuilderProgramState(newProgram, oldState) { + var _a, _b; + const state = BuilderState.create( + newProgram, + oldState, + /*disableUseFileVersionAsSignature*/ + false + ); + state.program = newProgram; + const compilerOptions = newProgram.getCompilerOptions(); + state.compilerOptions = compilerOptions; + const outFilePath = outFile(compilerOptions); + if (!outFilePath) { + state.semanticDiagnosticsPerFile = /* @__PURE__ */ new Map(); + } else if (compilerOptions.composite && (oldState == null ? void 0 : oldState.outSignature) && outFilePath === outFile(oldState == null ? void 0 : oldState.compilerOptions)) { + state.outSignature = oldState.outSignature && getEmitSignatureFromOldSignature(compilerOptions, oldState.compilerOptions, oldState.outSignature); + } + state.changedFilesSet = /* @__PURE__ */ new Set(); + state.latestChangedDtsFile = compilerOptions.composite ? oldState == null ? void 0 : oldState.latestChangedDtsFile : void 0; + const useOldState = BuilderState.canReuseOldState(state.referencedMap, oldState); + const oldCompilerOptions = useOldState ? oldState.compilerOptions : void 0; + const canCopySemanticDiagnostics = useOldState && oldState.semanticDiagnosticsPerFile && !!state.semanticDiagnosticsPerFile && !compilerOptionsAffectSemanticDiagnostics(compilerOptions, oldCompilerOptions); + const canCopyEmitSignatures = compilerOptions.composite && (oldState == null ? void 0 : oldState.emitSignatures) && !outFilePath && !compilerOptionsAffectDeclarationPath(compilerOptions, oldState.compilerOptions); + if (useOldState) { + (_a = oldState.changedFilesSet) == null ? void 0 : _a.forEach((value) => state.changedFilesSet.add(value)); + if (!outFilePath && ((_b = oldState.affectedFilesPendingEmit) == null ? void 0 : _b.size)) { + state.affectedFilesPendingEmit = new Map(oldState.affectedFilesPendingEmit); + state.seenAffectedFiles = /* @__PURE__ */ new Set(); + } + state.programEmitPending = oldState.programEmitPending; + } else { + state.buildInfoEmitPending = true; + } + const referencedMap = state.referencedMap; + const oldReferencedMap = useOldState ? oldState.referencedMap : void 0; + const copyDeclarationFileDiagnostics = canCopySemanticDiagnostics && !compilerOptions.skipLibCheck === !oldCompilerOptions.skipLibCheck; + const copyLibFileDiagnostics = copyDeclarationFileDiagnostics && !compilerOptions.skipDefaultLibCheck === !oldCompilerOptions.skipDefaultLibCheck; + state.fileInfos.forEach((info, sourceFilePath) => { + let oldInfo; + let newReferences; + if (!useOldState || // File wasn't present in old state + !(oldInfo = oldState.fileInfos.get(sourceFilePath)) || // versions dont match + oldInfo.version !== info.version || // Implied formats dont match + oldInfo.impliedFormat !== info.impliedFormat || // Referenced files changed + !hasSameKeys(newReferences = referencedMap && referencedMap.getValues(sourceFilePath), oldReferencedMap && oldReferencedMap.getValues(sourceFilePath)) || // Referenced file was deleted in the new program + newReferences && forEachKey(newReferences, (path) => !state.fileInfos.has(path) && oldState.fileInfos.has(path))) { + addFileToChangeSet(state, sourceFilePath); + } else if (canCopySemanticDiagnostics) { + const sourceFile = newProgram.getSourceFileByPath(sourceFilePath); + if (sourceFile.isDeclarationFile && !copyDeclarationFileDiagnostics) + return; + if (sourceFile.hasNoDefaultLib && !copyLibFileDiagnostics) + return; + const diagnostics = oldState.semanticDiagnosticsPerFile.get(sourceFilePath); + if (diagnostics) { + state.semanticDiagnosticsPerFile.set( + sourceFilePath, + oldState.hasReusableDiagnostic ? convertToDiagnostics(diagnostics, newProgram) : repopulateDiagnostics(diagnostics, newProgram) + ); + if (!state.semanticDiagnosticsFromOldState) { + state.semanticDiagnosticsFromOldState = /* @__PURE__ */ new Set(); + } + state.semanticDiagnosticsFromOldState.add(sourceFilePath); + } + } + if (canCopyEmitSignatures) { + const oldEmitSignature = oldState.emitSignatures.get(sourceFilePath); + if (oldEmitSignature) { + (state.emitSignatures ?? (state.emitSignatures = /* @__PURE__ */ new Map())).set(sourceFilePath, getEmitSignatureFromOldSignature(compilerOptions, oldState.compilerOptions, oldEmitSignature)); + } + } + }); + if (useOldState && forEachEntry(oldState.fileInfos, (info, sourceFilePath) => { + if (state.fileInfos.has(sourceFilePath)) + return false; + if (outFilePath || info.affectsGlobalScope) + return true; + state.buildInfoEmitPending = true; + return false; + })) { + BuilderState.getAllFilesExcludingDefaultLibraryFile( + state, + newProgram, + /*firstSourceFile*/ + void 0 + ).forEach((file) => addFileToChangeSet(state, file.resolvedPath)); + } else if (oldCompilerOptions) { + const pendingEmitKind = compilerOptionsAffectEmit(compilerOptions, oldCompilerOptions) ? getBuilderFileEmit(compilerOptions) : getPendingEmitKind(compilerOptions, oldCompilerOptions); + if (pendingEmitKind !== 0 /* None */) { + if (!outFilePath) { + newProgram.getSourceFiles().forEach((f) => { + if (!state.changedFilesSet.has(f.resolvedPath)) { + addToAffectedFilesPendingEmit( + state, + f.resolvedPath, + pendingEmitKind + ); + } + }); + Debug.assert(!state.seenAffectedFiles || !state.seenAffectedFiles.size); + state.seenAffectedFiles = state.seenAffectedFiles || /* @__PURE__ */ new Set(); + state.buildInfoEmitPending = true; + } else { + state.programEmitPending = state.programEmitPending ? state.programEmitPending | pendingEmitKind : pendingEmitKind; + } + } + } + if (outFilePath && !state.changedFilesSet.size) { + if (useOldState) + state.bundle = oldState.bundle; + if (some(newProgram.getProjectReferences(), (ref) => !!ref.prepend)) + state.programEmitPending = getBuilderFileEmit(compilerOptions); + } + return state; + } + function addFileToChangeSet(state, path) { + state.changedFilesSet.add(path); + state.buildInfoEmitPending = true; + state.programEmitPending = void 0; + } + function getEmitSignatureFromOldSignature(options, oldOptions, oldEmitSignature) { + return !!options.declarationMap === !!oldOptions.declarationMap ? ( + // Use same format of signature + oldEmitSignature + ) : ( + // Convert to different format + isString(oldEmitSignature) ? [oldEmitSignature] : oldEmitSignature[0] + ); + } + function repopulateDiagnostics(diagnostics, newProgram) { + if (!diagnostics.length) + return diagnostics; + return sameMap(diagnostics, (diag2) => { + if (isString(diag2.messageText)) + return diag2; + const repopulatedChain = convertOrRepopulateDiagnosticMessageChain(diag2.messageText, diag2.file, newProgram, (chain) => { + var _a; + return (_a = chain.repopulateInfo) == null ? void 0 : _a.call(chain); + }); + return repopulatedChain === diag2.messageText ? diag2 : { ...diag2, messageText: repopulatedChain }; + }); + } + function convertOrRepopulateDiagnosticMessageChain(chain, sourceFile, newProgram, repopulateInfo) { + const info = repopulateInfo(chain); + if (info) { + return { + ...createModuleNotFoundChain(sourceFile, newProgram, info.moduleReference, info.mode, info.packageName || info.moduleReference), + next: convertOrRepopulateDiagnosticMessageChainArray(chain.next, sourceFile, newProgram, repopulateInfo) + }; + } + const next = convertOrRepopulateDiagnosticMessageChainArray(chain.next, sourceFile, newProgram, repopulateInfo); + return next === chain.next ? chain : { ...chain, next }; + } + function convertOrRepopulateDiagnosticMessageChainArray(array, sourceFile, newProgram, repopulateInfo) { + return sameMap(array, (chain) => convertOrRepopulateDiagnosticMessageChain(chain, sourceFile, newProgram, repopulateInfo)); + } + function convertToDiagnostics(diagnostics, newProgram) { + if (!diagnostics.length) + return emptyArray; + let buildInfoDirectory; + return diagnostics.map((diagnostic) => { + const result = convertToDiagnosticRelatedInformation(diagnostic, newProgram, toPathInBuildInfoDirectory); + result.reportsUnnecessary = diagnostic.reportsUnnecessary; + result.reportsDeprecated = diagnostic.reportDeprecated; + result.source = diagnostic.source; + result.skippedOn = diagnostic.skippedOn; + const { relatedInformation } = diagnostic; + result.relatedInformation = relatedInformation ? relatedInformation.length ? relatedInformation.map((r) => convertToDiagnosticRelatedInformation(r, newProgram, toPathInBuildInfoDirectory)) : [] : void 0; + return result; + }); + function toPathInBuildInfoDirectory(path) { + buildInfoDirectory ?? (buildInfoDirectory = getDirectoryPath(getNormalizedAbsolutePath(getTsBuildInfoEmitOutputFilePath(newProgram.getCompilerOptions()), newProgram.getCurrentDirectory()))); + return toPath(path, buildInfoDirectory, newProgram.getCanonicalFileName); + } + } + function convertToDiagnosticRelatedInformation(diagnostic, newProgram, toPath3) { + const { file } = diagnostic; + const sourceFile = file ? newProgram.getSourceFileByPath(toPath3(file)) : void 0; + return { + ...diagnostic, + file: sourceFile, + messageText: isString(diagnostic.messageText) ? diagnostic.messageText : convertOrRepopulateDiagnosticMessageChain(diagnostic.messageText, sourceFile, newProgram, (chain) => chain.info) + }; + } + function releaseCache(state) { + BuilderState.releaseCache(state); + state.program = void 0; + } + function backupBuilderProgramEmitState(state) { + const outFilePath = outFile(state.compilerOptions); + Debug.assert(!state.changedFilesSet.size || outFilePath); + return { + affectedFilesPendingEmit: state.affectedFilesPendingEmit && new Map(state.affectedFilesPendingEmit), + seenEmittedFiles: state.seenEmittedFiles && new Map(state.seenEmittedFiles), + programEmitPending: state.programEmitPending, + emitSignatures: state.emitSignatures && new Map(state.emitSignatures), + outSignature: state.outSignature, + latestChangedDtsFile: state.latestChangedDtsFile, + hasChangedEmitSignature: state.hasChangedEmitSignature, + changedFilesSet: outFilePath ? new Set(state.changedFilesSet) : void 0 + }; + } + function restoreBuilderProgramEmitState(state, savedEmitState) { + state.affectedFilesPendingEmit = savedEmitState.affectedFilesPendingEmit; + state.seenEmittedFiles = savedEmitState.seenEmittedFiles; + state.programEmitPending = savedEmitState.programEmitPending; + state.emitSignatures = savedEmitState.emitSignatures; + state.outSignature = savedEmitState.outSignature; + state.latestChangedDtsFile = savedEmitState.latestChangedDtsFile; + state.hasChangedEmitSignature = savedEmitState.hasChangedEmitSignature; + if (savedEmitState.changedFilesSet) + state.changedFilesSet = savedEmitState.changedFilesSet; + } + function assertSourceFileOkWithoutNextAffectedCall(state, sourceFile) { + Debug.assert(!sourceFile || !state.affectedFiles || state.affectedFiles[state.affectedFilesIndex - 1] !== sourceFile || !state.semanticDiagnosticsPerFile.has(sourceFile.resolvedPath)); + } + function getNextAffectedFile(state, cancellationToken, host) { + var _a, _b; + while (true) { + const { affectedFiles } = state; + if (affectedFiles) { + const seenAffectedFiles = state.seenAffectedFiles; + let affectedFilesIndex = state.affectedFilesIndex; + while (affectedFilesIndex < affectedFiles.length) { + const affectedFile = affectedFiles[affectedFilesIndex]; + if (!seenAffectedFiles.has(affectedFile.resolvedPath)) { + state.affectedFilesIndex = affectedFilesIndex; + addToAffectedFilesPendingEmit(state, affectedFile.resolvedPath, getBuilderFileEmit(state.compilerOptions)); + handleDtsMayChangeOfAffectedFile( + state, + affectedFile, + cancellationToken, + host + ); + return affectedFile; + } + affectedFilesIndex++; + } + state.changedFilesSet.delete(state.currentChangedFilePath); + state.currentChangedFilePath = void 0; + (_a = state.oldSignatures) == null ? void 0 : _a.clear(); + (_b = state.oldExportedModulesMap) == null ? void 0 : _b.clear(); + state.affectedFiles = void 0; + } + const nextKey = state.changedFilesSet.keys().next(); + if (nextKey.done) { + return void 0; + } + const program = Debug.checkDefined(state.program); + const compilerOptions = program.getCompilerOptions(); + if (outFile(compilerOptions)) { + Debug.assert(!state.semanticDiagnosticsPerFile); + return program; + } + state.affectedFiles = BuilderState.getFilesAffectedByWithOldState( + state, + program, + nextKey.value, + cancellationToken, + host + ); + state.currentChangedFilePath = nextKey.value; + state.affectedFilesIndex = 0; + if (!state.seenAffectedFiles) + state.seenAffectedFiles = /* @__PURE__ */ new Set(); + } + } + function clearAffectedFilesPendingEmit(state, emitOnlyDtsFiles) { + var _a; + if (!((_a = state.affectedFilesPendingEmit) == null ? void 0 : _a.size)) + return; + if (!emitOnlyDtsFiles) + return state.affectedFilesPendingEmit = void 0; + state.affectedFilesPendingEmit.forEach((emitKind, path) => { + const pending = emitKind & 7 /* AllJs */; + if (!pending) + state.affectedFilesPendingEmit.delete(path); + else + state.affectedFilesPendingEmit.set(path, pending); + }); + } + function getNextAffectedFilePendingEmit(state, emitOnlyDtsFiles) { + var _a; + if (!((_a = state.affectedFilesPendingEmit) == null ? void 0 : _a.size)) + return void 0; + return forEachEntry(state.affectedFilesPendingEmit, (emitKind, path) => { + var _a2; + const affectedFile = state.program.getSourceFileByPath(path); + if (!affectedFile || !sourceFileMayBeEmitted(affectedFile, state.program)) { + state.affectedFilesPendingEmit.delete(path); + return void 0; + } + const seenKind = (_a2 = state.seenEmittedFiles) == null ? void 0 : _a2.get(affectedFile.resolvedPath); + let pendingKind = getPendingEmitKind(emitKind, seenKind); + if (emitOnlyDtsFiles) + pendingKind = pendingKind & 24 /* AllDts */; + if (pendingKind) + return { affectedFile, emitKind: pendingKind }; + }); + } + function removeDiagnosticsOfLibraryFiles(state) { + if (!state.cleanedDiagnosticsOfLibFiles) { + state.cleanedDiagnosticsOfLibFiles = true; + const program = Debug.checkDefined(state.program); + const options = program.getCompilerOptions(); + forEach(program.getSourceFiles(), (f) => program.isSourceFileDefaultLibrary(f) && !skipTypeChecking(f, options, program) && removeSemanticDiagnosticsOf(state, f.resolvedPath)); + } + } + function handleDtsMayChangeOfAffectedFile(state, affectedFile, cancellationToken, host) { + removeSemanticDiagnosticsOf(state, affectedFile.resolvedPath); + if (state.allFilesExcludingDefaultLibraryFile === state.affectedFiles) { + removeDiagnosticsOfLibraryFiles(state); + BuilderState.updateShapeSignature( + state, + Debug.checkDefined(state.program), + affectedFile, + cancellationToken, + host + ); + return; + } + if (state.compilerOptions.assumeChangesOnlyAffectDirectDependencies) + return; + handleDtsMayChangeOfReferencingExportOfAffectedFile( + state, + affectedFile, + cancellationToken, + host + ); + } + function handleDtsMayChangeOf(state, path, cancellationToken, host) { + removeSemanticDiagnosticsOf(state, path); + if (!state.changedFilesSet.has(path)) { + const program = Debug.checkDefined(state.program); + const sourceFile = program.getSourceFileByPath(path); + if (sourceFile) { + BuilderState.updateShapeSignature( + state, + program, + sourceFile, + cancellationToken, + host, + /*useFileVersionAsSignature*/ + true + ); + if (getEmitDeclarations(state.compilerOptions)) { + addToAffectedFilesPendingEmit(state, path, state.compilerOptions.declarationMap ? 24 /* AllDts */ : 8 /* Dts */); + } + } + } + } + function removeSemanticDiagnosticsOf(state, path) { + if (!state.semanticDiagnosticsFromOldState) { + return true; + } + state.semanticDiagnosticsFromOldState.delete(path); + state.semanticDiagnosticsPerFile.delete(path); + return !state.semanticDiagnosticsFromOldState.size; + } + function isChangedSignature(state, path) { + const oldSignature = Debug.checkDefined(state.oldSignatures).get(path) || void 0; + const newSignature = Debug.checkDefined(state.fileInfos.get(path)).signature; + return newSignature !== oldSignature; + } + function handleDtsMayChangeOfGlobalScope(state, filePath, cancellationToken, host) { + var _a; + if (!((_a = state.fileInfos.get(filePath)) == null ? void 0 : _a.affectsGlobalScope)) + return false; + BuilderState.getAllFilesExcludingDefaultLibraryFile( + state, + state.program, + /*firstSourceFile*/ + void 0 + ).forEach( + (file) => handleDtsMayChangeOf( + state, + file.resolvedPath, + cancellationToken, + host + ) + ); + removeDiagnosticsOfLibraryFiles(state); + return true; + } + function handleDtsMayChangeOfReferencingExportOfAffectedFile(state, affectedFile, cancellationToken, host) { + var _a; + if (!state.exportedModulesMap || !state.changedFilesSet.has(affectedFile.resolvedPath)) + return; + if (!isChangedSignature(state, affectedFile.resolvedPath)) + return; + if (getIsolatedModules(state.compilerOptions)) { + const seenFileNamesMap = /* @__PURE__ */ new Map(); + seenFileNamesMap.set(affectedFile.resolvedPath, true); + const queue = BuilderState.getReferencedByPaths(state, affectedFile.resolvedPath); + while (queue.length > 0) { + const currentPath = queue.pop(); + if (!seenFileNamesMap.has(currentPath)) { + seenFileNamesMap.set(currentPath, true); + if (handleDtsMayChangeOfGlobalScope(state, currentPath, cancellationToken, host)) + return; + handleDtsMayChangeOf(state, currentPath, cancellationToken, host); + if (isChangedSignature(state, currentPath)) { + const currentSourceFile = Debug.checkDefined(state.program).getSourceFileByPath(currentPath); + queue.push(...BuilderState.getReferencedByPaths(state, currentSourceFile.resolvedPath)); + } + } + } + } + const seenFileAndExportsOfFile = /* @__PURE__ */ new Set(); + (_a = state.exportedModulesMap.getKeys(affectedFile.resolvedPath)) == null ? void 0 : _a.forEach((exportedFromPath) => { + if (handleDtsMayChangeOfGlobalScope(state, exportedFromPath, cancellationToken, host)) + return true; + const references = state.referencedMap.getKeys(exportedFromPath); + return references && forEachKey(references, (filePath) => handleDtsMayChangeOfFileAndExportsOfFile( + state, + filePath, + seenFileAndExportsOfFile, + cancellationToken, + host + )); + }); + } + function handleDtsMayChangeOfFileAndExportsOfFile(state, filePath, seenFileAndExportsOfFile, cancellationToken, host) { + var _a, _b; + if (!tryAddToSet(seenFileAndExportsOfFile, filePath)) + return void 0; + if (handleDtsMayChangeOfGlobalScope(state, filePath, cancellationToken, host)) + return true; + handleDtsMayChangeOf(state, filePath, cancellationToken, host); + (_a = state.exportedModulesMap.getKeys(filePath)) == null ? void 0 : _a.forEach( + (exportedFromPath) => handleDtsMayChangeOfFileAndExportsOfFile( + state, + exportedFromPath, + seenFileAndExportsOfFile, + cancellationToken, + host + ) + ); + (_b = state.referencedMap.getKeys(filePath)) == null ? void 0 : _b.forEach( + (referencingFilePath) => !seenFileAndExportsOfFile.has(referencingFilePath) && // Not already removed diagnostic file + handleDtsMayChangeOf( + // Dont add to seen since this is not yet done with the export removal + state, + referencingFilePath, + cancellationToken, + host + ) + ); + return void 0; + } + function getSemanticDiagnosticsOfFile(state, sourceFile, cancellationToken) { + return concatenate( + getBinderAndCheckerDiagnosticsOfFile(state, sourceFile, cancellationToken), + Debug.checkDefined(state.program).getProgramDiagnostics(sourceFile) + ); + } + function getBinderAndCheckerDiagnosticsOfFile(state, sourceFile, cancellationToken) { + const path = sourceFile.resolvedPath; + if (state.semanticDiagnosticsPerFile) { + const cachedDiagnostics = state.semanticDiagnosticsPerFile.get(path); + if (cachedDiagnostics) { + return filterSemanticDiagnostics(cachedDiagnostics, state.compilerOptions); + } + } + const diagnostics = Debug.checkDefined(state.program).getBindAndCheckDiagnostics(sourceFile, cancellationToken); + if (state.semanticDiagnosticsPerFile) { + state.semanticDiagnosticsPerFile.set(path, diagnostics); + } + return filterSemanticDiagnostics(diagnostics, state.compilerOptions); + } + function isProgramBundleEmitBuildInfo(info) { + return !!outFile(info.options || {}); + } + function getBuildInfo2(state, bundle) { + var _a, _b, _c; + const currentDirectory = Debug.checkDefined(state.program).getCurrentDirectory(); + const buildInfoDirectory = getDirectoryPath(getNormalizedAbsolutePath(getTsBuildInfoEmitOutputFilePath(state.compilerOptions), currentDirectory)); + const latestChangedDtsFile = state.latestChangedDtsFile ? relativeToBuildInfoEnsuringAbsolutePath(state.latestChangedDtsFile) : void 0; + const fileNames = []; + const fileNameToFileId = /* @__PURE__ */ new Map(); + const root = []; + if (outFile(state.compilerOptions)) { + const fileInfos2 = arrayFrom(state.fileInfos.entries(), ([key, value]) => { + const fileId = toFileId(key); + tryAddRoot(key, fileId); + return value.impliedFormat ? { version: value.version, impliedFormat: value.impliedFormat, signature: void 0, affectsGlobalScope: void 0 } : value.version; + }); + const program2 = { + fileNames, + fileInfos: fileInfos2, + root, + options: convertToProgramBuildInfoCompilerOptions(state.compilerOptions), + outSignature: state.outSignature, + latestChangedDtsFile, + pendingEmit: !state.programEmitPending ? void 0 : ( + // Pending is undefined or None is encoded as undefined + state.programEmitPending === getBuilderFileEmit(state.compilerOptions) ? false : ( + // Pending emit is same as deteremined by compilerOptions + state.programEmitPending + ) + ) + // Actual value + }; + const { js, dts, commonSourceDirectory, sourceFiles } = bundle; + state.bundle = bundle = { + commonSourceDirectory, + sourceFiles, + js: js || (!state.compilerOptions.emitDeclarationOnly ? (_a = state.bundle) == null ? void 0 : _a.js : void 0), + dts: dts || (getEmitDeclarations(state.compilerOptions) ? (_b = state.bundle) == null ? void 0 : _b.dts : void 0) + }; + return createBuildInfo(program2, bundle); + } + let fileIdsList; + let fileNamesToFileIdListId; + let emitSignatures; + const fileInfos = arrayFrom(state.fileInfos.entries(), ([key, value]) => { + var _a2, _b2; + const fileId = toFileId(key); + tryAddRoot(key, fileId); + Debug.assert(fileNames[fileId - 1] === relativeToBuildInfo(key)); + const oldSignature = (_a2 = state.oldSignatures) == null ? void 0 : _a2.get(key); + const actualSignature = oldSignature !== void 0 ? oldSignature || void 0 : value.signature; + if (state.compilerOptions.composite) { + const file = state.program.getSourceFileByPath(key); + if (!isJsonSourceFile(file) && sourceFileMayBeEmitted(file, state.program)) { + const emitSignature = (_b2 = state.emitSignatures) == null ? void 0 : _b2.get(key); + if (emitSignature !== actualSignature) { + (emitSignatures || (emitSignatures = [])).push( + emitSignature === void 0 ? fileId : ( + // There is no emit, encode as false + // fileId, signature: emptyArray if signature only differs in dtsMap option than our own compilerOptions otherwise EmitSignature + [fileId, !isString(emitSignature) && emitSignature[0] === actualSignature ? emptyArray : emitSignature] + ) + ); + } + } + } + return value.version === actualSignature ? value.affectsGlobalScope || value.impliedFormat ? ( + // If file version is same as signature, dont serialize signature + { version: value.version, signature: void 0, affectsGlobalScope: value.affectsGlobalScope, impliedFormat: value.impliedFormat } + ) : ( + // If file info only contains version and signature and both are same we can just write string + value.version + ) : actualSignature !== void 0 ? ( + // If signature is not same as version, encode signature in the fileInfo + oldSignature === void 0 ? ( + // If we havent computed signature, use fileInfo as is + value + ) : ( + // Serialize fileInfo with new updated signature + { version: value.version, signature: actualSignature, affectsGlobalScope: value.affectsGlobalScope, impliedFormat: value.impliedFormat } + ) + ) : ( + // Signature of the FileInfo is undefined, serialize it as false + { version: value.version, signature: false, affectsGlobalScope: value.affectsGlobalScope, impliedFormat: value.impliedFormat } + ); + }); + let referencedMap; + if (state.referencedMap) { + referencedMap = arrayFrom(state.referencedMap.keys()).sort(compareStringsCaseSensitive).map((key) => [ + toFileId(key), + toFileIdListId(state.referencedMap.getValues(key)) + ]); + } + let exportedModulesMap; + if (state.exportedModulesMap) { + exportedModulesMap = mapDefined(arrayFrom(state.exportedModulesMap.keys()).sort(compareStringsCaseSensitive), (key) => { + var _a2; + const oldValue = (_a2 = state.oldExportedModulesMap) == null ? void 0 : _a2.get(key); + if (oldValue === void 0) + return [toFileId(key), toFileIdListId(state.exportedModulesMap.getValues(key))]; + if (oldValue) + return [toFileId(key), toFileIdListId(oldValue)]; + return void 0; + }); + } + let semanticDiagnosticsPerFile; + if (state.semanticDiagnosticsPerFile) { + for (const key of arrayFrom(state.semanticDiagnosticsPerFile.keys()).sort(compareStringsCaseSensitive)) { + const value = state.semanticDiagnosticsPerFile.get(key); + (semanticDiagnosticsPerFile || (semanticDiagnosticsPerFile = [])).push( + value.length ? [ + toFileId(key), + convertToReusableDiagnostics(value, relativeToBuildInfo) + ] : toFileId(key) + ); + } + } + let affectedFilesPendingEmit; + if ((_c = state.affectedFilesPendingEmit) == null ? void 0 : _c.size) { + const fullEmitForOptions = getBuilderFileEmit(state.compilerOptions); + const seenFiles = /* @__PURE__ */ new Set(); + for (const path of arrayFrom(state.affectedFilesPendingEmit.keys()).sort(compareStringsCaseSensitive)) { + if (tryAddToSet(seenFiles, path)) { + const file = state.program.getSourceFileByPath(path); + if (!file || !sourceFileMayBeEmitted(file, state.program)) + continue; + const fileId = toFileId(path), pendingEmit = state.affectedFilesPendingEmit.get(path); + (affectedFilesPendingEmit || (affectedFilesPendingEmit = [])).push( + pendingEmit === fullEmitForOptions ? fileId : ( + // Pending full emit per options + pendingEmit === 8 /* Dts */ ? [fileId] : ( + // Pending on Dts only + [fileId, pendingEmit] + ) ) + // Anything else ); - return exportedModules; - } - BuilderState2.getExportedModules = getExportedModules; - function getAllDependencies(state, programOfThisState, sourceFile) { - const compilerOptions = programOfThisState.getCompilerOptions(); - if (outFile(compilerOptions)) { - return getAllFileNames(state, programOfThisState); - } - if (!state.referencedMap || isFileAffectingGlobalScope(sourceFile)) { - return getAllFileNames(state, programOfThisState); - } - const seenMap = /* @__PURE__ */ new Set(); - const queue = [sourceFile.resolvedPath]; - while (queue.length) { - const path = queue.pop(); - if (!seenMap.has(path)) { - seenMap.add(path); - const references = state.referencedMap.getValues(path); - if (references) { - for (const key of references.keys()) { - queue.push(key); - } - } - } - } - return arrayFrom(mapDefinedIterator(seenMap.keys(), (path) => { - var _a; - return ((_a = programOfThisState.getSourceFileByPath(path)) == null ? void 0 : _a.fileName) ?? path; - })); - } - BuilderState2.getAllDependencies = getAllDependencies; - function getAllFileNames(state, programOfThisState) { - if (!state.allFileNames) { - const sourceFiles = programOfThisState.getSourceFiles(); - state.allFileNames = sourceFiles === emptyArray ? emptyArray : sourceFiles.map((file) => file.fileName); - } - return state.allFileNames; - } - function getReferencedByPaths(state, referencedFilePath) { - const keys = state.referencedMap.getKeys(referencedFilePath); - return keys ? arrayFrom(keys.keys()) : []; - } - BuilderState2.getReferencedByPaths = getReferencedByPaths; - function containsOnlyAmbientModules(sourceFile) { - for (const statement of sourceFile.statements) { - if (!isModuleWithStringLiteralName(statement)) { - return false; - } - } - return true; - } - function containsGlobalScopeAugmentation(sourceFile) { - return some(sourceFile.moduleAugmentations, (augmentation) => isGlobalScopeAugmentation(augmentation.parent)); - } - function isFileAffectingGlobalScope(sourceFile) { - return containsGlobalScopeAugmentation(sourceFile) || !isExternalOrCommonJsModule(sourceFile) && !isJsonSourceFile(sourceFile) && !containsOnlyAmbientModules(sourceFile); - } - function getAllFilesExcludingDefaultLibraryFile(state, programOfThisState, firstSourceFile) { - if (state.allFilesExcludingDefaultLibraryFile) { - return state.allFilesExcludingDefaultLibraryFile; - } - let result; - if (firstSourceFile) - addSourceFile(firstSourceFile); - for (const sourceFile of programOfThisState.getSourceFiles()) { - if (sourceFile !== firstSourceFile) { - addSourceFile(sourceFile); - } - } - state.allFilesExcludingDefaultLibraryFile = result || emptyArray; - return state.allFilesExcludingDefaultLibraryFile; - function addSourceFile(sourceFile) { - if (!programOfThisState.isSourceFileDefaultLibrary(sourceFile)) { - (result || (result = [])).push(sourceFile); - } - } } - BuilderState2.getAllFilesExcludingDefaultLibraryFile = getAllFilesExcludingDefaultLibraryFile; - function getFilesAffectedByUpdatedShapeWhenNonModuleEmit(state, programOfThisState, sourceFileWithUpdatedShape) { - const compilerOptions = programOfThisState.getCompilerOptions(); - if (compilerOptions && outFile(compilerOptions)) { - return [sourceFileWithUpdatedShape]; - } - return getAllFilesExcludingDefaultLibraryFile(state, programOfThisState, sourceFileWithUpdatedShape); + } + } + let changeFileSet; + if (state.changedFilesSet.size) { + for (const path of arrayFrom(state.changedFilesSet.keys()).sort(compareStringsCaseSensitive)) { + (changeFileSet || (changeFileSet = [])).push(toFileId(path)); + } + } + const program = { + fileNames, + fileInfos, + root, + options: convertToProgramBuildInfoCompilerOptions(state.compilerOptions), + fileIdsList, + referencedMap, + exportedModulesMap, + semanticDiagnosticsPerFile, + affectedFilesPendingEmit, + changeFileSet, + emitSignatures, + latestChangedDtsFile + }; + return createBuildInfo(program, bundle); + function relativeToBuildInfoEnsuringAbsolutePath(path) { + return relativeToBuildInfo(getNormalizedAbsolutePath(path, currentDirectory)); + } + function relativeToBuildInfo(path) { + return ensurePathIsNonModuleName(getRelativePathFromDirectory(buildInfoDirectory, path, state.program.getCanonicalFileName)); + } + function toFileId(path) { + let fileId = fileNameToFileId.get(path); + if (fileId === void 0) { + fileNames.push(relativeToBuildInfo(path)); + fileNameToFileId.set(path, fileId = fileNames.length); + } + return fileId; + } + function toFileIdListId(set) { + const fileIds = arrayFrom(set.keys(), toFileId).sort(compareValues); + const key = fileIds.join(); + let fileIdListId = fileNamesToFileIdListId == null ? void 0 : fileNamesToFileIdListId.get(key); + if (fileIdListId === void 0) { + (fileIdsList || (fileIdsList = [])).push(fileIds); + (fileNamesToFileIdListId || (fileNamesToFileIdListId = /* @__PURE__ */ new Map())).set(key, fileIdListId = fileIdsList.length); + } + return fileIdListId; + } + function tryAddRoot(path, fileId) { + const file = state.program.getSourceFile(path); + if (!state.program.getFileIncludeReasons().get(file.path).some((r) => r.kind === 0 /* RootFile */)) + return; + if (!root.length) + return root.push(fileId); + const last2 = root[root.length - 1]; + const isLastStartEnd = isArray(last2); + if (isLastStartEnd && last2[1] === fileId - 1) + return last2[1] = fileId; + if (isLastStartEnd || root.length === 1 || last2 !== fileId - 1) + return root.push(fileId); + const lastButOne = root[root.length - 2]; + if (!isNumber(lastButOne) || lastButOne !== last2 - 1) + return root.push(fileId); + root[root.length - 2] = [lastButOne, fileId]; + return root.length = root.length - 1; + } + function convertToProgramBuildInfoCompilerOptions(options) { + let result; + const { optionsNameMap } = getOptionsNameMap(); + for (const name of getOwnKeys(options).sort(compareStringsCaseSensitive)) { + const optionInfo = optionsNameMap.get(name.toLowerCase()); + if (optionInfo == null ? void 0 : optionInfo.affectsBuildInfo) { + (result || (result = {}))[name] = convertToReusableCompilerOptionValue( + optionInfo, + options[name], + relativeToBuildInfoEnsuringAbsolutePath + ); } - function getFilesAffectedByUpdatedShapeWhenModuleEmit(state, programOfThisState, sourceFileWithUpdatedShape, cancellationToken, host) { - if (isFileAffectingGlobalScope(sourceFileWithUpdatedShape)) { - return getAllFilesExcludingDefaultLibraryFile(state, programOfThisState, sourceFileWithUpdatedShape); - } - const compilerOptions = programOfThisState.getCompilerOptions(); - if (compilerOptions && (getIsolatedModules(compilerOptions) || outFile(compilerOptions))) { - return [sourceFileWithUpdatedShape]; - } - const seenFileNamesMap = /* @__PURE__ */ new Map(); - seenFileNamesMap.set(sourceFileWithUpdatedShape.resolvedPath, sourceFileWithUpdatedShape); - const queue = getReferencedByPaths(state, sourceFileWithUpdatedShape.resolvedPath); - while (queue.length > 0) { - const currentPath = queue.pop(); - if (!seenFileNamesMap.has(currentPath)) { - const currentSourceFile = programOfThisState.getSourceFileByPath(currentPath); - seenFileNamesMap.set(currentPath, currentSourceFile); - if (currentSourceFile && updateShapeSignature(state, programOfThisState, currentSourceFile, cancellationToken, host)) { - queue.push(...getReferencedByPaths(state, currentSourceFile.resolvedPath)); - } - } - } - return arrayFrom(mapDefinedIterator(seenFileNamesMap.values(), (value) => value)); + } + return result; + } + } + function convertToReusableCompilerOptionValue(option, value, relativeToBuildInfo) { + if (option) { + Debug.assert(option.type !== "listOrElement"); + if (option.type === "list") { + const values = value; + if (option.element.isFilePath && values.length) { + return values.map(relativeToBuildInfo); } - })(BuilderState || (BuilderState = {})); + } else if (option.isFilePath) { + return relativeToBuildInfo(value); + } } - }); - - // src/compiler/builder.ts - function getBuilderFileEmit(options) { - let result = 1 /* Js */; - if (options.sourceMap) - result = result | 2 /* JsMap */; - if (options.inlineSourceMap) - result = result | 4 /* JsInlineMap */; - if (getEmitDeclarations(options)) - result = result | 8 /* Dts */; - if (options.declarationMap) - result = result | 16 /* DtsMap */; - if (options.emitDeclarationOnly) - result = result & 24 /* AllDts */; - return result; + return value; } - function getPendingEmitKind(optionsOrEmitKind, oldOptionsOrEmitKind) { - const oldEmitKind = oldOptionsOrEmitKind && (isNumber(oldOptionsOrEmitKind) ? oldOptionsOrEmitKind : getBuilderFileEmit(oldOptionsOrEmitKind)); - const emitKind = isNumber(optionsOrEmitKind) ? optionsOrEmitKind : getBuilderFileEmit(optionsOrEmitKind); - if (oldEmitKind === emitKind) - return 0 /* None */; - if (!oldEmitKind || !emitKind) - return emitKind; - const diff = oldEmitKind ^ emitKind; - let result = 0 /* None */; - if (diff & 7 /* AllJs */) - result = emitKind & 7 /* AllJs */; - if (diff & 24 /* AllDts */) - result = result | emitKind & 24 /* AllDts */; - return result; + function convertToReusableDiagnostics(diagnostics, relativeToBuildInfo) { + Debug.assert(!!diagnostics.length); + return diagnostics.map((diagnostic) => { + const result = convertToReusableDiagnosticRelatedInformation(diagnostic, relativeToBuildInfo); + result.reportsUnnecessary = diagnostic.reportsUnnecessary; + result.reportDeprecated = diagnostic.reportsDeprecated; + result.source = diagnostic.source; + result.skippedOn = diagnostic.skippedOn; + const { relatedInformation } = diagnostic; + result.relatedInformation = relatedInformation ? relatedInformation.length ? relatedInformation.map((r) => convertToReusableDiagnosticRelatedInformation(r, relativeToBuildInfo)) : [] : void 0; + return result; + }); } - function hasSameKeys(map1, map2) { - return map1 === map2 || map1 !== void 0 && map2 !== void 0 && map1.size === map2.size && !forEachKey(map1, (key) => !map2.has(key)); + function convertToReusableDiagnosticRelatedInformation(diagnostic, relativeToBuildInfo) { + const { file } = diagnostic; + return { + ...diagnostic, + file: file ? relativeToBuildInfo(file.resolvedPath) : void 0, + messageText: isString(diagnostic.messageText) ? diagnostic.messageText : convertToReusableDiagnosticMessageChain(diagnostic.messageText) + }; } - function createBuilderProgramState(newProgram, oldState) { - var _a, _b; - const state = BuilderState.create( - newProgram, - oldState, - /*disableUseFileVersionAsSignature*/ - false - ); - state.program = newProgram; - const compilerOptions = newProgram.getCompilerOptions(); - state.compilerOptions = compilerOptions; - const outFilePath = outFile(compilerOptions); - if (!outFilePath) { - state.semanticDiagnosticsPerFile = /* @__PURE__ */ new Map(); - } else if (compilerOptions.composite && (oldState == null ? void 0 : oldState.outSignature) && outFilePath === outFile(oldState == null ? void 0 : oldState.compilerOptions)) { - state.outSignature = oldState.outSignature && getEmitSignatureFromOldSignature(compilerOptions, oldState.compilerOptions, oldState.outSignature); + function convertToReusableDiagnosticMessageChain(chain) { + if (chain.repopulateInfo) { + return { + info: chain.repopulateInfo(), + next: convertToReusableDiagnosticMessageChainArray(chain.next) + }; } - state.changedFilesSet = /* @__PURE__ */ new Set(); - state.latestChangedDtsFile = compilerOptions.composite ? oldState == null ? void 0 : oldState.latestChangedDtsFile : void 0; - const useOldState = BuilderState.canReuseOldState(state.referencedMap, oldState); - const oldCompilerOptions = useOldState ? oldState.compilerOptions : void 0; - const canCopySemanticDiagnostics = useOldState && oldState.semanticDiagnosticsPerFile && !!state.semanticDiagnosticsPerFile && !compilerOptionsAffectSemanticDiagnostics(compilerOptions, oldCompilerOptions); - const canCopyEmitSignatures = compilerOptions.composite && (oldState == null ? void 0 : oldState.emitSignatures) && !outFilePath && !compilerOptionsAffectDeclarationPath(compilerOptions, oldState.compilerOptions); - if (useOldState) { - (_a = oldState.changedFilesSet) == null ? void 0 : _a.forEach((value) => state.changedFilesSet.add(value)); - if (!outFilePath && ((_b = oldState.affectedFilesPendingEmit) == null ? void 0 : _b.size)) { - state.affectedFilesPendingEmit = new Map(oldState.affectedFilesPendingEmit); - state.seenAffectedFiles = /* @__PURE__ */ new Set(); + const next = convertToReusableDiagnosticMessageChainArray(chain.next); + return next === chain.next ? chain : { ...chain, next }; + } + function convertToReusableDiagnosticMessageChainArray(array) { + if (!array) + return array; + return forEach(array, (chain, index) => { + const reusable = convertToReusableDiagnosticMessageChain(chain); + if (chain === reusable) + return void 0; + const result = index > 0 ? array.slice(0, index - 1) : []; + result.push(reusable); + for (let i = index + 1; i < array.length; i++) { + result.push(convertToReusableDiagnosticMessageChain(array[i])); } - state.programEmitPending = oldState.programEmitPending; + return result; + }) || array; + } + function getBuilderCreationParameters(newProgramOrRootNames, hostOrOptions, oldProgramOrHost, configFileParsingDiagnosticsOrOldProgram, configFileParsingDiagnostics, projectReferences) { + let host; + let newProgram; + let oldProgram; + if (newProgramOrRootNames === void 0) { + Debug.assert(hostOrOptions === void 0); + host = oldProgramOrHost; + oldProgram = configFileParsingDiagnosticsOrOldProgram; + Debug.assert(!!oldProgram); + newProgram = oldProgram.getProgram(); + } else if (isArray(newProgramOrRootNames)) { + oldProgram = configFileParsingDiagnosticsOrOldProgram; + newProgram = createProgram({ + rootNames: newProgramOrRootNames, + options: hostOrOptions, + host: oldProgramOrHost, + oldProgram: oldProgram && oldProgram.getProgramOrUndefined(), + configFileParsingDiagnostics, + projectReferences + }); + host = oldProgramOrHost; } else { - state.buildInfoEmitPending = true; + newProgram = newProgramOrRootNames; + host = hostOrOptions; + oldProgram = oldProgramOrHost; + configFileParsingDiagnostics = configFileParsingDiagnosticsOrOldProgram; } - const referencedMap = state.referencedMap; - const oldReferencedMap = useOldState ? oldState.referencedMap : void 0; - const copyDeclarationFileDiagnostics = canCopySemanticDiagnostics && !compilerOptions.skipLibCheck === !oldCompilerOptions.skipLibCheck; - const copyLibFileDiagnostics = copyDeclarationFileDiagnostics && !compilerOptions.skipDefaultLibCheck === !oldCompilerOptions.skipDefaultLibCheck; - state.fileInfos.forEach((info, sourceFilePath) => { - let oldInfo; - let newReferences; - if (!useOldState || // File wasn't present in old state - !(oldInfo = oldState.fileInfos.get(sourceFilePath)) || // versions dont match - oldInfo.version !== info.version || // Implied formats dont match - oldInfo.impliedFormat !== info.impliedFormat || // Referenced files changed - !hasSameKeys(newReferences = referencedMap && referencedMap.getValues(sourceFilePath), oldReferencedMap && oldReferencedMap.getValues(sourceFilePath)) || // Referenced file was deleted in the new program - newReferences && forEachKey(newReferences, (path) => !state.fileInfos.has(path) && oldState.fileInfos.has(path))) { - addFileToChangeSet(state, sourceFilePath); - } else if (canCopySemanticDiagnostics) { - const sourceFile = newProgram.getSourceFileByPath(sourceFilePath); - if (sourceFile.isDeclarationFile && !copyDeclarationFileDiagnostics) - return; - if (sourceFile.hasNoDefaultLib && !copyLibFileDiagnostics) - return; - const diagnostics = oldState.semanticDiagnosticsPerFile.get(sourceFilePath); - if (diagnostics) { - state.semanticDiagnosticsPerFile.set( - sourceFilePath, - oldState.hasReusableDiagnostic ? convertToDiagnostics(diagnostics, newProgram) : repopulateDiagnostics(diagnostics, newProgram) - ); - if (!state.semanticDiagnosticsFromOldState) { - state.semanticDiagnosticsFromOldState = /* @__PURE__ */ new Set(); + return { host, newProgram, oldProgram, configFileParsingDiagnostics: configFileParsingDiagnostics || emptyArray }; + } + function getTextHandlingSourceMapForSignature(text, data) { + return (data == null ? void 0 : data.sourceMapUrlPos) !== void 0 ? text.substring(0, data.sourceMapUrlPos) : text; + } + function computeSignatureWithDiagnostics(program, sourceFile, text, host, data) { + var _a; + text = getTextHandlingSourceMapForSignature(text, data); + let sourceFileDirectory; + if ((_a = data == null ? void 0 : data.diagnostics) == null ? void 0 : _a.length) { + text += data.diagnostics.map((diagnostic) => `${locationInfo(diagnostic)}${DiagnosticCategory[diagnostic.category]}${diagnostic.code}: ${flattenDiagnosticMessageText2(diagnostic.messageText)}`).join("\n"); + } + return (host.createHash ?? generateDjb2Hash)(text); + function flattenDiagnosticMessageText2(diagnostic) { + return isString(diagnostic) ? diagnostic : diagnostic === void 0 ? "" : !diagnostic.next ? diagnostic.messageText : diagnostic.messageText + diagnostic.next.map(flattenDiagnosticMessageText2).join("\n"); + } + function locationInfo(diagnostic) { + if (diagnostic.file.resolvedPath === sourceFile.resolvedPath) + return `(${diagnostic.start},${diagnostic.length})`; + if (sourceFileDirectory === void 0) + sourceFileDirectory = getDirectoryPath(sourceFile.resolvedPath); + return `${ensurePathIsNonModuleName(getRelativePathFromDirectory( + sourceFileDirectory, + diagnostic.file.resolvedPath, + program.getCanonicalFileName + ))}(${diagnostic.start},${diagnostic.length})`; + } + } + function computeSignature(text, host, data) { + return (host.createHash ?? generateDjb2Hash)(getTextHandlingSourceMapForSignature(text, data)); + } + function createBuilderProgram(kind, { newProgram, host, oldProgram, configFileParsingDiagnostics }) { + let oldState = oldProgram && oldProgram.getState(); + if (oldState && newProgram === oldState.program && configFileParsingDiagnostics === newProgram.getConfigFileParsingDiagnostics()) { + newProgram = void 0; + oldState = void 0; + return oldProgram; + } + const state = createBuilderProgramState(newProgram, oldState); + newProgram.getBuildInfo = (bundle) => getBuildInfo2(state, bundle); + newProgram = void 0; + oldProgram = void 0; + oldState = void 0; + const getState = () => state; + const builderProgram = createRedirectedBuilderProgram(getState, configFileParsingDiagnostics); + builderProgram.getState = getState; + builderProgram.saveEmitState = () => backupBuilderProgramEmitState(state); + builderProgram.restoreEmitState = (saved) => restoreBuilderProgramEmitState(state, saved); + builderProgram.hasChangedEmitSignature = () => !!state.hasChangedEmitSignature; + builderProgram.getAllDependencies = (sourceFile) => BuilderState.getAllDependencies(state, Debug.checkDefined(state.program), sourceFile); + builderProgram.getSemanticDiagnostics = getSemanticDiagnostics; + builderProgram.emit = emit; + builderProgram.releaseProgram = () => releaseCache(state); + if (kind === 0 /* SemanticDiagnosticsBuilderProgram */) { + builderProgram.getSemanticDiagnosticsOfNextAffectedFile = getSemanticDiagnosticsOfNextAffectedFile; + } else if (kind === 1 /* EmitAndSemanticDiagnosticsBuilderProgram */) { + builderProgram.getSemanticDiagnosticsOfNextAffectedFile = getSemanticDiagnosticsOfNextAffectedFile; + builderProgram.emitNextAffectedFile = emitNextAffectedFile; + builderProgram.emitBuildInfo = emitBuildInfo; + } else { + notImplemented(); + } + return builderProgram; + function emitBuildInfo(writeFile2, cancellationToken) { + if (state.buildInfoEmitPending) { + const result = Debug.checkDefined(state.program).emitBuildInfo(writeFile2 || maybeBind(host, host.writeFile), cancellationToken); + state.buildInfoEmitPending = false; + return result; + } + return emitSkippedWithNoDiagnostics; + } + function emitNextAffectedFile(writeFile2, cancellationToken, emitOnlyDtsFiles, customTransformers) { + var _a, _b, _c; + let affected = getNextAffectedFile(state, cancellationToken, host); + const programEmitKind = getBuilderFileEmit(state.compilerOptions); + let emitKind = emitOnlyDtsFiles ? programEmitKind & 24 /* AllDts */ : programEmitKind; + if (!affected) { + if (!outFile(state.compilerOptions)) { + const pendingAffectedFile = getNextAffectedFilePendingEmit(state, emitOnlyDtsFiles); + if (!pendingAffectedFile) { + if (!state.buildInfoEmitPending) + return void 0; + const affected2 = state.program; + const result2 = affected2.emitBuildInfo(writeFile2 || maybeBind(host, host.writeFile), cancellationToken); + state.buildInfoEmitPending = false; + return { result: result2, affected: affected2 }; } - state.semanticDiagnosticsFromOldState.add(sourceFilePath); + ({ affectedFile: affected, emitKind } = pendingAffectedFile); + } else { + if (!state.programEmitPending) + return void 0; + emitKind = state.programEmitPending; + if (emitOnlyDtsFiles) + emitKind = emitKind & 24 /* AllDts */; + if (!emitKind) + return void 0; + affected = state.program; } } - if (canCopyEmitSignatures) { - const oldEmitSignature = oldState.emitSignatures.get(sourceFilePath); - if (oldEmitSignature) { - (state.emitSignatures ?? (state.emitSignatures = /* @__PURE__ */ new Map())).set(sourceFilePath, getEmitSignatureFromOldSignature(compilerOptions, oldState.compilerOptions, oldEmitSignature)); - } + let emitOnly; + if (emitKind & 7 /* AllJs */) + emitOnly = 0 /* Js */; + if (emitKind & 24 /* AllDts */) + emitOnly = emitOnly === void 0 ? 1 /* Dts */ : void 0; + if (affected === state.program) { + state.programEmitPending = state.changedFilesSet.size ? getPendingEmitKind(programEmitKind, emitKind) : state.programEmitPending ? getPendingEmitKind(state.programEmitPending, emitKind) : void 0; } - }); - if (useOldState && forEachEntry(oldState.fileInfos, (info, sourceFilePath) => { - if (state.fileInfos.has(sourceFilePath)) - return false; - if (outFilePath || info.affectsGlobalScope) - return true; - state.buildInfoEmitPending = true; - return false; - })) { - BuilderState.getAllFilesExcludingDefaultLibraryFile( - state, - newProgram, - /*firstSourceFile*/ - void 0 - ).forEach((file) => addFileToChangeSet(state, file.resolvedPath)); - } else if (oldCompilerOptions) { - const pendingEmitKind = compilerOptionsAffectEmit(compilerOptions, oldCompilerOptions) ? getBuilderFileEmit(compilerOptions) : getPendingEmitKind(compilerOptions, oldCompilerOptions); - if (pendingEmitKind !== 0 /* None */) { - if (!outFilePath) { - newProgram.getSourceFiles().forEach((f) => { - if (!state.changedFilesSet.has(f.resolvedPath)) { - addToAffectedFilesPendingEmit( - state, - f.resolvedPath, - pendingEmitKind - ); + const result = state.program.emit( + affected === state.program ? void 0 : affected, + getWriteFileCallback(writeFile2, customTransformers), + cancellationToken, + emitOnly, + customTransformers + ); + if (affected !== state.program) { + const affectedSourceFile = affected; + state.seenAffectedFiles.add(affectedSourceFile.resolvedPath); + if (state.affectedFilesIndex !== void 0) + state.affectedFilesIndex++; + state.buildInfoEmitPending = true; + const existing = ((_a = state.seenEmittedFiles) == null ? void 0 : _a.get(affectedSourceFile.resolvedPath)) || 0 /* None */; + (state.seenEmittedFiles ?? (state.seenEmittedFiles = /* @__PURE__ */ new Map())).set(affectedSourceFile.resolvedPath, emitKind | existing); + const existingPending = ((_b = state.affectedFilesPendingEmit) == null ? void 0 : _b.get(affectedSourceFile.resolvedPath)) || programEmitKind; + const pendingKind = getPendingEmitKind(existingPending, emitKind | existing); + if (pendingKind) + (state.affectedFilesPendingEmit ?? (state.affectedFilesPendingEmit = /* @__PURE__ */ new Map())).set(affectedSourceFile.resolvedPath, pendingKind); + else + (_c = state.affectedFilesPendingEmit) == null ? void 0 : _c.delete(affectedSourceFile.resolvedPath); + } else { + state.changedFilesSet.clear(); + } + return { result, affected }; + } + function getWriteFileCallback(writeFile2, customTransformers) { + if (!getEmitDeclarations(state.compilerOptions)) + return writeFile2 || maybeBind(host, host.writeFile); + return (fileName, text, writeByteOrderMark, onError, sourceFiles, data) => { + var _a, _b, _c, _d; + if (isDeclarationFileName(fileName)) { + if (!outFile(state.compilerOptions)) { + Debug.assert((sourceFiles == null ? void 0 : sourceFiles.length) === 1); + let emitSignature; + if (!customTransformers) { + const file = sourceFiles[0]; + const info = state.fileInfos.get(file.resolvedPath); + if (info.signature === file.version) { + const signature = computeSignatureWithDiagnostics( + state.program, + file, + text, + host, + data + ); + if (!((_a = data == null ? void 0 : data.diagnostics) == null ? void 0 : _a.length)) + emitSignature = signature; + if (signature !== file.version) { + if (host.storeFilesChangingSignatureDuringEmit) + (state.filesChangingSignature ?? (state.filesChangingSignature = /* @__PURE__ */ new Set())).add(file.resolvedPath); + if (state.exportedModulesMap) + BuilderState.updateExportedModules(state, file, file.exportedModulesFromDeclarationEmit); + if (state.affectedFiles) { + const existing = (_b = state.oldSignatures) == null ? void 0 : _b.get(file.resolvedPath); + if (existing === void 0) + (state.oldSignatures ?? (state.oldSignatures = /* @__PURE__ */ new Map())).set(file.resolvedPath, info.signature || false); + info.signature = signature; + } else { + info.signature = signature; + (_c = state.oldExportedModulesMap) == null ? void 0 : _c.clear(); + } + } + } } - }); - Debug.assert(!state.seenAffectedFiles || !state.seenAffectedFiles.size); - state.seenAffectedFiles = state.seenAffectedFiles || /* @__PURE__ */ new Set(); + if (state.compilerOptions.composite) { + const filePath = sourceFiles[0].resolvedPath; + emitSignature = handleNewSignature((_d = state.emitSignatures) == null ? void 0 : _d.get(filePath), emitSignature); + if (!emitSignature) + return; + (state.emitSignatures ?? (state.emitSignatures = /* @__PURE__ */ new Map())).set(filePath, emitSignature); + } + } else if (state.compilerOptions.composite) { + const newSignature = handleNewSignature( + state.outSignature, + /*newSignature*/ + void 0 + ); + if (!newSignature) + return; + state.outSignature = newSignature; + } + } + if (writeFile2) + writeFile2(fileName, text, writeByteOrderMark, onError, sourceFiles, data); + else if (host.writeFile) + host.writeFile(fileName, text, writeByteOrderMark, onError, sourceFiles, data); + else + state.program.writeFile(fileName, text, writeByteOrderMark, onError, sourceFiles, data); + function handleNewSignature(oldSignatureFormat, newSignature) { + const oldSignature = !oldSignatureFormat || isString(oldSignatureFormat) ? oldSignatureFormat : oldSignatureFormat[0]; + newSignature ?? (newSignature = computeSignature(text, host, data)); + if (newSignature === oldSignature) { + if (oldSignatureFormat === oldSignature) + return void 0; + else if (data) + data.differsOnlyInMap = true; + else + data = { differsOnlyInMap: true }; + } else { + state.hasChangedEmitSignature = true; + state.latestChangedDtsFile = fileName; + } + return newSignature; + } + }; + } + function emit(targetSourceFile, writeFile2, cancellationToken, emitOnlyDtsFiles, customTransformers) { + if (kind === 1 /* EmitAndSemanticDiagnosticsBuilderProgram */) { + assertSourceFileOkWithoutNextAffectedCall(state, targetSourceFile); + } + const result = handleNoEmitOptions(builderProgram, targetSourceFile, writeFile2, cancellationToken); + if (result) + return result; + if (!targetSourceFile) { + if (kind === 1 /* EmitAndSemanticDiagnosticsBuilderProgram */) { + let sourceMaps = []; + let emitSkipped = false; + let diagnostics; + let emittedFiles = []; + let affectedEmitResult; + while (affectedEmitResult = emitNextAffectedFile(writeFile2, cancellationToken, emitOnlyDtsFiles, customTransformers)) { + emitSkipped = emitSkipped || affectedEmitResult.result.emitSkipped; + diagnostics = addRange(diagnostics, affectedEmitResult.result.diagnostics); + emittedFiles = addRange(emittedFiles, affectedEmitResult.result.emittedFiles); + sourceMaps = addRange(sourceMaps, affectedEmitResult.result.sourceMaps); + } + return { + emitSkipped, + diagnostics: diagnostics || emptyArray, + emittedFiles, + sourceMaps + }; + } else { + clearAffectedFilesPendingEmit(state, emitOnlyDtsFiles); + } + } + return Debug.checkDefined(state.program).emit( + targetSourceFile, + getWriteFileCallback(writeFile2, customTransformers), + cancellationToken, + emitOnlyDtsFiles, + customTransformers + ); + } + function getSemanticDiagnosticsOfNextAffectedFile(cancellationToken, ignoreSourceFile) { + while (true) { + const affected = getNextAffectedFile(state, cancellationToken, host); + let result; + if (!affected) + return void 0; + else if (affected !== state.program) { + const affectedSourceFile = affected; + if (!ignoreSourceFile || !ignoreSourceFile(affectedSourceFile)) { + result = getSemanticDiagnosticsOfFile(state, affectedSourceFile, cancellationToken); + } + state.seenAffectedFiles.add(affectedSourceFile.resolvedPath); + state.affectedFilesIndex++; state.buildInfoEmitPending = true; + if (!result) + continue; } else { - state.programEmitPending = state.programEmitPending ? state.programEmitPending | pendingEmitKind : pendingEmitKind; + result = state.program.getSemanticDiagnostics( + /*sourceFile*/ + void 0, + cancellationToken + ); + state.changedFilesSet.clear(); + state.programEmitPending = getBuilderFileEmit(state.compilerOptions); } + return { result, affected }; } } - if (outFilePath && !state.changedFilesSet.size) { - if (useOldState) - state.bundle = oldState.bundle; - if (some(newProgram.getProjectReferences(), (ref) => !!ref.prepend)) - state.programEmitPending = getBuilderFileEmit(compilerOptions); + function getSemanticDiagnostics(sourceFile, cancellationToken) { + assertSourceFileOkWithoutNextAffectedCall(state, sourceFile); + const compilerOptions = Debug.checkDefined(state.program).getCompilerOptions(); + if (outFile(compilerOptions)) { + Debug.assert(!state.semanticDiagnosticsPerFile); + return Debug.checkDefined(state.program).getSemanticDiagnostics(sourceFile, cancellationToken); + } + if (sourceFile) { + return getSemanticDiagnosticsOfFile(state, sourceFile, cancellationToken); + } + while (getSemanticDiagnosticsOfNextAffectedFile(cancellationToken)) { + } + let diagnostics; + for (const sourceFile2 of Debug.checkDefined(state.program).getSourceFiles()) { + diagnostics = addRange(diagnostics, getSemanticDiagnosticsOfFile(state, sourceFile2, cancellationToken)); + } + return diagnostics || emptyArray; } - return state; - } - function addFileToChangeSet(state, path) { - state.changedFilesSet.add(path); - state.buildInfoEmitPending = true; - state.programEmitPending = void 0; } - function getEmitSignatureFromOldSignature(options, oldOptions, oldEmitSignature) { - return !!options.declarationMap === !!oldOptions.declarationMap ? ( - // Use same format of signature - oldEmitSignature - ) : ( - // Convert to different format - isString(oldEmitSignature) ? [oldEmitSignature] : oldEmitSignature[0] - ); + function addToAffectedFilesPendingEmit(state, affectedFilePendingEmit, kind) { + var _a; + const existingKind = ((_a = state.affectedFilesPendingEmit) == null ? void 0 : _a.get(affectedFilePendingEmit)) || 0 /* None */; + (state.affectedFilesPendingEmit ?? (state.affectedFilesPendingEmit = /* @__PURE__ */ new Map())).set(affectedFilePendingEmit, existingKind | kind); } - function repopulateDiagnostics(diagnostics, newProgram) { - if (!diagnostics.length) - return diagnostics; - return sameMap(diagnostics, (diag2) => { - if (isString(diag2.messageText)) - return diag2; - const repopulatedChain = convertOrRepopulateDiagnosticMessageChain(diag2.messageText, diag2.file, newProgram, (chain) => { - var _a; - return (_a = chain.repopulateInfo) == null ? void 0 : _a.call(chain); - }); - return repopulatedChain === diag2.messageText ? diag2 : { ...diag2, messageText: repopulatedChain }; - }); + function toBuilderStateFileInfoForMultiEmit(fileInfo) { + return isString(fileInfo) ? { version: fileInfo, signature: fileInfo, affectsGlobalScope: void 0, impliedFormat: void 0 } : isString(fileInfo.signature) ? fileInfo : { version: fileInfo.version, signature: fileInfo.signature === false ? void 0 : fileInfo.version, affectsGlobalScope: fileInfo.affectsGlobalScope, impliedFormat: fileInfo.impliedFormat }; } - function convertOrRepopulateDiagnosticMessageChain(chain, sourceFile, newProgram, repopulateInfo) { - const info = repopulateInfo(chain); - if (info) { - return { - ...createModuleNotFoundChain(sourceFile, newProgram, info.moduleReference, info.mode, info.packageName || info.moduleReference), - next: convertOrRepopulateDiagnosticMessageChainArray(chain.next, sourceFile, newProgram, repopulateInfo) - }; - } - const next = convertOrRepopulateDiagnosticMessageChainArray(chain.next, sourceFile, newProgram, repopulateInfo); - return next === chain.next ? chain : { ...chain, next }; + function toBuilderFileEmit(value, fullEmitForOptions) { + return isNumber(value) ? fullEmitForOptions : value[1] || 8 /* Dts */; } - function convertOrRepopulateDiagnosticMessageChainArray(array, sourceFile, newProgram, repopulateInfo) { - return sameMap(array, (chain) => convertOrRepopulateDiagnosticMessageChain(chain, sourceFile, newProgram, repopulateInfo)); + function toProgramEmitPending(value, options) { + return !value ? getBuilderFileEmit(options || {}) : value; } - function convertToDiagnostics(diagnostics, newProgram) { - if (!diagnostics.length) - return emptyArray; - let buildInfoDirectory; - return diagnostics.map((diagnostic) => { - const result = convertToDiagnosticRelatedInformation(diagnostic, newProgram, toPathInBuildInfoDirectory); - result.reportsUnnecessary = diagnostic.reportsUnnecessary; - result.reportsDeprecated = diagnostic.reportDeprecated; - result.source = diagnostic.source; - result.skippedOn = diagnostic.skippedOn; - const { relatedInformation } = diagnostic; - result.relatedInformation = relatedInformation ? relatedInformation.length ? relatedInformation.map((r) => convertToDiagnosticRelatedInformation(r, newProgram, toPathInBuildInfoDirectory)) : [] : void 0; - return result; - }); - function toPathInBuildInfoDirectory(path) { - buildInfoDirectory ?? (buildInfoDirectory = getDirectoryPath(getNormalizedAbsolutePath(getTsBuildInfoEmitOutputFilePath(newProgram.getCompilerOptions()), newProgram.getCurrentDirectory()))); - return toPath(path, buildInfoDirectory, newProgram.getCanonicalFileName); + function createBuilderProgramUsingProgramBuildInfo(buildInfo, buildInfoPath, host) { + var _a, _b, _c, _d; + const program = buildInfo.program; + const buildInfoDirectory = getDirectoryPath(getNormalizedAbsolutePath(buildInfoPath, host.getCurrentDirectory())); + const getCanonicalFileName = createGetCanonicalFileName(host.useCaseSensitiveFileNames()); + let state; + const filePaths = (_a = program.fileNames) == null ? void 0 : _a.map(toPathInBuildInfoDirectory); + let filePathsSetList; + const latestChangedDtsFile = program.latestChangedDtsFile ? toAbsolutePath(program.latestChangedDtsFile) : void 0; + if (isProgramBundleEmitBuildInfo(program)) { + const fileInfos = /* @__PURE__ */ new Map(); + program.fileInfos.forEach((fileInfo, index) => { + const path = toFilePath(index + 1); + fileInfos.set(path, isString(fileInfo) ? { version: fileInfo, signature: void 0, affectsGlobalScope: void 0, impliedFormat: void 0 } : fileInfo); + }); + state = { + fileInfos, + compilerOptions: program.options ? convertToOptionsWithAbsolutePaths(program.options, toAbsolutePath) : {}, + latestChangedDtsFile, + outSignature: program.outSignature, + programEmitPending: program.pendingEmit === void 0 ? void 0 : toProgramEmitPending(program.pendingEmit, program.options), + bundle: buildInfo.bundle + }; + } else { + filePathsSetList = (_b = program.fileIdsList) == null ? void 0 : _b.map((fileIds) => new Set(fileIds.map(toFilePath))); + const fileInfos = /* @__PURE__ */ new Map(); + const emitSignatures = ((_c = program.options) == null ? void 0 : _c.composite) && !outFile(program.options) ? /* @__PURE__ */ new Map() : void 0; + program.fileInfos.forEach((fileInfo, index) => { + const path = toFilePath(index + 1); + const stateFileInfo = toBuilderStateFileInfoForMultiEmit(fileInfo); + fileInfos.set(path, stateFileInfo); + if (emitSignatures && stateFileInfo.signature) + emitSignatures.set(path, stateFileInfo.signature); + }); + (_d = program.emitSignatures) == null ? void 0 : _d.forEach((value) => { + if (isNumber(value)) + emitSignatures.delete(toFilePath(value)); + else { + const key = toFilePath(value[0]); + emitSignatures.set( + key, + !isString(value[1]) && !value[1].length ? ( + // File signature is emit signature but differs in map + [emitSignatures.get(key)] + ) : value[1] + ); + } + }); + const fullEmitForOptions = program.affectedFilesPendingEmit ? getBuilderFileEmit(program.options || {}) : void 0; + state = { + fileInfos, + compilerOptions: program.options ? convertToOptionsWithAbsolutePaths(program.options, toAbsolutePath) : {}, + referencedMap: toManyToManyPathMap(program.referencedMap), + exportedModulesMap: toManyToManyPathMap(program.exportedModulesMap), + semanticDiagnosticsPerFile: program.semanticDiagnosticsPerFile && arrayToMap(program.semanticDiagnosticsPerFile, (value) => toFilePath(isNumber(value) ? value : value[0]), (value) => isNumber(value) ? emptyArray : value[1]), + hasReusableDiagnostic: true, + affectedFilesPendingEmit: program.affectedFilesPendingEmit && arrayToMap(program.affectedFilesPendingEmit, (value) => toFilePath(isNumber(value) ? value : value[0]), (value) => toBuilderFileEmit(value, fullEmitForOptions)), + changedFilesSet: new Set(map(program.changeFileSet, toFilePath)), + latestChangedDtsFile, + emitSignatures: (emitSignatures == null ? void 0 : emitSignatures.size) ? emitSignatures : void 0 + }; } - } - function convertToDiagnosticRelatedInformation(diagnostic, newProgram, toPath3) { - const { file } = diagnostic; - const sourceFile = file ? newProgram.getSourceFileByPath(toPath3(file)) : void 0; return { - ...diagnostic, - file: sourceFile, - messageText: isString(diagnostic.messageText) ? diagnostic.messageText : convertOrRepopulateDiagnosticMessageChain(diagnostic.messageText, sourceFile, newProgram, (chain) => chain.info) + getState: () => state, + saveEmitState: noop, + restoreEmitState: noop, + getProgram: notImplemented, + getProgramOrUndefined: returnUndefined, + releaseProgram: noop, + getCompilerOptions: () => state.compilerOptions, + getSourceFile: notImplemented, + getSourceFiles: notImplemented, + getOptionsDiagnostics: notImplemented, + getGlobalDiagnostics: notImplemented, + getConfigFileParsingDiagnostics: notImplemented, + getSyntacticDiagnostics: notImplemented, + getDeclarationDiagnostics: notImplemented, + getSemanticDiagnostics: notImplemented, + emit: notImplemented, + getAllDependencies: notImplemented, + getCurrentDirectory: notImplemented, + emitNextAffectedFile: notImplemented, + getSemanticDiagnosticsOfNextAffectedFile: notImplemented, + emitBuildInfo: notImplemented, + close: noop, + hasChangedEmitSignature: returnFalse }; + function toPathInBuildInfoDirectory(path) { + return toPath(path, buildInfoDirectory, getCanonicalFileName); + } + function toAbsolutePath(path) { + return getNormalizedAbsolutePath(path, buildInfoDirectory); + } + function toFilePath(fileId) { + return filePaths[fileId - 1]; + } + function toFilePathsSet(fileIdsListId) { + return filePathsSetList[fileIdsListId - 1]; + } + function toManyToManyPathMap(referenceMap) { + if (!referenceMap) { + return void 0; + } + const map2 = BuilderState.createManyToManyPathMap(); + referenceMap.forEach(([fileId, fileIdListId]) => map2.set(toFilePath(fileId), toFilePathsSet(fileIdListId))); + return map2; + } } - function releaseCache(state) { - BuilderState.releaseCache(state); - state.program = void 0; + function getBuildInfoFileVersionMap(program, buildInfoPath, host) { + const buildInfoDirectory = getDirectoryPath(getNormalizedAbsolutePath(buildInfoPath, host.getCurrentDirectory())); + const getCanonicalFileName = createGetCanonicalFileName(host.useCaseSensitiveFileNames()); + const fileInfos = /* @__PURE__ */ new Map(); + let rootIndex = 0; + const roots = []; + program.fileInfos.forEach((fileInfo, index) => { + const path = toPath(program.fileNames[index], buildInfoDirectory, getCanonicalFileName); + const version2 = isString(fileInfo) ? fileInfo : fileInfo.version; + fileInfos.set(path, version2); + if (rootIndex < program.root.length) { + const current = program.root[rootIndex]; + const fileId = index + 1; + if (isArray(current)) { + if (current[0] <= fileId && fileId <= current[1]) { + roots.push(path); + if (current[1] === fileId) + rootIndex++; + } + } else if (current === fileId) { + roots.push(path); + rootIndex++; + } + } + }); + return { fileInfos, roots }; } - function backupBuilderProgramEmitState(state) { - const outFilePath = outFile(state.compilerOptions); - Debug.assert(!state.changedFilesSet.size || outFilePath); + function createRedirectedBuilderProgram(getState, configFileParsingDiagnostics) { return { - affectedFilesPendingEmit: state.affectedFilesPendingEmit && new Map(state.affectedFilesPendingEmit), - seenEmittedFiles: state.seenEmittedFiles && new Map(state.seenEmittedFiles), - programEmitPending: state.programEmitPending, - emitSignatures: state.emitSignatures && new Map(state.emitSignatures), - outSignature: state.outSignature, - latestChangedDtsFile: state.latestChangedDtsFile, - hasChangedEmitSignature: state.hasChangedEmitSignature, - changedFilesSet: outFilePath ? new Set(state.changedFilesSet) : void 0 + getState: notImplemented, + saveEmitState: noop, + restoreEmitState: noop, + getProgram, + getProgramOrUndefined: () => getState().program, + releaseProgram: () => getState().program = void 0, + getCompilerOptions: () => getState().compilerOptions, + getSourceFile: (fileName) => getProgram().getSourceFile(fileName), + getSourceFiles: () => getProgram().getSourceFiles(), + getOptionsDiagnostics: (cancellationToken) => getProgram().getOptionsDiagnostics(cancellationToken), + getGlobalDiagnostics: (cancellationToken) => getProgram().getGlobalDiagnostics(cancellationToken), + getConfigFileParsingDiagnostics: () => configFileParsingDiagnostics, + getSyntacticDiagnostics: (sourceFile, cancellationToken) => getProgram().getSyntacticDiagnostics(sourceFile, cancellationToken), + getDeclarationDiagnostics: (sourceFile, cancellationToken) => getProgram().getDeclarationDiagnostics(sourceFile, cancellationToken), + getSemanticDiagnostics: (sourceFile, cancellationToken) => getProgram().getSemanticDiagnostics(sourceFile, cancellationToken), + emit: (sourceFile, writeFile2, cancellationToken, emitOnlyDts, customTransformers) => getProgram().emit(sourceFile, writeFile2, cancellationToken, emitOnlyDts, customTransformers), + emitBuildInfo: (writeFile2, cancellationToken) => getProgram().emitBuildInfo(writeFile2, cancellationToken), + getAllDependencies: notImplemented, + getCurrentDirectory: () => getProgram().getCurrentDirectory(), + close: noop }; + function getProgram() { + return Debug.checkDefined(getState().program); + } + } + var BuilderFileEmit, BuilderProgramKind; + var init_builder = __esm({ + "src/compiler/builder.ts"() { + "use strict"; + init_ts2(); + BuilderFileEmit = /* @__PURE__ */ ((BuilderFileEmit2) => { + BuilderFileEmit2[BuilderFileEmit2["None"] = 0] = "None"; + BuilderFileEmit2[BuilderFileEmit2["Js"] = 1] = "Js"; + BuilderFileEmit2[BuilderFileEmit2["JsMap"] = 2] = "JsMap"; + BuilderFileEmit2[BuilderFileEmit2["JsInlineMap"] = 4] = "JsInlineMap"; + BuilderFileEmit2[BuilderFileEmit2["Dts"] = 8] = "Dts"; + BuilderFileEmit2[BuilderFileEmit2["DtsMap"] = 16] = "DtsMap"; + BuilderFileEmit2[BuilderFileEmit2["AllJs"] = 7] = "AllJs"; + BuilderFileEmit2[BuilderFileEmit2["AllDts"] = 24] = "AllDts"; + BuilderFileEmit2[BuilderFileEmit2["All"] = 31] = "All"; + return BuilderFileEmit2; + })(BuilderFileEmit || {}); + BuilderProgramKind = /* @__PURE__ */ ((BuilderProgramKind2) => { + BuilderProgramKind2[BuilderProgramKind2["SemanticDiagnosticsBuilderProgram"] = 0] = "SemanticDiagnosticsBuilderProgram"; + BuilderProgramKind2[BuilderProgramKind2["EmitAndSemanticDiagnosticsBuilderProgram"] = 1] = "EmitAndSemanticDiagnosticsBuilderProgram"; + return BuilderProgramKind2; + })(BuilderProgramKind || {}); + } + }); + + // src/compiler/builderPublic.ts + function createSemanticDiagnosticsBuilderProgram(newProgramOrRootNames, hostOrOptions, oldProgramOrHost, configFileParsingDiagnosticsOrOldProgram, configFileParsingDiagnostics, projectReferences) { + return createBuilderProgram(0 /* SemanticDiagnosticsBuilderProgram */, getBuilderCreationParameters(newProgramOrRootNames, hostOrOptions, oldProgramOrHost, configFileParsingDiagnosticsOrOldProgram, configFileParsingDiagnostics, projectReferences)); } - function restoreBuilderProgramEmitState(state, savedEmitState) { - state.affectedFilesPendingEmit = savedEmitState.affectedFilesPendingEmit; - state.seenEmittedFiles = savedEmitState.seenEmittedFiles; - state.programEmitPending = savedEmitState.programEmitPending; - state.emitSignatures = savedEmitState.emitSignatures; - state.outSignature = savedEmitState.outSignature; - state.latestChangedDtsFile = savedEmitState.latestChangedDtsFile; - state.hasChangedEmitSignature = savedEmitState.hasChangedEmitSignature; - if (savedEmitState.changedFilesSet) - state.changedFilesSet = savedEmitState.changedFilesSet; + function createEmitAndSemanticDiagnosticsBuilderProgram(newProgramOrRootNames, hostOrOptions, oldProgramOrHost, configFileParsingDiagnosticsOrOldProgram, configFileParsingDiagnostics, projectReferences) { + return createBuilderProgram(1 /* EmitAndSemanticDiagnosticsBuilderProgram */, getBuilderCreationParameters(newProgramOrRootNames, hostOrOptions, oldProgramOrHost, configFileParsingDiagnosticsOrOldProgram, configFileParsingDiagnostics, projectReferences)); } - function assertSourceFileOkWithoutNextAffectedCall(state, sourceFile) { - Debug.assert(!sourceFile || !state.affectedFiles || state.affectedFiles[state.affectedFilesIndex - 1] !== sourceFile || !state.semanticDiagnosticsPerFile.has(sourceFile.resolvedPath)); + function createAbstractBuilder(newProgramOrRootNames, hostOrOptions, oldProgramOrHost, configFileParsingDiagnosticsOrOldProgram, configFileParsingDiagnostics, projectReferences) { + const { newProgram, configFileParsingDiagnostics: newConfigFileParsingDiagnostics } = getBuilderCreationParameters(newProgramOrRootNames, hostOrOptions, oldProgramOrHost, configFileParsingDiagnosticsOrOldProgram, configFileParsingDiagnostics, projectReferences); + return createRedirectedBuilderProgram(() => ({ program: newProgram, compilerOptions: newProgram.getCompilerOptions() }), newConfigFileParsingDiagnostics); } - function getNextAffectedFile(state, cancellationToken, host) { - var _a, _b; - while (true) { - const { affectedFiles } = state; - if (affectedFiles) { - const seenAffectedFiles = state.seenAffectedFiles; - let affectedFilesIndex = state.affectedFilesIndex; - while (affectedFilesIndex < affectedFiles.length) { - const affectedFile = affectedFiles[affectedFilesIndex]; - if (!seenAffectedFiles.has(affectedFile.resolvedPath)) { - state.affectedFilesIndex = affectedFilesIndex; - addToAffectedFilesPendingEmit(state, affectedFile.resolvedPath, getBuilderFileEmit(state.compilerOptions)); - handleDtsMayChangeOfAffectedFile( - state, - affectedFile, - cancellationToken, - host - ); - return affectedFile; - } - affectedFilesIndex++; - } - state.changedFilesSet.delete(state.currentChangedFilePath); - state.currentChangedFilePath = void 0; - (_a = state.oldSignatures) == null ? void 0 : _a.clear(); - (_b = state.oldExportedModulesMap) == null ? void 0 : _b.clear(); - state.affectedFiles = void 0; - } - const nextKey = state.changedFilesSet.keys().next(); - if (nextKey.done) { - return void 0; - } - const program = Debug.checkDefined(state.program); - const compilerOptions = program.getCompilerOptions(); - if (outFile(compilerOptions)) { - Debug.assert(!state.semanticDiagnosticsPerFile); - return program; - } - state.affectedFiles = BuilderState.getFilesAffectedByWithOldState( - state, - program, - nextKey.value, - cancellationToken, - host - ); - state.currentChangedFilePath = nextKey.value; - state.affectedFilesIndex = 0; - if (!state.seenAffectedFiles) - state.seenAffectedFiles = /* @__PURE__ */ new Set(); + var init_builderPublic = __esm({ + "src/compiler/builderPublic.ts"() { + "use strict"; + init_ts2(); + } + }); + + // src/compiler/resolutionCache.ts + function removeIgnoredPath(path) { + if (endsWith(path, "/node_modules/.staging")) { + return removeSuffix(path, "/.staging"); } + return some(ignoredPaths, (searchPath) => path.includes(searchPath)) ? void 0 : path; } - function clearAffectedFilesPendingEmit(state, emitOnlyDtsFiles) { - var _a; - if (!((_a = state.affectedFilesPendingEmit) == null ? void 0 : _a.size)) - return; - if (!emitOnlyDtsFiles) - return state.affectedFilesPendingEmit = void 0; - state.affectedFilesPendingEmit.forEach((emitKind, path) => { - const pending = emitKind & 7 /* AllJs */; - if (!pending) - state.affectedFilesPendingEmit.delete(path); - else - state.affectedFilesPendingEmit.set(path, pending); - }); + function perceivedOsRootLengthForWatching(pathComponents2, length2) { + if (length2 <= 1) + return 1; + let indexAfterOsRoot = 1; + let isDosStyle = pathComponents2[0].search(/[a-zA-Z]:/) === 0; + if (pathComponents2[0] !== directorySeparator && !isDosStyle && // Non dos style paths + pathComponents2[1].search(/[a-zA-Z]\$$/) === 0) { + if (length2 === 2) + return 2; + indexAfterOsRoot = 2; + isDosStyle = true; + } + if (isDosStyle && !pathComponents2[indexAfterOsRoot].match(/^users$/i)) { + return indexAfterOsRoot; + } + if (pathComponents2[indexAfterOsRoot].match(/^workspaces$/i)) { + return indexAfterOsRoot + 1; + } + return indexAfterOsRoot + 2; } - function getNextAffectedFilePendingEmit(state, emitOnlyDtsFiles) { - var _a; - if (!((_a = state.affectedFilesPendingEmit) == null ? void 0 : _a.size)) - return void 0; - return forEachEntry(state.affectedFilesPendingEmit, (emitKind, path) => { - var _a2; - const affectedFile = state.program.getSourceFileByPath(path); - if (!affectedFile || !sourceFileMayBeEmitted(affectedFile, state.program)) { - state.affectedFilesPendingEmit.delete(path); - return void 0; - } - const seenKind = (_a2 = state.seenEmittedFiles) == null ? void 0 : _a2.get(affectedFile.resolvedPath); - let pendingKind = getPendingEmitKind(emitKind, seenKind); - if (emitOnlyDtsFiles) - pendingKind = pendingKind & 24 /* AllDts */; - if (pendingKind) - return { affectedFile, emitKind: pendingKind }; - }); + function canWatchDirectoryOrFile(pathComponents2, length2) { + if (length2 === void 0) + length2 = pathComponents2.length; + if (length2 <= 2) + return false; + const perceivedOsRootLength = perceivedOsRootLengthForWatching(pathComponents2, length2); + return length2 > perceivedOsRootLength + 1; } - function removeDiagnosticsOfLibraryFiles(state) { - if (!state.cleanedDiagnosticsOfLibFiles) { - state.cleanedDiagnosticsOfLibFiles = true; - const program = Debug.checkDefined(state.program); - const options = program.getCompilerOptions(); - forEach( - program.getSourceFiles(), - (f) => program.isSourceFileDefaultLibrary(f) && !skipTypeChecking(f, options, program) && removeSemanticDiagnosticsOf(state, f.resolvedPath) - ); + function canWatchAtTypes(atTypes) { + return canWatchAffectedPackageJsonOrNodeModulesOfAtTypes(getDirectoryPath(atTypes)); + } + function isInDirectoryPath(dirComponents, fileOrDirComponents) { + if (fileOrDirComponents.length < fileOrDirComponents.length) + return false; + for (let i = 0; i < dirComponents.length; i++) { + if (fileOrDirComponents[i] !== dirComponents[i]) + return false; } + return true; } - function handleDtsMayChangeOfAffectedFile(state, affectedFile, cancellationToken, host) { - removeSemanticDiagnosticsOf(state, affectedFile.resolvedPath); - if (state.allFilesExcludingDefaultLibraryFile === state.affectedFiles) { - removeDiagnosticsOfLibraryFiles(state); - BuilderState.updateShapeSignature( - state, - Debug.checkDefined(state.program), - affectedFile, - cancellationToken, - host - ); - return; + function canWatchAffectedPackageJsonOrNodeModulesOfAtTypes(fileOrDirPath) { + return canWatchDirectoryOrFile(getPathComponents(fileOrDirPath)); + } + function canWatchAffectingLocation(filePath) { + return canWatchAffectedPackageJsonOrNodeModulesOfAtTypes(filePath); + } + function getDirectoryToWatchFailedLookupLocation(failedLookupLocation, failedLookupLocationPath, rootDir, rootPath, rootPathComponents, getCurrentDirectory) { + const failedLookupPathComponents = getPathComponents(failedLookupLocationPath); + failedLookupLocation = isRootedDiskPath(failedLookupLocation) ? normalizePath(failedLookupLocation) : getNormalizedAbsolutePath(failedLookupLocation, getCurrentDirectory()); + const failedLookupComponents = getPathComponents(failedLookupLocation); + const perceivedOsRootLength = perceivedOsRootLengthForWatching(failedLookupPathComponents, failedLookupPathComponents.length); + if (failedLookupPathComponents.length <= perceivedOsRootLength + 1) + return void 0; + const nodeModulesIndex = failedLookupPathComponents.indexOf("node_modules"); + if (nodeModulesIndex !== -1 && nodeModulesIndex + 1 <= perceivedOsRootLength + 1) + return void 0; + if (isInDirectoryPath(rootPathComponents, failedLookupPathComponents)) { + if (failedLookupPathComponents.length > rootPathComponents.length + 1) { + return getDirectoryOfFailedLookupWatch(failedLookupComponents, failedLookupPathComponents, Math.max(rootPathComponents.length + 1, perceivedOsRootLength + 1)); + } else { + return { + dir: rootDir, + dirPath: rootPath, + nonRecursive: true + }; + } } - if (state.compilerOptions.assumeChangesOnlyAffectDirectDependencies) - return; - handleDtsMayChangeOfReferencingExportOfAffectedFile( - state, - affectedFile, - cancellationToken, - host + return getDirectoryToWatchFromFailedLookupLocationDirectory( + failedLookupComponents, + failedLookupPathComponents, + failedLookupPathComponents.length - 1, + perceivedOsRootLength, + nodeModulesIndex, + rootPathComponents ); } - function handleDtsMayChangeOf(state, path, cancellationToken, host) { - removeSemanticDiagnosticsOf(state, path); - if (!state.changedFilesSet.has(path)) { - const program = Debug.checkDefined(state.program); - const sourceFile = program.getSourceFileByPath(path); - if (sourceFile) { - BuilderState.updateShapeSignature( - state, - program, - sourceFile, - cancellationToken, - host, - /*useFileVersionAsSignature*/ - true - ); - if (getEmitDeclarations(state.compilerOptions)) { - addToAffectedFilesPendingEmit(state, path, state.compilerOptions.declarationMap ? 24 /* AllDts */ : 8 /* Dts */); - } + function getDirectoryToWatchFromFailedLookupLocationDirectory(dirComponents, dirPathComponents, dirPathComponentsLength, perceivedOsRootLength, nodeModulesIndex, rootPathComponents) { + if (nodeModulesIndex !== -1) { + return getDirectoryOfFailedLookupWatch(dirComponents, dirPathComponents, nodeModulesIndex + 1); + } + let nonRecursive = true; + let length2 = dirPathComponentsLength; + for (let i = 0; i < dirPathComponentsLength; i++) { + if (dirPathComponents[i] !== rootPathComponents[i]) { + nonRecursive = false; + length2 = Math.max(i + 1, perceivedOsRootLength + 1); + break; } } + return getDirectoryOfFailedLookupWatch(dirComponents, dirPathComponents, length2, nonRecursive); } - function removeSemanticDiagnosticsOf(state, path) { - if (!state.semanticDiagnosticsFromOldState) { - return true; + function getDirectoryOfFailedLookupWatch(dirComponents, dirPathComponents, length2, nonRecursive) { + return { + dir: getPathFromPathComponents(dirComponents, length2), + dirPath: getPathFromPathComponents(dirPathComponents, length2), + nonRecursive + }; + } + function getDirectoryToWatchFailedLookupLocationFromTypeRoot(typeRoot, typeRootPath, rootPath, rootPathComponents, getCurrentDirectory, filterCustomPath) { + const typeRootPathComponents = getPathComponents(typeRootPath); + if (isInDirectoryPath(rootPathComponents, typeRootPathComponents)) { + return rootPath; } - state.semanticDiagnosticsFromOldState.delete(path); - state.semanticDiagnosticsPerFile.delete(path); - return !state.semanticDiagnosticsFromOldState.size; + typeRoot = isRootedDiskPath(typeRoot) ? normalizePath(typeRoot) : getNormalizedAbsolutePath(typeRoot, getCurrentDirectory()); + const toWatch = getDirectoryToWatchFromFailedLookupLocationDirectory( + getPathComponents(typeRoot), + typeRootPathComponents, + typeRootPathComponents.length, + perceivedOsRootLengthForWatching(typeRootPathComponents, typeRootPathComponents.length), + typeRootPathComponents.indexOf("node_modules"), + rootPathComponents + ); + return toWatch && filterCustomPath(toWatch.dirPath) ? toWatch.dirPath : void 0; } - function isChangedSignature(state, path) { - const oldSignature = Debug.checkDefined(state.oldSignatures).get(path) || void 0; - const newSignature = Debug.checkDefined(state.fileInfos.get(path)).signature; - return newSignature !== oldSignature; + function getRootDirectoryOfResolutionCache(rootDirForResolution, getCurrentDirectory) { + const normalized = getNormalizedAbsolutePath(rootDirForResolution, getCurrentDirectory()); + return !isDiskPathRoot(normalized) ? removeTrailingDirectorySeparator(normalized) : normalized; } - function handleDtsMayChangeOfGlobalScope(state, filePath, cancellationToken, host) { - var _a; - if (!((_a = state.fileInfos.get(filePath)) == null ? void 0 : _a.affectsGlobalScope)) - return false; - BuilderState.getAllFilesExcludingDefaultLibraryFile( - state, - state.program, - /*firstSourceFile*/ - void 0 - ).forEach((file) => handleDtsMayChangeOf( - state, - file.resolvedPath, - cancellationToken, - host - )); - removeDiagnosticsOfLibraryFiles(state); - return true; + function getRootPathSplitLength(rootPath) { + return rootPath.split(directorySeparator).length - (hasTrailingDirectorySeparator(rootPath) ? 1 : 0); } - function handleDtsMayChangeOfReferencingExportOfAffectedFile(state, affectedFile, cancellationToken, host) { + function getModuleResolutionHost(resolutionHost) { var _a; - if (!state.exportedModulesMap || !state.changedFilesSet.has(affectedFile.resolvedPath)) - return; - if (!isChangedSignature(state, affectedFile.resolvedPath)) - return; - if (getIsolatedModules(state.compilerOptions)) { - const seenFileNamesMap = /* @__PURE__ */ new Map(); - seenFileNamesMap.set(affectedFile.resolvedPath, true); - const queue = BuilderState.getReferencedByPaths(state, affectedFile.resolvedPath); - while (queue.length > 0) { - const currentPath = queue.pop(); - if (!seenFileNamesMap.has(currentPath)) { - seenFileNamesMap.set(currentPath, true); - if (handleDtsMayChangeOfGlobalScope(state, currentPath, cancellationToken, host)) - return; - handleDtsMayChangeOf(state, currentPath, cancellationToken, host); - if (isChangedSignature(state, currentPath)) { - const currentSourceFile = Debug.checkDefined(state.program).getSourceFileByPath(currentPath); - queue.push(...BuilderState.getReferencedByPaths(state, currentSourceFile.resolvedPath)); - } - } - } + return ((_a = resolutionHost.getCompilerHost) == null ? void 0 : _a.call(resolutionHost)) || resolutionHost; + } + function createModuleResolutionLoaderUsingGlobalCache(containingFile, redirectedReference, options, resolutionHost, moduleResolutionCache) { + return { + nameAndMode: moduleResolutionNameAndModeGetter, + resolve: (moduleName, resoluionMode) => resolveModuleNameUsingGlobalCache( + resolutionHost, + moduleResolutionCache, + moduleName, + containingFile, + options, + redirectedReference, + resoluionMode + ) + }; + } + function resolveModuleNameUsingGlobalCache(resolutionHost, moduleResolutionCache, moduleName, containingFile, compilerOptions, redirectedReference, mode) { + const host = getModuleResolutionHost(resolutionHost); + const primaryResult = resolveModuleName(moduleName, containingFile, compilerOptions, host, moduleResolutionCache, redirectedReference, mode); + if (!resolutionHost.getGlobalCache) { + return primaryResult; } - const seenFileAndExportsOfFile = /* @__PURE__ */ new Set(); - (_a = state.exportedModulesMap.getKeys(affectedFile.resolvedPath)) == null ? void 0 : _a.forEach((exportedFromPath) => { - if (handleDtsMayChangeOfGlobalScope(state, exportedFromPath, cancellationToken, host)) - return true; - const references = state.referencedMap.getKeys(exportedFromPath); - return references && forEachKey( - references, - (filePath) => handleDtsMayChangeOfFileAndExportsOfFile( - state, - filePath, - seenFileAndExportsOfFile, - cancellationToken, - host - ) + const globalCache = resolutionHost.getGlobalCache(); + if (globalCache !== void 0 && !isExternalModuleNameRelative(moduleName) && !(primaryResult.resolvedModule && extensionIsTS(primaryResult.resolvedModule.extension))) { + const { resolvedModule, failedLookupLocations, affectingLocations, resolutionDiagnostics } = loadModuleFromGlobalCache( + Debug.checkDefined(resolutionHost.globalCacheResolutionModuleName)(moduleName), + resolutionHost.projectName, + compilerOptions, + host, + globalCache, + moduleResolutionCache ); - }); + if (resolvedModule) { + primaryResult.resolvedModule = resolvedModule; + primaryResult.failedLookupLocations = updateResolutionField(primaryResult.failedLookupLocations, failedLookupLocations); + primaryResult.affectingLocations = updateResolutionField(primaryResult.affectingLocations, affectingLocations); + primaryResult.resolutionDiagnostics = updateResolutionField(primaryResult.resolutionDiagnostics, resolutionDiagnostics); + return primaryResult; + } + } + return primaryResult; } - function handleDtsMayChangeOfFileAndExportsOfFile(state, filePath, seenFileAndExportsOfFile, cancellationToken, host) { - var _a, _b; - if (!tryAddToSet(seenFileAndExportsOfFile, filePath)) - return void 0; - if (handleDtsMayChangeOfGlobalScope(state, filePath, cancellationToken, host)) - return true; - handleDtsMayChangeOf(state, filePath, cancellationToken, host); - (_a = state.exportedModulesMap.getKeys(filePath)) == null ? void 0 : _a.forEach( - (exportedFromPath) => handleDtsMayChangeOfFileAndExportsOfFile( - state, - exportedFromPath, - seenFileAndExportsOfFile, - cancellationToken, - host - ) + function createResolutionCache(resolutionHost, rootDirForResolution, logChangesWhenResolvingModule) { + let filesWithChangedSetOfUnresolvedImports; + let filesWithInvalidatedResolutions; + let filesWithInvalidatedNonRelativeUnresolvedImports; + const nonRelativeExternalModuleResolutions = createMultiMap(); + const resolutionsWithFailedLookups = /* @__PURE__ */ new Set(); + const resolutionsWithOnlyAffectingLocations = /* @__PURE__ */ new Set(); + const resolvedFileToResolution = /* @__PURE__ */ new Map(); + const impliedFormatPackageJsons = /* @__PURE__ */ new Map(); + let hasChangedAutomaticTypeDirectiveNames = false; + let affectingPathChecksForFile; + let affectingPathChecks; + let failedLookupChecks; + let startsWithPathChecks; + let isInDirectoryChecks; + let allModuleAndTypeResolutionsAreInvalidated = false; + const getCurrentDirectory = memoize(() => resolutionHost.getCurrentDirectory()); + const cachedDirectoryStructureHost = resolutionHost.getCachedDirectoryStructureHost(); + const resolvedModuleNames = /* @__PURE__ */ new Map(); + const moduleResolutionCache = createModuleResolutionCache( + getCurrentDirectory(), + resolutionHost.getCanonicalFileName, + resolutionHost.getCompilationSettings() ); - (_b = state.referencedMap.getKeys(filePath)) == null ? void 0 : _b.forEach( - (referencingFilePath) => !seenFileAndExportsOfFile.has(referencingFilePath) && // Not already removed diagnostic file - handleDtsMayChangeOf( - // Dont add to seen since this is not yet done with the export removal - state, - referencingFilePath, - cancellationToken, - host - ) + const resolvedTypeReferenceDirectives = /* @__PURE__ */ new Map(); + const typeReferenceDirectiveResolutionCache = createTypeReferenceDirectiveResolutionCache( + getCurrentDirectory(), + resolutionHost.getCanonicalFileName, + resolutionHost.getCompilationSettings(), + moduleResolutionCache.getPackageJsonInfoCache(), + moduleResolutionCache.optionsToRedirectsKey ); - return void 0; - } - function getSemanticDiagnosticsOfFile(state, sourceFile, cancellationToken) { - return concatenate( - getBinderAndCheckerDiagnosticsOfFile(state, sourceFile, cancellationToken), - Debug.checkDefined(state.program).getProgramDiagnostics(sourceFile) + const resolvedLibraries = /* @__PURE__ */ new Map(); + const libraryResolutionCache = createModuleResolutionCache( + getCurrentDirectory(), + resolutionHost.getCanonicalFileName, + getOptionsForLibraryResolution(resolutionHost.getCompilationSettings()), + moduleResolutionCache.getPackageJsonInfoCache() ); - } - function getBinderAndCheckerDiagnosticsOfFile(state, sourceFile, cancellationToken) { - const path = sourceFile.resolvedPath; - if (state.semanticDiagnosticsPerFile) { - const cachedDiagnostics = state.semanticDiagnosticsPerFile.get(path); - if (cachedDiagnostics) { - return filterSemanticDiagnostics(cachedDiagnostics, state.compilerOptions); + const directoryWatchesOfFailedLookups = /* @__PURE__ */ new Map(); + const fileWatchesOfAffectingLocations = /* @__PURE__ */ new Map(); + const rootDir = getRootDirectoryOfResolutionCache(rootDirForResolution, getCurrentDirectory); + const rootPath = resolutionHost.toPath(rootDir); + const rootPathComponents = getPathComponents(rootPath); + const typeRootsWatches = /* @__PURE__ */ new Map(); + return { + rootDirForResolution, + resolvedModuleNames, + resolvedTypeReferenceDirectives, + resolvedLibraries, + resolvedFileToResolution, + resolutionsWithFailedLookups, + resolutionsWithOnlyAffectingLocations, + directoryWatchesOfFailedLookups, + fileWatchesOfAffectingLocations, + watchFailedLookupLocationsOfExternalModuleResolutions, + getModuleResolutionCache: () => moduleResolutionCache, + startRecordingFilesWithChangedResolutions, + finishRecordingFilesWithChangedResolutions, + // perDirectoryResolvedModuleNames and perDirectoryResolvedTypeReferenceDirectives could be non empty if there was exception during program update + // (between startCachingPerDirectoryResolution and finishCachingPerDirectoryResolution) + startCachingPerDirectoryResolution, + finishCachingPerDirectoryResolution, + resolveModuleNameLiterals, + resolveTypeReferenceDirectiveReferences, + resolveLibrary: resolveLibrary2, + resolveSingleModuleNameWithoutWatching, + removeResolutionsFromProjectReferenceRedirects, + removeResolutionsOfFile, + hasChangedAutomaticTypeDirectiveNames: () => hasChangedAutomaticTypeDirectiveNames, + invalidateResolutionOfFile, + invalidateResolutionsOfFailedLookupLocations, + setFilesWithInvalidatedNonRelativeUnresolvedImports, + createHasInvalidatedResolutions, + isFileWithInvalidatedNonRelativeUnresolvedImports, + updateTypeRootsWatch, + closeTypeRootsWatch, + clear: clear2, + onChangesAffectModuleResolution + }; + function getResolvedModule(resolution) { + return resolution.resolvedModule; + } + function getResolvedTypeReferenceDirective(resolution) { + return resolution.resolvedTypeReferenceDirective; + } + function clear2() { + clearMap(directoryWatchesOfFailedLookups, closeFileWatcherOf); + clearMap(fileWatchesOfAffectingLocations, closeFileWatcherOf); + nonRelativeExternalModuleResolutions.clear(); + closeTypeRootsWatch(); + resolvedModuleNames.clear(); + resolvedTypeReferenceDirectives.clear(); + resolvedFileToResolution.clear(); + resolutionsWithFailedLookups.clear(); + resolutionsWithOnlyAffectingLocations.clear(); + failedLookupChecks = void 0; + startsWithPathChecks = void 0; + isInDirectoryChecks = void 0; + affectingPathChecks = void 0; + affectingPathChecksForFile = void 0; + allModuleAndTypeResolutionsAreInvalidated = false; + moduleResolutionCache.clear(); + typeReferenceDirectiveResolutionCache.clear(); + moduleResolutionCache.update(resolutionHost.getCompilationSettings()); + typeReferenceDirectiveResolutionCache.update(resolutionHost.getCompilationSettings()); + libraryResolutionCache.clear(); + impliedFormatPackageJsons.clear(); + resolvedLibraries.clear(); + hasChangedAutomaticTypeDirectiveNames = false; + } + function onChangesAffectModuleResolution() { + allModuleAndTypeResolutionsAreInvalidated = true; + moduleResolutionCache.clearAllExceptPackageJsonInfoCache(); + typeReferenceDirectiveResolutionCache.clearAllExceptPackageJsonInfoCache(); + moduleResolutionCache.update(resolutionHost.getCompilationSettings()); + typeReferenceDirectiveResolutionCache.update(resolutionHost.getCompilationSettings()); + } + function startRecordingFilesWithChangedResolutions() { + filesWithChangedSetOfUnresolvedImports = []; + } + function finishRecordingFilesWithChangedResolutions() { + const collected = filesWithChangedSetOfUnresolvedImports; + filesWithChangedSetOfUnresolvedImports = void 0; + return collected; + } + function isFileWithInvalidatedNonRelativeUnresolvedImports(path) { + if (!filesWithInvalidatedNonRelativeUnresolvedImports) { + return false; } + const value = filesWithInvalidatedNonRelativeUnresolvedImports.get(path); + return !!value && !!value.length; } - const diagnostics = Debug.checkDefined(state.program).getBindAndCheckDiagnostics(sourceFile, cancellationToken); - if (state.semanticDiagnosticsPerFile) { - state.semanticDiagnosticsPerFile.set(path, diagnostics); + function createHasInvalidatedResolutions(customHasInvalidatedResolutions, customHasInvalidatedLibResolutions) { + invalidateResolutionsOfFailedLookupLocations(); + const collected = filesWithInvalidatedResolutions; + filesWithInvalidatedResolutions = void 0; + return { + hasInvalidatedResolutions: (path) => customHasInvalidatedResolutions(path) || allModuleAndTypeResolutionsAreInvalidated || !!(collected == null ? void 0 : collected.has(path)) || isFileWithInvalidatedNonRelativeUnresolvedImports(path), + hasInvalidatedLibResolutions: (libFileName) => { + var _a; + return customHasInvalidatedLibResolutions(libFileName) || !!((_a = resolvedLibraries == null ? void 0 : resolvedLibraries.get(libFileName)) == null ? void 0 : _a.isInvalidated); + } + }; } - return filterSemanticDiagnostics(diagnostics, state.compilerOptions); - } - function isProgramBundleEmitBuildInfo(info) { - return !!outFile(info.options || {}); - } - function getBuildInfo2(state, bundle) { - var _a, _b, _c; - const currentDirectory = Debug.checkDefined(state.program).getCurrentDirectory(); - const buildInfoDirectory = getDirectoryPath(getNormalizedAbsolutePath(getTsBuildInfoEmitOutputFilePath(state.compilerOptions), currentDirectory)); - const latestChangedDtsFile = state.latestChangedDtsFile ? relativeToBuildInfoEnsuringAbsolutePath(state.latestChangedDtsFile) : void 0; - const fileNames = []; - const fileNameToFileId = /* @__PURE__ */ new Map(); - const root = []; - if (outFile(state.compilerOptions)) { - const fileInfos2 = arrayFrom(state.fileInfos.entries(), ([key, value]) => { - const fileId = toFileId(key); - tryAddRoot(key, fileId); - return value.impliedFormat ? { version: value.version, impliedFormat: value.impliedFormat, signature: void 0, affectsGlobalScope: void 0 } : value.version; + function startCachingPerDirectoryResolution() { + moduleResolutionCache.isReadonly = void 0; + typeReferenceDirectiveResolutionCache.isReadonly = void 0; + libraryResolutionCache.isReadonly = void 0; + moduleResolutionCache.getPackageJsonInfoCache().isReadonly = void 0; + moduleResolutionCache.clearAllExceptPackageJsonInfoCache(); + typeReferenceDirectiveResolutionCache.clearAllExceptPackageJsonInfoCache(); + libraryResolutionCache.clearAllExceptPackageJsonInfoCache(); + nonRelativeExternalModuleResolutions.forEach(watchFailedLookupLocationOfNonRelativeModuleResolutions); + nonRelativeExternalModuleResolutions.clear(); + } + function cleanupLibResolutionWatching(newProgram) { + resolvedLibraries.forEach((resolution, libFileName) => { + var _a; + if (!((_a = newProgram == null ? void 0 : newProgram.resolvedLibReferences) == null ? void 0 : _a.has(libFileName))) { + stopWatchFailedLookupLocationOfResolution( + resolution, + resolutionHost.toPath(getInferredLibraryNameResolveFrom(resolutionHost.getCompilationSettings(), getCurrentDirectory(), libFileName)), + getResolvedModule + ); + resolvedLibraries.delete(libFileName); + } }); - const program2 = { - fileNames, - fileInfos: fileInfos2, - root, - options: convertToProgramBuildInfoCompilerOptions(state.compilerOptions), - outSignature: state.outSignature, - latestChangedDtsFile, - pendingEmit: !state.programEmitPending ? void 0 : ( - // Pending is undefined or None is encoded as undefined - state.programEmitPending === getBuilderFileEmit(state.compilerOptions) ? false : ( - // Pending emit is same as deteremined by compilerOptions - state.programEmitPending - ) - ) - // Actual value - }; - const { js, dts, commonSourceDirectory, sourceFiles } = bundle; - state.bundle = bundle = { - commonSourceDirectory, - sourceFiles, - js: js || (!state.compilerOptions.emitDeclarationOnly ? (_a = state.bundle) == null ? void 0 : _a.js : void 0), - dts: dts || (getEmitDeclarations(state.compilerOptions) ? (_b = state.bundle) == null ? void 0 : _b.dts : void 0) - }; - return createBuildInfo(program2, bundle); } - let fileIdsList; - let fileNamesToFileIdListId; - let emitSignatures; - const fileInfos = arrayFrom(state.fileInfos.entries(), ([key, value]) => { - var _a2, _b2; - const fileId = toFileId(key); - tryAddRoot(key, fileId); - Debug.assert(fileNames[fileId - 1] === relativeToBuildInfo(key)); - const oldSignature = (_a2 = state.oldSignatures) == null ? void 0 : _a2.get(key); - const actualSignature = oldSignature !== void 0 ? oldSignature || void 0 : value.signature; - if (state.compilerOptions.composite) { - const file = state.program.getSourceFileByPath(key); - if (!isJsonSourceFile(file) && sourceFileMayBeEmitted(file, state.program)) { - const emitSignature = (_b2 = state.emitSignatures) == null ? void 0 : _b2.get(key); - if (emitSignature !== actualSignature) { - (emitSignatures || (emitSignatures = [])).push(emitSignature === void 0 ? fileId : ( - // There is no emit, encode as false - // fileId, signature: emptyArray if signature only differs in dtsMap option than our own compilerOptions otherwise EmitSignature - [fileId, !isString(emitSignature) && emitSignature[0] === actualSignature ? emptyArray : emitSignature] - )); + function finishCachingPerDirectoryResolution(newProgram, oldProgram) { + filesWithInvalidatedNonRelativeUnresolvedImports = void 0; + allModuleAndTypeResolutionsAreInvalidated = false; + nonRelativeExternalModuleResolutions.forEach(watchFailedLookupLocationOfNonRelativeModuleResolutions); + nonRelativeExternalModuleResolutions.clear(); + if (newProgram !== oldProgram) { + cleanupLibResolutionWatching(newProgram); + newProgram == null ? void 0 : newProgram.getSourceFiles().forEach((newFile) => { + var _a; + const expected = isExternalOrCommonJsModule(newFile) ? ((_a = newFile.packageJsonLocations) == null ? void 0 : _a.length) ?? 0 : 0; + const existing = impliedFormatPackageJsons.get(newFile.path) ?? emptyArray; + for (let i = existing.length; i < expected; i++) { + createFileWatcherOfAffectingLocation( + newFile.packageJsonLocations[i], + /*forResolution*/ + false + ); + } + if (existing.length > expected) { + for (let i = expected; i < existing.length; i++) { + fileWatchesOfAffectingLocations.get(existing[i]).files--; + } + } + if (expected) + impliedFormatPackageJsons.set(newFile.path, newFile.packageJsonLocations); + else + impliedFormatPackageJsons.delete(newFile.path); + }); + impliedFormatPackageJsons.forEach((existing, path) => { + if (!(newProgram == null ? void 0 : newProgram.getSourceFileByPath(path))) { + existing.forEach((location) => fileWatchesOfAffectingLocations.get(location).files--); + impliedFormatPackageJsons.delete(path); + } + }); + } + directoryWatchesOfFailedLookups.forEach(closeDirectoryWatchesOfFailedLookup); + fileWatchesOfAffectingLocations.forEach(closeFileWatcherOfAffectingLocation); + hasChangedAutomaticTypeDirectiveNames = false; + moduleResolutionCache.isReadonly = true; + typeReferenceDirectiveResolutionCache.isReadonly = true; + libraryResolutionCache.isReadonly = true; + moduleResolutionCache.getPackageJsonInfoCache().isReadonly = true; + } + function closeDirectoryWatchesOfFailedLookup(watcher, path) { + if (watcher.refCount === 0) { + directoryWatchesOfFailedLookups.delete(path); + watcher.watcher.close(); + } + } + function closeFileWatcherOfAffectingLocation(watcher, path) { + var _a; + if (watcher.files === 0 && watcher.resolutions === 0 && !((_a = watcher.symlinks) == null ? void 0 : _a.size)) { + fileWatchesOfAffectingLocations.delete(path); + watcher.watcher.close(); + } + } + function resolveNamesWithLocalCache({ + entries, + containingFile, + containingSourceFile, + redirectedReference, + options, + perFileCache, + reusedNames, + loader, + getResolutionWithResolvedFileName, + deferWatchingNonRelativeResolution, + shouldRetryResolution, + logChanges + }) { + const path = resolutionHost.toPath(containingFile); + const resolutionsInFile = perFileCache.get(path) || perFileCache.set(path, createModeAwareCache()).get(path); + const resolvedModules = []; + const hasInvalidatedNonRelativeUnresolvedImport = logChanges && isFileWithInvalidatedNonRelativeUnresolvedImports(path); + const program = resolutionHost.getCurrentProgram(); + const oldRedirect = program && program.getResolvedProjectReferenceToRedirect(containingFile); + const unmatchedRedirects = oldRedirect ? !redirectedReference || redirectedReference.sourceFile.path !== oldRedirect.sourceFile.path : !!redirectedReference; + const seenNamesInFile = createModeAwareCache(); + for (const entry of entries) { + const name = loader.nameAndMode.getName(entry); + const mode = loader.nameAndMode.getMode(entry, containingSourceFile); + let resolution = resolutionsInFile.get(name, mode); + if (!seenNamesInFile.has(name, mode) && (allModuleAndTypeResolutionsAreInvalidated || unmatchedRedirects || !resolution || resolution.isInvalidated || // If the name is unresolved import that was invalidated, recalculate + hasInvalidatedNonRelativeUnresolvedImport && !isExternalModuleNameRelative(name) && shouldRetryResolution(resolution))) { + const existingResolution = resolution; + resolution = loader.resolve(name, mode); + if (resolutionHost.onDiscoveredSymlink && resolutionIsSymlink(resolution)) { + resolutionHost.onDiscoveredSymlink(); + } + resolutionsInFile.set(name, mode, resolution); + if (resolution !== existingResolution) { + watchFailedLookupLocationsOfExternalModuleResolutions(name, resolution, path, getResolutionWithResolvedFileName, deferWatchingNonRelativeResolution); + if (existingResolution) { + stopWatchFailedLookupLocationOfResolution(existingResolution, path, getResolutionWithResolvedFileName); + } + } + if (logChanges && filesWithChangedSetOfUnresolvedImports && !resolutionIsEqualTo(existingResolution, resolution)) { + filesWithChangedSetOfUnresolvedImports.push(path); + logChanges = false; + } + } else { + const host = getModuleResolutionHost(resolutionHost); + if (isTraceEnabled(options, host) && !seenNamesInFile.has(name, mode)) { + const resolved = getResolutionWithResolvedFileName(resolution); + trace( + host, + perFileCache === resolvedModuleNames ? (resolved == null ? void 0 : resolved.resolvedFileName) ? resolved.packageId ? Diagnostics.Reusing_resolution_of_module_0_from_1_of_old_program_it_was_successfully_resolved_to_2_with_Package_ID_3 : Diagnostics.Reusing_resolution_of_module_0_from_1_of_old_program_it_was_successfully_resolved_to_2 : Diagnostics.Reusing_resolution_of_module_0_from_1_of_old_program_it_was_not_resolved : (resolved == null ? void 0 : resolved.resolvedFileName) ? resolved.packageId ? Diagnostics.Reusing_resolution_of_type_reference_directive_0_from_1_of_old_program_it_was_successfully_resolved_to_2_with_Package_ID_3 : Diagnostics.Reusing_resolution_of_type_reference_directive_0_from_1_of_old_program_it_was_successfully_resolved_to_2 : Diagnostics.Reusing_resolution_of_type_reference_directive_0_from_1_of_old_program_it_was_not_resolved, + name, + containingFile, + resolved == null ? void 0 : resolved.resolvedFileName, + (resolved == null ? void 0 : resolved.packageId) && packageIdToString(resolved.packageId) + ); } } + Debug.assert(resolution !== void 0 && !resolution.isInvalidated); + seenNamesInFile.set(name, mode, true); + resolvedModules.push(resolution); } - return value.version === actualSignature ? value.affectsGlobalScope || value.impliedFormat ? ( - // If file version is same as signature, dont serialize signature - { version: value.version, signature: void 0, affectsGlobalScope: value.affectsGlobalScope, impliedFormat: value.impliedFormat } - ) : ( - // If file info only contains version and signature and both are same we can just write string - value.version - ) : actualSignature !== void 0 ? ( - // If signature is not same as version, encode signature in the fileInfo - oldSignature === void 0 ? ( - // If we havent computed signature, use fileInfo as is - value - ) : ( - // Serialize fileInfo with new updated signature - { version: value.version, signature: actualSignature, affectsGlobalScope: value.affectsGlobalScope, impliedFormat: value.impliedFormat } + reusedNames == null ? void 0 : reusedNames.forEach( + (entry) => seenNamesInFile.set( + loader.nameAndMode.getName(entry), + loader.nameAndMode.getMode(entry, containingSourceFile), + true ) - ) : ( - // Signature of the FileInfo is undefined, serialize it as false - { version: value.version, signature: false, affectsGlobalScope: value.affectsGlobalScope, impliedFormat: value.impliedFormat } ); - }); - let referencedMap; - if (state.referencedMap) { - referencedMap = arrayFrom(state.referencedMap.keys()).sort(compareStringsCaseSensitive).map((key) => [ - toFileId(key), - toFileIdListId(state.referencedMap.getValues(key)) - ]); + if (resolutionsInFile.size() !== seenNamesInFile.size()) { + resolutionsInFile.forEach((resolution, name, mode) => { + if (!seenNamesInFile.has(name, mode)) { + stopWatchFailedLookupLocationOfResolution(resolution, path, getResolutionWithResolvedFileName); + resolutionsInFile.delete(name, mode); + } + }); + } + return resolvedModules; + function resolutionIsEqualTo(oldResolution, newResolution) { + if (oldResolution === newResolution) { + return true; + } + if (!oldResolution || !newResolution) { + return false; + } + const oldResult = getResolutionWithResolvedFileName(oldResolution); + const newResult = getResolutionWithResolvedFileName(newResolution); + if (oldResult === newResult) { + return true; + } + if (!oldResult || !newResult) { + return false; + } + return oldResult.resolvedFileName === newResult.resolvedFileName; + } } - let exportedModulesMap; - if (state.exportedModulesMap) { - exportedModulesMap = mapDefined(arrayFrom(state.exportedModulesMap.keys()).sort(compareStringsCaseSensitive), (key) => { - var _a2; - const oldValue = (_a2 = state.oldExportedModulesMap) == null ? void 0 : _a2.get(key); - if (oldValue === void 0) - return [toFileId(key), toFileIdListId(state.exportedModulesMap.getValues(key))]; - if (oldValue) - return [toFileId(key), toFileIdListId(oldValue)]; - return void 0; + function resolveTypeReferenceDirectiveReferences(typeDirectiveReferences, containingFile, redirectedReference, options, containingSourceFile, reusedNames) { + return resolveNamesWithLocalCache({ + entries: typeDirectiveReferences, + containingFile, + containingSourceFile, + redirectedReference, + options, + reusedNames, + perFileCache: resolvedTypeReferenceDirectives, + loader: createTypeReferenceResolutionLoader( + containingFile, + redirectedReference, + options, + getModuleResolutionHost(resolutionHost), + typeReferenceDirectiveResolutionCache + ), + getResolutionWithResolvedFileName: getResolvedTypeReferenceDirective, + shouldRetryResolution: (resolution) => resolution.resolvedTypeReferenceDirective === void 0, + deferWatchingNonRelativeResolution: false }); } - let semanticDiagnosticsPerFile; - if (state.semanticDiagnosticsPerFile) { - for (const key of arrayFrom(state.semanticDiagnosticsPerFile.keys()).sort(compareStringsCaseSensitive)) { - const value = state.semanticDiagnosticsPerFile.get(key); - (semanticDiagnosticsPerFile || (semanticDiagnosticsPerFile = [])).push( - value.length ? [ - toFileId(key), - convertToReusableDiagnostics(value, relativeToBuildInfo) - ] : toFileId(key) - ); - } + function resolveModuleNameLiterals(moduleLiterals, containingFile, redirectedReference, options, containingSourceFile, reusedNames) { + return resolveNamesWithLocalCache({ + entries: moduleLiterals, + containingFile, + containingSourceFile, + redirectedReference, + options, + reusedNames, + perFileCache: resolvedModuleNames, + loader: createModuleResolutionLoaderUsingGlobalCache( + containingFile, + redirectedReference, + options, + resolutionHost, + moduleResolutionCache + ), + getResolutionWithResolvedFileName: getResolvedModule, + shouldRetryResolution: (resolution) => !resolution.resolvedModule || !resolutionExtensionIsTSOrJson(resolution.resolvedModule.extension), + logChanges: logChangesWhenResolvingModule, + deferWatchingNonRelativeResolution: true + // Defer non relative resolution watch because we could be using ambient modules + }); } - let affectedFilesPendingEmit; - if ((_c = state.affectedFilesPendingEmit) == null ? void 0 : _c.size) { - const fullEmitForOptions = getBuilderFileEmit(state.compilerOptions); - const seenFiles = /* @__PURE__ */ new Set(); - for (const path of arrayFrom(state.affectedFilesPendingEmit.keys()).sort(compareStringsCaseSensitive)) { - if (tryAddToSet(seenFiles, path)) { - const file = state.program.getSourceFileByPath(path); - if (!file || !sourceFileMayBeEmitted(file, state.program)) - continue; - const fileId = toFileId(path), pendingEmit = state.affectedFilesPendingEmit.get(path); - (affectedFilesPendingEmit || (affectedFilesPendingEmit = [])).push( - pendingEmit === fullEmitForOptions ? fileId : ( - // Pending full emit per options - pendingEmit === 8 /* Dts */ ? [fileId] : ( - // Pending on Dts only - [fileId, pendingEmit] - ) - ) - // Anything else + function resolveLibrary2(libraryName, resolveFrom, options, libFileName) { + const host = getModuleResolutionHost(resolutionHost); + let resolution = resolvedLibraries == null ? void 0 : resolvedLibraries.get(libFileName); + if (!resolution || resolution.isInvalidated) { + const existingResolution = resolution; + resolution = resolveLibrary(libraryName, resolveFrom, options, host, libraryResolutionCache); + const path = resolutionHost.toPath(resolveFrom); + watchFailedLookupLocationsOfExternalModuleResolutions( + libraryName, + resolution, + path, + getResolvedModule, + /*deferWatchingNonRelativeResolution*/ + false + ); + resolvedLibraries.set(libFileName, resolution); + if (existingResolution) { + stopWatchFailedLookupLocationOfResolution(existingResolution, path, getResolvedModule); + } + } else { + if (isTraceEnabled(options, host)) { + const resolved = getResolvedModule(resolution); + trace( + host, + (resolved == null ? void 0 : resolved.resolvedFileName) ? resolved.packageId ? Diagnostics.Reusing_resolution_of_module_0_from_1_of_old_program_it_was_successfully_resolved_to_2_with_Package_ID_3 : Diagnostics.Reusing_resolution_of_module_0_from_1_of_old_program_it_was_successfully_resolved_to_2 : Diagnostics.Reusing_resolution_of_module_0_from_1_of_old_program_it_was_not_resolved, + libraryName, + resolveFrom, + resolved == null ? void 0 : resolved.resolvedFileName, + (resolved == null ? void 0 : resolved.packageId) && packageIdToString(resolved.packageId) ); } } + return resolution; } - let changeFileSet; - if (state.changedFilesSet.size) { - for (const path of arrayFrom(state.changedFilesSet.keys()).sort(compareStringsCaseSensitive)) { - (changeFileSet || (changeFileSet = [])).push(toFileId(path)); - } + function resolveSingleModuleNameWithoutWatching(moduleName, containingFile) { + var _a, _b; + const path = resolutionHost.toPath(containingFile); + const resolutionsInFile = resolvedModuleNames.get(path); + const resolution = resolutionsInFile == null ? void 0 : resolutionsInFile.get( + moduleName, + /*mode*/ + void 0 + ); + if (resolution && !resolution.isInvalidated) + return resolution; + const data = (_a = resolutionHost.beforeResolveSingleModuleNameWithoutWatching) == null ? void 0 : _a.call(resolutionHost, moduleResolutionCache); + const host = getModuleResolutionHost(resolutionHost); + const result = resolveModuleName( + moduleName, + containingFile, + resolutionHost.getCompilationSettings(), + host, + moduleResolutionCache + ); + (_b = resolutionHost.afterResolveSingleModuleNameWithoutWatching) == null ? void 0 : _b.call(resolutionHost, moduleResolutionCache, moduleName, containingFile, result, data); + return result; } - const program = { - fileNames, - fileInfos, - root, - options: convertToProgramBuildInfoCompilerOptions(state.compilerOptions), - fileIdsList, - referencedMap, - exportedModulesMap, - semanticDiagnosticsPerFile, - affectedFilesPendingEmit, - changeFileSet, - emitSignatures, - latestChangedDtsFile - }; - return createBuildInfo(program, bundle); - function relativeToBuildInfoEnsuringAbsolutePath(path) { - return relativeToBuildInfo(getNormalizedAbsolutePath(path, currentDirectory)); + function isNodeModulesAtTypesDirectory(dirPath) { + return endsWith(dirPath, "/node_modules/@types"); } - function relativeToBuildInfo(path) { - return ensurePathIsNonModuleName(getRelativePathFromDirectory(buildInfoDirectory, path, state.program.getCanonicalFileName)); + function watchFailedLookupLocationsOfExternalModuleResolutions(name, resolution, filePath, getResolutionWithResolvedFileName, deferWatchingNonRelativeResolution) { + var _a; + if (resolution.refCount) { + resolution.refCount++; + Debug.assertIsDefined(resolution.files); + } else { + resolution.refCount = 1; + Debug.assert(!((_a = resolution.files) == null ? void 0 : _a.size)); + if (!deferWatchingNonRelativeResolution || isExternalModuleNameRelative(name)) { + watchFailedLookupLocationOfResolution(resolution); + } else { + nonRelativeExternalModuleResolutions.add(name, resolution); + } + const resolved = getResolutionWithResolvedFileName(resolution); + if (resolved && resolved.resolvedFileName) { + const key = resolutionHost.toPath(resolved.resolvedFileName); + let resolutions = resolvedFileToResolution.get(key); + if (!resolutions) + resolvedFileToResolution.set(key, resolutions = /* @__PURE__ */ new Set()); + resolutions.add(resolution); + } + } + (resolution.files ?? (resolution.files = /* @__PURE__ */ new Set())).add(filePath); } - function toFileId(path) { - let fileId = fileNameToFileId.get(path); - if (fileId === void 0) { - fileNames.push(relativeToBuildInfo(path)); - fileNameToFileId.set(path, fileId = fileNames.length); + function watchFailedLookupLocation(failedLookupLocation, setAtRoot) { + const failedLookupLocationPath = resolutionHost.toPath(failedLookupLocation); + const toWatch = getDirectoryToWatchFailedLookupLocation( + failedLookupLocation, + failedLookupLocationPath, + rootDir, + rootPath, + rootPathComponents, + getCurrentDirectory + ); + if (toWatch) { + const { dir, dirPath, nonRecursive } = toWatch; + if (dirPath === rootPath) { + Debug.assert(nonRecursive); + setAtRoot = true; + } else { + setDirectoryWatcher(dir, dirPath, nonRecursive); + } } - return fileId; + return setAtRoot; } - function toFileIdListId(set) { - const fileIds = arrayFrom(set.keys(), toFileId).sort(compareValues); - const key = fileIds.join(); - let fileIdListId = fileNamesToFileIdListId == null ? void 0 : fileNamesToFileIdListId.get(key); - if (fileIdListId === void 0) { - (fileIdsList || (fileIdsList = [])).push(fileIds); - (fileNamesToFileIdListId || (fileNamesToFileIdListId = /* @__PURE__ */ new Map())).set(key, fileIdListId = fileIdsList.length); + function watchFailedLookupLocationOfResolution(resolution) { + Debug.assert(!!resolution.refCount); + const { failedLookupLocations, affectingLocations, node10Result } = resolution; + if (!(failedLookupLocations == null ? void 0 : failedLookupLocations.length) && !(affectingLocations == null ? void 0 : affectingLocations.length) && !node10Result) + return; + if ((failedLookupLocations == null ? void 0 : failedLookupLocations.length) || node10Result) + resolutionsWithFailedLookups.add(resolution); + let setAtRoot = false; + if (failedLookupLocations) { + for (const failedLookupLocation of failedLookupLocations) { + setAtRoot = watchFailedLookupLocation(failedLookupLocation, setAtRoot); + } } - return fileIdListId; + if (node10Result) + setAtRoot = watchFailedLookupLocation(node10Result, setAtRoot); + if (setAtRoot) { + setDirectoryWatcher( + rootDir, + rootPath, + /*nonRecursive*/ + true + ); + } + watchAffectingLocationsOfResolution(resolution, !(failedLookupLocations == null ? void 0 : failedLookupLocations.length) && !node10Result); } - function tryAddRoot(path, fileId) { - const file = state.program.getSourceFile(path); - if (!state.program.getFileIncludeReasons().get(file.path).some((r) => r.kind === 0 /* RootFile */)) + function watchAffectingLocationsOfResolution(resolution, addToResolutionsWithOnlyAffectingLocations) { + Debug.assert(!!resolution.refCount); + const { affectingLocations } = resolution; + if (!(affectingLocations == null ? void 0 : affectingLocations.length)) return; - if (!root.length) - return root.push(fileId); - const last2 = root[root.length - 1]; - const isLastStartEnd = isArray(last2); - if (isLastStartEnd && last2[1] === fileId - 1) - return last2[1] = fileId; - if (isLastStartEnd || root.length === 1 || last2 !== fileId - 1) - return root.push(fileId); - const lastButOne = root[root.length - 2]; - if (!isNumber(lastButOne) || lastButOne !== last2 - 1) - return root.push(fileId); - root[root.length - 2] = [lastButOne, fileId]; - return root.length = root.length - 1; + if (addToResolutionsWithOnlyAffectingLocations) + resolutionsWithOnlyAffectingLocations.add(resolution); + for (const affectingLocation of affectingLocations) { + createFileWatcherOfAffectingLocation( + affectingLocation, + /*forResolution*/ + true + ); + } } - function convertToProgramBuildInfoCompilerOptions(options) { - let result; - const { optionsNameMap } = getOptionsNameMap(); - for (const name of getOwnKeys(options).sort(compareStringsCaseSensitive)) { - const optionInfo = optionsNameMap.get(name.toLowerCase()); - if (optionInfo == null ? void 0 : optionInfo.affectsBuildInfo) { - (result || (result = {}))[name] = convertToReusableCompilerOptionValue( - optionInfo, - options[name], - relativeToBuildInfoEnsuringAbsolutePath - ); + function createFileWatcherOfAffectingLocation(affectingLocation, forResolution) { + const fileWatcher = fileWatchesOfAffectingLocations.get(affectingLocation); + if (fileWatcher) { + if (forResolution) + fileWatcher.resolutions++; + else + fileWatcher.files++; + return; + } + let locationToWatch = affectingLocation; + let isSymlink = false; + let symlinkWatcher; + if (resolutionHost.realpath) { + locationToWatch = resolutionHost.realpath(affectingLocation); + if (affectingLocation !== locationToWatch) { + isSymlink = true; + symlinkWatcher = fileWatchesOfAffectingLocations.get(locationToWatch); + } + } + const resolutions = forResolution ? 1 : 0; + const files = forResolution ? 0 : 1; + if (!isSymlink || !symlinkWatcher) { + const watcher = { + watcher: canWatchAffectingLocation(resolutionHost.toPath(locationToWatch)) ? resolutionHost.watchAffectingFileLocation(locationToWatch, (fileName, eventKind) => { + cachedDirectoryStructureHost == null ? void 0 : cachedDirectoryStructureHost.addOrDeleteFile(fileName, resolutionHost.toPath(locationToWatch), eventKind); + invalidateAffectingFileWatcher(locationToWatch, moduleResolutionCache.getPackageJsonInfoCache().getInternalMap()); + resolutionHost.scheduleInvalidateResolutionsOfFailedLookupLocations(); + }) : noopFileWatcher, + resolutions: isSymlink ? 0 : resolutions, + files: isSymlink ? 0 : files, + symlinks: void 0 + }; + fileWatchesOfAffectingLocations.set(locationToWatch, watcher); + if (isSymlink) + symlinkWatcher = watcher; + } + if (isSymlink) { + Debug.assert(!!symlinkWatcher); + const watcher = { + watcher: { + close: () => { + var _a; + const symlinkWatcher2 = fileWatchesOfAffectingLocations.get(locationToWatch); + if (((_a = symlinkWatcher2 == null ? void 0 : symlinkWatcher2.symlinks) == null ? void 0 : _a.delete(affectingLocation)) && !symlinkWatcher2.symlinks.size && !symlinkWatcher2.resolutions && !symlinkWatcher2.files) { + fileWatchesOfAffectingLocations.delete(locationToWatch); + symlinkWatcher2.watcher.close(); + } + } + }, + resolutions, + files, + symlinks: void 0 + }; + fileWatchesOfAffectingLocations.set(affectingLocation, watcher); + (symlinkWatcher.symlinks ?? (symlinkWatcher.symlinks = /* @__PURE__ */ new Set())).add(affectingLocation); + } + } + function invalidateAffectingFileWatcher(path, packageJsonMap) { + var _a; + const watcher = fileWatchesOfAffectingLocations.get(path); + if (watcher == null ? void 0 : watcher.resolutions) + (affectingPathChecks ?? (affectingPathChecks = /* @__PURE__ */ new Set())).add(path); + if (watcher == null ? void 0 : watcher.files) + (affectingPathChecksForFile ?? (affectingPathChecksForFile = /* @__PURE__ */ new Set())).add(path); + (_a = watcher == null ? void 0 : watcher.symlinks) == null ? void 0 : _a.forEach((path2) => invalidateAffectingFileWatcher(path2, packageJsonMap)); + packageJsonMap == null ? void 0 : packageJsonMap.delete(resolutionHost.toPath(path)); + } + function watchFailedLookupLocationOfNonRelativeModuleResolutions(resolutions, name) { + const program = resolutionHost.getCurrentProgram(); + if (!program || !program.getTypeChecker().tryFindAmbientModuleWithoutAugmentations(name)) { + resolutions.forEach(watchFailedLookupLocationOfResolution); + } else { + resolutions.forEach((resolution) => watchAffectingLocationsOfResolution( + resolution, + /*addToResolutionsWithOnlyAffectingLocations*/ + true + )); + } + } + function setDirectoryWatcher(dir, dirPath, nonRecursive) { + const dirWatcher = directoryWatchesOfFailedLookups.get(dirPath); + if (dirWatcher) { + Debug.assert(!!nonRecursive === !!dirWatcher.nonRecursive); + dirWatcher.refCount++; + } else { + directoryWatchesOfFailedLookups.set(dirPath, { watcher: createDirectoryWatcher(dir, dirPath, nonRecursive), refCount: 1, nonRecursive }); + } + } + function stopWatchFailedLookupLocation(failedLookupLocation, removeAtRoot, syncDirWatcherRemove) { + const failedLookupLocationPath = resolutionHost.toPath(failedLookupLocation); + const toWatch = getDirectoryToWatchFailedLookupLocation( + failedLookupLocation, + failedLookupLocationPath, + rootDir, + rootPath, + rootPathComponents, + getCurrentDirectory + ); + if (toWatch) { + const { dirPath } = toWatch; + if (dirPath === rootPath) { + removeAtRoot = true; + } else { + removeDirectoryWatcher(dirPath, syncDirWatcherRemove); } } - return result; + return removeAtRoot; } - } - function convertToReusableCompilerOptionValue(option, value, relativeToBuildInfo) { - if (option) { - Debug.assert(option.type !== "listOrElement"); - if (option.type === "list") { - const values = value; - if (option.element.isFilePath && values.length) { - return values.map(relativeToBuildInfo); + function stopWatchFailedLookupLocationOfResolution(resolution, filePath, getResolutionWithResolvedFileName, syncDirWatcherRemove) { + Debug.checkDefined(resolution.files).delete(filePath); + resolution.refCount--; + if (resolution.refCount) { + return; + } + const resolved = getResolutionWithResolvedFileName(resolution); + if (resolved && resolved.resolvedFileName) { + const key = resolutionHost.toPath(resolved.resolvedFileName); + const resolutions = resolvedFileToResolution.get(key); + if ((resolutions == null ? void 0 : resolutions.delete(resolution)) && !resolutions.size) + resolvedFileToResolution.delete(key); + } + const { failedLookupLocations, affectingLocations, node10Result } = resolution; + if (resolutionsWithFailedLookups.delete(resolution)) { + let removeAtRoot = false; + if (failedLookupLocations) { + for (const failedLookupLocation of failedLookupLocations) { + removeAtRoot = stopWatchFailedLookupLocation(failedLookupLocation, removeAtRoot, syncDirWatcherRemove); + } + } + if (node10Result) + removeAtRoot = stopWatchFailedLookupLocation(node10Result, removeAtRoot, syncDirWatcherRemove); + if (removeAtRoot) + removeDirectoryWatcher(rootPath, syncDirWatcherRemove); + } else if (affectingLocations == null ? void 0 : affectingLocations.length) { + resolutionsWithOnlyAffectingLocations.delete(resolution); + } + if (affectingLocations) { + for (const affectingLocation of affectingLocations) { + const watcher = fileWatchesOfAffectingLocations.get(affectingLocation); + watcher.resolutions--; + if (syncDirWatcherRemove) + closeFileWatcherOfAffectingLocation(watcher, affectingLocation); } - } else if (option.isFilePath) { - return relativeToBuildInfo(value); } } - return value; - } - function convertToReusableDiagnostics(diagnostics, relativeToBuildInfo) { - Debug.assert(!!diagnostics.length); - return diagnostics.map((diagnostic) => { - const result = convertToReusableDiagnosticRelatedInformation(diagnostic, relativeToBuildInfo); - result.reportsUnnecessary = diagnostic.reportsUnnecessary; - result.reportDeprecated = diagnostic.reportsDeprecated; - result.source = diagnostic.source; - result.skippedOn = diagnostic.skippedOn; - const { relatedInformation } = diagnostic; - result.relatedInformation = relatedInformation ? relatedInformation.length ? relatedInformation.map((r) => convertToReusableDiagnosticRelatedInformation(r, relativeToBuildInfo)) : [] : void 0; - return result; - }); - } - function convertToReusableDiagnosticRelatedInformation(diagnostic, relativeToBuildInfo) { - const { file } = diagnostic; - return { - ...diagnostic, - file: file ? relativeToBuildInfo(file.resolvedPath) : void 0, - messageText: isString(diagnostic.messageText) ? diagnostic.messageText : convertToReusableDiagnosticMessageChain(diagnostic.messageText) - }; - } - function convertToReusableDiagnosticMessageChain(chain) { - if (chain.repopulateInfo) { - return { - info: chain.repopulateInfo(), - next: convertToReusableDiagnosticMessageChainArray(chain.next) - }; + function removeDirectoryWatcher(dirPath, syncDirWatcherRemove) { + const dirWatcher = directoryWatchesOfFailedLookups.get(dirPath); + dirWatcher.refCount--; + if (syncDirWatcherRemove) + closeDirectoryWatchesOfFailedLookup(dirWatcher, dirPath); } - const next = convertToReusableDiagnosticMessageChainArray(chain.next); - return next === chain.next ? chain : { ...chain, next }; - } - function convertToReusableDiagnosticMessageChainArray(array) { - if (!array) - return array; - return forEach(array, (chain, index) => { - const reusable = convertToReusableDiagnosticMessageChain(chain); - if (chain === reusable) - return void 0; - const result = index > 0 ? array.slice(0, index - 1) : []; - result.push(reusable); - for (let i = index + 1; i < array.length; i++) { - result.push(convertToReusableDiagnosticMessageChain(array[i])); + function createDirectoryWatcher(directory, dirPath, nonRecursive) { + return resolutionHost.watchDirectoryOfFailedLookupLocation(directory, (fileOrDirectory) => { + const fileOrDirectoryPath = resolutionHost.toPath(fileOrDirectory); + if (cachedDirectoryStructureHost) { + cachedDirectoryStructureHost.addOrDeleteFileOrDirectory(fileOrDirectory, fileOrDirectoryPath); + } + scheduleInvalidateResolutionOfFailedLookupLocation(fileOrDirectoryPath, dirPath === fileOrDirectoryPath); + }, nonRecursive ? 0 /* None */ : 1 /* Recursive */); + } + function removeResolutionsOfFileFromCache(cache, filePath, getResolutionWithResolvedFileName, syncDirWatcherRemove) { + const resolutions = cache.get(filePath); + if (resolutions) { + resolutions.forEach( + (resolution) => stopWatchFailedLookupLocationOfResolution( + resolution, + filePath, + getResolutionWithResolvedFileName, + syncDirWatcherRemove + ) + ); + cache.delete(filePath); } - return result; - }) || array; - } - function getBuilderCreationParameters(newProgramOrRootNames, hostOrOptions, oldProgramOrHost, configFileParsingDiagnosticsOrOldProgram, configFileParsingDiagnostics, projectReferences) { - let host; - let newProgram; - let oldProgram; - if (newProgramOrRootNames === void 0) { - Debug.assert(hostOrOptions === void 0); - host = oldProgramOrHost; - oldProgram = configFileParsingDiagnosticsOrOldProgram; - Debug.assert(!!oldProgram); - newProgram = oldProgram.getProgram(); - } else if (isArray(newProgramOrRootNames)) { - oldProgram = configFileParsingDiagnosticsOrOldProgram; - newProgram = createProgram({ - rootNames: newProgramOrRootNames, - options: hostOrOptions, - host: oldProgramOrHost, - oldProgram: oldProgram && oldProgram.getProgramOrUndefined(), - configFileParsingDiagnostics, - projectReferences - }); - host = oldProgramOrHost; - } else { - newProgram = newProgramOrRootNames; - host = hostOrOptions; - oldProgram = oldProgramOrHost; - configFileParsingDiagnostics = configFileParsingDiagnosticsOrOldProgram; } - return { host, newProgram, oldProgram, configFileParsingDiagnostics: configFileParsingDiagnostics || emptyArray }; - } - function getTextHandlingSourceMapForSignature(text, data) { - return (data == null ? void 0 : data.sourceMapUrlPos) !== void 0 ? text.substring(0, data.sourceMapUrlPos) : text; - } - function computeSignatureWithDiagnostics(program, sourceFile, text, host, data) { - var _a; - text = getTextHandlingSourceMapForSignature(text, data); - let sourceFileDirectory; - if ((_a = data == null ? void 0 : data.diagnostics) == null ? void 0 : _a.length) { - text += data.diagnostics.map( - (diagnostic) => `${locationInfo(diagnostic)}${DiagnosticCategory[diagnostic.category]}${diagnostic.code}: ${flattenDiagnosticMessageText2(diagnostic.messageText)}` - ).join("\n"); + function removeResolutionsFromProjectReferenceRedirects(filePath) { + if (!fileExtensionIs(filePath, ".json" /* Json */)) + return; + const program = resolutionHost.getCurrentProgram(); + if (!program) + return; + const resolvedProjectReference = program.getResolvedProjectReferenceByPath(filePath); + if (!resolvedProjectReference) + return; + resolvedProjectReference.commandLine.fileNames.forEach((f) => removeResolutionsOfFile(resolutionHost.toPath(f))); } - return (host.createHash ?? generateDjb2Hash)(text); - function flattenDiagnosticMessageText2(diagnostic) { - return isString(diagnostic) ? diagnostic : diagnostic === void 0 ? "" : !diagnostic.next ? diagnostic.messageText : diagnostic.messageText + diagnostic.next.map(flattenDiagnosticMessageText2).join("\n"); + function removeResolutionsOfFile(filePath, syncDirWatcherRemove) { + removeResolutionsOfFileFromCache(resolvedModuleNames, filePath, getResolvedModule, syncDirWatcherRemove); + removeResolutionsOfFileFromCache(resolvedTypeReferenceDirectives, filePath, getResolvedTypeReferenceDirective, syncDirWatcherRemove); } - function locationInfo(diagnostic) { - if (diagnostic.file.resolvedPath === sourceFile.resolvedPath) - return `(${diagnostic.start},${diagnostic.length})`; - if (sourceFileDirectory === void 0) - sourceFileDirectory = getDirectoryPath(sourceFile.resolvedPath); - return `${ensurePathIsNonModuleName(getRelativePathFromDirectory( - sourceFileDirectory, - diagnostic.file.resolvedPath, - program.getCanonicalFileName - ))}(${diagnostic.start},${diagnostic.length})`; + function invalidateResolutions(resolutions, canInvalidate) { + if (!resolutions) + return false; + let invalidated = false; + resolutions.forEach((resolution) => { + if (resolution.isInvalidated || !canInvalidate(resolution)) + return; + resolution.isInvalidated = invalidated = true; + for (const containingFilePath of Debug.checkDefined(resolution.files)) { + (filesWithInvalidatedResolutions ?? (filesWithInvalidatedResolutions = /* @__PURE__ */ new Set())).add(containingFilePath); + hasChangedAutomaticTypeDirectiveNames = hasChangedAutomaticTypeDirectiveNames || endsWith(containingFilePath, inferredTypesContainingFile); + } + }); + return invalidated; } - } - function computeSignature(text, host, data) { - return (host.createHash ?? generateDjb2Hash)(getTextHandlingSourceMapForSignature(text, data)); - } - function createBuilderProgram(kind, { newProgram, host, oldProgram, configFileParsingDiagnostics }) { - let oldState = oldProgram && oldProgram.getState(); - if (oldState && newProgram === oldState.program && configFileParsingDiagnostics === newProgram.getConfigFileParsingDiagnostics()) { - newProgram = void 0; - oldState = void 0; - return oldProgram; + function invalidateResolutionOfFile(filePath) { + removeResolutionsOfFile(filePath); + const prevHasChangedAutomaticTypeDirectiveNames = hasChangedAutomaticTypeDirectiveNames; + if (invalidateResolutions(resolvedFileToResolution.get(filePath), returnTrue) && hasChangedAutomaticTypeDirectiveNames && !prevHasChangedAutomaticTypeDirectiveNames) { + resolutionHost.onChangedAutomaticTypeDirectiveNames(); + } } - const state = createBuilderProgramState(newProgram, oldState); - newProgram.getBuildInfo = (bundle) => getBuildInfo2(state, bundle); - newProgram = void 0; - oldProgram = void 0; - oldState = void 0; - const getState = () => state; - const builderProgram = createRedirectedBuilderProgram(getState, configFileParsingDiagnostics); - builderProgram.getState = getState; - builderProgram.saveEmitState = () => backupBuilderProgramEmitState(state); - builderProgram.restoreEmitState = (saved) => restoreBuilderProgramEmitState(state, saved); - builderProgram.hasChangedEmitSignature = () => !!state.hasChangedEmitSignature; - builderProgram.getAllDependencies = (sourceFile) => BuilderState.getAllDependencies(state, Debug.checkDefined(state.program), sourceFile); - builderProgram.getSemanticDiagnostics = getSemanticDiagnostics; - builderProgram.emit = emit; - builderProgram.releaseProgram = () => releaseCache(state); - if (kind === 0 /* SemanticDiagnosticsBuilderProgram */) { - builderProgram.getSemanticDiagnosticsOfNextAffectedFile = getSemanticDiagnosticsOfNextAffectedFile; - } else if (kind === 1 /* EmitAndSemanticDiagnosticsBuilderProgram */) { - builderProgram.getSemanticDiagnosticsOfNextAffectedFile = getSemanticDiagnosticsOfNextAffectedFile; - builderProgram.emitNextAffectedFile = emitNextAffectedFile; - builderProgram.emitBuildInfo = emitBuildInfo; - } else { - notImplemented(); + function setFilesWithInvalidatedNonRelativeUnresolvedImports(filesMap) { + Debug.assert(filesWithInvalidatedNonRelativeUnresolvedImports === filesMap || filesWithInvalidatedNonRelativeUnresolvedImports === void 0); + filesWithInvalidatedNonRelativeUnresolvedImports = filesMap; } - return builderProgram; - function emitBuildInfo(writeFile2, cancellationToken) { - if (state.buildInfoEmitPending) { - const result = Debug.checkDefined(state.program).emitBuildInfo(writeFile2 || maybeBind(host, host.writeFile), cancellationToken); - state.buildInfoEmitPending = false; - return result; + function scheduleInvalidateResolutionOfFailedLookupLocation(fileOrDirectoryPath, isCreatingWatchedDirectory) { + if (isCreatingWatchedDirectory) { + (isInDirectoryChecks || (isInDirectoryChecks = /* @__PURE__ */ new Set())).add(fileOrDirectoryPath); + } else { + const updatedPath = removeIgnoredPath(fileOrDirectoryPath); + if (!updatedPath) + return false; + fileOrDirectoryPath = updatedPath; + if (resolutionHost.fileIsOpen(fileOrDirectoryPath)) { + return false; + } + const dirOfFileOrDirectory = getDirectoryPath(fileOrDirectoryPath); + if (isNodeModulesAtTypesDirectory(fileOrDirectoryPath) || isNodeModulesDirectory(fileOrDirectoryPath) || isNodeModulesAtTypesDirectory(dirOfFileOrDirectory) || isNodeModulesDirectory(dirOfFileOrDirectory)) { + (failedLookupChecks || (failedLookupChecks = /* @__PURE__ */ new Set())).add(fileOrDirectoryPath); + (startsWithPathChecks || (startsWithPathChecks = /* @__PURE__ */ new Set())).add(fileOrDirectoryPath); + } else { + if (isEmittedFileOfProgram(resolutionHost.getCurrentProgram(), fileOrDirectoryPath)) { + return false; + } + if (fileExtensionIs(fileOrDirectoryPath, ".map")) { + return false; + } + (failedLookupChecks || (failedLookupChecks = /* @__PURE__ */ new Set())).add(fileOrDirectoryPath); + const packagePath = parseNodeModuleFromPath( + fileOrDirectoryPath, + /*isFolder*/ + true + ); + if (packagePath) + (startsWithPathChecks || (startsWithPathChecks = /* @__PURE__ */ new Set())).add(packagePath); + } } - return emitSkippedWithNoDiagnostics; + resolutionHost.scheduleInvalidateResolutionsOfFailedLookupLocations(); } - function emitNextAffectedFile(writeFile2, cancellationToken, emitOnlyDtsFiles, customTransformers) { - var _a, _b, _c; - let affected = getNextAffectedFile(state, cancellationToken, host); - const programEmitKind = getBuilderFileEmit(state.compilerOptions); - let emitKind = emitOnlyDtsFiles ? programEmitKind & 24 /* AllDts */ : programEmitKind; - if (!affected) { - if (!outFile(state.compilerOptions)) { - const pendingAffectedFile = getNextAffectedFilePendingEmit(state, emitOnlyDtsFiles); - if (!pendingAffectedFile) { - if (!state.buildInfoEmitPending) - return void 0; - const affected2 = state.program; - const result2 = affected2.emitBuildInfo(writeFile2 || maybeBind(host, host.writeFile), cancellationToken); - state.buildInfoEmitPending = false; - return { result: result2, affected: affected2 }; - } - ({ affectedFile: affected, emitKind } = pendingAffectedFile); - } else { - if (!state.programEmitPending) - return void 0; - emitKind = state.programEmitPending; - if (emitOnlyDtsFiles) - emitKind = emitKind & 24 /* AllDts */; - if (!emitKind) - return void 0; - affected = state.program; + function invalidatePackageJsonMap() { + const packageJsonMap = moduleResolutionCache.getPackageJsonInfoCache().getInternalMap(); + if (packageJsonMap && (failedLookupChecks || startsWithPathChecks || isInDirectoryChecks)) { + packageJsonMap.forEach((_value, path) => isInvalidatedFailedLookup(path) ? packageJsonMap.delete(path) : void 0); + } + } + function invalidateResolutionsOfFailedLookupLocations() { + var _a; + if (allModuleAndTypeResolutionsAreInvalidated) { + affectingPathChecksForFile = void 0; + invalidatePackageJsonMap(); + if (failedLookupChecks || startsWithPathChecks || isInDirectoryChecks || affectingPathChecks) { + invalidateResolutions(resolvedLibraries, canInvalidateFailedLookupResolution); } + failedLookupChecks = void 0; + startsWithPathChecks = void 0; + isInDirectoryChecks = void 0; + affectingPathChecks = void 0; + return true; } - let emitOnly; - if (emitKind & 7 /* AllJs */) - emitOnly = 0 /* Js */; - if (emitKind & 24 /* AllDts */) - emitOnly = emitOnly === void 0 ? 1 /* Dts */ : void 0; - if (affected === state.program) { - state.programEmitPending = state.changedFilesSet.size ? getPendingEmitKind(programEmitKind, emitKind) : state.programEmitPending ? getPendingEmitKind(state.programEmitPending, emitKind) : void 0; + let invalidated = false; + if (affectingPathChecksForFile) { + (_a = resolutionHost.getCurrentProgram()) == null ? void 0 : _a.getSourceFiles().forEach((f) => { + if (some(f.packageJsonLocations, (location) => affectingPathChecksForFile.has(location))) { + (filesWithInvalidatedResolutions ?? (filesWithInvalidatedResolutions = /* @__PURE__ */ new Set())).add(f.path); + invalidated = true; + } + }); + affectingPathChecksForFile = void 0; } - const result = state.program.emit( - affected === state.program ? void 0 : affected, - getWriteFileCallback(writeFile2, customTransformers), - cancellationToken, - emitOnly, - customTransformers - ); - if (affected !== state.program) { - const affectedSourceFile = affected; - state.seenAffectedFiles.add(affectedSourceFile.resolvedPath); - if (state.affectedFilesIndex !== void 0) - state.affectedFilesIndex++; - state.buildInfoEmitPending = true; - const existing = ((_a = state.seenEmittedFiles) == null ? void 0 : _a.get(affectedSourceFile.resolvedPath)) || 0 /* None */; - (state.seenEmittedFiles ?? (state.seenEmittedFiles = /* @__PURE__ */ new Map())).set(affectedSourceFile.resolvedPath, emitKind | existing); - const existingPending = ((_b = state.affectedFilesPendingEmit) == null ? void 0 : _b.get(affectedSourceFile.resolvedPath)) || programEmitKind; - const pendingKind = getPendingEmitKind(existingPending, emitKind | existing); - if (pendingKind) - (state.affectedFilesPendingEmit ?? (state.affectedFilesPendingEmit = /* @__PURE__ */ new Map())).set(affectedSourceFile.resolvedPath, pendingKind); - else - (_c = state.affectedFilesPendingEmit) == null ? void 0 : _c.delete(affectedSourceFile.resolvedPath); - } else { - state.changedFilesSet.clear(); + if (!failedLookupChecks && !startsWithPathChecks && !isInDirectoryChecks && !affectingPathChecks) { + return invalidated; } - return { result, affected }; + invalidated = invalidateResolutions(resolutionsWithFailedLookups, canInvalidateFailedLookupResolution) || invalidated; + invalidatePackageJsonMap(); + failedLookupChecks = void 0; + startsWithPathChecks = void 0; + isInDirectoryChecks = void 0; + invalidated = invalidateResolutions(resolutionsWithOnlyAffectingLocations, canInvalidatedFailedLookupResolutionWithAffectingLocation) || invalidated; + affectingPathChecks = void 0; + return invalidated; } - function getWriteFileCallback(writeFile2, customTransformers) { - if (!getEmitDeclarations(state.compilerOptions)) - return writeFile2 || maybeBind(host, host.writeFile); - return (fileName, text, writeByteOrderMark, onError, sourceFiles, data) => { - var _a, _b, _c, _d; - if (isDeclarationFileName(fileName)) { - if (!outFile(state.compilerOptions)) { - Debug.assert((sourceFiles == null ? void 0 : sourceFiles.length) === 1); - let emitSignature; - if (!customTransformers) { - const file = sourceFiles[0]; - const info = state.fileInfos.get(file.resolvedPath); - if (info.signature === file.version) { - const signature = computeSignatureWithDiagnostics( - state.program, - file, - text, - host, - data - ); - if (!((_a = data == null ? void 0 : data.diagnostics) == null ? void 0 : _a.length)) - emitSignature = signature; - if (signature !== file.version) { - if (host.storeFilesChangingSignatureDuringEmit) - (state.filesChangingSignature ?? (state.filesChangingSignature = /* @__PURE__ */ new Set())).add(file.resolvedPath); - if (state.exportedModulesMap) - BuilderState.updateExportedModules(state, file, file.exportedModulesFromDeclarationEmit); - if (state.affectedFiles) { - const existing = (_b = state.oldSignatures) == null ? void 0 : _b.get(file.resolvedPath); - if (existing === void 0) - (state.oldSignatures ?? (state.oldSignatures = /* @__PURE__ */ new Map())).set(file.resolvedPath, info.signature || false); - info.signature = signature; - } else { - info.signature = signature; - (_c = state.oldExportedModulesMap) == null ? void 0 : _c.clear(); - } - } - } - } - if (state.compilerOptions.composite) { - const filePath = sourceFiles[0].resolvedPath; - emitSignature = handleNewSignature((_d = state.emitSignatures) == null ? void 0 : _d.get(filePath), emitSignature); - if (!emitSignature) - return; - (state.emitSignatures ?? (state.emitSignatures = /* @__PURE__ */ new Map())).set(filePath, emitSignature); - } - } else if (state.compilerOptions.composite) { - const newSignature = handleNewSignature( - state.outSignature, - /*newSignature*/ - void 0 - ); - if (!newSignature) - return; - state.outSignature = newSignature; - } + function canInvalidateFailedLookupResolution(resolution) { + var _a; + if (canInvalidatedFailedLookupResolutionWithAffectingLocation(resolution)) + return true; + if (!failedLookupChecks && !startsWithPathChecks && !isInDirectoryChecks) + return false; + return ((_a = resolution.failedLookupLocations) == null ? void 0 : _a.some((location) => isInvalidatedFailedLookup(resolutionHost.toPath(location)))) || !!resolution.node10Result && isInvalidatedFailedLookup(resolutionHost.toPath(resolution.node10Result)); + } + function isInvalidatedFailedLookup(locationPath) { + return (failedLookupChecks == null ? void 0 : failedLookupChecks.has(locationPath)) || firstDefinedIterator((startsWithPathChecks == null ? void 0 : startsWithPathChecks.keys()) || [], (fileOrDirectoryPath) => startsWith(locationPath, fileOrDirectoryPath) ? true : void 0) || firstDefinedIterator((isInDirectoryChecks == null ? void 0 : isInDirectoryChecks.keys()) || [], (dirPath) => locationPath.length > dirPath.length && startsWith(locationPath, dirPath) && (isDiskPathRoot(dirPath) || locationPath[dirPath.length] === directorySeparator) ? true : void 0); + } + function canInvalidatedFailedLookupResolutionWithAffectingLocation(resolution) { + var _a; + return !!affectingPathChecks && ((_a = resolution.affectingLocations) == null ? void 0 : _a.some((location) => affectingPathChecks.has(location))); + } + function closeTypeRootsWatch() { + clearMap(typeRootsWatches, closeFileWatcher); + } + function createTypeRootsWatch(typeRootPath, typeRoot) { + return canWatchTypeRootPath(typeRootPath) ? resolutionHost.watchTypeRootsDirectory(typeRoot, (fileOrDirectory) => { + const fileOrDirectoryPath = resolutionHost.toPath(fileOrDirectory); + if (cachedDirectoryStructureHost) { + cachedDirectoryStructureHost.addOrDeleteFileOrDirectory(fileOrDirectory, fileOrDirectoryPath); } - if (writeFile2) - writeFile2(fileName, text, writeByteOrderMark, onError, sourceFiles, data); - else if (host.writeFile) - host.writeFile(fileName, text, writeByteOrderMark, onError, sourceFiles, data); - else - state.program.writeFile(fileName, text, writeByteOrderMark, onError, sourceFiles, data); - function handleNewSignature(oldSignatureFormat, newSignature) { - const oldSignature = !oldSignatureFormat || isString(oldSignatureFormat) ? oldSignatureFormat : oldSignatureFormat[0]; - newSignature ?? (newSignature = computeSignature(text, host, data)); - if (newSignature === oldSignature) { - if (oldSignatureFormat === oldSignature) - return void 0; - else if (data) - data.differsOnlyInMap = true; - else - data = { differsOnlyInMap: true }; - } else { - state.hasChangedEmitSignature = true; - state.latestChangedDtsFile = fileName; - } - return newSignature; + hasChangedAutomaticTypeDirectiveNames = true; + resolutionHost.onChangedAutomaticTypeDirectiveNames(); + const dirPath = getDirectoryToWatchFailedLookupLocationFromTypeRoot( + typeRoot, + typeRootPath, + rootPath, + rootPathComponents, + getCurrentDirectory, + (dirPath2) => directoryWatchesOfFailedLookups.has(dirPath2) + ); + if (dirPath) { + scheduleInvalidateResolutionOfFailedLookupLocation(fileOrDirectoryPath, dirPath === fileOrDirectoryPath); } - }; + }, 1 /* Recursive */) : noopFileWatcher; } - function emit(targetSourceFile, writeFile2, cancellationToken, emitOnlyDtsFiles, customTransformers) { - if (kind === 1 /* EmitAndSemanticDiagnosticsBuilderProgram */) { - assertSourceFileOkWithoutNextAffectedCall(state, targetSourceFile); + function updateTypeRootsWatch() { + const options = resolutionHost.getCompilationSettings(); + if (options.types) { + closeTypeRootsWatch(); + return; } - const result = handleNoEmitOptions(builderProgram, targetSourceFile, writeFile2, cancellationToken); - if (result) - return result; - if (!targetSourceFile) { - if (kind === 1 /* EmitAndSemanticDiagnosticsBuilderProgram */) { - let sourceMaps = []; - let emitSkipped = false; - let diagnostics; - let emittedFiles = []; - let affectedEmitResult; - while (affectedEmitResult = emitNextAffectedFile(writeFile2, cancellationToken, emitOnlyDtsFiles, customTransformers)) { - emitSkipped = emitSkipped || affectedEmitResult.result.emitSkipped; - diagnostics = addRange(diagnostics, affectedEmitResult.result.diagnostics); - emittedFiles = addRange(emittedFiles, affectedEmitResult.result.emittedFiles); - sourceMaps = addRange(sourceMaps, affectedEmitResult.result.sourceMaps); + const typeRoots = getEffectiveTypeRoots(options, { getCurrentDirectory }); + if (typeRoots) { + mutateMap( + typeRootsWatches, + arrayToMap(typeRoots, (tr) => resolutionHost.toPath(tr)), + { + createNewValue: createTypeRootsWatch, + onDeleteValue: closeFileWatcher } - return { - emitSkipped, - diagnostics: diagnostics || emptyArray, - emittedFiles, - sourceMaps - }; - } else { - clearAffectedFilesPendingEmit(state, emitOnlyDtsFiles); - } + ); + } else { + closeTypeRootsWatch(); } - return Debug.checkDefined(state.program).emit( - targetSourceFile, - getWriteFileCallback(writeFile2, customTransformers), - cancellationToken, - emitOnlyDtsFiles, - customTransformers - ); } - function getSemanticDiagnosticsOfNextAffectedFile(cancellationToken, ignoreSourceFile) { - while (true) { - const affected = getNextAffectedFile(state, cancellationToken, host); - let result; - if (!affected) - return void 0; - else if (affected !== state.program) { - const affectedSourceFile = affected; - if (!ignoreSourceFile || !ignoreSourceFile(affectedSourceFile)) { - result = getSemanticDiagnosticsOfFile(state, affectedSourceFile, cancellationToken); - } - state.seenAffectedFiles.add(affectedSourceFile.resolvedPath); - state.affectedFilesIndex++; - state.buildInfoEmitPending = true; - if (!result) - continue; - } else { - result = state.program.getSemanticDiagnostics( - /*sourceFile*/ - void 0, - cancellationToken - ); - state.changedFilesSet.clear(); - state.programEmitPending = getBuilderFileEmit(state.compilerOptions); - } - return { result, affected }; - } + function canWatchTypeRootPath(typeRoot) { + if (resolutionHost.getCompilationSettings().typeRoots) + return true; + return canWatchAtTypes(resolutionHost.toPath(typeRoot)); } - function getSemanticDiagnostics(sourceFile, cancellationToken) { - assertSourceFileOkWithoutNextAffectedCall(state, sourceFile); - const compilerOptions = Debug.checkDefined(state.program).getCompilerOptions(); - if (outFile(compilerOptions)) { - Debug.assert(!state.semanticDiagnosticsPerFile); - return Debug.checkDefined(state.program).getSemanticDiagnostics(sourceFile, cancellationToken); + } + function resolutionIsSymlink(resolution) { + var _a, _b; + return !!(((_a = resolution.resolvedModule) == null ? void 0 : _a.originalPath) || ((_b = resolution.resolvedTypeReferenceDirective) == null ? void 0 : _b.originalPath)); + } + var init_resolutionCache = __esm({ + "src/compiler/resolutionCache.ts"() { + "use strict"; + init_ts2(); + } + }); + + // src/compiler/watch.ts + function createDiagnosticReporter(system, pretty) { + const host = system === sys && sysFormatDiagnosticsHost ? sysFormatDiagnosticsHost : { + getCurrentDirectory: () => system.getCurrentDirectory(), + getNewLine: () => system.newLine, + getCanonicalFileName: createGetCanonicalFileName(system.useCaseSensitiveFileNames) + }; + if (!pretty) { + return (diagnostic) => system.write(formatDiagnostic(diagnostic, host)); + } + const diagnostics = new Array(1); + return (diagnostic) => { + diagnostics[0] = diagnostic; + system.write(formatDiagnosticsWithColorAndContext(diagnostics, host) + host.getNewLine()); + diagnostics[0] = void 0; + }; + } + function clearScreenIfNotWatchingForFileChanges(system, diagnostic, options) { + if (system.clearScreen && !options.preserveWatchOutput && !options.extendedDiagnostics && !options.diagnostics && contains(screenStartingMessageCodes, diagnostic.code)) { + system.clearScreen(); + return true; + } + return false; + } + function getPlainDiagnosticFollowingNewLines(diagnostic, newLine) { + return contains(screenStartingMessageCodes, diagnostic.code) ? newLine + newLine : newLine; + } + function getLocaleTimeString(system) { + return !system.now ? (/* @__PURE__ */ new Date()).toLocaleTimeString() : ( + // On some systems / builds of Node, there's a non-breaking space between the time and AM/PM. + // This branch is solely for testing, so just switch it to a normal space for baseline stability. + // See: + // - https://github.com/nodejs/node/issues/45171 + // - https://github.com/nodejs/node/issues/45753 + system.now().toLocaleTimeString("en-US", { timeZone: "UTC" }).replace("\u202F", " ") + ); + } + function createWatchStatusReporter(system, pretty) { + return pretty ? (diagnostic, newLine, options) => { + clearScreenIfNotWatchingForFileChanges(system, diagnostic, options); + let output = `[${formatColorAndReset(getLocaleTimeString(system), "\x1B[90m" /* Grey */)}] `; + output += `${flattenDiagnosticMessageText(diagnostic.messageText, system.newLine)}${newLine + newLine}`; + system.write(output); + } : (diagnostic, newLine, options) => { + let output = ""; + if (!clearScreenIfNotWatchingForFileChanges(system, diagnostic, options)) { + output += newLine; } - if (sourceFile) { - return getSemanticDiagnosticsOfFile(state, sourceFile, cancellationToken); + output += `${getLocaleTimeString(system)} - `; + output += `${flattenDiagnosticMessageText(diagnostic.messageText, system.newLine)}${getPlainDiagnosticFollowingNewLines(diagnostic, newLine)}`; + system.write(output); + }; + } + function parseConfigFileWithSystem(configFileName, optionsToExtend, extendedConfigCache, watchOptionsToExtend, system, reportDiagnostic) { + const host = system; + host.onUnRecoverableConfigFileDiagnostic = (diagnostic) => reportUnrecoverableDiagnostic(system, reportDiagnostic, diagnostic); + const result = getParsedCommandLineOfConfigFile(configFileName, optionsToExtend, host, extendedConfigCache, watchOptionsToExtend); + host.onUnRecoverableConfigFileDiagnostic = void 0; + return result; + } + function getErrorCountForSummary(diagnostics) { + return countWhere(diagnostics, (diagnostic) => diagnostic.category === 1 /* Error */); + } + function getFilesInErrorForSummary(diagnostics) { + const filesInError = filter(diagnostics, (diagnostic) => diagnostic.category === 1 /* Error */).map( + (errorDiagnostic) => { + if (errorDiagnostic.file === void 0) + return; + return `${errorDiagnostic.file.fileName}`; } - while (getSemanticDiagnosticsOfNextAffectedFile(cancellationToken)) { + ); + return filesInError.map((fileName) => { + if (fileName === void 0) { + return void 0; } - let diagnostics; - for (const sourceFile2 of Debug.checkDefined(state.program).getSourceFiles()) { - diagnostics = addRange(diagnostics, getSemanticDiagnosticsOfFile(state, sourceFile2, cancellationToken)); + const diagnosticForFileName = find(diagnostics, (diagnostic) => diagnostic.file !== void 0 && diagnostic.file.fileName === fileName); + if (diagnosticForFileName !== void 0) { + const { line } = getLineAndCharacterOfPosition(diagnosticForFileName.file, diagnosticForFileName.start); + return { + fileName, + line: line + 1 + }; } - return diagnostics || emptyArray; - } + }); } - function addToAffectedFilesPendingEmit(state, affectedFilePendingEmit, kind) { - var _a; - const existingKind = ((_a = state.affectedFilesPendingEmit) == null ? void 0 : _a.get(affectedFilePendingEmit)) || 0 /* None */; - (state.affectedFilesPendingEmit ?? (state.affectedFilesPendingEmit = /* @__PURE__ */ new Map())).set(affectedFilePendingEmit, existingKind | kind); + function getWatchErrorSummaryDiagnosticMessage(errorCount) { + return errorCount === 1 ? Diagnostics.Found_1_error_Watching_for_file_changes : Diagnostics.Found_0_errors_Watching_for_file_changes; } - function toBuilderStateFileInfoForMultiEmit(fileInfo) { - return isString(fileInfo) ? { version: fileInfo, signature: fileInfo, affectsGlobalScope: void 0, impliedFormat: void 0 } : isString(fileInfo.signature) ? fileInfo : { version: fileInfo.version, signature: fileInfo.signature === false ? void 0 : fileInfo.version, affectsGlobalScope: fileInfo.affectsGlobalScope, impliedFormat: fileInfo.impliedFormat }; + function prettyPathForFileError(error2, cwd) { + const line = formatColorAndReset(":" + error2.line, "\x1B[90m" /* Grey */); + if (pathIsAbsolute(error2.fileName) && pathIsAbsolute(cwd)) { + return getRelativePathFromDirectory( + cwd, + error2.fileName, + /*ignoreCase*/ + false + ) + line; + } + return error2.fileName + line; } - function toBuilderFileEmit(value, fullEmitForOptions) { - return isNumber(value) ? fullEmitForOptions : value[1] || 8 /* Dts */; + function getErrorSummaryText(errorCount, filesInError, newLine, host) { + if (errorCount === 0) + return ""; + const nonNilFiles = filesInError.filter((fileInError) => fileInError !== void 0); + const distinctFileNamesWithLines = nonNilFiles.map((fileInError) => `${fileInError.fileName}:${fileInError.line}`).filter((value, index, self) => self.indexOf(value) === index); + const firstFileReference = nonNilFiles[0] && prettyPathForFileError(nonNilFiles[0], host.getCurrentDirectory()); + let messageAndArgs; + if (errorCount === 1) { + messageAndArgs = filesInError[0] !== void 0 ? [Diagnostics.Found_1_error_in_0, firstFileReference] : [Diagnostics.Found_1_error]; + } else { + messageAndArgs = distinctFileNamesWithLines.length === 0 ? [Diagnostics.Found_0_errors, errorCount] : distinctFileNamesWithLines.length === 1 ? [Diagnostics.Found_0_errors_in_the_same_file_starting_at_Colon_1, errorCount, firstFileReference] : [Diagnostics.Found_0_errors_in_1_files, errorCount, distinctFileNamesWithLines.length]; + } + const d = createCompilerDiagnostic(...messageAndArgs); + const suffix = distinctFileNamesWithLines.length > 1 ? createTabularErrorsDisplay(nonNilFiles, host) : ""; + return `${newLine}${flattenDiagnosticMessageText(d.messageText, newLine)}${newLine}${newLine}${suffix}`; } - function toProgramEmitPending(value, options) { - return !value ? getBuilderFileEmit(options || {}) : value; + function createTabularErrorsDisplay(filesInError, host) { + const distinctFiles = filesInError.filter((value, index, self) => index === self.findIndex((file) => (file == null ? void 0 : file.fileName) === (value == null ? void 0 : value.fileName))); + if (distinctFiles.length === 0) + return ""; + const numberLength = (num) => Math.log(num) * Math.LOG10E + 1; + const fileToErrorCount = distinctFiles.map((file) => [file, countWhere(filesInError, (fileInError) => fileInError.fileName === file.fileName)]); + const maxErrors = fileToErrorCount.reduce((acc, value) => Math.max(acc, value[1] || 0), 0); + const headerRow = Diagnostics.Errors_Files.message; + const leftColumnHeadingLength = headerRow.split(" ")[0].length; + const leftPaddingGoal = Math.max(leftColumnHeadingLength, numberLength(maxErrors)); + const headerPadding = Math.max(numberLength(maxErrors) - leftColumnHeadingLength, 0); + let tabularData = ""; + tabularData += " ".repeat(headerPadding) + headerRow + "\n"; + fileToErrorCount.forEach((row) => { + const [file, errorCount] = row; + const errorCountDigitsLength = Math.log(errorCount) * Math.LOG10E + 1 | 0; + const leftPadding = errorCountDigitsLength < leftPaddingGoal ? " ".repeat(leftPaddingGoal - errorCountDigitsLength) : ""; + const fileRef = prettyPathForFileError(file, host.getCurrentDirectory()); + tabularData += `${leftPadding}${errorCount} ${fileRef} +`; + }); + return tabularData; } - function createBuilderProgramUsingProgramBuildInfo(buildInfo, buildInfoPath, host) { - var _a, _b, _c, _d; - const program = buildInfo.program; - const buildInfoDirectory = getDirectoryPath(getNormalizedAbsolutePath(buildInfoPath, host.getCurrentDirectory())); - const getCanonicalFileName = createGetCanonicalFileName(host.useCaseSensitiveFileNames()); - let state; - const filePaths = (_a = program.fileNames) == null ? void 0 : _a.map(toPathInBuildInfoDirectory); - let filePathsSetList; - const latestChangedDtsFile = program.latestChangedDtsFile ? toAbsolutePath(program.latestChangedDtsFile) : void 0; - if (isProgramBundleEmitBuildInfo(program)) { - const fileInfos = /* @__PURE__ */ new Map(); - program.fileInfos.forEach((fileInfo, index) => { - const path = toFilePath(index + 1); - fileInfos.set(path, isString(fileInfo) ? { version: fileInfo, signature: void 0, affectsGlobalScope: void 0, impliedFormat: void 0 } : fileInfo); - }); - state = { - fileInfos, - compilerOptions: program.options ? convertToOptionsWithAbsolutePaths(program.options, toAbsolutePath) : {}, - latestChangedDtsFile, - outSignature: program.outSignature, - programEmitPending: program.pendingEmit === void 0 ? void 0 : toProgramEmitPending(program.pendingEmit, program.options), - bundle: buildInfo.bundle - }; - } else { - filePathsSetList = (_b = program.fileIdsList) == null ? void 0 : _b.map((fileIds) => new Set(fileIds.map(toFilePath))); - const fileInfos = /* @__PURE__ */ new Map(); - const emitSignatures = ((_c = program.options) == null ? void 0 : _c.composite) && !outFile(program.options) ? /* @__PURE__ */ new Map() : void 0; - program.fileInfos.forEach((fileInfo, index) => { - const path = toFilePath(index + 1); - const stateFileInfo = toBuilderStateFileInfoForMultiEmit(fileInfo); - fileInfos.set(path, stateFileInfo); - if (emitSignatures && stateFileInfo.signature) - emitSignatures.set(path, stateFileInfo.signature); - }); - (_d = program.emitSignatures) == null ? void 0 : _d.forEach((value) => { - if (isNumber(value)) - emitSignatures.delete(toFilePath(value)); - else { - const key = toFilePath(value[0]); - emitSignatures.set( - key, - !isString(value[1]) && !value[1].length ? ( - // File signature is emit signature but differs in map - [emitSignatures.get(key)] - ) : value[1] - ); - } + function isBuilderProgram2(program) { + return !!program.getState; + } + function listFiles(program, write) { + const options = program.getCompilerOptions(); + if (options.explainFiles) { + explainFiles(isBuilderProgram2(program) ? program.getProgram() : program, write); + } else if (options.listFiles || options.listFilesOnly) { + forEach(program.getSourceFiles(), (file) => { + write(file.fileName); }); - const fullEmitForOptions = program.affectedFilesPendingEmit ? getBuilderFileEmit(program.options || {}) : void 0; - state = { - fileInfos, - compilerOptions: program.options ? convertToOptionsWithAbsolutePaths(program.options, toAbsolutePath) : {}, - referencedMap: toManyToManyPathMap(program.referencedMap), - exportedModulesMap: toManyToManyPathMap(program.exportedModulesMap), - semanticDiagnosticsPerFile: program.semanticDiagnosticsPerFile && arrayToMap(program.semanticDiagnosticsPerFile, (value) => toFilePath(isNumber(value) ? value : value[0]), (value) => isNumber(value) ? emptyArray : value[1]), - hasReusableDiagnostic: true, - affectedFilesPendingEmit: program.affectedFilesPendingEmit && arrayToMap(program.affectedFilesPendingEmit, (value) => toFilePath(isNumber(value) ? value : value[0]), (value) => toBuilderFileEmit(value, fullEmitForOptions)), - changedFilesSet: new Set(map(program.changeFileSet, toFilePath)), - latestChangedDtsFile, - emitSignatures: (emitSignatures == null ? void 0 : emitSignatures.size) ? emitSignatures : void 0 - }; - } - return { - getState: () => state, - saveEmitState: noop, - restoreEmitState: noop, - getProgram: notImplemented, - getProgramOrUndefined: returnUndefined, - releaseProgram: noop, - getCompilerOptions: () => state.compilerOptions, - getSourceFile: notImplemented, - getSourceFiles: notImplemented, - getOptionsDiagnostics: notImplemented, - getGlobalDiagnostics: notImplemented, - getConfigFileParsingDiagnostics: notImplemented, - getSyntacticDiagnostics: notImplemented, - getDeclarationDiagnostics: notImplemented, - getSemanticDiagnostics: notImplemented, - emit: notImplemented, - getAllDependencies: notImplemented, - getCurrentDirectory: notImplemented, - emitNextAffectedFile: notImplemented, - getSemanticDiagnosticsOfNextAffectedFile: notImplemented, - emitBuildInfo: notImplemented, - close: noop, - hasChangedEmitSignature: returnFalse - }; - function toPathInBuildInfoDirectory(path) { - return toPath(path, buildInfoDirectory, getCanonicalFileName); } - function toAbsolutePath(path) { - return getNormalizedAbsolutePath(path, buildInfoDirectory); + } + function explainFiles(program, write) { + var _a, _b; + const reasons = program.getFileIncludeReasons(); + const relativeFileName = (fileName) => convertToRelativePath(fileName, program.getCurrentDirectory(), program.getCanonicalFileName); + for (const file of program.getSourceFiles()) { + write(`${toFileName(file, relativeFileName)}`); + (_a = reasons.get(file.path)) == null ? void 0 : _a.forEach((reason) => write(` ${fileIncludeReasonToDiagnostics(program, reason, relativeFileName).messageText}`)); + (_b = explainIfFileIsRedirectAndImpliedFormat(file, relativeFileName)) == null ? void 0 : _b.forEach((d) => write(` ${d.messageText}`)); } - function toFilePath(fileId) { - return filePaths[fileId - 1]; + } + function explainIfFileIsRedirectAndImpliedFormat(file, fileNameConvertor) { + var _a; + let result; + if (file.path !== file.resolvedPath) { + (result ?? (result = [])).push(chainDiagnosticMessages( + /*details*/ + void 0, + Diagnostics.File_is_output_of_project_reference_source_0, + toFileName(file.originalFileName, fileNameConvertor) + )); } - function toFilePathsSet(fileIdsListId) { - return filePathsSetList[fileIdsListId - 1]; + if (file.redirectInfo) { + (result ?? (result = [])).push(chainDiagnosticMessages( + /*details*/ + void 0, + Diagnostics.File_redirects_to_file_0, + toFileName(file.redirectInfo.redirectTarget, fileNameConvertor) + )); } - function toManyToManyPathMap(referenceMap) { - if (!referenceMap) { - return void 0; + if (isExternalOrCommonJsModule(file)) { + switch (file.impliedNodeFormat) { + case 99 /* ESNext */: + if (file.packageJsonScope) { + (result ?? (result = [])).push(chainDiagnosticMessages( + /*details*/ + void 0, + Diagnostics.File_is_ECMAScript_module_because_0_has_field_type_with_value_module, + toFileName(last(file.packageJsonLocations), fileNameConvertor) + )); + } + break; + case 1 /* CommonJS */: + if (file.packageJsonScope) { + (result ?? (result = [])).push(chainDiagnosticMessages( + /*details*/ + void 0, + file.packageJsonScope.contents.packageJsonContent.type ? Diagnostics.File_is_CommonJS_module_because_0_has_field_type_whose_value_is_not_module : Diagnostics.File_is_CommonJS_module_because_0_does_not_have_field_type, + toFileName(last(file.packageJsonLocations), fileNameConvertor) + )); + } else if ((_a = file.packageJsonLocations) == null ? void 0 : _a.length) { + (result ?? (result = [])).push(chainDiagnosticMessages( + /*details*/ + void 0, + Diagnostics.File_is_CommonJS_module_because_package_json_was_not_found + )); + } + break; } - const map2 = BuilderState.createManyToManyPathMap(); - referenceMap.forEach( - ([fileId, fileIdListId]) => map2.set(toFilePath(fileId), toFilePathsSet(fileIdListId)) - ); - return map2; } + return result; } - function getBuildInfoFileVersionMap(program, buildInfoPath, host) { - const buildInfoDirectory = getDirectoryPath(getNormalizedAbsolutePath(buildInfoPath, host.getCurrentDirectory())); - const getCanonicalFileName = createGetCanonicalFileName(host.useCaseSensitiveFileNames()); - const fileInfos = /* @__PURE__ */ new Map(); - let rootIndex = 0; - const roots = []; - program.fileInfos.forEach((fileInfo, index) => { - const path = toPath(program.fileNames[index], buildInfoDirectory, getCanonicalFileName); - const version2 = isString(fileInfo) ? fileInfo : fileInfo.version; - fileInfos.set(path, version2); - if (rootIndex < program.root.length) { - const current = program.root[rootIndex]; - const fileId = index + 1; - if (isArray(current)) { - if (current[0] <= fileId && fileId <= current[1]) { - roots.push(path); - if (current[1] === fileId) - rootIndex++; + function getMatchedFileSpec(program, fileName) { + var _a; + const configFile = program.getCompilerOptions().configFile; + if (!((_a = configFile == null ? void 0 : configFile.configFileSpecs) == null ? void 0 : _a.validatedFilesSpec)) + return void 0; + const filePath = program.getCanonicalFileName(fileName); + const basePath = getDirectoryPath(getNormalizedAbsolutePath(configFile.fileName, program.getCurrentDirectory())); + return find(configFile.configFileSpecs.validatedFilesSpec, (fileSpec) => program.getCanonicalFileName(getNormalizedAbsolutePath(fileSpec, basePath)) === filePath); + } + function getMatchedIncludeSpec(program, fileName) { + var _a, _b; + const configFile = program.getCompilerOptions().configFile; + if (!((_a = configFile == null ? void 0 : configFile.configFileSpecs) == null ? void 0 : _a.validatedIncludeSpecs)) + return void 0; + if (configFile.configFileSpecs.isDefaultIncludeSpec) + return true; + const isJsonFile = fileExtensionIs(fileName, ".json" /* Json */); + const basePath = getDirectoryPath(getNormalizedAbsolutePath(configFile.fileName, program.getCurrentDirectory())); + const useCaseSensitiveFileNames2 = program.useCaseSensitiveFileNames(); + return find((_b = configFile == null ? void 0 : configFile.configFileSpecs) == null ? void 0 : _b.validatedIncludeSpecs, (includeSpec) => { + if (isJsonFile && !endsWith(includeSpec, ".json" /* Json */)) + return false; + const pattern = getPatternFromSpec(includeSpec, basePath, "files"); + return !!pattern && getRegexFromPattern(`(${pattern})$`, useCaseSensitiveFileNames2).test(fileName); + }); + } + function fileIncludeReasonToDiagnostics(program, reason, fileNameConvertor) { + var _a, _b; + const options = program.getCompilerOptions(); + if (isReferencedFile(reason)) { + const referenceLocation = getReferencedFileLocation(program, reason); + const referenceText = isReferenceFileLocation(referenceLocation) ? referenceLocation.file.text.substring(referenceLocation.pos, referenceLocation.end) : `"${referenceLocation.text}"`; + let message; + Debug.assert(isReferenceFileLocation(referenceLocation) || reason.kind === 3 /* Import */, "Only synthetic references are imports"); + switch (reason.kind) { + case 3 /* Import */: + if (isReferenceFileLocation(referenceLocation)) { + message = referenceLocation.packageId ? Diagnostics.Imported_via_0_from_file_1_with_packageId_2 : Diagnostics.Imported_via_0_from_file_1; + } else if (referenceLocation.text === externalHelpersModuleNameText) { + message = referenceLocation.packageId ? Diagnostics.Imported_via_0_from_file_1_with_packageId_2_to_import_importHelpers_as_specified_in_compilerOptions : Diagnostics.Imported_via_0_from_file_1_to_import_importHelpers_as_specified_in_compilerOptions; + } else { + message = referenceLocation.packageId ? Diagnostics.Imported_via_0_from_file_1_with_packageId_2_to_import_jsx_and_jsxs_factory_functions : Diagnostics.Imported_via_0_from_file_1_to_import_jsx_and_jsxs_factory_functions; } - } else if (current === fileId) { - roots.push(path); - rootIndex++; - } + break; + case 4 /* ReferenceFile */: + Debug.assert(!referenceLocation.packageId); + message = Diagnostics.Referenced_via_0_from_file_1; + break; + case 5 /* TypeReferenceDirective */: + message = referenceLocation.packageId ? Diagnostics.Type_library_referenced_via_0_from_file_1_with_packageId_2 : Diagnostics.Type_library_referenced_via_0_from_file_1; + break; + case 7 /* LibReferenceDirective */: + Debug.assert(!referenceLocation.packageId); + message = Diagnostics.Library_referenced_via_0_from_file_1; + break; + default: + Debug.assertNever(reason); + } + return chainDiagnosticMessages( + /*details*/ + void 0, + message, + referenceText, + toFileName(referenceLocation.file, fileNameConvertor), + referenceLocation.packageId && packageIdToString(referenceLocation.packageId) + ); + } + switch (reason.kind) { + case 0 /* RootFile */: + if (!((_a = options.configFile) == null ? void 0 : _a.configFileSpecs)) + return chainDiagnosticMessages( + /*details*/ + void 0, + Diagnostics.Root_file_specified_for_compilation + ); + const fileName = getNormalizedAbsolutePath(program.getRootFileNames()[reason.index], program.getCurrentDirectory()); + const matchedByFiles = getMatchedFileSpec(program, fileName); + if (matchedByFiles) + return chainDiagnosticMessages( + /*details*/ + void 0, + Diagnostics.Part_of_files_list_in_tsconfig_json + ); + const matchedByInclude = getMatchedIncludeSpec(program, fileName); + return isString(matchedByInclude) ? chainDiagnosticMessages( + /*details*/ + void 0, + Diagnostics.Matched_by_include_pattern_0_in_1, + matchedByInclude, + toFileName(options.configFile, fileNameConvertor) + ) : ( + // Could be additional files specified as roots or matched by default include + chainDiagnosticMessages( + /*details*/ + void 0, + matchedByInclude ? Diagnostics.Matched_by_default_include_pattern_Asterisk_Asterisk_Slash_Asterisk : Diagnostics.Root_file_specified_for_compilation + ) + ); + case 1 /* SourceFromProjectReference */: + case 2 /* OutputFromProjectReference */: + const isOutput = reason.kind === 2 /* OutputFromProjectReference */; + const referencedResolvedRef = Debug.checkDefined((_b = program.getResolvedProjectReferences()) == null ? void 0 : _b[reason.index]); + return chainDiagnosticMessages( + /*details*/ + void 0, + outFile(options) ? isOutput ? Diagnostics.Output_from_referenced_project_0_included_because_1_specified : Diagnostics.Source_from_referenced_project_0_included_because_1_specified : isOutput ? Diagnostics.Output_from_referenced_project_0_included_because_module_is_specified_as_none : Diagnostics.Source_from_referenced_project_0_included_because_module_is_specified_as_none, + toFileName(referencedResolvedRef.sourceFile.fileName, fileNameConvertor), + options.outFile ? "--outFile" : "--out" + ); + case 8 /* AutomaticTypeDirectiveFile */: { + const messageAndArgs = options.types ? reason.packageId ? [Diagnostics.Entry_point_of_type_library_0_specified_in_compilerOptions_with_packageId_1, reason.typeReference, packageIdToString(reason.packageId)] : [Diagnostics.Entry_point_of_type_library_0_specified_in_compilerOptions, reason.typeReference] : reason.packageId ? [Diagnostics.Entry_point_for_implicit_type_library_0_with_packageId_1, reason.typeReference, packageIdToString(reason.packageId)] : [Diagnostics.Entry_point_for_implicit_type_library_0, reason.typeReference]; + return chainDiagnosticMessages( + /*details*/ + void 0, + ...messageAndArgs + ); + } + case 6 /* LibFile */: { + if (reason.index !== void 0) + return chainDiagnosticMessages( + /*details*/ + void 0, + Diagnostics.Library_0_specified_in_compilerOptions, + options.lib[reason.index] + ); + const target = forEachEntry(targetOptionDeclaration.type, (value, key) => value === getEmitScriptTarget(options) ? key : void 0); + const messageAndArgs = target ? [Diagnostics.Default_library_for_target_0, target] : [Diagnostics.Default_library]; + return chainDiagnosticMessages( + /*details*/ + void 0, + ...messageAndArgs + ); } - }); - return { fileInfos, roots }; - } - function createRedirectedBuilderProgram(getState, configFileParsingDiagnostics) { - return { - getState: notImplemented, - saveEmitState: noop, - restoreEmitState: noop, - getProgram, - getProgramOrUndefined: () => getState().program, - releaseProgram: () => getState().program = void 0, - getCompilerOptions: () => getState().compilerOptions, - getSourceFile: (fileName) => getProgram().getSourceFile(fileName), - getSourceFiles: () => getProgram().getSourceFiles(), - getOptionsDiagnostics: (cancellationToken) => getProgram().getOptionsDiagnostics(cancellationToken), - getGlobalDiagnostics: (cancellationToken) => getProgram().getGlobalDiagnostics(cancellationToken), - getConfigFileParsingDiagnostics: () => configFileParsingDiagnostics, - getSyntacticDiagnostics: (sourceFile, cancellationToken) => getProgram().getSyntacticDiagnostics(sourceFile, cancellationToken), - getDeclarationDiagnostics: (sourceFile, cancellationToken) => getProgram().getDeclarationDiagnostics(sourceFile, cancellationToken), - getSemanticDiagnostics: (sourceFile, cancellationToken) => getProgram().getSemanticDiagnostics(sourceFile, cancellationToken), - emit: (sourceFile, writeFile2, cancellationToken, emitOnlyDts, customTransformers) => getProgram().emit(sourceFile, writeFile2, cancellationToken, emitOnlyDts, customTransformers), - emitBuildInfo: (writeFile2, cancellationToken) => getProgram().emitBuildInfo(writeFile2, cancellationToken), - getAllDependencies: notImplemented, - getCurrentDirectory: () => getProgram().getCurrentDirectory(), - close: noop - }; - function getProgram() { - return Debug.checkDefined(getState().program); - } - } - var BuilderFileEmit, BuilderProgramKind; - var init_builder = __esm({ - "src/compiler/builder.ts"() { - "use strict"; - init_ts2(); - BuilderFileEmit = /* @__PURE__ */ ((BuilderFileEmit2) => { - BuilderFileEmit2[BuilderFileEmit2["None"] = 0] = "None"; - BuilderFileEmit2[BuilderFileEmit2["Js"] = 1] = "Js"; - BuilderFileEmit2[BuilderFileEmit2["JsMap"] = 2] = "JsMap"; - BuilderFileEmit2[BuilderFileEmit2["JsInlineMap"] = 4] = "JsInlineMap"; - BuilderFileEmit2[BuilderFileEmit2["Dts"] = 8] = "Dts"; - BuilderFileEmit2[BuilderFileEmit2["DtsMap"] = 16] = "DtsMap"; - BuilderFileEmit2[BuilderFileEmit2["AllJs"] = 7] = "AllJs"; - BuilderFileEmit2[BuilderFileEmit2["AllDts"] = 24] = "AllDts"; - BuilderFileEmit2[BuilderFileEmit2["All"] = 31] = "All"; - return BuilderFileEmit2; - })(BuilderFileEmit || {}); - BuilderProgramKind = /* @__PURE__ */ ((BuilderProgramKind2) => { - BuilderProgramKind2[BuilderProgramKind2["SemanticDiagnosticsBuilderProgram"] = 0] = "SemanticDiagnosticsBuilderProgram"; - BuilderProgramKind2[BuilderProgramKind2["EmitAndSemanticDiagnosticsBuilderProgram"] = 1] = "EmitAndSemanticDiagnosticsBuilderProgram"; - return BuilderProgramKind2; - })(BuilderProgramKind || {}); + default: + Debug.assertNever(reason); } - }); - - // src/compiler/builderPublic.ts - function createSemanticDiagnosticsBuilderProgram(newProgramOrRootNames, hostOrOptions, oldProgramOrHost, configFileParsingDiagnosticsOrOldProgram, configFileParsingDiagnostics, projectReferences) { - return createBuilderProgram(0 /* SemanticDiagnosticsBuilderProgram */, getBuilderCreationParameters(newProgramOrRootNames, hostOrOptions, oldProgramOrHost, configFileParsingDiagnosticsOrOldProgram, configFileParsingDiagnostics, projectReferences)); } - function createEmitAndSemanticDiagnosticsBuilderProgram(newProgramOrRootNames, hostOrOptions, oldProgramOrHost, configFileParsingDiagnosticsOrOldProgram, configFileParsingDiagnostics, projectReferences) { - return createBuilderProgram(1 /* EmitAndSemanticDiagnosticsBuilderProgram */, getBuilderCreationParameters(newProgramOrRootNames, hostOrOptions, oldProgramOrHost, configFileParsingDiagnosticsOrOldProgram, configFileParsingDiagnostics, projectReferences)); - } - function createAbstractBuilder(newProgramOrRootNames, hostOrOptions, oldProgramOrHost, configFileParsingDiagnosticsOrOldProgram, configFileParsingDiagnostics, projectReferences) { - const { newProgram, configFileParsingDiagnostics: newConfigFileParsingDiagnostics } = getBuilderCreationParameters(newProgramOrRootNames, hostOrOptions, oldProgramOrHost, configFileParsingDiagnosticsOrOldProgram, configFileParsingDiagnostics, projectReferences); - return createRedirectedBuilderProgram(() => ({ program: newProgram, compilerOptions: newProgram.getCompilerOptions() }), newConfigFileParsingDiagnostics); + function toFileName(file, fileNameConvertor) { + const fileName = isString(file) ? file : file.fileName; + return fileNameConvertor ? fileNameConvertor(fileName) : fileName; } - var init_builderPublic = __esm({ - "src/compiler/builderPublic.ts"() { - "use strict"; - init_ts2(); - } - }); - - // src/compiler/resolutionCache.ts - function removeIgnoredPath(path) { - if (endsWith(path, "/node_modules/.staging")) { - return removeSuffix(path, "/.staging"); + function emitFilesAndReportErrors(program, reportDiagnostic, write, reportSummary, writeFile2, cancellationToken, emitOnlyDtsFiles, customTransformers) { + const isListFilesOnly = !!program.getCompilerOptions().listFilesOnly; + const allDiagnostics = program.getConfigFileParsingDiagnostics().slice(); + const configFileParsingDiagnosticsLength = allDiagnostics.length; + addRange(allDiagnostics, program.getSyntacticDiagnostics( + /*sourceFile*/ + void 0, + cancellationToken + )); + if (allDiagnostics.length === configFileParsingDiagnosticsLength) { + addRange(allDiagnostics, program.getOptionsDiagnostics(cancellationToken)); + if (!isListFilesOnly) { + addRange(allDiagnostics, program.getGlobalDiagnostics(cancellationToken)); + if (allDiagnostics.length === configFileParsingDiagnosticsLength) { + addRange(allDiagnostics, program.getSemanticDiagnostics( + /*sourceFile*/ + void 0, + cancellationToken + )); + } + } } - return some(ignoredPaths, (searchPath) => stringContains(path, searchPath)) ? void 0 : path; - } - function perceivedOsRootLengthForWatching(pathComponents2, length2) { - if (length2 <= 1) - return 1; - let userCheckIndex = 1; - let isDosStyle = pathComponents2[0].search(/[a-zA-Z]:/) === 0; - if (pathComponents2[0] !== directorySeparator && !isDosStyle && // Non dos style paths - pathComponents2[1].search(/[a-zA-Z]\$$/) === 0) { - if (length2 === 2) - return 2; - userCheckIndex = 2; - isDosStyle = true; + const emitResult = isListFilesOnly ? { emitSkipped: true, diagnostics: emptyArray } : program.emit( + /*targetSourceFile*/ + void 0, + writeFile2, + cancellationToken, + emitOnlyDtsFiles, + customTransformers + ); + const { emittedFiles, diagnostics: emitDiagnostics } = emitResult; + addRange(allDiagnostics, emitDiagnostics); + const diagnostics = sortAndDeduplicateDiagnostics(allDiagnostics); + diagnostics.forEach(reportDiagnostic); + if (write) { + const currentDir = program.getCurrentDirectory(); + forEach(emittedFiles, (file) => { + const filepath = getNormalizedAbsolutePath(file, currentDir); + write(`TSFILE: ${filepath}`); + }); + listFiles(program, write); } - if (isDosStyle && !pathComponents2[userCheckIndex].match(/^users$/i)) { - return userCheckIndex; + if (reportSummary) { + reportSummary(getErrorCountForSummary(diagnostics), getFilesInErrorForSummary(diagnostics)); } - return userCheckIndex + 2; - } - function canWatchDirectoryOrFile(pathComponents2, length2) { - if (length2 === void 0) - length2 = pathComponents2.length; - if (length2 <= 2) - return false; - const perceivedOsRootLength = perceivedOsRootLengthForWatching(pathComponents2, length2); - return length2 > perceivedOsRootLength + 1; - } - function canWatchAtTypes(atTypes) { - return canWatchAffectedPackageJsonOrNodeModulesOfAtTypes(getDirectoryPath(atTypes)); + return { + emitResult, + diagnostics + }; } - function isInDirectoryPath(dirComponents, fileOrDirComponents) { - if (fileOrDirComponents.length < fileOrDirComponents.length) - return false; - for (let i = 0; i < dirComponents.length; i++) { - if (fileOrDirComponents[i] !== dirComponents[i]) - return false; + function emitFilesAndReportErrorsAndGetExitStatus(program, reportDiagnostic, write, reportSummary, writeFile2, cancellationToken, emitOnlyDtsFiles, customTransformers) { + const { emitResult, diagnostics } = emitFilesAndReportErrors( + program, + reportDiagnostic, + write, + reportSummary, + writeFile2, + cancellationToken, + emitOnlyDtsFiles, + customTransformers + ); + if (emitResult.emitSkipped && diagnostics.length > 0) { + return 1 /* DiagnosticsPresent_OutputsSkipped */; + } else if (diagnostics.length > 0) { + return 2 /* DiagnosticsPresent_OutputsGenerated */; } - return true; + return 0 /* Success */; } - function canWatchAffectedPackageJsonOrNodeModulesOfAtTypes(fileOrDirPath) { - return canWatchDirectoryOrFile(getPathComponents(fileOrDirPath)); + function createWatchHost(system = sys, reportWatchStatus2) { + const onWatchStatusChange = reportWatchStatus2 || createWatchStatusReporter(system); + return { + onWatchStatusChange, + watchFile: maybeBind(system, system.watchFile) || returnNoopFileWatcher, + watchDirectory: maybeBind(system, system.watchDirectory) || returnNoopFileWatcher, + setTimeout: maybeBind(system, system.setTimeout) || noop, + clearTimeout: maybeBind(system, system.clearTimeout) || noop + }; } - function canWatchAffectingLocation(filePath) { - return canWatchAffectedPackageJsonOrNodeModulesOfAtTypes(filePath); + function createWatchFactory(host, options) { + const watchLogLevel = host.trace ? options.extendedDiagnostics ? 2 /* Verbose */ : options.diagnostics ? 1 /* TriggerOnly */ : 0 /* None */ : 0 /* None */; + const writeLog = watchLogLevel !== 0 /* None */ ? (s) => host.trace(s) : noop; + const result = getWatchFactory(host, watchLogLevel, writeLog); + result.writeLog = writeLog; + return result; } - function getDirectoryToWatchFailedLookupLocation(failedLookupLocation, failedLookupLocationPath, rootDir, rootPath, rootPathComponents, getCurrentDirectory) { - const failedLookupPathComponents = getPathComponents(failedLookupLocationPath); - failedLookupLocation = isRootedDiskPath(failedLookupLocation) ? normalizePath(failedLookupLocation) : getNormalizedAbsolutePath(failedLookupLocation, getCurrentDirectory()); - const failedLookupComponents = getPathComponents(failedLookupLocation); - const perceivedOsRootLength = perceivedOsRootLengthForWatching(failedLookupPathComponents, failedLookupPathComponents.length); - if (failedLookupPathComponents.length <= perceivedOsRootLength + 1) - return void 0; - const nodeModulesIndex = failedLookupPathComponents.indexOf("node_modules"); - if (nodeModulesIndex !== -1 && nodeModulesIndex + 1 <= perceivedOsRootLength + 1) - return void 0; - if (isInDirectoryPath(rootPathComponents, failedLookupPathComponents)) { - if (failedLookupPathComponents.length > rootPathComponents.length + 1) { - return getDirectoryOfFailedLookupWatch(failedLookupComponents, failedLookupPathComponents, Math.max(rootPathComponents.length + 1, perceivedOsRootLength + 1)); - } else { - return { - dir: rootDir, - dirPath: rootPath, - nonRecursive: true - }; + function createCompilerHostFromProgramHost(host, getCompilerOptions, directoryStructureHost = host) { + const useCaseSensitiveFileNames2 = host.useCaseSensitiveFileNames(); + const compilerHost = { + getSourceFile: createGetSourceFile( + (fileName, encoding) => !encoding ? compilerHost.readFile(fileName) : host.readFile(fileName, encoding), + getCompilerOptions, + /*setParentNodes*/ + void 0 + ), + getDefaultLibLocation: maybeBind(host, host.getDefaultLibLocation), + getDefaultLibFileName: (options) => host.getDefaultLibFileName(options), + writeFile: createWriteFileMeasuringIO( + (path, data, writeByteOrderMark) => host.writeFile(path, data, writeByteOrderMark), + (path) => host.createDirectory(path), + (path) => host.directoryExists(path) + ), + getCurrentDirectory: memoize(() => host.getCurrentDirectory()), + useCaseSensitiveFileNames: () => useCaseSensitiveFileNames2, + getCanonicalFileName: createGetCanonicalFileName(useCaseSensitiveFileNames2), + getNewLine: () => getNewLineCharacter(getCompilerOptions()), + fileExists: (f) => host.fileExists(f), + readFile: (f) => host.readFile(f), + trace: maybeBind(host, host.trace), + directoryExists: maybeBind(directoryStructureHost, directoryStructureHost.directoryExists), + getDirectories: maybeBind(directoryStructureHost, directoryStructureHost.getDirectories), + realpath: maybeBind(host, host.realpath), + getEnvironmentVariable: maybeBind(host, host.getEnvironmentVariable) || (() => ""), + createHash: maybeBind(host, host.createHash), + readDirectory: maybeBind(host, host.readDirectory), + storeFilesChangingSignatureDuringEmit: host.storeFilesChangingSignatureDuringEmit, + jsDocParsingMode: host.jsDocParsingMode + }; + return compilerHost; + } + function getSourceFileVersionAsHashFromText(host, text) { + if (text.match(sourceMapCommentRegExpDontCareLineStart)) { + let lineEnd = text.length; + let lineStart = lineEnd; + for (let pos = lineEnd - 1; pos >= 0; pos--) { + const ch = text.charCodeAt(pos); + switch (ch) { + case 10 /* lineFeed */: + if (pos && text.charCodeAt(pos - 1) === 13 /* carriageReturn */) { + pos--; + } + case 13 /* carriageReturn */: + break; + default: + if (ch < 127 /* maxAsciiCharacter */ || !isLineBreak(ch)) { + lineStart = pos; + continue; + } + break; + } + const line = text.substring(lineStart, lineEnd); + if (line.match(sourceMapCommentRegExp)) { + text = text.substring(0, lineStart); + break; + } else if (!line.match(whitespaceOrMapCommentRegExp)) { + break; + } + lineEnd = lineStart; } } - return getDirectoryToWatchFromFailedLookupLocationDirectory( - failedLookupComponents, - failedLookupPathComponents, - failedLookupPathComponents.length - 1, - perceivedOsRootLength, - nodeModulesIndex, - rootPathComponents - ); + return (host.createHash || generateDjb2Hash)(text); } - function getDirectoryToWatchFromFailedLookupLocationDirectory(dirComponents, dirPathComponents, dirPathComponentsLength, perceivedOsRootLength, nodeModulesIndex, rootPathComponents) { - if (nodeModulesIndex !== -1) { - return getDirectoryOfFailedLookupWatch(dirComponents, dirPathComponents, nodeModulesIndex + 1); - } - let nonRecursive = true; - let length2 = dirPathComponentsLength; - for (let i = 0; i < dirPathComponentsLength; i++) { - if (dirPathComponents[i] !== rootPathComponents[i]) { - nonRecursive = false; - length2 = Math.max(i + 1, perceivedOsRootLength + 1); - break; + function setGetSourceFileAsHashVersioned(compilerHost) { + const originalGetSourceFile = compilerHost.getSourceFile; + compilerHost.getSourceFile = (...args) => { + const result = originalGetSourceFile.call(compilerHost, ...args); + if (result) { + result.version = getSourceFileVersionAsHashFromText(compilerHost, result.text); } - } - return getDirectoryOfFailedLookupWatch(dirComponents, dirPathComponents, length2, nonRecursive); + return result; + }; } - function getDirectoryOfFailedLookupWatch(dirComponents, dirPathComponents, length2, nonRecursive) { + function createProgramHost(system, createProgram2) { + const getDefaultLibLocation = memoize(() => getDirectoryPath(normalizePath(system.getExecutingFilePath()))); return { - dir: getPathFromPathComponents(dirComponents, length2), - dirPath: getPathFromPathComponents(dirPathComponents, length2), - nonRecursive + useCaseSensitiveFileNames: () => system.useCaseSensitiveFileNames, + getNewLine: () => system.newLine, + getCurrentDirectory: memoize(() => system.getCurrentDirectory()), + getDefaultLibLocation, + getDefaultLibFileName: (options) => combinePaths(getDefaultLibLocation(), getDefaultLibFileName(options)), + fileExists: (path) => system.fileExists(path), + readFile: (path, encoding) => system.readFile(path, encoding), + directoryExists: (path) => system.directoryExists(path), + getDirectories: (path) => system.getDirectories(path), + readDirectory: (path, extensions, exclude, include, depth) => system.readDirectory(path, extensions, exclude, include, depth), + realpath: maybeBind(system, system.realpath), + getEnvironmentVariable: maybeBind(system, system.getEnvironmentVariable), + trace: (s) => system.write(s + system.newLine), + createDirectory: (path) => system.createDirectory(path), + writeFile: (path, data, writeByteOrderMark) => system.writeFile(path, data, writeByteOrderMark), + createHash: maybeBind(system, system.createHash), + createProgram: createProgram2 || createEmitAndSemanticDiagnosticsBuilderProgram, + storeFilesChangingSignatureDuringEmit: system.storeFilesChangingSignatureDuringEmit, + now: maybeBind(system, system.now) }; } - function getDirectoryToWatchFailedLookupLocationFromTypeRoot(typeRoot, typeRootPath, rootPath, rootPathComponents, getCurrentDirectory, filterCustomPath) { - const typeRootPathComponents = getPathComponents(typeRootPath); - if (isInDirectoryPath(rootPathComponents, typeRootPathComponents)) { - return rootPath; - } - typeRoot = isRootedDiskPath(typeRoot) ? normalizePath(typeRoot) : getNormalizedAbsolutePath(typeRoot, getCurrentDirectory()); - const toWatch = getDirectoryToWatchFromFailedLookupLocationDirectory( - getPathComponents(typeRoot), - typeRootPathComponents, - typeRootPathComponents.length, - perceivedOsRootLengthForWatching(typeRootPathComponents, typeRootPathComponents.length), - typeRootPathComponents.indexOf("node_modules"), - rootPathComponents - ); - return toWatch && filterCustomPath(toWatch.dirPath) ? toWatch.dirPath : void 0; + function createWatchCompilerHost(system = sys, createProgram2, reportDiagnostic, reportWatchStatus2) { + const write = (s) => system.write(s + system.newLine); + const result = createProgramHost(system, createProgram2); + copyProperties(result, createWatchHost(system, reportWatchStatus2)); + result.afterProgramCreate = (builderProgram) => { + const compilerOptions = builderProgram.getCompilerOptions(); + const newLine = getNewLineCharacter(compilerOptions); + emitFilesAndReportErrors( + builderProgram, + reportDiagnostic, + write, + (errorCount) => result.onWatchStatusChange( + createCompilerDiagnostic(getWatchErrorSummaryDiagnosticMessage(errorCount), errorCount), + newLine, + compilerOptions, + errorCount + ) + ); + }; + return result; } - function getRootDirectoryOfResolutionCache(rootDirForResolution, getCurrentDirectory) { - const normalized = getNormalizedAbsolutePath(rootDirForResolution, getCurrentDirectory()); - return !isDiskPathRoot(normalized) ? removeTrailingDirectorySeparator(normalized) : normalized; + function reportUnrecoverableDiagnostic(system, reportDiagnostic, diagnostic) { + reportDiagnostic(diagnostic); + system.exit(1 /* DiagnosticsPresent_OutputsSkipped */); } - function getRootPathSplitLength(rootPath) { - return rootPath.split(directorySeparator).length - (hasTrailingDirectorySeparator(rootPath) ? 1 : 0); + function createWatchCompilerHostOfConfigFile({ + configFileName, + optionsToExtend, + watchOptionsToExtend, + extraFileExtensions, + system, + createProgram: createProgram2, + reportDiagnostic, + reportWatchStatus: reportWatchStatus2 + }) { + const diagnosticReporter = reportDiagnostic || createDiagnosticReporter(system); + const host = createWatchCompilerHost(system, createProgram2, diagnosticReporter, reportWatchStatus2); + host.onUnRecoverableConfigFileDiagnostic = (diagnostic) => reportUnrecoverableDiagnostic(system, diagnosticReporter, diagnostic); + host.configFileName = configFileName; + host.optionsToExtend = optionsToExtend; + host.watchOptionsToExtend = watchOptionsToExtend; + host.extraFileExtensions = extraFileExtensions; + return host; } - function createResolutionCache(resolutionHost, rootDirForResolution, logChangesWhenResolvingModule) { - let filesWithChangedSetOfUnresolvedImports; - let filesWithInvalidatedResolutions; - let filesWithInvalidatedNonRelativeUnresolvedImports; - const nonRelativeExternalModuleResolutions = createMultiMap(); - const resolutionsWithFailedLookups = /* @__PURE__ */ new Set(); - const resolutionsWithOnlyAffectingLocations = /* @__PURE__ */ new Set(); - const resolvedFileToResolution = /* @__PURE__ */ new Map(); - const impliedFormatPackageJsons = /* @__PURE__ */ new Map(); - let hasChangedAutomaticTypeDirectiveNames = false; - let affectingPathChecksForFile; - let affectingPathChecks; - let failedLookupChecks; - let startsWithPathChecks; - let isInDirectoryChecks; - let allModuleAndTypeResolutionsAreInvalidated = false; - const getCurrentDirectory = memoize(() => resolutionHost.getCurrentDirectory()); - const cachedDirectoryStructureHost = resolutionHost.getCachedDirectoryStructureHost(); - const resolvedModuleNames = /* @__PURE__ */ new Map(); - const moduleResolutionCache = createModuleResolutionCache( - getCurrentDirectory(), - resolutionHost.getCanonicalFileName, - resolutionHost.getCompilationSettings() - ); - const resolvedTypeReferenceDirectives = /* @__PURE__ */ new Map(); - const typeReferenceDirectiveResolutionCache = createTypeReferenceDirectiveResolutionCache( - getCurrentDirectory(), - resolutionHost.getCanonicalFileName, - resolutionHost.getCompilationSettings(), - moduleResolutionCache.getPackageJsonInfoCache() - ); - const resolvedLibraries = /* @__PURE__ */ new Map(); - const libraryResolutionCache = createModuleResolutionCache( - getCurrentDirectory(), - resolutionHost.getCanonicalFileName, - getOptionsForLibraryResolution(resolutionHost.getCompilationSettings()), - moduleResolutionCache.getPackageJsonInfoCache() + function createWatchCompilerHostOfFilesAndCompilerOptions({ + rootFiles, + options, + watchOptions, + projectReferences, + system, + createProgram: createProgram2, + reportDiagnostic, + reportWatchStatus: reportWatchStatus2 + }) { + const host = createWatchCompilerHost(system, createProgram2, reportDiagnostic || createDiagnosticReporter(system), reportWatchStatus2); + host.rootFiles = rootFiles; + host.options = options; + host.watchOptions = watchOptions; + host.projectReferences = projectReferences; + return host; + } + function performIncrementalCompilation(input) { + const system = input.system || sys; + const host = input.host || (input.host = createIncrementalCompilerHost(input.options, system)); + const builderProgram = createIncrementalProgram(input); + const exitStatus = emitFilesAndReportErrorsAndGetExitStatus( + builderProgram, + input.reportDiagnostic || createDiagnosticReporter(system), + (s) => host.trace && host.trace(s), + input.reportErrorSummary || input.options.pretty ? (errorCount, filesInError) => system.write(getErrorSummaryText(errorCount, filesInError, system.newLine, host)) : void 0 ); - const directoryWatchesOfFailedLookups = /* @__PURE__ */ new Map(); - const fileWatchesOfAffectingLocations = /* @__PURE__ */ new Map(); - const rootDir = getRootDirectoryOfResolutionCache(rootDirForResolution, getCurrentDirectory); - const rootPath = resolutionHost.toPath(rootDir); - const rootPathComponents = getPathComponents(rootPath); - const typeRootsWatches = /* @__PURE__ */ new Map(); - return { - getModuleResolutionCache: () => moduleResolutionCache, - startRecordingFilesWithChangedResolutions, - finishRecordingFilesWithChangedResolutions, - // perDirectoryResolvedModuleNames and perDirectoryResolvedTypeReferenceDirectives could be non empty if there was exception during program update - // (between startCachingPerDirectoryResolution and finishCachingPerDirectoryResolution) - startCachingPerDirectoryResolution, - finishCachingPerDirectoryResolution, - resolveModuleNameLiterals, - resolveTypeReferenceDirectiveReferences, - resolveLibrary: resolveLibrary2, - resolveSingleModuleNameWithoutWatching, - removeResolutionsFromProjectReferenceRedirects, - removeResolutionsOfFile, - hasChangedAutomaticTypeDirectiveNames: () => hasChangedAutomaticTypeDirectiveNames, - invalidateResolutionOfFile, - invalidateResolutionsOfFailedLookupLocations, - setFilesWithInvalidatedNonRelativeUnresolvedImports, - createHasInvalidatedResolutions, - isFileWithInvalidatedNonRelativeUnresolvedImports, - updateTypeRootsWatch, - closeTypeRootsWatch, - clear: clear2, - onChangesAffectModuleResolution - }; - function getResolvedModule2(resolution) { - return resolution.resolvedModule; + if (input.afterProgramEmitAndDiagnostics) + input.afterProgramEmitAndDiagnostics(builderProgram); + return exitStatus; + } + var sysFormatDiagnosticsHost, screenStartingMessageCodes, noopFileWatcher, returnNoopFileWatcher, WatchType; + var init_watch = __esm({ + "src/compiler/watch.ts"() { + "use strict"; + init_ts2(); + sysFormatDiagnosticsHost = sys ? { + getCurrentDirectory: () => sys.getCurrentDirectory(), + getNewLine: () => sys.newLine, + getCanonicalFileName: createGetCanonicalFileName(sys.useCaseSensitiveFileNames) + } : void 0; + screenStartingMessageCodes = [ + Diagnostics.Starting_compilation_in_watch_mode.code, + Diagnostics.File_change_detected_Starting_incremental_compilation.code + ]; + noopFileWatcher = { close: noop }; + returnNoopFileWatcher = () => noopFileWatcher; + WatchType = { + ConfigFile: "Config file", + ExtendedConfigFile: "Extended config file", + SourceFile: "Source file", + MissingFile: "Missing file", + WildcardDirectory: "Wild card directory", + FailedLookupLocations: "Failed Lookup Locations", + AffectingFileLocation: "File location affecting resolution", + TypeRoots: "Type roots", + ConfigFileOfReferencedProject: "Config file of referened project", + ExtendedConfigOfReferencedProject: "Extended config file of referenced project", + WildcardDirectoryOfReferencedProject: "Wild card directory of referenced project", + PackageJson: "package.json file", + ClosedScriptInfo: "Closed Script info", + ConfigFileForInferredRoot: "Config file for the inferred project root", + NodeModules: "node_modules for closed script infos and package.jsons affecting module specifier cache", + MissingSourceMapFile: "Missing source map file", + NoopConfigFileForInferredRoot: "Noop Config file for the inferred project root", + MissingGeneratedFile: "Missing generated file", + NodeModulesForModuleSpecifierCache: "node_modules for module specifier cache invalidation", + TypingInstallerLocationFile: "File location for typing installer", + TypingInstallerLocationDirectory: "Directory location for typing installer" + }; } - function getResolvedTypeReferenceDirective2(resolution) { - return resolution.resolvedTypeReferenceDirective; + }); + + // src/compiler/watchPublic.ts + function readBuilderProgram(compilerOptions, host) { + const buildInfoPath = getTsBuildInfoEmitOutputFilePath(compilerOptions); + if (!buildInfoPath) + return void 0; + let buildInfo; + if (host.getBuildInfo) { + buildInfo = host.getBuildInfo(buildInfoPath, compilerOptions.configFilePath); + } else { + const content = host.readFile(buildInfoPath); + if (!content) + return void 0; + buildInfo = getBuildInfo(buildInfoPath, content); } - function clear2() { - clearMap(directoryWatchesOfFailedLookups, closeFileWatcherOf); - clearMap(fileWatchesOfAffectingLocations, closeFileWatcherOf); - nonRelativeExternalModuleResolutions.clear(); - closeTypeRootsWatch(); - resolvedModuleNames.clear(); - resolvedTypeReferenceDirectives.clear(); - resolvedFileToResolution.clear(); - resolutionsWithFailedLookups.clear(); - resolutionsWithOnlyAffectingLocations.clear(); - failedLookupChecks = void 0; - startsWithPathChecks = void 0; - isInDirectoryChecks = void 0; - affectingPathChecks = void 0; - affectingPathChecksForFile = void 0; - allModuleAndTypeResolutionsAreInvalidated = false; - moduleResolutionCache.clear(); - typeReferenceDirectiveResolutionCache.clear(); - moduleResolutionCache.update(resolutionHost.getCompilationSettings()); - typeReferenceDirectiveResolutionCache.update(resolutionHost.getCompilationSettings()); - libraryResolutionCache.clear(); - impliedFormatPackageJsons.clear(); - resolvedLibraries.clear(); - hasChangedAutomaticTypeDirectiveNames = false; + if (!buildInfo || buildInfo.version !== version || !buildInfo.program) + return void 0; + return createBuilderProgramUsingProgramBuildInfo(buildInfo, buildInfoPath, host); + } + function createIncrementalCompilerHost(options, system = sys) { + const host = createCompilerHostWorker( + options, + /*setParentNodes*/ + void 0, + system + ); + host.createHash = maybeBind(system, system.createHash); + host.storeFilesChangingSignatureDuringEmit = system.storeFilesChangingSignatureDuringEmit; + setGetSourceFileAsHashVersioned(host); + changeCompilerHostLikeToUseCache(host, (fileName) => toPath(fileName, host.getCurrentDirectory(), host.getCanonicalFileName)); + return host; + } + function createIncrementalProgram({ + rootNames, + options, + configFileParsingDiagnostics, + projectReferences, + host, + createProgram: createProgram2 + }) { + host = host || createIncrementalCompilerHost(options); + createProgram2 = createProgram2 || createEmitAndSemanticDiagnosticsBuilderProgram; + const oldProgram = readBuilderProgram(options, host); + return createProgram2(rootNames, options, host, oldProgram, configFileParsingDiagnostics, projectReferences); + } + function createWatchCompilerHost2(rootFilesOrConfigFileName, options, system, createProgram2, reportDiagnostic, reportWatchStatus2, projectReferencesOrWatchOptionsToExtend, watchOptionsOrExtraFileExtensions) { + if (isArray(rootFilesOrConfigFileName)) { + return createWatchCompilerHostOfFilesAndCompilerOptions({ + rootFiles: rootFilesOrConfigFileName, + options, + watchOptions: watchOptionsOrExtraFileExtensions, + projectReferences: projectReferencesOrWatchOptionsToExtend, + system, + createProgram: createProgram2, + reportDiagnostic, + reportWatchStatus: reportWatchStatus2 + }); + } else { + return createWatchCompilerHostOfConfigFile({ + configFileName: rootFilesOrConfigFileName, + optionsToExtend: options, + watchOptionsToExtend: projectReferencesOrWatchOptionsToExtend, + extraFileExtensions: watchOptionsOrExtraFileExtensions, + system, + createProgram: createProgram2, + reportDiagnostic, + reportWatchStatus: reportWatchStatus2 + }); } - function onChangesAffectModuleResolution() { - allModuleAndTypeResolutionsAreInvalidated = true; - moduleResolutionCache.clearAllExceptPackageJsonInfoCache(); - typeReferenceDirectiveResolutionCache.clearAllExceptPackageJsonInfoCache(); - moduleResolutionCache.update(resolutionHost.getCompilationSettings()); - typeReferenceDirectiveResolutionCache.update(resolutionHost.getCompilationSettings()); + } + function createWatchProgram(host) { + let builderProgram; + let updateLevel; + let missingFilesMap; + let watchedWildcardDirectories; + let timerToUpdateProgram; + let timerToInvalidateFailedLookupResolutions; + let parsedConfigs; + let sharedExtendedConfigFileWatchers; + let extendedConfigCache = host.extendedConfigCache; + let reportFileChangeDetectedOnCreateProgram = false; + const sourceFilesCache = /* @__PURE__ */ new Map(); + let missingFilePathsRequestedForRelease; + let hasChangedCompilerOptions = false; + const useCaseSensitiveFileNames2 = host.useCaseSensitiveFileNames(); + const currentDirectory = host.getCurrentDirectory(); + const { configFileName, optionsToExtend: optionsToExtendForConfigFile = {}, watchOptionsToExtend, extraFileExtensions, createProgram: createProgram2 } = host; + let { rootFiles: rootFileNames, options: compilerOptions, watchOptions, projectReferences } = host; + let wildcardDirectories; + let configFileParsingDiagnostics; + let canConfigFileJsonReportNoInputFiles = false; + let hasChangedConfigFileParsingErrors = false; + const cachedDirectoryStructureHost = configFileName === void 0 ? void 0 : createCachedDirectoryStructureHost(host, currentDirectory, useCaseSensitiveFileNames2); + const directoryStructureHost = cachedDirectoryStructureHost || host; + const parseConfigFileHost = parseConfigHostFromCompilerHostLike(host, directoryStructureHost); + let newLine = updateNewLine(); + if (configFileName && host.configFileParsingResult) { + setConfigFileParsingResult(host.configFileParsingResult); + newLine = updateNewLine(); } - function startRecordingFilesWithChangedResolutions() { - filesWithChangedSetOfUnresolvedImports = []; + reportWatchDiagnostic(Diagnostics.Starting_compilation_in_watch_mode); + if (configFileName && !host.configFileParsingResult) { + newLine = getNewLineCharacter(optionsToExtendForConfigFile); + Debug.assert(!rootFileNames); + parseConfigFile2(); + newLine = updateNewLine(); } - function finishRecordingFilesWithChangedResolutions() { - const collected = filesWithChangedSetOfUnresolvedImports; - filesWithChangedSetOfUnresolvedImports = void 0; - return collected; + Debug.assert(compilerOptions); + Debug.assert(rootFileNames); + const { watchFile: watchFile2, watchDirectory, writeLog } = createWatchFactory(host, compilerOptions); + const getCanonicalFileName = createGetCanonicalFileName(useCaseSensitiveFileNames2); + writeLog(`Current directory: ${currentDirectory} CaseSensitiveFileNames: ${useCaseSensitiveFileNames2}`); + let configFileWatcher; + if (configFileName) { + configFileWatcher = watchFile2(configFileName, scheduleProgramReload, 2e3 /* High */, watchOptions, WatchType.ConfigFile); } - function isFileWithInvalidatedNonRelativeUnresolvedImports(path) { - if (!filesWithInvalidatedNonRelativeUnresolvedImports) { - return false; - } - const value = filesWithInvalidatedNonRelativeUnresolvedImports.get(path); - return !!value && !!value.length; + let pnpFileWatcher; + const pnpApiPath = getPnpApiPath(__filename); + if (pnpApiPath) { + pnpFileWatcher = watchFile2(pnpApiPath, scheduleResolutionReload, 2e3 /* High */, watchOptions, WatchType.ConfigFile); } - function createHasInvalidatedResolutions(customHasInvalidatedResolutions, customHasInvalidatedLibResolutions) { - invalidateResolutionsOfFailedLookupLocations(); - const collected = filesWithInvalidatedResolutions; - filesWithInvalidatedResolutions = void 0; - return { - hasInvalidatedResolutions: (path) => customHasInvalidatedResolutions(path) || allModuleAndTypeResolutionsAreInvalidated || !!(collected == null ? void 0 : collected.has(path)) || isFileWithInvalidatedNonRelativeUnresolvedImports(path), - hasInvalidatedLibResolutions: (libFileName) => { - var _a; - return customHasInvalidatedLibResolutions(libFileName) || !!((_a = resolvedLibraries == null ? void 0 : resolvedLibraries.get(libFileName)) == null ? void 0 : _a.isInvalidated); - } - }; + const compilerHost = createCompilerHostFromProgramHost(host, () => compilerOptions, directoryStructureHost); + setGetSourceFileAsHashVersioned(compilerHost); + const getNewSourceFile = compilerHost.getSourceFile; + compilerHost.getSourceFile = (fileName, ...args) => getVersionedSourceFileByPath(fileName, toPath3(fileName), ...args); + compilerHost.getSourceFileByPath = getVersionedSourceFileByPath; + compilerHost.getNewLine = () => newLine; + compilerHost.fileExists = fileExists; + compilerHost.onReleaseOldSourceFile = onReleaseOldSourceFile; + compilerHost.onReleaseParsedCommandLine = onReleaseParsedCommandLine; + compilerHost.toPath = toPath3; + compilerHost.getCompilationSettings = () => compilerOptions; + compilerHost.useSourceOfProjectReferenceRedirect = maybeBind(host, host.useSourceOfProjectReferenceRedirect); + compilerHost.watchDirectoryOfFailedLookupLocation = (dir, cb, flags) => watchDirectory(dir, cb, flags, watchOptions, WatchType.FailedLookupLocations); + compilerHost.watchAffectingFileLocation = (file, cb) => watchFile2(file, cb, 2e3 /* High */, watchOptions, WatchType.AffectingFileLocation); + compilerHost.watchTypeRootsDirectory = (dir, cb, flags) => watchDirectory(dir, cb, flags, watchOptions, WatchType.TypeRoots); + compilerHost.getCachedDirectoryStructureHost = () => cachedDirectoryStructureHost; + compilerHost.scheduleInvalidateResolutionsOfFailedLookupLocations = scheduleInvalidateResolutionsOfFailedLookupLocations; + compilerHost.onInvalidatedResolution = scheduleProgramUpdate; + compilerHost.onChangedAutomaticTypeDirectiveNames = scheduleProgramUpdate; + compilerHost.fileIsOpen = returnFalse; + compilerHost.getCurrentProgram = getCurrentProgram; + compilerHost.writeLog = writeLog; + compilerHost.getParsedCommandLine = getParsedCommandLine; + const resolutionCache = createResolutionCache( + compilerHost, + configFileName ? getDirectoryPath(getNormalizedAbsolutePath(configFileName, currentDirectory)) : currentDirectory, + /*logChangesWhenResolvingModule*/ + false + ); + compilerHost.resolveModuleNameLiterals = maybeBind(host, host.resolveModuleNameLiterals); + compilerHost.resolveModuleNames = maybeBind(host, host.resolveModuleNames); + if (!compilerHost.resolveModuleNameLiterals && !compilerHost.resolveModuleNames) { + compilerHost.resolveModuleNameLiterals = resolutionCache.resolveModuleNameLiterals.bind(resolutionCache); } - function startCachingPerDirectoryResolution() { - moduleResolutionCache.clearAllExceptPackageJsonInfoCache(); - typeReferenceDirectiveResolutionCache.clearAllExceptPackageJsonInfoCache(); - libraryResolutionCache.clearAllExceptPackageJsonInfoCache(); - nonRelativeExternalModuleResolutions.forEach(watchFailedLookupLocationOfNonRelativeModuleResolutions); - nonRelativeExternalModuleResolutions.clear(); + compilerHost.resolveTypeReferenceDirectiveReferences = maybeBind(host, host.resolveTypeReferenceDirectiveReferences); + compilerHost.resolveTypeReferenceDirectives = maybeBind(host, host.resolveTypeReferenceDirectives); + if (!compilerHost.resolveTypeReferenceDirectiveReferences && !compilerHost.resolveTypeReferenceDirectives) { + compilerHost.resolveTypeReferenceDirectiveReferences = resolutionCache.resolveTypeReferenceDirectiveReferences.bind(resolutionCache); } - function cleanupLibResolutionWatching(newProgram) { - resolvedLibraries.forEach((resolution, libFileName) => { - var _a; - if (!((_a = newProgram == null ? void 0 : newProgram.resolvedLibReferences) == null ? void 0 : _a.has(libFileName))) { - stopWatchFailedLookupLocationOfResolution( - resolution, - resolutionHost.toPath(getInferredLibraryNameResolveFrom(newProgram.getCompilerOptions(), getCurrentDirectory(), libFileName)), - getResolvedModule2 - ); - resolvedLibraries.delete(libFileName); + compilerHost.resolveLibrary = !host.resolveLibrary ? resolutionCache.resolveLibrary.bind(resolutionCache) : host.resolveLibrary.bind(host); + compilerHost.getModuleResolutionCache = host.resolveModuleNameLiterals || host.resolveModuleNames ? maybeBind(host, host.getModuleResolutionCache) : () => resolutionCache.getModuleResolutionCache(); + const userProvidedResolution = !!host.resolveModuleNameLiterals || !!host.resolveTypeReferenceDirectiveReferences || !!host.resolveModuleNames || !!host.resolveTypeReferenceDirectives; + const customHasInvalidatedResolutions = userProvidedResolution ? maybeBind(host, host.hasInvalidatedResolutions) || returnTrue : returnFalse; + const customHasInvalidLibResolutions = host.resolveLibrary ? maybeBind(host, host.hasInvalidatedLibResolutions) || returnTrue : returnFalse; + builderProgram = readBuilderProgram(compilerOptions, compilerHost); + synchronizeProgram(); + watchConfigFileWildCardDirectories(); + if (configFileName) + updateExtendedConfigFilesWatches(toPath3(configFileName), compilerOptions, watchOptions, WatchType.ExtendedConfigFile); + return configFileName ? { getCurrentProgram: getCurrentBuilderProgram, getProgram: updateProgram, close, getResolutionCache } : { getCurrentProgram: getCurrentBuilderProgram, getProgram: updateProgram, updateRootFileNames, close, getResolutionCache }; + function close() { + clearInvalidateResolutionsOfFailedLookupLocations(); + resolutionCache.clear(); + clearMap(sourceFilesCache, (value) => { + if (value && value.fileWatcher) { + value.fileWatcher.close(); + value.fileWatcher = void 0; } }); - } - function finishCachingPerDirectoryResolution(newProgram, oldProgram) { - filesWithInvalidatedNonRelativeUnresolvedImports = void 0; - allModuleAndTypeResolutionsAreInvalidated = false; - nonRelativeExternalModuleResolutions.forEach(watchFailedLookupLocationOfNonRelativeModuleResolutions); - nonRelativeExternalModuleResolutions.clear(); - if (newProgram !== oldProgram) { - cleanupLibResolutionWatching(newProgram); - newProgram == null ? void 0 : newProgram.getSourceFiles().forEach((newFile) => { - var _a; - const expected = isExternalOrCommonJsModule(newFile) ? ((_a = newFile.packageJsonLocations) == null ? void 0 : _a.length) ?? 0 : 0; - const existing = impliedFormatPackageJsons.get(newFile.path) ?? emptyArray; - for (let i = existing.length; i < expected; i++) { - createFileWatcherOfAffectingLocation( - newFile.packageJsonLocations[i], - /*forResolution*/ - false - ); - } - if (existing.length > expected) { - for (let i = expected; i < existing.length; i++) { - fileWatchesOfAffectingLocations.get(existing[i]).files--; - } - } - if (expected) - impliedFormatPackageJsons.set(newFile.path, newFile.packageJsonLocations); - else - impliedFormatPackageJsons.delete(newFile.path); - }); - impliedFormatPackageJsons.forEach((existing, path) => { - if (!(newProgram == null ? void 0 : newProgram.getSourceFileByPath(path))) { - existing.forEach((location) => fileWatchesOfAffectingLocations.get(location).files--); - impliedFormatPackageJsons.delete(path); - } - }); + if (configFileWatcher) { + configFileWatcher.close(); + configFileWatcher = void 0; } - directoryWatchesOfFailedLookups.forEach((watcher, path) => { - if (watcher.refCount === 0) { - directoryWatchesOfFailedLookups.delete(path); - watcher.watcher.close(); - } - }); - fileWatchesOfAffectingLocations.forEach((watcher, path) => { - if (watcher.files === 0 && watcher.resolutions === 0) { - fileWatchesOfAffectingLocations.delete(path); - watcher.watcher.close(); - } - }); - hasChangedAutomaticTypeDirectiveNames = false; - } - function resolveModuleName2(moduleName, containingFile, compilerOptions, redirectedReference, mode) { - var _a; - const host = ((_a = resolutionHost.getCompilerHost) == null ? void 0 : _a.call(resolutionHost)) || resolutionHost; - const primaryResult = resolveModuleName(moduleName, containingFile, compilerOptions, host, moduleResolutionCache, redirectedReference, mode); - if (!resolutionHost.getGlobalCache) { - return primaryResult; + if (pnpFileWatcher) { + pnpFileWatcher.close(); + pnpFileWatcher = void 0; } - const globalCache = resolutionHost.getGlobalCache(); - if (globalCache !== void 0 && !isExternalModuleNameRelative(moduleName) && !(primaryResult.resolvedModule && extensionIsTS(primaryResult.resolvedModule.extension))) { - const { resolvedModule, failedLookupLocations, affectingLocations, resolutionDiagnostics } = loadModuleFromGlobalCache( - Debug.checkDefined(resolutionHost.globalCacheResolutionModuleName)(moduleName), - resolutionHost.projectName, - compilerOptions, - host, - globalCache, - moduleResolutionCache - ); - if (resolvedModule) { - primaryResult.resolvedModule = resolvedModule; - primaryResult.failedLookupLocations = updateResolutionField(primaryResult.failedLookupLocations, failedLookupLocations); - primaryResult.affectingLocations = updateResolutionField(primaryResult.affectingLocations, affectingLocations); - primaryResult.resolutionDiagnostics = updateResolutionField(primaryResult.resolutionDiagnostics, resolutionDiagnostics); - return primaryResult; - } + extendedConfigCache == null ? void 0 : extendedConfigCache.clear(); + extendedConfigCache = void 0; + if (sharedExtendedConfigFileWatchers) { + clearMap(sharedExtendedConfigFileWatchers, closeFileWatcherOf); + sharedExtendedConfigFileWatchers = void 0; } - return primaryResult; - } - function createModuleResolutionLoader2(containingFile, redirectedReference, options) { - return { - nameAndMode: moduleResolutionNameAndModeGetter, - resolve: (moduleName, resoluionMode) => resolveModuleName2( - moduleName, - containingFile, - options, - redirectedReference, - resoluionMode - ) - }; - } - function resolveNamesWithLocalCache({ - entries, - containingFile, - containingSourceFile, - redirectedReference, - options, - perFileCache, - reusedNames, - loader, - getResolutionWithResolvedFileName, - deferWatchingNonRelativeResolution, - shouldRetryResolution, - logChanges - }) { - var _a; - const path = resolutionHost.toPath(containingFile); - const resolutionsInFile = perFileCache.get(path) || perFileCache.set(path, createModeAwareCache()).get(path); - const resolvedModules = []; - const hasInvalidatedNonRelativeUnresolvedImport = logChanges && isFileWithInvalidatedNonRelativeUnresolvedImports(path); - const program = resolutionHost.getCurrentProgram(); - const oldRedirect = program && program.getResolvedProjectReferenceToRedirect(containingFile); - const unmatchedRedirects = oldRedirect ? !redirectedReference || redirectedReference.sourceFile.path !== oldRedirect.sourceFile.path : !!redirectedReference; - const seenNamesInFile = createModeAwareCache(); - for (const entry of entries) { - const name = loader.nameAndMode.getName(entry); - const mode = loader.nameAndMode.getMode(entry, containingSourceFile); - let resolution = resolutionsInFile.get(name, mode); - if (!seenNamesInFile.has(name, mode) && (allModuleAndTypeResolutionsAreInvalidated || unmatchedRedirects || !resolution || resolution.isInvalidated || // If the name is unresolved import that was invalidated, recalculate - hasInvalidatedNonRelativeUnresolvedImport && !isExternalModuleNameRelative(name) && shouldRetryResolution(resolution))) { - const existingResolution = resolution; - resolution = loader.resolve(name, mode); - if (resolutionHost.onDiscoveredSymlink && resolutionIsSymlink(resolution)) { - resolutionHost.onDiscoveredSymlink(); - } - resolutionsInFile.set(name, mode, resolution); - watchFailedLookupLocationsOfExternalModuleResolutions(name, resolution, path, getResolutionWithResolvedFileName, deferWatchingNonRelativeResolution); - if (existingResolution) { - stopWatchFailedLookupLocationOfResolution(existingResolution, path, getResolutionWithResolvedFileName); - } - if (logChanges && filesWithChangedSetOfUnresolvedImports && !resolutionIsEqualTo(existingResolution, resolution)) { - filesWithChangedSetOfUnresolvedImports.push(path); - logChanges = false; - } - } else { - const host = ((_a = resolutionHost.getCompilerHost) == null ? void 0 : _a.call(resolutionHost)) || resolutionHost; - if (isTraceEnabled(options, host) && !seenNamesInFile.has(name, mode)) { - const resolved = getResolutionWithResolvedFileName(resolution); - trace( - host, - perFileCache === resolvedModuleNames ? (resolved == null ? void 0 : resolved.resolvedFileName) ? resolved.packageId ? Diagnostics.Reusing_resolution_of_module_0_from_1_of_old_program_it_was_successfully_resolved_to_2_with_Package_ID_3 : Diagnostics.Reusing_resolution_of_module_0_from_1_of_old_program_it_was_successfully_resolved_to_2 : Diagnostics.Reusing_resolution_of_module_0_from_1_of_old_program_it_was_not_resolved : (resolved == null ? void 0 : resolved.resolvedFileName) ? resolved.packageId ? Diagnostics.Reusing_resolution_of_type_reference_directive_0_from_1_of_old_program_it_was_successfully_resolved_to_2_with_Package_ID_3 : Diagnostics.Reusing_resolution_of_type_reference_directive_0_from_1_of_old_program_it_was_successfully_resolved_to_2 : Diagnostics.Reusing_resolution_of_type_reference_directive_0_from_1_of_old_program_it_was_not_resolved, - name, - containingFile, - resolved == null ? void 0 : resolved.resolvedFileName, - (resolved == null ? void 0 : resolved.packageId) && packageIdToString(resolved.packageId) - ); - } - } - Debug.assert(resolution !== void 0 && !resolution.isInvalidated); - seenNamesInFile.set(name, mode, true); - resolvedModules.push(resolution); + if (watchedWildcardDirectories) { + clearMap(watchedWildcardDirectories, closeFileWatcherOf); + watchedWildcardDirectories = void 0; } - reusedNames == null ? void 0 : reusedNames.forEach((entry) => seenNamesInFile.set( - loader.nameAndMode.getName(entry), - loader.nameAndMode.getMode(entry, containingSourceFile), - true - )); - if (resolutionsInFile.size() !== seenNamesInFile.size()) { - resolutionsInFile.forEach((resolution, name, mode) => { - if (!seenNamesInFile.has(name, mode)) { - stopWatchFailedLookupLocationOfResolution(resolution, path, getResolutionWithResolvedFileName); - resolutionsInFile.delete(name, mode); - } - }); + if (missingFilesMap) { + clearMap(missingFilesMap, closeFileWatcher); + missingFilesMap = void 0; } - return resolvedModules; - function resolutionIsEqualTo(oldResolution, newResolution) { - if (oldResolution === newResolution) { - return true; - } - if (!oldResolution || !newResolution) { - return false; - } - const oldResult = getResolutionWithResolvedFileName(oldResolution); - const newResult = getResolutionWithResolvedFileName(newResolution); - if (oldResult === newResult) { - return true; - } - if (!oldResult || !newResult) { - return false; - } - return oldResult.resolvedFileName === newResult.resolvedFileName; + if (parsedConfigs) { + clearMap(parsedConfigs, (config) => { + var _a; + (_a = config.watcher) == null ? void 0 : _a.close(); + config.watcher = void 0; + if (config.watchedDirectories) + clearMap(config.watchedDirectories, closeFileWatcherOf); + config.watchedDirectories = void 0; + }); + parsedConfigs = void 0; } } - function resolveTypeReferenceDirectiveReferences(typeDirectiveReferences, containingFile, redirectedReference, options, containingSourceFile, reusedNames) { - var _a; - return resolveNamesWithLocalCache({ - entries: typeDirectiveReferences, - containingFile, - containingSourceFile, - redirectedReference, - options, - reusedNames, - perFileCache: resolvedTypeReferenceDirectives, - loader: createTypeReferenceResolutionLoader( - containingFile, - redirectedReference, - options, - ((_a = resolutionHost.getCompilerHost) == null ? void 0 : _a.call(resolutionHost)) || resolutionHost, - typeReferenceDirectiveResolutionCache - ), - getResolutionWithResolvedFileName: getResolvedTypeReferenceDirective2, - shouldRetryResolution: (resolution) => resolution.resolvedTypeReferenceDirective === void 0, - deferWatchingNonRelativeResolution: false - }); + function getResolutionCache() { + return resolutionCache; } - function resolveModuleNameLiterals(moduleLiterals, containingFile, redirectedReference, options, containingSourceFile, reusedNames) { - return resolveNamesWithLocalCache({ - entries: moduleLiterals, - containingFile, - containingSourceFile, - redirectedReference, - options, - reusedNames, - perFileCache: resolvedModuleNames, - loader: createModuleResolutionLoader2( - containingFile, - redirectedReference, - options - ), - getResolutionWithResolvedFileName: getResolvedModule2, - shouldRetryResolution: (resolution) => !resolution.resolvedModule || !resolutionExtensionIsTSOrJson(resolution.resolvedModule.extension), - logChanges: logChangesWhenResolvingModule, - deferWatchingNonRelativeResolution: true - // Defer non relative resolution watch because we could be using ambient modules - }); + function getCurrentBuilderProgram() { + return builderProgram; } - function resolveLibrary2(libraryName, resolveFrom, options, libFileName) { - var _a; - const host = ((_a = resolutionHost.getCompilerHost) == null ? void 0 : _a.call(resolutionHost)) || resolutionHost; - let resolution = resolvedLibraries == null ? void 0 : resolvedLibraries.get(libFileName); - if (!resolution || resolution.isInvalidated) { - const existingResolution = resolution; - resolution = resolveLibrary(libraryName, resolveFrom, options, host, libraryResolutionCache); - const path = resolutionHost.toPath(resolveFrom); - watchFailedLookupLocationsOfExternalModuleResolutions( - libraryName, - resolution, - path, - getResolvedModule2, - /*deferWatchingNonRelativeResolution*/ - false - ); - resolvedLibraries.set(libFileName, resolution); - if (existingResolution) { - stopWatchFailedLookupLocationOfResolution(existingResolution, path, getResolvedModule2); + function getCurrentProgram() { + return builderProgram && builderProgram.getProgramOrUndefined(); + } + function synchronizeProgram(forceAllFilesAsInvalidated = false) { + writeLog(`Synchronizing program`); + Debug.assert(compilerOptions); + Debug.assert(rootFileNames); + clearInvalidateResolutionsOfFailedLookupLocations(); + const program = getCurrentBuilderProgram(); + if (hasChangedCompilerOptions) { + newLine = updateNewLine(); + if (program && changesAffectModuleResolution(program.getCompilerOptions(), compilerOptions)) { + resolutionCache.onChangesAffectModuleResolution(); } - } else { - if (isTraceEnabled(options, host)) { - const resolved = getResolvedModule2(resolution); - trace( - host, - (resolved == null ? void 0 : resolved.resolvedFileName) ? resolved.packageId ? Diagnostics.Reusing_resolution_of_module_0_from_1_of_old_program_it_was_successfully_resolved_to_2_with_Package_ID_3 : Diagnostics.Reusing_resolution_of_module_0_from_1_of_old_program_it_was_successfully_resolved_to_2 : Diagnostics.Reusing_resolution_of_module_0_from_1_of_old_program_it_was_not_resolved, - libraryName, - resolveFrom, - resolved == null ? void 0 : resolved.resolvedFileName, - (resolved == null ? void 0 : resolved.packageId) && packageIdToString(resolved.packageId) + } + const { hasInvalidatedResolutions, hasInvalidatedLibResolutions } = resolutionCache.createHasInvalidatedResolutions(forceAllFilesAsInvalidated ? returnTrue : customHasInvalidatedResolutions, customHasInvalidLibResolutions); + const { + originalReadFile, + originalFileExists, + originalDirectoryExists, + originalCreateDirectory, + originalWriteFile, + readFileWithCache + } = changeCompilerHostLikeToUseCache(compilerHost, toPath3); + if (isProgramUptoDate(getCurrentProgram(), rootFileNames, compilerOptions, (path) => getSourceVersion(path, readFileWithCache), (fileName) => compilerHost.fileExists(fileName), hasInvalidatedResolutions, hasInvalidatedLibResolutions, hasChangedAutomaticTypeDirectiveNames, getParsedCommandLine, projectReferences)) { + if (hasChangedConfigFileParsingErrors) { + if (reportFileChangeDetectedOnCreateProgram) { + reportWatchDiagnostic(Diagnostics.File_change_detected_Starting_incremental_compilation); + } + builderProgram = createProgram2( + /*rootNames*/ + void 0, + /*options*/ + void 0, + compilerHost, + builderProgram, + configFileParsingDiagnostics, + projectReferences ); + hasChangedConfigFileParsingErrors = false; + } + } else { + if (reportFileChangeDetectedOnCreateProgram) { + reportWatchDiagnostic(Diagnostics.File_change_detected_Starting_incremental_compilation); } + createNewProgram(hasInvalidatedResolutions, hasInvalidatedLibResolutions); } - return resolution; + reportFileChangeDetectedOnCreateProgram = false; + if (host.afterProgramCreate && program !== builderProgram) { + host.afterProgramCreate(builderProgram); + } + compilerHost.readFile = originalReadFile; + compilerHost.fileExists = originalFileExists; + compilerHost.directoryExists = originalDirectoryExists; + compilerHost.createDirectory = originalCreateDirectory; + compilerHost.writeFile = originalWriteFile; + return builderProgram; } - function resolveSingleModuleNameWithoutWatching(moduleName, containingFile) { - const path = resolutionHost.toPath(containingFile); - const resolutionsInFile = resolvedModuleNames.get(path); - const resolution = resolutionsInFile == null ? void 0 : resolutionsInFile.get( - moduleName, - /*mode*/ - void 0 - ); - if (resolution && !resolution.isInvalidated) - return resolution; - return resolveModuleName2(moduleName, containingFile, resolutionHost.getCompilationSettings()); + function createNewProgram(hasInvalidatedResolutions, hasInvalidatedLibResolutions) { + writeLog("CreatingProgramWith::"); + writeLog(` roots: ${JSON.stringify(rootFileNames)}`); + writeLog(` options: ${JSON.stringify(compilerOptions)}`); + if (projectReferences) + writeLog(` projectReferences: ${JSON.stringify(projectReferences)}`); + const needsUpdateInTypeRootWatch = hasChangedCompilerOptions || !getCurrentProgram(); + hasChangedCompilerOptions = false; + hasChangedConfigFileParsingErrors = false; + resolutionCache.startCachingPerDirectoryResolution(); + compilerHost.hasInvalidatedResolutions = hasInvalidatedResolutions; + compilerHost.hasInvalidatedLibResolutions = hasInvalidatedLibResolutions; + compilerHost.hasChangedAutomaticTypeDirectiveNames = hasChangedAutomaticTypeDirectiveNames; + const oldProgram = getCurrentProgram(); + builderProgram = createProgram2(rootFileNames, compilerOptions, compilerHost, builderProgram, configFileParsingDiagnostics, projectReferences); + resolutionCache.finishCachingPerDirectoryResolution(builderProgram.getProgram(), oldProgram); + updateMissingFilePathsWatch(builderProgram.getProgram(), missingFilesMap || (missingFilesMap = /* @__PURE__ */ new Map()), watchMissingFilePath); + if (needsUpdateInTypeRootWatch) { + resolutionCache.updateTypeRootsWatch(); + } + if (missingFilePathsRequestedForRelease) { + for (const missingFilePath of missingFilePathsRequestedForRelease) { + if (!missingFilesMap.has(missingFilePath)) { + sourceFilesCache.delete(missingFilePath); + } + } + missingFilePathsRequestedForRelease = void 0; + } } - function isNodeModulesAtTypesDirectory(dirPath) { - return endsWith(dirPath, "/node_modules/@types"); + function updateRootFileNames(files) { + Debug.assert(!configFileName, "Cannot update root file names with config file watch mode"); + rootFileNames = files; + scheduleProgramUpdate(); } - function watchFailedLookupLocationsOfExternalModuleResolutions(name, resolution, filePath, getResolutionWithResolvedFileName, deferWatchingNonRelativeResolution) { - var _a; - if (resolution.refCount) { - resolution.refCount++; - Debug.assertIsDefined(resolution.files); - } else { - resolution.refCount = 1; - Debug.assert(!((_a = resolution.files) == null ? void 0 : _a.size)); - if (!deferWatchingNonRelativeResolution || isExternalModuleNameRelative(name)) { - watchFailedLookupLocationOfResolution(resolution); + function updateNewLine() { + return getNewLineCharacter(compilerOptions || optionsToExtendForConfigFile); + } + function toPath3(fileName) { + return toPath(fileName, currentDirectory, getCanonicalFileName); + } + function isFileMissingOnHost(hostSourceFile) { + return typeof hostSourceFile === "boolean"; + } + function isFilePresenceUnknownOnHost(hostSourceFile) { + return typeof hostSourceFile.version === "boolean"; + } + function fileExists(fileName) { + const path = toPath3(fileName); + if (isFileMissingOnHost(sourceFilesCache.get(path))) { + return false; + } + return directoryStructureHost.fileExists(fileName); + } + function getVersionedSourceFileByPath(fileName, path, languageVersionOrOptions, onError, shouldCreateNewSourceFile) { + const hostSourceFile = sourceFilesCache.get(path); + if (isFileMissingOnHost(hostSourceFile)) { + return void 0; + } + const impliedNodeFormat = typeof languageVersionOrOptions === "object" ? languageVersionOrOptions.impliedNodeFormat : void 0; + if (hostSourceFile === void 0 || shouldCreateNewSourceFile || isFilePresenceUnknownOnHost(hostSourceFile) || hostSourceFile.sourceFile.impliedNodeFormat !== impliedNodeFormat) { + const sourceFile = getNewSourceFile(fileName, languageVersionOrOptions, onError); + if (hostSourceFile) { + if (sourceFile) { + hostSourceFile.sourceFile = sourceFile; + hostSourceFile.version = sourceFile.version; + if (!hostSourceFile.fileWatcher) { + hostSourceFile.fileWatcher = watchFilePath(path, fileName, onSourceFileChange, 250 /* Low */, watchOptions, WatchType.SourceFile); + } + } else { + if (hostSourceFile.fileWatcher) { + hostSourceFile.fileWatcher.close(); + } + sourceFilesCache.set(path, false); + } } else { - nonRelativeExternalModuleResolutions.add(name, resolution); - } - const resolved = getResolutionWithResolvedFileName(resolution); - if (resolved && resolved.resolvedFileName) { - const key = resolutionHost.toPath(resolved.resolvedFileName); - let resolutions = resolvedFileToResolution.get(key); - if (!resolutions) - resolvedFileToResolution.set(key, resolutions = /* @__PURE__ */ new Set()); - resolutions.add(resolution); + if (sourceFile) { + const fileWatcher = watchFilePath(path, fileName, onSourceFileChange, 250 /* Low */, watchOptions, WatchType.SourceFile); + sourceFilesCache.set(path, { sourceFile, version: sourceFile.version, fileWatcher }); + } else { + sourceFilesCache.set(path, false); + } } + return sourceFile; } - (resolution.files ?? (resolution.files = /* @__PURE__ */ new Set())).add(filePath); + return hostSourceFile.sourceFile; } - function watchFailedLookupLocation(failedLookupLocation, setAtRoot) { - const failedLookupLocationPath = resolutionHost.toPath(failedLookupLocation); - const toWatch = getDirectoryToWatchFailedLookupLocation( - failedLookupLocation, - failedLookupLocationPath, - rootDir, - rootPath, - rootPathComponents, - getCurrentDirectory - ); - if (toWatch) { - const { dir, dirPath, nonRecursive } = toWatch; - if (dirPath === rootPath) { - Debug.assert(nonRecursive); - setAtRoot = true; + function nextSourceFileVersion(path) { + const hostSourceFile = sourceFilesCache.get(path); + if (hostSourceFile !== void 0) { + if (isFileMissingOnHost(hostSourceFile)) { + sourceFilesCache.set(path, { version: false }); } else { - setDirectoryWatcher(dir, dirPath, nonRecursive); + hostSourceFile.version = false; } } - return setAtRoot; } - function watchFailedLookupLocationOfResolution(resolution) { - Debug.assert(!!resolution.refCount); - const { failedLookupLocations, affectingLocations, node10Result } = resolution; - if (!(failedLookupLocations == null ? void 0 : failedLookupLocations.length) && !(affectingLocations == null ? void 0 : affectingLocations.length) && !node10Result) - return; - if ((failedLookupLocations == null ? void 0 : failedLookupLocations.length) || node10Result) - resolutionsWithFailedLookups.add(resolution); - let setAtRoot = false; - if (failedLookupLocations) { - for (const failedLookupLocation of failedLookupLocations) { - setAtRoot = watchFailedLookupLocation(failedLookupLocation, setAtRoot); + function getSourceVersion(path, readFileWithCache) { + const hostSourceFile = sourceFilesCache.get(path); + if (!hostSourceFile) + return void 0; + if (hostSourceFile.version) + return hostSourceFile.version; + const text = readFileWithCache(path); + return text !== void 0 ? getSourceFileVersionAsHashFromText(compilerHost, text) : void 0; + } + function onReleaseOldSourceFile(oldSourceFile, _oldOptions, hasSourceFileByPath) { + const hostSourceFileInfo = sourceFilesCache.get(oldSourceFile.resolvedPath); + if (hostSourceFileInfo !== void 0) { + if (isFileMissingOnHost(hostSourceFileInfo)) { + (missingFilePathsRequestedForRelease || (missingFilePathsRequestedForRelease = [])).push(oldSourceFile.path); + } else if (hostSourceFileInfo.sourceFile === oldSourceFile) { + if (hostSourceFileInfo.fileWatcher) { + hostSourceFileInfo.fileWatcher.close(); + } + sourceFilesCache.delete(oldSourceFile.resolvedPath); + if (!hasSourceFileByPath) { + resolutionCache.removeResolutionsOfFile(oldSourceFile.path); + } } } - if (node10Result) - setAtRoot = watchFailedLookupLocation(node10Result, setAtRoot); - if (setAtRoot) { - setDirectoryWatcher( - rootDir, - rootPath, - /*nonRecursive*/ - true - ); + } + function reportWatchDiagnostic(message) { + if (host.onWatchStatusChange) { + host.onWatchStatusChange(createCompilerDiagnostic(message), newLine, compilerOptions || optionsToExtendForConfigFile); } - watchAffectingLocationsOfResolution(resolution, !(failedLookupLocations == null ? void 0 : failedLookupLocations.length) && !node10Result); } - function watchAffectingLocationsOfResolution(resolution, addToResolutionsWithOnlyAffectingLocations) { - Debug.assert(!!resolution.refCount); - const { affectingLocations } = resolution; - if (!(affectingLocations == null ? void 0 : affectingLocations.length)) - return; - if (addToResolutionsWithOnlyAffectingLocations) - resolutionsWithOnlyAffectingLocations.add(resolution); - for (const affectingLocation of affectingLocations) { - createFileWatcherOfAffectingLocation( - affectingLocation, - /*forResolution*/ - true - ); + function hasChangedAutomaticTypeDirectiveNames() { + return resolutionCache.hasChangedAutomaticTypeDirectiveNames(); + } + function clearInvalidateResolutionsOfFailedLookupLocations() { + if (!timerToInvalidateFailedLookupResolutions) + return false; + host.clearTimeout(timerToInvalidateFailedLookupResolutions); + timerToInvalidateFailedLookupResolutions = void 0; + return true; + } + function scheduleInvalidateResolutionsOfFailedLookupLocations() { + if (!host.setTimeout || !host.clearTimeout) { + return resolutionCache.invalidateResolutionsOfFailedLookupLocations(); } + const pending = clearInvalidateResolutionsOfFailedLookupLocations(); + writeLog(`Scheduling invalidateFailedLookup${pending ? ", Cancelled earlier one" : ""}`); + timerToInvalidateFailedLookupResolutions = host.setTimeout(invalidateResolutionsOfFailedLookup, 250, "timerToInvalidateFailedLookupResolutions"); } - function createFileWatcherOfAffectingLocation(affectingLocation, forResolution) { - const fileWatcher = fileWatchesOfAffectingLocations.get(affectingLocation); - if (fileWatcher) { - if (forResolution) - fileWatcher.resolutions++; - else - fileWatcher.files++; + function invalidateResolutionsOfFailedLookup() { + timerToInvalidateFailedLookupResolutions = void 0; + if (resolutionCache.invalidateResolutionsOfFailedLookupLocations()) { + scheduleProgramUpdate(); + } + } + function scheduleProgramUpdate() { + if (!host.setTimeout || !host.clearTimeout) { return; } - let locationToWatch = affectingLocation; - if (resolutionHost.realpath) { - locationToWatch = resolutionHost.realpath(affectingLocation); - if (affectingLocation !== locationToWatch) { - const fileWatcher2 = fileWatchesOfAffectingLocations.get(locationToWatch); - if (fileWatcher2) { - if (forResolution) - fileWatcher2.resolutions++; - else - fileWatcher2.files++; - fileWatcher2.paths.add(affectingLocation); - fileWatchesOfAffectingLocations.set(affectingLocation, fileWatcher2); - return; - } - } + if (timerToUpdateProgram) { + host.clearTimeout(timerToUpdateProgram); } - const paths = /* @__PURE__ */ new Set(); - paths.add(locationToWatch); - let actualWatcher = canWatchAffectingLocation(resolutionHost.toPath(locationToWatch)) ? resolutionHost.watchAffectingFileLocation(locationToWatch, (fileName, eventKind) => { - cachedDirectoryStructureHost == null ? void 0 : cachedDirectoryStructureHost.addOrDeleteFile(fileName, resolutionHost.toPath(locationToWatch), eventKind); - const packageJsonMap = moduleResolutionCache.getPackageJsonInfoCache().getInternalMap(); - paths.forEach((path) => { - if (watcher.resolutions) - (affectingPathChecks ?? (affectingPathChecks = /* @__PURE__ */ new Set())).add(path); - if (watcher.files) - (affectingPathChecksForFile ?? (affectingPathChecksForFile = /* @__PURE__ */ new Set())).add(path); - packageJsonMap == null ? void 0 : packageJsonMap.delete(resolutionHost.toPath(path)); - }); - resolutionHost.scheduleInvalidateResolutionsOfFailedLookupLocations(); - }) : noopFileWatcher; - const watcher = { - watcher: actualWatcher !== noopFileWatcher ? { - close: () => { - actualWatcher.close(); - actualWatcher = noopFileWatcher; - } - } : actualWatcher, - resolutions: forResolution ? 1 : 0, - files: forResolution ? 0 : 1, - paths - }; - fileWatchesOfAffectingLocations.set(locationToWatch, watcher); - if (affectingLocation !== locationToWatch) { - fileWatchesOfAffectingLocations.set(affectingLocation, watcher); - paths.add(affectingLocation); + writeLog("Scheduling update"); + timerToUpdateProgram = host.setTimeout(updateProgramWithWatchStatus, 250, "timerToUpdateProgram"); + } + function scheduleProgramReload() { + Debug.assert(!!configFileName); + updateLevel = 2 /* Full */; + scheduleProgramUpdate(); + } + function scheduleResolutionReload() { + writeLog("Clearing resolutions"); + resolutionCache.clear(); + updateLevel = 3 /* Resolutions */; + scheduleProgramUpdate(); + } + function updateProgramWithWatchStatus() { + timerToUpdateProgram = void 0; + reportFileChangeDetectedOnCreateProgram = true; + updateProgram(); + } + function updateProgram() { + var _a, _b, _c, _d, _e; + switch (updateLevel) { + case 1 /* RootNamesAndUpdate */: + (_a = perfLogger) == null ? void 0 : _a.logStartUpdateProgram("PartialConfigReload"); + reloadFileNamesFromConfigFile(); + break; + case 2 /* Full */: + (_b = perfLogger) == null ? void 0 : _b.logStartUpdateProgram("FullConfigReload"); + reloadConfigFile(); + break; + case 3 /* Resolutions */: + (_c = perfLogger) == null ? void 0 : _c.logStartUpdateProgram("SynchronizeProgramWithResolutions"); + synchronizeProgram( + /*forceAllFilesAsInvalidated*/ + true + ); + break; + default: + (_d = perfLogger) == null ? void 0 : _d.logStartUpdateProgram("SynchronizeProgram"); + synchronizeProgram(); + break; } + (_e = perfLogger) == null ? void 0 : _e.logStopUpdateProgram("Done"); + return getCurrentBuilderProgram(); } - function watchFailedLookupLocationOfNonRelativeModuleResolutions(resolutions, name) { - const program = resolutionHost.getCurrentProgram(); - if (!program || !program.getTypeChecker().tryFindAmbientModuleWithoutAugmentations(name)) { - resolutions.forEach(watchFailedLookupLocationOfResolution); - } else { - resolutions.forEach((resolution) => watchAffectingLocationsOfResolution( - resolution, - /*addToResolutionsWithOnlyAffectingLocations*/ - true - )); + function reloadFileNamesFromConfigFile() { + writeLog("Reloading new file names and options"); + Debug.assert(compilerOptions); + Debug.assert(configFileName); + updateLevel = 0 /* Update */; + rootFileNames = getFileNamesFromConfigSpecs(compilerOptions.configFile.configFileSpecs, getNormalizedAbsolutePath(getDirectoryPath(configFileName), currentDirectory), compilerOptions, parseConfigFileHost, extraFileExtensions); + if (updateErrorForNoInputFiles(rootFileNames, getNormalizedAbsolutePath(configFileName, currentDirectory), compilerOptions.configFile.configFileSpecs, configFileParsingDiagnostics, canConfigFileJsonReportNoInputFiles)) { + hasChangedConfigFileParsingErrors = true; } + synchronizeProgram(); } - function setDirectoryWatcher(dir, dirPath, nonRecursive) { - const dirWatcher = directoryWatchesOfFailedLookups.get(dirPath); - if (dirWatcher) { - Debug.assert(!!nonRecursive === !!dirWatcher.nonRecursive); - dirWatcher.refCount++; - } else { - directoryWatchesOfFailedLookups.set(dirPath, { watcher: createDirectoryWatcher(dir, dirPath, nonRecursive), refCount: 1, nonRecursive }); + function reloadConfigFile() { + Debug.assert(configFileName); + writeLog(`Reloading config file: ${configFileName}`); + updateLevel = 0 /* Update */; + if (cachedDirectoryStructureHost) { + cachedDirectoryStructureHost.clearCache(); } + parseConfigFile2(); + hasChangedCompilerOptions = true; + synchronizeProgram(); + watchConfigFileWildCardDirectories(); + updateExtendedConfigFilesWatches(toPath3(configFileName), compilerOptions, watchOptions, WatchType.ExtendedConfigFile); } - function stopWatchFailedLookupLocation(failedLookupLocation, removeAtRoot) { - const failedLookupLocationPath = resolutionHost.toPath(failedLookupLocation); - const toWatch = getDirectoryToWatchFailedLookupLocation( - failedLookupLocation, - failedLookupLocationPath, - rootDir, - rootPath, - rootPathComponents, - getCurrentDirectory + function parseConfigFile2() { + Debug.assert(configFileName); + setConfigFileParsingResult( + getParsedCommandLineOfConfigFile( + configFileName, + optionsToExtendForConfigFile, + parseConfigFileHost, + extendedConfigCache || (extendedConfigCache = /* @__PURE__ */ new Map()), + watchOptionsToExtend, + extraFileExtensions + ) ); - if (toWatch) { - const { dirPath } = toWatch; - if (dirPath === rootPath) { - removeAtRoot = true; - } else { - removeDirectoryWatcher(dirPath); - } - } - return removeAtRoot; } - function stopWatchFailedLookupLocationOfResolution(resolution, filePath, getResolutionWithResolvedFileName) { - Debug.checkDefined(resolution.files).delete(filePath); - resolution.refCount--; - if (resolution.refCount) { - return; - } - const resolved = getResolutionWithResolvedFileName(resolution); - if (resolved && resolved.resolvedFileName) { - const key = resolutionHost.toPath(resolved.resolvedFileName); - const resolutions = resolvedFileToResolution.get(key); - if ((resolutions == null ? void 0 : resolutions.delete(resolution)) && !resolutions.size) - resolvedFileToResolution.delete(key); - } - const { failedLookupLocations, affectingLocations, node10Result } = resolution; - if (resolutionsWithFailedLookups.delete(resolution)) { - let removeAtRoot = false; - if (failedLookupLocations) { - for (const failedLookupLocation of failedLookupLocations) { - removeAtRoot = stopWatchFailedLookupLocation(failedLookupLocation, removeAtRoot); - } + function setConfigFileParsingResult(configFileParseResult) { + rootFileNames = configFileParseResult.fileNames; + compilerOptions = configFileParseResult.options; + watchOptions = configFileParseResult.watchOptions; + projectReferences = configFileParseResult.projectReferences; + wildcardDirectories = configFileParseResult.wildcardDirectories; + configFileParsingDiagnostics = getConfigFileParsingDiagnostics(configFileParseResult).slice(); + canConfigFileJsonReportNoInputFiles = canJsonReportNoInputFiles(configFileParseResult.raw); + hasChangedConfigFileParsingErrors = true; + } + function getParsedCommandLine(configFileName2) { + const configPath = toPath3(configFileName2); + let config = parsedConfigs == null ? void 0 : parsedConfigs.get(configPath); + if (config) { + if (!config.updateLevel) + return config.parsedCommandLine; + if (config.parsedCommandLine && config.updateLevel === 1 /* RootNamesAndUpdate */ && !host.getParsedCommandLine) { + writeLog("Reloading new file names and options"); + Debug.assert(compilerOptions); + const fileNames = getFileNamesFromConfigSpecs( + config.parsedCommandLine.options.configFile.configFileSpecs, + getNormalizedAbsolutePath(getDirectoryPath(configFileName2), currentDirectory), + compilerOptions, + parseConfigFileHost + ); + config.parsedCommandLine = { ...config.parsedCommandLine, fileNames }; + config.updateLevel = void 0; + return config.parsedCommandLine; } - if (node10Result) - removeAtRoot = stopWatchFailedLookupLocation(node10Result, removeAtRoot); - if (removeAtRoot) - removeDirectoryWatcher(rootPath); - } else if (affectingLocations == null ? void 0 : affectingLocations.length) { - resolutionsWithOnlyAffectingLocations.delete(resolution); } - if (affectingLocations) { - for (const affectingLocation of affectingLocations) { - const watcher = fileWatchesOfAffectingLocations.get(affectingLocation); - watcher.resolutions--; - } + writeLog(`Loading config file: ${configFileName2}`); + const parsedCommandLine = host.getParsedCommandLine ? host.getParsedCommandLine(configFileName2) : getParsedCommandLineFromConfigFileHost(configFileName2); + if (config) { + config.parsedCommandLine = parsedCommandLine; + config.updateLevel = void 0; + } else { + (parsedConfigs || (parsedConfigs = /* @__PURE__ */ new Map())).set(configPath, config = { parsedCommandLine }); } + watchReferencedProject(configFileName2, configPath, config); + return parsedCommandLine; } - function removeDirectoryWatcher(dirPath) { - const dirWatcher = directoryWatchesOfFailedLookups.get(dirPath); - dirWatcher.refCount--; + function getParsedCommandLineFromConfigFileHost(configFileName2) { + const onUnRecoverableConfigFileDiagnostic = parseConfigFileHost.onUnRecoverableConfigFileDiagnostic; + parseConfigFileHost.onUnRecoverableConfigFileDiagnostic = noop; + const parsedCommandLine = getParsedCommandLineOfConfigFile( + configFileName2, + /*optionsToExtend*/ + void 0, + parseConfigFileHost, + extendedConfigCache || (extendedConfigCache = /* @__PURE__ */ new Map()), + watchOptionsToExtend + ); + parseConfigFileHost.onUnRecoverableConfigFileDiagnostic = onUnRecoverableConfigFileDiagnostic; + return parsedCommandLine; } - function createDirectoryWatcher(directory, dirPath, nonRecursive) { - return resolutionHost.watchDirectoryOfFailedLookupLocation(directory, (fileOrDirectory) => { - const fileOrDirectoryPath = resolutionHost.toPath(fileOrDirectory); - if (cachedDirectoryStructureHost) { - cachedDirectoryStructureHost.addOrDeleteFileOrDirectory(fileOrDirectory, fileOrDirectoryPath); - } - scheduleInvalidateResolutionOfFailedLookupLocation(fileOrDirectoryPath, dirPath === fileOrDirectoryPath); - }, nonRecursive ? 0 /* None */ : 1 /* Recursive */); + function onReleaseParsedCommandLine(fileName) { + var _a; + const path = toPath3(fileName); + const config = parsedConfigs == null ? void 0 : parsedConfigs.get(path); + if (!config) + return; + parsedConfigs.delete(path); + if (config.watchedDirectories) + clearMap(config.watchedDirectories, closeFileWatcherOf); + (_a = config.watcher) == null ? void 0 : _a.close(); + clearSharedExtendedConfigFileWatcher(path, sharedExtendedConfigFileWatchers); } - function removeResolutionsOfFileFromCache(cache, filePath, getResolutionWithResolvedFileName) { - const resolutions = cache.get(filePath); - if (resolutions) { - resolutions.forEach((resolution) => stopWatchFailedLookupLocationOfResolution(resolution, filePath, getResolutionWithResolvedFileName)); - cache.delete(filePath); - } + function watchFilePath(path, file, callback, pollingInterval, options, watchType) { + return watchFile2(file, (fileName, eventKind) => callback(fileName, eventKind, path), pollingInterval, options, watchType); } - function removeResolutionsFromProjectReferenceRedirects(filePath) { - if (!fileExtensionIs(filePath, ".json" /* Json */)) - return; - const program = resolutionHost.getCurrentProgram(); - if (!program) - return; - const resolvedProjectReference = program.getResolvedProjectReferenceByPath(filePath); - if (!resolvedProjectReference) - return; - resolvedProjectReference.commandLine.fileNames.forEach((f) => removeResolutionsOfFile(resolutionHost.toPath(f))); + function onSourceFileChange(fileName, eventKind, path) { + updateCachedSystemWithFile(fileName, path, eventKind); + if (eventKind === 2 /* Deleted */ && sourceFilesCache.has(path)) { + resolutionCache.invalidateResolutionOfFile(path); + } + nextSourceFileVersion(path); + scheduleProgramUpdate(); } - function removeResolutionsOfFile(filePath) { - removeResolutionsOfFileFromCache(resolvedModuleNames, filePath, getResolvedModule2); - removeResolutionsOfFileFromCache(resolvedTypeReferenceDirectives, filePath, getResolvedTypeReferenceDirective2); + function updateCachedSystemWithFile(fileName, path, eventKind) { + if (cachedDirectoryStructureHost) { + cachedDirectoryStructureHost.addOrDeleteFile(fileName, path, eventKind); + } } - function invalidateResolutions(resolutions, canInvalidate) { - if (!resolutions) - return false; - let invalidated = false; - resolutions.forEach((resolution) => { - if (resolution.isInvalidated || !canInvalidate(resolution)) - return; - resolution.isInvalidated = invalidated = true; - for (const containingFilePath of Debug.checkDefined(resolution.files)) { - (filesWithInvalidatedResolutions ?? (filesWithInvalidatedResolutions = /* @__PURE__ */ new Set())).add(containingFilePath); - hasChangedAutomaticTypeDirectiveNames = hasChangedAutomaticTypeDirectiveNames || endsWith(containingFilePath, inferredTypesContainingFile); - } - }); - return invalidated; + function watchMissingFilePath(missingFilePath) { + return (parsedConfigs == null ? void 0 : parsedConfigs.has(missingFilePath)) ? noopFileWatcher : watchFilePath(missingFilePath, missingFilePath, onMissingFileChange, 500 /* Medium */, watchOptions, WatchType.MissingFile); } - function invalidateResolutionOfFile(filePath) { - removeResolutionsOfFile(filePath); - const prevHasChangedAutomaticTypeDirectiveNames = hasChangedAutomaticTypeDirectiveNames; - if (invalidateResolutions(resolvedFileToResolution.get(filePath), returnTrue) && hasChangedAutomaticTypeDirectiveNames && !prevHasChangedAutomaticTypeDirectiveNames) { - resolutionHost.onChangedAutomaticTypeDirectiveNames(); + function onMissingFileChange(fileName, eventKind, missingFilePath) { + updateCachedSystemWithFile(fileName, missingFilePath, eventKind); + if (eventKind === 0 /* Created */ && missingFilesMap.has(missingFilePath)) { + missingFilesMap.get(missingFilePath).close(); + missingFilesMap.delete(missingFilePath); + nextSourceFileVersion(missingFilePath); + scheduleProgramUpdate(); } } - function setFilesWithInvalidatedNonRelativeUnresolvedImports(filesMap) { - Debug.assert(filesWithInvalidatedNonRelativeUnresolvedImports === filesMap || filesWithInvalidatedNonRelativeUnresolvedImports === void 0); - filesWithInvalidatedNonRelativeUnresolvedImports = filesMap; + function watchConfigFileWildCardDirectories() { + if (wildcardDirectories) { + updateWatchingWildcardDirectories( + watchedWildcardDirectories || (watchedWildcardDirectories = /* @__PURE__ */ new Map()), + new Map(Object.entries(wildcardDirectories)), + watchWildcardDirectory + ); + } else if (watchedWildcardDirectories) { + clearMap(watchedWildcardDirectories, closeFileWatcherOf); + } } - function scheduleInvalidateResolutionOfFailedLookupLocation(fileOrDirectoryPath, isCreatingWatchedDirectory) { - if (isCreatingWatchedDirectory) { - (isInDirectoryChecks || (isInDirectoryChecks = /* @__PURE__ */ new Set())).add(fileOrDirectoryPath); - } else { - const updatedPath = removeIgnoredPath(fileOrDirectoryPath); - if (!updatedPath) - return false; - fileOrDirectoryPath = updatedPath; - if (resolutionHost.fileIsOpen(fileOrDirectoryPath)) { - return false; - } - const dirOfFileOrDirectory = getDirectoryPath(fileOrDirectoryPath); - if (isNodeModulesAtTypesDirectory(fileOrDirectoryPath) || isNodeModulesDirectory(fileOrDirectoryPath) || isNodeModulesAtTypesDirectory(dirOfFileOrDirectory) || isNodeModulesDirectory(dirOfFileOrDirectory)) { - (failedLookupChecks || (failedLookupChecks = /* @__PURE__ */ new Set())).add(fileOrDirectoryPath); - (startsWithPathChecks || (startsWithPathChecks = /* @__PURE__ */ new Set())).add(fileOrDirectoryPath); - } else { - if (isEmittedFileOfProgram(resolutionHost.getCurrentProgram(), fileOrDirectoryPath)) { - return false; - } - if (fileExtensionIs(fileOrDirectoryPath, ".map")) { - return false; + function watchWildcardDirectory(directory, flags) { + return watchDirectory( + directory, + (fileOrDirectory) => { + Debug.assert(configFileName); + Debug.assert(compilerOptions); + const fileOrDirectoryPath = toPath3(fileOrDirectory); + if (cachedDirectoryStructureHost) { + cachedDirectoryStructureHost.addOrDeleteFileOrDirectory(fileOrDirectory, fileOrDirectoryPath); } - (failedLookupChecks || (failedLookupChecks = /* @__PURE__ */ new Set())).add(fileOrDirectoryPath); - const packagePath = parseNodeModuleFromPath( + nextSourceFileVersion(fileOrDirectoryPath); + if (isIgnoredFileFromWildCardWatching({ + watchedDirPath: toPath3(directory), + fileOrDirectory, fileOrDirectoryPath, - /*isFolder*/ - true - ); - if (packagePath) - (startsWithPathChecks || (startsWithPathChecks = /* @__PURE__ */ new Set())).add(packagePath); - } - } - resolutionHost.scheduleInvalidateResolutionsOfFailedLookupLocations(); + configFileName, + extraFileExtensions, + options: compilerOptions, + program: getCurrentBuilderProgram() || rootFileNames, + currentDirectory, + useCaseSensitiveFileNames: useCaseSensitiveFileNames2, + writeLog, + toPath: toPath3 + })) + return; + if (updateLevel !== 2 /* Full */) { + updateLevel = 1 /* RootNamesAndUpdate */; + scheduleProgramUpdate(); + } + }, + flags, + watchOptions, + WatchType.WildcardDirectory + ); } - function invalidatePackageJsonMap() { - const packageJsonMap = moduleResolutionCache.getPackageJsonInfoCache().getInternalMap(); - if (packageJsonMap && (failedLookupChecks || startsWithPathChecks || isInDirectoryChecks)) { - packageJsonMap.forEach((_value, path) => isInvalidatedFailedLookup(path) ? packageJsonMap.delete(path) : void 0); - } + function updateExtendedConfigFilesWatches(forProjectPath, options, watchOptions2, watchType) { + updateSharedExtendedConfigFileWatcher( + forProjectPath, + options, + sharedExtendedConfigFileWatchers || (sharedExtendedConfigFileWatchers = /* @__PURE__ */ new Map()), + (extendedConfigFileName, extendedConfigFilePath) => watchFile2( + extendedConfigFileName, + (_fileName, eventKind) => { + var _a; + updateCachedSystemWithFile(extendedConfigFileName, extendedConfigFilePath, eventKind); + if (extendedConfigCache) + cleanExtendedConfigCache(extendedConfigCache, extendedConfigFilePath, toPath3); + const projects = (_a = sharedExtendedConfigFileWatchers.get(extendedConfigFilePath)) == null ? void 0 : _a.projects; + if (!(projects == null ? void 0 : projects.size)) + return; + projects.forEach((projectPath) => { + if (configFileName && toPath3(configFileName) === projectPath) { + updateLevel = 2 /* Full */; + } else { + const config = parsedConfigs == null ? void 0 : parsedConfigs.get(projectPath); + if (config) + config.updateLevel = 2 /* Full */; + resolutionCache.removeResolutionsFromProjectReferenceRedirects(projectPath); + } + scheduleProgramUpdate(); + }); + }, + 2e3 /* High */, + watchOptions2, + watchType + ), + toPath3 + ); } - function invalidateResolutionsOfFailedLookupLocations() { - var _a; - if (allModuleAndTypeResolutionsAreInvalidated) { - affectingPathChecksForFile = void 0; - invalidatePackageJsonMap(); - if (failedLookupChecks || startsWithPathChecks || isInDirectoryChecks || affectingPathChecks) { - invalidateResolutions(resolvedLibraries, canInvalidateFailedLookupResolution); - } - failedLookupChecks = void 0; - startsWithPathChecks = void 0; - isInDirectoryChecks = void 0; - affectingPathChecks = void 0; - return true; - } - let invalidated = false; - if (affectingPathChecksForFile) { - (_a = resolutionHost.getCurrentProgram()) == null ? void 0 : _a.getSourceFiles().forEach((f) => { - if (some(f.packageJsonLocations, (location) => affectingPathChecksForFile.has(location))) { - (filesWithInvalidatedResolutions ?? (filesWithInvalidatedResolutions = /* @__PURE__ */ new Set())).add(f.path); - invalidated = true; + function watchReferencedProject(configFileName2, configPath, commandLine) { + var _a, _b, _c, _d, _e; + commandLine.watcher || (commandLine.watcher = watchFile2( + configFileName2, + (_fileName, eventKind) => { + updateCachedSystemWithFile(configFileName2, configPath, eventKind); + const config = parsedConfigs == null ? void 0 : parsedConfigs.get(configPath); + if (config) + config.updateLevel = 2 /* Full */; + resolutionCache.removeResolutionsFromProjectReferenceRedirects(configPath); + scheduleProgramUpdate(); + }, + 2e3 /* High */, + ((_a = commandLine.parsedCommandLine) == null ? void 0 : _a.watchOptions) || watchOptions, + WatchType.ConfigFileOfReferencedProject + )); + if ((_b = commandLine.parsedCommandLine) == null ? void 0 : _b.wildcardDirectories) { + updateWatchingWildcardDirectories( + commandLine.watchedDirectories || (commandLine.watchedDirectories = /* @__PURE__ */ new Map()), + new Map(Object.entries((_c = commandLine.parsedCommandLine) == null ? void 0 : _c.wildcardDirectories)), + (directory, flags) => { + var _a2; + return watchDirectory( + directory, + (fileOrDirectory) => { + const fileOrDirectoryPath = toPath3(fileOrDirectory); + if (cachedDirectoryStructureHost) { + cachedDirectoryStructureHost.addOrDeleteFileOrDirectory(fileOrDirectory, fileOrDirectoryPath); + } + nextSourceFileVersion(fileOrDirectoryPath); + const config = parsedConfigs == null ? void 0 : parsedConfigs.get(configPath); + if (!(config == null ? void 0 : config.parsedCommandLine)) + return; + if (isIgnoredFileFromWildCardWatching({ + watchedDirPath: toPath3(directory), + fileOrDirectory, + fileOrDirectoryPath, + configFileName: configFileName2, + options: config.parsedCommandLine.options, + program: config.parsedCommandLine.fileNames, + currentDirectory, + useCaseSensitiveFileNames: useCaseSensitiveFileNames2, + writeLog, + toPath: toPath3 + })) + return; + if (config.updateLevel !== 2 /* Full */) { + config.updateLevel = 1 /* RootNamesAndUpdate */; + scheduleProgramUpdate(); + } + }, + flags, + ((_a2 = commandLine.parsedCommandLine) == null ? void 0 : _a2.watchOptions) || watchOptions, + WatchType.WildcardDirectoryOfReferencedProject + ); } - }); - affectingPathChecksForFile = void 0; - } - if (!failedLookupChecks && !startsWithPathChecks && !isInDirectoryChecks && !affectingPathChecks) { - return invalidated; + ); + } else if (commandLine.watchedDirectories) { + clearMap(commandLine.watchedDirectories, closeFileWatcherOf); + commandLine.watchedDirectories = void 0; } - invalidated = invalidateResolutions(resolutionsWithFailedLookups, canInvalidateFailedLookupResolution) || invalidated; - invalidatePackageJsonMap(); - failedLookupChecks = void 0; - startsWithPathChecks = void 0; - isInDirectoryChecks = void 0; - invalidated = invalidateResolutions(resolutionsWithOnlyAffectingLocations, canInvalidatedFailedLookupResolutionWithAffectingLocation) || invalidated; - affectingPathChecks = void 0; - return invalidated; + updateExtendedConfigFilesWatches( + configPath, + (_d = commandLine.parsedCommandLine) == null ? void 0 : _d.options, + ((_e = commandLine.parsedCommandLine) == null ? void 0 : _e.watchOptions) || watchOptions, + WatchType.ExtendedConfigOfReferencedProject + ); } - function canInvalidateFailedLookupResolution(resolution) { - var _a; - if (canInvalidatedFailedLookupResolutionWithAffectingLocation(resolution)) - return true; - if (!failedLookupChecks && !startsWithPathChecks && !isInDirectoryChecks) - return false; - return ((_a = resolution.failedLookupLocations) == null ? void 0 : _a.some((location) => isInvalidatedFailedLookup(resolutionHost.toPath(location)))) || !!resolution.node10Result && isInvalidatedFailedLookup(resolutionHost.toPath(resolution.node10Result)); + } + var init_watchPublic = __esm({ + "src/compiler/watchPublic.ts"() { + "use strict"; + init_ts2(); + init_pnp(); } - function isInvalidatedFailedLookup(locationPath) { - return (failedLookupChecks == null ? void 0 : failedLookupChecks.has(locationPath)) || firstDefinedIterator((startsWithPathChecks == null ? void 0 : startsWithPathChecks.keys()) || [], (fileOrDirectoryPath) => startsWith(locationPath, fileOrDirectoryPath) ? true : void 0) || firstDefinedIterator((isInDirectoryChecks == null ? void 0 : isInDirectoryChecks.keys()) || [], (dirPath) => locationPath.length > dirPath.length && startsWith(locationPath, dirPath) && (isDiskPathRoot(dirPath) || locationPath[dirPath.length] === directorySeparator) ? true : void 0); + }); + + // src/compiler/tsbuild.ts + function resolveConfigFileProjectName(project) { + if (fileExtensionIs(project, ".json" /* Json */)) { + return project; } - function canInvalidatedFailedLookupResolutionWithAffectingLocation(resolution) { - var _a; - return !!affectingPathChecks && ((_a = resolution.affectingLocations) == null ? void 0 : _a.some((location) => affectingPathChecks.has(location))); + return combinePaths(project, "tsconfig.json"); + } + var UpToDateStatusType; + var init_tsbuild = __esm({ + "src/compiler/tsbuild.ts"() { + "use strict"; + init_ts2(); + UpToDateStatusType = /* @__PURE__ */ ((UpToDateStatusType2) => { + UpToDateStatusType2[UpToDateStatusType2["Unbuildable"] = 0] = "Unbuildable"; + UpToDateStatusType2[UpToDateStatusType2["UpToDate"] = 1] = "UpToDate"; + UpToDateStatusType2[UpToDateStatusType2["UpToDateWithUpstreamTypes"] = 2] = "UpToDateWithUpstreamTypes"; + UpToDateStatusType2[UpToDateStatusType2["OutOfDateWithPrepend"] = 3] = "OutOfDateWithPrepend"; + UpToDateStatusType2[UpToDateStatusType2["OutputMissing"] = 4] = "OutputMissing"; + UpToDateStatusType2[UpToDateStatusType2["ErrorReadingFile"] = 5] = "ErrorReadingFile"; + UpToDateStatusType2[UpToDateStatusType2["OutOfDateWithSelf"] = 6] = "OutOfDateWithSelf"; + UpToDateStatusType2[UpToDateStatusType2["OutOfDateWithUpstream"] = 7] = "OutOfDateWithUpstream"; + UpToDateStatusType2[UpToDateStatusType2["OutOfDateBuildInfo"] = 8] = "OutOfDateBuildInfo"; + UpToDateStatusType2[UpToDateStatusType2["OutOfDateOptions"] = 9] = "OutOfDateOptions"; + UpToDateStatusType2[UpToDateStatusType2["OutOfDateRoots"] = 10] = "OutOfDateRoots"; + UpToDateStatusType2[UpToDateStatusType2["UpstreamOutOfDate"] = 11] = "UpstreamOutOfDate"; + UpToDateStatusType2[UpToDateStatusType2["UpstreamBlocked"] = 12] = "UpstreamBlocked"; + UpToDateStatusType2[UpToDateStatusType2["ComputingUpstream"] = 13] = "ComputingUpstream"; + UpToDateStatusType2[UpToDateStatusType2["TsVersionOutputOfDate"] = 14] = "TsVersionOutputOfDate"; + UpToDateStatusType2[UpToDateStatusType2["UpToDateWithInputFileText"] = 15] = "UpToDateWithInputFileText"; + UpToDateStatusType2[UpToDateStatusType2["ContainerOnly"] = 16] = "ContainerOnly"; + UpToDateStatusType2[UpToDateStatusType2["ForceBuild"] = 17] = "ForceBuild"; + return UpToDateStatusType2; + })(UpToDateStatusType || {}); } - function closeTypeRootsWatch() { - clearMap(typeRootsWatches, closeFileWatcher); + }); + + // src/compiler/tsbuildPublic.ts + function getOrCreateValueFromConfigFileMap(configFileMap, resolved, createT) { + const existingValue = configFileMap.get(resolved); + let newValue; + if (!existingValue) { + newValue = createT(); + configFileMap.set(resolved, newValue); } - function createTypeRootsWatch(typeRootPath, typeRoot) { - return canWatchTypeRootPath(typeRootPath) ? resolutionHost.watchTypeRootsDirectory(typeRoot, (fileOrDirectory) => { - const fileOrDirectoryPath = resolutionHost.toPath(fileOrDirectory); - if (cachedDirectoryStructureHost) { - cachedDirectoryStructureHost.addOrDeleteFileOrDirectory(fileOrDirectory, fileOrDirectoryPath); - } - hasChangedAutomaticTypeDirectiveNames = true; - resolutionHost.onChangedAutomaticTypeDirectiveNames(); - const dirPath = getDirectoryToWatchFailedLookupLocationFromTypeRoot( - typeRoot, - typeRootPath, - rootPath, - rootPathComponents, - getCurrentDirectory, - (dirPath2) => directoryWatchesOfFailedLookups.has(dirPath2) - ); - if (dirPath) { - scheduleInvalidateResolutionOfFailedLookupLocation(fileOrDirectoryPath, dirPath === fileOrDirectoryPath); + return existingValue || newValue; + } + function getOrCreateValueMapFromConfigFileMap(configFileMap, resolved) { + return getOrCreateValueFromConfigFileMap(configFileMap, resolved, () => /* @__PURE__ */ new Map()); + } + function getCurrentTime(host) { + return host.now ? host.now() : /* @__PURE__ */ new Date(); + } + function isCircularBuildOrder(buildOrder) { + return !!buildOrder && !!buildOrder.buildOrder; + } + function getBuildOrderFromAnyBuildOrder(anyBuildOrder) { + return isCircularBuildOrder(anyBuildOrder) ? anyBuildOrder.buildOrder : anyBuildOrder; + } + function createBuilderStatusReporter(system, pretty) { + return (diagnostic) => { + let output = pretty ? `[${formatColorAndReset(getLocaleTimeString(system), "\x1B[90m" /* Grey */)}] ` : `${getLocaleTimeString(system)} - `; + output += `${flattenDiagnosticMessageText(diagnostic.messageText, system.newLine)}${system.newLine + system.newLine}`; + system.write(output); + }; + } + function createSolutionBuilderHostBase(system, createProgram2, reportDiagnostic, reportSolutionBuilderStatus) { + const host = createProgramHost(system, createProgram2); + host.getModifiedTime = system.getModifiedTime ? (path) => system.getModifiedTime(path) : returnUndefined; + host.setModifiedTime = system.setModifiedTime ? (path, date) => system.setModifiedTime(path, date) : noop; + host.deleteFile = system.deleteFile ? (path) => system.deleteFile(path) : noop; + host.reportDiagnostic = reportDiagnostic || createDiagnosticReporter(system); + host.reportSolutionBuilderStatus = reportSolutionBuilderStatus || createBuilderStatusReporter(system); + host.now = maybeBind(system, system.now); + return host; + } + function createSolutionBuilderHost(system = sys, createProgram2, reportDiagnostic, reportSolutionBuilderStatus, reportErrorSummary2) { + const host = createSolutionBuilderHostBase(system, createProgram2, reportDiagnostic, reportSolutionBuilderStatus); + host.reportErrorSummary = reportErrorSummary2; + return host; + } + function createSolutionBuilderWithWatchHost(system = sys, createProgram2, reportDiagnostic, reportSolutionBuilderStatus, reportWatchStatus2) { + const host = createSolutionBuilderHostBase(system, createProgram2, reportDiagnostic, reportSolutionBuilderStatus); + const watchHost = createWatchHost(system, reportWatchStatus2); + copyProperties(host, watchHost); + return host; + } + function getCompilerOptionsOfBuildOptions(buildOptions) { + const result = {}; + commonOptionsWithBuild.forEach((option) => { + if (hasProperty(buildOptions, option.name)) + result[option.name] = buildOptions[option.name]; + }); + return result; + } + function createSolutionBuilder(host, rootNames, defaultOptions) { + return createSolutionBuilderWorker( + /*watch*/ + false, + host, + rootNames, + defaultOptions + ); + } + function createSolutionBuilderWithWatch(host, rootNames, defaultOptions, baseWatchOptions) { + return createSolutionBuilderWorker( + /*watch*/ + true, + host, + rootNames, + defaultOptions, + baseWatchOptions + ); + } + function createSolutionBuilderState(watch, hostOrHostWithWatch, rootNames, options, baseWatchOptions) { + const host = hostOrHostWithWatch; + const hostWithWatch = hostOrHostWithWatch; + const baseCompilerOptions = getCompilerOptionsOfBuildOptions(options); + const compilerHost = createCompilerHostFromProgramHost(host, () => state.projectCompilerOptions); + setGetSourceFileAsHashVersioned(compilerHost); + compilerHost.getParsedCommandLine = (fileName) => parseConfigFile(state, fileName, toResolvedConfigFilePath(state, fileName)); + compilerHost.resolveModuleNameLiterals = maybeBind(host, host.resolveModuleNameLiterals); + compilerHost.resolveTypeReferenceDirectiveReferences = maybeBind(host, host.resolveTypeReferenceDirectiveReferences); + compilerHost.resolveLibrary = maybeBind(host, host.resolveLibrary); + compilerHost.resolveModuleNames = maybeBind(host, host.resolveModuleNames); + compilerHost.resolveTypeReferenceDirectives = maybeBind(host, host.resolveTypeReferenceDirectives); + compilerHost.getModuleResolutionCache = maybeBind(host, host.getModuleResolutionCache); + let moduleResolutionCache, typeReferenceDirectiveResolutionCache; + if (!compilerHost.resolveModuleNameLiterals && !compilerHost.resolveModuleNames) { + moduleResolutionCache = createModuleResolutionCache(compilerHost.getCurrentDirectory(), compilerHost.getCanonicalFileName); + compilerHost.resolveModuleNameLiterals = (moduleNames, containingFile, redirectedReference, options2, containingSourceFile) => loadWithModeAwareCache( + moduleNames, + containingFile, + redirectedReference, + options2, + containingSourceFile, + host, + moduleResolutionCache, + createModuleResolutionLoader + ); + compilerHost.getModuleResolutionCache = () => moduleResolutionCache; + } + if (!compilerHost.resolveTypeReferenceDirectiveReferences && !compilerHost.resolveTypeReferenceDirectives) { + typeReferenceDirectiveResolutionCache = createTypeReferenceDirectiveResolutionCache( + compilerHost.getCurrentDirectory(), + compilerHost.getCanonicalFileName, + /*options*/ + void 0, + moduleResolutionCache == null ? void 0 : moduleResolutionCache.getPackageJsonInfoCache(), + moduleResolutionCache == null ? void 0 : moduleResolutionCache.optionsToRedirectsKey + ); + compilerHost.resolveTypeReferenceDirectiveReferences = (typeDirectiveNames, containingFile, redirectedReference, options2, containingSourceFile) => loadWithModeAwareCache( + typeDirectiveNames, + containingFile, + redirectedReference, + options2, + containingSourceFile, + host, + typeReferenceDirectiveResolutionCache, + createTypeReferenceResolutionLoader + ); + } + let libraryResolutionCache; + if (!compilerHost.resolveLibrary) { + libraryResolutionCache = createModuleResolutionCache( + compilerHost.getCurrentDirectory(), + compilerHost.getCanonicalFileName, + /*options*/ + void 0, + moduleResolutionCache == null ? void 0 : moduleResolutionCache.getPackageJsonInfoCache() + ); + compilerHost.resolveLibrary = (libraryName, resolveFrom, options2) => resolveLibrary( + libraryName, + resolveFrom, + options2, + host, + libraryResolutionCache + ); + } + compilerHost.getBuildInfo = (fileName, configFilePath) => getBuildInfo3( + state, + fileName, + toResolvedConfigFilePath(state, configFilePath), + /*modifiedTime*/ + void 0 + ); + const { watchFile: watchFile2, watchDirectory, writeLog } = createWatchFactory(hostWithWatch, options); + const state = { + host, + hostWithWatch, + parseConfigFileHost: parseConfigHostFromCompilerHostLike(host), + write: maybeBind(host, host.trace), + // State of solution + options, + baseCompilerOptions, + rootNames, + baseWatchOptions, + resolvedConfigFilePaths: /* @__PURE__ */ new Map(), + configFileCache: /* @__PURE__ */ new Map(), + projectStatus: /* @__PURE__ */ new Map(), + extendedConfigCache: /* @__PURE__ */ new Map(), + buildInfoCache: /* @__PURE__ */ new Map(), + outputTimeStamps: /* @__PURE__ */ new Map(), + builderPrograms: /* @__PURE__ */ new Map(), + diagnostics: /* @__PURE__ */ new Map(), + projectPendingBuild: /* @__PURE__ */ new Map(), + projectErrorsReported: /* @__PURE__ */ new Map(), + compilerHost, + moduleResolutionCache, + typeReferenceDirectiveResolutionCache, + libraryResolutionCache, + // Mutable state + buildOrder: void 0, + readFileWithCache: (f) => host.readFile(f), + projectCompilerOptions: baseCompilerOptions, + cache: void 0, + allProjectBuildPending: true, + needsSummary: true, + watchAllProjectsPending: watch, + // Watch state + watch, + allWatchedWildcardDirectories: /* @__PURE__ */ new Map(), + allWatchedInputFiles: /* @__PURE__ */ new Map(), + allWatchedConfigFiles: /* @__PURE__ */ new Map(), + allWatchedExtendedConfigFiles: /* @__PURE__ */ new Map(), + allWatchedPackageJsonFiles: /* @__PURE__ */ new Map(), + filesWatched: /* @__PURE__ */ new Map(), + lastCachedPackageJsonLookups: /* @__PURE__ */ new Map(), + timerToBuildInvalidatedProject: void 0, + reportFileChangeDetected: false, + watchFile: watchFile2, + watchDirectory, + writeLog + }; + return state; + } + function toPath2(state, fileName) { + return toPath(fileName, state.compilerHost.getCurrentDirectory(), state.compilerHost.getCanonicalFileName); + } + function toResolvedConfigFilePath(state, fileName) { + const { resolvedConfigFilePaths } = state; + const path = resolvedConfigFilePaths.get(fileName); + if (path !== void 0) + return path; + const resolvedPath = toPath2(state, fileName); + resolvedConfigFilePaths.set(fileName, resolvedPath); + return resolvedPath; + } + function isParsedCommandLine(entry) { + return !!entry.options; + } + function getCachedParsedConfigFile(state, configFilePath) { + const value = state.configFileCache.get(configFilePath); + return value && isParsedCommandLine(value) ? value : void 0; + } + function parseConfigFile(state, configFileName, configFilePath) { + const { configFileCache } = state; + const value = configFileCache.get(configFilePath); + if (value) { + return isParsedCommandLine(value) ? value : void 0; + } + mark("SolutionBuilder::beforeConfigFileParsing"); + let diagnostic; + const { parseConfigFileHost, baseCompilerOptions, baseWatchOptions, extendedConfigCache, host } = state; + let parsed; + if (host.getParsedCommandLine) { + parsed = host.getParsedCommandLine(configFileName); + if (!parsed) + diagnostic = createCompilerDiagnostic(Diagnostics.File_0_not_found, configFileName); + } else { + parseConfigFileHost.onUnRecoverableConfigFileDiagnostic = (d) => diagnostic = d; + parsed = getParsedCommandLineOfConfigFile(configFileName, baseCompilerOptions, parseConfigFileHost, extendedConfigCache, baseWatchOptions); + parseConfigFileHost.onUnRecoverableConfigFileDiagnostic = noop; + } + configFileCache.set(configFilePath, parsed || diagnostic); + mark("SolutionBuilder::afterConfigFileParsing"); + measure("SolutionBuilder::Config file parsing", "SolutionBuilder::beforeConfigFileParsing", "SolutionBuilder::afterConfigFileParsing"); + return parsed; + } + function resolveProjectName(state, name) { + return resolveConfigFileProjectName(resolvePath(state.compilerHost.getCurrentDirectory(), name)); + } + function createBuildOrder(state, roots) { + const temporaryMarks = /* @__PURE__ */ new Map(); + const permanentMarks = /* @__PURE__ */ new Map(); + const circularityReportStack = []; + let buildOrder; + let circularDiagnostics; + for (const root of roots) { + visit(root); + } + return circularDiagnostics ? { buildOrder: buildOrder || emptyArray, circularDiagnostics } : buildOrder || emptyArray; + function visit(configFileName, inCircularContext) { + const projPath = toResolvedConfigFilePath(state, configFileName); + if (permanentMarks.has(projPath)) + return; + if (temporaryMarks.has(projPath)) { + if (!inCircularContext) { + (circularDiagnostics || (circularDiagnostics = [])).push( + createCompilerDiagnostic( + Diagnostics.Project_references_may_not_form_a_circular_graph_Cycle_detected_Colon_0, + circularityReportStack.join("\r\n") + ) + ); } - }, 1 /* Recursive */) : noopFileWatcher; - } - function updateTypeRootsWatch() { - const options = resolutionHost.getCompilationSettings(); - if (options.types) { - closeTypeRootsWatch(); return; } - const typeRoots = getEffectiveTypeRoots(options, { getCurrentDirectory }); - if (typeRoots) { - mutateMap( - typeRootsWatches, - arrayToMap(typeRoots, (tr) => resolutionHost.toPath(tr)), - { - createNewValue: createTypeRootsWatch, - onDeleteValue: closeFileWatcher - } - ); - } else { - closeTypeRootsWatch(); + temporaryMarks.set(projPath, true); + circularityReportStack.push(configFileName); + const parsed = parseConfigFile(state, configFileName, projPath); + if (parsed && parsed.projectReferences) { + for (const ref of parsed.projectReferences) { + const resolvedRefPath = resolveProjectName(state, ref.path); + visit(resolvedRefPath, inCircularContext || ref.circular); + } } - } - function canWatchTypeRootPath(typeRoot) { - if (resolutionHost.getCompilationSettings().typeRoots) - return true; - return canWatchAtTypes(resolutionHost.toPath(typeRoot)); + circularityReportStack.pop(); + permanentMarks.set(projPath, true); + (buildOrder || (buildOrder = [])).push(configFileName); } } - function resolutionIsSymlink(resolution) { - var _a, _b; - return !!(((_a = resolution.resolvedModule) == null ? void 0 : _a.originalPath) || ((_b = resolution.resolvedTypeReferenceDirective) == null ? void 0 : _b.originalPath)); + function getBuildOrder(state) { + return state.buildOrder || createStateBuildOrder(state); } - var init_resolutionCache = __esm({ - "src/compiler/resolutionCache.ts"() { - "use strict"; - init_ts2(); - } - }); - - // src/compiler/watch.ts - function createDiagnosticReporter(system, pretty) { - const host = system === sys && sysFormatDiagnosticsHost ? sysFormatDiagnosticsHost : { - getCurrentDirectory: () => system.getCurrentDirectory(), - getNewLine: () => system.newLine, - getCanonicalFileName: createGetCanonicalFileName(system.useCaseSensitiveFileNames) - }; - if (!pretty) { - return (diagnostic) => system.write(formatDiagnostic(diagnostic, host)); + function createStateBuildOrder(state) { + const buildOrder = createBuildOrder(state, state.rootNames.map((f) => resolveProjectName(state, f))); + state.resolvedConfigFilePaths.clear(); + const currentProjects = new Map( + getBuildOrderFromAnyBuildOrder(buildOrder).map( + (resolved) => [toResolvedConfigFilePath(state, resolved), true] + ) + ); + const noopOnDelete = { onDeleteValue: noop }; + mutateMapSkippingNewValues(state.configFileCache, currentProjects, noopOnDelete); + mutateMapSkippingNewValues(state.projectStatus, currentProjects, noopOnDelete); + mutateMapSkippingNewValues(state.builderPrograms, currentProjects, noopOnDelete); + mutateMapSkippingNewValues(state.diagnostics, currentProjects, noopOnDelete); + mutateMapSkippingNewValues(state.projectPendingBuild, currentProjects, noopOnDelete); + mutateMapSkippingNewValues(state.projectErrorsReported, currentProjects, noopOnDelete); + mutateMapSkippingNewValues(state.buildInfoCache, currentProjects, noopOnDelete); + mutateMapSkippingNewValues(state.outputTimeStamps, currentProjects, noopOnDelete); + if (state.watch) { + mutateMapSkippingNewValues( + state.allWatchedConfigFiles, + currentProjects, + { onDeleteValue: closeFileWatcher } + ); + state.allWatchedExtendedConfigFiles.forEach((watcher) => { + watcher.projects.forEach((project) => { + if (!currentProjects.has(project)) { + watcher.projects.delete(project); + } + }); + watcher.close(); + }); + mutateMapSkippingNewValues( + state.allWatchedWildcardDirectories, + currentProjects, + { onDeleteValue: (existingMap) => existingMap.forEach(closeFileWatcherOf) } + ); + mutateMapSkippingNewValues( + state.allWatchedInputFiles, + currentProjects, + { onDeleteValue: (existingMap) => existingMap.forEach(closeFileWatcher) } + ); + mutateMapSkippingNewValues( + state.allWatchedPackageJsonFiles, + currentProjects, + { onDeleteValue: (existingMap) => existingMap.forEach(closeFileWatcher) } + ); } - const diagnostics = new Array(1); - return (diagnostic) => { - diagnostics[0] = diagnostic; - system.write(formatDiagnosticsWithColorAndContext(diagnostics, host) + host.getNewLine()); - diagnostics[0] = void 0; - }; + return state.buildOrder = buildOrder; } - function clearScreenIfNotWatchingForFileChanges(system, diagnostic, options) { - if (system.clearScreen && !options.preserveWatchOutput && !options.extendedDiagnostics && !options.diagnostics && contains(screenStartingMessageCodes, diagnostic.code)) { - system.clearScreen(); - return true; + function getBuildOrderFor(state, project, onlyReferences) { + const resolvedProject = project && resolveProjectName(state, project); + const buildOrderFromState = getBuildOrder(state); + if (isCircularBuildOrder(buildOrderFromState)) + return buildOrderFromState; + if (resolvedProject) { + const projectPath = toResolvedConfigFilePath(state, resolvedProject); + const projectIndex = findIndex( + buildOrderFromState, + (configFileName) => toResolvedConfigFilePath(state, configFileName) === projectPath + ); + if (projectIndex === -1) + return void 0; } - return false; - } - function getPlainDiagnosticFollowingNewLines(diagnostic, newLine) { - return contains(screenStartingMessageCodes, diagnostic.code) ? newLine + newLine : newLine; + const buildOrder = resolvedProject ? createBuildOrder(state, [resolvedProject]) : buildOrderFromState; + Debug.assert(!isCircularBuildOrder(buildOrder)); + Debug.assert(!onlyReferences || resolvedProject !== void 0); + Debug.assert(!onlyReferences || buildOrder[buildOrder.length - 1] === resolvedProject); + return onlyReferences ? buildOrder.slice(0, buildOrder.length - 1) : buildOrder; } - function getLocaleTimeString(system) { - return !system.now ? (/* @__PURE__ */ new Date()).toLocaleTimeString() : ( - // On some systems / builds of Node, there's a non-breaking space between the time and AM/PM. - // This branch is solely for testing, so just switch it to a normal space for baseline stability. - // See: - // - https://github.com/nodejs/node/issues/45171 - // - https://github.com/nodejs/node/issues/45753 - system.now().toLocaleTimeString("en-US", { timeZone: "UTC" }).replace("\u202F", " ") + function enableCache(state) { + if (state.cache) { + disableCache(state); + } + const { compilerHost, host } = state; + const originalReadFileWithCache = state.readFileWithCache; + const originalGetSourceFile = compilerHost.getSourceFile; + const { + originalReadFile, + originalFileExists, + originalDirectoryExists, + originalCreateDirectory, + originalWriteFile, + getSourceFileWithCache, + readFileWithCache + } = changeCompilerHostLikeToUseCache( + host, + (fileName) => toPath2(state, fileName), + (...args) => originalGetSourceFile.call(compilerHost, ...args) ); - } - function createWatchStatusReporter(system, pretty) { - return pretty ? (diagnostic, newLine, options) => { - clearScreenIfNotWatchingForFileChanges(system, diagnostic, options); - let output = `[${formatColorAndReset(getLocaleTimeString(system), "\x1B[90m" /* Grey */)}] `; - output += `${flattenDiagnosticMessageText(diagnostic.messageText, system.newLine)}${newLine + newLine}`; - system.write(output); - } : (diagnostic, newLine, options) => { - let output = ""; - if (!clearScreenIfNotWatchingForFileChanges(system, diagnostic, options)) { - output += newLine; - } - output += `${getLocaleTimeString(system)} - `; - output += `${flattenDiagnosticMessageText(diagnostic.messageText, system.newLine)}${getPlainDiagnosticFollowingNewLines(diagnostic, newLine)}`; - system.write(output); + state.readFileWithCache = readFileWithCache; + compilerHost.getSourceFile = getSourceFileWithCache; + state.cache = { + originalReadFile, + originalFileExists, + originalDirectoryExists, + originalCreateDirectory, + originalWriteFile, + originalReadFileWithCache, + originalGetSourceFile }; } - function parseConfigFileWithSystem(configFileName, optionsToExtend, extendedConfigCache, watchOptionsToExtend, system, reportDiagnostic) { - const host = system; - host.onUnRecoverableConfigFileDiagnostic = (diagnostic) => reportUnrecoverableDiagnostic(system, reportDiagnostic, diagnostic); - const result = getParsedCommandLineOfConfigFile(configFileName, optionsToExtend, host, extendedConfigCache, watchOptionsToExtend); - host.onUnRecoverableConfigFileDiagnostic = void 0; - return result; - } - function getErrorCountForSummary(diagnostics) { - return countWhere(diagnostics, (diagnostic) => diagnostic.category === 1 /* Error */); - } - function getFilesInErrorForSummary(diagnostics) { - const filesInError = filter(diagnostics, (diagnostic) => diagnostic.category === 1 /* Error */).map( - (errorDiagnostic) => { - if (errorDiagnostic.file === void 0) - return; - return `${errorDiagnostic.file.fileName}`; - } - ); - return filesInError.map((fileName) => { - if (fileName === void 0) { - return void 0; - } - const diagnosticForFileName = find( - diagnostics, - (diagnostic) => diagnostic.file !== void 0 && diagnostic.file.fileName === fileName - ); - if (diagnosticForFileName !== void 0) { - const { line } = getLineAndCharacterOfPosition(diagnosticForFileName.file, diagnosticForFileName.start); - return { - fileName, - line: line + 1 - }; - } - }); + function disableCache(state) { + if (!state.cache) + return; + const { cache, host, compilerHost, extendedConfigCache, moduleResolutionCache, typeReferenceDirectiveResolutionCache, libraryResolutionCache } = state; + host.readFile = cache.originalReadFile; + host.fileExists = cache.originalFileExists; + host.directoryExists = cache.originalDirectoryExists; + host.createDirectory = cache.originalCreateDirectory; + host.writeFile = cache.originalWriteFile; + compilerHost.getSourceFile = cache.originalGetSourceFile; + state.readFileWithCache = cache.originalReadFileWithCache; + extendedConfigCache.clear(); + moduleResolutionCache == null ? void 0 : moduleResolutionCache.clear(); + typeReferenceDirectiveResolutionCache == null ? void 0 : typeReferenceDirectiveResolutionCache.clear(); + libraryResolutionCache == null ? void 0 : libraryResolutionCache.clear(); + state.cache = void 0; } - function getWatchErrorSummaryDiagnosticMessage(errorCount) { - return errorCount === 1 ? Diagnostics.Found_1_error_Watching_for_file_changes : Diagnostics.Found_0_errors_Watching_for_file_changes; + function clearProjectStatus(state, resolved) { + state.projectStatus.delete(resolved); + state.diagnostics.delete(resolved); } - function prettyPathForFileError(error, cwd) { - const line = formatColorAndReset(":" + error.line, "\x1B[90m" /* Grey */); - if (pathIsAbsolute(error.fileName) && pathIsAbsolute(cwd)) { - return getRelativePathFromDirectory( - cwd, - error.fileName, - /*ignoreCase*/ - false - ) + line; + function addProjToQueue({ projectPendingBuild }, proj, updateLevel) { + const value = projectPendingBuild.get(proj); + if (value === void 0) { + projectPendingBuild.set(proj, updateLevel); + } else if (value < updateLevel) { + projectPendingBuild.set(proj, updateLevel); } - return error.fileName + line; } - function getErrorSummaryText(errorCount, filesInError, newLine, host) { - if (errorCount === 0) - return ""; - const nonNilFiles = filesInError.filter((fileInError) => fileInError !== void 0); - const distinctFileNamesWithLines = nonNilFiles.map((fileInError) => `${fileInError.fileName}:${fileInError.line}`).filter((value, index, self) => self.indexOf(value) === index); - const firstFileReference = nonNilFiles[0] && prettyPathForFileError(nonNilFiles[0], host.getCurrentDirectory()); - let messageAndArgs; - if (errorCount === 1) { - messageAndArgs = filesInError[0] !== void 0 ? [Diagnostics.Found_1_error_in_0, firstFileReference] : [Diagnostics.Found_1_error]; - } else { - messageAndArgs = distinctFileNamesWithLines.length === 0 ? [Diagnostics.Found_0_errors, errorCount] : distinctFileNamesWithLines.length === 1 ? [Diagnostics.Found_0_errors_in_the_same_file_starting_at_Colon_1, errorCount, firstFileReference] : [Diagnostics.Found_0_errors_in_1_files, errorCount, distinctFileNamesWithLines.length]; + function setupInitialBuild(state, cancellationToken) { + if (!state.allProjectBuildPending) + return; + state.allProjectBuildPending = false; + if (state.options.watch) + reportWatchStatus(state, Diagnostics.Starting_compilation_in_watch_mode); + enableCache(state); + const buildOrder = getBuildOrderFromAnyBuildOrder(getBuildOrder(state)); + buildOrder.forEach( + (configFileName) => state.projectPendingBuild.set( + toResolvedConfigFilePath(state, configFileName), + 0 /* Update */ + ) + ); + if (cancellationToken) { + cancellationToken.throwIfCancellationRequested(); } - const d = createCompilerDiagnostic(...messageAndArgs); - const suffix = distinctFileNamesWithLines.length > 1 ? createTabularErrorsDisplay(nonNilFiles, host) : ""; - return `${newLine}${flattenDiagnosticMessageText(d.messageText, newLine)}${newLine}${newLine}${suffix}`; - } - function createTabularErrorsDisplay(filesInError, host) { - const distinctFiles = filesInError.filter((value, index, self) => index === self.findIndex((file) => (file == null ? void 0 : file.fileName) === (value == null ? void 0 : value.fileName))); - if (distinctFiles.length === 0) - return ""; - const numberLength = (num) => Math.log(num) * Math.LOG10E + 1; - const fileToErrorCount = distinctFiles.map((file) => [file, countWhere(filesInError, (fileInError) => fileInError.fileName === file.fileName)]); - const maxErrors = fileToErrorCount.reduce((acc, value) => Math.max(acc, value[1] || 0), 0); - const headerRow = Diagnostics.Errors_Files.message; - const leftColumnHeadingLength = headerRow.split(" ")[0].length; - const leftPaddingGoal = Math.max(leftColumnHeadingLength, numberLength(maxErrors)); - const headerPadding = Math.max(numberLength(maxErrors) - leftColumnHeadingLength, 0); - let tabularData = ""; - tabularData += " ".repeat(headerPadding) + headerRow + "\n"; - fileToErrorCount.forEach((row) => { - const [file, errorCount] = row; - const errorCountDigitsLength = Math.log(errorCount) * Math.LOG10E + 1 | 0; - const leftPadding = errorCountDigitsLength < leftPaddingGoal ? " ".repeat(leftPaddingGoal - errorCountDigitsLength) : ""; - const fileRef = prettyPathForFileError(file, host.getCurrentDirectory()); - tabularData += `${leftPadding}${errorCount} ${fileRef} -`; - }); - return tabularData; } - function isBuilderProgram2(program) { - return !!program.getState; + function doneInvalidatedProject(state, projectPath) { + state.projectPendingBuild.delete(projectPath); + return state.diagnostics.has(projectPath) ? 1 /* DiagnosticsPresent_OutputsSkipped */ : 0 /* Success */; } - function listFiles(program, write) { - const options = program.getCompilerOptions(); - if (options.explainFiles) { - explainFiles(isBuilderProgram2(program) ? program.getProgram() : program, write); - } else if (options.listFiles || options.listFilesOnly) { - forEach(program.getSourceFiles(), (file) => { - write(file.fileName); - }); - } + function createUpdateOutputFileStampsProject(state, project, projectPath, config, buildOrder) { + let updateOutputFileStampsPending = true; + return { + kind: 2 /* UpdateOutputFileStamps */, + project, + projectPath, + buildOrder, + getCompilerOptions: () => config.options, + getCurrentDirectory: () => state.compilerHost.getCurrentDirectory(), + updateOutputFileStatmps: () => { + updateOutputTimestamps(state, config, projectPath); + updateOutputFileStampsPending = false; + }, + done: () => { + if (updateOutputFileStampsPending) { + updateOutputTimestamps(state, config, projectPath); + } + mark("SolutionBuilder::Timestamps only updates"); + return doneInvalidatedProject(state, projectPath); + } + }; } - function explainFiles(program, write) { - var _a, _b; - const reasons = program.getFileIncludeReasons(); - const relativeFileName = (fileName) => convertToRelativePath(fileName, program.getCurrentDirectory(), program.getCanonicalFileName); - for (const file of program.getSourceFiles()) { - write(`${toFileName(file, relativeFileName)}`); - (_a = reasons.get(file.path)) == null ? void 0 : _a.forEach((reason) => write(` ${fileIncludeReasonToDiagnostics(program, reason, relativeFileName).messageText}`)); - (_b = explainIfFileIsRedirectAndImpliedFormat(file, relativeFileName)) == null ? void 0 : _b.forEach((d) => write(` ${d.messageText}`)); + function createBuildOrUpdateInvalidedProject(kind, state, project, projectPath, projectIndex, config, buildOrder) { + let step = kind === 0 /* Build */ ? 0 /* CreateProgram */ : 4 /* EmitBundle */; + let program; + let buildResult; + let invalidatedProjectOfBundle; + return kind === 0 /* Build */ ? { + kind, + project, + projectPath, + buildOrder, + getCompilerOptions: () => config.options, + getCurrentDirectory: () => state.compilerHost.getCurrentDirectory(), + getBuilderProgram: () => withProgramOrUndefined(identity), + getProgram: () => withProgramOrUndefined( + (program2) => program2.getProgramOrUndefined() + ), + getSourceFile: (fileName) => withProgramOrUndefined( + (program2) => program2.getSourceFile(fileName) + ), + getSourceFiles: () => withProgramOrEmptyArray( + (program2) => program2.getSourceFiles() + ), + getOptionsDiagnostics: (cancellationToken) => withProgramOrEmptyArray( + (program2) => program2.getOptionsDiagnostics(cancellationToken) + ), + getGlobalDiagnostics: (cancellationToken) => withProgramOrEmptyArray( + (program2) => program2.getGlobalDiagnostics(cancellationToken) + ), + getConfigFileParsingDiagnostics: () => withProgramOrEmptyArray( + (program2) => program2.getConfigFileParsingDiagnostics() + ), + getSyntacticDiagnostics: (sourceFile, cancellationToken) => withProgramOrEmptyArray( + (program2) => program2.getSyntacticDiagnostics(sourceFile, cancellationToken) + ), + getAllDependencies: (sourceFile) => withProgramOrEmptyArray( + (program2) => program2.getAllDependencies(sourceFile) + ), + getSemanticDiagnostics: (sourceFile, cancellationToken) => withProgramOrEmptyArray( + (program2) => program2.getSemanticDiagnostics(sourceFile, cancellationToken) + ), + getSemanticDiagnosticsOfNextAffectedFile: (cancellationToken, ignoreSourceFile) => withProgramOrUndefined( + (program2) => program2.getSemanticDiagnosticsOfNextAffectedFile && program2.getSemanticDiagnosticsOfNextAffectedFile(cancellationToken, ignoreSourceFile) + ), + emit: (targetSourceFile, writeFile2, cancellationToken, emitOnlyDtsFiles, customTransformers) => { + if (targetSourceFile || emitOnlyDtsFiles) { + return withProgramOrUndefined( + (program2) => { + var _a, _b; + return program2.emit(targetSourceFile, writeFile2, cancellationToken, emitOnlyDtsFiles, customTransformers || ((_b = (_a = state.host).getCustomTransformers) == null ? void 0 : _b.call(_a, project))); + } + ); + } + executeSteps(2 /* SemanticDiagnostics */, cancellationToken); + if (step === 5 /* EmitBuildInfo */) { + return emitBuildInfo(writeFile2, cancellationToken); + } + if (step !== 3 /* Emit */) + return void 0; + return emit(writeFile2, cancellationToken, customTransformers); + }, + done + } : { + kind, + project, + projectPath, + buildOrder, + getCompilerOptions: () => config.options, + getCurrentDirectory: () => state.compilerHost.getCurrentDirectory(), + emit: (writeFile2, customTransformers) => { + if (step !== 4 /* EmitBundle */) + return invalidatedProjectOfBundle; + return emitBundle(writeFile2, customTransformers); + }, + done + }; + function done(cancellationToken, writeFile2, customTransformers) { + executeSteps(8 /* Done */, cancellationToken, writeFile2, customTransformers); + if (kind === 0 /* Build */) + mark("SolutionBuilder::Projects built"); + else + mark("SolutionBuilder::Bundles updated"); + return doneInvalidatedProject(state, projectPath); } - } - function explainIfFileIsRedirectAndImpliedFormat(file, fileNameConvertor) { - var _a; - let result; - if (file.path !== file.resolvedPath) { - (result ?? (result = [])).push(chainDiagnosticMessages( - /*details*/ - void 0, - Diagnostics.File_is_output_of_project_reference_source_0, - toFileName(file.originalFileName, fileNameConvertor) - )); + function withProgramOrUndefined(action) { + executeSteps(0 /* CreateProgram */); + return program && action(program); } - if (file.redirectInfo) { - (result ?? (result = [])).push(chainDiagnosticMessages( - /*details*/ - void 0, - Diagnostics.File_redirects_to_file_0, - toFileName(file.redirectInfo.redirectTarget, fileNameConvertor) - )); + function withProgramOrEmptyArray(action) { + return withProgramOrUndefined(action) || emptyArray; } - if (isExternalOrCommonJsModule(file)) { - switch (file.impliedNodeFormat) { - case 99 /* ESNext */: - if (file.packageJsonScope) { - (result ?? (result = [])).push(chainDiagnosticMessages( - /*details*/ - void 0, - Diagnostics.File_is_ECMAScript_module_because_0_has_field_type_with_value_module, - toFileName(last(file.packageJsonLocations), fileNameConvertor) - )); - } - break; - case 1 /* CommonJS */: - if (file.packageJsonScope) { - (result ?? (result = [])).push(chainDiagnosticMessages( - /*details*/ - void 0, - file.packageJsonScope.contents.packageJsonContent.type ? Diagnostics.File_is_CommonJS_module_because_0_has_field_type_whose_value_is_not_module : Diagnostics.File_is_CommonJS_module_because_0_does_not_have_field_type, - toFileName(last(file.packageJsonLocations), fileNameConvertor) - )); - } else if ((_a = file.packageJsonLocations) == null ? void 0 : _a.length) { - (result ?? (result = [])).push(chainDiagnosticMessages( - /*details*/ - void 0, - Diagnostics.File_is_CommonJS_module_because_package_json_was_not_found - )); - } - break; + function createProgram2() { + var _a, _b; + Debug.assert(program === void 0); + if (state.options.dry) { + reportStatus(state, Diagnostics.A_non_dry_build_would_build_project_0, project); + buildResult = 1 /* Success */; + step = 7 /* QueueReferencingProjects */; + return; } - } - return result; - } - function getMatchedFileSpec(program, fileName) { - var _a; - const configFile = program.getCompilerOptions().configFile; - if (!((_a = configFile == null ? void 0 : configFile.configFileSpecs) == null ? void 0 : _a.validatedFilesSpec)) - return void 0; - const filePath = program.getCanonicalFileName(fileName); - const basePath = getDirectoryPath(getNormalizedAbsolutePath(configFile.fileName, program.getCurrentDirectory())); - return find(configFile.configFileSpecs.validatedFilesSpec, (fileSpec) => program.getCanonicalFileName(getNormalizedAbsolutePath(fileSpec, basePath)) === filePath); - } - function getMatchedIncludeSpec(program, fileName) { - var _a, _b; - const configFile = program.getCompilerOptions().configFile; - if (!((_a = configFile == null ? void 0 : configFile.configFileSpecs) == null ? void 0 : _a.validatedIncludeSpecs)) - return void 0; - if (configFile.configFileSpecs.isDefaultIncludeSpec) - return true; - const isJsonFile = fileExtensionIs(fileName, ".json" /* Json */); - const basePath = getDirectoryPath(getNormalizedAbsolutePath(configFile.fileName, program.getCurrentDirectory())); - const useCaseSensitiveFileNames = program.useCaseSensitiveFileNames(); - return find((_b = configFile == null ? void 0 : configFile.configFileSpecs) == null ? void 0 : _b.validatedIncludeSpecs, (includeSpec) => { - if (isJsonFile && !endsWith(includeSpec, ".json" /* Json */)) - return false; - const pattern = getPatternFromSpec(includeSpec, basePath, "files"); - return !!pattern && getRegexFromPattern(`(${pattern})$`, useCaseSensitiveFileNames).test(fileName); - }); - } - function fileIncludeReasonToDiagnostics(program, reason, fileNameConvertor) { - var _a, _b; - const options = program.getCompilerOptions(); - if (isReferencedFile(reason)) { - const referenceLocation = getReferencedFileLocation((path) => program.getSourceFileByPath(path), reason); - const referenceText = isReferenceFileLocation(referenceLocation) ? referenceLocation.file.text.substring(referenceLocation.pos, referenceLocation.end) : `"${referenceLocation.text}"`; - let message; - Debug.assert(isReferenceFileLocation(referenceLocation) || reason.kind === 3 /* Import */, "Only synthetic references are imports"); - switch (reason.kind) { - case 3 /* Import */: - if (isReferenceFileLocation(referenceLocation)) { - message = referenceLocation.packageId ? Diagnostics.Imported_via_0_from_file_1_with_packageId_2 : Diagnostics.Imported_via_0_from_file_1; - } else if (referenceLocation.text === externalHelpersModuleNameText) { - message = referenceLocation.packageId ? Diagnostics.Imported_via_0_from_file_1_with_packageId_2_to_import_importHelpers_as_specified_in_compilerOptions : Diagnostics.Imported_via_0_from_file_1_to_import_importHelpers_as_specified_in_compilerOptions; - } else { - message = referenceLocation.packageId ? Diagnostics.Imported_via_0_from_file_1_with_packageId_2_to_import_jsx_and_jsxs_factory_functions : Diagnostics.Imported_via_0_from_file_1_to_import_jsx_and_jsxs_factory_functions; - } - break; - case 4 /* ReferenceFile */: - Debug.assert(!referenceLocation.packageId); - message = Diagnostics.Referenced_via_0_from_file_1; - break; - case 5 /* TypeReferenceDirective */: - message = referenceLocation.packageId ? Diagnostics.Type_library_referenced_via_0_from_file_1_with_packageId_2 : Diagnostics.Type_library_referenced_via_0_from_file_1; - break; - case 7 /* LibReferenceDirective */: - Debug.assert(!referenceLocation.packageId); - message = Diagnostics.Library_referenced_via_0_from_file_1; - break; - default: - Debug.assertNever(reason); + if (state.options.verbose) + reportStatus(state, Diagnostics.Building_project_0, project); + if (config.fileNames.length === 0) { + reportAndStoreErrors(state, projectPath, getConfigFileParsingDiagnostics(config)); + buildResult = 0 /* None */; + step = 7 /* QueueReferencingProjects */; + return; } - return chainDiagnosticMessages( - /*details*/ - void 0, - message, - referenceText, - toFileName(referenceLocation.file, fileNameConvertor), - referenceLocation.packageId && packageIdToString(referenceLocation.packageId) + const { host, compilerHost } = state; + state.projectCompilerOptions = config.options; + (_a = state.moduleResolutionCache) == null ? void 0 : _a.update(config.options); + (_b = state.typeReferenceDirectiveResolutionCache) == null ? void 0 : _b.update(config.options); + program = host.createProgram( + config.fileNames, + config.options, + compilerHost, + getOldProgram(state, projectPath, config), + getConfigFileParsingDiagnostics(config), + config.projectReferences ); - } - switch (reason.kind) { - case 0 /* RootFile */: - if (!((_a = options.configFile) == null ? void 0 : _a.configFileSpecs)) - return chainDiagnosticMessages( - /*details*/ - void 0, - Diagnostics.Root_file_specified_for_compilation - ); - const fileName = getNormalizedAbsolutePath(program.getRootFileNames()[reason.index], program.getCurrentDirectory()); - const matchedByFiles = getMatchedFileSpec(program, fileName); - if (matchedByFiles) - return chainDiagnosticMessages( - /*details*/ - void 0, - Diagnostics.Part_of_files_list_in_tsconfig_json - ); - const matchedByInclude = getMatchedIncludeSpec(program, fileName); - return isString(matchedByInclude) ? chainDiagnosticMessages( - /*details*/ - void 0, - Diagnostics.Matched_by_include_pattern_0_in_1, - matchedByInclude, - toFileName(options.configFile, fileNameConvertor) - ) : ( - // Could be additional files specified as roots or matched by default include - chainDiagnosticMessages( - /*details*/ - void 0, - matchedByInclude ? Diagnostics.Matched_by_default_include_pattern_Asterisk_Asterisk_Slash_Asterisk : Diagnostics.Root_file_specified_for_compilation + if (state.watch) { + state.lastCachedPackageJsonLookups.set( + projectPath, + state.moduleResolutionCache && map( + state.moduleResolutionCache.getPackageJsonInfoCache().entries(), + ([path, data]) => [state.host.realpath && data ? toPath2(state, state.host.realpath(path)) : path, data] ) ); - case 1 /* SourceFromProjectReference */: - case 2 /* OutputFromProjectReference */: - const isOutput = reason.kind === 2 /* OutputFromProjectReference */; - const referencedResolvedRef = Debug.checkDefined((_b = program.getResolvedProjectReferences()) == null ? void 0 : _b[reason.index]); - return chainDiagnosticMessages( - /*details*/ - void 0, - outFile(options) ? isOutput ? Diagnostics.Output_from_referenced_project_0_included_because_1_specified : Diagnostics.Source_from_referenced_project_0_included_because_1_specified : isOutput ? Diagnostics.Output_from_referenced_project_0_included_because_module_is_specified_as_none : Diagnostics.Source_from_referenced_project_0_included_because_module_is_specified_as_none, - toFileName(referencedResolvedRef.sourceFile.fileName, fileNameConvertor), - options.outFile ? "--outFile" : "--out" - ); - case 8 /* AutomaticTypeDirectiveFile */: { - const messageAndArgs = options.types ? reason.packageId ? [Diagnostics.Entry_point_of_type_library_0_specified_in_compilerOptions_with_packageId_1, reason.typeReference, packageIdToString(reason.packageId)] : [Diagnostics.Entry_point_of_type_library_0_specified_in_compilerOptions, reason.typeReference] : reason.packageId ? [Diagnostics.Entry_point_for_implicit_type_library_0_with_packageId_1, reason.typeReference, packageIdToString(reason.packageId)] : [Diagnostics.Entry_point_for_implicit_type_library_0, reason.typeReference]; - return chainDiagnosticMessages( - /*details*/ - void 0, - ...messageAndArgs - ); + state.builderPrograms.set(projectPath, program); } - case 6 /* LibFile */: { - if (reason.index !== void 0) - return chainDiagnosticMessages( - /*details*/ - void 0, - Diagnostics.Library_0_specified_in_compilerOptions, - options.lib[reason.index] - ); - const target = forEachEntry(targetOptionDeclaration.type, (value, key) => value === getEmitScriptTarget(options) ? key : void 0); - const messageAndArgs = target ? [Diagnostics.Default_library_for_target_0, target] : [Diagnostics.Default_library]; - return chainDiagnosticMessages( - /*details*/ - void 0, - ...messageAndArgs - ); + step++; + } + function handleDiagnostics(diagnostics, errorFlags, errorType) { + if (diagnostics.length) { + ({ buildResult, step } = buildErrors( + state, + projectPath, + program, + config, + diagnostics, + errorFlags, + errorType + )); + } else { + step++; } - default: - Debug.assertNever(reason); } - } - function toFileName(file, fileNameConvertor) { - const fileName = isString(file) ? file : file.fileName; - return fileNameConvertor ? fileNameConvertor(fileName) : fileName; - } - function emitFilesAndReportErrors(program, reportDiagnostic, write, reportSummary, writeFile2, cancellationToken, emitOnlyDtsFiles, customTransformers) { - const isListFilesOnly = !!program.getCompilerOptions().listFilesOnly; - const allDiagnostics = program.getConfigFileParsingDiagnostics().slice(); - const configFileParsingDiagnosticsLength = allDiagnostics.length; - addRange(allDiagnostics, program.getSyntacticDiagnostics( - /*sourceFile*/ - void 0, - cancellationToken - )); - if (allDiagnostics.length === configFileParsingDiagnosticsLength) { - addRange(allDiagnostics, program.getOptionsDiagnostics(cancellationToken)); - if (!isListFilesOnly) { - addRange(allDiagnostics, program.getGlobalDiagnostics(cancellationToken)); - if (allDiagnostics.length === configFileParsingDiagnosticsLength) { - addRange(allDiagnostics, program.getSemanticDiagnostics( + function getSyntaxDiagnostics(cancellationToken) { + Debug.assertIsDefined(program); + handleDiagnostics( + [ + ...program.getConfigFileParsingDiagnostics(), + ...program.getOptionsDiagnostics(cancellationToken), + ...program.getGlobalDiagnostics(cancellationToken), + ...program.getSyntacticDiagnostics( /*sourceFile*/ void 0, cancellationToken - )); + ) + ], + 8 /* SyntaxErrors */, + "Syntactic" + ); + } + function getSemanticDiagnostics(cancellationToken) { + handleDiagnostics( + Debug.checkDefined(program).getSemanticDiagnostics( + /*sourceFile*/ + void 0, + cancellationToken + ), + 16 /* TypeErrors */, + "Semantic" + ); + } + function emit(writeFileCallback, cancellationToken, customTransformers) { + var _a, _b, _c; + Debug.assertIsDefined(program); + Debug.assert(step === 3 /* Emit */); + const saved = program.saveEmitState(); + let declDiagnostics; + const reportDeclarationDiagnostics = (d) => (declDiagnostics || (declDiagnostics = [])).push(d); + const outputFiles = []; + const { emitResult } = emitFilesAndReportErrors( + program, + reportDeclarationDiagnostics, + /*write*/ + void 0, + /*reportSummary*/ + void 0, + (name, text, writeByteOrderMark, _onError, _sourceFiles, data) => outputFiles.push({ name, text, writeByteOrderMark, data }), + cancellationToken, + /*emitOnlyDtsFiles*/ + false, + customTransformers || ((_b = (_a = state.host).getCustomTransformers) == null ? void 0 : _b.call(_a, project)) + ); + if (declDiagnostics) { + program.restoreEmitState(saved); + ({ buildResult, step } = buildErrors( + state, + projectPath, + program, + config, + declDiagnostics, + 32 /* DeclarationEmitErrors */, + "Declaration file" + )); + return { + emitSkipped: true, + diagnostics: emitResult.diagnostics + }; + } + const { host, compilerHost } = state; + const resultFlags = ((_c = program.hasChangedEmitSignature) == null ? void 0 : _c.call(program)) ? 0 /* None */ : 2 /* DeclarationOutputUnchanged */; + const emitterDiagnostics = createDiagnosticCollection(); + const emittedOutputs = /* @__PURE__ */ new Map(); + const options = program.getCompilerOptions(); + const isIncremental = isIncrementalCompilation(options); + let outputTimeStampMap; + let now; + outputFiles.forEach(({ name, text, writeByteOrderMark, data }) => { + const path = toPath2(state, name); + emittedOutputs.set(toPath2(state, name), name); + if (data == null ? void 0 : data.buildInfo) + setBuildInfo(state, data.buildInfo, projectPath, options, resultFlags); + const modifiedTime = (data == null ? void 0 : data.differsOnlyInMap) ? getModifiedTime(state.host, name) : void 0; + writeFile(writeFileCallback ? { writeFile: writeFileCallback } : compilerHost, emitterDiagnostics, name, text, writeByteOrderMark); + if (data == null ? void 0 : data.differsOnlyInMap) + state.host.setModifiedTime(name, modifiedTime); + else if (!isIncremental && state.watch) { + (outputTimeStampMap || (outputTimeStampMap = getOutputTimeStampMap(state, projectPath))).set(path, now || (now = getCurrentTime(state.host))); } + }); + finishEmit( + emitterDiagnostics, + emittedOutputs, + outputFiles.length ? outputFiles[0].name : getFirstProjectOutput(config, !host.useCaseSensitiveFileNames()), + resultFlags + ); + return emitResult; + } + function emitBuildInfo(writeFileCallback, cancellationToken) { + Debug.assertIsDefined(program); + Debug.assert(step === 5 /* EmitBuildInfo */); + const emitResult = program.emitBuildInfo((name, text, writeByteOrderMark, onError, sourceFiles, data) => { + if (data == null ? void 0 : data.buildInfo) + setBuildInfo(state, data.buildInfo, projectPath, program.getCompilerOptions(), 2 /* DeclarationOutputUnchanged */); + if (writeFileCallback) + writeFileCallback(name, text, writeByteOrderMark, onError, sourceFiles, data); + else + state.compilerHost.writeFile(name, text, writeByteOrderMark, onError, sourceFiles, data); + }, cancellationToken); + if (emitResult.diagnostics.length) { + reportErrors(state, emitResult.diagnostics); + state.diagnostics.set(projectPath, [...state.diagnostics.get(projectPath), ...emitResult.diagnostics]); + buildResult = 64 /* EmitErrors */ & buildResult; + } + if (emitResult.emittedFiles && state.write) { + emitResult.emittedFiles.forEach((name) => listEmittedFile(state, config, name)); } + afterProgramDone(state, program, config); + step = 7 /* QueueReferencingProjects */; + return emitResult; } - const emitResult = isListFilesOnly ? { emitSkipped: true, diagnostics: emptyArray } : program.emit( - /*targetSourceFile*/ - void 0, - writeFile2, - cancellationToken, - emitOnlyDtsFiles, - customTransformers - ); - const { emittedFiles, diagnostics: emitDiagnostics } = emitResult; - addRange(allDiagnostics, emitDiagnostics); - const diagnostics = sortAndDeduplicateDiagnostics(allDiagnostics); - diagnostics.forEach(reportDiagnostic); - if (write) { - const currentDir = program.getCurrentDirectory(); - forEach(emittedFiles, (file) => { - const filepath = getNormalizedAbsolutePath(file, currentDir); - write(`TSFILE: ${filepath}`); + function finishEmit(emitterDiagnostics, emittedOutputs, oldestOutputFileName, resultFlags) { + const emitDiagnostics = emitterDiagnostics.getDiagnostics(); + if (emitDiagnostics.length) { + ({ buildResult, step } = buildErrors( + state, + projectPath, + program, + config, + emitDiagnostics, + 64 /* EmitErrors */, + "Emit" + )); + return emitDiagnostics; + } + if (state.write) { + emittedOutputs.forEach((name) => listEmittedFile(state, config, name)); + } + updateOutputTimestampsWorker(state, config, projectPath, Diagnostics.Updating_unchanged_output_timestamps_of_project_0, emittedOutputs); + state.diagnostics.delete(projectPath); + state.projectStatus.set(projectPath, { + type: 1 /* UpToDate */, + oldestOutputFileName }); - listFiles(program, write); + afterProgramDone(state, program, config); + step = 7 /* QueueReferencingProjects */; + buildResult = resultFlags; + return emitDiagnostics; } - if (reportSummary) { - reportSummary(getErrorCountForSummary(diagnostics), getFilesInErrorForSummary(diagnostics)); + function emitBundle(writeFileCallback, customTransformers) { + var _a, _b, _c, _d; + Debug.assert(kind === 1 /* UpdateBundle */); + if (state.options.dry) { + reportStatus(state, Diagnostics.A_non_dry_build_would_update_output_of_project_0, project); + buildResult = 1 /* Success */; + step = 7 /* QueueReferencingProjects */; + return void 0; + } + if (state.options.verbose) + reportStatus(state, Diagnostics.Updating_output_of_project_0, project); + const { compilerHost } = state; + state.projectCompilerOptions = config.options; + (_b = (_a = state.host).beforeEmitBundle) == null ? void 0 : _b.call(_a, config); + const outputFiles = emitUsingBuildInfo( + config, + compilerHost, + (ref) => { + const refName = resolveProjectName(state, ref.path); + return parseConfigFile(state, refName, toResolvedConfigFilePath(state, refName)); + }, + customTransformers || ((_d = (_c = state.host).getCustomTransformers) == null ? void 0 : _d.call(_c, project)) + ); + if (isString(outputFiles)) { + reportStatus(state, Diagnostics.Cannot_update_output_of_project_0_because_there_was_error_reading_file_1, project, relName(state, outputFiles)); + step = 6 /* BuildInvalidatedProjectOfBundle */; + return invalidatedProjectOfBundle = createBuildOrUpdateInvalidedProject( + 0 /* Build */, + state, + project, + projectPath, + projectIndex, + config, + buildOrder + ); + } + Debug.assert(!!outputFiles.length); + const emitterDiagnostics = createDiagnosticCollection(); + const emittedOutputs = /* @__PURE__ */ new Map(); + let resultFlags = 2 /* DeclarationOutputUnchanged */; + const existingBuildInfo = state.buildInfoCache.get(projectPath).buildInfo || void 0; + outputFiles.forEach(({ name, text, writeByteOrderMark, data }) => { + var _a2, _b2; + emittedOutputs.set(toPath2(state, name), name); + if (data == null ? void 0 : data.buildInfo) { + if (((_a2 = data.buildInfo.program) == null ? void 0 : _a2.outSignature) !== ((_b2 = existingBuildInfo == null ? void 0 : existingBuildInfo.program) == null ? void 0 : _b2.outSignature)) { + resultFlags &= ~2 /* DeclarationOutputUnchanged */; + } + setBuildInfo(state, data.buildInfo, projectPath, config.options, resultFlags); + } + writeFile(writeFileCallback ? { writeFile: writeFileCallback } : compilerHost, emitterDiagnostics, name, text, writeByteOrderMark); + }); + const emitDiagnostics = finishEmit( + emitterDiagnostics, + emittedOutputs, + outputFiles[0].name, + resultFlags + ); + return { emitSkipped: false, diagnostics: emitDiagnostics }; } - return { - emitResult, - diagnostics - }; - } - function emitFilesAndReportErrorsAndGetExitStatus(program, reportDiagnostic, write, reportSummary, writeFile2, cancellationToken, emitOnlyDtsFiles, customTransformers) { - const { emitResult, diagnostics } = emitFilesAndReportErrors( - program, - reportDiagnostic, - write, - reportSummary, - writeFile2, - cancellationToken, - emitOnlyDtsFiles, - customTransformers - ); - if (emitResult.emitSkipped && diagnostics.length > 0) { - return 1 /* DiagnosticsPresent_OutputsSkipped */; - } else if (diagnostics.length > 0) { - return 2 /* DiagnosticsPresent_OutputsGenerated */; + function executeSteps(till, cancellationToken, writeFile2, customTransformers) { + while (step <= till && step < 8 /* Done */) { + const currentStep = step; + switch (step) { + case 0 /* CreateProgram */: + createProgram2(); + break; + case 1 /* SyntaxDiagnostics */: + getSyntaxDiagnostics(cancellationToken); + break; + case 2 /* SemanticDiagnostics */: + getSemanticDiagnostics(cancellationToken); + break; + case 3 /* Emit */: + emit(writeFile2, cancellationToken, customTransformers); + break; + case 5 /* EmitBuildInfo */: + emitBuildInfo(writeFile2, cancellationToken); + break; + case 4 /* EmitBundle */: + emitBundle(writeFile2, customTransformers); + break; + case 6 /* BuildInvalidatedProjectOfBundle */: + Debug.checkDefined(invalidatedProjectOfBundle).done(cancellationToken, writeFile2, customTransformers); + step = 8 /* Done */; + break; + case 7 /* QueueReferencingProjects */: + queueReferencingProjects(state, project, projectPath, projectIndex, config, buildOrder, Debug.checkDefined(buildResult)); + step++; + break; + case 8 /* Done */: + default: + assertType(step); + } + Debug.assert(step > currentStep); + } } - return 0 /* Success */; - } - function createWatchHost(system = sys, reportWatchStatus2) { - const onWatchStatusChange = reportWatchStatus2 || createWatchStatusReporter(system); - return { - onWatchStatusChange, - watchFile: maybeBind(system, system.watchFile) || returnNoopFileWatcher, - watchDirectory: maybeBind(system, system.watchDirectory) || returnNoopFileWatcher, - setTimeout: maybeBind(system, system.setTimeout) || noop, - clearTimeout: maybeBind(system, system.clearTimeout) || noop - }; - } - function createWatchFactory(host, options) { - const watchLogLevel = host.trace ? options.extendedDiagnostics ? 2 /* Verbose */ : options.diagnostics ? 1 /* TriggerOnly */ : 0 /* None */ : 0 /* None */; - const writeLog = watchLogLevel !== 0 /* None */ ? (s) => host.trace(s) : noop; - const result = getWatchFactory(host, watchLogLevel, writeLog); - result.writeLog = writeLog; - return result; } - function createCompilerHostFromProgramHost(host, getCompilerOptions, directoryStructureHost = host) { - const useCaseSensitiveFileNames = host.useCaseSensitiveFileNames(); - const compilerHost = { - getSourceFile: createGetSourceFile( - (fileName, encoding) => !encoding ? compilerHost.readFile(fileName) : host.readFile(fileName, encoding), - getCompilerOptions, - /*setParentNodes*/ - void 0 - ), - getDefaultLibLocation: maybeBind(host, host.getDefaultLibLocation), - getDefaultLibFileName: (options) => host.getDefaultLibFileName(options), - writeFile: createWriteFileMeasuringIO( - (path, data, writeByteOrderMark) => host.writeFile(path, data, writeByteOrderMark), - (path) => host.createDirectory(path), - (path) => host.directoryExists(path) - ), - getCurrentDirectory: memoize(() => host.getCurrentDirectory()), - useCaseSensitiveFileNames: () => useCaseSensitiveFileNames, - getCanonicalFileName: createGetCanonicalFileName(useCaseSensitiveFileNames), - getNewLine: () => getNewLineCharacter(getCompilerOptions()), - fileExists: (f) => host.fileExists(f), - readFile: (f) => host.readFile(f), - trace: maybeBind(host, host.trace), - directoryExists: maybeBind(directoryStructureHost, directoryStructureHost.directoryExists), - getDirectories: maybeBind(directoryStructureHost, directoryStructureHost.getDirectories), - realpath: maybeBind(host, host.realpath), - getEnvironmentVariable: maybeBind(host, host.getEnvironmentVariable) || (() => ""), - createHash: maybeBind(host, host.createHash), - readDirectory: maybeBind(host, host.readDirectory), - storeFilesChangingSignatureDuringEmit: host.storeFilesChangingSignatureDuringEmit - }; - return compilerHost; + function needsBuild({ options }, status, config) { + if (status.type !== 3 /* OutOfDateWithPrepend */ || options.force) + return true; + return config.fileNames.length === 0 || !!getConfigFileParsingDiagnostics(config).length || !isIncrementalCompilation(config.options); } - function getSourceFileVersionAsHashFromText(host, text) { - if (text.match(sourceMapCommentRegExpDontCareLineStart)) { - let lineEnd = text.length; - let lineStart = lineEnd; - for (let pos = lineEnd - 1; pos >= 0; pos--) { - const ch = text.charCodeAt(pos); - switch (ch) { - case 10 /* lineFeed */: - if (pos && text.charCodeAt(pos - 1) === 13 /* carriageReturn */) { - pos--; - } - case 13 /* carriageReturn */: - break; - default: - if (ch < 127 /* maxAsciiCharacter */ || !isLineBreak(ch)) { - lineStart = pos; - continue; - } - break; + function getNextInvalidatedProjectCreateInfo(state, buildOrder, reportQueue) { + if (!state.projectPendingBuild.size) + return void 0; + if (isCircularBuildOrder(buildOrder)) + return void 0; + const { options, projectPendingBuild } = state; + for (let projectIndex = 0; projectIndex < buildOrder.length; projectIndex++) { + const project = buildOrder[projectIndex]; + const projectPath = toResolvedConfigFilePath(state, project); + const updateLevel = state.projectPendingBuild.get(projectPath); + if (updateLevel === void 0) + continue; + if (reportQueue) { + reportQueue = false; + reportBuildQueue(state, buildOrder); + } + const config = parseConfigFile(state, project, projectPath); + if (!config) { + reportParseConfigFileDiagnostic(state, projectPath); + projectPendingBuild.delete(projectPath); + continue; + } + if (updateLevel === 2 /* Full */) { + watchConfigFile(state, project, projectPath, config); + watchExtendedConfigFiles(state, projectPath, config); + watchWildCardDirectories(state, project, projectPath, config); + watchInputFiles(state, project, projectPath, config); + watchPackageJsonFiles(state, project, projectPath, config); + } else if (updateLevel === 1 /* RootNamesAndUpdate */) { + config.fileNames = getFileNamesFromConfigSpecs(config.options.configFile.configFileSpecs, getDirectoryPath(project), config.options, state.parseConfigFileHost); + updateErrorForNoInputFiles(config.fileNames, project, config.options.configFile.configFileSpecs, config.errors, canJsonReportNoInputFiles(config.raw)); + watchInputFiles(state, project, projectPath, config); + watchPackageJsonFiles(state, project, projectPath, config); + } + const status = getUpToDateStatus(state, config, projectPath); + if (!options.force) { + if (status.type === 1 /* UpToDate */) { + verboseReportProjectStatus(state, project, status); + reportAndStoreErrors(state, projectPath, getConfigFileParsingDiagnostics(config)); + projectPendingBuild.delete(projectPath); + if (options.dry) { + reportStatus(state, Diagnostics.Project_0_is_up_to_date, project); + } + continue; } - const line = text.substring(lineStart, lineEnd); - if (line.match(sourceMapCommentRegExp)) { - text = text.substring(0, lineStart); - break; - } else if (!line.match(whitespaceOrMapCommentRegExp)) { - break; + if (status.type === 2 /* UpToDateWithUpstreamTypes */ || status.type === 15 /* UpToDateWithInputFileText */) { + reportAndStoreErrors(state, projectPath, getConfigFileParsingDiagnostics(config)); + return { + kind: 2 /* UpdateOutputFileStamps */, + status, + project, + projectPath, + projectIndex, + config + }; } - lineEnd = lineStart; } + if (status.type === 12 /* UpstreamBlocked */) { + verboseReportProjectStatus(state, project, status); + reportAndStoreErrors(state, projectPath, getConfigFileParsingDiagnostics(config)); + projectPendingBuild.delete(projectPath); + if (options.verbose) { + reportStatus( + state, + status.upstreamProjectBlocked ? Diagnostics.Skipping_build_of_project_0_because_its_dependency_1_was_not_built : Diagnostics.Skipping_build_of_project_0_because_its_dependency_1_has_errors, + project, + status.upstreamProjectName + ); + } + continue; + } + if (status.type === 16 /* ContainerOnly */) { + verboseReportProjectStatus(state, project, status); + reportAndStoreErrors(state, projectPath, getConfigFileParsingDiagnostics(config)); + projectPendingBuild.delete(projectPath); + continue; + } + return { + kind: needsBuild(state, status, config) ? 0 /* Build */ : 1 /* UpdateBundle */, + status, + project, + projectPath, + projectIndex, + config + }; } - return (host.createHash || generateDjb2Hash)(text); + return void 0; } - function setGetSourceFileAsHashVersioned(compilerHost) { - const originalGetSourceFile = compilerHost.getSourceFile; - compilerHost.getSourceFile = (...args) => { - const result = originalGetSourceFile.call(compilerHost, ...args); - if (result) { - result.version = getSourceFileVersionAsHashFromText(compilerHost, result.text); - } - return result; - }; + function createInvalidatedProjectWithInfo(state, info, buildOrder) { + verboseReportProjectStatus(state, info.project, info.status); + return info.kind !== 2 /* UpdateOutputFileStamps */ ? createBuildOrUpdateInvalidedProject( + info.kind, + state, + info.project, + info.projectPath, + info.projectIndex, + info.config, + buildOrder + ) : createUpdateOutputFileStampsProject( + state, + info.project, + info.projectPath, + info.config, + buildOrder + ); } - function createProgramHost(system, createProgram2) { - const getDefaultLibLocation = memoize(() => getDirectoryPath(normalizePath(system.getExecutingFilePath()))); - return { - useCaseSensitiveFileNames: () => system.useCaseSensitiveFileNames, - getNewLine: () => system.newLine, - getCurrentDirectory: memoize(() => system.getCurrentDirectory()), - getDefaultLibLocation, - getDefaultLibFileName: (options) => combinePaths(getDefaultLibLocation(), getDefaultLibFileName(options)), - fileExists: (path) => system.fileExists(path), - readFile: (path, encoding) => system.readFile(path, encoding), - directoryExists: (path) => system.directoryExists(path), - getDirectories: (path) => system.getDirectories(path), - readDirectory: (path, extensions, exclude, include, depth) => system.readDirectory(path, extensions, exclude, include, depth), - realpath: maybeBind(system, system.realpath), - getEnvironmentVariable: maybeBind(system, system.getEnvironmentVariable), - trace: (s) => system.write(s + system.newLine), - createDirectory: (path) => system.createDirectory(path), - writeFile: (path, data, writeByteOrderMark) => system.writeFile(path, data, writeByteOrderMark), - createHash: maybeBind(system, system.createHash), - createProgram: createProgram2 || createEmitAndSemanticDiagnosticsBuilderProgram, - storeFilesChangingSignatureDuringEmit: system.storeFilesChangingSignatureDuringEmit, - now: maybeBind(system, system.now) - }; + function getNextInvalidatedProject(state, buildOrder, reportQueue) { + const info = getNextInvalidatedProjectCreateInfo(state, buildOrder, reportQueue); + if (!info) + return info; + return createInvalidatedProjectWithInfo(state, info, buildOrder); } - function createWatchCompilerHost(system = sys, createProgram2, reportDiagnostic, reportWatchStatus2) { - const write = (s) => system.write(s + system.newLine); - const result = createProgramHost(system, createProgram2); - copyProperties(result, createWatchHost(system, reportWatchStatus2)); - result.afterProgramCreate = (builderProgram) => { - const compilerOptions = builderProgram.getCompilerOptions(); - const newLine = getNewLineCharacter(compilerOptions); - emitFilesAndReportErrors( - builderProgram, - reportDiagnostic, - write, - (errorCount) => result.onWatchStatusChange( - createCompilerDiagnostic(getWatchErrorSummaryDiagnosticMessage(errorCount), errorCount), - newLine, - compilerOptions, - errorCount - ) - ); - }; - return result; + function listEmittedFile({ write }, proj, file) { + if (write && proj.options.listEmittedFiles) { + write(`TSFILE: ${file}`); + } } - function reportUnrecoverableDiagnostic(system, reportDiagnostic, diagnostic) { - reportDiagnostic(diagnostic); - system.exit(1 /* DiagnosticsPresent_OutputsSkipped */); + function getOldProgram({ options, builderPrograms, compilerHost }, proj, parsed) { + if (options.force) + return void 0; + const value = builderPrograms.get(proj); + if (value) + return value; + return readBuilderProgram(parsed.options, compilerHost); } - function createWatchCompilerHostOfConfigFile({ - configFileName, - optionsToExtend, - watchOptionsToExtend, - extraFileExtensions, - system, - createProgram: createProgram2, - reportDiagnostic, - reportWatchStatus: reportWatchStatus2 - }) { - const diagnosticReporter = reportDiagnostic || createDiagnosticReporter(system); - const host = createWatchCompilerHost(system, createProgram2, diagnosticReporter, reportWatchStatus2); - host.onUnRecoverableConfigFileDiagnostic = (diagnostic) => reportUnrecoverableDiagnostic(system, diagnosticReporter, diagnostic); - host.configFileName = configFileName; - host.optionsToExtend = optionsToExtend; - host.watchOptionsToExtend = watchOptionsToExtend; - host.extraFileExtensions = extraFileExtensions; - return host; + function afterProgramDone(state, program, config) { + if (program) { + if (state.write) + listFiles(program, state.write); + if (state.host.afterProgramEmitAndDiagnostics) { + state.host.afterProgramEmitAndDiagnostics(program); + } + program.releaseProgram(); + } else if (state.host.afterEmitBundle) { + state.host.afterEmitBundle(config); + } + state.projectCompilerOptions = state.baseCompilerOptions; } - function createWatchCompilerHostOfFilesAndCompilerOptions({ - rootFiles, - options, - watchOptions, - projectReferences, - system, - createProgram: createProgram2, - reportDiagnostic, - reportWatchStatus: reportWatchStatus2 - }) { - const host = createWatchCompilerHost(system, createProgram2, reportDiagnostic || createDiagnosticReporter(system), reportWatchStatus2); - host.rootFiles = rootFiles; - host.options = options; - host.watchOptions = watchOptions; - host.projectReferences = projectReferences; - return host; + function buildErrors(state, resolvedPath, program, config, diagnostics, buildResult, errorType) { + const canEmitBuildInfo = program && !outFile(program.getCompilerOptions()); + reportAndStoreErrors(state, resolvedPath, diagnostics); + state.projectStatus.set(resolvedPath, { type: 0 /* Unbuildable */, reason: `${errorType} errors` }); + if (canEmitBuildInfo) + return { buildResult, step: 5 /* EmitBuildInfo */ }; + afterProgramDone(state, program, config); + return { buildResult, step: 7 /* QueueReferencingProjects */ }; } - function performIncrementalCompilation(input) { - const system = input.system || sys; - const host = input.host || (input.host = createIncrementalCompilerHost(input.options, system)); - const builderProgram = createIncrementalProgram(input); - const exitStatus = emitFilesAndReportErrorsAndGetExitStatus( - builderProgram, - input.reportDiagnostic || createDiagnosticReporter(system), - (s) => host.trace && host.trace(s), - input.reportErrorSummary || input.options.pretty ? (errorCount, filesInError) => system.write(getErrorSummaryText(errorCount, filesInError, system.newLine, host)) : void 0 - ); - if (input.afterProgramEmitAndDiagnostics) - input.afterProgramEmitAndDiagnostics(builderProgram); - return exitStatus; + function isFileWatcherWithModifiedTime(value) { + return !!value.watcher; } - var sysFormatDiagnosticsHost, screenStartingMessageCodes, noopFileWatcher, returnNoopFileWatcher, WatchType; - var init_watch = __esm({ - "src/compiler/watch.ts"() { - "use strict"; - init_ts2(); - sysFormatDiagnosticsHost = sys ? { - getCurrentDirectory: () => sys.getCurrentDirectory(), - getNewLine: () => sys.newLine, - getCanonicalFileName: createGetCanonicalFileName(sys.useCaseSensitiveFileNames) - } : void 0; - screenStartingMessageCodes = [ - Diagnostics.Starting_compilation_in_watch_mode.code, - Diagnostics.File_change_detected_Starting_incremental_compilation.code - ]; - noopFileWatcher = { close: noop }; - returnNoopFileWatcher = () => noopFileWatcher; - WatchType = { - ConfigFile: "Config file", - ExtendedConfigFile: "Extended config file", - SourceFile: "Source file", - MissingFile: "Missing file", - WildcardDirectory: "Wild card directory", - FailedLookupLocations: "Failed Lookup Locations", - AffectingFileLocation: "File location affecting resolution", - TypeRoots: "Type roots", - ConfigFileOfReferencedProject: "Config file of referened project", - ExtendedConfigOfReferencedProject: "Extended config file of referenced project", - WildcardDirectoryOfReferencedProject: "Wild card directory of referenced project", - PackageJson: "package.json file", - ClosedScriptInfo: "Closed Script info", - ConfigFileForInferredRoot: "Config file for the inferred project root", - NodeModules: "node_modules for closed script infos and package.jsons affecting module specifier cache", - MissingSourceMapFile: "Missing source map file", - NoopConfigFileForInferredRoot: "Noop Config file for the inferred project root", - MissingGeneratedFile: "Missing generated file", - NodeModulesForModuleSpecifierCache: "node_modules for module specifier cache invalidation", - TypingInstallerLocationFile: "File location for typing installer", - TypingInstallerLocationDirectory: "Directory location for typing installer" - }; + function getModifiedTime2(state, fileName) { + const path = toPath2(state, fileName); + const existing = state.filesWatched.get(path); + if (state.watch && !!existing) { + if (!isFileWatcherWithModifiedTime(existing)) + return existing; + if (existing.modifiedTime) + return existing.modifiedTime; } - }); - - // src/compiler/watchPublic.ts - function readBuilderProgram(compilerOptions, host) { - const buildInfoPath = getTsBuildInfoEmitOutputFilePath(compilerOptions); - if (!buildInfoPath) - return void 0; - let buildInfo; - if (host.getBuildInfo) { - buildInfo = host.getBuildInfo(buildInfoPath, compilerOptions.configFilePath); - } else { - const content = host.readFile(buildInfoPath); - if (!content) - return void 0; - buildInfo = getBuildInfo(buildInfoPath, content); + const result = getModifiedTime(state.host, fileName); + if (state.watch) { + if (existing) + existing.modifiedTime = result; + else + state.filesWatched.set(path, result); } - if (!buildInfo || buildInfo.version !== version || !buildInfo.program) - return void 0; - return createBuilderProgramUsingProgramBuildInfo(buildInfo, buildInfoPath, host); + return result; } - function createIncrementalCompilerHost(options, system = sys) { - const host = createCompilerHostWorker( - options, - /*setParentNodes*/ - void 0, - system - ); - host.createHash = maybeBind(system, system.createHash); - host.storeFilesChangingSignatureDuringEmit = system.storeFilesChangingSignatureDuringEmit; - setGetSourceFileAsHashVersioned(host); - changeCompilerHostLikeToUseCache(host, (fileName) => toPath(fileName, host.getCurrentDirectory(), host.getCanonicalFileName)); - return host; + function watchFile(state, file, callback, pollingInterval, options, watchType, project) { + const path = toPath2(state, file); + const existing = state.filesWatched.get(path); + if (existing && isFileWatcherWithModifiedTime(existing)) { + existing.callbacks.push(callback); + } else { + const watcher = state.watchFile( + file, + (fileName, eventKind, modifiedTime) => { + const existing2 = Debug.checkDefined(state.filesWatched.get(path)); + Debug.assert(isFileWatcherWithModifiedTime(existing2)); + existing2.modifiedTime = modifiedTime; + existing2.callbacks.forEach((cb) => cb(fileName, eventKind, modifiedTime)); + }, + pollingInterval, + options, + watchType, + project + ); + state.filesWatched.set(path, { callbacks: [callback], watcher, modifiedTime: existing }); + } + return { + close: () => { + const existing2 = Debug.checkDefined(state.filesWatched.get(path)); + Debug.assert(isFileWatcherWithModifiedTime(existing2)); + if (existing2.callbacks.length === 1) { + state.filesWatched.delete(path); + closeFileWatcherOf(existing2); + } else { + unorderedRemoveItem(existing2.callbacks, callback); + } + } + }; } - function createIncrementalProgram({ - rootNames, - options, - configFileParsingDiagnostics, - projectReferences, - host, - createProgram: createProgram2 - }) { - host = host || createIncrementalCompilerHost(options); - createProgram2 = createProgram2 || createEmitAndSemanticDiagnosticsBuilderProgram; - const oldProgram = readBuilderProgram(options, host); - return createProgram2(rootNames, options, host, oldProgram, configFileParsingDiagnostics, projectReferences); + function getOutputTimeStampMap(state, resolvedConfigFilePath) { + if (!state.watch) + return void 0; + let result = state.outputTimeStamps.get(resolvedConfigFilePath); + if (!result) + state.outputTimeStamps.set(resolvedConfigFilePath, result = /* @__PURE__ */ new Map()); + return result; } - function createWatchCompilerHost2(rootFilesOrConfigFileName, options, system, createProgram2, reportDiagnostic, reportWatchStatus2, projectReferencesOrWatchOptionsToExtend, watchOptionsOrExtraFileExtensions) { - if (isArray(rootFilesOrConfigFileName)) { - return createWatchCompilerHostOfFilesAndCompilerOptions({ - rootFiles: rootFilesOrConfigFileName, - options, - watchOptions: watchOptionsOrExtraFileExtensions, - projectReferences: projectReferencesOrWatchOptionsToExtend, - system, - createProgram: createProgram2, - reportDiagnostic, - reportWatchStatus: reportWatchStatus2 - }); + function setBuildInfo(state, buildInfo, resolvedConfigPath, options, resultFlags) { + const buildInfoPath = getTsBuildInfoEmitOutputFilePath(options); + const existing = getBuildInfoCacheEntry(state, buildInfoPath, resolvedConfigPath); + const modifiedTime = getCurrentTime(state.host); + if (existing) { + existing.buildInfo = buildInfo; + existing.modifiedTime = modifiedTime; + if (!(resultFlags & 2 /* DeclarationOutputUnchanged */)) + existing.latestChangedDtsTime = modifiedTime; } else { - return createWatchCompilerHostOfConfigFile({ - configFileName: rootFilesOrConfigFileName, - optionsToExtend: options, - watchOptionsToExtend: projectReferencesOrWatchOptionsToExtend, - extraFileExtensions: watchOptionsOrExtraFileExtensions, - system, - createProgram: createProgram2, - reportDiagnostic, - reportWatchStatus: reportWatchStatus2 + state.buildInfoCache.set(resolvedConfigPath, { + path: toPath2(state, buildInfoPath), + buildInfo, + modifiedTime, + latestChangedDtsTime: resultFlags & 2 /* DeclarationOutputUnchanged */ ? void 0 : modifiedTime }); } } - function createWatchProgram(host) { - let builderProgram; - let reloadLevel; - let missingFilesMap; - let watchedWildcardDirectories; - let timerToUpdateProgram; - let timerToInvalidateFailedLookupResolutions; - let parsedConfigs; - let sharedExtendedConfigFileWatchers; - let extendedConfigCache = host.extendedConfigCache; - let reportFileChangeDetectedOnCreateProgram = false; - const sourceFilesCache = /* @__PURE__ */ new Map(); - let missingFilePathsRequestedForRelease; - let hasChangedCompilerOptions = false; - const useCaseSensitiveFileNames = host.useCaseSensitiveFileNames(); - const currentDirectory = host.getCurrentDirectory(); - const { configFileName, optionsToExtend: optionsToExtendForConfigFile = {}, watchOptionsToExtend, extraFileExtensions, createProgram: createProgram2 } = host; - let { rootFiles: rootFileNames, options: compilerOptions, watchOptions, projectReferences } = host; - let wildcardDirectories; - let configFileParsingDiagnostics; - let canConfigFileJsonReportNoInputFiles = false; - let hasChangedConfigFileParsingErrors = false; - const cachedDirectoryStructureHost = configFileName === void 0 ? void 0 : createCachedDirectoryStructureHost(host, currentDirectory, useCaseSensitiveFileNames); - const directoryStructureHost = cachedDirectoryStructureHost || host; - const parseConfigFileHost = parseConfigHostFromCompilerHostLike(host, directoryStructureHost); - let newLine = updateNewLine(); - if (configFileName && host.configFileParsingResult) { - setConfigFileParsingResult(host.configFileParsingResult); - newLine = updateNewLine(); - } - reportWatchDiagnostic(Diagnostics.Starting_compilation_in_watch_mode); - if (configFileName && !host.configFileParsingResult) { - newLine = getNewLineCharacter(optionsToExtendForConfigFile); - Debug.assert(!rootFileNames); - parseConfigFile2(); - newLine = updateNewLine(); - } - Debug.assert(compilerOptions); - Debug.assert(rootFileNames); - const { watchFile: watchFile2, watchDirectory, writeLog } = createWatchFactory(host, compilerOptions); - const getCanonicalFileName = createGetCanonicalFileName(useCaseSensitiveFileNames); - writeLog(`Current directory: ${currentDirectory} CaseSensitiveFileNames: ${useCaseSensitiveFileNames}`); - let configFileWatcher; - if (configFileName) { - configFileWatcher = watchFile2(configFileName, scheduleProgramReload, 2e3 /* High */, watchOptions, WatchType.ConfigFile); + function getBuildInfoCacheEntry(state, buildInfoPath, resolvedConfigPath) { + const path = toPath2(state, buildInfoPath); + const existing = state.buildInfoCache.get(resolvedConfigPath); + return (existing == null ? void 0 : existing.path) === path ? existing : void 0; + } + function getBuildInfo3(state, buildInfoPath, resolvedConfigPath, modifiedTime) { + const path = toPath2(state, buildInfoPath); + const existing = state.buildInfoCache.get(resolvedConfigPath); + if (existing !== void 0 && existing.path === path) { + return existing.buildInfo || void 0; } - const compilerHost = createCompilerHostFromProgramHost(host, () => compilerOptions, directoryStructureHost); - setGetSourceFileAsHashVersioned(compilerHost); - const getNewSourceFile = compilerHost.getSourceFile; - compilerHost.getSourceFile = (fileName, ...args) => getVersionedSourceFileByPath(fileName, toPath3(fileName), ...args); - compilerHost.getSourceFileByPath = getVersionedSourceFileByPath; - compilerHost.getNewLine = () => newLine; - compilerHost.fileExists = fileExists; - compilerHost.onReleaseOldSourceFile = onReleaseOldSourceFile; - compilerHost.onReleaseParsedCommandLine = onReleaseParsedCommandLine; - compilerHost.toPath = toPath3; - compilerHost.getCompilationSettings = () => compilerOptions; - compilerHost.useSourceOfProjectReferenceRedirect = maybeBind(host, host.useSourceOfProjectReferenceRedirect); - compilerHost.watchDirectoryOfFailedLookupLocation = (dir, cb, flags) => watchDirectory(dir, cb, flags, watchOptions, WatchType.FailedLookupLocations); - compilerHost.watchAffectingFileLocation = (file, cb) => watchFile2(file, cb, 2e3 /* High */, watchOptions, WatchType.AffectingFileLocation); - compilerHost.watchTypeRootsDirectory = (dir, cb, flags) => watchDirectory(dir, cb, flags, watchOptions, WatchType.TypeRoots); - compilerHost.getCachedDirectoryStructureHost = () => cachedDirectoryStructureHost; - compilerHost.scheduleInvalidateResolutionsOfFailedLookupLocations = scheduleInvalidateResolutionsOfFailedLookupLocations; - compilerHost.onInvalidatedResolution = scheduleProgramUpdate; - compilerHost.onChangedAutomaticTypeDirectiveNames = scheduleProgramUpdate; - compilerHost.fileIsOpen = returnFalse; - compilerHost.getCurrentProgram = getCurrentProgram; - compilerHost.writeLog = writeLog; - compilerHost.getParsedCommandLine = getParsedCommandLine; - const resolutionCache = createResolutionCache( - compilerHost, - configFileName ? getDirectoryPath(getNormalizedAbsolutePath(configFileName, currentDirectory)) : currentDirectory, - /*logChangesWhenResolvingModule*/ - false - ); - compilerHost.resolveModuleNameLiterals = maybeBind(host, host.resolveModuleNameLiterals); - compilerHost.resolveModuleNames = maybeBind(host, host.resolveModuleNames); - if (!compilerHost.resolveModuleNameLiterals && !compilerHost.resolveModuleNames) { - compilerHost.resolveModuleNameLiterals = resolutionCache.resolveModuleNameLiterals.bind(resolutionCache); + const value = state.readFileWithCache(buildInfoPath); + const buildInfo = value ? getBuildInfo(buildInfoPath, value) : void 0; + state.buildInfoCache.set(resolvedConfigPath, { path, buildInfo: buildInfo || false, modifiedTime: modifiedTime || missingFileModifiedTime }); + return buildInfo; + } + function checkConfigFileUpToDateStatus(state, configFile, oldestOutputFileTime, oldestOutputFileName) { + const tsconfigTime = getModifiedTime2(state, configFile); + if (oldestOutputFileTime < tsconfigTime) { + return { + type: 6 /* OutOfDateWithSelf */, + outOfDateOutputFileName: oldestOutputFileName, + newerInputFileName: configFile + }; } - compilerHost.resolveTypeReferenceDirectiveReferences = maybeBind(host, host.resolveTypeReferenceDirectiveReferences); - compilerHost.resolveTypeReferenceDirectives = maybeBind(host, host.resolveTypeReferenceDirectives); - if (!compilerHost.resolveTypeReferenceDirectiveReferences && !compilerHost.resolveTypeReferenceDirectives) { - compilerHost.resolveTypeReferenceDirectiveReferences = resolutionCache.resolveTypeReferenceDirectiveReferences.bind(resolutionCache); + } + function getUpToDateStatusWorker(state, project, resolvedPath) { + var _a, _b; + if (!project.fileNames.length && !canJsonReportNoInputFiles(project.raw)) { + return { + type: 16 /* ContainerOnly */ + }; } - compilerHost.resolveLibrary = !host.resolveLibrary ? resolutionCache.resolveLibrary.bind(resolutionCache) : host.resolveLibrary.bind(host); - compilerHost.getModuleResolutionCache = host.resolveModuleNameLiterals || host.resolveModuleNames ? maybeBind(host, host.getModuleResolutionCache) : () => resolutionCache.getModuleResolutionCache(); - const userProvidedResolution = !!host.resolveModuleNameLiterals || !!host.resolveTypeReferenceDirectiveReferences || !!host.resolveModuleNames || !!host.resolveTypeReferenceDirectives; - const customHasInvalidatedResolutions = userProvidedResolution ? maybeBind(host, host.hasInvalidatedResolutions) || returnTrue : returnFalse; - const customHasInvalidLibResolutions = host.resolveLibrary ? maybeBind(host, host.hasInvalidatedLibResolutions) || returnTrue : returnFalse; - builderProgram = readBuilderProgram(compilerOptions, compilerHost); - synchronizeProgram(); - watchConfigFileWildCardDirectories(); - if (configFileName) - updateExtendedConfigFilesWatches(toPath3(configFileName), compilerOptions, watchOptions, WatchType.ExtendedConfigFile); - return configFileName ? { getCurrentProgram: getCurrentBuilderProgram, getProgram: updateProgram, close } : { getCurrentProgram: getCurrentBuilderProgram, getProgram: updateProgram, updateRootFileNames, close }; - function close() { - clearInvalidateResolutionsOfFailedLookupLocations(); - resolutionCache.clear(); - clearMap(sourceFilesCache, (value) => { - if (value && value.fileWatcher) { - value.fileWatcher.close(); - value.fileWatcher = void 0; + let referenceStatuses; + const force = !!state.options.force; + if (project.projectReferences) { + state.projectStatus.set(resolvedPath, { type: 13 /* ComputingUpstream */ }); + for (const ref of project.projectReferences) { + const resolvedRef = resolveProjectReferencePath(ref); + const resolvedRefPath = toResolvedConfigFilePath(state, resolvedRef); + const resolvedConfig = parseConfigFile(state, resolvedRef, resolvedRefPath); + const refStatus = getUpToDateStatus(state, resolvedConfig, resolvedRefPath); + if (refStatus.type === 13 /* ComputingUpstream */ || refStatus.type === 16 /* ContainerOnly */) { + continue; } - }); - if (configFileWatcher) { - configFileWatcher.close(); - configFileWatcher = void 0; + if (refStatus.type === 0 /* Unbuildable */ || refStatus.type === 12 /* UpstreamBlocked */) { + return { + type: 12 /* UpstreamBlocked */, + upstreamProjectName: ref.path, + upstreamProjectBlocked: refStatus.type === 12 /* UpstreamBlocked */ + }; + } + if (refStatus.type !== 1 /* UpToDate */) { + return { + type: 11 /* UpstreamOutOfDate */, + upstreamProjectName: ref.path + }; + } + if (!force) + (referenceStatuses || (referenceStatuses = [])).push({ ref, refStatus, resolvedRefPath, resolvedConfig }); } - extendedConfigCache == null ? void 0 : extendedConfigCache.clear(); - extendedConfigCache = void 0; - if (sharedExtendedConfigFileWatchers) { - clearMap(sharedExtendedConfigFileWatchers, closeFileWatcherOf); - sharedExtendedConfigFileWatchers = void 0; + } + if (force) + return { type: 17 /* ForceBuild */ }; + const { host } = state; + const buildInfoPath = getTsBuildInfoEmitOutputFilePath(project.options); + let oldestOutputFileName; + let oldestOutputFileTime = maximumDate; + let buildInfoTime; + let buildInfoProgram; + let buildInfoVersionMap; + if (buildInfoPath) { + const buildInfoCacheEntry2 = getBuildInfoCacheEntry(state, buildInfoPath, resolvedPath); + buildInfoTime = (buildInfoCacheEntry2 == null ? void 0 : buildInfoCacheEntry2.modifiedTime) || getModifiedTime(host, buildInfoPath); + if (buildInfoTime === missingFileModifiedTime) { + if (!buildInfoCacheEntry2) { + state.buildInfoCache.set(resolvedPath, { + path: toPath2(state, buildInfoPath), + buildInfo: false, + modifiedTime: buildInfoTime + }); + } + return { + type: 4 /* OutputMissing */, + missingOutputFileName: buildInfoPath + }; } - if (watchedWildcardDirectories) { - clearMap(watchedWildcardDirectories, closeFileWatcherOf); - watchedWildcardDirectories = void 0; + const buildInfo = getBuildInfo3(state, buildInfoPath, resolvedPath, buildInfoTime); + if (!buildInfo) { + return { + type: 5 /* ErrorReadingFile */, + fileName: buildInfoPath + }; } - if (missingFilesMap) { - clearMap(missingFilesMap, closeFileWatcher); - missingFilesMap = void 0; + if ((buildInfo.bundle || buildInfo.program) && buildInfo.version !== version) { + return { + type: 14 /* TsVersionOutputOfDate */, + version: buildInfo.version + }; } - if (parsedConfigs) { - clearMap(parsedConfigs, (config) => { - var _a; - (_a = config.watcher) == null ? void 0 : _a.close(); - config.watcher = void 0; - if (config.watchedDirectories) - clearMap(config.watchedDirectories, closeFileWatcherOf); - config.watchedDirectories = void 0; - }); - parsedConfigs = void 0; + if (buildInfo.program) { + if (((_a = buildInfo.program.changeFileSet) == null ? void 0 : _a.length) || (!project.options.noEmit ? (_b = buildInfo.program.affectedFilesPendingEmit) == null ? void 0 : _b.length : some(buildInfo.program.semanticDiagnosticsPerFile, isArray))) { + return { + type: 8 /* OutOfDateBuildInfo */, + buildInfoFile: buildInfoPath + }; + } + if (!project.options.noEmit && getPendingEmitKind(project.options, buildInfo.program.options || {})) { + return { + type: 9 /* OutOfDateOptions */, + buildInfoFile: buildInfoPath + }; + } + buildInfoProgram = buildInfo.program; } + oldestOutputFileTime = buildInfoTime; + oldestOutputFileName = buildInfoPath; } - function getCurrentBuilderProgram() { - return builderProgram; - } - function getCurrentProgram() { - return builderProgram && builderProgram.getProgramOrUndefined(); - } - function synchronizeProgram() { - writeLog(`Synchronizing program`); - Debug.assert(compilerOptions); - Debug.assert(rootFileNames); - clearInvalidateResolutionsOfFailedLookupLocations(); - const program = getCurrentBuilderProgram(); - if (hasChangedCompilerOptions) { - newLine = updateNewLine(); - if (program && changesAffectModuleResolution(program.getCompilerOptions(), compilerOptions)) { - debugger; - resolutionCache.onChangesAffectModuleResolution(); - } + let newestInputFileName = void 0; + let newestInputFileTime = minimumDate; + let pseudoInputUpToDate = false; + const seenRoots = /* @__PURE__ */ new Set(); + for (const inputFile of project.fileNames) { + const inputTime = getModifiedTime2(state, inputFile); + if (inputTime === missingFileModifiedTime) { + return { + type: 0 /* Unbuildable */, + reason: `${inputFile} does not exist` + }; } - const { hasInvalidatedResolutions, hasInvalidatedLibResolutions } = resolutionCache.createHasInvalidatedResolutions(customHasInvalidatedResolutions, customHasInvalidLibResolutions); - const { - originalReadFile, - originalFileExists, - originalDirectoryExists, - originalCreateDirectory, - originalWriteFile, - readFileWithCache - } = changeCompilerHostLikeToUseCache(compilerHost, toPath3); - if (isProgramUptoDate(getCurrentProgram(), rootFileNames, compilerOptions, (path) => getSourceVersion(path, readFileWithCache), (fileName) => compilerHost.fileExists(fileName), hasInvalidatedResolutions, hasInvalidatedLibResolutions, hasChangedAutomaticTypeDirectiveNames, getParsedCommandLine, projectReferences)) { - if (hasChangedConfigFileParsingErrors) { - if (reportFileChangeDetectedOnCreateProgram) { - reportWatchDiagnostic(Diagnostics.File_change_detected_Starting_incremental_compilation); - } - builderProgram = createProgram2( - /*rootNames*/ - void 0, - /*options*/ - void 0, - compilerHost, - builderProgram, - configFileParsingDiagnostics, - projectReferences - ); - hasChangedConfigFileParsingErrors = false; + if (buildInfoTime && buildInfoTime < inputTime) { + let version2; + let currentVersion; + if (buildInfoProgram) { + if (!buildInfoVersionMap) + buildInfoVersionMap = getBuildInfoFileVersionMap(buildInfoProgram, buildInfoPath, host); + version2 = buildInfoVersionMap.fileInfos.get(toPath2(state, inputFile)); + const text = version2 ? state.readFileWithCache(inputFile) : void 0; + currentVersion = text !== void 0 ? getSourceFileVersionAsHashFromText(host, text) : void 0; + if (version2 && version2 === currentVersion) + pseudoInputUpToDate = true; } - } else { - if (reportFileChangeDetectedOnCreateProgram) { - reportWatchDiagnostic(Diagnostics.File_change_detected_Starting_incremental_compilation); + if (!version2 || version2 !== currentVersion) { + return { + type: 6 /* OutOfDateWithSelf */, + outOfDateOutputFileName: buildInfoPath, + newerInputFileName: inputFile + }; } - createNewProgram(hasInvalidatedResolutions, hasInvalidatedLibResolutions); } - reportFileChangeDetectedOnCreateProgram = false; - if (host.afterProgramCreate && program !== builderProgram) { - host.afterProgramCreate(builderProgram); + if (inputTime > newestInputFileTime) { + newestInputFileName = inputFile; + newestInputFileTime = inputTime; } - compilerHost.readFile = originalReadFile; - compilerHost.fileExists = originalFileExists; - compilerHost.directoryExists = originalDirectoryExists; - compilerHost.createDirectory = originalCreateDirectory; - compilerHost.writeFile = originalWriteFile; - return builderProgram; + if (buildInfoProgram) + seenRoots.add(toPath2(state, inputFile)); } - function createNewProgram(hasInvalidatedResolutions, hasInvalidatedLibResolutions) { - writeLog("CreatingProgramWith::"); - writeLog(` roots: ${JSON.stringify(rootFileNames)}`); - writeLog(` options: ${JSON.stringify(compilerOptions)}`); - if (projectReferences) - writeLog(` projectReferences: ${JSON.stringify(projectReferences)}`); - const needsUpdateInTypeRootWatch = hasChangedCompilerOptions || !getCurrentProgram(); - hasChangedCompilerOptions = false; - hasChangedConfigFileParsingErrors = false; - resolutionCache.startCachingPerDirectoryResolution(); - compilerHost.hasInvalidatedResolutions = hasInvalidatedResolutions; - compilerHost.hasInvalidatedLibResolutions = hasInvalidatedLibResolutions; - compilerHost.hasChangedAutomaticTypeDirectiveNames = hasChangedAutomaticTypeDirectiveNames; - const oldProgram = getCurrentProgram(); - builderProgram = createProgram2(rootFileNames, compilerOptions, compilerHost, builderProgram, configFileParsingDiagnostics, projectReferences); - resolutionCache.finishCachingPerDirectoryResolution(builderProgram.getProgram(), oldProgram); - updateMissingFilePathsWatch(builderProgram.getProgram(), missingFilesMap || (missingFilesMap = /* @__PURE__ */ new Map()), watchMissingFilePath); - if (needsUpdateInTypeRootWatch) { - resolutionCache.updateTypeRootsWatch(); - } - if (missingFilePathsRequestedForRelease) { - for (const missingFilePath of missingFilePathsRequestedForRelease) { - if (!missingFilesMap.has(missingFilePath)) { - sourceFilesCache.delete(missingFilePath); - } + if (buildInfoProgram) { + if (!buildInfoVersionMap) + buildInfoVersionMap = getBuildInfoFileVersionMap(buildInfoProgram, buildInfoPath, host); + for (const existingRoot of buildInfoVersionMap.roots) { + if (!seenRoots.has(existingRoot)) { + return { + type: 10 /* OutOfDateRoots */, + buildInfoFile: buildInfoPath, + inputFile: existingRoot + }; } - missingFilePathsRequestedForRelease = void 0; } } - function updateRootFileNames(files) { - Debug.assert(!configFileName, "Cannot update root file names with config file watch mode"); - rootFileNames = files; - scheduleProgramUpdate(); + if (!buildInfoPath) { + const outputs = getAllProjectOutputs(project, !host.useCaseSensitiveFileNames()); + const outputTimeStampMap = getOutputTimeStampMap(state, resolvedPath); + for (const output of outputs) { + const path = toPath2(state, output); + let outputTime = outputTimeStampMap == null ? void 0 : outputTimeStampMap.get(path); + if (!outputTime) { + outputTime = getModifiedTime(state.host, output); + outputTimeStampMap == null ? void 0 : outputTimeStampMap.set(path, outputTime); + } + if (outputTime === missingFileModifiedTime) { + return { + type: 4 /* OutputMissing */, + missingOutputFileName: output + }; + } + if (outputTime < newestInputFileTime) { + return { + type: 6 /* OutOfDateWithSelf */, + outOfDateOutputFileName: output, + newerInputFileName: newestInputFileName + }; + } + if (outputTime < oldestOutputFileTime) { + oldestOutputFileTime = outputTime; + oldestOutputFileName = output; + } + } } - function updateNewLine() { - return getNewLineCharacter(compilerOptions || optionsToExtendForConfigFile); + const buildInfoCacheEntry = state.buildInfoCache.get(resolvedPath); + let pseudoUpToDate = false; + let usesPrepend = false; + let upstreamChangedProject; + if (referenceStatuses) { + for (const { ref, refStatus, resolvedConfig, resolvedRefPath } of referenceStatuses) { + usesPrepend = usesPrepend || !!ref.prepend; + if (refStatus.newestInputFileTime && refStatus.newestInputFileTime <= oldestOutputFileTime) { + continue; + } + if (buildInfoCacheEntry && hasSameBuildInfo(state, buildInfoCacheEntry, resolvedRefPath)) { + return { + type: 7 /* OutOfDateWithUpstream */, + outOfDateOutputFileName: buildInfoPath, + newerProjectName: ref.path + }; + } + const newestDeclarationFileContentChangedTime = getLatestChangedDtsTime(state, resolvedConfig.options, resolvedRefPath); + if (newestDeclarationFileContentChangedTime && newestDeclarationFileContentChangedTime <= oldestOutputFileTime) { + pseudoUpToDate = true; + upstreamChangedProject = ref.path; + continue; + } + Debug.assert(oldestOutputFileName !== void 0, "Should have an oldest output filename here"); + return { + type: 7 /* OutOfDateWithUpstream */, + outOfDateOutputFileName: oldestOutputFileName, + newerProjectName: ref.path + }; + } } - function toPath3(fileName) { - return toPath(fileName, currentDirectory, getCanonicalFileName); + const configStatus = checkConfigFileUpToDateStatus(state, project.options.configFilePath, oldestOutputFileTime, oldestOutputFileName); + if (configStatus) + return configStatus; + const extendedConfigStatus = forEach(project.options.configFile.extendedSourceFiles || emptyArray, (configFile) => checkConfigFileUpToDateStatus(state, configFile, oldestOutputFileTime, oldestOutputFileName)); + if (extendedConfigStatus) + return extendedConfigStatus; + const dependentPackageFileStatus = forEach( + state.lastCachedPackageJsonLookups.get(resolvedPath) || emptyArray, + ([path]) => checkConfigFileUpToDateStatus(state, path, oldestOutputFileTime, oldestOutputFileName) + ); + if (dependentPackageFileStatus) + return dependentPackageFileStatus; + if (usesPrepend && pseudoUpToDate) { + return { + type: 3 /* OutOfDateWithPrepend */, + outOfDateOutputFileName: oldestOutputFileName, + newerProjectName: upstreamChangedProject + }; } - function isFileMissingOnHost(hostSourceFile) { - return typeof hostSourceFile === "boolean"; + return { + type: pseudoUpToDate ? 2 /* UpToDateWithUpstreamTypes */ : pseudoInputUpToDate ? 15 /* UpToDateWithInputFileText */ : 1 /* UpToDate */, + newestInputFileTime, + newestInputFileName, + oldestOutputFileName + }; + } + function hasSameBuildInfo(state, buildInfoCacheEntry, resolvedRefPath) { + const refBuildInfo = state.buildInfoCache.get(resolvedRefPath); + return refBuildInfo.path === buildInfoCacheEntry.path; + } + function getUpToDateStatus(state, project, resolvedPath) { + if (project === void 0) { + return { type: 0 /* Unbuildable */, reason: "File deleted mid-build" }; } - function isFilePresenceUnknownOnHost(hostSourceFile) { - return typeof hostSourceFile.version === "boolean"; + const prior = state.projectStatus.get(resolvedPath); + if (prior !== void 0) { + return prior; } - function fileExists(fileName) { - const path = toPath3(fileName); - if (isFileMissingOnHost(sourceFilesCache.get(path))) { - return false; + mark("SolutionBuilder::beforeUpToDateCheck"); + const actual = getUpToDateStatusWorker(state, project, resolvedPath); + mark("SolutionBuilder::afterUpToDateCheck"); + measure("SolutionBuilder::Up-to-date check", "SolutionBuilder::beforeUpToDateCheck", "SolutionBuilder::afterUpToDateCheck"); + state.projectStatus.set(resolvedPath, actual); + return actual; + } + function updateOutputTimestampsWorker(state, proj, projectPath, verboseMessage, skipOutputs) { + if (proj.options.noEmit) + return; + let now; + const buildInfoPath = getTsBuildInfoEmitOutputFilePath(proj.options); + if (buildInfoPath) { + if (!(skipOutputs == null ? void 0 : skipOutputs.has(toPath2(state, buildInfoPath)))) { + if (!!state.options.verbose) + reportStatus(state, verboseMessage, proj.options.configFilePath); + state.host.setModifiedTime(buildInfoPath, now = getCurrentTime(state.host)); + getBuildInfoCacheEntry(state, buildInfoPath, projectPath).modifiedTime = now; } - return directoryStructureHost.fileExists(fileName); + state.outputTimeStamps.delete(projectPath); + return; } - function getVersionedSourceFileByPath(fileName, path, languageVersionOrOptions, onError, shouldCreateNewSourceFile) { - const hostSourceFile = sourceFilesCache.get(path); - if (isFileMissingOnHost(hostSourceFile)) { - return void 0; - } - if (hostSourceFile === void 0 || shouldCreateNewSourceFile || isFilePresenceUnknownOnHost(hostSourceFile)) { - const sourceFile = getNewSourceFile(fileName, languageVersionOrOptions, onError); - if (hostSourceFile) { - if (sourceFile) { - hostSourceFile.sourceFile = sourceFile; - hostSourceFile.version = sourceFile.version; - if (!hostSourceFile.fileWatcher) { - hostSourceFile.fileWatcher = watchFilePath(path, fileName, onSourceFileChange, 250 /* Low */, watchOptions, WatchType.SourceFile); - } - } else { - if (hostSourceFile.fileWatcher) { - hostSourceFile.fileWatcher.close(); - } - sourceFilesCache.set(path, false); - } - } else { - if (sourceFile) { - const fileWatcher = watchFilePath(path, fileName, onSourceFileChange, 250 /* Low */, watchOptions, WatchType.SourceFile); - sourceFilesCache.set(path, { sourceFile, version: sourceFile.version, fileWatcher }); - } else { - sourceFilesCache.set(path, false); - } + const { host } = state; + const outputs = getAllProjectOutputs(proj, !host.useCaseSensitiveFileNames()); + const outputTimeStampMap = getOutputTimeStampMap(state, projectPath); + const modifiedOutputs = outputTimeStampMap ? /* @__PURE__ */ new Set() : void 0; + if (!skipOutputs || outputs.length !== skipOutputs.size) { + let reportVerbose = !!state.options.verbose; + for (const file of outputs) { + const path = toPath2(state, file); + if (skipOutputs == null ? void 0 : skipOutputs.has(path)) + continue; + if (reportVerbose) { + reportVerbose = false; + reportStatus(state, verboseMessage, proj.options.configFilePath); } - return sourceFile; - } - return hostSourceFile.sourceFile; - } - function nextSourceFileVersion(path) { - const hostSourceFile = sourceFilesCache.get(path); - if (hostSourceFile !== void 0) { - if (isFileMissingOnHost(hostSourceFile)) { - sourceFilesCache.set(path, { version: false }); - } else { - hostSourceFile.version = false; + host.setModifiedTime(file, now || (now = getCurrentTime(state.host))); + if (outputTimeStampMap) { + outputTimeStampMap.set(path, now); + modifiedOutputs.add(path); } } } - function getSourceVersion(path, readFileWithCache) { - const hostSourceFile = sourceFilesCache.get(path); - if (!hostSourceFile) - return void 0; - if (hostSourceFile.version) - return hostSourceFile.version; - const text = readFileWithCache(path); - return text !== void 0 ? getSourceFileVersionAsHashFromText(compilerHost, text) : void 0; + outputTimeStampMap == null ? void 0 : outputTimeStampMap.forEach((_value, key) => { + if (!(skipOutputs == null ? void 0 : skipOutputs.has(key)) && !modifiedOutputs.has(key)) + outputTimeStampMap.delete(key); + }); + } + function getLatestChangedDtsTime(state, options, resolvedConfigPath) { + if (!options.composite) + return void 0; + const entry = Debug.checkDefined(state.buildInfoCache.get(resolvedConfigPath)); + if (entry.latestChangedDtsTime !== void 0) + return entry.latestChangedDtsTime || void 0; + const latestChangedDtsTime = entry.buildInfo && entry.buildInfo.program && entry.buildInfo.program.latestChangedDtsFile ? state.host.getModifiedTime(getNormalizedAbsolutePath(entry.buildInfo.program.latestChangedDtsFile, getDirectoryPath(entry.path))) : void 0; + entry.latestChangedDtsTime = latestChangedDtsTime || false; + return latestChangedDtsTime; + } + function updateOutputTimestamps(state, proj, resolvedPath) { + if (state.options.dry) { + return reportStatus(state, Diagnostics.A_non_dry_build_would_update_timestamps_for_output_of_project_0, proj.options.configFilePath); } - function onReleaseOldSourceFile(oldSourceFile, _oldOptions, hasSourceFileByPath) { - const hostSourceFileInfo = sourceFilesCache.get(oldSourceFile.resolvedPath); - if (hostSourceFileInfo !== void 0) { - if (isFileMissingOnHost(hostSourceFileInfo)) { - (missingFilePathsRequestedForRelease || (missingFilePathsRequestedForRelease = [])).push(oldSourceFile.path); - } else if (hostSourceFileInfo.sourceFile === oldSourceFile) { - if (hostSourceFileInfo.fileWatcher) { - hostSourceFileInfo.fileWatcher.close(); - } - sourceFilesCache.delete(oldSourceFile.resolvedPath); - if (!hasSourceFileByPath) { - resolutionCache.removeResolutionsOfFile(oldSourceFile.path); + updateOutputTimestampsWorker(state, proj, resolvedPath, Diagnostics.Updating_output_timestamps_of_project_0); + state.projectStatus.set(resolvedPath, { + type: 1 /* UpToDate */, + oldestOutputFileName: getFirstProjectOutput(proj, !state.host.useCaseSensitiveFileNames()) + }); + } + function queueReferencingProjects(state, project, projectPath, projectIndex, config, buildOrder, buildResult) { + if (buildResult & 124 /* AnyErrors */) + return; + if (!config.options.composite) + return; + for (let index = projectIndex + 1; index < buildOrder.length; index++) { + const nextProject = buildOrder[index]; + const nextProjectPath = toResolvedConfigFilePath(state, nextProject); + if (state.projectPendingBuild.has(nextProjectPath)) + continue; + const nextProjectConfig = parseConfigFile(state, nextProject, nextProjectPath); + if (!nextProjectConfig || !nextProjectConfig.projectReferences) + continue; + for (const ref of nextProjectConfig.projectReferences) { + const resolvedRefPath = resolveProjectName(state, ref.path); + if (toResolvedConfigFilePath(state, resolvedRefPath) !== projectPath) + continue; + const status = state.projectStatus.get(nextProjectPath); + if (status) { + switch (status.type) { + case 1 /* UpToDate */: + if (buildResult & 2 /* DeclarationOutputUnchanged */) { + if (ref.prepend) { + state.projectStatus.set(nextProjectPath, { + type: 3 /* OutOfDateWithPrepend */, + outOfDateOutputFileName: status.oldestOutputFileName, + newerProjectName: project + }); + } else { + status.type = 2 /* UpToDateWithUpstreamTypes */; + } + break; + } + case 15 /* UpToDateWithInputFileText */: + case 2 /* UpToDateWithUpstreamTypes */: + case 3 /* OutOfDateWithPrepend */: + if (!(buildResult & 2 /* DeclarationOutputUnchanged */)) { + state.projectStatus.set(nextProjectPath, { + type: 7 /* OutOfDateWithUpstream */, + outOfDateOutputFileName: status.type === 3 /* OutOfDateWithPrepend */ ? status.outOfDateOutputFileName : status.oldestOutputFileName, + newerProjectName: project + }); + } + break; + case 12 /* UpstreamBlocked */: + if (toResolvedConfigFilePath(state, resolveProjectName(state, status.upstreamProjectName)) === projectPath) { + clearProjectStatus(state, nextProjectPath); + } + break; } } + addProjToQueue(state, nextProjectPath, 0 /* Update */); + break; } } - function reportWatchDiagnostic(message) { - if (host.onWatchStatusChange) { - host.onWatchStatusChange(createCompilerDiagnostic(message), newLine, compilerOptions || optionsToExtendForConfigFile); - } - } - function hasChangedAutomaticTypeDirectiveNames() { - return resolutionCache.hasChangedAutomaticTypeDirectiveNames(); - } - function clearInvalidateResolutionsOfFailedLookupLocations() { - if (!timerToInvalidateFailedLookupResolutions) - return false; - host.clearTimeout(timerToInvalidateFailedLookupResolutions); - timerToInvalidateFailedLookupResolutions = void 0; - return true; - } - function scheduleInvalidateResolutionsOfFailedLookupLocations() { - if (!host.setTimeout || !host.clearTimeout) { - return resolutionCache.invalidateResolutionsOfFailedLookupLocations(); - } - const pending = clearInvalidateResolutionsOfFailedLookupLocations(); - writeLog(`Scheduling invalidateFailedLookup${pending ? ", Cancelled earlier one" : ""}`); - timerToInvalidateFailedLookupResolutions = host.setTimeout(invalidateResolutionsOfFailedLookup, 250, "timerToInvalidateFailedLookupResolutions"); - } - function invalidateResolutionsOfFailedLookup() { - timerToInvalidateFailedLookupResolutions = void 0; - if (resolutionCache.invalidateResolutionsOfFailedLookupLocations()) { - scheduleProgramUpdate(); - } - } - function scheduleProgramUpdate() { - if (!host.setTimeout || !host.clearTimeout) { - return; - } - if (timerToUpdateProgram) { - host.clearTimeout(timerToUpdateProgram); - } - writeLog("Scheduling update"); - timerToUpdateProgram = host.setTimeout(updateProgramWithWatchStatus, 250, "timerToUpdateProgram"); - } - function scheduleProgramReload() { - Debug.assert(!!configFileName); - reloadLevel = 2 /* Full */; - scheduleProgramUpdate(); - } - function updateProgramWithWatchStatus() { - timerToUpdateProgram = void 0; - reportFileChangeDetectedOnCreateProgram = true; - updateProgram(); - } - function updateProgram() { - var _a, _b, _c, _d; - switch (reloadLevel) { - case 1 /* Partial */: - (_a = perfLogger) == null ? void 0 : _a.logStartUpdateProgram("PartialConfigReload"); - reloadFileNamesFromConfigFile(); - break; - case 2 /* Full */: - (_b = perfLogger) == null ? void 0 : _b.logStartUpdateProgram("FullConfigReload"); - reloadConfigFile(); - break; - default: - (_c = perfLogger) == null ? void 0 : _c.logStartUpdateProgram("SynchronizeProgram"); - synchronizeProgram(); - break; - } - (_d = perfLogger) == null ? void 0 : _d.logStopUpdateProgram("Done"); - return getCurrentBuilderProgram(); + } + function build(state, project, cancellationToken, writeFile2, getCustomTransformers, onlyReferences) { + mark("SolutionBuilder::beforeBuild"); + const result = buildWorker(state, project, cancellationToken, writeFile2, getCustomTransformers, onlyReferences); + mark("SolutionBuilder::afterBuild"); + measure("SolutionBuilder::Build", "SolutionBuilder::beforeBuild", "SolutionBuilder::afterBuild"); + return result; + } + function buildWorker(state, project, cancellationToken, writeFile2, getCustomTransformers, onlyReferences) { + const buildOrder = getBuildOrderFor(state, project, onlyReferences); + if (!buildOrder) + return 3 /* InvalidProject_OutputsSkipped */; + setupInitialBuild(state, cancellationToken); + let reportQueue = true; + let successfulProjects = 0; + while (true) { + const invalidatedProject = getNextInvalidatedProject(state, buildOrder, reportQueue); + if (!invalidatedProject) + break; + reportQueue = false; + invalidatedProject.done(cancellationToken, writeFile2, getCustomTransformers == null ? void 0 : getCustomTransformers(invalidatedProject.project)); + if (!state.diagnostics.has(invalidatedProject.projectPath)) + successfulProjects++; } - function reloadFileNamesFromConfigFile() { - writeLog("Reloading new file names and options"); - Debug.assert(compilerOptions); - Debug.assert(configFileName); - reloadLevel = 0 /* None */; - rootFileNames = getFileNamesFromConfigSpecs(compilerOptions.configFile.configFileSpecs, getNormalizedAbsolutePath(getDirectoryPath(configFileName), currentDirectory), compilerOptions, parseConfigFileHost, extraFileExtensions); - if (updateErrorForNoInputFiles(rootFileNames, getNormalizedAbsolutePath(configFileName, currentDirectory), compilerOptions.configFile.configFileSpecs, configFileParsingDiagnostics, canConfigFileJsonReportNoInputFiles)) { - hasChangedConfigFileParsingErrors = true; - } - synchronizeProgram(); + disableCache(state); + reportErrorSummary(state, buildOrder); + startWatching(state, buildOrder); + return isCircularBuildOrder(buildOrder) ? 4 /* ProjectReferenceCycle_OutputsSkipped */ : !buildOrder.some((p) => state.diagnostics.has(toResolvedConfigFilePath(state, p))) ? 0 /* Success */ : successfulProjects ? 2 /* DiagnosticsPresent_OutputsGenerated */ : 1 /* DiagnosticsPresent_OutputsSkipped */; + } + function clean(state, project, onlyReferences) { + mark("SolutionBuilder::beforeClean"); + const result = cleanWorker(state, project, onlyReferences); + mark("SolutionBuilder::afterClean"); + measure("SolutionBuilder::Clean", "SolutionBuilder::beforeClean", "SolutionBuilder::afterClean"); + return result; + } + function cleanWorker(state, project, onlyReferences) { + const buildOrder = getBuildOrderFor(state, project, onlyReferences); + if (!buildOrder) + return 3 /* InvalidProject_OutputsSkipped */; + if (isCircularBuildOrder(buildOrder)) { + reportErrors(state, buildOrder.circularDiagnostics); + return 4 /* ProjectReferenceCycle_OutputsSkipped */; } - function reloadConfigFile() { - Debug.assert(configFileName); - writeLog(`Reloading config file: ${configFileName}`); - reloadLevel = 0 /* None */; - if (cachedDirectoryStructureHost) { - cachedDirectoryStructureHost.clearCache(); + const { options, host } = state; + const filesToDelete = options.dry ? [] : void 0; + for (const proj of buildOrder) { + const resolvedPath = toResolvedConfigFilePath(state, proj); + const parsed = parseConfigFile(state, proj, resolvedPath); + if (parsed === void 0) { + reportParseConfigFileDiagnostic(state, resolvedPath); + continue; } - parseConfigFile2(); - hasChangedCompilerOptions = true; - synchronizeProgram(); - watchConfigFileWildCardDirectories(); - updateExtendedConfigFilesWatches(toPath3(configFileName), compilerOptions, watchOptions, WatchType.ExtendedConfigFile); - } - function parseConfigFile2() { - Debug.assert(configFileName); - setConfigFileParsingResult(getParsedCommandLineOfConfigFile( - configFileName, - optionsToExtendForConfigFile, - parseConfigFileHost, - extendedConfigCache || (extendedConfigCache = /* @__PURE__ */ new Map()), - watchOptionsToExtend, - extraFileExtensions - )); - } - function setConfigFileParsingResult(configFileParseResult) { - rootFileNames = configFileParseResult.fileNames; - compilerOptions = configFileParseResult.options; - watchOptions = configFileParseResult.watchOptions; - projectReferences = configFileParseResult.projectReferences; - wildcardDirectories = configFileParseResult.wildcardDirectories; - configFileParsingDiagnostics = getConfigFileParsingDiagnostics(configFileParseResult).slice(); - canConfigFileJsonReportNoInputFiles = canJsonReportNoInputFiles(configFileParseResult.raw); - hasChangedConfigFileParsingErrors = true; - } - function getParsedCommandLine(configFileName2) { - const configPath = toPath3(configFileName2); - let config = parsedConfigs == null ? void 0 : parsedConfigs.get(configPath); - if (config) { - if (!config.reloadLevel) - return config.parsedCommandLine; - if (config.parsedCommandLine && config.reloadLevel === 1 /* Partial */ && !host.getParsedCommandLine) { - writeLog("Reloading new file names and options"); - Debug.assert(compilerOptions); - const fileNames = getFileNamesFromConfigSpecs( - config.parsedCommandLine.options.configFile.configFileSpecs, - getNormalizedAbsolutePath(getDirectoryPath(configFileName2), currentDirectory), - compilerOptions, - parseConfigFileHost - ); - config.parsedCommandLine = { ...config.parsedCommandLine, fileNames }; - config.reloadLevel = void 0; - return config.parsedCommandLine; + const outputs = getAllProjectOutputs(parsed, !host.useCaseSensitiveFileNames()); + if (!outputs.length) + continue; + const inputFileNames = new Set(parsed.fileNames.map((f) => toPath2(state, f))); + for (const output of outputs) { + if (inputFileNames.has(toPath2(state, output))) + continue; + if (host.fileExists(output)) { + if (filesToDelete) { + filesToDelete.push(output); + } else { + host.deleteFile(output); + invalidateProject(state, resolvedPath, 0 /* Update */); + } } } - writeLog(`Loading config file: ${configFileName2}`); - const parsedCommandLine = host.getParsedCommandLine ? host.getParsedCommandLine(configFileName2) : getParsedCommandLineFromConfigFileHost(configFileName2); - if (config) { - config.parsedCommandLine = parsedCommandLine; - config.reloadLevel = void 0; - } else { - (parsedConfigs || (parsedConfigs = /* @__PURE__ */ new Map())).set(configPath, config = { parsedCommandLine }); - } - watchReferencedProject(configFileName2, configPath, config); - return parsedCommandLine; - } - function getParsedCommandLineFromConfigFileHost(configFileName2) { - const onUnRecoverableConfigFileDiagnostic = parseConfigFileHost.onUnRecoverableConfigFileDiagnostic; - parseConfigFileHost.onUnRecoverableConfigFileDiagnostic = noop; - const parsedCommandLine = getParsedCommandLineOfConfigFile( - configFileName2, - /*optionsToExtend*/ - void 0, - parseConfigFileHost, - extendedConfigCache || (extendedConfigCache = /* @__PURE__ */ new Map()), - watchOptionsToExtend - ); - parseConfigFileHost.onUnRecoverableConfigFileDiagnostic = onUnRecoverableConfigFileDiagnostic; - return parsedCommandLine; } - function onReleaseParsedCommandLine(fileName) { - var _a; - const path = toPath3(fileName); - const config = parsedConfigs == null ? void 0 : parsedConfigs.get(path); - if (!config) - return; - parsedConfigs.delete(path); - if (config.watchedDirectories) - clearMap(config.watchedDirectories, closeFileWatcherOf); - (_a = config.watcher) == null ? void 0 : _a.close(); - clearSharedExtendedConfigFileWatcher(path, sharedExtendedConfigFileWatchers); + if (filesToDelete) { + reportStatus(state, Diagnostics.A_non_dry_build_would_delete_the_following_files_Colon_0, filesToDelete.map((f) => `\r + * ${f}`).join("")); } - function watchFilePath(path, file, callback, pollingInterval, options, watchType) { - return watchFile2(file, (fileName, eventKind) => callback(fileName, eventKind, path), pollingInterval, options, watchType); + return 0 /* Success */; + } + function invalidateProject(state, resolved, updateLevel) { + if (state.host.getParsedCommandLine && updateLevel === 1 /* RootNamesAndUpdate */) { + updateLevel = 2 /* Full */; } - function onSourceFileChange(fileName, eventKind, path) { - updateCachedSystemWithFile(fileName, path, eventKind); - if (eventKind === 2 /* Deleted */ && sourceFilesCache.has(path)) { - resolutionCache.invalidateResolutionOfFile(path); - } - nextSourceFileVersion(path); - scheduleProgramUpdate(); + if (updateLevel === 2 /* Full */) { + state.configFileCache.delete(resolved); + state.buildOrder = void 0; } - function updateCachedSystemWithFile(fileName, path, eventKind) { - if (cachedDirectoryStructureHost) { - cachedDirectoryStructureHost.addOrDeleteFile(fileName, path, eventKind); - } + state.needsSummary = true; + clearProjectStatus(state, resolved); + addProjToQueue(state, resolved, updateLevel); + enableCache(state); + } + function invalidateProjectAndScheduleBuilds(state, resolvedPath, updateLevel) { + state.reportFileChangeDetected = true; + invalidateProject(state, resolvedPath, updateLevel); + scheduleBuildInvalidatedProject( + state, + 250, + /*changeDetected*/ + true + ); + } + function scheduleBuildInvalidatedProject(state, time, changeDetected) { + const { hostWithWatch } = state; + if (!hostWithWatch.setTimeout || !hostWithWatch.clearTimeout) { + return; } - function watchMissingFilePath(missingFilePath) { - return (parsedConfigs == null ? void 0 : parsedConfigs.has(missingFilePath)) ? noopFileWatcher : watchFilePath(missingFilePath, missingFilePath, onMissingFileChange, 500 /* Medium */, watchOptions, WatchType.MissingFile); + if (state.timerToBuildInvalidatedProject) { + hostWithWatch.clearTimeout(state.timerToBuildInvalidatedProject); } - function onMissingFileChange(fileName, eventKind, missingFilePath) { - updateCachedSystemWithFile(fileName, missingFilePath, eventKind); - if (eventKind === 0 /* Created */ && missingFilesMap.has(missingFilePath)) { - missingFilesMap.get(missingFilePath).close(); - missingFilesMap.delete(missingFilePath); - nextSourceFileVersion(missingFilePath); - scheduleProgramUpdate(); - } + state.timerToBuildInvalidatedProject = hostWithWatch.setTimeout(buildNextInvalidatedProject, time, "timerToBuildInvalidatedProject", state, changeDetected); + } + function buildNextInvalidatedProject(_timeoutType, state, changeDetected) { + mark("SolutionBuilder::beforeBuild"); + const buildOrder = buildNextInvalidatedProjectWorker(state, changeDetected); + mark("SolutionBuilder::afterBuild"); + measure("SolutionBuilder::Build", "SolutionBuilder::beforeBuild", "SolutionBuilder::afterBuild"); + if (buildOrder) + reportErrorSummary(state, buildOrder); + } + function buildNextInvalidatedProjectWorker(state, changeDetected) { + state.timerToBuildInvalidatedProject = void 0; + if (state.reportFileChangeDetected) { + state.reportFileChangeDetected = false; + state.projectErrorsReported.clear(); + reportWatchStatus(state, Diagnostics.File_change_detected_Starting_incremental_compilation); } - function watchConfigFileWildCardDirectories() { - if (wildcardDirectories) { - updateWatchingWildcardDirectories( - watchedWildcardDirectories || (watchedWildcardDirectories = /* @__PURE__ */ new Map()), - new Map(Object.entries(wildcardDirectories)), - watchWildcardDirectory + let projectsBuilt = 0; + const buildOrder = getBuildOrder(state); + const invalidatedProject = getNextInvalidatedProject( + state, + buildOrder, + /*reportQueue*/ + false + ); + if (invalidatedProject) { + invalidatedProject.done(); + projectsBuilt++; + while (state.projectPendingBuild.size) { + if (state.timerToBuildInvalidatedProject) + return; + const info = getNextInvalidatedProjectCreateInfo( + state, + buildOrder, + /*reportQueue*/ + false ); - } else if (watchedWildcardDirectories) { - clearMap(watchedWildcardDirectories, closeFileWatcherOf); + if (!info) + break; + if (info.kind !== 2 /* UpdateOutputFileStamps */ && (changeDetected || projectsBuilt === 5)) { + scheduleBuildInvalidatedProject( + state, + 100, + /*changeDetected*/ + false + ); + return; + } + const project = createInvalidatedProjectWithInfo(state, info, buildOrder); + project.done(); + if (info.kind !== 2 /* UpdateOutputFileStamps */) + projectsBuilt++; } } - function watchWildcardDirectory(directory, flags) { - return watchDirectory( - directory, + disableCache(state); + return buildOrder; + } + function watchConfigFile(state, resolved, resolvedPath, parsed) { + if (!state.watch || state.allWatchedConfigFiles.has(resolvedPath)) + return; + state.allWatchedConfigFiles.set( + resolvedPath, + watchFile( + state, + resolved, + () => invalidateProjectAndScheduleBuilds(state, resolvedPath, 2 /* Full */), + 2e3 /* High */, + parsed == null ? void 0 : parsed.watchOptions, + WatchType.ConfigFile, + resolved + ) + ); + } + function watchExtendedConfigFiles(state, resolvedPath, parsed) { + updateSharedExtendedConfigFileWatcher( + resolvedPath, + parsed == null ? void 0 : parsed.options, + state.allWatchedExtendedConfigFiles, + (extendedConfigFileName, extendedConfigFilePath) => watchFile( + state, + extendedConfigFileName, + () => { + var _a; + return (_a = state.allWatchedExtendedConfigFiles.get(extendedConfigFilePath)) == null ? void 0 : _a.projects.forEach((projectConfigFilePath) => invalidateProjectAndScheduleBuilds(state, projectConfigFilePath, 2 /* Full */)); + }, + 2e3 /* High */, + parsed == null ? void 0 : parsed.watchOptions, + WatchType.ExtendedConfigFile + ), + (fileName) => toPath2(state, fileName) + ); + } + function watchWildCardDirectories(state, resolved, resolvedPath, parsed) { + if (!state.watch) + return; + updateWatchingWildcardDirectories( + getOrCreateValueMapFromConfigFileMap(state.allWatchedWildcardDirectories, resolvedPath), + new Map(Object.entries(parsed.wildcardDirectories)), + (dir, flags) => state.watchDirectory( + dir, (fileOrDirectory) => { - Debug.assert(configFileName); - Debug.assert(compilerOptions); - const fileOrDirectoryPath = toPath3(fileOrDirectory); - if (cachedDirectoryStructureHost) { - cachedDirectoryStructureHost.addOrDeleteFileOrDirectory(fileOrDirectory, fileOrDirectoryPath); - } - nextSourceFileVersion(fileOrDirectoryPath); + var _a; if (isIgnoredFileFromWildCardWatching({ - watchedDirPath: toPath3(directory), + watchedDirPath: toPath2(state, dir), fileOrDirectory, - fileOrDirectoryPath, - configFileName, - extraFileExtensions, - options: compilerOptions, - program: getCurrentBuilderProgram() || rootFileNames, - currentDirectory, - useCaseSensitiveFileNames, - writeLog, - toPath: toPath3 + fileOrDirectoryPath: toPath2(state, fileOrDirectory), + configFileName: resolved, + currentDirectory: state.compilerHost.getCurrentDirectory(), + options: parsed.options, + program: state.builderPrograms.get(resolvedPath) || ((_a = getCachedParsedConfigFile(state, resolvedPath)) == null ? void 0 : _a.fileNames), + useCaseSensitiveFileNames: state.parseConfigFileHost.useCaseSensitiveFileNames, + writeLog: (s) => state.writeLog(s), + toPath: (fileName) => toPath2(state, fileName) })) return; - if (reloadLevel !== 2 /* Full */) { - reloadLevel = 1 /* Partial */; - scheduleProgramUpdate(); - } + invalidateProjectAndScheduleBuilds(state, resolvedPath, 1 /* RootNamesAndUpdate */); }, flags, - watchOptions, - WatchType.WildcardDirectory - ); - } - function updateExtendedConfigFilesWatches(forProjectPath, options, watchOptions2, watchType) { - updateSharedExtendedConfigFileWatcher( - forProjectPath, - options, - sharedExtendedConfigFileWatchers || (sharedExtendedConfigFileWatchers = /* @__PURE__ */ new Map()), - (extendedConfigFileName, extendedConfigFilePath) => watchFile2( - extendedConfigFileName, - (_fileName, eventKind) => { - var _a; - updateCachedSystemWithFile(extendedConfigFileName, extendedConfigFilePath, eventKind); - if (extendedConfigCache) - cleanExtendedConfigCache(extendedConfigCache, extendedConfigFilePath, toPath3); - const projects = (_a = sharedExtendedConfigFileWatchers.get(extendedConfigFilePath)) == null ? void 0 : _a.projects; - if (!(projects == null ? void 0 : projects.size)) - return; - projects.forEach((projectPath) => { - if (configFileName && toPath3(configFileName) === projectPath) { - reloadLevel = 2 /* Full */; - } else { - const config = parsedConfigs == null ? void 0 : parsedConfigs.get(projectPath); - if (config) - config.reloadLevel = 2 /* Full */; - resolutionCache.removeResolutionsFromProjectReferenceRedirects(projectPath); - } - scheduleProgramUpdate(); - }); - }, - 2e3 /* High */, - watchOptions2, - watchType + parsed == null ? void 0 : parsed.watchOptions, + WatchType.WildcardDirectory, + resolved + ) + ); + } + function watchInputFiles(state, resolved, resolvedPath, parsed) { + if (!state.watch) + return; + mutateMap( + getOrCreateValueMapFromConfigFileMap(state.allWatchedInputFiles, resolvedPath), + arrayToMap(parsed.fileNames, (fileName) => toPath2(state, fileName)), + { + createNewValue: (_path, input) => watchFile( + state, + input, + () => invalidateProjectAndScheduleBuilds(state, resolvedPath, 0 /* Update */), + 250 /* Low */, + parsed == null ? void 0 : parsed.watchOptions, + WatchType.SourceFile, + resolved ), - toPath3 - ); - } - function watchReferencedProject(configFileName2, configPath, commandLine) { - var _a, _b, _c, _d, _e; - commandLine.watcher || (commandLine.watcher = watchFile2( - configFileName2, - (_fileName, eventKind) => { - updateCachedSystemWithFile(configFileName2, configPath, eventKind); - const config = parsedConfigs == null ? void 0 : parsedConfigs.get(configPath); - if (config) - config.reloadLevel = 2 /* Full */; - resolutionCache.removeResolutionsFromProjectReferenceRedirects(configPath); - scheduleProgramUpdate(); - }, - 2e3 /* High */, - ((_a = commandLine.parsedCommandLine) == null ? void 0 : _a.watchOptions) || watchOptions, - WatchType.ConfigFileOfReferencedProject - )); - if ((_b = commandLine.parsedCommandLine) == null ? void 0 : _b.wildcardDirectories) { - updateWatchingWildcardDirectories( - commandLine.watchedDirectories || (commandLine.watchedDirectories = /* @__PURE__ */ new Map()), - new Map(Object.entries((_c = commandLine.parsedCommandLine) == null ? void 0 : _c.wildcardDirectories)), - (directory, flags) => { - var _a2; - return watchDirectory( - directory, - (fileOrDirectory) => { - const fileOrDirectoryPath = toPath3(fileOrDirectory); - if (cachedDirectoryStructureHost) { - cachedDirectoryStructureHost.addOrDeleteFileOrDirectory(fileOrDirectory, fileOrDirectoryPath); - } - nextSourceFileVersion(fileOrDirectoryPath); - const config = parsedConfigs == null ? void 0 : parsedConfigs.get(configPath); - if (!(config == null ? void 0 : config.parsedCommandLine)) - return; - if (isIgnoredFileFromWildCardWatching({ - watchedDirPath: toPath3(directory), - fileOrDirectory, - fileOrDirectoryPath, - configFileName: configFileName2, - options: config.parsedCommandLine.options, - program: config.parsedCommandLine.fileNames, - currentDirectory, - useCaseSensitiveFileNames, - writeLog, - toPath: toPath3 - })) - return; - if (config.reloadLevel !== 2 /* Full */) { - config.reloadLevel = 1 /* Partial */; - scheduleProgramUpdate(); - } - }, - flags, - ((_a2 = commandLine.parsedCommandLine) == null ? void 0 : _a2.watchOptions) || watchOptions, - WatchType.WildcardDirectoryOfReferencedProject - ); - } - ); - } else if (commandLine.watchedDirectories) { - clearMap(commandLine.watchedDirectories, closeFileWatcherOf); - commandLine.watchedDirectories = void 0; + onDeleteValue: closeFileWatcher } - updateExtendedConfigFilesWatches( - configPath, - (_d = commandLine.parsedCommandLine) == null ? void 0 : _d.options, - ((_e = commandLine.parsedCommandLine) == null ? void 0 : _e.watchOptions) || watchOptions, - WatchType.ExtendedConfigOfReferencedProject - ); - } + ); } - var init_watchPublic = __esm({ - "src/compiler/watchPublic.ts"() { - "use strict"; - init_ts2(); - } - }); - - // src/compiler/tsbuild.ts - function resolveConfigFileProjectName(project) { - if (fileExtensionIs(project, ".json" /* Json */)) { - return project; - } - return combinePaths(project, "tsconfig.json"); + function watchPackageJsonFiles(state, resolved, resolvedPath, parsed) { + if (!state.watch || !state.lastCachedPackageJsonLookups) + return; + mutateMap( + getOrCreateValueMapFromConfigFileMap(state.allWatchedPackageJsonFiles, resolvedPath), + new Map(state.lastCachedPackageJsonLookups.get(resolvedPath)), + { + createNewValue: (path, _input) => watchFile( + state, + path, + () => invalidateProjectAndScheduleBuilds(state, resolvedPath, 0 /* Update */), + 2e3 /* High */, + parsed == null ? void 0 : parsed.watchOptions, + WatchType.PackageJson, + resolved + ), + onDeleteValue: closeFileWatcher + } + ); } - var UpToDateStatusType; - var init_tsbuild = __esm({ - "src/compiler/tsbuild.ts"() { - "use strict"; - init_ts2(); - UpToDateStatusType = /* @__PURE__ */ ((UpToDateStatusType2) => { - UpToDateStatusType2[UpToDateStatusType2["Unbuildable"] = 0] = "Unbuildable"; - UpToDateStatusType2[UpToDateStatusType2["UpToDate"] = 1] = "UpToDate"; - UpToDateStatusType2[UpToDateStatusType2["UpToDateWithUpstreamTypes"] = 2] = "UpToDateWithUpstreamTypes"; - UpToDateStatusType2[UpToDateStatusType2["OutOfDateWithPrepend"] = 3] = "OutOfDateWithPrepend"; - UpToDateStatusType2[UpToDateStatusType2["OutputMissing"] = 4] = "OutputMissing"; - UpToDateStatusType2[UpToDateStatusType2["ErrorReadingFile"] = 5] = "ErrorReadingFile"; - UpToDateStatusType2[UpToDateStatusType2["OutOfDateWithSelf"] = 6] = "OutOfDateWithSelf"; - UpToDateStatusType2[UpToDateStatusType2["OutOfDateWithUpstream"] = 7] = "OutOfDateWithUpstream"; - UpToDateStatusType2[UpToDateStatusType2["OutOfDateBuildInfo"] = 8] = "OutOfDateBuildInfo"; - UpToDateStatusType2[UpToDateStatusType2["OutOfDateOptions"] = 9] = "OutOfDateOptions"; - UpToDateStatusType2[UpToDateStatusType2["OutOfDateRoots"] = 10] = "OutOfDateRoots"; - UpToDateStatusType2[UpToDateStatusType2["UpstreamOutOfDate"] = 11] = "UpstreamOutOfDate"; - UpToDateStatusType2[UpToDateStatusType2["UpstreamBlocked"] = 12] = "UpstreamBlocked"; - UpToDateStatusType2[UpToDateStatusType2["ComputingUpstream"] = 13] = "ComputingUpstream"; - UpToDateStatusType2[UpToDateStatusType2["TsVersionOutputOfDate"] = 14] = "TsVersionOutputOfDate"; - UpToDateStatusType2[UpToDateStatusType2["UpToDateWithInputFileText"] = 15] = "UpToDateWithInputFileText"; - UpToDateStatusType2[UpToDateStatusType2["ContainerOnly"] = 16] = "ContainerOnly"; - UpToDateStatusType2[UpToDateStatusType2["ForceBuild"] = 17] = "ForceBuild"; - return UpToDateStatusType2; - })(UpToDateStatusType || {}); - } - }); - - // src/compiler/tsbuildPublic.ts - function getOrCreateValueFromConfigFileMap(configFileMap, resolved, createT) { - const existingValue = configFileMap.get(resolved); - let newValue; - if (!existingValue) { - newValue = createT(); - configFileMap.set(resolved, newValue); + function startWatching(state, buildOrder) { + if (!state.watchAllProjectsPending) + return; + mark("SolutionBuilder::beforeWatcherCreation"); + state.watchAllProjectsPending = false; + for (const resolved of getBuildOrderFromAnyBuildOrder(buildOrder)) { + const resolvedPath = toResolvedConfigFilePath(state, resolved); + const cfg = parseConfigFile(state, resolved, resolvedPath); + watchConfigFile(state, resolved, resolvedPath, cfg); + watchExtendedConfigFiles(state, resolvedPath, cfg); + if (cfg) { + watchWildCardDirectories(state, resolved, resolvedPath, cfg); + watchInputFiles(state, resolved, resolvedPath, cfg); + watchPackageJsonFiles(state, resolved, resolvedPath, cfg); + } } - return existingValue || newValue; + mark("SolutionBuilder::afterWatcherCreation"); + measure("SolutionBuilder::Watcher creation", "SolutionBuilder::beforeWatcherCreation", "SolutionBuilder::afterWatcherCreation"); } - function getOrCreateValueMapFromConfigFileMap(configFileMap, resolved) { - return getOrCreateValueFromConfigFileMap(configFileMap, resolved, () => /* @__PURE__ */ new Map()); + function stopWatching(state) { + clearMap(state.allWatchedConfigFiles, closeFileWatcher); + clearMap(state.allWatchedExtendedConfigFiles, closeFileWatcherOf); + clearMap(state.allWatchedWildcardDirectories, (watchedWildcardDirectories) => clearMap(watchedWildcardDirectories, closeFileWatcherOf)); + clearMap(state.allWatchedInputFiles, (watchedWildcardDirectories) => clearMap(watchedWildcardDirectories, closeFileWatcher)); + clearMap(state.allWatchedPackageJsonFiles, (watchedPacageJsonFiles) => clearMap(watchedPacageJsonFiles, closeFileWatcher)); } - function getCurrentTime(host) { - return host.now ? host.now() : /* @__PURE__ */ new Date(); + function createSolutionBuilderWorker(watch, hostOrHostWithWatch, rootNames, options, baseWatchOptions) { + const state = createSolutionBuilderState(watch, hostOrHostWithWatch, rootNames, options, baseWatchOptions); + return { + build: (project, cancellationToken, writeFile2, getCustomTransformers) => build(state, project, cancellationToken, writeFile2, getCustomTransformers), + clean: (project) => clean(state, project), + buildReferences: (project, cancellationToken, writeFile2, getCustomTransformers) => build( + state, + project, + cancellationToken, + writeFile2, + getCustomTransformers, + /*onlyReferences*/ + true + ), + cleanReferences: (project) => clean( + state, + project, + /*onlyReferences*/ + true + ), + getNextInvalidatedProject: (cancellationToken) => { + setupInitialBuild(state, cancellationToken); + return getNextInvalidatedProject( + state, + getBuildOrder(state), + /*reportQueue*/ + false + ); + }, + getBuildOrder: () => getBuildOrder(state), + getUpToDateStatusOfProject: (project) => { + const configFileName = resolveProjectName(state, project); + const configFilePath = toResolvedConfigFilePath(state, configFileName); + return getUpToDateStatus(state, parseConfigFile(state, configFileName, configFilePath), configFilePath); + }, + invalidateProject: (configFilePath, updateLevel) => invalidateProject(state, configFilePath, updateLevel || 0 /* Update */), + close: () => stopWatching(state) + }; } - function isCircularBuildOrder(buildOrder) { - return !!buildOrder && !!buildOrder.buildOrder; + function relName(state, path) { + return convertToRelativePath(path, state.compilerHost.getCurrentDirectory(), state.compilerHost.getCanonicalFileName); } - function getBuildOrderFromAnyBuildOrder(anyBuildOrder) { - return isCircularBuildOrder(anyBuildOrder) ? anyBuildOrder.buildOrder : anyBuildOrder; + function reportStatus(state, message, ...args) { + state.host.reportSolutionBuilderStatus(createCompilerDiagnostic(message, ...args)); } - function createBuilderStatusReporter(system, pretty) { - return (diagnostic) => { - let output = pretty ? `[${formatColorAndReset(getLocaleTimeString(system), "\x1B[90m" /* Grey */)}] ` : `${getLocaleTimeString(system)} - `; - output += `${flattenDiagnosticMessageText(diagnostic.messageText, system.newLine)}${system.newLine + system.newLine}`; - system.write(output); - }; + function reportWatchStatus(state, message, ...args) { + var _a, _b; + (_b = (_a = state.hostWithWatch).onWatchStatusChange) == null ? void 0 : _b.call(_a, createCompilerDiagnostic(message, ...args), state.host.getNewLine(), state.baseCompilerOptions); } - function createSolutionBuilderHostBase(system, createProgram2, reportDiagnostic, reportSolutionBuilderStatus) { - const host = createProgramHost(system, createProgram2); - host.getModifiedTime = system.getModifiedTime ? (path) => system.getModifiedTime(path) : returnUndefined; - host.setModifiedTime = system.setModifiedTime ? (path, date) => system.setModifiedTime(path, date) : noop; - host.deleteFile = system.deleteFile ? (path) => system.deleteFile(path) : noop; - host.reportDiagnostic = reportDiagnostic || createDiagnosticReporter(system); - host.reportSolutionBuilderStatus = reportSolutionBuilderStatus || createBuilderStatusReporter(system); - host.now = maybeBind(system, system.now); - return host; + function reportErrors({ host }, errors) { + errors.forEach((err) => host.reportDiagnostic(err)); } - function createSolutionBuilderHost(system = sys, createProgram2, reportDiagnostic, reportSolutionBuilderStatus, reportErrorSummary2) { - const host = createSolutionBuilderHostBase(system, createProgram2, reportDiagnostic, reportSolutionBuilderStatus); - host.reportErrorSummary = reportErrorSummary2; - return host; + function reportAndStoreErrors(state, proj, errors) { + reportErrors(state, errors); + state.projectErrorsReported.set(proj, true); + if (errors.length) { + state.diagnostics.set(proj, errors); + } } - function createSolutionBuilderWithWatchHost(system = sys, createProgram2, reportDiagnostic, reportSolutionBuilderStatus, reportWatchStatus2) { - const host = createSolutionBuilderHostBase(system, createProgram2, reportDiagnostic, reportSolutionBuilderStatus); - const watchHost = createWatchHost(system, reportWatchStatus2); - copyProperties(host, watchHost); - return host; + function reportParseConfigFileDiagnostic(state, proj) { + reportAndStoreErrors(state, proj, [state.configFileCache.get(proj)]); } - function getCompilerOptionsOfBuildOptions(buildOptions) { - const result = {}; - commonOptionsWithBuild.forEach((option) => { - if (hasProperty(buildOptions, option.name)) - result[option.name] = buildOptions[option.name]; - }); - return result; + function reportErrorSummary(state, buildOrder) { + if (!state.needsSummary) + return; + state.needsSummary = false; + const canReportSummary = state.watch || !!state.host.reportErrorSummary; + const { diagnostics } = state; + let totalErrors = 0; + let filesInError = []; + if (isCircularBuildOrder(buildOrder)) { + reportBuildQueue(state, buildOrder.buildOrder); + reportErrors(state, buildOrder.circularDiagnostics); + if (canReportSummary) + totalErrors += getErrorCountForSummary(buildOrder.circularDiagnostics); + if (canReportSummary) + filesInError = [...filesInError, ...getFilesInErrorForSummary(buildOrder.circularDiagnostics)]; + } else { + buildOrder.forEach((project) => { + const projectPath = toResolvedConfigFilePath(state, project); + if (!state.projectErrorsReported.has(projectPath)) { + reportErrors(state, diagnostics.get(projectPath) || emptyArray); + } + }); + if (canReportSummary) + diagnostics.forEach((singleProjectErrors) => totalErrors += getErrorCountForSummary(singleProjectErrors)); + if (canReportSummary) + diagnostics.forEach((singleProjectErrors) => [...filesInError, ...getFilesInErrorForSummary(singleProjectErrors)]); + } + if (state.watch) { + reportWatchStatus(state, getWatchErrorSummaryDiagnosticMessage(totalErrors), totalErrors); + } else if (state.host.reportErrorSummary) { + state.host.reportErrorSummary(totalErrors, filesInError); + } } - function createSolutionBuilder(host, rootNames, defaultOptions) { - return createSolutionBuilderWorker( - /*watch*/ - false, - host, - rootNames, - defaultOptions - ); + function reportBuildQueue(state, buildQueue) { + if (state.options.verbose) { + reportStatus(state, Diagnostics.Projects_in_this_build_Colon_0, buildQueue.map((s) => "\r\n * " + relName(state, s)).join("")); + } } - function createSolutionBuilderWithWatch(host, rootNames, defaultOptions, baseWatchOptions) { - return createSolutionBuilderWorker( - /*watch*/ - true, - host, - rootNames, - defaultOptions, - baseWatchOptions - ); + function reportUpToDateStatus(state, configFileName, status) { + switch (status.type) { + case 6 /* OutOfDateWithSelf */: + return reportStatus( + state, + Diagnostics.Project_0_is_out_of_date_because_output_1_is_older_than_input_2, + relName(state, configFileName), + relName(state, status.outOfDateOutputFileName), + relName(state, status.newerInputFileName) + ); + case 7 /* OutOfDateWithUpstream */: + return reportStatus( + state, + Diagnostics.Project_0_is_out_of_date_because_output_1_is_older_than_input_2, + relName(state, configFileName), + relName(state, status.outOfDateOutputFileName), + relName(state, status.newerProjectName) + ); + case 4 /* OutputMissing */: + return reportStatus( + state, + Diagnostics.Project_0_is_out_of_date_because_output_file_1_does_not_exist, + relName(state, configFileName), + relName(state, status.missingOutputFileName) + ); + case 5 /* ErrorReadingFile */: + return reportStatus( + state, + Diagnostics.Project_0_is_out_of_date_because_there_was_error_reading_file_1, + relName(state, configFileName), + relName(state, status.fileName) + ); + case 8 /* OutOfDateBuildInfo */: + return reportStatus( + state, + Diagnostics.Project_0_is_out_of_date_because_buildinfo_file_1_indicates_that_some_of_the_changes_were_not_emitted, + relName(state, configFileName), + relName(state, status.buildInfoFile) + ); + case 9 /* OutOfDateOptions */: + return reportStatus( + state, + Diagnostics.Project_0_is_out_of_date_because_buildinfo_file_1_indicates_there_is_change_in_compilerOptions, + relName(state, configFileName), + relName(state, status.buildInfoFile) + ); + case 10 /* OutOfDateRoots */: + return reportStatus( + state, + Diagnostics.Project_0_is_out_of_date_because_buildinfo_file_1_indicates_that_file_2_was_root_file_of_compilation_but_not_any_more, + relName(state, configFileName), + relName(state, status.buildInfoFile), + relName(state, status.inputFile) + ); + case 1 /* UpToDate */: + if (status.newestInputFileTime !== void 0) { + return reportStatus( + state, + Diagnostics.Project_0_is_up_to_date_because_newest_input_1_is_older_than_output_2, + relName(state, configFileName), + relName(state, status.newestInputFileName || ""), + relName(state, status.oldestOutputFileName || "") + ); + } + break; + case 3 /* OutOfDateWithPrepend */: + return reportStatus( + state, + Diagnostics.Project_0_is_out_of_date_because_output_of_its_dependency_1_has_changed, + relName(state, configFileName), + relName(state, status.newerProjectName) + ); + case 2 /* UpToDateWithUpstreamTypes */: + return reportStatus( + state, + Diagnostics.Project_0_is_up_to_date_with_d_ts_files_from_its_dependencies, + relName(state, configFileName) + ); + case 15 /* UpToDateWithInputFileText */: + return reportStatus( + state, + Diagnostics.Project_0_is_up_to_date_but_needs_to_update_timestamps_of_output_files_that_are_older_than_input_files, + relName(state, configFileName) + ); + case 11 /* UpstreamOutOfDate */: + return reportStatus( + state, + Diagnostics.Project_0_is_out_of_date_because_its_dependency_1_is_out_of_date, + relName(state, configFileName), + relName(state, status.upstreamProjectName) + ); + case 12 /* UpstreamBlocked */: + return reportStatus( + state, + status.upstreamProjectBlocked ? Diagnostics.Project_0_can_t_be_built_because_its_dependency_1_was_not_built : Diagnostics.Project_0_can_t_be_built_because_its_dependency_1_has_errors, + relName(state, configFileName), + relName(state, status.upstreamProjectName) + ); + case 0 /* Unbuildable */: + return reportStatus( + state, + Diagnostics.Failed_to_parse_file_0_Colon_1, + relName(state, configFileName), + status.reason + ); + case 14 /* TsVersionOutputOfDate */: + return reportStatus( + state, + Diagnostics.Project_0_is_out_of_date_because_output_for_it_was_generated_with_version_1_that_differs_with_current_version_2, + relName(state, configFileName), + status.version, + version + ); + case 17 /* ForceBuild */: + return reportStatus( + state, + Diagnostics.Project_0_is_being_forcibly_rebuilt, + relName(state, configFileName) + ); + case 16 /* ContainerOnly */: + case 13 /* ComputingUpstream */: + break; + default: + assertType(status); + } } - function createSolutionBuilderState(watch, hostOrHostWithWatch, rootNames, options, baseWatchOptions) { - const host = hostOrHostWithWatch; - const hostWithWatch = hostOrHostWithWatch; - const baseCompilerOptions = getCompilerOptionsOfBuildOptions(options); - const compilerHost = createCompilerHostFromProgramHost(host, () => state.projectCompilerOptions); - setGetSourceFileAsHashVersioned(compilerHost); - compilerHost.getParsedCommandLine = (fileName) => parseConfigFile(state, fileName, toResolvedConfigFilePath(state, fileName)); - compilerHost.resolveModuleNameLiterals = maybeBind(host, host.resolveModuleNameLiterals); - compilerHost.resolveTypeReferenceDirectiveReferences = maybeBind(host, host.resolveTypeReferenceDirectiveReferences); - compilerHost.resolveLibrary = maybeBind(host, host.resolveLibrary); - compilerHost.resolveModuleNames = maybeBind(host, host.resolveModuleNames); - compilerHost.resolveTypeReferenceDirectives = maybeBind(host, host.resolveTypeReferenceDirectives); - compilerHost.getModuleResolutionCache = maybeBind(host, host.getModuleResolutionCache); - let moduleResolutionCache, typeReferenceDirectiveResolutionCache; - if (!compilerHost.resolveModuleNameLiterals && !compilerHost.resolveModuleNames) { - moduleResolutionCache = createModuleResolutionCache(compilerHost.getCurrentDirectory(), compilerHost.getCanonicalFileName); - compilerHost.resolveModuleNameLiterals = (moduleNames, containingFile, redirectedReference, options2, containingSourceFile) => loadWithModeAwareCache( - moduleNames, - containingFile, - redirectedReference, - options2, - containingSourceFile, - host, - moduleResolutionCache, - createModuleResolutionLoader - ); - compilerHost.getModuleResolutionCache = () => moduleResolutionCache; + function verboseReportProjectStatus(state, configFileName, status) { + if (state.options.verbose) { + reportUpToDateStatus(state, configFileName, status); } - if (!compilerHost.resolveTypeReferenceDirectiveReferences && !compilerHost.resolveTypeReferenceDirectives) { - typeReferenceDirectiveResolutionCache = createTypeReferenceDirectiveResolutionCache( - compilerHost.getCurrentDirectory(), - compilerHost.getCanonicalFileName, - /*options*/ - void 0, - moduleResolutionCache == null ? void 0 : moduleResolutionCache.getPackageJsonInfoCache() - ); - compilerHost.resolveTypeReferenceDirectiveReferences = (typeDirectiveNames, containingFile, redirectedReference, options2, containingSourceFile) => loadWithModeAwareCache( - typeDirectiveNames, - containingFile, - redirectedReference, - options2, - containingSourceFile, - host, - typeReferenceDirectiveResolutionCache, - createTypeReferenceResolutionLoader - ); + } + var minimumDate, maximumDate, InvalidatedProjectKind; + var init_tsbuildPublic = __esm({ + "src/compiler/tsbuildPublic.ts"() { + "use strict"; + init_ts2(); + init_ts_performance(); + minimumDate = /* @__PURE__ */ new Date(-864e13); + maximumDate = /* @__PURE__ */ new Date(864e13); + InvalidatedProjectKind = /* @__PURE__ */ ((InvalidatedProjectKind2) => { + InvalidatedProjectKind2[InvalidatedProjectKind2["Build"] = 0] = "Build"; + InvalidatedProjectKind2[InvalidatedProjectKind2["UpdateBundle"] = 1] = "UpdateBundle"; + InvalidatedProjectKind2[InvalidatedProjectKind2["UpdateOutputFileStamps"] = 2] = "UpdateOutputFileStamps"; + return InvalidatedProjectKind2; + })(InvalidatedProjectKind || {}); } - let libraryResolutionCache; - if (!compilerHost.resolveLibrary) { - libraryResolutionCache = createModuleResolutionCache( - compilerHost.getCurrentDirectory(), - compilerHost.getCanonicalFileName, - /*options*/ - void 0, - moduleResolutionCache == null ? void 0 : moduleResolutionCache.getPackageJsonInfoCache() - ); - compilerHost.resolveLibrary = (libraryName, resolveFrom, options2) => resolveLibrary( - libraryName, - resolveFrom, - options2, - host, - libraryResolutionCache - ); + }); + + // src/compiler/_namespaces/ts.ts + var init_ts2 = __esm({ + "src/compiler/_namespaces/ts.ts"() { + "use strict"; + init_corePublic(); + init_core(); + init_debug(); + init_semver(); + init_performanceCore(); + init_perfLogger(); + init_tracing(); + init_types(); + init_sys(); + init_path(); + init_diagnosticInformationMap_generated(); + init_scanner(); + init_utilitiesPublic(); + init_utilities(); + init_baseNodeFactory(); + init_parenthesizerRules(); + init_nodeConverters(); + init_nodeFactory(); + init_emitNode(); + init_emitHelpers(); + init_nodeTests(); + init_utilities2(); + init_utilitiesPublic2(); + init_parser(); + init_commandLineParser(); + init_moduleNameResolver(); + init_binder(); + init_symbolWalker(); + init_checker(); + init_visitorPublic(); + init_sourcemap(); + init_utilities3(); + init_destructuring(); + init_classThis(); + init_namedEvaluation(); + init_taggedTemplate(); + init_ts(); + init_classFields(); + init_typeSerializer(); + init_legacyDecorators(); + init_esDecorators(); + init_es2017(); + init_es2018(); + init_es2019(); + init_es2020(); + init_es2021(); + init_esnext(); + init_jsx(); + init_es2016(); + init_es2015(); + init_es5(); + init_generators(); + init_module(); + init_system(); + init_esnextAnd2015(); + init_node(); + init_diagnostics(); + init_declarations(); + init_transformer(); + init_emitter(); + init_watchUtilities(); + init_program(); + init_builderStatePublic(); + init_builderState(); + init_builder(); + init_builderPublic(); + init_resolutionCache(); + init_watch(); + init_watchPublic(); + init_tsbuild(); + init_tsbuildPublic(); + init_ts_moduleSpecifiers(); + init_ts_performance(); } - compilerHost.getBuildInfo = (fileName, configFilePath) => getBuildInfo3( - state, - fileName, - toResolvedConfigFilePath(state, configFilePath), - /*modifiedTime*/ - void 0 - ); - const { watchFile: watchFile2, watchDirectory, writeLog } = createWatchFactory(hostWithWatch, options); - const state = { - host, - hostWithWatch, - parseConfigFileHost: parseConfigHostFromCompilerHostLike(host), - write: maybeBind(host, host.trace), - // State of solution - options, - baseCompilerOptions, - rootNames, - baseWatchOptions, - resolvedConfigFilePaths: /* @__PURE__ */ new Map(), - configFileCache: /* @__PURE__ */ new Map(), - projectStatus: /* @__PURE__ */ new Map(), - extendedConfigCache: /* @__PURE__ */ new Map(), - buildInfoCache: /* @__PURE__ */ new Map(), - outputTimeStamps: /* @__PURE__ */ new Map(), - builderPrograms: /* @__PURE__ */ new Map(), - diagnostics: /* @__PURE__ */ new Map(), - projectPendingBuild: /* @__PURE__ */ new Map(), - projectErrorsReported: /* @__PURE__ */ new Map(), - compilerHost, - moduleResolutionCache, - typeReferenceDirectiveResolutionCache, - libraryResolutionCache, - // Mutable state - buildOrder: void 0, - readFileWithCache: (f) => host.readFile(f), - projectCompilerOptions: baseCompilerOptions, - cache: void 0, - allProjectBuildPending: true, - needsSummary: true, - watchAllProjectsPending: watch, - // Watch state - watch, - allWatchedWildcardDirectories: /* @__PURE__ */ new Map(), - allWatchedInputFiles: /* @__PURE__ */ new Map(), - allWatchedConfigFiles: /* @__PURE__ */ new Map(), - allWatchedExtendedConfigFiles: /* @__PURE__ */ new Map(), - allWatchedPackageJsonFiles: /* @__PURE__ */ new Map(), - filesWatched: /* @__PURE__ */ new Map(), - lastCachedPackageJsonLookups: /* @__PURE__ */ new Map(), - timerToBuildInvalidatedProject: void 0, - reportFileChangeDetected: false, - watchFile: watchFile2, - watchDirectory, - writeLog - }; - return state; + }); + + // src/jsTyping/shared.ts + function hasArgument(argumentName) { + return sys.args.includes(argumentName); } - function toPath2(state, fileName) { - return toPath(fileName, state.compilerHost.getCurrentDirectory(), state.compilerHost.getCanonicalFileName); + function findArgument(argumentName) { + const index = sys.args.indexOf(argumentName); + return index >= 0 && index < sys.args.length - 1 ? sys.args[index + 1] : void 0; } - function toResolvedConfigFilePath(state, fileName) { - const { resolvedConfigFilePaths } = state; - const path = resolvedConfigFilePaths.get(fileName); - if (path !== void 0) - return path; - const resolvedPath = toPath2(state, fileName); - resolvedConfigFilePaths.set(fileName, resolvedPath); - return resolvedPath; + function nowString() { + const d = /* @__PURE__ */ new Date(); + return `${d.getHours().toString().padStart(2, "0")}:${d.getMinutes().toString().padStart(2, "0")}:${d.getSeconds().toString().padStart(2, "0")}.${d.getMilliseconds().toString().padStart(3, "0")}`; } - function isParsedCommandLine(entry) { - return !!entry.options; + function indent2(str) { + return indentStr + str.replace(/\n/g, indentStr); } - function getCachedParsedConfigFile(state, configFilePath) { - const value = state.configFileCache.get(configFilePath); - return value && isParsedCommandLine(value) ? value : void 0; + function stringifyIndented(json) { + return indent2(JSON.stringify(json, void 0, 2)); } - function parseConfigFile(state, configFileName, configFilePath) { - const { configFileCache } = state; - const value = configFileCache.get(configFilePath); - if (value) { - return isParsedCommandLine(value) ? value : void 0; + var ActionSet, ActionInvalidate, ActionPackageInstalled, EventTypesRegistry, EventBeginInstallTypes, EventEndInstallTypes, EventInitializationFailed, ActionWatchTypingLocations, Arguments, indentStr; + var init_shared = __esm({ + "src/jsTyping/shared.ts"() { + "use strict"; + init_ts3(); + ActionSet = "action::set"; + ActionInvalidate = "action::invalidate"; + ActionPackageInstalled = "action::packageInstalled"; + EventTypesRegistry = "event::typesRegistry"; + EventBeginInstallTypes = "event::beginInstallTypes"; + EventEndInstallTypes = "event::endInstallTypes"; + EventInitializationFailed = "event::initializationFailed"; + ActionWatchTypingLocations = "action::watchTypingLocations"; + ((Arguments2) => { + Arguments2.GlobalCacheLocation = "--globalTypingsCacheLocation"; + Arguments2.LogFile = "--logFile"; + Arguments2.EnableTelemetry = "--enableTelemetry"; + Arguments2.TypingSafeListLocation = "--typingSafeListLocation"; + Arguments2.TypesMapLocation = "--typesMapLocation"; + Arguments2.NpmLocation = "--npmLocation"; + Arguments2.ValidateDefaultNpmLocation = "--validateDefaultNpmLocation"; + })(Arguments || (Arguments = {})); + indentStr = "\n "; } - mark("SolutionBuilder::beforeConfigFileParsing"); - let diagnostic; - const { parseConfigFileHost, baseCompilerOptions, baseWatchOptions, extendedConfigCache, host } = state; - let parsed; - if (host.getParsedCommandLine) { - parsed = host.getParsedCommandLine(configFileName); - if (!parsed) - diagnostic = createCompilerDiagnostic(Diagnostics.File_0_not_found, configFileName); - } else { - parseConfigFileHost.onUnRecoverableConfigFileDiagnostic = (d) => diagnostic = d; - parsed = getParsedCommandLineOfConfigFile(configFileName, baseCompilerOptions, parseConfigFileHost, extendedConfigCache, baseWatchOptions); - parseConfigFileHost.onUnRecoverableConfigFileDiagnostic = noop; + }); + + // src/jsTyping/types.ts + var init_types2 = __esm({ + "src/jsTyping/types.ts"() { + "use strict"; } - configFileCache.set(configFilePath, parsed || diagnostic); - mark("SolutionBuilder::afterConfigFileParsing"); - measure("SolutionBuilder::Config file parsing", "SolutionBuilder::beforeConfigFileParsing", "SolutionBuilder::afterConfigFileParsing"); - return parsed; + }); + + // src/jsTyping/_namespaces/ts.server.ts + var init_ts_server = __esm({ + "src/jsTyping/_namespaces/ts.server.ts"() { + "use strict"; + init_shared(); + init_types2(); + } + }); + + // src/jsTyping/jsTyping.ts + function isTypingUpToDate(cachedTyping, availableTypingVersions) { + const availableVersion = new Version(getProperty(availableTypingVersions, `ts${versionMajorMinor}`) || getProperty(availableTypingVersions, "latest")); + return availableVersion.compareTo(cachedTyping.version) <= 0; } - function resolveProjectName(state, name) { - return resolveConfigFileProjectName(resolvePath(state.compilerHost.getCurrentDirectory(), name)); + function nonRelativeModuleNameForTypingCache(moduleName) { + return nodeCoreModules.has(moduleName) ? "node" : moduleName; } - function createBuildOrder(state, roots) { - const temporaryMarks = /* @__PURE__ */ new Map(); - const permanentMarks = /* @__PURE__ */ new Map(); - const circularityReportStack = []; - let buildOrder; - let circularDiagnostics; - for (const root of roots) { - visit(root); + function loadSafeList(host, safeListPath) { + const result = readConfigFile(safeListPath, (path) => host.readFile(path)); + return new Map(Object.entries(result.config)); + } + function loadTypesMap(host, typesMapPath) { + var _a; + const result = readConfigFile(typesMapPath, (path) => host.readFile(path)); + if ((_a = result.config) == null ? void 0 : _a.simpleMap) { + return new Map(Object.entries(result.config.simpleMap)); } - return circularDiagnostics ? { buildOrder: buildOrder || emptyArray, circularDiagnostics } : buildOrder || emptyArray; - function visit(configFileName, inCircularContext) { - const projPath = toResolvedConfigFilePath(state, configFileName); - if (permanentMarks.has(projPath)) - return; - if (temporaryMarks.has(projPath)) { - if (!inCircularContext) { - (circularDiagnostics || (circularDiagnostics = [])).push( - createCompilerDiagnostic( - Diagnostics.Project_references_may_not_form_a_circular_graph_Cycle_detected_Colon_0, - circularityReportStack.join("\r\n") - ) - ); - } + return void 0; + } + function discoverTypings(host, log, fileNames, projectRootPath, safeList, packageNameToTypingLocation, typeAcquisition, unresolvedImports, typesRegistry, compilerOptions) { + if (!typeAcquisition || !typeAcquisition.enable) { + return { cachedTypingPaths: [], newTypingNames: [], filesToWatch: [] }; + } + const inferredTypings = /* @__PURE__ */ new Map(); + fileNames = mapDefined(fileNames, (fileName) => { + const path = normalizePath(fileName); + if (hasJSFileExtension(path)) { + return path; + } + }); + const filesToWatch = []; + if (typeAcquisition.include) + addInferredTypings(typeAcquisition.include, "Explicitly included types"); + const exclude = typeAcquisition.exclude || []; + if (!compilerOptions.types) { + const possibleSearchDirs = new Set(fileNames.map(getDirectoryPath)); + possibleSearchDirs.add(projectRootPath); + possibleSearchDirs.forEach((searchDir) => { + getTypingNames(searchDir, "bower.json", "bower_components", filesToWatch); + getTypingNames(searchDir, "package.json", "node_modules", filesToWatch); + }); + } + if (!typeAcquisition.disableFilenameBasedTypeAcquisition) { + getTypingNamesFromSourceFileNames(fileNames); + } + if (unresolvedImports) { + const module2 = deduplicate( + unresolvedImports.map(nonRelativeModuleNameForTypingCache), + equateStringsCaseSensitive, + compareStringsCaseSensitive + ); + addInferredTypings(module2, "Inferred typings from unresolved imports"); + } + for (const excludeTypingName of exclude) { + const didDelete = inferredTypings.delete(excludeTypingName); + if (didDelete && log) + log(`Typing for ${excludeTypingName} is in exclude list, will be ignored.`); + } + packageNameToTypingLocation.forEach((typing, name) => { + const registryEntry = typesRegistry.get(name); + if (inferredTypings.get(name) === false && registryEntry !== void 0 && isTypingUpToDate(typing, registryEntry)) { + inferredTypings.set(name, typing.typingLocation); + } + }); + const newTypingNames = []; + const cachedTypingPaths = []; + inferredTypings.forEach((inferred, typing) => { + if (inferred) { + cachedTypingPaths.push(inferred); + } else { + newTypingNames.push(typing); + } + }); + const result = { cachedTypingPaths, newTypingNames, filesToWatch }; + if (log) + log(`Finished typings discovery:${stringifyIndented(result)}`); + return result; + function addInferredTyping(typingName) { + if (!inferredTypings.has(typingName)) { + inferredTypings.set(typingName, false); + } + } + function addInferredTypings(typingNames, message) { + if (log) + log(`${message}: ${JSON.stringify(typingNames)}`); + forEach(typingNames, addInferredTyping); + } + function getTypingNames(projectRootPath2, manifestName, modulesDirName, filesToWatch2) { + const manifestPath = combinePaths(projectRootPath2, manifestName); + let manifest; + let manifestTypingNames; + if (host.fileExists(manifestPath)) { + filesToWatch2.push(manifestPath); + manifest = readConfigFile(manifestPath, (path) => host.readFile(path)).config; + manifestTypingNames = flatMap([manifest.dependencies, manifest.devDependencies, manifest.optionalDependencies, manifest.peerDependencies], getOwnKeys); + addInferredTypings(manifestTypingNames, `Typing names in '${manifestPath}' dependencies`); + } + const packagesFolderPath = combinePaths(projectRootPath2, modulesDirName); + filesToWatch2.push(packagesFolderPath); + if (!host.directoryExists(packagesFolderPath)) { return; } - temporaryMarks.set(projPath, true); - circularityReportStack.push(configFileName); - const parsed = parseConfigFile(state, configFileName, projPath); - if (parsed && parsed.projectReferences) { - for (const ref of parsed.projectReferences) { - const resolvedRefPath = resolveProjectName(state, ref.path); - visit(resolvedRefPath, inCircularContext || ref.circular); + const packageNames = []; + const dependencyManifestNames = manifestTypingNames ? manifestTypingNames.map((typingName) => combinePaths(packagesFolderPath, typingName, manifestName)) : host.readDirectory( + packagesFolderPath, + [".json" /* Json */], + /*excludes*/ + void 0, + /*includes*/ + void 0, + /*depth*/ + 3 + ).filter((manifestPath2) => { + if (getBaseFileName(manifestPath2) !== manifestName) { + return false; + } + const pathComponents2 = getPathComponents(normalizePath(manifestPath2)); + const isScoped = pathComponents2[pathComponents2.length - 3][0] === "@"; + return isScoped && toFileNameLowerCase(pathComponents2[pathComponents2.length - 4]) === modulesDirName || // `node_modules/@foo/bar` + !isScoped && toFileNameLowerCase(pathComponents2[pathComponents2.length - 3]) === modulesDirName; + }); + if (log) + log(`Searching for typing names in ${packagesFolderPath}; all files: ${JSON.stringify(dependencyManifestNames)}`); + for (const manifestPath2 of dependencyManifestNames) { + const normalizedFileName = normalizePath(manifestPath2); + const result2 = readConfigFile(normalizedFileName, (path) => host.readFile(path)); + const manifest2 = result2.config; + if (!manifest2.name) { + continue; + } + const ownTypes = manifest2.types || manifest2.typings; + if (ownTypes) { + const absolutePath = getNormalizedAbsolutePath(ownTypes, getDirectoryPath(normalizedFileName)); + if (host.fileExists(absolutePath)) { + if (log) + log(` Package '${manifest2.name}' provides its own types.`); + inferredTypings.set(manifest2.name, absolutePath); + } else { + if (log) + log(` Package '${manifest2.name}' provides its own types but they are missing.`); + } + } else { + packageNames.push(manifest2.name); } } - circularityReportStack.pop(); - permanentMarks.set(projPath, true); - (buildOrder || (buildOrder = [])).push(configFileName); + addInferredTypings(packageNames, " Found package names"); } - } - function getBuildOrder(state) { - return state.buildOrder || createStateBuildOrder(state); - } - function createStateBuildOrder(state) { - const buildOrder = createBuildOrder(state, state.rootNames.map((f) => resolveProjectName(state, f))); - state.resolvedConfigFilePaths.clear(); - const currentProjects = new Map( - getBuildOrderFromAnyBuildOrder(buildOrder).map( - (resolved) => [toResolvedConfigFilePath(state, resolved), true] - ) - ); - const noopOnDelete = { onDeleteValue: noop }; - mutateMapSkippingNewValues(state.configFileCache, currentProjects, noopOnDelete); - mutateMapSkippingNewValues(state.projectStatus, currentProjects, noopOnDelete); - mutateMapSkippingNewValues(state.builderPrograms, currentProjects, noopOnDelete); - mutateMapSkippingNewValues(state.diagnostics, currentProjects, noopOnDelete); - mutateMapSkippingNewValues(state.projectPendingBuild, currentProjects, noopOnDelete); - mutateMapSkippingNewValues(state.projectErrorsReported, currentProjects, noopOnDelete); - mutateMapSkippingNewValues(state.buildInfoCache, currentProjects, noopOnDelete); - mutateMapSkippingNewValues(state.outputTimeStamps, currentProjects, noopOnDelete); - if (state.watch) { - mutateMapSkippingNewValues( - state.allWatchedConfigFiles, - currentProjects, - { onDeleteValue: closeFileWatcher } - ); - state.allWatchedExtendedConfigFiles.forEach((watcher) => { - watcher.projects.forEach((project) => { - if (!currentProjects.has(project)) { - watcher.projects.delete(project); - } - }); - watcher.close(); + function getTypingNamesFromSourceFileNames(fileNames2) { + const fromFileNames = mapDefined(fileNames2, (j) => { + if (!hasJSFileExtension(j)) + return void 0; + const inferredTypingName = removeFileExtension(toFileNameLowerCase(getBaseFileName(j))); + const cleanedTypingName = removeMinAndVersionNumbers(inferredTypingName); + return safeList.get(cleanedTypingName); }); - mutateMapSkippingNewValues( - state.allWatchedWildcardDirectories, - currentProjects, - { onDeleteValue: (existingMap) => existingMap.forEach(closeFileWatcherOf) } - ); - mutateMapSkippingNewValues( - state.allWatchedInputFiles, - currentProjects, - { onDeleteValue: (existingMap) => existingMap.forEach(closeFileWatcher) } - ); - mutateMapSkippingNewValues( - state.allWatchedPackageJsonFiles, - currentProjects, - { onDeleteValue: (existingMap) => existingMap.forEach(closeFileWatcher) } - ); - } - return state.buildOrder = buildOrder; - } - function getBuildOrderFor(state, project, onlyReferences) { - const resolvedProject = project && resolveProjectName(state, project); - const buildOrderFromState = getBuildOrder(state); - if (isCircularBuildOrder(buildOrderFromState)) - return buildOrderFromState; - if (resolvedProject) { - const projectPath = toResolvedConfigFilePath(state, resolvedProject); - const projectIndex = findIndex( - buildOrderFromState, - (configFileName) => toResolvedConfigFilePath(state, configFileName) === projectPath - ); - if (projectIndex === -1) - return void 0; + if (fromFileNames.length) { + addInferredTypings(fromFileNames, "Inferred typings from file names"); + } + const hasJsxFile = some(fileNames2, (f) => fileExtensionIs(f, ".jsx" /* Jsx */)); + if (hasJsxFile) { + if (log) + log(`Inferred 'react' typings due to presence of '.jsx' extension`); + addInferredTyping("react"); + } } - const buildOrder = resolvedProject ? createBuildOrder(state, [resolvedProject]) : buildOrderFromState; - Debug.assert(!isCircularBuildOrder(buildOrder)); - Debug.assert(!onlyReferences || resolvedProject !== void 0); - Debug.assert(!onlyReferences || buildOrder[buildOrder.length - 1] === resolvedProject); - return onlyReferences ? buildOrder.slice(0, buildOrder.length - 1) : buildOrder; } - function enableCache(state) { - if (state.cache) { - disableCache(state); - } - const { compilerHost, host } = state; - const originalReadFileWithCache = state.readFileWithCache; - const originalGetSourceFile = compilerHost.getSourceFile; - const { - originalReadFile, - originalFileExists, - originalDirectoryExists, - originalCreateDirectory, - originalWriteFile, - getSourceFileWithCache, - readFileWithCache - } = changeCompilerHostLikeToUseCache( - host, - (fileName) => toPath2(state, fileName), - (...args) => originalGetSourceFile.call(compilerHost, ...args) + function validatePackageName(packageName) { + return validatePackageNameWorker( + packageName, + /*supportScopedPackage*/ + true ); - state.readFileWithCache = readFileWithCache; - compilerHost.getSourceFile = getSourceFileWithCache; - state.cache = { - originalReadFile, - originalFileExists, - originalDirectoryExists, - originalCreateDirectory, - originalWriteFile, - originalReadFileWithCache, - originalGetSourceFile - }; - } - function disableCache(state) { - if (!state.cache) - return; - const { cache, host, compilerHost, extendedConfigCache, moduleResolutionCache, typeReferenceDirectiveResolutionCache, libraryResolutionCache } = state; - host.readFile = cache.originalReadFile; - host.fileExists = cache.originalFileExists; - host.directoryExists = cache.originalDirectoryExists; - host.createDirectory = cache.originalCreateDirectory; - host.writeFile = cache.originalWriteFile; - compilerHost.getSourceFile = cache.originalGetSourceFile; - state.readFileWithCache = cache.originalReadFileWithCache; - extendedConfigCache.clear(); - moduleResolutionCache == null ? void 0 : moduleResolutionCache.clear(); - typeReferenceDirectiveResolutionCache == null ? void 0 : typeReferenceDirectiveResolutionCache.clear(); - libraryResolutionCache == null ? void 0 : libraryResolutionCache.clear(); - state.cache = void 0; - } - function clearProjectStatus(state, resolved) { - state.projectStatus.delete(resolved); - state.diagnostics.delete(resolved); } - function addProjToQueue({ projectPendingBuild }, proj, reloadLevel) { - const value = projectPendingBuild.get(proj); - if (value === void 0) { - projectPendingBuild.set(proj, reloadLevel); - } else if (value < reloadLevel) { - projectPendingBuild.set(proj, reloadLevel); + function validatePackageNameWorker(packageName, supportScopedPackage) { + if (!packageName) { + return 1 /* EmptyName */; + } + if (packageName.length > maxPackageNameLength) { + return 2 /* NameTooLong */; + } + if (packageName.charCodeAt(0) === 46 /* dot */) { + return 3 /* NameStartsWithDot */; + } + if (packageName.charCodeAt(0) === 95 /* _ */) { + return 4 /* NameStartsWithUnderscore */; } + if (supportScopedPackage) { + const matches = /^@([^/]+)\/([^/]+)$/.exec(packageName); + if (matches) { + const scopeResult = validatePackageNameWorker( + matches[1], + /*supportScopedPackage*/ + false + ); + if (scopeResult !== 0 /* Ok */) { + return { name: matches[1], isScopeName: true, result: scopeResult }; + } + const packageResult = validatePackageNameWorker( + matches[2], + /*supportScopedPackage*/ + false + ); + if (packageResult !== 0 /* Ok */) { + return { name: matches[2], isScopeName: false, result: packageResult }; + } + return 0 /* Ok */; + } + } + if (encodeURIComponent(packageName) !== packageName) { + return 5 /* NameContainsNonURISafeCharacters */; + } + return 0 /* Ok */; } - function setupInitialBuild(state, cancellationToken) { - if (!state.allProjectBuildPending) - return; - state.allProjectBuildPending = false; - if (state.options.watch) - reportWatchStatus(state, Diagnostics.Starting_compilation_in_watch_mode); - enableCache(state); - const buildOrder = getBuildOrderFromAnyBuildOrder(getBuildOrder(state)); - buildOrder.forEach( - (configFileName) => state.projectPendingBuild.set( - toResolvedConfigFilePath(state, configFileName), - 0 /* None */ - ) + function renderPackageNameValidationFailure(result, typing) { + return typeof result === "object" ? renderPackageNameValidationFailureWorker(typing, result.result, result.name, result.isScopeName) : renderPackageNameValidationFailureWorker( + typing, + result, + typing, + /*isScopeName*/ + false ); - if (cancellationToken) { - cancellationToken.throwIfCancellationRequested(); - } } - function doneInvalidatedProject(state, projectPath) { - state.projectPendingBuild.delete(projectPath); - return state.diagnostics.has(projectPath) ? 1 /* DiagnosticsPresent_OutputsSkipped */ : 0 /* Success */; + function renderPackageNameValidationFailureWorker(typing, result, name, isScopeName) { + const kind = isScopeName ? "Scope" : "Package"; + switch (result) { + case 1 /* EmptyName */: + return `'${typing}':: ${kind} name '${name}' cannot be empty`; + case 2 /* NameTooLong */: + return `'${typing}':: ${kind} name '${name}' should be less than ${maxPackageNameLength} characters`; + case 3 /* NameStartsWithDot */: + return `'${typing}':: ${kind} name '${name}' cannot start with '.'`; + case 4 /* NameStartsWithUnderscore */: + return `'${typing}':: ${kind} name '${name}' cannot start with '_'`; + case 5 /* NameContainsNonURISafeCharacters */: + return `'${typing}':: ${kind} name '${name}' contains non URI safe characters`; + case 0 /* Ok */: + return Debug.fail(); + default: + Debug.assertNever(result); + } } - function createUpdateOutputFileStampsProject(state, project, projectPath, config, buildOrder) { - let updateOutputFileStampsPending = true; + var unprefixedNodeCoreModuleList, prefixedNodeCoreModuleList, nodeCoreModuleList, nodeCoreModules, NameValidationResult, maxPackageNameLength; + var init_jsTyping = __esm({ + "src/jsTyping/jsTyping.ts"() { + "use strict"; + init_ts3(); + init_ts_server(); + unprefixedNodeCoreModuleList = [ + "assert", + "assert/strict", + "async_hooks", + "buffer", + "child_process", + "cluster", + "console", + "constants", + "crypto", + "dgram", + "diagnostics_channel", + "dns", + "dns/promises", + "domain", + "events", + "fs", + "fs/promises", + "http", + "https", + "http2", + "inspector", + "module", + "net", + "os", + "path", + "perf_hooks", + "process", + "punycode", + "querystring", + "readline", + "repl", + "stream", + "stream/promises", + "string_decoder", + "timers", + "timers/promises", + "tls", + "trace_events", + "tty", + "url", + "util", + "util/types", + "v8", + "vm", + "wasi", + "worker_threads", + "zlib" + ]; + prefixedNodeCoreModuleList = unprefixedNodeCoreModuleList.map((name) => `node:${name}`); + nodeCoreModuleList = [...unprefixedNodeCoreModuleList, ...prefixedNodeCoreModuleList]; + nodeCoreModules = new Set(nodeCoreModuleList); + NameValidationResult = /* @__PURE__ */ ((NameValidationResult2) => { + NameValidationResult2[NameValidationResult2["Ok"] = 0] = "Ok"; + NameValidationResult2[NameValidationResult2["EmptyName"] = 1] = "EmptyName"; + NameValidationResult2[NameValidationResult2["NameTooLong"] = 2] = "NameTooLong"; + NameValidationResult2[NameValidationResult2["NameStartsWithDot"] = 3] = "NameStartsWithDot"; + NameValidationResult2[NameValidationResult2["NameStartsWithUnderscore"] = 4] = "NameStartsWithUnderscore"; + NameValidationResult2[NameValidationResult2["NameContainsNonURISafeCharacters"] = 5] = "NameContainsNonURISafeCharacters"; + return NameValidationResult2; + })(NameValidationResult || {}); + maxPackageNameLength = 214; + } + }); + + // src/jsTyping/_namespaces/ts.JsTyping.ts + var ts_JsTyping_exports = {}; + __export(ts_JsTyping_exports, { + NameValidationResult: () => NameValidationResult, + discoverTypings: () => discoverTypings, + isTypingUpToDate: () => isTypingUpToDate, + loadSafeList: () => loadSafeList, + loadTypesMap: () => loadTypesMap, + nodeCoreModuleList: () => nodeCoreModuleList, + nodeCoreModules: () => nodeCoreModules, + nonRelativeModuleNameForTypingCache: () => nonRelativeModuleNameForTypingCache, + prefixedNodeCoreModuleList: () => prefixedNodeCoreModuleList, + renderPackageNameValidationFailure: () => renderPackageNameValidationFailure, + validatePackageName: () => validatePackageName + }); + var init_ts_JsTyping = __esm({ + "src/jsTyping/_namespaces/ts.JsTyping.ts"() { + "use strict"; + init_jsTyping(); + } + }); + + // src/jsTyping/_namespaces/ts.ts + var init_ts3 = __esm({ + "src/jsTyping/_namespaces/ts.ts"() { + "use strict"; + init_ts2(); + init_ts_JsTyping(); + init_ts_server(); + } + }); + + // src/services/types.ts + function getDefaultFormatCodeSettings(newLineCharacter) { return { - kind: 2 /* UpdateOutputFileStamps */, - project, - projectPath, - buildOrder, - getCompilerOptions: () => config.options, - getCurrentDirectory: () => state.compilerHost.getCurrentDirectory(), - updateOutputFileStatmps: () => { - updateOutputTimestamps(state, config, projectPath); - updateOutputFileStampsPending = false; - }, - done: () => { - if (updateOutputFileStampsPending) { - updateOutputTimestamps(state, config, projectPath); - } - mark("SolutionBuilder::Timestamps only updates"); - return doneInvalidatedProject(state, projectPath); - } + indentSize: 4, + tabSize: 4, + newLineCharacter: newLineCharacter || "\n", + convertTabsToSpaces: true, + indentStyle: 2 /* Smart */, + insertSpaceAfterConstructor: false, + insertSpaceAfterCommaDelimiter: true, + insertSpaceAfterSemicolonInForStatements: true, + insertSpaceBeforeAndAfterBinaryOperators: true, + insertSpaceAfterKeywordsInControlFlowStatements: true, + insertSpaceAfterFunctionKeywordForAnonymousFunctions: false, + insertSpaceAfterOpeningAndBeforeClosingNonemptyParenthesis: false, + insertSpaceAfterOpeningAndBeforeClosingNonemptyBrackets: false, + insertSpaceAfterOpeningAndBeforeClosingNonemptyBraces: true, + insertSpaceAfterOpeningAndBeforeClosingTemplateStringBraces: false, + insertSpaceAfterOpeningAndBeforeClosingJsxExpressionBraces: false, + insertSpaceBeforeFunctionParenthesis: false, + placeOpenBraceOnNewLineForFunctions: false, + placeOpenBraceOnNewLineForControlBlocks: false, + semicolons: "ignore" /* Ignore */, + trimTrailingWhitespace: true, + indentSwitchCase: true }; } - function createBuildOrUpdateInvalidedProject(kind, state, project, projectPath, projectIndex, config, buildOrder) { - let step = kind === 0 /* Build */ ? 0 /* CreateProgram */ : 4 /* EmitBundle */; - let program; - let buildResult; - let invalidatedProjectOfBundle; - return kind === 0 /* Build */ ? { - kind, - project, - projectPath, - buildOrder, - getCompilerOptions: () => config.options, - getCurrentDirectory: () => state.compilerHost.getCurrentDirectory(), - getBuilderProgram: () => withProgramOrUndefined(identity), - getProgram: () => withProgramOrUndefined( - (program2) => program2.getProgramOrUndefined() - ), - getSourceFile: (fileName) => withProgramOrUndefined( - (program2) => program2.getSourceFile(fileName) - ), - getSourceFiles: () => withProgramOrEmptyArray( - (program2) => program2.getSourceFiles() - ), - getOptionsDiagnostics: (cancellationToken) => withProgramOrEmptyArray( - (program2) => program2.getOptionsDiagnostics(cancellationToken) - ), - getGlobalDiagnostics: (cancellationToken) => withProgramOrEmptyArray( - (program2) => program2.getGlobalDiagnostics(cancellationToken) - ), - getConfigFileParsingDiagnostics: () => withProgramOrEmptyArray( - (program2) => program2.getConfigFileParsingDiagnostics() - ), - getSyntacticDiagnostics: (sourceFile, cancellationToken) => withProgramOrEmptyArray( - (program2) => program2.getSyntacticDiagnostics(sourceFile, cancellationToken) - ), - getAllDependencies: (sourceFile) => withProgramOrEmptyArray( - (program2) => program2.getAllDependencies(sourceFile) - ), - getSemanticDiagnostics: (sourceFile, cancellationToken) => withProgramOrEmptyArray( - (program2) => program2.getSemanticDiagnostics(sourceFile, cancellationToken) - ), - getSemanticDiagnosticsOfNextAffectedFile: (cancellationToken, ignoreSourceFile) => withProgramOrUndefined( - (program2) => program2.getSemanticDiagnosticsOfNextAffectedFile && program2.getSemanticDiagnosticsOfNextAffectedFile(cancellationToken, ignoreSourceFile) - ), - emit: (targetSourceFile, writeFile2, cancellationToken, emitOnlyDtsFiles, customTransformers) => { - if (targetSourceFile || emitOnlyDtsFiles) { - return withProgramOrUndefined( - (program2) => { - var _a, _b; - return program2.emit(targetSourceFile, writeFile2, cancellationToken, emitOnlyDtsFiles, customTransformers || ((_b = (_a = state.host).getCustomTransformers) == null ? void 0 : _b.call(_a, project))); - } - ); + var ScriptSnapshot, PackageJsonDependencyGroup, PackageJsonAutoImportPreference, LanguageServiceMode, emptyOptions, SemanticClassificationFormat, OrganizeImportsMode, CompletionTriggerKind, InlayHintKind, HighlightSpanKind, IndentStyle, SemicolonPreference, testFormatSettings, SymbolDisplayPartKind, CompletionInfoFlags, OutliningSpanKind, OutputFileType, EndOfLineState, TokenClass, ScriptElementKind, ScriptElementKindModifier, ClassificationTypeNames, ClassificationType; + var init_types3 = __esm({ + "src/services/types.ts"() { + "use strict"; + ((ScriptSnapshot2) => { + class StringScriptSnapshot { + constructor(text) { + this.text = text; + } + getText(start, end) { + return start === 0 && end === this.text.length ? this.text : this.text.substring(start, end); + } + getLength() { + return this.text.length; + } + getChangeRange() { + return void 0; + } } - executeSteps(2 /* SemanticDiagnostics */, cancellationToken); - if (step === 5 /* EmitBuildInfo */) { - return emitBuildInfo(writeFile2, cancellationToken); + function fromString(text) { + return new StringScriptSnapshot(text); } - if (step !== 3 /* Emit */) - return void 0; - return emit(writeFile2, cancellationToken, customTransformers); - }, - done - } : { - kind, - project, - projectPath, - buildOrder, - getCompilerOptions: () => config.options, - getCurrentDirectory: () => state.compilerHost.getCurrentDirectory(), - emit: (writeFile2, customTransformers) => { - if (step !== 4 /* EmitBundle */) - return invalidatedProjectOfBundle; - return emitBundle(writeFile2, customTransformers); - }, - done - }; - function done(cancellationToken, writeFile2, customTransformers) { - executeSteps(8 /* Done */, cancellationToken, writeFile2, customTransformers); - if (kind === 0 /* Build */) - mark("SolutionBuilder::Projects built"); - else - mark("SolutionBuilder::Bundles updated"); - return doneInvalidatedProject(state, projectPath); - } - function withProgramOrUndefined(action) { - executeSteps(0 /* CreateProgram */); - return program && action(program); - } - function withProgramOrEmptyArray(action) { - return withProgramOrUndefined(action) || emptyArray; - } - function createProgram2() { - var _a, _b; - Debug.assert(program === void 0); - if (state.options.dry) { - reportStatus(state, Diagnostics.A_non_dry_build_would_build_project_0, project); - buildResult = 1 /* Success */; - step = 7 /* QueueReferencingProjects */; - return; - } - if (state.options.verbose) - reportStatus(state, Diagnostics.Building_project_0, project); - if (config.fileNames.length === 0) { - reportAndStoreErrors(state, projectPath, getConfigFileParsingDiagnostics(config)); - buildResult = 0 /* None */; - step = 7 /* QueueReferencingProjects */; - return; - } - const { host, compilerHost } = state; - state.projectCompilerOptions = config.options; - (_a = state.moduleResolutionCache) == null ? void 0 : _a.update(config.options); - (_b = state.typeReferenceDirectiveResolutionCache) == null ? void 0 : _b.update(config.options); - program = host.createProgram( - config.fileNames, - config.options, - compilerHost, - getOldProgram(state, projectPath, config), - getConfigFileParsingDiagnostics(config), - config.projectReferences - ); - if (state.watch) { - state.lastCachedPackageJsonLookups.set(projectPath, state.moduleResolutionCache && map( - state.moduleResolutionCache.getPackageJsonInfoCache().entries(), - ([path, data]) => [state.host.realpath && data ? toPath2(state, state.host.realpath(path)) : path, data] - )); - state.builderPrograms.set(projectPath, program); - } - step++; + ScriptSnapshot2.fromString = fromString; + })(ScriptSnapshot || (ScriptSnapshot = {})); + PackageJsonDependencyGroup = /* @__PURE__ */ ((PackageJsonDependencyGroup2) => { + PackageJsonDependencyGroup2[PackageJsonDependencyGroup2["Dependencies"] = 1] = "Dependencies"; + PackageJsonDependencyGroup2[PackageJsonDependencyGroup2["DevDependencies"] = 2] = "DevDependencies"; + PackageJsonDependencyGroup2[PackageJsonDependencyGroup2["PeerDependencies"] = 4] = "PeerDependencies"; + PackageJsonDependencyGroup2[PackageJsonDependencyGroup2["OptionalDependencies"] = 8] = "OptionalDependencies"; + PackageJsonDependencyGroup2[PackageJsonDependencyGroup2["All"] = 15] = "All"; + return PackageJsonDependencyGroup2; + })(PackageJsonDependencyGroup || {}); + PackageJsonAutoImportPreference = /* @__PURE__ */ ((PackageJsonAutoImportPreference2) => { + PackageJsonAutoImportPreference2[PackageJsonAutoImportPreference2["Off"] = 0] = "Off"; + PackageJsonAutoImportPreference2[PackageJsonAutoImportPreference2["On"] = 1] = "On"; + PackageJsonAutoImportPreference2[PackageJsonAutoImportPreference2["Auto"] = 2] = "Auto"; + return PackageJsonAutoImportPreference2; + })(PackageJsonAutoImportPreference || {}); + LanguageServiceMode = /* @__PURE__ */ ((LanguageServiceMode2) => { + LanguageServiceMode2[LanguageServiceMode2["Semantic"] = 0] = "Semantic"; + LanguageServiceMode2[LanguageServiceMode2["PartialSemantic"] = 1] = "PartialSemantic"; + LanguageServiceMode2[LanguageServiceMode2["Syntactic"] = 2] = "Syntactic"; + return LanguageServiceMode2; + })(LanguageServiceMode || {}); + emptyOptions = {}; + SemanticClassificationFormat = /* @__PURE__ */ ((SemanticClassificationFormat2) => { + SemanticClassificationFormat2["Original"] = "original"; + SemanticClassificationFormat2["TwentyTwenty"] = "2020"; + return SemanticClassificationFormat2; + })(SemanticClassificationFormat || {}); + OrganizeImportsMode = /* @__PURE__ */ ((OrganizeImportsMode3) => { + OrganizeImportsMode3["All"] = "All"; + OrganizeImportsMode3["SortAndCombine"] = "SortAndCombine"; + OrganizeImportsMode3["RemoveUnused"] = "RemoveUnused"; + return OrganizeImportsMode3; + })(OrganizeImportsMode || {}); + CompletionTriggerKind = /* @__PURE__ */ ((CompletionTriggerKind4) => { + CompletionTriggerKind4[CompletionTriggerKind4["Invoked"] = 1] = "Invoked"; + CompletionTriggerKind4[CompletionTriggerKind4["TriggerCharacter"] = 2] = "TriggerCharacter"; + CompletionTriggerKind4[CompletionTriggerKind4["TriggerForIncompleteCompletions"] = 3] = "TriggerForIncompleteCompletions"; + return CompletionTriggerKind4; + })(CompletionTriggerKind || {}); + InlayHintKind = /* @__PURE__ */ ((InlayHintKind2) => { + InlayHintKind2["Type"] = "Type"; + InlayHintKind2["Parameter"] = "Parameter"; + InlayHintKind2["Enum"] = "Enum"; + return InlayHintKind2; + })(InlayHintKind || {}); + HighlightSpanKind = /* @__PURE__ */ ((HighlightSpanKind2) => { + HighlightSpanKind2["none"] = "none"; + HighlightSpanKind2["definition"] = "definition"; + HighlightSpanKind2["reference"] = "reference"; + HighlightSpanKind2["writtenReference"] = "writtenReference"; + return HighlightSpanKind2; + })(HighlightSpanKind || {}); + IndentStyle = /* @__PURE__ */ ((IndentStyle3) => { + IndentStyle3[IndentStyle3["None"] = 0] = "None"; + IndentStyle3[IndentStyle3["Block"] = 1] = "Block"; + IndentStyle3[IndentStyle3["Smart"] = 2] = "Smart"; + return IndentStyle3; + })(IndentStyle || {}); + SemicolonPreference = /* @__PURE__ */ ((SemicolonPreference3) => { + SemicolonPreference3["Ignore"] = "ignore"; + SemicolonPreference3["Insert"] = "insert"; + SemicolonPreference3["Remove"] = "remove"; + return SemicolonPreference3; + })(SemicolonPreference || {}); + testFormatSettings = getDefaultFormatCodeSettings("\n"); + SymbolDisplayPartKind = /* @__PURE__ */ ((SymbolDisplayPartKind2) => { + SymbolDisplayPartKind2[SymbolDisplayPartKind2["aliasName"] = 0] = "aliasName"; + SymbolDisplayPartKind2[SymbolDisplayPartKind2["className"] = 1] = "className"; + SymbolDisplayPartKind2[SymbolDisplayPartKind2["enumName"] = 2] = "enumName"; + SymbolDisplayPartKind2[SymbolDisplayPartKind2["fieldName"] = 3] = "fieldName"; + SymbolDisplayPartKind2[SymbolDisplayPartKind2["interfaceName"] = 4] = "interfaceName"; + SymbolDisplayPartKind2[SymbolDisplayPartKind2["keyword"] = 5] = "keyword"; + SymbolDisplayPartKind2[SymbolDisplayPartKind2["lineBreak"] = 6] = "lineBreak"; + SymbolDisplayPartKind2[SymbolDisplayPartKind2["numericLiteral"] = 7] = "numericLiteral"; + SymbolDisplayPartKind2[SymbolDisplayPartKind2["stringLiteral"] = 8] = "stringLiteral"; + SymbolDisplayPartKind2[SymbolDisplayPartKind2["localName"] = 9] = "localName"; + SymbolDisplayPartKind2[SymbolDisplayPartKind2["methodName"] = 10] = "methodName"; + SymbolDisplayPartKind2[SymbolDisplayPartKind2["moduleName"] = 11] = "moduleName"; + SymbolDisplayPartKind2[SymbolDisplayPartKind2["operator"] = 12] = "operator"; + SymbolDisplayPartKind2[SymbolDisplayPartKind2["parameterName"] = 13] = "parameterName"; + SymbolDisplayPartKind2[SymbolDisplayPartKind2["propertyName"] = 14] = "propertyName"; + SymbolDisplayPartKind2[SymbolDisplayPartKind2["punctuation"] = 15] = "punctuation"; + SymbolDisplayPartKind2[SymbolDisplayPartKind2["space"] = 16] = "space"; + SymbolDisplayPartKind2[SymbolDisplayPartKind2["text"] = 17] = "text"; + SymbolDisplayPartKind2[SymbolDisplayPartKind2["typeParameterName"] = 18] = "typeParameterName"; + SymbolDisplayPartKind2[SymbolDisplayPartKind2["enumMemberName"] = 19] = "enumMemberName"; + SymbolDisplayPartKind2[SymbolDisplayPartKind2["functionName"] = 20] = "functionName"; + SymbolDisplayPartKind2[SymbolDisplayPartKind2["regularExpressionLiteral"] = 21] = "regularExpressionLiteral"; + SymbolDisplayPartKind2[SymbolDisplayPartKind2["link"] = 22] = "link"; + SymbolDisplayPartKind2[SymbolDisplayPartKind2["linkName"] = 23] = "linkName"; + SymbolDisplayPartKind2[SymbolDisplayPartKind2["linkText"] = 24] = "linkText"; + return SymbolDisplayPartKind2; + })(SymbolDisplayPartKind || {}); + CompletionInfoFlags = /* @__PURE__ */ ((CompletionInfoFlags2) => { + CompletionInfoFlags2[CompletionInfoFlags2["None"] = 0] = "None"; + CompletionInfoFlags2[CompletionInfoFlags2["MayIncludeAutoImports"] = 1] = "MayIncludeAutoImports"; + CompletionInfoFlags2[CompletionInfoFlags2["IsImportStatementCompletion"] = 2] = "IsImportStatementCompletion"; + CompletionInfoFlags2[CompletionInfoFlags2["IsContinuation"] = 4] = "IsContinuation"; + CompletionInfoFlags2[CompletionInfoFlags2["ResolvedModuleSpecifiers"] = 8] = "ResolvedModuleSpecifiers"; + CompletionInfoFlags2[CompletionInfoFlags2["ResolvedModuleSpecifiersBeyondLimit"] = 16] = "ResolvedModuleSpecifiersBeyondLimit"; + CompletionInfoFlags2[CompletionInfoFlags2["MayIncludeMethodSnippets"] = 32] = "MayIncludeMethodSnippets"; + return CompletionInfoFlags2; + })(CompletionInfoFlags || {}); + OutliningSpanKind = /* @__PURE__ */ ((OutliningSpanKind2) => { + OutliningSpanKind2["Comment"] = "comment"; + OutliningSpanKind2["Region"] = "region"; + OutliningSpanKind2["Code"] = "code"; + OutliningSpanKind2["Imports"] = "imports"; + return OutliningSpanKind2; + })(OutliningSpanKind || {}); + OutputFileType = /* @__PURE__ */ ((OutputFileType2) => { + OutputFileType2[OutputFileType2["JavaScript"] = 0] = "JavaScript"; + OutputFileType2[OutputFileType2["SourceMap"] = 1] = "SourceMap"; + OutputFileType2[OutputFileType2["Declaration"] = 2] = "Declaration"; + return OutputFileType2; + })(OutputFileType || {}); + EndOfLineState = /* @__PURE__ */ ((EndOfLineState2) => { + EndOfLineState2[EndOfLineState2["None"] = 0] = "None"; + EndOfLineState2[EndOfLineState2["InMultiLineCommentTrivia"] = 1] = "InMultiLineCommentTrivia"; + EndOfLineState2[EndOfLineState2["InSingleQuoteStringLiteral"] = 2] = "InSingleQuoteStringLiteral"; + EndOfLineState2[EndOfLineState2["InDoubleQuoteStringLiteral"] = 3] = "InDoubleQuoteStringLiteral"; + EndOfLineState2[EndOfLineState2["InTemplateHeadOrNoSubstitutionTemplate"] = 4] = "InTemplateHeadOrNoSubstitutionTemplate"; + EndOfLineState2[EndOfLineState2["InTemplateMiddleOrTail"] = 5] = "InTemplateMiddleOrTail"; + EndOfLineState2[EndOfLineState2["InTemplateSubstitutionPosition"] = 6] = "InTemplateSubstitutionPosition"; + return EndOfLineState2; + })(EndOfLineState || {}); + TokenClass = /* @__PURE__ */ ((TokenClass2) => { + TokenClass2[TokenClass2["Punctuation"] = 0] = "Punctuation"; + TokenClass2[TokenClass2["Keyword"] = 1] = "Keyword"; + TokenClass2[TokenClass2["Operator"] = 2] = "Operator"; + TokenClass2[TokenClass2["Comment"] = 3] = "Comment"; + TokenClass2[TokenClass2["Whitespace"] = 4] = "Whitespace"; + TokenClass2[TokenClass2["Identifier"] = 5] = "Identifier"; + TokenClass2[TokenClass2["NumberLiteral"] = 6] = "NumberLiteral"; + TokenClass2[TokenClass2["BigIntLiteral"] = 7] = "BigIntLiteral"; + TokenClass2[TokenClass2["StringLiteral"] = 8] = "StringLiteral"; + TokenClass2[TokenClass2["RegExpLiteral"] = 9] = "RegExpLiteral"; + return TokenClass2; + })(TokenClass || {}); + ScriptElementKind = /* @__PURE__ */ ((ScriptElementKind2) => { + ScriptElementKind2["unknown"] = ""; + ScriptElementKind2["warning"] = "warning"; + ScriptElementKind2["keyword"] = "keyword"; + ScriptElementKind2["scriptElement"] = "script"; + ScriptElementKind2["moduleElement"] = "module"; + ScriptElementKind2["classElement"] = "class"; + ScriptElementKind2["localClassElement"] = "local class"; + ScriptElementKind2["interfaceElement"] = "interface"; + ScriptElementKind2["typeElement"] = "type"; + ScriptElementKind2["enumElement"] = "enum"; + ScriptElementKind2["enumMemberElement"] = "enum member"; + ScriptElementKind2["variableElement"] = "var"; + ScriptElementKind2["localVariableElement"] = "local var"; + ScriptElementKind2["variableUsingElement"] = "using"; + ScriptElementKind2["variableAwaitUsingElement"] = "await using"; + ScriptElementKind2["functionElement"] = "function"; + ScriptElementKind2["localFunctionElement"] = "local function"; + ScriptElementKind2["memberFunctionElement"] = "method"; + ScriptElementKind2["memberGetAccessorElement"] = "getter"; + ScriptElementKind2["memberSetAccessorElement"] = "setter"; + ScriptElementKind2["memberVariableElement"] = "property"; + ScriptElementKind2["memberAccessorVariableElement"] = "accessor"; + ScriptElementKind2["constructorImplementationElement"] = "constructor"; + ScriptElementKind2["callSignatureElement"] = "call"; + ScriptElementKind2["indexSignatureElement"] = "index"; + ScriptElementKind2["constructSignatureElement"] = "construct"; + ScriptElementKind2["parameterElement"] = "parameter"; + ScriptElementKind2["typeParameterElement"] = "type parameter"; + ScriptElementKind2["primitiveType"] = "primitive type"; + ScriptElementKind2["label"] = "label"; + ScriptElementKind2["alias"] = "alias"; + ScriptElementKind2["constElement"] = "const"; + ScriptElementKind2["letElement"] = "let"; + ScriptElementKind2["directory"] = "directory"; + ScriptElementKind2["externalModuleName"] = "external module name"; + ScriptElementKind2["jsxAttribute"] = "JSX attribute"; + ScriptElementKind2["string"] = "string"; + ScriptElementKind2["link"] = "link"; + ScriptElementKind2["linkName"] = "link name"; + ScriptElementKind2["linkText"] = "link text"; + return ScriptElementKind2; + })(ScriptElementKind || {}); + ScriptElementKindModifier = /* @__PURE__ */ ((ScriptElementKindModifier2) => { + ScriptElementKindModifier2["none"] = ""; + ScriptElementKindModifier2["publicMemberModifier"] = "public"; + ScriptElementKindModifier2["privateMemberModifier"] = "private"; + ScriptElementKindModifier2["protectedMemberModifier"] = "protected"; + ScriptElementKindModifier2["exportedModifier"] = "export"; + ScriptElementKindModifier2["ambientModifier"] = "declare"; + ScriptElementKindModifier2["staticModifier"] = "static"; + ScriptElementKindModifier2["abstractModifier"] = "abstract"; + ScriptElementKindModifier2["optionalModifier"] = "optional"; + ScriptElementKindModifier2["deprecatedModifier"] = "deprecated"; + ScriptElementKindModifier2["dtsModifier"] = ".d.ts"; + ScriptElementKindModifier2["tsModifier"] = ".ts"; + ScriptElementKindModifier2["tsxModifier"] = ".tsx"; + ScriptElementKindModifier2["jsModifier"] = ".js"; + ScriptElementKindModifier2["jsxModifier"] = ".jsx"; + ScriptElementKindModifier2["jsonModifier"] = ".json"; + ScriptElementKindModifier2["dmtsModifier"] = ".d.mts"; + ScriptElementKindModifier2["mtsModifier"] = ".mts"; + ScriptElementKindModifier2["mjsModifier"] = ".mjs"; + ScriptElementKindModifier2["dctsModifier"] = ".d.cts"; + ScriptElementKindModifier2["ctsModifier"] = ".cts"; + ScriptElementKindModifier2["cjsModifier"] = ".cjs"; + return ScriptElementKindModifier2; + })(ScriptElementKindModifier || {}); + ClassificationTypeNames = /* @__PURE__ */ ((ClassificationTypeNames2) => { + ClassificationTypeNames2["comment"] = "comment"; + ClassificationTypeNames2["identifier"] = "identifier"; + ClassificationTypeNames2["keyword"] = "keyword"; + ClassificationTypeNames2["numericLiteral"] = "number"; + ClassificationTypeNames2["bigintLiteral"] = "bigint"; + ClassificationTypeNames2["operator"] = "operator"; + ClassificationTypeNames2["stringLiteral"] = "string"; + ClassificationTypeNames2["whiteSpace"] = "whitespace"; + ClassificationTypeNames2["text"] = "text"; + ClassificationTypeNames2["punctuation"] = "punctuation"; + ClassificationTypeNames2["className"] = "class name"; + ClassificationTypeNames2["enumName"] = "enum name"; + ClassificationTypeNames2["interfaceName"] = "interface name"; + ClassificationTypeNames2["moduleName"] = "module name"; + ClassificationTypeNames2["typeParameterName"] = "type parameter name"; + ClassificationTypeNames2["typeAliasName"] = "type alias name"; + ClassificationTypeNames2["parameterName"] = "parameter name"; + ClassificationTypeNames2["docCommentTagName"] = "doc comment tag name"; + ClassificationTypeNames2["jsxOpenTagName"] = "jsx open tag name"; + ClassificationTypeNames2["jsxCloseTagName"] = "jsx close tag name"; + ClassificationTypeNames2["jsxSelfClosingTagName"] = "jsx self closing tag name"; + ClassificationTypeNames2["jsxAttribute"] = "jsx attribute"; + ClassificationTypeNames2["jsxText"] = "jsx text"; + ClassificationTypeNames2["jsxAttributeStringLiteralValue"] = "jsx attribute string literal value"; + return ClassificationTypeNames2; + })(ClassificationTypeNames || {}); + ClassificationType = /* @__PURE__ */ ((ClassificationType3) => { + ClassificationType3[ClassificationType3["comment"] = 1] = "comment"; + ClassificationType3[ClassificationType3["identifier"] = 2] = "identifier"; + ClassificationType3[ClassificationType3["keyword"] = 3] = "keyword"; + ClassificationType3[ClassificationType3["numericLiteral"] = 4] = "numericLiteral"; + ClassificationType3[ClassificationType3["operator"] = 5] = "operator"; + ClassificationType3[ClassificationType3["stringLiteral"] = 6] = "stringLiteral"; + ClassificationType3[ClassificationType3["regularExpressionLiteral"] = 7] = "regularExpressionLiteral"; + ClassificationType3[ClassificationType3["whiteSpace"] = 8] = "whiteSpace"; + ClassificationType3[ClassificationType3["text"] = 9] = "text"; + ClassificationType3[ClassificationType3["punctuation"] = 10] = "punctuation"; + ClassificationType3[ClassificationType3["className"] = 11] = "className"; + ClassificationType3[ClassificationType3["enumName"] = 12] = "enumName"; + ClassificationType3[ClassificationType3["interfaceName"] = 13] = "interfaceName"; + ClassificationType3[ClassificationType3["moduleName"] = 14] = "moduleName"; + ClassificationType3[ClassificationType3["typeParameterName"] = 15] = "typeParameterName"; + ClassificationType3[ClassificationType3["typeAliasName"] = 16] = "typeAliasName"; + ClassificationType3[ClassificationType3["parameterName"] = 17] = "parameterName"; + ClassificationType3[ClassificationType3["docCommentTagName"] = 18] = "docCommentTagName"; + ClassificationType3[ClassificationType3["jsxOpenTagName"] = 19] = "jsxOpenTagName"; + ClassificationType3[ClassificationType3["jsxCloseTagName"] = 20] = "jsxCloseTagName"; + ClassificationType3[ClassificationType3["jsxSelfClosingTagName"] = 21] = "jsxSelfClosingTagName"; + ClassificationType3[ClassificationType3["jsxAttribute"] = 22] = "jsxAttribute"; + ClassificationType3[ClassificationType3["jsxText"] = 23] = "jsxText"; + ClassificationType3[ClassificationType3["jsxAttributeStringLiteralValue"] = 24] = "jsxAttributeStringLiteralValue"; + ClassificationType3[ClassificationType3["bigintLiteral"] = 25] = "bigintLiteral"; + return ClassificationType3; + })(ClassificationType || {}); } - function handleDiagnostics(diagnostics, errorFlags, errorType) { - if (diagnostics.length) { - ({ buildResult, step } = buildErrors( - state, - projectPath, - program, - config, - diagnostics, - errorFlags, - errorType - )); - } else { - step++; - } + }); + + // src/services/utilities.ts + function getMeaningFromDeclaration(node) { + switch (node.kind) { + case 260 /* VariableDeclaration */: + return isInJSFile(node) && getJSDocEnumTag(node) ? 7 /* All */ : 1 /* Value */; + case 169 /* Parameter */: + case 208 /* BindingElement */: + case 172 /* PropertyDeclaration */: + case 171 /* PropertySignature */: + case 303 /* PropertyAssignment */: + case 304 /* ShorthandPropertyAssignment */: + case 174 /* MethodDeclaration */: + case 173 /* MethodSignature */: + case 176 /* Constructor */: + case 177 /* GetAccessor */: + case 178 /* SetAccessor */: + case 262 /* FunctionDeclaration */: + case 218 /* FunctionExpression */: + case 219 /* ArrowFunction */: + case 299 /* CatchClause */: + case 291 /* JsxAttribute */: + return 1 /* Value */; + case 168 /* TypeParameter */: + case 264 /* InterfaceDeclaration */: + case 265 /* TypeAliasDeclaration */: + case 187 /* TypeLiteral */: + return 2 /* Type */; + case 353 /* JSDocTypedefTag */: + return node.name === void 0 ? 1 /* Value */ | 2 /* Type */ : 2 /* Type */; + case 306 /* EnumMember */: + case 263 /* ClassDeclaration */: + return 1 /* Value */ | 2 /* Type */; + case 267 /* ModuleDeclaration */: + if (isAmbientModule(node)) { + return 4 /* Namespace */ | 1 /* Value */; + } else if (getModuleInstanceState(node) === 1 /* Instantiated */) { + return 4 /* Namespace */ | 1 /* Value */; + } else { + return 4 /* Namespace */; + } + case 266 /* EnumDeclaration */: + case 275 /* NamedImports */: + case 276 /* ImportSpecifier */: + case 271 /* ImportEqualsDeclaration */: + case 272 /* ImportDeclaration */: + case 277 /* ExportAssignment */: + case 278 /* ExportDeclaration */: + return 7 /* All */; + case 312 /* SourceFile */: + return 4 /* Namespace */ | 1 /* Value */; } - function getSyntaxDiagnostics(cancellationToken) { - Debug.assertIsDefined(program); - handleDiagnostics( - [ - ...program.getConfigFileParsingDiagnostics(), - ...program.getOptionsDiagnostics(cancellationToken), - ...program.getGlobalDiagnostics(cancellationToken), - ...program.getSyntacticDiagnostics( - /*sourceFile*/ - void 0, - cancellationToken - ) - ], - 8 /* SyntaxErrors */, - "Syntactic" - ); + return 7 /* All */; + } + function getMeaningFromLocation(node) { + node = getAdjustedReferenceLocation(node); + const parent2 = node.parent; + if (node.kind === 312 /* SourceFile */) { + return 1 /* Value */; + } else if (isExportAssignment(parent2) || isExportSpecifier(parent2) || isExternalModuleReference(parent2) || isImportSpecifier(parent2) || isImportClause(parent2) || isImportEqualsDeclaration(parent2) && node === parent2.name) { + return 7 /* All */; + } else if (isInRightSideOfInternalImportEqualsDeclaration(node)) { + return getMeaningFromRightHandSideOfImportEquals(node); + } else if (isDeclarationName(node)) { + return getMeaningFromDeclaration(parent2); + } else if (isEntityName(node) && findAncestor(node, or(isJSDocNameReference, isJSDocLinkLike, isJSDocMemberName))) { + return 7 /* All */; + } else if (isTypeReference(node)) { + return 2 /* Type */; + } else if (isNamespaceReference(node)) { + return 4 /* Namespace */; + } else if (isTypeParameterDeclaration(parent2)) { + Debug.assert(isJSDocTemplateTag(parent2.parent)); + return 2 /* Type */; + } else if (isLiteralTypeNode(parent2)) { + return 2 /* Type */ | 1 /* Value */; + } else { + return 1 /* Value */; } - function getSemanticDiagnostics(cancellationToken) { - handleDiagnostics( - Debug.checkDefined(program).getSemanticDiagnostics( - /*sourceFile*/ - void 0, - cancellationToken - ), - 16 /* TypeErrors */, - "Semantic" - ); + } + function getMeaningFromRightHandSideOfImportEquals(node) { + const name = node.kind === 166 /* QualifiedName */ ? node : isQualifiedName(node.parent) && node.parent.right === node ? node.parent : void 0; + return name && name.parent.kind === 271 /* ImportEqualsDeclaration */ ? 7 /* All */ : 4 /* Namespace */; + } + function isInRightSideOfInternalImportEqualsDeclaration(node) { + while (node.parent.kind === 166 /* QualifiedName */) { + node = node.parent; } - function emit(writeFileCallback, cancellationToken, customTransformers) { - var _a, _b, _c; - Debug.assertIsDefined(program); - Debug.assert(step === 3 /* Emit */); - const saved = program.saveEmitState(); - let declDiagnostics; - const reportDeclarationDiagnostics = (d) => (declDiagnostics || (declDiagnostics = [])).push(d); - const outputFiles = []; - const { emitResult } = emitFilesAndReportErrors( - program, - reportDeclarationDiagnostics, - /*write*/ - void 0, - /*reportSummary*/ - void 0, - (name, text, writeByteOrderMark, _onError, _sourceFiles, data) => outputFiles.push({ name, text, writeByteOrderMark, data }), - cancellationToken, - /*emitOnlyDtsFiles*/ - false, - customTransformers || ((_b = (_a = state.host).getCustomTransformers) == null ? void 0 : _b.call(_a, project)) - ); - if (declDiagnostics) { - program.restoreEmitState(saved); - ({ buildResult, step } = buildErrors( - state, - projectPath, - program, - config, - declDiagnostics, - 32 /* DeclarationEmitErrors */, - "Declaration file" - )); - return { - emitSkipped: true, - diagnostics: emitResult.diagnostics - }; + return isInternalModuleImportEqualsDeclaration(node.parent) && node.parent.moduleReference === node; + } + function isNamespaceReference(node) { + return isQualifiedNameNamespaceReference(node) || isPropertyAccessNamespaceReference(node); + } + function isQualifiedNameNamespaceReference(node) { + let root = node; + let isLastClause = true; + if (root.parent.kind === 166 /* QualifiedName */) { + while (root.parent && root.parent.kind === 166 /* QualifiedName */) { + root = root.parent; } - const { host, compilerHost } = state; - const resultFlags = ((_c = program.hasChangedEmitSignature) == null ? void 0 : _c.call(program)) ? 0 /* None */ : 2 /* DeclarationOutputUnchanged */; - const emitterDiagnostics = createDiagnosticCollection(); - const emittedOutputs = /* @__PURE__ */ new Map(); - const options = program.getCompilerOptions(); - const isIncremental = isIncrementalCompilation(options); - let outputTimeStampMap; - let now; - outputFiles.forEach(({ name, text, writeByteOrderMark, data }) => { - const path = toPath2(state, name); - emittedOutputs.set(toPath2(state, name), name); - if (data == null ? void 0 : data.buildInfo) - setBuildInfo(state, data.buildInfo, projectPath, options, resultFlags); - const modifiedTime = (data == null ? void 0 : data.differsOnlyInMap) ? getModifiedTime(state.host, name) : void 0; - writeFile(writeFileCallback ? { writeFile: writeFileCallback } : compilerHost, emitterDiagnostics, name, text, writeByteOrderMark); - if (data == null ? void 0 : data.differsOnlyInMap) - state.host.setModifiedTime(name, modifiedTime); - else if (!isIncremental && state.watch) { - (outputTimeStampMap || (outputTimeStampMap = getOutputTimeStampMap(state, projectPath))).set(path, now || (now = getCurrentTime(state.host))); - } - }); - finishEmit( - emitterDiagnostics, - emittedOutputs, - outputFiles.length ? outputFiles[0].name : getFirstProjectOutput(config, !host.useCaseSensitiveFileNames()), - resultFlags - ); - return emitResult; + isLastClause = root.right === node; } - function emitBuildInfo(writeFileCallback, cancellationToken) { - Debug.assertIsDefined(program); - Debug.assert(step === 5 /* EmitBuildInfo */); - const emitResult = program.emitBuildInfo((name, text, writeByteOrderMark, onError, sourceFiles, data) => { - if (data == null ? void 0 : data.buildInfo) - setBuildInfo(state, data.buildInfo, projectPath, program.getCompilerOptions(), 2 /* DeclarationOutputUnchanged */); - if (writeFileCallback) - writeFileCallback(name, text, writeByteOrderMark, onError, sourceFiles, data); - else - state.compilerHost.writeFile(name, text, writeByteOrderMark, onError, sourceFiles, data); - }, cancellationToken); - if (emitResult.diagnostics.length) { - reportErrors(state, emitResult.diagnostics); - state.diagnostics.set(projectPath, [...state.diagnostics.get(projectPath), ...emitResult.diagnostics]); - buildResult = 64 /* EmitErrors */ & buildResult; - } - if (emitResult.emittedFiles && state.write) { - emitResult.emittedFiles.forEach((name) => listEmittedFile(state, config, name)); + return root.parent.kind === 183 /* TypeReference */ && !isLastClause; + } + function isPropertyAccessNamespaceReference(node) { + let root = node; + let isLastClause = true; + if (root.parent.kind === 211 /* PropertyAccessExpression */) { + while (root.parent && root.parent.kind === 211 /* PropertyAccessExpression */) { + root = root.parent; } - afterProgramDone(state, program, config); - step = 7 /* QueueReferencingProjects */; - return emitResult; + isLastClause = root.name === node; } - function finishEmit(emitterDiagnostics, emittedOutputs, oldestOutputFileName, resultFlags) { - const emitDiagnostics = emitterDiagnostics.getDiagnostics(); - if (emitDiagnostics.length) { - ({ buildResult, step } = buildErrors( - state, - projectPath, - program, - config, - emitDiagnostics, - 64 /* EmitErrors */, - "Emit" - )); - return emitDiagnostics; - } - if (state.write) { - emittedOutputs.forEach((name) => listEmittedFile(state, config, name)); - } - updateOutputTimestampsWorker(state, config, projectPath, Diagnostics.Updating_unchanged_output_timestamps_of_project_0, emittedOutputs); - state.diagnostics.delete(projectPath); - state.projectStatus.set(projectPath, { - type: 1 /* UpToDate */, - oldestOutputFileName - }); - afterProgramDone(state, program, config); - step = 7 /* QueueReferencingProjects */; - buildResult = resultFlags; - return emitDiagnostics; + if (!isLastClause && root.parent.kind === 233 /* ExpressionWithTypeArguments */ && root.parent.parent.kind === 298 /* HeritageClause */) { + const decl = root.parent.parent.parent; + return decl.kind === 263 /* ClassDeclaration */ && root.parent.parent.token === 119 /* ImplementsKeyword */ || decl.kind === 264 /* InterfaceDeclaration */ && root.parent.parent.token === 96 /* ExtendsKeyword */; } - function emitBundle(writeFileCallback, customTransformers) { - var _a, _b, _c, _d; - Debug.assert(kind === 1 /* UpdateBundle */); - if (state.options.dry) { - reportStatus(state, Diagnostics.A_non_dry_build_would_update_output_of_project_0, project); - buildResult = 1 /* Success */; - step = 7 /* QueueReferencingProjects */; - return void 0; - } - if (state.options.verbose) - reportStatus(state, Diagnostics.Updating_output_of_project_0, project); - const { compilerHost } = state; - state.projectCompilerOptions = config.options; - (_b = (_a = state.host).beforeEmitBundle) == null ? void 0 : _b.call(_a, config); - const outputFiles = emitUsingBuildInfo( - config, - compilerHost, - (ref) => { - const refName = resolveProjectName(state, ref.path); - return parseConfigFile(state, refName, toResolvedConfigFilePath(state, refName)); - }, - customTransformers || ((_d = (_c = state.host).getCustomTransformers) == null ? void 0 : _d.call(_c, project)) - ); - if (isString(outputFiles)) { - reportStatus(state, Diagnostics.Cannot_update_output_of_project_0_because_there_was_error_reading_file_1, project, relName(state, outputFiles)); - step = 6 /* BuildInvalidatedProjectOfBundle */; - return invalidatedProjectOfBundle = createBuildOrUpdateInvalidedProject( - 0 /* Build */, - state, - project, - projectPath, - projectIndex, - config, - buildOrder - ); - } - Debug.assert(!!outputFiles.length); - const emitterDiagnostics = createDiagnosticCollection(); - const emittedOutputs = /* @__PURE__ */ new Map(); - let resultFlags = 2 /* DeclarationOutputUnchanged */; - const existingBuildInfo = state.buildInfoCache.get(projectPath).buildInfo || void 0; - outputFiles.forEach(({ name, text, writeByteOrderMark, data }) => { - var _a2, _b2; - emittedOutputs.set(toPath2(state, name), name); - if (data == null ? void 0 : data.buildInfo) { - if (((_a2 = data.buildInfo.program) == null ? void 0 : _a2.outSignature) !== ((_b2 = existingBuildInfo == null ? void 0 : existingBuildInfo.program) == null ? void 0 : _b2.outSignature)) { - resultFlags &= ~2 /* DeclarationOutputUnchanged */; - } - setBuildInfo(state, data.buildInfo, projectPath, config.options, resultFlags); - } - writeFile(writeFileCallback ? { writeFile: writeFileCallback } : compilerHost, emitterDiagnostics, name, text, writeByteOrderMark); - }); - const emitDiagnostics = finishEmit( - emitterDiagnostics, - emittedOutputs, - outputFiles[0].name, - resultFlags - ); - return { emitSkipped: false, diagnostics: emitDiagnostics }; + return false; + } + function isTypeReference(node) { + if (isRightSideOfQualifiedNameOrPropertyAccess(node)) { + node = node.parent; } - function executeSteps(till, cancellationToken, writeFile2, customTransformers) { - while (step <= till && step < 8 /* Done */) { - const currentStep = step; - switch (step) { - case 0 /* CreateProgram */: - createProgram2(); - break; - case 1 /* SyntaxDiagnostics */: - getSyntaxDiagnostics(cancellationToken); - break; - case 2 /* SemanticDiagnostics */: - getSemanticDiagnostics(cancellationToken); - break; - case 3 /* Emit */: - emit(writeFile2, cancellationToken, customTransformers); - break; - case 5 /* EmitBuildInfo */: - emitBuildInfo(writeFile2, cancellationToken); - break; - case 4 /* EmitBundle */: - emitBundle(writeFile2, customTransformers); - break; - case 6 /* BuildInvalidatedProjectOfBundle */: - Debug.checkDefined(invalidatedProjectOfBundle).done(cancellationToken, writeFile2, customTransformers); - step = 8 /* Done */; - break; - case 7 /* QueueReferencingProjects */: - queueReferencingProjects(state, project, projectPath, projectIndex, config, buildOrder, Debug.checkDefined(buildResult)); - step++; - break; - case 8 /* Done */: - default: - assertType(step); - } - Debug.assert(step > currentStep); - } + switch (node.kind) { + case 110 /* ThisKeyword */: + return !isExpressionNode(node); + case 197 /* ThisType */: + return true; + } + switch (node.parent.kind) { + case 183 /* TypeReference */: + return true; + case 205 /* ImportType */: + return !node.parent.isTypeOf; + case 233 /* ExpressionWithTypeArguments */: + return isPartOfTypeNode(node.parent); } + return false; } - function needsBuild({ options }, status, config) { - if (status.type !== 3 /* OutOfDateWithPrepend */ || options.force) - return true; - return config.fileNames.length === 0 || !!getConfigFileParsingDiagnostics(config).length || !isIncrementalCompilation(config.options); + function isCallExpressionTarget(node, includeElementAccess = false, skipPastOuterExpressions = false) { + return isCalleeWorker(node, isCallExpression, selectExpressionOfCallOrNewExpressionOrDecorator, includeElementAccess, skipPastOuterExpressions); } - function getNextInvalidatedProjectCreateInfo(state, buildOrder, reportQueue) { - if (!state.projectPendingBuild.size) - return void 0; - if (isCircularBuildOrder(buildOrder)) - return void 0; - const { options, projectPendingBuild } = state; - for (let projectIndex = 0; projectIndex < buildOrder.length; projectIndex++) { - const project = buildOrder[projectIndex]; - const projectPath = toResolvedConfigFilePath(state, project); - const reloadLevel = state.projectPendingBuild.get(projectPath); - if (reloadLevel === void 0) - continue; - if (reportQueue) { - reportQueue = false; - reportBuildQueue(state, buildOrder); - } - const config = parseConfigFile(state, project, projectPath); - if (!config) { - reportParseConfigFileDiagnostic(state, projectPath); - projectPendingBuild.delete(projectPath); - continue; - } - if (reloadLevel === 2 /* Full */) { - watchConfigFile(state, project, projectPath, config); - watchExtendedConfigFiles(state, projectPath, config); - watchWildCardDirectories(state, project, projectPath, config); - watchInputFiles(state, project, projectPath, config); - watchPackageJsonFiles(state, project, projectPath, config); - } else if (reloadLevel === 1 /* Partial */) { - config.fileNames = getFileNamesFromConfigSpecs(config.options.configFile.configFileSpecs, getDirectoryPath(project), config.options, state.parseConfigFileHost); - updateErrorForNoInputFiles(config.fileNames, project, config.options.configFile.configFileSpecs, config.errors, canJsonReportNoInputFiles(config.raw)); - watchInputFiles(state, project, projectPath, config); - watchPackageJsonFiles(state, project, projectPath, config); - } - const status = getUpToDateStatus(state, config, projectPath); - if (!options.force) { - if (status.type === 1 /* UpToDate */) { - verboseReportProjectStatus(state, project, status); - reportAndStoreErrors(state, projectPath, getConfigFileParsingDiagnostics(config)); - projectPendingBuild.delete(projectPath); - if (options.dry) { - reportStatus(state, Diagnostics.Project_0_is_up_to_date, project); - } - continue; - } - if (status.type === 2 /* UpToDateWithUpstreamTypes */ || status.type === 15 /* UpToDateWithInputFileText */) { - reportAndStoreErrors(state, projectPath, getConfigFileParsingDiagnostics(config)); - return { - kind: 2 /* UpdateOutputFileStamps */, - status, - project, - projectPath, - projectIndex, - config - }; - } - } - if (status.type === 12 /* UpstreamBlocked */) { - verboseReportProjectStatus(state, project, status); - reportAndStoreErrors(state, projectPath, getConfigFileParsingDiagnostics(config)); - projectPendingBuild.delete(projectPath); - if (options.verbose) { - reportStatus( - state, - status.upstreamProjectBlocked ? Diagnostics.Skipping_build_of_project_0_because_its_dependency_1_was_not_built : Diagnostics.Skipping_build_of_project_0_because_its_dependency_1_has_errors, - project, - status.upstreamProjectName - ); - } - continue; - } - if (status.type === 16 /* ContainerOnly */) { - verboseReportProjectStatus(state, project, status); - reportAndStoreErrors(state, projectPath, getConfigFileParsingDiagnostics(config)); - projectPendingBuild.delete(projectPath); - continue; - } - return { - kind: needsBuild(state, status, config) ? 0 /* Build */ : 1 /* UpdateBundle */, - status, - project, - projectPath, - projectIndex, - config - }; - } - return void 0; + function isNewExpressionTarget(node, includeElementAccess = false, skipPastOuterExpressions = false) { + return isCalleeWorker(node, isNewExpression, selectExpressionOfCallOrNewExpressionOrDecorator, includeElementAccess, skipPastOuterExpressions); } - function createInvalidatedProjectWithInfo(state, info, buildOrder) { - verboseReportProjectStatus(state, info.project, info.status); - return info.kind !== 2 /* UpdateOutputFileStamps */ ? createBuildOrUpdateInvalidedProject( - info.kind, - state, - info.project, - info.projectPath, - info.projectIndex, - info.config, - buildOrder - ) : createUpdateOutputFileStampsProject( - state, - info.project, - info.projectPath, - info.config, - buildOrder - ); + function isCallOrNewExpressionTarget(node, includeElementAccess = false, skipPastOuterExpressions = false) { + return isCalleeWorker(node, isCallOrNewExpression, selectExpressionOfCallOrNewExpressionOrDecorator, includeElementAccess, skipPastOuterExpressions); } - function getNextInvalidatedProject(state, buildOrder, reportQueue) { - const info = getNextInvalidatedProjectCreateInfo(state, buildOrder, reportQueue); - if (!info) - return info; - return createInvalidatedProjectWithInfo(state, info, buildOrder); + function isTaggedTemplateTag(node, includeElementAccess = false, skipPastOuterExpressions = false) { + return isCalleeWorker(node, isTaggedTemplateExpression, selectTagOfTaggedTemplateExpression, includeElementAccess, skipPastOuterExpressions); } - function listEmittedFile({ write }, proj, file) { - if (write && proj.options.listEmittedFiles) { - write(`TSFILE: ${file}`); - } + function isDecoratorTarget(node, includeElementAccess = false, skipPastOuterExpressions = false) { + return isCalleeWorker(node, isDecorator, selectExpressionOfCallOrNewExpressionOrDecorator, includeElementAccess, skipPastOuterExpressions); } - function getOldProgram({ options, builderPrograms, compilerHost }, proj, parsed) { - if (options.force) - return void 0; - const value = builderPrograms.get(proj); - if (value) - return value; - return readBuilderProgram(parsed.options, compilerHost); + function isJsxOpeningLikeElementTagName(node, includeElementAccess = false, skipPastOuterExpressions = false) { + return isCalleeWorker(node, isJsxOpeningLikeElement, selectTagNameOfJsxOpeningLikeElement, includeElementAccess, skipPastOuterExpressions); } - function afterProgramDone(state, program, config) { - if (program) { - if (state.write) - listFiles(program, state.write); - if (state.host.afterProgramEmitAndDiagnostics) { - state.host.afterProgramEmitAndDiagnostics(program); - } - program.releaseProgram(); - } else if (state.host.afterEmitBundle) { - state.host.afterEmitBundle(config); - } - state.projectCompilerOptions = state.baseCompilerOptions; + function selectExpressionOfCallOrNewExpressionOrDecorator(node) { + return node.expression; } - function buildErrors(state, resolvedPath, program, config, diagnostics, buildResult, errorType) { - const canEmitBuildInfo = program && !outFile(program.getCompilerOptions()); - reportAndStoreErrors(state, resolvedPath, diagnostics); - state.projectStatus.set(resolvedPath, { type: 0 /* Unbuildable */, reason: `${errorType} errors` }); - if (canEmitBuildInfo) - return { buildResult, step: 5 /* EmitBuildInfo */ }; - afterProgramDone(state, program, config); - return { buildResult, step: 7 /* QueueReferencingProjects */ }; + function selectTagOfTaggedTemplateExpression(node) { + return node.tag; } - function isFileWatcherWithModifiedTime(value) { - return !!value.watcher; + function selectTagNameOfJsxOpeningLikeElement(node) { + return node.tagName; } - function getModifiedTime2(state, fileName) { - const path = toPath2(state, fileName); - const existing = state.filesWatched.get(path); - if (state.watch && !!existing) { - if (!isFileWatcherWithModifiedTime(existing)) - return existing; - if (existing.modifiedTime) - return existing.modifiedTime; + function isCalleeWorker(node, pred, calleeSelector, includeElementAccess, skipPastOuterExpressions) { + let target = includeElementAccess ? climbPastPropertyOrElementAccess(node) : climbPastPropertyAccess(node); + if (skipPastOuterExpressions) { + target = skipOuterExpressions(target); } - const result = getModifiedTime(state.host, fileName); - if (state.watch) { - if (existing) - existing.modifiedTime = result; - else - state.filesWatched.set(path, result); + return !!target && !!target.parent && pred(target.parent) && calleeSelector(target.parent) === target; + } + function climbPastPropertyAccess(node) { + return isRightSideOfPropertyAccess(node) ? node.parent : node; + } + function climbPastPropertyOrElementAccess(node) { + return isRightSideOfPropertyAccess(node) || isArgumentExpressionOfElementAccess(node) ? node.parent : node; + } + function getTargetLabel(referenceNode, labelName) { + while (referenceNode) { + if (referenceNode.kind === 256 /* LabeledStatement */ && referenceNode.label.escapedText === labelName) { + return referenceNode.label; + } + referenceNode = referenceNode.parent; } - return result; + return void 0; } - function watchFile(state, file, callback, pollingInterval, options, watchType, project) { - const path = toPath2(state, file); - const existing = state.filesWatched.get(path); - if (existing && isFileWatcherWithModifiedTime(existing)) { - existing.callbacks.push(callback); - } else { - const watcher = state.watchFile( - file, - (fileName, eventKind, modifiedTime) => { - const existing2 = Debug.checkDefined(state.filesWatched.get(path)); - Debug.assert(isFileWatcherWithModifiedTime(existing2)); - existing2.modifiedTime = modifiedTime; - existing2.callbacks.forEach((cb) => cb(fileName, eventKind, modifiedTime)); - }, - pollingInterval, - options, - watchType, - project - ); - state.filesWatched.set(path, { callbacks: [callback], watcher, modifiedTime: existing }); + function hasPropertyAccessExpressionWithName(node, funcName) { + if (!isPropertyAccessExpression(node.expression)) { + return false; } - return { - close: () => { - const existing2 = Debug.checkDefined(state.filesWatched.get(path)); - Debug.assert(isFileWatcherWithModifiedTime(existing2)); - if (existing2.callbacks.length === 1) { - state.filesWatched.delete(path); - closeFileWatcherOf(existing2); - } else { - unorderedRemoveItem(existing2.callbacks, callback); - } - } - }; + return node.expression.name.text === funcName; } - function getOutputTimeStampMap(state, resolvedConfigFilePath) { - if (!state.watch) - return void 0; - let result = state.outputTimeStamps.get(resolvedConfigFilePath); - if (!result) - state.outputTimeStamps.set(resolvedConfigFilePath, result = /* @__PURE__ */ new Map()); - return result; + function isJumpStatementTarget(node) { + var _a; + return isIdentifier(node) && ((_a = tryCast(node.parent, isBreakOrContinueStatement)) == null ? void 0 : _a.label) === node; } - function setBuildInfo(state, buildInfo, resolvedConfigPath, options, resultFlags) { - const buildInfoPath = getTsBuildInfoEmitOutputFilePath(options); - const existing = getBuildInfoCacheEntry(state, buildInfoPath, resolvedConfigPath); - const modifiedTime = getCurrentTime(state.host); - if (existing) { - existing.buildInfo = buildInfo; - existing.modifiedTime = modifiedTime; - if (!(resultFlags & 2 /* DeclarationOutputUnchanged */)) - existing.latestChangedDtsTime = modifiedTime; - } else { - state.buildInfoCache.set(resolvedConfigPath, { - path: toPath2(state, buildInfoPath), - buildInfo, - modifiedTime, - latestChangedDtsTime: resultFlags & 2 /* DeclarationOutputUnchanged */ ? void 0 : modifiedTime - }); - } + function isLabelOfLabeledStatement(node) { + var _a; + return isIdentifier(node) && ((_a = tryCast(node.parent, isLabeledStatement)) == null ? void 0 : _a.label) === node; } - function getBuildInfoCacheEntry(state, buildInfoPath, resolvedConfigPath) { - const path = toPath2(state, buildInfoPath); - const existing = state.buildInfoCache.get(resolvedConfigPath); - return (existing == null ? void 0 : existing.path) === path ? existing : void 0; + function isLabelName(node) { + return isLabelOfLabeledStatement(node) || isJumpStatementTarget(node); } - function getBuildInfo3(state, buildInfoPath, resolvedConfigPath, modifiedTime) { - const path = toPath2(state, buildInfoPath); - const existing = state.buildInfoCache.get(resolvedConfigPath); - if (existing !== void 0 && existing.path === path) { - return existing.buildInfo || void 0; - } - const value = state.readFileWithCache(buildInfoPath); - const buildInfo = value ? getBuildInfo(buildInfoPath, value) : void 0; - state.buildInfoCache.set(resolvedConfigPath, { path, buildInfo: buildInfo || false, modifiedTime: modifiedTime || missingFileModifiedTime }); - return buildInfo; + function isTagName(node) { + var _a; + return ((_a = tryCast(node.parent, isJSDocTag)) == null ? void 0 : _a.tagName) === node; } - function checkConfigFileUpToDateStatus(state, configFile, oldestOutputFileTime, oldestOutputFileName) { - const tsconfigTime = getModifiedTime2(state, configFile); - if (oldestOutputFileTime < tsconfigTime) { - return { - type: 6 /* OutOfDateWithSelf */, - outOfDateOutputFileName: oldestOutputFileName, - newerInputFileName: configFile - }; - } + function isRightSideOfQualifiedName(node) { + var _a; + return ((_a = tryCast(node.parent, isQualifiedName)) == null ? void 0 : _a.right) === node; } - function getUpToDateStatusWorker(state, project, resolvedPath) { - var _a, _b; - if (!project.fileNames.length && !canJsonReportNoInputFiles(project.raw)) { - return { - type: 16 /* ContainerOnly */ - }; + function isRightSideOfPropertyAccess(node) { + var _a; + return ((_a = tryCast(node.parent, isPropertyAccessExpression)) == null ? void 0 : _a.name) === node; + } + function isArgumentExpressionOfElementAccess(node) { + var _a; + return ((_a = tryCast(node.parent, isElementAccessExpression)) == null ? void 0 : _a.argumentExpression) === node; + } + function isNameOfModuleDeclaration(node) { + var _a; + return ((_a = tryCast(node.parent, isModuleDeclaration)) == null ? void 0 : _a.name) === node; + } + function isNameOfFunctionDeclaration(node) { + var _a; + return isIdentifier(node) && ((_a = tryCast(node.parent, isFunctionLike)) == null ? void 0 : _a.name) === node; + } + function isLiteralNameOfPropertyDeclarationOrIndexAccess(node) { + switch (node.parent.kind) { + case 172 /* PropertyDeclaration */: + case 171 /* PropertySignature */: + case 303 /* PropertyAssignment */: + case 306 /* EnumMember */: + case 174 /* MethodDeclaration */: + case 173 /* MethodSignature */: + case 177 /* GetAccessor */: + case 178 /* SetAccessor */: + case 267 /* ModuleDeclaration */: + return getNameOfDeclaration(node.parent) === node; + case 212 /* ElementAccessExpression */: + return node.parent.argumentExpression === node; + case 167 /* ComputedPropertyName */: + return true; + case 201 /* LiteralType */: + return node.parent.parent.kind === 199 /* IndexedAccessType */; + default: + return false; } - let referenceStatuses; - const force = !!state.options.force; - if (project.projectReferences) { - state.projectStatus.set(resolvedPath, { type: 13 /* ComputingUpstream */ }); - for (const ref of project.projectReferences) { - const resolvedRef = resolveProjectReferencePath(ref); - const resolvedRefPath = toResolvedConfigFilePath(state, resolvedRef); - const resolvedConfig = parseConfigFile(state, resolvedRef, resolvedRefPath); - const refStatus = getUpToDateStatus(state, resolvedConfig, resolvedRefPath); - if (refStatus.type === 13 /* ComputingUpstream */ || refStatus.type === 16 /* ContainerOnly */) { - continue; - } - if (refStatus.type === 0 /* Unbuildable */ || refStatus.type === 12 /* UpstreamBlocked */) { - return { - type: 12 /* UpstreamBlocked */, - upstreamProjectName: ref.path, - upstreamProjectBlocked: refStatus.type === 12 /* UpstreamBlocked */ - }; - } - if (refStatus.type !== 1 /* UpToDate */) { - return { - type: 11 /* UpstreamOutOfDate */, - upstreamProjectName: ref.path - }; - } - if (!force) - (referenceStatuses || (referenceStatuses = [])).push({ ref, refStatus, resolvedRefPath, resolvedConfig }); - } + } + function isExpressionOfExternalModuleImportEqualsDeclaration(node) { + return isExternalModuleImportEqualsDeclaration(node.parent.parent) && getExternalModuleImportEqualsDeclarationExpression(node.parent.parent) === node; + } + function getContainerNode(node) { + if (isJSDocTypeAlias(node)) { + node = node.parent.parent; } - if (force) - return { type: 17 /* ForceBuild */ }; - const { host } = state; - const buildInfoPath = getTsBuildInfoEmitOutputFilePath(project.options); - let oldestOutputFileName; - let oldestOutputFileTime = maximumDate; - let buildInfoTime; - let buildInfoProgram; - let buildInfoVersionMap; - if (buildInfoPath) { - const buildInfoCacheEntry2 = getBuildInfoCacheEntry(state, buildInfoPath, resolvedPath); - buildInfoTime = (buildInfoCacheEntry2 == null ? void 0 : buildInfoCacheEntry2.modifiedTime) || getModifiedTime(host, buildInfoPath); - if (buildInfoTime === missingFileModifiedTime) { - if (!buildInfoCacheEntry2) { - state.buildInfoCache.set(resolvedPath, { - path: toPath2(state, buildInfoPath), - buildInfo: false, - modifiedTime: buildInfoTime - }); - } - return { - type: 4 /* OutputMissing */, - missingOutputFileName: buildInfoPath - }; - } - const buildInfo = getBuildInfo3(state, buildInfoPath, resolvedPath, buildInfoTime); - if (!buildInfo) { - return { - type: 5 /* ErrorReadingFile */, - fileName: buildInfoPath - }; - } - if ((buildInfo.bundle || buildInfo.program) && buildInfo.version !== version) { - return { - type: 14 /* TsVersionOutputOfDate */, - version: buildInfo.version - }; + while (true) { + node = node.parent; + if (!node) { + return void 0; } - if (buildInfo.program) { - if (((_a = buildInfo.program.changeFileSet) == null ? void 0 : _a.length) || (!project.options.noEmit ? (_b = buildInfo.program.affectedFilesPendingEmit) == null ? void 0 : _b.length : some(buildInfo.program.semanticDiagnosticsPerFile, isArray))) { - return { - type: 8 /* OutOfDateBuildInfo */, - buildInfoFile: buildInfoPath - }; - } - if (!project.options.noEmit && getPendingEmitKind(project.options, buildInfo.program.options || {})) { - return { - type: 9 /* OutOfDateOptions */, - buildInfoFile: buildInfoPath - }; - } - buildInfoProgram = buildInfo.program; + switch (node.kind) { + case 312 /* SourceFile */: + case 174 /* MethodDeclaration */: + case 173 /* MethodSignature */: + case 262 /* FunctionDeclaration */: + case 218 /* FunctionExpression */: + case 177 /* GetAccessor */: + case 178 /* SetAccessor */: + case 263 /* ClassDeclaration */: + case 264 /* InterfaceDeclaration */: + case 266 /* EnumDeclaration */: + case 267 /* ModuleDeclaration */: + return node; } - oldestOutputFileTime = buildInfoTime; - oldestOutputFileName = buildInfoPath; } - let newestInputFileName = void 0; - let newestInputFileTime = minimumDate; - let pseudoInputUpToDate = false; - const seenRoots = /* @__PURE__ */ new Set(); - for (const inputFile of project.fileNames) { - const inputTime = getModifiedTime2(state, inputFile); - if (inputTime === missingFileModifiedTime) { - return { - type: 0 /* Unbuildable */, - reason: `${inputFile} does not exist` - }; - } - if (buildInfoTime && buildInfoTime < inputTime) { - let version2; - let currentVersion; - if (buildInfoProgram) { - if (!buildInfoVersionMap) - buildInfoVersionMap = getBuildInfoFileVersionMap(buildInfoProgram, buildInfoPath, host); - version2 = buildInfoVersionMap.fileInfos.get(toPath2(state, inputFile)); - const text = version2 ? state.readFileWithCache(inputFile) : void 0; - currentVersion = text !== void 0 ? getSourceFileVersionAsHashFromText(host, text) : void 0; - if (version2 && version2 === currentVersion) - pseudoInputUpToDate = true; - } - if (!version2 || version2 !== currentVersion) { - return { - type: 6 /* OutOfDateWithSelf */, - outOfDateOutputFileName: buildInfoPath, - newerInputFileName: inputFile - }; + } + function getNodeKind(node) { + switch (node.kind) { + case 312 /* SourceFile */: + return isExternalModule(node) ? "module" /* moduleElement */ : "script" /* scriptElement */; + case 267 /* ModuleDeclaration */: + return "module" /* moduleElement */; + case 263 /* ClassDeclaration */: + case 231 /* ClassExpression */: + return "class" /* classElement */; + case 264 /* InterfaceDeclaration */: + return "interface" /* interfaceElement */; + case 265 /* TypeAliasDeclaration */: + case 345 /* JSDocCallbackTag */: + case 353 /* JSDocTypedefTag */: + return "type" /* typeElement */; + case 266 /* EnumDeclaration */: + return "enum" /* enumElement */; + case 260 /* VariableDeclaration */: + return getKindOfVariableDeclaration(node); + case 208 /* BindingElement */: + return getKindOfVariableDeclaration(getRootDeclaration(node)); + case 219 /* ArrowFunction */: + case 262 /* FunctionDeclaration */: + case 218 /* FunctionExpression */: + return "function" /* functionElement */; + case 177 /* GetAccessor */: + return "getter" /* memberGetAccessorElement */; + case 178 /* SetAccessor */: + return "setter" /* memberSetAccessorElement */; + case 174 /* MethodDeclaration */: + case 173 /* MethodSignature */: + return "method" /* memberFunctionElement */; + case 303 /* PropertyAssignment */: + const { initializer } = node; + return isFunctionLike(initializer) ? "method" /* memberFunctionElement */ : "property" /* memberVariableElement */; + case 172 /* PropertyDeclaration */: + case 171 /* PropertySignature */: + case 304 /* ShorthandPropertyAssignment */: + case 305 /* SpreadAssignment */: + return "property" /* memberVariableElement */; + case 181 /* IndexSignature */: + return "index" /* indexSignatureElement */; + case 180 /* ConstructSignature */: + return "construct" /* constructSignatureElement */; + case 179 /* CallSignature */: + return "call" /* callSignatureElement */; + case 176 /* Constructor */: + case 175 /* ClassStaticBlockDeclaration */: + return "constructor" /* constructorImplementationElement */; + case 168 /* TypeParameter */: + return "type parameter" /* typeParameterElement */; + case 306 /* EnumMember */: + return "enum member" /* enumMemberElement */; + case 169 /* Parameter */: + return hasSyntacticModifier(node, 31 /* ParameterPropertyModifier */) ? "property" /* memberVariableElement */ : "parameter" /* parameterElement */; + case 271 /* ImportEqualsDeclaration */: + case 276 /* ImportSpecifier */: + case 281 /* ExportSpecifier */: + case 274 /* NamespaceImport */: + case 280 /* NamespaceExport */: + return "alias" /* alias */; + case 226 /* BinaryExpression */: + const kind = getAssignmentDeclarationKind(node); + const { right } = node; + switch (kind) { + case 7 /* ObjectDefinePropertyValue */: + case 8 /* ObjectDefinePropertyExports */: + case 9 /* ObjectDefinePrototypeProperty */: + case 0 /* None */: + return "" /* unknown */; + case 1 /* ExportsProperty */: + case 2 /* ModuleExports */: + const rightKind = getNodeKind(right); + return rightKind === "" /* unknown */ ? "const" /* constElement */ : rightKind; + case 3 /* PrototypeProperty */: + return isFunctionExpression(right) ? "method" /* memberFunctionElement */ : "property" /* memberVariableElement */; + case 4 /* ThisProperty */: + return "property" /* memberVariableElement */; + case 5 /* Property */: + return isFunctionExpression(right) ? "method" /* memberFunctionElement */ : "property" /* memberVariableElement */; + case 6 /* Prototype */: + return "local class" /* localClassElement */; + default: { + assertType(kind); + return "" /* unknown */; + } } - } - if (inputTime > newestInputFileTime) { - newestInputFileName = inputFile; - newestInputFileTime = inputTime; - } - if (buildInfoProgram) - seenRoots.add(toPath2(state, inputFile)); + case 80 /* Identifier */: + return isImportClause(node.parent) ? "alias" /* alias */ : "" /* unknown */; + case 277 /* ExportAssignment */: + const scriptKind = getNodeKind(node.expression); + return scriptKind === "" /* unknown */ ? "const" /* constElement */ : scriptKind; + default: + return "" /* unknown */; } - if (buildInfoProgram) { - if (!buildInfoVersionMap) - buildInfoVersionMap = getBuildInfoFileVersionMap(buildInfoProgram, buildInfoPath, host); - for (const existingRoot of buildInfoVersionMap.roots) { - if (!seenRoots.has(existingRoot)) { - return { - type: 10 /* OutOfDateRoots */, - buildInfoFile: buildInfoPath, - inputFile: existingRoot - }; - } - } + function getKindOfVariableDeclaration(v) { + return isVarConst(v) ? "const" /* constElement */ : isLet(v) ? "let" /* letElement */ : "var" /* variableElement */; } - if (!buildInfoPath) { - const outputs = getAllProjectOutputs(project, !host.useCaseSensitiveFileNames()); - const outputTimeStampMap = getOutputTimeStampMap(state, resolvedPath); - for (const output of outputs) { - const path = toPath2(state, output); - let outputTime = outputTimeStampMap == null ? void 0 : outputTimeStampMap.get(path); - if (!outputTime) { - outputTime = getModifiedTime(state.host, output); - outputTimeStampMap == null ? void 0 : outputTimeStampMap.set(path, outputTime); - } - if (outputTime === missingFileModifiedTime) { - return { - type: 4 /* OutputMissing */, - missingOutputFileName: output - }; - } - if (outputTime < newestInputFileTime) { - return { - type: 6 /* OutOfDateWithSelf */, - outOfDateOutputFileName: output, - newerInputFileName: newestInputFileName - }; + } + function isThis(node) { + switch (node.kind) { + case 110 /* ThisKeyword */: + return true; + case 80 /* Identifier */: + return identifierIsThisKeyword(node) && node.parent.kind === 169 /* Parameter */; + default: + return false; + } + } + function getLineStartPositionForPosition(position, sourceFile) { + const lineStarts = getLineStarts(sourceFile); + const line = sourceFile.getLineAndCharacterOfPosition(position).line; + return lineStarts[line]; + } + function rangeContainsRange(r1, r2) { + return startEndContainsRange(r1.pos, r1.end, r2); + } + function rangeContainsRangeExclusive(r1, r2) { + return rangeContainsPositionExclusive(r1, r2.pos) && rangeContainsPositionExclusive(r1, r2.end); + } + function rangeContainsPosition(r, pos) { + return r.pos <= pos && pos <= r.end; + } + function rangeContainsPositionExclusive(r, pos) { + return r.pos < pos && pos < r.end; + } + function startEndContainsRange(start, end, range) { + return start <= range.pos && end >= range.end; + } + function rangeContainsStartEnd(range, start, end) { + return range.pos <= start && range.end >= end; + } + function rangeOverlapsWithStartEnd(r1, start, end) { + return startEndOverlapsWithStartEnd(r1.pos, r1.end, start, end); + } + function nodeOverlapsWithStartEnd(node, sourceFile, start, end) { + return startEndOverlapsWithStartEnd(node.getStart(sourceFile), node.end, start, end); + } + function startEndOverlapsWithStartEnd(start1, end1, start2, end2) { + const start = Math.max(start1, start2); + const end = Math.min(end1, end2); + return start < end; + } + function positionBelongsToNode(candidate, position, sourceFile) { + Debug.assert(candidate.pos <= position); + return position < candidate.end || !isCompletedNode(candidate, sourceFile); + } + function isCompletedNode(n, sourceFile) { + if (n === void 0 || nodeIsMissing(n)) { + return false; + } + switch (n.kind) { + case 263 /* ClassDeclaration */: + case 264 /* InterfaceDeclaration */: + case 266 /* EnumDeclaration */: + case 210 /* ObjectLiteralExpression */: + case 206 /* ObjectBindingPattern */: + case 187 /* TypeLiteral */: + case 241 /* Block */: + case 268 /* ModuleBlock */: + case 269 /* CaseBlock */: + case 275 /* NamedImports */: + case 279 /* NamedExports */: + return nodeEndsWith(n, 20 /* CloseBraceToken */, sourceFile); + case 299 /* CatchClause */: + return isCompletedNode(n.block, sourceFile); + case 214 /* NewExpression */: + if (!n.arguments) { + return true; } - if (outputTime < oldestOutputFileTime) { - oldestOutputFileTime = outputTime; - oldestOutputFileName = output; + case 213 /* CallExpression */: + case 217 /* ParenthesizedExpression */: + case 196 /* ParenthesizedType */: + return nodeEndsWith(n, 22 /* CloseParenToken */, sourceFile); + case 184 /* FunctionType */: + case 185 /* ConstructorType */: + return isCompletedNode(n.type, sourceFile); + case 176 /* Constructor */: + case 177 /* GetAccessor */: + case 178 /* SetAccessor */: + case 262 /* FunctionDeclaration */: + case 218 /* FunctionExpression */: + case 174 /* MethodDeclaration */: + case 173 /* MethodSignature */: + case 180 /* ConstructSignature */: + case 179 /* CallSignature */: + case 219 /* ArrowFunction */: + if (n.body) { + return isCompletedNode(n.body, sourceFile); } - } - } - const buildInfoCacheEntry = state.buildInfoCache.get(resolvedPath); - let pseudoUpToDate = false; - let usesPrepend = false; - let upstreamChangedProject; - if (referenceStatuses) { - for (const { ref, refStatus, resolvedConfig, resolvedRefPath } of referenceStatuses) { - usesPrepend = usesPrepend || !!ref.prepend; - if (refStatus.newestInputFileTime && refStatus.newestInputFileTime <= oldestOutputFileTime) { - continue; + if (n.type) { + return isCompletedNode(n.type, sourceFile); } - if (buildInfoCacheEntry && hasSameBuildInfo(state, buildInfoCacheEntry, resolvedRefPath)) { - return { - type: 7 /* OutOfDateWithUpstream */, - outOfDateOutputFileName: buildInfoPath, - newerProjectName: ref.path - }; + return hasChildOfKind(n, 22 /* CloseParenToken */, sourceFile); + case 267 /* ModuleDeclaration */: + return !!n.body && isCompletedNode(n.body, sourceFile); + case 245 /* IfStatement */: + if (n.elseStatement) { + return isCompletedNode(n.elseStatement, sourceFile); } - const newestDeclarationFileContentChangedTime = getLatestChangedDtsTime(state, resolvedConfig.options, resolvedRefPath); - if (newestDeclarationFileContentChangedTime && newestDeclarationFileContentChangedTime <= oldestOutputFileTime) { - pseudoUpToDate = true; - upstreamChangedProject = ref.path; - continue; + return isCompletedNode(n.thenStatement, sourceFile); + case 244 /* ExpressionStatement */: + return isCompletedNode(n.expression, sourceFile) || hasChildOfKind(n, 27 /* SemicolonToken */, sourceFile); + case 209 /* ArrayLiteralExpression */: + case 207 /* ArrayBindingPattern */: + case 212 /* ElementAccessExpression */: + case 167 /* ComputedPropertyName */: + case 189 /* TupleType */: + return nodeEndsWith(n, 24 /* CloseBracketToken */, sourceFile); + case 181 /* IndexSignature */: + if (n.type) { + return isCompletedNode(n.type, sourceFile); } - Debug.assert(oldestOutputFileName !== void 0, "Should have an oldest output filename here"); - return { - type: 7 /* OutOfDateWithUpstream */, - outOfDateOutputFileName: oldestOutputFileName, - newerProjectName: ref.path - }; - } - } - const configStatus = checkConfigFileUpToDateStatus(state, project.options.configFilePath, oldestOutputFileTime, oldestOutputFileName); - if (configStatus) - return configStatus; - const extendedConfigStatus = forEach(project.options.configFile.extendedSourceFiles || emptyArray, (configFile) => checkConfigFileUpToDateStatus(state, configFile, oldestOutputFileTime, oldestOutputFileName)); - if (extendedConfigStatus) - return extendedConfigStatus; - const dependentPackageFileStatus = forEach( - state.lastCachedPackageJsonLookups.get(resolvedPath) || emptyArray, - ([path]) => checkConfigFileUpToDateStatus(state, path, oldestOutputFileTime, oldestOutputFileName) - ); - if (dependentPackageFileStatus) - return dependentPackageFileStatus; - if (usesPrepend && pseudoUpToDate) { - return { - type: 3 /* OutOfDateWithPrepend */, - outOfDateOutputFileName: oldestOutputFileName, - newerProjectName: upstreamChangedProject - }; + return hasChildOfKind(n, 24 /* CloseBracketToken */, sourceFile); + case 296 /* CaseClause */: + case 297 /* DefaultClause */: + return false; + case 248 /* ForStatement */: + case 249 /* ForInStatement */: + case 250 /* ForOfStatement */: + case 247 /* WhileStatement */: + return isCompletedNode(n.statement, sourceFile); + case 246 /* DoStatement */: + return hasChildOfKind(n, 117 /* WhileKeyword */, sourceFile) ? nodeEndsWith(n, 22 /* CloseParenToken */, sourceFile) : isCompletedNode(n.statement, sourceFile); + case 186 /* TypeQuery */: + return isCompletedNode(n.exprName, sourceFile); + case 221 /* TypeOfExpression */: + case 220 /* DeleteExpression */: + case 222 /* VoidExpression */: + case 229 /* YieldExpression */: + case 230 /* SpreadElement */: + const unaryWordExpression = n; + return isCompletedNode(unaryWordExpression.expression, sourceFile); + case 215 /* TaggedTemplateExpression */: + return isCompletedNode(n.template, sourceFile); + case 228 /* TemplateExpression */: + const lastSpan = lastOrUndefined(n.templateSpans); + return isCompletedNode(lastSpan, sourceFile); + case 239 /* TemplateSpan */: + return nodeIsPresent(n.literal); + case 278 /* ExportDeclaration */: + case 272 /* ImportDeclaration */: + return nodeIsPresent(n.moduleSpecifier); + case 224 /* PrefixUnaryExpression */: + return isCompletedNode(n.operand, sourceFile); + case 226 /* BinaryExpression */: + return isCompletedNode(n.right, sourceFile); + case 227 /* ConditionalExpression */: + return isCompletedNode(n.whenFalse, sourceFile); + default: + return true; } + } + function nodeEndsWith(n, expectedLastToken, sourceFile) { + const children = n.getChildren(sourceFile); + if (children.length) { + const lastChild = last(children); + if (lastChild.kind === expectedLastToken) { + return true; + } else if (lastChild.kind === 27 /* SemicolonToken */ && children.length !== 1) { + return children[children.length - 2].kind === expectedLastToken; + } + } + return false; + } + function findListItemInfo(node) { + const list = findContainingList(node); + if (!list) { + return void 0; + } + const children = list.getChildren(); + const listItemIndex = indexOfNode(children, node); return { - type: pseudoUpToDate ? 2 /* UpToDateWithUpstreamTypes */ : pseudoInputUpToDate ? 15 /* UpToDateWithInputFileText */ : 1 /* UpToDate */, - newestInputFileTime, - newestInputFileName, - oldestOutputFileName + listItemIndex, + list }; } - function hasSameBuildInfo(state, buildInfoCacheEntry, resolvedRefPath) { - const refBuildInfo = state.buildInfoCache.get(resolvedRefPath); - return refBuildInfo.path === buildInfoCacheEntry.path; + function hasChildOfKind(n, kind, sourceFile) { + return !!findChildOfKind(n, kind, sourceFile); } - function getUpToDateStatus(state, project, resolvedPath) { - if (project === void 0) { - return { type: 0 /* Unbuildable */, reason: "File deleted mid-build" }; + function findChildOfKind(n, kind, sourceFile) { + return find(n.getChildren(sourceFile), (c) => c.kind === kind); + } + function findContainingList(node) { + const syntaxList = find(node.parent.getChildren(), (c) => isSyntaxList(c) && rangeContainsRange(c, node)); + Debug.assert(!syntaxList || contains(syntaxList.getChildren(), node)); + return syntaxList; + } + function isDefaultModifier2(node) { + return node.kind === 90 /* DefaultKeyword */; + } + function isClassKeyword(node) { + return node.kind === 86 /* ClassKeyword */; + } + function isFunctionKeyword(node) { + return node.kind === 100 /* FunctionKeyword */; + } + function getAdjustedLocationForClass(node) { + if (isNamedDeclaration(node)) { + return node.name; } - const prior = state.projectStatus.get(resolvedPath); - if (prior !== void 0) { - return prior; + if (isClassDeclaration(node)) { + const defaultModifier = node.modifiers && find(node.modifiers, isDefaultModifier2); + if (defaultModifier) + return defaultModifier; + } + if (isClassExpression(node)) { + const classKeyword = find(node.getChildren(), isClassKeyword); + if (classKeyword) + return classKeyword; } - mark("SolutionBuilder::beforeUpToDateCheck"); - const actual = getUpToDateStatusWorker(state, project, resolvedPath); - mark("SolutionBuilder::afterUpToDateCheck"); - measure("SolutionBuilder::Up-to-date check", "SolutionBuilder::beforeUpToDateCheck", "SolutionBuilder::afterUpToDateCheck"); - state.projectStatus.set(resolvedPath, actual); - return actual; } - function updateOutputTimestampsWorker(state, proj, projectPath, verboseMessage, skipOutputs) { - if (proj.options.noEmit) - return; - let now; - const buildInfoPath = getTsBuildInfoEmitOutputFilePath(proj.options); - if (buildInfoPath) { - if (!(skipOutputs == null ? void 0 : skipOutputs.has(toPath2(state, buildInfoPath)))) { - if (!!state.options.verbose) - reportStatus(state, verboseMessage, proj.options.configFilePath); - state.host.setModifiedTime(buildInfoPath, now = getCurrentTime(state.host)); - getBuildInfoCacheEntry(state, buildInfoPath, projectPath).modifiedTime = now; - } - state.outputTimeStamps.delete(projectPath); - return; + function getAdjustedLocationForFunction(node) { + if (isNamedDeclaration(node)) { + return node.name; } - const { host } = state; - const outputs = getAllProjectOutputs(proj, !host.useCaseSensitiveFileNames()); - const outputTimeStampMap = getOutputTimeStampMap(state, projectPath); - const modifiedOutputs = outputTimeStampMap ? /* @__PURE__ */ new Set() : void 0; - if (!skipOutputs || outputs.length !== skipOutputs.size) { - let reportVerbose = !!state.options.verbose; - for (const file of outputs) { - const path = toPath2(state, file); - if (skipOutputs == null ? void 0 : skipOutputs.has(path)) - continue; - if (reportVerbose) { - reportVerbose = false; - reportStatus(state, verboseMessage, proj.options.configFilePath); - } - host.setModifiedTime(file, now || (now = getCurrentTime(state.host))); - if (outputTimeStampMap) { - outputTimeStampMap.set(path, now); - modifiedOutputs.add(path); - } - } + if (isFunctionDeclaration(node)) { + const defaultModifier = find(node.modifiers, isDefaultModifier2); + if (defaultModifier) + return defaultModifier; } - outputTimeStampMap == null ? void 0 : outputTimeStampMap.forEach((_value, key) => { - if (!(skipOutputs == null ? void 0 : skipOutputs.has(key)) && !modifiedOutputs.has(key)) - outputTimeStampMap.delete(key); + if (isFunctionExpression(node)) { + const functionKeyword = find(node.getChildren(), isFunctionKeyword); + if (functionKeyword) + return functionKeyword; + } + } + function getAncestorTypeNode(node) { + let lastTypeNode; + findAncestor(node, (a) => { + if (isTypeNode(a)) { + lastTypeNode = a; + } + return !isQualifiedName(a.parent) && !isTypeNode(a.parent) && !isTypeElement(a.parent); }); + return lastTypeNode; } - function getLatestChangedDtsTime(state, options, resolvedConfigPath) { - if (!options.composite) + function getContextualTypeFromParentOrAncestorTypeNode(node, checker) { + if (node.flags & (16777216 /* JSDoc */ & ~524288 /* JavaScriptFile */)) return void 0; - const entry = Debug.checkDefined(state.buildInfoCache.get(resolvedConfigPath)); - if (entry.latestChangedDtsTime !== void 0) - return entry.latestChangedDtsTime || void 0; - const latestChangedDtsTime = entry.buildInfo && entry.buildInfo.program && entry.buildInfo.program.latestChangedDtsFile ? state.host.getModifiedTime(getNormalizedAbsolutePath(entry.buildInfo.program.latestChangedDtsFile, getDirectoryPath(entry.path))) : void 0; - entry.latestChangedDtsTime = latestChangedDtsTime || false; - return latestChangedDtsTime; + const contextualType = getContextualTypeFromParent(node, checker); + if (contextualType) + return contextualType; + const ancestorTypeNode = getAncestorTypeNode(node); + return ancestorTypeNode && checker.getTypeAtLocation(ancestorTypeNode); } - function updateOutputTimestamps(state, proj, resolvedPath) { - if (state.options.dry) { - return reportStatus(state, Diagnostics.A_non_dry_build_would_update_timestamps_for_output_of_project_0, proj.options.configFilePath); + function getAdjustedLocationForDeclaration(node, forRename) { + if (!forRename) { + switch (node.kind) { + case 263 /* ClassDeclaration */: + case 231 /* ClassExpression */: + return getAdjustedLocationForClass(node); + case 262 /* FunctionDeclaration */: + case 218 /* FunctionExpression */: + return getAdjustedLocationForFunction(node); + case 176 /* Constructor */: + return node; + } + } + if (isNamedDeclaration(node)) { + return node.name; } - updateOutputTimestampsWorker(state, proj, resolvedPath, Diagnostics.Updating_output_timestamps_of_project_0); - state.projectStatus.set(resolvedPath, { - type: 1 /* UpToDate */, - oldestOutputFileName: getFirstProjectOutput(proj, !state.host.useCaseSensitiveFileNames()) - }); } - function queueReferencingProjects(state, project, projectPath, projectIndex, config, buildOrder, buildResult) { - if (buildResult & 124 /* AnyErrors */) - return; - if (!config.options.composite) - return; - for (let index = projectIndex + 1; index < buildOrder.length; index++) { - const nextProject = buildOrder[index]; - const nextProjectPath = toResolvedConfigFilePath(state, nextProject); - if (state.projectPendingBuild.has(nextProjectPath)) - continue; - const nextProjectConfig = parseConfigFile(state, nextProject, nextProjectPath); - if (!nextProjectConfig || !nextProjectConfig.projectReferences) - continue; - for (const ref of nextProjectConfig.projectReferences) { - const resolvedRefPath = resolveProjectName(state, ref.path); - if (toResolvedConfigFilePath(state, resolvedRefPath) !== projectPath) - continue; - const status = state.projectStatus.get(nextProjectPath); - if (status) { - switch (status.type) { - case 1 /* UpToDate */: - if (buildResult & 2 /* DeclarationOutputUnchanged */) { - if (ref.prepend) { - state.projectStatus.set(nextProjectPath, { - type: 3 /* OutOfDateWithPrepend */, - outOfDateOutputFileName: status.oldestOutputFileName, - newerProjectName: project - }); - } else { - status.type = 2 /* UpToDateWithUpstreamTypes */; - } - break; - } - case 15 /* UpToDateWithInputFileText */: - case 2 /* UpToDateWithUpstreamTypes */: - case 3 /* OutOfDateWithPrepend */: - if (!(buildResult & 2 /* DeclarationOutputUnchanged */)) { - state.projectStatus.set(nextProjectPath, { - type: 7 /* OutOfDateWithUpstream */, - outOfDateOutputFileName: status.type === 3 /* OutOfDateWithPrepend */ ? status.outOfDateOutputFileName : status.oldestOutputFileName, - newerProjectName: project - }); - } - break; - case 12 /* UpstreamBlocked */: - if (toResolvedConfigFilePath(state, resolveProjectName(state, status.upstreamProjectName)) === projectPath) { - clearProjectStatus(state, nextProjectPath); - } - break; + function getAdjustedLocationForImportDeclaration(node, forRename) { + if (node.importClause) { + if (node.importClause.name && node.importClause.namedBindings) { + return; + } + if (node.importClause.name) { + return node.importClause.name; + } + if (node.importClause.namedBindings) { + if (isNamedImports(node.importClause.namedBindings)) { + const onlyBinding = singleOrUndefined(node.importClause.namedBindings.elements); + if (!onlyBinding) { + return; } + return onlyBinding.name; + } else if (isNamespaceImport(node.importClause.namedBindings)) { + return node.importClause.namedBindings.name; } - addProjToQueue(state, nextProjectPath, 0 /* None */); - break; } } + if (!forRename) { + return node.moduleSpecifier; + } } - function build(state, project, cancellationToken, writeFile2, getCustomTransformers, onlyReferences) { - mark("SolutionBuilder::beforeBuild"); - const result = buildWorker(state, project, cancellationToken, writeFile2, getCustomTransformers, onlyReferences); - mark("SolutionBuilder::afterBuild"); - measure("SolutionBuilder::Build", "SolutionBuilder::beforeBuild", "SolutionBuilder::afterBuild"); - return result; - } - function buildWorker(state, project, cancellationToken, writeFile2, getCustomTransformers, onlyReferences) { - const buildOrder = getBuildOrderFor(state, project, onlyReferences); - if (!buildOrder) - return 3 /* InvalidProject_OutputsSkipped */; - setupInitialBuild(state, cancellationToken); - let reportQueue = true; - let successfulProjects = 0; - while (true) { - const invalidatedProject = getNextInvalidatedProject(state, buildOrder, reportQueue); - if (!invalidatedProject) - break; - reportQueue = false; - invalidatedProject.done(cancellationToken, writeFile2, getCustomTransformers == null ? void 0 : getCustomTransformers(invalidatedProject.project)); - if (!state.diagnostics.has(invalidatedProject.projectPath)) - successfulProjects++; + function getAdjustedLocationForExportDeclaration(node, forRename) { + if (node.exportClause) { + if (isNamedExports(node.exportClause)) { + const onlyBinding = singleOrUndefined(node.exportClause.elements); + if (!onlyBinding) { + return; + } + return node.exportClause.elements[0].name; + } else if (isNamespaceExport(node.exportClause)) { + return node.exportClause.name; + } + } + if (!forRename) { + return node.moduleSpecifier; } - disableCache(state); - reportErrorSummary(state, buildOrder); - startWatching(state, buildOrder); - return isCircularBuildOrder(buildOrder) ? 4 /* ProjectReferenceCycle_OutputsSkipped */ : !buildOrder.some((p) => state.diagnostics.has(toResolvedConfigFilePath(state, p))) ? 0 /* Success */ : successfulProjects ? 2 /* DiagnosticsPresent_OutputsGenerated */ : 1 /* DiagnosticsPresent_OutputsSkipped */; } - function clean(state, project, onlyReferences) { - mark("SolutionBuilder::beforeClean"); - const result = cleanWorker(state, project, onlyReferences); - mark("SolutionBuilder::afterClean"); - measure("SolutionBuilder::Clean", "SolutionBuilder::beforeClean", "SolutionBuilder::afterClean"); - return result; + function getAdjustedLocationForHeritageClause(node) { + if (node.types.length === 1) { + return node.types[0].expression; + } } - function cleanWorker(state, project, onlyReferences) { - const buildOrder = getBuildOrderFor(state, project, onlyReferences); - if (!buildOrder) - return 3 /* InvalidProject_OutputsSkipped */; - if (isCircularBuildOrder(buildOrder)) { - reportErrors(state, buildOrder.circularDiagnostics); - return 4 /* ProjectReferenceCycle_OutputsSkipped */; + function getAdjustedLocation(node, forRename) { + const { parent: parent2 } = node; + if (isModifier(node) && (forRename || node.kind !== 90 /* DefaultKeyword */) ? canHaveModifiers(parent2) && contains(parent2.modifiers, node) : node.kind === 86 /* ClassKeyword */ ? isClassDeclaration(parent2) || isClassExpression(node) : node.kind === 100 /* FunctionKeyword */ ? isFunctionDeclaration(parent2) || isFunctionExpression(node) : node.kind === 120 /* InterfaceKeyword */ ? isInterfaceDeclaration(parent2) : node.kind === 94 /* EnumKeyword */ ? isEnumDeclaration(parent2) : node.kind === 156 /* TypeKeyword */ ? isTypeAliasDeclaration(parent2) : node.kind === 145 /* NamespaceKeyword */ || node.kind === 144 /* ModuleKeyword */ ? isModuleDeclaration(parent2) : node.kind === 102 /* ImportKeyword */ ? isImportEqualsDeclaration(parent2) : node.kind === 139 /* GetKeyword */ ? isGetAccessorDeclaration(parent2) : node.kind === 153 /* SetKeyword */ && isSetAccessorDeclaration(parent2)) { + const location = getAdjustedLocationForDeclaration(parent2, forRename); + if (location) { + return location; + } } - const { options, host } = state; - const filesToDelete = options.dry ? [] : void 0; - for (const proj of buildOrder) { - const resolvedPath = toResolvedConfigFilePath(state, proj); - const parsed = parseConfigFile(state, proj, resolvedPath); - if (parsed === void 0) { - reportParseConfigFileDiagnostic(state, resolvedPath); - continue; + if ((node.kind === 115 /* VarKeyword */ || node.kind === 87 /* ConstKeyword */ || node.kind === 121 /* LetKeyword */) && isVariableDeclarationList(parent2) && parent2.declarations.length === 1) { + const decl = parent2.declarations[0]; + if (isIdentifier(decl.name)) { + return decl.name; } - const outputs = getAllProjectOutputs(parsed, !host.useCaseSensitiveFileNames()); - if (!outputs.length) - continue; - const inputFileNames = new Set(parsed.fileNames.map((f) => toPath2(state, f))); - for (const output of outputs) { - if (inputFileNames.has(toPath2(state, output))) - continue; - if (host.fileExists(output)) { - if (filesToDelete) { - filesToDelete.push(output); - } else { - host.deleteFile(output); - invalidateProject(state, resolvedPath, 0 /* None */); - } + } + if (node.kind === 156 /* TypeKeyword */) { + if (isImportClause(parent2) && parent2.isTypeOnly) { + const location = getAdjustedLocationForImportDeclaration(parent2.parent, forRename); + if (location) { + return location; + } + } + if (isExportDeclaration(parent2) && parent2.isTypeOnly) { + const location = getAdjustedLocationForExportDeclaration(parent2, forRename); + if (location) { + return location; } } } - if (filesToDelete) { - reportStatus(state, Diagnostics.A_non_dry_build_would_delete_the_following_files_Colon_0, filesToDelete.map((f) => `\r - * ${f}`).join("")); + if (node.kind === 130 /* AsKeyword */) { + if (isImportSpecifier(parent2) && parent2.propertyName || isExportSpecifier(parent2) && parent2.propertyName || isNamespaceImport(parent2) || isNamespaceExport(parent2)) { + return parent2.name; + } + if (isExportDeclaration(parent2) && parent2.exportClause && isNamespaceExport(parent2.exportClause)) { + return parent2.exportClause.name; + } } - return 0 /* Success */; - } - function invalidateProject(state, resolved, reloadLevel) { - if (state.host.getParsedCommandLine && reloadLevel === 1 /* Partial */) { - reloadLevel = 2 /* Full */; + if (node.kind === 102 /* ImportKeyword */ && isImportDeclaration(parent2)) { + const location = getAdjustedLocationForImportDeclaration(parent2, forRename); + if (location) { + return location; + } } - if (reloadLevel === 2 /* Full */) { - state.configFileCache.delete(resolved); - state.buildOrder = void 0; + if (node.kind === 95 /* ExportKeyword */) { + if (isExportDeclaration(parent2)) { + const location = getAdjustedLocationForExportDeclaration(parent2, forRename); + if (location) { + return location; + } + } + if (isExportAssignment(parent2)) { + return skipOuterExpressions(parent2.expression); + } } - state.needsSummary = true; - clearProjectStatus(state, resolved); - addProjToQueue(state, resolved, reloadLevel); - enableCache(state); - } - function invalidateProjectAndScheduleBuilds(state, resolvedPath, reloadLevel) { - state.reportFileChangeDetected = true; - invalidateProject(state, resolvedPath, reloadLevel); - scheduleBuildInvalidatedProject( - state, - 250, - /*changeDetected*/ - true - ); - } - function scheduleBuildInvalidatedProject(state, time, changeDetected) { - const { hostWithWatch } = state; - if (!hostWithWatch.setTimeout || !hostWithWatch.clearTimeout) { - return; + if (node.kind === 149 /* RequireKeyword */ && isExternalModuleReference(parent2)) { + return parent2.expression; } - if (state.timerToBuildInvalidatedProject) { - hostWithWatch.clearTimeout(state.timerToBuildInvalidatedProject); + if (node.kind === 161 /* FromKeyword */ && (isImportDeclaration(parent2) || isExportDeclaration(parent2)) && parent2.moduleSpecifier) { + return parent2.moduleSpecifier; } - state.timerToBuildInvalidatedProject = hostWithWatch.setTimeout(buildNextInvalidatedProject, time, "timerToBuildInvalidatedProject", state, changeDetected); - } - function buildNextInvalidatedProject(_timeoutType, state, changeDetected) { - mark("SolutionBuilder::beforeBuild"); - const buildOrder = buildNextInvalidatedProjectWorker(state, changeDetected); - mark("SolutionBuilder::afterBuild"); - measure("SolutionBuilder::Build", "SolutionBuilder::beforeBuild", "SolutionBuilder::afterBuild"); - if (buildOrder) - reportErrorSummary(state, buildOrder); - } - function buildNextInvalidatedProjectWorker(state, changeDetected) { - state.timerToBuildInvalidatedProject = void 0; - if (state.reportFileChangeDetected) { - state.reportFileChangeDetected = false; - state.projectErrorsReported.clear(); - reportWatchStatus(state, Diagnostics.File_change_detected_Starting_incremental_compilation); + if ((node.kind === 96 /* ExtendsKeyword */ || node.kind === 119 /* ImplementsKeyword */) && isHeritageClause(parent2) && parent2.token === node.kind) { + const location = getAdjustedLocationForHeritageClause(parent2); + if (location) { + return location; + } } - let projectsBuilt = 0; - const buildOrder = getBuildOrder(state); - const invalidatedProject = getNextInvalidatedProject( - state, - buildOrder, - /*reportQueue*/ - false - ); - if (invalidatedProject) { - invalidatedProject.done(); - projectsBuilt++; - while (state.projectPendingBuild.size) { - if (state.timerToBuildInvalidatedProject) - return; - const info = getNextInvalidatedProjectCreateInfo( - state, - buildOrder, - /*reportQueue*/ - false - ); - if (!info) - break; - if (info.kind !== 2 /* UpdateOutputFileStamps */ && (changeDetected || projectsBuilt === 5)) { - scheduleBuildInvalidatedProject( - state, - 100, - /*changeDetected*/ - false - ); - return; + if (node.kind === 96 /* ExtendsKeyword */) { + if (isTypeParameterDeclaration(parent2) && parent2.constraint && isTypeReferenceNode(parent2.constraint)) { + return parent2.constraint.typeName; + } + if (isConditionalTypeNode(parent2) && isTypeReferenceNode(parent2.extendsType)) { + return parent2.extendsType.typeName; + } + } + if (node.kind === 140 /* InferKeyword */ && isInferTypeNode(parent2)) { + return parent2.typeParameter.name; + } + if (node.kind === 103 /* InKeyword */ && isTypeParameterDeclaration(parent2) && isMappedTypeNode(parent2.parent)) { + return parent2.name; + } + if (node.kind === 143 /* KeyOfKeyword */ && isTypeOperatorNode(parent2) && parent2.operator === 143 /* KeyOfKeyword */ && isTypeReferenceNode(parent2.type)) { + return parent2.type.typeName; + } + if (node.kind === 148 /* ReadonlyKeyword */ && isTypeOperatorNode(parent2) && parent2.operator === 148 /* ReadonlyKeyword */ && isArrayTypeNode(parent2.type) && isTypeReferenceNode(parent2.type.elementType)) { + return parent2.type.elementType.typeName; + } + if (!forRename) { + if (node.kind === 105 /* NewKeyword */ && isNewExpression(parent2) || node.kind === 116 /* VoidKeyword */ && isVoidExpression(parent2) || node.kind === 114 /* TypeOfKeyword */ && isTypeOfExpression(parent2) || node.kind === 135 /* AwaitKeyword */ && isAwaitExpression(parent2) || node.kind === 127 /* YieldKeyword */ && isYieldExpression(parent2) || node.kind === 91 /* DeleteKeyword */ && isDeleteExpression(parent2)) { + if (parent2.expression) { + return skipOuterExpressions(parent2.expression); } - const project = createInvalidatedProjectWithInfo(state, info, buildOrder); - project.done(); - if (info.kind !== 2 /* UpdateOutputFileStamps */) - projectsBuilt++; + } + if ((node.kind === 103 /* InKeyword */ || node.kind === 104 /* InstanceOfKeyword */) && isBinaryExpression(parent2) && parent2.operatorToken === node) { + return skipOuterExpressions(parent2.right); + } + if (node.kind === 130 /* AsKeyword */ && isAsExpression(parent2) && isTypeReferenceNode(parent2.type)) { + return parent2.type.typeName; + } + if (node.kind === 103 /* InKeyword */ && isForInStatement(parent2) || node.kind === 165 /* OfKeyword */ && isForOfStatement(parent2)) { + return skipOuterExpressions(parent2.expression); } } - disableCache(state); - return buildOrder; - } - function watchConfigFile(state, resolved, resolvedPath, parsed) { - if (!state.watch || state.allWatchedConfigFiles.has(resolvedPath)) - return; - state.allWatchedConfigFiles.set(resolvedPath, watchFile( - state, - resolved, - () => invalidateProjectAndScheduleBuilds(state, resolvedPath, 2 /* Full */), - 2e3 /* High */, - parsed == null ? void 0 : parsed.watchOptions, - WatchType.ConfigFile, - resolved - )); + return node; } - function watchExtendedConfigFiles(state, resolvedPath, parsed) { - updateSharedExtendedConfigFileWatcher( - resolvedPath, - parsed == null ? void 0 : parsed.options, - state.allWatchedExtendedConfigFiles, - (extendedConfigFileName, extendedConfigFilePath) => watchFile( - state, - extendedConfigFileName, - () => { - var _a; - return (_a = state.allWatchedExtendedConfigFiles.get(extendedConfigFilePath)) == null ? void 0 : _a.projects.forEach((projectConfigFilePath) => invalidateProjectAndScheduleBuilds(state, projectConfigFilePath, 2 /* Full */)); - }, - 2e3 /* High */, - parsed == null ? void 0 : parsed.watchOptions, - WatchType.ExtendedConfigFile - ), - (fileName) => toPath2(state, fileName) + function getAdjustedReferenceLocation(node) { + return getAdjustedLocation( + node, + /*forRename*/ + false ); } - function watchWildCardDirectories(state, resolved, resolvedPath, parsed) { - if (!state.watch) - return; - updateWatchingWildcardDirectories( - getOrCreateValueMapFromConfigFileMap(state.allWatchedWildcardDirectories, resolvedPath), - new Map(Object.entries(parsed.wildcardDirectories)), - (dir, flags) => state.watchDirectory( - dir, - (fileOrDirectory) => { - var _a; - if (isIgnoredFileFromWildCardWatching({ - watchedDirPath: toPath2(state, dir), - fileOrDirectory, - fileOrDirectoryPath: toPath2(state, fileOrDirectory), - configFileName: resolved, - currentDirectory: state.compilerHost.getCurrentDirectory(), - options: parsed.options, - program: state.builderPrograms.get(resolvedPath) || ((_a = getCachedParsedConfigFile(state, resolvedPath)) == null ? void 0 : _a.fileNames), - useCaseSensitiveFileNames: state.parseConfigFileHost.useCaseSensitiveFileNames, - writeLog: (s) => state.writeLog(s), - toPath: (fileName) => toPath2(state, fileName) - })) - return; - invalidateProjectAndScheduleBuilds(state, resolvedPath, 1 /* Partial */); - }, - flags, - parsed == null ? void 0 : parsed.watchOptions, - WatchType.WildcardDirectory, - resolved - ) + function getAdjustedRenameLocation(node) { + return getAdjustedLocation( + node, + /*forRename*/ + true ); } - function watchInputFiles(state, resolved, resolvedPath, parsed) { - if (!state.watch) - return; - mutateMap( - getOrCreateValueMapFromConfigFileMap(state.allWatchedInputFiles, resolvedPath), - arrayToMap(parsed.fileNames, (fileName) => toPath2(state, fileName)), - { - createNewValue: (_path, input) => watchFile( - state, - input, - () => invalidateProjectAndScheduleBuilds(state, resolvedPath, 0 /* None */), - 250 /* Low */, - parsed == null ? void 0 : parsed.watchOptions, - WatchType.SourceFile, - resolved - ), - onDeleteValue: closeFileWatcher - } + function getTouchingPropertyName(sourceFile, position) { + return getTouchingToken(sourceFile, position, (n) => isPropertyNameLiteral(n) || isKeyword(n.kind) || isPrivateIdentifier(n)); + } + function getTouchingToken(sourceFile, position, includePrecedingTokenAtEndPosition) { + return getTokenAtPositionWorker( + sourceFile, + position, + /*allowPositionInLeadingTrivia*/ + false, + includePrecedingTokenAtEndPosition, + /*includeEndPosition*/ + false ); } - function watchPackageJsonFiles(state, resolved, resolvedPath, parsed) { - if (!state.watch || !state.lastCachedPackageJsonLookups) - return; - mutateMap( - getOrCreateValueMapFromConfigFileMap(state.allWatchedPackageJsonFiles, resolvedPath), - new Map(state.lastCachedPackageJsonLookups.get(resolvedPath)), - { - createNewValue: (path, _input) => watchFile( - state, - path, - () => invalidateProjectAndScheduleBuilds(state, resolvedPath, 0 /* None */), - 2e3 /* High */, - parsed == null ? void 0 : parsed.watchOptions, - WatchType.PackageJson, - resolved - ), - onDeleteValue: closeFileWatcher - } + function getTokenAtPosition(sourceFile, position) { + return getTokenAtPositionWorker( + sourceFile, + position, + /*allowPositionInLeadingTrivia*/ + true, + /*includePrecedingTokenAtEndPosition*/ + void 0, + /*includeEndPosition*/ + false ); } - function startWatching(state, buildOrder) { - if (!state.watchAllProjectsPending) - return; - mark("SolutionBuilder::beforeWatcherCreation"); - state.watchAllProjectsPending = false; - for (const resolved of getBuildOrderFromAnyBuildOrder(buildOrder)) { - const resolvedPath = toResolvedConfigFilePath(state, resolved); - const cfg = parseConfigFile(state, resolved, resolvedPath); - watchConfigFile(state, resolved, resolvedPath, cfg); - watchExtendedConfigFiles(state, resolvedPath, cfg); - if (cfg) { - watchWildCardDirectories(state, resolved, resolvedPath, cfg); - watchInputFiles(state, resolved, resolvedPath, cfg); - watchPackageJsonFiles(state, resolved, resolvedPath, cfg); + function getTokenAtPositionWorker(sourceFile, position, allowPositionInLeadingTrivia, includePrecedingTokenAtEndPosition, includeEndPosition) { + let current = sourceFile; + let foundToken; + outer: + while (true) { + const children = current.getChildren(sourceFile); + const i = binarySearchKey(children, position, (_, i2) => i2, (middle, _) => { + const end = children[middle].getEnd(); + if (end < position) { + return -1 /* LessThan */; + } + const start = allowPositionInLeadingTrivia ? children[middle].getFullStart() : children[middle].getStart( + sourceFile, + /*includeJsDocComment*/ + true + ); + if (start > position) { + return 1 /* GreaterThan */; + } + if (nodeContainsPosition(children[middle], start, end)) { + if (children[middle - 1]) { + if (nodeContainsPosition(children[middle - 1])) { + return 1 /* GreaterThan */; + } + } + return 0 /* EqualTo */; + } + if (includePrecedingTokenAtEndPosition && start === position && children[middle - 1] && children[middle - 1].getEnd() === position && nodeContainsPosition(children[middle - 1])) { + return 1 /* GreaterThan */; + } + return -1 /* LessThan */; + }); + if (foundToken) { + return foundToken; + } + if (i >= 0 && children[i]) { + current = children[i]; + continue outer; + } + return current; } - } - mark("SolutionBuilder::afterWatcherCreation"); - measure("SolutionBuilder::Watcher creation", "SolutionBuilder::beforeWatcherCreation", "SolutionBuilder::afterWatcherCreation"); - } - function stopWatching(state) { - clearMap(state.allWatchedConfigFiles, closeFileWatcher); - clearMap(state.allWatchedExtendedConfigFiles, closeFileWatcherOf); - clearMap(state.allWatchedWildcardDirectories, (watchedWildcardDirectories) => clearMap(watchedWildcardDirectories, closeFileWatcherOf)); - clearMap(state.allWatchedInputFiles, (watchedWildcardDirectories) => clearMap(watchedWildcardDirectories, closeFileWatcher)); - clearMap(state.allWatchedPackageJsonFiles, (watchedPacageJsonFiles) => clearMap(watchedPacageJsonFiles, closeFileWatcher)); - } - function createSolutionBuilderWorker(watch, hostOrHostWithWatch, rootNames, options, baseWatchOptions) { - const state = createSolutionBuilderState(watch, hostOrHostWithWatch, rootNames, options, baseWatchOptions); - return { - build: (project, cancellationToken, writeFile2, getCustomTransformers) => build(state, project, cancellationToken, writeFile2, getCustomTransformers), - clean: (project) => clean(state, project), - buildReferences: (project, cancellationToken, writeFile2, getCustomTransformers) => build( - state, - project, - cancellationToken, - writeFile2, - getCustomTransformers, - /*onlyReferences*/ - true - ), - cleanReferences: (project) => clean( - state, - project, - /*onlyReferences*/ + function nodeContainsPosition(node, start, end) { + end ?? (end = node.getEnd()); + if (end < position) { + return false; + } + start ?? (start = allowPositionInLeadingTrivia ? node.getFullStart() : node.getStart( + sourceFile, + /*includeJsDocComment*/ true - ), - getNextInvalidatedProject: (cancellationToken) => { - setupInitialBuild(state, cancellationToken); - return getNextInvalidatedProject( - state, - getBuildOrder(state), - /*reportQueue*/ - false - ); - }, - getBuildOrder: () => getBuildOrder(state), - getUpToDateStatusOfProject: (project) => { - const configFileName = resolveProjectName(state, project); - const configFilePath = toResolvedConfigFilePath(state, configFileName); - return getUpToDateStatus(state, parseConfigFile(state, configFileName, configFilePath), configFilePath); - }, - invalidateProject: (configFilePath, reloadLevel) => invalidateProject(state, configFilePath, reloadLevel || 0 /* None */), - close: () => stopWatching(state) - }; - } - function relName(state, path) { - return convertToRelativePath(path, state.compilerHost.getCurrentDirectory(), state.compilerHost.getCanonicalFileName); - } - function reportStatus(state, message, ...args) { - state.host.reportSolutionBuilderStatus(createCompilerDiagnostic(message, ...args)); - } - function reportWatchStatus(state, message, ...args) { - var _a, _b; - (_b = (_a = state.hostWithWatch).onWatchStatusChange) == null ? void 0 : _b.call(_a, createCompilerDiagnostic(message, ...args), state.host.getNewLine(), state.baseCompilerOptions); - } - function reportErrors({ host }, errors) { - errors.forEach((err) => host.reportDiagnostic(err)); - } - function reportAndStoreErrors(state, proj, errors) { - reportErrors(state, errors); - state.projectErrorsReported.set(proj, true); - if (errors.length) { - state.diagnostics.set(proj, errors); - } - } - function reportParseConfigFileDiagnostic(state, proj) { - reportAndStoreErrors(state, proj, [state.configFileCache.get(proj)]); - } - function reportErrorSummary(state, buildOrder) { - if (!state.needsSummary) - return; - state.needsSummary = false; - const canReportSummary = state.watch || !!state.host.reportErrorSummary; - const { diagnostics } = state; - let totalErrors = 0; - let filesInError = []; - if (isCircularBuildOrder(buildOrder)) { - reportBuildQueue(state, buildOrder.buildOrder); - reportErrors(state, buildOrder.circularDiagnostics); - if (canReportSummary) - totalErrors += getErrorCountForSummary(buildOrder.circularDiagnostics); - if (canReportSummary) - filesInError = [...filesInError, ...getFilesInErrorForSummary(buildOrder.circularDiagnostics)]; - } else { - buildOrder.forEach((project) => { - const projectPath = toResolvedConfigFilePath(state, project); - if (!state.projectErrorsReported.has(projectPath)) { - reportErrors(state, diagnostics.get(projectPath) || emptyArray); + )); + if (start > position) { + return false; + } + if (position < end || position === end && (node.kind === 1 /* EndOfFileToken */ || includeEndPosition)) { + return true; + } else if (includePrecedingTokenAtEndPosition && end === position) { + const previousToken = findPrecedingToken(position, sourceFile, node); + if (previousToken && includePrecedingTokenAtEndPosition(previousToken)) { + foundToken = previousToken; + return true; } - }); - if (canReportSummary) - diagnostics.forEach((singleProjectErrors) => totalErrors += getErrorCountForSummary(singleProjectErrors)); - if (canReportSummary) - diagnostics.forEach((singleProjectErrors) => [...filesInError, ...getFilesInErrorForSummary(singleProjectErrors)]); - } - if (state.watch) { - reportWatchStatus(state, getWatchErrorSummaryDiagnosticMessage(totalErrors), totalErrors); - } else if (state.host.reportErrorSummary) { - state.host.reportErrorSummary(totalErrors, filesInError); + } + return false; } } - function reportBuildQueue(state, buildQueue) { - if (state.options.verbose) { - reportStatus(state, Diagnostics.Projects_in_this_build_Colon_0, buildQueue.map((s) => "\r\n * " + relName(state, s)).join("")); + function findFirstNonJsxWhitespaceToken(sourceFile, position) { + let tokenAtPosition = getTokenAtPosition(sourceFile, position); + while (isWhiteSpaceOnlyJsxText(tokenAtPosition)) { + const nextToken = findNextToken(tokenAtPosition, tokenAtPosition.parent, sourceFile); + if (!nextToken) + return; + tokenAtPosition = nextToken; } + return tokenAtPosition; } - function reportUpToDateStatus(state, configFileName, status) { - switch (status.type) { - case 6 /* OutOfDateWithSelf */: - return reportStatus( - state, - Diagnostics.Project_0_is_out_of_date_because_output_1_is_older_than_input_2, - relName(state, configFileName), - relName(state, status.outOfDateOutputFileName), - relName(state, status.newerInputFileName) - ); - case 7 /* OutOfDateWithUpstream */: - return reportStatus( - state, - Diagnostics.Project_0_is_out_of_date_because_output_1_is_older_than_input_2, - relName(state, configFileName), - relName(state, status.outOfDateOutputFileName), - relName(state, status.newerProjectName) - ); - case 4 /* OutputMissing */: - return reportStatus( - state, - Diagnostics.Project_0_is_out_of_date_because_output_file_1_does_not_exist, - relName(state, configFileName), - relName(state, status.missingOutputFileName) - ); - case 5 /* ErrorReadingFile */: - return reportStatus( - state, - Diagnostics.Project_0_is_out_of_date_because_there_was_error_reading_file_1, - relName(state, configFileName), - relName(state, status.fileName) - ); - case 8 /* OutOfDateBuildInfo */: - return reportStatus( - state, - Diagnostics.Project_0_is_out_of_date_because_buildinfo_file_1_indicates_that_some_of_the_changes_were_not_emitted, - relName(state, configFileName), - relName(state, status.buildInfoFile) - ); - case 9 /* OutOfDateOptions */: - return reportStatus( - state, - Diagnostics.Project_0_is_out_of_date_because_buildinfo_file_1_indicates_there_is_change_in_compilerOptions, - relName(state, configFileName), - relName(state, status.buildInfoFile) - ); - case 10 /* OutOfDateRoots */: - return reportStatus( - state, - Diagnostics.Project_0_is_out_of_date_because_buildinfo_file_1_indicates_that_file_2_was_root_file_of_compilation_but_not_any_more, - relName(state, configFileName), - relName(state, status.buildInfoFile), - relName(state, status.inputFile) - ); - case 1 /* UpToDate */: - if (status.newestInputFileTime !== void 0) { - return reportStatus( - state, - Diagnostics.Project_0_is_up_to_date_because_newest_input_1_is_older_than_output_2, - relName(state, configFileName), - relName(state, status.newestInputFileName || ""), - relName(state, status.oldestOutputFileName || "") - ); - } - break; - case 3 /* OutOfDateWithPrepend */: - return reportStatus( - state, - Diagnostics.Project_0_is_out_of_date_because_output_of_its_dependency_1_has_changed, - relName(state, configFileName), - relName(state, status.newerProjectName) - ); - case 2 /* UpToDateWithUpstreamTypes */: - return reportStatus( - state, - Diagnostics.Project_0_is_up_to_date_with_d_ts_files_from_its_dependencies, - relName(state, configFileName) - ); - case 15 /* UpToDateWithInputFileText */: - return reportStatus( - state, - Diagnostics.Project_0_is_up_to_date_but_needs_to_update_timestamps_of_output_files_that_are_older_than_input_files, - relName(state, configFileName) - ); - case 11 /* UpstreamOutOfDate */: - return reportStatus( - state, - Diagnostics.Project_0_is_out_of_date_because_its_dependency_1_is_out_of_date, - relName(state, configFileName), - relName(state, status.upstreamProjectName) - ); - case 12 /* UpstreamBlocked */: - return reportStatus( - state, - status.upstreamProjectBlocked ? Diagnostics.Project_0_can_t_be_built_because_its_dependency_1_was_not_built : Diagnostics.Project_0_can_t_be_built_because_its_dependency_1_has_errors, - relName(state, configFileName), - relName(state, status.upstreamProjectName) - ); - case 0 /* Unbuildable */: - return reportStatus( - state, - Diagnostics.Failed_to_parse_file_0_Colon_1, - relName(state, configFileName), - status.reason - ); - case 14 /* TsVersionOutputOfDate */: - return reportStatus( - state, - Diagnostics.Project_0_is_out_of_date_because_output_for_it_was_generated_with_version_1_that_differs_with_current_version_2, - relName(state, configFileName), - status.version, - version - ); - case 17 /* ForceBuild */: - return reportStatus( - state, - Diagnostics.Project_0_is_being_forcibly_rebuilt, - relName(state, configFileName) - ); - case 16 /* ContainerOnly */: - case 13 /* ComputingUpstream */: - break; - default: - assertType(status); + function findTokenOnLeftOfPosition(file, position) { + const tokenAtPosition = getTokenAtPosition(file, position); + if (isToken(tokenAtPosition) && position > tokenAtPosition.getStart(file) && position < tokenAtPosition.getEnd()) { + return tokenAtPosition; } + return findPrecedingToken(position, file); } - function verboseReportProjectStatus(state, configFileName, status) { - if (state.options.verbose) { - reportUpToDateStatus(state, configFileName, status); + function findNextToken(previousToken, parent2, sourceFile) { + return find2(parent2); + function find2(n) { + if (isToken(n) && n.pos === previousToken.end) { + return n; + } + return firstDefined(n.getChildren(sourceFile), (child) => { + const shouldDiveInChildNode = ( + // previous token is enclosed somewhere in the child + child.pos <= previousToken.pos && child.end > previousToken.end || // previous token ends exactly at the beginning of child + child.pos === previousToken.end + ); + return shouldDiveInChildNode && nodeHasTokens(child, sourceFile) ? find2(child) : void 0; + }); } } - var minimumDate, maximumDate, InvalidatedProjectKind; - var init_tsbuildPublic = __esm({ - "src/compiler/tsbuildPublic.ts"() { - "use strict"; - init_ts2(); - init_ts_performance(); - minimumDate = /* @__PURE__ */ new Date(-864e13); - maximumDate = /* @__PURE__ */ new Date(864e13); - InvalidatedProjectKind = /* @__PURE__ */ ((InvalidatedProjectKind2) => { - InvalidatedProjectKind2[InvalidatedProjectKind2["Build"] = 0] = "Build"; - InvalidatedProjectKind2[InvalidatedProjectKind2["UpdateBundle"] = 1] = "UpdateBundle"; - InvalidatedProjectKind2[InvalidatedProjectKind2["UpdateOutputFileStamps"] = 2] = "UpdateOutputFileStamps"; - return InvalidatedProjectKind2; - })(InvalidatedProjectKind || {}); - } - }); - - // src/compiler/_namespaces/ts.ts - var init_ts2 = __esm({ - "src/compiler/_namespaces/ts.ts"() { - "use strict"; - init_corePublic(); - init_core(); - init_debug(); - init_semver(); - init_performanceCore(); - init_perfLogger(); - init_tracing(); - init_types(); - init_sys(); - init_path(); - init_diagnosticInformationMap_generated(); - init_scanner(); - init_utilitiesPublic(); - init_utilities(); - init_baseNodeFactory(); - init_parenthesizerRules(); - init_nodeConverters(); - init_nodeFactory(); - init_emitNode(); - init_emitHelpers(); - init_nodeTests(); - init_utilities2(); - init_utilitiesPublic2(); - init_parser(); - init_commandLineParser(); - init_moduleNameResolver(); - init_binder(); - init_symbolWalker(); - init_checker(); - init_visitorPublic(); - init_sourcemap(); - init_utilities3(); - init_destructuring(); - init_taggedTemplate(); - init_ts(); - init_classFields(); - init_typeSerializer(); - init_legacyDecorators(); - init_esDecorators(); - init_es2017(); - init_es2018(); - init_es2019(); - init_es2020(); - init_es2021(); - init_esnext(); - init_jsx(); - init_es2016(); - init_es2015(); - init_es5(); - init_generators(); - init_module(); - init_system(); - init_esnextAnd2015(); - init_node(); - init_diagnostics(); - init_declarations(); - init_transformer(); - init_emitter(); - init_watchUtilities(); - init_program(); - init_builderStatePublic(); - init_builderState(); - init_builder(); - init_builderPublic(); - init_resolutionCache(); - init_watch(); - init_watchPublic(); - init_tsbuild(); - init_tsbuildPublic(); - init_ts_moduleSpecifiers(); - init_ts_performance(); + function findPrecedingToken(position, sourceFile, startNode2, excludeJsdoc) { + const result = find2(startNode2 || sourceFile); + Debug.assert(!(result && isWhiteSpaceOnlyJsxText(result))); + return result; + function find2(n) { + if (isNonWhitespaceToken(n) && n.kind !== 1 /* EndOfFileToken */) { + return n; + } + const children = n.getChildren(sourceFile); + const i = binarySearchKey(children, position, (_, i2) => i2, (middle, _) => { + if (position < children[middle].end) { + if (!children[middle - 1] || position >= children[middle - 1].end) { + return 0 /* EqualTo */; + } + return 1 /* GreaterThan */; + } + return -1 /* LessThan */; + }); + if (i >= 0 && children[i]) { + const child = children[i]; + if (position < child.end) { + const start = child.getStart( + sourceFile, + /*includeJsDoc*/ + !excludeJsdoc + ); + const lookInPreviousChild = start >= position || // cursor in the leading trivia + !nodeHasTokens(child, sourceFile) || isWhiteSpaceOnlyJsxText(child); + if (lookInPreviousChild) { + const candidate2 = findRightmostChildNodeWithTokens( + children, + /*exclusiveStartPosition*/ + i, + sourceFile, + n.kind + ); + if (candidate2) { + if (!excludeJsdoc && isJSDocCommentContainingNode(candidate2) && candidate2.getChildren(sourceFile).length) { + return find2(candidate2); + } + return findRightmostToken(candidate2, sourceFile); + } + return void 0; + } else { + return find2(child); + } + } + } + Debug.assert(startNode2 !== void 0 || n.kind === 312 /* SourceFile */ || n.kind === 1 /* EndOfFileToken */ || isJSDocCommentContainingNode(n)); + const candidate = findRightmostChildNodeWithTokens( + children, + /*exclusiveStartPosition*/ + children.length, + sourceFile, + n.kind + ); + return candidate && findRightmostToken(candidate, sourceFile); } - }); - - // src/jsTyping/jsTyping.ts - function isTypingUpToDate(cachedTyping, availableTypingVersions) { - const availableVersion = new Version(getProperty(availableTypingVersions, `ts${versionMajorMinor}`) || getProperty(availableTypingVersions, "latest")); - return availableVersion.compareTo(cachedTyping.version) <= 0; - } - function nonRelativeModuleNameForTypingCache(moduleName) { - return nodeCoreModules.has(moduleName) ? "node" : moduleName; } - function loadSafeList(host, safeListPath) { - const result = readConfigFile(safeListPath, (path) => host.readFile(path)); - return new Map(Object.entries(result.config)); + function isNonWhitespaceToken(n) { + return isToken(n) && !isWhiteSpaceOnlyJsxText(n); } - function loadTypesMap(host, typesMapPath) { - var _a; - const result = readConfigFile(typesMapPath, (path) => host.readFile(path)); - if ((_a = result.config) == null ? void 0 : _a.simpleMap) { - return new Map(Object.entries(result.config.simpleMap)); + function findRightmostToken(n, sourceFile) { + if (isNonWhitespaceToken(n)) { + return n; } - return void 0; + const children = n.getChildren(sourceFile); + if (children.length === 0) { + return n; + } + const candidate = findRightmostChildNodeWithTokens( + children, + /*exclusiveStartPosition*/ + children.length, + sourceFile, + n.kind + ); + return candidate && findRightmostToken(candidate, sourceFile); } - function discoverTypings(host, log, fileNames, projectRootPath, safeList, packageNameToTypingLocation, typeAcquisition, unresolvedImports, typesRegistry, compilerOptions) { - if (!typeAcquisition || !typeAcquisition.enable) { - return { cachedTypingPaths: [], newTypingNames: [], filesToWatch: [] }; + function findRightmostChildNodeWithTokens(children, exclusiveStartPosition, sourceFile, parentKind) { + for (let i = exclusiveStartPosition - 1; i >= 0; i--) { + const child = children[i]; + if (isWhiteSpaceOnlyJsxText(child)) { + if (i === 0 && (parentKind === 12 /* JsxText */ || parentKind === 285 /* JsxSelfClosingElement */)) { + Debug.fail("`JsxText` tokens should not be the first child of `JsxElement | JsxSelfClosingElement`"); + } + } else if (nodeHasTokens(children[i], sourceFile)) { + return children[i]; + } } - const inferredTypings = /* @__PURE__ */ new Map(); - fileNames = mapDefined(fileNames, (fileName) => { - const path = normalizePath(fileName); - if (hasJSFileExtension(path)) { - return path; + } + function isInString(sourceFile, position, previousToken = findPrecedingToken(position, sourceFile)) { + if (previousToken && isStringTextContainingNode(previousToken)) { + const start = previousToken.getStart(sourceFile); + const end = previousToken.getEnd(); + if (start < position && position < end) { + return true; + } + if (position === end) { + return !!previousToken.isUnterminated; } - }); - const filesToWatch = []; - if (typeAcquisition.include) - addInferredTypings(typeAcquisition.include, "Explicitly included types"); - const exclude = typeAcquisition.exclude || []; - if (!compilerOptions.types) { - const possibleSearchDirs = new Set(fileNames.map(getDirectoryPath)); - possibleSearchDirs.add(projectRootPath); - possibleSearchDirs.forEach((searchDir) => { - getTypingNames(searchDir, "bower.json", "bower_components", filesToWatch); - getTypingNames(searchDir, "package.json", "node_modules", filesToWatch); - }); } - if (!typeAcquisition.disableFilenameBasedTypeAcquisition) { - getTypingNamesFromSourceFileNames(fileNames); + return false; + } + function isInsideJsxElementOrAttribute(sourceFile, position) { + const token = getTokenAtPosition(sourceFile, position); + if (!token) { + return false; } - if (unresolvedImports) { - const module2 = deduplicate( - unresolvedImports.map(nonRelativeModuleNameForTypingCache), - equateStringsCaseSensitive, - compareStringsCaseSensitive - ); - addInferredTypings(module2, "Inferred typings from unresolved imports"); + if (token.kind === 12 /* JsxText */) { + return true; } - packageNameToTypingLocation.forEach((typing, name) => { - const registryEntry = typesRegistry.get(name); - if (inferredTypings.has(name) && inferredTypings.get(name) === void 0 && registryEntry !== void 0 && isTypingUpToDate(typing, registryEntry)) { - inferredTypings.set(name, typing.typingLocation); - } - }); - for (const excludeTypingName of exclude) { - const didDelete = inferredTypings.delete(excludeTypingName); - if (didDelete && log) - log(`Typing for ${excludeTypingName} is in exclude list, will be ignored.`); + if (token.kind === 30 /* LessThanToken */ && token.parent.kind === 12 /* JsxText */) { + return true; } - const newTypingNames = []; - const cachedTypingPaths = []; - inferredTypings.forEach((inferred, typing) => { - if (inferred !== void 0) { - cachedTypingPaths.push(inferred); - } else { - newTypingNames.push(typing); - } - }); - const result = { cachedTypingPaths, newTypingNames, filesToWatch }; - if (log) - log(`Result: ${JSON.stringify(result)}`); - return result; - function addInferredTyping(typingName) { - if (!inferredTypings.has(typingName)) { - inferredTypings.set(typingName, void 0); + if (token.kind === 30 /* LessThanToken */ && token.parent.kind === 294 /* JsxExpression */) { + return true; + } + if (token && token.kind === 20 /* CloseBraceToken */ && token.parent.kind === 294 /* JsxExpression */) { + return true; + } + if (token.kind === 30 /* LessThanToken */ && token.parent.kind === 287 /* JsxClosingElement */) { + return true; + } + return false; + } + function isWhiteSpaceOnlyJsxText(node) { + return isJsxText(node) && node.containsOnlyTriviaWhiteSpaces; + } + function isInTemplateString(sourceFile, position) { + const token = getTokenAtPosition(sourceFile, position); + return isTemplateLiteralKind(token.kind) && position > token.getStart(sourceFile); + } + function isInJSXText(sourceFile, position) { + const token = getTokenAtPosition(sourceFile, position); + if (isJsxText(token)) { + return true; + } + if (token.kind === 19 /* OpenBraceToken */ && isJsxExpression(token.parent) && isJsxElement(token.parent.parent)) { + return true; + } + if (token.kind === 30 /* LessThanToken */ && isJsxOpeningLikeElement(token.parent) && isJsxElement(token.parent.parent)) { + return true; + } + return false; + } + function isInsideJsxElement(sourceFile, position) { + function isInsideJsxElementTraversal(node) { + while (node) { + if (node.kind >= 285 /* JsxSelfClosingElement */ && node.kind <= 294 /* JsxExpression */ || node.kind === 12 /* JsxText */ || node.kind === 30 /* LessThanToken */ || node.kind === 32 /* GreaterThanToken */ || node.kind === 80 /* Identifier */ || node.kind === 20 /* CloseBraceToken */ || node.kind === 19 /* OpenBraceToken */ || node.kind === 44 /* SlashToken */) { + node = node.parent; + } else if (node.kind === 284 /* JsxElement */) { + if (position > node.getStart(sourceFile)) + return true; + node = node.parent; + } else { + return false; + } } + return false; } - function addInferredTypings(typingNames, message) { - if (log) - log(`${message}: ${JSON.stringify(typingNames)}`); - forEach(typingNames, addInferredTyping); + return isInsideJsxElementTraversal(getTokenAtPosition(sourceFile, position)); + } + function findPrecedingMatchingToken(token, matchingTokenKind, sourceFile) { + const closeTokenText = tokenToString(token.kind); + const matchingTokenText = tokenToString(matchingTokenKind); + const tokenFullStart = token.getFullStart(); + const bestGuessIndex = sourceFile.text.lastIndexOf(matchingTokenText, tokenFullStart); + if (bestGuessIndex === -1) { + return void 0; } - function getTypingNames(projectRootPath2, manifestName, modulesDirName, filesToWatch2) { - const manifestPath = combinePaths(projectRootPath2, manifestName); - let manifest; - let manifestTypingNames; - if (host.fileExists(manifestPath)) { - filesToWatch2.push(manifestPath); - manifest = readConfigFile(manifestPath, (path) => host.readFile(path)).config; - manifestTypingNames = flatMap([manifest.dependencies, manifest.devDependencies, manifest.optionalDependencies, manifest.peerDependencies], getOwnKeys); - addInferredTypings(manifestTypingNames, `Typing names in '${manifestPath}' dependencies`); + if (sourceFile.text.lastIndexOf(closeTokenText, tokenFullStart - 1) < bestGuessIndex) { + const nodeAtGuess = findPrecedingToken(bestGuessIndex + 1, sourceFile); + if (nodeAtGuess && nodeAtGuess.kind === matchingTokenKind) { + return nodeAtGuess; } - const packagesFolderPath = combinePaths(projectRootPath2, modulesDirName); - filesToWatch2.push(packagesFolderPath); - if (!host.directoryExists(packagesFolderPath)) { - return; + } + const tokenKind = token.kind; + let remainingMatchingTokens = 0; + while (true) { + const preceding = findPrecedingToken(token.getFullStart(), sourceFile); + if (!preceding) { + return void 0; } - const packageNames = []; - const dependencyManifestNames = manifestTypingNames ? manifestTypingNames.map((typingName) => combinePaths(packagesFolderPath, typingName, manifestName)) : host.readDirectory( - packagesFolderPath, - [".json" /* Json */], - /*excludes*/ - void 0, - /*includes*/ - void 0, - /*depth*/ - 3 - ).filter((manifestPath2) => { - if (getBaseFileName(manifestPath2) !== manifestName) { - return false; - } - const pathComponents2 = getPathComponents(normalizePath(manifestPath2)); - const isScoped = pathComponents2[pathComponents2.length - 3][0] === "@"; - return isScoped && toFileNameLowerCase(pathComponents2[pathComponents2.length - 4]) === modulesDirName || // `node_modules/@foo/bar` - !isScoped && toFileNameLowerCase(pathComponents2[pathComponents2.length - 3]) === modulesDirName; - }); - if (log) - log(`Searching for typing names in ${packagesFolderPath}; all files: ${JSON.stringify(dependencyManifestNames)}`); - for (const manifestPath2 of dependencyManifestNames) { - const normalizedFileName = normalizePath(manifestPath2); - const result2 = readConfigFile(normalizedFileName, (path) => host.readFile(path)); - const manifest2 = result2.config; - if (!manifest2.name) { - continue; - } - const ownTypes = manifest2.types || manifest2.typings; - if (ownTypes) { - const absolutePath = getNormalizedAbsolutePath(ownTypes, getDirectoryPath(normalizedFileName)); - if (host.fileExists(absolutePath)) { - if (log) - log(` Package '${manifest2.name}' provides its own types.`); - inferredTypings.set(manifest2.name, absolutePath); - } else { - if (log) - log(` Package '${manifest2.name}' provides its own types but they are missing.`); - } - } else { - packageNames.push(manifest2.name); + token = preceding; + if (token.kind === matchingTokenKind) { + if (remainingMatchingTokens === 0) { + return token; } + remainingMatchingTokens--; + } else if (token.kind === tokenKind) { + remainingMatchingTokens++; } - addInferredTypings(packageNames, " Found package names"); } - function getTypingNamesFromSourceFileNames(fileNames2) { - const fromFileNames = mapDefined(fileNames2, (j) => { - if (!hasJSFileExtension(j)) + } + function removeOptionality(type, isOptionalExpression, isOptionalChain2) { + return isOptionalExpression ? type.getNonNullableType() : isOptionalChain2 ? type.getNonOptionalType() : type; + } + function isPossiblyTypeArgumentPosition(token, sourceFile, checker) { + const info = getPossibleTypeArgumentsInfo(token, sourceFile); + return info !== void 0 && (isPartOfTypeNode(info.called) || getPossibleGenericSignatures(info.called, info.nTypeArguments, checker).length !== 0 || isPossiblyTypeArgumentPosition(info.called, sourceFile, checker)); + } + function getPossibleGenericSignatures(called, typeArgumentCount, checker) { + let type = checker.getTypeAtLocation(called); + if (isOptionalChain(called.parent)) { + type = removeOptionality( + type, + isOptionalChainRoot(called.parent), + /*isOptionalChain*/ + true + ); + } + const signatures = isNewExpression(called.parent) ? type.getConstructSignatures() : type.getCallSignatures(); + return signatures.filter((candidate) => !!candidate.typeParameters && candidate.typeParameters.length >= typeArgumentCount); + } + function getPossibleTypeArgumentsInfo(tokenIn, sourceFile) { + if (sourceFile.text.lastIndexOf("<", tokenIn ? tokenIn.pos : sourceFile.text.length) === -1) { + return void 0; + } + let token = tokenIn; + let remainingLessThanTokens = 0; + let nTypeArguments = 0; + while (token) { + switch (token.kind) { + case 30 /* LessThanToken */: + token = findPrecedingToken(token.getFullStart(), sourceFile); + if (token && token.kind === 29 /* QuestionDotToken */) { + token = findPrecedingToken(token.getFullStart(), sourceFile); + } + if (!token || !isIdentifier(token)) + return void 0; + if (!remainingLessThanTokens) { + return isDeclarationName(token) ? void 0 : { called: token, nTypeArguments }; + } + remainingLessThanTokens--; + break; + case 50 /* GreaterThanGreaterThanGreaterThanToken */: + remainingLessThanTokens = 3; + break; + case 49 /* GreaterThanGreaterThanToken */: + remainingLessThanTokens = 2; + break; + case 32 /* GreaterThanToken */: + remainingLessThanTokens++; + break; + case 20 /* CloseBraceToken */: + token = findPrecedingMatchingToken(token, 19 /* OpenBraceToken */, sourceFile); + if (!token) + return void 0; + break; + case 22 /* CloseParenToken */: + token = findPrecedingMatchingToken(token, 21 /* OpenParenToken */, sourceFile); + if (!token) + return void 0; + break; + case 24 /* CloseBracketToken */: + token = findPrecedingMatchingToken(token, 23 /* OpenBracketToken */, sourceFile); + if (!token) + return void 0; + break; + case 28 /* CommaToken */: + nTypeArguments++; + break; + case 39 /* EqualsGreaterThanToken */: + case 80 /* Identifier */: + case 11 /* StringLiteral */: + case 9 /* NumericLiteral */: + case 10 /* BigIntLiteral */: + case 112 /* TrueKeyword */: + case 97 /* FalseKeyword */: + case 114 /* TypeOfKeyword */: + case 96 /* ExtendsKeyword */: + case 143 /* KeyOfKeyword */: + case 25 /* DotToken */: + case 52 /* BarToken */: + case 58 /* QuestionToken */: + case 59 /* ColonToken */: + break; + default: + if (isTypeNode(token)) { + break; + } return void 0; - const inferredTypingName = removeFileExtension(toFileNameLowerCase(getBaseFileName(j))); - const cleanedTypingName = removeMinAndVersionNumbers(inferredTypingName); - return safeList.get(cleanedTypingName); - }); - if (fromFileNames.length) { - addInferredTypings(fromFileNames, "Inferred typings from file names"); - } - const hasJsxFile = some(fileNames2, (f) => fileExtensionIs(f, ".jsx" /* Jsx */)); - if (hasJsxFile) { - if (log) - log(`Inferred 'react' typings due to presence of '.jsx' extension`); - addInferredTyping("react"); } + token = findPrecedingToken(token.getFullStart(), sourceFile); } + return void 0; } - function validatePackageName(packageName) { - return validatePackageNameWorker( - packageName, - /*supportScopedPackage*/ - true + function isInComment(sourceFile, position, tokenAtPosition) { + return ts_formatting_exports.getRangeOfEnclosingComment( + sourceFile, + position, + /*precedingToken*/ + void 0, + tokenAtPosition ); } - function validatePackageNameWorker(packageName, supportScopedPackage) { - if (!packageName) { - return 1 /* EmptyName */; + function hasDocComment(sourceFile, position) { + const token = getTokenAtPosition(sourceFile, position); + return !!findAncestor(token, isJSDoc); + } + function nodeHasTokens(n, sourceFile) { + return n.kind === 1 /* EndOfFileToken */ ? !!n.jsDoc : n.getWidth(sourceFile) !== 0; + } + function getNodeModifiers(node, excludeFlags = 0 /* None */) { + const result = []; + const flags = isDeclaration(node) ? getCombinedNodeFlagsAlwaysIncludeJSDoc(node) & ~excludeFlags : 0 /* None */; + if (flags & 2 /* Private */) + result.push("private" /* privateMemberModifier */); + if (flags & 4 /* Protected */) + result.push("protected" /* protectedMemberModifier */); + if (flags & 1 /* Public */) + result.push("public" /* publicMemberModifier */); + if (flags & 256 /* Static */ || isClassStaticBlockDeclaration(node)) + result.push("static" /* staticModifier */); + if (flags & 64 /* Abstract */) + result.push("abstract" /* abstractModifier */); + if (flags & 32 /* Export */) + result.push("export" /* exportedModifier */); + if (flags & 65536 /* Deprecated */) + result.push("deprecated" /* deprecatedModifier */); + if (node.flags & 33554432 /* Ambient */) + result.push("declare" /* ambientModifier */); + if (node.kind === 277 /* ExportAssignment */) + result.push("export" /* exportedModifier */); + return result.length > 0 ? result.join(",") : "" /* none */; + } + function getTypeArgumentOrTypeParameterList(node) { + if (node.kind === 183 /* TypeReference */ || node.kind === 213 /* CallExpression */) { + return node.typeArguments; } - if (packageName.length > maxPackageNameLength) { - return 2 /* NameTooLong */; + if (isFunctionLike(node) || node.kind === 263 /* ClassDeclaration */ || node.kind === 264 /* InterfaceDeclaration */) { + return node.typeParameters; } - if (packageName.charCodeAt(0) === 46 /* dot */) { - return 3 /* NameStartsWithDot */; + return void 0; + } + function isComment(kind) { + return kind === 2 /* SingleLineCommentTrivia */ || kind === 3 /* MultiLineCommentTrivia */; + } + function isStringOrRegularExpressionOrTemplateLiteral(kind) { + if (kind === 11 /* StringLiteral */ || kind === 14 /* RegularExpressionLiteral */ || isTemplateLiteralKind(kind)) { + return true; } - if (packageName.charCodeAt(0) === 95 /* _ */) { - return 4 /* NameStartsWithUnderscore */; + return false; + } + function areIntersectedTypesAvoidingStringReduction(checker, t1, t2) { + return !!(t1.flags & 4 /* String */) && checker.isEmptyAnonymousObjectType(t2); + } + function isStringAndEmptyAnonymousObjectIntersection(type) { + if (!type.isIntersection()) { + return false; } - if (supportScopedPackage) { - const matches = /^@([^/]+)\/([^/]+)$/.exec(packageName); - if (matches) { - const scopeResult = validatePackageNameWorker( - matches[1], - /*supportScopedPackage*/ - false - ); - if (scopeResult !== 0 /* Ok */) { - return { name: matches[1], isScopeName: true, result: scopeResult }; - } - const packageResult = validatePackageNameWorker( - matches[2], - /*supportScopedPackage*/ - false - ); - if (packageResult !== 0 /* Ok */) { - return { name: matches[2], isScopeName: false, result: packageResult }; - } - return 0 /* Ok */; - } + const { types, checker } = type; + return types.length === 2 && (areIntersectedTypesAvoidingStringReduction(checker, types[0], types[1]) || areIntersectedTypesAvoidingStringReduction(checker, types[1], types[0])); + } + function isInsideTemplateLiteral(node, position, sourceFile) { + return isTemplateLiteralKind(node.kind) && (node.getStart(sourceFile) < position && position < node.end) || !!node.isUnterminated && position === node.end; + } + function isAccessibilityModifier(kind) { + switch (kind) { + case 125 /* PublicKeyword */: + case 123 /* PrivateKeyword */: + case 124 /* ProtectedKeyword */: + return true; } - if (encodeURIComponent(packageName) !== packageName) { - return 5 /* NameContainsNonURISafeCharacters */; + return false; + } + function cloneCompilerOptions(options) { + const result = clone(options); + setConfigFileInOptions(result, options && options.configFile); + return result; + } + function isArrayLiteralOrObjectLiteralDestructuringPattern(node) { + if (node.kind === 209 /* ArrayLiteralExpression */ || node.kind === 210 /* ObjectLiteralExpression */) { + if (node.parent.kind === 226 /* BinaryExpression */ && node.parent.left === node && node.parent.operatorToken.kind === 64 /* EqualsToken */) { + return true; + } + if (node.parent.kind === 250 /* ForOfStatement */ && node.parent.initializer === node) { + return true; + } + if (isArrayLiteralOrObjectLiteralDestructuringPattern(node.parent.kind === 303 /* PropertyAssignment */ ? node.parent.parent : node.parent)) { + return true; + } } - return 0 /* Ok */; + return false; } - function renderPackageNameValidationFailure(result, typing) { - return typeof result === "object" ? renderPackageNameValidationFailureWorker(typing, result.result, result.name, result.isScopeName) : renderPackageNameValidationFailureWorker( - typing, - result, - typing, - /*isScopeName*/ + function isInReferenceComment(sourceFile, position) { + return isInReferenceCommentWorker( + sourceFile, + position, + /*shouldBeReference*/ + true + ); + } + function isInNonReferenceComment(sourceFile, position) { + return isInReferenceCommentWorker( + sourceFile, + position, + /*shouldBeReference*/ false ); } - function renderPackageNameValidationFailureWorker(typing, result, name, isScopeName) { - const kind = isScopeName ? "Scope" : "Package"; - switch (result) { - case 1 /* EmptyName */: - return `'${typing}':: ${kind} name '${name}' cannot be empty`; - case 2 /* NameTooLong */: - return `'${typing}':: ${kind} name '${name}' should be less than ${maxPackageNameLength} characters`; - case 3 /* NameStartsWithDot */: - return `'${typing}':: ${kind} name '${name}' cannot start with '.'`; - case 4 /* NameStartsWithUnderscore */: - return `'${typing}':: ${kind} name '${name}' cannot start with '_'`; - case 5 /* NameContainsNonURISafeCharacters */: - return `'${typing}':: ${kind} name '${name}' contains non URI safe characters`; - case 0 /* Ok */: - return Debug.fail(); + function isInReferenceCommentWorker(sourceFile, position, shouldBeReference) { + const range = isInComment( + sourceFile, + position, + /*tokenAtPosition*/ + void 0 + ); + return !!range && shouldBeReference === tripleSlashDirectivePrefixRegex.test(sourceFile.text.substring(range.pos, range.end)); + } + function getReplacementSpanForContextToken(contextToken) { + if (!contextToken) + return void 0; + switch (contextToken.kind) { + case 11 /* StringLiteral */: + case 15 /* NoSubstitutionTemplateLiteral */: + return createTextSpanFromStringLiteralLikeContent(contextToken); default: - Debug.assertNever(result); + return createTextSpanFromNode(contextToken); } } - var unprefixedNodeCoreModuleList, prefixedNodeCoreModuleList, nodeCoreModuleList, nodeCoreModules, NameValidationResult, maxPackageNameLength; - var init_jsTyping = __esm({ - "src/jsTyping/jsTyping.ts"() { - "use strict"; - init_ts3(); - unprefixedNodeCoreModuleList = [ - "assert", - "assert/strict", - "async_hooks", - "buffer", - "child_process", - "cluster", - "console", - "constants", - "crypto", - "dgram", - "diagnostics_channel", - "dns", - "dns/promises", - "domain", - "events", - "fs", - "fs/promises", - "http", - "https", - "http2", - "inspector", - "module", - "net", - "os", - "path", - "perf_hooks", - "process", - "punycode", - "querystring", - "readline", - "repl", - "stream", - "stream/promises", - "string_decoder", - "timers", - "timers/promises", - "tls", - "trace_events", - "tty", - "url", - "util", - "util/types", - "v8", - "vm", - "wasi", - "worker_threads", - "zlib" - ]; - prefixedNodeCoreModuleList = unprefixedNodeCoreModuleList.map((name) => `node:${name}`); - nodeCoreModuleList = [...unprefixedNodeCoreModuleList, ...prefixedNodeCoreModuleList]; - nodeCoreModules = new Set(nodeCoreModuleList); - NameValidationResult = /* @__PURE__ */ ((NameValidationResult2) => { - NameValidationResult2[NameValidationResult2["Ok"] = 0] = "Ok"; - NameValidationResult2[NameValidationResult2["EmptyName"] = 1] = "EmptyName"; - NameValidationResult2[NameValidationResult2["NameTooLong"] = 2] = "NameTooLong"; - NameValidationResult2[NameValidationResult2["NameStartsWithDot"] = 3] = "NameStartsWithDot"; - NameValidationResult2[NameValidationResult2["NameStartsWithUnderscore"] = 4] = "NameStartsWithUnderscore"; - NameValidationResult2[NameValidationResult2["NameContainsNonURISafeCharacters"] = 5] = "NameContainsNonURISafeCharacters"; - return NameValidationResult2; - })(NameValidationResult || {}); - maxPackageNameLength = 214; - } - }); - - // src/jsTyping/_namespaces/ts.JsTyping.ts - var ts_JsTyping_exports = {}; - __export(ts_JsTyping_exports, { - NameValidationResult: () => NameValidationResult, - discoverTypings: () => discoverTypings, - isTypingUpToDate: () => isTypingUpToDate, - loadSafeList: () => loadSafeList, - loadTypesMap: () => loadTypesMap, - nodeCoreModuleList: () => nodeCoreModuleList, - nodeCoreModules: () => nodeCoreModules, - nonRelativeModuleNameForTypingCache: () => nonRelativeModuleNameForTypingCache, - prefixedNodeCoreModuleList: () => prefixedNodeCoreModuleList, - renderPackageNameValidationFailure: () => renderPackageNameValidationFailure, - validatePackageName: () => validatePackageName - }); - var init_ts_JsTyping = __esm({ - "src/jsTyping/_namespaces/ts.JsTyping.ts"() { - "use strict"; - init_jsTyping(); - } - }); - - // src/jsTyping/shared.ts - function hasArgument(argumentName) { - return sys.args.indexOf(argumentName) >= 0; + function createTextSpanFromNode(node, sourceFile, endNode2) { + return createTextSpanFromBounds(node.getStart(sourceFile), (endNode2 || node).getEnd()); } - function findArgument(argumentName) { - const index = sys.args.indexOf(argumentName); - return index >= 0 && index < sys.args.length - 1 ? sys.args[index + 1] : void 0; + function createTextSpanFromStringLiteralLikeContent(node) { + if (node.isUnterminated) + return void 0; + return createTextSpanFromBounds(node.getStart() + 1, node.getEnd() - 1); } - function nowString() { - const d = /* @__PURE__ */ new Date(); - return `${padLeft(d.getHours().toString(), 2, "0")}:${padLeft(d.getMinutes().toString(), 2, "0")}:${padLeft(d.getSeconds().toString(), 2, "0")}.${padLeft(d.getMilliseconds().toString(), 3, "0")}`; + function createTextRangeFromNode(node, sourceFile) { + return createRange(node.getStart(sourceFile), node.end); } - var ActionSet, ActionInvalidate, ActionPackageInstalled, EventTypesRegistry, EventBeginInstallTypes, EventEndInstallTypes, EventInitializationFailed, ActionWatchTypingLocations, Arguments; - var init_shared = __esm({ - "src/jsTyping/shared.ts"() { - "use strict"; - init_ts3(); - ActionSet = "action::set"; - ActionInvalidate = "action::invalidate"; - ActionPackageInstalled = "action::packageInstalled"; - EventTypesRegistry = "event::typesRegistry"; - EventBeginInstallTypes = "event::beginInstallTypes"; - EventEndInstallTypes = "event::endInstallTypes"; - EventInitializationFailed = "event::initializationFailed"; - ActionWatchTypingLocations = "action::watchTypingLocations"; - ((Arguments2) => { - Arguments2.GlobalCacheLocation = "--globalTypingsCacheLocation"; - Arguments2.LogFile = "--logFile"; - Arguments2.EnableTelemetry = "--enableTelemetry"; - Arguments2.TypingSafeListLocation = "--typingSafeListLocation"; - Arguments2.TypesMapLocation = "--typesMapLocation"; - Arguments2.NpmLocation = "--npmLocation"; - Arguments2.ValidateDefaultNpmLocation = "--validateDefaultNpmLocation"; - })(Arguments || (Arguments = {})); - } - }); - - // src/jsTyping/types.ts - var init_types2 = __esm({ - "src/jsTyping/types.ts"() { - "use strict"; - } - }); - - // src/jsTyping/_namespaces/ts.server.ts - var ts_server_exports = {}; - __export(ts_server_exports, { - ActionInvalidate: () => ActionInvalidate, - ActionPackageInstalled: () => ActionPackageInstalled, - ActionSet: () => ActionSet, - ActionWatchTypingLocations: () => ActionWatchTypingLocations, - Arguments: () => Arguments, - EventBeginInstallTypes: () => EventBeginInstallTypes, - EventEndInstallTypes: () => EventEndInstallTypes, - EventInitializationFailed: () => EventInitializationFailed, - EventTypesRegistry: () => EventTypesRegistry, - findArgument: () => findArgument, - hasArgument: () => hasArgument, - nowString: () => nowString - }); - var init_ts_server = __esm({ - "src/jsTyping/_namespaces/ts.server.ts"() { - "use strict"; - init_shared(); - init_types2(); - } - }); - - // src/jsTyping/_namespaces/ts.ts - var init_ts3 = __esm({ - "src/jsTyping/_namespaces/ts.ts"() { - "use strict"; - init_ts2(); - init_ts_JsTyping(); - init_ts_server(); - } - }); - - // src/services/types.ts - function getDefaultFormatCodeSettings(newLineCharacter) { - return { - indentSize: 4, - tabSize: 4, - newLineCharacter: newLineCharacter || "\n", - convertTabsToSpaces: true, - indentStyle: 2 /* Smart */, - insertSpaceAfterConstructor: false, - insertSpaceAfterCommaDelimiter: true, - insertSpaceAfterSemicolonInForStatements: true, - insertSpaceBeforeAndAfterBinaryOperators: true, - insertSpaceAfterKeywordsInControlFlowStatements: true, - insertSpaceAfterFunctionKeywordForAnonymousFunctions: false, - insertSpaceAfterOpeningAndBeforeClosingNonemptyParenthesis: false, - insertSpaceAfterOpeningAndBeforeClosingNonemptyBrackets: false, - insertSpaceAfterOpeningAndBeforeClosingNonemptyBraces: true, - insertSpaceAfterOpeningAndBeforeClosingTemplateStringBraces: false, - insertSpaceAfterOpeningAndBeforeClosingJsxExpressionBraces: false, - insertSpaceBeforeFunctionParenthesis: false, - placeOpenBraceOnNewLineForFunctions: false, - placeOpenBraceOnNewLineForControlBlocks: false, - semicolons: "ignore" /* Ignore */, - trimTrailingWhitespace: true, - indentSwitchCase: true - }; + function createTextSpanFromRange(range) { + return createTextSpanFromBounds(range.pos, range.end); } - var ScriptSnapshot, PackageJsonDependencyGroup, PackageJsonAutoImportPreference, LanguageServiceMode, emptyOptions, SemanticClassificationFormat, OrganizeImportsMode, CompletionTriggerKind, InlayHintKind, HighlightSpanKind, IndentStyle, SemicolonPreference, testFormatSettings, SymbolDisplayPartKind, CompletionInfoFlags, OutliningSpanKind, OutputFileType, EndOfLineState, TokenClass, ScriptElementKind, ScriptElementKindModifier, ClassificationTypeNames, ClassificationType; - var init_types3 = __esm({ - "src/services/types.ts"() { - "use strict"; - ((ScriptSnapshot2) => { - class StringScriptSnapshot { - constructor(text) { - this.text = text; - } - getText(start, end) { - return start === 0 && end === this.text.length ? this.text : this.text.substring(start, end); - } - getLength() { - return this.text.length; - } - getChangeRange() { - return void 0; - } - } - function fromString(text) { - return new StringScriptSnapshot(text); - } - ScriptSnapshot2.fromString = fromString; - })(ScriptSnapshot || (ScriptSnapshot = {})); - PackageJsonDependencyGroup = /* @__PURE__ */ ((PackageJsonDependencyGroup2) => { - PackageJsonDependencyGroup2[PackageJsonDependencyGroup2["Dependencies"] = 1] = "Dependencies"; - PackageJsonDependencyGroup2[PackageJsonDependencyGroup2["DevDependencies"] = 2] = "DevDependencies"; - PackageJsonDependencyGroup2[PackageJsonDependencyGroup2["PeerDependencies"] = 4] = "PeerDependencies"; - PackageJsonDependencyGroup2[PackageJsonDependencyGroup2["OptionalDependencies"] = 8] = "OptionalDependencies"; - PackageJsonDependencyGroup2[PackageJsonDependencyGroup2["All"] = 15] = "All"; - return PackageJsonDependencyGroup2; - })(PackageJsonDependencyGroup || {}); - PackageJsonAutoImportPreference = /* @__PURE__ */ ((PackageJsonAutoImportPreference2) => { - PackageJsonAutoImportPreference2[PackageJsonAutoImportPreference2["Off"] = 0] = "Off"; - PackageJsonAutoImportPreference2[PackageJsonAutoImportPreference2["On"] = 1] = "On"; - PackageJsonAutoImportPreference2[PackageJsonAutoImportPreference2["Auto"] = 2] = "Auto"; - return PackageJsonAutoImportPreference2; - })(PackageJsonAutoImportPreference || {}); - LanguageServiceMode = /* @__PURE__ */ ((LanguageServiceMode2) => { - LanguageServiceMode2[LanguageServiceMode2["Semantic"] = 0] = "Semantic"; - LanguageServiceMode2[LanguageServiceMode2["PartialSemantic"] = 1] = "PartialSemantic"; - LanguageServiceMode2[LanguageServiceMode2["Syntactic"] = 2] = "Syntactic"; - return LanguageServiceMode2; - })(LanguageServiceMode || {}); - emptyOptions = {}; - SemanticClassificationFormat = /* @__PURE__ */ ((SemanticClassificationFormat3) => { - SemanticClassificationFormat3["Original"] = "original"; - SemanticClassificationFormat3["TwentyTwenty"] = "2020"; - return SemanticClassificationFormat3; - })(SemanticClassificationFormat || {}); - OrganizeImportsMode = /* @__PURE__ */ ((OrganizeImportsMode2) => { - OrganizeImportsMode2["All"] = "All"; - OrganizeImportsMode2["SortAndCombine"] = "SortAndCombine"; - OrganizeImportsMode2["RemoveUnused"] = "RemoveUnused"; - return OrganizeImportsMode2; - })(OrganizeImportsMode || {}); - CompletionTriggerKind = /* @__PURE__ */ ((CompletionTriggerKind2) => { - CompletionTriggerKind2[CompletionTriggerKind2["Invoked"] = 1] = "Invoked"; - CompletionTriggerKind2[CompletionTriggerKind2["TriggerCharacter"] = 2] = "TriggerCharacter"; - CompletionTriggerKind2[CompletionTriggerKind2["TriggerForIncompleteCompletions"] = 3] = "TriggerForIncompleteCompletions"; - return CompletionTriggerKind2; - })(CompletionTriggerKind || {}); - InlayHintKind = /* @__PURE__ */ ((InlayHintKind2) => { - InlayHintKind2["Type"] = "Type"; - InlayHintKind2["Parameter"] = "Parameter"; - InlayHintKind2["Enum"] = "Enum"; - return InlayHintKind2; - })(InlayHintKind || {}); - HighlightSpanKind = /* @__PURE__ */ ((HighlightSpanKind2) => { - HighlightSpanKind2["none"] = "none"; - HighlightSpanKind2["definition"] = "definition"; - HighlightSpanKind2["reference"] = "reference"; - HighlightSpanKind2["writtenReference"] = "writtenReference"; - return HighlightSpanKind2; - })(HighlightSpanKind || {}); - IndentStyle = /* @__PURE__ */ ((IndentStyle2) => { - IndentStyle2[IndentStyle2["None"] = 0] = "None"; - IndentStyle2[IndentStyle2["Block"] = 1] = "Block"; - IndentStyle2[IndentStyle2["Smart"] = 2] = "Smart"; - return IndentStyle2; - })(IndentStyle || {}); - SemicolonPreference = /* @__PURE__ */ ((SemicolonPreference2) => { - SemicolonPreference2["Ignore"] = "ignore"; - SemicolonPreference2["Insert"] = "insert"; - SemicolonPreference2["Remove"] = "remove"; - return SemicolonPreference2; - })(SemicolonPreference || {}); - testFormatSettings = getDefaultFormatCodeSettings("\n"); - SymbolDisplayPartKind = /* @__PURE__ */ ((SymbolDisplayPartKind2) => { - SymbolDisplayPartKind2[SymbolDisplayPartKind2["aliasName"] = 0] = "aliasName"; - SymbolDisplayPartKind2[SymbolDisplayPartKind2["className"] = 1] = "className"; - SymbolDisplayPartKind2[SymbolDisplayPartKind2["enumName"] = 2] = "enumName"; - SymbolDisplayPartKind2[SymbolDisplayPartKind2["fieldName"] = 3] = "fieldName"; - SymbolDisplayPartKind2[SymbolDisplayPartKind2["interfaceName"] = 4] = "interfaceName"; - SymbolDisplayPartKind2[SymbolDisplayPartKind2["keyword"] = 5] = "keyword"; - SymbolDisplayPartKind2[SymbolDisplayPartKind2["lineBreak"] = 6] = "lineBreak"; - SymbolDisplayPartKind2[SymbolDisplayPartKind2["numericLiteral"] = 7] = "numericLiteral"; - SymbolDisplayPartKind2[SymbolDisplayPartKind2["stringLiteral"] = 8] = "stringLiteral"; - SymbolDisplayPartKind2[SymbolDisplayPartKind2["localName"] = 9] = "localName"; - SymbolDisplayPartKind2[SymbolDisplayPartKind2["methodName"] = 10] = "methodName"; - SymbolDisplayPartKind2[SymbolDisplayPartKind2["moduleName"] = 11] = "moduleName"; - SymbolDisplayPartKind2[SymbolDisplayPartKind2["operator"] = 12] = "operator"; - SymbolDisplayPartKind2[SymbolDisplayPartKind2["parameterName"] = 13] = "parameterName"; - SymbolDisplayPartKind2[SymbolDisplayPartKind2["propertyName"] = 14] = "propertyName"; - SymbolDisplayPartKind2[SymbolDisplayPartKind2["punctuation"] = 15] = "punctuation"; - SymbolDisplayPartKind2[SymbolDisplayPartKind2["space"] = 16] = "space"; - SymbolDisplayPartKind2[SymbolDisplayPartKind2["text"] = 17] = "text"; - SymbolDisplayPartKind2[SymbolDisplayPartKind2["typeParameterName"] = 18] = "typeParameterName"; - SymbolDisplayPartKind2[SymbolDisplayPartKind2["enumMemberName"] = 19] = "enumMemberName"; - SymbolDisplayPartKind2[SymbolDisplayPartKind2["functionName"] = 20] = "functionName"; - SymbolDisplayPartKind2[SymbolDisplayPartKind2["regularExpressionLiteral"] = 21] = "regularExpressionLiteral"; - SymbolDisplayPartKind2[SymbolDisplayPartKind2["link"] = 22] = "link"; - SymbolDisplayPartKind2[SymbolDisplayPartKind2["linkName"] = 23] = "linkName"; - SymbolDisplayPartKind2[SymbolDisplayPartKind2["linkText"] = 24] = "linkText"; - return SymbolDisplayPartKind2; - })(SymbolDisplayPartKind || {}); - CompletionInfoFlags = /* @__PURE__ */ ((CompletionInfoFlags2) => { - CompletionInfoFlags2[CompletionInfoFlags2["None"] = 0] = "None"; - CompletionInfoFlags2[CompletionInfoFlags2["MayIncludeAutoImports"] = 1] = "MayIncludeAutoImports"; - CompletionInfoFlags2[CompletionInfoFlags2["IsImportStatementCompletion"] = 2] = "IsImportStatementCompletion"; - CompletionInfoFlags2[CompletionInfoFlags2["IsContinuation"] = 4] = "IsContinuation"; - CompletionInfoFlags2[CompletionInfoFlags2["ResolvedModuleSpecifiers"] = 8] = "ResolvedModuleSpecifiers"; - CompletionInfoFlags2[CompletionInfoFlags2["ResolvedModuleSpecifiersBeyondLimit"] = 16] = "ResolvedModuleSpecifiersBeyondLimit"; - CompletionInfoFlags2[CompletionInfoFlags2["MayIncludeMethodSnippets"] = 32] = "MayIncludeMethodSnippets"; - return CompletionInfoFlags2; - })(CompletionInfoFlags || {}); - OutliningSpanKind = /* @__PURE__ */ ((OutliningSpanKind2) => { - OutliningSpanKind2["Comment"] = "comment"; - OutliningSpanKind2["Region"] = "region"; - OutliningSpanKind2["Code"] = "code"; - OutliningSpanKind2["Imports"] = "imports"; - return OutliningSpanKind2; - })(OutliningSpanKind || {}); - OutputFileType = /* @__PURE__ */ ((OutputFileType2) => { - OutputFileType2[OutputFileType2["JavaScript"] = 0] = "JavaScript"; - OutputFileType2[OutputFileType2["SourceMap"] = 1] = "SourceMap"; - OutputFileType2[OutputFileType2["Declaration"] = 2] = "Declaration"; - return OutputFileType2; - })(OutputFileType || {}); - EndOfLineState = /* @__PURE__ */ ((EndOfLineState3) => { - EndOfLineState3[EndOfLineState3["None"] = 0] = "None"; - EndOfLineState3[EndOfLineState3["InMultiLineCommentTrivia"] = 1] = "InMultiLineCommentTrivia"; - EndOfLineState3[EndOfLineState3["InSingleQuoteStringLiteral"] = 2] = "InSingleQuoteStringLiteral"; - EndOfLineState3[EndOfLineState3["InDoubleQuoteStringLiteral"] = 3] = "InDoubleQuoteStringLiteral"; - EndOfLineState3[EndOfLineState3["InTemplateHeadOrNoSubstitutionTemplate"] = 4] = "InTemplateHeadOrNoSubstitutionTemplate"; - EndOfLineState3[EndOfLineState3["InTemplateMiddleOrTail"] = 5] = "InTemplateMiddleOrTail"; - EndOfLineState3[EndOfLineState3["InTemplateSubstitutionPosition"] = 6] = "InTemplateSubstitutionPosition"; - return EndOfLineState3; - })(EndOfLineState || {}); - TokenClass = /* @__PURE__ */ ((TokenClass2) => { - TokenClass2[TokenClass2["Punctuation"] = 0] = "Punctuation"; - TokenClass2[TokenClass2["Keyword"] = 1] = "Keyword"; - TokenClass2[TokenClass2["Operator"] = 2] = "Operator"; - TokenClass2[TokenClass2["Comment"] = 3] = "Comment"; - TokenClass2[TokenClass2["Whitespace"] = 4] = "Whitespace"; - TokenClass2[TokenClass2["Identifier"] = 5] = "Identifier"; - TokenClass2[TokenClass2["NumberLiteral"] = 6] = "NumberLiteral"; - TokenClass2[TokenClass2["BigIntLiteral"] = 7] = "BigIntLiteral"; - TokenClass2[TokenClass2["StringLiteral"] = 8] = "StringLiteral"; - TokenClass2[TokenClass2["RegExpLiteral"] = 9] = "RegExpLiteral"; - return TokenClass2; - })(TokenClass || {}); - ScriptElementKind = /* @__PURE__ */ ((ScriptElementKind2) => { - ScriptElementKind2["unknown"] = ""; - ScriptElementKind2["warning"] = "warning"; - ScriptElementKind2["keyword"] = "keyword"; - ScriptElementKind2["scriptElement"] = "script"; - ScriptElementKind2["moduleElement"] = "module"; - ScriptElementKind2["classElement"] = "class"; - ScriptElementKind2["localClassElement"] = "local class"; - ScriptElementKind2["interfaceElement"] = "interface"; - ScriptElementKind2["typeElement"] = "type"; - ScriptElementKind2["enumElement"] = "enum"; - ScriptElementKind2["enumMemberElement"] = "enum member"; - ScriptElementKind2["variableElement"] = "var"; - ScriptElementKind2["localVariableElement"] = "local var"; - ScriptElementKind2["functionElement"] = "function"; - ScriptElementKind2["localFunctionElement"] = "local function"; - ScriptElementKind2["memberFunctionElement"] = "method"; - ScriptElementKind2["memberGetAccessorElement"] = "getter"; - ScriptElementKind2["memberSetAccessorElement"] = "setter"; - ScriptElementKind2["memberVariableElement"] = "property"; - ScriptElementKind2["memberAccessorVariableElement"] = "accessor"; - ScriptElementKind2["constructorImplementationElement"] = "constructor"; - ScriptElementKind2["callSignatureElement"] = "call"; - ScriptElementKind2["indexSignatureElement"] = "index"; - ScriptElementKind2["constructSignatureElement"] = "construct"; - ScriptElementKind2["parameterElement"] = "parameter"; - ScriptElementKind2["typeParameterElement"] = "type parameter"; - ScriptElementKind2["primitiveType"] = "primitive type"; - ScriptElementKind2["label"] = "label"; - ScriptElementKind2["alias"] = "alias"; - ScriptElementKind2["constElement"] = "const"; - ScriptElementKind2["letElement"] = "let"; - ScriptElementKind2["directory"] = "directory"; - ScriptElementKind2["externalModuleName"] = "external module name"; - ScriptElementKind2["jsxAttribute"] = "JSX attribute"; - ScriptElementKind2["string"] = "string"; - ScriptElementKind2["link"] = "link"; - ScriptElementKind2["linkName"] = "link name"; - ScriptElementKind2["linkText"] = "link text"; - return ScriptElementKind2; - })(ScriptElementKind || {}); - ScriptElementKindModifier = /* @__PURE__ */ ((ScriptElementKindModifier2) => { - ScriptElementKindModifier2["none"] = ""; - ScriptElementKindModifier2["publicMemberModifier"] = "public"; - ScriptElementKindModifier2["privateMemberModifier"] = "private"; - ScriptElementKindModifier2["protectedMemberModifier"] = "protected"; - ScriptElementKindModifier2["exportedModifier"] = "export"; - ScriptElementKindModifier2["ambientModifier"] = "declare"; - ScriptElementKindModifier2["staticModifier"] = "static"; - ScriptElementKindModifier2["abstractModifier"] = "abstract"; - ScriptElementKindModifier2["optionalModifier"] = "optional"; - ScriptElementKindModifier2["deprecatedModifier"] = "deprecated"; - ScriptElementKindModifier2["dtsModifier"] = ".d.ts"; - ScriptElementKindModifier2["tsModifier"] = ".ts"; - ScriptElementKindModifier2["tsxModifier"] = ".tsx"; - ScriptElementKindModifier2["jsModifier"] = ".js"; - ScriptElementKindModifier2["jsxModifier"] = ".jsx"; - ScriptElementKindModifier2["jsonModifier"] = ".json"; - ScriptElementKindModifier2["dmtsModifier"] = ".d.mts"; - ScriptElementKindModifier2["mtsModifier"] = ".mts"; - ScriptElementKindModifier2["mjsModifier"] = ".mjs"; - ScriptElementKindModifier2["dctsModifier"] = ".d.cts"; - ScriptElementKindModifier2["ctsModifier"] = ".cts"; - ScriptElementKindModifier2["cjsModifier"] = ".cjs"; - return ScriptElementKindModifier2; - })(ScriptElementKindModifier || {}); - ClassificationTypeNames = /* @__PURE__ */ ((ClassificationTypeNames2) => { - ClassificationTypeNames2["comment"] = "comment"; - ClassificationTypeNames2["identifier"] = "identifier"; - ClassificationTypeNames2["keyword"] = "keyword"; - ClassificationTypeNames2["numericLiteral"] = "number"; - ClassificationTypeNames2["bigintLiteral"] = "bigint"; - ClassificationTypeNames2["operator"] = "operator"; - ClassificationTypeNames2["stringLiteral"] = "string"; - ClassificationTypeNames2["whiteSpace"] = "whitespace"; - ClassificationTypeNames2["text"] = "text"; - ClassificationTypeNames2["punctuation"] = "punctuation"; - ClassificationTypeNames2["className"] = "class name"; - ClassificationTypeNames2["enumName"] = "enum name"; - ClassificationTypeNames2["interfaceName"] = "interface name"; - ClassificationTypeNames2["moduleName"] = "module name"; - ClassificationTypeNames2["typeParameterName"] = "type parameter name"; - ClassificationTypeNames2["typeAliasName"] = "type alias name"; - ClassificationTypeNames2["parameterName"] = "parameter name"; - ClassificationTypeNames2["docCommentTagName"] = "doc comment tag name"; - ClassificationTypeNames2["jsxOpenTagName"] = "jsx open tag name"; - ClassificationTypeNames2["jsxCloseTagName"] = "jsx close tag name"; - ClassificationTypeNames2["jsxSelfClosingTagName"] = "jsx self closing tag name"; - ClassificationTypeNames2["jsxAttribute"] = "jsx attribute"; - ClassificationTypeNames2["jsxText"] = "jsx text"; - ClassificationTypeNames2["jsxAttributeStringLiteralValue"] = "jsx attribute string literal value"; - return ClassificationTypeNames2; - })(ClassificationTypeNames || {}); - ClassificationType = /* @__PURE__ */ ((ClassificationType2) => { - ClassificationType2[ClassificationType2["comment"] = 1] = "comment"; - ClassificationType2[ClassificationType2["identifier"] = 2] = "identifier"; - ClassificationType2[ClassificationType2["keyword"] = 3] = "keyword"; - ClassificationType2[ClassificationType2["numericLiteral"] = 4] = "numericLiteral"; - ClassificationType2[ClassificationType2["operator"] = 5] = "operator"; - ClassificationType2[ClassificationType2["stringLiteral"] = 6] = "stringLiteral"; - ClassificationType2[ClassificationType2["regularExpressionLiteral"] = 7] = "regularExpressionLiteral"; - ClassificationType2[ClassificationType2["whiteSpace"] = 8] = "whiteSpace"; - ClassificationType2[ClassificationType2["text"] = 9] = "text"; - ClassificationType2[ClassificationType2["punctuation"] = 10] = "punctuation"; - ClassificationType2[ClassificationType2["className"] = 11] = "className"; - ClassificationType2[ClassificationType2["enumName"] = 12] = "enumName"; - ClassificationType2[ClassificationType2["interfaceName"] = 13] = "interfaceName"; - ClassificationType2[ClassificationType2["moduleName"] = 14] = "moduleName"; - ClassificationType2[ClassificationType2["typeParameterName"] = 15] = "typeParameterName"; - ClassificationType2[ClassificationType2["typeAliasName"] = 16] = "typeAliasName"; - ClassificationType2[ClassificationType2["parameterName"] = 17] = "parameterName"; - ClassificationType2[ClassificationType2["docCommentTagName"] = 18] = "docCommentTagName"; - ClassificationType2[ClassificationType2["jsxOpenTagName"] = 19] = "jsxOpenTagName"; - ClassificationType2[ClassificationType2["jsxCloseTagName"] = 20] = "jsxCloseTagName"; - ClassificationType2[ClassificationType2["jsxSelfClosingTagName"] = 21] = "jsxSelfClosingTagName"; - ClassificationType2[ClassificationType2["jsxAttribute"] = 22] = "jsxAttribute"; - ClassificationType2[ClassificationType2["jsxText"] = 23] = "jsxText"; - ClassificationType2[ClassificationType2["jsxAttributeStringLiteralValue"] = 24] = "jsxAttributeStringLiteralValue"; - ClassificationType2[ClassificationType2["bigintLiteral"] = 25] = "bigintLiteral"; - return ClassificationType2; - })(ClassificationType || {}); - } - }); - - // src/services/utilities.ts - function getMeaningFromDeclaration(node) { - switch (node.kind) { - case 259 /* VariableDeclaration */: - return isInJSFile(node) && getJSDocEnumTag(node) ? 7 /* All */ : 1 /* Value */; - case 168 /* Parameter */: - case 207 /* BindingElement */: - case 171 /* PropertyDeclaration */: - case 170 /* PropertySignature */: - case 302 /* PropertyAssignment */: - case 303 /* ShorthandPropertyAssignment */: - case 173 /* MethodDeclaration */: - case 172 /* MethodSignature */: - case 175 /* Constructor */: - case 176 /* GetAccessor */: - case 177 /* SetAccessor */: - case 261 /* FunctionDeclaration */: - case 217 /* FunctionExpression */: - case 218 /* ArrowFunction */: - case 298 /* CatchClause */: - case 290 /* JsxAttribute */: - return 1 /* Value */; - case 167 /* TypeParameter */: - case 263 /* InterfaceDeclaration */: - case 264 /* TypeAliasDeclaration */: - case 186 /* TypeLiteral */: - return 2 /* Type */; - case 352 /* JSDocTypedefTag */: - return node.name === void 0 ? 1 /* Value */ | 2 /* Type */ : 2 /* Type */; - case 305 /* EnumMember */: - case 262 /* ClassDeclaration */: - return 1 /* Value */ | 2 /* Type */; - case 266 /* ModuleDeclaration */: - if (isAmbientModule(node)) { - return 4 /* Namespace */ | 1 /* Value */; - } else if (getModuleInstanceState(node) === 1 /* Instantiated */) { - return 4 /* Namespace */ | 1 /* Value */; - } else { - return 4 /* Namespace */; - } - case 265 /* EnumDeclaration */: - case 274 /* NamedImports */: - case 275 /* ImportSpecifier */: - case 270 /* ImportEqualsDeclaration */: - case 271 /* ImportDeclaration */: - case 276 /* ExportAssignment */: - case 277 /* ExportDeclaration */: - return 7 /* All */; - case 311 /* SourceFile */: - return 4 /* Namespace */ | 1 /* Value */; + function createTextRangeFromSpan(span) { + return createRange(span.start, span.start + span.length); + } + function createTextChangeFromStartLength(start, length2, newText) { + return createTextChange(createTextSpan(start, length2), newText); + } + function createTextChange(span, newText) { + return { span, newText }; + } + function isTypeKeyword(kind) { + return contains(typeKeywords, kind); + } + function isTypeKeywordToken(node) { + return node.kind === 156 /* TypeKeyword */; + } + function isTypeKeywordTokenOrIdentifier(node) { + return isTypeKeywordToken(node) || isIdentifier(node) && node.text === "type"; + } + function isExternalModuleSymbol(moduleSymbol) { + return !!(moduleSymbol.flags & 1536 /* Module */) && moduleSymbol.name.charCodeAt(0) === 34 /* doubleQuote */; + } + function nodeSeenTracker() { + const seen = []; + return (node) => { + const id = getNodeId(node); + return !seen[id] && (seen[id] = true); + }; + } + function getSnapshotText(snap) { + return snap.getText(0, snap.getLength()); + } + function repeatString(str, count) { + let result = ""; + for (let i = 0; i < count; i++) { + result += str; } - return 7 /* All */; + return result; } - function getMeaningFromLocation(node) { - node = getAdjustedReferenceLocation(node); - const parent2 = node.parent; - if (node.kind === 311 /* SourceFile */) { - return 1 /* Value */; - } else if (isExportAssignment(parent2) || isExportSpecifier(parent2) || isExternalModuleReference(parent2) || isImportSpecifier(parent2) || isImportClause(parent2) || isImportEqualsDeclaration(parent2) && node === parent2.name) { - return 7 /* All */; - } else if (isInRightSideOfInternalImportEqualsDeclaration(node)) { - return getMeaningFromRightHandSideOfImportEquals(node); - } else if (isDeclarationName(node)) { - return getMeaningFromDeclaration(parent2); - } else if (isEntityName(node) && findAncestor(node, or(isJSDocNameReference, isJSDocLinkLike, isJSDocMemberName))) { - return 7 /* All */; - } else if (isTypeReference(node)) { - return 2 /* Type */; - } else if (isNamespaceReference(node)) { - return 4 /* Namespace */; - } else if (isTypeParameterDeclaration(parent2)) { - Debug.assert(isJSDocTemplateTag(parent2.parent)); - return 2 /* Type */; - } else if (isLiteralTypeNode(parent2)) { - return 2 /* Type */ | 1 /* Value */; + function skipConstraint(type) { + return type.isTypeParameter() ? type.getConstraint() || type : type; + } + function getNameFromPropertyName(name) { + return name.kind === 167 /* ComputedPropertyName */ ? isStringOrNumericLiteralLike(name.expression) ? name.expression.text : void 0 : isPrivateIdentifier(name) ? idText(name) : getTextOfIdentifierOrLiteral(name); + } + function programContainsModules(program) { + return program.getSourceFiles().some((s) => !s.isDeclarationFile && !program.isSourceFileFromExternalLibrary(s) && !!(s.externalModuleIndicator || s.commonJsModuleIndicator)); + } + function programContainsEsModules(program) { + return program.getSourceFiles().some((s) => !s.isDeclarationFile && !program.isSourceFileFromExternalLibrary(s) && !!s.externalModuleIndicator); + } + function compilerOptionsIndicateEsModules(compilerOptions) { + return !!compilerOptions.module || getEmitScriptTarget(compilerOptions) >= 2 /* ES2015 */ || !!compilerOptions.noEmit; + } + function createModuleSpecifierResolutionHost(program, host) { + return { + fileExists: (fileName) => program.fileExists(fileName), + getCurrentDirectory: () => host.getCurrentDirectory(), + readFile: maybeBind(host, host.readFile), + useCaseSensitiveFileNames: maybeBind(host, host.useCaseSensitiveFileNames), + getSymlinkCache: maybeBind(host, host.getSymlinkCache) || program.getSymlinkCache, + getModuleSpecifierCache: maybeBind(host, host.getModuleSpecifierCache), + getPackageJsonInfoCache: () => { + var _a; + return (_a = program.getModuleResolutionCache()) == null ? void 0 : _a.getPackageJsonInfoCache(); + }, + getGlobalTypingsCacheLocation: maybeBind(host, host.getGlobalTypingsCacheLocation), + redirectTargetsMap: program.redirectTargetsMap, + getProjectReferenceRedirect: (fileName) => program.getProjectReferenceRedirect(fileName), + isSourceOfProjectReferenceRedirect: (fileName) => program.isSourceOfProjectReferenceRedirect(fileName), + getNearestAncestorDirectoryWithPackageJson: maybeBind(host, host.getNearestAncestorDirectoryWithPackageJson), + getFileIncludeReasons: () => program.getFileIncludeReasons() + }; + } + function getModuleSpecifierResolverHost(program, host) { + return { + ...createModuleSpecifierResolutionHost(program, host), + getCommonSourceDirectory: () => program.getCommonSourceDirectory() + }; + } + function moduleResolutionUsesNodeModules(moduleResolution) { + return moduleResolution === 2 /* Node10 */ || moduleResolution >= 3 /* Node16 */ && moduleResolution <= 99 /* NodeNext */ || moduleResolution === 100 /* Bundler */; + } + function makeImportIfNecessary(defaultImport, namedImports, moduleSpecifier, quotePreference) { + return defaultImport || namedImports && namedImports.length ? makeImport(defaultImport, namedImports, moduleSpecifier, quotePreference) : void 0; + } + function makeImport(defaultImport, namedImports, moduleSpecifier, quotePreference, isTypeOnly) { + return factory.createImportDeclaration( + /*modifiers*/ + void 0, + defaultImport || namedImports ? factory.createImportClause(!!isTypeOnly, defaultImport, namedImports && namedImports.length ? factory.createNamedImports(namedImports) : void 0) : void 0, + typeof moduleSpecifier === "string" ? makeStringLiteral(moduleSpecifier, quotePreference) : moduleSpecifier, + /*attributes*/ + void 0 + ); + } + function makeStringLiteral(text, quotePreference) { + return factory.createStringLiteral(text, quotePreference === 0 /* Single */); + } + function quotePreferenceFromString(str, sourceFile) { + return isStringDoubleQuoted(str, sourceFile) ? 1 /* Double */ : 0 /* Single */; + } + function getQuotePreference(sourceFile, preferences) { + if (preferences.quotePreference && preferences.quotePreference !== "auto") { + return preferences.quotePreference === "single" ? 0 /* Single */ : 1 /* Double */; } else { - return 1 /* Value */; + const firstModuleSpecifier = sourceFile.imports && find(sourceFile.imports, (n) => isStringLiteral(n) && !nodeIsSynthesized(n.parent)); + return firstModuleSpecifier ? quotePreferenceFromString(firstModuleSpecifier, sourceFile) : 1 /* Double */; } } - function getMeaningFromRightHandSideOfImportEquals(node) { - const name = node.kind === 165 /* QualifiedName */ ? node : isQualifiedName(node.parent) && node.parent.right === node ? node.parent : void 0; - return name && name.parent.kind === 270 /* ImportEqualsDeclaration */ ? 7 /* All */ : 4 /* Namespace */; + function getQuoteFromPreference(qp) { + switch (qp) { + case 0 /* Single */: + return "'"; + case 1 /* Double */: + return '"'; + default: + return Debug.assertNever(qp); + } } - function isInRightSideOfInternalImportEqualsDeclaration(node) { - while (node.parent.kind === 165 /* QualifiedName */) { + function symbolNameNoDefault(symbol) { + const escaped = symbolEscapedNameNoDefault(symbol); + return escaped === void 0 ? void 0 : unescapeLeadingUnderscores(escaped); + } + function symbolEscapedNameNoDefault(symbol) { + if (symbol.escapedName !== "default" /* Default */) { + return symbol.escapedName; + } + return firstDefined(symbol.declarations, (decl) => { + const name = getNameOfDeclaration(decl); + return name && name.kind === 80 /* Identifier */ ? name.escapedText : void 0; + }); + } + function isModuleSpecifierLike(node) { + return isStringLiteralLike(node) && (isExternalModuleReference(node.parent) || isImportDeclaration(node.parent) || isRequireCall( + node.parent, + /*requireStringLiteralLikeArgument*/ + false + ) && node.parent.arguments[0] === node || isImportCall(node.parent) && node.parent.arguments[0] === node); + } + function isObjectBindingElementWithoutPropertyName(bindingElement) { + return isBindingElement(bindingElement) && isObjectBindingPattern(bindingElement.parent) && isIdentifier(bindingElement.name) && !bindingElement.propertyName; + } + function getPropertySymbolFromBindingElement(checker, bindingElement) { + const typeOfPattern = checker.getTypeAtLocation(bindingElement.parent); + return typeOfPattern && checker.getPropertyOfType(typeOfPattern, bindingElement.name.text); + } + function getParentNodeInSpan(node, file, span) { + if (!node) + return void 0; + while (node.parent) { + if (isSourceFile(node.parent) || !spanContainsNode(span, node.parent, file)) { + return node; + } node = node.parent; } - return isInternalModuleImportEqualsDeclaration(node.parent) && node.parent.moduleReference === node; } - function isNamespaceReference(node) { - return isQualifiedNameNamespaceReference(node) || isPropertyAccessNamespaceReference(node); + function spanContainsNode(span, node, file) { + return textSpanContainsPosition(span, node.getStart(file)) && node.getEnd() <= textSpanEnd(span); } - function isQualifiedNameNamespaceReference(node) { - let root = node; - let isLastClause = true; - if (root.parent.kind === 165 /* QualifiedName */) { - while (root.parent && root.parent.kind === 165 /* QualifiedName */) { - root = root.parent; + function findModifier(node, kind) { + return canHaveModifiers(node) ? find(node.modifiers, (m) => m.kind === kind) : void 0; + } + function insertImports(changes, sourceFile, imports, blankLineBetween, preferences) { + const decl = isArray(imports) ? imports[0] : imports; + const importKindPredicate = decl.kind === 243 /* VariableStatement */ ? isRequireVariableStatement : isAnyImportSyntax; + const existingImportStatements = filter(sourceFile.statements, importKindPredicate); + let sortKind = isArray(imports) ? ts_OrganizeImports_exports.detectImportDeclarationSorting(imports, preferences) : 3 /* Both */; + const comparer = ts_OrganizeImports_exports.getOrganizeImportsComparer(preferences, sortKind === 2 /* CaseInsensitive */); + const sortedNewImports = isArray(imports) ? stableSort(imports, (a, b) => ts_OrganizeImports_exports.compareImportsOrRequireStatements(a, b, comparer)) : [imports]; + if (!existingImportStatements.length) { + changes.insertNodesAtTopOfFile(sourceFile, sortedNewImports, blankLineBetween); + } else if (existingImportStatements && (sortKind = ts_OrganizeImports_exports.detectImportDeclarationSorting(existingImportStatements, preferences))) { + const comparer2 = ts_OrganizeImports_exports.getOrganizeImportsComparer(preferences, sortKind === 2 /* CaseInsensitive */); + for (const newImport of sortedNewImports) { + const insertionIndex = ts_OrganizeImports_exports.getImportDeclarationInsertionIndex(existingImportStatements, newImport, comparer2); + if (insertionIndex === 0) { + const options = existingImportStatements[0] === sourceFile.statements[0] ? { leadingTriviaOption: ts_textChanges_exports.LeadingTriviaOption.Exclude } : {}; + changes.insertNodeBefore( + sourceFile, + existingImportStatements[0], + newImport, + /*blankLineBetween*/ + false, + options + ); + } else { + const prevImport = existingImportStatements[insertionIndex - 1]; + changes.insertNodeAfter(sourceFile, prevImport, newImport); + } + } + } else { + const lastExistingImport = lastOrUndefined(existingImportStatements); + if (lastExistingImport) { + changes.insertNodesAfter(sourceFile, lastExistingImport, sortedNewImports); + } else { + changes.insertNodesAtTopOfFile(sourceFile, sortedNewImports, blankLineBetween); } - isLastClause = root.right === node; } - return root.parent.kind === 182 /* TypeReference */ && !isLastClause; } - function isPropertyAccessNamespaceReference(node) { - let root = node; - let isLastClause = true; - if (root.parent.kind === 210 /* PropertyAccessExpression */) { - while (root.parent && root.parent.kind === 210 /* PropertyAccessExpression */) { - root = root.parent; + function getTypeKeywordOfTypeOnlyImport(importClause, sourceFile) { + Debug.assert(importClause.isTypeOnly); + return cast(importClause.getChildAt(0, sourceFile), isTypeKeywordToken); + } + function textSpansEqual(a, b) { + return !!a && !!b && a.start === b.start && a.length === b.length; + } + function documentSpansEqual(a, b) { + return a.fileName === b.fileName && textSpansEqual(a.textSpan, b.textSpan); + } + function forEachUnique(array, callback) { + if (array) { + for (let i = 0; i < array.length; i++) { + if (array.indexOf(array[i]) === i) { + const result = callback(array[i], i); + if (result) { + return result; + } + } } - isLastClause = root.name === node; } - if (!isLastClause && root.parent.kind === 232 /* ExpressionWithTypeArguments */ && root.parent.parent.kind === 297 /* HeritageClause */) { - const decl = root.parent.parent.parent; - return decl.kind === 262 /* ClassDeclaration */ && root.parent.parent.token === 119 /* ImplementsKeyword */ || decl.kind === 263 /* InterfaceDeclaration */ && root.parent.parent.token === 96 /* ExtendsKeyword */; + return void 0; + } + function isTextWhiteSpaceLike(text, startPos, endPos) { + for (let i = startPos; i < endPos; i++) { + if (!isWhiteSpaceLike(text.charCodeAt(i))) { + return false; + } } - return false; + return true; } - function isTypeReference(node) { - if (isRightSideOfQualifiedNameOrPropertyAccess(node)) { - node = node.parent; + function getMappedLocation(location, sourceMapper, fileExists) { + const mapsTo = sourceMapper.tryGetSourcePosition(location); + return mapsTo && (!fileExists || fileExists(normalizePath(mapsTo.fileName)) ? mapsTo : void 0); + } + function getMappedDocumentSpan(documentSpan, sourceMapper, fileExists) { + const { fileName, textSpan } = documentSpan; + const newPosition = getMappedLocation({ fileName, pos: textSpan.start }, sourceMapper, fileExists); + if (!newPosition) + return void 0; + const newEndPosition = getMappedLocation({ fileName, pos: textSpan.start + textSpan.length }, sourceMapper, fileExists); + const newLength = newEndPosition ? newEndPosition.pos - newPosition.pos : textSpan.length; + return { + fileName: newPosition.fileName, + textSpan: { + start: newPosition.pos, + length: newLength + }, + originalFileName: documentSpan.fileName, + originalTextSpan: documentSpan.textSpan, + contextSpan: getMappedContextSpan(documentSpan, sourceMapper, fileExists), + originalContextSpan: documentSpan.contextSpan + }; + } + function getMappedContextSpan(documentSpan, sourceMapper, fileExists) { + const contextSpanStart = documentSpan.contextSpan && getMappedLocation( + { fileName: documentSpan.fileName, pos: documentSpan.contextSpan.start }, + sourceMapper, + fileExists + ); + const contextSpanEnd = documentSpan.contextSpan && getMappedLocation( + { fileName: documentSpan.fileName, pos: documentSpan.contextSpan.start + documentSpan.contextSpan.length }, + sourceMapper, + fileExists + ); + return contextSpanStart && contextSpanEnd ? { start: contextSpanStart.pos, length: contextSpanEnd.pos - contextSpanStart.pos } : void 0; + } + function isFirstDeclarationOfSymbolParameter(symbol) { + const declaration = symbol.declarations ? firstOrUndefined(symbol.declarations) : void 0; + return !!findAncestor(declaration, (n) => isParameter(n) ? true : isBindingElement(n) || isObjectBindingPattern(n) || isArrayBindingPattern(n) ? false : "quit"); + } + function getDisplayPartWriter() { + const absoluteMaximumLength = defaultMaximumTruncationLength * 10; + let displayParts; + let lineStart; + let indent3; + let length2; + resetWriter(); + const unknownWrite = (text) => writeKind(text, 17 /* text */); + return { + displayParts: () => { + const finalText = displayParts.length && displayParts[displayParts.length - 1].text; + if (length2 > absoluteMaximumLength && finalText && finalText !== "...") { + if (!isWhiteSpaceLike(finalText.charCodeAt(finalText.length - 1))) { + displayParts.push(displayPart(" ", 16 /* space */)); + } + displayParts.push(displayPart("...", 15 /* punctuation */)); + } + return displayParts; + }, + writeKeyword: (text) => writeKind(text, 5 /* keyword */), + writeOperator: (text) => writeKind(text, 12 /* operator */), + writePunctuation: (text) => writeKind(text, 15 /* punctuation */), + writeTrailingSemicolon: (text) => writeKind(text, 15 /* punctuation */), + writeSpace: (text) => writeKind(text, 16 /* space */), + writeStringLiteral: (text) => writeKind(text, 8 /* stringLiteral */), + writeParameter: (text) => writeKind(text, 13 /* parameterName */), + writeProperty: (text) => writeKind(text, 14 /* propertyName */), + writeLiteral: (text) => writeKind(text, 8 /* stringLiteral */), + writeSymbol, + writeLine, + write: unknownWrite, + writeComment: unknownWrite, + getText: () => "", + getTextPos: () => 0, + getColumn: () => 0, + getLine: () => 0, + isAtStartOfLine: () => false, + hasTrailingWhitespace: () => false, + hasTrailingComment: () => false, + rawWrite: notImplemented, + getIndent: () => indent3, + increaseIndent: () => { + indent3++; + }, + decreaseIndent: () => { + indent3--; + }, + clear: resetWriter + }; + function writeIndent() { + if (length2 > absoluteMaximumLength) + return; + if (lineStart) { + const indentString = getIndentString(indent3); + if (indentString) { + length2 += indentString.length; + displayParts.push(displayPart(indentString, 16 /* space */)); + } + lineStart = false; + } } - switch (node.kind) { - case 110 /* ThisKeyword */: - return !isExpressionNode(node); - case 196 /* ThisType */: - return true; + function writeKind(text, kind) { + if (length2 > absoluteMaximumLength) + return; + writeIndent(); + length2 += text.length; + displayParts.push(displayPart(text, kind)); } - switch (node.parent.kind) { - case 182 /* TypeReference */: - return true; - case 204 /* ImportType */: - return !node.parent.isTypeOf; - case 232 /* ExpressionWithTypeArguments */: - return isPartOfTypeNode(node.parent); + function writeSymbol(text, symbol) { + if (length2 > absoluteMaximumLength) + return; + writeIndent(); + length2 += text.length; + displayParts.push(symbolPart(text, symbol)); + } + function writeLine() { + if (length2 > absoluteMaximumLength) + return; + length2 += 1; + displayParts.push(lineBreakPart()); + lineStart = true; + } + function resetWriter() { + displayParts = []; + lineStart = true; + indent3 = 0; + length2 = 0; } - return false; } - function isCallExpressionTarget(node, includeElementAccess = false, skipPastOuterExpressions = false) { - return isCalleeWorker(node, isCallExpression, selectExpressionOfCallOrNewExpressionOrDecorator, includeElementAccess, skipPastOuterExpressions); + function symbolPart(text, symbol) { + return displayPart(text, displayPartKind(symbol)); + function displayPartKind(symbol2) { + const flags = symbol2.flags; + if (flags & 3 /* Variable */) { + return isFirstDeclarationOfSymbolParameter(symbol2) ? 13 /* parameterName */ : 9 /* localName */; + } + if (flags & 4 /* Property */) + return 14 /* propertyName */; + if (flags & 32768 /* GetAccessor */) + return 14 /* propertyName */; + if (flags & 65536 /* SetAccessor */) + return 14 /* propertyName */; + if (flags & 8 /* EnumMember */) + return 19 /* enumMemberName */; + if (flags & 16 /* Function */) + return 20 /* functionName */; + if (flags & 32 /* Class */) + return 1 /* className */; + if (flags & 64 /* Interface */) + return 4 /* interfaceName */; + if (flags & 384 /* Enum */) + return 2 /* enumName */; + if (flags & 1536 /* Module */) + return 11 /* moduleName */; + if (flags & 8192 /* Method */) + return 10 /* methodName */; + if (flags & 262144 /* TypeParameter */) + return 18 /* typeParameterName */; + if (flags & 524288 /* TypeAlias */) + return 0 /* aliasName */; + if (flags & 2097152 /* Alias */) + return 0 /* aliasName */; + return 17 /* text */; + } } - function isNewExpressionTarget(node, includeElementAccess = false, skipPastOuterExpressions = false) { - return isCalleeWorker(node, isNewExpression, selectExpressionOfCallOrNewExpressionOrDecorator, includeElementAccess, skipPastOuterExpressions); + function displayPart(text, kind) { + return { text, kind: SymbolDisplayPartKind[kind] }; } - function isCallOrNewExpressionTarget(node, includeElementAccess = false, skipPastOuterExpressions = false) { - return isCalleeWorker(node, isCallOrNewExpression, selectExpressionOfCallOrNewExpressionOrDecorator, includeElementAccess, skipPastOuterExpressions); + function spacePart() { + return displayPart(" ", 16 /* space */); } - function isTaggedTemplateTag(node, includeElementAccess = false, skipPastOuterExpressions = false) { - return isCalleeWorker(node, isTaggedTemplateExpression, selectTagOfTaggedTemplateExpression, includeElementAccess, skipPastOuterExpressions); + function keywordPart(kind) { + return displayPart(tokenToString(kind), 5 /* keyword */); } - function isDecoratorTarget(node, includeElementAccess = false, skipPastOuterExpressions = false) { - return isCalleeWorker(node, isDecorator, selectExpressionOfCallOrNewExpressionOrDecorator, includeElementAccess, skipPastOuterExpressions); + function punctuationPart(kind) { + return displayPart(tokenToString(kind), 15 /* punctuation */); } - function isJsxOpeningLikeElementTagName(node, includeElementAccess = false, skipPastOuterExpressions = false) { - return isCalleeWorker(node, isJsxOpeningLikeElement, selectTagNameOfJsxOpeningLikeElement, includeElementAccess, skipPastOuterExpressions); + function operatorPart(kind) { + return displayPart(tokenToString(kind), 12 /* operator */); } - function selectExpressionOfCallOrNewExpressionOrDecorator(node) { - return node.expression; + function parameterNamePart(text) { + return displayPart(text, 13 /* parameterName */); } - function selectTagOfTaggedTemplateExpression(node) { - return node.tag; + function propertyNamePart(text) { + return displayPart(text, 14 /* propertyName */); } - function selectTagNameOfJsxOpeningLikeElement(node) { - return node.tagName; + function textOrKeywordPart(text) { + const kind = stringToToken(text); + return kind === void 0 ? textPart(text) : keywordPart(kind); } - function isCalleeWorker(node, pred, calleeSelector, includeElementAccess, skipPastOuterExpressions) { - let target = includeElementAccess ? climbPastPropertyOrElementAccess(node) : climbPastPropertyAccess(node); - if (skipPastOuterExpressions) { - target = skipOuterExpressions(target); - } - return !!target && !!target.parent && pred(target.parent) && calleeSelector(target.parent) === target; + function textPart(text) { + return displayPart(text, 17 /* text */); } - function climbPastPropertyAccess(node) { - return isRightSideOfPropertyAccess(node) ? node.parent : node; + function typeAliasNamePart(text) { + return displayPart(text, 0 /* aliasName */); } - function climbPastPropertyOrElementAccess(node) { - return isRightSideOfPropertyAccess(node) || isArgumentExpressionOfElementAccess(node) ? node.parent : node; + function typeParameterNamePart(text) { + return displayPart(text, 18 /* typeParameterName */); } - function getTargetLabel(referenceNode, labelName) { - while (referenceNode) { - if (referenceNode.kind === 255 /* LabeledStatement */ && referenceNode.label.escapedText === labelName) { - return referenceNode.label; + function linkTextPart(text) { + return displayPart(text, 24 /* linkText */); + } + function linkNamePart(text, target) { + return { + text, + kind: SymbolDisplayPartKind[23 /* linkName */], + target: { + fileName: getSourceFileOfNode(target).fileName, + textSpan: createTextSpanFromNode(target) + } + }; + } + function linkPart(text) { + return displayPart(text, 22 /* link */); + } + function buildLinkParts(link, checker) { + var _a; + const prefix = isJSDocLink(link) ? "link" : isJSDocLinkCode(link) ? "linkcode" : "linkplain"; + const parts = [linkPart(`{@${prefix} `)]; + if (!link.name) { + if (link.text) { + parts.push(linkTextPart(link.text)); + } + } else { + const symbol = checker == null ? void 0 : checker.getSymbolAtLocation(link.name); + const suffix = findLinkNameEnd(link.text); + const name = getTextOfNode(link.name) + link.text.slice(0, suffix); + const text = skipSeparatorFromLinkText(link.text.slice(suffix)); + const decl = (symbol == null ? void 0 : symbol.valueDeclaration) || ((_a = symbol == null ? void 0 : symbol.declarations) == null ? void 0 : _a[0]); + if (decl) { + parts.push(linkNamePart(name, decl)); + if (text) + parts.push(linkTextPart(text)); + } else { + parts.push(linkTextPart(name + (suffix ? "" : " ") + text)); } - referenceNode = referenceNode.parent; } - return void 0; + parts.push(linkPart("}")); + return parts; } - function hasPropertyAccessExpressionWithName(node, funcName) { - if (!isPropertyAccessExpression(node.expression)) { - return false; + function skipSeparatorFromLinkText(text) { + let pos = 0; + if (text.charCodeAt(pos++) === 124 /* bar */) { + while (pos < text.length && text.charCodeAt(pos) === 32 /* space */) + pos++; + return text.slice(pos); } - return node.expression.name.text === funcName; + return text; } - function isJumpStatementTarget(node) { - var _a; - return isIdentifier(node) && ((_a = tryCast(node.parent, isBreakOrContinueStatement)) == null ? void 0 : _a.label) === node; + function findLinkNameEnd(text) { + let pos = text.indexOf("://"); + if (pos === 0) { + while (pos < text.length && text.charCodeAt(pos) !== 124 /* bar */) + pos++; + return pos; + } + if (text.indexOf("()") === 0) + return 2; + if (text.charAt(0) === "<") { + let brackets2 = 0; + let i = 0; + while (i < text.length) { + if (text[i] === "<") + brackets2++; + if (text[i] === ">") + brackets2--; + i++; + if (!brackets2) + return i; + } + } + return 0; } - function isLabelOfLabeledStatement(node) { + function getNewLineOrDefaultFromHost(host, formatSettings) { var _a; - return isIdentifier(node) && ((_a = tryCast(node.parent, isLabeledStatement)) == null ? void 0 : _a.label) === node; + return (formatSettings == null ? void 0 : formatSettings.newLineCharacter) || ((_a = host.getNewLine) == null ? void 0 : _a.call(host)) || lineFeed2; } - function isLabelName(node) { - return isLabelOfLabeledStatement(node) || isJumpStatementTarget(node); + function lineBreakPart() { + return displayPart("\n", 6 /* lineBreak */); } - function isTagName(node) { - var _a; - return ((_a = tryCast(node.parent, isJSDocTag)) == null ? void 0 : _a.tagName) === node; + function mapToDisplayParts(writeDisplayParts) { + try { + writeDisplayParts(displayPartWriter); + return displayPartWriter.displayParts(); + } finally { + displayPartWriter.clear(); + } } - function isRightSideOfQualifiedName(node) { - var _a; - return ((_a = tryCast(node.parent, isQualifiedName)) == null ? void 0 : _a.right) === node; + function typeToDisplayParts(typechecker, type, enclosingDeclaration, flags = 0 /* None */) { + return mapToDisplayParts((writer) => { + typechecker.writeType(type, enclosingDeclaration, flags | 1024 /* MultilineObjectLiterals */ | 16384 /* UseAliasDefinedOutsideCurrentScope */, writer); + }); } - function isRightSideOfPropertyAccess(node) { - var _a; - return ((_a = tryCast(node.parent, isPropertyAccessExpression)) == null ? void 0 : _a.name) === node; + function symbolToDisplayParts(typeChecker, symbol, enclosingDeclaration, meaning, flags = 0 /* None */) { + return mapToDisplayParts((writer) => { + typeChecker.writeSymbol(symbol, enclosingDeclaration, meaning, flags | 8 /* UseAliasDefinedOutsideCurrentScope */, writer); + }); } - function isArgumentExpressionOfElementAccess(node) { - var _a; - return ((_a = tryCast(node.parent, isElementAccessExpression)) == null ? void 0 : _a.argumentExpression) === node; + function signatureToDisplayParts(typechecker, signature, enclosingDeclaration, flags = 0 /* None */) { + flags |= 16384 /* UseAliasDefinedOutsideCurrentScope */ | 1024 /* MultilineObjectLiterals */ | 32 /* WriteTypeArgumentsOfSignature */ | 8192 /* OmitParameterModifiers */; + return mapToDisplayParts((writer) => { + typechecker.writeSignature( + signature, + enclosingDeclaration, + flags, + /*kind*/ + void 0, + writer + ); + }); } - function isNameOfModuleDeclaration(node) { - var _a; - return ((_a = tryCast(node.parent, isModuleDeclaration)) == null ? void 0 : _a.name) === node; + function nodeToDisplayParts(node, enclosingDeclaration) { + const file = enclosingDeclaration.getSourceFile(); + return mapToDisplayParts((writer) => { + const printer = createPrinterWithRemoveCommentsOmitTrailingSemicolon(); + printer.writeNode(4 /* Unspecified */, node, file, writer); + }); } - function isNameOfFunctionDeclaration(node) { - var _a; - return isIdentifier(node) && ((_a = tryCast(node.parent, isFunctionLike)) == null ? void 0 : _a.name) === node; + function isImportOrExportSpecifierName(location) { + return !!location.parent && isImportOrExportSpecifier(location.parent) && location.parent.propertyName === location; } - function isLiteralNameOfPropertyDeclarationOrIndexAccess(node) { - switch (node.parent.kind) { - case 171 /* PropertyDeclaration */: - case 170 /* PropertySignature */: - case 302 /* PropertyAssignment */: - case 305 /* EnumMember */: - case 173 /* MethodDeclaration */: - case 172 /* MethodSignature */: - case 176 /* GetAccessor */: - case 177 /* SetAccessor */: - case 266 /* ModuleDeclaration */: - return getNameOfDeclaration(node.parent) === node; - case 211 /* ElementAccessExpression */: - return node.parent.argumentExpression === node; - case 166 /* ComputedPropertyName */: - return true; - case 200 /* LiteralType */: - return node.parent.parent.kind === 198 /* IndexedAccessType */; - default: - return false; + function getScriptKind(fileName, host) { + return ensureScriptKind(fileName, host.getScriptKind && host.getScriptKind(fileName)); + } + function getSymbolTarget(symbol, checker) { + let next = symbol; + while (isAliasSymbol(next) || isTransientSymbol(next) && next.links.target) { + if (isTransientSymbol(next) && next.links.target) { + next = next.links.target; + } else { + next = skipAlias(next, checker); + } } + return next; } - function isExpressionOfExternalModuleImportEqualsDeclaration(node) { - return isExternalModuleImportEqualsDeclaration(node.parent.parent) && getExternalModuleImportEqualsDeclarationExpression(node.parent.parent) === node; + function isAliasSymbol(symbol) { + return (symbol.flags & 2097152 /* Alias */) !== 0; } - function getContainerNode(node) { - if (isJSDocTypeAlias(node)) { - node = node.parent.parent; + function getUniqueSymbolId(symbol, checker) { + return getSymbolId(skipAlias(symbol, checker)); + } + function getFirstNonSpaceCharacterPosition(text, position) { + while (isWhiteSpaceLike(text.charCodeAt(position))) { + position += 1; } - while (true) { - node = node.parent; - if (!node) { - return void 0; - } - switch (node.kind) { - case 311 /* SourceFile */: - case 173 /* MethodDeclaration */: - case 172 /* MethodSignature */: - case 261 /* FunctionDeclaration */: - case 217 /* FunctionExpression */: - case 176 /* GetAccessor */: - case 177 /* SetAccessor */: - case 262 /* ClassDeclaration */: - case 263 /* InterfaceDeclaration */: - case 265 /* EnumDeclaration */: - case 266 /* ModuleDeclaration */: - return node; - } + return position; + } + function getPrecedingNonSpaceCharacterPosition(text, position) { + while (position > -1 && isWhiteSpaceSingleLine(text.charCodeAt(position))) { + position -= 1; } + return position + 1; } - function getNodeKind(node) { - switch (node.kind) { - case 311 /* SourceFile */: - return isExternalModule(node) ? "module" /* moduleElement */ : "script" /* scriptElement */; - case 266 /* ModuleDeclaration */: - return "module" /* moduleElement */; - case 262 /* ClassDeclaration */: - case 230 /* ClassExpression */: - return "class" /* classElement */; - case 263 /* InterfaceDeclaration */: - return "interface" /* interfaceElement */; - case 264 /* TypeAliasDeclaration */: - case 344 /* JSDocCallbackTag */: - case 352 /* JSDocTypedefTag */: - return "type" /* typeElement */; - case 265 /* EnumDeclaration */: - return "enum" /* enumElement */; - case 259 /* VariableDeclaration */: - return getKindOfVariableDeclaration(node); - case 207 /* BindingElement */: - return getKindOfVariableDeclaration(getRootDeclaration(node)); - case 218 /* ArrowFunction */: - case 261 /* FunctionDeclaration */: - case 217 /* FunctionExpression */: - return "function" /* functionElement */; - case 176 /* GetAccessor */: - return "getter" /* memberGetAccessorElement */; - case 177 /* SetAccessor */: - return "setter" /* memberSetAccessorElement */; - case 173 /* MethodDeclaration */: - case 172 /* MethodSignature */: - return "method" /* memberFunctionElement */; - case 302 /* PropertyAssignment */: - const { initializer } = node; - return isFunctionLike(initializer) ? "method" /* memberFunctionElement */ : "property" /* memberVariableElement */; - case 171 /* PropertyDeclaration */: - case 170 /* PropertySignature */: - case 303 /* ShorthandPropertyAssignment */: - case 304 /* SpreadAssignment */: - return "property" /* memberVariableElement */; - case 180 /* IndexSignature */: - return "index" /* indexSignatureElement */; - case 179 /* ConstructSignature */: - return "construct" /* constructSignatureElement */; - case 178 /* CallSignature */: - return "call" /* callSignatureElement */; - case 175 /* Constructor */: - case 174 /* ClassStaticBlockDeclaration */: - return "constructor" /* constructorImplementationElement */; - case 167 /* TypeParameter */: - return "type parameter" /* typeParameterElement */; - case 305 /* EnumMember */: - return "enum member" /* enumMemberElement */; - case 168 /* Parameter */: - return hasSyntacticModifier(node, 16476 /* ParameterPropertyModifier */) ? "property" /* memberVariableElement */ : "parameter" /* parameterElement */; - case 270 /* ImportEqualsDeclaration */: - case 275 /* ImportSpecifier */: - case 280 /* ExportSpecifier */: - case 273 /* NamespaceImport */: - case 279 /* NamespaceExport */: - return "alias" /* alias */; - case 225 /* BinaryExpression */: - const kind = getAssignmentDeclarationKind(node); - const { right } = node; - switch (kind) { - case 7 /* ObjectDefinePropertyValue */: - case 8 /* ObjectDefinePropertyExports */: - case 9 /* ObjectDefinePrototypeProperty */: - case 0 /* None */: - return "" /* unknown */; - case 1 /* ExportsProperty */: - case 2 /* ModuleExports */: - const rightKind = getNodeKind(right); - return rightKind === "" /* unknown */ ? "const" /* constElement */ : rightKind; - case 3 /* PrototypeProperty */: - return isFunctionExpression(right) ? "method" /* memberFunctionElement */ : "property" /* memberVariableElement */; - case 4 /* ThisProperty */: - return "property" /* memberVariableElement */; - case 5 /* Property */: - return isFunctionExpression(right) ? "method" /* memberFunctionElement */ : "property" /* memberVariableElement */; - case 6 /* Prototype */: - return "local class" /* localClassElement */; - default: { - assertType(kind); - return "" /* unknown */; + function getSynthesizedDeepClone(node, includeTrivia = true) { + const clone2 = node && getSynthesizedDeepCloneWorker(node); + if (clone2 && !includeTrivia) + suppressLeadingAndTrailingTrivia(clone2); + return clone2; + } + function getSynthesizedDeepCloneWithReplacements(node, includeTrivia, replaceNode) { + let clone2 = replaceNode(node); + if (clone2) { + setOriginalNode(clone2, node); + } else { + clone2 = getSynthesizedDeepCloneWorker(node, replaceNode); + } + if (clone2 && !includeTrivia) + suppressLeadingAndTrailingTrivia(clone2); + return clone2; + } + function getSynthesizedDeepCloneWorker(node, replaceNode) { + const nodeClone = replaceNode ? (n) => getSynthesizedDeepCloneWithReplacements( + n, + /*includeTrivia*/ + true, + replaceNode + ) : getSynthesizedDeepClone; + const nodesClone = replaceNode ? (ns) => ns && getSynthesizedDeepClonesWithReplacements( + ns, + /*includeTrivia*/ + true, + replaceNode + ) : (ns) => ns && getSynthesizedDeepClones(ns); + const visited = visitEachChild(node, nodeClone, nullTransformationContext, nodesClone, nodeClone); + if (visited === node) { + const clone2 = isStringLiteral(node) ? setOriginalNode(factory.createStringLiteralFromNode(node), node) : isNumericLiteral(node) ? setOriginalNode(factory.createNumericLiteral(node.text, node.numericLiteralFlags), node) : factory.cloneNode(node); + return setTextRange(clone2, node); + } + visited.parent = void 0; + return visited; + } + function getSynthesizedDeepClones(nodes, includeTrivia = true) { + if (nodes) { + const cloned = factory.createNodeArray(nodes.map((n) => getSynthesizedDeepClone(n, includeTrivia)), nodes.hasTrailingComma); + setTextRange(cloned, nodes); + return cloned; + } + return nodes; + } + function getSynthesizedDeepClonesWithReplacements(nodes, includeTrivia, replaceNode) { + return factory.createNodeArray(nodes.map((n) => getSynthesizedDeepCloneWithReplacements(n, includeTrivia, replaceNode)), nodes.hasTrailingComma); + } + function suppressLeadingAndTrailingTrivia(node) { + suppressLeadingTrivia(node); + suppressTrailingTrivia(node); + } + function suppressLeadingTrivia(node) { + addEmitFlagsRecursively(node, 1024 /* NoLeadingComments */, getFirstChild); + } + function suppressTrailingTrivia(node) { + addEmitFlagsRecursively(node, 2048 /* NoTrailingComments */, getLastChild); + } + function copyComments(sourceNode, targetNode) { + const sourceFile = sourceNode.getSourceFile(); + const text = sourceFile.text; + if (hasLeadingLineBreak(sourceNode, text)) { + copyLeadingComments(sourceNode, targetNode, sourceFile); + } else { + copyTrailingAsLeadingComments(sourceNode, targetNode, sourceFile); + } + copyTrailingComments(sourceNode, targetNode, sourceFile); + } + function hasLeadingLineBreak(node, text) { + const start = node.getFullStart(); + const end = node.getStart(); + for (let i = start; i < end; i++) { + if (text.charCodeAt(i) === 10 /* lineFeed */) + return true; + } + return false; + } + function addEmitFlagsRecursively(node, flag, getChild) { + addEmitFlags(node, flag); + const child = getChild(node); + if (child) + addEmitFlagsRecursively(child, flag, getChild); + } + function getFirstChild(node) { + return node.forEachChild((child) => child); + } + function getUniqueName(baseName, sourceFile) { + let nameText = baseName; + for (let i = 1; !isFileLevelUniqueName(sourceFile, nameText); i++) { + nameText = `${baseName}_${i}`; + } + return nameText; + } + function getRenameLocation(edits, renameFilename, name, preferLastLocation) { + let delta = 0; + let lastPos = -1; + for (const { fileName, textChanges: textChanges2 } of edits) { + Debug.assert(fileName === renameFilename); + for (const change of textChanges2) { + const { span, newText } = change; + const index = indexInTextChange(newText, escapeString(name)); + if (index !== -1) { + lastPos = span.start + delta + index; + if (!preferLastLocation) { + return lastPos; } } - case 80 /* Identifier */: - return isImportClause(node.parent) ? "alias" /* alias */ : "" /* unknown */; - case 276 /* ExportAssignment */: - const scriptKind = getNodeKind(node.expression); - return scriptKind === "" /* unknown */ ? "const" /* constElement */ : scriptKind; + delta += newText.length - span.length; + } + } + Debug.assert(preferLastLocation); + Debug.assert(lastPos >= 0); + return lastPos; + } + function copyLeadingComments(sourceNode, targetNode, sourceFile, commentKind, hasTrailingNewLine) { + forEachLeadingCommentRange(sourceFile.text, sourceNode.pos, getAddCommentsFunction(targetNode, sourceFile, commentKind, hasTrailingNewLine, addSyntheticLeadingComment)); + } + function copyTrailingComments(sourceNode, targetNode, sourceFile, commentKind, hasTrailingNewLine) { + forEachTrailingCommentRange(sourceFile.text, sourceNode.end, getAddCommentsFunction(targetNode, sourceFile, commentKind, hasTrailingNewLine, addSyntheticTrailingComment)); + } + function copyTrailingAsLeadingComments(sourceNode, targetNode, sourceFile, commentKind, hasTrailingNewLine) { + forEachTrailingCommentRange(sourceFile.text, sourceNode.pos, getAddCommentsFunction(targetNode, sourceFile, commentKind, hasTrailingNewLine, addSyntheticLeadingComment)); + } + function getAddCommentsFunction(targetNode, sourceFile, commentKind, hasTrailingNewLine, cb) { + return (pos, end, kind, htnl) => { + if (kind === 3 /* MultiLineCommentTrivia */) { + pos += 2; + end -= 2; + } else { + pos += 2; + } + cb(targetNode, commentKind || kind, sourceFile.text.slice(pos, end), hasTrailingNewLine !== void 0 ? hasTrailingNewLine : htnl); + }; + } + function indexInTextChange(change, name) { + if (startsWith(change, name)) + return 0; + let idx = change.indexOf(" " + name); + if (idx === -1) + idx = change.indexOf("." + name); + if (idx === -1) + idx = change.indexOf('"' + name); + return idx === -1 ? -1 : idx + 1; + } + function needsParentheses(expression) { + return isBinaryExpression(expression) && expression.operatorToken.kind === 28 /* CommaToken */ || isObjectLiteralExpression(expression) || (isAsExpression(expression) || isSatisfiesExpression(expression)) && isObjectLiteralExpression(expression.expression); + } + function getContextualTypeFromParent(node, checker, contextFlags) { + const parent2 = walkUpParenthesizedExpressions(node.parent); + switch (parent2.kind) { + case 214 /* NewExpression */: + return checker.getContextualType(parent2, contextFlags); + case 226 /* BinaryExpression */: { + const { left, operatorToken, right } = parent2; + return isEqualityOperatorKind(operatorToken.kind) ? checker.getTypeAtLocation(node === right ? left : right) : checker.getContextualType(node, contextFlags); + } + case 296 /* CaseClause */: + return getSwitchedType(parent2, checker); default: - return "" /* unknown */; + return checker.getContextualType(node, contextFlags); } - function getKindOfVariableDeclaration(v) { - return isVarConst(v) ? "const" /* constElement */ : isLet(v) ? "let" /* letElement */ : "var" /* variableElement */; + } + function quote(sourceFile, preferences, text) { + const quotePreference = getQuotePreference(sourceFile, preferences); + const quoted = JSON.stringify(text); + return quotePreference === 0 /* Single */ ? `'${stripQuotes(quoted).replace(/'/g, "\\'").replace(/\\"/g, '"')}'` : quoted; + } + function isEqualityOperatorKind(kind) { + switch (kind) { + case 37 /* EqualsEqualsEqualsToken */: + case 35 /* EqualsEqualsToken */: + case 38 /* ExclamationEqualsEqualsToken */: + case 36 /* ExclamationEqualsToken */: + return true; + default: + return false; } } - function isThis(node) { + function isStringLiteralOrTemplate(node) { switch (node.kind) { - case 110 /* ThisKeyword */: + case 11 /* StringLiteral */: + case 15 /* NoSubstitutionTemplateLiteral */: + case 228 /* TemplateExpression */: + case 215 /* TaggedTemplateExpression */: return true; - case 80 /* Identifier */: - return identifierIsThisKeyword(node) && node.parent.kind === 168 /* Parameter */; default: return false; } } - function getLineStartPositionForPosition(position, sourceFile) { - const lineStarts = getLineStarts(sourceFile); - const line = sourceFile.getLineAndCharacterOfPosition(position).line; - return lineStarts[line]; - } - function rangeContainsRange(r1, r2) { - return startEndContainsRange(r1.pos, r1.end, r2); - } - function rangeContainsRangeExclusive(r1, r2) { - return rangeContainsPositionExclusive(r1, r2.pos) && rangeContainsPositionExclusive(r1, r2.end); - } - function rangeContainsPosition(r, pos) { - return r.pos <= pos && pos <= r.end; - } - function rangeContainsPositionExclusive(r, pos) { - return r.pos < pos && pos < r.end; + function hasIndexSignature(type) { + return !!type.getStringIndexType() || !!type.getNumberIndexType(); } - function startEndContainsRange(start, end, range) { - return start <= range.pos && end >= range.end; + function getSwitchedType(caseClause, checker) { + return checker.getTypeAtLocation(caseClause.parent.parent.expression); } - function rangeContainsStartEnd(range, start, end) { - return range.pos <= start && range.end >= end; + function getTypeNodeIfAccessible(type, enclosingScope, program, host) { + const checker = program.getTypeChecker(); + let typeIsAccessible = true; + const notAccessible = () => typeIsAccessible = false; + const res = checker.typeToTypeNode(type, enclosingScope, 1 /* NoTruncation */, { + trackSymbol: (symbol, declaration, meaning) => { + typeIsAccessible = typeIsAccessible && checker.isSymbolAccessible( + symbol, + declaration, + meaning, + /*shouldComputeAliasToMarkVisible*/ + false + ).accessibility === 0 /* Accessible */; + return !typeIsAccessible; + }, + reportInaccessibleThisError: notAccessible, + reportPrivateInBaseOfClassExpression: notAccessible, + reportInaccessibleUniqueSymbolError: notAccessible, + moduleResolverHost: getModuleSpecifierResolverHost(program, host) + }); + return typeIsAccessible ? res : void 0; } - function rangeOverlapsWithStartEnd(r1, start, end) { - return startEndOverlapsWithStartEnd(r1.pos, r1.end, start, end); + function syntaxRequiresTrailingCommaOrSemicolonOrASI(kind) { + return kind === 179 /* CallSignature */ || kind === 180 /* ConstructSignature */ || kind === 181 /* IndexSignature */ || kind === 171 /* PropertySignature */ || kind === 173 /* MethodSignature */; } - function nodeOverlapsWithStartEnd(node, sourceFile, start, end) { - return startEndOverlapsWithStartEnd(node.getStart(sourceFile), node.end, start, end); + function syntaxRequiresTrailingFunctionBlockOrSemicolonOrASI(kind) { + return kind === 262 /* FunctionDeclaration */ || kind === 176 /* Constructor */ || kind === 174 /* MethodDeclaration */ || kind === 177 /* GetAccessor */ || kind === 178 /* SetAccessor */; } - function startEndOverlapsWithStartEnd(start1, end1, start2, end2) { - const start = Math.max(start1, start2); - const end = Math.min(end1, end2); - return start < end; + function syntaxRequiresTrailingModuleBlockOrSemicolonOrASI(kind) { + return kind === 267 /* ModuleDeclaration */; } - function positionBelongsToNode(candidate, position, sourceFile) { - Debug.assert(candidate.pos <= position); - return position < candidate.end || !isCompletedNode(candidate, sourceFile); + function syntaxRequiresTrailingSemicolonOrASI(kind) { + return kind === 243 /* VariableStatement */ || kind === 244 /* ExpressionStatement */ || kind === 246 /* DoStatement */ || kind === 251 /* ContinueStatement */ || kind === 252 /* BreakStatement */ || kind === 253 /* ReturnStatement */ || kind === 257 /* ThrowStatement */ || kind === 259 /* DebuggerStatement */ || kind === 172 /* PropertyDeclaration */ || kind === 265 /* TypeAliasDeclaration */ || kind === 272 /* ImportDeclaration */ || kind === 271 /* ImportEqualsDeclaration */ || kind === 278 /* ExportDeclaration */ || kind === 270 /* NamespaceExportDeclaration */ || kind === 277 /* ExportAssignment */; } - function isCompletedNode(n, sourceFile) { - if (n === void 0 || nodeIsMissing(n)) { + function nodeIsASICandidate(node, sourceFile) { + const lastToken = node.getLastToken(sourceFile); + if (lastToken && lastToken.kind === 27 /* SemicolonToken */) { return false; } - switch (n.kind) { - case 262 /* ClassDeclaration */: - case 263 /* InterfaceDeclaration */: - case 265 /* EnumDeclaration */: - case 209 /* ObjectLiteralExpression */: - case 205 /* ObjectBindingPattern */: - case 186 /* TypeLiteral */: - case 240 /* Block */: - case 267 /* ModuleBlock */: - case 268 /* CaseBlock */: - case 274 /* NamedImports */: - case 278 /* NamedExports */: - return nodeEndsWith(n, 20 /* CloseBraceToken */, sourceFile); - case 298 /* CatchClause */: - return isCompletedNode(n.block, sourceFile); - case 213 /* NewExpression */: - if (!n.arguments) { - return true; - } - case 212 /* CallExpression */: - case 216 /* ParenthesizedExpression */: - case 195 /* ParenthesizedType */: - return nodeEndsWith(n, 22 /* CloseParenToken */, sourceFile); - case 183 /* FunctionType */: - case 184 /* ConstructorType */: - return isCompletedNode(n.type, sourceFile); - case 175 /* Constructor */: - case 176 /* GetAccessor */: - case 177 /* SetAccessor */: - case 261 /* FunctionDeclaration */: - case 217 /* FunctionExpression */: - case 173 /* MethodDeclaration */: - case 172 /* MethodSignature */: - case 179 /* ConstructSignature */: - case 178 /* CallSignature */: - case 218 /* ArrowFunction */: - if (n.body) { - return isCompletedNode(n.body, sourceFile); - } - if (n.type) { - return isCompletedNode(n.type, sourceFile); - } - return hasChildOfKind(n, 22 /* CloseParenToken */, sourceFile); - case 266 /* ModuleDeclaration */: - return !!n.body && isCompletedNode(n.body, sourceFile); - case 244 /* IfStatement */: - if (n.elseStatement) { - return isCompletedNode(n.elseStatement, sourceFile); - } - return isCompletedNode(n.thenStatement, sourceFile); - case 243 /* ExpressionStatement */: - return isCompletedNode(n.expression, sourceFile) || hasChildOfKind(n, 27 /* SemicolonToken */, sourceFile); - case 208 /* ArrayLiteralExpression */: - case 206 /* ArrayBindingPattern */: - case 211 /* ElementAccessExpression */: - case 166 /* ComputedPropertyName */: - case 188 /* TupleType */: - return nodeEndsWith(n, 24 /* CloseBracketToken */, sourceFile); - case 180 /* IndexSignature */: - if (n.type) { - return isCompletedNode(n.type, sourceFile); - } - return hasChildOfKind(n, 24 /* CloseBracketToken */, sourceFile); - case 295 /* CaseClause */: - case 296 /* DefaultClause */: + if (syntaxRequiresTrailingCommaOrSemicolonOrASI(node.kind)) { + if (lastToken && lastToken.kind === 28 /* CommaToken */) { return false; - case 247 /* ForStatement */: - case 248 /* ForInStatement */: - case 249 /* ForOfStatement */: - case 246 /* WhileStatement */: - return isCompletedNode(n.statement, sourceFile); - case 245 /* DoStatement */: - return hasChildOfKind(n, 117 /* WhileKeyword */, sourceFile) ? nodeEndsWith(n, 22 /* CloseParenToken */, sourceFile) : isCompletedNode(n.statement, sourceFile); - case 185 /* TypeQuery */: - return isCompletedNode(n.exprName, sourceFile); - case 220 /* TypeOfExpression */: - case 219 /* DeleteExpression */: - case 221 /* VoidExpression */: - case 228 /* YieldExpression */: - case 229 /* SpreadElement */: - const unaryWordExpression = n; - return isCompletedNode(unaryWordExpression.expression, sourceFile); - case 214 /* TaggedTemplateExpression */: - return isCompletedNode(n.template, sourceFile); - case 227 /* TemplateExpression */: - const lastSpan = lastOrUndefined(n.templateSpans); - return isCompletedNode(lastSpan, sourceFile); - case 238 /* TemplateSpan */: - return nodeIsPresent(n.literal); - case 277 /* ExportDeclaration */: - case 271 /* ImportDeclaration */: - return nodeIsPresent(n.moduleSpecifier); - case 223 /* PrefixUnaryExpression */: - return isCompletedNode(n.operand, sourceFile); - case 225 /* BinaryExpression */: - return isCompletedNode(n.right, sourceFile); - case 226 /* ConditionalExpression */: - return isCompletedNode(n.whenFalse, sourceFile); - default: - return true; + } + } else if (syntaxRequiresTrailingModuleBlockOrSemicolonOrASI(node.kind)) { + const lastChild = last(node.getChildren(sourceFile)); + if (lastChild && isModuleBlock(lastChild)) { + return false; + } + } else if (syntaxRequiresTrailingFunctionBlockOrSemicolonOrASI(node.kind)) { + const lastChild = last(node.getChildren(sourceFile)); + if (lastChild && isFunctionBlock(lastChild)) { + return false; + } + } else if (!syntaxRequiresTrailingSemicolonOrASI(node.kind)) { + return false; + } + if (node.kind === 246 /* DoStatement */) { + return true; + } + const topNode = findAncestor(node, (ancestor) => !ancestor.parent); + const nextToken = findNextToken(node, topNode, sourceFile); + if (!nextToken || nextToken.kind === 20 /* CloseBraceToken */) { + return true; } + const startLine = sourceFile.getLineAndCharacterOfPosition(node.getEnd()).line; + const endLine = sourceFile.getLineAndCharacterOfPosition(nextToken.getStart(sourceFile)).line; + return startLine !== endLine; } - function nodeEndsWith(n, expectedLastToken, sourceFile) { - const children = n.getChildren(sourceFile); - if (children.length) { - const lastChild = last(children); - if (lastChild.kind === expectedLastToken) { + function positionIsASICandidate(pos, context, sourceFile) { + const contextAncestor = findAncestor(context, (ancestor) => { + if (ancestor.end !== pos) { + return "quit"; + } + return syntaxMayBeASICandidate(ancestor.kind); + }); + return !!contextAncestor && nodeIsASICandidate(contextAncestor, sourceFile); + } + function probablyUsesSemicolons(sourceFile) { + let withSemicolon = 0; + let withoutSemicolon = 0; + const nStatementsToObserve = 5; + forEachChild(sourceFile, function visit(node) { + if (syntaxRequiresTrailingSemicolonOrASI(node.kind)) { + const lastToken = node.getLastToken(sourceFile); + if ((lastToken == null ? void 0 : lastToken.kind) === 27 /* SemicolonToken */) { + withSemicolon++; + } else { + withoutSemicolon++; + } + } else if (syntaxRequiresTrailingCommaOrSemicolonOrASI(node.kind)) { + const lastToken = node.getLastToken(sourceFile); + if ((lastToken == null ? void 0 : lastToken.kind) === 27 /* SemicolonToken */) { + withSemicolon++; + } else if (lastToken && lastToken.kind !== 28 /* CommaToken */) { + const lastTokenLine = getLineAndCharacterOfPosition(sourceFile, lastToken.getStart(sourceFile)).line; + const nextTokenLine = getLineAndCharacterOfPosition(sourceFile, getSpanOfTokenAtPosition(sourceFile, lastToken.end).start).line; + if (lastTokenLine !== nextTokenLine) { + withoutSemicolon++; + } + } + } + if (withSemicolon + withoutSemicolon >= nStatementsToObserve) { return true; - } else if (lastChild.kind === 27 /* SemicolonToken */ && children.length !== 1) { - return children[children.length - 2].kind === expectedLastToken; } + return forEachChild(node, visit); + }); + if (withSemicolon === 0 && withoutSemicolon <= 1) { + return true; } - return false; + return withSemicolon / withoutSemicolon > 1 / nStatementsToObserve; } - function findListItemInfo(node) { - const list = findContainingList(node); - if (!list) { - return void 0; - } - const children = list.getChildren(); - const listItemIndex = indexOfNode(children, node); - return { - listItemIndex, - list - }; + function tryGetDirectories(host, directoryName) { + return tryIOAndConsumeErrors(host, host.getDirectories, directoryName) || []; } - function hasChildOfKind(n, kind, sourceFile) { - return !!findChildOfKind(n, kind, sourceFile); + function tryReadDirectory(host, path, extensions, exclude, include) { + return tryIOAndConsumeErrors(host, host.readDirectory, path, extensions, exclude, include) || emptyArray; } - function findChildOfKind(n, kind, sourceFile) { - return find(n.getChildren(sourceFile), (c) => c.kind === kind); + function tryFileExists(host, path) { + return tryIOAndConsumeErrors(host, host.fileExists, path); } - function findContainingList(node) { - const syntaxList = find(node.parent.getChildren(), (c) => isSyntaxList(c) && rangeContainsRange(c, node)); - Debug.assert(!syntaxList || contains(syntaxList.getChildren(), node)); - return syntaxList; + function tryDirectoryExists(host, path) { + return tryAndIgnoreErrors(() => directoryProbablyExists(path, host)) || false; } - function isDefaultModifier2(node) { - return node.kind === 90 /* DefaultKeyword */; + function tryAndIgnoreErrors(cb) { + try { + return cb(); + } catch { + return void 0; + } } - function isClassKeyword(node) { - return node.kind === 86 /* ClassKeyword */; + function tryIOAndConsumeErrors(host, toApply, ...args) { + return tryAndIgnoreErrors(() => toApply && toApply.apply(host, args)); } - function isFunctionKeyword(node) { - return node.kind === 100 /* FunctionKeyword */; + function findPackageJsons(startDirectory, host, stopDirectory) { + const paths = []; + forEachAncestorDirectory(startDirectory, (ancestor) => { + if (ancestor === stopDirectory) { + return true; + } + const currentConfigPath = combinePaths(ancestor, "package.json"); + if (tryFileExists(host, currentConfigPath)) { + paths.push(currentConfigPath); + } + }); + return paths; } - function getAdjustedLocationForClass(node) { - if (isNamedDeclaration(node)) { - return node.name; - } - if (isClassDeclaration(node)) { - const defaultModifier = node.modifiers && find(node.modifiers, isDefaultModifier2); - if (defaultModifier) - return defaultModifier; - } - if (isClassExpression(node)) { - const classKeyword = find(node.getChildren(), isClassKeyword); - if (classKeyword) - return classKeyword; - } + function findPackageJson(directory, host) { + let packageJson; + forEachAncestorDirectory(directory, (ancestor) => { + if (ancestor === "node_modules") + return true; + packageJson = findConfigFile(ancestor, (f) => tryFileExists(host, f), "package.json"); + if (packageJson) { + return true; + } + }); + return packageJson; } - function getAdjustedLocationForFunction(node) { - if (isNamedDeclaration(node)) { - return node.name; - } - if (isFunctionDeclaration(node)) { - const defaultModifier = find(node.modifiers, isDefaultModifier2); - if (defaultModifier) - return defaultModifier; - } - if (isFunctionExpression(node)) { - const functionKeyword = find(node.getChildren(), isFunctionKeyword); - if (functionKeyword) - return functionKeyword; + function getPackageJsonsVisibleToFile(fileName, host) { + if (!host.fileExists) { + return []; } - } - function getAncestorTypeNode(node) { - let lastTypeNode; - findAncestor(node, (a) => { - if (isTypeNode(a)) { - lastTypeNode = a; + const packageJsons = []; + forEachAncestorDirectory(getDirectoryPath(fileName), (ancestor) => { + const packageJsonFileName = combinePaths(ancestor, "package.json"); + if (host.fileExists(packageJsonFileName)) { + const info = createPackageJsonInfo(packageJsonFileName, host); + if (info) { + packageJsons.push(info); + } } - return !isQualifiedName(a.parent) && !isTypeNode(a.parent) && !isTypeElement(a.parent); }); - return lastTypeNode; + return packageJsons; } - function getContextualTypeFromParentOrAncestorTypeNode(node, checker) { - if (node.flags & (8388608 /* JSDoc */ & ~262144 /* JavaScriptFile */)) + function createPackageJsonInfo(fileName, host) { + if (!host.readFile) { return void 0; - const contextualType = getContextualTypeFromParent(node, checker); - if (contextualType) - return contextualType; - const ancestorTypeNode = getAncestorTypeNode(node); - return ancestorTypeNode && checker.getTypeAtLocation(ancestorTypeNode); - } - function getAdjustedLocationForDeclaration(node, forRename) { - if (!forRename) { - switch (node.kind) { - case 262 /* ClassDeclaration */: - case 230 /* ClassExpression */: - return getAdjustedLocationForClass(node); - case 261 /* FunctionDeclaration */: - case 217 /* FunctionExpression */: - return getAdjustedLocationForFunction(node); - case 175 /* Constructor */: - return node; - } - } - if (isNamedDeclaration(node)) { - return node.name; } - } - function getAdjustedLocationForImportDeclaration(node, forRename) { - if (node.importClause) { - if (node.importClause.name && node.importClause.namedBindings) { - return; + const dependencyKeys = ["dependencies", "devDependencies", "optionalDependencies", "peerDependencies"]; + const stringContent = host.readFile(fileName) || ""; + const content = tryParseJson(stringContent); + const info = {}; + if (content) { + for (const key of dependencyKeys) { + const dependencies = content[key]; + if (!dependencies) { + continue; + } + const dependencyMap = /* @__PURE__ */ new Map(); + for (const packageName in dependencies) { + dependencyMap.set(packageName, dependencies[packageName]); + } + info[key] = dependencyMap; } - if (node.importClause.name) { - return node.importClause.name; + } + const dependencyGroups = [ + [1 /* Dependencies */, info.dependencies], + [2 /* DevDependencies */, info.devDependencies], + [8 /* OptionalDependencies */, info.optionalDependencies], + [4 /* PeerDependencies */, info.peerDependencies] + ]; + return { + ...info, + parseable: !!content, + fileName, + get, + has(dependencyName, inGroups) { + return !!get(dependencyName, inGroups); } - if (node.importClause.namedBindings) { - if (isNamedImports(node.importClause.namedBindings)) { - const onlyBinding = singleOrUndefined(node.importClause.namedBindings.elements); - if (!onlyBinding) { - return; + }; + function get(dependencyName, inGroups = 15 /* All */) { + for (const [group2, deps] of dependencyGroups) { + if (deps && inGroups & group2) { + const dep = deps.get(dependencyName); + if (dep !== void 0) { + return dep; } - return onlyBinding.name; - } else if (isNamespaceImport(node.importClause.namedBindings)) { - return node.importClause.namedBindings.name; } } } - if (!forRename) { - return node.moduleSpecifier; - } } - function getAdjustedLocationForExportDeclaration(node, forRename) { - if (node.exportClause) { - if (isNamedExports(node.exportClause)) { - const onlyBinding = singleOrUndefined(node.exportClause.elements); - if (!onlyBinding) { - return; + function createPackageJsonImportFilter(fromFile, preferences, host) { + const packageJsons = (host.getPackageJsonsVisibleToFile && host.getPackageJsonsVisibleToFile(fromFile.fileName) || getPackageJsonsVisibleToFile(fromFile.fileName, host)).filter((p) => p.parseable); + let usesNodeCoreModules; + let ambientModuleCache; + let sourceFileCache; + return { + allowsImportingAmbientModule, + allowsImportingSourceFile, + allowsImportingSpecifier + }; + function moduleSpecifierIsCoveredByPackageJson(specifier) { + const packageName = getNodeModuleRootSpecifier(specifier); + for (const packageJson of packageJsons) { + if (packageJson.has(packageName) || packageJson.has(getTypesPackageName(packageName))) { + return true; } - return node.exportClause.elements[0].name; - } else if (isNamespaceExport(node.exportClause)) { - return node.exportClause.name; } + return false; } - if (!forRename) { - return node.moduleSpecifier; - } - } - function getAdjustedLocationForHeritageClause(node) { - if (node.types.length === 1) { - return node.types[0].expression; - } - } - function getAdjustedLocation(node, forRename) { - const { parent: parent2 } = node; - if (isModifier(node) && (forRename || node.kind !== 90 /* DefaultKeyword */) ? canHaveModifiers(parent2) && contains(parent2.modifiers, node) : node.kind === 86 /* ClassKeyword */ ? isClassDeclaration(parent2) || isClassExpression(node) : node.kind === 100 /* FunctionKeyword */ ? isFunctionDeclaration(parent2) || isFunctionExpression(node) : node.kind === 120 /* InterfaceKeyword */ ? isInterfaceDeclaration(parent2) : node.kind === 94 /* EnumKeyword */ ? isEnumDeclaration(parent2) : node.kind === 156 /* TypeKeyword */ ? isTypeAliasDeclaration(parent2) : node.kind === 145 /* NamespaceKeyword */ || node.kind === 144 /* ModuleKeyword */ ? isModuleDeclaration(parent2) : node.kind === 102 /* ImportKeyword */ ? isImportEqualsDeclaration(parent2) : node.kind === 139 /* GetKeyword */ ? isGetAccessorDeclaration(parent2) : node.kind === 153 /* SetKeyword */ && isSetAccessorDeclaration(parent2)) { - const location = getAdjustedLocationForDeclaration(parent2, forRename); - if (location) { - return location; + function allowsImportingAmbientModule(moduleSymbol, moduleSpecifierResolutionHost) { + if (!packageJsons.length || !moduleSymbol.valueDeclaration) { + return true; } - } - if ((node.kind === 115 /* VarKeyword */ || node.kind === 87 /* ConstKeyword */ || node.kind === 121 /* LetKeyword */) && isVariableDeclarationList(parent2) && parent2.declarations.length === 1) { - const decl = parent2.declarations[0]; - if (isIdentifier(decl.name)) { - return decl.name; + if (!ambientModuleCache) { + ambientModuleCache = /* @__PURE__ */ new Map(); + } else { + const cached = ambientModuleCache.get(moduleSymbol); + if (cached !== void 0) { + return cached; + } + } + const declaredModuleSpecifier = stripQuotes(moduleSymbol.getName()); + if (isAllowedCoreNodeModulesImport(declaredModuleSpecifier)) { + ambientModuleCache.set(moduleSymbol, true); + return true; + } + const declaringSourceFile = moduleSymbol.valueDeclaration.getSourceFile(); + const declaringNodeModuleName = getNodeModulesPackageNameFromFileName(declaringSourceFile.fileName, moduleSpecifierResolutionHost); + if (typeof declaringNodeModuleName === "undefined") { + ambientModuleCache.set(moduleSymbol, true); + return true; } + const result = moduleSpecifierIsCoveredByPackageJson(declaringNodeModuleName) || moduleSpecifierIsCoveredByPackageJson(declaredModuleSpecifier); + ambientModuleCache.set(moduleSymbol, result); + return result; } - if (node.kind === 156 /* TypeKeyword */) { - if (isImportClause(parent2) && parent2.isTypeOnly) { - const location = getAdjustedLocationForImportDeclaration(parent2.parent, forRename); - if (location) { - return location; - } + function allowsImportingSourceFile(sourceFile, moduleSpecifierResolutionHost) { + if (!packageJsons.length) { + return true; } - if (isExportDeclaration(parent2) && parent2.isTypeOnly) { - const location = getAdjustedLocationForExportDeclaration(parent2, forRename); - if (location) { - return location; + if (!sourceFileCache) { + sourceFileCache = /* @__PURE__ */ new Map(); + } else { + const cached = sourceFileCache.get(sourceFile); + if (cached !== void 0) { + return cached; } } + const moduleSpecifier = getNodeModulesPackageNameFromFileName(sourceFile.fileName, moduleSpecifierResolutionHost); + if (!moduleSpecifier) { + sourceFileCache.set(sourceFile, true); + return true; + } + const result = moduleSpecifierIsCoveredByPackageJson(moduleSpecifier); + sourceFileCache.set(sourceFile, result); + return result; } - if (node.kind === 130 /* AsKeyword */) { - if (isImportSpecifier(parent2) && parent2.propertyName || isExportSpecifier(parent2) && parent2.propertyName || isNamespaceImport(parent2) || isNamespaceExport(parent2)) { - return parent2.name; + function allowsImportingSpecifier(moduleSpecifier) { + if (!packageJsons.length || isAllowedCoreNodeModulesImport(moduleSpecifier)) { + return true; } - if (isExportDeclaration(parent2) && parent2.exportClause && isNamespaceExport(parent2.exportClause)) { - return parent2.exportClause.name; + if (pathIsRelative(moduleSpecifier) || isRootedDiskPath(moduleSpecifier)) { + return true; } + return moduleSpecifierIsCoveredByPackageJson(moduleSpecifier); } - if (node.kind === 102 /* ImportKeyword */ && isImportDeclaration(parent2)) { - const location = getAdjustedLocationForImportDeclaration(parent2, forRename); - if (location) { - return location; + function isAllowedCoreNodeModulesImport(moduleSpecifier) { + if (isSourceFileJS(fromFile) && ts_JsTyping_exports.nodeCoreModules.has(moduleSpecifier)) { + if (usesNodeCoreModules === void 0) { + usesNodeCoreModules = consumesNodeCoreModules(fromFile); + } + if (usesNodeCoreModules) { + return true; + } } + return false; } - if (node.kind === 95 /* ExportKeyword */) { - if (isExportDeclaration(parent2)) { - const location = getAdjustedLocationForExportDeclaration(parent2, forRename); - if (location) { - return location; + function getNodeModulesPackageNameFromFileName(importedFileName, moduleSpecifierResolutionHost) { + const pnpapi = getPnpApi(importedFileName); + if (pnpapi) { + const fromLocator = pnpapi.findPackageLocator(fromFile.fileName); + const toLocator = pnpapi.findPackageLocator(importedFileName); + if (!(fromLocator && toLocator)) { + return void 0; } + } else if (!importedFileName.includes("node_modules")) { + return void 0; } - if (isExportAssignment(parent2)) { - return skipOuterExpressions(parent2.expression); + const specifier = ts_moduleSpecifiers_exports.getNodeModulesPackageName( + host.getCompilationSettings(), + fromFile, + importedFileName, + moduleSpecifierResolutionHost, + preferences + ); + if (!specifier) { + return void 0; } - } - if (node.kind === 149 /* RequireKeyword */ && isExternalModuleReference(parent2)) { - return parent2.expression; - } - if (node.kind === 160 /* FromKeyword */ && (isImportDeclaration(parent2) || isExportDeclaration(parent2)) && parent2.moduleSpecifier) { - return parent2.moduleSpecifier; - } - if ((node.kind === 96 /* ExtendsKeyword */ || node.kind === 119 /* ImplementsKeyword */) && isHeritageClause(parent2) && parent2.token === node.kind) { - const location = getAdjustedLocationForHeritageClause(parent2); - if (location) { - return location; + if (!pathIsRelative(specifier) && !isRootedDiskPath(specifier)) { + return getNodeModuleRootSpecifier(specifier); } } - if (node.kind === 96 /* ExtendsKeyword */) { - if (isTypeParameterDeclaration(parent2) && parent2.constraint && isTypeReferenceNode(parent2.constraint)) { - return parent2.constraint.typeName; - } - if (isConditionalTypeNode(parent2) && isTypeReferenceNode(parent2.extendsType)) { - return parent2.extendsType.typeName; + function getNodeModuleRootSpecifier(fullSpecifier) { + const components = getPathComponents(getPackageNameFromTypesPackageName(fullSpecifier)).slice(1); + if (startsWith(components[0], "@")) { + return `${components[0]}/${components[1]}`; } + return components[0]; } - if (node.kind === 140 /* InferKeyword */ && isInferTypeNode(parent2)) { - return parent2.typeParameter.name; + } + function tryParseJson(text) { + try { + return JSON.parse(text); + } catch { + return void 0; } - if (node.kind === 103 /* InKeyword */ && isTypeParameterDeclaration(parent2) && isMappedTypeNode(parent2.parent)) { - return parent2.name; + } + function consumesNodeCoreModules(sourceFile) { + return some(sourceFile.imports, ({ text }) => ts_JsTyping_exports.nodeCoreModules.has(text)); + } + function isInsideNodeModules(fileOrDirectory) { + return contains(getPathComponents(fileOrDirectory), "node_modules"); + } + function isDiagnosticWithLocation(diagnostic) { + return diagnostic.file !== void 0 && diagnostic.start !== void 0 && diagnostic.length !== void 0; + } + function findDiagnosticForNode(node, sortedFileDiagnostics) { + const span = createTextSpanFromNode(node); + const index = binarySearchKey(sortedFileDiagnostics, span, identity, compareTextSpans); + if (index >= 0) { + const diagnostic = sortedFileDiagnostics[index]; + Debug.assertEqual(diagnostic.file, node.getSourceFile(), "Diagnostics proided to 'findDiagnosticForNode' must be from a single SourceFile"); + return cast(diagnostic, isDiagnosticWithLocation); } - if (node.kind === 143 /* KeyOfKeyword */ && isTypeOperatorNode(parent2) && parent2.operator === 143 /* KeyOfKeyword */ && isTypeReferenceNode(parent2.type)) { - return parent2.type.typeName; + } + function getDiagnosticsWithinSpan(span, sortedFileDiagnostics) { + var _a; + let index = binarySearchKey(sortedFileDiagnostics, span.start, (diag2) => diag2.start, compareValues); + if (index < 0) { + index = ~index; } - if (node.kind === 148 /* ReadonlyKeyword */ && isTypeOperatorNode(parent2) && parent2.operator === 148 /* ReadonlyKeyword */ && isArrayTypeNode(parent2.type) && isTypeReferenceNode(parent2.type.elementType)) { - return parent2.type.elementType.typeName; + while (((_a = sortedFileDiagnostics[index - 1]) == null ? void 0 : _a.start) === span.start) { + index--; } - if (!forRename) { - if (node.kind === 105 /* NewKeyword */ && isNewExpression(parent2) || node.kind === 116 /* VoidKeyword */ && isVoidExpression(parent2) || node.kind === 114 /* TypeOfKeyword */ && isTypeOfExpression(parent2) || node.kind === 135 /* AwaitKeyword */ && isAwaitExpression(parent2) || node.kind === 127 /* YieldKeyword */ && isYieldExpression(parent2) || node.kind === 91 /* DeleteKeyword */ && isDeleteExpression(parent2)) { - if (parent2.expression) { - return skipOuterExpressions(parent2.expression); - } - } - if ((node.kind === 103 /* InKeyword */ || node.kind === 104 /* InstanceOfKeyword */) && isBinaryExpression(parent2) && parent2.operatorToken === node) { - return skipOuterExpressions(parent2.right); + const result = []; + const end = textSpanEnd(span); + while (true) { + const diagnostic = tryCast(sortedFileDiagnostics[index], isDiagnosticWithLocation); + if (!diagnostic || diagnostic.start > end) { + break; } - if (node.kind === 130 /* AsKeyword */ && isAsExpression(parent2) && isTypeReferenceNode(parent2.type)) { - return parent2.type.typeName; + if (textSpanContainsTextSpan(span, diagnostic)) { + result.push(diagnostic); } - if (node.kind === 103 /* InKeyword */ && isForInStatement(parent2) || node.kind === 164 /* OfKeyword */ && isForOfStatement(parent2)) { - return skipOuterExpressions(parent2.expression); + index++; + } + return result; + } + function getRefactorContextSpan({ startPosition, endPosition }) { + return createTextSpanFromBounds(startPosition, endPosition === void 0 ? startPosition : endPosition); + } + function getFixableErrorSpanExpression(sourceFile, span) { + const token = getTokenAtPosition(sourceFile, span.start); + const expression = findAncestor(token, (node) => { + if (node.getStart(sourceFile) < span.start || node.getEnd() > textSpanEnd(span)) { + return "quit"; } + return isExpression(node) && textSpansEqual(span, createTextSpanFromNode(node, sourceFile)); + }); + return expression; + } + function mapOneOrMany(valueOrArray, f, resultSelector = identity) { + return valueOrArray ? isArray(valueOrArray) ? resultSelector(map(valueOrArray, f)) : f(valueOrArray, 0) : void 0; + } + function firstOrOnly(valueOrArray) { + return isArray(valueOrArray) ? first(valueOrArray) : valueOrArray; + } + function getNamesForExportedSymbol(symbol, scriptTarget) { + if (needsNameFromDeclaration(symbol)) { + const fromDeclaration = getDefaultLikeExportNameFromDeclaration(symbol); + if (fromDeclaration) + return fromDeclaration; + const fileNameCase = ts_codefix_exports.moduleSymbolToValidIdentifier( + getSymbolParentOrFail(symbol), + scriptTarget, + /*forceCapitalize*/ + false + ); + const capitalized = ts_codefix_exports.moduleSymbolToValidIdentifier( + getSymbolParentOrFail(symbol), + scriptTarget, + /*forceCapitalize*/ + true + ); + if (fileNameCase === capitalized) + return fileNameCase; + return [fileNameCase, capitalized]; } - return node; + return symbol.name; } - function getAdjustedReferenceLocation(node) { - return getAdjustedLocation( - node, - /*forRename*/ - false - ); + function getNameForExportedSymbol(symbol, scriptTarget, preferCapitalized) { + if (needsNameFromDeclaration(symbol)) { + return getDefaultLikeExportNameFromDeclaration(symbol) || ts_codefix_exports.moduleSymbolToValidIdentifier(getSymbolParentOrFail(symbol), scriptTarget, !!preferCapitalized); + } + return symbol.name; } - function getAdjustedRenameLocation(node) { - return getAdjustedLocation( - node, - /*forRename*/ - true - ); + function needsNameFromDeclaration(symbol) { + return !(symbol.flags & 33554432 /* Transient */) && (symbol.escapedName === "export=" /* ExportEquals */ || symbol.escapedName === "default" /* Default */); } - function getTouchingPropertyName(sourceFile, position) { - return getTouchingToken(sourceFile, position, (n) => isPropertyNameLiteral(n) || isKeyword(n.kind) || isPrivateIdentifier(n)); + function getDefaultLikeExportNameFromDeclaration(symbol) { + return firstDefined(symbol.declarations, (d) => { + var _a, _b, _c; + if (isExportAssignment(d)) { + return (_a = tryCast(skipOuterExpressions(d.expression), isIdentifier)) == null ? void 0 : _a.text; + } + if (isExportSpecifier(d) && d.symbol.flags === 2097152 /* Alias */) { + return (_b = tryCast(d.propertyName, isIdentifier)) == null ? void 0 : _b.text; + } + return (_c = tryCast(getNameOfDeclaration(d), isIdentifier)) == null ? void 0 : _c.text; + }); } - function getTouchingToken(sourceFile, position, includePrecedingTokenAtEndPosition) { - return getTokenAtPositionWorker( - sourceFile, - position, - /*allowPositionInLeadingTrivia*/ - false, - includePrecedingTokenAtEndPosition, - /*includeEndPosition*/ - false + function getSymbolParentOrFail(symbol) { + var _a; + return Debug.checkDefined( + symbol.parent, + `Symbol parent was undefined. Flags: ${Debug.formatSymbolFlags(symbol.flags)}. Declarations: ${(_a = symbol.declarations) == null ? void 0 : _a.map((d) => { + const kind = Debug.formatSyntaxKind(d.kind); + const inJS = isInJSFile(d); + const { expression } = d; + return (inJS ? "[JS]" : "") + kind + (expression ? ` (expression: ${Debug.formatSyntaxKind(expression.kind)})` : ""); + }).join(", ")}.` ); } - function getTokenAtPosition(sourceFile, position) { - return getTokenAtPositionWorker( - sourceFile, - position, - /*allowPositionInLeadingTrivia*/ - true, - /*includePrecedingTokenAtEndPosition*/ - void 0, - /*includeEndPosition*/ - false - ); + function stringContainsAt(haystack, needle, startIndex) { + const needleLength = needle.length; + if (needleLength + startIndex > haystack.length) { + return false; + } + for (let i = 0; i < needleLength; i++) { + if (needle.charCodeAt(i) !== haystack.charCodeAt(i + startIndex)) + return false; + } + return true; } - function getTokenAtPositionWorker(sourceFile, position, allowPositionInLeadingTrivia, includePrecedingTokenAtEndPosition, includeEndPosition) { - let current = sourceFile; - let foundToken; - outer: - while (true) { - const children = current.getChildren(sourceFile); - const i = binarySearchKey(children, position, (_, i2) => i2, (middle, _) => { - const end = children[middle].getEnd(); - if (end < position) { - return -1 /* LessThan */; - } - const start = allowPositionInLeadingTrivia ? children[middle].getFullStart() : children[middle].getStart( - sourceFile, - /*includeJsDocComment*/ - true - ); - if (start > position) { - return 1 /* GreaterThan */; - } - if (nodeContainsPosition(children[middle], start, end)) { - if (children[middle - 1]) { - if (nodeContainsPosition(children[middle - 1])) { - return 1 /* GreaterThan */; + function startsWithUnderscore(name) { + return name.charCodeAt(0) === 95 /* _ */; + } + function isGlobalDeclaration(declaration) { + return !isNonGlobalDeclaration(declaration); + } + function isNonGlobalDeclaration(declaration) { + const sourceFile = declaration.getSourceFile(); + if (!sourceFile.externalModuleIndicator && !sourceFile.commonJsModuleIndicator) { + return false; + } + return isInJSFile(declaration) || !findAncestor(declaration, (d) => isModuleDeclaration(d) && isGlobalScopeAugmentation(d)); + } + function isDeprecatedDeclaration(decl) { + return !!(getCombinedNodeFlagsAlwaysIncludeJSDoc(decl) & 65536 /* Deprecated */); + } + function shouldUseUriStyleNodeCoreModules(file, program) { + const decisionFromFile = firstDefined(file.imports, (node) => { + if (ts_JsTyping_exports.nodeCoreModules.has(node.text)) { + return startsWith(node.text, "node:"); + } + }); + return decisionFromFile ?? program.usesUriStyleNodeCoreModules; + } + function getNewLineKind(newLineCharacter) { + return newLineCharacter === "\n" ? 1 /* LineFeed */ : 0 /* CarriageReturnLineFeed */; + } + function diagnosticToString(diag2) { + return isArray(diag2) ? formatStringFromArgs(getLocaleSpecificMessage(diag2[0]), diag2.slice(1)) : getLocaleSpecificMessage(diag2); + } + function getFormatCodeSettingsForWriting({ options }, sourceFile) { + const shouldAutoDetectSemicolonPreference = !options.semicolons || options.semicolons === "ignore" /* Ignore */; + const shouldRemoveSemicolons = options.semicolons === "remove" /* Remove */ || shouldAutoDetectSemicolonPreference && !probablyUsesSemicolons(sourceFile); + return { + ...options, + semicolons: shouldRemoveSemicolons ? "remove" /* Remove */ : "ignore" /* Ignore */ + }; + } + function jsxModeNeedsExplicitImport(jsx) { + return jsx === 2 /* React */ || jsx === 3 /* ReactNative */; + } + function isSourceFileFromLibrary(program, node) { + return program.isSourceFileFromExternalLibrary(node) || program.isSourceFileDefaultLibrary(node); + } + function newCaseClauseTracker(checker, clauses) { + const existingStrings = /* @__PURE__ */ new Set(); + const existingNumbers = /* @__PURE__ */ new Set(); + const existingBigInts = /* @__PURE__ */ new Set(); + for (const clause of clauses) { + if (!isDefaultClause(clause)) { + const expression = skipParentheses(clause.expression); + if (isLiteralExpression(expression)) { + switch (expression.kind) { + case 15 /* NoSubstitutionTemplateLiteral */: + case 11 /* StringLiteral */: + existingStrings.add(expression.text); + break; + case 9 /* NumericLiteral */: + existingNumbers.add(parseInt(expression.text)); + break; + case 10 /* BigIntLiteral */: + const parsedBigInt = parseBigInt(endsWith(expression.text, "n") ? expression.text.slice(0, -1) : expression.text); + if (parsedBigInt) { + existingBigInts.add(pseudoBigIntToString(parsedBigInt)); } - } - return 0 /* EqualTo */; + break; } - if (includePrecedingTokenAtEndPosition && start === position && children[middle - 1] && children[middle - 1].getEnd() === position && nodeContainsPosition(children[middle - 1])) { - return 1 /* GreaterThan */; + } else { + const symbol = checker.getSymbolAtLocation(clause.expression); + if (symbol && symbol.valueDeclaration && isEnumMember(symbol.valueDeclaration)) { + const enumValue = checker.getConstantValue(symbol.valueDeclaration); + if (enumValue !== void 0) { + addValue(enumValue); + } } - return -1 /* LessThan */; - }); - if (foundToken) { - return foundToken; - } - if (i >= 0 && children[i]) { - current = children[i]; - continue outer; } - return current; - } - function nodeContainsPosition(node, start, end) { - end ?? (end = node.getEnd()); - if (end < position) { - return false; } - start ?? (start = allowPositionInLeadingTrivia ? node.getFullStart() : node.getStart( - sourceFile, - /*includeJsDocComment*/ - true - )); - if (start > position) { - return false; + } + return { + addValue, + hasValue + }; + function addValue(value) { + switch (typeof value) { + case "string": + existingStrings.add(value); + break; + case "number": + existingNumbers.add(value); } - if (position < end || position === end && (node.kind === 1 /* EndOfFileToken */ || includeEndPosition)) { - return true; - } else if (includePrecedingTokenAtEndPosition && end === position) { - const previousToken = findPrecedingToken(position, sourceFile, node); - if (previousToken && includePrecedingTokenAtEndPosition(previousToken)) { - foundToken = previousToken; - return true; - } + } + function hasValue(value) { + switch (typeof value) { + case "string": + return existingStrings.has(value); + case "number": + return existingNumbers.has(value); + case "object": + return existingBigInts.has(pseudoBigIntToString(value)); } - return false; } } - function findFirstNonJsxWhitespaceToken(sourceFile, position) { - let tokenAtPosition = getTokenAtPosition(sourceFile, position); - while (isWhiteSpaceOnlyJsxText(tokenAtPosition)) { - const nextToken = findNextToken(tokenAtPosition, tokenAtPosition.parent, sourceFile); - if (!nextToken) - return; - tokenAtPosition = nextToken; + function fileShouldUseJavaScriptRequire(file, program, host, preferRequire) { + var _a; + const fileName = typeof file === "string" ? file : file.fileName; + if (!hasJSFileExtension(fileName)) { + return false; } - return tokenAtPosition; - } - function findTokenOnLeftOfPosition(file, position) { - const tokenAtPosition = getTokenAtPosition(file, position); - if (isToken(tokenAtPosition) && position > tokenAtPosition.getStart(file) && position < tokenAtPosition.getEnd()) { - return tokenAtPosition; + const compilerOptions = program.getCompilerOptions(); + const moduleKind = getEmitModuleKind(compilerOptions); + const impliedNodeFormat = typeof file === "string" ? getImpliedNodeFormatForFile(toPath(file, host.getCurrentDirectory(), hostGetCanonicalFileName(host)), (_a = program.getPackageJsonInfoCache) == null ? void 0 : _a.call(program), host, compilerOptions) : file.impliedNodeFormat; + if (impliedNodeFormat === 99 /* ESNext */) { + return false; } - return findPrecedingToken(position, file); - } - function findNextToken(previousToken, parent2, sourceFile) { - return find2(parent2); - function find2(n) { - if (isToken(n) && n.pos === previousToken.end) { - return n; + if (impliedNodeFormat === 1 /* CommonJS */) { + return true; + } + if (compilerOptions.verbatimModuleSyntax && moduleKind === 1 /* CommonJS */) { + return true; + } + if (compilerOptions.verbatimModuleSyntax && emitModuleKindIsNonNodeESM(moduleKind)) { + return false; + } + if (typeof file === "object") { + if (file.commonJsModuleIndicator) { + return true; + } + if (file.externalModuleIndicator) { + return false; } - return firstDefined(n.getChildren(sourceFile), (child) => { - const shouldDiveInChildNode = ( - // previous token is enclosed somewhere in the child - child.pos <= previousToken.pos && child.end > previousToken.end || // previous token ends exactly at the beginning of child - child.pos === previousToken.end - ); - return shouldDiveInChildNode && nodeHasTokens(child, sourceFile) ? find2(child) : void 0; - }); } + return preferRequire; } - function findPrecedingToken(position, sourceFile, startNode2, excludeJsdoc) { - const result = find2(startNode2 || sourceFile); - Debug.assert(!(result && isWhiteSpaceOnlyJsxText(result))); - return result; - function find2(n) { - if (isNonWhitespaceToken(n) && n.kind !== 1 /* EndOfFileToken */) { - return n; - } - const children = n.getChildren(sourceFile); - const i = binarySearchKey(children, position, (_, i2) => i2, (middle, _) => { - if (position < children[middle].end) { - if (!children[middle - 1] || position >= children[middle - 1].end) { - return 0 /* EqualTo */; - } - return 1 /* GreaterThan */; + var scanner, SemanticMeaning, tripleSlashDirectivePrefixRegex, typeKeywords, QuotePreference, displayPartWriter, lineFeed2, ANONYMOUS, syntaxMayBeASICandidate; + var init_utilities4 = __esm({ + "src/services/utilities.ts"() { + "use strict"; + init_pnp(); + init_ts4(); + scanner = createScanner( + 99 /* Latest */, + /*skipTrivia*/ + true + ); + SemanticMeaning = /* @__PURE__ */ ((SemanticMeaning3) => { + SemanticMeaning3[SemanticMeaning3["None"] = 0] = "None"; + SemanticMeaning3[SemanticMeaning3["Value"] = 1] = "Value"; + SemanticMeaning3[SemanticMeaning3["Type"] = 2] = "Type"; + SemanticMeaning3[SemanticMeaning3["Namespace"] = 4] = "Namespace"; + SemanticMeaning3[SemanticMeaning3["All"] = 7] = "All"; + return SemanticMeaning3; + })(SemanticMeaning || {}); + tripleSlashDirectivePrefixRegex = /^\/\/\/\s* { + QuotePreference7[QuotePreference7["Single"] = 0] = "Single"; + QuotePreference7[QuotePreference7["Double"] = 1] = "Double"; + return QuotePreference7; + })(QuotePreference || {}); + displayPartWriter = getDisplayPartWriter(); + lineFeed2 = "\n"; + ANONYMOUS = "anonymous function"; + syntaxMayBeASICandidate = or( + syntaxRequiresTrailingCommaOrSemicolonOrASI, + syntaxRequiresTrailingFunctionBlockOrSemicolonOrASI, + syntaxRequiresTrailingModuleBlockOrSemicolonOrASI, + syntaxRequiresTrailingSemicolonOrASI + ); + } + }); + + // src/services/exportInfoMap.ts + function createCacheableExportInfoMap(host) { + let exportInfoId = 1; + const exportInfo = createMultiMap(); + const symbols = /* @__PURE__ */ new Map(); + const packages = /* @__PURE__ */ new Map(); + let usableByFileName; + const cache = { + isUsableByFile: (importingFile) => importingFile === usableByFileName, + isEmpty: () => !exportInfo.size, + clear: () => { + exportInfo.clear(); + symbols.clear(); + usableByFileName = void 0; + }, + add: (importingFile, symbol, symbolTableKey, moduleSymbol, moduleFile, exportKind, isFromPackageJson, checker) => { + if (importingFile !== usableByFileName) { + cache.clear(); + usableByFileName = importingFile; } - return -1 /* LessThan */; - }); - if (i >= 0 && children[i]) { - const child = children[i]; - if (position < child.end) { - const start = child.getStart( - sourceFile, - /*includeJsDoc*/ - !excludeJsdoc - ); - const lookInPreviousChild = start >= position || // cursor in the leading trivia - !nodeHasTokens(child, sourceFile) || isWhiteSpaceOnlyJsxText(child); - if (lookInPreviousChild) { - const candidate2 = findRightmostChildNodeWithTokens( - children, - /*exclusiveStartPosition*/ - i, - sourceFile, - n.kind - ); - if (candidate2) { - if (!excludeJsdoc && isJSDocCommentContainingNode(candidate2) && candidate2.getChildren(sourceFile).length) { - return find2(candidate2); + let packageName; + if (moduleFile) { + const nodeModulesPathParts = getNodeModulePathParts(moduleFile.fileName); + if (nodeModulesPathParts) { + const { topLevelNodeModulesIndex, topLevelPackageNameIndex, packageRootIndex } = nodeModulesPathParts; + packageName = unmangleScopedPackageName(getPackageNameFromTypesPackageName(moduleFile.fileName.substring(topLevelPackageNameIndex + 1, packageRootIndex))); + if (startsWith(importingFile, moduleFile.path.substring(0, topLevelNodeModulesIndex))) { + const prevDeepestNodeModulesPath = packages.get(packageName); + const nodeModulesPath = moduleFile.fileName.substring(0, topLevelPackageNameIndex + 1); + if (prevDeepestNodeModulesPath) { + const prevDeepestNodeModulesIndex = prevDeepestNodeModulesPath.indexOf(nodeModulesPathPart); + if (topLevelNodeModulesIndex > prevDeepestNodeModulesIndex) { + packages.set(packageName, nodeModulesPath); + } + } else { + packages.set(packageName, nodeModulesPath); } - return findRightmostToken(candidate2, sourceFile); } - return void 0; - } else { - return find2(child); } } + const isDefault = exportKind === 1 /* Default */; + const namedSymbol = isDefault && getLocalSymbolForExportDefault(symbol) || symbol; + const names = exportKind === 0 /* Named */ || isExternalModuleSymbol(namedSymbol) ? unescapeLeadingUnderscores(symbolTableKey) : getNamesForExportedSymbol( + namedSymbol, + /*scriptTarget*/ + void 0 + ); + const symbolName2 = typeof names === "string" ? names : names[0]; + const capitalizedSymbolName = typeof names === "string" ? void 0 : names[1]; + const moduleName = stripQuotes(moduleSymbol.name); + const id = exportInfoId++; + const target = skipAlias(symbol, checker); + const storedSymbol = symbol.flags & 33554432 /* Transient */ ? void 0 : symbol; + const storedModuleSymbol = moduleSymbol.flags & 33554432 /* Transient */ ? void 0 : moduleSymbol; + if (!storedSymbol || !storedModuleSymbol) + symbols.set(id, [symbol, moduleSymbol]); + exportInfo.add(key(symbolName2, symbol, isExternalModuleNameRelative(moduleName) ? void 0 : moduleName, checker), { + id, + symbolTableKey, + symbolName: symbolName2, + capitalizedSymbolName, + moduleName, + moduleFile, + moduleFileName: moduleFile == null ? void 0 : moduleFile.fileName, + packageName, + exportKind, + targetFlags: target.flags, + isFromPackageJson, + symbol: storedSymbol, + moduleSymbol: storedModuleSymbol + }); + }, + get: (importingFile, key2) => { + if (importingFile !== usableByFileName) + return; + const result = exportInfo.get(key2); + return result == null ? void 0 : result.map(rehydrateCachedInfo); + }, + search: (importingFile, preferCapitalized, matches, action) => { + if (importingFile !== usableByFileName) + return; + return forEachEntry(exportInfo, (info, key2) => { + const { symbolName: symbolName2, ambientModuleName } = parseKey(key2); + const name = preferCapitalized && info[0].capitalizedSymbolName || symbolName2; + if (matches(name, info[0].targetFlags)) { + const rehydrated = info.map(rehydrateCachedInfo); + const filtered = rehydrated.filter((r, i) => isNotShadowedByDeeperNodeModulesPackage(r, info[i].packageName)); + if (filtered.length) { + const res = action(filtered, name, !!ambientModuleName, key2); + if (res !== void 0) + return res; + } + } + }); + }, + releaseSymbols: () => { + symbols.clear(); + }, + onFileChanged: (oldSourceFile, newSourceFile, typeAcquisitionEnabled) => { + if (fileIsGlobalOnly(oldSourceFile) && fileIsGlobalOnly(newSourceFile)) { + return false; + } + if (usableByFileName && usableByFileName !== newSourceFile.path || // If ATA is enabled, auto-imports uses existing imports to guess whether you want auto-imports from node. + // Adding or removing imports from node could change the outcome of that guess, so could change the suggestions list. + typeAcquisitionEnabled && consumesNodeCoreModules(oldSourceFile) !== consumesNodeCoreModules(newSourceFile) || // Module agumentation and ambient module changes can add or remove exports available to be auto-imported. + // Changes elsewhere in the file can change the *type* of an export in a module augmentation, + // but type info is gathered in getCompletionEntryDetails, which doesn't use the cache. + !arrayIsEqualTo(oldSourceFile.moduleAugmentations, newSourceFile.moduleAugmentations) || !ambientModuleDeclarationsAreEqual(oldSourceFile, newSourceFile)) { + cache.clear(); + return true; + } + usableByFileName = newSourceFile.path; + return false; + } + }; + if (Debug.isDebugging) { + Object.defineProperty(cache, "__cache", { value: exportInfo }); + } + return cache; + function rehydrateCachedInfo(info) { + if (info.symbol && info.moduleSymbol) + return info; + const { id, exportKind, targetFlags, isFromPackageJson, moduleFileName } = info; + const [cachedSymbol, cachedModuleSymbol] = symbols.get(id) || emptyArray; + if (cachedSymbol && cachedModuleSymbol) { + return { + symbol: cachedSymbol, + moduleSymbol: cachedModuleSymbol, + moduleFileName, + exportKind, + targetFlags, + isFromPackageJson + }; + } + const checker = (isFromPackageJson ? host.getPackageJsonAutoImportProvider() : host.getCurrentProgram()).getTypeChecker(); + const moduleSymbol = info.moduleSymbol || cachedModuleSymbol || Debug.checkDefined( + info.moduleFile ? checker.getMergedSymbol(info.moduleFile.symbol) : checker.tryFindAmbientModule(info.moduleName) + ); + const symbol = info.symbol || cachedSymbol || Debug.checkDefined( + exportKind === 2 /* ExportEquals */ ? checker.resolveExternalModuleSymbol(moduleSymbol) : checker.tryGetMemberInModuleExportsAndProperties(unescapeLeadingUnderscores(info.symbolTableKey), moduleSymbol), + `Could not find symbol '${info.symbolName}' by key '${info.symbolTableKey}' in module ${moduleSymbol.name}` + ); + symbols.set(id, [symbol, moduleSymbol]); + return { + symbol, + moduleSymbol, + moduleFileName, + exportKind, + targetFlags, + isFromPackageJson + }; + } + function key(importedName, symbol, ambientModuleName, checker) { + const moduleKey = ambientModuleName || ""; + return `${importedName.length} ${getSymbolId(skipAlias(symbol, checker))} ${importedName} ${moduleKey}`; + } + function parseKey(key2) { + const firstSpace = key2.indexOf(" "); + const secondSpace = key2.indexOf(" ", firstSpace + 1); + const symbolNameLength = parseInt(key2.substring(0, firstSpace), 10); + const data = key2.substring(secondSpace + 1); + const symbolName2 = data.substring(0, symbolNameLength); + const moduleKey = data.substring(symbolNameLength + 1); + const ambientModuleName = moduleKey === "" ? void 0 : moduleKey; + return { symbolName: symbolName2, ambientModuleName }; + } + function fileIsGlobalOnly(file) { + return !file.commonJsModuleIndicator && !file.externalModuleIndicator && !file.moduleAugmentations && !file.ambientModuleNames; + } + function ambientModuleDeclarationsAreEqual(oldSourceFile, newSourceFile) { + if (!arrayIsEqualTo(oldSourceFile.ambientModuleNames, newSourceFile.ambientModuleNames)) { + return false; + } + let oldFileStatementIndex = -1; + let newFileStatementIndex = -1; + for (const ambientModuleName of newSourceFile.ambientModuleNames) { + const isMatchingModuleDeclaration = (node) => isNonGlobalAmbientModule(node) && node.name.text === ambientModuleName; + oldFileStatementIndex = findIndex(oldSourceFile.statements, isMatchingModuleDeclaration, oldFileStatementIndex + 1); + newFileStatementIndex = findIndex(newSourceFile.statements, isMatchingModuleDeclaration, newFileStatementIndex + 1); + if (oldSourceFile.statements[oldFileStatementIndex] !== newSourceFile.statements[newFileStatementIndex]) { + return false; + } + } + return true; + } + function isNotShadowedByDeeperNodeModulesPackage(info, packageName) { + if (!packageName || !info.moduleFileName) + return true; + const typingsCacheLocation = host.getGlobalTypingsCacheLocation(); + if (typingsCacheLocation && startsWith(info.moduleFileName, typingsCacheLocation)) + return true; + const packageDeepestNodeModulesPath = packages.get(packageName); + return !packageDeepestNodeModulesPath || startsWith(info.moduleFileName, packageDeepestNodeModulesPath); + } + } + function isImportableFile(program, from, to, preferences, packageJsonFilter, moduleSpecifierResolutionHost, moduleSpecifierCache) { + var _a; + if (from === to) + return false; + const cachedResult = moduleSpecifierCache == null ? void 0 : moduleSpecifierCache.get(from.path, to.path, preferences, {}); + if ((cachedResult == null ? void 0 : cachedResult.isBlockedByPackageJsonDependencies) !== void 0) { + return !cachedResult.isBlockedByPackageJsonDependencies; + } + const getCanonicalFileName = hostGetCanonicalFileName(moduleSpecifierResolutionHost); + const globalTypingsCache = (_a = moduleSpecifierResolutionHost.getGlobalTypingsCacheLocation) == null ? void 0 : _a.call(moduleSpecifierResolutionHost); + const hasImportablePath = !!ts_moduleSpecifiers_exports.forEachFileNameOfModule( + from.fileName, + to.fileName, + moduleSpecifierResolutionHost, + /*preferSymlinks*/ + false, + (toPath3) => { + const toFile = program.getSourceFile(toPath3); + return (toFile === to || !toFile) && isImportablePath(from.fileName, toPath3, getCanonicalFileName, globalTypingsCache); } - Debug.assert(startNode2 !== void 0 || n.kind === 311 /* SourceFile */ || n.kind === 1 /* EndOfFileToken */ || isJSDocCommentContainingNode(n)); - const candidate = findRightmostChildNodeWithTokens( - children, - /*exclusiveStartPosition*/ - children.length, - sourceFile, - n.kind - ); - return candidate && findRightmostToken(candidate, sourceFile); + ); + if (packageJsonFilter) { + const isAutoImportable = hasImportablePath && packageJsonFilter.allowsImportingSourceFile(to, moduleSpecifierResolutionHost); + moduleSpecifierCache == null ? void 0 : moduleSpecifierCache.setBlockedByPackageJsonDependencies(from.path, to.path, preferences, {}, !isAutoImportable); + return isAutoImportable; } + return hasImportablePath; } - function isNonWhitespaceToken(n) { - return isToken(n) && !isWhiteSpaceOnlyJsxText(n); - } - function findRightmostToken(n, sourceFile) { - if (isNonWhitespaceToken(n)) { - return n; - } - const children = n.getChildren(sourceFile); - if (children.length === 0) { - return n; + function isImportablePath(fromPath, toPath3, getCanonicalFileName, globalCachePath) { + if (getPnpApi(fromPath)) { + return isImportablePathPnp(fromPath, toPath3); } - const candidate = findRightmostChildNodeWithTokens( - children, - /*exclusiveStartPosition*/ - children.length, - sourceFile, - n.kind - ); - return candidate && findRightmostToken(candidate, sourceFile); + const toNodeModules = forEachAncestorDirectory(toPath3, (ancestor) => getBaseFileName(ancestor) === "node_modules" ? ancestor : void 0); + const toNodeModulesParent = toNodeModules && getDirectoryPath(getCanonicalFileName(toNodeModules)); + return toNodeModulesParent === void 0 || startsWith(getCanonicalFileName(fromPath), toNodeModulesParent) || !!globalCachePath && startsWith(getCanonicalFileName(globalCachePath), toNodeModulesParent); } - function findRightmostChildNodeWithTokens(children, exclusiveStartPosition, sourceFile, parentKind) { - for (let i = exclusiveStartPosition - 1; i >= 0; i--) { - const child = children[i]; - if (isWhiteSpaceOnlyJsxText(child)) { - if (i === 0 && (parentKind === 12 /* JsxText */ || parentKind === 284 /* JsxSelfClosingElement */)) { - Debug.fail("`JsxText` tokens should not be the first child of `JsxElement | JsxSelfClosingElement`"); + function forEachExternalModuleToImportFrom(program, host, preferences, useAutoImportProvider, cb) { + var _a, _b; + const useCaseSensitiveFileNames2 = hostUsesCaseSensitiveFileNames(host); + const excludePatterns = preferences.autoImportFileExcludePatterns && mapDefined(preferences.autoImportFileExcludePatterns, (spec) => { + const pattern = getPatternFromSpec(spec, "", "exclude"); + return pattern ? getRegexFromPattern(pattern, useCaseSensitiveFileNames2) : void 0; + }); + forEachExternalModule(program.getTypeChecker(), program.getSourceFiles(), excludePatterns, (module2, file) => cb( + module2, + file, + program, + /*isFromPackageJson*/ + false + )); + const autoImportProvider = useAutoImportProvider && ((_a = host.getPackageJsonAutoImportProvider) == null ? void 0 : _a.call(host)); + if (autoImportProvider) { + const start = timestamp(); + const checker = program.getTypeChecker(); + forEachExternalModule(autoImportProvider.getTypeChecker(), autoImportProvider.getSourceFiles(), excludePatterns, (module2, file) => { + if (file && !program.getSourceFile(file.fileName) || !file && !checker.resolveName( + module2.name, + /*location*/ + void 0, + 1536 /* Module */, + /*excludeGlobals*/ + false + )) { + cb( + module2, + file, + autoImportProvider, + /*isFromPackageJson*/ + true + ); } - } else if (nodeHasTokens(children[i], sourceFile)) { - return children[i]; - } + }); + (_b = host.log) == null ? void 0 : _b.call(host, `forEachExternalModuleToImportFrom autoImportProvider: ${timestamp() - start}`); } } - function isInString(sourceFile, position, previousToken = findPrecedingToken(position, sourceFile)) { - if (previousToken && isStringTextContainingNode(previousToken)) { - const start = previousToken.getStart(sourceFile); - const end = previousToken.getEnd(); - if (start < position && position < end) { - return true; + function forEachExternalModule(checker, allSourceFiles, excludePatterns, cb) { + var _a; + const isExcluded = excludePatterns && ((fileName) => excludePatterns.some((p) => p.test(fileName))); + for (const ambient of checker.getAmbientModules()) { + if (!ambient.name.includes("*") && !(excludePatterns && ((_a = ambient.declarations) == null ? void 0 : _a.every((d) => isExcluded(d.getSourceFile().fileName))))) { + cb( + ambient, + /*sourceFile*/ + void 0 + ); } - if (position === end) { - return !!previousToken.isUnterminated; + } + for (const sourceFile of allSourceFiles) { + if (isExternalOrCommonJsModule(sourceFile) && !(isExcluded == null ? void 0 : isExcluded(sourceFile.fileName))) { + cb(checker.getMergedSymbol(sourceFile.symbol), sourceFile); } } - return false; } - function isInsideJsxElementOrAttribute(sourceFile, position) { - const token = getTokenAtPosition(sourceFile, position); - if (!token) { - return false; - } - if (token.kind === 12 /* JsxText */) { - return true; - } - if (token.kind === 30 /* LessThanToken */ && token.parent.kind === 12 /* JsxText */) { - return true; - } - if (token.kind === 30 /* LessThanToken */ && token.parent.kind === 293 /* JsxExpression */) { - return true; - } - if (token && token.kind === 20 /* CloseBraceToken */ && token.parent.kind === 293 /* JsxExpression */) { - return true; + function getExportInfoMap(importingFile, host, program, preferences, cancellationToken) { + var _a, _b, _c, _d, _e; + const start = timestamp(); + (_a = host.getPackageJsonAutoImportProvider) == null ? void 0 : _a.call(host); + const cache = ((_b = host.getCachedExportInfoMap) == null ? void 0 : _b.call(host)) || createCacheableExportInfoMap({ + getCurrentProgram: () => program, + getPackageJsonAutoImportProvider: () => { + var _a2; + return (_a2 = host.getPackageJsonAutoImportProvider) == null ? void 0 : _a2.call(host); + }, + getGlobalTypingsCacheLocation: () => { + var _a2; + return (_a2 = host.getGlobalTypingsCacheLocation) == null ? void 0 : _a2.call(host); + } + }); + if (cache.isUsableByFile(importingFile.path)) { + (_c = host.log) == null ? void 0 : _c.call(host, "getExportInfoMap: cache hit"); + return cache; } - if (token.kind === 30 /* LessThanToken */ && token.parent.kind === 286 /* JsxClosingElement */) { - return true; + (_d = host.log) == null ? void 0 : _d.call(host, "getExportInfoMap: cache miss or empty; calculating new results"); + const compilerOptions = program.getCompilerOptions(); + let moduleCount = 0; + try { + forEachExternalModuleToImportFrom( + program, + host, + preferences, + /*useAutoImportProvider*/ + true, + (moduleSymbol, moduleFile, program2, isFromPackageJson) => { + if (++moduleCount % 100 === 0) + cancellationToken == null ? void 0 : cancellationToken.throwIfCancellationRequested(); + const seenExports = /* @__PURE__ */ new Map(); + const checker = program2.getTypeChecker(); + const defaultInfo = getDefaultLikeExportInfo(moduleSymbol, checker, compilerOptions); + if (defaultInfo && isImportableSymbol(defaultInfo.symbol, checker)) { + cache.add( + importingFile.path, + defaultInfo.symbol, + defaultInfo.exportKind === 1 /* Default */ ? "default" /* Default */ : "export=" /* ExportEquals */, + moduleSymbol, + moduleFile, + defaultInfo.exportKind, + isFromPackageJson, + checker + ); + } + checker.forEachExportAndPropertyOfModule(moduleSymbol, (exported, key) => { + if (exported !== (defaultInfo == null ? void 0 : defaultInfo.symbol) && isImportableSymbol(exported, checker) && addToSeen(seenExports, key)) { + cache.add( + importingFile.path, + exported, + key, + moduleSymbol, + moduleFile, + 0 /* Named */, + isFromPackageJson, + checker + ); + } + }); + } + ); + } catch (err) { + cache.clear(); + throw err; } - return false; + (_e = host.log) == null ? void 0 : _e.call(host, `getExportInfoMap: done in ${timestamp() - start} ms`); + return cache; } - function isWhiteSpaceOnlyJsxText(node) { - return isJsxText(node) && node.containsOnlyTriviaWhiteSpaces; + function getDefaultLikeExportInfo(moduleSymbol, checker, compilerOptions) { + const exported = getDefaultLikeExportWorker(moduleSymbol, checker); + if (!exported) + return void 0; + const { symbol, exportKind } = exported; + const info = getDefaultExportInfoWorker(symbol, checker, compilerOptions); + return info && { symbol, exportKind, ...info }; } - function isInTemplateString(sourceFile, position) { - const token = getTokenAtPosition(sourceFile, position); - return isTemplateLiteralKind(token.kind) && position > token.getStart(sourceFile); + function isImportableSymbol(symbol, checker) { + return !checker.isUndefinedSymbol(symbol) && !checker.isUnknownSymbol(symbol) && !isKnownSymbol(symbol) && !isPrivateIdentifierSymbol(symbol); } - function isInJSXText(sourceFile, position) { - const token = getTokenAtPosition(sourceFile, position); - if (isJsxText(token)) { - return true; - } - if (token.kind === 19 /* OpenBraceToken */ && isJsxExpression(token.parent) && isJsxElement(token.parent.parent)) { - return true; + function getDefaultLikeExportWorker(moduleSymbol, checker) { + const exportEquals = checker.resolveExternalModuleSymbol(moduleSymbol); + if (exportEquals !== moduleSymbol) + return { symbol: exportEquals, exportKind: 2 /* ExportEquals */ }; + const defaultExport = checker.tryGetMemberInModuleExports("default" /* Default */, moduleSymbol); + if (defaultExport) + return { symbol: defaultExport, exportKind: 1 /* Default */ }; + } + function getDefaultExportInfoWorker(defaultExport, checker, compilerOptions) { + const localSymbol = getLocalSymbolForExportDefault(defaultExport); + if (localSymbol) + return { resolvedSymbol: localSymbol, name: localSymbol.name }; + const name = getNameForExportDefault(defaultExport); + if (name !== void 0) + return { resolvedSymbol: defaultExport, name }; + if (defaultExport.flags & 2097152 /* Alias */) { + const aliased = checker.getImmediateAliasedSymbol(defaultExport); + if (aliased && aliased.parent) { + return getDefaultExportInfoWorker(aliased, checker, compilerOptions); + } } - if (token.kind === 30 /* LessThanToken */ && isJsxOpeningLikeElement(token.parent) && isJsxElement(token.parent.parent)) { - return true; + if (defaultExport.escapedName !== "default" /* Default */ && defaultExport.escapedName !== "export=" /* ExportEquals */) { + return { resolvedSymbol: defaultExport, name: defaultExport.getName() }; } - return false; + return { resolvedSymbol: defaultExport, name: getNameForExportedSymbol(defaultExport, compilerOptions.target) }; } - function isInsideJsxElement(sourceFile, position) { - function isInsideJsxElementTraversal(node) { - while (node) { - if (node.kind >= 284 /* JsxSelfClosingElement */ && node.kind <= 293 /* JsxExpression */ || node.kind === 12 /* JsxText */ || node.kind === 30 /* LessThanToken */ || node.kind === 32 /* GreaterThanToken */ || node.kind === 80 /* Identifier */ || node.kind === 20 /* CloseBraceToken */ || node.kind === 19 /* OpenBraceToken */ || node.kind === 44 /* SlashToken */) { - node = node.parent; - } else if (node.kind === 283 /* JsxElement */) { - if (position > node.getStart(sourceFile)) - return true; - node = node.parent; - } else { - return false; - } + function getNameForExportDefault(symbol) { + return symbol.declarations && firstDefined(symbol.declarations, (declaration) => { + var _a; + if (isExportAssignment(declaration)) { + return (_a = tryCast(skipOuterExpressions(declaration.expression), isIdentifier)) == null ? void 0 : _a.text; + } else if (isExportSpecifier(declaration)) { + Debug.assert(declaration.name.text === "default" /* Default */, "Expected the specifier to be a default export"); + return declaration.propertyName && declaration.propertyName.text; } - return false; - } - return isInsideJsxElementTraversal(getTokenAtPosition(sourceFile, position)); + }); } - function findPrecedingMatchingToken(token, matchingTokenKind, sourceFile) { - const closeTokenText = tokenToString(token.kind); - const matchingTokenText = tokenToString(matchingTokenKind); - const tokenFullStart = token.getFullStart(); - const bestGuessIndex = sourceFile.text.lastIndexOf(matchingTokenText, tokenFullStart); - if (bestGuessIndex === -1) { - return void 0; + var ImportKind, ExportKind; + var init_exportInfoMap = __esm({ + "src/services/exportInfoMap.ts"() { + "use strict"; + init_pnp(); + init_ts4(); + ImportKind = /* @__PURE__ */ ((ImportKind2) => { + ImportKind2[ImportKind2["Named"] = 0] = "Named"; + ImportKind2[ImportKind2["Default"] = 1] = "Default"; + ImportKind2[ImportKind2["Namespace"] = 2] = "Namespace"; + ImportKind2[ImportKind2["CommonJS"] = 3] = "CommonJS"; + return ImportKind2; + })(ImportKind || {}); + ExportKind = /* @__PURE__ */ ((ExportKind3) => { + ExportKind3[ExportKind3["Named"] = 0] = "Named"; + ExportKind3[ExportKind3["Default"] = 1] = "Default"; + ExportKind3[ExportKind3["ExportEquals"] = 2] = "ExportEquals"; + ExportKind3[ExportKind3["UMD"] = 3] = "UMD"; + return ExportKind3; + })(ExportKind || {}); } - if (sourceFile.text.lastIndexOf(closeTokenText, tokenFullStart - 1) < bestGuessIndex) { - const nodeAtGuess = findPrecedingToken(bestGuessIndex + 1, sourceFile); - if (nodeAtGuess && nodeAtGuess.kind === matchingTokenKind) { - return nodeAtGuess; - } + }); + + // src/services/classifier.ts + function createClassifier() { + const scanner2 = createScanner( + 99 /* Latest */, + /*skipTrivia*/ + false + ); + function getClassificationsForLine(text, lexState, syntacticClassifierAbsent) { + return convertClassificationsToResult(getEncodedLexicalClassifications(text, lexState, syntacticClassifierAbsent), text); } - const tokenKind = token.kind; - let remainingMatchingTokens = 0; - while (true) { - const preceding = findPrecedingToken(token.getFullStart(), sourceFile); - if (!preceding) { - return void 0; + function getEncodedLexicalClassifications(text, lexState, syntacticClassifierAbsent) { + let token = 0 /* Unknown */; + let lastNonTriviaToken = 0 /* Unknown */; + const templateStack = []; + const { prefix, pushTemplate } = getPrefixFromLexState(lexState); + text = prefix + text; + const offset = prefix.length; + if (pushTemplate) { + templateStack.push(16 /* TemplateHead */); } - token = preceding; - if (token.kind === matchingTokenKind) { - if (remainingMatchingTokens === 0) { - return token; + scanner2.setText(text); + let endOfLineState = 0 /* None */; + const spans = []; + let angleBracketStack = 0; + do { + token = scanner2.scan(); + if (!isTrivia(token)) { + handleToken(); + lastNonTriviaToken = token; + } + const end = scanner2.getTokenEnd(); + pushEncodedClassification(scanner2.getTokenStart(), end, offset, classFromKind(token), spans); + if (end >= text.length) { + const end2 = getNewEndOfLineState(scanner2, token, lastOrUndefined(templateStack)); + if (end2 !== void 0) { + endOfLineState = end2; + } + } + } while (token !== 1 /* EndOfFileToken */); + function handleToken() { + switch (token) { + case 44 /* SlashToken */: + case 69 /* SlashEqualsToken */: + if (!noRegexTable[lastNonTriviaToken] && scanner2.reScanSlashToken() === 14 /* RegularExpressionLiteral */) { + token = 14 /* RegularExpressionLiteral */; + } + break; + case 30 /* LessThanToken */: + if (lastNonTriviaToken === 80 /* Identifier */) { + angleBracketStack++; + } + break; + case 32 /* GreaterThanToken */: + if (angleBracketStack > 0) { + angleBracketStack--; + } + break; + case 133 /* AnyKeyword */: + case 154 /* StringKeyword */: + case 150 /* NumberKeyword */: + case 136 /* BooleanKeyword */: + case 155 /* SymbolKeyword */: + if (angleBracketStack > 0 && !syntacticClassifierAbsent) { + token = 80 /* Identifier */; + } + break; + case 16 /* TemplateHead */: + templateStack.push(token); + break; + case 19 /* OpenBraceToken */: + if (templateStack.length > 0) { + templateStack.push(token); + } + break; + case 20 /* CloseBraceToken */: + if (templateStack.length > 0) { + const lastTemplateStackToken = lastOrUndefined(templateStack); + if (lastTemplateStackToken === 16 /* TemplateHead */) { + token = scanner2.reScanTemplateToken( + /*isTaggedTemplate*/ + false + ); + if (token === 18 /* TemplateTail */) { + templateStack.pop(); + } else { + Debug.assertEqual(token, 17 /* TemplateMiddle */, "Should have been a template middle."); + } + } else { + Debug.assertEqual(lastTemplateStackToken, 19 /* OpenBraceToken */, "Should have been an open brace"); + templateStack.pop(); + } + } + break; + default: + if (!isKeyword(token)) { + break; + } + if (lastNonTriviaToken === 25 /* DotToken */) { + token = 80 /* Identifier */; + } else if (isKeyword(lastNonTriviaToken) && isKeyword(token) && !canFollow(lastNonTriviaToken, token)) { + token = 80 /* Identifier */; + } } - remainingMatchingTokens--; - } else if (token.kind === tokenKind) { - remainingMatchingTokens++; } + return { endOfLineState, spans }; } + return { getClassificationsForLine, getEncodedLexicalClassifications }; } - function removeOptionality(type, isOptionalExpression, isOptionalChain2) { - return isOptionalExpression ? type.getNonNullableType() : isOptionalChain2 ? type.getNonOptionalType() : type; - } - function isPossiblyTypeArgumentPosition(token, sourceFile, checker) { - const info = getPossibleTypeArgumentsInfo(token, sourceFile); - return info !== void 0 && (isPartOfTypeNode(info.called) || getPossibleGenericSignatures(info.called, info.nTypeArguments, checker).length !== 0 || isPossiblyTypeArgumentPosition(info.called, sourceFile, checker)); - } - function getPossibleGenericSignatures(called, typeArgumentCount, checker) { - let type = checker.getTypeAtLocation(called); - if (isOptionalChain(called.parent)) { - type = removeOptionality( - type, - isOptionalChainRoot(called.parent), - /*isOptionalChain*/ - true - ); - } - const signatures = isNewExpression(called.parent) ? type.getConstructSignatures() : type.getCallSignatures(); - return signatures.filter((candidate) => !!candidate.typeParameters && candidate.typeParameters.length >= typeArgumentCount); - } - function getPossibleTypeArgumentsInfo(tokenIn, sourceFile) { - if (sourceFile.text.lastIndexOf("<", tokenIn ? tokenIn.pos : sourceFile.text.length) === -1) { - return void 0; - } - let token = tokenIn; - let remainingLessThanTokens = 0; - let nTypeArguments = 0; - while (token) { - switch (token.kind) { - case 30 /* LessThanToken */: - token = findPrecedingToken(token.getFullStart(), sourceFile); - if (token && token.kind === 29 /* QuestionDotToken */) { - token = findPrecedingToken(token.getFullStart(), sourceFile); - } - if (!token || !isIdentifier(token)) + function getNewEndOfLineState(scanner2, token, lastOnTemplateStack) { + switch (token) { + case 11 /* StringLiteral */: { + if (!scanner2.isUnterminated()) + return void 0; + const tokenText = scanner2.getTokenText(); + const lastCharIndex = tokenText.length - 1; + let numBackslashes = 0; + while (tokenText.charCodeAt(lastCharIndex - numBackslashes) === 92 /* backslash */) { + numBackslashes++; + } + if ((numBackslashes & 1) === 0) + return void 0; + return tokenText.charCodeAt(0) === 34 /* doubleQuote */ ? 3 /* InDoubleQuoteStringLiteral */ : 2 /* InSingleQuoteStringLiteral */; + } + case 3 /* MultiLineCommentTrivia */: + return scanner2.isUnterminated() ? 1 /* InMultiLineCommentTrivia */ : void 0; + default: + if (isTemplateLiteralKind(token)) { + if (!scanner2.isUnterminated()) { return void 0; - if (!remainingLessThanTokens) { - return isDeclarationName(token) ? void 0 : { called: token, nTypeArguments }; } - remainingLessThanTokens--; - break; - case 50 /* GreaterThanGreaterThanGreaterThanToken */: - remainingLessThanTokens = 3; - break; - case 49 /* GreaterThanGreaterThanToken */: - remainingLessThanTokens = 2; - break; - case 32 /* GreaterThanToken */: - remainingLessThanTokens++; - break; - case 20 /* CloseBraceToken */: - token = findPrecedingMatchingToken(token, 19 /* OpenBraceToken */, sourceFile); - if (!token) - return void 0; - break; - case 22 /* CloseParenToken */: - token = findPrecedingMatchingToken(token, 21 /* OpenParenToken */, sourceFile); - if (!token) - return void 0; - break; - case 24 /* CloseBracketToken */: - token = findPrecedingMatchingToken(token, 23 /* OpenBracketToken */, sourceFile); - if (!token) - return void 0; - break; - case 28 /* CommaToken */: - nTypeArguments++; - break; - case 39 /* EqualsGreaterThanToken */: - case 80 /* Identifier */: - case 11 /* StringLiteral */: - case 9 /* NumericLiteral */: - case 10 /* BigIntLiteral */: - case 112 /* TrueKeyword */: - case 97 /* FalseKeyword */: - case 114 /* TypeOfKeyword */: - case 96 /* ExtendsKeyword */: - case 143 /* KeyOfKeyword */: - case 25 /* DotToken */: - case 52 /* BarToken */: - case 58 /* QuestionToken */: - case 59 /* ColonToken */: - break; - default: - if (isTypeNode(token)) { - break; + switch (token) { + case 18 /* TemplateTail */: + return 5 /* InTemplateMiddleOrTail */; + case 15 /* NoSubstitutionTemplateLiteral */: + return 4 /* InTemplateHeadOrNoSubstitutionTemplate */; + default: + return Debug.fail("Only 'NoSubstitutionTemplateLiteral's and 'TemplateTail's can be unterminated; got SyntaxKind #" + token); } - return void 0; - } - token = findPrecedingToken(token.getFullStart(), sourceFile); + } + return lastOnTemplateStack === 16 /* TemplateHead */ ? 6 /* InTemplateSubstitutionPosition */ : void 0; } - return void 0; - } - function isInComment(sourceFile, position, tokenAtPosition) { - return ts_formatting_exports.getRangeOfEnclosingComment( - sourceFile, - position, - /*precedingToken*/ - void 0, - tokenAtPosition - ); - } - function hasDocComment(sourceFile, position) { - const token = getTokenAtPosition(sourceFile, position); - return !!findAncestor(token, isJSDoc); - } - function nodeHasTokens(n, sourceFile) { - return n.kind === 1 /* EndOfFileToken */ ? !!n.jsDoc : n.getWidth(sourceFile) !== 0; } - function getNodeModifiers(node, excludeFlags = 0 /* None */) { - const result = []; - const flags = isDeclaration(node) ? getCombinedNodeFlagsAlwaysIncludeJSDoc(node) & ~excludeFlags : 0 /* None */; - if (flags & 8 /* Private */) - result.push("private" /* privateMemberModifier */); - if (flags & 16 /* Protected */) - result.push("protected" /* protectedMemberModifier */); - if (flags & 4 /* Public */) - result.push("public" /* publicMemberModifier */); - if (flags & 32 /* Static */ || isClassStaticBlockDeclaration(node)) - result.push("static" /* staticModifier */); - if (flags & 256 /* Abstract */) - result.push("abstract" /* abstractModifier */); - if (flags & 1 /* Export */) - result.push("export" /* exportedModifier */); - if (flags & 8192 /* Deprecated */) - result.push("deprecated" /* deprecatedModifier */); - if (node.flags & 16777216 /* Ambient */) - result.push("declare" /* ambientModifier */); - if (node.kind === 276 /* ExportAssignment */) - result.push("export" /* exportedModifier */); - return result.length > 0 ? result.join(",") : "" /* none */; + function pushEncodedClassification(start, end, offset, classification, result) { + if (classification === 8 /* whiteSpace */) { + return; + } + if (start === 0 && offset > 0) { + start += offset; + } + const length2 = end - start; + if (length2 > 0) { + result.push(start - offset, length2, classification); + } } - function getTypeArgumentOrTypeParameterList(node) { - if (node.kind === 182 /* TypeReference */ || node.kind === 212 /* CallExpression */) { - return node.typeArguments; + function convertClassificationsToResult(classifications, text) { + const entries = []; + const dense = classifications.spans; + let lastEnd = 0; + for (let i = 0; i < dense.length; i += 3) { + const start = dense[i]; + const length2 = dense[i + 1]; + const type = dense[i + 2]; + if (lastEnd >= 0) { + const whitespaceLength2 = start - lastEnd; + if (whitespaceLength2 > 0) { + entries.push({ length: whitespaceLength2, classification: 4 /* Whitespace */ }); + } + } + entries.push({ length: length2, classification: convertClassification(type) }); + lastEnd = start + length2; } - if (isFunctionLike(node) || node.kind === 262 /* ClassDeclaration */ || node.kind === 263 /* InterfaceDeclaration */) { - return node.typeParameters; + const whitespaceLength = text.length - lastEnd; + if (whitespaceLength > 0) { + entries.push({ length: whitespaceLength, classification: 4 /* Whitespace */ }); } - return void 0; + return { entries, finalLexState: classifications.endOfLineState }; } - function isComment(kind) { - return kind === 2 /* SingleLineCommentTrivia */ || kind === 3 /* MultiLineCommentTrivia */; + function convertClassification(type) { + switch (type) { + case 1 /* comment */: + return 3 /* Comment */; + case 3 /* keyword */: + return 1 /* Keyword */; + case 4 /* numericLiteral */: + return 6 /* NumberLiteral */; + case 25 /* bigintLiteral */: + return 7 /* BigIntLiteral */; + case 5 /* operator */: + return 2 /* Operator */; + case 6 /* stringLiteral */: + return 8 /* StringLiteral */; + case 8 /* whiteSpace */: + return 4 /* Whitespace */; + case 10 /* punctuation */: + return 0 /* Punctuation */; + case 2 /* identifier */: + case 11 /* className */: + case 12 /* enumName */: + case 13 /* interfaceName */: + case 14 /* moduleName */: + case 15 /* typeParameterName */: + case 16 /* typeAliasName */: + case 9 /* text */: + case 17 /* parameterName */: + return 5 /* Identifier */; + default: + return void 0; + } } - function isStringOrRegularExpressionOrTemplateLiteral(kind) { - if (kind === 11 /* StringLiteral */ || kind === 14 /* RegularExpressionLiteral */ || isTemplateLiteralKind(kind)) { + function canFollow(keyword1, keyword2) { + if (!isAccessibilityModifier(keyword1)) { return true; } - return false; - } - function areIntersectedTypesAvoidingStringReduction(checker, t1, t2) { - return !!(t1.flags & 4 /* String */) && checker.isEmptyAnonymousObjectType(t2); - } - function isStringAndEmptyAnonymousObjectIntersection(type) { - if (!type.isIntersection()) { - return false; + switch (keyword2) { + case 139 /* GetKeyword */: + case 153 /* SetKeyword */: + case 137 /* ConstructorKeyword */: + case 126 /* StaticKeyword */: + case 129 /* AccessorKeyword */: + return true; + default: + return false; } - const { types, checker } = type; - return types.length === 2 && (areIntersectedTypesAvoidingStringReduction(checker, types[0], types[1]) || areIntersectedTypesAvoidingStringReduction(checker, types[1], types[0])); } - function isInsideTemplateLiteral(node, position, sourceFile) { - return isTemplateLiteralKind(node.kind) && (node.getStart(sourceFile) < position && position < node.end) || !!node.isUnterminated && position === node.end; + function getPrefixFromLexState(lexState) { + switch (lexState) { + case 3 /* InDoubleQuoteStringLiteral */: + return { prefix: '"\\\n' }; + case 2 /* InSingleQuoteStringLiteral */: + return { prefix: "'\\\n" }; + case 1 /* InMultiLineCommentTrivia */: + return { prefix: "/*\n" }; + case 4 /* InTemplateHeadOrNoSubstitutionTemplate */: + return { prefix: "`\n" }; + case 5 /* InTemplateMiddleOrTail */: + return { prefix: "}\n", pushTemplate: true }; + case 6 /* InTemplateSubstitutionPosition */: + return { prefix: "", pushTemplate: true }; + case 0 /* None */: + return { prefix: "" }; + default: + return Debug.assertNever(lexState); + } } - function isAccessibilityModifier(kind) { - switch (kind) { - case 125 /* PublicKeyword */: - case 123 /* PrivateKeyword */: - case 124 /* ProtectedKeyword */: + function isBinaryExpressionOperatorToken(token) { + switch (token) { + case 42 /* AsteriskToken */: + case 44 /* SlashToken */: + case 45 /* PercentToken */: + case 40 /* PlusToken */: + case 41 /* MinusToken */: + case 48 /* LessThanLessThanToken */: + case 49 /* GreaterThanGreaterThanToken */: + case 50 /* GreaterThanGreaterThanGreaterThanToken */: + case 30 /* LessThanToken */: + case 32 /* GreaterThanToken */: + case 33 /* LessThanEqualsToken */: + case 34 /* GreaterThanEqualsToken */: + case 104 /* InstanceOfKeyword */: + case 103 /* InKeyword */: + case 130 /* AsKeyword */: + case 152 /* SatisfiesKeyword */: + case 35 /* EqualsEqualsToken */: + case 36 /* ExclamationEqualsToken */: + case 37 /* EqualsEqualsEqualsToken */: + case 38 /* ExclamationEqualsEqualsToken */: + case 51 /* AmpersandToken */: + case 53 /* CaretToken */: + case 52 /* BarToken */: + case 56 /* AmpersandAmpersandToken */: + case 57 /* BarBarToken */: + case 75 /* BarEqualsToken */: + case 74 /* AmpersandEqualsToken */: + case 79 /* CaretEqualsToken */: + case 71 /* LessThanLessThanEqualsToken */: + case 72 /* GreaterThanGreaterThanEqualsToken */: + case 73 /* GreaterThanGreaterThanGreaterThanEqualsToken */: + case 65 /* PlusEqualsToken */: + case 66 /* MinusEqualsToken */: + case 67 /* AsteriskEqualsToken */: + case 69 /* SlashEqualsToken */: + case 70 /* PercentEqualsToken */: + case 64 /* EqualsToken */: + case 28 /* CommaToken */: + case 61 /* QuestionQuestionToken */: + case 76 /* BarBarEqualsToken */: + case 77 /* AmpersandAmpersandEqualsToken */: + case 78 /* QuestionQuestionEqualsToken */: return true; + default: + return false; } - return false; - } - function cloneCompilerOptions(options) { - const result = clone(options); - setConfigFileInOptions(result, options && options.configFile); - return result; } - function isArrayLiteralOrObjectLiteralDestructuringPattern(node) { - if (node.kind === 208 /* ArrayLiteralExpression */ || node.kind === 209 /* ObjectLiteralExpression */) { - if (node.parent.kind === 225 /* BinaryExpression */ && node.parent.left === node && node.parent.operatorToken.kind === 64 /* EqualsToken */) { - return true; - } - if (node.parent.kind === 249 /* ForOfStatement */ && node.parent.initializer === node) { - return true; - } - if (isArrayLiteralOrObjectLiteralDestructuringPattern(node.parent.kind === 302 /* PropertyAssignment */ ? node.parent.parent : node.parent)) { + function isPrefixUnaryExpressionOperatorToken(token) { + switch (token) { + case 40 /* PlusToken */: + case 41 /* MinusToken */: + case 55 /* TildeToken */: + case 54 /* ExclamationToken */: + case 46 /* PlusPlusToken */: + case 47 /* MinusMinusToken */: return true; - } + default: + return false; } - return false; - } - function isInReferenceComment(sourceFile, position) { - return isInReferenceCommentWorker( - sourceFile, - position, - /*shouldBeReference*/ - true - ); - } - function isInNonReferenceComment(sourceFile, position) { - return isInReferenceCommentWorker( - sourceFile, - position, - /*shouldBeReference*/ - false - ); - } - function isInReferenceCommentWorker(sourceFile, position, shouldBeReference) { - const range = isInComment( - sourceFile, - position, - /*tokenAtPosition*/ - void 0 - ); - return !!range && shouldBeReference === tripleSlashDirectivePrefixRegex.test(sourceFile.text.substring(range.pos, range.end)); } - function getReplacementSpanForContextToken(contextToken) { - if (!contextToken) - return void 0; - switch (contextToken.kind) { + function classFromKind(token) { + if (isKeyword(token)) { + return 3 /* keyword */; + } else if (isBinaryExpressionOperatorToken(token) || isPrefixUnaryExpressionOperatorToken(token)) { + return 5 /* operator */; + } else if (token >= 19 /* FirstPunctuation */ && token <= 79 /* LastPunctuation */) { + return 10 /* punctuation */; + } + switch (token) { + case 9 /* NumericLiteral */: + return 4 /* numericLiteral */; + case 10 /* BigIntLiteral */: + return 25 /* bigintLiteral */; case 11 /* StringLiteral */: - case 15 /* NoSubstitutionTemplateLiteral */: - return createTextSpanFromStringLiteralLikeContent(contextToken); + return 6 /* stringLiteral */; + case 14 /* RegularExpressionLiteral */: + return 7 /* regularExpressionLiteral */; + case 7 /* ConflictMarkerTrivia */: + case 3 /* MultiLineCommentTrivia */: + case 2 /* SingleLineCommentTrivia */: + return 1 /* comment */; + case 5 /* WhitespaceTrivia */: + case 4 /* NewLineTrivia */: + return 8 /* whiteSpace */; + case 80 /* Identifier */: default: - return createTextSpanFromNode(contextToken); + if (isTemplateLiteralKind(token)) { + return 6 /* stringLiteral */; + } + return 2 /* identifier */; } } - function createTextSpanFromNode(node, sourceFile, endNode2) { - return createTextSpanFromBounds(node.getStart(sourceFile), (endNode2 || node).getEnd()); - } - function createTextSpanFromStringLiteralLikeContent(node) { - if (node.isUnterminated) - return void 0; - return createTextSpanFromBounds(node.getStart() + 1, node.getEnd() - 1); - } - function createTextRangeFromNode(node, sourceFile) { - return createRange(node.getStart(sourceFile), node.end); - } - function createTextSpanFromRange(range) { - return createTextSpanFromBounds(range.pos, range.end); - } - function createTextRangeFromSpan(span) { - return createRange(span.start, span.start + span.length); - } - function createTextChangeFromStartLength(start, length2, newText) { - return createTextChange(createTextSpan(start, length2), newText); - } - function createTextChange(span, newText) { - return { span, newText }; - } - function isTypeKeyword(kind) { - return contains(typeKeywords, kind); - } - function isTypeKeywordToken(node) { - return node.kind === 156 /* TypeKeyword */; - } - function isTypeKeywordTokenOrIdentifier(node) { - return isTypeKeywordToken(node) || isIdentifier(node) && node.text === "type"; - } - function isExternalModuleSymbol(moduleSymbol) { - return !!(moduleSymbol.flags & 1536 /* Module */) && moduleSymbol.name.charCodeAt(0) === 34 /* doubleQuote */; - } - function nodeSeenTracker() { - const seen = []; - return (node) => { - const id = getNodeId(node); - return !seen[id] && (seen[id] = true); - }; - } - function getSnapshotText(snap) { - return snap.getText(0, snap.getLength()); + function getSemanticClassifications(typeChecker, cancellationToken, sourceFile, classifiableNames, span) { + return convertClassificationsToSpans(getEncodedSemanticClassifications(typeChecker, cancellationToken, sourceFile, classifiableNames, span)); } - function repeatString(str, count) { - let result = ""; - for (let i = 0; i < count; i++) { - result += str; + function checkForClassificationCancellation(cancellationToken, kind) { + switch (kind) { + case 267 /* ModuleDeclaration */: + case 263 /* ClassDeclaration */: + case 264 /* InterfaceDeclaration */: + case 262 /* FunctionDeclaration */: + case 231 /* ClassExpression */: + case 218 /* FunctionExpression */: + case 219 /* ArrowFunction */: + cancellationToken.throwIfCancellationRequested(); } - return result; - } - function skipConstraint(type) { - return type.isTypeParameter() ? type.getConstraint() || type : type; - } - function getNameFromPropertyName(name) { - return name.kind === 166 /* ComputedPropertyName */ ? isStringOrNumericLiteralLike(name.expression) ? name.expression.text : void 0 : isPrivateIdentifier(name) ? idText(name) : getTextOfIdentifierOrLiteral(name); - } - function programContainsModules(program) { - return program.getSourceFiles().some((s) => !s.isDeclarationFile && !program.isSourceFileFromExternalLibrary(s) && !!(s.externalModuleIndicator || s.commonJsModuleIndicator)); - } - function programContainsEsModules(program) { - return program.getSourceFiles().some((s) => !s.isDeclarationFile && !program.isSourceFileFromExternalLibrary(s) && !!s.externalModuleIndicator); - } - function compilerOptionsIndicateEsModules(compilerOptions) { - return !!compilerOptions.module || getEmitScriptTarget(compilerOptions) >= 2 /* ES2015 */ || !!compilerOptions.noEmit; - } - function createModuleSpecifierResolutionHost(program, host) { - return { - fileExists: (fileName) => program.fileExists(fileName), - getCurrentDirectory: () => host.getCurrentDirectory(), - readFile: maybeBind(host, host.readFile), - useCaseSensitiveFileNames: maybeBind(host, host.useCaseSensitiveFileNames), - getSymlinkCache: maybeBind(host, host.getSymlinkCache) || program.getSymlinkCache, - getModuleSpecifierCache: maybeBind(host, host.getModuleSpecifierCache), - getPackageJsonInfoCache: () => { - var _a; - return (_a = program.getModuleResolutionCache()) == null ? void 0 : _a.getPackageJsonInfoCache(); - }, - getGlobalTypingsCacheLocation: maybeBind(host, host.getGlobalTypingsCacheLocation), - redirectTargetsMap: program.redirectTargetsMap, - getProjectReferenceRedirect: (fileName) => program.getProjectReferenceRedirect(fileName), - isSourceOfProjectReferenceRedirect: (fileName) => program.isSourceOfProjectReferenceRedirect(fileName), - getNearestAncestorDirectoryWithPackageJson: maybeBind(host, host.getNearestAncestorDirectoryWithPackageJson), - getFileIncludeReasons: () => program.getFileIncludeReasons() - }; - } - function getModuleSpecifierResolverHost(program, host) { - return { - ...createModuleSpecifierResolutionHost(program, host), - getCommonSourceDirectory: () => program.getCommonSourceDirectory() - }; - } - function moduleResolutionUsesNodeModules(moduleResolution) { - return moduleResolution === 2 /* Node10 */ || moduleResolution >= 3 /* Node16 */ && moduleResolution <= 99 /* NodeNext */ || moduleResolution === 100 /* Bundler */; - } - function makeImportIfNecessary(defaultImport, namedImports, moduleSpecifier, quotePreference) { - return defaultImport || namedImports && namedImports.length ? makeImport(defaultImport, namedImports, moduleSpecifier, quotePreference) : void 0; - } - function makeImport(defaultImport, namedImports, moduleSpecifier, quotePreference, isTypeOnly) { - return factory.createImportDeclaration( - /*modifiers*/ - void 0, - defaultImport || namedImports ? factory.createImportClause(!!isTypeOnly, defaultImport, namedImports && namedImports.length ? factory.createNamedImports(namedImports) : void 0) : void 0, - typeof moduleSpecifier === "string" ? makeStringLiteral(moduleSpecifier, quotePreference) : moduleSpecifier, - /*assertClause*/ - void 0 - ); - } - function makeStringLiteral(text, quotePreference) { - return factory.createStringLiteral(text, quotePreference === 0 /* Single */); } - function quotePreferenceFromString(str, sourceFile) { - return isStringDoubleQuoted(str, sourceFile) ? 1 /* Double */ : 0 /* Single */; + function getEncodedSemanticClassifications(typeChecker, cancellationToken, sourceFile, classifiableNames, span) { + const spans = []; + sourceFile.forEachChild(function cb(node) { + if (!node || !textSpanIntersectsWith(span, node.pos, node.getFullWidth())) { + return; + } + checkForClassificationCancellation(cancellationToken, node.kind); + if (isIdentifier(node) && !nodeIsMissing(node) && classifiableNames.has(node.escapedText)) { + const symbol = typeChecker.getSymbolAtLocation(node); + const type = symbol && classifySymbol(symbol, getMeaningFromLocation(node), typeChecker); + if (type) { + pushClassification(node.getStart(sourceFile), node.getEnd(), type); + } + } + node.forEachChild(cb); + }); + return { spans, endOfLineState: 0 /* None */ }; + function pushClassification(start, end, type) { + const length2 = end - start; + Debug.assert(length2 > 0, `Classification had non-positive length of ${length2}`); + spans.push(start); + spans.push(length2); + spans.push(type); + } } - function getQuotePreference(sourceFile, preferences) { - if (preferences.quotePreference && preferences.quotePreference !== "auto") { - return preferences.quotePreference === "single" ? 0 /* Single */ : 1 /* Double */; + function classifySymbol(symbol, meaningAtPosition, checker) { + const flags = symbol.getFlags(); + if ((flags & 2885600 /* Classifiable */) === 0 /* None */) { + return void 0; + } else if (flags & 32 /* Class */) { + return 11 /* className */; + } else if (flags & 384 /* Enum */) { + return 12 /* enumName */; + } else if (flags & 524288 /* TypeAlias */) { + return 16 /* typeAliasName */; + } else if (flags & 1536 /* Module */) { + return meaningAtPosition & 4 /* Namespace */ || meaningAtPosition & 1 /* Value */ && hasValueSideModule(symbol) ? 14 /* moduleName */ : void 0; + } else if (flags & 2097152 /* Alias */) { + return classifySymbol(checker.getAliasedSymbol(symbol), meaningAtPosition, checker); + } else if (meaningAtPosition & 2 /* Type */) { + return flags & 64 /* Interface */ ? 13 /* interfaceName */ : flags & 262144 /* TypeParameter */ ? 15 /* typeParameterName */ : void 0; } else { - const firstModuleSpecifier = sourceFile.imports && find(sourceFile.imports, (n) => isStringLiteral(n) && !nodeIsSynthesized(n.parent)); - return firstModuleSpecifier ? quotePreferenceFromString(firstModuleSpecifier, sourceFile) : 1 /* Double */; + return void 0; } } - function getQuoteFromPreference(qp) { - switch (qp) { - case 0 /* Single */: - return "'"; - case 1 /* Double */: - return '"'; + function hasValueSideModule(symbol) { + return some(symbol.declarations, (declaration) => isModuleDeclaration(declaration) && getModuleInstanceState(declaration) === 1 /* Instantiated */); + } + function getClassificationTypeName(type) { + switch (type) { + case 1 /* comment */: + return "comment" /* comment */; + case 2 /* identifier */: + return "identifier" /* identifier */; + case 3 /* keyword */: + return "keyword" /* keyword */; + case 4 /* numericLiteral */: + return "number" /* numericLiteral */; + case 25 /* bigintLiteral */: + return "bigint" /* bigintLiteral */; + case 5 /* operator */: + return "operator" /* operator */; + case 6 /* stringLiteral */: + return "string" /* stringLiteral */; + case 8 /* whiteSpace */: + return "whitespace" /* whiteSpace */; + case 9 /* text */: + return "text" /* text */; + case 10 /* punctuation */: + return "punctuation" /* punctuation */; + case 11 /* className */: + return "class name" /* className */; + case 12 /* enumName */: + return "enum name" /* enumName */; + case 13 /* interfaceName */: + return "interface name" /* interfaceName */; + case 14 /* moduleName */: + return "module name" /* moduleName */; + case 15 /* typeParameterName */: + return "type parameter name" /* typeParameterName */; + case 16 /* typeAliasName */: + return "type alias name" /* typeAliasName */; + case 17 /* parameterName */: + return "parameter name" /* parameterName */; + case 18 /* docCommentTagName */: + return "doc comment tag name" /* docCommentTagName */; + case 19 /* jsxOpenTagName */: + return "jsx open tag name" /* jsxOpenTagName */; + case 20 /* jsxCloseTagName */: + return "jsx close tag name" /* jsxCloseTagName */; + case 21 /* jsxSelfClosingTagName */: + return "jsx self closing tag name" /* jsxSelfClosingTagName */; + case 22 /* jsxAttribute */: + return "jsx attribute" /* jsxAttribute */; + case 23 /* jsxText */: + return "jsx text" /* jsxText */; + case 24 /* jsxAttributeStringLiteralValue */: + return "jsx attribute string literal value" /* jsxAttributeStringLiteralValue */; default: - return Debug.assertNever(qp); + return void 0; + } + } + function convertClassificationsToSpans(classifications) { + Debug.assert(classifications.spans.length % 3 === 0); + const dense = classifications.spans; + const result = []; + for (let i = 0; i < dense.length; i += 3) { + result.push({ + textSpan: createTextSpan(dense[i], dense[i + 1]), + classificationType: getClassificationTypeName(dense[i + 2]) + }); } + return result; } - function symbolNameNoDefault(symbol) { - const escaped = symbolEscapedNameNoDefault(symbol); - return escaped === void 0 ? void 0 : unescapeLeadingUnderscores(escaped); + function getSyntacticClassifications(cancellationToken, sourceFile, span) { + return convertClassificationsToSpans(getEncodedSyntacticClassifications(cancellationToken, sourceFile, span)); } - function symbolEscapedNameNoDefault(symbol) { - if (symbol.escapedName !== "default" /* Default */) { - return symbol.escapedName; + function getEncodedSyntacticClassifications(cancellationToken, sourceFile, span) { + const spanStart = span.start; + const spanLength = span.length; + const triviaScanner = createScanner( + 99 /* Latest */, + /*skipTrivia*/ + false, + sourceFile.languageVariant, + sourceFile.text + ); + const mergeConflictScanner = createScanner( + 99 /* Latest */, + /*skipTrivia*/ + false, + sourceFile.languageVariant, + sourceFile.text + ); + const result = []; + processElement(sourceFile); + return { spans: result, endOfLineState: 0 /* None */ }; + function pushClassification(start, length2, type) { + result.push(start); + result.push(length2); + result.push(type); } - return firstDefined(symbol.declarations, (decl) => { - const name = getNameOfDeclaration(decl); - return name && name.kind === 80 /* Identifier */ ? name.escapedText : void 0; - }); - } - function isModuleSpecifierLike(node) { - return isStringLiteralLike(node) && (isExternalModuleReference(node.parent) || isImportDeclaration(node.parent) || isRequireCall( - node.parent, - /*requireStringLiteralLikeArgument*/ - false - ) && node.parent.arguments[0] === node || isImportCall(node.parent) && node.parent.arguments[0] === node); - } - function isObjectBindingElementWithoutPropertyName(bindingElement) { - return isBindingElement(bindingElement) && isObjectBindingPattern(bindingElement.parent) && isIdentifier(bindingElement.name) && !bindingElement.propertyName; - } - function getPropertySymbolFromBindingElement(checker, bindingElement) { - const typeOfPattern = checker.getTypeAtLocation(bindingElement.parent); - return typeOfPattern && checker.getPropertyOfType(typeOfPattern, bindingElement.name.text); - } - function getParentNodeInSpan(node, file, span) { - if (!node) - return void 0; - while (node.parent) { - if (isSourceFile(node.parent) || !spanContainsNode(span, node.parent, file)) { - return node; + function classifyLeadingTriviaAndGetTokenStart(token) { + triviaScanner.resetTokenState(token.pos); + while (true) { + const start = triviaScanner.getTokenEnd(); + if (!couldStartTrivia(sourceFile.text, start)) { + return start; + } + const kind = triviaScanner.scan(); + const end = triviaScanner.getTokenEnd(); + const width = end - start; + if (!isTrivia(kind)) { + return start; + } + switch (kind) { + case 4 /* NewLineTrivia */: + case 5 /* WhitespaceTrivia */: + continue; + case 2 /* SingleLineCommentTrivia */: + case 3 /* MultiLineCommentTrivia */: + classifyComment(token, kind, start, width); + triviaScanner.resetTokenState(end); + continue; + case 7 /* ConflictMarkerTrivia */: + const text = sourceFile.text; + const ch = text.charCodeAt(start); + if (ch === 60 /* lessThan */ || ch === 62 /* greaterThan */) { + pushClassification(start, width, 1 /* comment */); + continue; + } + Debug.assert(ch === 124 /* bar */ || ch === 61 /* equals */); + classifyDisabledMergeCode(text, start, end); + break; + case 6 /* ShebangTrivia */: + break; + default: + Debug.assertNever(kind); + } } - node = node.parent; } - } - function spanContainsNode(span, node, file) { - return textSpanContainsPosition(span, node.getStart(file)) && node.getEnd() <= textSpanEnd(span); - } - function findModifier(node, kind) { - return canHaveModifiers(node) ? find(node.modifiers, (m) => m.kind === kind) : void 0; - } - function insertImports(changes, sourceFile, imports, blankLineBetween, preferences) { - const decl = isArray(imports) ? imports[0] : imports; - const importKindPredicate = decl.kind === 242 /* VariableStatement */ ? isRequireVariableStatement : isAnyImportSyntax; - const existingImportStatements = filter(sourceFile.statements, importKindPredicate); - let sortKind = isArray(imports) ? ts_OrganizeImports_exports.detectImportDeclarationSorting(imports, preferences) : 3 /* Both */; - const comparer = ts_OrganizeImports_exports.getOrganizeImportsComparer(preferences, sortKind === 2 /* CaseInsensitive */); - const sortedNewImports = isArray(imports) ? stableSort(imports, (a, b) => ts_OrganizeImports_exports.compareImportsOrRequireStatements(a, b, comparer)) : [imports]; - if (!existingImportStatements.length) { - changes.insertNodesAtTopOfFile(sourceFile, sortedNewImports, blankLineBetween); - } else if (existingImportStatements && (sortKind = ts_OrganizeImports_exports.detectImportDeclarationSorting(existingImportStatements, preferences))) { - const comparer2 = ts_OrganizeImports_exports.getOrganizeImportsComparer(preferences, sortKind === 2 /* CaseInsensitive */); - for (const newImport of sortedNewImports) { - const insertionIndex = ts_OrganizeImports_exports.getImportDeclarationInsertionIndex(existingImportStatements, newImport, comparer2); - if (insertionIndex === 0) { - const options = existingImportStatements[0] === sourceFile.statements[0] ? { leadingTriviaOption: ts_textChanges_exports.LeadingTriviaOption.Exclude } : {}; - changes.insertNodeBefore( - sourceFile, - existingImportStatements[0], - newImport, - /*blankLineBetween*/ - false, - options - ); - } else { - const prevImport = existingImportStatements[insertionIndex - 1]; - changes.insertNodeAfter(sourceFile, prevImport, newImport); + function classifyComment(token, kind, start, width) { + if (kind === 3 /* MultiLineCommentTrivia */) { + const docCommentAndDiagnostics = parseIsolatedJSDocComment(sourceFile.text, start, width); + if (docCommentAndDiagnostics && docCommentAndDiagnostics.jsDoc) { + setParent(docCommentAndDiagnostics.jsDoc, token); + classifyJSDocComment(docCommentAndDiagnostics.jsDoc); + return; + } + } else if (kind === 2 /* SingleLineCommentTrivia */) { + if (tryClassifyTripleSlashComment(start, width)) { + return; } } - } else { - const lastExistingImport = lastOrUndefined(existingImportStatements); - if (lastExistingImport) { - changes.insertNodesAfter(sourceFile, lastExistingImport, sortedNewImports); - } else { - changes.insertNodesAtTopOfFile(sourceFile, sortedNewImports, blankLineBetween); - } + pushCommentRange(start, width); } - } - function getTypeKeywordOfTypeOnlyImport(importClause, sourceFile) { - Debug.assert(importClause.isTypeOnly); - return cast(importClause.getChildAt(0, sourceFile), isTypeKeywordToken); - } - function textSpansEqual(a, b) { - return !!a && !!b && a.start === b.start && a.length === b.length; - } - function documentSpansEqual(a, b) { - return a.fileName === b.fileName && textSpansEqual(a.textSpan, b.textSpan); - } - function forEachUnique(array, callback) { - if (array) { - for (let i = 0; i < array.length; i++) { - if (array.indexOf(array[i]) === i) { - const result = callback(array[i], i); - if (result) { - return result; + function pushCommentRange(start, width) { + pushClassification(start, width, 1 /* comment */); + } + function classifyJSDocComment(docComment) { + var _a, _b, _c, _d, _e, _f, _g, _h; + let pos = docComment.pos; + if (docComment.tags) { + for (const tag of docComment.tags) { + if (tag.pos !== pos) { + pushCommentRange(pos, tag.pos - pos); + } + pushClassification(tag.pos, 1, 10 /* punctuation */); + pushClassification(tag.tagName.pos, tag.tagName.end - tag.tagName.pos, 18 /* docCommentTagName */); + pos = tag.tagName.end; + let commentStart = tag.tagName.end; + switch (tag.kind) { + case 348 /* JSDocParameterTag */: + const param = tag; + processJSDocParameterTag(param); + commentStart = param.isNameFirst && ((_a = param.typeExpression) == null ? void 0 : _a.end) || param.name.end; + break; + case 355 /* JSDocPropertyTag */: + const prop = tag; + commentStart = prop.isNameFirst && ((_b = prop.typeExpression) == null ? void 0 : _b.end) || prop.name.end; + break; + case 352 /* JSDocTemplateTag */: + processJSDocTemplateTag(tag); + pos = tag.end; + commentStart = tag.typeParameters.end; + break; + case 353 /* JSDocTypedefTag */: + const type = tag; + commentStart = ((_c = type.typeExpression) == null ? void 0 : _c.kind) === 316 /* JSDocTypeExpression */ && ((_d = type.fullName) == null ? void 0 : _d.end) || ((_e = type.typeExpression) == null ? void 0 : _e.end) || commentStart; + break; + case 345 /* JSDocCallbackTag */: + commentStart = tag.typeExpression.end; + break; + case 351 /* JSDocTypeTag */: + processElement(tag.typeExpression); + pos = tag.end; + commentStart = tag.typeExpression.end; + break; + case 350 /* JSDocThisTag */: + case 347 /* JSDocEnumTag */: + commentStart = tag.typeExpression.end; + break; + case 349 /* JSDocReturnTag */: + processElement(tag.typeExpression); + pos = tag.end; + commentStart = ((_f = tag.typeExpression) == null ? void 0 : _f.end) || commentStart; + break; + case 354 /* JSDocSeeTag */: + commentStart = ((_g = tag.name) == null ? void 0 : _g.end) || commentStart; + break; + case 335 /* JSDocAugmentsTag */: + case 336 /* JSDocImplementsTag */: + commentStart = tag.class.end; + break; + case 356 /* JSDocThrowsTag */: + processElement(tag.typeExpression); + pos = tag.end; + commentStart = ((_h = tag.typeExpression) == null ? void 0 : _h.end) || commentStart; + break; + } + if (typeof tag.comment === "object") { + pushCommentRange(tag.comment.pos, tag.comment.end - tag.comment.pos); + } else if (typeof tag.comment === "string") { + pushCommentRange(commentStart, tag.end - commentStart); } } } + if (pos !== docComment.end) { + pushCommentRange(pos, docComment.end - pos); + } + return; + function processJSDocParameterTag(tag) { + if (tag.isNameFirst) { + pushCommentRange(pos, tag.name.pos - pos); + pushClassification(tag.name.pos, tag.name.end - tag.name.pos, 17 /* parameterName */); + pos = tag.name.end; + } + if (tag.typeExpression) { + pushCommentRange(pos, tag.typeExpression.pos - pos); + processElement(tag.typeExpression); + pos = tag.typeExpression.end; + } + if (!tag.isNameFirst) { + pushCommentRange(pos, tag.name.pos - pos); + pushClassification(tag.name.pos, tag.name.end - tag.name.pos, 17 /* parameterName */); + pos = tag.name.end; + } + } } - return void 0; - } - function isTextWhiteSpaceLike(text, startPos, endPos) { - for (let i = startPos; i < endPos; i++) { - if (!isWhiteSpaceLike(text.charCodeAt(i))) { + function tryClassifyTripleSlashComment(start, width) { + const tripleSlashXMLCommentRegEx = /^(\/\/\/\s*)(<)(?:(\S+)((?:[^/]|\/[^>])*)(\/>)?)?/im; + const attributeRegex = /(\s)(\S+)(\s*)(=)(\s*)('[^']+'|"[^"]+")/img; + const text = sourceFile.text.substr(start, width); + const match = tripleSlashXMLCommentRegEx.exec(text); + if (!match) { return false; } - } - return true; - } - function getMappedLocation(location, sourceMapper, fileExists) { - const mapsTo = sourceMapper.tryGetSourcePosition(location); - return mapsTo && (!fileExists || fileExists(normalizePath(mapsTo.fileName)) ? mapsTo : void 0); - } - function getMappedDocumentSpan(documentSpan, sourceMapper, fileExists) { - const { fileName, textSpan } = documentSpan; - const newPosition = getMappedLocation({ fileName, pos: textSpan.start }, sourceMapper, fileExists); - if (!newPosition) - return void 0; - const newEndPosition = getMappedLocation({ fileName, pos: textSpan.start + textSpan.length }, sourceMapper, fileExists); - const newLength = newEndPosition ? newEndPosition.pos - newPosition.pos : textSpan.length; - return { - fileName: newPosition.fileName, - textSpan: { - start: newPosition.pos, - length: newLength - }, - originalFileName: documentSpan.fileName, - originalTextSpan: documentSpan.textSpan, - contextSpan: getMappedContextSpan(documentSpan, sourceMapper, fileExists), - originalContextSpan: documentSpan.contextSpan - }; - } - function getMappedContextSpan(documentSpan, sourceMapper, fileExists) { - const contextSpanStart = documentSpan.contextSpan && getMappedLocation( - { fileName: documentSpan.fileName, pos: documentSpan.contextSpan.start }, - sourceMapper, - fileExists - ); - const contextSpanEnd = documentSpan.contextSpan && getMappedLocation( - { fileName: documentSpan.fileName, pos: documentSpan.contextSpan.start + documentSpan.contextSpan.length }, - sourceMapper, - fileExists - ); - return contextSpanStart && contextSpanEnd ? { start: contextSpanStart.pos, length: contextSpanEnd.pos - contextSpanStart.pos } : void 0; - } - function isFirstDeclarationOfSymbolParameter(symbol) { - const declaration = symbol.declarations ? firstOrUndefined(symbol.declarations) : void 0; - return !!findAncestor(declaration, (n) => isParameter(n) ? true : isBindingElement(n) || isObjectBindingPattern(n) || isArrayBindingPattern(n) ? false : "quit"); - } - function getDisplayPartWriter() { - const absoluteMaximumLength = defaultMaximumTruncationLength * 10; - let displayParts; - let lineStart; - let indent2; - let length2; - resetWriter(); - const unknownWrite = (text) => writeKind(text, 17 /* text */); - return { - displayParts: () => { - const finalText = displayParts.length && displayParts[displayParts.length - 1].text; - if (length2 > absoluteMaximumLength && finalText && finalText !== "...") { - if (!isWhiteSpaceLike(finalText.charCodeAt(finalText.length - 1))) { - displayParts.push(displayPart(" ", 16 /* space */)); - } - displayParts.push(displayPart("...", 15 /* punctuation */)); + if (!match[3] || !(match[3] in commentPragmas)) { + return false; + } + let pos = start; + pushCommentRange(pos, match[1].length); + pos += match[1].length; + pushClassification(pos, match[2].length, 10 /* punctuation */); + pos += match[2].length; + pushClassification(pos, match[3].length, 21 /* jsxSelfClosingTagName */); + pos += match[3].length; + const attrText = match[4]; + let attrPos = pos; + while (true) { + const attrMatch = attributeRegex.exec(attrText); + if (!attrMatch) { + break; } - return displayParts; - }, - writeKeyword: (text) => writeKind(text, 5 /* keyword */), - writeOperator: (text) => writeKind(text, 12 /* operator */), - writePunctuation: (text) => writeKind(text, 15 /* punctuation */), - writeTrailingSemicolon: (text) => writeKind(text, 15 /* punctuation */), - writeSpace: (text) => writeKind(text, 16 /* space */), - writeStringLiteral: (text) => writeKind(text, 8 /* stringLiteral */), - writeParameter: (text) => writeKind(text, 13 /* parameterName */), - writeProperty: (text) => writeKind(text, 14 /* propertyName */), - writeLiteral: (text) => writeKind(text, 8 /* stringLiteral */), - writeSymbol, - writeLine, - write: unknownWrite, - writeComment: unknownWrite, - getText: () => "", - getTextPos: () => 0, - getColumn: () => 0, - getLine: () => 0, - isAtStartOfLine: () => false, - hasTrailingWhitespace: () => false, - hasTrailingComment: () => false, - rawWrite: notImplemented, - getIndent: () => indent2, - increaseIndent: () => { - indent2++; - }, - decreaseIndent: () => { - indent2--; - }, - clear: resetWriter - }; - function writeIndent() { - if (length2 > absoluteMaximumLength) - return; - if (lineStart) { - const indentString = getIndentString(indent2); - if (indentString) { - length2 += indentString.length; - displayParts.push(displayPart(indentString, 16 /* space */)); + const newAttrPos = pos + attrMatch.index + attrMatch[1].length; + if (newAttrPos > attrPos) { + pushCommentRange(attrPos, newAttrPos - attrPos); + attrPos = newAttrPos; } - lineStart = false; + pushClassification(attrPos, attrMatch[2].length, 22 /* jsxAttribute */); + attrPos += attrMatch[2].length; + if (attrMatch[3].length) { + pushCommentRange(attrPos, attrMatch[3].length); + attrPos += attrMatch[3].length; + } + pushClassification(attrPos, attrMatch[4].length, 5 /* operator */); + attrPos += attrMatch[4].length; + if (attrMatch[5].length) { + pushCommentRange(attrPos, attrMatch[5].length); + attrPos += attrMatch[5].length; + } + pushClassification(attrPos, attrMatch[6].length, 24 /* jsxAttributeStringLiteralValue */); + attrPos += attrMatch[6].length; + } + pos += match[4].length; + if (pos > attrPos) { + pushCommentRange(attrPos, pos - attrPos); + } + if (match[5]) { + pushClassification(pos, match[5].length, 10 /* punctuation */); + pos += match[5].length; + } + const end = start + width; + if (pos < end) { + pushCommentRange(pos, end - pos); } + return true; } - function writeKind(text, kind) { - if (length2 > absoluteMaximumLength) - return; - writeIndent(); - length2 += text.length; - displayParts.push(displayPart(text, kind)); + function processJSDocTemplateTag(tag) { + for (const child of tag.getChildren()) { + processElement(child); + } } - function writeSymbol(text, symbol) { - if (length2 > absoluteMaximumLength) - return; - writeIndent(); - length2 += text.length; - displayParts.push(symbolPart(text, symbol)); + function classifyDisabledMergeCode(text, start, end) { + let i; + for (i = start; i < end; i++) { + if (isLineBreak(text.charCodeAt(i))) { + break; + } + } + pushClassification(start, i - start, 1 /* comment */); + mergeConflictScanner.resetTokenState(i); + while (mergeConflictScanner.getTokenEnd() < end) { + classifyDisabledCodeToken(); + } } - function writeLine() { - if (length2 > absoluteMaximumLength) - return; - length2 += 1; - displayParts.push(lineBreakPart()); - lineStart = true; + function classifyDisabledCodeToken() { + const start = mergeConflictScanner.getTokenEnd(); + const tokenKind = mergeConflictScanner.scan(); + const end = mergeConflictScanner.getTokenEnd(); + const type = classifyTokenType(tokenKind); + if (type) { + pushClassification(start, end - start, type); + } } - function resetWriter() { - displayParts = []; - lineStart = true; - indent2 = 0; - length2 = 0; + function tryClassifyNode(node) { + if (isJSDoc(node)) { + return true; + } + if (nodeIsMissing(node)) { + return true; + } + const classifiedElementName = tryClassifyJsxElementName(node); + if (!isToken(node) && node.kind !== 12 /* JsxText */ && classifiedElementName === void 0) { + return false; + } + const tokenStart = node.kind === 12 /* JsxText */ ? node.pos : classifyLeadingTriviaAndGetTokenStart(node); + const tokenWidth = node.end - tokenStart; + Debug.assert(tokenWidth >= 0); + if (tokenWidth > 0) { + const type = classifiedElementName || classifyTokenType(node.kind, node); + if (type) { + pushClassification(tokenStart, tokenWidth, type); + } + } + return true; } - } - function symbolPart(text, symbol) { - return displayPart(text, displayPartKind(symbol)); - function displayPartKind(symbol2) { - const flags = symbol2.flags; - if (flags & 3 /* Variable */) { - return isFirstDeclarationOfSymbolParameter(symbol2) ? 13 /* parameterName */ : 9 /* localName */; + function tryClassifyJsxElementName(token) { + switch (token.parent && token.parent.kind) { + case 286 /* JsxOpeningElement */: + if (token.parent.tagName === token) { + return 19 /* jsxOpenTagName */; + } + break; + case 287 /* JsxClosingElement */: + if (token.parent.tagName === token) { + return 20 /* jsxCloseTagName */; + } + break; + case 285 /* JsxSelfClosingElement */: + if (token.parent.tagName === token) { + return 21 /* jsxSelfClosingTagName */; + } + break; + case 291 /* JsxAttribute */: + if (token.parent.name === token) { + return 22 /* jsxAttribute */; + } + break; } - if (flags & 4 /* Property */) - return 14 /* propertyName */; - if (flags & 32768 /* GetAccessor */) - return 14 /* propertyName */; - if (flags & 65536 /* SetAccessor */) - return 14 /* propertyName */; - if (flags & 8 /* EnumMember */) - return 19 /* enumMemberName */; - if (flags & 16 /* Function */) - return 20 /* functionName */; - if (flags & 32 /* Class */) - return 1 /* className */; - if (flags & 64 /* Interface */) - return 4 /* interfaceName */; - if (flags & 384 /* Enum */) - return 2 /* enumName */; - if (flags & 1536 /* Module */) - return 11 /* moduleName */; - if (flags & 8192 /* Method */) - return 10 /* methodName */; - if (flags & 262144 /* TypeParameter */) - return 18 /* typeParameterName */; - if (flags & 524288 /* TypeAlias */) - return 0 /* aliasName */; - if (flags & 2097152 /* Alias */) - return 0 /* aliasName */; - return 17 /* text */; + return void 0; } - } - function displayPart(text, kind) { - return { text, kind: SymbolDisplayPartKind[kind] }; - } - function spacePart() { - return displayPart(" ", 16 /* space */); - } - function keywordPart(kind) { - return displayPart(tokenToString(kind), 5 /* keyword */); - } - function punctuationPart(kind) { - return displayPart(tokenToString(kind), 15 /* punctuation */); - } - function operatorPart(kind) { - return displayPart(tokenToString(kind), 12 /* operator */); - } - function parameterNamePart(text) { - return displayPart(text, 13 /* parameterName */); - } - function propertyNamePart(text) { - return displayPart(text, 14 /* propertyName */); - } - function textOrKeywordPart(text) { - const kind = stringToToken(text); - return kind === void 0 ? textPart(text) : keywordPart(kind); - } - function textPart(text) { - return displayPart(text, 17 /* text */); - } - function typeAliasNamePart(text) { - return displayPart(text, 0 /* aliasName */); - } - function typeParameterNamePart(text) { - return displayPart(text, 18 /* typeParameterName */); - } - function linkTextPart(text) { - return displayPart(text, 24 /* linkText */); - } - function linkNamePart(text, target) { - return { - text, - kind: SymbolDisplayPartKind[23 /* linkName */], - target: { - fileName: getSourceFileOfNode(target).fileName, - textSpan: createTextSpanFromNode(target) + function classifyTokenType(tokenKind, token) { + if (isKeyword(tokenKind)) { + return 3 /* keyword */; } - }; - } - function linkPart(text) { - return displayPart(text, 22 /* link */); - } - function buildLinkParts(link, checker) { - var _a; - const prefix = isJSDocLink(link) ? "link" : isJSDocLinkCode(link) ? "linkcode" : "linkplain"; - const parts = [linkPart(`{@${prefix} `)]; - if (!link.name) { - if (link.text) { - parts.push(linkTextPart(link.text)); + if (tokenKind === 30 /* LessThanToken */ || tokenKind === 32 /* GreaterThanToken */) { + if (token && getTypeArgumentOrTypeParameterList(token.parent)) { + return 10 /* punctuation */; + } } - } else { - const symbol = checker == null ? void 0 : checker.getSymbolAtLocation(link.name); - const suffix = findLinkNameEnd(link.text); - const name = getTextOfNode(link.name) + link.text.slice(0, suffix); - const text = skipSeparatorFromLinkText(link.text.slice(suffix)); - const decl = (symbol == null ? void 0 : symbol.valueDeclaration) || ((_a = symbol == null ? void 0 : symbol.declarations) == null ? void 0 : _a[0]); - if (decl) { - parts.push(linkNamePart(name, decl)); - if (text) - parts.push(linkTextPart(text)); - } else { - parts.push(linkTextPart(name + (suffix ? "" : " ") + text)); + if (isPunctuation(tokenKind)) { + if (token) { + const parent2 = token.parent; + if (tokenKind === 64 /* EqualsToken */) { + if (parent2.kind === 260 /* VariableDeclaration */ || parent2.kind === 172 /* PropertyDeclaration */ || parent2.kind === 169 /* Parameter */ || parent2.kind === 291 /* JsxAttribute */) { + return 5 /* operator */; + } + } + if (parent2.kind === 226 /* BinaryExpression */ || parent2.kind === 224 /* PrefixUnaryExpression */ || parent2.kind === 225 /* PostfixUnaryExpression */ || parent2.kind === 227 /* ConditionalExpression */) { + return 5 /* operator */; + } + } + return 10 /* punctuation */; + } else if (tokenKind === 9 /* NumericLiteral */) { + return 4 /* numericLiteral */; + } else if (tokenKind === 10 /* BigIntLiteral */) { + return 25 /* bigintLiteral */; + } else if (tokenKind === 11 /* StringLiteral */) { + return token && token.parent.kind === 291 /* JsxAttribute */ ? 24 /* jsxAttributeStringLiteralValue */ : 6 /* stringLiteral */; + } else if (tokenKind === 14 /* RegularExpressionLiteral */) { + return 6 /* stringLiteral */; + } else if (isTemplateLiteralKind(tokenKind)) { + return 6 /* stringLiteral */; + } else if (tokenKind === 12 /* JsxText */) { + return 23 /* jsxText */; + } else if (tokenKind === 80 /* Identifier */) { + if (token) { + switch (token.parent.kind) { + case 263 /* ClassDeclaration */: + if (token.parent.name === token) { + return 11 /* className */; + } + return; + case 168 /* TypeParameter */: + if (token.parent.name === token) { + return 15 /* typeParameterName */; + } + return; + case 264 /* InterfaceDeclaration */: + if (token.parent.name === token) { + return 13 /* interfaceName */; + } + return; + case 266 /* EnumDeclaration */: + if (token.parent.name === token) { + return 12 /* enumName */; + } + return; + case 267 /* ModuleDeclaration */: + if (token.parent.name === token) { + return 14 /* moduleName */; + } + return; + case 169 /* Parameter */: + if (token.parent.name === token) { + return isThisIdentifier(token) ? 3 /* keyword */ : 17 /* parameterName */; + } + return; + } + if (isConstTypeReference(token.parent)) { + return 3 /* keyword */; + } + } + return 2 /* identifier */; + } + } + function processElement(element) { + if (!element) { + return; + } + if (decodedTextSpanIntersectsWith(spanStart, spanLength, element.pos, element.getFullWidth())) { + checkForClassificationCancellation(cancellationToken, element.kind); + for (const child of element.getChildren(sourceFile)) { + if (!tryClassifyNode(child)) { + processElement(child); + } + } } } - parts.push(linkPart("}")); - return parts; } - function skipSeparatorFromLinkText(text) { - let pos = 0; - if (text.charCodeAt(pos++) === 124 /* bar */) { - while (pos < text.length && text.charCodeAt(pos) === 32 /* space */) - pos++; - return text.slice(pos); - } - return text; + var noRegexTable; + var init_classifier = __esm({ + "src/services/classifier.ts"() { + "use strict"; + init_ts4(); + noRegexTable = arrayToNumericMap( + [ + 80 /* Identifier */, + 11 /* StringLiteral */, + 9 /* NumericLiteral */, + 10 /* BigIntLiteral */, + 14 /* RegularExpressionLiteral */, + 110 /* ThisKeyword */, + 46 /* PlusPlusToken */, + 47 /* MinusMinusToken */, + 22 /* CloseParenToken */, + 24 /* CloseBracketToken */, + 20 /* CloseBraceToken */, + 112 /* TrueKeyword */, + 97 /* FalseKeyword */ + ], + (token) => token, + () => true + ); + } + }); + + // src/services/documentHighlights.ts + var DocumentHighlights; + var init_documentHighlights = __esm({ + "src/services/documentHighlights.ts"() { + "use strict"; + init_ts4(); + ((DocumentHighlights3) => { + function getDocumentHighlights(program, cancellationToken, sourceFile, position, sourceFilesToSearch) { + const node = getTouchingPropertyName(sourceFile, position); + if (node.parent && (isJsxOpeningElement(node.parent) && node.parent.tagName === node || isJsxClosingElement(node.parent))) { + const { openingElement, closingElement } = node.parent.parent; + const highlightSpans = [openingElement, closingElement].map(({ tagName }) => getHighlightSpanForNode(tagName, sourceFile)); + return [{ fileName: sourceFile.fileName, highlightSpans }]; + } + return getSemanticDocumentHighlights(position, node, program, cancellationToken, sourceFilesToSearch) || getSyntacticDocumentHighlights(node, sourceFile); + } + DocumentHighlights3.getDocumentHighlights = getDocumentHighlights; + function getHighlightSpanForNode(node, sourceFile) { + return { + fileName: sourceFile.fileName, + textSpan: createTextSpanFromNode(node, sourceFile), + kind: "none" /* none */ + }; + } + function getSemanticDocumentHighlights(position, node, program, cancellationToken, sourceFilesToSearch) { + const sourceFilesSet = new Set(sourceFilesToSearch.map((f) => f.fileName)); + const referenceEntries = ts_FindAllReferences_exports.getReferenceEntriesForNode( + position, + node, + program, + sourceFilesToSearch, + cancellationToken, + /*options*/ + void 0, + sourceFilesSet + ); + if (!referenceEntries) + return void 0; + const map2 = arrayToMultiMap(referenceEntries.map(ts_FindAllReferences_exports.toHighlightSpan), (e) => e.fileName, (e) => e.span); + const getCanonicalFileName = createGetCanonicalFileName(program.useCaseSensitiveFileNames()); + return arrayFrom(mapDefinedIterator(map2.entries(), ([fileName, highlightSpans]) => { + if (!sourceFilesSet.has(fileName)) { + if (!program.redirectTargetsMap.has(toPath(fileName, program.getCurrentDirectory(), getCanonicalFileName))) { + return void 0; + } + const redirectTarget = program.getSourceFile(fileName); + const redirect = find(sourceFilesToSearch, (f) => !!f.redirectInfo && f.redirectInfo.redirectTarget === redirectTarget); + fileName = redirect.fileName; + Debug.assert(sourceFilesSet.has(fileName)); + } + return { fileName, highlightSpans }; + })); + } + function getSyntacticDocumentHighlights(node, sourceFile) { + const highlightSpans = getHighlightSpans(node, sourceFile); + return highlightSpans && [{ fileName: sourceFile.fileName, highlightSpans }]; + } + function getHighlightSpans(node, sourceFile) { + switch (node.kind) { + case 101 /* IfKeyword */: + case 93 /* ElseKeyword */: + return isIfStatement(node.parent) ? getIfElseOccurrences(node.parent, sourceFile) : void 0; + case 107 /* ReturnKeyword */: + return useParent(node.parent, isReturnStatement, getReturnOccurrences); + case 111 /* ThrowKeyword */: + return useParent(node.parent, isThrowStatement, getThrowOccurrences); + case 113 /* TryKeyword */: + case 85 /* CatchKeyword */: + case 98 /* FinallyKeyword */: + const tryStatement = node.kind === 85 /* CatchKeyword */ ? node.parent.parent : node.parent; + return useParent(tryStatement, isTryStatement, getTryCatchFinallyOccurrences); + case 109 /* SwitchKeyword */: + return useParent(node.parent, isSwitchStatement, getSwitchCaseDefaultOccurrences); + case 84 /* CaseKeyword */: + case 90 /* DefaultKeyword */: { + if (isDefaultClause(node.parent) || isCaseClause(node.parent)) { + return useParent(node.parent.parent.parent, isSwitchStatement, getSwitchCaseDefaultOccurrences); + } + return void 0; + } + case 83 /* BreakKeyword */: + case 88 /* ContinueKeyword */: + return useParent(node.parent, isBreakOrContinueStatement, getBreakOrContinueStatementOccurrences); + case 99 /* ForKeyword */: + case 117 /* WhileKeyword */: + case 92 /* DoKeyword */: + return useParent(node.parent, (n) => isIterationStatement( + n, + /*lookInLabeledStatements*/ + true + ), getLoopBreakContinueOccurrences); + case 137 /* ConstructorKeyword */: + return getFromAllDeclarations(isConstructorDeclaration, [137 /* ConstructorKeyword */]); + case 139 /* GetKeyword */: + case 153 /* SetKeyword */: + return getFromAllDeclarations(isAccessor, [139 /* GetKeyword */, 153 /* SetKeyword */]); + case 135 /* AwaitKeyword */: + return useParent(node.parent, isAwaitExpression, getAsyncAndAwaitOccurrences); + case 134 /* AsyncKeyword */: + return highlightSpans(getAsyncAndAwaitOccurrences(node)); + case 127 /* YieldKeyword */: + return highlightSpans(getYieldOccurrences(node)); + case 103 /* InKeyword */: + return void 0; + default: + return isModifierKind(node.kind) && (isDeclaration(node.parent) || isVariableStatement(node.parent)) ? highlightSpans(getModifierOccurrences(node.kind, node.parent)) : void 0; + } + function getFromAllDeclarations(nodeTest, keywords) { + return useParent(node.parent, nodeTest, (decl) => { + var _a; + return mapDefined((_a = tryCast(decl, canHaveSymbol)) == null ? void 0 : _a.symbol.declarations, (d) => nodeTest(d) ? find(d.getChildren(sourceFile), (c) => contains(keywords, c.kind)) : void 0); + }); + } + function useParent(node2, nodeTest, getNodes4) { + return nodeTest(node2) ? highlightSpans(getNodes4(node2, sourceFile)) : void 0; + } + function highlightSpans(nodes) { + return nodes && nodes.map((node2) => getHighlightSpanForNode(node2, sourceFile)); + } + } + function aggregateOwnedThrowStatements(node) { + if (isThrowStatement(node)) { + return [node]; + } else if (isTryStatement(node)) { + return concatenate( + node.catchClause ? aggregateOwnedThrowStatements(node.catchClause) : node.tryBlock && aggregateOwnedThrowStatements(node.tryBlock), + node.finallyBlock && aggregateOwnedThrowStatements(node.finallyBlock) + ); + } + return isFunctionLike(node) ? void 0 : flatMapChildren(node, aggregateOwnedThrowStatements); + } + function getThrowStatementOwner(throwStatement) { + let child = throwStatement; + while (child.parent) { + const parent2 = child.parent; + if (isFunctionBlock(parent2) || parent2.kind === 312 /* SourceFile */) { + return parent2; + } + if (isTryStatement(parent2) && parent2.tryBlock === child && parent2.catchClause) { + return child; + } + child = parent2; + } + return void 0; + } + function aggregateAllBreakAndContinueStatements(node) { + return isBreakOrContinueStatement(node) ? [node] : isFunctionLike(node) ? void 0 : flatMapChildren(node, aggregateAllBreakAndContinueStatements); + } + function flatMapChildren(node, cb) { + const result = []; + node.forEachChild((child) => { + const value = cb(child); + if (value !== void 0) { + result.push(...toArray(value)); + } + }); + return result; + } + function ownsBreakOrContinueStatement(owner, statement) { + const actualOwner = getBreakOrContinueOwner(statement); + return !!actualOwner && actualOwner === owner; + } + function getBreakOrContinueOwner(statement) { + return findAncestor(statement, (node) => { + switch (node.kind) { + case 255 /* SwitchStatement */: + if (statement.kind === 251 /* ContinueStatement */) { + return false; + } + case 248 /* ForStatement */: + case 249 /* ForInStatement */: + case 250 /* ForOfStatement */: + case 247 /* WhileStatement */: + case 246 /* DoStatement */: + return !statement.label || isLabeledBy(node, statement.label.escapedText); + default: + return isFunctionLike(node) && "quit"; + } + }); + } + function getModifierOccurrences(modifier, declaration) { + return mapDefined(getNodesToSearchForModifier(declaration, modifierToFlag(modifier)), (node) => findModifier(node, modifier)); + } + function getNodesToSearchForModifier(declaration, modifierFlag) { + const container = declaration.parent; + switch (container.kind) { + case 268 /* ModuleBlock */: + case 312 /* SourceFile */: + case 241 /* Block */: + case 296 /* CaseClause */: + case 297 /* DefaultClause */: + if (modifierFlag & 64 /* Abstract */ && isClassDeclaration(declaration)) { + return [...declaration.members, declaration]; + } else { + return container.statements; + } + case 176 /* Constructor */: + case 174 /* MethodDeclaration */: + case 262 /* FunctionDeclaration */: + return [...container.parameters, ...isClassLike(container.parent) ? container.parent.members : []]; + case 263 /* ClassDeclaration */: + case 231 /* ClassExpression */: + case 264 /* InterfaceDeclaration */: + case 187 /* TypeLiteral */: + const nodes = container.members; + if (modifierFlag & (7 /* AccessibilityModifier */ | 8 /* Readonly */)) { + const constructor = find(container.members, isConstructorDeclaration); + if (constructor) { + return [...nodes, ...constructor.parameters]; + } + } else if (modifierFlag & 64 /* Abstract */) { + return [...nodes, container]; + } + return nodes; + case 210 /* ObjectLiteralExpression */: + return void 0; + default: + Debug.assertNever(container, "Invalid container kind."); + } + } + function pushKeywordIf(keywordList, token, ...expected) { + if (token && contains(expected, token.kind)) { + keywordList.push(token); + return true; + } + return false; + } + function getLoopBreakContinueOccurrences(loopNode) { + const keywords = []; + if (pushKeywordIf(keywords, loopNode.getFirstToken(), 99 /* ForKeyword */, 117 /* WhileKeyword */, 92 /* DoKeyword */)) { + if (loopNode.kind === 246 /* DoStatement */) { + const loopTokens = loopNode.getChildren(); + for (let i = loopTokens.length - 1; i >= 0; i--) { + if (pushKeywordIf(keywords, loopTokens[i], 117 /* WhileKeyword */)) { + break; + } + } + } + } + forEach(aggregateAllBreakAndContinueStatements(loopNode.statement), (statement) => { + if (ownsBreakOrContinueStatement(loopNode, statement)) { + pushKeywordIf(keywords, statement.getFirstToken(), 83 /* BreakKeyword */, 88 /* ContinueKeyword */); + } + }); + return keywords; + } + function getBreakOrContinueStatementOccurrences(breakOrContinueStatement) { + const owner = getBreakOrContinueOwner(breakOrContinueStatement); + if (owner) { + switch (owner.kind) { + case 248 /* ForStatement */: + case 249 /* ForInStatement */: + case 250 /* ForOfStatement */: + case 246 /* DoStatement */: + case 247 /* WhileStatement */: + return getLoopBreakContinueOccurrences(owner); + case 255 /* SwitchStatement */: + return getSwitchCaseDefaultOccurrences(owner); + } + } + return void 0; + } + function getSwitchCaseDefaultOccurrences(switchStatement) { + const keywords = []; + pushKeywordIf(keywords, switchStatement.getFirstToken(), 109 /* SwitchKeyword */); + forEach(switchStatement.caseBlock.clauses, (clause) => { + pushKeywordIf(keywords, clause.getFirstToken(), 84 /* CaseKeyword */, 90 /* DefaultKeyword */); + forEach(aggregateAllBreakAndContinueStatements(clause), (statement) => { + if (ownsBreakOrContinueStatement(switchStatement, statement)) { + pushKeywordIf(keywords, statement.getFirstToken(), 83 /* BreakKeyword */); + } + }); + }); + return keywords; + } + function getTryCatchFinallyOccurrences(tryStatement, sourceFile) { + const keywords = []; + pushKeywordIf(keywords, tryStatement.getFirstToken(), 113 /* TryKeyword */); + if (tryStatement.catchClause) { + pushKeywordIf(keywords, tryStatement.catchClause.getFirstToken(), 85 /* CatchKeyword */); + } + if (tryStatement.finallyBlock) { + const finallyKeyword = findChildOfKind(tryStatement, 98 /* FinallyKeyword */, sourceFile); + pushKeywordIf(keywords, finallyKeyword, 98 /* FinallyKeyword */); + } + return keywords; + } + function getThrowOccurrences(throwStatement, sourceFile) { + const owner = getThrowStatementOwner(throwStatement); + if (!owner) { + return void 0; + } + const keywords = []; + forEach(aggregateOwnedThrowStatements(owner), (throwStatement2) => { + keywords.push(findChildOfKind(throwStatement2, 111 /* ThrowKeyword */, sourceFile)); + }); + if (isFunctionBlock(owner)) { + forEachReturnStatement(owner, (returnStatement) => { + keywords.push(findChildOfKind(returnStatement, 107 /* ReturnKeyword */, sourceFile)); + }); + } + return keywords; + } + function getReturnOccurrences(returnStatement, sourceFile) { + const func = getContainingFunction(returnStatement); + if (!func) { + return void 0; + } + const keywords = []; + forEachReturnStatement(cast(func.body, isBlock), (returnStatement2) => { + keywords.push(findChildOfKind(returnStatement2, 107 /* ReturnKeyword */, sourceFile)); + }); + forEach(aggregateOwnedThrowStatements(func.body), (throwStatement) => { + keywords.push(findChildOfKind(throwStatement, 111 /* ThrowKeyword */, sourceFile)); + }); + return keywords; + } + function getAsyncAndAwaitOccurrences(node) { + const func = getContainingFunction(node); + if (!func) { + return void 0; + } + const keywords = []; + if (func.modifiers) { + func.modifiers.forEach((modifier) => { + pushKeywordIf(keywords, modifier, 134 /* AsyncKeyword */); + }); + } + forEachChild(func, (child) => { + traverseWithoutCrossingFunction(child, (node2) => { + if (isAwaitExpression(node2)) { + pushKeywordIf(keywords, node2.getFirstToken(), 135 /* AwaitKeyword */); + } + }); + }); + return keywords; + } + function getYieldOccurrences(node) { + const func = getContainingFunction(node); + if (!func) { + return void 0; + } + const keywords = []; + forEachChild(func, (child) => { + traverseWithoutCrossingFunction(child, (node2) => { + if (isYieldExpression(node2)) { + pushKeywordIf(keywords, node2.getFirstToken(), 127 /* YieldKeyword */); + } + }); + }); + return keywords; + } + function traverseWithoutCrossingFunction(node, cb) { + cb(node); + if (!isFunctionLike(node) && !isClassLike(node) && !isInterfaceDeclaration(node) && !isModuleDeclaration(node) && !isTypeAliasDeclaration(node) && !isTypeNode(node)) { + forEachChild(node, (child) => traverseWithoutCrossingFunction(child, cb)); + } + } + function getIfElseOccurrences(ifStatement, sourceFile) { + const keywords = getIfElseKeywords(ifStatement, sourceFile); + const result = []; + for (let i = 0; i < keywords.length; i++) { + if (keywords[i].kind === 93 /* ElseKeyword */ && i < keywords.length - 1) { + const elseKeyword = keywords[i]; + const ifKeyword = keywords[i + 1]; + let shouldCombineElseAndIf = true; + for (let j = ifKeyword.getStart(sourceFile) - 1; j >= elseKeyword.end; j--) { + if (!isWhiteSpaceSingleLine(sourceFile.text.charCodeAt(j))) { + shouldCombineElseAndIf = false; + break; + } + } + if (shouldCombineElseAndIf) { + result.push({ + fileName: sourceFile.fileName, + textSpan: createTextSpanFromBounds(elseKeyword.getStart(), ifKeyword.end), + kind: "reference" /* reference */ + }); + i++; + continue; + } + } + result.push(getHighlightSpanForNode(keywords[i], sourceFile)); + } + return result; + } + function getIfElseKeywords(ifStatement, sourceFile) { + const keywords = []; + while (isIfStatement(ifStatement.parent) && ifStatement.parent.elseStatement === ifStatement) { + ifStatement = ifStatement.parent; + } + while (true) { + const children = ifStatement.getChildren(sourceFile); + pushKeywordIf(keywords, children[0], 101 /* IfKeyword */); + for (let i = children.length - 1; i >= 0; i--) { + if (pushKeywordIf(keywords, children[i], 93 /* ElseKeyword */)) { + break; + } + } + if (!ifStatement.elseStatement || !isIfStatement(ifStatement.elseStatement)) { + break; + } + ifStatement = ifStatement.elseStatement; + } + return keywords; + } + function isLabeledBy(node, labelName) { + return !!findAncestor(node.parent, (owner) => !isLabeledStatement(owner) ? "quit" : owner.label.escapedText === labelName); + } + })(DocumentHighlights || (DocumentHighlights = {})); + } + }); + + // src/services/documentRegistry.ts + function isDocumentRegistryEntry(entry) { + return !!entry.sourceFile; + } + function createDocumentRegistry(useCaseSensitiveFileNames2, currentDirectory, jsDocParsingMode) { + return createDocumentRegistryInternal(useCaseSensitiveFileNames2, currentDirectory, jsDocParsingMode); } - function findLinkNameEnd(text) { - let pos = text.indexOf("://"); - if (pos === 0) { - while (pos < text.length && text.charCodeAt(pos) !== 124 /* bar */) - pos++; - return pos; + function createDocumentRegistryInternal(useCaseSensitiveFileNames2, currentDirectory = "", jsDocParsingMode, externalCache) { + const buckets = /* @__PURE__ */ new Map(); + const getCanonicalFileName = createGetCanonicalFileName(!!useCaseSensitiveFileNames2); + function reportStats() { + const bucketInfoArray = arrayFrom(buckets.keys()).filter((name) => name && name.charAt(0) === "_").map((name) => { + const entries = buckets.get(name); + const sourceFiles = []; + entries.forEach((entry, name2) => { + if (isDocumentRegistryEntry(entry)) { + sourceFiles.push({ + name: name2, + scriptKind: entry.sourceFile.scriptKind, + refCount: entry.languageServiceRefCount + }); + } else { + entry.forEach((value, scriptKind) => sourceFiles.push({ name: name2, scriptKind, refCount: value.languageServiceRefCount })); + } + }); + sourceFiles.sort((x, y) => y.refCount - x.refCount); + return { + bucket: name, + sourceFiles + }; + }); + return JSON.stringify(bucketInfoArray, void 0, 2); } - if (text.indexOf("()") === 0) - return 2; - if (text.charAt(0) === "<") { - let brackets2 = 0; - let i = 0; - while (i < text.length) { - if (text[i] === "<") - brackets2++; - if (text[i] === ">") - brackets2--; - i++; - if (!brackets2) - return i; + function getCompilationSettings(settingsOrHost) { + if (typeof settingsOrHost.getCompilationSettings === "function") { + return settingsOrHost.getCompilationSettings(); } + return settingsOrHost; } - return 0; - } - function getNewLineOrDefaultFromHost(host, formatSettings) { - var _a; - return (formatSettings == null ? void 0 : formatSettings.newLineCharacter) || ((_a = host.getNewLine) == null ? void 0 : _a.call(host)) || lineFeed2; - } - function lineBreakPart() { - return displayPart("\n", 6 /* lineBreak */); - } - function mapToDisplayParts(writeDisplayParts) { - try { - writeDisplayParts(displayPartWriter); - return displayPartWriter.displayParts(); - } finally { - displayPartWriter.clear(); + function acquireDocument(fileName, compilationSettings, scriptSnapshot, version2, scriptKind, languageVersionOrOptions) { + const path = toPath(fileName, currentDirectory, getCanonicalFileName); + const key = getKeyForCompilationSettings(getCompilationSettings(compilationSettings)); + return acquireDocumentWithKey(fileName, path, compilationSettings, key, scriptSnapshot, version2, scriptKind, languageVersionOrOptions); } - } - function typeToDisplayParts(typechecker, type, enclosingDeclaration, flags = 0 /* None */) { - return mapToDisplayParts((writer) => { - typechecker.writeType(type, enclosingDeclaration, flags | 1024 /* MultilineObjectLiterals */ | 16384 /* UseAliasDefinedOutsideCurrentScope */, writer); - }); - } - function symbolToDisplayParts(typeChecker, symbol, enclosingDeclaration, meaning, flags = 0 /* None */) { - return mapToDisplayParts((writer) => { - typeChecker.writeSymbol(symbol, enclosingDeclaration, meaning, flags | 8 /* UseAliasDefinedOutsideCurrentScope */, writer); - }); - } - function signatureToDisplayParts(typechecker, signature, enclosingDeclaration, flags = 0 /* None */) { - flags |= 16384 /* UseAliasDefinedOutsideCurrentScope */ | 1024 /* MultilineObjectLiterals */ | 32 /* WriteTypeArgumentsOfSignature */ | 8192 /* OmitParameterModifiers */; - return mapToDisplayParts((writer) => { - typechecker.writeSignature( - signature, - enclosingDeclaration, - flags, - /*kind*/ - void 0, - writer + function acquireDocumentWithKey(fileName, path, compilationSettings, key, scriptSnapshot, version2, scriptKind, languageVersionOrOptions) { + return acquireOrUpdateDocument( + fileName, + path, + compilationSettings, + key, + scriptSnapshot, + version2, + /*acquiring*/ + true, + scriptKind, + languageVersionOrOptions ); - }); - } - function nodeToDisplayParts(node, enclosingDeclaration) { - const file = enclosingDeclaration.getSourceFile(); - return mapToDisplayParts((writer) => { - const printer = createPrinterWithRemoveCommentsOmitTrailingSemicolon(); - printer.writeNode(4 /* Unspecified */, node, file, writer); - }); - } - function isImportOrExportSpecifierName(location) { - return !!location.parent && isImportOrExportSpecifier(location.parent) && location.parent.propertyName === location; - } - function getScriptKind(fileName, host) { - return ensureScriptKind(fileName, host.getScriptKind && host.getScriptKind(fileName)); - } - function getSymbolTarget(symbol, checker) { - let next = symbol; - while (isAliasSymbol(next) || isTransientSymbol(next) && next.links.target) { - if (isTransientSymbol(next) && next.links.target) { - next = next.links.target; - } else { - next = skipAlias(next, checker); - } - } - return next; - } - function isAliasSymbol(symbol) { - return (symbol.flags & 2097152 /* Alias */) !== 0; - } - function getUniqueSymbolId(symbol, checker) { - return getSymbolId(skipAlias(symbol, checker)); - } - function getFirstNonSpaceCharacterPosition(text, position) { - while (isWhiteSpaceLike(text.charCodeAt(position))) { - position += 1; - } - return position; - } - function getPrecedingNonSpaceCharacterPosition(text, position) { - while (position > -1 && isWhiteSpaceSingleLine(text.charCodeAt(position))) { - position -= 1; - } - return position + 1; - } - function getSynthesizedDeepClone(node, includeTrivia = true) { - const clone2 = node && getSynthesizedDeepCloneWorker(node); - if (clone2 && !includeTrivia) - suppressLeadingAndTrailingTrivia(clone2); - return clone2; - } - function getSynthesizedDeepCloneWithReplacements(node, includeTrivia, replaceNode) { - let clone2 = replaceNode(node); - if (clone2) { - setOriginalNode(clone2, node); - } else { - clone2 = getSynthesizedDeepCloneWorker(node, replaceNode); - } - if (clone2 && !includeTrivia) - suppressLeadingAndTrailingTrivia(clone2); - return clone2; - } - function getSynthesizedDeepCloneWorker(node, replaceNode) { - const nodeClone = replaceNode ? (n) => getSynthesizedDeepCloneWithReplacements( - n, - /*includeTrivia*/ - true, - replaceNode - ) : getSynthesizedDeepClone; - const nodesClone = replaceNode ? (ns) => ns && getSynthesizedDeepClonesWithReplacements( - ns, - /*includeTrivia*/ - true, - replaceNode - ) : (ns) => ns && getSynthesizedDeepClones(ns); - const visited = visitEachChild(node, nodeClone, nullTransformationContext, nodesClone, nodeClone); - if (visited === node) { - const clone2 = isStringLiteral(node) ? setOriginalNode(factory.createStringLiteralFromNode(node), node) : isNumericLiteral(node) ? setOriginalNode(factory.createNumericLiteral(node.text, node.numericLiteralFlags), node) : factory.cloneNode(node); - return setTextRange(clone2, node); - } - visited.parent = void 0; - return visited; - } - function getSynthesizedDeepClones(nodes, includeTrivia = true) { - if (nodes) { - const cloned = factory.createNodeArray(nodes.map((n) => getSynthesizedDeepClone(n, includeTrivia)), nodes.hasTrailingComma); - setTextRange(cloned, nodes); - return cloned; } - return nodes; - } - function getSynthesizedDeepClonesWithReplacements(nodes, includeTrivia, replaceNode) { - return factory.createNodeArray(nodes.map((n) => getSynthesizedDeepCloneWithReplacements(n, includeTrivia, replaceNode)), nodes.hasTrailingComma); - } - function suppressLeadingAndTrailingTrivia(node) { - suppressLeadingTrivia(node); - suppressTrailingTrivia(node); - } - function suppressLeadingTrivia(node) { - addEmitFlagsRecursively(node, 1024 /* NoLeadingComments */, getFirstChild); - } - function suppressTrailingTrivia(node) { - addEmitFlagsRecursively(node, 2048 /* NoTrailingComments */, getLastChild); - } - function copyComments(sourceNode, targetNode) { - const sourceFile = sourceNode.getSourceFile(); - const text = sourceFile.text; - if (hasLeadingLineBreak(sourceNode, text)) { - copyLeadingComments(sourceNode, targetNode, sourceFile); - } else { - copyTrailingAsLeadingComments(sourceNode, targetNode, sourceFile); + function updateDocument(fileName, compilationSettings, scriptSnapshot, version2, scriptKind, languageVersionOrOptions) { + const path = toPath(fileName, currentDirectory, getCanonicalFileName); + const key = getKeyForCompilationSettings(getCompilationSettings(compilationSettings)); + return updateDocumentWithKey(fileName, path, compilationSettings, key, scriptSnapshot, version2, scriptKind, languageVersionOrOptions); } - copyTrailingComments(sourceNode, targetNode, sourceFile); - } - function hasLeadingLineBreak(node, text) { - const start = node.getFullStart(); - const end = node.getStart(); - for (let i = start; i < end; i++) { - if (text.charCodeAt(i) === 10 /* lineFeed */) - return true; + function updateDocumentWithKey(fileName, path, compilationSettings, key, scriptSnapshot, version2, scriptKind, languageVersionOrOptions) { + return acquireOrUpdateDocument( + fileName, + path, + getCompilationSettings(compilationSettings), + key, + scriptSnapshot, + version2, + /*acquiring*/ + false, + scriptKind, + languageVersionOrOptions + ); } - return false; - } - function addEmitFlagsRecursively(node, flag, getChild) { - addEmitFlags(node, flag); - const child = getChild(node); - if (child) - addEmitFlagsRecursively(child, flag, getChild); - } - function getFirstChild(node) { - return node.forEachChild((child) => child); - } - function getUniqueName(baseName, sourceFile) { - let nameText = baseName; - for (let i = 1; !isFileLevelUniqueName(sourceFile, nameText); i++) { - nameText = `${baseName}_${i}`; + function getDocumentRegistryEntry(bucketEntry, scriptKind) { + const entry = isDocumentRegistryEntry(bucketEntry) ? bucketEntry : bucketEntry.get(Debug.checkDefined(scriptKind, "If there are more than one scriptKind's for same document the scriptKind should be provided")); + Debug.assert(scriptKind === void 0 || !entry || entry.sourceFile.scriptKind === scriptKind, `Script kind should match provided ScriptKind:${scriptKind} and sourceFile.scriptKind: ${entry == null ? void 0 : entry.sourceFile.scriptKind}, !entry: ${!entry}`); + return entry; } - return nameText; - } - function getRenameLocation(edits, renameFilename, name, preferLastLocation) { - let delta = 0; - let lastPos = -1; - for (const { fileName, textChanges: textChanges2 } of edits) { - Debug.assert(fileName === renameFilename); - for (const change of textChanges2) { - const { span, newText } = change; - const index = indexInTextChange(newText, escapeString(name)); - if (index !== -1) { - lastPos = span.start + delta + index; - if (!preferLastLocation) { - return lastPos; - } + function acquireOrUpdateDocument(fileName, path, compilationSettingsOrHost, key, scriptSnapshot, version2, acquiring, scriptKind, languageVersionOrOptions) { + var _a, _b, _c, _d; + scriptKind = ensureScriptKind(fileName, scriptKind); + const compilationSettings = getCompilationSettings(compilationSettingsOrHost); + const host = compilationSettingsOrHost === compilationSettings ? void 0 : compilationSettingsOrHost; + const scriptTarget = scriptKind === 6 /* JSON */ ? 100 /* JSON */ : getEmitScriptTarget(compilationSettings); + const sourceFileOptions = typeof languageVersionOrOptions === "object" ? languageVersionOrOptions : { + languageVersion: scriptTarget, + impliedNodeFormat: host && getImpliedNodeFormatForFile(path, (_d = (_c = (_b = (_a = host.getCompilerHost) == null ? void 0 : _a.call(host)) == null ? void 0 : _b.getModuleResolutionCache) == null ? void 0 : _c.call(_b)) == null ? void 0 : _d.getPackageJsonInfoCache(), host, compilationSettings), + setExternalModuleIndicator: getSetExternalModuleIndicator(compilationSettings), + jsDocParsingMode + }; + sourceFileOptions.languageVersion = scriptTarget; + Debug.assertEqual(jsDocParsingMode, sourceFileOptions.jsDocParsingMode); + const oldBucketCount = buckets.size; + const keyWithMode = getDocumentRegistryBucketKeyWithMode(key, sourceFileOptions.impliedNodeFormat); + const bucket = getOrUpdate(buckets, keyWithMode, () => /* @__PURE__ */ new Map()); + if (tracing) { + if (buckets.size > oldBucketCount) { + tracing.instant(tracing.Phase.Session, "createdDocumentRegistryBucket", { configFilePath: compilationSettings.configFilePath, key: keyWithMode }); + } + const otherBucketKey = !isDeclarationFileName(path) && forEachEntry(buckets, (bucket2, bucketKey) => bucketKey !== keyWithMode && bucket2.has(path) && bucketKey); + if (otherBucketKey) { + tracing.instant(tracing.Phase.Session, "documentRegistryBucketOverlap", { path, key1: otherBucketKey, key2: keyWithMode }); } - delta += newText.length - span.length; - } - } - Debug.assert(preferLastLocation); - Debug.assert(lastPos >= 0); - return lastPos; - } - function copyLeadingComments(sourceNode, targetNode, sourceFile, commentKind, hasTrailingNewLine) { - forEachLeadingCommentRange(sourceFile.text, sourceNode.pos, getAddCommentsFunction(targetNode, sourceFile, commentKind, hasTrailingNewLine, addSyntheticLeadingComment)); - } - function copyTrailingComments(sourceNode, targetNode, sourceFile, commentKind, hasTrailingNewLine) { - forEachTrailingCommentRange(sourceFile.text, sourceNode.end, getAddCommentsFunction(targetNode, sourceFile, commentKind, hasTrailingNewLine, addSyntheticTrailingComment)); - } - function copyTrailingAsLeadingComments(sourceNode, targetNode, sourceFile, commentKind, hasTrailingNewLine) { - forEachTrailingCommentRange(sourceFile.text, sourceNode.pos, getAddCommentsFunction(targetNode, sourceFile, commentKind, hasTrailingNewLine, addSyntheticLeadingComment)); - } - function getAddCommentsFunction(targetNode, sourceFile, commentKind, hasTrailingNewLine, cb) { - return (pos, end, kind, htnl) => { - if (kind === 3 /* MultiLineCommentTrivia */) { - pos += 2; - end -= 2; - } else { - pos += 2; - } - cb(targetNode, commentKind || kind, sourceFile.text.slice(pos, end), hasTrailingNewLine !== void 0 ? hasTrailingNewLine : htnl); - }; - } - function indexInTextChange(change, name) { - if (startsWith(change, name)) - return 0; - let idx = change.indexOf(" " + name); - if (idx === -1) - idx = change.indexOf("." + name); - if (idx === -1) - idx = change.indexOf('"' + name); - return idx === -1 ? -1 : idx + 1; - } - function needsParentheses(expression) { - return isBinaryExpression(expression) && expression.operatorToken.kind === 28 /* CommaToken */ || isObjectLiteralExpression(expression) || isAsExpression(expression) && isObjectLiteralExpression(expression.expression); - } - function getContextualTypeFromParent(node, checker, contextFlags) { - const parent2 = walkUpParenthesizedExpressions(node.parent); - switch (parent2.kind) { - case 213 /* NewExpression */: - return checker.getContextualType(parent2, contextFlags); - case 225 /* BinaryExpression */: { - const { left, operatorToken, right } = parent2; - return isEqualityOperatorKind(operatorToken.kind) ? checker.getTypeAtLocation(node === right ? left : right) : checker.getContextualType(node, contextFlags); } - case 295 /* CaseClause */: - return getSwitchedType(parent2, checker); - default: - return checker.getContextualType(node, contextFlags); - } - } - function quote(sourceFile, preferences, text) { - const quotePreference = getQuotePreference(sourceFile, preferences); - const quoted = JSON.stringify(text); - return quotePreference === 0 /* Single */ ? `'${stripQuotes(quoted).replace(/'/g, "\\'").replace(/\\"/g, '"')}'` : quoted; - } - function isEqualityOperatorKind(kind) { - switch (kind) { - case 37 /* EqualsEqualsEqualsToken */: - case 35 /* EqualsEqualsToken */: - case 38 /* ExclamationEqualsEqualsToken */: - case 36 /* ExclamationEqualsToken */: - return true; - default: - return false; - } - } - function isStringLiteralOrTemplate(node) { - switch (node.kind) { - case 11 /* StringLiteral */: - case 15 /* NoSubstitutionTemplateLiteral */: - case 227 /* TemplateExpression */: - case 214 /* TaggedTemplateExpression */: - return true; - default: - return false; - } - } - function hasIndexSignature(type) { - return !!type.getStringIndexType() || !!type.getNumberIndexType(); - } - function getSwitchedType(caseClause, checker) { - return checker.getTypeAtLocation(caseClause.parent.parent.expression); - } - function getTypeNodeIfAccessible(type, enclosingScope, program, host) { - const checker = program.getTypeChecker(); - let typeIsAccessible = true; - const notAccessible = () => typeIsAccessible = false; - const res = checker.typeToTypeNode(type, enclosingScope, 1 /* NoTruncation */, { - trackSymbol: (symbol, declaration, meaning) => { - typeIsAccessible = typeIsAccessible && checker.isSymbolAccessible( - symbol, - declaration, - meaning, - /*shouldComputeAliasToMarkVisible*/ - false - ).accessibility === 0 /* Accessible */; - return !typeIsAccessible; - }, - reportInaccessibleThisError: notAccessible, - reportPrivateInBaseOfClassExpression: notAccessible, - reportInaccessibleUniqueSymbolError: notAccessible, - moduleResolverHost: getModuleSpecifierResolverHost(program, host) - }); - return typeIsAccessible ? res : void 0; - } - function syntaxRequiresTrailingCommaOrSemicolonOrASI(kind) { - return kind === 178 /* CallSignature */ || kind === 179 /* ConstructSignature */ || kind === 180 /* IndexSignature */ || kind === 170 /* PropertySignature */ || kind === 172 /* MethodSignature */; - } - function syntaxRequiresTrailingFunctionBlockOrSemicolonOrASI(kind) { - return kind === 261 /* FunctionDeclaration */ || kind === 175 /* Constructor */ || kind === 173 /* MethodDeclaration */ || kind === 176 /* GetAccessor */ || kind === 177 /* SetAccessor */; - } - function syntaxRequiresTrailingModuleBlockOrSemicolonOrASI(kind) { - return kind === 266 /* ModuleDeclaration */; - } - function syntaxRequiresTrailingSemicolonOrASI(kind) { - return kind === 242 /* VariableStatement */ || kind === 243 /* ExpressionStatement */ || kind === 245 /* DoStatement */ || kind === 250 /* ContinueStatement */ || kind === 251 /* BreakStatement */ || kind === 252 /* ReturnStatement */ || kind === 256 /* ThrowStatement */ || kind === 258 /* DebuggerStatement */ || kind === 171 /* PropertyDeclaration */ || kind === 264 /* TypeAliasDeclaration */ || kind === 271 /* ImportDeclaration */ || kind === 270 /* ImportEqualsDeclaration */ || kind === 277 /* ExportDeclaration */ || kind === 269 /* NamespaceExportDeclaration */ || kind === 276 /* ExportAssignment */; - } - function nodeIsASICandidate(node, sourceFile) { - const lastToken = node.getLastToken(sourceFile); - if (lastToken && lastToken.kind === 27 /* SemicolonToken */) { - return false; - } - if (syntaxRequiresTrailingCommaOrSemicolonOrASI(node.kind)) { - if (lastToken && lastToken.kind === 28 /* CommaToken */) { - return false; + const bucketEntry = bucket.get(path); + let entry = bucketEntry && getDocumentRegistryEntry(bucketEntry, scriptKind); + if (!entry && externalCache) { + const sourceFile = externalCache.getDocument(keyWithMode, path); + if (sourceFile) { + Debug.assert(acquiring); + entry = { + sourceFile, + languageServiceRefCount: 0 + }; + setBucketEntry(); + } } - } else if (syntaxRequiresTrailingModuleBlockOrSemicolonOrASI(node.kind)) { - const lastChild = last(node.getChildren(sourceFile)); - if (lastChild && isModuleBlock(lastChild)) { - return false; + if (!entry) { + const sourceFile = createLanguageServiceSourceFile( + fileName, + scriptSnapshot, + sourceFileOptions, + version2, + /*setNodeParents*/ + false, + scriptKind + ); + if (externalCache) { + externalCache.setDocument(keyWithMode, path, sourceFile); + } + entry = { + sourceFile, + languageServiceRefCount: 1 + }; + setBucketEntry(); + } else { + if (entry.sourceFile.version !== version2) { + entry.sourceFile = updateLanguageServiceSourceFile(entry.sourceFile, scriptSnapshot, version2, scriptSnapshot.getChangeRange(entry.sourceFile.scriptSnapshot)); + if (externalCache) { + externalCache.setDocument(keyWithMode, path, entry.sourceFile); + } + } + if (acquiring) { + entry.languageServiceRefCount++; + } } - } else if (syntaxRequiresTrailingFunctionBlockOrSemicolonOrASI(node.kind)) { - const lastChild = last(node.getChildren(sourceFile)); - if (lastChild && isFunctionBlock(lastChild)) { - return false; + Debug.assert(entry.languageServiceRefCount !== 0); + return entry.sourceFile; + function setBucketEntry() { + if (!bucketEntry) { + bucket.set(path, entry); + } else if (isDocumentRegistryEntry(bucketEntry)) { + const scriptKindMap = /* @__PURE__ */ new Map(); + scriptKindMap.set(bucketEntry.sourceFile.scriptKind, bucketEntry); + scriptKindMap.set(scriptKind, entry); + bucket.set(path, scriptKindMap); + } else { + bucketEntry.set(scriptKind, entry); + } } - } else if (!syntaxRequiresTrailingSemicolonOrASI(node.kind)) { - return false; } - if (node.kind === 245 /* DoStatement */) { - return true; - } - const topNode = findAncestor(node, (ancestor) => !ancestor.parent); - const nextToken = findNextToken(node, topNode, sourceFile); - if (!nextToken || nextToken.kind === 20 /* CloseBraceToken */) { - return true; + function releaseDocument(fileName, compilationSettings, scriptKind, impliedNodeFormat) { + const path = toPath(fileName, currentDirectory, getCanonicalFileName); + const key = getKeyForCompilationSettings(compilationSettings); + return releaseDocumentWithKey(path, key, scriptKind, impliedNodeFormat); } - const startLine = sourceFile.getLineAndCharacterOfPosition(node.getEnd()).line; - const endLine = sourceFile.getLineAndCharacterOfPosition(nextToken.getStart(sourceFile)).line; - return startLine !== endLine; - } - function positionIsASICandidate(pos, context, sourceFile) { - const contextAncestor = findAncestor(context, (ancestor) => { - if (ancestor.end !== pos) { - return "quit"; - } - return syntaxMayBeASICandidate(ancestor.kind); - }); - return !!contextAncestor && nodeIsASICandidate(contextAncestor, sourceFile); - } - function probablyUsesSemicolons(sourceFile) { - let withSemicolon = 0; - let withoutSemicolon = 0; - const nStatementsToObserve = 5; - forEachChild(sourceFile, function visit(node) { - if (syntaxRequiresTrailingSemicolonOrASI(node.kind)) { - const lastToken = node.getLastToken(sourceFile); - if ((lastToken == null ? void 0 : lastToken.kind) === 27 /* SemicolonToken */) { - withSemicolon++; + function releaseDocumentWithKey(path, key, scriptKind, impliedNodeFormat) { + const bucket = Debug.checkDefined(buckets.get(getDocumentRegistryBucketKeyWithMode(key, impliedNodeFormat))); + const bucketEntry = bucket.get(path); + const entry = getDocumentRegistryEntry(bucketEntry, scriptKind); + entry.languageServiceRefCount--; + Debug.assert(entry.languageServiceRefCount >= 0); + if (entry.languageServiceRefCount === 0) { + if (isDocumentRegistryEntry(bucketEntry)) { + bucket.delete(path); } else { - withoutSemicolon++; - } - } else if (syntaxRequiresTrailingCommaOrSemicolonOrASI(node.kind)) { - const lastToken = node.getLastToken(sourceFile); - if ((lastToken == null ? void 0 : lastToken.kind) === 27 /* SemicolonToken */) { - withSemicolon++; - } else if (lastToken && lastToken.kind !== 28 /* CommaToken */) { - const lastTokenLine = getLineAndCharacterOfPosition(sourceFile, lastToken.getStart(sourceFile)).line; - const nextTokenLine = getLineAndCharacterOfPosition(sourceFile, getSpanOfTokenAtPosition(sourceFile, lastToken.end).start).line; - if (lastTokenLine !== nextTokenLine) { - withoutSemicolon++; + bucketEntry.delete(scriptKind); + if (bucketEntry.size === 1) { + bucket.set(path, firstDefinedIterator(bucketEntry.values(), identity)); } } } - if (withSemicolon + withoutSemicolon >= nStatementsToObserve) { - return true; - } - return forEachChild(node, visit); - }); - if (withSemicolon === 0 && withoutSemicolon <= 1) { - return true; - } - return withSemicolon / withoutSemicolon > 1 / nStatementsToObserve; - } - function tryGetDirectories(host, directoryName) { - return tryIOAndConsumeErrors(host, host.getDirectories, directoryName) || []; - } - function tryReadDirectory(host, path, extensions, exclude, include) { - return tryIOAndConsumeErrors(host, host.readDirectory, path, extensions, exclude, include) || emptyArray; - } - function tryFileExists(host, path) { - return tryIOAndConsumeErrors(host, host.fileExists, path); - } - function tryDirectoryExists(host, path) { - return tryAndIgnoreErrors(() => directoryProbablyExists(path, host)) || false; - } - function tryAndIgnoreErrors(cb) { - try { - return cb(); - } catch { - return void 0; } + return { + acquireDocument, + acquireDocumentWithKey, + updateDocument, + updateDocumentWithKey, + releaseDocument, + releaseDocumentWithKey, + getKeyForCompilationSettings, + getDocumentRegistryBucketKeyWithMode, + reportStats, + getBuckets: () => buckets + }; } - function tryIOAndConsumeErrors(host, toApply, ...args) { - return tryAndIgnoreErrors(() => toApply && toApply.apply(host, args)); - } - function findPackageJsons(startDirectory, host, stopDirectory) { - const paths = []; - forEachAncestorDirectory(startDirectory, (ancestor) => { - if (ancestor === stopDirectory) { - return true; - } - const currentConfigPath = combinePaths(ancestor, "package.json"); - if (tryFileExists(host, currentConfigPath)) { - paths.push(currentConfigPath); - } - }); - return paths; + function getKeyForCompilationSettings(settings) { + return getKeyForCompilerOptions(settings, sourceFileAffectingCompilerOptions); } - function findPackageJson(directory, host) { - let packageJson; - forEachAncestorDirectory(directory, (ancestor) => { - if (ancestor === "node_modules") - return true; - packageJson = findConfigFile(ancestor, (f) => tryFileExists(host, f), "package.json"); - if (packageJson) { - return true; - } - }); - return packageJson; + function getDocumentRegistryBucketKeyWithMode(key, mode) { + return mode ? `${key}|${mode}` : key; } - function getPackageJsonsVisibleToFile(fileName, host) { - if (!host.fileExists) { - return []; + var init_documentRegistry = __esm({ + "src/services/documentRegistry.ts"() { + "use strict"; + init_ts4(); } - const packageJsons = []; - forEachAncestorDirectory(getDirectoryPath(fileName), (ancestor) => { - const packageJsonFileName = combinePaths(ancestor, "package.json"); - if (host.fileExists(packageJsonFileName)) { - const info = createPackageJsonInfo(packageJsonFileName, host); - if (info) { - packageJsons.push(info); - } - } + }); + + // src/services/getEditsForFileRename.ts + function getEditsForFileRename(program, oldFileOrDirPath, newFileOrDirPath, host, formatContext, preferences, sourceMapper) { + const useCaseSensitiveFileNames2 = hostUsesCaseSensitiveFileNames(host); + const getCanonicalFileName = createGetCanonicalFileName(useCaseSensitiveFileNames2); + const oldToNew = getPathUpdater(oldFileOrDirPath, newFileOrDirPath, getCanonicalFileName, sourceMapper); + const newToOld = getPathUpdater(newFileOrDirPath, oldFileOrDirPath, getCanonicalFileName, sourceMapper); + return ts_textChanges_exports.ChangeTracker.with({ host, formatContext, preferences }, (changeTracker) => { + updateTsconfigFiles(program, changeTracker, oldToNew, oldFileOrDirPath, newFileOrDirPath, host.getCurrentDirectory(), useCaseSensitiveFileNames2); + updateImports(program, changeTracker, oldToNew, newToOld, host, getCanonicalFileName); }); - return packageJsons; } - function createPackageJsonInfo(fileName, host) { - if (!host.readFile) { - return void 0; - } - const dependencyKeys = ["dependencies", "devDependencies", "optionalDependencies", "peerDependencies"]; - const stringContent = host.readFile(fileName) || ""; - const content = tryParseJson(stringContent); - const info = {}; - if (content) { - for (const key of dependencyKeys) { - const dependencies = content[key]; - if (!dependencies) { - continue; - } - const dependencyMap = /* @__PURE__ */ new Map(); - for (const packageName in dependencies) { - dependencyMap.set(packageName, dependencies[packageName]); - } - info[key] = dependencyMap; - } - } - const dependencyGroups = [ - [1 /* Dependencies */, info.dependencies], - [2 /* DevDependencies */, info.devDependencies], - [8 /* OptionalDependencies */, info.optionalDependencies], - [4 /* PeerDependencies */, info.peerDependencies] - ]; - return { - ...info, - parseable: !!content, - fileName, - get, - has(dependencyName, inGroups) { - return !!get(dependencyName, inGroups); - } + function getPathUpdater(oldFileOrDirPath, newFileOrDirPath, getCanonicalFileName, sourceMapper) { + const canonicalOldPath = getCanonicalFileName(oldFileOrDirPath); + return (path) => { + const originalPath = sourceMapper && sourceMapper.tryGetSourcePosition({ fileName: path, pos: 0 }); + const updatedPath = getUpdatedPath(originalPath ? originalPath.fileName : path); + return originalPath ? updatedPath === void 0 ? void 0 : makeCorrespondingRelativeChange(originalPath.fileName, updatedPath, path, getCanonicalFileName) : updatedPath; }; - function get(dependencyName, inGroups = 15 /* All */) { - for (const [group2, deps] of dependencyGroups) { - if (deps && inGroups & group2) { - const dep = deps.get(dependencyName); - if (dep !== void 0) { - return dep; - } - } - } + function getUpdatedPath(pathToUpdate) { + if (getCanonicalFileName(pathToUpdate) === canonicalOldPath) + return newFileOrDirPath; + const suffix = tryRemoveDirectoryPrefix(pathToUpdate, canonicalOldPath, getCanonicalFileName); + return suffix === void 0 ? void 0 : newFileOrDirPath + "/" + suffix; } } - function createPackageJsonImportFilter(fromFile, preferences, host) { - const packageJsons = (host.getPackageJsonsVisibleToFile && host.getPackageJsonsVisibleToFile(fromFile.fileName) || getPackageJsonsVisibleToFile(fromFile.fileName, host)).filter((p) => p.parseable); - let usesNodeCoreModules; - let ambientModuleCache; - let sourceFileCache; - return { - allowsImportingAmbientModule, - allowsImportingSourceFile, - allowsImportingSpecifier - }; - function moduleSpecifierIsCoveredByPackageJson(specifier) { - const packageName = getNodeModuleRootSpecifier(specifier); - for (const packageJson of packageJsons) { - if (packageJson.has(packageName) || packageJson.has(getTypesPackageName(packageName))) { - return true; - } - } - return false; - } - function allowsImportingAmbientModule(moduleSymbol, moduleSpecifierResolutionHost) { - if (!packageJsons.length || !moduleSymbol.valueDeclaration) { - return true; - } - if (!ambientModuleCache) { - ambientModuleCache = /* @__PURE__ */ new Map(); - } else { - const cached = ambientModuleCache.get(moduleSymbol); - if (cached !== void 0) { - return cached; - } - } - const declaredModuleSpecifier = stripQuotes(moduleSymbol.getName()); - if (isAllowedCoreNodeModulesImport(declaredModuleSpecifier)) { - ambientModuleCache.set(moduleSymbol, true); - return true; - } - const declaringSourceFile = moduleSymbol.valueDeclaration.getSourceFile(); - const declaringNodeModuleName = getNodeModulesPackageNameFromFileName(declaringSourceFile.fileName, moduleSpecifierResolutionHost); - if (typeof declaringNodeModuleName === "undefined") { - ambientModuleCache.set(moduleSymbol, true); - return true; - } - const result = moduleSpecifierIsCoveredByPackageJson(declaringNodeModuleName) || moduleSpecifierIsCoveredByPackageJson(declaredModuleSpecifier); - ambientModuleCache.set(moduleSymbol, result); - return result; - } - function allowsImportingSourceFile(sourceFile, moduleSpecifierResolutionHost) { - if (!packageJsons.length) { - return true; - } - if (!sourceFileCache) { - sourceFileCache = /* @__PURE__ */ new Map(); - } else { - const cached = sourceFileCache.get(sourceFile); - if (cached !== void 0) { - return cached; + function makeCorrespondingRelativeChange(a0, b0, a1, getCanonicalFileName) { + const rel = getRelativePathFromFile(a0, b0, getCanonicalFileName); + return combinePathsSafe(getDirectoryPath(a1), rel); + } + function updateTsconfigFiles(program, changeTracker, oldToNew, oldFileOrDirPath, newFileOrDirPath, currentDirectory, useCaseSensitiveFileNames2) { + const { configFile } = program.getCompilerOptions(); + if (!configFile) + return; + const configDir = getDirectoryPath(configFile.fileName); + const jsonObjectLiteral = getTsConfigObjectLiteralExpression(configFile); + if (!jsonObjectLiteral) + return; + forEachProperty(jsonObjectLiteral, (property, propertyName) => { + switch (propertyName) { + case "files": + case "include": + case "exclude": { + const foundExactMatch = updatePaths(property); + if (foundExactMatch || propertyName !== "include" || !isArrayLiteralExpression(property.initializer)) + return; + const includes = mapDefined(property.initializer.elements, (e) => isStringLiteral(e) ? e.text : void 0); + if (includes.length === 0) + return; + const matchers = getFileMatcherPatterns( + configDir, + /*excludes*/ + [], + includes, + useCaseSensitiveFileNames2, + currentDirectory + ); + if (getRegexFromPattern(Debug.checkDefined(matchers.includeFilePattern), useCaseSensitiveFileNames2).test(oldFileOrDirPath) && !getRegexFromPattern(Debug.checkDefined(matchers.includeFilePattern), useCaseSensitiveFileNames2).test(newFileOrDirPath)) { + changeTracker.insertNodeAfter(configFile, last(property.initializer.elements), factory.createStringLiteral(relativePath(newFileOrDirPath))); + } + return; } + case "compilerOptions": + forEachProperty(property.initializer, (property2, propertyName2) => { + const option = getOptionFromName(propertyName2); + Debug.assert((option == null ? void 0 : option.type) !== "listOrElement"); + if (option && (option.isFilePath || option.type === "list" && option.element.isFilePath)) { + updatePaths(property2); + } else if (propertyName2 === "paths") { + forEachProperty(property2.initializer, (pathsProperty) => { + if (!isArrayLiteralExpression(pathsProperty.initializer)) + return; + for (const e of pathsProperty.initializer.elements) { + tryUpdateString(e); + } + }); + } + }); + return; } - const moduleSpecifier = getNodeModulesPackageNameFromFileName(sourceFile.fileName, moduleSpecifierResolutionHost); - if (!moduleSpecifier) { - sourceFileCache.set(sourceFile, true); - return true; + }); + function updatePaths(property) { + const elements = isArrayLiteralExpression(property.initializer) ? property.initializer.elements : [property.initializer]; + let foundExactMatch = false; + for (const element of elements) { + foundExactMatch = tryUpdateString(element) || foundExactMatch; } - const result = moduleSpecifierIsCoveredByPackageJson(moduleSpecifier); - sourceFileCache.set(sourceFile, result); - return result; + return foundExactMatch; } - function allowsImportingSpecifier(moduleSpecifier) { - if (!packageJsons.length || isAllowedCoreNodeModulesImport(moduleSpecifier)) { - return true; - } - if (pathIsRelative(moduleSpecifier) || isRootedDiskPath(moduleSpecifier)) { + function tryUpdateString(element) { + if (!isStringLiteral(element)) + return false; + const elementFileName = combinePathsSafe(configDir, element.text); + const updated = oldToNew(elementFileName); + if (updated !== void 0) { + changeTracker.replaceRangeWithText(configFile, createStringRange(element, configFile), relativePath(updated)); return true; } - return moduleSpecifierIsCoveredByPackageJson(moduleSpecifier); - } - function isAllowedCoreNodeModulesImport(moduleSpecifier) { - if (isSourceFileJS(fromFile) && ts_JsTyping_exports.nodeCoreModules.has(moduleSpecifier)) { - if (usesNodeCoreModules === void 0) { - usesNodeCoreModules = consumesNodeCoreModules(fromFile); - } - if (usesNodeCoreModules) { - return true; - } - } return false; } - function getNodeModulesPackageNameFromFileName(importedFileName, moduleSpecifierResolutionHost) { - if (!stringContains(importedFileName, "node_modules")) { - return void 0; - } - const specifier = ts_moduleSpecifiers_exports.getNodeModulesPackageName( - host.getCompilationSettings(), - fromFile, - importedFileName, - moduleSpecifierResolutionHost, - preferences + function relativePath(path) { + return getRelativePathFromDirectory( + configDir, + path, + /*ignoreCase*/ + !useCaseSensitiveFileNames2 ); - if (!specifier) { - return void 0; - } - if (!pathIsRelative(specifier) && !isRootedDiskPath(specifier)) { - return getNodeModuleRootSpecifier(specifier); - } - } - function getNodeModuleRootSpecifier(fullSpecifier) { - const components = getPathComponents(getPackageNameFromTypesPackageName(fullSpecifier)).slice(1); - if (startsWith(components[0], "@")) { - return `${components[0]}/${components[1]}`; - } - return components[0]; - } - } - function tryParseJson(text) { - try { - return JSON.parse(text); - } catch { - return void 0; - } - } - function consumesNodeCoreModules(sourceFile) { - return some(sourceFile.imports, ({ text }) => ts_JsTyping_exports.nodeCoreModules.has(text)); - } - function isInsideNodeModules(fileOrDirectory) { - return contains(getPathComponents(fileOrDirectory), "node_modules"); - } - function isDiagnosticWithLocation(diagnostic) { - return diagnostic.file !== void 0 && diagnostic.start !== void 0 && diagnostic.length !== void 0; - } - function findDiagnosticForNode(node, sortedFileDiagnostics) { - const span = createTextSpanFromNode(node); - const index = binarySearchKey(sortedFileDiagnostics, span, identity, compareTextSpans); - if (index >= 0) { - const diagnostic = sortedFileDiagnostics[index]; - Debug.assertEqual(diagnostic.file, node.getSourceFile(), "Diagnostics proided to 'findDiagnosticForNode' must be from a single SourceFile"); - return cast(diagnostic, isDiagnosticWithLocation); } } - function getDiagnosticsWithinSpan(span, sortedFileDiagnostics) { - var _a; - let index = binarySearchKey(sortedFileDiagnostics, span.start, (diag2) => diag2.start, compareValues); - if (index < 0) { - index = ~index; - } - while (((_a = sortedFileDiagnostics[index - 1]) == null ? void 0 : _a.start) === span.start) { - index--; - } - const result = []; - const end = textSpanEnd(span); - while (true) { - const diagnostic = tryCast(sortedFileDiagnostics[index], isDiagnosticWithLocation); - if (!diagnostic || diagnostic.start > end) { - break; - } - if (textSpanContainsTextSpan(span, diagnostic)) { - result.push(diagnostic); - } - index++; + function updateImports(program, changeTracker, oldToNew, newToOld, host, getCanonicalFileName) { + const allFiles = program.getSourceFiles(); + for (const sourceFile of allFiles) { + const newFromOld = oldToNew(sourceFile.fileName); + const newImportFromPath = newFromOld ?? sourceFile.fileName; + const newImportFromDirectory = getDirectoryPath(newImportFromPath); + const oldFromNew = newToOld(sourceFile.fileName); + const oldImportFromPath = oldFromNew || sourceFile.fileName; + const oldImportFromDirectory = getDirectoryPath(oldImportFromPath); + const importingSourceFileMoved = newFromOld !== void 0 || oldFromNew !== void 0; + updateImportsWorker(sourceFile, changeTracker, (referenceText) => { + if (!pathIsRelative(referenceText)) + return void 0; + const oldAbsolute = combinePathsSafe(oldImportFromDirectory, referenceText); + const newAbsolute = oldToNew(oldAbsolute); + return newAbsolute === void 0 ? void 0 : ensurePathIsNonModuleName(getRelativePathFromDirectory(newImportFromDirectory, newAbsolute, getCanonicalFileName)); + }, (importLiteral) => { + const importedModuleSymbol = program.getTypeChecker().getSymbolAtLocation(importLiteral); + if ((importedModuleSymbol == null ? void 0 : importedModuleSymbol.declarations) && importedModuleSymbol.declarations.some((d) => isAmbientModule(d))) + return void 0; + const toImport = oldFromNew !== void 0 ? getSourceFileToImportFromResolved(importLiteral, resolveModuleName(importLiteral.text, oldImportFromPath, program.getCompilerOptions(), host), oldToNew, allFiles) : getSourceFileToImport(importedModuleSymbol, importLiteral, sourceFile, program, host, oldToNew); + return toImport !== void 0 && (toImport.updated || importingSourceFileMoved && pathIsRelative(importLiteral.text)) ? ts_moduleSpecifiers_exports.updateModuleSpecifier(program.getCompilerOptions(), sourceFile, getCanonicalFileName(newImportFromPath), toImport.newFileName, createModuleSpecifierResolutionHost(program, host), importLiteral.text) : void 0; + }); } - return result; - } - function getRefactorContextSpan({ startPosition, endPosition }) { - return createTextSpanFromBounds(startPosition, endPosition === void 0 ? startPosition : endPosition); - } - function getFixableErrorSpanExpression(sourceFile, span) { - const token = getTokenAtPosition(sourceFile, span.start); - const expression = findAncestor(token, (node) => { - if (node.getStart(sourceFile) < span.start || node.getEnd() > textSpanEnd(span)) { - return "quit"; - } - return isExpression(node) && textSpansEqual(span, createTextSpanFromNode(node, sourceFile)); - }); - return expression; } - function mapOneOrMany(valueOrArray, f, resultSelector = identity) { - return valueOrArray ? isArray(valueOrArray) ? resultSelector(map(valueOrArray, f)) : f(valueOrArray, 0) : void 0; + function combineNormal(pathA, pathB) { + return normalizePath(combinePaths(pathA, pathB)); } - function firstOrOnly(valueOrArray) { - return isArray(valueOrArray) ? first(valueOrArray) : valueOrArray; + function combinePathsSafe(pathA, pathB) { + return ensurePathIsNonModuleName(combineNormal(pathA, pathB)); } - function getNamesForExportedSymbol(symbol, scriptTarget) { - if (needsNameFromDeclaration(symbol)) { - const fromDeclaration = getDefaultLikeExportNameFromDeclaration(symbol); - if (fromDeclaration) - return fromDeclaration; - const fileNameCase = ts_codefix_exports.moduleSymbolToValidIdentifier( - getSymbolParentOrFail(symbol), - scriptTarget, - /*forceCapitalize*/ - false - ); - const capitalized = ts_codefix_exports.moduleSymbolToValidIdentifier( - getSymbolParentOrFail(symbol), - scriptTarget, - /*forceCapitalize*/ - true - ); - if (fileNameCase === capitalized) - return fileNameCase; - return [fileNameCase, capitalized]; + function getSourceFileToImport(importedModuleSymbol, importLiteral, importingSourceFile, program, host, oldToNew) { + if (importedModuleSymbol) { + const oldFileName = find(importedModuleSymbol.declarations, isSourceFile).fileName; + const newFileName = oldToNew(oldFileName); + return newFileName === void 0 ? { newFileName: oldFileName, updated: false } : { newFileName, updated: true }; + } else { + const mode = getModeForUsageLocation(importingSourceFile, importLiteral); + const resolved = host.resolveModuleNameLiterals || !host.resolveModuleNames ? program.getResolvedModule(importingSourceFile, importLiteral.text, mode) : host.getResolvedModuleWithFailedLookupLocationsFromCache && host.getResolvedModuleWithFailedLookupLocationsFromCache(importLiteral.text, importingSourceFile.fileName, mode); + return getSourceFileToImportFromResolved(importLiteral, resolved, oldToNew, program.getSourceFiles()); } - return symbol.name; } - function getNameForExportedSymbol(symbol, scriptTarget, preferCapitalized) { - if (needsNameFromDeclaration(symbol)) { - return getDefaultLikeExportNameFromDeclaration(symbol) || ts_codefix_exports.moduleSymbolToValidIdentifier(getSymbolParentOrFail(symbol), scriptTarget, !!preferCapitalized); + function getSourceFileToImportFromResolved(importLiteral, resolved, oldToNew, sourceFiles) { + if (!resolved) + return void 0; + if (resolved.resolvedModule) { + const result2 = tryChange(resolved.resolvedModule.resolvedFileName); + if (result2) + return result2; } - return symbol.name; - } - function needsNameFromDeclaration(symbol) { - return !(symbol.flags & 33554432 /* Transient */) && (symbol.escapedName === "export=" /* ExportEquals */ || symbol.escapedName === "default" /* Default */); - } - function getDefaultLikeExportNameFromDeclaration(symbol) { - return firstDefined( - symbol.declarations, - (d) => { - var _a, _b; - return isExportAssignment(d) ? (_a = tryCast(skipOuterExpressions(d.expression), isIdentifier)) == null ? void 0 : _a.text : (_b = tryCast(getNameOfDeclaration(d), isIdentifier)) == null ? void 0 : _b.text; - } - ); - } - function getSymbolParentOrFail(symbol) { - var _a; - return Debug.checkDefined( - symbol.parent, - `Symbol parent was undefined. Flags: ${Debug.formatSymbolFlags(symbol.flags)}. Declarations: ${(_a = symbol.declarations) == null ? void 0 : _a.map((d) => { - const kind = Debug.formatSyntaxKind(d.kind); - const inJS = isInJSFile(d); - const { expression } = d; - return (inJS ? "[JS]" : "") + kind + (expression ? ` (expression: ${Debug.formatSyntaxKind(expression.kind)})` : ""); - }).join(", ")}.` - ); - } - function stringContainsAt(haystack, needle, startIndex) { - const needleLength = needle.length; - if (needleLength + startIndex > haystack.length) { - return false; + const result = forEach(resolved.failedLookupLocations, tryChangeWithIgnoringPackageJsonExisting) || pathIsRelative(importLiteral.text) && forEach(resolved.failedLookupLocations, tryChangeWithIgnoringPackageJson); + if (result) + return result; + return resolved.resolvedModule && { newFileName: resolved.resolvedModule.resolvedFileName, updated: false }; + function tryChangeWithIgnoringPackageJsonExisting(oldFileName) { + const newFileName = oldToNew(oldFileName); + return newFileName && find(sourceFiles, (src) => src.fileName === newFileName) ? tryChangeWithIgnoringPackageJson(oldFileName) : void 0; } - for (let i = 0; i < needleLength; i++) { - if (needle.charCodeAt(i) !== haystack.charCodeAt(i + startIndex)) - return false; + function tryChangeWithIgnoringPackageJson(oldFileName) { + return !endsWith(oldFileName, "/package.json") ? tryChange(oldFileName) : void 0; + } + function tryChange(oldFileName) { + const newFileName = oldToNew(oldFileName); + return newFileName && { newFileName, updated: true }; } - return true; - } - function startsWithUnderscore(name) { - return name.charCodeAt(0) === 95 /* _ */; - } - function isGlobalDeclaration(declaration) { - return !isNonGlobalDeclaration(declaration); } - function isNonGlobalDeclaration(declaration) { - const sourceFile = declaration.getSourceFile(); - if (!sourceFile.externalModuleIndicator && !sourceFile.commonJsModuleIndicator) { - return false; + function updateImportsWorker(sourceFile, changeTracker, updateRef, updateImport2) { + for (const ref of sourceFile.referencedFiles || emptyArray) { + const updated = updateRef(ref.fileName); + if (updated !== void 0 && updated !== sourceFile.text.slice(ref.pos, ref.end)) + changeTracker.replaceRangeWithText(sourceFile, ref, updated); + } + for (const importStringLiteral of sourceFile.imports) { + const updated = updateImport2(importStringLiteral); + if (updated !== void 0 && updated !== importStringLiteral.text) + changeTracker.replaceRangeWithText(sourceFile, createStringRange(importStringLiteral, sourceFile), updated); } - return isInJSFile(declaration) || !findAncestor(declaration, (d) => isModuleDeclaration(d) && isGlobalScopeAugmentation(d)); } - function isDeprecatedDeclaration(decl) { - return !!(getCombinedNodeFlagsAlwaysIncludeJSDoc(decl) & 8192 /* Deprecated */); + function createStringRange(node, sourceFile) { + return createRange(node.getStart(sourceFile) + 1, node.end - 1); } - function shouldUseUriStyleNodeCoreModules(file, program) { - const decisionFromFile = firstDefined(file.imports, (node) => { - if (ts_JsTyping_exports.nodeCoreModules.has(node.text)) { - return startsWith(node.text, "node:"); + function forEachProperty(objectLiteral, cb) { + if (!isObjectLiteralExpression(objectLiteral)) + return; + for (const property of objectLiteral.properties) { + if (isPropertyAssignment(property) && isStringLiteral(property.name)) { + cb(property, property.name.text); } - }); - return decisionFromFile ?? program.usesUriStyleNodeCoreModules; - } - function getNewLineKind(newLineCharacter) { - return newLineCharacter === "\n" ? 1 /* LineFeed */ : 0 /* CarriageReturnLineFeed */; - } - function diagnosticToString(diag2) { - return isArray(diag2) ? formatStringFromArgs(getLocaleSpecificMessage(diag2[0]), diag2.slice(1)) : getLocaleSpecificMessage(diag2); + } } - function getFormatCodeSettingsForWriting({ options }, sourceFile) { - const shouldAutoDetectSemicolonPreference = !options.semicolons || options.semicolons === "ignore" /* Ignore */; - const shouldRemoveSemicolons = options.semicolons === "remove" /* Remove */ || shouldAutoDetectSemicolonPreference && !probablyUsesSemicolons(sourceFile); + var init_getEditsForFileRename = __esm({ + "src/services/getEditsForFileRename.ts"() { + "use strict"; + init_ts4(); + } + }); + + // src/services/patternMatcher.ts + function createPatternMatch(kind, isCaseSensitive) { return { - ...options, - semicolons: shouldRemoveSemicolons ? "remove" /* Remove */ : "ignore" /* Ignore */ + kind, + isCaseSensitive }; } - function jsxModeNeedsExplicitImport(jsx) { - return jsx === 2 /* React */ || jsx === 3 /* ReactNative */; - } - function isSourceFileFromLibrary(program, node) { - return program.isSourceFileFromExternalLibrary(node) || program.isSourceFileDefaultLibrary(node); - } - function newCaseClauseTracker(checker, clauses) { - const existingStrings = /* @__PURE__ */ new Set(); - const existingNumbers = /* @__PURE__ */ new Set(); - const existingBigInts = /* @__PURE__ */ new Set(); - for (const clause of clauses) { - if (!isDefaultClause(clause)) { - const expression = skipParentheses(clause.expression); - if (isLiteralExpression(expression)) { - switch (expression.kind) { - case 15 /* NoSubstitutionTemplateLiteral */: - case 11 /* StringLiteral */: - existingStrings.add(expression.text); - break; - case 9 /* NumericLiteral */: - existingNumbers.add(parseInt(expression.text)); - break; - case 10 /* BigIntLiteral */: - const parsedBigInt = parseBigInt(endsWith(expression.text, "n") ? expression.text.slice(0, -1) : expression.text); - if (parsedBigInt) { - existingBigInts.add(pseudoBigIntToString(parsedBigInt)); - } - break; - } - } else { - const symbol = checker.getSymbolAtLocation(clause.expression); - if (symbol && symbol.valueDeclaration && isEnumMember(symbol.valueDeclaration)) { - const enumValue = checker.getConstantValue(symbol.valueDeclaration); - if (enumValue !== void 0) { - addValue(enumValue); - } - } - } - } + function createPatternMatcher(pattern) { + const stringToWordSpans = /* @__PURE__ */ new Map(); + const dotSeparatedSegments = pattern.trim().split(".").map((p) => createSegment(p.trim())); + if (dotSeparatedSegments.length === 1 && dotSeparatedSegments[0].totalTextChunk.text === "") { + return { + getMatchForLastSegmentOfPattern: () => createPatternMatch( + 2 /* substring */, + /*isCaseSensitive*/ + true + ), + getFullMatch: () => createPatternMatch( + 2 /* substring */, + /*isCaseSensitive*/ + true + ), + patternContainsDots: false + }; } + if (dotSeparatedSegments.some((segment) => !segment.subWordTextChunks.length)) + return void 0; return { - addValue, - hasValue + getFullMatch: (containers, candidate) => getFullMatch(containers, candidate, dotSeparatedSegments, stringToWordSpans), + getMatchForLastSegmentOfPattern: (candidate) => matchSegment(candidate, last(dotSeparatedSegments), stringToWordSpans), + patternContainsDots: dotSeparatedSegments.length > 1 }; - function addValue(value) { - switch (typeof value) { - case "string": - existingStrings.add(value); - break; - case "number": - existingNumbers.add(value); - } - } - function hasValue(value) { - switch (typeof value) { - case "string": - return existingStrings.has(value); - case "number": - return existingNumbers.has(value); - case "object": - return existingBigInts.has(pseudoBigIntToString(value)); - } - } } - function fileShouldUseJavaScriptRequire(file, program, host, preferRequire) { - var _a; - const fileName = typeof file === "string" ? file : file.fileName; - if (!hasJSFileExtension(fileName)) { - return false; - } - const compilerOptions = program.getCompilerOptions(); - const moduleKind = getEmitModuleKind(compilerOptions); - const impliedNodeFormat = typeof file === "string" ? getImpliedNodeFormatForFile(toPath(file, host.getCurrentDirectory(), hostGetCanonicalFileName(host)), (_a = program.getPackageJsonInfoCache) == null ? void 0 : _a.call(program), host, compilerOptions) : file.impliedNodeFormat; - if (impliedNodeFormat === 99 /* ESNext */) { - return false; - } - if (impliedNodeFormat === 1 /* CommonJS */) { - return true; + function getFullMatch(candidateContainers, candidate, dotSeparatedSegments, stringToWordSpans) { + const candidateMatch = matchSegment(candidate, last(dotSeparatedSegments), stringToWordSpans); + if (!candidateMatch) { + return void 0; } - if (compilerOptions.verbatimModuleSyntax && moduleKind === 1 /* CommonJS */) { - return true; + if (dotSeparatedSegments.length - 1 > candidateContainers.length) { + return void 0; } - if (compilerOptions.verbatimModuleSyntax && emitModuleKindIsNonNodeESM(moduleKind)) { - return false; + let bestMatch; + for (let i = dotSeparatedSegments.length - 2, j = candidateContainers.length - 1; i >= 0; i -= 1, j -= 1) { + bestMatch = betterMatch(bestMatch, matchSegment(candidateContainers[j], dotSeparatedSegments[i], stringToWordSpans)); } - if (typeof file === "object") { - if (file.commonJsModuleIndicator) { - return true; - } - if (file.externalModuleIndicator) { - return false; - } + return bestMatch; + } + function getWordSpans(word, stringToWordSpans) { + let spans = stringToWordSpans.get(word); + if (!spans) { + stringToWordSpans.set(word, spans = breakIntoWordSpans(word)); } - return preferRequire; + return spans; } - var scanner, SemanticMeaning, tripleSlashDirectivePrefixRegex, typeKeywords, QuotePreference, displayPartWriter, lineFeed2, ANONYMOUS, syntaxMayBeASICandidate; - var init_utilities4 = __esm({ - "src/services/utilities.ts"() { - "use strict"; - init_ts4(); - scanner = createScanner( - 99 /* Latest */, - /*skipTrivia*/ - true - ); - SemanticMeaning = /* @__PURE__ */ ((SemanticMeaning3) => { - SemanticMeaning3[SemanticMeaning3["None"] = 0] = "None"; - SemanticMeaning3[SemanticMeaning3["Value"] = 1] = "Value"; - SemanticMeaning3[SemanticMeaning3["Type"] = 2] = "Type"; - SemanticMeaning3[SemanticMeaning3["Namespace"] = 4] = "Namespace"; - SemanticMeaning3[SemanticMeaning3["All"] = 7] = "All"; - return SemanticMeaning3; - })(SemanticMeaning || {}); - tripleSlashDirectivePrefixRegex = /^\/\/\/\s* { - QuotePreference7[QuotePreference7["Single"] = 0] = "Single"; - QuotePreference7[QuotePreference7["Double"] = 1] = "Double"; - return QuotePreference7; - })(QuotePreference || {}); - displayPartWriter = getDisplayPartWriter(); - lineFeed2 = "\n"; - ANONYMOUS = "anonymous function"; - syntaxMayBeASICandidate = or( - syntaxRequiresTrailingCommaOrSemicolonOrASI, - syntaxRequiresTrailingFunctionBlockOrSemicolonOrASI, - syntaxRequiresTrailingModuleBlockOrSemicolonOrASI, - syntaxRequiresTrailingSemicolonOrASI + function matchTextChunk(candidate, chunk, stringToWordSpans) { + const index = indexOfIgnoringCase(candidate, chunk.textLowerCase); + if (index === 0) { + return createPatternMatch( + chunk.text.length === candidate.length ? 0 /* exact */ : 1 /* prefix */, + /*isCaseSensitive:*/ + startsWith(candidate, chunk.text) ); } - }); - - // src/services/exportInfoMap.ts - function createCacheableExportInfoMap(host) { - let exportInfoId = 1; - const exportInfo = createMultiMap(); - const symbols = /* @__PURE__ */ new Map(); - const packages = /* @__PURE__ */ new Map(); - let usableByFileName; - const cache = { - isUsableByFile: (importingFile) => importingFile === usableByFileName, - isEmpty: () => !exportInfo.size, - clear: () => { - exportInfo.clear(); - symbols.clear(); - usableByFileName = void 0; - }, - add: (importingFile, symbol, symbolTableKey, moduleSymbol, moduleFile, exportKind, isFromPackageJson, checker) => { - if (importingFile !== usableByFileName) { - cache.clear(); - usableByFileName = importingFile; - } - let packageName; - if (moduleFile) { - const nodeModulesPathParts = getNodeModulePathParts(moduleFile.fileName); - if (nodeModulesPathParts) { - const { topLevelNodeModulesIndex, topLevelPackageNameIndex, packageRootIndex } = nodeModulesPathParts; - packageName = unmangleScopedPackageName(getPackageNameFromTypesPackageName(moduleFile.fileName.substring(topLevelPackageNameIndex + 1, packageRootIndex))); - if (startsWith(importingFile, moduleFile.path.substring(0, topLevelNodeModulesIndex))) { - const prevDeepestNodeModulesPath = packages.get(packageName); - const nodeModulesPath = moduleFile.fileName.substring(0, topLevelPackageNameIndex + 1); - if (prevDeepestNodeModulesPath) { - const prevDeepestNodeModulesIndex = prevDeepestNodeModulesPath.indexOf(nodeModulesPathPart); - if (topLevelNodeModulesIndex > prevDeepestNodeModulesIndex) { - packages.set(packageName, nodeModulesPath); - } - } else { - packages.set(packageName, nodeModulesPath); - } - } - } + if (chunk.isLowerCase) { + if (index === -1) + return void 0; + const wordSpans = getWordSpans(candidate, stringToWordSpans); + for (const span of wordSpans) { + if (partStartsWith( + candidate, + span, + chunk.text, + /*ignoreCase*/ + true + )) { + return createPatternMatch( + 2 /* substring */, + /*isCaseSensitive:*/ + partStartsWith( + candidate, + span, + chunk.text, + /*ignoreCase*/ + false + ) + ); } - const isDefault = exportKind === 1 /* Default */; - const namedSymbol = isDefault && getLocalSymbolForExportDefault(symbol) || symbol; - const names = exportKind === 0 /* Named */ || isExternalModuleSymbol(namedSymbol) ? unescapeLeadingUnderscores(symbolTableKey) : getNamesForExportedSymbol( - namedSymbol, - /*scriptTarget*/ - void 0 + } + if (chunk.text.length < candidate.length && isUpperCaseLetter(candidate.charCodeAt(index))) { + return createPatternMatch( + 2 /* substring */, + /*isCaseSensitive*/ + false ); - const symbolName2 = typeof names === "string" ? names : names[0]; - const capitalizedSymbolName = typeof names === "string" ? void 0 : names[1]; - const moduleName = stripQuotes(moduleSymbol.name); - const id = exportInfoId++; - const target = skipAlias(symbol, checker); - const storedSymbol = symbol.flags & 33554432 /* Transient */ ? void 0 : symbol; - const storedModuleSymbol = moduleSymbol.flags & 33554432 /* Transient */ ? void 0 : moduleSymbol; - if (!storedSymbol || !storedModuleSymbol) - symbols.set(id, [symbol, moduleSymbol]); - exportInfo.add(key(symbolName2, symbol, isExternalModuleNameRelative(moduleName) ? void 0 : moduleName, checker), { - id, - symbolTableKey, - symbolName: symbolName2, - capitalizedSymbolName, - moduleName, - moduleFile, - moduleFileName: moduleFile == null ? void 0 : moduleFile.fileName, - packageName, - exportKind, - targetFlags: target.flags, - isFromPackageJson, - symbol: storedSymbol, - moduleSymbol: storedModuleSymbol - }); - }, - get: (importingFile, key2) => { - if (importingFile !== usableByFileName) - return; - const result = exportInfo.get(key2); - return result == null ? void 0 : result.map(rehydrateCachedInfo); - }, - search: (importingFile, preferCapitalized, matches, action) => { - if (importingFile !== usableByFileName) - return; - return forEachEntry(exportInfo, (info, key2) => { - const { symbolName: symbolName2, ambientModuleName } = parseKey(key2); - const name = preferCapitalized && info[0].capitalizedSymbolName || symbolName2; - if (matches(name, info[0].targetFlags)) { - const rehydrated = info.map(rehydrateCachedInfo); - const filtered = rehydrated.filter((r, i) => isNotShadowedByDeeperNodeModulesPackage(r, info[i].packageName)); - if (filtered.length) { - const res = action(filtered, name, !!ambientModuleName, key2); - if (res !== void 0) - return res; - } - } - }); - }, - releaseSymbols: () => { - symbols.clear(); - }, - onFileChanged: (oldSourceFile, newSourceFile, typeAcquisitionEnabled) => { - if (fileIsGlobalOnly(oldSourceFile) && fileIsGlobalOnly(newSourceFile)) { - return false; - } - if (usableByFileName && usableByFileName !== newSourceFile.path || // If ATA is enabled, auto-imports uses existing imports to guess whether you want auto-imports from node. - // Adding or removing imports from node could change the outcome of that guess, so could change the suggestions list. - typeAcquisitionEnabled && consumesNodeCoreModules(oldSourceFile) !== consumesNodeCoreModules(newSourceFile) || // Module agumentation and ambient module changes can add or remove exports available to be auto-imported. - // Changes elsewhere in the file can change the *type* of an export in a module augmentation, - // but type info is gathered in getCompletionEntryDetails, which doesn't use the cache. - !arrayIsEqualTo(oldSourceFile.moduleAugmentations, newSourceFile.moduleAugmentations) || !ambientModuleDeclarationsAreEqual(oldSourceFile, newSourceFile)) { - cache.clear(); - return true; - } - usableByFileName = newSourceFile.path; - return false; } - }; - if (Debug.isDebugging) { - Object.defineProperty(cache, "__cache", { get: () => exportInfo }); - } - return cache; - function rehydrateCachedInfo(info) { - if (info.symbol && info.moduleSymbol) - return info; - const { id, exportKind, targetFlags, isFromPackageJson, moduleFileName } = info; - const [cachedSymbol, cachedModuleSymbol] = symbols.get(id) || emptyArray; - if (cachedSymbol && cachedModuleSymbol) { - return { - symbol: cachedSymbol, - moduleSymbol: cachedModuleSymbol, - moduleFileName, - exportKind, - targetFlags, - isFromPackageJson - }; + } else { + if (candidate.indexOf(chunk.text) > 0) { + return createPatternMatch( + 2 /* substring */, + /*isCaseSensitive*/ + true + ); + } + if (chunk.characterSpans.length > 0) { + const candidateParts = getWordSpans(candidate, stringToWordSpans); + const isCaseSensitive = tryCamelCaseMatch( + candidate, + candidateParts, + chunk, + /*ignoreCase*/ + false + ) ? true : tryCamelCaseMatch( + candidate, + candidateParts, + chunk, + /*ignoreCase*/ + true + ) ? false : void 0; + if (isCaseSensitive !== void 0) { + return createPatternMatch(3 /* camelCase */, isCaseSensitive); + } } - const checker = (isFromPackageJson ? host.getPackageJsonAutoImportProvider() : host.getCurrentProgram()).getTypeChecker(); - const moduleSymbol = info.moduleSymbol || cachedModuleSymbol || Debug.checkDefined(info.moduleFile ? checker.getMergedSymbol(info.moduleFile.symbol) : checker.tryFindAmbientModule(info.moduleName)); - const symbol = info.symbol || cachedSymbol || Debug.checkDefined( - exportKind === 2 /* ExportEquals */ ? checker.resolveExternalModuleSymbol(moduleSymbol) : checker.tryGetMemberInModuleExportsAndProperties(unescapeLeadingUnderscores(info.symbolTableKey), moduleSymbol), - `Could not find symbol '${info.symbolName}' by key '${info.symbolTableKey}' in module ${moduleSymbol.name}` - ); - symbols.set(id, [symbol, moduleSymbol]); - return { - symbol, - moduleSymbol, - moduleFileName, - exportKind, - targetFlags, - isFromPackageJson - }; - } - function key(importedName, symbol, ambientModuleName, checker) { - const moduleKey = ambientModuleName || ""; - return `${importedName}|${getSymbolId(skipAlias(symbol, checker))}|${moduleKey}`; } - function parseKey(key2) { - const symbolName2 = key2.substring(0, key2.indexOf("|")); - const moduleKey = key2.substring(key2.lastIndexOf("|") + 1); - const ambientModuleName = moduleKey === "" ? void 0 : moduleKey; - return { symbolName: symbolName2, ambientModuleName }; + } + function matchSegment(candidate, segment, stringToWordSpans) { + if (every2(segment.totalTextChunk.text, (ch) => ch !== 32 /* space */ && ch !== 42 /* asterisk */)) { + const match = matchTextChunk(candidate, segment.totalTextChunk, stringToWordSpans); + if (match) + return match; } - function fileIsGlobalOnly(file) { - return !file.commonJsModuleIndicator && !file.externalModuleIndicator && !file.moduleAugmentations && !file.ambientModuleNames; + const subWordTextChunks = segment.subWordTextChunks; + let bestMatch; + for (const subWordTextChunk of subWordTextChunks) { + bestMatch = betterMatch(bestMatch, matchTextChunk(candidate, subWordTextChunk, stringToWordSpans)); } - function ambientModuleDeclarationsAreEqual(oldSourceFile, newSourceFile) { - if (!arrayIsEqualTo(oldSourceFile.ambientModuleNames, newSourceFile.ambientModuleNames)) { + return bestMatch; + } + function betterMatch(a, b) { + return min([a, b], compareMatches); + } + function compareMatches(a, b) { + return a === void 0 ? 1 /* GreaterThan */ : b === void 0 ? -1 /* LessThan */ : compareValues(a.kind, b.kind) || compareBooleans(!a.isCaseSensitive, !b.isCaseSensitive); + } + function partStartsWith(candidate, candidateSpan, pattern, ignoreCase, patternSpan = { start: 0, length: pattern.length }) { + return patternSpan.length <= candidateSpan.length && everyInRange(0, patternSpan.length, (i) => equalChars(pattern.charCodeAt(patternSpan.start + i), candidate.charCodeAt(candidateSpan.start + i), ignoreCase)); + } + function equalChars(ch1, ch2, ignoreCase) { + return ignoreCase ? toLowerCase2(ch1) === toLowerCase2(ch2) : ch1 === ch2; + } + function tryCamelCaseMatch(candidate, candidateParts, chunk, ignoreCase) { + const chunkCharacterSpans = chunk.characterSpans; + let currentCandidate = 0; + let currentChunkSpan = 0; + let firstMatch; + let contiguous; + while (true) { + if (currentChunkSpan === chunkCharacterSpans.length) { + return true; + } else if (currentCandidate === candidateParts.length) { return false; } - let oldFileStatementIndex = -1; - let newFileStatementIndex = -1; - for (const ambientModuleName of newSourceFile.ambientModuleNames) { - const isMatchingModuleDeclaration = (node) => isNonGlobalAmbientModule(node) && node.name.text === ambientModuleName; - oldFileStatementIndex = findIndex(oldSourceFile.statements, isMatchingModuleDeclaration, oldFileStatementIndex + 1); - newFileStatementIndex = findIndex(newSourceFile.statements, isMatchingModuleDeclaration, newFileStatementIndex + 1); - if (oldSourceFile.statements[oldFileStatementIndex] !== newSourceFile.statements[newFileStatementIndex]) { - return false; + let candidatePart = candidateParts[currentCandidate]; + let gotOneMatchThisCandidate = false; + for (; currentChunkSpan < chunkCharacterSpans.length; currentChunkSpan++) { + const chunkCharacterSpan = chunkCharacterSpans[currentChunkSpan]; + if (gotOneMatchThisCandidate) { + if (!isUpperCaseLetter(chunk.text.charCodeAt(chunkCharacterSpans[currentChunkSpan - 1].start)) || !isUpperCaseLetter(chunk.text.charCodeAt(chunkCharacterSpans[currentChunkSpan].start))) { + break; + } + } + if (!partStartsWith(candidate, candidatePart, chunk.text, ignoreCase, chunkCharacterSpan)) { + break; } + gotOneMatchThisCandidate = true; + firstMatch = firstMatch === void 0 ? currentCandidate : firstMatch; + contiguous = contiguous === void 0 ? true : contiguous; + candidatePart = createTextSpan(candidatePart.start + chunkCharacterSpan.length, candidatePart.length - chunkCharacterSpan.length); + } + if (!gotOneMatchThisCandidate && contiguous !== void 0) { + contiguous = false; } + currentCandidate++; + } + } + function createSegment(text) { + return { + totalTextChunk: createTextChunk(text), + subWordTextChunks: breakPatternIntoTextChunks(text) + }; + } + function isUpperCaseLetter(ch) { + if (ch >= 65 /* A */ && ch <= 90 /* Z */) { return true; } - function isNotShadowedByDeeperNodeModulesPackage(info, packageName) { - if (!packageName || !info.moduleFileName) - return true; - const typingsCacheLocation = host.getGlobalTypingsCacheLocation(); - if (typingsCacheLocation && startsWith(info.moduleFileName, typingsCacheLocation)) - return true; - const packageDeepestNodeModulesPath = packages.get(packageName); - return !packageDeepestNodeModulesPath || startsWith(info.moduleFileName, packageDeepestNodeModulesPath); + if (ch < 127 /* maxAsciiCharacter */ || !isUnicodeIdentifierStart(ch, 99 /* Latest */)) { + return false; } + const str = String.fromCharCode(ch); + return str === str.toUpperCase(); } - function isImportableFile(program, from, to, preferences, packageJsonFilter, moduleSpecifierResolutionHost, moduleSpecifierCache) { - var _a; - if (from === to) + function isLowerCaseLetter(ch) { + if (ch >= 97 /* a */ && ch <= 122 /* z */) { + return true; + } + if (ch < 127 /* maxAsciiCharacter */ || !isUnicodeIdentifierStart(ch, 99 /* Latest */)) { return false; - const cachedResult = moduleSpecifierCache == null ? void 0 : moduleSpecifierCache.get(from.path, to.path, preferences, {}); - if ((cachedResult == null ? void 0 : cachedResult.isBlockedByPackageJsonDependencies) !== void 0) { - return !cachedResult.isBlockedByPackageJsonDependencies; } - const getCanonicalFileName = hostGetCanonicalFileName(moduleSpecifierResolutionHost); - const globalTypingsCache = (_a = moduleSpecifierResolutionHost.getGlobalTypingsCacheLocation) == null ? void 0 : _a.call(moduleSpecifierResolutionHost); - const hasImportablePath = !!ts_moduleSpecifiers_exports.forEachFileNameOfModule( - from.fileName, - to.fileName, - moduleSpecifierResolutionHost, - /*preferSymlinks*/ - false, - (toPath3) => { - const toFile = program.getSourceFile(toPath3); - return (toFile === to || !toFile) && isImportablePath(from.fileName, toPath3, getCanonicalFileName, globalTypingsCache); + const str = String.fromCharCode(ch); + return str === str.toLowerCase(); + } + function indexOfIgnoringCase(str, value) { + const n = str.length - value.length; + for (let start = 0; start <= n; start++) { + if (every2(value, (valueChar, i) => toLowerCase2(str.charCodeAt(i + start)) === valueChar)) { + return start; } - ); - if (packageJsonFilter) { - const isAutoImportable = hasImportablePath && packageJsonFilter.allowsImportingSourceFile(to, moduleSpecifierResolutionHost); - moduleSpecifierCache == null ? void 0 : moduleSpecifierCache.setBlockedByPackageJsonDependencies(from.path, to.path, preferences, {}, !isAutoImportable); - return isAutoImportable; } - return hasImportablePath; - } - function isImportablePath(fromPath, toPath3, getCanonicalFileName, globalCachePath) { - const toNodeModules = forEachAncestorDirectory(toPath3, (ancestor) => getBaseFileName(ancestor) === "node_modules" ? ancestor : void 0); - const toNodeModulesParent = toNodeModules && getDirectoryPath(getCanonicalFileName(toNodeModules)); - return toNodeModulesParent === void 0 || startsWith(getCanonicalFileName(fromPath), toNodeModulesParent) || !!globalCachePath && startsWith(getCanonicalFileName(globalCachePath), toNodeModulesParent); + return -1; } - function forEachExternalModuleToImportFrom(program, host, preferences, useAutoImportProvider, cb) { - var _a, _b; - const useCaseSensitiveFileNames = hostUsesCaseSensitiveFileNames(host); - const excludePatterns = preferences.autoImportFileExcludePatterns && mapDefined(preferences.autoImportFileExcludePatterns, (spec) => { - const pattern = getPatternFromSpec(spec, "", "exclude"); - return pattern ? getRegexFromPattern(pattern, useCaseSensitiveFileNames) : void 0; - }); - forEachExternalModule(program.getTypeChecker(), program.getSourceFiles(), excludePatterns, (module2, file) => cb( - module2, - file, - program, - /*isFromPackageJson*/ - false - )); - const autoImportProvider = useAutoImportProvider && ((_a = host.getPackageJsonAutoImportProvider) == null ? void 0 : _a.call(host)); - if (autoImportProvider) { - const start = timestamp(); - const checker = program.getTypeChecker(); - forEachExternalModule(autoImportProvider.getTypeChecker(), autoImportProvider.getSourceFiles(), excludePatterns, (module2, file) => { - if (file && !program.getSourceFile(file.fileName) || !file && !checker.resolveName( - module2.name, - /*location*/ - void 0, - 1536 /* Module */, - /*excludeGlobals*/ - false - )) { - cb( - module2, - file, - autoImportProvider, - /*isFromPackageJson*/ - true - ); - } - }); - (_b = host.log) == null ? void 0 : _b.call(host, `forEachExternalModuleToImportFrom autoImportProvider: ${timestamp() - start}`); + function toLowerCase2(ch) { + if (ch >= 65 /* A */ && ch <= 90 /* Z */) { + return 97 /* a */ + (ch - 65 /* A */); } + if (ch < 127 /* maxAsciiCharacter */) { + return ch; + } + return String.fromCharCode(ch).toLowerCase().charCodeAt(0); } - function forEachExternalModule(checker, allSourceFiles, excludePatterns, cb) { - var _a; - const isExcluded = excludePatterns && ((fileName) => excludePatterns.some((p) => p.test(fileName))); - for (const ambient of checker.getAmbientModules()) { - if (!stringContains(ambient.name, "*") && !(excludePatterns && ((_a = ambient.declarations) == null ? void 0 : _a.every((d) => isExcluded(d.getSourceFile().fileName))))) { - cb( - ambient, - /*sourceFile*/ - void 0 - ); + function isDigit2(ch) { + return ch >= 48 /* _0 */ && ch <= 57 /* _9 */; + } + function isWordChar(ch) { + return isUpperCaseLetter(ch) || isLowerCaseLetter(ch) || isDigit2(ch) || ch === 95 /* _ */ || ch === 36 /* $ */; + } + function breakPatternIntoTextChunks(pattern) { + const result = []; + let wordStart = 0; + let wordLength = 0; + for (let i = 0; i < pattern.length; i++) { + const ch = pattern.charCodeAt(i); + if (isWordChar(ch)) { + if (wordLength === 0) { + wordStart = i; + } + wordLength++; + } else { + if (wordLength > 0) { + result.push(createTextChunk(pattern.substr(wordStart, wordLength))); + wordLength = 0; + } } } - for (const sourceFile of allSourceFiles) { - if (isExternalOrCommonJsModule(sourceFile) && !(isExcluded == null ? void 0 : isExcluded(sourceFile.fileName))) { - cb(checker.getMergedSymbol(sourceFile.symbol), sourceFile); - } + if (wordLength > 0) { + result.push(createTextChunk(pattern.substr(wordStart, wordLength))); } + return result; } - function getExportInfoMap(importingFile, host, program, preferences, cancellationToken) { - var _a, _b, _c, _d, _e; - const start = timestamp(); - (_a = host.getPackageJsonAutoImportProvider) == null ? void 0 : _a.call(host); - const cache = ((_b = host.getCachedExportInfoMap) == null ? void 0 : _b.call(host)) || createCacheableExportInfoMap({ - getCurrentProgram: () => program, - getPackageJsonAutoImportProvider: () => { - var _a2; - return (_a2 = host.getPackageJsonAutoImportProvider) == null ? void 0 : _a2.call(host); - }, - getGlobalTypingsCacheLocation: () => { - var _a2; - return (_a2 = host.getGlobalTypingsCacheLocation) == null ? void 0 : _a2.call(host); + function createTextChunk(text) { + const textLowerCase = text.toLowerCase(); + return { + text, + textLowerCase, + isLowerCase: text === textLowerCase, + characterSpans: breakIntoCharacterSpans(text) + }; + } + function breakIntoCharacterSpans(identifier) { + return breakIntoSpans( + identifier, + /*word*/ + false + ); + } + function breakIntoWordSpans(identifier) { + return breakIntoSpans( + identifier, + /*word*/ + true + ); + } + function breakIntoSpans(identifier, word) { + const result = []; + let wordStart = 0; + for (let i = 1; i < identifier.length; i++) { + const lastIsDigit = isDigit2(identifier.charCodeAt(i - 1)); + const currentIsDigit = isDigit2(identifier.charCodeAt(i)); + const hasTransitionFromLowerToUpper = transitionFromLowerToUpper(identifier, word, i); + const hasTransitionFromUpperToLower = word && transitionFromUpperToLower(identifier, i, wordStart); + if (charIsPunctuation(identifier.charCodeAt(i - 1)) || charIsPunctuation(identifier.charCodeAt(i)) || lastIsDigit !== currentIsDigit || hasTransitionFromLowerToUpper || hasTransitionFromUpperToLower) { + if (!isAllPunctuation(identifier, wordStart, i)) { + result.push(createTextSpan(wordStart, i - wordStart)); + } + wordStart = i; } - }); - if (cache.isUsableByFile(importingFile.path)) { - (_c = host.log) == null ? void 0 : _c.call(host, "getExportInfoMap: cache hit"); - return cache; } - (_d = host.log) == null ? void 0 : _d.call(host, "getExportInfoMap: cache miss or empty; calculating new results"); - const compilerOptions = program.getCompilerOptions(); - let moduleCount = 0; - try { - forEachExternalModuleToImportFrom( - program, - host, - preferences, - /*useAutoImportProvider*/ - true, - (moduleSymbol, moduleFile, program2, isFromPackageJson) => { - if (++moduleCount % 100 === 0) - cancellationToken == null ? void 0 : cancellationToken.throwIfCancellationRequested(); - const seenExports = /* @__PURE__ */ new Map(); - const checker = program2.getTypeChecker(); - const defaultInfo = getDefaultLikeExportInfo(moduleSymbol, checker, compilerOptions); - if (defaultInfo && isImportableSymbol(defaultInfo.symbol, checker)) { - cache.add( - importingFile.path, - defaultInfo.symbol, - defaultInfo.exportKind === 1 /* Default */ ? "default" /* Default */ : "export=" /* ExportEquals */, - moduleSymbol, - moduleFile, - defaultInfo.exportKind, - isFromPackageJson, - checker - ); - } - checker.forEachExportAndPropertyOfModule(moduleSymbol, (exported, key) => { - if (exported !== (defaultInfo == null ? void 0 : defaultInfo.symbol) && isImportableSymbol(exported, checker) && addToSeen(seenExports, key)) { - cache.add( - importingFile.path, - exported, - key, - moduleSymbol, - moduleFile, - 0 /* Named */, - isFromPackageJson, - checker - ); - } - }); - } - ); - } catch (err) { - cache.clear(); - throw err; + if (!isAllPunctuation(identifier, wordStart, identifier.length)) { + result.push(createTextSpan(wordStart, identifier.length - wordStart)); } - (_e = host.log) == null ? void 0 : _e.call(host, `getExportInfoMap: done in ${timestamp() - start} ms`); - return cache; + return result; } - function getDefaultLikeExportInfo(moduleSymbol, checker, compilerOptions) { - const exported = getDefaultLikeExportWorker(moduleSymbol, checker); - if (!exported) - return void 0; - const { symbol, exportKind } = exported; - const info = getDefaultExportInfoWorker(symbol, checker, compilerOptions); - return info && { symbol, exportKind, ...info }; + function charIsPunctuation(ch) { + switch (ch) { + case 33 /* exclamation */: + case 34 /* doubleQuote */: + case 35 /* hash */: + case 37 /* percent */: + case 38 /* ampersand */: + case 39 /* singleQuote */: + case 40 /* openParen */: + case 41 /* closeParen */: + case 42 /* asterisk */: + case 44 /* comma */: + case 45 /* minus */: + case 46 /* dot */: + case 47 /* slash */: + case 58 /* colon */: + case 59 /* semicolon */: + case 63 /* question */: + case 64 /* at */: + case 91 /* openBracket */: + case 92 /* backslash */: + case 93 /* closeBracket */: + case 95 /* _ */: + case 123 /* openBrace */: + case 125 /* closeBrace */: + return true; + } + return false; } - function isImportableSymbol(symbol, checker) { - return !checker.isUndefinedSymbol(symbol) && !checker.isUnknownSymbol(symbol) && !isKnownSymbol(symbol) && !isPrivateIdentifierSymbol(symbol); + function isAllPunctuation(identifier, start, end) { + return every2(identifier, (ch) => charIsPunctuation(ch) && ch !== 95 /* _ */, start, end); } - function getDefaultLikeExportWorker(moduleSymbol, checker) { - const exportEquals = checker.resolveExternalModuleSymbol(moduleSymbol); - if (exportEquals !== moduleSymbol) - return { symbol: exportEquals, exportKind: 2 /* ExportEquals */ }; - const defaultExport = checker.tryGetMemberInModuleExports("default" /* Default */, moduleSymbol); - if (defaultExport) - return { symbol: defaultExport, exportKind: 1 /* Default */ }; + function transitionFromUpperToLower(identifier, index, wordStart) { + return index !== wordStart && index + 1 < identifier.length && isUpperCaseLetter(identifier.charCodeAt(index)) && isLowerCaseLetter(identifier.charCodeAt(index + 1)) && every2(identifier, isUpperCaseLetter, wordStart, index); } - function getDefaultExportInfoWorker(defaultExport, checker, compilerOptions) { - const localSymbol = getLocalSymbolForExportDefault(defaultExport); - if (localSymbol) - return { resolvedSymbol: localSymbol, name: localSymbol.name }; - const name = getNameForExportDefault(defaultExport); - if (name !== void 0) - return { resolvedSymbol: defaultExport, name }; - if (defaultExport.flags & 2097152 /* Alias */) { - const aliased = checker.getImmediateAliasedSymbol(defaultExport); - if (aliased && aliased.parent) { - return getDefaultExportInfoWorker(aliased, checker, compilerOptions); + function transitionFromLowerToUpper(identifier, word, index) { + const lastIsUpper = isUpperCaseLetter(identifier.charCodeAt(index - 1)); + const currentIsUpper = isUpperCaseLetter(identifier.charCodeAt(index)); + return currentIsUpper && (!word || !lastIsUpper); + } + function everyInRange(start, end, pred) { + for (let i = start; i < end; i++) { + if (!pred(i)) { + return false; } } - if (defaultExport.escapedName !== "default" /* Default */ && defaultExport.escapedName !== "export=" /* ExportEquals */) { - return { resolvedSymbol: defaultExport, name: defaultExport.getName() }; - } - return { resolvedSymbol: defaultExport, name: getNameForExportedSymbol(defaultExport, compilerOptions.target) }; + return true; } - function getNameForExportDefault(symbol) { - return symbol.declarations && firstDefined(symbol.declarations, (declaration) => { - var _a; - if (isExportAssignment(declaration)) { - return (_a = tryCast(skipOuterExpressions(declaration.expression), isIdentifier)) == null ? void 0 : _a.text; - } else if (isExportSpecifier(declaration)) { - Debug.assert(declaration.name.text === "default" /* Default */, "Expected the specifier to be a default export"); - return declaration.propertyName && declaration.propertyName.text; - } - }); + function every2(s, pred, start = 0, end = s.length) { + return everyInRange(start, end, (i) => pred(s.charCodeAt(i), i)); } - var ImportKind, ExportKind; - var init_exportInfoMap = __esm({ - "src/services/exportInfoMap.ts"() { + var PatternMatchKind; + var init_patternMatcher = __esm({ + "src/services/patternMatcher.ts"() { "use strict"; init_ts4(); - ImportKind = /* @__PURE__ */ ((ImportKind2) => { - ImportKind2[ImportKind2["Named"] = 0] = "Named"; - ImportKind2[ImportKind2["Default"] = 1] = "Default"; - ImportKind2[ImportKind2["Namespace"] = 2] = "Namespace"; - ImportKind2[ImportKind2["CommonJS"] = 3] = "CommonJS"; - return ImportKind2; - })(ImportKind || {}); - ExportKind = /* @__PURE__ */ ((ExportKind3) => { - ExportKind3[ExportKind3["Named"] = 0] = "Named"; - ExportKind3[ExportKind3["Default"] = 1] = "Default"; - ExportKind3[ExportKind3["ExportEquals"] = 2] = "ExportEquals"; - ExportKind3[ExportKind3["UMD"] = 3] = "UMD"; - return ExportKind3; - })(ExportKind || {}); + PatternMatchKind = /* @__PURE__ */ ((PatternMatchKind2) => { + PatternMatchKind2[PatternMatchKind2["exact"] = 0] = "exact"; + PatternMatchKind2[PatternMatchKind2["prefix"] = 1] = "prefix"; + PatternMatchKind2[PatternMatchKind2["substring"] = 2] = "substring"; + PatternMatchKind2[PatternMatchKind2["camelCase"] = 3] = "camelCase"; + return PatternMatchKind2; + })(PatternMatchKind || {}); } }); - // src/services/classifier.ts - function createClassifier() { - const scanner2 = createScanner( - 99 /* Latest */, - /*skipTrivia*/ - false - ); - function getClassificationsForLine(text, lexState, syntacticClassifierAbsent) { - return convertClassificationsToResult(getEncodedLexicalClassifications(text, lexState, syntacticClassifierAbsent), text); + // src/services/preProcess.ts + function preProcessFile(sourceText, readImportFiles = true, detectJavaScriptImports = false) { + const pragmaContext = { + languageVersion: 1 /* ES5 */, + // controls whether the token scanner considers unicode identifiers or not - shouldn't matter, since we're only using it for trivia + pragmas: void 0, + checkJsDirective: void 0, + referencedFiles: [], + typeReferenceDirectives: [], + libReferenceDirectives: [], + amdDependencies: [], + hasNoDefaultLib: void 0, + moduleName: void 0 + }; + const importedFiles = []; + let ambientExternalModules; + let lastToken; + let currentToken; + let braceNesting = 0; + let externalModule = false; + function nextToken() { + lastToken = currentToken; + currentToken = scanner.scan(); + if (currentToken === 19 /* OpenBraceToken */) { + braceNesting++; + } else if (currentToken === 20 /* CloseBraceToken */) { + braceNesting--; + } + return currentToken; } - function getEncodedLexicalClassifications(text, lexState, syntacticClassifierAbsent) { - let token = 0 /* Unknown */; - let lastNonTriviaToken = 0 /* Unknown */; - const templateStack = []; - const { prefix, pushTemplate } = getPrefixFromLexState(lexState); - text = prefix + text; - const offset = prefix.length; - if (pushTemplate) { - templateStack.push(16 /* TemplateHead */); + function getFileReference() { + const fileName = scanner.getTokenValue(); + const pos = scanner.getTokenStart(); + return { fileName, pos, end: pos + fileName.length }; + } + function recordAmbientExternalModule() { + if (!ambientExternalModules) { + ambientExternalModules = []; } - scanner2.setText(text); - let endOfLineState = 0 /* None */; - const spans = []; - let angleBracketStack = 0; - do { - token = scanner2.scan(); - if (!isTrivia(token)) { - handleToken(); - lastNonTriviaToken = token; - } - const end = scanner2.getTokenEnd(); - pushEncodedClassification(scanner2.getTokenStart(), end, offset, classFromKind(token), spans); - if (end >= text.length) { - const end2 = getNewEndOfLineState(scanner2, token, lastOrUndefined(templateStack)); - if (end2 !== void 0) { - endOfLineState = end2; + ambientExternalModules.push({ ref: getFileReference(), depth: braceNesting }); + } + function recordModuleName() { + importedFiles.push(getFileReference()); + markAsExternalModuleIfTopLevel(); + } + function markAsExternalModuleIfTopLevel() { + if (braceNesting === 0) { + externalModule = true; + } + } + function tryConsumeDeclare() { + let token = scanner.getToken(); + if (token === 138 /* DeclareKeyword */) { + token = nextToken(); + if (token === 144 /* ModuleKeyword */) { + token = nextToken(); + if (token === 11 /* StringLiteral */) { + recordAmbientExternalModule(); } } - } while (token !== 1 /* EndOfFileToken */); - function handleToken() { - switch (token) { - case 44 /* SlashToken */: - case 69 /* SlashEqualsToken */: - if (!noRegexTable[lastNonTriviaToken] && scanner2.reScanSlashToken() === 14 /* RegularExpressionLiteral */) { - token = 14 /* RegularExpressionLiteral */; - } - break; - case 30 /* LessThanToken */: - if (lastNonTriviaToken === 80 /* Identifier */) { - angleBracketStack++; + return true; + } + return false; + } + function tryConsumeImport() { + if (lastToken === 25 /* DotToken */) { + return false; + } + let token = scanner.getToken(); + if (token === 102 /* ImportKeyword */) { + token = nextToken(); + if (token === 21 /* OpenParenToken */) { + token = nextToken(); + if (token === 11 /* StringLiteral */ || token === 15 /* NoSubstitutionTemplateLiteral */) { + recordModuleName(); + return true; + } + } else if (token === 11 /* StringLiteral */) { + recordModuleName(); + return true; + } else { + if (token === 156 /* TypeKeyword */) { + const skipTypeKeyword = scanner.lookAhead(() => { + const token2 = scanner.scan(); + return token2 !== 161 /* FromKeyword */ && (token2 === 42 /* AsteriskToken */ || token2 === 19 /* OpenBraceToken */ || token2 === 80 /* Identifier */ || isKeyword(token2)); + }); + if (skipTypeKeyword) { + token = nextToken(); } - break; - case 32 /* GreaterThanToken */: - if (angleBracketStack > 0) { - angleBracketStack--; + } + if (token === 80 /* Identifier */ || isKeyword(token)) { + token = nextToken(); + if (token === 161 /* FromKeyword */) { + token = nextToken(); + if (token === 11 /* StringLiteral */) { + recordModuleName(); + return true; + } + } else if (token === 64 /* EqualsToken */) { + if (tryConsumeRequireCall( + /*skipCurrentToken*/ + true + )) { + return true; + } + } else if (token === 28 /* CommaToken */) { + token = nextToken(); + } else { + return true; } - break; - case 133 /* AnyKeyword */: - case 154 /* StringKeyword */: - case 150 /* NumberKeyword */: - case 136 /* BooleanKeyword */: - case 155 /* SymbolKeyword */: - if (angleBracketStack > 0 && !syntacticClassifierAbsent) { - token = 80 /* Identifier */; + } + if (token === 19 /* OpenBraceToken */) { + token = nextToken(); + while (token !== 20 /* CloseBraceToken */ && token !== 1 /* EndOfFileToken */) { + token = nextToken(); } - break; - case 16 /* TemplateHead */: - templateStack.push(token); - break; - case 19 /* OpenBraceToken */: - if (templateStack.length > 0) { - templateStack.push(token); + if (token === 20 /* CloseBraceToken */) { + token = nextToken(); + if (token === 161 /* FromKeyword */) { + token = nextToken(); + if (token === 11 /* StringLiteral */) { + recordModuleName(); + } + } } - break; - case 20 /* CloseBraceToken */: - if (templateStack.length > 0) { - const lastTemplateStackToken = lastOrUndefined(templateStack); - if (lastTemplateStackToken === 16 /* TemplateHead */) { - token = scanner2.reScanTemplateToken( - /*isTaggedTemplate*/ - false - ); - if (token === 18 /* TemplateTail */) { - templateStack.pop(); - } else { - Debug.assertEqual(token, 17 /* TemplateMiddle */, "Should have been a template middle."); + } else if (token === 42 /* AsteriskToken */) { + token = nextToken(); + if (token === 130 /* AsKeyword */) { + token = nextToken(); + if (token === 80 /* Identifier */ || isKeyword(token)) { + token = nextToken(); + if (token === 161 /* FromKeyword */) { + token = nextToken(); + if (token === 11 /* StringLiteral */) { + recordModuleName(); + } } - } else { - Debug.assertEqual(lastTemplateStackToken, 19 /* OpenBraceToken */, "Should have been an open brace"); - templateStack.pop(); } } - break; - default: - if (!isKeyword(token)) { - break; + } + } + return true; + } + return false; + } + function tryConsumeExport() { + let token = scanner.getToken(); + if (token === 95 /* ExportKeyword */) { + markAsExternalModuleIfTopLevel(); + token = nextToken(); + if (token === 156 /* TypeKeyword */) { + const skipTypeKeyword = scanner.lookAhead(() => { + const token2 = scanner.scan(); + return token2 === 42 /* AsteriskToken */ || token2 === 19 /* OpenBraceToken */; + }); + if (skipTypeKeyword) { + token = nextToken(); + } + } + if (token === 19 /* OpenBraceToken */) { + token = nextToken(); + while (token !== 20 /* CloseBraceToken */ && token !== 1 /* EndOfFileToken */) { + token = nextToken(); + } + if (token === 20 /* CloseBraceToken */) { + token = nextToken(); + if (token === 161 /* FromKeyword */) { + token = nextToken(); + if (token === 11 /* StringLiteral */) { + recordModuleName(); + } } - if (lastNonTriviaToken === 25 /* DotToken */) { - token = 80 /* Identifier */; - } else if (isKeyword(lastNonTriviaToken) && isKeyword(token) && !canFollow(lastNonTriviaToken, token)) { - token = 80 /* Identifier */; + } + } else if (token === 42 /* AsteriskToken */) { + token = nextToken(); + if (token === 161 /* FromKeyword */) { + token = nextToken(); + if (token === 11 /* StringLiteral */) { + recordModuleName(); + } + } + } else if (token === 102 /* ImportKeyword */) { + token = nextToken(); + if (token === 156 /* TypeKeyword */) { + const skipTypeKeyword = scanner.lookAhead(() => { + const token2 = scanner.scan(); + return token2 === 80 /* Identifier */ || isKeyword(token2); + }); + if (skipTypeKeyword) { + token = nextToken(); + } + } + if (token === 80 /* Identifier */ || isKeyword(token)) { + token = nextToken(); + if (token === 64 /* EqualsToken */) { + if (tryConsumeRequireCall( + /*skipCurrentToken*/ + true + )) { + return true; + } } + } } + return true; } - return { endOfLineState, spans }; + return false; } - return { getClassificationsForLine, getEncodedLexicalClassifications }; - } - function getNewEndOfLineState(scanner2, token, lastOnTemplateStack) { - switch (token) { - case 11 /* StringLiteral */: { - if (!scanner2.isUnterminated()) - return void 0; - const tokenText = scanner2.getTokenText(); - const lastCharIndex = tokenText.length - 1; - let numBackslashes = 0; - while (tokenText.charCodeAt(lastCharIndex - numBackslashes) === 92 /* backslash */) { - numBackslashes++; + function tryConsumeRequireCall(skipCurrentToken, allowTemplateLiterals = false) { + let token = skipCurrentToken ? nextToken() : scanner.getToken(); + if (token === 149 /* RequireKeyword */) { + token = nextToken(); + if (token === 21 /* OpenParenToken */) { + token = nextToken(); + if (token === 11 /* StringLiteral */ || allowTemplateLiterals && token === 15 /* NoSubstitutionTemplateLiteral */) { + recordModuleName(); + } } - if ((numBackslashes & 1) === 0) - return void 0; - return tokenText.charCodeAt(0) === 34 /* doubleQuote */ ? 3 /* InDoubleQuoteStringLiteral */ : 2 /* InSingleQuoteStringLiteral */; + return true; } - case 3 /* MultiLineCommentTrivia */: - return scanner2.isUnterminated() ? 1 /* InMultiLineCommentTrivia */ : void 0; - default: - if (isTemplateLiteralKind(token)) { - if (!scanner2.isUnterminated()) { - return void 0; + return false; + } + function tryConsumeDefine() { + let token = scanner.getToken(); + if (token === 80 /* Identifier */ && scanner.getTokenValue() === "define") { + token = nextToken(); + if (token !== 21 /* OpenParenToken */) { + return true; + } + token = nextToken(); + if (token === 11 /* StringLiteral */ || token === 15 /* NoSubstitutionTemplateLiteral */) { + token = nextToken(); + if (token === 28 /* CommaToken */) { + token = nextToken(); + } else { + return true; } - switch (token) { - case 18 /* TemplateTail */: - return 5 /* InTemplateMiddleOrTail */; - case 15 /* NoSubstitutionTemplateLiteral */: - return 4 /* InTemplateHeadOrNoSubstitutionTemplate */; - default: - return Debug.fail("Only 'NoSubstitutionTemplateLiteral's and 'TemplateTail's can be unterminated; got SyntaxKind #" + token); + } + if (token !== 23 /* OpenBracketToken */) { + return true; + } + token = nextToken(); + while (token !== 24 /* CloseBracketToken */ && token !== 1 /* EndOfFileToken */) { + if (token === 11 /* StringLiteral */ || token === 15 /* NoSubstitutionTemplateLiteral */) { + recordModuleName(); } + token = nextToken(); } - return lastOnTemplateStack === 16 /* TemplateHead */ ? 6 /* InTemplateSubstitutionPosition */ : void 0; + return true; + } + return false; } - } - function pushEncodedClassification(start, end, offset, classification, result) { - if (classification === 8 /* whiteSpace */) { - return; + function processImports() { + scanner.setText(sourceText); + nextToken(); + while (true) { + if (scanner.getToken() === 1 /* EndOfFileToken */) { + break; + } + if (scanner.getToken() === 16 /* TemplateHead */) { + const stack = [scanner.getToken()]; + loop: + while (length(stack)) { + const token = scanner.scan(); + switch (token) { + case 1 /* EndOfFileToken */: + break loop; + case 102 /* ImportKeyword */: + tryConsumeImport(); + break; + case 16 /* TemplateHead */: + stack.push(token); + break; + case 19 /* OpenBraceToken */: + if (length(stack)) { + stack.push(token); + } + break; + case 20 /* CloseBraceToken */: + if (length(stack)) { + if (lastOrUndefined(stack) === 16 /* TemplateHead */) { + if (scanner.reScanTemplateToken( + /*isTaggedTemplate*/ + false + ) === 18 /* TemplateTail */) { + stack.pop(); + } + } else { + stack.pop(); + } + } + break; + } + } + nextToken(); + } + if (tryConsumeDeclare() || tryConsumeImport() || tryConsumeExport() || detectJavaScriptImports && (tryConsumeRequireCall( + /*skipCurrentToken*/ + false, + /*allowTemplateLiterals*/ + true + ) || tryConsumeDefine())) { + continue; + } else { + nextToken(); + } + } + scanner.setText(void 0); } - if (start === 0 && offset > 0) { - start += offset; + if (readImportFiles) { + processImports(); } - const length2 = end - start; - if (length2 > 0) { - result.push(start - offset, length2, classification); + processCommentPragmas(pragmaContext, sourceText); + processPragmasIntoFields(pragmaContext, noop); + if (externalModule) { + if (ambientExternalModules) { + for (const decl of ambientExternalModules) { + importedFiles.push(decl.ref); + } + } + return { referencedFiles: pragmaContext.referencedFiles, typeReferenceDirectives: pragmaContext.typeReferenceDirectives, libReferenceDirectives: pragmaContext.libReferenceDirectives, importedFiles, isLibFile: !!pragmaContext.hasNoDefaultLib, ambientExternalModules: void 0 }; + } else { + let ambientModuleNames; + if (ambientExternalModules) { + for (const decl of ambientExternalModules) { + if (decl.depth === 0) { + if (!ambientModuleNames) { + ambientModuleNames = []; + } + ambientModuleNames.push(decl.ref.fileName); + } else { + importedFiles.push(decl.ref); + } + } + } + return { referencedFiles: pragmaContext.referencedFiles, typeReferenceDirectives: pragmaContext.typeReferenceDirectives, libReferenceDirectives: pragmaContext.libReferenceDirectives, importedFiles, isLibFile: !!pragmaContext.hasNoDefaultLib, ambientExternalModules: ambientModuleNames }; } } - function convertClassificationsToResult(classifications, text) { - const entries = []; - const dense = classifications.spans; - let lastEnd = 0; - for (let i = 0; i < dense.length; i += 3) { - const start = dense[i]; - const length2 = dense[i + 1]; - const type = dense[i + 2]; - if (lastEnd >= 0) { - const whitespaceLength2 = start - lastEnd; - if (whitespaceLength2 > 0) { - entries.push({ length: whitespaceLength2, classification: 4 /* Whitespace */ }); - } + var init_preProcess = __esm({ + "src/services/preProcess.ts"() { + "use strict"; + init_ts4(); + } + }); + + // src/services/sourcemaps.ts + function getSourceMapper(host) { + const getCanonicalFileName = createGetCanonicalFileName(host.useCaseSensitiveFileNames()); + const currentDirectory = host.getCurrentDirectory(); + const sourceFileLike = /* @__PURE__ */ new Map(); + const documentPositionMappers = /* @__PURE__ */ new Map(); + return { tryGetSourcePosition, tryGetGeneratedPosition, toLineColumnOffset, clearCache }; + function toPath3(fileName) { + return toPath(fileName, currentDirectory, getCanonicalFileName); + } + function getDocumentPositionMapper2(generatedFileName, sourceFileName) { + const path = toPath3(generatedFileName); + const value = documentPositionMappers.get(path); + if (value) + return value; + let mapper; + if (host.getDocumentPositionMapper) { + mapper = host.getDocumentPositionMapper(generatedFileName, sourceFileName); + } else if (host.readFile) { + const file = getSourceFileLike(generatedFileName); + mapper = file && getDocumentPositionMapper( + { getSourceFileLike, getCanonicalFileName, log: (s) => host.log(s) }, + generatedFileName, + getLineInfo(file.text, getLineStarts(file)), + (f) => !host.fileExists || host.fileExists(f) ? host.readFile(f) : void 0 + ); } - entries.push({ length: length2, classification: convertClassification(type) }); - lastEnd = start + length2; + documentPositionMappers.set(path, mapper || identitySourceMapConsumer); + return mapper || identitySourceMapConsumer; } - const whitespaceLength = text.length - lastEnd; - if (whitespaceLength > 0) { - entries.push({ length: whitespaceLength, classification: 4 /* Whitespace */ }); + function tryGetSourcePosition(info) { + if (!isDeclarationFileName(info.fileName)) + return void 0; + const file = getSourceFile(info.fileName); + if (!file) + return void 0; + const newLoc = getDocumentPositionMapper2(info.fileName).getSourcePosition(info); + return !newLoc || newLoc === info ? void 0 : tryGetSourcePosition(newLoc) || newLoc; } - return { entries, finalLexState: classifications.endOfLineState }; - } - function convertClassification(type) { - switch (type) { - case 1 /* comment */: - return 3 /* Comment */; - case 3 /* keyword */: - return 1 /* Keyword */; - case 4 /* numericLiteral */: - return 6 /* NumberLiteral */; - case 25 /* bigintLiteral */: - return 7 /* BigIntLiteral */; - case 5 /* operator */: - return 2 /* Operator */; - case 6 /* stringLiteral */: - return 8 /* StringLiteral */; - case 8 /* whiteSpace */: - return 4 /* Whitespace */; - case 10 /* punctuation */: - return 0 /* Punctuation */; - case 2 /* identifier */: - case 11 /* className */: - case 12 /* enumName */: - case 13 /* interfaceName */: - case 14 /* moduleName */: - case 15 /* typeParameterName */: - case 16 /* typeAliasName */: - case 9 /* text */: - case 17 /* parameterName */: - return 5 /* Identifier */; - default: + function tryGetGeneratedPosition(info) { + if (isDeclarationFileName(info.fileName)) + return void 0; + const sourceFile = getSourceFile(info.fileName); + if (!sourceFile) + return void 0; + const program = host.getProgram(); + if (program.isSourceOfProjectReferenceRedirect(sourceFile.fileName)) { + return void 0; + } + const options = program.getCompilerOptions(); + const outPath = outFile(options); + const declarationPath = outPath ? removeFileExtension(outPath) + ".d.ts" /* Dts */ : getDeclarationEmitOutputFilePathWorker(info.fileName, program.getCompilerOptions(), currentDirectory, program.getCommonSourceDirectory(), getCanonicalFileName); + if (declarationPath === void 0) return void 0; + const newLoc = getDocumentPositionMapper2(declarationPath, info.fileName).getGeneratedPosition(info); + return newLoc === info ? void 0 : newLoc; } - } - function canFollow(keyword1, keyword2) { - if (!isAccessibilityModifier(keyword1)) { - return true; + function getSourceFile(fileName) { + const program = host.getProgram(); + if (!program) + return void 0; + const path = toPath3(fileName); + const file = program.getSourceFileByPath(path); + return file && file.resolvedPath === path ? file : void 0; } - switch (keyword2) { - case 139 /* GetKeyword */: - case 153 /* SetKeyword */: - case 137 /* ConstructorKeyword */: - case 126 /* StaticKeyword */: - case 129 /* AccessorKeyword */: - return true; - default: - return false; + function getOrCreateSourceFileLike(fileName) { + const path = toPath3(fileName); + const fileFromCache = sourceFileLike.get(path); + if (fileFromCache !== void 0) + return fileFromCache ? fileFromCache : void 0; + if (!host.readFile || host.fileExists && !host.fileExists(path)) { + sourceFileLike.set(path, false); + return void 0; + } + const text = host.readFile(path); + const file = text ? createSourceFileLike(text) : false; + sourceFileLike.set(path, file); + return file ? file : void 0; } - } - function getPrefixFromLexState(lexState) { - switch (lexState) { - case 3 /* InDoubleQuoteStringLiteral */: - return { prefix: '"\\\n' }; - case 2 /* InSingleQuoteStringLiteral */: - return { prefix: "'\\\n" }; - case 1 /* InMultiLineCommentTrivia */: - return { prefix: "/*\n" }; - case 4 /* InTemplateHeadOrNoSubstitutionTemplate */: - return { prefix: "`\n" }; - case 5 /* InTemplateMiddleOrTail */: - return { prefix: "}\n", pushTemplate: true }; - case 6 /* InTemplateSubstitutionPosition */: - return { prefix: "", pushTemplate: true }; - case 0 /* None */: - return { prefix: "" }; - default: - return Debug.assertNever(lexState); + function getSourceFileLike(fileName) { + return !host.getSourceFileLike ? getSourceFile(fileName) || getOrCreateSourceFileLike(fileName) : host.getSourceFileLike(fileName); } - } - function isBinaryExpressionOperatorToken(token) { - switch (token) { - case 42 /* AsteriskToken */: - case 44 /* SlashToken */: - case 45 /* PercentToken */: - case 40 /* PlusToken */: - case 41 /* MinusToken */: - case 48 /* LessThanLessThanToken */: - case 49 /* GreaterThanGreaterThanToken */: - case 50 /* GreaterThanGreaterThanGreaterThanToken */: - case 30 /* LessThanToken */: - case 32 /* GreaterThanToken */: - case 33 /* LessThanEqualsToken */: - case 34 /* GreaterThanEqualsToken */: - case 104 /* InstanceOfKeyword */: - case 103 /* InKeyword */: - case 130 /* AsKeyword */: - case 152 /* SatisfiesKeyword */: - case 35 /* EqualsEqualsToken */: - case 36 /* ExclamationEqualsToken */: - case 37 /* EqualsEqualsEqualsToken */: - case 38 /* ExclamationEqualsEqualsToken */: - case 51 /* AmpersandToken */: - case 53 /* CaretToken */: - case 52 /* BarToken */: - case 56 /* AmpersandAmpersandToken */: - case 57 /* BarBarToken */: - case 75 /* BarEqualsToken */: - case 74 /* AmpersandEqualsToken */: - case 79 /* CaretEqualsToken */: - case 71 /* LessThanLessThanEqualsToken */: - case 72 /* GreaterThanGreaterThanEqualsToken */: - case 73 /* GreaterThanGreaterThanGreaterThanEqualsToken */: - case 65 /* PlusEqualsToken */: - case 66 /* MinusEqualsToken */: - case 67 /* AsteriskEqualsToken */: - case 69 /* SlashEqualsToken */: - case 70 /* PercentEqualsToken */: - case 64 /* EqualsToken */: - case 28 /* CommaToken */: - case 61 /* QuestionQuestionToken */: - case 76 /* BarBarEqualsToken */: - case 77 /* AmpersandAmpersandEqualsToken */: - case 78 /* QuestionQuestionEqualsToken */: - return true; - default: - return false; + function toLineColumnOffset(fileName, position) { + const file = getSourceFileLike(fileName); + return file.getLineAndCharacterOfPosition(position); } - } - function isPrefixUnaryExpressionOperatorToken(token) { - switch (token) { - case 40 /* PlusToken */: - case 41 /* MinusToken */: - case 55 /* TildeToken */: - case 54 /* ExclamationToken */: - case 46 /* PlusPlusToken */: - case 47 /* MinusMinusToken */: - return true; - default: - return false; + function clearCache() { + sourceFileLike.clear(); + documentPositionMappers.clear(); } } - function classFromKind(token) { - if (isKeyword(token)) { - return 3 /* keyword */; - } else if (isBinaryExpressionOperatorToken(token) || isPrefixUnaryExpressionOperatorToken(token)) { - return 5 /* operator */; - } else if (token >= 19 /* FirstPunctuation */ && token <= 79 /* LastPunctuation */) { - return 10 /* punctuation */; - } - switch (token) { - case 9 /* NumericLiteral */: - return 4 /* numericLiteral */; - case 10 /* BigIntLiteral */: - return 25 /* bigintLiteral */; - case 11 /* StringLiteral */: - return 6 /* stringLiteral */; - case 14 /* RegularExpressionLiteral */: - return 7 /* regularExpressionLiteral */; - case 7 /* ConflictMarkerTrivia */: - case 3 /* MultiLineCommentTrivia */: - case 2 /* SingleLineCommentTrivia */: - return 1 /* comment */; - case 5 /* WhitespaceTrivia */: - case 4 /* NewLineTrivia */: - return 8 /* whiteSpace */; - case 80 /* Identifier */: - default: - if (isTemplateLiteralKind(token)) { - return 6 /* stringLiteral */; + function getDocumentPositionMapper(host, generatedFileName, generatedFileLineInfo, readMapFile) { + let mapFileName = tryGetSourceMappingURL(generatedFileLineInfo); + if (mapFileName) { + const match = base64UrlRegExp.exec(mapFileName); + if (match) { + if (match[1]) { + const base64Object = match[1]; + return convertDocumentToSourceMapper(host, base64decode(sys, base64Object), generatedFileName); } - return 2 /* identifier */; + mapFileName = void 0; + } } - } - function getSemanticClassifications(typeChecker, cancellationToken, sourceFile, classifiableNames, span) { - return convertClassificationsToSpans(getEncodedSemanticClassifications(typeChecker, cancellationToken, sourceFile, classifiableNames, span)); - } - function checkForClassificationCancellation(cancellationToken, kind) { - switch (kind) { - case 266 /* ModuleDeclaration */: - case 262 /* ClassDeclaration */: - case 263 /* InterfaceDeclaration */: - case 261 /* FunctionDeclaration */: - case 230 /* ClassExpression */: - case 217 /* FunctionExpression */: - case 218 /* ArrowFunction */: - cancellationToken.throwIfCancellationRequested(); + const possibleMapLocations = []; + if (mapFileName) { + possibleMapLocations.push(mapFileName); } - } - function getEncodedSemanticClassifications(typeChecker, cancellationToken, sourceFile, classifiableNames, span) { - const spans = []; - sourceFile.forEachChild(function cb(node) { - if (!node || !textSpanIntersectsWith(span, node.pos, node.getFullWidth())) { - return; + possibleMapLocations.push(generatedFileName + ".map"); + const originalMapFileName = mapFileName && getNormalizedAbsolutePath(mapFileName, getDirectoryPath(generatedFileName)); + for (const location of possibleMapLocations) { + const mapFileName2 = getNormalizedAbsolutePath(location, getDirectoryPath(generatedFileName)); + const mapFileContents = readMapFile(mapFileName2, originalMapFileName); + if (isString(mapFileContents)) { + return convertDocumentToSourceMapper(host, mapFileContents, mapFileName2); } - checkForClassificationCancellation(cancellationToken, node.kind); - if (isIdentifier(node) && !nodeIsMissing(node) && classifiableNames.has(node.escapedText)) { - const symbol = typeChecker.getSymbolAtLocation(node); - const type = symbol && classifySymbol(symbol, getMeaningFromLocation(node), typeChecker); - if (type) { - pushClassification(node.getStart(sourceFile), node.getEnd(), type); - } + if (mapFileContents !== void 0) { + return mapFileContents || void 0; } - node.forEachChild(cb); - }); - return { spans, endOfLineState: 0 /* None */ }; - function pushClassification(start, end, type) { - const length2 = end - start; - Debug.assert(length2 > 0, `Classification had non-positive length of ${length2}`); - spans.push(start); - spans.push(length2); - spans.push(type); } + return void 0; } - function classifySymbol(symbol, meaningAtPosition, checker) { - const flags = symbol.getFlags(); - if ((flags & 2885600 /* Classifiable */) === 0 /* None */) { - return void 0; - } else if (flags & 32 /* Class */) { - return 11 /* className */; - } else if (flags & 384 /* Enum */) { - return 12 /* enumName */; - } else if (flags & 524288 /* TypeAlias */) { - return 16 /* typeAliasName */; - } else if (flags & 1536 /* Module */) { - return meaningAtPosition & 4 /* Namespace */ || meaningAtPosition & 1 /* Value */ && hasValueSideModule(symbol) ? 14 /* moduleName */ : void 0; - } else if (flags & 2097152 /* Alias */) { - return classifySymbol(checker.getAliasedSymbol(symbol), meaningAtPosition, checker); - } else if (meaningAtPosition & 2 /* Type */) { - return flags & 64 /* Interface */ ? 13 /* interfaceName */ : flags & 262144 /* TypeParameter */ ? 15 /* typeParameterName */ : void 0; - } else { + function convertDocumentToSourceMapper(host, contents, mapFileName) { + const map2 = tryParseRawSourceMap(contents); + if (!map2 || !map2.sources || !map2.file || !map2.mappings) { return void 0; } + if (map2.sourcesContent && map2.sourcesContent.some(isString)) + return void 0; + return createDocumentPositionMapper(host, map2, mapFileName); } - function hasValueSideModule(symbol) { - return some(symbol.declarations, (declaration) => isModuleDeclaration(declaration) && getModuleInstanceState(declaration) === 1 /* Instantiated */); + function createSourceFileLike(text, lineMap) { + return { + text, + lineMap, + getLineAndCharacterOfPosition(pos) { + return computeLineAndCharacterOfPosition(getLineStarts(this), pos); + } + }; } - function getClassificationTypeName(type) { - switch (type) { - case 1 /* comment */: - return "comment" /* comment */; - case 2 /* identifier */: - return "identifier" /* identifier */; - case 3 /* keyword */: - return "keyword" /* keyword */; - case 4 /* numericLiteral */: - return "number" /* numericLiteral */; - case 25 /* bigintLiteral */: - return "bigint" /* bigintLiteral */; - case 5 /* operator */: - return "operator" /* operator */; - case 6 /* stringLiteral */: - return "string" /* stringLiteral */; - case 8 /* whiteSpace */: - return "whitespace" /* whiteSpace */; - case 9 /* text */: - return "text" /* text */; - case 10 /* punctuation */: - return "punctuation" /* punctuation */; - case 11 /* className */: - return "class name" /* className */; - case 12 /* enumName */: - return "enum name" /* enumName */; - case 13 /* interfaceName */: - return "interface name" /* interfaceName */; - case 14 /* moduleName */: - return "module name" /* moduleName */; - case 15 /* typeParameterName */: - return "type parameter name" /* typeParameterName */; - case 16 /* typeAliasName */: - return "type alias name" /* typeAliasName */; - case 17 /* parameterName */: - return "parameter name" /* parameterName */; - case 18 /* docCommentTagName */: - return "doc comment tag name" /* docCommentTagName */; - case 19 /* jsxOpenTagName */: - return "jsx open tag name" /* jsxOpenTagName */; - case 20 /* jsxCloseTagName */: - return "jsx close tag name" /* jsxCloseTagName */; - case 21 /* jsxSelfClosingTagName */: - return "jsx self closing tag name" /* jsxSelfClosingTagName */; - case 22 /* jsxAttribute */: - return "jsx attribute" /* jsxAttribute */; - case 23 /* jsxText */: - return "jsx text" /* jsxText */; - case 24 /* jsxAttributeStringLiteralValue */: - return "jsx attribute string literal value" /* jsxAttributeStringLiteralValue */; - default: - return void 0; + var base64UrlRegExp; + var init_sourcemaps = __esm({ + "src/services/sourcemaps.ts"() { + "use strict"; + init_ts4(); + base64UrlRegExp = /^data:(?:application\/json(?:;charset=[uU][tT][fF]-8);base64,([A-Za-z0-9+/=]+)$)?/; } - } - function convertClassificationsToSpans(classifications) { - Debug.assert(classifications.spans.length % 3 === 0); - const dense = classifications.spans; - const result = []; - for (let i = 0; i < dense.length; i += 3) { - result.push({ - textSpan: createTextSpan(dense[i], dense[i + 1]), - classificationType: getClassificationTypeName(dense[i + 2]) - }); + }); + + // src/services/suggestionDiagnostics.ts + function computeSuggestionDiagnostics(sourceFile, program, cancellationToken) { + var _a; + program.getSemanticDiagnostics(sourceFile, cancellationToken); + const diags = []; + const checker = program.getTypeChecker(); + const isCommonJSFile = sourceFile.impliedNodeFormat === 1 /* CommonJS */ || fileExtensionIsOneOf(sourceFile.fileName, [".cts" /* Cts */, ".cjs" /* Cjs */]); + if (!isCommonJSFile && sourceFile.commonJsModuleIndicator && (programContainsEsModules(program) || compilerOptionsIndicateEsModules(program.getCompilerOptions())) && containsTopLevelCommonjs(sourceFile)) { + diags.push(createDiagnosticForNode(getErrorNodeFromCommonJsIndicator(sourceFile.commonJsModuleIndicator), Diagnostics.File_is_a_CommonJS_module_it_may_be_converted_to_an_ES_module)); } - return result; - } - function getSyntacticClassifications(cancellationToken, sourceFile, span) { - return convertClassificationsToSpans(getEncodedSyntacticClassifications(cancellationToken, sourceFile, span)); - } - function getEncodedSyntacticClassifications(cancellationToken, sourceFile, span) { - const spanStart = span.start; - const spanLength = span.length; - const triviaScanner = createScanner( - 99 /* Latest */, - /*skipTrivia*/ - false, - sourceFile.languageVariant, - sourceFile.text - ); - const mergeConflictScanner = createScanner( - 99 /* Latest */, - /*skipTrivia*/ - false, - sourceFile.languageVariant, - sourceFile.text - ); - const result = []; - processElement(sourceFile); - return { spans: result, endOfLineState: 0 /* None */ }; - function pushClassification(start, length2, type) { - result.push(start); - result.push(length2); - result.push(type); + const isJsFile = isSourceFileJS(sourceFile); + visitedNestedConvertibleFunctions.clear(); + check(sourceFile); + if (getAllowSyntheticDefaultImports(program.getCompilerOptions())) { + for (const moduleSpecifier of sourceFile.imports) { + const importNode = importFromModuleSpecifier(moduleSpecifier); + const name = importNameForConvertToDefaultImport(importNode); + if (!name) + continue; + const module2 = (_a = program.getResolvedModule(sourceFile, moduleSpecifier.text, getModeForUsageLocation(sourceFile, moduleSpecifier))) == null ? void 0 : _a.resolvedModule; + const resolvedFile = module2 && program.getSourceFile(module2.resolvedFileName); + if (resolvedFile && resolvedFile.externalModuleIndicator && resolvedFile.externalModuleIndicator !== true && isExportAssignment(resolvedFile.externalModuleIndicator) && resolvedFile.externalModuleIndicator.isExportEquals) { + diags.push(createDiagnosticForNode(name, Diagnostics.Import_may_be_converted_to_a_default_import)); + } + } } - function classifyLeadingTriviaAndGetTokenStart(token) { - triviaScanner.resetTokenState(token.pos); - while (true) { - const start = triviaScanner.getTokenEnd(); - if (!couldStartTrivia(sourceFile.text, start)) { - return start; + addRange(diags, sourceFile.bindSuggestionDiagnostics); + addRange(diags, program.getSuggestionDiagnostics(sourceFile, cancellationToken)); + return diags.sort((d1, d2) => d1.start - d2.start); + function check(node) { + if (isJsFile) { + if (canBeConvertedToClass(node, checker)) { + diags.push(createDiagnosticForNode(isVariableDeclaration(node.parent) ? node.parent.name : node, Diagnostics.This_constructor_function_may_be_converted_to_a_class_declaration)); } - const kind = triviaScanner.scan(); - const end = triviaScanner.getTokenEnd(); - const width = end - start; - if (!isTrivia(kind)) { - return start; + } else { + if (isVariableStatement(node) && node.parent === sourceFile && node.declarationList.flags & 2 /* Const */ && node.declarationList.declarations.length === 1) { + const init = node.declarationList.declarations[0].initializer; + if (init && isRequireCall( + init, + /*requireStringLiteralLikeArgument*/ + true + )) { + diags.push(createDiagnosticForNode(init, Diagnostics.require_call_may_be_converted_to_an_import)); + } } - switch (kind) { - case 4 /* NewLineTrivia */: - case 5 /* WhitespaceTrivia */: - continue; - case 2 /* SingleLineCommentTrivia */: - case 3 /* MultiLineCommentTrivia */: - classifyComment(token, kind, start, width); - triviaScanner.resetTokenState(end); - continue; - case 7 /* ConflictMarkerTrivia */: - const text = sourceFile.text; - const ch = text.charCodeAt(start); - if (ch === 60 /* lessThan */ || ch === 62 /* greaterThan */) { - pushClassification(start, width, 1 /* comment */); - continue; - } - Debug.assert(ch === 124 /* bar */ || ch === 61 /* equals */); - classifyDisabledMergeCode(text, start, end); - break; - case 6 /* ShebangTrivia */: - break; - default: - Debug.assertNever(kind); + const jsdocTypedefNodes = ts_codefix_exports.getJSDocTypedefNodes(node); + for (const jsdocTypedefNode of jsdocTypedefNodes) { + diags.push(createDiagnosticForNode(jsdocTypedefNode, Diagnostics.JSDoc_typedef_may_be_converted_to_TypeScript_type)); } + if (ts_codefix_exports.parameterShouldGetTypeFromJSDoc(node)) { + diags.push(createDiagnosticForNode(node.name || node, Diagnostics.JSDoc_types_may_be_moved_to_TypeScript_types)); + } + } + if (canBeConvertedToAsync(node)) { + addConvertToAsyncFunctionDiagnostics(node, checker, diags); } + node.forEachChild(check); } - function classifyComment(token, kind, start, width) { - if (kind === 3 /* MultiLineCommentTrivia */) { - const docCommentAndDiagnostics = parseIsolatedJSDocComment(sourceFile.text, start, width); - if (docCommentAndDiagnostics && docCommentAndDiagnostics.jsDoc) { - setParent(docCommentAndDiagnostics.jsDoc, token); - classifyJSDocComment(docCommentAndDiagnostics.jsDoc); - return; - } - } else if (kind === 2 /* SingleLineCommentTrivia */) { - if (tryClassifyTripleSlashComment(start, width)) { - return; + } + function containsTopLevelCommonjs(sourceFile) { + return sourceFile.statements.some((statement) => { + switch (statement.kind) { + case 243 /* VariableStatement */: + return statement.declarationList.declarations.some((decl) => !!decl.initializer && isRequireCall( + propertyAccessLeftHandSide(decl.initializer), + /*requireStringLiteralLikeArgument*/ + true + )); + case 244 /* ExpressionStatement */: { + const { expression } = statement; + if (!isBinaryExpression(expression)) + return isRequireCall( + expression, + /*requireStringLiteralLikeArgument*/ + true + ); + const kind = getAssignmentDeclarationKind(expression); + return kind === 1 /* ExportsProperty */ || kind === 2 /* ModuleExports */; } + default: + return false; } - pushCommentRange(start, width); + }); + } + function propertyAccessLeftHandSide(node) { + return isPropertyAccessExpression(node) ? propertyAccessLeftHandSide(node.expression) : node; + } + function importNameForConvertToDefaultImport(node) { + switch (node.kind) { + case 272 /* ImportDeclaration */: + const { importClause, moduleSpecifier } = node; + return importClause && !importClause.name && importClause.namedBindings && importClause.namedBindings.kind === 274 /* NamespaceImport */ && isStringLiteral(moduleSpecifier) ? importClause.namedBindings.name : void 0; + case 271 /* ImportEqualsDeclaration */: + return node.name; + default: + return void 0; } - function pushCommentRange(start, width) { - pushClassification(start, width, 1 /* comment */); + } + function addConvertToAsyncFunctionDiagnostics(node, checker, diags) { + if (isConvertibleFunction(node, checker) && !visitedNestedConvertibleFunctions.has(getKeyFromNode(node))) { + diags.push(createDiagnosticForNode( + !node.name && isVariableDeclaration(node.parent) && isIdentifier(node.parent.name) ? node.parent.name : node, + Diagnostics.This_may_be_converted_to_an_async_function + )); } - function classifyJSDocComment(docComment) { - var _a, _b, _c, _d, _e, _f, _g, _h; - let pos = docComment.pos; - if (docComment.tags) { - for (const tag of docComment.tags) { - if (tag.pos !== pos) { - pushCommentRange(pos, tag.pos - pos); - } - pushClassification(tag.pos, 1, 10 /* punctuation */); - pushClassification(tag.tagName.pos, tag.tagName.end - tag.tagName.pos, 18 /* docCommentTagName */); - pos = tag.tagName.end; - let commentStart = tag.tagName.end; - switch (tag.kind) { - case 347 /* JSDocParameterTag */: - const param = tag; - processJSDocParameterTag(param); - commentStart = param.isNameFirst && ((_a = param.typeExpression) == null ? void 0 : _a.end) || param.name.end; - break; - case 354 /* JSDocPropertyTag */: - const prop = tag; - commentStart = prop.isNameFirst && ((_b = prop.typeExpression) == null ? void 0 : _b.end) || prop.name.end; - break; - case 351 /* JSDocTemplateTag */: - processJSDocTemplateTag(tag); - pos = tag.end; - commentStart = tag.typeParameters.end; - break; - case 352 /* JSDocTypedefTag */: - const type = tag; - commentStart = ((_c = type.typeExpression) == null ? void 0 : _c.kind) === 315 /* JSDocTypeExpression */ && ((_d = type.fullName) == null ? void 0 : _d.end) || ((_e = type.typeExpression) == null ? void 0 : _e.end) || commentStart; - break; - case 344 /* JSDocCallbackTag */: - commentStart = tag.typeExpression.end; - break; - case 350 /* JSDocTypeTag */: - processElement(tag.typeExpression); - pos = tag.end; - commentStart = tag.typeExpression.end; - break; - case 349 /* JSDocThisTag */: - case 346 /* JSDocEnumTag */: - commentStart = tag.typeExpression.end; - break; - case 348 /* JSDocReturnTag */: - processElement(tag.typeExpression); - pos = tag.end; - commentStart = ((_f = tag.typeExpression) == null ? void 0 : _f.end) || commentStart; - break; - case 353 /* JSDocSeeTag */: - commentStart = ((_g = tag.name) == null ? void 0 : _g.end) || commentStart; - break; - case 334 /* JSDocAugmentsTag */: - case 335 /* JSDocImplementsTag */: - commentStart = tag.class.end; - break; - case 355 /* JSDocThrowsTag */: - processElement(tag.typeExpression); - pos = tag.end; - commentStart = ((_h = tag.typeExpression) == null ? void 0 : _h.end) || commentStart; - break; - } - if (typeof tag.comment === "object") { - pushCommentRange(tag.comment.pos, tag.comment.end - tag.comment.pos); - } else if (typeof tag.comment === "string") { - pushCommentRange(commentStart, tag.end - commentStart); - } - } - } - if (pos !== docComment.end) { - pushCommentRange(pos, docComment.end - pos); - } - return; - function processJSDocParameterTag(tag) { - if (tag.isNameFirst) { - pushCommentRange(pos, tag.name.pos - pos); - pushClassification(tag.name.pos, tag.name.end - tag.name.pos, 17 /* parameterName */); - pos = tag.name.end; - } - if (tag.typeExpression) { - pushCommentRange(pos, tag.typeExpression.pos - pos); - processElement(tag.typeExpression); - pos = tag.typeExpression.end; - } - if (!tag.isNameFirst) { - pushCommentRange(pos, tag.name.pos - pos); - pushClassification(tag.name.pos, tag.name.end - tag.name.pos, 17 /* parameterName */); - pos = tag.name.end; + } + function isConvertibleFunction(node, checker) { + return !isAsyncFunction(node) && node.body && isBlock(node.body) && hasReturnStatementWithPromiseHandler(node.body, checker) && returnsPromise(node, checker); + } + function returnsPromise(node, checker) { + const signature = checker.getSignatureFromDeclaration(node); + const returnType = signature ? checker.getReturnTypeOfSignature(signature) : void 0; + return !!returnType && !!checker.getPromisedTypeOfPromise(returnType); + } + function getErrorNodeFromCommonJsIndicator(commonJsModuleIndicator) { + return isBinaryExpression(commonJsModuleIndicator) ? commonJsModuleIndicator.left : commonJsModuleIndicator; + } + function hasReturnStatementWithPromiseHandler(body, checker) { + return !!forEachReturnStatement(body, (statement) => isReturnStatementWithFixablePromiseHandler(statement, checker)); + } + function isReturnStatementWithFixablePromiseHandler(node, checker) { + return isReturnStatement(node) && !!node.expression && isFixablePromiseHandler(node.expression, checker); + } + function isFixablePromiseHandler(node, checker) { + if (!isPromiseHandler(node) || !hasSupportedNumberOfArguments(node) || !node.arguments.every((arg) => isFixablePromiseArgument(arg, checker))) { + return false; + } + let currentNode = node.expression.expression; + while (isPromiseHandler(currentNode) || isPropertyAccessExpression(currentNode)) { + if (isCallExpression(currentNode)) { + if (!hasSupportedNumberOfArguments(currentNode) || !currentNode.arguments.every((arg) => isFixablePromiseArgument(arg, checker))) { + return false; } + currentNode = currentNode.expression.expression; + } else { + currentNode = currentNode.expression; } } - function tryClassifyTripleSlashComment(start, width) { - const tripleSlashXMLCommentRegEx = /^(\/\/\/\s*)(<)(?:(\S+)((?:[^/]|\/[^>])*)(\/>)?)?/im; - const attributeRegex = /(\s)(\S+)(\s*)(=)(\s*)('[^']+'|"[^"]+")/img; - const text = sourceFile.text.substr(start, width); - const match = tripleSlashXMLCommentRegEx.exec(text); - if (!match) { - return false; - } - if (!match[3] || !(match[3] in commentPragmas)) { - return false; - } - let pos = start; - pushCommentRange(pos, match[1].length); - pos += match[1].length; - pushClassification(pos, match[2].length, 10 /* punctuation */); - pos += match[2].length; - pushClassification(pos, match[3].length, 21 /* jsxSelfClosingTagName */); - pos += match[3].length; - const attrText = match[4]; - let attrPos = pos; - while (true) { - const attrMatch = attributeRegex.exec(attrText); - if (!attrMatch) { - break; - } - const newAttrPos = pos + attrMatch.index + attrMatch[1].length; - if (newAttrPos > attrPos) { - pushCommentRange(attrPos, newAttrPos - attrPos); - attrPos = newAttrPos; - } - pushClassification(attrPos, attrMatch[2].length, 22 /* jsxAttribute */); - attrPos += attrMatch[2].length; - if (attrMatch[3].length) { - pushCommentRange(attrPos, attrMatch[3].length); - attrPos += attrMatch[3].length; + return true; + } + function isPromiseHandler(node) { + return isCallExpression(node) && (hasPropertyAccessExpressionWithName(node, "then") || hasPropertyAccessExpressionWithName(node, "catch") || hasPropertyAccessExpressionWithName(node, "finally")); + } + function hasSupportedNumberOfArguments(node) { + const name = node.expression.name.text; + const maxArguments = name === "then" ? 2 : name === "catch" ? 1 : name === "finally" ? 1 : 0; + if (node.arguments.length > maxArguments) + return false; + if (node.arguments.length < maxArguments) + return true; + return maxArguments === 1 || some(node.arguments, (arg) => { + return arg.kind === 106 /* NullKeyword */ || isIdentifier(arg) && arg.text === "undefined"; + }); + } + function isFixablePromiseArgument(arg, checker) { + switch (arg.kind) { + case 262 /* FunctionDeclaration */: + case 218 /* FunctionExpression */: + const functionFlags = getFunctionFlags(arg); + if (functionFlags & 1 /* Generator */) { + return false; } - pushClassification(attrPos, attrMatch[4].length, 5 /* operator */); - attrPos += attrMatch[4].length; - if (attrMatch[5].length) { - pushCommentRange(attrPos, attrMatch[5].length); - attrPos += attrMatch[5].length; + case 219 /* ArrowFunction */: + visitedNestedConvertibleFunctions.set(getKeyFromNode(arg), true); + case 106 /* NullKeyword */: + return true; + case 80 /* Identifier */: + case 211 /* PropertyAccessExpression */: { + const symbol = checker.getSymbolAtLocation(arg); + if (!symbol) { + return false; } - pushClassification(attrPos, attrMatch[6].length, 24 /* jsxAttributeStringLiteralValue */); - attrPos += attrMatch[6].length; - } - pos += match[4].length; - if (pos > attrPos) { - pushCommentRange(attrPos, pos - attrPos); + return checker.isUndefinedSymbol(symbol) || some(skipAlias(symbol, checker).declarations, (d) => isFunctionLike(d) || hasInitializer(d) && !!d.initializer && isFunctionLike(d.initializer)); } - if (match[5]) { - pushClassification(pos, match[5].length, 10 /* punctuation */); - pos += match[5].length; + default: + return false; + } + } + function getKeyFromNode(exp) { + return `${exp.pos.toString()}:${exp.end.toString()}`; + } + function canBeConvertedToClass(node, checker) { + var _a, _b, _c, _d; + if (isFunctionExpression(node)) { + if (isVariableDeclaration(node.parent) && ((_a = node.symbol.members) == null ? void 0 : _a.size)) { + return true; } - const end = start + width; - if (pos < end) { - pushCommentRange(pos, end - pos); + const symbol = checker.getSymbolOfExpando( + node, + /*allowDeclaration*/ + false + ); + return !!(symbol && (((_b = symbol.exports) == null ? void 0 : _b.size) || ((_c = symbol.members) == null ? void 0 : _c.size))); + } + if (isFunctionDeclaration(node)) { + return !!((_d = node.symbol.members) == null ? void 0 : _d.size); + } + return false; + } + function canBeConvertedToAsync(node) { + switch (node.kind) { + case 262 /* FunctionDeclaration */: + case 174 /* MethodDeclaration */: + case 218 /* FunctionExpression */: + case 219 /* ArrowFunction */: + return true; + default: + return false; + } + } + var visitedNestedConvertibleFunctions; + var init_suggestionDiagnostics = __esm({ + "src/services/suggestionDiagnostics.ts"() { + "use strict"; + init_ts4(); + visitedNestedConvertibleFunctions = /* @__PURE__ */ new Map(); + } + }); + + // src/services/transpile.ts + function transpileModule(input, transpileOptions) { + const diagnostics = []; + const options = transpileOptions.compilerOptions ? fixupCompilerOptions(transpileOptions.compilerOptions, diagnostics) : {}; + const defaultOptions = getDefaultCompilerOptions2(); + for (const key in defaultOptions) { + if (hasProperty(defaultOptions, key) && options[key] === void 0) { + options[key] = defaultOptions[key]; } - return true; } - function processJSDocTemplateTag(tag) { - for (const child of tag.getChildren()) { - processElement(child); + for (const option of transpileOptionValueCompilerOptions) { + if (options.verbatimModuleSyntax && optionsRedundantWithVerbatimModuleSyntax.has(option.name)) { + continue; } + options[option.name] = option.transpileOptionValue; } - function classifyDisabledMergeCode(text, start, end) { - let i; - for (i = start; i < end; i++) { - if (isLineBreak(text.charCodeAt(i))) { - break; + options.suppressOutputPathCheck = true; + options.allowNonTsExtensions = true; + const newLine = getNewLineCharacter(options); + const compilerHost = { + getSourceFile: (fileName) => fileName === normalizePath(inputFileName) ? sourceFile : void 0, + writeFile: (name, text) => { + if (fileExtensionIs(name, ".map")) { + Debug.assertEqual(sourceMapText, void 0, "Unexpected multiple source map outputs, file:", name); + sourceMapText = text; + } else { + Debug.assertEqual(outputText, void 0, "Unexpected multiple outputs, file:", name); + outputText = text; } + }, + getDefaultLibFileName: () => "lib.d.ts", + useCaseSensitiveFileNames: () => false, + getCanonicalFileName: (fileName) => fileName, + getCurrentDirectory: () => "", + getNewLine: () => newLine, + fileExists: (fileName) => fileName === inputFileName, + readFile: () => "", + directoryExists: () => true, + getDirectories: () => [] + }; + const inputFileName = transpileOptions.fileName || (transpileOptions.compilerOptions && transpileOptions.compilerOptions.jsx ? "module.tsx" : "module.ts"); + const sourceFile = createSourceFile( + inputFileName, + input, + { + languageVersion: getEmitScriptTarget(options), + impliedNodeFormat: getImpliedNodeFormatForFile( + toPath(inputFileName, "", compilerHost.getCanonicalFileName), + /*packageJsonInfoCache*/ + void 0, + compilerHost, + options + ), + setExternalModuleIndicator: getSetExternalModuleIndicator(options), + jsDocParsingMode: transpileOptions.jsDocParsingMode ?? 0 /* ParseAll */ } - pushClassification(start, i - start, 1 /* comment */); - mergeConflictScanner.resetTokenState(i); - while (mergeConflictScanner.getTokenEnd() < end) { - classifyDisabledCodeToken(); - } + ); + if (transpileOptions.moduleName) { + sourceFile.moduleName = transpileOptions.moduleName; } - function classifyDisabledCodeToken() { - const start = mergeConflictScanner.getTokenEnd(); - const tokenKind = mergeConflictScanner.scan(); - const end = mergeConflictScanner.getTokenEnd(); - const type = classifyTokenType(tokenKind); - if (type) { - pushClassification(start, end - start, type); - } + if (transpileOptions.renamedDependencies) { + sourceFile.renamedDependencies = new Map(Object.entries(transpileOptions.renamedDependencies)); } - function tryClassifyNode(node) { - if (isJSDoc(node)) { - return true; - } - if (nodeIsMissing(node)) { - return true; - } - const classifiedElementName = tryClassifyJsxElementName(node); - if (!isToken(node) && node.kind !== 12 /* JsxText */ && classifiedElementName === void 0) { - return false; + let outputText; + let sourceMapText; + const program = createProgram([inputFileName], options, compilerHost); + if (transpileOptions.reportDiagnostics) { + addRange( + /*to*/ + diagnostics, + /*from*/ + program.getSyntacticDiagnostics(sourceFile) + ); + addRange( + /*to*/ + diagnostics, + /*from*/ + program.getOptionsDiagnostics() + ); + } + program.emit( + /*targetSourceFile*/ + void 0, + /*writeFile*/ + void 0, + /*cancellationToken*/ + void 0, + /*emitOnlyDtsFiles*/ + void 0, + transpileOptions.transformers + ); + if (outputText === void 0) + return Debug.fail("Output generation failed"); + return { outputText, diagnostics, sourceMapText }; + } + function transpile(input, compilerOptions, fileName, diagnostics, moduleName) { + const output = transpileModule(input, { compilerOptions, fileName, reportDiagnostics: !!diagnostics, moduleName }); + addRange(diagnostics, output.diagnostics); + return output.outputText; + } + function fixupCompilerOptions(options, diagnostics) { + commandLineOptionsStringToEnum = commandLineOptionsStringToEnum || filter(optionDeclarations, (o) => typeof o.type === "object" && !forEachEntry(o.type, (v) => typeof v !== "number")); + options = cloneCompilerOptions(options); + for (const opt of commandLineOptionsStringToEnum) { + if (!hasProperty(options, opt.name)) { + continue; } - const tokenStart = node.kind === 12 /* JsxText */ ? node.pos : classifyLeadingTriviaAndGetTokenStart(node); - const tokenWidth = node.end - tokenStart; - Debug.assert(tokenWidth >= 0); - if (tokenWidth > 0) { - const type = classifiedElementName || classifyTokenType(node.kind, node); - if (type) { - pushClassification(tokenStart, tokenWidth, type); + const value = options[opt.name]; + if (isString(value)) { + options[opt.name] = parseCustomTypeOption(opt, value, diagnostics); + } else { + if (!forEachEntry(opt.type, (v) => v === value)) { + diagnostics.push(createCompilerDiagnosticForInvalidCustomType(opt)); } } - return true; } - function tryClassifyJsxElementName(token) { - switch (token.parent && token.parent.kind) { - case 285 /* JsxOpeningElement */: - if (token.parent.tagName === token) { - return 19 /* jsxOpenTagName */; - } - break; - case 286 /* JsxClosingElement */: - if (token.parent.tagName === token) { - return 20 /* jsxCloseTagName */; - } - break; - case 284 /* JsxSelfClosingElement */: - if (token.parent.tagName === token) { - return 21 /* jsxSelfClosingTagName */; - } - break; - case 290 /* JsxAttribute */: - if (token.parent.name === token) { - return 22 /* jsxAttribute */; - } - break; - } - return void 0; + return options; + } + var optionsRedundantWithVerbatimModuleSyntax, commandLineOptionsStringToEnum; + var init_transpile = __esm({ + "src/services/transpile.ts"() { + "use strict"; + init_ts4(); + optionsRedundantWithVerbatimModuleSyntax = /* @__PURE__ */ new Set([ + "isolatedModules", + "preserveValueImports", + "importsNotUsedAsValues" + ]); } - function classifyTokenType(tokenKind, token) { - if (isKeyword(tokenKind)) { - return 3 /* keyword */; + }); + + // src/services/navigateTo.ts + function getNavigateToItems(sourceFiles, checker, cancellationToken, searchValue, maxResultCount, excludeDtsFiles, excludeLibFiles) { + const patternMatcher = createPatternMatcher(searchValue); + if (!patternMatcher) + return emptyArray; + const rawItems = []; + const singleCurrentFile = sourceFiles.length === 1 ? sourceFiles[0] : void 0; + for (const sourceFile of sourceFiles) { + cancellationToken.throwIfCancellationRequested(); + if (excludeDtsFiles && sourceFile.isDeclarationFile) { + continue; } - if (tokenKind === 30 /* LessThanToken */ || tokenKind === 32 /* GreaterThanToken */) { - if (token && getTypeArgumentOrTypeParameterList(token.parent)) { - return 10 /* punctuation */; - } + if (shouldExcludeFile(sourceFile, !!excludeLibFiles, singleCurrentFile)) { + continue; } - if (isPunctuation(tokenKind)) { - if (token) { - const parent2 = token.parent; - if (tokenKind === 64 /* EqualsToken */) { - if (parent2.kind === 259 /* VariableDeclaration */ || parent2.kind === 171 /* PropertyDeclaration */ || parent2.kind === 168 /* Parameter */ || parent2.kind === 290 /* JsxAttribute */) { - return 5 /* operator */; - } - } - if (parent2.kind === 225 /* BinaryExpression */ || parent2.kind === 223 /* PrefixUnaryExpression */ || parent2.kind === 224 /* PostfixUnaryExpression */ || parent2.kind === 226 /* ConditionalExpression */) { - return 5 /* operator */; - } - } - return 10 /* punctuation */; - } else if (tokenKind === 9 /* NumericLiteral */) { - return 4 /* numericLiteral */; - } else if (tokenKind === 10 /* BigIntLiteral */) { - return 25 /* bigintLiteral */; - } else if (tokenKind === 11 /* StringLiteral */) { - return token && token.parent.kind === 290 /* JsxAttribute */ ? 24 /* jsxAttributeStringLiteralValue */ : 6 /* stringLiteral */; - } else if (tokenKind === 14 /* RegularExpressionLiteral */) { - return 6 /* stringLiteral */; - } else if (isTemplateLiteralKind(tokenKind)) { - return 6 /* stringLiteral */; - } else if (tokenKind === 12 /* JsxText */) { - return 23 /* jsxText */; - } else if (tokenKind === 80 /* Identifier */) { - if (token) { - switch (token.parent.kind) { - case 262 /* ClassDeclaration */: - if (token.parent.name === token) { - return 11 /* className */; - } - return; - case 167 /* TypeParameter */: - if (token.parent.name === token) { - return 15 /* typeParameterName */; - } - return; - case 263 /* InterfaceDeclaration */: - if (token.parent.name === token) { - return 13 /* interfaceName */; - } - return; - case 265 /* EnumDeclaration */: - if (token.parent.name === token) { - return 12 /* enumName */; - } - return; - case 266 /* ModuleDeclaration */: - if (token.parent.name === token) { - return 14 /* moduleName */; - } - return; - case 168 /* Parameter */: - if (token.parent.name === token) { - return isThisIdentifier(token) ? 3 /* keyword */ : 17 /* parameterName */; - } - return; - } - if (isConstTypeReference(token.parent)) { - return 3 /* keyword */; - } + sourceFile.getNamedDeclarations().forEach((declarations, name) => { + getItemsFromNamedDeclaration(patternMatcher, name, declarations, checker, sourceFile.fileName, !!excludeLibFiles, singleCurrentFile, rawItems); + }); + } + rawItems.sort(compareNavigateToItems); + return (maxResultCount === void 0 ? rawItems : rawItems.slice(0, maxResultCount)).map(createNavigateToItem); + } + function shouldExcludeFile(file, excludeLibFiles, singleCurrentFile) { + return file !== singleCurrentFile && excludeLibFiles && (isInsideNodeModules(file.path) || file.hasNoDefaultLib); + } + function getItemsFromNamedDeclaration(patternMatcher, name, declarations, checker, fileName, excludeLibFiles, singleCurrentFile, rawItems) { + const match = patternMatcher.getMatchForLastSegmentOfPattern(name); + if (!match) { + return; + } + for (const declaration of declarations) { + if (!shouldKeepItem(declaration, checker, excludeLibFiles, singleCurrentFile)) + continue; + if (patternMatcher.patternContainsDots) { + const fullMatch = patternMatcher.getFullMatch(getContainers(declaration), name); + if (fullMatch) { + rawItems.push({ name, fileName, matchKind: fullMatch.kind, isCaseSensitive: fullMatch.isCaseSensitive, declaration }); } - return 2 /* identifier */; + } else { + rawItems.push({ name, fileName, matchKind: match.kind, isCaseSensitive: match.isCaseSensitive, declaration }); } } - function processElement(element) { - if (!element) { - return; - } - if (decodedTextSpanIntersectsWith(spanStart, spanLength, element.pos, element.getFullWidth())) { - checkForClassificationCancellation(cancellationToken, element.kind); - for (const child of element.getChildren(sourceFile)) { - if (!tryClassifyNode(child)) { - processElement(child); - } - } + } + function shouldKeepItem(declaration, checker, excludeLibFiles, singleCurrentFile) { + var _a; + switch (declaration.kind) { + case 273 /* ImportClause */: + case 276 /* ImportSpecifier */: + case 271 /* ImportEqualsDeclaration */: + const importer = checker.getSymbolAtLocation(declaration.name); + const imported = checker.getAliasedSymbol(importer); + return importer.escapedName !== imported.escapedName && !((_a = imported.declarations) == null ? void 0 : _a.every((d) => shouldExcludeFile(d.getSourceFile(), excludeLibFiles, singleCurrentFile))); + default: + return true; + } + } + function tryAddSingleDeclarationName(declaration, containers) { + const name = getNameOfDeclaration(declaration); + return !!name && (pushLiteral(name, containers) || name.kind === 167 /* ComputedPropertyName */ && tryAddComputedPropertyName(name.expression, containers)); + } + function tryAddComputedPropertyName(expression, containers) { + return pushLiteral(expression, containers) || isPropertyAccessExpression(expression) && (containers.push(expression.name.text), true) && tryAddComputedPropertyName(expression.expression, containers); + } + function pushLiteral(node, containers) { + return isPropertyNameLiteral(node) && (containers.push(getTextOfIdentifierOrLiteral(node)), true); + } + function getContainers(declaration) { + const containers = []; + const name = getNameOfDeclaration(declaration); + if (name && name.kind === 167 /* ComputedPropertyName */ && !tryAddComputedPropertyName(name.expression, containers)) { + return emptyArray; + } + containers.shift(); + let container = getContainerNode(declaration); + while (container) { + if (!tryAddSingleDeclarationName(container, containers)) { + return emptyArray; } + container = getContainerNode(container); } + return containers.reverse(); } - var noRegexTable; - var init_classifier = __esm({ - "src/services/classifier.ts"() { + function compareNavigateToItems(i1, i2) { + return compareValues(i1.matchKind, i2.matchKind) || compareStringsCaseSensitiveUI(i1.name, i2.name); + } + function createNavigateToItem(rawItem) { + const declaration = rawItem.declaration; + const container = getContainerNode(declaration); + const containerName = container && getNameOfDeclaration(container); + return { + name: rawItem.name, + kind: getNodeKind(declaration), + kindModifiers: getNodeModifiers(declaration), + matchKind: PatternMatchKind[rawItem.matchKind], + isCaseSensitive: rawItem.isCaseSensitive, + fileName: rawItem.fileName, + textSpan: createTextSpanFromNode(declaration), + // TODO(jfreeman): What should be the containerName when the container has a computed name? + containerName: containerName ? containerName.text : "", + containerKind: containerName ? getNodeKind(container) : "" /* unknown */ + }; + } + var init_navigateTo = __esm({ + "src/services/navigateTo.ts"() { "use strict"; init_ts4(); - noRegexTable = arrayToNumericMap([ - 80 /* Identifier */, - 11 /* StringLiteral */, - 9 /* NumericLiteral */, - 10 /* BigIntLiteral */, - 14 /* RegularExpressionLiteral */, - 110 /* ThisKeyword */, - 46 /* PlusPlusToken */, - 47 /* MinusMinusToken */, - 22 /* CloseParenToken */, - 24 /* CloseBracketToken */, - 20 /* CloseBraceToken */, - 112 /* TrueKeyword */, - 97 /* FalseKeyword */ - ], (token) => token, () => true); } }); - // src/services/documentHighlights.ts - var DocumentHighlights; - var init_documentHighlights = __esm({ - "src/services/documentHighlights.ts"() { + // src/services/_namespaces/ts.NavigateTo.ts + var ts_NavigateTo_exports = {}; + __export(ts_NavigateTo_exports, { + getNavigateToItems: () => getNavigateToItems + }); + var init_ts_NavigateTo = __esm({ + "src/services/_namespaces/ts.NavigateTo.ts"() { "use strict"; - init_ts4(); - ((DocumentHighlights2) => { - function getDocumentHighlights(program, cancellationToken, sourceFile, position, sourceFilesToSearch) { - const node = getTouchingPropertyName(sourceFile, position); - if (node.parent && (isJsxOpeningElement(node.parent) && node.parent.tagName === node || isJsxClosingElement(node.parent))) { - const { openingElement, closingElement } = node.parent.parent; - const highlightSpans = [openingElement, closingElement].map(({ tagName }) => getHighlightSpanForNode(tagName, sourceFile)); - return [{ fileName: sourceFile.fileName, highlightSpans }]; + init_navigateTo(); + } + }); + + // src/services/navigationBar.ts + function getNavigationBarItems(sourceFile, cancellationToken) { + curCancellationToken = cancellationToken; + curSourceFile = sourceFile; + try { + return map(primaryNavBarMenuItems(rootNavigationBarNode(sourceFile)), convertToPrimaryNavBarMenuItem); + } finally { + reset(); + } + } + function getNavigationTree(sourceFile, cancellationToken) { + curCancellationToken = cancellationToken; + curSourceFile = sourceFile; + try { + return convertToTree(rootNavigationBarNode(sourceFile)); + } finally { + reset(); + } + } + function reset() { + curSourceFile = void 0; + curCancellationToken = void 0; + parentsStack = []; + parent = void 0; + emptyChildItemArray = []; + } + function nodeText(node) { + return cleanText(node.getText(curSourceFile)); + } + function navigationBarNodeKind(n) { + return n.node.kind; + } + function pushChild(parent2, child) { + if (parent2.children) { + parent2.children.push(child); + } else { + parent2.children = [child]; + } + } + function rootNavigationBarNode(sourceFile) { + Debug.assert(!parentsStack.length); + const root = { node: sourceFile, name: void 0, additionalNodes: void 0, parent: void 0, children: void 0, indent: 0 }; + parent = root; + for (const statement of sourceFile.statements) { + addChildrenRecursively(statement); + } + endNode(); + Debug.assert(!parent && !parentsStack.length); + return root; + } + function addLeafNode(node, name) { + pushChild(parent, emptyNavigationBarNode(node, name)); + } + function emptyNavigationBarNode(node, name) { + return { + node, + name: name || (isDeclaration(node) || isExpression(node) ? getNameOfDeclaration(node) : void 0), + additionalNodes: void 0, + parent, + children: void 0, + indent: parent.indent + 1 + }; + } + function addTrackedEs5Class(name) { + if (!trackedEs5Classes) { + trackedEs5Classes = /* @__PURE__ */ new Map(); + } + trackedEs5Classes.set(name, true); + } + function endNestedNodes(depth) { + for (let i = 0; i < depth; i++) + endNode(); + } + function startNestedNodes(targetNode, entityName) { + const names = []; + while (!isPropertyNameLiteral(entityName)) { + const name = getNameOrArgument(entityName); + const nameText = getElementOrPropertyAccessName(entityName); + entityName = entityName.expression; + if (nameText === "prototype" || isPrivateIdentifier(name)) + continue; + names.push(name); + } + names.push(entityName); + for (let i = names.length - 1; i > 0; i--) { + const name = names[i]; + startNode(targetNode, name); + } + return [names.length - 1, names[0]]; + } + function startNode(node, name) { + const navNode = emptyNavigationBarNode(node, name); + pushChild(parent, navNode); + parentsStack.push(parent); + trackedEs5ClassesStack.push(trackedEs5Classes); + trackedEs5Classes = void 0; + parent = navNode; + } + function endNode() { + if (parent.children) { + mergeChildren(parent.children, parent); + sortChildren(parent.children); + } + parent = parentsStack.pop(); + trackedEs5Classes = trackedEs5ClassesStack.pop(); + } + function addNodeWithRecursiveChild(node, child, name) { + startNode(node, name); + addChildrenRecursively(child); + endNode(); + } + function addNodeWithRecursiveInitializer(node) { + if (node.initializer && isFunctionOrClassExpression(node.initializer)) { + startNode(node); + forEachChild(node.initializer, addChildrenRecursively); + endNode(); + } else { + addNodeWithRecursiveChild(node, node.initializer); + } + } + function hasNavigationBarName(node) { + const name = getNameOfDeclaration(node); + if (name === void 0) + return false; + if (isComputedPropertyName(name)) { + const expression = name.expression; + return isEntityNameExpression(expression) || isNumericLiteral(expression) || isStringOrNumericLiteralLike(expression); + } + return !!name; + } + function addChildrenRecursively(node) { + curCancellationToken.throwIfCancellationRequested(); + if (!node || isToken(node)) { + return; + } + switch (node.kind) { + case 176 /* Constructor */: + const ctr = node; + addNodeWithRecursiveChild(ctr, ctr.body); + for (const param of ctr.parameters) { + if (isParameterPropertyDeclaration(param, ctr)) { + addLeafNode(param); } - return getSemanticDocumentHighlights(position, node, program, cancellationToken, sourceFilesToSearch) || getSyntacticDocumentHighlights(node, sourceFile); - } - DocumentHighlights2.getDocumentHighlights = getDocumentHighlights; - function getHighlightSpanForNode(node, sourceFile) { - return { - fileName: sourceFile.fileName, - textSpan: createTextSpanFromNode(node, sourceFile), - kind: "none" /* none */ - }; } - function getSemanticDocumentHighlights(position, node, program, cancellationToken, sourceFilesToSearch) { - const sourceFilesSet = new Set(sourceFilesToSearch.map((f) => f.fileName)); - const referenceEntries = ts_FindAllReferences_exports.getReferenceEntriesForNode( - position, - node, - program, - sourceFilesToSearch, - cancellationToken, - /*options*/ - void 0, - sourceFilesSet - ); - if (!referenceEntries) - return void 0; - const map2 = arrayToMultiMap(referenceEntries.map(ts_FindAllReferences_exports.toHighlightSpan), (e) => e.fileName, (e) => e.span); - const getCanonicalFileName = createGetCanonicalFileName(program.useCaseSensitiveFileNames()); - return arrayFrom(mapDefinedIterator(map2.entries(), ([fileName, highlightSpans]) => { - if (!sourceFilesSet.has(fileName)) { - if (!program.redirectTargetsMap.has(toPath(fileName, program.getCurrentDirectory(), getCanonicalFileName))) { - return void 0; - } - const redirectTarget = program.getSourceFile(fileName); - const redirect = find(sourceFilesToSearch, (f) => !!f.redirectInfo && f.redirectInfo.redirectTarget === redirectTarget); - fileName = redirect.fileName; - Debug.assert(sourceFilesSet.has(fileName)); - } - return { fileName, highlightSpans }; - })); + break; + case 174 /* MethodDeclaration */: + case 177 /* GetAccessor */: + case 178 /* SetAccessor */: + case 173 /* MethodSignature */: + if (hasNavigationBarName(node)) { + addNodeWithRecursiveChild(node, node.body); } - function getSyntacticDocumentHighlights(node, sourceFile) { - const highlightSpans = getHighlightSpans(node, sourceFile); - return highlightSpans && [{ fileName: sourceFile.fileName, highlightSpans }]; + break; + case 172 /* PropertyDeclaration */: + if (hasNavigationBarName(node)) { + addNodeWithRecursiveInitializer(node); } - function getHighlightSpans(node, sourceFile) { - switch (node.kind) { - case 101 /* IfKeyword */: - case 93 /* ElseKeyword */: - return isIfStatement(node.parent) ? getIfElseOccurrences(node.parent, sourceFile) : void 0; - case 107 /* ReturnKeyword */: - return useParent(node.parent, isReturnStatement, getReturnOccurrences); - case 111 /* ThrowKeyword */: - return useParent(node.parent, isThrowStatement, getThrowOccurrences); - case 113 /* TryKeyword */: - case 85 /* CatchKeyword */: - case 98 /* FinallyKeyword */: - const tryStatement = node.kind === 85 /* CatchKeyword */ ? node.parent.parent : node.parent; - return useParent(tryStatement, isTryStatement, getTryCatchFinallyOccurrences); - case 109 /* SwitchKeyword */: - return useParent(node.parent, isSwitchStatement, getSwitchCaseDefaultOccurrences); - case 84 /* CaseKeyword */: - case 90 /* DefaultKeyword */: { - if (isDefaultClause(node.parent) || isCaseClause(node.parent)) { - return useParent(node.parent.parent.parent, isSwitchStatement, getSwitchCaseDefaultOccurrences); - } - return void 0; - } - case 83 /* BreakKeyword */: - case 88 /* ContinueKeyword */: - return useParent(node.parent, isBreakOrContinueStatement, getBreakOrContinueStatementOccurrences); - case 99 /* ForKeyword */: - case 117 /* WhileKeyword */: - case 92 /* DoKeyword */: - return useParent(node.parent, (n) => isIterationStatement( - n, - /*lookInLabeledStatements*/ - true - ), getLoopBreakContinueOccurrences); - case 137 /* ConstructorKeyword */: - return getFromAllDeclarations(isConstructorDeclaration, [137 /* ConstructorKeyword */]); - case 139 /* GetKeyword */: - case 153 /* SetKeyword */: - return getFromAllDeclarations(isAccessor, [139 /* GetKeyword */, 153 /* SetKeyword */]); - case 135 /* AwaitKeyword */: - return useParent(node.parent, isAwaitExpression, getAsyncAndAwaitOccurrences); - case 134 /* AsyncKeyword */: - return highlightSpans(getAsyncAndAwaitOccurrences(node)); - case 127 /* YieldKeyword */: - return highlightSpans(getYieldOccurrences(node)); - case 103 /* InKeyword */: - return void 0; - default: - return isModifierKind(node.kind) && (isDeclaration(node.parent) || isVariableStatement(node.parent)) ? highlightSpans(getModifierOccurrences(node.kind, node.parent)) : void 0; - } - function getFromAllDeclarations(nodeTest, keywords) { - return useParent(node.parent, nodeTest, (decl) => { - var _a; - return mapDefined((_a = tryCast(decl, canHaveSymbol)) == null ? void 0 : _a.symbol.declarations, (d) => nodeTest(d) ? find(d.getChildren(sourceFile), (c) => contains(keywords, c.kind)) : void 0); - }); - } - function useParent(node2, nodeTest, getNodes4) { - return nodeTest(node2) ? highlightSpans(getNodes4(node2, sourceFile)) : void 0; - } - function highlightSpans(nodes) { - return nodes && nodes.map((node2) => getHighlightSpanForNode(node2, sourceFile)); - } + break; + case 171 /* PropertySignature */: + if (hasNavigationBarName(node)) { + addLeafNode(node); } - function aggregateOwnedThrowStatements(node) { - if (isThrowStatement(node)) { - return [node]; - } else if (isTryStatement(node)) { - return concatenate( - node.catchClause ? aggregateOwnedThrowStatements(node.catchClause) : node.tryBlock && aggregateOwnedThrowStatements(node.tryBlock), - node.finallyBlock && aggregateOwnedThrowStatements(node.finallyBlock) - ); - } - return isFunctionLike(node) ? void 0 : flatMapChildren(node, aggregateOwnedThrowStatements); + break; + case 273 /* ImportClause */: + const importClause = node; + if (importClause.name) { + addLeafNode(importClause.name); } - function getThrowStatementOwner(throwStatement) { - let child = throwStatement; - while (child.parent) { - const parent2 = child.parent; - if (isFunctionBlock(parent2) || parent2.kind === 311 /* SourceFile */) { - return parent2; - } - if (isTryStatement(parent2) && parent2.tryBlock === child && parent2.catchClause) { - return child; + const { namedBindings } = importClause; + if (namedBindings) { + if (namedBindings.kind === 274 /* NamespaceImport */) { + addLeafNode(namedBindings); + } else { + for (const element of namedBindings.elements) { + addLeafNode(element); } - child = parent2; } - return void 0; - } - function aggregateAllBreakAndContinueStatements(node) { - return isBreakOrContinueStatement(node) ? [node] : isFunctionLike(node) ? void 0 : flatMapChildren(node, aggregateAllBreakAndContinueStatements); - } - function flatMapChildren(node, cb) { - const result = []; - node.forEachChild((child) => { - const value = cb(child); - if (value !== void 0) { - result.push(...toArray(value)); - } - }); - return result; - } - function ownsBreakOrContinueStatement(owner, statement) { - const actualOwner = getBreakOrContinueOwner(statement); - return !!actualOwner && actualOwner === owner; } - function getBreakOrContinueOwner(statement) { - return findAncestor(statement, (node) => { - switch (node.kind) { - case 254 /* SwitchStatement */: - if (statement.kind === 250 /* ContinueStatement */) { - return false; - } - case 247 /* ForStatement */: - case 248 /* ForInStatement */: - case 249 /* ForOfStatement */: - case 246 /* WhileStatement */: - case 245 /* DoStatement */: - return !statement.label || isLabeledBy(node, statement.label.escapedText); - default: - return isFunctionLike(node) && "quit"; - } - }); + break; + case 304 /* ShorthandPropertyAssignment */: + addNodeWithRecursiveChild(node, node.name); + break; + case 305 /* SpreadAssignment */: + const { expression } = node; + isIdentifier(expression) ? addLeafNode(node, expression) : addLeafNode(node); + break; + case 208 /* BindingElement */: + case 303 /* PropertyAssignment */: + case 260 /* VariableDeclaration */: { + const child = node; + if (isBindingPattern(child.name)) { + addChildrenRecursively(child.name); + } else { + addNodeWithRecursiveInitializer(child); } - function getModifierOccurrences(modifier, declaration) { - return mapDefined(getNodesToSearchForModifier(declaration, modifierToFlag(modifier)), (node) => findModifier(node, modifier)); + break; + } + case 262 /* FunctionDeclaration */: + const nameNode = node.name; + if (nameNode && isIdentifier(nameNode)) { + addTrackedEs5Class(nameNode.text); } - function getNodesToSearchForModifier(declaration, modifierFlag) { - const container = declaration.parent; - switch (container.kind) { - case 267 /* ModuleBlock */: - case 311 /* SourceFile */: - case 240 /* Block */: - case 295 /* CaseClause */: - case 296 /* DefaultClause */: - if (modifierFlag & 256 /* Abstract */ && isClassDeclaration(declaration)) { - return [...declaration.members, declaration]; - } else { - return container.statements; - } - case 175 /* Constructor */: - case 173 /* MethodDeclaration */: - case 261 /* FunctionDeclaration */: - return [...container.parameters, ...isClassLike(container.parent) ? container.parent.members : []]; - case 262 /* ClassDeclaration */: - case 230 /* ClassExpression */: - case 263 /* InterfaceDeclaration */: - case 186 /* TypeLiteral */: - const nodes = container.members; - if (modifierFlag & (28 /* AccessibilityModifier */ | 64 /* Readonly */)) { - const constructor = find(container.members, isConstructorDeclaration); - if (constructor) { - return [...nodes, ...constructor.parameters]; - } - } else if (modifierFlag & 256 /* Abstract */) { - return [...nodes, container]; - } - return nodes; - case 209 /* ObjectLiteralExpression */: - return void 0; - default: - Debug.assertNever(container, "Invalid container kind."); + addNodeWithRecursiveChild(node, node.body); + break; + case 219 /* ArrowFunction */: + case 218 /* FunctionExpression */: + addNodeWithRecursiveChild(node, node.body); + break; + case 266 /* EnumDeclaration */: + startNode(node); + for (const member of node.members) { + if (!isComputedProperty(member)) { + addLeafNode(member); } } - function pushKeywordIf(keywordList, token, ...expected) { - if (token && contains(expected, token.kind)) { - keywordList.push(token); - return true; - } - return false; + endNode(); + break; + case 263 /* ClassDeclaration */: + case 231 /* ClassExpression */: + case 264 /* InterfaceDeclaration */: + startNode(node); + for (const member of node.members) { + addChildrenRecursively(member); } - function getLoopBreakContinueOccurrences(loopNode) { - const keywords = []; - if (pushKeywordIf(keywords, loopNode.getFirstToken(), 99 /* ForKeyword */, 117 /* WhileKeyword */, 92 /* DoKeyword */)) { - if (loopNode.kind === 245 /* DoStatement */) { - const loopTokens = loopNode.getChildren(); - for (let i = loopTokens.length - 1; i >= 0; i--) { - if (pushKeywordIf(keywords, loopTokens[i], 117 /* WhileKeyword */)) { - break; + endNode(); + break; + case 267 /* ModuleDeclaration */: + addNodeWithRecursiveChild(node, getInteriorModule(node).body); + break; + case 277 /* ExportAssignment */: { + const expression2 = node.expression; + const child = isObjectLiteralExpression(expression2) || isCallExpression(expression2) ? expression2 : isArrowFunction(expression2) || isFunctionExpression(expression2) ? expression2.body : void 0; + if (child) { + startNode(node); + addChildrenRecursively(child); + endNode(); + } else { + addLeafNode(node); + } + break; + } + case 281 /* ExportSpecifier */: + case 271 /* ImportEqualsDeclaration */: + case 181 /* IndexSignature */: + case 179 /* CallSignature */: + case 180 /* ConstructSignature */: + case 265 /* TypeAliasDeclaration */: + addLeafNode(node); + break; + case 213 /* CallExpression */: + case 226 /* BinaryExpression */: { + const special = getAssignmentDeclarationKind(node); + switch (special) { + case 1 /* ExportsProperty */: + case 2 /* ModuleExports */: + addNodeWithRecursiveChild(node, node.right); + return; + case 6 /* Prototype */: + case 3 /* PrototypeProperty */: { + const binaryExpression = node; + const assignmentTarget = binaryExpression.left; + const prototypeAccess = special === 3 /* PrototypeProperty */ ? assignmentTarget.expression : assignmentTarget; + let depth = 0; + let className; + if (isIdentifier(prototypeAccess.expression)) { + addTrackedEs5Class(prototypeAccess.expression.text); + className = prototypeAccess.expression; + } else { + [depth, className] = startNestedNodes(binaryExpression, prototypeAccess.expression); + } + if (special === 6 /* Prototype */) { + if (isObjectLiteralExpression(binaryExpression.right)) { + if (binaryExpression.right.properties.length > 0) { + startNode(binaryExpression, className); + forEachChild(binaryExpression.right, addChildrenRecursively); + endNode(); } } + } else if (isFunctionExpression(binaryExpression.right) || isArrowFunction(binaryExpression.right)) { + addNodeWithRecursiveChild(node, binaryExpression.right, className); + } else { + startNode(binaryExpression, className); + addNodeWithRecursiveChild(node, binaryExpression.right, assignmentTarget.name); + endNode(); } + endNestedNodes(depth); + return; } - forEach(aggregateAllBreakAndContinueStatements(loopNode.statement), (statement) => { - if (ownsBreakOrContinueStatement(loopNode, statement)) { - pushKeywordIf(keywords, statement.getFirstToken(), 83 /* BreakKeyword */, 88 /* ContinueKeyword */); - } - }); - return keywords; - } - function getBreakOrContinueStatementOccurrences(breakOrContinueStatement) { - const owner = getBreakOrContinueOwner(breakOrContinueStatement); - if (owner) { - switch (owner.kind) { - case 247 /* ForStatement */: - case 248 /* ForInStatement */: - case 249 /* ForOfStatement */: - case 245 /* DoStatement */: - case 246 /* WhileStatement */: - return getLoopBreakContinueOccurrences(owner); - case 254 /* SwitchStatement */: - return getSwitchCaseDefaultOccurrences(owner); - } + case 7 /* ObjectDefinePropertyValue */: + case 9 /* ObjectDefinePrototypeProperty */: { + const defineCall = node; + const className = special === 7 /* ObjectDefinePropertyValue */ ? defineCall.arguments[0] : defineCall.arguments[0].expression; + const memberName = defineCall.arguments[1]; + const [depth, classNameIdentifier] = startNestedNodes(node, className); + startNode(node, classNameIdentifier); + startNode(node, setTextRange(factory.createIdentifier(memberName.text), memberName)); + addChildrenRecursively(node.arguments[2]); + endNode(); + endNode(); + endNestedNodes(depth); + return; } - return void 0; - } - function getSwitchCaseDefaultOccurrences(switchStatement) { - const keywords = []; - pushKeywordIf(keywords, switchStatement.getFirstToken(), 109 /* SwitchKeyword */); - forEach(switchStatement.caseBlock.clauses, (clause) => { - pushKeywordIf(keywords, clause.getFirstToken(), 84 /* CaseKeyword */, 90 /* DefaultKeyword */); - forEach(aggregateAllBreakAndContinueStatements(clause), (statement) => { - if (ownsBreakOrContinueStatement(switchStatement, statement)) { - pushKeywordIf(keywords, statement.getFirstToken(), 83 /* BreakKeyword */); + case 5 /* Property */: { + const binaryExpression = node; + const assignmentTarget = binaryExpression.left; + const targetFunction = assignmentTarget.expression; + if (isIdentifier(targetFunction) && getElementOrPropertyAccessName(assignmentTarget) !== "prototype" && trackedEs5Classes && trackedEs5Classes.has(targetFunction.text)) { + if (isFunctionExpression(binaryExpression.right) || isArrowFunction(binaryExpression.right)) { + addNodeWithRecursiveChild(node, binaryExpression.right, targetFunction); + } else if (isBindableStaticAccessExpression(assignmentTarget)) { + startNode(binaryExpression, targetFunction); + addNodeWithRecursiveChild(binaryExpression.left, binaryExpression.right, getNameOrArgument(assignmentTarget)); + endNode(); } - }); - }); - return keywords; - } - function getTryCatchFinallyOccurrences(tryStatement, sourceFile) { - const keywords = []; - pushKeywordIf(keywords, tryStatement.getFirstToken(), 113 /* TryKeyword */); - if (tryStatement.catchClause) { - pushKeywordIf(keywords, tryStatement.catchClause.getFirstToken(), 85 /* CatchKeyword */); - } - if (tryStatement.finallyBlock) { - const finallyKeyword = findChildOfKind(tryStatement, 98 /* FinallyKeyword */, sourceFile); - pushKeywordIf(keywords, finallyKeyword, 98 /* FinallyKeyword */); - } - return keywords; - } - function getThrowOccurrences(throwStatement, sourceFile) { - const owner = getThrowStatementOwner(throwStatement); - if (!owner) { - return void 0; - } - const keywords = []; - forEach(aggregateOwnedThrowStatements(owner), (throwStatement2) => { - keywords.push(findChildOfKind(throwStatement2, 111 /* ThrowKeyword */, sourceFile)); - }); - if (isFunctionBlock(owner)) { - forEachReturnStatement(owner, (returnStatement) => { - keywords.push(findChildOfKind(returnStatement, 107 /* ReturnKeyword */, sourceFile)); - }); - } - return keywords; - } - function getReturnOccurrences(returnStatement, sourceFile) { - const func = getContainingFunction(returnStatement); - if (!func) { - return void 0; - } - const keywords = []; - forEachReturnStatement(cast(func.body, isBlock), (returnStatement2) => { - keywords.push(findChildOfKind(returnStatement2, 107 /* ReturnKeyword */, sourceFile)); - }); - forEach(aggregateOwnedThrowStatements(func.body), (throwStatement) => { - keywords.push(findChildOfKind(throwStatement, 111 /* ThrowKeyword */, sourceFile)); - }); - return keywords; - } - function getAsyncAndAwaitOccurrences(node) { - const func = getContainingFunction(node); - if (!func) { - return void 0; - } - const keywords = []; - if (func.modifiers) { - func.modifiers.forEach((modifier) => { - pushKeywordIf(keywords, modifier, 134 /* AsyncKeyword */); - }); + return; + } + break; } - forEachChild(func, (child) => { - traverseWithoutCrossingFunction(child, (node2) => { - if (isAwaitExpression(node2)) { - pushKeywordIf(keywords, node2.getFirstToken(), 135 /* AwaitKeyword */); - } - }); - }); - return keywords; + case 4 /* ThisProperty */: + case 0 /* None */: + case 8 /* ObjectDefinePropertyExports */: + break; + default: + Debug.assertNever(special); } - function getYieldOccurrences(node) { - const func = getContainingFunction(node); - if (!func) { - return void 0; - } - const keywords = []; - forEachChild(func, (child) => { - traverseWithoutCrossingFunction(child, (node2) => { - if (isYieldExpression(node2)) { - pushKeywordIf(keywords, node2.getFirstToken(), 127 /* YieldKeyword */); + } + default: + if (hasJSDocNodes(node)) { + forEach(node.jsDoc, (jsDoc) => { + forEach(jsDoc.tags, (tag) => { + if (isJSDocTypeAlias(tag)) { + addLeafNode(tag); } }); }); - return keywords; - } - function traverseWithoutCrossingFunction(node, cb) { - cb(node); - if (!isFunctionLike(node) && !isClassLike(node) && !isInterfaceDeclaration(node) && !isModuleDeclaration(node) && !isTypeAliasDeclaration(node) && !isTypeNode(node)) { - forEachChild(node, (child) => traverseWithoutCrossingFunction(child, cb)); - } } - function getIfElseOccurrences(ifStatement, sourceFile) { - const keywords = getIfElseKeywords(ifStatement, sourceFile); - const result = []; - for (let i = 0; i < keywords.length; i++) { - if (keywords[i].kind === 93 /* ElseKeyword */ && i < keywords.length - 1) { - const elseKeyword = keywords[i]; - const ifKeyword = keywords[i + 1]; - let shouldCombineElseAndIf = true; - for (let j = ifKeyword.getStart(sourceFile) - 1; j >= elseKeyword.end; j--) { - if (!isWhiteSpaceSingleLine(sourceFile.text.charCodeAt(j))) { - shouldCombineElseAndIf = false; - break; - } - } - if (shouldCombineElseAndIf) { - result.push({ - fileName: sourceFile.fileName, - textSpan: createTextSpanFromBounds(elseKeyword.getStart(), ifKeyword.end), - kind: "reference" /* reference */ - }); - i++; - continue; - } - } - result.push(getHighlightSpanForNode(keywords[i], sourceFile)); + forEachChild(node, addChildrenRecursively); + } + } + function mergeChildren(children, node) { + const nameToItems = /* @__PURE__ */ new Map(); + filterMutate(children, (child, index) => { + const declName = child.name || getNameOfDeclaration(child.node); + const name = declName && nodeText(declName); + if (!name) { + return true; + } + const itemsWithSameName = nameToItems.get(name); + if (!itemsWithSameName) { + nameToItems.set(name, child); + return true; + } + if (itemsWithSameName instanceof Array) { + for (const itemWithSameName of itemsWithSameName) { + if (tryMerge(itemWithSameName, child, index, node)) { + return false; } - return result; } - function getIfElseKeywords(ifStatement, sourceFile) { - const keywords = []; - while (isIfStatement(ifStatement.parent) && ifStatement.parent.elseStatement === ifStatement) { - ifStatement = ifStatement.parent; - } - while (true) { - const children = ifStatement.getChildren(sourceFile); - pushKeywordIf(keywords, children[0], 101 /* IfKeyword */); - for (let i = children.length - 1; i >= 0; i--) { - if (pushKeywordIf(keywords, children[i], 93 /* ElseKeyword */)) { - break; - } - } - if (!ifStatement.elseStatement || !isIfStatement(ifStatement.elseStatement)) { - break; + itemsWithSameName.push(child); + return true; + } else { + const itemWithSameName = itemsWithSameName; + if (tryMerge(itemWithSameName, child, index, node)) { + return false; + } + nameToItems.set(name, [itemWithSameName, child]); + return true; + } + }); + } + function tryMergeEs5Class(a, b, bIndex, parent2) { + function isPossibleConstructor(node) { + return isFunctionExpression(node) || isFunctionDeclaration(node) || isVariableDeclaration(node); + } + const bAssignmentDeclarationKind = isBinaryExpression(b.node) || isCallExpression(b.node) ? getAssignmentDeclarationKind(b.node) : 0 /* None */; + const aAssignmentDeclarationKind = isBinaryExpression(a.node) || isCallExpression(a.node) ? getAssignmentDeclarationKind(a.node) : 0 /* None */; + if (isEs5ClassMember[bAssignmentDeclarationKind] && isEs5ClassMember[aAssignmentDeclarationKind] || isPossibleConstructor(a.node) && isEs5ClassMember[bAssignmentDeclarationKind] || isPossibleConstructor(b.node) && isEs5ClassMember[aAssignmentDeclarationKind] || isClassDeclaration(a.node) && isSynthesized(a.node) && isEs5ClassMember[bAssignmentDeclarationKind] || isClassDeclaration(b.node) && isEs5ClassMember[aAssignmentDeclarationKind] || isClassDeclaration(a.node) && isSynthesized(a.node) && isPossibleConstructor(b.node) || isClassDeclaration(b.node) && isPossibleConstructor(a.node) && isSynthesized(a.node)) { + let lastANode = a.additionalNodes && lastOrUndefined(a.additionalNodes) || a.node; + if (!isClassDeclaration(a.node) && !isClassDeclaration(b.node) || isPossibleConstructor(a.node) || isPossibleConstructor(b.node)) { + const ctorFunction = isPossibleConstructor(a.node) ? a.node : isPossibleConstructor(b.node) ? b.node : void 0; + if (ctorFunction !== void 0) { + const ctorNode = setTextRange( + factory.createConstructorDeclaration( + /*modifiers*/ + void 0, + [], + /*body*/ + void 0 + ), + ctorFunction + ); + const ctor = emptyNavigationBarNode(ctorNode); + ctor.indent = a.indent + 1; + ctor.children = a.node === ctorFunction ? a.children : b.children; + a.children = a.node === ctorFunction ? concatenate([ctor], b.children || [b]) : concatenate(a.children || [{ ...a }], [ctor]); + } else { + if (a.children || b.children) { + a.children = concatenate(a.children || [{ ...a }], b.children || [b]); + if (a.children) { + mergeChildren(a.children, a); + sortChildren(a.children); } - ifStatement = ifStatement.elseStatement; } - return keywords; } - function isLabeledBy(node, labelName) { - return !!findAncestor(node.parent, (owner) => !isLabeledStatement(owner) ? "quit" : owner.label.escapedText === labelName); + lastANode = a.node = setTextRange( + factory.createClassDeclaration( + /*modifiers*/ + void 0, + a.name || factory.createIdentifier("__class__"), + /*typeParameters*/ + void 0, + /*heritageClauses*/ + void 0, + [] + ), + a.node + ); + } else { + a.children = concatenate(a.children, b.children); + if (a.children) { + mergeChildren(a.children, a); } - })(DocumentHighlights || (DocumentHighlights = {})); + } + const bNode = b.node; + if (parent2.children[bIndex - 1].node.end === lastANode.end) { + setTextRange(lastANode, { pos: lastANode.pos, end: bNode.end }); + } else { + if (!a.additionalNodes) + a.additionalNodes = []; + a.additionalNodes.push(setTextRange( + factory.createClassDeclaration( + /*modifiers*/ + void 0, + a.name || factory.createIdentifier("__class__"), + /*typeParameters*/ + void 0, + /*heritageClauses*/ + void 0, + [] + ), + b.node + )); + } + return true; } - }); - - // src/services/documentRegistry.ts - function isDocumentRegistryEntry(entry) { - return !!entry.sourceFile; + return bAssignmentDeclarationKind === 0 /* None */ ? false : true; } - function createDocumentRegistry(useCaseSensitiveFileNames, currentDirectory) { - return createDocumentRegistryInternal(useCaseSensitiveFileNames, currentDirectory); + function tryMerge(a, b, bIndex, parent2) { + if (tryMergeEs5Class(a, b, bIndex, parent2)) { + return true; + } + if (shouldReallyMerge(a.node, b.node, parent2)) { + merge(a, b); + return true; + } + return false; } - function createDocumentRegistryInternal(useCaseSensitiveFileNames, currentDirectory = "", externalCache) { - const buckets = /* @__PURE__ */ new Map(); - const getCanonicalFileName = createGetCanonicalFileName(!!useCaseSensitiveFileNames); - function reportStats() { - const bucketInfoArray = arrayFrom(buckets.keys()).filter((name) => name && name.charAt(0) === "_").map((name) => { - const entries = buckets.get(name); - const sourceFiles = []; - entries.forEach((entry, name2) => { - if (isDocumentRegistryEntry(entry)) { - sourceFiles.push({ - name: name2, - scriptKind: entry.sourceFile.scriptKind, - refCount: entry.languageServiceRefCount - }); - } else { - entry.forEach((value, scriptKind) => sourceFiles.push({ name: name2, scriptKind, refCount: value.languageServiceRefCount })); - } - }); - sourceFiles.sort((x, y) => y.refCount - x.refCount); - return { - bucket: name, - sourceFiles - }; - }); - return JSON.stringify(bucketInfoArray, void 0, 2); + function shouldReallyMerge(a, b, parent2) { + if (a.kind !== b.kind || a.parent !== b.parent && !(isOwnChild(a, parent2) && isOwnChild(b, parent2))) { + return false; } - function getCompilationSettings(settingsOrHost) { - if (typeof settingsOrHost.getCompilationSettings === "function") { - return settingsOrHost.getCompilationSettings(); - } - return settingsOrHost; + switch (a.kind) { + case 172 /* PropertyDeclaration */: + case 174 /* MethodDeclaration */: + case 177 /* GetAccessor */: + case 178 /* SetAccessor */: + return isStatic(a) === isStatic(b); + case 267 /* ModuleDeclaration */: + return areSameModule(a, b) && getFullyQualifiedModuleName(a) === getFullyQualifiedModuleName(b); + default: + return true; } - function acquireDocument(fileName, compilationSettings, scriptSnapshot, version2, scriptKind, languageVersionOrOptions) { - const path = toPath(fileName, currentDirectory, getCanonicalFileName); - const key = getKeyForCompilationSettings(getCompilationSettings(compilationSettings)); - return acquireDocumentWithKey(fileName, path, compilationSettings, key, scriptSnapshot, version2, scriptKind, languageVersionOrOptions); + } + function isSynthesized(node) { + return !!(node.flags & 16 /* Synthesized */); + } + function isOwnChild(n, parent2) { + const par = isModuleBlock(n.parent) ? n.parent.parent : n.parent; + return par === parent2.node || contains(parent2.additionalNodes, par); + } + function areSameModule(a, b) { + if (!a.body || !b.body) { + return a.body === b.body; } - function acquireDocumentWithKey(fileName, path, compilationSettings, key, scriptSnapshot, version2, scriptKind, languageVersionOrOptions) { - return acquireOrUpdateDocument( - fileName, - path, - compilationSettings, - key, - scriptSnapshot, - version2, - /*acquiring*/ - true, - scriptKind, - languageVersionOrOptions - ); + return a.body.kind === b.body.kind && (a.body.kind !== 267 /* ModuleDeclaration */ || areSameModule(a.body, b.body)); + } + function merge(target, source) { + target.additionalNodes = target.additionalNodes || []; + target.additionalNodes.push(source.node); + if (source.additionalNodes) { + target.additionalNodes.push(...source.additionalNodes); } - function updateDocument(fileName, compilationSettings, scriptSnapshot, version2, scriptKind, languageVersionOrOptions) { - const path = toPath(fileName, currentDirectory, getCanonicalFileName); - const key = getKeyForCompilationSettings(getCompilationSettings(compilationSettings)); - return updateDocumentWithKey(fileName, path, compilationSettings, key, scriptSnapshot, version2, scriptKind, languageVersionOrOptions); + target.children = concatenate(target.children, source.children); + if (target.children) { + mergeChildren(target.children, target); + sortChildren(target.children); } - function updateDocumentWithKey(fileName, path, compilationSettings, key, scriptSnapshot, version2, scriptKind, languageVersionOrOptions) { - return acquireOrUpdateDocument( - fileName, - path, - getCompilationSettings(compilationSettings), - key, - scriptSnapshot, - version2, - /*acquiring*/ - false, - scriptKind, - languageVersionOrOptions - ); + } + function sortChildren(children) { + children.sort(compareChildren); + } + function compareChildren(child1, child2) { + return compareStringsCaseSensitiveUI(tryGetName(child1.node), tryGetName(child2.node)) || compareValues(navigationBarNodeKind(child1), navigationBarNodeKind(child2)); + } + function tryGetName(node) { + if (node.kind === 267 /* ModuleDeclaration */) { + return getModuleName(node); } - function getDocumentRegistryEntry(bucketEntry, scriptKind) { - const entry = isDocumentRegistryEntry(bucketEntry) ? bucketEntry : bucketEntry.get(Debug.checkDefined(scriptKind, "If there are more than one scriptKind's for same document the scriptKind should be provided")); - Debug.assert(scriptKind === void 0 || !entry || entry.sourceFile.scriptKind === scriptKind, `Script kind should match provided ScriptKind:${scriptKind} and sourceFile.scriptKind: ${entry == null ? void 0 : entry.sourceFile.scriptKind}, !entry: ${!entry}`); - return entry; + const declName = getNameOfDeclaration(node); + if (declName && isPropertyName(declName)) { + const propertyName = getPropertyNameForPropertyNameNode(declName); + return propertyName && unescapeLeadingUnderscores(propertyName); } - function acquireOrUpdateDocument(fileName, path, compilationSettingsOrHost, key, scriptSnapshot, version2, acquiring, scriptKind, languageVersionOrOptions) { - var _a, _b, _c, _d; - scriptKind = ensureScriptKind(fileName, scriptKind); - const compilationSettings = getCompilationSettings(compilationSettingsOrHost); - const host = compilationSettingsOrHost === compilationSettings ? void 0 : compilationSettingsOrHost; - const scriptTarget = scriptKind === 6 /* JSON */ ? 100 /* JSON */ : getEmitScriptTarget(compilationSettings); - const sourceFileOptions = typeof languageVersionOrOptions === "object" ? languageVersionOrOptions : { - languageVersion: scriptTarget, - impliedNodeFormat: host && getImpliedNodeFormatForFile(path, (_d = (_c = (_b = (_a = host.getCompilerHost) == null ? void 0 : _a.call(host)) == null ? void 0 : _b.getModuleResolutionCache) == null ? void 0 : _c.call(_b)) == null ? void 0 : _d.getPackageJsonInfoCache(), host, compilationSettings), - setExternalModuleIndicator: getSetExternalModuleIndicator(compilationSettings) - }; - sourceFileOptions.languageVersion = scriptTarget; - const oldBucketCount = buckets.size; - const keyWithMode = getDocumentRegistryBucketKeyWithMode(key, sourceFileOptions.impliedNodeFormat); - const bucket = getOrUpdate(buckets, keyWithMode, () => /* @__PURE__ */ new Map()); - if (tracing) { - if (buckets.size > oldBucketCount) { - tracing.instant(tracing.Phase.Session, "createdDocumentRegistryBucket", { configFilePath: compilationSettings.configFilePath, key: keyWithMode }); + switch (node.kind) { + case 218 /* FunctionExpression */: + case 219 /* ArrowFunction */: + case 231 /* ClassExpression */: + return getFunctionOrClassName(node); + default: + return void 0; + } + } + function getItemName(node, name) { + if (node.kind === 267 /* ModuleDeclaration */) { + return cleanText(getModuleName(node)); + } + if (name) { + const text = isIdentifier(name) ? name.text : isElementAccessExpression(name) ? `[${nodeText(name.argumentExpression)}]` : nodeText(name); + if (text.length > 0) { + return cleanText(text); + } + } + switch (node.kind) { + case 312 /* SourceFile */: + const sourceFile = node; + return isExternalModule(sourceFile) ? `"${escapeString(getBaseFileName(removeFileExtension(normalizePath(sourceFile.fileName))))}"` : ""; + case 277 /* ExportAssignment */: + return isExportAssignment(node) && node.isExportEquals ? "export=" /* ExportEquals */ : "default" /* Default */; + case 219 /* ArrowFunction */: + case 262 /* FunctionDeclaration */: + case 218 /* FunctionExpression */: + case 263 /* ClassDeclaration */: + case 231 /* ClassExpression */: + if (getSyntacticModifierFlags(node) & 2048 /* Default */) { + return "default"; } - const otherBucketKey = !isDeclarationFileName(path) && forEachEntry(buckets, (bucket2, bucketKey) => bucketKey !== keyWithMode && bucket2.has(path) && bucketKey); - if (otherBucketKey) { - tracing.instant(tracing.Phase.Session, "documentRegistryBucketOverlap", { path, key1: otherBucketKey, key2: keyWithMode }); + return getFunctionOrClassName(node); + case 176 /* Constructor */: + return "constructor"; + case 180 /* ConstructSignature */: + return "new()"; + case 179 /* CallSignature */: + return "()"; + case 181 /* IndexSignature */: + return "[]"; + default: + return ""; + } + } + function primaryNavBarMenuItems(root) { + const primaryNavBarMenuItems2 = []; + function recur(item) { + if (shouldAppearInPrimaryNavBarMenu(item)) { + primaryNavBarMenuItems2.push(item); + if (item.children) { + for (const child of item.children) { + recur(child); + } } } - const bucketEntry = bucket.get(path); - let entry = bucketEntry && getDocumentRegistryEntry(bucketEntry, scriptKind); - if (!entry && externalCache) { - const sourceFile = externalCache.getDocument(keyWithMode, path); - if (sourceFile) { - Debug.assert(acquiring); - entry = { - sourceFile, - languageServiceRefCount: 0 - }; - setBucketEntry(); - } + } + recur(root); + return primaryNavBarMenuItems2; + function shouldAppearInPrimaryNavBarMenu(item) { + if (item.children) { + return true; } - if (!entry) { - const sourceFile = createLanguageServiceSourceFile( - fileName, - scriptSnapshot, - sourceFileOptions, - version2, - /*setNodeParents*/ - false, - scriptKind - ); - if (externalCache) { - externalCache.setDocument(keyWithMode, path, sourceFile); - } - entry = { - sourceFile, - languageServiceRefCount: 1 - }; - setBucketEntry(); - } else { - if (entry.sourceFile.version !== version2) { - entry.sourceFile = updateLanguageServiceSourceFile( - entry.sourceFile, - scriptSnapshot, - version2, - scriptSnapshot.getChangeRange(entry.sourceFile.scriptSnapshot) - ); - if (externalCache) { - externalCache.setDocument(keyWithMode, path, entry.sourceFile); - } + switch (navigationBarNodeKind(item)) { + case 263 /* ClassDeclaration */: + case 231 /* ClassExpression */: + case 266 /* EnumDeclaration */: + case 264 /* InterfaceDeclaration */: + case 267 /* ModuleDeclaration */: + case 312 /* SourceFile */: + case 265 /* TypeAliasDeclaration */: + case 353 /* JSDocTypedefTag */: + case 345 /* JSDocCallbackTag */: + return true; + case 219 /* ArrowFunction */: + case 262 /* FunctionDeclaration */: + case 218 /* FunctionExpression */: + return isTopLevelFunctionDeclaration(item); + default: + return false; + } + function isTopLevelFunctionDeclaration(item2) { + if (!item2.node.body) { + return false; } - if (acquiring) { - entry.languageServiceRefCount++; + switch (navigationBarNodeKind(item2.parent)) { + case 268 /* ModuleBlock */: + case 312 /* SourceFile */: + case 174 /* MethodDeclaration */: + case 176 /* Constructor */: + return true; + default: + return false; } } - Debug.assert(entry.languageServiceRefCount !== 0); - return entry.sourceFile; - function setBucketEntry() { - if (!bucketEntry) { - bucket.set(path, entry); - } else if (isDocumentRegistryEntry(bucketEntry)) { - const scriptKindMap = /* @__PURE__ */ new Map(); - scriptKindMap.set(bucketEntry.sourceFile.scriptKind, bucketEntry); - scriptKindMap.set(scriptKind, entry); - bucket.set(path, scriptKindMap); - } else { - bucketEntry.set(scriptKind, entry); - } + } + } + function convertToTree(n) { + return { + text: getItemName(n.node, n.name), + kind: getNodeKind(n.node), + kindModifiers: getModifiers2(n.node), + spans: getSpans(n), + nameSpan: n.name && getNodeSpan(n.name), + childItems: map(n.children, convertToTree) + }; + } + function convertToPrimaryNavBarMenuItem(n) { + return { + text: getItemName(n.node, n.name), + kind: getNodeKind(n.node), + kindModifiers: getModifiers2(n.node), + spans: getSpans(n), + childItems: map(n.children, convertToSecondaryNavBarMenuItem) || emptyChildItemArray, + indent: n.indent, + bolded: false, + grayed: false + }; + function convertToSecondaryNavBarMenuItem(n2) { + return { + text: getItemName(n2.node, n2.name), + kind: getNodeKind(n2.node), + kindModifiers: getNodeModifiers(n2.node), + spans: getSpans(n2), + childItems: emptyChildItemArray, + indent: 0, + bolded: false, + grayed: false + }; + } + } + function getSpans(n) { + const spans = [getNodeSpan(n.node)]; + if (n.additionalNodes) { + for (const node of n.additionalNodes) { + spans.push(getNodeSpan(node)); } } - function releaseDocument(fileName, compilationSettings, scriptKind, impliedNodeFormat) { - const path = toPath(fileName, currentDirectory, getCanonicalFileName); - const key = getKeyForCompilationSettings(compilationSettings); - return releaseDocumentWithKey(path, key, scriptKind, impliedNodeFormat); + return spans; + } + function getModuleName(moduleDeclaration) { + if (isAmbientModule(moduleDeclaration)) { + return getTextOfNode(moduleDeclaration.name); } - function releaseDocumentWithKey(path, key, scriptKind, impliedNodeFormat) { - const bucket = Debug.checkDefined(buckets.get(getDocumentRegistryBucketKeyWithMode(key, impliedNodeFormat))); - const bucketEntry = bucket.get(path); - const entry = getDocumentRegistryEntry(bucketEntry, scriptKind); - entry.languageServiceRefCount--; - Debug.assert(entry.languageServiceRefCount >= 0); - if (entry.languageServiceRefCount === 0) { - if (isDocumentRegistryEntry(bucketEntry)) { - bucket.delete(path); - } else { - bucketEntry.delete(scriptKind); - if (bucketEntry.size === 1) { - bucket.set(path, firstDefinedIterator(bucketEntry.values(), identity)); - } + return getFullyQualifiedModuleName(moduleDeclaration); + } + function getFullyQualifiedModuleName(moduleDeclaration) { + const result = [getTextOfIdentifierOrLiteral(moduleDeclaration.name)]; + while (moduleDeclaration.body && moduleDeclaration.body.kind === 267 /* ModuleDeclaration */) { + moduleDeclaration = moduleDeclaration.body; + result.push(getTextOfIdentifierOrLiteral(moduleDeclaration.name)); + } + return result.join("."); + } + function getInteriorModule(decl) { + return decl.body && isModuleDeclaration(decl.body) ? getInteriorModule(decl.body) : decl; + } + function isComputedProperty(member) { + return !member.name || member.name.kind === 167 /* ComputedPropertyName */; + } + function getNodeSpan(node) { + return node.kind === 312 /* SourceFile */ ? createTextSpanFromRange(node) : createTextSpanFromNode(node, curSourceFile); + } + function getModifiers2(node) { + if (node.parent && node.parent.kind === 260 /* VariableDeclaration */) { + node = node.parent; + } + return getNodeModifiers(node); + } + function getFunctionOrClassName(node) { + const { parent: parent2 } = node; + if (node.name && getFullWidth(node.name) > 0) { + return cleanText(declarationNameToString(node.name)); + } else if (isVariableDeclaration(parent2)) { + return cleanText(declarationNameToString(parent2.name)); + } else if (isBinaryExpression(parent2) && parent2.operatorToken.kind === 64 /* EqualsToken */) { + return nodeText(parent2.left).replace(whiteSpaceRegex, ""); + } else if (isPropertyAssignment(parent2)) { + return nodeText(parent2.name); + } else if (getSyntacticModifierFlags(node) & 2048 /* Default */) { + return "default"; + } else if (isClassLike(node)) { + return ""; + } else if (isCallExpression(parent2)) { + let name = getCalledExpressionName(parent2.expression); + if (name !== void 0) { + name = cleanText(name); + if (name.length > maxLength) { + return `${name} callback`; } + const args = cleanText(mapDefined(parent2.arguments, (a) => isStringLiteralLike(a) ? a.getText(curSourceFile) : void 0).join(", ")); + return `${name}(${args}) callback`; } } - function getLanguageServiceRefCounts(path, scriptKind) { - return arrayFrom(buckets.entries(), ([key, bucket]) => { - const bucketEntry = bucket.get(path); - const entry = bucketEntry && getDocumentRegistryEntry(bucketEntry, scriptKind); - return [key, entry && entry.languageServiceRefCount]; - }); + return ""; + } + function getCalledExpressionName(expr) { + if (isIdentifier(expr)) { + return expr.text; + } else if (isPropertyAccessExpression(expr)) { + const left = getCalledExpressionName(expr.expression); + const right = expr.name.text; + return left === void 0 ? right : `${left}.${right}`; + } else { + return void 0; } - return { - acquireDocument, - acquireDocumentWithKey, - updateDocument, - updateDocumentWithKey, - releaseDocument, - releaseDocumentWithKey, - getLanguageServiceRefCounts, - reportStats, - getKeyForCompilationSettings - }; } - function getKeyForCompilationSettings(settings) { - return getKeyForCompilerOptions(settings, sourceFileAffectingCompilerOptions); + function isFunctionOrClassExpression(node) { + switch (node.kind) { + case 219 /* ArrowFunction */: + case 218 /* FunctionExpression */: + case 231 /* ClassExpression */: + return true; + default: + return false; + } } - function getDocumentRegistryBucketKeyWithMode(key, mode) { - return mode ? `${key}|${mode}` : key; + function cleanText(text) { + text = text.length > maxLength ? text.substring(0, maxLength) + "..." : text; + return text.replace(/\\?(\r?\n|\r|\u2028|\u2029)/g, ""); } - var init_documentRegistry = __esm({ - "src/services/documentRegistry.ts"() { + var whiteSpaceRegex, maxLength, curCancellationToken, curSourceFile, parentsStack, parent, trackedEs5ClassesStack, trackedEs5Classes, emptyChildItemArray, isEs5ClassMember; + var init_navigationBar = __esm({ + "src/services/navigationBar.ts"() { "use strict"; init_ts4(); + whiteSpaceRegex = /\s+/g; + maxLength = 150; + parentsStack = []; + trackedEs5ClassesStack = []; + emptyChildItemArray = []; + isEs5ClassMember = { + [5 /* Property */]: true, + [3 /* PrototypeProperty */]: true, + [7 /* ObjectDefinePropertyValue */]: true, + [9 /* ObjectDefinePrototypeProperty */]: true, + [0 /* None */]: false, + [1 /* ExportsProperty */]: false, + [2 /* ModuleExports */]: false, + [8 /* ObjectDefinePropertyExports */]: false, + [6 /* Prototype */]: true, + [4 /* ThisProperty */]: false + }; } }); - // src/services/getEditsForFileRename.ts - function getEditsForFileRename(program, oldFileOrDirPath, newFileOrDirPath, host, formatContext, preferences, sourceMapper) { - const useCaseSensitiveFileNames = hostUsesCaseSensitiveFileNames(host); - const getCanonicalFileName = createGetCanonicalFileName(useCaseSensitiveFileNames); - const oldToNew = getPathUpdater(oldFileOrDirPath, newFileOrDirPath, getCanonicalFileName, sourceMapper); - const newToOld = getPathUpdater(newFileOrDirPath, oldFileOrDirPath, getCanonicalFileName, sourceMapper); - return ts_textChanges_exports.ChangeTracker.with({ host, formatContext, preferences }, (changeTracker) => { - updateTsconfigFiles(program, changeTracker, oldToNew, oldFileOrDirPath, newFileOrDirPath, host.getCurrentDirectory(), useCaseSensitiveFileNames); - updateImports(program, changeTracker, oldToNew, newToOld, host, getCanonicalFileName); - }); - } - function getPathUpdater(oldFileOrDirPath, newFileOrDirPath, getCanonicalFileName, sourceMapper) { - const canonicalOldPath = getCanonicalFileName(oldFileOrDirPath); - return (path) => { - const originalPath = sourceMapper && sourceMapper.tryGetSourcePosition({ fileName: path, pos: 0 }); - const updatedPath = getUpdatedPath(originalPath ? originalPath.fileName : path); - return originalPath ? updatedPath === void 0 ? void 0 : makeCorrespondingRelativeChange(originalPath.fileName, updatedPath, path, getCanonicalFileName) : updatedPath; - }; - function getUpdatedPath(pathToUpdate) { - if (getCanonicalFileName(pathToUpdate) === canonicalOldPath) - return newFileOrDirPath; - const suffix = tryRemoveDirectoryPrefix(pathToUpdate, canonicalOldPath, getCanonicalFileName); - return suffix === void 0 ? void 0 : newFileOrDirPath + "/" + suffix; + // src/services/_namespaces/ts.NavigationBar.ts + var ts_NavigationBar_exports = {}; + __export(ts_NavigationBar_exports, { + getNavigationBarItems: () => getNavigationBarItems, + getNavigationTree: () => getNavigationTree + }); + var init_ts_NavigationBar = __esm({ + "src/services/_namespaces/ts.NavigationBar.ts"() { + "use strict"; + init_navigationBar(); } + }); + + // src/services/refactorProvider.ts + function registerRefactor(name, refactor) { + refactors.set(name, refactor); } - function makeCorrespondingRelativeChange(a0, b0, a1, getCanonicalFileName) { - const rel = getRelativePathFromFile(a0, b0, getCanonicalFileName); - return combinePathsSafe(getDirectoryPath(a1), rel); + function getApplicableRefactors(context, includeInteractiveActions) { + return arrayFrom(flatMapIterator(refactors.values(), (refactor) => { + var _a; + return context.cancellationToken && context.cancellationToken.isCancellationRequested() || !((_a = refactor.kinds) == null ? void 0 : _a.some((kind) => refactorKindBeginsWith(kind, context.kind))) ? void 0 : refactor.getAvailableActions(context, includeInteractiveActions); + })); } - function updateTsconfigFiles(program, changeTracker, oldToNew, oldFileOrDirPath, newFileOrDirPath, currentDirectory, useCaseSensitiveFileNames) { - const { configFile } = program.getCompilerOptions(); - if (!configFile) - return; - const configDir = getDirectoryPath(configFile.fileName); - const jsonObjectLiteral = getTsConfigObjectLiteralExpression(configFile); - if (!jsonObjectLiteral) - return; - forEachProperty(jsonObjectLiteral, (property, propertyName) => { - switch (propertyName) { - case "files": - case "include": - case "exclude": { - const foundExactMatch = updatePaths(property); - if (foundExactMatch || propertyName !== "include" || !isArrayLiteralExpression(property.initializer)) - return; - const includes = mapDefined(property.initializer.elements, (e) => isStringLiteral(e) ? e.text : void 0); - if (includes.length === 0) - return; - const matchers = getFileMatcherPatterns( - configDir, - /*excludes*/ - [], - includes, - useCaseSensitiveFileNames, - currentDirectory - ); - if (getRegexFromPattern(Debug.checkDefined(matchers.includeFilePattern), useCaseSensitiveFileNames).test(oldFileOrDirPath) && !getRegexFromPattern(Debug.checkDefined(matchers.includeFilePattern), useCaseSensitiveFileNames).test(newFileOrDirPath)) { - changeTracker.insertNodeAfter(configFile, last(property.initializer.elements), factory.createStringLiteral(relativePath(newFileOrDirPath))); - } - return; - } - case "compilerOptions": - forEachProperty(property.initializer, (property2, propertyName2) => { - const option = getOptionFromName(propertyName2); - Debug.assert((option == null ? void 0 : option.type) !== "listOrElement"); - if (option && (option.isFilePath || option.type === "list" && option.element.isFilePath)) { - updatePaths(property2); - } else if (propertyName2 === "paths") { - forEachProperty(property2.initializer, (pathsProperty) => { - if (!isArrayLiteralExpression(pathsProperty.initializer)) - return; - for (const e of pathsProperty.initializer.elements) { - tryUpdateString(e); - } - }); - } - }); - return; - } - }); - function updatePaths(property) { - const elements = isArrayLiteralExpression(property.initializer) ? property.initializer.elements : [property.initializer]; - let foundExactMatch = false; - for (const element of elements) { - foundExactMatch = tryUpdateString(element) || foundExactMatch; - } - return foundExactMatch; + function getEditsForRefactor(context, refactorName14, actionName2, interactiveRefactorArguments) { + const refactor = refactors.get(refactorName14); + return refactor && refactor.getEditsForAction(context, actionName2, interactiveRefactorArguments); + } + var refactors; + var init_refactorProvider = __esm({ + "src/services/refactorProvider.ts"() { + "use strict"; + init_ts4(); + init_ts_refactor(); + refactors = /* @__PURE__ */ new Map(); } - function tryUpdateString(element) { - if (!isStringLiteral(element)) - return false; - const elementFileName = combinePathsSafe(configDir, element.text); - const updated = oldToNew(elementFileName); - if (updated !== void 0) { - changeTracker.replaceRangeWithText(configFile, createStringRange(element, configFile), relativePath(updated)); - return true; - } - return false; + }); + + // src/services/refactors/convertExport.ts + function getInfo2(context, considerPartialSpans = true) { + const { file, program } = context; + const span = getRefactorContextSpan(context); + const token = getTokenAtPosition(file, span.start); + const exportNode = !!(token.parent && getSyntacticModifierFlags(token.parent) & 32 /* Export */) && considerPartialSpans ? token.parent : getParentNodeInSpan(token, file, span); + if (!exportNode || !isSourceFile(exportNode.parent) && !(isModuleBlock(exportNode.parent) && isAmbientModule(exportNode.parent.parent))) { + return { error: getLocaleSpecificMessage(Diagnostics.Could_not_find_export_statement) }; } - function relativePath(path) { - return getRelativePathFromDirectory( - configDir, - path, - /*ignoreCase*/ - !useCaseSensitiveFileNames - ); + const checker = program.getTypeChecker(); + const exportingModuleSymbol = getExportingModuleSymbol(exportNode.parent, checker); + const flags = getSyntacticModifierFlags(exportNode) || (isExportAssignment(exportNode) && !exportNode.isExportEquals ? 2080 /* ExportDefault */ : 0 /* None */); + const wasDefault = !!(flags & 2048 /* Default */); + if (!(flags & 32 /* Export */) || !wasDefault && exportingModuleSymbol.exports.has("default" /* Default */)) { + return { error: getLocaleSpecificMessage(Diagnostics.This_file_already_has_a_default_export) }; } - } - function updateImports(program, changeTracker, oldToNew, newToOld, host, getCanonicalFileName) { - const allFiles = program.getSourceFiles(); - for (const sourceFile of allFiles) { - const newFromOld = oldToNew(sourceFile.fileName); - const newImportFromPath = newFromOld ?? sourceFile.fileName; - const newImportFromDirectory = getDirectoryPath(newImportFromPath); - const oldFromNew = newToOld(sourceFile.fileName); - const oldImportFromPath = oldFromNew || sourceFile.fileName; - const oldImportFromDirectory = getDirectoryPath(oldImportFromPath); - const importingSourceFileMoved = newFromOld !== void 0 || oldFromNew !== void 0; - updateImportsWorker( - sourceFile, - changeTracker, - (referenceText) => { - if (!pathIsRelative(referenceText)) - return void 0; - const oldAbsolute = combinePathsSafe(oldImportFromDirectory, referenceText); - const newAbsolute = oldToNew(oldAbsolute); - return newAbsolute === void 0 ? void 0 : ensurePathIsNonModuleName(getRelativePathFromDirectory(newImportFromDirectory, newAbsolute, getCanonicalFileName)); - }, - (importLiteral) => { - const importedModuleSymbol = program.getTypeChecker().getSymbolAtLocation(importLiteral); - if ((importedModuleSymbol == null ? void 0 : importedModuleSymbol.declarations) && importedModuleSymbol.declarations.some((d) => isAmbientModule(d))) - return void 0; - const toImport = oldFromNew !== void 0 ? getSourceFileToImportFromResolved( - importLiteral, - resolveModuleName(importLiteral.text, oldImportFromPath, program.getCompilerOptions(), host), - oldToNew, - allFiles - ) : getSourceFileToImport(importedModuleSymbol, importLiteral, sourceFile, program, host, oldToNew); - return toImport !== void 0 && (toImport.updated || importingSourceFileMoved && pathIsRelative(importLiteral.text)) ? ts_moduleSpecifiers_exports.updateModuleSpecifier(program.getCompilerOptions(), sourceFile, getCanonicalFileName(newImportFromPath), toImport.newFileName, createModuleSpecifierResolutionHost(program, host), importLiteral.text) : void 0; + const noSymbolError = (id) => isIdentifier(id) && checker.getSymbolAtLocation(id) ? void 0 : { error: getLocaleSpecificMessage(Diagnostics.Can_only_convert_named_export) }; + switch (exportNode.kind) { + case 262 /* FunctionDeclaration */: + case 263 /* ClassDeclaration */: + case 264 /* InterfaceDeclaration */: + case 266 /* EnumDeclaration */: + case 265 /* TypeAliasDeclaration */: + case 267 /* ModuleDeclaration */: { + const node = exportNode; + if (!node.name) + return void 0; + return noSymbolError(node.name) || { exportNode: node, exportName: node.name, wasDefault, exportingModuleSymbol }; + } + case 243 /* VariableStatement */: { + const vs = exportNode; + if (!(vs.declarationList.flags & 2 /* Const */) || vs.declarationList.declarations.length !== 1) { + return void 0; } - ); + const decl = first(vs.declarationList.declarations); + if (!decl.initializer) + return void 0; + Debug.assert(!wasDefault, "Can't have a default flag here"); + return noSymbolError(decl.name) || { exportNode: vs, exportName: decl.name, wasDefault, exportingModuleSymbol }; + } + case 277 /* ExportAssignment */: { + const node = exportNode; + if (node.isExportEquals) + return void 0; + return noSymbolError(node.expression) || { exportNode: node, exportName: node.expression, wasDefault, exportingModuleSymbol }; + } + default: + return void 0; } } - function combineNormal(pathA, pathB) { - return normalizePath(combinePaths(pathA, pathB)); - } - function combinePathsSafe(pathA, pathB) { - return ensurePathIsNonModuleName(combineNormal(pathA, pathB)); + function doChange(exportingSourceFile, program, info, changes, cancellationToken) { + changeExport(exportingSourceFile, info, changes, program.getTypeChecker()); + changeImports(program, info, changes, cancellationToken); } - function getSourceFileToImport(importedModuleSymbol, importLiteral, importingSourceFile, program, host, oldToNew) { - var _a; - if (importedModuleSymbol) { - const oldFileName = find(importedModuleSymbol.declarations, isSourceFile).fileName; - const newFileName = oldToNew(oldFileName); - return newFileName === void 0 ? { newFileName: oldFileName, updated: false } : { newFileName, updated: true }; + function changeExport(exportingSourceFile, { wasDefault, exportNode, exportName }, changes, checker) { + if (wasDefault) { + if (isExportAssignment(exportNode) && !exportNode.isExportEquals) { + const exp = exportNode.expression; + const spec = makeExportSpecifier(exp.text, exp.text); + changes.replaceNode(exportingSourceFile, exportNode, factory.createExportDeclaration( + /*modifiers*/ + void 0, + /*isTypeOnly*/ + false, + factory.createNamedExports([spec]) + )); + } else { + changes.delete(exportingSourceFile, Debug.checkDefined(findModifier(exportNode, 90 /* DefaultKeyword */), "Should find a default keyword in modifier list")); + } } else { - const mode = getModeForUsageLocation(importingSourceFile, importLiteral); - const resolved = host.resolveModuleNameLiterals || !host.resolveModuleNames ? (_a = importingSourceFile.resolvedModules) == null ? void 0 : _a.get(importLiteral.text, mode) : host.getResolvedModuleWithFailedLookupLocationsFromCache && host.getResolvedModuleWithFailedLookupLocationsFromCache(importLiteral.text, importingSourceFile.fileName, mode); - return getSourceFileToImportFromResolved(importLiteral, resolved, oldToNew, program.getSourceFiles()); + const exportKeyword = Debug.checkDefined(findModifier(exportNode, 95 /* ExportKeyword */), "Should find an export keyword in modifier list"); + switch (exportNode.kind) { + case 262 /* FunctionDeclaration */: + case 263 /* ClassDeclaration */: + case 264 /* InterfaceDeclaration */: + changes.insertNodeAfter(exportingSourceFile, exportKeyword, factory.createToken(90 /* DefaultKeyword */)); + break; + case 243 /* VariableStatement */: + const decl = first(exportNode.declarationList.declarations); + if (!ts_FindAllReferences_exports.Core.isSymbolReferencedInFile(exportName, checker, exportingSourceFile) && !decl.type) { + changes.replaceNode(exportingSourceFile, exportNode, factory.createExportDefault(Debug.checkDefined(decl.initializer, "Initializer was previously known to be present"))); + break; + } + case 266 /* EnumDeclaration */: + case 265 /* TypeAliasDeclaration */: + case 267 /* ModuleDeclaration */: + changes.deleteModifier(exportingSourceFile, exportKeyword); + changes.insertNodeAfter(exportingSourceFile, exportNode, factory.createExportDefault(factory.createIdentifier(exportName.text))); + break; + default: + Debug.fail(`Unexpected exportNode kind ${exportNode.kind}`); + } } } - function getSourceFileToImportFromResolved(importLiteral, resolved, oldToNew, sourceFiles) { - if (!resolved) - return void 0; - if (resolved.resolvedModule) { - const result2 = tryChange(resolved.resolvedModule.resolvedFileName); - if (result2) - return result2; - } - const result = forEach(resolved.failedLookupLocations, tryChangeWithIgnoringPackageJsonExisting) || pathIsRelative(importLiteral.text) && forEach(resolved.failedLookupLocations, tryChangeWithIgnoringPackageJson); - if (result) - return result; - return resolved.resolvedModule && { newFileName: resolved.resolvedModule.resolvedFileName, updated: false }; - function tryChangeWithIgnoringPackageJsonExisting(oldFileName) { - const newFileName = oldToNew(oldFileName); - return newFileName && find(sourceFiles, (src) => src.fileName === newFileName) ? tryChangeWithIgnoringPackageJson(oldFileName) : void 0; - } - function tryChangeWithIgnoringPackageJson(oldFileName) { - return !endsWith(oldFileName, "/package.json") ? tryChange(oldFileName) : void 0; - } - function tryChange(oldFileName) { - const newFileName = oldToNew(oldFileName); - return newFileName && { newFileName, updated: true }; - } + function changeImports(program, { wasDefault, exportName, exportingModuleSymbol }, changes, cancellationToken) { + const checker = program.getTypeChecker(); + const exportSymbol = Debug.checkDefined(checker.getSymbolAtLocation(exportName), "Export name should resolve to a symbol"); + ts_FindAllReferences_exports.Core.eachExportReference(program.getSourceFiles(), checker, cancellationToken, exportSymbol, exportingModuleSymbol, exportName.text, wasDefault, (ref) => { + if (exportName === ref) + return; + const importingSourceFile = ref.getSourceFile(); + if (wasDefault) { + changeDefaultToNamedImport(importingSourceFile, ref, changes, exportName.text); + } else { + changeNamedToDefaultImport(importingSourceFile, ref, changes); + } + }); } - function updateImportsWorker(sourceFile, changeTracker, updateRef, updateImport2) { - for (const ref of sourceFile.referencedFiles || emptyArray) { - const updated = updateRef(ref.fileName); - if (updated !== void 0 && updated !== sourceFile.text.slice(ref.pos, ref.end)) - changeTracker.replaceRangeWithText(sourceFile, ref, updated); + function changeDefaultToNamedImport(importingSourceFile, ref, changes, exportName) { + const { parent: parent2 } = ref; + switch (parent2.kind) { + case 211 /* PropertyAccessExpression */: + changes.replaceNode(importingSourceFile, ref, factory.createIdentifier(exportName)); + break; + case 276 /* ImportSpecifier */: + case 281 /* ExportSpecifier */: { + const spec = parent2; + changes.replaceNode(importingSourceFile, spec, makeImportSpecifier(exportName, spec.name.text)); + break; + } + case 273 /* ImportClause */: { + const clause = parent2; + Debug.assert(clause.name === ref, "Import clause name should match provided ref"); + const spec = makeImportSpecifier(exportName, ref.text); + const { namedBindings } = clause; + if (!namedBindings) { + changes.replaceNode(importingSourceFile, ref, factory.createNamedImports([spec])); + } else if (namedBindings.kind === 274 /* NamespaceImport */) { + changes.deleteRange(importingSourceFile, { pos: ref.getStart(importingSourceFile), end: namedBindings.getStart(importingSourceFile) }); + const quotePreference = isStringLiteral(clause.parent.moduleSpecifier) ? quotePreferenceFromString(clause.parent.moduleSpecifier, importingSourceFile) : 1 /* Double */; + const newImport = makeImport( + /*defaultImport*/ + void 0, + [makeImportSpecifier(exportName, ref.text)], + clause.parent.moduleSpecifier, + quotePreference + ); + changes.insertNodeAfter(importingSourceFile, clause.parent, newImport); + } else { + changes.delete(importingSourceFile, ref); + changes.insertNodeAtEndOfList(importingSourceFile, namedBindings.elements, spec); + } + break; + } + case 205 /* ImportType */: + const importTypeNode = parent2; + changes.replaceNode(importingSourceFile, parent2, factory.createImportTypeNode(importTypeNode.argument, importTypeNode.attributes, factory.createIdentifier(exportName), importTypeNode.typeArguments, importTypeNode.isTypeOf)); + break; + default: + Debug.failBadSyntaxKind(parent2); } - for (const importStringLiteral of sourceFile.imports) { - const updated = updateImport2(importStringLiteral); - if (updated !== void 0 && updated !== importStringLiteral.text) - changeTracker.replaceRangeWithText(sourceFile, createStringRange(importStringLiteral, sourceFile), updated); + } + function changeNamedToDefaultImport(importingSourceFile, ref, changes) { + const parent2 = ref.parent; + switch (parent2.kind) { + case 211 /* PropertyAccessExpression */: + changes.replaceNode(importingSourceFile, ref, factory.createIdentifier("default")); + break; + case 276 /* ImportSpecifier */: { + const defaultImport = factory.createIdentifier(parent2.name.text); + if (parent2.parent.elements.length === 1) { + changes.replaceNode(importingSourceFile, parent2.parent, defaultImport); + } else { + changes.delete(importingSourceFile, parent2); + changes.insertNodeBefore(importingSourceFile, parent2.parent, defaultImport); + } + break; + } + case 281 /* ExportSpecifier */: { + changes.replaceNode(importingSourceFile, parent2, makeExportSpecifier("default", parent2.name.text)); + break; + } + default: + Debug.assertNever(parent2, `Unexpected parent kind ${parent2.kind}`); } } - function createStringRange(node, sourceFile) { - return createRange(node.getStart(sourceFile) + 1, node.end - 1); + function makeImportSpecifier(propertyName, name) { + return factory.createImportSpecifier( + /*isTypeOnly*/ + false, + propertyName === name ? void 0 : factory.createIdentifier(propertyName), + factory.createIdentifier(name) + ); } - function forEachProperty(objectLiteral, cb) { - if (!isObjectLiteralExpression(objectLiteral)) - return; - for (const property of objectLiteral.properties) { - if (isPropertyAssignment(property) && isStringLiteral(property.name)) { - cb(property, property.name.text); - } + function makeExportSpecifier(propertyName, name) { + return factory.createExportSpecifier( + /*isTypeOnly*/ + false, + propertyName === name ? void 0 : factory.createIdentifier(propertyName), + factory.createIdentifier(name) + ); + } + function getExportingModuleSymbol(parent2, checker) { + if (isSourceFile(parent2)) { + return parent2.symbol; + } + const symbol = parent2.parent.symbol; + if (symbol.valueDeclaration && isExternalModuleAugmentation(symbol.valueDeclaration)) { + return checker.getMergedSymbol(symbol); } + return symbol; } - var init_getEditsForFileRename = __esm({ - "src/services/getEditsForFileRename.ts"() { + var refactorName, defaultToNamedAction, namedToDefaultAction; + var init_convertExport = __esm({ + "src/services/refactors/convertExport.ts"() { "use strict"; init_ts4(); + init_ts_refactor(); + refactorName = "Convert export"; + defaultToNamedAction = { + name: "Convert default export to named export", + description: getLocaleSpecificMessage(Diagnostics.Convert_default_export_to_named_export), + kind: "refactor.rewrite.export.named" + }; + namedToDefaultAction = { + name: "Convert named export to default export", + description: getLocaleSpecificMessage(Diagnostics.Convert_named_export_to_default_export), + kind: "refactor.rewrite.export.default" + }; + registerRefactor(refactorName, { + kinds: [ + defaultToNamedAction.kind, + namedToDefaultAction.kind + ], + getAvailableActions: function getRefactorActionsToConvertBetweenNamedAndDefaultExports(context) { + const info = getInfo2(context, context.triggerReason === "invoked"); + if (!info) + return emptyArray; + if (!isRefactorErrorInfo(info)) { + const action = info.wasDefault ? defaultToNamedAction : namedToDefaultAction; + return [{ name: refactorName, description: action.description, actions: [action] }]; + } + if (context.preferences.provideRefactorNotApplicableReason) { + return [ + { + name: refactorName, + description: getLocaleSpecificMessage(Diagnostics.Convert_default_export_to_named_export), + actions: [ + { ...defaultToNamedAction, notApplicableReason: info.error }, + { ...namedToDefaultAction, notApplicableReason: info.error } + ] + } + ]; + } + return emptyArray; + }, + getEditsForAction: function getRefactorEditsToConvertBetweenNamedAndDefaultExports(context, actionName2) { + Debug.assert(actionName2 === defaultToNamedAction.name || actionName2 === namedToDefaultAction.name, "Unexpected action name"); + const info = getInfo2(context); + Debug.assert(info && !isRefactorErrorInfo(info), "Expected applicable refactor info"); + const edits = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange(context.file, context.program, info, t, context.cancellationToken)); + return { edits, renameFilename: void 0, renameLocation: void 0 }; + } + }); } }); - // src/services/patternMatcher.ts - function createPatternMatch(kind, isCaseSensitive) { - return { - kind, - isCaseSensitive - }; - } - function createPatternMatcher(pattern) { - const stringToWordSpans = /* @__PURE__ */ new Map(); - const dotSeparatedSegments = pattern.trim().split(".").map((p) => createSegment(p.trim())); - if (dotSeparatedSegments.some((segment) => !segment.subWordTextChunks.length)) - return void 0; - return { - getFullMatch: (containers, candidate) => getFullMatch(containers, candidate, dotSeparatedSegments, stringToWordSpans), - getMatchForLastSegmentOfPattern: (candidate) => matchSegment(candidate, last(dotSeparatedSegments), stringToWordSpans), - patternContainsDots: dotSeparatedSegments.length > 1 - }; - } - function getFullMatch(candidateContainers, candidate, dotSeparatedSegments, stringToWordSpans) { - const candidateMatch = matchSegment(candidate, last(dotSeparatedSegments), stringToWordSpans); - if (!candidateMatch) { - return void 0; - } - if (dotSeparatedSegments.length - 1 > candidateContainers.length) { + // src/services/refactors/convertImport.ts + function getImportConversionInfo(context, considerPartialSpans = true) { + const { file } = context; + const span = getRefactorContextSpan(context); + const token = getTokenAtPosition(file, span.start); + const importDecl = considerPartialSpans ? findAncestor(token, isImportDeclaration) : getParentNodeInSpan(token, file, span); + if (!importDecl || !isImportDeclaration(importDecl)) + return { error: "Selection is not an import declaration." }; + const end = span.start + span.length; + const nextToken = findNextToken(importDecl, importDecl.parent, file); + if (nextToken && end > nextToken.getStart()) return void 0; + const { importClause } = importDecl; + if (!importClause) { + return { error: getLocaleSpecificMessage(Diagnostics.Could_not_find_import_clause) }; } - let bestMatch; - for (let i = dotSeparatedSegments.length - 2, j = candidateContainers.length - 1; i >= 0; i -= 1, j -= 1) { - bestMatch = betterMatch(bestMatch, matchSegment(candidateContainers[j], dotSeparatedSegments[i], stringToWordSpans)); - } - return bestMatch; - } - function getWordSpans(word, stringToWordSpans) { - let spans = stringToWordSpans.get(word); - if (!spans) { - stringToWordSpans.set(word, spans = breakIntoWordSpans(word)); + if (!importClause.namedBindings) { + return { error: getLocaleSpecificMessage(Diagnostics.Could_not_find_namespace_import_or_named_imports) }; } - return spans; - } - function matchTextChunk(candidate, chunk, stringToWordSpans) { - const index = indexOfIgnoringCase(candidate, chunk.textLowerCase); - if (index === 0) { - return createPatternMatch( - chunk.text.length === candidate.length ? 0 /* exact */ : 1 /* prefix */, - /*isCaseSensitive:*/ - startsWith(candidate, chunk.text) - ); + if (importClause.namedBindings.kind === 274 /* NamespaceImport */) { + return { convertTo: 0 /* Named */, import: importClause.namedBindings }; } - if (chunk.isLowerCase) { - if (index === -1) - return void 0; - const wordSpans = getWordSpans(candidate, stringToWordSpans); - for (const span of wordSpans) { - if (partStartsWith( - candidate, - span, - chunk.text, - /*ignoreCase*/ - true - )) { - return createPatternMatch( - 2 /* substring */, - /*isCaseSensitive:*/ - partStartsWith( - candidate, - span, - chunk.text, - /*ignoreCase*/ - false - ) - ); - } - } - if (chunk.text.length < candidate.length && isUpperCaseLetter(candidate.charCodeAt(index))) { - return createPatternMatch( - 2 /* substring */, - /*isCaseSensitive*/ - false - ); - } - } else { - if (candidate.indexOf(chunk.text) > 0) { - return createPatternMatch( - 2 /* substring */, - /*isCaseSensitive*/ - true - ); - } - if (chunk.characterSpans.length > 0) { - const candidateParts = getWordSpans(candidate, stringToWordSpans); - const isCaseSensitive = tryCamelCaseMatch( - candidate, - candidateParts, - chunk, - /*ignoreCase*/ - false - ) ? true : tryCamelCaseMatch( - candidate, - candidateParts, - chunk, - /*ignoreCase*/ + const shouldUseDefault = getShouldUseDefault(context.program, importClause); + return shouldUseDefault ? { convertTo: 1 /* Default */, import: importClause.namedBindings } : { convertTo: 2 /* Namespace */, import: importClause.namedBindings }; + } + function getShouldUseDefault(program, importClause) { + return getAllowSyntheticDefaultImports(program.getCompilerOptions()) && isExportEqualsModule(importClause.parent.moduleSpecifier, program.getTypeChecker()); + } + function doChange2(sourceFile, program, changes, info) { + const checker = program.getTypeChecker(); + if (info.convertTo === 0 /* Named */) { + doChangeNamespaceToNamed(sourceFile, checker, changes, info.import, getAllowSyntheticDefaultImports(program.getCompilerOptions())); + } else { + doChangeNamedToNamespaceOrDefault(sourceFile, program, changes, info.import, info.convertTo === 1 /* Default */); + } + } + function doChangeNamespaceToNamed(sourceFile, checker, changes, toConvert, allowSyntheticDefaultImports) { + let usedAsNamespaceOrDefault = false; + const nodesToReplace = []; + const conflictingNames = /* @__PURE__ */ new Map(); + ts_FindAllReferences_exports.Core.eachSymbolReferenceInFile(toConvert.name, checker, sourceFile, (id) => { + if (!isPropertyAccessOrQualifiedName(id.parent)) { + usedAsNamespaceOrDefault = true; + } else { + const exportName = getRightOfPropertyAccessOrQualifiedName(id.parent).text; + if (checker.resolveName( + exportName, + id, + 67108863 /* All */, + /*excludeGlobals*/ true - ) ? false : void 0; - if (isCaseSensitive !== void 0) { - return createPatternMatch(3 /* camelCase */, isCaseSensitive); + )) { + conflictingNames.set(exportName, true); } + Debug.assert(getLeftOfPropertyAccessOrQualifiedName(id.parent) === id, "Parent expression should match id"); + nodesToReplace.push(id.parent); } + }); + const exportNameToImportName = /* @__PURE__ */ new Map(); + for (const propertyAccessOrQualifiedName of nodesToReplace) { + const exportName = getRightOfPropertyAccessOrQualifiedName(propertyAccessOrQualifiedName).text; + let importName = exportNameToImportName.get(exportName); + if (importName === void 0) { + exportNameToImportName.set(exportName, importName = conflictingNames.has(exportName) ? getUniqueName(exportName, sourceFile) : exportName); + } + changes.replaceNode(sourceFile, propertyAccessOrQualifiedName, factory.createIdentifier(importName)); } - } - function matchSegment(candidate, segment, stringToWordSpans) { - if (every2(segment.totalTextChunk.text, (ch) => ch !== 32 /* space */ && ch !== 42 /* asterisk */)) { - const match = matchTextChunk(candidate, segment.totalTextChunk, stringToWordSpans); - if (match) - return match; - } - const subWordTextChunks = segment.subWordTextChunks; - let bestMatch; - for (const subWordTextChunk of subWordTextChunks) { - bestMatch = betterMatch(bestMatch, matchTextChunk(candidate, subWordTextChunk, stringToWordSpans)); + const importSpecifiers = []; + exportNameToImportName.forEach((name, propertyName) => { + importSpecifiers.push(factory.createImportSpecifier( + /*isTypeOnly*/ + false, + name === propertyName ? void 0 : factory.createIdentifier(propertyName), + factory.createIdentifier(name) + )); + }); + const importDecl = toConvert.parent.parent; + if (usedAsNamespaceOrDefault && !allowSyntheticDefaultImports) { + changes.insertNodeAfter(sourceFile, importDecl, updateImport( + importDecl, + /*defaultImportName*/ + void 0, + importSpecifiers + )); + } else { + changes.replaceNode(sourceFile, importDecl, updateImport(importDecl, usedAsNamespaceOrDefault ? factory.createIdentifier(toConvert.name.text) : void 0, importSpecifiers)); } - return bestMatch; - } - function betterMatch(a, b) { - return min([a, b], compareMatches); - } - function compareMatches(a, b) { - return a === void 0 ? 1 /* GreaterThan */ : b === void 0 ? -1 /* LessThan */ : compareValues(a.kind, b.kind) || compareBooleans(!a.isCaseSensitive, !b.isCaseSensitive); } - function partStartsWith(candidate, candidateSpan, pattern, ignoreCase, patternSpan = { start: 0, length: pattern.length }) { - return patternSpan.length <= candidateSpan.length && everyInRange(0, patternSpan.length, (i) => equalChars(pattern.charCodeAt(patternSpan.start + i), candidate.charCodeAt(candidateSpan.start + i), ignoreCase)); + function getRightOfPropertyAccessOrQualifiedName(propertyAccessOrQualifiedName) { + return isPropertyAccessExpression(propertyAccessOrQualifiedName) ? propertyAccessOrQualifiedName.name : propertyAccessOrQualifiedName.right; } - function equalChars(ch1, ch2, ignoreCase) { - return ignoreCase ? toLowerCase2(ch1) === toLowerCase2(ch2) : ch1 === ch2; + function getLeftOfPropertyAccessOrQualifiedName(propertyAccessOrQualifiedName) { + return isPropertyAccessExpression(propertyAccessOrQualifiedName) ? propertyAccessOrQualifiedName.expression : propertyAccessOrQualifiedName.left; } - function tryCamelCaseMatch(candidate, candidateParts, chunk, ignoreCase) { - const chunkCharacterSpans = chunk.characterSpans; - let currentCandidate = 0; - let currentChunkSpan = 0; - let firstMatch; - let contiguous; - while (true) { - if (currentChunkSpan === chunkCharacterSpans.length) { - return true; - } else if (currentCandidate === candidateParts.length) { - return false; + function doChangeNamedToNamespaceOrDefault(sourceFile, program, changes, toConvert, shouldUseDefault = getShouldUseDefault(program, toConvert.parent)) { + const checker = program.getTypeChecker(); + const importDecl = toConvert.parent.parent; + const { moduleSpecifier } = importDecl; + const toConvertSymbols = /* @__PURE__ */ new Set(); + toConvert.elements.forEach((namedImport) => { + const symbol = checker.getSymbolAtLocation(namedImport.name); + if (symbol) { + toConvertSymbols.add(symbol); } - let candidatePart = candidateParts[currentCandidate]; - let gotOneMatchThisCandidate = false; - for (; currentChunkSpan < chunkCharacterSpans.length; currentChunkSpan++) { - const chunkCharacterSpan = chunkCharacterSpans[currentChunkSpan]; - if (gotOneMatchThisCandidate) { - if (!isUpperCaseLetter(chunk.text.charCodeAt(chunkCharacterSpans[currentChunkSpan - 1].start)) || !isUpperCaseLetter(chunk.text.charCodeAt(chunkCharacterSpans[currentChunkSpan].start))) { - break; + }); + const preferredName = moduleSpecifier && isStringLiteral(moduleSpecifier) ? ts_codefix_exports.moduleSpecifierToValidIdentifier(moduleSpecifier.text, 99 /* ESNext */) : "module"; + function hasNamespaceNameConflict(namedImport) { + return !!ts_FindAllReferences_exports.Core.eachSymbolReferenceInFile(namedImport.name, checker, sourceFile, (id) => { + const symbol = checker.resolveName( + preferredName, + id, + 67108863 /* All */, + /*excludeGlobals*/ + true + ); + if (symbol) { + if (toConvertSymbols.has(symbol)) { + return isExportSpecifier(id.parent); } + return true; } - if (!partStartsWith(candidate, candidatePart, chunk.text, ignoreCase, chunkCharacterSpan)) { - break; + return false; + }); + } + const namespaceNameConflicts = toConvert.elements.some(hasNamespaceNameConflict); + const namespaceImportName = namespaceNameConflicts ? getUniqueName(preferredName, sourceFile) : preferredName; + const neededNamedImports = /* @__PURE__ */ new Set(); + for (const element of toConvert.elements) { + const propertyName = (element.propertyName || element.name).text; + ts_FindAllReferences_exports.Core.eachSymbolReferenceInFile(element.name, checker, sourceFile, (id) => { + const access = factory.createPropertyAccessExpression(factory.createIdentifier(namespaceImportName), propertyName); + if (isShorthandPropertyAssignment(id.parent)) { + changes.replaceNode(sourceFile, id.parent, factory.createPropertyAssignment(id.text, access)); + } else if (isExportSpecifier(id.parent)) { + neededNamedImports.add(element); + } else { + changes.replaceNode(sourceFile, id, access); } - gotOneMatchThisCandidate = true; - firstMatch = firstMatch === void 0 ? currentCandidate : firstMatch; - contiguous = contiguous === void 0 ? true : contiguous; - candidatePart = createTextSpan(candidatePart.start + chunkCharacterSpan.length, candidatePart.length - chunkCharacterSpan.length); - } - if (!gotOneMatchThisCandidate && contiguous !== void 0) { - contiguous = false; - } - currentCandidate++; + }); } - } - function createSegment(text) { - return { - totalTextChunk: createTextChunk(text), - subWordTextChunks: breakPatternIntoTextChunks(text) - }; - } - function isUpperCaseLetter(ch) { - if (ch >= 65 /* A */ && ch <= 90 /* Z */) { - return true; + changes.replaceNode( + sourceFile, + toConvert, + shouldUseDefault ? factory.createIdentifier(namespaceImportName) : factory.createNamespaceImport(factory.createIdentifier(namespaceImportName)) + ); + if (neededNamedImports.size) { + const newNamedImports = arrayFrom(neededNamedImports.values(), (element) => factory.createImportSpecifier(element.isTypeOnly, element.propertyName && factory.createIdentifier(element.propertyName.text), factory.createIdentifier(element.name.text))); + changes.insertNodeAfter(sourceFile, toConvert.parent.parent, updateImport( + importDecl, + /*defaultImportName*/ + void 0, + newNamedImports + )); } - if (ch < 127 /* maxAsciiCharacter */ || !isUnicodeIdentifierStart(ch, 99 /* Latest */)) { + } + function isExportEqualsModule(moduleSpecifier, checker) { + const externalModule = checker.resolveExternalModuleName(moduleSpecifier); + if (!externalModule) return false; - } - const str = String.fromCharCode(ch); - return str === str.toUpperCase(); + const exportEquals = checker.resolveExternalModuleSymbol(externalModule); + return externalModule !== exportEquals; } - function isLowerCaseLetter(ch) { - if (ch >= 97 /* a */ && ch <= 122 /* z */) { - return true; + function updateImport(old, defaultImportName, elements) { + return factory.createImportDeclaration( + /*modifiers*/ + void 0, + factory.createImportClause( + /*isTypeOnly*/ + false, + defaultImportName, + elements && elements.length ? factory.createNamedImports(elements) : void 0 + ), + old.moduleSpecifier, + /*attributes*/ + void 0 + ); + } + var refactorName2, actions; + var init_convertImport = __esm({ + "src/services/refactors/convertImport.ts"() { + "use strict"; + init_ts4(); + init_ts_refactor(); + refactorName2 = "Convert import"; + actions = { + [0 /* Named */]: { + name: "Convert namespace import to named imports", + description: getLocaleSpecificMessage(Diagnostics.Convert_namespace_import_to_named_imports), + kind: "refactor.rewrite.import.named" + }, + [2 /* Namespace */]: { + name: "Convert named imports to namespace import", + description: getLocaleSpecificMessage(Diagnostics.Convert_named_imports_to_namespace_import), + kind: "refactor.rewrite.import.namespace" + }, + [1 /* Default */]: { + name: "Convert named imports to default import", + description: getLocaleSpecificMessage(Diagnostics.Convert_named_imports_to_default_import), + kind: "refactor.rewrite.import.default" + } + }; + registerRefactor(refactorName2, { + kinds: getOwnValues(actions).map((a) => a.kind), + getAvailableActions: function getRefactorActionsToConvertBetweenNamedAndNamespacedImports(context) { + const info = getImportConversionInfo(context, context.triggerReason === "invoked"); + if (!info) + return emptyArray; + if (!isRefactorErrorInfo(info)) { + const action = actions[info.convertTo]; + return [{ name: refactorName2, description: action.description, actions: [action] }]; + } + if (context.preferences.provideRefactorNotApplicableReason) { + return getOwnValues(actions).map((action) => ({ + name: refactorName2, + description: action.description, + actions: [{ ...action, notApplicableReason: info.error }] + })); + } + return emptyArray; + }, + getEditsForAction: function getRefactorEditsToConvertBetweenNamedAndNamespacedImports(context, actionName2) { + Debug.assert(some(getOwnValues(actions), (action) => action.name === actionName2), "Unexpected action name"); + const info = getImportConversionInfo(context); + Debug.assert(info && !isRefactorErrorInfo(info), "Expected applicable refactor info"); + const edits = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange2(context.file, context.program, t, info)); + return { edits, renameFilename: void 0, renameLocation: void 0 }; + } + }); } - if (ch < 127 /* maxAsciiCharacter */ || !isUnicodeIdentifierStart(ch, 99 /* Latest */)) { - return false; + }); + + // src/services/refactors/extractType.ts + function getRangeToExtract(context, considerEmptySpans = true) { + const { file, startPosition } = context; + const isJS = isSourceFileJS(file); + const current = getTokenAtPosition(file, startPosition); + const range = createTextRangeFromSpan(getRefactorContextSpan(context)); + const cursorRequest = range.pos === range.end && considerEmptySpans; + const overlappingRange = nodeOverlapsWithStartEnd(current, file, range.pos, range.end); + const firstType = findAncestor(current, (node) => node.parent && isTypeNode(node) && !rangeContainsSkipTrivia(range, node.parent, file) && (cursorRequest || overlappingRange)); + if (!firstType || !isTypeNode(firstType)) + return { error: getLocaleSpecificMessage(Diagnostics.Selection_is_not_a_valid_type_node) }; + const checker = context.program.getTypeChecker(); + const enclosingNode = getEnclosingNode(firstType, isJS); + if (enclosingNode === void 0) + return { error: getLocaleSpecificMessage(Diagnostics.No_type_could_be_extracted_from_this_type_node) }; + const expandedFirstType = getExpandedSelectionNode(firstType, enclosingNode); + if (!isTypeNode(expandedFirstType)) + return { error: getLocaleSpecificMessage(Diagnostics.Selection_is_not_a_valid_type_node) }; + const typeList = []; + if ((isUnionTypeNode(expandedFirstType.parent) || isIntersectionTypeNode(expandedFirstType.parent)) && range.end > firstType.end) { + addRange( + typeList, + expandedFirstType.parent.types.filter((type) => { + return nodeOverlapsWithStartEnd(type, file, range.pos, range.end); + }) + ); } - const str = String.fromCharCode(ch); - return str === str.toLowerCase(); + const selection = typeList.length > 1 ? typeList : expandedFirstType; + const typeParameters = collectTypeParameters(checker, selection, enclosingNode, file); + if (!typeParameters) + return { error: getLocaleSpecificMessage(Diagnostics.No_type_could_be_extracted_from_this_type_node) }; + const typeElements = flattenTypeLiteralNodeReference(checker, selection); + return { isJS, selection, enclosingNode, typeParameters, typeElements }; } - function indexOfIgnoringCase(str, value) { - const n = str.length - value.length; - for (let start = 0; start <= n; start++) { - if (every2(value, (valueChar, i) => toLowerCase2(str.charCodeAt(i + start)) === valueChar)) { - return start; + function flattenTypeLiteralNodeReference(checker, selection) { + if (!selection) + return void 0; + if (isArray(selection)) { + const result = []; + for (const type of selection) { + const flattenedTypeMembers = flattenTypeLiteralNodeReference(checker, type); + if (!flattenedTypeMembers) + return void 0; + addRange(result, flattenedTypeMembers); } + return result; } - return -1; - } - function toLowerCase2(ch) { - if (ch >= 65 /* A */ && ch <= 90 /* Z */) { - return 97 /* a */ + (ch - 65 /* A */); - } - if (ch < 127 /* maxAsciiCharacter */) { - return ch; + if (isIntersectionTypeNode(selection)) { + const result = []; + const seen = /* @__PURE__ */ new Map(); + for (const type of selection.types) { + const flattenedTypeMembers = flattenTypeLiteralNodeReference(checker, type); + if (!flattenedTypeMembers || !flattenedTypeMembers.every((type2) => type2.name && addToSeen(seen, getNameFromPropertyName(type2.name)))) { + return void 0; + } + addRange(result, flattenedTypeMembers); + } + return result; + } else if (isParenthesizedTypeNode(selection)) { + return flattenTypeLiteralNodeReference(checker, selection.type); + } else if (isTypeLiteralNode(selection)) { + return selection.members; } - return String.fromCharCode(ch).toLowerCase().charCodeAt(0); - } - function isDigit2(ch) { - return ch >= 48 /* _0 */ && ch <= 57 /* _9 */; + return void 0; } - function isWordChar(ch) { - return isUpperCaseLetter(ch) || isLowerCaseLetter(ch) || isDigit2(ch) || ch === 95 /* _ */ || ch === 36 /* $ */; + function rangeContainsSkipTrivia(r1, node, file) { + return rangeContainsStartEnd(r1, skipTrivia(file.text, node.pos), node.end); } - function breakPatternIntoTextChunks(pattern) { + function collectTypeParameters(checker, selection, enclosingNode, file) { const result = []; - let wordStart = 0; - let wordLength = 0; - for (let i = 0; i < pattern.length; i++) { - const ch = pattern.charCodeAt(i); - if (isWordChar(ch)) { - if (wordLength === 0) { - wordStart = i; + const selectionArray = toArray(selection); + const selectionRange = { pos: selectionArray[0].pos, end: selectionArray[selectionArray.length - 1].end }; + for (const t of selectionArray) { + if (visitor(t)) + return void 0; + } + return result; + function visitor(node) { + if (isTypeReferenceNode(node)) { + if (isIdentifier(node.typeName)) { + const typeName = node.typeName; + const symbol = checker.resolveName( + typeName.text, + typeName, + 262144 /* TypeParameter */, + /*excludeGlobals*/ + true + ); + for (const decl of (symbol == null ? void 0 : symbol.declarations) || emptyArray) { + if (isTypeParameterDeclaration(decl) && decl.getSourceFile() === file) { + if (decl.name.escapedText === typeName.escapedText && rangeContainsSkipTrivia(decl, selectionRange, file)) { + return true; + } + if (rangeContainsSkipTrivia(enclosingNode, decl, file) && !rangeContainsSkipTrivia(selectionRange, decl, file)) { + pushIfUnique(result, decl); + break; + } + } + } } - wordLength++; - } else { - if (wordLength > 0) { - result.push(createTextChunk(pattern.substr(wordStart, wordLength))); - wordLength = 0; + } else if (isInferTypeNode(node)) { + const conditionalTypeNode = findAncestor(node, (n) => isConditionalTypeNode(n) && rangeContainsSkipTrivia(n.extendsType, node, file)); + if (!conditionalTypeNode || !rangeContainsSkipTrivia(selectionRange, conditionalTypeNode, file)) { + return true; + } + } else if (isTypePredicateNode(node) || isThisTypeNode(node)) { + const functionLikeNode = findAncestor(node.parent, isFunctionLike); + if (functionLikeNode && functionLikeNode.type && rangeContainsSkipTrivia(functionLikeNode.type, node, file) && !rangeContainsSkipTrivia(selectionRange, functionLikeNode, file)) { + return true; + } + } else if (isTypeQueryNode(node)) { + if (isIdentifier(node.exprName)) { + const symbol = checker.resolveName( + node.exprName.text, + node.exprName, + 111551 /* Value */, + /*excludeGlobals*/ + false + ); + if ((symbol == null ? void 0 : symbol.valueDeclaration) && rangeContainsSkipTrivia(enclosingNode, symbol.valueDeclaration, file) && !rangeContainsSkipTrivia(selectionRange, symbol.valueDeclaration, file)) { + return true; + } + } else { + if (isThisIdentifier(node.exprName.left) && !rangeContainsSkipTrivia(selectionRange, node.parent, file)) { + return true; + } } } + if (file && isTupleTypeNode(node) && getLineAndCharacterOfPosition(file, node.pos).line === getLineAndCharacterOfPosition(file, node.end).line) { + setEmitFlags(node, 1 /* SingleLine */); + } + return forEachChild(node, visitor); } - if (wordLength > 0) { - result.push(createTextChunk(pattern.substr(wordStart, wordLength))); - } - return result; } - function createTextChunk(text) { - const textLowerCase = text.toLowerCase(); - return { - text, - textLowerCase, - isLowerCase: text === textLowerCase, - characterSpans: breakIntoCharacterSpans(text) - }; - } - function breakIntoCharacterSpans(identifier) { - return breakIntoSpans( - identifier, - /*word*/ - false + function doTypeAliasChange(changes, file, name, info) { + const { enclosingNode, typeParameters } = info; + const { firstTypeNode, lastTypeNode, newTypeNode } = getNodesToEdit(info); + const newTypeDeclaration = factory.createTypeAliasDeclaration( + /*modifiers*/ + void 0, + name, + typeParameters.map((id) => factory.updateTypeParameterDeclaration( + id, + id.modifiers, + id.name, + id.constraint, + /*defaultType*/ + void 0 + )), + newTypeNode + ); + changes.insertNodeBefore( + file, + enclosingNode, + ignoreSourceNewlines(newTypeDeclaration), + /*blankLineBetween*/ + true ); + changes.replaceNodeRange(file, firstTypeNode, lastTypeNode, factory.createTypeReferenceNode(name, typeParameters.map((id) => factory.createTypeReferenceNode( + id.name, + /*typeArguments*/ + void 0 + ))), { leadingTriviaOption: ts_textChanges_exports.LeadingTriviaOption.Exclude, trailingTriviaOption: ts_textChanges_exports.TrailingTriviaOption.ExcludeWhitespace }); } - function breakIntoWordSpans(identifier) { - return breakIntoSpans( - identifier, - /*word*/ + function doInterfaceChange(changes, file, name, info) { + var _a; + const { enclosingNode, typeParameters, typeElements } = info; + const newTypeNode = factory.createInterfaceDeclaration( + /*modifiers*/ + void 0, + name, + typeParameters, + /*heritageClauses*/ + void 0, + typeElements + ); + setTextRange(newTypeNode, (_a = typeElements[0]) == null ? void 0 : _a.parent); + changes.insertNodeBefore( + file, + enclosingNode, + ignoreSourceNewlines(newTypeNode), + /*blankLineBetween*/ true ); + const { firstTypeNode, lastTypeNode } = getNodesToEdit(info); + changes.replaceNodeRange(file, firstTypeNode, lastTypeNode, factory.createTypeReferenceNode(name, typeParameters.map((id) => factory.createTypeReferenceNode( + id.name, + /*typeArguments*/ + void 0 + ))), { leadingTriviaOption: ts_textChanges_exports.LeadingTriviaOption.Exclude, trailingTriviaOption: ts_textChanges_exports.TrailingTriviaOption.ExcludeWhitespace }); } - function breakIntoSpans(identifier, word) { - const result = []; - let wordStart = 0; - for (let i = 1; i < identifier.length; i++) { - const lastIsDigit = isDigit2(identifier.charCodeAt(i - 1)); - const currentIsDigit = isDigit2(identifier.charCodeAt(i)); - const hasTransitionFromLowerToUpper = transitionFromLowerToUpper(identifier, word, i); - const hasTransitionFromUpperToLower = word && transitionFromUpperToLower(identifier, i, wordStart); - if (charIsPunctuation(identifier.charCodeAt(i - 1)) || charIsPunctuation(identifier.charCodeAt(i)) || lastIsDigit !== currentIsDigit || hasTransitionFromLowerToUpper || hasTransitionFromUpperToLower) { - if (!isAllPunctuation(identifier, wordStart, i)) { - result.push(createTextSpan(wordStart, i - wordStart)); - } - wordStart = i; - } - } - if (!isAllPunctuation(identifier, wordStart, identifier.length)) { - result.push(createTextSpan(wordStart, identifier.length - wordStart)); + function doTypedefChange(changes, context, file, name, info) { + var _a; + toArray(info.selection).forEach((typeNode) => { + setEmitFlags(typeNode, 3072 /* NoComments */ | 4096 /* NoNestedComments */); + }); + const { enclosingNode, typeParameters } = info; + const { firstTypeNode, lastTypeNode, newTypeNode } = getNodesToEdit(info); + const node = factory.createJSDocTypedefTag( + factory.createIdentifier("typedef"), + factory.createJSDocTypeExpression(newTypeNode), + factory.createIdentifier(name) + ); + const templates = []; + forEach(typeParameters, (typeParameter) => { + const constraint = getEffectiveConstraintOfTypeParameter(typeParameter); + const parameter = factory.createTypeParameterDeclaration( + /*modifiers*/ + void 0, + typeParameter.name + ); + const template = factory.createJSDocTemplateTag( + factory.createIdentifier("template"), + constraint && cast(constraint, isJSDocTypeExpression), + [parameter] + ); + templates.push(template); + }); + const jsDoc = factory.createJSDocComment( + /*comment*/ + void 0, + factory.createNodeArray(concatenate(templates, [node])) + ); + if (isJSDoc(enclosingNode)) { + const pos = enclosingNode.getStart(file); + const newLineCharacter = getNewLineOrDefaultFromHost(context.host, (_a = context.formatContext) == null ? void 0 : _a.options); + changes.insertNodeAt(file, enclosingNode.getStart(file), jsDoc, { + suffix: newLineCharacter + newLineCharacter + file.text.slice(getPrecedingNonSpaceCharacterPosition(file.text, pos - 1), pos) + }); + } else { + changes.insertNodeBefore( + file, + enclosingNode, + jsDoc, + /*blankLineBetween*/ + true + ); } - return result; + changes.replaceNodeRange(file, firstTypeNode, lastTypeNode, factory.createTypeReferenceNode(name, typeParameters.map((id) => factory.createTypeReferenceNode( + id.name, + /*typeArguments*/ + void 0 + )))); } - function charIsPunctuation(ch) { - switch (ch) { - case 33 /* exclamation */: - case 34 /* doubleQuote */: - case 35 /* hash */: - case 37 /* percent */: - case 38 /* ampersand */: - case 39 /* singleQuote */: - case 40 /* openParen */: - case 41 /* closeParen */: - case 42 /* asterisk */: - case 44 /* comma */: - case 45 /* minus */: - case 46 /* dot */: - case 47 /* slash */: - case 58 /* colon */: - case 59 /* semicolon */: - case 63 /* question */: - case 64 /* at */: - case 91 /* openBracket */: - case 92 /* backslash */: - case 93 /* closeBracket */: - case 95 /* _ */: - case 123 /* openBrace */: - case 125 /* closeBrace */: - return true; + function getNodesToEdit(info) { + if (isArray(info.selection)) { + return { + firstTypeNode: info.selection[0], + lastTypeNode: info.selection[info.selection.length - 1], + newTypeNode: isUnionTypeNode(info.selection[0].parent) ? factory.createUnionTypeNode(info.selection) : factory.createIntersectionTypeNode(info.selection) + }; } - return false; - } - function isAllPunctuation(identifier, start, end) { - return every2(identifier, (ch) => charIsPunctuation(ch) && ch !== 95 /* _ */, start, end); - } - function transitionFromUpperToLower(identifier, index, wordStart) { - return index !== wordStart && index + 1 < identifier.length && isUpperCaseLetter(identifier.charCodeAt(index)) && isLowerCaseLetter(identifier.charCodeAt(index + 1)) && every2(identifier, isUpperCaseLetter, wordStart, index); + return { + firstTypeNode: info.selection, + lastTypeNode: info.selection, + newTypeNode: info.selection + }; } - function transitionFromLowerToUpper(identifier, word, index) { - const lastIsUpper = isUpperCaseLetter(identifier.charCodeAt(index - 1)); - const currentIsUpper = isUpperCaseLetter(identifier.charCodeAt(index)); - return currentIsUpper && (!word || !lastIsUpper); + function getEnclosingNode(node, isJS) { + return findAncestor(node, isStatement) || (isJS ? findAncestor(node, isJSDoc) : void 0); } - function everyInRange(start, end, pred) { - for (let i = start; i < end; i++) { - if (!pred(i)) { - return false; + function getExpandedSelectionNode(firstType, enclosingNode) { + return findAncestor(firstType, (node) => { + if (node === enclosingNode) + return "quit"; + if (isUnionTypeNode(node.parent) || isIntersectionTypeNode(node.parent)) { + return true; } - } - return true; - } - function every2(s, pred, start = 0, end = s.length) { - return everyInRange(start, end, (i) => pred(s.charCodeAt(i), i)); + return false; + }) ?? firstType; } - var PatternMatchKind; - var init_patternMatcher = __esm({ - "src/services/patternMatcher.ts"() { + var refactorName3, extractToTypeAliasAction, extractToInterfaceAction, extractToTypeDefAction; + var init_extractType = __esm({ + "src/services/refactors/extractType.ts"() { "use strict"; init_ts4(); - PatternMatchKind = /* @__PURE__ */ ((PatternMatchKind2) => { - PatternMatchKind2[PatternMatchKind2["exact"] = 0] = "exact"; - PatternMatchKind2[PatternMatchKind2["prefix"] = 1] = "prefix"; - PatternMatchKind2[PatternMatchKind2["substring"] = 2] = "substring"; - PatternMatchKind2[PatternMatchKind2["camelCase"] = 3] = "camelCase"; - return PatternMatchKind2; - })(PatternMatchKind || {}); + init_ts_refactor(); + refactorName3 = "Extract type"; + extractToTypeAliasAction = { + name: "Extract to type alias", + description: getLocaleSpecificMessage(Diagnostics.Extract_to_type_alias), + kind: "refactor.extract.type" + }; + extractToInterfaceAction = { + name: "Extract to interface", + description: getLocaleSpecificMessage(Diagnostics.Extract_to_interface), + kind: "refactor.extract.interface" + }; + extractToTypeDefAction = { + name: "Extract to typedef", + description: getLocaleSpecificMessage(Diagnostics.Extract_to_typedef), + kind: "refactor.extract.typedef" + }; + registerRefactor(refactorName3, { + kinds: [ + extractToTypeAliasAction.kind, + extractToInterfaceAction.kind, + extractToTypeDefAction.kind + ], + getAvailableActions: function getRefactorActionsToExtractType(context) { + const info = getRangeToExtract(context, context.triggerReason === "invoked"); + if (!info) + return emptyArray; + if (!isRefactorErrorInfo(info)) { + return [{ + name: refactorName3, + description: getLocaleSpecificMessage(Diagnostics.Extract_type), + actions: info.isJS ? [extractToTypeDefAction] : append([extractToTypeAliasAction], info.typeElements && extractToInterfaceAction) + }]; + } + if (context.preferences.provideRefactorNotApplicableReason) { + return [{ + name: refactorName3, + description: getLocaleSpecificMessage(Diagnostics.Extract_type), + actions: [ + { ...extractToTypeDefAction, notApplicableReason: info.error }, + { ...extractToTypeAliasAction, notApplicableReason: info.error }, + { ...extractToInterfaceAction, notApplicableReason: info.error } + ] + }]; + } + return emptyArray; + }, + getEditsForAction: function getRefactorEditsToExtractType(context, actionName2) { + const { file } = context; + const info = getRangeToExtract(context); + Debug.assert(info && !isRefactorErrorInfo(info), "Expected to find a range to extract"); + const name = getUniqueName("NewType", file); + const edits = ts_textChanges_exports.ChangeTracker.with(context, (changes) => { + switch (actionName2) { + case extractToTypeAliasAction.name: + Debug.assert(!info.isJS, "Invalid actionName/JS combo"); + return doTypeAliasChange(changes, file, name, info); + case extractToTypeDefAction.name: + Debug.assert(info.isJS, "Invalid actionName/JS combo"); + return doTypedefChange(changes, context, file, name, info); + case extractToInterfaceAction.name: + Debug.assert(!info.isJS && !!info.typeElements, "Invalid actionName/JS combo"); + return doInterfaceChange(changes, file, name, info); + default: + Debug.fail("Unexpected action name"); + } + }); + const renameFilename = file.fileName; + const renameLocation = getRenameLocation( + edits, + renameFilename, + name, + /*preferLastLocation*/ + false + ); + return { edits, renameFilename, renameLocation }; + } + }); } }); - // src/services/preProcess.ts - function preProcessFile(sourceText, readImportFiles = true, detectJavaScriptImports = false) { - const pragmaContext = { - languageVersion: 1 /* ES5 */, - // controls whether the token scanner considers unicode identifiers or not - shouldn't matter, since we're only using it for trivia - pragmas: void 0, - checkJsDirective: void 0, - referencedFiles: [], - typeReferenceDirectives: [], - libReferenceDirectives: [], - amdDependencies: [], - hasNoDefaultLib: void 0, - moduleName: void 0 - }; - const importedFiles = []; - let ambientExternalModules; - let lastToken; - let currentToken; - let braceNesting = 0; - let externalModule = false; - function nextToken() { - lastToken = currentToken; - currentToken = scanner.scan(); - if (currentToken === 19 /* OpenBraceToken */) { - braceNesting++; - } else if (currentToken === 20 /* CloseBraceToken */) { - braceNesting--; - } - return currentToken; + // src/services/refactors/helpers.ts + function isRefactorErrorInfo(info) { + return info.error !== void 0; + } + function refactorKindBeginsWith(known, requested) { + if (!requested) + return true; + return known.substr(0, requested.length) === requested; + } + var init_helpers = __esm({ + "src/services/refactors/helpers.ts"() { + "use strict"; } - function getFileReference() { - const fileName = scanner.getTokenValue(); - const pos = scanner.getTokenStart(); - return { fileName, pos, end: pos + fileName.length }; + }); + + // src/services/refactors/inlineVariable.ts + function getInliningInfo(file, startPosition, tryWithReferenceToken, program) { + var _a, _b; + const checker = program.getTypeChecker(); + const token = getTouchingPropertyName(file, startPosition); + const parent2 = token.parent; + if (!isIdentifier(token)) { + return void 0; } - function recordAmbientExternalModule() { - if (!ambientExternalModules) { - ambientExternalModules = []; + if (isInitializedVariable(parent2) && isVariableDeclarationInVariableStatement(parent2) && isIdentifier(parent2.name)) { + if (((_a = checker.getMergedSymbol(parent2.symbol).declarations) == null ? void 0 : _a.length) !== 1) { + return { error: getLocaleSpecificMessage(Diagnostics.Variables_with_multiple_declarations_cannot_be_inlined) }; } - ambientExternalModules.push({ ref: getFileReference(), depth: braceNesting }); - } - function recordModuleName() { - importedFiles.push(getFileReference()); - markAsExternalModuleIfTopLevel(); + if (isDeclarationExported(parent2)) { + return void 0; + } + const references = getReferenceNodes(parent2, checker, file); + return references && { references, declaration: parent2, replacement: parent2.initializer }; } - function markAsExternalModuleIfTopLevel() { - if (braceNesting === 0) { - externalModule = true; + if (tryWithReferenceToken) { + let definition = checker.resolveName( + token.text, + token, + 111551 /* Value */, + /*excludeGlobals*/ + false + ); + definition = definition && checker.getMergedSymbol(definition); + if (((_b = definition == null ? void 0 : definition.declarations) == null ? void 0 : _b.length) !== 1) { + return { error: getLocaleSpecificMessage(Diagnostics.Variables_with_multiple_declarations_cannot_be_inlined) }; + } + const declaration = definition.declarations[0]; + if (!isInitializedVariable(declaration) || !isVariableDeclarationInVariableStatement(declaration) || !isIdentifier(declaration.name)) { + return void 0; + } + if (isDeclarationExported(declaration)) { + return void 0; } + const references = getReferenceNodes(declaration, checker, file); + return references && { references, declaration, replacement: declaration.initializer }; } - function tryConsumeDeclare() { - let token = scanner.getToken(); - if (token === 138 /* DeclareKeyword */) { - token = nextToken(); - if (token === 144 /* ModuleKeyword */) { - token = nextToken(); - if (token === 11 /* StringLiteral */) { - recordAmbientExternalModule(); - } - } + return { error: getLocaleSpecificMessage(Diagnostics.Could_not_find_variable_to_inline) }; + } + function isDeclarationExported(declaration) { + const variableStatement = cast(declaration.parent.parent, isVariableStatement); + return some(variableStatement.modifiers, isExportModifier); + } + function getReferenceNodes(declaration, checker, file) { + const references = []; + const cannotInline = ts_FindAllReferences_exports.Core.eachSymbolReferenceInFile(declaration.name, checker, file, (ref) => { + if (ts_FindAllReferences_exports.isWriteAccessForReference(ref)) { return true; } - return false; - } - function tryConsumeImport() { - if (lastToken === 25 /* DotToken */) { - return false; + if (isExportSpecifier(ref.parent) || isExportAssignment(ref.parent)) { + return true; } - let token = scanner.getToken(); - if (token === 102 /* ImportKeyword */) { - token = nextToken(); - if (token === 21 /* OpenParenToken */) { - token = nextToken(); - if (token === 11 /* StringLiteral */ || token === 15 /* NoSubstitutionTemplateLiteral */) { - recordModuleName(); - return true; - } - } else if (token === 11 /* StringLiteral */) { - recordModuleName(); - return true; - } else { - if (token === 156 /* TypeKeyword */) { - const skipTypeKeyword = scanner.lookAhead(() => { - const token2 = scanner.scan(); - return token2 !== 160 /* FromKeyword */ && (token2 === 42 /* AsteriskToken */ || token2 === 19 /* OpenBraceToken */ || token2 === 80 /* Identifier */ || isKeyword(token2)); - }); - if (skipTypeKeyword) { - token = nextToken(); - } - } - if (token === 80 /* Identifier */ || isKeyword(token)) { - token = nextToken(); - if (token === 160 /* FromKeyword */) { - token = nextToken(); - if (token === 11 /* StringLiteral */) { - recordModuleName(); - return true; - } - } else if (token === 64 /* EqualsToken */) { - if (tryConsumeRequireCall( - /*skipCurrentToken*/ - true - )) { - return true; - } - } else if (token === 28 /* CommaToken */) { - token = nextToken(); - } else { - return true; - } - } - if (token === 19 /* OpenBraceToken */) { - token = nextToken(); - while (token !== 20 /* CloseBraceToken */ && token !== 1 /* EndOfFileToken */) { - token = nextToken(); - } - if (token === 20 /* CloseBraceToken */) { - token = nextToken(); - if (token === 160 /* FromKeyword */) { - token = nextToken(); - if (token === 11 /* StringLiteral */) { - recordModuleName(); - } - } - } - } else if (token === 42 /* AsteriskToken */) { - token = nextToken(); - if (token === 130 /* AsKeyword */) { - token = nextToken(); - if (token === 80 /* Identifier */ || isKeyword(token)) { - token = nextToken(); - if (token === 160 /* FromKeyword */) { - token = nextToken(); - if (token === 11 /* StringLiteral */) { - recordModuleName(); - } - } - } - } - } - } + if (isTypeQueryNode(ref.parent)) { return true; } - return false; + if (textRangeContainsPositionInclusive(declaration, ref.pos)) { + return true; + } + references.push(ref); + }); + return references.length === 0 || cannotInline ? void 0 : references; + } + function getReplacementExpression(reference, replacement) { + replacement = getSynthesizedDeepClone(replacement); + const { parent: parent2 } = reference; + if (isExpression(parent2) && (getExpressionPrecedence(replacement) < getExpressionPrecedence(parent2) || needsParentheses(parent2))) { + return factory.createParenthesizedExpression(replacement); } - function tryConsumeExport() { - let token = scanner.getToken(); - if (token === 95 /* ExportKeyword */) { - markAsExternalModuleIfTopLevel(); - token = nextToken(); - if (token === 156 /* TypeKeyword */) { - const skipTypeKeyword = scanner.lookAhead(() => { - const token2 = scanner.scan(); - return token2 === 42 /* AsteriskToken */ || token2 === 19 /* OpenBraceToken */; - }); - if (skipTypeKeyword) { - token = nextToken(); - } - } - if (token === 19 /* OpenBraceToken */) { - token = nextToken(); - while (token !== 20 /* CloseBraceToken */ && token !== 1 /* EndOfFileToken */) { - token = nextToken(); + if (isFunctionLike(replacement) && (isCallLikeExpression(parent2) || isPropertyAccessExpression(parent2))) { + return factory.createParenthesizedExpression(replacement); + } + if (isPropertyAccessExpression(parent2) && (isNumericLiteral(replacement) || isObjectLiteralExpression(replacement))) { + return factory.createParenthesizedExpression(replacement); + } + return replacement; + } + var refactorName4, refactorDescription, inlineVariableAction; + var init_inlineVariable = __esm({ + "src/services/refactors/inlineVariable.ts"() { + "use strict"; + init_ts4(); + init_ts_refactor(); + refactorName4 = "Inline variable"; + refactorDescription = getLocaleSpecificMessage(Diagnostics.Inline_variable); + inlineVariableAction = { + name: refactorName4, + description: refactorDescription, + kind: "refactor.inline.variable" + }; + registerRefactor(refactorName4, { + kinds: [inlineVariableAction.kind], + getAvailableActions(context) { + const { + file, + program, + preferences, + startPosition, + triggerReason + } = context; + const info = getInliningInfo(file, startPosition, triggerReason === "invoked", program); + if (!info) { + return emptyArray; } - if (token === 20 /* CloseBraceToken */) { - token = nextToken(); - if (token === 160 /* FromKeyword */) { - token = nextToken(); - if (token === 11 /* StringLiteral */) { - recordModuleName(); - } - } + if (!ts_refactor_exports.isRefactorErrorInfo(info)) { + return [{ + name: refactorName4, + description: refactorDescription, + actions: [inlineVariableAction] + }]; } - } else if (token === 42 /* AsteriskToken */) { - token = nextToken(); - if (token === 160 /* FromKeyword */) { - token = nextToken(); - if (token === 11 /* StringLiteral */) { - recordModuleName(); - } + if (preferences.provideRefactorNotApplicableReason) { + return [{ + name: refactorName4, + description: refactorDescription, + actions: [{ + ...inlineVariableAction, + notApplicableReason: info.error + }] + }]; } - } else if (token === 102 /* ImportKeyword */) { - token = nextToken(); - if (token === 156 /* TypeKeyword */) { - const skipTypeKeyword = scanner.lookAhead(() => { - const token2 = scanner.scan(); - return token2 === 80 /* Identifier */ || isKeyword(token2); - }); - if (skipTypeKeyword) { - token = nextToken(); - } + return emptyArray; + }, + getEditsForAction(context, actionName2) { + Debug.assert(actionName2 === refactorName4, "Unexpected refactor invoked"); + const { file, program, startPosition } = context; + const info = getInliningInfo( + file, + startPosition, + /*tryWithReferenceToken*/ + true, + program + ); + if (!info || ts_refactor_exports.isRefactorErrorInfo(info)) { + return void 0; } - if (token === 80 /* Identifier */ || isKeyword(token)) { - token = nextToken(); - if (token === 64 /* EqualsToken */) { - if (tryConsumeRequireCall( - /*skipCurrentToken*/ - true - )) { - return true; - } + const { references, declaration, replacement } = info; + const edits = ts_textChanges_exports.ChangeTracker.with(context, (tracker) => { + for (const node of references) { + tracker.replaceNode(file, node, getReplacementExpression(node, replacement)); } - } - } - return true; - } - return false; - } - function tryConsumeRequireCall(skipCurrentToken, allowTemplateLiterals = false) { - let token = skipCurrentToken ? nextToken() : scanner.getToken(); - if (token === 149 /* RequireKeyword */) { - token = nextToken(); - if (token === 21 /* OpenParenToken */) { - token = nextToken(); - if (token === 11 /* StringLiteral */ || allowTemplateLiterals && token === 15 /* NoSubstitutionTemplateLiteral */) { - recordModuleName(); - } + tracker.delete(file, declaration); + }); + return { edits }; } - return true; - } - return false; + }); } - function tryConsumeDefine() { - let token = scanner.getToken(); - if (token === 80 /* Identifier */ && scanner.getTokenValue() === "define") { - token = nextToken(); - if (token !== 21 /* OpenParenToken */) { - return true; - } - token = nextToken(); - if (token === 11 /* StringLiteral */ || token === 15 /* NoSubstitutionTemplateLiteral */) { - token = nextToken(); - if (token === 28 /* CommaToken */) { - token = nextToken(); - } else { - return true; - } - } - if (token !== 23 /* OpenBracketToken */) { - return true; - } - token = nextToken(); - while (token !== 24 /* CloseBracketToken */ && token !== 1 /* EndOfFileToken */) { - if (token === 11 /* StringLiteral */ || token === 15 /* NoSubstitutionTemplateLiteral */) { - recordModuleName(); - } - token = nextToken(); - } - return true; - } - return false; + }); + + // src/services/refactors/moveToNewFile.ts + function doChange3(oldFile, program, toMove, changes, host, preferences, context) { + const checker = program.getTypeChecker(); + const usage = getUsageInfo(oldFile, toMove.all, checker); + const newFilename = createNewFileName(oldFile, program, context, host); + changes.createNewFile(oldFile, newFilename, getNewStatementsAndRemoveFromOldFile(oldFile, usage, changes, toMove, program, host, newFilename, preferences)); + addNewFileToTsconfig(program, changes, oldFile.fileName, newFilename, hostGetCanonicalFileName(host)); + } + function getNewStatementsAndRemoveFromOldFile(oldFile, usage, changes, toMove, program, host, newFilename, preferences) { + const checker = program.getTypeChecker(); + const prologueDirectives = takeWhile(oldFile.statements, isPrologueDirective); + if (oldFile.externalModuleIndicator === void 0 && oldFile.commonJsModuleIndicator === void 0 && usage.oldImportsNeededByTargetFile.size === 0) { + deleteMovedStatements(oldFile, toMove.ranges, changes); + return [...prologueDirectives, ...toMove.all]; } - function processImports() { - scanner.setText(sourceText); - nextToken(); - while (true) { - if (scanner.getToken() === 1 /* EndOfFileToken */) { - break; - } - if (scanner.getToken() === 16 /* TemplateHead */) { - const stack = [scanner.getToken()]; - loop: - while (length(stack)) { - const token = scanner.scan(); - switch (token) { - case 1 /* EndOfFileToken */: - break loop; - case 102 /* ImportKeyword */: - tryConsumeImport(); - break; - case 16 /* TemplateHead */: - stack.push(token); - break; - case 19 /* OpenBraceToken */: - if (length(stack)) { - stack.push(token); - } - break; - case 20 /* CloseBraceToken */: - if (length(stack)) { - if (lastOrUndefined(stack) === 16 /* TemplateHead */) { - if (scanner.reScanTemplateToken( - /*isTaggedTemplate*/ - false - ) === 18 /* TemplateTail */) { - stack.pop(); - } - } else { - stack.pop(); - } - } - break; - } - } - nextToken(); - } - if (tryConsumeDeclare() || tryConsumeImport() || tryConsumeExport() || detectJavaScriptImports && (tryConsumeRequireCall( - /*skipCurrentToken*/ - false, - /*allowTemplateLiterals*/ - true - ) || tryConsumeDefine())) { - continue; - } else { - nextToken(); - } - } - scanner.setText(void 0); + const useEsModuleSyntax = !fileShouldUseJavaScriptRequire(newFilename, program, host, !!oldFile.commonJsModuleIndicator); + const quotePreference = getQuotePreference(oldFile, preferences); + const importsFromNewFile = createOldFileImportsFromTargetFile(oldFile, usage.oldFileImportsFromTargetFile, newFilename, program, host, useEsModuleSyntax, quotePreference); + if (importsFromNewFile) { + insertImports( + changes, + oldFile, + importsFromNewFile, + /*blankLineBetween*/ + true, + preferences + ); } - if (readImportFiles) { - processImports(); + deleteUnusedOldImports(oldFile, toMove.all, changes, usage.unusedImportsFromOldFile, checker); + deleteMovedStatements(oldFile, toMove.ranges, changes); + updateImportsInOtherFiles(changes, program, host, oldFile, usage.movedSymbols, newFilename, quotePreference); + const imports = getNewFileImportsAndAddExportInOldFile(oldFile, usage.oldImportsNeededByTargetFile, usage.targetFileImportsFromOldFile, changes, checker, program, host, useEsModuleSyntax, quotePreference); + const body = addExports(oldFile, toMove.all, usage.oldFileImportsFromTargetFile, useEsModuleSyntax); + if (imports.length && body.length) { + return [ + ...prologueDirectives, + ...imports, + 4 /* NewLineTrivia */, + ...body + ]; } - processCommentPragmas(pragmaContext, sourceText); - processPragmasIntoFields(pragmaContext, noop); - if (externalModule) { - if (ambientExternalModules) { - for (const decl of ambientExternalModules) { - importedFiles.push(decl.ref); - } + return [ + ...prologueDirectives, + ...imports, + ...body + ]; + } + function getNewFileImportsAndAddExportInOldFile(oldFile, importsToCopy, newFileImportsFromOldFile, changes, checker, program, host, useEsModuleSyntax, quotePreference) { + const copiedOldImports = []; + for (const oldStatement of oldFile.statements) { + forEachImportInStatement(oldStatement, (i) => { + append(copiedOldImports, filterImport(i, moduleSpecifierFromImport(i), (name) => importsToCopy.has(checker.getSymbolAtLocation(name)))); + }); + } + let oldFileDefault; + const oldFileNamedImports = []; + const markSeenTop = nodeSeenTracker(); + newFileImportsFromOldFile.forEach((symbol) => { + if (!symbol.declarations) { + return; } - return { referencedFiles: pragmaContext.referencedFiles, typeReferenceDirectives: pragmaContext.typeReferenceDirectives, libReferenceDirectives: pragmaContext.libReferenceDirectives, importedFiles, isLibFile: !!pragmaContext.hasNoDefaultLib, ambientExternalModules: void 0 }; - } else { - let ambientModuleNames; - if (ambientExternalModules) { - for (const decl of ambientExternalModules) { - if (decl.depth === 0) { - if (!ambientModuleNames) { - ambientModuleNames = []; - } - ambientModuleNames.push(decl.ref.fileName); - } else { - importedFiles.push(decl.ref); - } + for (const decl of symbol.declarations) { + if (!isTopLevelDeclaration(decl)) + continue; + const name = nameOfTopLevelDeclaration(decl); + if (!name) + continue; + const top = getTopLevelDeclarationStatement(decl); + if (markSeenTop(top)) { + addExportToChanges(oldFile, top, name, changes, useEsModuleSyntax); + } + if (hasSyntacticModifier(decl, 2048 /* Default */)) { + oldFileDefault = name; + } else { + oldFileNamedImports.push(name.text); } } - return { referencedFiles: pragmaContext.referencedFiles, typeReferenceDirectives: pragmaContext.typeReferenceDirectives, libReferenceDirectives: pragmaContext.libReferenceDirectives, importedFiles, isLibFile: !!pragmaContext.hasNoDefaultLib, ambientExternalModules: ambientModuleNames }; - } + }); + append(copiedOldImports, makeImportOrRequire(oldFile, oldFileDefault, oldFileNamedImports, getBaseFileName(oldFile.fileName), program, host, useEsModuleSyntax, quotePreference)); + return copiedOldImports; } - var init_preProcess = __esm({ - "src/services/preProcess.ts"() { + var refactorName5, description, moveToNewFileAction; + var init_moveToNewFile = __esm({ + "src/services/refactors/moveToNewFile.ts"() { "use strict"; init_ts4(); + init_ts_refactor(); + refactorName5 = "Move to a new file"; + description = getLocaleSpecificMessage(Diagnostics.Move_to_a_new_file); + moveToNewFileAction = { + name: refactorName5, + description, + kind: "refactor.move.newFile" + }; + registerRefactor(refactorName5, { + kinds: [moveToNewFileAction.kind], + getAvailableActions: function getRefactorActionsToMoveToNewFile(context) { + const statements = getStatementsToMove(context); + if (context.preferences.allowTextChangesInNewFiles && statements) { + return [{ name: refactorName5, description, actions: [moveToNewFileAction] }]; + } + if (context.preferences.provideRefactorNotApplicableReason) { + return [{ name: refactorName5, description, actions: [{ ...moveToNewFileAction, notApplicableReason: getLocaleSpecificMessage(Diagnostics.Selection_is_not_a_valid_statement_or_statements) }] }]; + } + return emptyArray; + }, + getEditsForAction: function getRefactorEditsToMoveToNewFile(context, actionName2) { + Debug.assert(actionName2 === refactorName5, "Wrong refactor invoked"); + const statements = Debug.checkDefined(getStatementsToMove(context)); + const edits = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange3(context.file, context.program, statements, t, context.host, context.preferences, context)); + return { edits, renameFilename: void 0, renameLocation: void 0 }; + } + }); } }); - // src/services/sourcemaps.ts - function getSourceMapper(host) { - const getCanonicalFileName = createGetCanonicalFileName(host.useCaseSensitiveFileNames()); - const currentDirectory = host.getCurrentDirectory(); - const sourceFileLike = /* @__PURE__ */ new Map(); - const documentPositionMappers = /* @__PURE__ */ new Map(); - return { tryGetSourcePosition, tryGetGeneratedPosition, toLineColumnOffset, clearCache }; - function toPath3(fileName) { - return toPath(fileName, currentDirectory, getCanonicalFileName); + // src/services/refactors/moveToFile.ts + function error(notApplicableReason) { + return { edits: [], renameFilename: void 0, renameLocation: void 0, notApplicableReason }; + } + function doChange4(context, oldFile, targetFile, program, toMove, changes, host, preferences) { + const checker = program.getTypeChecker(); + if (!host.fileExists(targetFile)) { + changes.createNewFile(oldFile, targetFile, getNewStatementsAndRemoveFromOldFile2(oldFile, targetFile, getUsageInfo(oldFile, toMove.all, checker), changes, toMove, program, host, preferences)); + addNewFileToTsconfig(program, changes, oldFile.fileName, targetFile, hostGetCanonicalFileName(host)); + } else { + const targetSourceFile = Debug.checkDefined(program.getSourceFile(targetFile)); + const importAdder = ts_codefix_exports.createImportAdder(targetSourceFile, context.program, context.preferences, context.host); + getNewStatementsAndRemoveFromOldFile2(oldFile, targetSourceFile, getUsageInfo(oldFile, toMove.all, checker, getExistingImports(targetSourceFile, checker)), changes, toMove, program, host, preferences, importAdder); } - function getDocumentPositionMapper2(generatedFileName, sourceFileName) { - const path = toPath3(generatedFileName); - const value = documentPositionMappers.get(path); - if (value) - return value; - let mapper; - if (host.getDocumentPositionMapper) { - mapper = host.getDocumentPositionMapper(generatedFileName, sourceFileName); - } else if (host.readFile) { - const file = getSourceFileLike(generatedFileName); - mapper = file && getDocumentPositionMapper( - { getSourceFileLike, getCanonicalFileName, log: (s) => host.log(s) }, - generatedFileName, - getLineInfo(file.text, getLineStarts(file)), - (f) => !host.fileExists || host.fileExists(f) ? host.readFile(f) : void 0 + } + function getNewStatementsAndRemoveFromOldFile2(oldFile, targetFile, usage, changes, toMove, program, host, preferences, importAdder) { + const checker = program.getTypeChecker(); + const prologueDirectives = takeWhile(oldFile.statements, isPrologueDirective); + if (oldFile.externalModuleIndicator === void 0 && oldFile.commonJsModuleIndicator === void 0 && usage.oldImportsNeededByTargetFile.size === 0 && usage.targetFileImportsFromOldFile.size === 0 && typeof targetFile === "string") { + deleteMovedStatements(oldFile, toMove.ranges, changes); + return [...prologueDirectives, ...toMove.all]; + } + const targetFileName = typeof targetFile === "string" ? targetFile : targetFile.fileName; + const useEsModuleSyntax = !fileShouldUseJavaScriptRequire(targetFileName, program, host, !!oldFile.commonJsModuleIndicator); + const quotePreference = getQuotePreference(oldFile, preferences); + const importsFromTargetFile = createOldFileImportsFromTargetFile(oldFile, usage.oldFileImportsFromTargetFile, targetFileName, program, host, useEsModuleSyntax, quotePreference); + if (importsFromTargetFile) { + insertImports( + changes, + oldFile, + importsFromTargetFile, + /*blankLineBetween*/ + true, + preferences + ); + } + deleteUnusedOldImports(oldFile, toMove.all, changes, usage.unusedImportsFromOldFile, checker); + deleteMovedStatements(oldFile, toMove.ranges, changes); + updateImportsInOtherFiles(changes, program, host, oldFile, usage.movedSymbols, targetFileName, quotePreference); + const imports = getTargetFileImportsAndAddExportInOldFile(oldFile, targetFileName, usage.oldImportsNeededByTargetFile, usage.targetFileImportsFromOldFile, changes, checker, program, host, useEsModuleSyntax, quotePreference, importAdder); + const body = addExports(oldFile, toMove.all, usage.oldFileImportsFromTargetFile, useEsModuleSyntax); + if (typeof targetFile !== "string") { + if (targetFile.statements.length > 0) { + moveStatementsToTargetFile(changes, program, body, targetFile, toMove); + } else { + changes.insertNodesAtEndOfFile( + targetFile, + body, + /*blankLineBetween*/ + false + ); + } + if (imports.length > 0) { + insertImports( + changes, + targetFile, + imports, + /*blankLineBetween*/ + true, + preferences ); } - documentPositionMappers.set(path, mapper || identitySourceMapConsumer); - return mapper || identitySourceMapConsumer; } - function tryGetSourcePosition(info) { - if (!isDeclarationFileName(info.fileName)) - return void 0; - const file = getSourceFile(info.fileName); - if (!file) - return void 0; - const newLoc = getDocumentPositionMapper2(info.fileName).getSourcePosition(info); - return !newLoc || newLoc === info ? void 0 : tryGetSourcePosition(newLoc) || newLoc; + if (importAdder) { + importAdder.writeFixes(changes, quotePreference); } - function tryGetGeneratedPosition(info) { - if (isDeclarationFileName(info.fileName)) - return void 0; - const sourceFile = getSourceFile(info.fileName); - if (!sourceFile) - return void 0; - const program = host.getProgram(); - if (program.isSourceOfProjectReferenceRedirect(sourceFile.fileName)) { - return void 0; - } - const options = program.getCompilerOptions(); - const outPath = outFile(options); - const declarationPath = outPath ? removeFileExtension(outPath) + ".d.ts" /* Dts */ : getDeclarationEmitOutputFilePathWorker(info.fileName, program.getCompilerOptions(), currentDirectory, program.getCommonSourceDirectory(), getCanonicalFileName); - if (declarationPath === void 0) - return void 0; - const newLoc = getDocumentPositionMapper2(declarationPath, info.fileName).getGeneratedPosition(info); - return newLoc === info ? void 0 : newLoc; + if (imports.length && body.length) { + return [ + ...prologueDirectives, + ...imports, + 4 /* NewLineTrivia */, + ...body + ]; } - function getSourceFile(fileName) { - const program = host.getProgram(); - if (!program) - return void 0; - const path = toPath3(fileName); - const file = program.getSourceFileByPath(path); - return file && file.resolvedPath === path ? file : void 0; + return [ + ...prologueDirectives, + ...imports, + ...body + ]; + } + function getTargetFileImportsAndAddExportInOldFile(oldFile, targetFile, importsToCopy, targetFileImportsFromOldFile, changes, checker, program, host, useEsModuleSyntax, quotePreference, importAdder) { + const copiedOldImports = []; + if (importAdder) { + importsToCopy.forEach((isValidTypeOnlyUseSite, symbol) => { + try { + importAdder.addImportFromExportedSymbol(skipAlias(symbol, checker), isValidTypeOnlyUseSite); + } catch { + for (const oldStatement of oldFile.statements) { + forEachImportInStatement(oldStatement, (i) => { + append(copiedOldImports, filterImport(i, factory.createStringLiteral(moduleSpecifierFromImport(i).text), (name) => importsToCopy.has(checker.getSymbolAtLocation(name)))); + }); + } + } + }); + } else { + const targetSourceFile = program.getSourceFile(targetFile); + for (const oldStatement of oldFile.statements) { + forEachImportInStatement(oldStatement, (i) => { + var _a; + const moduleSpecifier = moduleSpecifierFromImport(i); + const resolved = program.getResolvedModule(oldFile, moduleSpecifier.text, getModeForUsageLocation(oldFile, moduleSpecifier)); + const fileName = (_a = resolved == null ? void 0 : resolved.resolvedModule) == null ? void 0 : _a.resolvedFileName; + if (fileName && targetSourceFile) { + const newModuleSpecifier = getModuleSpecifier(program.getCompilerOptions(), targetSourceFile, targetSourceFile.path, fileName, createModuleSpecifierResolutionHost(program, host)); + append(copiedOldImports, filterImport(i, makeStringLiteral(newModuleSpecifier, quotePreference), (name) => importsToCopy.has(checker.getSymbolAtLocation(name)))); + } else { + append(copiedOldImports, filterImport(i, factory.createStringLiteral(moduleSpecifierFromImport(i).text), (name) => importsToCopy.has(checker.getSymbolAtLocation(name)))); + } + }); + } } - function getOrCreateSourceFileLike(fileName) { - const path = toPath3(fileName); - const fileFromCache = sourceFileLike.get(path); - if (fileFromCache !== void 0) - return fileFromCache ? fileFromCache : void 0; - if (!host.readFile || host.fileExists && !host.fileExists(path)) { - sourceFileLike.set(path, false); - return void 0; + const targetFileSourceFile = program.getSourceFile(targetFile); + let oldFileDefault; + const oldFileNamedImports = []; + const markSeenTop = nodeSeenTracker(); + targetFileImportsFromOldFile.forEach((symbol) => { + if (!symbol.declarations) { + return; } - const text = host.readFile(path); - const file = text ? createSourceFileLike(text) : false; - sourceFileLike.set(path, file); - return file ? file : void 0; + for (const decl of symbol.declarations) { + if (!isTopLevelDeclaration(decl)) + continue; + const name = nameOfTopLevelDeclaration(decl); + if (!name) + continue; + const top = getTopLevelDeclarationStatement(decl); + if (markSeenTop(top)) { + addExportToChanges(oldFile, top, name, changes, useEsModuleSyntax); + } + if (importAdder && checker.isUnknownSymbol(symbol)) { + importAdder.addImportFromExportedSymbol(skipAlias(symbol, checker)); + } else { + if (hasSyntacticModifier(decl, 2048 /* Default */)) { + oldFileDefault = name; + } else { + oldFileNamedImports.push(name.text); + } + } + } + }); + return targetFileSourceFile ? append(copiedOldImports, makeImportOrRequire(targetFileSourceFile, oldFileDefault, oldFileNamedImports, oldFile.fileName, program, host, useEsModuleSyntax, quotePreference)) : append(copiedOldImports, makeImportOrRequire(oldFile, oldFileDefault, oldFileNamedImports, oldFile.fileName, program, host, useEsModuleSyntax, quotePreference)); + } + function addNewFileToTsconfig(program, changes, oldFileName, newFileNameWithExtension, getCanonicalFileName) { + const cfg = program.getCompilerOptions().configFile; + if (!cfg) + return; + const newFileAbsolutePath = normalizePath(combinePaths(oldFileName, "..", newFileNameWithExtension)); + const newFilePath = getRelativePathFromFile(cfg.fileName, newFileAbsolutePath, getCanonicalFileName); + const cfgObject = cfg.statements[0] && tryCast(cfg.statements[0].expression, isObjectLiteralExpression); + const filesProp = cfgObject && find(cfgObject.properties, (prop) => isPropertyAssignment(prop) && isStringLiteral(prop.name) && prop.name.text === "files"); + if (filesProp && isArrayLiteralExpression(filesProp.initializer)) { + changes.insertNodeInListAfter(cfg, last(filesProp.initializer.elements), factory.createStringLiteral(newFilePath), filesProp.initializer.elements); } - function getSourceFileLike(fileName) { - return !host.getSourceFileLike ? getSourceFile(fileName) || getOrCreateSourceFileLike(fileName) : host.getSourceFileLike(fileName); + } + function deleteMovedStatements(sourceFile, moved, changes) { + for (const { first: first2, afterLast } of moved) { + changes.deleteNodeRangeExcludingEnd(sourceFile, first2, afterLast); } - function toLineColumnOffset(fileName, position) { - const file = getSourceFileLike(fileName); - return file.getLineAndCharacterOfPosition(position); + } + function deleteUnusedOldImports(oldFile, toMove, changes, toDelete, checker) { + for (const statement of oldFile.statements) { + if (contains(toMove, statement)) + continue; + forEachImportInStatement(statement, (i) => deleteUnusedImports(oldFile, i, changes, (name) => toDelete.has(checker.getSymbolAtLocation(name)))); } - function clearCache() { - sourceFileLike.clear(); - documentPositionMappers.clear(); + } + function updateImportsInOtherFiles(changes, program, host, oldFile, movedSymbols, targetFileName, quotePreference) { + const checker = program.getTypeChecker(); + for (const sourceFile of program.getSourceFiles()) { + if (sourceFile === oldFile) + continue; + for (const statement of sourceFile.statements) { + forEachImportInStatement(statement, (importNode) => { + if (checker.getSymbolAtLocation(moduleSpecifierFromImport(importNode)) !== oldFile.symbol) + return; + const shouldMove = (name) => { + const symbol = isBindingElement(name.parent) ? getPropertySymbolFromBindingElement(checker, name.parent) : skipAlias(checker.getSymbolAtLocation(name), checker); + return !!symbol && movedSymbols.has(symbol); + }; + deleteUnusedImports(sourceFile, importNode, changes, shouldMove); + const pathToTargetFileWithExtension = resolvePath(getDirectoryPath(oldFile.path), targetFileName); + const newModuleSpecifier = getModuleSpecifier(program.getCompilerOptions(), sourceFile, sourceFile.path, pathToTargetFileWithExtension, createModuleSpecifierResolutionHost(program, host)); + const newImportDeclaration = filterImport(importNode, makeStringLiteral(newModuleSpecifier, quotePreference), shouldMove); + if (newImportDeclaration) + changes.insertNodeAfter(sourceFile, statement, newImportDeclaration); + const ns = getNamespaceLikeImport(importNode); + if (ns) + updateNamespaceLikeImport(changes, sourceFile, checker, movedSymbols, newModuleSpecifier, ns, importNode, quotePreference); + }); + } } } - function getDocumentPositionMapper(host, generatedFileName, generatedFileLineInfo, readMapFile) { - let mapFileName = tryGetSourceMappingURL(generatedFileLineInfo); - if (mapFileName) { - const match = base64UrlRegExp.exec(mapFileName); - if (match) { - if (match[1]) { - const base64Object = match[1]; - return convertDocumentToSourceMapper(host, base64decode(sys, base64Object), generatedFileName); - } - mapFileName = void 0; + function getNamespaceLikeImport(node) { + switch (node.kind) { + case 272 /* ImportDeclaration */: + return node.importClause && node.importClause.namedBindings && node.importClause.namedBindings.kind === 274 /* NamespaceImport */ ? node.importClause.namedBindings.name : void 0; + case 271 /* ImportEqualsDeclaration */: + return node.name; + case 260 /* VariableDeclaration */: + return tryCast(node.name, isIdentifier); + default: + return Debug.assertNever(node, `Unexpected node kind ${node.kind}`); + } + } + function updateNamespaceLikeImport(changes, sourceFile, checker, movedSymbols, newModuleSpecifier, oldImportId, oldImportNode, quotePreference) { + const preferredNewNamespaceName = ts_codefix_exports.moduleSpecifierToValidIdentifier(newModuleSpecifier, 99 /* ESNext */); + let needUniqueName = false; + const toChange = []; + ts_FindAllReferences_exports.Core.eachSymbolReferenceInFile(oldImportId, checker, sourceFile, (ref) => { + if (!isPropertyAccessExpression(ref.parent)) + return; + needUniqueName = needUniqueName || !!checker.resolveName( + preferredNewNamespaceName, + ref, + 67108863 /* All */, + /*excludeGlobals*/ + true + ); + if (movedSymbols.has(checker.getSymbolAtLocation(ref.parent.name))) { + toChange.push(ref); + } + }); + if (toChange.length) { + const newNamespaceName = needUniqueName ? getUniqueName(preferredNewNamespaceName, sourceFile) : preferredNewNamespaceName; + for (const ref of toChange) { + changes.replaceNode(sourceFile, ref, factory.createIdentifier(newNamespaceName)); } + changes.insertNodeAfter(sourceFile, oldImportNode, updateNamespaceLikeImportNode(oldImportNode, preferredNewNamespaceName, newModuleSpecifier, quotePreference)); } - const possibleMapLocations = []; - if (mapFileName) { - possibleMapLocations.push(mapFileName); + } + function updateNamespaceLikeImportNode(node, newNamespaceName, newModuleSpecifier, quotePreference) { + const newNamespaceId = factory.createIdentifier(newNamespaceName); + const newModuleString = makeStringLiteral(newModuleSpecifier, quotePreference); + switch (node.kind) { + case 272 /* ImportDeclaration */: + return factory.createImportDeclaration( + /*modifiers*/ + void 0, + factory.createImportClause( + /*isTypeOnly*/ + false, + /*name*/ + void 0, + factory.createNamespaceImport(newNamespaceId) + ), + newModuleString, + /*attributes*/ + void 0 + ); + case 271 /* ImportEqualsDeclaration */: + return factory.createImportEqualsDeclaration( + /*modifiers*/ + void 0, + /*isTypeOnly*/ + false, + newNamespaceId, + factory.createExternalModuleReference(newModuleString) + ); + case 260 /* VariableDeclaration */: + return factory.createVariableDeclaration( + newNamespaceId, + /*exclamationToken*/ + void 0, + /*type*/ + void 0, + createRequireCall(newModuleString) + ); + default: + return Debug.assertNever(node, `Unexpected node kind ${node.kind}`); } - possibleMapLocations.push(generatedFileName + ".map"); - const originalMapFileName = mapFileName && getNormalizedAbsolutePath(mapFileName, getDirectoryPath(generatedFileName)); - for (const location of possibleMapLocations) { - const mapFileName2 = getNormalizedAbsolutePath(location, getDirectoryPath(generatedFileName)); - const mapFileContents = readMapFile(mapFileName2, originalMapFileName); - if (isString(mapFileContents)) { - return convertDocumentToSourceMapper(host, mapFileContents, mapFileName2); + } + function createRequireCall(moduleSpecifier) { + return factory.createCallExpression( + factory.createIdentifier("require"), + /*typeArguments*/ + void 0, + [moduleSpecifier] + ); + } + function moduleSpecifierFromImport(i) { + return i.kind === 272 /* ImportDeclaration */ ? i.moduleSpecifier : i.kind === 271 /* ImportEqualsDeclaration */ ? i.moduleReference.expression : i.initializer.arguments[0]; + } + function forEachImportInStatement(statement, cb) { + if (isImportDeclaration(statement)) { + if (isStringLiteral(statement.moduleSpecifier)) + cb(statement); + } else if (isImportEqualsDeclaration(statement)) { + if (isExternalModuleReference(statement.moduleReference) && isStringLiteralLike(statement.moduleReference.expression)) { + cb(statement); } - if (mapFileContents !== void 0) { - return mapFileContents || void 0; + } else if (isVariableStatement(statement)) { + for (const decl of statement.declarationList.declarations) { + if (decl.initializer && isRequireCall( + decl.initializer, + /*requireStringLiteralLikeArgument*/ + true + )) { + cb(decl); + } } } - return void 0; } - function convertDocumentToSourceMapper(host, contents, mapFileName) { - const map2 = tryParseRawSourceMap(contents); - if (!map2 || !map2.sources || !map2.file || !map2.mappings) { - return void 0; + function createOldFileImportsFromTargetFile(sourceFile, targetFileNeedExport, targetFileNameWithExtension, program, host, useEs6Imports, quotePreference) { + let defaultImport; + const imports = []; + targetFileNeedExport.forEach((symbol) => { + if (symbol.escapedName === "default" /* Default */) { + defaultImport = factory.createIdentifier(symbolNameNoDefault(symbol)); + } else { + imports.push(symbol.name); + } + }); + return makeImportOrRequire(sourceFile, defaultImport, imports, targetFileNameWithExtension, program, host, useEs6Imports, quotePreference); + } + function makeImportOrRequire(sourceFile, defaultImport, imports, targetFileNameWithExtension, program, host, useEs6Imports, quotePreference) { + const pathToTargetFile = resolvePath(getDirectoryPath(sourceFile.path), targetFileNameWithExtension); + const pathToTargetFileWithCorrectExtension = getModuleSpecifier(program.getCompilerOptions(), sourceFile, sourceFile.path, pathToTargetFile, createModuleSpecifierResolutionHost(program, host)); + if (useEs6Imports) { + const specifiers = imports.map((i) => factory.createImportSpecifier( + /*isTypeOnly*/ + false, + /*propertyName*/ + void 0, + factory.createIdentifier(i) + )); + return makeImportIfNecessary(defaultImport, specifiers, pathToTargetFileWithCorrectExtension, quotePreference); + } else { + Debug.assert(!defaultImport, "No default import should exist"); + const bindingElements = imports.map((i) => factory.createBindingElement( + /*dotDotDotToken*/ + void 0, + /*propertyName*/ + void 0, + i + )); + return bindingElements.length ? makeVariableStatement( + factory.createObjectBindingPattern(bindingElements), + /*type*/ + void 0, + createRequireCall(makeStringLiteral(pathToTargetFileWithCorrectExtension, quotePreference)) + ) : void 0; } - if (map2.sourcesContent && map2.sourcesContent.some(isString)) - return void 0; - return createDocumentPositionMapper(host, map2, mapFileName); } - function createSourceFileLike(text, lineMap) { - return { - text, - lineMap, - getLineAndCharacterOfPosition(pos) { - return computeLineAndCharacterOfPosition(getLineStarts(this), pos); + function makeVariableStatement(name, type, initializer, flags = 2 /* Const */) { + return factory.createVariableStatement( + /*modifiers*/ + void 0, + factory.createVariableDeclarationList([factory.createVariableDeclaration( + name, + /*exclamationToken*/ + void 0, + type, + initializer + )], flags) + ); + } + function addExports(sourceFile, toMove, needExport, useEs6Exports) { + return flatMap(toMove, (statement) => { + if (isTopLevelDeclarationStatement(statement) && !isExported(sourceFile, statement, useEs6Exports) && forEachTopLevelDeclaration(statement, (d) => { + var _a; + return needExport.has(Debug.checkDefined((_a = tryCast(d, canHaveSymbol)) == null ? void 0 : _a.symbol)); + })) { + const exports = addExport(getSynthesizedDeepClone(statement), useEs6Exports); + if (exports) + return exports; } - }; + return getSynthesizedDeepClone(statement); + }); } - var base64UrlRegExp; - var init_sourcemaps = __esm({ - "src/services/sourcemaps.ts"() { - "use strict"; - init_ts4(); - base64UrlRegExp = /^data:(?:application\/json(?:;charset=[uU][tT][fF]-8);base64,([A-Za-z0-9+\/=]+)$)?/; + function isExported(sourceFile, decl, useEs6Exports, name) { + var _a; + if (useEs6Exports) { + return !isExpressionStatement(decl) && hasSyntacticModifier(decl, 32 /* Export */) || !!(name && sourceFile.symbol && ((_a = sourceFile.symbol.exports) == null ? void 0 : _a.has(name.escapedText))); } - }); - - // src/services/suggestionDiagnostics.ts - function computeSuggestionDiagnostics(sourceFile, program, cancellationToken) { - program.getSemanticDiagnostics(sourceFile, cancellationToken); - const diags = []; - const checker = program.getTypeChecker(); - const isCommonJSFile = sourceFile.impliedNodeFormat === 1 /* CommonJS */ || fileExtensionIsOneOf(sourceFile.fileName, [".cts" /* Cts */, ".cjs" /* Cjs */]); - if (!isCommonJSFile && sourceFile.commonJsModuleIndicator && (programContainsEsModules(program) || compilerOptionsIndicateEsModules(program.getCompilerOptions())) && containsTopLevelCommonjs(sourceFile)) { - diags.push(createDiagnosticForNode(getErrorNodeFromCommonJsIndicator(sourceFile.commonJsModuleIndicator), Diagnostics.File_is_a_CommonJS_module_it_may_be_converted_to_an_ES_module)); + return !!sourceFile.symbol && !!sourceFile.symbol.exports && getNamesToExportInCommonJS(decl).some((name2) => sourceFile.symbol.exports.has(escapeLeadingUnderscores(name2))); + } + function deleteUnusedImports(sourceFile, importDecl, changes, isUnused) { + switch (importDecl.kind) { + case 272 /* ImportDeclaration */: + deleteUnusedImportsInDeclaration(sourceFile, importDecl, changes, isUnused); + break; + case 271 /* ImportEqualsDeclaration */: + if (isUnused(importDecl.name)) { + changes.delete(sourceFile, importDecl); + } + break; + case 260 /* VariableDeclaration */: + deleteUnusedImportsInVariableDeclaration(sourceFile, importDecl, changes, isUnused); + break; + default: + Debug.assertNever(importDecl, `Unexpected import decl kind ${importDecl.kind}`); } - const isJsFile = isSourceFileJS(sourceFile); - visitedNestedConvertibleFunctions.clear(); - check(sourceFile); - if (getAllowSyntheticDefaultImports(program.getCompilerOptions())) { - for (const moduleSpecifier of sourceFile.imports) { - const importNode = importFromModuleSpecifier(moduleSpecifier); - const name = importNameForConvertToDefaultImport(importNode); - if (!name) - continue; - const module2 = getResolvedModule(sourceFile, moduleSpecifier.text, getModeForUsageLocation(sourceFile, moduleSpecifier)); - const resolvedFile = module2 && program.getSourceFile(module2.resolvedFileName); - if (resolvedFile && resolvedFile.externalModuleIndicator && resolvedFile.externalModuleIndicator !== true && isExportAssignment(resolvedFile.externalModuleIndicator) && resolvedFile.externalModuleIndicator.isExportEquals) { - diags.push(createDiagnosticForNode(name, Diagnostics.Import_may_be_converted_to_a_default_import)); + } + function deleteUnusedImportsInDeclaration(sourceFile, importDecl, changes, isUnused) { + if (!importDecl.importClause) + return; + const { name, namedBindings } = importDecl.importClause; + const defaultUnused = !name || isUnused(name); + const namedBindingsUnused = !namedBindings || (namedBindings.kind === 274 /* NamespaceImport */ ? isUnused(namedBindings.name) : namedBindings.elements.length !== 0 && namedBindings.elements.every((e) => isUnused(e.name))); + if (defaultUnused && namedBindingsUnused) { + changes.delete(sourceFile, importDecl); + } else { + if (name && defaultUnused) { + changes.delete(sourceFile, name); + } + if (namedBindings) { + if (namedBindingsUnused) { + changes.replaceNode( + sourceFile, + importDecl.importClause, + factory.updateImportClause( + importDecl.importClause, + importDecl.importClause.isTypeOnly, + name, + /*namedBindings*/ + void 0 + ) + ); + } else if (namedBindings.kind === 275 /* NamedImports */) { + for (const element of namedBindings.elements) { + if (isUnused(element.name)) + changes.delete(sourceFile, element); + } } } } - addRange(diags, sourceFile.bindSuggestionDiagnostics); - addRange(diags, program.getSuggestionDiagnostics(sourceFile, cancellationToken)); - return diags.sort((d1, d2) => d1.start - d2.start); - function check(node) { - if (isJsFile) { - if (canBeConvertedToClass(node, checker)) { - diags.push(createDiagnosticForNode(isVariableDeclaration(node.parent) ? node.parent.name : node, Diagnostics.This_constructor_function_may_be_converted_to_a_class_declaration)); - } - } else { - if (isVariableStatement(node) && node.parent === sourceFile && node.declarationList.flags & 2 /* Const */ && node.declarationList.declarations.length === 1) { - const init = node.declarationList.declarations[0].initializer; - if (init && isRequireCall( - init, + } + function deleteUnusedImportsInVariableDeclaration(sourceFile, varDecl, changes, isUnused) { + const { name } = varDecl; + switch (name.kind) { + case 80 /* Identifier */: + if (isUnused(name)) { + if (varDecl.initializer && isRequireCall( + varDecl.initializer, /*requireStringLiteralLikeArgument*/ true )) { - diags.push(createDiagnosticForNode(init, Diagnostics.require_call_may_be_converted_to_an_import)); + changes.delete(sourceFile, isVariableDeclarationList(varDecl.parent) && length(varDecl.parent.declarations) === 1 ? varDecl.parent.parent : varDecl); + } else { + changes.delete(sourceFile, name); } } - const jsdocTypedefNode = ts_codefix_exports.getJSDocTypedefNode(node); - if (jsdocTypedefNode) { - diags.push(createDiagnosticForNode(jsdocTypedefNode, Diagnostics.JSDoc_typedef_may_be_converted_to_TypeScript_type)); - } - if (ts_codefix_exports.parameterShouldGetTypeFromJSDoc(node)) { - diags.push(createDiagnosticForNode(node.name || node, Diagnostics.JSDoc_types_may_be_moved_to_TypeScript_types)); + break; + case 207 /* ArrayBindingPattern */: + break; + case 206 /* ObjectBindingPattern */: + if (name.elements.every((e) => isIdentifier(e.name) && isUnused(e.name))) { + changes.delete(sourceFile, isVariableDeclarationList(varDecl.parent) && varDecl.parent.declarations.length === 1 ? varDecl.parent.parent : varDecl); + } else { + for (const element of name.elements) { + if (isIdentifier(element.name) && isUnused(element.name)) { + changes.delete(sourceFile, element.name); + } + } } + break; + } + } + function isTopLevelDeclarationStatement(node) { + Debug.assert(isSourceFile(node.parent), "Node parent should be a SourceFile"); + return isNonVariableTopLevelDeclaration(node) || isVariableStatement(node); + } + function addExport(decl, useEs6Exports) { + return useEs6Exports ? [addEs6Export(decl)] : addCommonjsExport(decl); + } + function addEs6Export(d) { + const modifiers = canHaveModifiers(d) ? concatenate([factory.createModifier(95 /* ExportKeyword */)], getModifiers(d)) : void 0; + switch (d.kind) { + case 262 /* FunctionDeclaration */: + return factory.updateFunctionDeclaration(d, modifiers, d.asteriskToken, d.name, d.typeParameters, d.parameters, d.type, d.body); + case 263 /* ClassDeclaration */: + const decorators = canHaveDecorators(d) ? getDecorators(d) : void 0; + return factory.updateClassDeclaration(d, concatenate(decorators, modifiers), d.name, d.typeParameters, d.heritageClauses, d.members); + case 243 /* VariableStatement */: + return factory.updateVariableStatement(d, modifiers, d.declarationList); + case 267 /* ModuleDeclaration */: + return factory.updateModuleDeclaration(d, modifiers, d.name, d.body); + case 266 /* EnumDeclaration */: + return factory.updateEnumDeclaration(d, modifiers, d.name, d.members); + case 265 /* TypeAliasDeclaration */: + return factory.updateTypeAliasDeclaration(d, modifiers, d.name, d.typeParameters, d.type); + case 264 /* InterfaceDeclaration */: + return factory.updateInterfaceDeclaration(d, modifiers, d.name, d.typeParameters, d.heritageClauses, d.members); + case 271 /* ImportEqualsDeclaration */: + return factory.updateImportEqualsDeclaration(d, modifiers, d.isTypeOnly, d.name, d.moduleReference); + case 244 /* ExpressionStatement */: + return Debug.fail(); + default: + return Debug.assertNever(d, `Unexpected declaration kind ${d.kind}`); + } + } + function addCommonjsExport(decl) { + return [decl, ...getNamesToExportInCommonJS(decl).map(createExportAssignment)]; + } + function createExportAssignment(name) { + return factory.createExpressionStatement( + factory.createBinaryExpression( + factory.createPropertyAccessExpression(factory.createIdentifier("exports"), factory.createIdentifier(name)), + 64 /* EqualsToken */, + factory.createIdentifier(name) + ) + ); + } + function getNamesToExportInCommonJS(decl) { + switch (decl.kind) { + case 262 /* FunctionDeclaration */: + case 263 /* ClassDeclaration */: + return [decl.name.text]; + case 243 /* VariableStatement */: + return mapDefined(decl.declarationList.declarations, (d) => isIdentifier(d.name) ? d.name.text : void 0); + case 267 /* ModuleDeclaration */: + case 266 /* EnumDeclaration */: + case 265 /* TypeAliasDeclaration */: + case 264 /* InterfaceDeclaration */: + case 271 /* ImportEqualsDeclaration */: + return emptyArray; + case 244 /* ExpressionStatement */: + return Debug.fail("Can't export an ExpressionStatement"); + default: + return Debug.assertNever(decl, `Unexpected decl kind ${decl.kind}`); + } + } + function filterImport(i, moduleSpecifier, keep) { + switch (i.kind) { + case 272 /* ImportDeclaration */: { + const clause = i.importClause; + if (!clause) + return void 0; + const defaultImport = clause.name && keep(clause.name) ? clause.name : void 0; + const namedBindings = clause.namedBindings && filterNamedBindings(clause.namedBindings, keep); + return defaultImport || namedBindings ? factory.createImportDeclaration( + /*modifiers*/ + void 0, + factory.createImportClause(clause.isTypeOnly, defaultImport, namedBindings), + getSynthesizedDeepClone(moduleSpecifier), + /*attributes*/ + void 0 + ) : void 0; } - if (canBeConvertedToAsync(node)) { - addConvertToAsyncFunctionDiagnostics(node, checker, diags); + case 271 /* ImportEqualsDeclaration */: + return keep(i.name) ? i : void 0; + case 260 /* VariableDeclaration */: { + const name = filterBindingName(i.name, keep); + return name ? makeVariableStatement(name, i.type, createRequireCall(moduleSpecifier), i.parent.flags) : void 0; } - node.forEachChild(check); + default: + return Debug.assertNever(i, `Unexpected import kind ${i.kind}`); } } - function containsTopLevelCommonjs(sourceFile) { - return sourceFile.statements.some((statement) => { - switch (statement.kind) { - case 242 /* VariableStatement */: - return statement.declarationList.declarations.some((decl) => !!decl.initializer && isRequireCall( - propertyAccessLeftHandSide(decl.initializer), - /*requireStringLiteralLikeArgument*/ - true - )); - case 243 /* ExpressionStatement */: { - const { expression } = statement; - if (!isBinaryExpression(expression)) - return isRequireCall( - expression, - /*requireStringLiteralLikeArgument*/ - true - ); - const kind = getAssignmentDeclarationKind(expression); - return kind === 1 /* ExportsProperty */ || kind === 2 /* ModuleExports */; - } - default: - return false; + function filterNamedBindings(namedBindings, keep) { + if (namedBindings.kind === 274 /* NamespaceImport */) { + return keep(namedBindings.name) ? namedBindings : void 0; + } else { + const newElements = namedBindings.elements.filter((e) => keep(e.name)); + return newElements.length ? factory.createNamedImports(newElements) : void 0; + } + } + function filterBindingName(name, keep) { + switch (name.kind) { + case 80 /* Identifier */: + return keep(name) ? name : void 0; + case 207 /* ArrayBindingPattern */: + return name; + case 206 /* ObjectBindingPattern */: { + const newElements = name.elements.filter((prop) => prop.propertyName || !isIdentifier(prop.name) || keep(prop.name)); + return newElements.length ? factory.createObjectBindingPattern(newElements) : void 0; } - }); + } } - function propertyAccessLeftHandSide(node) { - return isPropertyAccessExpression(node) ? propertyAccessLeftHandSide(node.expression) : node; + function nameOfTopLevelDeclaration(d) { + return isExpressionStatement(d) ? tryCast(d.expression.left.name, isIdentifier) : tryCast(d.name, isIdentifier); } - function importNameForConvertToDefaultImport(node) { - switch (node.kind) { - case 271 /* ImportDeclaration */: - const { importClause, moduleSpecifier } = node; - return importClause && !importClause.name && importClause.namedBindings && importClause.namedBindings.kind === 273 /* NamespaceImport */ && isStringLiteral(moduleSpecifier) ? importClause.namedBindings.name : void 0; - case 270 /* ImportEqualsDeclaration */: - return node.name; + function getTopLevelDeclarationStatement(d) { + switch (d.kind) { + case 260 /* VariableDeclaration */: + return d.parent.parent; + case 208 /* BindingElement */: + return getTopLevelDeclarationStatement( + cast(d.parent.parent, (p) => isVariableDeclaration(p) || isBindingElement(p)) + ); default: - return void 0; + return d; } } - function addConvertToAsyncFunctionDiagnostics(node, checker, diags) { - if (isConvertibleFunction(node, checker) && !visitedNestedConvertibleFunctions.has(getKeyFromNode(node))) { - diags.push(createDiagnosticForNode( - !node.name && isVariableDeclaration(node.parent) && isIdentifier(node.parent.name) ? node.parent.name : node, - Diagnostics.This_may_be_converted_to_an_async_function - )); + function addExportToChanges(sourceFile, decl, name, changes, useEs6Exports) { + if (isExported(sourceFile, decl, useEs6Exports, name)) + return; + if (useEs6Exports) { + if (!isExpressionStatement(decl)) + changes.insertExportModifier(sourceFile, decl); + } else { + const names = getNamesToExportInCommonJS(decl); + if (names.length !== 0) + changes.insertNodesAfter(sourceFile, decl, names.map(createExportAssignment)); } } - function isConvertibleFunction(node, checker) { - return !isAsyncFunction(node) && node.body && isBlock(node.body) && hasReturnStatementWithPromiseHandler(node.body, checker) && returnsPromise(node, checker); + function createNewFileName(oldFile, program, context, host) { + const checker = program.getTypeChecker(); + const toMove = getStatementsToMove(context); + let usage; + if (toMove) { + usage = getUsageInfo(oldFile, toMove.all, checker); + const currentDirectory = getDirectoryPath(oldFile.fileName); + const extension = extensionFromPath(oldFile.fileName); + const newFileName = combinePaths( + // new file is always placed in the same directory as the old file + currentDirectory, + // ensures the filename computed below isn't already taken + makeUniqueFilename( + // infers a name for the new file from the symbols being moved + inferNewFileName(usage.oldFileImportsFromTargetFile, usage.movedSymbols), + extension, + currentDirectory, + host + ) + ) + extension; + return newFileName; + } + return ""; } - function returnsPromise(node, checker) { - const signature = checker.getSignatureFromDeclaration(node); - const returnType = signature ? checker.getReturnTypeOfSignature(signature) : void 0; - return !!returnType && !!checker.getPromisedTypeOfPromise(returnType); + function getRangeToMove(context) { + const { file } = context; + const range = createTextRangeFromSpan(getRefactorContextSpan(context)); + const { statements } = file; + let startNodeIndex = findIndex(statements, (s) => s.end > range.pos); + if (startNodeIndex === -1) + return void 0; + const startStatement = statements[startNodeIndex]; + const overloadRangeToMove = getOverloadRangeToMove(file, startStatement); + if (overloadRangeToMove) { + startNodeIndex = overloadRangeToMove.start; + } + let endNodeIndex = findIndex(statements, (s) => s.end >= range.end, startNodeIndex); + if (endNodeIndex !== -1 && range.end <= statements[endNodeIndex].getStart()) { + endNodeIndex--; + } + const endingOverloadRangeToMove = getOverloadRangeToMove(file, statements[endNodeIndex]); + if (endingOverloadRangeToMove) { + endNodeIndex = endingOverloadRangeToMove.end; + } + return { + toMove: statements.slice(startNodeIndex, endNodeIndex === -1 ? statements.length : endNodeIndex + 1), + afterLast: endNodeIndex === -1 ? void 0 : statements[endNodeIndex + 1] + }; } - function getErrorNodeFromCommonJsIndicator(commonJsModuleIndicator) { - return isBinaryExpression(commonJsModuleIndicator) ? commonJsModuleIndicator.left : commonJsModuleIndicator; + function getStatementsToMove(context) { + const rangeToMove = getRangeToMove(context); + if (rangeToMove === void 0) + return void 0; + const all = []; + const ranges = []; + const { toMove, afterLast } = rangeToMove; + getRangesWhere(toMove, isAllowedStatementToMove, (start, afterEndIndex) => { + for (let i = start; i < afterEndIndex; i++) + all.push(toMove[i]); + ranges.push({ first: toMove[start], afterLast }); + }); + return all.length === 0 ? void 0 : { all, ranges }; } - function hasReturnStatementWithPromiseHandler(body, checker) { - return !!forEachReturnStatement(body, (statement) => isReturnStatementWithFixablePromiseHandler(statement, checker)); + function isAllowedStatementToMove(statement) { + return !isPureImport(statement) && !isPrologueDirective(statement); } - function isReturnStatementWithFixablePromiseHandler(node, checker) { - return isReturnStatement(node) && !!node.expression && isFixablePromiseHandler(node.expression, checker); + function isPureImport(node) { + switch (node.kind) { + case 272 /* ImportDeclaration */: + return true; + case 271 /* ImportEqualsDeclaration */: + return !hasSyntacticModifier(node, 32 /* Export */); + case 243 /* VariableStatement */: + return node.declarationList.declarations.every((d) => !!d.initializer && isRequireCall( + d.initializer, + /*requireStringLiteralLikeArgument*/ + true + )); + default: + return false; + } } - function isFixablePromiseHandler(node, checker) { - if (!isPromiseHandler(node) || !hasSupportedNumberOfArguments(node) || !node.arguments.every((arg) => isFixablePromiseArgument(arg, checker))) { - return false; + function getUsageInfo(oldFile, toMove, checker, existingTargetImports = /* @__PURE__ */ new Set()) { + const movedSymbols = /* @__PURE__ */ new Set(); + const oldImportsNeededByTargetFile = /* @__PURE__ */ new Map(); + const targetFileImportsFromOldFile = /* @__PURE__ */ new Set(); + const containsJsx = find(toMove, (statement) => !!(statement.transformFlags & 2 /* ContainsJsx */)); + const jsxNamespaceSymbol = getJsxNamespaceSymbol(containsJsx); + if (jsxNamespaceSymbol) { + oldImportsNeededByTargetFile.set(jsxNamespaceSymbol, false); } - let currentNode = node.expression.expression; - while (isPromiseHandler(currentNode) || isPropertyAccessExpression(currentNode)) { - if (isCallExpression(currentNode)) { - if (!hasSupportedNumberOfArguments(currentNode) || !currentNode.arguments.every((arg) => isFixablePromiseArgument(arg, checker))) { - return false; + for (const statement of toMove) { + forEachTopLevelDeclaration(statement, (decl) => { + movedSymbols.add(Debug.checkDefined(isExpressionStatement(decl) ? checker.getSymbolAtLocation(decl.expression.left) : decl.symbol, "Need a symbol here")); + }); + } + const unusedImportsFromOldFile = /* @__PURE__ */ new Set(); + for (const statement of toMove) { + forEachReference(statement, checker, (symbol, isValidTypeOnlyUseSite) => { + if (!symbol.declarations) { + return; } - currentNode = currentNode.expression.expression; - } else { - currentNode = currentNode.expression; + if (existingTargetImports.has(skipAlias(symbol, checker))) { + unusedImportsFromOldFile.add(symbol); + return; + } + for (const decl of symbol.declarations) { + if (isInImport(decl)) { + const prevIsTypeOnly = oldImportsNeededByTargetFile.get(symbol); + oldImportsNeededByTargetFile.set(symbol, prevIsTypeOnly === void 0 ? isValidTypeOnlyUseSite : prevIsTypeOnly && isValidTypeOnlyUseSite); + } else if (isTopLevelDeclaration(decl) && sourceFileOfTopLevelDeclaration(decl) === oldFile && !movedSymbols.has(symbol)) { + targetFileImportsFromOldFile.add(symbol); + } + } + }); + } + for (const unusedImport of oldImportsNeededByTargetFile.keys()) { + unusedImportsFromOldFile.add(unusedImport); + } + const oldFileImportsFromTargetFile = /* @__PURE__ */ new Set(); + for (const statement of oldFile.statements) { + if (contains(toMove, statement)) + continue; + if (jsxNamespaceSymbol && !!(statement.transformFlags & 2 /* ContainsJsx */)) { + unusedImportsFromOldFile.delete(jsxNamespaceSymbol); } + forEachReference(statement, checker, (symbol) => { + if (movedSymbols.has(symbol)) + oldFileImportsFromTargetFile.add(symbol); + unusedImportsFromOldFile.delete(symbol); + }); + } + return { movedSymbols, targetFileImportsFromOldFile, oldFileImportsFromTargetFile, oldImportsNeededByTargetFile, unusedImportsFromOldFile }; + function getJsxNamespaceSymbol(containsJsx2) { + if (containsJsx2 === void 0) { + return void 0; + } + const jsxNamespace = checker.getJsxNamespace(containsJsx2); + const jsxNamespaceSymbol2 = checker.resolveName( + jsxNamespace, + containsJsx2, + 1920 /* Namespace */, + /*excludeGlobals*/ + true + ); + return !!jsxNamespaceSymbol2 && some(jsxNamespaceSymbol2.declarations, isInImport) ? jsxNamespaceSymbol2 : void 0; } - return true; } - function isPromiseHandler(node) { - return isCallExpression(node) && (hasPropertyAccessExpressionWithName(node, "then") || hasPropertyAccessExpressionWithName(node, "catch") || hasPropertyAccessExpressionWithName(node, "finally")); + function makeUniqueFilename(proposedFilename, extension, inDirectory, host) { + let newFilename = proposedFilename; + for (let i = 1; ; i++) { + const name = combinePaths(inDirectory, newFilename + extension); + if (!host.fileExists(name)) + return newFilename; + newFilename = `${proposedFilename}.${i}`; + } } - function hasSupportedNumberOfArguments(node) { - const name = node.expression.name.text; - const maxArguments = name === "then" ? 2 : name === "catch" ? 1 : name === "finally" ? 1 : 0; - if (node.arguments.length > maxArguments) - return false; - if (node.arguments.length < maxArguments) - return true; - return maxArguments === 1 || some(node.arguments, (arg) => { - return arg.kind === 106 /* NullKeyword */ || isIdentifier(arg) && arg.text === "undefined"; + function inferNewFileName(importsFromNewFile, movedSymbols) { + return forEachKey(importsFromNewFile, symbolNameNoDefault) || forEachKey(movedSymbols, symbolNameNoDefault) || "newFile"; + } + function forEachReference(node, checker, onReference) { + node.forEachChild(function cb(node2) { + if (isIdentifier(node2) && !isDeclarationName(node2)) { + const sym = checker.getSymbolAtLocation(node2); + if (sym) + onReference(sym, isValidTypeOnlyAliasUseSite(node2)); + } else { + node2.forEachChild(cb); + } }); } - function isFixablePromiseArgument(arg, checker) { - switch (arg.kind) { - case 261 /* FunctionDeclaration */: - case 217 /* FunctionExpression */: - const functionFlags = getFunctionFlags(arg); - if (functionFlags & 1 /* Generator */) { - return false; - } - case 218 /* ArrowFunction */: - visitedNestedConvertibleFunctions.set(getKeyFromNode(arg), true); - case 106 /* NullKeyword */: - return true; - case 80 /* Identifier */: - case 210 /* PropertyAccessExpression */: { - const symbol = checker.getSymbolAtLocation(arg); - if (!symbol) { - return false; - } - return checker.isUndefinedSymbol(symbol) || some(skipAlias(symbol, checker).declarations, (d) => isFunctionLike(d) || hasInitializer(d) && !!d.initializer && isFunctionLike(d.initializer)); + function forEachTopLevelDeclaration(statement, cb) { + switch (statement.kind) { + case 262 /* FunctionDeclaration */: + case 263 /* ClassDeclaration */: + case 267 /* ModuleDeclaration */: + case 266 /* EnumDeclaration */: + case 265 /* TypeAliasDeclaration */: + case 264 /* InterfaceDeclaration */: + case 271 /* ImportEqualsDeclaration */: + return cb(statement); + case 243 /* VariableStatement */: + return firstDefined(statement.declarationList.declarations, (decl) => forEachTopLevelDeclarationInBindingName(decl.name, cb)); + case 244 /* ExpressionStatement */: { + const { expression } = statement; + return isBinaryExpression(expression) && getAssignmentDeclarationKind(expression) === 1 /* ExportsProperty */ ? cb(statement) : void 0; } + } + } + function isInImport(decl) { + switch (decl.kind) { + case 271 /* ImportEqualsDeclaration */: + case 276 /* ImportSpecifier */: + case 273 /* ImportClause */: + case 274 /* NamespaceImport */: + return true; + case 260 /* VariableDeclaration */: + return isVariableDeclarationInImport(decl); + case 208 /* BindingElement */: + return isVariableDeclaration(decl.parent.parent) && isVariableDeclarationInImport(decl.parent.parent); default: return false; } } - function getKeyFromNode(exp) { - return `${exp.pos.toString()}:${exp.end.toString()}`; + function isVariableDeclarationInImport(decl) { + return isSourceFile(decl.parent.parent.parent) && !!decl.initializer && isRequireCall( + decl.initializer, + /*requireStringLiteralLikeArgument*/ + true + ); } - function canBeConvertedToClass(node, checker) { - var _a, _b, _c, _d; - if (isFunctionExpression(node)) { - if (isVariableDeclaration(node.parent) && ((_a = node.symbol.members) == null ? void 0 : _a.size)) { - return true; - } - const symbol = checker.getSymbolOfExpando( - node, - /*allowDeclaration*/ - false - ); - return !!(symbol && (((_b = symbol.exports) == null ? void 0 : _b.size) || ((_c = symbol.members) == null ? void 0 : _c.size))); - } - if (isFunctionDeclaration(node)) { - return !!((_d = node.symbol.members) == null ? void 0 : _d.size); + function isTopLevelDeclaration(node) { + return isNonVariableTopLevelDeclaration(node) && isSourceFile(node.parent) || isVariableDeclaration(node) && isSourceFile(node.parent.parent.parent); + } + function sourceFileOfTopLevelDeclaration(node) { + return isVariableDeclaration(node) ? node.parent.parent.parent : node.parent; + } + function forEachTopLevelDeclarationInBindingName(name, cb) { + switch (name.kind) { + case 80 /* Identifier */: + return cb(cast(name.parent, (x) => isVariableDeclaration(x) || isBindingElement(x))); + case 207 /* ArrayBindingPattern */: + case 206 /* ObjectBindingPattern */: + return firstDefined(name.elements, (em) => isOmittedExpression(em) ? void 0 : forEachTopLevelDeclarationInBindingName(em.name, cb)); + default: + return Debug.assertNever(name, `Unexpected name kind ${name.kind}`); } - return false; } - function canBeConvertedToAsync(node) { + function isNonVariableTopLevelDeclaration(node) { switch (node.kind) { - case 261 /* FunctionDeclaration */: - case 173 /* MethodDeclaration */: - case 217 /* FunctionExpression */: - case 218 /* ArrowFunction */: + case 262 /* FunctionDeclaration */: + case 263 /* ClassDeclaration */: + case 267 /* ModuleDeclaration */: + case 266 /* EnumDeclaration */: + case 265 /* TypeAliasDeclaration */: + case 264 /* InterfaceDeclaration */: + case 271 /* ImportEqualsDeclaration */: return true; default: return false; } } - var visitedNestedConvertibleFunctions; - var init_suggestionDiagnostics = __esm({ - "src/services/suggestionDiagnostics.ts"() { - "use strict"; - init_ts4(); - visitedNestedConvertibleFunctions = /* @__PURE__ */ new Map(); - } - }); - - // src/services/transpile.ts - function transpileModule(input, transpileOptions) { - const diagnostics = []; - const options = transpileOptions.compilerOptions ? fixupCompilerOptions(transpileOptions.compilerOptions, diagnostics) : {}; - const defaultOptions = getDefaultCompilerOptions2(); - for (const key in defaultOptions) { - if (hasProperty(defaultOptions, key) && options[key] === void 0) { - options[key] = defaultOptions[key]; - } - } - for (const option of transpileOptionValueCompilerOptions) { - if (options.verbatimModuleSyntax && optionsRedundantWithVerbatimModuleSyntax.has(option.name)) { - continue; + function moveStatementsToTargetFile(changes, program, statements, targetFile, toMove) { + var _a; + const removedExports = /* @__PURE__ */ new Set(); + const targetExports = (_a = targetFile.symbol) == null ? void 0 : _a.exports; + if (targetExports) { + const checker = program.getTypeChecker(); + const targetToSourceExports = /* @__PURE__ */ new Map(); + for (const node of toMove.all) { + if (isTopLevelDeclarationStatement(node) && hasSyntacticModifier(node, 32 /* Export */)) { + forEachTopLevelDeclaration(node, (declaration) => { + var _a2; + const targetDeclarations = canHaveSymbol(declaration) ? (_a2 = targetExports.get(declaration.symbol.escapedName)) == null ? void 0 : _a2.declarations : void 0; + const exportDeclaration = firstDefined(targetDeclarations, (d) => isExportDeclaration(d) ? d : isExportSpecifier(d) ? tryCast(d.parent.parent, isExportDeclaration) : void 0); + if (exportDeclaration && exportDeclaration.moduleSpecifier) { + targetToSourceExports.set(exportDeclaration, (targetToSourceExports.get(exportDeclaration) || /* @__PURE__ */ new Set()).add(declaration)); + } + }); + } } - options[option.name] = option.transpileOptionValue; - } - options.suppressOutputPathCheck = true; - options.allowNonTsExtensions = true; - const newLine = getNewLineCharacter(options); - const compilerHost = { - getSourceFile: (fileName) => fileName === normalizePath(inputFileName) ? sourceFile : void 0, - writeFile: (name, text) => { - if (fileExtensionIs(name, ".map")) { - Debug.assertEqual(sourceMapText, void 0, "Unexpected multiple source map outputs, file:", name); - sourceMapText = text; - } else { - Debug.assertEqual(outputText, void 0, "Unexpected multiple outputs, file:", name); - outputText = text; + for (const [exportDeclaration, topLevelDeclarations] of arrayFrom(targetToSourceExports)) { + if (exportDeclaration.exportClause && isNamedExports(exportDeclaration.exportClause) && length(exportDeclaration.exportClause.elements)) { + const elements = exportDeclaration.exportClause.elements; + const updatedElements = filter(elements, (elem) => find(skipAlias(elem.symbol, checker).declarations, (d) => isTopLevelDeclaration(d) && topLevelDeclarations.has(d)) === void 0); + if (length(updatedElements) === 0) { + changes.deleteNode(targetFile, exportDeclaration); + removedExports.add(exportDeclaration); + continue; + } + if (length(updatedElements) < length(elements)) { + changes.replaceNode(targetFile, exportDeclaration, factory.updateExportDeclaration(exportDeclaration, exportDeclaration.modifiers, exportDeclaration.isTypeOnly, factory.updateNamedExports(exportDeclaration.exportClause, factory.createNodeArray(updatedElements, elements.hasTrailingComma)), exportDeclaration.moduleSpecifier, exportDeclaration.attributes)); + } } - }, - getDefaultLibFileName: () => "lib.d.ts", - useCaseSensitiveFileNames: () => false, - getCanonicalFileName: (fileName) => fileName, - getCurrentDirectory: () => "", - getNewLine: () => newLine, - fileExists: (fileName) => fileName === inputFileName, - readFile: () => "", - directoryExists: () => true, - getDirectories: () => [] - }; - const inputFileName = transpileOptions.fileName || (transpileOptions.compilerOptions && transpileOptions.compilerOptions.jsx ? "module.tsx" : "module.ts"); - const sourceFile = createSourceFile( - inputFileName, - input, - { - languageVersion: getEmitScriptTarget(options), - impliedNodeFormat: getImpliedNodeFormatForFile( - toPath(inputFileName, "", compilerHost.getCanonicalFileName), - /*packageJsonInfoCache*/ - void 0, - compilerHost, - options - ), - setExternalModuleIndicator: getSetExternalModuleIndicator(options) } - ); - if (transpileOptions.moduleName) { - sourceFile.moduleName = transpileOptions.moduleName; - } - if (transpileOptions.renamedDependencies) { - sourceFile.renamedDependencies = new Map(Object.entries(transpileOptions.renamedDependencies)); } - let outputText; - let sourceMapText; - const program = createProgram([inputFileName], options, compilerHost); - if (transpileOptions.reportDiagnostics) { - addRange( - /*to*/ - diagnostics, - /*from*/ - program.getSyntacticDiagnostics(sourceFile) - ); - addRange( - /*to*/ - diagnostics, - /*from*/ - program.getOptionsDiagnostics() + const lastReExport = findLast(targetFile.statements, (n) => isExportDeclaration(n) && !!n.moduleSpecifier && !removedExports.has(n)); + if (lastReExport) { + changes.insertNodesBefore( + targetFile, + lastReExport, + statements, + /*blankLineBetween*/ + true ); + } else { + changes.insertNodesAfter(targetFile, targetFile.statements[targetFile.statements.length - 1], statements); } - program.emit( - /*targetSourceFile*/ - void 0, - /*writeFile*/ - void 0, - /*cancellationToken*/ - void 0, - /*emitOnlyDtsFiles*/ - void 0, - transpileOptions.transformers - ); - if (outputText === void 0) - return Debug.fail("Output generation failed"); - return { outputText, diagnostics, sourceMapText }; } - function transpile(input, compilerOptions, fileName, diagnostics, moduleName) { - const output = transpileModule(input, { compilerOptions, fileName, reportDiagnostics: !!diagnostics, moduleName }); - addRange(diagnostics, output.diagnostics); - return output.outputText; + function getOverloadRangeToMove(sourceFile, statement) { + if (isFunctionLikeDeclaration(statement)) { + const declarations = statement.symbol.declarations; + if (declarations === void 0 || length(declarations) <= 1 || !contains(declarations, statement)) { + return void 0; + } + const firstDecl = declarations[0]; + const lastDecl = declarations[length(declarations) - 1]; + const statementsToMove = mapDefined(declarations, (d) => getSourceFileOfNode(d) === sourceFile && isStatement(d) ? d : void 0); + const end = findIndex(sourceFile.statements, (s) => s.end >= lastDecl.end); + const start = findIndex(sourceFile.statements, (s) => s.end >= firstDecl.end); + return { toMove: statementsToMove, start, end }; + } + return void 0; } - function fixupCompilerOptions(options, diagnostics) { - commandLineOptionsStringToEnum = commandLineOptionsStringToEnum || filter(optionDeclarations, (o) => typeof o.type === "object" && !forEachEntry(o.type, (v) => typeof v !== "number")); - options = cloneCompilerOptions(options); - for (const opt of commandLineOptionsStringToEnum) { - if (!hasProperty(options, opt.name)) { - continue; + function getExistingImports(sourceFile, checker) { + const imports = /* @__PURE__ */ new Set(); + for (const moduleSpecifier of sourceFile.imports) { + const declaration = importFromModuleSpecifier(moduleSpecifier); + if (isImportDeclaration(declaration) && declaration.importClause && declaration.importClause.namedBindings && isNamedImports(declaration.importClause.namedBindings)) { + for (const e of declaration.importClause.namedBindings.elements) { + const symbol = checker.getSymbolAtLocation(e.propertyName || e.name); + if (symbol) { + imports.add(skipAlias(symbol, checker)); + } + } } - const value = options[opt.name]; - if (isString(value)) { - options[opt.name] = parseCustomTypeOption(opt, value, diagnostics); - } else { - if (!forEachEntry(opt.type, (v) => v === value)) { - diagnostics.push(createCompilerDiagnosticForInvalidCustomType(opt)); + if (isVariableDeclarationInitializedToRequire(declaration.parent) && isObjectBindingPattern(declaration.parent.name)) { + for (const e of declaration.parent.name.elements) { + const symbol = checker.getSymbolAtLocation(e.propertyName || e.name); + if (symbol) { + imports.add(skipAlias(symbol, checker)); + } } } } - return options; + return imports; } - var optionsRedundantWithVerbatimModuleSyntax, commandLineOptionsStringToEnum; - var init_transpile = __esm({ - "src/services/transpile.ts"() { + var refactorNameForMoveToFile, description2, moveToFileAction; + var init_moveToFile = __esm({ + "src/services/refactors/moveToFile.ts"() { "use strict"; + init_moduleSpecifiers(); init_ts4(); - optionsRedundantWithVerbatimModuleSyntax = /* @__PURE__ */ new Set([ - "isolatedModules", - "preserveValueImports", - "importsNotUsedAsValues" - ]); + init_refactorProvider(); + refactorNameForMoveToFile = "Move to file"; + description2 = getLocaleSpecificMessage(Diagnostics.Move_to_file); + moveToFileAction = { + name: "Move to file", + description: description2, + kind: "refactor.move.file" + }; + registerRefactor(refactorNameForMoveToFile, { + kinds: [moveToFileAction.kind], + getAvailableActions: function getRefactorActionsToMoveToFile(context, interactiveRefactorArguments) { + const statements = getStatementsToMove(context); + if (!interactiveRefactorArguments) { + return emptyArray; + } + if (context.preferences.allowTextChangesInNewFiles && statements) { + return [{ name: refactorNameForMoveToFile, description: description2, actions: [moveToFileAction] }]; + } + if (context.preferences.provideRefactorNotApplicableReason) { + return [{ name: refactorNameForMoveToFile, description: description2, actions: [{ ...moveToFileAction, notApplicableReason: getLocaleSpecificMessage(Diagnostics.Selection_is_not_a_valid_statement_or_statements) }] }]; + } + return emptyArray; + }, + getEditsForAction: function getRefactorEditsToMoveToFile(context, actionName2, interactiveRefactorArguments) { + Debug.assert(actionName2 === refactorNameForMoveToFile, "Wrong refactor invoked"); + const statements = Debug.checkDefined(getStatementsToMove(context)); + const { host, program } = context; + Debug.assert(interactiveRefactorArguments, "No interactive refactor arguments available"); + const targetFile = interactiveRefactorArguments.targetFile; + if (hasJSFileExtension(targetFile) || hasTSFileExtension(targetFile)) { + if (host.fileExists(targetFile) && program.getSourceFile(targetFile) === void 0) { + return error(getLocaleSpecificMessage(Diagnostics.Cannot_move_statements_to_the_selected_file)); + } + const edits = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange4(context, context.file, interactiveRefactorArguments.targetFile, context.program, statements, t, context.host, context.preferences)); + return { edits, renameFilename: void 0, renameLocation: void 0 }; + } + return error(getLocaleSpecificMessage(Diagnostics.Cannot_move_to_file_selected_file_is_invalid)); + } + }); } }); - // src/services/navigateTo.ts - function getNavigateToItems(sourceFiles, checker, cancellationToken, searchValue, maxResultCount, excludeDtsFiles) { - const patternMatcher = createPatternMatcher(searchValue); - if (!patternMatcher) + // src/services/refactors/convertOverloadListToSingleSignature.ts + function getRefactorActionsToConvertOverloadsToOneSignature(context) { + const { file, startPosition, program } = context; + const info = getConvertableOverloadListAtPosition(file, startPosition, program); + if (!info) return emptyArray; - const rawItems = []; - for (const sourceFile of sourceFiles) { - cancellationToken.throwIfCancellationRequested(); - if (excludeDtsFiles && sourceFile.isDeclarationFile) { - continue; + return [{ + name: refactorName6, + description: refactorDescription2, + actions: [functionOverloadAction] + }]; + } + function getRefactorEditsToConvertOverloadsToOneSignature(context) { + const { file, startPosition, program } = context; + const signatureDecls = getConvertableOverloadListAtPosition(file, startPosition, program); + if (!signatureDecls) + return void 0; + const checker = program.getTypeChecker(); + const lastDeclaration = signatureDecls[signatureDecls.length - 1]; + let updated = lastDeclaration; + switch (lastDeclaration.kind) { + case 173 /* MethodSignature */: { + updated = factory.updateMethodSignature( + lastDeclaration, + lastDeclaration.modifiers, + lastDeclaration.name, + lastDeclaration.questionToken, + lastDeclaration.typeParameters, + getNewParametersForCombinedSignature(signatureDecls), + lastDeclaration.type + ); + break; } - sourceFile.getNamedDeclarations().forEach((declarations, name) => { - getItemsFromNamedDeclaration(patternMatcher, name, declarations, checker, sourceFile.fileName, rawItems); - }); + case 174 /* MethodDeclaration */: { + updated = factory.updateMethodDeclaration( + lastDeclaration, + lastDeclaration.modifiers, + lastDeclaration.asteriskToken, + lastDeclaration.name, + lastDeclaration.questionToken, + lastDeclaration.typeParameters, + getNewParametersForCombinedSignature(signatureDecls), + lastDeclaration.type, + lastDeclaration.body + ); + break; + } + case 179 /* CallSignature */: { + updated = factory.updateCallSignature( + lastDeclaration, + lastDeclaration.typeParameters, + getNewParametersForCombinedSignature(signatureDecls), + lastDeclaration.type + ); + break; + } + case 176 /* Constructor */: { + updated = factory.updateConstructorDeclaration( + lastDeclaration, + lastDeclaration.modifiers, + getNewParametersForCombinedSignature(signatureDecls), + lastDeclaration.body + ); + break; + } + case 180 /* ConstructSignature */: { + updated = factory.updateConstructSignature( + lastDeclaration, + lastDeclaration.typeParameters, + getNewParametersForCombinedSignature(signatureDecls), + lastDeclaration.type + ); + break; + } + case 262 /* FunctionDeclaration */: { + updated = factory.updateFunctionDeclaration( + lastDeclaration, + lastDeclaration.modifiers, + lastDeclaration.asteriskToken, + lastDeclaration.name, + lastDeclaration.typeParameters, + getNewParametersForCombinedSignature(signatureDecls), + lastDeclaration.type, + lastDeclaration.body + ); + break; + } + default: + return Debug.failBadSyntaxKind(lastDeclaration, "Unhandled signature kind in overload list conversion refactoring"); } - rawItems.sort(compareNavigateToItems); - return (maxResultCount === void 0 ? rawItems : rawItems.slice(0, maxResultCount)).map(createNavigateToItem); - } - function getItemsFromNamedDeclaration(patternMatcher, name, declarations, checker, fileName, rawItems) { - const match = patternMatcher.getMatchForLastSegmentOfPattern(name); - if (!match) { + if (updated === lastDeclaration) { return; } - for (const declaration of declarations) { - if (!shouldKeepItem(declaration, checker)) - continue; - if (patternMatcher.patternContainsDots) { - const fullMatch = patternMatcher.getFullMatch(getContainers(declaration), name); - if (fullMatch) { - rawItems.push({ name, fileName, matchKind: fullMatch.kind, isCaseSensitive: fullMatch.isCaseSensitive, declaration }); + const edits = ts_textChanges_exports.ChangeTracker.with(context, (t) => { + t.replaceNodeRange(file, signatureDecls[0], signatureDecls[signatureDecls.length - 1], updated); + }); + return { renameFilename: void 0, renameLocation: void 0, edits }; + function getNewParametersForCombinedSignature(signatureDeclarations) { + const lastSig = signatureDeclarations[signatureDeclarations.length - 1]; + if (isFunctionLikeDeclaration(lastSig) && lastSig.body) { + signatureDeclarations = signatureDeclarations.slice(0, signatureDeclarations.length - 1); + } + return factory.createNodeArray([ + factory.createParameterDeclaration( + /*modifiers*/ + void 0, + factory.createToken(26 /* DotDotDotToken */), + "args", + /*questionToken*/ + void 0, + factory.createUnionTypeNode(map(signatureDeclarations, convertSignatureParametersToTuple)) + ) + ]); + } + function convertSignatureParametersToTuple(decl) { + const members = map(decl.parameters, convertParameterToNamedTupleMember); + return setEmitFlags(factory.createTupleTypeNode(members), some(members, (m) => !!length(getSyntheticLeadingComments(m))) ? 0 /* None */ : 1 /* SingleLine */); + } + function convertParameterToNamedTupleMember(p) { + Debug.assert(isIdentifier(p.name)); + const result = setTextRange( + factory.createNamedTupleMember( + p.dotDotDotToken, + p.name, + p.questionToken, + p.type || factory.createKeywordTypeNode(133 /* AnyKeyword */) + ), + p + ); + const parameterDocComment = p.symbol && p.symbol.getDocumentationComment(checker); + if (parameterDocComment) { + const newComment = displayPartsToString(parameterDocComment); + if (newComment.length) { + setSyntheticLeadingComments(result, [{ + text: `* +${newComment.split("\n").map((c) => ` * ${c}`).join("\n")} + `, + kind: 3 /* MultiLineCommentTrivia */, + pos: -1, + end: -1, + hasTrailingNewLine: true, + hasLeadingNewline: true + }]); } - } else { - rawItems.push({ name, fileName, matchKind: match.kind, isCaseSensitive: match.isCaseSensitive, declaration }); } + return result; } } - function shouldKeepItem(declaration, checker) { - switch (declaration.kind) { - case 272 /* ImportClause */: - case 275 /* ImportSpecifier */: - case 270 /* ImportEqualsDeclaration */: - const importer = checker.getSymbolAtLocation(declaration.name); - const imported = checker.getAliasedSymbol(importer); - return importer.escapedName !== imported.escapedName; - default: + function isConvertableSignatureDeclaration(d) { + switch (d.kind) { + case 173 /* MethodSignature */: + case 174 /* MethodDeclaration */: + case 179 /* CallSignature */: + case 176 /* Constructor */: + case 180 /* ConstructSignature */: + case 262 /* FunctionDeclaration */: return true; } + return false; } - function tryAddSingleDeclarationName(declaration, containers) { - const name = getNameOfDeclaration(declaration); - return !!name && (pushLiteral(name, containers) || name.kind === 166 /* ComputedPropertyName */ && tryAddComputedPropertyName(name.expression, containers)); - } - function tryAddComputedPropertyName(expression, containers) { - return pushLiteral(expression, containers) || isPropertyAccessExpression(expression) && (containers.push(expression.name.text), true) && tryAddComputedPropertyName(expression.expression, containers); - } - function pushLiteral(node, containers) { - return isPropertyNameLiteral(node) && (containers.push(getTextOfIdentifierOrLiteral(node)), true); + function getConvertableOverloadListAtPosition(file, startPosition, program) { + const node = getTokenAtPosition(file, startPosition); + const containingDecl = findAncestor(node, isConvertableSignatureDeclaration); + if (!containingDecl) { + return; + } + if (isFunctionLikeDeclaration(containingDecl) && containingDecl.body && rangeContainsPosition(containingDecl.body, startPosition)) { + return; + } + const checker = program.getTypeChecker(); + const signatureSymbol = containingDecl.symbol; + if (!signatureSymbol) { + return; + } + const decls = signatureSymbol.declarations; + if (length(decls) <= 1) { + return; + } + if (!every(decls, (d) => getSourceFileOfNode(d) === file)) { + return; + } + if (!isConvertableSignatureDeclaration(decls[0])) { + return; + } + const kindOne = decls[0].kind; + if (!every(decls, (d) => d.kind === kindOne)) { + return; + } + const signatureDecls = decls; + if (some(signatureDecls, (d) => !!d.typeParameters || some(d.parameters, (p) => !!p.modifiers || !isIdentifier(p.name)))) { + return; + } + const signatures = mapDefined(signatureDecls, (d) => checker.getSignatureFromDeclaration(d)); + if (length(signatures) !== length(decls)) { + return; + } + const returnOne = checker.getReturnTypeOfSignature(signatures[0]); + if (!every(signatures, (s) => checker.getReturnTypeOfSignature(s) === returnOne)) { + return; + } + return signatureDecls; } - function getContainers(declaration) { - const containers = []; - const name = getNameOfDeclaration(declaration); - if (name && name.kind === 166 /* ComputedPropertyName */ && !tryAddComputedPropertyName(name.expression, containers)) { + var refactorName6, refactorDescription2, functionOverloadAction; + var init_convertOverloadListToSingleSignature = __esm({ + "src/services/refactors/convertOverloadListToSingleSignature.ts"() { + "use strict"; + init_ts4(); + init_ts_refactor(); + refactorName6 = "Convert overload list to single signature"; + refactorDescription2 = getLocaleSpecificMessage(Diagnostics.Convert_overload_list_to_single_signature); + functionOverloadAction = { + name: refactorName6, + description: refactorDescription2, + kind: "refactor.rewrite.function.overloadList" + }; + registerRefactor(refactorName6, { + kinds: [functionOverloadAction.kind], + getEditsForAction: getRefactorEditsToConvertOverloadsToOneSignature, + getAvailableActions: getRefactorActionsToConvertOverloadsToOneSignature + }); + } + }); + + // src/services/refactors/addOrRemoveBracesToArrowFunction.ts + function getRefactorActionsToRemoveFunctionBraces(context) { + const { file, startPosition, triggerReason } = context; + const info = getConvertibleArrowFunctionAtPosition(file, startPosition, triggerReason === "invoked"); + if (!info) return emptyArray; + if (!isRefactorErrorInfo(info)) { + return [{ + name: refactorName7, + description: refactorDescription3, + actions: [ + info.addBraces ? addBracesAction : removeBracesAction + ] + }]; } - containers.shift(); - let container = getContainerNode(declaration); - while (container) { - if (!tryAddSingleDeclarationName(container, containers)) { - return emptyArray; - } - container = getContainerNode(container); + if (context.preferences.provideRefactorNotApplicableReason) { + return [{ + name: refactorName7, + description: refactorDescription3, + actions: [ + { ...addBracesAction, notApplicableReason: info.error }, + { ...removeBracesAction, notApplicableReason: info.error } + ] + }]; } - return containers.reverse(); + return emptyArray; } - function compareNavigateToItems(i1, i2) { - return compareValues(i1.matchKind, i2.matchKind) || compareStringsCaseSensitiveUI(i1.name, i2.name); + function getRefactorEditsToRemoveFunctionBraces(context, actionName2) { + const { file, startPosition } = context; + const info = getConvertibleArrowFunctionAtPosition(file, startPosition); + Debug.assert(info && !isRefactorErrorInfo(info), "Expected applicable refactor info"); + const { expression, returnStatement, func } = info; + let body; + if (actionName2 === addBracesAction.name) { + const returnStatement2 = factory.createReturnStatement(expression); + body = factory.createBlock( + [returnStatement2], + /*multiLine*/ + true + ); + copyLeadingComments( + expression, + returnStatement2, + file, + 3 /* MultiLineCommentTrivia */, + /*hasTrailingNewLine*/ + true + ); + } else if (actionName2 === removeBracesAction.name && returnStatement) { + const actualExpression = expression || factory.createVoidZero(); + body = needsParentheses(actualExpression) ? factory.createParenthesizedExpression(actualExpression) : actualExpression; + copyTrailingAsLeadingComments( + returnStatement, + body, + file, + 3 /* MultiLineCommentTrivia */, + /*hasTrailingNewLine*/ + false + ); + copyLeadingComments( + returnStatement, + body, + file, + 3 /* MultiLineCommentTrivia */, + /*hasTrailingNewLine*/ + false + ); + copyTrailingComments( + returnStatement, + body, + file, + 3 /* MultiLineCommentTrivia */, + /*hasTrailingNewLine*/ + false + ); + } else { + Debug.fail("invalid action"); + } + const edits = ts_textChanges_exports.ChangeTracker.with(context, (t) => { + t.replaceNode(file, func.body, body); + }); + return { renameFilename: void 0, renameLocation: void 0, edits }; } - function createNavigateToItem(rawItem) { - const declaration = rawItem.declaration; - const container = getContainerNode(declaration); - const containerName = container && getNameOfDeclaration(container); - return { - name: rawItem.name, - kind: getNodeKind(declaration), - kindModifiers: getNodeModifiers(declaration), - matchKind: PatternMatchKind[rawItem.matchKind], - isCaseSensitive: rawItem.isCaseSensitive, - fileName: rawItem.fileName, - textSpan: createTextSpanFromNode(declaration), - // TODO(jfreeman): What should be the containerName when the container has a computed name? - containerName: containerName ? containerName.text : "", - containerKind: containerName ? getNodeKind(container) : "" /* unknown */ - }; + function getConvertibleArrowFunctionAtPosition(file, startPosition, considerFunctionBodies = true, kind) { + const node = getTokenAtPosition(file, startPosition); + const func = getContainingFunction(node); + if (!func) { + return { + error: getLocaleSpecificMessage(Diagnostics.Could_not_find_a_containing_arrow_function) + }; + } + if (!isArrowFunction(func)) { + return { + error: getLocaleSpecificMessage(Diagnostics.Containing_function_is_not_an_arrow_function) + }; + } + if (!rangeContainsRange(func, node) || rangeContainsRange(func.body, node) && !considerFunctionBodies) { + return void 0; + } + if (refactorKindBeginsWith(addBracesAction.kind, kind) && isExpression(func.body)) { + return { func, addBraces: true, expression: func.body }; + } else if (refactorKindBeginsWith(removeBracesAction.kind, kind) && isBlock(func.body) && func.body.statements.length === 1) { + const firstStatement = first(func.body.statements); + if (isReturnStatement(firstStatement)) { + const expression = firstStatement.expression && isObjectLiteralExpression(getLeftmostExpression( + firstStatement.expression, + /*stopAtCallExpressions*/ + false + )) ? factory.createParenthesizedExpression(firstStatement.expression) : firstStatement.expression; + return { func, addBraces: false, expression, returnStatement: firstStatement }; + } + } + return void 0; } - var init_navigateTo = __esm({ - "src/services/navigateTo.ts"() { + var refactorName7, refactorDescription3, addBracesAction, removeBracesAction; + var init_addOrRemoveBracesToArrowFunction = __esm({ + "src/services/refactors/addOrRemoveBracesToArrowFunction.ts"() { "use strict"; init_ts4(); + init_ts_refactor(); + refactorName7 = "Add or remove braces in an arrow function"; + refactorDescription3 = getLocaleSpecificMessage(Diagnostics.Add_or_remove_braces_in_an_arrow_function); + addBracesAction = { + name: "Add braces to arrow function", + description: getLocaleSpecificMessage(Diagnostics.Add_braces_to_arrow_function), + kind: "refactor.rewrite.arrow.braces.add" + }; + removeBracesAction = { + name: "Remove braces from arrow function", + description: getLocaleSpecificMessage(Diagnostics.Remove_braces_from_arrow_function), + kind: "refactor.rewrite.arrow.braces.remove" + }; + registerRefactor(refactorName7, { + kinds: [removeBracesAction.kind], + getEditsForAction: getRefactorEditsToRemoveFunctionBraces, + getAvailableActions: getRefactorActionsToRemoveFunctionBraces + }); } }); - // src/services/_namespaces/ts.NavigateTo.ts - var ts_NavigateTo_exports = {}; - __export(ts_NavigateTo_exports, { - getNavigateToItems: () => getNavigateToItems - }); - var init_ts_NavigateTo = __esm({ - "src/services/_namespaces/ts.NavigateTo.ts"() { + // src/services/_namespaces/ts.refactor.addOrRemoveBracesToArrowFunction.ts + var ts_refactor_addOrRemoveBracesToArrowFunction_exports = {}; + var init_ts_refactor_addOrRemoveBracesToArrowFunction = __esm({ + "src/services/_namespaces/ts.refactor.addOrRemoveBracesToArrowFunction.ts"() { "use strict"; - init_navigateTo(); + init_convertOverloadListToSingleSignature(); + init_addOrRemoveBracesToArrowFunction(); } }); - // src/services/navigationBar.ts - function getNavigationBarItems(sourceFile, cancellationToken) { - curCancellationToken = cancellationToken; - curSourceFile = sourceFile; - try { - return map(primaryNavBarMenuItems(rootNavigationBarNode(sourceFile)), convertToPrimaryNavBarMenuItem); - } finally { - reset(); + // src/services/refactors/convertArrowFunctionOrFunctionExpression.ts + function getRefactorActionsToConvertFunctionExpressions(context) { + const { file, startPosition, program, kind } = context; + const info = getFunctionInfo(file, startPosition, program); + if (!info) + return emptyArray; + const { selectedVariableDeclaration, func } = info; + const possibleActions = []; + const errors = []; + if (refactorKindBeginsWith(toNamedFunctionAction.kind, kind)) { + const error2 = selectedVariableDeclaration || isArrowFunction(func) && isVariableDeclaration(func.parent) ? void 0 : getLocaleSpecificMessage(Diagnostics.Could_not_convert_to_named_function); + if (error2) { + errors.push({ ...toNamedFunctionAction, notApplicableReason: error2 }); + } else { + possibleActions.push(toNamedFunctionAction); + } + } + if (refactorKindBeginsWith(toAnonymousFunctionAction.kind, kind)) { + const error2 = !selectedVariableDeclaration && isArrowFunction(func) ? void 0 : getLocaleSpecificMessage(Diagnostics.Could_not_convert_to_anonymous_function); + if (error2) { + errors.push({ ...toAnonymousFunctionAction, notApplicableReason: error2 }); + } else { + possibleActions.push(toAnonymousFunctionAction); + } + } + if (refactorKindBeginsWith(toArrowFunctionAction.kind, kind)) { + const error2 = isFunctionExpression(func) ? void 0 : getLocaleSpecificMessage(Diagnostics.Could_not_convert_to_arrow_function); + if (error2) { + errors.push({ ...toArrowFunctionAction, notApplicableReason: error2 }); + } else { + possibleActions.push(toArrowFunctionAction); + } } + return [{ + name: refactorName8, + description: refactorDescription4, + actions: possibleActions.length === 0 && context.preferences.provideRefactorNotApplicableReason ? errors : possibleActions + }]; } - function getNavigationTree(sourceFile, cancellationToken) { - curCancellationToken = cancellationToken; - curSourceFile = sourceFile; - try { - return convertToTree(rootNavigationBarNode(sourceFile)); - } finally { - reset(); + function getRefactorEditsToConvertFunctionExpressions(context, actionName2) { + const { file, startPosition, program } = context; + const info = getFunctionInfo(file, startPosition, program); + if (!info) + return void 0; + const { func } = info; + const edits = []; + switch (actionName2) { + case toAnonymousFunctionAction.name: + edits.push(...getEditInfoForConvertToAnonymousFunction(context, func)); + break; + case toNamedFunctionAction.name: + const variableInfo = getVariableInfo(func); + if (!variableInfo) + return void 0; + edits.push(...getEditInfoForConvertToNamedFunction(context, func, variableInfo)); + break; + case toArrowFunctionAction.name: + if (!isFunctionExpression(func)) + return void 0; + edits.push(...getEditInfoForConvertToArrowFunction(context, func)); + break; + default: + return Debug.fail("invalid action"); } + return { renameFilename: void 0, renameLocation: void 0, edits }; } - function reset() { - curSourceFile = void 0; - curCancellationToken = void 0; - parentsStack = []; - parent = void 0; - emptyChildItemArray = []; + function containingThis(node) { + let containsThis = false; + node.forEachChild(function checkThis(child) { + if (isThis(child)) { + containsThis = true; + return; + } + if (!isClassLike(child) && !isFunctionDeclaration(child) && !isFunctionExpression(child)) { + forEachChild(child, checkThis); + } + }); + return containsThis; } - function nodeText(node) { - return cleanText(node.getText(curSourceFile)); + function getFunctionInfo(file, startPosition, program) { + const token = getTokenAtPosition(file, startPosition); + const typeChecker = program.getTypeChecker(); + const func = tryGetFunctionFromVariableDeclaration(file, typeChecker, token.parent); + if (func && !containingThis(func.body) && !typeChecker.containsArgumentsReference(func)) { + return { selectedVariableDeclaration: true, func }; + } + const maybeFunc = getContainingFunction(token); + if (maybeFunc && (isFunctionExpression(maybeFunc) || isArrowFunction(maybeFunc)) && !rangeContainsRange(maybeFunc.body, token) && !containingThis(maybeFunc.body) && !typeChecker.containsArgumentsReference(maybeFunc)) { + if (isFunctionExpression(maybeFunc) && isFunctionReferencedInFile(file, typeChecker, maybeFunc)) + return void 0; + return { selectedVariableDeclaration: false, func: maybeFunc }; + } + return void 0; } - function navigationBarNodeKind(n) { - return n.node.kind; + function isSingleVariableDeclaration(parent2) { + return isVariableDeclaration(parent2) || isVariableDeclarationList(parent2) && parent2.declarations.length === 1; } - function pushChild(parent2, child) { - if (parent2.children) { - parent2.children.push(child); - } else { - parent2.children = [child]; + function tryGetFunctionFromVariableDeclaration(sourceFile, typeChecker, parent2) { + if (!isSingleVariableDeclaration(parent2)) { + return void 0; + } + const variableDeclaration = isVariableDeclaration(parent2) ? parent2 : first(parent2.declarations); + const initializer = variableDeclaration.initializer; + if (initializer && (isArrowFunction(initializer) || isFunctionExpression(initializer) && !isFunctionReferencedInFile(sourceFile, typeChecker, initializer))) { + return initializer; } + return void 0; } - function rootNavigationBarNode(sourceFile) { - Debug.assert(!parentsStack.length); - const root = { node: sourceFile, name: void 0, additionalNodes: void 0, parent: void 0, children: void 0, indent: 0 }; - parent = root; - for (const statement of sourceFile.statements) { - addChildrenRecursively(statement); + function convertToBlock(body) { + if (isExpression(body)) { + const returnStatement = factory.createReturnStatement(body); + const file = body.getSourceFile(); + setTextRange(returnStatement, body); + suppressLeadingAndTrailingTrivia(returnStatement); + copyTrailingAsLeadingComments( + body, + returnStatement, + file, + /*commentKind*/ + void 0, + /*hasTrailingNewLine*/ + true + ); + return factory.createBlock( + [returnStatement], + /*multiLine*/ + true + ); + } else { + return body; } - endNode(); - Debug.assert(!parent && !parentsStack.length); - return root; } - function addLeafNode(node, name) { - pushChild(parent, emptyNavigationBarNode(node, name)); + function getVariableInfo(func) { + const variableDeclaration = func.parent; + if (!isVariableDeclaration(variableDeclaration) || !isVariableDeclarationInVariableStatement(variableDeclaration)) + return void 0; + const variableDeclarationList = variableDeclaration.parent; + const statement = variableDeclarationList.parent; + if (!isVariableDeclarationList(variableDeclarationList) || !isVariableStatement(statement) || !isIdentifier(variableDeclaration.name)) + return void 0; + return { variableDeclaration, variableDeclarationList, statement, name: variableDeclaration.name }; } - function emptyNavigationBarNode(node, name) { - return { - node, - name: name || (isDeclaration(node) || isExpression(node) ? getNameOfDeclaration(node) : void 0), - additionalNodes: void 0, - parent, - children: void 0, - indent: parent.indent + 1 - }; + function getEditInfoForConvertToAnonymousFunction(context, func) { + const { file } = context; + const body = convertToBlock(func.body); + const newNode = factory.createFunctionExpression( + func.modifiers, + func.asteriskToken, + /*name*/ + void 0, + func.typeParameters, + func.parameters, + func.type, + body + ); + return ts_textChanges_exports.ChangeTracker.with(context, (t) => t.replaceNode(file, func, newNode)); } - function addTrackedEs5Class(name) { - if (!trackedEs5Classes) { - trackedEs5Classes = /* @__PURE__ */ new Map(); + function getEditInfoForConvertToNamedFunction(context, func, variableInfo) { + const { file } = context; + const body = convertToBlock(func.body); + const { variableDeclaration, variableDeclarationList, statement, name } = variableInfo; + suppressLeadingTrivia(statement); + const modifiersFlags = getCombinedModifierFlags(variableDeclaration) & 32 /* Export */ | getEffectiveModifierFlags(func); + const modifiers = factory.createModifiersFromModifierFlags(modifiersFlags); + const newNode = factory.createFunctionDeclaration(length(modifiers) ? modifiers : void 0, func.asteriskToken, name, func.typeParameters, func.parameters, func.type, body); + if (variableDeclarationList.declarations.length === 1) { + return ts_textChanges_exports.ChangeTracker.with(context, (t) => t.replaceNode(file, statement, newNode)); + } else { + return ts_textChanges_exports.ChangeTracker.with(context, (t) => { + t.delete(file, variableDeclaration); + t.insertNodeAfter(file, statement, newNode); + }); } - trackedEs5Classes.set(name, true); - } - function endNestedNodes(depth) { - for (let i = 0; i < depth; i++) - endNode(); } - function startNestedNodes(targetNode, entityName) { - const names = []; - while (!isPropertyNameLiteral(entityName)) { - const name = getNameOrArgument(entityName); - const nameText = getElementOrPropertyAccessName(entityName); - entityName = entityName.expression; - if (nameText === "prototype" || isPrivateIdentifier(name)) - continue; - names.push(name); - } - names.push(entityName); - for (let i = names.length - 1; i > 0; i--) { - const name = names[i]; - startNode(targetNode, name); + function getEditInfoForConvertToArrowFunction(context, func) { + const { file } = context; + const statements = func.body.statements; + const head = statements[0]; + let body; + if (canBeConvertedToExpression(func.body, head)) { + body = head.expression; + suppressLeadingAndTrailingTrivia(body); + copyComments(head, body); + } else { + body = func.body; } - return [names.length - 1, names[0]]; - } - function startNode(node, name) { - const navNode = emptyNavigationBarNode(node, name); - pushChild(parent, navNode); - parentsStack.push(parent); - trackedEs5ClassesStack.push(trackedEs5Classes); - trackedEs5Classes = void 0; - parent = navNode; + const newNode = factory.createArrowFunction(func.modifiers, func.typeParameters, func.parameters, func.type, factory.createToken(39 /* EqualsGreaterThanToken */), body); + return ts_textChanges_exports.ChangeTracker.with(context, (t) => t.replaceNode(file, func, newNode)); } - function endNode() { - if (parent.children) { - mergeChildren(parent.children, parent); - sortChildren(parent.children); - } - parent = parentsStack.pop(); - trackedEs5Classes = trackedEs5ClassesStack.pop(); + function canBeConvertedToExpression(body, head) { + return body.statements.length === 1 && (isReturnStatement(head) && !!head.expression); } - function addNodeWithRecursiveChild(node, child, name) { - startNode(node, name); - addChildrenRecursively(child); - endNode(); + function isFunctionReferencedInFile(sourceFile, typeChecker, node) { + return !!node.name && ts_FindAllReferences_exports.Core.isSymbolReferencedInFile(node.name, typeChecker, sourceFile); } - function addNodeWithRecursiveInitializer(node) { - if (node.initializer && isFunctionOrClassExpression(node.initializer)) { - startNode(node); - forEachChild(node.initializer, addChildrenRecursively); - endNode(); - } else { - addNodeWithRecursiveChild(node, node.initializer); + var refactorName8, refactorDescription4, toAnonymousFunctionAction, toNamedFunctionAction, toArrowFunctionAction; + var init_convertArrowFunctionOrFunctionExpression = __esm({ + "src/services/refactors/convertArrowFunctionOrFunctionExpression.ts"() { + "use strict"; + init_ts4(); + init_ts_refactor(); + refactorName8 = "Convert arrow function or function expression"; + refactorDescription4 = getLocaleSpecificMessage(Diagnostics.Convert_arrow_function_or_function_expression); + toAnonymousFunctionAction = { + name: "Convert to anonymous function", + description: getLocaleSpecificMessage(Diagnostics.Convert_to_anonymous_function), + kind: "refactor.rewrite.function.anonymous" + }; + toNamedFunctionAction = { + name: "Convert to named function", + description: getLocaleSpecificMessage(Diagnostics.Convert_to_named_function), + kind: "refactor.rewrite.function.named" + }; + toArrowFunctionAction = { + name: "Convert to arrow function", + description: getLocaleSpecificMessage(Diagnostics.Convert_to_arrow_function), + kind: "refactor.rewrite.function.arrow" + }; + registerRefactor(refactorName8, { + kinds: [ + toAnonymousFunctionAction.kind, + toNamedFunctionAction.kind, + toArrowFunctionAction.kind + ], + getEditsForAction: getRefactorEditsToConvertFunctionExpressions, + getAvailableActions: getRefactorActionsToConvertFunctionExpressions + }); + } + }); + + // src/services/_namespaces/ts.refactor.convertArrowFunctionOrFunctionExpression.ts + var ts_refactor_convertArrowFunctionOrFunctionExpression_exports = {}; + var init_ts_refactor_convertArrowFunctionOrFunctionExpression = __esm({ + "src/services/_namespaces/ts.refactor.convertArrowFunctionOrFunctionExpression.ts"() { + "use strict"; + init_convertArrowFunctionOrFunctionExpression(); } + }); + + // src/services/refactors/convertParamsToDestructuredObject.ts + function getRefactorActionsToConvertParametersToDestructuredObject(context) { + const { file, startPosition } = context; + const isJSFile = isSourceFileJS(file); + if (isJSFile) + return emptyArray; + const functionDeclaration = getFunctionDeclarationAtPosition(file, startPosition, context.program.getTypeChecker()); + if (!functionDeclaration) + return emptyArray; + return [{ + name: refactorName9, + description: refactorDescription5, + actions: [toDestructuredAction] + }]; } - function hasNavigationBarName(node) { - return !hasDynamicName(node) || node.kind !== 225 /* BinaryExpression */ && isPropertyAccessExpression(node.name.expression) && isIdentifier(node.name.expression.expression) && idText(node.name.expression.expression) === "Symbol"; + function getRefactorEditsToConvertParametersToDestructuredObject(context, actionName2) { + Debug.assert(actionName2 === refactorName9, "Unexpected action name"); + const { file, startPosition, program, cancellationToken, host } = context; + const functionDeclaration = getFunctionDeclarationAtPosition(file, startPosition, program.getTypeChecker()); + if (!functionDeclaration || !cancellationToken) + return void 0; + const groupedReferences = getGroupedReferences(functionDeclaration, program, cancellationToken); + if (groupedReferences.valid) { + const edits = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange5(file, program, host, t, functionDeclaration, groupedReferences)); + return { renameFilename: void 0, renameLocation: void 0, edits }; + } + return { edits: [] }; } - function addChildrenRecursively(node) { - curCancellationToken.throwIfCancellationRequested(); - if (!node || isToken(node)) { - return; + function doChange5(sourceFile, program, host, changes, functionDeclaration, groupedReferences) { + const signature = groupedReferences.signature; + const newFunctionDeclarationParams = map(createNewParameters(functionDeclaration, program, host), (param) => getSynthesizedDeepClone(param)); + if (signature) { + const newSignatureParams = map(createNewParameters(signature, program, host), (param) => getSynthesizedDeepClone(param)); + replaceParameters(signature, newSignatureParams); } - switch (node.kind) { - case 175 /* Constructor */: - const ctr = node; - addNodeWithRecursiveChild(ctr, ctr.body); - for (const param of ctr.parameters) { - if (isParameterPropertyDeclaration(param, ctr)) { - addLeafNode(param); - } - } - break; - case 173 /* MethodDeclaration */: - case 176 /* GetAccessor */: - case 177 /* SetAccessor */: - case 172 /* MethodSignature */: - if (hasNavigationBarName(node)) { - addNodeWithRecursiveChild(node, node.body); - } - break; - case 171 /* PropertyDeclaration */: - if (hasNavigationBarName(node)) { - addNodeWithRecursiveInitializer(node); - } - break; - case 170 /* PropertySignature */: - if (hasNavigationBarName(node)) { - addLeafNode(node); - } - break; - case 272 /* ImportClause */: - const importClause = node; - if (importClause.name) { - addLeafNode(importClause.name); - } - const { namedBindings } = importClause; - if (namedBindings) { - if (namedBindings.kind === 273 /* NamespaceImport */) { - addLeafNode(namedBindings); - } else { - for (const element of namedBindings.elements) { - addLeafNode(element); - } - } - } - break; - case 303 /* ShorthandPropertyAssignment */: - addNodeWithRecursiveChild(node, node.name); - break; - case 304 /* SpreadAssignment */: - const { expression } = node; - isIdentifier(expression) ? addLeafNode(node, expression) : addLeafNode(node); - break; - case 207 /* BindingElement */: - case 302 /* PropertyAssignment */: - case 259 /* VariableDeclaration */: { - const child = node; - if (isBindingPattern(child.name)) { - addChildrenRecursively(child.name); - } else { - addNodeWithRecursiveInitializer(child); - } - break; + replaceParameters(functionDeclaration, newFunctionDeclarationParams); + const functionCalls = sortAndDeduplicate( + groupedReferences.functionCalls, + /*comparer*/ + (a, b) => compareValues(a.pos, b.pos) + ); + for (const call of functionCalls) { + if (call.arguments && call.arguments.length) { + const newArgument = getSynthesizedDeepClone( + createNewArgument(functionDeclaration, call.arguments), + /*includeTrivia*/ + true + ); + changes.replaceNodeRange( + getSourceFileOfNode(call), + first(call.arguments), + last(call.arguments), + newArgument, + { leadingTriviaOption: ts_textChanges_exports.LeadingTriviaOption.IncludeAll, trailingTriviaOption: ts_textChanges_exports.TrailingTriviaOption.Include } + ); } - case 261 /* FunctionDeclaration */: - const nameNode = node.name; - if (nameNode && isIdentifier(nameNode)) { - addTrackedEs5Class(nameNode.text); + } + function replaceParameters(declarationOrSignature, parameterDeclarations) { + changes.replaceNodeRangeWithNodes( + sourceFile, + first(declarationOrSignature.parameters), + last(declarationOrSignature.parameters), + parameterDeclarations, + { + joiner: ", ", + // indentation is set to 0 because otherwise the object parameter will be indented if there is a `this` parameter + indentation: 0, + leadingTriviaOption: ts_textChanges_exports.LeadingTriviaOption.IncludeAll, + trailingTriviaOption: ts_textChanges_exports.TrailingTriviaOption.Include + } + ); + } + } + function getGroupedReferences(functionDeclaration, program, cancellationToken) { + const functionNames = getFunctionNames(functionDeclaration); + const classNames = isConstructorDeclaration(functionDeclaration) ? getClassNames(functionDeclaration) : []; + const names = deduplicate([...functionNames, ...classNames], equateValues); + const checker = program.getTypeChecker(); + const references = flatMap( + names, + /*mapfn*/ + (name) => ts_FindAllReferences_exports.getReferenceEntriesForNode(-1, name, program, program.getSourceFiles(), cancellationToken) + ); + const groupedReferences = groupReferences(references); + if (!every( + groupedReferences.declarations, + /*callback*/ + (decl) => contains(names, decl) + )) { + groupedReferences.valid = false; + } + return groupedReferences; + function groupReferences(referenceEntries) { + const classReferences = { accessExpressions: [], typeUsages: [] }; + const groupedReferences2 = { functionCalls: [], declarations: [], classReferences, valid: true }; + const functionSymbols = map(functionNames, getSymbolTargetAtLocation); + const classSymbols = map(classNames, getSymbolTargetAtLocation); + const isConstructor = isConstructorDeclaration(functionDeclaration); + const contextualSymbols = map(functionNames, (name) => getSymbolForContextualType(name, checker)); + for (const entry of referenceEntries) { + if (entry.kind === ts_FindAllReferences_exports.EntryKind.Span) { + groupedReferences2.valid = false; + continue; } - addNodeWithRecursiveChild(node, node.body); - break; - case 218 /* ArrowFunction */: - case 217 /* FunctionExpression */: - addNodeWithRecursiveChild(node, node.body); - break; - case 265 /* EnumDeclaration */: - startNode(node); - for (const member of node.members) { - if (!isComputedProperty(member)) { - addLeafNode(member); + if (contains(contextualSymbols, getSymbolTargetAtLocation(entry.node))) { + if (isValidMethodSignature(entry.node.parent)) { + groupedReferences2.signature = entry.node.parent; + continue; + } + const call = entryToFunctionCall(entry); + if (call) { + groupedReferences2.functionCalls.push(call); + continue; } } - endNode(); - break; - case 262 /* ClassDeclaration */: - case 230 /* ClassExpression */: - case 263 /* InterfaceDeclaration */: - startNode(node); - for (const member of node.members) { - addChildrenRecursively(member); + const contextualSymbol = getSymbolForContextualType(entry.node, checker); + if (contextualSymbol && contains(contextualSymbols, contextualSymbol)) { + const decl = entryToDeclaration(entry); + if (decl) { + groupedReferences2.declarations.push(decl); + continue; + } } - endNode(); - break; - case 266 /* ModuleDeclaration */: - addNodeWithRecursiveChild(node, getInteriorModule(node).body); - break; - case 276 /* ExportAssignment */: { - const expression2 = node.expression; - const child = isObjectLiteralExpression(expression2) || isCallExpression(expression2) ? expression2 : isArrowFunction(expression2) || isFunctionExpression(expression2) ? expression2.body : void 0; - if (child) { - startNode(node); - addChildrenRecursively(child); - endNode(); - } else { - addLeafNode(node); + if (contains(functionSymbols, getSymbolTargetAtLocation(entry.node)) || isNewExpressionTarget(entry.node)) { + const importOrExportReference = entryToImportOrExport(entry); + if (importOrExportReference) { + continue; + } + const decl = entryToDeclaration(entry); + if (decl) { + groupedReferences2.declarations.push(decl); + continue; + } + const call = entryToFunctionCall(entry); + if (call) { + groupedReferences2.functionCalls.push(call); + continue; + } } - break; - } - case 280 /* ExportSpecifier */: - case 270 /* ImportEqualsDeclaration */: - case 180 /* IndexSignature */: - case 178 /* CallSignature */: - case 179 /* ConstructSignature */: - case 264 /* TypeAliasDeclaration */: - addLeafNode(node); - break; - case 212 /* CallExpression */: - case 225 /* BinaryExpression */: { - const special = getAssignmentDeclarationKind(node); - switch (special) { - case 1 /* ExportsProperty */: - case 2 /* ModuleExports */: - addNodeWithRecursiveChild(node, node.right); - return; - case 6 /* Prototype */: - case 3 /* PrototypeProperty */: { - const binaryExpression = node; - const assignmentTarget = binaryExpression.left; - const prototypeAccess = special === 3 /* PrototypeProperty */ ? assignmentTarget.expression : assignmentTarget; - let depth = 0; - let className; - if (isIdentifier(prototypeAccess.expression)) { - addTrackedEs5Class(prototypeAccess.expression.text); - className = prototypeAccess.expression; - } else { - [depth, className] = startNestedNodes(binaryExpression, prototypeAccess.expression); - } - if (special === 6 /* Prototype */) { - if (isObjectLiteralExpression(binaryExpression.right)) { - if (binaryExpression.right.properties.length > 0) { - startNode(binaryExpression, className); - forEachChild(binaryExpression.right, addChildrenRecursively); - endNode(); - } - } - } else if (isFunctionExpression(binaryExpression.right) || isArrowFunction(binaryExpression.right)) { - addNodeWithRecursiveChild( - node, - binaryExpression.right, - className - ); - } else { - startNode(binaryExpression, className); - addNodeWithRecursiveChild(node, binaryExpression.right, assignmentTarget.name); - endNode(); - } - endNestedNodes(depth); - return; + if (isConstructor && contains(classSymbols, getSymbolTargetAtLocation(entry.node))) { + const importOrExportReference = entryToImportOrExport(entry); + if (importOrExportReference) { + continue; } - case 7 /* ObjectDefinePropertyValue */: - case 9 /* ObjectDefinePrototypeProperty */: { - const defineCall = node; - const className = special === 7 /* ObjectDefinePropertyValue */ ? defineCall.arguments[0] : defineCall.arguments[0].expression; - const memberName = defineCall.arguments[1]; - const [depth, classNameIdentifier] = startNestedNodes(node, className); - startNode(node, classNameIdentifier); - startNode(node, setTextRange(factory.createIdentifier(memberName.text), memberName)); - addChildrenRecursively(node.arguments[2]); - endNode(); - endNode(); - endNestedNodes(depth); - return; + const decl = entryToDeclaration(entry); + if (decl) { + groupedReferences2.declarations.push(decl); + continue; } - case 5 /* Property */: { - const binaryExpression = node; - const assignmentTarget = binaryExpression.left; - const targetFunction = assignmentTarget.expression; - if (isIdentifier(targetFunction) && getElementOrPropertyAccessName(assignmentTarget) !== "prototype" && trackedEs5Classes && trackedEs5Classes.has(targetFunction.text)) { - if (isFunctionExpression(binaryExpression.right) || isArrowFunction(binaryExpression.right)) { - addNodeWithRecursiveChild(node, binaryExpression.right, targetFunction); - } else if (isBindableStaticAccessExpression(assignmentTarget)) { - startNode(binaryExpression, targetFunction); - addNodeWithRecursiveChild(binaryExpression.left, binaryExpression.right, getNameOrArgument(assignmentTarget)); - endNode(); - } - return; + const accessExpression = entryToAccessExpression(entry); + if (accessExpression) { + classReferences.accessExpressions.push(accessExpression); + continue; + } + if (isClassDeclaration(functionDeclaration.parent)) { + const type = entryToType(entry); + if (type) { + classReferences.typeUsages.push(type); + continue; } - break; } - case 4 /* ThisProperty */: - case 0 /* None */: - case 8 /* ObjectDefinePropertyExports */: - break; - default: - Debug.assertNever(special); } + groupedReferences2.valid = false; } - default: - if (hasJSDocNodes(node)) { - forEach(node.jsDoc, (jsDoc) => { - forEach(jsDoc.tags, (tag) => { - if (isJSDocTypeAlias(tag)) { - addLeafNode(tag); - } - }); - }); - } - forEachChild(node, addChildrenRecursively); + return groupedReferences2; + } + function getSymbolTargetAtLocation(node) { + const symbol = checker.getSymbolAtLocation(node); + return symbol && getSymbolTarget(symbol, checker); } } - function mergeChildren(children, node) { - const nameToItems = /* @__PURE__ */ new Map(); - filterMutate(children, (child, index) => { - const declName = child.name || getNameOfDeclaration(child.node); - const name = declName && nodeText(declName); - if (!name) { - return true; - } - const itemsWithSameName = nameToItems.get(name); - if (!itemsWithSameName) { - nameToItems.set(name, child); - return true; - } - if (itemsWithSameName instanceof Array) { - for (const itemWithSameName of itemsWithSameName) { - if (tryMerge(itemWithSameName, child, index, node)) { - return false; - } - } - itemsWithSameName.push(child); - return true; - } else { - const itemWithSameName = itemsWithSameName; - if (tryMerge(itemWithSameName, child, index, node)) { - return false; - } - nameToItems.set(name, [itemWithSameName, child]); - return true; + function getSymbolForContextualType(node, checker) { + const element = getContainingObjectLiteralElement(node); + if (element) { + const contextualType = checker.getContextualTypeForObjectLiteralElement(element); + const symbol = contextualType == null ? void 0 : contextualType.getSymbol(); + if (symbol && !(getCheckFlags(symbol) & 6 /* Synthetic */)) { + return symbol; } - }); + } } - function tryMergeEs5Class(a, b, bIndex, parent2) { - function isPossibleConstructor(node) { - return isFunctionExpression(node) || isFunctionDeclaration(node) || isVariableDeclaration(node); + function entryToImportOrExport(entry) { + const node = entry.node; + if (isImportSpecifier(node.parent) || isImportClause(node.parent) || isImportEqualsDeclaration(node.parent) || isNamespaceImport(node.parent)) { + return node; } - const bAssignmentDeclarationKind = isBinaryExpression(b.node) || isCallExpression(b.node) ? getAssignmentDeclarationKind(b.node) : 0 /* None */; - const aAssignmentDeclarationKind = isBinaryExpression(a.node) || isCallExpression(a.node) ? getAssignmentDeclarationKind(a.node) : 0 /* None */; - if (isEs5ClassMember[bAssignmentDeclarationKind] && isEs5ClassMember[aAssignmentDeclarationKind] || isPossibleConstructor(a.node) && isEs5ClassMember[bAssignmentDeclarationKind] || isPossibleConstructor(b.node) && isEs5ClassMember[aAssignmentDeclarationKind] || isClassDeclaration(a.node) && isSynthesized(a.node) && isEs5ClassMember[bAssignmentDeclarationKind] || isClassDeclaration(b.node) && isEs5ClassMember[aAssignmentDeclarationKind] || isClassDeclaration(a.node) && isSynthesized(a.node) && isPossibleConstructor(b.node) || isClassDeclaration(b.node) && isPossibleConstructor(a.node) && isSynthesized(a.node)) { - let lastANode = a.additionalNodes && lastOrUndefined(a.additionalNodes) || a.node; - if (!isClassDeclaration(a.node) && !isClassDeclaration(b.node) || isPossibleConstructor(a.node) || isPossibleConstructor(b.node)) { - const ctorFunction = isPossibleConstructor(a.node) ? a.node : isPossibleConstructor(b.node) ? b.node : void 0; - if (ctorFunction !== void 0) { - const ctorNode = setTextRange( - factory.createConstructorDeclaration( - /*modifiers*/ - void 0, - [], - /*body*/ - void 0 - ), - ctorFunction - ); - const ctor = emptyNavigationBarNode(ctorNode); - ctor.indent = a.indent + 1; - ctor.children = a.node === ctorFunction ? a.children : b.children; - a.children = a.node === ctorFunction ? concatenate([ctor], b.children || [b]) : concatenate(a.children || [{ ...a }], [ctor]); - } else { - if (a.children || b.children) { - a.children = concatenate(a.children || [{ ...a }], b.children || [b]); - if (a.children) { - mergeChildren(a.children, a); - sortChildren(a.children); + if (isExportSpecifier(node.parent) || isExportAssignment(node.parent)) { + return node; + } + return void 0; + } + function entryToDeclaration(entry) { + if (isDeclaration(entry.node.parent)) { + return entry.node; + } + return void 0; + } + function entryToFunctionCall(entry) { + if (entry.node.parent) { + const functionReference = entry.node; + const parent2 = functionReference.parent; + switch (parent2.kind) { + case 213 /* CallExpression */: + case 214 /* NewExpression */: + const callOrNewExpression = tryCast(parent2, isCallOrNewExpression); + if (callOrNewExpression && callOrNewExpression.expression === functionReference) { + return callOrNewExpression; + } + break; + case 211 /* PropertyAccessExpression */: + const propertyAccessExpression = tryCast(parent2, isPropertyAccessExpression); + if (propertyAccessExpression && propertyAccessExpression.parent && propertyAccessExpression.name === functionReference) { + const callOrNewExpression2 = tryCast(propertyAccessExpression.parent, isCallOrNewExpression); + if (callOrNewExpression2 && callOrNewExpression2.expression === propertyAccessExpression) { + return callOrNewExpression2; } } - } - lastANode = a.node = setTextRange(factory.createClassDeclaration( - /*modifiers*/ - void 0, - a.name || factory.createIdentifier("__class__"), - /*typeParameters*/ - void 0, - /*heritageClauses*/ - void 0, - [] - ), a.node); - } else { - a.children = concatenate(a.children, b.children); - if (a.children) { - mergeChildren(a.children, a); - } + break; + case 212 /* ElementAccessExpression */: + const elementAccessExpression = tryCast(parent2, isElementAccessExpression); + if (elementAccessExpression && elementAccessExpression.parent && elementAccessExpression.argumentExpression === functionReference) { + const callOrNewExpression2 = tryCast(elementAccessExpression.parent, isCallOrNewExpression); + if (callOrNewExpression2 && callOrNewExpression2.expression === elementAccessExpression) { + return callOrNewExpression2; + } + } + break; } - const bNode = b.node; - if (parent2.children[bIndex - 1].node.end === lastANode.end) { - setTextRange(lastANode, { pos: lastANode.pos, end: bNode.end }); - } else { - if (!a.additionalNodes) - a.additionalNodes = []; - a.additionalNodes.push(setTextRange(factory.createClassDeclaration( - /*modifiers*/ - void 0, - a.name || factory.createIdentifier("__class__"), - /*typeParameters*/ - void 0, - /*heritageClauses*/ - void 0, - [] - ), b.node)); + } + return void 0; + } + function entryToAccessExpression(entry) { + if (entry.node.parent) { + const reference = entry.node; + const parent2 = reference.parent; + switch (parent2.kind) { + case 211 /* PropertyAccessExpression */: + const propertyAccessExpression = tryCast(parent2, isPropertyAccessExpression); + if (propertyAccessExpression && propertyAccessExpression.expression === reference) { + return propertyAccessExpression; + } + break; + case 212 /* ElementAccessExpression */: + const elementAccessExpression = tryCast(parent2, isElementAccessExpression); + if (elementAccessExpression && elementAccessExpression.expression === reference) { + return elementAccessExpression; + } + break; } - return true; } - return bAssignmentDeclarationKind === 0 /* None */ ? false : true; + return void 0; } - function tryMerge(a, b, bIndex, parent2) { - if (tryMergeEs5Class(a, b, bIndex, parent2)) { - return true; + function entryToType(entry) { + const reference = entry.node; + if (getMeaningFromLocation(reference) === 2 /* Type */ || isExpressionWithTypeArgumentsInClassExtendsClause(reference.parent)) { + return reference; } - if (shouldReallyMerge(a.node, b.node, parent2)) { - merge(a, b); - return true; + return void 0; + } + function getFunctionDeclarationAtPosition(file, startPosition, checker) { + const node = getTouchingToken(file, startPosition); + const functionDeclaration = getContainingFunctionDeclaration(node); + if (isTopLevelJSDoc(node)) + return void 0; + if (functionDeclaration && isValidFunctionDeclaration(functionDeclaration, checker) && rangeContainsRange(functionDeclaration, node) && !(functionDeclaration.body && rangeContainsRange(functionDeclaration.body, node))) + return functionDeclaration; + return void 0; + } + function isTopLevelJSDoc(node) { + const containingJSDoc = findAncestor(node, isJSDocNode); + if (containingJSDoc) { + const containingNonJSDoc = findAncestor(containingJSDoc, (n) => !isJSDocNode(n)); + return !!containingNonJSDoc && isFunctionLikeDeclaration(containingNonJSDoc); } return false; } - function shouldReallyMerge(a, b, parent2) { - if (a.kind !== b.kind || a.parent !== b.parent && !(isOwnChild(a, parent2) && isOwnChild(b, parent2))) { + function isValidMethodSignature(node) { + return isMethodSignature(node) && (isInterfaceDeclaration(node.parent) || isTypeLiteralNode(node.parent)); + } + function isValidFunctionDeclaration(functionDeclaration, checker) { + var _a; + if (!isValidParameterNodeArray(functionDeclaration.parameters, checker)) return false; + switch (functionDeclaration.kind) { + case 262 /* FunctionDeclaration */: + return hasNameOrDefault(functionDeclaration) && isSingleImplementation(functionDeclaration, checker); + case 174 /* MethodDeclaration */: + if (isObjectLiteralExpression(functionDeclaration.parent)) { + const contextualSymbol = getSymbolForContextualType(functionDeclaration.name, checker); + return ((_a = contextualSymbol == null ? void 0 : contextualSymbol.declarations) == null ? void 0 : _a.length) === 1 && isSingleImplementation(functionDeclaration, checker); + } + return isSingleImplementation(functionDeclaration, checker); + case 176 /* Constructor */: + if (isClassDeclaration(functionDeclaration.parent)) { + return hasNameOrDefault(functionDeclaration.parent) && isSingleImplementation(functionDeclaration, checker); + } else { + return isValidVariableDeclaration(functionDeclaration.parent.parent) && isSingleImplementation(functionDeclaration, checker); + } + case 218 /* FunctionExpression */: + case 219 /* ArrowFunction */: + return isValidVariableDeclaration(functionDeclaration.parent); } - switch (a.kind) { - case 171 /* PropertyDeclaration */: - case 173 /* MethodDeclaration */: - case 176 /* GetAccessor */: - case 177 /* SetAccessor */: - return isStatic(a) === isStatic(b); - case 266 /* ModuleDeclaration */: - return areSameModule(a, b) && getFullyQualifiedModuleName(a) === getFullyQualifiedModuleName(b); - default: - return true; - } - } - function isSynthesized(node) { - return !!(node.flags & 8 /* Synthesized */); + return false; } - function isOwnChild(n, parent2) { - const par = isModuleBlock(n.parent) ? n.parent.parent : n.parent; - return par === parent2.node || contains(parent2.additionalNodes, par); + function isSingleImplementation(functionDeclaration, checker) { + return !!functionDeclaration.body && !checker.isImplementationOfOverload(functionDeclaration); } - function areSameModule(a, b) { - if (!a.body || !b.body) { - return a.body === b.body; + function hasNameOrDefault(functionOrClassDeclaration) { + if (!functionOrClassDeclaration.name) { + const defaultKeyword = findModifier(functionOrClassDeclaration, 90 /* DefaultKeyword */); + return !!defaultKeyword; } - return a.body.kind === b.body.kind && (a.body.kind !== 266 /* ModuleDeclaration */ || areSameModule(a.body, b.body)); + return true; } - function merge(target, source) { - target.additionalNodes = target.additionalNodes || []; - target.additionalNodes.push(source.node); - if (source.additionalNodes) { - target.additionalNodes.push(...source.additionalNodes); - } - target.children = concatenate(target.children, source.children); - if (target.children) { - mergeChildren(target.children, target); - sortChildren(target.children); + function isValidParameterNodeArray(parameters, checker) { + return getRefactorableParametersLength(parameters) >= minimumParameterLength && every( + parameters, + /*callback*/ + (paramDecl) => isValidParameterDeclaration(paramDecl, checker) + ); + } + function isValidParameterDeclaration(parameterDeclaration, checker) { + if (isRestParameter(parameterDeclaration)) { + const type = checker.getTypeAtLocation(parameterDeclaration); + if (!checker.isArrayType(type) && !checker.isTupleType(type)) + return false; } + return !parameterDeclaration.modifiers && isIdentifier(parameterDeclaration.name); } - function sortChildren(children) { - children.sort(compareChildren); + function isValidVariableDeclaration(node) { + return isVariableDeclaration(node) && isVarConst(node) && isIdentifier(node.name) && !node.type; } - function compareChildren(child1, child2) { - return compareStringsCaseSensitiveUI(tryGetName(child1.node), tryGetName(child2.node)) || compareValues(navigationBarNodeKind(child1), navigationBarNodeKind(child2)); + function hasThisParameter(parameters) { + return parameters.length > 0 && isThis(parameters[0].name); } - function tryGetName(node) { - if (node.kind === 266 /* ModuleDeclaration */) { - return getModuleName(node); - } - const declName = getNameOfDeclaration(node); - if (declName && isPropertyName(declName)) { - const propertyName = getPropertyNameForPropertyNameNode(declName); - return propertyName && unescapeLeadingUnderscores(propertyName); - } - switch (node.kind) { - case 217 /* FunctionExpression */: - case 218 /* ArrowFunction */: - case 230 /* ClassExpression */: - return getFunctionOrClassName(node); - default: - return void 0; + function getRefactorableParametersLength(parameters) { + if (hasThisParameter(parameters)) { + return parameters.length - 1; } + return parameters.length; } - function getItemName(node, name) { - if (node.kind === 266 /* ModuleDeclaration */) { - return cleanText(getModuleName(node)); + function getRefactorableParameters(parameters) { + if (hasThisParameter(parameters)) { + parameters = factory.createNodeArray(parameters.slice(1), parameters.hasTrailingComma); } - if (name) { - const text = isIdentifier(name) ? name.text : isElementAccessExpression(name) ? `[${nodeText(name.argumentExpression)}]` : nodeText(name); - if (text.length > 0) { - return cleanText(text); - } + return parameters; + } + function createPropertyOrShorthandAssignment(name, initializer) { + if (isIdentifier(initializer) && getTextOfIdentifierOrLiteral(initializer) === name) { + return factory.createShorthandPropertyAssignment(name); } - switch (node.kind) { - case 311 /* SourceFile */: - const sourceFile = node; - return isExternalModule(sourceFile) ? `"${escapeString(getBaseFileName(removeFileExtension(normalizePath(sourceFile.fileName))))}"` : ""; - case 276 /* ExportAssignment */: - return isExportAssignment(node) && node.isExportEquals ? "export=" /* ExportEquals */ : "default" /* Default */; - case 218 /* ArrowFunction */: - case 261 /* FunctionDeclaration */: - case 217 /* FunctionExpression */: - case 262 /* ClassDeclaration */: - case 230 /* ClassExpression */: - if (getSyntacticModifierFlags(node) & 1024 /* Default */) { - return "default"; - } - return getFunctionOrClassName(node); - case 175 /* Constructor */: - return "constructor"; - case 179 /* ConstructSignature */: - return "new()"; - case 178 /* CallSignature */: - return "()"; - case 180 /* IndexSignature */: - return "[]"; - default: - return ""; + return factory.createPropertyAssignment(name, initializer); + } + function createNewArgument(functionDeclaration, functionArguments) { + const parameters = getRefactorableParameters(functionDeclaration.parameters); + const hasRestParameter2 = isRestParameter(last(parameters)); + const nonRestArguments = hasRestParameter2 ? functionArguments.slice(0, parameters.length - 1) : functionArguments; + const properties = map(nonRestArguments, (arg, i) => { + const parameterName = getParameterName(parameters[i]); + const property = createPropertyOrShorthandAssignment(parameterName, arg); + suppressLeadingAndTrailingTrivia(property.name); + if (isPropertyAssignment(property)) + suppressLeadingAndTrailingTrivia(property.initializer); + copyComments(arg, property); + return property; + }); + if (hasRestParameter2 && functionArguments.length >= parameters.length) { + const restArguments = functionArguments.slice(parameters.length - 1); + const restProperty = factory.createPropertyAssignment(getParameterName(last(parameters)), factory.createArrayLiteralExpression(restArguments)); + properties.push(restProperty); } + const objectLiteral = factory.createObjectLiteralExpression( + properties, + /*multiLine*/ + false + ); + return objectLiteral; } - function primaryNavBarMenuItems(root) { - const primaryNavBarMenuItems2 = []; - function recur(item) { - if (shouldAppearInPrimaryNavBarMenu(item)) { - primaryNavBarMenuItems2.push(item); - if (item.children) { - for (const child of item.children) { - recur(child); - } - } - } + function createNewParameters(functionDeclaration, program, host) { + const checker = program.getTypeChecker(); + const refactorableParameters = getRefactorableParameters(functionDeclaration.parameters); + const bindingElements = map(refactorableParameters, createBindingElementFromParameterDeclaration); + const objectParameterName = factory.createObjectBindingPattern(bindingElements); + const objectParameterType = createParameterTypeNode(refactorableParameters); + let objectInitializer; + if (every(refactorableParameters, isOptionalParameter)) { + objectInitializer = factory.createObjectLiteralExpression(); } - recur(root); - return primaryNavBarMenuItems2; - function shouldAppearInPrimaryNavBarMenu(item) { - if (item.children) { - return true; - } - switch (navigationBarNodeKind(item)) { - case 262 /* ClassDeclaration */: - case 230 /* ClassExpression */: - case 265 /* EnumDeclaration */: - case 263 /* InterfaceDeclaration */: - case 266 /* ModuleDeclaration */: - case 311 /* SourceFile */: - case 264 /* TypeAliasDeclaration */: - case 352 /* JSDocTypedefTag */: - case 344 /* JSDocCallbackTag */: - return true; - case 218 /* ArrowFunction */: - case 261 /* FunctionDeclaration */: - case 217 /* FunctionExpression */: - return isTopLevelFunctionDeclaration(item); - default: - return false; + const objectParameter = factory.createParameterDeclaration( + /*modifiers*/ + void 0, + /*dotDotDotToken*/ + void 0, + objectParameterName, + /*questionToken*/ + void 0, + objectParameterType, + objectInitializer + ); + if (hasThisParameter(functionDeclaration.parameters)) { + const thisParameter = functionDeclaration.parameters[0]; + const newThisParameter = factory.createParameterDeclaration( + /*modifiers*/ + void 0, + /*dotDotDotToken*/ + void 0, + thisParameter.name, + /*questionToken*/ + void 0, + thisParameter.type + ); + suppressLeadingAndTrailingTrivia(newThisParameter.name); + copyComments(thisParameter.name, newThisParameter.name); + if (thisParameter.type) { + suppressLeadingAndTrailingTrivia(newThisParameter.type); + copyComments(thisParameter.type, newThisParameter.type); } - function isTopLevelFunctionDeclaration(item2) { - if (!item2.node.body) { - return false; - } - switch (navigationBarNodeKind(item2.parent)) { - case 267 /* ModuleBlock */: - case 311 /* SourceFile */: - case 173 /* MethodDeclaration */: - case 175 /* Constructor */: - return true; - default: - return false; - } + return factory.createNodeArray([newThisParameter, objectParameter]); + } + return factory.createNodeArray([objectParameter]); + function createBindingElementFromParameterDeclaration(parameterDeclaration) { + const element = factory.createBindingElement( + /*dotDotDotToken*/ + void 0, + /*propertyName*/ + void 0, + getParameterName(parameterDeclaration), + isRestParameter(parameterDeclaration) && isOptionalParameter(parameterDeclaration) ? factory.createArrayLiteralExpression() : parameterDeclaration.initializer + ); + suppressLeadingAndTrailingTrivia(element); + if (parameterDeclaration.initializer && element.initializer) { + copyComments(parameterDeclaration.initializer, element.initializer); } + return element; } - } - function convertToTree(n) { - return { - text: getItemName(n.node, n.name), - kind: getNodeKind(n.node), - kindModifiers: getModifiers2(n.node), - spans: getSpans(n), - nameSpan: n.name && getNodeSpan(n.name), - childItems: map(n.children, convertToTree) - }; - } - function convertToPrimaryNavBarMenuItem(n) { - return { - text: getItemName(n.node, n.name), - kind: getNodeKind(n.node), - kindModifiers: getModifiers2(n.node), - spans: getSpans(n), - childItems: map(n.children, convertToSecondaryNavBarMenuItem) || emptyChildItemArray, - indent: n.indent, - bolded: false, - grayed: false - }; - function convertToSecondaryNavBarMenuItem(n2) { - return { - text: getItemName(n2.node, n2.name), - kind: getNodeKind(n2.node), - kindModifiers: getNodeModifiers(n2.node), - spans: getSpans(n2), - childItems: emptyChildItemArray, - indent: 0, - bolded: false, - grayed: false - }; + function createParameterTypeNode(parameters) { + const members = map(parameters, createPropertySignatureFromParameterDeclaration); + const typeNode = addEmitFlags(factory.createTypeLiteralNode(members), 1 /* SingleLine */); + return typeNode; } - } - function getSpans(n) { - const spans = [getNodeSpan(n.node)]; - if (n.additionalNodes) { - for (const node of n.additionalNodes) { - spans.push(getNodeSpan(node)); + function createPropertySignatureFromParameterDeclaration(parameterDeclaration) { + let parameterType = parameterDeclaration.type; + if (!parameterType && (parameterDeclaration.initializer || isRestParameter(parameterDeclaration))) { + parameterType = getTypeNode3(parameterDeclaration); + } + const propertySignature = factory.createPropertySignature( + /*modifiers*/ + void 0, + getParameterName(parameterDeclaration), + isOptionalParameter(parameterDeclaration) ? factory.createToken(58 /* QuestionToken */) : parameterDeclaration.questionToken, + parameterType + ); + suppressLeadingAndTrailingTrivia(propertySignature); + copyComments(parameterDeclaration.name, propertySignature.name); + if (parameterDeclaration.type && propertySignature.type) { + copyComments(parameterDeclaration.type, propertySignature.type); } + return propertySignature; } - return spans; - } - function getModuleName(moduleDeclaration) { - if (isAmbientModule(moduleDeclaration)) { - return getTextOfNode(moduleDeclaration.name); + function getTypeNode3(node) { + const type = checker.getTypeAtLocation(node); + return getTypeNodeIfAccessible(type, node, program, host); } - return getFullyQualifiedModuleName(moduleDeclaration); - } - function getFullyQualifiedModuleName(moduleDeclaration) { - const result = [getTextOfIdentifierOrLiteral(moduleDeclaration.name)]; - while (moduleDeclaration.body && moduleDeclaration.body.kind === 266 /* ModuleDeclaration */) { - moduleDeclaration = moduleDeclaration.body; - result.push(getTextOfIdentifierOrLiteral(moduleDeclaration.name)); + function isOptionalParameter(parameterDeclaration) { + if (isRestParameter(parameterDeclaration)) { + const type = checker.getTypeAtLocation(parameterDeclaration); + return !checker.isTupleType(type); + } + return checker.isOptionalParameter(parameterDeclaration); } - return result.join("."); - } - function getInteriorModule(decl) { - return decl.body && isModuleDeclaration(decl.body) ? getInteriorModule(decl.body) : decl; - } - function isComputedProperty(member) { - return !member.name || member.name.kind === 166 /* ComputedPropertyName */; } - function getNodeSpan(node) { - return node.kind === 311 /* SourceFile */ ? createTextSpanFromRange(node) : createTextSpanFromNode(node, curSourceFile); + function getParameterName(paramDeclaration) { + return getTextOfIdentifierOrLiteral(paramDeclaration.name); } - function getModifiers2(node) { - if (node.parent && node.parent.kind === 259 /* VariableDeclaration */) { - node = node.parent; + function getClassNames(constructorDeclaration) { + switch (constructorDeclaration.parent.kind) { + case 263 /* ClassDeclaration */: + const classDeclaration = constructorDeclaration.parent; + if (classDeclaration.name) + return [classDeclaration.name]; + const defaultModifier = Debug.checkDefined( + findModifier(classDeclaration, 90 /* DefaultKeyword */), + "Nameless class declaration should be a default export" + ); + return [defaultModifier]; + case 231 /* ClassExpression */: + const classExpression = constructorDeclaration.parent; + const variableDeclaration = constructorDeclaration.parent.parent; + const className = classExpression.name; + if (className) + return [className, variableDeclaration.name]; + return [variableDeclaration.name]; } - return getNodeModifiers(node); } - function getFunctionOrClassName(node) { - const { parent: parent2 } = node; - if (node.name && getFullWidth(node.name) > 0) { - return cleanText(declarationNameToString(node.name)); - } else if (isVariableDeclaration(parent2)) { - return cleanText(declarationNameToString(parent2.name)); - } else if (isBinaryExpression(parent2) && parent2.operatorToken.kind === 64 /* EqualsToken */) { - return nodeText(parent2.left).replace(whiteSpaceRegex, ""); - } else if (isPropertyAssignment(parent2)) { - return nodeText(parent2.name); - } else if (getSyntacticModifierFlags(node) & 1024 /* Default */) { - return "default"; - } else if (isClassLike(node)) { - return ""; - } else if (isCallExpression(parent2)) { - let name = getCalledExpressionName(parent2.expression); - if (name !== void 0) { - name = cleanText(name); - if (name.length > maxLength) { - return `${name} callback`; + function getFunctionNames(functionDeclaration) { + switch (functionDeclaration.kind) { + case 262 /* FunctionDeclaration */: + if (functionDeclaration.name) + return [functionDeclaration.name]; + const defaultModifier = Debug.checkDefined( + findModifier(functionDeclaration, 90 /* DefaultKeyword */), + "Nameless function declaration should be a default export" + ); + return [defaultModifier]; + case 174 /* MethodDeclaration */: + return [functionDeclaration.name]; + case 176 /* Constructor */: + const ctrKeyword = Debug.checkDefined( + findChildOfKind(functionDeclaration, 137 /* ConstructorKeyword */, functionDeclaration.getSourceFile()), + "Constructor declaration should have constructor keyword" + ); + if (functionDeclaration.parent.kind === 231 /* ClassExpression */) { + const variableDeclaration = functionDeclaration.parent.parent; + return [variableDeclaration.name, ctrKeyword]; } - const args = cleanText(mapDefined(parent2.arguments, (a) => isStringLiteralLike(a) ? a.getText(curSourceFile) : void 0).join(", ")); - return `${name}(${args}) callback`; - } - } - return ""; - } - function getCalledExpressionName(expr) { - if (isIdentifier(expr)) { - return expr.text; - } else if (isPropertyAccessExpression(expr)) { - const left = getCalledExpressionName(expr.expression); - const right = expr.name.text; - return left === void 0 ? right : `${left}.${right}`; - } else { - return void 0; - } - } - function isFunctionOrClassExpression(node) { - switch (node.kind) { - case 218 /* ArrowFunction */: - case 217 /* FunctionExpression */: - case 230 /* ClassExpression */: - return true; + return [ctrKeyword]; + case 219 /* ArrowFunction */: + return [functionDeclaration.parent.name]; + case 218 /* FunctionExpression */: + if (functionDeclaration.name) + return [functionDeclaration.name, functionDeclaration.parent.name]; + return [functionDeclaration.parent.name]; default: - return false; + return Debug.assertNever(functionDeclaration, `Unexpected function declaration kind ${functionDeclaration.kind}`); } } - function cleanText(text) { - text = text.length > maxLength ? text.substring(0, maxLength) + "..." : text; - return text.replace(/\\?(\r?\n|\r|\u2028|\u2029)/g, ""); - } - var whiteSpaceRegex, maxLength, curCancellationToken, curSourceFile, parentsStack, parent, trackedEs5ClassesStack, trackedEs5Classes, emptyChildItemArray, isEs5ClassMember; - var init_navigationBar = __esm({ - "src/services/navigationBar.ts"() { + var refactorName9, minimumParameterLength, refactorDescription5, toDestructuredAction; + var init_convertParamsToDestructuredObject = __esm({ + "src/services/refactors/convertParamsToDestructuredObject.ts"() { "use strict"; init_ts4(); - whiteSpaceRegex = /\s+/g; - maxLength = 150; - parentsStack = []; - trackedEs5ClassesStack = []; - emptyChildItemArray = []; - isEs5ClassMember = { - [5 /* Property */]: true, - [3 /* PrototypeProperty */]: true, - [7 /* ObjectDefinePropertyValue */]: true, - [9 /* ObjectDefinePrototypeProperty */]: true, - [0 /* None */]: false, - [1 /* ExportsProperty */]: false, - [2 /* ModuleExports */]: false, - [8 /* ObjectDefinePropertyExports */]: false, - [6 /* Prototype */]: true, - [4 /* ThisProperty */]: false + init_ts_refactor(); + refactorName9 = "Convert parameters to destructured object"; + minimumParameterLength = 1; + refactorDescription5 = getLocaleSpecificMessage(Diagnostics.Convert_parameters_to_destructured_object); + toDestructuredAction = { + name: refactorName9, + description: refactorDescription5, + kind: "refactor.rewrite.parameters.toDestructured" }; + registerRefactor(refactorName9, { + kinds: [toDestructuredAction.kind], + getEditsForAction: getRefactorEditsToConvertParametersToDestructuredObject, + getAvailableActions: getRefactorActionsToConvertParametersToDestructuredObject + }); } }); - // src/services/_namespaces/ts.NavigationBar.ts - var ts_NavigationBar_exports = {}; - __export(ts_NavigationBar_exports, { - getNavigationBarItems: () => getNavigationBarItems, - getNavigationTree: () => getNavigationTree - }); - var init_ts_NavigationBar = __esm({ - "src/services/_namespaces/ts.NavigationBar.ts"() { + // src/services/_namespaces/ts.refactor.convertParamsToDestructuredObject.ts + var ts_refactor_convertParamsToDestructuredObject_exports = {}; + var init_ts_refactor_convertParamsToDestructuredObject = __esm({ + "src/services/_namespaces/ts.refactor.convertParamsToDestructuredObject.ts"() { "use strict"; - init_navigationBar(); + init_convertParamsToDestructuredObject(); } }); - // src/services/refactorProvider.ts - function registerRefactor(name, refactor) { - refactors.set(name, refactor); - } - function getApplicableRefactors(context, includeInteractiveActions) { - return arrayFrom(flatMapIterator(refactors.values(), (refactor) => { - var _a; - return context.cancellationToken && context.cancellationToken.isCancellationRequested() || !((_a = refactor.kinds) == null ? void 0 : _a.some((kind) => refactorKindBeginsWith(kind, context.kind))) ? void 0 : refactor.getAvailableActions(context, includeInteractiveActions); - })); - } - function getEditsForRefactor(context, refactorName13, actionName2, interactiveRefactorArguments) { - const refactor = refactors.get(refactorName13); - return refactor && refactor.getEditsForAction(context, actionName2, interactiveRefactorArguments); - } - var refactors; - var init_refactorProvider = __esm({ - "src/services/refactorProvider.ts"() { - "use strict"; - init_ts4(); - init_ts_refactor(); - refactors = /* @__PURE__ */ new Map(); + // src/services/refactors/convertStringOrTemplateLiteral.ts + function getRefactorActionsToConvertToTemplateString(context) { + const { file, startPosition } = context; + const node = getNodeOrParentOfParentheses(file, startPosition); + const maybeBinary = getParentBinaryExpression(node); + const nodeIsStringLiteral = isStringLiteral(maybeBinary); + const refactorInfo = { name: refactorName10, description: refactorDescription6, actions: [] }; + if (nodeIsStringLiteral && context.triggerReason !== "invoked") { + return emptyArray; } - }); - - // src/services/refactors/convertExport.ts - function getInfo2(context, considerPartialSpans = true) { - const { file, program } = context; - const span = getRefactorContextSpan(context); - const token = getTokenAtPosition(file, span.start); - const exportNode = !!(token.parent && getSyntacticModifierFlags(token.parent) & 1 /* Export */) && considerPartialSpans ? token.parent : getParentNodeInSpan(token, file, span); - if (!exportNode || !isSourceFile(exportNode.parent) && !(isModuleBlock(exportNode.parent) && isAmbientModule(exportNode.parent.parent))) { - return { error: getLocaleSpecificMessage(Diagnostics.Could_not_find_export_statement) }; + if (isExpressionNode(maybeBinary) && (nodeIsStringLiteral || isBinaryExpression(maybeBinary) && treeToArray(maybeBinary).isValidConcatenation)) { + refactorInfo.actions.push(convertStringAction); + return [refactorInfo]; + } else if (context.preferences.provideRefactorNotApplicableReason) { + refactorInfo.actions.push({ ...convertStringAction, notApplicableReason: getLocaleSpecificMessage(Diagnostics.Can_only_convert_string_concatenations_and_string_literals) }); + return [refactorInfo]; } - const checker = program.getTypeChecker(); - const exportingModuleSymbol = getExportingModuleSymbol(exportNode.parent, checker); - const flags = getSyntacticModifierFlags(exportNode) || (isExportAssignment(exportNode) && !exportNode.isExportEquals ? 1025 /* ExportDefault */ : 0 /* None */); - const wasDefault = !!(flags & 1024 /* Default */); - if (!(flags & 1 /* Export */) || !wasDefault && exportingModuleSymbol.exports.has("default" /* Default */)) { - return { error: getLocaleSpecificMessage(Diagnostics.This_file_already_has_a_default_export) }; + return emptyArray; + } + function getNodeOrParentOfParentheses(file, startPosition) { + const node = getTokenAtPosition(file, startPosition); + const nestedBinary = getParentBinaryExpression(node); + const isNonStringBinary = !treeToArray(nestedBinary).isValidConcatenation; + if (isNonStringBinary && isParenthesizedExpression(nestedBinary.parent) && isBinaryExpression(nestedBinary.parent.parent)) { + return nestedBinary.parent.parent; } - const noSymbolError = (id) => isIdentifier(id) && checker.getSymbolAtLocation(id) ? void 0 : { error: getLocaleSpecificMessage(Diagnostics.Can_only_convert_named_export) }; - switch (exportNode.kind) { - case 261 /* FunctionDeclaration */: - case 262 /* ClassDeclaration */: - case 263 /* InterfaceDeclaration */: - case 265 /* EnumDeclaration */: - case 264 /* TypeAliasDeclaration */: - case 266 /* ModuleDeclaration */: { - const node = exportNode; - if (!node.name) - return void 0; - return noSymbolError(node.name) || { exportNode: node, exportName: node.name, wasDefault, exportingModuleSymbol }; - } - case 242 /* VariableStatement */: { - const vs = exportNode; - if (!(vs.declarationList.flags & 2 /* Const */) || vs.declarationList.declarations.length !== 1) { - return void 0; - } - const decl = first(vs.declarationList.declarations); - if (!decl.initializer) - return void 0; - Debug.assert(!wasDefault, "Can't have a default flag here"); - return noSymbolError(decl.name) || { exportNode: vs, exportName: decl.name, wasDefault, exportingModuleSymbol }; - } - case 276 /* ExportAssignment */: { - const node = exportNode; - if (node.isExportEquals) - return void 0; - return noSymbolError(node.expression) || { exportNode: node, exportName: node.expression, wasDefault, exportingModuleSymbol }; - } + return node; + } + function getRefactorEditsToConvertToTemplateString(context, actionName2) { + const { file, startPosition } = context; + const node = getNodeOrParentOfParentheses(file, startPosition); + switch (actionName2) { + case refactorDescription6: + return { edits: getEditsForToTemplateLiteral(context, node) }; default: - return void 0; + return Debug.fail("invalid action"); } } - function doChange(exportingSourceFile, program, info, changes, cancellationToken) { - changeExport(exportingSourceFile, info, changes, program.getTypeChecker()); - changeImports(program, info, changes, cancellationToken); - } - function changeExport(exportingSourceFile, { wasDefault, exportNode, exportName }, changes, checker) { - if (wasDefault) { - if (isExportAssignment(exportNode) && !exportNode.isExportEquals) { - const exp = exportNode.expression; - const spec = makeExportSpecifier(exp.text, exp.text); - changes.replaceNode(exportingSourceFile, exportNode, factory.createExportDeclaration( - /*modifiers*/ - void 0, - /*isTypeOnly*/ - false, - factory.createNamedExports([spec]) - )); - } else { - changes.delete(exportingSourceFile, Debug.checkDefined(findModifier(exportNode, 90 /* DefaultKeyword */), "Should find a default keyword in modifier list")); - } + function getEditsForToTemplateLiteral(context, node) { + const maybeBinary = getParentBinaryExpression(node); + const file = context.file; + const templateLiteral = nodesToTemplate(treeToArray(maybeBinary), file); + const trailingCommentRanges = getTrailingCommentRanges(file.text, maybeBinary.end); + if (trailingCommentRanges) { + const lastComment = trailingCommentRanges[trailingCommentRanges.length - 1]; + const trailingRange = { pos: trailingCommentRanges[0].pos, end: lastComment.end }; + return ts_textChanges_exports.ChangeTracker.with(context, (t) => { + t.deleteRange(file, trailingRange); + t.replaceNode(file, maybeBinary, templateLiteral); + }); } else { - const exportKeyword = Debug.checkDefined(findModifier(exportNode, 95 /* ExportKeyword */), "Should find an export keyword in modifier list"); - switch (exportNode.kind) { - case 261 /* FunctionDeclaration */: - case 262 /* ClassDeclaration */: - case 263 /* InterfaceDeclaration */: - changes.insertNodeAfter(exportingSourceFile, exportKeyword, factory.createToken(90 /* DefaultKeyword */)); - break; - case 242 /* VariableStatement */: - const decl = first(exportNode.declarationList.declarations); - if (!ts_FindAllReferences_exports.Core.isSymbolReferencedInFile(exportName, checker, exportingSourceFile) && !decl.type) { - changes.replaceNode(exportingSourceFile, exportNode, factory.createExportDefault(Debug.checkDefined(decl.initializer, "Initializer was previously known to be present"))); - break; - } - case 265 /* EnumDeclaration */: - case 264 /* TypeAliasDeclaration */: - case 266 /* ModuleDeclaration */: - changes.deleteModifier(exportingSourceFile, exportKeyword); - changes.insertNodeAfter(exportingSourceFile, exportNode, factory.createExportDefault(factory.createIdentifier(exportName.text))); - break; - default: - Debug.fail(`Unexpected exportNode kind ${exportNode.kind}`); - } + return ts_textChanges_exports.ChangeTracker.with(context, (t) => t.replaceNode(file, maybeBinary, templateLiteral)); } } - function changeImports(program, { wasDefault, exportName, exportingModuleSymbol }, changes, cancellationToken) { - const checker = program.getTypeChecker(); - const exportSymbol = Debug.checkDefined(checker.getSymbolAtLocation(exportName), "Export name should resolve to a symbol"); - ts_FindAllReferences_exports.Core.eachExportReference(program.getSourceFiles(), checker, cancellationToken, exportSymbol, exportingModuleSymbol, exportName.text, wasDefault, (ref) => { - if (exportName === ref) - return; - const importingSourceFile = ref.getSourceFile(); - if (wasDefault) { - changeDefaultToNamedImport(importingSourceFile, ref, changes, exportName.text); - } else { - changeNamedToDefaultImport(importingSourceFile, ref, changes); + function isNotEqualsOperator(node) { + return !(node.operatorToken.kind === 64 /* EqualsToken */ || node.operatorToken.kind === 65 /* PlusEqualsToken */); + } + function getParentBinaryExpression(expr) { + const container = findAncestor(expr.parent, (n) => { + switch (n.kind) { + case 211 /* PropertyAccessExpression */: + case 212 /* ElementAccessExpression */: + return false; + case 228 /* TemplateExpression */: + case 226 /* BinaryExpression */: + return !(isBinaryExpression(n.parent) && isNotEqualsOperator(n.parent)); + default: + return "quit"; } }); + return container || expr; } - function changeDefaultToNamedImport(importingSourceFile, ref, changes, exportName) { - const { parent: parent2 } = ref; - switch (parent2.kind) { - case 210 /* PropertyAccessExpression */: - changes.replaceNode(importingSourceFile, ref, factory.createIdentifier(exportName)); - break; - case 275 /* ImportSpecifier */: - case 280 /* ExportSpecifier */: { - const spec = parent2; - changes.replaceNode(importingSourceFile, spec, makeImportSpecifier(exportName, spec.name.text)); - break; + function treeToArray(current) { + const loop = (current2) => { + if (!isBinaryExpression(current2)) { + return { nodes: [current2], operators: [], validOperators: true, hasString: isStringLiteral(current2) || isNoSubstitutionTemplateLiteral(current2) }; } - case 272 /* ImportClause */: { - const clause = parent2; - Debug.assert(clause.name === ref, "Import clause name should match provided ref"); - const spec = makeImportSpecifier(exportName, ref.text); - const { namedBindings } = clause; - if (!namedBindings) { - changes.replaceNode(importingSourceFile, ref, factory.createNamedImports([spec])); - } else if (namedBindings.kind === 273 /* NamespaceImport */) { - changes.deleteRange(importingSourceFile, { pos: ref.getStart(importingSourceFile), end: namedBindings.getStart(importingSourceFile) }); - const quotePreference = isStringLiteral(clause.parent.moduleSpecifier) ? quotePreferenceFromString(clause.parent.moduleSpecifier, importingSourceFile) : 1 /* Double */; - const newImport = makeImport( - /*defaultImport*/ - void 0, - [makeImportSpecifier(exportName, ref.text)], - clause.parent.moduleSpecifier, - quotePreference - ); - changes.insertNodeAfter(importingSourceFile, clause.parent, newImport); - } else { - changes.delete(importingSourceFile, ref); - changes.insertNodeAtEndOfList(importingSourceFile, namedBindings.elements, spec); - } - break; + const { nodes: nodes2, operators: operators2, hasString: leftHasString, validOperators: leftOperatorValid } = loop(current2.left); + if (!(leftHasString || isStringLiteral(current2.right) || isTemplateExpression(current2.right))) { + return { nodes: [current2], operators: [], hasString: false, validOperators: true }; } - case 204 /* ImportType */: - const importTypeNode = parent2; - changes.replaceNode(importingSourceFile, parent2, factory.createImportTypeNode(importTypeNode.argument, importTypeNode.assertions, factory.createIdentifier(exportName), importTypeNode.typeArguments, importTypeNode.isTypeOf)); - break; - default: - Debug.failBadSyntaxKind(parent2); - } + const currentOperatorValid = current2.operatorToken.kind === 40 /* PlusToken */; + const validOperators2 = leftOperatorValid && currentOperatorValid; + nodes2.push(current2.right); + operators2.push(current2.operatorToken); + return { nodes: nodes2, operators: operators2, hasString: true, validOperators: validOperators2 }; + }; + const { nodes, operators, validOperators, hasString } = loop(current); + return { nodes, operators, isValidConcatenation: validOperators && hasString }; } - function changeNamedToDefaultImport(importingSourceFile, ref, changes) { - const parent2 = ref.parent; - switch (parent2.kind) { - case 210 /* PropertyAccessExpression */: - changes.replaceNode(importingSourceFile, ref, factory.createIdentifier("default")); - break; - case 275 /* ImportSpecifier */: { - const defaultImport = factory.createIdentifier(parent2.name.text); - if (parent2.parent.elements.length === 1) { - changes.replaceNode(importingSourceFile, parent2.parent, defaultImport); - } else { - changes.delete(importingSourceFile, parent2); - changes.insertNodeBefore(importingSourceFile, parent2.parent, defaultImport); - } + function escapeRawStringForTemplate(s) { + return s.replace(/\\.|[$`]/g, (m) => m[0] === "\\" ? m : "\\" + m); + } + function getRawTextOfTemplate(node) { + const rightShaving = isTemplateHead(node) || isTemplateMiddle(node) ? -2 : -1; + return getTextOfNode(node).slice(1, rightShaving); + } + function concatConsecutiveString(index, nodes) { + const indexes = []; + let text = "", rawText = ""; + while (index < nodes.length) { + const node = nodes[index]; + if (isStringLiteralLike(node)) { + text += node.text; + rawText += escapeRawStringForTemplate(getTextOfNode(node).slice(1, -1)); + indexes.push(index); + index++; + } else if (isTemplateExpression(node)) { + text += node.head.text; + rawText += getRawTextOfTemplate(node.head); break; - } - case 280 /* ExportSpecifier */: { - changes.replaceNode(importingSourceFile, parent2, makeExportSpecifier("default", parent2.name.text)); + } else { break; } - default: - Debug.assertNever(parent2, `Unexpected parent kind ${parent2.kind}`); } + return [index, text, rawText, indexes]; } - function makeImportSpecifier(propertyName, name) { - return factory.createImportSpecifier( - /*isTypeOnly*/ - false, - propertyName === name ? void 0 : factory.createIdentifier(propertyName), - factory.createIdentifier(name) - ); + function nodesToTemplate({ nodes, operators }, file) { + const copyOperatorComments = copyTrailingOperatorComments(operators, file); + const copyCommentFromStringLiterals = copyCommentFromMultiNode(nodes, file, copyOperatorComments); + const [begin, headText, rawHeadText, headIndexes] = concatConsecutiveString(0, nodes); + if (begin === nodes.length) { + const noSubstitutionTemplateLiteral = factory.createNoSubstitutionTemplateLiteral(headText, rawHeadText); + copyCommentFromStringLiterals(headIndexes, noSubstitutionTemplateLiteral); + return noSubstitutionTemplateLiteral; + } + const templateSpans = []; + const templateHead = factory.createTemplateHead(headText, rawHeadText); + copyCommentFromStringLiterals(headIndexes, templateHead); + for (let i = begin; i < nodes.length; i++) { + const currentNode = getExpressionFromParenthesesOrExpression(nodes[i]); + copyOperatorComments(i, currentNode); + const [newIndex, subsequentText, rawSubsequentText, stringIndexes] = concatConsecutiveString(i + 1, nodes); + i = newIndex - 1; + const isLast = i === nodes.length - 1; + if (isTemplateExpression(currentNode)) { + const spans = map(currentNode.templateSpans, (span, index) => { + copyExpressionComments(span); + const isLastSpan = index === currentNode.templateSpans.length - 1; + const text = span.literal.text + (isLastSpan ? subsequentText : ""); + const rawText = getRawTextOfTemplate(span.literal) + (isLastSpan ? rawSubsequentText : ""); + return factory.createTemplateSpan( + span.expression, + isLast && isLastSpan ? factory.createTemplateTail(text, rawText) : factory.createTemplateMiddle(text, rawText) + ); + }); + templateSpans.push(...spans); + } else { + const templatePart = isLast ? factory.createTemplateTail(subsequentText, rawSubsequentText) : factory.createTemplateMiddle(subsequentText, rawSubsequentText); + copyCommentFromStringLiterals(stringIndexes, templatePart); + templateSpans.push(factory.createTemplateSpan(currentNode, templatePart)); + } + } + return factory.createTemplateExpression(templateHead, templateSpans); } - function makeExportSpecifier(propertyName, name) { - return factory.createExportSpecifier( - /*isTypeOnly*/ - false, - propertyName === name ? void 0 : factory.createIdentifier(propertyName), - factory.createIdentifier(name) + function copyExpressionComments(node) { + const file = node.getSourceFile(); + copyTrailingComments( + node, + node.expression, + file, + 3 /* MultiLineCommentTrivia */, + /*hasTrailingNewLine*/ + false + ); + copyTrailingAsLeadingComments( + node.expression, + node.expression, + file, + 3 /* MultiLineCommentTrivia */, + /*hasTrailingNewLine*/ + false ); } - function getExportingModuleSymbol(parent2, checker) { - if (isSourceFile(parent2)) { - return parent2.symbol; - } - const symbol = parent2.parent.symbol; - if (symbol.valueDeclaration && isExternalModuleAugmentation(symbol.valueDeclaration)) { - return checker.getMergedSymbol(symbol); + function getExpressionFromParenthesesOrExpression(node) { + if (isParenthesizedExpression(node)) { + copyExpressionComments(node); + node = node.expression; } - return symbol; + return node; } - var refactorName, defaultToNamedAction, namedToDefaultAction; - var init_convertExport = __esm({ - "src/services/refactors/convertExport.ts"() { + var refactorName10, refactorDescription6, convertStringAction, copyTrailingOperatorComments, copyCommentFromMultiNode; + var init_convertStringOrTemplateLiteral = __esm({ + "src/services/refactors/convertStringOrTemplateLiteral.ts"() { "use strict"; init_ts4(); init_ts_refactor(); - refactorName = "Convert export"; - defaultToNamedAction = { - name: "Convert default export to named export", - description: Diagnostics.Convert_default_export_to_named_export.message, - kind: "refactor.rewrite.export.named" + refactorName10 = "Convert to template string"; + refactorDescription6 = getLocaleSpecificMessage(Diagnostics.Convert_to_template_string); + convertStringAction = { + name: refactorName10, + description: refactorDescription6, + kind: "refactor.rewrite.string" }; - namedToDefaultAction = { - name: "Convert named export to default export", - description: Diagnostics.Convert_named_export_to_default_export.message, - kind: "refactor.rewrite.export.default" + registerRefactor(refactorName10, { + kinds: [convertStringAction.kind], + getEditsForAction: getRefactorEditsToConvertToTemplateString, + getAvailableActions: getRefactorActionsToConvertToTemplateString + }); + copyTrailingOperatorComments = (operators, file) => (index, targetNode) => { + if (index < operators.length) { + copyTrailingComments( + operators[index], + targetNode, + file, + 3 /* MultiLineCommentTrivia */, + /*hasTrailingNewLine*/ + false + ); + } }; - registerRefactor(refactorName, { - kinds: [ - defaultToNamedAction.kind, - namedToDefaultAction.kind - ], - getAvailableActions: function getRefactorActionsToConvertBetweenNamedAndDefaultExports(context) { - const info = getInfo2(context, context.triggerReason === "invoked"); - if (!info) - return emptyArray; - if (!isRefactorErrorInfo(info)) { - const action = info.wasDefault ? defaultToNamedAction : namedToDefaultAction; - return [{ name: refactorName, description: action.description, actions: [action] }]; - } - if (context.preferences.provideRefactorNotApplicableReason) { - return [ - { name: refactorName, description: Diagnostics.Convert_default_export_to_named_export.message, actions: [ - { ...defaultToNamedAction, notApplicableReason: info.error }, - { ...namedToDefaultAction, notApplicableReason: info.error } - ] } - ]; - } - return emptyArray; - }, - getEditsForAction: function getRefactorEditsToConvertBetweenNamedAndDefaultExports(context, actionName2) { - Debug.assert(actionName2 === defaultToNamedAction.name || actionName2 === namedToDefaultAction.name, "Unexpected action name"); - const info = getInfo2(context); - Debug.assert(info && !isRefactorErrorInfo(info), "Expected applicable refactor info"); - const edits = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange(context.file, context.program, info, t, context.cancellationToken)); - return { edits, renameFilename: void 0, renameLocation: void 0 }; + copyCommentFromMultiNode = (nodes, file, copyOperatorComments) => (indexes, targetNode) => { + while (indexes.length > 0) { + const index = indexes.shift(); + copyTrailingComments( + nodes[index], + targetNode, + file, + 3 /* MultiLineCommentTrivia */, + /*hasTrailingNewLine*/ + false + ); + copyOperatorComments(index, targetNode); } - }); + }; } }); - // src/services/refactors/convertImport.ts - function getImportConversionInfo(context, considerPartialSpans = true) { - const { file } = context; - const span = getRefactorContextSpan(context); - const token = getTokenAtPosition(file, span.start); - const importDecl = considerPartialSpans ? findAncestor(token, isImportDeclaration) : getParentNodeInSpan(token, file, span); - if (!importDecl || !isImportDeclaration(importDecl)) - return { error: "Selection is not an import declaration." }; - const end = span.start + span.length; - const nextToken = findNextToken(importDecl, importDecl.parent, file); - if (nextToken && end > nextToken.getStart()) - return void 0; - const { importClause } = importDecl; - if (!importClause) { - return { error: getLocaleSpecificMessage(Diagnostics.Could_not_find_import_clause) }; + // src/services/_namespaces/ts.refactor.convertStringOrTemplateLiteral.ts + var ts_refactor_convertStringOrTemplateLiteral_exports = {}; + var init_ts_refactor_convertStringOrTemplateLiteral = __esm({ + "src/services/_namespaces/ts.refactor.convertStringOrTemplateLiteral.ts"() { + "use strict"; + init_convertStringOrTemplateLiteral(); } - if (!importClause.namedBindings) { - return { error: getLocaleSpecificMessage(Diagnostics.Could_not_find_namespace_import_or_named_imports) }; + }); + + // src/services/refactors/convertToOptionalChainExpression.ts + function getRefactorActionsToConvertToOptionalChain(context) { + const info = getInfo3(context, context.triggerReason === "invoked"); + if (!info) + return emptyArray; + if (!isRefactorErrorInfo(info)) { + return [{ + name: refactorName11, + description: convertToOptionalChainExpressionMessage, + actions: [toOptionalChainAction] + }]; } - if (importClause.namedBindings.kind === 273 /* NamespaceImport */) { - return { convertTo: 0 /* Named */, import: importClause.namedBindings }; + if (context.preferences.provideRefactorNotApplicableReason) { + return [{ + name: refactorName11, + description: convertToOptionalChainExpressionMessage, + actions: [{ ...toOptionalChainAction, notApplicableReason: info.error }] + }]; } - const shouldUseDefault = getShouldUseDefault(context.program, importClause); - return shouldUseDefault ? { convertTo: 1 /* Default */, import: importClause.namedBindings } : { convertTo: 2 /* Namespace */, import: importClause.namedBindings }; + return emptyArray; } - function getShouldUseDefault(program, importClause) { - return getAllowSyntheticDefaultImports(program.getCompilerOptions()) && isExportEqualsModule(importClause.parent.moduleSpecifier, program.getTypeChecker()); + function getRefactorEditsToConvertToOptionalChain(context, actionName2) { + const info = getInfo3(context); + Debug.assert(info && !isRefactorErrorInfo(info), "Expected applicable refactor info"); + const edits = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange6(context.file, context.program.getTypeChecker(), t, info, actionName2)); + return { edits, renameFilename: void 0, renameLocation: void 0 }; } - function doChange2(sourceFile, program, changes, info) { + function isValidExpression(node) { + return isBinaryExpression(node) || isConditionalExpression(node); + } + function isValidStatement(node) { + return isExpressionStatement(node) || isReturnStatement(node) || isVariableStatement(node); + } + function isValidExpressionOrStatement(node) { + return isValidExpression(node) || isValidStatement(node); + } + function getInfo3(context, considerEmptySpans = true) { + const { file, program } = context; + const span = getRefactorContextSpan(context); + const forEmptySpan = span.length === 0; + if (forEmptySpan && !considerEmptySpans) + return void 0; + const startToken = getTokenAtPosition(file, span.start); + const endToken = findTokenOnLeftOfPosition(file, span.start + span.length); + const adjustedSpan = createTextSpanFromBounds(startToken.pos, endToken && endToken.end >= startToken.pos ? endToken.getEnd() : startToken.getEnd()); + const parent2 = forEmptySpan ? getValidParentNodeOfEmptySpan(startToken) : getValidParentNodeContainingSpan(startToken, adjustedSpan); + const expression = parent2 && isValidExpressionOrStatement(parent2) ? getExpression(parent2) : void 0; + if (!expression) + return { error: getLocaleSpecificMessage(Diagnostics.Could_not_find_convertible_access_expression) }; const checker = program.getTypeChecker(); - if (info.convertTo === 0 /* Named */) { - doChangeNamespaceToNamed(sourceFile, checker, changes, info.import, getAllowSyntheticDefaultImports(program.getCompilerOptions())); - } else { - doChangeNamedToNamespaceOrDefault(sourceFile, program, changes, info.import, info.convertTo === 1 /* Default */); - } + return isConditionalExpression(expression) ? getConditionalInfo(expression, checker) : getBinaryInfo(expression); } - function doChangeNamespaceToNamed(sourceFile, checker, changes, toConvert, allowSyntheticDefaultImports) { - let usedAsNamespaceOrDefault = false; - const nodesToReplace = []; - const conflictingNames = /* @__PURE__ */ new Map(); - ts_FindAllReferences_exports.Core.eachSymbolReferenceInFile(toConvert.name, checker, sourceFile, (id) => { - if (!isPropertyAccessOrQualifiedName(id.parent)) { - usedAsNamespaceOrDefault = true; - } else { - const exportName = getRightOfPropertyAccessOrQualifiedName(id.parent).text; - if (checker.resolveName( - exportName, - id, - 67108863 /* All */, - /*excludeGlobals*/ - true - )) { - conflictingNames.set(exportName, true); - } - Debug.assert(getLeftOfPropertyAccessOrQualifiedName(id.parent) === id, "Parent expression should match id"); - nodesToReplace.push(id.parent); - } - }); - const exportNameToImportName = /* @__PURE__ */ new Map(); - for (const propertyAccessOrQualifiedName of nodesToReplace) { - const exportName = getRightOfPropertyAccessOrQualifiedName(propertyAccessOrQualifiedName).text; - let importName = exportNameToImportName.get(exportName); - if (importName === void 0) { - exportNameToImportName.set(exportName, importName = conflictingNames.has(exportName) ? getUniqueName(exportName, sourceFile) : exportName); - } - changes.replaceNode(sourceFile, propertyAccessOrQualifiedName, factory.createIdentifier(importName)); + function getConditionalInfo(expression, checker) { + const condition = expression.condition; + const finalExpression = getFinalExpressionInChain(expression.whenTrue); + if (!finalExpression || checker.isNullableType(checker.getTypeAtLocation(finalExpression))) { + return { error: getLocaleSpecificMessage(Diagnostics.Could_not_find_convertible_access_expression) }; } - const importSpecifiers = []; - exportNameToImportName.forEach((name, propertyName) => { - importSpecifiers.push(factory.createImportSpecifier( - /*isTypeOnly*/ - false, - name === propertyName ? void 0 : factory.createIdentifier(propertyName), - factory.createIdentifier(name) - )); - }); - const importDecl = toConvert.parent.parent; - if (usedAsNamespaceOrDefault && !allowSyntheticDefaultImports) { - changes.insertNodeAfter(sourceFile, importDecl, updateImport( - importDecl, - /*defaultImportName*/ - void 0, - importSpecifiers - )); - } else { - changes.replaceNode(sourceFile, importDecl, updateImport(importDecl, usedAsNamespaceOrDefault ? factory.createIdentifier(toConvert.name.text) : void 0, importSpecifiers)); + if ((isPropertyAccessExpression(condition) || isIdentifier(condition)) && getMatchingStart(condition, finalExpression.expression)) { + return { finalExpression, occurrences: [condition], expression }; + } else if (isBinaryExpression(condition)) { + const occurrences = getOccurrencesInExpression(finalExpression.expression, condition); + return occurrences ? { finalExpression, occurrences, expression } : { error: getLocaleSpecificMessage(Diagnostics.Could_not_find_matching_access_expressions) }; } } - function getRightOfPropertyAccessOrQualifiedName(propertyAccessOrQualifiedName) { - return isPropertyAccessExpression(propertyAccessOrQualifiedName) ? propertyAccessOrQualifiedName.name : propertyAccessOrQualifiedName.right; - } - function getLeftOfPropertyAccessOrQualifiedName(propertyAccessOrQualifiedName) { - return isPropertyAccessExpression(propertyAccessOrQualifiedName) ? propertyAccessOrQualifiedName.expression : propertyAccessOrQualifiedName.left; + function getBinaryInfo(expression) { + if (expression.operatorToken.kind !== 56 /* AmpersandAmpersandToken */) { + return { error: getLocaleSpecificMessage(Diagnostics.Can_only_convert_logical_AND_access_chains) }; + } + const finalExpression = getFinalExpressionInChain(expression.right); + if (!finalExpression) + return { error: getLocaleSpecificMessage(Diagnostics.Could_not_find_convertible_access_expression) }; + const occurrences = getOccurrencesInExpression(finalExpression.expression, expression.left); + return occurrences ? { finalExpression, occurrences, expression } : { error: getLocaleSpecificMessage(Diagnostics.Could_not_find_matching_access_expressions) }; } - function doChangeNamedToNamespaceOrDefault(sourceFile, program, changes, toConvert, shouldUseDefault = getShouldUseDefault(program, toConvert.parent)) { - const checker = program.getTypeChecker(); - const importDecl = toConvert.parent.parent; - const { moduleSpecifier } = importDecl; - const toConvertSymbols = /* @__PURE__ */ new Set(); - toConvert.elements.forEach((namedImport) => { - const symbol = checker.getSymbolAtLocation(namedImport.name); - if (symbol) { - toConvertSymbols.add(symbol); + function getOccurrencesInExpression(matchTo, expression) { + const occurrences = []; + while (isBinaryExpression(expression) && expression.operatorToken.kind === 56 /* AmpersandAmpersandToken */) { + const match = getMatchingStart(skipParentheses(matchTo), skipParentheses(expression.right)); + if (!match) { + break; } - }); - const preferredName = moduleSpecifier && isStringLiteral(moduleSpecifier) ? ts_codefix_exports.moduleSpecifierToValidIdentifier(moduleSpecifier.text, 99 /* ESNext */) : "module"; - function hasNamespaceNameConflict(namedImport) { - return !!ts_FindAllReferences_exports.Core.eachSymbolReferenceInFile(namedImport.name, checker, sourceFile, (id) => { - const symbol = checker.resolveName( - preferredName, - id, - 67108863 /* All */, - /*excludeGlobals*/ - true - ); - if (symbol) { - if (toConvertSymbols.has(symbol)) { - return isExportSpecifier(id.parent); - } - return true; - } - return false; - }); - } - const namespaceNameConflicts = toConvert.elements.some(hasNamespaceNameConflict); - const namespaceImportName = namespaceNameConflicts ? getUniqueName(preferredName, sourceFile) : preferredName; - const neededNamedImports = /* @__PURE__ */ new Set(); - for (const element of toConvert.elements) { - const propertyName = (element.propertyName || element.name).text; - ts_FindAllReferences_exports.Core.eachSymbolReferenceInFile(element.name, checker, sourceFile, (id) => { - const access = factory.createPropertyAccessExpression(factory.createIdentifier(namespaceImportName), propertyName); - if (isShorthandPropertyAssignment(id.parent)) { - changes.replaceNode(sourceFile, id.parent, factory.createPropertyAssignment(id.text, access)); - } else if (isExportSpecifier(id.parent)) { - neededNamedImports.add(element); - } else { - changes.replaceNode(sourceFile, id, access); - } - }); + occurrences.push(match); + matchTo = match; + expression = expression.left; } - changes.replaceNode(sourceFile, toConvert, shouldUseDefault ? factory.createIdentifier(namespaceImportName) : factory.createNamespaceImport(factory.createIdentifier(namespaceImportName))); - if (neededNamedImports.size) { - const newNamedImports = arrayFrom(neededNamedImports.values(), (element) => factory.createImportSpecifier(element.isTypeOnly, element.propertyName && factory.createIdentifier(element.propertyName.text), factory.createIdentifier(element.name.text))); - changes.insertNodeAfter(sourceFile, toConvert.parent.parent, updateImport( - importDecl, - /*defaultImportName*/ - void 0, - newNamedImports - )); + const finalMatch = getMatchingStart(matchTo, expression); + if (finalMatch) { + occurrences.push(finalMatch); } + return occurrences.length > 0 ? occurrences : void 0; } - function isExportEqualsModule(moduleSpecifier, checker) { - const externalModule = checker.resolveExternalModuleName(moduleSpecifier); - if (!externalModule) - return false; - const exportEquals = checker.resolveExternalModuleSymbol(externalModule); - return externalModule !== exportEquals; + function getMatchingStart(chain, subchain) { + if (!isIdentifier(subchain) && !isPropertyAccessExpression(subchain) && !isElementAccessExpression(subchain)) { + return void 0; + } + return chainStartsWith(chain, subchain) ? subchain : void 0; } - function updateImport(old, defaultImportName, elements) { - return factory.createImportDeclaration( - /*modifiers*/ - void 0, - factory.createImportClause( - /*isTypeOnly*/ - false, - defaultImportName, - elements && elements.length ? factory.createNamedImports(elements) : void 0 - ), - old.moduleSpecifier, - /*assertClause*/ - void 0 - ); + function chainStartsWith(chain, subchain) { + while (isCallExpression(chain) || isPropertyAccessExpression(chain) || isElementAccessExpression(chain)) { + if (getTextOfChainNode(chain) === getTextOfChainNode(subchain)) + break; + chain = chain.expression; + } + while (isPropertyAccessExpression(chain) && isPropertyAccessExpression(subchain) || isElementAccessExpression(chain) && isElementAccessExpression(subchain)) { + if (getTextOfChainNode(chain) !== getTextOfChainNode(subchain)) + return false; + chain = chain.expression; + subchain = subchain.expression; + } + return isIdentifier(chain) && isIdentifier(subchain) && chain.getText() === subchain.getText(); } - var refactorName2, actions; - var init_convertImport = __esm({ - "src/services/refactors/convertImport.ts"() { - "use strict"; - init_ts4(); - init_ts_refactor(); - refactorName2 = "Convert import"; - actions = { - [0 /* Named */]: { - name: "Convert namespace import to named imports", - description: Diagnostics.Convert_namespace_import_to_named_imports.message, - kind: "refactor.rewrite.import.named" - }, - [2 /* Namespace */]: { - name: "Convert named imports to namespace import", - description: Diagnostics.Convert_named_imports_to_namespace_import.message, - kind: "refactor.rewrite.import.namespace" - }, - [1 /* Default */]: { - name: "Convert named imports to default import", - description: Diagnostics.Convert_named_imports_to_default_import.message, - kind: "refactor.rewrite.import.default" - } - }; - registerRefactor(refactorName2, { - kinds: getOwnValues(actions).map((a) => a.kind), - getAvailableActions: function getRefactorActionsToConvertBetweenNamedAndNamespacedImports(context) { - const info = getImportConversionInfo(context, context.triggerReason === "invoked"); - if (!info) - return emptyArray; - if (!isRefactorErrorInfo(info)) { - const action = actions[info.convertTo]; - return [{ name: refactorName2, description: action.description, actions: [action] }]; - } - if (context.preferences.provideRefactorNotApplicableReason) { - return getOwnValues(actions).map((action) => ({ - name: refactorName2, - description: action.description, - actions: [{ ...action, notApplicableReason: info.error }] - })); - } - return emptyArray; - }, - getEditsForAction: function getRefactorEditsToConvertBetweenNamedAndNamespacedImports(context, actionName2) { - Debug.assert(some(getOwnValues(actions), (action) => action.name === actionName2), "Unexpected action name"); - const info = getImportConversionInfo(context); - Debug.assert(info && !isRefactorErrorInfo(info), "Expected applicable refactor info"); - const edits = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange2(context.file, context.program, t, info)); - return { edits, renameFilename: void 0, renameLocation: void 0 }; - } - }); + function getTextOfChainNode(node) { + if (isIdentifier(node) || isStringOrNumericLiteralLike(node)) { + return node.getText(); } - }); - - // src/services/refactors/extractType.ts - function getRangeToExtract(context, considerEmptySpans = true) { - const { file, startPosition } = context; - const isJS = isSourceFileJS(file); - const current = getTokenAtPosition(file, startPosition); - const range = createTextRangeFromSpan(getRefactorContextSpan(context)); - const cursorRequest = range.pos === range.end && considerEmptySpans; - const selection = findAncestor(current, (node) => node.parent && isTypeNode(node) && !rangeContainsSkipTrivia(range, node.parent, file) && (cursorRequest || nodeOverlapsWithStartEnd(current, file, range.pos, range.end))); - if (!selection || !isTypeNode(selection)) - return { error: getLocaleSpecificMessage(Diagnostics.Selection_is_not_a_valid_type_node) }; - const checker = context.program.getTypeChecker(); - const enclosingNode = getEnclosingNode(selection, isJS); - if (enclosingNode === void 0) - return { error: getLocaleSpecificMessage(Diagnostics.No_type_could_be_extracted_from_this_type_node) }; - const typeParameters = collectTypeParameters(checker, selection, enclosingNode, file); - if (!typeParameters) - return { error: getLocaleSpecificMessage(Diagnostics.No_type_could_be_extracted_from_this_type_node) }; - const typeElements = flattenTypeLiteralNodeReference(checker, selection); - return { isJS, selection, enclosingNode, typeParameters, typeElements }; + if (isPropertyAccessExpression(node)) { + return getTextOfChainNode(node.name); + } + if (isElementAccessExpression(node)) { + return getTextOfChainNode(node.argumentExpression); + } + return void 0; } - function flattenTypeLiteralNodeReference(checker, node) { - if (!node) - return void 0; - if (isIntersectionTypeNode(node)) { - const result = []; - const seen = /* @__PURE__ */ new Map(); - for (const type of node.types) { - const flattenedTypeMembers = flattenTypeLiteralNodeReference(checker, type); - if (!flattenedTypeMembers || !flattenedTypeMembers.every((type2) => type2.name && addToSeen(seen, getNameFromPropertyName(type2.name)))) { - return void 0; - } - addRange(result, flattenedTypeMembers); + function getValidParentNodeContainingSpan(node, span) { + while (node.parent) { + if (isValidExpressionOrStatement(node) && span.length !== 0 && node.end >= span.start + span.length) { + return node; } - return result; - } else if (isParenthesizedTypeNode(node)) { - return flattenTypeLiteralNodeReference(checker, node.type); - } else if (isTypeLiteralNode(node)) { - return node.members; + node = node.parent; } return void 0; } - function rangeContainsSkipTrivia(r1, node, file) { - return rangeContainsStartEnd(r1, skipTrivia(file.text, node.pos), node.end); - } - function collectTypeParameters(checker, selection, enclosingNode, file) { - const result = []; - return visitor(selection) ? void 0 : result; - function visitor(node) { - if (isTypeReferenceNode(node)) { - if (isIdentifier(node.typeName)) { - const typeName = node.typeName; - const symbol = checker.resolveName( - typeName.text, - typeName, - 262144 /* TypeParameter */, - /*excludeGlobals*/ - true - ); - for (const decl of (symbol == null ? void 0 : symbol.declarations) || emptyArray) { - if (isTypeParameterDeclaration(decl) && decl.getSourceFile() === file) { - if (decl.name.escapedText === typeName.escapedText && rangeContainsSkipTrivia(decl, selection, file)) { - return true; - } - if (rangeContainsSkipTrivia(enclosingNode, decl, file) && !rangeContainsSkipTrivia(selection, decl, file)) { - pushIfUnique(result, decl); - break; - } - } - } - } - } else if (isInferTypeNode(node)) { - const conditionalTypeNode = findAncestor(node, (n) => isConditionalTypeNode(n) && rangeContainsSkipTrivia(n.extendsType, node, file)); - if (!conditionalTypeNode || !rangeContainsSkipTrivia(selection, conditionalTypeNode, file)) { - return true; - } - } else if (isTypePredicateNode(node) || isThisTypeNode(node)) { - const functionLikeNode = findAncestor(node.parent, isFunctionLike); - if (functionLikeNode && functionLikeNode.type && rangeContainsSkipTrivia(functionLikeNode.type, node, file) && !rangeContainsSkipTrivia(selection, functionLikeNode, file)) { - return true; - } - } else if (isTypeQueryNode(node)) { - if (isIdentifier(node.exprName)) { - const symbol = checker.resolveName( - node.exprName.text, - node.exprName, - 111551 /* Value */, - /*excludeGlobals*/ - false - ); - if ((symbol == null ? void 0 : symbol.valueDeclaration) && rangeContainsSkipTrivia(enclosingNode, symbol.valueDeclaration, file) && !rangeContainsSkipTrivia(selection, symbol.valueDeclaration, file)) { - return true; - } - } else { - if (isThisIdentifier(node.exprName.left) && !rangeContainsSkipTrivia(selection, node.parent, file)) { - return true; - } - } - } - if (file && isTupleTypeNode(node) && getLineAndCharacterOfPosition(file, node.pos).line === getLineAndCharacterOfPosition(file, node.end).line) { - setEmitFlags(node, 1 /* SingleLine */); + function getValidParentNodeOfEmptySpan(node) { + while (node.parent) { + if (isValidExpressionOrStatement(node) && !isValidExpressionOrStatement(node.parent)) { + return node; } - return forEachChild(node, visitor); + node = node.parent; } + return void 0; } - function doTypeAliasChange(changes, file, name, info) { - const { enclosingNode, selection, typeParameters } = info; - const newTypeNode = factory.createTypeAliasDeclaration( - /*modifiers*/ - void 0, - name, - typeParameters.map((id) => factory.updateTypeParameterDeclaration( - id, - id.modifiers, - id.name, - id.constraint, - /*defaultType*/ - void 0 - )), - selection - ); - changes.insertNodeBefore( - file, - enclosingNode, - ignoreSourceNewlines(newTypeNode), - /*blankLineBetween*/ - true - ); - changes.replaceNode(file, selection, factory.createTypeReferenceNode(name, typeParameters.map((id) => factory.createTypeReferenceNode( - id.name, - /*typeArguments*/ - void 0 - ))), { leadingTriviaOption: ts_textChanges_exports.LeadingTriviaOption.Exclude, trailingTriviaOption: ts_textChanges_exports.TrailingTriviaOption.ExcludeWhitespace }); + function getExpression(node) { + if (isValidExpression(node)) { + return node; + } + if (isVariableStatement(node)) { + const variable = getSingleVariableOfVariableStatement(node); + const initializer = variable == null ? void 0 : variable.initializer; + return initializer && isValidExpression(initializer) ? initializer : void 0; + } + return node.expression && isValidExpression(node.expression) ? node.expression : void 0; } - function doInterfaceChange(changes, file, name, info) { - var _a; - const { enclosingNode, selection, typeParameters, typeElements } = info; - const newTypeNode = factory.createInterfaceDeclaration( - /*modifiers*/ - void 0, - name, - typeParameters, - /*heritageClauses*/ - void 0, - typeElements - ); - setTextRange(newTypeNode, (_a = typeElements[0]) == null ? void 0 : _a.parent); - changes.insertNodeBefore( - file, - enclosingNode, - ignoreSourceNewlines(newTypeNode), - /*blankLineBetween*/ - true - ); - changes.replaceNode(file, selection, factory.createTypeReferenceNode(name, typeParameters.map((id) => factory.createTypeReferenceNode( - id.name, - /*typeArguments*/ - void 0 - ))), { leadingTriviaOption: ts_textChanges_exports.LeadingTriviaOption.Exclude, trailingTriviaOption: ts_textChanges_exports.TrailingTriviaOption.ExcludeWhitespace }); + function getFinalExpressionInChain(node) { + node = skipParentheses(node); + if (isBinaryExpression(node)) { + return getFinalExpressionInChain(node.left); + } else if ((isPropertyAccessExpression(node) || isElementAccessExpression(node) || isCallExpression(node)) && !isOptionalChain(node)) { + return node; + } + return void 0; } - function doTypedefChange(changes, context, file, name, info) { - var _a; - const { enclosingNode, selection, typeParameters } = info; - setEmitFlags(selection, 3072 /* NoComments */ | 4096 /* NoNestedComments */); - const node = factory.createJSDocTypedefTag( - factory.createIdentifier("typedef"), - factory.createJSDocTypeExpression(selection), - factory.createIdentifier(name) - ); - const templates = []; - forEach(typeParameters, (typeParameter) => { - const constraint = getEffectiveConstraintOfTypeParameter(typeParameter); - const parameter = factory.createTypeParameterDeclaration( - /*modifiers*/ - void 0, - typeParameter.name - ); - const template = factory.createJSDocTemplateTag( - factory.createIdentifier("template"), - constraint && cast(constraint, isJSDocTypeExpression), - [parameter] - ); - templates.push(template); - }); - const jsDoc = factory.createJSDocComment( - /*comment*/ - void 0, - factory.createNodeArray(concatenate(templates, [node])) - ); - if (isJSDoc(enclosingNode)) { - const pos = enclosingNode.getStart(file); - const newLineCharacter = getNewLineOrDefaultFromHost(context.host, (_a = context.formatContext) == null ? void 0 : _a.options); - changes.insertNodeAt(file, enclosingNode.getStart(file), jsDoc, { - suffix: newLineCharacter + newLineCharacter + file.text.slice(getPrecedingNonSpaceCharacterPosition(file.text, pos - 1), pos) - }); - } else { - changes.insertNodeBefore( - file, - enclosingNode, - jsDoc, - /*blankLineBetween*/ - true - ); + function convertOccurrences(checker, toConvert, occurrences) { + if (isPropertyAccessExpression(toConvert) || isElementAccessExpression(toConvert) || isCallExpression(toConvert)) { + const chain = convertOccurrences(checker, toConvert.expression, occurrences); + const lastOccurrence = occurrences.length > 0 ? occurrences[occurrences.length - 1] : void 0; + const isOccurrence = (lastOccurrence == null ? void 0 : lastOccurrence.getText()) === toConvert.expression.getText(); + if (isOccurrence) + occurrences.pop(); + if (isCallExpression(toConvert)) { + return isOccurrence ? factory.createCallChain(chain, factory.createToken(29 /* QuestionDotToken */), toConvert.typeArguments, toConvert.arguments) : factory.createCallChain(chain, toConvert.questionDotToken, toConvert.typeArguments, toConvert.arguments); + } else if (isPropertyAccessExpression(toConvert)) { + return isOccurrence ? factory.createPropertyAccessChain(chain, factory.createToken(29 /* QuestionDotToken */), toConvert.name) : factory.createPropertyAccessChain(chain, toConvert.questionDotToken, toConvert.name); + } else if (isElementAccessExpression(toConvert)) { + return isOccurrence ? factory.createElementAccessChain(chain, factory.createToken(29 /* QuestionDotToken */), toConvert.argumentExpression) : factory.createElementAccessChain(chain, toConvert.questionDotToken, toConvert.argumentExpression); + } } - changes.replaceNode(file, selection, factory.createTypeReferenceNode(name, typeParameters.map((id) => factory.createTypeReferenceNode( - id.name, - /*typeArguments*/ - void 0 - )))); + return toConvert; } - function getEnclosingNode(node, isJS) { - return findAncestor(node, isStatement) || (isJS ? findAncestor(node, isJSDoc) : void 0); + function doChange6(sourceFile, checker, changes, info, _actionName) { + const { finalExpression, occurrences, expression } = info; + const firstOccurrence = occurrences[occurrences.length - 1]; + const convertedChain = convertOccurrences(checker, finalExpression, occurrences); + if (convertedChain && (isPropertyAccessExpression(convertedChain) || isElementAccessExpression(convertedChain) || isCallExpression(convertedChain))) { + if (isBinaryExpression(expression)) { + changes.replaceNodeRange(sourceFile, firstOccurrence, finalExpression, convertedChain); + } else if (isConditionalExpression(expression)) { + changes.replaceNode(sourceFile, expression, factory.createBinaryExpression(convertedChain, factory.createToken(61 /* QuestionQuestionToken */), expression.whenFalse)); + } + } } - var refactorName3, extractToTypeAliasAction, extractToInterfaceAction, extractToTypeDefAction; - var init_extractType = __esm({ - "src/services/refactors/extractType.ts"() { + var refactorName11, convertToOptionalChainExpressionMessage, toOptionalChainAction; + var init_convertToOptionalChainExpression = __esm({ + "src/services/refactors/convertToOptionalChainExpression.ts"() { "use strict"; init_ts4(); init_ts_refactor(); - refactorName3 = "Extract type"; - extractToTypeAliasAction = { - name: "Extract to type alias", - description: getLocaleSpecificMessage(Diagnostics.Extract_to_type_alias), - kind: "refactor.extract.type" - }; - extractToInterfaceAction = { - name: "Extract to interface", - description: getLocaleSpecificMessage(Diagnostics.Extract_to_interface), - kind: "refactor.extract.interface" - }; - extractToTypeDefAction = { - name: "Extract to typedef", - description: getLocaleSpecificMessage(Diagnostics.Extract_to_typedef), - kind: "refactor.extract.typedef" + refactorName11 = "Convert to optional chain expression"; + convertToOptionalChainExpressionMessage = getLocaleSpecificMessage(Diagnostics.Convert_to_optional_chain_expression); + toOptionalChainAction = { + name: refactorName11, + description: convertToOptionalChainExpressionMessage, + kind: "refactor.rewrite.expression.optionalChain" }; - registerRefactor(refactorName3, { - kinds: [ - extractToTypeAliasAction.kind, - extractToInterfaceAction.kind, - extractToTypeDefAction.kind - ], - getAvailableActions: function getRefactorActionsToExtractType(context) { - const info = getRangeToExtract(context, context.triggerReason === "invoked"); - if (!info) - return emptyArray; - if (!isRefactorErrorInfo(info)) { - return [{ - name: refactorName3, - description: getLocaleSpecificMessage(Diagnostics.Extract_type), - actions: info.isJS ? [extractToTypeDefAction] : append([extractToTypeAliasAction], info.typeElements && extractToInterfaceAction) - }]; - } - if (context.preferences.provideRefactorNotApplicableReason) { - return [{ - name: refactorName3, - description: getLocaleSpecificMessage(Diagnostics.Extract_type), - actions: [ - { ...extractToTypeDefAction, notApplicableReason: info.error }, - { ...extractToTypeAliasAction, notApplicableReason: info.error }, - { ...extractToInterfaceAction, notApplicableReason: info.error } - ] - }]; - } - return emptyArray; - }, - getEditsForAction: function getRefactorEditsToExtractType(context, actionName2) { - const { file } = context; - const info = getRangeToExtract(context); - Debug.assert(info && !isRefactorErrorInfo(info), "Expected to find a range to extract"); - const name = getUniqueName("NewType", file); - const edits = ts_textChanges_exports.ChangeTracker.with(context, (changes) => { - switch (actionName2) { - case extractToTypeAliasAction.name: - Debug.assert(!info.isJS, "Invalid actionName/JS combo"); - return doTypeAliasChange(changes, file, name, info); - case extractToTypeDefAction.name: - Debug.assert(info.isJS, "Invalid actionName/JS combo"); - return doTypedefChange(changes, context, file, name, info); - case extractToInterfaceAction.name: - Debug.assert(!info.isJS && !!info.typeElements, "Invalid actionName/JS combo"); - return doInterfaceChange(changes, file, name, info); - default: - Debug.fail("Unexpected action name"); - } - }); - const renameFilename = file.fileName; - const renameLocation = getRenameLocation( - edits, - renameFilename, - name, - /*preferLastLocation*/ - false - ); - return { edits, renameFilename, renameLocation }; - } + registerRefactor(refactorName11, { + kinds: [toOptionalChainAction.kind], + getEditsForAction: getRefactorEditsToConvertToOptionalChain, + getAvailableActions: getRefactorActionsToConvertToOptionalChain }); } }); - // src/services/refactors/helpers.ts - function isRefactorErrorInfo(info) { - return info.error !== void 0; - } - function refactorKindBeginsWith(known, requested) { - if (!requested) - return true; - return known.substr(0, requested.length) === requested; - } - var init_helpers = __esm({ - "src/services/refactors/helpers.ts"() { + // src/services/_namespaces/ts.refactor.convertToOptionalChainExpression.ts + var ts_refactor_convertToOptionalChainExpression_exports = {}; + var init_ts_refactor_convertToOptionalChainExpression = __esm({ + "src/services/_namespaces/ts.refactor.convertToOptionalChainExpression.ts"() { "use strict"; + init_convertToOptionalChainExpression(); } }); - // src/services/refactors/moveToNewFile.ts - function doChange3(oldFile, program, toMove, changes, host, preferences, context) { - const checker = program.getTypeChecker(); - const usage = getUsageInfo(oldFile, toMove.all, checker); - const newFilename = createNewFileName(oldFile, program, context, host); - changes.createNewFile(oldFile, newFilename, getNewStatementsAndRemoveFromOldFile(oldFile, usage, changes, toMove, program, host, newFilename, preferences)); - addNewFileToTsconfig(program, changes, oldFile.fileName, newFilename, hostGetCanonicalFileName(host)); - } - function getNewStatementsAndRemoveFromOldFile(oldFile, usage, changes, toMove, program, host, newFilename, preferences) { - const checker = program.getTypeChecker(); - const prologueDirectives = takeWhile(oldFile.statements, isPrologueDirective); - if (oldFile.externalModuleIndicator === void 0 && oldFile.commonJsModuleIndicator === void 0 && usage.oldImportsNeededByTargetFile.size === 0) { - deleteMovedStatements(oldFile, toMove.ranges, changes); - return [...prologueDirectives, ...toMove.all]; - } - const useEsModuleSyntax = !fileShouldUseJavaScriptRequire(newFilename, program, host, !!oldFile.commonJsModuleIndicator); - const quotePreference = getQuotePreference(oldFile, preferences); - const importsFromNewFile = createOldFileImportsFromTargetFile(oldFile, usage.oldFileImportsFromTargetFile, newFilename, program, host, useEsModuleSyntax, quotePreference); - if (importsFromNewFile) { - insertImports( - changes, - oldFile, - importsFromNewFile, - /*blankLineBetween*/ - true, - preferences - ); - } - deleteUnusedOldImports(oldFile, toMove.all, changes, usage.unusedImportsFromOldFile, checker); - deleteMovedStatements(oldFile, toMove.ranges, changes); - updateImportsInOtherFiles(changes, program, host, oldFile, usage.movedSymbols, newFilename, quotePreference); - const imports = getNewFileImportsAndAddExportInOldFile(oldFile, usage.oldImportsNeededByTargetFile, usage.targetFileImportsFromOldFile, changes, checker, program, host, useEsModuleSyntax, quotePreference); - const body = addExports(oldFile, toMove.all, usage.oldFileImportsFromTargetFile, useEsModuleSyntax); - if (imports.length && body.length) { - return [ - ...prologueDirectives, - ...imports, - 4 /* NewLineTrivia */, - ...body - ]; + // src/services/refactors/extractSymbol.ts + function getRefactorActionsToExtractSymbol(context) { + const requestedRefactor = context.kind; + const rangeToExtract = getRangeToExtract2(context.file, getRefactorContextSpan(context), context.triggerReason === "invoked"); + const targetRange = rangeToExtract.targetRange; + if (targetRange === void 0) { + if (!rangeToExtract.errors || rangeToExtract.errors.length === 0 || !context.preferences.provideRefactorNotApplicableReason) { + return emptyArray; + } + const errors = []; + if (refactorKindBeginsWith(extractFunctionAction.kind, requestedRefactor)) { + errors.push({ + name: refactorName12, + description: extractFunctionAction.description, + actions: [{ ...extractFunctionAction, notApplicableReason: getStringError(rangeToExtract.errors) }] + }); + } + if (refactorKindBeginsWith(extractConstantAction.kind, requestedRefactor)) { + errors.push({ + name: refactorName12, + description: extractConstantAction.description, + actions: [{ ...extractConstantAction, notApplicableReason: getStringError(rangeToExtract.errors) }] + }); + } + return errors; } - return [ - ...prologueDirectives, - ...imports, - ...body - ]; - } - function getNewFileImportsAndAddExportInOldFile(oldFile, importsToCopy, newFileImportsFromOldFile, changes, checker, program, host, useEsModuleSyntax, quotePreference) { - const copiedOldImports = []; - for (const oldStatement of oldFile.statements) { - forEachImportInStatement(oldStatement, (i) => { - append(copiedOldImports, filterImport(i, moduleSpecifierFromImport(i), (name) => importsToCopy.has(checker.getSymbolAtLocation(name)))); - }); + const extractions = getPossibleExtractions(targetRange, context); + if (extractions === void 0) { + return emptyArray; } - let oldFileDefault; - const oldFileNamedImports = []; - const markSeenTop = nodeSeenTracker(); - newFileImportsFromOldFile.forEach((symbol) => { - if (!symbol.declarations) { - return; - } - for (const decl of symbol.declarations) { - if (!isTopLevelDeclaration(decl)) - continue; - const name = nameOfTopLevelDeclaration(decl); - if (!name) - continue; - const top = getTopLevelDeclarationStatement(decl); - if (markSeenTop(top)) { - addExportToChanges(oldFile, top, name, changes, useEsModuleSyntax); - } - if (hasSyntacticModifier(decl, 1024 /* Default */)) { - oldFileDefault = name; - } else { - oldFileNamedImports.push(name.text); + const functionActions = []; + const usedFunctionNames = /* @__PURE__ */ new Map(); + let innermostErrorFunctionAction; + const constantActions = []; + const usedConstantNames = /* @__PURE__ */ new Map(); + let innermostErrorConstantAction; + let i = 0; + for (const { functionExtraction, constantExtraction } of extractions) { + if (refactorKindBeginsWith(extractFunctionAction.kind, requestedRefactor)) { + const description3 = functionExtraction.description; + if (functionExtraction.errors.length === 0) { + if (!usedFunctionNames.has(description3)) { + usedFunctionNames.set(description3, true); + functionActions.push({ + description: description3, + name: `function_scope_${i}`, + kind: extractFunctionAction.kind + }); + } + } else if (!innermostErrorFunctionAction) { + innermostErrorFunctionAction = { + description: description3, + name: `function_scope_${i}`, + notApplicableReason: getStringError(functionExtraction.errors), + kind: extractFunctionAction.kind + }; } } - }); - append(copiedOldImports, makeImportOrRequire(oldFile, oldFileDefault, oldFileNamedImports, getBaseFileName(oldFile.fileName), program, host, useEsModuleSyntax, quotePreference)); - return copiedOldImports; - } - var refactorName4, description, moveToNewFileAction; - var init_moveToNewFile = __esm({ - "src/services/refactors/moveToNewFile.ts"() { - "use strict"; - init_ts4(); - init_ts_refactor(); - refactorName4 = "Move to a new file"; - description = getLocaleSpecificMessage(Diagnostics.Move_to_a_new_file); - moveToNewFileAction = { - name: refactorName4, - description, - kind: "refactor.move.newFile" - }; - registerRefactor(refactorName4, { - kinds: [moveToNewFileAction.kind], - getAvailableActions: function getRefactorActionsToMoveToNewFile(context) { - const statements = getStatementsToMove(context); - if (context.preferences.allowTextChangesInNewFiles && statements) { - return [{ name: refactorName4, description, actions: [moveToNewFileAction] }]; - } - if (context.preferences.provideRefactorNotApplicableReason) { - return [{ - name: refactorName4, - description, - actions: [{ ...moveToNewFileAction, notApplicableReason: getLocaleSpecificMessage(Diagnostics.Selection_is_not_a_valid_statement_or_statements) }] - }]; + if (refactorKindBeginsWith(extractConstantAction.kind, requestedRefactor)) { + const description3 = constantExtraction.description; + if (constantExtraction.errors.length === 0) { + if (!usedConstantNames.has(description3)) { + usedConstantNames.set(description3, true); + constantActions.push({ + description: description3, + name: `constant_scope_${i}`, + kind: extractConstantAction.kind + }); } - return emptyArray; - }, - getEditsForAction: function getRefactorEditsToMoveToNewFile(context, actionName2) { - Debug.assert(actionName2 === refactorName4, "Wrong refactor invoked"); - const statements = Debug.checkDefined(getStatementsToMove(context)); - const edits = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange3(context.file, context.program, statements, t, context.host, context.preferences, context)); - return { edits, renameFilename: void 0, renameLocation: void 0 }; + } else if (!innermostErrorConstantAction) { + innermostErrorConstantAction = { + description: description3, + name: `constant_scope_${i}`, + notApplicableReason: getStringError(constantExtraction.errors), + kind: extractConstantAction.kind + }; } + } + i++; + } + const infos = []; + if (functionActions.length) { + infos.push({ + name: refactorName12, + description: getLocaleSpecificMessage(Diagnostics.Extract_function), + actions: functionActions + }); + } else if (context.preferences.provideRefactorNotApplicableReason && innermostErrorFunctionAction) { + infos.push({ + name: refactorName12, + description: getLocaleSpecificMessage(Diagnostics.Extract_function), + actions: [innermostErrorFunctionAction] }); } - }); - - // src/services/refactors/moveToFile.ts - function doChange4(context, oldFile, targetFile, program, toMove, changes, host, preferences) { - const checker = program.getTypeChecker(); - const usage = getUsageInfo(oldFile, toMove.all, checker); - if (!host.fileExists(targetFile)) { - changes.createNewFile(oldFile, targetFile, getNewStatementsAndRemoveFromOldFile2(oldFile, targetFile, usage, changes, toMove, program, host, preferences)); - addNewFileToTsconfig(program, changes, oldFile.fileName, targetFile, hostGetCanonicalFileName(host)); - } else { - const targetSourceFile = Debug.checkDefined(program.getSourceFile(targetFile)); - const importAdder = ts_codefix_exports.createImportAdder(targetSourceFile, context.program, context.preferences, context.host); - getNewStatementsAndRemoveFromOldFile2(oldFile, targetSourceFile, usage, changes, toMove, program, host, preferences, importAdder); + if (constantActions.length) { + infos.push({ + name: refactorName12, + description: getLocaleSpecificMessage(Diagnostics.Extract_constant), + actions: constantActions + }); + } else if (context.preferences.provideRefactorNotApplicableReason && innermostErrorConstantAction) { + infos.push({ + name: refactorName12, + description: getLocaleSpecificMessage(Diagnostics.Extract_constant), + actions: [innermostErrorConstantAction] + }); + } + return infos.length ? infos : emptyArray; + function getStringError(errors) { + let error2 = errors[0].messageText; + if (typeof error2 !== "string") { + error2 = error2.messageText; + } + return error2; + } + } + function getRefactorEditsToExtractSymbol(context, actionName2) { + const rangeToExtract = getRangeToExtract2(context.file, getRefactorContextSpan(context)); + const targetRange = rangeToExtract.targetRange; + const parsedFunctionIndexMatch = /^function_scope_(\d+)$/.exec(actionName2); + if (parsedFunctionIndexMatch) { + const index = +parsedFunctionIndexMatch[1]; + Debug.assert(isFinite(index), "Expected to parse a finite number from the function scope index"); + return getFunctionExtractionAtIndex(targetRange, context, index); + } + const parsedConstantIndexMatch = /^constant_scope_(\d+)$/.exec(actionName2); + if (parsedConstantIndexMatch) { + const index = +parsedConstantIndexMatch[1]; + Debug.assert(isFinite(index), "Expected to parse a finite number from the constant scope index"); + return getConstantExtractionAtIndex(targetRange, context, index); } + Debug.fail("Unrecognized action name"); } - function getNewStatementsAndRemoveFromOldFile2(oldFile, targetFile, usage, changes, toMove, program, host, preferences, importAdder) { - const checker = program.getTypeChecker(); - const prologueDirectives = takeWhile(oldFile.statements, isPrologueDirective); - if (oldFile.externalModuleIndicator === void 0 && oldFile.commonJsModuleIndicator === void 0 && usage.oldImportsNeededByTargetFile.size === 0 && usage.targetFileImportsFromOldFile.size === 0 && typeof targetFile === "string") { - deleteMovedStatements(oldFile, toMove.ranges, changes); - return [...prologueDirectives, ...toMove.all]; + function getRangeToExtract2(sourceFile, span, invoked = true) { + const { length: length2 } = span; + if (length2 === 0 && !invoked) { + return { errors: [createFileDiagnostic(sourceFile, span.start, length2, Messages.cannotExtractEmpty)] }; } - const targetFileName = typeof targetFile === "string" ? targetFile : targetFile.fileName; - const useEsModuleSyntax = !fileShouldUseJavaScriptRequire(targetFileName, program, host, !!oldFile.commonJsModuleIndicator); - const quotePreference = getQuotePreference(oldFile, preferences); - const importsFromTargetFile = createOldFileImportsFromTargetFile(oldFile, usage.oldFileImportsFromTargetFile, targetFileName, program, host, useEsModuleSyntax, quotePreference); - if (importsFromTargetFile) { - insertImports( - changes, - oldFile, - importsFromTargetFile, - /*blankLineBetween*/ - true, - preferences - ); + const cursorRequest = length2 === 0 && invoked; + const startToken = findFirstNonJsxWhitespaceToken(sourceFile, span.start); + const endToken = findTokenOnLeftOfPosition(sourceFile, textSpanEnd(span)); + const adjustedSpan = startToken && endToken && invoked ? getAdjustedSpanFromNodes(startToken, endToken, sourceFile) : span; + const start = cursorRequest ? getExtractableParent(startToken) : getParentNodeInSpan(startToken, sourceFile, adjustedSpan); + const end = cursorRequest ? start : getParentNodeInSpan(endToken, sourceFile, adjustedSpan); + let rangeFacts = 0 /* None */; + let thisNode; + if (!start || !end) { + return { errors: [createFileDiagnostic(sourceFile, span.start, length2, Messages.cannotExtractRange)] }; } - deleteUnusedOldImports(oldFile, toMove.all, changes, usage.unusedImportsFromOldFile, checker); - deleteMovedStatements(oldFile, toMove.ranges, changes); - updateImportsInOtherFiles(changes, program, host, oldFile, usage.movedSymbols, targetFileName, quotePreference); - const imports = getTargetFileImportsAndAddExportInOldFile(oldFile, targetFileName, usage.oldImportsNeededByTargetFile, usage.targetFileImportsFromOldFile, changes, checker, program, host, useEsModuleSyntax, quotePreference, importAdder); - const body = addExports(oldFile, toMove.all, usage.oldFileImportsFromTargetFile, useEsModuleSyntax); - if (typeof targetFile !== "string") { - if (targetFile.statements.length > 0) { - changes.insertNodesAfter(targetFile, targetFile.statements[targetFile.statements.length - 1], body); - } else { - changes.insertNodesAtEndOfFile( - targetFile, - body, - /*blankLineBetween*/ - false - ); + if (start.flags & 16777216 /* JSDoc */) { + return { errors: [createFileDiagnostic(sourceFile, span.start, length2, Messages.cannotExtractJSDoc)] }; + } + if (start.parent !== end.parent) { + return { errors: [createFileDiagnostic(sourceFile, span.start, length2, Messages.cannotExtractRange)] }; + } + if (start !== end) { + if (!isBlockLike(start.parent)) { + return { errors: [createFileDiagnostic(sourceFile, span.start, length2, Messages.cannotExtractRange)] }; } - if (imports.length > 0) { - insertImports( - changes, - targetFile, - imports, - /*blankLineBetween*/ - true, - preferences - ); + const statements = []; + for (const statement of start.parent.statements) { + if (statement === start || statements.length) { + const errors2 = checkNode(statement); + if (errors2) { + return { errors: errors2 }; + } + statements.push(statement); + } + if (statement === end) { + break; + } + } + if (!statements.length) { + return { errors: [createFileDiagnostic(sourceFile, span.start, length2, Messages.cannotExtractRange)] }; } + return { targetRange: { range: statements, facts: rangeFacts, thisNode } }; } - if (importAdder) { - importAdder.writeFixes(changes); + if (isReturnStatement(start) && !start.expression) { + return { errors: [createFileDiagnostic(sourceFile, span.start, length2, Messages.cannotExtractRange)] }; } - if (imports.length && body.length) { - return [ - ...prologueDirectives, - ...imports, - 4 /* NewLineTrivia */, - ...body - ]; + const node = refineNode(start); + const errors = checkRootNode(node) || checkNode(node); + if (errors) { + return { errors }; } - return [ - ...prologueDirectives, - ...imports, - ...body - ]; - } - function getTargetFileImportsAndAddExportInOldFile(oldFile, targetFile, importsToCopy, targetFileImportsFromOldFile, changes, checker, program, host, useEsModuleSyntax, quotePreference, importAdder) { - const copiedOldImports = []; - if (importAdder) { - importsToCopy.forEach((isValidTypeOnlyUseSite, symbol) => { - try { - importAdder.addImportFromExportedSymbol(skipAlias(symbol, checker), isValidTypeOnlyUseSite); - } catch { - for (const oldStatement of oldFile.statements) { - forEachImportInStatement(oldStatement, (i) => { - append(copiedOldImports, filterImport(i, factory.createStringLiteral(moduleSpecifierFromImport(i).text), (name) => importsToCopy.has(checker.getSymbolAtLocation(name)))); - }); + return { targetRange: { range: getStatementOrExpressionRange(node), facts: rangeFacts, thisNode } }; + function refineNode(node2) { + if (isReturnStatement(node2)) { + if (node2.expression) { + return node2.expression; + } + } else if (isVariableStatement(node2) || isVariableDeclarationList(node2)) { + const declarations = isVariableStatement(node2) ? node2.declarationList.declarations : node2.declarations; + let numInitializers = 0; + let lastInitializer; + for (const declaration of declarations) { + if (declaration.initializer) { + numInitializers++; + lastInitializer = declaration.initializer; } } - }); - } else { - const targetSourceFile = program.getSourceFile(targetFile); - for (const oldStatement of oldFile.statements) { - forEachImportInStatement(oldStatement, (i) => { - var _a, _b; - const moduleSpecifier = moduleSpecifierFromImport(i); - const resolved = (_a = oldFile.resolvedModules) == null ? void 0 : _a.get(moduleSpecifier.text, getModeForUsageLocation(oldFile, moduleSpecifier)); - const fileName = (_b = resolved == null ? void 0 : resolved.resolvedModule) == null ? void 0 : _b.resolvedFileName; - if (fileName && targetSourceFile) { - const newModuleSpecifier = getModuleSpecifier(program.getCompilerOptions(), targetSourceFile, targetSourceFile.path, fileName, createModuleSpecifierResolutionHost(program, host)); - append(copiedOldImports, filterImport(i, makeStringLiteral(newModuleSpecifier, quotePreference), (name) => importsToCopy.has(checker.getSymbolAtLocation(name)))); - } else { - append(copiedOldImports, filterImport(i, factory.createStringLiteral(moduleSpecifierFromImport(i).text), (name) => importsToCopy.has(checker.getSymbolAtLocation(name)))); + if (numInitializers === 1) { + return lastInitializer; + } + } else if (isVariableDeclaration(node2)) { + if (node2.initializer) { + return node2.initializer; + } + } + return node2; + } + function checkRootNode(node2) { + if (isIdentifier(isExpressionStatement(node2) ? node2.expression : node2)) { + return [createDiagnosticForNode(node2, Messages.cannotExtractIdentifier)]; + } + return void 0; + } + function checkForStaticContext(nodeToCheck, containingClass) { + let current = nodeToCheck; + while (current !== containingClass) { + if (current.kind === 172 /* PropertyDeclaration */) { + if (isStatic(current)) { + rangeFacts |= 32 /* InStaticRegion */; } - }); + break; + } else if (current.kind === 169 /* Parameter */) { + const ctorOrMethod = getContainingFunction(current); + if (ctorOrMethod.kind === 176 /* Constructor */) { + rangeFacts |= 32 /* InStaticRegion */; + } + break; + } else if (current.kind === 174 /* MethodDeclaration */) { + if (isStatic(current)) { + rangeFacts |= 32 /* InStaticRegion */; + } + } + current = current.parent; } } - const targetFileSourceFile = program.getSourceFile(targetFile); - let oldFileDefault; - const oldFileNamedImports = []; - const markSeenTop = nodeSeenTracker(); - targetFileImportsFromOldFile.forEach((symbol) => { - if (!symbol.declarations) { - return; + function checkNode(nodeToCheck) { + let PermittedJumps; + ((PermittedJumps2) => { + PermittedJumps2[PermittedJumps2["None"] = 0] = "None"; + PermittedJumps2[PermittedJumps2["Break"] = 1] = "Break"; + PermittedJumps2[PermittedJumps2["Continue"] = 2] = "Continue"; + PermittedJumps2[PermittedJumps2["Return"] = 4] = "Return"; + })(PermittedJumps || (PermittedJumps = {})); + Debug.assert(nodeToCheck.pos <= nodeToCheck.end, "This failure could trigger https://github.com/Microsoft/TypeScript/issues/20809 (1)"); + Debug.assert(!positionIsSynthesized(nodeToCheck.pos), "This failure could trigger https://github.com/Microsoft/TypeScript/issues/20809 (2)"); + if (!isStatement(nodeToCheck) && !(isExpressionNode(nodeToCheck) && isExtractableExpression(nodeToCheck)) && !isStringLiteralJsxAttribute(nodeToCheck)) { + return [createDiagnosticForNode(nodeToCheck, Messages.statementOrExpressionExpected)]; } - for (const decl of symbol.declarations) { - if (!isTopLevelDeclaration(decl)) - continue; - const name = nameOfTopLevelDeclaration(decl); - if (!name) - continue; - const top = getTopLevelDeclarationStatement(decl); - if (markSeenTop(top)) { - addExportToChanges(oldFile, top, name, changes, useEsModuleSyntax); + if (nodeToCheck.flags & 33554432 /* Ambient */) { + return [createDiagnosticForNode(nodeToCheck, Messages.cannotExtractAmbientBlock)]; + } + const containingClass = getContainingClass(nodeToCheck); + if (containingClass) { + checkForStaticContext(nodeToCheck, containingClass); + } + let errors2; + let permittedJumps = 4 /* Return */; + let seenLabels; + visit(nodeToCheck); + if (rangeFacts & 8 /* UsesThis */) { + const container = getThisContainer( + nodeToCheck, + /*includeArrowFunctions*/ + false, + /*includeClassComputedPropertyName*/ + false + ); + if (container.kind === 262 /* FunctionDeclaration */ || container.kind === 174 /* MethodDeclaration */ && container.parent.kind === 210 /* ObjectLiteralExpression */ || container.kind === 218 /* FunctionExpression */) { + rangeFacts |= 16 /* UsesThisInFunction */; } - if (importAdder && checker.isUnknownSymbol(symbol)) { - importAdder.addImportFromExportedSymbol(skipAlias(symbol, checker)); - } else { - if (hasSyntacticModifier(decl, 1024 /* Default */)) { - oldFileDefault = name; - } else { - oldFileNamedImports.push(name.text); + } + return errors2; + function visit(node2) { + if (errors2) { + return true; + } + if (isDeclaration(node2)) { + const declaringNode = node2.kind === 260 /* VariableDeclaration */ ? node2.parent.parent : node2; + if (hasSyntacticModifier(declaringNode, 32 /* Export */)) { + (errors2 || (errors2 = [])).push(createDiagnosticForNode(node2, Messages.cannotExtractExportedEntity)); + return true; + } + } + switch (node2.kind) { + case 272 /* ImportDeclaration */: + (errors2 || (errors2 = [])).push(createDiagnosticForNode(node2, Messages.cannotExtractImport)); + return true; + case 277 /* ExportAssignment */: + (errors2 || (errors2 = [])).push(createDiagnosticForNode(node2, Messages.cannotExtractExportedEntity)); + return true; + case 108 /* SuperKeyword */: + if (node2.parent.kind === 213 /* CallExpression */) { + const containingClass2 = getContainingClass(node2); + if (containingClass2 === void 0 || containingClass2.pos < span.start || containingClass2.end >= span.start + span.length) { + (errors2 || (errors2 = [])).push(createDiagnosticForNode(node2, Messages.cannotExtractSuper)); + return true; + } + } else { + rangeFacts |= 8 /* UsesThis */; + thisNode = node2; + } + break; + case 219 /* ArrowFunction */: + forEachChild(node2, function check(n) { + if (isThis(n)) { + rangeFacts |= 8 /* UsesThis */; + thisNode = node2; + } else if (isClassLike(n) || isFunctionLike(n) && !isArrowFunction(n)) { + return false; + } else { + forEachChild(n, check); + } + }); + case 263 /* ClassDeclaration */: + case 262 /* FunctionDeclaration */: + if (isSourceFile(node2.parent) && node2.parent.externalModuleIndicator === void 0) { + (errors2 || (errors2 = [])).push(createDiagnosticForNode(node2, Messages.functionWillNotBeVisibleInTheNewScope)); + } + case 231 /* ClassExpression */: + case 218 /* FunctionExpression */: + case 174 /* MethodDeclaration */: + case 176 /* Constructor */: + case 177 /* GetAccessor */: + case 178 /* SetAccessor */: + return false; + } + const savedPermittedJumps = permittedJumps; + switch (node2.kind) { + case 245 /* IfStatement */: + permittedJumps &= ~4 /* Return */; + break; + case 258 /* TryStatement */: + permittedJumps = 0 /* None */; + break; + case 241 /* Block */: + if (node2.parent && node2.parent.kind === 258 /* TryStatement */ && node2.parent.finallyBlock === node2) { + permittedJumps = 4 /* Return */; + } + break; + case 297 /* DefaultClause */: + case 296 /* CaseClause */: + permittedJumps |= 1 /* Break */; + break; + default: + if (isIterationStatement( + node2, + /*lookInLabeledStatements*/ + false + )) { + permittedJumps |= 1 /* Break */ | 2 /* Continue */; + } + break; + } + switch (node2.kind) { + case 197 /* ThisType */: + case 110 /* ThisKeyword */: + rangeFacts |= 8 /* UsesThis */; + thisNode = node2; + break; + case 256 /* LabeledStatement */: { + const label = node2.label; + (seenLabels || (seenLabels = [])).push(label.escapedText); + forEachChild(node2, visit); + seenLabels.pop(); + break; + } + case 252 /* BreakStatement */: + case 251 /* ContinueStatement */: { + const label = node2.label; + if (label) { + if (!contains(seenLabels, label.escapedText)) { + (errors2 || (errors2 = [])).push(createDiagnosticForNode(node2, Messages.cannotExtractRangeContainingLabeledBreakOrContinueStatementWithTargetOutsideOfTheRange)); + } + } else { + if (!(permittedJumps & (node2.kind === 252 /* BreakStatement */ ? 1 /* Break */ : 2 /* Continue */))) { + (errors2 || (errors2 = [])).push(createDiagnosticForNode(node2, Messages.cannotExtractRangeContainingConditionalBreakOrContinueStatements)); + } + } + break; } + case 223 /* AwaitExpression */: + rangeFacts |= 4 /* IsAsyncFunction */; + break; + case 229 /* YieldExpression */: + rangeFacts |= 2 /* IsGenerator */; + break; + case 253 /* ReturnStatement */: + if (permittedJumps & 4 /* Return */) { + rangeFacts |= 1 /* HasReturn */; + } else { + (errors2 || (errors2 = [])).push(createDiagnosticForNode(node2, Messages.cannotExtractRangeContainingConditionalReturnStatement)); + } + break; + default: + forEachChild(node2, visit); + break; } + permittedJumps = savedPermittedJumps; } - }); - return targetFileSourceFile ? append(copiedOldImports, makeImportOrRequire(targetFileSourceFile, oldFileDefault, oldFileNamedImports, oldFile.fileName, program, host, useEsModuleSyntax, quotePreference)) : append(copiedOldImports, makeImportOrRequire(oldFile, oldFileDefault, oldFileNamedImports, oldFile.fileName, program, host, useEsModuleSyntax, quotePreference)); - } - function addNewFileToTsconfig(program, changes, oldFileName, newFileNameWithExtension, getCanonicalFileName) { - const cfg = program.getCompilerOptions().configFile; - if (!cfg) - return; - const newFileAbsolutePath = normalizePath(combinePaths(oldFileName, "..", newFileNameWithExtension)); - const newFilePath = getRelativePathFromFile(cfg.fileName, newFileAbsolutePath, getCanonicalFileName); - const cfgObject = cfg.statements[0] && tryCast(cfg.statements[0].expression, isObjectLiteralExpression); - const filesProp = cfgObject && find(cfgObject.properties, (prop) => isPropertyAssignment(prop) && isStringLiteral(prop.name) && prop.name.text === "files"); - if (filesProp && isArrayLiteralExpression(filesProp.initializer)) { - changes.insertNodeInListAfter(cfg, last(filesProp.initializer.elements), factory.createStringLiteral(newFilePath), filesProp.initializer.elements); } } - function deleteMovedStatements(sourceFile, moved, changes) { - for (const { first: first2, afterLast } of moved) { - changes.deleteNodeRangeExcludingEnd(sourceFile, first2, afterLast); + function getAdjustedSpanFromNodes(startNode2, endNode2, sourceFile) { + const start = startNode2.getStart(sourceFile); + let end = endNode2.getEnd(); + if (sourceFile.text.charCodeAt(end) === 59 /* semicolon */) { + end++; } + return { start, length: end - start }; } - function deleteUnusedOldImports(oldFile, toMove, changes, toDelete, checker) { - for (const statement of oldFile.statements) { - if (contains(toMove, statement)) - continue; - forEachImportInStatement(statement, (i) => deleteUnusedImports(oldFile, i, changes, (name) => toDelete.has(checker.getSymbolAtLocation(name)))); + function getStatementOrExpressionRange(node) { + if (isStatement(node)) { + return [node]; + } + if (isExpressionNode(node)) { + return isExpressionStatement(node.parent) ? [node.parent] : node; + } + if (isStringLiteralJsxAttribute(node)) { + return node; } + return void 0; } - function updateImportsInOtherFiles(changes, program, host, oldFile, movedSymbols, targetFileName, quotePreference) { - const checker = program.getTypeChecker(); - for (const sourceFile of program.getSourceFiles()) { - if (sourceFile === oldFile) - continue; - for (const statement of sourceFile.statements) { - forEachImportInStatement(statement, (importNode) => { - if (checker.getSymbolAtLocation(moduleSpecifierFromImport(importNode)) !== oldFile.symbol) - return; - const shouldMove = (name) => { - const symbol = isBindingElement(name.parent) ? getPropertySymbolFromBindingElement(checker, name.parent) : skipAlias(checker.getSymbolAtLocation(name), checker); - return !!symbol && movedSymbols.has(symbol); - }; - deleteUnusedImports(sourceFile, importNode, changes, shouldMove); - const pathToTargetFileWithExtension = resolvePath(getDirectoryPath(oldFile.path), targetFileName); - const newModuleSpecifier = getModuleSpecifier(program.getCompilerOptions(), sourceFile, sourceFile.path, pathToTargetFileWithExtension, createModuleSpecifierResolutionHost(program, host)); - const newImportDeclaration = filterImport(importNode, makeStringLiteral(newModuleSpecifier, quotePreference), shouldMove); - if (newImportDeclaration) - changes.insertNodeAfter(sourceFile, statement, newImportDeclaration); - const ns = getNamespaceLikeImport(importNode); - if (ns) - updateNamespaceLikeImport(changes, sourceFile, checker, movedSymbols, newModuleSpecifier, ns, importNode, quotePreference); - }); + function isScope(node) { + return isArrowFunction(node) ? isFunctionBody(node.body) : isFunctionLikeDeclaration(node) || isSourceFile(node) || isModuleBlock(node) || isClassLike(node); + } + function collectEnclosingScopes(range) { + let current = isReadonlyArray(range.range) ? first(range.range) : range.range; + if (range.facts & 8 /* UsesThis */ && !(range.facts & 16 /* UsesThisInFunction */)) { + const containingClass = getContainingClass(current); + if (containingClass) { + const containingFunction = findAncestor(current, isFunctionLikeDeclaration); + return containingFunction ? [containingFunction, containingClass] : [containingClass]; + } + } + const scopes = []; + while (true) { + current = current.parent; + if (current.kind === 169 /* Parameter */) { + current = findAncestor(current, (parent2) => isFunctionLikeDeclaration(parent2)).parent; + } + if (isScope(current)) { + scopes.push(current); + if (current.kind === 312 /* SourceFile */) { + return scopes; + } } } } - function getNamespaceLikeImport(node) { - switch (node.kind) { - case 271 /* ImportDeclaration */: - return node.importClause && node.importClause.namedBindings && node.importClause.namedBindings.kind === 273 /* NamespaceImport */ ? node.importClause.namedBindings.name : void 0; - case 270 /* ImportEqualsDeclaration */: - return node.name; - case 259 /* VariableDeclaration */: - return tryCast(node.name, isIdentifier); + function getFunctionExtractionAtIndex(targetRange, context, requestedChangesIndex) { + const { scopes, readsAndWrites: { target, usagesPerScope, functionErrorsPerScope, exposedVariableDeclarations } } = getPossibleExtractionsWorker(targetRange, context); + Debug.assert(!functionErrorsPerScope[requestedChangesIndex].length, "The extraction went missing? How?"); + context.cancellationToken.throwIfCancellationRequested(); + return extractFunctionInScope(target, scopes[requestedChangesIndex], usagesPerScope[requestedChangesIndex], exposedVariableDeclarations, targetRange, context); + } + function getConstantExtractionAtIndex(targetRange, context, requestedChangesIndex) { + const { scopes, readsAndWrites: { target, usagesPerScope, constantErrorsPerScope, exposedVariableDeclarations } } = getPossibleExtractionsWorker(targetRange, context); + Debug.assert(!constantErrorsPerScope[requestedChangesIndex].length, "The extraction went missing? How?"); + Debug.assert(exposedVariableDeclarations.length === 0, "Extract constant accepted a range containing a variable declaration?"); + context.cancellationToken.throwIfCancellationRequested(); + const expression = isExpression(target) ? target : target.statements[0].expression; + return extractConstantInScope(expression, scopes[requestedChangesIndex], usagesPerScope[requestedChangesIndex], targetRange.facts, context); + } + function getPossibleExtractions(targetRange, context) { + const { scopes, readsAndWrites: { functionErrorsPerScope, constantErrorsPerScope } } = getPossibleExtractionsWorker(targetRange, context); + const extractions = scopes.map((scope, i) => { + const functionDescriptionPart = getDescriptionForFunctionInScope(scope); + const constantDescriptionPart = getDescriptionForConstantInScope(scope); + const scopeDescription = isFunctionLikeDeclaration(scope) ? getDescriptionForFunctionLikeDeclaration(scope) : isClassLike(scope) ? getDescriptionForClassLikeDeclaration(scope) : getDescriptionForModuleLikeDeclaration(scope); + let functionDescription; + let constantDescription; + if (scopeDescription === 1 /* Global */) { + functionDescription = formatStringFromArgs(getLocaleSpecificMessage(Diagnostics.Extract_to_0_in_1_scope), [functionDescriptionPart, "global"]); + constantDescription = formatStringFromArgs(getLocaleSpecificMessage(Diagnostics.Extract_to_0_in_1_scope), [constantDescriptionPart, "global"]); + } else if (scopeDescription === 0 /* Module */) { + functionDescription = formatStringFromArgs(getLocaleSpecificMessage(Diagnostics.Extract_to_0_in_1_scope), [functionDescriptionPart, "module"]); + constantDescription = formatStringFromArgs(getLocaleSpecificMessage(Diagnostics.Extract_to_0_in_1_scope), [constantDescriptionPart, "module"]); + } else { + functionDescription = formatStringFromArgs(getLocaleSpecificMessage(Diagnostics.Extract_to_0_in_1), [functionDescriptionPart, scopeDescription]); + constantDescription = formatStringFromArgs(getLocaleSpecificMessage(Diagnostics.Extract_to_0_in_1), [constantDescriptionPart, scopeDescription]); + } + if (i === 0 && !isClassLike(scope)) { + constantDescription = formatStringFromArgs(getLocaleSpecificMessage(Diagnostics.Extract_to_0_in_enclosing_scope), [constantDescriptionPart]); + } + return { + functionExtraction: { + description: functionDescription, + errors: functionErrorsPerScope[i] + }, + constantExtraction: { + description: constantDescription, + errors: constantErrorsPerScope[i] + } + }; + }); + return extractions; + } + function getPossibleExtractionsWorker(targetRange, context) { + const { file: sourceFile } = context; + const scopes = collectEnclosingScopes(targetRange); + const enclosingTextRange = getEnclosingTextRange(targetRange, sourceFile); + const readsAndWrites = collectReadsAndWrites( + targetRange, + scopes, + enclosingTextRange, + sourceFile, + context.program.getTypeChecker(), + context.cancellationToken + ); + return { scopes, readsAndWrites }; + } + function getDescriptionForFunctionInScope(scope) { + return isFunctionLikeDeclaration(scope) ? "inner function" : isClassLike(scope) ? "method" : "function"; + } + function getDescriptionForConstantInScope(scope) { + return isClassLike(scope) ? "readonly field" : "constant"; + } + function getDescriptionForFunctionLikeDeclaration(scope) { + switch (scope.kind) { + case 176 /* Constructor */: + return "constructor"; + case 218 /* FunctionExpression */: + case 262 /* FunctionDeclaration */: + return scope.name ? `function '${scope.name.text}'` : ANONYMOUS; + case 219 /* ArrowFunction */: + return "arrow function"; + case 174 /* MethodDeclaration */: + return `method '${scope.name.getText()}'`; + case 177 /* GetAccessor */: + return `'get ${scope.name.getText()}'`; + case 178 /* SetAccessor */: + return `'set ${scope.name.getText()}'`; default: - return Debug.assertNever(node, `Unexpected node kind ${node.kind}`); + Debug.assertNever(scope, `Unexpected scope kind ${scope.kind}`); } } - function updateNamespaceLikeImport(changes, sourceFile, checker, movedSymbols, newModuleSpecifier, oldImportId, oldImportNode, quotePreference) { - const preferredNewNamespaceName = ts_codefix_exports.moduleSpecifierToValidIdentifier(newModuleSpecifier, 99 /* ESNext */); - let needUniqueName = false; - const toChange = []; - ts_FindAllReferences_exports.Core.eachSymbolReferenceInFile(oldImportId, checker, sourceFile, (ref) => { - if (!isPropertyAccessExpression(ref.parent)) - return; - needUniqueName = needUniqueName || !!checker.resolveName( - preferredNewNamespaceName, - ref, - 67108863 /* All */, - /*excludeGlobals*/ - true + function getDescriptionForClassLikeDeclaration(scope) { + return scope.kind === 263 /* ClassDeclaration */ ? scope.name ? `class '${scope.name.text}'` : "anonymous class declaration" : scope.name ? `class expression '${scope.name.text}'` : "anonymous class expression"; + } + function getDescriptionForModuleLikeDeclaration(scope) { + return scope.kind === 268 /* ModuleBlock */ ? `namespace '${scope.parent.name.getText()}'` : scope.externalModuleIndicator ? 0 /* Module */ : 1 /* Global */; + } + function extractFunctionInScope(node, scope, { usages: usagesInScope, typeParameterUsages, substitutions }, exposedVariableDeclarations, range, context) { + const checker = context.program.getTypeChecker(); + const scriptTarget = getEmitScriptTarget(context.program.getCompilerOptions()); + const importAdder = ts_codefix_exports.createImportAdder(context.file, context.program, context.preferences, context.host); + const file = scope.getSourceFile(); + const functionNameText = getUniqueName(isClassLike(scope) ? "newMethod" : "newFunction", file); + const isJS = isInJSFile(scope); + const functionName = factory.createIdentifier(functionNameText); + let returnType; + const parameters = []; + const callArguments = []; + let writes; + usagesInScope.forEach((usage, name) => { + let typeNode; + if (!isJS) { + let type = checker.getTypeOfSymbolAtLocation(usage.symbol, usage.node); + type = checker.getBaseTypeOfLiteralType(type); + typeNode = ts_codefix_exports.typeToAutoImportableTypeNode(checker, importAdder, type, scope, scriptTarget, 1 /* NoTruncation */); + } + const paramDecl = factory.createParameterDeclaration( + /*modifiers*/ + void 0, + /*dotDotDotToken*/ + void 0, + /*name*/ + name, + /*questionToken*/ + void 0, + typeNode ); - if (movedSymbols.has(checker.getSymbolAtLocation(ref.parent.name))) { - toChange.push(ref); + parameters.push(paramDecl); + if (usage.usage === 2 /* Write */) { + (writes || (writes = [])).push(usage); } + callArguments.push(factory.createIdentifier(name)); }); - if (toChange.length) { - const newNamespaceName = needUniqueName ? getUniqueName(preferredNewNamespaceName, sourceFile) : preferredNewNamespaceName; - for (const ref of toChange) { - changes.replaceNode(sourceFile, ref, factory.createIdentifier(newNamespaceName)); + const typeParametersAndDeclarations = arrayFrom(typeParameterUsages.values(), (type) => ({ type, declaration: getFirstDeclarationBeforePosition(type, context.startPosition) })); + const sortedTypeParametersAndDeclarations = typeParametersAndDeclarations.sort(compareTypesByDeclarationOrder); + const typeParameters = sortedTypeParametersAndDeclarations.length === 0 ? void 0 : mapDefined(sortedTypeParametersAndDeclarations, ({ declaration }) => declaration); + const callTypeArguments = typeParameters !== void 0 ? typeParameters.map((decl) => factory.createTypeReferenceNode( + decl.name, + /*typeArguments*/ + void 0 + )) : void 0; + if (isExpression(node) && !isJS) { + const contextualType = checker.getContextualType(node); + returnType = checker.typeToTypeNode(contextualType, scope, 1 /* NoTruncation */); + } + const { body, returnValueProperty } = transformFunctionBody(node, exposedVariableDeclarations, writes, substitutions, !!(range.facts & 1 /* HasReturn */)); + suppressLeadingAndTrailingTrivia(body); + let newFunction; + const callThis = !!(range.facts & 16 /* UsesThisInFunction */); + if (isClassLike(scope)) { + const modifiers = isJS ? [] : [factory.createModifier(123 /* PrivateKeyword */)]; + if (range.facts & 32 /* InStaticRegion */) { + modifiers.push(factory.createModifier(126 /* StaticKeyword */)); } - changes.insertNodeAfter(sourceFile, oldImportNode, updateNamespaceLikeImportNode(oldImportNode, preferredNewNamespaceName, newModuleSpecifier, quotePreference)); + if (range.facts & 4 /* IsAsyncFunction */) { + modifiers.push(factory.createModifier(134 /* AsyncKeyword */)); + } + newFunction = factory.createMethodDeclaration( + modifiers.length ? modifiers : void 0, + range.facts & 2 /* IsGenerator */ ? factory.createToken(42 /* AsteriskToken */) : void 0, + functionName, + /*questionToken*/ + void 0, + typeParameters, + parameters, + returnType, + body + ); + } else { + if (callThis) { + parameters.unshift( + factory.createParameterDeclaration( + /*modifiers*/ + void 0, + /*dotDotDotToken*/ + void 0, + /*name*/ + "this", + /*questionToken*/ + void 0, + checker.typeToTypeNode( + checker.getTypeAtLocation(range.thisNode), + scope, + 1 /* NoTruncation */ + ), + /*initializer*/ + void 0 + ) + ); + } + newFunction = factory.createFunctionDeclaration( + range.facts & 4 /* IsAsyncFunction */ ? [factory.createToken(134 /* AsyncKeyword */)] : void 0, + range.facts & 2 /* IsGenerator */ ? factory.createToken(42 /* AsteriskToken */) : void 0, + functionName, + typeParameters, + parameters, + returnType, + body + ); } - } - function updateNamespaceLikeImportNode(node, newNamespaceName, newModuleSpecifier, quotePreference) { - const newNamespaceId = factory.createIdentifier(newNamespaceName); - const newModuleString = makeStringLiteral(newModuleSpecifier, quotePreference); - switch (node.kind) { - case 271 /* ImportDeclaration */: - return factory.createImportDeclaration( + const changeTracker = ts_textChanges_exports.ChangeTracker.fromContext(context); + const minInsertionPos = (isReadonlyArray(range.range) ? last(range.range) : range.range).end; + const nodeToInsertBefore = getNodeToInsertFunctionBefore(minInsertionPos, scope); + if (nodeToInsertBefore) { + changeTracker.insertNodeBefore( + context.file, + nodeToInsertBefore, + newFunction, + /*blankLineBetween*/ + true + ); + } else { + changeTracker.insertNodeAtEndOfScope(context.file, scope, newFunction); + } + importAdder.writeFixes(changeTracker); + const newNodes = []; + const called = getCalledExpression(scope, range, functionNameText); + if (callThis) { + callArguments.unshift(factory.createIdentifier("this")); + } + let call = factory.createCallExpression( + callThis ? factory.createPropertyAccessExpression( + called, + "call" + ) : called, + callTypeArguments, + // Note that no attempt is made to take advantage of type argument inference + callArguments + ); + if (range.facts & 2 /* IsGenerator */) { + call = factory.createYieldExpression(factory.createToken(42 /* AsteriskToken */), call); + } + if (range.facts & 4 /* IsAsyncFunction */) { + call = factory.createAwaitExpression(call); + } + if (isInJSXContent(node)) { + call = factory.createJsxExpression( + /*dotDotDotToken*/ + void 0, + call + ); + } + if (exposedVariableDeclarations.length && !writes) { + Debug.assert(!returnValueProperty, "Expected no returnValueProperty"); + Debug.assert(!(range.facts & 1 /* HasReturn */), "Expected RangeFacts.HasReturn flag to be unset"); + if (exposedVariableDeclarations.length === 1) { + const variableDeclaration = exposedVariableDeclarations[0]; + newNodes.push(factory.createVariableStatement( /*modifiers*/ void 0, - factory.createImportClause( - /*isTypeOnly*/ - false, + factory.createVariableDeclarationList( + [factory.createVariableDeclaration( + getSynthesizedDeepClone(variableDeclaration.name), + /*exclamationToken*/ + void 0, + /*type*/ + getSynthesizedDeepClone(variableDeclaration.type), + /*initializer*/ + call + )], + variableDeclaration.parent.flags + ) + )); + } else { + const bindingElements = []; + const typeElements = []; + let commonNodeFlags = exposedVariableDeclarations[0].parent.flags; + let sawExplicitType = false; + for (const variableDeclaration of exposedVariableDeclarations) { + bindingElements.push(factory.createBindingElement( + /*dotDotDotToken*/ + void 0, + /*propertyName*/ + void 0, /*name*/ + getSynthesizedDeepClone(variableDeclaration.name) + )); + const variableType = checker.typeToTypeNode( + checker.getBaseTypeOfLiteralType(checker.getTypeAtLocation(variableDeclaration)), + scope, + 1 /* NoTruncation */ + ); + typeElements.push(factory.createPropertySignature( + /*modifiers*/ void 0, - factory.createNamespaceImport(newNamespaceId) - ), - newModuleString, - /*assertClause*/ - void 0 - ); - case 270 /* ImportEqualsDeclaration */: - return factory.createImportEqualsDeclaration( + /*name*/ + variableDeclaration.symbol.name, + /*questionToken*/ + void 0, + /*type*/ + variableType + )); + sawExplicitType = sawExplicitType || variableDeclaration.type !== void 0; + commonNodeFlags = commonNodeFlags & variableDeclaration.parent.flags; + } + const typeLiteral = sawExplicitType ? factory.createTypeLiteralNode(typeElements) : void 0; + if (typeLiteral) { + setEmitFlags(typeLiteral, 1 /* SingleLine */); + } + newNodes.push(factory.createVariableStatement( /*modifiers*/ void 0, - /*isTypeOnly*/ - false, - newNamespaceId, - factory.createExternalModuleReference(newModuleString) - ); - case 259 /* VariableDeclaration */: - return factory.createVariableDeclaration( - newNamespaceId, - /*exclamationToken*/ - void 0, - /*type*/ + factory.createVariableDeclarationList( + [factory.createVariableDeclaration( + factory.createObjectBindingPattern(bindingElements), + /*exclamationToken*/ + void 0, + /*type*/ + typeLiteral, + /*initializer*/ + call + )], + commonNodeFlags + ) + )); + } + } else if (exposedVariableDeclarations.length || writes) { + if (exposedVariableDeclarations.length) { + for (const variableDeclaration of exposedVariableDeclarations) { + let flags = variableDeclaration.parent.flags; + if (flags & 2 /* Const */) { + flags = flags & ~2 /* Const */ | 1 /* Let */; + } + newNodes.push(factory.createVariableStatement( + /*modifiers*/ + void 0, + factory.createVariableDeclarationList( + [factory.createVariableDeclaration( + variableDeclaration.symbol.name, + /*exclamationToken*/ + void 0, + getTypeDeepCloneUnionUndefined(variableDeclaration.type) + )], + flags + ) + )); + } + } + if (returnValueProperty) { + newNodes.push(factory.createVariableStatement( + /*modifiers*/ void 0, - createRequireCall(newModuleString) - ); - default: - return Debug.assertNever(node, `Unexpected node kind ${node.kind}`); - } - } - function createRequireCall(moduleSpecifier) { - return factory.createCallExpression( - factory.createIdentifier("require"), - /*typeArguments*/ - void 0, - [moduleSpecifier] - ); - } - function moduleSpecifierFromImport(i) { - return i.kind === 271 /* ImportDeclaration */ ? i.moduleSpecifier : i.kind === 270 /* ImportEqualsDeclaration */ ? i.moduleReference.expression : i.initializer.arguments[0]; - } - function forEachImportInStatement(statement, cb) { - if (isImportDeclaration(statement)) { - if (isStringLiteral(statement.moduleSpecifier)) - cb(statement); - } else if (isImportEqualsDeclaration(statement)) { - if (isExternalModuleReference(statement.moduleReference) && isStringLiteralLike(statement.moduleReference.expression)) { - cb(statement); + factory.createVariableDeclarationList( + [factory.createVariableDeclaration( + returnValueProperty, + /*exclamationToken*/ + void 0, + getTypeDeepCloneUnionUndefined(returnType) + )], + 1 /* Let */ + ) + )); } - } else if (isVariableStatement(statement)) { - for (const decl of statement.declarationList.declarations) { - if (decl.initializer && isRequireCall( - decl.initializer, - /*requireStringLiteralLikeArgument*/ - true - )) { - cb(decl); + const assignments = getPropertyAssignmentsForWritesAndVariableDeclarations(exposedVariableDeclarations, writes); + if (returnValueProperty) { + assignments.unshift(factory.createShorthandPropertyAssignment(returnValueProperty)); + } + if (assignments.length === 1) { + Debug.assert(!returnValueProperty, "Shouldn't have returnValueProperty here"); + newNodes.push(factory.createExpressionStatement(factory.createAssignment(assignments[0].name, call))); + if (range.facts & 1 /* HasReturn */) { + newNodes.push(factory.createReturnStatement()); + } + } else { + newNodes.push(factory.createExpressionStatement(factory.createAssignment(factory.createObjectLiteralExpression(assignments), call))); + if (returnValueProperty) { + newNodes.push(factory.createReturnStatement(factory.createIdentifier(returnValueProperty))); } } - } - } - function createOldFileImportsFromTargetFile(sourceFile, targetFileNeedExport, targetFileNameWithExtension, program, host, useEs6Imports, quotePreference) { - let defaultImport; - const imports = []; - targetFileNeedExport.forEach((symbol) => { - if (symbol.escapedName === "default" /* Default */) { - defaultImport = factory.createIdentifier(symbolNameNoDefault(symbol)); + } else { + if (range.facts & 1 /* HasReturn */) { + newNodes.push(factory.createReturnStatement(call)); + } else if (isReadonlyArray(range.range)) { + newNodes.push(factory.createExpressionStatement(call)); } else { - imports.push(symbol.name); + newNodes.push(call); } - }); - return makeImportOrRequire(sourceFile, defaultImport, imports, targetFileNameWithExtension, program, host, useEs6Imports, quotePreference); - } - function makeImportOrRequire(sourceFile, defaultImport, imports, targetFileNameWithExtension, program, host, useEs6Imports, quotePreference) { - const pathToTargetFile = resolvePath(getDirectoryPath(sourceFile.path), targetFileNameWithExtension); - const pathToTargetFileWithCorrectExtension = getModuleSpecifier(program.getCompilerOptions(), sourceFile, sourceFile.path, pathToTargetFile, createModuleSpecifierResolutionHost(program, host)); - if (useEs6Imports) { - const specifiers = imports.map((i) => factory.createImportSpecifier( - /*isTypeOnly*/ - false, - /*propertyName*/ - void 0, - factory.createIdentifier(i) - )); - return makeImportIfNecessary(defaultImport, specifiers, pathToTargetFileWithCorrectExtension, quotePreference); + } + if (isReadonlyArray(range.range)) { + changeTracker.replaceNodeRangeWithNodes(context.file, first(range.range), last(range.range), newNodes); } else { - Debug.assert(!defaultImport, "No default import should exist"); - const bindingElements = imports.map((i) => factory.createBindingElement( - /*dotDotDotToken*/ - void 0, - /*propertyName*/ - void 0, - i - )); - return bindingElements.length ? makeVariableStatement( - factory.createObjectBindingPattern(bindingElements), - /*type*/ - void 0, - createRequireCall(makeStringLiteral(pathToTargetFileWithCorrectExtension, quotePreference)) - ) : void 0; + changeTracker.replaceNodeWithNodes(context.file, range.range, newNodes); } - } - function makeVariableStatement(name, type, initializer, flags = 2 /* Const */) { - return factory.createVariableStatement( - /*modifiers*/ - void 0, - factory.createVariableDeclarationList([factory.createVariableDeclaration( - name, - /*exclamationToken*/ - void 0, - type, - initializer - )], flags) + const edits = changeTracker.getChanges(); + const renameRange = isReadonlyArray(range.range) ? first(range.range) : range.range; + const renameFilename = renameRange.getSourceFile().fileName; + const renameLocation = getRenameLocation( + edits, + renameFilename, + functionNameText, + /*preferLastLocation*/ + false ); - } - function addExports(sourceFile, toMove, needExport, useEs6Exports) { - return flatMap(toMove, (statement) => { - if (isTopLevelDeclarationStatement(statement) && !isExported(sourceFile, statement, useEs6Exports) && forEachTopLevelDeclaration(statement, (d) => { - var _a; - return needExport.has(Debug.checkDefined((_a = tryCast(d, canHaveSymbol)) == null ? void 0 : _a.symbol)); - })) { - const exports = addExport(getSynthesizedDeepClone(statement), useEs6Exports); - if (exports) - return exports; + return { renameFilename, renameLocation, edits }; + function getTypeDeepCloneUnionUndefined(typeNode) { + if (typeNode === void 0) { + return void 0; } - return getSynthesizedDeepClone(statement); - }); - } - function isExported(sourceFile, decl, useEs6Exports, name) { - var _a; - if (useEs6Exports) { - return !isExpressionStatement(decl) && hasSyntacticModifier(decl, 1 /* Export */) || !!(name && sourceFile.symbol && ((_a = sourceFile.symbol.exports) == null ? void 0 : _a.has(name.escapedText))); - } - return !!sourceFile.symbol && !!sourceFile.symbol.exports && getNamesToExportInCommonJS(decl).some((name2) => sourceFile.symbol.exports.has(escapeLeadingUnderscores(name2))); - } - function deleteUnusedImports(sourceFile, importDecl, changes, isUnused) { - switch (importDecl.kind) { - case 271 /* ImportDeclaration */: - deleteUnusedImportsInDeclaration(sourceFile, importDecl, changes, isUnused); - break; - case 270 /* ImportEqualsDeclaration */: - if (isUnused(importDecl.name)) { - changes.delete(sourceFile, importDecl); - } - break; - case 259 /* VariableDeclaration */: - deleteUnusedImportsInVariableDeclaration(sourceFile, importDecl, changes, isUnused); - break; - default: - Debug.assertNever(importDecl, `Unexpected import decl kind ${importDecl.kind}`); + const clone2 = getSynthesizedDeepClone(typeNode); + let withoutParens = clone2; + while (isParenthesizedTypeNode(withoutParens)) { + withoutParens = withoutParens.type; + } + return isUnionTypeNode(withoutParens) && find(withoutParens.types, (t) => t.kind === 157 /* UndefinedKeyword */) ? clone2 : factory.createUnionTypeNode([clone2, factory.createKeywordTypeNode(157 /* UndefinedKeyword */)]); } } - function deleteUnusedImportsInDeclaration(sourceFile, importDecl, changes, isUnused) { - if (!importDecl.importClause) - return; - const { name, namedBindings } = importDecl.importClause; - const defaultUnused = !name || isUnused(name); - const namedBindingsUnused = !namedBindings || (namedBindings.kind === 273 /* NamespaceImport */ ? isUnused(namedBindings.name) : namedBindings.elements.length !== 0 && namedBindings.elements.every((e) => isUnused(e.name))); - if (defaultUnused && namedBindingsUnused) { - changes.delete(sourceFile, importDecl); - } else { - if (name && defaultUnused) { - changes.delete(sourceFile, name); + function extractConstantInScope(node, scope, { substitutions }, rangeFacts, context) { + const checker = context.program.getTypeChecker(); + const file = scope.getSourceFile(); + const localNameText = isPropertyAccessExpression(node) && !isClassLike(scope) && !checker.resolveName( + node.name.text, + node, + 111551 /* Value */, + /*excludeGlobals*/ + false + ) && !isPrivateIdentifier(node.name) && !identifierToKeywordKind(node.name) ? node.name.text : getUniqueName(isClassLike(scope) ? "newProperty" : "newLocal", file); + const isJS = isInJSFile(scope); + let variableType = isJS || !checker.isContextSensitive(node) ? void 0 : checker.typeToTypeNode(checker.getContextualType(node), scope, 1 /* NoTruncation */); + let initializer = transformConstantInitializer(skipParentheses(node), substitutions); + ({ variableType, initializer } = transformFunctionInitializerAndType(variableType, initializer)); + suppressLeadingAndTrailingTrivia(initializer); + const changeTracker = ts_textChanges_exports.ChangeTracker.fromContext(context); + if (isClassLike(scope)) { + Debug.assert(!isJS, "Cannot extract to a JS class"); + const modifiers = []; + modifiers.push(factory.createModifier(123 /* PrivateKeyword */)); + if (rangeFacts & 32 /* InStaticRegion */) { + modifiers.push(factory.createModifier(126 /* StaticKeyword */)); } - if (namedBindings) { - if (namedBindingsUnused) { - changes.replaceNode( - sourceFile, - importDecl.importClause, - factory.updateImportClause( - importDecl.importClause, - importDecl.importClause.isTypeOnly, - name, - /*namedBindings*/ - void 0 - ) + modifiers.push(factory.createModifier(148 /* ReadonlyKeyword */)); + const newVariable = factory.createPropertyDeclaration( + modifiers, + localNameText, + /*questionOrExclamationToken*/ + void 0, + variableType, + initializer + ); + let localReference = factory.createPropertyAccessExpression( + rangeFacts & 32 /* InStaticRegion */ ? factory.createIdentifier(scope.name.getText()) : factory.createThis(), + factory.createIdentifier(localNameText) + ); + if (isInJSXContent(node)) { + localReference = factory.createJsxExpression( + /*dotDotDotToken*/ + void 0, + localReference + ); + } + const maxInsertionPos = node.pos; + const nodeToInsertBefore = getNodeToInsertPropertyBefore(maxInsertionPos, scope); + changeTracker.insertNodeBefore( + context.file, + nodeToInsertBefore, + newVariable, + /*blankLineBetween*/ + true + ); + changeTracker.replaceNode(context.file, node, localReference); + } else { + const newVariableDeclaration = factory.createVariableDeclaration( + localNameText, + /*exclamationToken*/ + void 0, + variableType, + initializer + ); + const oldVariableDeclaration = getContainingVariableDeclarationIfInList(node, scope); + if (oldVariableDeclaration) { + changeTracker.insertNodeBefore(context.file, oldVariableDeclaration, newVariableDeclaration); + const localReference = factory.createIdentifier(localNameText); + changeTracker.replaceNode(context.file, node, localReference); + } else if (node.parent.kind === 244 /* ExpressionStatement */ && scope === findAncestor(node, isScope)) { + const newVariableStatement = factory.createVariableStatement( + /*modifiers*/ + void 0, + factory.createVariableDeclarationList([newVariableDeclaration], 2 /* Const */) + ); + changeTracker.replaceNode(context.file, node.parent, newVariableStatement); + } else { + const newVariableStatement = factory.createVariableStatement( + /*modifiers*/ + void 0, + factory.createVariableDeclarationList([newVariableDeclaration], 2 /* Const */) + ); + const nodeToInsertBefore = getNodeToInsertConstantBefore(node, scope); + if (nodeToInsertBefore.pos === 0) { + changeTracker.insertNodeAtTopOfFile( + context.file, + newVariableStatement, + /*blankLineBetween*/ + false + ); + } else { + changeTracker.insertNodeBefore( + context.file, + nodeToInsertBefore, + newVariableStatement, + /*blankLineBetween*/ + false ); - } else if (namedBindings.kind === 274 /* NamedImports */) { - for (const element of namedBindings.elements) { - if (isUnused(element.name)) - changes.delete(sourceFile, element); - } } - } - } - } - function deleteUnusedImportsInVariableDeclaration(sourceFile, varDecl, changes, isUnused) { - const { name } = varDecl; - switch (name.kind) { - case 80 /* Identifier */: - if (isUnused(name)) { - if (varDecl.initializer && isRequireCall( - varDecl.initializer, - /*requireStringLiteralLikeArgument*/ - true - )) { - changes.delete( - sourceFile, - isVariableDeclarationList(varDecl.parent) && length(varDecl.parent.declarations) === 1 ? varDecl.parent.parent : varDecl + if (node.parent.kind === 244 /* ExpressionStatement */) { + changeTracker.delete(context.file, node.parent); + } else { + let localReference = factory.createIdentifier(localNameText); + if (isInJSXContent(node)) { + localReference = factory.createJsxExpression( + /*dotDotDotToken*/ + void 0, + localReference ); - } else { - changes.delete(sourceFile, name); } + changeTracker.replaceNode(context.file, node, localReference); } - break; - case 206 /* ArrayBindingPattern */: - break; - case 205 /* ObjectBindingPattern */: - if (name.elements.every((e) => isIdentifier(e.name) && isUnused(e.name))) { - changes.delete( - sourceFile, - isVariableDeclarationList(varDecl.parent) && varDecl.parent.declarations.length === 1 ? varDecl.parent.parent : varDecl - ); + } + } + const edits = changeTracker.getChanges(); + const renameFilename = node.getSourceFile().fileName; + const renameLocation = getRenameLocation( + edits, + renameFilename, + localNameText, + /*preferLastLocation*/ + true + ); + return { renameFilename, renameLocation, edits }; + function transformFunctionInitializerAndType(variableType2, initializer2) { + if (variableType2 === void 0) + return { variableType: variableType2, initializer: initializer2 }; + if (!isFunctionExpression(initializer2) && !isArrowFunction(initializer2) || !!initializer2.typeParameters) + return { variableType: variableType2, initializer: initializer2 }; + const functionType = checker.getTypeAtLocation(node); + const functionSignature = singleOrUndefined(checker.getSignaturesOfType(functionType, 0 /* Call */)); + if (!functionSignature) + return { variableType: variableType2, initializer: initializer2 }; + if (!!functionSignature.getTypeParameters()) + return { variableType: variableType2, initializer: initializer2 }; + const parameters = []; + let hasAny = false; + for (const p of initializer2.parameters) { + if (p.type) { + parameters.push(p); } else { - for (const element of name.elements) { - if (isIdentifier(element.name) && isUnused(element.name)) { - changes.delete(sourceFile, element.name); - } + const paramType = checker.getTypeAtLocation(p); + if (paramType === checker.getAnyType()) + hasAny = true; + parameters.push(factory.updateParameterDeclaration(p, p.modifiers, p.dotDotDotToken, p.name, p.questionToken, p.type || checker.typeToTypeNode(paramType, scope, 1 /* NoTruncation */), p.initializer)); + } + } + if (hasAny) + return { variableType: variableType2, initializer: initializer2 }; + variableType2 = void 0; + if (isArrowFunction(initializer2)) { + initializer2 = factory.updateArrowFunction(initializer2, canHaveModifiers(node) ? getModifiers(node) : void 0, initializer2.typeParameters, parameters, initializer2.type || checker.typeToTypeNode(functionSignature.getReturnType(), scope, 1 /* NoTruncation */), initializer2.equalsGreaterThanToken, initializer2.body); + } else { + if (functionSignature && !!functionSignature.thisParameter) { + const firstParameter = firstOrUndefined(parameters); + if (!firstParameter || isIdentifier(firstParameter.name) && firstParameter.name.escapedText !== "this") { + const thisType = checker.getTypeOfSymbolAtLocation(functionSignature.thisParameter, node); + parameters.splice( + 0, + 0, + factory.createParameterDeclaration( + /*modifiers*/ + void 0, + /*dotDotDotToken*/ + void 0, + "this", + /*questionToken*/ + void 0, + checker.typeToTypeNode(thisType, scope, 1 /* NoTruncation */) + ) + ); } } - break; + initializer2 = factory.updateFunctionExpression(initializer2, canHaveModifiers(node) ? getModifiers(node) : void 0, initializer2.asteriskToken, initializer2.name, initializer2.typeParameters, parameters, initializer2.type || checker.typeToTypeNode(functionSignature.getReturnType(), scope, 1 /* NoTruncation */), initializer2.body); + } + return { variableType: variableType2, initializer: initializer2 }; } } - function isTopLevelDeclarationStatement(node) { - Debug.assert(isSourceFile(node.parent), "Node parent should be a SourceFile"); - return isNonVariableTopLevelDeclaration(node) || isVariableStatement(node); - } - function addExport(decl, useEs6Exports) { - return useEs6Exports ? [addEs6Export(decl)] : addCommonjsExport(decl); - } - function addEs6Export(d) { - const modifiers = canHaveModifiers(d) ? concatenate([factory.createModifier(95 /* ExportKeyword */)], getModifiers(d)) : void 0; - switch (d.kind) { - case 261 /* FunctionDeclaration */: - return factory.updateFunctionDeclaration(d, modifiers, d.asteriskToken, d.name, d.typeParameters, d.parameters, d.type, d.body); - case 262 /* ClassDeclaration */: - const decorators = canHaveDecorators(d) ? getDecorators(d) : void 0; - return factory.updateClassDeclaration(d, concatenate(decorators, modifiers), d.name, d.typeParameters, d.heritageClauses, d.members); - case 242 /* VariableStatement */: - return factory.updateVariableStatement(d, modifiers, d.declarationList); - case 266 /* ModuleDeclaration */: - return factory.updateModuleDeclaration(d, modifiers, d.name, d.body); - case 265 /* EnumDeclaration */: - return factory.updateEnumDeclaration(d, modifiers, d.name, d.members); - case 264 /* TypeAliasDeclaration */: - return factory.updateTypeAliasDeclaration(d, modifiers, d.name, d.typeParameters, d.type); - case 263 /* InterfaceDeclaration */: - return factory.updateInterfaceDeclaration(d, modifiers, d.name, d.typeParameters, d.heritageClauses, d.members); - case 270 /* ImportEqualsDeclaration */: - return factory.updateImportEqualsDeclaration(d, modifiers, d.isTypeOnly, d.name, d.moduleReference); - case 243 /* ExpressionStatement */: - return Debug.fail(); - default: - return Debug.assertNever(d, `Unexpected declaration kind ${d.kind}`); + function getContainingVariableDeclarationIfInList(node, scope) { + let prevNode; + while (node !== void 0 && node !== scope) { + if (isVariableDeclaration(node) && node.initializer === prevNode && isVariableDeclarationList(node.parent) && node.parent.declarations.length > 1) { + return node; + } + prevNode = node; + node = node.parent; } } - function addCommonjsExport(decl) { - return [decl, ...getNamesToExportInCommonJS(decl).map(createExportAssignment)]; + function getFirstDeclarationBeforePosition(type, position) { + let firstDeclaration; + const symbol = type.symbol; + if (symbol && symbol.declarations) { + for (const declaration of symbol.declarations) { + if ((firstDeclaration === void 0 || declaration.pos < firstDeclaration.pos) && declaration.pos < position) { + firstDeclaration = declaration; + } + } + } + return firstDeclaration; } - function createExportAssignment(name) { - return factory.createExpressionStatement( - factory.createBinaryExpression( - factory.createPropertyAccessExpression(factory.createIdentifier("exports"), factory.createIdentifier(name)), - 64 /* EqualsToken */, - factory.createIdentifier(name) - ) - ); + function compareTypesByDeclarationOrder({ type: type1, declaration: declaration1 }, { type: type2, declaration: declaration2 }) { + return compareProperties(declaration1, declaration2, "pos", compareValues) || compareStringsCaseSensitive( + type1.symbol ? type1.symbol.getName() : "", + type2.symbol ? type2.symbol.getName() : "" + ) || compareValues(type1.id, type2.id); } - function getNamesToExportInCommonJS(decl) { - switch (decl.kind) { - case 261 /* FunctionDeclaration */: - case 262 /* ClassDeclaration */: - return [decl.name.text]; - case 242 /* VariableStatement */: - return mapDefined(decl.declarationList.declarations, (d) => isIdentifier(d.name) ? d.name.text : void 0); - case 266 /* ModuleDeclaration */: - case 265 /* EnumDeclaration */: - case 264 /* TypeAliasDeclaration */: - case 263 /* InterfaceDeclaration */: - case 270 /* ImportEqualsDeclaration */: - return emptyArray; - case 243 /* ExpressionStatement */: - return Debug.fail("Can't export an ExpressionStatement"); - default: - return Debug.assertNever(decl, `Unexpected decl kind ${decl.kind}`); + function getCalledExpression(scope, range, functionNameText) { + const functionReference = factory.createIdentifier(functionNameText); + if (isClassLike(scope)) { + const lhs = range.facts & 32 /* InStaticRegion */ ? factory.createIdentifier(scope.name.text) : factory.createThis(); + return factory.createPropertyAccessExpression(lhs, functionReference); + } else { + return functionReference; } } - function filterImport(i, moduleSpecifier, keep) { - switch (i.kind) { - case 271 /* ImportDeclaration */: { - const clause = i.importClause; - if (!clause) - return void 0; - const defaultImport = clause.name && keep(clause.name) ? clause.name : void 0; - const namedBindings = clause.namedBindings && filterNamedBindings(clause.namedBindings, keep); - return defaultImport || namedBindings ? factory.createImportDeclaration( - /*modifiers*/ - void 0, - factory.createImportClause(clause.isTypeOnly, defaultImport, namedBindings), - getSynthesizedDeepClone(moduleSpecifier), - /*assertClause*/ - void 0 - ) : void 0; + function transformFunctionBody(body, exposedVariableDeclarations, writes, substitutions, hasReturn2) { + const hasWritesOrVariableDeclarations = writes !== void 0 || exposedVariableDeclarations.length > 0; + if (isBlock(body) && !hasWritesOrVariableDeclarations && substitutions.size === 0) { + return { body: factory.createBlock( + body.statements, + /*multiLine*/ + true + ), returnValueProperty: void 0 }; + } + let returnValueProperty; + let ignoreReturns = false; + const statements = factory.createNodeArray(isBlock(body) ? body.statements.slice(0) : [isStatement(body) ? body : factory.createReturnStatement(skipParentheses(body))]); + if (hasWritesOrVariableDeclarations || substitutions.size) { + const rewrittenStatements = visitNodes2(statements, visitor, isStatement).slice(); + if (hasWritesOrVariableDeclarations && !hasReturn2 && isStatement(body)) { + const assignments = getPropertyAssignmentsForWritesAndVariableDeclarations(exposedVariableDeclarations, writes); + if (assignments.length === 1) { + rewrittenStatements.push(factory.createReturnStatement(assignments[0].name)); + } else { + rewrittenStatements.push(factory.createReturnStatement(factory.createObjectLiteralExpression(assignments))); + } } - case 270 /* ImportEqualsDeclaration */: - return keep(i.name) ? i : void 0; - case 259 /* VariableDeclaration */: { - const name = filterBindingName(i.name, keep); - return name ? makeVariableStatement(name, i.type, createRequireCall(moduleSpecifier), i.parent.flags) : void 0; + return { body: factory.createBlock( + rewrittenStatements, + /*multiLine*/ + true + ), returnValueProperty }; + } else { + return { body: factory.createBlock( + statements, + /*multiLine*/ + true + ), returnValueProperty: void 0 }; + } + function visitor(node) { + if (!ignoreReturns && isReturnStatement(node) && hasWritesOrVariableDeclarations) { + const assignments = getPropertyAssignmentsForWritesAndVariableDeclarations(exposedVariableDeclarations, writes); + if (node.expression) { + if (!returnValueProperty) { + returnValueProperty = "__return"; + } + assignments.unshift(factory.createPropertyAssignment(returnValueProperty, visitNode(node.expression, visitor, isExpression))); + } + if (assignments.length === 1) { + return factory.createReturnStatement(assignments[0].name); + } else { + return factory.createReturnStatement(factory.createObjectLiteralExpression(assignments)); + } + } else { + const oldIgnoreReturns = ignoreReturns; + ignoreReturns = ignoreReturns || isFunctionLikeDeclaration(node) || isClassLike(node); + const substitution = substitutions.get(getNodeId(node).toString()); + const result = substitution ? getSynthesizedDeepClone(substitution) : visitEachChild(node, visitor, nullTransformationContext); + ignoreReturns = oldIgnoreReturns; + return result; } - default: - return Debug.assertNever(i, `Unexpected import kind ${i.kind}`); } } - function filterNamedBindings(namedBindings, keep) { - if (namedBindings.kind === 273 /* NamespaceImport */) { - return keep(namedBindings.name) ? namedBindings : void 0; - } else { - const newElements = namedBindings.elements.filter((e) => keep(e.name)); - return newElements.length ? factory.createNamedImports(newElements) : void 0; + function transformConstantInitializer(initializer, substitutions) { + return substitutions.size ? visitor(initializer) : initializer; + function visitor(node) { + const substitution = substitutions.get(getNodeId(node).toString()); + return substitution ? getSynthesizedDeepClone(substitution) : visitEachChild(node, visitor, nullTransformationContext); } } - function filterBindingName(name, keep) { - switch (name.kind) { - case 80 /* Identifier */: - return keep(name) ? name : void 0; - case 206 /* ArrayBindingPattern */: - return name; - case 205 /* ObjectBindingPattern */: { - const newElements = name.elements.filter((prop) => prop.propertyName || !isIdentifier(prop.name) || keep(prop.name)); - return newElements.length ? factory.createObjectBindingPattern(newElements) : void 0; + function getStatementsOrClassElements(scope) { + if (isFunctionLikeDeclaration(scope)) { + const body = scope.body; + if (isBlock(body)) { + return body.statements; } + } else if (isModuleBlock(scope) || isSourceFile(scope)) { + return scope.statements; + } else if (isClassLike(scope)) { + return scope.members; + } else { + assertType(scope); } + return emptyArray; } - function nameOfTopLevelDeclaration(d) { - return isExpressionStatement(d) ? tryCast(d.expression.left.name, isIdentifier) : tryCast(d.name, isIdentifier); + function getNodeToInsertFunctionBefore(minPos, scope) { + return find(getStatementsOrClassElements(scope), (child) => child.pos >= minPos && isFunctionLikeDeclaration(child) && !isConstructorDeclaration(child)); } - function getTopLevelDeclarationStatement(d) { - switch (d.kind) { - case 259 /* VariableDeclaration */: - return d.parent.parent; - case 207 /* BindingElement */: - return getTopLevelDeclarationStatement( - cast(d.parent.parent, (p) => isVariableDeclaration(p) || isBindingElement(p)) - ); - default: - return d; + function getNodeToInsertPropertyBefore(maxPos, scope) { + const members = scope.members; + Debug.assert(members.length > 0, "Found no members"); + let prevMember; + let allProperties = true; + for (const member of members) { + if (member.pos > maxPos) { + return prevMember || members[0]; + } + if (allProperties && !isPropertyDeclaration(member)) { + if (prevMember !== void 0) { + return member; + } + allProperties = false; + } + prevMember = member; } + if (prevMember === void 0) + return Debug.fail(); + return prevMember; } - function addExportToChanges(sourceFile, decl, name, changes, useEs6Exports) { - if (isExported(sourceFile, decl, useEs6Exports, name)) - return; - if (useEs6Exports) { - if (!isExpressionStatement(decl)) - changes.insertExportModifier(sourceFile, decl); - } else { - const names = getNamesToExportInCommonJS(decl); - if (names.length !== 0) - changes.insertNodesAfter(sourceFile, decl, names.map(createExportAssignment)); + function getNodeToInsertConstantBefore(node, scope) { + Debug.assert(!isClassLike(scope)); + let prevScope; + for (let curr = node; curr !== scope; curr = curr.parent) { + if (isScope(curr)) { + prevScope = curr; + } } - } - function createNewFileName(oldFile, program, context, host) { - const checker = program.getTypeChecker(); - const toMove = getStatementsToMove(context); - let usage; - if (toMove) { - usage = getUsageInfo(oldFile, toMove.all, checker); - const currentDirectory = getDirectoryPath(oldFile.fileName); - const extension = extensionFromPath(oldFile.fileName); - const newFileName = combinePaths( - // new file is always placed in the same directory as the old file - currentDirectory, - // ensures the filename computed below isn't already taken - makeUniqueFilename( - // infers a name for the new file from the symbols being moved - inferNewFileName(usage.oldFileImportsFromTargetFile, usage.movedSymbols), - extension, - currentDirectory, - host - ) - ) + extension; - return newFileName; + for (let curr = (prevScope || node).parent; ; curr = curr.parent) { + if (isBlockLike(curr)) { + let prevStatement; + for (const statement of curr.statements) { + if (statement.pos > node.pos) { + break; + } + prevStatement = statement; + } + if (!prevStatement && isCaseClause(curr)) { + Debug.assert(isSwitchStatement(curr.parent.parent), "Grandparent isn't a switch statement"); + return curr.parent.parent; + } + return Debug.checkDefined(prevStatement, "prevStatement failed to get set"); + } + Debug.assert(curr !== scope, "Didn't encounter a block-like before encountering scope"); } - return ""; } - function getRangeToMove(context) { - const { file } = context; - const range = createTextRangeFromSpan(getRefactorContextSpan(context)); - const { statements } = file; - const startNodeIndex = findIndex(statements, (s) => s.end > range.pos); - if (startNodeIndex === -1) - return void 0; - const startStatement = statements[startNodeIndex]; - if (isNamedDeclaration(startStatement) && startStatement.name && rangeContainsRange(startStatement.name, range)) { - return { toMove: [statements[startNodeIndex]], afterLast: statements[startNodeIndex + 1] }; - } - if (range.pos > startStatement.getStart(file)) - return void 0; - const afterEndNodeIndex = findIndex(statements, (s) => s.end > range.end, startNodeIndex); - if (afterEndNodeIndex !== -1 && (afterEndNodeIndex === 0 || statements[afterEndNodeIndex].getStart(file) < range.end)) - return void 0; - return { - toMove: statements.slice(startNodeIndex, afterEndNodeIndex === -1 ? statements.length : afterEndNodeIndex), - afterLast: afterEndNodeIndex === -1 ? void 0 : statements[afterEndNodeIndex] - }; + function getPropertyAssignmentsForWritesAndVariableDeclarations(exposedVariableDeclarations, writes) { + const variableAssignments = map(exposedVariableDeclarations, (v) => factory.createShorthandPropertyAssignment(v.symbol.name)); + const writeAssignments = map(writes, (w) => factory.createShorthandPropertyAssignment(w.symbol.name)); + return variableAssignments === void 0 ? writeAssignments : writeAssignments === void 0 ? variableAssignments : variableAssignments.concat(writeAssignments); } - function getStatementsToMove(context) { - const rangeToMove = getRangeToMove(context); - if (rangeToMove === void 0) - return void 0; - const all = []; - const ranges = []; - const { toMove, afterLast } = rangeToMove; - getRangesWhere(toMove, isAllowedStatementToMove, (start, afterEndIndex) => { - for (let i = start; i < afterEndIndex; i++) - all.push(toMove[i]); - ranges.push({ first: toMove[start], afterLast }); - }); - return all.length === 0 ? void 0 : { all, ranges }; + function isReadonlyArray(v) { + return isArray(v); } - function isAllowedStatementToMove(statement) { - return !isPureImport(statement) && !isPrologueDirective(statement); + function getEnclosingTextRange(targetRange, sourceFile) { + return isReadonlyArray(targetRange.range) ? { pos: first(targetRange.range).getStart(sourceFile), end: last(targetRange.range).getEnd() } : targetRange.range; } - function isPureImport(node) { - switch (node.kind) { - case 271 /* ImportDeclaration */: - return true; - case 270 /* ImportEqualsDeclaration */: - return !hasSyntacticModifier(node, 1 /* Export */); - case 242 /* VariableStatement */: - return node.declarationList.declarations.every((d) => !!d.initializer && isRequireCall( - d.initializer, - /*requireStringLiteralLikeArgument*/ - true - )); - default: - return false; + function collectReadsAndWrites(targetRange, scopes, enclosingTextRange, sourceFile, checker, cancellationToken) { + const allTypeParameterUsages = /* @__PURE__ */ new Map(); + const usagesPerScope = []; + const substitutionsPerScope = []; + const functionErrorsPerScope = []; + const constantErrorsPerScope = []; + const visibleDeclarationsInExtractedRange = []; + const exposedVariableSymbolSet = /* @__PURE__ */ new Map(); + const exposedVariableDeclarations = []; + let firstExposedNonVariableDeclaration; + const expression = !isReadonlyArray(targetRange.range) ? targetRange.range : targetRange.range.length === 1 && isExpressionStatement(targetRange.range[0]) ? targetRange.range[0].expression : void 0; + let expressionDiagnostic; + if (expression === void 0) { + const statements = targetRange.range; + const start = first(statements).getStart(); + const end = last(statements).end; + expressionDiagnostic = createFileDiagnostic(sourceFile, start, end - start, Messages.expressionExpected); + } else if (checker.getTypeAtLocation(expression).flags & (16384 /* Void */ | 131072 /* Never */)) { + expressionDiagnostic = createDiagnosticForNode(expression, Messages.uselessConstantType); } - } - function getUsageInfo(oldFile, toMove, checker) { - const movedSymbols = /* @__PURE__ */ new Set(); - const oldImportsNeededByTargetFile = /* @__PURE__ */ new Map(); - const targetFileImportsFromOldFile = /* @__PURE__ */ new Set(); - const containsJsx = find(toMove, (statement) => !!(statement.transformFlags & 2 /* ContainsJsx */)); - const jsxNamespaceSymbol = getJsxNamespaceSymbol(containsJsx); - if (jsxNamespaceSymbol) { - oldImportsNeededByTargetFile.set(jsxNamespaceSymbol, false); + for (const scope of scopes) { + usagesPerScope.push({ usages: /* @__PURE__ */ new Map(), typeParameterUsages: /* @__PURE__ */ new Map(), substitutions: /* @__PURE__ */ new Map() }); + substitutionsPerScope.push(/* @__PURE__ */ new Map()); + functionErrorsPerScope.push([]); + const constantErrors = []; + if (expressionDiagnostic) { + constantErrors.push(expressionDiagnostic); + } + if (isClassLike(scope) && isInJSFile(scope)) { + constantErrors.push(createDiagnosticForNode(scope, Messages.cannotExtractToJSClass)); + } + if (isArrowFunction(scope) && !isBlock(scope.body)) { + constantErrors.push(createDiagnosticForNode(scope, Messages.cannotExtractToExpressionArrowFunction)); + } + constantErrorsPerScope.push(constantErrors); } - for (const statement of toMove) { - forEachTopLevelDeclaration(statement, (decl) => { - movedSymbols.add(Debug.checkDefined(isExpressionStatement(decl) ? checker.getSymbolAtLocation(decl.expression.left) : decl.symbol, "Need a symbol here")); - }); + const seenUsages = /* @__PURE__ */ new Map(); + const target = isReadonlyArray(targetRange.range) ? factory.createBlock(targetRange.range) : targetRange.range; + const unmodifiedNode = isReadonlyArray(targetRange.range) ? first(targetRange.range) : targetRange.range; + const inGenericContext = isInGenericContext(unmodifiedNode); + collectUsages(target); + if (inGenericContext && !isReadonlyArray(targetRange.range) && !isJsxAttribute(targetRange.range)) { + const contextualType = checker.getContextualType(targetRange.range); + recordTypeParameterUsages(contextualType); } - for (const statement of toMove) { - forEachReference(statement, checker, (symbol, isValidTypeOnlyUseSite) => { - if (!symbol.declarations) - return; - for (const decl of symbol.declarations) { - if (isInImport(decl)) { - const prevIsTypeOnly = oldImportsNeededByTargetFile.get(symbol); - oldImportsNeededByTargetFile.set(symbol, prevIsTypeOnly === void 0 ? isValidTypeOnlyUseSite : prevIsTypeOnly && isValidTypeOnlyUseSite); - } else if (isTopLevelDeclaration(decl) && sourceFileOfTopLevelDeclaration(decl) === oldFile && !movedSymbols.has(symbol)) { - targetFileImportsFromOldFile.add(symbol); + if (allTypeParameterUsages.size > 0) { + const seenTypeParameterUsages = /* @__PURE__ */ new Map(); + let i = 0; + for (let curr = unmodifiedNode; curr !== void 0 && i < scopes.length; curr = curr.parent) { + if (curr === scopes[i]) { + seenTypeParameterUsages.forEach((typeParameter, id) => { + usagesPerScope[i].typeParameterUsages.set(id, typeParameter); + }); + i++; + } + if (isDeclarationWithTypeParameters(curr)) { + for (const typeParameterDecl of getEffectiveTypeParameterDeclarations(curr)) { + const typeParameter = checker.getTypeAtLocation(typeParameterDecl); + if (allTypeParameterUsages.has(typeParameter.id.toString())) { + seenTypeParameterUsages.set(typeParameter.id.toString(), typeParameter); + } } } - }); - } - const unusedImportsFromOldFile = new Set(oldImportsNeededByTargetFile.keys()); - const oldFileImportsFromTargetFile = /* @__PURE__ */ new Set(); - for (const statement of oldFile.statements) { - if (contains(toMove, statement)) - continue; - if (jsxNamespaceSymbol && !!(statement.transformFlags & 2 /* ContainsJsx */)) { - unusedImportsFromOldFile.delete(jsxNamespaceSymbol); - } - forEachReference(statement, checker, (symbol) => { - if (movedSymbols.has(symbol)) - oldFileImportsFromTargetFile.add(symbol); - unusedImportsFromOldFile.delete(symbol); - }); - } - return { movedSymbols, targetFileImportsFromOldFile, oldFileImportsFromTargetFile, oldImportsNeededByTargetFile, unusedImportsFromOldFile }; - function getJsxNamespaceSymbol(containsJsx2) { - if (containsJsx2 === void 0) { - return void 0; } - const jsxNamespace = checker.getJsxNamespace(containsJsx2); - const jsxNamespaceSymbol2 = checker.resolveName( - jsxNamespace, - containsJsx2, - 1920 /* Namespace */, - /*excludeGlobals*/ - true - ); - return !!jsxNamespaceSymbol2 && some(jsxNamespaceSymbol2.declarations, isInImport) ? jsxNamespaceSymbol2 : void 0; + Debug.assert(i === scopes.length, "Should have iterated all scopes"); } - } - function makeUniqueFilename(proposedFilename, extension, inDirectory, host) { - let newFilename = proposedFilename; - for (let i = 1; ; i++) { - const name = combinePaths(inDirectory, newFilename + extension); - if (!host.fileExists(name)) - return newFilename; - newFilename = `${proposedFilename}.${i}`; + if (visibleDeclarationsInExtractedRange.length) { + const containingLexicalScopeOfExtraction = isBlockScope(scopes[0], scopes[0].parent) ? scopes[0] : getEnclosingBlockScopeContainer(scopes[0]); + forEachChild(containingLexicalScopeOfExtraction, checkForUsedDeclarations); } - } - function inferNewFileName(importsFromNewFile, movedSymbols) { - return forEachKey(importsFromNewFile, symbolNameNoDefault) || forEachKey(movedSymbols, symbolNameNoDefault) || "newFile"; - } - function forEachReference(node, checker, onReference) { - node.forEachChild(function cb(node2) { - if (isIdentifier(node2) && !isDeclarationName(node2)) { - const sym = checker.getSymbolAtLocation(node2); - if (sym) - onReference(sym, isValidTypeOnlyAliasUseSite(node2)); - } else { - node2.forEachChild(cb); + for (let i = 0; i < scopes.length; i++) { + const scopeUsages = usagesPerScope[i]; + if (i > 0 && (scopeUsages.usages.size > 0 || scopeUsages.typeParameterUsages.size > 0)) { + const errorNode = isReadonlyArray(targetRange.range) ? targetRange.range[0] : targetRange.range; + constantErrorsPerScope[i].push(createDiagnosticForNode(errorNode, Messages.cannotAccessVariablesFromNestedScopes)); } - }); - } - function forEachTopLevelDeclaration(statement, cb) { - switch (statement.kind) { - case 261 /* FunctionDeclaration */: - case 262 /* ClassDeclaration */: - case 266 /* ModuleDeclaration */: - case 265 /* EnumDeclaration */: - case 264 /* TypeAliasDeclaration */: - case 263 /* InterfaceDeclaration */: - case 270 /* ImportEqualsDeclaration */: - return cb(statement); - case 242 /* VariableStatement */: - return firstDefined(statement.declarationList.declarations, (decl) => forEachTopLevelDeclarationInBindingName(decl.name, cb)); - case 243 /* ExpressionStatement */: { - const { expression } = statement; - return isBinaryExpression(expression) && getAssignmentDeclarationKind(expression) === 1 /* ExportsProperty */ ? cb(statement) : void 0; + if (targetRange.facts & 16 /* UsesThisInFunction */ && isClassLike(scopes[i])) { + functionErrorsPerScope[i].push(createDiagnosticForNode(targetRange.thisNode, Messages.cannotExtractFunctionsContainingThisToMethod)); + } + let hasWrite = false; + let readonlyClassPropertyWrite; + usagesPerScope[i].usages.forEach((value) => { + if (value.usage === 2 /* Write */) { + hasWrite = true; + if (value.symbol.flags & 106500 /* ClassMember */ && value.symbol.valueDeclaration && hasEffectiveModifier(value.symbol.valueDeclaration, 8 /* Readonly */)) { + readonlyClassPropertyWrite = value.symbol.valueDeclaration; + } + } + }); + Debug.assert(isReadonlyArray(targetRange.range) || exposedVariableDeclarations.length === 0, "No variable declarations expected if something was extracted"); + if (hasWrite && !isReadonlyArray(targetRange.range)) { + const diag2 = createDiagnosticForNode(targetRange.range, Messages.cannotWriteInExpression); + functionErrorsPerScope[i].push(diag2); + constantErrorsPerScope[i].push(diag2); + } else if (readonlyClassPropertyWrite && i > 0) { + const diag2 = createDiagnosticForNode(readonlyClassPropertyWrite, Messages.cannotExtractReadonlyPropertyInitializerOutsideConstructor); + functionErrorsPerScope[i].push(diag2); + constantErrorsPerScope[i].push(diag2); + } else if (firstExposedNonVariableDeclaration) { + const diag2 = createDiagnosticForNode(firstExposedNonVariableDeclaration, Messages.cannotExtractExportedEntity); + functionErrorsPerScope[i].push(diag2); + constantErrorsPerScope[i].push(diag2); } } - } - function isInImport(decl) { - switch (decl.kind) { - case 270 /* ImportEqualsDeclaration */: - case 275 /* ImportSpecifier */: - case 272 /* ImportClause */: - case 273 /* NamespaceImport */: - return true; - case 259 /* VariableDeclaration */: - return isVariableDeclarationInImport(decl); - case 207 /* BindingElement */: - return isVariableDeclaration(decl.parent.parent) && isVariableDeclarationInImport(decl.parent.parent); - default: - return false; + return { target, usagesPerScope, functionErrorsPerScope, constantErrorsPerScope, exposedVariableDeclarations }; + function isInGenericContext(node) { + return !!findAncestor(node, (n) => isDeclarationWithTypeParameters(n) && getEffectiveTypeParameterDeclarations(n).length !== 0); } - } - function isVariableDeclarationInImport(decl) { - return isSourceFile(decl.parent.parent.parent) && !!decl.initializer && isRequireCall( - decl.initializer, - /*requireStringLiteralLikeArgument*/ - true - ); - } - function isTopLevelDeclaration(node) { - return isNonVariableTopLevelDeclaration(node) && isSourceFile(node.parent) || isVariableDeclaration(node) && isSourceFile(node.parent.parent.parent); - } - function sourceFileOfTopLevelDeclaration(node) { - return isVariableDeclaration(node) ? node.parent.parent.parent : node.parent; - } - function forEachTopLevelDeclarationInBindingName(name, cb) { - switch (name.kind) { - case 80 /* Identifier */: - return cb(cast(name.parent, (x) => isVariableDeclaration(x) || isBindingElement(x))); - case 206 /* ArrayBindingPattern */: - case 205 /* ObjectBindingPattern */: - return firstDefined(name.elements, (em) => isOmittedExpression(em) ? void 0 : forEachTopLevelDeclarationInBindingName(em.name, cb)); - default: - return Debug.assertNever(name, `Unexpected name kind ${name.kind}`); + function recordTypeParameterUsages(type) { + const symbolWalker = checker.getSymbolWalker(() => (cancellationToken.throwIfCancellationRequested(), true)); + const { visitedTypes } = symbolWalker.walkType(type); + for (const visitedType of visitedTypes) { + if (visitedType.isTypeParameter()) { + allTypeParameterUsages.set(visitedType.id.toString(), visitedType); + } + } } - } - function isNonVariableTopLevelDeclaration(node) { - switch (node.kind) { - case 261 /* FunctionDeclaration */: - case 262 /* ClassDeclaration */: - case 266 /* ModuleDeclaration */: - case 265 /* EnumDeclaration */: - case 264 /* TypeAliasDeclaration */: - case 263 /* InterfaceDeclaration */: - case 270 /* ImportEqualsDeclaration */: - return true; - default: - return false; + function collectUsages(node, valueUsage = 1 /* Read */) { + if (inGenericContext) { + const type = checker.getTypeAtLocation(node); + recordTypeParameterUsages(type); + } + if (isDeclaration(node) && node.symbol) { + visibleDeclarationsInExtractedRange.push(node); + } + if (isAssignmentExpression(node)) { + collectUsages(node.left, 2 /* Write */); + collectUsages(node.right); + } else if (isUnaryExpressionWithWrite(node)) { + collectUsages(node.operand, 2 /* Write */); + } else if (isPropertyAccessExpression(node) || isElementAccessExpression(node)) { + forEachChild(node, collectUsages); + } else if (isIdentifier(node)) { + if (!node.parent) { + return; + } + if (isQualifiedName(node.parent) && node !== node.parent.left) { + return; + } + if (isPropertyAccessExpression(node.parent) && node !== node.parent.expression) { + return; + } + recordUsage( + node, + valueUsage, + /*isTypeNode*/ + isPartOfTypeNode(node) + ); + } else { + forEachChild(node, collectUsages); + } } - } - var refactorNameForMoveToFile, description2, moveToFileAction; - var init_moveToFile = __esm({ - "src/services/refactors/moveToFile.ts"() { - "use strict"; - init_moduleSpecifiers(); - init_ts4(); - init_refactorProvider(); - refactorNameForMoveToFile = "Move to file"; - description2 = getLocaleSpecificMessage(Diagnostics.Move_to_file); - moveToFileAction = { - name: "Move to file", - description: description2, - kind: "refactor.move.file" - }; - registerRefactor(refactorNameForMoveToFile, { - kinds: [moveToFileAction.kind], - getAvailableActions: function getRefactorActionsToMoveToFile(context, interactiveRefactorArguments) { - const statements = getStatementsToMove(context); - if (!interactiveRefactorArguments) { - return emptyArray; - } - if (context.preferences.allowTextChangesInNewFiles && statements) { - return [{ name: refactorNameForMoveToFile, description: description2, actions: [moveToFileAction] }]; - } - if (context.preferences.provideRefactorNotApplicableReason) { - return [{ - name: refactorNameForMoveToFile, - description: description2, - actions: [{ ...moveToFileAction, notApplicableReason: getLocaleSpecificMessage(Diagnostics.Selection_is_not_a_valid_statement_or_statements) }] - }]; - } - return emptyArray; - }, - getEditsForAction: function getRefactorEditsToMoveToFile(context, actionName2, interactiveRefactorArguments) { - Debug.assert(actionName2 === refactorNameForMoveToFile, "Wrong refactor invoked"); - const statements = Debug.checkDefined(getStatementsToMove(context)); - Debug.assert(interactiveRefactorArguments, "No interactive refactor arguments available"); - const targetFile = interactiveRefactorArguments.targetFile; - if (hasJSFileExtension(targetFile) || hasTSFileExtension(targetFile)) { - const edits = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange4(context, context.file, interactiveRefactorArguments.targetFile, context.program, statements, t, context.host, context.preferences)); - return { edits, renameFilename: void 0, renameLocation: void 0 }; + function recordUsage(n, usage, isTypeNode2) { + const symbolId = recordUsagebySymbol(n, usage, isTypeNode2); + if (symbolId) { + for (let i = 0; i < scopes.length; i++) { + const substitution = substitutionsPerScope[i].get(symbolId); + if (substitution) { + usagesPerScope[i].substitutions.set(getNodeId(n).toString(), substitution); } - return { edits: [], renameFilename: void 0, renameLocation: void 0, notApplicableReason: getLocaleSpecificMessage(Diagnostics.Cannot_move_to_file_selected_file_is_invalid) }; } - }); + } } - }); - - // src/services/refactors/convertOverloadListToSingleSignature.ts - function getRefactorActionsToConvertOverloadsToOneSignature(context) { - const { file, startPosition, program } = context; - const info = getConvertableOverloadListAtPosition(file, startPosition, program); - if (!info) - return emptyArray; - return [{ - name: refactorName5, - description: refactorDescription, - actions: [functionOverloadAction] - }]; - } - function getRefactorEditsToConvertOverloadsToOneSignature(context) { - const { file, startPosition, program } = context; - const signatureDecls = getConvertableOverloadListAtPosition(file, startPosition, program); - if (!signatureDecls) - return void 0; - const checker = program.getTypeChecker(); - const lastDeclaration = signatureDecls[signatureDecls.length - 1]; - let updated = lastDeclaration; - switch (lastDeclaration.kind) { - case 172 /* MethodSignature */: { - updated = factory.updateMethodSignature( - lastDeclaration, - lastDeclaration.modifiers, - lastDeclaration.name, - lastDeclaration.questionToken, - lastDeclaration.typeParameters, - getNewParametersForCombinedSignature(signatureDecls), - lastDeclaration.type - ); - break; + function recordUsagebySymbol(identifier, usage, isTypeName) { + const symbol = getSymbolReferencedByIdentifier(identifier); + if (!symbol) { + return void 0; } - case 173 /* MethodDeclaration */: { - updated = factory.updateMethodDeclaration( - lastDeclaration, - lastDeclaration.modifiers, - lastDeclaration.asteriskToken, - lastDeclaration.name, - lastDeclaration.questionToken, - lastDeclaration.typeParameters, - getNewParametersForCombinedSignature(signatureDecls), - lastDeclaration.type, - lastDeclaration.body - ); - break; + const symbolId = getSymbolId(symbol).toString(); + const lastUsage = seenUsages.get(symbolId); + if (lastUsage && lastUsage >= usage) { + return symbolId; } - case 178 /* CallSignature */: { - updated = factory.updateCallSignature( - lastDeclaration, - lastDeclaration.typeParameters, - getNewParametersForCombinedSignature(signatureDecls), - lastDeclaration.type - ); - break; + seenUsages.set(symbolId, usage); + if (lastUsage) { + for (const perScope of usagesPerScope) { + const prevEntry = perScope.usages.get(identifier.text); + if (prevEntry) { + perScope.usages.set(identifier.text, { usage, symbol, node: identifier }); + } + } + return symbolId; } - case 175 /* Constructor */: { - updated = factory.updateConstructorDeclaration( - lastDeclaration, - lastDeclaration.modifiers, - getNewParametersForCombinedSignature(signatureDecls), - lastDeclaration.body - ); - break; + const decls = symbol.getDeclarations(); + const declInFile = decls && find(decls, (d) => d.getSourceFile() === sourceFile); + if (!declInFile) { + return void 0; } - case 179 /* ConstructSignature */: { - updated = factory.updateConstructSignature( - lastDeclaration, - lastDeclaration.typeParameters, - getNewParametersForCombinedSignature(signatureDecls), - lastDeclaration.type - ); - break; + if (rangeContainsStartEnd(enclosingTextRange, declInFile.getStart(), declInFile.end)) { + return void 0; } - case 261 /* FunctionDeclaration */: { - updated = factory.updateFunctionDeclaration( - lastDeclaration, - lastDeclaration.modifiers, - lastDeclaration.asteriskToken, - lastDeclaration.name, - lastDeclaration.typeParameters, - getNewParametersForCombinedSignature(signatureDecls), - lastDeclaration.type, - lastDeclaration.body + if (targetRange.facts & 2 /* IsGenerator */ && usage === 2 /* Write */) { + const diag2 = createDiagnosticForNode(identifier, Messages.cannotExtractRangeThatContainsWritesToReferencesLocatedOutsideOfTheTargetRangeInGenerators); + for (const errors of functionErrorsPerScope) { + errors.push(diag2); + } + for (const errors of constantErrorsPerScope) { + errors.push(diag2); + } + } + for (let i = 0; i < scopes.length; i++) { + const scope = scopes[i]; + const resolvedSymbol = checker.resolveName( + symbol.name, + scope, + symbol.flags, + /*excludeGlobals*/ + false ); - break; + if (resolvedSymbol === symbol) { + continue; + } + if (!substitutionsPerScope[i].has(symbolId)) { + const substitution = tryReplaceWithQualifiedNameOrPropertyAccess(symbol.exportSymbol || symbol, scope, isTypeName); + if (substitution) { + substitutionsPerScope[i].set(symbolId, substitution); + } else if (isTypeName) { + if (!(symbol.flags & 262144 /* TypeParameter */)) { + const diag2 = createDiagnosticForNode(identifier, Messages.typeWillNotBeVisibleInTheNewScope); + functionErrorsPerScope[i].push(diag2); + constantErrorsPerScope[i].push(diag2); + } + } else { + usagesPerScope[i].usages.set(identifier.text, { usage, symbol, node: identifier }); + } + } } - default: - return Debug.failBadSyntaxKind(lastDeclaration, "Unhandled signature kind in overload list conversion refactoring"); - } - if (updated === lastDeclaration) { - return; + return symbolId; } - const edits = ts_textChanges_exports.ChangeTracker.with(context, (t) => { - t.replaceNodeRange(file, signatureDecls[0], signatureDecls[signatureDecls.length - 1], updated); - }); - return { renameFilename: void 0, renameLocation: void 0, edits }; - function getNewParametersForCombinedSignature(signatureDeclarations) { - const lastSig = signatureDeclarations[signatureDeclarations.length - 1]; - if (isFunctionLikeDeclaration(lastSig) && lastSig.body) { - signatureDeclarations = signatureDeclarations.slice(0, signatureDeclarations.length - 1); + function checkForUsedDeclarations(node) { + if (node === targetRange.range || isReadonlyArray(targetRange.range) && targetRange.range.includes(node)) { + return; } - return factory.createNodeArray([ - factory.createParameterDeclaration( - /*modifiers*/ - void 0, - factory.createToken(26 /* DotDotDotToken */), - "args", - /*questionToken*/ - void 0, - factory.createUnionTypeNode(map(signatureDeclarations, convertSignatureParametersToTuple)) - ) - ]); + const sym = isIdentifier(node) ? getSymbolReferencedByIdentifier(node) : checker.getSymbolAtLocation(node); + if (sym) { + const decl = find(visibleDeclarationsInExtractedRange, (d) => d.symbol === sym); + if (decl) { + if (isVariableDeclaration(decl)) { + const idString = decl.symbol.id.toString(); + if (!exposedVariableSymbolSet.has(idString)) { + exposedVariableDeclarations.push(decl); + exposedVariableSymbolSet.set(idString, true); + } + } else { + firstExposedNonVariableDeclaration = firstExposedNonVariableDeclaration || decl; + } + } + } + forEachChild(node, checkForUsedDeclarations); } - function convertSignatureParametersToTuple(decl) { - const members = map(decl.parameters, convertParameterToNamedTupleMember); - return setEmitFlags(factory.createTupleTypeNode(members), some(members, (m) => !!length(getSyntheticLeadingComments(m))) ? 0 /* None */ : 1 /* SingleLine */); + function getSymbolReferencedByIdentifier(identifier) { + return identifier.parent && isShorthandPropertyAssignment(identifier.parent) && identifier.parent.name === identifier ? checker.getShorthandAssignmentValueSymbol(identifier.parent) : checker.getSymbolAtLocation(identifier); } - function convertParameterToNamedTupleMember(p) { - Debug.assert(isIdentifier(p.name)); - const result = setTextRange(factory.createNamedTupleMember( - p.dotDotDotToken, - p.name, - p.questionToken, - p.type || factory.createKeywordTypeNode(133 /* AnyKeyword */) - ), p); - const parameterDocComment = p.symbol && p.symbol.getDocumentationComment(checker); - if (parameterDocComment) { - const newComment = displayPartsToString(parameterDocComment); - if (newComment.length) { - setSyntheticLeadingComments(result, [{ - text: `* -${newComment.split("\n").map((c) => ` * ${c}`).join("\n")} - `, - kind: 3 /* MultiLineCommentTrivia */, - pos: -1, - end: -1, - hasTrailingNewLine: true, - hasLeadingNewline: true - }]); - } + function tryReplaceWithQualifiedNameOrPropertyAccess(symbol, scopeDecl, isTypeNode2) { + if (!symbol) { + return void 0; } - return result; + const decls = symbol.getDeclarations(); + if (decls && decls.some((d) => d.parent === scopeDecl)) { + return factory.createIdentifier(symbol.name); + } + const prefix = tryReplaceWithQualifiedNameOrPropertyAccess(symbol.parent, scopeDecl, isTypeNode2); + if (prefix === void 0) { + return void 0; + } + return isTypeNode2 ? factory.createQualifiedName(prefix, factory.createIdentifier(symbol.name)) : factory.createPropertyAccessExpression(prefix, symbol.name); } } - function isConvertableSignatureDeclaration(d) { - switch (d.kind) { - case 172 /* MethodSignature */: - case 173 /* MethodDeclaration */: - case 178 /* CallSignature */: - case 175 /* Constructor */: - case 179 /* ConstructSignature */: - case 261 /* FunctionDeclaration */: - return true; - } - return false; + function getExtractableParent(node) { + return findAncestor(node, (node2) => node2.parent && isExtractableExpression(node2) && !isBinaryExpression(node2.parent)); } - function getConvertableOverloadListAtPosition(file, startPosition, program) { - const node = getTokenAtPosition(file, startPosition); - const containingDecl = findAncestor(node, isConvertableSignatureDeclaration); - if (!containingDecl) { - return; - } - if (isFunctionLikeDeclaration(containingDecl) && containingDecl.body && rangeContainsPosition(containingDecl.body, startPosition)) { - return; - } - const checker = program.getTypeChecker(); - const signatureSymbol = containingDecl.symbol; - if (!signatureSymbol) { - return; - } - const decls = signatureSymbol.declarations; - if (length(decls) <= 1) { - return; - } - if (!every(decls, (d) => getSourceFileOfNode(d) === file)) { - return; - } - if (!isConvertableSignatureDeclaration(decls[0])) { - return; + function isExtractableExpression(node) { + const { parent: parent2 } = node; + switch (parent2.kind) { + case 306 /* EnumMember */: + return false; } - const kindOne = decls[0].kind; - if (!every(decls, (d) => d.kind === kindOne)) { - return; + switch (node.kind) { + case 11 /* StringLiteral */: + return parent2.kind !== 272 /* ImportDeclaration */ && parent2.kind !== 276 /* ImportSpecifier */; + case 230 /* SpreadElement */: + case 206 /* ObjectBindingPattern */: + case 208 /* BindingElement */: + return false; + case 80 /* Identifier */: + return parent2.kind !== 208 /* BindingElement */ && parent2.kind !== 276 /* ImportSpecifier */ && parent2.kind !== 281 /* ExportSpecifier */; } - const signatureDecls = decls; - if (some(signatureDecls, (d) => !!d.typeParameters || some(d.parameters, (p) => !!p.modifiers || !isIdentifier(p.name)))) { - return; + return true; + } + function isBlockLike(node) { + switch (node.kind) { + case 241 /* Block */: + case 312 /* SourceFile */: + case 268 /* ModuleBlock */: + case 296 /* CaseClause */: + return true; + default: + return false; } - const signatures = mapDefined(signatureDecls, (d) => checker.getSignatureFromDeclaration(d)); - if (length(signatures) !== length(decls)) { - return; + } + function isInJSXContent(node) { + return isStringLiteralJsxAttribute(node) || (isJsxElement(node) || isJsxSelfClosingElement(node) || isJsxFragment(node)) && (isJsxElement(node.parent) || isJsxFragment(node.parent)); + } + function isStringLiteralJsxAttribute(node) { + return isStringLiteral(node) && node.parent && isJsxAttribute(node.parent); + } + var refactorName12, extractConstantAction, extractFunctionAction, Messages, RangeFacts; + var init_extractSymbol = __esm({ + "src/services/refactors/extractSymbol.ts"() { + "use strict"; + init_ts4(); + init_ts_refactor(); + refactorName12 = "Extract Symbol"; + extractConstantAction = { + name: "Extract Constant", + description: getLocaleSpecificMessage(Diagnostics.Extract_constant), + kind: "refactor.extract.constant" + }; + extractFunctionAction = { + name: "Extract Function", + description: getLocaleSpecificMessage(Diagnostics.Extract_function), + kind: "refactor.extract.function" + }; + registerRefactor(refactorName12, { + kinds: [ + extractConstantAction.kind, + extractFunctionAction.kind + ], + getEditsForAction: getRefactorEditsToExtractSymbol, + getAvailableActions: getRefactorActionsToExtractSymbol + }); + ((Messages2) => { + function createMessage(message) { + return { message, code: 0, category: 3 /* Message */, key: message }; + } + Messages2.cannotExtractRange = createMessage("Cannot extract range."); + Messages2.cannotExtractImport = createMessage("Cannot extract import statement."); + Messages2.cannotExtractSuper = createMessage("Cannot extract super call."); + Messages2.cannotExtractJSDoc = createMessage("Cannot extract JSDoc."); + Messages2.cannotExtractEmpty = createMessage("Cannot extract empty range."); + Messages2.expressionExpected = createMessage("expression expected."); + Messages2.uselessConstantType = createMessage("No reason to extract constant of type."); + Messages2.statementOrExpressionExpected = createMessage("Statement or expression expected."); + Messages2.cannotExtractRangeContainingConditionalBreakOrContinueStatements = createMessage("Cannot extract range containing conditional break or continue statements."); + Messages2.cannotExtractRangeContainingConditionalReturnStatement = createMessage("Cannot extract range containing conditional return statement."); + Messages2.cannotExtractRangeContainingLabeledBreakOrContinueStatementWithTargetOutsideOfTheRange = createMessage("Cannot extract range containing labeled break or continue with target outside of the range."); + Messages2.cannotExtractRangeThatContainsWritesToReferencesLocatedOutsideOfTheTargetRangeInGenerators = createMessage("Cannot extract range containing writes to references located outside of the target range in generators."); + Messages2.typeWillNotBeVisibleInTheNewScope = createMessage("Type will not visible in the new scope."); + Messages2.functionWillNotBeVisibleInTheNewScope = createMessage("Function will not visible in the new scope."); + Messages2.cannotExtractIdentifier = createMessage("Select more than a single identifier."); + Messages2.cannotExtractExportedEntity = createMessage("Cannot extract exported declaration"); + Messages2.cannotWriteInExpression = createMessage("Cannot write back side-effects when extracting an expression"); + Messages2.cannotExtractReadonlyPropertyInitializerOutsideConstructor = createMessage("Cannot move initialization of read-only class property outside of the constructor"); + Messages2.cannotExtractAmbientBlock = createMessage("Cannot extract code from ambient contexts"); + Messages2.cannotAccessVariablesFromNestedScopes = createMessage("Cannot access variables from nested scopes"); + Messages2.cannotExtractToJSClass = createMessage("Cannot extract constant to a class scope in JS"); + Messages2.cannotExtractToExpressionArrowFunction = createMessage("Cannot extract constant to an arrow function without a block"); + Messages2.cannotExtractFunctionsContainingThisToMethod = createMessage("Cannot extract functions containing this to method"); + })(Messages || (Messages = {})); + RangeFacts = /* @__PURE__ */ ((RangeFacts2) => { + RangeFacts2[RangeFacts2["None"] = 0] = "None"; + RangeFacts2[RangeFacts2["HasReturn"] = 1] = "HasReturn"; + RangeFacts2[RangeFacts2["IsGenerator"] = 2] = "IsGenerator"; + RangeFacts2[RangeFacts2["IsAsyncFunction"] = 4] = "IsAsyncFunction"; + RangeFacts2[RangeFacts2["UsesThis"] = 8] = "UsesThis"; + RangeFacts2[RangeFacts2["UsesThisInFunction"] = 16] = "UsesThisInFunction"; + RangeFacts2[RangeFacts2["InStaticRegion"] = 32] = "InStaticRegion"; + return RangeFacts2; + })(RangeFacts || {}); } - const returnOne = checker.getReturnTypeOfSignature(signatures[0]); - if (!every(signatures, (s) => checker.getReturnTypeOfSignature(s) === returnOne)) { - return; + }); + + // src/services/_namespaces/ts.refactor.extractSymbol.ts + var ts_refactor_extractSymbol_exports = {}; + __export(ts_refactor_extractSymbol_exports, { + Messages: () => Messages, + RangeFacts: () => RangeFacts, + getRangeToExtract: () => getRangeToExtract2, + getRefactorActionsToExtractSymbol: () => getRefactorActionsToExtractSymbol, + getRefactorEditsToExtractSymbol: () => getRefactorEditsToExtractSymbol + }); + var init_ts_refactor_extractSymbol = __esm({ + "src/services/_namespaces/ts.refactor.extractSymbol.ts"() { + "use strict"; + init_extractSymbol(); } - return signatureDecls; - } - var refactorName5, refactorDescription, functionOverloadAction; - var init_convertOverloadListToSingleSignature = __esm({ - "src/services/refactors/convertOverloadListToSingleSignature.ts"() { + }); + + // src/services/refactors/generateGetAccessorAndSetAccessor.ts + var actionName, actionDescription, generateGetSetAction; + var init_generateGetAccessorAndSetAccessor = __esm({ + "src/services/refactors/generateGetAccessorAndSetAccessor.ts"() { "use strict"; init_ts4(); init_ts_refactor(); - refactorName5 = "Convert overload list to single signature"; - refactorDescription = Diagnostics.Convert_overload_list_to_single_signature.message; - functionOverloadAction = { - name: refactorName5, - description: refactorDescription, - kind: "refactor.rewrite.function.overloadList" + actionName = "Generate 'get' and 'set' accessors"; + actionDescription = getLocaleSpecificMessage(Diagnostics.Generate_get_and_set_accessors); + generateGetSetAction = { + name: actionName, + description: actionDescription, + kind: "refactor.rewrite.property.generateAccessors" }; - registerRefactor(refactorName5, { - kinds: [functionOverloadAction.kind], - getEditsForAction: getRefactorEditsToConvertOverloadsToOneSignature, - getAvailableActions: getRefactorActionsToConvertOverloadsToOneSignature + registerRefactor(actionName, { + kinds: [generateGetSetAction.kind], + getEditsForAction: function getRefactorActionsToGenerateGetAndSetAccessors(context, actionName2) { + if (!context.endPosition) + return void 0; + const info = ts_codefix_exports.getAccessorConvertiblePropertyAtPosition(context.file, context.program, context.startPosition, context.endPosition); + Debug.assert(info && !isRefactorErrorInfo(info), "Expected applicable refactor info"); + const edits = ts_codefix_exports.generateAccessorFromProperty(context.file, context.program, context.startPosition, context.endPosition, context, actionName2); + if (!edits) + return void 0; + const renameFilename = context.file.fileName; + const nameNeedRename = info.renameAccessor ? info.accessorName : info.fieldName; + const renameLocationOffset = isIdentifier(nameNeedRename) ? 0 : -1; + const renameLocation = renameLocationOffset + getRenameLocation( + edits, + renameFilename, + nameNeedRename.text, + /*preferLastLocation*/ + isParameter(info.declaration) + ); + return { renameFilename, renameLocation, edits }; + }, + getAvailableActions(context) { + if (!context.endPosition) + return emptyArray; + const info = ts_codefix_exports.getAccessorConvertiblePropertyAtPosition(context.file, context.program, context.startPosition, context.endPosition, context.triggerReason === "invoked"); + if (!info) + return emptyArray; + if (!isRefactorErrorInfo(info)) { + return [{ + name: actionName, + description: actionDescription, + actions: [generateGetSetAction] + }]; + } + if (context.preferences.provideRefactorNotApplicableReason) { + return [{ + name: actionName, + description: actionDescription, + actions: [{ ...generateGetSetAction, notApplicableReason: info.error }] + }]; + } + return emptyArray; + } }); } }); - // src/services/refactors/addOrRemoveBracesToArrowFunction.ts - function getRefactorActionsToRemoveFunctionBraces(context) { - const { file, startPosition, triggerReason } = context; - const info = getConvertibleArrowFunctionAtPosition(file, startPosition, triggerReason === "invoked"); + // src/services/_namespaces/ts.refactor.generateGetAccessorAndSetAccessor.ts + var ts_refactor_generateGetAccessorAndSetAccessor_exports = {}; + var init_ts_refactor_generateGetAccessorAndSetAccessor = __esm({ + "src/services/_namespaces/ts.refactor.generateGetAccessorAndSetAccessor.ts"() { + "use strict"; + init_generateGetAccessorAndSetAccessor(); + } + }); + + // src/services/refactors/inferFunctionReturnType.ts + function getRefactorEditsToInferReturnType(context) { + const info = getInfo4(context); + if (info && !isRefactorErrorInfo(info)) { + const edits = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange7(context.file, t, info.declaration, info.returnTypeNode)); + return { renameFilename: void 0, renameLocation: void 0, edits }; + } + return void 0; + } + function getRefactorActionsToInferReturnType(context) { + const info = getInfo4(context); if (!info) return emptyArray; if (!isRefactorErrorInfo(info)) { return [{ - name: refactorName6, - description: refactorDescription2, - actions: [ - info.addBraces ? addBracesAction : removeBracesAction - ] + name: refactorName13, + description: refactorDescription7, + actions: [inferReturnTypeAction] }]; } if (context.preferences.provideRefactorNotApplicableReason) { return [{ - name: refactorName6, - description: refactorDescription2, - actions: [ - { ...addBracesAction, notApplicableReason: info.error }, - { ...removeBracesAction, notApplicableReason: info.error } - ] + name: refactorName13, + description: refactorDescription7, + actions: [{ ...inferReturnTypeAction, notApplicableReason: info.error }] }]; } return emptyArray; } - function getRefactorEditsToRemoveFunctionBraces(context, actionName2) { - const { file, startPosition } = context; - const info = getConvertibleArrowFunctionAtPosition(file, startPosition); - Debug.assert(info && !isRefactorErrorInfo(info), "Expected applicable refactor info"); - const { expression, returnStatement, func } = info; - let body; - if (actionName2 === addBracesAction.name) { - const returnStatement2 = factory.createReturnStatement(expression); - body = factory.createBlock( - [returnStatement2], - /*multiLine*/ - true - ); - copyLeadingComments( - expression, - returnStatement2, - file, - 3 /* MultiLineCommentTrivia */, - /*hasTrailingNewLine*/ - true - ); - } else if (actionName2 === removeBracesAction.name && returnStatement) { - const actualExpression = expression || factory.createVoidZero(); - body = needsParentheses(actualExpression) ? factory.createParenthesizedExpression(actualExpression) : actualExpression; - copyTrailingAsLeadingComments( - returnStatement, - body, - file, - 3 /* MultiLineCommentTrivia */, - /*hasTrailingNewLine*/ - false - ); - copyLeadingComments( - returnStatement, - body, - file, - 3 /* MultiLineCommentTrivia */, - /*hasTrailingNewLine*/ - false - ); - copyTrailingComments( - returnStatement, - body, - file, - 3 /* MultiLineCommentTrivia */, - /*hasTrailingNewLine*/ - false - ); - } else { - Debug.fail("invalid action"); + function doChange7(sourceFile, changes, declaration, typeNode) { + const closeParen = findChildOfKind(declaration, 22 /* CloseParenToken */, sourceFile); + const needParens = isArrowFunction(declaration) && closeParen === void 0; + const endNode2 = needParens ? first(declaration.parameters) : closeParen; + if (endNode2) { + if (needParens) { + changes.insertNodeBefore(sourceFile, endNode2, factory.createToken(21 /* OpenParenToken */)); + changes.insertNodeAfter(sourceFile, endNode2, factory.createToken(22 /* CloseParenToken */)); + } + changes.insertNodeAt(sourceFile, endNode2.end, typeNode, { prefix: ": " }); } - const edits = ts_textChanges_exports.ChangeTracker.with(context, (t) => { - t.replaceNode(file, func.body, body); - }); - return { renameFilename: void 0, renameLocation: void 0, edits }; } - function getConvertibleArrowFunctionAtPosition(file, startPosition, considerFunctionBodies = true, kind) { - const node = getTokenAtPosition(file, startPosition); - const func = getContainingFunction(node); - if (!func) { - return { - error: getLocaleSpecificMessage(Diagnostics.Could_not_find_a_containing_arrow_function) - }; + function getInfo4(context) { + if (isInJSFile(context.file) || !refactorKindBeginsWith(inferReturnTypeAction.kind, context.kind)) + return; + const token = getTouchingPropertyName(context.file, context.startPosition); + const declaration = findAncestor(token, (n) => isBlock(n) || n.parent && isArrowFunction(n.parent) && (n.kind === 39 /* EqualsGreaterThanToken */ || n.parent.body === n) ? "quit" : isConvertibleDeclaration(n)); + if (!declaration || !declaration.body || declaration.type) { + return { error: getLocaleSpecificMessage(Diagnostics.Return_type_must_be_inferred_from_a_function) }; } - if (!isArrowFunction(func)) { - return { - error: getLocaleSpecificMessage(Diagnostics.Containing_function_is_not_an_arrow_function) - }; + const typeChecker = context.program.getTypeChecker(); + const returnType = tryGetReturnType(typeChecker, declaration); + if (!returnType) { + return { error: getLocaleSpecificMessage(Diagnostics.Could_not_determine_function_return_type) }; } - if (!rangeContainsRange(func, node) || rangeContainsRange(func.body, node) && !considerFunctionBodies) { - return void 0; + const returnTypeNode = typeChecker.typeToTypeNode(returnType, declaration, 1 /* NoTruncation */); + if (returnTypeNode) { + return { declaration, returnTypeNode }; } - if (refactorKindBeginsWith(addBracesAction.kind, kind) && isExpression(func.body)) { - return { func, addBraces: true, expression: func.body }; - } else if (refactorKindBeginsWith(removeBracesAction.kind, kind) && isBlock(func.body) && func.body.statements.length === 1) { - const firstStatement = first(func.body.statements); - if (isReturnStatement(firstStatement)) { - return { func, addBraces: false, expression: firstStatement.expression, returnStatement: firstStatement }; + } + function isConvertibleDeclaration(node) { + switch (node.kind) { + case 262 /* FunctionDeclaration */: + case 218 /* FunctionExpression */: + case 219 /* ArrowFunction */: + case 174 /* MethodDeclaration */: + return true; + default: + return false; + } + } + function tryGetReturnType(typeChecker, node) { + if (typeChecker.isImplementationOfOverload(node)) { + const signatures = typeChecker.getTypeAtLocation(node).getCallSignatures(); + if (signatures.length > 1) { + return typeChecker.getUnionType(mapDefined(signatures, (s) => s.getReturnType())); } } - return void 0; + const signature = typeChecker.getSignatureFromDeclaration(node); + if (signature) { + return typeChecker.getReturnTypeOfSignature(signature); + } } - var refactorName6, refactorDescription2, addBracesAction, removeBracesAction; - var init_addOrRemoveBracesToArrowFunction = __esm({ - "src/services/refactors/addOrRemoveBracesToArrowFunction.ts"() { + var refactorName13, refactorDescription7, inferReturnTypeAction; + var init_inferFunctionReturnType = __esm({ + "src/services/refactors/inferFunctionReturnType.ts"() { "use strict"; init_ts4(); init_ts_refactor(); - refactorName6 = "Add or remove braces in an arrow function"; - refactorDescription2 = Diagnostics.Add_or_remove_braces_in_an_arrow_function.message; - addBracesAction = { - name: "Add braces to arrow function", - description: Diagnostics.Add_braces_to_arrow_function.message, - kind: "refactor.rewrite.arrow.braces.add" - }; - removeBracesAction = { - name: "Remove braces from arrow function", - description: Diagnostics.Remove_braces_from_arrow_function.message, - kind: "refactor.rewrite.arrow.braces.remove" + refactorName13 = "Infer function return type"; + refactorDescription7 = getLocaleSpecificMessage(Diagnostics.Infer_function_return_type); + inferReturnTypeAction = { + name: refactorName13, + description: refactorDescription7, + kind: "refactor.rewrite.function.returnType" }; - registerRefactor(refactorName6, { - kinds: [removeBracesAction.kind], - getEditsForAction: getRefactorEditsToRemoveFunctionBraces, - getAvailableActions: getRefactorActionsToRemoveFunctionBraces + registerRefactor(refactorName13, { + kinds: [inferReturnTypeAction.kind], + getEditsForAction: getRefactorEditsToInferReturnType, + getAvailableActions: getRefactorActionsToInferReturnType }); } }); - // src/services/_namespaces/ts.refactor.addOrRemoveBracesToArrowFunction.ts - var ts_refactor_addOrRemoveBracesToArrowFunction_exports = {}; - var init_ts_refactor_addOrRemoveBracesToArrowFunction = __esm({ - "src/services/_namespaces/ts.refactor.addOrRemoveBracesToArrowFunction.ts"() { + // src/services/_namespaces/ts.refactor.inferFunctionReturnType.ts + var ts_refactor_inferFunctionReturnType_exports = {}; + var init_ts_refactor_inferFunctionReturnType = __esm({ + "src/services/_namespaces/ts.refactor.inferFunctionReturnType.ts"() { "use strict"; - init_convertOverloadListToSingleSignature(); - init_addOrRemoveBracesToArrowFunction(); + init_inferFunctionReturnType(); } }); - // src/services/refactors/convertArrowFunctionOrFunctionExpression.ts - function getRefactorActionsToConvertFunctionExpressions(context) { - const { file, startPosition, program, kind } = context; - const info = getFunctionInfo(file, startPosition, program); - if (!info) - return emptyArray; - const { selectedVariableDeclaration, func } = info; - const possibleActions = []; - const errors = []; - if (refactorKindBeginsWith(toNamedFunctionAction.kind, kind)) { - const error = selectedVariableDeclaration || isArrowFunction(func) && isVariableDeclaration(func.parent) ? void 0 : getLocaleSpecificMessage(Diagnostics.Could_not_convert_to_named_function); - if (error) { - errors.push({ ...toNamedFunctionAction, notApplicableReason: error }); - } else { - possibleActions.push(toNamedFunctionAction); - } - } - if (refactorKindBeginsWith(toAnonymousFunctionAction.kind, kind)) { - const error = !selectedVariableDeclaration && isArrowFunction(func) ? void 0 : getLocaleSpecificMessage(Diagnostics.Could_not_convert_to_anonymous_function); - if (error) { - errors.push({ ...toAnonymousFunctionAction, notApplicableReason: error }); - } else { - possibleActions.push(toAnonymousFunctionAction); - } + // src/services/_namespaces/ts.refactor.ts + var ts_refactor_exports = {}; + __export(ts_refactor_exports, { + addExportToChanges: () => addExportToChanges, + addExports: () => addExports, + addNewFileToTsconfig: () => addNewFileToTsconfig, + addOrRemoveBracesToArrowFunction: () => ts_refactor_addOrRemoveBracesToArrowFunction_exports, + convertArrowFunctionOrFunctionExpression: () => ts_refactor_convertArrowFunctionOrFunctionExpression_exports, + convertParamsToDestructuredObject: () => ts_refactor_convertParamsToDestructuredObject_exports, + convertStringOrTemplateLiteral: () => ts_refactor_convertStringOrTemplateLiteral_exports, + convertToOptionalChainExpression: () => ts_refactor_convertToOptionalChainExpression_exports, + createNewFileName: () => createNewFileName, + createOldFileImportsFromTargetFile: () => createOldFileImportsFromTargetFile, + deleteMovedStatements: () => deleteMovedStatements, + deleteUnusedImports: () => deleteUnusedImports, + deleteUnusedOldImports: () => deleteUnusedOldImports, + doChangeNamedToNamespaceOrDefault: () => doChangeNamedToNamespaceOrDefault, + extractSymbol: () => ts_refactor_extractSymbol_exports, + filterImport: () => filterImport, + forEachImportInStatement: () => forEachImportInStatement, + generateGetAccessorAndSetAccessor: () => ts_refactor_generateGetAccessorAndSetAccessor_exports, + getApplicableRefactors: () => getApplicableRefactors, + getEditsForRefactor: () => getEditsForRefactor, + getStatementsToMove: () => getStatementsToMove, + getTopLevelDeclarationStatement: () => getTopLevelDeclarationStatement, + getUsageInfo: () => getUsageInfo, + inferFunctionReturnType: () => ts_refactor_inferFunctionReturnType_exports, + isRefactorErrorInfo: () => isRefactorErrorInfo, + isTopLevelDeclaration: () => isTopLevelDeclaration, + makeImportOrRequire: () => makeImportOrRequire, + moduleSpecifierFromImport: () => moduleSpecifierFromImport, + nameOfTopLevelDeclaration: () => nameOfTopLevelDeclaration, + refactorKindBeginsWith: () => refactorKindBeginsWith, + registerRefactor: () => registerRefactor, + updateImportsInOtherFiles: () => updateImportsInOtherFiles + }); + var init_ts_refactor = __esm({ + "src/services/_namespaces/ts.refactor.ts"() { + "use strict"; + init_refactorProvider(); + init_convertExport(); + init_convertImport(); + init_extractType(); + init_helpers(); + init_inlineVariable(); + init_moveToNewFile(); + init_moveToFile(); + init_ts_refactor_addOrRemoveBracesToArrowFunction(); + init_ts_refactor_convertArrowFunctionOrFunctionExpression(); + init_ts_refactor_convertParamsToDestructuredObject(); + init_ts_refactor_convertStringOrTemplateLiteral(); + init_ts_refactor_convertToOptionalChainExpression(); + init_ts_refactor_extractSymbol(); + init_ts_refactor_generateGetAccessorAndSetAccessor(); + init_ts_refactor_inferFunctionReturnType(); } - if (refactorKindBeginsWith(toArrowFunctionAction.kind, kind)) { - const error = isFunctionExpression(func) ? void 0 : getLocaleSpecificMessage(Diagnostics.Could_not_convert_to_arrow_function); - if (error) { - errors.push({ ...toArrowFunctionAction, notApplicableReason: error }); - } else { - possibleActions.push(toArrowFunctionAction); - } + }); + + // src/services/classifier2020.ts + function getSemanticClassifications2(program, cancellationToken, sourceFile, span) { + const classifications = getEncodedSemanticClassifications2(program, cancellationToken, sourceFile, span); + Debug.assert(classifications.spans.length % 3 === 0); + const dense = classifications.spans; + const result = []; + for (let i = 0; i < dense.length; i += 3) { + result.push({ + textSpan: createTextSpan(dense[i], dense[i + 1]), + classificationType: dense[i + 2] + }); } - return [{ - name: refactorName7, - description: refactorDescription3, - actions: possibleActions.length === 0 && context.preferences.provideRefactorNotApplicableReason ? errors : possibleActions - }]; + return result; } - function getRefactorEditsToConvertFunctionExpressions(context, actionName2) { - const { file, startPosition, program } = context; - const info = getFunctionInfo(file, startPosition, program); - if (!info) - return void 0; - const { func } = info; - const edits = []; - switch (actionName2) { - case toAnonymousFunctionAction.name: - edits.push(...getEditInfoForConvertToAnonymousFunction(context, func)); - break; - case toNamedFunctionAction.name: - const variableInfo = getVariableInfo(func); - if (!variableInfo) - return void 0; - edits.push(...getEditInfoForConvertToNamedFunction(context, func, variableInfo)); - break; - case toArrowFunctionAction.name: - if (!isFunctionExpression(func)) - return void 0; - edits.push(...getEditInfoForConvertToArrowFunction(context, func)); - break; - default: - return Debug.fail("invalid action"); + function getEncodedSemanticClassifications2(program, cancellationToken, sourceFile, span) { + return { + spans: getSemanticTokens(program, sourceFile, span, cancellationToken), + endOfLineState: 0 /* None */ + }; + } + function getSemanticTokens(program, sourceFile, span, cancellationToken) { + const resultTokens = []; + const collector = (node, typeIdx, modifierSet) => { + resultTokens.push(node.getStart(sourceFile), node.getWidth(sourceFile), (typeIdx + 1 << 8 /* typeOffset */) + modifierSet); + }; + if (program && sourceFile) { + collectTokens(program, sourceFile, span, collector, cancellationToken); } - return { renameFilename: void 0, renameLocation: void 0, edits }; + return resultTokens; } - function containingThis(node) { - let containsThis = false; - node.forEachChild(function checkThis(child) { - if (isThis(child)) { - containsThis = true; + function collectTokens(program, sourceFile, span, collector, cancellationToken) { + const typeChecker = program.getTypeChecker(); + let inJSXElement = false; + function visit(node) { + switch (node.kind) { + case 267 /* ModuleDeclaration */: + case 263 /* ClassDeclaration */: + case 264 /* InterfaceDeclaration */: + case 262 /* FunctionDeclaration */: + case 231 /* ClassExpression */: + case 218 /* FunctionExpression */: + case 219 /* ArrowFunction */: + cancellationToken.throwIfCancellationRequested(); + } + if (!node || !textSpanIntersectsWith(span, node.pos, node.getFullWidth()) || node.getFullWidth() === 0) { return; } - if (!isClassLike(child) && !isFunctionDeclaration(child) && !isFunctionExpression(child)) { - forEachChild(child, checkThis); + const prevInJSXElement = inJSXElement; + if (isJsxElement(node) || isJsxSelfClosingElement(node)) { + inJSXElement = true; } - }); - return containsThis; + if (isJsxExpression(node)) { + inJSXElement = false; + } + if (isIdentifier(node) && !inJSXElement && !inImportClause(node) && !isInfinityOrNaNString(node.escapedText)) { + let symbol = typeChecker.getSymbolAtLocation(node); + if (symbol) { + if (symbol.flags & 2097152 /* Alias */) { + symbol = typeChecker.getAliasedSymbol(symbol); + } + let typeIdx = classifySymbol2(symbol, getMeaningFromLocation(node)); + if (typeIdx !== void 0) { + let modifierSet = 0; + if (node.parent) { + const parentIsDeclaration = isBindingElement(node.parent) || tokenFromDeclarationMapping.get(node.parent.kind) === typeIdx; + if (parentIsDeclaration && node.parent.name === node) { + modifierSet = 1 << 0 /* declaration */; + } + } + if (typeIdx === 6 /* parameter */ && isRightSideOfQualifiedNameOrPropertyAccess2(node)) { + typeIdx = 9 /* property */; + } + typeIdx = reclassifyByType(typeChecker, node, typeIdx); + const decl = symbol.valueDeclaration; + if (decl) { + const modifiers = getCombinedModifierFlags(decl); + const nodeFlags = getCombinedNodeFlags(decl); + if (modifiers & 256 /* Static */) { + modifierSet |= 1 << 1 /* static */; + } + if (modifiers & 1024 /* Async */) { + modifierSet |= 1 << 2 /* async */; + } + if (typeIdx !== 0 /* class */ && typeIdx !== 2 /* interface */) { + if (modifiers & 8 /* Readonly */ || nodeFlags & 2 /* Const */ || symbol.getFlags() & 8 /* EnumMember */) { + modifierSet |= 1 << 3 /* readonly */; + } + } + if ((typeIdx === 7 /* variable */ || typeIdx === 10 /* function */) && isLocalDeclaration(decl, sourceFile)) { + modifierSet |= 1 << 5 /* local */; + } + if (program.isSourceFileDefaultLibrary(decl.getSourceFile())) { + modifierSet |= 1 << 4 /* defaultLibrary */; + } + } else if (symbol.declarations && symbol.declarations.some((d) => program.isSourceFileDefaultLibrary(d.getSourceFile()))) { + modifierSet |= 1 << 4 /* defaultLibrary */; + } + collector(node, typeIdx, modifierSet); + } + } + } + forEachChild(node, visit); + inJSXElement = prevInJSXElement; + } + visit(sourceFile); } - function getFunctionInfo(file, startPosition, program) { - const token = getTokenAtPosition(file, startPosition); - const typeChecker = program.getTypeChecker(); - const func = tryGetFunctionFromVariableDeclaration(file, typeChecker, token.parent); - if (func && !containingThis(func.body) && !typeChecker.containsArgumentsReference(func)) { - return { selectedVariableDeclaration: true, func }; + function classifySymbol2(symbol, meaning) { + const flags = symbol.getFlags(); + if (flags & 32 /* Class */) { + return 0 /* class */; + } else if (flags & 384 /* Enum */) { + return 1 /* enum */; + } else if (flags & 524288 /* TypeAlias */) { + return 5 /* type */; + } else if (flags & 64 /* Interface */) { + if (meaning & 2 /* Type */) { + return 2 /* interface */; + } + } else if (flags & 262144 /* TypeParameter */) { + return 4 /* typeParameter */; } - const maybeFunc = getContainingFunction(token); - if (maybeFunc && (isFunctionExpression(maybeFunc) || isArrowFunction(maybeFunc)) && !rangeContainsRange(maybeFunc.body, token) && !containingThis(maybeFunc.body) && !typeChecker.containsArgumentsReference(maybeFunc)) { - if (isFunctionExpression(maybeFunc) && isFunctionReferencedInFile(file, typeChecker, maybeFunc)) - return void 0; - return { selectedVariableDeclaration: false, func: maybeFunc }; + let decl = symbol.valueDeclaration || symbol.declarations && symbol.declarations[0]; + if (decl && isBindingElement(decl)) { + decl = getDeclarationForBindingElement(decl); } - return void 0; + return decl && tokenFromDeclarationMapping.get(decl.kind); } - function isSingleVariableDeclaration(parent2) { - return isVariableDeclaration(parent2) || isVariableDeclarationList(parent2) && parent2.declarations.length === 1; + function reclassifyByType(typeChecker, node, typeIdx) { + if (typeIdx === 7 /* variable */ || typeIdx === 9 /* property */ || typeIdx === 6 /* parameter */) { + const type = typeChecker.getTypeAtLocation(node); + if (type) { + const test = (condition) => { + return condition(type) || type.isUnion() && type.types.some(condition); + }; + if (typeIdx !== 6 /* parameter */ && test((t) => t.getConstructSignatures().length > 0)) { + return 0 /* class */; + } + if (test((t) => t.getCallSignatures().length > 0) && !test((t) => t.getProperties().length > 0) || isExpressionInCallExpression(node)) { + return typeIdx === 9 /* property */ ? 11 /* member */ : 10 /* function */; + } + } + } + return typeIdx; } - function tryGetFunctionFromVariableDeclaration(sourceFile, typeChecker, parent2) { - if (!isSingleVariableDeclaration(parent2)) { - return void 0; + function isLocalDeclaration(decl, sourceFile) { + if (isBindingElement(decl)) { + decl = getDeclarationForBindingElement(decl); } - const variableDeclaration = isVariableDeclaration(parent2) ? parent2 : first(parent2.declarations); - const initializer = variableDeclaration.initializer; - if (initializer && (isArrowFunction(initializer) || isFunctionExpression(initializer) && !isFunctionReferencedInFile(sourceFile, typeChecker, initializer))) { - return initializer; + if (isVariableDeclaration(decl)) { + return (!isSourceFile(decl.parent.parent.parent) || isCatchClause(decl.parent)) && decl.getSourceFile() === sourceFile; + } else if (isFunctionDeclaration(decl)) { + return !isSourceFile(decl.parent) && decl.getSourceFile() === sourceFile; } - return void 0; + return false; } - function convertToBlock(body) { - if (isExpression(body)) { - const returnStatement = factory.createReturnStatement(body); - const file = body.getSourceFile(); - setTextRange(returnStatement, body); - suppressLeadingAndTrailingTrivia(returnStatement); - copyTrailingAsLeadingComments( - body, - returnStatement, - file, - /*commentKind*/ - void 0, - /*hasTrailingNewLine*/ - true - ); - return factory.createBlock( - [returnStatement], - /*multiLine*/ - true - ); - } else { - return body; + function getDeclarationForBindingElement(element) { + while (true) { + if (isBindingElement(element.parent.parent)) { + element = element.parent.parent; + } else { + return element.parent.parent; + } } } - function getVariableInfo(func) { - const variableDeclaration = func.parent; - if (!isVariableDeclaration(variableDeclaration) || !isVariableDeclarationInVariableStatement(variableDeclaration)) - return void 0; - const variableDeclarationList = variableDeclaration.parent; - const statement = variableDeclarationList.parent; - if (!isVariableDeclarationList(variableDeclarationList) || !isVariableStatement(statement) || !isIdentifier(variableDeclaration.name)) - return void 0; - return { variableDeclaration, variableDeclarationList, statement, name: variableDeclaration.name }; - } - function getEditInfoForConvertToAnonymousFunction(context, func) { - const { file } = context; - const body = convertToBlock(func.body); - const newNode = factory.createFunctionExpression( - func.modifiers, - func.asteriskToken, - /*name*/ - void 0, - func.typeParameters, - func.parameters, - func.type, - body - ); - return ts_textChanges_exports.ChangeTracker.with(context, (t) => t.replaceNode(file, func, newNode)); - } - function getEditInfoForConvertToNamedFunction(context, func, variableInfo) { - const { file } = context; - const body = convertToBlock(func.body); - const { variableDeclaration, variableDeclarationList, statement, name } = variableInfo; - suppressLeadingTrivia(statement); - const modifiersFlags = getCombinedModifierFlags(variableDeclaration) & 1 /* Export */ | getEffectiveModifierFlags(func); - const modifiers = factory.createModifiersFromModifierFlags(modifiersFlags); - const newNode = factory.createFunctionDeclaration(length(modifiers) ? modifiers : void 0, func.asteriskToken, name, func.typeParameters, func.parameters, func.type, body); - if (variableDeclarationList.declarations.length === 1) { - return ts_textChanges_exports.ChangeTracker.with(context, (t) => t.replaceNode(file, statement, newNode)); - } else { - return ts_textChanges_exports.ChangeTracker.with(context, (t) => { - t.delete(file, variableDeclaration); - t.insertNodeAfter(file, statement, newNode); - }); - } + function inImportClause(node) { + const parent2 = node.parent; + return parent2 && (isImportClause(parent2) || isImportSpecifier(parent2) || isNamespaceImport(parent2)); } - function getEditInfoForConvertToArrowFunction(context, func) { - const { file } = context; - const statements = func.body.statements; - const head = statements[0]; - let body; - if (canBeConvertedToExpression(func.body, head)) { - body = head.expression; - suppressLeadingAndTrailingTrivia(body); - copyComments(head, body); - } else { - body = func.body; + function isExpressionInCallExpression(node) { + while (isRightSideOfQualifiedNameOrPropertyAccess2(node)) { + node = node.parent; } - const newNode = factory.createArrowFunction(func.modifiers, func.typeParameters, func.parameters, func.type, factory.createToken(39 /* EqualsGreaterThanToken */), body); - return ts_textChanges_exports.ChangeTracker.with(context, (t) => t.replaceNode(file, func, newNode)); - } - function canBeConvertedToExpression(body, head) { - return body.statements.length === 1 && (isReturnStatement(head) && !!head.expression); + return isCallExpression(node.parent) && node.parent.expression === node; } - function isFunctionReferencedInFile(sourceFile, typeChecker, node) { - return !!node.name && ts_FindAllReferences_exports.Core.isSymbolReferencedInFile(node.name, typeChecker, sourceFile); + function isRightSideOfQualifiedNameOrPropertyAccess2(node) { + return isQualifiedName(node.parent) && node.parent.right === node || isPropertyAccessExpression(node.parent) && node.parent.name === node; } - var refactorName7, refactorDescription3, toAnonymousFunctionAction, toNamedFunctionAction, toArrowFunctionAction; - var init_convertArrowFunctionOrFunctionExpression = __esm({ - "src/services/refactors/convertArrowFunctionOrFunctionExpression.ts"() { + var TokenEncodingConsts, TokenType, TokenModifier, tokenFromDeclarationMapping; + var init_classifier2020 = __esm({ + "src/services/classifier2020.ts"() { "use strict"; init_ts4(); - init_ts_refactor(); - refactorName7 = "Convert arrow function or function expression"; - refactorDescription3 = getLocaleSpecificMessage(Diagnostics.Convert_arrow_function_or_function_expression); - toAnonymousFunctionAction = { - name: "Convert to anonymous function", - description: getLocaleSpecificMessage(Diagnostics.Convert_to_anonymous_function), - kind: "refactor.rewrite.function.anonymous" - }; - toNamedFunctionAction = { - name: "Convert to named function", - description: getLocaleSpecificMessage(Diagnostics.Convert_to_named_function), - kind: "refactor.rewrite.function.named" - }; - toArrowFunctionAction = { - name: "Convert to arrow function", - description: getLocaleSpecificMessage(Diagnostics.Convert_to_arrow_function), - kind: "refactor.rewrite.function.arrow" - }; - registerRefactor(refactorName7, { - kinds: [ - toAnonymousFunctionAction.kind, - toNamedFunctionAction.kind, - toArrowFunctionAction.kind - ], - getEditsForAction: getRefactorEditsToConvertFunctionExpressions, - getAvailableActions: getRefactorActionsToConvertFunctionExpressions - }); - } - }); - - // src/services/_namespaces/ts.refactor.convertArrowFunctionOrFunctionExpression.ts - var ts_refactor_convertArrowFunctionOrFunctionExpression_exports = {}; - var init_ts_refactor_convertArrowFunctionOrFunctionExpression = __esm({ - "src/services/_namespaces/ts.refactor.convertArrowFunctionOrFunctionExpression.ts"() { - "use strict"; - init_convertArrowFunctionOrFunctionExpression(); + TokenEncodingConsts = /* @__PURE__ */ ((TokenEncodingConsts2) => { + TokenEncodingConsts2[TokenEncodingConsts2["typeOffset"] = 8] = "typeOffset"; + TokenEncodingConsts2[TokenEncodingConsts2["modifierMask"] = 255] = "modifierMask"; + return TokenEncodingConsts2; + })(TokenEncodingConsts || {}); + TokenType = /* @__PURE__ */ ((TokenType2) => { + TokenType2[TokenType2["class"] = 0] = "class"; + TokenType2[TokenType2["enum"] = 1] = "enum"; + TokenType2[TokenType2["interface"] = 2] = "interface"; + TokenType2[TokenType2["namespace"] = 3] = "namespace"; + TokenType2[TokenType2["typeParameter"] = 4] = "typeParameter"; + TokenType2[TokenType2["type"] = 5] = "type"; + TokenType2[TokenType2["parameter"] = 6] = "parameter"; + TokenType2[TokenType2["variable"] = 7] = "variable"; + TokenType2[TokenType2["enumMember"] = 8] = "enumMember"; + TokenType2[TokenType2["property"] = 9] = "property"; + TokenType2[TokenType2["function"] = 10] = "function"; + TokenType2[TokenType2["member"] = 11] = "member"; + return TokenType2; + })(TokenType || {}); + TokenModifier = /* @__PURE__ */ ((TokenModifier2) => { + TokenModifier2[TokenModifier2["declaration"] = 0] = "declaration"; + TokenModifier2[TokenModifier2["static"] = 1] = "static"; + TokenModifier2[TokenModifier2["async"] = 2] = "async"; + TokenModifier2[TokenModifier2["readonly"] = 3] = "readonly"; + TokenModifier2[TokenModifier2["defaultLibrary"] = 4] = "defaultLibrary"; + TokenModifier2[TokenModifier2["local"] = 5] = "local"; + return TokenModifier2; + })(TokenModifier || {}); + tokenFromDeclarationMapping = /* @__PURE__ */ new Map([ + [260 /* VariableDeclaration */, 7 /* variable */], + [169 /* Parameter */, 6 /* parameter */], + [172 /* PropertyDeclaration */, 9 /* property */], + [267 /* ModuleDeclaration */, 3 /* namespace */], + [266 /* EnumDeclaration */, 1 /* enum */], + [306 /* EnumMember */, 8 /* enumMember */], + [263 /* ClassDeclaration */, 0 /* class */], + [174 /* MethodDeclaration */, 11 /* member */], + [262 /* FunctionDeclaration */, 10 /* function */], + [218 /* FunctionExpression */, 10 /* function */], + [173 /* MethodSignature */, 11 /* member */], + [177 /* GetAccessor */, 9 /* property */], + [178 /* SetAccessor */, 9 /* property */], + [171 /* PropertySignature */, 9 /* property */], + [264 /* InterfaceDeclaration */, 2 /* interface */], + [265 /* TypeAliasDeclaration */, 5 /* type */], + [168 /* TypeParameter */, 4 /* typeParameter */], + [303 /* PropertyAssignment */, 9 /* property */], + [304 /* ShorthandPropertyAssignment */, 9 /* property */] + ]); } }); - // src/services/refactors/convertParamsToDestructuredObject.ts - function getRefactorActionsToConvertParametersToDestructuredObject(context) { - const { file, startPosition } = context; - const isJSFile = isSourceFileJS(file); - if (isJSFile) - return emptyArray; - const functionDeclaration = getFunctionDeclarationAtPosition(file, startPosition, context.program.getTypeChecker()); - if (!functionDeclaration) - return emptyArray; - return [{ - name: refactorName8, - description: refactorDescription4, - actions: [toDestructuredAction] - }]; - } - function getRefactorEditsToConvertParametersToDestructuredObject(context, actionName2) { - Debug.assert(actionName2 === refactorName8, "Unexpected action name"); - const { file, startPosition, program, cancellationToken, host } = context; - const functionDeclaration = getFunctionDeclarationAtPosition(file, startPosition, program.getTypeChecker()); - if (!functionDeclaration || !cancellationToken) - return void 0; - const groupedReferences = getGroupedReferences(functionDeclaration, program, cancellationToken); - if (groupedReferences.valid) { - const edits = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange5(file, program, host, t, functionDeclaration, groupedReferences)); - return { renameFilename: void 0, renameLocation: void 0, edits }; - } - return { edits: [] }; + // src/services/services.ts + function createNode(kind, pos, end, parent2) { + const node = isNodeKind(kind) ? new NodeObject(kind, pos, end) : kind === 80 /* Identifier */ ? new IdentifierObject(80 /* Identifier */, pos, end) : kind === 81 /* PrivateIdentifier */ ? new PrivateIdentifierObject(81 /* PrivateIdentifier */, pos, end) : new TokenObject(kind, pos, end); + node.parent = parent2; + node.flags = parent2.flags & 101441536 /* ContextFlags */; + return node; } - function doChange5(sourceFile, program, host, changes, functionDeclaration, groupedReferences) { - const signature = groupedReferences.signature; - const newFunctionDeclarationParams = map(createNewParameters(functionDeclaration, program, host), (param) => getSynthesizedDeepClone(param)); - if (signature) { - const newSignatureParams = map(createNewParameters(signature, program, host), (param) => getSynthesizedDeepClone(param)); - replaceParameters(signature, newSignatureParams); - } - replaceParameters(functionDeclaration, newFunctionDeclarationParams); - const functionCalls = sortAndDeduplicate( - groupedReferences.functionCalls, - /*comparer*/ - (a, b) => compareValues(a.pos, b.pos) - ); - for (const call of functionCalls) { - if (call.arguments && call.arguments.length) { - const newArgument = getSynthesizedDeepClone( - createNewArgument(functionDeclaration, call.arguments), - /*includeTrivia*/ - true - ); - changes.replaceNodeRange( - getSourceFileOfNode(call), - first(call.arguments), - last(call.arguments), - newArgument, - { leadingTriviaOption: ts_textChanges_exports.LeadingTriviaOption.IncludeAll, trailingTriviaOption: ts_textChanges_exports.TrailingTriviaOption.Include } - ); - } + function createChildren(node, sourceFile) { + if (!isNodeKind(node.kind)) { + return emptyArray; } - function replaceParameters(declarationOrSignature, parameterDeclarations) { - changes.replaceNodeRangeWithNodes( - sourceFile, - first(declarationOrSignature.parameters), - last(declarationOrSignature.parameters), - parameterDeclarations, - { - joiner: ", ", - // indentation is set to 0 because otherwise the object parameter will be indented if there is a `this` parameter - indentation: 0, - leadingTriviaOption: ts_textChanges_exports.LeadingTriviaOption.IncludeAll, - trailingTriviaOption: ts_textChanges_exports.TrailingTriviaOption.Include - } - ); + const children = []; + if (isJSDocCommentContainingNode(node)) { + node.forEachChild((child) => { + children.push(child); + }); + return children; } + scanner.setText((sourceFile || node.getSourceFile()).text); + let pos = node.pos; + const processNode = (child) => { + addSyntheticNodes(children, pos, child.pos, node); + children.push(child); + pos = child.end; + }; + const processNodes = (nodes) => { + addSyntheticNodes(children, pos, nodes.pos, node); + children.push(createSyntaxList(nodes, node)); + pos = nodes.end; + }; + forEach(node.jsDoc, processNode); + pos = node.pos; + node.forEachChild(processNode, processNodes); + addSyntheticNodes(children, pos, node.end, node); + scanner.setText(void 0); + return children; } - function getGroupedReferences(functionDeclaration, program, cancellationToken) { - const functionNames = getFunctionNames(functionDeclaration); - const classNames = isConstructorDeclaration(functionDeclaration) ? getClassNames(functionDeclaration) : []; - const names = deduplicate([...functionNames, ...classNames], equateValues); - const checker = program.getTypeChecker(); - const references = flatMap( - names, - /*mapfn*/ - (name) => ts_FindAllReferences_exports.getReferenceEntriesForNode(-1, name, program, program.getSourceFiles(), cancellationToken) - ); - const groupedReferences = groupReferences(references); - if (!every( - groupedReferences.declarations, - /*callback*/ - (decl) => contains(names, decl) - )) { - groupedReferences.valid = false; - } - return groupedReferences; - function groupReferences(referenceEntries) { - const classReferences = { accessExpressions: [], typeUsages: [] }; - const groupedReferences2 = { functionCalls: [], declarations: [], classReferences, valid: true }; - const functionSymbols = map(functionNames, getSymbolTargetAtLocation); - const classSymbols = map(classNames, getSymbolTargetAtLocation); - const isConstructor = isConstructorDeclaration(functionDeclaration); - const contextualSymbols = map(functionNames, (name) => getSymbolForContextualType(name, checker)); - for (const entry of referenceEntries) { - if (entry.kind === ts_FindAllReferences_exports.EntryKind.Span) { - groupedReferences2.valid = false; - continue; - } - if (contains(contextualSymbols, getSymbolTargetAtLocation(entry.node))) { - if (isValidMethodSignature(entry.node.parent)) { - groupedReferences2.signature = entry.node.parent; - continue; - } - const call = entryToFunctionCall(entry); - if (call) { - groupedReferences2.functionCalls.push(call); - continue; - } - } - const contextualSymbol = getSymbolForContextualType(entry.node, checker); - if (contextualSymbol && contains(contextualSymbols, contextualSymbol)) { - const decl = entryToDeclaration(entry); - if (decl) { - groupedReferences2.declarations.push(decl); - continue; - } - } - if (contains(functionSymbols, getSymbolTargetAtLocation(entry.node)) || isNewExpressionTarget(entry.node)) { - const importOrExportReference = entryToImportOrExport(entry); - if (importOrExportReference) { - continue; - } - const decl = entryToDeclaration(entry); - if (decl) { - groupedReferences2.declarations.push(decl); - continue; - } - const call = entryToFunctionCall(entry); - if (call) { - groupedReferences2.functionCalls.push(call); - continue; - } - } - if (isConstructor && contains(classSymbols, getSymbolTargetAtLocation(entry.node))) { - const importOrExportReference = entryToImportOrExport(entry); - if (importOrExportReference) { - continue; - } - const decl = entryToDeclaration(entry); - if (decl) { - groupedReferences2.declarations.push(decl); - continue; - } - const accessExpression = entryToAccessExpression(entry); - if (accessExpression) { - classReferences.accessExpressions.push(accessExpression); + function addSyntheticNodes(nodes, pos, end, parent2) { + scanner.resetTokenState(pos); + while (pos < end) { + const token = scanner.scan(); + const textPos = scanner.getTokenEnd(); + if (textPos <= end) { + if (token === 80 /* Identifier */) { + if (hasTabstop(parent2)) { continue; } - if (isClassDeclaration(functionDeclaration.parent)) { - const type = entryToType(entry); - if (type) { - classReferences.typeUsages.push(type); - continue; - } - } + Debug.fail(`Did not expect ${Debug.formatSyntaxKind(parent2.kind)} to have an Identifier in its trivia`); } - groupedReferences2.valid = false; + nodes.push(createNode(token, pos, textPos, parent2)); } - return groupedReferences2; - } - function getSymbolTargetAtLocation(node) { - const symbol = checker.getSymbolAtLocation(node); - return symbol && getSymbolTarget(symbol, checker); - } - } - function getSymbolForContextualType(node, checker) { - const element = getContainingObjectLiteralElement(node); - if (element) { - const contextualType = checker.getContextualTypeForObjectLiteralElement(element); - const symbol = contextualType == null ? void 0 : contextualType.getSymbol(); - if (symbol && !(getCheckFlags(symbol) & 6 /* Synthetic */)) { - return symbol; + pos = textPos; + if (token === 1 /* EndOfFileToken */) { + break; } } } - function entryToImportOrExport(entry) { - const node = entry.node; - if (isImportSpecifier(node.parent) || isImportClause(node.parent) || isImportEqualsDeclaration(node.parent) || isNamespaceImport(node.parent)) { - return node; - } - if (isExportSpecifier(node.parent) || isExportAssignment(node.parent)) { - return node; + function createSyntaxList(nodes, parent2) { + const list = createNode(358 /* SyntaxList */, nodes.pos, nodes.end, parent2); + list._children = []; + let pos = nodes.pos; + for (const node of nodes) { + addSyntheticNodes(list._children, pos, node.pos, parent2); + list._children.push(node); + pos = node.end; } - return void 0; + addSyntheticNodes(list._children, pos, nodes.end, parent2); + return list; } - function entryToDeclaration(entry) { - if (isDeclaration(entry.node.parent)) { - return entry.node; - } - return void 0; + function hasJSDocInheritDocTag(node) { + return getJSDocTags(node).some((tag) => tag.tagName.text === "inheritDoc" || tag.tagName.text === "inheritdoc"); } - function entryToFunctionCall(entry) { - if (entry.node.parent) { - const functionReference = entry.node; - const parent2 = functionReference.parent; - switch (parent2.kind) { - case 212 /* CallExpression */: - case 213 /* NewExpression */: - const callOrNewExpression = tryCast(parent2, isCallOrNewExpression); - if (callOrNewExpression && callOrNewExpression.expression === functionReference) { - return callOrNewExpression; - } - break; - case 210 /* PropertyAccessExpression */: - const propertyAccessExpression = tryCast(parent2, isPropertyAccessExpression); - if (propertyAccessExpression && propertyAccessExpression.parent && propertyAccessExpression.name === functionReference) { - const callOrNewExpression2 = tryCast(propertyAccessExpression.parent, isCallOrNewExpression); - if (callOrNewExpression2 && callOrNewExpression2.expression === propertyAccessExpression) { - return callOrNewExpression2; - } - } - break; - case 211 /* ElementAccessExpression */: - const elementAccessExpression = tryCast(parent2, isElementAccessExpression); - if (elementAccessExpression && elementAccessExpression.parent && elementAccessExpression.argumentExpression === functionReference) { - const callOrNewExpression2 = tryCast(elementAccessExpression.parent, isCallOrNewExpression); - if (callOrNewExpression2 && callOrNewExpression2.expression === elementAccessExpression) { - return callOrNewExpression2; + function getJsDocTagsOfDeclarations(declarations, checker) { + if (!declarations) + return emptyArray; + let tags = ts_JsDoc_exports.getJsDocTagsFromDeclarations(declarations, checker); + if (checker && (tags.length === 0 || declarations.some(hasJSDocInheritDocTag))) { + const seenSymbols = /* @__PURE__ */ new Set(); + for (const declaration of declarations) { + const inheritedTags = findBaseOfDeclaration(checker, declaration, (symbol) => { + var _a; + if (!seenSymbols.has(symbol)) { + seenSymbols.add(symbol); + if (declaration.kind === 177 /* GetAccessor */ || declaration.kind === 178 /* SetAccessor */) { + return symbol.getContextualJsDocTags(declaration, checker); } + return ((_a = symbol.declarations) == null ? void 0 : _a.length) === 1 ? symbol.getJsDocTags() : void 0; } - break; - } - } - return void 0; - } - function entryToAccessExpression(entry) { - if (entry.node.parent) { - const reference = entry.node; - const parent2 = reference.parent; - switch (parent2.kind) { - case 210 /* PropertyAccessExpression */: - const propertyAccessExpression = tryCast(parent2, isPropertyAccessExpression); - if (propertyAccessExpression && propertyAccessExpression.expression === reference) { - return propertyAccessExpression; - } - break; - case 211 /* ElementAccessExpression */: - const elementAccessExpression = tryCast(parent2, isElementAccessExpression); - if (elementAccessExpression && elementAccessExpression.expression === reference) { - return elementAccessExpression; - } - break; + }); + if (inheritedTags) { + tags = [...inheritedTags, ...tags]; + } } } - return void 0; + return tags; } - function entryToType(entry) { - const reference = entry.node; - if (getMeaningFromLocation(reference) === 2 /* Type */ || isExpressionWithTypeArgumentsInClassExtendsClause(reference.parent)) { - return reference; + function getDocumentationComment(declarations, checker) { + if (!declarations) + return emptyArray; + let doc = ts_JsDoc_exports.getJsDocCommentsFromDeclarations(declarations, checker); + if (checker && (doc.length === 0 || declarations.some(hasJSDocInheritDocTag))) { + const seenSymbols = /* @__PURE__ */ new Set(); + for (const declaration of declarations) { + const inheritedDocs = findBaseOfDeclaration(checker, declaration, (symbol) => { + if (!seenSymbols.has(symbol)) { + seenSymbols.add(symbol); + if (declaration.kind === 177 /* GetAccessor */ || declaration.kind === 178 /* SetAccessor */) { + return symbol.getContextualDocumentationComment(declaration, checker); + } + return symbol.getDocumentationComment(checker); + } + }); + if (inheritedDocs) + doc = doc.length === 0 ? inheritedDocs.slice() : inheritedDocs.concat(lineBreakPart(), doc); + } } - return void 0; - } - function getFunctionDeclarationAtPosition(file, startPosition, checker) { - const node = getTouchingToken(file, startPosition); - const functionDeclaration = getContainingFunctionDeclaration(node); - if (isTopLevelJSDoc(node)) - return void 0; - if (functionDeclaration && isValidFunctionDeclaration(functionDeclaration, checker) && rangeContainsRange(functionDeclaration, node) && !(functionDeclaration.body && rangeContainsRange(functionDeclaration.body, node))) - return functionDeclaration; - return void 0; + return doc; } - function isTopLevelJSDoc(node) { - const containingJSDoc = findAncestor(node, isJSDocNode); - if (containingJSDoc) { - const containingNonJSDoc = findAncestor(containingJSDoc, (n) => !isJSDocNode(n)); - return !!containingNonJSDoc && isFunctionLikeDeclaration(containingNonJSDoc); - } - return false; + function findBaseOfDeclaration(checker, declaration, cb) { + var _a; + const classOrInterfaceDeclaration = ((_a = declaration.parent) == null ? void 0 : _a.kind) === 176 /* Constructor */ ? declaration.parent.parent : declaration.parent; + if (!classOrInterfaceDeclaration) + return; + const isStaticMember = hasStaticModifier(declaration); + return firstDefined(getAllSuperTypeNodes(classOrInterfaceDeclaration), (superTypeNode) => { + const baseType = checker.getTypeAtLocation(superTypeNode); + const type = isStaticMember && baseType.symbol ? checker.getTypeOfSymbol(baseType.symbol) : baseType; + const symbol = checker.getPropertyOfType(type, declaration.symbol.name); + return symbol ? cb(symbol) : void 0; + }); } - function isValidMethodSignature(node) { - return isMethodSignature(node) && (isInterfaceDeclaration(node.parent) || isTypeLiteralNode(node.parent)); + function getServicesObjectAllocator() { + return { + getNodeConstructor: () => NodeObject, + getTokenConstructor: () => TokenObject, + getIdentifierConstructor: () => IdentifierObject, + getPrivateIdentifierConstructor: () => PrivateIdentifierObject, + getSourceFileConstructor: () => SourceFileObject, + getSymbolConstructor: () => SymbolObject, + getTypeConstructor: () => TypeObject, + getSignatureConstructor: () => SignatureObject, + getSourceMapSourceConstructor: () => SourceMapSourceObject + }; } - function isValidFunctionDeclaration(functionDeclaration, checker) { - var _a; - if (!isValidParameterNodeArray(functionDeclaration.parameters, checker)) - return false; - switch (functionDeclaration.kind) { - case 261 /* FunctionDeclaration */: - return hasNameOrDefault(functionDeclaration) && isSingleImplementation(functionDeclaration, checker); - case 173 /* MethodDeclaration */: - if (isObjectLiteralExpression(functionDeclaration.parent)) { - const contextualSymbol = getSymbolForContextualType(functionDeclaration.name, checker); - return ((_a = contextualSymbol == null ? void 0 : contextualSymbol.declarations) == null ? void 0 : _a.length) === 1 && isSingleImplementation(functionDeclaration, checker); - } - return isSingleImplementation(functionDeclaration, checker); - case 175 /* Constructor */: - if (isClassDeclaration(functionDeclaration.parent)) { - return hasNameOrDefault(functionDeclaration.parent) && isSingleImplementation(functionDeclaration, checker); - } else { - return isValidVariableDeclaration(functionDeclaration.parent.parent) && isSingleImplementation(functionDeclaration, checker); - } - case 217 /* FunctionExpression */: - case 218 /* ArrowFunction */: - return isValidVariableDeclaration(functionDeclaration.parent); + function toEditorSettings(optionsAsMap) { + let allPropertiesAreCamelCased = true; + for (const key in optionsAsMap) { + if (hasProperty(optionsAsMap, key) && !isCamelCase(key)) { + allPropertiesAreCamelCased = false; + break; + } } - return false; + if (allPropertiesAreCamelCased) { + return optionsAsMap; + } + const settings = {}; + for (const key in optionsAsMap) { + if (hasProperty(optionsAsMap, key)) { + const newKey = isCamelCase(key) ? key : key.charAt(0).toLowerCase() + key.substr(1); + settings[newKey] = optionsAsMap[key]; + } + } + return settings; } - function isSingleImplementation(functionDeclaration, checker) { - return !!functionDeclaration.body && !checker.isImplementationOfOverload(functionDeclaration); + function isCamelCase(s) { + return !s.length || s.charAt(0) === s.charAt(0).toLowerCase(); } - function hasNameOrDefault(functionOrClassDeclaration) { - if (!functionOrClassDeclaration.name) { - const defaultKeyword = findModifier(functionOrClassDeclaration, 90 /* DefaultKeyword */); - return !!defaultKeyword; + function displayPartsToString(displayParts) { + if (displayParts) { + return map(displayParts, (displayPart2) => displayPart2.text).join(""); } - return true; + return ""; } - function isValidParameterNodeArray(parameters, checker) { - return getRefactorableParametersLength(parameters) >= minimumParameterLength && every( - parameters, - /*callback*/ - (paramDecl) => isValidParameterDeclaration(paramDecl, checker) - ); + function getDefaultCompilerOptions2() { + return { + target: 1 /* ES5 */, + jsx: 1 /* Preserve */ + }; } - function isValidParameterDeclaration(parameterDeclaration, checker) { - if (isRestParameter(parameterDeclaration)) { - const type = checker.getTypeAtLocation(parameterDeclaration); - if (!checker.isArrayType(type) && !checker.isTupleType(type)) - return false; - } - return !parameterDeclaration.modifiers && isIdentifier(parameterDeclaration.name); + function getSupportedCodeFixes() { + return ts_codefix_exports.getSupportedErrorCodes(); } - function isValidVariableDeclaration(node) { - return isVariableDeclaration(node) && isVarConst(node) && isIdentifier(node.name) && !node.type; + function setSourceFileFields(sourceFile, scriptSnapshot, version2) { + sourceFile.version = version2; + sourceFile.scriptSnapshot = scriptSnapshot; } - function hasThisParameter(parameters) { - return parameters.length > 0 && isThis(parameters[0].name); + function createLanguageServiceSourceFile(fileName, scriptSnapshot, scriptTargetOrOptions, version2, setNodeParents, scriptKind) { + const sourceFile = createSourceFile(fileName, getSnapshotText(scriptSnapshot), scriptTargetOrOptions, setNodeParents, scriptKind); + setSourceFileFields(sourceFile, scriptSnapshot, version2); + return sourceFile; } - function getRefactorableParametersLength(parameters) { - if (hasThisParameter(parameters)) { - return parameters.length - 1; + function updateLanguageServiceSourceFile(sourceFile, scriptSnapshot, version2, textChangeRange, aggressiveChecks) { + if (textChangeRange) { + if (version2 !== sourceFile.version) { + let newText; + const prefix = textChangeRange.span.start !== 0 ? sourceFile.text.substr(0, textChangeRange.span.start) : ""; + const suffix = textSpanEnd(textChangeRange.span) !== sourceFile.text.length ? sourceFile.text.substr(textSpanEnd(textChangeRange.span)) : ""; + if (textChangeRange.newLength === 0) { + newText = prefix && suffix ? prefix + suffix : prefix || suffix; + } else { + const changedText = scriptSnapshot.getText(textChangeRange.span.start, textChangeRange.span.start + textChangeRange.newLength); + newText = prefix && suffix ? prefix + changedText + suffix : prefix ? prefix + changedText : changedText + suffix; + } + const newSourceFile = updateSourceFile(sourceFile, newText, textChangeRange, aggressiveChecks); + setSourceFileFields(newSourceFile, scriptSnapshot, version2); + newSourceFile.nameTable = void 0; + if (sourceFile !== newSourceFile && sourceFile.scriptSnapshot) { + if (sourceFile.scriptSnapshot.dispose) { + sourceFile.scriptSnapshot.dispose(); + } + sourceFile.scriptSnapshot = void 0; + } + return newSourceFile; + } } - return parameters.length; + const options = { + languageVersion: sourceFile.languageVersion, + impliedNodeFormat: sourceFile.impliedNodeFormat, + setExternalModuleIndicator: sourceFile.setExternalModuleIndicator, + jsDocParsingMode: sourceFile.jsDocParsingMode + }; + return createLanguageServiceSourceFile( + sourceFile.fileName, + scriptSnapshot, + options, + version2, + /*setNodeParents*/ + true, + sourceFile.scriptKind + ); } - function getRefactorableParameters(parameters) { - if (hasThisParameter(parameters)) { - parameters = factory.createNodeArray(parameters.slice(1), parameters.hasTrailingComma); + function createLanguageService(host, documentRegistry = createDocumentRegistry(host.useCaseSensitiveFileNames && host.useCaseSensitiveFileNames(), host.getCurrentDirectory()), syntaxOnlyOrLanguageServiceMode) { + var _a; + let languageServiceMode; + if (syntaxOnlyOrLanguageServiceMode === void 0) { + languageServiceMode = 0 /* Semantic */; + } else if (typeof syntaxOnlyOrLanguageServiceMode === "boolean") { + languageServiceMode = syntaxOnlyOrLanguageServiceMode ? 2 /* Syntactic */ : 0 /* Semantic */; + } else { + languageServiceMode = syntaxOnlyOrLanguageServiceMode; } - return parameters; - } - function createPropertyOrShorthandAssignment(name, initializer) { - if (isIdentifier(initializer) && getTextOfIdentifierOrLiteral(initializer) === name) { - return factory.createShorthandPropertyAssignment(name); + const syntaxTreeCache = new SyntaxTreeCache(host); + let program; + let lastProjectVersion; + let lastTypesRootVersion = 0; + const cancellationToken = host.getCancellationToken ? new CancellationTokenObject(host.getCancellationToken()) : NoopCancellationToken; + const currentDirectory = host.getCurrentDirectory(); + maybeSetLocalizedDiagnosticMessages((_a = host.getLocalizedDiagnosticMessages) == null ? void 0 : _a.bind(host)); + function log(message) { + if (host.log) { + host.log(message); + } } - return factory.createPropertyAssignment(name, initializer); - } - function createNewArgument(functionDeclaration, functionArguments) { - const parameters = getRefactorableParameters(functionDeclaration.parameters); - const hasRestParameter2 = isRestParameter(last(parameters)); - const nonRestArguments = hasRestParameter2 ? functionArguments.slice(0, parameters.length - 1) : functionArguments; - const properties = map(nonRestArguments, (arg, i) => { - const parameterName = getParameterName(parameters[i]); - const property = createPropertyOrShorthandAssignment(parameterName, arg); - suppressLeadingAndTrailingTrivia(property.name); - if (isPropertyAssignment(property)) - suppressLeadingAndTrailingTrivia(property.initializer); - copyComments(arg, property); - return property; + const useCaseSensitiveFileNames2 = hostUsesCaseSensitiveFileNames(host); + const getCanonicalFileName = createGetCanonicalFileName(useCaseSensitiveFileNames2); + const sourceMapper = getSourceMapper({ + useCaseSensitiveFileNames: () => useCaseSensitiveFileNames2, + getCurrentDirectory: () => currentDirectory, + getProgram, + fileExists: maybeBind(host, host.fileExists), + readFile: maybeBind(host, host.readFile), + getDocumentPositionMapper: maybeBind(host, host.getDocumentPositionMapper), + getSourceFileLike: maybeBind(host, host.getSourceFileLike), + log }); - if (hasRestParameter2 && functionArguments.length >= parameters.length) { - const restArguments = functionArguments.slice(parameters.length - 1); - const restProperty = factory.createPropertyAssignment(getParameterName(last(parameters)), factory.createArrayLiteralExpression(restArguments)); - properties.push(restProperty); - } - const objectLiteral = factory.createObjectLiteralExpression( - properties, - /*multiLine*/ - false - ); - return objectLiteral; - } - function createNewParameters(functionDeclaration, program, host) { - const checker = program.getTypeChecker(); - const refactorableParameters = getRefactorableParameters(functionDeclaration.parameters); - const bindingElements = map(refactorableParameters, createBindingElementFromParameterDeclaration); - const objectParameterName = factory.createObjectBindingPattern(bindingElements); - const objectParameterType = createParameterTypeNode(refactorableParameters); - let objectInitializer; - if (every(refactorableParameters, isOptionalParameter)) { - objectInitializer = factory.createObjectLiteralExpression(); + function getValidSourceFile(fileName) { + const sourceFile = program.getSourceFile(fileName); + if (!sourceFile) { + const error2 = new Error(`Could not find source file: '${fileName}'.`); + error2.ProgramFiles = program.getSourceFiles().map((f) => f.fileName); + throw error2; + } + return sourceFile; } - const objectParameter = factory.createParameterDeclaration( - /*modifiers*/ - void 0, - /*dotDotDotToken*/ - void 0, - objectParameterName, - /*questionToken*/ - void 0, - objectParameterType, - objectInitializer - ); - if (hasThisParameter(functionDeclaration.parameters)) { - const thisParameter = functionDeclaration.parameters[0]; - const newThisParameter = factory.createParameterDeclaration( - /*modifiers*/ - void 0, - /*dotDotDotToken*/ - void 0, - thisParameter.name, - /*questionToken*/ - void 0, - thisParameter.type + function synchronizeHostData() { + var _a2, _b, _c; + Debug.assert(languageServiceMode !== 2 /* Syntactic */); + if (host.getProjectVersion) { + const hostProjectVersion = host.getProjectVersion(); + if (hostProjectVersion) { + if (lastProjectVersion === hostProjectVersion && !((_a2 = host.hasChangedAutomaticTypeDirectiveNames) == null ? void 0 : _a2.call(host))) { + return; + } + lastProjectVersion = hostProjectVersion; + } + } + const typeRootsVersion = host.getTypeRootsVersion ? host.getTypeRootsVersion() : 0; + if (lastTypesRootVersion !== typeRootsVersion) { + log("TypeRoots version has changed; provide new program"); + program = void 0; + lastTypesRootVersion = typeRootsVersion; + } + const rootFileNames = host.getScriptFileNames().slice(); + const newSettings = host.getCompilationSettings() || getDefaultCompilerOptions2(); + const hasInvalidatedResolutions = host.hasInvalidatedResolutions || returnFalse; + const hasInvalidatedLibResolutions = maybeBind(host, host.hasInvalidatedLibResolutions) || returnFalse; + const hasChangedAutomaticTypeDirectiveNames = maybeBind(host, host.hasChangedAutomaticTypeDirectiveNames); + const projectReferences = (_b = host.getProjectReferences) == null ? void 0 : _b.call(host); + let parsedCommandLines; + let compilerHost = { + getSourceFile: getOrCreateSourceFile, + getSourceFileByPath: getOrCreateSourceFileByPath, + getCancellationToken: () => cancellationToken, + getCanonicalFileName, + useCaseSensitiveFileNames: () => useCaseSensitiveFileNames2, + getNewLine: () => getNewLineCharacter(newSettings), + getDefaultLibFileName: (options2) => host.getDefaultLibFileName(options2), + writeFile: noop, + getCurrentDirectory: () => currentDirectory, + fileExists: (fileName) => host.fileExists(fileName), + readFile: (fileName) => host.readFile && host.readFile(fileName), + getSymlinkCache: maybeBind(host, host.getSymlinkCache), + realpath: maybeBind(host, host.realpath), + directoryExists: (directoryName) => { + return directoryProbablyExists(directoryName, host); + }, + getDirectories: (path) => { + return host.getDirectories ? host.getDirectories(path) : []; + }, + readDirectory: (path, extensions, exclude, include, depth) => { + Debug.checkDefined(host.readDirectory, "'LanguageServiceHost.readDirectory' must be implemented to correctly process 'projectReferences'"); + return host.readDirectory(path, extensions, exclude, include, depth); + }, + onReleaseOldSourceFile, + onReleaseParsedCommandLine, + hasInvalidatedResolutions, + hasInvalidatedLibResolutions, + hasChangedAutomaticTypeDirectiveNames, + trace: maybeBind(host, host.trace), + resolveModuleNames: maybeBind(host, host.resolveModuleNames), + getModuleResolutionCache: maybeBind(host, host.getModuleResolutionCache), + createHash: maybeBind(host, host.createHash), + resolveTypeReferenceDirectives: maybeBind(host, host.resolveTypeReferenceDirectives), + resolveModuleNameLiterals: maybeBind(host, host.resolveModuleNameLiterals), + resolveTypeReferenceDirectiveReferences: maybeBind(host, host.resolveTypeReferenceDirectiveReferences), + resolveLibrary: maybeBind(host, host.resolveLibrary), + useSourceOfProjectReferenceRedirect: maybeBind(host, host.useSourceOfProjectReferenceRedirect), + getParsedCommandLine, + jsDocParsingMode: host.jsDocParsingMode + }; + const originalGetSourceFile = compilerHost.getSourceFile; + const { getSourceFileWithCache } = changeCompilerHostLikeToUseCache( + compilerHost, + (fileName) => toPath(fileName, currentDirectory, getCanonicalFileName), + (...args) => originalGetSourceFile.call(compilerHost, ...args) ); - suppressLeadingAndTrailingTrivia(newThisParameter.name); - copyComments(thisParameter.name, newThisParameter.name); - if (thisParameter.type) { - suppressLeadingAndTrailingTrivia(newThisParameter.type); - copyComments(thisParameter.type, newThisParameter.type); + compilerHost.getSourceFile = getSourceFileWithCache; + (_c = host.setCompilerHost) == null ? void 0 : _c.call(host, compilerHost); + const parseConfigHost = { + useCaseSensitiveFileNames: useCaseSensitiveFileNames2, + fileExists: (fileName) => compilerHost.fileExists(fileName), + readFile: (fileName) => compilerHost.readFile(fileName), + directoryExists: (f) => compilerHost.directoryExists(f), + getDirectories: (f) => compilerHost.getDirectories(f), + realpath: compilerHost.realpath, + readDirectory: (...args) => compilerHost.readDirectory(...args), + trace: compilerHost.trace, + getCurrentDirectory: compilerHost.getCurrentDirectory, + onUnRecoverableConfigFileDiagnostic: noop + }; + const documentRegistryBucketKey = documentRegistry.getKeyForCompilationSettings(newSettings); + let releasedScriptKinds = /* @__PURE__ */ new Set(); + if (isProgramUptoDate(program, rootFileNames, newSettings, (_path, fileName) => host.getScriptVersion(fileName), (fileName) => compilerHost.fileExists(fileName), hasInvalidatedResolutions, hasInvalidatedLibResolutions, hasChangedAutomaticTypeDirectiveNames, getParsedCommandLine, projectReferences)) { + compilerHost = void 0; + parsedCommandLines = void 0; + releasedScriptKinds = void 0; + return; + } + const options = { + rootNames: rootFileNames, + options: newSettings, + host: compilerHost, + oldProgram: program, + projectReferences + }; + program = createProgram(options); + compilerHost = void 0; + parsedCommandLines = void 0; + releasedScriptKinds = void 0; + sourceMapper.clearCache(); + program.getTypeChecker(); + return; + function getParsedCommandLine(fileName) { + const path = toPath(fileName, currentDirectory, getCanonicalFileName); + const existing = parsedCommandLines == null ? void 0 : parsedCommandLines.get(path); + if (existing !== void 0) + return existing || void 0; + const result = host.getParsedCommandLine ? host.getParsedCommandLine(fileName) : getParsedCommandLineOfConfigFileUsingSourceFile(fileName); + (parsedCommandLines || (parsedCommandLines = /* @__PURE__ */ new Map())).set(path, result || false); + return result; + } + function getParsedCommandLineOfConfigFileUsingSourceFile(configFileName) { + const result = getOrCreateSourceFile(configFileName, 100 /* JSON */); + if (!result) + return void 0; + result.path = toPath(configFileName, currentDirectory, getCanonicalFileName); + result.resolvedPath = result.path; + result.originalFileName = result.fileName; + return parseJsonSourceFileConfigFileContent( + result, + parseConfigHost, + getNormalizedAbsolutePath(getDirectoryPath(configFileName), currentDirectory), + /*existingOptions*/ + void 0, + getNormalizedAbsolutePath(configFileName, currentDirectory) + ); + } + function onReleaseParsedCommandLine(configFileName, oldResolvedRef, oldOptions) { + var _a3; + if (host.getParsedCommandLine) { + (_a3 = host.onReleaseParsedCommandLine) == null ? void 0 : _a3.call(host, configFileName, oldResolvedRef, oldOptions); + } else if (oldResolvedRef) { + onReleaseOldSourceFile(oldResolvedRef.sourceFile, oldOptions); + } + } + function onReleaseOldSourceFile(oldSourceFile, oldOptions) { + const oldSettingsKey = documentRegistry.getKeyForCompilationSettings(oldOptions); + documentRegistry.releaseDocumentWithKey(oldSourceFile.resolvedPath, oldSettingsKey, oldSourceFile.scriptKind, oldSourceFile.impliedNodeFormat); + } + function getOrCreateSourceFile(fileName, languageVersionOrOptions, onError, shouldCreateNewSourceFile) { + return getOrCreateSourceFileByPath(fileName, toPath(fileName, currentDirectory, getCanonicalFileName), languageVersionOrOptions, onError, shouldCreateNewSourceFile); + } + function getOrCreateSourceFileByPath(fileName, path, languageVersionOrOptions, _onError, shouldCreateNewSourceFile) { + Debug.assert(compilerHost, "getOrCreateSourceFileByPath called after typical CompilerHost lifetime, check the callstack something with a reference to an old host."); + const scriptSnapshot = host.getScriptSnapshot(fileName); + if (!scriptSnapshot) { + return void 0; + } + const scriptKind = getScriptKind(fileName, host); + const scriptVersion = host.getScriptVersion(fileName); + if (!shouldCreateNewSourceFile) { + const oldSourceFile = program && program.getSourceFileByPath(path); + if (oldSourceFile) { + if (scriptKind === oldSourceFile.scriptKind || releasedScriptKinds.has(oldSourceFile.resolvedPath)) { + return documentRegistry.updateDocumentWithKey(fileName, path, host, documentRegistryBucketKey, scriptSnapshot, scriptVersion, scriptKind, languageVersionOrOptions); + } else { + documentRegistry.releaseDocumentWithKey(oldSourceFile.resolvedPath, documentRegistry.getKeyForCompilationSettings(program.getCompilerOptions()), oldSourceFile.scriptKind, oldSourceFile.impliedNodeFormat); + releasedScriptKinds.add(oldSourceFile.resolvedPath); + } + } + } + return documentRegistry.acquireDocumentWithKey(fileName, path, host, documentRegistryBucketKey, scriptSnapshot, scriptVersion, scriptKind, languageVersionOrOptions); } - return factory.createNodeArray([newThisParameter, objectParameter]); } - return factory.createNodeArray([objectParameter]); - function createBindingElementFromParameterDeclaration(parameterDeclaration) { - const element = factory.createBindingElement( - /*dotDotDotToken*/ - void 0, - /*propertyName*/ - void 0, - getParameterName(parameterDeclaration), - isRestParameter(parameterDeclaration) && isOptionalParameter(parameterDeclaration) ? factory.createArrayLiteralExpression() : parameterDeclaration.initializer - ); - suppressLeadingAndTrailingTrivia(element); - if (parameterDeclaration.initializer && element.initializer) { - copyComments(parameterDeclaration.initializer, element.initializer); + function getProgram() { + if (languageServiceMode === 2 /* Syntactic */) { + Debug.assert(program === void 0); + return void 0; } - return element; + synchronizeHostData(); + return program; } - function createParameterTypeNode(parameters) { - const members = map(parameters, createPropertySignatureFromParameterDeclaration); - const typeNode = addEmitFlags(factory.createTypeLiteralNode(members), 1 /* SingleLine */); - return typeNode; + function getAutoImportProvider() { + var _a2; + return (_a2 = host.getPackageJsonAutoImportProvider) == null ? void 0 : _a2.call(host); } - function createPropertySignatureFromParameterDeclaration(parameterDeclaration) { - let parameterType = parameterDeclaration.type; - if (!parameterType && (parameterDeclaration.initializer || isRestParameter(parameterDeclaration))) { - parameterType = getTypeNode3(parameterDeclaration); + function updateIsDefinitionOfReferencedSymbols(referencedSymbols, knownSymbolSpans) { + const checker = program.getTypeChecker(); + const symbol = getSymbolForProgram(); + if (!symbol) + return false; + for (const referencedSymbol of referencedSymbols) { + for (const ref of referencedSymbol.references) { + const refNode = getNodeForSpan(ref); + Debug.assertIsDefined(refNode); + if (knownSymbolSpans.has(ref) || ts_FindAllReferences_exports.isDeclarationOfSymbol(refNode, symbol)) { + knownSymbolSpans.add(ref); + ref.isDefinition = true; + const mappedSpan = getMappedDocumentSpan(ref, sourceMapper, maybeBind(host, host.fileExists)); + if (mappedSpan) { + knownSymbolSpans.add(mappedSpan); + } + } else { + ref.isDefinition = false; + } + } } - const propertySignature = factory.createPropertySignature( - /*modifiers*/ - void 0, - getParameterName(parameterDeclaration), - isOptionalParameter(parameterDeclaration) ? factory.createToken(58 /* QuestionToken */) : parameterDeclaration.questionToken, - parameterType - ); - suppressLeadingAndTrailingTrivia(propertySignature); - copyComments(parameterDeclaration.name, propertySignature.name); - if (parameterDeclaration.type && propertySignature.type) { - copyComments(parameterDeclaration.type, propertySignature.type); + return true; + function getSymbolForProgram() { + for (const referencedSymbol of referencedSymbols) { + for (const ref of referencedSymbol.references) { + if (knownSymbolSpans.has(ref)) { + const refNode = getNodeForSpan(ref); + Debug.assertIsDefined(refNode); + return checker.getSymbolAtLocation(refNode); + } + const mappedSpan = getMappedDocumentSpan(ref, sourceMapper, maybeBind(host, host.fileExists)); + if (mappedSpan && knownSymbolSpans.has(mappedSpan)) { + const refNode = getNodeForSpan(mappedSpan); + if (refNode) { + return checker.getSymbolAtLocation(refNode); + } + } + } + } + return void 0; + } + function getNodeForSpan(docSpan) { + const sourceFile = program.getSourceFile(docSpan.fileName); + if (!sourceFile) + return void 0; + const rawNode = getTouchingPropertyName(sourceFile, docSpan.textSpan.start); + const adjustedNode = ts_FindAllReferences_exports.Core.getAdjustedNode(rawNode, { use: ts_FindAllReferences_exports.FindReferencesUse.References }); + return adjustedNode; } - return propertySignature; - } - function getTypeNode3(node) { - const type = checker.getTypeAtLocation(node); - return getTypeNodeIfAccessible(type, node, program, host); } - function isOptionalParameter(parameterDeclaration) { - if (isRestParameter(parameterDeclaration)) { - const type = checker.getTypeAtLocation(parameterDeclaration); - return !checker.isTupleType(type); + function cleanupSemanticCache() { + if (program) { + const key = documentRegistry.getKeyForCompilationSettings(program.getCompilerOptions()); + forEach(program.getSourceFiles(), (f) => documentRegistry.releaseDocumentWithKey(f.resolvedPath, key, f.scriptKind, f.impliedNodeFormat)); + program = void 0; } - return checker.isOptionalParameter(parameterDeclaration); } - } - function getParameterName(paramDeclaration) { - return getTextOfIdentifierOrLiteral(paramDeclaration.name); - } - function getClassNames(constructorDeclaration) { - switch (constructorDeclaration.parent.kind) { - case 262 /* ClassDeclaration */: - const classDeclaration = constructorDeclaration.parent; - if (classDeclaration.name) - return [classDeclaration.name]; - const defaultModifier = Debug.checkDefined( - findModifier(classDeclaration, 90 /* DefaultKeyword */), - "Nameless class declaration should be a default export" - ); - return [defaultModifier]; - case 230 /* ClassExpression */: - const classExpression = constructorDeclaration.parent; - const variableDeclaration = constructorDeclaration.parent.parent; - const className = classExpression.name; - if (className) - return [className, variableDeclaration.name]; - return [variableDeclaration.name]; + function dispose() { + cleanupSemanticCache(); + host = void 0; } - } - function getFunctionNames(functionDeclaration) { - switch (functionDeclaration.kind) { - case 261 /* FunctionDeclaration */: - if (functionDeclaration.name) - return [functionDeclaration.name]; - const defaultModifier = Debug.checkDefined( - findModifier(functionDeclaration, 90 /* DefaultKeyword */), - "Nameless function declaration should be a default export" - ); - return [defaultModifier]; - case 173 /* MethodDeclaration */: - return [functionDeclaration.name]; - case 175 /* Constructor */: - const ctrKeyword = Debug.checkDefined( - findChildOfKind(functionDeclaration, 137 /* ConstructorKeyword */, functionDeclaration.getSourceFile()), - "Constructor declaration should have constructor keyword" - ); - if (functionDeclaration.parent.kind === 230 /* ClassExpression */) { - const variableDeclaration = functionDeclaration.parent.parent; - return [variableDeclaration.name, ctrKeyword]; - } - return [ctrKeyword]; - case 218 /* ArrowFunction */: - return [functionDeclaration.parent.name]; - case 217 /* FunctionExpression */: - if (functionDeclaration.name) - return [functionDeclaration.name, functionDeclaration.parent.name]; - return [functionDeclaration.parent.name]; - default: - return Debug.assertNever(functionDeclaration, `Unexpected function declaration kind ${functionDeclaration.kind}`); + function getSyntacticDiagnostics(fileName) { + synchronizeHostData(); + return program.getSyntacticDiagnostics(getValidSourceFile(fileName), cancellationToken).slice(); } - } - var refactorName8, minimumParameterLength, refactorDescription4, toDestructuredAction; - var init_convertParamsToDestructuredObject = __esm({ - "src/services/refactors/convertParamsToDestructuredObject.ts"() { - "use strict"; - init_ts4(); - init_ts_refactor(); - refactorName8 = "Convert parameters to destructured object"; - minimumParameterLength = 1; - refactorDescription4 = getLocaleSpecificMessage(Diagnostics.Convert_parameters_to_destructured_object); - toDestructuredAction = { - name: refactorName8, - description: refactorDescription4, - kind: "refactor.rewrite.parameters.toDestructured" - }; - registerRefactor(refactorName8, { - kinds: [toDestructuredAction.kind], - getEditsForAction: getRefactorEditsToConvertParametersToDestructuredObject, - getAvailableActions: getRefactorActionsToConvertParametersToDestructuredObject - }); + function getSemanticDiagnostics(fileName) { + synchronizeHostData(); + const targetSourceFile = getValidSourceFile(fileName); + const semanticDiagnostics = program.getSemanticDiagnostics(targetSourceFile, cancellationToken); + if (!getEmitDeclarations(program.getCompilerOptions())) { + return semanticDiagnostics.slice(); + } + const declarationDiagnostics = program.getDeclarationDiagnostics(targetSourceFile, cancellationToken); + return [...semanticDiagnostics, ...declarationDiagnostics]; } - }); - - // src/services/_namespaces/ts.refactor.convertParamsToDestructuredObject.ts - var ts_refactor_convertParamsToDestructuredObject_exports = {}; - var init_ts_refactor_convertParamsToDestructuredObject = __esm({ - "src/services/_namespaces/ts.refactor.convertParamsToDestructuredObject.ts"() { - "use strict"; - init_convertParamsToDestructuredObject(); + function getSuggestionDiagnostics(fileName) { + synchronizeHostData(); + return computeSuggestionDiagnostics(getValidSourceFile(fileName), program, cancellationToken); } - }); - - // src/services/refactors/convertStringOrTemplateLiteral.ts - function getRefactorActionsToConvertToTemplateString(context) { - const { file, startPosition } = context; - const node = getNodeOrParentOfParentheses(file, startPosition); - const maybeBinary = getParentBinaryExpression(node); - const refactorInfo = { name: refactorName9, description: refactorDescription5, actions: [] }; - if (isBinaryExpression(maybeBinary) && treeToArray(maybeBinary).isValidConcatenation) { - refactorInfo.actions.push(convertStringAction); - return [refactorInfo]; - } else if (context.preferences.provideRefactorNotApplicableReason) { - refactorInfo.actions.push({ - ...convertStringAction, - notApplicableReason: getLocaleSpecificMessage(Diagnostics.Can_only_convert_string_concatenation) - }); - return [refactorInfo]; + function getCompilerOptionsDiagnostics() { + synchronizeHostData(); + return [...program.getOptionsDiagnostics(cancellationToken), ...program.getGlobalDiagnostics(cancellationToken)]; } - return emptyArray; - } - function getNodeOrParentOfParentheses(file, startPosition) { - const node = getTokenAtPosition(file, startPosition); - const nestedBinary = getParentBinaryExpression(node); - const isNonStringBinary = !treeToArray(nestedBinary).isValidConcatenation; - if (isNonStringBinary && isParenthesizedExpression(nestedBinary.parent) && isBinaryExpression(nestedBinary.parent.parent)) { - return nestedBinary.parent.parent; + function getCompletionsAtPosition2(fileName, position, options = emptyOptions, formattingSettings) { + const fullPreferences = { + ...identity(options), + // avoid excess property check + includeCompletionsForModuleExports: options.includeCompletionsForModuleExports || options.includeExternalModuleExports, + includeCompletionsWithInsertText: options.includeCompletionsWithInsertText || options.includeInsertTextCompletions + }; + synchronizeHostData(); + return ts_Completions_exports.getCompletionsAtPosition( + host, + program, + log, + getValidSourceFile(fileName), + position, + fullPreferences, + options.triggerCharacter, + options.triggerKind, + cancellationToken, + formattingSettings && ts_formatting_exports.getFormatContext(formattingSettings, host), + options.includeSymbol + ); } - return node; - } - function getRefactorEditsToConvertToTemplateString(context, actionName2) { - const { file, startPosition } = context; - const node = getNodeOrParentOfParentheses(file, startPosition); - switch (actionName2) { - case refactorDescription5: - return { edits: getEditsForToTemplateLiteral(context, node) }; - default: - return Debug.fail("invalid action"); + function getCompletionEntryDetails2(fileName, position, name, formattingOptions, source, preferences = emptyOptions, data) { + synchronizeHostData(); + return ts_Completions_exports.getCompletionEntryDetails( + program, + log, + getValidSourceFile(fileName), + position, + { name, source, data }, + host, + formattingOptions && ts_formatting_exports.getFormatContext(formattingOptions, host), + // TODO: GH#18217 + preferences, + cancellationToken + ); } - } - function getEditsForToTemplateLiteral(context, node) { - const maybeBinary = getParentBinaryExpression(node); - const file = context.file; - const templateLiteral = nodesToTemplate(treeToArray(maybeBinary), file); - const trailingCommentRanges = getTrailingCommentRanges(file.text, maybeBinary.end); - if (trailingCommentRanges) { - const lastComment = trailingCommentRanges[trailingCommentRanges.length - 1]; - const trailingRange = { pos: trailingCommentRanges[0].pos, end: lastComment.end }; - return ts_textChanges_exports.ChangeTracker.with(context, (t) => { - t.deleteRange(file, trailingRange); - t.replaceNode(file, maybeBinary, templateLiteral); - }); - } else { - return ts_textChanges_exports.ChangeTracker.with(context, (t) => t.replaceNode(file, maybeBinary, templateLiteral)); + function getCompletionEntrySymbol2(fileName, position, name, source, preferences = emptyOptions) { + synchronizeHostData(); + return ts_Completions_exports.getCompletionEntrySymbol(program, log, getValidSourceFile(fileName), position, { name, source }, host, preferences); } - } - function isNotEqualsOperator(node) { - return node.operatorToken.kind !== 64 /* EqualsToken */; - } - function getParentBinaryExpression(expr) { - const container = findAncestor(expr.parent, (n) => { - switch (n.kind) { - case 210 /* PropertyAccessExpression */: - case 211 /* ElementAccessExpression */: - return false; - case 227 /* TemplateExpression */: - case 225 /* BinaryExpression */: - return !(isBinaryExpression(n.parent) && isNotEqualsOperator(n.parent)); - default: - return "quit"; + function getQuickInfoAtPosition(fileName, position) { + synchronizeHostData(); + const sourceFile = getValidSourceFile(fileName); + const node = getTouchingPropertyName(sourceFile, position); + if (node === sourceFile) { + return void 0; } - }); - return container || expr; - } - function treeToArray(current) { - const loop = (current2) => { - if (!isBinaryExpression(current2)) { - return { - nodes: [current2], - operators: [], - validOperators: true, - hasString: isStringLiteral(current2) || isNoSubstitutionTemplateLiteral(current2) + const typeChecker = program.getTypeChecker(); + const nodeForQuickInfo = getNodeForQuickInfo(node); + const symbol = getSymbolAtLocationForQuickInfo(nodeForQuickInfo, typeChecker); + if (!symbol || typeChecker.isUnknownSymbol(symbol)) { + const type = shouldGetType(sourceFile, nodeForQuickInfo, position) ? typeChecker.getTypeAtLocation(nodeForQuickInfo) : void 0; + return type && { + kind: "" /* unknown */, + kindModifiers: "" /* none */, + textSpan: createTextSpanFromNode(nodeForQuickInfo, sourceFile), + displayParts: typeChecker.runWithCancellationToken(cancellationToken, (typeChecker2) => typeToDisplayParts(typeChecker2, type, getContainerNode(nodeForQuickInfo))), + documentation: type.symbol ? type.symbol.getDocumentationComment(typeChecker) : void 0, + tags: type.symbol ? type.symbol.getJsDocTags(typeChecker) : void 0 }; } - const { nodes: nodes2, operators: operators2, hasString: leftHasString, validOperators: leftOperatorValid } = loop(current2.left); - if (!(leftHasString || isStringLiteral(current2.right) || isTemplateExpression(current2.right))) { - return { nodes: [current2], operators: [], hasString: false, validOperators: true }; + const { symbolKind, displayParts, documentation, tags } = typeChecker.runWithCancellationToken(cancellationToken, (typeChecker2) => ts_SymbolDisplay_exports.getSymbolDisplayPartsDocumentationAndSymbolKind(typeChecker2, symbol, sourceFile, getContainerNode(nodeForQuickInfo), nodeForQuickInfo)); + return { + kind: symbolKind, + kindModifiers: ts_SymbolDisplay_exports.getSymbolModifiers(typeChecker, symbol), + textSpan: createTextSpanFromNode(nodeForQuickInfo, sourceFile), + displayParts, + documentation, + tags + }; + } + function getNodeForQuickInfo(node) { + if (isNewExpression(node.parent) && node.pos === node.parent.pos) { + return node.parent.expression; } - const currentOperatorValid = current2.operatorToken.kind === 40 /* PlusToken */; - const validOperators2 = leftOperatorValid && currentOperatorValid; - nodes2.push(current2.right); - operators2.push(current2.operatorToken); - return { nodes: nodes2, operators: operators2, hasString: true, validOperators: validOperators2 }; - }; - const { nodes, operators, validOperators, hasString } = loop(current); - return { nodes, operators, isValidConcatenation: validOperators && hasString }; - } - function escapeRawStringForTemplate(s) { - return s.replace(/\\.|[$`]/g, (m) => m[0] === "\\" ? m : "\\" + m); - } - function getRawTextOfTemplate(node) { - const rightShaving = isTemplateHead(node) || isTemplateMiddle(node) ? -2 : -1; - return getTextOfNode(node).slice(1, rightShaving); - } - function concatConsecutiveString(index, nodes) { - const indexes = []; - let text = "", rawText = ""; - while (index < nodes.length) { - const node = nodes[index]; - if (isStringLiteralLike(node)) { - text += node.text; - rawText += escapeRawStringForTemplate(getTextOfNode(node).slice(1, -1)); - indexes.push(index); - index++; - } else if (isTemplateExpression(node)) { - text += node.head.text; - rawText += getRawTextOfTemplate(node.head); - break; - } else { - break; + if (isNamedTupleMember(node.parent) && node.pos === node.parent.pos) { + return node.parent; + } + if (isImportMeta(node.parent) && node.parent.name === node) { + return node.parent; + } + if (isJsxNamespacedName(node.parent)) { + return node.parent; } + return node; } - return [index, text, rawText, indexes]; - } - function nodesToTemplate({ nodes, operators }, file) { - const copyOperatorComments = copyTrailingOperatorComments(operators, file); - const copyCommentFromStringLiterals = copyCommentFromMultiNode(nodes, file, copyOperatorComments); - const [begin, headText, rawHeadText, headIndexes] = concatConsecutiveString(0, nodes); - if (begin === nodes.length) { - const noSubstitutionTemplateLiteral = factory.createNoSubstitutionTemplateLiteral(headText, rawHeadText); - copyCommentFromStringLiterals(headIndexes, noSubstitutionTemplateLiteral); - return noSubstitutionTemplateLiteral; + function shouldGetType(sourceFile, node, position) { + switch (node.kind) { + case 80 /* Identifier */: + return !isLabelName(node) && !isTagName(node) && !isConstTypeReference(node.parent); + case 211 /* PropertyAccessExpression */: + case 166 /* QualifiedName */: + return !isInComment(sourceFile, position); + case 110 /* ThisKeyword */: + case 197 /* ThisType */: + case 108 /* SuperKeyword */: + case 202 /* NamedTupleMember */: + return true; + case 236 /* MetaProperty */: + return isImportMeta(node); + default: + return false; + } } - const templateSpans = []; - const templateHead = factory.createTemplateHead(headText, rawHeadText); - copyCommentFromStringLiterals(headIndexes, templateHead); - for (let i = begin; i < nodes.length; i++) { - const currentNode = getExpressionFromParenthesesOrExpression(nodes[i]); - copyOperatorComments(i, currentNode); - const [newIndex, subsequentText, rawSubsequentText, stringIndexes] = concatConsecutiveString(i + 1, nodes); - i = newIndex - 1; - const isLast = i === nodes.length - 1; - if (isTemplateExpression(currentNode)) { - const spans = map(currentNode.templateSpans, (span, index) => { - copyExpressionComments(span); - const isLastSpan = index === currentNode.templateSpans.length - 1; - const text = span.literal.text + (isLastSpan ? subsequentText : ""); - const rawText = getRawTextOfTemplate(span.literal) + (isLastSpan ? rawSubsequentText : ""); - return factory.createTemplateSpan(span.expression, isLast && isLastSpan ? factory.createTemplateTail(text, rawText) : factory.createTemplateMiddle(text, rawText)); + function getDefinitionAtPosition2(fileName, position, searchOtherFilesOnly, stopAtAlias) { + synchronizeHostData(); + return ts_GoToDefinition_exports.getDefinitionAtPosition(program, getValidSourceFile(fileName), position, searchOtherFilesOnly, stopAtAlias); + } + function getDefinitionAndBoundSpan2(fileName, position) { + synchronizeHostData(); + return ts_GoToDefinition_exports.getDefinitionAndBoundSpan(program, getValidSourceFile(fileName), position); + } + function getTypeDefinitionAtPosition2(fileName, position) { + synchronizeHostData(); + return ts_GoToDefinition_exports.getTypeDefinitionAtPosition(program.getTypeChecker(), getValidSourceFile(fileName), position); + } + function getImplementationAtPosition(fileName, position) { + synchronizeHostData(); + return ts_FindAllReferences_exports.getImplementationsAtPosition(program, cancellationToken, program.getSourceFiles(), getValidSourceFile(fileName), position); + } + function getDocumentHighlights(fileName, position, filesToSearch) { + const normalizedFileName = normalizePath(fileName); + Debug.assert(filesToSearch.some((f) => normalizePath(f) === normalizedFileName)); + synchronizeHostData(); + const sourceFilesToSearch = mapDefined(filesToSearch, (fileName2) => program.getSourceFile(fileName2)); + const sourceFile = getValidSourceFile(fileName); + return DocumentHighlights.getDocumentHighlights(program, cancellationToken, sourceFile, position, sourceFilesToSearch); + } + function findRenameLocations(fileName, position, findInStrings, findInComments, preferences) { + synchronizeHostData(); + const sourceFile = getValidSourceFile(fileName); + const node = getAdjustedRenameLocation(getTouchingPropertyName(sourceFile, position)); + if (!ts_Rename_exports.nodeIsEligibleForRename(node)) + return void 0; + if (isIdentifier(node) && (isJsxOpeningElement(node.parent) || isJsxClosingElement(node.parent)) && isIntrinsicJsxName(node.escapedText)) { + const { openingElement, closingElement } = node.parent.parent; + return [openingElement, closingElement].map((node2) => { + const textSpan = createTextSpanFromNode(node2.tagName, sourceFile); + return { + fileName: sourceFile.fileName, + textSpan, + ...ts_FindAllReferences_exports.toContextSpan(textSpan, sourceFile, node2.parent) + }; }); - templateSpans.push(...spans); } else { - const templatePart = isLast ? factory.createTemplateTail(subsequentText, rawSubsequentText) : factory.createTemplateMiddle(subsequentText, rawSubsequentText); - copyCommentFromStringLiterals(stringIndexes, templatePart); - templateSpans.push(factory.createTemplateSpan(currentNode, templatePart)); + const quotePreference = getQuotePreference(sourceFile, preferences ?? emptyOptions); + const providePrefixAndSuffixTextForRename = typeof preferences === "boolean" ? preferences : preferences == null ? void 0 : preferences.providePrefixAndSuffixTextForRename; + return getReferencesWorker2(node, position, { findInStrings, findInComments, providePrefixAndSuffixTextForRename, use: ts_FindAllReferences_exports.FindReferencesUse.Rename }, (entry, originalNode, checker) => ts_FindAllReferences_exports.toRenameLocation(entry, originalNode, checker, providePrefixAndSuffixTextForRename || false, quotePreference)); } } - return factory.createTemplateExpression(templateHead, templateSpans); - } - function copyExpressionComments(node) { - const file = node.getSourceFile(); - copyTrailingComments( - node, - node.expression, - file, - 3 /* MultiLineCommentTrivia */, - /*hasTrailingNewLine*/ - false - ); - copyTrailingAsLeadingComments( - node.expression, - node.expression, - file, - 3 /* MultiLineCommentTrivia */, - /*hasTrailingNewLine*/ - false - ); - } - function getExpressionFromParenthesesOrExpression(node) { - if (isParenthesizedExpression(node)) { - copyExpressionComments(node); - node = node.expression; + function getReferencesAtPosition(fileName, position) { + synchronizeHostData(); + return getReferencesWorker2(getTouchingPropertyName(getValidSourceFile(fileName), position), position, { use: ts_FindAllReferences_exports.FindReferencesUse.References }, ts_FindAllReferences_exports.toReferenceEntry); } - return node; - } - var refactorName9, refactorDescription5, convertStringAction, copyTrailingOperatorComments, copyCommentFromMultiNode; - var init_convertStringOrTemplateLiteral = __esm({ - "src/services/refactors/convertStringOrTemplateLiteral.ts"() { - "use strict"; - init_ts4(); - init_ts_refactor(); - refactorName9 = "Convert to template string"; - refactorDescription5 = getLocaleSpecificMessage(Diagnostics.Convert_to_template_string); - convertStringAction = { - name: refactorName9, - description: refactorDescription5, - kind: "refactor.rewrite.string" - }; - registerRefactor(refactorName9, { - kinds: [convertStringAction.kind], - getEditsForAction: getRefactorEditsToConvertToTemplateString, - getAvailableActions: getRefactorActionsToConvertToTemplateString - }); - copyTrailingOperatorComments = (operators, file) => (index, targetNode) => { - if (index < operators.length) { - copyTrailingComments( - operators[index], - targetNode, - file, - 3 /* MultiLineCommentTrivia */, - /*hasTrailingNewLine*/ - false - ); - } - }; - copyCommentFromMultiNode = (nodes, file, copyOperatorComments) => (indexes, targetNode) => { - while (indexes.length > 0) { - const index = indexes.shift(); - copyTrailingComments( - nodes[index], - targetNode, - file, - 3 /* MultiLineCommentTrivia */, - /*hasTrailingNewLine*/ - false - ); - copyOperatorComments(index, targetNode); + function getReferencesWorker2(node, position, options, cb) { + synchronizeHostData(); + const sourceFiles = options && options.use === ts_FindAllReferences_exports.FindReferencesUse.Rename ? program.getSourceFiles().filter((sourceFile) => !program.isSourceFileDefaultLibrary(sourceFile)) : program.getSourceFiles(); + return ts_FindAllReferences_exports.findReferenceOrRenameEntries(program, cancellationToken, sourceFiles, node, position, options, cb); + } + function findReferences(fileName, position) { + synchronizeHostData(); + return ts_FindAllReferences_exports.findReferencedSymbols(program, cancellationToken, program.getSourceFiles(), getValidSourceFile(fileName), position); + } + function getFileReferences(fileName) { + synchronizeHostData(); + return ts_FindAllReferences_exports.Core.getReferencesForFileName(fileName, program, program.getSourceFiles()).map(ts_FindAllReferences_exports.toReferenceEntry); + } + function getNavigateToItems2(searchValue, maxResultCount, fileName, excludeDtsFiles = false, excludeLibFiles = false) { + synchronizeHostData(); + const sourceFiles = fileName ? [getValidSourceFile(fileName)] : program.getSourceFiles(); + return getNavigateToItems(sourceFiles, program.getTypeChecker(), cancellationToken, searchValue, maxResultCount, excludeDtsFiles, excludeLibFiles); + } + function getEmitOutput(fileName, emitOnlyDtsFiles, forceDtsEmit) { + synchronizeHostData(); + const sourceFile = getValidSourceFile(fileName); + const customTransformers = host.getCustomTransformers && host.getCustomTransformers(); + return getFileEmitOutput(program, sourceFile, !!emitOnlyDtsFiles, cancellationToken, customTransformers, forceDtsEmit); + } + function getSignatureHelpItems2(fileName, position, { triggerReason } = emptyOptions) { + synchronizeHostData(); + const sourceFile = getValidSourceFile(fileName); + return ts_SignatureHelp_exports.getSignatureHelpItems(program, sourceFile, position, triggerReason, cancellationToken); + } + function getNonBoundSourceFile(fileName) { + return syntaxTreeCache.getCurrentSourceFile(fileName); + } + function getNameOrDottedNameSpan(fileName, startPos, _endPos) { + const sourceFile = syntaxTreeCache.getCurrentSourceFile(fileName); + const node = getTouchingPropertyName(sourceFile, startPos); + if (node === sourceFile) { + return void 0; + } + switch (node.kind) { + case 211 /* PropertyAccessExpression */: + case 166 /* QualifiedName */: + case 11 /* StringLiteral */: + case 97 /* FalseKeyword */: + case 112 /* TrueKeyword */: + case 106 /* NullKeyword */: + case 108 /* SuperKeyword */: + case 110 /* ThisKeyword */: + case 197 /* ThisType */: + case 80 /* Identifier */: + break; + default: + return void 0; + } + let nodeForStartPos = node; + while (true) { + if (isRightSideOfPropertyAccess(nodeForStartPos) || isRightSideOfQualifiedName(nodeForStartPos)) { + nodeForStartPos = nodeForStartPos.parent; + } else if (isNameOfModuleDeclaration(nodeForStartPos)) { + if (nodeForStartPos.parent.parent.kind === 267 /* ModuleDeclaration */ && nodeForStartPos.parent.parent.body === nodeForStartPos.parent) { + nodeForStartPos = nodeForStartPos.parent.parent.name; + } else { + break; + } + } else { + break; } - }; - } - }); - - // src/services/_namespaces/ts.refactor.convertStringOrTemplateLiteral.ts - var ts_refactor_convertStringOrTemplateLiteral_exports = {}; - var init_ts_refactor_convertStringOrTemplateLiteral = __esm({ - "src/services/_namespaces/ts.refactor.convertStringOrTemplateLiteral.ts"() { - "use strict"; - init_convertStringOrTemplateLiteral(); - } - }); - - // src/services/refactors/convertToOptionalChainExpression.ts - function getRefactorActionsToConvertToOptionalChain(context) { - const info = getInfo3(context, context.triggerReason === "invoked"); - if (!info) - return emptyArray; - if (!isRefactorErrorInfo(info)) { - return [{ - name: refactorName10, - description: convertToOptionalChainExpressionMessage, - actions: [toOptionalChainAction] - }]; + } + return createTextSpanFromBounds(nodeForStartPos.getStart(), node.getEnd()); } - if (context.preferences.provideRefactorNotApplicableReason) { - return [{ - name: refactorName10, - description: convertToOptionalChainExpressionMessage, - actions: [{ ...toOptionalChainAction, notApplicableReason: info.error }] - }]; + function getBreakpointStatementAtPosition(fileName, position) { + const sourceFile = syntaxTreeCache.getCurrentSourceFile(fileName); + return ts_BreakpointResolver_exports.spanInSourceFileAtLocation(sourceFile, position); } - return emptyArray; - } - function getRefactorEditsToConvertToOptionalChain(context, actionName2) { - const info = getInfo3(context); - Debug.assert(info && !isRefactorErrorInfo(info), "Expected applicable refactor info"); - const edits = ts_textChanges_exports.ChangeTracker.with( - context, - (t) => doChange6(context.file, context.program.getTypeChecker(), t, info, actionName2) - ); - return { edits, renameFilename: void 0, renameLocation: void 0 }; - } - function isValidExpression(node) { - return isBinaryExpression(node) || isConditionalExpression(node); - } - function isValidStatement(node) { - return isExpressionStatement(node) || isReturnStatement(node) || isVariableStatement(node); - } - function isValidExpressionOrStatement(node) { - return isValidExpression(node) || isValidStatement(node); - } - function getInfo3(context, considerEmptySpans = true) { - const { file, program } = context; - const span = getRefactorContextSpan(context); - const forEmptySpan = span.length === 0; - if (forEmptySpan && !considerEmptySpans) - return void 0; - const startToken = getTokenAtPosition(file, span.start); - const endToken = findTokenOnLeftOfPosition(file, span.start + span.length); - const adjustedSpan = createTextSpanFromBounds(startToken.pos, endToken && endToken.end >= startToken.pos ? endToken.getEnd() : startToken.getEnd()); - const parent2 = forEmptySpan ? getValidParentNodeOfEmptySpan(startToken) : getValidParentNodeContainingSpan(startToken, adjustedSpan); - const expression = parent2 && isValidExpressionOrStatement(parent2) ? getExpression(parent2) : void 0; - if (!expression) - return { error: getLocaleSpecificMessage(Diagnostics.Could_not_find_convertible_access_expression) }; - const checker = program.getTypeChecker(); - return isConditionalExpression(expression) ? getConditionalInfo(expression, checker) : getBinaryInfo(expression); - } - function getConditionalInfo(expression, checker) { - const condition = expression.condition; - const finalExpression = getFinalExpressionInChain(expression.whenTrue); - if (!finalExpression || checker.isNullableType(checker.getTypeAtLocation(finalExpression))) { - return { error: getLocaleSpecificMessage(Diagnostics.Could_not_find_convertible_access_expression) }; + function getNavigationBarItems2(fileName) { + return getNavigationBarItems(syntaxTreeCache.getCurrentSourceFile(fileName), cancellationToken); } - if ((isPropertyAccessExpression(condition) || isIdentifier(condition)) && getMatchingStart(condition, finalExpression.expression)) { - return { finalExpression, occurrences: [condition], expression }; - } else if (isBinaryExpression(condition)) { - const occurrences = getOccurrencesInExpression(finalExpression.expression, condition); - return occurrences ? { finalExpression, occurrences, expression } : { error: getLocaleSpecificMessage(Diagnostics.Could_not_find_matching_access_expressions) }; + function getNavigationTree2(fileName) { + return getNavigationTree(syntaxTreeCache.getCurrentSourceFile(fileName), cancellationToken); } - } - function getBinaryInfo(expression) { - if (expression.operatorToken.kind !== 56 /* AmpersandAmpersandToken */) { - return { error: getLocaleSpecificMessage(Diagnostics.Can_only_convert_logical_AND_access_chains) }; + function getSemanticClassifications3(fileName, span, format) { + synchronizeHostData(); + const responseFormat = format || "original" /* Original */; + if (responseFormat === "2020" /* TwentyTwenty */) { + return getSemanticClassifications2(program, cancellationToken, getValidSourceFile(fileName), span); + } else { + return getSemanticClassifications(program.getTypeChecker(), cancellationToken, getValidSourceFile(fileName), program.getClassifiableNames(), span); + } } - const finalExpression = getFinalExpressionInChain(expression.right); - if (!finalExpression) - return { error: getLocaleSpecificMessage(Diagnostics.Could_not_find_convertible_access_expression) }; - const occurrences = getOccurrencesInExpression(finalExpression.expression, expression.left); - return occurrences ? { finalExpression, occurrences, expression } : { error: getLocaleSpecificMessage(Diagnostics.Could_not_find_matching_access_expressions) }; - } - function getOccurrencesInExpression(matchTo, expression) { - const occurrences = []; - while (isBinaryExpression(expression) && expression.operatorToken.kind === 56 /* AmpersandAmpersandToken */) { - const match = getMatchingStart(skipParentheses(matchTo), skipParentheses(expression.right)); - if (!match) { - break; + function getEncodedSemanticClassifications3(fileName, span, format) { + synchronizeHostData(); + const responseFormat = format || "original" /* Original */; + if (responseFormat === "original" /* Original */) { + return getEncodedSemanticClassifications(program.getTypeChecker(), cancellationToken, getValidSourceFile(fileName), program.getClassifiableNames(), span); + } else { + return getEncodedSemanticClassifications2(program, cancellationToken, getValidSourceFile(fileName), span); } - occurrences.push(match); - matchTo = match; - expression = expression.left; } - const finalMatch = getMatchingStart(matchTo, expression); - if (finalMatch) { - occurrences.push(finalMatch); + function getSyntacticClassifications2(fileName, span) { + return getSyntacticClassifications(cancellationToken, syntaxTreeCache.getCurrentSourceFile(fileName), span); } - return occurrences.length > 0 ? occurrences : void 0; - } - function getMatchingStart(chain, subchain) { - if (!isIdentifier(subchain) && !isPropertyAccessExpression(subchain) && !isElementAccessExpression(subchain)) { - return void 0; + function getEncodedSyntacticClassifications2(fileName, span) { + return getEncodedSyntacticClassifications(cancellationToken, syntaxTreeCache.getCurrentSourceFile(fileName), span); } - return chainStartsWith(chain, subchain) ? subchain : void 0; - } - function chainStartsWith(chain, subchain) { - while (isCallExpression(chain) || isPropertyAccessExpression(chain) || isElementAccessExpression(chain)) { - if (getTextOfChainNode(chain) === getTextOfChainNode(subchain)) - break; - chain = chain.expression; + function getOutliningSpans(fileName) { + const sourceFile = syntaxTreeCache.getCurrentSourceFile(fileName); + return ts_OutliningElementsCollector_exports.collectElements(sourceFile, cancellationToken); } - while (isPropertyAccessExpression(chain) && isPropertyAccessExpression(subchain) || isElementAccessExpression(chain) && isElementAccessExpression(subchain)) { - if (getTextOfChainNode(chain) !== getTextOfChainNode(subchain)) - return false; - chain = chain.expression; - subchain = subchain.expression; + const braceMatching = new Map(Object.entries({ + [19 /* OpenBraceToken */]: 20 /* CloseBraceToken */, + [21 /* OpenParenToken */]: 22 /* CloseParenToken */, + [23 /* OpenBracketToken */]: 24 /* CloseBracketToken */, + [32 /* GreaterThanToken */]: 30 /* LessThanToken */ + })); + braceMatching.forEach((value, key) => braceMatching.set(value.toString(), Number(key))); + function getBraceMatchingAtPosition(fileName, position) { + const sourceFile = syntaxTreeCache.getCurrentSourceFile(fileName); + const token = getTouchingToken(sourceFile, position); + const matchKind = token.getStart(sourceFile) === position ? braceMatching.get(token.kind.toString()) : void 0; + const match = matchKind && findChildOfKind(token.parent, matchKind, sourceFile); + return match ? [createTextSpanFromNode(token, sourceFile), createTextSpanFromNode(match, sourceFile)].sort((a, b) => a.start - b.start) : emptyArray; } - return isIdentifier(chain) && isIdentifier(subchain) && chain.getText() === subchain.getText(); - } - function getTextOfChainNode(node) { - if (isIdentifier(node) || isStringOrNumericLiteralLike(node)) { - return node.getText(); + function getIndentationAtPosition(fileName, position, editorOptions) { + let start = timestamp(); + const settings = toEditorSettings(editorOptions); + const sourceFile = syntaxTreeCache.getCurrentSourceFile(fileName); + log("getIndentationAtPosition: getCurrentSourceFile: " + (timestamp() - start)); + start = timestamp(); + const result = ts_formatting_exports.SmartIndenter.getIndentation(position, sourceFile, settings); + log("getIndentationAtPosition: computeIndentation : " + (timestamp() - start)); + return result; } - if (isPropertyAccessExpression(node)) { - return getTextOfChainNode(node.name); + function getFormattingEditsForRange(fileName, start, end, options) { + const sourceFile = syntaxTreeCache.getCurrentSourceFile(fileName); + return ts_formatting_exports.formatSelection(start, end, sourceFile, ts_formatting_exports.getFormatContext(toEditorSettings(options), host)); } - if (isElementAccessExpression(node)) { - return getTextOfChainNode(node.argumentExpression); + function getFormattingEditsForDocument(fileName, options) { + return ts_formatting_exports.formatDocument(syntaxTreeCache.getCurrentSourceFile(fileName), ts_formatting_exports.getFormatContext(toEditorSettings(options), host)); } - return void 0; - } - function getValidParentNodeContainingSpan(node, span) { - while (node.parent) { - if (isValidExpressionOrStatement(node) && span.length !== 0 && node.end >= span.start + span.length) { - return node; + function getFormattingEditsAfterKeystroke(fileName, position, key, options) { + const sourceFile = syntaxTreeCache.getCurrentSourceFile(fileName); + const formatContext = ts_formatting_exports.getFormatContext(toEditorSettings(options), host); + if (!isInComment(sourceFile, position)) { + switch (key) { + case "{": + return ts_formatting_exports.formatOnOpeningCurly(position, sourceFile, formatContext); + case "}": + return ts_formatting_exports.formatOnClosingCurly(position, sourceFile, formatContext); + case ";": + return ts_formatting_exports.formatOnSemicolon(position, sourceFile, formatContext); + case "\n": + return ts_formatting_exports.formatOnEnter(position, sourceFile, formatContext); + } } - node = node.parent; + return []; } - return void 0; - } - function getValidParentNodeOfEmptySpan(node) { - while (node.parent) { - if (isValidExpressionOrStatement(node) && !isValidExpressionOrStatement(node.parent)) { - return node; - } - node = node.parent; + function getCodeFixesAtPosition(fileName, start, end, errorCodes64, formatOptions, preferences = emptyOptions) { + synchronizeHostData(); + const sourceFile = getValidSourceFile(fileName); + const span = createTextSpanFromBounds(start, end); + const formatContext = ts_formatting_exports.getFormatContext(formatOptions, host); + return flatMap(deduplicate(errorCodes64, equateValues, compareValues), (errorCode) => { + cancellationToken.throwIfCancellationRequested(); + return ts_codefix_exports.getFixes({ errorCode, sourceFile, span, program, host, cancellationToken, formatContext, preferences }); + }); } - return void 0; - } - function getExpression(node) { - if (isValidExpression(node)) { - return node; + function getCombinedCodeFix(scope, fixId52, formatOptions, preferences = emptyOptions) { + synchronizeHostData(); + Debug.assert(scope.type === "file"); + const sourceFile = getValidSourceFile(scope.fileName); + const formatContext = ts_formatting_exports.getFormatContext(formatOptions, host); + return ts_codefix_exports.getAllFixes({ fixId: fixId52, sourceFile, program, host, cancellationToken, formatContext, preferences }); } - if (isVariableStatement(node)) { - const variable = getSingleVariableOfVariableStatement(node); - const initializer = variable == null ? void 0 : variable.initializer; - return initializer && isValidExpression(initializer) ? initializer : void 0; + function organizeImports2(args, formatOptions, preferences = emptyOptions) { + synchronizeHostData(); + Debug.assert(args.type === "file"); + const sourceFile = getValidSourceFile(args.fileName); + const formatContext = ts_formatting_exports.getFormatContext(formatOptions, host); + const mode = args.mode ?? (args.skipDestructiveCodeActions ? "SortAndCombine" /* SortAndCombine */ : "All" /* All */); + return ts_OrganizeImports_exports.organizeImports(sourceFile, formatContext, host, program, preferences, mode); } - return node.expression && isValidExpression(node.expression) ? node.expression : void 0; - } - function getFinalExpressionInChain(node) { - node = skipParentheses(node); - if (isBinaryExpression(node)) { - return getFinalExpressionInChain(node.left); - } else if ((isPropertyAccessExpression(node) || isElementAccessExpression(node) || isCallExpression(node)) && !isOptionalChain(node)) { - return node; + function getEditsForFileRename2(oldFilePath, newFilePath, formatOptions, preferences = emptyOptions) { + return getEditsForFileRename(getProgram(), oldFilePath, newFilePath, host, ts_formatting_exports.getFormatContext(formatOptions, host), preferences, sourceMapper); } - return void 0; - } - function convertOccurrences(checker, toConvert, occurrences) { - if (isPropertyAccessExpression(toConvert) || isElementAccessExpression(toConvert) || isCallExpression(toConvert)) { - const chain = convertOccurrences(checker, toConvert.expression, occurrences); - const lastOccurrence = occurrences.length > 0 ? occurrences[occurrences.length - 1] : void 0; - const isOccurrence = (lastOccurrence == null ? void 0 : lastOccurrence.getText()) === toConvert.expression.getText(); - if (isOccurrence) - occurrences.pop(); - if (isCallExpression(toConvert)) { - return isOccurrence ? factory.createCallChain(chain, factory.createToken(29 /* QuestionDotToken */), toConvert.typeArguments, toConvert.arguments) : factory.createCallChain(chain, toConvert.questionDotToken, toConvert.typeArguments, toConvert.arguments); - } else if (isPropertyAccessExpression(toConvert)) { - return isOccurrence ? factory.createPropertyAccessChain(chain, factory.createToken(29 /* QuestionDotToken */), toConvert.name) : factory.createPropertyAccessChain(chain, toConvert.questionDotToken, toConvert.name); - } else if (isElementAccessExpression(toConvert)) { - return isOccurrence ? factory.createElementAccessChain(chain, factory.createToken(29 /* QuestionDotToken */), toConvert.argumentExpression) : factory.createElementAccessChain(chain, toConvert.questionDotToken, toConvert.argumentExpression); - } + function applyCodeActionCommand(fileName, actionOrFormatSettingsOrUndefined) { + const action = typeof fileName === "string" ? actionOrFormatSettingsOrUndefined : fileName; + return isArray(action) ? Promise.all(action.map((a) => applySingleCodeActionCommand(a))) : applySingleCodeActionCommand(action); } - return toConvert; - } - function doChange6(sourceFile, checker, changes, info, _actionName) { - const { finalExpression, occurrences, expression } = info; - const firstOccurrence = occurrences[occurrences.length - 1]; - const convertedChain = convertOccurrences(checker, finalExpression, occurrences); - if (convertedChain && (isPropertyAccessExpression(convertedChain) || isElementAccessExpression(convertedChain) || isCallExpression(convertedChain))) { - if (isBinaryExpression(expression)) { - changes.replaceNodeRange(sourceFile, firstOccurrence, finalExpression, convertedChain); - } else if (isConditionalExpression(expression)) { - changes.replaceNode( - sourceFile, - expression, - factory.createBinaryExpression(convertedChain, factory.createToken(61 /* QuestionQuestionToken */), expression.whenFalse) - ); - } + function applySingleCodeActionCommand(action) { + const getPath = (path) => toPath(path, currentDirectory, getCanonicalFileName); + Debug.assertEqual(action.type, "install package"); + return host.installPackage ? host.installPackage({ fileName: getPath(action.file), packageName: action.packageName }) : Promise.reject("Host does not implement `installPackage`"); } - } - var refactorName10, convertToOptionalChainExpressionMessage, toOptionalChainAction; - var init_convertToOptionalChainExpression = __esm({ - "src/services/refactors/convertToOptionalChainExpression.ts"() { - "use strict"; - init_ts4(); - init_ts_refactor(); - refactorName10 = "Convert to optional chain expression"; - convertToOptionalChainExpressionMessage = getLocaleSpecificMessage(Diagnostics.Convert_to_optional_chain_expression); - toOptionalChainAction = { - name: refactorName10, - description: convertToOptionalChainExpressionMessage, - kind: "refactor.rewrite.expression.optionalChain" - }; - registerRefactor(refactorName10, { - kinds: [toOptionalChainAction.kind], - getEditsForAction: getRefactorEditsToConvertToOptionalChain, - getAvailableActions: getRefactorActionsToConvertToOptionalChain - }); + function getDocCommentTemplateAtPosition2(fileName, position, options, formatOptions) { + const formatSettings = formatOptions ? ts_formatting_exports.getFormatContext(formatOptions, host).options : void 0; + return ts_JsDoc_exports.getDocCommentTemplateAtPosition(getNewLineOrDefaultFromHost(host, formatSettings), syntaxTreeCache.getCurrentSourceFile(fileName), position, options); } - }); - - // src/services/_namespaces/ts.refactor.convertToOptionalChainExpression.ts - var ts_refactor_convertToOptionalChainExpression_exports = {}; - var init_ts_refactor_convertToOptionalChainExpression = __esm({ - "src/services/_namespaces/ts.refactor.convertToOptionalChainExpression.ts"() { - "use strict"; - init_convertToOptionalChainExpression(); + function isValidBraceCompletionAtPosition(fileName, position, openingBrace) { + if (openingBrace === 60 /* lessThan */) { + return false; + } + const sourceFile = syntaxTreeCache.getCurrentSourceFile(fileName); + if (isInString(sourceFile, position)) { + return false; + } + if (isInsideJsxElementOrAttribute(sourceFile, position)) { + return openingBrace === 123 /* openBrace */; + } + if (isInTemplateString(sourceFile, position)) { + return false; + } + switch (openingBrace) { + case 39 /* singleQuote */: + case 34 /* doubleQuote */: + case 96 /* backtick */: + return !isInComment(sourceFile, position); + } + return true; } - }); - - // src/services/refactors/extractSymbol.ts - function getRefactorActionsToExtractSymbol(context) { - const requestedRefactor = context.kind; - const rangeToExtract = getRangeToExtract2(context.file, getRefactorContextSpan(context), context.triggerReason === "invoked"); - const targetRange = rangeToExtract.targetRange; - if (targetRange === void 0) { - if (!rangeToExtract.errors || rangeToExtract.errors.length === 0 || !context.preferences.provideRefactorNotApplicableReason) { - return emptyArray; + function getJsxClosingTagAtPosition(fileName, position) { + const sourceFile = syntaxTreeCache.getCurrentSourceFile(fileName); + const token = findPrecedingToken(position, sourceFile); + if (!token) + return void 0; + const element = token.kind === 32 /* GreaterThanToken */ && isJsxOpeningElement(token.parent) ? token.parent.parent : isJsxText(token) && isJsxElement(token.parent) ? token.parent : void 0; + if (element && isUnclosedTag(element)) { + return { newText: `` }; } - const errors = []; - if (refactorKindBeginsWith(extractFunctionAction.kind, requestedRefactor)) { - errors.push({ - name: refactorName11, - description: extractFunctionAction.description, - actions: [{ ...extractFunctionAction, notApplicableReason: getStringError(rangeToExtract.errors) }] - }); + const fragment = token.kind === 32 /* GreaterThanToken */ && isJsxOpeningFragment(token.parent) ? token.parent.parent : isJsxText(token) && isJsxFragment(token.parent) ? token.parent : void 0; + if (fragment && isUnclosedFragment(fragment)) { + return { newText: "" }; } - if (refactorKindBeginsWith(extractConstantAction.kind, requestedRefactor)) { - errors.push({ - name: refactorName11, - description: extractConstantAction.description, - actions: [{ ...extractConstantAction, notApplicableReason: getStringError(rangeToExtract.errors) }] + } + function getLinkedEditingRangeAtPosition(fileName, position) { + const sourceFile = syntaxTreeCache.getCurrentSourceFile(fileName); + const token = findPrecedingToken(position, sourceFile); + if (!token || token.parent.kind === 312 /* SourceFile */) + return void 0; + const jsxTagWordPattern = "[a-zA-Z0-9:\\-\\._$]*"; + if (isJsxFragment(token.parent.parent)) { + const openFragment = token.parent.parent.openingFragment; + const closeFragment = token.parent.parent.closingFragment; + if (containsParseError(openFragment) || containsParseError(closeFragment)) + return void 0; + const openPos = openFragment.getStart(sourceFile) + 1; + const closePos = closeFragment.getStart(sourceFile) + 2; + if (position !== openPos && position !== closePos) + return void 0; + return { + ranges: [{ start: openPos, length: 0 }, { start: closePos, length: 0 }], + wordPattern: jsxTagWordPattern + }; + } else { + const tag = findAncestor(token.parent, (n) => { + if (isJsxOpeningElement(n) || isJsxClosingElement(n)) { + return true; + } + return false; }); + if (!tag) + return void 0; + Debug.assert(isJsxOpeningElement(tag) || isJsxClosingElement(tag), "tag should be opening or closing element"); + const openTag = tag.parent.openingElement; + const closeTag = tag.parent.closingElement; + const openTagStart = openTag.tagName.getStart(sourceFile); + const openTagEnd = openTag.tagName.end; + const closeTagStart = closeTag.tagName.getStart(sourceFile); + const closeTagEnd = closeTag.tagName.end; + if (!(openTagStart <= position && position <= openTagEnd || closeTagStart <= position && position <= closeTagEnd)) + return void 0; + const openingTagText = openTag.tagName.getText(sourceFile); + if (openingTagText !== closeTag.tagName.getText(sourceFile)) + return void 0; + return { + ranges: [{ start: openTagStart, length: openTagEnd - openTagStart }, { start: closeTagStart, length: closeTagEnd - closeTagStart }], + wordPattern: jsxTagWordPattern + }; } - return errors; } - const extractions = getPossibleExtractions(targetRange, context); - if (extractions === void 0) { - return emptyArray; + function getLinesForRange(sourceFile, textRange) { + return { + lineStarts: sourceFile.getLineStarts(), + firstLine: sourceFile.getLineAndCharacterOfPosition(textRange.pos).line, + lastLine: sourceFile.getLineAndCharacterOfPosition(textRange.end).line + }; } - const functionActions = []; - const usedFunctionNames = /* @__PURE__ */ new Map(); - let innermostErrorFunctionAction; - const constantActions = []; - const usedConstantNames = /* @__PURE__ */ new Map(); - let innermostErrorConstantAction; - let i = 0; - for (const { functionExtraction, constantExtraction } of extractions) { - if (refactorKindBeginsWith(extractFunctionAction.kind, requestedRefactor)) { - const description3 = functionExtraction.description; - if (functionExtraction.errors.length === 0) { - if (!usedFunctionNames.has(description3)) { - usedFunctionNames.set(description3, true); - functionActions.push({ - description: description3, - name: `function_scope_${i}`, - kind: extractFunctionAction.kind + function toggleLineComment(fileName, textRange, insertComment) { + const sourceFile = syntaxTreeCache.getCurrentSourceFile(fileName); + const textChanges2 = []; + const { lineStarts, firstLine, lastLine } = getLinesForRange(sourceFile, textRange); + let isCommenting = insertComment || false; + let leftMostPosition = Number.MAX_VALUE; + const lineTextStarts = /* @__PURE__ */ new Map(); + const firstNonWhitespaceCharacterRegex = new RegExp(/\S/); + const isJsx = isInsideJsxElement(sourceFile, lineStarts[firstLine]); + const openComment = isJsx ? "{/*" : "//"; + for (let i = firstLine; i <= lastLine; i++) { + const lineText = sourceFile.text.substring(lineStarts[i], sourceFile.getLineEndOfPosition(lineStarts[i])); + const regExec = firstNonWhitespaceCharacterRegex.exec(lineText); + if (regExec) { + leftMostPosition = Math.min(leftMostPosition, regExec.index); + lineTextStarts.set(i.toString(), regExec.index); + if (lineText.substr(regExec.index, openComment.length) !== openComment) { + isCommenting = insertComment === void 0 || insertComment; + } + } + } + for (let i = firstLine; i <= lastLine; i++) { + if (firstLine !== lastLine && lineStarts[i] === textRange.end) { + continue; + } + const lineTextStart = lineTextStarts.get(i.toString()); + if (lineTextStart !== void 0) { + if (isJsx) { + textChanges2.push(...toggleMultilineComment(fileName, { pos: lineStarts[i] + leftMostPosition, end: sourceFile.getLineEndOfPosition(lineStarts[i]) }, isCommenting, isJsx)); + } else if (isCommenting) { + textChanges2.push({ + newText: openComment, + span: { + length: 0, + start: lineStarts[i] + leftMostPosition + } + }); + } else if (sourceFile.text.substr(lineStarts[i] + lineTextStart, openComment.length) === openComment) { + textChanges2.push({ + newText: "", + span: { + length: openComment.length, + start: lineStarts[i] + lineTextStart + } }); } - } else if (!innermostErrorFunctionAction) { - innermostErrorFunctionAction = { - description: description3, - name: `function_scope_${i}`, - notApplicableReason: getStringError(functionExtraction.errors), - kind: extractFunctionAction.kind - }; } } - if (refactorKindBeginsWith(extractConstantAction.kind, requestedRefactor)) { - const description3 = constantExtraction.description; - if (constantExtraction.errors.length === 0) { - if (!usedConstantNames.has(description3)) { - usedConstantNames.set(description3, true); - constantActions.push({ - description: description3, - name: `constant_scope_${i}`, - kind: extractConstantAction.kind + return textChanges2; + } + function toggleMultilineComment(fileName, textRange, insertComment, isInsideJsx) { + var _a2; + const sourceFile = syntaxTreeCache.getCurrentSourceFile(fileName); + const textChanges2 = []; + const { text } = sourceFile; + let hasComment = false; + let isCommenting = insertComment || false; + const positions = []; + let { pos } = textRange; + const isJsx = isInsideJsx !== void 0 ? isInsideJsx : isInsideJsxElement(sourceFile, pos); + const openMultiline = isJsx ? "{/*" : "/*"; + const closeMultiline = isJsx ? "*/}" : "*/"; + const openMultilineRegex = isJsx ? "\\{\\/\\*" : "\\/\\*"; + const closeMultilineRegex = isJsx ? "\\*\\/\\}" : "\\*\\/"; + while (pos <= textRange.end) { + const offset = text.substr(pos, openMultiline.length) === openMultiline ? openMultiline.length : 0; + const commentRange = isInComment(sourceFile, pos + offset); + if (commentRange) { + if (isJsx) { + commentRange.pos--; + commentRange.end++; + } + positions.push(commentRange.pos); + if (commentRange.kind === 3 /* MultiLineCommentTrivia */) { + positions.push(commentRange.end); + } + hasComment = true; + pos = commentRange.end + 1; + } else { + const newPos = text.substring(pos, textRange.end).search(`(${openMultilineRegex})|(${closeMultilineRegex})`); + isCommenting = insertComment !== void 0 ? insertComment : isCommenting || !isTextWhiteSpaceLike(text, pos, newPos === -1 ? textRange.end : pos + newPos); + pos = newPos === -1 ? textRange.end + 1 : pos + newPos + closeMultiline.length; + } + } + if (isCommenting || !hasComment) { + if (((_a2 = isInComment(sourceFile, textRange.pos)) == null ? void 0 : _a2.kind) !== 2 /* SingleLineCommentTrivia */) { + insertSorted(positions, textRange.pos, compareValues); + } + insertSorted(positions, textRange.end, compareValues); + const firstPos = positions[0]; + if (text.substr(firstPos, openMultiline.length) !== openMultiline) { + textChanges2.push({ + newText: openMultiline, + span: { + length: 0, + start: firstPos + } + }); + } + for (let i = 1; i < positions.length - 1; i++) { + if (text.substr(positions[i] - closeMultiline.length, closeMultiline.length) !== closeMultiline) { + textChanges2.push({ + newText: closeMultiline, + span: { + length: 0, + start: positions[i] + } }); } - } else if (!innermostErrorConstantAction) { - innermostErrorConstantAction = { - description: description3, - name: `constant_scope_${i}`, - notApplicableReason: getStringError(constantExtraction.errors), - kind: extractConstantAction.kind - }; + if (text.substr(positions[i], openMultiline.length) !== openMultiline) { + textChanges2.push({ + newText: openMultiline, + span: { + length: 0, + start: positions[i] + } + }); + } + } + if (textChanges2.length % 2 !== 0) { + textChanges2.push({ + newText: closeMultiline, + span: { + length: 0, + start: positions[positions.length - 1] + } + }); + } + } else { + for (const pos2 of positions) { + const from = pos2 - closeMultiline.length > 0 ? pos2 - closeMultiline.length : 0; + const offset = text.substr(from, closeMultiline.length) === closeMultiline ? closeMultiline.length : 0; + textChanges2.push({ + newText: "", + span: { + length: openMultiline.length, + start: pos2 - offset + } + }); } } - i++; + return textChanges2; } - const infos = []; - if (functionActions.length) { - infos.push({ - name: refactorName11, - description: getLocaleSpecificMessage(Diagnostics.Extract_function), - actions: functionActions - }); - } else if (context.preferences.provideRefactorNotApplicableReason && innermostErrorFunctionAction) { - infos.push({ - name: refactorName11, - description: getLocaleSpecificMessage(Diagnostics.Extract_function), - actions: [innermostErrorFunctionAction] - }); + function commentSelection(fileName, textRange) { + const sourceFile = syntaxTreeCache.getCurrentSourceFile(fileName); + const { firstLine, lastLine } = getLinesForRange(sourceFile, textRange); + return firstLine === lastLine && textRange.pos !== textRange.end ? toggleMultilineComment( + fileName, + textRange, + /*insertComment*/ + true + ) : toggleLineComment( + fileName, + textRange, + /*insertComment*/ + true + ); } - if (constantActions.length) { - infos.push({ - name: refactorName11, - description: getLocaleSpecificMessage(Diagnostics.Extract_constant), - actions: constantActions - }); - } else if (context.preferences.provideRefactorNotApplicableReason && innermostErrorConstantAction) { - infos.push({ - name: refactorName11, - description: getLocaleSpecificMessage(Diagnostics.Extract_constant), - actions: [innermostErrorConstantAction] - }); + function uncommentSelection(fileName, textRange) { + const sourceFile = syntaxTreeCache.getCurrentSourceFile(fileName); + const textChanges2 = []; + const { pos } = textRange; + let { end } = textRange; + if (pos === end) { + end += isInsideJsxElement(sourceFile, pos) ? 2 : 1; + } + for (let i = pos; i <= end; i++) { + const commentRange = isInComment(sourceFile, i); + if (commentRange) { + switch (commentRange.kind) { + case 2 /* SingleLineCommentTrivia */: + textChanges2.push(...toggleLineComment( + fileName, + { end: commentRange.end, pos: commentRange.pos + 1 }, + /*insertComment*/ + false + )); + break; + case 3 /* MultiLineCommentTrivia */: + textChanges2.push(...toggleMultilineComment( + fileName, + { end: commentRange.end, pos: commentRange.pos + 1 }, + /*insertComment*/ + false + )); + } + i = commentRange.end + 1; + } + } + return textChanges2; } - return infos.length ? infos : emptyArray; - function getStringError(errors) { - let error = errors[0].messageText; - if (typeof error !== "string") { - error = error.messageText; + function isUnclosedTag({ openingElement, closingElement, parent: parent2 }) { + return !tagNamesAreEquivalent(openingElement.tagName, closingElement.tagName) || isJsxElement(parent2) && tagNamesAreEquivalent(openingElement.tagName, parent2.openingElement.tagName) && isUnclosedTag(parent2); + } + function isUnclosedFragment({ closingFragment, parent: parent2 }) { + return !!(closingFragment.flags & 262144 /* ThisNodeHasError */) || isJsxFragment(parent2) && isUnclosedFragment(parent2); + } + function getSpanOfEnclosingComment(fileName, position, onlyMultiLine) { + const sourceFile = syntaxTreeCache.getCurrentSourceFile(fileName); + const range = ts_formatting_exports.getRangeOfEnclosingComment(sourceFile, position); + return range && (!onlyMultiLine || range.kind === 3 /* MultiLineCommentTrivia */) ? createTextSpanFromRange(range) : void 0; + } + function getTodoComments(fileName, descriptors) { + synchronizeHostData(); + const sourceFile = getValidSourceFile(fileName); + cancellationToken.throwIfCancellationRequested(); + const fileContents = sourceFile.text; + const result = []; + if (descriptors.length > 0 && !isNodeModulesFile(sourceFile.fileName)) { + const regExp = getTodoCommentsRegExp(); + let matchArray; + while (matchArray = regExp.exec(fileContents)) { + cancellationToken.throwIfCancellationRequested(); + const firstDescriptorCaptureIndex = 3; + Debug.assert(matchArray.length === descriptors.length + firstDescriptorCaptureIndex); + const preamble = matchArray[1]; + const matchPosition = matchArray.index + preamble.length; + if (!isInComment(sourceFile, matchPosition)) { + continue; + } + let descriptor; + for (let i = 0; i < descriptors.length; i++) { + if (matchArray[i + firstDescriptorCaptureIndex]) { + descriptor = descriptors[i]; + } + } + if (descriptor === void 0) + return Debug.fail(); + if (isLetterOrDigit(fileContents.charCodeAt(matchPosition + descriptor.text.length))) { + continue; + } + const message = matchArray[2]; + result.push({ descriptor, message, position: matchPosition }); + } + } + return result; + function escapeRegExp(str) { + return str.replace(/[-[\]/{}()*+?.\\^$|]/g, "\\$&"); + } + function getTodoCommentsRegExp() { + const singleLineCommentStart = /(?:\/\/+\s*)/.source; + const multiLineCommentStart = /(?:\/\*+\s*)/.source; + const anyNumberOfSpacesAndAsterisksAtStartOfLine = /(?:^(?:\s|\*)*)/.source; + const preamble = "(" + anyNumberOfSpacesAndAsterisksAtStartOfLine + "|" + singleLineCommentStart + "|" + multiLineCommentStart + ")"; + const literals = "(?:" + map(descriptors, (d) => "(" + escapeRegExp(d.text) + ")").join("|") + ")"; + const endOfLineOrEndOfComment = /(?:$|\*\/)/.source; + const messageRemainder = /(?:.*?)/.source; + const messagePortion = "(" + literals + messageRemainder + ")"; + const regExpString = preamble + messagePortion + endOfLineOrEndOfComment; + return new RegExp(regExpString, "gim"); + } + function isLetterOrDigit(char) { + return char >= 97 /* a */ && char <= 122 /* z */ || char >= 65 /* A */ && char <= 90 /* Z */ || char >= 48 /* _0 */ && char <= 57 /* _9 */; + } + function isNodeModulesFile(path) { + return path.includes("/node_modules/"); } - return error; } - } - function getRefactorEditsToExtractSymbol(context, actionName2) { - const rangeToExtract = getRangeToExtract2(context.file, getRefactorContextSpan(context)); - const targetRange = rangeToExtract.targetRange; - const parsedFunctionIndexMatch = /^function_scope_(\d+)$/.exec(actionName2); - if (parsedFunctionIndexMatch) { - const index = +parsedFunctionIndexMatch[1]; - Debug.assert(isFinite(index), "Expected to parse a finite number from the function scope index"); - return getFunctionExtractionAtIndex(targetRange, context, index); + function getRenameInfo2(fileName, position, preferences) { + synchronizeHostData(); + return ts_Rename_exports.getRenameInfo(program, getValidSourceFile(fileName), position, preferences || {}); } - const parsedConstantIndexMatch = /^constant_scope_(\d+)$/.exec(actionName2); - if (parsedConstantIndexMatch) { - const index = +parsedConstantIndexMatch[1]; - Debug.assert(isFinite(index), "Expected to parse a finite number from the constant scope index"); - return getConstantExtractionAtIndex(targetRange, context, index); + function getRefactorContext(file, positionOrRange, preferences, formatOptions, triggerReason, kind) { + const [startPosition, endPosition] = typeof positionOrRange === "number" ? [positionOrRange, void 0] : [positionOrRange.pos, positionOrRange.end]; + return { + file, + startPosition, + endPosition, + program: getProgram(), + host, + formatContext: ts_formatting_exports.getFormatContext(formatOptions, host), + // TODO: GH#18217 + cancellationToken, + preferences, + triggerReason, + kind + }; } - Debug.fail("Unrecognized action name"); - } - function getRangeToExtract2(sourceFile, span, invoked = true) { - const { length: length2 } = span; - if (length2 === 0 && !invoked) { - return { errors: [createFileDiagnostic(sourceFile, span.start, length2, Messages.cannotExtractEmpty)] }; + function getInlayHintsContext(file, span, preferences) { + return { + file, + program: getProgram(), + host, + span, + preferences, + cancellationToken + }; } - const cursorRequest = length2 === 0 && invoked; - const startToken = findFirstNonJsxWhitespaceToken(sourceFile, span.start); - const endToken = findTokenOnLeftOfPosition(sourceFile, textSpanEnd(span)); - const adjustedSpan = startToken && endToken && invoked ? getAdjustedSpanFromNodes(startToken, endToken, sourceFile) : span; - const start = cursorRequest ? getExtractableParent(startToken) : getParentNodeInSpan(startToken, sourceFile, adjustedSpan); - const end = cursorRequest ? start : getParentNodeInSpan(endToken, sourceFile, adjustedSpan); - let rangeFacts = 0 /* None */; - let thisNode; - if (!start || !end) { - return { errors: [createFileDiagnostic(sourceFile, span.start, length2, Messages.cannotExtractRange)] }; + function getSmartSelectionRange2(fileName, position) { + return ts_SmartSelectionRange_exports.getSmartSelectionRange(position, syntaxTreeCache.getCurrentSourceFile(fileName)); } - if (start.flags & 8388608 /* JSDoc */) { - return { errors: [createFileDiagnostic(sourceFile, span.start, length2, Messages.cannotExtractJSDoc)] }; + function getApplicableRefactors2(fileName, positionOrRange, preferences = emptyOptions, triggerReason, kind, includeInteractiveActions) { + synchronizeHostData(); + const file = getValidSourceFile(fileName); + return ts_refactor_exports.getApplicableRefactors(getRefactorContext(file, positionOrRange, preferences, emptyOptions, triggerReason, kind), includeInteractiveActions); } - if (start.parent !== end.parent) { - return { errors: [createFileDiagnostic(sourceFile, span.start, length2, Messages.cannotExtractRange)] }; + function getMoveToRefactoringFileSuggestions(fileName, positionOrRange, preferences = emptyOptions) { + synchronizeHostData(); + const sourceFile = getValidSourceFile(fileName); + const allFiles = Debug.checkDefined(program.getSourceFiles()); + const extension = extensionFromPath(fileName); + const files = mapDefined(allFiles, (file) => !(program == null ? void 0 : program.isSourceFileFromExternalLibrary(sourceFile)) && !(sourceFile === getValidSourceFile(file.fileName) || extension === ".ts" /* Ts */ && extensionFromPath(file.fileName) === ".d.ts" /* Dts */ || extension === ".d.ts" /* Dts */ && startsWith(getBaseFileName(file.fileName), "lib.") && extensionFromPath(file.fileName) === ".d.ts" /* Dts */) && extension === extensionFromPath(file.fileName) ? file.fileName : void 0); + const newFileName = createNewFileName(sourceFile, program, getRefactorContext(sourceFile, positionOrRange, preferences, emptyOptions), host); + return { newFileName, files }; } - if (start !== end) { - if (!isBlockLike(start.parent)) { - return { errors: [createFileDiagnostic(sourceFile, span.start, length2, Messages.cannotExtractRange)] }; + function getEditsForRefactor2(fileName, formatOptions, positionOrRange, refactorName14, actionName2, preferences = emptyOptions, interactiveRefactorArguments) { + synchronizeHostData(); + const file = getValidSourceFile(fileName); + return ts_refactor_exports.getEditsForRefactor(getRefactorContext(file, positionOrRange, preferences, formatOptions), refactorName14, actionName2, interactiveRefactorArguments); + } + function toLineColumnOffset(fileName, position) { + if (position === 0) { + return { line: 0, character: 0 }; } - const statements = []; - for (const statement of start.parent.statements) { - if (statement === start || statements.length) { - const errors2 = checkNode(statement); - if (errors2) { - return { errors: errors2 }; + return sourceMapper.toLineColumnOffset(fileName, position); + } + function prepareCallHierarchy(fileName, position) { + synchronizeHostData(); + const declarations = ts_CallHierarchy_exports.resolveCallHierarchyDeclaration(program, getTouchingPropertyName(getValidSourceFile(fileName), position)); + return declarations && mapOneOrMany(declarations, (declaration) => ts_CallHierarchy_exports.createCallHierarchyItem(program, declaration)); + } + function provideCallHierarchyIncomingCalls(fileName, position) { + synchronizeHostData(); + const sourceFile = getValidSourceFile(fileName); + const declaration = firstOrOnly(ts_CallHierarchy_exports.resolveCallHierarchyDeclaration(program, position === 0 ? sourceFile : getTouchingPropertyName(sourceFile, position))); + return declaration ? ts_CallHierarchy_exports.getIncomingCalls(program, declaration, cancellationToken) : []; + } + function provideCallHierarchyOutgoingCalls(fileName, position) { + synchronizeHostData(); + const sourceFile = getValidSourceFile(fileName); + const declaration = firstOrOnly(ts_CallHierarchy_exports.resolveCallHierarchyDeclaration(program, position === 0 ? sourceFile : getTouchingPropertyName(sourceFile, position))); + return declaration ? ts_CallHierarchy_exports.getOutgoingCalls(program, declaration) : []; + } + function provideInlayHints2(fileName, span, preferences = emptyOptions) { + synchronizeHostData(); + const sourceFile = getValidSourceFile(fileName); + return ts_InlayHints_exports.provideInlayHints(getInlayHintsContext(sourceFile, span, preferences)); + } + const ls = { + dispose, + cleanupSemanticCache, + getSyntacticDiagnostics, + getSemanticDiagnostics, + getSuggestionDiagnostics, + getCompilerOptionsDiagnostics, + getSyntacticClassifications: getSyntacticClassifications2, + getSemanticClassifications: getSemanticClassifications3, + getEncodedSyntacticClassifications: getEncodedSyntacticClassifications2, + getEncodedSemanticClassifications: getEncodedSemanticClassifications3, + getCompletionsAtPosition: getCompletionsAtPosition2, + getCompletionEntryDetails: getCompletionEntryDetails2, + getCompletionEntrySymbol: getCompletionEntrySymbol2, + getSignatureHelpItems: getSignatureHelpItems2, + getQuickInfoAtPosition, + getDefinitionAtPosition: getDefinitionAtPosition2, + getDefinitionAndBoundSpan: getDefinitionAndBoundSpan2, + getImplementationAtPosition, + getTypeDefinitionAtPosition: getTypeDefinitionAtPosition2, + getReferencesAtPosition, + findReferences, + getFileReferences, + getDocumentHighlights, + getNameOrDottedNameSpan, + getBreakpointStatementAtPosition, + getNavigateToItems: getNavigateToItems2, + getRenameInfo: getRenameInfo2, + getSmartSelectionRange: getSmartSelectionRange2, + findRenameLocations, + getNavigationBarItems: getNavigationBarItems2, + getNavigationTree: getNavigationTree2, + getOutliningSpans, + getTodoComments, + getBraceMatchingAtPosition, + getIndentationAtPosition, + getFormattingEditsForRange, + getFormattingEditsForDocument, + getFormattingEditsAfterKeystroke, + getDocCommentTemplateAtPosition: getDocCommentTemplateAtPosition2, + isValidBraceCompletionAtPosition, + getJsxClosingTagAtPosition, + getLinkedEditingRangeAtPosition, + getSpanOfEnclosingComment, + getCodeFixesAtPosition, + getCombinedCodeFix, + applyCodeActionCommand, + organizeImports: organizeImports2, + getEditsForFileRename: getEditsForFileRename2, + getEmitOutput, + getNonBoundSourceFile, + getProgram, + getCurrentProgram: () => program, + getAutoImportProvider, + updateIsDefinitionOfReferencedSymbols, + getApplicableRefactors: getApplicableRefactors2, + getEditsForRefactor: getEditsForRefactor2, + getMoveToRefactoringFileSuggestions, + toLineColumnOffset, + getSourceMapper: () => sourceMapper, + clearSourceMapperCache: () => sourceMapper.clearCache(), + prepareCallHierarchy, + provideCallHierarchyIncomingCalls, + provideCallHierarchyOutgoingCalls, + toggleLineComment, + toggleMultilineComment, + commentSelection, + uncommentSelection, + provideInlayHints: provideInlayHints2, + getSupportedCodeFixes + }; + switch (languageServiceMode) { + case 0 /* Semantic */: + break; + case 1 /* PartialSemantic */: + invalidOperationsInPartialSemanticMode.forEach( + (key) => ls[key] = () => { + throw new Error(`LanguageService Operation: ${key} not allowed in LanguageServiceMode.PartialSemantic`); } - statements.push(statement); + ); + break; + case 2 /* Syntactic */: + invalidOperationsInSyntacticMode.forEach( + (key) => ls[key] = () => { + throw new Error(`LanguageService Operation: ${key} not allowed in LanguageServiceMode.Syntactic`); + } + ); + break; + default: + Debug.assertNever(languageServiceMode); + } + return ls; + } + function getNameTable(sourceFile) { + if (!sourceFile.nameTable) { + initializeNameTable(sourceFile); + } + return sourceFile.nameTable; + } + function initializeNameTable(sourceFile) { + const nameTable = sourceFile.nameTable = /* @__PURE__ */ new Map(); + sourceFile.forEachChild(function walk(node) { + if (isIdentifier(node) && !isTagName(node) && node.escapedText || isStringOrNumericLiteralLike(node) && literalIsName(node)) { + const text = getEscapedTextOfIdentifierOrLiteral(node); + nameTable.set(text, nameTable.get(text) === void 0 ? node.pos : -1); + } else if (isPrivateIdentifier(node)) { + const text = node.escapedText; + nameTable.set(text, nameTable.get(text) === void 0 ? node.pos : -1); + } + forEachChild(node, walk); + if (hasJSDocNodes(node)) { + for (const jsDoc of node.jsDoc) { + forEachChild(jsDoc, walk); + } + } + }); + } + function literalIsName(node) { + return isDeclarationName(node) || node.parent.kind === 283 /* ExternalModuleReference */ || isArgumentOfElementAccessExpression(node) || isLiteralComputedPropertyDeclarationName(node); + } + function getContainingObjectLiteralElement(node) { + const element = getContainingObjectLiteralElementWorker(node); + return element && (isObjectLiteralExpression(element.parent) || isJsxAttributes(element.parent)) ? element : void 0; + } + function getContainingObjectLiteralElementWorker(node) { + switch (node.kind) { + case 11 /* StringLiteral */: + case 15 /* NoSubstitutionTemplateLiteral */: + case 9 /* NumericLiteral */: + if (node.parent.kind === 167 /* ComputedPropertyName */) { + return isObjectLiteralElement(node.parent.parent) ? node.parent.parent : void 0; + } + case 80 /* Identifier */: + return isObjectLiteralElement(node.parent) && (node.parent.parent.kind === 210 /* ObjectLiteralExpression */ || node.parent.parent.kind === 292 /* JsxAttributes */) && node.parent.name === node ? node.parent : void 0; + } + return void 0; + } + function getSymbolAtLocationForQuickInfo(node, checker) { + const object = getContainingObjectLiteralElement(node); + if (object) { + const contextualType = checker.getContextualType(object.parent); + const properties = contextualType && getPropertySymbolsFromContextualType( + object, + checker, + contextualType, + /*unionSymbolOk*/ + false + ); + if (properties && properties.length === 1) { + return first(properties); + } + } + return checker.getSymbolAtLocation(node); + } + function getPropertySymbolsFromContextualType(node, checker, contextualType, unionSymbolOk) { + const name = getNameFromPropertyName(node.name); + if (!name) + return emptyArray; + if (!contextualType.isUnion()) { + const symbol = contextualType.getProperty(name); + return symbol ? [symbol] : emptyArray; + } + const discriminatedPropertySymbols = mapDefined(contextualType.types, (t) => (isObjectLiteralExpression(node.parent) || isJsxAttributes(node.parent)) && checker.isTypeInvalidDueToUnionDiscriminant(t, node.parent) ? void 0 : t.getProperty(name)); + if (unionSymbolOk && (discriminatedPropertySymbols.length === 0 || discriminatedPropertySymbols.length === contextualType.types.length)) { + const symbol = contextualType.getProperty(name); + if (symbol) + return [symbol]; + } + if (discriminatedPropertySymbols.length === 0) { + return mapDefined(contextualType.types, (t) => t.getProperty(name)); + } + return discriminatedPropertySymbols; + } + function isArgumentOfElementAccessExpression(node) { + return node && node.parent && node.parent.kind === 212 /* ElementAccessExpression */ && node.parent.argumentExpression === node; + } + function getDefaultLibFilePath(options) { + if (sys) { + return combinePaths(getDirectoryPath(normalizePath(sys.getExecutingFilePath())), getDefaultLibFileName(options)); + } + throw new Error("getDefaultLibFilePath is only supported when consumed as a node module. "); + } + var servicesVersion, NodeObject, TokenOrIdentifierObject, SymbolObject, TokenObject, IdentifierObject, PrivateIdentifierObject, TypeObject, SignatureObject, SourceFileObject, SourceMapSourceObject, SyntaxTreeCache, NoopCancellationToken, CancellationTokenObject, ThrottledCancellationToken, invalidOperationsInPartialSemanticMode, invalidOperationsInSyntacticMode; + var init_services = __esm({ + "src/services/services.ts"() { + "use strict"; + init_ts4(); + init_ts_NavigateTo(); + init_ts_NavigationBar(); + init_ts_refactor(); + init_classifier(); + init_classifier2020(); + servicesVersion = "0.8"; + NodeObject = class { + constructor(kind, pos, end) { + this.pos = pos; + this.end = end; + this.flags = 0 /* None */; + this.modifierFlagsCache = 0 /* None */; + this.transformFlags = 0 /* None */; + this.parent = void 0; + this.kind = kind; } - if (statement === end) { - break; + assertHasRealPosition(message) { + Debug.assert(!positionIsSynthesized(this.pos) && !positionIsSynthesized(this.end), message || "Node must have a real position for this operation"); } - } - if (!statements.length) { - return { errors: [createFileDiagnostic(sourceFile, span.start, length2, Messages.cannotExtractRange)] }; - } - return { targetRange: { range: statements, facts: rangeFacts, thisNode } }; - } - if (isReturnStatement(start) && !start.expression) { - return { errors: [createFileDiagnostic(sourceFile, span.start, length2, Messages.cannotExtractRange)] }; - } - const node = refineNode(start); - const errors = checkRootNode(node) || checkNode(node); - if (errors) { - return { errors }; - } - return { targetRange: { range: getStatementOrExpressionRange(node), facts: rangeFacts, thisNode } }; - function refineNode(node2) { - if (isReturnStatement(node2)) { - if (node2.expression) { - return node2.expression; + getSourceFile() { + return getSourceFileOfNode(this); } - } else if (isVariableStatement(node2) || isVariableDeclarationList(node2)) { - const declarations = isVariableStatement(node2) ? node2.declarationList.declarations : node2.declarations; - let numInitializers = 0; - let lastInitializer; - for (const declaration of declarations) { - if (declaration.initializer) { - numInitializers++; - lastInitializer = declaration.initializer; + getStart(sourceFile, includeJsDocComment) { + this.assertHasRealPosition(); + return getTokenPosOfNode(this, sourceFile, includeJsDocComment); + } + getFullStart() { + this.assertHasRealPosition(); + return this.pos; + } + getEnd() { + this.assertHasRealPosition(); + return this.end; + } + getWidth(sourceFile) { + this.assertHasRealPosition(); + return this.getEnd() - this.getStart(sourceFile); + } + getFullWidth() { + this.assertHasRealPosition(); + return this.end - this.pos; + } + getLeadingTriviaWidth(sourceFile) { + this.assertHasRealPosition(); + return this.getStart(sourceFile) - this.pos; + } + getFullText(sourceFile) { + this.assertHasRealPosition(); + return (sourceFile || this.getSourceFile()).text.substring(this.pos, this.end); + } + getText(sourceFile) { + this.assertHasRealPosition(); + if (!sourceFile) { + sourceFile = this.getSourceFile(); } + return sourceFile.text.substring(this.getStart(sourceFile), this.getEnd()); } - if (numInitializers === 1) { - return lastInitializer; + getChildCount(sourceFile) { + return this.getChildren(sourceFile).length; } - } else if (isVariableDeclaration(node2)) { - if (node2.initializer) { - return node2.initializer; + getChildAt(index, sourceFile) { + return this.getChildren(sourceFile)[index]; } - } - return node2; - } - function checkRootNode(node2) { - if (isIdentifier(isExpressionStatement(node2) ? node2.expression : node2)) { - return [createDiagnosticForNode(node2, Messages.cannotExtractIdentifier)]; - } - return void 0; - } - function checkForStaticContext(nodeToCheck, containingClass) { - let current = nodeToCheck; - while (current !== containingClass) { - if (current.kind === 171 /* PropertyDeclaration */) { - if (isStatic(current)) { - rangeFacts |= 32 /* InStaticRegion */; + getChildren(sourceFile) { + this.assertHasRealPosition("Node without a real position cannot be scanned and thus has no token nodes - use forEachChild and collect the result if that's fine"); + return this._children || (this._children = createChildren(this, sourceFile)); + } + getFirstToken(sourceFile) { + this.assertHasRealPosition(); + const children = this.getChildren(sourceFile); + if (!children.length) { + return void 0; } - break; - } else if (current.kind === 168 /* Parameter */) { - const ctorOrMethod = getContainingFunction(current); - if (ctorOrMethod.kind === 175 /* Constructor */) { - rangeFacts |= 32 /* InStaticRegion */; + const child = find(children, (kid) => kid.kind < 316 /* FirstJSDocNode */ || kid.kind > 357 /* LastJSDocNode */); + return child.kind < 166 /* FirstNode */ ? child : child.getFirstToken(sourceFile); + } + getLastToken(sourceFile) { + this.assertHasRealPosition(); + const children = this.getChildren(sourceFile); + const child = lastOrUndefined(children); + if (!child) { + return void 0; } - break; - } else if (current.kind === 173 /* MethodDeclaration */) { - if (isStatic(current)) { - rangeFacts |= 32 /* InStaticRegion */; + return child.kind < 166 /* FirstNode */ ? child : child.getLastToken(sourceFile); + } + forEachChild(cbNode, cbNodeArray) { + return forEachChild(this, cbNode, cbNodeArray); + } + }; + TokenOrIdentifierObject = class { + constructor(pos, end) { + this.pos = pos; + this.end = end; + this.flags = 0 /* None */; + this.modifierFlagsCache = 0 /* None */; + this.transformFlags = 0 /* None */; + this.parent = void 0; + } + getSourceFile() { + return getSourceFileOfNode(this); + } + getStart(sourceFile, includeJsDocComment) { + return getTokenPosOfNode(this, sourceFile, includeJsDocComment); + } + getFullStart() { + return this.pos; + } + getEnd() { + return this.end; + } + getWidth(sourceFile) { + return this.getEnd() - this.getStart(sourceFile); + } + getFullWidth() { + return this.end - this.pos; + } + getLeadingTriviaWidth(sourceFile) { + return this.getStart(sourceFile) - this.pos; + } + getFullText(sourceFile) { + return (sourceFile || this.getSourceFile()).text.substring(this.pos, this.end); + } + getText(sourceFile) { + if (!sourceFile) { + sourceFile = this.getSourceFile(); } + return sourceFile.text.substring(this.getStart(sourceFile), this.getEnd()); } - current = current.parent; - } - } - function checkNode(nodeToCheck) { - let PermittedJumps; - ((PermittedJumps2) => { - PermittedJumps2[PermittedJumps2["None"] = 0] = "None"; - PermittedJumps2[PermittedJumps2["Break"] = 1] = "Break"; - PermittedJumps2[PermittedJumps2["Continue"] = 2] = "Continue"; - PermittedJumps2[PermittedJumps2["Return"] = 4] = "Return"; - })(PermittedJumps || (PermittedJumps = {})); - Debug.assert(nodeToCheck.pos <= nodeToCheck.end, "This failure could trigger https://github.com/Microsoft/TypeScript/issues/20809 (1)"); - Debug.assert(!positionIsSynthesized(nodeToCheck.pos), "This failure could trigger https://github.com/Microsoft/TypeScript/issues/20809 (2)"); - if (!isStatement(nodeToCheck) && !(isExpressionNode(nodeToCheck) && isExtractableExpression(nodeToCheck)) && !isStringLiteralJsxAttribute(nodeToCheck)) { - return [createDiagnosticForNode(nodeToCheck, Messages.statementOrExpressionExpected)]; - } - if (nodeToCheck.flags & 16777216 /* Ambient */) { - return [createDiagnosticForNode(nodeToCheck, Messages.cannotExtractAmbientBlock)]; - } - const containingClass = getContainingClass(nodeToCheck); - if (containingClass) { - checkForStaticContext(nodeToCheck, containingClass); - } - let errors2; - let permittedJumps = 4 /* Return */; - let seenLabels; - visit(nodeToCheck); - if (rangeFacts & 8 /* UsesThis */) { - const container = getThisContainer( - nodeToCheck, - /*includeArrowFunctions*/ - false, - /*includeClassComputedPropertyName*/ - false - ); - if (container.kind === 261 /* FunctionDeclaration */ || container.kind === 173 /* MethodDeclaration */ && container.parent.kind === 209 /* ObjectLiteralExpression */ || container.kind === 217 /* FunctionExpression */) { - rangeFacts |= 16 /* UsesThisInFunction */; + getChildCount() { + return this.getChildren().length; } - } - return errors2; - function visit(node2) { - if (errors2) { - return true; + getChildAt(index) { + return this.getChildren()[index]; } - if (isDeclaration(node2)) { - const declaringNode = node2.kind === 259 /* VariableDeclaration */ ? node2.parent.parent : node2; - if (hasSyntacticModifier(declaringNode, 1 /* Export */)) { - (errors2 || (errors2 = [])).push(createDiagnosticForNode(node2, Messages.cannotExtractExportedEntity)); - return true; + getChildren() { + return this.kind === 1 /* EndOfFileToken */ ? this.jsDoc || emptyArray : emptyArray; + } + getFirstToken() { + return void 0; + } + getLastToken() { + return void 0; + } + forEachChild() { + return void 0; + } + }; + SymbolObject = class { + constructor(flags, name) { + this.id = 0; + this.mergeId = 0; + this.flags = flags; + this.escapedName = name; + } + getFlags() { + return this.flags; + } + get name() { + return symbolName(this); + } + getEscapedName() { + return this.escapedName; + } + getName() { + return this.name; + } + getDeclarations() { + return this.declarations; + } + getDocumentationComment(checker) { + if (!this.documentationComment) { + this.documentationComment = emptyArray; + if (!this.declarations && isTransientSymbol(this) && this.links.target && isTransientSymbol(this.links.target) && this.links.target.links.tupleLabelDeclaration) { + const labelDecl = this.links.target.links.tupleLabelDeclaration; + this.documentationComment = getDocumentationComment([labelDecl], checker); + } else { + this.documentationComment = getDocumentationComment(this.declarations, checker); + } } + return this.documentationComment; } - switch (node2.kind) { - case 271 /* ImportDeclaration */: - (errors2 || (errors2 = [])).push(createDiagnosticForNode(node2, Messages.cannotExtractImport)); - return true; - case 276 /* ExportAssignment */: - (errors2 || (errors2 = [])).push(createDiagnosticForNode(node2, Messages.cannotExtractExportedEntity)); - return true; - case 108 /* SuperKeyword */: - if (node2.parent.kind === 212 /* CallExpression */) { - const containingClass2 = getContainingClass(node2); - if (containingClass2 === void 0 || containingClass2.pos < span.start || containingClass2.end >= span.start + span.length) { - (errors2 || (errors2 = [])).push(createDiagnosticForNode(node2, Messages.cannotExtractSuper)); - return true; + getContextualDocumentationComment(context, checker) { + if (context) { + if (isGetAccessor(context)) { + if (!this.contextualGetAccessorDocumentationComment) { + this.contextualGetAccessorDocumentationComment = getDocumentationComment(filter(this.declarations, isGetAccessor), checker); + } + if (length(this.contextualGetAccessorDocumentationComment)) { + return this.contextualGetAccessorDocumentationComment; } - } else { - rangeFacts |= 8 /* UsesThis */; - thisNode = node2; } - break; - case 218 /* ArrowFunction */: - forEachChild(node2, function check(n) { - if (isThis(n)) { - rangeFacts |= 8 /* UsesThis */; - thisNode = node2; - } else if (isClassLike(n) || isFunctionLike(n) && !isArrowFunction(n)) { - return false; - } else { - forEachChild(n, check); + if (isSetAccessor(context)) { + if (!this.contextualSetAccessorDocumentationComment) { + this.contextualSetAccessorDocumentationComment = getDocumentationComment(filter(this.declarations, isSetAccessor), checker); + } + if (length(this.contextualSetAccessorDocumentationComment)) { + return this.contextualSetAccessorDocumentationComment; } - }); - case 262 /* ClassDeclaration */: - case 261 /* FunctionDeclaration */: - if (isSourceFile(node2.parent) && node2.parent.externalModuleIndicator === void 0) { - (errors2 || (errors2 = [])).push(createDiagnosticForNode(node2, Messages.functionWillNotBeVisibleInTheNewScope)); } - case 230 /* ClassExpression */: - case 217 /* FunctionExpression */: - case 173 /* MethodDeclaration */: - case 175 /* Constructor */: - case 176 /* GetAccessor */: - case 177 /* SetAccessor */: - return false; + } + return this.getDocumentationComment(checker); } - const savedPermittedJumps = permittedJumps; - switch (node2.kind) { - case 244 /* IfStatement */: - permittedJumps &= ~4 /* Return */; - break; - case 257 /* TryStatement */: - permittedJumps = 0 /* None */; - break; - case 240 /* Block */: - if (node2.parent && node2.parent.kind === 257 /* TryStatement */ && node2.parent.finallyBlock === node2) { - permittedJumps = 4 /* Return */; + getJsDocTags(checker) { + if (this.tags === void 0) { + this.tags = getJsDocTagsOfDeclarations(this.declarations, checker); + } + return this.tags; + } + getContextualJsDocTags(context, checker) { + if (context) { + if (isGetAccessor(context)) { + if (!this.contextualGetAccessorTags) { + this.contextualGetAccessorTags = getJsDocTagsOfDeclarations(filter(this.declarations, isGetAccessor), checker); + } + if (length(this.contextualGetAccessorTags)) { + return this.contextualGetAccessorTags; + } } - break; - case 296 /* DefaultClause */: - case 295 /* CaseClause */: - permittedJumps |= 1 /* Break */; - break; - default: - if (isIterationStatement( - node2, - /*lookInLabeledStatements*/ - false - )) { - permittedJumps |= 1 /* Break */ | 2 /* Continue */; + if (isSetAccessor(context)) { + if (!this.contextualSetAccessorTags) { + this.contextualSetAccessorTags = getJsDocTagsOfDeclarations(filter(this.declarations, isSetAccessor), checker); + } + if (length(this.contextualSetAccessorTags)) { + return this.contextualSetAccessorTags; + } } - break; + } + return this.getJsDocTags(checker); } - switch (node2.kind) { - case 196 /* ThisType */: - case 110 /* ThisKeyword */: - rangeFacts |= 8 /* UsesThis */; - thisNode = node2; - break; - case 255 /* LabeledStatement */: { - const label = node2.label; - (seenLabels || (seenLabels = [])).push(label.escapedText); - forEachChild(node2, visit); - seenLabels.pop(); - break; + }; + TokenObject = class extends TokenOrIdentifierObject { + constructor(kind, pos, end) { + super(pos, end); + this.kind = kind; + } + }; + IdentifierObject = class extends TokenOrIdentifierObject { + constructor(_kind, pos, end) { + super(pos, end); + this.kind = 80 /* Identifier */; + } + get text() { + return idText(this); + } + }; + IdentifierObject.prototype.kind = 80 /* Identifier */; + PrivateIdentifierObject = class extends TokenOrIdentifierObject { + constructor(_kind, pos, end) { + super(pos, end); + this.kind = 81 /* PrivateIdentifier */; + } + get text() { + return idText(this); + } + }; + PrivateIdentifierObject.prototype.kind = 81 /* PrivateIdentifier */; + TypeObject = class { + constructor(checker, flags) { + this.checker = checker; + this.flags = flags; + } + getFlags() { + return this.flags; + } + getSymbol() { + return this.symbol; + } + getProperties() { + return this.checker.getPropertiesOfType(this); + } + getProperty(propertyName) { + return this.checker.getPropertyOfType(this, propertyName); + } + getApparentProperties() { + return this.checker.getAugmentedPropertiesOfType(this); + } + getCallSignatures() { + return this.checker.getSignaturesOfType(this, 0 /* Call */); + } + getConstructSignatures() { + return this.checker.getSignaturesOfType(this, 1 /* Construct */); + } + getStringIndexType() { + return this.checker.getIndexTypeOfType(this, 0 /* String */); + } + getNumberIndexType() { + return this.checker.getIndexTypeOfType(this, 1 /* Number */); + } + getBaseTypes() { + return this.isClassOrInterface() ? this.checker.getBaseTypes(this) : void 0; + } + isNullableType() { + return this.checker.isNullableType(this); + } + getNonNullableType() { + return this.checker.getNonNullableType(this); + } + getNonOptionalType() { + return this.checker.getNonOptionalType(this); + } + getConstraint() { + return this.checker.getBaseConstraintOfType(this); + } + getDefault() { + return this.checker.getDefaultFromTypeParameter(this); + } + isUnion() { + return !!(this.flags & 1048576 /* Union */); + } + isIntersection() { + return !!(this.flags & 2097152 /* Intersection */); + } + isUnionOrIntersection() { + return !!(this.flags & 3145728 /* UnionOrIntersection */); + } + isLiteral() { + return !!(this.flags & (128 /* StringLiteral */ | 256 /* NumberLiteral */ | 2048 /* BigIntLiteral */)); + } + isStringLiteral() { + return !!(this.flags & 128 /* StringLiteral */); + } + isNumberLiteral() { + return !!(this.flags & 256 /* NumberLiteral */); + } + isTypeParameter() { + return !!(this.flags & 262144 /* TypeParameter */); + } + isClassOrInterface() { + return !!(getObjectFlags(this) & 3 /* ClassOrInterface */); + } + isClass() { + return !!(getObjectFlags(this) & 1 /* Class */); + } + isIndexType() { + return !!(this.flags & 4194304 /* Index */); + } + /** + * This polyfills `referenceType.typeArguments` for API consumers + */ + get typeArguments() { + if (getObjectFlags(this) & 4 /* Reference */) { + return this.checker.getTypeArguments(this); } - case 251 /* BreakStatement */: - case 250 /* ContinueStatement */: { - const label = node2.label; - if (label) { - if (!contains(seenLabels, label.escapedText)) { - (errors2 || (errors2 = [])).push(createDiagnosticForNode(node2, Messages.cannotExtractRangeContainingLabeledBreakOrContinueStatementWithTargetOutsideOfTheRange)); - } - } else { - if (!(permittedJumps & (node2.kind === 251 /* BreakStatement */ ? 1 /* Break */ : 2 /* Continue */))) { - (errors2 || (errors2 = [])).push(createDiagnosticForNode(node2, Messages.cannotExtractRangeContainingConditionalBreakOrContinueStatements)); - } + return void 0; + } + }; + SignatureObject = class { + // same + constructor(checker, flags) { + this.checker = checker; + this.flags = flags; + } + getDeclaration() { + return this.declaration; + } + getTypeParameters() { + return this.typeParameters; + } + getParameters() { + return this.parameters; + } + getReturnType() { + return this.checker.getReturnTypeOfSignature(this); + } + getTypeParameterAtPosition(pos) { + const type = this.checker.getParameterType(this, pos); + if (type.isIndexType() && isThisTypeParameter(type.type)) { + const constraint = type.type.getConstraint(); + if (constraint) { + return this.checker.getIndexType(constraint); } - break; } - case 222 /* AwaitExpression */: - rangeFacts |= 4 /* IsAsyncFunction */; - break; - case 228 /* YieldExpression */: - rangeFacts |= 2 /* IsGenerator */; - break; - case 252 /* ReturnStatement */: - if (permittedJumps & 4 /* Return */) { - rangeFacts |= 1 /* HasReturn */; - } else { - (errors2 || (errors2 = [])).push(createDiagnosticForNode(node2, Messages.cannotExtractRangeContainingConditionalReturnStatement)); + return type; + } + getDocumentationComment() { + return this.documentationComment || (this.documentationComment = getDocumentationComment(singleElementArray(this.declaration), this.checker)); + } + getJsDocTags() { + return this.jsDocTags || (this.jsDocTags = getJsDocTagsOfDeclarations(singleElementArray(this.declaration), this.checker)); + } + }; + SourceFileObject = class extends NodeObject { + constructor(kind, pos, end) { + super(kind, pos, end); + this.kind = 312 /* SourceFile */; + } + update(newText, textChangeRange) { + return updateSourceFile(this, newText, textChangeRange); + } + getLineAndCharacterOfPosition(position) { + return getLineAndCharacterOfPosition(this, position); + } + getLineStarts() { + return getLineStarts(this); + } + getPositionOfLineAndCharacter(line, character, allowEdits) { + return computePositionOfLineAndCharacter(getLineStarts(this), line, character, this.text, allowEdits); + } + getLineEndOfPosition(pos) { + const { line } = this.getLineAndCharacterOfPosition(pos); + const lineStarts = this.getLineStarts(); + let lastCharPos; + if (line + 1 >= lineStarts.length) { + lastCharPos = this.getEnd(); + } + if (!lastCharPos) { + lastCharPos = lineStarts[line + 1] - 1; + } + const fullText = this.getFullText(); + return fullText[lastCharPos] === "\n" && fullText[lastCharPos - 1] === "\r" ? lastCharPos - 1 : lastCharPos; + } + getNamedDeclarations() { + if (!this.namedDeclarations) { + this.namedDeclarations = this.computeNamedDeclarations(); + } + return this.namedDeclarations; + } + computeNamedDeclarations() { + const result = createMultiMap(); + this.forEachChild(visit); + return result; + function addDeclaration(declaration) { + const name = getDeclarationName(declaration); + if (name) { + result.add(name, declaration); } - break; - default: - forEachChild(node2, visit); - break; + } + function getDeclarations(name) { + let declarations = result.get(name); + if (!declarations) { + result.set(name, declarations = []); + } + return declarations; + } + function getDeclarationName(declaration) { + const name = getNonAssignedNameOfDeclaration(declaration); + return name && (isComputedPropertyName(name) && isPropertyAccessExpression(name.expression) ? name.expression.name.text : isPropertyName(name) ? getNameFromPropertyName(name) : void 0); + } + function visit(node) { + switch (node.kind) { + case 262 /* FunctionDeclaration */: + case 218 /* FunctionExpression */: + case 174 /* MethodDeclaration */: + case 173 /* MethodSignature */: + const functionDeclaration = node; + const declarationName = getDeclarationName(functionDeclaration); + if (declarationName) { + const declarations = getDeclarations(declarationName); + const lastDeclaration = lastOrUndefined(declarations); + if (lastDeclaration && functionDeclaration.parent === lastDeclaration.parent && functionDeclaration.symbol === lastDeclaration.symbol) { + if (functionDeclaration.body && !lastDeclaration.body) { + declarations[declarations.length - 1] = functionDeclaration; + } + } else { + declarations.push(functionDeclaration); + } + } + forEachChild(node, visit); + break; + case 263 /* ClassDeclaration */: + case 231 /* ClassExpression */: + case 264 /* InterfaceDeclaration */: + case 265 /* TypeAliasDeclaration */: + case 266 /* EnumDeclaration */: + case 267 /* ModuleDeclaration */: + case 271 /* ImportEqualsDeclaration */: + case 281 /* ExportSpecifier */: + case 276 /* ImportSpecifier */: + case 273 /* ImportClause */: + case 274 /* NamespaceImport */: + case 177 /* GetAccessor */: + case 178 /* SetAccessor */: + case 187 /* TypeLiteral */: + addDeclaration(node); + forEachChild(node, visit); + break; + case 169 /* Parameter */: + if (!hasSyntacticModifier(node, 31 /* ParameterPropertyModifier */)) { + break; + } + case 260 /* VariableDeclaration */: + case 208 /* BindingElement */: { + const decl = node; + if (isBindingPattern(decl.name)) { + forEachChild(decl.name, visit); + break; + } + if (decl.initializer) { + visit(decl.initializer); + } + } + case 306 /* EnumMember */: + case 172 /* PropertyDeclaration */: + case 171 /* PropertySignature */: + addDeclaration(node); + break; + case 278 /* ExportDeclaration */: + const exportDeclaration = node; + if (exportDeclaration.exportClause) { + if (isNamedExports(exportDeclaration.exportClause)) { + forEach(exportDeclaration.exportClause.elements, visit); + } else { + visit(exportDeclaration.exportClause.name); + } + } + break; + case 272 /* ImportDeclaration */: + const importClause = node.importClause; + if (importClause) { + if (importClause.name) { + addDeclaration(importClause.name); + } + if (importClause.namedBindings) { + if (importClause.namedBindings.kind === 274 /* NamespaceImport */) { + addDeclaration(importClause.namedBindings); + } else { + forEach(importClause.namedBindings.elements, visit); + } + } + } + break; + case 226 /* BinaryExpression */: + if (getAssignmentDeclarationKind(node) !== 0 /* None */) { + addDeclaration(node); + } + default: + forEachChild(node, visit); + } + } } - permittedJumps = savedPermittedJumps; - } - } - } - function getAdjustedSpanFromNodes(startNode2, endNode2, sourceFile) { - const start = startNode2.getStart(sourceFile); - let end = endNode2.getEnd(); - if (sourceFile.text.charCodeAt(end) === 59 /* semicolon */) { - end++; - } - return { start, length: end - start }; - } - function getStatementOrExpressionRange(node) { - if (isStatement(node)) { - return [node]; - } - if (isExpressionNode(node)) { - return isExpressionStatement(node.parent) ? [node.parent] : node; - } - if (isStringLiteralJsxAttribute(node)) { - return node; - } - return void 0; - } - function isScope(node) { - return isArrowFunction(node) ? isFunctionBody(node.body) : isFunctionLikeDeclaration(node) || isSourceFile(node) || isModuleBlock(node) || isClassLike(node); - } - function collectEnclosingScopes(range) { - let current = isReadonlyArray(range.range) ? first(range.range) : range.range; - if (range.facts & 8 /* UsesThis */ && !(range.facts & 16 /* UsesThisInFunction */)) { - const containingClass = getContainingClass(current); - if (containingClass) { - const containingFunction = findAncestor(current, isFunctionLikeDeclaration); - return containingFunction ? [containingFunction, containingClass] : [containingClass]; - } - } - const scopes = []; - while (true) { - current = current.parent; - if (current.kind === 168 /* Parameter */) { - current = findAncestor(current, (parent2) => isFunctionLikeDeclaration(parent2)).parent; - } - if (isScope(current)) { - scopes.push(current); - if (current.kind === 311 /* SourceFile */) { - return scopes; + }; + SourceMapSourceObject = class { + constructor(fileName, text, skipTrivia2) { + this.fileName = fileName; + this.text = text; + this.skipTrivia = skipTrivia2; } - } - } - } - function getFunctionExtractionAtIndex(targetRange, context, requestedChangesIndex) { - const { scopes, readsAndWrites: { target, usagesPerScope, functionErrorsPerScope, exposedVariableDeclarations } } = getPossibleExtractionsWorker(targetRange, context); - Debug.assert(!functionErrorsPerScope[requestedChangesIndex].length, "The extraction went missing? How?"); - context.cancellationToken.throwIfCancellationRequested(); - return extractFunctionInScope(target, scopes[requestedChangesIndex], usagesPerScope[requestedChangesIndex], exposedVariableDeclarations, targetRange, context); - } - function getConstantExtractionAtIndex(targetRange, context, requestedChangesIndex) { - const { scopes, readsAndWrites: { target, usagesPerScope, constantErrorsPerScope, exposedVariableDeclarations } } = getPossibleExtractionsWorker(targetRange, context); - Debug.assert(!constantErrorsPerScope[requestedChangesIndex].length, "The extraction went missing? How?"); - Debug.assert(exposedVariableDeclarations.length === 0, "Extract constant accepted a range containing a variable declaration?"); - context.cancellationToken.throwIfCancellationRequested(); - const expression = isExpression(target) ? target : target.statements[0].expression; - return extractConstantInScope(expression, scopes[requestedChangesIndex], usagesPerScope[requestedChangesIndex], targetRange.facts, context); - } - function getPossibleExtractions(targetRange, context) { - const { scopes, readsAndWrites: { functionErrorsPerScope, constantErrorsPerScope } } = getPossibleExtractionsWorker(targetRange, context); - const extractions = scopes.map((scope, i) => { - const functionDescriptionPart = getDescriptionForFunctionInScope(scope); - const constantDescriptionPart = getDescriptionForConstantInScope(scope); - const scopeDescription = isFunctionLikeDeclaration(scope) ? getDescriptionForFunctionLikeDeclaration(scope) : isClassLike(scope) ? getDescriptionForClassLikeDeclaration(scope) : getDescriptionForModuleLikeDeclaration(scope); - let functionDescription; - let constantDescription; - if (scopeDescription === 1 /* Global */) { - functionDescription = formatStringFromArgs(getLocaleSpecificMessage(Diagnostics.Extract_to_0_in_1_scope), [functionDescriptionPart, "global"]); - constantDescription = formatStringFromArgs(getLocaleSpecificMessage(Diagnostics.Extract_to_0_in_1_scope), [constantDescriptionPart, "global"]); - } else if (scopeDescription === 0 /* Module */) { - functionDescription = formatStringFromArgs(getLocaleSpecificMessage(Diagnostics.Extract_to_0_in_1_scope), [functionDescriptionPart, "module"]); - constantDescription = formatStringFromArgs(getLocaleSpecificMessage(Diagnostics.Extract_to_0_in_1_scope), [constantDescriptionPart, "module"]); - } else { - functionDescription = formatStringFromArgs(getLocaleSpecificMessage(Diagnostics.Extract_to_0_in_1), [functionDescriptionPart, scopeDescription]); - constantDescription = formatStringFromArgs(getLocaleSpecificMessage(Diagnostics.Extract_to_0_in_1), [constantDescriptionPart, scopeDescription]); - } - if (i === 0 && !isClassLike(scope)) { - constantDescription = formatStringFromArgs(getLocaleSpecificMessage(Diagnostics.Extract_to_0_in_enclosing_scope), [constantDescriptionPart]); - } - return { - functionExtraction: { - description: functionDescription, - errors: functionErrorsPerScope[i] - }, - constantExtraction: { - description: constantDescription, - errors: constantErrorsPerScope[i] + getLineAndCharacterOfPosition(pos) { + return getLineAndCharacterOfPosition(this, pos); } }; - }); - return extractions; - } - function getPossibleExtractionsWorker(targetRange, context) { - const { file: sourceFile } = context; - const scopes = collectEnclosingScopes(targetRange); - const enclosingTextRange = getEnclosingTextRange(targetRange, sourceFile); - const readsAndWrites = collectReadsAndWrites( - targetRange, - scopes, - enclosingTextRange, - sourceFile, - context.program.getTypeChecker(), - context.cancellationToken - ); - return { scopes, readsAndWrites }; - } - function getDescriptionForFunctionInScope(scope) { - return isFunctionLikeDeclaration(scope) ? "inner function" : isClassLike(scope) ? "method" : "function"; - } - function getDescriptionForConstantInScope(scope) { - return isClassLike(scope) ? "readonly field" : "constant"; - } - function getDescriptionForFunctionLikeDeclaration(scope) { - switch (scope.kind) { - case 175 /* Constructor */: - return "constructor"; - case 217 /* FunctionExpression */: - case 261 /* FunctionDeclaration */: - return scope.name ? `function '${scope.name.text}'` : ANONYMOUS; - case 218 /* ArrowFunction */: - return "arrow function"; - case 173 /* MethodDeclaration */: - return `method '${scope.name.getText()}'`; - case 176 /* GetAccessor */: - return `'get ${scope.name.getText()}'`; - case 177 /* SetAccessor */: - return `'set ${scope.name.getText()}'`; - default: - Debug.assertNever(scope, `Unexpected scope kind ${scope.kind}`); + SyntaxTreeCache = class { + constructor(host) { + this.host = host; + } + getCurrentSourceFile(fileName) { + var _a, _b, _c, _d, _e, _f, _g, _h; + const scriptSnapshot = this.host.getScriptSnapshot(fileName); + if (!scriptSnapshot) { + throw new Error("Could not find file: '" + fileName + "'."); + } + const scriptKind = getScriptKind(fileName, this.host); + const version2 = this.host.getScriptVersion(fileName); + let sourceFile; + if (this.currentFileName !== fileName) { + const options = { + languageVersion: 99 /* Latest */, + impliedNodeFormat: getImpliedNodeFormatForFile( + toPath(fileName, this.host.getCurrentDirectory(), ((_c = (_b = (_a = this.host).getCompilerHost) == null ? void 0 : _b.call(_a)) == null ? void 0 : _c.getCanonicalFileName) || hostGetCanonicalFileName(this.host)), + (_h = (_g = (_f = (_e = (_d = this.host).getCompilerHost) == null ? void 0 : _e.call(_d)) == null ? void 0 : _f.getModuleResolutionCache) == null ? void 0 : _g.call(_f)) == null ? void 0 : _h.getPackageJsonInfoCache(), + this.host, + this.host.getCompilationSettings() + ), + setExternalModuleIndicator: getSetExternalModuleIndicator(this.host.getCompilationSettings()), + // These files are used to produce syntax-based highlighting, which reads JSDoc, so we must use ParseAll. + jsDocParsingMode: 0 /* ParseAll */ + }; + sourceFile = createLanguageServiceSourceFile( + fileName, + scriptSnapshot, + options, + version2, + /*setNodeParents*/ + true, + scriptKind + ); + } else if (this.currentFileVersion !== version2) { + const editRange = scriptSnapshot.getChangeRange(this.currentFileScriptSnapshot); + sourceFile = updateLanguageServiceSourceFile(this.currentSourceFile, scriptSnapshot, version2, editRange); + } + if (sourceFile) { + this.currentFileVersion = version2; + this.currentFileName = fileName; + this.currentFileScriptSnapshot = scriptSnapshot; + this.currentSourceFile = sourceFile; + } + return this.currentSourceFile; + } + }; + NoopCancellationToken = { + isCancellationRequested: returnFalse, + throwIfCancellationRequested: noop + }; + CancellationTokenObject = class { + constructor(cancellationToken) { + this.cancellationToken = cancellationToken; + } + isCancellationRequested() { + return this.cancellationToken.isCancellationRequested(); + } + throwIfCancellationRequested() { + var _a; + if (this.isCancellationRequested()) { + (_a = tracing) == null ? void 0 : _a.instant(tracing.Phase.Session, "cancellationThrown", { kind: "CancellationTokenObject" }); + throw new OperationCanceledException(); + } + } + }; + ThrottledCancellationToken = class { + constructor(hostCancellationToken, throttleWaitMilliseconds = 20) { + this.hostCancellationToken = hostCancellationToken; + this.throttleWaitMilliseconds = throttleWaitMilliseconds; + // Store when we last tried to cancel. Checking cancellation can be expensive (as we have + // to marshall over to the host layer). So we only bother actually checking once enough + // time has passed. + this.lastCancellationCheckTime = 0; + } + isCancellationRequested() { + const time = timestamp(); + const duration = Math.abs(time - this.lastCancellationCheckTime); + if (duration >= this.throttleWaitMilliseconds) { + this.lastCancellationCheckTime = time; + return this.hostCancellationToken.isCancellationRequested(); + } + return false; + } + throwIfCancellationRequested() { + var _a; + if (this.isCancellationRequested()) { + (_a = tracing) == null ? void 0 : _a.instant(tracing.Phase.Session, "cancellationThrown", { kind: "ThrottledCancellationToken" }); + throw new OperationCanceledException(); + } + } + }; + invalidOperationsInPartialSemanticMode = [ + "getSemanticDiagnostics", + "getSuggestionDiagnostics", + "getCompilerOptionsDiagnostics", + "getSemanticClassifications", + "getEncodedSemanticClassifications", + "getCodeFixesAtPosition", + "getCombinedCodeFix", + "applyCodeActionCommand", + "organizeImports", + "getEditsForFileRename", + "getEmitOutput", + "getApplicableRefactors", + "getEditsForRefactor", + "prepareCallHierarchy", + "provideCallHierarchyIncomingCalls", + "provideCallHierarchyOutgoingCalls", + "provideInlayHints", + "getSupportedCodeFixes" + ]; + invalidOperationsInSyntacticMode = [ + ...invalidOperationsInPartialSemanticMode, + "getCompletionsAtPosition", + "getCompletionEntryDetails", + "getCompletionEntrySymbol", + "getSignatureHelpItems", + "getQuickInfoAtPosition", + "getDefinitionAtPosition", + "getDefinitionAndBoundSpan", + "getImplementationAtPosition", + "getTypeDefinitionAtPosition", + "getReferencesAtPosition", + "findReferences", + "getDocumentHighlights", + "getNavigateToItems", + "getRenameInfo", + "findRenameLocations", + "getApplicableRefactors" + ]; + setObjectAllocator(getServicesObjectAllocator()); } + }); + + // src/services/transform.ts + function transform(source, transformers, compilerOptions) { + const diagnostics = []; + compilerOptions = fixupCompilerOptions(compilerOptions, diagnostics); + const nodes = isArray(source) ? source : [source]; + const result = transformNodes( + /*resolver*/ + void 0, + /*host*/ + void 0, + factory, + compilerOptions, + nodes, + transformers, + /*allowDtsFiles*/ + true + ); + result.diagnostics = concatenate(result.diagnostics, diagnostics); + return result; } - function getDescriptionForClassLikeDeclaration(scope) { - return scope.kind === 262 /* ClassDeclaration */ ? scope.name ? `class '${scope.name.text}'` : "anonymous class declaration" : scope.name ? `class expression '${scope.name.text}'` : "anonymous class expression"; - } - function getDescriptionForModuleLikeDeclaration(scope) { - return scope.kind === 267 /* ModuleBlock */ ? `namespace '${scope.parent.name.getText()}'` : scope.externalModuleIndicator ? 0 /* Module */ : 1 /* Global */; - } - function extractFunctionInScope(node, scope, { usages: usagesInScope, typeParameterUsages, substitutions }, exposedVariableDeclarations, range, context) { - const checker = context.program.getTypeChecker(); - const scriptTarget = getEmitScriptTarget(context.program.getCompilerOptions()); - const importAdder = ts_codefix_exports.createImportAdder(context.file, context.program, context.preferences, context.host); - const file = scope.getSourceFile(); - const functionNameText = getUniqueName(isClassLike(scope) ? "newMethod" : "newFunction", file); - const isJS = isInJSFile(scope); - const functionName = factory.createIdentifier(functionNameText); - let returnType; - const parameters = []; - const callArguments = []; - let writes; - usagesInScope.forEach((usage, name) => { - let typeNode; - if (!isJS) { - let type = checker.getTypeOfSymbolAtLocation(usage.symbol, usage.node); - type = checker.getBaseTypeOfLiteralType(type); - typeNode = ts_codefix_exports.typeToAutoImportableTypeNode(checker, importAdder, type, scope, scriptTarget, 1 /* NoTruncation */); - } - const paramDecl = factory.createParameterDeclaration( - /*modifiers*/ - void 0, - /*dotDotDotToken*/ - void 0, - /*name*/ - name, - /*questionToken*/ - void 0, - typeNode - ); - parameters.push(paramDecl); - if (usage.usage === 2 /* Write */) { - (writes || (writes = [])).push(usage); - } - callArguments.push(factory.createIdentifier(name)); - }); - const typeParametersAndDeclarations = arrayFrom(typeParameterUsages.values(), (type) => ({ type, declaration: getFirstDeclarationBeforePosition(type, context.startPosition) })); - const sortedTypeParametersAndDeclarations = typeParametersAndDeclarations.sort(compareTypesByDeclarationOrder); - const typeParameters = sortedTypeParametersAndDeclarations.length === 0 ? void 0 : mapDefined(sortedTypeParametersAndDeclarations, ({ declaration }) => declaration); - const callTypeArguments = typeParameters !== void 0 ? typeParameters.map((decl) => factory.createTypeReferenceNode( - decl.name, - /*typeArguments*/ - void 0 - )) : void 0; - if (isExpression(node) && !isJS) { - const contextualType = checker.getContextualType(node); - returnType = checker.typeToTypeNode(contextualType, scope, 1 /* NoTruncation */); + var init_transform = __esm({ + "src/services/transform.ts"() { + "use strict"; + init_ts4(); } - const { body, returnValueProperty } = transformFunctionBody(node, exposedVariableDeclarations, writes, substitutions, !!(range.facts & 1 /* HasReturn */)); - suppressLeadingAndTrailingTrivia(body); - let newFunction; - const callThis = !!(range.facts & 16 /* UsesThisInFunction */); - if (isClassLike(scope)) { - const modifiers = isJS ? [] : [factory.createModifier(123 /* PrivateKeyword */)]; - if (range.facts & 32 /* InStaticRegion */) { - modifiers.push(factory.createModifier(126 /* StaticKeyword */)); - } - if (range.facts & 4 /* IsAsyncFunction */) { - modifiers.push(factory.createModifier(134 /* AsyncKeyword */)); - } - newFunction = factory.createMethodDeclaration( - modifiers.length ? modifiers : void 0, - range.facts & 2 /* IsGenerator */ ? factory.createToken(42 /* AsteriskToken */) : void 0, - functionName, - /*questionToken*/ - void 0, - typeParameters, - parameters, - returnType, - body - ); - } else { - if (callThis) { - parameters.unshift( - factory.createParameterDeclaration( - /*modifiers*/ - void 0, - /*dotDotDotToken*/ - void 0, - /*name*/ - "this", - /*questionToken*/ - void 0, - checker.typeToTypeNode( - checker.getTypeAtLocation(range.thisNode), - scope, - 1 /* NoTruncation */ - ), - /*initializer*/ - void 0 - ) - ); + }); + + // src/services/breakpoints.ts + function spanInSourceFileAtLocation(sourceFile, position) { + if (sourceFile.isDeclarationFile) { + return void 0; + } + let tokenAtLocation = getTokenAtPosition(sourceFile, position); + const lineOfPosition = sourceFile.getLineAndCharacterOfPosition(position).line; + if (sourceFile.getLineAndCharacterOfPosition(tokenAtLocation.getStart(sourceFile)).line > lineOfPosition) { + const preceding = findPrecedingToken(tokenAtLocation.pos, sourceFile); + if (!preceding || sourceFile.getLineAndCharacterOfPosition(preceding.getEnd()).line !== lineOfPosition) { + return void 0; } - newFunction = factory.createFunctionDeclaration( - range.facts & 4 /* IsAsyncFunction */ ? [factory.createToken(134 /* AsyncKeyword */)] : void 0, - range.facts & 2 /* IsGenerator */ ? factory.createToken(42 /* AsteriskToken */) : void 0, - functionName, - typeParameters, - parameters, - returnType, - body - ); + tokenAtLocation = preceding; } - const changeTracker = ts_textChanges_exports.ChangeTracker.fromContext(context); - const minInsertionPos = (isReadonlyArray(range.range) ? last(range.range) : range.range).end; - const nodeToInsertBefore = getNodeToInsertFunctionBefore(minInsertionPos, scope); - if (nodeToInsertBefore) { - changeTracker.insertNodeBefore( - context.file, - nodeToInsertBefore, - newFunction, - /*blankLineBetween*/ - true - ); - } else { - changeTracker.insertNodeAtEndOfScope(context.file, scope, newFunction); + if (tokenAtLocation.flags & 33554432 /* Ambient */) { + return void 0; } - importAdder.writeFixes(changeTracker); - const newNodes = []; - const called = getCalledExpression(scope, range, functionNameText); - if (callThis) { - callArguments.unshift(factory.createIdentifier("this")); + return spanInNode(tokenAtLocation); + function textSpan(startNode2, endNode2) { + const lastDecorator = canHaveDecorators(startNode2) ? findLast(startNode2.modifiers, isDecorator) : void 0; + const start = lastDecorator ? skipTrivia(sourceFile.text, lastDecorator.end) : startNode2.getStart(sourceFile); + return createTextSpanFromBounds(start, (endNode2 || startNode2).getEnd()); } - let call = factory.createCallExpression( - callThis ? factory.createPropertyAccessExpression( - called, - "call" - ) : called, - callTypeArguments, - // Note that no attempt is made to take advantage of type argument inference - callArguments - ); - if (range.facts & 2 /* IsGenerator */) { - call = factory.createYieldExpression(factory.createToken(42 /* AsteriskToken */), call); + function textSpanEndingAtNextToken(startNode2, previousTokenToFindNextEndToken) { + return textSpan(startNode2, findNextToken(previousTokenToFindNextEndToken, previousTokenToFindNextEndToken.parent, sourceFile)); } - if (range.facts & 4 /* IsAsyncFunction */) { - call = factory.createAwaitExpression(call); + function spanInNodeIfStartsOnSameLine(node, otherwiseOnNode) { + if (node && lineOfPosition === sourceFile.getLineAndCharacterOfPosition(node.getStart(sourceFile)).line) { + return spanInNode(node); + } + return spanInNode(otherwiseOnNode); } - if (isInJSXContent(node)) { - call = factory.createJsxExpression( - /*dotDotDotToken*/ - void 0, - call - ); + function spanInNodeArray(nodeArray, node, match) { + if (nodeArray) { + const index = nodeArray.indexOf(node); + if (index >= 0) { + let start = index; + let end = index + 1; + while (start > 0 && match(nodeArray[start - 1])) + start--; + while (end < nodeArray.length && match(nodeArray[end])) + end++; + return createTextSpanFromBounds(skipTrivia(sourceFile.text, nodeArray[start].pos), nodeArray[end - 1].end); + } + } + return textSpan(node); } - if (exposedVariableDeclarations.length && !writes) { - Debug.assert(!returnValueProperty, "Expected no returnValueProperty"); - Debug.assert(!(range.facts & 1 /* HasReturn */), "Expected RangeFacts.HasReturn flag to be unset"); - if (exposedVariableDeclarations.length === 1) { - const variableDeclaration = exposedVariableDeclarations[0]; - newNodes.push(factory.createVariableStatement( - /*modifiers*/ - void 0, - factory.createVariableDeclarationList( - [factory.createVariableDeclaration( - getSynthesizedDeepClone(variableDeclaration.name), - /*exclamationToken*/ - void 0, - /*type*/ - getSynthesizedDeepClone(variableDeclaration.type), - /*initializer*/ - call - )], - variableDeclaration.parent.flags - ) - )); - } else { - const bindingElements = []; - const typeElements = []; - let commonNodeFlags = exposedVariableDeclarations[0].parent.flags; - let sawExplicitType = false; - for (const variableDeclaration of exposedVariableDeclarations) { - bindingElements.push(factory.createBindingElement( - /*dotDotDotToken*/ - void 0, - /*propertyName*/ - void 0, - /*name*/ - getSynthesizedDeepClone(variableDeclaration.name) - )); - const variableType = checker.typeToTypeNode( - checker.getBaseTypeOfLiteralType(checker.getTypeAtLocation(variableDeclaration)), - scope, - 1 /* NoTruncation */ - ); - typeElements.push(factory.createPropertySignature( - /*modifiers*/ - void 0, - /*name*/ - variableDeclaration.symbol.name, - /*questionToken*/ - void 0, - /*type*/ - variableType - )); - sawExplicitType = sawExplicitType || variableDeclaration.type !== void 0; - commonNodeFlags = commonNodeFlags & variableDeclaration.parent.flags; + function spanInPreviousNode(node) { + return spanInNode(findPrecedingToken(node.pos, sourceFile)); + } + function spanInNextNode(node) { + return spanInNode(findNextToken(node, node.parent, sourceFile)); + } + function spanInNode(node) { + if (node) { + const { parent: parent2 } = node; + switch (node.kind) { + case 243 /* VariableStatement */: + return spanInVariableDeclaration(node.declarationList.declarations[0]); + case 260 /* VariableDeclaration */: + case 172 /* PropertyDeclaration */: + case 171 /* PropertySignature */: + return spanInVariableDeclaration(node); + case 169 /* Parameter */: + return spanInParameterDeclaration(node); + case 262 /* FunctionDeclaration */: + case 174 /* MethodDeclaration */: + case 173 /* MethodSignature */: + case 177 /* GetAccessor */: + case 178 /* SetAccessor */: + case 176 /* Constructor */: + case 218 /* FunctionExpression */: + case 219 /* ArrowFunction */: + return spanInFunctionDeclaration(node); + case 241 /* Block */: + if (isFunctionBlock(node)) { + return spanInFunctionBlock(node); + } + case 268 /* ModuleBlock */: + return spanInBlock(node); + case 299 /* CatchClause */: + return spanInBlock(node.block); + case 244 /* ExpressionStatement */: + return textSpan(node.expression); + case 253 /* ReturnStatement */: + return textSpan(node.getChildAt(0), node.expression); + case 247 /* WhileStatement */: + return textSpanEndingAtNextToken(node, node.expression); + case 246 /* DoStatement */: + return spanInNode(node.statement); + case 259 /* DebuggerStatement */: + return textSpan(node.getChildAt(0)); + case 245 /* IfStatement */: + return textSpanEndingAtNextToken(node, node.expression); + case 256 /* LabeledStatement */: + return spanInNode(node.statement); + case 252 /* BreakStatement */: + case 251 /* ContinueStatement */: + return textSpan(node.getChildAt(0), node.label); + case 248 /* ForStatement */: + return spanInForStatement(node); + case 249 /* ForInStatement */: + return textSpanEndingAtNextToken(node, node.expression); + case 250 /* ForOfStatement */: + return spanInInitializerOfForLike(node); + case 255 /* SwitchStatement */: + return textSpanEndingAtNextToken(node, node.expression); + case 296 /* CaseClause */: + case 297 /* DefaultClause */: + return spanInNode(node.statements[0]); + case 258 /* TryStatement */: + return spanInBlock(node.tryBlock); + case 257 /* ThrowStatement */: + return textSpan(node, node.expression); + case 277 /* ExportAssignment */: + return textSpan(node, node.expression); + case 271 /* ImportEqualsDeclaration */: + return textSpan(node, node.moduleReference); + case 272 /* ImportDeclaration */: + return textSpan(node, node.moduleSpecifier); + case 278 /* ExportDeclaration */: + return textSpan(node, node.moduleSpecifier); + case 267 /* ModuleDeclaration */: + if (getModuleInstanceState(node) !== 1 /* Instantiated */) { + return void 0; + } + case 263 /* ClassDeclaration */: + case 266 /* EnumDeclaration */: + case 306 /* EnumMember */: + case 208 /* BindingElement */: + return textSpan(node); + case 254 /* WithStatement */: + return spanInNode(node.statement); + case 170 /* Decorator */: + return spanInNodeArray(parent2.modifiers, node, isDecorator); + case 206 /* ObjectBindingPattern */: + case 207 /* ArrayBindingPattern */: + return spanInBindingPattern(node); + case 264 /* InterfaceDeclaration */: + case 265 /* TypeAliasDeclaration */: + return void 0; + case 27 /* SemicolonToken */: + case 1 /* EndOfFileToken */: + return spanInNodeIfStartsOnSameLine(findPrecedingToken(node.pos, sourceFile)); + case 28 /* CommaToken */: + return spanInPreviousNode(node); + case 19 /* OpenBraceToken */: + return spanInOpenBraceToken(node); + case 20 /* CloseBraceToken */: + return spanInCloseBraceToken(node); + case 24 /* CloseBracketToken */: + return spanInCloseBracketToken(node); + case 21 /* OpenParenToken */: + return spanInOpenParenToken(node); + case 22 /* CloseParenToken */: + return spanInCloseParenToken(node); + case 59 /* ColonToken */: + return spanInColonToken(node); + case 32 /* GreaterThanToken */: + case 30 /* LessThanToken */: + return spanInGreaterThanOrLessThanToken(node); + case 117 /* WhileKeyword */: + return spanInWhileKeyword(node); + case 93 /* ElseKeyword */: + case 85 /* CatchKeyword */: + case 98 /* FinallyKeyword */: + return spanInNextNode(node); + case 165 /* OfKeyword */: + return spanInOfKeyword(node); + default: + if (isArrayLiteralOrObjectLiteralDestructuringPattern(node)) { + return spanInArrayLiteralOrObjectLiteralDestructuringPattern(node); + } + if ((node.kind === 80 /* Identifier */ || node.kind === 230 /* SpreadElement */ || node.kind === 303 /* PropertyAssignment */ || node.kind === 304 /* ShorthandPropertyAssignment */) && isArrayLiteralOrObjectLiteralDestructuringPattern(parent2)) { + return textSpan(node); + } + if (node.kind === 226 /* BinaryExpression */) { + const { left, operatorToken } = node; + if (isArrayLiteralOrObjectLiteralDestructuringPattern(left)) { + return spanInArrayLiteralOrObjectLiteralDestructuringPattern( + left + ); + } + if (operatorToken.kind === 64 /* EqualsToken */ && isArrayLiteralOrObjectLiteralDestructuringPattern(node.parent)) { + return textSpan(node); + } + if (operatorToken.kind === 28 /* CommaToken */) { + return spanInNode(left); + } + } + if (isExpressionNode(node)) { + switch (parent2.kind) { + case 246 /* DoStatement */: + return spanInPreviousNode(node); + case 170 /* Decorator */: + return spanInNode(node.parent); + case 248 /* ForStatement */: + case 250 /* ForOfStatement */: + return textSpan(node); + case 226 /* BinaryExpression */: + if (node.parent.operatorToken.kind === 28 /* CommaToken */) { + return textSpan(node); + } + break; + case 219 /* ArrowFunction */: + if (node.parent.body === node) { + return textSpan(node); + } + break; + } + } + switch (node.parent.kind) { + case 303 /* PropertyAssignment */: + if (node.parent.name === node && !isArrayLiteralOrObjectLiteralDestructuringPattern(node.parent.parent)) { + return spanInNode(node.parent.initializer); + } + break; + case 216 /* TypeAssertionExpression */: + if (node.parent.type === node) { + return spanInNextNode(node.parent.type); + } + break; + case 260 /* VariableDeclaration */: + case 169 /* Parameter */: { + const { initializer, type } = node.parent; + if (initializer === node || type === node || isAssignmentOperator(node.kind)) { + return spanInPreviousNode(node); + } + break; + } + case 226 /* BinaryExpression */: { + const { left } = node.parent; + if (isArrayLiteralOrObjectLiteralDestructuringPattern(left) && node !== left) { + return spanInPreviousNode(node); + } + break; + } + default: + if (isFunctionLike(node.parent) && node.parent.type === node) { + return spanInPreviousNode(node); + } + } + return spanInNode(node.parent); } - const typeLiteral = sawExplicitType ? factory.createTypeLiteralNode(typeElements) : void 0; - if (typeLiteral) { - setEmitFlags(typeLiteral, 1 /* SingleLine */); + } + function textSpanFromVariableDeclaration(variableDeclaration) { + if (isVariableDeclarationList(variableDeclaration.parent) && variableDeclaration.parent.declarations[0] === variableDeclaration) { + return textSpan(findPrecedingToken(variableDeclaration.pos, sourceFile, variableDeclaration.parent), variableDeclaration); + } else { + return textSpan(variableDeclaration); } - newNodes.push(factory.createVariableStatement( - /*modifiers*/ - void 0, - factory.createVariableDeclarationList( - [factory.createVariableDeclaration( - factory.createObjectBindingPattern(bindingElements), - /*exclamationToken*/ - void 0, - /*type*/ - typeLiteral, - /*initializer*/ - call - )], - commonNodeFlags - ) - )); } - } else if (exposedVariableDeclarations.length || writes) { - if (exposedVariableDeclarations.length) { - for (const variableDeclaration of exposedVariableDeclarations) { - let flags = variableDeclaration.parent.flags; - if (flags & 2 /* Const */) { - flags = flags & ~2 /* Const */ | 1 /* Let */; - } - newNodes.push(factory.createVariableStatement( - /*modifiers*/ - void 0, - factory.createVariableDeclarationList( - [factory.createVariableDeclaration( - variableDeclaration.symbol.name, - /*exclamationToken*/ - void 0, - getTypeDeepCloneUnionUndefined(variableDeclaration.type) - )], - flags - ) - )); + function spanInVariableDeclaration(variableDeclaration) { + if (variableDeclaration.parent.parent.kind === 249 /* ForInStatement */) { + return spanInNode(variableDeclaration.parent.parent); + } + const parent2 = variableDeclaration.parent; + if (isBindingPattern(variableDeclaration.name)) { + return spanInBindingPattern(variableDeclaration.name); + } + if (hasOnlyExpressionInitializer(variableDeclaration) && variableDeclaration.initializer || hasSyntacticModifier(variableDeclaration, 32 /* Export */) || parent2.parent.kind === 250 /* ForOfStatement */) { + return textSpanFromVariableDeclaration(variableDeclaration); + } + if (isVariableDeclarationList(variableDeclaration.parent) && variableDeclaration.parent.declarations[0] !== variableDeclaration) { + return spanInNode(findPrecedingToken(variableDeclaration.pos, sourceFile, variableDeclaration.parent)); } } - if (returnValueProperty) { - newNodes.push(factory.createVariableStatement( - /*modifiers*/ - void 0, - factory.createVariableDeclarationList( - [factory.createVariableDeclaration( - returnValueProperty, - /*exclamationToken*/ - void 0, - getTypeDeepCloneUnionUndefined(returnType) - )], - 1 /* Let */ - ) - )); + function canHaveSpanInParameterDeclaration(parameter) { + return !!parameter.initializer || parameter.dotDotDotToken !== void 0 || hasSyntacticModifier(parameter, 1 /* Public */ | 2 /* Private */); } - const assignments = getPropertyAssignmentsForWritesAndVariableDeclarations(exposedVariableDeclarations, writes); - if (returnValueProperty) { - assignments.unshift(factory.createShorthandPropertyAssignment(returnValueProperty)); + function spanInParameterDeclaration(parameter) { + if (isBindingPattern(parameter.name)) { + return spanInBindingPattern(parameter.name); + } else if (canHaveSpanInParameterDeclaration(parameter)) { + return textSpan(parameter); + } else { + const functionDeclaration = parameter.parent; + const indexOfParameter = functionDeclaration.parameters.indexOf(parameter); + Debug.assert(indexOfParameter !== -1); + if (indexOfParameter !== 0) { + return spanInParameterDeclaration(functionDeclaration.parameters[indexOfParameter - 1]); + } else { + return spanInNode(functionDeclaration.body); + } + } } - if (assignments.length === 1) { - Debug.assert(!returnValueProperty, "Shouldn't have returnValueProperty here"); - newNodes.push(factory.createExpressionStatement(factory.createAssignment(assignments[0].name, call))); - if (range.facts & 1 /* HasReturn */) { - newNodes.push(factory.createReturnStatement()); + function canFunctionHaveSpanInWholeDeclaration(functionDeclaration) { + return hasSyntacticModifier(functionDeclaration, 32 /* Export */) || functionDeclaration.parent.kind === 263 /* ClassDeclaration */ && functionDeclaration.kind !== 176 /* Constructor */; + } + function spanInFunctionDeclaration(functionDeclaration) { + if (!functionDeclaration.body) { + return void 0; } - } else { - newNodes.push(factory.createExpressionStatement(factory.createAssignment(factory.createObjectLiteralExpression(assignments), call))); - if (returnValueProperty) { - newNodes.push(factory.createReturnStatement(factory.createIdentifier(returnValueProperty))); + if (canFunctionHaveSpanInWholeDeclaration(functionDeclaration)) { + return textSpan(functionDeclaration); } + return spanInNode(functionDeclaration.body); } - } else { - if (range.facts & 1 /* HasReturn */) { - newNodes.push(factory.createReturnStatement(call)); - } else if (isReadonlyArray(range.range)) { - newNodes.push(factory.createExpressionStatement(call)); - } else { - newNodes.push(call); - } - } - if (isReadonlyArray(range.range)) { - changeTracker.replaceNodeRangeWithNodes(context.file, first(range.range), last(range.range), newNodes); - } else { - changeTracker.replaceNodeWithNodes(context.file, range.range, newNodes); - } - const edits = changeTracker.getChanges(); - const renameRange = isReadonlyArray(range.range) ? first(range.range) : range.range; - const renameFilename = renameRange.getSourceFile().fileName; - const renameLocation = getRenameLocation( - edits, - renameFilename, - functionNameText, - /*preferLastLocation*/ - false - ); - return { renameFilename, renameLocation, edits }; - function getTypeDeepCloneUnionUndefined(typeNode) { - if (typeNode === void 0) { - return void 0; + function spanInFunctionBlock(block) { + const nodeForSpanInBlock = block.statements.length ? block.statements[0] : block.getLastToken(); + if (canFunctionHaveSpanInWholeDeclaration(block.parent)) { + return spanInNodeIfStartsOnSameLine(block.parent, nodeForSpanInBlock); + } + return spanInNode(nodeForSpanInBlock); } - const clone2 = getSynthesizedDeepClone(typeNode); - let withoutParens = clone2; - while (isParenthesizedTypeNode(withoutParens)) { - withoutParens = withoutParens.type; + function spanInBlock(block) { + switch (block.parent.kind) { + case 267 /* ModuleDeclaration */: + if (getModuleInstanceState(block.parent) !== 1 /* Instantiated */) { + return void 0; + } + case 247 /* WhileStatement */: + case 245 /* IfStatement */: + case 249 /* ForInStatement */: + return spanInNodeIfStartsOnSameLine(block.parent, block.statements[0]); + case 248 /* ForStatement */: + case 250 /* ForOfStatement */: + return spanInNodeIfStartsOnSameLine(findPrecedingToken(block.pos, sourceFile, block.parent), block.statements[0]); + } + return spanInNode(block.statements[0]); } - return isUnionTypeNode(withoutParens) && find(withoutParens.types, (t) => t.kind === 157 /* UndefinedKeyword */) ? clone2 : factory.createUnionTypeNode([clone2, factory.createKeywordTypeNode(157 /* UndefinedKeyword */)]); - } - } - function extractConstantInScope(node, scope, { substitutions }, rangeFacts, context) { - const checker = context.program.getTypeChecker(); - const file = scope.getSourceFile(); - const localNameText = isPropertyAccessExpression(node) && !isClassLike(scope) && !checker.resolveName( - node.name.text, - node, - 111551 /* Value */, - /*excludeGlobals*/ - false - ) && !isPrivateIdentifier(node.name) && !identifierToKeywordKind(node.name) ? node.name.text : getUniqueName(isClassLike(scope) ? "newProperty" : "newLocal", file); - const isJS = isInJSFile(scope); - let variableType = isJS || !checker.isContextSensitive(node) ? void 0 : checker.typeToTypeNode(checker.getContextualType(node), scope, 1 /* NoTruncation */); - let initializer = transformConstantInitializer(skipParentheses(node), substitutions); - ({ variableType, initializer } = transformFunctionInitializerAndType(variableType, initializer)); - suppressLeadingAndTrailingTrivia(initializer); - const changeTracker = ts_textChanges_exports.ChangeTracker.fromContext(context); - if (isClassLike(scope)) { - Debug.assert(!isJS, "Cannot extract to a JS class"); - const modifiers = []; - modifiers.push(factory.createModifier(123 /* PrivateKeyword */)); - if (rangeFacts & 32 /* InStaticRegion */) { - modifiers.push(factory.createModifier(126 /* StaticKeyword */)); + function spanInInitializerOfForLike(forLikeStatement) { + if (forLikeStatement.initializer.kind === 261 /* VariableDeclarationList */) { + const variableDeclarationList = forLikeStatement.initializer; + if (variableDeclarationList.declarations.length > 0) { + return spanInNode(variableDeclarationList.declarations[0]); + } + } else { + return spanInNode(forLikeStatement.initializer); + } } - modifiers.push(factory.createModifier(148 /* ReadonlyKeyword */)); - const newVariable = factory.createPropertyDeclaration( - modifiers, - localNameText, - /*questionOrExclamationToken*/ - void 0, - variableType, - initializer - ); - let localReference = factory.createPropertyAccessExpression( - rangeFacts & 32 /* InStaticRegion */ ? factory.createIdentifier(scope.name.getText()) : factory.createThis(), - factory.createIdentifier(localNameText) - ); - if (isInJSXContent(node)) { - localReference = factory.createJsxExpression( - /*dotDotDotToken*/ - void 0, - localReference - ); + function spanInForStatement(forStatement) { + if (forStatement.initializer) { + return spanInInitializerOfForLike(forStatement); + } + if (forStatement.condition) { + return textSpan(forStatement.condition); + } + if (forStatement.incrementor) { + return textSpan(forStatement.incrementor); + } } - const maxInsertionPos = node.pos; - const nodeToInsertBefore = getNodeToInsertPropertyBefore(maxInsertionPos, scope); - changeTracker.insertNodeBefore( - context.file, - nodeToInsertBefore, - newVariable, - /*blankLineBetween*/ - true - ); - changeTracker.replaceNode(context.file, node, localReference); - } else { - const newVariableDeclaration = factory.createVariableDeclaration( - localNameText, - /*exclamationToken*/ - void 0, - variableType, - initializer - ); - const oldVariableDeclaration = getContainingVariableDeclarationIfInList(node, scope); - if (oldVariableDeclaration) { - changeTracker.insertNodeBefore(context.file, oldVariableDeclaration, newVariableDeclaration); - const localReference = factory.createIdentifier(localNameText); - changeTracker.replaceNode(context.file, node, localReference); - } else if (node.parent.kind === 243 /* ExpressionStatement */ && scope === findAncestor(node, isScope)) { - const newVariableStatement = factory.createVariableStatement( - /*modifiers*/ - void 0, - factory.createVariableDeclarationList([newVariableDeclaration], 2 /* Const */) - ); - changeTracker.replaceNode(context.file, node.parent, newVariableStatement); - } else { - const newVariableStatement = factory.createVariableStatement( - /*modifiers*/ - void 0, - factory.createVariableDeclarationList([newVariableDeclaration], 2 /* Const */) - ); - const nodeToInsertBefore = getNodeToInsertConstantBefore(node, scope); - if (nodeToInsertBefore.pos === 0) { - changeTracker.insertNodeAtTopOfFile( - context.file, - newVariableStatement, - /*blankLineBetween*/ - false - ); - } else { - changeTracker.insertNodeBefore( - context.file, - nodeToInsertBefore, - newVariableStatement, - /*blankLineBetween*/ - false - ); + function spanInBindingPattern(bindingPattern) { + const firstBindingElement = forEach(bindingPattern.elements, (element) => element.kind !== 232 /* OmittedExpression */ ? element : void 0); + if (firstBindingElement) { + return spanInNode(firstBindingElement); } - if (node.parent.kind === 243 /* ExpressionStatement */) { - changeTracker.delete(context.file, node.parent); - } else { - let localReference = factory.createIdentifier(localNameText); - if (isInJSXContent(node)) { - localReference = factory.createJsxExpression( - /*dotDotDotToken*/ - void 0, - localReference - ); - } - changeTracker.replaceNode(context.file, node, localReference); + if (bindingPattern.parent.kind === 208 /* BindingElement */) { + return textSpan(bindingPattern.parent); } + return textSpanFromVariableDeclaration(bindingPattern.parent); } - } - const edits = changeTracker.getChanges(); - const renameFilename = node.getSourceFile().fileName; - const renameLocation = getRenameLocation( - edits, - renameFilename, - localNameText, - /*preferLastLocation*/ - true - ); - return { renameFilename, renameLocation, edits }; - function transformFunctionInitializerAndType(variableType2, initializer2) { - if (variableType2 === void 0) - return { variableType: variableType2, initializer: initializer2 }; - if (!isFunctionExpression(initializer2) && !isArrowFunction(initializer2) || !!initializer2.typeParameters) - return { variableType: variableType2, initializer: initializer2 }; - const functionType = checker.getTypeAtLocation(node); - const functionSignature = singleOrUndefined(checker.getSignaturesOfType(functionType, 0 /* Call */)); - if (!functionSignature) - return { variableType: variableType2, initializer: initializer2 }; - if (!!functionSignature.getTypeParameters()) - return { variableType: variableType2, initializer: initializer2 }; - const parameters = []; - let hasAny = false; - for (const p of initializer2.parameters) { - if (p.type) { - parameters.push(p); - } else { - const paramType = checker.getTypeAtLocation(p); - if (paramType === checker.getAnyType()) - hasAny = true; - parameters.push(factory.updateParameterDeclaration( - p, - p.modifiers, - p.dotDotDotToken, - p.name, - p.questionToken, - p.type || checker.typeToTypeNode(paramType, scope, 1 /* NoTruncation */), - p.initializer - )); + function spanInArrayLiteralOrObjectLiteralDestructuringPattern(node2) { + Debug.assert(node2.kind !== 207 /* ArrayBindingPattern */ && node2.kind !== 206 /* ObjectBindingPattern */); + const elements = node2.kind === 209 /* ArrayLiteralExpression */ ? node2.elements : node2.properties; + const firstBindingElement = forEach(elements, (element) => element.kind !== 232 /* OmittedExpression */ ? element : void 0); + if (firstBindingElement) { + return spanInNode(firstBindingElement); } + return textSpan(node2.parent.kind === 226 /* BinaryExpression */ ? node2.parent : node2); } - if (hasAny) - return { variableType: variableType2, initializer: initializer2 }; - variableType2 = void 0; - if (isArrowFunction(initializer2)) { - initializer2 = factory.updateArrowFunction( - initializer2, - canHaveModifiers(node) ? getModifiers(node) : void 0, - initializer2.typeParameters, - parameters, - initializer2.type || checker.typeToTypeNode(functionSignature.getReturnType(), scope, 1 /* NoTruncation */), - initializer2.equalsGreaterThanToken, - initializer2.body - ); - } else { - if (functionSignature && !!functionSignature.thisParameter) { - const firstParameter = firstOrUndefined(parameters); - if (!firstParameter || isIdentifier(firstParameter.name) && firstParameter.name.escapedText !== "this") { - const thisType = checker.getTypeOfSymbolAtLocation(functionSignature.thisParameter, node); - parameters.splice(0, 0, factory.createParameterDeclaration( - /*modifiers*/ - void 0, - /*dotDotDotToken*/ - void 0, - "this", - /*questionToken*/ - void 0, - checker.typeToTypeNode(thisType, scope, 1 /* NoTruncation */) - )); - } + function spanInOpenBraceToken(node2) { + switch (node2.parent.kind) { + case 266 /* EnumDeclaration */: + const enumDeclaration = node2.parent; + return spanInNodeIfStartsOnSameLine(findPrecedingToken(node2.pos, sourceFile, node2.parent), enumDeclaration.members.length ? enumDeclaration.members[0] : enumDeclaration.getLastToken(sourceFile)); + case 263 /* ClassDeclaration */: + const classDeclaration = node2.parent; + return spanInNodeIfStartsOnSameLine(findPrecedingToken(node2.pos, sourceFile, node2.parent), classDeclaration.members.length ? classDeclaration.members[0] : classDeclaration.getLastToken(sourceFile)); + case 269 /* CaseBlock */: + return spanInNodeIfStartsOnSameLine(node2.parent.parent, node2.parent.clauses[0]); } - initializer2 = factory.updateFunctionExpression( - initializer2, - canHaveModifiers(node) ? getModifiers(node) : void 0, - initializer2.asteriskToken, - initializer2.name, - initializer2.typeParameters, - parameters, - initializer2.type || checker.typeToTypeNode(functionSignature.getReturnType(), scope, 1 /* NoTruncation */), - initializer2.body - ); + return spanInNode(node2.parent); } - return { variableType: variableType2, initializer: initializer2 }; - } - } - function getContainingVariableDeclarationIfInList(node, scope) { - let prevNode; - while (node !== void 0 && node !== scope) { - if (isVariableDeclaration(node) && node.initializer === prevNode && isVariableDeclarationList(node.parent) && node.parent.declarations.length > 1) { - return node; + function spanInCloseBraceToken(node2) { + switch (node2.parent.kind) { + case 268 /* ModuleBlock */: + if (getModuleInstanceState(node2.parent.parent) !== 1 /* Instantiated */) { + return void 0; + } + case 266 /* EnumDeclaration */: + case 263 /* ClassDeclaration */: + return textSpan(node2); + case 241 /* Block */: + if (isFunctionBlock(node2.parent)) { + return textSpan(node2); + } + case 299 /* CatchClause */: + return spanInNode(lastOrUndefined(node2.parent.statements)); + case 269 /* CaseBlock */: + const caseBlock = node2.parent; + const lastClause = lastOrUndefined(caseBlock.clauses); + if (lastClause) { + return spanInNode(lastOrUndefined(lastClause.statements)); + } + return void 0; + case 206 /* ObjectBindingPattern */: + const bindingPattern = node2.parent; + return spanInNode(lastOrUndefined(bindingPattern.elements) || bindingPattern); + default: + if (isArrayLiteralOrObjectLiteralDestructuringPattern(node2.parent)) { + const objectLiteral = node2.parent; + return textSpan(lastOrUndefined(objectLiteral.properties) || objectLiteral); + } + return spanInNode(node2.parent); + } } - prevNode = node; - node = node.parent; - } - } - function getFirstDeclarationBeforePosition(type, position) { - let firstDeclaration; - const symbol = type.symbol; - if (symbol && symbol.declarations) { - for (const declaration of symbol.declarations) { - if ((firstDeclaration === void 0 || declaration.pos < firstDeclaration.pos) && declaration.pos < position) { - firstDeclaration = declaration; + function spanInCloseBracketToken(node2) { + switch (node2.parent.kind) { + case 207 /* ArrayBindingPattern */: + const bindingPattern = node2.parent; + return textSpan(lastOrUndefined(bindingPattern.elements) || bindingPattern); + default: + if (isArrayLiteralOrObjectLiteralDestructuringPattern(node2.parent)) { + const arrayLiteral = node2.parent; + return textSpan(lastOrUndefined(arrayLiteral.elements) || arrayLiteral); + } + return spanInNode(node2.parent); } } - } - return firstDeclaration; - } - function compareTypesByDeclarationOrder({ type: type1, declaration: declaration1 }, { type: type2, declaration: declaration2 }) { - return compareProperties(declaration1, declaration2, "pos", compareValues) || compareStringsCaseSensitive( - type1.symbol ? type1.symbol.getName() : "", - type2.symbol ? type2.symbol.getName() : "" - ) || compareValues(type1.id, type2.id); - } - function getCalledExpression(scope, range, functionNameText) { - const functionReference = factory.createIdentifier(functionNameText); - if (isClassLike(scope)) { - const lhs = range.facts & 32 /* InStaticRegion */ ? factory.createIdentifier(scope.name.text) : factory.createThis(); - return factory.createPropertyAccessExpression(lhs, functionReference); - } else { - return functionReference; - } - } - function transformFunctionBody(body, exposedVariableDeclarations, writes, substitutions, hasReturn2) { - const hasWritesOrVariableDeclarations = writes !== void 0 || exposedVariableDeclarations.length > 0; - if (isBlock(body) && !hasWritesOrVariableDeclarations && substitutions.size === 0) { - return { body: factory.createBlock( - body.statements, - /*multiLine*/ - true - ), returnValueProperty: void 0 }; - } - let returnValueProperty; - let ignoreReturns = false; - const statements = factory.createNodeArray(isBlock(body) ? body.statements.slice(0) : [isStatement(body) ? body : factory.createReturnStatement(skipParentheses(body))]); - if (hasWritesOrVariableDeclarations || substitutions.size) { - const rewrittenStatements = visitNodes2(statements, visitor, isStatement).slice(); - if (hasWritesOrVariableDeclarations && !hasReturn2 && isStatement(body)) { - const assignments = getPropertyAssignmentsForWritesAndVariableDeclarations(exposedVariableDeclarations, writes); - if (assignments.length === 1) { - rewrittenStatements.push(factory.createReturnStatement(assignments[0].name)); - } else { - rewrittenStatements.push(factory.createReturnStatement(factory.createObjectLiteralExpression(assignments))); + function spanInOpenParenToken(node2) { + if (node2.parent.kind === 246 /* DoStatement */ || // Go to while keyword and do action instead + node2.parent.kind === 213 /* CallExpression */ || node2.parent.kind === 214 /* NewExpression */) { + return spanInPreviousNode(node2); + } + if (node2.parent.kind === 217 /* ParenthesizedExpression */) { + return spanInNextNode(node2); } + return spanInNode(node2.parent); } - return { body: factory.createBlock( - rewrittenStatements, - /*multiLine*/ - true - ), returnValueProperty }; - } else { - return { body: factory.createBlock( - statements, - /*multiLine*/ - true - ), returnValueProperty: void 0 }; - } - function visitor(node) { - if (!ignoreReturns && isReturnStatement(node) && hasWritesOrVariableDeclarations) { - const assignments = getPropertyAssignmentsForWritesAndVariableDeclarations(exposedVariableDeclarations, writes); - if (node.expression) { - if (!returnValueProperty) { - returnValueProperty = "__return"; - } - assignments.unshift(factory.createPropertyAssignment(returnValueProperty, visitNode(node.expression, visitor, isExpression))); + function spanInCloseParenToken(node2) { + switch (node2.parent.kind) { + case 218 /* FunctionExpression */: + case 262 /* FunctionDeclaration */: + case 219 /* ArrowFunction */: + case 174 /* MethodDeclaration */: + case 173 /* MethodSignature */: + case 177 /* GetAccessor */: + case 178 /* SetAccessor */: + case 176 /* Constructor */: + case 247 /* WhileStatement */: + case 246 /* DoStatement */: + case 248 /* ForStatement */: + case 250 /* ForOfStatement */: + case 213 /* CallExpression */: + case 214 /* NewExpression */: + case 217 /* ParenthesizedExpression */: + return spanInPreviousNode(node2); + default: + return spanInNode(node2.parent); } - if (assignments.length === 1) { - return factory.createReturnStatement(assignments[0].name); - } else { - return factory.createReturnStatement(factory.createObjectLiteralExpression(assignments)); + } + function spanInColonToken(node2) { + if (isFunctionLike(node2.parent) || node2.parent.kind === 303 /* PropertyAssignment */ || node2.parent.kind === 169 /* Parameter */) { + return spanInPreviousNode(node2); } - } else { - const oldIgnoreReturns = ignoreReturns; - ignoreReturns = ignoreReturns || isFunctionLikeDeclaration(node) || isClassLike(node); - const substitution = substitutions.get(getNodeId(node).toString()); - const result = substitution ? getSynthesizedDeepClone(substitution) : visitEachChild(node, visitor, nullTransformationContext); - ignoreReturns = oldIgnoreReturns; - return result; + return spanInNode(node2.parent); } - } - } - function transformConstantInitializer(initializer, substitutions) { - return substitutions.size ? visitor(initializer) : initializer; - function visitor(node) { - const substitution = substitutions.get(getNodeId(node).toString()); - return substitution ? getSynthesizedDeepClone(substitution) : visitEachChild(node, visitor, nullTransformationContext); - } - } - function getStatementsOrClassElements(scope) { - if (isFunctionLikeDeclaration(scope)) { - const body = scope.body; - if (isBlock(body)) { - return body.statements; + function spanInGreaterThanOrLessThanToken(node2) { + if (node2.parent.kind === 216 /* TypeAssertionExpression */) { + return spanInNextNode(node2); + } + return spanInNode(node2.parent); } - } else if (isModuleBlock(scope) || isSourceFile(scope)) { - return scope.statements; - } else if (isClassLike(scope)) { - return scope.members; - } else { - assertType(scope); - } - return emptyArray; - } - function getNodeToInsertFunctionBefore(minPos, scope) { - return find(getStatementsOrClassElements(scope), (child) => child.pos >= minPos && isFunctionLikeDeclaration(child) && !isConstructorDeclaration(child)); - } - function getNodeToInsertPropertyBefore(maxPos, scope) { - const members = scope.members; - Debug.assert(members.length > 0, "Found no members"); - let prevMember; - let allProperties = true; - for (const member of members) { - if (member.pos > maxPos) { - return prevMember || members[0]; + function spanInWhileKeyword(node2) { + if (node2.parent.kind === 246 /* DoStatement */) { + return textSpanEndingAtNextToken(node2, node2.parent.expression); + } + return spanInNode(node2.parent); } - if (allProperties && !isPropertyDeclaration(member)) { - if (prevMember !== void 0) { - return member; + function spanInOfKeyword(node2) { + if (node2.parent.kind === 250 /* ForOfStatement */) { + return spanInNextNode(node2); } - allProperties = false; + return spanInNode(node2.parent); } - prevMember = member; } - if (prevMember === void 0) - return Debug.fail(); - return prevMember; } - function getNodeToInsertConstantBefore(node, scope) { - Debug.assert(!isClassLike(scope)); - let prevScope; - for (let curr = node; curr !== scope; curr = curr.parent) { - if (isScope(curr)) { - prevScope = curr; - } + var init_breakpoints = __esm({ + "src/services/breakpoints.ts"() { + "use strict"; + init_ts4(); } - for (let curr = (prevScope || node).parent; ; curr = curr.parent) { - if (isBlockLike(curr)) { - let prevStatement; - for (const statement of curr.statements) { - if (statement.pos > node.pos) { - break; - } - prevStatement = statement; - } - if (!prevStatement && isCaseClause(curr)) { - Debug.assert(isSwitchStatement(curr.parent.parent), "Grandparent isn't a switch statement"); - return curr.parent.parent; - } - return Debug.checkDefined(prevStatement, "prevStatement failed to get set"); - } - Debug.assert(curr !== scope, "Didn't encounter a block-like before encountering scope"); + }); + + // src/services/_namespaces/ts.BreakpointResolver.ts + var ts_BreakpointResolver_exports = {}; + __export(ts_BreakpointResolver_exports, { + spanInSourceFileAtLocation: () => spanInSourceFileAtLocation + }); + var init_ts_BreakpointResolver = __esm({ + "src/services/_namespaces/ts.BreakpointResolver.ts"() { + "use strict"; + init_breakpoints(); } + }); + + // src/services/callHierarchy.ts + function isNamedExpression(node) { + return (isFunctionExpression(node) || isClassExpression(node)) && isNamedDeclaration(node); } - function getPropertyAssignmentsForWritesAndVariableDeclarations(exposedVariableDeclarations, writes) { - const variableAssignments = map(exposedVariableDeclarations, (v) => factory.createShorthandPropertyAssignment(v.symbol.name)); - const writeAssignments = map(writes, (w) => factory.createShorthandPropertyAssignment(w.symbol.name)); - return variableAssignments === void 0 ? writeAssignments : writeAssignments === void 0 ? variableAssignments : variableAssignments.concat(writeAssignments); + function isConstNamedExpression(node) { + return (isFunctionExpression(node) || isArrowFunction(node) || isClassExpression(node)) && isVariableDeclaration(node.parent) && node === node.parent.initializer && isIdentifier(node.parent.name) && !!(getCombinedNodeFlags(node.parent) & 2 /* Const */); } - function isReadonlyArray(v) { - return isArray(v); + function isPossibleCallHierarchyDeclaration(node) { + return isSourceFile(node) || isModuleDeclaration(node) || isFunctionDeclaration(node) || isFunctionExpression(node) || isClassDeclaration(node) || isClassExpression(node) || isClassStaticBlockDeclaration(node) || isMethodDeclaration(node) || isMethodSignature(node) || isGetAccessorDeclaration(node) || isSetAccessorDeclaration(node); } - function getEnclosingTextRange(targetRange, sourceFile) { - return isReadonlyArray(targetRange.range) ? { pos: first(targetRange.range).getStart(sourceFile), end: last(targetRange.range).getEnd() } : targetRange.range; + function isValidCallHierarchyDeclaration(node) { + return isSourceFile(node) || isModuleDeclaration(node) && isIdentifier(node.name) || isFunctionDeclaration(node) || isClassDeclaration(node) || isClassStaticBlockDeclaration(node) || isMethodDeclaration(node) || isMethodSignature(node) || isGetAccessorDeclaration(node) || isSetAccessorDeclaration(node) || isNamedExpression(node) || isConstNamedExpression(node); } - function collectReadsAndWrites(targetRange, scopes, enclosingTextRange, sourceFile, checker, cancellationToken) { - const allTypeParameterUsages = /* @__PURE__ */ new Map(); - const usagesPerScope = []; - const substitutionsPerScope = []; - const functionErrorsPerScope = []; - const constantErrorsPerScope = []; - const visibleDeclarationsInExtractedRange = []; - const exposedVariableSymbolSet = /* @__PURE__ */ new Map(); - const exposedVariableDeclarations = []; - let firstExposedNonVariableDeclaration; - const expression = !isReadonlyArray(targetRange.range) ? targetRange.range : targetRange.range.length === 1 && isExpressionStatement(targetRange.range[0]) ? targetRange.range[0].expression : void 0; - let expressionDiagnostic; - if (expression === void 0) { - const statements = targetRange.range; - const start = first(statements).getStart(); - const end = last(statements).end; - expressionDiagnostic = createFileDiagnostic(sourceFile, start, end - start, Messages.expressionExpected); - } else if (checker.getTypeAtLocation(expression).flags & (16384 /* Void */ | 131072 /* Never */)) { - expressionDiagnostic = createDiagnosticForNode(expression, Messages.uselessConstantType); + function getCallHierarchyDeclarationReferenceNode(node) { + if (isSourceFile(node)) + return node; + if (isNamedDeclaration(node)) + return node.name; + if (isConstNamedExpression(node)) + return node.parent.name; + return Debug.checkDefined(node.modifiers && find(node.modifiers, isDefaultModifier3)); + } + function isDefaultModifier3(node) { + return node.kind === 90 /* DefaultKeyword */; + } + function getSymbolOfCallHierarchyDeclaration(typeChecker, node) { + const location = getCallHierarchyDeclarationReferenceNode(node); + return location && typeChecker.getSymbolAtLocation(location); + } + function getCallHierarchyItemName(program, node) { + if (isSourceFile(node)) { + return { text: node.fileName, pos: 0, end: 0 }; } - for (const scope of scopes) { - usagesPerScope.push({ usages: /* @__PURE__ */ new Map(), typeParameterUsages: /* @__PURE__ */ new Map(), substitutions: /* @__PURE__ */ new Map() }); - substitutionsPerScope.push(/* @__PURE__ */ new Map()); - functionErrorsPerScope.push([]); - const constantErrors = []; - if (expressionDiagnostic) { - constantErrors.push(expressionDiagnostic); - } - if (isClassLike(scope) && isInJSFile(scope)) { - constantErrors.push(createDiagnosticForNode(scope, Messages.cannotExtractToJSClass)); + if ((isFunctionDeclaration(node) || isClassDeclaration(node)) && !isNamedDeclaration(node)) { + const defaultModifier = node.modifiers && find(node.modifiers, isDefaultModifier3); + if (defaultModifier) { + return { text: "default", pos: defaultModifier.getStart(), end: defaultModifier.getEnd() }; } - if (isArrowFunction(scope) && !isBlock(scope.body)) { - constantErrors.push(createDiagnosticForNode(scope, Messages.cannotExtractToExpressionArrowFunction)); + } + if (isClassStaticBlockDeclaration(node)) { + const sourceFile = node.getSourceFile(); + const pos = skipTrivia(sourceFile.text, moveRangePastModifiers(node).pos); + const end = pos + 6; + const typeChecker = program.getTypeChecker(); + const symbol = typeChecker.getSymbolAtLocation(node.parent); + const prefix = symbol ? `${typeChecker.symbolToString(symbol, node.parent)} ` : ""; + return { text: `${prefix}static {}`, pos, end }; + } + const declName = isConstNamedExpression(node) ? node.parent.name : Debug.checkDefined(getNameOfDeclaration(node), "Expected call hierarchy item to have a name"); + let text = isIdentifier(declName) ? idText(declName) : isStringOrNumericLiteralLike(declName) ? declName.text : isComputedPropertyName(declName) ? isStringOrNumericLiteralLike(declName.expression) ? declName.expression.text : void 0 : void 0; + if (text === void 0) { + const typeChecker = program.getTypeChecker(); + const symbol = typeChecker.getSymbolAtLocation(declName); + if (symbol) { + text = typeChecker.symbolToString(symbol, node); } - constantErrorsPerScope.push(constantErrors); } - const seenUsages = /* @__PURE__ */ new Map(); - const target = isReadonlyArray(targetRange.range) ? factory.createBlock(targetRange.range) : targetRange.range; - const unmodifiedNode = isReadonlyArray(targetRange.range) ? first(targetRange.range) : targetRange.range; - const inGenericContext = isInGenericContext(unmodifiedNode); - collectUsages(target); - if (inGenericContext && !isReadonlyArray(targetRange.range) && !isJsxAttribute(targetRange.range)) { - const contextualType = checker.getContextualType(targetRange.range); - recordTypeParameterUsages(contextualType); + if (text === void 0) { + const printer = createPrinterWithRemoveCommentsOmitTrailingSemicolon(); + text = usingSingleLineStringWriter((writer) => printer.writeNode(4 /* Unspecified */, node, node.getSourceFile(), writer)); } - if (allTypeParameterUsages.size > 0) { - const seenTypeParameterUsages = /* @__PURE__ */ new Map(); - let i = 0; - for (let curr = unmodifiedNode; curr !== void 0 && i < scopes.length; curr = curr.parent) { - if (curr === scopes[i]) { - seenTypeParameterUsages.forEach((typeParameter, id) => { - usagesPerScope[i].typeParameterUsages.set(id, typeParameter); - }); - i++; + return { text, pos: declName.getStart(), end: declName.getEnd() }; + } + function getCallHierarchItemContainerName(node) { + var _a, _b; + if (isConstNamedExpression(node)) { + if (isModuleBlock(node.parent.parent.parent.parent) && isIdentifier(node.parent.parent.parent.parent.parent.name)) { + return node.parent.parent.parent.parent.parent.name.getText(); + } + return; + } + switch (node.kind) { + case 177 /* GetAccessor */: + case 178 /* SetAccessor */: + case 174 /* MethodDeclaration */: + if (node.parent.kind === 210 /* ObjectLiteralExpression */) { + return (_a = getAssignedName(node.parent)) == null ? void 0 : _a.getText(); } - if (isDeclarationWithTypeParameters(curr)) { - for (const typeParameterDecl of getEffectiveTypeParameterDeclarations(curr)) { - const typeParameter = checker.getTypeAtLocation(typeParameterDecl); - if (allTypeParameterUsages.has(typeParameter.id.toString())) { - seenTypeParameterUsages.set(typeParameter.id.toString(), typeParameter); - } - } + return (_b = getNameOfDeclaration(node.parent)) == null ? void 0 : _b.getText(); + case 262 /* FunctionDeclaration */: + case 263 /* ClassDeclaration */: + case 267 /* ModuleDeclaration */: + if (isModuleBlock(node.parent) && isIdentifier(node.parent.parent.name)) { + return node.parent.parent.name.getText(); } - } - Debug.assert(i === scopes.length, "Should have iterated all scopes"); } - if (visibleDeclarationsInExtractedRange.length) { - const containingLexicalScopeOfExtraction = isBlockScope(scopes[0], scopes[0].parent) ? scopes[0] : getEnclosingBlockScopeContainer(scopes[0]); - forEachChild(containingLexicalScopeOfExtraction, checkForUsedDeclarations); + } + function findImplementation(typeChecker, node) { + if (node.body) { + return node; } - for (let i = 0; i < scopes.length; i++) { - const scopeUsages = usagesPerScope[i]; - if (i > 0 && (scopeUsages.usages.size > 0 || scopeUsages.typeParameterUsages.size > 0)) { - const errorNode = isReadonlyArray(targetRange.range) ? targetRange.range[0] : targetRange.range; - constantErrorsPerScope[i].push(createDiagnosticForNode(errorNode, Messages.cannotAccessVariablesFromNestedScopes)); - } - if (targetRange.facts & 16 /* UsesThisInFunction */ && isClassLike(scopes[i])) { - functionErrorsPerScope[i].push(createDiagnosticForNode(targetRange.thisNode, Messages.cannotExtractFunctionsContainingThisToMethod)); + if (isConstructorDeclaration(node)) { + return getFirstConstructorWithBody(node.parent); + } + if (isFunctionDeclaration(node) || isMethodDeclaration(node)) { + const symbol = getSymbolOfCallHierarchyDeclaration(typeChecker, node); + if (symbol && symbol.valueDeclaration && isFunctionLikeDeclaration(symbol.valueDeclaration) && symbol.valueDeclaration.body) { + return symbol.valueDeclaration; } - let hasWrite = false; - let readonlyClassPropertyWrite; - usagesPerScope[i].usages.forEach((value) => { - if (value.usage === 2 /* Write */) { - hasWrite = true; - if (value.symbol.flags & 106500 /* ClassMember */ && value.symbol.valueDeclaration && hasEffectiveModifier(value.symbol.valueDeclaration, 64 /* Readonly */)) { - readonlyClassPropertyWrite = value.symbol.valueDeclaration; + return void 0; + } + return node; + } + function findAllInitialDeclarations(typeChecker, node) { + const symbol = getSymbolOfCallHierarchyDeclaration(typeChecker, node); + let declarations; + if (symbol && symbol.declarations) { + const indices = indicesOf(symbol.declarations); + const keys = map(symbol.declarations, (decl) => ({ file: decl.getSourceFile().fileName, pos: decl.pos })); + indices.sort((a, b) => compareStringsCaseSensitive(keys[a].file, keys[b].file) || keys[a].pos - keys[b].pos); + const sortedDeclarations = map(indices, (i) => symbol.declarations[i]); + let lastDecl; + for (const decl of sortedDeclarations) { + if (isValidCallHierarchyDeclaration(decl)) { + if (!lastDecl || lastDecl.parent !== decl.parent || lastDecl.end !== decl.pos) { + declarations = append(declarations, decl); } + lastDecl = decl; } - }); - Debug.assert(isReadonlyArray(targetRange.range) || exposedVariableDeclarations.length === 0, "No variable declarations expected if something was extracted"); - if (hasWrite && !isReadonlyArray(targetRange.range)) { - const diag2 = createDiagnosticForNode(targetRange.range, Messages.cannotWriteInExpression); - functionErrorsPerScope[i].push(diag2); - constantErrorsPerScope[i].push(diag2); - } else if (readonlyClassPropertyWrite && i > 0) { - const diag2 = createDiagnosticForNode(readonlyClassPropertyWrite, Messages.cannotExtractReadonlyPropertyInitializerOutsideConstructor); - functionErrorsPerScope[i].push(diag2); - constantErrorsPerScope[i].push(diag2); - } else if (firstExposedNonVariableDeclaration) { - const diag2 = createDiagnosticForNode(firstExposedNonVariableDeclaration, Messages.cannotExtractExportedEntity); - functionErrorsPerScope[i].push(diag2); - constantErrorsPerScope[i].push(diag2); } } - return { target, usagesPerScope, functionErrorsPerScope, constantErrorsPerScope, exposedVariableDeclarations }; - function isInGenericContext(node) { - return !!findAncestor(node, (n) => isDeclarationWithTypeParameters(n) && getEffectiveTypeParameterDeclarations(n).length !== 0); + return declarations; + } + function findImplementationOrAllInitialDeclarations(typeChecker, node) { + if (isClassStaticBlockDeclaration(node)) { + return node; } - function recordTypeParameterUsages(type) { - const symbolWalker = checker.getSymbolWalker(() => (cancellationToken.throwIfCancellationRequested(), true)); - const { visitedTypes } = symbolWalker.walkType(type); - for (const visitedType of visitedTypes) { - if (visitedType.isTypeParameter()) { - allTypeParameterUsages.set(visitedType.id.toString(), visitedType); - } - } + if (isFunctionLikeDeclaration(node)) { + return findImplementation(typeChecker, node) ?? findAllInitialDeclarations(typeChecker, node) ?? node; } - function collectUsages(node, valueUsage = 1 /* Read */) { - if (inGenericContext) { - const type = checker.getTypeAtLocation(node); - recordTypeParameterUsages(type); + return findAllInitialDeclarations(typeChecker, node) ?? node; + } + function resolveCallHierarchyDeclaration(program, location) { + const typeChecker = program.getTypeChecker(); + let followingSymbol = false; + while (true) { + if (isValidCallHierarchyDeclaration(location)) { + return findImplementationOrAllInitialDeclarations(typeChecker, location); } - if (isDeclaration(node) && node.symbol) { - visibleDeclarationsInExtractedRange.push(node); + if (isPossibleCallHierarchyDeclaration(location)) { + const ancestor = findAncestor(location, isValidCallHierarchyDeclaration); + return ancestor && findImplementationOrAllInitialDeclarations(typeChecker, ancestor); } - if (isAssignmentExpression(node)) { - collectUsages(node.left, 2 /* Write */); - collectUsages(node.right); - } else if (isUnaryExpressionWithWrite(node)) { - collectUsages(node.operand, 2 /* Write */); - } else if (isPropertyAccessExpression(node) || isElementAccessExpression(node)) { - forEachChild(node, collectUsages); - } else if (isIdentifier(node)) { - if (!node.parent) { - return; + if (isDeclarationName(location)) { + if (isValidCallHierarchyDeclaration(location.parent)) { + return findImplementationOrAllInitialDeclarations(typeChecker, location.parent); } - if (isQualifiedName(node.parent) && node !== node.parent.left) { - return; + if (isPossibleCallHierarchyDeclaration(location.parent)) { + const ancestor = findAncestor(location.parent, isValidCallHierarchyDeclaration); + return ancestor && findImplementationOrAllInitialDeclarations(typeChecker, ancestor); } - if (isPropertyAccessExpression(node.parent) && node !== node.parent.expression) { - return; + if (isVariableDeclaration(location.parent) && location.parent.initializer && isConstNamedExpression(location.parent.initializer)) { + return location.parent.initializer; } - recordUsage( - node, - valueUsage, - /*isTypeNode*/ - isPartOfTypeNode(node) - ); - } else { - forEachChild(node, collectUsages); + return void 0; } - } - function recordUsage(n, usage, isTypeNode2) { - const symbolId = recordUsagebySymbol(n, usage, isTypeNode2); - if (symbolId) { - for (let i = 0; i < scopes.length; i++) { - const substitution = substitutionsPerScope[i].get(symbolId); - if (substitution) { - usagesPerScope[i].substitutions.set(getNodeId(n).toString(), substitution); - } + if (isConstructorDeclaration(location)) { + if (isValidCallHierarchyDeclaration(location.parent)) { + return location.parent; } - } - } - function recordUsagebySymbol(identifier, usage, isTypeName) { - const symbol = getSymbolReferencedByIdentifier(identifier); - if (!symbol) { return void 0; } - const symbolId = getSymbolId(symbol).toString(); - const lastUsage = seenUsages.get(symbolId); - if (lastUsage && lastUsage >= usage) { - return symbolId; + if (location.kind === 126 /* StaticKeyword */ && isClassStaticBlockDeclaration(location.parent)) { + location = location.parent; + continue; } - seenUsages.set(symbolId, usage); - if (lastUsage) { - for (const perScope of usagesPerScope) { - const prevEntry = perScope.usages.get(identifier.text); - if (prevEntry) { - perScope.usages.set(identifier.text, { usage, symbol, node: identifier }); + if (isVariableDeclaration(location) && location.initializer && isConstNamedExpression(location.initializer)) { + return location.initializer; + } + if (!followingSymbol) { + let symbol = typeChecker.getSymbolAtLocation(location); + if (symbol) { + if (symbol.flags & 2097152 /* Alias */) { + symbol = typeChecker.getAliasedSymbol(symbol); + } + if (symbol.valueDeclaration) { + followingSymbol = true; + location = symbol.valueDeclaration; + continue; } } - return symbolId; - } - const decls = symbol.getDeclarations(); - const declInFile = decls && find(decls, (d) => d.getSourceFile() === sourceFile); - if (!declInFile) { - return void 0; - } - if (rangeContainsStartEnd(enclosingTextRange, declInFile.getStart(), declInFile.end)) { - return void 0; } - if (targetRange.facts & 2 /* IsGenerator */ && usage === 2 /* Write */) { - const diag2 = createDiagnosticForNode(identifier, Messages.cannotExtractRangeThatContainsWritesToReferencesLocatedOutsideOfTheTargetRangeInGenerators); - for (const errors of functionErrorsPerScope) { - errors.push(diag2); - } - for (const errors of constantErrorsPerScope) { - errors.push(diag2); - } + return void 0; + } + } + function createCallHierarchyItem(program, node) { + const sourceFile = node.getSourceFile(); + const name = getCallHierarchyItemName(program, node); + const containerName = getCallHierarchItemContainerName(node); + const kind = getNodeKind(node); + const kindModifiers = getNodeModifiers(node); + const span = createTextSpanFromBounds(skipTrivia( + sourceFile.text, + node.getFullStart(), + /*stopAfterLineBreak*/ + false, + /*stopAtComments*/ + true + ), node.getEnd()); + const selectionSpan = createTextSpanFromBounds(name.pos, name.end); + return { file: sourceFile.fileName, kind, kindModifiers, name: name.text, containerName, span, selectionSpan }; + } + function isDefined(x) { + return x !== void 0; + } + function convertEntryToCallSite(entry) { + if (entry.kind === ts_FindAllReferences_exports.EntryKind.Node) { + const { node } = entry; + if (isCallOrNewExpressionTarget( + node, + /*includeElementAccess*/ + true, + /*skipPastOuterExpressions*/ + true + ) || isTaggedTemplateTag( + node, + /*includeElementAccess*/ + true, + /*skipPastOuterExpressions*/ + true + ) || isDecoratorTarget( + node, + /*includeElementAccess*/ + true, + /*skipPastOuterExpressions*/ + true + ) || isJsxOpeningLikeElementTagName( + node, + /*includeElementAccess*/ + true, + /*skipPastOuterExpressions*/ + true + ) || isRightSideOfPropertyAccess(node) || isArgumentExpressionOfElementAccess(node)) { + const sourceFile = node.getSourceFile(); + const ancestor = findAncestor(node, isValidCallHierarchyDeclaration) || sourceFile; + return { declaration: ancestor, range: createTextRangeFromNode(node, sourceFile) }; } - for (let i = 0; i < scopes.length; i++) { - const scope = scopes[i]; - const resolvedSymbol = checker.resolveName( - symbol.name, - scope, - symbol.flags, - /*excludeGlobals*/ - false - ); - if (resolvedSymbol === symbol) { - continue; - } - if (!substitutionsPerScope[i].has(symbolId)) { - const substitution = tryReplaceWithQualifiedNameOrPropertyAccess(symbol.exportSymbol || symbol, scope, isTypeName); - if (substitution) { - substitutionsPerScope[i].set(symbolId, substitution); - } else if (isTypeName) { - if (!(symbol.flags & 262144 /* TypeParameter */)) { - const diag2 = createDiagnosticForNode(identifier, Messages.typeWillNotBeVisibleInTheNewScope); - functionErrorsPerScope[i].push(diag2); - constantErrorsPerScope[i].push(diag2); - } - } else { - usagesPerScope[i].usages.set(identifier.text, { usage, symbol, node: identifier }); + } + } + function getCallSiteGroupKey(entry) { + return getNodeId(entry.declaration); + } + function createCallHierarchyIncomingCall(from, fromSpans) { + return { from, fromSpans }; + } + function convertCallSiteGroupToIncomingCall(program, entries) { + return createCallHierarchyIncomingCall(createCallHierarchyItem(program, entries[0].declaration), map(entries, (entry) => createTextSpanFromRange(entry.range))); + } + function getIncomingCalls(program, declaration, cancellationToken) { + if (isSourceFile(declaration) || isModuleDeclaration(declaration) || isClassStaticBlockDeclaration(declaration)) { + return []; + } + const location = getCallHierarchyDeclarationReferenceNode(declaration); + const calls = filter(ts_FindAllReferences_exports.findReferenceOrRenameEntries( + program, + cancellationToken, + program.getSourceFiles(), + location, + /*position*/ + 0, + { use: ts_FindAllReferences_exports.FindReferencesUse.References }, + convertEntryToCallSite + ), isDefined); + return calls ? group(calls, getCallSiteGroupKey, (entries) => convertCallSiteGroupToIncomingCall(program, entries)) : []; + } + function createCallSiteCollector(program, callSites) { + function recordCallSite(node) { + const target = isTaggedTemplateExpression(node) ? node.tag : isJsxOpeningLikeElement(node) ? node.tagName : isAccessExpression(node) ? node : isClassStaticBlockDeclaration(node) ? node : node.expression; + const declaration = resolveCallHierarchyDeclaration(program, target); + if (declaration) { + const range = createTextRangeFromNode(target, node.getSourceFile()); + if (isArray(declaration)) { + for (const decl of declaration) { + callSites.push({ declaration: decl, range }); } + } else { + callSites.push({ declaration, range }); } } - return symbolId; } - function checkForUsedDeclarations(node) { - if (node === targetRange.range || isReadonlyArray(targetRange.range) && targetRange.range.indexOf(node) >= 0) { + function collect(node) { + if (!node) + return; + if (node.flags & 33554432 /* Ambient */) { return; } - const sym = isIdentifier(node) ? getSymbolReferencedByIdentifier(node) : checker.getSymbolAtLocation(node); - if (sym) { - const decl = find(visibleDeclarationsInExtractedRange, (d) => d.symbol === sym); - if (decl) { - if (isVariableDeclaration(decl)) { - const idString = decl.symbol.id.toString(); - if (!exposedVariableSymbolSet.has(idString)) { - exposedVariableDeclarations.push(decl); - exposedVariableSymbolSet.set(idString, true); + if (isValidCallHierarchyDeclaration(node)) { + if (isClassLike(node)) { + for (const member of node.members) { + if (member.name && isComputedPropertyName(member.name)) { + collect(member.name.expression); } - } else { - firstExposedNonVariableDeclaration = firstExposedNonVariableDeclaration || decl; } } + return; } - forEachChild(node, checkForUsedDeclarations); - } - function getSymbolReferencedByIdentifier(identifier) { - return identifier.parent && isShorthandPropertyAssignment(identifier.parent) && identifier.parent.name === identifier ? checker.getShorthandAssignmentValueSymbol(identifier.parent) : checker.getSymbolAtLocation(identifier); - } - function tryReplaceWithQualifiedNameOrPropertyAccess(symbol, scopeDecl, isTypeNode2) { - if (!symbol) { - return void 0; - } - const decls = symbol.getDeclarations(); - if (decls && decls.some((d) => d.parent === scopeDecl)) { - return factory.createIdentifier(symbol.name); + switch (node.kind) { + case 80 /* Identifier */: + case 271 /* ImportEqualsDeclaration */: + case 272 /* ImportDeclaration */: + case 278 /* ExportDeclaration */: + case 264 /* InterfaceDeclaration */: + case 265 /* TypeAliasDeclaration */: + return; + case 175 /* ClassStaticBlockDeclaration */: + recordCallSite(node); + return; + case 216 /* TypeAssertionExpression */: + case 234 /* AsExpression */: + collect(node.expression); + return; + case 260 /* VariableDeclaration */: + case 169 /* Parameter */: + collect(node.name); + collect(node.initializer); + return; + case 213 /* CallExpression */: + recordCallSite(node); + collect(node.expression); + forEach(node.arguments, collect); + return; + case 214 /* NewExpression */: + recordCallSite(node); + collect(node.expression); + forEach(node.arguments, collect); + return; + case 215 /* TaggedTemplateExpression */: + recordCallSite(node); + collect(node.tag); + collect(node.template); + return; + case 286 /* JsxOpeningElement */: + case 285 /* JsxSelfClosingElement */: + recordCallSite(node); + collect(node.tagName); + collect(node.attributes); + return; + case 170 /* Decorator */: + recordCallSite(node); + collect(node.expression); + return; + case 211 /* PropertyAccessExpression */: + case 212 /* ElementAccessExpression */: + recordCallSite(node); + forEachChild(node, collect); + break; + case 238 /* SatisfiesExpression */: + collect(node.expression); + return; } - const prefix = tryReplaceWithQualifiedNameOrPropertyAccess(symbol.parent, scopeDecl, isTypeNode2); - if (prefix === void 0) { - return void 0; + if (isPartOfTypeNode(node)) { + return; } - return isTypeNode2 ? factory.createQualifiedName(prefix, factory.createIdentifier(symbol.name)) : factory.createPropertyAccessExpression(prefix, symbol.name); + forEachChild(node, collect); } + return collect; } - function getExtractableParent(node) { - return findAncestor(node, (node2) => node2.parent && isExtractableExpression(node2) && !isBinaryExpression(node2.parent)); + function collectCallSitesOfSourceFile(node, collect) { + forEach(node.statements, collect); } - function isExtractableExpression(node) { - const { parent: parent2 } = node; - switch (parent2.kind) { - case 305 /* EnumMember */: - return false; + function collectCallSitesOfModuleDeclaration(node, collect) { + if (!hasSyntacticModifier(node, 128 /* Ambient */) && node.body && isModuleBlock(node.body)) { + forEach(node.body.statements, collect); } - switch (node.kind) { - case 11 /* StringLiteral */: - return parent2.kind !== 271 /* ImportDeclaration */ && parent2.kind !== 275 /* ImportSpecifier */; - case 229 /* SpreadElement */: - case 205 /* ObjectBindingPattern */: - case 207 /* BindingElement */: - return false; - case 80 /* Identifier */: - return parent2.kind !== 207 /* BindingElement */ && parent2.kind !== 275 /* ImportSpecifier */ && parent2.kind !== 280 /* ExportSpecifier */; + } + function collectCallSitesOfFunctionLikeDeclaration(typeChecker, node, collect) { + const implementation = findImplementation(typeChecker, node); + if (implementation) { + forEach(implementation.parameters, collect); + collect(implementation.body); } - return true; } - function isBlockLike(node) { + function collectCallSitesOfClassStaticBlockDeclaration(node, collect) { + collect(node.body); + } + function collectCallSitesOfClassLikeDeclaration(node, collect) { + forEach(node.modifiers, collect); + const heritage = getClassExtendsHeritageElement(node); + if (heritage) { + collect(heritage.expression); + } + for (const member of node.members) { + if (canHaveModifiers(member)) { + forEach(member.modifiers, collect); + } + if (isPropertyDeclaration(member)) { + collect(member.initializer); + } else if (isConstructorDeclaration(member) && member.body) { + forEach(member.parameters, collect); + collect(member.body); + } else if (isClassStaticBlockDeclaration(member)) { + collect(member); + } + } + } + function collectCallSites(program, node) { + const callSites = []; + const collect = createCallSiteCollector(program, callSites); switch (node.kind) { - case 240 /* Block */: - case 311 /* SourceFile */: - case 267 /* ModuleBlock */: - case 295 /* CaseClause */: - return true; + case 312 /* SourceFile */: + collectCallSitesOfSourceFile(node, collect); + break; + case 267 /* ModuleDeclaration */: + collectCallSitesOfModuleDeclaration(node, collect); + break; + case 262 /* FunctionDeclaration */: + case 218 /* FunctionExpression */: + case 219 /* ArrowFunction */: + case 174 /* MethodDeclaration */: + case 177 /* GetAccessor */: + case 178 /* SetAccessor */: + collectCallSitesOfFunctionLikeDeclaration(program.getTypeChecker(), node, collect); + break; + case 263 /* ClassDeclaration */: + case 231 /* ClassExpression */: + collectCallSitesOfClassLikeDeclaration(node, collect); + break; + case 175 /* ClassStaticBlockDeclaration */: + collectCallSitesOfClassStaticBlockDeclaration(node, collect); + break; default: - return false; + Debug.assertNever(node); } + return callSites; } - function isInJSXContent(node) { - return isStringLiteralJsxAttribute(node) || (isJsxElement(node) || isJsxSelfClosingElement(node) || isJsxFragment(node)) && (isJsxElement(node.parent) || isJsxFragment(node.parent)); + function createCallHierarchyOutgoingCall(to, fromSpans) { + return { to, fromSpans }; } - function isStringLiteralJsxAttribute(node) { - return isStringLiteral(node) && node.parent && isJsxAttribute(node.parent); + function convertCallSiteGroupToOutgoingCall(program, entries) { + return createCallHierarchyOutgoingCall(createCallHierarchyItem(program, entries[0].declaration), map(entries, (entry) => createTextSpanFromRange(entry.range))); } - var refactorName11, extractConstantAction, extractFunctionAction, Messages, RangeFacts; - var init_extractSymbol = __esm({ - "src/services/refactors/extractSymbol.ts"() { + function getOutgoingCalls(program, declaration) { + if (declaration.flags & 33554432 /* Ambient */ || isMethodSignature(declaration)) { + return []; + } + return group(collectCallSites(program, declaration), getCallSiteGroupKey, (entries) => convertCallSiteGroupToOutgoingCall(program, entries)); + } + var init_callHierarchy = __esm({ + "src/services/callHierarchy.ts"() { "use strict"; init_ts4(); - init_ts_refactor(); - refactorName11 = "Extract Symbol"; - extractConstantAction = { - name: "Extract Constant", - description: getLocaleSpecificMessage(Diagnostics.Extract_constant), - kind: "refactor.extract.constant" - }; - extractFunctionAction = { - name: "Extract Function", - description: getLocaleSpecificMessage(Diagnostics.Extract_function), - kind: "refactor.extract.function" - }; - registerRefactor(refactorName11, { - kinds: [ - extractConstantAction.kind, - extractFunctionAction.kind - ], - getEditsForAction: getRefactorEditsToExtractSymbol, - getAvailableActions: getRefactorActionsToExtractSymbol - }); - ((Messages2) => { - function createMessage(message) { - return { message, code: 0, category: 3 /* Message */, key: message }; - } - Messages2.cannotExtractRange = createMessage("Cannot extract range."); - Messages2.cannotExtractImport = createMessage("Cannot extract import statement."); - Messages2.cannotExtractSuper = createMessage("Cannot extract super call."); - Messages2.cannotExtractJSDoc = createMessage("Cannot extract JSDoc."); - Messages2.cannotExtractEmpty = createMessage("Cannot extract empty range."); - Messages2.expressionExpected = createMessage("expression expected."); - Messages2.uselessConstantType = createMessage("No reason to extract constant of type."); - Messages2.statementOrExpressionExpected = createMessage("Statement or expression expected."); - Messages2.cannotExtractRangeContainingConditionalBreakOrContinueStatements = createMessage("Cannot extract range containing conditional break or continue statements."); - Messages2.cannotExtractRangeContainingConditionalReturnStatement = createMessage("Cannot extract range containing conditional return statement."); - Messages2.cannotExtractRangeContainingLabeledBreakOrContinueStatementWithTargetOutsideOfTheRange = createMessage("Cannot extract range containing labeled break or continue with target outside of the range."); - Messages2.cannotExtractRangeThatContainsWritesToReferencesLocatedOutsideOfTheTargetRangeInGenerators = createMessage("Cannot extract range containing writes to references located outside of the target range in generators."); - Messages2.typeWillNotBeVisibleInTheNewScope = createMessage("Type will not visible in the new scope."); - Messages2.functionWillNotBeVisibleInTheNewScope = createMessage("Function will not visible in the new scope."); - Messages2.cannotExtractIdentifier = createMessage("Select more than a single identifier."); - Messages2.cannotExtractExportedEntity = createMessage("Cannot extract exported declaration"); - Messages2.cannotWriteInExpression = createMessage("Cannot write back side-effects when extracting an expression"); - Messages2.cannotExtractReadonlyPropertyInitializerOutsideConstructor = createMessage("Cannot move initialization of read-only class property outside of the constructor"); - Messages2.cannotExtractAmbientBlock = createMessage("Cannot extract code from ambient contexts"); - Messages2.cannotAccessVariablesFromNestedScopes = createMessage("Cannot access variables from nested scopes"); - Messages2.cannotExtractToJSClass = createMessage("Cannot extract constant to a class scope in JS"); - Messages2.cannotExtractToExpressionArrowFunction = createMessage("Cannot extract constant to an arrow function without a block"); - Messages2.cannotExtractFunctionsContainingThisToMethod = createMessage("Cannot extract functions containing this to method"); - })(Messages || (Messages = {})); - RangeFacts = /* @__PURE__ */ ((RangeFacts2) => { - RangeFacts2[RangeFacts2["None"] = 0] = "None"; - RangeFacts2[RangeFacts2["HasReturn"] = 1] = "HasReturn"; - RangeFacts2[RangeFacts2["IsGenerator"] = 2] = "IsGenerator"; - RangeFacts2[RangeFacts2["IsAsyncFunction"] = 4] = "IsAsyncFunction"; - RangeFacts2[RangeFacts2["UsesThis"] = 8] = "UsesThis"; - RangeFacts2[RangeFacts2["UsesThisInFunction"] = 16] = "UsesThisInFunction"; - RangeFacts2[RangeFacts2["InStaticRegion"] = 32] = "InStaticRegion"; - return RangeFacts2; - })(RangeFacts || {}); } }); - // src/services/_namespaces/ts.refactor.extractSymbol.ts - var ts_refactor_extractSymbol_exports = {}; - __export(ts_refactor_extractSymbol_exports, { - Messages: () => Messages, - RangeFacts: () => RangeFacts, - getRangeToExtract: () => getRangeToExtract2, - getRefactorActionsToExtractSymbol: () => getRefactorActionsToExtractSymbol, - getRefactorEditsToExtractSymbol: () => getRefactorEditsToExtractSymbol + // src/services/_namespaces/ts.CallHierarchy.ts + var ts_CallHierarchy_exports = {}; + __export(ts_CallHierarchy_exports, { + createCallHierarchyItem: () => createCallHierarchyItem, + getIncomingCalls: () => getIncomingCalls, + getOutgoingCalls: () => getOutgoingCalls, + resolveCallHierarchyDeclaration: () => resolveCallHierarchyDeclaration }); - var init_ts_refactor_extractSymbol = __esm({ - "src/services/_namespaces/ts.refactor.extractSymbol.ts"() { + var init_ts_CallHierarchy = __esm({ + "src/services/_namespaces/ts.CallHierarchy.ts"() { "use strict"; - init_extractSymbol(); + init_callHierarchy(); } }); - // src/services/refactors/generateGetAccessorAndSetAccessor.ts - var actionName, actionDescription, generateGetSetAction; - var init_generateGetAccessorAndSetAccessor = __esm({ - "src/services/refactors/generateGetAccessorAndSetAccessor.ts"() { + // src/services/_namespaces/ts.classifier.v2020.ts + var ts_classifier_v2020_exports = {}; + __export(ts_classifier_v2020_exports, { + TokenEncodingConsts: () => TokenEncodingConsts, + TokenModifier: () => TokenModifier, + TokenType: () => TokenType, + getEncodedSemanticClassifications: () => getEncodedSemanticClassifications2, + getSemanticClassifications: () => getSemanticClassifications2 + }); + var init_ts_classifier_v2020 = __esm({ + "src/services/_namespaces/ts.classifier.v2020.ts"() { + "use strict"; + init_classifier2020(); + } + }); + + // src/services/_namespaces/ts.classifier.ts + var ts_classifier_exports = {}; + __export(ts_classifier_exports, { + v2020: () => ts_classifier_v2020_exports + }); + var init_ts_classifier = __esm({ + "src/services/_namespaces/ts.classifier.ts"() { + "use strict"; + init_ts_classifier_v2020(); + } + }); + + // src/services/codeFixProvider.ts + function createCodeFixActionWithoutFixAll(fixName8, changes, description3) { + return createCodeFixActionWorker( + fixName8, + diagnosticToString(description3), + changes, + /*fixId*/ + void 0, + /*fixAllDescription*/ + void 0 + ); + } + function createCodeFixAction(fixName8, changes, description3, fixId52, fixAllDescription, command) { + return createCodeFixActionWorker(fixName8, diagnosticToString(description3), changes, fixId52, diagnosticToString(fixAllDescription), command); + } + function createCodeFixActionMaybeFixAll(fixName8, changes, description3, fixId52, fixAllDescription, command) { + return createCodeFixActionWorker(fixName8, diagnosticToString(description3), changes, fixId52, fixAllDescription && diagnosticToString(fixAllDescription), command); + } + function createCodeFixActionWorker(fixName8, description3, changes, fixId52, fixAllDescription, command) { + return { fixName: fixName8, description: description3, changes, fixId: fixId52, fixAllDescription, commands: command ? [command] : void 0 }; + } + function registerCodeFix(reg) { + for (const error2 of reg.errorCodes) { + errorCodeToFixesArray = void 0; + errorCodeToFixes.add(String(error2), reg); + } + if (reg.fixIds) { + for (const fixId52 of reg.fixIds) { + Debug.assert(!fixIdToRegistration.has(fixId52)); + fixIdToRegistration.set(fixId52, reg); + } + } + } + function getSupportedErrorCodes() { + return errorCodeToFixesArray ?? (errorCodeToFixesArray = arrayFrom(errorCodeToFixes.keys())); + } + function removeFixIdIfFixAllUnavailable(registration, diagnostics) { + const { errorCodes: errorCodes64 } = registration; + let maybeFixableDiagnostics = 0; + for (const diag2 of diagnostics) { + if (contains(errorCodes64, diag2.code)) + maybeFixableDiagnostics++; + if (maybeFixableDiagnostics > 1) + break; + } + const fixAllUnavailable = maybeFixableDiagnostics < 2; + return ({ fixId: fixId52, fixAllDescription, ...action }) => { + return fixAllUnavailable ? action : { ...action, fixId: fixId52, fixAllDescription }; + }; + } + function getFixes(context) { + const diagnostics = getDiagnostics(context); + const registrations = errorCodeToFixes.get(String(context.errorCode)); + return flatMap(registrations, (f) => map(f.getCodeActions(context), removeFixIdIfFixAllUnavailable(f, diagnostics))); + } + function getAllFixes(context) { + return fixIdToRegistration.get(cast(context.fixId, isString)).getAllCodeActions(context); + } + function createCombinedCodeActions(changes, commands) { + return { changes, commands }; + } + function createFileTextChanges(fileName, textChanges2) { + return { fileName, textChanges: textChanges2 }; + } + function codeFixAll(context, errorCodes64, use) { + const commands = []; + const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => eachDiagnostic(context, errorCodes64, (diag2) => use(t, diag2, commands))); + return createCombinedCodeActions(changes, commands.length === 0 ? void 0 : commands); + } + function eachDiagnostic(context, errorCodes64, cb) { + for (const diag2 of getDiagnostics(context)) { + if (contains(errorCodes64, diag2.code)) { + cb(diag2); + } + } + } + function getDiagnostics({ program, sourceFile, cancellationToken }) { + return [ + ...program.getSemanticDiagnostics(sourceFile, cancellationToken), + ...program.getSyntacticDiagnostics(sourceFile, cancellationToken), + ...computeSuggestionDiagnostics(sourceFile, program, cancellationToken) + ]; + } + var errorCodeToFixes, fixIdToRegistration, errorCodeToFixesArray; + var init_codeFixProvider = __esm({ + "src/services/codeFixProvider.ts"() { "use strict"; init_ts4(); - init_ts_refactor(); - actionName = "Generate 'get' and 'set' accessors"; - actionDescription = Diagnostics.Generate_get_and_set_accessors.message; - generateGetSetAction = { - name: actionName, - description: actionDescription, - kind: "refactor.rewrite.property.generateAccessors" - }; - registerRefactor(actionName, { - kinds: [generateGetSetAction.kind], - getEditsForAction: function getRefactorActionsToGenerateGetAndSetAccessors(context, actionName2) { - if (!context.endPosition) - return void 0; - const info = ts_codefix_exports.getAccessorConvertiblePropertyAtPosition(context.file, context.program, context.startPosition, context.endPosition); - Debug.assert(info && !isRefactorErrorInfo(info), "Expected applicable refactor info"); - const edits = ts_codefix_exports.generateAccessorFromProperty(context.file, context.program, context.startPosition, context.endPosition, context, actionName2); - if (!edits) + errorCodeToFixes = createMultiMap(); + fixIdToRegistration = /* @__PURE__ */ new Map(); + } + }); + + // src/services/codefixes/addConvertToUnknownForNonOverlappingTypes.ts + function makeChange(changeTracker, sourceFile, assertion) { + const replacement = isAsExpression(assertion) ? factory.createAsExpression(assertion.expression, factory.createKeywordTypeNode(159 /* UnknownKeyword */)) : factory.createTypeAssertion(factory.createKeywordTypeNode(159 /* UnknownKeyword */), assertion.expression); + changeTracker.replaceNode(sourceFile, assertion.expression, replacement); + } + function getAssertion(sourceFile, pos) { + if (isInJSFile(sourceFile)) + return void 0; + return findAncestor(getTokenAtPosition(sourceFile, pos), (n) => isAsExpression(n) || isTypeAssertionExpression(n)); + } + var fixId, errorCodes; + var init_addConvertToUnknownForNonOverlappingTypes = __esm({ + "src/services/codefixes/addConvertToUnknownForNonOverlappingTypes.ts"() { + "use strict"; + init_ts4(); + init_ts_codefix(); + fixId = "addConvertToUnknownForNonOverlappingTypes"; + errorCodes = [Diagnostics.Conversion_of_type_0_to_type_1_may_be_a_mistake_because_neither_type_sufficiently_overlaps_with_the_other_If_this_was_intentional_convert_the_expression_to_unknown_first.code]; + registerCodeFix({ + errorCodes, + getCodeActions: function getCodeActionsToAddConvertToUnknownForNonOverlappingTypes(context) { + const assertion = getAssertion(context.sourceFile, context.span.start); + if (assertion === void 0) return void 0; - const renameFilename = context.file.fileName; - const nameNeedRename = info.renameAccessor ? info.accessorName : info.fieldName; - const renameLocationOffset = isIdentifier(nameNeedRename) ? 0 : -1; - const renameLocation = renameLocationOffset + getRenameLocation( - edits, - renameFilename, - nameNeedRename.text, - /*preferLastLocation*/ - isParameter(info.declaration) - ); - return { renameFilename, renameLocation, edits }; + const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => makeChange(t, context.sourceFile, assertion)); + return [createCodeFixAction(fixId, changes, Diagnostics.Add_unknown_conversion_for_non_overlapping_types, fixId, Diagnostics.Add_unknown_to_all_conversions_of_non_overlapping_types)]; }, - getAvailableActions(context) { - if (!context.endPosition) - return emptyArray; - const info = ts_codefix_exports.getAccessorConvertiblePropertyAtPosition(context.file, context.program, context.startPosition, context.endPosition, context.triggerReason === "invoked"); - if (!info) - return emptyArray; - if (!isRefactorErrorInfo(info)) { - return [{ - name: actionName, - description: actionDescription, - actions: [generateGetSetAction] - }]; + fixIds: [fixId], + getAllCodeActions: (context) => codeFixAll(context, errorCodes, (changes, diag2) => { + const assertion = getAssertion(diag2.file, diag2.start); + if (assertion) { + makeChange(changes, diag2.file, assertion); } - if (context.preferences.provideRefactorNotApplicableReason) { - return [{ - name: actionName, - description: actionDescription, - actions: [{ ...generateGetSetAction, notApplicableReason: info.error }] - }]; + }) + }); + } + }); + + // src/services/codefixes/addEmptyExportDeclaration.ts + var init_addEmptyExportDeclaration = __esm({ + "src/services/codefixes/addEmptyExportDeclaration.ts"() { + "use strict"; + init_ts4(); + init_ts_codefix(); + registerCodeFix({ + errorCodes: [ + Diagnostics.await_expressions_are_only_allowed_at_the_top_level_of_a_file_when_that_file_is_a_module_but_this_file_has_no_imports_or_exports_Consider_adding_an_empty_export_to_make_this_file_a_module.code, + Diagnostics.await_using_statements_are_only_allowed_at_the_top_level_of_a_file_when_that_file_is_a_module_but_this_file_has_no_imports_or_exports_Consider_adding_an_empty_export_to_make_this_file_a_module.code, + Diagnostics.for_await_loops_are_only_allowed_at_the_top_level_of_a_file_when_that_file_is_a_module_but_this_file_has_no_imports_or_exports_Consider_adding_an_empty_export_to_make_this_file_a_module.code + ], + getCodeActions: function getCodeActionsToAddEmptyExportDeclaration(context) { + const { sourceFile } = context; + const changes = ts_textChanges_exports.ChangeTracker.with(context, (changes2) => { + const exportDeclaration = factory.createExportDeclaration( + /*modifiers*/ + void 0, + /*isTypeOnly*/ + false, + factory.createNamedExports([]), + /*moduleSpecifier*/ + void 0 + ); + changes2.insertNodeAtEndOfScope(sourceFile, sourceFile, exportDeclaration); + }); + return [createCodeFixActionWithoutFixAll("addEmptyExportDeclaration", changes, Diagnostics.Add_export_to_make_this_file_into_a_module)]; + } + }); + } + }); + + // src/services/codefixes/addMissingAsync.ts + function getFix(context, decl, trackChanges, fixedDeclarations) { + const changes = trackChanges((t) => makeChange2(t, context.sourceFile, decl, fixedDeclarations)); + return createCodeFixAction(fixId2, changes, Diagnostics.Add_async_modifier_to_containing_function, fixId2, Diagnostics.Add_all_missing_async_modifiers); + } + function makeChange2(changeTracker, sourceFile, insertionSite, fixedDeclarations) { + if (fixedDeclarations) { + if (fixedDeclarations.has(getNodeId(insertionSite))) { + return; + } + } + fixedDeclarations == null ? void 0 : fixedDeclarations.add(getNodeId(insertionSite)); + const cloneWithModifier = factory.replaceModifiers( + getSynthesizedDeepClone( + insertionSite, + /*includeTrivia*/ + true + ), + factory.createNodeArray(factory.createModifiersFromModifierFlags(getSyntacticModifierFlags(insertionSite) | 1024 /* Async */)) + ); + changeTracker.replaceNode( + sourceFile, + insertionSite, + cloneWithModifier + ); + } + function getFixableErrorSpanDeclaration(sourceFile, span) { + if (!span) + return void 0; + const token = getTokenAtPosition(sourceFile, span.start); + const decl = findAncestor(token, (node) => { + if (node.getStart(sourceFile) < span.start || node.getEnd() > textSpanEnd(span)) { + return "quit"; + } + return (isArrowFunction(node) || isMethodDeclaration(node) || isFunctionExpression(node) || isFunctionDeclaration(node)) && textSpansEqual(span, createTextSpanFromNode(node, sourceFile)); + }); + return decl; + } + function getIsMatchingAsyncError(span, errorCode) { + return ({ start, length: length2, relatedInformation, code }) => isNumber(start) && isNumber(length2) && textSpansEqual({ start, length: length2 }, span) && code === errorCode && !!relatedInformation && some(relatedInformation, (related) => related.code === Diagnostics.Did_you_mean_to_mark_this_function_as_async.code); + } + var fixId2, errorCodes2; + var init_addMissingAsync = __esm({ + "src/services/codefixes/addMissingAsync.ts"() { + "use strict"; + init_ts4(); + init_ts_codefix(); + fixId2 = "addMissingAsync"; + errorCodes2 = [ + Diagnostics.Argument_of_type_0_is_not_assignable_to_parameter_of_type_1.code, + Diagnostics.Type_0_is_not_assignable_to_type_1.code, + Diagnostics.Type_0_is_not_comparable_to_type_1.code + ]; + registerCodeFix({ + fixIds: [fixId2], + errorCodes: errorCodes2, + getCodeActions: function getCodeActionsToAddMissingAsync(context) { + const { sourceFile, errorCode, cancellationToken, program, span } = context; + const diagnostic = find(program.getTypeChecker().getDiagnostics(sourceFile, cancellationToken), getIsMatchingAsyncError(span, errorCode)); + const directSpan = diagnostic && diagnostic.relatedInformation && find(diagnostic.relatedInformation, (r) => r.code === Diagnostics.Did_you_mean_to_mark_this_function_as_async.code); + const decl = getFixableErrorSpanDeclaration(sourceFile, directSpan); + if (!decl) { + return; } - return emptyArray; + const trackChanges = (cb) => ts_textChanges_exports.ChangeTracker.with(context, cb); + return [getFix(context, decl, trackChanges)]; + }, + getAllCodeActions: (context) => { + const { sourceFile } = context; + const fixedDeclarations = /* @__PURE__ */ new Set(); + return codeFixAll(context, errorCodes2, (t, diagnostic) => { + const span = diagnostic.relatedInformation && find(diagnostic.relatedInformation, (r) => r.code === Diagnostics.Did_you_mean_to_mark_this_function_as_async.code); + const decl = getFixableErrorSpanDeclaration(sourceFile, span); + if (!decl) { + return; + } + const trackChanges = (cb) => (cb(t), []); + return getFix(context, decl, trackChanges, fixedDeclarations); + }); } }); } }); - // src/services/_namespaces/ts.refactor.generateGetAccessorAndSetAccessor.ts - var ts_refactor_generateGetAccessorAndSetAccessor_exports = {}; - var init_ts_refactor_generateGetAccessorAndSetAccessor = __esm({ - "src/services/_namespaces/ts.refactor.generateGetAccessorAndSetAccessor.ts"() { + // src/services/codefixes/addMissingAwait.ts + function getAwaitErrorSpanExpression(sourceFile, errorCode, span, cancellationToken, program) { + const expression = getFixableErrorSpanExpression(sourceFile, span); + return expression && isMissingAwaitError(sourceFile, errorCode, span, cancellationToken, program) && isInsideAwaitableBody(expression) ? expression : void 0; + } + function getDeclarationSiteFix(context, expression, errorCode, checker, trackChanges, fixedDeclarations) { + const { sourceFile, program, cancellationToken } = context; + const awaitableInitializers = findAwaitableInitializers(expression, sourceFile, cancellationToken, program, checker); + if (awaitableInitializers) { + const initializerChanges = trackChanges((t) => { + forEach(awaitableInitializers.initializers, ({ expression: expression2 }) => makeChange3(t, errorCode, sourceFile, checker, expression2, fixedDeclarations)); + if (fixedDeclarations && awaitableInitializers.needsSecondPassForFixAll) { + makeChange3(t, errorCode, sourceFile, checker, expression, fixedDeclarations); + } + }); + return createCodeFixActionWithoutFixAll( + "addMissingAwaitToInitializer", + initializerChanges, + awaitableInitializers.initializers.length === 1 ? [Diagnostics.Add_await_to_initializer_for_0, awaitableInitializers.initializers[0].declarationSymbol.name] : Diagnostics.Add_await_to_initializers + ); + } + } + function getUseSiteFix(context, expression, errorCode, checker, trackChanges, fixedDeclarations) { + const changes = trackChanges((t) => makeChange3(t, errorCode, context.sourceFile, checker, expression, fixedDeclarations)); + return createCodeFixAction(fixId3, changes, Diagnostics.Add_await, fixId3, Diagnostics.Fix_all_expressions_possibly_missing_await); + } + function isMissingAwaitError(sourceFile, errorCode, span, cancellationToken, program) { + const checker = program.getTypeChecker(); + const diagnostics = checker.getDiagnostics(sourceFile, cancellationToken); + return some(diagnostics, ({ start, length: length2, relatedInformation, code }) => isNumber(start) && isNumber(length2) && textSpansEqual({ start, length: length2 }, span) && code === errorCode && !!relatedInformation && some(relatedInformation, (related) => related.code === Diagnostics.Did_you_forget_to_use_await.code)); + } + function findAwaitableInitializers(expression, sourceFile, cancellationToken, program, checker) { + const identifiers = getIdentifiersFromErrorSpanExpression(expression, checker); + if (!identifiers) { + return; + } + let isCompleteFix = identifiers.isCompleteFix; + let initializers; + for (const identifier of identifiers.identifiers) { + const symbol = checker.getSymbolAtLocation(identifier); + if (!symbol) { + continue; + } + const declaration = tryCast(symbol.valueDeclaration, isVariableDeclaration); + const variableName = declaration && tryCast(declaration.name, isIdentifier); + const variableStatement = getAncestor(declaration, 243 /* VariableStatement */); + if (!declaration || !variableStatement || declaration.type || !declaration.initializer || variableStatement.getSourceFile() !== sourceFile || hasSyntacticModifier(variableStatement, 32 /* Export */) || !variableName || !isInsideAwaitableBody(declaration.initializer)) { + isCompleteFix = false; + continue; + } + const diagnostics = program.getSemanticDiagnostics(sourceFile, cancellationToken); + const isUsedElsewhere = ts_FindAllReferences_exports.Core.eachSymbolReferenceInFile(variableName, checker, sourceFile, (reference) => { + return identifier !== reference && !symbolReferenceIsAlsoMissingAwait(reference, diagnostics, sourceFile, checker); + }); + if (isUsedElsewhere) { + isCompleteFix = false; + continue; + } + (initializers || (initializers = [])).push({ + expression: declaration.initializer, + declarationSymbol: symbol + }); + } + return initializers && { + initializers, + needsSecondPassForFixAll: !isCompleteFix + }; + } + function getIdentifiersFromErrorSpanExpression(expression, checker) { + if (isPropertyAccessExpression(expression.parent) && isIdentifier(expression.parent.expression)) { + return { identifiers: [expression.parent.expression], isCompleteFix: true }; + } + if (isIdentifier(expression)) { + return { identifiers: [expression], isCompleteFix: true }; + } + if (isBinaryExpression(expression)) { + let sides; + let isCompleteFix = true; + for (const side of [expression.left, expression.right]) { + const type = checker.getTypeAtLocation(side); + if (checker.getPromisedTypeOfPromise(type)) { + if (!isIdentifier(side)) { + isCompleteFix = false; + continue; + } + (sides || (sides = [])).push(side); + } + } + return sides && { identifiers: sides, isCompleteFix }; + } + } + function symbolReferenceIsAlsoMissingAwait(reference, diagnostics, sourceFile, checker) { + const errorNode = isPropertyAccessExpression(reference.parent) ? reference.parent.name : isBinaryExpression(reference.parent) ? reference.parent : reference; + const diagnostic = find(diagnostics, (diagnostic2) => diagnostic2.start === errorNode.getStart(sourceFile) && diagnostic2.start + diagnostic2.length === errorNode.getEnd()); + return diagnostic && contains(errorCodes3, diagnostic.code) || // A Promise is usually not correct in a binary expression (it's not valid + // in an arithmetic expression and an equality comparison seems unusual), + // but if the other side of the binary expression has an error, the side + // is typed `any` which will squash the error that would identify this + // Promise as an invalid operand. So if the whole binary expression is + // typed `any` as a result, there is a strong likelihood that this Promise + // is accidentally missing `await`. + checker.getTypeAtLocation(errorNode).flags & 1 /* Any */; + } + function isInsideAwaitableBody(node) { + return node.flags & 65536 /* AwaitContext */ || !!findAncestor(node, (ancestor) => ancestor.parent && isArrowFunction(ancestor.parent) && ancestor.parent.body === ancestor || isBlock(ancestor) && (ancestor.parent.kind === 262 /* FunctionDeclaration */ || ancestor.parent.kind === 218 /* FunctionExpression */ || ancestor.parent.kind === 219 /* ArrowFunction */ || ancestor.parent.kind === 174 /* MethodDeclaration */)); + } + function makeChange3(changeTracker, errorCode, sourceFile, checker, insertionSite, fixedDeclarations) { + if (isForOfStatement(insertionSite.parent) && !insertionSite.parent.awaitModifier) { + const exprType = checker.getTypeAtLocation(insertionSite); + const asyncIter = checker.getAsyncIterableType(); + if (asyncIter && checker.isTypeAssignableTo(exprType, asyncIter)) { + const forOf = insertionSite.parent; + changeTracker.replaceNode(sourceFile, forOf, factory.updateForOfStatement(forOf, factory.createToken(135 /* AwaitKeyword */), forOf.initializer, forOf.expression, forOf.statement)); + return; + } + } + if (isBinaryExpression(insertionSite)) { + for (const side of [insertionSite.left, insertionSite.right]) { + if (fixedDeclarations && isIdentifier(side)) { + const symbol = checker.getSymbolAtLocation(side); + if (symbol && fixedDeclarations.has(getSymbolId(symbol))) { + continue; + } + } + const type = checker.getTypeAtLocation(side); + const newNode = checker.getPromisedTypeOfPromise(type) ? factory.createAwaitExpression(side) : side; + changeTracker.replaceNode(sourceFile, side, newNode); + } + } else if (errorCode === propertyAccessCode && isPropertyAccessExpression(insertionSite.parent)) { + if (fixedDeclarations && isIdentifier(insertionSite.parent.expression)) { + const symbol = checker.getSymbolAtLocation(insertionSite.parent.expression); + if (symbol && fixedDeclarations.has(getSymbolId(symbol))) { + return; + } + } + changeTracker.replaceNode( + sourceFile, + insertionSite.parent.expression, + factory.createParenthesizedExpression(factory.createAwaitExpression(insertionSite.parent.expression)) + ); + insertLeadingSemicolonIfNeeded(changeTracker, insertionSite.parent.expression, sourceFile); + } else if (contains(callableConstructableErrorCodes, errorCode) && isCallOrNewExpression(insertionSite.parent)) { + if (fixedDeclarations && isIdentifier(insertionSite)) { + const symbol = checker.getSymbolAtLocation(insertionSite); + if (symbol && fixedDeclarations.has(getSymbolId(symbol))) { + return; + } + } + changeTracker.replaceNode(sourceFile, insertionSite, factory.createParenthesizedExpression(factory.createAwaitExpression(insertionSite))); + insertLeadingSemicolonIfNeeded(changeTracker, insertionSite, sourceFile); + } else { + if (fixedDeclarations && isVariableDeclaration(insertionSite.parent) && isIdentifier(insertionSite.parent.name)) { + const symbol = checker.getSymbolAtLocation(insertionSite.parent.name); + if (symbol && !tryAddToSet(fixedDeclarations, getSymbolId(symbol))) { + return; + } + } + changeTracker.replaceNode(sourceFile, insertionSite, factory.createAwaitExpression(insertionSite)); + } + } + function insertLeadingSemicolonIfNeeded(changeTracker, beforeNode, sourceFile) { + const precedingToken = findPrecedingToken(beforeNode.pos, sourceFile); + if (precedingToken && positionIsASICandidate(precedingToken.end, precedingToken.parent, sourceFile)) { + changeTracker.insertText(sourceFile, beforeNode.getStart(sourceFile), ";"); + } + } + var fixId3, propertyAccessCode, callableConstructableErrorCodes, errorCodes3; + var init_addMissingAwait = __esm({ + "src/services/codefixes/addMissingAwait.ts"() { "use strict"; - init_generateGetAccessorAndSetAccessor(); + init_ts4(); + init_ts_codefix(); + fixId3 = "addMissingAwait"; + propertyAccessCode = Diagnostics.Property_0_does_not_exist_on_type_1.code; + callableConstructableErrorCodes = [ + Diagnostics.This_expression_is_not_callable.code, + Diagnostics.This_expression_is_not_constructable.code + ]; + errorCodes3 = [ + Diagnostics.An_arithmetic_operand_must_be_of_type_any_number_bigint_or_an_enum_type.code, + Diagnostics.The_left_hand_side_of_an_arithmetic_operation_must_be_of_type_any_number_bigint_or_an_enum_type.code, + Diagnostics.The_right_hand_side_of_an_arithmetic_operation_must_be_of_type_any_number_bigint_or_an_enum_type.code, + Diagnostics.Operator_0_cannot_be_applied_to_type_1.code, + Diagnostics.Operator_0_cannot_be_applied_to_types_1_and_2.code, + Diagnostics.This_comparison_appears_to_be_unintentional_because_the_types_0_and_1_have_no_overlap.code, + Diagnostics.This_condition_will_always_return_true_since_this_0_is_always_defined.code, + Diagnostics.Type_0_is_not_an_array_type.code, + Diagnostics.Type_0_is_not_an_array_type_or_a_string_type.code, + Diagnostics.Type_0_can_only_be_iterated_through_when_using_the_downlevelIteration_flag_or_with_a_target_of_es2015_or_higher.code, + Diagnostics.Type_0_is_not_an_array_type_or_a_string_type_or_does_not_have_a_Symbol_iterator_method_that_returns_an_iterator.code, + Diagnostics.Type_0_is_not_an_array_type_or_does_not_have_a_Symbol_iterator_method_that_returns_an_iterator.code, + Diagnostics.Type_0_must_have_a_Symbol_iterator_method_that_returns_an_iterator.code, + Diagnostics.Type_0_must_have_a_Symbol_asyncIterator_method_that_returns_an_async_iterator.code, + Diagnostics.Argument_of_type_0_is_not_assignable_to_parameter_of_type_1.code, + propertyAccessCode, + ...callableConstructableErrorCodes + ]; + registerCodeFix({ + fixIds: [fixId3], + errorCodes: errorCodes3, + getCodeActions: function getCodeActionsToAddMissingAwait(context) { + const { sourceFile, errorCode, span, cancellationToken, program } = context; + const expression = getAwaitErrorSpanExpression(sourceFile, errorCode, span, cancellationToken, program); + if (!expression) { + return; + } + const checker = context.program.getTypeChecker(); + const trackChanges = (cb) => ts_textChanges_exports.ChangeTracker.with(context, cb); + return compact([ + getDeclarationSiteFix(context, expression, errorCode, checker, trackChanges), + getUseSiteFix(context, expression, errorCode, checker, trackChanges) + ]); + }, + getAllCodeActions: (context) => { + const { sourceFile, program, cancellationToken } = context; + const checker = context.program.getTypeChecker(); + const fixedDeclarations = /* @__PURE__ */ new Set(); + return codeFixAll(context, errorCodes3, (t, diagnostic) => { + const expression = getAwaitErrorSpanExpression(sourceFile, diagnostic.code, diagnostic, cancellationToken, program); + if (!expression) { + return; + } + const trackChanges = (cb) => (cb(t), []); + return getDeclarationSiteFix(context, expression, diagnostic.code, checker, trackChanges, fixedDeclarations) || getUseSiteFix(context, expression, diagnostic.code, checker, trackChanges, fixedDeclarations); + }); + } + }); } }); - // src/services/refactors/inferFunctionReturnType.ts - function getRefactorEditsToInferReturnType(context) { - const info = getInfo4(context); - if (info && !isRefactorErrorInfo(info)) { - const edits = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange7(context.file, t, info.declaration, info.returnTypeNode)); - return { renameFilename: void 0, renameLocation: void 0, edits }; - } - return void 0; - } - function getRefactorActionsToInferReturnType(context) { - const info = getInfo4(context); - if (!info) - return emptyArray; - if (!isRefactorErrorInfo(info)) { - return [{ - name: refactorName12, - description: refactorDescription6, - actions: [inferReturnTypeAction] - }]; + // src/services/codefixes/addMissingConst.ts + function makeChange4(changeTracker, sourceFile, pos, program, fixedNodes) { + const token = getTokenAtPosition(sourceFile, pos); + const forInitializer = findAncestor(token, (node) => isForInOrOfStatement(node.parent) ? node.parent.initializer === node : isPossiblyPartOfDestructuring(node) ? false : "quit"); + if (forInitializer) + return applyChange(changeTracker, forInitializer, sourceFile, fixedNodes); + const parent2 = token.parent; + if (isBinaryExpression(parent2) && parent2.operatorToken.kind === 64 /* EqualsToken */ && isExpressionStatement(parent2.parent)) { + return applyChange(changeTracker, token, sourceFile, fixedNodes); } - if (context.preferences.provideRefactorNotApplicableReason) { - return [{ - name: refactorName12, - description: refactorDescription6, - actions: [{ ...inferReturnTypeAction, notApplicableReason: info.error }] - }]; + if (isArrayLiteralExpression(parent2)) { + const checker = program.getTypeChecker(); + if (!every(parent2.elements, (element) => arrayElementCouldBeVariableDeclaration(element, checker))) { + return; + } + return applyChange(changeTracker, parent2, sourceFile, fixedNodes); } - return emptyArray; - } - function doChange7(sourceFile, changes, declaration, typeNode) { - const closeParen = findChildOfKind(declaration, 22 /* CloseParenToken */, sourceFile); - const needParens = isArrowFunction(declaration) && closeParen === void 0; - const endNode2 = needParens ? first(declaration.parameters) : closeParen; - if (endNode2) { - if (needParens) { - changes.insertNodeBefore(sourceFile, endNode2, factory.createToken(21 /* OpenParenToken */)); - changes.insertNodeAfter(sourceFile, endNode2, factory.createToken(22 /* CloseParenToken */)); + const commaExpression = findAncestor(token, (node) => isExpressionStatement(node.parent) ? true : isPossiblyPartOfCommaSeperatedInitializer(node) ? false : "quit"); + if (commaExpression) { + const checker = program.getTypeChecker(); + if (!expressionCouldBeVariableDeclaration(commaExpression, checker)) { + return; } - changes.insertNodeAt(sourceFile, endNode2.end, typeNode, { prefix: ": " }); + return applyChange(changeTracker, commaExpression, sourceFile, fixedNodes); } } - function getInfo4(context) { - if (isInJSFile(context.file) || !refactorKindBeginsWith(inferReturnTypeAction.kind, context.kind)) - return; - const token = getTokenAtPosition(context.file, context.startPosition); - const declaration = findAncestor(token, (n) => isBlock(n) || n.parent && isArrowFunction(n.parent) && (n.kind === 39 /* EqualsGreaterThanToken */ || n.parent.body === n) ? "quit" : isConvertibleDeclaration(n)); - if (!declaration || !declaration.body || declaration.type) { - return { error: getLocaleSpecificMessage(Diagnostics.Return_type_must_be_inferred_from_a_function) }; - } - const typeChecker = context.program.getTypeChecker(); - const returnType = tryGetReturnType(typeChecker, declaration); - if (!returnType) { - return { error: getLocaleSpecificMessage(Diagnostics.Could_not_determine_function_return_type) }; + function applyChange(changeTracker, initializer, sourceFile, fixedNodes) { + if (!fixedNodes || tryAddToSet(fixedNodes, initializer)) { + changeTracker.insertModifierBefore(sourceFile, 87 /* ConstKeyword */, initializer); } - const returnTypeNode = typeChecker.typeToTypeNode(returnType, declaration, 1 /* NoTruncation */); - if (returnTypeNode) { - return { declaration, returnTypeNode }; + } + function isPossiblyPartOfDestructuring(node) { + switch (node.kind) { + case 80 /* Identifier */: + case 209 /* ArrayLiteralExpression */: + case 210 /* ObjectLiteralExpression */: + case 303 /* PropertyAssignment */: + case 304 /* ShorthandPropertyAssignment */: + return true; + default: + return false; } } - function isConvertibleDeclaration(node) { + function arrayElementCouldBeVariableDeclaration(expression, checker) { + const identifier = isIdentifier(expression) ? expression : isAssignmentExpression( + expression, + /*excludeCompoundAssignment*/ + true + ) && isIdentifier(expression.left) ? expression.left : void 0; + return !!identifier && !checker.getSymbolAtLocation(identifier); + } + function isPossiblyPartOfCommaSeperatedInitializer(node) { switch (node.kind) { - case 261 /* FunctionDeclaration */: - case 217 /* FunctionExpression */: - case 218 /* ArrowFunction */: - case 173 /* MethodDeclaration */: + case 80 /* Identifier */: + case 226 /* BinaryExpression */: + case 28 /* CommaToken */: return true; default: return false; } } - function tryGetReturnType(typeChecker, node) { - if (typeChecker.isImplementationOfOverload(node)) { - const signatures = typeChecker.getTypeAtLocation(node).getCallSignatures(); - if (signatures.length > 1) { - return typeChecker.getUnionType(mapDefined(signatures, (s) => s.getReturnType())); - } + function expressionCouldBeVariableDeclaration(expression, checker) { + if (!isBinaryExpression(expression)) { + return false; } - const signature = typeChecker.getSignatureFromDeclaration(node); - if (signature) { - return typeChecker.getReturnTypeOfSignature(signature); + if (expression.operatorToken.kind === 28 /* CommaToken */) { + return every([expression.left, expression.right], (expression2) => expressionCouldBeVariableDeclaration(expression2, checker)); } + return expression.operatorToken.kind === 64 /* EqualsToken */ && isIdentifier(expression.left) && !checker.getSymbolAtLocation(expression.left); } - var refactorName12, refactorDescription6, inferReturnTypeAction; - var init_inferFunctionReturnType = __esm({ - "src/services/refactors/inferFunctionReturnType.ts"() { + var fixId4, errorCodes4; + var init_addMissingConst = __esm({ + "src/services/codefixes/addMissingConst.ts"() { "use strict"; init_ts4(); - init_ts_refactor(); - refactorName12 = "Infer function return type"; - refactorDescription6 = Diagnostics.Infer_function_return_type.message; - inferReturnTypeAction = { - name: refactorName12, - description: refactorDescription6, - kind: "refactor.rewrite.function.returnType" - }; - registerRefactor(refactorName12, { - kinds: [inferReturnTypeAction.kind], - getEditsForAction: getRefactorEditsToInferReturnType, - getAvailableActions: getRefactorActionsToInferReturnType + init_ts_codefix(); + fixId4 = "addMissingConst"; + errorCodes4 = [ + Diagnostics.Cannot_find_name_0.code, + Diagnostics.No_value_exists_in_scope_for_the_shorthand_property_0_Either_declare_one_or_provide_an_initializer.code + ]; + registerCodeFix({ + errorCodes: errorCodes4, + getCodeActions: function getCodeActionsToAddMissingConst(context) { + const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => makeChange4(t, context.sourceFile, context.span.start, context.program)); + if (changes.length > 0) { + return [createCodeFixAction(fixId4, changes, Diagnostics.Add_const_to_unresolved_variable, fixId4, Diagnostics.Add_const_to_all_unresolved_variables)]; + } + }, + fixIds: [fixId4], + getAllCodeActions: (context) => { + const fixedNodes = /* @__PURE__ */ new Set(); + return codeFixAll(context, errorCodes4, (changes, diag2) => makeChange4(changes, diag2.file, diag2.start, context.program, fixedNodes)); + } }); } }); - // src/services/_namespaces/ts.refactor.inferFunctionReturnType.ts - var ts_refactor_inferFunctionReturnType_exports = {}; - var init_ts_refactor_inferFunctionReturnType = __esm({ - "src/services/_namespaces/ts.refactor.inferFunctionReturnType.ts"() { + // src/services/codefixes/addMissingDeclareProperty.ts + function makeChange5(changeTracker, sourceFile, pos, fixedNodes) { + const token = getTokenAtPosition(sourceFile, pos); + if (!isIdentifier(token)) { + return; + } + const declaration = token.parent; + if (declaration.kind === 172 /* PropertyDeclaration */ && (!fixedNodes || tryAddToSet(fixedNodes, declaration))) { + changeTracker.insertModifierBefore(sourceFile, 138 /* DeclareKeyword */, declaration); + } + } + var fixId5, errorCodes5; + var init_addMissingDeclareProperty = __esm({ + "src/services/codefixes/addMissingDeclareProperty.ts"() { "use strict"; - init_inferFunctionReturnType(); + init_ts4(); + init_ts_codefix(); + fixId5 = "addMissingDeclareProperty"; + errorCodes5 = [ + Diagnostics.Property_0_will_overwrite_the_base_property_in_1_If_this_is_intentional_add_an_initializer_Otherwise_add_a_declare_modifier_or_remove_the_redundant_declaration.code + ]; + registerCodeFix({ + errorCodes: errorCodes5, + getCodeActions: function getCodeActionsToAddMissingDeclareOnProperty(context) { + const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => makeChange5(t, context.sourceFile, context.span.start)); + if (changes.length > 0) { + return [createCodeFixAction(fixId5, changes, Diagnostics.Prefix_with_declare, fixId5, Diagnostics.Prefix_all_incorrect_property_declarations_with_declare)]; + } + }, + fixIds: [fixId5], + getAllCodeActions: (context) => { + const fixedNodes = /* @__PURE__ */ new Set(); + return codeFixAll(context, errorCodes5, (changes, diag2) => makeChange5(changes, diag2.file, diag2.start, fixedNodes)); + } + }); } }); - // src/services/_namespaces/ts.refactor.ts - var ts_refactor_exports = {}; - __export(ts_refactor_exports, { - addExportToChanges: () => addExportToChanges, - addExports: () => addExports, - addNewFileToTsconfig: () => addNewFileToTsconfig, - addOrRemoveBracesToArrowFunction: () => ts_refactor_addOrRemoveBracesToArrowFunction_exports, - convertArrowFunctionOrFunctionExpression: () => ts_refactor_convertArrowFunctionOrFunctionExpression_exports, - convertParamsToDestructuredObject: () => ts_refactor_convertParamsToDestructuredObject_exports, - convertStringOrTemplateLiteral: () => ts_refactor_convertStringOrTemplateLiteral_exports, - convertToOptionalChainExpression: () => ts_refactor_convertToOptionalChainExpression_exports, - createNewFileName: () => createNewFileName, - createOldFileImportsFromTargetFile: () => createOldFileImportsFromTargetFile, - deleteMovedStatements: () => deleteMovedStatements, - deleteUnusedImports: () => deleteUnusedImports, - deleteUnusedOldImports: () => deleteUnusedOldImports, - doChangeNamedToNamespaceOrDefault: () => doChangeNamedToNamespaceOrDefault, - extractSymbol: () => ts_refactor_extractSymbol_exports, - filterImport: () => filterImport, - forEachImportInStatement: () => forEachImportInStatement, - generateGetAccessorAndSetAccessor: () => ts_refactor_generateGetAccessorAndSetAccessor_exports, - getApplicableRefactors: () => getApplicableRefactors, - getEditsForRefactor: () => getEditsForRefactor, - getStatementsToMove: () => getStatementsToMove, - getTopLevelDeclarationStatement: () => getTopLevelDeclarationStatement, - getUsageInfo: () => getUsageInfo, - inferFunctionReturnType: () => ts_refactor_inferFunctionReturnType_exports, - isRefactorErrorInfo: () => isRefactorErrorInfo, - isTopLevelDeclaration: () => isTopLevelDeclaration, - makeImportOrRequire: () => makeImportOrRequire, - moduleSpecifierFromImport: () => moduleSpecifierFromImport, - nameOfTopLevelDeclaration: () => nameOfTopLevelDeclaration, - refactorKindBeginsWith: () => refactorKindBeginsWith, - registerRefactor: () => registerRefactor, - updateImportsInOtherFiles: () => updateImportsInOtherFiles - }); - var init_ts_refactor = __esm({ - "src/services/_namespaces/ts.refactor.ts"() { + // src/services/codefixes/addMissingInvocationForDecorator.ts + function makeChange6(changeTracker, sourceFile, pos) { + const token = getTokenAtPosition(sourceFile, pos); + const decorator = findAncestor(token, isDecorator); + Debug.assert(!!decorator, "Expected position to be owned by a decorator."); + const replacement = factory.createCallExpression( + decorator.expression, + /*typeArguments*/ + void 0, + /*argumentsArray*/ + void 0 + ); + changeTracker.replaceNode(sourceFile, decorator.expression, replacement); + } + var fixId6, errorCodes6; + var init_addMissingInvocationForDecorator = __esm({ + "src/services/codefixes/addMissingInvocationForDecorator.ts"() { "use strict"; - init_refactorProvider(); - init_convertExport(); - init_convertImport(); - init_extractType(); - init_helpers(); - init_moveToNewFile(); - init_moveToFile(); - init_ts_refactor_addOrRemoveBracesToArrowFunction(); - init_ts_refactor_convertArrowFunctionOrFunctionExpression(); - init_ts_refactor_convertParamsToDestructuredObject(); - init_ts_refactor_convertStringOrTemplateLiteral(); - init_ts_refactor_convertToOptionalChainExpression(); - init_ts_refactor_extractSymbol(); - init_ts_refactor_generateGetAccessorAndSetAccessor(); - init_ts_refactor_inferFunctionReturnType(); + init_ts4(); + init_ts_codefix(); + fixId6 = "addMissingInvocationForDecorator"; + errorCodes6 = [Diagnostics._0_accepts_too_few_arguments_to_be_used_as_a_decorator_here_Did_you_mean_to_call_it_first_and_write_0.code]; + registerCodeFix({ + errorCodes: errorCodes6, + getCodeActions: function getCodeActionsToAddMissingInvocationForDecorator(context) { + const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => makeChange6(t, context.sourceFile, context.span.start)); + return [createCodeFixAction(fixId6, changes, Diagnostics.Call_decorator_expression, fixId6, Diagnostics.Add_to_all_uncalled_decorators)]; + }, + fixIds: [fixId6], + getAllCodeActions: (context) => codeFixAll(context, errorCodes6, (changes, diag2) => makeChange6(changes, diag2.file, diag2.start)) + }); } }); - // src/services/classifier2020.ts - function getSemanticClassifications2(program, cancellationToken, sourceFile, span) { - const classifications = getEncodedSemanticClassifications2(program, cancellationToken, sourceFile, span); - Debug.assert(classifications.spans.length % 3 === 0); - const dense = classifications.spans; - const result = []; - for (let i = 0; i < dense.length; i += 3) { - result.push({ - textSpan: createTextSpan(dense[i], dense[i + 1]), - classificationType: dense[i + 2] - }); + // src/services/codefixes/addNameToNamelessParameter.ts + function makeChange7(changeTracker, sourceFile, start) { + const token = getTokenAtPosition(sourceFile, start); + const param = token.parent; + if (!isParameter(param)) { + return Debug.fail("Tried to add a parameter name to a non-parameter: " + Debug.formatSyntaxKind(token.kind)); } - return result; + const i = param.parent.parameters.indexOf(param); + Debug.assert(!param.type, "Tried to add a parameter name to a parameter that already had one."); + Debug.assert(i > -1, "Parameter not found in parent parameter list."); + let end = param.name.getEnd(); + let typeNode = factory.createTypeReferenceNode( + param.name, + /*typeArguments*/ + void 0 + ); + let nextParam = tryGetNextParam(sourceFile, param); + while (nextParam) { + typeNode = factory.createArrayTypeNode(typeNode); + end = nextParam.getEnd(); + nextParam = tryGetNextParam(sourceFile, nextParam); + } + const replacement = factory.createParameterDeclaration( + param.modifiers, + param.dotDotDotToken, + "arg" + i, + param.questionToken, + param.dotDotDotToken && !isArrayTypeNode(typeNode) ? factory.createArrayTypeNode(typeNode) : typeNode, + param.initializer + ); + changeTracker.replaceRange(sourceFile, createRange(param.getStart(sourceFile), end), replacement); } - function getEncodedSemanticClassifications2(program, cancellationToken, sourceFile, span) { - return { - spans: getSemanticTokens(program, sourceFile, span, cancellationToken), - endOfLineState: 0 /* None */ - }; + function tryGetNextParam(sourceFile, param) { + const nextToken = findNextToken(param.name, param.parent, sourceFile); + if (nextToken && nextToken.kind === 23 /* OpenBracketToken */ && isArrayBindingPattern(nextToken.parent) && isParameter(nextToken.parent.parent)) { + return nextToken.parent.parent; + } + return void 0; } - function getSemanticTokens(program, sourceFile, span, cancellationToken) { - const resultTokens = []; - const collector = (node, typeIdx, modifierSet) => { - resultTokens.push(node.getStart(sourceFile), node.getWidth(sourceFile), (typeIdx + 1 << 8 /* typeOffset */) + modifierSet); - }; - if (program && sourceFile) { - collectTokens(program, sourceFile, span, collector, cancellationToken); + var fixId7, errorCodes7; + var init_addNameToNamelessParameter = __esm({ + "src/services/codefixes/addNameToNamelessParameter.ts"() { + "use strict"; + init_ts4(); + init_ts_codefix(); + fixId7 = "addNameToNamelessParameter"; + errorCodes7 = [Diagnostics.Parameter_has_a_name_but_no_type_Did_you_mean_0_Colon_1.code]; + registerCodeFix({ + errorCodes: errorCodes7, + getCodeActions: function getCodeActionsToAddNameToNamelessParameter(context) { + const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => makeChange7(t, context.sourceFile, context.span.start)); + return [createCodeFixAction(fixId7, changes, Diagnostics.Add_parameter_name, fixId7, Diagnostics.Add_names_to_all_parameters_without_names)]; + }, + fixIds: [fixId7], + getAllCodeActions: (context) => codeFixAll(context, errorCodes7, (changes, diag2) => makeChange7(changes, diag2.file, diag2.start)) + }); } - return resultTokens; + }); + + // src/services/codefixes/addOptionalPropertyUndefined.ts + function getPropertiesToAdd(file, span, checker) { + var _a, _b; + const sourceTarget = getSourceTarget(getFixableErrorSpanExpression(file, span), checker); + if (!sourceTarget) { + return emptyArray; + } + const { source: sourceNode, target: targetNode } = sourceTarget; + const target = shouldUseParentTypeOfProperty(sourceNode, targetNode, checker) ? checker.getTypeAtLocation(targetNode.expression) : checker.getTypeAtLocation(targetNode); + if ((_b = (_a = target.symbol) == null ? void 0 : _a.declarations) == null ? void 0 : _b.some((d) => getSourceFileOfNode(d).fileName.match(/\.d\.ts$/))) { + return emptyArray; + } + return checker.getExactOptionalProperties(target); } - function collectTokens(program, sourceFile, span, collector, cancellationToken) { - const typeChecker = program.getTypeChecker(); - let inJSXElement = false; - function visit(node) { - switch (node.kind) { - case 266 /* ModuleDeclaration */: - case 262 /* ClassDeclaration */: - case 263 /* InterfaceDeclaration */: - case 261 /* FunctionDeclaration */: - case 230 /* ClassExpression */: - case 217 /* FunctionExpression */: - case 218 /* ArrowFunction */: - cancellationToken.throwIfCancellationRequested(); - } - if (!node || !textSpanIntersectsWith(span, node.pos, node.getFullWidth()) || node.getFullWidth() === 0) { - return; - } - const prevInJSXElement = inJSXElement; - if (isJsxElement(node) || isJsxSelfClosingElement(node)) { - inJSXElement = true; - } - if (isJsxExpression(node)) { - inJSXElement = false; - } - if (isIdentifier(node) && !inJSXElement && !inImportClause(node) && !isInfinityOrNaNString(node.escapedText)) { - let symbol = typeChecker.getSymbolAtLocation(node); - if (symbol) { - if (symbol.flags & 2097152 /* Alias */) { - symbol = typeChecker.getAliasedSymbol(symbol); - } - let typeIdx = classifySymbol2(symbol, getMeaningFromLocation(node)); - if (typeIdx !== void 0) { - let modifierSet = 0; - if (node.parent) { - const parentIsDeclaration = isBindingElement(node.parent) || tokenFromDeclarationMapping.get(node.parent.kind) === typeIdx; - if (parentIsDeclaration && node.parent.name === node) { - modifierSet = 1 << 0 /* declaration */; - } - } - if (typeIdx === 6 /* parameter */ && isRightSideOfQualifiedNameOrPropertyAccess2(node)) { - typeIdx = 9 /* property */; - } - typeIdx = reclassifyByType(typeChecker, node, typeIdx); - const decl = symbol.valueDeclaration; - if (decl) { - const modifiers = getCombinedModifierFlags(decl); - const nodeFlags = getCombinedNodeFlags(decl); - if (modifiers & 32 /* Static */) { - modifierSet |= 1 << 1 /* static */; - } - if (modifiers & 512 /* Async */) { - modifierSet |= 1 << 2 /* async */; - } - if (typeIdx !== 0 /* class */ && typeIdx !== 2 /* interface */) { - if (modifiers & 64 /* Readonly */ || nodeFlags & 2 /* Const */ || symbol.getFlags() & 8 /* EnumMember */) { - modifierSet |= 1 << 3 /* readonly */; - } - } - if ((typeIdx === 7 /* variable */ || typeIdx === 10 /* function */) && isLocalDeclaration(decl, sourceFile)) { - modifierSet |= 1 << 5 /* local */; - } - if (program.isSourceFileDefaultLibrary(decl.getSourceFile())) { - modifierSet |= 1 << 4 /* defaultLibrary */; - } - } else if (symbol.declarations && symbol.declarations.some((d) => program.isSourceFileDefaultLibrary(d.getSourceFile()))) { - modifierSet |= 1 << 4 /* defaultLibrary */; - } - collector(node, typeIdx, modifierSet); - } - } - } - forEachChild(node, visit); - inJSXElement = prevInJSXElement; + function shouldUseParentTypeOfProperty(sourceNode, targetNode, checker) { + return isPropertyAccessExpression(targetNode) && !!checker.getExactOptionalProperties(checker.getTypeAtLocation(targetNode.expression)).length && checker.getTypeAtLocation(sourceNode) === checker.getUndefinedType(); + } + function getSourceTarget(errorNode, checker) { + var _a; + if (!errorNode) { + return void 0; + } else if (isBinaryExpression(errorNode.parent) && errorNode.parent.operatorToken.kind === 64 /* EqualsToken */) { + return { source: errorNode.parent.right, target: errorNode.parent.left }; + } else if (isVariableDeclaration(errorNode.parent) && errorNode.parent.initializer) { + return { source: errorNode.parent.initializer, target: errorNode.parent.name }; + } else if (isCallExpression(errorNode.parent)) { + const n = checker.getSymbolAtLocation(errorNode.parent.expression); + if (!(n == null ? void 0 : n.valueDeclaration) || !isFunctionLikeKind(n.valueDeclaration.kind)) + return void 0; + if (!isExpression(errorNode)) + return void 0; + const i = errorNode.parent.arguments.indexOf(errorNode); + if (i === -1) + return void 0; + const name = n.valueDeclaration.parameters[i].name; + if (isIdentifier(name)) + return { source: errorNode, target: name }; + } else if (isPropertyAssignment(errorNode.parent) && isIdentifier(errorNode.parent.name) || isShorthandPropertyAssignment(errorNode.parent)) { + const parentTarget = getSourceTarget(errorNode.parent.parent, checker); + if (!parentTarget) + return void 0; + const prop = checker.getPropertyOfType(checker.getTypeAtLocation(parentTarget.target), errorNode.parent.name.text); + const declaration = (_a = prop == null ? void 0 : prop.declarations) == null ? void 0 : _a[0]; + if (!declaration) + return void 0; + return { + source: isPropertyAssignment(errorNode.parent) ? errorNode.parent.initializer : errorNode.parent.name, + target: declaration + }; } - visit(sourceFile); + return void 0; } - function classifySymbol2(symbol, meaning) { - const flags = symbol.getFlags(); - if (flags & 32 /* Class */) { - return 0 /* class */; - } else if (flags & 384 /* Enum */) { - return 1 /* enum */; - } else if (flags & 524288 /* TypeAlias */) { - return 5 /* type */; - } else if (flags & 64 /* Interface */) { - if (meaning & 2 /* Type */) { - return 2 /* interface */; + function addUndefinedToOptionalProperty(changes, toAdd) { + for (const add of toAdd) { + const d = add.valueDeclaration; + if (d && (isPropertySignature(d) || isPropertyDeclaration(d)) && d.type) { + const t = factory.createUnionTypeNode([ + ...d.type.kind === 192 /* UnionType */ ? d.type.types : [d.type], + factory.createTypeReferenceNode("undefined") + ]); + changes.replaceNode(d.getSourceFile(), d.type, t); } - } else if (flags & 262144 /* TypeParameter */) { - return 4 /* typeParameter */; } - let decl = symbol.valueDeclaration || symbol.declarations && symbol.declarations[0]; - if (decl && isBindingElement(decl)) { - decl = getDeclarationForBindingElement(decl); + } + var addOptionalPropertyUndefined, errorCodes8; + var init_addOptionalPropertyUndefined = __esm({ + "src/services/codefixes/addOptionalPropertyUndefined.ts"() { + "use strict"; + init_ts4(); + init_ts_codefix(); + addOptionalPropertyUndefined = "addOptionalPropertyUndefined"; + errorCodes8 = [ + Diagnostics.Type_0_is_not_assignable_to_type_1_with_exactOptionalPropertyTypes_Colon_true_Consider_adding_undefined_to_the_type_of_the_target.code, + Diagnostics.Type_0_is_not_assignable_to_type_1_with_exactOptionalPropertyTypes_Colon_true_Consider_adding_undefined_to_the_types_of_the_target_s_properties.code, + Diagnostics.Argument_of_type_0_is_not_assignable_to_parameter_of_type_1_with_exactOptionalPropertyTypes_Colon_true_Consider_adding_undefined_to_the_types_of_the_target_s_properties.code + ]; + registerCodeFix({ + errorCodes: errorCodes8, + getCodeActions(context) { + const typeChecker = context.program.getTypeChecker(); + const toAdd = getPropertiesToAdd(context.sourceFile, context.span, typeChecker); + if (!toAdd.length) { + return void 0; + } + const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => addUndefinedToOptionalProperty(t, toAdd)); + return [createCodeFixActionWithoutFixAll(addOptionalPropertyUndefined, changes, Diagnostics.Add_undefined_to_optional_property_type)]; + }, + fixIds: [addOptionalPropertyUndefined] + }); } - return decl && tokenFromDeclarationMapping.get(decl.kind); + }); + + // src/services/codefixes/annotateWithTypeFromJSDoc.ts + function getDeclaration(file, pos) { + const name = getTokenAtPosition(file, pos); + return tryCast(isParameter(name.parent) ? name.parent.parent : name.parent, parameterShouldGetTypeFromJSDoc); } - function reclassifyByType(typeChecker, node, typeIdx) { - if (typeIdx === 7 /* variable */ || typeIdx === 9 /* property */ || typeIdx === 6 /* parameter */) { - const type = typeChecker.getTypeAtLocation(node); - if (type) { - const test = (condition) => { - return condition(type) || type.isUnion() && type.types.some(condition); - }; - if (typeIdx !== 6 /* parameter */ && test((t) => t.getConstructSignatures().length > 0)) { - return 0 /* class */; - } - if (test((t) => t.getCallSignatures().length > 0) && !test((t) => t.getProperties().length > 0) || isExpressionInCallExpression(node)) { - return typeIdx === 9 /* property */ ? 11 /* member */ : 10 /* function */; + function parameterShouldGetTypeFromJSDoc(node) { + return isDeclarationWithType(node) && hasUsableJSDoc(node); + } + function hasUsableJSDoc(decl) { + return isFunctionLikeDeclaration(decl) ? decl.parameters.some(hasUsableJSDoc) || !decl.type && !!getJSDocReturnType(decl) : !decl.type && !!getJSDocType(decl); + } + function doChange8(changes, sourceFile, decl) { + if (isFunctionLikeDeclaration(decl) && (getJSDocReturnType(decl) || decl.parameters.some((p) => !!getJSDocType(p)))) { + if (!decl.typeParameters) { + const typeParameters = getJSDocTypeParameterDeclarations(decl); + if (typeParameters.length) + changes.insertTypeParameters(sourceFile, decl, typeParameters); + } + const needParens = isArrowFunction(decl) && !findChildOfKind(decl, 21 /* OpenParenToken */, sourceFile); + if (needParens) + changes.insertNodeBefore(sourceFile, first(decl.parameters), factory.createToken(21 /* OpenParenToken */)); + for (const param of decl.parameters) { + if (!param.type) { + const paramType = getJSDocType(param); + if (paramType) + changes.tryInsertTypeAnnotation(sourceFile, param, visitNode(paramType, transformJSDocType, isTypeNode)); } } + if (needParens) + changes.insertNodeAfter(sourceFile, last(decl.parameters), factory.createToken(22 /* CloseParenToken */)); + if (!decl.type) { + const returnType = getJSDocReturnType(decl); + if (returnType) + changes.tryInsertTypeAnnotation(sourceFile, decl, visitNode(returnType, transformJSDocType, isTypeNode)); + } + } else { + const jsdocType = Debug.checkDefined(getJSDocType(decl), "A JSDocType for this declaration should exist"); + Debug.assert(!decl.type, "The JSDocType decl should have a type"); + changes.tryInsertTypeAnnotation(sourceFile, decl, visitNode(jsdocType, transformJSDocType, isTypeNode)); } - return typeIdx; } - function isLocalDeclaration(decl, sourceFile) { - if (isBindingElement(decl)) { - decl = getDeclarationForBindingElement(decl); - } - if (isVariableDeclaration(decl)) { - return (!isSourceFile(decl.parent.parent.parent) || isCatchClause(decl.parent)) && decl.getSourceFile() === sourceFile; - } else if (isFunctionDeclaration(decl)) { - return !isSourceFile(decl.parent) && decl.getSourceFile() === sourceFile; - } - return false; + function isDeclarationWithType(node) { + return isFunctionLikeDeclaration(node) || node.kind === 260 /* VariableDeclaration */ || node.kind === 171 /* PropertySignature */ || node.kind === 172 /* PropertyDeclaration */; } - function getDeclarationForBindingElement(element) { - while (true) { - if (isBindingElement(element.parent.parent)) { - element = element.parent.parent; - } else { - return element.parent.parent; - } + function transformJSDocType(node) { + switch (node.kind) { + case 319 /* JSDocAllType */: + case 320 /* JSDocUnknownType */: + return factory.createTypeReferenceNode("any", emptyArray); + case 323 /* JSDocOptionalType */: + return transformJSDocOptionalType(node); + case 322 /* JSDocNonNullableType */: + return transformJSDocType(node.type); + case 321 /* JSDocNullableType */: + return transformJSDocNullableType(node); + case 325 /* JSDocVariadicType */: + return transformJSDocVariadicType(node); + case 324 /* JSDocFunctionType */: + return transformJSDocFunctionType(node); + case 183 /* TypeReference */: + return transformJSDocTypeReference(node); + case 329 /* JSDocTypeLiteral */: + return transformJSDocTypeLiteral(node); + default: + const visited = visitEachChild(node, transformJSDocType, nullTransformationContext); + setEmitFlags(visited, 1 /* SingleLine */); + return visited; } } - function inImportClause(node) { - const parent2 = node.parent; - return parent2 && (isImportClause(parent2) || isImportSpecifier(parent2) || isNamespaceImport(parent2)); + function transformJSDocTypeLiteral(node) { + const typeNode = factory.createTypeLiteralNode(map(node.jsDocPropertyTags, (tag) => factory.createPropertySignature( + /*modifiers*/ + void 0, + isIdentifier(tag.name) ? tag.name : tag.name.right, + isOptionalJSDocPropertyLikeTag(tag) ? factory.createToken(58 /* QuestionToken */) : void 0, + tag.typeExpression && visitNode(tag.typeExpression.type, transformJSDocType, isTypeNode) || factory.createKeywordTypeNode(133 /* AnyKeyword */) + ))); + setEmitFlags(typeNode, 1 /* SingleLine */); + return typeNode; } - function isExpressionInCallExpression(node) { - while (isRightSideOfQualifiedNameOrPropertyAccess2(node)) { - node = node.parent; + function transformJSDocOptionalType(node) { + return factory.createUnionTypeNode([visitNode(node.type, transformJSDocType, isTypeNode), factory.createTypeReferenceNode("undefined", emptyArray)]); + } + function transformJSDocNullableType(node) { + return factory.createUnionTypeNode([visitNode(node.type, transformJSDocType, isTypeNode), factory.createTypeReferenceNode("null", emptyArray)]); + } + function transformJSDocVariadicType(node) { + return factory.createArrayTypeNode(visitNode(node.type, transformJSDocType, isTypeNode)); + } + function transformJSDocFunctionType(node) { + return factory.createFunctionTypeNode(emptyArray, node.parameters.map(transformJSDocParameter), node.type ?? factory.createKeywordTypeNode(133 /* AnyKeyword */)); + } + function transformJSDocParameter(node) { + const index = node.parent.parameters.indexOf(node); + const isRest = node.type.kind === 325 /* JSDocVariadicType */ && index === node.parent.parameters.length - 1; + const name = node.name || (isRest ? "rest" : "arg" + index); + const dotdotdot = isRest ? factory.createToken(26 /* DotDotDotToken */) : node.dotDotDotToken; + return factory.createParameterDeclaration(node.modifiers, dotdotdot, name, node.questionToken, visitNode(node.type, transformJSDocType, isTypeNode), node.initializer); + } + function transformJSDocTypeReference(node) { + let name = node.typeName; + let args = node.typeArguments; + if (isIdentifier(node.typeName)) { + if (isJSDocIndexSignature(node)) { + return transformJSDocIndexSignature(node); + } + let text = node.typeName.text; + switch (node.typeName.text) { + case "String": + case "Boolean": + case "Object": + case "Number": + text = text.toLowerCase(); + break; + case "array": + case "date": + case "promise": + text = text[0].toUpperCase() + text.slice(1); + break; + } + name = factory.createIdentifier(text); + if ((text === "Array" || text === "Promise") && !node.typeArguments) { + args = factory.createNodeArray([factory.createTypeReferenceNode("any", emptyArray)]); + } else { + args = visitNodes2(node.typeArguments, transformJSDocType, isTypeNode); + } } - return isCallExpression(node.parent) && node.parent.expression === node; + return factory.createTypeReferenceNode(name, args); } - function isRightSideOfQualifiedNameOrPropertyAccess2(node) { - return isQualifiedName(node.parent) && node.parent.right === node || isPropertyAccessExpression(node.parent) && node.parent.name === node; + function transformJSDocIndexSignature(node) { + const index = factory.createParameterDeclaration( + /*modifiers*/ + void 0, + /*dotDotDotToken*/ + void 0, + node.typeArguments[0].kind === 150 /* NumberKeyword */ ? "n" : "s", + /*questionToken*/ + void 0, + factory.createTypeReferenceNode(node.typeArguments[0].kind === 150 /* NumberKeyword */ ? "number" : "string", []), + /*initializer*/ + void 0 + ); + const indexSignature = factory.createTypeLiteralNode([factory.createIndexSignature( + /*modifiers*/ + void 0, + [index], + node.typeArguments[1] + )]); + setEmitFlags(indexSignature, 1 /* SingleLine */); + return indexSignature; } - var TokenEncodingConsts, TokenType, TokenModifier, tokenFromDeclarationMapping; - var init_classifier2020 = __esm({ - "src/services/classifier2020.ts"() { + var fixId8, errorCodes9; + var init_annotateWithTypeFromJSDoc = __esm({ + "src/services/codefixes/annotateWithTypeFromJSDoc.ts"() { "use strict"; init_ts4(); - TokenEncodingConsts = /* @__PURE__ */ ((TokenEncodingConsts2) => { - TokenEncodingConsts2[TokenEncodingConsts2["typeOffset"] = 8] = "typeOffset"; - TokenEncodingConsts2[TokenEncodingConsts2["modifierMask"] = 255] = "modifierMask"; - return TokenEncodingConsts2; - })(TokenEncodingConsts || {}); - TokenType = /* @__PURE__ */ ((TokenType2) => { - TokenType2[TokenType2["class"] = 0] = "class"; - TokenType2[TokenType2["enum"] = 1] = "enum"; - TokenType2[TokenType2["interface"] = 2] = "interface"; - TokenType2[TokenType2["namespace"] = 3] = "namespace"; - TokenType2[TokenType2["typeParameter"] = 4] = "typeParameter"; - TokenType2[TokenType2["type"] = 5] = "type"; - TokenType2[TokenType2["parameter"] = 6] = "parameter"; - TokenType2[TokenType2["variable"] = 7] = "variable"; - TokenType2[TokenType2["enumMember"] = 8] = "enumMember"; - TokenType2[TokenType2["property"] = 9] = "property"; - TokenType2[TokenType2["function"] = 10] = "function"; - TokenType2[TokenType2["member"] = 11] = "member"; - return TokenType2; - })(TokenType || {}); - TokenModifier = /* @__PURE__ */ ((TokenModifier2) => { - TokenModifier2[TokenModifier2["declaration"] = 0] = "declaration"; - TokenModifier2[TokenModifier2["static"] = 1] = "static"; - TokenModifier2[TokenModifier2["async"] = 2] = "async"; - TokenModifier2[TokenModifier2["readonly"] = 3] = "readonly"; - TokenModifier2[TokenModifier2["defaultLibrary"] = 4] = "defaultLibrary"; - TokenModifier2[TokenModifier2["local"] = 5] = "local"; - return TokenModifier2; - })(TokenModifier || {}); - tokenFromDeclarationMapping = /* @__PURE__ */ new Map([ - [259 /* VariableDeclaration */, 7 /* variable */], - [168 /* Parameter */, 6 /* parameter */], - [171 /* PropertyDeclaration */, 9 /* property */], - [266 /* ModuleDeclaration */, 3 /* namespace */], - [265 /* EnumDeclaration */, 1 /* enum */], - [305 /* EnumMember */, 8 /* enumMember */], - [262 /* ClassDeclaration */, 0 /* class */], - [173 /* MethodDeclaration */, 11 /* member */], - [261 /* FunctionDeclaration */, 10 /* function */], - [217 /* FunctionExpression */, 10 /* function */], - [172 /* MethodSignature */, 11 /* member */], - [176 /* GetAccessor */, 9 /* property */], - [177 /* SetAccessor */, 9 /* property */], - [170 /* PropertySignature */, 9 /* property */], - [263 /* InterfaceDeclaration */, 2 /* interface */], - [264 /* TypeAliasDeclaration */, 5 /* type */], - [167 /* TypeParameter */, 4 /* typeParameter */], - [302 /* PropertyAssignment */, 9 /* property */], - [303 /* ShorthandPropertyAssignment */, 9 /* property */] - ]); + init_ts_codefix(); + fixId8 = "annotateWithTypeFromJSDoc"; + errorCodes9 = [Diagnostics.JSDoc_types_may_be_moved_to_TypeScript_types.code]; + registerCodeFix({ + errorCodes: errorCodes9, + getCodeActions(context) { + const decl = getDeclaration(context.sourceFile, context.span.start); + if (!decl) + return; + const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange8(t, context.sourceFile, decl)); + return [createCodeFixAction(fixId8, changes, Diagnostics.Annotate_with_type_from_JSDoc, fixId8, Diagnostics.Annotate_everything_with_types_from_JSDoc)]; + }, + fixIds: [fixId8], + getAllCodeActions: (context) => codeFixAll(context, errorCodes9, (changes, diag2) => { + const decl = getDeclaration(diag2.file, diag2.start); + if (decl) + doChange8(changes, diag2.file, decl); + }) + }); } }); - // src/services/services.ts - function createNode(kind, pos, end, parent2) { - const node = isNodeKind(kind) ? new NodeObject(kind, pos, end) : kind === 80 /* Identifier */ ? new IdentifierObject(80 /* Identifier */, pos, end) : kind === 81 /* PrivateIdentifier */ ? new PrivateIdentifierObject(81 /* PrivateIdentifier */, pos, end) : new TokenObject(kind, pos, end); - node.parent = parent2; - node.flags = parent2.flags & 50720768 /* ContextFlags */; - return node; - } - function createChildren(node, sourceFile) { - if (!isNodeKind(node.kind)) { - return emptyArray; - } - const children = []; - if (isJSDocCommentContainingNode(node)) { - node.forEachChild((child) => { - children.push(child); - }); - return children; + // src/services/codefixes/convertFunctionToEs6Class.ts + function doChange9(changes, sourceFile, position, checker, preferences, compilerOptions) { + const ctorSymbol = checker.getSymbolAtLocation(getTokenAtPosition(sourceFile, position)); + if (!ctorSymbol || !ctorSymbol.valueDeclaration || !(ctorSymbol.flags & (16 /* Function */ | 3 /* Variable */))) { + return void 0; } - scanner.setText((sourceFile || node.getSourceFile()).text); - let pos = node.pos; - const processNode = (child) => { - addSyntheticNodes(children, pos, child.pos, node); - children.push(child); - pos = child.end; - }; - const processNodes = (nodes) => { - addSyntheticNodes(children, pos, nodes.pos, node); - children.push(createSyntaxList(nodes, node)); - pos = nodes.end; - }; - forEach(node.jsDoc, processNode); - pos = node.pos; - node.forEachChild(processNode, processNodes); - addSyntheticNodes(children, pos, node.end, node); - scanner.setText(void 0); - return children; - } - function addSyntheticNodes(nodes, pos, end, parent2) { - scanner.resetTokenState(pos); - while (pos < end) { - const token = scanner.scan(); - const textPos = scanner.getTokenEnd(); - if (textPos <= end) { - if (token === 80 /* Identifier */) { - if (hasTabstop(parent2)) { - continue; - } - Debug.fail(`Did not expect ${Debug.formatSyntaxKind(parent2.kind)} to have an Identifier in its trivia`); - } - nodes.push(createNode(token, pos, textPos, parent2)); + const ctorDeclaration = ctorSymbol.valueDeclaration; + if (isFunctionDeclaration(ctorDeclaration) || isFunctionExpression(ctorDeclaration)) { + changes.replaceNode(sourceFile, ctorDeclaration, createClassFromFunction(ctorDeclaration)); + } else if (isVariableDeclaration(ctorDeclaration)) { + const classDeclaration = createClassFromVariableDeclaration(ctorDeclaration); + if (!classDeclaration) { + return void 0; } - pos = textPos; - if (token === 1 /* EndOfFileToken */) { - break; + const ancestor = ctorDeclaration.parent.parent; + if (isVariableDeclarationList(ctorDeclaration.parent) && ctorDeclaration.parent.declarations.length > 1) { + changes.delete(sourceFile, ctorDeclaration); + changes.insertNodeAfter(sourceFile, ancestor, classDeclaration); + } else { + changes.replaceNode(sourceFile, ancestor, classDeclaration); } } - } - function createSyntaxList(nodes, parent2) { - const list = createNode(357 /* SyntaxList */, nodes.pos, nodes.end, parent2); - list._children = []; - let pos = nodes.pos; - for (const node of nodes) { - addSyntheticNodes(list._children, pos, node.pos, parent2); - list._children.push(node); - pos = node.end; - } - addSyntheticNodes(list._children, pos, nodes.end, parent2); - return list; - } - function hasJSDocInheritDocTag(node) { - return getJSDocTags(node).some((tag) => tag.tagName.text === "inheritDoc" || tag.tagName.text === "inheritdoc"); - } - function getJsDocTagsOfDeclarations(declarations, checker) { - if (!declarations) - return emptyArray; - let tags = ts_JsDoc_exports.getJsDocTagsFromDeclarations(declarations, checker); - if (checker && (tags.length === 0 || declarations.some(hasJSDocInheritDocTag))) { - const seenSymbols = /* @__PURE__ */ new Set(); - for (const declaration of declarations) { - const inheritedTags = findBaseOfDeclaration(checker, declaration, (symbol) => { - var _a; - if (!seenSymbols.has(symbol)) { - seenSymbols.add(symbol); - if (declaration.kind === 176 /* GetAccessor */ || declaration.kind === 177 /* SetAccessor */) { - return symbol.getContextualJsDocTags(declaration, checker); + function createClassElementsFromSymbol(symbol) { + const memberElements = []; + if (symbol.exports) { + symbol.exports.forEach((member) => { + if (member.name === "prototype" && member.declarations) { + const firstDeclaration = member.declarations[0]; + if (member.declarations.length === 1 && isPropertyAccessExpression(firstDeclaration) && isBinaryExpression(firstDeclaration.parent) && firstDeclaration.parent.operatorToken.kind === 64 /* EqualsToken */ && isObjectLiteralExpression(firstDeclaration.parent.right)) { + const prototypes = firstDeclaration.parent.right; + createClassElement( + prototypes.symbol, + /*modifiers*/ + void 0, + memberElements + ); } - return ((_a = symbol.declarations) == null ? void 0 : _a.length) === 1 ? symbol.getJsDocTags() : void 0; + } else { + createClassElement(member, [factory.createToken(126 /* StaticKeyword */)], memberElements); } }); - if (inheritedTags) { - tags = [...inheritedTags, ...tags]; + } + if (symbol.members) { + symbol.members.forEach((member, key) => { + var _a, _b, _c, _d; + if (key === "constructor" && member.valueDeclaration) { + const prototypeAssignment = (_d = (_c = (_b = (_a = symbol.exports) == null ? void 0 : _a.get("prototype")) == null ? void 0 : _b.declarations) == null ? void 0 : _c[0]) == null ? void 0 : _d.parent; + if (prototypeAssignment && isBinaryExpression(prototypeAssignment) && isObjectLiteralExpression(prototypeAssignment.right) && some(prototypeAssignment.right.properties, isConstructorAssignment)) { + } else { + changes.delete(sourceFile, member.valueDeclaration.parent); + } + return; + } + createClassElement( + member, + /*modifiers*/ + void 0, + memberElements + ); + }); + } + return memberElements; + function shouldConvertDeclaration(_target, source) { + if (isAccessExpression(_target)) { + if (isPropertyAccessExpression(_target) && isConstructorAssignment(_target)) + return true; + return isFunctionLike(source); + } else { + return every(_target.properties, (property) => { + if (isMethodDeclaration(property) || isGetOrSetAccessorDeclaration(property)) + return true; + if (isPropertyAssignment(property) && isFunctionExpression(property.initializer) && !!property.name) + return true; + if (isConstructorAssignment(property)) + return true; + return false; + }); + } + } + function createClassElement(symbol2, modifiers, members) { + if (!(symbol2.flags & 8192 /* Method */) && !(symbol2.flags & 4096 /* ObjectLiteral */)) { + return; + } + const memberDeclaration = symbol2.valueDeclaration; + const assignmentBinaryExpression = memberDeclaration.parent; + const assignmentExpr = assignmentBinaryExpression.right; + if (!shouldConvertDeclaration(memberDeclaration, assignmentExpr)) { + return; + } + if (some(members, (m) => { + const name = getNameOfDeclaration(m); + if (name && isIdentifier(name) && idText(name) === symbolName(symbol2)) { + return true; + } + return false; + })) { + return; + } + const nodeToDelete = assignmentBinaryExpression.parent && assignmentBinaryExpression.parent.kind === 244 /* ExpressionStatement */ ? assignmentBinaryExpression.parent : assignmentBinaryExpression; + changes.delete(sourceFile, nodeToDelete); + if (!assignmentExpr) { + members.push(factory.createPropertyDeclaration( + modifiers, + symbol2.name, + /*questionOrExclamationToken*/ + void 0, + /*type*/ + void 0, + /*initializer*/ + void 0 + )); + return; + } + if (isAccessExpression(memberDeclaration) && (isFunctionExpression(assignmentExpr) || isArrowFunction(assignmentExpr))) { + const quotePreference = getQuotePreference(sourceFile, preferences); + const name = tryGetPropertyName(memberDeclaration, compilerOptions, quotePreference); + if (name) { + createFunctionLikeExpressionMember(members, assignmentExpr, name); + } + return; + } else if (isObjectLiteralExpression(assignmentExpr)) { + forEach( + assignmentExpr.properties, + (property) => { + if (isMethodDeclaration(property) || isGetOrSetAccessorDeclaration(property)) { + members.push(property); + } + if (isPropertyAssignment(property) && isFunctionExpression(property.initializer)) { + createFunctionLikeExpressionMember(members, property.initializer, property.name); + } + if (isConstructorAssignment(property)) + return; + return; + } + ); + return; + } else { + if (isSourceFileJS(sourceFile)) + return; + if (!isPropertyAccessExpression(memberDeclaration)) + return; + const prop = factory.createPropertyDeclaration( + modifiers, + memberDeclaration.name, + /*questionOrExclamationToken*/ + void 0, + /*type*/ + void 0, + assignmentExpr + ); + copyLeadingComments(assignmentBinaryExpression.parent, prop, sourceFile); + members.push(prop); + return; + } + function createFunctionLikeExpressionMember(members2, expression, name) { + if (isFunctionExpression(expression)) + return createFunctionExpressionMember(members2, expression, name); + else + return createArrowFunctionExpressionMember(members2, expression, name); + } + function createFunctionExpressionMember(members2, functionExpression, name) { + const fullModifiers = concatenate(modifiers, getModifierKindFromSource(functionExpression, 134 /* AsyncKeyword */)); + const method = factory.createMethodDeclaration( + fullModifiers, + /*asteriskToken*/ + void 0, + name, + /*questionToken*/ + void 0, + /*typeParameters*/ + void 0, + functionExpression.parameters, + /*type*/ + void 0, + functionExpression.body + ); + copyLeadingComments(assignmentBinaryExpression, method, sourceFile); + members2.push(method); + return; + } + function createArrowFunctionExpressionMember(members2, arrowFunction, name) { + const arrowFunctionBody = arrowFunction.body; + let bodyBlock; + if (arrowFunctionBody.kind === 241 /* Block */) { + bodyBlock = arrowFunctionBody; + } else { + bodyBlock = factory.createBlock([factory.createReturnStatement(arrowFunctionBody)]); + } + const fullModifiers = concatenate(modifiers, getModifierKindFromSource(arrowFunction, 134 /* AsyncKeyword */)); + const method = factory.createMethodDeclaration( + fullModifiers, + /*asteriskToken*/ + void 0, + name, + /*questionToken*/ + void 0, + /*typeParameters*/ + void 0, + arrowFunction.parameters, + /*type*/ + void 0, + bodyBlock + ); + copyLeadingComments(assignmentBinaryExpression, method, sourceFile); + members2.push(method); } } } - return tags; - } - function getDocumentationComment(declarations, checker) { - if (!declarations) - return emptyArray; - let doc = ts_JsDoc_exports.getJsDocCommentsFromDeclarations(declarations, checker); - if (checker && (doc.length === 0 || declarations.some(hasJSDocInheritDocTag))) { - const seenSymbols = /* @__PURE__ */ new Set(); - for (const declaration of declarations) { - const inheritedDocs = findBaseOfDeclaration(checker, declaration, (symbol) => { - if (!seenSymbols.has(symbol)) { - seenSymbols.add(symbol); - if (declaration.kind === 176 /* GetAccessor */ || declaration.kind === 177 /* SetAccessor */) { - return symbol.getContextualDocumentationComment(declaration, checker); - } - return symbol.getDocumentationComment(checker); - } - }); - if (inheritedDocs) - doc = doc.length === 0 ? inheritedDocs.slice() : inheritedDocs.concat(lineBreakPart(), doc); + function createClassFromVariableDeclaration(node) { + const initializer = node.initializer; + if (!initializer || !isFunctionExpression(initializer) || !isIdentifier(node.name)) { + return void 0; + } + const memberElements = createClassElementsFromSymbol(node.symbol); + if (initializer.body) { + memberElements.unshift(factory.createConstructorDeclaration( + /*modifiers*/ + void 0, + initializer.parameters, + initializer.body + )); + } + const modifiers = getModifierKindFromSource(node.parent.parent, 95 /* ExportKeyword */); + const cls = factory.createClassDeclaration( + modifiers, + node.name, + /*typeParameters*/ + void 0, + /*heritageClauses*/ + void 0, + memberElements + ); + return cls; + } + function createClassFromFunction(node) { + const memberElements = createClassElementsFromSymbol(ctorSymbol); + if (node.body) { + memberElements.unshift(factory.createConstructorDeclaration( + /*modifiers*/ + void 0, + node.parameters, + node.body + )); } + const modifiers = getModifierKindFromSource(node, 95 /* ExportKeyword */); + const cls = factory.createClassDeclaration( + modifiers, + node.name, + /*typeParameters*/ + void 0, + /*heritageClauses*/ + void 0, + memberElements + ); + return cls; } - return doc; } - function findBaseOfDeclaration(checker, declaration, cb) { - var _a; - const classOrInterfaceDeclaration = ((_a = declaration.parent) == null ? void 0 : _a.kind) === 175 /* Constructor */ ? declaration.parent.parent : declaration.parent; - if (!classOrInterfaceDeclaration) - return; - const isStaticMember = hasStaticModifier(declaration); - return firstDefined(getAllSuperTypeNodes(classOrInterfaceDeclaration), (superTypeNode) => { - const baseType = checker.getTypeAtLocation(superTypeNode); - const type = isStaticMember && baseType.symbol ? checker.getTypeOfSymbol(baseType.symbol) : baseType; - const symbol = checker.getPropertyOfType(type, declaration.symbol.name); - return symbol ? cb(symbol) : void 0; - }); + function getModifierKindFromSource(source, kind) { + return canHaveModifiers(source) ? filter(source.modifiers, (modifier) => modifier.kind === kind) : void 0; } - function getServicesObjectAllocator() { - return { - getNodeConstructor: () => NodeObject, - getTokenConstructor: () => TokenObject, - getIdentifierConstructor: () => IdentifierObject, - getPrivateIdentifierConstructor: () => PrivateIdentifierObject, - getSourceFileConstructor: () => SourceFileObject, - getSymbolConstructor: () => SymbolObject, - getTypeConstructor: () => TypeObject, - getSignatureConstructor: () => SignatureObject, - getSourceMapSourceConstructor: () => SourceMapSourceObject - }; + function isConstructorAssignment(x) { + if (!x.name) + return false; + if (isIdentifier(x.name) && x.name.text === "constructor") + return true; + return false; } - function toEditorSettings(optionsAsMap) { - let allPropertiesAreCamelCased = true; - for (const key in optionsAsMap) { - if (hasProperty(optionsAsMap, key) && !isCamelCase(key)) { - allPropertiesAreCamelCased = false; - break; - } - } - if (allPropertiesAreCamelCased) { - return optionsAsMap; + function tryGetPropertyName(node, compilerOptions, quotePreference) { + if (isPropertyAccessExpression(node)) { + return node.name; } - const settings = {}; - for (const key in optionsAsMap) { - if (hasProperty(optionsAsMap, key)) { - const newKey = isCamelCase(key) ? key : key.charAt(0).toLowerCase() + key.substr(1); - settings[newKey] = optionsAsMap[key]; - } + const propName = node.argumentExpression; + if (isNumericLiteral(propName)) { + return propName; } - return settings; - } - function isCamelCase(s) { - return !s.length || s.charAt(0) === s.charAt(0).toLowerCase(); - } - function displayPartsToString(displayParts) { - if (displayParts) { - return map(displayParts, (displayPart2) => displayPart2.text).join(""); + if (isStringLiteralLike(propName)) { + return isIdentifierText(propName.text, getEmitScriptTarget(compilerOptions)) ? factory.createIdentifier(propName.text) : isNoSubstitutionTemplateLiteral(propName) ? factory.createStringLiteral(propName.text, quotePreference === 0 /* Single */) : propName; } - return ""; - } - function getDefaultCompilerOptions2() { - return { - target: 1 /* ES5 */, - jsx: 1 /* Preserve */ - }; - } - function getSupportedCodeFixes() { - return ts_codefix_exports.getSupportedErrorCodes(); - } - function setSourceFileFields(sourceFile, scriptSnapshot, version2) { - sourceFile.version = version2; - sourceFile.scriptSnapshot = scriptSnapshot; - } - function createLanguageServiceSourceFile(fileName, scriptSnapshot, scriptTargetOrOptions, version2, setNodeParents, scriptKind) { - const sourceFile = createSourceFile(fileName, getSnapshotText(scriptSnapshot), scriptTargetOrOptions, setNodeParents, scriptKind); - setSourceFileFields(sourceFile, scriptSnapshot, version2); - return sourceFile; + return void 0; } - function updateLanguageServiceSourceFile(sourceFile, scriptSnapshot, version2, textChangeRange, aggressiveChecks) { - if (textChangeRange) { - if (version2 !== sourceFile.version) { - let newText; - const prefix = textChangeRange.span.start !== 0 ? sourceFile.text.substr(0, textChangeRange.span.start) : ""; - const suffix = textSpanEnd(textChangeRange.span) !== sourceFile.text.length ? sourceFile.text.substr(textSpanEnd(textChangeRange.span)) : ""; - if (textChangeRange.newLength === 0) { - newText = prefix && suffix ? prefix + suffix : prefix || suffix; - } else { - const changedText = scriptSnapshot.getText(textChangeRange.span.start, textChangeRange.span.start + textChangeRange.newLength); - newText = prefix && suffix ? prefix + changedText + suffix : prefix ? prefix + changedText : changedText + suffix; - } - const newSourceFile = updateSourceFile(sourceFile, newText, textChangeRange, aggressiveChecks); - setSourceFileFields(newSourceFile, scriptSnapshot, version2); - newSourceFile.nameTable = void 0; - if (sourceFile !== newSourceFile && sourceFile.scriptSnapshot) { - if (sourceFile.scriptSnapshot.dispose) { - sourceFile.scriptSnapshot.dispose(); - } - sourceFile.scriptSnapshot = void 0; - } - return newSourceFile; - } + var fixId9, errorCodes10; + var init_convertFunctionToEs6Class = __esm({ + "src/services/codefixes/convertFunctionToEs6Class.ts"() { + "use strict"; + init_ts4(); + init_ts_codefix(); + fixId9 = "convertFunctionToEs6Class"; + errorCodes10 = [Diagnostics.This_constructor_function_may_be_converted_to_a_class_declaration.code]; + registerCodeFix({ + errorCodes: errorCodes10, + getCodeActions(context) { + const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange9(t, context.sourceFile, context.span.start, context.program.getTypeChecker(), context.preferences, context.program.getCompilerOptions())); + return [createCodeFixAction(fixId9, changes, Diagnostics.Convert_function_to_an_ES2015_class, fixId9, Diagnostics.Convert_all_constructor_functions_to_classes)]; + }, + fixIds: [fixId9], + getAllCodeActions: (context) => codeFixAll(context, errorCodes10, (changes, err) => doChange9(changes, err.file, err.start, context.program.getTypeChecker(), context.preferences, context.program.getCompilerOptions())) + }); } - const options = { - languageVersion: sourceFile.languageVersion, - impliedNodeFormat: sourceFile.impliedNodeFormat, - setExternalModuleIndicator: sourceFile.setExternalModuleIndicator - }; - return createLanguageServiceSourceFile( - sourceFile.fileName, - scriptSnapshot, - options, - version2, - /*setNodeParents*/ - true, - sourceFile.scriptKind - ); - } - function createLanguageService(host, documentRegistry = createDocumentRegistry(host.useCaseSensitiveFileNames && host.useCaseSensitiveFileNames(), host.getCurrentDirectory()), syntaxOnlyOrLanguageServiceMode) { - var _a; - let languageServiceMode; - if (syntaxOnlyOrLanguageServiceMode === void 0) { - languageServiceMode = 0 /* Semantic */; - } else if (typeof syntaxOnlyOrLanguageServiceMode === "boolean") { - languageServiceMode = syntaxOnlyOrLanguageServiceMode ? 2 /* Syntactic */ : 0 /* Semantic */; + }); + + // src/services/codefixes/convertToAsyncFunction.ts + function convertToAsyncFunction(changes, sourceFile, position, checker) { + const tokenAtPosition = getTokenAtPosition(sourceFile, position); + let functionToConvert; + if (isIdentifier(tokenAtPosition) && isVariableDeclaration(tokenAtPosition.parent) && tokenAtPosition.parent.initializer && isFunctionLikeDeclaration(tokenAtPosition.parent.initializer)) { + functionToConvert = tokenAtPosition.parent.initializer; } else { - languageServiceMode = syntaxOnlyOrLanguageServiceMode; + functionToConvert = tryCast(getContainingFunction(getTokenAtPosition(sourceFile, position)), canBeConvertedToAsync); } - const syntaxTreeCache = new SyntaxTreeCache(host); - let program; - let lastProjectVersion; - let lastTypesRootVersion = 0; - const cancellationToken = host.getCancellationToken ? new CancellationTokenObject(host.getCancellationToken()) : NoopCancellationToken; - const currentDirectory = host.getCurrentDirectory(); - maybeSetLocalizedDiagnosticMessages((_a = host.getLocalizedDiagnosticMessages) == null ? void 0 : _a.bind(host)); - function log(message) { - if (host.log) { - host.log(message); - } + if (!functionToConvert) { + return; } - const useCaseSensitiveFileNames = hostUsesCaseSensitiveFileNames(host); - const getCanonicalFileName = createGetCanonicalFileName(useCaseSensitiveFileNames); - const sourceMapper = getSourceMapper({ - useCaseSensitiveFileNames: () => useCaseSensitiveFileNames, - getCurrentDirectory: () => currentDirectory, - getProgram, - fileExists: maybeBind(host, host.fileExists), - readFile: maybeBind(host, host.readFile), - getDocumentPositionMapper: maybeBind(host, host.getDocumentPositionMapper), - getSourceFileLike: maybeBind(host, host.getSourceFileLike), - log - }); - function getValidSourceFile(fileName) { - const sourceFile = program.getSourceFile(fileName); - if (!sourceFile) { - const error = new Error(`Could not find source file: '${fileName}'.`); - error.ProgramFiles = program.getSourceFiles().map((f) => f.fileName); - throw error; - } - return sourceFile; + const synthNamesMap = /* @__PURE__ */ new Map(); + const isInJavascript = isInJSFile(functionToConvert); + const setOfExpressionsToReturn = getAllPromiseExpressionsToReturn(functionToConvert, checker); + const functionToConvertRenamed = renameCollidingVarNames(functionToConvert, checker, synthNamesMap); + if (!returnsPromise(functionToConvertRenamed, checker)) { + return; } - function synchronizeHostData() { - var _a2, _b, _c; - Debug.assert(languageServiceMode !== 2 /* Syntactic */); - if (host.getProjectVersion) { - const hostProjectVersion = host.getProjectVersion(); - if (hostProjectVersion) { - if (lastProjectVersion === hostProjectVersion && !((_a2 = host.hasChangedAutomaticTypeDirectiveNames) == null ? void 0 : _a2.call(host))) { - return; + const returnStatements = functionToConvertRenamed.body && isBlock(functionToConvertRenamed.body) ? getReturnStatementsWithPromiseHandlers(functionToConvertRenamed.body, checker) : emptyArray; + const transformer = { checker, synthNamesMap, setOfExpressionsToReturn, isInJSFile: isInJavascript }; + if (!returnStatements.length) { + return; + } + const pos = skipTrivia(sourceFile.text, moveRangePastModifiers(functionToConvert).pos); + changes.insertModifierAt(sourceFile, pos, 134 /* AsyncKeyword */, { suffix: " " }); + for (const returnStatement of returnStatements) { + forEachChild(returnStatement, function visit(node) { + if (isCallExpression(node)) { + const newNodes = transformExpression( + node, + node, + transformer, + /*hasContinuation*/ + false + ); + if (hasFailed()) { + return true; + } + changes.replaceNodeWithNodes(sourceFile, returnStatement, newNodes); + } else if (!isFunctionLike(node)) { + forEachChild(node, visit); + if (hasFailed()) { + return true; } - lastProjectVersion = hostProjectVersion; } - } - const typeRootsVersion = host.getTypeRootsVersion ? host.getTypeRootsVersion() : 0; - if (lastTypesRootVersion !== typeRootsVersion) { - log("TypeRoots version has changed; provide new program"); - program = void 0; - lastTypesRootVersion = typeRootsVersion; - } - const rootFileNames = host.getScriptFileNames().slice(); - const newSettings = host.getCompilationSettings() || getDefaultCompilerOptions2(); - const hasInvalidatedResolutions = host.hasInvalidatedResolutions || returnFalse; - const hasInvalidatedLibResolutions = maybeBind(host, host.hasInvalidatedLibResolutions) || returnFalse; - const hasChangedAutomaticTypeDirectiveNames = maybeBind(host, host.hasChangedAutomaticTypeDirectiveNames); - const projectReferences = (_b = host.getProjectReferences) == null ? void 0 : _b.call(host); - let parsedCommandLines; - let compilerHost = { - getSourceFile: getOrCreateSourceFile, - getSourceFileByPath: getOrCreateSourceFileByPath, - getCancellationToken: () => cancellationToken, - getCanonicalFileName, - useCaseSensitiveFileNames: () => useCaseSensitiveFileNames, - getNewLine: () => getNewLineCharacter(newSettings), - getDefaultLibFileName: (options2) => host.getDefaultLibFileName(options2), - writeFile: noop, - getCurrentDirectory: () => currentDirectory, - fileExists: (fileName) => host.fileExists(fileName), - readFile: (fileName) => host.readFile && host.readFile(fileName), - getSymlinkCache: maybeBind(host, host.getSymlinkCache), - realpath: maybeBind(host, host.realpath), - directoryExists: (directoryName) => { - return directoryProbablyExists(directoryName, host); - }, - getDirectories: (path) => { - return host.getDirectories ? host.getDirectories(path) : []; - }, - readDirectory: (path, extensions, exclude, include, depth) => { - Debug.checkDefined(host.readDirectory, "'LanguageServiceHost.readDirectory' must be implemented to correctly process 'projectReferences'"); - return host.readDirectory(path, extensions, exclude, include, depth); - }, - onReleaseOldSourceFile, - onReleaseParsedCommandLine, - hasInvalidatedResolutions, - hasInvalidatedLibResolutions, - hasChangedAutomaticTypeDirectiveNames, - trace: maybeBind(host, host.trace), - resolveModuleNames: maybeBind(host, host.resolveModuleNames), - getModuleResolutionCache: maybeBind(host, host.getModuleResolutionCache), - createHash: maybeBind(host, host.createHash), - resolveTypeReferenceDirectives: maybeBind(host, host.resolveTypeReferenceDirectives), - resolveModuleNameLiterals: maybeBind(host, host.resolveModuleNameLiterals), - resolveTypeReferenceDirectiveReferences: maybeBind(host, host.resolveTypeReferenceDirectiveReferences), - resolveLibrary: maybeBind(host, host.resolveLibrary), - useSourceOfProjectReferenceRedirect: maybeBind(host, host.useSourceOfProjectReferenceRedirect), - getParsedCommandLine - }; - const originalGetSourceFile = compilerHost.getSourceFile; - const { getSourceFileWithCache } = changeCompilerHostLikeToUseCache( - compilerHost, - (fileName) => toPath(fileName, currentDirectory, getCanonicalFileName), - (...args) => originalGetSourceFile.call(compilerHost, ...args) - ); - compilerHost.getSourceFile = getSourceFileWithCache; - (_c = host.setCompilerHost) == null ? void 0 : _c.call(host, compilerHost); - const parseConfigHost = { - useCaseSensitiveFileNames, - fileExists: (fileName) => compilerHost.fileExists(fileName), - readFile: (fileName) => compilerHost.readFile(fileName), - readDirectory: (...args) => compilerHost.readDirectory(...args), - trace: compilerHost.trace, - getCurrentDirectory: compilerHost.getCurrentDirectory, - onUnRecoverableConfigFileDiagnostic: noop - }; - const documentRegistryBucketKey = documentRegistry.getKeyForCompilationSettings(newSettings); - let releasedScriptKinds = /* @__PURE__ */ new Set(); - if (isProgramUptoDate(program, rootFileNames, newSettings, (_path, fileName) => host.getScriptVersion(fileName), (fileName) => compilerHost.fileExists(fileName), hasInvalidatedResolutions, hasInvalidatedLibResolutions, hasChangedAutomaticTypeDirectiveNames, getParsedCommandLine, projectReferences)) { - compilerHost = void 0; - parsedCommandLines = void 0; - releasedScriptKinds = void 0; + }); + if (hasFailed()) { return; } - const options = { - rootNames: rootFileNames, - options: newSettings, - host: compilerHost, - oldProgram: program, - projectReferences - }; - program = createProgram(options); - compilerHost = void 0; - parsedCommandLines = void 0; - releasedScriptKinds = void 0; - sourceMapper.clearCache(); - program.getTypeChecker(); - return; - function getParsedCommandLine(fileName) { - const path = toPath(fileName, currentDirectory, getCanonicalFileName); - const existing = parsedCommandLines == null ? void 0 : parsedCommandLines.get(path); - if (existing !== void 0) - return existing || void 0; - const result = host.getParsedCommandLine ? host.getParsedCommandLine(fileName) : getParsedCommandLineOfConfigFileUsingSourceFile(fileName); - (parsedCommandLines || (parsedCommandLines = /* @__PURE__ */ new Map())).set(path, result || false); - return result; - } - function getParsedCommandLineOfConfigFileUsingSourceFile(configFileName) { - const result = getOrCreateSourceFile(configFileName, 100 /* JSON */); - if (!result) - return void 0; - result.path = toPath(configFileName, currentDirectory, getCanonicalFileName); - result.resolvedPath = result.path; - result.originalFileName = result.fileName; - return parseJsonSourceFileConfigFileContent( - result, - parseConfigHost, - getNormalizedAbsolutePath(getDirectoryPath(configFileName), currentDirectory), - /*existingOptions*/ - void 0, - getNormalizedAbsolutePath(configFileName, currentDirectory) - ); - } - function onReleaseParsedCommandLine(configFileName, oldResolvedRef, oldOptions) { - var _a3; - if (host.getParsedCommandLine) { - (_a3 = host.onReleaseParsedCommandLine) == null ? void 0 : _a3.call(host, configFileName, oldResolvedRef, oldOptions); - } else if (oldResolvedRef) { - onReleaseOldSourceFile(oldResolvedRef.sourceFile, oldOptions); - } - } - function onReleaseOldSourceFile(oldSourceFile, oldOptions) { - const oldSettingsKey = documentRegistry.getKeyForCompilationSettings(oldOptions); - documentRegistry.releaseDocumentWithKey(oldSourceFile.resolvedPath, oldSettingsKey, oldSourceFile.scriptKind, oldSourceFile.impliedNodeFormat); - } - function getOrCreateSourceFile(fileName, languageVersionOrOptions, onError, shouldCreateNewSourceFile) { - return getOrCreateSourceFileByPath(fileName, toPath(fileName, currentDirectory, getCanonicalFileName), languageVersionOrOptions, onError, shouldCreateNewSourceFile); + } + } + function getReturnStatementsWithPromiseHandlers(body, checker) { + const res = []; + forEachReturnStatement(body, (ret) => { + if (isReturnStatementWithFixablePromiseHandler(ret, checker)) + res.push(ret); + }); + return res; + } + function getAllPromiseExpressionsToReturn(func, checker) { + if (!func.body) { + return /* @__PURE__ */ new Set(); + } + const setOfExpressionsToReturn = /* @__PURE__ */ new Set(); + forEachChild(func.body, function visit(node) { + if (isPromiseReturningCallExpression(node, checker, "then")) { + setOfExpressionsToReturn.add(getNodeId(node)); + forEach(node.arguments, visit); + } else if (isPromiseReturningCallExpression(node, checker, "catch") || isPromiseReturningCallExpression(node, checker, "finally")) { + setOfExpressionsToReturn.add(getNodeId(node)); + forEachChild(node, visit); + } else if (isPromiseTypedExpression(node, checker)) { + setOfExpressionsToReturn.add(getNodeId(node)); + } else { + forEachChild(node, visit); } - function getOrCreateSourceFileByPath(fileName, path, languageVersionOrOptions, _onError, shouldCreateNewSourceFile) { - Debug.assert(compilerHost, "getOrCreateSourceFileByPath called after typical CompilerHost lifetime, check the callstack something with a reference to an old host."); - const scriptSnapshot = host.getScriptSnapshot(fileName); - if (!scriptSnapshot) { - return void 0; - } - const scriptKind = getScriptKind(fileName, host); - const scriptVersion = host.getScriptVersion(fileName); - if (!shouldCreateNewSourceFile) { - const oldSourceFile = program && program.getSourceFileByPath(path); - if (oldSourceFile) { - if (scriptKind === oldSourceFile.scriptKind || releasedScriptKinds.has(oldSourceFile.resolvedPath)) { - return documentRegistry.updateDocumentWithKey(fileName, path, host, documentRegistryBucketKey, scriptSnapshot, scriptVersion, scriptKind, languageVersionOrOptions); - } else { - documentRegistry.releaseDocumentWithKey(oldSourceFile.resolvedPath, documentRegistry.getKeyForCompilationSettings(program.getCompilerOptions()), oldSourceFile.scriptKind, oldSourceFile.impliedNodeFormat); - releasedScriptKinds.add(oldSourceFile.resolvedPath); - } - } + }); + return setOfExpressionsToReturn; + } + function isPromiseReturningCallExpression(node, checker, name) { + if (!isCallExpression(node)) + return false; + const isExpressionOfName = hasPropertyAccessExpressionWithName(node, name); + const nodeType = isExpressionOfName && checker.getTypeAtLocation(node); + return !!(nodeType && checker.getPromisedTypeOfPromise(nodeType)); + } + function isReferenceToType(type, target) { + return (getObjectFlags(type) & 4 /* Reference */) !== 0 && type.target === target; + } + function getExplicitPromisedTypeOfPromiseReturningCallExpression(node, callback, checker) { + if (node.expression.name.escapedText === "finally") { + return void 0; + } + const promiseType = checker.getTypeAtLocation(node.expression.expression); + if (isReferenceToType(promiseType, checker.getPromiseType()) || isReferenceToType(promiseType, checker.getPromiseLikeType())) { + if (node.expression.name.escapedText === "then") { + if (callback === elementAt(node.arguments, 0)) { + return elementAt(node.typeArguments, 0); + } else if (callback === elementAt(node.arguments, 1)) { + return elementAt(node.typeArguments, 1); } - return documentRegistry.acquireDocumentWithKey(fileName, path, host, documentRegistryBucketKey, scriptSnapshot, scriptVersion, scriptKind, languageVersionOrOptions); + } else { + return elementAt(node.typeArguments, 0); } } - function getProgram() { - if (languageServiceMode === 2 /* Syntactic */) { - Debug.assert(program === void 0); - return void 0; + } + function isPromiseTypedExpression(node, checker) { + if (!isExpression(node)) + return false; + return !!checker.getPromisedTypeOfPromise(checker.getTypeAtLocation(node)); + } + function renameCollidingVarNames(nodeToRename, checker, synthNamesMap) { + const identsToRenameMap = /* @__PURE__ */ new Map(); + const collidingSymbolMap = createMultiMap(); + forEachChild(nodeToRename, function visit(node) { + if (!isIdentifier(node)) { + forEachChild(node, visit); + return; } - synchronizeHostData(); - return program; - } - function getAutoImportProvider() { - var _a2; - return (_a2 = host.getPackageJsonAutoImportProvider) == null ? void 0 : _a2.call(host); - } - function updateIsDefinitionOfReferencedSymbols(referencedSymbols, knownSymbolSpans) { - const checker = program.getTypeChecker(); - const symbol = getSymbolForProgram(); - if (!symbol) - return false; - for (const referencedSymbol of referencedSymbols) { - for (const ref of referencedSymbol.references) { - const refNode = getNodeForSpan(ref); - Debug.assertIsDefined(refNode); - if (knownSymbolSpans.has(ref) || ts_FindAllReferences_exports.isDeclarationOfSymbol(refNode, symbol)) { - knownSymbolSpans.add(ref); - ref.isDefinition = true; - const mappedSpan = getMappedDocumentSpan(ref, sourceMapper, maybeBind(host, host.fileExists)); - if (mappedSpan) { - knownSymbolSpans.add(mappedSpan); - } + const symbol = checker.getSymbolAtLocation(node); + if (symbol) { + const type = checker.getTypeAtLocation(node); + const lastCallSignature = getLastCallSignature(type, checker); + const symbolIdString = getSymbolId(symbol).toString(); + if (lastCallSignature && !isParameter(node.parent) && !isFunctionLikeDeclaration(node.parent) && !synthNamesMap.has(symbolIdString)) { + const firstParameter = firstOrUndefined(lastCallSignature.parameters); + const ident = (firstParameter == null ? void 0 : firstParameter.valueDeclaration) && isParameter(firstParameter.valueDeclaration) && tryCast(firstParameter.valueDeclaration.name, isIdentifier) || factory.createUniqueName("result", 16 /* Optimistic */); + const synthName = getNewNameIfConflict(ident, collidingSymbolMap); + synthNamesMap.set(symbolIdString, synthName); + collidingSymbolMap.add(ident.text, symbol); + } else if (node.parent && (isParameter(node.parent) || isVariableDeclaration(node.parent) || isBindingElement(node.parent))) { + const originalName = node.text; + const collidingSymbols = collidingSymbolMap.get(originalName); + if (collidingSymbols && collidingSymbols.some((prevSymbol) => prevSymbol !== symbol)) { + const newName = getNewNameIfConflict(node, collidingSymbolMap); + identsToRenameMap.set(symbolIdString, newName.identifier); + synthNamesMap.set(symbolIdString, newName); + collidingSymbolMap.add(originalName, symbol); } else { - ref.isDefinition = false; + const identifier = getSynthesizedDeepClone(node); + synthNamesMap.set(symbolIdString, createSynthIdentifier(identifier)); + collidingSymbolMap.add(originalName, symbol); } } } - return true; - function getSymbolForProgram() { - for (const referencedSymbol of referencedSymbols) { - for (const ref of referencedSymbol.references) { - if (knownSymbolSpans.has(ref)) { - const refNode = getNodeForSpan(ref); - Debug.assertIsDefined(refNode); - return checker.getSymbolAtLocation(refNode); - } - const mappedSpan = getMappedDocumentSpan(ref, sourceMapper, maybeBind(host, host.fileExists)); - if (mappedSpan && knownSymbolSpans.has(mappedSpan)) { - const refNode = getNodeForSpan(mappedSpan); - if (refNode) { - return checker.getSymbolAtLocation(refNode); - } - } + }); + return getSynthesizedDeepCloneWithReplacements( + nodeToRename, + /*includeTrivia*/ + true, + (original) => { + if (isBindingElement(original) && isIdentifier(original.name) && isObjectBindingPattern(original.parent)) { + const symbol = checker.getSymbolAtLocation(original.name); + const renameInfo = symbol && identsToRenameMap.get(String(getSymbolId(symbol))); + if (renameInfo && renameInfo.text !== (original.name || original.propertyName).getText()) { + return factory.createBindingElement( + original.dotDotDotToken, + original.propertyName || original.name, + renameInfo, + original.initializer + ); + } + } else if (isIdentifier(original)) { + const symbol = checker.getSymbolAtLocation(original); + const renameInfo = symbol && identsToRenameMap.get(String(getSymbolId(symbol))); + if (renameInfo) { + return factory.createIdentifier(renameInfo.text); } } - return void 0; - } - function getNodeForSpan(docSpan) { - const sourceFile = program.getSourceFile(docSpan.fileName); - if (!sourceFile) - return void 0; - const rawNode = getTouchingPropertyName(sourceFile, docSpan.textSpan.start); - const adjustedNode = ts_FindAllReferences_exports.Core.getAdjustedNode(rawNode, { use: ts_FindAllReferences_exports.FindReferencesUse.References }); - return adjustedNode; } + ); + } + function getNewNameIfConflict(name, originalNames) { + const numVarsSameName = (originalNames.get(name.text) || emptyArray).length; + const identifier = numVarsSameName === 0 ? name : factory.createIdentifier(name.text + "_" + numVarsSameName); + return createSynthIdentifier(identifier); + } + function hasFailed() { + return !codeActionSucceeded; + } + function silentFail() { + codeActionSucceeded = false; + return emptyArray; + } + function transformExpression(returnContextNode, node, transformer, hasContinuation, continuationArgName) { + if (isPromiseReturningCallExpression(node, transformer.checker, "then")) { + return transformThen(node, elementAt(node.arguments, 0), elementAt(node.arguments, 1), transformer, hasContinuation, continuationArgName); } - function cleanupSemanticCache() { - program = void 0; + if (isPromiseReturningCallExpression(node, transformer.checker, "catch")) { + return transformCatch(node, elementAt(node.arguments, 0), transformer, hasContinuation, continuationArgName); } - function dispose() { - if (program) { - const key = documentRegistry.getKeyForCompilationSettings(program.getCompilerOptions()); - forEach(program.getSourceFiles(), (f) => documentRegistry.releaseDocumentWithKey(f.resolvedPath, key, f.scriptKind, f.impliedNodeFormat)); - program = void 0; - } - host = void 0; + if (isPromiseReturningCallExpression(node, transformer.checker, "finally")) { + return transformFinally(node, elementAt(node.arguments, 0), transformer, hasContinuation, continuationArgName); } - function getSyntacticDiagnostics(fileName) { - synchronizeHostData(); - return program.getSyntacticDiagnostics(getValidSourceFile(fileName), cancellationToken).slice(); + if (isPropertyAccessExpression(node)) { + return transformExpression(returnContextNode, node.expression, transformer, hasContinuation, continuationArgName); } - function getSemanticDiagnostics(fileName) { - synchronizeHostData(); - const targetSourceFile = getValidSourceFile(fileName); - const semanticDiagnostics = program.getSemanticDiagnostics(targetSourceFile, cancellationToken); - if (!getEmitDeclarations(program.getCompilerOptions())) { - return semanticDiagnostics.slice(); - } - const declarationDiagnostics = program.getDeclarationDiagnostics(targetSourceFile, cancellationToken); - return [...semanticDiagnostics, ...declarationDiagnostics]; + const nodeType = transformer.checker.getTypeAtLocation(node); + if (nodeType && transformer.checker.getPromisedTypeOfPromise(nodeType)) { + Debug.assertNode(getOriginalNode(node).parent, isPropertyAccessExpression); + return transformPromiseExpressionOfPropertyAccess(returnContextNode, node, transformer, hasContinuation, continuationArgName); } - function getSuggestionDiagnostics(fileName) { - synchronizeHostData(); - return computeSuggestionDiagnostics(getValidSourceFile(fileName), program, cancellationToken); + return silentFail(); + } + function isNullOrUndefined2({ checker }, node) { + if (node.kind === 106 /* NullKeyword */) + return true; + if (isIdentifier(node) && !isGeneratedIdentifier(node) && idText(node) === "undefined") { + const symbol = checker.getSymbolAtLocation(node); + return !symbol || checker.isUndefinedSymbol(symbol); } - function getCompilerOptionsDiagnostics() { - synchronizeHostData(); - return [...program.getOptionsDiagnostics(cancellationToken), ...program.getGlobalDiagnostics(cancellationToken)]; + return false; + } + function createUniqueSynthName(prevArgName) { + const renamedPrevArg = factory.createUniqueName(prevArgName.identifier.text, 16 /* Optimistic */); + return createSynthIdentifier(renamedPrevArg); + } + function getPossibleNameForVarDecl(node, transformer, continuationArgName) { + let possibleNameForVarDecl; + if (continuationArgName && !shouldReturn(node, transformer)) { + if (isSynthIdentifier(continuationArgName)) { + possibleNameForVarDecl = continuationArgName; + transformer.synthNamesMap.forEach((val, key) => { + if (val.identifier.text === continuationArgName.identifier.text) { + const newSynthName = createUniqueSynthName(continuationArgName); + transformer.synthNamesMap.set(key, newSynthName); + } + }); + } else { + possibleNameForVarDecl = createSynthIdentifier(factory.createUniqueName("result", 16 /* Optimistic */), continuationArgName.types); + } + declareSynthIdentifier(possibleNameForVarDecl); } - function getCompletionsAtPosition2(fileName, position, options = emptyOptions, formattingSettings) { - const fullPreferences = { - ...identity(options), - // avoid excess property check - includeCompletionsForModuleExports: options.includeCompletionsForModuleExports || options.includeExternalModuleExports, - includeCompletionsWithInsertText: options.includeCompletionsWithInsertText || options.includeInsertTextCompletions - }; - synchronizeHostData(); - return ts_Completions_exports.getCompletionsAtPosition( - host, - program, - log, - getValidSourceFile(fileName), - position, - fullPreferences, - options.triggerCharacter, - options.triggerKind, - cancellationToken, - formattingSettings && ts_formatting_exports.getFormatContext(formattingSettings, host), - options.includeSymbol + return possibleNameForVarDecl; + } + function finishCatchOrFinallyTransform(node, transformer, tryStatement, possibleNameForVarDecl, continuationArgName) { + const statements = []; + let varDeclIdentifier; + if (possibleNameForVarDecl && !shouldReturn(node, transformer)) { + varDeclIdentifier = getSynthesizedDeepClone(declareSynthIdentifier(possibleNameForVarDecl)); + const typeArray = possibleNameForVarDecl.types; + const unionType = transformer.checker.getUnionType(typeArray, 2 /* Subtype */); + const unionTypeNode = transformer.isInJSFile ? void 0 : transformer.checker.typeToTypeNode( + unionType, + /*enclosingDeclaration*/ + void 0, + /*flags*/ + void 0 ); - } - function getCompletionEntryDetails2(fileName, position, name, formattingOptions, source, preferences = emptyOptions, data) { - synchronizeHostData(); - return ts_Completions_exports.getCompletionEntryDetails( - program, - log, - getValidSourceFile(fileName), - position, - { name, source, data }, - host, - formattingOptions && ts_formatting_exports.getFormatContext(formattingOptions, host), - // TODO: GH#18217 - preferences, - cancellationToken + const varDecl = [factory.createVariableDeclaration( + varDeclIdentifier, + /*exclamationToken*/ + void 0, + unionTypeNode + )]; + const varDeclList = factory.createVariableStatement( + /*modifiers*/ + void 0, + factory.createVariableDeclarationList(varDecl, 1 /* Let */) ); + statements.push(varDeclList); } - function getCompletionEntrySymbol2(fileName, position, name, source, preferences = emptyOptions) { - synchronizeHostData(); - return ts_Completions_exports.getCompletionEntrySymbol(program, log, getValidSourceFile(fileName), position, { name, source }, host, preferences); + statements.push(tryStatement); + if (continuationArgName && varDeclIdentifier && isSynthBindingPattern(continuationArgName)) { + statements.push(factory.createVariableStatement( + /*modifiers*/ + void 0, + factory.createVariableDeclarationList([ + factory.createVariableDeclaration( + getSynthesizedDeepClone(declareSynthBindingPattern(continuationArgName)), + /*exclamationToken*/ + void 0, + /*type*/ + void 0, + varDeclIdentifier + ) + ], 2 /* Const */) + )); } - function getQuickInfoAtPosition(fileName, position) { - synchronizeHostData(); - const sourceFile = getValidSourceFile(fileName); - const node = getTouchingPropertyName(sourceFile, position); - if (node === sourceFile) { - return void 0; - } - const typeChecker = program.getTypeChecker(); - const nodeForQuickInfo = getNodeForQuickInfo(node); - const symbol = getSymbolAtLocationForQuickInfo(nodeForQuickInfo, typeChecker); - if (!symbol || typeChecker.isUnknownSymbol(symbol)) { - const type = shouldGetType(sourceFile, nodeForQuickInfo, position) ? typeChecker.getTypeAtLocation(nodeForQuickInfo) : void 0; - return type && { - kind: "" /* unknown */, - kindModifiers: "" /* none */, - textSpan: createTextSpanFromNode(nodeForQuickInfo, sourceFile), - displayParts: typeChecker.runWithCancellationToken(cancellationToken, (typeChecker2) => typeToDisplayParts(typeChecker2, type, getContainerNode(nodeForQuickInfo))), - documentation: type.symbol ? type.symbol.getDocumentationComment(typeChecker) : void 0, - tags: type.symbol ? type.symbol.getJsDocTags(typeChecker) : void 0 - }; - } - const { symbolKind, displayParts, documentation, tags } = typeChecker.runWithCancellationToken( - cancellationToken, - (typeChecker2) => ts_SymbolDisplay_exports.getSymbolDisplayPartsDocumentationAndSymbolKind(typeChecker2, symbol, sourceFile, getContainerNode(nodeForQuickInfo), nodeForQuickInfo) + return statements; + } + function transformFinally(node, onFinally, transformer, hasContinuation, continuationArgName) { + if (!onFinally || isNullOrUndefined2(transformer, onFinally)) { + return transformExpression( + /* returnContextNode */ + node, + node.expression.expression, + transformer, + hasContinuation, + continuationArgName ); - return { - kind: symbolKind, - kindModifiers: ts_SymbolDisplay_exports.getSymbolModifiers(typeChecker, symbol), - textSpan: createTextSpanFromNode(nodeForQuickInfo, sourceFile), - displayParts, - documentation, - tags - }; } - function getNodeForQuickInfo(node) { - if (isNewExpression(node.parent) && node.pos === node.parent.pos) { - return node.parent.expression; - } - if (isNamedTupleMember(node.parent) && node.pos === node.parent.pos) { - return node.parent; - } - if (isImportMeta(node.parent) && node.parent.name === node) { - return node.parent; - } - if (isJsxNamespacedName(node.parent)) { - return node.parent; - } - return node; + const possibleNameForVarDecl = getPossibleNameForVarDecl(node, transformer, continuationArgName); + const inlinedLeftHandSide = transformExpression( + /*returnContextNode*/ + node, + node.expression.expression, + transformer, + /*hasContinuation*/ + true, + possibleNameForVarDecl + ); + if (hasFailed()) + return silentFail(); + const inlinedCallback = transformCallbackArgument( + onFinally, + hasContinuation, + /*continuationArgName*/ + void 0, + /*inputArgName*/ + void 0, + node, + transformer + ); + if (hasFailed()) + return silentFail(); + const tryBlock = factory.createBlock(inlinedLeftHandSide); + const finallyBlock = factory.createBlock(inlinedCallback); + const tryStatement = factory.createTryStatement( + tryBlock, + /*catchClause*/ + void 0, + finallyBlock + ); + return finishCatchOrFinallyTransform(node, transformer, tryStatement, possibleNameForVarDecl, continuationArgName); + } + function transformCatch(node, onRejected, transformer, hasContinuation, continuationArgName) { + if (!onRejected || isNullOrUndefined2(transformer, onRejected)) { + return transformExpression( + /* returnContextNode */ + node, + node.expression.expression, + transformer, + hasContinuation, + continuationArgName + ); } - function shouldGetType(sourceFile, node, position) { - switch (node.kind) { - case 80 /* Identifier */: - return !isLabelName(node) && !isTagName(node) && !isConstTypeReference(node.parent); - case 210 /* PropertyAccessExpression */: - case 165 /* QualifiedName */: - return !isInComment(sourceFile, position); - case 110 /* ThisKeyword */: - case 196 /* ThisType */: - case 108 /* SuperKeyword */: - case 201 /* NamedTupleMember */: - return true; - case 235 /* MetaProperty */: - return isImportMeta(node); - default: - return false; - } + const inputArgName = getArgBindingName(onRejected, transformer); + const possibleNameForVarDecl = getPossibleNameForVarDecl(node, transformer, continuationArgName); + const inlinedLeftHandSide = transformExpression( + /*returnContextNode*/ + node, + node.expression.expression, + transformer, + /*hasContinuation*/ + true, + possibleNameForVarDecl + ); + if (hasFailed()) + return silentFail(); + const inlinedCallback = transformCallbackArgument(onRejected, hasContinuation, possibleNameForVarDecl, inputArgName, node, transformer); + if (hasFailed()) + return silentFail(); + const tryBlock = factory.createBlock(inlinedLeftHandSide); + const catchClause = factory.createCatchClause(inputArgName && getSynthesizedDeepClone(declareSynthBindingName(inputArgName)), factory.createBlock(inlinedCallback)); + const tryStatement = factory.createTryStatement( + tryBlock, + catchClause, + /*finallyBlock*/ + void 0 + ); + return finishCatchOrFinallyTransform(node, transformer, tryStatement, possibleNameForVarDecl, continuationArgName); + } + function transformThen(node, onFulfilled, onRejected, transformer, hasContinuation, continuationArgName) { + if (!onFulfilled || isNullOrUndefined2(transformer, onFulfilled)) { + return transformCatch(node, onRejected, transformer, hasContinuation, continuationArgName); } - function getDefinitionAtPosition2(fileName, position, searchOtherFilesOnly, stopAtAlias) { - synchronizeHostData(); - return ts_GoToDefinition_exports.getDefinitionAtPosition(program, getValidSourceFile(fileName), position, searchOtherFilesOnly, stopAtAlias); + if (onRejected && !isNullOrUndefined2(transformer, onRejected)) { + return silentFail(); } - function getDefinitionAndBoundSpan2(fileName, position) { - synchronizeHostData(); - return ts_GoToDefinition_exports.getDefinitionAndBoundSpan(program, getValidSourceFile(fileName), position); + const inputArgName = getArgBindingName(onFulfilled, transformer); + const inlinedLeftHandSide = transformExpression( + node.expression.expression, + node.expression.expression, + transformer, + /*hasContinuation*/ + true, + inputArgName + ); + if (hasFailed()) + return silentFail(); + const inlinedCallback = transformCallbackArgument(onFulfilled, hasContinuation, continuationArgName, inputArgName, node, transformer); + if (hasFailed()) + return silentFail(); + return concatenate(inlinedLeftHandSide, inlinedCallback); + } + function transformPromiseExpressionOfPropertyAccess(returnContextNode, node, transformer, hasContinuation, continuationArgName) { + if (shouldReturn(returnContextNode, transformer)) { + let returnValue = getSynthesizedDeepClone(node); + if (hasContinuation) { + returnValue = factory.createAwaitExpression(returnValue); + } + return [factory.createReturnStatement(returnValue)]; } - function getTypeDefinitionAtPosition2(fileName, position) { - synchronizeHostData(); - return ts_GoToDefinition_exports.getTypeDefinitionAtPosition(program.getTypeChecker(), getValidSourceFile(fileName), position); + return createVariableOrAssignmentOrExpressionStatement( + continuationArgName, + factory.createAwaitExpression(node), + /*typeAnnotation*/ + void 0 + ); + } + function createVariableOrAssignmentOrExpressionStatement(variableName, rightHandSide, typeAnnotation) { + if (!variableName || isEmptyBindingName(variableName)) { + return [factory.createExpressionStatement(rightHandSide)]; } - function getImplementationAtPosition(fileName, position) { - synchronizeHostData(); - return ts_FindAllReferences_exports.getImplementationsAtPosition(program, cancellationToken, program.getSourceFiles(), getValidSourceFile(fileName), position); + if (isSynthIdentifier(variableName) && variableName.hasBeenDeclared) { + return [factory.createExpressionStatement(factory.createAssignment(getSynthesizedDeepClone(referenceSynthIdentifier(variableName)), rightHandSide))]; } - function getDocumentHighlights(fileName, position, filesToSearch) { - const normalizedFileName = normalizePath(fileName); - Debug.assert(filesToSearch.some((f) => normalizePath(f) === normalizedFileName)); - synchronizeHostData(); - const sourceFilesToSearch = mapDefined(filesToSearch, (fileName2) => program.getSourceFile(fileName2)); - const sourceFile = getValidSourceFile(fileName); - return DocumentHighlights.getDocumentHighlights(program, cancellationToken, sourceFile, position, sourceFilesToSearch); + return [ + factory.createVariableStatement( + /*modifiers*/ + void 0, + factory.createVariableDeclarationList([ + factory.createVariableDeclaration( + getSynthesizedDeepClone(declareSynthBindingName(variableName)), + /*exclamationToken*/ + void 0, + typeAnnotation, + rightHandSide + ) + ], 2 /* Const */) + ) + ]; + } + function maybeAnnotateAndReturn(expressionToReturn, typeAnnotation) { + if (typeAnnotation && expressionToReturn) { + const name = factory.createUniqueName("result", 16 /* Optimistic */); + return [ + ...createVariableOrAssignmentOrExpressionStatement(createSynthIdentifier(name), expressionToReturn, typeAnnotation), + factory.createReturnStatement(name) + ]; } - function findRenameLocations(fileName, position, findInStrings, findInComments, preferences) { - synchronizeHostData(); - const sourceFile = getValidSourceFile(fileName); - const node = getAdjustedRenameLocation(getTouchingPropertyName(sourceFile, position)); - if (!ts_Rename_exports.nodeIsEligibleForRename(node)) - return void 0; - if (isIdentifier(node) && (isJsxOpeningElement(node.parent) || isJsxClosingElement(node.parent)) && isIntrinsicJsxName(node.escapedText)) { - const { openingElement, closingElement } = node.parent.parent; - return [openingElement, closingElement].map((node2) => { - const textSpan = createTextSpanFromNode(node2.tagName, sourceFile); - return { - fileName: sourceFile.fileName, - textSpan, - ...ts_FindAllReferences_exports.toContextSpan(textSpan, sourceFile, node2.parent) - }; - }); - } else { - const quotePreference = getQuotePreference(sourceFile, preferences ?? emptyOptions); - const providePrefixAndSuffixTextForRename = typeof preferences === "boolean" ? preferences : preferences == null ? void 0 : preferences.providePrefixAndSuffixTextForRename; - return getReferencesWorker( - node, - position, - { findInStrings, findInComments, providePrefixAndSuffixTextForRename, use: ts_FindAllReferences_exports.FindReferencesUse.Rename }, - (entry, originalNode, checker) => ts_FindAllReferences_exports.toRenameLocation(entry, originalNode, checker, providePrefixAndSuffixTextForRename || false, quotePreference) + return [factory.createReturnStatement(expressionToReturn)]; + } + function transformCallbackArgument(func, hasContinuation, continuationArgName, inputArgName, parent2, transformer) { + var _a; + switch (func.kind) { + case 106 /* NullKeyword */: + break; + case 211 /* PropertyAccessExpression */: + case 80 /* Identifier */: + if (!inputArgName) { + break; + } + const synthCall = factory.createCallExpression( + getSynthesizedDeepClone(func), + /*typeArguments*/ + void 0, + isSynthIdentifier(inputArgName) ? [referenceSynthIdentifier(inputArgName)] : [] ); + if (shouldReturn(parent2, transformer)) { + return maybeAnnotateAndReturn(synthCall, getExplicitPromisedTypeOfPromiseReturningCallExpression(parent2, func, transformer.checker)); + } + const type = transformer.checker.getTypeAtLocation(func); + const callSignatures = transformer.checker.getSignaturesOfType(type, 0 /* Call */); + if (!callSignatures.length) { + return silentFail(); + } + const returnType = callSignatures[0].getReturnType(); + const varDeclOrAssignment = createVariableOrAssignmentOrExpressionStatement(continuationArgName, factory.createAwaitExpression(synthCall), getExplicitPromisedTypeOfPromiseReturningCallExpression(parent2, func, transformer.checker)); + if (continuationArgName) { + continuationArgName.types.push(transformer.checker.getAwaitedType(returnType) || returnType); + } + return varDeclOrAssignment; + case 218 /* FunctionExpression */: + case 219 /* ArrowFunction */: { + const funcBody = func.body; + const returnType2 = (_a = getLastCallSignature(transformer.checker.getTypeAtLocation(func), transformer.checker)) == null ? void 0 : _a.getReturnType(); + if (isBlock(funcBody)) { + let refactoredStmts = []; + let seenReturnStatement = false; + for (const statement of funcBody.statements) { + if (isReturnStatement(statement)) { + seenReturnStatement = true; + if (isReturnStatementWithFixablePromiseHandler(statement, transformer.checker)) { + refactoredStmts = refactoredStmts.concat(transformReturnStatementWithFixablePromiseHandler(transformer, statement, hasContinuation, continuationArgName)); + } else { + const possiblyAwaitedRightHandSide = returnType2 && statement.expression ? getPossiblyAwaitedRightHandSide(transformer.checker, returnType2, statement.expression) : statement.expression; + refactoredStmts.push(...maybeAnnotateAndReturn(possiblyAwaitedRightHandSide, getExplicitPromisedTypeOfPromiseReturningCallExpression(parent2, func, transformer.checker))); + } + } else if (hasContinuation && forEachReturnStatement(statement, returnTrue)) { + return silentFail(); + } else { + refactoredStmts.push(statement); + } + } + return shouldReturn(parent2, transformer) ? refactoredStmts.map((s) => getSynthesizedDeepClone(s)) : removeReturns( + refactoredStmts, + continuationArgName, + transformer, + seenReturnStatement + ); + } else { + const inlinedStatements = isFixablePromiseHandler(funcBody, transformer.checker) ? transformReturnStatementWithFixablePromiseHandler(transformer, factory.createReturnStatement(funcBody), hasContinuation, continuationArgName) : emptyArray; + if (inlinedStatements.length > 0) { + return inlinedStatements; + } + if (returnType2) { + const possiblyAwaitedRightHandSide = getPossiblyAwaitedRightHandSide(transformer.checker, returnType2, funcBody); + if (!shouldReturn(parent2, transformer)) { + const transformedStatement = createVariableOrAssignmentOrExpressionStatement( + continuationArgName, + possiblyAwaitedRightHandSide, + /*typeAnnotation*/ + void 0 + ); + if (continuationArgName) { + continuationArgName.types.push(transformer.checker.getAwaitedType(returnType2) || returnType2); + } + return transformedStatement; + } else { + return maybeAnnotateAndReturn(possiblyAwaitedRightHandSide, getExplicitPromisedTypeOfPromiseReturningCallExpression(parent2, func, transformer.checker)); + } + } else { + return silentFail(); + } + } } + default: + return silentFail(); } - function getReferencesAtPosition(fileName, position) { - synchronizeHostData(); - return getReferencesWorker(getTouchingPropertyName(getValidSourceFile(fileName), position), position, { use: ts_FindAllReferences_exports.FindReferencesUse.References }, ts_FindAllReferences_exports.toReferenceEntry); - } - function getReferencesWorker(node, position, options, cb) { - synchronizeHostData(); - const sourceFiles = options && options.use === ts_FindAllReferences_exports.FindReferencesUse.Rename ? program.getSourceFiles().filter((sourceFile) => !program.isSourceFileDefaultLibrary(sourceFile)) : program.getSourceFiles(); - return ts_FindAllReferences_exports.findReferenceOrRenameEntries(program, cancellationToken, sourceFiles, node, position, options, cb); - } - function findReferences(fileName, position) { - synchronizeHostData(); - return ts_FindAllReferences_exports.findReferencedSymbols(program, cancellationToken, program.getSourceFiles(), getValidSourceFile(fileName), position); - } - function getFileReferences(fileName) { - synchronizeHostData(); - return ts_FindAllReferences_exports.Core.getReferencesForFileName(fileName, program, program.getSourceFiles()).map(ts_FindAllReferences_exports.toReferenceEntry); - } - function getNavigateToItems2(searchValue, maxResultCount, fileName, excludeDtsFiles = false) { - synchronizeHostData(); - const sourceFiles = fileName ? [getValidSourceFile(fileName)] : program.getSourceFiles(); - return getNavigateToItems(sourceFiles, program.getTypeChecker(), cancellationToken, searchValue, maxResultCount, excludeDtsFiles); - } - function getEmitOutput(fileName, emitOnlyDtsFiles, forceDtsEmit) { - synchronizeHostData(); - const sourceFile = getValidSourceFile(fileName); - const customTransformers = host.getCustomTransformers && host.getCustomTransformers(); - return getFileEmitOutput(program, sourceFile, !!emitOnlyDtsFiles, cancellationToken, customTransformers, forceDtsEmit); - } - function getSignatureHelpItems2(fileName, position, { triggerReason } = emptyOptions) { - synchronizeHostData(); - const sourceFile = getValidSourceFile(fileName); - return ts_SignatureHelp_exports.getSignatureHelpItems(program, sourceFile, position, triggerReason, cancellationToken); - } - function getNonBoundSourceFile(fileName) { - return syntaxTreeCache.getCurrentSourceFile(fileName); - } - function getNameOrDottedNameSpan(fileName, startPos, _endPos) { - const sourceFile = syntaxTreeCache.getCurrentSourceFile(fileName); - const node = getTouchingPropertyName(sourceFile, startPos); - if (node === sourceFile) { - return void 0; - } - switch (node.kind) { - case 210 /* PropertyAccessExpression */: - case 165 /* QualifiedName */: - case 11 /* StringLiteral */: - case 97 /* FalseKeyword */: - case 112 /* TrueKeyword */: - case 106 /* NullKeyword */: - case 108 /* SuperKeyword */: - case 110 /* ThisKeyword */: - case 196 /* ThisType */: - case 80 /* Identifier */: - break; - default: - return void 0; - } - let nodeForStartPos = node; - while (true) { - if (isRightSideOfPropertyAccess(nodeForStartPos) || isRightSideOfQualifiedName(nodeForStartPos)) { - nodeForStartPos = nodeForStartPos.parent; - } else if (isNameOfModuleDeclaration(nodeForStartPos)) { - if (nodeForStartPos.parent.parent.kind === 266 /* ModuleDeclaration */ && nodeForStartPos.parent.parent.body === nodeForStartPos.parent) { - nodeForStartPos = nodeForStartPos.parent.parent.name; + return emptyArray; + } + function getPossiblyAwaitedRightHandSide(checker, type, expr) { + const rightHandSide = getSynthesizedDeepClone(expr); + return !!checker.getPromisedTypeOfPromise(type) ? factory.createAwaitExpression(rightHandSide) : rightHandSide; + } + function getLastCallSignature(type, checker) { + const callSignatures = checker.getSignaturesOfType(type, 0 /* Call */); + return lastOrUndefined(callSignatures); + } + function removeReturns(stmts, prevArgName, transformer, seenReturnStatement) { + const ret = []; + for (const stmt of stmts) { + if (isReturnStatement(stmt)) { + if (stmt.expression) { + const possiblyAwaitedExpression = isPromiseTypedExpression(stmt.expression, transformer.checker) ? factory.createAwaitExpression(stmt.expression) : stmt.expression; + if (prevArgName === void 0) { + ret.push(factory.createExpressionStatement(possiblyAwaitedExpression)); + } else if (isSynthIdentifier(prevArgName) && prevArgName.hasBeenDeclared) { + ret.push(factory.createExpressionStatement(factory.createAssignment(referenceSynthIdentifier(prevArgName), possiblyAwaitedExpression))); } else { - break; + ret.push(factory.createVariableStatement( + /*modifiers*/ + void 0, + factory.createVariableDeclarationList([factory.createVariableDeclaration( + declareSynthBindingName(prevArgName), + /*exclamationToken*/ + void 0, + /*type*/ + void 0, + possiblyAwaitedExpression + )], 2 /* Const */) + )); } - } else { - break; } + } else { + ret.push(getSynthesizedDeepClone(stmt)); } - return createTextSpanFromBounds(nodeForStartPos.getStart(), node.getEnd()); } - function getBreakpointStatementAtPosition(fileName, position) { - const sourceFile = syntaxTreeCache.getCurrentSourceFile(fileName); - return ts_BreakpointResolver_exports.spanInSourceFileAtLocation(sourceFile, position); - } - function getNavigationBarItems2(fileName) { - return getNavigationBarItems(syntaxTreeCache.getCurrentSourceFile(fileName), cancellationToken); - } - function getNavigationTree2(fileName) { - return getNavigationTree(syntaxTreeCache.getCurrentSourceFile(fileName), cancellationToken); + if (!seenReturnStatement && prevArgName !== void 0) { + ret.push(factory.createVariableStatement( + /*modifiers*/ + void 0, + factory.createVariableDeclarationList([factory.createVariableDeclaration( + declareSynthBindingName(prevArgName), + /*exclamationToken*/ + void 0, + /*type*/ + void 0, + factory.createIdentifier("undefined") + )], 2 /* Const */) + )); } - function getSemanticClassifications3(fileName, span, format) { - synchronizeHostData(); - const responseFormat = format || "original" /* Original */; - if (responseFormat === "2020" /* TwentyTwenty */) { - return getSemanticClassifications2(program, cancellationToken, getValidSourceFile(fileName), span); - } else { - return getSemanticClassifications(program.getTypeChecker(), cancellationToken, getValidSourceFile(fileName), program.getClassifiableNames(), span); + return ret; + } + function transformReturnStatementWithFixablePromiseHandler(transformer, innerRetStmt, hasContinuation, continuationArgName) { + let innerCbBody = []; + forEachChild(innerRetStmt, function visit(node) { + if (isCallExpression(node)) { + const temp = transformExpression(node, node, transformer, hasContinuation, continuationArgName); + innerCbBody = innerCbBody.concat(temp); + if (innerCbBody.length > 0) { + return; + } + } else if (!isFunctionLike(node)) { + forEachChild(node, visit); } - } - function getEncodedSemanticClassifications3(fileName, span, format) { - synchronizeHostData(); - const responseFormat = format || "original" /* Original */; - if (responseFormat === "original" /* Original */) { - return getEncodedSemanticClassifications(program.getTypeChecker(), cancellationToken, getValidSourceFile(fileName), program.getClassifiableNames(), span); - } else { - return getEncodedSemanticClassifications2(program, cancellationToken, getValidSourceFile(fileName), span); + }); + return innerCbBody; + } + function getArgBindingName(funcNode, transformer) { + const types = []; + let name; + if (isFunctionLikeDeclaration(funcNode)) { + if (funcNode.parameters.length > 0) { + const param = funcNode.parameters[0].name; + name = getMappedBindingNameOrDefault(param); } + } else if (isIdentifier(funcNode)) { + name = getMapEntryOrDefault(funcNode); + } else if (isPropertyAccessExpression(funcNode) && isIdentifier(funcNode.name)) { + name = getMapEntryOrDefault(funcNode.name); } - function getSyntacticClassifications2(fileName, span) { - return getSyntacticClassifications(cancellationToken, syntaxTreeCache.getCurrentSourceFile(fileName), span); + if (!name || "identifier" in name && name.identifier.text === "undefined") { + return void 0; } - function getEncodedSyntacticClassifications2(fileName, span) { - return getEncodedSyntacticClassifications(cancellationToken, syntaxTreeCache.getCurrentSourceFile(fileName), span); + return name; + function getMappedBindingNameOrDefault(bindingName) { + if (isIdentifier(bindingName)) + return getMapEntryOrDefault(bindingName); + const elements = flatMap(bindingName.elements, (element) => { + if (isOmittedExpression(element)) + return []; + return [getMappedBindingNameOrDefault(element.name)]; + }); + return createSynthBindingPattern(bindingName, elements); } - function getOutliningSpans(fileName) { - const sourceFile = syntaxTreeCache.getCurrentSourceFile(fileName); - return ts_OutliningElementsCollector_exports.collectElements(sourceFile, cancellationToken); + function getMapEntryOrDefault(identifier) { + const originalNode = getOriginalNode2(identifier); + const symbol = getSymbol2(originalNode); + if (!symbol) { + return createSynthIdentifier(identifier, types); + } + const mapEntry = transformer.synthNamesMap.get(getSymbolId(symbol).toString()); + return mapEntry || createSynthIdentifier(identifier, types); } - const braceMatching = new Map(Object.entries({ - [19 /* OpenBraceToken */]: 20 /* CloseBraceToken */, - [21 /* OpenParenToken */]: 22 /* CloseParenToken */, - [23 /* OpenBracketToken */]: 24 /* CloseBracketToken */, - [32 /* GreaterThanToken */]: 30 /* LessThanToken */ - })); - braceMatching.forEach((value, key) => braceMatching.set(value.toString(), Number(key))); - function getBraceMatchingAtPosition(fileName, position) { - const sourceFile = syntaxTreeCache.getCurrentSourceFile(fileName); - const token = getTouchingToken(sourceFile, position); - const matchKind = token.getStart(sourceFile) === position ? braceMatching.get(token.kind.toString()) : void 0; - const match = matchKind && findChildOfKind(token.parent, matchKind, sourceFile); - return match ? [createTextSpanFromNode(token, sourceFile), createTextSpanFromNode(match, sourceFile)].sort((a, b) => a.start - b.start) : emptyArray; + function getSymbol2(node) { + var _a; + return ((_a = tryCast(node, canHaveSymbol)) == null ? void 0 : _a.symbol) ?? transformer.checker.getSymbolAtLocation(node); } - function getIndentationAtPosition(fileName, position, editorOptions) { - let start = timestamp(); - const settings = toEditorSettings(editorOptions); - const sourceFile = syntaxTreeCache.getCurrentSourceFile(fileName); - log("getIndentationAtPosition: getCurrentSourceFile: " + (timestamp() - start)); - start = timestamp(); - const result = ts_formatting_exports.SmartIndenter.getIndentation(position, sourceFile, settings); - log("getIndentationAtPosition: computeIndentation : " + (timestamp() - start)); - return result; + function getOriginalNode2(node) { + return node.original ? node.original : node; } - function getFormattingEditsForRange(fileName, start, end, options) { - const sourceFile = syntaxTreeCache.getCurrentSourceFile(fileName); - return ts_formatting_exports.formatSelection(start, end, sourceFile, ts_formatting_exports.getFormatContext(toEditorSettings(options), host)); + } + function isEmptyBindingName(bindingName) { + if (!bindingName) { + return true; } - function getFormattingEditsForDocument(fileName, options) { - return ts_formatting_exports.formatDocument(syntaxTreeCache.getCurrentSourceFile(fileName), ts_formatting_exports.getFormatContext(toEditorSettings(options), host)); + if (isSynthIdentifier(bindingName)) { + return !bindingName.identifier.text; } - function getFormattingEditsAfterKeystroke(fileName, position, key, options) { - const sourceFile = syntaxTreeCache.getCurrentSourceFile(fileName); - const formatContext = ts_formatting_exports.getFormatContext(toEditorSettings(options), host); - if (!isInComment(sourceFile, position)) { - switch (key) { - case "{": - return ts_formatting_exports.formatOnOpeningCurly(position, sourceFile, formatContext); - case "}": - return ts_formatting_exports.formatOnClosingCurly(position, sourceFile, formatContext); - case ";": - return ts_formatting_exports.formatOnSemicolon(position, sourceFile, formatContext); - case "\n": - return ts_formatting_exports.formatOnEnter(position, sourceFile, formatContext); - } - } - return []; + return every(bindingName.elements, isEmptyBindingName); + } + function createSynthIdentifier(identifier, types = []) { + return { kind: 0 /* Identifier */, identifier, types, hasBeenDeclared: false, hasBeenReferenced: false }; + } + function createSynthBindingPattern(bindingPattern, elements = emptyArray, types = []) { + return { kind: 1 /* BindingPattern */, bindingPattern, elements, types }; + } + function referenceSynthIdentifier(synthId) { + synthId.hasBeenReferenced = true; + return synthId.identifier; + } + function declareSynthBindingName(synthName) { + return isSynthIdentifier(synthName) ? declareSynthIdentifier(synthName) : declareSynthBindingPattern(synthName); + } + function declareSynthBindingPattern(synthPattern) { + for (const element of synthPattern.elements) { + declareSynthBindingName(element); } - function getCodeFixesAtPosition(fileName, start, end, errorCodes64, formatOptions, preferences = emptyOptions) { - synchronizeHostData(); - const sourceFile = getValidSourceFile(fileName); - const span = createTextSpanFromBounds(start, end); - const formatContext = ts_formatting_exports.getFormatContext(formatOptions, host); - return flatMap(deduplicate(errorCodes64, equateValues, compareValues), (errorCode) => { - cancellationToken.throwIfCancellationRequested(); - return ts_codefix_exports.getFixes({ errorCode, sourceFile, span, program, host, cancellationToken, formatContext, preferences }); + return synthPattern.bindingPattern; + } + function declareSynthIdentifier(synthId) { + synthId.hasBeenDeclared = true; + return synthId.identifier; + } + function isSynthIdentifier(bindingName) { + return bindingName.kind === 0 /* Identifier */; + } + function isSynthBindingPattern(bindingName) { + return bindingName.kind === 1 /* BindingPattern */; + } + function shouldReturn(expression, transformer) { + return !!expression.original && transformer.setOfExpressionsToReturn.has(getNodeId(expression.original)); + } + var fixId10, errorCodes11, codeActionSucceeded; + var init_convertToAsyncFunction = __esm({ + "src/services/codefixes/convertToAsyncFunction.ts"() { + "use strict"; + init_ts4(); + init_ts_codefix(); + fixId10 = "convertToAsyncFunction"; + errorCodes11 = [Diagnostics.This_may_be_converted_to_an_async_function.code]; + codeActionSucceeded = true; + registerCodeFix({ + errorCodes: errorCodes11, + getCodeActions(context) { + codeActionSucceeded = true; + const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => convertToAsyncFunction(t, context.sourceFile, context.span.start, context.program.getTypeChecker())); + return codeActionSucceeded ? [createCodeFixAction(fixId10, changes, Diagnostics.Convert_to_async_function, fixId10, Diagnostics.Convert_all_to_async_functions)] : []; + }, + fixIds: [fixId10], + getAllCodeActions: (context) => codeFixAll(context, errorCodes11, (changes, err) => convertToAsyncFunction(changes, err.file, err.start, context.program.getTypeChecker())) }); } - function getCombinedCodeFix(scope, fixId52, formatOptions, preferences = emptyOptions) { - synchronizeHostData(); - Debug.assert(scope.type === "file"); - const sourceFile = getValidSourceFile(scope.fileName); - const formatContext = ts_formatting_exports.getFormatContext(formatOptions, host); - return ts_codefix_exports.getAllFixes({ fixId: fixId52, sourceFile, program, host, cancellationToken, formatContext, preferences }); - } - function organizeImports2(args, formatOptions, preferences = emptyOptions) { - synchronizeHostData(); - Debug.assert(args.type === "file"); - const sourceFile = getValidSourceFile(args.fileName); - const formatContext = ts_formatting_exports.getFormatContext(formatOptions, host); - const mode = args.mode ?? (args.skipDestructiveCodeActions ? "SortAndCombine" /* SortAndCombine */ : "All" /* All */); - return ts_OrganizeImports_exports.organizeImports(sourceFile, formatContext, host, program, preferences, mode); - } - function getEditsForFileRename2(oldFilePath, newFilePath, formatOptions, preferences = emptyOptions) { - return getEditsForFileRename(getProgram(), oldFilePath, newFilePath, host, ts_formatting_exports.getFormatContext(formatOptions, host), preferences, sourceMapper); - } - function applyCodeActionCommand(fileName, actionOrFormatSettingsOrUndefined) { - const action = typeof fileName === "string" ? actionOrFormatSettingsOrUndefined : fileName; - return isArray(action) ? Promise.all(action.map((a) => applySingleCodeActionCommand(a))) : applySingleCodeActionCommand(action); + }); + + // src/services/codefixes/convertToEsModule.ts + function fixImportOfModuleExports(importingFile, exportingFile, program, changes, quotePreference) { + var _a; + for (const moduleSpecifier of importingFile.imports) { + const imported = (_a = program.getResolvedModule(importingFile, moduleSpecifier.text, getModeForUsageLocation(importingFile, moduleSpecifier))) == null ? void 0 : _a.resolvedModule; + if (!imported || imported.resolvedFileName !== exportingFile.fileName) { + continue; + } + const importNode = importFromModuleSpecifier(moduleSpecifier); + switch (importNode.kind) { + case 271 /* ImportEqualsDeclaration */: + changes.replaceNode(importingFile, importNode, makeImport( + importNode.name, + /*namedImports*/ + void 0, + moduleSpecifier, + quotePreference + )); + break; + case 213 /* CallExpression */: + if (isRequireCall( + importNode, + /*requireStringLiteralLikeArgument*/ + false + )) { + changes.replaceNode(importingFile, importNode, factory.createPropertyAccessExpression(getSynthesizedDeepClone(importNode), "default")); + } + break; + } } - function applySingleCodeActionCommand(action) { - const getPath = (path) => toPath(path, currentDirectory, getCanonicalFileName); - Debug.assertEqual(action.type, "install package"); - return host.installPackage ? host.installPackage({ fileName: getPath(action.file), packageName: action.packageName }) : Promise.reject("Host does not implement `installPackage`"); + } + function convertFileToEsModule(sourceFile, checker, changes, target, quotePreference) { + const identifiers = { original: collectFreeIdentifiers(sourceFile), additional: /* @__PURE__ */ new Set() }; + const exports = collectExportRenames(sourceFile, checker, identifiers); + convertExportsAccesses(sourceFile, exports, changes); + let moduleExportsChangedToDefault = false; + let useSitesToUnqualify; + for (const statement of filter(sourceFile.statements, isVariableStatement)) { + const newUseSites = convertVariableStatement(sourceFile, statement, changes, checker, identifiers, target, quotePreference); + if (newUseSites) { + copyEntries(newUseSites, useSitesToUnqualify ?? (useSitesToUnqualify = /* @__PURE__ */ new Map())); + } } - function getDocCommentTemplateAtPosition2(fileName, position, options, formatOptions) { - const formatSettings = formatOptions ? ts_formatting_exports.getFormatContext(formatOptions, host).options : void 0; - return ts_JsDoc_exports.getDocCommentTemplateAtPosition(getNewLineOrDefaultFromHost(host, formatSettings), syntaxTreeCache.getCurrentSourceFile(fileName), position, options); + for (const statement of filter(sourceFile.statements, (s) => !isVariableStatement(s))) { + const moduleExportsChanged = convertStatement(sourceFile, statement, checker, changes, identifiers, target, exports, useSitesToUnqualify, quotePreference); + moduleExportsChangedToDefault = moduleExportsChangedToDefault || moduleExportsChanged; } - function isValidBraceCompletionAtPosition(fileName, position, openingBrace) { - if (openingBrace === 60 /* lessThan */) { - return false; + useSitesToUnqualify == null ? void 0 : useSitesToUnqualify.forEach((replacement, original) => { + changes.replaceNode(sourceFile, original, replacement); + }); + return moduleExportsChangedToDefault; + } + function collectExportRenames(sourceFile, checker, identifiers) { + const res = /* @__PURE__ */ new Map(); + forEachExportReference(sourceFile, (node) => { + const { text } = node.name; + if (!res.has(text) && (isIdentifierANonContextualKeyword(node.name) || checker.resolveName( + text, + node, + 111551 /* Value */, + /*excludeGlobals*/ + true + ))) { + res.set(text, makeUniqueName(`_${text}`, identifiers)); } - const sourceFile = syntaxTreeCache.getCurrentSourceFile(fileName); - if (isInString(sourceFile, position)) { - return false; + }); + return res; + } + function convertExportsAccesses(sourceFile, exports, changes) { + forEachExportReference(sourceFile, (node, isAssignmentLhs) => { + if (isAssignmentLhs) { + return; } - if (isInsideJsxElementOrAttribute(sourceFile, position)) { - return openingBrace === 123 /* openBrace */; + const { text } = node.name; + changes.replaceNode(sourceFile, node, factory.createIdentifier(exports.get(text) || text)); + }); + } + function forEachExportReference(sourceFile, cb) { + sourceFile.forEachChild(function recur(node) { + if (isPropertyAccessExpression(node) && isExportsOrModuleExportsOrAlias(sourceFile, node.expression) && isIdentifier(node.name)) { + const { parent: parent2 } = node; + cb(node, isBinaryExpression(parent2) && parent2.left === node && parent2.operatorToken.kind === 64 /* EqualsToken */); } - if (isInTemplateString(sourceFile, position)) { + node.forEachChild(recur); + }); + } + function convertStatement(sourceFile, statement, checker, changes, identifiers, target, exports, useSitesToUnqualify, quotePreference) { + switch (statement.kind) { + case 243 /* VariableStatement */: + convertVariableStatement(sourceFile, statement, changes, checker, identifiers, target, quotePreference); return false; - } - switch (openingBrace) { - case 39 /* singleQuote */: - case 34 /* doubleQuote */: - case 96 /* backtick */: - return !isInComment(sourceFile, position); - } - return true; - } - function getJsxClosingTagAtPosition(fileName, position) { - const sourceFile = syntaxTreeCache.getCurrentSourceFile(fileName); - const token = findPrecedingToken(position, sourceFile); - if (!token) - return void 0; - const element = token.kind === 32 /* GreaterThanToken */ && isJsxOpeningElement(token.parent) ? token.parent.parent : isJsxText(token) && isJsxElement(token.parent) ? token.parent : void 0; - if (element && isUnclosedTag(element)) { - return { newText: `` }; - } - const fragment = token.kind === 32 /* GreaterThanToken */ && isJsxOpeningFragment(token.parent) ? token.parent.parent : isJsxText(token) && isJsxFragment(token.parent) ? token.parent : void 0; - if (fragment && isUnclosedFragment(fragment)) { - return { newText: "" }; - } - } - function getLinkedEditingRangeAtPosition(fileName, position) { - const sourceFile = syntaxTreeCache.getCurrentSourceFile(fileName); - const token = findPrecedingToken(position, sourceFile); - if (!token || token.parent.kind === 311 /* SourceFile */) - return void 0; - const jsxTagWordPattern = "[a-zA-Z0-9:\\-\\._$]*"; - if (isJsxFragment(token.parent.parent)) { - const openFragment = token.parent.parent.openingFragment; - const closeFragment = token.parent.parent.closingFragment; - if (containsParseError(openFragment) || containsParseError(closeFragment)) - return void 0; - const openPos = openFragment.getStart(sourceFile) + 1; - const closePos = closeFragment.getStart(sourceFile) + 2; - if (position !== openPos && position !== closePos) - return void 0; - return { - ranges: [{ start: openPos, length: 0 }, { start: closePos, length: 0 }], - wordPattern: jsxTagWordPattern - }; - } else { - const tag = findAncestor( - token.parent, - (n) => { - if (isJsxOpeningElement(n) || isJsxClosingElement(n)) { - return true; + case 244 /* ExpressionStatement */: { + const { expression } = statement; + switch (expression.kind) { + case 213 /* CallExpression */: { + if (isRequireCall( + expression, + /*requireStringLiteralLikeArgument*/ + true + )) { + changes.replaceNode(sourceFile, statement, makeImport( + /*defaultImport*/ + void 0, + /*namedImports*/ + void 0, + expression.arguments[0], + quotePreference + )); } return false; } - ); - if (!tag) - return void 0; - Debug.assert(isJsxOpeningElement(tag) || isJsxClosingElement(tag), "tag should be opening or closing element"); - const openTag = tag.parent.openingElement; - const closeTag = tag.parent.closingElement; - const openTagStart = openTag.tagName.getStart(sourceFile); - const openTagEnd = openTag.tagName.end; - const closeTagStart = closeTag.tagName.getStart(sourceFile); - const closeTagEnd = closeTag.tagName.end; - if (!(openTagStart <= position && position <= openTagEnd || closeTagStart <= position && position <= closeTagEnd)) - return void 0; - const openingTagText = openTag.tagName.getText(sourceFile); - if (openingTagText !== closeTag.tagName.getText(sourceFile)) - return void 0; - return { - ranges: [{ start: openTagStart, length: openTagEnd - openTagStart }, { start: closeTagStart, length: closeTagEnd - closeTagStart }], - wordPattern: jsxTagWordPattern - }; - } - } - function getLinesForRange(sourceFile, textRange) { - return { - lineStarts: sourceFile.getLineStarts(), - firstLine: sourceFile.getLineAndCharacterOfPosition(textRange.pos).line, - lastLine: sourceFile.getLineAndCharacterOfPosition(textRange.end).line - }; - } - function toggleLineComment(fileName, textRange, insertComment) { - const sourceFile = syntaxTreeCache.getCurrentSourceFile(fileName); - const textChanges2 = []; - const { lineStarts, firstLine, lastLine } = getLinesForRange(sourceFile, textRange); - let isCommenting = insertComment || false; - let leftMostPosition = Number.MAX_VALUE; - const lineTextStarts = /* @__PURE__ */ new Map(); - const firstNonWhitespaceCharacterRegex = new RegExp(/\S/); - const isJsx = isInsideJsxElement(sourceFile, lineStarts[firstLine]); - const openComment = isJsx ? "{/*" : "//"; - for (let i = firstLine; i <= lastLine; i++) { - const lineText = sourceFile.text.substring(lineStarts[i], sourceFile.getLineEndOfPosition(lineStarts[i])); - const regExec = firstNonWhitespaceCharacterRegex.exec(lineText); - if (regExec) { - leftMostPosition = Math.min(leftMostPosition, regExec.index); - lineTextStarts.set(i.toString(), regExec.index); - if (lineText.substr(regExec.index, openComment.length) !== openComment) { - isCommenting = insertComment === void 0 || insertComment; - } - } - } - for (let i = firstLine; i <= lastLine; i++) { - if (firstLine !== lastLine && lineStarts[i] === textRange.end) { - continue; - } - const lineTextStart = lineTextStarts.get(i.toString()); - if (lineTextStart !== void 0) { - if (isJsx) { - textChanges2.push.apply(textChanges2, toggleMultilineComment(fileName, { pos: lineStarts[i] + leftMostPosition, end: sourceFile.getLineEndOfPosition(lineStarts[i]) }, isCommenting, isJsx)); - } else if (isCommenting) { - textChanges2.push({ - newText: openComment, - span: { - length: 0, - start: lineStarts[i] + leftMostPosition - } - }); - } else if (sourceFile.text.substr(lineStarts[i] + lineTextStart, openComment.length) === openComment) { - textChanges2.push({ - newText: "", - span: { - length: openComment.length, - start: lineStarts[i] + lineTextStart - } - }); + case 226 /* BinaryExpression */: { + const { operatorToken } = expression; + return operatorToken.kind === 64 /* EqualsToken */ && convertAssignment(sourceFile, checker, expression, changes, exports, useSitesToUnqualify); } } } - return textChanges2; + default: + return false; } - function toggleMultilineComment(fileName, textRange, insertComment, isInsideJsx) { - var _a2; - const sourceFile = syntaxTreeCache.getCurrentSourceFile(fileName); - const textChanges2 = []; - const { text } = sourceFile; - let hasComment = false; - let isCommenting = insertComment || false; - const positions = []; - let { pos } = textRange; - const isJsx = isInsideJsx !== void 0 ? isInsideJsx : isInsideJsxElement(sourceFile, pos); - const openMultiline = isJsx ? "{/*" : "/*"; - const closeMultiline = isJsx ? "*/}" : "*/"; - const openMultilineRegex = isJsx ? "\\{\\/\\*" : "\\/\\*"; - const closeMultilineRegex = isJsx ? "\\*\\/\\}" : "\\*\\/"; - while (pos <= textRange.end) { - const offset = text.substr(pos, openMultiline.length) === openMultiline ? openMultiline.length : 0; - const commentRange = isInComment(sourceFile, pos + offset); - if (commentRange) { - if (isJsx) { - commentRange.pos--; - commentRange.end++; - } - positions.push(commentRange.pos); - if (commentRange.kind === 3 /* MultiLineCommentTrivia */) { - positions.push(commentRange.end); - } - hasComment = true; - pos = commentRange.end + 1; - } else { - const newPos = text.substring(pos, textRange.end).search(`(${openMultilineRegex})|(${closeMultilineRegex})`); - isCommenting = insertComment !== void 0 ? insertComment : isCommenting || !isTextWhiteSpaceLike(text, pos, newPos === -1 ? textRange.end : pos + newPos); - pos = newPos === -1 ? textRange.end + 1 : pos + newPos + closeMultiline.length; + } + function convertVariableStatement(sourceFile, statement, changes, checker, identifiers, target, quotePreference) { + const { declarationList } = statement; + let foundImport = false; + const converted = map(declarationList.declarations, (decl) => { + const { name, initializer } = decl; + if (initializer) { + if (isExportsOrModuleExportsOrAlias(sourceFile, initializer)) { + foundImport = true; + return convertedImports([]); + } else if (isRequireCall( + initializer, + /*requireStringLiteralLikeArgument*/ + true + )) { + foundImport = true; + return convertSingleImport(name, initializer.arguments[0], checker, identifiers, target, quotePreference); + } else if (isPropertyAccessExpression(initializer) && isRequireCall( + initializer.expression, + /*requireStringLiteralLikeArgument*/ + true + )) { + foundImport = true; + return convertPropertyAccessImport(name, initializer.name.text, initializer.expression.arguments[0], identifiers, quotePreference); } } - if (isCommenting || !hasComment) { - if (((_a2 = isInComment(sourceFile, textRange.pos)) == null ? void 0 : _a2.kind) !== 2 /* SingleLineCommentTrivia */) { - insertSorted(positions, textRange.pos, compareValues); - } - insertSorted(positions, textRange.end, compareValues); - const firstPos = positions[0]; - if (text.substr(firstPos, openMultiline.length) !== openMultiline) { - textChanges2.push({ - newText: openMultiline, - span: { - length: 0, - start: firstPos - } - }); - } - for (let i = 1; i < positions.length - 1; i++) { - if (text.substr(positions[i] - closeMultiline.length, closeMultiline.length) !== closeMultiline) { - textChanges2.push({ - newText: closeMultiline, - span: { - length: 0, - start: positions[i] - } - }); - } - if (text.substr(positions[i], openMultiline.length) !== openMultiline) { - textChanges2.push({ - newText: openMultiline, - span: { - length: 0, - start: positions[i] - } - }); - } - } - if (textChanges2.length % 2 !== 0) { - textChanges2.push({ - newText: closeMultiline, - span: { - length: 0, - start: positions[positions.length - 1] - } - }); - } - } else { - for (const pos2 of positions) { - const from = pos2 - closeMultiline.length > 0 ? pos2 - closeMultiline.length : 0; - const offset = text.substr(from, closeMultiline.length) === closeMultiline ? closeMultiline.length : 0; - textChanges2.push({ - newText: "", - span: { - length: openMultiline.length, - start: pos2 - offset - } - }); + return convertedImports([factory.createVariableStatement( + /*modifiers*/ + void 0, + factory.createVariableDeclarationList([decl], declarationList.flags) + )]); + }); + if (foundImport) { + changes.replaceNodeWithNodes(sourceFile, statement, flatMap(converted, (c) => c.newImports)); + let combinedUseSites; + forEach(converted, (c) => { + if (c.useSitesToUnqualify) { + copyEntries(c.useSitesToUnqualify, combinedUseSites ?? (combinedUseSites = /* @__PURE__ */ new Map())); } - } - return textChanges2; - } - function commentSelection(fileName, textRange) { - const sourceFile = syntaxTreeCache.getCurrentSourceFile(fileName); - const { firstLine, lastLine } = getLinesForRange(sourceFile, textRange); - return firstLine === lastLine && textRange.pos !== textRange.end ? toggleMultilineComment( - fileName, - textRange, - /*insertComment*/ - true - ) : toggleLineComment( - fileName, - textRange, - /*insertComment*/ - true - ); + }); + return combinedUseSites; } - function uncommentSelection(fileName, textRange) { - const sourceFile = syntaxTreeCache.getCurrentSourceFile(fileName); - const textChanges2 = []; - const { pos } = textRange; - let { end } = textRange; - if (pos === end) { - end += isInsideJsxElement(sourceFile, pos) ? 2 : 1; - } - for (let i = pos; i <= end; i++) { - const commentRange = isInComment(sourceFile, i); - if (commentRange) { - switch (commentRange.kind) { - case 2 /* SingleLineCommentTrivia */: - textChanges2.push.apply(textChanges2, toggleLineComment( - fileName, - { end: commentRange.end, pos: commentRange.pos + 1 }, - /*insertComment*/ - false - )); - break; - case 3 /* MultiLineCommentTrivia */: - textChanges2.push.apply(textChanges2, toggleMultilineComment( - fileName, - { end: commentRange.end, pos: commentRange.pos + 1 }, - /*insertComment*/ - false - )); - } - i = commentRange.end + 1; - } + } + function convertPropertyAccessImport(name, propertyName, moduleSpecifier, identifiers, quotePreference) { + switch (name.kind) { + case 206 /* ObjectBindingPattern */: + case 207 /* ArrayBindingPattern */: { + const tmp = makeUniqueName(propertyName, identifiers); + return convertedImports([ + makeSingleImport(tmp, propertyName, moduleSpecifier, quotePreference), + makeConst( + /*modifiers*/ + void 0, + name, + factory.createIdentifier(tmp) + ) + ]); } - return textChanges2; - } - function isUnclosedTag({ openingElement, closingElement, parent: parent2 }) { - return !tagNamesAreEquivalent(openingElement.tagName, closingElement.tagName) || isJsxElement(parent2) && tagNamesAreEquivalent(openingElement.tagName, parent2.openingElement.tagName) && isUnclosedTag(parent2); - } - function isUnclosedFragment({ closingFragment, parent: parent2 }) { - return !!(closingFragment.flags & 131072 /* ThisNodeHasError */) || isJsxFragment(parent2) && isUnclosedFragment(parent2); + case 80 /* Identifier */: + return convertedImports([makeSingleImport(name.text, propertyName, moduleSpecifier, quotePreference)]); + default: + return Debug.assertNever(name, `Convert to ES module got invalid syntax form ${name.kind}`); } - function getSpanOfEnclosingComment(fileName, position, onlyMultiLine) { - const sourceFile = syntaxTreeCache.getCurrentSourceFile(fileName); - const range = ts_formatting_exports.getRangeOfEnclosingComment(sourceFile, position); - return range && (!onlyMultiLine || range.kind === 3 /* MultiLineCommentTrivia */) ? createTextSpanFromRange(range) : void 0; + } + function convertAssignment(sourceFile, checker, assignment, changes, exports, useSitesToUnqualify) { + const { left, right } = assignment; + if (!isPropertyAccessExpression(left)) { + return false; } - function getTodoComments(fileName, descriptors) { - synchronizeHostData(); - const sourceFile = getValidSourceFile(fileName); - cancellationToken.throwIfCancellationRequested(); - const fileContents = sourceFile.text; - const result = []; - if (descriptors.length > 0 && !isNodeModulesFile(sourceFile.fileName)) { - const regExp = getTodoCommentsRegExp(); - let matchArray; - while (matchArray = regExp.exec(fileContents)) { - cancellationToken.throwIfCancellationRequested(); - const firstDescriptorCaptureIndex = 3; - Debug.assert(matchArray.length === descriptors.length + firstDescriptorCaptureIndex); - const preamble = matchArray[1]; - const matchPosition = matchArray.index + preamble.length; - if (!isInComment(sourceFile, matchPosition)) { - continue; - } - let descriptor; - for (let i = 0; i < descriptors.length; i++) { - if (matchArray[i + firstDescriptorCaptureIndex]) { - descriptor = descriptors[i]; - } - } - if (descriptor === void 0) - return Debug.fail(); - if (isLetterOrDigit(fileContents.charCodeAt(matchPosition + descriptor.text.length))) { - continue; - } - const message = matchArray[2]; - result.push({ descriptor, message, position: matchPosition }); + if (isExportsOrModuleExportsOrAlias(sourceFile, left)) { + if (isExportsOrModuleExportsOrAlias(sourceFile, right)) { + changes.delete(sourceFile, assignment.parent); + } else { + const replacement = isObjectLiteralExpression(right) ? tryChangeModuleExportsObject(right, useSitesToUnqualify) : isRequireCall( + right, + /*requireStringLiteralLikeArgument*/ + true + ) ? convertReExportAll(right.arguments[0], checker) : void 0; + if (replacement) { + changes.replaceNodeWithNodes(sourceFile, assignment.parent, replacement[0]); + return replacement[1]; + } else { + changes.replaceRangeWithText(sourceFile, createRange(left.getStart(sourceFile), right.pos), "export default"); + return true; } } - return result; - function escapeRegExp(str) { - return str.replace(/[\-\[\]\/\{\}\(\)\*\+\?\.\\\^\$\|]/g, "\\$&"); - } - function getTodoCommentsRegExp() { - const singleLineCommentStart = /(?:\/\/+\s*)/.source; - const multiLineCommentStart = /(?:\/\*+\s*)/.source; - const anyNumberOfSpacesAndAsterisksAtStartOfLine = /(?:^(?:\s|\*)*)/.source; - const preamble = "(" + anyNumberOfSpacesAndAsterisksAtStartOfLine + "|" + singleLineCommentStart + "|" + multiLineCommentStart + ")"; - const literals = "(?:" + map(descriptors, (d) => "(" + escapeRegExp(d.text) + ")").join("|") + ")"; - const endOfLineOrEndOfComment = /(?:$|\*\/)/.source; - const messageRemainder = /(?:.*?)/.source; - const messagePortion = "(" + literals + messageRemainder + ")"; - const regExpString = preamble + messagePortion + endOfLineOrEndOfComment; - return new RegExp(regExpString, "gim"); - } - function isLetterOrDigit(char) { - return char >= 97 /* a */ && char <= 122 /* z */ || char >= 65 /* A */ && char <= 90 /* Z */ || char >= 48 /* _0 */ && char <= 57 /* _9 */; - } - function isNodeModulesFile(path) { - return stringContains(path, "/node_modules/"); - } - } - function getRenameInfo2(fileName, position, preferences) { - synchronizeHostData(); - return ts_Rename_exports.getRenameInfo(program, getValidSourceFile(fileName), position, preferences || {}); - } - function getRefactorContext(file, positionOrRange, preferences, formatOptions, triggerReason, kind) { - const [startPosition, endPosition] = typeof positionOrRange === "number" ? [positionOrRange, void 0] : [positionOrRange.pos, positionOrRange.end]; - return { - file, - startPosition, - endPosition, - program: getProgram(), - host, - formatContext: ts_formatting_exports.getFormatContext(formatOptions, host), - // TODO: GH#18217 - cancellationToken, - preferences, - triggerReason, - kind - }; - } - function getInlayHintsContext(file, span, preferences) { - return { - file, - program: getProgram(), - host, - span, - preferences, - cancellationToken - }; - } - function getSmartSelectionRange2(fileName, position) { - return ts_SmartSelectionRange_exports.getSmartSelectionRange(position, syntaxTreeCache.getCurrentSourceFile(fileName)); - } - function getApplicableRefactors2(fileName, positionOrRange, preferences = emptyOptions, triggerReason, kind, includeInteractiveActions) { - synchronizeHostData(); - const file = getValidSourceFile(fileName); - return ts_refactor_exports.getApplicableRefactors(getRefactorContext(file, positionOrRange, preferences, emptyOptions, triggerReason, kind), includeInteractiveActions); - } - function getMoveToRefactoringFileSuggestions(fileName, positionOrRange, preferences = emptyOptions) { - synchronizeHostData(); - const sourceFile = getValidSourceFile(fileName); - const allFiles = Debug.checkDefined(program.getSourceFiles()); - const extension = extensionFromPath(fileName); - const files = mapDefined(allFiles, (file) => !(program == null ? void 0 : program.isSourceFileFromExternalLibrary(sourceFile)) && !(sourceFile === getValidSourceFile(file.fileName) || extension === ".ts" /* Ts */ && extensionFromPath(file.fileName) === ".d.ts" /* Dts */ || extension === ".d.ts" /* Dts */ && startsWith(getBaseFileName(file.fileName), "lib.") && extensionFromPath(file.fileName) === ".d.ts" /* Dts */) && extension === extensionFromPath(file.fileName) ? file.fileName : void 0); - const newFileName = createNewFileName(sourceFile, program, getRefactorContext(sourceFile, positionOrRange, preferences, emptyOptions), host); - return { newFileName, files }; - } - function getEditsForRefactor2(fileName, formatOptions, positionOrRange, refactorName13, actionName2, preferences = emptyOptions, interactiveRefactorArguments) { - synchronizeHostData(); - const file = getValidSourceFile(fileName); - return ts_refactor_exports.getEditsForRefactor(getRefactorContext(file, positionOrRange, preferences, formatOptions), refactorName13, actionName2, interactiveRefactorArguments); + } else if (isExportsOrModuleExportsOrAlias(sourceFile, left.expression)) { + convertNamedExport(sourceFile, assignment, changes, exports); } - function toLineColumnOffset(fileName, position) { - if (position === 0) { - return { line: 0, character: 0 }; + return false; + } + function tryChangeModuleExportsObject(object, useSitesToUnqualify) { + const statements = mapAllOrFail(object.properties, (prop) => { + switch (prop.kind) { + case 177 /* GetAccessor */: + case 178 /* SetAccessor */: + case 304 /* ShorthandPropertyAssignment */: + case 305 /* SpreadAssignment */: + return void 0; + case 303 /* PropertyAssignment */: + return !isIdentifier(prop.name) ? void 0 : convertExportsDotXEquals_replaceNode(prop.name.text, prop.initializer, useSitesToUnqualify); + case 174 /* MethodDeclaration */: + return !isIdentifier(prop.name) ? void 0 : functionExpressionToDeclaration(prop.name.text, [factory.createToken(95 /* ExportKeyword */)], prop, useSitesToUnqualify); + default: + Debug.assertNever(prop, `Convert to ES6 got invalid prop kind ${prop.kind}`); } - return sourceMapper.toLineColumnOffset(fileName, position); - } - function prepareCallHierarchy(fileName, position) { - synchronizeHostData(); - const declarations = ts_CallHierarchy_exports.resolveCallHierarchyDeclaration(program, getTouchingPropertyName(getValidSourceFile(fileName), position)); - return declarations && mapOneOrMany(declarations, (declaration) => ts_CallHierarchy_exports.createCallHierarchyItem(program, declaration)); - } - function provideCallHierarchyIncomingCalls(fileName, position) { - synchronizeHostData(); - const sourceFile = getValidSourceFile(fileName); - const declaration = firstOrOnly(ts_CallHierarchy_exports.resolveCallHierarchyDeclaration(program, position === 0 ? sourceFile : getTouchingPropertyName(sourceFile, position))); - return declaration ? ts_CallHierarchy_exports.getIncomingCalls(program, declaration, cancellationToken) : []; - } - function provideCallHierarchyOutgoingCalls(fileName, position) { - synchronizeHostData(); - const sourceFile = getValidSourceFile(fileName); - const declaration = firstOrOnly(ts_CallHierarchy_exports.resolveCallHierarchyDeclaration(program, position === 0 ? sourceFile : getTouchingPropertyName(sourceFile, position))); - return declaration ? ts_CallHierarchy_exports.getOutgoingCalls(program, declaration) : []; - } - function provideInlayHints2(fileName, span, preferences = emptyOptions) { - synchronizeHostData(); - const sourceFile = getValidSourceFile(fileName); - return ts_InlayHints_exports.provideInlayHints(getInlayHintsContext(sourceFile, span, preferences)); - } - const ls = { - dispose, - cleanupSemanticCache, - getSyntacticDiagnostics, - getSemanticDiagnostics, - getSuggestionDiagnostics, - getCompilerOptionsDiagnostics, - getSyntacticClassifications: getSyntacticClassifications2, - getSemanticClassifications: getSemanticClassifications3, - getEncodedSyntacticClassifications: getEncodedSyntacticClassifications2, - getEncodedSemanticClassifications: getEncodedSemanticClassifications3, - getCompletionsAtPosition: getCompletionsAtPosition2, - getCompletionEntryDetails: getCompletionEntryDetails2, - getCompletionEntrySymbol: getCompletionEntrySymbol2, - getSignatureHelpItems: getSignatureHelpItems2, - getQuickInfoAtPosition, - getDefinitionAtPosition: getDefinitionAtPosition2, - getDefinitionAndBoundSpan: getDefinitionAndBoundSpan2, - getImplementationAtPosition, - getTypeDefinitionAtPosition: getTypeDefinitionAtPosition2, - getReferencesAtPosition, - findReferences, - getFileReferences, - getDocumentHighlights, - getNameOrDottedNameSpan, - getBreakpointStatementAtPosition, - getNavigateToItems: getNavigateToItems2, - getRenameInfo: getRenameInfo2, - getSmartSelectionRange: getSmartSelectionRange2, - findRenameLocations, - getNavigationBarItems: getNavigationBarItems2, - getNavigationTree: getNavigationTree2, - getOutliningSpans, - getTodoComments, - getBraceMatchingAtPosition, - getIndentationAtPosition, - getFormattingEditsForRange, - getFormattingEditsForDocument, - getFormattingEditsAfterKeystroke, - getDocCommentTemplateAtPosition: getDocCommentTemplateAtPosition2, - isValidBraceCompletionAtPosition, - getJsxClosingTagAtPosition, - getLinkedEditingRangeAtPosition, - getSpanOfEnclosingComment, - getCodeFixesAtPosition, - getCombinedCodeFix, - applyCodeActionCommand, - organizeImports: organizeImports2, - getEditsForFileRename: getEditsForFileRename2, - getEmitOutput, - getNonBoundSourceFile, - getProgram, - getCurrentProgram: () => program, - getAutoImportProvider, - updateIsDefinitionOfReferencedSymbols, - getApplicableRefactors: getApplicableRefactors2, - getEditsForRefactor: getEditsForRefactor2, - getMoveToRefactoringFileSuggestions, - toLineColumnOffset, - getSourceMapper: () => sourceMapper, - clearSourceMapperCache: () => sourceMapper.clearCache(), - prepareCallHierarchy, - provideCallHierarchyIncomingCalls, - provideCallHierarchyOutgoingCalls, - toggleLineComment, - toggleMultilineComment, - commentSelection, - uncommentSelection, - provideInlayHints: provideInlayHints2, - getSupportedCodeFixes - }; - switch (languageServiceMode) { - case 0 /* Semantic */: - break; - case 1 /* PartialSemantic */: - invalidOperationsInPartialSemanticMode.forEach( - (key) => ls[key] = () => { - throw new Error(`LanguageService Operation: ${key} not allowed in LanguageServiceMode.PartialSemantic`); - } - ); - break; - case 2 /* Syntactic */: - invalidOperationsInSyntacticMode.forEach( - (key) => ls[key] = () => { - throw new Error(`LanguageService Operation: ${key} not allowed in LanguageServiceMode.Syntactic`); - } - ); - break; - default: - Debug.assertNever(languageServiceMode); + }); + return statements && [statements, false]; + } + function convertNamedExport(sourceFile, assignment, changes, exports) { + const { text } = assignment.left.name; + const rename = exports.get(text); + if (rename !== void 0) { + const newNodes = [ + makeConst( + /*modifiers*/ + void 0, + rename, + assignment.right + ), + makeExportDeclaration([factory.createExportSpecifier( + /*isTypeOnly*/ + false, + rename, + text + )]) + ]; + changes.replaceNodeWithNodes(sourceFile, assignment.parent, newNodes); + } else { + convertExportsPropertyAssignment(assignment, sourceFile, changes); } - return ls; } - function getNameTable(sourceFile) { - if (!sourceFile.nameTable) { - initializeNameTable(sourceFile); + function convertReExportAll(reExported, checker) { + const moduleSpecifier = reExported.text; + const moduleSymbol = checker.getSymbolAtLocation(reExported); + const exports = moduleSymbol ? moduleSymbol.exports : emptyMap; + return exports.has("export=" /* ExportEquals */) ? [[reExportDefault(moduleSpecifier)], true] : !exports.has("default" /* Default */) ? [[reExportStar(moduleSpecifier)], false] : ( + // If there's some non-default export, must include both `export *` and `export default`. + exports.size > 1 ? [[reExportStar(moduleSpecifier), reExportDefault(moduleSpecifier)], true] : [[reExportDefault(moduleSpecifier)], true] + ); + } + function reExportStar(moduleSpecifier) { + return makeExportDeclaration( + /*exportSpecifiers*/ + void 0, + moduleSpecifier + ); + } + function reExportDefault(moduleSpecifier) { + return makeExportDeclaration([factory.createExportSpecifier( + /*isTypeOnly*/ + false, + /*propertyName*/ + void 0, + "default" + )], moduleSpecifier); + } + function convertExportsPropertyAssignment({ left, right, parent: parent2 }, sourceFile, changes) { + const name = left.name.text; + if ((isFunctionExpression(right) || isArrowFunction(right) || isClassExpression(right)) && (!right.name || right.name.text === name)) { + changes.replaceRange(sourceFile, { pos: left.getStart(sourceFile), end: right.getStart(sourceFile) }, factory.createToken(95 /* ExportKeyword */), { suffix: " " }); + if (!right.name) + changes.insertName(sourceFile, right, name); + const semi = findChildOfKind(parent2, 27 /* SemicolonToken */, sourceFile); + if (semi) + changes.delete(sourceFile, semi); + } else { + changes.replaceNodeRangeWithNodes(sourceFile, left.expression, findChildOfKind(left, 25 /* DotToken */, sourceFile), [factory.createToken(95 /* ExportKeyword */), factory.createToken(87 /* ConstKeyword */)], { joiner: " ", suffix: " " }); } - return sourceFile.nameTable; } - function initializeNameTable(sourceFile) { - const nameTable = sourceFile.nameTable = /* @__PURE__ */ new Map(); - sourceFile.forEachChild(function walk(node) { - if (isIdentifier(node) && !isTagName(node) && node.escapedText || isStringOrNumericLiteralLike(node) && literalIsName(node)) { - const text = getEscapedTextOfIdentifierOrLiteral(node); - nameTable.set(text, nameTable.get(text) === void 0 ? node.pos : -1); - } else if (isPrivateIdentifier(node)) { - const text = node.escapedText; - nameTable.set(text, nameTable.get(text) === void 0 ? node.pos : -1); - } - forEachChild(node, walk); - if (hasJSDocNodes(node)) { - for (const jsDoc of node.jsDoc) { - forEachChild(jsDoc, walk); + function convertExportsDotXEquals_replaceNode(name, exported, useSitesToUnqualify) { + const modifiers = [factory.createToken(95 /* ExportKeyword */)]; + switch (exported.kind) { + case 218 /* FunctionExpression */: { + const { name: expressionName } = exported; + if (expressionName && expressionName.text !== name) { + return exportConst(); } } - }); - } - function literalIsName(node) { - return isDeclarationName(node) || node.parent.kind === 282 /* ExternalModuleReference */ || isArgumentOfElementAccessExpression(node) || isLiteralComputedPropertyDeclarationName(node); + case 219 /* ArrowFunction */: + return functionExpressionToDeclaration(name, modifiers, exported, useSitesToUnqualify); + case 231 /* ClassExpression */: + return classExpressionToDeclaration(name, modifiers, exported, useSitesToUnqualify); + default: + return exportConst(); + } + function exportConst() { + return makeConst(modifiers, factory.createIdentifier(name), replaceImportUseSites(exported, useSitesToUnqualify)); + } } - function getContainingObjectLiteralElement(node) { - const element = getContainingObjectLiteralElementWorker(node); - return element && (isObjectLiteralExpression(element.parent) || isJsxAttributes(element.parent)) ? element : void 0; + function replaceImportUseSites(nodeOrNodes, useSitesToUnqualify) { + if (!useSitesToUnqualify || !some(arrayFrom(useSitesToUnqualify.keys()), (original) => rangeContainsRange(nodeOrNodes, original))) { + return nodeOrNodes; + } + return isArray(nodeOrNodes) ? getSynthesizedDeepClonesWithReplacements( + nodeOrNodes, + /*includeTrivia*/ + true, + replaceNode + ) : getSynthesizedDeepCloneWithReplacements( + nodeOrNodes, + /*includeTrivia*/ + true, + replaceNode + ); + function replaceNode(original) { + if (original.kind === 211 /* PropertyAccessExpression */) { + const replacement = useSitesToUnqualify.get(original); + useSitesToUnqualify.delete(original); + return replacement; + } + } } - function getContainingObjectLiteralElementWorker(node) { - switch (node.kind) { - case 11 /* StringLiteral */: - case 15 /* NoSubstitutionTemplateLiteral */: - case 9 /* NumericLiteral */: - if (node.parent.kind === 166 /* ComputedPropertyName */) { - return isObjectLiteralElement(node.parent.parent) ? node.parent.parent : void 0; + function convertSingleImport(name, moduleSpecifier, checker, identifiers, target, quotePreference) { + switch (name.kind) { + case 206 /* ObjectBindingPattern */: { + const importSpecifiers = mapAllOrFail(name.elements, (e) => e.dotDotDotToken || e.initializer || e.propertyName && !isIdentifier(e.propertyName) || !isIdentifier(e.name) ? void 0 : makeImportSpecifier2(e.propertyName && e.propertyName.text, e.name.text)); + if (importSpecifiers) { + return convertedImports([makeImport( + /*defaultImport*/ + void 0, + importSpecifiers, + moduleSpecifier, + quotePreference + )]); } + } + case 207 /* ArrayBindingPattern */: { + const tmp = makeUniqueName(moduleSpecifierToValidIdentifier(moduleSpecifier.text, target), identifiers); + return convertedImports([ + makeImport( + factory.createIdentifier(tmp), + /*namedImports*/ + void 0, + moduleSpecifier, + quotePreference + ), + makeConst( + /*modifiers*/ + void 0, + getSynthesizedDeepClone(name), + factory.createIdentifier(tmp) + ) + ]); + } case 80 /* Identifier */: - return isObjectLiteralElement(node.parent) && (node.parent.parent.kind === 209 /* ObjectLiteralExpression */ || node.parent.parent.kind === 291 /* JsxAttributes */) && node.parent.name === node ? node.parent : void 0; + return convertSingleIdentifierImport(name, moduleSpecifier, checker, identifiers, quotePreference); + default: + return Debug.assertNever(name, `Convert to ES module got invalid name kind ${name.kind}`); } - return void 0; } - function getSymbolAtLocationForQuickInfo(node, checker) { - const object = getContainingObjectLiteralElement(node); - if (object) { - const contextualType = checker.getContextualType(object.parent); - const properties = contextualType && getPropertySymbolsFromContextualType( - object, - checker, - contextualType, - /*unionSymbolOk*/ - false - ); - if (properties && properties.length === 1) { - return first(properties); + function convertSingleIdentifierImport(name, moduleSpecifier, checker, identifiers, quotePreference) { + const nameSymbol = checker.getSymbolAtLocation(name); + const namedBindingsNames = /* @__PURE__ */ new Map(); + let needDefaultImport = false; + let useSitesToUnqualify; + for (const use of identifiers.original.get(name.text)) { + if (checker.getSymbolAtLocation(use) !== nameSymbol || use === name) { + continue; + } + const { parent: parent2 } = use; + if (isPropertyAccessExpression(parent2)) { + const { name: { text: propertyName } } = parent2; + if (propertyName === "default") { + needDefaultImport = true; + const importDefaultName = use.getText(); + (useSitesToUnqualify ?? (useSitesToUnqualify = /* @__PURE__ */ new Map())).set(parent2, factory.createIdentifier(importDefaultName)); + } else { + Debug.assert(parent2.expression === use, "Didn't expect expression === use"); + let idName = namedBindingsNames.get(propertyName); + if (idName === void 0) { + idName = makeUniqueName(propertyName, identifiers); + namedBindingsNames.set(propertyName, idName); + } + (useSitesToUnqualify ?? (useSitesToUnqualify = /* @__PURE__ */ new Map())).set(parent2, factory.createIdentifier(idName)); + } + } else { + needDefaultImport = true; } } - return checker.getSymbolAtLocation(node); - } - function getPropertySymbolsFromContextualType(node, checker, contextualType, unionSymbolOk) { - const name = getNameFromPropertyName(node.name); - if (!name) - return emptyArray; - if (!contextualType.isUnion()) { - const symbol = contextualType.getProperty(name); - return symbol ? [symbol] : emptyArray; - } - const discriminatedPropertySymbols = mapDefined(contextualType.types, (t) => (isObjectLiteralExpression(node.parent) || isJsxAttributes(node.parent)) && checker.isTypeInvalidDueToUnionDiscriminant(t, node.parent) ? void 0 : t.getProperty(name)); - if (unionSymbolOk && (discriminatedPropertySymbols.length === 0 || discriminatedPropertySymbols.length === contextualType.types.length)) { - const symbol = contextualType.getProperty(name); - if (symbol) - return [symbol]; + const namedBindings = namedBindingsNames.size === 0 ? void 0 : arrayFrom(mapIterator(namedBindingsNames.entries(), ([propertyName, idName]) => factory.createImportSpecifier( + /*isTypeOnly*/ + false, + propertyName === idName ? void 0 : factory.createIdentifier(propertyName), + factory.createIdentifier(idName) + ))); + if (!namedBindings) { + needDefaultImport = true; } - if (discriminatedPropertySymbols.length === 0) { - return mapDefined(contextualType.types, (t) => t.getProperty(name)); + return convertedImports( + [makeImport(needDefaultImport ? getSynthesizedDeepClone(name) : void 0, namedBindings, moduleSpecifier, quotePreference)], + useSitesToUnqualify + ); + } + function makeUniqueName(name, identifiers) { + while (identifiers.original.has(name) || identifiers.additional.has(name)) { + name = `_${name}`; } - return discriminatedPropertySymbols; + identifiers.additional.add(name); + return name; } - function isArgumentOfElementAccessExpression(node) { - return node && node.parent && node.parent.kind === 211 /* ElementAccessExpression */ && node.parent.argumentExpression === node; + function collectFreeIdentifiers(file) { + const map2 = createMultiMap(); + forEachFreeIdentifier(file, (id) => map2.add(id.text, id)); + return map2; } - function getDefaultLibFilePath(options) { - if (sys) { - return combinePaths(getDirectoryPath(normalizePath(sys.getExecutingFilePath())), getDefaultLibFileName(options)); + function forEachFreeIdentifier(node, cb) { + if (isIdentifier(node) && isFreeIdentifier(node)) + cb(node); + node.forEachChild((child) => forEachFreeIdentifier(child, cb)); + } + function isFreeIdentifier(node) { + const { parent: parent2 } = node; + switch (parent2.kind) { + case 211 /* PropertyAccessExpression */: + return parent2.name !== node; + case 208 /* BindingElement */: + return parent2.propertyName !== node; + case 276 /* ImportSpecifier */: + return parent2.propertyName !== node; + default: + return true; } - throw new Error("getDefaultLibFilePath is only supported when consumed as a node module. "); } - var servicesVersion, NodeObject, TokenOrIdentifierObject, SymbolObject, TokenObject, IdentifierObject, PrivateIdentifierObject, TypeObject, SignatureObject, SourceFileObject, SourceMapSourceObject, SyntaxTreeCache, NoopCancellationToken, CancellationTokenObject, ThrottledCancellationToken, invalidOperationsInPartialSemanticMode, invalidOperationsInSyntacticMode; - var init_services = __esm({ - "src/services/services.ts"() { + function functionExpressionToDeclaration(name, additionalModifiers, fn, useSitesToUnqualify) { + return factory.createFunctionDeclaration( + concatenate(additionalModifiers, getSynthesizedDeepClones(fn.modifiers)), + getSynthesizedDeepClone(fn.asteriskToken), + name, + getSynthesizedDeepClones(fn.typeParameters), + getSynthesizedDeepClones(fn.parameters), + getSynthesizedDeepClone(fn.type), + factory.converters.convertToFunctionBlock(replaceImportUseSites(fn.body, useSitesToUnqualify)) + ); + } + function classExpressionToDeclaration(name, additionalModifiers, cls, useSitesToUnqualify) { + return factory.createClassDeclaration( + concatenate(additionalModifiers, getSynthesizedDeepClones(cls.modifiers)), + name, + getSynthesizedDeepClones(cls.typeParameters), + getSynthesizedDeepClones(cls.heritageClauses), + replaceImportUseSites(cls.members, useSitesToUnqualify) + ); + } + function makeSingleImport(localName, propertyName, moduleSpecifier, quotePreference) { + return propertyName === "default" ? makeImport( + factory.createIdentifier(localName), + /*namedImports*/ + void 0, + moduleSpecifier, + quotePreference + ) : makeImport( + /*defaultImport*/ + void 0, + [makeImportSpecifier2(propertyName, localName)], + moduleSpecifier, + quotePreference + ); + } + function makeImportSpecifier2(propertyName, name) { + return factory.createImportSpecifier( + /*isTypeOnly*/ + false, + propertyName !== void 0 && propertyName !== name ? factory.createIdentifier(propertyName) : void 0, + factory.createIdentifier(name) + ); + } + function makeConst(modifiers, name, init) { + return factory.createVariableStatement( + modifiers, + factory.createVariableDeclarationList( + [factory.createVariableDeclaration( + name, + /*exclamationToken*/ + void 0, + /*type*/ + void 0, + init + )], + 2 /* Const */ + ) + ); + } + function makeExportDeclaration(exportSpecifiers, moduleSpecifier) { + return factory.createExportDeclaration( + /*modifiers*/ + void 0, + /*isTypeOnly*/ + false, + exportSpecifiers && factory.createNamedExports(exportSpecifiers), + moduleSpecifier === void 0 ? void 0 : factory.createStringLiteral(moduleSpecifier) + ); + } + function convertedImports(newImports, useSitesToUnqualify) { + return { + newImports, + useSitesToUnqualify + }; + } + var init_convertToEsModule = __esm({ + "src/services/codefixes/convertToEsModule.ts"() { "use strict"; init_ts4(); - init_ts_NavigateTo(); - init_ts_NavigationBar(); - init_ts_refactor(); - init_classifier(); - init_classifier2020(); - servicesVersion = "0.8"; - NodeObject = class { - constructor(kind, pos, end) { - this.pos = pos; - this.end = end; - this.flags = 0 /* None */; - this.modifierFlagsCache = 0 /* None */; - this.transformFlags = 0 /* None */; - this.parent = void 0; - this.kind = kind; - } - assertHasRealPosition(message) { - Debug.assert(!positionIsSynthesized(this.pos) && !positionIsSynthesized(this.end), message || "Node must have a real position for this operation"); - } - getSourceFile() { - return getSourceFileOfNode(this); - } - getStart(sourceFile, includeJsDocComment) { - this.assertHasRealPosition(); - return getTokenPosOfNode(this, sourceFile, includeJsDocComment); - } - getFullStart() { - this.assertHasRealPosition(); - return this.pos; - } - getEnd() { - this.assertHasRealPosition(); - return this.end; - } - getWidth(sourceFile) { - this.assertHasRealPosition(); - return this.getEnd() - this.getStart(sourceFile); - } - getFullWidth() { - this.assertHasRealPosition(); - return this.end - this.pos; - } - getLeadingTriviaWidth(sourceFile) { - this.assertHasRealPosition(); - return this.getStart(sourceFile) - this.pos; - } - getFullText(sourceFile) { - this.assertHasRealPosition(); - return (sourceFile || this.getSourceFile()).text.substring(this.pos, this.end); - } - getText(sourceFile) { - this.assertHasRealPosition(); - if (!sourceFile) { - sourceFile = this.getSourceFile(); - } - return sourceFile.text.substring(this.getStart(sourceFile), this.getEnd()); - } - getChildCount(sourceFile) { - return this.getChildren(sourceFile).length; - } - getChildAt(index, sourceFile) { - return this.getChildren(sourceFile)[index]; - } - getChildren(sourceFile) { - this.assertHasRealPosition("Node without a real position cannot be scanned and thus has no token nodes - use forEachChild and collect the result if that's fine"); - return this._children || (this._children = createChildren(this, sourceFile)); - } - getFirstToken(sourceFile) { - this.assertHasRealPosition(); - const children = this.getChildren(sourceFile); - if (!children.length) { - return void 0; - } - const child = find(children, (kid) => kid.kind < 315 /* FirstJSDocNode */ || kid.kind > 356 /* LastJSDocNode */); - return child.kind < 165 /* FirstNode */ ? child : child.getFirstToken(sourceFile); - } - getLastToken(sourceFile) { - this.assertHasRealPosition(); - const children = this.getChildren(sourceFile); - const child = lastOrUndefined(children); - if (!child) { - return void 0; - } - return child.kind < 165 /* FirstNode */ ? child : child.getLastToken(sourceFile); - } - forEachChild(cbNode, cbNodeArray) { - return forEachChild(this, cbNode, cbNodeArray); - } - }; - TokenOrIdentifierObject = class { - constructor(pos, end) { - this.pos = pos; - this.end = end; - this.flags = 0 /* None */; - this.modifierFlagsCache = 0 /* None */; - this.transformFlags = 0 /* None */; - this.parent = void 0; - } - getSourceFile() { - return getSourceFileOfNode(this); - } - getStart(sourceFile, includeJsDocComment) { - return getTokenPosOfNode(this, sourceFile, includeJsDocComment); - } - getFullStart() { - return this.pos; - } - getEnd() { - return this.end; - } - getWidth(sourceFile) { - return this.getEnd() - this.getStart(sourceFile); - } - getFullWidth() { - return this.end - this.pos; - } - getLeadingTriviaWidth(sourceFile) { - return this.getStart(sourceFile) - this.pos; - } - getFullText(sourceFile) { - return (sourceFile || this.getSourceFile()).text.substring(this.pos, this.end); - } - getText(sourceFile) { - if (!sourceFile) { - sourceFile = this.getSourceFile(); - } - return sourceFile.text.substring(this.getStart(sourceFile), this.getEnd()); - } - getChildCount() { - return this.getChildren().length; - } - getChildAt(index) { - return this.getChildren()[index]; - } - getChildren() { - return this.kind === 1 /* EndOfFileToken */ ? this.jsDoc || emptyArray : emptyArray; - } - getFirstToken() { - return void 0; - } - getLastToken() { - return void 0; - } - forEachChild() { - return void 0; - } - }; - SymbolObject = class { - constructor(flags, name) { - this.id = 0; - this.mergeId = 0; - this.flags = flags; - this.escapedName = name; - } - getFlags() { - return this.flags; - } - get name() { - return symbolName(this); - } - getEscapedName() { - return this.escapedName; - } - getName() { - return this.name; - } - getDeclarations() { - return this.declarations; - } - getDocumentationComment(checker) { - if (!this.documentationComment) { - this.documentationComment = emptyArray; - if (!this.declarations && isTransientSymbol(this) && this.links.target && isTransientSymbol(this.links.target) && this.links.target.links.tupleLabelDeclaration) { - const labelDecl = this.links.target.links.tupleLabelDeclaration; - this.documentationComment = getDocumentationComment([labelDecl], checker); - } else { - this.documentationComment = getDocumentationComment(this.declarations, checker); - } - } - return this.documentationComment; - } - getContextualDocumentationComment(context, checker) { - if (context) { - if (isGetAccessor(context)) { - if (!this.contextualGetAccessorDocumentationComment) { - this.contextualGetAccessorDocumentationComment = getDocumentationComment(filter(this.declarations, isGetAccessor), checker); - } - if (length(this.contextualGetAccessorDocumentationComment)) { - return this.contextualGetAccessorDocumentationComment; - } - } - if (isSetAccessor(context)) { - if (!this.contextualSetAccessorDocumentationComment) { - this.contextualSetAccessorDocumentationComment = getDocumentationComment(filter(this.declarations, isSetAccessor), checker); - } - if (length(this.contextualSetAccessorDocumentationComment)) { - return this.contextualSetAccessorDocumentationComment; - } - } - } - return this.getDocumentationComment(checker); - } - getJsDocTags(checker) { - if (this.tags === void 0) { - this.tags = getJsDocTagsOfDeclarations(this.declarations, checker); - } - return this.tags; - } - getContextualJsDocTags(context, checker) { - if (context) { - if (isGetAccessor(context)) { - if (!this.contextualGetAccessorTags) { - this.contextualGetAccessorTags = getJsDocTagsOfDeclarations(filter(this.declarations, isGetAccessor), checker); - } - if (length(this.contextualGetAccessorTags)) { - return this.contextualGetAccessorTags; - } - } - if (isSetAccessor(context)) { - if (!this.contextualSetAccessorTags) { - this.contextualSetAccessorTags = getJsDocTagsOfDeclarations(filter(this.declarations, isSetAccessor), checker); - } - if (length(this.contextualSetAccessorTags)) { - return this.contextualSetAccessorTags; - } - } - } - return this.getJsDocTags(checker); - } - }; - TokenObject = class extends TokenOrIdentifierObject { - constructor(kind, pos, end) { - super(pos, end); - this.kind = kind; - } - }; - IdentifierObject = class extends TokenOrIdentifierObject { - constructor(_kind, pos, end) { - super(pos, end); - this.kind = 80 /* Identifier */; - } - get text() { - return idText(this); - } - }; - IdentifierObject.prototype.kind = 80 /* Identifier */; - PrivateIdentifierObject = class extends TokenOrIdentifierObject { - constructor(_kind, pos, end) { - super(pos, end); - this.kind = 81 /* PrivateIdentifier */; - } - get text() { - return idText(this); - } - }; - PrivateIdentifierObject.prototype.kind = 81 /* PrivateIdentifier */; - TypeObject = class { - constructor(checker, flags) { - this.checker = checker; - this.flags = flags; - } - getFlags() { - return this.flags; - } - getSymbol() { - return this.symbol; - } - getProperties() { - return this.checker.getPropertiesOfType(this); - } - getProperty(propertyName) { - return this.checker.getPropertyOfType(this, propertyName); - } - getApparentProperties() { - return this.checker.getAugmentedPropertiesOfType(this); - } - getCallSignatures() { - return this.checker.getSignaturesOfType(this, 0 /* Call */); - } - getConstructSignatures() { - return this.checker.getSignaturesOfType(this, 1 /* Construct */); - } - getStringIndexType() { - return this.checker.getIndexTypeOfType(this, 0 /* String */); - } - getNumberIndexType() { - return this.checker.getIndexTypeOfType(this, 1 /* Number */); - } - getBaseTypes() { - return this.isClassOrInterface() ? this.checker.getBaseTypes(this) : void 0; - } - isNullableType() { - return this.checker.isNullableType(this); - } - getNonNullableType() { - return this.checker.getNonNullableType(this); - } - getNonOptionalType() { - return this.checker.getNonOptionalType(this); - } - getConstraint() { - return this.checker.getBaseConstraintOfType(this); - } - getDefault() { - return this.checker.getDefaultFromTypeParameter(this); - } - isUnion() { - return !!(this.flags & 1048576 /* Union */); - } - isIntersection() { - return !!(this.flags & 2097152 /* Intersection */); - } - isUnionOrIntersection() { - return !!(this.flags & 3145728 /* UnionOrIntersection */); - } - isLiteral() { - return !!(this.flags & (128 /* StringLiteral */ | 256 /* NumberLiteral */ | 2048 /* BigIntLiteral */)); - } - isStringLiteral() { - return !!(this.flags & 128 /* StringLiteral */); - } - isNumberLiteral() { - return !!(this.flags & 256 /* NumberLiteral */); - } - isTypeParameter() { - return !!(this.flags & 262144 /* TypeParameter */); - } - isClassOrInterface() { - return !!(getObjectFlags(this) & 3 /* ClassOrInterface */); - } - isClass() { - return !!(getObjectFlags(this) & 1 /* Class */); - } - isIndexType() { - return !!(this.flags & 4194304 /* Index */); - } - /** - * This polyfills `referenceType.typeArguments` for API consumers - */ - get typeArguments() { - if (getObjectFlags(this) & 4 /* Reference */) { - return this.checker.getTypeArguments(this); - } - return void 0; - } - }; - SignatureObject = class { - // same - constructor(checker, flags) { - this.checker = checker; - this.flags = flags; - } - getDeclaration() { - return this.declaration; - } - getTypeParameters() { - return this.typeParameters; - } - getParameters() { - return this.parameters; - } - getReturnType() { - return this.checker.getReturnTypeOfSignature(this); - } - getTypeParameterAtPosition(pos) { - const type = this.checker.getParameterType(this, pos); - if (type.isIndexType() && isThisTypeParameter(type.type)) { - const constraint = type.type.getConstraint(); - if (constraint) { - return this.checker.getIndexType(constraint); - } - } - return type; - } - getDocumentationComment() { - return this.documentationComment || (this.documentationComment = getDocumentationComment(singleElementArray(this.declaration), this.checker)); - } - getJsDocTags() { - return this.jsDocTags || (this.jsDocTags = getJsDocTagsOfDeclarations(singleElementArray(this.declaration), this.checker)); - } - }; - SourceFileObject = class extends NodeObject { - constructor(kind, pos, end) { - super(kind, pos, end); - this.kind = 311 /* SourceFile */; - } - update(newText, textChangeRange) { - return updateSourceFile(this, newText, textChangeRange); - } - getLineAndCharacterOfPosition(position) { - return getLineAndCharacterOfPosition(this, position); - } - getLineStarts() { - return getLineStarts(this); - } - getPositionOfLineAndCharacter(line, character, allowEdits) { - return computePositionOfLineAndCharacter(getLineStarts(this), line, character, this.text, allowEdits); - } - getLineEndOfPosition(pos) { - const { line } = this.getLineAndCharacterOfPosition(pos); - const lineStarts = this.getLineStarts(); - let lastCharPos; - if (line + 1 >= lineStarts.length) { - lastCharPos = this.getEnd(); - } - if (!lastCharPos) { - lastCharPos = lineStarts[line + 1] - 1; - } - const fullText = this.getFullText(); - return fullText[lastCharPos] === "\n" && fullText[lastCharPos - 1] === "\r" ? lastCharPos - 1 : lastCharPos; - } - getNamedDeclarations() { - if (!this.namedDeclarations) { - this.namedDeclarations = this.computeNamedDeclarations(); - } - return this.namedDeclarations; - } - computeNamedDeclarations() { - const result = createMultiMap(); - this.forEachChild(visit); - return result; - function addDeclaration(declaration) { - const name = getDeclarationName(declaration); - if (name) { - result.add(name, declaration); - } - } - function getDeclarations(name) { - let declarations = result.get(name); - if (!declarations) { - result.set(name, declarations = []); - } - return declarations; - } - function getDeclarationName(declaration) { - const name = getNonAssignedNameOfDeclaration(declaration); - return name && (isComputedPropertyName(name) && isPropertyAccessExpression(name.expression) ? name.expression.name.text : isPropertyName(name) ? getNameFromPropertyName(name) : void 0); - } - function visit(node) { - switch (node.kind) { - case 261 /* FunctionDeclaration */: - case 217 /* FunctionExpression */: - case 173 /* MethodDeclaration */: - case 172 /* MethodSignature */: - const functionDeclaration = node; - const declarationName = getDeclarationName(functionDeclaration); - if (declarationName) { - const declarations = getDeclarations(declarationName); - const lastDeclaration = lastOrUndefined(declarations); - if (lastDeclaration && functionDeclaration.parent === lastDeclaration.parent && functionDeclaration.symbol === lastDeclaration.symbol) { - if (functionDeclaration.body && !lastDeclaration.body) { - declarations[declarations.length - 1] = functionDeclaration; - } - } else { - declarations.push(functionDeclaration); - } - } - forEachChild(node, visit); - break; - case 262 /* ClassDeclaration */: - case 230 /* ClassExpression */: - case 263 /* InterfaceDeclaration */: - case 264 /* TypeAliasDeclaration */: - case 265 /* EnumDeclaration */: - case 266 /* ModuleDeclaration */: - case 270 /* ImportEqualsDeclaration */: - case 280 /* ExportSpecifier */: - case 275 /* ImportSpecifier */: - case 272 /* ImportClause */: - case 273 /* NamespaceImport */: - case 176 /* GetAccessor */: - case 177 /* SetAccessor */: - case 186 /* TypeLiteral */: - addDeclaration(node); - forEachChild(node, visit); - break; - case 168 /* Parameter */: - if (!hasSyntacticModifier(node, 16476 /* ParameterPropertyModifier */)) { - break; - } - case 259 /* VariableDeclaration */: - case 207 /* BindingElement */: { - const decl = node; - if (isBindingPattern(decl.name)) { - forEachChild(decl.name, visit); - break; - } - if (decl.initializer) { - visit(decl.initializer); - } + init_ts_codefix(); + registerCodeFix({ + errorCodes: [Diagnostics.File_is_a_CommonJS_module_it_may_be_converted_to_an_ES_module.code], + getCodeActions(context) { + const { sourceFile, program, preferences } = context; + const changes = ts_textChanges_exports.ChangeTracker.with(context, (changes2) => { + const moduleExportsChangedToDefault = convertFileToEsModule(sourceFile, program.getTypeChecker(), changes2, getEmitScriptTarget(program.getCompilerOptions()), getQuotePreference(sourceFile, preferences)); + if (moduleExportsChangedToDefault) { + for (const importingFile of program.getSourceFiles()) { + fixImportOfModuleExports(importingFile, sourceFile, program, changes2, getQuotePreference(importingFile, preferences)); } - case 305 /* EnumMember */: - case 171 /* PropertyDeclaration */: - case 170 /* PropertySignature */: - addDeclaration(node); - break; - case 277 /* ExportDeclaration */: - const exportDeclaration = node; - if (exportDeclaration.exportClause) { - if (isNamedExports(exportDeclaration.exportClause)) { - forEach(exportDeclaration.exportClause.elements, visit); - } else { - visit(exportDeclaration.exportClause.name); - } - } - break; - case 271 /* ImportDeclaration */: - const importClause = node.importClause; - if (importClause) { - if (importClause.name) { - addDeclaration(importClause.name); - } - if (importClause.namedBindings) { - if (importClause.namedBindings.kind === 273 /* NamespaceImport */) { - addDeclaration(importClause.namedBindings); - } else { - forEach(importClause.namedBindings.elements, visit); - } - } - } - break; - case 225 /* BinaryExpression */: - if (getAssignmentDeclarationKind(node) !== 0 /* None */) { - addDeclaration(node); - } - default: - forEachChild(node, visit); } - } - } - }; - SourceMapSourceObject = class { - constructor(fileName, text, skipTrivia2) { - this.fileName = fileName; - this.text = text; - this.skipTrivia = skipTrivia2; - } - getLineAndCharacterOfPosition(pos) { - return getLineAndCharacterOfPosition(this, pos); - } - }; - SyntaxTreeCache = class { - constructor(host) { - this.host = host; - } - getCurrentSourceFile(fileName) { - var _a, _b, _c, _d, _e, _f, _g, _h; - const scriptSnapshot = this.host.getScriptSnapshot(fileName); - if (!scriptSnapshot) { - throw new Error("Could not find file: '" + fileName + "'."); - } - const scriptKind = getScriptKind(fileName, this.host); - const version2 = this.host.getScriptVersion(fileName); - let sourceFile; - if (this.currentFileName !== fileName) { - const options = { - languageVersion: 99 /* Latest */, - impliedNodeFormat: getImpliedNodeFormatForFile( - toPath(fileName, this.host.getCurrentDirectory(), ((_c = (_b = (_a = this.host).getCompilerHost) == null ? void 0 : _b.call(_a)) == null ? void 0 : _c.getCanonicalFileName) || hostGetCanonicalFileName(this.host)), - (_h = (_g = (_f = (_e = (_d = this.host).getCompilerHost) == null ? void 0 : _e.call(_d)) == null ? void 0 : _f.getModuleResolutionCache) == null ? void 0 : _g.call(_f)) == null ? void 0 : _h.getPackageJsonInfoCache(), - this.host, - this.host.getCompilationSettings() - ), - setExternalModuleIndicator: getSetExternalModuleIndicator(this.host.getCompilationSettings()) - }; - sourceFile = createLanguageServiceSourceFile( - fileName, - scriptSnapshot, - options, - version2, - /*setNodeParents*/ - true, - scriptKind - ); - } else if (this.currentFileVersion !== version2) { - const editRange = scriptSnapshot.getChangeRange(this.currentFileScriptSnapshot); - sourceFile = updateLanguageServiceSourceFile(this.currentSourceFile, scriptSnapshot, version2, editRange); - } - if (sourceFile) { - this.currentFileVersion = version2; - this.currentFileName = fileName; - this.currentFileScriptSnapshot = scriptSnapshot; - this.currentSourceFile = sourceFile; - } - return this.currentSourceFile; - } - }; - NoopCancellationToken = { - isCancellationRequested: returnFalse, - throwIfCancellationRequested: noop - }; - CancellationTokenObject = class { - constructor(cancellationToken) { - this.cancellationToken = cancellationToken; - } - isCancellationRequested() { - return this.cancellationToken.isCancellationRequested(); - } - throwIfCancellationRequested() { - var _a; - if (this.isCancellationRequested()) { - (_a = tracing) == null ? void 0 : _a.instant(tracing.Phase.Session, "cancellationThrown", { kind: "CancellationTokenObject" }); - throw new OperationCanceledException(); - } - } - }; - ThrottledCancellationToken = class { - constructor(hostCancellationToken, throttleWaitMilliseconds = 20) { - this.hostCancellationToken = hostCancellationToken; - this.throttleWaitMilliseconds = throttleWaitMilliseconds; - // Store when we last tried to cancel. Checking cancellation can be expensive (as we have - // to marshall over to the host layer). So we only bother actually checking once enough - // time has passed. - this.lastCancellationCheckTime = 0; - } - isCancellationRequested() { - const time = timestamp(); - const duration = Math.abs(time - this.lastCancellationCheckTime); - if (duration >= this.throttleWaitMilliseconds) { - this.lastCancellationCheckTime = time; - return this.hostCancellationToken.isCancellationRequested(); - } - return false; - } - throwIfCancellationRequested() { - var _a; - if (this.isCancellationRequested()) { - (_a = tracing) == null ? void 0 : _a.instant(tracing.Phase.Session, "cancellationThrown", { kind: "ThrottledCancellationToken" }); - throw new OperationCanceledException(); - } + }); + return [createCodeFixActionWithoutFixAll("convertToEsModule", changes, Diagnostics.Convert_to_ES_module)]; } - }; - invalidOperationsInPartialSemanticMode = [ - "getSemanticDiagnostics", - "getSuggestionDiagnostics", - "getCompilerOptionsDiagnostics", - "getSemanticClassifications", - "getEncodedSemanticClassifications", - "getCodeFixesAtPosition", - "getCombinedCodeFix", - "applyCodeActionCommand", - "organizeImports", - "getEditsForFileRename", - "getEmitOutput", - "getApplicableRefactors", - "getEditsForRefactor", - "prepareCallHierarchy", - "provideCallHierarchyIncomingCalls", - "provideCallHierarchyOutgoingCalls", - "provideInlayHints", - "getSupportedCodeFixes" - ]; - invalidOperationsInSyntacticMode = [ - ...invalidOperationsInPartialSemanticMode, - "getCompletionsAtPosition", - "getCompletionEntryDetails", - "getCompletionEntrySymbol", - "getSignatureHelpItems", - "getQuickInfoAtPosition", - "getDefinitionAtPosition", - "getDefinitionAndBoundSpan", - "getImplementationAtPosition", - "getTypeDefinitionAtPosition", - "getReferencesAtPosition", - "findReferences", - "getDocumentHighlights", - "getNavigateToItems", - "getRenameInfo", - "findRenameLocations", - "getApplicableRefactors" - ]; - setObjectAllocator(getServicesObjectAllocator()); + }); + } + }); + + // src/services/codefixes/correctQualifiedNameToIndexedAccessType.ts + function getQualifiedName(sourceFile, pos) { + const qualifiedName = findAncestor(getTokenAtPosition(sourceFile, pos), isQualifiedName); + Debug.assert(!!qualifiedName, "Expected position to be owned by a qualified name."); + return isIdentifier(qualifiedName.left) ? qualifiedName : void 0; + } + function doChange10(changeTracker, sourceFile, qualifiedName) { + const rightText = qualifiedName.right.text; + const replacement = factory.createIndexedAccessTypeNode( + factory.createTypeReferenceNode( + qualifiedName.left, + /*typeArguments*/ + void 0 + ), + factory.createLiteralTypeNode(factory.createStringLiteral(rightText)) + ); + changeTracker.replaceNode(sourceFile, qualifiedName, replacement); + } + var fixId11, errorCodes12; + var init_correctQualifiedNameToIndexedAccessType = __esm({ + "src/services/codefixes/correctQualifiedNameToIndexedAccessType.ts"() { + "use strict"; + init_ts4(); + init_ts_codefix(); + fixId11 = "correctQualifiedNameToIndexedAccessType"; + errorCodes12 = [Diagnostics.Cannot_access_0_1_because_0_is_a_type_but_not_a_namespace_Did_you_mean_to_retrieve_the_type_of_the_property_1_in_0_with_0_1.code]; + registerCodeFix({ + errorCodes: errorCodes12, + getCodeActions(context) { + const qualifiedName = getQualifiedName(context.sourceFile, context.span.start); + if (!qualifiedName) + return void 0; + const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange10(t, context.sourceFile, qualifiedName)); + const newText = `${qualifiedName.left.text}["${qualifiedName.right.text}"]`; + return [createCodeFixAction(fixId11, changes, [Diagnostics.Rewrite_as_the_indexed_access_type_0, newText], fixId11, Diagnostics.Rewrite_all_as_indexed_access_types)]; + }, + fixIds: [fixId11], + getAllCodeActions: (context) => codeFixAll(context, errorCodes12, (changes, diag2) => { + const q = getQualifiedName(diag2.file, diag2.start); + if (q) { + doChange10(changes, diag2.file, q); + } + }) + }); } }); - // src/services/transform.ts - function transform(source, transformers, compilerOptions) { - const diagnostics = []; - compilerOptions = fixupCompilerOptions(compilerOptions, diagnostics); - const nodes = isArray(source) ? source : [source]; - const result = transformNodes( - /*resolver*/ - void 0, - /*host*/ - void 0, - factory, - compilerOptions, - nodes, - transformers, - /*allowDtsFiles*/ - true + // src/services/codefixes/convertToTypeOnlyExport.ts + function getExportSpecifierForDiagnosticSpan(span, sourceFile) { + return tryCast(getTokenAtPosition(sourceFile, span.start).parent, isExportSpecifier); + } + function fixSingleExportDeclaration(changes, exportSpecifier, context) { + if (!exportSpecifier) { + return; + } + const exportClause = exportSpecifier.parent; + const exportDeclaration = exportClause.parent; + const typeExportSpecifiers = getTypeExportSpecifiers(exportSpecifier, context); + if (typeExportSpecifiers.length === exportClause.elements.length) { + changes.insertModifierBefore(context.sourceFile, 156 /* TypeKeyword */, exportClause); + } else { + const valueExportDeclaration = factory.updateExportDeclaration( + exportDeclaration, + exportDeclaration.modifiers, + /*isTypeOnly*/ + false, + factory.updateNamedExports(exportClause, filter(exportClause.elements, (e) => !contains(typeExportSpecifiers, e))), + exportDeclaration.moduleSpecifier, + /*attributes*/ + void 0 + ); + const typeExportDeclaration = factory.createExportDeclaration( + /*modifiers*/ + void 0, + /*isTypeOnly*/ + true, + factory.createNamedExports(typeExportSpecifiers), + exportDeclaration.moduleSpecifier, + /*attributes*/ + void 0 + ); + changes.replaceNode(context.sourceFile, exportDeclaration, valueExportDeclaration, { + leadingTriviaOption: ts_textChanges_exports.LeadingTriviaOption.IncludeAll, + trailingTriviaOption: ts_textChanges_exports.TrailingTriviaOption.Exclude + }); + changes.insertNodeAfter(context.sourceFile, exportDeclaration, typeExportDeclaration); + } + } + function getTypeExportSpecifiers(originExportSpecifier, context) { + const exportClause = originExportSpecifier.parent; + if (exportClause.elements.length === 1) { + return exportClause.elements; + } + const diagnostics = getDiagnosticsWithinSpan( + createTextSpanFromNode(exportClause), + context.program.getSemanticDiagnostics(context.sourceFile, context.cancellationToken) ); - result.diagnostics = concatenate(result.diagnostics, diagnostics); - return result; + return filter(exportClause.elements, (element) => { + var _a; + return element === originExportSpecifier || ((_a = findDiagnosticForNode(element, diagnostics)) == null ? void 0 : _a.code) === errorCodes13[0]; + }); } - var init_transform = __esm({ - "src/services/transform.ts"() { + var errorCodes13, fixId12; + var init_convertToTypeOnlyExport = __esm({ + "src/services/codefixes/convertToTypeOnlyExport.ts"() { "use strict"; init_ts4(); + init_ts_codefix(); + errorCodes13 = [Diagnostics.Re_exporting_a_type_when_0_is_enabled_requires_using_export_type.code]; + fixId12 = "convertToTypeOnlyExport"; + registerCodeFix({ + errorCodes: errorCodes13, + getCodeActions: function getCodeActionsToConvertToTypeOnlyExport(context) { + const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => fixSingleExportDeclaration(t, getExportSpecifierForDiagnosticSpan(context.span, context.sourceFile), context)); + if (changes.length) { + return [createCodeFixAction(fixId12, changes, Diagnostics.Convert_to_type_only_export, fixId12, Diagnostics.Convert_all_re_exported_types_to_type_only_exports)]; + } + }, + fixIds: [fixId12], + getAllCodeActions: function getAllCodeActionsToConvertToTypeOnlyExport(context) { + const fixedExportDeclarations = /* @__PURE__ */ new Map(); + return codeFixAll(context, errorCodes13, (changes, diag2) => { + const exportSpecifier = getExportSpecifierForDiagnosticSpan(diag2, context.sourceFile); + if (exportSpecifier && addToSeen(fixedExportDeclarations, getNodeId(exportSpecifier.parent.parent))) { + fixSingleExportDeclaration(changes, exportSpecifier, context); + } + }); + } + }); } }); - // src/services/shims.ts - function logInternalError(logger, err) { - if (logger) { - logger.log("*INTERNAL ERROR* - Exception in typescript services: " + err.message); + // src/services/codefixes/convertToTypeOnlyImport.ts + function getDeclaration2(sourceFile, pos) { + const { parent: parent2 } = getTokenAtPosition(sourceFile, pos); + return isImportSpecifier(parent2) || isImportDeclaration(parent2) && parent2.importClause ? parent2 : void 0; + } + function canConvertImportDeclarationForSpecifier(specifier, sourceFile, program) { + if (specifier.parent.parent.name) { + return false; + } + const nonTypeOnlySpecifiers = specifier.parent.elements.filter((e) => !e.isTypeOnly); + if (nonTypeOnlySpecifiers.length === 1) { + return true; + } + const checker = program.getTypeChecker(); + for (const specifier2 of nonTypeOnlySpecifiers) { + const isUsedAsValue = ts_FindAllReferences_exports.Core.eachSymbolReferenceInFile(specifier2.name, checker, sourceFile, (usage) => { + return !isValidTypeOnlyAliasUseSite(usage); + }); + if (isUsedAsValue) { + return false; + } } + return true; } - function simpleForwardCall(logger, actionDescription2, action, logPerformance) { - let start; - if (logPerformance) { - logger.log(actionDescription2); - start = timestamp(); + function doChange11(changes, sourceFile, declaration) { + var _a; + if (isImportSpecifier(declaration)) { + changes.replaceNode(sourceFile, declaration, factory.updateImportSpecifier( + declaration, + /*isTypeOnly*/ + true, + declaration.propertyName, + declaration.name + )); + } else { + const importClause = declaration.importClause; + if (importClause.name && importClause.namedBindings) { + changes.replaceNodeWithNodes(sourceFile, declaration, [ + factory.createImportDeclaration( + getSynthesizedDeepClones( + declaration.modifiers, + /*includeTrivia*/ + true + ), + factory.createImportClause( + /*isTypeOnly*/ + true, + getSynthesizedDeepClone( + importClause.name, + /*includeTrivia*/ + true + ), + /*namedBindings*/ + void 0 + ), + getSynthesizedDeepClone( + declaration.moduleSpecifier, + /*includeTrivia*/ + true + ), + getSynthesizedDeepClone( + declaration.attributes, + /*includeTrivia*/ + true + ) + ), + factory.createImportDeclaration( + getSynthesizedDeepClones( + declaration.modifiers, + /*includeTrivia*/ + true + ), + factory.createImportClause( + /*isTypeOnly*/ + true, + /*name*/ + void 0, + getSynthesizedDeepClone( + importClause.namedBindings, + /*includeTrivia*/ + true + ) + ), + getSynthesizedDeepClone( + declaration.moduleSpecifier, + /*includeTrivia*/ + true + ), + getSynthesizedDeepClone( + declaration.attributes, + /*includeTrivia*/ + true + ) + ) + ]); + } else { + const newNamedBindings = ((_a = importClause.namedBindings) == null ? void 0 : _a.kind) === 275 /* NamedImports */ ? factory.updateNamedImports( + importClause.namedBindings, + sameMap(importClause.namedBindings.elements, (e) => factory.updateImportSpecifier( + e, + /*isTypeOnly*/ + false, + e.propertyName, + e.name + )) + ) : importClause.namedBindings; + const importDeclaration = factory.updateImportDeclaration(declaration, declaration.modifiers, factory.updateImportClause( + importClause, + /*isTypeOnly*/ + true, + importClause.name, + newNamedBindings + ), declaration.moduleSpecifier, declaration.attributes); + changes.replaceNode(sourceFile, declaration, importDeclaration); + } } - const result = action(); - if (logPerformance) { - const end = timestamp(); - logger.log(`${actionDescription2} completed in ${end - start} msec`); - if (isString(result)) { - let str = result; - if (str.length > 128) { - str = str.substring(0, 128) + "..."; + } + var errorCodes14, fixId13; + var init_convertToTypeOnlyImport = __esm({ + "src/services/codefixes/convertToTypeOnlyImport.ts"() { + "use strict"; + init_ts4(); + init_ts_codefix(); + errorCodes14 = [ + Diagnostics.This_import_is_never_used_as_a_value_and_must_use_import_type_because_importsNotUsedAsValues_is_set_to_error.code, + Diagnostics._0_is_a_type_and_must_be_imported_using_a_type_only_import_when_verbatimModuleSyntax_is_enabled.code + ]; + fixId13 = "convertToTypeOnlyImport"; + registerCodeFix({ + errorCodes: errorCodes14, + getCodeActions: function getCodeActionsToConvertToTypeOnlyImport(context) { + var _a; + const declaration = getDeclaration2(context.sourceFile, context.span.start); + if (declaration) { + const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange11(t, context.sourceFile, declaration)); + const importDeclarationChanges = declaration.kind === 276 /* ImportSpecifier */ && canConvertImportDeclarationForSpecifier(declaration, context.sourceFile, context.program) ? ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange11(t, context.sourceFile, declaration.parent.parent.parent)) : void 0; + const mainAction = createCodeFixAction( + fixId13, + changes, + declaration.kind === 276 /* ImportSpecifier */ ? [Diagnostics.Use_type_0, ((_a = declaration.propertyName) == null ? void 0 : _a.text) ?? declaration.name.text] : Diagnostics.Use_import_type, + fixId13, + Diagnostics.Fix_all_with_type_only_imports + ); + if (some(importDeclarationChanges)) { + return [ + createCodeFixActionWithoutFixAll(fixId13, importDeclarationChanges, Diagnostics.Use_import_type), + mainAction + ]; + } + return [mainAction]; + } + return void 0; + }, + fixIds: [fixId13], + getAllCodeActions: function getAllCodeActionsToConvertToTypeOnlyImport(context) { + const fixedImportDeclarations = /* @__PURE__ */ new Set(); + return codeFixAll(context, errorCodes14, (changes, diag2) => { + const errorDeclaration = getDeclaration2(diag2.file, diag2.start); + if ((errorDeclaration == null ? void 0 : errorDeclaration.kind) === 272 /* ImportDeclaration */ && !fixedImportDeclarations.has(errorDeclaration)) { + doChange11(changes, diag2.file, errorDeclaration); + fixedImportDeclarations.add(errorDeclaration); + } else if ((errorDeclaration == null ? void 0 : errorDeclaration.kind) === 276 /* ImportSpecifier */ && !fixedImportDeclarations.has(errorDeclaration.parent.parent.parent) && canConvertImportDeclarationForSpecifier(errorDeclaration, diag2.file, context.program)) { + doChange11(changes, diag2.file, errorDeclaration.parent.parent.parent); + fixedImportDeclarations.add(errorDeclaration.parent.parent.parent); + } else if ((errorDeclaration == null ? void 0 : errorDeclaration.kind) === 276 /* ImportSpecifier */) { + doChange11(changes, diag2.file, errorDeclaration); + } + }); } - logger.log(` result.length=${str.length}, result='${JSON.stringify(str)}'`); + }); + } + }); + + // src/services/codefixes/convertTypedefToType.ts + function doChange12(changes, node, sourceFile, newLine, fixAll = false) { + if (!isJSDocTypedefTag(node)) + return; + const declaration = createDeclaration(node); + if (!declaration) + return; + const commentNode = node.parent; + const { leftSibling, rightSibling } = getLeftAndRightSiblings(node); + let pos = commentNode.getStart(); + let prefix = ""; + if (!leftSibling && commentNode.comment) { + pos = findEndOfTextBetween(commentNode, commentNode.getStart(), node.getStart()); + prefix = `${newLine} */${newLine}`; + } + if (leftSibling) { + if (fixAll && isJSDocTypedefTag(leftSibling)) { + pos = node.getStart(); + prefix = ""; + } else { + pos = findEndOfTextBetween(commentNode, leftSibling.getStart(), node.getStart()); + prefix = `${newLine} */${newLine}`; } } - return result; + let end = commentNode.getEnd(); + let suffix = ""; + if (rightSibling) { + if (fixAll && isJSDocTypedefTag(rightSibling)) { + end = rightSibling.getStart(); + suffix = `${newLine}${newLine}`; + } else { + end = rightSibling.getStart(); + suffix = `${newLine}/**${newLine} * `; + } + } + changes.replaceRange(sourceFile, { pos, end }, declaration, { prefix, suffix }); } - function forwardJSONCall(logger, actionDescription2, action, logPerformance) { - return forwardCall( - logger, - actionDescription2, - /*returnJson*/ - true, - action, - logPerformance + function getLeftAndRightSiblings(typedefNode) { + const commentNode = typedefNode.parent; + const maxChildIndex = commentNode.getChildCount() - 1; + const currentNodeIndex = commentNode.getChildren().findIndex( + (n) => n.getStart() === typedefNode.getStart() && n.getEnd() === typedefNode.getEnd() ); + const leftSibling = currentNodeIndex > 0 ? commentNode.getChildAt(currentNodeIndex - 1) : void 0; + const rightSibling = currentNodeIndex < maxChildIndex ? commentNode.getChildAt(currentNodeIndex + 1) : void 0; + return { leftSibling, rightSibling }; } - function forwardCall(logger, actionDescription2, returnJson, action, logPerformance) { - try { - const result = simpleForwardCall(logger, actionDescription2, action, logPerformance); - return returnJson ? JSON.stringify({ result }) : result; - } catch (err) { - if (err instanceof OperationCanceledException) { - return JSON.stringify({ canceled: true }); + function findEndOfTextBetween(jsDocComment, from, to) { + const comment = jsDocComment.getText().substring(from - jsDocComment.getStart(), to - jsDocComment.getStart()); + for (let i = comment.length; i > 0; i--) { + if (!/[*/\s]/g.test(comment.substring(i - 1, i))) { + return from + i; } - logInternalError(logger, err); - err.description = actionDescription2; - return JSON.stringify({ error: err }); + } + return to; + } + function createDeclaration(tag) { + var _a; + const { typeExpression } = tag; + if (!typeExpression) + return; + const typeName = (_a = tag.name) == null ? void 0 : _a.getText(); + if (!typeName) + return; + if (typeExpression.kind === 329 /* JSDocTypeLiteral */) { + return createInterfaceForTypeLiteral(typeName, typeExpression); + } + if (typeExpression.kind === 316 /* JSDocTypeExpression */) { + return createTypeAliasForTypeExpression(typeName, typeExpression); } } - function realizeDiagnostics(diagnostics, newLine) { - return diagnostics.map((d) => realizeDiagnostic(d, newLine)); + function createInterfaceForTypeLiteral(typeName, typeLiteral) { + const propertySignatures = createSignatureFromTypeLiteral(typeLiteral); + if (!some(propertySignatures)) + return; + return factory.createInterfaceDeclaration( + /*modifiers*/ + void 0, + typeName, + /*typeParameters*/ + void 0, + /*heritageClauses*/ + void 0, + propertySignatures + ); } - function realizeDiagnostic(diagnostic, newLine) { - return { - message: flattenDiagnosticMessageText(diagnostic.messageText, newLine), - start: diagnostic.start, - // TODO: GH#18217 - length: diagnostic.length, - // TODO: GH#18217 - category: diagnosticCategoryName(diagnostic), - code: diagnostic.code, - reportsUnnecessary: diagnostic.reportsUnnecessary, - reportsDeprecated: diagnostic.reportsDeprecated + function createTypeAliasForTypeExpression(typeName, typeExpression) { + const typeReference = getSynthesizedDeepClone(typeExpression.type); + if (!typeReference) + return; + return factory.createTypeAliasDeclaration( + /*modifiers*/ + void 0, + factory.createIdentifier(typeName), + /*typeParameters*/ + void 0, + typeReference + ); + } + function createSignatureFromTypeLiteral(typeLiteral) { + const propertyTags = typeLiteral.jsDocPropertyTags; + if (!some(propertyTags)) + return; + const getSignature = (tag) => { + var _a; + const name = getPropertyName(tag); + const type = (_a = tag.typeExpression) == null ? void 0 : _a.type; + const isOptional = tag.isBracketed; + let typeReference; + if (type && isJSDocTypeLiteral(type)) { + const signatures = createSignatureFromTypeLiteral(type); + typeReference = factory.createTypeLiteralNode(signatures); + } else if (type) { + typeReference = getSynthesizedDeepClone(type); + } + if (typeReference && name) { + const questionToken = isOptional ? factory.createToken(58 /* QuestionToken */) : void 0; + return factory.createPropertySignature( + /*modifiers*/ + void 0, + name, + questionToken, + typeReference + ); + } }; + return mapDefined(propertyTags, getSignature); + } + function getPropertyName(tag) { + return tag.name.kind === 80 /* Identifier */ ? tag.name.text : tag.name.right.text; } - function convertClassifications(classifications) { - return { spans: classifications.spans.join(","), endOfLineState: classifications.endOfLineState }; + function getJSDocTypedefNodes(node) { + if (hasJSDocNodes(node)) { + return flatMap(node.jsDoc, (doc) => { + var _a; + return (_a = doc.tags) == null ? void 0 : _a.filter((tag) => isJSDocTypedefTag(tag)); + }); + } + return []; } - var debugObjectHost, ScriptSnapshotShimAdapter, LanguageServiceShimHostAdapter, CoreServicesShimHostAdapter, ShimBase, LanguageServiceShimObject, ClassifierShimObject, CoreServicesShimObject, TypeScriptServicesFactory; - var init_shims = __esm({ - "src/services/shims.ts"() { + var fixId14, errorCodes15; + var init_convertTypedefToType = __esm({ + "src/services/codefixes/convertTypedefToType.ts"() { "use strict"; init_ts4(); - debugObjectHost = function() { - return this; - }(); - ScriptSnapshotShimAdapter = class { - constructor(scriptSnapshotShim) { - this.scriptSnapshotShim = scriptSnapshotShim; - } - getText(start, end) { - return this.scriptSnapshotShim.getText(start, end); - } - getLength() { - return this.scriptSnapshotShim.getLength(); - } - getChangeRange(oldSnapshot) { - const oldSnapshotShim = oldSnapshot; - const encoded = this.scriptSnapshotShim.getChangeRange(oldSnapshotShim.scriptSnapshotShim); - if (encoded === null) { - return null; - } - const decoded = JSON.parse(encoded); - return createTextChangeRange( - createTextSpan(decoded.span.start, decoded.span.length), - decoded.newLength - ); - } - dispose() { - if ("dispose" in this.scriptSnapshotShim) { - this.scriptSnapshotShim.dispose(); - } - } - }; - LanguageServiceShimHostAdapter = class { - constructor(shimHost) { - this.shimHost = shimHost; - this.loggingEnabled = false; - this.tracingEnabled = false; - if ("getModuleResolutionsForFile" in this.shimHost) { - this.resolveModuleNames = (moduleNames, containingFile) => { - const resolutionsInFile = JSON.parse(this.shimHost.getModuleResolutionsForFile(containingFile)); - return map(moduleNames, (name) => { - const result = getProperty(resolutionsInFile, name); - return result ? { resolvedFileName: result, extension: extensionFromPath(result), isExternalLibraryImport: false } : void 0; - }); - }; - } - if ("directoryExists" in this.shimHost) { - this.directoryExists = (directoryName) => this.shimHost.directoryExists(directoryName); - } - if ("getTypeReferenceDirectiveResolutionsForFile" in this.shimHost) { - this.resolveTypeReferenceDirectives = (typeDirectiveNames, containingFile) => { - const typeDirectivesForFile = JSON.parse(this.shimHost.getTypeReferenceDirectiveResolutionsForFile(containingFile)); - return map(typeDirectiveNames, (name) => getProperty(typeDirectivesForFile, isString(name) ? name : toFileNameLowerCase(name.fileName))); - }; - } - } - log(s) { - if (this.loggingEnabled) { - this.shimHost.log(s); - } - } - trace(s) { - if (this.tracingEnabled) { - this.shimHost.trace(s); - } - } - error(s) { - this.shimHost.error(s); - } - getProjectVersion() { - if (!this.shimHost.getProjectVersion) { - return void 0; - } - return this.shimHost.getProjectVersion(); - } - getTypeRootsVersion() { - if (!this.shimHost.getTypeRootsVersion) { - return 0; - } - return this.shimHost.getTypeRootsVersion(); - } - useCaseSensitiveFileNames() { - return this.shimHost.useCaseSensitiveFileNames ? this.shimHost.useCaseSensitiveFileNames() : false; - } - getCompilationSettings() { - const settingsJson = this.shimHost.getCompilationSettings(); - if (settingsJson === null || settingsJson === "") { - throw Error("LanguageServiceShimHostAdapter.getCompilationSettings: empty compilationSettings"); - } - const compilerOptions = JSON.parse(settingsJson); - compilerOptions.allowNonTsExtensions = true; - return compilerOptions; - } - getScriptFileNames() { - const encoded = this.shimHost.getScriptFileNames(); - return JSON.parse(encoded); - } - getScriptSnapshot(fileName) { - const scriptSnapshot = this.shimHost.getScriptSnapshot(fileName); - return scriptSnapshot && new ScriptSnapshotShimAdapter(scriptSnapshot); - } - getScriptKind(fileName) { - if ("getScriptKind" in this.shimHost) { - return this.shimHost.getScriptKind(fileName); - } else { - return 0 /* Unknown */; - } - } - getScriptVersion(fileName) { - return this.shimHost.getScriptVersion(fileName); - } - getLocalizedDiagnosticMessages() { - const diagnosticMessagesJson = this.shimHost.getLocalizedDiagnosticMessages(); - if (diagnosticMessagesJson === null || diagnosticMessagesJson === "") { - return null; - } - try { - return JSON.parse(diagnosticMessagesJson); - } catch (e) { - this.log(e.description || "diagnosticMessages.generated.json has invalid JSON format"); - return null; - } - } - getCancellationToken() { - const hostCancellationToken = this.shimHost.getCancellationToken(); - return new ThrottledCancellationToken(hostCancellationToken); - } - getCurrentDirectory() { - return this.shimHost.getCurrentDirectory(); - } - getDirectories(path) { - return JSON.parse(this.shimHost.getDirectories(path)); - } - getDefaultLibFileName(options) { - return this.shimHost.getDefaultLibFileName(JSON.stringify(options)); - } - readDirectory(path, extensions, exclude, include, depth) { - const pattern = getFileMatcherPatterns( - path, - exclude, - include, - this.shimHost.useCaseSensitiveFileNames(), - this.shimHost.getCurrentDirectory() - ); - return JSON.parse(this.shimHost.readDirectory( - path, - JSON.stringify(extensions), - JSON.stringify(pattern.basePaths), - pattern.excludePattern, - pattern.includeFilePattern, - pattern.includeDirectoryPattern, - depth - )); - } - readFile(path, encoding) { - return this.shimHost.readFile(path, encoding); - } - fileExists(path) { - return this.shimHost.fileExists(path); - } - }; - CoreServicesShimHostAdapter = class { - constructor(shimHost) { - this.shimHost = shimHost; - this.useCaseSensitiveFileNames = this.shimHost.useCaseSensitiveFileNames ? this.shimHost.useCaseSensitiveFileNames() : false; - if ("directoryExists" in this.shimHost) { - this.directoryExists = (directoryName) => this.shimHost.directoryExists(directoryName); - } else { - this.directoryExists = void 0; - } - if ("realpath" in this.shimHost) { - this.realpath = (path) => this.shimHost.realpath(path); - } else { - this.realpath = void 0; - } - } - readDirectory(rootDir, extensions, exclude, include, depth) { - const pattern = getFileMatcherPatterns( - rootDir, - exclude, - include, - this.shimHost.useCaseSensitiveFileNames(), - this.shimHost.getCurrentDirectory() + init_ts_codefix(); + fixId14 = "convertTypedefToType"; + errorCodes15 = [Diagnostics.JSDoc_typedef_may_be_converted_to_TypeScript_type.code]; + registerCodeFix({ + fixIds: [fixId14], + errorCodes: errorCodes15, + getCodeActions(context) { + const newLineCharacter = getNewLineOrDefaultFromHost(context.host, context.formatContext.options); + const node = getTokenAtPosition( + context.sourceFile, + context.span.start ); - return JSON.parse(this.shimHost.readDirectory( - rootDir, - JSON.stringify(extensions), - JSON.stringify(pattern.basePaths), - pattern.excludePattern, - pattern.includeFilePattern, - pattern.includeDirectoryPattern, - depth - )); - } - fileExists(fileName) { - return this.shimHost.fileExists(fileName); - } - readFile(fileName) { - return this.shimHost.readFile(fileName); - } - getDirectories(path) { - return JSON.parse(this.shimHost.getDirectories(path)); - } - }; - ShimBase = class { - constructor(factory2) { - this.factory = factory2; - factory2.registerShim(this); - } - dispose(_dummy) { - this.factory.unregisterShim(this); - } - }; - LanguageServiceShimObject = class extends ShimBase { - constructor(factory2, host, languageService) { - super(factory2); - this.host = host; - this.languageService = languageService; - this.logPerformance = false; - this.logger = this.host; - } - forwardJSONCall(actionDescription2, action) { - return forwardJSONCall(this.logger, actionDescription2, action, this.logPerformance); - } - /// DISPOSE - /** - * Ensure (almost) deterministic release of internal Javascript resources when - * some external native objects holds onto us (e.g. Com/Interop). - */ - dispose(dummy) { - this.logger.log("dispose()"); - this.languageService.dispose(); - this.languageService = null; - if (debugObjectHost && debugObjectHost.CollectGarbage) { - debugObjectHost.CollectGarbage(); - this.logger.log("CollectGarbage()"); + if (!node) + return; + const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange12(t, node, context.sourceFile, newLineCharacter)); + if (changes.length > 0) { + return [ + createCodeFixAction( + fixId14, + changes, + Diagnostics.Convert_typedef_to_TypeScript_type, + fixId14, + Diagnostics.Convert_all_typedef_to_TypeScript_types + ) + ]; } - this.logger = null; - super.dispose(dummy); - } - /// REFRESH - /** - * Update the list of scripts known to the compiler - */ - refresh(throwOnError) { - this.forwardJSONCall( - `refresh(${throwOnError})`, - () => null - // eslint-disable-line no-null/no-null - ); - } - cleanupSemanticCache() { - this.forwardJSONCall( - "cleanupSemanticCache()", - () => { - this.languageService.cleanupSemanticCache(); - return null; - } - ); - } - realizeDiagnostics(diagnostics) { - const newLine = getNewLineOrDefaultFromHost( - this.host, - /*formatSettings*/ - void 0 - ); - return realizeDiagnostics(diagnostics, newLine); - } - getSyntacticClassifications(fileName, start, length2) { - return this.forwardJSONCall( - `getSyntacticClassifications('${fileName}', ${start}, ${length2})`, - () => this.languageService.getSyntacticClassifications(fileName, createTextSpan(start, length2)) - ); - } - getSemanticClassifications(fileName, start, length2) { - return this.forwardJSONCall( - `getSemanticClassifications('${fileName}', ${start}, ${length2})`, - () => this.languageService.getSemanticClassifications(fileName, createTextSpan(start, length2)) - ); - } - getEncodedSyntacticClassifications(fileName, start, length2) { - return this.forwardJSONCall( - `getEncodedSyntacticClassifications('${fileName}', ${start}, ${length2})`, - // directly serialize the spans out to a string. This is much faster to decode - // on the managed side versus a full JSON array. - () => convertClassifications(this.languageService.getEncodedSyntacticClassifications(fileName, createTextSpan(start, length2))) - ); - } - getEncodedSemanticClassifications(fileName, start, length2) { - return this.forwardJSONCall( - `getEncodedSemanticClassifications('${fileName}', ${start}, ${length2})`, - // directly serialize the spans out to a string. This is much faster to decode - // on the managed side versus a full JSON array. - () => convertClassifications(this.languageService.getEncodedSemanticClassifications(fileName, createTextSpan(start, length2))) - ); - } - getSyntacticDiagnostics(fileName) { - return this.forwardJSONCall( - `getSyntacticDiagnostics('${fileName}')`, - () => { - const diagnostics = this.languageService.getSyntacticDiagnostics(fileName); - return this.realizeDiagnostics(diagnostics); - } - ); - } - getSemanticDiagnostics(fileName) { - return this.forwardJSONCall( - `getSemanticDiagnostics('${fileName}')`, - () => { - const diagnostics = this.languageService.getSemanticDiagnostics(fileName); - return this.realizeDiagnostics(diagnostics); - } - ); - } - getSuggestionDiagnostics(fileName) { - return this.forwardJSONCall(`getSuggestionDiagnostics('${fileName}')`, () => this.realizeDiagnostics(this.languageService.getSuggestionDiagnostics(fileName))); - } - getCompilerOptionsDiagnostics() { - return this.forwardJSONCall( - "getCompilerOptionsDiagnostics()", - () => { - const diagnostics = this.languageService.getCompilerOptionsDiagnostics(); - return this.realizeDiagnostics(diagnostics); - } - ); - } - /// QUICKINFO - /** - * Computes a string representation of the type at the requested position - * in the active file. - */ - getQuickInfoAtPosition(fileName, position) { - return this.forwardJSONCall( - `getQuickInfoAtPosition('${fileName}', ${position})`, - () => this.languageService.getQuickInfoAtPosition(fileName, position) - ); - } - /// NAMEORDOTTEDNAMESPAN - /** - * Computes span information of the name or dotted name at the requested position - * in the active file. - */ - getNameOrDottedNameSpan(fileName, startPos, endPos) { - return this.forwardJSONCall( - `getNameOrDottedNameSpan('${fileName}', ${startPos}, ${endPos})`, - () => this.languageService.getNameOrDottedNameSpan(fileName, startPos, endPos) - ); - } - /** - * STATEMENTSPAN - * Computes span information of statement at the requested position in the active file. - */ - getBreakpointStatementAtPosition(fileName, position) { - return this.forwardJSONCall( - `getBreakpointStatementAtPosition('${fileName}', ${position})`, - () => this.languageService.getBreakpointStatementAtPosition(fileName, position) - ); - } - /// SIGNATUREHELP - getSignatureHelpItems(fileName, position, options) { - return this.forwardJSONCall( - `getSignatureHelpItems('${fileName}', ${position})`, - () => this.languageService.getSignatureHelpItems(fileName, position, options) - ); - } - /// GOTO DEFINITION - /** - * Computes the definition location and file for the symbol - * at the requested position. - */ - getDefinitionAtPosition(fileName, position) { - return this.forwardJSONCall( - `getDefinitionAtPosition('${fileName}', ${position})`, - () => this.languageService.getDefinitionAtPosition(fileName, position) - ); - } - /** - * Computes the definition location and file for the symbol - * at the requested position. - */ - getDefinitionAndBoundSpan(fileName, position) { - return this.forwardJSONCall( - `getDefinitionAndBoundSpan('${fileName}', ${position})`, - () => this.languageService.getDefinitionAndBoundSpan(fileName, position) - ); - } - /// GOTO Type - /** - * Computes the definition location of the type of the symbol - * at the requested position. - */ - getTypeDefinitionAtPosition(fileName, position) { - return this.forwardJSONCall( - `getTypeDefinitionAtPosition('${fileName}', ${position})`, - () => this.languageService.getTypeDefinitionAtPosition(fileName, position) - ); - } - /// GOTO Implementation - /** - * Computes the implementation location of the symbol - * at the requested position. - */ - getImplementationAtPosition(fileName, position) { - return this.forwardJSONCall( - `getImplementationAtPosition('${fileName}', ${position})`, - () => this.languageService.getImplementationAtPosition(fileName, position) - ); - } - getRenameInfo(fileName, position, preferences) { - return this.forwardJSONCall( - `getRenameInfo('${fileName}', ${position})`, - () => this.languageService.getRenameInfo(fileName, position, preferences) - ); - } - getSmartSelectionRange(fileName, position) { - return this.forwardJSONCall( - `getSmartSelectionRange('${fileName}', ${position})`, - () => this.languageService.getSmartSelectionRange(fileName, position) - ); - } - findRenameLocations(fileName, position, findInStrings, findInComments, preferences) { - return this.forwardJSONCall( - `findRenameLocations('${fileName}', ${position}, ${findInStrings}, ${findInComments})`, - () => this.languageService.findRenameLocations(fileName, position, findInStrings, findInComments, preferences) - ); - } - /// GET BRACE MATCHING - getBraceMatchingAtPosition(fileName, position) { - return this.forwardJSONCall( - `getBraceMatchingAtPosition('${fileName}', ${position})`, - () => this.languageService.getBraceMatchingAtPosition(fileName, position) - ); - } - isValidBraceCompletionAtPosition(fileName, position, openingBrace) { - return this.forwardJSONCall( - `isValidBraceCompletionAtPosition('${fileName}', ${position}, ${openingBrace})`, - () => this.languageService.isValidBraceCompletionAtPosition(fileName, position, openingBrace) - ); - } - getSpanOfEnclosingComment(fileName, position, onlyMultiLine) { - return this.forwardJSONCall( - `getSpanOfEnclosingComment('${fileName}', ${position})`, - () => this.languageService.getSpanOfEnclosingComment(fileName, position, onlyMultiLine) - ); - } - /// GET SMART INDENT - getIndentationAtPosition(fileName, position, options) { - return this.forwardJSONCall( - `getIndentationAtPosition('${fileName}', ${position})`, - () => { - const localOptions = JSON.parse(options); - return this.languageService.getIndentationAtPosition(fileName, position, localOptions); - } - ); - } - /// GET REFERENCES - getReferencesAtPosition(fileName, position) { - return this.forwardJSONCall( - `getReferencesAtPosition('${fileName}', ${position})`, - () => this.languageService.getReferencesAtPosition(fileName, position) - ); - } - findReferences(fileName, position) { - return this.forwardJSONCall( - `findReferences('${fileName}', ${position})`, - () => this.languageService.findReferences(fileName, position) - ); - } - getFileReferences(fileName) { - return this.forwardJSONCall( - `getFileReferences('${fileName})`, - () => this.languageService.getFileReferences(fileName) - ); - } - getDocumentHighlights(fileName, position, filesToSearch) { - return this.forwardJSONCall( - `getDocumentHighlights('${fileName}', ${position})`, - () => { - const results = this.languageService.getDocumentHighlights(fileName, position, JSON.parse(filesToSearch)); - const normalizedName = toFileNameLowerCase(normalizeSlashes(fileName)); - return filter(results, (r) => toFileNameLowerCase(normalizeSlashes(r.fileName)) === normalizedName); - } - ); - } - /// COMPLETION LISTS - /** - * Get a string based representation of the completions - * to provide at the given source position and providing a member completion - * list if requested. - */ - getCompletionsAtPosition(fileName, position, preferences, formattingSettings) { - return this.forwardJSONCall( - `getCompletionsAtPosition('${fileName}', ${position}, ${preferences}, ${formattingSettings})`, - () => this.languageService.getCompletionsAtPosition(fileName, position, preferences, formattingSettings) - ); - } - /** Get a string based representation of a completion list entry details */ - getCompletionEntryDetails(fileName, position, entryName, formatOptions, source, preferences, data) { - return this.forwardJSONCall( - `getCompletionEntryDetails('${fileName}', ${position}, '${entryName}')`, - () => { - const localOptions = formatOptions === void 0 ? void 0 : JSON.parse(formatOptions); - return this.languageService.getCompletionEntryDetails(fileName, position, entryName, localOptions, source, preferences, data); - } - ); - } - getFormattingEditsForRange(fileName, start, end, options) { - return this.forwardJSONCall( - `getFormattingEditsForRange('${fileName}', ${start}, ${end})`, - () => { - const localOptions = JSON.parse(options); - return this.languageService.getFormattingEditsForRange(fileName, start, end, localOptions); - } - ); - } - getFormattingEditsForDocument(fileName, options) { - return this.forwardJSONCall( - `getFormattingEditsForDocument('${fileName}')`, - () => { - const localOptions = JSON.parse(options); - return this.languageService.getFormattingEditsForDocument(fileName, localOptions); - } - ); - } - getFormattingEditsAfterKeystroke(fileName, position, key, options) { - return this.forwardJSONCall( - `getFormattingEditsAfterKeystroke('${fileName}', ${position}, '${key}')`, - () => { - const localOptions = JSON.parse(options); - return this.languageService.getFormattingEditsAfterKeystroke(fileName, position, key, localOptions); - } - ); - } - getDocCommentTemplateAtPosition(fileName, position, options, formatOptions) { - return this.forwardJSONCall( - `getDocCommentTemplateAtPosition('${fileName}', ${position})`, - () => this.languageService.getDocCommentTemplateAtPosition(fileName, position, options, formatOptions) - ); - } - /// NAVIGATE TO - /** Return a list of symbols that are interesting to navigate to */ - getNavigateToItems(searchValue, maxResultCount, fileName) { - return this.forwardJSONCall( - `getNavigateToItems('${searchValue}', ${maxResultCount}, ${fileName})`, - () => this.languageService.getNavigateToItems(searchValue, maxResultCount, fileName) - ); - } - getNavigationBarItems(fileName) { - return this.forwardJSONCall( - `getNavigationBarItems('${fileName}')`, - () => this.languageService.getNavigationBarItems(fileName) - ); - } - getNavigationTree(fileName) { - return this.forwardJSONCall( - `getNavigationTree('${fileName}')`, - () => this.languageService.getNavigationTree(fileName) - ); - } - getOutliningSpans(fileName) { - return this.forwardJSONCall( - `getOutliningSpans('${fileName}')`, - () => this.languageService.getOutliningSpans(fileName) - ); - } - getTodoComments(fileName, descriptors) { - return this.forwardJSONCall( - `getTodoComments('${fileName}')`, - () => this.languageService.getTodoComments(fileName, JSON.parse(descriptors)) - ); - } - /// CALL HIERARCHY - prepareCallHierarchy(fileName, position) { - return this.forwardJSONCall( - `prepareCallHierarchy('${fileName}', ${position})`, - () => this.languageService.prepareCallHierarchy(fileName, position) - ); - } - provideCallHierarchyIncomingCalls(fileName, position) { - return this.forwardJSONCall( - `provideCallHierarchyIncomingCalls('${fileName}', ${position})`, - () => this.languageService.provideCallHierarchyIncomingCalls(fileName, position) - ); - } - provideCallHierarchyOutgoingCalls(fileName, position) { - return this.forwardJSONCall( - `provideCallHierarchyOutgoingCalls('${fileName}', ${position})`, - () => this.languageService.provideCallHierarchyOutgoingCalls(fileName, position) - ); - } - provideInlayHints(fileName, span, preference) { - return this.forwardJSONCall( - `provideInlayHints('${fileName}', '${JSON.stringify(span)}', ${JSON.stringify(preference)})`, - () => this.languageService.provideInlayHints(fileName, span, preference) - ); - } - /// Emit - getEmitOutput(fileName) { - return this.forwardJSONCall( - `getEmitOutput('${fileName}')`, - () => { - const { diagnostics, ...rest } = this.languageService.getEmitOutput(fileName); - return { ...rest, diagnostics: this.realizeDiagnostics(diagnostics) }; - } - ); - } - getEmitOutputObject(fileName) { - return forwardCall( - this.logger, - `getEmitOutput('${fileName}')`, - /*returnJson*/ - false, - () => this.languageService.getEmitOutput(fileName), - this.logPerformance - ); - } - toggleLineComment(fileName, textRange) { - return this.forwardJSONCall( - `toggleLineComment('${fileName}', '${JSON.stringify(textRange)}')`, - () => this.languageService.toggleLineComment(fileName, textRange) - ); - } - toggleMultilineComment(fileName, textRange) { - return this.forwardJSONCall( - `toggleMultilineComment('${fileName}', '${JSON.stringify(textRange)}')`, - () => this.languageService.toggleMultilineComment(fileName, textRange) - ); - } - commentSelection(fileName, textRange) { - return this.forwardJSONCall( - `commentSelection('${fileName}', '${JSON.stringify(textRange)}')`, - () => this.languageService.commentSelection(fileName, textRange) - ); - } - uncommentSelection(fileName, textRange) { - return this.forwardJSONCall( - `uncommentSelection('${fileName}', '${JSON.stringify(textRange)}')`, - () => this.languageService.uncommentSelection(fileName, textRange) - ); - } - }; - ClassifierShimObject = class extends ShimBase { - constructor(factory2, logger) { - super(factory2); - this.logger = logger; - this.logPerformance = false; - this.classifier = createClassifier(); - } - getEncodedLexicalClassifications(text, lexState, syntacticClassifierAbsent = false) { - return forwardJSONCall( - this.logger, - "getEncodedLexicalClassifications", - () => convertClassifications(this.classifier.getEncodedLexicalClassifications(text, lexState, syntacticClassifierAbsent)), - this.logPerformance - ); - } - /// COLORIZATION - getClassificationsForLine(text, lexState, classifyKeywordsInGenerics = false) { - const classification = this.classifier.getClassificationsForLine(text, lexState, classifyKeywordsInGenerics); - let result = ""; - for (const item of classification.entries) { - result += item.length + "\n"; - result += item.classification + "\n"; + }, + getAllCodeActions: (context) => codeFixAll( + context, + errorCodes15, + (changes, diag2) => { + const newLineCharacter = getNewLineOrDefaultFromHost(context.host, context.formatContext.options); + const node = getTokenAtPosition(diag2.file, diag2.start); + const fixAll = true; + if (node) + doChange12(changes, node, diag2.file, newLineCharacter, fixAll); } - result += classification.finalLexState; - return result; - } + ) + }); + } + }); + + // src/services/codefixes/convertLiteralTypeToMappedType.ts + function getInfo5(sourceFile, pos) { + const token = getTokenAtPosition(sourceFile, pos); + if (isIdentifier(token)) { + const propertySignature = cast(token.parent.parent, isPropertySignature); + const propertyName = token.getText(sourceFile); + return { + container: cast(propertySignature.parent, isTypeLiteralNode), + typeNode: propertySignature.type, + constraint: propertyName, + name: propertyName === "K" ? "P" : "K" }; - CoreServicesShimObject = class extends ShimBase { - constructor(factory2, logger, host) { - super(factory2); - this.logger = logger; - this.host = host; - this.logPerformance = false; - } - forwardJSONCall(actionDescription2, action) { - return forwardJSONCall(this.logger, actionDescription2, action, this.logPerformance); - } - resolveModuleName(fileName, moduleName, compilerOptionsJson) { - return this.forwardJSONCall(`resolveModuleName('${fileName}')`, () => { - const compilerOptions = JSON.parse(compilerOptionsJson); - const result = resolveModuleName(moduleName, normalizeSlashes(fileName), compilerOptions, this.host); - let resolvedFileName = result.resolvedModule ? result.resolvedModule.resolvedFileName : void 0; - if (result.resolvedModule && result.resolvedModule.extension !== ".ts" /* Ts */ && result.resolvedModule.extension !== ".tsx" /* Tsx */ && result.resolvedModule.extension !== ".d.ts" /* Dts */) { - resolvedFileName = void 0; - } - return { - resolvedFileName, - failedLookupLocations: result.failedLookupLocations, - affectingLocations: result.affectingLocations - }; - }); - } - resolveTypeReferenceDirective(fileName, typeReferenceDirective, compilerOptionsJson) { - return this.forwardJSONCall(`resolveTypeReferenceDirective(${fileName})`, () => { - const compilerOptions = JSON.parse(compilerOptionsJson); - const result = resolveTypeReferenceDirective(typeReferenceDirective, normalizeSlashes(fileName), compilerOptions, this.host); - return { - resolvedFileName: result.resolvedTypeReferenceDirective ? result.resolvedTypeReferenceDirective.resolvedFileName : void 0, - primary: result.resolvedTypeReferenceDirective ? result.resolvedTypeReferenceDirective.primary : true, - failedLookupLocations: result.failedLookupLocations - }; - }); - } - getPreProcessedFileInfo(fileName, sourceTextSnapshot) { - return this.forwardJSONCall( - `getPreProcessedFileInfo('${fileName}')`, - () => { - const result = preProcessFile( - getSnapshotText(sourceTextSnapshot), - /*readImportFiles*/ - true, - /*detectJavaScriptImports*/ - true - ); - return { - referencedFiles: this.convertFileReferences(result.referencedFiles), - importedFiles: this.convertFileReferences(result.importedFiles), - ambientExternalModules: result.ambientExternalModules, - isLibFile: result.isLibFile, - typeReferenceDirectives: this.convertFileReferences(result.typeReferenceDirectives), - libReferenceDirectives: this.convertFileReferences(result.libReferenceDirectives) - }; - } - ); - } - getAutomaticTypeDirectiveNames(compilerOptionsJson) { - return this.forwardJSONCall( - `getAutomaticTypeDirectiveNames('${compilerOptionsJson}')`, - () => { - const compilerOptions = JSON.parse(compilerOptionsJson); - return getAutomaticTypeDirectiveNames(compilerOptions, this.host); - } - ); - } - convertFileReferences(refs) { - if (!refs) { + } + return void 0; + } + function doChange13(changes, sourceFile, { container, typeNode, constraint, name }) { + changes.replaceNode( + sourceFile, + container, + factory.createMappedTypeNode( + /*readonlyToken*/ + void 0, + factory.createTypeParameterDeclaration( + /*modifiers*/ + void 0, + name, + factory.createTypeReferenceNode(constraint) + ), + /*nameType*/ + void 0, + /*questionToken*/ + void 0, + typeNode, + /*members*/ + void 0 + ) + ); + } + var fixId15, errorCodes16; + var init_convertLiteralTypeToMappedType = __esm({ + "src/services/codefixes/convertLiteralTypeToMappedType.ts"() { + "use strict"; + init_ts4(); + init_ts_codefix(); + fixId15 = "convertLiteralTypeToMappedType"; + errorCodes16 = [Diagnostics._0_only_refers_to_a_type_but_is_being_used_as_a_value_here_Did_you_mean_to_use_1_in_0.code]; + registerCodeFix({ + errorCodes: errorCodes16, + getCodeActions: function getCodeActionsToConvertLiteralTypeToMappedType(context) { + const { sourceFile, span } = context; + const info = getInfo5(sourceFile, span.start); + if (!info) { return void 0; } - const result = []; - for (const ref of refs) { - result.push({ - path: normalizeSlashes(ref.fileName), - position: ref.pos, - length: ref.end - ref.pos - }); - } - return result; - } - getTSConfigFileInfo(fileName, sourceTextSnapshot) { - return this.forwardJSONCall( - `getTSConfigFileInfo('${fileName}')`, - () => { - const result = parseJsonText(fileName, getSnapshotText(sourceTextSnapshot)); - const normalizedFileName = normalizeSlashes(fileName); - const configFile = parseJsonSourceFileConfigFileContent( - result, - this.host, - getDirectoryPath(normalizedFileName), - /*existingOptions*/ - {}, - normalizedFileName - ); - return { - options: configFile.options, - typeAcquisition: configFile.typeAcquisition, - files: configFile.fileNames, - raw: configFile.raw, - errors: realizeDiagnostics([...result.parseDiagnostics, ...configFile.errors], "\r\n") - }; - } - ); - } - getDefaultCompilationSettings() { - return this.forwardJSONCall( - "getDefaultCompilationSettings()", - () => getDefaultCompilerOptions2() - ); - } - discoverTypings(discoverTypingsJson) { - const getCanonicalFileName = createGetCanonicalFileName( - /*useCaseSensitiveFileNames*/ - false - ); - return this.forwardJSONCall("discoverTypings()", () => { - const info = JSON.parse(discoverTypingsJson); - if (this.safeList === void 0) { - this.safeList = ts_JsTyping_exports.loadSafeList(this.host, toPath(info.safeListPath, info.safeListPath, getCanonicalFileName)); - } - return ts_JsTyping_exports.discoverTypings( - this.host, - (msg) => this.logger.log(msg), - info.fileNames, - toPath(info.projectRootPath, info.projectRootPath, getCanonicalFileName), - this.safeList, - info.packageNameToTypingLocation, - info.typeAcquisition, - info.unresolvedImports, - info.typesRegistry, - emptyOptions - ); - }); - } - }; - TypeScriptServicesFactory = class { - constructor() { - this._shims = []; - } - /* - * Returns script API version. - */ - getServicesVersion() { - return servicesVersion; - } - createLanguageServiceShim(host) { - try { - if (this.documentRegistry === void 0) { - this.documentRegistry = createDocumentRegistry(host.useCaseSensitiveFileNames && host.useCaseSensitiveFileNames(), host.getCurrentDirectory()); - } - const hostAdapter = new LanguageServiceShimHostAdapter(host); - const languageService = createLanguageService( - hostAdapter, - this.documentRegistry, - /*syntaxOnlyOrLanguageServiceMode*/ - false - ); - return new LanguageServiceShimObject(this, host, languageService); - } catch (err) { - logInternalError(host, err); - throw err; - } - } - createClassifierShim(logger) { - try { - return new ClassifierShimObject(this, logger); - } catch (err) { - logInternalError(logger, err); - throw err; - } - } - createCoreServicesShim(host) { - try { - const adapter = new CoreServicesShimHostAdapter(host); - return new CoreServicesShimObject(this, host, adapter); - } catch (err) { - logInternalError(host, err); - throw err; - } - } - close() { - clear(this._shims); - this.documentRegistry = void 0; - } - registerShim(shim) { - this._shims.push(shim); - } - unregisterShim(shim) { - for (let i = 0; i < this._shims.length; i++) { - if (this._shims[i] === shim) { - delete this._shims[i]; - return; - } + const { name, constraint } = info; + const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange13(t, sourceFile, info)); + return [createCodeFixAction(fixId15, changes, [Diagnostics.Convert_0_to_1_in_0, constraint, name], fixId15, Diagnostics.Convert_all_type_literals_to_mapped_type)]; + }, + fixIds: [fixId15], + getAllCodeActions: (context) => codeFixAll(context, errorCodes16, (changes, diag2) => { + const info = getInfo5(diag2.file, diag2.start); + if (info) { + doChange13(changes, diag2.file, info); } - throw new Error("Invalid operation"); - } - }; + }) + }); } }); - // src/services/breakpoints.ts - function spanInSourceFileAtLocation(sourceFile, position) { - if (sourceFile.isDeclarationFile) { - return void 0; - } - let tokenAtLocation = getTokenAtPosition(sourceFile, position); - const lineOfPosition = sourceFile.getLineAndCharacterOfPosition(position).line; - if (sourceFile.getLineAndCharacterOfPosition(tokenAtLocation.getStart(sourceFile)).line > lineOfPosition) { - const preceding = findPrecedingToken(tokenAtLocation.pos, sourceFile); - if (!preceding || sourceFile.getLineAndCharacterOfPosition(preceding.getEnd()).line !== lineOfPosition) { - return void 0; - } - tokenAtLocation = preceding; - } - if (tokenAtLocation.flags & 16777216 /* Ambient */) { - return void 0; - } - return spanInNode(tokenAtLocation); - function textSpan(startNode2, endNode2) { - const lastDecorator = canHaveDecorators(startNode2) ? findLast(startNode2.modifiers, isDecorator) : void 0; - const start = lastDecorator ? skipTrivia(sourceFile.text, lastDecorator.end) : startNode2.getStart(sourceFile); - return createTextSpanFromBounds(start, (endNode2 || startNode2).getEnd()); + // src/services/codefixes/fixClassIncorrectlyImplementsInterface.ts + function getClass(sourceFile, pos) { + return Debug.checkDefined(getContainingClass(getTokenAtPosition(sourceFile, pos)), "There should be a containing class"); + } + function symbolPointsToNonPrivateMember(symbol) { + return !symbol.valueDeclaration || !(getEffectiveModifierFlags(symbol.valueDeclaration) & 2 /* Private */); + } + function addMissingDeclarations(context, implementedTypeNode, sourceFile, classDeclaration, changeTracker, preferences) { + const checker = context.program.getTypeChecker(); + const maybeHeritageClauseSymbol = getHeritageClauseSymbolTable(classDeclaration, checker); + const implementedType = checker.getTypeAtLocation(implementedTypeNode); + const implementedTypeSymbols = checker.getPropertiesOfType(implementedType); + const nonPrivateAndNotExistedInHeritageClauseMembers = implementedTypeSymbols.filter(and(symbolPointsToNonPrivateMember, (symbol) => !maybeHeritageClauseSymbol.has(symbol.escapedName))); + const classType = checker.getTypeAtLocation(classDeclaration); + const constructor = find(classDeclaration.members, (m) => isConstructorDeclaration(m)); + if (!classType.getNumberIndexType()) { + createMissingIndexSignatureDeclaration(implementedType, 1 /* Number */); } - function textSpanEndingAtNextToken(startNode2, previousTokenToFindNextEndToken) { - return textSpan(startNode2, findNextToken(previousTokenToFindNextEndToken, previousTokenToFindNextEndToken.parent, sourceFile)); + if (!classType.getStringIndexType()) { + createMissingIndexSignatureDeclaration(implementedType, 0 /* String */); } - function spanInNodeIfStartsOnSameLine(node, otherwiseOnNode) { - if (node && lineOfPosition === sourceFile.getLineAndCharacterOfPosition(node.getStart(sourceFile)).line) { - return spanInNode(node); + const importAdder = createImportAdder(sourceFile, context.program, preferences, context.host); + createMissingMemberNodes(classDeclaration, nonPrivateAndNotExistedInHeritageClauseMembers, sourceFile, context, preferences, importAdder, (member) => insertInterfaceMemberNode(sourceFile, classDeclaration, member)); + importAdder.writeFixes(changeTracker); + function createMissingIndexSignatureDeclaration(type, kind) { + const indexInfoOfKind = checker.getIndexInfoOfType(type, kind); + if (indexInfoOfKind) { + insertInterfaceMemberNode(sourceFile, classDeclaration, checker.indexInfoToIndexSignatureDeclaration( + indexInfoOfKind, + classDeclaration, + /*flags*/ + void 0, + getNoopSymbolTrackerWithResolver(context) + )); } - return spanInNode(otherwiseOnNode); } - function spanInNodeArray(nodeArray, node, match) { - if (nodeArray) { - const index = nodeArray.indexOf(node); - if (index >= 0) { - let start = index; - let end = index + 1; - while (start > 0 && match(nodeArray[start - 1])) - start--; - while (end < nodeArray.length && match(nodeArray[end])) - end++; - return createTextSpanFromBounds(skipTrivia(sourceFile.text, nodeArray[start].pos), nodeArray[end - 1].end); - } + function insertInterfaceMemberNode(sourceFile2, cls, newElement) { + if (constructor) { + changeTracker.insertNodeAfter(sourceFile2, constructor, newElement); + } else { + changeTracker.insertMemberAtStart(sourceFile2, cls, newElement); } - return textSpan(node); - } - function spanInPreviousNode(node) { - return spanInNode(findPrecedingToken(node.pos, sourceFile)); - } - function spanInNextNode(node) { - return spanInNode(findNextToken(node, node.parent, sourceFile)); } - function spanInNode(node) { - if (node) { - const { parent: parent2 } = node; - switch (node.kind) { - case 242 /* VariableStatement */: - return spanInVariableDeclaration(node.declarationList.declarations[0]); - case 259 /* VariableDeclaration */: - case 171 /* PropertyDeclaration */: - case 170 /* PropertySignature */: - return spanInVariableDeclaration(node); - case 168 /* Parameter */: - return spanInParameterDeclaration(node); - case 261 /* FunctionDeclaration */: - case 173 /* MethodDeclaration */: - case 172 /* MethodSignature */: - case 176 /* GetAccessor */: - case 177 /* SetAccessor */: - case 175 /* Constructor */: - case 217 /* FunctionExpression */: - case 218 /* ArrowFunction */: - return spanInFunctionDeclaration(node); - case 240 /* Block */: - if (isFunctionBlock(node)) { - return spanInFunctionBlock(node); - } - case 267 /* ModuleBlock */: - return spanInBlock(node); - case 298 /* CatchClause */: - return spanInBlock(node.block); - case 243 /* ExpressionStatement */: - return textSpan(node.expression); - case 252 /* ReturnStatement */: - return textSpan(node.getChildAt(0), node.expression); - case 246 /* WhileStatement */: - return textSpanEndingAtNextToken(node, node.expression); - case 245 /* DoStatement */: - return spanInNode(node.statement); - case 258 /* DebuggerStatement */: - return textSpan(node.getChildAt(0)); - case 244 /* IfStatement */: - return textSpanEndingAtNextToken(node, node.expression); - case 255 /* LabeledStatement */: - return spanInNode(node.statement); - case 251 /* BreakStatement */: - case 250 /* ContinueStatement */: - return textSpan(node.getChildAt(0), node.label); - case 247 /* ForStatement */: - return spanInForStatement(node); - case 248 /* ForInStatement */: - return textSpanEndingAtNextToken(node, node.expression); - case 249 /* ForOfStatement */: - return spanInInitializerOfForLike(node); - case 254 /* SwitchStatement */: - return textSpanEndingAtNextToken(node, node.expression); - case 295 /* CaseClause */: - case 296 /* DefaultClause */: - return spanInNode(node.statements[0]); - case 257 /* TryStatement */: - return spanInBlock(node.tryBlock); - case 256 /* ThrowStatement */: - return textSpan(node, node.expression); - case 276 /* ExportAssignment */: - return textSpan(node, node.expression); - case 270 /* ImportEqualsDeclaration */: - return textSpan(node, node.moduleReference); - case 271 /* ImportDeclaration */: - return textSpan(node, node.moduleSpecifier); - case 277 /* ExportDeclaration */: - return textSpan(node, node.moduleSpecifier); - case 266 /* ModuleDeclaration */: - if (getModuleInstanceState(node) !== 1 /* Instantiated */) { - return void 0; - } - case 262 /* ClassDeclaration */: - case 265 /* EnumDeclaration */: - case 305 /* EnumMember */: - case 207 /* BindingElement */: - return textSpan(node); - case 253 /* WithStatement */: - return spanInNode(node.statement); - case 169 /* Decorator */: - return spanInNodeArray(parent2.modifiers, node, isDecorator); - case 205 /* ObjectBindingPattern */: - case 206 /* ArrayBindingPattern */: - return spanInBindingPattern(node); - case 263 /* InterfaceDeclaration */: - case 264 /* TypeAliasDeclaration */: - return void 0; - case 27 /* SemicolonToken */: - case 1 /* EndOfFileToken */: - return spanInNodeIfStartsOnSameLine(findPrecedingToken(node.pos, sourceFile)); - case 28 /* CommaToken */: - return spanInPreviousNode(node); - case 19 /* OpenBraceToken */: - return spanInOpenBraceToken(node); - case 20 /* CloseBraceToken */: - return spanInCloseBraceToken(node); - case 24 /* CloseBracketToken */: - return spanInCloseBracketToken(node); - case 21 /* OpenParenToken */: - return spanInOpenParenToken(node); - case 22 /* CloseParenToken */: - return spanInCloseParenToken(node); - case 59 /* ColonToken */: - return spanInColonToken(node); - case 32 /* GreaterThanToken */: - case 30 /* LessThanToken */: - return spanInGreaterThanOrLessThanToken(node); - case 117 /* WhileKeyword */: - return spanInWhileKeyword(node); - case 93 /* ElseKeyword */: - case 85 /* CatchKeyword */: - case 98 /* FinallyKeyword */: - return spanInNextNode(node); - case 164 /* OfKeyword */: - return spanInOfKeyword(node); - default: - if (isArrayLiteralOrObjectLiteralDestructuringPattern(node)) { - return spanInArrayLiteralOrObjectLiteralDestructuringPattern(node); - } - if ((node.kind === 80 /* Identifier */ || node.kind === 229 /* SpreadElement */ || node.kind === 302 /* PropertyAssignment */ || node.kind === 303 /* ShorthandPropertyAssignment */) && isArrayLiteralOrObjectLiteralDestructuringPattern(parent2)) { - return textSpan(node); - } - if (node.kind === 225 /* BinaryExpression */) { - const { left, operatorToken } = node; - if (isArrayLiteralOrObjectLiteralDestructuringPattern(left)) { - return spanInArrayLiteralOrObjectLiteralDestructuringPattern( - left - ); - } - if (operatorToken.kind === 64 /* EqualsToken */ && isArrayLiteralOrObjectLiteralDestructuringPattern(node.parent)) { - return textSpan(node); - } - if (operatorToken.kind === 28 /* CommaToken */) { - return spanInNode(left); - } - } - if (isExpressionNode(node)) { - switch (parent2.kind) { - case 245 /* DoStatement */: - return spanInPreviousNode(node); - case 169 /* Decorator */: - return spanInNode(node.parent); - case 247 /* ForStatement */: - case 249 /* ForOfStatement */: - return textSpan(node); - case 225 /* BinaryExpression */: - if (node.parent.operatorToken.kind === 28 /* CommaToken */) { - return textSpan(node); - } - break; - case 218 /* ArrowFunction */: - if (node.parent.body === node) { - return textSpan(node); - } - break; - } - } - switch (node.parent.kind) { - case 302 /* PropertyAssignment */: - if (node.parent.name === node && !isArrayLiteralOrObjectLiteralDestructuringPattern(node.parent.parent)) { - return spanInNode(node.parent.initializer); - } - break; - case 215 /* TypeAssertionExpression */: - if (node.parent.type === node) { - return spanInNextNode(node.parent.type); - } - break; - case 259 /* VariableDeclaration */: - case 168 /* Parameter */: { - const { initializer, type } = node.parent; - if (initializer === node || type === node || isAssignmentOperator(node.kind)) { - return spanInPreviousNode(node); - } - break; - } - case 225 /* BinaryExpression */: { - const { left } = node.parent; - if (isArrayLiteralOrObjectLiteralDestructuringPattern(left) && node !== left) { - return spanInPreviousNode(node); - } - break; + } + function getHeritageClauseSymbolTable(classDeclaration, checker) { + const heritageClauseNode = getEffectiveBaseTypeNode(classDeclaration); + if (!heritageClauseNode) + return createSymbolTable(); + const heritageClauseType = checker.getTypeAtLocation(heritageClauseNode); + const heritageClauseTypeSymbols = checker.getPropertiesOfType(heritageClauseType); + return createSymbolTable(heritageClauseTypeSymbols.filter(symbolPointsToNonPrivateMember)); + } + var errorCodes17, fixId16; + var init_fixClassIncorrectlyImplementsInterface = __esm({ + "src/services/codefixes/fixClassIncorrectlyImplementsInterface.ts"() { + "use strict"; + init_ts4(); + init_ts_codefix(); + errorCodes17 = [ + Diagnostics.Class_0_incorrectly_implements_interface_1.code, + Diagnostics.Class_0_incorrectly_implements_class_1_Did_you_mean_to_extend_1_and_inherit_its_members_as_a_subclass.code + ]; + fixId16 = "fixClassIncorrectlyImplementsInterface"; + registerCodeFix({ + errorCodes: errorCodes17, + getCodeActions(context) { + const { sourceFile, span } = context; + const classDeclaration = getClass(sourceFile, span.start); + return mapDefined(getEffectiveImplementsTypeNodes(classDeclaration), (implementedTypeNode) => { + const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => addMissingDeclarations(context, implementedTypeNode, sourceFile, classDeclaration, t, context.preferences)); + return changes.length === 0 ? void 0 : createCodeFixAction(fixId16, changes, [Diagnostics.Implement_interface_0, implementedTypeNode.getText(sourceFile)], fixId16, Diagnostics.Implement_all_unimplemented_interfaces); + }); + }, + fixIds: [fixId16], + getAllCodeActions(context) { + const seenClassDeclarations = /* @__PURE__ */ new Map(); + return codeFixAll(context, errorCodes17, (changes, diag2) => { + const classDeclaration = getClass(diag2.file, diag2.start); + if (addToSeen(seenClassDeclarations, getNodeId(classDeclaration))) { + for (const implementedTypeNode of getEffectiveImplementsTypeNodes(classDeclaration)) { + addMissingDeclarations(context, implementedTypeNode, diag2.file, classDeclaration, changes, context.preferences); } - default: - if (isFunctionLike(node.parent) && node.parent.type === node) { - return spanInPreviousNode(node); - } } - return spanInNode(node.parent); - } - } - function textSpanFromVariableDeclaration(variableDeclaration) { - if (isVariableDeclarationList(variableDeclaration.parent) && variableDeclaration.parent.declarations[0] === variableDeclaration) { - return textSpan(findPrecedingToken(variableDeclaration.pos, sourceFile, variableDeclaration.parent), variableDeclaration); - } else { - return textSpan(variableDeclaration); - } - } - function spanInVariableDeclaration(variableDeclaration) { - if (variableDeclaration.parent.parent.kind === 248 /* ForInStatement */) { - return spanInNode(variableDeclaration.parent.parent); - } - const parent2 = variableDeclaration.parent; - if (isBindingPattern(variableDeclaration.name)) { - return spanInBindingPattern(variableDeclaration.name); - } - if (hasOnlyExpressionInitializer(variableDeclaration) && variableDeclaration.initializer || hasSyntacticModifier(variableDeclaration, 1 /* Export */) || parent2.parent.kind === 249 /* ForOfStatement */) { - return textSpanFromVariableDeclaration(variableDeclaration); - } - if (isVariableDeclarationList(variableDeclaration.parent) && variableDeclaration.parent.declarations[0] !== variableDeclaration) { - return spanInNode(findPrecedingToken(variableDeclaration.pos, sourceFile, variableDeclaration.parent)); + }); } + }); + } + }); + + // src/services/codefixes/importFixes.ts + function createImportAdder(sourceFile, program, preferences, host, cancellationToken) { + return createImportAdderWorker( + sourceFile, + program, + /*useAutoImportProvider*/ + false, + preferences, + host, + cancellationToken + ); + } + function createImportAdderWorker(sourceFile, program, useAutoImportProvider, preferences, host, cancellationToken) { + const compilerOptions = program.getCompilerOptions(); + const addToNamespace = []; + const importType = []; + const addToExisting = /* @__PURE__ */ new Map(); + const newImports = /* @__PURE__ */ new Map(); + return { addImportFromDiagnostic, addImportFromExportedSymbol, writeFixes, hasFixes }; + function addImportFromDiagnostic(diagnostic, context) { + const info = getFixInfos(context, diagnostic.code, diagnostic.start, useAutoImportProvider); + if (!info || !info.length) + return; + addImport(first(info)); + } + function addImportFromExportedSymbol(exportedSymbol, isValidTypeOnlyUseSite) { + const moduleSymbol = Debug.checkDefined(exportedSymbol.parent); + const symbolName2 = getNameForExportedSymbol(exportedSymbol, getEmitScriptTarget(compilerOptions)); + const checker = program.getTypeChecker(); + const symbol = checker.getMergedSymbol(skipAlias(exportedSymbol, checker)); + const exportInfo = getAllExportInfoForSymbol( + sourceFile, + symbol, + symbolName2, + moduleSymbol, + /*preferCapitalized*/ + false, + program, + host, + preferences, + cancellationToken + ); + const useRequire = shouldUseRequire(sourceFile, program); + const fix = getImportFixForSymbol( + sourceFile, + Debug.checkDefined(exportInfo), + program, + /*position*/ + void 0, + !!isValidTypeOnlyUseSite, + useRequire, + host, + preferences + ); + if (fix) { + addImport({ fix, symbolName: symbolName2, errorIdentifierText: void 0 }); } - function canHaveSpanInParameterDeclaration(parameter) { - return !!parameter.initializer || parameter.dotDotDotToken !== void 0 || hasSyntacticModifier(parameter, 4 /* Public */ | 8 /* Private */); - } - function spanInParameterDeclaration(parameter) { - if (isBindingPattern(parameter.name)) { - return spanInBindingPattern(parameter.name); - } else if (canHaveSpanInParameterDeclaration(parameter)) { - return textSpan(parameter); - } else { - const functionDeclaration = parameter.parent; - const indexOfParameter = functionDeclaration.parameters.indexOf(parameter); - Debug.assert(indexOfParameter !== -1); - if (indexOfParameter !== 0) { - return spanInParameterDeclaration(functionDeclaration.parameters[indexOfParameter - 1]); + } + function addImport(info) { + var _a, _b; + const { fix, symbolName: symbolName2 } = info; + switch (fix.kind) { + case 0 /* UseNamespace */: + addToNamespace.push(fix); + break; + case 1 /* JsdocTypeImport */: + importType.push(fix); + break; + case 2 /* AddToExisting */: { + const { importClauseOrBindingPattern, importKind, addAsTypeOnly } = fix; + const key = String(getNodeId(importClauseOrBindingPattern)); + let entry = addToExisting.get(key); + if (!entry) { + addToExisting.set(key, entry = { importClauseOrBindingPattern, defaultImport: void 0, namedImports: /* @__PURE__ */ new Map() }); + } + if (importKind === 0 /* Named */) { + const prevValue = entry == null ? void 0 : entry.namedImports.get(symbolName2); + entry.namedImports.set(symbolName2, reduceAddAsTypeOnlyValues(prevValue, addAsTypeOnly)); } else { - return spanInNode(functionDeclaration.body); + Debug.assert(entry.defaultImport === void 0 || entry.defaultImport.name === symbolName2, "(Add to Existing) Default import should be missing or match symbolName"); + entry.defaultImport = { + name: symbolName2, + addAsTypeOnly: reduceAddAsTypeOnlyValues((_a = entry.defaultImport) == null ? void 0 : _a.addAsTypeOnly, addAsTypeOnly) + }; + } + break; + } + case 3 /* AddNew */: { + const { moduleSpecifier, importKind, useRequire, addAsTypeOnly } = fix; + const entry = getNewImportEntry(moduleSpecifier, importKind, useRequire, addAsTypeOnly); + Debug.assert(entry.useRequire === useRequire, "(Add new) Tried to add an `import` and a `require` for the same module"); + switch (importKind) { + case 1 /* Default */: + Debug.assert(entry.defaultImport === void 0 || entry.defaultImport.name === symbolName2, "(Add new) Default import should be missing or match symbolName"); + entry.defaultImport = { name: symbolName2, addAsTypeOnly: reduceAddAsTypeOnlyValues((_b = entry.defaultImport) == null ? void 0 : _b.addAsTypeOnly, addAsTypeOnly) }; + break; + case 0 /* Named */: + const prevValue = (entry.namedImports || (entry.namedImports = /* @__PURE__ */ new Map())).get(symbolName2); + entry.namedImports.set(symbolName2, reduceAddAsTypeOnlyValues(prevValue, addAsTypeOnly)); + break; + case 3 /* CommonJS */: + case 2 /* Namespace */: + Debug.assert(entry.namespaceLikeImport === void 0 || entry.namespaceLikeImport.name === symbolName2, "Namespacelike import shoudl be missing or match symbolName"); + entry.namespaceLikeImport = { importKind, name: symbolName2, addAsTypeOnly }; + break; } + break; } + case 4 /* PromoteTypeOnly */: + break; + default: + Debug.assertNever(fix, `fix wasn't never - got kind ${fix.kind}`); } - function canFunctionHaveSpanInWholeDeclaration(functionDeclaration) { - return hasSyntacticModifier(functionDeclaration, 1 /* Export */) || functionDeclaration.parent.kind === 262 /* ClassDeclaration */ && functionDeclaration.kind !== 175 /* Constructor */; + function reduceAddAsTypeOnlyValues(prevValue, newValue) { + return Math.max(prevValue ?? 0, newValue); } - function spanInFunctionDeclaration(functionDeclaration) { - if (!functionDeclaration.body) { - return void 0; + function getNewImportEntry(moduleSpecifier, importKind, useRequire, addAsTypeOnly) { + const typeOnlyKey = newImportsKey( + moduleSpecifier, + /*topLevelTypeOnly*/ + true + ); + const nonTypeOnlyKey = newImportsKey( + moduleSpecifier, + /*topLevelTypeOnly*/ + false + ); + const typeOnlyEntry = newImports.get(typeOnlyKey); + const nonTypeOnlyEntry = newImports.get(nonTypeOnlyKey); + const newEntry = { + defaultImport: void 0, + namedImports: void 0, + namespaceLikeImport: void 0, + useRequire + }; + if (importKind === 1 /* Default */ && addAsTypeOnly === 2 /* Required */) { + if (typeOnlyEntry) + return typeOnlyEntry; + newImports.set(typeOnlyKey, newEntry); + return newEntry; } - if (canFunctionHaveSpanInWholeDeclaration(functionDeclaration)) { - return textSpan(functionDeclaration); + if (addAsTypeOnly === 1 /* Allowed */ && (typeOnlyEntry || nonTypeOnlyEntry)) { + return typeOnlyEntry || nonTypeOnlyEntry; } - return spanInNode(functionDeclaration.body); - } - function spanInFunctionBlock(block) { - const nodeForSpanInBlock = block.statements.length ? block.statements[0] : block.getLastToken(); - if (canFunctionHaveSpanInWholeDeclaration(block.parent)) { - return spanInNodeIfStartsOnSameLine(block.parent, nodeForSpanInBlock); + if (nonTypeOnlyEntry) { + return nonTypeOnlyEntry; } - return spanInNode(nodeForSpanInBlock); + newImports.set(nonTypeOnlyKey, newEntry); + return newEntry; } - function spanInBlock(block) { - switch (block.parent.kind) { - case 266 /* ModuleDeclaration */: - if (getModuleInstanceState(block.parent) !== 1 /* Instantiated */) { - return void 0; - } - case 246 /* WhileStatement */: - case 244 /* IfStatement */: - case 248 /* ForInStatement */: - return spanInNodeIfStartsOnSameLine(block.parent, block.statements[0]); - case 247 /* ForStatement */: - case 249 /* ForOfStatement */: - return spanInNodeIfStartsOnSameLine(findPrecedingToken(block.pos, sourceFile, block.parent), block.statements[0]); - } - return spanInNode(block.statements[0]); + function newImportsKey(moduleSpecifier, topLevelTypeOnly) { + return `${topLevelTypeOnly ? 1 : 0}|${moduleSpecifier}`; } - function spanInInitializerOfForLike(forLikeStatement) { - if (forLikeStatement.initializer.kind === 260 /* VariableDeclarationList */) { - const variableDeclarationList = forLikeStatement.initializer; - if (variableDeclarationList.declarations.length > 0) { - return spanInNode(variableDeclarationList.declarations[0]); - } - } else { - return spanInNode(forLikeStatement.initializer); - } + } + function writeFixes(changeTracker, oldFileQuotePreference) { + let quotePreference; + if (sourceFile.imports.length === 0 && oldFileQuotePreference !== void 0) { + quotePreference = oldFileQuotePreference; + } else { + quotePreference = getQuotePreference(sourceFile, preferences); } - function spanInForStatement(forStatement) { - if (forStatement.initializer) { - return spanInInitializerOfForLike(forStatement); - } - if (forStatement.condition) { - return textSpan(forStatement.condition); - } - if (forStatement.incrementor) { - return textSpan(forStatement.incrementor); - } + for (const fix of addToNamespace) { + addNamespaceQualifier(changeTracker, sourceFile, fix); } - function spanInBindingPattern(bindingPattern) { - const firstBindingElement = forEach( - bindingPattern.elements, - (element) => element.kind !== 231 /* OmittedExpression */ ? element : void 0 - ); - if (firstBindingElement) { - return spanInNode(firstBindingElement); - } - if (bindingPattern.parent.kind === 207 /* BindingElement */) { - return textSpan(bindingPattern.parent); - } - return textSpanFromVariableDeclaration(bindingPattern.parent); + for (const fix of importType) { + addImportType(changeTracker, sourceFile, fix, quotePreference); } - function spanInArrayLiteralOrObjectLiteralDestructuringPattern(node2) { - Debug.assert(node2.kind !== 206 /* ArrayBindingPattern */ && node2.kind !== 205 /* ObjectBindingPattern */); - const elements = node2.kind === 208 /* ArrayLiteralExpression */ ? node2.elements : node2.properties; - const firstBindingElement = forEach( - elements, - (element) => element.kind !== 231 /* OmittedExpression */ ? element : void 0 + addToExisting.forEach(({ importClauseOrBindingPattern, defaultImport, namedImports }) => { + doAddExistingFix( + changeTracker, + sourceFile, + importClauseOrBindingPattern, + defaultImport, + arrayFrom(namedImports.entries(), ([name, addAsTypeOnly]) => ({ addAsTypeOnly, name })), + preferences + ); + }); + let newDeclarations; + newImports.forEach(({ useRequire, defaultImport, namedImports, namespaceLikeImport }, key) => { + const moduleSpecifier = key.slice(2); + const getDeclarations = useRequire ? getNewRequires : getNewImports; + const declarations = getDeclarations( + moduleSpecifier, + quotePreference, + defaultImport, + namedImports && arrayFrom(namedImports.entries(), ([name, addAsTypeOnly]) => ({ addAsTypeOnly, name })), + namespaceLikeImport, + compilerOptions, + preferences + ); + newDeclarations = combine(newDeclarations, declarations); + }); + if (newDeclarations) { + insertImports( + changeTracker, + sourceFile, + newDeclarations, + /*blankLineBetween*/ + true, + preferences ); - if (firstBindingElement) { - return spanInNode(firstBindingElement); - } - return textSpan(node2.parent.kind === 225 /* BinaryExpression */ ? node2.parent : node2); } - function spanInOpenBraceToken(node2) { - switch (node2.parent.kind) { - case 265 /* EnumDeclaration */: - const enumDeclaration = node2.parent; - return spanInNodeIfStartsOnSameLine(findPrecedingToken(node2.pos, sourceFile, node2.parent), enumDeclaration.members.length ? enumDeclaration.members[0] : enumDeclaration.getLastToken(sourceFile)); - case 262 /* ClassDeclaration */: - const classDeclaration = node2.parent; - return spanInNodeIfStartsOnSameLine(findPrecedingToken(node2.pos, sourceFile, node2.parent), classDeclaration.members.length ? classDeclaration.members[0] : classDeclaration.getLastToken(sourceFile)); - case 268 /* CaseBlock */: - return spanInNodeIfStartsOnSameLine(node2.parent.parent, node2.parent.clauses[0]); - } - return spanInNode(node2.parent); + } + function hasFixes() { + return addToNamespace.length > 0 || importType.length > 0 || addToExisting.size > 0 || newImports.size > 0; + } + } + function createImportSpecifierResolver(importingFile, program, host, preferences) { + const packageJsonImportFilter = createPackageJsonImportFilter(importingFile, preferences, host); + const importMap = createExistingImportMap(program.getTypeChecker(), importingFile, program.getCompilerOptions()); + return { getModuleSpecifierForBestExportInfo }; + function getModuleSpecifierForBestExportInfo(exportInfo, position, isValidTypeOnlyUseSite, fromCacheOnly) { + const { fixes, computedWithoutCacheCount } = getImportFixes( + exportInfo, + position, + isValidTypeOnlyUseSite, + /*useRequire*/ + false, + program, + importingFile, + host, + preferences, + importMap, + fromCacheOnly + ); + const result = getBestFix(fixes, importingFile, program, packageJsonImportFilter, host); + return result && { ...result, computedWithoutCacheCount }; + } + } + function getImportCompletionAction(targetSymbol, moduleSymbol, exportMapKey, sourceFile, symbolName2, isJsxTagName, host, program, formatContext, position, preferences, cancellationToken) { + let exportInfos; + if (exportMapKey) { + exportInfos = getExportInfoMap(sourceFile, host, program, preferences, cancellationToken).get(sourceFile.path, exportMapKey); + Debug.assertIsDefined(exportInfos, "Some exportInfo should match the specified exportMapKey"); + } else { + exportInfos = pathIsBareSpecifier(stripQuotes(moduleSymbol.name)) ? [getSingleExportInfoForSymbol(targetSymbol, symbolName2, moduleSymbol, program, host)] : getAllExportInfoForSymbol(sourceFile, targetSymbol, symbolName2, moduleSymbol, isJsxTagName, program, host, preferences, cancellationToken); + Debug.assertIsDefined(exportInfos, "Some exportInfo should match the specified symbol / moduleSymbol"); + } + const useRequire = shouldUseRequire(sourceFile, program); + const isValidTypeOnlyUseSite = isValidTypeOnlyAliasUseSite(getTokenAtPosition(sourceFile, position)); + const fix = Debug.checkDefined(getImportFixForSymbol(sourceFile, exportInfos, program, position, isValidTypeOnlyUseSite, useRequire, host, preferences)); + return { + moduleSpecifier: fix.moduleSpecifier, + codeAction: codeFixActionToCodeAction(codeActionForFix( + { host, formatContext, preferences }, + sourceFile, + symbolName2, + fix, + /*includeSymbolNameInDescription*/ + false, + program, + preferences + )) + }; + } + function getPromoteTypeOnlyCompletionAction(sourceFile, symbolToken, program, host, formatContext, preferences) { + const compilerOptions = program.getCompilerOptions(); + const symbolName2 = single(getSymbolNamesToImport(sourceFile, program.getTypeChecker(), symbolToken, compilerOptions)); + const fix = getTypeOnlyPromotionFix(sourceFile, symbolToken, symbolName2, program); + const includeSymbolNameInDescription = symbolName2 !== symbolToken.text; + return fix && codeFixActionToCodeAction(codeActionForFix( + { host, formatContext, preferences }, + sourceFile, + symbolName2, + fix, + includeSymbolNameInDescription, + program, + preferences + )); + } + function getImportFixForSymbol(sourceFile, exportInfos, program, position, isValidTypeOnlyUseSite, useRequire, host, preferences) { + const packageJsonImportFilter = createPackageJsonImportFilter(sourceFile, preferences, host); + return getBestFix(getImportFixes(exportInfos, position, isValidTypeOnlyUseSite, useRequire, program, sourceFile, host, preferences).fixes, sourceFile, program, packageJsonImportFilter, host); + } + function codeFixActionToCodeAction({ description: description3, changes, commands }) { + return { description: description3, changes, commands }; + } + function getAllExportInfoForSymbol(importingFile, symbol, symbolName2, moduleSymbol, preferCapitalized, program, host, preferences, cancellationToken) { + const getChecker = createGetChecker(program, host); + return getExportInfoMap(importingFile, host, program, preferences, cancellationToken).search(importingFile.path, preferCapitalized, (name) => name === symbolName2, (info) => { + if (skipAlias(info[0].symbol, getChecker(info[0].isFromPackageJson)) === symbol && info.some((i) => i.moduleSymbol === moduleSymbol || i.symbol.parent === moduleSymbol)) { + return info; } - function spanInCloseBraceToken(node2) { - switch (node2.parent.kind) { - case 267 /* ModuleBlock */: - if (getModuleInstanceState(node2.parent.parent) !== 1 /* Instantiated */) { - return void 0; - } - case 265 /* EnumDeclaration */: - case 262 /* ClassDeclaration */: - return textSpan(node2); - case 240 /* Block */: - if (isFunctionBlock(node2.parent)) { - return textSpan(node2); - } - case 298 /* CatchClause */: - return spanInNode(lastOrUndefined(node2.parent.statements)); - case 268 /* CaseBlock */: - const caseBlock = node2.parent; - const lastClause = lastOrUndefined(caseBlock.clauses); - if (lastClause) { - return spanInNode(lastOrUndefined(lastClause.statements)); - } - return void 0; - case 205 /* ObjectBindingPattern */: - const bindingPattern = node2.parent; - return spanInNode(lastOrUndefined(bindingPattern.elements) || bindingPattern); - default: - if (isArrayLiteralOrObjectLiteralDestructuringPattern(node2.parent)) { - const objectLiteral = node2.parent; - return textSpan(lastOrUndefined(objectLiteral.properties) || objectLiteral); - } - return spanInNode(node2.parent); - } + }); + } + function getSingleExportInfoForSymbol(symbol, symbolName2, moduleSymbol, program, host) { + var _a, _b; + const compilerOptions = program.getCompilerOptions(); + const mainProgramInfo = getInfoWithChecker( + program.getTypeChecker(), + /*isFromPackageJson*/ + false + ); + if (mainProgramInfo) { + return mainProgramInfo; + } + const autoImportProvider = (_b = (_a = host.getPackageJsonAutoImportProvider) == null ? void 0 : _a.call(host)) == null ? void 0 : _b.getTypeChecker(); + return Debug.checkDefined(autoImportProvider && getInfoWithChecker( + autoImportProvider, + /*isFromPackageJson*/ + true + ), `Could not find symbol in specified module for code actions`); + function getInfoWithChecker(checker, isFromPackageJson) { + const defaultInfo = getDefaultLikeExportInfo(moduleSymbol, checker, compilerOptions); + if (defaultInfo && skipAlias(defaultInfo.symbol, checker) === symbol) { + return { symbol: defaultInfo.symbol, moduleSymbol, moduleFileName: void 0, exportKind: defaultInfo.exportKind, targetFlags: skipAlias(symbol, checker).flags, isFromPackageJson }; } - function spanInCloseBracketToken(node2) { - switch (node2.parent.kind) { - case 206 /* ArrayBindingPattern */: - const bindingPattern = node2.parent; - return textSpan(lastOrUndefined(bindingPattern.elements) || bindingPattern); - default: - if (isArrayLiteralOrObjectLiteralDestructuringPattern(node2.parent)) { - const arrayLiteral = node2.parent; - return textSpan(lastOrUndefined(arrayLiteral.elements) || arrayLiteral); - } - return spanInNode(node2.parent); - } + const named = checker.tryGetMemberInModuleExportsAndProperties(symbolName2, moduleSymbol); + if (named && skipAlias(named, checker) === symbol) { + return { symbol: named, moduleSymbol, moduleFileName: void 0, exportKind: 0 /* Named */, targetFlags: skipAlias(symbol, checker).flags, isFromPackageJson }; } - function spanInOpenParenToken(node2) { - if (node2.parent.kind === 245 /* DoStatement */ || // Go to while keyword and do action instead - node2.parent.kind === 212 /* CallExpression */ || node2.parent.kind === 213 /* NewExpression */) { - return spanInPreviousNode(node2); - } - if (node2.parent.kind === 216 /* ParenthesizedExpression */) { - return spanInNextNode(node2); - } - return spanInNode(node2.parent); + } + } + function getImportFixes(exportInfos, usagePosition, isValidTypeOnlyUseSite, useRequire, program, sourceFile, host, preferences, importMap = createExistingImportMap(program.getTypeChecker(), sourceFile, program.getCompilerOptions()), fromCacheOnly) { + const checker = program.getTypeChecker(); + const existingImports = flatMap(exportInfos, importMap.getImportsForExportInfo); + const useNamespace = usagePosition !== void 0 && tryUseExistingNamespaceImport(existingImports, usagePosition); + const addToExisting = tryAddToExistingImport(existingImports, isValidTypeOnlyUseSite, checker, program.getCompilerOptions()); + if (addToExisting) { + return { + computedWithoutCacheCount: 0, + fixes: [...useNamespace ? [useNamespace] : emptyArray, addToExisting] + }; + } + const { fixes, computedWithoutCacheCount = 0 } = getFixesForAddImport( + exportInfos, + existingImports, + program, + sourceFile, + usagePosition, + isValidTypeOnlyUseSite, + useRequire, + host, + preferences, + fromCacheOnly + ); + return { + computedWithoutCacheCount, + fixes: [...useNamespace ? [useNamespace] : emptyArray, ...fixes] + }; + } + function tryUseExistingNamespaceImport(existingImports, position) { + return firstDefined(existingImports, ({ declaration, importKind }) => { + var _a; + if (importKind !== 0 /* Named */) + return void 0; + const namespacePrefix = getNamespaceLikeImportText(declaration); + const moduleSpecifier = namespacePrefix && ((_a = tryGetModuleSpecifierFromDeclaration(declaration)) == null ? void 0 : _a.text); + if (moduleSpecifier) { + return { kind: 0 /* UseNamespace */, namespacePrefix, usagePosition: position, moduleSpecifier }; } - function spanInCloseParenToken(node2) { - switch (node2.parent.kind) { - case 217 /* FunctionExpression */: - case 261 /* FunctionDeclaration */: - case 218 /* ArrowFunction */: - case 173 /* MethodDeclaration */: - case 172 /* MethodSignature */: - case 176 /* GetAccessor */: - case 177 /* SetAccessor */: - case 175 /* Constructor */: - case 246 /* WhileStatement */: - case 245 /* DoStatement */: - case 247 /* ForStatement */: - case 249 /* ForOfStatement */: - case 212 /* CallExpression */: - case 213 /* NewExpression */: - case 216 /* ParenthesizedExpression */: - return spanInPreviousNode(node2); - default: - return spanInNode(node2.parent); - } + }); + } + function getNamespaceLikeImportText(declaration) { + var _a, _b, _c; + switch (declaration.kind) { + case 260 /* VariableDeclaration */: + return (_a = tryCast(declaration.name, isIdentifier)) == null ? void 0 : _a.text; + case 271 /* ImportEqualsDeclaration */: + return declaration.name.text; + case 272 /* ImportDeclaration */: + return (_c = tryCast((_b = declaration.importClause) == null ? void 0 : _b.namedBindings, isNamespaceImport)) == null ? void 0 : _c.name.text; + default: + return Debug.assertNever(declaration); + } + } + function getAddAsTypeOnly(isValidTypeOnlyUseSite, isForNewImportDeclaration, symbol, targetFlags, checker, compilerOptions) { + if (!isValidTypeOnlyUseSite) { + return 4 /* NotAllowed */; + } + if (isForNewImportDeclaration && compilerOptions.importsNotUsedAsValues === 2 /* Error */) { + return 2 /* Required */; + } + if (importNameElisionDisabled(compilerOptions) && (!(targetFlags & 111551 /* Value */) || !!checker.getTypeOnlyAliasDeclaration(symbol))) { + return 2 /* Required */; + } + return 1 /* Allowed */; + } + function tryAddToExistingImport(existingImports, isValidTypeOnlyUseSite, checker, compilerOptions) { + let best; + for (const existingImport of existingImports) { + const fix = getAddToExistingImportFix(existingImport); + if (!fix) + continue; + const isTypeOnly = isTypeOnlyImportDeclaration(fix.importClauseOrBindingPattern); + if (fix.addAsTypeOnly !== 4 /* NotAllowed */ && isTypeOnly || fix.addAsTypeOnly === 4 /* NotAllowed */ && !isTypeOnly) { + return fix; } - function spanInColonToken(node2) { - if (isFunctionLike(node2.parent) || node2.parent.kind === 302 /* PropertyAssignment */ || node2.parent.kind === 168 /* Parameter */) { - return spanInPreviousNode(node2); - } - return spanInNode(node2.parent); + best ?? (best = fix); + } + return best; + function getAddToExistingImportFix({ declaration, importKind, symbol, targetFlags }) { + if (importKind === 3 /* CommonJS */ || importKind === 2 /* Namespace */ || declaration.kind === 271 /* ImportEqualsDeclaration */) { + return void 0; } - function spanInGreaterThanOrLessThanToken(node2) { - if (node2.parent.kind === 215 /* TypeAssertionExpression */) { - return spanInNextNode(node2); - } - return spanInNode(node2.parent); + if (declaration.kind === 260 /* VariableDeclaration */) { + return (importKind === 0 /* Named */ || importKind === 1 /* Default */) && declaration.name.kind === 206 /* ObjectBindingPattern */ ? { kind: 2 /* AddToExisting */, importClauseOrBindingPattern: declaration.name, importKind, moduleSpecifier: declaration.initializer.arguments[0].text, addAsTypeOnly: 4 /* NotAllowed */ } : void 0; } - function spanInWhileKeyword(node2) { - if (node2.parent.kind === 245 /* DoStatement */) { - return textSpanEndingAtNextToken(node2, node2.parent.expression); - } - return spanInNode(node2.parent); + const { importClause } = declaration; + if (!importClause || !isStringLiteralLike(declaration.moduleSpecifier)) { + return void 0; } - function spanInOfKeyword(node2) { - if (node2.parent.kind === 249 /* ForOfStatement */) { - return spanInNextNode(node2); + const { name, namedBindings } = importClause; + if (importClause.isTypeOnly && !(importKind === 0 /* Named */ && namedBindings)) { + return void 0; + } + const addAsTypeOnly = getAddAsTypeOnly( + isValidTypeOnlyUseSite, + /*isForNewImportDeclaration*/ + false, + symbol, + targetFlags, + checker, + compilerOptions + ); + if (importKind === 1 /* Default */ && (name || // Cannot add a default import to a declaration that already has one + addAsTypeOnly === 2 /* Required */ && namedBindings)) { + return void 0; + } + if (importKind === 0 /* Named */ && (namedBindings == null ? void 0 : namedBindings.kind) === 274 /* NamespaceImport */) { + return void 0; + } + return { + kind: 2 /* AddToExisting */, + importClauseOrBindingPattern: importClause, + importKind, + moduleSpecifier: declaration.moduleSpecifier.text, + addAsTypeOnly + }; + } + } + function createExistingImportMap(checker, importingFile, compilerOptions) { + let importMap; + for (const moduleSpecifier of importingFile.imports) { + const i = importFromModuleSpecifier(moduleSpecifier); + if (isVariableDeclarationInitializedToRequire(i.parent)) { + const moduleSymbol = checker.resolveExternalModuleName(moduleSpecifier); + if (moduleSymbol) { + (importMap || (importMap = createMultiMap())).add(getSymbolId(moduleSymbol), i.parent); + } + } else if (i.kind === 272 /* ImportDeclaration */ || i.kind === 271 /* ImportEqualsDeclaration */) { + const moduleSymbol = checker.getSymbolAtLocation(moduleSpecifier); + if (moduleSymbol) { + (importMap || (importMap = createMultiMap())).add(getSymbolId(moduleSymbol), i); } - return spanInNode(node2.parent); } } + return { + getImportsForExportInfo: ({ moduleSymbol, exportKind, targetFlags, symbol }) => { + if (!(targetFlags & 111551 /* Value */) && isSourceFileJS(importingFile)) + return emptyArray; + const matchingDeclarations = importMap == null ? void 0 : importMap.get(getSymbolId(moduleSymbol)); + if (!matchingDeclarations) + return emptyArray; + const importKind = getImportKind(importingFile, exportKind, compilerOptions); + return matchingDeclarations.map((declaration) => ({ declaration, importKind, symbol, targetFlags })); + } + }; } - var init_breakpoints = __esm({ - "src/services/breakpoints.ts"() { - "use strict"; - init_ts4(); + function shouldUseRequire(sourceFile, program) { + if (!isSourceFileJS(sourceFile)) { + return false; } - }); - - // src/services/_namespaces/ts.BreakpointResolver.ts - var ts_BreakpointResolver_exports = {}; - __export(ts_BreakpointResolver_exports, { - spanInSourceFileAtLocation: () => spanInSourceFileAtLocation - }); - var init_ts_BreakpointResolver = __esm({ - "src/services/_namespaces/ts.BreakpointResolver.ts"() { - "use strict"; - init_breakpoints(); + if (sourceFile.commonJsModuleIndicator && !sourceFile.externalModuleIndicator) + return true; + if (sourceFile.externalModuleIndicator && !sourceFile.commonJsModuleIndicator) + return false; + const compilerOptions = program.getCompilerOptions(); + if (compilerOptions.configFile) { + return getEmitModuleKind(compilerOptions) < 5 /* ES2015 */; } - }); - - // src/services/callHierarchy.ts - function isNamedExpression(node) { - return (isFunctionExpression(node) || isClassExpression(node)) && isNamedDeclaration(node); + if (sourceFile.impliedNodeFormat === 1 /* CommonJS */) + return true; + if (sourceFile.impliedNodeFormat === 99 /* ESNext */) + return false; + for (const otherFile of program.getSourceFiles()) { + if (otherFile === sourceFile || !isSourceFileJS(otherFile) || program.isSourceFileFromExternalLibrary(otherFile)) + continue; + if (otherFile.commonJsModuleIndicator && !otherFile.externalModuleIndicator) + return true; + if (otherFile.externalModuleIndicator && !otherFile.commonJsModuleIndicator) + return false; + } + return true; } - function isConstNamedExpression(node) { - return (isFunctionExpression(node) || isArrowFunction(node) || isClassExpression(node)) && isVariableDeclaration(node.parent) && node === node.parent.initializer && isIdentifier(node.parent.name) && !!(getCombinedNodeFlags(node.parent) & 2 /* Const */); + function createGetChecker(program, host) { + return memoizeOne((isFromPackageJson) => isFromPackageJson ? host.getPackageJsonAutoImportProvider().getTypeChecker() : program.getTypeChecker()); } - function isPossibleCallHierarchyDeclaration(node) { - return isSourceFile(node) || isModuleDeclaration(node) || isFunctionDeclaration(node) || isFunctionExpression(node) || isClassDeclaration(node) || isClassExpression(node) || isClassStaticBlockDeclaration(node) || isMethodDeclaration(node) || isMethodSignature(node) || isGetAccessorDeclaration(node) || isSetAccessorDeclaration(node); + function getNewImportFixes(program, sourceFile, usagePosition, isValidTypeOnlyUseSite, useRequire, exportInfo, host, preferences, fromCacheOnly) { + const isJs = isSourceFileJS(sourceFile); + const compilerOptions = program.getCompilerOptions(); + const moduleSpecifierResolutionHost = createModuleSpecifierResolutionHost(program, host); + const getChecker = createGetChecker(program, host); + const moduleResolution = getEmitModuleResolutionKind(compilerOptions); + const rejectNodeModulesRelativePaths = moduleResolutionUsesNodeModules(moduleResolution); + const getModuleSpecifiers2 = fromCacheOnly ? (moduleSymbol) => ({ moduleSpecifiers: ts_moduleSpecifiers_exports.tryGetModuleSpecifiersFromCache(moduleSymbol, sourceFile, moduleSpecifierResolutionHost, preferences), computedWithoutCache: false }) : (moduleSymbol, checker) => ts_moduleSpecifiers_exports.getModuleSpecifiersWithCacheInfo( + moduleSymbol, + checker, + compilerOptions, + sourceFile, + moduleSpecifierResolutionHost, + preferences, + /*options*/ + void 0, + /*forAutoImport*/ + true + ); + let computedWithoutCacheCount = 0; + const fixes = flatMap(exportInfo, (exportInfo2, i) => { + const checker = getChecker(exportInfo2.isFromPackageJson); + const { computedWithoutCache, moduleSpecifiers } = getModuleSpecifiers2(exportInfo2.moduleSymbol, checker); + const importedSymbolHasValueMeaning = !!(exportInfo2.targetFlags & 111551 /* Value */); + const addAsTypeOnly = getAddAsTypeOnly( + isValidTypeOnlyUseSite, + /*isForNewImportDeclaration*/ + true, + exportInfo2.symbol, + exportInfo2.targetFlags, + checker, + compilerOptions + ); + computedWithoutCacheCount += computedWithoutCache ? 1 : 0; + return mapDefined(moduleSpecifiers, (moduleSpecifier) => { + var _a; + if (rejectNodeModulesRelativePaths && pathContainsNodeModules(moduleSpecifier)) { + return void 0; + } + if (!importedSymbolHasValueMeaning && isJs && usagePosition !== void 0) { + return { kind: 1 /* JsdocTypeImport */, moduleSpecifier, usagePosition, exportInfo: exportInfo2, isReExport: i > 0 }; + } + const importKind = getImportKind(sourceFile, exportInfo2.exportKind, compilerOptions); + let qualification; + if (usagePosition !== void 0 && importKind === 3 /* CommonJS */ && exportInfo2.exportKind === 0 /* Named */) { + const exportEquals = checker.resolveExternalModuleSymbol(exportInfo2.moduleSymbol); + let namespacePrefix; + if (exportEquals !== exportInfo2.moduleSymbol) { + namespacePrefix = (_a = getDefaultExportInfoWorker(exportEquals, checker, compilerOptions)) == null ? void 0 : _a.name; + } + namespacePrefix || (namespacePrefix = moduleSymbolToValidIdentifier( + exportInfo2.moduleSymbol, + getEmitScriptTarget(compilerOptions), + /*forceCapitalize*/ + false + )); + qualification = { namespacePrefix, usagePosition }; + } + return { + kind: 3 /* AddNew */, + moduleSpecifier, + importKind, + useRequire, + addAsTypeOnly, + exportInfo: exportInfo2, + isReExport: i > 0, + qualification + }; + }); + }); + return { computedWithoutCacheCount, fixes }; } - function isValidCallHierarchyDeclaration(node) { - return isSourceFile(node) || isModuleDeclaration(node) && isIdentifier(node.name) || isFunctionDeclaration(node) || isClassDeclaration(node) || isClassStaticBlockDeclaration(node) || isMethodDeclaration(node) || isMethodSignature(node) || isGetAccessorDeclaration(node) || isSetAccessorDeclaration(node) || isNamedExpression(node) || isConstNamedExpression(node); + function getFixesForAddImport(exportInfos, existingImports, program, sourceFile, usagePosition, isValidTypeOnlyUseSite, useRequire, host, preferences, fromCacheOnly) { + const existingDeclaration = firstDefined(existingImports, (info) => newImportInfoFromExistingSpecifier(info, isValidTypeOnlyUseSite, useRequire, program.getTypeChecker(), program.getCompilerOptions())); + return existingDeclaration ? { fixes: [existingDeclaration] } : getNewImportFixes(program, sourceFile, usagePosition, isValidTypeOnlyUseSite, useRequire, exportInfos, host, preferences, fromCacheOnly); } - function getCallHierarchyDeclarationReferenceNode(node) { - if (isSourceFile(node)) - return node; - if (isNamedDeclaration(node)) - return node.name; - if (isConstNamedExpression(node)) - return node.parent.name; - return Debug.checkDefined(node.modifiers && find(node.modifiers, isDefaultModifier3)); + function newImportInfoFromExistingSpecifier({ declaration, importKind, symbol, targetFlags }, isValidTypeOnlyUseSite, useRequire, checker, compilerOptions) { + var _a; + const moduleSpecifier = (_a = tryGetModuleSpecifierFromDeclaration(declaration)) == null ? void 0 : _a.text; + if (moduleSpecifier) { + const addAsTypeOnly = useRequire ? 4 /* NotAllowed */ : getAddAsTypeOnly( + isValidTypeOnlyUseSite, + /*isForNewImportDeclaration*/ + true, + symbol, + targetFlags, + checker, + compilerOptions + ); + return { kind: 3 /* AddNew */, moduleSpecifier, importKind, addAsTypeOnly, useRequire }; + } } - function isDefaultModifier3(node) { - return node.kind === 90 /* DefaultKeyword */; + function getFixInfos(context, errorCode, pos, useAutoImportProvider) { + const symbolToken = getTokenAtPosition(context.sourceFile, pos); + let info; + if (errorCode === Diagnostics._0_refers_to_a_UMD_global_but_the_current_file_is_a_module_Consider_adding_an_import_instead.code) { + info = getFixesInfoForUMDImport(context, symbolToken); + } else if (!isIdentifier(symbolToken)) { + return void 0; + } else if (errorCode === Diagnostics._0_cannot_be_used_as_a_value_because_it_was_imported_using_import_type.code) { + const symbolName2 = single(getSymbolNamesToImport(context.sourceFile, context.program.getTypeChecker(), symbolToken, context.program.getCompilerOptions())); + const fix = getTypeOnlyPromotionFix(context.sourceFile, symbolToken, symbolName2, context.program); + return fix && [{ fix, symbolName: symbolName2, errorIdentifierText: symbolToken.text }]; + } else { + info = getFixesInfoForNonUMDImport(context, symbolToken, useAutoImportProvider); + } + const packageJsonImportFilter = createPackageJsonImportFilter(context.sourceFile, context.preferences, context.host); + return info && sortFixInfo(info, context.sourceFile, context.program, packageJsonImportFilter, context.host); } - function getSymbolOfCallHierarchyDeclaration(typeChecker, node) { - const location = getCallHierarchyDeclarationReferenceNode(node); - return location && typeChecker.getSymbolAtLocation(location); + function sortFixInfo(fixes, sourceFile, program, packageJsonImportFilter, host) { + const _toPath = (fileName) => toPath(fileName, host.getCurrentDirectory(), hostGetCanonicalFileName(host)); + return sort(fixes, (a, b) => compareBooleans(!!a.isJsxNamespaceFix, !!b.isJsxNamespaceFix) || compareValues(a.fix.kind, b.fix.kind) || compareModuleSpecifiers(a.fix, b.fix, sourceFile, program, packageJsonImportFilter.allowsImportingSpecifier, _toPath)); } - function getCallHierarchyItemName(program, node) { - if (isSourceFile(node)) { - return { text: node.fileName, pos: 0, end: 0 }; + function getBestFix(fixes, sourceFile, program, packageJsonImportFilter, host) { + if (!some(fixes)) + return; + if (fixes[0].kind === 0 /* UseNamespace */ || fixes[0].kind === 2 /* AddToExisting */) { + return fixes[0]; } - if ((isFunctionDeclaration(node) || isClassDeclaration(node)) && !isNamedDeclaration(node)) { - const defaultModifier = node.modifiers && find(node.modifiers, isDefaultModifier3); - if (defaultModifier) { - return { text: "default", pos: defaultModifier.getStart(), end: defaultModifier.getEnd() }; - } + return fixes.reduce( + (best, fix) => ( + // Takes true branch of conditional if `fix` is better than `best` + compareModuleSpecifiers( + fix, + best, + sourceFile, + program, + packageJsonImportFilter.allowsImportingSpecifier, + (fileName) => toPath(fileName, host.getCurrentDirectory(), hostGetCanonicalFileName(host)) + ) === -1 /* LessThan */ ? fix : best + ) + ); + } + function compareModuleSpecifiers(a, b, importingFile, program, allowsImportingSpecifier, toPath3) { + if (a.kind !== 0 /* UseNamespace */ && b.kind !== 0 /* UseNamespace */) { + return compareBooleans(allowsImportingSpecifier(b.moduleSpecifier), allowsImportingSpecifier(a.moduleSpecifier)) || compareNodeCoreModuleSpecifiers(a.moduleSpecifier, b.moduleSpecifier, importingFile, program) || compareBooleans( + isFixPossiblyReExportingImportingFile(a, importingFile, program.getCompilerOptions(), toPath3), + isFixPossiblyReExportingImportingFile(b, importingFile, program.getCompilerOptions(), toPath3) + ) || compareNumberOfDirectorySeparators(a.moduleSpecifier, b.moduleSpecifier); } - if (isClassStaticBlockDeclaration(node)) { - const sourceFile = node.getSourceFile(); - const pos = skipTrivia(sourceFile.text, moveRangePastModifiers(node).pos); - const end = pos + 6; - const typeChecker = program.getTypeChecker(); - const symbol = typeChecker.getSymbolAtLocation(node.parent); - const prefix = symbol ? `${typeChecker.symbolToString(symbol, node.parent)} ` : ""; - return { text: `${prefix}static {}`, pos, end }; + return 0 /* EqualTo */; + } + function isFixPossiblyReExportingImportingFile(fix, importingFile, compilerOptions, toPath3) { + var _a; + if (fix.isReExport && ((_a = fix.exportInfo) == null ? void 0 : _a.moduleFileName) && getEmitModuleResolutionKind(compilerOptions) === 2 /* Node10 */ && isIndexFileName(fix.exportInfo.moduleFileName)) { + const reExportDir = toPath3(getDirectoryPath(fix.exportInfo.moduleFileName)); + return startsWith(importingFile.path, reExportDir); } - const declName = isConstNamedExpression(node) ? node.parent.name : Debug.checkDefined(getNameOfDeclaration(node), "Expected call hierarchy item to have a name"); - let text = isIdentifier(declName) ? idText(declName) : isStringOrNumericLiteralLike(declName) ? declName.text : isComputedPropertyName(declName) ? isStringOrNumericLiteralLike(declName.expression) ? declName.expression.text : void 0 : void 0; - if (text === void 0) { - const typeChecker = program.getTypeChecker(); - const symbol = typeChecker.getSymbolAtLocation(declName); - if (symbol) { - text = typeChecker.symbolToString(symbol, node); + return false; + } + function isIndexFileName(fileName) { + return getBaseFileName( + fileName, + [".js", ".jsx", ".d.ts", ".ts", ".tsx"], + /*ignoreCase*/ + true + ) === "index"; + } + function compareNodeCoreModuleSpecifiers(a, b, importingFile, program) { + if (startsWith(a, "node:") && !startsWith(b, "node:")) + return shouldUseUriStyleNodeCoreModules(importingFile, program) ? -1 /* LessThan */ : 1 /* GreaterThan */; + if (startsWith(b, "node:") && !startsWith(a, "node:")) + return shouldUseUriStyleNodeCoreModules(importingFile, program) ? 1 /* GreaterThan */ : -1 /* LessThan */; + return 0 /* EqualTo */; + } + function getFixesInfoForUMDImport({ sourceFile, program, host, preferences }, token) { + const checker = program.getTypeChecker(); + const umdSymbol = getUmdSymbol(token, checker); + if (!umdSymbol) + return void 0; + const symbol = checker.getAliasedSymbol(umdSymbol); + const symbolName2 = umdSymbol.name; + const exportInfo = [{ symbol: umdSymbol, moduleSymbol: symbol, moduleFileName: void 0, exportKind: 3 /* UMD */, targetFlags: symbol.flags, isFromPackageJson: false }]; + const useRequire = shouldUseRequire(sourceFile, program); + const fixes = getImportFixes( + exportInfo, + /*usagePosition*/ + void 0, + /*isValidTypeOnlyUseSite*/ + false, + useRequire, + program, + sourceFile, + host, + preferences + ).fixes; + return fixes.map((fix) => { + var _a; + return { fix, symbolName: symbolName2, errorIdentifierText: (_a = tryCast(token, isIdentifier)) == null ? void 0 : _a.text }; + }); + } + function getUmdSymbol(token, checker) { + const umdSymbol = isIdentifier(token) ? checker.getSymbolAtLocation(token) : void 0; + if (isUMDExportSymbol(umdSymbol)) + return umdSymbol; + const { parent: parent2 } = token; + if (isJsxOpeningLikeElement(parent2) && parent2.tagName === token || isJsxOpeningFragment(parent2)) { + const parentSymbol = checker.resolveName( + checker.getJsxNamespace(parent2), + isJsxOpeningLikeElement(parent2) ? token : parent2, + 111551 /* Value */, + /*excludeGlobals*/ + false + ); + if (isUMDExportSymbol(parentSymbol)) { + return parentSymbol; } } - if (text === void 0) { - const printer = createPrinterWithRemoveCommentsOmitTrailingSemicolon(); - text = usingSingleLineStringWriter((writer) => printer.writeNode(4 /* Unspecified */, node, node.getSourceFile(), writer)); + return void 0; + } + function getImportKind(importingFile, exportKind, compilerOptions, forceImportKeyword) { + if (compilerOptions.verbatimModuleSyntax && (getEmitModuleKind(compilerOptions) === 1 /* CommonJS */ || importingFile.impliedNodeFormat === 1 /* CommonJS */)) { + return 3 /* CommonJS */; + } + switch (exportKind) { + case 0 /* Named */: + return 0 /* Named */; + case 1 /* Default */: + return 1 /* Default */; + case 2 /* ExportEquals */: + return getExportEqualsImportKind(importingFile, compilerOptions, !!forceImportKeyword); + case 3 /* UMD */: + return getUmdImportKind(importingFile, compilerOptions, !!forceImportKeyword); + default: + return Debug.assertNever(exportKind); } - return { text, pos: declName.getStart(), end: declName.getEnd() }; } - function getCallHierarchItemContainerName(node) { - var _a, _b; - if (isConstNamedExpression(node)) { - if (isModuleBlock(node.parent.parent.parent.parent) && isIdentifier(node.parent.parent.parent.parent.parent.name)) { - return node.parent.parent.parent.parent.parent.name.getText(); - } - return; + function getUmdImportKind(importingFile, compilerOptions, forceImportKeyword) { + if (getAllowSyntheticDefaultImports(compilerOptions)) { + return 1 /* Default */; } - switch (node.kind) { - case 176 /* GetAccessor */: - case 177 /* SetAccessor */: - case 173 /* MethodDeclaration */: - if (node.parent.kind === 209 /* ObjectLiteralExpression */) { - return (_a = getAssignedName(node.parent)) == null ? void 0 : _a.getText(); - } - return (_b = getNameOfDeclaration(node.parent)) == null ? void 0 : _b.getText(); - case 261 /* FunctionDeclaration */: - case 262 /* ClassDeclaration */: - case 266 /* ModuleDeclaration */: - if (isModuleBlock(node.parent) && isIdentifier(node.parent.parent.name)) { - return node.parent.parent.name.getText(); + const moduleKind = getEmitModuleKind(compilerOptions); + switch (moduleKind) { + case 2 /* AMD */: + case 1 /* CommonJS */: + case 3 /* UMD */: + if (isInJSFile(importingFile)) { + return isExternalModule(importingFile) || forceImportKeyword ? 2 /* Namespace */ : 3 /* CommonJS */; } + return 3 /* CommonJS */; + case 4 /* System */: + case 5 /* ES2015 */: + case 6 /* ES2020 */: + case 7 /* ES2022 */: + case 99 /* ESNext */: + case 0 /* None */: + return 2 /* Namespace */; + case 100 /* Node16 */: + case 199 /* NodeNext */: + return importingFile.impliedNodeFormat === 99 /* ESNext */ ? 2 /* Namespace */ : 3 /* CommonJS */; + default: + return Debug.assertNever(moduleKind, `Unexpected moduleKind ${moduleKind}`); } } - function findImplementation(typeChecker, node) { - if (node.body) { - return node; + function getFixesInfoForNonUMDImport({ sourceFile, program, cancellationToken, host, preferences }, symbolToken, useAutoImportProvider) { + const checker = program.getTypeChecker(); + const compilerOptions = program.getCompilerOptions(); + return flatMap(getSymbolNamesToImport(sourceFile, checker, symbolToken, compilerOptions), (symbolName2) => { + if (symbolName2 === "default" /* Default */) { + return void 0; + } + const isValidTypeOnlyUseSite = isValidTypeOnlyAliasUseSite(symbolToken); + const useRequire = shouldUseRequire(sourceFile, program); + const exportInfo = getExportInfos(symbolName2, isJSXTagName(symbolToken), getMeaningFromLocation(symbolToken), cancellationToken, sourceFile, program, useAutoImportProvider, host, preferences); + return arrayFrom( + flatMapIterator(exportInfo.values(), (exportInfos) => getImportFixes(exportInfos, symbolToken.getStart(sourceFile), isValidTypeOnlyUseSite, useRequire, program, sourceFile, host, preferences).fixes), + (fix) => ({ fix, symbolName: symbolName2, errorIdentifierText: symbolToken.text, isJsxNamespaceFix: symbolName2 !== symbolToken.text }) + ); + }); + } + function getTypeOnlyPromotionFix(sourceFile, symbolToken, symbolName2, program) { + const checker = program.getTypeChecker(); + const symbol = checker.resolveName( + symbolName2, + symbolToken, + 111551 /* Value */, + /*excludeGlobals*/ + true + ); + if (!symbol) + return void 0; + const typeOnlyAliasDeclaration = checker.getTypeOnlyAliasDeclaration(symbol); + if (!typeOnlyAliasDeclaration || getSourceFileOfNode(typeOnlyAliasDeclaration) !== sourceFile) + return void 0; + return { kind: 4 /* PromoteTypeOnly */, typeOnlyAliasDeclaration }; + } + function getSymbolNamesToImport(sourceFile, checker, symbolToken, compilerOptions) { + const parent2 = symbolToken.parent; + if ((isJsxOpeningLikeElement(parent2) || isJsxClosingElement(parent2)) && parent2.tagName === symbolToken && jsxModeNeedsExplicitImport(compilerOptions.jsx)) { + const jsxNamespace = checker.getJsxNamespace(sourceFile); + if (needsJsxNamespaceFix(jsxNamespace, symbolToken, checker)) { + const needsComponentNameFix = !isIntrinsicJsxName(symbolToken.text) && !checker.resolveName( + symbolToken.text, + symbolToken, + 111551 /* Value */, + /*excludeGlobals*/ + false + ); + return needsComponentNameFix ? [symbolToken.text, jsxNamespace] : [jsxNamespace]; + } } - if (isConstructorDeclaration(node)) { - return getFirstConstructorWithBody(node.parent); + return [symbolToken.text]; + } + function needsJsxNamespaceFix(jsxNamespace, symbolToken, checker) { + if (isIntrinsicJsxName(symbolToken.text)) + return true; + const namespaceSymbol = checker.resolveName( + jsxNamespace, + symbolToken, + 111551 /* Value */, + /*excludeGlobals*/ + true + ); + return !namespaceSymbol || some(namespaceSymbol.declarations, isTypeOnlyImportOrExportDeclaration) && !(namespaceSymbol.flags & 111551 /* Value */); + } + function getExportInfos(symbolName2, isJsxTagName, currentTokenMeaning, cancellationToken, fromFile, program, useAutoImportProvider, host, preferences) { + var _a; + const originalSymbolToExportInfos = createMultiMap(); + const packageJsonFilter = createPackageJsonImportFilter(fromFile, preferences, host); + const moduleSpecifierCache = (_a = host.getModuleSpecifierCache) == null ? void 0 : _a.call(host); + const getModuleSpecifierResolutionHost = memoizeOne((isFromPackageJson) => { + return createModuleSpecifierResolutionHost(isFromPackageJson ? host.getPackageJsonAutoImportProvider() : program, host); + }); + function addSymbol(moduleSymbol, toFile, exportedSymbol, exportKind, program2, isFromPackageJson) { + const moduleSpecifierResolutionHost = getModuleSpecifierResolutionHost(isFromPackageJson); + if (toFile && isImportableFile(program2, fromFile, toFile, preferences, packageJsonFilter, moduleSpecifierResolutionHost, moduleSpecifierCache) || !toFile && packageJsonFilter.allowsImportingAmbientModule(moduleSymbol, moduleSpecifierResolutionHost)) { + const checker = program2.getTypeChecker(); + originalSymbolToExportInfos.add(getUniqueSymbolId(exportedSymbol, checker).toString(), { symbol: exportedSymbol, moduleSymbol, moduleFileName: toFile == null ? void 0 : toFile.fileName, exportKind, targetFlags: skipAlias(exportedSymbol, checker).flags, isFromPackageJson }); + } } - if (isFunctionDeclaration(node) || isMethodDeclaration(node)) { - const symbol = getSymbolOfCallHierarchyDeclaration(typeChecker, node); - if (symbol && symbol.valueDeclaration && isFunctionLikeDeclaration(symbol.valueDeclaration) && symbol.valueDeclaration.body) { - return symbol.valueDeclaration; + forEachExternalModuleToImportFrom(program, host, preferences, useAutoImportProvider, (moduleSymbol, sourceFile, program2, isFromPackageJson) => { + const checker = program2.getTypeChecker(); + cancellationToken.throwIfCancellationRequested(); + const compilerOptions = program2.getCompilerOptions(); + const defaultInfo = getDefaultLikeExportInfo(moduleSymbol, checker, compilerOptions); + if (defaultInfo && (defaultInfo.name === symbolName2 || moduleSymbolToValidIdentifier(moduleSymbol, getEmitScriptTarget(compilerOptions), isJsxTagName) === symbolName2) && symbolHasMeaning(defaultInfo.resolvedSymbol, currentTokenMeaning)) { + addSymbol(moduleSymbol, sourceFile, defaultInfo.symbol, defaultInfo.exportKind, program2, isFromPackageJson); } - return void 0; + const exportSymbolWithIdenticalName = checker.tryGetMemberInModuleExportsAndProperties(symbolName2, moduleSymbol); + if (exportSymbolWithIdenticalName && symbolHasMeaning(exportSymbolWithIdenticalName, currentTokenMeaning)) { + addSymbol(moduleSymbol, sourceFile, exportSymbolWithIdenticalName, 0 /* Named */, program2, isFromPackageJson); + } + }); + return originalSymbolToExportInfos; + } + function getExportEqualsImportKind(importingFile, compilerOptions, forceImportKeyword) { + const allowSyntheticDefaults = getAllowSyntheticDefaultImports(compilerOptions); + const isJS = isInJSFile(importingFile); + if (!isJS && getEmitModuleKind(compilerOptions) >= 5 /* ES2015 */) { + return allowSyntheticDefaults ? 1 /* Default */ : 2 /* Namespace */; } - return node; + if (isJS) { + return isExternalModule(importingFile) || forceImportKeyword ? allowSyntheticDefaults ? 1 /* Default */ : 2 /* Namespace */ : 3 /* CommonJS */; + } + for (const statement of importingFile.statements) { + if (isImportEqualsDeclaration(statement) && !nodeIsMissing(statement.moduleReference)) { + return 3 /* CommonJS */; + } + } + return allowSyntheticDefaults ? 1 /* Default */ : 3 /* CommonJS */; } - function findAllInitialDeclarations(typeChecker, node) { - const symbol = getSymbolOfCallHierarchyDeclaration(typeChecker, node); - let declarations; - if (symbol && symbol.declarations) { - const indices = indicesOf(symbol.declarations); - const keys = map(symbol.declarations, (decl) => ({ file: decl.getSourceFile().fileName, pos: decl.pos })); - indices.sort((a, b) => compareStringsCaseSensitive(keys[a].file, keys[b].file) || keys[a].pos - keys[b].pos); - const sortedDeclarations = map(indices, (i) => symbol.declarations[i]); - let lastDecl; - for (const decl of sortedDeclarations) { - if (isValidCallHierarchyDeclaration(decl)) { - if (!lastDecl || lastDecl.parent !== decl.parent || lastDecl.end !== decl.pos) { - declarations = append(declarations, decl); - } - lastDecl = decl; + function codeActionForFix(context, sourceFile, symbolName2, fix, includeSymbolNameInDescription, program, preferences) { + let diag2; + const changes = ts_textChanges_exports.ChangeTracker.with(context, (tracker) => { + diag2 = codeActionForFixWorker(tracker, sourceFile, symbolName2, fix, includeSymbolNameInDescription, program, preferences); + }); + return createCodeFixAction(importFixName, changes, diag2, importFixId, Diagnostics.Add_all_missing_imports); + } + function codeActionForFixWorker(changes, sourceFile, symbolName2, fix, includeSymbolNameInDescription, program, preferences) { + const quotePreference = getQuotePreference(sourceFile, preferences); + switch (fix.kind) { + case 0 /* UseNamespace */: + addNamespaceQualifier(changes, sourceFile, fix); + return [Diagnostics.Change_0_to_1, symbolName2, `${fix.namespacePrefix}.${symbolName2}`]; + case 1 /* JsdocTypeImport */: + addImportType(changes, sourceFile, fix, quotePreference); + return [Diagnostics.Change_0_to_1, symbolName2, getImportTypePrefix(fix.moduleSpecifier, quotePreference) + symbolName2]; + case 2 /* AddToExisting */: { + const { importClauseOrBindingPattern, importKind, addAsTypeOnly, moduleSpecifier } = fix; + doAddExistingFix( + changes, + sourceFile, + importClauseOrBindingPattern, + importKind === 1 /* Default */ ? { name: symbolName2, addAsTypeOnly } : void 0, + importKind === 0 /* Named */ ? [{ name: symbolName2, addAsTypeOnly }] : emptyArray, + preferences + ); + const moduleSpecifierWithoutQuotes = stripQuotes(moduleSpecifier); + return includeSymbolNameInDescription ? [Diagnostics.Import_0_from_1, symbolName2, moduleSpecifierWithoutQuotes] : [Diagnostics.Update_import_from_0, moduleSpecifierWithoutQuotes]; + } + case 3 /* AddNew */: { + const { importKind, moduleSpecifier, addAsTypeOnly, useRequire, qualification } = fix; + const getDeclarations = useRequire ? getNewRequires : getNewImports; + const defaultImport = importKind === 1 /* Default */ ? { name: symbolName2, addAsTypeOnly } : void 0; + const namedImports = importKind === 0 /* Named */ ? [{ name: symbolName2, addAsTypeOnly }] : void 0; + const namespaceLikeImport = importKind === 2 /* Namespace */ || importKind === 3 /* CommonJS */ ? { importKind, name: (qualification == null ? void 0 : qualification.namespacePrefix) || symbolName2, addAsTypeOnly } : void 0; + insertImports( + changes, + sourceFile, + getDeclarations( + moduleSpecifier, + quotePreference, + defaultImport, + namedImports, + namespaceLikeImport, + program.getCompilerOptions(), + preferences + ), + /*blankLineBetween*/ + true, + preferences + ); + if (qualification) { + addNamespaceQualifier(changes, sourceFile, qualification); } + return includeSymbolNameInDescription ? [Diagnostics.Import_0_from_1, symbolName2, moduleSpecifier] : [Diagnostics.Add_import_from_0, moduleSpecifier]; + } + case 4 /* PromoteTypeOnly */: { + const { typeOnlyAliasDeclaration } = fix; + const promotedDeclaration = promoteFromTypeOnly(changes, typeOnlyAliasDeclaration, program, sourceFile, preferences); + return promotedDeclaration.kind === 276 /* ImportSpecifier */ ? [Diagnostics.Remove_type_from_import_of_0_from_1, symbolName2, getModuleSpecifierText(promotedDeclaration.parent.parent)] : [Diagnostics.Remove_type_from_import_declaration_from_0, getModuleSpecifierText(promotedDeclaration)]; } + default: + return Debug.assertNever(fix, `Unexpected fix kind ${fix.kind}`); } - return declarations; } - function findImplementationOrAllInitialDeclarations(typeChecker, node) { - if (isClassStaticBlockDeclaration(node)) { - return node; - } - if (isFunctionLikeDeclaration(node)) { - return findImplementation(typeChecker, node) ?? findAllInitialDeclarations(typeChecker, node) ?? node; - } - return findAllInitialDeclarations(typeChecker, node) ?? node; + function getModuleSpecifierText(promotedDeclaration) { + var _a, _b; + return promotedDeclaration.kind === 271 /* ImportEqualsDeclaration */ ? ((_b = tryCast((_a = tryCast(promotedDeclaration.moduleReference, isExternalModuleReference)) == null ? void 0 : _a.expression, isStringLiteralLike)) == null ? void 0 : _b.text) || promotedDeclaration.moduleReference.getText() : cast(promotedDeclaration.parent.moduleSpecifier, isStringLiteral).text; } - function resolveCallHierarchyDeclaration(program, location) { - const typeChecker = program.getTypeChecker(); - let followingSymbol = false; - while (true) { - if (isValidCallHierarchyDeclaration(location)) { - return findImplementationOrAllInitialDeclarations(typeChecker, location); - } - if (isPossibleCallHierarchyDeclaration(location)) { - const ancestor = findAncestor(location, isValidCallHierarchyDeclaration); - return ancestor && findImplementationOrAllInitialDeclarations(typeChecker, ancestor); - } - if (isDeclarationName(location)) { - if (isValidCallHierarchyDeclaration(location.parent)) { - return findImplementationOrAllInitialDeclarations(typeChecker, location.parent); - } - if (isPossibleCallHierarchyDeclaration(location.parent)) { - const ancestor = findAncestor(location.parent, isValidCallHierarchyDeclaration); - return ancestor && findImplementationOrAllInitialDeclarations(typeChecker, ancestor); - } - if (isVariableDeclaration(location.parent) && location.parent.initializer && isConstNamedExpression(location.parent.initializer)) { - return location.parent.initializer; + function promoteFromTypeOnly(changes, aliasDeclaration, program, sourceFile, preferences) { + const compilerOptions = program.getCompilerOptions(); + const convertExistingToTypeOnly = importNameElisionDisabled(compilerOptions); + switch (aliasDeclaration.kind) { + case 276 /* ImportSpecifier */: + if (aliasDeclaration.isTypeOnly) { + const sortKind = ts_OrganizeImports_exports.detectImportSpecifierSorting(aliasDeclaration.parent.elements, preferences); + if (aliasDeclaration.parent.elements.length > 1 && sortKind) { + const newSpecifier = factory.updateImportSpecifier( + aliasDeclaration, + /*isTypeOnly*/ + false, + aliasDeclaration.propertyName, + aliasDeclaration.name + ); + const comparer = ts_OrganizeImports_exports.getOrganizeImportsComparer(preferences, sortKind === 2 /* CaseInsensitive */); + const insertionIndex = ts_OrganizeImports_exports.getImportSpecifierInsertionIndex(aliasDeclaration.parent.elements, newSpecifier, comparer); + if (aliasDeclaration.parent.elements.indexOf(aliasDeclaration) !== insertionIndex) { + changes.delete(sourceFile, aliasDeclaration); + changes.insertImportSpecifierAtIndex(sourceFile, newSpecifier, aliasDeclaration.parent, insertionIndex); + return aliasDeclaration; + } + } + changes.deleteRange(sourceFile, aliasDeclaration.getFirstToken()); + return aliasDeclaration; + } else { + Debug.assert(aliasDeclaration.parent.parent.isTypeOnly); + promoteImportClause(aliasDeclaration.parent.parent); + return aliasDeclaration.parent.parent; } - return void 0; - } - if (isConstructorDeclaration(location)) { - if (isValidCallHierarchyDeclaration(location.parent)) { - return location.parent; + case 273 /* ImportClause */: + promoteImportClause(aliasDeclaration); + return aliasDeclaration; + case 274 /* NamespaceImport */: + promoteImportClause(aliasDeclaration.parent); + return aliasDeclaration.parent; + case 271 /* ImportEqualsDeclaration */: + changes.deleteRange(sourceFile, aliasDeclaration.getChildAt(1)); + return aliasDeclaration; + default: + Debug.failBadSyntaxKind(aliasDeclaration); + } + function promoteImportClause(importClause) { + var _a; + changes.delete(sourceFile, getTypeKeywordOfTypeOnlyImport(importClause, sourceFile)); + if (!compilerOptions.allowImportingTsExtensions) { + const moduleSpecifier = tryGetModuleSpecifierFromDeclaration(importClause.parent); + const resolvedModule = moduleSpecifier && ((_a = program.getResolvedModule(sourceFile, moduleSpecifier.text, getModeForUsageLocation(sourceFile, moduleSpecifier))) == null ? void 0 : _a.resolvedModule); + if (resolvedModule == null ? void 0 : resolvedModule.resolvedUsingTsExtension) { + const changedExtension = changeAnyExtension(moduleSpecifier.text, getOutputExtension(moduleSpecifier.text, compilerOptions)); + changes.replaceNode(sourceFile, moduleSpecifier, factory.createStringLiteral(changedExtension)); } - return void 0; - } - if (location.kind === 126 /* StaticKeyword */ && isClassStaticBlockDeclaration(location.parent)) { - location = location.parent; - continue; - } - if (isVariableDeclaration(location) && location.initializer && isConstNamedExpression(location.initializer)) { - return location.initializer; } - if (!followingSymbol) { - let symbol = typeChecker.getSymbolAtLocation(location); - if (symbol) { - if (symbol.flags & 2097152 /* Alias */) { - symbol = typeChecker.getAliasedSymbol(symbol); + if (convertExistingToTypeOnly) { + const namedImports = tryCast(importClause.namedBindings, isNamedImports); + if (namedImports && namedImports.elements.length > 1) { + if (ts_OrganizeImports_exports.detectImportSpecifierSorting(namedImports.elements, preferences) && aliasDeclaration.kind === 276 /* ImportSpecifier */ && namedImports.elements.indexOf(aliasDeclaration) !== 0) { + changes.delete(sourceFile, aliasDeclaration); + changes.insertImportSpecifierAtIndex(sourceFile, aliasDeclaration, namedImports, 0); } - if (symbol.valueDeclaration) { - followingSymbol = true; - location = symbol.valueDeclaration; - continue; + for (const element of namedImports.elements) { + if (element !== aliasDeclaration && !element.isTypeOnly) { + changes.insertModifierBefore(sourceFile, 156 /* TypeKeyword */, element); + } } } } - return void 0; } } - function createCallHierarchyItem(program, node) { - const sourceFile = node.getSourceFile(); - const name = getCallHierarchyItemName(program, node); - const containerName = getCallHierarchItemContainerName(node); - const kind = getNodeKind(node); - const kindModifiers = getNodeModifiers(node); - const span = createTextSpanFromBounds(skipTrivia( - sourceFile.text, - node.getFullStart(), - /*stopAfterLineBreak*/ - false, - /*stopAtComments*/ - true - ), node.getEnd()); - const selectionSpan = createTextSpanFromBounds(name.pos, name.end); - return { file: sourceFile.fileName, kind, kindModifiers, name: name.text, containerName, span, selectionSpan }; - } - function isDefined(x) { - return x !== void 0; - } - function convertEntryToCallSite(entry) { - if (entry.kind === ts_FindAllReferences_exports.EntryKind.Node) { - const { node } = entry; - if (isCallOrNewExpressionTarget( - node, - /*includeElementAccess*/ - true, - /*skipPastOuterExpressions*/ - true - ) || isTaggedTemplateTag( - node, - /*includeElementAccess*/ - true, - /*skipPastOuterExpressions*/ - true - ) || isDecoratorTarget( - node, - /*includeElementAccess*/ - true, - /*skipPastOuterExpressions*/ - true - ) || isJsxOpeningLikeElementTagName( - node, - /*includeElementAccess*/ - true, - /*skipPastOuterExpressions*/ - true - ) || isRightSideOfPropertyAccess(node) || isArgumentExpressionOfElementAccess(node)) { - const sourceFile = node.getSourceFile(); - const ancestor = findAncestor(node, isValidCallHierarchyDeclaration) || sourceFile; - return { declaration: ancestor, range: createTextRangeFromNode(node, sourceFile) }; + function doAddExistingFix(changes, sourceFile, clause, defaultImport, namedImports, preferences) { + var _a; + if (clause.kind === 206 /* ObjectBindingPattern */) { + if (defaultImport) { + addElementToBindingPattern(clause, defaultImport.name, "default"); + } + for (const specifier of namedImports) { + addElementToBindingPattern( + clause, + specifier.name, + /*propertyName*/ + void 0 + ); } + return; } - } - function getCallSiteGroupKey(entry) { - return getNodeId(entry.declaration); - } - function createCallHierarchyIncomingCall(from, fromSpans) { - return { from, fromSpans }; - } - function convertCallSiteGroupToIncomingCall(program, entries) { - return createCallHierarchyIncomingCall(createCallHierarchyItem(program, entries[0].declaration), map(entries, (entry) => createTextSpanFromRange(entry.range))); - } - function getIncomingCalls(program, declaration, cancellationToken) { - if (isSourceFile(declaration) || isModuleDeclaration(declaration) || isClassStaticBlockDeclaration(declaration)) { - return []; + const promoteFromTypeOnly2 = clause.isTypeOnly && some([defaultImport, ...namedImports], (i) => (i == null ? void 0 : i.addAsTypeOnly) === 4 /* NotAllowed */); + const existingSpecifiers = clause.namedBindings && ((_a = tryCast(clause.namedBindings, isNamedImports)) == null ? void 0 : _a.elements); + if (defaultImport) { + Debug.assert(!clause.name, "Cannot add a default import to an import clause that already has one"); + changes.insertNodeAt(sourceFile, clause.getStart(sourceFile), factory.createIdentifier(defaultImport.name), { suffix: ", " }); } - const location = getCallHierarchyDeclarationReferenceNode(declaration); - const calls = filter(ts_FindAllReferences_exports.findReferenceOrRenameEntries( - program, - cancellationToken, - program.getSourceFiles(), - location, - /*position*/ - 0, - { use: ts_FindAllReferences_exports.FindReferencesUse.References }, - convertEntryToCallSite - ), isDefined); - return calls ? group(calls, getCallSiteGroupKey, (entries) => convertCallSiteGroupToIncomingCall(program, entries)) : []; - } - function createCallSiteCollector(program, callSites) { - function recordCallSite(node) { - const target = isTaggedTemplateExpression(node) ? node.tag : isJsxOpeningLikeElement(node) ? node.tagName : isAccessExpression(node) ? node : isClassStaticBlockDeclaration(node) ? node : node.expression; - const declaration = resolveCallHierarchyDeclaration(program, target); - if (declaration) { - const range = createTextRangeFromNode(target, node.getSourceFile()); - if (isArray(declaration)) { - for (const decl of declaration) { - callSites.push({ declaration: decl, range }); - } - } else { - callSites.push({ declaration, range }); + if (namedImports.length) { + let ignoreCaseForSorting; + if (typeof preferences.organizeImportsIgnoreCase === "boolean") { + ignoreCaseForSorting = preferences.organizeImportsIgnoreCase; + } else if (existingSpecifiers) { + const targetImportSorting = ts_OrganizeImports_exports.detectImportSpecifierSorting(existingSpecifiers, preferences); + if (targetImportSorting !== 3 /* Both */) { + ignoreCaseForSorting = targetImportSorting === 2 /* CaseInsensitive */; } } - } - function collect(node) { - if (!node) - return; - if (node.flags & 16777216 /* Ambient */) { - return; + if (ignoreCaseForSorting === void 0) { + ignoreCaseForSorting = ts_OrganizeImports_exports.detectSorting(sourceFile, preferences) === 2 /* CaseInsensitive */; } - if (isValidCallHierarchyDeclaration(node)) { - if (isClassLike(node)) { - for (const member of node.members) { - if (member.name && isComputedPropertyName(member.name)) { - collect(member.name.expression); - } + const comparer = ts_OrganizeImports_exports.getOrganizeImportsComparer(preferences, ignoreCaseForSorting); + const newSpecifiers = stableSort( + namedImports.map( + (namedImport) => factory.createImportSpecifier( + (!clause.isTypeOnly || promoteFromTypeOnly2) && shouldUseTypeOnly(namedImport, preferences), + /*propertyName*/ + void 0, + factory.createIdentifier(namedImport.name) + ) + ), + (s1, s2) => ts_OrganizeImports_exports.compareImportOrExportSpecifiers(s1, s2, comparer) + ); + const specifierSort = (existingSpecifiers == null ? void 0 : existingSpecifiers.length) && ts_OrganizeImports_exports.detectImportSpecifierSorting(existingSpecifiers, preferences); + if (specifierSort && !(ignoreCaseForSorting && specifierSort === 1 /* CaseSensitive */)) { + for (const spec of newSpecifiers) { + const insertionIndex = promoteFromTypeOnly2 && !spec.isTypeOnly ? 0 : ts_OrganizeImports_exports.getImportSpecifierInsertionIndex(existingSpecifiers, spec, comparer); + changes.insertImportSpecifierAtIndex(sourceFile, spec, clause.namedBindings, insertionIndex); + } + } else if (existingSpecifiers == null ? void 0 : existingSpecifiers.length) { + for (const spec of newSpecifiers) { + changes.insertNodeInListAfter(sourceFile, last(existingSpecifiers), spec, existingSpecifiers); + } + } else { + if (newSpecifiers.length) { + const namedImports2 = factory.createNamedImports(newSpecifiers); + if (clause.namedBindings) { + changes.replaceNode(sourceFile, clause.namedBindings, namedImports2); + } else { + changes.insertNodeAfter(sourceFile, Debug.checkDefined(clause.name, "Import clause must have either named imports or a default import"), namedImports2); } } - return; } - switch (node.kind) { - case 80 /* Identifier */: - case 270 /* ImportEqualsDeclaration */: - case 271 /* ImportDeclaration */: - case 277 /* ExportDeclaration */: - case 263 /* InterfaceDeclaration */: - case 264 /* TypeAliasDeclaration */: - return; - case 174 /* ClassStaticBlockDeclaration */: - recordCallSite(node); - return; - case 215 /* TypeAssertionExpression */: - case 233 /* AsExpression */: - collect(node.expression); - return; - case 259 /* VariableDeclaration */: - case 168 /* Parameter */: - collect(node.name); - collect(node.initializer); - return; - case 212 /* CallExpression */: - recordCallSite(node); - collect(node.expression); - forEach(node.arguments, collect); - return; - case 213 /* NewExpression */: - recordCallSite(node); - collect(node.expression); - forEach(node.arguments, collect); - return; - case 214 /* TaggedTemplateExpression */: - recordCallSite(node); - collect(node.tag); - collect(node.template); - return; - case 285 /* JsxOpeningElement */: - case 284 /* JsxSelfClosingElement */: - recordCallSite(node); - collect(node.tagName); - collect(node.attributes); - return; - case 169 /* Decorator */: - recordCallSite(node); - collect(node.expression); - return; - case 210 /* PropertyAccessExpression */: - case 211 /* ElementAccessExpression */: - recordCallSite(node); - forEachChild(node, collect); - break; - case 237 /* SatisfiesExpression */: - collect(node.expression); - return; + } + if (promoteFromTypeOnly2) { + changes.delete(sourceFile, getTypeKeywordOfTypeOnlyImport(clause, sourceFile)); + if (existingSpecifiers) { + for (const specifier of existingSpecifiers) { + changes.insertModifierBefore(sourceFile, 156 /* TypeKeyword */, specifier); + } } - if (isPartOfTypeNode(node)) { - return; + } + function addElementToBindingPattern(bindingPattern, name, propertyName) { + const element = factory.createBindingElement( + /*dotDotDotToken*/ + void 0, + propertyName, + name + ); + if (bindingPattern.elements.length) { + changes.insertNodeInListAfter(sourceFile, last(bindingPattern.elements), element); + } else { + changes.replaceNode(sourceFile, bindingPattern, factory.createObjectBindingPattern([element])); } - forEachChild(node, collect); } - return collect; } - function collectCallSitesOfSourceFile(node, collect) { - forEach(node.statements, collect); + function addNamespaceQualifier(changes, sourceFile, { namespacePrefix, usagePosition }) { + changes.insertText(sourceFile, usagePosition, namespacePrefix + "."); } - function collectCallSitesOfModuleDeclaration(node, collect) { - if (!hasSyntacticModifier(node, 2 /* Ambient */) && node.body && isModuleBlock(node.body)) { - forEach(node.body.statements, collect); - } + function addImportType(changes, sourceFile, { moduleSpecifier, usagePosition: position }, quotePreference) { + changes.insertText(sourceFile, position, getImportTypePrefix(moduleSpecifier, quotePreference)); } - function collectCallSitesOfFunctionLikeDeclaration(typeChecker, node, collect) { - const implementation = findImplementation(typeChecker, node); - if (implementation) { - forEach(implementation.parameters, collect); - collect(implementation.body); - } + function getImportTypePrefix(moduleSpecifier, quotePreference) { + const quote2 = getQuoteFromPreference(quotePreference); + return `import(${quote2}${moduleSpecifier}${quote2}).`; } - function collectCallSitesOfClassStaticBlockDeclaration(node, collect) { - collect(node.body); + function needsTypeOnly({ addAsTypeOnly }) { + return addAsTypeOnly === 2 /* Required */; } - function collectCallSitesOfClassLikeDeclaration(node, collect) { - forEach(node.modifiers, collect); - const heritage = getClassExtendsHeritageElement(node); - if (heritage) { - collect(heritage.expression); + function shouldUseTypeOnly(info, preferences) { + return needsTypeOnly(info) || !!preferences.preferTypeOnlyAutoImports && info.addAsTypeOnly !== 4 /* NotAllowed */; + } + function getNewImports(moduleSpecifier, quotePreference, defaultImport, namedImports, namespaceLikeImport, compilerOptions, preferences) { + const quotedModuleSpecifier = makeStringLiteral(moduleSpecifier, quotePreference); + let statements; + if (defaultImport !== void 0 || (namedImports == null ? void 0 : namedImports.length)) { + const topLevelTypeOnly = (!defaultImport || needsTypeOnly(defaultImport)) && every(namedImports, needsTypeOnly) || (compilerOptions.verbatimModuleSyntax || preferences.preferTypeOnlyAutoImports) && (defaultImport == null ? void 0 : defaultImport.addAsTypeOnly) !== 4 /* NotAllowed */ && !some(namedImports, (i) => i.addAsTypeOnly === 4 /* NotAllowed */); + statements = combine( + statements, + makeImport( + defaultImport && factory.createIdentifier(defaultImport.name), + namedImports == null ? void 0 : namedImports.map( + (namedImport) => factory.createImportSpecifier( + !topLevelTypeOnly && shouldUseTypeOnly(namedImport, preferences), + /*propertyName*/ + void 0, + factory.createIdentifier(namedImport.name) + ) + ), + moduleSpecifier, + quotePreference, + topLevelTypeOnly + ) + ); } - for (const member of node.members) { - if (canHaveModifiers(member)) { - forEach(member.modifiers, collect); - } - if (isPropertyDeclaration(member)) { - collect(member.initializer); - } else if (isConstructorDeclaration(member) && member.body) { - forEach(member.parameters, collect); - collect(member.body); - } else if (isClassStaticBlockDeclaration(member)) { - collect(member); - } + if (namespaceLikeImport) { + const declaration = namespaceLikeImport.importKind === 3 /* CommonJS */ ? factory.createImportEqualsDeclaration( + /*modifiers*/ + void 0, + shouldUseTypeOnly(namespaceLikeImport, preferences), + factory.createIdentifier(namespaceLikeImport.name), + factory.createExternalModuleReference(quotedModuleSpecifier) + ) : factory.createImportDeclaration( + /*modifiers*/ + void 0, + factory.createImportClause( + shouldUseTypeOnly(namespaceLikeImport, preferences), + /*name*/ + void 0, + factory.createNamespaceImport(factory.createIdentifier(namespaceLikeImport.name)) + ), + quotedModuleSpecifier, + /*attributes*/ + void 0 + ); + statements = combine(statements, declaration); } + return Debug.checkDefined(statements); } - function collectCallSites(program, node) { - const callSites = []; - const collect = createCallSiteCollector(program, callSites); - switch (node.kind) { - case 311 /* SourceFile */: - collectCallSitesOfSourceFile(node, collect); - break; - case 266 /* ModuleDeclaration */: - collectCallSitesOfModuleDeclaration(node, collect); - break; - case 261 /* FunctionDeclaration */: - case 217 /* FunctionExpression */: - case 218 /* ArrowFunction */: - case 173 /* MethodDeclaration */: - case 176 /* GetAccessor */: - case 177 /* SetAccessor */: - collectCallSitesOfFunctionLikeDeclaration(program.getTypeChecker(), node, collect); - break; - case 262 /* ClassDeclaration */: - case 230 /* ClassExpression */: - collectCallSitesOfClassLikeDeclaration(node, collect); - break; - case 174 /* ClassStaticBlockDeclaration */: - collectCallSitesOfClassStaticBlockDeclaration(node, collect); - break; - default: - Debug.assertNever(node); + function getNewRequires(moduleSpecifier, quotePreference, defaultImport, namedImports, namespaceLikeImport) { + const quotedModuleSpecifier = makeStringLiteral(moduleSpecifier, quotePreference); + let statements; + if (defaultImport || (namedImports == null ? void 0 : namedImports.length)) { + const bindingElements = (namedImports == null ? void 0 : namedImports.map(({ name }) => factory.createBindingElement( + /*dotDotDotToken*/ + void 0, + /*propertyName*/ + void 0, + name + ))) || []; + if (defaultImport) { + bindingElements.unshift(factory.createBindingElement( + /*dotDotDotToken*/ + void 0, + "default", + defaultImport.name + )); + } + const declaration = createConstEqualsRequireDeclaration(factory.createObjectBindingPattern(bindingElements), quotedModuleSpecifier); + statements = combine(statements, declaration); } - return callSites; + if (namespaceLikeImport) { + const declaration = createConstEqualsRequireDeclaration(namespaceLikeImport.name, quotedModuleSpecifier); + statements = combine(statements, declaration); + } + return Debug.checkDefined(statements); } - function createCallHierarchyOutgoingCall(to, fromSpans) { - return { to, fromSpans }; + function createConstEqualsRequireDeclaration(name, quotedModuleSpecifier) { + return factory.createVariableStatement( + /*modifiers*/ + void 0, + factory.createVariableDeclarationList([ + factory.createVariableDeclaration( + typeof name === "string" ? factory.createIdentifier(name) : name, + /*exclamationToken*/ + void 0, + /*type*/ + void 0, + factory.createCallExpression( + factory.createIdentifier("require"), + /*typeArguments*/ + void 0, + [quotedModuleSpecifier] + ) + ) + ], 2 /* Const */) + ); } - function convertCallSiteGroupToOutgoingCall(program, entries) { - return createCallHierarchyOutgoingCall(createCallHierarchyItem(program, entries[0].declaration), map(entries, (entry) => createTextSpanFromRange(entry.range))); + function symbolHasMeaning({ declarations }, meaning) { + return some(declarations, (decl) => !!(getMeaningFromDeclaration(decl) & meaning)); } - function getOutgoingCalls(program, declaration) { - if (declaration.flags & 16777216 /* Ambient */ || isMethodSignature(declaration)) { - return []; + function moduleSymbolToValidIdentifier(moduleSymbol, target, forceCapitalize) { + return moduleSpecifierToValidIdentifier(removeFileExtension(stripQuotes(moduleSymbol.name)), target, forceCapitalize); + } + function moduleSpecifierToValidIdentifier(moduleSpecifier, target, forceCapitalize) { + const baseName = getBaseFileName(removeSuffix(moduleSpecifier, "/index")); + let res = ""; + let lastCharWasValid = true; + const firstCharCode = baseName.charCodeAt(0); + if (isIdentifierStart(firstCharCode, target)) { + res += String.fromCharCode(firstCharCode); + if (forceCapitalize) { + res = res.toUpperCase(); + } + } else { + lastCharWasValid = false; } - return group(collectCallSites(program, declaration), getCallSiteGroupKey, (entries) => convertCallSiteGroupToOutgoingCall(program, entries)); + for (let i = 1; i < baseName.length; i++) { + const ch = baseName.charCodeAt(i); + const isValid = isIdentifierPart(ch, target); + if (isValid) { + let char = String.fromCharCode(ch); + if (!lastCharWasValid) { + char = char.toUpperCase(); + } + res += char; + } + lastCharWasValid = isValid; + } + return !isStringANonContextualKeyword(res) ? res || "_" : `_${res}`; } - var init_callHierarchy = __esm({ - "src/services/callHierarchy.ts"() { + var importFixName, importFixId, errorCodes18; + var init_importFixes = __esm({ + "src/services/codefixes/importFixes.ts"() { "use strict"; init_ts4(); + init_ts_codefix(); + importFixName = "import"; + importFixId = "fixMissingImport"; + errorCodes18 = [ + Diagnostics.Cannot_find_name_0.code, + Diagnostics.Cannot_find_name_0_Did_you_mean_1.code, + Diagnostics.Cannot_find_name_0_Did_you_mean_the_instance_member_this_0.code, + Diagnostics.Cannot_find_name_0_Did_you_mean_the_static_member_1_0.code, + Diagnostics.Cannot_find_namespace_0.code, + Diagnostics._0_refers_to_a_UMD_global_but_the_current_file_is_a_module_Consider_adding_an_import_instead.code, + Diagnostics._0_only_refers_to_a_type_but_is_being_used_as_a_value_here.code, + Diagnostics.No_value_exists_in_scope_for_the_shorthand_property_0_Either_declare_one_or_provide_an_initializer.code, + Diagnostics._0_cannot_be_used_as_a_value_because_it_was_imported_using_import_type.code + ]; + registerCodeFix({ + errorCodes: errorCodes18, + getCodeActions(context) { + const { errorCode, preferences, sourceFile, span, program } = context; + const info = getFixInfos( + context, + errorCode, + span.start, + /*useAutoImportProvider*/ + true + ); + if (!info) + return void 0; + return info.map( + ({ fix, symbolName: symbolName2, errorIdentifierText }) => codeActionForFix( + context, + sourceFile, + symbolName2, + fix, + /*includeSymbolNameInDescription*/ + symbolName2 !== errorIdentifierText, + program, + preferences + ) + ); + }, + fixIds: [importFixId], + getAllCodeActions: (context) => { + const { sourceFile, program, preferences, host, cancellationToken } = context; + const importAdder = createImportAdderWorker( + sourceFile, + program, + /*useAutoImportProvider*/ + true, + preferences, + host, + cancellationToken + ); + eachDiagnostic(context, errorCodes18, (diag2) => importAdder.addImportFromDiagnostic(diag2, context)); + return createCombinedCodeActions(ts_textChanges_exports.ChangeTracker.with(context, importAdder.writeFixes)); + } + }); } }); - // src/services/_namespaces/ts.CallHierarchy.ts - var ts_CallHierarchy_exports = {}; - __export(ts_CallHierarchy_exports, { - createCallHierarchyItem: () => createCallHierarchyItem, - getIncomingCalls: () => getIncomingCalls, - getOutgoingCalls: () => getOutgoingCalls, - resolveCallHierarchyDeclaration: () => resolveCallHierarchyDeclaration - }); - var init_ts_CallHierarchy = __esm({ - "src/services/_namespaces/ts.CallHierarchy.ts"() { - "use strict"; - init_callHierarchy(); - } - }); - - // src/services/_namespaces/ts.classifier.v2020.ts - var ts_classifier_v2020_exports = {}; - __export(ts_classifier_v2020_exports, { - TokenEncodingConsts: () => TokenEncodingConsts, - TokenModifier: () => TokenModifier, - TokenType: () => TokenType, - getEncodedSemanticClassifications: () => getEncodedSemanticClassifications2, - getSemanticClassifications: () => getSemanticClassifications2 - }); - var init_ts_classifier_v2020 = __esm({ - "src/services/_namespaces/ts.classifier.v2020.ts"() { - "use strict"; - init_classifier2020(); + // src/services/codefixes/fixAddMissingConstraint.ts + function getInfo6(program, sourceFile, span) { + const diag2 = find(program.getSemanticDiagnostics(sourceFile), (diag3) => diag3.start === span.start && diag3.length === span.length); + if (diag2 === void 0 || diag2.relatedInformation === void 0) + return; + const related = find(diag2.relatedInformation, (related2) => related2.code === Diagnostics.This_type_parameter_might_need_an_extends_0_constraint.code); + if (related === void 0 || related.file === void 0 || related.start === void 0 || related.length === void 0) + return; + let declaration = findAncestorMatchingSpan(related.file, createTextSpan(related.start, related.length)); + if (declaration === void 0) + return; + if (isIdentifier(declaration) && isTypeParameterDeclaration(declaration.parent)) { + declaration = declaration.parent; } - }); - - // src/services/_namespaces/ts.classifier.ts - var ts_classifier_exports = {}; - __export(ts_classifier_exports, { - v2020: () => ts_classifier_v2020_exports - }); - var init_ts_classifier = __esm({ - "src/services/_namespaces/ts.classifier.ts"() { - "use strict"; - init_ts_classifier_v2020(); + if (isTypeParameterDeclaration(declaration)) { + if (isMappedTypeNode(declaration.parent)) + return; + const token = getTokenAtPosition(sourceFile, span.start); + const checker = program.getTypeChecker(); + const constraint = tryGetConstraintType(checker, token) || tryGetConstraintFromDiagnosticMessage(related.messageText); + return { constraint, declaration, token }; } - }); - - // src/services/codeFixProvider.ts - function createCodeFixActionWithoutFixAll(fixName8, changes, description3) { - return createCodeFixActionWorker( - fixName8, - diagnosticToString(description3), - changes, - /*fixId*/ - void 0, - /*fixAllDescription*/ - void 0 - ); - } - function createCodeFixAction(fixName8, changes, description3, fixId52, fixAllDescription, command) { - return createCodeFixActionWorker(fixName8, diagnosticToString(description3), changes, fixId52, diagnosticToString(fixAllDescription), command); - } - function createCodeFixActionMaybeFixAll(fixName8, changes, description3, fixId52, fixAllDescription, command) { - return createCodeFixActionWorker(fixName8, diagnosticToString(description3), changes, fixId52, fixAllDescription && diagnosticToString(fixAllDescription), command); - } - function createCodeFixActionWorker(fixName8, description3, changes, fixId52, fixAllDescription, command) { - return { fixName: fixName8, description: description3, changes, fixId: fixId52, fixAllDescription, commands: command ? [command] : void 0 }; + return void 0; } - function registerCodeFix(reg) { - for (const error of reg.errorCodes) { - errorCodeToFixesArray = void 0; - errorCodeToFixes.add(String(error), reg); - } - if (reg.fixIds) { - for (const fixId52 of reg.fixIds) { - Debug.assert(!fixIdToRegistration.has(fixId52)); - fixIdToRegistration.set(fixId52, reg); + function addMissingConstraint(changes, program, preferences, host, sourceFile, info) { + const { declaration, constraint } = info; + const checker = program.getTypeChecker(); + if (isString(constraint)) { + changes.insertText(sourceFile, declaration.name.end, ` extends ${constraint}`); + } else { + const scriptTarget = getEmitScriptTarget(program.getCompilerOptions()); + const tracker = getNoopSymbolTrackerWithResolver({ program, host }); + const importAdder = createImportAdder(sourceFile, program, preferences, host); + const typeNode = typeToAutoImportableTypeNode( + checker, + importAdder, + constraint, + /*contextNode*/ + void 0, + scriptTarget, + /*flags*/ + void 0, + tracker + ); + if (typeNode) { + changes.replaceNode(sourceFile, declaration, factory.updateTypeParameterDeclaration( + declaration, + /*modifiers*/ + void 0, + declaration.name, + typeNode, + declaration.default + )); + importAdder.writeFixes(changes); } } } - function getSupportedErrorCodes() { - return errorCodeToFixesArray ?? (errorCodeToFixesArray = arrayFrom(errorCodeToFixes.keys())); - } - function removeFixIdIfFixAllUnavailable(registration, diagnostics) { - const { errorCodes: errorCodes64 } = registration; - let maybeFixableDiagnostics = 0; - for (const diag2 of diagnostics) { - if (contains(errorCodes64, diag2.code)) - maybeFixableDiagnostics++; - if (maybeFixableDiagnostics > 1) - break; - } - const fixAllUnavailable = maybeFixableDiagnostics < 2; - return ({ fixId: fixId52, fixAllDescription, ...action }) => { - return fixAllUnavailable ? action : { ...action, fixId: fixId52, fixAllDescription }; - }; - } - function getFixes(context) { - const diagnostics = getDiagnostics(context); - const registrations = errorCodeToFixes.get(String(context.errorCode)); - return flatMap(registrations, (f) => map(f.getCodeActions(context), removeFixIdIfFixAllUnavailable(f, diagnostics))); - } - function getAllFixes(context) { - return fixIdToRegistration.get(cast(context.fixId, isString)).getAllCodeActions(context); - } - function createCombinedCodeActions(changes, commands) { - return { changes, commands }; - } - function createFileTextChanges(fileName, textChanges2) { - return { fileName, textChanges: textChanges2 }; - } - function codeFixAll(context, errorCodes64, use) { - const commands = []; - const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => eachDiagnostic(context, errorCodes64, (diag2) => use(t, diag2, commands))); - return createCombinedCodeActions(changes, commands.length === 0 ? void 0 : commands); + function tryGetConstraintFromDiagnosticMessage(messageText) { + const [_, constraint] = flattenDiagnosticMessageText(messageText, "\n", 0).match(/`extends (.*)`/) || []; + return constraint; } - function eachDiagnostic(context, errorCodes64, cb) { - for (const diag2 of getDiagnostics(context)) { - if (contains(errorCodes64, diag2.code)) { - cb(diag2); - } + function tryGetConstraintType(checker, node) { + if (isTypeNode(node.parent)) { + return checker.getTypeArgumentConstraint(node.parent); } + const contextualType = isExpression(node) ? checker.getContextualType(node) : void 0; + return contextualType || checker.getTypeAtLocation(node); } - function getDiagnostics({ program, sourceFile, cancellationToken }) { - return [ - ...program.getSemanticDiagnostics(sourceFile, cancellationToken), - ...program.getSyntacticDiagnostics(sourceFile, cancellationToken), - ...computeSuggestionDiagnostics(sourceFile, program, cancellationToken) - ]; - } - var errorCodeToFixes, fixIdToRegistration, errorCodeToFixesArray; - var init_codeFixProvider = __esm({ - "src/services/codeFixProvider.ts"() { + var fixId17, errorCodes19; + var init_fixAddMissingConstraint = __esm({ + "src/services/codefixes/fixAddMissingConstraint.ts"() { "use strict"; init_ts4(); - errorCodeToFixes = createMultiMap(); - fixIdToRegistration = /* @__PURE__ */ new Map(); + init_ts_codefix(); + fixId17 = "addMissingConstraint"; + errorCodes19 = [ + // We want errors this could be attached to: + // Diagnostics.This_type_parameter_probably_needs_an_extends_0_constraint + Diagnostics.Type_0_is_not_comparable_to_type_1.code, + Diagnostics.Type_0_is_not_assignable_to_type_1_Two_different_types_with_this_name_exist_but_they_are_unrelated.code, + Diagnostics.Type_0_is_not_assignable_to_type_1_with_exactOptionalPropertyTypes_Colon_true_Consider_adding_undefined_to_the_types_of_the_target_s_properties.code, + Diagnostics.Type_0_is_not_assignable_to_type_1.code, + Diagnostics.Argument_of_type_0_is_not_assignable_to_parameter_of_type_1_with_exactOptionalPropertyTypes_Colon_true_Consider_adding_undefined_to_the_types_of_the_target_s_properties.code, + Diagnostics.Property_0_is_incompatible_with_index_signature.code, + Diagnostics.Property_0_in_type_1_is_not_assignable_to_type_2.code, + Diagnostics.Type_0_does_not_satisfy_the_constraint_1.code + ]; + registerCodeFix({ + errorCodes: errorCodes19, + getCodeActions(context) { + const { sourceFile, span, program, preferences, host } = context; + const info = getInfo6(program, sourceFile, span); + if (info === void 0) + return; + const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => addMissingConstraint(t, program, preferences, host, sourceFile, info)); + return [createCodeFixAction(fixId17, changes, Diagnostics.Add_extends_constraint, fixId17, Diagnostics.Add_extends_constraint_to_all_type_parameters)]; + }, + fixIds: [fixId17], + getAllCodeActions: (context) => { + const { program, preferences, host } = context; + const seen = /* @__PURE__ */ new Map(); + return createCombinedCodeActions(ts_textChanges_exports.ChangeTracker.with(context, (changes) => { + eachDiagnostic(context, errorCodes19, (diag2) => { + const info = getInfo6(program, diag2.file, createTextSpan(diag2.start, diag2.length)); + if (info) { + if (addToSeen(seen, getNodeId(info.declaration))) { + return addMissingConstraint(changes, program, preferences, host, diag2.file, info); + } + } + return void 0; + }); + })); + } + }); } }); - // src/services/codefixes/addConvertToUnknownForNonOverlappingTypes.ts - function makeChange(changeTracker, sourceFile, assertion) { - const replacement = isAsExpression(assertion) ? factory.createAsExpression(assertion.expression, factory.createKeywordTypeNode(159 /* UnknownKeyword */)) : factory.createTypeAssertion(factory.createKeywordTypeNode(159 /* UnknownKeyword */), assertion.expression); - changeTracker.replaceNode(sourceFile, assertion.expression, replacement); + // src/services/codefixes/fixOverrideModifier.ts + function dispatchChanges(changeTracker, context, errorCode, pos) { + switch (errorCode) { + case Diagnostics.This_member_must_have_an_override_modifier_because_it_overrides_a_member_in_the_base_class_0.code: + case Diagnostics.This_member_must_have_a_JSDoc_comment_with_an_override_tag_because_it_overrides_a_member_in_the_base_class_0.code: + case Diagnostics.This_member_must_have_an_override_modifier_because_it_overrides_an_abstract_method_that_is_declared_in_the_base_class_0.code: + case Diagnostics.This_parameter_property_must_have_an_override_modifier_because_it_overrides_a_member_in_base_class_0.code: + case Diagnostics.This_parameter_property_must_have_a_JSDoc_comment_with_an_override_tag_because_it_overrides_a_member_in_the_base_class_0.code: + return doAddOverrideModifierChange(changeTracker, context.sourceFile, pos); + case Diagnostics.This_member_cannot_have_an_override_modifier_because_it_is_not_declared_in_the_base_class_0.code: + case Diagnostics.This_member_cannot_have_a_JSDoc_comment_with_an_override_tag_because_it_is_not_declared_in_the_base_class_0.code: + case Diagnostics.This_member_cannot_have_an_override_modifier_because_its_containing_class_0_does_not_extend_another_class.code: + case Diagnostics.This_member_cannot_have_a_JSDoc_comment_with_an_override_tag_because_its_containing_class_0_does_not_extend_another_class.code: + return doRemoveOverrideModifierChange(changeTracker, context.sourceFile, pos); + default: + Debug.fail("Unexpected error code: " + errorCode); + } } - function getAssertion(sourceFile, pos) { - if (isInJSFile(sourceFile)) - return void 0; - return findAncestor(getTokenAtPosition(sourceFile, pos), (n) => isAsExpression(n) || isTypeAssertionExpression(n)); + function doAddOverrideModifierChange(changeTracker, sourceFile, pos) { + const classElement = findContainerClassElementLike(sourceFile, pos); + if (isSourceFileJS(sourceFile)) { + changeTracker.addJSDocTags(sourceFile, classElement, [factory.createJSDocOverrideTag(factory.createIdentifier("override"))]); + return; + } + const modifiers = classElement.modifiers || emptyArray; + const staticModifier = find(modifiers, isStaticModifier); + const abstractModifier = find(modifiers, isAbstractModifier); + const accessibilityModifier = find(modifiers, (m) => isAccessibilityModifier(m.kind)); + const lastDecorator = findLast(modifiers, isDecorator); + const modifierPos = abstractModifier ? abstractModifier.end : staticModifier ? staticModifier.end : accessibilityModifier ? accessibilityModifier.end : lastDecorator ? skipTrivia(sourceFile.text, lastDecorator.end) : classElement.getStart(sourceFile); + const options = accessibilityModifier || staticModifier || abstractModifier ? { prefix: " " } : { suffix: " " }; + changeTracker.insertModifierAt(sourceFile, modifierPos, 164 /* OverrideKeyword */, options); } - var fixId, errorCodes; - var init_addConvertToUnknownForNonOverlappingTypes = __esm({ - "src/services/codefixes/addConvertToUnknownForNonOverlappingTypes.ts"() { + function doRemoveOverrideModifierChange(changeTracker, sourceFile, pos) { + const classElement = findContainerClassElementLike(sourceFile, pos); + if (isSourceFileJS(sourceFile)) { + changeTracker.filterJSDocTags(sourceFile, classElement, not(isJSDocOverrideTag)); + return; + } + const overrideModifier = find(classElement.modifiers, isOverrideModifier); + Debug.assertIsDefined(overrideModifier); + changeTracker.deleteModifier(sourceFile, overrideModifier); + } + function isClassElementLikeHasJSDoc(node) { + switch (node.kind) { + case 176 /* Constructor */: + case 172 /* PropertyDeclaration */: + case 174 /* MethodDeclaration */: + case 177 /* GetAccessor */: + case 178 /* SetAccessor */: + return true; + case 169 /* Parameter */: + return isParameterPropertyDeclaration(node, node.parent); + default: + return false; + } + } + function findContainerClassElementLike(sourceFile, pos) { + const token = getTokenAtPosition(sourceFile, pos); + const classElement = findAncestor(token, (node) => { + if (isClassLike(node)) + return "quit"; + return isClassElementLikeHasJSDoc(node); + }); + Debug.assert(classElement && isClassElementLikeHasJSDoc(classElement)); + return classElement; + } + var fixName, fixAddOverrideId, fixRemoveOverrideId, errorCodes20, errorCodeFixIdMap; + var init_fixOverrideModifier = __esm({ + "src/services/codefixes/fixOverrideModifier.ts"() { "use strict"; init_ts4(); init_ts_codefix(); - fixId = "addConvertToUnknownForNonOverlappingTypes"; - errorCodes = [Diagnostics.Conversion_of_type_0_to_type_1_may_be_a_mistake_because_neither_type_sufficiently_overlaps_with_the_other_If_this_was_intentional_convert_the_expression_to_unknown_first.code]; + fixName = "fixOverrideModifier"; + fixAddOverrideId = "fixAddOverrideModifier"; + fixRemoveOverrideId = "fixRemoveOverrideModifier"; + errorCodes20 = [ + Diagnostics.This_member_cannot_have_an_override_modifier_because_it_is_not_declared_in_the_base_class_0.code, + Diagnostics.This_member_cannot_have_an_override_modifier_because_its_containing_class_0_does_not_extend_another_class.code, + Diagnostics.This_member_must_have_an_override_modifier_because_it_overrides_an_abstract_method_that_is_declared_in_the_base_class_0.code, + Diagnostics.This_member_must_have_an_override_modifier_because_it_overrides_a_member_in_the_base_class_0.code, + Diagnostics.This_parameter_property_must_have_an_override_modifier_because_it_overrides_a_member_in_base_class_0.code, + Diagnostics.This_member_must_have_a_JSDoc_comment_with_an_override_tag_because_it_overrides_a_member_in_the_base_class_0.code, + Diagnostics.This_member_cannot_have_a_JSDoc_comment_with_an_override_tag_because_its_containing_class_0_does_not_extend_another_class.code, + Diagnostics.This_parameter_property_must_have_a_JSDoc_comment_with_an_override_tag_because_it_overrides_a_member_in_the_base_class_0.code, + Diagnostics.This_member_cannot_have_a_JSDoc_comment_with_an_override_tag_because_it_is_not_declared_in_the_base_class_0.code + ]; + errorCodeFixIdMap = { + // case #1: + [Diagnostics.This_member_must_have_an_override_modifier_because_it_overrides_a_member_in_the_base_class_0.code]: { + descriptions: Diagnostics.Add_override_modifier, + fixId: fixAddOverrideId, + fixAllDescriptions: Diagnostics.Add_all_missing_override_modifiers + }, + [Diagnostics.This_member_must_have_a_JSDoc_comment_with_an_override_tag_because_it_overrides_a_member_in_the_base_class_0.code]: { + descriptions: Diagnostics.Add_override_modifier, + fixId: fixAddOverrideId, + fixAllDescriptions: Diagnostics.Add_all_missing_override_modifiers + }, + // case #2: + [Diagnostics.This_member_cannot_have_an_override_modifier_because_its_containing_class_0_does_not_extend_another_class.code]: { + descriptions: Diagnostics.Remove_override_modifier, + fixId: fixRemoveOverrideId, + fixAllDescriptions: Diagnostics.Remove_all_unnecessary_override_modifiers + }, + [Diagnostics.This_member_cannot_have_a_JSDoc_comment_with_an_override_tag_because_its_containing_class_0_does_not_extend_another_class.code]: { + descriptions: Diagnostics.Remove_override_modifier, + fixId: fixRemoveOverrideId, + fixAllDescriptions: Diagnostics.Remove_override_modifier + }, + // case #3: + [Diagnostics.This_parameter_property_must_have_an_override_modifier_because_it_overrides_a_member_in_base_class_0.code]: { + descriptions: Diagnostics.Add_override_modifier, + fixId: fixAddOverrideId, + fixAllDescriptions: Diagnostics.Add_all_missing_override_modifiers + }, + [Diagnostics.This_parameter_property_must_have_a_JSDoc_comment_with_an_override_tag_because_it_overrides_a_member_in_the_base_class_0.code]: { + descriptions: Diagnostics.Add_override_modifier, + fixId: fixAddOverrideId, + fixAllDescriptions: Diagnostics.Add_all_missing_override_modifiers + }, + // case #4: + [Diagnostics.This_member_must_have_an_override_modifier_because_it_overrides_an_abstract_method_that_is_declared_in_the_base_class_0.code]: { + descriptions: Diagnostics.Add_override_modifier, + fixId: fixAddOverrideId, + fixAllDescriptions: Diagnostics.Remove_all_unnecessary_override_modifiers + }, + // case #5: + [Diagnostics.This_member_cannot_have_an_override_modifier_because_it_is_not_declared_in_the_base_class_0.code]: { + descriptions: Diagnostics.Remove_override_modifier, + fixId: fixRemoveOverrideId, + fixAllDescriptions: Diagnostics.Remove_all_unnecessary_override_modifiers + }, + [Diagnostics.This_member_cannot_have_a_JSDoc_comment_with_an_override_tag_because_it_is_not_declared_in_the_base_class_0.code]: { + descriptions: Diagnostics.Remove_override_modifier, + fixId: fixRemoveOverrideId, + fixAllDescriptions: Diagnostics.Remove_all_unnecessary_override_modifiers + } + }; registerCodeFix({ - errorCodes, - getCodeActions: function getCodeActionsToAddConvertToUnknownForNonOverlappingTypes(context) { - const assertion = getAssertion(context.sourceFile, context.span.start); - if (assertion === void 0) - return void 0; - const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => makeChange(t, context.sourceFile, assertion)); - return [createCodeFixAction(fixId, changes, Diagnostics.Add_unknown_conversion_for_non_overlapping_types, fixId, Diagnostics.Add_unknown_to_all_conversions_of_non_overlapping_types)]; + errorCodes: errorCodes20, + getCodeActions: function getCodeActionsToFixOverrideModifierIssues(context) { + const { errorCode, span } = context; + const info = errorCodeFixIdMap[errorCode]; + if (!info) + return emptyArray; + const { descriptions, fixId: fixId52, fixAllDescriptions } = info; + const changes = ts_textChanges_exports.ChangeTracker.with(context, (changes2) => dispatchChanges(changes2, context, errorCode, span.start)); + return [ + createCodeFixActionMaybeFixAll(fixName, changes, descriptions, fixId52, fixAllDescriptions) + ]; }, - fixIds: [fixId], - getAllCodeActions: (context) => codeFixAll(context, errorCodes, (changes, diag2) => { - const assertion = getAssertion(diag2.file, diag2.start); - if (assertion) { - makeChange(changes, diag2.file, assertion); + fixIds: [fixName, fixAddOverrideId, fixRemoveOverrideId], + getAllCodeActions: (context) => codeFixAll(context, errorCodes20, (changes, diag2) => { + const { code, start } = diag2; + const info = errorCodeFixIdMap[code]; + if (!info || info.fixId !== context.fixId) { + return; } + dispatchChanges(changes, context, code, start); }) }); } }); - // src/services/codefixes/addEmptyExportDeclaration.ts - var init_addEmptyExportDeclaration = __esm({ - "src/services/codefixes/addEmptyExportDeclaration.ts"() { - "use strict"; - init_ts4(); - init_ts_codefix(); - registerCodeFix({ - errorCodes: [ - Diagnostics.await_expressions_are_only_allowed_at_the_top_level_of_a_file_when_that_file_is_a_module_but_this_file_has_no_imports_or_exports_Consider_adding_an_empty_export_to_make_this_file_a_module.code, - Diagnostics.for_await_loops_are_only_allowed_at_the_top_level_of_a_file_when_that_file_is_a_module_but_this_file_has_no_imports_or_exports_Consider_adding_an_empty_export_to_make_this_file_a_module.code - ], - getCodeActions: function getCodeActionsToAddEmptyExportDeclaration(context) { - const { sourceFile } = context; - const changes = ts_textChanges_exports.ChangeTracker.with(context, (changes2) => { - const exportDeclaration = factory.createExportDeclaration( - /*modifiers*/ - void 0, - /*isTypeOnly*/ - false, - factory.createNamedExports([]), - /*moduleSpecifier*/ - void 0 - ); - changes2.insertNodeAtEndOfScope(sourceFile, sourceFile, exportDeclaration); - }); - return [createCodeFixActionWithoutFixAll("addEmptyExportDeclaration", changes, Diagnostics.Add_export_to_make_this_file_into_a_module)]; - } - }); - } - }); - - // src/services/codefixes/addMissingAsync.ts - function getFix(context, decl, trackChanges, fixedDeclarations) { - const changes = trackChanges((t) => makeChange2(t, context.sourceFile, decl, fixedDeclarations)); - return createCodeFixAction(fixId2, changes, Diagnostics.Add_async_modifier_to_containing_function, fixId2, Diagnostics.Add_all_missing_async_modifiers); - } - function makeChange2(changeTracker, sourceFile, insertionSite, fixedDeclarations) { - if (fixedDeclarations) { - if (fixedDeclarations.has(getNodeId(insertionSite))) { - return; - } - } - fixedDeclarations == null ? void 0 : fixedDeclarations.add(getNodeId(insertionSite)); - const cloneWithModifier = factory.updateModifiers( - getSynthesizedDeepClone( - insertionSite, - /*includeTrivia*/ - true - ), - factory.createNodeArray(factory.createModifiersFromModifierFlags(getSyntacticModifierFlags(insertionSite) | 512 /* Async */)) - ); - changeTracker.replaceNode( + // src/services/codefixes/fixNoPropertyAccessFromIndexSignature.ts + function doChange14(changes, sourceFile, node, preferences) { + const quotePreference = getQuotePreference(sourceFile, preferences); + const argumentsExpression = factory.createStringLiteral(node.name.text, quotePreference === 0 /* Single */); + changes.replaceNode( sourceFile, - insertionSite, - cloneWithModifier + node, + isPropertyAccessChain(node) ? factory.createElementAccessChain(node.expression, node.questionDotToken, argumentsExpression) : factory.createElementAccessExpression(node.expression, argumentsExpression) ); } - function getFixableErrorSpanDeclaration(sourceFile, span) { - if (!span) - return void 0; - const token = getTokenAtPosition(sourceFile, span.start); - const decl = findAncestor(token, (node) => { - if (node.getStart(sourceFile) < span.start || node.getEnd() > textSpanEnd(span)) { - return "quit"; - } - return (isArrowFunction(node) || isMethodDeclaration(node) || isFunctionExpression(node) || isFunctionDeclaration(node)) && textSpansEqual(span, createTextSpanFromNode(node, sourceFile)); - }); - return decl; - } - function getIsMatchingAsyncError(span, errorCode) { - return ({ start, length: length2, relatedInformation, code }) => isNumber(start) && isNumber(length2) && textSpansEqual({ start, length: length2 }, span) && code === errorCode && !!relatedInformation && some(relatedInformation, (related) => related.code === Diagnostics.Did_you_mean_to_mark_this_function_as_async.code); + function getPropertyAccessExpression(sourceFile, pos) { + return cast(getTokenAtPosition(sourceFile, pos).parent, isPropertyAccessExpression); } - var fixId2, errorCodes2; - var init_addMissingAsync = __esm({ - "src/services/codefixes/addMissingAsync.ts"() { + var fixId18, errorCodes21; + var init_fixNoPropertyAccessFromIndexSignature = __esm({ + "src/services/codefixes/fixNoPropertyAccessFromIndexSignature.ts"() { "use strict"; init_ts4(); init_ts_codefix(); - fixId2 = "addMissingAsync"; - errorCodes2 = [ - Diagnostics.Argument_of_type_0_is_not_assignable_to_parameter_of_type_1.code, - Diagnostics.Type_0_is_not_assignable_to_type_1.code, - Diagnostics.Type_0_is_not_comparable_to_type_1.code + fixId18 = "fixNoPropertyAccessFromIndexSignature"; + errorCodes21 = [ + Diagnostics.Property_0_comes_from_an_index_signature_so_it_must_be_accessed_with_0.code ]; registerCodeFix({ - fixIds: [fixId2], - errorCodes: errorCodes2, - getCodeActions: function getCodeActionsToAddMissingAsync(context) { - const { sourceFile, errorCode, cancellationToken, program, span } = context; - const diagnostic = find(program.getTypeChecker().getDiagnostics(sourceFile, cancellationToken), getIsMatchingAsyncError(span, errorCode)); - const directSpan = diagnostic && diagnostic.relatedInformation && find(diagnostic.relatedInformation, (r) => r.code === Diagnostics.Did_you_mean_to_mark_this_function_as_async.code); - const decl = getFixableErrorSpanDeclaration(sourceFile, directSpan); - if (!decl) { - return; - } - const trackChanges = (cb) => ts_textChanges_exports.ChangeTracker.with(context, cb); - return [getFix(context, decl, trackChanges)]; + errorCodes: errorCodes21, + fixIds: [fixId18], + getCodeActions(context) { + const { sourceFile, span, preferences } = context; + const property = getPropertyAccessExpression(sourceFile, span.start); + const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange14(t, context.sourceFile, property, preferences)); + return [createCodeFixAction(fixId18, changes, [Diagnostics.Use_element_access_for_0, property.name.text], fixId18, Diagnostics.Use_element_access_for_all_undeclared_properties)]; }, - getAllCodeActions: (context) => { - const { sourceFile } = context; - const fixedDeclarations = /* @__PURE__ */ new Set(); - return codeFixAll(context, errorCodes2, (t, diagnostic) => { - const span = diagnostic.relatedInformation && find(diagnostic.relatedInformation, (r) => r.code === Diagnostics.Did_you_mean_to_mark_this_function_as_async.code); - const decl = getFixableErrorSpanDeclaration(sourceFile, span); - if (!decl) { - return; - } - const trackChanges = (cb) => (cb(t), []); - return getFix(context, decl, trackChanges, fixedDeclarations); - }); - } + getAllCodeActions: (context) => codeFixAll(context, errorCodes21, (changes, diag2) => doChange14(changes, diag2.file, getPropertyAccessExpression(diag2.file, diag2.start), context.preferences)) }); } }); - // src/services/codefixes/addMissingAwait.ts - function getAwaitErrorSpanExpression(sourceFile, errorCode, span, cancellationToken, program) { - const expression = getFixableErrorSpanExpression(sourceFile, span); - return expression && isMissingAwaitError(sourceFile, errorCode, span, cancellationToken, program) && isInsideAwaitableBody(expression) ? expression : void 0; - } - function getDeclarationSiteFix(context, expression, errorCode, checker, trackChanges, fixedDeclarations) { - const { sourceFile, program, cancellationToken } = context; - const awaitableInitializers = findAwaitableInitializers(expression, sourceFile, cancellationToken, program, checker); - if (awaitableInitializers) { - const initializerChanges = trackChanges((t) => { - forEach(awaitableInitializers.initializers, ({ expression: expression2 }) => makeChange3(t, errorCode, sourceFile, checker, expression2, fixedDeclarations)); - if (fixedDeclarations && awaitableInitializers.needsSecondPassForFixAll) { - makeChange3(t, errorCode, sourceFile, checker, expression, fixedDeclarations); - } - }); - return createCodeFixActionWithoutFixAll( - "addMissingAwaitToInitializer", - initializerChanges, - awaitableInitializers.initializers.length === 1 ? [Diagnostics.Add_await_to_initializer_for_0, awaitableInitializers.initializers[0].declarationSymbol.name] : Diagnostics.Add_await_to_initializers - ); - } - } - function getUseSiteFix(context, expression, errorCode, checker, trackChanges, fixedDeclarations) { - const changes = trackChanges((t) => makeChange3(t, errorCode, context.sourceFile, checker, expression, fixedDeclarations)); - return createCodeFixAction(fixId3, changes, Diagnostics.Add_await, fixId3, Diagnostics.Fix_all_expressions_possibly_missing_await); - } - function isMissingAwaitError(sourceFile, errorCode, span, cancellationToken, program) { - const checker = program.getTypeChecker(); - const diagnostics = checker.getDiagnostics(sourceFile, cancellationToken); - return some(diagnostics, ({ start, length: length2, relatedInformation, code }) => isNumber(start) && isNumber(length2) && textSpansEqual({ start, length: length2 }, span) && code === errorCode && !!relatedInformation && some(relatedInformation, (related) => related.code === Diagnostics.Did_you_forget_to_use_await.code)); - } - function findAwaitableInitializers(expression, sourceFile, cancellationToken, program, checker) { - const identifiers = getIdentifiersFromErrorSpanExpression(expression, checker); - if (!identifiers) { - return; - } - let isCompleteFix = identifiers.isCompleteFix; - let initializers; - for (const identifier of identifiers.identifiers) { - const symbol = checker.getSymbolAtLocation(identifier); - if (!symbol) { - continue; - } - const declaration = tryCast(symbol.valueDeclaration, isVariableDeclaration); - const variableName = declaration && tryCast(declaration.name, isIdentifier); - const variableStatement = getAncestor(declaration, 242 /* VariableStatement */); - if (!declaration || !variableStatement || declaration.type || !declaration.initializer || variableStatement.getSourceFile() !== sourceFile || hasSyntacticModifier(variableStatement, 1 /* Export */) || !variableName || !isInsideAwaitableBody(declaration.initializer)) { - isCompleteFix = false; - continue; - } - const diagnostics = program.getSemanticDiagnostics(sourceFile, cancellationToken); - const isUsedElsewhere = ts_FindAllReferences_exports.Core.eachSymbolReferenceInFile(variableName, checker, sourceFile, (reference) => { - return identifier !== reference && !symbolReferenceIsAlsoMissingAwait(reference, diagnostics, sourceFile, checker); - }); - if (isUsedElsewhere) { - isCompleteFix = false; - continue; - } - (initializers || (initializers = [])).push({ - expression: declaration.initializer, - declarationSymbol: symbol - }); - } - return initializers && { - initializers, - needsSecondPassForFixAll: !isCompleteFix - }; - } - function getIdentifiersFromErrorSpanExpression(expression, checker) { - if (isPropertyAccessExpression(expression.parent) && isIdentifier(expression.parent.expression)) { - return { identifiers: [expression.parent.expression], isCompleteFix: true }; - } - if (isIdentifier(expression)) { - return { identifiers: [expression], isCompleteFix: true }; - } - if (isBinaryExpression(expression)) { - let sides; - let isCompleteFix = true; - for (const side of [expression.left, expression.right]) { - const type = checker.getTypeAtLocation(side); - if (checker.getPromisedTypeOfPromise(type)) { - if (!isIdentifier(side)) { - isCompleteFix = false; - continue; - } - (sides || (sides = [])).push(side); - } - } - return sides && { identifiers: sides, isCompleteFix }; - } - } - function symbolReferenceIsAlsoMissingAwait(reference, diagnostics, sourceFile, checker) { - const errorNode = isPropertyAccessExpression(reference.parent) ? reference.parent.name : isBinaryExpression(reference.parent) ? reference.parent : reference; - const diagnostic = find(diagnostics, (diagnostic2) => diagnostic2.start === errorNode.getStart(sourceFile) && diagnostic2.start + diagnostic2.length === errorNode.getEnd()); - return diagnostic && contains(errorCodes3, diagnostic.code) || // A Promise is usually not correct in a binary expression (it's not valid - // in an arithmetic expression and an equality comparison seems unusual), - // but if the other side of the binary expression has an error, the side - // is typed `any` which will squash the error that would identify this - // Promise as an invalid operand. So if the whole binary expression is - // typed `any` as a result, there is a strong likelihood that this Promise - // is accidentally missing `await`. - checker.getTypeAtLocation(errorNode).flags & 1 /* Any */; - } - function isInsideAwaitableBody(node) { - return node.kind & 32768 /* AwaitContext */ || !!findAncestor(node, (ancestor) => ancestor.parent && isArrowFunction(ancestor.parent) && ancestor.parent.body === ancestor || isBlock(ancestor) && (ancestor.parent.kind === 261 /* FunctionDeclaration */ || ancestor.parent.kind === 217 /* FunctionExpression */ || ancestor.parent.kind === 218 /* ArrowFunction */ || ancestor.parent.kind === 173 /* MethodDeclaration */)); - } - function makeChange3(changeTracker, errorCode, sourceFile, checker, insertionSite, fixedDeclarations) { - if (isForOfStatement(insertionSite.parent) && !insertionSite.parent.awaitModifier) { - const exprType = checker.getTypeAtLocation(insertionSite); - const asyncIter = checker.getAsyncIterableType(); - if (asyncIter && checker.isTypeAssignableTo(exprType, asyncIter)) { - const forOf = insertionSite.parent; - changeTracker.replaceNode(sourceFile, forOf, factory.updateForOfStatement(forOf, factory.createToken(135 /* AwaitKeyword */), forOf.initializer, forOf.expression, forOf.statement)); - return; - } - } - if (isBinaryExpression(insertionSite)) { - for (const side of [insertionSite.left, insertionSite.right]) { - if (fixedDeclarations && isIdentifier(side)) { - const symbol = checker.getSymbolAtLocation(side); - if (symbol && fixedDeclarations.has(getSymbolId(symbol))) { - continue; - } - } - const type = checker.getTypeAtLocation(side); - const newNode = checker.getPromisedTypeOfPromise(type) ? factory.createAwaitExpression(side) : side; - changeTracker.replaceNode(sourceFile, side, newNode); - } - } else if (errorCode === propertyAccessCode && isPropertyAccessExpression(insertionSite.parent)) { - if (fixedDeclarations && isIdentifier(insertionSite.parent.expression)) { - const symbol = checker.getSymbolAtLocation(insertionSite.parent.expression); - if (symbol && fixedDeclarations.has(getSymbolId(symbol))) { - return; - } - } - changeTracker.replaceNode( - sourceFile, - insertionSite.parent.expression, - factory.createParenthesizedExpression(factory.createAwaitExpression(insertionSite.parent.expression)) - ); - insertLeadingSemicolonIfNeeded(changeTracker, insertionSite.parent.expression, sourceFile); - } else if (contains(callableConstructableErrorCodes, errorCode) && isCallOrNewExpression(insertionSite.parent)) { - if (fixedDeclarations && isIdentifier(insertionSite)) { - const symbol = checker.getSymbolAtLocation(insertionSite); - if (symbol && fixedDeclarations.has(getSymbolId(symbol))) { - return; + // src/services/codefixes/fixImplicitThis.ts + function doChange15(changes, sourceFile, pos, checker) { + const token = getTokenAtPosition(sourceFile, pos); + if (!isThis(token)) + return void 0; + const fn = getThisContainer( + token, + /*includeArrowFunctions*/ + false, + /*includeClassComputedPropertyName*/ + false + ); + if (!isFunctionDeclaration(fn) && !isFunctionExpression(fn)) + return void 0; + if (!isSourceFile(getThisContainer( + fn, + /*includeArrowFunctions*/ + false, + /*includeClassComputedPropertyName*/ + false + ))) { + const fnKeyword = Debug.checkDefined(findChildOfKind(fn, 100 /* FunctionKeyword */, sourceFile)); + const { name } = fn; + const body = Debug.checkDefined(fn.body); + if (isFunctionExpression(fn)) { + if (name && ts_FindAllReferences_exports.Core.isSymbolReferencedInFile(name, checker, sourceFile, body)) { + return void 0; } - } - changeTracker.replaceNode(sourceFile, insertionSite, factory.createParenthesizedExpression(factory.createAwaitExpression(insertionSite))); - insertLeadingSemicolonIfNeeded(changeTracker, insertionSite, sourceFile); - } else { - if (fixedDeclarations && isVariableDeclaration(insertionSite.parent) && isIdentifier(insertionSite.parent.name)) { - const symbol = checker.getSymbolAtLocation(insertionSite.parent.name); - if (symbol && !tryAddToSet(fixedDeclarations, getSymbolId(symbol))) { - return; + changes.delete(sourceFile, fnKeyword); + if (name) { + changes.delete(sourceFile, name); } + changes.insertText(sourceFile, body.pos, " =>"); + return [Diagnostics.Convert_function_expression_0_to_arrow_function, name ? name.text : ANONYMOUS]; + } else { + changes.replaceNode(sourceFile, fnKeyword, factory.createToken(87 /* ConstKeyword */)); + changes.insertText(sourceFile, name.end, " = "); + changes.insertText(sourceFile, body.pos, " =>"); + return [Diagnostics.Convert_function_declaration_0_to_arrow_function, name.text]; } - changeTracker.replaceNode(sourceFile, insertionSite, factory.createAwaitExpression(insertionSite)); - } - } - function insertLeadingSemicolonIfNeeded(changeTracker, beforeNode, sourceFile) { - const precedingToken = findPrecedingToken(beforeNode.pos, sourceFile); - if (precedingToken && positionIsASICandidate(precedingToken.end, precedingToken.parent, sourceFile)) { - changeTracker.insertText(sourceFile, beforeNode.getStart(sourceFile), ";"); } } - var fixId3, propertyAccessCode, callableConstructableErrorCodes, errorCodes3; - var init_addMissingAwait = __esm({ - "src/services/codefixes/addMissingAwait.ts"() { + var fixId19, errorCodes22; + var init_fixImplicitThis = __esm({ + "src/services/codefixes/fixImplicitThis.ts"() { "use strict"; init_ts4(); init_ts_codefix(); - fixId3 = "addMissingAwait"; - propertyAccessCode = Diagnostics.Property_0_does_not_exist_on_type_1.code; - callableConstructableErrorCodes = [ - Diagnostics.This_expression_is_not_callable.code, - Diagnostics.This_expression_is_not_constructable.code - ]; - errorCodes3 = [ - Diagnostics.An_arithmetic_operand_must_be_of_type_any_number_bigint_or_an_enum_type.code, - Diagnostics.The_left_hand_side_of_an_arithmetic_operation_must_be_of_type_any_number_bigint_or_an_enum_type.code, - Diagnostics.The_right_hand_side_of_an_arithmetic_operation_must_be_of_type_any_number_bigint_or_an_enum_type.code, - Diagnostics.Operator_0_cannot_be_applied_to_type_1.code, - Diagnostics.Operator_0_cannot_be_applied_to_types_1_and_2.code, - Diagnostics.This_comparison_appears_to_be_unintentional_because_the_types_0_and_1_have_no_overlap.code, - Diagnostics.This_condition_will_always_return_true_since_this_0_is_always_defined.code, - Diagnostics.Type_0_is_not_an_array_type.code, - Diagnostics.Type_0_is_not_an_array_type_or_a_string_type.code, - Diagnostics.Type_0_can_only_be_iterated_through_when_using_the_downlevelIteration_flag_or_with_a_target_of_es2015_or_higher.code, - Diagnostics.Type_0_is_not_an_array_type_or_a_string_type_or_does_not_have_a_Symbol_iterator_method_that_returns_an_iterator.code, - Diagnostics.Type_0_is_not_an_array_type_or_does_not_have_a_Symbol_iterator_method_that_returns_an_iterator.code, - Diagnostics.Type_0_must_have_a_Symbol_iterator_method_that_returns_an_iterator.code, - Diagnostics.Type_0_must_have_a_Symbol_asyncIterator_method_that_returns_an_async_iterator.code, - Diagnostics.Argument_of_type_0_is_not_assignable_to_parameter_of_type_1.code, - propertyAccessCode, - ...callableConstructableErrorCodes - ]; + fixId19 = "fixImplicitThis"; + errorCodes22 = [Diagnostics.this_implicitly_has_type_any_because_it_does_not_have_a_type_annotation.code]; registerCodeFix({ - fixIds: [fixId3], - errorCodes: errorCodes3, - getCodeActions: function getCodeActionsToAddMissingAwait(context) { - const { sourceFile, errorCode, span, cancellationToken, program } = context; - const expression = getAwaitErrorSpanExpression(sourceFile, errorCode, span, cancellationToken, program); - if (!expression) { - return; - } - const checker = context.program.getTypeChecker(); - const trackChanges = (cb) => ts_textChanges_exports.ChangeTracker.with(context, cb); - return compact([ - getDeclarationSiteFix(context, expression, errorCode, checker, trackChanges), - getUseSiteFix(context, expression, errorCode, checker, trackChanges) - ]); - }, - getAllCodeActions: (context) => { - const { sourceFile, program, cancellationToken } = context; - const checker = context.program.getTypeChecker(); - const fixedDeclarations = /* @__PURE__ */ new Set(); - return codeFixAll(context, errorCodes3, (t, diagnostic) => { - const expression = getAwaitErrorSpanExpression(sourceFile, diagnostic.code, diagnostic, cancellationToken, program); - if (!expression) { - return; - } - const trackChanges = (cb) => (cb(t), []); - return getDeclarationSiteFix(context, expression, diagnostic.code, checker, trackChanges, fixedDeclarations) || getUseSiteFix(context, expression, diagnostic.code, checker, trackChanges, fixedDeclarations); + errorCodes: errorCodes22, + getCodeActions: function getCodeActionsToFixImplicitThis(context) { + const { sourceFile, program, span } = context; + let diagnostic; + const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => { + diagnostic = doChange15(t, sourceFile, span.start, program.getTypeChecker()); }); - } + return diagnostic ? [createCodeFixAction(fixId19, changes, diagnostic, fixId19, Diagnostics.Fix_all_implicit_this_errors)] : emptyArray; + }, + fixIds: [fixId19], + getAllCodeActions: (context) => codeFixAll(context, errorCodes22, (changes, diag2) => { + doChange15(changes, diag2.file, diag2.start, context.program.getTypeChecker()); + }) }); } }); - // src/services/codefixes/addMissingConst.ts - function makeChange4(changeTracker, sourceFile, pos, program, fixedNodes) { + // src/services/codefixes/fixImportNonExportedMember.ts + function getInfo7(sourceFile, pos, program) { + var _a, _b; const token = getTokenAtPosition(sourceFile, pos); - const forInitializer = findAncestor( - token, - (node) => isForInOrOfStatement(node.parent) ? node.parent.initializer === node : isPossiblyPartOfDestructuring(node) ? false : "quit" - ); - if (forInitializer) - return applyChange(changeTracker, forInitializer, sourceFile, fixedNodes); - const parent2 = token.parent; - if (isBinaryExpression(parent2) && parent2.operatorToken.kind === 64 /* EqualsToken */ && isExpressionStatement(parent2.parent)) { - return applyChange(changeTracker, token, sourceFile, fixedNodes); + if (isIdentifier(token)) { + const importDeclaration = findAncestor(token, isImportDeclaration); + if (importDeclaration === void 0) + return void 0; + const moduleSpecifier = isStringLiteral(importDeclaration.moduleSpecifier) ? importDeclaration.moduleSpecifier.text : void 0; + if (moduleSpecifier === void 0) + return void 0; + const resolvedModule = (_a = program.getResolvedModule( + sourceFile, + moduleSpecifier, + /*mode*/ + void 0 + )) == null ? void 0 : _a.resolvedModule; + if (resolvedModule === void 0) + return void 0; + const moduleSourceFile = program.getSourceFile(resolvedModule.resolvedFileName); + if (moduleSourceFile === void 0 || isSourceFileFromLibrary(program, moduleSourceFile)) + return void 0; + const moduleSymbol = moduleSourceFile.symbol; + const locals = (_b = tryCast(moduleSymbol.valueDeclaration, canHaveLocals)) == null ? void 0 : _b.locals; + if (locals === void 0) + return void 0; + const localSymbol = locals.get(token.escapedText); + if (localSymbol === void 0) + return void 0; + const node = getNodeOfSymbol(localSymbol); + if (node === void 0) + return void 0; + const exportName = { node: token, isTypeOnly: isTypeDeclaration(node) }; + return { exportName, node, moduleSourceFile, moduleSpecifier }; } - if (isArrayLiteralExpression(parent2)) { - const checker = program.getTypeChecker(); - if (!every(parent2.elements, (element) => arrayElementCouldBeVariableDeclaration(element, checker))) { - return; - } - return applyChange(changeTracker, parent2, sourceFile, fixedNodes); + return void 0; + } + function doChange16(changes, program, { exportName, node, moduleSourceFile }) { + const exportDeclaration = tryGetExportDeclaration(moduleSourceFile, exportName.isTypeOnly); + if (exportDeclaration) { + updateExport(changes, program, moduleSourceFile, exportDeclaration, [exportName]); + } else if (canHaveExportModifier(node)) { + changes.insertExportModifier(moduleSourceFile, node); + } else { + createExport(changes, program, moduleSourceFile, [exportName]); } - const commaExpression = findAncestor( - token, - (node) => isExpressionStatement(node.parent) ? true : isPossiblyPartOfCommaSeperatedInitializer(node) ? false : "quit" - ); - if (commaExpression) { - const checker = program.getTypeChecker(); - if (!expressionCouldBeVariableDeclaration(commaExpression, checker)) { - return; + } + function doChanges(changes, program, sourceFile, moduleExports, node) { + if (length(moduleExports)) { + if (node) { + updateExport(changes, program, sourceFile, node, moduleExports); + } else { + createExport(changes, program, sourceFile, moduleExports); } - return applyChange(changeTracker, commaExpression, sourceFile, fixedNodes); } } - function applyChange(changeTracker, initializer, sourceFile, fixedNodes) { - if (!fixedNodes || tryAddToSet(fixedNodes, initializer)) { - changeTracker.insertModifierBefore(sourceFile, 87 /* ConstKeyword */, initializer); - } + function tryGetExportDeclaration(sourceFile, isTypeOnly) { + const predicate = (node) => isExportDeclaration(node) && (isTypeOnly && node.isTypeOnly || !node.isTypeOnly); + return findLast(sourceFile.statements, predicate); } - function isPossiblyPartOfDestructuring(node) { - switch (node.kind) { - case 80 /* Identifier */: - case 208 /* ArrayLiteralExpression */: - case 209 /* ObjectLiteralExpression */: - case 302 /* PropertyAssignment */: - case 303 /* ShorthandPropertyAssignment */: - return true; - default: - return false; - } + function updateExport(changes, program, sourceFile, node, names) { + const namedExports = node.exportClause && isNamedExports(node.exportClause) ? node.exportClause.elements : factory.createNodeArray([]); + const allowTypeModifier = !node.isTypeOnly && !!(getIsolatedModules(program.getCompilerOptions()) || find(namedExports, (e) => e.isTypeOnly)); + changes.replaceNode( + sourceFile, + node, + factory.updateExportDeclaration( + node, + node.modifiers, + node.isTypeOnly, + factory.createNamedExports( + factory.createNodeArray( + [...namedExports, ...createExportSpecifiers(names, allowTypeModifier)], + /*hasTrailingComma*/ + namedExports.hasTrailingComma + ) + ), + node.moduleSpecifier, + node.attributes + ) + ); } - function arrayElementCouldBeVariableDeclaration(expression, checker) { - const identifier = isIdentifier(expression) ? expression : isAssignmentExpression( - expression, - /*excludeCompoundAssignment*/ - true - ) && isIdentifier(expression.left) ? expression.left : void 0; - return !!identifier && !checker.getSymbolAtLocation(identifier); + function createExport(changes, program, sourceFile, names) { + changes.insertNodeAtEndOfScope(sourceFile, sourceFile, factory.createExportDeclaration( + /*modifiers*/ + void 0, + /*isTypeOnly*/ + false, + factory.createNamedExports(createExportSpecifiers( + names, + /*allowTypeModifier*/ + getIsolatedModules(program.getCompilerOptions()) + )), + /*moduleSpecifier*/ + void 0, + /*attributes*/ + void 0 + )); } - function isPossiblyPartOfCommaSeperatedInitializer(node) { - switch (node.kind) { - case 80 /* Identifier */: - case 225 /* BinaryExpression */: - case 28 /* CommaToken */: - return true; - default: - return false; - } + function createExportSpecifiers(names, allowTypeModifier) { + return factory.createNodeArray(map(names, (n) => factory.createExportSpecifier( + allowTypeModifier && n.isTypeOnly, + /*propertyName*/ + void 0, + n.node + ))); } - function expressionCouldBeVariableDeclaration(expression, checker) { - if (!isBinaryExpression(expression)) { - return false; - } - if (expression.operatorToken.kind === 28 /* CommaToken */) { - return every([expression.left, expression.right], (expression2) => expressionCouldBeVariableDeclaration(expression2, checker)); + function getNodeOfSymbol(symbol) { + if (symbol.valueDeclaration === void 0) { + return firstOrUndefined(symbol.declarations); } - return expression.operatorToken.kind === 64 /* EqualsToken */ && isIdentifier(expression.left) && !checker.getSymbolAtLocation(expression.left); + const declaration = symbol.valueDeclaration; + const variableStatement = isVariableDeclaration(declaration) ? tryCast(declaration.parent.parent, isVariableStatement) : void 0; + return variableStatement && length(variableStatement.declarationList.declarations) === 1 ? variableStatement : declaration; } - var fixId4, errorCodes4; - var init_addMissingConst = __esm({ - "src/services/codefixes/addMissingConst.ts"() { + var fixId20, errorCodes23; + var init_fixImportNonExportedMember = __esm({ + "src/services/codefixes/fixImportNonExportedMember.ts"() { "use strict"; init_ts4(); init_ts_codefix(); - fixId4 = "addMissingConst"; - errorCodes4 = [ - Diagnostics.Cannot_find_name_0.code, - Diagnostics.No_value_exists_in_scope_for_the_shorthand_property_0_Either_declare_one_or_provide_an_initializer.code + fixId20 = "fixImportNonExportedMember"; + errorCodes23 = [ + Diagnostics.Module_0_declares_1_locally_but_it_is_not_exported.code ]; registerCodeFix({ - errorCodes: errorCodes4, - getCodeActions: function getCodeActionsToAddMissingConst(context) { - const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => makeChange4(t, context.sourceFile, context.span.start, context.program)); - if (changes.length > 0) { - return [createCodeFixAction(fixId4, changes, Diagnostics.Add_const_to_unresolved_variable, fixId4, Diagnostics.Add_const_to_all_unresolved_variables)]; - } + errorCodes: errorCodes23, + fixIds: [fixId20], + getCodeActions(context) { + const { sourceFile, span, program } = context; + const info = getInfo7(sourceFile, span.start, program); + if (info === void 0) + return void 0; + const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange16(t, program, info)); + return [createCodeFixAction(fixId20, changes, [Diagnostics.Export_0_from_module_1, info.exportName.node.text, info.moduleSpecifier], fixId20, Diagnostics.Export_all_referenced_locals)]; }, - fixIds: [fixId4], - getAllCodeActions: (context) => { - const fixedNodes = /* @__PURE__ */ new Set(); - return codeFixAll(context, errorCodes4, (changes, diag2) => makeChange4(changes, diag2.file, diag2.start, context.program, fixedNodes)); + getAllCodeActions(context) { + const { program } = context; + return createCombinedCodeActions(ts_textChanges_exports.ChangeTracker.with(context, (changes) => { + const exports = /* @__PURE__ */ new Map(); + eachDiagnostic(context, errorCodes23, (diag2) => { + const info = getInfo7(diag2.file, diag2.start, program); + if (info === void 0) + return void 0; + const { exportName, node, moduleSourceFile } = info; + if (tryGetExportDeclaration(moduleSourceFile, exportName.isTypeOnly) === void 0 && canHaveExportModifier(node)) { + changes.insertExportModifier(moduleSourceFile, node); + } else { + const moduleExports = exports.get(moduleSourceFile) || { typeOnlyExports: [], exports: [] }; + if (exportName.isTypeOnly) { + moduleExports.typeOnlyExports.push(exportName); + } else { + moduleExports.exports.push(exportName); + } + exports.set(moduleSourceFile, moduleExports); + } + }); + exports.forEach((moduleExports, moduleSourceFile) => { + const exportDeclaration = tryGetExportDeclaration( + moduleSourceFile, + /*isTypeOnly*/ + true + ); + if (exportDeclaration && exportDeclaration.isTypeOnly) { + doChanges(changes, program, moduleSourceFile, moduleExports.typeOnlyExports, exportDeclaration); + doChanges(changes, program, moduleSourceFile, moduleExports.exports, tryGetExportDeclaration( + moduleSourceFile, + /*isTypeOnly*/ + false + )); + } else { + doChanges(changes, program, moduleSourceFile, [...moduleExports.exports, ...moduleExports.typeOnlyExports], exportDeclaration); + } + }); + })); } }); } }); - // src/services/codefixes/addMissingDeclareProperty.ts - function makeChange5(changeTracker, sourceFile, pos, fixedNodes) { + // src/services/codefixes/fixIncorrectNamedTupleSyntax.ts + function getNamedTupleMember(sourceFile, pos) { const token = getTokenAtPosition(sourceFile, pos); - if (!isIdentifier(token)) { + return findAncestor(token, (t) => t.kind === 202 /* NamedTupleMember */); + } + function doChange17(changes, sourceFile, namedTupleMember) { + if (!namedTupleMember) { return; } - const declaration = token.parent; - if (declaration.kind === 171 /* PropertyDeclaration */ && (!fixedNodes || tryAddToSet(fixedNodes, declaration))) { - changeTracker.insertModifierBefore(sourceFile, 138 /* DeclareKeyword */, declaration); + let unwrappedType = namedTupleMember.type; + let sawOptional = false; + let sawRest = false; + while (unwrappedType.kind === 190 /* OptionalType */ || unwrappedType.kind === 191 /* RestType */ || unwrappedType.kind === 196 /* ParenthesizedType */) { + if (unwrappedType.kind === 190 /* OptionalType */) { + sawOptional = true; + } else if (unwrappedType.kind === 191 /* RestType */) { + sawRest = true; + } + unwrappedType = unwrappedType.type; + } + const updated = factory.updateNamedTupleMember( + namedTupleMember, + namedTupleMember.dotDotDotToken || (sawRest ? factory.createToken(26 /* DotDotDotToken */) : void 0), + namedTupleMember.name, + namedTupleMember.questionToken || (sawOptional ? factory.createToken(58 /* QuestionToken */) : void 0), + unwrappedType + ); + if (updated === namedTupleMember) { + return; } + changes.replaceNode(sourceFile, namedTupleMember, updated); } - var fixId5, errorCodes5; - var init_addMissingDeclareProperty = __esm({ - "src/services/codefixes/addMissingDeclareProperty.ts"() { + var fixId21, errorCodes24; + var init_fixIncorrectNamedTupleSyntax = __esm({ + "src/services/codefixes/fixIncorrectNamedTupleSyntax.ts"() { "use strict"; init_ts4(); init_ts_codefix(); - fixId5 = "addMissingDeclareProperty"; - errorCodes5 = [ - Diagnostics.Property_0_will_overwrite_the_base_property_in_1_If_this_is_intentional_add_an_initializer_Otherwise_add_a_declare_modifier_or_remove_the_redundant_declaration.code + fixId21 = "fixIncorrectNamedTupleSyntax"; + errorCodes24 = [ + Diagnostics.A_labeled_tuple_element_is_declared_as_optional_with_a_question_mark_after_the_name_and_before_the_colon_rather_than_after_the_type.code, + Diagnostics.A_labeled_tuple_element_is_declared_as_rest_with_a_before_the_name_rather_than_before_the_type.code ]; registerCodeFix({ - errorCodes: errorCodes5, - getCodeActions: function getCodeActionsToAddMissingDeclareOnProperty(context) { - const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => makeChange5(t, context.sourceFile, context.span.start)); - if (changes.length > 0) { - return [createCodeFixAction(fixId5, changes, Diagnostics.Prefix_with_declare, fixId5, Diagnostics.Prefix_all_incorrect_property_declarations_with_declare)]; - } + errorCodes: errorCodes24, + getCodeActions: function getCodeActionsToFixIncorrectNamedTupleSyntax(context) { + const { sourceFile, span } = context; + const namedTupleMember = getNamedTupleMember(sourceFile, span.start); + const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange17(t, sourceFile, namedTupleMember)); + return [createCodeFixAction(fixId21, changes, Diagnostics.Move_labeled_tuple_element_modifiers_to_labels, fixId21, Diagnostics.Move_labeled_tuple_element_modifiers_to_labels)]; }, - fixIds: [fixId5], - getAllCodeActions: (context) => { - const fixedNodes = /* @__PURE__ */ new Set(); - return codeFixAll(context, errorCodes5, (changes, diag2) => makeChange5(changes, diag2.file, diag2.start, fixedNodes)); - } + fixIds: [fixId21] }); } }); - // src/services/codefixes/addMissingInvocationForDecorator.ts - function makeChange6(changeTracker, sourceFile, pos) { - const token = getTokenAtPosition(sourceFile, pos); - const decorator = findAncestor(token, isDecorator); - Debug.assert(!!decorator, "Expected position to be owned by a decorator."); - const replacement = factory.createCallExpression( - decorator.expression, - /*typeArguments*/ - void 0, - /*argumentsArray*/ - void 0 - ); - changeTracker.replaceNode(sourceFile, decorator.expression, replacement); + // src/services/codefixes/fixSpelling.ts + function getInfo8(sourceFile, pos, context, errorCode) { + const node = getTokenAtPosition(sourceFile, pos); + const parent2 = node.parent; + if ((errorCode === Diagnostics.No_overload_matches_this_call.code || errorCode === Diagnostics.Type_0_is_not_assignable_to_type_1.code) && !isJsxAttribute(parent2)) + return void 0; + const checker = context.program.getTypeChecker(); + let suggestedSymbol; + if (isPropertyAccessExpression(parent2) && parent2.name === node) { + Debug.assert(isMemberName(node), "Expected an identifier for spelling (property access)"); + let containingType = checker.getTypeAtLocation(parent2.expression); + if (parent2.flags & 64 /* OptionalChain */) { + containingType = checker.getNonNullableType(containingType); + } + suggestedSymbol = checker.getSuggestedSymbolForNonexistentProperty(node, containingType); + } else if (isBinaryExpression(parent2) && parent2.operatorToken.kind === 103 /* InKeyword */ && parent2.left === node && isPrivateIdentifier(node)) { + const receiverType = checker.getTypeAtLocation(parent2.right); + suggestedSymbol = checker.getSuggestedSymbolForNonexistentProperty(node, receiverType); + } else if (isQualifiedName(parent2) && parent2.right === node) { + const symbol = checker.getSymbolAtLocation(parent2.left); + if (symbol && symbol.flags & 1536 /* Module */) { + suggestedSymbol = checker.getSuggestedSymbolForNonexistentModule(parent2.right, symbol); + } + } else if (isImportSpecifier(parent2) && parent2.name === node) { + Debug.assertNode(node, isIdentifier, "Expected an identifier for spelling (import)"); + const importDeclaration = findAncestor(node, isImportDeclaration); + const resolvedSourceFile = getResolvedSourceFileFromImportDeclaration(sourceFile, context, importDeclaration); + if (resolvedSourceFile && resolvedSourceFile.symbol) { + suggestedSymbol = checker.getSuggestedSymbolForNonexistentModule(node, resolvedSourceFile.symbol); + } + } else if (isJsxAttribute(parent2) && parent2.name === node) { + Debug.assertNode(node, isIdentifier, "Expected an identifier for JSX attribute"); + const tag = findAncestor(node, isJsxOpeningLikeElement); + const props = checker.getContextualTypeForArgumentAtIndex(tag, 0); + suggestedSymbol = checker.getSuggestedSymbolForNonexistentJSXAttribute(node, props); + } else if (hasOverrideModifier(parent2) && isClassElement(parent2) && parent2.name === node) { + const baseDeclaration = findAncestor(node, isClassLike); + const baseTypeNode = baseDeclaration ? getEffectiveBaseTypeNode(baseDeclaration) : void 0; + const baseType = baseTypeNode ? checker.getTypeAtLocation(baseTypeNode) : void 0; + if (baseType) { + suggestedSymbol = checker.getSuggestedSymbolForNonexistentClassMember(getTextOfNode(node), baseType); + } + } else { + const meaning = getMeaningFromLocation(node); + const name = getTextOfNode(node); + Debug.assert(name !== void 0, "name should be defined"); + suggestedSymbol = checker.getSuggestedSymbolForNonexistentSymbol(node, name, convertSemanticMeaningToSymbolFlags(meaning)); + } + return suggestedSymbol === void 0 ? void 0 : { node, suggestedSymbol }; } - var fixId6, errorCodes6; - var init_addMissingInvocationForDecorator = __esm({ - "src/services/codefixes/addMissingInvocationForDecorator.ts"() { + function doChange18(changes, sourceFile, node, suggestedSymbol, target) { + const suggestion = symbolName(suggestedSymbol); + if (!isIdentifierText(suggestion, target) && isPropertyAccessExpression(node.parent)) { + const valDecl = suggestedSymbol.valueDeclaration; + if (valDecl && isNamedDeclaration(valDecl) && isPrivateIdentifier(valDecl.name)) { + changes.replaceNode(sourceFile, node, factory.createIdentifier(suggestion)); + } else { + changes.replaceNode(sourceFile, node.parent, factory.createElementAccessExpression(node.parent.expression, factory.createStringLiteral(suggestion))); + } + } else { + changes.replaceNode(sourceFile, node, factory.createIdentifier(suggestion)); + } + } + function convertSemanticMeaningToSymbolFlags(meaning) { + let flags = 0; + if (meaning & 4 /* Namespace */) { + flags |= 1920 /* Namespace */; + } + if (meaning & 2 /* Type */) { + flags |= 788968 /* Type */; + } + if (meaning & 1 /* Value */) { + flags |= 111551 /* Value */; + } + return flags; + } + function getResolvedSourceFileFromImportDeclaration(sourceFile, context, importDeclaration) { + var _a; + if (!importDeclaration || !isStringLiteralLike(importDeclaration.moduleSpecifier)) + return void 0; + const resolvedModule = (_a = context.program.getResolvedModule(sourceFile, importDeclaration.moduleSpecifier.text, getModeForUsageLocation(sourceFile, importDeclaration.moduleSpecifier))) == null ? void 0 : _a.resolvedModule; + if (!resolvedModule) + return void 0; + return context.program.getSourceFile(resolvedModule.resolvedFileName); + } + var fixId22, errorCodes25; + var init_fixSpelling = __esm({ + "src/services/codefixes/fixSpelling.ts"() { "use strict"; init_ts4(); init_ts_codefix(); - fixId6 = "addMissingInvocationForDecorator"; - errorCodes6 = [Diagnostics._0_accepts_too_few_arguments_to_be_used_as_a_decorator_here_Did_you_mean_to_call_it_first_and_write_0.code]; + fixId22 = "fixSpelling"; + errorCodes25 = [ + Diagnostics.Property_0_does_not_exist_on_type_1_Did_you_mean_2.code, + Diagnostics.Property_0_may_not_exist_on_type_1_Did_you_mean_2.code, + Diagnostics.Cannot_find_name_0_Did_you_mean_1.code, + Diagnostics.Could_not_find_name_0_Did_you_mean_1.code, + Diagnostics.Cannot_find_namespace_0_Did_you_mean_1.code, + Diagnostics.Cannot_find_name_0_Did_you_mean_the_instance_member_this_0.code, + Diagnostics.Cannot_find_name_0_Did_you_mean_the_static_member_1_0.code, + Diagnostics._0_has_no_exported_member_named_1_Did_you_mean_2.code, + Diagnostics.This_member_cannot_have_an_override_modifier_because_it_is_not_declared_in_the_base_class_0_Did_you_mean_1.code, + Diagnostics.This_member_cannot_have_a_JSDoc_comment_with_an_override_tag_because_it_is_not_declared_in_the_base_class_0_Did_you_mean_1.code, + // for JSX class components + Diagnostics.No_overload_matches_this_call.code, + // for JSX FC + Diagnostics.Type_0_is_not_assignable_to_type_1.code + ]; registerCodeFix({ - errorCodes: errorCodes6, - getCodeActions: function getCodeActionsToAddMissingInvocationForDecorator(context) { - const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => makeChange6(t, context.sourceFile, context.span.start)); - return [createCodeFixAction(fixId6, changes, Diagnostics.Call_decorator_expression, fixId6, Diagnostics.Add_to_all_uncalled_decorators)]; + errorCodes: errorCodes25, + getCodeActions(context) { + const { sourceFile, errorCode } = context; + const info = getInfo8(sourceFile, context.span.start, context, errorCode); + if (!info) + return void 0; + const { node, suggestedSymbol } = info; + const target = getEmitScriptTarget(context.host.getCompilationSettings()); + const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange18(t, sourceFile, node, suggestedSymbol, target)); + return [createCodeFixAction("spelling", changes, [Diagnostics.Change_spelling_to_0, symbolName(suggestedSymbol)], fixId22, Diagnostics.Fix_all_detected_spelling_errors)]; }, - fixIds: [fixId6], - getAllCodeActions: (context) => codeFixAll(context, errorCodes6, (changes, diag2) => makeChange6(changes, diag2.file, diag2.start)) + fixIds: [fixId22], + getAllCodeActions: (context) => codeFixAll(context, errorCodes25, (changes, diag2) => { + const info = getInfo8(diag2.file, diag2.start, context, diag2.code); + const target = getEmitScriptTarget(context.host.getCompilationSettings()); + if (info) + doChange18(changes, context.sourceFile, info.node, info.suggestedSymbol, target); + }) }); } }); - // src/services/codefixes/addNameToNamelessParameter.ts - function makeChange7(changeTracker, sourceFile, pos) { - const token = getTokenAtPosition(sourceFile, pos); - const param = token.parent; - if (!isParameter(param)) { - return Debug.fail("Tried to add a parameter name to a non-parameter: " + Debug.formatSyntaxKind(token.kind)); - } - const i = param.parent.parameters.indexOf(param); - Debug.assert(!param.type, "Tried to add a parameter name to a parameter that already had one."); - Debug.assert(i > -1, "Parameter not found in parent parameter list."); - const typeNode = factory.createTypeReferenceNode( - param.name, - /*typeArguments*/ - void 0 - ); - const replacement = factory.createParameterDeclaration( - param.modifiers, - param.dotDotDotToken, - "arg" + i, - param.questionToken, - param.dotDotDotToken ? factory.createArrayTypeNode(typeNode) : typeNode, - param.initializer + // src/services/codefixes/returnValueCorrect.ts + function createObjectTypeFromLabeledExpression(checker, label, expression) { + const member = checker.createSymbol(4 /* Property */, label.escapedText); + member.links.type = checker.getTypeAtLocation(expression); + const members = createSymbolTable([member]); + return checker.createAnonymousType( + /*symbol*/ + void 0, + members, + [], + [], + [] ); - changeTracker.replaceNode(sourceFile, param, replacement); } - var fixId7, errorCodes7; - var init_addNameToNamelessParameter = __esm({ - "src/services/codefixes/addNameToNamelessParameter.ts"() { + function getFixInfo(checker, declaration, expectType, isFunctionType) { + if (!declaration.body || !isBlock(declaration.body) || length(declaration.body.statements) !== 1) + return void 0; + const firstStatement = first(declaration.body.statements); + if (isExpressionStatement(firstStatement) && checkFixedAssignableTo(checker, declaration, checker.getTypeAtLocation(firstStatement.expression), expectType, isFunctionType)) { + return { + declaration, + kind: 0 /* MissingReturnStatement */, + expression: firstStatement.expression, + statement: firstStatement, + commentSource: firstStatement.expression + }; + } else if (isLabeledStatement(firstStatement) && isExpressionStatement(firstStatement.statement)) { + const node = factory.createObjectLiteralExpression([factory.createPropertyAssignment(firstStatement.label, firstStatement.statement.expression)]); + const nodeType = createObjectTypeFromLabeledExpression(checker, firstStatement.label, firstStatement.statement.expression); + if (checkFixedAssignableTo(checker, declaration, nodeType, expectType, isFunctionType)) { + return isArrowFunction(declaration) ? { + declaration, + kind: 1 /* MissingParentheses */, + expression: node, + statement: firstStatement, + commentSource: firstStatement.statement.expression + } : { + declaration, + kind: 0 /* MissingReturnStatement */, + expression: node, + statement: firstStatement, + commentSource: firstStatement.statement.expression + }; + } + } else if (isBlock(firstStatement) && length(firstStatement.statements) === 1) { + const firstBlockStatement = first(firstStatement.statements); + if (isLabeledStatement(firstBlockStatement) && isExpressionStatement(firstBlockStatement.statement)) { + const node = factory.createObjectLiteralExpression([factory.createPropertyAssignment(firstBlockStatement.label, firstBlockStatement.statement.expression)]); + const nodeType = createObjectTypeFromLabeledExpression(checker, firstBlockStatement.label, firstBlockStatement.statement.expression); + if (checkFixedAssignableTo(checker, declaration, nodeType, expectType, isFunctionType)) { + return { + declaration, + kind: 0 /* MissingReturnStatement */, + expression: node, + statement: firstStatement, + commentSource: firstBlockStatement + }; + } + } + } + return void 0; + } + function checkFixedAssignableTo(checker, declaration, exprType, type, isFunctionType) { + if (isFunctionType) { + const sig = checker.getSignatureFromDeclaration(declaration); + if (sig) { + if (hasSyntacticModifier(declaration, 1024 /* Async */)) { + exprType = checker.createPromiseType(exprType); + } + const newSig = checker.createSignature( + declaration, + sig.typeParameters, + sig.thisParameter, + sig.parameters, + exprType, + /*typePredicate*/ + void 0, + sig.minArgumentCount, + sig.flags + ); + exprType = checker.createAnonymousType( + /*symbol*/ + void 0, + createSymbolTable(), + [newSig], + [], + [] + ); + } else { + exprType = checker.getAnyType(); + } + } + return checker.isTypeAssignableTo(exprType, type); + } + function getInfo9(checker, sourceFile, position, errorCode) { + const node = getTokenAtPosition(sourceFile, position); + if (!node.parent) + return void 0; + const declaration = findAncestor(node.parent, isFunctionLikeDeclaration); + switch (errorCode) { + case Diagnostics.A_function_whose_declared_type_is_neither_undefined_void_nor_any_must_return_a_value.code: + if (!declaration || !declaration.body || !declaration.type || !rangeContainsRange(declaration.type, node)) + return void 0; + return getFixInfo( + checker, + declaration, + checker.getTypeFromTypeNode(declaration.type), + /*isFunctionType*/ + false + ); + case Diagnostics.Argument_of_type_0_is_not_assignable_to_parameter_of_type_1.code: + if (!declaration || !isCallExpression(declaration.parent) || !declaration.body) + return void 0; + const pos = declaration.parent.arguments.indexOf(declaration); + if (pos === -1) + return void 0; + const type = checker.getContextualTypeForArgumentAtIndex(declaration.parent, pos); + if (!type) + return void 0; + return getFixInfo( + checker, + declaration, + type, + /*isFunctionType*/ + true + ); + case Diagnostics.Type_0_is_not_assignable_to_type_1.code: + if (!isDeclarationName(node) || !isVariableLike(node.parent) && !isJsxAttribute(node.parent)) + return void 0; + const initializer = getVariableLikeInitializer(node.parent); + if (!initializer || !isFunctionLikeDeclaration(initializer) || !initializer.body) + return void 0; + return getFixInfo( + checker, + initializer, + checker.getTypeAtLocation(node.parent), + /*isFunctionType*/ + true + ); + } + return void 0; + } + function getVariableLikeInitializer(declaration) { + switch (declaration.kind) { + case 260 /* VariableDeclaration */: + case 169 /* Parameter */: + case 208 /* BindingElement */: + case 172 /* PropertyDeclaration */: + case 303 /* PropertyAssignment */: + return declaration.initializer; + case 291 /* JsxAttribute */: + return declaration.initializer && (isJsxExpression(declaration.initializer) ? declaration.initializer.expression : void 0); + case 304 /* ShorthandPropertyAssignment */: + case 171 /* PropertySignature */: + case 306 /* EnumMember */: + case 355 /* JSDocPropertyTag */: + case 348 /* JSDocParameterTag */: + return void 0; + } + } + function addReturnStatement(changes, sourceFile, expression, statement) { + suppressLeadingAndTrailingTrivia(expression); + const probablyNeedSemi = probablyUsesSemicolons(sourceFile); + changes.replaceNode(sourceFile, statement, factory.createReturnStatement(expression), { + leadingTriviaOption: ts_textChanges_exports.LeadingTriviaOption.Exclude, + trailingTriviaOption: ts_textChanges_exports.TrailingTriviaOption.Exclude, + suffix: probablyNeedSemi ? ";" : void 0 + }); + } + function removeBlockBodyBrace(changes, sourceFile, declaration, expression, commentSource, withParen) { + const newBody = withParen || needsParentheses(expression) ? factory.createParenthesizedExpression(expression) : expression; + suppressLeadingAndTrailingTrivia(commentSource); + copyComments(commentSource, newBody); + changes.replaceNode(sourceFile, declaration.body, newBody); + } + function wrapBlockWithParen(changes, sourceFile, declaration, expression) { + changes.replaceNode(sourceFile, declaration.body, factory.createParenthesizedExpression(expression)); + } + function getActionForfixAddReturnStatement(context, expression, statement) { + const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => addReturnStatement(t, context.sourceFile, expression, statement)); + return createCodeFixAction(fixId23, changes, Diagnostics.Add_a_return_statement, fixIdAddReturnStatement, Diagnostics.Add_all_missing_return_statement); + } + function getActionForFixRemoveBracesFromArrowFunctionBody(context, declaration, expression, commentSource) { + const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => removeBlockBodyBrace( + t, + context.sourceFile, + declaration, + expression, + commentSource, + /*withParen*/ + false + )); + return createCodeFixAction(fixId23, changes, Diagnostics.Remove_braces_from_arrow_function_body, fixRemoveBracesFromArrowFunctionBody, Diagnostics.Remove_braces_from_all_arrow_function_bodies_with_relevant_issues); + } + function getActionForfixWrapTheBlockWithParen(context, declaration, expression) { + const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => wrapBlockWithParen(t, context.sourceFile, declaration, expression)); + return createCodeFixAction(fixId23, changes, Diagnostics.Wrap_the_following_body_with_parentheses_which_should_be_an_object_literal, fixIdWrapTheBlockWithParen, Diagnostics.Wrap_all_object_literal_with_parentheses); + } + var fixId23, fixIdAddReturnStatement, fixRemoveBracesFromArrowFunctionBody, fixIdWrapTheBlockWithParen, errorCodes26; + var init_returnValueCorrect = __esm({ + "src/services/codefixes/returnValueCorrect.ts"() { "use strict"; init_ts4(); init_ts_codefix(); - fixId7 = "addNameToNamelessParameter"; - errorCodes7 = [Diagnostics.Parameter_has_a_name_but_no_type_Did_you_mean_0_Colon_1.code]; + fixId23 = "returnValueCorrect"; + fixIdAddReturnStatement = "fixAddReturnStatement"; + fixRemoveBracesFromArrowFunctionBody = "fixRemoveBracesFromArrowFunctionBody"; + fixIdWrapTheBlockWithParen = "fixWrapTheBlockWithParen"; + errorCodes26 = [ + Diagnostics.A_function_whose_declared_type_is_neither_undefined_void_nor_any_must_return_a_value.code, + Diagnostics.Type_0_is_not_assignable_to_type_1.code, + Diagnostics.Argument_of_type_0_is_not_assignable_to_parameter_of_type_1.code + ]; registerCodeFix({ - errorCodes: errorCodes7, - getCodeActions: function getCodeActionsToAddNameToNamelessParameter(context) { - const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => makeChange7(t, context.sourceFile, context.span.start)); - return [createCodeFixAction(fixId7, changes, Diagnostics.Add_parameter_name, fixId7, Diagnostics.Add_names_to_all_parameters_without_names)]; + errorCodes: errorCodes26, + fixIds: [fixIdAddReturnStatement, fixRemoveBracesFromArrowFunctionBody, fixIdWrapTheBlockWithParen], + getCodeActions: function getCodeActionsToCorrectReturnValue(context) { + const { program, sourceFile, span: { start }, errorCode } = context; + const info = getInfo9(program.getTypeChecker(), sourceFile, start, errorCode); + if (!info) + return void 0; + if (info.kind === 0 /* MissingReturnStatement */) { + return append( + [getActionForfixAddReturnStatement(context, info.expression, info.statement)], + isArrowFunction(info.declaration) ? getActionForFixRemoveBracesFromArrowFunctionBody(context, info.declaration, info.expression, info.commentSource) : void 0 + ); + } else { + return [getActionForfixWrapTheBlockWithParen(context, info.declaration, info.expression)]; + } }, - fixIds: [fixId7], - getAllCodeActions: (context) => codeFixAll(context, errorCodes7, (changes, diag2) => makeChange7(changes, diag2.file, diag2.start)) + getAllCodeActions: (context) => codeFixAll(context, errorCodes26, (changes, diag2) => { + const info = getInfo9(context.program.getTypeChecker(), diag2.file, diag2.start, diag2.code); + if (!info) + return void 0; + switch (context.fixId) { + case fixIdAddReturnStatement: + addReturnStatement(changes, diag2.file, info.expression, info.statement); + break; + case fixRemoveBracesFromArrowFunctionBody: + if (!isArrowFunction(info.declaration)) + return void 0; + removeBlockBodyBrace( + changes, + diag2.file, + info.declaration, + info.expression, + info.commentSource, + /*withParen*/ + false + ); + break; + case fixIdWrapTheBlockWithParen: + if (!isArrowFunction(info.declaration)) + return void 0; + wrapBlockWithParen(changes, diag2.file, info.declaration, info.expression); + break; + default: + Debug.fail(JSON.stringify(context.fixId)); + } + }) }); } }); - // src/services/codefixes/addOptionalPropertyUndefined.ts - function getPropertiesToAdd(file, span, checker) { - var _a, _b; - const sourceTarget = getSourceTarget(getFixableErrorSpanExpression(file, span), checker); - if (!sourceTarget) { - return emptyArray; - } - const { source: sourceNode, target: targetNode } = sourceTarget; - const target = shouldUseParentTypeOfProperty(sourceNode, targetNode, checker) ? checker.getTypeAtLocation(targetNode.expression) : checker.getTypeAtLocation(targetNode); - if ((_b = (_a = target.symbol) == null ? void 0 : _a.declarations) == null ? void 0 : _b.some((d) => getSourceFileOfNode(d).fileName.match(/\.d\.ts$/))) { - return emptyArray; - } - return checker.getExactOptionalProperties(target); - } - function shouldUseParentTypeOfProperty(sourceNode, targetNode, checker) { - return isPropertyAccessExpression(targetNode) && !!checker.getExactOptionalProperties(checker.getTypeAtLocation(targetNode.expression)).length && checker.getTypeAtLocation(sourceNode) === checker.getUndefinedType(); - } - function getSourceTarget(errorNode, checker) { + // src/services/codefixes/fixAddMissingMember.ts + function getInfo10(sourceFile, tokenPos, errorCode, checker, program) { var _a; - if (!errorNode) { - return void 0; - } else if (isBinaryExpression(errorNode.parent) && errorNode.parent.operatorToken.kind === 64 /* EqualsToken */) { - return { source: errorNode.parent.right, target: errorNode.parent.left }; - } else if (isVariableDeclaration(errorNode.parent) && errorNode.parent.initializer) { - return { source: errorNode.parent.initializer, target: errorNode.parent.name }; - } else if (isCallExpression(errorNode.parent)) { - const n = checker.getSymbolAtLocation(errorNode.parent.expression); - if (!(n == null ? void 0 : n.valueDeclaration) || !isFunctionLikeKind(n.valueDeclaration.kind)) + const token = getTokenAtPosition(sourceFile, tokenPos); + const parent2 = token.parent; + if (errorCode === Diagnostics.Argument_of_type_0_is_not_assignable_to_parameter_of_type_1.code) { + if (!(token.kind === 19 /* OpenBraceToken */ && isObjectLiteralExpression(parent2) && isCallExpression(parent2.parent))) return void 0; - if (!isExpression(errorNode)) + const argIndex = findIndex(parent2.parent.arguments, (arg) => arg === parent2); + if (argIndex < 0) return void 0; - const i = errorNode.parent.arguments.indexOf(errorNode); - if (i === -1) + const signature = checker.getResolvedSignature(parent2.parent); + if (!(signature && signature.declaration && signature.parameters[argIndex])) return void 0; - const name = n.valueDeclaration.parameters[i].name; - if (isIdentifier(name)) - return { source: errorNode, target: name }; - } else if (isPropertyAssignment(errorNode.parent) && isIdentifier(errorNode.parent.name) || isShorthandPropertyAssignment(errorNode.parent)) { - const parentTarget = getSourceTarget(errorNode.parent.parent, checker); - if (!parentTarget) + const param = signature.parameters[argIndex].valueDeclaration; + if (!(param && isParameter(param) && isIdentifier(param.name))) return void 0; - const prop = checker.getPropertyOfType(checker.getTypeAtLocation(parentTarget.target), errorNode.parent.name.text); - const declaration = (_a = prop == null ? void 0 : prop.declarations) == null ? void 0 : _a[0]; - if (!declaration) + const properties = arrayFrom(checker.getUnmatchedProperties( + checker.getTypeAtLocation(parent2), + checker.getParameterType(signature, argIndex), + /*requireOptionalProperties*/ + false, + /*matchDiscriminantProperties*/ + false + )); + if (!length(properties)) return void 0; - return { - source: isPropertyAssignment(errorNode.parent) ? errorNode.parent.initializer : errorNode.parent.name, - target: declaration - }; + return { kind: 3 /* ObjectLiteral */, token: param.name, properties, parentDeclaration: parent2 }; } - return void 0; - } - function addUndefinedToOptionalProperty(changes, toAdd) { - for (const add of toAdd) { - const d = add.valueDeclaration; - if (d && (isPropertySignature(d) || isPropertyDeclaration(d)) && d.type) { - const t = factory.createUnionTypeNode([ - ...d.type.kind === 191 /* UnionType */ ? d.type.types : [d.type], - factory.createTypeReferenceNode("undefined") - ]); - changes.replaceNode(d.getSourceFile(), d.type, t); + if (!isMemberName(token)) + return void 0; + if (isIdentifier(token) && hasInitializer(parent2) && parent2.initializer && isObjectLiteralExpression(parent2.initializer)) { + const targetType = checker.getContextualType(token) || checker.getTypeAtLocation(token); + const properties = arrayFrom(checker.getUnmatchedProperties( + checker.getTypeAtLocation(parent2.initializer), + targetType, + /*requireOptionalProperties*/ + false, + /*matchDiscriminantProperties*/ + false + )); + if (!length(properties)) + return void 0; + return { kind: 3 /* ObjectLiteral */, token, properties, parentDeclaration: parent2.initializer }; + } + if (isIdentifier(token) && isJsxOpeningLikeElement(token.parent)) { + const target = getEmitScriptTarget(program.getCompilerOptions()); + const attributes = getUnmatchedAttributes(checker, target, token.parent); + if (!length(attributes)) + return void 0; + return { kind: 4 /* JsxAttributes */, token, attributes, parentDeclaration: token.parent }; + } + if (isIdentifier(token)) { + const type = (_a = checker.getContextualType(token)) == null ? void 0 : _a.getNonNullableType(); + if (type && getObjectFlags(type) & 16 /* Anonymous */) { + const signature = firstOrUndefined(checker.getSignaturesOfType(type, 0 /* Call */)); + if (signature === void 0) + return void 0; + return { kind: 5 /* Signature */, token, signature, sourceFile, parentDeclaration: findScope(token) }; + } + if (isCallExpression(parent2) && parent2.expression === token) { + return { kind: 2 /* Function */, token, call: parent2, sourceFile, modifierFlags: 0 /* None */, parentDeclaration: findScope(token) }; } } - } - var addOptionalPropertyUndefined, errorCodes8; - var init_addOptionalPropertyUndefined = __esm({ - "src/services/codefixes/addOptionalPropertyUndefined.ts"() { - "use strict"; - init_ts4(); - init_ts_codefix(); - addOptionalPropertyUndefined = "addOptionalPropertyUndefined"; - errorCodes8 = [ - Diagnostics.Type_0_is_not_assignable_to_type_1_with_exactOptionalPropertyTypes_Colon_true_Consider_adding_undefined_to_the_type_of_the_target.code, - Diagnostics.Type_0_is_not_assignable_to_type_1_with_exactOptionalPropertyTypes_Colon_true_Consider_adding_undefined_to_the_types_of_the_target_s_properties.code, - Diagnostics.Argument_of_type_0_is_not_assignable_to_parameter_of_type_1_with_exactOptionalPropertyTypes_Colon_true_Consider_adding_undefined_to_the_types_of_the_target_s_properties.code - ]; - registerCodeFix({ - errorCodes: errorCodes8, - getCodeActions(context) { - const typeChecker = context.program.getTypeChecker(); - const toAdd = getPropertiesToAdd(context.sourceFile, context.span, typeChecker); - if (!toAdd.length) { - return void 0; - } - const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => addUndefinedToOptionalProperty(t, toAdd)); - return [createCodeFixActionWithoutFixAll(addOptionalPropertyUndefined, changes, Diagnostics.Add_undefined_to_optional_property_type)]; - }, - fixIds: [addOptionalPropertyUndefined] - }); + if (!isPropertyAccessExpression(parent2)) + return void 0; + const leftExpressionType = skipConstraint(checker.getTypeAtLocation(parent2.expression)); + const symbol = leftExpressionType.symbol; + if (!symbol || !symbol.declarations) + return void 0; + if (isIdentifier(token) && isCallExpression(parent2.parent)) { + const moduleDeclaration = find(symbol.declarations, isModuleDeclaration); + const moduleDeclarationSourceFile = moduleDeclaration == null ? void 0 : moduleDeclaration.getSourceFile(); + if (moduleDeclaration && moduleDeclarationSourceFile && !isSourceFileFromLibrary(program, moduleDeclarationSourceFile)) { + return { kind: 2 /* Function */, token, call: parent2.parent, sourceFile, modifierFlags: 32 /* Export */, parentDeclaration: moduleDeclaration }; + } + const moduleSourceFile = find(symbol.declarations, isSourceFile); + if (sourceFile.commonJsModuleIndicator) + return void 0; + if (moduleSourceFile && !isSourceFileFromLibrary(program, moduleSourceFile)) { + return { kind: 2 /* Function */, token, call: parent2.parent, sourceFile: moduleSourceFile, modifierFlags: 32 /* Export */, parentDeclaration: moduleSourceFile }; + } } - }); - - // src/services/codefixes/annotateWithTypeFromJSDoc.ts - function getDeclaration(file, pos) { - const name = getTokenAtPosition(file, pos); - return tryCast(isParameter(name.parent) ? name.parent.parent : name.parent, parameterShouldGetTypeFromJSDoc); + const classDeclaration = find(symbol.declarations, isClassLike); + if (!classDeclaration && isPrivateIdentifier(token)) + return void 0; + const declaration = classDeclaration || find(symbol.declarations, (d) => isInterfaceDeclaration(d) || isTypeLiteralNode(d)); + if (declaration && !isSourceFileFromLibrary(program, declaration.getSourceFile())) { + const makeStatic = !isTypeLiteralNode(declaration) && (leftExpressionType.target || leftExpressionType) !== checker.getDeclaredTypeOfSymbol(symbol); + if (makeStatic && (isPrivateIdentifier(token) || isInterfaceDeclaration(declaration))) + return void 0; + const declSourceFile = declaration.getSourceFile(); + const modifierFlags = isTypeLiteralNode(declaration) ? 0 /* None */ : (makeStatic ? 256 /* Static */ : 0 /* None */) | (startsWithUnderscore(token.text) ? 2 /* Private */ : 0 /* None */); + const isJSFile = isSourceFileJS(declSourceFile); + const call = tryCast(parent2.parent, isCallExpression); + return { kind: 0 /* TypeLikeDeclaration */, token, call, modifierFlags, parentDeclaration: declaration, declSourceFile, isJSFile }; + } + const enumDeclaration = find(symbol.declarations, isEnumDeclaration); + if (enumDeclaration && !(leftExpressionType.flags & 1056 /* EnumLike */) && !isPrivateIdentifier(token) && !isSourceFileFromLibrary(program, enumDeclaration.getSourceFile())) { + return { kind: 1 /* Enum */, token, parentDeclaration: enumDeclaration }; + } + return void 0; } - function parameterShouldGetTypeFromJSDoc(node) { - return isDeclarationWithType(node) && hasUsableJSDoc(node); + function getActionsForMissingMemberDeclaration(context, info) { + return info.isJSFile ? singleElementArray(createActionForAddMissingMemberInJavascriptFile(context, info)) : createActionsForAddMissingMemberInTypeScriptFile(context, info); } - function hasUsableJSDoc(decl) { - return isFunctionLikeDeclaration(decl) ? decl.parameters.some(hasUsableJSDoc) || !decl.type && !!getJSDocReturnType(decl) : !decl.type && !!getJSDocType(decl); + function createActionForAddMissingMemberInJavascriptFile(context, { parentDeclaration, declSourceFile, modifierFlags, token }) { + if (isInterfaceDeclaration(parentDeclaration) || isTypeLiteralNode(parentDeclaration)) { + return void 0; + } + const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => addMissingMemberInJs(t, declSourceFile, parentDeclaration, token, !!(modifierFlags & 256 /* Static */))); + if (changes.length === 0) { + return void 0; + } + const diagnostic = modifierFlags & 256 /* Static */ ? Diagnostics.Initialize_static_property_0 : isPrivateIdentifier(token) ? Diagnostics.Declare_a_private_field_named_0 : Diagnostics.Initialize_property_0_in_the_constructor; + return createCodeFixAction(fixMissingMember, changes, [diagnostic, token.text], fixMissingMember, Diagnostics.Add_all_missing_members); } - function doChange8(changes, sourceFile, decl) { - if (isFunctionLikeDeclaration(decl) && (getJSDocReturnType(decl) || decl.parameters.some((p) => !!getJSDocType(p)))) { - if (!decl.typeParameters) { - const typeParameters = getJSDocTypeParameterDeclarations(decl); - if (typeParameters.length) - changes.insertTypeParameters(sourceFile, decl, typeParameters); - } - const needParens = isArrowFunction(decl) && !findChildOfKind(decl, 21 /* OpenParenToken */, sourceFile); - if (needParens) - changes.insertNodeBefore(sourceFile, first(decl.parameters), factory.createToken(21 /* OpenParenToken */)); - for (const param of decl.parameters) { - if (!param.type) { - const paramType = getJSDocType(param); - if (paramType) - changes.tryInsertTypeAnnotation(sourceFile, param, visitNode(paramType, transformJSDocType, isTypeNode)); - } + function addMissingMemberInJs(changeTracker, sourceFile, classDeclaration, token, makeStatic) { + const tokenName = token.text; + if (makeStatic) { + if (classDeclaration.kind === 231 /* ClassExpression */) { + return; } - if (needParens) - changes.insertNodeAfter(sourceFile, last(decl.parameters), factory.createToken(22 /* CloseParenToken */)); - if (!decl.type) { - const returnType = getJSDocReturnType(decl); - if (returnType) - changes.tryInsertTypeAnnotation(sourceFile, decl, visitNode(returnType, transformJSDocType, isTypeNode)); + const className = classDeclaration.name.getText(); + const staticInitialization = initializePropertyToUndefined(factory.createIdentifier(className), tokenName); + changeTracker.insertNodeAfter(sourceFile, classDeclaration, staticInitialization); + } else if (isPrivateIdentifier(token)) { + const property = factory.createPropertyDeclaration( + /*modifiers*/ + void 0, + tokenName, + /*questionOrExclamationToken*/ + void 0, + /*type*/ + void 0, + /*initializer*/ + void 0 + ); + const lastProp = getNodeToInsertPropertyAfter(classDeclaration); + if (lastProp) { + changeTracker.insertNodeAfter(sourceFile, lastProp, property); + } else { + changeTracker.insertMemberAtStart(sourceFile, classDeclaration, property); } } else { - const jsdocType = Debug.checkDefined(getJSDocType(decl), "A JSDocType for this declaration should exist"); - Debug.assert(!decl.type, "The JSDocType decl should have a type"); - changes.tryInsertTypeAnnotation(sourceFile, decl, visitNode(jsdocType, transformJSDocType, isTypeNode)); + const classConstructor = getFirstConstructorWithBody(classDeclaration); + if (!classConstructor) { + return; + } + const propertyInitialization = initializePropertyToUndefined(factory.createThis(), tokenName); + changeTracker.insertNodeAtConstructorEnd(sourceFile, classConstructor, propertyInitialization); } } - function isDeclarationWithType(node) { - return isFunctionLikeDeclaration(node) || node.kind === 259 /* VariableDeclaration */ || node.kind === 170 /* PropertySignature */ || node.kind === 171 /* PropertyDeclaration */; + function initializePropertyToUndefined(obj, propertyName) { + return factory.createExpressionStatement(factory.createAssignment(factory.createPropertyAccessExpression(obj, propertyName), createUndefined())); } - function transformJSDocType(node) { - switch (node.kind) { - case 318 /* JSDocAllType */: - case 319 /* JSDocUnknownType */: - return factory.createTypeReferenceNode("any", emptyArray); - case 322 /* JSDocOptionalType */: - return transformJSDocOptionalType(node); - case 321 /* JSDocNonNullableType */: - return transformJSDocType(node.type); - case 320 /* JSDocNullableType */: - return transformJSDocNullableType(node); - case 324 /* JSDocVariadicType */: - return transformJSDocVariadicType(node); - case 323 /* JSDocFunctionType */: - return transformJSDocFunctionType(node); - case 182 /* TypeReference */: - return transformJSDocTypeReference(node); - case 328 /* JSDocTypeLiteral */: - return transformJSDocTypeLiteral(node); - default: - const visited = visitEachChild(node, transformJSDocType, nullTransformationContext); - setEmitFlags(visited, 1 /* SingleLine */); - return visited; + function createActionsForAddMissingMemberInTypeScriptFile(context, { parentDeclaration, declSourceFile, modifierFlags, token }) { + const memberName = token.text; + const isStatic2 = modifierFlags & 256 /* Static */; + const typeNode = getTypeNode2(context.program.getTypeChecker(), parentDeclaration, token); + const addPropertyDeclarationChanges = (modifierFlags2) => ts_textChanges_exports.ChangeTracker.with(context, (t) => addPropertyDeclaration(t, declSourceFile, parentDeclaration, memberName, typeNode, modifierFlags2)); + const actions2 = [createCodeFixAction(fixMissingMember, addPropertyDeclarationChanges(modifierFlags & 256 /* Static */), [isStatic2 ? Diagnostics.Declare_static_property_0 : Diagnostics.Declare_property_0, memberName], fixMissingMember, Diagnostics.Add_all_missing_members)]; + if (isStatic2 || isPrivateIdentifier(token)) { + return actions2; } + if (modifierFlags & 2 /* Private */) { + actions2.unshift(createCodeFixActionWithoutFixAll(fixMissingMember, addPropertyDeclarationChanges(2 /* Private */), [Diagnostics.Declare_private_property_0, memberName])); + } + actions2.push(createAddIndexSignatureAction(context, declSourceFile, parentDeclaration, token.text, typeNode)); + return actions2; } - function transformJSDocTypeLiteral(node) { - const typeNode = factory.createTypeLiteralNode(map(node.jsDocPropertyTags, (tag) => factory.createPropertySignature( + function getTypeNode2(checker, node, token) { + let typeNode; + if (token.parent.parent.kind === 226 /* BinaryExpression */) { + const binaryExpression = token.parent.parent; + const otherExpression = token.parent === binaryExpression.left ? binaryExpression.right : binaryExpression.left; + const widenedType = checker.getWidenedType(checker.getBaseTypeOfLiteralType(checker.getTypeAtLocation(otherExpression))); + typeNode = checker.typeToTypeNode(widenedType, node, 1 /* NoTruncation */); + } else { + const contextualType = checker.getContextualType(token.parent); + typeNode = contextualType ? checker.typeToTypeNode( + contextualType, + /*enclosingDeclaration*/ + void 0, + 1 /* NoTruncation */ + ) : void 0; + } + return typeNode || factory.createKeywordTypeNode(133 /* AnyKeyword */); + } + function addPropertyDeclaration(changeTracker, sourceFile, node, tokenName, typeNode, modifierFlags) { + const modifiers = modifierFlags ? factory.createNodeArray(factory.createModifiersFromModifierFlags(modifierFlags)) : void 0; + const property = isClassLike(node) ? factory.createPropertyDeclaration( + modifiers, + tokenName, + /*questionOrExclamationToken*/ + void 0, + typeNode, + /*initializer*/ + void 0 + ) : factory.createPropertySignature( /*modifiers*/ void 0, - isIdentifier(tag.name) ? tag.name : tag.name.right, - isOptionalJSDocPropertyLikeTag(tag) ? factory.createToken(58 /* QuestionToken */) : void 0, - tag.typeExpression && visitNode(tag.typeExpression.type, transformJSDocType, isTypeNode) || factory.createKeywordTypeNode(133 /* AnyKeyword */) - ))); - setEmitFlags(typeNode, 1 /* SingleLine */); - return typeNode; - } - function transformJSDocOptionalType(node) { - return factory.createUnionTypeNode([visitNode(node.type, transformJSDocType, isTypeNode), factory.createTypeReferenceNode("undefined", emptyArray)]); - } - function transformJSDocNullableType(node) { - return factory.createUnionTypeNode([visitNode(node.type, transformJSDocType, isTypeNode), factory.createTypeReferenceNode("null", emptyArray)]); - } - function transformJSDocVariadicType(node) { - return factory.createArrayTypeNode(visitNode(node.type, transformJSDocType, isTypeNode)); - } - function transformJSDocFunctionType(node) { - return factory.createFunctionTypeNode(emptyArray, node.parameters.map(transformJSDocParameter), node.type ?? factory.createKeywordTypeNode(133 /* AnyKeyword */)); - } - function transformJSDocParameter(node) { - const index = node.parent.parameters.indexOf(node); - const isRest = node.type.kind === 324 /* JSDocVariadicType */ && index === node.parent.parameters.length - 1; - const name = node.name || (isRest ? "rest" : "arg" + index); - const dotdotdot = isRest ? factory.createToken(26 /* DotDotDotToken */) : node.dotDotDotToken; - return factory.createParameterDeclaration(node.modifiers, dotdotdot, name, node.questionToken, visitNode(node.type, transformJSDocType, isTypeNode), node.initializer); + tokenName, + /*questionToken*/ + void 0, + typeNode + ); + const lastProp = getNodeToInsertPropertyAfter(node); + if (lastProp) { + changeTracker.insertNodeAfter(sourceFile, lastProp, property); + } else { + changeTracker.insertMemberAtStart(sourceFile, node, property); + } } - function transformJSDocTypeReference(node) { - let name = node.typeName; - let args = node.typeArguments; - if (isIdentifier(node.typeName)) { - if (isJSDocIndexSignature(node)) { - return transformJSDocIndexSignature(node); - } - let text = node.typeName.text; - switch (node.typeName.text) { - case "String": - case "Boolean": - case "Object": - case "Number": - text = text.toLowerCase(); - break; - case "array": - case "date": - case "promise": - text = text[0].toUpperCase() + text.slice(1); - break; - } - name = factory.createIdentifier(text); - if ((text === "Array" || text === "Promise") && !node.typeArguments) { - args = factory.createNodeArray([factory.createTypeReferenceNode("any", emptyArray)]); - } else { - args = visitNodes2(node.typeArguments, transformJSDocType, isTypeNode); - } + function getNodeToInsertPropertyAfter(node) { + let res; + for (const member of node.members) { + if (!isPropertyDeclaration(member)) + break; + res = member; } - return factory.createTypeReferenceNode(name, args); + return res; } - function transformJSDocIndexSignature(node) { - const index = factory.createParameterDeclaration( + function createAddIndexSignatureAction(context, sourceFile, node, tokenName, typeNode) { + const stringTypeNode = factory.createKeywordTypeNode(154 /* StringKeyword */); + const indexingParameter = factory.createParameterDeclaration( /*modifiers*/ void 0, /*dotDotDotToken*/ void 0, - node.typeArguments[0].kind === 150 /* NumberKeyword */ ? "n" : "s", + "x", /*questionToken*/ void 0, - factory.createTypeReferenceNode(node.typeArguments[0].kind === 150 /* NumberKeyword */ ? "number" : "string", []), + stringTypeNode, /*initializer*/ void 0 ); - const indexSignature = factory.createTypeLiteralNode([factory.createIndexSignature( + const indexSignature = factory.createIndexSignature( /*modifiers*/ void 0, - [index], - node.typeArguments[1] - )]); - setEmitFlags(indexSignature, 1 /* SingleLine */); - return indexSignature; + [indexingParameter], + typeNode + ); + const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => t.insertMemberAtStart(sourceFile, node, indexSignature)); + return createCodeFixActionWithoutFixAll(fixMissingMember, changes, [Diagnostics.Add_index_signature_for_property_0, tokenName]); } - var fixId8, errorCodes9; - var init_annotateWithTypeFromJSDoc = __esm({ - "src/services/codefixes/annotateWithTypeFromJSDoc.ts"() { - "use strict"; - init_ts4(); - init_ts_codefix(); - fixId8 = "annotateWithTypeFromJSDoc"; - errorCodes9 = [Diagnostics.JSDoc_types_may_be_moved_to_TypeScript_types.code]; - registerCodeFix({ - errorCodes: errorCodes9, - getCodeActions(context) { - const decl = getDeclaration(context.sourceFile, context.span.start); - if (!decl) - return; - const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange8(t, context.sourceFile, decl)); - return [createCodeFixAction(fixId8, changes, Diagnostics.Annotate_with_type_from_JSDoc, fixId8, Diagnostics.Annotate_everything_with_types_from_JSDoc)]; - }, - fixIds: [fixId8], - getAllCodeActions: (context) => codeFixAll(context, errorCodes9, (changes, diag2) => { - const decl = getDeclaration(diag2.file, diag2.start); - if (decl) - doChange8(changes, diag2.file, decl); - }) - }); - } - }); - - // src/services/codefixes/convertFunctionToEs6Class.ts - function doChange9(changes, sourceFile, position, checker, preferences, compilerOptions) { - const ctorSymbol = checker.getSymbolAtLocation(getTokenAtPosition(sourceFile, position)); - if (!ctorSymbol || !ctorSymbol.valueDeclaration || !(ctorSymbol.flags & (16 /* Function */ | 3 /* Variable */))) { + function getActionsForMissingMethodDeclaration(context, info) { + const { parentDeclaration, declSourceFile, modifierFlags, token, call } = info; + if (call === void 0) { return void 0; } - const ctorDeclaration = ctorSymbol.valueDeclaration; - if (isFunctionDeclaration(ctorDeclaration) || isFunctionExpression(ctorDeclaration)) { - changes.replaceNode(sourceFile, ctorDeclaration, createClassFromFunction(ctorDeclaration)); - } else if (isVariableDeclaration(ctorDeclaration)) { - const classDeclaration = createClassFromVariableDeclaration(ctorDeclaration); - if (!classDeclaration) { - return void 0; - } - const ancestor = ctorDeclaration.parent.parent; - if (isVariableDeclarationList(ctorDeclaration.parent) && ctorDeclaration.parent.declarations.length > 1) { - changes.delete(sourceFile, ctorDeclaration); - changes.insertNodeAfter(sourceFile, ancestor, classDeclaration); - } else { - changes.replaceNode(sourceFile, ancestor, classDeclaration); - } + const methodName = token.text; + const addMethodDeclarationChanges = (modifierFlags2) => ts_textChanges_exports.ChangeTracker.with(context, (t) => addMethodDeclaration(context, t, call, token, modifierFlags2, parentDeclaration, declSourceFile)); + const actions2 = [createCodeFixAction(fixMissingMember, addMethodDeclarationChanges(modifierFlags & 256 /* Static */), [modifierFlags & 256 /* Static */ ? Diagnostics.Declare_static_method_0 : Diagnostics.Declare_method_0, methodName], fixMissingMember, Diagnostics.Add_all_missing_members)]; + if (modifierFlags & 2 /* Private */) { + actions2.unshift(createCodeFixActionWithoutFixAll(fixMissingMember, addMethodDeclarationChanges(2 /* Private */), [Diagnostics.Declare_private_method_0, methodName])); } - function createClassElementsFromSymbol(symbol) { - const memberElements = []; - if (symbol.exports) { - symbol.exports.forEach((member) => { - if (member.name === "prototype" && member.declarations) { - const firstDeclaration = member.declarations[0]; - if (member.declarations.length === 1 && isPropertyAccessExpression(firstDeclaration) && isBinaryExpression(firstDeclaration.parent) && firstDeclaration.parent.operatorToken.kind === 64 /* EqualsToken */ && isObjectLiteralExpression(firstDeclaration.parent.right)) { - const prototypes = firstDeclaration.parent.right; - createClassElement( - prototypes.symbol, - /*modifiers*/ - void 0, - memberElements - ); - } - } else { - createClassElement(member, [factory.createToken(126 /* StaticKeyword */)], memberElements); - } - }); - } - if (symbol.members) { - symbol.members.forEach((member, key) => { - var _a, _b, _c, _d; - if (key === "constructor" && member.valueDeclaration) { - const prototypeAssignment = (_d = (_c = (_b = (_a = symbol.exports) == null ? void 0 : _a.get("prototype")) == null ? void 0 : _b.declarations) == null ? void 0 : _c[0]) == null ? void 0 : _d.parent; - if (prototypeAssignment && isBinaryExpression(prototypeAssignment) && isObjectLiteralExpression(prototypeAssignment.right) && some(prototypeAssignment.right.properties, isConstructorAssignment)) { - } else { - changes.delete(sourceFile, member.valueDeclaration.parent); - } - return; - } - createClassElement( - member, - /*modifiers*/ - void 0, - memberElements - ); - }); - } - return memberElements; - function shouldConvertDeclaration(_target, source) { - if (isAccessExpression(_target)) { - if (isPropertyAccessExpression(_target) && isConstructorAssignment(_target)) - return true; - return isFunctionLike(source); - } else { - return every(_target.properties, (property) => { - if (isMethodDeclaration(property) || isGetOrSetAccessorDeclaration(property)) - return true; - if (isPropertyAssignment(property) && isFunctionExpression(property.initializer) && !!property.name) - return true; - if (isConstructorAssignment(property)) - return true; - return false; - }); - } - } - function createClassElement(symbol2, modifiers, members) { - if (!(symbol2.flags & 8192 /* Method */) && !(symbol2.flags & 4096 /* ObjectLiteral */)) { - return; - } - const memberDeclaration = symbol2.valueDeclaration; - const assignmentBinaryExpression = memberDeclaration.parent; - const assignmentExpr = assignmentBinaryExpression.right; - if (!shouldConvertDeclaration(memberDeclaration, assignmentExpr)) { - return; - } - if (some(members, (m) => { - const name = getNameOfDeclaration(m); - if (name && isIdentifier(name) && idText(name) === symbolName(symbol2)) { - return true; - } - return false; - })) { - return; - } - const nodeToDelete = assignmentBinaryExpression.parent && assignmentBinaryExpression.parent.kind === 243 /* ExpressionStatement */ ? assignmentBinaryExpression.parent : assignmentBinaryExpression; - changes.delete(sourceFile, nodeToDelete); - if (!assignmentExpr) { - members.push(factory.createPropertyDeclaration( - modifiers, - symbol2.name, - /*questionOrExclamationToken*/ - void 0, - /*type*/ - void 0, - /*initializer*/ - void 0 - )); - return; - } - if (isAccessExpression(memberDeclaration) && (isFunctionExpression(assignmentExpr) || isArrowFunction(assignmentExpr))) { - const quotePreference = getQuotePreference(sourceFile, preferences); - const name = tryGetPropertyName(memberDeclaration, compilerOptions, quotePreference); - if (name) { - createFunctionLikeExpressionMember(members, assignmentExpr, name); - } - return; - } else if (isObjectLiteralExpression(assignmentExpr)) { - forEach( - assignmentExpr.properties, - (property) => { - if (isMethodDeclaration(property) || isGetOrSetAccessorDeclaration(property)) { - members.push(property); - } - if (isPropertyAssignment(property) && isFunctionExpression(property.initializer)) { - createFunctionLikeExpressionMember(members, property.initializer, property.name); - } - if (isConstructorAssignment(property)) - return; - return; - } - ); - return; - } else { - if (isSourceFileJS(sourceFile)) - return; - if (!isPropertyAccessExpression(memberDeclaration)) - return; - const prop = factory.createPropertyDeclaration( - modifiers, - memberDeclaration.name, - /*questionOrExclamationToken*/ - void 0, - /*type*/ - void 0, - assignmentExpr - ); - copyLeadingComments(assignmentBinaryExpression.parent, prop, sourceFile); - members.push(prop); - return; - } - function createFunctionLikeExpressionMember(members2, expression, name) { - if (isFunctionExpression(expression)) - return createFunctionExpressionMember(members2, expression, name); - else - return createArrowFunctionExpressionMember(members2, expression, name); - } - function createFunctionExpressionMember(members2, functionExpression, name) { - const fullModifiers = concatenate(modifiers, getModifierKindFromSource(functionExpression, 134 /* AsyncKeyword */)); - const method = factory.createMethodDeclaration( - fullModifiers, - /*asteriskToken*/ - void 0, - name, - /*questionToken*/ - void 0, - /*typeParameters*/ - void 0, - functionExpression.parameters, - /*type*/ - void 0, - functionExpression.body - ); - copyLeadingComments(assignmentBinaryExpression, method, sourceFile); - members2.push(method); - return; - } - function createArrowFunctionExpressionMember(members2, arrowFunction, name) { - const arrowFunctionBody = arrowFunction.body; - let bodyBlock; - if (arrowFunctionBody.kind === 240 /* Block */) { - bodyBlock = arrowFunctionBody; - } else { - bodyBlock = factory.createBlock([factory.createReturnStatement(arrowFunctionBody)]); - } - const fullModifiers = concatenate(modifiers, getModifierKindFromSource(arrowFunction, 134 /* AsyncKeyword */)); - const method = factory.createMethodDeclaration( - fullModifiers, - /*asteriskToken*/ - void 0, - name, - /*questionToken*/ - void 0, - /*typeParameters*/ - void 0, - arrowFunction.parameters, - /*type*/ - void 0, - bodyBlock - ); - copyLeadingComments(assignmentBinaryExpression, method, sourceFile); - members2.push(method); - } - } + return actions2; + } + function addMethodDeclaration(context, changes, callExpression, name, modifierFlags, parentDeclaration, sourceFile) { + const importAdder = createImportAdder(sourceFile, context.program, context.preferences, context.host); + const kind = isClassLike(parentDeclaration) ? 174 /* MethodDeclaration */ : 173 /* MethodSignature */; + const signatureDeclaration = createSignatureDeclarationFromCallExpression(kind, context, importAdder, callExpression, name, modifierFlags, parentDeclaration); + const containingMethodDeclaration = tryGetContainingMethodDeclaration(parentDeclaration, callExpression); + if (containingMethodDeclaration) { + changes.insertNodeAfter(sourceFile, containingMethodDeclaration, signatureDeclaration); + } else { + changes.insertMemberAtStart(sourceFile, parentDeclaration, signatureDeclaration); } - function createClassFromVariableDeclaration(node) { - const initializer = node.initializer; - if (!initializer || !isFunctionExpression(initializer) || !isIdentifier(node.name)) { - return void 0; - } - const memberElements = createClassElementsFromSymbol(node.symbol); - if (initializer.body) { - memberElements.unshift(factory.createConstructorDeclaration( - /*modifiers*/ - void 0, - initializer.parameters, - initializer.body - )); + importAdder.writeFixes(changes); + } + function addEnumMemberDeclaration(changes, checker, { token, parentDeclaration }) { + const hasStringInitializer = some(parentDeclaration.members, (member) => { + const type = checker.getTypeAtLocation(member); + return !!(type && type.flags & 402653316 /* StringLike */); + }); + const enumMember = factory.createEnumMember(token, hasStringInitializer ? factory.createStringLiteral(token.text) : void 0); + changes.replaceNode( + parentDeclaration.getSourceFile(), + parentDeclaration, + factory.updateEnumDeclaration( + parentDeclaration, + parentDeclaration.modifiers, + parentDeclaration.name, + concatenate(parentDeclaration.members, singleElementArray(enumMember)) + ), + { + leadingTriviaOption: ts_textChanges_exports.LeadingTriviaOption.IncludeAll, + trailingTriviaOption: ts_textChanges_exports.TrailingTriviaOption.Exclude } - const modifiers = getModifierKindFromSource(node.parent.parent, 95 /* ExportKeyword */); - const cls = factory.createClassDeclaration( - modifiers, - node.name, - /*typeParameters*/ + ); + } + function addFunctionDeclaration(changes, context, info) { + const quotePreference = getQuotePreference(context.sourceFile, context.preferences); + const importAdder = createImportAdder(context.sourceFile, context.program, context.preferences, context.host); + const functionDeclaration = info.kind === 2 /* Function */ ? createSignatureDeclarationFromCallExpression(262 /* FunctionDeclaration */, context, importAdder, info.call, idText(info.token), info.modifierFlags, info.parentDeclaration) : createSignatureDeclarationFromSignature( + 262 /* FunctionDeclaration */, + context, + quotePreference, + info.signature, + createStubbedBody(Diagnostics.Function_not_implemented.message, quotePreference), + info.token, + /*modifiers*/ + void 0, + /*optional*/ + void 0, + /*enclosingDeclaration*/ + void 0, + importAdder + ); + if (functionDeclaration === void 0) { + Debug.fail("fixMissingFunctionDeclaration codefix got unexpected error."); + } + isReturnStatement(info.parentDeclaration) ? changes.insertNodeBefore( + info.sourceFile, + info.parentDeclaration, + functionDeclaration, + /*blankLineBetween*/ + true + ) : changes.insertNodeAtEndOfScope(info.sourceFile, info.parentDeclaration, functionDeclaration); + importAdder.writeFixes(changes); + } + function addJsxAttributes(changes, context, info) { + const importAdder = createImportAdder(context.sourceFile, context.program, context.preferences, context.host); + const quotePreference = getQuotePreference(context.sourceFile, context.preferences); + const checker = context.program.getTypeChecker(); + const jsxAttributesNode = info.parentDeclaration.attributes; + const hasSpreadAttribute = some(jsxAttributesNode.properties, isJsxSpreadAttribute); + const attrs = map(info.attributes, (attr) => { + const value = tryGetValueFromType(context, checker, importAdder, quotePreference, checker.getTypeOfSymbol(attr), info.parentDeclaration); + const name = factory.createIdentifier(attr.name); + const jsxAttribute = factory.createJsxAttribute(name, factory.createJsxExpression( + /*dotDotDotToken*/ void 0, - /*heritageClauses*/ + value + )); + setParent(name, jsxAttribute); + return jsxAttribute; + }); + const jsxAttributes = factory.createJsxAttributes(hasSpreadAttribute ? [...attrs, ...jsxAttributesNode.properties] : [...jsxAttributesNode.properties, ...attrs]); + const options = { prefix: jsxAttributesNode.pos === jsxAttributesNode.end ? " " : void 0 }; + changes.replaceNode(context.sourceFile, jsxAttributesNode, jsxAttributes, options); + importAdder.writeFixes(changes); + } + function addObjectLiteralProperties(changes, context, info) { + const importAdder = createImportAdder(context.sourceFile, context.program, context.preferences, context.host); + const quotePreference = getQuotePreference(context.sourceFile, context.preferences); + const target = getEmitScriptTarget(context.program.getCompilerOptions()); + const checker = context.program.getTypeChecker(); + const props = map(info.properties, (prop) => { + const initializer = tryGetValueFromType(context, checker, importAdder, quotePreference, checker.getTypeOfSymbol(prop), info.parentDeclaration); + return factory.createPropertyAssignment(createPropertyNameFromSymbol(prop, target, quotePreference, checker), initializer); + }); + const options = { + leadingTriviaOption: ts_textChanges_exports.LeadingTriviaOption.Exclude, + trailingTriviaOption: ts_textChanges_exports.TrailingTriviaOption.Exclude, + indentation: info.indentation + }; + changes.replaceNode(context.sourceFile, info.parentDeclaration, factory.createObjectLiteralExpression( + [...info.parentDeclaration.properties, ...props], + /*multiLine*/ + true + ), options); + importAdder.writeFixes(changes); + } + function tryGetValueFromType(context, checker, importAdder, quotePreference, type, enclosingDeclaration) { + if (type.flags & 3 /* AnyOrUnknown */) { + return createUndefined(); + } + if (type.flags & (4 /* String */ | 134217728 /* TemplateLiteral */)) { + return factory.createStringLiteral( + "", + /* isSingleQuote */ + quotePreference === 0 /* Single */ + ); + } + if (type.flags & 8 /* Number */) { + return factory.createNumericLiteral(0); + } + if (type.flags & 64 /* BigInt */) { + return factory.createBigIntLiteral("0n"); + } + if (type.flags & 16 /* Boolean */) { + return factory.createFalse(); + } + if (type.flags & 1056 /* EnumLike */) { + const enumMember = type.symbol.exports ? firstOrUndefinedIterator(type.symbol.exports.values()) : type.symbol; + const name = checker.symbolToExpression( + type.symbol.parent ? type.symbol.parent : type.symbol, + 111551 /* Value */, + /*enclosingDeclaration*/ void 0, - memberElements + /*flags*/ + void 0 ); - return cls; + return enumMember === void 0 || name === void 0 ? factory.createNumericLiteral(0) : factory.createPropertyAccessExpression(name, checker.symbolToString(enumMember)); } - function createClassFromFunction(node) { - const memberElements = createClassElementsFromSymbol(ctorSymbol); - if (node.body) { - memberElements.unshift(factory.createConstructorDeclaration( - /*modifiers*/ - void 0, - node.parameters, - node.body - )); - } - const modifiers = getModifierKindFromSource(node, 95 /* ExportKeyword */); - const cls = factory.createClassDeclaration( - modifiers, - node.name, - /*typeParameters*/ + if (type.flags & 256 /* NumberLiteral */) { + return factory.createNumericLiteral(type.value); + } + if (type.flags & 2048 /* BigIntLiteral */) { + return factory.createBigIntLiteral(type.value); + } + if (type.flags & 128 /* StringLiteral */) { + return factory.createStringLiteral( + type.value, + /* isSingleQuote */ + quotePreference === 0 /* Single */ + ); + } + if (type.flags & 512 /* BooleanLiteral */) { + return type === checker.getFalseType() || type === checker.getFalseType( + /*fresh*/ + true + ) ? factory.createFalse() : factory.createTrue(); + } + if (type.flags & 65536 /* Null */) { + return factory.createNull(); + } + if (type.flags & 1048576 /* Union */) { + const expression = firstDefined(type.types, (t) => tryGetValueFromType(context, checker, importAdder, quotePreference, t, enclosingDeclaration)); + return expression ?? createUndefined(); + } + if (checker.isArrayLikeType(type)) { + return factory.createArrayLiteralExpression(); + } + if (isObjectLiteralType(type)) { + const props = map(checker.getPropertiesOfType(type), (prop) => { + const initializer = tryGetValueFromType(context, checker, importAdder, quotePreference, checker.getTypeOfSymbol(prop), enclosingDeclaration); + return factory.createPropertyAssignment(prop.name, initializer); + }); + return factory.createObjectLiteralExpression( + props, + /*multiLine*/ + true + ); + } + if (getObjectFlags(type) & 16 /* Anonymous */) { + const decl = find(type.symbol.declarations || emptyArray, or(isFunctionTypeNode, isMethodSignature, isMethodDeclaration)); + if (decl === void 0) + return createUndefined(); + const signature = checker.getSignaturesOfType(type, 0 /* Call */); + if (signature === void 0) + return createUndefined(); + const func = createSignatureDeclarationFromSignature( + 218 /* FunctionExpression */, + context, + quotePreference, + signature[0], + createStubbedBody(Diagnostics.Function_not_implemented.message, quotePreference), + /*name*/ void 0, - /*heritageClauses*/ + /*modifiers*/ void 0, - memberElements + /*optional*/ + void 0, + /*enclosingDeclaration*/ + enclosingDeclaration, + importAdder + ); + return func ?? createUndefined(); + } + if (getObjectFlags(type) & 1 /* Class */) { + const classDeclaration = getClassLikeDeclarationOfSymbol(type.symbol); + if (classDeclaration === void 0 || hasAbstractModifier(classDeclaration)) + return createUndefined(); + const constructorDeclaration = getFirstConstructorWithBody(classDeclaration); + if (constructorDeclaration && length(constructorDeclaration.parameters)) + return createUndefined(); + return factory.createNewExpression( + factory.createIdentifier(type.symbol.name), + /*typeArguments*/ + void 0, + /*argumentsArray*/ + void 0 ); - return cls; } + return createUndefined(); } - function getModifierKindFromSource(source, kind) { - return canHaveModifiers(source) ? filter(source.modifiers, (modifier) => modifier.kind === kind) : void 0; + function createUndefined() { + return factory.createIdentifier("undefined"); } - function isConstructorAssignment(x) { - if (!x.name) - return false; - if (isIdentifier(x.name) && x.name.text === "constructor") - return true; - return false; + function isObjectLiteralType(type) { + return type.flags & 524288 /* Object */ && (getObjectFlags(type) & 128 /* ObjectLiteral */ || type.symbol && tryCast(singleOrUndefined(type.symbol.declarations), isTypeLiteralNode)); } - function tryGetPropertyName(node, compilerOptions, quotePreference) { - if (isPropertyAccessExpression(node)) { - return node.name; + function getUnmatchedAttributes(checker, target, source) { + const attrsType = checker.getContextualType(source.attributes); + if (attrsType === void 0) + return emptyArray; + const targetProps = attrsType.getProperties(); + if (!length(targetProps)) + return emptyArray; + const seenNames = /* @__PURE__ */ new Set(); + for (const sourceProp of source.attributes.properties) { + if (isJsxAttribute(sourceProp)) { + seenNames.add(getEscapedTextOfJsxAttributeName(sourceProp.name)); + } + if (isJsxSpreadAttribute(sourceProp)) { + const type = checker.getTypeAtLocation(sourceProp.expression); + for (const prop of type.getProperties()) { + seenNames.add(prop.escapedName); + } + } } - const propName = node.argumentExpression; - if (isNumericLiteral(propName)) { - return propName; + return filter(targetProps, (targetProp) => isIdentifierText(targetProp.name, target, 1 /* JSX */) && !(targetProp.flags & 16777216 /* Optional */ || getCheckFlags(targetProp) & 48 /* Partial */ || seenNames.has(targetProp.escapedName))); + } + function tryGetContainingMethodDeclaration(node, callExpression) { + if (isTypeLiteralNode(node)) { + return void 0; } - if (isStringLiteralLike(propName)) { - return isIdentifierText(propName.text, getEmitScriptTarget(compilerOptions)) ? factory.createIdentifier(propName.text) : isNoSubstitutionTemplateLiteral(propName) ? factory.createStringLiteral(propName.text, quotePreference === 0 /* Single */) : propName; + const declaration = findAncestor(callExpression, (n) => isMethodDeclaration(n) || isConstructorDeclaration(n)); + return declaration && declaration.parent === node ? declaration : void 0; + } + function createPropertyNameFromSymbol(symbol, target, quotePreference, checker) { + if (isTransientSymbol(symbol)) { + const prop = checker.symbolToNode( + symbol, + 111551 /* Value */, + /*enclosingDeclaration*/ + void 0, + 1073741824 /* WriteComputedProps */ + ); + if (prop && isComputedPropertyName(prop)) + return prop; + } + return createPropertyNameNodeForIdentifierOrLiteral( + symbol.name, + target, + quotePreference === 0 /* Single */, + /*stringNamed*/ + false, + /*isMethod*/ + false + ); + } + function findScope(node) { + if (findAncestor(node, isJsxExpression)) { + const returnStatement = findAncestor(node.parent, isReturnStatement); + if (returnStatement) + return returnStatement; + } + return getSourceFileOfNode(node); + } + var fixMissingMember, fixMissingProperties, fixMissingAttributes, fixMissingFunctionDeclaration, errorCodes27; + var init_fixAddMissingMember = __esm({ + "src/services/codefixes/fixAddMissingMember.ts"() { + "use strict"; + init_ts4(); + init_ts_codefix(); + fixMissingMember = "fixMissingMember"; + fixMissingProperties = "fixMissingProperties"; + fixMissingAttributes = "fixMissingAttributes"; + fixMissingFunctionDeclaration = "fixMissingFunctionDeclaration"; + errorCodes27 = [ + Diagnostics.Property_0_does_not_exist_on_type_1.code, + Diagnostics.Property_0_does_not_exist_on_type_1_Did_you_mean_2.code, + Diagnostics.Property_0_is_missing_in_type_1_but_required_in_type_2.code, + Diagnostics.Type_0_is_missing_the_following_properties_from_type_1_Colon_2.code, + Diagnostics.Type_0_is_missing_the_following_properties_from_type_1_Colon_2_and_3_more.code, + Diagnostics.Argument_of_type_0_is_not_assignable_to_parameter_of_type_1.code, + Diagnostics.Cannot_find_name_0.code + ]; + registerCodeFix({ + errorCodes: errorCodes27, + getCodeActions(context) { + const typeChecker = context.program.getTypeChecker(); + const info = getInfo10(context.sourceFile, context.span.start, context.errorCode, typeChecker, context.program); + if (!info) { + return void 0; + } + if (info.kind === 3 /* ObjectLiteral */) { + const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => addObjectLiteralProperties(t, context, info)); + return [createCodeFixAction(fixMissingProperties, changes, Diagnostics.Add_missing_properties, fixMissingProperties, Diagnostics.Add_all_missing_properties)]; + } + if (info.kind === 4 /* JsxAttributes */) { + const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => addJsxAttributes(t, context, info)); + return [createCodeFixAction(fixMissingAttributes, changes, Diagnostics.Add_missing_attributes, fixMissingAttributes, Diagnostics.Add_all_missing_attributes)]; + } + if (info.kind === 2 /* Function */ || info.kind === 5 /* Signature */) { + const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => addFunctionDeclaration(t, context, info)); + return [createCodeFixAction(fixMissingFunctionDeclaration, changes, [Diagnostics.Add_missing_function_declaration_0, info.token.text], fixMissingFunctionDeclaration, Diagnostics.Add_all_missing_function_declarations)]; + } + if (info.kind === 1 /* Enum */) { + const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => addEnumMemberDeclaration(t, context.program.getTypeChecker(), info)); + return [createCodeFixAction(fixMissingMember, changes, [Diagnostics.Add_missing_enum_member_0, info.token.text], fixMissingMember, Diagnostics.Add_all_missing_members)]; + } + return concatenate(getActionsForMissingMethodDeclaration(context, info), getActionsForMissingMemberDeclaration(context, info)); + }, + fixIds: [fixMissingMember, fixMissingFunctionDeclaration, fixMissingProperties, fixMissingAttributes], + getAllCodeActions: (context) => { + const { program, fixId: fixId52 } = context; + const checker = program.getTypeChecker(); + const seen = /* @__PURE__ */ new Map(); + const typeDeclToMembers = /* @__PURE__ */ new Map(); + return createCombinedCodeActions(ts_textChanges_exports.ChangeTracker.with(context, (changes) => { + eachDiagnostic(context, errorCodes27, (diag2) => { + const info = getInfo10(diag2.file, diag2.start, diag2.code, checker, context.program); + if (!info || !addToSeen(seen, getNodeId(info.parentDeclaration) + "#" + info.token.text)) { + return; + } + if (fixId52 === fixMissingFunctionDeclaration && (info.kind === 2 /* Function */ || info.kind === 5 /* Signature */)) { + addFunctionDeclaration(changes, context, info); + } else if (fixId52 === fixMissingProperties && info.kind === 3 /* ObjectLiteral */) { + addObjectLiteralProperties(changes, context, info); + } else if (fixId52 === fixMissingAttributes && info.kind === 4 /* JsxAttributes */) { + addJsxAttributes(changes, context, info); + } else { + if (info.kind === 1 /* Enum */) { + addEnumMemberDeclaration(changes, checker, info); + } + if (info.kind === 0 /* TypeLikeDeclaration */) { + const { parentDeclaration, token } = info; + const infos = getOrUpdate(typeDeclToMembers, parentDeclaration, () => []); + if (!infos.some((i) => i.token.text === token.text)) { + infos.push(info); + } + } + } + }); + typeDeclToMembers.forEach((infos, declaration) => { + const supers = isTypeLiteralNode(declaration) ? void 0 : getAllSupers(declaration, checker); + for (const info of infos) { + if (supers == null ? void 0 : supers.some((superClassOrInterface) => { + const superInfos = typeDeclToMembers.get(superClassOrInterface); + return !!superInfos && superInfos.some(({ token: token2 }) => token2.text === info.token.text); + })) + continue; + const { parentDeclaration, declSourceFile, modifierFlags, token, call, isJSFile } = info; + if (call && !isPrivateIdentifier(token)) { + addMethodDeclaration(context, changes, call, token, modifierFlags & 256 /* Static */, parentDeclaration, declSourceFile); + } else { + if (isJSFile && !isInterfaceDeclaration(parentDeclaration) && !isTypeLiteralNode(parentDeclaration)) { + addMissingMemberInJs(changes, declSourceFile, parentDeclaration, token, !!(modifierFlags & 256 /* Static */)); + } else { + const typeNode = getTypeNode2(checker, parentDeclaration, token); + addPropertyDeclaration(changes, declSourceFile, parentDeclaration, token.text, typeNode, modifierFlags & 256 /* Static */); + } + } + } + }); + })); + } + }); + } + }); + + // src/services/codefixes/fixAddMissingNewOperator.ts + function addMissingNewOperator(changes, sourceFile, span) { + const call = cast(findAncestorMatchingSpan2(sourceFile, span), isCallExpression); + const newExpression = factory.createNewExpression(call.expression, call.typeArguments, call.arguments); + changes.replaceNode(sourceFile, call, newExpression); + } + function findAncestorMatchingSpan2(sourceFile, span) { + let token = getTokenAtPosition(sourceFile, span.start); + const end = textSpanEnd(span); + while (token.end < end) { + token = token.parent; } - return void 0; + return token; } - var fixId9, errorCodes10; - var init_convertFunctionToEs6Class = __esm({ - "src/services/codefixes/convertFunctionToEs6Class.ts"() { + var fixId24, errorCodes28; + var init_fixAddMissingNewOperator = __esm({ + "src/services/codefixes/fixAddMissingNewOperator.ts"() { "use strict"; init_ts4(); init_ts_codefix(); - fixId9 = "convertFunctionToEs6Class"; - errorCodes10 = [Diagnostics.This_constructor_function_may_be_converted_to_a_class_declaration.code]; + fixId24 = "addMissingNewOperator"; + errorCodes28 = [Diagnostics.Value_of_type_0_is_not_callable_Did_you_mean_to_include_new.code]; registerCodeFix({ - errorCodes: errorCodes10, + errorCodes: errorCodes28, getCodeActions(context) { - const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange9(t, context.sourceFile, context.span.start, context.program.getTypeChecker(), context.preferences, context.program.getCompilerOptions())); - return [createCodeFixAction(fixId9, changes, Diagnostics.Convert_function_to_an_ES2015_class, fixId9, Diagnostics.Convert_all_constructor_functions_to_classes)]; + const { sourceFile, span } = context; + const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => addMissingNewOperator(t, sourceFile, span)); + return [createCodeFixAction(fixId24, changes, Diagnostics.Add_missing_new_operator_to_call, fixId24, Diagnostics.Add_missing_new_operator_to_all_calls)]; }, - fixIds: [fixId9], - getAllCodeActions: (context) => codeFixAll(context, errorCodes10, (changes, err) => doChange9(changes, err.file, err.start, context.program.getTypeChecker(), context.preferences, context.program.getCompilerOptions())) + fixIds: [fixId24], + getAllCodeActions: (context) => codeFixAll(context, errorCodes28, (changes, diag2) => addMissingNewOperator(changes, context.sourceFile, diag2)) }); } }); - // src/services/codefixes/convertToAsyncFunction.ts - function convertToAsyncFunction(changes, sourceFile, position, checker) { - const tokenAtPosition = getTokenAtPosition(sourceFile, position); - let functionToConvert; - if (isIdentifier(tokenAtPosition) && isVariableDeclaration(tokenAtPosition.parent) && tokenAtPosition.parent.initializer && isFunctionLikeDeclaration(tokenAtPosition.parent.initializer)) { - functionToConvert = tokenAtPosition.parent.initializer; - } else { - functionToConvert = tryCast(getContainingFunction(getTokenAtPosition(sourceFile, position)), canBeConvertedToAsync); - } - if (!functionToConvert) { - return; - } - const synthNamesMap = /* @__PURE__ */ new Map(); - const isInJavascript = isInJSFile(functionToConvert); - const setOfExpressionsToReturn = getAllPromiseExpressionsToReturn(functionToConvert, checker); - const functionToConvertRenamed = renameCollidingVarNames(functionToConvert, checker, synthNamesMap); - if (!returnsPromise(functionToConvertRenamed, checker)) { - return; - } - const returnStatements = functionToConvertRenamed.body && isBlock(functionToConvertRenamed.body) ? getReturnStatementsWithPromiseHandlers(functionToConvertRenamed.body, checker) : emptyArray; - const transformer = { checker, synthNamesMap, setOfExpressionsToReturn, isInJSFile: isInJavascript }; - if (!returnStatements.length) { - return; - } - const pos = skipTrivia(sourceFile.text, moveRangePastModifiers(functionToConvert).pos); - changes.insertModifierAt(sourceFile, pos, 134 /* AsyncKeyword */, { suffix: " " }); - for (const returnStatement of returnStatements) { - forEachChild(returnStatement, function visit(node) { - if (isCallExpression(node)) { - const newNodes = transformExpression( - node, - node, - transformer, - /*hasContinuation*/ - false - ); - if (hasFailed()) { - return true; - } - changes.replaceNodeWithNodes(sourceFile, returnStatement, newNodes); - } else if (!isFunctionLike(node)) { - forEachChild(node, visit); - if (hasFailed()) { - return true; - } - } - }); - if (hasFailed()) { - return; - } - } - } - function getReturnStatementsWithPromiseHandlers(body, checker) { - const res = []; - forEachReturnStatement(body, (ret) => { - if (isReturnStatementWithFixablePromiseHandler(ret, checker)) - res.push(ret); - }); - return res; - } - function getAllPromiseExpressionsToReturn(func, checker) { - if (!func.body) { - return /* @__PURE__ */ new Set(); - } - const setOfExpressionsToReturn = /* @__PURE__ */ new Set(); - forEachChild(func.body, function visit(node) { - if (isPromiseReturningCallExpression(node, checker, "then")) { - setOfExpressionsToReturn.add(getNodeId(node)); - forEach(node.arguments, visit); - } else if (isPromiseReturningCallExpression(node, checker, "catch") || isPromiseReturningCallExpression(node, checker, "finally")) { - setOfExpressionsToReturn.add(getNodeId(node)); - forEachChild(node, visit); - } else if (isPromiseTypedExpression(node, checker)) { - setOfExpressionsToReturn.add(getNodeId(node)); - } else { - forEachChild(node, visit); - } - }); - return setOfExpressionsToReturn; - } - function isPromiseReturningCallExpression(node, checker, name) { - if (!isCallExpression(node)) - return false; - const isExpressionOfName = hasPropertyAccessExpressionWithName(node, name); - const nodeType = isExpressionOfName && checker.getTypeAtLocation(node); - return !!(nodeType && checker.getPromisedTypeOfPromise(nodeType)); - } - function isReferenceToType(type, target) { - return (getObjectFlags(type) & 4 /* Reference */) !== 0 && type.target === target; + // src/services/codefixes/fixCannotFindModule.ts + function getInstallCommand(fileName, packageName) { + return { type: "install package", file: fileName, packageName }; } - function getExplicitPromisedTypeOfPromiseReturningCallExpression(node, callback, checker) { - if (node.expression.name.escapedText === "finally") { + function tryGetImportedPackageName(sourceFile, pos) { + const moduleSpecifierText = tryCast(getTokenAtPosition(sourceFile, pos), isStringLiteral); + if (!moduleSpecifierText) return void 0; - } - const promiseType = checker.getTypeAtLocation(node.expression.expression); - if (isReferenceToType(promiseType, checker.getPromiseType()) || isReferenceToType(promiseType, checker.getPromiseLikeType())) { - if (node.expression.name.escapedText === "then") { - if (callback === elementAt(node.arguments, 0)) { - return elementAt(node.typeArguments, 0); - } else if (callback === elementAt(node.arguments, 1)) { - return elementAt(node.typeArguments, 1); - } - } else { - return elementAt(node.typeArguments, 0); - } - } + const moduleName = moduleSpecifierText.text; + const { packageName } = parsePackageName(moduleName); + return isExternalModuleNameRelative(packageName) ? void 0 : packageName; } - function isPromiseTypedExpression(node, checker) { - if (!isExpression(node)) - return false; - return !!checker.getPromisedTypeOfPromise(checker.getTypeAtLocation(node)); + function getTypesPackageNameToInstall(packageName, host, diagCode) { + var _a; + return diagCode === errorCodeCannotFindModule ? ts_JsTyping_exports.nodeCoreModules.has(packageName) ? "@types/node" : void 0 : ((_a = host.isKnownTypesPackageName) == null ? void 0 : _a.call(host, packageName)) ? getTypesPackageName(packageName) : void 0; } - function renameCollidingVarNames(nodeToRename, checker, synthNamesMap) { - const identsToRenameMap = /* @__PURE__ */ new Map(); - const collidingSymbolMap = createMultiMap(); - forEachChild(nodeToRename, function visit(node) { - if (!isIdentifier(node)) { - forEachChild(node, visit); - return; - } - const symbol = checker.getSymbolAtLocation(node); - if (symbol) { - const type = checker.getTypeAtLocation(node); - const lastCallSignature = getLastCallSignature(type, checker); - const symbolIdString = getSymbolId(symbol).toString(); - if (lastCallSignature && !isParameter(node.parent) && !isFunctionLikeDeclaration(node.parent) && !synthNamesMap.has(symbolIdString)) { - const firstParameter = firstOrUndefined(lastCallSignature.parameters); - const ident = (firstParameter == null ? void 0 : firstParameter.valueDeclaration) && isParameter(firstParameter.valueDeclaration) && tryCast(firstParameter.valueDeclaration.name, isIdentifier) || factory.createUniqueName("result", 16 /* Optimistic */); - const synthName = getNewNameIfConflict(ident, collidingSymbolMap); - synthNamesMap.set(symbolIdString, synthName); - collidingSymbolMap.add(ident.text, symbol); - } else if (node.parent && (isParameter(node.parent) || isVariableDeclaration(node.parent) || isBindingElement(node.parent))) { - const originalName = node.text; - const collidingSymbols = collidingSymbolMap.get(originalName); - if (collidingSymbols && collidingSymbols.some((prevSymbol) => prevSymbol !== symbol)) { - const newName = getNewNameIfConflict(node, collidingSymbolMap); - identsToRenameMap.set(symbolIdString, newName.identifier); - synthNamesMap.set(symbolIdString, newName); - collidingSymbolMap.add(originalName, symbol); - } else { - const identifier = getSynthesizedDeepClone(node); - synthNamesMap.set(symbolIdString, createSynthIdentifier(identifier)); - collidingSymbolMap.add(originalName, symbol); - } - } - } - }); - return getSynthesizedDeepCloneWithReplacements( - nodeToRename, - /*includeTrivia*/ - true, - (original) => { - if (isBindingElement(original) && isIdentifier(original.name) && isObjectBindingPattern(original.parent)) { - const symbol = checker.getSymbolAtLocation(original.name); - const renameInfo = symbol && identsToRenameMap.get(String(getSymbolId(symbol))); - if (renameInfo && renameInfo.text !== (original.name || original.propertyName).getText()) { - return factory.createBindingElement( - original.dotDotDotToken, - original.propertyName || original.name, - renameInfo, - original.initializer - ); - } - } else if (isIdentifier(original)) { - const symbol = checker.getSymbolAtLocation(original); - const renameInfo = symbol && identsToRenameMap.get(String(getSymbolId(symbol))); - if (renameInfo) { - return factory.createIdentifier(renameInfo.text); - } + var fixName2, fixIdInstallTypesPackage, errorCodeCannotFindModule, errorCodes29; + var init_fixCannotFindModule = __esm({ + "src/services/codefixes/fixCannotFindModule.ts"() { + "use strict"; + init_ts4(); + init_ts_codefix(); + fixName2 = "fixCannotFindModule"; + fixIdInstallTypesPackage = "installTypesPackage"; + errorCodeCannotFindModule = Diagnostics.Cannot_find_module_0_or_its_corresponding_type_declarations.code; + errorCodes29 = [ + errorCodeCannotFindModule, + Diagnostics.Could_not_find_a_declaration_file_for_module_0_1_implicitly_has_an_any_type.code + ]; + registerCodeFix({ + errorCodes: errorCodes29, + getCodeActions: function getCodeActionsToFixNotFoundModule(context) { + const { host, sourceFile, span: { start } } = context; + const packageName = tryGetImportedPackageName(sourceFile, start); + if (packageName === void 0) + return void 0; + const typesPackageName = getTypesPackageNameToInstall(packageName, host, context.errorCode); + return typesPackageName === void 0 ? [] : [createCodeFixAction( + fixName2, + /*changes*/ + [], + [Diagnostics.Install_0, typesPackageName], + fixIdInstallTypesPackage, + Diagnostics.Install_all_missing_types_packages, + getInstallCommand(sourceFile.fileName, typesPackageName) + )]; + }, + fixIds: [fixIdInstallTypesPackage], + getAllCodeActions: (context) => { + return codeFixAll(context, errorCodes29, (_changes, diag2, commands) => { + const packageName = tryGetImportedPackageName(diag2.file, diag2.start); + if (packageName === void 0) + return void 0; + switch (context.fixId) { + case fixIdInstallTypesPackage: { + const pkg = getTypesPackageNameToInstall(packageName, context.host, diag2.code); + if (pkg) { + commands.push(getInstallCommand(diag2.file.fileName, pkg)); + } + break; + } + default: + Debug.fail(`Bad fixId: ${context.fixId}`); + } + }); } - } - ); - } - function getNewNameIfConflict(name, originalNames) { - const numVarsSameName = (originalNames.get(name.text) || emptyArray).length; - const identifier = numVarsSameName === 0 ? name : factory.createIdentifier(name.text + "_" + numVarsSameName); - return createSynthIdentifier(identifier); - } - function hasFailed() { - return !codeActionSucceeded; + }); + } + }); + + // src/services/codefixes/fixClassDoesntImplementInheritedAbstractMember.ts + function getClass2(sourceFile, pos) { + const token = getTokenAtPosition(sourceFile, pos); + return cast(token.parent, isClassLike); } - function silentFail() { - codeActionSucceeded = false; - return emptyArray; + function addMissingMembers(classDeclaration, sourceFile, context, changeTracker, preferences) { + const extendsNode = getEffectiveBaseTypeNode(classDeclaration); + const checker = context.program.getTypeChecker(); + const instantiatedExtendsType = checker.getTypeAtLocation(extendsNode); + const abstractAndNonPrivateExtendsSymbols = checker.getPropertiesOfType(instantiatedExtendsType).filter(symbolPointsToNonPrivateAndAbstractMember); + const importAdder = createImportAdder(sourceFile, context.program, preferences, context.host); + createMissingMemberNodes(classDeclaration, abstractAndNonPrivateExtendsSymbols, sourceFile, context, preferences, importAdder, (member) => changeTracker.insertMemberAtStart(sourceFile, classDeclaration, member)); + importAdder.writeFixes(changeTracker); } - function transformExpression(returnContextNode, node, transformer, hasContinuation, continuationArgName) { - if (isPromiseReturningCallExpression(node, transformer.checker, "then")) { - return transformThen(node, elementAt(node.arguments, 0), elementAt(node.arguments, 1), transformer, hasContinuation, continuationArgName); - } - if (isPromiseReturningCallExpression(node, transformer.checker, "catch")) { - return transformCatch(node, elementAt(node.arguments, 0), transformer, hasContinuation, continuationArgName); - } - if (isPromiseReturningCallExpression(node, transformer.checker, "finally")) { - return transformFinally(node, elementAt(node.arguments, 0), transformer, hasContinuation, continuationArgName); - } - if (isPropertyAccessExpression(node)) { - return transformExpression(returnContextNode, node.expression, transformer, hasContinuation, continuationArgName); - } - const nodeType = transformer.checker.getTypeAtLocation(node); - if (nodeType && transformer.checker.getPromisedTypeOfPromise(nodeType)) { - Debug.assertNode(getOriginalNode(node).parent, isPropertyAccessExpression); - return transformPromiseExpressionOfPropertyAccess(returnContextNode, node, transformer, hasContinuation, continuationArgName); - } - return silentFail(); + function symbolPointsToNonPrivateAndAbstractMember(symbol) { + const flags = getSyntacticModifierFlags(first(symbol.getDeclarations())); + return !(flags & 2 /* Private */) && !!(flags & 64 /* Abstract */); } - function isNullOrUndefined2({ checker }, node) { - if (node.kind === 106 /* NullKeyword */) - return true; - if (isIdentifier(node) && !isGeneratedIdentifier(node) && idText(node) === "undefined") { - const symbol = checker.getSymbolAtLocation(node); - return !symbol || checker.isUndefinedSymbol(symbol); + var errorCodes30, fixId25; + var init_fixClassDoesntImplementInheritedAbstractMember = __esm({ + "src/services/codefixes/fixClassDoesntImplementInheritedAbstractMember.ts"() { + "use strict"; + init_ts4(); + init_ts_codefix(); + errorCodes30 = [ + Diagnostics.Non_abstract_class_0_does_not_implement_all_abstract_members_of_1.code + ]; + fixId25 = "fixClassDoesntImplementInheritedAbstractMember"; + registerCodeFix({ + errorCodes: errorCodes30, + getCodeActions: function getCodeActionsToFixClassNotImplementingInheritedMembers(context) { + const { sourceFile, span } = context; + const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => addMissingMembers(getClass2(sourceFile, span.start), sourceFile, context, t, context.preferences)); + return changes.length === 0 ? void 0 : [createCodeFixAction(fixId25, changes, Diagnostics.Implement_inherited_abstract_class, fixId25, Diagnostics.Implement_all_inherited_abstract_classes)]; + }, + fixIds: [fixId25], + getAllCodeActions: function getAllCodeActionsToFixClassDoesntImplementInheritedAbstractMember(context) { + const seenClassDeclarations = /* @__PURE__ */ new Map(); + return codeFixAll(context, errorCodes30, (changes, diag2) => { + const classDeclaration = getClass2(diag2.file, diag2.start); + if (addToSeen(seenClassDeclarations, getNodeId(classDeclaration))) { + addMissingMembers(classDeclaration, context.sourceFile, context, changes, context.preferences); + } + }); + } + }); } - return false; + }); + + // src/services/codefixes/fixClassSuperMustPrecedeThisAccess.ts + function doChange19(changes, sourceFile, constructor, superCall) { + changes.insertNodeAtConstructorStart(sourceFile, constructor, superCall); + changes.delete(sourceFile, superCall); } - function createUniqueSynthName(prevArgName) { - const renamedPrevArg = factory.createUniqueName(prevArgName.identifier.text, 16 /* Optimistic */); - return createSynthIdentifier(renamedPrevArg); + function getNodes(sourceFile, pos) { + const token = getTokenAtPosition(sourceFile, pos); + if (token.kind !== 110 /* ThisKeyword */) + return void 0; + const constructor = getContainingFunction(token); + const superCall = findSuperCall(constructor.body); + return superCall && !superCall.expression.arguments.some((arg) => isPropertyAccessExpression(arg) && arg.expression === token) ? { constructor, superCall } : void 0; } - function getPossibleNameForVarDecl(node, transformer, continuationArgName) { - let possibleNameForVarDecl; - if (continuationArgName && !shouldReturn(node, transformer)) { - if (isSynthIdentifier(continuationArgName)) { - possibleNameForVarDecl = continuationArgName; - transformer.synthNamesMap.forEach((val, key) => { - if (val.identifier.text === continuationArgName.identifier.text) { - const newSynthName = createUniqueSynthName(continuationArgName); - transformer.synthNamesMap.set(key, newSynthName); - } - }); - } else { - possibleNameForVarDecl = createSynthIdentifier(factory.createUniqueName("result", 16 /* Optimistic */), continuationArgName.types); - } - declareSynthIdentifier(possibleNameForVarDecl); - } - return possibleNameForVarDecl; + function findSuperCall(n) { + return isExpressionStatement(n) && isSuperCall(n.expression) ? n : isFunctionLike(n) ? void 0 : forEachChild(n, findSuperCall); } - function finishCatchOrFinallyTransform(node, transformer, tryStatement, possibleNameForVarDecl, continuationArgName) { - const statements = []; - let varDeclIdentifier; - if (possibleNameForVarDecl && !shouldReturn(node, transformer)) { - varDeclIdentifier = getSynthesizedDeepClone(declareSynthIdentifier(possibleNameForVarDecl)); - const typeArray = possibleNameForVarDecl.types; - const unionType = transformer.checker.getUnionType(typeArray, 2 /* Subtype */); - const unionTypeNode = transformer.isInJSFile ? void 0 : transformer.checker.typeToTypeNode( - unionType, - /*enclosingDeclaration*/ - void 0, - /*flags*/ - void 0 - ); - const varDecl = [factory.createVariableDeclaration( - varDeclIdentifier, - /*exclamationToken*/ - void 0, - unionTypeNode - )]; - const varDeclList = factory.createVariableStatement( - /*modifiers*/ - void 0, - factory.createVariableDeclarationList(varDecl, 1 /* Let */) - ); - statements.push(varDeclList); - } - statements.push(tryStatement); - if (continuationArgName && varDeclIdentifier && isSynthBindingPattern(continuationArgName)) { - statements.push(factory.createVariableStatement( - /*modifiers*/ - void 0, - factory.createVariableDeclarationList( - [ - factory.createVariableDeclaration( - getSynthesizedDeepClone(declareSynthBindingPattern(continuationArgName)), - /*exclamationToken*/ - void 0, - /*type*/ - void 0, - varDeclIdentifier - ) - ], - 2 /* Const */ - ) - )); + var fixId26, errorCodes31; + var init_fixClassSuperMustPrecedeThisAccess = __esm({ + "src/services/codefixes/fixClassSuperMustPrecedeThisAccess.ts"() { + "use strict"; + init_ts4(); + init_ts_codefix(); + fixId26 = "classSuperMustPrecedeThisAccess"; + errorCodes31 = [Diagnostics.super_must_be_called_before_accessing_this_in_the_constructor_of_a_derived_class.code]; + registerCodeFix({ + errorCodes: errorCodes31, + getCodeActions(context) { + const { sourceFile, span } = context; + const nodes = getNodes(sourceFile, span.start); + if (!nodes) + return void 0; + const { constructor, superCall } = nodes; + const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange19(t, sourceFile, constructor, superCall)); + return [createCodeFixAction(fixId26, changes, Diagnostics.Make_super_call_the_first_statement_in_the_constructor, fixId26, Diagnostics.Make_all_super_calls_the_first_statement_in_their_constructor)]; + }, + fixIds: [fixId26], + getAllCodeActions(context) { + const { sourceFile } = context; + const seenClasses = /* @__PURE__ */ new Map(); + return codeFixAll(context, errorCodes31, (changes, diag2) => { + const nodes = getNodes(diag2.file, diag2.start); + if (!nodes) + return; + const { constructor, superCall } = nodes; + if (addToSeen(seenClasses, getNodeId(constructor.parent))) { + doChange19(changes, sourceFile, constructor, superCall); + } + }); + } + }); } - return statements; + }); + + // src/services/codefixes/fixConstructorForDerivedNeedSuperCall.ts + function getNode(sourceFile, pos) { + const token = getTokenAtPosition(sourceFile, pos); + Debug.assert(isConstructorDeclaration(token.parent), "token should be at the constructor declaration"); + return token.parent; } - function transformFinally(node, onFinally, transformer, hasContinuation, continuationArgName) { - if (!onFinally || isNullOrUndefined2(transformer, onFinally)) { - return transformExpression( - /* returnContextNode */ - node, - node.expression.expression, - transformer, - hasContinuation, - continuationArgName - ); - } - const possibleNameForVarDecl = getPossibleNameForVarDecl(node, transformer, continuationArgName); - const inlinedLeftHandSide = transformExpression( - /*returnContextNode*/ - node, - node.expression.expression, - transformer, - /*hasContinuation*/ - true, - possibleNameForVarDecl - ); - if (hasFailed()) - return silentFail(); - const inlinedCallback = transformCallbackArgument( - onFinally, - hasContinuation, - /*continuationArgName*/ - void 0, - /*inputArgName*/ - void 0, - node, - transformer - ); - if (hasFailed()) - return silentFail(); - const tryBlock = factory.createBlock(inlinedLeftHandSide); - const finallyBlock = factory.createBlock(inlinedCallback); - const tryStatement = factory.createTryStatement( - tryBlock, - /*catchClause*/ + function doChange20(changes, sourceFile, ctr) { + const superCall = factory.createExpressionStatement(factory.createCallExpression( + factory.createSuper(), + /*typeArguments*/ void 0, - finallyBlock - ); - return finishCatchOrFinallyTransform(node, transformer, tryStatement, possibleNameForVarDecl, continuationArgName); + /*argumentsArray*/ + emptyArray + )); + changes.insertNodeAtConstructorStart(sourceFile, ctr, superCall); } - function transformCatch(node, onRejected, transformer, hasContinuation, continuationArgName) { - if (!onRejected || isNullOrUndefined2(transformer, onRejected)) { - return transformExpression( - /* returnContextNode */ - node, - node.expression.expression, - transformer, - hasContinuation, - continuationArgName - ); + var fixId27, errorCodes32; + var init_fixConstructorForDerivedNeedSuperCall = __esm({ + "src/services/codefixes/fixConstructorForDerivedNeedSuperCall.ts"() { + "use strict"; + init_ts4(); + init_ts_codefix(); + fixId27 = "constructorForDerivedNeedSuperCall"; + errorCodes32 = [Diagnostics.Constructors_for_derived_classes_must_contain_a_super_call.code]; + registerCodeFix({ + errorCodes: errorCodes32, + getCodeActions(context) { + const { sourceFile, span } = context; + const ctr = getNode(sourceFile, span.start); + const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange20(t, sourceFile, ctr)); + return [createCodeFixAction(fixId27, changes, Diagnostics.Add_missing_super_call, fixId27, Diagnostics.Add_all_missing_super_calls)]; + }, + fixIds: [fixId27], + getAllCodeActions: (context) => codeFixAll(context, errorCodes32, (changes, diag2) => doChange20(changes, context.sourceFile, getNode(diag2.file, diag2.start))) + }); } - const inputArgName = getArgBindingName(onRejected, transformer); - const possibleNameForVarDecl = getPossibleNameForVarDecl(node, transformer, continuationArgName); - const inlinedLeftHandSide = transformExpression( - /*returnContextNode*/ - node, - node.expression.expression, - transformer, - /*hasContinuation*/ - true, - possibleNameForVarDecl - ); - if (hasFailed()) - return silentFail(); - const inlinedCallback = transformCallbackArgument(onRejected, hasContinuation, possibleNameForVarDecl, inputArgName, node, transformer); - if (hasFailed()) - return silentFail(); - const tryBlock = factory.createBlock(inlinedLeftHandSide); - const catchClause = factory.createCatchClause(inputArgName && getSynthesizedDeepClone(declareSynthBindingName(inputArgName)), factory.createBlock(inlinedCallback)); - const tryStatement = factory.createTryStatement( - tryBlock, - catchClause, - /*finallyBlock*/ - void 0 - ); - return finishCatchOrFinallyTransform(node, transformer, tryStatement, possibleNameForVarDecl, continuationArgName); + }); + + // src/services/codefixes/fixEnableJsxFlag.ts + function doChange21(changeTracker, configFile) { + setJsonCompilerOptionValue(changeTracker, configFile, "jsx", factory.createStringLiteral("react")); } - function transformThen(node, onFulfilled, onRejected, transformer, hasContinuation, continuationArgName) { - if (!onFulfilled || isNullOrUndefined2(transformer, onFulfilled)) { - return transformCatch(node, onRejected, transformer, hasContinuation, continuationArgName); + var fixID, errorCodes33; + var init_fixEnableJsxFlag = __esm({ + "src/services/codefixes/fixEnableJsxFlag.ts"() { + "use strict"; + init_ts4(); + init_ts_codefix(); + fixID = "fixEnableJsxFlag"; + errorCodes33 = [Diagnostics.Cannot_use_JSX_unless_the_jsx_flag_is_provided.code]; + registerCodeFix({ + errorCodes: errorCodes33, + getCodeActions: function getCodeActionsToFixEnableJsxFlag(context) { + const { configFile } = context.program.getCompilerOptions(); + if (configFile === void 0) { + return void 0; + } + const changes = ts_textChanges_exports.ChangeTracker.with(context, (changeTracker) => doChange21(changeTracker, configFile)); + return [ + createCodeFixActionWithoutFixAll(fixID, changes, Diagnostics.Enable_the_jsx_flag_in_your_configuration_file) + ]; + }, + fixIds: [fixID], + getAllCodeActions: (context) => codeFixAll(context, errorCodes33, (changes) => { + const { configFile } = context.program.getCompilerOptions(); + if (configFile === void 0) { + return void 0; + } + doChange21(changes, configFile); + }) + }); } - if (onRejected && !isNullOrUndefined2(transformer, onRejected)) { - return silentFail(); + }); + + // src/services/codefixes/fixNaNEquality.ts + function getInfo11(program, sourceFile, span) { + const diag2 = find(program.getSemanticDiagnostics(sourceFile), (diag3) => diag3.start === span.start && diag3.length === span.length); + if (diag2 === void 0 || diag2.relatedInformation === void 0) + return; + const related = find(diag2.relatedInformation, (related2) => related2.code === Diagnostics.Did_you_mean_0.code); + if (related === void 0 || related.file === void 0 || related.start === void 0 || related.length === void 0) + return; + const token = findAncestorMatchingSpan(related.file, createTextSpan(related.start, related.length)); + if (token === void 0) + return; + if (isExpression(token) && isBinaryExpression(token.parent)) { + return { suggestion: getSuggestion(related.messageText), expression: token.parent, arg: token }; } - const inputArgName = getArgBindingName(onFulfilled, transformer); - const inlinedLeftHandSide = transformExpression( - node.expression.expression, - node.expression.expression, - transformer, - /*hasContinuation*/ - true, - inputArgName - ); - if (hasFailed()) - return silentFail(); - const inlinedCallback = transformCallbackArgument(onFulfilled, hasContinuation, continuationArgName, inputArgName, node, transformer); - if (hasFailed()) - return silentFail(); - return concatenate(inlinedLeftHandSide, inlinedCallback); + return void 0; } - function transformPromiseExpressionOfPropertyAccess(returnContextNode, node, transformer, hasContinuation, continuationArgName) { - if (shouldReturn(returnContextNode, transformer)) { - let returnValue = getSynthesizedDeepClone(node); - if (hasContinuation) { - returnValue = factory.createAwaitExpression(returnValue); - } - return [factory.createReturnStatement(returnValue)]; - } - return createVariableOrAssignmentOrExpressionStatement( - continuationArgName, - factory.createAwaitExpression(node), - /*typeAnnotation*/ - void 0 + function doChange22(changes, sourceFile, arg, expression) { + const callExpression = factory.createCallExpression( + factory.createPropertyAccessExpression(factory.createIdentifier("Number"), factory.createIdentifier("isNaN")), + /*typeArguments*/ + void 0, + [arg] + ); + const operator = expression.operatorToken.kind; + changes.replaceNode( + sourceFile, + expression, + operator === 38 /* ExclamationEqualsEqualsToken */ || operator === 36 /* ExclamationEqualsToken */ ? factory.createPrefixUnaryExpression(54 /* ExclamationToken */, callExpression) : callExpression ); } - function createVariableOrAssignmentOrExpressionStatement(variableName, rightHandSide, typeAnnotation) { - if (!variableName || isEmptyBindingName(variableName)) { - return [factory.createExpressionStatement(rightHandSide)]; - } - if (isSynthIdentifier(variableName) && variableName.hasBeenDeclared) { - return [factory.createExpressionStatement(factory.createAssignment(getSynthesizedDeepClone(referenceSynthIdentifier(variableName)), rightHandSide))]; - } - return [ - factory.createVariableStatement( - /*modifiers*/ - void 0, - factory.createVariableDeclarationList( - [ - factory.createVariableDeclaration( - getSynthesizedDeepClone(declareSynthBindingName(variableName)), - /*exclamationToken*/ - void 0, - typeAnnotation, - rightHandSide - ) - ], - 2 /* Const */ - ) - ) - ]; + function getSuggestion(messageText) { + const [_, suggestion] = flattenDiagnosticMessageText(messageText, "\n", 0).match(/'(.*)'/) || []; + return suggestion; } - function maybeAnnotateAndReturn(expressionToReturn, typeAnnotation) { - if (typeAnnotation && expressionToReturn) { - const name = factory.createUniqueName("result", 16 /* Optimistic */); - return [ - ...createVariableOrAssignmentOrExpressionStatement(createSynthIdentifier(name), expressionToReturn, typeAnnotation), - factory.createReturnStatement(name) + var fixId28, errorCodes34; + var init_fixNaNEquality = __esm({ + "src/services/codefixes/fixNaNEquality.ts"() { + "use strict"; + init_ts4(); + init_ts_codefix(); + fixId28 = "fixNaNEquality"; + errorCodes34 = [ + Diagnostics.This_condition_will_always_return_0.code ]; - } - return [factory.createReturnStatement(expressionToReturn)]; - } - function transformCallbackArgument(func, hasContinuation, continuationArgName, inputArgName, parent2, transformer) { - var _a; - switch (func.kind) { - case 106 /* NullKeyword */: - break; - case 210 /* PropertyAccessExpression */: - case 80 /* Identifier */: - if (!inputArgName) { - break; - } - const synthCall = factory.createCallExpression( - getSynthesizedDeepClone(func), - /*typeArguments*/ - void 0, - isSynthIdentifier(inputArgName) ? [referenceSynthIdentifier(inputArgName)] : [] - ); - if (shouldReturn(parent2, transformer)) { - return maybeAnnotateAndReturn(synthCall, getExplicitPromisedTypeOfPromiseReturningCallExpression(parent2, func, transformer.checker)); - } - const type = transformer.checker.getTypeAtLocation(func); - const callSignatures = transformer.checker.getSignaturesOfType(type, 0 /* Call */); - if (!callSignatures.length) { - return silentFail(); - } - const returnType = callSignatures[0].getReturnType(); - const varDeclOrAssignment = createVariableOrAssignmentOrExpressionStatement(continuationArgName, factory.createAwaitExpression(synthCall), getExplicitPromisedTypeOfPromiseReturningCallExpression(parent2, func, transformer.checker)); - if (continuationArgName) { - continuationArgName.types.push(transformer.checker.getAwaitedType(returnType) || returnType); - } - return varDeclOrAssignment; - case 217 /* FunctionExpression */: - case 218 /* ArrowFunction */: { - const funcBody = func.body; - const returnType2 = (_a = getLastCallSignature(transformer.checker.getTypeAtLocation(func), transformer.checker)) == null ? void 0 : _a.getReturnType(); - if (isBlock(funcBody)) { - let refactoredStmts = []; - let seenReturnStatement = false; - for (const statement of funcBody.statements) { - if (isReturnStatement(statement)) { - seenReturnStatement = true; - if (isReturnStatementWithFixablePromiseHandler(statement, transformer.checker)) { - refactoredStmts = refactoredStmts.concat(transformReturnStatementWithFixablePromiseHandler(transformer, statement, hasContinuation, continuationArgName)); - } else { - const possiblyAwaitedRightHandSide = returnType2 && statement.expression ? getPossiblyAwaitedRightHandSide(transformer.checker, returnType2, statement.expression) : statement.expression; - refactoredStmts.push(...maybeAnnotateAndReturn(possiblyAwaitedRightHandSide, getExplicitPromisedTypeOfPromiseReturningCallExpression(parent2, func, transformer.checker))); - } - } else if (hasContinuation && forEachReturnStatement(statement, returnTrue)) { - return silentFail(); - } else { - refactoredStmts.push(statement); + registerCodeFix({ + errorCodes: errorCodes34, + getCodeActions(context) { + const { sourceFile, span, program } = context; + const info = getInfo11(program, sourceFile, span); + if (info === void 0) + return; + const { suggestion, expression, arg } = info; + const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange22(t, sourceFile, arg, expression)); + return [createCodeFixAction(fixId28, changes, [Diagnostics.Use_0, suggestion], fixId28, Diagnostics.Use_Number_isNaN_in_all_conditions)]; + }, + fixIds: [fixId28], + getAllCodeActions: (context) => { + return codeFixAll(context, errorCodes34, (changes, diag2) => { + const info = getInfo11(context.program, diag2.file, createTextSpan(diag2.start, diag2.length)); + if (info) { + doChange22(changes, diag2.file, info.arg, info.expression); } + }); + } + }); + } + }); + + // src/services/codefixes/fixModuleAndTargetOptions.ts + var init_fixModuleAndTargetOptions = __esm({ + "src/services/codefixes/fixModuleAndTargetOptions.ts"() { + "use strict"; + init_ts4(); + init_ts_codefix(); + registerCodeFix({ + errorCodes: [ + Diagnostics.Top_level_await_expressions_are_only_allowed_when_the_module_option_is_set_to_es2022_esnext_system_node16_or_nodenext_and_the_target_option_is_set_to_es2017_or_higher.code, + Diagnostics.Top_level_await_using_statements_are_only_allowed_when_the_module_option_is_set_to_es2022_esnext_system_node16_or_nodenext_and_the_target_option_is_set_to_es2017_or_higher.code, + Diagnostics.Top_level_for_await_loops_are_only_allowed_when_the_module_option_is_set_to_es2022_esnext_system_node16_or_nodenext_and_the_target_option_is_set_to_es2017_or_higher.code + ], + getCodeActions: function getCodeActionsToFixModuleAndTarget(context) { + const compilerOptions = context.program.getCompilerOptions(); + const { configFile } = compilerOptions; + if (configFile === void 0) { + return void 0; } - return shouldReturn(parent2, transformer) ? refactoredStmts.map((s) => getSynthesizedDeepClone(s)) : removeReturns( - refactoredStmts, - continuationArgName, - transformer, - seenReturnStatement - ); - } else { - const inlinedStatements = isFixablePromiseHandler(funcBody, transformer.checker) ? transformReturnStatementWithFixablePromiseHandler(transformer, factory.createReturnStatement(funcBody), hasContinuation, continuationArgName) : emptyArray; - if (inlinedStatements.length > 0) { - return inlinedStatements; + const codeFixes = []; + const moduleKind = getEmitModuleKind(compilerOptions); + const moduleOutOfRange = moduleKind >= 5 /* ES2015 */ && moduleKind < 99 /* ESNext */; + if (moduleOutOfRange) { + const changes = ts_textChanges_exports.ChangeTracker.with(context, (changes2) => { + setJsonCompilerOptionValue(changes2, configFile, "module", factory.createStringLiteral("esnext")); + }); + codeFixes.push(createCodeFixActionWithoutFixAll("fixModuleOption", changes, [Diagnostics.Set_the_module_option_in_your_configuration_file_to_0, "esnext"])); } - if (returnType2) { - const possiblyAwaitedRightHandSide = getPossiblyAwaitedRightHandSide(transformer.checker, returnType2, funcBody); - if (!shouldReturn(parent2, transformer)) { - const transformedStatement = createVariableOrAssignmentOrExpressionStatement( - continuationArgName, - possiblyAwaitedRightHandSide, - /*typeAnnotation*/ - void 0 - ); - if (continuationArgName) { - continuationArgName.types.push(transformer.checker.getAwaitedType(returnType2) || returnType2); + const target = getEmitScriptTarget(compilerOptions); + const targetOutOfRange = target < 4 /* ES2017 */ || target > 99 /* ESNext */; + if (targetOutOfRange) { + const changes = ts_textChanges_exports.ChangeTracker.with(context, (tracker) => { + const configObject = getTsConfigObjectLiteralExpression(configFile); + if (!configObject) + return; + const options = [["target", factory.createStringLiteral("es2017")]]; + if (moduleKind === 1 /* CommonJS */) { + options.push(["module", factory.createStringLiteral("commonjs")]); } - return transformedStatement; - } else { - return maybeAnnotateAndReturn(possiblyAwaitedRightHandSide, getExplicitPromisedTypeOfPromiseReturningCallExpression(parent2, func, transformer.checker)); - } - } else { - return silentFail(); - } - } - } - default: - return silentFail(); - } - return emptyArray; - } - function getPossiblyAwaitedRightHandSide(checker, type, expr) { - const rightHandSide = getSynthesizedDeepClone(expr); - return !!checker.getPromisedTypeOfPromise(type) ? factory.createAwaitExpression(rightHandSide) : rightHandSide; - } - function getLastCallSignature(type, checker) { - const callSignatures = checker.getSignaturesOfType(type, 0 /* Call */); - return lastOrUndefined(callSignatures); - } - function removeReturns(stmts, prevArgName, transformer, seenReturnStatement) { - const ret = []; - for (const stmt of stmts) { - if (isReturnStatement(stmt)) { - if (stmt.expression) { - const possiblyAwaitedExpression = isPromiseTypedExpression(stmt.expression, transformer.checker) ? factory.createAwaitExpression(stmt.expression) : stmt.expression; - if (prevArgName === void 0) { - ret.push(factory.createExpressionStatement(possiblyAwaitedExpression)); - } else if (isSynthIdentifier(prevArgName) && prevArgName.hasBeenDeclared) { - ret.push(factory.createExpressionStatement(factory.createAssignment(referenceSynthIdentifier(prevArgName), possiblyAwaitedExpression))); - } else { - ret.push(factory.createVariableStatement( - /*modifiers*/ - void 0, - factory.createVariableDeclarationList([factory.createVariableDeclaration( - declareSynthBindingName(prevArgName), - /*exclamationToken*/ - void 0, - /*type*/ - void 0, - possiblyAwaitedExpression - )], 2 /* Const */) - )); + setJsonCompilerOptionValues(tracker, configFile, options); + }); + codeFixes.push(createCodeFixActionWithoutFixAll("fixTargetOption", changes, [Diagnostics.Set_the_target_option_in_your_configuration_file_to_0, "es2017"])); } + return codeFixes.length ? codeFixes : void 0; } - } else { - ret.push(getSynthesizedDeepClone(stmt)); - } - } - if (!seenReturnStatement && prevArgName !== void 0) { - ret.push(factory.createVariableStatement( - /*modifiers*/ - void 0, - factory.createVariableDeclarationList([factory.createVariableDeclaration( - declareSynthBindingName(prevArgName), - /*exclamationToken*/ - void 0, - /*type*/ - void 0, - factory.createIdentifier("undefined") - )], 2 /* Const */) - )); + }); } - return ret; + }); + + // src/services/codefixes/fixPropertyAssignment.ts + function doChange23(changes, sourceFile, node) { + changes.replaceNode(sourceFile, node, factory.createPropertyAssignment(node.name, node.objectAssignmentInitializer)); } - function transformReturnStatementWithFixablePromiseHandler(transformer, innerRetStmt, hasContinuation, continuationArgName) { - let innerCbBody = []; - forEachChild(innerRetStmt, function visit(node) { - if (isCallExpression(node)) { - const temp = transformExpression(node, node, transformer, hasContinuation, continuationArgName); - innerCbBody = innerCbBody.concat(temp); - if (innerCbBody.length > 0) { - return; - } - } else if (!isFunctionLike(node)) { - forEachChild(node, visit); - } - }); - return innerCbBody; + function getProperty2(sourceFile, pos) { + return cast(getTokenAtPosition(sourceFile, pos).parent, isShorthandPropertyAssignment); } - function getArgBindingName(funcNode, transformer) { - const types = []; - let name; - if (isFunctionLikeDeclaration(funcNode)) { - if (funcNode.parameters.length > 0) { - const param = funcNode.parameters[0].name; - name = getMappedBindingNameOrDefault(param); - } - } else if (isIdentifier(funcNode)) { - name = getMapEntryOrDefault(funcNode); - } else if (isPropertyAccessExpression(funcNode) && isIdentifier(funcNode.name)) { - name = getMapEntryOrDefault(funcNode.name); - } - if (!name || "identifier" in name && name.identifier.text === "undefined") { - return void 0; - } - return name; - function getMappedBindingNameOrDefault(bindingName) { - if (isIdentifier(bindingName)) - return getMapEntryOrDefault(bindingName); - const elements = flatMap(bindingName.elements, (element) => { - if (isOmittedExpression(element)) - return []; - return [getMappedBindingNameOrDefault(element.name)]; + var fixId29, errorCodes35; + var init_fixPropertyAssignment = __esm({ + "src/services/codefixes/fixPropertyAssignment.ts"() { + "use strict"; + init_ts4(); + init_ts_codefix(); + fixId29 = "fixPropertyAssignment"; + errorCodes35 = [ + Diagnostics.Did_you_mean_to_use_a_Colon_An_can_only_follow_a_property_name_when_the_containing_object_literal_is_part_of_a_destructuring_pattern.code + ]; + registerCodeFix({ + errorCodes: errorCodes35, + fixIds: [fixId29], + getCodeActions(context) { + const { sourceFile, span } = context; + const property = getProperty2(sourceFile, span.start); + const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange23(t, context.sourceFile, property)); + return [createCodeFixAction(fixId29, changes, [Diagnostics.Change_0_to_1, "=", ":"], fixId29, [Diagnostics.Switch_each_misused_0_to_1, "=", ":"])]; + }, + getAllCodeActions: (context) => codeFixAll(context, errorCodes35, (changes, diag2) => doChange23(changes, diag2.file, getProperty2(diag2.file, diag2.start))) }); - return createSynthBindingPattern(bindingName, elements); } - function getMapEntryOrDefault(identifier) { - const originalNode = getOriginalNode2(identifier); - const symbol = getSymbol2(originalNode); - if (!symbol) { - return createSynthIdentifier(identifier, types); + }); + + // src/services/codefixes/fixExtendsInterfaceBecomesImplements.ts + function getNodes2(sourceFile, pos) { + const token = getTokenAtPosition(sourceFile, pos); + const heritageClauses = getContainingClass(token).heritageClauses; + const extendsToken = heritageClauses[0].getFirstToken(); + return extendsToken.kind === 96 /* ExtendsKeyword */ ? { extendsToken, heritageClauses } : void 0; + } + function doChanges2(changes, sourceFile, extendsToken, heritageClauses) { + changes.replaceNode(sourceFile, extendsToken, factory.createToken(119 /* ImplementsKeyword */)); + if (heritageClauses.length === 2 && heritageClauses[0].token === 96 /* ExtendsKeyword */ && heritageClauses[1].token === 119 /* ImplementsKeyword */) { + const implementsToken = heritageClauses[1].getFirstToken(); + const implementsFullStart = implementsToken.getFullStart(); + changes.replaceRange(sourceFile, { pos: implementsFullStart, end: implementsFullStart }, factory.createToken(28 /* CommaToken */)); + const text = sourceFile.text; + let end = implementsToken.end; + while (end < text.length && isWhiteSpaceSingleLine(text.charCodeAt(end))) { + end++; } - const mapEntry = transformer.synthNamesMap.get(getSymbolId(symbol).toString()); - return mapEntry || createSynthIdentifier(identifier, types); - } - function getSymbol2(node) { - var _a; - return ((_a = tryCast(node, canHaveSymbol)) == null ? void 0 : _a.symbol) ?? transformer.checker.getSymbolAtLocation(node); - } - function getOriginalNode2(node) { - return node.original ? node.original : node; + changes.deleteRange(sourceFile, { pos: implementsToken.getStart(), end }); } } - function isEmptyBindingName(bindingName) { - if (!bindingName) { - return true; + var fixId30, errorCodes36; + var init_fixExtendsInterfaceBecomesImplements = __esm({ + "src/services/codefixes/fixExtendsInterfaceBecomesImplements.ts"() { + "use strict"; + init_ts4(); + init_ts_codefix(); + fixId30 = "extendsInterfaceBecomesImplements"; + errorCodes36 = [Diagnostics.Cannot_extend_an_interface_0_Did_you_mean_implements.code]; + registerCodeFix({ + errorCodes: errorCodes36, + getCodeActions(context) { + const { sourceFile } = context; + const nodes = getNodes2(sourceFile, context.span.start); + if (!nodes) + return void 0; + const { extendsToken, heritageClauses } = nodes; + const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChanges2(t, sourceFile, extendsToken, heritageClauses)); + return [createCodeFixAction(fixId30, changes, Diagnostics.Change_extends_to_implements, fixId30, Diagnostics.Change_all_extended_interfaces_to_implements)]; + }, + fixIds: [fixId30], + getAllCodeActions: (context) => codeFixAll(context, errorCodes36, (changes, diag2) => { + const nodes = getNodes2(diag2.file, diag2.start); + if (nodes) + doChanges2(changes, diag2.file, nodes.extendsToken, nodes.heritageClauses); + }) + }); } - if (isSynthIdentifier(bindingName)) { - return !bindingName.identifier.text; + }); + + // src/services/codefixes/fixForgottenThisPropertyAccess.ts + function getInfo12(sourceFile, pos, diagCode) { + const node = getTokenAtPosition(sourceFile, pos); + if (isIdentifier(node) || isPrivateIdentifier(node)) { + return { node, className: diagCode === didYouMeanStaticMemberCode ? getContainingClass(node).name.text : void 0 }; } - return every(bindingName.elements, isEmptyBindingName); - } - function createSynthIdentifier(identifier, types = []) { - return { kind: 0 /* Identifier */, identifier, types, hasBeenDeclared: false, hasBeenReferenced: false }; - } - function createSynthBindingPattern(bindingPattern, elements = emptyArray, types = []) { - return { kind: 1 /* BindingPattern */, bindingPattern, elements, types }; - } - function referenceSynthIdentifier(synthId) { - synthId.hasBeenReferenced = true; - return synthId.identifier; } - function declareSynthBindingName(synthName) { - return isSynthIdentifier(synthName) ? declareSynthIdentifier(synthName) : declareSynthBindingPattern(synthName); + function doChange24(changes, sourceFile, { node, className }) { + suppressLeadingAndTrailingTrivia(node); + changes.replaceNode(sourceFile, node, factory.createPropertyAccessExpression(className ? factory.createIdentifier(className) : factory.createThis(), node)); } - function declareSynthBindingPattern(synthPattern) { - for (const element of synthPattern.elements) { - declareSynthBindingName(element); + var fixId31, didYouMeanStaticMemberCode, errorCodes37; + var init_fixForgottenThisPropertyAccess = __esm({ + "src/services/codefixes/fixForgottenThisPropertyAccess.ts"() { + "use strict"; + init_ts4(); + init_ts_codefix(); + fixId31 = "forgottenThisPropertyAccess"; + didYouMeanStaticMemberCode = Diagnostics.Cannot_find_name_0_Did_you_mean_the_static_member_1_0.code; + errorCodes37 = [ + Diagnostics.Cannot_find_name_0_Did_you_mean_the_instance_member_this_0.code, + Diagnostics.Private_identifiers_are_only_allowed_in_class_bodies_and_may_only_be_used_as_part_of_a_class_member_declaration_property_access_or_on_the_left_hand_side_of_an_in_expression.code, + didYouMeanStaticMemberCode + ]; + registerCodeFix({ + errorCodes: errorCodes37, + getCodeActions(context) { + const { sourceFile } = context; + const info = getInfo12(sourceFile, context.span.start, context.errorCode); + if (!info) { + return void 0; + } + const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange24(t, sourceFile, info)); + return [createCodeFixAction(fixId31, changes, [Diagnostics.Add_0_to_unresolved_variable, info.className || "this"], fixId31, Diagnostics.Add_qualifier_to_all_unresolved_variables_matching_a_member_name)]; + }, + fixIds: [fixId31], + getAllCodeActions: (context) => codeFixAll(context, errorCodes37, (changes, diag2) => { + const info = getInfo12(diag2.file, diag2.start, diag2.code); + if (info) + doChange24(changes, context.sourceFile, info); + }) + }); } - return synthPattern.bindingPattern; - } - function declareSynthIdentifier(synthId) { - synthId.hasBeenDeclared = true; - return synthId.identifier; - } - function isSynthIdentifier(bindingName) { - return bindingName.kind === 0 /* Identifier */; - } - function isSynthBindingPattern(bindingName) { - return bindingName.kind === 1 /* BindingPattern */; + }); + + // src/services/codefixes/fixInvalidJsxCharacters.ts + function isValidCharacter(character) { + return hasProperty(htmlEntity, character); } - function shouldReturn(expression, transformer) { - return !!expression.original && transformer.setOfExpressionsToReturn.has(getNodeId(expression.original)); + function doChange25(changes, preferences, sourceFile, start, useHtmlEntity) { + const character = sourceFile.getText()[start]; + if (!isValidCharacter(character)) { + return; + } + const replacement = useHtmlEntity ? htmlEntity[character] : `{${quote(sourceFile, preferences, character)}}`; + changes.replaceRangeWithText(sourceFile, { pos: start, end: start + 1 }, replacement); } - var fixId10, errorCodes11, codeActionSucceeded; - var init_convertToAsyncFunction = __esm({ - "src/services/codefixes/convertToAsyncFunction.ts"() { + var fixIdExpression, fixIdHtmlEntity, errorCodes38, htmlEntity; + var init_fixInvalidJsxCharacters = __esm({ + "src/services/codefixes/fixInvalidJsxCharacters.ts"() { "use strict"; init_ts4(); init_ts_codefix(); - fixId10 = "convertToAsyncFunction"; - errorCodes11 = [Diagnostics.This_may_be_converted_to_an_async_function.code]; - codeActionSucceeded = true; + fixIdExpression = "fixInvalidJsxCharacters_expression"; + fixIdHtmlEntity = "fixInvalidJsxCharacters_htmlEntity"; + errorCodes38 = [ + Diagnostics.Unexpected_token_Did_you_mean_or_gt.code, + Diagnostics.Unexpected_token_Did_you_mean_or_rbrace.code + ]; registerCodeFix({ - errorCodes: errorCodes11, + errorCodes: errorCodes38, + fixIds: [fixIdExpression, fixIdHtmlEntity], getCodeActions(context) { - codeActionSucceeded = true; - const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => convertToAsyncFunction(t, context.sourceFile, context.span.start, context.program.getTypeChecker())); - return codeActionSucceeded ? [createCodeFixAction(fixId10, changes, Diagnostics.Convert_to_async_function, fixId10, Diagnostics.Convert_all_to_async_functions)] : []; + const { sourceFile, preferences, span } = context; + const changeToExpression = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange25( + t, + preferences, + sourceFile, + span.start, + /*useHtmlEntity*/ + false + )); + const changeToHtmlEntity = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange25( + t, + preferences, + sourceFile, + span.start, + /*useHtmlEntity*/ + true + )); + return [ + createCodeFixAction(fixIdExpression, changeToExpression, Diagnostics.Wrap_invalid_character_in_an_expression_container, fixIdExpression, Diagnostics.Wrap_all_invalid_characters_in_an_expression_container), + createCodeFixAction(fixIdHtmlEntity, changeToHtmlEntity, Diagnostics.Convert_invalid_character_to_its_html_entity_code, fixIdHtmlEntity, Diagnostics.Convert_all_invalid_characters_to_HTML_entity_code) + ]; }, - fixIds: [fixId10], - getAllCodeActions: (context) => codeFixAll(context, errorCodes11, (changes, err) => convertToAsyncFunction(changes, err.file, err.start, context.program.getTypeChecker())) + getAllCodeActions(context) { + return codeFixAll(context, errorCodes38, (changes, diagnostic) => doChange25(changes, context.preferences, diagnostic.file, diagnostic.start, context.fixId === fixIdHtmlEntity)); + } }); + htmlEntity = { + ">": ">", + "}": "}" + }; } }); - // src/services/codefixes/convertToEsModule.ts - function fixImportOfModuleExports(importingFile, exportingFile, changes, quotePreference) { - for (const moduleSpecifier of importingFile.imports) { - const imported = getResolvedModule(importingFile, moduleSpecifier.text, getModeForUsageLocation(importingFile, moduleSpecifier)); - if (!imported || imported.resolvedFileName !== exportingFile.fileName) { - continue; - } - const importNode = importFromModuleSpecifier(moduleSpecifier); - switch (importNode.kind) { - case 270 /* ImportEqualsDeclaration */: - changes.replaceNode(importingFile, importNode, makeImport( - importNode.name, - /*namedImports*/ - void 0, - moduleSpecifier, - quotePreference - )); - break; - case 212 /* CallExpression */: - if (isRequireCall( - importNode, - /*requireStringLiteralLikeArgument*/ - false - )) { - changes.replaceNode(importingFile, importNode, factory.createPropertyAccessExpression(getSynthesizedDeepClone(importNode), "default")); - } - break; - } - } + // src/services/codefixes/fixUnmatchedParameter.ts + function getDeleteAction(context, { name, jsDocHost, jsDocParameterTag }) { + const changes = ts_textChanges_exports.ChangeTracker.with(context, (changeTracker) => changeTracker.filterJSDocTags(context.sourceFile, jsDocHost, (t) => t !== jsDocParameterTag)); + return createCodeFixAction( + deleteUnmatchedParameter, + changes, + [Diagnostics.Delete_unused_param_tag_0, name.getText(context.sourceFile)], + deleteUnmatchedParameter, + Diagnostics.Delete_all_unused_param_tags + ); } - function convertFileToEsModule(sourceFile, checker, changes, target, quotePreference) { - const identifiers = { original: collectFreeIdentifiers(sourceFile), additional: /* @__PURE__ */ new Set() }; - const exports = collectExportRenames(sourceFile, checker, identifiers); - convertExportsAccesses(sourceFile, exports, changes); - let moduleExportsChangedToDefault = false; - let useSitesToUnqualify; - for (const statement of filter(sourceFile.statements, isVariableStatement)) { - const newUseSites = convertVariableStatement(sourceFile, statement, changes, checker, identifiers, target, quotePreference); - if (newUseSites) { - copyEntries(newUseSites, useSitesToUnqualify ?? (useSitesToUnqualify = /* @__PURE__ */ new Map())); + function getRenameAction(context, { name, jsDocHost, signature, jsDocParameterTag }) { + if (!length(signature.parameters)) + return void 0; + const sourceFile = context.sourceFile; + const tags = getJSDocTags(signature); + const names = /* @__PURE__ */ new Set(); + for (const tag of tags) { + if (isJSDocParameterTag(tag) && isIdentifier(tag.name)) { + names.add(tag.name.escapedText); } } - for (const statement of filter(sourceFile.statements, (s) => !isVariableStatement(s))) { - const moduleExportsChanged = convertStatement(sourceFile, statement, checker, changes, identifiers, target, exports, useSitesToUnqualify, quotePreference); - moduleExportsChangedToDefault = moduleExportsChangedToDefault || moduleExportsChanged; - } - useSitesToUnqualify == null ? void 0 : useSitesToUnqualify.forEach((replacement, original) => { - changes.replaceNode(sourceFile, original, replacement); - }); - return moduleExportsChangedToDefault; - } - function collectExportRenames(sourceFile, checker, identifiers) { - const res = /* @__PURE__ */ new Map(); - forEachExportReference(sourceFile, (node) => { - const { text } = node.name; - if (!res.has(text) && (isIdentifierANonContextualKeyword(node.name) || checker.resolveName( - text, - node, - 111551 /* Value */, - /*excludeGlobals*/ - true - ))) { - res.set(text, makeUniqueName(`_${text}`, identifiers)); - } - }); - return res; - } - function convertExportsAccesses(sourceFile, exports, changes) { - forEachExportReference(sourceFile, (node, isAssignmentLhs) => { - if (isAssignmentLhs) { - return; - } - const { text } = node.name; - changes.replaceNode(sourceFile, node, factory.createIdentifier(exports.get(text) || text)); - }); - } - function forEachExportReference(sourceFile, cb) { - sourceFile.forEachChild(function recur(node) { - if (isPropertyAccessExpression(node) && isExportsOrModuleExportsOrAlias(sourceFile, node.expression) && isIdentifier(node.name)) { - const { parent: parent2 } = node; - cb(node, isBinaryExpression(parent2) && parent2.left === node && parent2.operatorToken.kind === 64 /* EqualsToken */); - } - node.forEachChild(recur); - }); + const parameterName = firstDefined(signature.parameters, (p) => isIdentifier(p.name) && !names.has(p.name.escapedText) ? p.name.getText(sourceFile) : void 0); + if (parameterName === void 0) + return void 0; + const newJSDocParameterTag = factory.updateJSDocParameterTag( + jsDocParameterTag, + jsDocParameterTag.tagName, + factory.createIdentifier(parameterName), + jsDocParameterTag.isBracketed, + jsDocParameterTag.typeExpression, + jsDocParameterTag.isNameFirst, + jsDocParameterTag.comment + ); + const changes = ts_textChanges_exports.ChangeTracker.with(context, (changeTracker) => changeTracker.replaceJSDocComment(sourceFile, jsDocHost, map(tags, (t) => t === jsDocParameterTag ? newJSDocParameterTag : t))); + return createCodeFixActionWithoutFixAll(renameUnmatchedParameter, changes, [Diagnostics.Rename_param_tag_name_0_to_1, name.getText(sourceFile), parameterName]); } - function convertStatement(sourceFile, statement, checker, changes, identifiers, target, exports, useSitesToUnqualify, quotePreference) { - switch (statement.kind) { - case 242 /* VariableStatement */: - convertVariableStatement(sourceFile, statement, changes, checker, identifiers, target, quotePreference); - return false; - case 243 /* ExpressionStatement */: { - const { expression } = statement; - switch (expression.kind) { - case 212 /* CallExpression */: { - if (isRequireCall( - expression, - /*requireStringLiteralLikeArgument*/ - true - )) { - changes.replaceNode(sourceFile, statement, makeImport( - /*defaultImport*/ - void 0, - /*namedImports*/ - void 0, - expression.arguments[0], - quotePreference - )); - } - return false; - } - case 225 /* BinaryExpression */: { - const { operatorToken } = expression; - return operatorToken.kind === 64 /* EqualsToken */ && convertAssignment(sourceFile, checker, expression, changes, exports, useSitesToUnqualify); - } - } + function getInfo13(sourceFile, pos) { + const token = getTokenAtPosition(sourceFile, pos); + if (token.parent && isJSDocParameterTag(token.parent) && isIdentifier(token.parent.name)) { + const jsDocParameterTag = token.parent; + const jsDocHost = getJSDocHost(jsDocParameterTag); + const signature = getHostSignatureFromJSDoc(jsDocParameterTag); + if (jsDocHost && signature) { + return { jsDocHost, signature, name: token.parent.name, jsDocParameterTag }; } - default: - return false; } + return void 0; } - function convertVariableStatement(sourceFile, statement, changes, checker, identifiers, target, quotePreference) { - const { declarationList } = statement; - let foundImport = false; - const converted = map(declarationList.declarations, (decl) => { - const { name, initializer } = decl; - if (initializer) { - if (isExportsOrModuleExportsOrAlias(sourceFile, initializer)) { - foundImport = true; - return convertedImports([]); - } else if (isRequireCall( - initializer, - /*requireStringLiteralLikeArgument*/ - true - )) { - foundImport = true; - return convertSingleImport(name, initializer.arguments[0], checker, identifiers, target, quotePreference); - } else if (isPropertyAccessExpression(initializer) && isRequireCall( - initializer.expression, - /*requireStringLiteralLikeArgument*/ - true - )) { - foundImport = true; - return convertPropertyAccessImport(name, initializer.name.text, initializer.expression.arguments[0], identifiers, quotePreference); - } - } - return convertedImports([factory.createVariableStatement( - /*modifiers*/ - void 0, - factory.createVariableDeclarationList([decl], declarationList.flags) - )]); - }); - if (foundImport) { - changes.replaceNodeWithNodes(sourceFile, statement, flatMap(converted, (c) => c.newImports)); - let combinedUseSites; - forEach(converted, (c) => { - if (c.useSitesToUnqualify) { - copyEntries(c.useSitesToUnqualify, combinedUseSites ?? (combinedUseSites = /* @__PURE__ */ new Map())); + var deleteUnmatchedParameter, renameUnmatchedParameter, errorCodes39; + var init_fixUnmatchedParameter = __esm({ + "src/services/codefixes/fixUnmatchedParameter.ts"() { + "use strict"; + init_ts4(); + init_ts_codefix(); + deleteUnmatchedParameter = "deleteUnmatchedParameter"; + renameUnmatchedParameter = "renameUnmatchedParameter"; + errorCodes39 = [ + Diagnostics.JSDoc_param_tag_has_name_0_but_there_is_no_parameter_with_that_name.code + ]; + registerCodeFix({ + fixIds: [deleteUnmatchedParameter, renameUnmatchedParameter], + errorCodes: errorCodes39, + getCodeActions: function getCodeActionsToFixUnmatchedParameter(context) { + const { sourceFile, span } = context; + const actions2 = []; + const info = getInfo13(sourceFile, span.start); + if (info) { + append(actions2, getDeleteAction(context, info)); + append(actions2, getRenameAction(context, info)); + return actions2; + } + return void 0; + }, + getAllCodeActions: function getAllCodeActionsToFixUnmatchedParameter(context) { + const tagsToSignature = /* @__PURE__ */ new Map(); + return createCombinedCodeActions(ts_textChanges_exports.ChangeTracker.with(context, (changes) => { + eachDiagnostic(context, errorCodes39, ({ file, start }) => { + const info = getInfo13(file, start); + if (info) { + tagsToSignature.set(info.signature, append(tagsToSignature.get(info.signature), info.jsDocParameterTag)); + } + }); + tagsToSignature.forEach((tags, signature) => { + if (context.fixId === deleteUnmatchedParameter) { + const tagsSet = new Set(tags); + changes.filterJSDocTags(signature.getSourceFile(), signature, (t) => !tagsSet.has(t)); + } + }); + })); } }); - return combinedUseSites; } + }); + + // src/services/codefixes/fixUnreferenceableDecoratorMetadata.ts + function getImportDeclaration(sourceFile, program, start) { + const identifier = tryCast(getTokenAtPosition(sourceFile, start), isIdentifier); + if (!identifier || identifier.parent.kind !== 183 /* TypeReference */) + return; + const checker = program.getTypeChecker(); + const symbol = checker.getSymbolAtLocation(identifier); + return find((symbol == null ? void 0 : symbol.declarations) || emptyArray, or(isImportClause, isImportSpecifier, isImportEqualsDeclaration)); } - function convertPropertyAccessImport(name, propertyName, moduleSpecifier, identifiers, quotePreference) { - switch (name.kind) { - case 205 /* ObjectBindingPattern */: - case 206 /* ArrayBindingPattern */: { - const tmp = makeUniqueName(propertyName, identifiers); - return convertedImports([ - makeSingleImport(tmp, propertyName, moduleSpecifier, quotePreference), - makeConst( - /*modifiers*/ - void 0, - name, - factory.createIdentifier(tmp) - ) - ]); - } - case 80 /* Identifier */: - return convertedImports([makeSingleImport(name.text, propertyName, moduleSpecifier, quotePreference)]); - default: - return Debug.assertNever(name, `Convert to ES module got invalid syntax form ${name.kind}`); + function doTypeOnlyImportChange(changes, sourceFile, importDeclaration, program) { + if (importDeclaration.kind === 271 /* ImportEqualsDeclaration */) { + changes.insertModifierBefore(sourceFile, 156 /* TypeKeyword */, importDeclaration.name); + return; } - } - function convertAssignment(sourceFile, checker, assignment, changes, exports, useSitesToUnqualify) { - const { left, right } = assignment; - if (!isPropertyAccessExpression(left)) { - return false; + const importClause = importDeclaration.kind === 273 /* ImportClause */ ? importDeclaration : importDeclaration.parent.parent; + if (importClause.name && importClause.namedBindings) { + return; } - if (isExportsOrModuleExportsOrAlias(sourceFile, left)) { - if (isExportsOrModuleExportsOrAlias(sourceFile, right)) { - changes.delete(sourceFile, assignment.parent); - } else { - const replacement = isObjectLiteralExpression(right) ? tryChangeModuleExportsObject(right, useSitesToUnqualify) : isRequireCall( - right, - /*requireStringLiteralLikeArgument*/ - true - ) ? convertReExportAll(right.arguments[0], checker) : void 0; - if (replacement) { - changes.replaceNodeWithNodes(sourceFile, assignment.parent, replacement[0]); - return replacement[1]; - } else { - changes.replaceRangeWithText(sourceFile, createRange(left.getStart(sourceFile), right.pos), "export default"); - return true; - } - } - } else if (isExportsOrModuleExportsOrAlias(sourceFile, left.expression)) { - convertNamedExport(sourceFile, assignment, changes, exports); + const checker = program.getTypeChecker(); + const importsValue = !!forEachImportClauseDeclaration(importClause, (decl) => { + if (skipAlias(decl.symbol, checker).flags & 111551 /* Value */) + return true; + }); + if (importsValue) { + return; } - return false; + changes.insertModifierBefore(sourceFile, 156 /* TypeKeyword */, importClause); } - function tryChangeModuleExportsObject(object, useSitesToUnqualify) { - const statements = mapAllOrFail(object.properties, (prop) => { - switch (prop.kind) { - case 176 /* GetAccessor */: - case 177 /* SetAccessor */: - case 303 /* ShorthandPropertyAssignment */: - case 304 /* SpreadAssignment */: - return void 0; - case 302 /* PropertyAssignment */: - return !isIdentifier(prop.name) ? void 0 : convertExportsDotXEquals_replaceNode(prop.name.text, prop.initializer, useSitesToUnqualify); - case 173 /* MethodDeclaration */: - return !isIdentifier(prop.name) ? void 0 : functionExpressionToDeclaration(prop.name.text, [factory.createToken(95 /* ExportKeyword */)], prop, useSitesToUnqualify); - default: - Debug.assertNever(prop, `Convert to ES6 got invalid prop kind ${prop.kind}`); - } - }); - return statements && [statements, false]; + function doNamespaceImportChange(changes, sourceFile, importDeclaration, program) { + ts_refactor_exports.doChangeNamedToNamespaceOrDefault(sourceFile, program, changes, importDeclaration.parent); } - function convertNamedExport(sourceFile, assignment, changes, exports) { - const { text } = assignment.left.name; - const rename = exports.get(text); - if (rename !== void 0) { - const newNodes = [ - makeConst( - /*modifiers*/ - void 0, - rename, - assignment.right - ), - makeExportDeclaration([factory.createExportSpecifier( - /*isTypeOnly*/ - false, - rename, - text - )]) - ]; - changes.replaceNodeWithNodes(sourceFile, assignment.parent, newNodes); - } else { - convertExportsPropertyAssignment(assignment, sourceFile, changes); + var fixId32, errorCodes40; + var init_fixUnreferenceableDecoratorMetadata = __esm({ + "src/services/codefixes/fixUnreferenceableDecoratorMetadata.ts"() { + "use strict"; + init_ts4(); + init_ts_codefix(); + fixId32 = "fixUnreferenceableDecoratorMetadata"; + errorCodes40 = [Diagnostics.A_type_referenced_in_a_decorated_signature_must_be_imported_with_import_type_or_a_namespace_import_when_isolatedModules_and_emitDecoratorMetadata_are_enabled.code]; + registerCodeFix({ + errorCodes: errorCodes40, + getCodeActions: (context) => { + const importDeclaration = getImportDeclaration(context.sourceFile, context.program, context.span.start); + if (!importDeclaration) + return; + const namespaceChanges = ts_textChanges_exports.ChangeTracker.with(context, (t) => importDeclaration.kind === 276 /* ImportSpecifier */ && doNamespaceImportChange(t, context.sourceFile, importDeclaration, context.program)); + const typeOnlyChanges = ts_textChanges_exports.ChangeTracker.with(context, (t) => doTypeOnlyImportChange(t, context.sourceFile, importDeclaration, context.program)); + let actions2; + if (namespaceChanges.length) { + actions2 = append(actions2, createCodeFixActionWithoutFixAll(fixId32, namespaceChanges, Diagnostics.Convert_named_imports_to_namespace_import)); + } + if (typeOnlyChanges.length) { + actions2 = append(actions2, createCodeFixActionWithoutFixAll(fixId32, typeOnlyChanges, Diagnostics.Use_import_type)); + } + return actions2; + }, + fixIds: [fixId32] + }); } + }); + + // src/services/codefixes/fixUnusedIdentifier.ts + function changeInferToUnknown(changes, sourceFile, token) { + changes.replaceNode(sourceFile, token.parent, factory.createKeywordTypeNode(159 /* UnknownKeyword */)); } - function convertReExportAll(reExported, checker) { - const moduleSpecifier = reExported.text; - const moduleSymbol = checker.getSymbolAtLocation(reExported); - const exports = moduleSymbol ? moduleSymbol.exports : emptyMap; - return exports.has("export=" /* ExportEquals */) ? [[reExportDefault(moduleSpecifier)], true] : !exports.has("default" /* Default */) ? [[reExportStar(moduleSpecifier)], false] : ( - // If there's some non-default export, must include both `export *` and `export default`. - exports.size > 1 ? [[reExportStar(moduleSpecifier), reExportDefault(moduleSpecifier)], true] : [[reExportDefault(moduleSpecifier)], true] - ); + function createDeleteFix(changes, diag2) { + return createCodeFixAction(fixName3, changes, diag2, fixIdDelete, Diagnostics.Delete_all_unused_declarations); } - function reExportStar(moduleSpecifier) { - return makeExportDeclaration( - /*exportSpecifiers*/ - void 0, - moduleSpecifier - ); + function deleteTypeParameters(changes, sourceFile, token) { + changes.delete(sourceFile, Debug.checkDefined(cast(token.parent, isDeclarationWithTypeParameterChildren).typeParameters, "The type parameter to delete should exist")); } - function reExportDefault(moduleSpecifier) { - return makeExportDeclaration([factory.createExportSpecifier( - /*isTypeOnly*/ - false, - /*propertyName*/ - void 0, - "default" - )], moduleSpecifier); + function isImport(token) { + return token.kind === 102 /* ImportKeyword */ || token.kind === 80 /* Identifier */ && (token.parent.kind === 276 /* ImportSpecifier */ || token.parent.kind === 273 /* ImportClause */); } - function convertExportsPropertyAssignment({ left, right, parent: parent2 }, sourceFile, changes) { - const name = left.name.text; - if ((isFunctionExpression(right) || isArrowFunction(right) || isClassExpression(right)) && (!right.name || right.name.text === name)) { - changes.replaceRange(sourceFile, { pos: left.getStart(sourceFile), end: right.getStart(sourceFile) }, factory.createToken(95 /* ExportKeyword */), { suffix: " " }); - if (!right.name) - changes.insertName(sourceFile, right, name); - const semi = findChildOfKind(parent2, 27 /* SemicolonToken */, sourceFile); - if (semi) - changes.delete(sourceFile, semi); - } else { - changes.replaceNodeRangeWithNodes( - sourceFile, - left.expression, - findChildOfKind(left, 25 /* DotToken */, sourceFile), - [factory.createToken(95 /* ExportKeyword */), factory.createToken(87 /* ConstKeyword */)], - { joiner: " ", suffix: " " } - ); - } + function tryGetFullImport(token) { + return token.kind === 102 /* ImportKeyword */ ? tryCast(token.parent, isImportDeclaration) : void 0; } - function convertExportsDotXEquals_replaceNode(name, exported, useSitesToUnqualify) { - const modifiers = [factory.createToken(95 /* ExportKeyword */)]; - switch (exported.kind) { - case 217 /* FunctionExpression */: { - const { name: expressionName } = exported; - if (expressionName && expressionName.text !== name) { - return exportConst(); - } + function canDeleteEntireVariableStatement(sourceFile, token) { + return isVariableDeclarationList(token.parent) && first(token.parent.getChildren(sourceFile)) === token; + } + function deleteEntireVariableStatement(changes, sourceFile, node) { + changes.delete(sourceFile, node.parent.kind === 243 /* VariableStatement */ ? node.parent : node); + } + function deleteDestructuringElements(changes, sourceFile, node) { + forEach(node.elements, (n) => changes.delete(sourceFile, n)); + } + function deleteDestructuring(context, changes, sourceFile, { parent: parent2 }) { + if (isVariableDeclaration(parent2) && parent2.initializer && isCallLikeExpression(parent2.initializer)) { + if (isVariableDeclarationList(parent2.parent) && length(parent2.parent.declarations) > 1) { + const varStatement = parent2.parent.parent; + const pos = varStatement.getStart(sourceFile); + const end = varStatement.end; + changes.delete(sourceFile, parent2); + changes.insertNodeAt(sourceFile, end, parent2.initializer, { + prefix: getNewLineOrDefaultFromHost(context.host, context.formatContext.options) + sourceFile.text.slice(getPrecedingNonSpaceCharacterPosition(sourceFile.text, pos - 1), pos), + suffix: probablyUsesSemicolons(sourceFile) ? ";" : "" + }); + } else { + changes.replaceNode(sourceFile, parent2.parent, parent2.initializer); } - case 218 /* ArrowFunction */: - return functionExpressionToDeclaration(name, modifiers, exported, useSitesToUnqualify); - case 230 /* ClassExpression */: - return classExpressionToDeclaration(name, modifiers, exported, useSitesToUnqualify); - default: - return exportConst(); - } - function exportConst() { - return makeConst(modifiers, factory.createIdentifier(name), replaceImportUseSites(exported, useSitesToUnqualify)); + } else { + changes.delete(sourceFile, parent2); } } - function replaceImportUseSites(nodeOrNodes, useSitesToUnqualify) { - if (!useSitesToUnqualify || !some(arrayFrom(useSitesToUnqualify.keys()), (original) => rangeContainsRange(nodeOrNodes, original))) { - return nodeOrNodes; + function tryPrefixDeclaration(changes, errorCode, sourceFile, token) { + if (errorCode === Diagnostics.Property_0_is_declared_but_its_value_is_never_read.code) + return; + if (token.kind === 140 /* InferKeyword */) { + token = cast(token.parent, isInferTypeNode).typeParameter.name; } - return isArray(nodeOrNodes) ? getSynthesizedDeepClonesWithReplacements( - nodeOrNodes, - /*includeTrivia*/ - true, - replaceNode - ) : getSynthesizedDeepCloneWithReplacements( - nodeOrNodes, - /*includeTrivia*/ - true, - replaceNode - ); - function replaceNode(original) { - if (original.kind === 210 /* PropertyAccessExpression */) { - const replacement = useSitesToUnqualify.get(original); - useSitesToUnqualify.delete(original); - return replacement; + if (isIdentifier(token) && canPrefix(token)) { + changes.replaceNode(sourceFile, token, factory.createIdentifier(`_${token.text}`)); + if (isParameter(token.parent)) { + getJSDocParameterTags(token.parent).forEach((tag) => { + if (isIdentifier(tag.name)) { + changes.replaceNode(sourceFile, tag.name, factory.createIdentifier(`_${tag.name.text}`)); + } + }); } } } - function convertSingleImport(name, moduleSpecifier, checker, identifiers, target, quotePreference) { - switch (name.kind) { - case 205 /* ObjectBindingPattern */: { - const importSpecifiers = mapAllOrFail(name.elements, (e) => e.dotDotDotToken || e.initializer || e.propertyName && !isIdentifier(e.propertyName) || !isIdentifier(e.name) ? void 0 : makeImportSpecifier2(e.propertyName && e.propertyName.text, e.name.text)); - if (importSpecifiers) { - return convertedImports([makeImport( - /*defaultImport*/ - void 0, - importSpecifiers, - moduleSpecifier, - quotePreference - )]); + function canPrefix(token) { + switch (token.parent.kind) { + case 169 /* Parameter */: + case 168 /* TypeParameter */: + return true; + case 260 /* VariableDeclaration */: { + const varDecl = token.parent; + switch (varDecl.parent.parent.kind) { + case 250 /* ForOfStatement */: + case 249 /* ForInStatement */: + return true; } } - case 206 /* ArrayBindingPattern */: { - const tmp = makeUniqueName(moduleSpecifierToValidIdentifier(moduleSpecifier.text, target), identifiers); - return convertedImports([ - makeImport( - factory.createIdentifier(tmp), - /*namedImports*/ - void 0, - moduleSpecifier, - quotePreference - ), - makeConst( - /*modifiers*/ - void 0, - getSynthesizedDeepClone(name), - factory.createIdentifier(tmp) - ) - ]); - } - case 80 /* Identifier */: - return convertSingleIdentifierImport(name, moduleSpecifier, checker, identifiers, quotePreference); - default: - return Debug.assertNever(name, `Convert to ES module got invalid name kind ${name.kind}`); } + return false; } - function convertSingleIdentifierImport(name, moduleSpecifier, checker, identifiers, quotePreference) { - const nameSymbol = checker.getSymbolAtLocation(name); - const namedBindingsNames = /* @__PURE__ */ new Map(); - let needDefaultImport = false; - let useSitesToUnqualify; - for (const use of identifiers.original.get(name.text)) { - if (checker.getSymbolAtLocation(use) !== nameSymbol || use === name) { - continue; - } - const { parent: parent2 } = use; - if (isPropertyAccessExpression(parent2)) { - const { name: { text: propertyName } } = parent2; - if (propertyName === "default") { - needDefaultImport = true; - const importDefaultName = use.getText(); - (useSitesToUnqualify ?? (useSitesToUnqualify = /* @__PURE__ */ new Map())).set(parent2, factory.createIdentifier(importDefaultName)); - } else { - Debug.assert(parent2.expression === use, "Didn't expect expression === use"); - let idName = namedBindingsNames.get(propertyName); - if (idName === void 0) { - idName = makeUniqueName(propertyName, identifiers); - namedBindingsNames.set(propertyName, idName); - } - (useSitesToUnqualify ?? (useSitesToUnqualify = /* @__PURE__ */ new Map())).set(parent2, factory.createIdentifier(idName)); + function tryDeleteDeclaration(sourceFile, token, changes, checker, sourceFiles, program, cancellationToken, isFixAll) { + tryDeleteDeclarationWorker(token, changes, sourceFile, checker, sourceFiles, program, cancellationToken, isFixAll); + if (isIdentifier(token)) { + ts_FindAllReferences_exports.Core.eachSymbolReferenceInFile(token, checker, sourceFile, (ref) => { + if (isPropertyAccessExpression(ref.parent) && ref.parent.name === ref) + ref = ref.parent; + if (!isFixAll && mayDeleteExpression(ref)) { + changes.delete(sourceFile, ref.parent.parent); } - } else { - needDefaultImport = true; - } - } - const namedBindings = namedBindingsNames.size === 0 ? void 0 : arrayFrom(mapIterator(namedBindingsNames.entries(), ([propertyName, idName]) => factory.createImportSpecifier( - /*isTypeOnly*/ - false, - propertyName === idName ? void 0 : factory.createIdentifier(propertyName), - factory.createIdentifier(idName) - ))); - if (!namedBindings) { - needDefaultImport = true; + }); } - return convertedImports( - [makeImport(needDefaultImport ? getSynthesizedDeepClone(name) : void 0, namedBindings, moduleSpecifier, quotePreference)], - useSitesToUnqualify - ); } - function makeUniqueName(name, identifiers) { - while (identifiers.original.has(name) || identifiers.additional.has(name)) { - name = `_${name}`; + function tryDeleteDeclarationWorker(token, changes, sourceFile, checker, sourceFiles, program, cancellationToken, isFixAll) { + const { parent: parent2 } = token; + if (isParameter(parent2)) { + tryDeleteParameter(changes, sourceFile, parent2, checker, sourceFiles, program, cancellationToken, isFixAll); + } else if (!(isFixAll && isIdentifier(token) && ts_FindAllReferences_exports.Core.isSymbolReferencedInFile(token, checker, sourceFile))) { + const node = isImportClause(parent2) ? token : isComputedPropertyName(parent2) ? parent2.parent : parent2; + Debug.assert(node !== sourceFile, "should not delete whole source file"); + changes.delete(sourceFile, node); } - identifiers.additional.add(name); - return name; } - function collectFreeIdentifiers(file) { - const map2 = createMultiMap(); - forEachFreeIdentifier(file, (id) => map2.add(id.text, id)); - return map2; + function tryDeleteParameter(changes, sourceFile, parameter, checker, sourceFiles, program, cancellationToken, isFixAll = false) { + if (mayDeleteParameter(checker, sourceFile, parameter, sourceFiles, program, cancellationToken, isFixAll)) { + if (parameter.modifiers && parameter.modifiers.length > 0 && (!isIdentifier(parameter.name) || ts_FindAllReferences_exports.Core.isSymbolReferencedInFile(parameter.name, checker, sourceFile))) { + for (const modifier of parameter.modifiers) { + if (isModifier(modifier)) { + changes.deleteModifier(sourceFile, modifier); + } + } + } else if (!parameter.initializer && isNotProvidedArguments(parameter, checker, sourceFiles)) { + changes.delete(sourceFile, parameter); + } + } } - function forEachFreeIdentifier(node, cb) { - if (isIdentifier(node) && isFreeIdentifier(node)) - cb(node); - node.forEachChild((child) => forEachFreeIdentifier(child, cb)); + function isNotProvidedArguments(parameter, checker, sourceFiles) { + const index = parameter.parent.parameters.indexOf(parameter); + return !ts_FindAllReferences_exports.Core.someSignatureUsage(parameter.parent, sourceFiles, checker, (_, call) => !call || call.arguments.length > index); } - function isFreeIdentifier(node) { - const { parent: parent2 } = node; + function mayDeleteParameter(checker, sourceFile, parameter, sourceFiles, program, cancellationToken, isFixAll) { + const { parent: parent2 } = parameter; switch (parent2.kind) { - case 210 /* PropertyAccessExpression */: - return parent2.name !== node; - case 207 /* BindingElement */: - return parent2.propertyName !== node; - case 275 /* ImportSpecifier */: - return parent2.propertyName !== node; - default: + case 174 /* MethodDeclaration */: + case 176 /* Constructor */: + const index = parent2.parameters.indexOf(parameter); + const referent = isMethodDeclaration(parent2) ? parent2.name : parent2; + const entries = ts_FindAllReferences_exports.Core.getReferencedSymbolsForNode(parent2.pos, referent, program, sourceFiles, cancellationToken); + if (entries) { + for (const entry of entries) { + for (const reference of entry.references) { + if (reference.kind === ts_FindAllReferences_exports.EntryKind.Node) { + const isSuperCall2 = isSuperKeyword(reference.node) && isCallExpression(reference.node.parent) && reference.node.parent.arguments.length > index; + const isSuperMethodCall = isPropertyAccessExpression(reference.node.parent) && isSuperKeyword(reference.node.parent.expression) && isCallExpression(reference.node.parent.parent) && reference.node.parent.parent.arguments.length > index; + const isOverriddenMethod = (isMethodDeclaration(reference.node.parent) || isMethodSignature(reference.node.parent)) && reference.node.parent !== parameter.parent && reference.node.parent.parameters.length > index; + if (isSuperCall2 || isSuperMethodCall || isOverriddenMethod) + return false; + } + } + } + } + return true; + case 262 /* FunctionDeclaration */: { + if (parent2.name && isCallbackLike(checker, sourceFile, parent2.name)) { + return isLastParameter(parent2, parameter, isFixAll); + } + return true; + } + case 218 /* FunctionExpression */: + case 219 /* ArrowFunction */: + return isLastParameter(parent2, parameter, isFixAll); + case 178 /* SetAccessor */: + return false; + case 177 /* GetAccessor */: return true; + default: + return Debug.failBadSyntaxKind(parent2); } } - function functionExpressionToDeclaration(name, additionalModifiers, fn, useSitesToUnqualify) { - return factory.createFunctionDeclaration( - concatenate(additionalModifiers, getSynthesizedDeepClones(fn.modifiers)), - getSynthesizedDeepClone(fn.asteriskToken), - name, - getSynthesizedDeepClones(fn.typeParameters), - getSynthesizedDeepClones(fn.parameters), - getSynthesizedDeepClone(fn.type), - factory.converters.convertToFunctionBlock(replaceImportUseSites(fn.body, useSitesToUnqualify)) - ); - } - function classExpressionToDeclaration(name, additionalModifiers, cls, useSitesToUnqualify) { - return factory.createClassDeclaration( - concatenate(additionalModifiers, getSynthesizedDeepClones(cls.modifiers)), - name, - getSynthesizedDeepClones(cls.typeParameters), - getSynthesizedDeepClones(cls.heritageClauses), - replaceImportUseSites(cls.members, useSitesToUnqualify) - ); - } - function makeSingleImport(localName, propertyName, moduleSpecifier, quotePreference) { - return propertyName === "default" ? makeImport( - factory.createIdentifier(localName), - /*namedImports*/ - void 0, - moduleSpecifier, - quotePreference - ) : makeImport( - /*defaultImport*/ - void 0, - [makeImportSpecifier2(propertyName, localName)], - moduleSpecifier, - quotePreference - ); - } - function makeImportSpecifier2(propertyName, name) { - return factory.createImportSpecifier( - /*isTypeOnly*/ - false, - propertyName !== void 0 && propertyName !== name ? factory.createIdentifier(propertyName) : void 0, - factory.createIdentifier(name) - ); - } - function makeConst(modifiers, name, init) { - return factory.createVariableStatement( - modifiers, - factory.createVariableDeclarationList( - [factory.createVariableDeclaration( - name, - /*exclamationToken*/ - void 0, - /*type*/ - void 0, - init - )], - 2 /* Const */ - ) - ); + function isCallbackLike(checker, sourceFile, name) { + return !!ts_FindAllReferences_exports.Core.eachSymbolReferenceInFile(name, checker, sourceFile, (reference) => isIdentifier(reference) && isCallExpression(reference.parent) && reference.parent.arguments.includes(reference)); } - function makeExportDeclaration(exportSpecifiers, moduleSpecifier) { - return factory.createExportDeclaration( - /*modifiers*/ - void 0, - /*isTypeOnly*/ - false, - exportSpecifiers && factory.createNamedExports(exportSpecifiers), - moduleSpecifier === void 0 ? void 0 : factory.createStringLiteral(moduleSpecifier) - ); + function isLastParameter(func, parameter, isFixAll) { + const parameters = func.parameters; + const index = parameters.indexOf(parameter); + Debug.assert(index !== -1, "The parameter should already be in the list"); + return isFixAll ? parameters.slice(index + 1).every((p) => isIdentifier(p.name) && !p.symbol.isReferenced) : index === parameters.length - 1; } - function convertedImports(newImports, useSitesToUnqualify) { - return { - newImports, - useSitesToUnqualify - }; + function mayDeleteExpression(node) { + return (isBinaryExpression(node.parent) && node.parent.left === node || (isPostfixUnaryExpression(node.parent) || isPrefixUnaryExpression(node.parent)) && node.parent.operand === node) && isExpressionStatement(node.parent.parent); } - var init_convertToEsModule = __esm({ - "src/services/codefixes/convertToEsModule.ts"() { + var fixName3, fixIdPrefix, fixIdDelete, fixIdDeleteImports, fixIdInfer, errorCodes41; + var init_fixUnusedIdentifier = __esm({ + "src/services/codefixes/fixUnusedIdentifier.ts"() { "use strict"; init_ts4(); init_ts_codefix(); + fixName3 = "unusedIdentifier"; + fixIdPrefix = "unusedIdentifier_prefix"; + fixIdDelete = "unusedIdentifier_delete"; + fixIdDeleteImports = "unusedIdentifier_deleteImports"; + fixIdInfer = "unusedIdentifier_infer"; + errorCodes41 = [ + Diagnostics._0_is_declared_but_its_value_is_never_read.code, + Diagnostics._0_is_declared_but_never_used.code, + Diagnostics.Property_0_is_declared_but_its_value_is_never_read.code, + Diagnostics.All_imports_in_import_declaration_are_unused.code, + Diagnostics.All_destructured_elements_are_unused.code, + Diagnostics.All_variables_are_unused.code, + Diagnostics.All_type_parameters_are_unused.code + ]; registerCodeFix({ - errorCodes: [Diagnostics.File_is_a_CommonJS_module_it_may_be_converted_to_an_ES_module.code], + errorCodes: errorCodes41, getCodeActions(context) { - const { sourceFile, program, preferences } = context; - const changes = ts_textChanges_exports.ChangeTracker.with(context, (changes2) => { - const moduleExportsChangedToDefault = convertFileToEsModule(sourceFile, program.getTypeChecker(), changes2, getEmitScriptTarget(program.getCompilerOptions()), getQuotePreference(sourceFile, preferences)); - if (moduleExportsChangedToDefault) { - for (const importingFile of program.getSourceFiles()) { - fixImportOfModuleExports(importingFile, sourceFile, changes2, getQuotePreference(importingFile, preferences)); - } + const { errorCode, sourceFile, program, cancellationToken } = context; + const checker = program.getTypeChecker(); + const sourceFiles = program.getSourceFiles(); + const token = getTokenAtPosition(sourceFile, context.span.start); + if (isJSDocTemplateTag(token)) { + return [createDeleteFix(ts_textChanges_exports.ChangeTracker.with(context, (t) => t.delete(sourceFile, token)), Diagnostics.Remove_template_tag)]; + } + if (token.kind === 30 /* LessThanToken */) { + const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => deleteTypeParameters(t, sourceFile, token)); + return [createDeleteFix(changes, Diagnostics.Remove_type_parameters)]; + } + const importDecl = tryGetFullImport(token); + if (importDecl) { + const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => t.delete(sourceFile, importDecl)); + return [createCodeFixAction(fixName3, changes, [Diagnostics.Remove_import_from_0, showModuleSpecifier(importDecl)], fixIdDeleteImports, Diagnostics.Delete_all_unused_imports)]; + } else if (isImport(token)) { + const deletion = ts_textChanges_exports.ChangeTracker.with(context, (t) => tryDeleteDeclaration( + sourceFile, + token, + t, + checker, + sourceFiles, + program, + cancellationToken, + /*isFixAll*/ + false + )); + if (deletion.length) { + return [createCodeFixAction(fixName3, deletion, [Diagnostics.Remove_unused_declaration_for_Colon_0, token.getText(sourceFile)], fixIdDeleteImports, Diagnostics.Delete_all_unused_imports)]; } - }); - return [createCodeFixActionWithoutFixAll("convertToEsModule", changes, Diagnostics.Convert_to_ES_module)]; - } - }); - } - }); - - // src/services/codefixes/correctQualifiedNameToIndexedAccessType.ts - function getQualifiedName(sourceFile, pos) { - const qualifiedName = findAncestor(getTokenAtPosition(sourceFile, pos), isQualifiedName); - Debug.assert(!!qualifiedName, "Expected position to be owned by a qualified name."); - return isIdentifier(qualifiedName.left) ? qualifiedName : void 0; - } - function doChange10(changeTracker, sourceFile, qualifiedName) { - const rightText = qualifiedName.right.text; - const replacement = factory.createIndexedAccessTypeNode( - factory.createTypeReferenceNode( - qualifiedName.left, - /*typeArguments*/ - void 0 - ), - factory.createLiteralTypeNode(factory.createStringLiteral(rightText)) - ); - changeTracker.replaceNode(sourceFile, qualifiedName, replacement); - } - var fixId11, errorCodes12; - var init_correctQualifiedNameToIndexedAccessType = __esm({ - "src/services/codefixes/correctQualifiedNameToIndexedAccessType.ts"() { - "use strict"; - init_ts4(); - init_ts_codefix(); - fixId11 = "correctQualifiedNameToIndexedAccessType"; - errorCodes12 = [Diagnostics.Cannot_access_0_1_because_0_is_a_type_but_not_a_namespace_Did_you_mean_to_retrieve_the_type_of_the_property_1_in_0_with_0_1.code]; - registerCodeFix({ - errorCodes: errorCodes12, - getCodeActions(context) { - const qualifiedName = getQualifiedName(context.sourceFile, context.span.start); - if (!qualifiedName) - return void 0; - const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange10(t, context.sourceFile, qualifiedName)); - const newText = `${qualifiedName.left.text}["${qualifiedName.right.text}"]`; - return [createCodeFixAction(fixId11, changes, [Diagnostics.Rewrite_as_the_indexed_access_type_0, newText], fixId11, Diagnostics.Rewrite_all_as_indexed_access_types)]; - }, - fixIds: [fixId11], - getAllCodeActions: (context) => codeFixAll(context, errorCodes12, (changes, diag2) => { - const q = getQualifiedName(diag2.file, diag2.start); - if (q) { - doChange10(changes, diag2.file, q); } - }) + if (isObjectBindingPattern(token.parent) || isArrayBindingPattern(token.parent)) { + if (isParameter(token.parent.parent)) { + const elements = token.parent.elements; + const diagnostic = [ + elements.length > 1 ? Diagnostics.Remove_unused_declarations_for_Colon_0 : Diagnostics.Remove_unused_declaration_for_Colon_0, + map(elements, (e) => e.getText(sourceFile)).join(", ") + ]; + return [ + createDeleteFix(ts_textChanges_exports.ChangeTracker.with(context, (t) => deleteDestructuringElements(t, sourceFile, token.parent)), diagnostic) + ]; + } + return [ + createDeleteFix(ts_textChanges_exports.ChangeTracker.with(context, (t) => deleteDestructuring(context, t, sourceFile, token.parent)), Diagnostics.Remove_unused_destructuring_declaration) + ]; + } + if (canDeleteEntireVariableStatement(sourceFile, token)) { + return [ + createDeleteFix(ts_textChanges_exports.ChangeTracker.with(context, (t) => deleteEntireVariableStatement(t, sourceFile, token.parent)), Diagnostics.Remove_variable_statement) + ]; + } + const result = []; + if (token.kind === 140 /* InferKeyword */) { + const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => changeInferToUnknown(t, sourceFile, token)); + const name = cast(token.parent, isInferTypeNode).typeParameter.name.text; + result.push(createCodeFixAction(fixName3, changes, [Diagnostics.Replace_infer_0_with_unknown, name], fixIdInfer, Diagnostics.Replace_all_unused_infer_with_unknown)); + } else { + const deletion = ts_textChanges_exports.ChangeTracker.with(context, (t) => tryDeleteDeclaration( + sourceFile, + token, + t, + checker, + sourceFiles, + program, + cancellationToken, + /*isFixAll*/ + false + )); + if (deletion.length) { + const name = isComputedPropertyName(token.parent) ? token.parent : token; + result.push(createDeleteFix(deletion, [Diagnostics.Remove_unused_declaration_for_Colon_0, name.getText(sourceFile)])); + } + } + const prefix = ts_textChanges_exports.ChangeTracker.with(context, (t) => tryPrefixDeclaration(t, errorCode, sourceFile, token)); + if (prefix.length) { + result.push(createCodeFixAction(fixName3, prefix, [Diagnostics.Prefix_0_with_an_underscore, token.getText(sourceFile)], fixIdPrefix, Diagnostics.Prefix_all_unused_declarations_with_where_possible)); + } + return result; + }, + fixIds: [fixIdPrefix, fixIdDelete, fixIdDeleteImports, fixIdInfer], + getAllCodeActions: (context) => { + const { sourceFile, program, cancellationToken } = context; + const checker = program.getTypeChecker(); + const sourceFiles = program.getSourceFiles(); + return codeFixAll(context, errorCodes41, (changes, diag2) => { + const token = getTokenAtPosition(sourceFile, diag2.start); + switch (context.fixId) { + case fixIdPrefix: + tryPrefixDeclaration(changes, diag2.code, sourceFile, token); + break; + case fixIdDeleteImports: { + const importDecl = tryGetFullImport(token); + if (importDecl) { + changes.delete(sourceFile, importDecl); + } else if (isImport(token)) { + tryDeleteDeclaration( + sourceFile, + token, + changes, + checker, + sourceFiles, + program, + cancellationToken, + /*isFixAll*/ + true + ); + } + break; + } + case fixIdDelete: { + if (token.kind === 140 /* InferKeyword */ || isImport(token)) { + break; + } else if (isJSDocTemplateTag(token)) { + changes.delete(sourceFile, token); + } else if (token.kind === 30 /* LessThanToken */) { + deleteTypeParameters(changes, sourceFile, token); + } else if (isObjectBindingPattern(token.parent)) { + if (token.parent.parent.initializer) { + break; + } else if (!isParameter(token.parent.parent) || isNotProvidedArguments(token.parent.parent, checker, sourceFiles)) { + changes.delete(sourceFile, token.parent.parent); + } + } else if (isArrayBindingPattern(token.parent.parent) && token.parent.parent.parent.initializer) { + break; + } else if (canDeleteEntireVariableStatement(sourceFile, token)) { + deleteEntireVariableStatement(changes, sourceFile, token.parent); + } else { + tryDeleteDeclaration( + sourceFile, + token, + changes, + checker, + sourceFiles, + program, + cancellationToken, + /*isFixAll*/ + true + ); + } + break; + } + case fixIdInfer: + if (token.kind === 140 /* InferKeyword */) { + changeInferToUnknown(changes, sourceFile, token); + } + break; + default: + Debug.fail(JSON.stringify(context.fixId)); + } + }); + } }); } }); - // src/services/codefixes/convertToTypeOnlyExport.ts - function getExportSpecifierForDiagnosticSpan(span, sourceFile) { - return tryCast(getTokenAtPosition(sourceFile, span.start).parent, isExportSpecifier); - } - function fixSingleExportDeclaration(changes, exportSpecifier, context) { - if (!exportSpecifier) { - return; + // src/services/codefixes/fixUnreachableCode.ts + function doChange26(changes, sourceFile, start, length2, errorCode) { + const token = getTokenAtPosition(sourceFile, start); + const statement = findAncestor(token, isStatement); + if (statement.getStart(sourceFile) !== token.getStart(sourceFile)) { + const logData = JSON.stringify({ + statementKind: Debug.formatSyntaxKind(statement.kind), + tokenKind: Debug.formatSyntaxKind(token.kind), + errorCode, + start, + length: length2 + }); + Debug.fail("Token and statement should start at the same point. " + logData); } - const exportClause = exportSpecifier.parent; - const exportDeclaration = exportClause.parent; - const typeExportSpecifiers = getTypeExportSpecifiers(exportSpecifier, context); - if (typeExportSpecifiers.length === exportClause.elements.length) { - changes.insertModifierBefore(context.sourceFile, 156 /* TypeKeyword */, exportClause); + const container = (isBlock(statement.parent) ? statement.parent : statement).parent; + if (!isBlock(statement.parent) || statement === first(statement.parent.statements)) { + switch (container.kind) { + case 245 /* IfStatement */: + if (container.elseStatement) { + if (isBlock(statement.parent)) { + break; + } else { + changes.replaceNode(sourceFile, statement, factory.createBlock(emptyArray)); + } + return; + } + case 247 /* WhileStatement */: + case 248 /* ForStatement */: + changes.delete(sourceFile, container); + return; + } + } + if (isBlock(statement.parent)) { + const end = start + length2; + const lastStatement = Debug.checkDefined(lastWhere(sliceAfter(statement.parent.statements, statement), (s) => s.pos < end), "Some statement should be last"); + changes.deleteNodeRange(sourceFile, statement, lastStatement); } else { - const valueExportDeclaration = factory.updateExportDeclaration( - exportDeclaration, - exportDeclaration.modifiers, - /*isTypeOnly*/ - false, - factory.updateNamedExports(exportClause, filter(exportClause.elements, (e) => !contains(typeExportSpecifiers, e))), - exportDeclaration.moduleSpecifier, - /*assertClause*/ - void 0 - ); - const typeExportDeclaration = factory.createExportDeclaration( - /*modifiers*/ - void 0, - /*isTypeOnly*/ - true, - factory.createNamedExports(typeExportSpecifiers), - exportDeclaration.moduleSpecifier, - /*assertClause*/ - void 0 - ); - changes.replaceNode(context.sourceFile, exportDeclaration, valueExportDeclaration, { - leadingTriviaOption: ts_textChanges_exports.LeadingTriviaOption.IncludeAll, - trailingTriviaOption: ts_textChanges_exports.TrailingTriviaOption.Exclude - }); - changes.insertNodeAfter(context.sourceFile, exportDeclaration, typeExportDeclaration); + changes.delete(sourceFile, statement); } } - function getTypeExportSpecifiers(originExportSpecifier, context) { - const exportClause = originExportSpecifier.parent; - if (exportClause.elements.length === 1) { - return exportClause.elements; + function lastWhere(a, pred) { + let last2; + for (const value of a) { + if (!pred(value)) + break; + last2 = value; } - const diagnostics = getDiagnosticsWithinSpan( - createTextSpanFromNode(exportClause), - context.program.getSemanticDiagnostics(context.sourceFile, context.cancellationToken) - ); - return filter(exportClause.elements, (element) => { - var _a; - return element === originExportSpecifier || ((_a = findDiagnosticForNode(element, diagnostics)) == null ? void 0 : _a.code) === errorCodes13[0]; - }); + return last2; } - var errorCodes13, fixId12; - var init_convertToTypeOnlyExport = __esm({ - "src/services/codefixes/convertToTypeOnlyExport.ts"() { + var fixId33, errorCodes42; + var init_fixUnreachableCode = __esm({ + "src/services/codefixes/fixUnreachableCode.ts"() { "use strict"; init_ts4(); init_ts_codefix(); - errorCodes13 = [Diagnostics.Re_exporting_a_type_when_0_is_enabled_requires_using_export_type.code]; - fixId12 = "convertToTypeOnlyExport"; + fixId33 = "fixUnreachableCode"; + errorCodes42 = [Diagnostics.Unreachable_code_detected.code]; registerCodeFix({ - errorCodes: errorCodes13, - getCodeActions: function getCodeActionsToConvertToTypeOnlyExport(context) { - const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => fixSingleExportDeclaration(t, getExportSpecifierForDiagnosticSpan(context.span, context.sourceFile), context)); - if (changes.length) { - return [createCodeFixAction(fixId12, changes, Diagnostics.Convert_to_type_only_export, fixId12, Diagnostics.Convert_all_re_exported_types_to_type_only_exports)]; - } + errorCodes: errorCodes42, + getCodeActions(context) { + const syntacticDiagnostics = context.program.getSyntacticDiagnostics(context.sourceFile, context.cancellationToken); + if (syntacticDiagnostics.length) + return; + const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange26(t, context.sourceFile, context.span.start, context.span.length, context.errorCode)); + return [createCodeFixAction(fixId33, changes, Diagnostics.Remove_unreachable_code, fixId33, Diagnostics.Remove_all_unreachable_code)]; }, - fixIds: [fixId12], - getAllCodeActions: function getAllCodeActionsToConvertToTypeOnlyExport(context) { - const fixedExportDeclarations = /* @__PURE__ */ new Map(); - return codeFixAll(context, errorCodes13, (changes, diag2) => { - const exportSpecifier = getExportSpecifierForDiagnosticSpan(diag2, context.sourceFile); - if (exportSpecifier && addToSeen(fixedExportDeclarations, getNodeId(exportSpecifier.parent.parent))) { - fixSingleExportDeclaration(changes, exportSpecifier, context); - } - }); - } + fixIds: [fixId33], + getAllCodeActions: (context) => codeFixAll(context, errorCodes42, (changes, diag2) => doChange26(changes, diag2.file, diag2.start, diag2.length, diag2.code)) }); } }); - // src/services/codefixes/convertToTypeOnlyImport.ts - function getDeclaration2(sourceFile, pos) { - const { parent: parent2 } = getTokenAtPosition(sourceFile, pos); - return isImportSpecifier(parent2) || isImportDeclaration(parent2) && parent2.importClause ? parent2 : void 0; - } - function doChange11(changes, sourceFile, declaration) { - if (isImportSpecifier(declaration)) { - changes.replaceNode(sourceFile, declaration, factory.updateImportSpecifier( - declaration, - /*isTypeOnly*/ - true, - declaration.propertyName, - declaration.name - )); - } else { - const importClause = declaration.importClause; - if (importClause.name && importClause.namedBindings) { - changes.replaceNodeWithNodes(sourceFile, declaration, [ - factory.createImportDeclaration( - getSynthesizedDeepClones( - declaration.modifiers, - /*includeTrivia*/ - true - ), - factory.createImportClause( - /*isTypeOnly*/ - true, - getSynthesizedDeepClone( - importClause.name, - /*includeTrivia*/ - true - ), - /*namedBindings*/ - void 0 - ), - getSynthesizedDeepClone( - declaration.moduleSpecifier, - /*includeTrivia*/ - true - ), - getSynthesizedDeepClone( - declaration.assertClause, - /*includeTrivia*/ - true - ) - ), - factory.createImportDeclaration( - getSynthesizedDeepClones( - declaration.modifiers, - /*includeTrivia*/ - true - ), - factory.createImportClause( - /*isTypeOnly*/ - true, - /*name*/ - void 0, - getSynthesizedDeepClone( - importClause.namedBindings, - /*includeTrivia*/ - true - ) - ), - getSynthesizedDeepClone( - declaration.moduleSpecifier, - /*includeTrivia*/ - true - ), - getSynthesizedDeepClone( - declaration.assertClause, - /*includeTrivia*/ - true - ) - ) - ]); - } else { - const importDeclaration = factory.updateImportDeclaration( - declaration, - declaration.modifiers, - factory.updateImportClause( - importClause, - /*isTypeOnly*/ - true, - importClause.name, - importClause.namedBindings - ), - declaration.moduleSpecifier, - declaration.assertClause - ); - changes.replaceNode(sourceFile, declaration, importDeclaration); - } - } + // src/services/codefixes/fixUnusedLabel.ts + function doChange27(changes, sourceFile, start) { + const token = getTokenAtPosition(sourceFile, start); + const labeledStatement = cast(token.parent, isLabeledStatement); + const pos = token.getStart(sourceFile); + const statementPos = labeledStatement.statement.getStart(sourceFile); + const end = positionsAreOnSameLine(pos, statementPos, sourceFile) ? statementPos : skipTrivia( + sourceFile.text, + findChildOfKind(labeledStatement, 59 /* ColonToken */, sourceFile).end, + /*stopAfterLineBreak*/ + true + ); + changes.deleteRange(sourceFile, { pos, end }); } - var errorCodes14, fixId13; - var init_convertToTypeOnlyImport = __esm({ - "src/services/codefixes/convertToTypeOnlyImport.ts"() { + var fixId34, errorCodes43; + var init_fixUnusedLabel = __esm({ + "src/services/codefixes/fixUnusedLabel.ts"() { "use strict"; init_ts4(); init_ts_codefix(); - errorCodes14 = [ - Diagnostics.This_import_is_never_used_as_a_value_and_must_use_import_type_because_importsNotUsedAsValues_is_set_to_error.code, - Diagnostics._0_is_a_type_and_must_be_imported_using_a_type_only_import_when_verbatimModuleSyntax_is_enabled.code - ]; - fixId13 = "convertToTypeOnlyImport"; + fixId34 = "fixUnusedLabel"; + errorCodes43 = [Diagnostics.Unused_label.code]; registerCodeFix({ - errorCodes: errorCodes14, - getCodeActions: function getCodeActionsToConvertToTypeOnlyImport(context) { - const declaration = getDeclaration2(context.sourceFile, context.span.start); - if (declaration) { - const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange11(t, context.sourceFile, declaration)); - return [createCodeFixAction(fixId13, changes, Diagnostics.Convert_to_type_only_import, fixId13, Diagnostics.Convert_all_imports_not_used_as_a_value_to_type_only_imports)]; - } - return void 0; + errorCodes: errorCodes43, + getCodeActions(context) { + const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange27(t, context.sourceFile, context.span.start)); + return [createCodeFixAction(fixId34, changes, Diagnostics.Remove_unused_label, fixId34, Diagnostics.Remove_all_unused_labels)]; }, - fixIds: [fixId13], - getAllCodeActions: function getAllCodeActionsToConvertToTypeOnlyImport(context) { - return codeFixAll(context, errorCodes14, (changes, diag2) => { - const declaration = getDeclaration2(diag2.file, diag2.start); - if (declaration) { - doChange11(changes, diag2.file, declaration); - } - }); - } + fixIds: [fixId34], + getAllCodeActions: (context) => codeFixAll(context, errorCodes43, (changes, diag2) => doChange27(changes, diag2.file, diag2.start)) }); } }); - // src/services/codefixes/convertTypedefToType.ts - function doChange12(changes, node, sourceFile) { - if (isJSDocTypedefTag(node)) { - fixSingleTypeDef(changes, node, sourceFile); - } + // src/services/codefixes/fixJSDocTypes.ts + function doChange28(changes, sourceFile, oldTypeNode, newType, checker) { + changes.replaceNode(sourceFile, oldTypeNode, checker.typeToTypeNode( + newType, + /*enclosingDeclaration*/ + oldTypeNode, + /*flags*/ + void 0 + )); } - function fixSingleTypeDef(changes, typeDefNode, sourceFile) { - if (!typeDefNode) - return; - const declaration = createDeclaration(typeDefNode); - if (!declaration) - return; - const comment = typeDefNode.parent; - changes.replaceNode( - sourceFile, - comment, - declaration - ); + function getInfo14(sourceFile, pos, checker) { + const decl = findAncestor(getTokenAtPosition(sourceFile, pos), isTypeContainer); + const typeNode = decl && decl.type; + return typeNode && { typeNode, type: getType(checker, typeNode) }; } - function createDeclaration(tag) { - var _a; - const { typeExpression } = tag; - if (!typeExpression) - return; - const typeName = (_a = tag.name) == null ? void 0 : _a.getText(); - if (!typeName) - return; - if (typeExpression.kind === 328 /* JSDocTypeLiteral */) { - return createInterfaceForTypeLiteral(typeName, typeExpression); - } - if (typeExpression.kind === 315 /* JSDocTypeExpression */) { - return createTypeAliasForTypeExpression(typeName, typeExpression); + function isTypeContainer(node) { + switch (node.kind) { + case 234 /* AsExpression */: + case 179 /* CallSignature */: + case 180 /* ConstructSignature */: + case 262 /* FunctionDeclaration */: + case 177 /* GetAccessor */: + case 181 /* IndexSignature */: + case 200 /* MappedType */: + case 174 /* MethodDeclaration */: + case 173 /* MethodSignature */: + case 169 /* Parameter */: + case 172 /* PropertyDeclaration */: + case 171 /* PropertySignature */: + case 178 /* SetAccessor */: + case 265 /* TypeAliasDeclaration */: + case 216 /* TypeAssertionExpression */: + case 260 /* VariableDeclaration */: + return true; + default: + return false; } } - function createInterfaceForTypeLiteral(typeName, typeLiteral) { - const propertySignatures = createSignatureFromTypeLiteral(typeLiteral); - if (!some(propertySignatures)) - return; - const interfaceDeclaration = factory.createInterfaceDeclaration( - /*modifiers*/ - void 0, - typeName, - /*typeParameters*/ - void 0, - /*heritageClauses*/ - void 0, - propertySignatures - ); - return interfaceDeclaration; - } - function createTypeAliasForTypeExpression(typeName, typeExpression) { - const typeReference = getSynthesizedDeepClone(typeExpression.type); - if (!typeReference) - return; - const declaration = factory.createTypeAliasDeclaration( - /*modifiers*/ - void 0, - factory.createIdentifier(typeName), - /*typeParameters*/ - void 0, - typeReference - ); - return declaration; - } - function createSignatureFromTypeLiteral(typeLiteral) { - const propertyTags = typeLiteral.jsDocPropertyTags; - if (!some(propertyTags)) - return; - const getSignature = (tag) => { - var _a; - const name = getPropertyName(tag); - const type = (_a = tag.typeExpression) == null ? void 0 : _a.type; - const isOptional = tag.isBracketed; - let typeReference; - if (type && isJSDocTypeLiteral(type)) { - const signatures = createSignatureFromTypeLiteral(type); - typeReference = factory.createTypeLiteralNode(signatures); - } else if (type) { - typeReference = getSynthesizedDeepClone(type); - } - if (typeReference && name) { - const questionToken = isOptional ? factory.createToken(58 /* QuestionToken */) : void 0; - const prop = factory.createPropertySignature( - /*modifiers*/ - void 0, - name, - questionToken, - typeReference - ); - return prop; + function getType(checker, node) { + if (isJSDocNullableType(node)) { + const type = checker.getTypeFromTypeNode(node.type); + if (type === checker.getNeverType() || type === checker.getVoidType()) { + return type; } - }; - const props = mapDefined(propertyTags, getSignature); - return props; - } - function getPropertyName(tag) { - return tag.name.kind === 80 /* Identifier */ ? tag.name.text : tag.name.right.text; - } - function getJSDocTypedefNode(node) { - if (hasJSDocNodes(node)) { - return forEach(node.jsDoc, (node2) => { - var _a; - return (_a = node2.tags) == null ? void 0 : _a.find(isJSDocTypedefTag); - }); + return checker.getUnionType( + append([type, checker.getUndefinedType()], node.postfix ? void 0 : checker.getNullType()) + ); } - return void 0; + return checker.getTypeFromTypeNode(node); } - var fixId14, errorCodes15; - var init_convertTypedefToType = __esm({ - "src/services/codefixes/convertTypedefToType.ts"() { + var fixIdPlain, fixIdNullable, errorCodes44; + var init_fixJSDocTypes = __esm({ + "src/services/codefixes/fixJSDocTypes.ts"() { "use strict"; init_ts4(); init_ts_codefix(); - fixId14 = "convertTypedefToType"; - errorCodes15 = [Diagnostics.JSDoc_typedef_may_be_converted_to_TypeScript_type.code]; + fixIdPlain = "fixJSDocTypes_plain"; + fixIdNullable = "fixJSDocTypes_nullable"; + errorCodes44 = [ + Diagnostics.JSDoc_types_can_only_be_used_inside_documentation_comments.code, + Diagnostics._0_at_the_end_of_a_type_is_not_valid_TypeScript_syntax_Did_you_mean_to_write_1.code, + Diagnostics._0_at_the_start_of_a_type_is_not_valid_TypeScript_syntax_Did_you_mean_to_write_1.code + ]; registerCodeFix({ - fixIds: [fixId14], - errorCodes: errorCodes15, + errorCodes: errorCodes44, getCodeActions(context) { - const node = getTokenAtPosition( - context.sourceFile, - context.span.start - ); - if (!node) - return; - const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange12(t, node, context.sourceFile)); - if (changes.length > 0) { - return [ - createCodeFixAction( - fixId14, - changes, - Diagnostics.Convert_typedef_to_TypeScript_type, - fixId14, - Diagnostics.Convert_all_typedef_to_TypeScript_types - ) - ]; + const { sourceFile } = context; + const checker = context.program.getTypeChecker(); + const info = getInfo14(sourceFile, context.span.start, checker); + if (!info) + return void 0; + const { typeNode, type } = info; + const original = typeNode.getText(sourceFile); + const actions2 = [fix(type, fixIdPlain, Diagnostics.Change_all_jsdoc_style_types_to_TypeScript)]; + if (typeNode.kind === 321 /* JSDocNullableType */) { + actions2.push(fix(type, fixIdNullable, Diagnostics.Change_all_jsdoc_style_types_to_TypeScript_and_add_undefined_to_nullable_types)); + } + return actions2; + function fix(type2, fixId52, fixAllDescription) { + const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange28(t, sourceFile, typeNode, type2, checker)); + return createCodeFixAction("jdocTypes", changes, [Diagnostics.Change_0_to_1, original, checker.typeToString(type2)], fixId52, fixAllDescription); } }, - getAllCodeActions: (context) => codeFixAll(context, errorCodes15, (changes, diag2) => { - const node = getTokenAtPosition(diag2.file, diag2.start); - if (node) - doChange12(changes, node, diag2.file); - }) + fixIds: [fixIdPlain, fixIdNullable], + getAllCodeActions(context) { + const { fixId: fixId52, program, sourceFile } = context; + const checker = program.getTypeChecker(); + return codeFixAll(context, errorCodes44, (changes, err) => { + const info = getInfo14(err.file, err.start, checker); + if (!info) + return; + const { typeNode, type } = info; + const fixedType = typeNode.kind === 321 /* JSDocNullableType */ && fixId52 === fixIdNullable ? checker.getNullableType(type, 32768 /* Undefined */) : type; + doChange28(changes, sourceFile, typeNode, fixedType, checker); + }); + } }); } }); - // src/services/codefixes/convertLiteralTypeToMappedType.ts - function getInfo5(sourceFile, pos) { - const token = getTokenAtPosition(sourceFile, pos); + // src/services/codefixes/fixMissingCallParentheses.ts + function doChange29(changes, sourceFile, name) { + changes.replaceNodeWithText(sourceFile, name, `${name.text}()`); + } + function getCallName(sourceFile, start) { + const token = getTokenAtPosition(sourceFile, start); + if (isPropertyAccessExpression(token.parent)) { + let current = token.parent; + while (isPropertyAccessExpression(current.parent)) { + current = current.parent; + } + return current.name; + } if (isIdentifier(token)) { - const propertySignature = cast(token.parent.parent, isPropertySignature); - const propertyName = token.getText(sourceFile); - return { - container: cast(propertySignature.parent, isTypeLiteralNode), - typeNode: propertySignature.type, - constraint: propertyName, - name: propertyName === "K" ? "P" : "K" - }; + return token; } return void 0; } - function doChange13(changes, sourceFile, { container, typeNode, constraint, name }) { - changes.replaceNode(sourceFile, container, factory.createMappedTypeNode( - /*readonlyToken*/ - void 0, - factory.createTypeParameterDeclaration( - /*modifiers*/ - void 0, - name, - factory.createTypeReferenceNode(constraint) - ), - /*nameType*/ - void 0, - /*questionToken*/ - void 0, - typeNode, - /*members*/ - void 0 - )); - } - var fixId15, errorCodes16; - var init_convertLiteralTypeToMappedType = __esm({ - "src/services/codefixes/convertLiteralTypeToMappedType.ts"() { + var fixId35, errorCodes45; + var init_fixMissingCallParentheses = __esm({ + "src/services/codefixes/fixMissingCallParentheses.ts"() { "use strict"; init_ts4(); init_ts_codefix(); - fixId15 = "convertLiteralTypeToMappedType"; - errorCodes16 = [Diagnostics._0_only_refers_to_a_type_but_is_being_used_as_a_value_here_Did_you_mean_to_use_1_in_0.code]; + fixId35 = "fixMissingCallParentheses"; + errorCodes45 = [ + Diagnostics.This_condition_will_always_return_true_since_this_function_is_always_defined_Did_you_mean_to_call_it_instead.code + ]; registerCodeFix({ - errorCodes: errorCodes16, - getCodeActions: function getCodeActionsToConvertLiteralTypeToMappedType(context) { + errorCodes: errorCodes45, + fixIds: [fixId35], + getCodeActions(context) { const { sourceFile, span } = context; - const info = getInfo5(sourceFile, span.start); - if (!info) { - return void 0; - } - const { name, constraint } = info; - const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange13(t, sourceFile, info)); - return [createCodeFixAction(fixId15, changes, [Diagnostics.Convert_0_to_1_in_0, constraint, name], fixId15, Diagnostics.Convert_all_type_literals_to_mapped_type)]; + const callName = getCallName(sourceFile, span.start); + if (!callName) + return; + const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange29(t, context.sourceFile, callName)); + return [createCodeFixAction(fixId35, changes, Diagnostics.Add_missing_call_parentheses, fixId35, Diagnostics.Add_all_missing_call_parentheses)]; }, - fixIds: [fixId15], - getAllCodeActions: (context) => codeFixAll(context, errorCodes16, (changes, diag2) => { - const info = getInfo5(diag2.file, diag2.start); - if (info) { - doChange13(changes, diag2.file, info); - } + getAllCodeActions: (context) => codeFixAll(context, errorCodes45, (changes, diag2) => { + const callName = getCallName(diag2.file, diag2.start); + if (callName) + doChange29(changes, diag2.file, callName); }) }); } }); - // src/services/codefixes/fixClassIncorrectlyImplementsInterface.ts - function getClass(sourceFile, pos) { - return Debug.checkDefined(getContainingClass(getTokenAtPosition(sourceFile, pos)), "There should be a containing class"); - } - function symbolPointsToNonPrivateMember(symbol) { - return !symbol.valueDeclaration || !(getEffectiveModifierFlags(symbol.valueDeclaration) & 8 /* Private */); - } - function addMissingDeclarations(context, implementedTypeNode, sourceFile, classDeclaration, changeTracker, preferences) { - const checker = context.program.getTypeChecker(); - const maybeHeritageClauseSymbol = getHeritageClauseSymbolTable(classDeclaration, checker); - const implementedType = checker.getTypeAtLocation(implementedTypeNode); - const implementedTypeSymbols = checker.getPropertiesOfType(implementedType); - const nonPrivateAndNotExistedInHeritageClauseMembers = implementedTypeSymbols.filter(and(symbolPointsToNonPrivateMember, (symbol) => !maybeHeritageClauseSymbol.has(symbol.escapedName))); - const classType = checker.getTypeAtLocation(classDeclaration); - const constructor = find(classDeclaration.members, (m) => isConstructorDeclaration(m)); - if (!classType.getNumberIndexType()) { - createMissingIndexSignatureDeclaration(implementedType, 1 /* Number */); + // src/services/codefixes/fixAwaitInSyncFunction.ts + function getReturnType(expr) { + if (expr.type) { + return expr.type; } - if (!classType.getStringIndexType()) { - createMissingIndexSignatureDeclaration(implementedType, 0 /* String */); + if (isVariableDeclaration(expr.parent) && expr.parent.type && isFunctionTypeNode(expr.parent.type)) { + return expr.parent.type.type; } - const importAdder = createImportAdder(sourceFile, context.program, preferences, context.host); - createMissingMemberNodes(classDeclaration, nonPrivateAndNotExistedInHeritageClauseMembers, sourceFile, context, preferences, importAdder, (member) => insertInterfaceMemberNode(sourceFile, classDeclaration, member)); - importAdder.writeFixes(changeTracker); - function createMissingIndexSignatureDeclaration(type, kind) { - const indexInfoOfKind = checker.getIndexInfoOfType(type, kind); - if (indexInfoOfKind) { - insertInterfaceMemberNode(sourceFile, classDeclaration, checker.indexInfoToIndexSignatureDeclaration( - indexInfoOfKind, - classDeclaration, - /*flags*/ - void 0, - getNoopSymbolTrackerWithResolver(context) - )); - } + } + function getNodes3(sourceFile, start) { + const token = getTokenAtPosition(sourceFile, start); + const containingFunction = getContainingFunction(token); + if (!containingFunction) { + return; } - function insertInterfaceMemberNode(sourceFile2, cls, newElement) { - if (constructor) { - changeTracker.insertNodeAfter(sourceFile2, constructor, newElement); - } else { - changeTracker.insertMemberAtStart(sourceFile2, cls, newElement); - } + let insertBefore; + switch (containingFunction.kind) { + case 174 /* MethodDeclaration */: + insertBefore = containingFunction.name; + break; + case 262 /* FunctionDeclaration */: + case 218 /* FunctionExpression */: + insertBefore = findChildOfKind(containingFunction, 100 /* FunctionKeyword */, sourceFile); + break; + case 219 /* ArrowFunction */: + const kind = containingFunction.typeParameters ? 30 /* LessThanToken */ : 21 /* OpenParenToken */; + insertBefore = findChildOfKind(containingFunction, kind, sourceFile) || first(containingFunction.parameters); + break; + default: + return; } + return insertBefore && { + insertBefore, + returnType: getReturnType(containingFunction) + }; } - function getHeritageClauseSymbolTable(classDeclaration, checker) { - const heritageClauseNode = getEffectiveBaseTypeNode(classDeclaration); - if (!heritageClauseNode) - return createSymbolTable(); - const heritageClauseType = checker.getTypeAtLocation(heritageClauseNode); - const heritageClauseTypeSymbols = checker.getPropertiesOfType(heritageClauseType); - return createSymbolTable(heritageClauseTypeSymbols.filter(symbolPointsToNonPrivateMember)); + function doChange30(changes, sourceFile, { insertBefore, returnType }) { + if (returnType) { + const entityName = getEntityNameFromTypeNode(returnType); + if (!entityName || entityName.kind !== 80 /* Identifier */ || entityName.text !== "Promise") { + changes.replaceNode(sourceFile, returnType, factory.createTypeReferenceNode("Promise", factory.createNodeArray([returnType]))); + } + } + changes.insertModifierBefore(sourceFile, 134 /* AsyncKeyword */, insertBefore); } - var errorCodes17, fixId16; - var init_fixClassIncorrectlyImplementsInterface = __esm({ - "src/services/codefixes/fixClassIncorrectlyImplementsInterface.ts"() { + var fixId36, errorCodes46; + var init_fixAwaitInSyncFunction = __esm({ + "src/services/codefixes/fixAwaitInSyncFunction.ts"() { "use strict"; init_ts4(); init_ts_codefix(); - errorCodes17 = [ - Diagnostics.Class_0_incorrectly_implements_interface_1.code, - Diagnostics.Class_0_incorrectly_implements_class_1_Did_you_mean_to_extend_1_and_inherit_its_members_as_a_subclass.code + fixId36 = "fixAwaitInSyncFunction"; + errorCodes46 = [ + Diagnostics.await_expressions_are_only_allowed_within_async_functions_and_at_the_top_levels_of_modules.code, + Diagnostics.await_using_statements_are_only_allowed_within_async_functions_and_at_the_top_levels_of_modules.code, + Diagnostics.for_await_loops_are_only_allowed_within_async_functions_and_at_the_top_levels_of_modules.code, + Diagnostics.Cannot_find_name_0_Did_you_mean_to_write_this_in_an_async_function.code ]; - fixId16 = "fixClassIncorrectlyImplementsInterface"; registerCodeFix({ - errorCodes: errorCodes17, + errorCodes: errorCodes46, getCodeActions(context) { const { sourceFile, span } = context; - const classDeclaration = getClass(sourceFile, span.start); - return mapDefined(getEffectiveImplementsTypeNodes(classDeclaration), (implementedTypeNode) => { - const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => addMissingDeclarations(context, implementedTypeNode, sourceFile, classDeclaration, t, context.preferences)); - return changes.length === 0 ? void 0 : createCodeFixAction(fixId16, changes, [Diagnostics.Implement_interface_0, implementedTypeNode.getText(sourceFile)], fixId16, Diagnostics.Implement_all_unimplemented_interfaces); - }); + const nodes = getNodes3(sourceFile, span.start); + if (!nodes) + return void 0; + const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange30(t, sourceFile, nodes)); + return [createCodeFixAction(fixId36, changes, Diagnostics.Add_async_modifier_to_containing_function, fixId36, Diagnostics.Add_all_missing_async_modifiers)]; }, - fixIds: [fixId16], - getAllCodeActions(context) { - const seenClassDeclarations = /* @__PURE__ */ new Map(); - return codeFixAll(context, errorCodes17, (changes, diag2) => { - const classDeclaration = getClass(diag2.file, diag2.start); - if (addToSeen(seenClassDeclarations, getNodeId(classDeclaration))) { - for (const implementedTypeNode of getEffectiveImplementsTypeNodes(classDeclaration)) { - addMissingDeclarations(context, implementedTypeNode, diag2.file, classDeclaration, changes, context.preferences); - } - } + fixIds: [fixId36], + getAllCodeActions: function getAllCodeActionsToFixAwaitInSyncFunction(context) { + const seen = /* @__PURE__ */ new Map(); + return codeFixAll(context, errorCodes46, (changes, diag2) => { + const nodes = getNodes3(diag2.file, diag2.start); + if (!nodes || !addToSeen(seen, getNodeId(nodes.insertBefore))) + return; + doChange30(changes, context.sourceFile, nodes); }); } }); } }); - // src/services/codefixes/importFixes.ts - function createImportAdder(sourceFile, program, preferences, host, cancellationToken) { - return createImportAdderWorker( - sourceFile, - program, - /*useAutoImportProvider*/ - false, - preferences, - host, - cancellationToken - ); - } - function createImportAdderWorker(sourceFile, program, useAutoImportProvider, preferences, host, cancellationToken) { - const compilerOptions = program.getCompilerOptions(); - const addToNamespace = []; - const importType = []; - const addToExisting = /* @__PURE__ */ new Map(); - const newImports = /* @__PURE__ */ new Map(); - return { addImportFromDiagnostic, addImportFromExportedSymbol, writeFixes, hasFixes }; - function addImportFromDiagnostic(diagnostic, context) { - const info = getFixInfos(context, diagnostic.code, diagnostic.start, useAutoImportProvider); - if (!info || !info.length) - return; - addImport(first(info)); - } - function addImportFromExportedSymbol(exportedSymbol, isValidTypeOnlyUseSite) { - const moduleSymbol = Debug.checkDefined(exportedSymbol.parent); - const symbolName2 = getNameForExportedSymbol(exportedSymbol, getEmitScriptTarget(compilerOptions)); - const checker = program.getTypeChecker(); - const symbol = checker.getMergedSymbol(skipAlias(exportedSymbol, checker)); - const exportInfo = getAllExportInfoForSymbol( - sourceFile, - symbol, - symbolName2, - moduleSymbol, - /*preferCapitalized*/ - false, - program, - host, - preferences, - cancellationToken - ); - const useRequire = shouldUseRequire(sourceFile, program); - const fix = getImportFixForSymbol( - sourceFile, - Debug.checkDefined(exportInfo), - program, - /*position*/ - void 0, - !!isValidTypeOnlyUseSite, - useRequire, - host, - preferences - ); - if (fix) { - addImport({ fix, symbolName: symbolName2, errorIdentifierText: void 0 }); - } - } - function addImport(info) { - var _a, _b; - const { fix, symbolName: symbolName2 } = info; - switch (fix.kind) { - case 0 /* UseNamespace */: - addToNamespace.push(fix); - break; - case 1 /* JsdocTypeImport */: - importType.push(fix); - break; - case 2 /* AddToExisting */: { - const { importClauseOrBindingPattern, importKind, addAsTypeOnly } = fix; - const key = String(getNodeId(importClauseOrBindingPattern)); - let entry = addToExisting.get(key); - if (!entry) { - addToExisting.set(key, entry = { importClauseOrBindingPattern, defaultImport: void 0, namedImports: /* @__PURE__ */ new Map() }); - } - if (importKind === 0 /* Named */) { - const prevValue = entry == null ? void 0 : entry.namedImports.get(symbolName2); - entry.namedImports.set(symbolName2, reduceAddAsTypeOnlyValues(prevValue, addAsTypeOnly)); - } else { - Debug.assert(entry.defaultImport === void 0 || entry.defaultImport.name === symbolName2, "(Add to Existing) Default import should be missing or match symbolName"); - entry.defaultImport = { - name: symbolName2, - addAsTypeOnly: reduceAddAsTypeOnlyValues((_a = entry.defaultImport) == null ? void 0 : _a.addAsTypeOnly, addAsTypeOnly) - }; - } - break; - } - case 3 /* AddNew */: { - const { moduleSpecifier, importKind, useRequire, addAsTypeOnly } = fix; - const entry = getNewImportEntry(moduleSpecifier, importKind, useRequire, addAsTypeOnly); - Debug.assert(entry.useRequire === useRequire, "(Add new) Tried to add an `import` and a `require` for the same module"); - switch (importKind) { - case 1 /* Default */: - Debug.assert(entry.defaultImport === void 0 || entry.defaultImport.name === symbolName2, "(Add new) Default import should be missing or match symbolName"); - entry.defaultImport = { name: symbolName2, addAsTypeOnly: reduceAddAsTypeOnlyValues((_b = entry.defaultImport) == null ? void 0 : _b.addAsTypeOnly, addAsTypeOnly) }; - break; - case 0 /* Named */: - const prevValue = (entry.namedImports || (entry.namedImports = /* @__PURE__ */ new Map())).get(symbolName2); - entry.namedImports.set(symbolName2, reduceAddAsTypeOnlyValues(prevValue, addAsTypeOnly)); - break; - case 3 /* CommonJS */: - case 2 /* Namespace */: - Debug.assert(entry.namespaceLikeImport === void 0 || entry.namespaceLikeImport.name === symbolName2, "Namespacelike import shoudl be missing or match symbolName"); - entry.namespaceLikeImport = { importKind, name: symbolName2, addAsTypeOnly }; - break; - } - break; - } - case 4 /* PromoteTypeOnly */: - break; - default: - Debug.assertNever(fix, `fix wasn't never - got kind ${fix.kind}`); - } - function reduceAddAsTypeOnlyValues(prevValue, newValue) { - return Math.max(prevValue ?? 0, newValue); - } - function getNewImportEntry(moduleSpecifier, importKind, useRequire, addAsTypeOnly) { - const typeOnlyKey = newImportsKey( - moduleSpecifier, - /*topLevelTypeOnly*/ - true - ); - const nonTypeOnlyKey = newImportsKey( - moduleSpecifier, - /*topLevelTypeOnly*/ - false - ); - const typeOnlyEntry = newImports.get(typeOnlyKey); - const nonTypeOnlyEntry = newImports.get(nonTypeOnlyKey); - const newEntry = { - defaultImport: void 0, - namedImports: void 0, - namespaceLikeImport: void 0, - useRequire - }; - if (importKind === 1 /* Default */ && addAsTypeOnly === 2 /* Required */) { - if (typeOnlyEntry) - return typeOnlyEntry; - newImports.set(typeOnlyKey, newEntry); - return newEntry; - } - if (addAsTypeOnly === 1 /* Allowed */ && (typeOnlyEntry || nonTypeOnlyEntry)) { - return typeOnlyEntry || nonTypeOnlyEntry; - } - if (nonTypeOnlyEntry) { - return nonTypeOnlyEntry; - } - newImports.set(nonTypeOnlyKey, newEntry); - return newEntry; - } - function newImportsKey(moduleSpecifier, topLevelTypeOnly) { - return `${topLevelTypeOnly ? 1 : 0}|${moduleSpecifier}`; - } - } - function writeFixes(changeTracker) { - const quotePreference = getQuotePreference(sourceFile, preferences); - for (const fix of addToNamespace) { - addNamespaceQualifier(changeTracker, sourceFile, fix); - } - for (const fix of importType) { - addImportType(changeTracker, sourceFile, fix, quotePreference); - } - addToExisting.forEach(({ importClauseOrBindingPattern, defaultImport, namedImports }) => { - doAddExistingFix( - changeTracker, - sourceFile, - importClauseOrBindingPattern, - defaultImport, - arrayFrom(namedImports.entries(), ([name, addAsTypeOnly]) => ({ addAsTypeOnly, name })), - preferences - ); - }); - let newDeclarations; - newImports.forEach(({ useRequire, defaultImport, namedImports, namespaceLikeImport }, key) => { - const moduleSpecifier = key.slice(2); - const getDeclarations = useRequire ? getNewRequires : getNewImports; - const declarations = getDeclarations( - moduleSpecifier, - quotePreference, - defaultImport, - namedImports && arrayFrom(namedImports.entries(), ([name, addAsTypeOnly]) => ({ addAsTypeOnly, name })), - namespaceLikeImport, - compilerOptions - ); - newDeclarations = combine(newDeclarations, declarations); - }); - if (newDeclarations) { - insertImports( - changeTracker, - sourceFile, - newDeclarations, - /*blankLineBetween*/ - true, - preferences - ); - } - } - function hasFixes() { - return addToNamespace.length > 0 || importType.length > 0 || addToExisting.size > 0 || newImports.size > 0; - } - } - function createImportSpecifierResolver(importingFile, program, host, preferences) { - const packageJsonImportFilter = createPackageJsonImportFilter(importingFile, preferences, host); - const importMap = createExistingImportMap(program.getTypeChecker(), importingFile, program.getCompilerOptions()); - return { getModuleSpecifierForBestExportInfo }; - function getModuleSpecifierForBestExportInfo(exportInfo, position, isValidTypeOnlyUseSite, fromCacheOnly) { - const { fixes, computedWithoutCacheCount } = getImportFixes( - exportInfo, - position, - isValidTypeOnlyUseSite, - /*useRequire*/ - false, - program, - importingFile, - host, - preferences, - importMap, - fromCacheOnly - ); - const result = getBestFix(fixes, importingFile, program, packageJsonImportFilter, host); - return result && { ...result, computedWithoutCacheCount }; - } - } - function getImportCompletionAction(targetSymbol, moduleSymbol, exportMapKey, sourceFile, symbolName2, isJsxTagName, host, program, formatContext, position, preferences, cancellationToken) { - const compilerOptions = program.getCompilerOptions(); - let exportInfos; - if (exportMapKey) { - exportInfos = getExportInfoMap(sourceFile, host, program, preferences, cancellationToken).get(sourceFile.path, exportMapKey); - Debug.assertIsDefined(exportInfos, "Some exportInfo should match the specified exportMapKey"); + // src/services/codefixes/fixPropertyOverrideAccessor.ts + function doChange31(file, start, length2, code, context) { + let startPosition; + let endPosition; + if (code === Diagnostics._0_is_defined_as_an_accessor_in_class_1_but_is_overridden_here_in_2_as_an_instance_property.code) { + startPosition = start; + endPosition = start + length2; + } else if (code === Diagnostics._0_is_defined_as_a_property_in_class_1_but_is_overridden_here_in_2_as_an_accessor.code) { + const checker = context.program.getTypeChecker(); + const node = getTokenAtPosition(file, start).parent; + Debug.assert(isAccessor(node), "error span of fixPropertyOverrideAccessor should only be on an accessor"); + const containingClass = node.parent; + Debug.assert(isClassLike(containingClass), "erroneous accessors should only be inside classes"); + const base = singleOrUndefined(getAllSupers(containingClass, checker)); + if (!base) + return []; + const name = unescapeLeadingUnderscores(getTextOfPropertyName(node.name)); + const baseProp = checker.getPropertyOfType(checker.getTypeAtLocation(base), name); + if (!baseProp || !baseProp.valueDeclaration) + return []; + startPosition = baseProp.valueDeclaration.pos; + endPosition = baseProp.valueDeclaration.end; + file = getSourceFileOfNode(baseProp.valueDeclaration); } else { - exportInfos = pathIsBareSpecifier(stripQuotes(moduleSymbol.name)) ? [getSingleExportInfoForSymbol(targetSymbol, symbolName2, moduleSymbol, program, host)] : getAllExportInfoForSymbol(sourceFile, targetSymbol, symbolName2, moduleSymbol, isJsxTagName, program, host, preferences, cancellationToken); - Debug.assertIsDefined(exportInfos, "Some exportInfo should match the specified symbol / moduleSymbol"); - } - const useRequire = shouldUseRequire(sourceFile, program); - const isValidTypeOnlyUseSite = isValidTypeOnlyAliasUseSite(getTokenAtPosition(sourceFile, position)); - const fix = Debug.checkDefined(getImportFixForSymbol(sourceFile, exportInfos, program, position, isValidTypeOnlyUseSite, useRequire, host, preferences)); - return { - moduleSpecifier: fix.moduleSpecifier, - codeAction: codeFixActionToCodeAction(codeActionForFix( - { host, formatContext, preferences }, - sourceFile, - symbolName2, - fix, - /*includeSymbolNameInDescription*/ - false, - compilerOptions, - preferences - )) - }; - } - function getPromoteTypeOnlyCompletionAction(sourceFile, symbolToken, program, host, formatContext, preferences) { - const compilerOptions = program.getCompilerOptions(); - const symbolName2 = single(getSymbolNamesToImport(sourceFile, program.getTypeChecker(), symbolToken, compilerOptions)); - const fix = getTypeOnlyPromotionFix(sourceFile, symbolToken, symbolName2, program); - const includeSymbolNameInDescription = symbolName2 !== symbolToken.text; - return fix && codeFixActionToCodeAction(codeActionForFix({ host, formatContext, preferences }, sourceFile, symbolName2, fix, includeSymbolNameInDescription, compilerOptions, preferences)); - } - function getImportFixForSymbol(sourceFile, exportInfos, program, position, isValidTypeOnlyUseSite, useRequire, host, preferences) { - const packageJsonImportFilter = createPackageJsonImportFilter(sourceFile, preferences, host); - return getBestFix(getImportFixes(exportInfos, position, isValidTypeOnlyUseSite, useRequire, program, sourceFile, host, preferences).fixes, sourceFile, program, packageJsonImportFilter, host); - } - function codeFixActionToCodeAction({ description: description3, changes, commands }) { - return { description: description3, changes, commands }; - } - function getAllExportInfoForSymbol(importingFile, symbol, symbolName2, moduleSymbol, preferCapitalized, program, host, preferences, cancellationToken) { - const getChecker = createGetChecker(program, host); - return getExportInfoMap(importingFile, host, program, preferences, cancellationToken).search(importingFile.path, preferCapitalized, (name) => name === symbolName2, (info) => { - if (skipAlias(info[0].symbol, getChecker(info[0].isFromPackageJson)) === symbol && info.some((i) => i.moduleSymbol === moduleSymbol || i.symbol.parent === moduleSymbol)) { - return info; - } - }); - } - function getSingleExportInfoForSymbol(symbol, symbolName2, moduleSymbol, program, host) { - var _a, _b; - const compilerOptions = program.getCompilerOptions(); - const mainProgramInfo = getInfoWithChecker( - program.getTypeChecker(), - /*isFromPackageJson*/ - false - ); - if (mainProgramInfo) { - return mainProgramInfo; - } - const autoImportProvider = (_b = (_a = host.getPackageJsonAutoImportProvider) == null ? void 0 : _a.call(host)) == null ? void 0 : _b.getTypeChecker(); - return Debug.checkDefined(autoImportProvider && getInfoWithChecker( - autoImportProvider, - /*isFromPackageJson*/ - true - ), `Could not find symbol in specified module for code actions`); - function getInfoWithChecker(checker, isFromPackageJson) { - const defaultInfo = getDefaultLikeExportInfo(moduleSymbol, checker, compilerOptions); - if (defaultInfo && skipAlias(defaultInfo.symbol, checker) === symbol) { - return { symbol: defaultInfo.symbol, moduleSymbol, moduleFileName: void 0, exportKind: defaultInfo.exportKind, targetFlags: skipAlias(symbol, checker).flags, isFromPackageJson }; - } - const named = checker.tryGetMemberInModuleExportsAndProperties(symbolName2, moduleSymbol); - if (named && skipAlias(named, checker) === symbol) { - return { symbol: named, moduleSymbol, moduleFileName: void 0, exportKind: 0 /* Named */, targetFlags: skipAlias(symbol, checker).flags, isFromPackageJson }; - } - } - } - function getImportFixes(exportInfos, usagePosition, isValidTypeOnlyUseSite, useRequire, program, sourceFile, host, preferences, importMap = createExistingImportMap(program.getTypeChecker(), sourceFile, program.getCompilerOptions()), fromCacheOnly) { - const checker = program.getTypeChecker(); - const existingImports = flatMap(exportInfos, importMap.getImportsForExportInfo); - const useNamespace = usagePosition !== void 0 && tryUseExistingNamespaceImport(existingImports, usagePosition); - const addToExisting = tryAddToExistingImport(existingImports, isValidTypeOnlyUseSite, checker, program.getCompilerOptions()); - if (addToExisting) { - return { - computedWithoutCacheCount: 0, - fixes: [...useNamespace ? [useNamespace] : emptyArray, addToExisting] - }; + Debug.fail("fixPropertyOverrideAccessor codefix got unexpected error code " + code); } - const { fixes, computedWithoutCacheCount = 0 } = getFixesForAddImport( - exportInfos, - existingImports, - program, - sourceFile, - usagePosition, - isValidTypeOnlyUseSite, - useRequire, - host, - preferences, - fromCacheOnly - ); - return { - computedWithoutCacheCount, - fixes: [...useNamespace ? [useNamespace] : emptyArray, ...fixes] - }; - } - function tryUseExistingNamespaceImport(existingImports, position) { - return firstDefined(existingImports, ({ declaration, importKind }) => { - var _a; - if (importKind !== 0 /* Named */) - return void 0; - const namespacePrefix = getNamespaceLikeImportText(declaration); - const moduleSpecifier = namespacePrefix && ((_a = tryGetModuleSpecifierFromDeclaration(declaration)) == null ? void 0 : _a.text); - if (moduleSpecifier) { - return { kind: 0 /* UseNamespace */, namespacePrefix, usagePosition: position, moduleSpecifier }; - } - }); + return generateAccessorFromProperty(file, context.program, startPosition, endPosition, context, Diagnostics.Generate_get_and_set_accessors.message); } - function getNamespaceLikeImportText(declaration) { - var _a, _b, _c; - switch (declaration.kind) { - case 259 /* VariableDeclaration */: - return (_a = tryCast(declaration.name, isIdentifier)) == null ? void 0 : _a.text; - case 270 /* ImportEqualsDeclaration */: - return declaration.name.text; - case 271 /* ImportDeclaration */: - return (_c = tryCast((_b = declaration.importClause) == null ? void 0 : _b.namedBindings, isNamespaceImport)) == null ? void 0 : _c.name.text; + var errorCodes47, fixId37; + var init_fixPropertyOverrideAccessor = __esm({ + "src/services/codefixes/fixPropertyOverrideAccessor.ts"() { + "use strict"; + init_ts4(); + init_ts_codefix(); + errorCodes47 = [ + Diagnostics._0_is_defined_as_an_accessor_in_class_1_but_is_overridden_here_in_2_as_an_instance_property.code, + Diagnostics._0_is_defined_as_a_property_in_class_1_but_is_overridden_here_in_2_as_an_accessor.code + ]; + fixId37 = "fixPropertyOverrideAccessor"; + registerCodeFix({ + errorCodes: errorCodes47, + getCodeActions(context) { + const edits = doChange31(context.sourceFile, context.span.start, context.span.length, context.errorCode, context); + if (edits) { + return [createCodeFixAction(fixId37, edits, Diagnostics.Generate_get_and_set_accessors, fixId37, Diagnostics.Generate_get_and_set_accessors_for_all_overriding_properties)]; + } + }, + fixIds: [fixId37], + getAllCodeActions: (context) => codeFixAll(context, errorCodes47, (changes, diag2) => { + const edits = doChange31(diag2.file, diag2.start, diag2.length, diag2.code, context); + if (edits) { + for (const edit of edits) { + changes.pushRaw(context.sourceFile, edit); + } + } + }) + }); + } + }); + + // src/services/codefixes/inferFromUsage.ts + function getDiagnostic(errorCode, token) { + switch (errorCode) { + case Diagnostics.Parameter_0_implicitly_has_an_1_type.code: + case Diagnostics.Parameter_0_implicitly_has_an_1_type_but_a_better_type_may_be_inferred_from_usage.code: + return isSetAccessorDeclaration(getContainingFunction(token)) ? Diagnostics.Infer_type_of_0_from_usage : Diagnostics.Infer_parameter_types_from_usage; + case Diagnostics.Rest_parameter_0_implicitly_has_an_any_type.code: + case Diagnostics.Rest_parameter_0_implicitly_has_an_any_type_but_a_better_type_may_be_inferred_from_usage.code: + return Diagnostics.Infer_parameter_types_from_usage; + case Diagnostics.this_implicitly_has_type_any_because_it_does_not_have_a_type_annotation.code: + return Diagnostics.Infer_this_type_of_0_from_usage; default: - return Debug.assertNever(declaration); + return Diagnostics.Infer_type_of_0_from_usage; } } - function getAddAsTypeOnly(isValidTypeOnlyUseSite, isForNewImportDeclaration, symbol, targetFlags, checker, compilerOptions) { - if (!isValidTypeOnlyUseSite) { - return 4 /* NotAllowed */; - } - if (isForNewImportDeclaration && compilerOptions.importsNotUsedAsValues === 2 /* Error */) { - return 2 /* Required */; - } - if (importNameElisionDisabled(compilerOptions) && (!(targetFlags & 111551 /* Value */) || !!checker.getTypeOnlyAliasDeclaration(symbol))) { - return 2 /* Required */; + function mapSuggestionDiagnostic(errorCode) { + switch (errorCode) { + case Diagnostics.Variable_0_implicitly_has_type_1_in_some_locations_but_a_better_type_may_be_inferred_from_usage.code: + return Diagnostics.Variable_0_implicitly_has_type_1_in_some_locations_where_its_type_cannot_be_determined.code; + case Diagnostics.Variable_0_implicitly_has_an_1_type_but_a_better_type_may_be_inferred_from_usage.code: + return Diagnostics.Variable_0_implicitly_has_an_1_type.code; + case Diagnostics.Parameter_0_implicitly_has_an_1_type_but_a_better_type_may_be_inferred_from_usage.code: + return Diagnostics.Parameter_0_implicitly_has_an_1_type.code; + case Diagnostics.Rest_parameter_0_implicitly_has_an_any_type_but_a_better_type_may_be_inferred_from_usage.code: + return Diagnostics.Rest_parameter_0_implicitly_has_an_any_type.code; + case Diagnostics.Property_0_implicitly_has_type_any_but_a_better_type_for_its_get_accessor_may_be_inferred_from_usage.code: + return Diagnostics.Property_0_implicitly_has_type_any_because_its_get_accessor_lacks_a_return_type_annotation.code; + case Diagnostics._0_implicitly_has_an_1_return_type_but_a_better_type_may_be_inferred_from_usage.code: + return Diagnostics._0_which_lacks_return_type_annotation_implicitly_has_an_1_return_type.code; + case Diagnostics.Property_0_implicitly_has_type_any_but_a_better_type_for_its_set_accessor_may_be_inferred_from_usage.code: + return Diagnostics.Property_0_implicitly_has_type_any_because_its_set_accessor_lacks_a_parameter_type_annotation.code; + case Diagnostics.Member_0_implicitly_has_an_1_type_but_a_better_type_may_be_inferred_from_usage.code: + return Diagnostics.Member_0_implicitly_has_an_1_type.code; } - return 1 /* Allowed */; + return errorCode; } - function tryAddToExistingImport(existingImports, isValidTypeOnlyUseSite, checker, compilerOptions) { - let best; - for (const existingImport of existingImports) { - const fix = getAddToExistingImportFix(existingImport); - if (!fix) - continue; - const isTypeOnly = isTypeOnlyImportDeclaration(fix.importClauseOrBindingPattern); - if (fix.addAsTypeOnly !== 4 /* NotAllowed */ && isTypeOnly || fix.addAsTypeOnly === 4 /* NotAllowed */ && !isTypeOnly) { - return fix; - } - best ?? (best = fix); + function doChange32(changes, sourceFile, token, errorCode, program, cancellationToken, markSeen, host, preferences) { + if (!isParameterPropertyModifier(token.kind) && token.kind !== 80 /* Identifier */ && token.kind !== 26 /* DotDotDotToken */ && token.kind !== 110 /* ThisKeyword */) { + return void 0; } - return best; - function getAddToExistingImportFix({ declaration, importKind, symbol, targetFlags }) { - if (importKind === 3 /* CommonJS */ || importKind === 2 /* Namespace */ || declaration.kind === 270 /* ImportEqualsDeclaration */) { - return void 0; - } - if (declaration.kind === 259 /* VariableDeclaration */) { - return (importKind === 0 /* Named */ || importKind === 1 /* Default */) && declaration.name.kind === 205 /* ObjectBindingPattern */ ? { kind: 2 /* AddToExisting */, importClauseOrBindingPattern: declaration.name, importKind, moduleSpecifier: declaration.initializer.arguments[0].text, addAsTypeOnly: 4 /* NotAllowed */ } : void 0; - } - const { importClause } = declaration; - if (!importClause || !isStringLiteralLike(declaration.moduleSpecifier)) { - return void 0; - } - const { name, namedBindings } = importClause; - if (importClause.isTypeOnly && !(importKind === 0 /* Named */ && namedBindings)) { - return void 0; - } - const addAsTypeOnly = getAddAsTypeOnly( - isValidTypeOnlyUseSite, - /*isForNewImportDeclaration*/ - false, - symbol, - targetFlags, - checker, - compilerOptions - ); - if (importKind === 1 /* Default */ && (name || // Cannot add a default import to a declaration that already has one - addAsTypeOnly === 2 /* Required */ && namedBindings)) { + const { parent: parent2 } = token; + const importAdder = createImportAdder(sourceFile, program, preferences, host); + errorCode = mapSuggestionDiagnostic(errorCode); + switch (errorCode) { + case Diagnostics.Member_0_implicitly_has_an_1_type.code: + case Diagnostics.Variable_0_implicitly_has_type_1_in_some_locations_where_its_type_cannot_be_determined.code: + if (isVariableDeclaration(parent2) && markSeen(parent2) || isPropertyDeclaration(parent2) || isPropertySignature(parent2)) { + annotateVariableDeclaration(changes, importAdder, sourceFile, parent2, program, host, cancellationToken); + importAdder.writeFixes(changes); + return parent2; + } + if (isPropertyAccessExpression(parent2)) { + const type = inferTypeForVariableFromUsage(parent2.name, program, cancellationToken); + const typeNode = getTypeNodeIfAccessible(type, parent2, program, host); + if (typeNode) { + const typeTag = factory.createJSDocTypeTag( + /*tagName*/ + void 0, + factory.createJSDocTypeExpression(typeNode), + /*comment*/ + void 0 + ); + changes.addJSDocTags(sourceFile, cast(parent2.parent.parent, isExpressionStatement), [typeTag]); + } + importAdder.writeFixes(changes); + return parent2; + } return void 0; - } - if (importKind === 0 /* Named */ && (namedBindings == null ? void 0 : namedBindings.kind) === 273 /* NamespaceImport */) { + case Diagnostics.Variable_0_implicitly_has_an_1_type.code: { + const symbol = program.getTypeChecker().getSymbolAtLocation(token); + if (symbol && symbol.valueDeclaration && isVariableDeclaration(symbol.valueDeclaration) && markSeen(symbol.valueDeclaration)) { + annotateVariableDeclaration(changes, importAdder, getSourceFileOfNode(symbol.valueDeclaration), symbol.valueDeclaration, program, host, cancellationToken); + importAdder.writeFixes(changes); + return symbol.valueDeclaration; + } return void 0; } - return { - kind: 2 /* AddToExisting */, - importClauseOrBindingPattern: importClause, - importKind, - moduleSpecifier: declaration.moduleSpecifier.text, - addAsTypeOnly - }; } - } - function createExistingImportMap(checker, importingFile, compilerOptions) { - let importMap; - for (const moduleSpecifier of importingFile.imports) { - const i = importFromModuleSpecifier(moduleSpecifier); - if (isVariableDeclarationInitializedToRequire(i.parent)) { - const moduleSymbol = checker.resolveExternalModuleName(moduleSpecifier); - if (moduleSymbol) { - (importMap || (importMap = createMultiMap())).add(getSymbolId(moduleSymbol), i.parent); + const containingFunction = getContainingFunction(token); + if (containingFunction === void 0) { + return void 0; + } + let declaration; + switch (errorCode) { + case Diagnostics.Parameter_0_implicitly_has_an_1_type.code: + if (isSetAccessorDeclaration(containingFunction)) { + annotateSetAccessor(changes, importAdder, sourceFile, containingFunction, program, host, cancellationToken); + declaration = containingFunction; + break; } - } else if (i.kind === 271 /* ImportDeclaration */ || i.kind === 270 /* ImportEqualsDeclaration */) { - const moduleSymbol = checker.getSymbolAtLocation(moduleSpecifier); - if (moduleSymbol) { - (importMap || (importMap = createMultiMap())).add(getSymbolId(moduleSymbol), i); + case Diagnostics.Rest_parameter_0_implicitly_has_an_any_type.code: + if (markSeen(containingFunction)) { + const param = cast(parent2, isParameter); + annotateParameters(changes, importAdder, sourceFile, param, containingFunction, program, host, cancellationToken); + declaration = param; } - } - } - return { - getImportsForExportInfo: ({ moduleSymbol, exportKind, targetFlags, symbol }) => { - if (!(targetFlags & 111551 /* Value */) && isSourceFileJS(importingFile)) - return emptyArray; - const matchingDeclarations = importMap == null ? void 0 : importMap.get(getSymbolId(moduleSymbol)); - if (!matchingDeclarations) - return emptyArray; - const importKind = getImportKind(importingFile, exportKind, compilerOptions); - return matchingDeclarations.map((declaration) => ({ declaration, importKind, symbol, targetFlags })); - } - }; - } - function shouldUseRequire(sourceFile, program) { - if (!isSourceFileJS(sourceFile)) { - return false; - } - if (sourceFile.commonJsModuleIndicator && !sourceFile.externalModuleIndicator) - return true; - if (sourceFile.externalModuleIndicator && !sourceFile.commonJsModuleIndicator) - return false; - const compilerOptions = program.getCompilerOptions(); - if (compilerOptions.configFile) { - return getEmitModuleKind(compilerOptions) < 5 /* ES2015 */; - } - for (const otherFile of program.getSourceFiles()) { - if (otherFile === sourceFile || !isSourceFileJS(otherFile) || program.isSourceFileFromExternalLibrary(otherFile)) - continue; - if (otherFile.commonJsModuleIndicator && !otherFile.externalModuleIndicator) - return true; - if (otherFile.externalModuleIndicator && !otherFile.commonJsModuleIndicator) - return false; - } - return true; - } - function createGetChecker(program, host) { - return memoizeOne((isFromPackageJson) => isFromPackageJson ? host.getPackageJsonAutoImportProvider().getTypeChecker() : program.getTypeChecker()); - } - function getNewImportFixes(program, sourceFile, usagePosition, isValidTypeOnlyUseSite, useRequire, exportInfo, host, preferences, fromCacheOnly) { - const isJs = isSourceFileJS(sourceFile); - const compilerOptions = program.getCompilerOptions(); - const moduleSpecifierResolutionHost = createModuleSpecifierResolutionHost(program, host); - const getChecker = createGetChecker(program, host); - const moduleResolution = getEmitModuleResolutionKind(compilerOptions); - const rejectNodeModulesRelativePaths = moduleResolutionUsesNodeModules(moduleResolution); - const getModuleSpecifiers2 = fromCacheOnly ? (moduleSymbol) => ({ moduleSpecifiers: ts_moduleSpecifiers_exports.tryGetModuleSpecifiersFromCache(moduleSymbol, sourceFile, moduleSpecifierResolutionHost, preferences), computedWithoutCache: false }) : (moduleSymbol, checker) => ts_moduleSpecifiers_exports.getModuleSpecifiersWithCacheInfo(moduleSymbol, checker, compilerOptions, sourceFile, moduleSpecifierResolutionHost, preferences); - let computedWithoutCacheCount = 0; - const fixes = flatMap(exportInfo, (exportInfo2, i) => { - const checker = getChecker(exportInfo2.isFromPackageJson); - const { computedWithoutCache, moduleSpecifiers } = getModuleSpecifiers2(exportInfo2.moduleSymbol, checker); - const importedSymbolHasValueMeaning = !!(exportInfo2.targetFlags & 111551 /* Value */); - const addAsTypeOnly = getAddAsTypeOnly( - isValidTypeOnlyUseSite, - /*isForNewImportDeclaration*/ - true, - exportInfo2.symbol, - exportInfo2.targetFlags, - checker, - compilerOptions - ); - computedWithoutCacheCount += computedWithoutCache ? 1 : 0; - return mapDefined(moduleSpecifiers, (moduleSpecifier) => { - var _a; - if (rejectNodeModulesRelativePaths && pathContainsNodeModules(moduleSpecifier)) { - return void 0; + break; + case Diagnostics.Property_0_implicitly_has_type_any_because_its_get_accessor_lacks_a_return_type_annotation.code: + case Diagnostics._0_which_lacks_return_type_annotation_implicitly_has_an_1_return_type.code: + if (isGetAccessorDeclaration(containingFunction) && isIdentifier(containingFunction.name)) { + annotate(changes, importAdder, sourceFile, containingFunction, inferTypeForVariableFromUsage(containingFunction.name, program, cancellationToken), program, host); + declaration = containingFunction; } - if (!importedSymbolHasValueMeaning && isJs && usagePosition !== void 0) { - return { kind: 1 /* JsdocTypeImport */, moduleSpecifier, usagePosition, exportInfo: exportInfo2, isReExport: i > 0 }; + break; + case Diagnostics.Property_0_implicitly_has_type_any_because_its_set_accessor_lacks_a_parameter_type_annotation.code: + if (isSetAccessorDeclaration(containingFunction)) { + annotateSetAccessor(changes, importAdder, sourceFile, containingFunction, program, host, cancellationToken); + declaration = containingFunction; } - const importKind = getImportKind(sourceFile, exportInfo2.exportKind, compilerOptions); - let qualification; - if (usagePosition !== void 0 && importKind === 3 /* CommonJS */ && exportInfo2.exportKind === 0 /* Named */) { - const exportEquals = checker.resolveExternalModuleSymbol(exportInfo2.moduleSymbol); - let namespacePrefix; - if (exportEquals !== exportInfo2.moduleSymbol) { - namespacePrefix = (_a = getDefaultExportInfoWorker(exportEquals, checker, compilerOptions)) == null ? void 0 : _a.name; - } - namespacePrefix || (namespacePrefix = moduleSymbolToValidIdentifier( - exportInfo2.moduleSymbol, - getEmitScriptTarget(compilerOptions), - /*forceCapitalize*/ - false - )); - qualification = { namespacePrefix, usagePosition }; + break; + case Diagnostics.this_implicitly_has_type_any_because_it_does_not_have_a_type_annotation.code: + if (ts_textChanges_exports.isThisTypeAnnotatable(containingFunction) && markSeen(containingFunction)) { + annotateThis(changes, sourceFile, containingFunction, program, host, cancellationToken); + declaration = containingFunction; } - return { - kind: 3 /* AddNew */, - moduleSpecifier, - importKind, - useRequire, - addAsTypeOnly, - exportInfo: exportInfo2, - isReExport: i > 0, - qualification - }; - }); - }); - return { computedWithoutCacheCount, fixes }; - } - function getFixesForAddImport(exportInfos, existingImports, program, sourceFile, usagePosition, isValidTypeOnlyUseSite, useRequire, host, preferences, fromCacheOnly) { - const existingDeclaration = firstDefined(existingImports, (info) => newImportInfoFromExistingSpecifier(info, isValidTypeOnlyUseSite, useRequire, program.getTypeChecker(), program.getCompilerOptions())); - return existingDeclaration ? { fixes: [existingDeclaration] } : getNewImportFixes(program, sourceFile, usagePosition, isValidTypeOnlyUseSite, useRequire, exportInfos, host, preferences, fromCacheOnly); + break; + default: + return Debug.fail(String(errorCode)); + } + importAdder.writeFixes(changes); + return declaration; } - function newImportInfoFromExistingSpecifier({ declaration, importKind, symbol, targetFlags }, isValidTypeOnlyUseSite, useRequire, checker, compilerOptions) { - var _a; - const moduleSpecifier = (_a = tryGetModuleSpecifierFromDeclaration(declaration)) == null ? void 0 : _a.text; - if (moduleSpecifier) { - const addAsTypeOnly = useRequire ? 4 /* NotAllowed */ : getAddAsTypeOnly( - isValidTypeOnlyUseSite, - /*isForNewImportDeclaration*/ - true, - symbol, - targetFlags, - checker, - compilerOptions - ); - return { kind: 3 /* AddNew */, moduleSpecifier, importKind, addAsTypeOnly, useRequire }; + function annotateVariableDeclaration(changes, importAdder, sourceFile, declaration, program, host, cancellationToken) { + if (isIdentifier(declaration.name)) { + annotate(changes, importAdder, sourceFile, declaration, inferTypeForVariableFromUsage(declaration.name, program, cancellationToken), program, host); } } - function getFixInfos(context, errorCode, pos, useAutoImportProvider) { - const symbolToken = getTokenAtPosition(context.sourceFile, pos); - let info; - if (errorCode === Diagnostics._0_refers_to_a_UMD_global_but_the_current_file_is_a_module_Consider_adding_an_import_instead.code) { - info = getFixesInfoForUMDImport(context, symbolToken); - } else if (!isIdentifier(symbolToken)) { - return void 0; - } else if (errorCode === Diagnostics._0_cannot_be_used_as_a_value_because_it_was_imported_using_import_type.code) { - const symbolName2 = single(getSymbolNamesToImport(context.sourceFile, context.program.getTypeChecker(), symbolToken, context.program.getCompilerOptions())); - const fix = getTypeOnlyPromotionFix(context.sourceFile, symbolToken, symbolName2, context.program); - return fix && [{ fix, symbolName: symbolName2, errorIdentifierText: symbolToken.text }]; + function annotateParameters(changes, importAdder, sourceFile, parameterDeclaration, containingFunction, program, host, cancellationToken) { + if (!isIdentifier(parameterDeclaration.name)) { + return; + } + const parameterInferences = inferTypeForParametersFromUsage(containingFunction, sourceFile, program, cancellationToken); + Debug.assert(containingFunction.parameters.length === parameterInferences.length, "Parameter count and inference count should match"); + if (isInJSFile(containingFunction)) { + annotateJSDocParameters(changes, sourceFile, parameterInferences, program, host); } else { - info = getFixesInfoForNonUMDImport(context, symbolToken, useAutoImportProvider); + const needParens = isArrowFunction(containingFunction) && !findChildOfKind(containingFunction, 21 /* OpenParenToken */, sourceFile); + if (needParens) + changes.insertNodeBefore(sourceFile, first(containingFunction.parameters), factory.createToken(21 /* OpenParenToken */)); + for (const { declaration, type } of parameterInferences) { + if (declaration && !declaration.type && !declaration.initializer) { + annotate(changes, importAdder, sourceFile, declaration, type, program, host); + } + } + if (needParens) + changes.insertNodeAfter(sourceFile, last(containingFunction.parameters), factory.createToken(22 /* CloseParenToken */)); } - const packageJsonImportFilter = createPackageJsonImportFilter(context.sourceFile, context.preferences, context.host); - return info && sortFixInfo(info, context.sourceFile, context.program, packageJsonImportFilter, context.host); - } - function sortFixInfo(fixes, sourceFile, program, packageJsonImportFilter, host) { - const _toPath = (fileName) => toPath(fileName, host.getCurrentDirectory(), hostGetCanonicalFileName(host)); - return sort(fixes, (a, b) => compareBooleans(!!a.isJsxNamespaceFix, !!b.isJsxNamespaceFix) || compareValues(a.fix.kind, b.fix.kind) || compareModuleSpecifiers(a.fix, b.fix, sourceFile, program, packageJsonImportFilter.allowsImportingSpecifier, _toPath)); } - function getBestFix(fixes, sourceFile, program, packageJsonImportFilter, host) { - if (!some(fixes)) + function annotateThis(changes, sourceFile, containingFunction, program, host, cancellationToken) { + const references = getFunctionReferences(containingFunction, sourceFile, program, cancellationToken); + if (!references || !references.length) { return; - if (fixes[0].kind === 0 /* UseNamespace */ || fixes[0].kind === 2 /* AddToExisting */) { - return fixes[0]; } - return fixes.reduce( - (best, fix) => ( - // Takes true branch of conditional if `fix` is better than `best` - compareModuleSpecifiers( - fix, - best, - sourceFile, - program, - packageJsonImportFilter.allowsImportingSpecifier, - (fileName) => toPath(fileName, host.getCurrentDirectory(), hostGetCanonicalFileName(host)) - ) === -1 /* LessThan */ ? fix : best - ) - ); - } - function compareModuleSpecifiers(a, b, importingFile, program, allowsImportingSpecifier, toPath3) { - if (a.kind !== 0 /* UseNamespace */ && b.kind !== 0 /* UseNamespace */) { - return compareBooleans(allowsImportingSpecifier(b.moduleSpecifier), allowsImportingSpecifier(a.moduleSpecifier)) || compareNodeCoreModuleSpecifiers(a.moduleSpecifier, b.moduleSpecifier, importingFile, program) || compareBooleans( - isFixPossiblyReExportingImportingFile(a, importingFile, program.getCompilerOptions(), toPath3), - isFixPossiblyReExportingImportingFile(b, importingFile, program.getCompilerOptions(), toPath3) - ) || compareNumberOfDirectorySeparators(a.moduleSpecifier, b.moduleSpecifier); + const thisInference = inferTypeFromReferences(program, references, cancellationToken).thisParameter(); + const typeNode = getTypeNodeIfAccessible(thisInference, containingFunction, program, host); + if (!typeNode) { + return; } - return 0 /* EqualTo */; - } - function isFixPossiblyReExportingImportingFile(fix, importingFile, compilerOptions, toPath3) { - var _a; - if (fix.isReExport && ((_a = fix.exportInfo) == null ? void 0 : _a.moduleFileName) && getEmitModuleResolutionKind(compilerOptions) === 2 /* Node10 */ && isIndexFileName(fix.exportInfo.moduleFileName)) { - const reExportDir = toPath3(getDirectoryPath(fix.exportInfo.moduleFileName)); - return startsWith(importingFile.path, reExportDir); + if (isInJSFile(containingFunction)) { + annotateJSDocThis(changes, sourceFile, containingFunction, typeNode); + } else { + changes.tryInsertThisTypeAnnotation(sourceFile, containingFunction, typeNode); } - return false; - } - function isIndexFileName(fileName) { - return getBaseFileName( - fileName, - [".js", ".jsx", ".d.ts", ".ts", ".tsx"], - /*ignoreCase*/ - true - ) === "index"; } - function compareNodeCoreModuleSpecifiers(a, b, importingFile, program) { - if (startsWith(a, "node:") && !startsWith(b, "node:")) - return shouldUseUriStyleNodeCoreModules(importingFile, program) ? -1 /* LessThan */ : 1 /* GreaterThan */; - if (startsWith(b, "node:") && !startsWith(a, "node:")) - return shouldUseUriStyleNodeCoreModules(importingFile, program) ? 1 /* GreaterThan */ : -1 /* LessThan */; - return 0 /* EqualTo */; - } - function getFixesInfoForUMDImport({ sourceFile, program, host, preferences }, token) { - const checker = program.getTypeChecker(); - const umdSymbol = getUmdSymbol(token, checker); - if (!umdSymbol) - return void 0; - const symbol = checker.getAliasedSymbol(umdSymbol); - const symbolName2 = umdSymbol.name; - const exportInfo = [{ symbol: umdSymbol, moduleSymbol: symbol, moduleFileName: void 0, exportKind: 3 /* UMD */, targetFlags: symbol.flags, isFromPackageJson: false }]; - const useRequire = shouldUseRequire(sourceFile, program); - const fixes = getImportFixes( - exportInfo, - /*usagePosition*/ - void 0, - /*isValidTypeOnlyUseSite*/ - false, - useRequire, - program, - sourceFile, - host, - preferences - ).fixes; - return fixes.map((fix) => { - var _a; - return { fix, symbolName: symbolName2, errorIdentifierText: (_a = tryCast(token, isIdentifier)) == null ? void 0 : _a.text }; - }); + function annotateJSDocThis(changes, sourceFile, containingFunction, typeNode) { + changes.addJSDocTags(sourceFile, containingFunction, [ + factory.createJSDocThisTag( + /*tagName*/ + void 0, + factory.createJSDocTypeExpression(typeNode) + ) + ]); } - function getUmdSymbol(token, checker) { - const umdSymbol = isIdentifier(token) ? checker.getSymbolAtLocation(token) : void 0; - if (isUMDExportSymbol(umdSymbol)) - return umdSymbol; - const { parent: parent2 } = token; - if (isJsxOpeningLikeElement(parent2) && parent2.tagName === token || isJsxOpeningFragment(parent2)) { - const parentSymbol = checker.resolveName( - checker.getJsxNamespace(parent2), - isJsxOpeningLikeElement(parent2) ? token : parent2, - 111551 /* Value */, - /*excludeGlobals*/ - false - ); - if (isUMDExportSymbol(parentSymbol)) { - return parentSymbol; + function annotateSetAccessor(changes, importAdder, sourceFile, setAccessorDeclaration, program, host, cancellationToken) { + const param = firstOrUndefined(setAccessorDeclaration.parameters); + if (param && isIdentifier(setAccessorDeclaration.name) && isIdentifier(param.name)) { + let type = inferTypeForVariableFromUsage(setAccessorDeclaration.name, program, cancellationToken); + if (type === program.getTypeChecker().getAnyType()) { + type = inferTypeForVariableFromUsage(param.name, program, cancellationToken); + } + if (isInJSFile(setAccessorDeclaration)) { + annotateJSDocParameters(changes, sourceFile, [{ declaration: param, type }], program, host); + } else { + annotate(changes, importAdder, sourceFile, param, type, program, host); } } - return void 0; } - function getImportKind(importingFile, exportKind, compilerOptions, forceImportKeyword) { - if (compilerOptions.verbatimModuleSyntax && (getEmitModuleKind(compilerOptions) === 1 /* CommonJS */ || importingFile.impliedNodeFormat === 1 /* CommonJS */)) { - return 3 /* CommonJS */; - } - switch (exportKind) { - case 0 /* Named */: - return 0 /* Named */; - case 1 /* Default */: - return 1 /* Default */; - case 2 /* ExportEquals */: - return getExportEqualsImportKind(importingFile, compilerOptions, !!forceImportKeyword); - case 3 /* UMD */: - return getUmdImportKind(importingFile, compilerOptions, !!forceImportKeyword); - default: - return Debug.assertNever(exportKind); + function annotate(changes, importAdder, sourceFile, declaration, type, program, host) { + const typeNode = getTypeNodeIfAccessible(type, declaration, program, host); + if (typeNode) { + if (isInJSFile(sourceFile) && declaration.kind !== 171 /* PropertySignature */) { + const parent2 = isVariableDeclaration(declaration) ? tryCast(declaration.parent.parent, isVariableStatement) : declaration; + if (!parent2) { + return; + } + const typeExpression = factory.createJSDocTypeExpression(typeNode); + const typeTag = isGetAccessorDeclaration(declaration) ? factory.createJSDocReturnTag( + /*tagName*/ + void 0, + typeExpression, + /*comment*/ + void 0 + ) : factory.createJSDocTypeTag( + /*tagName*/ + void 0, + typeExpression, + /*comment*/ + void 0 + ); + changes.addJSDocTags(sourceFile, parent2, [typeTag]); + } else if (!tryReplaceImportTypeNodeWithAutoImport(typeNode, declaration, sourceFile, changes, importAdder, getEmitScriptTarget(program.getCompilerOptions()))) { + changes.tryInsertTypeAnnotation(sourceFile, declaration, typeNode); + } } } - function getUmdImportKind(importingFile, compilerOptions, forceImportKeyword) { - if (getAllowSyntheticDefaultImports(compilerOptions)) { - return 1 /* Default */; - } - const moduleKind = getEmitModuleKind(compilerOptions); - switch (moduleKind) { - case 2 /* AMD */: - case 1 /* CommonJS */: - case 3 /* UMD */: - if (isInJSFile(importingFile)) { - return isExternalModule(importingFile) || forceImportKeyword ? 2 /* Namespace */ : 3 /* CommonJS */; - } - return 3 /* CommonJS */; - case 4 /* System */: - case 5 /* ES2015 */: - case 6 /* ES2020 */: - case 7 /* ES2022 */: - case 99 /* ESNext */: - case 0 /* None */: - return 2 /* Namespace */; - case 100 /* Node16 */: - case 199 /* NodeNext */: - return importingFile.impliedNodeFormat === 99 /* ESNext */ ? 2 /* Namespace */ : 3 /* CommonJS */; - default: - return Debug.assertNever(moduleKind, `Unexpected moduleKind ${moduleKind}`); + function tryReplaceImportTypeNodeWithAutoImport(typeNode, declaration, sourceFile, changes, importAdder, scriptTarget) { + const importableReference = tryGetAutoImportableReferenceFromTypeNode(typeNode, scriptTarget); + if (importableReference && changes.tryInsertTypeAnnotation(sourceFile, declaration, importableReference.typeNode)) { + forEach(importableReference.symbols, (s) => importAdder.addImportFromExportedSymbol( + s, + /*isValidTypeOnlyUseSite*/ + true + )); + return true; } + return false; } - function getFixesInfoForNonUMDImport({ sourceFile, program, cancellationToken, host, preferences }, symbolToken, useAutoImportProvider) { - const checker = program.getTypeChecker(); - const compilerOptions = program.getCompilerOptions(); - return flatMap(getSymbolNamesToImport(sourceFile, checker, symbolToken, compilerOptions), (symbolName2) => { - if (symbolName2 === "default" /* Default */) { - return void 0; + function annotateJSDocParameters(changes, sourceFile, parameterInferences, program, host) { + const signature = parameterInferences.length && parameterInferences[0].declaration.parent; + if (!signature) { + return; + } + const inferences = mapDefined(parameterInferences, (inference) => { + const param = inference.declaration; + if (param.initializer || getJSDocType(param) || !isIdentifier(param.name)) { + return; + } + const typeNode = inference.type && getTypeNodeIfAccessible(inference.type, param, program, host); + if (typeNode) { + const name = factory.cloneNode(param.name); + setEmitFlags(name, 3072 /* NoComments */ | 4096 /* NoNestedComments */); + return { name: factory.cloneNode(param.name), param, isOptional: !!inference.isOptional, typeNode }; } - const isValidTypeOnlyUseSite = isValidTypeOnlyAliasUseSite(symbolToken); - const useRequire = shouldUseRequire(sourceFile, program); - const exportInfo = getExportInfos(symbolName2, isJSXTagName(symbolToken), getMeaningFromLocation(symbolToken), cancellationToken, sourceFile, program, useAutoImportProvider, host, preferences); - return arrayFrom( - flatMapIterator(exportInfo.values(), (exportInfos) => getImportFixes(exportInfos, symbolToken.getStart(sourceFile), isValidTypeOnlyUseSite, useRequire, program, sourceFile, host, preferences).fixes), - (fix) => ({ fix, symbolName: symbolName2, errorIdentifierText: symbolToken.text, isJsxNamespaceFix: symbolName2 !== symbolToken.text }) - ); }); - } - function getTypeOnlyPromotionFix(sourceFile, symbolToken, symbolName2, program) { - const checker = program.getTypeChecker(); - const symbol = checker.resolveName( - symbolName2, - symbolToken, - 111551 /* Value */, - /*excludeGlobals*/ - true - ); - if (!symbol) - return void 0; - const typeOnlyAliasDeclaration = checker.getTypeOnlyAliasDeclaration(symbol); - if (!typeOnlyAliasDeclaration || getSourceFileOfNode(typeOnlyAliasDeclaration) !== sourceFile) - return void 0; - return { kind: 4 /* PromoteTypeOnly */, typeOnlyAliasDeclaration }; - } - function getSymbolNamesToImport(sourceFile, checker, symbolToken, compilerOptions) { - const parent2 = symbolToken.parent; - if ((isJsxOpeningLikeElement(parent2) || isJsxClosingElement(parent2)) && parent2.tagName === symbolToken && jsxModeNeedsExplicitImport(compilerOptions.jsx)) { - const jsxNamespace = checker.getJsxNamespace(sourceFile); - if (needsJsxNamespaceFix(jsxNamespace, symbolToken, checker)) { - const needsComponentNameFix = !isIntrinsicJsxName(symbolToken.text) && !checker.resolveName( - symbolToken.text, - symbolToken, - 111551 /* Value */, - /*excludeGlobals*/ - false + if (!inferences.length) { + return; + } + if (isArrowFunction(signature) || isFunctionExpression(signature)) { + const needParens = isArrowFunction(signature) && !findChildOfKind(signature, 21 /* OpenParenToken */, sourceFile); + if (needParens) { + changes.insertNodeBefore(sourceFile, first(signature.parameters), factory.createToken(21 /* OpenParenToken */)); + } + forEach(inferences, ({ typeNode, param }) => { + const typeTag = factory.createJSDocTypeTag( + /*tagName*/ + void 0, + factory.createJSDocTypeExpression(typeNode) ); - return needsComponentNameFix ? [symbolToken.text, jsxNamespace] : [jsxNamespace]; + const jsDoc = factory.createJSDocComment( + /*comment*/ + void 0, + [typeTag] + ); + changes.insertNodeAt(sourceFile, param.getStart(sourceFile), jsDoc, { suffix: " " }); + }); + if (needParens) { + changes.insertNodeAfter(sourceFile, last(signature.parameters), factory.createToken(22 /* CloseParenToken */)); } + } else { + const paramTags = map(inferences, ({ name, typeNode, isOptional }) => factory.createJSDocParameterTag( + /*tagName*/ + void 0, + name, + /*isBracketed*/ + !!isOptional, + factory.createJSDocTypeExpression(typeNode), + /*isNameFirst*/ + false, + /*comment*/ + void 0 + )); + changes.addJSDocTags(sourceFile, signature, paramTags); } - return [symbolToken.text]; } - function needsJsxNamespaceFix(jsxNamespace, symbolToken, checker) { - if (isIntrinsicJsxName(symbolToken.text)) - return true; - const namespaceSymbol = checker.resolveName( - jsxNamespace, - symbolToken, - 111551 /* Value */, - /*excludeGlobals*/ - true - ); - return !namespaceSymbol || some(namespaceSymbol.declarations, isTypeOnlyImportOrExportDeclaration) && !(namespaceSymbol.flags & 111551 /* Value */); + function getReferences(token, program, cancellationToken) { + return mapDefined(ts_FindAllReferences_exports.getReferenceEntriesForNode(-1, token, program, program.getSourceFiles(), cancellationToken), (entry) => entry.kind !== ts_FindAllReferences_exports.EntryKind.Span ? tryCast(entry.node, isIdentifier) : void 0); } - function getExportInfos(symbolName2, isJsxTagName, currentTokenMeaning, cancellationToken, fromFile, program, useAutoImportProvider, host, preferences) { - var _a; - const originalSymbolToExportInfos = createMultiMap(); - const packageJsonFilter = createPackageJsonImportFilter(fromFile, preferences, host); - const moduleSpecifierCache = (_a = host.getModuleSpecifierCache) == null ? void 0 : _a.call(host); - const getModuleSpecifierResolutionHost = memoizeOne((isFromPackageJson) => { - return createModuleSpecifierResolutionHost(isFromPackageJson ? host.getPackageJsonAutoImportProvider() : program, host); - }); - function addSymbol(moduleSymbol, toFile, exportedSymbol, exportKind, program2, isFromPackageJson) { - const moduleSpecifierResolutionHost = getModuleSpecifierResolutionHost(isFromPackageJson); - if (toFile && isImportableFile(program2, fromFile, toFile, preferences, packageJsonFilter, moduleSpecifierResolutionHost, moduleSpecifierCache) || !toFile && packageJsonFilter.allowsImportingAmbientModule(moduleSymbol, moduleSpecifierResolutionHost)) { - const checker = program2.getTypeChecker(); - originalSymbolToExportInfos.add(getUniqueSymbolId(exportedSymbol, checker).toString(), { symbol: exportedSymbol, moduleSymbol, moduleFileName: toFile == null ? void 0 : toFile.fileName, exportKind, targetFlags: skipAlias(exportedSymbol, checker).flags, isFromPackageJson }); + function inferTypeForVariableFromUsage(token, program, cancellationToken) { + const references = getReferences(token, program, cancellationToken); + return inferTypeFromReferences(program, references, cancellationToken).single(); + } + function inferTypeForParametersFromUsage(func, sourceFile, program, cancellationToken) { + const references = getFunctionReferences(func, sourceFile, program, cancellationToken); + return references && inferTypeFromReferences(program, references, cancellationToken).parameters(func) || func.parameters.map((p) => ({ + declaration: p, + type: isIdentifier(p.name) ? inferTypeForVariableFromUsage(p.name, program, cancellationToken) : program.getTypeChecker().getAnyType() + })); + } + function getFunctionReferences(containingFunction, sourceFile, program, cancellationToken) { + let searchToken; + switch (containingFunction.kind) { + case 176 /* Constructor */: + searchToken = findChildOfKind(containingFunction, 137 /* ConstructorKeyword */, sourceFile); + break; + case 219 /* ArrowFunction */: + case 218 /* FunctionExpression */: + const parent2 = containingFunction.parent; + searchToken = (isVariableDeclaration(parent2) || isPropertyDeclaration(parent2)) && isIdentifier(parent2.name) ? parent2.name : containingFunction.name; + break; + case 262 /* FunctionDeclaration */: + case 174 /* MethodDeclaration */: + case 173 /* MethodSignature */: + searchToken = containingFunction.name; + break; + } + if (!searchToken) { + return void 0; + } + return getReferences(searchToken, program, cancellationToken); + } + function inferTypeFromReferences(program, references, cancellationToken) { + const checker = program.getTypeChecker(); + const builtinConstructors = { + string: () => checker.getStringType(), + number: () => checker.getNumberType(), + Array: (t) => checker.createArrayType(t), + Promise: (t) => checker.createPromiseType(t) + }; + const builtins = [ + checker.getStringType(), + checker.getNumberType(), + checker.createArrayType(checker.getAnyType()), + checker.createPromiseType(checker.getAnyType()) + ]; + return { + single: single2, + parameters, + thisParameter + }; + function createEmptyUsage() { + return { + isNumber: void 0, + isString: void 0, + isNumberOrString: void 0, + candidateTypes: void 0, + properties: void 0, + calls: void 0, + constructs: void 0, + numberIndex: void 0, + stringIndex: void 0, + candidateThisTypes: void 0, + inferredTypes: void 0 + }; + } + function combineUsages(usages) { + const combinedProperties = /* @__PURE__ */ new Map(); + for (const u of usages) { + if (u.properties) { + u.properties.forEach((p, name) => { + if (!combinedProperties.has(name)) { + combinedProperties.set(name, []); + } + combinedProperties.get(name).push(p); + }); + } } + const properties = /* @__PURE__ */ new Map(); + combinedProperties.forEach((ps, name) => { + properties.set(name, combineUsages(ps)); + }); + return { + isNumber: usages.some((u) => u.isNumber), + isString: usages.some((u) => u.isString), + isNumberOrString: usages.some((u) => u.isNumberOrString), + candidateTypes: flatMap(usages, (u) => u.candidateTypes), + properties, + calls: flatMap(usages, (u) => u.calls), + constructs: flatMap(usages, (u) => u.constructs), + numberIndex: forEach(usages, (u) => u.numberIndex), + stringIndex: forEach(usages, (u) => u.stringIndex), + candidateThisTypes: flatMap(usages, (u) => u.candidateThisTypes), + inferredTypes: void 0 + // clear type cache + }; } - forEachExternalModuleToImportFrom(program, host, preferences, useAutoImportProvider, (moduleSymbol, sourceFile, program2, isFromPackageJson) => { - const checker = program2.getTypeChecker(); - cancellationToken.throwIfCancellationRequested(); - const compilerOptions = program2.getCompilerOptions(); - const defaultInfo = getDefaultLikeExportInfo(moduleSymbol, checker, compilerOptions); - if (defaultInfo && (defaultInfo.name === symbolName2 || moduleSymbolToValidIdentifier(moduleSymbol, getEmitScriptTarget(compilerOptions), isJsxTagName) === symbolName2) && symbolHasMeaning(defaultInfo.resolvedSymbol, currentTokenMeaning)) { - addSymbol(moduleSymbol, sourceFile, defaultInfo.symbol, defaultInfo.exportKind, program2, isFromPackageJson); + function single2() { + return combineTypes(inferTypesFromReferencesSingle(references)); + } + function parameters(declaration) { + if (references.length === 0 || !declaration.parameters) { + return void 0; } - const exportSymbolWithIdenticalName = checker.tryGetMemberInModuleExportsAndProperties(symbolName2, moduleSymbol); - if (exportSymbolWithIdenticalName && symbolHasMeaning(exportSymbolWithIdenticalName, currentTokenMeaning)) { - addSymbol(moduleSymbol, sourceFile, exportSymbolWithIdenticalName, 0 /* Named */, program2, isFromPackageJson); + const usage = createEmptyUsage(); + for (const reference of references) { + cancellationToken.throwIfCancellationRequested(); + calculateUsageOfNode(reference, usage); } - }); - return originalSymbolToExportInfos; - } - function getExportEqualsImportKind(importingFile, compilerOptions, forceImportKeyword) { - const allowSyntheticDefaults = getAllowSyntheticDefaultImports(compilerOptions); - const isJS = isInJSFile(importingFile); - if (!isJS && getEmitModuleKind(compilerOptions) >= 5 /* ES2015 */) { - return allowSyntheticDefaults ? 1 /* Default */ : 2 /* Namespace */; + const calls = [...usage.constructs || [], ...usage.calls || []]; + return declaration.parameters.map((parameter, parameterIndex) => { + const types = []; + const isRest = isRestParameter(parameter); + let isOptional = false; + for (const call of calls) { + if (call.argumentTypes.length <= parameterIndex) { + isOptional = isInJSFile(declaration); + types.push(checker.getUndefinedType()); + } else if (isRest) { + for (let i = parameterIndex; i < call.argumentTypes.length; i++) { + types.push(checker.getBaseTypeOfLiteralType(call.argumentTypes[i])); + } + } else { + types.push(checker.getBaseTypeOfLiteralType(call.argumentTypes[parameterIndex])); + } + } + if (isIdentifier(parameter.name)) { + const inferred = inferTypesFromReferencesSingle(getReferences(parameter.name, program, cancellationToken)); + types.push(...isRest ? mapDefined(inferred, checker.getElementTypeOfArrayType) : inferred); + } + const type = combineTypes(types); + return { + type: isRest ? checker.createArrayType(type) : type, + isOptional: isOptional && !isRest, + declaration: parameter + }; + }); } - if (isJS) { - return isExternalModule(importingFile) || forceImportKeyword ? allowSyntheticDefaults ? 1 /* Default */ : 2 /* Namespace */ : 3 /* CommonJS */; + function thisParameter() { + const usage = createEmptyUsage(); + for (const reference of references) { + cancellationToken.throwIfCancellationRequested(); + calculateUsageOfNode(reference, usage); + } + return combineTypes(usage.candidateThisTypes || emptyArray); } - for (const statement of importingFile.statements) { - if (isImportEqualsDeclaration(statement) && !nodeIsMissing(statement.moduleReference)) { - return 3 /* CommonJS */; + function inferTypesFromReferencesSingle(references2) { + const usage = createEmptyUsage(); + for (const reference of references2) { + cancellationToken.throwIfCancellationRequested(); + calculateUsageOfNode(reference, usage); } + return inferTypes(usage); } - return allowSyntheticDefaults ? 1 /* Default */ : 3 /* CommonJS */; - } - function codeActionForFix(context, sourceFile, symbolName2, fix, includeSymbolNameInDescription, compilerOptions, preferences) { - let diag2; - const changes = ts_textChanges_exports.ChangeTracker.with(context, (tracker) => { - diag2 = codeActionForFixWorker(tracker, sourceFile, symbolName2, fix, includeSymbolNameInDescription, compilerOptions, preferences); - }); - return createCodeFixAction(importFixName, changes, diag2, importFixId, Diagnostics.Add_all_missing_imports); - } - function codeActionForFixWorker(changes, sourceFile, symbolName2, fix, includeSymbolNameInDescription, compilerOptions, preferences) { - const quotePreference = getQuotePreference(sourceFile, preferences); - switch (fix.kind) { - case 0 /* UseNamespace */: - addNamespaceQualifier(changes, sourceFile, fix); - return [Diagnostics.Change_0_to_1, symbolName2, `${fix.namespacePrefix}.${symbolName2}`]; - case 1 /* JsdocTypeImport */: - addImportType(changes, sourceFile, fix, quotePreference); - return [Diagnostics.Change_0_to_1, symbolName2, getImportTypePrefix(fix.moduleSpecifier, quotePreference) + symbolName2]; - case 2 /* AddToExisting */: { - const { importClauseOrBindingPattern, importKind, addAsTypeOnly, moduleSpecifier } = fix; - doAddExistingFix( - changes, - sourceFile, - importClauseOrBindingPattern, - importKind === 1 /* Default */ ? { name: symbolName2, addAsTypeOnly } : void 0, - importKind === 0 /* Named */ ? [{ name: symbolName2, addAsTypeOnly }] : emptyArray, - preferences - ); - const moduleSpecifierWithoutQuotes = stripQuotes(moduleSpecifier); - return includeSymbolNameInDescription ? [Diagnostics.Import_0_from_1, symbolName2, moduleSpecifierWithoutQuotes] : [Diagnostics.Update_import_from_0, moduleSpecifierWithoutQuotes]; + function calculateUsageOfNode(node, usage) { + while (isRightSideOfQualifiedNameOrPropertyAccess(node)) { + node = node.parent; } - case 3 /* AddNew */: { - const { importKind, moduleSpecifier, addAsTypeOnly, useRequire, qualification } = fix; - const getDeclarations = useRequire ? getNewRequires : getNewImports; - const defaultImport = importKind === 1 /* Default */ ? { name: symbolName2, addAsTypeOnly } : void 0; - const namedImports = importKind === 0 /* Named */ ? [{ name: symbolName2, addAsTypeOnly }] : void 0; - const namespaceLikeImport = importKind === 2 /* Namespace */ || importKind === 3 /* CommonJS */ ? { importKind, name: (qualification == null ? void 0 : qualification.namespacePrefix) || symbolName2, addAsTypeOnly } : void 0; - insertImports( - changes, - sourceFile, - getDeclarations( - moduleSpecifier, - quotePreference, - defaultImport, - namedImports, - namespaceLikeImport, - compilerOptions - ), - /*blankLineBetween*/ - true, - preferences - ); - if (qualification) { - addNamespaceQualifier(changes, sourceFile, qualification); + switch (node.parent.kind) { + case 244 /* ExpressionStatement */: + inferTypeFromExpressionStatement(node, usage); + break; + case 225 /* PostfixUnaryExpression */: + usage.isNumber = true; + break; + case 224 /* PrefixUnaryExpression */: + inferTypeFromPrefixUnaryExpression(node.parent, usage); + break; + case 226 /* BinaryExpression */: + inferTypeFromBinaryExpression(node, node.parent, usage); + break; + case 296 /* CaseClause */: + case 297 /* DefaultClause */: + inferTypeFromSwitchStatementLabel(node.parent, usage); + break; + case 213 /* CallExpression */: + case 214 /* NewExpression */: + if (node.parent.expression === node) { + inferTypeFromCallExpression(node.parent, usage); + } else { + inferTypeFromContextualType(node, usage); + } + break; + case 211 /* PropertyAccessExpression */: + inferTypeFromPropertyAccessExpression(node.parent, usage); + break; + case 212 /* ElementAccessExpression */: + inferTypeFromPropertyElementExpression(node.parent, node, usage); + break; + case 303 /* PropertyAssignment */: + case 304 /* ShorthandPropertyAssignment */: + inferTypeFromPropertyAssignment(node.parent, usage); + break; + case 172 /* PropertyDeclaration */: + inferTypeFromPropertyDeclaration(node.parent, usage); + break; + case 260 /* VariableDeclaration */: { + const { name, initializer } = node.parent; + if (node === name) { + if (initializer) { + addCandidateType(usage, checker.getTypeAtLocation(initializer)); + } + break; + } } - return includeSymbolNameInDescription ? [Diagnostics.Import_0_from_1, symbolName2, moduleSpecifier] : [Diagnostics.Add_import_from_0, moduleSpecifier]; + default: + return inferTypeFromContextualType(node, usage); } - case 4 /* PromoteTypeOnly */: { - const { typeOnlyAliasDeclaration } = fix; - const promotedDeclaration = promoteFromTypeOnly(changes, typeOnlyAliasDeclaration, compilerOptions, sourceFile, preferences); - return promotedDeclaration.kind === 275 /* ImportSpecifier */ ? [Diagnostics.Remove_type_from_import_of_0_from_1, symbolName2, getModuleSpecifierText(promotedDeclaration.parent.parent)] : [Diagnostics.Remove_type_from_import_declaration_from_0, getModuleSpecifierText(promotedDeclaration)]; + } + function inferTypeFromContextualType(node, usage) { + if (isExpressionNode(node)) { + addCandidateType(usage, checker.getContextualType(node)); } - default: - return Debug.assertNever(fix, `Unexpected fix kind ${fix.kind}`); } - } - function getModuleSpecifierText(promotedDeclaration) { - var _a, _b; - return promotedDeclaration.kind === 270 /* ImportEqualsDeclaration */ ? ((_b = tryCast((_a = tryCast(promotedDeclaration.moduleReference, isExternalModuleReference)) == null ? void 0 : _a.expression, isStringLiteralLike)) == null ? void 0 : _b.text) || promotedDeclaration.moduleReference.getText() : cast(promotedDeclaration.parent.moduleSpecifier, isStringLiteral).text; - } - function promoteFromTypeOnly(changes, aliasDeclaration, compilerOptions, sourceFile, preferences) { - const convertExistingToTypeOnly = importNameElisionDisabled(compilerOptions); - switch (aliasDeclaration.kind) { - case 275 /* ImportSpecifier */: - if (aliasDeclaration.isTypeOnly) { - const sortKind = ts_OrganizeImports_exports.detectImportSpecifierSorting(aliasDeclaration.parent.elements, preferences); - if (aliasDeclaration.parent.elements.length > 1 && sortKind) { - changes.delete(sourceFile, aliasDeclaration); - const newSpecifier = factory.updateImportSpecifier( - aliasDeclaration, - /*isTypeOnly*/ - false, - aliasDeclaration.propertyName, - aliasDeclaration.name - ); - const comparer = ts_OrganizeImports_exports.getOrganizeImportsComparer(preferences, sortKind === 2 /* CaseInsensitive */); - const insertionIndex = ts_OrganizeImports_exports.getImportSpecifierInsertionIndex(aliasDeclaration.parent.elements, newSpecifier, comparer); - changes.insertImportSpecifierAtIndex(sourceFile, newSpecifier, aliasDeclaration.parent, insertionIndex); + function inferTypeFromExpressionStatement(node, usage) { + addCandidateType(usage, isCallExpression(node) ? checker.getVoidType() : checker.getAnyType()); + } + function inferTypeFromPrefixUnaryExpression(node, usage) { + switch (node.operator) { + case 46 /* PlusPlusToken */: + case 47 /* MinusMinusToken */: + case 41 /* MinusToken */: + case 55 /* TildeToken */: + usage.isNumber = true; + break; + case 40 /* PlusToken */: + usage.isNumberOrString = true; + break; + } + } + function inferTypeFromBinaryExpression(node, parent2, usage) { + switch (parent2.operatorToken.kind) { + case 43 /* AsteriskAsteriskToken */: + case 42 /* AsteriskToken */: + case 44 /* SlashToken */: + case 45 /* PercentToken */: + case 48 /* LessThanLessThanToken */: + case 49 /* GreaterThanGreaterThanToken */: + case 50 /* GreaterThanGreaterThanGreaterThanToken */: + case 51 /* AmpersandToken */: + case 52 /* BarToken */: + case 53 /* CaretToken */: + case 66 /* MinusEqualsToken */: + case 68 /* AsteriskAsteriskEqualsToken */: + case 67 /* AsteriskEqualsToken */: + case 69 /* SlashEqualsToken */: + case 70 /* PercentEqualsToken */: + case 74 /* AmpersandEqualsToken */: + case 75 /* BarEqualsToken */: + case 79 /* CaretEqualsToken */: + case 71 /* LessThanLessThanEqualsToken */: + case 73 /* GreaterThanGreaterThanGreaterThanEqualsToken */: + case 72 /* GreaterThanGreaterThanEqualsToken */: + case 41 /* MinusToken */: + case 30 /* LessThanToken */: + case 33 /* LessThanEqualsToken */: + case 32 /* GreaterThanToken */: + case 34 /* GreaterThanEqualsToken */: + const operandType = checker.getTypeAtLocation(parent2.left === node ? parent2.right : parent2.left); + if (operandType.flags & 1056 /* EnumLike */) { + addCandidateType(usage, operandType); } else { - changes.deleteRange(sourceFile, aliasDeclaration.getFirstToken()); + usage.isNumber = true; } - return aliasDeclaration; - } else { - Debug.assert(aliasDeclaration.parent.parent.isTypeOnly); - promoteImportClause(aliasDeclaration.parent.parent); - return aliasDeclaration.parent.parent; - } - case 272 /* ImportClause */: - promoteImportClause(aliasDeclaration); - return aliasDeclaration; - case 273 /* NamespaceImport */: - promoteImportClause(aliasDeclaration.parent); - return aliasDeclaration.parent; - case 270 /* ImportEqualsDeclaration */: - changes.deleteRange(sourceFile, aliasDeclaration.getChildAt(1)); - return aliasDeclaration; - default: - Debug.failBadSyntaxKind(aliasDeclaration); - } - function promoteImportClause(importClause) { - changes.delete(sourceFile, getTypeKeywordOfTypeOnlyImport(importClause, sourceFile)); - if (convertExistingToTypeOnly) { - const namedImports = tryCast(importClause.namedBindings, isNamedImports); - if (namedImports && namedImports.elements.length > 1) { - if (ts_OrganizeImports_exports.detectImportSpecifierSorting(namedImports.elements, preferences) && aliasDeclaration.kind === 275 /* ImportSpecifier */ && namedImports.elements.indexOf(aliasDeclaration) !== 0) { - changes.delete(sourceFile, aliasDeclaration); - changes.insertImportSpecifierAtIndex(sourceFile, aliasDeclaration, namedImports, 0); + break; + case 65 /* PlusEqualsToken */: + case 40 /* PlusToken */: + const otherOperandType = checker.getTypeAtLocation(parent2.left === node ? parent2.right : parent2.left); + if (otherOperandType.flags & 1056 /* EnumLike */) { + addCandidateType(usage, otherOperandType); + } else if (otherOperandType.flags & 296 /* NumberLike */) { + usage.isNumber = true; + } else if (otherOperandType.flags & 402653316 /* StringLike */) { + usage.isString = true; + } else if (otherOperandType.flags & 1 /* Any */) { + } else { + usage.isNumberOrString = true; + } + break; + case 64 /* EqualsToken */: + case 35 /* EqualsEqualsToken */: + case 37 /* EqualsEqualsEqualsToken */: + case 38 /* ExclamationEqualsEqualsToken */: + case 36 /* ExclamationEqualsToken */: + case 77 /* AmpersandAmpersandEqualsToken */: + case 78 /* QuestionQuestionEqualsToken */: + case 76 /* BarBarEqualsToken */: + addCandidateType(usage, checker.getTypeAtLocation(parent2.left === node ? parent2.right : parent2.left)); + break; + case 103 /* InKeyword */: + if (node === parent2.left) { + usage.isString = true; } - for (const element of namedImports.elements) { - if (element !== aliasDeclaration && !element.isTypeOnly) { - changes.insertModifierBefore(sourceFile, 156 /* TypeKeyword */, element); - } + break; + case 57 /* BarBarToken */: + case 61 /* QuestionQuestionToken */: + if (node === parent2.left && (node.parent.parent.kind === 260 /* VariableDeclaration */ || isAssignmentExpression( + node.parent.parent, + /*excludeCompoundAssignment*/ + true + ))) { + addCandidateType(usage, checker.getTypeAtLocation(parent2.right)); } - } - } - } - } - function doAddExistingFix(changes, sourceFile, clause, defaultImport, namedImports, preferences) { - var _a; - if (clause.kind === 205 /* ObjectBindingPattern */) { - if (defaultImport) { - addElementToBindingPattern(clause, defaultImport.name, "default"); - } - for (const specifier of namedImports) { - addElementToBindingPattern( - clause, - specifier.name, - /*propertyName*/ - void 0 - ); + break; + case 56 /* AmpersandAmpersandToken */: + case 28 /* CommaToken */: + case 104 /* InstanceOfKeyword */: + break; } - return; } - const promoteFromTypeOnly2 = clause.isTypeOnly && some([defaultImport, ...namedImports], (i) => (i == null ? void 0 : i.addAsTypeOnly) === 4 /* NotAllowed */); - const existingSpecifiers = clause.namedBindings && ((_a = tryCast(clause.namedBindings, isNamedImports)) == null ? void 0 : _a.elements); - if (defaultImport) { - Debug.assert(!clause.name, "Cannot add a default import to an import clause that already has one"); - changes.insertNodeAt(sourceFile, clause.getStart(sourceFile), factory.createIdentifier(defaultImport.name), { suffix: ", " }); + function inferTypeFromSwitchStatementLabel(parent2, usage) { + addCandidateType(usage, checker.getTypeAtLocation(parent2.parent.parent.expression)); } - if (namedImports.length) { - let ignoreCaseForSorting; - if (typeof preferences.organizeImportsIgnoreCase === "boolean") { - ignoreCaseForSorting = preferences.organizeImportsIgnoreCase; - } else if (existingSpecifiers) { - const targetImportSorting = ts_OrganizeImports_exports.detectImportSpecifierSorting(existingSpecifiers, preferences); - if (targetImportSorting !== 3 /* Both */) { - ignoreCaseForSorting = targetImportSorting === 2 /* CaseInsensitive */; + function inferTypeFromCallExpression(parent2, usage) { + const call = { + argumentTypes: [], + return_: createEmptyUsage() + }; + if (parent2.arguments) { + for (const argument of parent2.arguments) { + call.argumentTypes.push(checker.getTypeAtLocation(argument)); } } - if (ignoreCaseForSorting === void 0) { - ignoreCaseForSorting = ts_OrganizeImports_exports.detectSorting(sourceFile, preferences) === 2 /* CaseInsensitive */; - } - const comparer = ts_OrganizeImports_exports.getOrganizeImportsComparer(preferences, ignoreCaseForSorting); - const newSpecifiers = stableSort( - namedImports.map((namedImport) => factory.createImportSpecifier( - (!clause.isTypeOnly || promoteFromTypeOnly2) && needsTypeOnly(namedImport), - /*propertyName*/ - void 0, - factory.createIdentifier(namedImport.name) - )), - (s1, s2) => ts_OrganizeImports_exports.compareImportOrExportSpecifiers(s1, s2, comparer) - ); - const specifierSort = (existingSpecifiers == null ? void 0 : existingSpecifiers.length) && ts_OrganizeImports_exports.detectImportSpecifierSorting(existingSpecifiers, preferences); - if (specifierSort && !(ignoreCaseForSorting && specifierSort === 1 /* CaseSensitive */)) { - for (const spec of newSpecifiers) { - const insertionIndex = promoteFromTypeOnly2 && !spec.isTypeOnly ? 0 : ts_OrganizeImports_exports.getImportSpecifierInsertionIndex(existingSpecifiers, spec, comparer); - changes.insertImportSpecifierAtIndex(sourceFile, spec, clause.namedBindings, insertionIndex); - } - } else if (existingSpecifiers == null ? void 0 : existingSpecifiers.length) { - for (const spec of newSpecifiers) { - changes.insertNodeInListAfter(sourceFile, last(existingSpecifiers), spec, existingSpecifiers); - } + calculateUsageOfNode(parent2, call.return_); + if (parent2.kind === 213 /* CallExpression */) { + (usage.calls || (usage.calls = [])).push(call); } else { - if (newSpecifiers.length) { - const namedImports2 = factory.createNamedImports(newSpecifiers); - if (clause.namedBindings) { - changes.replaceNode(sourceFile, clause.namedBindings, namedImports2); - } else { - changes.insertNodeAfter(sourceFile, Debug.checkDefined(clause.name, "Import clause must have either named imports or a default import"), namedImports2); - } - } + (usage.constructs || (usage.constructs = [])).push(call); } } - if (promoteFromTypeOnly2) { - changes.delete(sourceFile, getTypeKeywordOfTypeOnlyImport(clause, sourceFile)); - if (existingSpecifiers) { - for (const specifier of existingSpecifiers) { - changes.insertModifierBefore(sourceFile, 156 /* TypeKeyword */, specifier); - } + function inferTypeFromPropertyAccessExpression(parent2, usage) { + const name = escapeLeadingUnderscores(parent2.name.text); + if (!usage.properties) { + usage.properties = /* @__PURE__ */ new Map(); } + const propertyUsage = usage.properties.get(name) || createEmptyUsage(); + calculateUsageOfNode(parent2, propertyUsage); + usage.properties.set(name, propertyUsage); } - function addElementToBindingPattern(bindingPattern, name, propertyName) { - const element = factory.createBindingElement( - /*dotDotDotToken*/ - void 0, - propertyName, - name - ); - if (bindingPattern.elements.length) { - changes.insertNodeInListAfter(sourceFile, last(bindingPattern.elements), element); + function inferTypeFromPropertyElementExpression(parent2, node, usage) { + if (node === parent2.argumentExpression) { + usage.isNumberOrString = true; + return; } else { - changes.replaceNode(sourceFile, bindingPattern, factory.createObjectBindingPattern([element])); + const indexType = checker.getTypeAtLocation(parent2.argumentExpression); + const indexUsage = createEmptyUsage(); + calculateUsageOfNode(parent2, indexUsage); + if (indexType.flags & 296 /* NumberLike */) { + usage.numberIndex = indexUsage; + } else { + usage.stringIndex = indexUsage; + } } } - } - function addNamespaceQualifier(changes, sourceFile, { namespacePrefix, usagePosition }) { - changes.insertText(sourceFile, usagePosition, namespacePrefix + "."); - } - function addImportType(changes, sourceFile, { moduleSpecifier, usagePosition: position }, quotePreference) { - changes.insertText(sourceFile, position, getImportTypePrefix(moduleSpecifier, quotePreference)); - } - function getImportTypePrefix(moduleSpecifier, quotePreference) { - const quote2 = getQuoteFromPreference(quotePreference); - return `import(${quote2}${moduleSpecifier}${quote2}).`; - } - function needsTypeOnly({ addAsTypeOnly }) { - return addAsTypeOnly === 2 /* Required */; - } - function getNewImports(moduleSpecifier, quotePreference, defaultImport, namedImports, namespaceLikeImport, compilerOptions) { - const quotedModuleSpecifier = makeStringLiteral(moduleSpecifier, quotePreference); - let statements; - if (defaultImport !== void 0 || (namedImports == null ? void 0 : namedImports.length)) { - const topLevelTypeOnly = (!defaultImport || needsTypeOnly(defaultImport)) && every(namedImports, needsTypeOnly) || compilerOptions.verbatimModuleSyntax && (defaultImport == null ? void 0 : defaultImport.addAsTypeOnly) !== 4 /* NotAllowed */ && !some(namedImports, (i) => i.addAsTypeOnly === 4 /* NotAllowed */); - statements = combine(statements, makeImport( - defaultImport && factory.createIdentifier(defaultImport.name), - namedImports == null ? void 0 : namedImports.map(({ addAsTypeOnly, name }) => factory.createImportSpecifier( - !topLevelTypeOnly && addAsTypeOnly === 2 /* Required */, - /*propertyName*/ - void 0, - factory.createIdentifier(name) - )), - moduleSpecifier, - quotePreference, - topLevelTypeOnly - )); + function inferTypeFromPropertyAssignment(assignment, usage) { + const nodeWithRealType = isVariableDeclaration(assignment.parent.parent) ? assignment.parent.parent : assignment.parent; + addCandidateThisType(usage, checker.getTypeAtLocation(nodeWithRealType)); } - if (namespaceLikeImport) { - const declaration = namespaceLikeImport.importKind === 3 /* CommonJS */ ? factory.createImportEqualsDeclaration( - /*modifiers*/ - void 0, - needsTypeOnly(namespaceLikeImport), - factory.createIdentifier(namespaceLikeImport.name), - factory.createExternalModuleReference(quotedModuleSpecifier) - ) : factory.createImportDeclaration( - /*modifiers*/ - void 0, - factory.createImportClause( - needsTypeOnly(namespaceLikeImport), - /*name*/ - void 0, - factory.createNamespaceImport(factory.createIdentifier(namespaceLikeImport.name)) - ), - quotedModuleSpecifier, - /*assertClause*/ - void 0 - ); - statements = combine(statements, declaration); + function inferTypeFromPropertyDeclaration(declaration, usage) { + addCandidateThisType(usage, checker.getTypeAtLocation(declaration.parent)); } - return Debug.checkDefined(statements); - } - function getNewRequires(moduleSpecifier, quotePreference, defaultImport, namedImports, namespaceLikeImport) { - const quotedModuleSpecifier = makeStringLiteral(moduleSpecifier, quotePreference); - let statements; - if (defaultImport || (namedImports == null ? void 0 : namedImports.length)) { - const bindingElements = (namedImports == null ? void 0 : namedImports.map(({ name }) => factory.createBindingElement( - /*dotDotDotToken*/ - void 0, - /*propertyName*/ - void 0, - name - ))) || []; - if (defaultImport) { - bindingElements.unshift(factory.createBindingElement( - /*dotDotDotToken*/ - void 0, - "default", - defaultImport.name - )); + function removeLowPriorityInferences(inferences, priorities) { + const toRemove = []; + for (const i of inferences) { + for (const { high, low } of priorities) { + if (high(i)) { + Debug.assert(!low(i), "Priority can't have both low and high"); + toRemove.push(low); + } + } } - const declaration = createConstEqualsRequireDeclaration(factory.createObjectBindingPattern(bindingElements), quotedModuleSpecifier); - statements = combine(statements, declaration); - } - if (namespaceLikeImport) { - const declaration = createConstEqualsRequireDeclaration(namespaceLikeImport.name, quotedModuleSpecifier); - statements = combine(statements, declaration); + return inferences.filter((i) => toRemove.every((f) => !f(i))); } - return Debug.checkDefined(statements); - } - function createConstEqualsRequireDeclaration(name, quotedModuleSpecifier) { - return factory.createVariableStatement( - /*modifiers*/ - void 0, - factory.createVariableDeclarationList( - [ - factory.createVariableDeclaration( - typeof name === "string" ? factory.createIdentifier(name) : name, - /*exclamationToken*/ - void 0, - /*type*/ - void 0, - factory.createCallExpression( - factory.createIdentifier("require"), - /*typeArguments*/ - void 0, - [quotedModuleSpecifier] - ) - ) - ], - 2 /* Const */ - ) - ); - } - function symbolHasMeaning({ declarations }, meaning) { - return some(declarations, (decl) => !!(getMeaningFromDeclaration(decl) & meaning)); - } - function moduleSymbolToValidIdentifier(moduleSymbol, target, forceCapitalize) { - return moduleSpecifierToValidIdentifier(removeFileExtension(stripQuotes(moduleSymbol.name)), target, forceCapitalize); - } - function moduleSpecifierToValidIdentifier(moduleSpecifier, target, forceCapitalize) { - const baseName = getBaseFileName(removeSuffix(moduleSpecifier, "/index")); - let res = ""; - let lastCharWasValid = true; - const firstCharCode = baseName.charCodeAt(0); - if (isIdentifierStart(firstCharCode, target)) { - res += String.fromCharCode(firstCharCode); - if (forceCapitalize) { - res = res.toUpperCase(); - } - } else { - lastCharWasValid = false; + function combineFromUsage(usage) { + return combineTypes(inferTypes(usage)); } - for (let i = 1; i < baseName.length; i++) { - const ch = baseName.charCodeAt(i); - const isValid = isIdentifierPart(ch, target); - if (isValid) { - let char = String.fromCharCode(ch); - if (!lastCharWasValid) { - char = char.toUpperCase(); + function combineTypes(inferences) { + if (!inferences.length) + return checker.getAnyType(); + const stringNumber = checker.getUnionType([checker.getStringType(), checker.getNumberType()]); + const priorities = [ + { + high: (t) => t === checker.getStringType() || t === checker.getNumberType(), + low: (t) => t === stringNumber + }, + { + high: (t) => !(t.flags & (1 /* Any */ | 16384 /* Void */)), + low: (t) => !!(t.flags & (1 /* Any */ | 16384 /* Void */)) + }, + { + high: (t) => !(t.flags & (98304 /* Nullable */ | 1 /* Any */ | 16384 /* Void */)) && !(getObjectFlags(t) & 16 /* Anonymous */), + low: (t) => !!(getObjectFlags(t) & 16 /* Anonymous */) } - res += char; + ]; + let good = removeLowPriorityInferences(inferences, priorities); + const anons = good.filter((i) => getObjectFlags(i) & 16 /* Anonymous */); + if (anons.length) { + good = good.filter((i) => !(getObjectFlags(i) & 16 /* Anonymous */)); + good.push(combineAnonymousTypes(anons)); } - lastCharWasValid = isValid; + return checker.getWidenedType(checker.getUnionType(good.map(checker.getBaseTypeOfLiteralType), 2 /* Subtype */)); } - return !isStringANonContextualKeyword(res) ? res || "_" : `_${res}`; - } - var importFixName, importFixId, errorCodes18; - var init_importFixes = __esm({ - "src/services/codefixes/importFixes.ts"() { - "use strict"; - init_ts4(); - init_ts_codefix(); - importFixName = "import"; - importFixId = "fixMissingImport"; - errorCodes18 = [ - Diagnostics.Cannot_find_name_0.code, - Diagnostics.Cannot_find_name_0_Did_you_mean_1.code, - Diagnostics.Cannot_find_name_0_Did_you_mean_the_instance_member_this_0.code, - Diagnostics.Cannot_find_name_0_Did_you_mean_the_static_member_1_0.code, - Diagnostics.Cannot_find_namespace_0.code, - Diagnostics._0_refers_to_a_UMD_global_but_the_current_file_is_a_module_Consider_adding_an_import_instead.code, - Diagnostics._0_only_refers_to_a_type_but_is_being_used_as_a_value_here.code, - Diagnostics.No_value_exists_in_scope_for_the_shorthand_property_0_Either_declare_one_or_provide_an_initializer.code, - Diagnostics._0_cannot_be_used_as_a_value_because_it_was_imported_using_import_type.code - ]; - registerCodeFix({ - errorCodes: errorCodes18, - getCodeActions(context) { - const { errorCode, preferences, sourceFile, span, program } = context; - const info = getFixInfos( - context, - errorCode, - span.start, - /*useAutoImportProvider*/ - true - ); - if (!info) - return void 0; - return info.map(({ fix, symbolName: symbolName2, errorIdentifierText }) => codeActionForFix( - context, - sourceFile, - symbolName2, - fix, - /*includeSymbolNameInDescription*/ - symbolName2 !== errorIdentifierText, - program.getCompilerOptions(), - preferences - )); - }, - fixIds: [importFixId], - getAllCodeActions: (context) => { - const { sourceFile, program, preferences, host, cancellationToken } = context; - const importAdder = createImportAdderWorker( - sourceFile, - program, - /*useAutoImportProvider*/ - true, - preferences, - host, - cancellationToken - ); - eachDiagnostic(context, errorCodes18, (diag2) => importAdder.addImportFromDiagnostic(diag2, context)); - return createCombinedCodeActions(ts_textChanges_exports.ChangeTracker.with(context, importAdder.writeFixes)); + function combineAnonymousTypes(anons) { + if (anons.length === 1) { + return anons[0]; + } + const calls = []; + const constructs = []; + const stringIndices = []; + const numberIndices = []; + let stringIndexReadonly = false; + let numberIndexReadonly = false; + const props = createMultiMap(); + for (const anon2 of anons) { + for (const p of checker.getPropertiesOfType(anon2)) { + props.add(p.escapedName, p.valueDeclaration ? checker.getTypeOfSymbolAtLocation(p, p.valueDeclaration) : checker.getAnyType()); + } + calls.push(...checker.getSignaturesOfType(anon2, 0 /* Call */)); + constructs.push(...checker.getSignaturesOfType(anon2, 1 /* Construct */)); + const stringIndexInfo = checker.getIndexInfoOfType(anon2, 0 /* String */); + if (stringIndexInfo) { + stringIndices.push(stringIndexInfo.type); + stringIndexReadonly = stringIndexReadonly || stringIndexInfo.isReadonly; } + const numberIndexInfo = checker.getIndexInfoOfType(anon2, 1 /* Number */); + if (numberIndexInfo) { + numberIndices.push(numberIndexInfo.type); + numberIndexReadonly = numberIndexReadonly || numberIndexInfo.isReadonly; + } + } + const members = mapEntries(props, (name, types) => { + const isOptional = types.length < anons.length ? 16777216 /* Optional */ : 0; + const s = checker.createSymbol(4 /* Property */ | isOptional, name); + s.links.type = checker.getUnionType(types); + return [name, s]; }); - } - }); - - // src/services/codefixes/fixAddMissingConstraint.ts - function getInfo6(program, sourceFile, span) { - const diag2 = find(program.getSemanticDiagnostics(sourceFile), (diag3) => diag3.start === span.start && diag3.length === span.length); - if (diag2 === void 0 || diag2.relatedInformation === void 0) - return; - const related = find(diag2.relatedInformation, (related2) => related2.code === Diagnostics.This_type_parameter_might_need_an_extends_0_constraint.code); - if (related === void 0 || related.file === void 0 || related.start === void 0 || related.length === void 0) - return; - let declaration = findAncestorMatchingSpan(related.file, createTextSpan(related.start, related.length)); - if (declaration === void 0) - return; - if (isIdentifier(declaration) && isTypeParameterDeclaration(declaration.parent)) { - declaration = declaration.parent; - } - if (isTypeParameterDeclaration(declaration)) { - if (isMappedTypeNode(declaration.parent)) - return; - const token = getTokenAtPosition(sourceFile, span.start); - const checker = program.getTypeChecker(); - const constraint = tryGetConstraintType(checker, token) || tryGetConstraintFromDiagnosticMessage(related.messageText); - return { constraint, declaration, token }; - } - return void 0; - } - function addMissingConstraint(changes, program, preferences, host, sourceFile, info) { - const { declaration, constraint } = info; - const checker = program.getTypeChecker(); - if (isString(constraint)) { - changes.insertText(sourceFile, declaration.name.end, ` extends ${constraint}`); - } else { - const scriptTarget = getEmitScriptTarget(program.getCompilerOptions()); - const tracker = getNoopSymbolTrackerWithResolver({ program, host }); - const importAdder = createImportAdder(sourceFile, program, preferences, host); - const typeNode = typeToAutoImportableTypeNode( - checker, - importAdder, - constraint, - /*contextNode*/ - void 0, - scriptTarget, - /*flags*/ - void 0, - tracker + const indexInfos = []; + if (stringIndices.length) + indexInfos.push(checker.createIndexInfo(checker.getStringType(), checker.getUnionType(stringIndices), stringIndexReadonly)); + if (numberIndices.length) + indexInfos.push(checker.createIndexInfo(checker.getNumberType(), checker.getUnionType(numberIndices), numberIndexReadonly)); + return checker.createAnonymousType( + anons[0].symbol, + members, + calls, + constructs, + indexInfos ); - if (typeNode) { - changes.replaceNode(sourceFile, declaration, factory.updateTypeParameterDeclaration( - declaration, - /*modifiers*/ - void 0, - declaration.name, - typeNode, - declaration.default - )); - importAdder.writeFixes(changes); - } - } - } - function tryGetConstraintFromDiagnosticMessage(messageText) { - const [_, constraint] = flattenDiagnosticMessageText(messageText, "\n", 0).match(/`extends (.*)`/) || []; - return constraint; - } - function tryGetConstraintType(checker, node) { - if (isTypeNode(node.parent)) { - return checker.getTypeArgumentConstraint(node.parent); } - const contextualType = isExpression(node) ? checker.getContextualType(node) : void 0; - return contextualType || checker.getTypeAtLocation(node); - } - var fixId17, errorCodes19; - var init_fixAddMissingConstraint = __esm({ - "src/services/codefixes/fixAddMissingConstraint.ts"() { - "use strict"; - init_ts4(); - init_ts_codefix(); - fixId17 = "addMissingConstraint"; - errorCodes19 = [ - // We want errors this could be attached to: - // Diagnostics.This_type_parameter_probably_needs_an_extends_0_constraint - Diagnostics.Type_0_is_not_comparable_to_type_1.code, - Diagnostics.Type_0_is_not_assignable_to_type_1_Two_different_types_with_this_name_exist_but_they_are_unrelated.code, - Diagnostics.Type_0_is_not_assignable_to_type_1_with_exactOptionalPropertyTypes_Colon_true_Consider_adding_undefined_to_the_types_of_the_target_s_properties.code, - Diagnostics.Type_0_is_not_assignable_to_type_1.code, - Diagnostics.Argument_of_type_0_is_not_assignable_to_parameter_of_type_1_with_exactOptionalPropertyTypes_Colon_true_Consider_adding_undefined_to_the_types_of_the_target_s_properties.code, - Diagnostics.Property_0_is_incompatible_with_index_signature.code, - Diagnostics.Property_0_in_type_1_is_not_assignable_to_type_2.code, - Diagnostics.Type_0_does_not_satisfy_the_constraint_1.code - ]; - registerCodeFix({ - errorCodes: errorCodes19, - getCodeActions(context) { - const { sourceFile, span, program, preferences, host } = context; - const info = getInfo6(program, sourceFile, span); - if (info === void 0) - return; - const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => addMissingConstraint(t, program, preferences, host, sourceFile, info)); - return [createCodeFixAction(fixId17, changes, Diagnostics.Add_extends_constraint, fixId17, Diagnostics.Add_extends_constraint_to_all_type_parameters)]; - }, - fixIds: [fixId17], - getAllCodeActions: (context) => { - const { program, preferences, host } = context; - const seen = /* @__PURE__ */ new Map(); - return createCombinedCodeActions(ts_textChanges_exports.ChangeTracker.with(context, (changes) => { - eachDiagnostic(context, errorCodes19, (diag2) => { - const info = getInfo6(program, diag2.file, createTextSpan(diag2.start, diag2.length)); - if (info) { - if (addToSeen(seen, getNodeId(info.declaration))) { - return addMissingConstraint(changes, program, preferences, host, diag2.file, info); - } - } - return void 0; - }); - })); + function inferTypes(usage) { + var _a, _b, _c; + const types = []; + if (usage.isNumber) { + types.push(checker.getNumberType()); + } + if (usage.isString) { + types.push(checker.getStringType()); + } + if (usage.isNumberOrString) { + types.push(checker.getUnionType([checker.getStringType(), checker.getNumberType()])); + } + if (usage.numberIndex) { + types.push(checker.createArrayType(combineFromUsage(usage.numberIndex))); + } + if (((_a = usage.properties) == null ? void 0 : _a.size) || ((_b = usage.constructs) == null ? void 0 : _b.length) || usage.stringIndex) { + types.push(inferStructuralType(usage)); + } + const candidateTypes = (usage.candidateTypes || []).map((t) => checker.getBaseTypeOfLiteralType(t)); + const callsType = ((_c = usage.calls) == null ? void 0 : _c.length) ? inferStructuralType(usage) : void 0; + if (callsType && candidateTypes) { + types.push(checker.getUnionType([callsType, ...candidateTypes], 2 /* Subtype */)); + } else { + if (callsType) { + types.push(callsType); } - }); - } - }); - - // src/services/codefixes/fixOverrideModifier.ts - function dispatchChanges(changeTracker, context, errorCode, pos) { - switch (errorCode) { - case Diagnostics.This_member_must_have_an_override_modifier_because_it_overrides_a_member_in_the_base_class_0.code: - case Diagnostics.This_member_must_have_a_JSDoc_comment_with_an_override_tag_because_it_overrides_a_member_in_the_base_class_0.code: - case Diagnostics.This_member_must_have_an_override_modifier_because_it_overrides_an_abstract_method_that_is_declared_in_the_base_class_0.code: - case Diagnostics.This_parameter_property_must_have_an_override_modifier_because_it_overrides_a_member_in_base_class_0.code: - case Diagnostics.This_parameter_property_must_have_a_JSDoc_comment_with_an_override_tag_because_it_overrides_a_member_in_the_base_class_0.code: - return doAddOverrideModifierChange(changeTracker, context.sourceFile, pos); - case Diagnostics.This_member_cannot_have_an_override_modifier_because_it_is_not_declared_in_the_base_class_0.code: - case Diagnostics.This_member_cannot_have_a_JSDoc_comment_with_an_override_tag_because_it_is_not_declared_in_the_base_class_0.code: - case Diagnostics.This_member_cannot_have_an_override_modifier_because_its_containing_class_0_does_not_extend_another_class.code: - case Diagnostics.This_member_cannot_have_a_JSDoc_comment_with_an_override_tag_because_its_containing_class_0_does_not_extend_another_class.code: - return doRemoveOverrideModifierChange(changeTracker, context.sourceFile, pos); - default: - Debug.fail("Unexpected error code: " + errorCode); + if (length(candidateTypes)) { + types.push(...candidateTypes); + } + } + types.push(...inferNamedTypesFromProperties(usage)); + return types; } - } - function doAddOverrideModifierChange(changeTracker, sourceFile, pos) { - const classElement = findContainerClassElementLike(sourceFile, pos); - if (isSourceFileJS(sourceFile)) { - changeTracker.addJSDocTags(sourceFile, classElement, [factory.createJSDocOverrideTag(factory.createIdentifier("override"))]); - return; + function inferStructuralType(usage) { + const members = /* @__PURE__ */ new Map(); + if (usage.properties) { + usage.properties.forEach((u, name) => { + const symbol = checker.createSymbol(4 /* Property */, name); + symbol.links.type = combineFromUsage(u); + members.set(name, symbol); + }); + } + const callSignatures = usage.calls ? [getSignatureFromCalls(usage.calls)] : []; + const constructSignatures = usage.constructs ? [getSignatureFromCalls(usage.constructs)] : []; + const indexInfos = usage.stringIndex ? [checker.createIndexInfo( + checker.getStringType(), + combineFromUsage(usage.stringIndex), + /*isReadonly*/ + false + )] : []; + return checker.createAnonymousType( + /*symbol*/ + void 0, + members, + callSignatures, + constructSignatures, + indexInfos + ); } - const modifiers = classElement.modifiers || emptyArray; - const staticModifier = find(modifiers, isStaticModifier); - const abstractModifier = find(modifiers, isAbstractModifier); - const accessibilityModifier = find(modifiers, (m) => isAccessibilityModifier(m.kind)); - const lastDecorator = findLast(modifiers, isDecorator); - const modifierPos = abstractModifier ? abstractModifier.end : staticModifier ? staticModifier.end : accessibilityModifier ? accessibilityModifier.end : lastDecorator ? skipTrivia(sourceFile.text, lastDecorator.end) : classElement.getStart(sourceFile); - const options = accessibilityModifier || staticModifier || abstractModifier ? { prefix: " " } : { suffix: " " }; - changeTracker.insertModifierAt(sourceFile, modifierPos, 163 /* OverrideKeyword */, options); - } - function doRemoveOverrideModifierChange(changeTracker, sourceFile, pos) { - const classElement = findContainerClassElementLike(sourceFile, pos); - if (isSourceFileJS(sourceFile)) { - changeTracker.filterJSDocTags(sourceFile, classElement, not(isJSDocOverrideTag)); - return; + function inferNamedTypesFromProperties(usage) { + if (!usage.properties || !usage.properties.size) + return []; + const types = builtins.filter((t) => allPropertiesAreAssignableToUsage(t, usage)); + if (0 < types.length && types.length < 3) { + return types.map((t) => inferInstantiationFromUsage(t, usage)); + } + return []; } - const overrideModifier = find(classElement.modifiers, isOverrideModifier); - Debug.assertIsDefined(overrideModifier); - changeTracker.deleteModifier(sourceFile, overrideModifier); - } - function isClassElementLikeHasJSDoc(node) { - switch (node.kind) { - case 175 /* Constructor */: - case 171 /* PropertyDeclaration */: - case 173 /* MethodDeclaration */: - case 176 /* GetAccessor */: - case 177 /* SetAccessor */: - return true; - case 168 /* Parameter */: - return isParameterPropertyDeclaration(node, node.parent); - default: + function allPropertiesAreAssignableToUsage(type, usage) { + if (!usage.properties) return false; - } - } - function findContainerClassElementLike(sourceFile, pos) { - const token = getTokenAtPosition(sourceFile, pos); - const classElement = findAncestor(token, (node) => { - if (isClassLike(node)) - return "quit"; - return isClassElementLikeHasJSDoc(node); - }); - Debug.assert(classElement && isClassElementLikeHasJSDoc(classElement)); - return classElement; - } - var fixName, fixAddOverrideId, fixRemoveOverrideId, errorCodes20, errorCodeFixIdMap; - var init_fixOverrideModifier = __esm({ - "src/services/codefixes/fixOverrideModifier.ts"() { - "use strict"; - init_ts4(); - init_ts_codefix(); - fixName = "fixOverrideModifier"; - fixAddOverrideId = "fixAddOverrideModifier"; - fixRemoveOverrideId = "fixRemoveOverrideModifier"; - errorCodes20 = [ - Diagnostics.This_member_cannot_have_an_override_modifier_because_it_is_not_declared_in_the_base_class_0.code, - Diagnostics.This_member_cannot_have_an_override_modifier_because_its_containing_class_0_does_not_extend_another_class.code, - Diagnostics.This_member_must_have_an_override_modifier_because_it_overrides_an_abstract_method_that_is_declared_in_the_base_class_0.code, - Diagnostics.This_member_must_have_an_override_modifier_because_it_overrides_a_member_in_the_base_class_0.code, - Diagnostics.This_parameter_property_must_have_an_override_modifier_because_it_overrides_a_member_in_base_class_0.code, - Diagnostics.This_member_must_have_a_JSDoc_comment_with_an_override_tag_because_it_overrides_a_member_in_the_base_class_0.code, - Diagnostics.This_member_cannot_have_a_JSDoc_comment_with_an_override_tag_because_its_containing_class_0_does_not_extend_another_class.code, - Diagnostics.This_parameter_property_must_have_a_JSDoc_comment_with_an_override_tag_because_it_overrides_a_member_in_the_base_class_0.code, - Diagnostics.This_member_cannot_have_a_JSDoc_comment_with_an_override_tag_because_it_is_not_declared_in_the_base_class_0.code - ]; - errorCodeFixIdMap = { - // case #1: - [Diagnostics.This_member_must_have_an_override_modifier_because_it_overrides_a_member_in_the_base_class_0.code]: { - descriptions: Diagnostics.Add_override_modifier, - fixId: fixAddOverrideId, - fixAllDescriptions: Diagnostics.Add_all_missing_override_modifiers - }, - [Diagnostics.This_member_must_have_a_JSDoc_comment_with_an_override_tag_because_it_overrides_a_member_in_the_base_class_0.code]: { - descriptions: Diagnostics.Add_override_modifier, - fixId: fixAddOverrideId, - fixAllDescriptions: Diagnostics.Add_all_missing_override_modifiers - }, - // case #2: - [Diagnostics.This_member_cannot_have_an_override_modifier_because_its_containing_class_0_does_not_extend_another_class.code]: { - descriptions: Diagnostics.Remove_override_modifier, - fixId: fixRemoveOverrideId, - fixAllDescriptions: Diagnostics.Remove_all_unnecessary_override_modifiers - }, - [Diagnostics.This_member_cannot_have_a_JSDoc_comment_with_an_override_tag_because_its_containing_class_0_does_not_extend_another_class.code]: { - descriptions: Diagnostics.Remove_override_modifier, - fixId: fixRemoveOverrideId, - fixAllDescriptions: Diagnostics.Remove_override_modifier - }, - // case #3: - [Diagnostics.This_parameter_property_must_have_an_override_modifier_because_it_overrides_a_member_in_base_class_0.code]: { - descriptions: Diagnostics.Add_override_modifier, - fixId: fixAddOverrideId, - fixAllDescriptions: Diagnostics.Add_all_missing_override_modifiers - }, - [Diagnostics.This_parameter_property_must_have_a_JSDoc_comment_with_an_override_tag_because_it_overrides_a_member_in_the_base_class_0.code]: { - descriptions: Diagnostics.Add_override_modifier, - fixId: fixAddOverrideId, - fixAllDescriptions: Diagnostics.Add_all_missing_override_modifiers - }, - // case #4: - [Diagnostics.This_member_must_have_an_override_modifier_because_it_overrides_an_abstract_method_that_is_declared_in_the_base_class_0.code]: { - descriptions: Diagnostics.Add_override_modifier, - fixId: fixAddOverrideId, - fixAllDescriptions: Diagnostics.Remove_all_unnecessary_override_modifiers - }, - // case #5: - [Diagnostics.This_member_cannot_have_an_override_modifier_because_it_is_not_declared_in_the_base_class_0.code]: { - descriptions: Diagnostics.Remove_override_modifier, - fixId: fixRemoveOverrideId, - fixAllDescriptions: Diagnostics.Remove_all_unnecessary_override_modifiers - }, - [Diagnostics.This_member_cannot_have_a_JSDoc_comment_with_an_override_tag_because_it_is_not_declared_in_the_base_class_0.code]: { - descriptions: Diagnostics.Remove_override_modifier, - fixId: fixRemoveOverrideId, - fixAllDescriptions: Diagnostics.Remove_all_unnecessary_override_modifiers + return !forEachEntry(usage.properties, (propUsage, name) => { + const source = checker.getTypeOfPropertyOfType(type, name); + if (!source) { + return true; + } + if (propUsage.calls) { + const sigs = checker.getSignaturesOfType(source, 0 /* Call */); + return !sigs.length || !checker.isTypeAssignableTo(source, getFunctionFromCalls(propUsage.calls)); + } else { + return !checker.isTypeAssignableTo(source, combineFromUsage(propUsage)); } - }; - registerCodeFix({ - errorCodes: errorCodes20, - getCodeActions: function getCodeActionsToFixOverrideModifierIssues(context) { - const { errorCode, span } = context; - const info = errorCodeFixIdMap[errorCode]; - if (!info) - return emptyArray; - const { descriptions, fixId: fixId52, fixAllDescriptions } = info; - const changes = ts_textChanges_exports.ChangeTracker.with(context, (changes2) => dispatchChanges(changes2, context, errorCode, span.start)); - return [ - createCodeFixActionMaybeFixAll(fixName, changes, descriptions, fixId52, fixAllDescriptions) - ]; - }, - fixIds: [fixName, fixAddOverrideId, fixRemoveOverrideId], - getAllCodeActions: (context) => codeFixAll(context, errorCodes20, (changes, diag2) => { - const { code, start } = diag2; - const info = errorCodeFixIdMap[code]; - if (!info || info.fixId !== context.fixId) { - return; - } - dispatchChanges(changes, context, code, start); - }) }); } - }); - - // src/services/codefixes/fixNoPropertyAccessFromIndexSignature.ts - function doChange14(changes, sourceFile, node, preferences) { - const quotePreference = getQuotePreference(sourceFile, preferences); - const argumentsExpression = factory.createStringLiteral(node.name.text, quotePreference === 0 /* Single */); - changes.replaceNode( - sourceFile, - node, - isPropertyAccessChain(node) ? factory.createElementAccessChain(node.expression, node.questionDotToken, argumentsExpression) : factory.createElementAccessExpression(node.expression, argumentsExpression) - ); - } - function getPropertyAccessExpression(sourceFile, pos) { - return cast(getTokenAtPosition(sourceFile, pos).parent, isPropertyAccessExpression); - } - var fixId18, errorCodes21; - var init_fixNoPropertyAccessFromIndexSignature = __esm({ - "src/services/codefixes/fixNoPropertyAccessFromIndexSignature.ts"() { - "use strict"; - init_ts4(); - init_ts_codefix(); - fixId18 = "fixNoPropertyAccessFromIndexSignature"; - errorCodes21 = [ - Diagnostics.Property_0_comes_from_an_index_signature_so_it_must_be_accessed_with_0.code - ]; - registerCodeFix({ - errorCodes: errorCodes21, - fixIds: [fixId18], - getCodeActions(context) { - const { sourceFile, span, preferences } = context; - const property = getPropertyAccessExpression(sourceFile, span.start); - const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange14(t, context.sourceFile, property, preferences)); - return [createCodeFixAction(fixId18, changes, [Diagnostics.Use_element_access_for_0, property.name.text], fixId18, Diagnostics.Use_element_access_for_all_undeclared_properties)]; - }, - getAllCodeActions: (context) => codeFixAll(context, errorCodes21, (changes, diag2) => doChange14(changes, diag2.file, getPropertyAccessExpression(diag2.file, diag2.start), context.preferences)) + function inferInstantiationFromUsage(type, usage) { + if (!(getObjectFlags(type) & 4 /* Reference */) || !usage.properties) { + return type; + } + const generic = type.target; + const singleTypeParameter = singleOrUndefined(generic.typeParameters); + if (!singleTypeParameter) + return type; + const types = []; + usage.properties.forEach((propUsage, name) => { + const genericPropertyType = checker.getTypeOfPropertyOfType(generic, name); + Debug.assert(!!genericPropertyType, "generic should have all the properties of its reference."); + types.push(...inferTypeParameters(genericPropertyType, combineFromUsage(propUsage), singleTypeParameter)); }); + return builtinConstructors[type.symbol.escapedName](combineTypes(types)); } - }); - - // src/services/codefixes/fixImplicitThis.ts - function doChange15(changes, sourceFile, pos, checker) { - const token = getTokenAtPosition(sourceFile, pos); - if (!isThis(token)) - return void 0; - const fn = getThisContainer( - token, - /*includeArrowFunctions*/ - false, - /*includeClassComputedPropertyName*/ - false - ); - if (!isFunctionDeclaration(fn) && !isFunctionExpression(fn)) - return void 0; - if (!isSourceFile(getThisContainer( - fn, - /*includeArrowFunctions*/ - false, - /*includeClassComputedPropertyName*/ - false - ))) { - const fnKeyword = Debug.checkDefined(findChildOfKind(fn, 100 /* FunctionKeyword */, sourceFile)); - const { name } = fn; - const body = Debug.checkDefined(fn.body); - if (isFunctionExpression(fn)) { - if (name && ts_FindAllReferences_exports.Core.isSymbolReferencedInFile(name, checker, sourceFile, body)) { - return void 0; - } - changes.delete(sourceFile, fnKeyword); - if (name) { - changes.delete(sourceFile, name); + function inferTypeParameters(genericType, usageType, typeParameter) { + if (genericType === typeParameter) { + return [usageType]; + } else if (genericType.flags & 3145728 /* UnionOrIntersection */) { + return flatMap(genericType.types, (t) => inferTypeParameters(t, usageType, typeParameter)); + } else if (getObjectFlags(genericType) & 4 /* Reference */ && getObjectFlags(usageType) & 4 /* Reference */) { + const genericArgs = checker.getTypeArguments(genericType); + const usageArgs = checker.getTypeArguments(usageType); + const types = []; + if (genericArgs && usageArgs) { + for (let i = 0; i < genericArgs.length; i++) { + if (usageArgs[i]) { + types.push(...inferTypeParameters(genericArgs[i], usageArgs[i], typeParameter)); + } + } } - changes.insertText(sourceFile, body.pos, " =>"); - return [Diagnostics.Convert_function_expression_0_to_arrow_function, name ? name.text : ANONYMOUS]; - } else { - changes.replaceNode(sourceFile, fnKeyword, factory.createToken(87 /* ConstKeyword */)); - changes.insertText(sourceFile, name.end, " = "); - changes.insertText(sourceFile, body.pos, " =>"); - return [Diagnostics.Convert_function_declaration_0_to_arrow_function, name.text]; + return types; + } + const genericSigs = checker.getSignaturesOfType(genericType, 0 /* Call */); + const usageSigs = checker.getSignaturesOfType(usageType, 0 /* Call */); + if (genericSigs.length === 1 && usageSigs.length === 1) { + return inferFromSignatures(genericSigs[0], usageSigs[0], typeParameter); } + return []; } - } - var fixId19, errorCodes22; - var init_fixImplicitThis = __esm({ - "src/services/codefixes/fixImplicitThis.ts"() { - "use strict"; - init_ts4(); - init_ts_codefix(); - fixId19 = "fixImplicitThis"; - errorCodes22 = [Diagnostics.this_implicitly_has_type_any_because_it_does_not_have_a_type_annotation.code]; - registerCodeFix({ - errorCodes: errorCodes22, - getCodeActions: function getCodeActionsToFixImplicitThis(context) { - const { sourceFile, program, span } = context; - let diagnostic; - const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => { - diagnostic = doChange15(t, sourceFile, span.start, program.getTypeChecker()); - }); - return diagnostic ? [createCodeFixAction(fixId19, changes, diagnostic, fixId19, Diagnostics.Fix_all_implicit_this_errors)] : emptyArray; - }, - fixIds: [fixId19], - getAllCodeActions: (context) => codeFixAll(context, errorCodes22, (changes, diag2) => { - doChange15(changes, diag2.file, diag2.start, context.program.getTypeChecker()); - }) - }); + function inferFromSignatures(genericSig, usageSig, typeParameter) { + var _a; + const types = []; + for (let i = 0; i < genericSig.parameters.length; i++) { + const genericParam = genericSig.parameters[i]; + const usageParam = usageSig.parameters[i]; + const isRest = genericSig.declaration && isRestParameter(genericSig.declaration.parameters[i]); + if (!usageParam) { + break; + } + let genericParamType = genericParam.valueDeclaration ? checker.getTypeOfSymbolAtLocation(genericParam, genericParam.valueDeclaration) : checker.getAnyType(); + const elementType = isRest && checker.getElementTypeOfArrayType(genericParamType); + if (elementType) { + genericParamType = elementType; + } + const targetType = ((_a = tryCast(usageParam, isTransientSymbol)) == null ? void 0 : _a.links.type) || (usageParam.valueDeclaration ? checker.getTypeOfSymbolAtLocation(usageParam, usageParam.valueDeclaration) : checker.getAnyType()); + types.push(...inferTypeParameters(genericParamType, targetType, typeParameter)); + } + const genericReturn = checker.getReturnTypeOfSignature(genericSig); + const usageReturn = checker.getReturnTypeOfSignature(usageSig); + types.push(...inferTypeParameters(genericReturn, usageReturn, typeParameter)); + return types; } - }); - - // src/services/codefixes/fixImportNonExportedMember.ts - function getInfo7(sourceFile, pos, program) { - var _a; - const token = getTokenAtPosition(sourceFile, pos); - if (isIdentifier(token)) { - const importDeclaration = findAncestor(token, isImportDeclaration); - if (importDeclaration === void 0) - return void 0; - const moduleSpecifier = isStringLiteral(importDeclaration.moduleSpecifier) ? importDeclaration.moduleSpecifier.text : void 0; - if (moduleSpecifier === void 0) - return void 0; - const resolvedModule = getResolvedModule( - sourceFile, - moduleSpecifier, - /*mode*/ - void 0 + function getFunctionFromCalls(calls) { + return checker.createAnonymousType( + /*symbol*/ + void 0, + createSymbolTable(), + [getSignatureFromCalls(calls)], + emptyArray, + emptyArray ); - if (resolvedModule === void 0) - return void 0; - const moduleSourceFile = program.getSourceFile(resolvedModule.resolvedFileName); - if (moduleSourceFile === void 0 || isSourceFileFromLibrary(program, moduleSourceFile)) - return void 0; - const moduleSymbol = moduleSourceFile.symbol; - const locals = (_a = tryCast(moduleSymbol.valueDeclaration, canHaveLocals)) == null ? void 0 : _a.locals; - if (locals === void 0) - return void 0; - const localSymbol = locals.get(token.escapedText); - if (localSymbol === void 0) - return void 0; - const node = getNodeOfSymbol(localSymbol); - if (node === void 0) - return void 0; - const exportName = { node: token, isTypeOnly: isTypeDeclaration(node) }; - return { exportName, node, moduleSourceFile, moduleSpecifier }; - } - return void 0; - } - function doChange16(changes, program, { exportName, node, moduleSourceFile }) { - const exportDeclaration = tryGetExportDeclaration(moduleSourceFile, exportName.isTypeOnly); - if (exportDeclaration) { - updateExport(changes, program, moduleSourceFile, exportDeclaration, [exportName]); - } else if (canHaveExportModifier(node)) { - changes.insertExportModifier(moduleSourceFile, node); - } else { - createExport(changes, program, moduleSourceFile, [exportName]); } - } - function doChanges(changes, program, sourceFile, moduleExports, node) { - if (length(moduleExports)) { - if (node) { - updateExport(changes, program, sourceFile, node, moduleExports); - } else { - createExport(changes, program, sourceFile, moduleExports); + function getSignatureFromCalls(calls) { + const parameters2 = []; + const length2 = Math.max(...calls.map((c) => c.argumentTypes.length)); + for (let i = 0; i < length2; i++) { + const symbol = checker.createSymbol(1 /* FunctionScopedVariable */, escapeLeadingUnderscores(`arg${i}`)); + symbol.links.type = combineTypes(calls.map((call) => call.argumentTypes[i] || checker.getUndefinedType())); + if (calls.some((call) => call.argumentTypes[i] === void 0)) { + symbol.flags |= 16777216 /* Optional */; + } + parameters2.push(symbol); } - } - } - function tryGetExportDeclaration(sourceFile, isTypeOnly) { - const predicate = (node) => isExportDeclaration(node) && (isTypeOnly && node.isTypeOnly || !node.isTypeOnly); - return findLast(sourceFile.statements, predicate); - } - function updateExport(changes, program, sourceFile, node, names) { - const namedExports = node.exportClause && isNamedExports(node.exportClause) ? node.exportClause.elements : factory.createNodeArray([]); - const allowTypeModifier = !node.isTypeOnly && !!(getIsolatedModules(program.getCompilerOptions()) || find(namedExports, (e) => e.isTypeOnly)); - changes.replaceNode( - sourceFile, - node, - factory.updateExportDeclaration( - node, - node.modifiers, - node.isTypeOnly, - factory.createNamedExports( - factory.createNodeArray( - [...namedExports, ...createExportSpecifiers(names, allowTypeModifier)], - /*hasTrailingComma*/ - namedExports.hasTrailingComma - ) - ), - node.moduleSpecifier, - node.assertClause - ) - ); - } - function createExport(changes, program, sourceFile, names) { - changes.insertNodeAtEndOfScope( - sourceFile, - sourceFile, - factory.createExportDeclaration( - /*modifiers*/ + const returnType = combineFromUsage(combineUsages(calls.map((call) => call.return_))); + return checker.createSignature( + /*declaration*/ void 0, - /*isTypeOnly*/ - false, - factory.createNamedExports(createExportSpecifiers( - names, - /*allowTypeModifier*/ - getIsolatedModules(program.getCompilerOptions()) - )), - /*moduleSpecifier*/ + /*typeParameters*/ void 0, - /*assertClause*/ - void 0 - ) - ); - } - function createExportSpecifiers(names, allowTypeModifier) { - return factory.createNodeArray(map(names, (n) => factory.createExportSpecifier( - allowTypeModifier && n.isTypeOnly, - /*propertyName*/ - void 0, - n.node - ))); - } - function getNodeOfSymbol(symbol) { - if (symbol.valueDeclaration === void 0) { - return firstOrUndefined(symbol.declarations); + /*thisParameter*/ + void 0, + parameters2, + returnType, + /*typePredicate*/ + void 0, + length2, + 0 /* None */ + ); + } + function addCandidateType(usage, type) { + if (type && !(type.flags & 1 /* Any */) && !(type.flags & 131072 /* Never */)) { + (usage.candidateTypes || (usage.candidateTypes = [])).push(type); + } + } + function addCandidateThisType(usage, type) { + if (type && !(type.flags & 1 /* Any */) && !(type.flags & 131072 /* Never */)) { + (usage.candidateThisTypes || (usage.candidateThisTypes = [])).push(type); + } } - const declaration = symbol.valueDeclaration; - const variableStatement = isVariableDeclaration(declaration) ? tryCast(declaration.parent.parent, isVariableStatement) : void 0; - return variableStatement && length(variableStatement.declarationList.declarations) === 1 ? variableStatement : declaration; } - var fixId20, errorCodes23; - var init_fixImportNonExportedMember = __esm({ - "src/services/codefixes/fixImportNonExportedMember.ts"() { + var fixId38, errorCodes48; + var init_inferFromUsage = __esm({ + "src/services/codefixes/inferFromUsage.ts"() { "use strict"; init_ts4(); init_ts_codefix(); - fixId20 = "fixImportNonExportedMember"; - errorCodes23 = [ - Diagnostics.Module_0_declares_1_locally_but_it_is_not_exported.code + fixId38 = "inferFromUsage"; + errorCodes48 = [ + // Variable declarations + Diagnostics.Variable_0_implicitly_has_type_1_in_some_locations_where_its_type_cannot_be_determined.code, + // Variable uses + Diagnostics.Variable_0_implicitly_has_an_1_type.code, + // Parameter declarations + Diagnostics.Parameter_0_implicitly_has_an_1_type.code, + Diagnostics.Rest_parameter_0_implicitly_has_an_any_type.code, + // Get Accessor declarations + Diagnostics.Property_0_implicitly_has_type_any_because_its_get_accessor_lacks_a_return_type_annotation.code, + Diagnostics._0_which_lacks_return_type_annotation_implicitly_has_an_1_return_type.code, + // Set Accessor declarations + Diagnostics.Property_0_implicitly_has_type_any_because_its_set_accessor_lacks_a_parameter_type_annotation.code, + // Property declarations + Diagnostics.Member_0_implicitly_has_an_1_type.code, + //// Suggestions + // Variable declarations + Diagnostics.Variable_0_implicitly_has_type_1_in_some_locations_but_a_better_type_may_be_inferred_from_usage.code, + // Variable uses + Diagnostics.Variable_0_implicitly_has_an_1_type_but_a_better_type_may_be_inferred_from_usage.code, + // Parameter declarations + Diagnostics.Parameter_0_implicitly_has_an_1_type_but_a_better_type_may_be_inferred_from_usage.code, + Diagnostics.Rest_parameter_0_implicitly_has_an_any_type_but_a_better_type_may_be_inferred_from_usage.code, + // Get Accessor declarations + Diagnostics.Property_0_implicitly_has_type_any_but_a_better_type_for_its_get_accessor_may_be_inferred_from_usage.code, + Diagnostics._0_implicitly_has_an_1_return_type_but_a_better_type_may_be_inferred_from_usage.code, + // Set Accessor declarations + Diagnostics.Property_0_implicitly_has_type_any_but_a_better_type_for_its_set_accessor_may_be_inferred_from_usage.code, + // Property declarations + Diagnostics.Member_0_implicitly_has_an_1_type_but_a_better_type_may_be_inferred_from_usage.code, + // Function expressions and declarations + Diagnostics.this_implicitly_has_type_any_because_it_does_not_have_a_type_annotation.code ]; registerCodeFix({ - errorCodes: errorCodes23, - fixIds: [fixId20], + errorCodes: errorCodes48, getCodeActions(context) { - const { sourceFile, span, program } = context; - const info = getInfo7(sourceFile, span.start, program); - if (info === void 0) - return void 0; - const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange16(t, program, info)); - return [createCodeFixAction(fixId20, changes, [Diagnostics.Export_0_from_module_1, info.exportName.node.text, info.moduleSpecifier], fixId20, Diagnostics.Export_all_referenced_locals)]; + const { sourceFile, program, span: { start }, errorCode, cancellationToken, host, preferences } = context; + const token = getTokenAtPosition(sourceFile, start); + let declaration; + const changes = ts_textChanges_exports.ChangeTracker.with(context, (changes2) => { + declaration = doChange32( + changes2, + sourceFile, + token, + errorCode, + program, + cancellationToken, + /*markSeen*/ + returnTrue, + host, + preferences + ); + }); + const name = declaration && getNameOfDeclaration(declaration); + return !name || changes.length === 0 ? void 0 : [createCodeFixAction(fixId38, changes, [getDiagnostic(errorCode, token), getTextOfNode(name)], fixId38, Diagnostics.Infer_all_types_from_usage)]; }, + fixIds: [fixId38], getAllCodeActions(context) { - const { program } = context; - return createCombinedCodeActions(ts_textChanges_exports.ChangeTracker.with(context, (changes) => { - const exports = /* @__PURE__ */ new Map(); - eachDiagnostic(context, errorCodes23, (diag2) => { - const info = getInfo7(diag2.file, diag2.start, program); - if (info === void 0) - return void 0; - const { exportName, node, moduleSourceFile } = info; - if (tryGetExportDeclaration(moduleSourceFile, exportName.isTypeOnly) === void 0 && canHaveExportModifier(node)) { - changes.insertExportModifier(moduleSourceFile, node); - } else { - const moduleExports = exports.get(moduleSourceFile) || { typeOnlyExports: [], exports: [] }; - if (exportName.isTypeOnly) { - moduleExports.typeOnlyExports.push(exportName); - } else { - moduleExports.exports.push(exportName); - } - exports.set(moduleSourceFile, moduleExports); - } - }); - exports.forEach((moduleExports, moduleSourceFile) => { - const exportDeclaration = tryGetExportDeclaration( - moduleSourceFile, - /*isTypeOnly*/ - true - ); - if (exportDeclaration && exportDeclaration.isTypeOnly) { - doChanges(changes, program, moduleSourceFile, moduleExports.typeOnlyExports, exportDeclaration); - doChanges(changes, program, moduleSourceFile, moduleExports.exports, tryGetExportDeclaration( - moduleSourceFile, - /*isTypeOnly*/ - false - )); - } else { - doChanges(changes, program, moduleSourceFile, [...moduleExports.exports, ...moduleExports.typeOnlyExports], exportDeclaration); - } - }); - })); + const { sourceFile, program, cancellationToken, host, preferences } = context; + const markSeen = nodeSeenTracker(); + return codeFixAll(context, errorCodes48, (changes, err) => { + doChange32(changes, sourceFile, getTokenAtPosition(err.file, err.start), err.code, program, cancellationToken, markSeen, host, preferences); + }); } }); } }); - // src/services/codefixes/fixIncorrectNamedTupleSyntax.ts - function getNamedTupleMember(sourceFile, pos) { - const token = getTokenAtPosition(sourceFile, pos); - return findAncestor(token, (t) => t.kind === 201 /* NamedTupleMember */); - } - function doChange17(changes, sourceFile, namedTupleMember) { - if (!namedTupleMember) { - return; + // src/services/codefixes/fixReturnTypeInAsyncFunction.ts + function getInfo15(sourceFile, checker, pos) { + if (isInJSFile(sourceFile)) { + return void 0; } - let unwrappedType = namedTupleMember.type; - let sawOptional = false; - let sawRest = false; - while (unwrappedType.kind === 189 /* OptionalType */ || unwrappedType.kind === 190 /* RestType */ || unwrappedType.kind === 195 /* ParenthesizedType */) { - if (unwrappedType.kind === 189 /* OptionalType */) { - sawOptional = true; - } else if (unwrappedType.kind === 190 /* RestType */) { - sawRest = true; - } - unwrappedType = unwrappedType.type; + const token = getTokenAtPosition(sourceFile, pos); + const func = findAncestor(token, isFunctionLikeDeclaration); + const returnTypeNode = func == null ? void 0 : func.type; + if (!returnTypeNode) { + return void 0; } - const updated = factory.updateNamedTupleMember( - namedTupleMember, - namedTupleMember.dotDotDotToken || (sawRest ? factory.createToken(26 /* DotDotDotToken */) : void 0), - namedTupleMember.name, - namedTupleMember.questionToken || (sawOptional ? factory.createToken(58 /* QuestionToken */) : void 0), - unwrappedType + const returnType = checker.getTypeFromTypeNode(returnTypeNode); + const promisedType = checker.getAwaitedType(returnType) || checker.getVoidType(); + const promisedTypeNode = checker.typeToTypeNode( + promisedType, + /*enclosingDeclaration*/ + returnTypeNode, + /*flags*/ + void 0 ); - if (updated === namedTupleMember) { - return; + if (promisedTypeNode) { + return { returnTypeNode, returnType, promisedTypeNode, promisedType }; } - changes.replaceNode(sourceFile, namedTupleMember, updated); } - var fixId21, errorCodes24; - var init_fixIncorrectNamedTupleSyntax = __esm({ - "src/services/codefixes/fixIncorrectNamedTupleSyntax.ts"() { + function doChange33(changes, sourceFile, returnTypeNode, promisedTypeNode) { + changes.replaceNode(sourceFile, returnTypeNode, factory.createTypeReferenceNode("Promise", [promisedTypeNode])); + } + var fixId39, errorCodes49; + var init_fixReturnTypeInAsyncFunction = __esm({ + "src/services/codefixes/fixReturnTypeInAsyncFunction.ts"() { "use strict"; init_ts4(); init_ts_codefix(); - fixId21 = "fixIncorrectNamedTupleSyntax"; - errorCodes24 = [ - Diagnostics.A_labeled_tuple_element_is_declared_as_optional_with_a_question_mark_after_the_name_and_before_the_colon_rather_than_after_the_type.code, - Diagnostics.A_labeled_tuple_element_is_declared_as_rest_with_a_before_the_name_rather_than_before_the_type.code + fixId39 = "fixReturnTypeInAsyncFunction"; + errorCodes49 = [ + Diagnostics.The_return_type_of_an_async_function_or_method_must_be_the_global_Promise_T_type_Did_you_mean_to_write_Promise_0.code ]; registerCodeFix({ - errorCodes: errorCodes24, - getCodeActions: function getCodeActionsToFixIncorrectNamedTupleSyntax(context) { - const { sourceFile, span } = context; - const namedTupleMember = getNamedTupleMember(sourceFile, span.start); - const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange17(t, sourceFile, namedTupleMember)); - return [createCodeFixAction(fixId21, changes, Diagnostics.Move_labeled_tuple_element_modifiers_to_labels, fixId21, Diagnostics.Move_labeled_tuple_element_modifiers_to_labels)]; + errorCodes: errorCodes49, + fixIds: [fixId39], + getCodeActions: function getCodeActionsToFixReturnTypeInAsyncFunction(context) { + const { sourceFile, program, span } = context; + const checker = program.getTypeChecker(); + const info = getInfo15(sourceFile, program.getTypeChecker(), span.start); + if (!info) { + return void 0; + } + const { returnTypeNode, returnType, promisedTypeNode, promisedType } = info; + const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange33(t, sourceFile, returnTypeNode, promisedTypeNode)); + return [createCodeFixAction( + fixId39, + changes, + [Diagnostics.Replace_0_with_Promise_1, checker.typeToString(returnType), checker.typeToString(promisedType)], + fixId39, + Diagnostics.Fix_all_incorrect_return_type_of_an_async_functions + )]; }, - fixIds: [fixId21] + getAllCodeActions: (context) => codeFixAll(context, errorCodes49, (changes, diag2) => { + const info = getInfo15(diag2.file, context.program.getTypeChecker(), diag2.start); + if (info) { + doChange33(changes, diag2.file, info.returnTypeNode, info.promisedTypeNode); + } + }) }); } }); - // src/services/codefixes/fixSpelling.ts - function getInfo8(sourceFile, pos, context, errorCode) { - const node = getTokenAtPosition(sourceFile, pos); - const parent2 = node.parent; - if ((errorCode === Diagnostics.No_overload_matches_this_call.code || errorCode === Diagnostics.Type_0_is_not_assignable_to_type_1.code) && !isJsxAttribute(parent2)) - return void 0; - const checker = context.program.getTypeChecker(); - let suggestedSymbol; - if (isPropertyAccessExpression(parent2) && parent2.name === node) { - Debug.assert(isMemberName(node), "Expected an identifier for spelling (property access)"); - let containingType = checker.getTypeAtLocation(parent2.expression); - if (parent2.flags & 32 /* OptionalChain */) { - containingType = checker.getNonNullableType(containingType); - } - suggestedSymbol = checker.getSuggestedSymbolForNonexistentProperty(node, containingType); - } else if (isBinaryExpression(parent2) && parent2.operatorToken.kind === 103 /* InKeyword */ && parent2.left === node && isPrivateIdentifier(node)) { - const receiverType = checker.getTypeAtLocation(parent2.right); - suggestedSymbol = checker.getSuggestedSymbolForNonexistentProperty(node, receiverType); - } else if (isQualifiedName(parent2) && parent2.right === node) { - const symbol = checker.getSymbolAtLocation(parent2.left); - if (symbol && symbol.flags & 1536 /* Module */) { - suggestedSymbol = checker.getSuggestedSymbolForNonexistentModule(parent2.right, symbol); - } - } else if (isImportSpecifier(parent2) && parent2.name === node) { - Debug.assertNode(node, isIdentifier, "Expected an identifier for spelling (import)"); - const importDeclaration = findAncestor(node, isImportDeclaration); - const resolvedSourceFile = getResolvedSourceFileFromImportDeclaration(sourceFile, context, importDeclaration); - if (resolvedSourceFile && resolvedSourceFile.symbol) { - suggestedSymbol = checker.getSuggestedSymbolForNonexistentModule(node, resolvedSourceFile.symbol); - } - } else if (isJsxAttribute(parent2) && parent2.name === node) { - Debug.assertNode(node, isIdentifier, "Expected an identifier for JSX attribute"); - const tag = findAncestor(node, isJsxOpeningLikeElement); - const props = checker.getContextualTypeForArgumentAtIndex(tag, 0); - suggestedSymbol = checker.getSuggestedSymbolForNonexistentJSXAttribute(node, props); - } else if (hasSyntacticModifier(parent2, 16384 /* Override */) && isClassElement(parent2) && parent2.name === node) { - const baseDeclaration = findAncestor(node, isClassLike); - const baseTypeNode = baseDeclaration ? getEffectiveBaseTypeNode(baseDeclaration) : void 0; - const baseType = baseTypeNode ? checker.getTypeAtLocation(baseTypeNode) : void 0; - if (baseType) { - suggestedSymbol = checker.getSuggestedSymbolForNonexistentClassMember(getTextOfNode(node), baseType); - } - } else { - const meaning = getMeaningFromLocation(node); - const name = getTextOfNode(node); - Debug.assert(name !== void 0, "name should be defined"); - suggestedSymbol = checker.getSuggestedSymbolForNonexistentSymbol(node, name, convertSemanticMeaningToSymbolFlags(meaning)); - } - return suggestedSymbol === void 0 ? void 0 : { node, suggestedSymbol }; - } - function doChange18(changes, sourceFile, node, suggestedSymbol, target) { - const suggestion = symbolName(suggestedSymbol); - if (!isIdentifierText(suggestion, target) && isPropertyAccessExpression(node.parent)) { - const valDecl = suggestedSymbol.valueDeclaration; - if (valDecl && isNamedDeclaration(valDecl) && isPrivateIdentifier(valDecl.name)) { - changes.replaceNode(sourceFile, node, factory.createIdentifier(suggestion)); - } else { - changes.replaceNode(sourceFile, node.parent, factory.createElementAccessExpression(node.parent.expression, factory.createStringLiteral(suggestion))); - } - } else { - changes.replaceNode(sourceFile, node, factory.createIdentifier(suggestion)); - } - } - function convertSemanticMeaningToSymbolFlags(meaning) { - let flags = 0; - if (meaning & 4 /* Namespace */) { - flags |= 1920 /* Namespace */; - } - if (meaning & 2 /* Type */) { - flags |= 788968 /* Type */; - } - if (meaning & 1 /* Value */) { - flags |= 111551 /* Value */; + // src/services/codefixes/disableJsDiagnostics.ts + function makeChange8(changes, sourceFile, position, seenLines) { + const { line: lineNumber } = getLineAndCharacterOfPosition(sourceFile, position); + if (!seenLines || tryAddToSet(seenLines, lineNumber)) { + changes.insertCommentBeforeLine(sourceFile, lineNumber, position, " @ts-ignore"); } - return flags; } - function getResolvedSourceFileFromImportDeclaration(sourceFile, context, importDeclaration) { - if (!importDeclaration || !isStringLiteralLike(importDeclaration.moduleSpecifier)) - return void 0; - const resolvedModule = getResolvedModule(sourceFile, importDeclaration.moduleSpecifier.text, getModeForUsageLocation(sourceFile, importDeclaration.moduleSpecifier)); - if (!resolvedModule) - return void 0; - return context.program.getSourceFile(resolvedModule.resolvedFileName); - } - var fixId22, errorCodes25; - var init_fixSpelling = __esm({ - "src/services/codefixes/fixSpelling.ts"() { + var fixName4, fixId40, errorCodes50; + var init_disableJsDiagnostics = __esm({ + "src/services/codefixes/disableJsDiagnostics.ts"() { "use strict"; init_ts4(); init_ts_codefix(); - fixId22 = "fixSpelling"; - errorCodes25 = [ - Diagnostics.Property_0_does_not_exist_on_type_1_Did_you_mean_2.code, - Diagnostics.Property_0_may_not_exist_on_type_1_Did_you_mean_2.code, - Diagnostics.Cannot_find_name_0_Did_you_mean_1.code, - Diagnostics.Could_not_find_name_0_Did_you_mean_1.code, - Diagnostics.Cannot_find_namespace_0_Did_you_mean_1.code, - Diagnostics.Cannot_find_name_0_Did_you_mean_the_instance_member_this_0.code, - Diagnostics.Cannot_find_name_0_Did_you_mean_the_static_member_1_0.code, - Diagnostics._0_has_no_exported_member_named_1_Did_you_mean_2.code, - Diagnostics.This_member_cannot_have_an_override_modifier_because_it_is_not_declared_in_the_base_class_0_Did_you_mean_1.code, - Diagnostics.This_member_cannot_have_a_JSDoc_comment_with_an_override_tag_because_it_is_not_declared_in_the_base_class_0_Did_you_mean_1.code, - // for JSX class components - Diagnostics.No_overload_matches_this_call.code, - // for JSX FC - Diagnostics.Type_0_is_not_assignable_to_type_1.code - ]; + fixName4 = "disableJsDiagnostics"; + fixId40 = "disableJsDiagnostics"; + errorCodes50 = mapDefined(Object.keys(Diagnostics), (key) => { + const diag2 = Diagnostics[key]; + return diag2.category === 1 /* Error */ ? diag2.code : void 0; + }); registerCodeFix({ - errorCodes: errorCodes25, - getCodeActions(context) { - const { sourceFile, errorCode } = context; - const info = getInfo8(sourceFile, context.span.start, context, errorCode); - if (!info) + errorCodes: errorCodes50, + getCodeActions: function getCodeActionsToDisableJsDiagnostics(context) { + const { sourceFile, program, span, host, formatContext } = context; + if (!isInJSFile(sourceFile) || !isCheckJsEnabledForFile(sourceFile, program.getCompilerOptions())) { return void 0; - const { node, suggestedSymbol } = info; - const target = getEmitScriptTarget(context.host.getCompilationSettings()); - const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange18(t, sourceFile, node, suggestedSymbol, target)); - return [createCodeFixAction("spelling", changes, [Diagnostics.Change_spelling_to_0, symbolName(suggestedSymbol)], fixId22, Diagnostics.Fix_all_detected_spelling_errors)]; + } + const newLineCharacter = sourceFile.checkJsDirective ? "" : getNewLineOrDefaultFromHost(host, formatContext.options); + const fixes = [ + // fixId unnecessary because adding `// @ts-nocheck` even once will ignore every error in the file. + createCodeFixActionWithoutFixAll( + fixName4, + [createFileTextChanges(sourceFile.fileName, [ + createTextChange( + sourceFile.checkJsDirective ? createTextSpanFromBounds(sourceFile.checkJsDirective.pos, sourceFile.checkJsDirective.end) : createTextSpan(0, 0), + `// @ts-nocheck${newLineCharacter}` + ) + ])], + Diagnostics.Disable_checking_for_this_file + ) + ]; + if (ts_textChanges_exports.isValidLocationToAddComment(sourceFile, span.start)) { + fixes.unshift(createCodeFixAction(fixName4, ts_textChanges_exports.ChangeTracker.with(context, (t) => makeChange8(t, sourceFile, span.start)), Diagnostics.Ignore_this_error_message, fixId40, Diagnostics.Add_ts_ignore_to_all_error_messages)); + } + return fixes; }, - fixIds: [fixId22], - getAllCodeActions: (context) => codeFixAll(context, errorCodes25, (changes, diag2) => { - const info = getInfo8(diag2.file, diag2.start, context, diag2.code); - const target = getEmitScriptTarget(context.host.getCompilationSettings()); - if (info) - doChange18(changes, context.sourceFile, info.node, info.suggestedSymbol, target); - }) + fixIds: [fixId40], + getAllCodeActions: (context) => { + const seenLines = /* @__PURE__ */ new Set(); + return codeFixAll(context, errorCodes50, (changes, diag2) => { + if (ts_textChanges_exports.isValidLocationToAddComment(diag2.file, diag2.start)) { + makeChange8(changes, diag2.file, diag2.start, seenLines); + } + }); + } }); } }); - // src/services/codefixes/returnValueCorrect.ts - function createObjectTypeFromLabeledExpression(checker, label, expression) { - const member = checker.createSymbol(4 /* Property */, label.escapedText); - member.links.type = checker.getTypeAtLocation(expression); - const members = createSymbolTable([member]); - return checker.createAnonymousType( - /*symbol*/ - void 0, - members, - [], - [], - [] - ); - } - function getFixInfo(checker, declaration, expectType, isFunctionType) { - if (!declaration.body || !isBlock(declaration.body) || length(declaration.body.statements) !== 1) - return void 0; - const firstStatement = first(declaration.body.statements); - if (isExpressionStatement(firstStatement) && checkFixedAssignableTo(checker, declaration, checker.getTypeAtLocation(firstStatement.expression), expectType, isFunctionType)) { - return { - declaration, - kind: 0 /* MissingReturnStatement */, - expression: firstStatement.expression, - statement: firstStatement, - commentSource: firstStatement.expression - }; - } else if (isLabeledStatement(firstStatement) && isExpressionStatement(firstStatement.statement)) { - const node = factory.createObjectLiteralExpression([factory.createPropertyAssignment(firstStatement.label, firstStatement.statement.expression)]); - const nodeType = createObjectTypeFromLabeledExpression(checker, firstStatement.label, firstStatement.statement.expression); - if (checkFixedAssignableTo(checker, declaration, nodeType, expectType, isFunctionType)) { - return isArrowFunction(declaration) ? { - declaration, - kind: 1 /* MissingParentheses */, - expression: node, - statement: firstStatement, - commentSource: firstStatement.statement.expression - } : { - declaration, - kind: 0 /* MissingReturnStatement */, - expression: node, - statement: firstStatement, - commentSource: firstStatement.statement.expression - }; - } - } else if (isBlock(firstStatement) && length(firstStatement.statements) === 1) { - const firstBlockStatement = first(firstStatement.statements); - if (isLabeledStatement(firstBlockStatement) && isExpressionStatement(firstBlockStatement.statement)) { - const node = factory.createObjectLiteralExpression([factory.createPropertyAssignment(firstBlockStatement.label, firstBlockStatement.statement.expression)]); - const nodeType = createObjectTypeFromLabeledExpression(checker, firstBlockStatement.label, firstBlockStatement.statement.expression); - if (checkFixedAssignableTo(checker, declaration, nodeType, expectType, isFunctionType)) { - return { - declaration, - kind: 0 /* MissingReturnStatement */, - expression: node, - statement: firstStatement, - commentSource: firstBlockStatement - }; - } + // src/services/codefixes/helpers.ts + function createMissingMemberNodes(classDeclaration, possiblyMissingSymbols, sourceFile, context, preferences, importAdder, addClassElement) { + const classMembers = classDeclaration.symbol.members; + for (const symbol of possiblyMissingSymbols) { + if (!classMembers.has(symbol.escapedName)) { + addNewNodeForMemberSymbol( + symbol, + classDeclaration, + sourceFile, + context, + preferences, + importAdder, + addClassElement, + /*body*/ + void 0 + ); } } - return void 0; } - function checkFixedAssignableTo(checker, declaration, exprType, type, isFunctionType) { - if (isFunctionType) { - const sig = checker.getSignatureFromDeclaration(declaration); - if (sig) { - if (hasSyntacticModifier(declaration, 512 /* Async */)) { - exprType = checker.createPromiseType(exprType); + function getNoopSymbolTrackerWithResolver(context) { + return { + trackSymbol: () => false, + moduleResolverHost: getModuleSpecifierResolverHost(context.program, context.host) + }; + } + function addNewNodeForMemberSymbol(symbol, enclosingDeclaration, sourceFile, context, preferences, importAdder, addClassElement, body, preserveOptional = 3 /* All */, isAmbient = false) { + const declarations = symbol.getDeclarations(); + const declaration = firstOrUndefined(declarations); + const checker = context.program.getTypeChecker(); + const scriptTarget = getEmitScriptTarget(context.program.getCompilerOptions()); + const kind = (declaration == null ? void 0 : declaration.kind) ?? 171 /* PropertySignature */; + const declarationName = createDeclarationName(symbol, declaration); + const effectiveModifierFlags = declaration ? getEffectiveModifierFlags(declaration) : 0 /* None */; + let modifierFlags = effectiveModifierFlags & 256 /* Static */; + modifierFlags |= effectiveModifierFlags & 1 /* Public */ ? 1 /* Public */ : effectiveModifierFlags & 4 /* Protected */ ? 4 /* Protected */ : 0 /* None */; + if (declaration && isAutoAccessorPropertyDeclaration(declaration)) { + modifierFlags |= 512 /* Accessor */; + } + const modifiers = createModifiers(); + const type = checker.getWidenedType(checker.getTypeOfSymbolAtLocation(symbol, enclosingDeclaration)); + const optional = !!(symbol.flags & 16777216 /* Optional */); + const ambient = !!(enclosingDeclaration.flags & 33554432 /* Ambient */) || isAmbient; + const quotePreference = getQuotePreference(sourceFile, preferences); + switch (kind) { + case 171 /* PropertySignature */: + case 172 /* PropertyDeclaration */: + const flags = quotePreference === 0 /* Single */ ? 268435456 /* UseSingleQuotesForStringLiteralType */ : void 0; + let typeNode = checker.typeToTypeNode(type, enclosingDeclaration, flags, getNoopSymbolTrackerWithResolver(context)); + if (importAdder) { + const importableReference = tryGetAutoImportableReferenceFromTypeNode(typeNode, scriptTarget); + if (importableReference) { + typeNode = importableReference.typeNode; + importSymbols(importAdder, importableReference.symbols); + } } - const newSig = checker.createSignature( - declaration, - sig.typeParameters, - sig.thisParameter, - sig.parameters, - exprType, - /*typePredicate*/ - void 0, - sig.minArgumentCount, - sig.flags - ); - exprType = checker.createAnonymousType( - /*symbol*/ + addClassElement(factory.createPropertyDeclaration( + modifiers, + declaration ? createName(declarationName) : symbol.getName(), + optional && preserveOptional & 2 /* Property */ ? factory.createToken(58 /* QuestionToken */) : void 0, + typeNode, + /*initializer*/ + void 0 + )); + break; + case 177 /* GetAccessor */: + case 178 /* SetAccessor */: { + Debug.assertIsDefined(declarations); + let typeNode2 = checker.typeToTypeNode( + type, + enclosingDeclaration, + /*flags*/ void 0, - createSymbolTable(), - [newSig], - [], - [] + getNoopSymbolTrackerWithResolver(context) ); - } else { - exprType = checker.getAnyType(); + const allAccessors = getAllAccessorDeclarations(declarations, declaration); + const orderedAccessors = allAccessors.secondAccessor ? [allAccessors.firstAccessor, allAccessors.secondAccessor] : [allAccessors.firstAccessor]; + if (importAdder) { + const importableReference = tryGetAutoImportableReferenceFromTypeNode(typeNode2, scriptTarget); + if (importableReference) { + typeNode2 = importableReference.typeNode; + importSymbols(importAdder, importableReference.symbols); + } + } + for (const accessor of orderedAccessors) { + if (isGetAccessorDeclaration(accessor)) { + addClassElement(factory.createGetAccessorDeclaration( + modifiers, + createName(declarationName), + emptyArray, + createTypeNode(typeNode2), + createBody(body, quotePreference, ambient) + )); + } else { + Debug.assertNode(accessor, isSetAccessorDeclaration, "The counterpart to a getter should be a setter"); + const parameter = getSetAccessorValueParameter(accessor); + const parameterName = parameter && isIdentifier(parameter.name) ? idText(parameter.name) : void 0; + addClassElement(factory.createSetAccessorDeclaration( + modifiers, + createName(declarationName), + createDummyParameters( + 1, + [parameterName], + [createTypeNode(typeNode2)], + 1, + /*inJs*/ + false + ), + createBody(body, quotePreference, ambient) + )); + } + } + break; } + case 173 /* MethodSignature */: + case 174 /* MethodDeclaration */: + Debug.assertIsDefined(declarations); + const signatures = type.isUnion() ? flatMap(type.types, (t) => t.getCallSignatures()) : type.getCallSignatures(); + if (!some(signatures)) { + break; + } + if (declarations.length === 1) { + Debug.assert(signatures.length === 1, "One declaration implies one signature"); + const signature = signatures[0]; + outputMethod(quotePreference, signature, modifiers, createName(declarationName), createBody(body, quotePreference, ambient)); + break; + } + for (const signature of signatures) { + outputMethod(quotePreference, signature, modifiers, createName(declarationName)); + } + if (!ambient) { + if (declarations.length > signatures.length) { + const signature = checker.getSignatureFromDeclaration(declarations[declarations.length - 1]); + outputMethod(quotePreference, signature, modifiers, createName(declarationName), createBody(body, quotePreference)); + } else { + Debug.assert(declarations.length === signatures.length, "Declarations and signatures should match count"); + addClassElement(createMethodImplementingSignatures(checker, context, enclosingDeclaration, signatures, createName(declarationName), optional && !!(preserveOptional & 1 /* Method */), modifiers, quotePreference, body)); + } + } + break; } - return checker.isTypeAssignableTo(exprType, type); - } - function getInfo9(checker, sourceFile, position, errorCode) { - const node = getTokenAtPosition(sourceFile, position); - if (!node.parent) - return void 0; - const declaration = findAncestor(node.parent, isFunctionLikeDeclaration); - switch (errorCode) { - case Diagnostics.A_function_whose_declared_type_is_neither_undefined_void_nor_any_must_return_a_value.code: - if (!declaration || !declaration.body || !declaration.type || !rangeContainsRange(declaration.type, node)) - return void 0; - return getFixInfo( - checker, - declaration, - checker.getTypeFromTypeNode(declaration.type), - /*isFunctionType*/ - false - ); - case Diagnostics.Argument_of_type_0_is_not_assignable_to_parameter_of_type_1.code: - if (!declaration || !isCallExpression(declaration.parent) || !declaration.body) - return void 0; - const pos = declaration.parent.arguments.indexOf(declaration); - const type = checker.getContextualTypeForArgumentAtIndex(declaration.parent, pos); - if (!type) - return void 0; - return getFixInfo( - checker, - declaration, - type, - /*isFunctionType*/ - true - ); - case Diagnostics.Type_0_is_not_assignable_to_type_1.code: - if (!isDeclarationName(node) || !isVariableLike(node.parent) && !isJsxAttribute(node.parent)) - return void 0; - const initializer = getVariableLikeInitializer(node.parent); - if (!initializer || !isFunctionLikeDeclaration(initializer) || !initializer.body) - return void 0; - return getFixInfo( - checker, - initializer, - checker.getTypeAtLocation(node.parent), - /*isFunctionType*/ - true - ); + function outputMethod(quotePreference2, signature, modifiers2, name, body2) { + const method = createSignatureDeclarationFromSignature(174 /* MethodDeclaration */, context, quotePreference2, signature, body2, name, modifiers2, optional && !!(preserveOptional & 1 /* Method */), enclosingDeclaration, importAdder); + if (method) + addClassElement(method); } - return void 0; - } - function getVariableLikeInitializer(declaration) { - switch (declaration.kind) { - case 259 /* VariableDeclaration */: - case 168 /* Parameter */: - case 207 /* BindingElement */: - case 171 /* PropertyDeclaration */: - case 302 /* PropertyAssignment */: - return declaration.initializer; - case 290 /* JsxAttribute */: - return declaration.initializer && (isJsxExpression(declaration.initializer) ? declaration.initializer.expression : void 0); - case 303 /* ShorthandPropertyAssignment */: - case 170 /* PropertySignature */: - case 305 /* EnumMember */: - case 354 /* JSDocPropertyTag */: - case 347 /* JSDocParameterTag */: - return void 0; + function createModifiers() { + let modifiers2; + if (modifierFlags) { + modifiers2 = combine(modifiers2, factory.createModifiersFromModifierFlags(modifierFlags)); + } + if (shouldAddOverrideKeyword()) { + modifiers2 = append(modifiers2, factory.createToken(164 /* OverrideKeyword */)); + } + return modifiers2 && factory.createNodeArray(modifiers2); + } + function shouldAddOverrideKeyword() { + return !!(context.program.getCompilerOptions().noImplicitOverride && declaration && hasAbstractModifier(declaration)); + } + function createName(node) { + if (isIdentifier(node) && node.escapedText === "constructor") { + return factory.createComputedPropertyName(factory.createStringLiteral(idText(node), quotePreference === 0 /* Single */)); + } + return getSynthesizedDeepClone( + node, + /*includeTrivia*/ + false + ); + } + function createBody(block, quotePreference2, ambient2) { + return ambient2 ? void 0 : getSynthesizedDeepClone( + block, + /*includeTrivia*/ + false + ) || createStubbedMethodBody(quotePreference2); + } + function createTypeNode(typeNode) { + return getSynthesizedDeepClone( + typeNode, + /*includeTrivia*/ + false + ); + } + function createDeclarationName(symbol2, declaration2) { + if (getCheckFlags(symbol2) & 262144 /* Mapped */) { + const nameType = symbol2.links.nameType; + if (nameType && isTypeUsableAsPropertyName(nameType)) { + return factory.createIdentifier(unescapeLeadingUnderscores(getPropertyNameFromType(nameType))); + } + } + return getSynthesizedDeepClone( + getNameOfDeclaration(declaration2), + /*includeTrivia*/ + false + ); } } - function addReturnStatement(changes, sourceFile, expression, statement) { - suppressLeadingAndTrailingTrivia(expression); - const probablyNeedSemi = probablyUsesSemicolons(sourceFile); - changes.replaceNode(sourceFile, statement, factory.createReturnStatement(expression), { - leadingTriviaOption: ts_textChanges_exports.LeadingTriviaOption.Exclude, - trailingTriviaOption: ts_textChanges_exports.TrailingTriviaOption.Exclude, - suffix: probablyNeedSemi ? ";" : void 0 - }); - } - function removeBlockBodyBrace(changes, sourceFile, declaration, expression, commentSource, withParen) { - const newBody = withParen || needsParentheses(expression) ? factory.createParenthesizedExpression(expression) : expression; - suppressLeadingAndTrailingTrivia(commentSource); - copyComments(commentSource, newBody); - changes.replaceNode(sourceFile, declaration.body, newBody); - } - function wrapBlockWithParen(changes, sourceFile, declaration, expression) { - changes.replaceNode(sourceFile, declaration.body, factory.createParenthesizedExpression(expression)); - } - function getActionForfixAddReturnStatement(context, expression, statement) { - const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => addReturnStatement(t, context.sourceFile, expression, statement)); - return createCodeFixAction(fixId23, changes, Diagnostics.Add_a_return_statement, fixIdAddReturnStatement, Diagnostics.Add_all_missing_return_statement); - } - function getActionForFixRemoveBracesFromArrowFunctionBody(context, declaration, expression, commentSource) { - const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => removeBlockBodyBrace( - t, - context.sourceFile, - declaration, - expression, - commentSource, - /*withParen*/ - false - )); - return createCodeFixAction(fixId23, changes, Diagnostics.Remove_braces_from_arrow_function_body, fixRemoveBracesFromArrowFunctionBody, Diagnostics.Remove_braces_from_all_arrow_function_bodies_with_relevant_issues); - } - function getActionForfixWrapTheBlockWithParen(context, declaration, expression) { - const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => wrapBlockWithParen(t, context.sourceFile, declaration, expression)); - return createCodeFixAction(fixId23, changes, Diagnostics.Wrap_the_following_body_with_parentheses_which_should_be_an_object_literal, fixIdWrapTheBlockWithParen, Diagnostics.Wrap_all_object_literal_with_parentheses); - } - var fixId23, fixIdAddReturnStatement, fixRemoveBracesFromArrowFunctionBody, fixIdWrapTheBlockWithParen, errorCodes26; - var init_returnValueCorrect = __esm({ - "src/services/codefixes/returnValueCorrect.ts"() { - "use strict"; - init_ts4(); - init_ts_codefix(); - fixId23 = "returnValueCorrect"; - fixIdAddReturnStatement = "fixAddReturnStatement"; - fixRemoveBracesFromArrowFunctionBody = "fixRemoveBracesFromArrowFunctionBody"; - fixIdWrapTheBlockWithParen = "fixWrapTheBlockWithParen"; - errorCodes26 = [ - Diagnostics.A_function_whose_declared_type_is_neither_undefined_void_nor_any_must_return_a_value.code, - Diagnostics.Type_0_is_not_assignable_to_type_1.code, - Diagnostics.Argument_of_type_0_is_not_assignable_to_parameter_of_type_1.code - ]; - registerCodeFix({ - errorCodes: errorCodes26, - fixIds: [fixIdAddReturnStatement, fixRemoveBracesFromArrowFunctionBody, fixIdWrapTheBlockWithParen], - getCodeActions: function getCodeActionsToCorrectReturnValue(context) { - const { program, sourceFile, span: { start }, errorCode } = context; - const info = getInfo9(program.getTypeChecker(), sourceFile, start, errorCode); - if (!info) - return void 0; - if (info.kind === 0 /* MissingReturnStatement */) { - return append( - [getActionForfixAddReturnStatement(context, info.expression, info.statement)], - isArrowFunction(info.declaration) ? getActionForFixRemoveBracesFromArrowFunctionBody(context, info.declaration, info.expression, info.commentSource) : void 0 - ); - } else { - return [getActionForfixWrapTheBlockWithParen(context, info.declaration, info.expression)]; + function createSignatureDeclarationFromSignature(kind, context, quotePreference, signature, body, name, modifiers, optional, enclosingDeclaration, importAdder) { + const program = context.program; + const checker = program.getTypeChecker(); + const scriptTarget = getEmitScriptTarget(program.getCompilerOptions()); + const isJs = isInJSFile(enclosingDeclaration); + const flags = 1 /* NoTruncation */ | 256 /* SuppressAnyReturnType */ | 524288 /* AllowEmptyTuple */ | (quotePreference === 0 /* Single */ ? 268435456 /* UseSingleQuotesForStringLiteralType */ : 0 /* None */); + const signatureDeclaration = checker.signatureToSignatureDeclaration(signature, kind, enclosingDeclaration, flags, getNoopSymbolTrackerWithResolver(context)); + if (!signatureDeclaration) { + return void 0; + } + let typeParameters = isJs ? void 0 : signatureDeclaration.typeParameters; + let parameters = signatureDeclaration.parameters; + let type = isJs ? void 0 : signatureDeclaration.type; + if (importAdder) { + if (typeParameters) { + const newTypeParameters = sameMap(typeParameters, (typeParameterDecl) => { + let constraint = typeParameterDecl.constraint; + let defaultType = typeParameterDecl.default; + if (constraint) { + const importableReference = tryGetAutoImportableReferenceFromTypeNode(constraint, scriptTarget); + if (importableReference) { + constraint = importableReference.typeNode; + importSymbols(importAdder, importableReference.symbols); + } } - }, - getAllCodeActions: (context) => codeFixAll(context, errorCodes26, (changes, diag2) => { - const info = getInfo9(context.program.getTypeChecker(), diag2.file, diag2.start, diag2.code); - if (!info) - return void 0; - switch (context.fixId) { - case fixIdAddReturnStatement: - addReturnStatement(changes, diag2.file, info.expression, info.statement); - break; - case fixRemoveBracesFromArrowFunctionBody: - if (!isArrowFunction(info.declaration)) - return void 0; - removeBlockBodyBrace( - changes, - diag2.file, - info.declaration, - info.expression, - info.commentSource, - /*withParen*/ - false - ); - break; - case fixIdWrapTheBlockWithParen: - if (!isArrowFunction(info.declaration)) - return void 0; - wrapBlockWithParen(changes, diag2.file, info.declaration, info.expression); - break; - default: - Debug.fail(JSON.stringify(context.fixId)); + if (defaultType) { + const importableReference = tryGetAutoImportableReferenceFromTypeNode(defaultType, scriptTarget); + if (importableReference) { + defaultType = importableReference.typeNode; + importSymbols(importAdder, importableReference.symbols); + } } - }) + return factory.updateTypeParameterDeclaration( + typeParameterDecl, + typeParameterDecl.modifiers, + typeParameterDecl.name, + constraint, + defaultType + ); + }); + if (typeParameters !== newTypeParameters) { + typeParameters = setTextRange(factory.createNodeArray(newTypeParameters, typeParameters.hasTrailingComma), typeParameters); + } + } + const newParameters = sameMap(parameters, (parameterDecl) => { + let type2 = isJs ? void 0 : parameterDecl.type; + if (type2) { + const importableReference = tryGetAutoImportableReferenceFromTypeNode(type2, scriptTarget); + if (importableReference) { + type2 = importableReference.typeNode; + importSymbols(importAdder, importableReference.symbols); + } + } + return factory.updateParameterDeclaration( + parameterDecl, + parameterDecl.modifiers, + parameterDecl.dotDotDotToken, + parameterDecl.name, + isJs ? void 0 : parameterDecl.questionToken, + type2, + parameterDecl.initializer + ); }); + if (parameters !== newParameters) { + parameters = setTextRange(factory.createNodeArray(newParameters, parameters.hasTrailingComma), parameters); + } + if (type) { + const importableReference = tryGetAutoImportableReferenceFromTypeNode(type, scriptTarget); + if (importableReference) { + type = importableReference.typeNode; + importSymbols(importAdder, importableReference.symbols); + } + } } - }); - - // src/services/codefixes/fixAddMissingMember.ts - function getInfo10(sourceFile, tokenPos, errorCode, checker, program) { - var _a; - const token = getTokenAtPosition(sourceFile, tokenPos); - const parent2 = token.parent; - if (errorCode === Diagnostics.Argument_of_type_0_is_not_assignable_to_parameter_of_type_1.code) { - if (!(token.kind === 19 /* OpenBraceToken */ && isObjectLiteralExpression(parent2) && isCallExpression(parent2.parent))) - return void 0; - const argIndex = findIndex(parent2.parent.arguments, (arg) => arg === parent2); - if (argIndex < 0) - return void 0; - const signature = checker.getResolvedSignature(parent2.parent); - if (!(signature && signature.declaration && signature.parameters[argIndex])) - return void 0; - const param = signature.parameters[argIndex].valueDeclaration; - if (!(param && isParameter(param) && isIdentifier(param.name))) - return void 0; - const properties = arrayFrom(checker.getUnmatchedProperties( - checker.getTypeAtLocation(parent2), - checker.getParameterType(signature, argIndex), - /*requireOptionalProperties*/ - false, - /*matchDiscriminantProperties*/ - false - )); - if (!length(properties)) - return void 0; - return { kind: 3 /* ObjectLiteral */, token: param.name, properties, parentDeclaration: parent2 }; + const questionToken = optional ? factory.createToken(58 /* QuestionToken */) : void 0; + const asteriskToken = signatureDeclaration.asteriskToken; + if (isFunctionExpression(signatureDeclaration)) { + return factory.updateFunctionExpression(signatureDeclaration, modifiers, signatureDeclaration.asteriskToken, tryCast(name, isIdentifier), typeParameters, parameters, type, body ?? signatureDeclaration.body); } - if (!isMemberName(token)) - return void 0; - if (isIdentifier(token) && hasInitializer(parent2) && parent2.initializer && isObjectLiteralExpression(parent2.initializer)) { - const targetType = checker.getContextualType(token) || checker.getTypeAtLocation(token); - const properties = arrayFrom(checker.getUnmatchedProperties( - checker.getTypeAtLocation(parent2.initializer), - targetType, - /*requireOptionalProperties*/ - false, - /*matchDiscriminantProperties*/ - false - )); - if (!length(properties)) - return void 0; - return { kind: 3 /* ObjectLiteral */, token, properties, parentDeclaration: parent2.initializer }; + if (isArrowFunction(signatureDeclaration)) { + return factory.updateArrowFunction(signatureDeclaration, modifiers, typeParameters, parameters, type, signatureDeclaration.equalsGreaterThanToken, body ?? signatureDeclaration.body); } - if (isIdentifier(token) && isJsxOpeningLikeElement(token.parent)) { - const target = getEmitScriptTarget(program.getCompilerOptions()); - const attributes = getUnmatchedAttributes(checker, target, token.parent); - if (!length(attributes)) - return void 0; - return { kind: 4 /* JsxAttributes */, token, attributes, parentDeclaration: token.parent }; + if (isMethodDeclaration(signatureDeclaration)) { + return factory.updateMethodDeclaration(signatureDeclaration, modifiers, asteriskToken, name ?? factory.createIdentifier(""), questionToken, typeParameters, parameters, type, body); } - if (isIdentifier(token)) { - const type = (_a = checker.getContextualType(token)) == null ? void 0 : _a.getNonNullableType(); - if (type && getObjectFlags(type) & 16 /* Anonymous */) { - const signature = firstOrUndefined(checker.getSignaturesOfType(type, 0 /* Call */)); - if (signature === void 0) - return void 0; - return { kind: 5 /* Signature */, token, signature, sourceFile, parentDeclaration: findScope(token) }; - } - if (isCallExpression(parent2) && parent2.expression === token) { - return { kind: 2 /* Function */, token, call: parent2, sourceFile, modifierFlags: 0 /* None */, parentDeclaration: findScope(token) }; + if (isFunctionDeclaration(signatureDeclaration)) { + return factory.updateFunctionDeclaration(signatureDeclaration, modifiers, signatureDeclaration.asteriskToken, tryCast(name, isIdentifier), typeParameters, parameters, type, body ?? signatureDeclaration.body); + } + return void 0; + } + function createSignatureDeclarationFromCallExpression(kind, context, importAdder, call, name, modifierFlags, contextNode) { + const quotePreference = getQuotePreference(context.sourceFile, context.preferences); + const scriptTarget = getEmitScriptTarget(context.program.getCompilerOptions()); + const tracker = getNoopSymbolTrackerWithResolver(context); + const checker = context.program.getTypeChecker(); + const isJs = isInJSFile(contextNode); + const { typeArguments, arguments: args, parent: parent2 } = call; + const contextualType = isJs ? void 0 : checker.getContextualType(call); + const names = map(args, (arg) => isIdentifier(arg) ? arg.text : isPropertyAccessExpression(arg) && isIdentifier(arg.name) ? arg.name.text : void 0); + const instanceTypes = isJs ? [] : map(args, (arg) => checker.getTypeAtLocation(arg)); + const { argumentTypeNodes, argumentTypeParameters } = getArgumentTypesAndTypeParameters( + checker, + importAdder, + instanceTypes, + contextNode, + scriptTarget, + 1 /* NoTruncation */, + tracker + ); + const modifiers = modifierFlags ? factory.createNodeArray(factory.createModifiersFromModifierFlags(modifierFlags)) : void 0; + const asteriskToken = isYieldExpression(parent2) ? factory.createToken(42 /* AsteriskToken */) : void 0; + const typeParameters = isJs ? void 0 : createTypeParametersForArguments(checker, argumentTypeParameters, typeArguments); + const parameters = createDummyParameters( + args.length, + names, + argumentTypeNodes, + /*minArgumentCount*/ + void 0, + isJs + ); + const type = isJs || contextualType === void 0 ? void 0 : checker.typeToTypeNode( + contextualType, + contextNode, + /*flags*/ + void 0, + tracker + ); + switch (kind) { + case 174 /* MethodDeclaration */: + return factory.createMethodDeclaration( + modifiers, + asteriskToken, + name, + /*questionToken*/ + void 0, + typeParameters, + parameters, + type, + createStubbedMethodBody(quotePreference) + ); + case 173 /* MethodSignature */: + return factory.createMethodSignature( + modifiers, + name, + /*questionToken*/ + void 0, + typeParameters, + parameters, + type === void 0 ? factory.createKeywordTypeNode(159 /* UnknownKeyword */) : type + ); + case 262 /* FunctionDeclaration */: + Debug.assert(typeof name === "string" || isIdentifier(name), "Unexpected name"); + return factory.createFunctionDeclaration( + modifiers, + asteriskToken, + name, + typeParameters, + parameters, + type, + createStubbedBody(Diagnostics.Function_not_implemented.message, quotePreference) + ); + default: + Debug.fail("Unexpected kind"); + } + } + function createTypeParametersForArguments(checker, argumentTypeParameters, typeArguments) { + const usedNames = new Set(argumentTypeParameters.map((pair) => pair[0])); + const constraintsByName = new Map(argumentTypeParameters); + if (typeArguments) { + const typeArgumentsWithNewTypes = typeArguments.filter((typeArgument) => !argumentTypeParameters.some((pair) => { + var _a; + return checker.getTypeAtLocation(typeArgument) === ((_a = pair[1]) == null ? void 0 : _a.argumentType); + })); + const targetSize = usedNames.size + typeArgumentsWithNewTypes.length; + for (let i = 0; usedNames.size < targetSize; i += 1) { + usedNames.add(createTypeParameterName(i)); } } - if (!isPropertyAccessExpression(parent2)) - return void 0; - const leftExpressionType = skipConstraint(checker.getTypeAtLocation(parent2.expression)); - const symbol = leftExpressionType.symbol; - if (!symbol || !symbol.declarations) - return void 0; - if (isIdentifier(token) && isCallExpression(parent2.parent)) { - const moduleDeclaration = find(symbol.declarations, isModuleDeclaration); - const moduleDeclarationSourceFile = moduleDeclaration == null ? void 0 : moduleDeclaration.getSourceFile(); - if (moduleDeclaration && moduleDeclarationSourceFile && !isSourceFileFromLibrary(program, moduleDeclarationSourceFile)) { - return { kind: 2 /* Function */, token, call: parent2.parent, sourceFile, modifierFlags: 1 /* Export */, parentDeclaration: moduleDeclaration }; + return arrayFrom( + usedNames.values(), + (usedName) => { + var _a; + return factory.createTypeParameterDeclaration( + /*modifiers*/ + void 0, + usedName, + (_a = constraintsByName.get(usedName)) == null ? void 0 : _a.constraint + ); } - const moduleSourceFile = find(symbol.declarations, isSourceFile); - if (sourceFile.commonJsModuleIndicator) - return void 0; - if (moduleSourceFile && !isSourceFileFromLibrary(program, moduleSourceFile)) { - return { kind: 2 /* Function */, token, call: parent2.parent, sourceFile: moduleSourceFile, modifierFlags: 1 /* Export */, parentDeclaration: moduleSourceFile }; + ); + } + function createTypeParameterName(index) { + return 84 /* T */ + index <= 90 /* Z */ ? String.fromCharCode(84 /* T */ + index) : `T${index}`; + } + function typeToAutoImportableTypeNode(checker, importAdder, type, contextNode, scriptTarget, flags, tracker) { + let typeNode = checker.typeToTypeNode(type, contextNode, flags, tracker); + if (typeNode && isImportTypeNode(typeNode)) { + const importableReference = tryGetAutoImportableReferenceFromTypeNode(typeNode, scriptTarget); + if (importableReference) { + importSymbols(importAdder, importableReference.symbols); + typeNode = importableReference.typeNode; } } - const classDeclaration = find(symbol.declarations, isClassLike); - if (!classDeclaration && isPrivateIdentifier(token)) - return void 0; - const declaration = classDeclaration || find(symbol.declarations, (d) => isInterfaceDeclaration(d) || isTypeLiteralNode(d)); - if (declaration && !isSourceFileFromLibrary(program, declaration.getSourceFile())) { - const makeStatic = !isTypeLiteralNode(declaration) && (leftExpressionType.target || leftExpressionType) !== checker.getDeclaredTypeOfSymbol(symbol); - if (makeStatic && (isPrivateIdentifier(token) || isInterfaceDeclaration(declaration))) - return void 0; - const declSourceFile = declaration.getSourceFile(); - const modifierFlags = isTypeLiteralNode(declaration) ? 0 /* None */ : (makeStatic ? 32 /* Static */ : 0 /* None */) | (startsWithUnderscore(token.text) ? 8 /* Private */ : 0 /* None */); - const isJSFile = isSourceFileJS(declSourceFile); - const call = tryCast(parent2.parent, isCallExpression); - return { kind: 0 /* TypeLikeDeclaration */, token, call, modifierFlags, parentDeclaration: declaration, declSourceFile, isJSFile }; + return getSynthesizedDeepClone(typeNode); + } + function typeContainsTypeParameter(type) { + if (type.isUnionOrIntersection()) { + return type.types.some(typeContainsTypeParameter); } - const enumDeclaration = find(symbol.declarations, isEnumDeclaration); - if (enumDeclaration && !(leftExpressionType.flags & 1056 /* EnumLike */) && !isPrivateIdentifier(token) && !isSourceFileFromLibrary(program, enumDeclaration.getSourceFile())) { - return { kind: 1 /* Enum */, token, parentDeclaration: enumDeclaration }; + return type.flags & 262144 /* TypeParameter */; + } + function getArgumentTypesAndTypeParameters(checker, importAdder, instanceTypes, contextNode, scriptTarget, flags, tracker) { + const argumentTypeNodes = []; + const argumentTypeParameters = /* @__PURE__ */ new Map(); + for (let i = 0; i < instanceTypes.length; i += 1) { + const instanceType = instanceTypes[i]; + if (instanceType.isUnionOrIntersection() && instanceType.types.some(typeContainsTypeParameter)) { + const synthesizedTypeParameterName = createTypeParameterName(i); + argumentTypeNodes.push(factory.createTypeReferenceNode(synthesizedTypeParameterName)); + argumentTypeParameters.set(synthesizedTypeParameterName, void 0); + continue; + } + const widenedInstanceType = checker.getBaseTypeOfLiteralType(instanceType); + const argumentTypeNode = typeToAutoImportableTypeNode(checker, importAdder, widenedInstanceType, contextNode, scriptTarget, flags, tracker); + if (!argumentTypeNode) { + continue; + } + argumentTypeNodes.push(argumentTypeNode); + const argumentTypeParameter = getFirstTypeParameterName(instanceType); + const instanceTypeConstraint = instanceType.isTypeParameter() && instanceType.constraint && !isAnonymousObjectConstraintType(instanceType.constraint) ? typeToAutoImportableTypeNode(checker, importAdder, instanceType.constraint, contextNode, scriptTarget, flags, tracker) : void 0; + if (argumentTypeParameter) { + argumentTypeParameters.set(argumentTypeParameter, { argumentType: instanceType, constraint: instanceTypeConstraint }); + } } - return void 0; + return { argumentTypeNodes, argumentTypeParameters: arrayFrom(argumentTypeParameters.entries()) }; } - function getActionsForMissingMemberDeclaration(context, info) { - return info.isJSFile ? singleElementArray(createActionForAddMissingMemberInJavascriptFile(context, info)) : createActionsForAddMissingMemberInTypeScriptFile(context, info); + function isAnonymousObjectConstraintType(type) { + return type.flags & 524288 /* Object */ && type.objectFlags === 16 /* Anonymous */; } - function createActionForAddMissingMemberInJavascriptFile(context, { parentDeclaration, declSourceFile, modifierFlags, token }) { - if (isInterfaceDeclaration(parentDeclaration) || isTypeLiteralNode(parentDeclaration)) { - return void 0; - } - const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => addMissingMemberInJs(t, declSourceFile, parentDeclaration, token, !!(modifierFlags & 32 /* Static */))); - if (changes.length === 0) { - return void 0; + function getFirstTypeParameterName(type) { + var _a; + if (type.flags & (1048576 /* Union */ | 2097152 /* Intersection */)) { + for (const subType of type.types) { + const subTypeName = getFirstTypeParameterName(subType); + if (subTypeName) { + return subTypeName; + } + } } - const diagnostic = modifierFlags & 32 /* Static */ ? Diagnostics.Initialize_static_property_0 : isPrivateIdentifier(token) ? Diagnostics.Declare_a_private_field_named_0 : Diagnostics.Initialize_property_0_in_the_constructor; - return createCodeFixAction(fixMissingMember, changes, [diagnostic, token.text], fixMissingMember, Diagnostics.Add_all_missing_members); + return type.flags & 262144 /* TypeParameter */ ? (_a = type.getSymbol()) == null ? void 0 : _a.getName() : void 0; } - function addMissingMemberInJs(changeTracker, sourceFile, classDeclaration, token, makeStatic) { - const tokenName = token.text; - if (makeStatic) { - if (classDeclaration.kind === 230 /* ClassExpression */) { - return; - } - const className = classDeclaration.name.getText(); - const staticInitialization = initializePropertyToUndefined(factory.createIdentifier(className), tokenName); - changeTracker.insertNodeAfter(sourceFile, classDeclaration, staticInitialization); - } else if (isPrivateIdentifier(token)) { - const property = factory.createPropertyDeclaration( + function createDummyParameters(argCount, names, types, minArgumentCount, inJs) { + const parameters = []; + const parameterNameCounts = /* @__PURE__ */ new Map(); + for (let i = 0; i < argCount; i++) { + const parameterName = (names == null ? void 0 : names[i]) || `arg${i}`; + const parameterNameCount = parameterNameCounts.get(parameterName); + parameterNameCounts.set(parameterName, (parameterNameCount || 0) + 1); + const newParameter = factory.createParameterDeclaration( /*modifiers*/ void 0, - tokenName, - /*questionOrExclamationToken*/ + /*dotDotDotToken*/ void 0, + /*name*/ + parameterName + (parameterNameCount || ""), + /*questionToken*/ + minArgumentCount !== void 0 && i >= minArgumentCount ? factory.createToken(58 /* QuestionToken */) : void 0, /*type*/ - void 0, + inJs ? void 0 : (types == null ? void 0 : types[i]) || factory.createKeywordTypeNode(159 /* UnknownKeyword */), /*initializer*/ void 0 ); - const lastProp = getNodeToInsertPropertyAfter(classDeclaration); - if (lastProp) { - changeTracker.insertNodeAfter(sourceFile, lastProp, property); - } else { - changeTracker.insertMemberAtStart(sourceFile, classDeclaration, property); - } - } else { - const classConstructor = getFirstConstructorWithBody(classDeclaration); - if (!classConstructor) { - return; - } - const propertyInitialization = initializePropertyToUndefined(factory.createThis(), tokenName); - changeTracker.insertNodeAtConstructorEnd(sourceFile, classConstructor, propertyInitialization); + parameters.push(newParameter); } + return parameters; } - function initializePropertyToUndefined(obj, propertyName) { - return factory.createExpressionStatement(factory.createAssignment(factory.createPropertyAccessExpression(obj, propertyName), createUndefined())); - } - function createActionsForAddMissingMemberInTypeScriptFile(context, { parentDeclaration, declSourceFile, modifierFlags, token }) { - const memberName = token.text; - const isStatic2 = modifierFlags & 32 /* Static */; - const typeNode = getTypeNode2(context.program.getTypeChecker(), parentDeclaration, token); - const addPropertyDeclarationChanges = (modifierFlags2) => ts_textChanges_exports.ChangeTracker.with(context, (t) => addPropertyDeclaration(t, declSourceFile, parentDeclaration, memberName, typeNode, modifierFlags2)); - const actions2 = [createCodeFixAction(fixMissingMember, addPropertyDeclarationChanges(modifierFlags & 32 /* Static */), [isStatic2 ? Diagnostics.Declare_static_property_0 : Diagnostics.Declare_property_0, memberName], fixMissingMember, Diagnostics.Add_all_missing_members)]; - if (isStatic2 || isPrivateIdentifier(token)) { - return actions2; - } - if (modifierFlags & 8 /* Private */) { - actions2.unshift(createCodeFixActionWithoutFixAll(fixMissingMember, addPropertyDeclarationChanges(8 /* Private */), [Diagnostics.Declare_private_property_0, memberName])); + function createMethodImplementingSignatures(checker, context, enclosingDeclaration, signatures, name, optional, modifiers, quotePreference, body) { + let maxArgsSignature = signatures[0]; + let minArgumentCount = signatures[0].minArgumentCount; + let someSigHasRestParameter = false; + for (const sig of signatures) { + minArgumentCount = Math.min(sig.minArgumentCount, minArgumentCount); + if (signatureHasRestParameter(sig)) { + someSigHasRestParameter = true; + } + if (sig.parameters.length >= maxArgsSignature.parameters.length && (!signatureHasRestParameter(sig) || signatureHasRestParameter(maxArgsSignature))) { + maxArgsSignature = sig; + } } - actions2.push(createAddIndexSignatureAction(context, declSourceFile, parentDeclaration, token.text, typeNode)); - return actions2; - } - function getTypeNode2(checker, node, token) { - let typeNode; - if (token.parent.parent.kind === 225 /* BinaryExpression */) { - const binaryExpression = token.parent.parent; - const otherExpression = token.parent === binaryExpression.left ? binaryExpression.right : binaryExpression.left; - const widenedType = checker.getWidenedType(checker.getBaseTypeOfLiteralType(checker.getTypeAtLocation(otherExpression))); - typeNode = checker.typeToTypeNode(widenedType, node, 1 /* NoTruncation */); - } else { - const contextualType = checker.getContextualType(token.parent); - typeNode = contextualType ? checker.typeToTypeNode( - contextualType, - /*enclosingDeclaration*/ + const maxNonRestArgs = maxArgsSignature.parameters.length - (signatureHasRestParameter(maxArgsSignature) ? 1 : 0); + const maxArgsParameterSymbolNames = maxArgsSignature.parameters.map((symbol) => symbol.name); + const parameters = createDummyParameters( + maxNonRestArgs, + maxArgsParameterSymbolNames, + /*types*/ + void 0, + minArgumentCount, + /*inJs*/ + false + ); + if (someSigHasRestParameter) { + const restParameter = factory.createParameterDeclaration( + /*modifiers*/ void 0, - 1 /* NoTruncation */ - ) : void 0; + factory.createToken(26 /* DotDotDotToken */), + maxArgsParameterSymbolNames[maxNonRestArgs] || "rest", + /*questionToken*/ + maxNonRestArgs >= minArgumentCount ? factory.createToken(58 /* QuestionToken */) : void 0, + factory.createArrayTypeNode(factory.createKeywordTypeNode(159 /* UnknownKeyword */)), + /*initializer*/ + void 0 + ); + parameters.push(restParameter); } - return typeNode || factory.createKeywordTypeNode(133 /* AnyKeyword */); - } - function addPropertyDeclaration(changeTracker, sourceFile, node, tokenName, typeNode, modifierFlags) { - const modifiers = modifierFlags ? factory.createNodeArray(factory.createModifiersFromModifierFlags(modifierFlags)) : void 0; - const property = isClassLike(node) ? factory.createPropertyDeclaration( + return createStubbedMethod( modifiers, - tokenName, - /*questionOrExclamationToken*/ - void 0, - typeNode, - /*initializer*/ - void 0 - ) : factory.createPropertySignature( - /*modifiers*/ - void 0, - tokenName, - /*questionToken*/ + name, + optional, + /*typeParameters*/ void 0, - typeNode + parameters, + getReturnTypeFromSignatures(signatures, checker, context, enclosingDeclaration), + quotePreference, + body ); - const lastProp = getNodeToInsertPropertyAfter(node); - if (lastProp) { - changeTracker.insertNodeAfter(sourceFile, lastProp, property); - } else { - changeTracker.insertMemberAtStart(sourceFile, node, property); - } } - function getNodeToInsertPropertyAfter(node) { - let res; - for (const member of node.members) { - if (!isPropertyDeclaration(member)) - break; - res = member; + function getReturnTypeFromSignatures(signatures, checker, context, enclosingDeclaration) { + if (length(signatures)) { + const type = checker.getUnionType(map(signatures, checker.getReturnTypeOfSignature)); + return checker.typeToTypeNode(type, enclosingDeclaration, 1 /* NoTruncation */, getNoopSymbolTrackerWithResolver(context)); } - return res; } - function createAddIndexSignatureAction(context, sourceFile, node, tokenName, typeNode) { - const stringTypeNode = factory.createKeywordTypeNode(154 /* StringKeyword */); - const indexingParameter = factory.createParameterDeclaration( - /*modifiers*/ - void 0, - /*dotDotDotToken*/ - void 0, - "x", - /*questionToken*/ + function createStubbedMethod(modifiers, name, optional, typeParameters, parameters, returnType, quotePreference, body) { + return factory.createMethodDeclaration( + modifiers, + /*asteriskToken*/ void 0, - stringTypeNode, - /*initializer*/ - void 0 + name, + optional ? factory.createToken(58 /* QuestionToken */) : void 0, + typeParameters, + parameters, + returnType, + body || createStubbedMethodBody(quotePreference) ); - const indexSignature = factory.createIndexSignature( - /*modifiers*/ - void 0, - [indexingParameter], - typeNode + } + function createStubbedMethodBody(quotePreference) { + return createStubbedBody(Diagnostics.Method_not_implemented.message, quotePreference); + } + function createStubbedBody(text, quotePreference) { + return factory.createBlock( + [factory.createThrowStatement( + factory.createNewExpression( + factory.createIdentifier("Error"), + /*typeArguments*/ + void 0, + // TODO Handle auto quote preference. + [factory.createStringLiteral( + text, + /*isSingleQuote*/ + quotePreference === 0 /* Single */ + )] + ) + )], + /*multiLine*/ + true ); - const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => t.insertMemberAtStart(sourceFile, node, indexSignature)); - return createCodeFixActionWithoutFixAll(fixMissingMember, changes, [Diagnostics.Add_index_signature_for_property_0, tokenName]); } - function getActionsForMissingMethodDeclaration(context, info) { - const { parentDeclaration, declSourceFile, modifierFlags, token, call } = info; - if (call === void 0) { + function setJsonCompilerOptionValues(changeTracker, configFile, options) { + const tsconfigObjectLiteral = getTsConfigObjectLiteralExpression(configFile); + if (!tsconfigObjectLiteral) return void 0; + const compilerOptionsProperty = findJsonProperty(tsconfigObjectLiteral, "compilerOptions"); + if (compilerOptionsProperty === void 0) { + changeTracker.insertNodeAtObjectStart( + configFile, + tsconfigObjectLiteral, + createJsonPropertyAssignment( + "compilerOptions", + factory.createObjectLiteralExpression( + options.map(([optionName, optionValue]) => createJsonPropertyAssignment(optionName, optionValue)), + /*multiLine*/ + true + ) + ) + ); + return; } - if (isPrivateIdentifier(token)) { - return void 0; + const compilerOptions = compilerOptionsProperty.initializer; + if (!isObjectLiteralExpression(compilerOptions)) { + return; } - const methodName = token.text; - const addMethodDeclarationChanges = (modifierFlags2) => ts_textChanges_exports.ChangeTracker.with(context, (t) => addMethodDeclaration(context, t, call, token, modifierFlags2, parentDeclaration, declSourceFile)); - const actions2 = [createCodeFixAction(fixMissingMember, addMethodDeclarationChanges(modifierFlags & 32 /* Static */), [modifierFlags & 32 /* Static */ ? Diagnostics.Declare_static_method_0 : Diagnostics.Declare_method_0, methodName], fixMissingMember, Diagnostics.Add_all_missing_members)]; - if (modifierFlags & 8 /* Private */) { - actions2.unshift(createCodeFixActionWithoutFixAll(fixMissingMember, addMethodDeclarationChanges(8 /* Private */), [Diagnostics.Declare_private_method_0, methodName])); + for (const [optionName, optionValue] of options) { + const optionProperty = findJsonProperty(compilerOptions, optionName); + if (optionProperty === void 0) { + changeTracker.insertNodeAtObjectStart(configFile, compilerOptions, createJsonPropertyAssignment(optionName, optionValue)); + } else { + changeTracker.replaceNode(configFile, optionProperty.initializer, optionValue); + } } - return actions2; } - function addMethodDeclaration(context, changes, callExpression, name, modifierFlags, parentDeclaration, sourceFile) { - const importAdder = createImportAdder(sourceFile, context.program, context.preferences, context.host); - const kind = isClassLike(parentDeclaration) ? 173 /* MethodDeclaration */ : 172 /* MethodSignature */; - const signatureDeclaration = createSignatureDeclarationFromCallExpression(kind, context, importAdder, callExpression, name, modifierFlags, parentDeclaration); - const containingMethodDeclaration = tryGetContainingMethodDeclaration(parentDeclaration, callExpression); - if (containingMethodDeclaration) { - changes.insertNodeAfter(sourceFile, containingMethodDeclaration, signatureDeclaration); - } else { - changes.insertMemberAtStart(sourceFile, parentDeclaration, signatureDeclaration); - } - importAdder.writeFixes(changes); + function setJsonCompilerOptionValue(changeTracker, configFile, optionName, optionValue) { + setJsonCompilerOptionValues(changeTracker, configFile, [[optionName, optionValue]]); } - function addEnumMemberDeclaration(changes, checker, { token, parentDeclaration }) { - const hasStringInitializer = some(parentDeclaration.members, (member) => { - const type = checker.getTypeAtLocation(member); - return !!(type && type.flags & 402653316 /* StringLike */); - }); - const enumMember = factory.createEnumMember(token, hasStringInitializer ? factory.createStringLiteral(token.text) : void 0); - changes.replaceNode(parentDeclaration.getSourceFile(), parentDeclaration, factory.updateEnumDeclaration( - parentDeclaration, - parentDeclaration.modifiers, - parentDeclaration.name, - concatenate(parentDeclaration.members, singleElementArray(enumMember)) - ), { - leadingTriviaOption: ts_textChanges_exports.LeadingTriviaOption.IncludeAll, - trailingTriviaOption: ts_textChanges_exports.TrailingTriviaOption.Exclude - }); + function createJsonPropertyAssignment(name, initializer) { + return factory.createPropertyAssignment(factory.createStringLiteral(name), initializer); } - function addFunctionDeclaration(changes, context, info) { - const quotePreference = getQuotePreference(context.sourceFile, context.preferences); - const importAdder = createImportAdder(context.sourceFile, context.program, context.preferences, context.host); - const functionDeclaration = info.kind === 2 /* Function */ ? createSignatureDeclarationFromCallExpression(261 /* FunctionDeclaration */, context, importAdder, info.call, idText(info.token), info.modifierFlags, info.parentDeclaration) : createSignatureDeclarationFromSignature( - 261 /* FunctionDeclaration */, - context, - quotePreference, - info.signature, - createStubbedBody(Diagnostics.Function_not_implemented.message, quotePreference), - info.token, - /*modifiers*/ - void 0, - /*optional*/ - void 0, - /*enclosingDeclaration*/ - void 0, - importAdder - ); - if (functionDeclaration === void 0) { - Debug.fail("fixMissingFunctionDeclaration codefix got unexpected error."); + function findJsonProperty(obj, name) { + return find(obj.properties, (p) => isPropertyAssignment(p) && !!p.name && isStringLiteral(p.name) && p.name.text === name); + } + function tryGetAutoImportableReferenceFromTypeNode(importTypeNode, scriptTarget) { + let symbols; + const typeNode = visitNode(importTypeNode, visit, isTypeNode); + if (symbols && typeNode) { + return { typeNode, symbols }; + } + function visit(node) { + if (isLiteralImportTypeNode(node) && node.qualifier) { + const firstIdentifier = getFirstIdentifier(node.qualifier); + const name = getNameForExportedSymbol(firstIdentifier.symbol, scriptTarget); + const qualifier = name !== firstIdentifier.text ? replaceFirstIdentifierOfEntityName(node.qualifier, factory.createIdentifier(name)) : node.qualifier; + symbols = append(symbols, firstIdentifier.symbol); + const typeArguments = visitNodes2(node.typeArguments, visit, isTypeNode); + return factory.createTypeReferenceNode(qualifier, typeArguments); + } + return visitEachChild(node, visit, nullTransformationContext); } - isReturnStatement(info.parentDeclaration) ? changes.insertNodeBefore( - info.sourceFile, - info.parentDeclaration, - functionDeclaration, - /*blankLineBetween*/ - true - ) : changes.insertNodeAtEndOfScope(info.sourceFile, info.parentDeclaration, functionDeclaration); - importAdder.writeFixes(changes); } - function addJsxAttributes(changes, context, info) { - const importAdder = createImportAdder(context.sourceFile, context.program, context.preferences, context.host); - const quotePreference = getQuotePreference(context.sourceFile, context.preferences); - const checker = context.program.getTypeChecker(); - const jsxAttributesNode = info.parentDeclaration.attributes; - const hasSpreadAttribute = some(jsxAttributesNode.properties, isJsxSpreadAttribute); - const attrs = map(info.attributes, (attr) => { - const value = tryGetValueFromType(context, checker, importAdder, quotePreference, checker.getTypeOfSymbol(attr), info.parentDeclaration); - const name = factory.createIdentifier(attr.name); - const jsxAttribute = factory.createJsxAttribute(name, factory.createJsxExpression( - /*dotDotDotToken*/ - void 0, - value - )); - setParent(name, jsxAttribute); - return jsxAttribute; - }); - const jsxAttributes = factory.createJsxAttributes(hasSpreadAttribute ? [...attrs, ...jsxAttributesNode.properties] : [...jsxAttributesNode.properties, ...attrs]); - const options = { prefix: jsxAttributesNode.pos === jsxAttributesNode.end ? " " : void 0 }; - changes.replaceNode(context.sourceFile, jsxAttributesNode, jsxAttributes, options); - importAdder.writeFixes(changes); + function replaceFirstIdentifierOfEntityName(name, newIdentifier) { + if (name.kind === 80 /* Identifier */) { + return newIdentifier; + } + return factory.createQualifiedName(replaceFirstIdentifierOfEntityName(name.left, newIdentifier), name.right); } - function addObjectLiteralProperties(changes, context, info) { - const importAdder = createImportAdder(context.sourceFile, context.program, context.preferences, context.host); - const quotePreference = getQuotePreference(context.sourceFile, context.preferences); - const target = getEmitScriptTarget(context.program.getCompilerOptions()); - const checker = context.program.getTypeChecker(); - const props = map(info.properties, (prop) => { - const initializer = tryGetValueFromType(context, checker, importAdder, quotePreference, checker.getTypeOfSymbol(prop), info.parentDeclaration); - return factory.createPropertyAssignment(createPropertyNameFromSymbol(prop, target, quotePreference, checker), initializer); - }); - const options = { - leadingTriviaOption: ts_textChanges_exports.LeadingTriviaOption.Exclude, - trailingTriviaOption: ts_textChanges_exports.TrailingTriviaOption.Exclude, - indentation: info.indentation - }; - changes.replaceNode(context.sourceFile, info.parentDeclaration, factory.createObjectLiteralExpression( - [...info.parentDeclaration.properties, ...props], - /*multiLine*/ + function importSymbols(importAdder, symbols) { + symbols.forEach((s) => importAdder.addImportFromExportedSymbol( + s, + /*isValidTypeOnlyUseSite*/ true - ), options); - importAdder.writeFixes(changes); + )); } - function tryGetValueFromType(context, checker, importAdder, quotePreference, type, enclosingDeclaration) { - if (type.flags & 3 /* AnyOrUnknown */) { - return createUndefined(); - } - if (type.flags & (4 /* String */ | 134217728 /* TemplateLiteral */)) { - return factory.createStringLiteral( - "", - /* isSingleQuote */ - quotePreference === 0 /* Single */ - ); - } - if (type.flags & 8 /* Number */) { - return factory.createNumericLiteral(0); - } - if (type.flags & 64 /* BigInt */) { - return factory.createBigIntLiteral("0n"); - } - if (type.flags & 16 /* Boolean */) { - return factory.createFalse(); - } - if (type.flags & 1056 /* EnumLike */) { - const enumMember = type.symbol.exports ? firstOrUndefinedIterator(type.symbol.exports.values()) : type.symbol; - const name = checker.symbolToExpression( - type.symbol.parent ? type.symbol.parent : type.symbol, - 111551 /* Value */, - /*enclosingDeclaration*/ - void 0, - /*flags*/ - void 0 - ); - return enumMember === void 0 || name === void 0 ? factory.createNumericLiteral(0) : factory.createPropertyAccessExpression(name, checker.symbolToString(enumMember)); + function findAncestorMatchingSpan(sourceFile, span) { + const end = textSpanEnd(span); + let token = getTokenAtPosition(sourceFile, span.start); + while (token.end < end) { + token = token.parent; } - if (type.flags & 256 /* NumberLiteral */) { - return factory.createNumericLiteral(type.value); + return token; + } + var PreserveOptionalFlags; + var init_helpers2 = __esm({ + "src/services/codefixes/helpers.ts"() { + "use strict"; + init_ts4(); + PreserveOptionalFlags = /* @__PURE__ */ ((PreserveOptionalFlags2) => { + PreserveOptionalFlags2[PreserveOptionalFlags2["Method"] = 1] = "Method"; + PreserveOptionalFlags2[PreserveOptionalFlags2["Property"] = 2] = "Property"; + PreserveOptionalFlags2[PreserveOptionalFlags2["All"] = 3] = "All"; + return PreserveOptionalFlags2; + })(PreserveOptionalFlags || {}); } - if (type.flags & 2048 /* BigIntLiteral */) { - return factory.createBigIntLiteral(type.value); + }); + + // src/services/codefixes/generateAccessors.ts + function generateAccessorFromProperty(file, program, start, end, context, _actionName) { + const fieldInfo = getAccessorConvertiblePropertyAtPosition(file, program, start, end); + if (!fieldInfo || ts_refactor_exports.isRefactorErrorInfo(fieldInfo)) + return void 0; + const changeTracker = ts_textChanges_exports.ChangeTracker.fromContext(context); + const { isStatic: isStatic2, isReadonly, fieldName, accessorName, originalName, type, container, declaration } = fieldInfo; + suppressLeadingAndTrailingTrivia(fieldName); + suppressLeadingAndTrailingTrivia(accessorName); + suppressLeadingAndTrailingTrivia(declaration); + suppressLeadingAndTrailingTrivia(container); + let accessorModifiers; + let fieldModifiers; + if (isClassLike(container)) { + const modifierFlags = getEffectiveModifierFlags(declaration); + if (isSourceFileJS(file)) { + const modifiers = factory.createModifiersFromModifierFlags(modifierFlags); + accessorModifiers = modifiers; + fieldModifiers = modifiers; + } else { + accessorModifiers = factory.createModifiersFromModifierFlags(prepareModifierFlagsForAccessor(modifierFlags)); + fieldModifiers = factory.createModifiersFromModifierFlags(prepareModifierFlagsForField(modifierFlags)); + } + if (canHaveDecorators(declaration)) { + fieldModifiers = concatenate(getDecorators(declaration), fieldModifiers); + } } - if (type.flags & 128 /* StringLiteral */) { - return factory.createStringLiteral( - type.value, - /* isSingleQuote */ - quotePreference === 0 /* Single */ - ); + updateFieldDeclaration(changeTracker, file, declaration, type, fieldName, fieldModifiers); + const getAccessor = generateGetAccessor(fieldName, accessorName, type, accessorModifiers, isStatic2, container); + suppressLeadingAndTrailingTrivia(getAccessor); + insertAccessor(changeTracker, file, getAccessor, declaration, container); + if (isReadonly) { + const constructor = getFirstConstructorWithBody(container); + if (constructor) { + updateReadonlyPropertyInitializerStatementConstructor(changeTracker, file, constructor, fieldName.text, originalName); + } + } else { + const setAccessor = generateSetAccessor(fieldName, accessorName, type, accessorModifiers, isStatic2, container); + suppressLeadingAndTrailingTrivia(setAccessor); + insertAccessor(changeTracker, file, setAccessor, declaration, container); } - if (type.flags & 512 /* BooleanLiteral */) { - return type === checker.getFalseType() || type === checker.getFalseType( - /*fresh*/ - true - ) ? factory.createFalse() : factory.createTrue(); + return changeTracker.getChanges(); + } + function isConvertibleName(name) { + return isIdentifier(name) || isStringLiteral(name); + } + function isAcceptedDeclaration(node) { + return isParameterPropertyDeclaration(node, node.parent) || isPropertyDeclaration(node) || isPropertyAssignment(node); + } + function createPropertyName(name, originalName) { + return isIdentifier(originalName) ? factory.createIdentifier(name) : factory.createStringLiteral(name); + } + function createAccessorAccessExpression(fieldName, isStatic2, container) { + const leftHead = isStatic2 ? container.name : factory.createThis(); + return isIdentifier(fieldName) ? factory.createPropertyAccessExpression(leftHead, fieldName) : factory.createElementAccessExpression(leftHead, factory.createStringLiteralFromNode(fieldName)); + } + function prepareModifierFlagsForAccessor(modifierFlags) { + modifierFlags &= ~8 /* Readonly */; + modifierFlags &= ~2 /* Private */; + if (!(modifierFlags & 4 /* Protected */)) { + modifierFlags |= 1 /* Public */; } - if (type.flags & 65536 /* Null */) { - return factory.createNull(); + return modifierFlags; + } + function prepareModifierFlagsForField(modifierFlags) { + modifierFlags &= ~1 /* Public */; + modifierFlags &= ~4 /* Protected */; + modifierFlags |= 2 /* Private */; + return modifierFlags; + } + function getAccessorConvertiblePropertyAtPosition(file, program, start, end, considerEmptySpans = true) { + const node = getTokenAtPosition(file, start); + const cursorRequest = start === end && considerEmptySpans; + const declaration = findAncestor(node.parent, isAcceptedDeclaration); + const meaning = 7 /* AccessibilityModifier */ | 256 /* Static */ | 8 /* Readonly */; + if (!declaration || !(nodeOverlapsWithStartEnd(declaration.name, file, start, end) || cursorRequest)) { + return { + error: getLocaleSpecificMessage(Diagnostics.Could_not_find_property_for_which_to_generate_accessor) + }; } - if (type.flags & 1048576 /* Union */) { - const expression = firstDefined(type.types, (t) => tryGetValueFromType(context, checker, importAdder, quotePreference, t, enclosingDeclaration)); - return expression ?? createUndefined(); + if (!isConvertibleName(declaration.name)) { + return { + error: getLocaleSpecificMessage(Diagnostics.Name_is_not_valid) + }; } - if (checker.isArrayLikeType(type)) { - return factory.createArrayLiteralExpression(); + if ((getEffectiveModifierFlags(declaration) & 98303 /* Modifier */ | meaning) !== meaning) { + return { + error: getLocaleSpecificMessage(Diagnostics.Can_only_convert_property_with_modifier) + }; } - if (isObjectLiteralType(type)) { - const props = map(checker.getPropertiesOfType(type), (prop) => { - const initializer = tryGetValueFromType(context, checker, importAdder, quotePreference, checker.getTypeOfSymbol(prop), enclosingDeclaration); - return factory.createPropertyAssignment(prop.name, initializer); - }); - return factory.createObjectLiteralExpression( - props, + const name = declaration.name.text; + const startWithUnderscore = startsWithUnderscore(name); + const fieldName = createPropertyName(startWithUnderscore ? name : getUniqueName(`_${name}`, file), declaration.name); + const accessorName = createPropertyName(startWithUnderscore ? getUniqueName(name.substring(1), file) : name, declaration.name); + return { + isStatic: hasStaticModifier(declaration), + isReadonly: hasEffectiveReadonlyModifier(declaration), + type: getDeclarationType(declaration, program), + container: declaration.kind === 169 /* Parameter */ ? declaration.parent.parent : declaration.parent, + originalName: declaration.name.text, + declaration, + fieldName, + accessorName, + renameAccessor: startWithUnderscore + }; + } + function generateGetAccessor(fieldName, accessorName, type, modifiers, isStatic2, container) { + return factory.createGetAccessorDeclaration( + modifiers, + accessorName, + [], + type, + factory.createBlock( + [ + factory.createReturnStatement( + createAccessorAccessExpression(fieldName, isStatic2, container) + ) + ], /*multiLine*/ true - ); - } - if (getObjectFlags(type) & 16 /* Anonymous */) { - const decl = find(type.symbol.declarations || emptyArray, or(isFunctionTypeNode, isMethodSignature, isMethodDeclaration)); - if (decl === void 0) - return createUndefined(); - const signature = checker.getSignaturesOfType(type, 0 /* Call */); - if (signature === void 0) - return createUndefined(); - const func = createSignatureDeclarationFromSignature( - 217 /* FunctionExpression */, - context, - quotePreference, - signature[0], - createStubbedBody(Diagnostics.Function_not_implemented.message, quotePreference), - /*name*/ - void 0, + ) + ); + } + function generateSetAccessor(fieldName, accessorName, type, modifiers, isStatic2, container) { + return factory.createSetAccessorDeclaration( + modifiers, + accessorName, + [factory.createParameterDeclaration( /*modifiers*/ void 0, - /*optional*/ + /*dotDotDotToken*/ void 0, - /*enclosingDeclaration*/ - enclosingDeclaration, - importAdder - ); - return func ?? createUndefined(); - } - if (getObjectFlags(type) & 1 /* Class */) { - const classDeclaration = getClassLikeDeclarationOfSymbol(type.symbol); - if (classDeclaration === void 0 || hasAbstractModifier(classDeclaration)) - return createUndefined(); - const constructorDeclaration = getFirstConstructorWithBody(classDeclaration); - if (constructorDeclaration && length(constructorDeclaration.parameters)) - return createUndefined(); - return factory.createNewExpression( - factory.createIdentifier(type.symbol.name), - /*typeArguments*/ + factory.createIdentifier("value"), + /*questionToken*/ void 0, - /*argumentsArray*/ - void 0 - ); + type + )], + factory.createBlock( + [ + factory.createExpressionStatement( + factory.createAssignment( + createAccessorAccessExpression(fieldName, isStatic2, container), + factory.createIdentifier("value") + ) + ) + ], + /*multiLine*/ + true + ) + ); + } + function updatePropertyDeclaration(changeTracker, file, declaration, type, fieldName, modifiers) { + const property = factory.updatePropertyDeclaration( + declaration, + modifiers, + fieldName, + declaration.questionToken || declaration.exclamationToken, + type, + declaration.initializer + ); + changeTracker.replaceNode(file, declaration, property); + } + function updatePropertyAssignmentDeclaration(changeTracker, file, declaration, fieldName) { + let assignment = factory.updatePropertyAssignment(declaration, fieldName, declaration.initializer); + if (assignment.modifiers || assignment.questionToken || assignment.exclamationToken) { + if (assignment === declaration) + assignment = factory.cloneNode(assignment); + assignment.modifiers = void 0; + assignment.questionToken = void 0; + assignment.exclamationToken = void 0; } - return createUndefined(); + changeTracker.replacePropertyAssignment(file, declaration, assignment); } - function createUndefined() { - return factory.createIdentifier("undefined"); + function updateFieldDeclaration(changeTracker, file, declaration, type, fieldName, modifiers) { + if (isPropertyDeclaration(declaration)) { + updatePropertyDeclaration(changeTracker, file, declaration, type, fieldName, modifiers); + } else if (isPropertyAssignment(declaration)) { + updatePropertyAssignmentDeclaration(changeTracker, file, declaration, fieldName); + } else { + changeTracker.replaceNode(file, declaration, factory.updateParameterDeclaration(declaration, modifiers, declaration.dotDotDotToken, cast(fieldName, isIdentifier), declaration.questionToken, declaration.type, declaration.initializer)); + } } - function isObjectLiteralType(type) { - return type.flags & 524288 /* Object */ && (getObjectFlags(type) & 128 /* ObjectLiteral */ || type.symbol && tryCast(singleOrUndefined(type.symbol.declarations), isTypeLiteralNode)); + function insertAccessor(changeTracker, file, accessor, declaration, container) { + isParameterPropertyDeclaration(declaration, declaration.parent) ? changeTracker.insertMemberAtStart(file, container, accessor) : isPropertyAssignment(declaration) ? changeTracker.insertNodeAfterComma(file, declaration, accessor) : changeTracker.insertNodeAfter(file, declaration, accessor); } - function getUnmatchedAttributes(checker, target, source) { - const attrsType = checker.getContextualType(source.attributes); - if (attrsType === void 0) - return emptyArray; - const targetProps = attrsType.getProperties(); - if (!length(targetProps)) - return emptyArray; - const seenNames = /* @__PURE__ */ new Set(); - for (const sourceProp of source.attributes.properties) { - if (isJsxAttribute(sourceProp)) { - seenNames.add(getEscapedTextOfJsxAttributeName(sourceProp.name)); + function updateReadonlyPropertyInitializerStatementConstructor(changeTracker, file, constructor, fieldName, originalName) { + if (!constructor.body) + return; + constructor.body.forEachChild(function recur(node) { + if (isElementAccessExpression(node) && node.expression.kind === 110 /* ThisKeyword */ && isStringLiteral(node.argumentExpression) && node.argumentExpression.text === originalName && isWriteAccess(node)) { + changeTracker.replaceNode(file, node.argumentExpression, factory.createStringLiteral(fieldName)); } - if (isJsxSpreadAttribute(sourceProp)) { - const type = checker.getTypeAtLocation(sourceProp.expression); - for (const prop of type.getProperties()) { - seenNames.add(prop.escapedName); - } + if (isPropertyAccessExpression(node) && node.expression.kind === 110 /* ThisKeyword */ && node.name.text === originalName && isWriteAccess(node)) { + changeTracker.replaceNode(file, node.name, factory.createIdentifier(fieldName)); } - } - return filter(targetProps, (targetProp) => isIdentifierText(targetProp.name, target, 1 /* JSX */) && !(targetProp.flags & 16777216 /* Optional */ || getCheckFlags(targetProp) & 48 /* Partial */ || seenNames.has(targetProp.escapedName))); - } - function tryGetContainingMethodDeclaration(node, callExpression) { - if (isTypeLiteralNode(node)) { - return void 0; - } - const declaration = findAncestor(callExpression, (n) => isMethodDeclaration(n) || isConstructorDeclaration(n)); - return declaration && declaration.parent === node ? declaration : void 0; + if (!isFunctionLike(node) && !isClassLike(node)) { + node.forEachChild(recur); + } + }); } - function createPropertyNameFromSymbol(symbol, target, quotePreference, checker) { - if (isTransientSymbol(symbol)) { - const prop = checker.symbolToNode( - symbol, - 111551 /* Value */, - /*enclosingDeclaration*/ - void 0, - 1073741824 /* WriteComputedProps */ - ); - if (prop && isComputedPropertyName(prop)) - return prop; + function getDeclarationType(declaration, program) { + const typeNode = getTypeAnnotationNode(declaration); + if (isPropertyDeclaration(declaration) && typeNode && declaration.questionToken) { + const typeChecker = program.getTypeChecker(); + const type = typeChecker.getTypeFromTypeNode(typeNode); + if (!typeChecker.isTypeAssignableTo(typeChecker.getUndefinedType(), type)) { + const types = isUnionTypeNode(typeNode) ? typeNode.types : [typeNode]; + return factory.createUnionTypeNode([...types, factory.createKeywordTypeNode(157 /* UndefinedKeyword */)]); + } } - return createPropertyNameNodeForIdentifierOrLiteral(symbol.name, target, quotePreference === 0 /* Single */); + return typeNode; } - function findScope(node) { - if (findAncestor(node, isJsxExpression)) { - const returnStatement = findAncestor(node.parent, isReturnStatement); - if (returnStatement) - return returnStatement; + function getAllSupers(decl, checker) { + const res = []; + while (decl) { + const superElement = getClassExtendsHeritageElement(decl); + const superSymbol = superElement && checker.getSymbolAtLocation(superElement.expression); + if (!superSymbol) + break; + const symbol = superSymbol.flags & 2097152 /* Alias */ ? checker.getAliasedSymbol(superSymbol) : superSymbol; + const superDecl = symbol.declarations && find(symbol.declarations, isClassLike); + if (!superDecl) + break; + res.push(superDecl); + decl = superDecl; } - return getSourceFileOfNode(node); + return res; } - var fixMissingMember, fixMissingProperties, fixMissingAttributes, fixMissingFunctionDeclaration, errorCodes27; - var init_fixAddMissingMember = __esm({ - "src/services/codefixes/fixAddMissingMember.ts"() { + var init_generateAccessors = __esm({ + "src/services/codefixes/generateAccessors.ts"() { "use strict"; init_ts4(); - init_ts_codefix(); - fixMissingMember = "fixMissingMember"; - fixMissingProperties = "fixMissingProperties"; - fixMissingAttributes = "fixMissingAttributes"; - fixMissingFunctionDeclaration = "fixMissingFunctionDeclaration"; - errorCodes27 = [ - Diagnostics.Property_0_does_not_exist_on_type_1.code, - Diagnostics.Property_0_does_not_exist_on_type_1_Did_you_mean_2.code, - Diagnostics.Property_0_is_missing_in_type_1_but_required_in_type_2.code, - Diagnostics.Type_0_is_missing_the_following_properties_from_type_1_Colon_2.code, - Diagnostics.Type_0_is_missing_the_following_properties_from_type_1_Colon_2_and_3_more.code, - Diagnostics.Argument_of_type_0_is_not_assignable_to_parameter_of_type_1.code, - Diagnostics.Cannot_find_name_0.code - ]; - registerCodeFix({ - errorCodes: errorCodes27, - getCodeActions(context) { - const typeChecker = context.program.getTypeChecker(); - const info = getInfo10(context.sourceFile, context.span.start, context.errorCode, typeChecker, context.program); - if (!info) { - return void 0; - } - if (info.kind === 3 /* ObjectLiteral */) { - const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => addObjectLiteralProperties(t, context, info)); - return [createCodeFixAction(fixMissingProperties, changes, Diagnostics.Add_missing_properties, fixMissingProperties, Diagnostics.Add_all_missing_properties)]; - } - if (info.kind === 4 /* JsxAttributes */) { - const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => addJsxAttributes(t, context, info)); - return [createCodeFixAction(fixMissingAttributes, changes, Diagnostics.Add_missing_attributes, fixMissingAttributes, Diagnostics.Add_all_missing_attributes)]; - } - if (info.kind === 2 /* Function */ || info.kind === 5 /* Signature */) { - const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => addFunctionDeclaration(t, context, info)); - return [createCodeFixAction(fixMissingFunctionDeclaration, changes, [Diagnostics.Add_missing_function_declaration_0, info.token.text], fixMissingFunctionDeclaration, Diagnostics.Add_all_missing_function_declarations)]; - } - if (info.kind === 1 /* Enum */) { - const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => addEnumMemberDeclaration(t, context.program.getTypeChecker(), info)); - return [createCodeFixAction(fixMissingMember, changes, [Diagnostics.Add_missing_enum_member_0, info.token.text], fixMissingMember, Diagnostics.Add_all_missing_members)]; - } - return concatenate(getActionsForMissingMethodDeclaration(context, info), getActionsForMissingMemberDeclaration(context, info)); - }, - fixIds: [fixMissingMember, fixMissingFunctionDeclaration, fixMissingProperties, fixMissingAttributes], - getAllCodeActions: (context) => { - const { program, fixId: fixId52 } = context; - const checker = program.getTypeChecker(); - const seen = /* @__PURE__ */ new Map(); - const typeDeclToMembers = /* @__PURE__ */ new Map(); - return createCombinedCodeActions(ts_textChanges_exports.ChangeTracker.with(context, (changes) => { - eachDiagnostic(context, errorCodes27, (diag2) => { - const info = getInfo10(diag2.file, diag2.start, diag2.code, checker, context.program); - if (!info || !addToSeen(seen, getNodeId(info.parentDeclaration) + "#" + info.token.text)) { - return; - } - if (fixId52 === fixMissingFunctionDeclaration && (info.kind === 2 /* Function */ || info.kind === 5 /* Signature */)) { - addFunctionDeclaration(changes, context, info); - } else if (fixId52 === fixMissingProperties && info.kind === 3 /* ObjectLiteral */) { - addObjectLiteralProperties(changes, context, info); - } else if (fixId52 === fixMissingAttributes && info.kind === 4 /* JsxAttributes */) { - addJsxAttributes(changes, context, info); - } else { - if (info.kind === 1 /* Enum */) { - addEnumMemberDeclaration(changes, checker, info); - } - if (info.kind === 0 /* TypeLikeDeclaration */) { - const { parentDeclaration, token } = info; - const infos = getOrUpdate(typeDeclToMembers, parentDeclaration, () => []); - if (!infos.some((i) => i.token.text === token.text)) { - infos.push(info); - } - } - } - }); - typeDeclToMembers.forEach((infos, declaration) => { - const supers = isTypeLiteralNode(declaration) ? void 0 : getAllSupers(declaration, checker); - for (const info of infos) { - if (supers == null ? void 0 : supers.some((superClassOrInterface) => { - const superInfos = typeDeclToMembers.get(superClassOrInterface); - return !!superInfos && superInfos.some(({ token: token2 }) => token2.text === info.token.text); - })) - continue; - const { parentDeclaration, declSourceFile, modifierFlags, token, call, isJSFile } = info; - if (call && !isPrivateIdentifier(token)) { - addMethodDeclaration(context, changes, call, token, modifierFlags & 32 /* Static */, parentDeclaration, declSourceFile); - } else { - if (isJSFile && !isInterfaceDeclaration(parentDeclaration) && !isTypeLiteralNode(parentDeclaration)) { - addMissingMemberInJs(changes, declSourceFile, parentDeclaration, token, !!(modifierFlags & 32 /* Static */)); - } else { - const typeNode = getTypeNode2(checker, parentDeclaration, token); - addPropertyDeclaration(changes, declSourceFile, parentDeclaration, token.text, typeNode, modifierFlags & 32 /* Static */); - } - } - } - }); - })); - } - }); } }); - // src/services/codefixes/fixAddMissingNewOperator.ts - function addMissingNewOperator(changes, sourceFile, span) { - const call = cast(findAncestorMatchingSpan2(sourceFile, span), isCallExpression); - const newExpression = factory.createNewExpression(call.expression, call.typeArguments, call.arguments); - changes.replaceNode(sourceFile, call, newExpression); + // src/services/codefixes/fixInvalidImportSyntax.ts + function getCodeFixesForImportDeclaration(context, node) { + const sourceFile = getSourceFileOfNode(node); + const namespace = getNamespaceDeclarationNode(node); + const opts = context.program.getCompilerOptions(); + const variations = []; + variations.push(createAction(context, sourceFile, node, makeImport( + namespace.name, + /*namedImports*/ + void 0, + node.moduleSpecifier, + getQuotePreference(sourceFile, context.preferences) + ))); + if (getEmitModuleKind(opts) === 1 /* CommonJS */) { + variations.push(createAction( + context, + sourceFile, + node, + factory.createImportEqualsDeclaration( + /*modifiers*/ + void 0, + /*isTypeOnly*/ + false, + namespace.name, + factory.createExternalModuleReference(node.moduleSpecifier) + ) + )); + } + return variations; } - function findAncestorMatchingSpan2(sourceFile, span) { - let token = getTokenAtPosition(sourceFile, span.start); - const end = textSpanEnd(span); - while (token.end < end) { - token = token.parent; + function createAction(context, sourceFile, node, replacement) { + const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => t.replaceNode(sourceFile, node, replacement)); + return createCodeFixActionWithoutFixAll(fixName5, changes, [Diagnostics.Replace_import_with_0, changes[0].textChanges[0].newText]); + } + function getActionsForUsageOfInvalidImport(context) { + const sourceFile = context.sourceFile; + const targetKind = Diagnostics.This_expression_is_not_callable.code === context.errorCode ? 213 /* CallExpression */ : 214 /* NewExpression */; + const node = findAncestor(getTokenAtPosition(sourceFile, context.span.start), (a) => a.kind === targetKind); + if (!node) { + return []; } - return token; + const expr = node.expression; + return getImportCodeFixesForExpression(context, expr); } - var fixId24, errorCodes28; - var init_fixAddMissingNewOperator = __esm({ - "src/services/codefixes/fixAddMissingNewOperator.ts"() { + function getActionsForInvalidImportLocation(context) { + const sourceFile = context.sourceFile; + const node = findAncestor(getTokenAtPosition(sourceFile, context.span.start), (a) => a.getStart() === context.span.start && a.getEnd() === context.span.start + context.span.length); + if (!node) { + return []; + } + return getImportCodeFixesForExpression(context, node); + } + function getImportCodeFixesForExpression(context, expr) { + const type = context.program.getTypeChecker().getTypeAtLocation(expr); + if (!(type.symbol && isTransientSymbol(type.symbol) && type.symbol.links.originatingImport)) { + return []; + } + const fixes = []; + const relatedImport = type.symbol.links.originatingImport; + if (!isImportCall(relatedImport)) { + addRange(fixes, getCodeFixesForImportDeclaration(context, relatedImport)); + } + if (isExpression(expr) && !(isNamedDeclaration(expr.parent) && expr.parent.name === expr)) { + const sourceFile = context.sourceFile; + const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => t.replaceNode(sourceFile, expr, factory.createPropertyAccessExpression(expr, "default"), {})); + fixes.push(createCodeFixActionWithoutFixAll(fixName5, changes, Diagnostics.Use_synthetic_default_member)); + } + return fixes; + } + var fixName5; + var init_fixInvalidImportSyntax = __esm({ + "src/services/codefixes/fixInvalidImportSyntax.ts"() { "use strict"; init_ts4(); init_ts_codefix(); - fixId24 = "addMissingNewOperator"; - errorCodes28 = [Diagnostics.Value_of_type_0_is_not_callable_Did_you_mean_to_include_new.code]; + fixName5 = "invalidImportSyntax"; registerCodeFix({ - errorCodes: errorCodes28, - getCodeActions(context) { - const { sourceFile, span } = context; - const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => addMissingNewOperator(t, sourceFile, span)); - return [createCodeFixAction(fixId24, changes, Diagnostics.Add_missing_new_operator_to_call, fixId24, Diagnostics.Add_missing_new_operator_to_all_calls)]; - }, - fixIds: [fixId24], - getAllCodeActions: (context) => codeFixAll(context, errorCodes28, (changes, diag2) => addMissingNewOperator(changes, context.sourceFile, diag2)) + errorCodes: [ + Diagnostics.This_expression_is_not_callable.code, + Diagnostics.This_expression_is_not_constructable.code + ], + getCodeActions: getActionsForUsageOfInvalidImport + }); + registerCodeFix({ + errorCodes: [ + // The following error codes cover pretty much all assignability errors that could involve an expression + Diagnostics.Argument_of_type_0_is_not_assignable_to_parameter_of_type_1.code, + Diagnostics.Type_0_does_not_satisfy_the_constraint_1.code, + Diagnostics.Type_0_is_not_assignable_to_type_1.code, + Diagnostics.Type_0_is_not_assignable_to_type_1_Two_different_types_with_this_name_exist_but_they_are_unrelated.code, + Diagnostics.Type_predicate_0_is_not_assignable_to_1.code, + Diagnostics.Property_0_of_type_1_is_not_assignable_to_2_index_type_3.code, + Diagnostics._0_index_type_1_is_not_assignable_to_2_index_type_3.code, + Diagnostics.Property_0_in_type_1_is_not_assignable_to_the_same_property_in_base_type_2.code, + Diagnostics.Property_0_in_type_1_is_not_assignable_to_type_2.code, + Diagnostics.Property_0_of_JSX_spread_attribute_is_not_assignable_to_target_property.code, + Diagnostics.The_this_context_of_type_0_is_not_assignable_to_method_s_this_of_type_1.code + ], + getCodeActions: getActionsForInvalidImportLocation }); } - }); - - // src/services/codefixes/fixCannotFindModule.ts - function getInstallCommand(fileName, packageName) { - return { type: "install package", file: fileName, packageName }; + }); + + // src/services/codefixes/fixStrictClassInitialization.ts + function getInfo16(sourceFile, pos) { + const token = getTokenAtPosition(sourceFile, pos); + if (isIdentifier(token) && isPropertyDeclaration(token.parent)) { + const type = getEffectiveTypeAnnotationNode(token.parent); + if (type) { + return { type, prop: token.parent, isJs: isInJSFile(token.parent) }; + } + } + return void 0; + } + function getActionForAddMissingDefiniteAssignmentAssertion(context, info) { + if (info.isJs) + return void 0; + const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => addDefiniteAssignmentAssertion(t, context.sourceFile, info.prop)); + return createCodeFixAction(fixName6, changes, [Diagnostics.Add_definite_assignment_assertion_to_property_0, info.prop.getText()], fixIdAddDefiniteAssignmentAssertions, Diagnostics.Add_definite_assignment_assertions_to_all_uninitialized_properties); + } + function addDefiniteAssignmentAssertion(changeTracker, propertyDeclarationSourceFile, propertyDeclaration) { + suppressLeadingAndTrailingTrivia(propertyDeclaration); + const property = factory.updatePropertyDeclaration( + propertyDeclaration, + propertyDeclaration.modifiers, + propertyDeclaration.name, + factory.createToken(54 /* ExclamationToken */), + propertyDeclaration.type, + propertyDeclaration.initializer + ); + changeTracker.replaceNode(propertyDeclarationSourceFile, propertyDeclaration, property); + } + function getActionForAddMissingUndefinedType(context, info) { + const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => addUndefinedType(t, context.sourceFile, info)); + return createCodeFixAction(fixName6, changes, [Diagnostics.Add_undefined_type_to_property_0, info.prop.name.getText()], fixIdAddUndefinedType, Diagnostics.Add_undefined_type_to_all_uninitialized_properties); + } + function addUndefinedType(changeTracker, sourceFile, info) { + const undefinedTypeNode = factory.createKeywordTypeNode(157 /* UndefinedKeyword */); + const types = isUnionTypeNode(info.type) ? info.type.types.concat(undefinedTypeNode) : [info.type, undefinedTypeNode]; + const unionTypeNode = factory.createUnionTypeNode(types); + if (info.isJs) { + changeTracker.addJSDocTags(sourceFile, info.prop, [factory.createJSDocTypeTag( + /*tagName*/ + void 0, + factory.createJSDocTypeExpression(unionTypeNode) + )]); + } else { + changeTracker.replaceNode(sourceFile, info.type, unionTypeNode); + } } - function tryGetImportedPackageName(sourceFile, pos) { - const moduleSpecifierText = tryCast(getTokenAtPosition(sourceFile, pos), isStringLiteral); - if (!moduleSpecifierText) + function getActionForAddMissingInitializer(context, info) { + if (info.isJs) return void 0; - const moduleName = moduleSpecifierText.text; - const { packageName } = parsePackageName(moduleName); - return isExternalModuleNameRelative(packageName) ? void 0 : packageName; + const checker = context.program.getTypeChecker(); + const initializer = getInitializer(checker, info.prop); + if (!initializer) + return void 0; + const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => addInitializer(t, context.sourceFile, info.prop, initializer)); + return createCodeFixAction(fixName6, changes, [Diagnostics.Add_initializer_to_property_0, info.prop.name.getText()], fixIdAddInitializer, Diagnostics.Add_initializers_to_all_uninitialized_properties); } - function getTypesPackageNameToInstall(packageName, host, diagCode) { - var _a; - return diagCode === errorCodeCannotFindModule ? ts_JsTyping_exports.nodeCoreModules.has(packageName) ? "@types/node" : void 0 : ((_a = host.isKnownTypesPackageName) == null ? void 0 : _a.call(host, packageName)) ? getTypesPackageName(packageName) : void 0; + function addInitializer(changeTracker, propertyDeclarationSourceFile, propertyDeclaration, initializer) { + suppressLeadingAndTrailingTrivia(propertyDeclaration); + const property = factory.updatePropertyDeclaration( + propertyDeclaration, + propertyDeclaration.modifiers, + propertyDeclaration.name, + propertyDeclaration.questionToken, + propertyDeclaration.type, + initializer + ); + changeTracker.replaceNode(propertyDeclarationSourceFile, propertyDeclaration, property); } - var fixName2, fixIdInstallTypesPackage, errorCodeCannotFindModule, errorCodes29; - var init_fixCannotFindModule = __esm({ - "src/services/codefixes/fixCannotFindModule.ts"() { + function getInitializer(checker, propertyDeclaration) { + return getDefaultValueFromType(checker, checker.getTypeFromTypeNode(propertyDeclaration.type)); + } + function getDefaultValueFromType(checker, type) { + if (type.flags & 512 /* BooleanLiteral */) { + return type === checker.getFalseType() || type === checker.getFalseType( + /*fresh*/ + true + ) ? factory.createFalse() : factory.createTrue(); + } else if (type.isStringLiteral()) { + return factory.createStringLiteral(type.value); + } else if (type.isNumberLiteral()) { + return factory.createNumericLiteral(type.value); + } else if (type.flags & 2048 /* BigIntLiteral */) { + return factory.createBigIntLiteral(type.value); + } else if (type.isUnion()) { + return firstDefined(type.types, (t) => getDefaultValueFromType(checker, t)); + } else if (type.isClass()) { + const classDeclaration = getClassLikeDeclarationOfSymbol(type.symbol); + if (!classDeclaration || hasSyntacticModifier(classDeclaration, 64 /* Abstract */)) + return void 0; + const constructorDeclaration = getFirstConstructorWithBody(classDeclaration); + if (constructorDeclaration && constructorDeclaration.parameters.length) + return void 0; + return factory.createNewExpression( + factory.createIdentifier(type.symbol.name), + /*typeArguments*/ + void 0, + /*argumentsArray*/ + void 0 + ); + } else if (checker.isArrayLikeType(type)) { + return factory.createArrayLiteralExpression(); + } + return void 0; + } + var fixName6, fixIdAddDefiniteAssignmentAssertions, fixIdAddUndefinedType, fixIdAddInitializer, errorCodes51; + var init_fixStrictClassInitialization = __esm({ + "src/services/codefixes/fixStrictClassInitialization.ts"() { "use strict"; init_ts4(); init_ts_codefix(); - fixName2 = "fixCannotFindModule"; - fixIdInstallTypesPackage = "installTypesPackage"; - errorCodeCannotFindModule = Diagnostics.Cannot_find_module_0_or_its_corresponding_type_declarations.code; - errorCodes29 = [ - errorCodeCannotFindModule, - Diagnostics.Could_not_find_a_declaration_file_for_module_0_1_implicitly_has_an_any_type.code - ]; + fixName6 = "strictClassInitialization"; + fixIdAddDefiniteAssignmentAssertions = "addMissingPropertyDefiniteAssignmentAssertions"; + fixIdAddUndefinedType = "addMissingPropertyUndefinedType"; + fixIdAddInitializer = "addMissingPropertyInitializer"; + errorCodes51 = [Diagnostics.Property_0_has_no_initializer_and_is_not_definitely_assigned_in_the_constructor.code]; registerCodeFix({ - errorCodes: errorCodes29, - getCodeActions: function getCodeActionsToFixNotFoundModule(context) { - const { host, sourceFile, span: { start } } = context; - const packageName = tryGetImportedPackageName(sourceFile, start); - if (packageName === void 0) - return void 0; - const typesPackageName = getTypesPackageNameToInstall(packageName, host, context.errorCode); - return typesPackageName === void 0 ? [] : [createCodeFixAction( - fixName2, - /*changes*/ - [], - [Diagnostics.Install_0, typesPackageName], - fixIdInstallTypesPackage, - Diagnostics.Install_all_missing_types_packages, - getInstallCommand(sourceFile.fileName, typesPackageName) - )]; + errorCodes: errorCodes51, + getCodeActions: function getCodeActionsForStrictClassInitializationErrors(context) { + const info = getInfo16(context.sourceFile, context.span.start); + if (!info) + return; + const result = []; + append(result, getActionForAddMissingUndefinedType(context, info)); + append(result, getActionForAddMissingDefiniteAssignmentAssertion(context, info)); + append(result, getActionForAddMissingInitializer(context, info)); + return result; }, - fixIds: [fixIdInstallTypesPackage], + fixIds: [fixIdAddDefiniteAssignmentAssertions, fixIdAddUndefinedType, fixIdAddInitializer], getAllCodeActions: (context) => { - return codeFixAll(context, errorCodes29, (_changes, diag2, commands) => { - const packageName = tryGetImportedPackageName(diag2.file, diag2.start); - if (packageName === void 0) - return void 0; + return codeFixAll(context, errorCodes51, (changes, diag2) => { + const info = getInfo16(diag2.file, diag2.start); + if (!info) + return; switch (context.fixId) { - case fixIdInstallTypesPackage: { - const pkg = getTypesPackageNameToInstall(packageName, context.host, diag2.code); - if (pkg) { - commands.push(getInstallCommand(diag2.file.fileName, pkg)); - } + case fixIdAddDefiniteAssignmentAssertions: + addDefiniteAssignmentAssertion(changes, diag2.file, info.prop); + break; + case fixIdAddUndefinedType: + addUndefinedType(changes, diag2.file, info); + break; + case fixIdAddInitializer: + const checker = context.program.getTypeChecker(); + const initializer = getInitializer(checker, info.prop); + if (!initializer) + return; + addInitializer(changes, diag2.file, info.prop, initializer); break; - } default: - Debug.fail(`Bad fixId: ${context.fixId}`); + Debug.fail(JSON.stringify(context.fixId)); } }); } @@ -248722,19711 +237441,30695 @@ ${newComment.split("\n").map((c) => ` * ${c}`).join("\n")} } }); - // src/services/codefixes/fixClassDoesntImplementInheritedAbstractMember.ts - function getClass2(sourceFile, pos) { - const token = getTokenAtPosition(sourceFile, pos); - return cast(token.parent, isClassLike); - } - function addMissingMembers(classDeclaration, sourceFile, context, changeTracker, preferences) { - const extendsNode = getEffectiveBaseTypeNode(classDeclaration); - const checker = context.program.getTypeChecker(); - const instantiatedExtendsType = checker.getTypeAtLocation(extendsNode); - const abstractAndNonPrivateExtendsSymbols = checker.getPropertiesOfType(instantiatedExtendsType).filter(symbolPointsToNonPrivateAndAbstractMember); - const importAdder = createImportAdder(sourceFile, context.program, preferences, context.host); - createMissingMemberNodes(classDeclaration, abstractAndNonPrivateExtendsSymbols, sourceFile, context, preferences, importAdder, (member) => changeTracker.insertMemberAtStart(sourceFile, classDeclaration, member)); - importAdder.writeFixes(changeTracker); - } - function symbolPointsToNonPrivateAndAbstractMember(symbol) { - const flags = getSyntacticModifierFlags(first(symbol.getDeclarations())); - return !(flags & 8 /* Private */) && !!(flags & 256 /* Abstract */); + // src/services/codefixes/requireInTs.ts + function doChange34(changes, sourceFile, info) { + const { allowSyntheticDefaults, defaultImportName, namedImports, statement, required } = info; + changes.replaceNode( + sourceFile, + statement, + defaultImportName && !allowSyntheticDefaults ? factory.createImportEqualsDeclaration( + /*modifiers*/ + void 0, + /*isTypeOnly*/ + false, + defaultImportName, + factory.createExternalModuleReference(required) + ) : factory.createImportDeclaration( + /*modifiers*/ + void 0, + factory.createImportClause( + /*isTypeOnly*/ + false, + defaultImportName, + namedImports + ), + required, + /*attributes*/ + void 0 + ) + ); } - var errorCodes30, fixId25; - var init_fixClassDoesntImplementInheritedAbstractMember = __esm({ - "src/services/codefixes/fixClassDoesntImplementInheritedAbstractMember.ts"() { - "use strict"; - init_ts4(); - init_ts_codefix(); - errorCodes30 = [ - Diagnostics.Non_abstract_class_0_does_not_implement_all_abstract_members_of_1.code - ]; - fixId25 = "fixClassDoesntImplementInheritedAbstractMember"; - registerCodeFix({ - errorCodes: errorCodes30, - getCodeActions: function getCodeActionsToFixClassNotImplementingInheritedMembers(context) { - const { sourceFile, span } = context; - const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => addMissingMembers(getClass2(sourceFile, span.start), sourceFile, context, t, context.preferences)); - return changes.length === 0 ? void 0 : [createCodeFixAction(fixId25, changes, Diagnostics.Implement_inherited_abstract_class, fixId25, Diagnostics.Implement_all_inherited_abstract_classes)]; - }, - fixIds: [fixId25], - getAllCodeActions: function getAllCodeActionsToFixClassDoesntImplementInheritedAbstractMember(context) { - const seenClassDeclarations = /* @__PURE__ */ new Map(); - return codeFixAll(context, errorCodes30, (changes, diag2) => { - const classDeclaration = getClass2(diag2.file, diag2.start); - if (addToSeen(seenClassDeclarations, getNodeId(classDeclaration))) { - addMissingMembers(classDeclaration, context.sourceFile, context, changes, context.preferences); - } - }); - } - }); + function getInfo17(sourceFile, program, pos) { + const { parent: parent2 } = getTokenAtPosition(sourceFile, pos); + if (!isRequireCall( + parent2, + /*requireStringLiteralLikeArgument*/ + true + )) { + Debug.failBadSyntaxKind(parent2); + } + const decl = cast(parent2.parent, isVariableDeclaration); + const defaultImportName = tryCast(decl.name, isIdentifier); + const namedImports = isObjectBindingPattern(decl.name) ? tryCreateNamedImportsFromObjectBindingPattern(decl.name) : void 0; + if (defaultImportName || namedImports) { + return { + allowSyntheticDefaults: getAllowSyntheticDefaultImports(program.getCompilerOptions()), + defaultImportName, + namedImports, + statement: cast(decl.parent.parent, isVariableStatement), + required: first(parent2.arguments) + }; } - }); - - // src/services/codefixes/fixClassSuperMustPrecedeThisAccess.ts - function doChange19(changes, sourceFile, constructor, superCall) { - changes.insertNodeAtConstructorStart(sourceFile, constructor, superCall); - changes.delete(sourceFile, superCall); - } - function getNodes(sourceFile, pos) { - const token = getTokenAtPosition(sourceFile, pos); - if (token.kind !== 110 /* ThisKeyword */) - return void 0; - const constructor = getContainingFunction(token); - const superCall = findSuperCall(constructor.body); - return superCall && !superCall.expression.arguments.some((arg) => isPropertyAccessExpression(arg) && arg.expression === token) ? { constructor, superCall } : void 0; } - function findSuperCall(n) { - return isExpressionStatement(n) && isSuperCall(n.expression) ? n : isFunctionLike(n) ? void 0 : forEachChild(n, findSuperCall); + function tryCreateNamedImportsFromObjectBindingPattern(node) { + const importSpecifiers = []; + for (const element of node.elements) { + if (!isIdentifier(element.name) || element.initializer) { + return void 0; + } + importSpecifiers.push(factory.createImportSpecifier( + /*isTypeOnly*/ + false, + tryCast(element.propertyName, isIdentifier), + element.name + )); + } + if (importSpecifiers.length) { + return factory.createNamedImports(importSpecifiers); + } } - var fixId26, errorCodes31; - var init_fixClassSuperMustPrecedeThisAccess = __esm({ - "src/services/codefixes/fixClassSuperMustPrecedeThisAccess.ts"() { + var fixId41, errorCodes52; + var init_requireInTs = __esm({ + "src/services/codefixes/requireInTs.ts"() { "use strict"; init_ts4(); init_ts_codefix(); - fixId26 = "classSuperMustPrecedeThisAccess"; - errorCodes31 = [Diagnostics.super_must_be_called_before_accessing_this_in_the_constructor_of_a_derived_class.code]; + fixId41 = "requireInTs"; + errorCodes52 = [Diagnostics.require_call_may_be_converted_to_an_import.code]; registerCodeFix({ - errorCodes: errorCodes31, + errorCodes: errorCodes52, getCodeActions(context) { - const { sourceFile, span } = context; - const nodes = getNodes(sourceFile, span.start); - if (!nodes) + const info = getInfo17(context.sourceFile, context.program, context.span.start); + if (!info) { return void 0; - const { constructor, superCall } = nodes; - const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange19(t, sourceFile, constructor, superCall)); - return [createCodeFixAction(fixId26, changes, Diagnostics.Make_super_call_the_first_statement_in_the_constructor, fixId26, Diagnostics.Make_all_super_calls_the_first_statement_in_their_constructor)]; + } + const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange34(t, context.sourceFile, info)); + return [createCodeFixAction(fixId41, changes, Diagnostics.Convert_require_to_import, fixId41, Diagnostics.Convert_all_require_to_import)]; }, - fixIds: [fixId26], - getAllCodeActions(context) { - const { sourceFile } = context; - const seenClasses = /* @__PURE__ */ new Map(); - return codeFixAll(context, errorCodes31, (changes, diag2) => { - const nodes = getNodes(diag2.file, diag2.start); - if (!nodes) - return; - const { constructor, superCall } = nodes; - if (addToSeen(seenClasses, getNodeId(constructor.parent))) { - doChange19(changes, sourceFile, constructor, superCall); - } - }); - } + fixIds: [fixId41], + getAllCodeActions: (context) => codeFixAll(context, errorCodes52, (changes, diag2) => { + const info = getInfo17(diag2.file, context.program, diag2.start); + if (info) { + doChange34(changes, context.sourceFile, info); + } + }) }); } }); - // src/services/codefixes/fixConstructorForDerivedNeedSuperCall.ts - function getNode(sourceFile, pos) { - const token = getTokenAtPosition(sourceFile, pos); - Debug.assert(isConstructorDeclaration(token.parent), "token should be at the constructor declaration"); - return token.parent; + // src/services/codefixes/useDefaultImport.ts + function getInfo18(sourceFile, pos) { + const name = getTokenAtPosition(sourceFile, pos); + if (!isIdentifier(name)) + return void 0; + const { parent: parent2 } = name; + if (isImportEqualsDeclaration(parent2) && isExternalModuleReference(parent2.moduleReference)) { + return { importNode: parent2, name, moduleSpecifier: parent2.moduleReference.expression }; + } else if (isNamespaceImport(parent2)) { + const importNode = parent2.parent.parent; + return { importNode, name, moduleSpecifier: importNode.moduleSpecifier }; + } } - function doChange20(changes, sourceFile, ctr) { - const superCall = factory.createExpressionStatement(factory.createCallExpression( - factory.createSuper(), - /*typeArguments*/ + function doChange35(changes, sourceFile, info, preferences) { + changes.replaceNode(sourceFile, info.importNode, makeImport( + info.name, + /*namedImports*/ void 0, - /*argumentsArray*/ - emptyArray + info.moduleSpecifier, + getQuotePreference(sourceFile, preferences) )); - changes.insertNodeAtConstructorStart(sourceFile, ctr, superCall); } - var fixId27, errorCodes32; - var init_fixConstructorForDerivedNeedSuperCall = __esm({ - "src/services/codefixes/fixConstructorForDerivedNeedSuperCall.ts"() { + var fixId42, errorCodes53; + var init_useDefaultImport = __esm({ + "src/services/codefixes/useDefaultImport.ts"() { "use strict"; init_ts4(); init_ts_codefix(); - fixId27 = "constructorForDerivedNeedSuperCall"; - errorCodes32 = [Diagnostics.Constructors_for_derived_classes_must_contain_a_super_call.code]; + fixId42 = "useDefaultImport"; + errorCodes53 = [Diagnostics.Import_may_be_converted_to_a_default_import.code]; registerCodeFix({ - errorCodes: errorCodes32, + errorCodes: errorCodes53, getCodeActions(context) { - const { sourceFile, span } = context; - const ctr = getNode(sourceFile, span.start); - const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange20(t, sourceFile, ctr)); - return [createCodeFixAction(fixId27, changes, Diagnostics.Add_missing_super_call, fixId27, Diagnostics.Add_all_missing_super_calls)]; - }, - fixIds: [fixId27], - getAllCodeActions: (context) => codeFixAll(context, errorCodes32, (changes, diag2) => doChange20(changes, context.sourceFile, getNode(diag2.file, diag2.start))) - }); - } - }); - - // src/services/codefixes/fixEnableJsxFlag.ts - function doChange21(changeTracker, configFile) { - setJsonCompilerOptionValue(changeTracker, configFile, "jsx", factory.createStringLiteral("react")); - } - var fixID, errorCodes33; - var init_fixEnableJsxFlag = __esm({ - "src/services/codefixes/fixEnableJsxFlag.ts"() { - "use strict"; - init_ts4(); - init_ts_codefix(); - fixID = "fixEnableJsxFlag"; - errorCodes33 = [Diagnostics.Cannot_use_JSX_unless_the_jsx_flag_is_provided.code]; - registerCodeFix({ - errorCodes: errorCodes33, - getCodeActions: function getCodeActionsToFixEnableJsxFlag(context) { - const { configFile } = context.program.getCompilerOptions(); - if (configFile === void 0) { + const { sourceFile, span: { start } } = context; + const info = getInfo18(sourceFile, start); + if (!info) return void 0; - } - const changes = ts_textChanges_exports.ChangeTracker.with( - context, - (changeTracker) => doChange21(changeTracker, configFile) - ); - return [ - createCodeFixActionWithoutFixAll(fixID, changes, Diagnostics.Enable_the_jsx_flag_in_your_configuration_file) - ]; + const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange35(t, sourceFile, info, context.preferences)); + return [createCodeFixAction(fixId42, changes, Diagnostics.Convert_to_default_import, fixId42, Diagnostics.Convert_all_to_default_imports)]; }, - fixIds: [fixID], - getAllCodeActions: (context) => codeFixAll(context, errorCodes33, (changes) => { - const { configFile } = context.program.getCompilerOptions(); - if (configFile === void 0) { - return void 0; - } - doChange21(changes, configFile); + fixIds: [fixId42], + getAllCodeActions: (context) => codeFixAll(context, errorCodes53, (changes, diag2) => { + const info = getInfo18(diag2.file, diag2.start); + if (info) + doChange35(changes, diag2.file, info, context.preferences); }) }); } }); - // src/services/codefixes/fixNaNEquality.ts - function getInfo11(program, sourceFile, span) { - const diag2 = find(program.getSemanticDiagnostics(sourceFile), (diag3) => diag3.start === span.start && diag3.length === span.length); - if (diag2 === void 0 || diag2.relatedInformation === void 0) - return; - const related = find(diag2.relatedInformation, (related2) => related2.code === Diagnostics.Did_you_mean_0.code); - if (related === void 0 || related.file === void 0 || related.start === void 0 || related.length === void 0) - return; - const token = findAncestorMatchingSpan(related.file, createTextSpan(related.start, related.length)); - if (token === void 0) + // src/services/codefixes/useBigintLiteral.ts + function makeChange9(changeTracker, sourceFile, span) { + const numericLiteral = tryCast(getTokenAtPosition(sourceFile, span.start), isNumericLiteral); + if (!numericLiteral) { return; - if (isExpression(token) && isBinaryExpression(token.parent)) { - return { suggestion: getSuggestion(related.messageText), expression: token.parent, arg: token }; } - return void 0; - } - function doChange22(changes, sourceFile, arg, expression) { - const callExpression = factory.createCallExpression( - factory.createPropertyAccessExpression(factory.createIdentifier("Number"), factory.createIdentifier("isNaN")), - /*typeArguments*/ - void 0, - [arg] - ); - const operator = expression.operatorToken.kind; - changes.replaceNode( - sourceFile, - expression, - operator === 38 /* ExclamationEqualsEqualsToken */ || operator === 36 /* ExclamationEqualsToken */ ? factory.createPrefixUnaryExpression(54 /* ExclamationToken */, callExpression) : callExpression - ); - } - function getSuggestion(messageText) { - const [_, suggestion] = flattenDiagnosticMessageText(messageText, "\n", 0).match(/\'(.*)\'/) || []; - return suggestion; + const newText = numericLiteral.getText(sourceFile) + "n"; + changeTracker.replaceNode(sourceFile, numericLiteral, factory.createBigIntLiteral(newText)); } - var fixId28, errorCodes34; - var init_fixNaNEquality = __esm({ - "src/services/codefixes/fixNaNEquality.ts"() { + var fixId43, errorCodes54; + var init_useBigintLiteral = __esm({ + "src/services/codefixes/useBigintLiteral.ts"() { "use strict"; init_ts4(); init_ts_codefix(); - fixId28 = "fixNaNEquality"; - errorCodes34 = [ - Diagnostics.This_condition_will_always_return_0.code + fixId43 = "useBigintLiteral"; + errorCodes54 = [ + Diagnostics.Numeric_literals_with_absolute_values_equal_to_2_53_or_greater_are_too_large_to_be_represented_accurately_as_integers.code ]; registerCodeFix({ - errorCodes: errorCodes34, - getCodeActions(context) { - const { sourceFile, span, program } = context; - const info = getInfo11(program, sourceFile, span); - if (info === void 0) - return; - const { suggestion, expression, arg } = info; - const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange22(t, sourceFile, arg, expression)); - return [createCodeFixAction(fixId28, changes, [Diagnostics.Use_0, suggestion], fixId28, Diagnostics.Use_Number_isNaN_in_all_conditions)]; + errorCodes: errorCodes54, + getCodeActions: function getCodeActionsToUseBigintLiteral(context) { + const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => makeChange9(t, context.sourceFile, context.span)); + if (changes.length > 0) { + return [createCodeFixAction(fixId43, changes, Diagnostics.Convert_to_a_bigint_numeric_literal, fixId43, Diagnostics.Convert_all_to_bigint_numeric_literals)]; + } }, - fixIds: [fixId28], + fixIds: [fixId43], getAllCodeActions: (context) => { - return codeFixAll(context, errorCodes34, (changes, diag2) => { - const info = getInfo11(context.program, diag2.file, createTextSpan(diag2.start, diag2.length)); - if (info) { - doChange22(changes, diag2.file, info.arg, info.expression); - } - }); + return codeFixAll(context, errorCodes54, (changes, diag2) => makeChange9(changes, diag2.file, diag2)); } }); } }); - // src/services/codefixes/fixModuleAndTargetOptions.ts - var init_fixModuleAndTargetOptions = __esm({ - "src/services/codefixes/fixModuleAndTargetOptions.ts"() { + // src/services/codefixes/fixAddModuleReferTypeMissingTypeof.ts + function getImportTypeNode(sourceFile, pos) { + const token = getTokenAtPosition(sourceFile, pos); + Debug.assert(token.kind === 102 /* ImportKeyword */, "This token should be an ImportKeyword"); + Debug.assert(token.parent.kind === 205 /* ImportType */, "Token parent should be an ImportType"); + return token.parent; + } + function doChange36(changes, sourceFile, importType) { + const newTypeNode = factory.updateImportTypeNode( + importType, + importType.argument, + importType.attributes, + importType.qualifier, + importType.typeArguments, + /*isTypeOf*/ + true + ); + changes.replaceNode(sourceFile, importType, newTypeNode); + } + var fixIdAddMissingTypeof, fixId44, errorCodes55; + var init_fixAddModuleReferTypeMissingTypeof = __esm({ + "src/services/codefixes/fixAddModuleReferTypeMissingTypeof.ts"() { "use strict"; init_ts4(); init_ts_codefix(); + fixIdAddMissingTypeof = "fixAddModuleReferTypeMissingTypeof"; + fixId44 = fixIdAddMissingTypeof; + errorCodes55 = [Diagnostics.Module_0_does_not_refer_to_a_type_but_is_used_as_a_type_here_Did_you_mean_typeof_import_0.code]; registerCodeFix({ - errorCodes: [ - Diagnostics.Top_level_await_expressions_are_only_allowed_when_the_module_option_is_set_to_es2022_esnext_system_node16_or_nodenext_and_the_target_option_is_set_to_es2017_or_higher.code, - Diagnostics.Top_level_for_await_loops_are_only_allowed_when_the_module_option_is_set_to_es2022_esnext_system_node16_or_nodenext_and_the_target_option_is_set_to_es2017_or_higher.code - ], - getCodeActions: function getCodeActionsToFixModuleAndTarget(context) { - const compilerOptions = context.program.getCompilerOptions(); - const { configFile } = compilerOptions; - if (configFile === void 0) { - return void 0; - } - const codeFixes = []; - const moduleKind = getEmitModuleKind(compilerOptions); - const moduleOutOfRange = moduleKind >= 5 /* ES2015 */ && moduleKind < 99 /* ESNext */; - if (moduleOutOfRange) { - const changes = ts_textChanges_exports.ChangeTracker.with(context, (changes2) => { - setJsonCompilerOptionValue(changes2, configFile, "module", factory.createStringLiteral("esnext")); - }); - codeFixes.push(createCodeFixActionWithoutFixAll("fixModuleOption", changes, [Diagnostics.Set_the_module_option_in_your_configuration_file_to_0, "esnext"])); - } - const target = getEmitScriptTarget(compilerOptions); - const targetOutOfRange = target < 4 /* ES2017 */ || target > 99 /* ESNext */; - if (targetOutOfRange) { - const changes = ts_textChanges_exports.ChangeTracker.with(context, (tracker) => { - const configObject = getTsConfigObjectLiteralExpression(configFile); - if (!configObject) - return; - const options = [["target", factory.createStringLiteral("es2017")]]; - if (moduleKind === 1 /* CommonJS */) { - options.push(["module", factory.createStringLiteral("commonjs")]); - } - setJsonCompilerOptionValues(tracker, configFile, options); - }); - codeFixes.push(createCodeFixActionWithoutFixAll("fixTargetOption", changes, [Diagnostics.Set_the_target_option_in_your_configuration_file_to_0, "es2017"])); - } - return codeFixes.length ? codeFixes : void 0; - } + errorCodes: errorCodes55, + getCodeActions: function getCodeActionsToAddMissingTypeof(context) { + const { sourceFile, span } = context; + const importType = getImportTypeNode(sourceFile, span.start); + const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange36(t, sourceFile, importType)); + return [createCodeFixAction(fixId44, changes, Diagnostics.Add_missing_typeof, fixId44, Diagnostics.Add_missing_typeof)]; + }, + fixIds: [fixId44], + getAllCodeActions: (context) => codeFixAll(context, errorCodes55, (changes, diag2) => doChange36(changes, context.sourceFile, getImportTypeNode(diag2.file, diag2.start))) }); } }); - // src/services/codefixes/fixPropertyAssignment.ts - function doChange23(changes, sourceFile, node) { - changes.replaceNode(sourceFile, node, factory.createPropertyAssignment(node.name, node.objectAssignmentInitializer)); + // src/services/codefixes/wrapJsxInFragment.ts + function findNodeToFix(sourceFile, pos) { + const lessThanToken = getTokenAtPosition(sourceFile, pos); + const firstJsxElementOrOpenElement = lessThanToken.parent; + let binaryExpr = firstJsxElementOrOpenElement.parent; + if (!isBinaryExpression(binaryExpr)) { + binaryExpr = binaryExpr.parent; + if (!isBinaryExpression(binaryExpr)) + return void 0; + } + if (!nodeIsMissing(binaryExpr.operatorToken)) + return void 0; + return binaryExpr; } - function getProperty2(sourceFile, pos) { - return cast(getTokenAtPosition(sourceFile, pos).parent, isShorthandPropertyAssignment); + function doChange37(changeTracker, sf, node) { + const jsx = flattenInvalidBinaryExpr(node); + if (jsx) + changeTracker.replaceNode(sf, node, factory.createJsxFragment(factory.createJsxOpeningFragment(), jsx, factory.createJsxJsxClosingFragment())); } - var fixId29, errorCodes35; - var init_fixPropertyAssignment = __esm({ - "src/services/codefixes/fixPropertyAssignment.ts"() { + function flattenInvalidBinaryExpr(node) { + const children = []; + let current = node; + while (true) { + if (isBinaryExpression(current) && nodeIsMissing(current.operatorToken) && current.operatorToken.kind === 28 /* CommaToken */) { + children.push(current.left); + if (isJsxChild(current.right)) { + children.push(current.right); + return children; + } else if (isBinaryExpression(current.right)) { + current = current.right; + continue; + } else + return void 0; + } else + return void 0; + } + } + var fixID2, errorCodes56; + var init_wrapJsxInFragment = __esm({ + "src/services/codefixes/wrapJsxInFragment.ts"() { "use strict"; init_ts4(); init_ts_codefix(); - fixId29 = "fixPropertyAssignment"; - errorCodes35 = [ - Diagnostics.Did_you_mean_to_use_a_Colon_An_can_only_follow_a_property_name_when_the_containing_object_literal_is_part_of_a_destructuring_pattern.code - ]; + fixID2 = "wrapJsxInFragment"; + errorCodes56 = [Diagnostics.JSX_expressions_must_have_one_parent_element.code]; registerCodeFix({ - errorCodes: errorCodes35, - fixIds: [fixId29], - getCodeActions(context) { + errorCodes: errorCodes56, + getCodeActions: function getCodeActionsToWrapJsxInFragment(context) { const { sourceFile, span } = context; - const property = getProperty2(sourceFile, span.start); - const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange23(t, context.sourceFile, property)); - return [createCodeFixAction(fixId29, changes, [Diagnostics.Change_0_to_1, "=", ":"], fixId29, [Diagnostics.Switch_each_misused_0_to_1, "=", ":"])]; + const node = findNodeToFix(sourceFile, span.start); + if (!node) + return void 0; + const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange37(t, sourceFile, node)); + return [createCodeFixAction(fixID2, changes, Diagnostics.Wrap_in_JSX_fragment, fixID2, Diagnostics.Wrap_all_unparented_JSX_in_JSX_fragment)]; }, - getAllCodeActions: (context) => codeFixAll(context, errorCodes35, (changes, diag2) => doChange23(changes, diag2.file, getProperty2(diag2.file, diag2.start))) + fixIds: [fixID2], + getAllCodeActions: (context) => codeFixAll(context, errorCodes56, (changes, diag2) => { + const node = findNodeToFix(context.sourceFile, diag2.start); + if (!node) + return void 0; + doChange37(changes, context.sourceFile, node); + }) }); } }); - // src/services/codefixes/fixExtendsInterfaceBecomesImplements.ts - function getNodes2(sourceFile, pos) { + // src/services/codefixes/convertToMappedObjectType.ts + function getInfo19(sourceFile, pos) { const token = getTokenAtPosition(sourceFile, pos); - const heritageClauses = getContainingClass(token).heritageClauses; - const extendsToken = heritageClauses[0].getFirstToken(); - return extendsToken.kind === 96 /* ExtendsKeyword */ ? { extendsToken, heritageClauses } : void 0; + const indexSignature = tryCast(token.parent.parent, isIndexSignatureDeclaration); + if (!indexSignature) + return void 0; + const container = isInterfaceDeclaration(indexSignature.parent) ? indexSignature.parent : tryCast(indexSignature.parent.parent, isTypeAliasDeclaration); + if (!container) + return void 0; + return { indexSignature, container }; } - function doChanges2(changes, sourceFile, extendsToken, heritageClauses) { - changes.replaceNode(sourceFile, extendsToken, factory.createToken(119 /* ImplementsKeyword */)); - if (heritageClauses.length === 2 && heritageClauses[0].token === 96 /* ExtendsKeyword */ && heritageClauses[1].token === 119 /* ImplementsKeyword */) { - const implementsToken = heritageClauses[1].getFirstToken(); - const implementsFullStart = implementsToken.getFullStart(); - changes.replaceRange(sourceFile, { pos: implementsFullStart, end: implementsFullStart }, factory.createToken(28 /* CommaToken */)); - const text = sourceFile.text; - let end = implementsToken.end; - while (end < text.length && isWhiteSpaceSingleLine(text.charCodeAt(end))) { - end++; - } - changes.deleteRange(sourceFile, { pos: implementsToken.getStart(), end }); - } + function createTypeAliasFromInterface(declaration, type) { + return factory.createTypeAliasDeclaration(declaration.modifiers, declaration.name, declaration.typeParameters, type); } - var fixId30, errorCodes36; - var init_fixExtendsInterfaceBecomesImplements = __esm({ - "src/services/codefixes/fixExtendsInterfaceBecomesImplements.ts"() { + function doChange38(changes, sourceFile, { indexSignature, container }) { + const members = isInterfaceDeclaration(container) ? container.members : container.type.members; + const otherMembers = members.filter((member) => !isIndexSignatureDeclaration(member)); + const parameter = first(indexSignature.parameters); + const mappedTypeParameter = factory.createTypeParameterDeclaration( + /*modifiers*/ + void 0, + cast(parameter.name, isIdentifier), + parameter.type + ); + const mappedIntersectionType = factory.createMappedTypeNode( + hasEffectiveReadonlyModifier(indexSignature) ? factory.createModifier(148 /* ReadonlyKeyword */) : void 0, + mappedTypeParameter, + /*nameType*/ + void 0, + indexSignature.questionToken, + indexSignature.type, + /*members*/ + void 0 + ); + const intersectionType = factory.createIntersectionTypeNode([ + ...getAllSuperTypeNodes(container), + mappedIntersectionType, + ...otherMembers.length ? [factory.createTypeLiteralNode(otherMembers)] : emptyArray + ]); + changes.replaceNode(sourceFile, container, createTypeAliasFromInterface(container, intersectionType)); + } + var fixId45, errorCodes57; + var init_convertToMappedObjectType = __esm({ + "src/services/codefixes/convertToMappedObjectType.ts"() { "use strict"; init_ts4(); init_ts_codefix(); - fixId30 = "extendsInterfaceBecomesImplements"; - errorCodes36 = [Diagnostics.Cannot_extend_an_interface_0_Did_you_mean_implements.code]; + fixId45 = "fixConvertToMappedObjectType"; + errorCodes57 = [Diagnostics.An_index_signature_parameter_type_cannot_be_a_literal_type_or_generic_type_Consider_using_a_mapped_object_type_instead.code]; registerCodeFix({ - errorCodes: errorCodes36, - getCodeActions(context) { - const { sourceFile } = context; - const nodes = getNodes2(sourceFile, context.span.start); - if (!nodes) + errorCodes: errorCodes57, + getCodeActions: function getCodeActionsToConvertToMappedTypeObject(context) { + const { sourceFile, span } = context; + const info = getInfo19(sourceFile, span.start); + if (!info) return void 0; - const { extendsToken, heritageClauses } = nodes; - const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChanges2(t, sourceFile, extendsToken, heritageClauses)); - return [createCodeFixAction(fixId30, changes, Diagnostics.Change_extends_to_implements, fixId30, Diagnostics.Change_all_extended_interfaces_to_implements)]; + const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange38(t, sourceFile, info)); + const name = idText(info.container.name); + return [createCodeFixAction(fixId45, changes, [Diagnostics.Convert_0_to_mapped_object_type, name], fixId45, [Diagnostics.Convert_0_to_mapped_object_type, name])]; }, - fixIds: [fixId30], - getAllCodeActions: (context) => codeFixAll(context, errorCodes36, (changes, diag2) => { - const nodes = getNodes2(diag2.file, diag2.start); - if (nodes) - doChanges2(changes, diag2.file, nodes.extendsToken, nodes.heritageClauses); + fixIds: [fixId45], + getAllCodeActions: (context) => codeFixAll(context, errorCodes57, (changes, diag2) => { + const info = getInfo19(diag2.file, diag2.start); + if (info) + doChange38(changes, diag2.file, info); }) }); } }); - // src/services/codefixes/fixForgottenThisPropertyAccess.ts - function getInfo12(sourceFile, pos, diagCode) { - const node = getTokenAtPosition(sourceFile, pos); - if (isIdentifier(node) || isPrivateIdentifier(node)) { - return { node, className: diagCode === didYouMeanStaticMemberCode ? getContainingClass(node).name.text : void 0 }; - } - } - function doChange24(changes, sourceFile, { node, className }) { - suppressLeadingAndTrailingTrivia(node); - changes.replaceNode(sourceFile, node, factory.createPropertyAccessExpression(className ? factory.createIdentifier(className) : factory.createThis(), node)); - } - var fixId31, didYouMeanStaticMemberCode, errorCodes37; - var init_fixForgottenThisPropertyAccess = __esm({ - "src/services/codefixes/fixForgottenThisPropertyAccess.ts"() { + // src/services/codefixes/removeAccidentalCallParentheses.ts + var fixId46, errorCodes58; + var init_removeAccidentalCallParentheses = __esm({ + "src/services/codefixes/removeAccidentalCallParentheses.ts"() { "use strict"; init_ts4(); init_ts_codefix(); - fixId31 = "forgottenThisPropertyAccess"; - didYouMeanStaticMemberCode = Diagnostics.Cannot_find_name_0_Did_you_mean_the_static_member_1_0.code; - errorCodes37 = [ - Diagnostics.Cannot_find_name_0_Did_you_mean_the_instance_member_this_0.code, - Diagnostics.Private_identifiers_are_only_allowed_in_class_bodies_and_may_only_be_used_as_part_of_a_class_member_declaration_property_access_or_on_the_left_hand_side_of_an_in_expression.code, - didYouMeanStaticMemberCode + fixId46 = "removeAccidentalCallParentheses"; + errorCodes58 = [ + Diagnostics.This_expression_is_not_callable_because_it_is_a_get_accessor_Did_you_mean_to_use_it_without.code ]; registerCodeFix({ - errorCodes: errorCodes37, + errorCodes: errorCodes58, getCodeActions(context) { - const { sourceFile } = context; - const info = getInfo12(sourceFile, context.span.start, context.errorCode); - if (!info) { + const callExpression = findAncestor(getTokenAtPosition(context.sourceFile, context.span.start), isCallExpression); + if (!callExpression) { return void 0; } - const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange24(t, sourceFile, info)); - return [createCodeFixAction(fixId31, changes, [Diagnostics.Add_0_to_unresolved_variable, info.className || "this"], fixId31, Diagnostics.Add_qualifier_to_all_unresolved_variables_matching_a_member_name)]; + const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => { + t.deleteRange(context.sourceFile, { pos: callExpression.expression.end, end: callExpression.end }); + }); + return [createCodeFixActionWithoutFixAll(fixId46, changes, Diagnostics.Remove_parentheses)]; }, - fixIds: [fixId31], - getAllCodeActions: (context) => codeFixAll(context, errorCodes37, (changes, diag2) => { - const info = getInfo12(diag2.file, diag2.start, diag2.code); - if (info) - doChange24(changes, context.sourceFile, info); - }) + fixIds: [fixId46] }); } }); - // src/services/codefixes/fixInvalidJsxCharacters.ts - function isValidCharacter(character) { - return hasProperty(htmlEntity, character); - } - function doChange25(changes, preferences, sourceFile, start, useHtmlEntity) { - const character = sourceFile.getText()[start]; - if (!isValidCharacter(character)) { + // src/services/codefixes/removeUnnecessaryAwait.ts + function makeChange10(changeTracker, sourceFile, span) { + const awaitKeyword = tryCast(getTokenAtPosition(sourceFile, span.start), (node) => node.kind === 135 /* AwaitKeyword */); + const awaitExpression = awaitKeyword && tryCast(awaitKeyword.parent, isAwaitExpression); + if (!awaitExpression) { return; } - const replacement = useHtmlEntity ? htmlEntity[character] : `{${quote(sourceFile, preferences, character)}}`; - changes.replaceRangeWithText(sourceFile, { pos: start, end: start + 1 }, replacement); + let expressionToReplace = awaitExpression; + const hasSurroundingParens = isParenthesizedExpression(awaitExpression.parent); + if (hasSurroundingParens) { + const leftMostExpression = getLeftmostExpression( + awaitExpression.expression, + /*stopAtCallExpressions*/ + false + ); + if (isIdentifier(leftMostExpression)) { + const precedingToken = findPrecedingToken(awaitExpression.parent.pos, sourceFile); + if (precedingToken && precedingToken.kind !== 105 /* NewKeyword */) { + expressionToReplace = awaitExpression.parent; + } + } + } + changeTracker.replaceNode(sourceFile, expressionToReplace, awaitExpression.expression); } - var fixIdExpression, fixIdHtmlEntity, errorCodes38, htmlEntity; - var init_fixInvalidJsxCharacters = __esm({ - "src/services/codefixes/fixInvalidJsxCharacters.ts"() { + var fixId47, errorCodes59; + var init_removeUnnecessaryAwait = __esm({ + "src/services/codefixes/removeUnnecessaryAwait.ts"() { "use strict"; init_ts4(); init_ts_codefix(); - fixIdExpression = "fixInvalidJsxCharacters_expression"; - fixIdHtmlEntity = "fixInvalidJsxCharacters_htmlEntity"; - errorCodes38 = [ - Diagnostics.Unexpected_token_Did_you_mean_or_gt.code, - Diagnostics.Unexpected_token_Did_you_mean_or_rbrace.code + fixId47 = "removeUnnecessaryAwait"; + errorCodes59 = [ + Diagnostics.await_has_no_effect_on_the_type_of_this_expression.code ]; registerCodeFix({ - errorCodes: errorCodes38, - fixIds: [fixIdExpression, fixIdHtmlEntity], - getCodeActions(context) { - const { sourceFile, preferences, span } = context; - const changeToExpression = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange25( - t, - preferences, - sourceFile, - span.start, - /*useHtmlEntity*/ - false - )); - const changeToHtmlEntity = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange25( - t, - preferences, - sourceFile, - span.start, - /*useHtmlEntity*/ - true - )); - return [ - createCodeFixAction(fixIdExpression, changeToExpression, Diagnostics.Wrap_invalid_character_in_an_expression_container, fixIdExpression, Diagnostics.Wrap_all_invalid_characters_in_an_expression_container), - createCodeFixAction(fixIdHtmlEntity, changeToHtmlEntity, Diagnostics.Convert_invalid_character_to_its_html_entity_code, fixIdHtmlEntity, Diagnostics.Convert_all_invalid_characters_to_HTML_entity_code) - ]; + errorCodes: errorCodes59, + getCodeActions: function getCodeActionsToRemoveUnnecessaryAwait(context) { + const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => makeChange10(t, context.sourceFile, context.span)); + if (changes.length > 0) { + return [createCodeFixAction(fixId47, changes, Diagnostics.Remove_unnecessary_await, fixId47, Diagnostics.Remove_all_unnecessary_uses_of_await)]; + } }, - getAllCodeActions(context) { - return codeFixAll(context, errorCodes38, (changes, diagnostic) => doChange25(changes, context.preferences, diagnostic.file, diagnostic.start, context.fixId === fixIdHtmlEntity)); + fixIds: [fixId47], + getAllCodeActions: (context) => { + return codeFixAll(context, errorCodes59, (changes, diag2) => makeChange10(changes, diag2.file, diag2)); } }); - htmlEntity = { - ">": ">", - "}": "}" - }; } }); - // src/services/codefixes/fixUnmatchedParameter.ts - function getDeleteAction(context, { name, jsDocHost, jsDocParameterTag }) { - const changes = ts_textChanges_exports.ChangeTracker.with(context, (changeTracker) => changeTracker.filterJSDocTags(context.sourceFile, jsDocHost, (t) => t !== jsDocParameterTag)); - return createCodeFixAction( - deleteUnmatchedParameter, - changes, - [Diagnostics.Delete_unused_param_tag_0, name.getText(context.sourceFile)], - deleteUnmatchedParameter, - Diagnostics.Delete_all_unused_param_tags - ); + // src/services/codefixes/splitTypeOnlyImport.ts + function getImportDeclaration2(sourceFile, span) { + return findAncestor(getTokenAtPosition(sourceFile, span.start), isImportDeclaration); } - function getRenameAction(context, { name, jsDocHost, signature, jsDocParameterTag }) { - if (!length(signature.parameters)) - return void 0; - const sourceFile = context.sourceFile; - const tags = getJSDocTags(signature); - const names = /* @__PURE__ */ new Set(); - for (const tag of tags) { - if (isJSDocParameterTag(tag) && isIdentifier(tag.name)) { - names.add(tag.name.escapedText); - } + function splitTypeOnlyImport(changes, importDeclaration, context) { + if (!importDeclaration) { + return; } - const parameterName = firstDefined(signature.parameters, (p) => isIdentifier(p.name) && !names.has(p.name.escapedText) ? p.name.getText(sourceFile) : void 0); - if (parameterName === void 0) - return void 0; - const newJSDocParameterTag = factory.updateJSDocParameterTag( - jsDocParameterTag, - jsDocParameterTag.tagName, - factory.createIdentifier(parameterName), - jsDocParameterTag.isBracketed, - jsDocParameterTag.typeExpression, - jsDocParameterTag.isNameFirst, - jsDocParameterTag.comment + const importClause = Debug.checkDefined(importDeclaration.importClause); + changes.replaceNode( + context.sourceFile, + importDeclaration, + factory.updateImportDeclaration( + importDeclaration, + importDeclaration.modifiers, + factory.updateImportClause( + importClause, + importClause.isTypeOnly, + importClause.name, + /*namedBindings*/ + void 0 + ), + importDeclaration.moduleSpecifier, + importDeclaration.attributes + ) + ); + changes.insertNodeAfter( + context.sourceFile, + importDeclaration, + factory.createImportDeclaration( + /*modifiers*/ + void 0, + factory.updateImportClause( + importClause, + importClause.isTypeOnly, + /*name*/ + void 0, + importClause.namedBindings + ), + importDeclaration.moduleSpecifier, + importDeclaration.attributes + ) ); - const changes = ts_textChanges_exports.ChangeTracker.with(context, (changeTracker) => changeTracker.replaceJSDocComment(sourceFile, jsDocHost, map(tags, (t) => t === jsDocParameterTag ? newJSDocParameterTag : t))); - return createCodeFixActionWithoutFixAll(renameUnmatchedParameter, changes, [Diagnostics.Rename_param_tag_name_0_to_1, name.getText(sourceFile), parameterName]); } - function getInfo13(sourceFile, pos) { - const token = getTokenAtPosition(sourceFile, pos); - if (token.parent && isJSDocParameterTag(token.parent) && isIdentifier(token.parent.name)) { - const jsDocParameterTag = token.parent; - const jsDocHost = getJSDocHost(jsDocParameterTag); - const signature = getHostSignatureFromJSDoc(jsDocParameterTag); - if (jsDocHost && signature) { - return { jsDocHost, signature, name: token.parent.name, jsDocParameterTag }; - } + var errorCodes60, fixId48; + var init_splitTypeOnlyImport = __esm({ + "src/services/codefixes/splitTypeOnlyImport.ts"() { + "use strict"; + init_ts4(); + init_ts_codefix(); + errorCodes60 = [Diagnostics.A_type_only_import_can_specify_a_default_import_or_named_bindings_but_not_both.code]; + fixId48 = "splitTypeOnlyImport"; + registerCodeFix({ + errorCodes: errorCodes60, + fixIds: [fixId48], + getCodeActions: function getCodeActionsToSplitTypeOnlyImport(context) { + const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => { + return splitTypeOnlyImport(t, getImportDeclaration2(context.sourceFile, context.span), context); + }); + if (changes.length) { + return [createCodeFixAction(fixId48, changes, Diagnostics.Split_into_two_separate_import_declarations, fixId48, Diagnostics.Split_all_invalid_type_only_imports)]; + } + }, + getAllCodeActions: (context) => codeFixAll(context, errorCodes60, (changes, error2) => { + splitTypeOnlyImport(changes, getImportDeclaration2(context.sourceFile, error2), context); + }) + }); } - return void 0; + }); + + // src/services/codefixes/convertConstToLet.ts + function getInfo20(sourceFile, pos, program) { + var _a; + const checker = program.getTypeChecker(); + const symbol = checker.getSymbolAtLocation(getTokenAtPosition(sourceFile, pos)); + if (symbol === void 0) + return; + const declaration = tryCast((_a = symbol == null ? void 0 : symbol.valueDeclaration) == null ? void 0 : _a.parent, isVariableDeclarationList); + if (declaration === void 0) + return; + const constToken = findChildOfKind(declaration, 87 /* ConstKeyword */, sourceFile); + if (constToken === void 0) + return; + return { symbol, token: constToken }; } - var deleteUnmatchedParameter, renameUnmatchedParameter, errorCodes39; - var init_fixUnmatchedParameter = __esm({ - "src/services/codefixes/fixUnmatchedParameter.ts"() { + function doChange39(changes, sourceFile, token) { + changes.replaceNode(sourceFile, token, factory.createToken(121 /* LetKeyword */)); + } + var fixId49, errorCodes61; + var init_convertConstToLet = __esm({ + "src/services/codefixes/convertConstToLet.ts"() { "use strict"; init_ts4(); init_ts_codefix(); - deleteUnmatchedParameter = "deleteUnmatchedParameter"; - renameUnmatchedParameter = "renameUnmatchedParameter"; - errorCodes39 = [ - Diagnostics.JSDoc_param_tag_has_name_0_but_there_is_no_parameter_with_that_name.code - ]; + fixId49 = "fixConvertConstToLet"; + errorCodes61 = [Diagnostics.Cannot_assign_to_0_because_it_is_a_constant.code]; registerCodeFix({ - fixIds: [deleteUnmatchedParameter, renameUnmatchedParameter], - errorCodes: errorCodes39, - getCodeActions: function getCodeActionsToFixUnmatchedParameter(context) { - const { sourceFile, span } = context; - const actions2 = []; - const info = getInfo13(sourceFile, span.start); - if (info) { - append(actions2, getDeleteAction(context, info)); - append(actions2, getRenameAction(context, info)); - return actions2; - } - return void 0; + errorCodes: errorCodes61, + getCodeActions: function getCodeActionsToConvertConstToLet(context) { + const { sourceFile, span, program } = context; + const info = getInfo20(sourceFile, span.start, program); + if (info === void 0) + return; + const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange39(t, sourceFile, info.token)); + return [createCodeFixActionMaybeFixAll(fixId49, changes, Diagnostics.Convert_const_to_let, fixId49, Diagnostics.Convert_all_const_to_let)]; }, - getAllCodeActions: function getAllCodeActionsToFixUnmatchedParameter(context) { - const tagsToSignature = /* @__PURE__ */ new Map(); + getAllCodeActions: (context) => { + const { program } = context; + const seen = /* @__PURE__ */ new Map(); return createCombinedCodeActions(ts_textChanges_exports.ChangeTracker.with(context, (changes) => { - eachDiagnostic(context, errorCodes39, ({ file, start }) => { - const info = getInfo13(file, start); + eachDiagnostic(context, errorCodes61, (diag2) => { + const info = getInfo20(diag2.file, diag2.start, program); if (info) { - tagsToSignature.set(info.signature, append(tagsToSignature.get(info.signature), info.jsDocParameterTag)); - } - }); - tagsToSignature.forEach((tags, signature) => { - if (context.fixId === deleteUnmatchedParameter) { - const tagsSet = new Set(tags); - changes.filterJSDocTags(signature.getSourceFile(), signature, (t) => !tagsSet.has(t)); + if (addToSeen(seen, getSymbolId(info.symbol))) { + return doChange39(changes, diag2.file, info.token); + } } + return void 0; }); })); - } + }, + fixIds: [fixId49] + }); + } + }); + + // src/services/codefixes/fixExpectedComma.ts + function getInfo21(sourceFile, pos, _) { + const node = getTokenAtPosition(sourceFile, pos); + return node.kind === 27 /* SemicolonToken */ && node.parent && (isObjectLiteralExpression(node.parent) || isArrayLiteralExpression(node.parent)) ? { node } : void 0; + } + function doChange40(changes, sourceFile, { node }) { + const newNode = factory.createToken(28 /* CommaToken */); + changes.replaceNode(sourceFile, node, newNode); + } + var fixId50, expectedErrorCode, errorCodes62; + var init_fixExpectedComma = __esm({ + "src/services/codefixes/fixExpectedComma.ts"() { + "use strict"; + init_ts4(); + init_ts_codefix(); + fixId50 = "fixExpectedComma"; + expectedErrorCode = Diagnostics._0_expected.code; + errorCodes62 = [expectedErrorCode]; + registerCodeFix({ + errorCodes: errorCodes62, + getCodeActions(context) { + const { sourceFile } = context; + const info = getInfo21(sourceFile, context.span.start, context.errorCode); + if (!info) + return void 0; + const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange40(t, sourceFile, info)); + return [createCodeFixAction( + fixId50, + changes, + [Diagnostics.Change_0_to_1, ";", ","], + fixId50, + [Diagnostics.Change_0_to_1, ";", ","] + )]; + }, + fixIds: [fixId50], + getAllCodeActions: (context) => codeFixAll(context, errorCodes62, (changes, diag2) => { + const info = getInfo21(diag2.file, diag2.start, diag2.code); + if (info) + doChange40(changes, context.sourceFile, info); + }) }); } }); - // src/services/codefixes/fixUnreferenceableDecoratorMetadata.ts - function getImportDeclaration(sourceFile, program, start) { - const identifier = tryCast(getTokenAtPosition(sourceFile, start), isIdentifier); - if (!identifier || identifier.parent.kind !== 182 /* TypeReference */) + // src/services/codefixes/fixAddVoidToPromise.ts + function makeChange11(changes, sourceFile, span, program, seen) { + const node = getTokenAtPosition(sourceFile, span.start); + if (!isIdentifier(node) || !isCallExpression(node.parent) || node.parent.expression !== node || node.parent.arguments.length !== 0) return; const checker = program.getTypeChecker(); - const symbol = checker.getSymbolAtLocation(identifier); - return find((symbol == null ? void 0 : symbol.declarations) || emptyArray, or(isImportClause, isImportSpecifier, isImportEqualsDeclaration)); - } - function doTypeOnlyImportChange(changes, sourceFile, importDeclaration, program) { - if (importDeclaration.kind === 270 /* ImportEqualsDeclaration */) { - changes.insertModifierBefore(sourceFile, 156 /* TypeKeyword */, importDeclaration.name); - return; - } - const importClause = importDeclaration.kind === 272 /* ImportClause */ ? importDeclaration : importDeclaration.parent.parent; - if (importClause.name && importClause.namedBindings) { + const symbol = checker.getSymbolAtLocation(node); + const decl = symbol == null ? void 0 : symbol.valueDeclaration; + if (!decl || !isParameter(decl) || !isNewExpression(decl.parent.parent)) return; - } - const checker = program.getTypeChecker(); - const importsValue = !!forEachImportClauseDeclaration(importClause, (decl) => { - if (skipAlias(decl.symbol, checker).flags & 111551 /* Value */) - return true; - }); - if (importsValue) { + if (seen == null ? void 0 : seen.has(decl)) return; + seen == null ? void 0 : seen.add(decl); + const typeArguments = getEffectiveTypeArguments(decl.parent.parent); + if (some(typeArguments)) { + const typeArgument = typeArguments[0]; + const needsParens = !isUnionTypeNode(typeArgument) && !isParenthesizedTypeNode(typeArgument) && isParenthesizedTypeNode(factory.createUnionTypeNode([typeArgument, factory.createKeywordTypeNode(116 /* VoidKeyword */)]).types[0]); + if (needsParens) { + changes.insertText(sourceFile, typeArgument.pos, "("); + } + changes.insertText(sourceFile, typeArgument.end, needsParens ? ") | void" : " | void"); + } else { + const signature = checker.getResolvedSignature(node.parent); + const parameter = signature == null ? void 0 : signature.parameters[0]; + const parameterType = parameter && checker.getTypeOfSymbolAtLocation(parameter, decl.parent.parent); + if (isInJSFile(decl)) { + if (!parameterType || parameterType.flags & 3 /* AnyOrUnknown */) { + changes.insertText(sourceFile, decl.parent.parent.end, `)`); + changes.insertText(sourceFile, skipTrivia(sourceFile.text, decl.parent.parent.pos), `/** @type {Promise} */(`); + } + } else { + if (!parameterType || parameterType.flags & 2 /* Unknown */) { + changes.insertText(sourceFile, decl.parent.parent.expression.end, ""); + } + } } - changes.insertModifierBefore(sourceFile, 156 /* TypeKeyword */, importClause); } - function doNamespaceImportChange(changes, sourceFile, importDeclaration, program) { - ts_refactor_exports.doChangeNamedToNamespaceOrDefault(sourceFile, program, changes, importDeclaration.parent); + function getEffectiveTypeArguments(node) { + var _a; + if (isInJSFile(node)) { + if (isParenthesizedExpression(node.parent)) { + const jsDocType = (_a = getJSDocTypeTag(node.parent)) == null ? void 0 : _a.typeExpression.type; + if (jsDocType && isTypeReferenceNode(jsDocType) && isIdentifier(jsDocType.typeName) && idText(jsDocType.typeName) === "Promise") { + return jsDocType.typeArguments; + } + } + } else { + return node.typeArguments; + } } - var fixId32, errorCodes40; - var init_fixUnreferenceableDecoratorMetadata = __esm({ - "src/services/codefixes/fixUnreferenceableDecoratorMetadata.ts"() { + var fixName7, fixId51, errorCodes63; + var init_fixAddVoidToPromise = __esm({ + "src/services/codefixes/fixAddVoidToPromise.ts"() { "use strict"; init_ts4(); init_ts_codefix(); - fixId32 = "fixUnreferenceableDecoratorMetadata"; - errorCodes40 = [Diagnostics.A_type_referenced_in_a_decorated_signature_must_be_imported_with_import_type_or_a_namespace_import_when_isolatedModules_and_emitDecoratorMetadata_are_enabled.code]; + fixName7 = "addVoidToPromise"; + fixId51 = "addVoidToPromise"; + errorCodes63 = [ + Diagnostics.Expected_1_argument_but_got_0_new_Promise_needs_a_JSDoc_hint_to_produce_a_resolve_that_can_be_called_without_arguments.code, + Diagnostics.Expected_0_arguments_but_got_1_Did_you_forget_to_include_void_in_your_type_argument_to_Promise.code + ]; registerCodeFix({ - errorCodes: errorCodes40, - getCodeActions: (context) => { - const importDeclaration = getImportDeclaration(context.sourceFile, context.program, context.span.start); - if (!importDeclaration) - return; - const namespaceChanges = ts_textChanges_exports.ChangeTracker.with(context, (t) => importDeclaration.kind === 275 /* ImportSpecifier */ && doNamespaceImportChange(t, context.sourceFile, importDeclaration, context.program)); - const typeOnlyChanges = ts_textChanges_exports.ChangeTracker.with(context, (t) => doTypeOnlyImportChange(t, context.sourceFile, importDeclaration, context.program)); - let actions2; - if (namespaceChanges.length) { - actions2 = append(actions2, createCodeFixActionWithoutFixAll(fixId32, namespaceChanges, Diagnostics.Convert_named_imports_to_namespace_import)); - } - if (typeOnlyChanges.length) { - actions2 = append(actions2, createCodeFixActionWithoutFixAll(fixId32, typeOnlyChanges, Diagnostics.Convert_to_type_only_import)); + errorCodes: errorCodes63, + fixIds: [fixId51], + getCodeActions(context) { + const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => makeChange11(t, context.sourceFile, context.span, context.program)); + if (changes.length > 0) { + return [createCodeFixAction(fixName7, changes, Diagnostics.Add_void_to_Promise_resolved_without_a_value, fixId51, Diagnostics.Add_void_to_all_Promises_resolved_without_a_value)]; } - return actions2; }, - fixIds: [fixId32] + getAllCodeActions(context) { + return codeFixAll(context, errorCodes63, (changes, diag2) => makeChange11(changes, diag2.file, diag2, context.program, /* @__PURE__ */ new Set())); + } }); } }); - // src/services/codefixes/fixUnusedIdentifier.ts - function changeInferToUnknown(changes, sourceFile, token) { - changes.replaceNode(sourceFile, token.parent, factory.createKeywordTypeNode(159 /* UnknownKeyword */)); + // src/services/_namespaces/ts.codefix.ts + var ts_codefix_exports = {}; + __export(ts_codefix_exports, { + PreserveOptionalFlags: () => PreserveOptionalFlags, + addNewNodeForMemberSymbol: () => addNewNodeForMemberSymbol, + codeFixAll: () => codeFixAll, + createCodeFixAction: () => createCodeFixAction, + createCodeFixActionMaybeFixAll: () => createCodeFixActionMaybeFixAll, + createCodeFixActionWithoutFixAll: () => createCodeFixActionWithoutFixAll, + createCombinedCodeActions: () => createCombinedCodeActions, + createFileTextChanges: () => createFileTextChanges, + createImportAdder: () => createImportAdder, + createImportSpecifierResolver: () => createImportSpecifierResolver, + createJsonPropertyAssignment: () => createJsonPropertyAssignment, + createMissingMemberNodes: () => createMissingMemberNodes, + createSignatureDeclarationFromCallExpression: () => createSignatureDeclarationFromCallExpression, + createSignatureDeclarationFromSignature: () => createSignatureDeclarationFromSignature, + createStubbedBody: () => createStubbedBody, + eachDiagnostic: () => eachDiagnostic, + findAncestorMatchingSpan: () => findAncestorMatchingSpan, + findJsonProperty: () => findJsonProperty, + generateAccessorFromProperty: () => generateAccessorFromProperty, + getAccessorConvertiblePropertyAtPosition: () => getAccessorConvertiblePropertyAtPosition, + getAllFixes: () => getAllFixes, + getAllSupers: () => getAllSupers, + getArgumentTypesAndTypeParameters: () => getArgumentTypesAndTypeParameters, + getFixes: () => getFixes, + getImportCompletionAction: () => getImportCompletionAction, + getImportKind: () => getImportKind, + getJSDocTypedefNodes: () => getJSDocTypedefNodes, + getNoopSymbolTrackerWithResolver: () => getNoopSymbolTrackerWithResolver, + getPromoteTypeOnlyCompletionAction: () => getPromoteTypeOnlyCompletionAction, + getSupportedErrorCodes: () => getSupportedErrorCodes, + importFixName: () => importFixName, + importSymbols: () => importSymbols, + moduleSpecifierToValidIdentifier: () => moduleSpecifierToValidIdentifier, + moduleSymbolToValidIdentifier: () => moduleSymbolToValidIdentifier, + parameterShouldGetTypeFromJSDoc: () => parameterShouldGetTypeFromJSDoc, + registerCodeFix: () => registerCodeFix, + setJsonCompilerOptionValue: () => setJsonCompilerOptionValue, + setJsonCompilerOptionValues: () => setJsonCompilerOptionValues, + tryGetAutoImportableReferenceFromTypeNode: () => tryGetAutoImportableReferenceFromTypeNode, + typeToAutoImportableTypeNode: () => typeToAutoImportableTypeNode + }); + var init_ts_codefix = __esm({ + "src/services/_namespaces/ts.codefix.ts"() { + "use strict"; + init_codeFixProvider(); + init_addConvertToUnknownForNonOverlappingTypes(); + init_addEmptyExportDeclaration(); + init_addMissingAsync(); + init_addMissingAwait(); + init_addMissingConst(); + init_addMissingDeclareProperty(); + init_addMissingInvocationForDecorator(); + init_addNameToNamelessParameter(); + init_addOptionalPropertyUndefined(); + init_annotateWithTypeFromJSDoc(); + init_convertFunctionToEs6Class(); + init_convertToAsyncFunction(); + init_convertToEsModule(); + init_correctQualifiedNameToIndexedAccessType(); + init_convertToTypeOnlyExport(); + init_convertToTypeOnlyImport(); + init_convertTypedefToType(); + init_convertLiteralTypeToMappedType(); + init_fixClassIncorrectlyImplementsInterface(); + init_importFixes(); + init_fixAddMissingConstraint(); + init_fixOverrideModifier(); + init_fixNoPropertyAccessFromIndexSignature(); + init_fixImplicitThis(); + init_fixImportNonExportedMember(); + init_fixIncorrectNamedTupleSyntax(); + init_fixSpelling(); + init_returnValueCorrect(); + init_fixAddMissingMember(); + init_fixAddMissingNewOperator(); + init_fixCannotFindModule(); + init_fixClassDoesntImplementInheritedAbstractMember(); + init_fixClassSuperMustPrecedeThisAccess(); + init_fixConstructorForDerivedNeedSuperCall(); + init_fixEnableJsxFlag(); + init_fixNaNEquality(); + init_fixModuleAndTargetOptions(); + init_fixPropertyAssignment(); + init_fixExtendsInterfaceBecomesImplements(); + init_fixForgottenThisPropertyAccess(); + init_fixInvalidJsxCharacters(); + init_fixUnmatchedParameter(); + init_fixUnreferenceableDecoratorMetadata(); + init_fixUnusedIdentifier(); + init_fixUnreachableCode(); + init_fixUnusedLabel(); + init_fixJSDocTypes(); + init_fixMissingCallParentheses(); + init_fixAwaitInSyncFunction(); + init_fixPropertyOverrideAccessor(); + init_inferFromUsage(); + init_fixReturnTypeInAsyncFunction(); + init_disableJsDiagnostics(); + init_helpers2(); + init_generateAccessors(); + init_fixInvalidImportSyntax(); + init_fixStrictClassInitialization(); + init_requireInTs(); + init_useDefaultImport(); + init_useBigintLiteral(); + init_fixAddModuleReferTypeMissingTypeof(); + init_wrapJsxInFragment(); + init_convertToMappedObjectType(); + init_removeAccidentalCallParentheses(); + init_removeUnnecessaryAwait(); + init_splitTypeOnlyImport(); + init_convertConstToLet(); + init_fixExpectedComma(); + init_fixAddVoidToPromise(); + } + }); + + // src/services/completions.ts + function originIsThisType(origin) { + return !!(origin.kind & 1 /* ThisType */); } - function createDeleteFix(changes, diag2) { - return createCodeFixAction(fixName3, changes, diag2, fixIdDelete, Diagnostics.Delete_all_unused_declarations); + function originIsSymbolMember(origin) { + return !!(origin.kind & 2 /* SymbolMember */); } - function deleteTypeParameters(changes, sourceFile, token) { - changes.delete(sourceFile, Debug.checkDefined(cast(token.parent, isDeclarationWithTypeParameterChildren).typeParameters, "The type parameter to delete should exist")); + function originIsExport(origin) { + return !!(origin && origin.kind & 4 /* Export */); } - function isImport(token) { - return token.kind === 102 /* ImportKeyword */ || token.kind === 80 /* Identifier */ && (token.parent.kind === 275 /* ImportSpecifier */ || token.parent.kind === 272 /* ImportClause */); + function originIsResolvedExport(origin) { + return !!(origin && origin.kind === 32 /* ResolvedExport */); } - function tryGetFullImport(token) { - return token.kind === 102 /* ImportKeyword */ ? tryCast(token.parent, isImportDeclaration) : void 0; + function originIncludesSymbolName(origin) { + return originIsExport(origin) || originIsResolvedExport(origin) || originIsComputedPropertyName(origin); } - function canDeleteEntireVariableStatement(sourceFile, token) { - return isVariableDeclarationList(token.parent) && first(token.parent.getChildren(sourceFile)) === token; + function originIsPackageJsonImport(origin) { + return (originIsExport(origin) || originIsResolvedExport(origin)) && !!origin.isFromPackageJson; } - function deleteEntireVariableStatement(changes, sourceFile, node) { - changes.delete(sourceFile, node.parent.kind === 242 /* VariableStatement */ ? node.parent : node); + function originIsPromise(origin) { + return !!(origin.kind & 8 /* Promise */); } - function deleteDestructuringElements(changes, sourceFile, node) { - forEach(node.elements, (n) => changes.delete(sourceFile, n)); + function originIsNullableMember(origin) { + return !!(origin.kind & 16 /* Nullable */); } - function deleteDestructuring(context, changes, sourceFile, { parent: parent2 }) { - if (isVariableDeclaration(parent2) && parent2.initializer && isCallLikeExpression(parent2.initializer)) { - if (isVariableDeclarationList(parent2.parent) && length(parent2.parent.declarations) > 1) { - const varStatement = parent2.parent.parent; - const pos = varStatement.getStart(sourceFile); - const end = varStatement.end; - changes.delete(sourceFile, parent2); - changes.insertNodeAt(sourceFile, end, parent2.initializer, { - prefix: getNewLineOrDefaultFromHost(context.host, context.formatContext.options) + sourceFile.text.slice(getPrecedingNonSpaceCharacterPosition(sourceFile.text, pos - 1), pos), - suffix: probablyUsesSemicolons(sourceFile) ? ";" : "" - }); - } else { - changes.replaceNode(sourceFile, parent2.parent, parent2.initializer); + function originIsTypeOnlyAlias(origin) { + return !!(origin && origin.kind & 64 /* TypeOnlyAlias */); + } + function originIsObjectLiteralMethod(origin) { + return !!(origin && origin.kind & 128 /* ObjectLiteralMethod */); + } + function originIsIgnore(origin) { + return !!(origin && origin.kind & 256 /* Ignore */); + } + function originIsComputedPropertyName(origin) { + return !!(origin && origin.kind & 512 /* ComputedPropertyName */); + } + function resolvingModuleSpecifiers(logPrefix, host, resolver, program, position, preferences, isForImportStatementCompletion, isValidTypeOnlyUseSite, cb) { + var _a, _b, _c; + const start = timestamp(); + const needsFullResolution = isForImportStatementCompletion || moduleResolutionSupportsPackageJsonExportsAndImports(getEmitModuleResolutionKind(program.getCompilerOptions())); + let skippedAny = false; + let ambientCount = 0; + let resolvedCount = 0; + let resolvedFromCacheCount = 0; + let cacheAttemptCount = 0; + const result = cb({ + tryResolve, + skippedAny: () => skippedAny, + resolvedAny: () => resolvedCount > 0, + resolvedBeyondLimit: () => resolvedCount > moduleSpecifierResolutionLimit + }); + const hitRateMessage = cacheAttemptCount ? ` (${(resolvedFromCacheCount / cacheAttemptCount * 100).toFixed(1)}% hit rate)` : ""; + (_a = host.log) == null ? void 0 : _a.call(host, `${logPrefix}: resolved ${resolvedCount} module specifiers, plus ${ambientCount} ambient and ${resolvedFromCacheCount} from cache${hitRateMessage}`); + (_b = host.log) == null ? void 0 : _b.call(host, `${logPrefix}: response is ${skippedAny ? "incomplete" : "complete"}`); + (_c = host.log) == null ? void 0 : _c.call(host, `${logPrefix}: ${timestamp() - start}`); + return result; + function tryResolve(exportInfo, isFromAmbientModule) { + if (isFromAmbientModule) { + const result3 = resolver.getModuleSpecifierForBestExportInfo(exportInfo, position, isValidTypeOnlyUseSite); + if (result3) { + ambientCount++; + } + return result3 || "failed"; } - } else { - changes.delete(sourceFile, parent2); + const shouldResolveModuleSpecifier = needsFullResolution || preferences.allowIncompleteCompletions && resolvedCount < moduleSpecifierResolutionLimit; + const shouldGetModuleSpecifierFromCache = !shouldResolveModuleSpecifier && preferences.allowIncompleteCompletions && cacheAttemptCount < moduleSpecifierResolutionCacheAttemptLimit; + const result2 = shouldResolveModuleSpecifier || shouldGetModuleSpecifierFromCache ? resolver.getModuleSpecifierForBestExportInfo(exportInfo, position, isValidTypeOnlyUseSite, shouldGetModuleSpecifierFromCache) : void 0; + if (!shouldResolveModuleSpecifier && !shouldGetModuleSpecifierFromCache || shouldGetModuleSpecifierFromCache && !result2) { + skippedAny = true; + } + resolvedCount += (result2 == null ? void 0 : result2.computedWithoutCacheCount) || 0; + resolvedFromCacheCount += exportInfo.length - ((result2 == null ? void 0 : result2.computedWithoutCacheCount) || 0); + if (shouldGetModuleSpecifierFromCache) { + cacheAttemptCount++; + } + return result2 || (needsFullResolution ? "failed" : "skipped"); } } - function tryPrefixDeclaration(changes, errorCode, sourceFile, token) { - if (errorCode === Diagnostics.Property_0_is_declared_but_its_value_is_never_read.code) - return; - if (token.kind === 140 /* InferKeyword */) { - token = cast(token.parent, isInferTypeNode).typeParameter.name; + function getCompletionsAtPosition(host, program, log, sourceFile, position, preferences, triggerCharacter, completionKind, cancellationToken, formatContext, includeSymbol = false) { + var _a; + const { previousToken } = getRelevantTokens(position, sourceFile); + if (triggerCharacter && !isInString(sourceFile, position, previousToken) && !isValidTrigger(sourceFile, triggerCharacter, previousToken, position)) { + return void 0; } - if (isIdentifier(token) && canPrefix(token)) { - changes.replaceNode(sourceFile, token, factory.createIdentifier(`_${token.text}`)); - if (isParameter(token.parent)) { - getJSDocParameterTags(token.parent).forEach((tag) => { - if (isIdentifier(tag.name)) { - changes.replaceNode(sourceFile, tag.name, factory.createIdentifier(`_${tag.name.text}`)); - } - }); + if (triggerCharacter === " ") { + if (preferences.includeCompletionsForImportStatements && preferences.includeCompletionsWithInsertText) { + return { isGlobalCompletion: true, isMemberCompletion: false, isNewIdentifierLocation: true, isIncomplete: true, entries: [] }; } + return void 0; } - } - function canPrefix(token) { - switch (token.parent.kind) { - case 168 /* Parameter */: - case 167 /* TypeParameter */: - return true; - case 259 /* VariableDeclaration */: { - const varDecl = token.parent; - switch (varDecl.parent.parent.kind) { - case 249 /* ForOfStatement */: - case 248 /* ForInStatement */: - return true; - } + const compilerOptions = program.getCompilerOptions(); + const checker = program.getTypeChecker(); + const incompleteCompletionsCache = preferences.allowIncompleteCompletions ? (_a = host.getIncompleteCompletionsCache) == null ? void 0 : _a.call(host) : void 0; + if (incompleteCompletionsCache && completionKind === 3 /* TriggerForIncompleteCompletions */ && previousToken && isIdentifier(previousToken)) { + const incompleteContinuation = continuePreviousIncompleteResponse(incompleteCompletionsCache, sourceFile, previousToken, program, host, preferences, cancellationToken, position); + if (incompleteContinuation) { + return incompleteContinuation; } + } else { + incompleteCompletionsCache == null ? void 0 : incompleteCompletionsCache.clear(); } - return false; - } - function tryDeleteDeclaration(sourceFile, token, changes, checker, sourceFiles, program, cancellationToken, isFixAll) { - tryDeleteDeclarationWorker(token, changes, sourceFile, checker, sourceFiles, program, cancellationToken, isFixAll); - if (isIdentifier(token)) { - ts_FindAllReferences_exports.Core.eachSymbolReferenceInFile(token, checker, sourceFile, (ref) => { - if (isPropertyAccessExpression(ref.parent) && ref.parent.name === ref) - ref = ref.parent; - if (!isFixAll && mayDeleteExpression(ref)) { - changes.delete(sourceFile, ref.parent.parent); + const stringCompletions = ts_Completions_StringCompletions_exports.getStringLiteralCompletions(sourceFile, position, previousToken, compilerOptions, host, program, log, preferences, includeSymbol); + if (stringCompletions) { + return stringCompletions; + } + if (previousToken && isBreakOrContinueStatement(previousToken.parent) && (previousToken.kind === 83 /* BreakKeyword */ || previousToken.kind === 88 /* ContinueKeyword */ || previousToken.kind === 80 /* Identifier */)) { + return getLabelCompletionAtPosition(previousToken.parent); + } + const completionData = getCompletionData( + program, + log, + sourceFile, + compilerOptions, + position, + preferences, + /*detailsEntryId*/ + void 0, + host, + formatContext, + cancellationToken + ); + if (!completionData) { + return void 0; + } + switch (completionData.kind) { + case 0 /* Data */: + const response = completionInfoFromData(sourceFile, host, program, compilerOptions, log, completionData, preferences, formatContext, position, includeSymbol); + if (response == null ? void 0 : response.isIncomplete) { + incompleteCompletionsCache == null ? void 0 : incompleteCompletionsCache.set(response); } - }); + return response; + case 1 /* JsDocTagName */: + return jsdocCompletionInfo([ + ...ts_JsDoc_exports.getJSDocTagNameCompletions(), + ...getJSDocParameterCompletions( + sourceFile, + position, + checker, + compilerOptions, + preferences, + /*tagNameOnly*/ + true + ) + ]); + case 2 /* JsDocTag */: + return jsdocCompletionInfo([ + ...ts_JsDoc_exports.getJSDocTagCompletions(), + ...getJSDocParameterCompletions( + sourceFile, + position, + checker, + compilerOptions, + preferences, + /*tagNameOnly*/ + false + ) + ]); + case 3 /* JsDocParameterName */: + return jsdocCompletionInfo(ts_JsDoc_exports.getJSDocParameterNameCompletions(completionData.tag)); + case 4 /* Keywords */: + return specificKeywordCompletionInfo(completionData.keywordCompletions, completionData.isNewIdentifierLocation); + default: + return Debug.assertNever(completionData); } } - function tryDeleteDeclarationWorker(token, changes, sourceFile, checker, sourceFiles, program, cancellationToken, isFixAll) { - const { parent: parent2 } = token; - if (isParameter(parent2)) { - tryDeleteParameter(changes, sourceFile, parent2, checker, sourceFiles, program, cancellationToken, isFixAll); - } else if (!(isFixAll && isIdentifier(token) && ts_FindAllReferences_exports.Core.isSymbolReferencedInFile(token, checker, sourceFile))) { - const node = isImportClause(parent2) ? token : isComputedPropertyName(parent2) ? parent2.parent : parent2; - Debug.assert(node !== sourceFile, "should not delete whole source file"); - changes.delete(sourceFile, node); + function compareCompletionEntries(entryInArray, entryToInsert) { + var _a, _b; + let result = compareStringsCaseSensitiveUI(entryInArray.sortText, entryToInsert.sortText); + if (result === 0 /* EqualTo */) { + result = compareStringsCaseSensitiveUI(entryInArray.name, entryToInsert.name); + } + if (result === 0 /* EqualTo */ && ((_a = entryInArray.data) == null ? void 0 : _a.moduleSpecifier) && ((_b = entryToInsert.data) == null ? void 0 : _b.moduleSpecifier)) { + result = compareNumberOfDirectorySeparators( + entryInArray.data.moduleSpecifier, + entryToInsert.data.moduleSpecifier + ); + } + if (result === 0 /* EqualTo */) { + return -1 /* LessThan */; } + return result; } - function tryDeleteParameter(changes, sourceFile, parameter, checker, sourceFiles, program, cancellationToken, isFixAll = false) { - if (mayDeleteParameter(checker, sourceFile, parameter, sourceFiles, program, cancellationToken, isFixAll)) { - if (parameter.modifiers && parameter.modifiers.length > 0 && (!isIdentifier(parameter.name) || ts_FindAllReferences_exports.Core.isSymbolReferencedInFile(parameter.name, checker, sourceFile))) { - for (const modifier of parameter.modifiers) { - if (isModifier(modifier)) { - changes.deleteModifier(sourceFile, modifier); + function completionEntryDataIsResolved(data) { + return !!(data == null ? void 0 : data.moduleSpecifier); + } + function continuePreviousIncompleteResponse(cache, file, location, program, host, preferences, cancellationToken, position) { + const previousResponse = cache.get(); + if (!previousResponse) + return void 0; + const touchNode = getTouchingPropertyName(file, position); + const lowerCaseTokenText = location.text.toLowerCase(); + const exportMap = getExportInfoMap(file, host, program, preferences, cancellationToken); + const newEntries = resolvingModuleSpecifiers( + "continuePreviousIncompleteResponse", + host, + ts_codefix_exports.createImportSpecifierResolver(file, program, host, preferences), + program, + location.getStart(), + preferences, + /*isForImportStatementCompletion*/ + false, + isValidTypeOnlyAliasUseSite(location), + (context) => { + const entries = mapDefined(previousResponse.entries, (entry) => { + var _a; + if (!entry.hasAction || !entry.source || !entry.data || completionEntryDataIsResolved(entry.data)) { + return entry; + } + if (!charactersFuzzyMatchInString(entry.name, lowerCaseTokenText)) { + return void 0; + } + const { origin } = Debug.checkDefined(getAutoImportSymbolFromCompletionEntryData(entry.name, entry.data, program, host)); + const info = exportMap.get(file.path, entry.data.exportMapKey); + const result = info && context.tryResolve(info, !isExternalModuleNameRelative(stripQuotes(origin.moduleSymbol.name))); + if (result === "skipped") + return entry; + if (!result || result === "failed") { + (_a = host.log) == null ? void 0 : _a.call(host, `Unexpected failure resolving auto import for '${entry.name}' from '${entry.source}'`); + return void 0; } + const newOrigin = { + ...origin, + kind: 32 /* ResolvedExport */, + moduleSpecifier: result.moduleSpecifier + }; + entry.data = originToCompletionEntryData(newOrigin); + entry.source = getSourceFromOrigin(newOrigin); + entry.sourceDisplay = [textPart(newOrigin.moduleSpecifier)]; + return entry; + }); + if (!context.skippedAny()) { + previousResponse.isIncomplete = void 0; } - } else if (!parameter.initializer && isNotProvidedArguments(parameter, checker, sourceFiles)) { - changes.delete(sourceFile, parameter); + return entries; } + ); + previousResponse.entries = newEntries; + previousResponse.flags = (previousResponse.flags || 0) | 4 /* IsContinuation */; + previousResponse.optionalReplacementSpan = getOptionalReplacementSpan(touchNode); + return previousResponse; + } + function jsdocCompletionInfo(entries) { + return { isGlobalCompletion: false, isMemberCompletion: false, isNewIdentifierLocation: false, entries }; + } + function getJSDocParameterCompletions(sourceFile, position, checker, options, preferences, tagNameOnly) { + const currentToken = getTokenAtPosition(sourceFile, position); + if (!isJSDocTag(currentToken) && !isJSDoc(currentToken)) { + return []; + } + const jsDoc = isJSDoc(currentToken) ? currentToken : currentToken.parent; + if (!isJSDoc(jsDoc)) { + return []; + } + const func = jsDoc.parent; + if (!isFunctionLike(func)) { + return []; } + const isJs = isSourceFileJS(sourceFile); + const isSnippet = preferences.includeCompletionsWithSnippetText || void 0; + const paramTagCount = countWhere(jsDoc.tags, (tag) => isJSDocParameterTag(tag) && tag.getEnd() <= position); + return mapDefined(func.parameters, (param) => { + if (getJSDocParameterTags(param).length) { + return void 0; + } + if (isIdentifier(param.name)) { + const tabstopCounter = { tabstop: 1 }; + const paramName = param.name.text; + let displayText = getJSDocParamAnnotation( + paramName, + param.initializer, + param.dotDotDotToken, + isJs, + /*isObject*/ + false, + /*isSnippet*/ + false, + checker, + options, + preferences + ); + let snippetText = isSnippet ? getJSDocParamAnnotation( + paramName, + param.initializer, + param.dotDotDotToken, + isJs, + /*isObject*/ + false, + /*isSnippet*/ + true, + checker, + options, + preferences, + tabstopCounter + ) : void 0; + if (tagNameOnly) { + displayText = displayText.slice(1); + if (snippetText) + snippetText = snippetText.slice(1); + } + return { + name: displayText, + kind: "parameter" /* parameterElement */, + sortText: SortText.LocationPriority, + insertText: isSnippet ? snippetText : void 0, + isSnippet + }; + } else if (param.parent.parameters.indexOf(param) === paramTagCount) { + const paramPath = `param${paramTagCount}`; + const displayTextResult = generateJSDocParamTagsForDestructuring( + paramPath, + param.name, + param.initializer, + param.dotDotDotToken, + isJs, + /*isSnippet*/ + false, + checker, + options, + preferences + ); + const snippetTextResult = isSnippet ? generateJSDocParamTagsForDestructuring( + paramPath, + param.name, + param.initializer, + param.dotDotDotToken, + isJs, + /*isSnippet*/ + true, + checker, + options, + preferences + ) : void 0; + let displayText = displayTextResult.join(getNewLineCharacter(options) + "* "); + let snippetText = snippetTextResult == null ? void 0 : snippetTextResult.join(getNewLineCharacter(options) + "* "); + if (tagNameOnly) { + displayText = displayText.slice(1); + if (snippetText) + snippetText = snippetText.slice(1); + } + return { + name: displayText, + kind: "parameter" /* parameterElement */, + sortText: SortText.LocationPriority, + insertText: isSnippet ? snippetText : void 0, + isSnippet + }; + } + }); } - function isNotProvidedArguments(parameter, checker, sourceFiles) { - const index = parameter.parent.parameters.indexOf(parameter); - return !ts_FindAllReferences_exports.Core.someSignatureUsage(parameter.parent, sourceFiles, checker, (_, call) => !call || call.arguments.length > index); + function generateJSDocParamTagsForDestructuring(path, pattern, initializer, dotDotDotToken, isJs, isSnippet, checker, options, preferences) { + if (!isJs) { + return [ + getJSDocParamAnnotation( + path, + initializer, + dotDotDotToken, + isJs, + /*isObject*/ + false, + isSnippet, + checker, + options, + preferences, + { tabstop: 1 } + ) + ]; + } + return patternWorker(path, pattern, initializer, dotDotDotToken, { tabstop: 1 }); + function patternWorker(path2, pattern2, initializer2, dotDotDotToken2, counter) { + if (isObjectBindingPattern(pattern2) && !dotDotDotToken2) { + const oldTabstop = counter.tabstop; + const childCounter = { tabstop: oldTabstop }; + const rootParam = getJSDocParamAnnotation( + path2, + initializer2, + dotDotDotToken2, + isJs, + /*isObject*/ + true, + isSnippet, + checker, + options, + preferences, + childCounter + ); + let childTags = []; + for (const element of pattern2.elements) { + const elementTags = elementWorker(path2, element, childCounter); + if (!elementTags) { + childTags = void 0; + break; + } else { + childTags.push(...elementTags); + } + } + if (childTags) { + counter.tabstop = childCounter.tabstop; + return [rootParam, ...childTags]; + } + } + return [ + getJSDocParamAnnotation( + path2, + initializer2, + dotDotDotToken2, + isJs, + /*isObject*/ + false, + isSnippet, + checker, + options, + preferences, + counter + ) + ]; + } + function elementWorker(path2, element, counter) { + if (!element.propertyName && isIdentifier(element.name) || isIdentifier(element.name)) { + const propertyName = element.propertyName ? tryGetTextOfPropertyName(element.propertyName) : element.name.text; + if (!propertyName) { + return void 0; + } + const paramName = `${path2}.${propertyName}`; + return [ + getJSDocParamAnnotation( + paramName, + element.initializer, + element.dotDotDotToken, + isJs, + /*isObject*/ + false, + isSnippet, + checker, + options, + preferences, + counter + ) + ]; + } else if (element.propertyName) { + const propertyName = tryGetTextOfPropertyName(element.propertyName); + return propertyName && patternWorker(`${path2}.${propertyName}`, element.name, element.initializer, element.dotDotDotToken, counter); + } + return void 0; + } } - function mayDeleteParameter(checker, sourceFile, parameter, sourceFiles, program, cancellationToken, isFixAll) { - const { parent: parent2 } = parameter; - switch (parent2.kind) { - case 173 /* MethodDeclaration */: - case 175 /* Constructor */: - const index = parent2.parameters.indexOf(parameter); - const referent = isMethodDeclaration(parent2) ? parent2.name : parent2; - const entries = ts_FindAllReferences_exports.Core.getReferencedSymbolsForNode(parent2.pos, referent, program, sourceFiles, cancellationToken); - if (entries) { - for (const entry of entries) { - for (const reference of entry.references) { - if (reference.kind === ts_FindAllReferences_exports.EntryKind.Node) { - const isSuperCall2 = isSuperKeyword(reference.node) && isCallExpression(reference.node.parent) && reference.node.parent.arguments.length > index; - const isSuperMethodCall = isPropertyAccessExpression(reference.node.parent) && isSuperKeyword(reference.node.parent.expression) && isCallExpression(reference.node.parent.parent) && reference.node.parent.parent.arguments.length > index; - const isOverriddenMethod = (isMethodDeclaration(reference.node.parent) || isMethodSignature(reference.node.parent)) && reference.node.parent !== parameter.parent && reference.node.parent.parameters.length > index; - if (isSuperCall2 || isSuperMethodCall || isOverriddenMethod) - return false; - } + function getJSDocParamAnnotation(paramName, initializer, dotDotDotToken, isJs, isObject, isSnippet, checker, options, preferences, tabstopCounter) { + if (isSnippet) { + Debug.assertIsDefined(tabstopCounter); + } + if (initializer) { + paramName = getJSDocParamNameWithInitializer(paramName, initializer); + } + if (isSnippet) { + paramName = escapeSnippetText(paramName); + } + if (isJs) { + let type = "*"; + if (isObject) { + Debug.assert(!dotDotDotToken, `Cannot annotate a rest parameter with type 'Object'.`); + type = "Object"; + } else { + if (initializer) { + const inferredType = checker.getTypeAtLocation(initializer.parent); + if (!(inferredType.flags & (1 /* Any */ | 16384 /* Void */))) { + const sourceFile = initializer.getSourceFile(); + const quotePreference = getQuotePreference(sourceFile, preferences); + const builderFlags = quotePreference === 0 /* Single */ ? 268435456 /* UseSingleQuotesForStringLiteralType */ : 0 /* None */; + const typeNode = checker.typeToTypeNode(inferredType, findAncestor(initializer, isFunctionLike), builderFlags); + if (typeNode) { + const printer = isSnippet ? createSnippetPrinter({ + removeComments: true, + module: options.module, + target: options.target + }) : createPrinter({ + removeComments: true, + module: options.module, + target: options.target + }); + setEmitFlags(typeNode, 1 /* SingleLine */); + type = printer.printNode(4 /* Unspecified */, typeNode, sourceFile); } } } - return true; - case 261 /* FunctionDeclaration */: { - if (parent2.name && isCallbackLike(checker, sourceFile, parent2.name)) { - return isLastParameter(parent2, parameter, isFixAll); + if (isSnippet && type === "*") { + type = `\${${tabstopCounter.tabstop++}:${type}}`; } - return true; } - case 217 /* FunctionExpression */: - case 218 /* ArrowFunction */: - return isLastParameter(parent2, parameter, isFixAll); - case 177 /* SetAccessor */: - return false; - case 176 /* GetAccessor */: - return true; - default: - return Debug.failBadSyntaxKind(parent2); + const dotDotDot = !isObject && dotDotDotToken ? "..." : ""; + const description3 = isSnippet ? `\${${tabstopCounter.tabstop++}}` : ""; + return `@param {${dotDotDot}${type}} ${paramName} ${description3}`; + } else { + const description3 = isSnippet ? `\${${tabstopCounter.tabstop++}}` : ""; + return `@param ${paramName} ${description3}`; } } - function isCallbackLike(checker, sourceFile, name) { - return !!ts_FindAllReferences_exports.Core.eachSymbolReferenceInFile(name, checker, sourceFile, (reference) => isIdentifier(reference) && isCallExpression(reference.parent) && reference.parent.arguments.indexOf(reference) >= 0); + function getJSDocParamNameWithInitializer(paramName, initializer) { + const initializerText = initializer.getText().trim(); + if (initializerText.includes("\n") || initializerText.length > 80) { + return `[${paramName}]`; + } + return `[${paramName}=${initializerText}]`; } - function isLastParameter(func, parameter, isFixAll) { - const parameters = func.parameters; - const index = parameters.indexOf(parameter); - Debug.assert(index !== -1, "The parameter should already be in the list"); - return isFixAll ? parameters.slice(index + 1).every((p) => isIdentifier(p.name) && !p.symbol.isReferenced) : index === parameters.length - 1; + function keywordToCompletionEntry(keyword) { + return { + name: tokenToString(keyword), + kind: "keyword" /* keyword */, + kindModifiers: "" /* none */, + sortText: SortText.GlobalsOrKeywords + }; } - function mayDeleteExpression(node) { - return (isBinaryExpression(node.parent) && node.parent.left === node || (isPostfixUnaryExpression(node.parent) || isPrefixUnaryExpression(node.parent)) && node.parent.operand === node) && isExpressionStatement(node.parent.parent); + function specificKeywordCompletionInfo(entries, isNewIdentifierLocation) { + return { + isGlobalCompletion: false, + isMemberCompletion: false, + isNewIdentifierLocation, + entries: entries.slice() + }; } - var fixName3, fixIdPrefix, fixIdDelete, fixIdDeleteImports, fixIdInfer, errorCodes41; - var init_fixUnusedIdentifier = __esm({ - "src/services/codefixes/fixUnusedIdentifier.ts"() { - "use strict"; - init_ts4(); - init_ts_codefix(); - fixName3 = "unusedIdentifier"; - fixIdPrefix = "unusedIdentifier_prefix"; - fixIdDelete = "unusedIdentifier_delete"; - fixIdDeleteImports = "unusedIdentifier_deleteImports"; - fixIdInfer = "unusedIdentifier_infer"; - errorCodes41 = [ - Diagnostics._0_is_declared_but_its_value_is_never_read.code, - Diagnostics._0_is_declared_but_never_used.code, - Diagnostics.Property_0_is_declared_but_its_value_is_never_read.code, - Diagnostics.All_imports_in_import_declaration_are_unused.code, - Diagnostics.All_destructured_elements_are_unused.code, - Diagnostics.All_variables_are_unused.code, - Diagnostics.All_type_parameters_are_unused.code - ]; - registerCodeFix({ - errorCodes: errorCodes41, - getCodeActions(context) { - const { errorCode, sourceFile, program, cancellationToken } = context; - const checker = program.getTypeChecker(); - const sourceFiles = program.getSourceFiles(); - const token = getTokenAtPosition(sourceFile, context.span.start); - if (isJSDocTemplateTag(token)) { - return [createDeleteFix(ts_textChanges_exports.ChangeTracker.with(context, (t) => t.delete(sourceFile, token)), Diagnostics.Remove_template_tag)]; - } - if (token.kind === 30 /* LessThanToken */) { - const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => deleteTypeParameters(t, sourceFile, token)); - return [createDeleteFix(changes, Diagnostics.Remove_type_parameters)]; - } - const importDecl = tryGetFullImport(token); - if (importDecl) { - const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => t.delete(sourceFile, importDecl)); - return [createCodeFixAction(fixName3, changes, [Diagnostics.Remove_import_from_0, showModuleSpecifier(importDecl)], fixIdDeleteImports, Diagnostics.Delete_all_unused_imports)]; - } else if (isImport(token)) { - const deletion = ts_textChanges_exports.ChangeTracker.with(context, (t) => tryDeleteDeclaration( - sourceFile, - token, - t, - checker, - sourceFiles, - program, - cancellationToken, - /*isFixAll*/ - false - )); - if (deletion.length) { - return [createCodeFixAction(fixName3, deletion, [Diagnostics.Remove_unused_declaration_for_Colon_0, token.getText(sourceFile)], fixIdDeleteImports, Diagnostics.Delete_all_unused_imports)]; - } - } - if (isObjectBindingPattern(token.parent) || isArrayBindingPattern(token.parent)) { - if (isParameter(token.parent.parent)) { - const elements = token.parent.elements; - const diagnostic = [ - elements.length > 1 ? Diagnostics.Remove_unused_declarations_for_Colon_0 : Diagnostics.Remove_unused_declaration_for_Colon_0, - map(elements, (e) => e.getText(sourceFile)).join(", ") - ]; - return [ - createDeleteFix(ts_textChanges_exports.ChangeTracker.with(context, (t) => deleteDestructuringElements(t, sourceFile, token.parent)), diagnostic) - ]; - } - return [ - createDeleteFix(ts_textChanges_exports.ChangeTracker.with(context, (t) => deleteDestructuring(context, t, sourceFile, token.parent)), Diagnostics.Remove_unused_destructuring_declaration) - ]; - } - if (canDeleteEntireVariableStatement(sourceFile, token)) { - return [ - createDeleteFix(ts_textChanges_exports.ChangeTracker.with(context, (t) => deleteEntireVariableStatement(t, sourceFile, token.parent)), Diagnostics.Remove_variable_statement) - ]; - } - const result = []; - if (token.kind === 140 /* InferKeyword */) { - const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => changeInferToUnknown(t, sourceFile, token)); - const name = cast(token.parent, isInferTypeNode).typeParameter.name.text; - result.push(createCodeFixAction(fixName3, changes, [Diagnostics.Replace_infer_0_with_unknown, name], fixIdInfer, Diagnostics.Replace_all_unused_infer_with_unknown)); - } else { - const deletion = ts_textChanges_exports.ChangeTracker.with(context, (t) => tryDeleteDeclaration( - sourceFile, - token, - t, - checker, - sourceFiles, - program, - cancellationToken, - /*isFixAll*/ - false - )); - if (deletion.length) { - const name = isComputedPropertyName(token.parent) ? token.parent : token; - result.push(createDeleteFix(deletion, [Diagnostics.Remove_unused_declaration_for_Colon_0, name.getText(sourceFile)])); - } - } - const prefix = ts_textChanges_exports.ChangeTracker.with(context, (t) => tryPrefixDeclaration(t, errorCode, sourceFile, token)); - if (prefix.length) { - result.push(createCodeFixAction(fixName3, prefix, [Diagnostics.Prefix_0_with_an_underscore, token.getText(sourceFile)], fixIdPrefix, Diagnostics.Prefix_all_unused_declarations_with_where_possible)); - } - return result; - }, - fixIds: [fixIdPrefix, fixIdDelete, fixIdDeleteImports, fixIdInfer], - getAllCodeActions: (context) => { - const { sourceFile, program, cancellationToken } = context; - const checker = program.getTypeChecker(); - const sourceFiles = program.getSourceFiles(); - return codeFixAll(context, errorCodes41, (changes, diag2) => { - const token = getTokenAtPosition(sourceFile, diag2.start); - switch (context.fixId) { - case fixIdPrefix: - tryPrefixDeclaration(changes, diag2.code, sourceFile, token); - break; - case fixIdDeleteImports: { - const importDecl = tryGetFullImport(token); - if (importDecl) { - changes.delete(sourceFile, importDecl); - } else if (isImport(token)) { - tryDeleteDeclaration( - sourceFile, - token, - changes, - checker, - sourceFiles, - program, - cancellationToken, - /*isFixAll*/ - true - ); - } - break; - } - case fixIdDelete: { - if (token.kind === 140 /* InferKeyword */ || isImport(token)) { - break; - } else if (isJSDocTemplateTag(token)) { - changes.delete(sourceFile, token); - } else if (token.kind === 30 /* LessThanToken */) { - deleteTypeParameters(changes, sourceFile, token); - } else if (isObjectBindingPattern(token.parent)) { - if (token.parent.parent.initializer) { - break; - } else if (!isParameter(token.parent.parent) || isNotProvidedArguments(token.parent.parent, checker, sourceFiles)) { - changes.delete(sourceFile, token.parent.parent); - } - } else if (isArrayBindingPattern(token.parent.parent) && token.parent.parent.parent.initializer) { - break; - } else if (canDeleteEntireVariableStatement(sourceFile, token)) { - deleteEntireVariableStatement(changes, sourceFile, token.parent); - } else { - tryDeleteDeclaration( - sourceFile, - token, - changes, - checker, - sourceFiles, - program, - cancellationToken, - /*isFixAll*/ - true - ); - } - break; - } - case fixIdInfer: - if (token.kind === 140 /* InferKeyword */) { - changeInferToUnknown(changes, sourceFile, token); - } - break; - default: - Debug.fail(JSON.stringify(context.fixId)); - } - }); + function keywordCompletionData(keywordFilters, filterOutTsOnlyKeywords, isNewIdentifierLocation) { + return { + kind: 4 /* Keywords */, + keywordCompletions: getKeywordCompletions(keywordFilters, filterOutTsOnlyKeywords), + isNewIdentifierLocation + }; + } + function keywordFiltersFromSyntaxKind(keywordCompletion) { + switch (keywordCompletion) { + case 156 /* TypeKeyword */: + return 8 /* TypeKeyword */; + default: + Debug.fail("Unknown mapping from SyntaxKind to KeywordCompletionFilters"); + } + } + function getOptionalReplacementSpan(location) { + return (location == null ? void 0 : location.kind) === 80 /* Identifier */ ? createTextSpanFromNode(location) : void 0; + } + function completionInfoFromData(sourceFile, host, program, compilerOptions, log, completionData, preferences, formatContext, position, includeSymbol) { + const { + symbols, + contextToken, + completionKind, + isInSnippetScope, + isNewIdentifierLocation, + location, + propertyAccessToConvert, + keywordFilters, + symbolToOriginInfoMap, + recommendedCompletion, + isJsxInitializer, + isTypeOnlyLocation, + isJsxIdentifierExpected, + isRightOfOpenTag, + isRightOfDotOrQuestionDot, + importStatementCompletion, + insideJsDocTagTypeExpression, + symbolToSortTextMap, + hasUnresolvedAutoImports + } = completionData; + let literals = completionData.literals; + const checker = program.getTypeChecker(); + if (getLanguageVariant(sourceFile.scriptKind) === 1 /* JSX */) { + const completionInfo = getJsxClosingTagCompletion(location, sourceFile); + if (completionInfo) { + return completionInfo; + } + } + const caseClause = findAncestor(contextToken, isCaseClause); + if (caseClause && (isCaseKeyword(contextToken) || isNodeDescendantOf(contextToken, caseClause.expression))) { + const tracker = newCaseClauseTracker(checker, caseClause.parent.clauses); + literals = literals.filter((literal) => !tracker.hasValue(literal)); + symbols.forEach((symbol, i) => { + if (symbol.valueDeclaration && isEnumMember(symbol.valueDeclaration)) { + const value = checker.getConstantValue(symbol.valueDeclaration); + if (value !== void 0 && tracker.hasValue(value)) { + symbolToOriginInfoMap[i] = { kind: 256 /* Ignore */ }; + } } }); } - }); - - // src/services/codefixes/fixUnreachableCode.ts - function doChange26(changes, sourceFile, start, length2, errorCode) { - const token = getTokenAtPosition(sourceFile, start); - const statement = findAncestor(token, isStatement); - if (statement.getStart(sourceFile) !== token.getStart(sourceFile)) { - const logData = JSON.stringify({ - statementKind: Debug.formatSyntaxKind(statement.kind), - tokenKind: Debug.formatSyntaxKind(token.kind), - errorCode, - start, - length: length2 - }); - Debug.fail("Token and statement should start at the same point. " + logData); + const entries = createSortedArray(); + const isChecked = isCheckedFile(sourceFile, compilerOptions); + if (isChecked && !isNewIdentifierLocation && (!symbols || symbols.length === 0) && keywordFilters === 0 /* None */) { + return void 0; } - const container = (isBlock(statement.parent) ? statement.parent : statement).parent; - if (!isBlock(statement.parent) || statement === first(statement.parent.statements)) { - switch (container.kind) { - case 244 /* IfStatement */: - if (container.elseStatement) { - if (isBlock(statement.parent)) { - break; - } else { - changes.replaceNode(sourceFile, statement, factory.createBlock(emptyArray)); - } - return; - } - case 246 /* WhileStatement */: - case 247 /* ForStatement */: - changes.delete(sourceFile, container); - return; + const uniqueNames = getCompletionEntriesFromSymbols( + symbols, + entries, + /*replacementToken*/ + void 0, + contextToken, + location, + position, + sourceFile, + host, + program, + getEmitScriptTarget(compilerOptions), + log, + completionKind, + preferences, + compilerOptions, + formatContext, + isTypeOnlyLocation, + propertyAccessToConvert, + isJsxIdentifierExpected, + isJsxInitializer, + importStatementCompletion, + recommendedCompletion, + symbolToOriginInfoMap, + symbolToSortTextMap, + isJsxIdentifierExpected, + isRightOfOpenTag, + includeSymbol + ); + if (keywordFilters !== 0 /* None */) { + for (const keywordEntry of getKeywordCompletions(keywordFilters, !insideJsDocTagTypeExpression && isSourceFileJS(sourceFile))) { + if (isTypeOnlyLocation && isTypeKeyword(stringToToken(keywordEntry.name)) || !isTypeOnlyLocation && isContextualKeywordInAutoImportableExpressionSpace(keywordEntry.name) || !uniqueNames.has(keywordEntry.name)) { + uniqueNames.add(keywordEntry.name); + insertSorted( + entries, + keywordEntry, + compareCompletionEntries, + /*allowDuplicates*/ + true + ); + } } } - if (isBlock(statement.parent)) { - const end = start + length2; - const lastStatement = Debug.checkDefined(lastWhere(sliceAfter(statement.parent.statements, statement), (s) => s.pos < end), "Some statement should be last"); - changes.deleteNodeRange(sourceFile, statement, lastStatement); - } else { - changes.delete(sourceFile, statement); + for (const keywordEntry of getContextualKeywords(contextToken, position)) { + if (!uniqueNames.has(keywordEntry.name)) { + uniqueNames.add(keywordEntry.name); + insertSorted( + entries, + keywordEntry, + compareCompletionEntries, + /*allowDuplicates*/ + true + ); + } } - } - function lastWhere(a, pred) { - let last2; - for (const value of a) { - if (!pred(value)) - break; - last2 = value; + for (const literal of literals) { + const literalEntry = createCompletionEntryForLiteral(sourceFile, preferences, literal); + uniqueNames.add(literalEntry.name); + insertSorted( + entries, + literalEntry, + compareCompletionEntries, + /*allowDuplicates*/ + true + ); } - return last2; + if (!isChecked) { + getJSCompletionEntries(sourceFile, location.pos, uniqueNames, getEmitScriptTarget(compilerOptions), entries); + } + let caseBlock; + if (preferences.includeCompletionsWithInsertText && contextToken && !isRightOfOpenTag && !isRightOfDotOrQuestionDot && (caseBlock = findAncestor(contextToken, isCaseBlock))) { + const cases = getExhaustiveCaseSnippets(caseBlock, sourceFile, preferences, compilerOptions, host, program, formatContext); + if (cases) { + entries.push(cases.entry); + } + } + return { + flags: completionData.flags, + isGlobalCompletion: isInSnippetScope, + isIncomplete: preferences.allowIncompleteCompletions && hasUnresolvedAutoImports ? true : void 0, + isMemberCompletion: isMemberCompletionKind(completionKind), + isNewIdentifierLocation, + optionalReplacementSpan: getOptionalReplacementSpan(location), + entries + }; } - var fixId33, errorCodes42; - var init_fixUnreachableCode = __esm({ - "src/services/codefixes/fixUnreachableCode.ts"() { - "use strict"; - init_ts4(); - init_ts_codefix(); - fixId33 = "fixUnreachableCode"; - errorCodes42 = [Diagnostics.Unreachable_code_detected.code]; - registerCodeFix({ - errorCodes: errorCodes42, - getCodeActions(context) { - const syntacticDiagnostics = context.program.getSyntacticDiagnostics(context.sourceFile, context.cancellationToken); - if (syntacticDiagnostics.length) - return; - const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange26(t, context.sourceFile, context.span.start, context.span.length, context.errorCode)); - return [createCodeFixAction(fixId33, changes, Diagnostics.Remove_unreachable_code, fixId33, Diagnostics.Remove_all_unreachable_code)]; - }, - fixIds: [fixId33], - getAllCodeActions: (context) => codeFixAll(context, errorCodes42, (changes, diag2) => doChange26(changes, diag2.file, diag2.start, diag2.length, diag2.code)) + function isCheckedFile(sourceFile, compilerOptions) { + return !isSourceFileJS(sourceFile) || !!isCheckJsEnabledForFile(sourceFile, compilerOptions); + } + function getExhaustiveCaseSnippets(caseBlock, sourceFile, preferences, options, host, program, formatContext) { + const clauses = caseBlock.clauses; + const checker = program.getTypeChecker(); + const switchType = checker.getTypeAtLocation(caseBlock.parent.expression); + if (switchType && switchType.isUnion() && every(switchType.types, (type) => type.isLiteral())) { + const tracker = newCaseClauseTracker(checker, clauses); + const target = getEmitScriptTarget(options); + const quotePreference = getQuotePreference(sourceFile, preferences); + const importAdder = ts_codefix_exports.createImportAdder(sourceFile, program, preferences, host); + const elements = []; + for (const type of switchType.types) { + if (type.flags & 1024 /* EnumLiteral */) { + Debug.assert(type.symbol, "An enum member type should have a symbol"); + Debug.assert(type.symbol.parent, "An enum member type should have a parent symbol (the enum symbol)"); + const enumValue = type.symbol.valueDeclaration && checker.getConstantValue(type.symbol.valueDeclaration); + if (enumValue !== void 0) { + if (tracker.hasValue(enumValue)) { + continue; + } + tracker.addValue(enumValue); + } + const typeNode = ts_codefix_exports.typeToAutoImportableTypeNode(checker, importAdder, type, caseBlock, target); + if (!typeNode) { + return void 0; + } + const expr = typeNodeToExpression(typeNode, target, quotePreference); + if (!expr) { + return void 0; + } + elements.push(expr); + } else if (!tracker.hasValue(type.value)) { + switch (typeof type.value) { + case "object": + elements.push(type.value.negative ? factory.createPrefixUnaryExpression(41 /* MinusToken */, factory.createBigIntLiteral({ negative: false, base10Value: type.value.base10Value })) : factory.createBigIntLiteral(type.value)); + break; + case "number": + elements.push(type.value < 0 ? factory.createPrefixUnaryExpression(41 /* MinusToken */, factory.createNumericLiteral(-type.value)) : factory.createNumericLiteral(type.value)); + break; + case "string": + elements.push(factory.createStringLiteral(type.value, quotePreference === 0 /* Single */)); + break; + } + } + } + if (elements.length === 0) { + return void 0; + } + const newClauses = map(elements, (element) => factory.createCaseClause(element, [])); + const newLineChar = getNewLineOrDefaultFromHost(host, formatContext == null ? void 0 : formatContext.options); + const printer = createSnippetPrinter({ + removeComments: true, + module: options.module, + target: options.target, + newLine: getNewLineKind(newLineChar) }); + const printNode = formatContext ? (node) => printer.printAndFormatNode(4 /* Unspecified */, node, sourceFile, formatContext) : (node) => printer.printNode(4 /* Unspecified */, node, sourceFile); + const insertText = map(newClauses, (clause, i) => { + if (preferences.includeCompletionsWithSnippetText) { + return `${printNode(clause)}$${i + 1}`; + } + return `${printNode(clause)}`; + }).join(newLineChar); + const firstClause = printer.printNode(4 /* Unspecified */, newClauses[0], sourceFile); + return { + entry: { + name: `${firstClause} ...`, + kind: "" /* unknown */, + sortText: SortText.GlobalsOrKeywords, + insertText, + hasAction: importAdder.hasFixes() || void 0, + source: "SwitchCases/" /* SwitchCases */, + isSnippet: preferences.includeCompletionsWithSnippetText ? true : void 0 + }, + importAdder + }; } - }); - - // src/services/codefixes/fixUnusedLabel.ts - function doChange27(changes, sourceFile, start) { - const token = getTokenAtPosition(sourceFile, start); - const labeledStatement = cast(token.parent, isLabeledStatement); - const pos = token.getStart(sourceFile); - const statementPos = labeledStatement.statement.getStart(sourceFile); - const end = positionsAreOnSameLine(pos, statementPos, sourceFile) ? statementPos : skipTrivia( - sourceFile.text, - findChildOfKind(labeledStatement, 59 /* ColonToken */, sourceFile).end, - /*stopAfterLineBreak*/ - true - ); - changes.deleteRange(sourceFile, { pos, end }); + return void 0; } - var fixId34, errorCodes43; - var init_fixUnusedLabel = __esm({ - "src/services/codefixes/fixUnusedLabel.ts"() { - "use strict"; - init_ts4(); - init_ts_codefix(); - fixId34 = "fixUnusedLabel"; - errorCodes43 = [Diagnostics.Unused_label.code]; - registerCodeFix({ - errorCodes: errorCodes43, - getCodeActions(context) { - const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange27(t, context.sourceFile, context.span.start)); - return [createCodeFixAction(fixId34, changes, Diagnostics.Remove_unused_label, fixId34, Diagnostics.Remove_all_unused_labels)]; - }, - fixIds: [fixId34], - getAllCodeActions: (context) => codeFixAll(context, errorCodes43, (changes, diag2) => doChange27(changes, diag2.file, diag2.start)) - }); + function typeNodeToExpression(typeNode, languageVersion, quotePreference) { + switch (typeNode.kind) { + case 183 /* TypeReference */: + const typeName = typeNode.typeName; + return entityNameToExpression(typeName, languageVersion, quotePreference); + case 199 /* IndexedAccessType */: + const objectExpression = typeNodeToExpression(typeNode.objectType, languageVersion, quotePreference); + const indexExpression = typeNodeToExpression(typeNode.indexType, languageVersion, quotePreference); + return objectExpression && indexExpression && factory.createElementAccessExpression(objectExpression, indexExpression); + case 201 /* LiteralType */: + const literal = typeNode.literal; + switch (literal.kind) { + case 11 /* StringLiteral */: + return factory.createStringLiteral(literal.text, quotePreference === 0 /* Single */); + case 9 /* NumericLiteral */: + return factory.createNumericLiteral(literal.text, literal.numericLiteralFlags); + } + return void 0; + case 196 /* ParenthesizedType */: + const exp = typeNodeToExpression(typeNode.type, languageVersion, quotePreference); + return exp && (isIdentifier(exp) ? exp : factory.createParenthesizedExpression(exp)); + case 186 /* TypeQuery */: + return entityNameToExpression(typeNode.exprName, languageVersion, quotePreference); + case 205 /* ImportType */: + Debug.fail(`We should not get an import type after calling 'codefix.typeToAutoImportableTypeNode'.`); } - }); - - // src/services/codefixes/fixJSDocTypes.ts - function doChange28(changes, sourceFile, oldTypeNode, newType, checker) { - changes.replaceNode(sourceFile, oldTypeNode, checker.typeToTypeNode( - newType, - /*enclosingDeclaration*/ - oldTypeNode, - /*flags*/ - void 0 - )); + return void 0; } - function getInfo14(sourceFile, pos, checker) { - const decl = findAncestor(getTokenAtPosition(sourceFile, pos), isTypeContainer); - const typeNode = decl && decl.type; - return typeNode && { typeNode, type: getType(checker, typeNode) }; + function entityNameToExpression(entityName, languageVersion, quotePreference) { + if (isIdentifier(entityName)) { + return entityName; + } + const unescapedName = unescapeLeadingUnderscores(entityName.right.escapedText); + if (canUsePropertyAccess(unescapedName, languageVersion)) { + return factory.createPropertyAccessExpression( + entityNameToExpression(entityName.left, languageVersion, quotePreference), + unescapedName + ); + } else { + return factory.createElementAccessExpression( + entityNameToExpression(entityName.left, languageVersion, quotePreference), + factory.createStringLiteral(unescapedName, quotePreference === 0 /* Single */) + ); + } } - function isTypeContainer(node) { - switch (node.kind) { - case 233 /* AsExpression */: - case 178 /* CallSignature */: - case 179 /* ConstructSignature */: - case 261 /* FunctionDeclaration */: - case 176 /* GetAccessor */: - case 180 /* IndexSignature */: - case 199 /* MappedType */: - case 173 /* MethodDeclaration */: - case 172 /* MethodSignature */: - case 168 /* Parameter */: - case 171 /* PropertyDeclaration */: - case 170 /* PropertySignature */: - case 177 /* SetAccessor */: - case 264 /* TypeAliasDeclaration */: - case 215 /* TypeAssertionExpression */: - case 259 /* VariableDeclaration */: + function isMemberCompletionKind(kind) { + switch (kind) { + case 0 /* ObjectPropertyDeclaration */: + case 3 /* MemberLike */: + case 2 /* PropertyAccess */: return true; default: return false; } } - function getType(checker, node) { - if (isJSDocNullableType(node)) { - const type = checker.getTypeFromTypeNode(node.type); - if (type === checker.getNeverType() || type === checker.getVoidType()) { - return type; + function getJsxClosingTagCompletion(location, sourceFile) { + const jsxClosingElement = findAncestor(location, (node) => { + switch (node.kind) { + case 287 /* JsxClosingElement */: + return true; + case 44 /* SlashToken */: + case 32 /* GreaterThanToken */: + case 80 /* Identifier */: + case 211 /* PropertyAccessExpression */: + return false; + default: + return "quit"; } - return checker.getUnionType( - append([type, checker.getUndefinedType()], node.postfix ? void 0 : checker.getNullType()) - ); + }); + if (jsxClosingElement) { + const hasClosingAngleBracket = !!findChildOfKind(jsxClosingElement, 32 /* GreaterThanToken */, sourceFile); + const tagName = jsxClosingElement.parent.openingElement.tagName; + const closingTag = tagName.getText(sourceFile); + const fullClosingTag = closingTag + (hasClosingAngleBracket ? "" : ">"); + const replacementSpan = createTextSpanFromNode(jsxClosingElement.tagName); + const entry = { + name: fullClosingTag, + kind: "class" /* classElement */, + kindModifiers: void 0, + sortText: SortText.LocationPriority + }; + return { isGlobalCompletion: false, isMemberCompletion: true, isNewIdentifierLocation: false, optionalReplacementSpan: replacementSpan, entries: [entry] }; } - return checker.getTypeFromTypeNode(node); + return; } - var fixIdPlain, fixIdNullable, errorCodes44; - var init_fixJSDocTypes = __esm({ - "src/services/codefixes/fixJSDocTypes.ts"() { - "use strict"; - init_ts4(); - init_ts_codefix(); - fixIdPlain = "fixJSDocTypes_plain"; - fixIdNullable = "fixJSDocTypes_nullable"; - errorCodes44 = [ - Diagnostics.JSDoc_types_can_only_be_used_inside_documentation_comments.code, - Diagnostics._0_at_the_end_of_a_type_is_not_valid_TypeScript_syntax_Did_you_mean_to_write_1.code, - Diagnostics._0_at_the_start_of_a_type_is_not_valid_TypeScript_syntax_Did_you_mean_to_write_1.code - ]; - registerCodeFix({ - errorCodes: errorCodes44, - getCodeActions(context) { - const { sourceFile } = context; - const checker = context.program.getTypeChecker(); - const info = getInfo14(sourceFile, context.span.start, checker); - if (!info) - return void 0; - const { typeNode, type } = info; - const original = typeNode.getText(sourceFile); - const actions2 = [fix(type, fixIdPlain, Diagnostics.Change_all_jsdoc_style_types_to_TypeScript)]; - if (typeNode.kind === 320 /* JSDocNullableType */) { - actions2.push(fix(type, fixIdNullable, Diagnostics.Change_all_jsdoc_style_types_to_TypeScript_and_add_undefined_to_nullable_types)); - } - return actions2; - function fix(type2, fixId52, fixAllDescription) { - const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange28(t, sourceFile, typeNode, type2, checker)); - return createCodeFixAction("jdocTypes", changes, [Diagnostics.Change_0_to_1, original, checker.typeToString(type2)], fixId52, fixAllDescription); - } - }, - fixIds: [fixIdPlain, fixIdNullable], - getAllCodeActions(context) { - const { fixId: fixId52, program, sourceFile } = context; - const checker = program.getTypeChecker(); - return codeFixAll(context, errorCodes44, (changes, err) => { - const info = getInfo14(err.file, err.start, checker); - if (!info) - return; - const { typeNode, type } = info; - const fixedType = typeNode.kind === 320 /* JSDocNullableType */ && fixId52 === fixIdNullable ? checker.getNullableType(type, 32768 /* Undefined */) : type; - doChange28(changes, sourceFile, typeNode, fixedType, checker); - }); - } - }); - } - }); - - // src/services/codefixes/fixMissingCallParentheses.ts - function doChange29(changes, sourceFile, name) { - changes.replaceNodeWithText(sourceFile, name, `${name.text}()`); + function getJSCompletionEntries(sourceFile, position, uniqueNames, target, entries) { + getNameTable(sourceFile).forEach((pos, name) => { + if (pos === position) { + return; + } + const realName = unescapeLeadingUnderscores(name); + if (!uniqueNames.has(realName) && isIdentifierText(realName, target)) { + uniqueNames.add(realName); + insertSorted(entries, { + name: realName, + kind: "warning" /* warning */, + kindModifiers: "", + sortText: SortText.JavascriptIdentifiers, + isFromUncheckedFile: true + }, compareCompletionEntries); + } + }); } - function getCallName(sourceFile, start) { - const token = getTokenAtPosition(sourceFile, start); - if (isPropertyAccessExpression(token.parent)) { - let current = token.parent; - while (isPropertyAccessExpression(current.parent)) { - current = current.parent; + function completionNameForLiteral(sourceFile, preferences, literal) { + return typeof literal === "object" ? pseudoBigIntToString(literal) + "n" : isString(literal) ? quote(sourceFile, preferences, literal) : JSON.stringify(literal); + } + function createCompletionEntryForLiteral(sourceFile, preferences, literal) { + return { name: completionNameForLiteral(sourceFile, preferences, literal), kind: "string" /* string */, kindModifiers: "" /* none */, sortText: SortText.LocationPriority }; + } + function createCompletionEntry(symbol, sortText, replacementToken, contextToken, location, position, sourceFile, host, program, name, needsConvertPropertyAccess, origin, recommendedCompletion, propertyAccessToConvert, isJsxInitializer, importStatementCompletion, useSemicolons, options, preferences, completionKind, formatContext, isJsxIdentifierExpected, isRightOfOpenTag, includeSymbol) { + var _a, _b; + let insertText; + let filterText; + let replacementSpan = getReplacementSpanForContextToken(replacementToken); + let data; + let isSnippet; + let source = getSourceFromOrigin(origin); + let sourceDisplay; + let hasAction; + let labelDetails; + const typeChecker = program.getTypeChecker(); + const insertQuestionDot = origin && originIsNullableMember(origin); + const useBraces = origin && originIsSymbolMember(origin) || needsConvertPropertyAccess; + if (origin && originIsThisType(origin)) { + insertText = needsConvertPropertyAccess ? `this${insertQuestionDot ? "?." : ""}[${quotePropertyName(sourceFile, preferences, name)}]` : `this${insertQuestionDot ? "?." : "."}${name}`; + } else if ((useBraces || insertQuestionDot) && propertyAccessToConvert) { + insertText = useBraces ? needsConvertPropertyAccess ? `[${quotePropertyName(sourceFile, preferences, name)}]` : `[${name}]` : name; + if (insertQuestionDot || propertyAccessToConvert.questionDotToken) { + insertText = `?.${insertText}`; } - return current.name; + const dot = findChildOfKind(propertyAccessToConvert, 25 /* DotToken */, sourceFile) || findChildOfKind(propertyAccessToConvert, 29 /* QuestionDotToken */, sourceFile); + if (!dot) { + return void 0; + } + const end = startsWith(name, propertyAccessToConvert.name.text) ? propertyAccessToConvert.name.end : dot.end; + replacementSpan = createTextSpanFromBounds(dot.getStart(sourceFile), end); } - if (isIdentifier(token)) { - return token; + if (isJsxInitializer) { + if (insertText === void 0) + insertText = name; + insertText = `{${insertText}}`; + if (typeof isJsxInitializer !== "boolean") { + replacementSpan = createTextSpanFromNode(isJsxInitializer, sourceFile); + } } - return void 0; - } - var fixId35, errorCodes45; - var init_fixMissingCallParentheses = __esm({ - "src/services/codefixes/fixMissingCallParentheses.ts"() { - "use strict"; - init_ts4(); - init_ts_codefix(); - fixId35 = "fixMissingCallParentheses"; - errorCodes45 = [ - Diagnostics.This_condition_will_always_return_true_since_this_function_is_always_defined_Did_you_mean_to_call_it_instead.code - ]; - registerCodeFix({ - errorCodes: errorCodes45, - fixIds: [fixId35], - getCodeActions(context) { - const { sourceFile, span } = context; - const callName = getCallName(sourceFile, span.start); - if (!callName) - return; - const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange29(t, context.sourceFile, callName)); - return [createCodeFixAction(fixId35, changes, Diagnostics.Add_missing_call_parentheses, fixId35, Diagnostics.Add_all_missing_call_parentheses)]; - }, - getAllCodeActions: (context) => codeFixAll(context, errorCodes45, (changes, diag2) => { - const callName = getCallName(diag2.file, diag2.start); - if (callName) - doChange29(changes, diag2.file, callName); - }) - }); + if (origin && originIsPromise(origin) && propertyAccessToConvert) { + if (insertText === void 0) + insertText = name; + const precedingToken = findPrecedingToken(propertyAccessToConvert.pos, sourceFile); + let awaitText = ""; + if (precedingToken && positionIsASICandidate(precedingToken.end, precedingToken.parent, sourceFile)) { + awaitText = ";"; + } + awaitText += `(await ${propertyAccessToConvert.expression.getText()})`; + insertText = needsConvertPropertyAccess ? `${awaitText}${insertText}` : `${awaitText}${insertQuestionDot ? "?." : "."}${insertText}`; + const isInAwaitExpression = tryCast(propertyAccessToConvert.parent, isAwaitExpression); + const wrapNode = isInAwaitExpression ? propertyAccessToConvert.parent : propertyAccessToConvert.expression; + replacementSpan = createTextSpanFromBounds(wrapNode.getStart(sourceFile), propertyAccessToConvert.end); } - }); - - // src/services/codefixes/fixAwaitInSyncFunction.ts - function getReturnType(expr) { - if (expr.type) { - return expr.type; + if (originIsResolvedExport(origin)) { + sourceDisplay = [textPart(origin.moduleSpecifier)]; + if (importStatementCompletion) { + ({ insertText, replacementSpan } = getInsertTextAndReplacementSpanForImportCompletion(name, importStatementCompletion, origin, useSemicolons, sourceFile, options, preferences)); + isSnippet = preferences.includeCompletionsWithSnippetText ? true : void 0; + } } - if (isVariableDeclaration(expr.parent) && expr.parent.type && isFunctionTypeNode(expr.parent.type)) { - return expr.parent.type.type; + if ((origin == null ? void 0 : origin.kind) === 64 /* TypeOnlyAlias */) { + hasAction = true; } - } - function getNodes3(sourceFile, start) { - const token = getTokenAtPosition(sourceFile, start); - const containingFunction = getContainingFunction(token); - if (!containingFunction) { - return; + if (completionKind === 0 /* ObjectPropertyDeclaration */ && contextToken && ((_a = findPrecedingToken(contextToken.pos, sourceFile, contextToken)) == null ? void 0 : _a.kind) !== 28 /* CommaToken */) { + if (isMethodDeclaration(contextToken.parent.parent) || isGetAccessorDeclaration(contextToken.parent.parent) || isSetAccessorDeclaration(contextToken.parent.parent) || isSpreadAssignment(contextToken.parent) || ((_b = findAncestor(contextToken.parent, isPropertyAssignment)) == null ? void 0 : _b.getLastToken(sourceFile)) === contextToken || isShorthandPropertyAssignment(contextToken.parent) && getLineAndCharacterOfPosition(sourceFile, contextToken.getEnd()).line !== getLineAndCharacterOfPosition(sourceFile, position).line) { + source = "ObjectLiteralMemberWithComma/" /* ObjectLiteralMemberWithComma */; + hasAction = true; + } } - let insertBefore; - switch (containingFunction.kind) { - case 173 /* MethodDeclaration */: - insertBefore = containingFunction.name; - break; - case 261 /* FunctionDeclaration */: - case 217 /* FunctionExpression */: - insertBefore = findChildOfKind(containingFunction, 100 /* FunctionKeyword */, sourceFile); - break; - case 218 /* ArrowFunction */: - const kind = containingFunction.typeParameters ? 30 /* LessThanToken */ : 21 /* OpenParenToken */; - insertBefore = findChildOfKind(containingFunction, kind, sourceFile) || first(containingFunction.parameters); - break; - default: - return; + if (preferences.includeCompletionsWithClassMemberSnippets && preferences.includeCompletionsWithInsertText && completionKind === 3 /* MemberLike */ && isClassLikeMemberCompletion(symbol, location, sourceFile)) { + let importAdder; + const memberCompletionEntry = getEntryForMemberCompletion(host, program, options, preferences, name, symbol, location, position, contextToken, formatContext); + if (memberCompletionEntry) { + ({ insertText, filterText, isSnippet, importAdder } = memberCompletionEntry); + if (importAdder == null ? void 0 : importAdder.hasFixes()) { + hasAction = true; + source = "ClassMemberSnippet/" /* ClassMemberSnippet */; + } + } else { + return void 0; + } } - return insertBefore && { - insertBefore, - returnType: getReturnType(containingFunction) + if (origin && originIsObjectLiteralMethod(origin)) { + ({ insertText, isSnippet, labelDetails } = origin); + if (!preferences.useLabelDetailsInCompletionEntries) { + name = name + labelDetails.detail; + labelDetails = void 0; + } + source = "ObjectLiteralMethodSnippet/" /* ObjectLiteralMethodSnippet */; + sortText = SortText.SortBelow(sortText); + } + if (isJsxIdentifierExpected && !isRightOfOpenTag && preferences.includeCompletionsWithSnippetText && preferences.jsxAttributeCompletionStyle && preferences.jsxAttributeCompletionStyle !== "none" && !(isJsxAttribute(location.parent) && location.parent.initializer)) { + let useBraces2 = preferences.jsxAttributeCompletionStyle === "braces"; + const type = typeChecker.getTypeOfSymbolAtLocation(symbol, location); + if (preferences.jsxAttributeCompletionStyle === "auto" && !(type.flags & 528 /* BooleanLike */) && !(type.flags & 1048576 /* Union */ && find(type.types, (type2) => !!(type2.flags & 528 /* BooleanLike */)))) { + if (type.flags & 402653316 /* StringLike */ || type.flags & 1048576 /* Union */ && every(type.types, (type2) => !!(type2.flags & (402653316 /* StringLike */ | 32768 /* Undefined */) || isStringAndEmptyAnonymousObjectIntersection(type2)))) { + insertText = `${escapeSnippetText(name)}=${quote(sourceFile, preferences, "$1")}`; + isSnippet = true; + } else { + useBraces2 = true; + } + } + if (useBraces2) { + insertText = `${escapeSnippetText(name)}={$1}`; + isSnippet = true; + } + } + if (insertText !== void 0 && !preferences.includeCompletionsWithInsertText) { + return void 0; + } + if (originIsExport(origin) || originIsResolvedExport(origin)) { + data = originToCompletionEntryData(origin); + hasAction = !importStatementCompletion; + } + const parentNamedImportOrExport = findAncestor(location, isNamedImportsOrExports); + if ((parentNamedImportOrExport == null ? void 0 : parentNamedImportOrExport.kind) === 275 /* NamedImports */) { + const possibleToken = stringToToken(name); + if (parentNamedImportOrExport && possibleToken && (possibleToken === 135 /* AwaitKeyword */ || isNonContextualKeyword(possibleToken))) { + insertText = `${name} as ${name}_`; + } + } + return { + name, + kind: ts_SymbolDisplay_exports.getSymbolKind(typeChecker, symbol, location), + kindModifiers: ts_SymbolDisplay_exports.getSymbolModifiers(typeChecker, symbol), + sortText, + source, + hasAction: hasAction ? true : void 0, + isRecommended: isRecommendedCompletionMatch(symbol, recommendedCompletion, typeChecker) || void 0, + insertText, + filterText, + replacementSpan, + sourceDisplay, + labelDetails, + isSnippet, + isPackageJsonImport: originIsPackageJsonImport(origin) || void 0, + isImportStatementCompletion: !!importStatementCompletion || void 0, + data, + ...includeSymbol ? { symbol } : void 0 }; } - function doChange30(changes, sourceFile, { insertBefore, returnType }) { - if (returnType) { - const entityName = getEntityNameFromTypeNode(returnType); - if (!entityName || entityName.kind !== 80 /* Identifier */ || entityName.text !== "Promise") { - changes.replaceNode(sourceFile, returnType, factory.createTypeReferenceNode("Promise", factory.createNodeArray([returnType]))); - } + function isClassLikeMemberCompletion(symbol, location, sourceFile) { + if (isInJSFile(location)) { + return false; } - changes.insertModifierBefore(sourceFile, 134 /* AsyncKeyword */, insertBefore); + const memberFlags = 106500 /* ClassMember */ & 900095 /* EnumMemberExcludes */; + return !!(symbol.flags & memberFlags) && (isClassLike(location) || location.parent && location.parent.parent && isClassElement(location.parent) && location === location.parent.name && location.parent.getLastToken(sourceFile) === location.parent.name && isClassLike(location.parent.parent) || location.parent && isSyntaxList(location) && isClassLike(location.parent)); } - var fixId36, errorCodes46; - var init_fixAwaitInSyncFunction = __esm({ - "src/services/codefixes/fixAwaitInSyncFunction.ts"() { - "use strict"; - init_ts4(); - init_ts_codefix(); - fixId36 = "fixAwaitInSyncFunction"; - errorCodes46 = [ - Diagnostics.await_expressions_are_only_allowed_within_async_functions_and_at_the_top_levels_of_modules.code, - Diagnostics.for_await_loops_are_only_allowed_within_async_functions_and_at_the_top_levels_of_modules.code, - Diagnostics.Cannot_find_name_0_Did_you_mean_to_write_this_in_an_async_function.code - ]; - registerCodeFix({ - errorCodes: errorCodes46, - getCodeActions(context) { - const { sourceFile, span } = context; - const nodes = getNodes3(sourceFile, span.start); - if (!nodes) - return void 0; - const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange30(t, sourceFile, nodes)); - return [createCodeFixAction(fixId36, changes, Diagnostics.Add_async_modifier_to_containing_function, fixId36, Diagnostics.Add_all_missing_async_modifiers)]; - }, - fixIds: [fixId36], - getAllCodeActions: function getAllCodeActionsToFixAwaitInSyncFunction(context) { - const seen = /* @__PURE__ */ new Map(); - return codeFixAll(context, errorCodes46, (changes, diag2) => { - const nodes = getNodes3(diag2.file, diag2.start); - if (!nodes || !addToSeen(seen, getNodeId(nodes.insertBefore))) - return; - doChange30(changes, context.sourceFile, nodes); - }); - } - }); + function getEntryForMemberCompletion(host, program, options, preferences, name, symbol, location, position, contextToken, formatContext) { + const classLikeDeclaration = findAncestor(location, isClassLike); + if (!classLikeDeclaration) { + return void 0; } - }); - - // src/services/codefixes/fixPropertyOverrideAccessor.ts - function doChange31(file, start, length2, code, context) { - let startPosition; - let endPosition; - if (code === Diagnostics._0_is_defined_as_an_accessor_in_class_1_but_is_overridden_here_in_2_as_an_instance_property.code) { - startPosition = start; - endPosition = start + length2; - } else if (code === Diagnostics._0_is_defined_as_a_property_in_class_1_but_is_overridden_here_in_2_as_an_accessor.code) { - const checker = context.program.getTypeChecker(); - const node = getTokenAtPosition(file, start).parent; - Debug.assert(isAccessor(node), "error span of fixPropertyOverrideAccessor should only be on an accessor"); - const containingClass = node.parent; - Debug.assert(isClassLike(containingClass), "erroneous accessors should only be inside classes"); - const base = singleOrUndefined(getAllSupers(containingClass, checker)); - if (!base) - return []; - const name = unescapeLeadingUnderscores(getTextOfPropertyName(node.name)); - const baseProp = checker.getPropertyOfType(checker.getTypeAtLocation(base), name); - if (!baseProp || !baseProp.valueDeclaration) - return []; - startPosition = baseProp.valueDeclaration.pos; - endPosition = baseProp.valueDeclaration.end; - file = getSourceFileOfNode(baseProp.valueDeclaration); + let isSnippet; + let insertText = name; + const filterText = name; + const checker = program.getTypeChecker(); + const sourceFile = location.getSourceFile(); + const printer = createSnippetPrinter({ + removeComments: true, + module: options.module, + target: options.target, + omitTrailingSemicolon: false, + newLine: getNewLineKind(getNewLineOrDefaultFromHost(host, formatContext == null ? void 0 : formatContext.options)) + }); + const importAdder = ts_codefix_exports.createImportAdder(sourceFile, program, preferences, host); + let body; + if (preferences.includeCompletionsWithSnippetText) { + isSnippet = true; + const emptyStmt = factory.createEmptyStatement(); + body = factory.createBlock( + [emptyStmt], + /*multiLine*/ + true + ); + setSnippetElement(emptyStmt, { kind: 0 /* TabStop */, order: 0 }); } else { - Debug.fail("fixPropertyOverrideAccessor codefix got unexpected error code " + code); + body = factory.createBlock( + [], + /*multiLine*/ + true + ); } - return generateAccessorFromProperty(file, context.program, startPosition, endPosition, context, Diagnostics.Generate_get_and_set_accessors.message); + let modifiers = 0 /* None */; + const { modifiers: presentModifiers, range: eraseRange, decorators: presentDecorators } = getPresentModifiers(contextToken, sourceFile, position); + const isAbstract = presentModifiers & 64 /* Abstract */ && classLikeDeclaration.modifierFlagsCache & 64 /* Abstract */; + let completionNodes = []; + ts_codefix_exports.addNewNodeForMemberSymbol( + symbol, + classLikeDeclaration, + sourceFile, + { program, host }, + preferences, + importAdder, + // `addNewNodeForMemberSymbol` calls this callback function for each new member node + // it adds for the given member symbol. + // We store these member nodes in the `completionNodes` array. + // Note: there might be: + // - No nodes if `addNewNodeForMemberSymbol` cannot figure out a node for the member; + // - One node; + // - More than one node if the member is overloaded (e.g. a method with overload signatures). + (node) => { + let requiredModifiers = 0 /* None */; + if (isAbstract) { + requiredModifiers |= 64 /* Abstract */; + } + if (isClassElement(node) && checker.getMemberOverrideModifierStatus(classLikeDeclaration, node, symbol) === 1 /* NeedsOverride */) { + requiredModifiers |= 16 /* Override */; + } + if (!completionNodes.length) { + modifiers = node.modifierFlagsCache | requiredModifiers; + } + node = factory.replaceModifiers(node, modifiers); + completionNodes.push(node); + }, + body, + ts_codefix_exports.PreserveOptionalFlags.Property, + !!isAbstract + ); + if (completionNodes.length) { + const isMethod = symbol.flags & 8192 /* Method */; + let allowedModifiers = modifiers | 16 /* Override */ | 1 /* Public */; + if (!isMethod) { + allowedModifiers |= 128 /* Ambient */ | 8 /* Readonly */; + } else { + allowedModifiers |= 1024 /* Async */; + } + const allowedAndPresent = presentModifiers & allowedModifiers; + if (presentModifiers & ~allowedModifiers) { + return void 0; + } + if (modifiers & 4 /* Protected */ && allowedAndPresent & 1 /* Public */) { + modifiers &= ~4 /* Protected */; + } + if (allowedAndPresent !== 0 /* None */ && !(allowedAndPresent & 1 /* Public */)) { + modifiers &= ~1 /* Public */; + } + modifiers |= allowedAndPresent; + completionNodes = completionNodes.map((node) => factory.replaceModifiers(node, modifiers)); + if (presentDecorators == null ? void 0 : presentDecorators.length) { + const lastNode = completionNodes[completionNodes.length - 1]; + if (canHaveDecorators(lastNode)) { + completionNodes[completionNodes.length - 1] = factory.replaceDecoratorsAndModifiers(lastNode, presentDecorators.concat(getModifiers(lastNode) || [])); + } + } + const format = 1 /* MultiLine */ | 131072 /* NoTrailingNewLine */; + if (formatContext) { + insertText = printer.printAndFormatSnippetList( + format, + factory.createNodeArray(completionNodes), + sourceFile, + formatContext + ); + } else { + insertText = printer.printSnippetList( + format, + factory.createNodeArray(completionNodes), + sourceFile + ); + } + } + return { insertText, filterText, isSnippet, importAdder, eraseRange }; } - var errorCodes47, fixId37; - var init_fixPropertyOverrideAccessor = __esm({ - "src/services/codefixes/fixPropertyOverrideAccessor.ts"() { - "use strict"; - init_ts4(); - init_ts_codefix(); - errorCodes47 = [ - Diagnostics._0_is_defined_as_an_accessor_in_class_1_but_is_overridden_here_in_2_as_an_instance_property.code, - Diagnostics._0_is_defined_as_a_property_in_class_1_but_is_overridden_here_in_2_as_an_accessor.code - ]; - fixId37 = "fixPropertyOverrideAccessor"; - registerCodeFix({ - errorCodes: errorCodes47, - getCodeActions(context) { - const edits = doChange31(context.sourceFile, context.span.start, context.span.length, context.errorCode, context); - if (edits) { - return [createCodeFixAction(fixId37, edits, Diagnostics.Generate_get_and_set_accessors, fixId37, Diagnostics.Generate_get_and_set_accessors_for_all_overriding_properties)]; - } - }, - fixIds: [fixId37], - getAllCodeActions: (context) => codeFixAll(context, errorCodes47, (changes, diag2) => { - const edits = doChange31(diag2.file, diag2.start, diag2.length, diag2.code, context); - if (edits) { - for (const edit of edits) { - changes.pushRaw(context.sourceFile, edit); - } - } - }) - }); + function getPresentModifiers(contextToken, sourceFile, position) { + if (!contextToken || getLineAndCharacterOfPosition(sourceFile, position).line > getLineAndCharacterOfPosition(sourceFile, contextToken.getEnd()).line) { + return { modifiers: 0 /* None */ }; } - }); - - // src/services/codefixes/inferFromUsage.ts - function getDiagnostic(errorCode, token) { - switch (errorCode) { - case Diagnostics.Parameter_0_implicitly_has_an_1_type.code: - case Diagnostics.Parameter_0_implicitly_has_an_1_type_but_a_better_type_may_be_inferred_from_usage.code: - return isSetAccessorDeclaration(getContainingFunction(token)) ? Diagnostics.Infer_type_of_0_from_usage : Diagnostics.Infer_parameter_types_from_usage; - case Diagnostics.Rest_parameter_0_implicitly_has_an_any_type.code: - case Diagnostics.Rest_parameter_0_implicitly_has_an_any_type_but_a_better_type_may_be_inferred_from_usage.code: - return Diagnostics.Infer_parameter_types_from_usage; - case Diagnostics.this_implicitly_has_type_any_because_it_does_not_have_a_type_annotation.code: - return Diagnostics.Infer_this_type_of_0_from_usage; - default: - return Diagnostics.Infer_type_of_0_from_usage; + let modifiers = 0 /* None */; + let decorators; + let contextMod; + const range = { pos: position, end: position }; + if (isPropertyDeclaration(contextToken.parent) && contextToken.parent.modifiers) { + modifiers |= modifiersToFlags(contextToken.parent.modifiers) & 98303 /* Modifier */; + decorators = contextToken.parent.modifiers.filter(isDecorator) || []; + range.pos = Math.min(range.pos, contextToken.parent.modifiers.pos); + } + if (contextMod = isModifierLike2(contextToken)) { + const contextModifierFlag = modifierToFlag(contextMod); + if (!(modifiers & contextModifierFlag)) { + modifiers |= contextModifierFlag; + range.pos = Math.min(range.pos, contextToken.pos); + } } + return { modifiers, decorators, range: range.pos !== position ? range : void 0 }; } - function mapSuggestionDiagnostic(errorCode) { - switch (errorCode) { - case Diagnostics.Variable_0_implicitly_has_type_1_in_some_locations_but_a_better_type_may_be_inferred_from_usage.code: - return Diagnostics.Variable_0_implicitly_has_type_1_in_some_locations_where_its_type_cannot_be_determined.code; - case Diagnostics.Variable_0_implicitly_has_an_1_type_but_a_better_type_may_be_inferred_from_usage.code: - return Diagnostics.Variable_0_implicitly_has_an_1_type.code; - case Diagnostics.Parameter_0_implicitly_has_an_1_type_but_a_better_type_may_be_inferred_from_usage.code: - return Diagnostics.Parameter_0_implicitly_has_an_1_type.code; - case Diagnostics.Rest_parameter_0_implicitly_has_an_any_type_but_a_better_type_may_be_inferred_from_usage.code: - return Diagnostics.Rest_parameter_0_implicitly_has_an_any_type.code; - case Diagnostics.Property_0_implicitly_has_type_any_but_a_better_type_for_its_get_accessor_may_be_inferred_from_usage.code: - return Diagnostics.Property_0_implicitly_has_type_any_because_its_get_accessor_lacks_a_return_type_annotation.code; - case Diagnostics._0_implicitly_has_an_1_return_type_but_a_better_type_may_be_inferred_from_usage.code: - return Diagnostics._0_which_lacks_return_type_annotation_implicitly_has_an_1_return_type.code; - case Diagnostics.Property_0_implicitly_has_type_any_but_a_better_type_for_its_set_accessor_may_be_inferred_from_usage.code: - return Diagnostics.Property_0_implicitly_has_type_any_because_its_set_accessor_lacks_a_parameter_type_annotation.code; - case Diagnostics.Member_0_implicitly_has_an_1_type_but_a_better_type_may_be_inferred_from_usage.code: - return Diagnostics.Member_0_implicitly_has_an_1_type.code; + function isModifierLike2(node) { + if (isModifier(node)) { + return node.kind; } - return errorCode; + if (isIdentifier(node)) { + const originalKeywordKind = identifierToKeywordKind(node); + if (originalKeywordKind && isModifierKind(originalKeywordKind)) { + return originalKeywordKind; + } + } + return void 0; } - function doChange32(changes, sourceFile, token, errorCode, program, cancellationToken, markSeen, host, preferences) { - if (!isParameterPropertyModifier(token.kind) && token.kind !== 80 /* Identifier */ && token.kind !== 26 /* DotDotDotToken */ && token.kind !== 110 /* ThisKeyword */) { + function getEntryForObjectLiteralMethodCompletion(symbol, name, enclosingDeclaration, program, host, options, preferences, formatContext) { + const isSnippet = preferences.includeCompletionsWithSnippetText || void 0; + let insertText = name; + const sourceFile = enclosingDeclaration.getSourceFile(); + const method = createObjectLiteralMethod(symbol, enclosingDeclaration, sourceFile, program, host, preferences); + if (!method) { return void 0; } - const { parent: parent2 } = token; - const importAdder = createImportAdder(sourceFile, program, preferences, host); - errorCode = mapSuggestionDiagnostic(errorCode); - switch (errorCode) { - case Diagnostics.Member_0_implicitly_has_an_1_type.code: - case Diagnostics.Variable_0_implicitly_has_type_1_in_some_locations_where_its_type_cannot_be_determined.code: - if (isVariableDeclaration(parent2) && markSeen(parent2) || isPropertyDeclaration(parent2) || isPropertySignature(parent2)) { - annotateVariableDeclaration(changes, importAdder, sourceFile, parent2, program, host, cancellationToken); - importAdder.writeFixes(changes); - return parent2; - } - if (isPropertyAccessExpression(parent2)) { - const type = inferTypeForVariableFromUsage(parent2.name, program, cancellationToken); - const typeNode = getTypeNodeIfAccessible(type, parent2, program, host); - if (typeNode) { - const typeTag = factory.createJSDocTypeTag( - /*tagName*/ - void 0, - factory.createJSDocTypeExpression(typeNode), - /*comment*/ - void 0 - ); - changes.addJSDocTags(sourceFile, cast(parent2.parent.parent, isExpressionStatement), [typeTag]); + const printer = createSnippetPrinter({ + removeComments: true, + module: options.module, + target: options.target, + omitTrailingSemicolon: false, + newLine: getNewLineKind(getNewLineOrDefaultFromHost(host, formatContext == null ? void 0 : formatContext.options)) + }); + if (formatContext) { + insertText = printer.printAndFormatSnippetList(16 /* CommaDelimited */ | 64 /* AllowTrailingComma */, factory.createNodeArray( + [method], + /*hasTrailingComma*/ + true + ), sourceFile, formatContext); + } else { + insertText = printer.printSnippetList(16 /* CommaDelimited */ | 64 /* AllowTrailingComma */, factory.createNodeArray( + [method], + /*hasTrailingComma*/ + true + ), sourceFile); + } + const signaturePrinter = createPrinter({ + removeComments: true, + module: options.module, + target: options.target, + omitTrailingSemicolon: true + }); + const methodSignature = factory.createMethodSignature( + /*modifiers*/ + void 0, + /*name*/ + "", + method.questionToken, + method.typeParameters, + method.parameters, + method.type + ); + const labelDetails = { detail: signaturePrinter.printNode(4 /* Unspecified */, methodSignature, sourceFile) }; + return { isSnippet, insertText, labelDetails }; + } + function createObjectLiteralMethod(symbol, enclosingDeclaration, sourceFile, program, host, preferences) { + const declarations = symbol.getDeclarations(); + if (!(declarations && declarations.length)) { + return void 0; + } + const checker = program.getTypeChecker(); + const declaration = declarations[0]; + const name = getSynthesizedDeepClone( + getNameOfDeclaration(declaration), + /*includeTrivia*/ + false + ); + const type = checker.getWidenedType(checker.getTypeOfSymbolAtLocation(symbol, enclosingDeclaration)); + const quotePreference = getQuotePreference(sourceFile, preferences); + const builderFlags = 33554432 /* OmitThisParameter */ | (quotePreference === 0 /* Single */ ? 268435456 /* UseSingleQuotesForStringLiteralType */ : 0 /* None */); + switch (declaration.kind) { + case 171 /* PropertySignature */: + case 172 /* PropertyDeclaration */: + case 173 /* MethodSignature */: + case 174 /* MethodDeclaration */: { + let effectiveType = type.flags & 1048576 /* Union */ && type.types.length < 10 ? checker.getUnionType(type.types, 2 /* Subtype */) : type; + if (effectiveType.flags & 1048576 /* Union */) { + const functionTypes = filter(effectiveType.types, (type2) => checker.getSignaturesOfType(type2, 0 /* Call */).length > 0); + if (functionTypes.length === 1) { + effectiveType = functionTypes[0]; + } else { + return void 0; } - importAdder.writeFixes(changes); - return parent2; } - return void 0; - case Diagnostics.Variable_0_implicitly_has_an_1_type.code: { - const symbol = program.getTypeChecker().getSymbolAtLocation(token); - if (symbol && symbol.valueDeclaration && isVariableDeclaration(symbol.valueDeclaration) && markSeen(symbol.valueDeclaration)) { - annotateVariableDeclaration(changes, importAdder, getSourceFileOfNode(symbol.valueDeclaration), symbol.valueDeclaration, program, host, cancellationToken); - importAdder.writeFixes(changes); - return symbol.valueDeclaration; + const signatures = checker.getSignaturesOfType(effectiveType, 0 /* Call */); + if (signatures.length !== 1) { + return void 0; + } + const typeNode = checker.typeToTypeNode(effectiveType, enclosingDeclaration, builderFlags, ts_codefix_exports.getNoopSymbolTrackerWithResolver({ program, host })); + if (!typeNode || !isFunctionTypeNode(typeNode)) { + return void 0; + } + let body; + if (preferences.includeCompletionsWithSnippetText) { + const emptyStmt = factory.createEmptyStatement(); + body = factory.createBlock( + [emptyStmt], + /*multiLine*/ + true + ); + setSnippetElement(emptyStmt, { kind: 0 /* TabStop */, order: 0 }); + } else { + body = factory.createBlock( + [], + /*multiLine*/ + true + ); } + const parameters = typeNode.parameters.map( + (typedParam) => factory.createParameterDeclaration( + /*modifiers*/ + void 0, + typedParam.dotDotDotToken, + typedParam.name, + /*questionToken*/ + void 0, + /*type*/ + void 0, + typedParam.initializer + ) + ); + return factory.createMethodDeclaration( + /*modifiers*/ + void 0, + /*asteriskToken*/ + void 0, + name, + /*questionToken*/ + void 0, + /*typeParameters*/ + void 0, + parameters, + /*type*/ + void 0, + body + ); + } + default: return void 0; + } + } + function createSnippetPrinter(printerOptions) { + let escapes; + const baseWriter = ts_textChanges_exports.createWriter(getNewLineCharacter(printerOptions)); + const printer = createPrinter(printerOptions, baseWriter); + const writer = { + ...baseWriter, + write: (s) => escapingWrite(s, () => baseWriter.write(s)), + nonEscapingWrite: baseWriter.write, + writeLiteral: (s) => escapingWrite(s, () => baseWriter.writeLiteral(s)), + writeStringLiteral: (s) => escapingWrite(s, () => baseWriter.writeStringLiteral(s)), + writeSymbol: (s, symbol) => escapingWrite(s, () => baseWriter.writeSymbol(s, symbol)), + writeParameter: (s) => escapingWrite(s, () => baseWriter.writeParameter(s)), + writeComment: (s) => escapingWrite(s, () => baseWriter.writeComment(s)), + writeProperty: (s) => escapingWrite(s, () => baseWriter.writeProperty(s)) + }; + return { + printSnippetList, + printAndFormatSnippetList, + printNode, + printAndFormatNode + }; + function escapingWrite(s, write) { + const escaped = escapeSnippetText(s); + if (escaped !== s) { + const start = baseWriter.getTextPos(); + write(); + const end = baseWriter.getTextPos(); + escapes = append(escapes || (escapes = []), { newText: escaped, span: { start, length: end - start } }); + } else { + write(); } } - const containingFunction = getContainingFunction(token); - if (containingFunction === void 0) { - return void 0; + function printSnippetList(format, list, sourceFile) { + const unescaped = printUnescapedSnippetList(format, list, sourceFile); + return escapes ? ts_textChanges_exports.applyChanges(unescaped, escapes) : unescaped; } - let declaration; - switch (errorCode) { - case Diagnostics.Parameter_0_implicitly_has_an_1_type.code: - if (isSetAccessorDeclaration(containingFunction)) { - annotateSetAccessor(changes, importAdder, sourceFile, containingFunction, program, host, cancellationToken); - declaration = containingFunction; - break; - } - case Diagnostics.Rest_parameter_0_implicitly_has_an_any_type.code: - if (markSeen(containingFunction)) { - const param = cast(parent2, isParameter); - annotateParameters(changes, importAdder, sourceFile, param, containingFunction, program, host, cancellationToken); - declaration = param; - } - break; - case Diagnostics.Property_0_implicitly_has_type_any_because_its_get_accessor_lacks_a_return_type_annotation.code: - case Diagnostics._0_which_lacks_return_type_annotation_implicitly_has_an_1_return_type.code: - if (isGetAccessorDeclaration(containingFunction) && isIdentifier(containingFunction.name)) { - annotate(changes, importAdder, sourceFile, containingFunction, inferTypeForVariableFromUsage(containingFunction.name, program, cancellationToken), program, host); - declaration = containingFunction; - } - break; - case Diagnostics.Property_0_implicitly_has_type_any_because_its_set_accessor_lacks_a_parameter_type_annotation.code: - if (isSetAccessorDeclaration(containingFunction)) { - annotateSetAccessor(changes, importAdder, sourceFile, containingFunction, program, host, cancellationToken); - declaration = containingFunction; + function printUnescapedSnippetList(format, list, sourceFile) { + escapes = void 0; + writer.clear(); + printer.writeList(format, list, sourceFile, writer); + return writer.getText(); + } + function printAndFormatSnippetList(format, list, sourceFile, formatContext) { + const syntheticFile = { + text: printUnescapedSnippetList( + format, + list, + sourceFile + ), + getLineAndCharacterOfPosition(pos) { + return getLineAndCharacterOfPosition(this, pos); } - break; - case Diagnostics.this_implicitly_has_type_any_because_it_does_not_have_a_type_annotation.code: - if (ts_textChanges_exports.isThisTypeAnnotatable(containingFunction) && markSeen(containingFunction)) { - annotateThis(changes, sourceFile, containingFunction, program, host, cancellationToken); - declaration = containingFunction; + }; + const formatOptions = getFormatCodeSettingsForWriting(formatContext, sourceFile); + const changes = flatMap(list, (node) => { + const nodeWithPos = ts_textChanges_exports.assignPositionsToNode(node); + return ts_formatting_exports.formatNodeGivenIndentation( + nodeWithPos, + syntheticFile, + sourceFile.languageVariant, + /* indentation */ + 0, + /* delta */ + 0, + { ...formatContext, options: formatOptions } + ); + }); + const allChanges = escapes ? stableSort(concatenate(changes, escapes), (a, b) => compareTextSpans(a.span, b.span)) : changes; + return ts_textChanges_exports.applyChanges(syntheticFile.text, allChanges); + } + function printNode(hint, node, sourceFile) { + const unescaped = printUnescapedNode(hint, node, sourceFile); + return escapes ? ts_textChanges_exports.applyChanges(unescaped, escapes) : unescaped; + } + function printUnescapedNode(hint, node, sourceFile) { + escapes = void 0; + writer.clear(); + printer.writeNode(hint, node, sourceFile, writer); + return writer.getText(); + } + function printAndFormatNode(hint, node, sourceFile, formatContext) { + const syntheticFile = { + text: printUnescapedNode( + hint, + node, + sourceFile + ), + getLineAndCharacterOfPosition(pos) { + return getLineAndCharacterOfPosition(this, pos); } - break; - default: - return Debug.fail(String(errorCode)); + }; + const formatOptions = getFormatCodeSettingsForWriting(formatContext, sourceFile); + const nodeWithPos = ts_textChanges_exports.assignPositionsToNode(node); + const changes = ts_formatting_exports.formatNodeGivenIndentation( + nodeWithPos, + syntheticFile, + sourceFile.languageVariant, + /* indentation */ + 0, + /* delta */ + 0, + { ...formatContext, options: formatOptions } + ); + const allChanges = escapes ? stableSort(concatenate(changes, escapes), (a, b) => compareTextSpans(a.span, b.span)) : changes; + return ts_textChanges_exports.applyChanges(syntheticFile.text, allChanges); } - importAdder.writeFixes(changes); - return declaration; } - function annotateVariableDeclaration(changes, importAdder, sourceFile, declaration, program, host, cancellationToken) { - if (isIdentifier(declaration.name)) { - annotate(changes, importAdder, sourceFile, declaration, inferTypeForVariableFromUsage(declaration.name, program, cancellationToken), program, host); + function originToCompletionEntryData(origin) { + const ambientModuleName = origin.fileName ? void 0 : stripQuotes(origin.moduleSymbol.name); + const isPackageJsonImport = origin.isFromPackageJson ? true : void 0; + if (originIsResolvedExport(origin)) { + const resolvedData = { + exportName: origin.exportName, + exportMapKey: origin.exportMapKey, + moduleSpecifier: origin.moduleSpecifier, + ambientModuleName, + fileName: origin.fileName, + isPackageJsonImport + }; + return resolvedData; } + const unresolvedData = { + exportName: origin.exportName, + exportMapKey: origin.exportMapKey, + fileName: origin.fileName, + ambientModuleName: origin.fileName ? void 0 : stripQuotes(origin.moduleSymbol.name), + isPackageJsonImport: origin.isFromPackageJson ? true : void 0 + }; + return unresolvedData; } - function annotateParameters(changes, importAdder, sourceFile, parameterDeclaration, containingFunction, program, host, cancellationToken) { - if (!isIdentifier(parameterDeclaration.name)) { - return; + function completionEntryDataToSymbolOriginInfo(data, completionName, moduleSymbol) { + const isDefaultExport = data.exportName === "default" /* Default */; + const isFromPackageJson = !!data.isPackageJsonImport; + if (completionEntryDataIsResolved(data)) { + const resolvedOrigin = { + kind: 32 /* ResolvedExport */, + exportName: data.exportName, + exportMapKey: data.exportMapKey, + moduleSpecifier: data.moduleSpecifier, + symbolName: completionName, + fileName: data.fileName, + moduleSymbol, + isDefaultExport, + isFromPackageJson + }; + return resolvedOrigin; } - const parameterInferences = inferTypeForParametersFromUsage(containingFunction, sourceFile, program, cancellationToken); - Debug.assert(containingFunction.parameters.length === parameterInferences.length, "Parameter count and inference count should match"); - if (isInJSFile(containingFunction)) { - annotateJSDocParameters(changes, sourceFile, parameterInferences, program, host); - } else { - const needParens = isArrowFunction(containingFunction) && !findChildOfKind(containingFunction, 21 /* OpenParenToken */, sourceFile); - if (needParens) - changes.insertNodeBefore(sourceFile, first(containingFunction.parameters), factory.createToken(21 /* OpenParenToken */)); - for (const { declaration, type } of parameterInferences) { - if (declaration && !declaration.type && !declaration.initializer) { - annotate(changes, importAdder, sourceFile, declaration, type, program, host); - } - } - if (needParens) - changes.insertNodeAfter(sourceFile, last(containingFunction.parameters), factory.createToken(22 /* CloseParenToken */)); + const unresolvedOrigin = { + kind: 4 /* Export */, + exportName: data.exportName, + exportMapKey: data.exportMapKey, + symbolName: completionName, + fileName: data.fileName, + moduleSymbol, + isDefaultExport, + isFromPackageJson + }; + return unresolvedOrigin; + } + function getInsertTextAndReplacementSpanForImportCompletion(name, importStatementCompletion, origin, useSemicolons, sourceFile, options, preferences) { + const replacementSpan = importStatementCompletion.replacementSpan; + const quotedModuleSpecifier = escapeSnippetText(quote(sourceFile, preferences, origin.moduleSpecifier)); + const exportKind = origin.isDefaultExport ? 1 /* Default */ : origin.exportName === "export=" /* ExportEquals */ ? 2 /* ExportEquals */ : 0 /* Named */; + const tabStop = preferences.includeCompletionsWithSnippetText ? "$1" : ""; + const importKind = ts_codefix_exports.getImportKind( + sourceFile, + exportKind, + options, + /*forceImportKeyword*/ + true + ); + const isImportSpecifierTypeOnly = importStatementCompletion.couldBeTypeOnlyImportSpecifier; + const topLevelTypeOnlyText = importStatementCompletion.isTopLevelTypeOnly ? ` ${tokenToString(156 /* TypeKeyword */)} ` : " "; + const importSpecifierTypeOnlyText = isImportSpecifierTypeOnly ? `${tokenToString(156 /* TypeKeyword */)} ` : ""; + const suffix = useSemicolons ? ";" : ""; + switch (importKind) { + case 3 /* CommonJS */: + return { replacementSpan, insertText: `import${topLevelTypeOnlyText}${escapeSnippetText(name)}${tabStop} = require(${quotedModuleSpecifier})${suffix}` }; + case 1 /* Default */: + return { replacementSpan, insertText: `import${topLevelTypeOnlyText}${escapeSnippetText(name)}${tabStop} from ${quotedModuleSpecifier}${suffix}` }; + case 2 /* Namespace */: + return { replacementSpan, insertText: `import${topLevelTypeOnlyText}* as ${escapeSnippetText(name)} from ${quotedModuleSpecifier}${suffix}` }; + case 0 /* Named */: + return { replacementSpan, insertText: `import${topLevelTypeOnlyText}{ ${importSpecifierTypeOnlyText}${escapeSnippetText(name)}${tabStop} } from ${quotedModuleSpecifier}${suffix}` }; } } - function annotateThis(changes, sourceFile, containingFunction, program, host, cancellationToken) { - const references = getFunctionReferences(containingFunction, sourceFile, program, cancellationToken); - if (!references || !references.length) { - return; + function quotePropertyName(sourceFile, preferences, name) { + if (/^\d+$/.test(name)) { + return name; } - const thisInference = inferTypeFromReferences(program, references, cancellationToken).thisParameter(); - const typeNode = getTypeNodeIfAccessible(thisInference, containingFunction, program, host); - if (!typeNode) { - return; + return quote(sourceFile, preferences, name); + } + function isRecommendedCompletionMatch(localSymbol, recommendedCompletion, checker) { + return localSymbol === recommendedCompletion || !!(localSymbol.flags & 1048576 /* ExportValue */) && checker.getExportSymbolOfSymbol(localSymbol) === recommendedCompletion; + } + function getSourceFromOrigin(origin) { + if (originIsExport(origin)) { + return stripQuotes(origin.moduleSymbol.name); } - if (isInJSFile(containingFunction)) { - annotateJSDocThis(changes, sourceFile, containingFunction, typeNode); - } else { - changes.tryInsertThisTypeAnnotation(sourceFile, containingFunction, typeNode); + if (originIsResolvedExport(origin)) { + return origin.moduleSpecifier; + } + if ((origin == null ? void 0 : origin.kind) === 1 /* ThisType */) { + return "ThisProperty/" /* ThisProperty */; + } + if ((origin == null ? void 0 : origin.kind) === 64 /* TypeOnlyAlias */) { + return "TypeOnlyAlias/" /* TypeOnlyAlias */; } } - function annotateJSDocThis(changes, sourceFile, containingFunction, typeNode) { - changes.addJSDocTags(sourceFile, containingFunction, [ - factory.createJSDocThisTag( - /*tagName*/ - void 0, - factory.createJSDocTypeExpression(typeNode) - ) - ]); - } - function annotateSetAccessor(changes, importAdder, sourceFile, setAccessorDeclaration, program, host, cancellationToken) { - const param = firstOrUndefined(setAccessorDeclaration.parameters); - if (param && isIdentifier(setAccessorDeclaration.name) && isIdentifier(param.name)) { - let type = inferTypeForVariableFromUsage(setAccessorDeclaration.name, program, cancellationToken); - if (type === program.getTypeChecker().getAnyType()) { - type = inferTypeForVariableFromUsage(param.name, program, cancellationToken); + function getCompletionEntriesFromSymbols(symbols, entries, replacementToken, contextToken, location, position, sourceFile, host, program, target, log, kind, preferences, compilerOptions, formatContext, isTypeOnlyLocation, propertyAccessToConvert, jsxIdentifierExpected, isJsxInitializer, importStatementCompletion, recommendedCompletion, symbolToOriginInfoMap, symbolToSortTextMap, isJsxIdentifierExpected, isRightOfOpenTag, includeSymbol = false) { + const start = timestamp(); + const variableOrParameterDeclaration = getVariableOrParameterDeclaration(contextToken, location); + const useSemicolons = probablyUsesSemicolons(sourceFile); + const typeChecker = program.getTypeChecker(); + const uniques = /* @__PURE__ */ new Map(); + for (let i = 0; i < symbols.length; i++) { + const symbol = symbols[i]; + const origin = symbolToOriginInfoMap == null ? void 0 : symbolToOriginInfoMap[i]; + const info = getCompletionEntryDisplayNameForSymbol(symbol, target, origin, kind, !!jsxIdentifierExpected); + if (!info || uniques.get(info.name) && (!origin || !originIsObjectLiteralMethod(origin)) || kind === 1 /* Global */ && symbolToSortTextMap && !shouldIncludeSymbol(symbol, symbolToSortTextMap)) { + continue; } - if (isInJSFile(setAccessorDeclaration)) { - annotateJSDocParameters(changes, sourceFile, [{ declaration: param, type }], program, host); - } else { - annotate(changes, importAdder, sourceFile, param, type, program, host); + const { name, needsConvertPropertyAccess } = info; + const originalSortText = (symbolToSortTextMap == null ? void 0 : symbolToSortTextMap[getSymbolId(symbol)]) ?? SortText.LocationPriority; + const sortText = isDeprecated(symbol, typeChecker) ? SortText.Deprecated(originalSortText) : originalSortText; + const entry = createCompletionEntry( + symbol, + sortText, + replacementToken, + contextToken, + location, + position, + sourceFile, + host, + program, + name, + needsConvertPropertyAccess, + origin, + recommendedCompletion, + propertyAccessToConvert, + isJsxInitializer, + importStatementCompletion, + useSemicolons, + compilerOptions, + preferences, + kind, + formatContext, + isJsxIdentifierExpected, + isRightOfOpenTag, + includeSymbol + ); + if (!entry) { + continue; } + const shouldShadowLaterSymbols = (!origin || originIsTypeOnlyAlias(origin)) && !(symbol.parent === void 0 && !some(symbol.declarations, (d) => d.getSourceFile() === location.getSourceFile())); + uniques.set(name, shouldShadowLaterSymbols); + insertSorted( + entries, + entry, + compareCompletionEntries, + /*allowDuplicates*/ + true + ); } - } - function annotate(changes, importAdder, sourceFile, declaration, type, program, host) { - const typeNode = getTypeNodeIfAccessible(type, declaration, program, host); - if (typeNode) { - if (isInJSFile(sourceFile) && declaration.kind !== 170 /* PropertySignature */) { - const parent2 = isVariableDeclaration(declaration) ? tryCast(declaration.parent.parent, isVariableStatement) : declaration; - if (!parent2) { - return; + log("getCompletionsAtPosition: getCompletionEntriesFromSymbols: " + (timestamp() - start)); + return { + has: (name) => uniques.has(name), + add: (name) => uniques.set(name, true) + }; + function shouldIncludeSymbol(symbol, symbolToSortTextMap2) { + var _a; + let allFlags = symbol.flags; + if (!isSourceFile(location)) { + if (isExportAssignment(location.parent)) { + return true; + } + if (tryCast(variableOrParameterDeclaration, isVariableDeclaration) && symbol.valueDeclaration === variableOrParameterDeclaration) { + return false; + } + const symbolDeclaration = symbol.valueDeclaration ?? ((_a = symbol.declarations) == null ? void 0 : _a[0]); + if (variableOrParameterDeclaration && symbolDeclaration && (isTypeParameterDeclaration(variableOrParameterDeclaration) && isTypeParameterDeclaration(symbolDeclaration) || isParameter(variableOrParameterDeclaration) && isParameter(symbolDeclaration))) { + const symbolDeclarationPos = symbolDeclaration.pos; + const parameters = isParameter(variableOrParameterDeclaration) ? variableOrParameterDeclaration.parent.parameters : isInferTypeNode(variableOrParameterDeclaration.parent) ? void 0 : variableOrParameterDeclaration.parent.typeParameters; + if (symbolDeclarationPos >= variableOrParameterDeclaration.pos && parameters && symbolDeclarationPos < parameters.end) { + return false; + } + } + const symbolOrigin = skipAlias(symbol, typeChecker); + if (!!sourceFile.externalModuleIndicator && !compilerOptions.allowUmdGlobalAccess && symbolToSortTextMap2[getSymbolId(symbol)] === SortText.GlobalsOrKeywords && (symbolToSortTextMap2[getSymbolId(symbolOrigin)] === SortText.AutoImportSuggestions || symbolToSortTextMap2[getSymbolId(symbolOrigin)] === SortText.LocationPriority)) { + return false; + } + allFlags |= getCombinedLocalAndExportSymbolFlags(symbolOrigin); + if (isInRightSideOfInternalImportEqualsDeclaration(location)) { + return !!(allFlags & 1920 /* Namespace */); + } + if (isTypeOnlyLocation) { + return symbolCanBeReferencedAtTypeLocation(symbol, typeChecker); } - const typeExpression = factory.createJSDocTypeExpression(typeNode); - const typeTag = isGetAccessorDeclaration(declaration) ? factory.createJSDocReturnTag( - /*tagName*/ - void 0, - typeExpression, - /*comment*/ - void 0 - ) : factory.createJSDocTypeTag( - /*tagName*/ - void 0, - typeExpression, - /*comment*/ - void 0 - ); - changes.addJSDocTags(sourceFile, parent2, [typeTag]); - } else if (!tryReplaceImportTypeNodeWithAutoImport(typeNode, declaration, sourceFile, changes, importAdder, getEmitScriptTarget(program.getCompilerOptions()))) { - changes.tryInsertTypeAnnotation(sourceFile, declaration, typeNode); } + return !!(allFlags & 111551 /* Value */); } } - function tryReplaceImportTypeNodeWithAutoImport(typeNode, declaration, sourceFile, changes, importAdder, scriptTarget) { - const importableReference = tryGetAutoImportableReferenceFromTypeNode(typeNode, scriptTarget); - if (importableReference && changes.tryInsertTypeAnnotation(sourceFile, declaration, importableReference.typeNode)) { - forEach(importableReference.symbols, (s) => importAdder.addImportFromExportedSymbol( - s, - /*isValidTypeOnlyUseSite*/ - true - )); - return true; + function getLabelCompletionAtPosition(node) { + const entries = getLabelStatementCompletions(node); + if (entries.length) { + return { isGlobalCompletion: false, isMemberCompletion: false, isNewIdentifierLocation: false, entries }; } - return false; } - function annotateJSDocParameters(changes, sourceFile, parameterInferences, program, host) { - const signature = parameterInferences.length && parameterInferences[0].declaration.parent; - if (!signature) { - return; - } - const inferences = mapDefined(parameterInferences, (inference) => { - const param = inference.declaration; - if (param.initializer || getJSDocType(param) || !isIdentifier(param.name)) { - return; + function getLabelStatementCompletions(node) { + const entries = []; + const uniques = /* @__PURE__ */ new Map(); + let current = node; + while (current) { + if (isFunctionLike(current)) { + break; } - const typeNode = inference.type && getTypeNodeIfAccessible(inference.type, param, program, host); - if (typeNode) { - const name = factory.cloneNode(param.name); - setEmitFlags(name, 3072 /* NoComments */ | 4096 /* NoNestedComments */); - return { name: factory.cloneNode(param.name), param, isOptional: !!inference.isOptional, typeNode }; + if (isLabeledStatement(current)) { + const name = current.label.text; + if (!uniques.has(name)) { + uniques.set(name, true); + entries.push({ + name, + kindModifiers: "" /* none */, + kind: "label" /* label */, + sortText: SortText.LocationPriority + }); + } } - }); - if (!inferences.length) { - return; + current = current.parent; } - if (isArrowFunction(signature) || isFunctionExpression(signature)) { - const needParens = isArrowFunction(signature) && !findChildOfKind(signature, 21 /* OpenParenToken */, sourceFile); - if (needParens) { - changes.insertNodeBefore(sourceFile, first(signature.parameters), factory.createToken(21 /* OpenParenToken */)); - } - forEach(inferences, ({ typeNode, param }) => { - const typeTag = factory.createJSDocTypeTag( - /*tagName*/ - void 0, - factory.createJSDocTypeExpression(typeNode) - ); - const jsDoc = factory.createJSDocComment( - /*comment*/ - void 0, - [typeTag] - ); - changes.insertNodeAt(sourceFile, param.getStart(sourceFile), jsDoc, { suffix: " " }); - }); - if (needParens) { - changes.insertNodeAfter(sourceFile, last(signature.parameters), factory.createToken(22 /* CloseParenToken */)); + return entries; + } + function getSymbolCompletionFromEntryId(program, log, sourceFile, position, entryId, host, preferences) { + if (entryId.source === "SwitchCases/" /* SwitchCases */) { + return { type: "cases" }; + } + if (entryId.data) { + const autoImport = getAutoImportSymbolFromCompletionEntryData(entryId.name, entryId.data, program, host); + if (autoImport) { + const { contextToken: contextToken2, previousToken: previousToken2 } = getRelevantTokens(position, sourceFile); + return { + type: "symbol", + symbol: autoImport.symbol, + location: getTouchingPropertyName(sourceFile, position), + previousToken: previousToken2, + contextToken: contextToken2, + isJsxInitializer: false, + isTypeOnlyLocation: false, + origin: autoImport.origin + }; } - } else { - const paramTags = map(inferences, ({ name, typeNode, isOptional }) => factory.createJSDocParameterTag( - /*tagName*/ - void 0, - name, - /*isBracketed*/ - !!isOptional, - factory.createJSDocTypeExpression(typeNode), - /*isNameFirst*/ - false, - /*comment*/ - void 0 - )); - changes.addJSDocTags(sourceFile, signature, paramTags); } - } - function getReferences(token, program, cancellationToken) { - return mapDefined(ts_FindAllReferences_exports.getReferenceEntriesForNode(-1, token, program, program.getSourceFiles(), cancellationToken), (entry) => entry.kind !== ts_FindAllReferences_exports.EntryKind.Span ? tryCast(entry.node, isIdentifier) : void 0); - } - function inferTypeForVariableFromUsage(token, program, cancellationToken) { - const references = getReferences(token, program, cancellationToken); - return inferTypeFromReferences(program, references, cancellationToken).single(); - } - function inferTypeForParametersFromUsage(func, sourceFile, program, cancellationToken) { - const references = getFunctionReferences(func, sourceFile, program, cancellationToken); - return references && inferTypeFromReferences(program, references, cancellationToken).parameters(func) || func.parameters.map((p) => ({ - declaration: p, - type: isIdentifier(p.name) ? inferTypeForVariableFromUsage(p.name, program, cancellationToken) : program.getTypeChecker().getAnyType() - })); - } - function getFunctionReferences(containingFunction, sourceFile, program, cancellationToken) { - let searchToken; - switch (containingFunction.kind) { - case 175 /* Constructor */: - searchToken = findChildOfKind(containingFunction, 137 /* ConstructorKeyword */, sourceFile); - break; - case 218 /* ArrowFunction */: - case 217 /* FunctionExpression */: - const parent2 = containingFunction.parent; - searchToken = (isVariableDeclaration(parent2) || isPropertyDeclaration(parent2)) && isIdentifier(parent2.name) ? parent2.name : containingFunction.name; - break; - case 261 /* FunctionDeclaration */: - case 173 /* MethodDeclaration */: - case 172 /* MethodSignature */: - searchToken = containingFunction.name; - break; + const compilerOptions = program.getCompilerOptions(); + const completionData = getCompletionData( + program, + log, + sourceFile, + compilerOptions, + position, + { includeCompletionsForModuleExports: true, includeCompletionsWithInsertText: true }, + entryId, + host, + /*formatContext*/ + void 0 + ); + if (!completionData) { + return { type: "none" }; } - if (!searchToken) { - return void 0; + if (completionData.kind !== 0 /* Data */) { + return { type: "request", request: completionData }; } - return getReferences(searchToken, program, cancellationToken); + const { symbols, literals, location, completionKind, symbolToOriginInfoMap, contextToken, previousToken, isJsxInitializer, isTypeOnlyLocation } = completionData; + const literal = find(literals, (l) => completionNameForLiteral(sourceFile, preferences, l) === entryId.name); + if (literal !== void 0) + return { type: "literal", literal }; + return firstDefined(symbols, (symbol, index) => { + const origin = symbolToOriginInfoMap[index]; + const info = getCompletionEntryDisplayNameForSymbol(symbol, getEmitScriptTarget(compilerOptions), origin, completionKind, completionData.isJsxIdentifierExpected); + return info && info.name === entryId.name && (entryId.source === "ClassMemberSnippet/" /* ClassMemberSnippet */ && symbol.flags & 106500 /* ClassMember */ || entryId.source === "ObjectLiteralMethodSnippet/" /* ObjectLiteralMethodSnippet */ && symbol.flags & (4 /* Property */ | 8192 /* Method */) || getSourceFromOrigin(origin) === entryId.source || entryId.source === "ObjectLiteralMemberWithComma/" /* ObjectLiteralMemberWithComma */) ? { type: "symbol", symbol, location, origin, contextToken, previousToken, isJsxInitializer, isTypeOnlyLocation } : void 0; + }) || { type: "none" }; } - function inferTypeFromReferences(program, references, cancellationToken) { - const checker = program.getTypeChecker(); - const builtinConstructors = { - string: () => checker.getStringType(), - number: () => checker.getNumberType(), - Array: (t) => checker.createArrayType(t), - Promise: (t) => checker.createPromiseType(t) - }; - const builtins = [ - checker.getStringType(), - checker.getNumberType(), - checker.createArrayType(checker.getAnyType()), - checker.createPromiseType(checker.getAnyType()) - ]; - return { - single: single2, - parameters, - thisParameter - }; - function createEmptyUsage() { - return { - isNumber: void 0, - isString: void 0, - isNumberOrString: void 0, - candidateTypes: void 0, - properties: void 0, - calls: void 0, - constructs: void 0, - numberIndex: void 0, - stringIndex: void 0, - candidateThisTypes: void 0, - inferredTypes: void 0 - }; + function getCompletionEntryDetails(program, log, sourceFile, position, entryId, host, formatContext, preferences, cancellationToken) { + const typeChecker = program.getTypeChecker(); + const compilerOptions = program.getCompilerOptions(); + const { name, source, data } = entryId; + const { previousToken, contextToken } = getRelevantTokens(position, sourceFile); + if (isInString(sourceFile, position, previousToken)) { + return ts_Completions_StringCompletions_exports.getStringLiteralCompletionDetails(name, sourceFile, position, previousToken, typeChecker, compilerOptions, host, cancellationToken, preferences); } - function combineUsages(usages) { - const combinedProperties = /* @__PURE__ */ new Map(); - for (const u of usages) { - if (u.properties) { - u.properties.forEach((p, name) => { - if (!combinedProperties.has(name)) { - combinedProperties.set(name, []); - } - combinedProperties.get(name).push(p); - }); + const symbolCompletion = getSymbolCompletionFromEntryId(program, log, sourceFile, position, entryId, host, preferences); + switch (symbolCompletion.type) { + case "request": { + const { request } = symbolCompletion; + switch (request.kind) { + case 1 /* JsDocTagName */: + return ts_JsDoc_exports.getJSDocTagNameCompletionDetails(name); + case 2 /* JsDocTag */: + return ts_JsDoc_exports.getJSDocTagCompletionDetails(name); + case 3 /* JsDocParameterName */: + return ts_JsDoc_exports.getJSDocParameterNameCompletionDetails(name); + case 4 /* Keywords */: + return some(request.keywordCompletions, (c) => c.name === name) ? createSimpleDetails(name, "keyword" /* keyword */, 5 /* keyword */) : void 0; + default: + return Debug.assertNever(request); } } - const properties = /* @__PURE__ */ new Map(); - combinedProperties.forEach((ps, name) => { - properties.set(name, combineUsages(ps)); - }); - return { - isNumber: usages.some((u) => u.isNumber), - isString: usages.some((u) => u.isString), - isNumberOrString: usages.some((u) => u.isNumberOrString), - candidateTypes: flatMap(usages, (u) => u.candidateTypes), - properties, - calls: flatMap(usages, (u) => u.calls), - constructs: flatMap(usages, (u) => u.constructs), - numberIndex: forEach(usages, (u) => u.numberIndex), - stringIndex: forEach(usages, (u) => u.stringIndex), - candidateThisTypes: flatMap(usages, (u) => u.candidateThisTypes), - inferredTypes: void 0 - // clear type cache - }; - } - function single2() { - return combineTypes(inferTypesFromReferencesSingle(references)); - } - function parameters(declaration) { - if (references.length === 0 || !declaration.parameters) { - return void 0; + case "symbol": { + const { symbol, location, contextToken: contextToken2, origin, previousToken: previousToken2 } = symbolCompletion; + const { codeActions, sourceDisplay } = getCompletionEntryCodeActionsAndSourceDisplay(name, location, contextToken2, origin, symbol, program, host, compilerOptions, sourceFile, position, previousToken2, formatContext, preferences, data, source, cancellationToken); + const symbolName2 = originIsComputedPropertyName(origin) ? origin.symbolName : symbol.name; + return createCompletionDetailsForSymbol(symbol, symbolName2, typeChecker, sourceFile, location, cancellationToken, codeActions, sourceDisplay); } - const usage = createEmptyUsage(); - for (const reference of references) { - cancellationToken.throwIfCancellationRequested(); - calculateUsageOfNode(reference, usage); + case "literal": { + const { literal } = symbolCompletion; + return createSimpleDetails(completionNameForLiteral(sourceFile, preferences, literal), "string" /* string */, typeof literal === "string" ? 8 /* stringLiteral */ : 7 /* numericLiteral */); } - const calls = [...usage.constructs || [], ...usage.calls || []]; - return declaration.parameters.map((parameter, parameterIndex) => { - const types = []; - const isRest = isRestParameter(parameter); - let isOptional = false; - for (const call of calls) { - if (call.argumentTypes.length <= parameterIndex) { - isOptional = isInJSFile(declaration); - types.push(checker.getUndefinedType()); - } else if (isRest) { - for (let i = parameterIndex; i < call.argumentTypes.length; i++) { - types.push(checker.getBaseTypeOfLiteralType(call.argumentTypes[i])); - } - } else { - types.push(checker.getBaseTypeOfLiteralType(call.argumentTypes[parameterIndex])); - } - } - if (isIdentifier(parameter.name)) { - const inferred = inferTypesFromReferencesSingle(getReferences(parameter.name, program, cancellationToken)); - types.push(...isRest ? mapDefined(inferred, checker.getElementTypeOfArrayType) : inferred); + case "cases": { + const snippets = getExhaustiveCaseSnippets( + contextToken.parent, + sourceFile, + preferences, + program.getCompilerOptions(), + host, + program, + /*formatContext*/ + void 0 + ); + if (snippets == null ? void 0 : snippets.importAdder.hasFixes()) { + const { entry, importAdder } = snippets; + const changes = ts_textChanges_exports.ChangeTracker.with( + { host, formatContext, preferences }, + importAdder.writeFixes + ); + return { + name: entry.name, + kind: "" /* unknown */, + kindModifiers: "", + displayParts: [], + sourceDisplay: void 0, + codeActions: [{ + changes, + description: diagnosticToString([Diagnostics.Includes_imports_of_types_referenced_by_0, name]) + }] + }; } - const type = combineTypes(types); return { - type: isRest ? checker.createArrayType(type) : type, - isOptional: isOptional && !isRest, - declaration: parameter + name, + kind: "" /* unknown */, + kindModifiers: "", + displayParts: [], + sourceDisplay: void 0 }; - }); - } - function thisParameter() { - const usage = createEmptyUsage(); - for (const reference of references) { - cancellationToken.throwIfCancellationRequested(); - calculateUsageOfNode(reference, usage); } - return combineTypes(usage.candidateThisTypes || emptyArray); + case "none": + return allKeywordsCompletions().some((c) => c.name === name) ? createSimpleDetails(name, "keyword" /* keyword */, 5 /* keyword */) : void 0; + default: + Debug.assertNever(symbolCompletion); } - function inferTypesFromReferencesSingle(references2) { - const usage = createEmptyUsage(); - for (const reference of references2) { - cancellationToken.throwIfCancellationRequested(); - calculateUsageOfNode(reference, usage); + } + function createSimpleDetails(name, kind, kind2) { + return createCompletionDetails(name, "" /* none */, kind, [displayPart(name, kind2)]); + } + function createCompletionDetailsForSymbol(symbol, name, checker, sourceFile, location, cancellationToken, codeActions, sourceDisplay) { + const { displayParts, documentation, symbolKind, tags } = checker.runWithCancellationToken(cancellationToken, (checker2) => ts_SymbolDisplay_exports.getSymbolDisplayPartsDocumentationAndSymbolKind(checker2, symbol, sourceFile, location, location, 7 /* All */)); + return createCompletionDetails(name, ts_SymbolDisplay_exports.getSymbolModifiers(checker, symbol), symbolKind, displayParts, documentation, tags, codeActions, sourceDisplay); + } + function createCompletionDetails(name, kindModifiers, kind, displayParts, documentation, tags, codeActions, source) { + return { name, kindModifiers, kind, displayParts, documentation, tags, codeActions, source, sourceDisplay: source }; + } + function getCompletionEntryCodeActionsAndSourceDisplay(name, location, contextToken, origin, symbol, program, host, compilerOptions, sourceFile, position, previousToken, formatContext, preferences, data, source, cancellationToken) { + if (data == null ? void 0 : data.moduleSpecifier) { + if (previousToken && getImportStatementCompletionInfo(contextToken || previousToken, sourceFile).replacementSpan) { + return { codeActions: void 0, sourceDisplay: [textPart(data.moduleSpecifier)] }; } - return inferTypes(usage); } - function calculateUsageOfNode(node, usage) { - while (isRightSideOfQualifiedNameOrPropertyAccess(node)) { - node = node.parent; - } - switch (node.parent.kind) { - case 243 /* ExpressionStatement */: - inferTypeFromExpressionStatement(node, usage); - break; - case 224 /* PostfixUnaryExpression */: - usage.isNumber = true; - break; - case 223 /* PrefixUnaryExpression */: - inferTypeFromPrefixUnaryExpression(node.parent, usage); - break; - case 225 /* BinaryExpression */: - inferTypeFromBinaryExpression(node, node.parent, usage); - break; - case 295 /* CaseClause */: - case 296 /* DefaultClause */: - inferTypeFromSwitchStatementLabel(node.parent, usage); - break; - case 212 /* CallExpression */: - case 213 /* NewExpression */: - if (node.parent.expression === node) { - inferTypeFromCallExpression(node.parent, usage); - } else { - inferTypeFromContextualType(node, usage); - } - break; - case 210 /* PropertyAccessExpression */: - inferTypeFromPropertyAccessExpression(node.parent, usage); - break; - case 211 /* ElementAccessExpression */: - inferTypeFromPropertyElementExpression(node.parent, node, usage); - break; - case 302 /* PropertyAssignment */: - case 303 /* ShorthandPropertyAssignment */: - inferTypeFromPropertyAssignment(node.parent, usage); - break; - case 171 /* PropertyDeclaration */: - inferTypeFromPropertyDeclaration(node.parent, usage); - break; - case 259 /* VariableDeclaration */: { - const { name, initializer } = node.parent; - if (node === name) { - if (initializer) { - addCandidateType(usage, checker.getTypeAtLocation(initializer)); + if (source === "ClassMemberSnippet/" /* ClassMemberSnippet */) { + const { importAdder, eraseRange } = getEntryForMemberCompletion( + host, + program, + compilerOptions, + preferences, + name, + symbol, + location, + position, + contextToken, + formatContext + ); + if (importAdder || eraseRange) { + const changes = ts_textChanges_exports.ChangeTracker.with( + { host, formatContext, preferences }, + (tracker) => { + if (importAdder) { + importAdder.writeFixes(tracker); + } + if (eraseRange) { + tracker.deleteRange(sourceFile, eraseRange); } - break; } - } - default: - return inferTypeFromContextualType(node, usage); - } - } - function inferTypeFromContextualType(node, usage) { - if (isExpressionNode(node)) { - addCandidateType(usage, checker.getContextualType(node)); + ); + return { + sourceDisplay: void 0, + codeActions: [{ + changes, + description: diagnosticToString([Diagnostics.Includes_imports_of_types_referenced_by_0, name]) + }] + }; } } - function inferTypeFromExpressionStatement(node, usage) { - addCandidateType(usage, isCallExpression(node) ? checker.getVoidType() : checker.getAnyType()); - } - function inferTypeFromPrefixUnaryExpression(node, usage) { - switch (node.operator) { - case 46 /* PlusPlusToken */: - case 47 /* MinusMinusToken */: - case 41 /* MinusToken */: - case 55 /* TildeToken */: - usage.isNumber = true; - break; - case 40 /* PlusToken */: - usage.isNumberOrString = true; - break; - } + if (originIsTypeOnlyAlias(origin)) { + const codeAction2 = ts_codefix_exports.getPromoteTypeOnlyCompletionAction( + sourceFile, + origin.declaration.name, + program, + host, + formatContext, + preferences + ); + Debug.assertIsDefined(codeAction2, "Expected to have a code action for promoting type-only alias"); + return { codeActions: [codeAction2], sourceDisplay: void 0 }; } - function inferTypeFromBinaryExpression(node, parent2, usage) { - switch (parent2.operatorToken.kind) { - case 43 /* AsteriskAsteriskToken */: - case 42 /* AsteriskToken */: - case 44 /* SlashToken */: - case 45 /* PercentToken */: - case 48 /* LessThanLessThanToken */: - case 49 /* GreaterThanGreaterThanToken */: - case 50 /* GreaterThanGreaterThanGreaterThanToken */: - case 51 /* AmpersandToken */: - case 52 /* BarToken */: - case 53 /* CaretToken */: - case 66 /* MinusEqualsToken */: - case 68 /* AsteriskAsteriskEqualsToken */: - case 67 /* AsteriskEqualsToken */: - case 69 /* SlashEqualsToken */: - case 70 /* PercentEqualsToken */: - case 74 /* AmpersandEqualsToken */: - case 75 /* BarEqualsToken */: - case 79 /* CaretEqualsToken */: - case 71 /* LessThanLessThanEqualsToken */: - case 73 /* GreaterThanGreaterThanGreaterThanEqualsToken */: - case 72 /* GreaterThanGreaterThanEqualsToken */: - case 41 /* MinusToken */: - case 30 /* LessThanToken */: - case 33 /* LessThanEqualsToken */: - case 32 /* GreaterThanToken */: - case 34 /* GreaterThanEqualsToken */: - const operandType = checker.getTypeAtLocation(parent2.left === node ? parent2.right : parent2.left); - if (operandType.flags & 1056 /* EnumLike */) { - addCandidateType(usage, operandType); - } else { - usage.isNumber = true; - } - break; - case 65 /* PlusEqualsToken */: - case 40 /* PlusToken */: - const otherOperandType = checker.getTypeAtLocation(parent2.left === node ? parent2.right : parent2.left); - if (otherOperandType.flags & 1056 /* EnumLike */) { - addCandidateType(usage, otherOperandType); - } else if (otherOperandType.flags & 296 /* NumberLike */) { - usage.isNumber = true; - } else if (otherOperandType.flags & 402653316 /* StringLike */) { - usage.isString = true; - } else if (otherOperandType.flags & 1 /* Any */) { - } else { - usage.isNumberOrString = true; - } - break; - case 64 /* EqualsToken */: - case 35 /* EqualsEqualsToken */: - case 37 /* EqualsEqualsEqualsToken */: - case 38 /* ExclamationEqualsEqualsToken */: - case 36 /* ExclamationEqualsToken */: - case 77 /* AmpersandAmpersandEqualsToken */: - case 78 /* QuestionQuestionEqualsToken */: - case 76 /* BarBarEqualsToken */: - addCandidateType(usage, checker.getTypeAtLocation(parent2.left === node ? parent2.right : parent2.left)); - break; - case 103 /* InKeyword */: - if (node === parent2.left) { - usage.isString = true; - } - break; - case 57 /* BarBarToken */: - case 61 /* QuestionQuestionToken */: - if (node === parent2.left && (node.parent.parent.kind === 259 /* VariableDeclaration */ || isAssignmentExpression( - node.parent.parent, - /*excludeCompoundAssignment*/ - true - ))) { - addCandidateType(usage, checker.getTypeAtLocation(parent2.right)); - } - break; - case 56 /* AmpersandAmpersandToken */: - case 28 /* CommaToken */: - case 104 /* InstanceOfKeyword */: - break; + if (source === "ObjectLiteralMemberWithComma/" /* ObjectLiteralMemberWithComma */ && contextToken) { + const changes = ts_textChanges_exports.ChangeTracker.with( + { host, formatContext, preferences }, + (tracker) => tracker.insertText(sourceFile, contextToken.end, ",") + ); + if (changes) { + return { + sourceDisplay: void 0, + codeActions: [{ + changes, + description: diagnosticToString([Diagnostics.Add_missing_comma_for_object_member_completion_0, name]) + }] + }; } } - function inferTypeFromSwitchStatementLabel(parent2, usage) { - addCandidateType(usage, checker.getTypeAtLocation(parent2.parent.parent.expression)); + if (!origin || !(originIsExport(origin) || originIsResolvedExport(origin))) { + return { codeActions: void 0, sourceDisplay: void 0 }; } - function inferTypeFromCallExpression(parent2, usage) { - const call = { - argumentTypes: [], - return_: createEmptyUsage() - }; - if (parent2.arguments) { - for (const argument of parent2.arguments) { - call.argumentTypes.push(checker.getTypeAtLocation(argument)); + const checker = origin.isFromPackageJson ? host.getPackageJsonAutoImportProvider().getTypeChecker() : program.getTypeChecker(); + const { moduleSymbol } = origin; + const targetSymbol = checker.getMergedSymbol(skipAlias(symbol.exportSymbol || symbol, checker)); + const isJsxOpeningTagName = (contextToken == null ? void 0 : contextToken.kind) === 30 /* LessThanToken */ && isJsxOpeningLikeElement(contextToken.parent); + const { moduleSpecifier, codeAction } = ts_codefix_exports.getImportCompletionAction( + targetSymbol, + moduleSymbol, + data == null ? void 0 : data.exportMapKey, + sourceFile, + name, + isJsxOpeningTagName, + host, + program, + formatContext, + previousToken && isIdentifier(previousToken) ? previousToken.getStart(sourceFile) : position, + preferences, + cancellationToken + ); + Debug.assert(!(data == null ? void 0 : data.moduleSpecifier) || moduleSpecifier === data.moduleSpecifier); + return { sourceDisplay: [textPart(moduleSpecifier)], codeActions: [codeAction] }; + } + function getCompletionEntrySymbol(program, log, sourceFile, position, entryId, host, preferences) { + const completion = getSymbolCompletionFromEntryId(program, log, sourceFile, position, entryId, host, preferences); + return completion.type === "symbol" ? completion.symbol : void 0; + } + function getRecommendedCompletion(previousToken, contextualType, checker) { + return firstDefined(contextualType && (contextualType.isUnion() ? contextualType.types : [contextualType]), (type) => { + const symbol = type && type.symbol; + return symbol && (symbol.flags & (8 /* EnumMember */ | 384 /* Enum */ | 32 /* Class */) && !isAbstractConstructorSymbol(symbol)) ? getFirstSymbolInChain(symbol, previousToken, checker) : void 0; + }); + } + function getContextualType(previousToken, position, sourceFile, checker) { + const { parent: parent2 } = previousToken; + switch (previousToken.kind) { + case 80 /* Identifier */: + return getContextualTypeFromParent(previousToken, checker); + case 64 /* EqualsToken */: + switch (parent2.kind) { + case 260 /* VariableDeclaration */: + return checker.getContextualType(parent2.initializer); + case 226 /* BinaryExpression */: + return checker.getTypeAtLocation(parent2.left); + case 291 /* JsxAttribute */: + return checker.getContextualTypeForJsxAttribute(parent2); + default: + return void 0; } - } - calculateUsageOfNode(parent2, call.return_); - if (parent2.kind === 212 /* CallExpression */) { - (usage.calls || (usage.calls = [])).push(call); - } else { - (usage.constructs || (usage.constructs = [])).push(call); - } - } - function inferTypeFromPropertyAccessExpression(parent2, usage) { - const name = escapeLeadingUnderscores(parent2.name.text); - if (!usage.properties) { - usage.properties = /* @__PURE__ */ new Map(); - } - const propertyUsage = usage.properties.get(name) || createEmptyUsage(); - calculateUsageOfNode(parent2, propertyUsage); - usage.properties.set(name, propertyUsage); + case 105 /* NewKeyword */: + return checker.getContextualType(parent2); + case 84 /* CaseKeyword */: + const caseClause = tryCast(parent2, isCaseClause); + return caseClause ? getSwitchedType(caseClause, checker) : void 0; + case 19 /* OpenBraceToken */: + return isJsxExpression(parent2) && !isJsxElement(parent2.parent) && !isJsxFragment(parent2.parent) ? checker.getContextualTypeForJsxAttribute(parent2.parent) : void 0; + default: + const argInfo = ts_SignatureHelp_exports.getArgumentInfoForCompletions(previousToken, position, sourceFile); + return argInfo ? ( + // At `,`, treat this as the next argument after the comma. + checker.getContextualTypeForArgumentAtIndex(argInfo.invocation, argInfo.argumentIndex + (previousToken.kind === 28 /* CommaToken */ ? 1 : 0)) + ) : isEqualityOperatorKind(previousToken.kind) && isBinaryExpression(parent2) && isEqualityOperatorKind(parent2.operatorToken.kind) ? ( + // completion at `x ===/**/` should be for the right side + checker.getTypeAtLocation(parent2.left) + ) : checker.getContextualType(previousToken, 4 /* Completions */) || checker.getContextualType(previousToken); } - function inferTypeFromPropertyElementExpression(parent2, node, usage) { - if (node === parent2.argumentExpression) { - usage.isNumberOrString = true; - return; - } else { - const indexType = checker.getTypeAtLocation(parent2.argumentExpression); - const indexUsage = createEmptyUsage(); - calculateUsageOfNode(parent2, indexUsage); - if (indexType.flags & 296 /* NumberLike */) { - usage.numberIndex = indexUsage; + } + function getFirstSymbolInChain(symbol, enclosingDeclaration, checker) { + const chain = checker.getAccessibleSymbolChain( + symbol, + enclosingDeclaration, + /*meaning*/ + 67108863 /* All */, + /*useOnlyExternalAliasing*/ + false + ); + if (chain) + return first(chain); + return symbol.parent && (isModuleSymbol(symbol.parent) ? symbol : getFirstSymbolInChain(symbol.parent, enclosingDeclaration, checker)); + } + function isModuleSymbol(symbol) { + var _a; + return !!((_a = symbol.declarations) == null ? void 0 : _a.some((d) => d.kind === 312 /* SourceFile */)); + } + function getCompletionData(program, log, sourceFile, compilerOptions, position, preferences, detailsEntryId, host, formatContext, cancellationToken) { + const typeChecker = program.getTypeChecker(); + const inCheckedFile = isCheckedFile(sourceFile, compilerOptions); + let start = timestamp(); + let currentToken = getTokenAtPosition(sourceFile, position); + log("getCompletionData: Get current token: " + (timestamp() - start)); + start = timestamp(); + const insideComment = isInComment(sourceFile, position, currentToken); + log("getCompletionData: Is inside comment: " + (timestamp() - start)); + let insideJsDocTagTypeExpression = false; + let isInSnippetScope = false; + if (insideComment) { + if (hasDocComment(sourceFile, position)) { + if (sourceFile.text.charCodeAt(position - 1) === 64 /* at */) { + return { kind: 1 /* JsDocTagName */ }; } else { - usage.stringIndex = indexUsage; + const lineStart = getLineStartPositionForPosition(position, sourceFile); + if (!/[^*|\s(/)]/.test(sourceFile.text.substring(lineStart, position))) { + return { kind: 2 /* JsDocTag */ }; + } } } - } - function inferTypeFromPropertyAssignment(assignment, usage) { - const nodeWithRealType = isVariableDeclaration(assignment.parent.parent) ? assignment.parent.parent : assignment.parent; - addCandidateThisType(usage, checker.getTypeAtLocation(nodeWithRealType)); - } - function inferTypeFromPropertyDeclaration(declaration, usage) { - addCandidateThisType(usage, checker.getTypeAtLocation(declaration.parent)); - } - function removeLowPriorityInferences(inferences, priorities) { - const toRemove = []; - for (const i of inferences) { - for (const { high, low } of priorities) { - if (high(i)) { - Debug.assert(!low(i), "Priority can't have both low and high"); - toRemove.push(low); + const tag = getJsDocTagAtPosition(currentToken, position); + if (tag) { + if (tag.tagName.pos <= position && position <= tag.tagName.end) { + return { kind: 1 /* JsDocTagName */ }; + } + const typeExpression = tryGetTypeExpressionFromTag(tag); + if (typeExpression) { + currentToken = getTokenAtPosition(sourceFile, position); + if (!currentToken || !isDeclarationName(currentToken) && (currentToken.parent.kind !== 355 /* JSDocPropertyTag */ || currentToken.parent.name !== currentToken)) { + insideJsDocTagTypeExpression = isCurrentlyEditingNode(typeExpression); } } + if (!insideJsDocTagTypeExpression && isJSDocParameterTag(tag) && (nodeIsMissing(tag.name) || tag.name.pos <= position && position <= tag.name.end)) { + return { kind: 3 /* JsDocParameterName */, tag }; + } + } + if (!insideJsDocTagTypeExpression) { + log("Returning an empty list because completion was inside a regular comment or plain text part of a JsDoc comment."); + return void 0; } - return inferences.filter((i) => toRemove.every((f) => !f(i))); - } - function combineFromUsage(usage) { - return combineTypes(inferTypes(usage)); } - function combineTypes(inferences) { - if (!inferences.length) - return checker.getAnyType(); - const stringNumber = checker.getUnionType([checker.getStringType(), checker.getNumberType()]); - const priorities = [ - { - high: (t) => t === checker.getStringType() || t === checker.getNumberType(), - low: (t) => t === stringNumber - }, - { - high: (t) => !(t.flags & (1 /* Any */ | 16384 /* Void */)), - low: (t) => !!(t.flags & (1 /* Any */ | 16384 /* Void */)) - }, - { - high: (t) => !(t.flags & (98304 /* Nullable */ | 1 /* Any */ | 16384 /* Void */)) && !(getObjectFlags(t) & 16 /* Anonymous */), - low: (t) => !!(getObjectFlags(t) & 16 /* Anonymous */) + start = timestamp(); + const isJsOnlyLocation = !insideJsDocTagTypeExpression && isSourceFileJS(sourceFile); + const tokens = getRelevantTokens(position, sourceFile); + const previousToken = tokens.previousToken; + let contextToken = tokens.contextToken; + log("getCompletionData: Get previous token: " + (timestamp() - start)); + let node = currentToken; + let propertyAccessToConvert; + let isRightOfDot = false; + let isRightOfQuestionDot = false; + let isRightOfOpenTag = false; + let isStartingCloseTag = false; + let isJsxInitializer = false; + let isJsxIdentifierExpected = false; + let importStatementCompletion; + let location = getTouchingPropertyName(sourceFile, position); + let keywordFilters = 0 /* None */; + let isNewIdentifierLocation = false; + let flags = 0 /* None */; + if (contextToken) { + const importStatementCompletionInfo = getImportStatementCompletionInfo(contextToken, sourceFile); + if (importStatementCompletionInfo.keywordCompletion) { + if (importStatementCompletionInfo.isKeywordOnlyCompletion) { + return { + kind: 4 /* Keywords */, + keywordCompletions: [keywordToCompletionEntry(importStatementCompletionInfo.keywordCompletion)], + isNewIdentifierLocation: importStatementCompletionInfo.isNewIdentifierLocation + }; } - ]; - let good = removeLowPriorityInferences(inferences, priorities); - const anons = good.filter((i) => getObjectFlags(i) & 16 /* Anonymous */); - if (anons.length) { - good = good.filter((i) => !(getObjectFlags(i) & 16 /* Anonymous */)); - good.push(combineAnonymousTypes(anons)); + keywordFilters = keywordFiltersFromSyntaxKind(importStatementCompletionInfo.keywordCompletion); } - return checker.getWidenedType(checker.getUnionType(good.map(checker.getBaseTypeOfLiteralType), 2 /* Subtype */)); - } - function combineAnonymousTypes(anons) { - if (anons.length === 1) { - return anons[0]; + if (importStatementCompletionInfo.replacementSpan && preferences.includeCompletionsForImportStatements && preferences.includeCompletionsWithInsertText) { + flags |= 2 /* IsImportStatementCompletion */; + importStatementCompletion = importStatementCompletionInfo; + isNewIdentifierLocation = importStatementCompletionInfo.isNewIdentifierLocation; } - const calls = []; - const constructs = []; - const stringIndices = []; - const numberIndices = []; - let stringIndexReadonly = false; - let numberIndexReadonly = false; - const props = createMultiMap(); - for (const anon2 of anons) { - for (const p of checker.getPropertiesOfType(anon2)) { - props.add(p.escapedName, p.valueDeclaration ? checker.getTypeOfSymbolAtLocation(p, p.valueDeclaration) : checker.getAnyType()); + if (!importStatementCompletionInfo.replacementSpan && isCompletionListBlocker(contextToken)) { + log("Returning an empty list because completion was requested in an invalid position."); + return keywordFilters ? keywordCompletionData(keywordFilters, isJsOnlyLocation, isNewIdentifierDefinitionLocation()) : void 0; + } + let parent2 = contextToken.parent; + if (contextToken.kind === 25 /* DotToken */ || contextToken.kind === 29 /* QuestionDotToken */) { + isRightOfDot = contextToken.kind === 25 /* DotToken */; + isRightOfQuestionDot = contextToken.kind === 29 /* QuestionDotToken */; + switch (parent2.kind) { + case 211 /* PropertyAccessExpression */: + propertyAccessToConvert = parent2; + node = propertyAccessToConvert.expression; + const leftmostAccessExpression = getLeftmostAccessExpression(propertyAccessToConvert); + if (nodeIsMissing(leftmostAccessExpression) || (isCallExpression(node) || isFunctionLike(node)) && node.end === contextToken.pos && node.getChildCount(sourceFile) && last(node.getChildren(sourceFile)).kind !== 22 /* CloseParenToken */) { + return void 0; + } + break; + case 166 /* QualifiedName */: + node = parent2.left; + break; + case 267 /* ModuleDeclaration */: + node = parent2.name; + break; + case 205 /* ImportType */: + node = parent2; + break; + case 236 /* MetaProperty */: + node = parent2.getFirstToken(sourceFile); + Debug.assert(node.kind === 102 /* ImportKeyword */ || node.kind === 105 /* NewKeyword */); + break; + default: + return void 0; } - calls.push(...checker.getSignaturesOfType(anon2, 0 /* Call */)); - constructs.push(...checker.getSignaturesOfType(anon2, 1 /* Construct */)); - const stringIndexInfo = checker.getIndexInfoOfType(anon2, 0 /* String */); - if (stringIndexInfo) { - stringIndices.push(stringIndexInfo.type); - stringIndexReadonly = stringIndexReadonly || stringIndexInfo.isReadonly; + } else if (!importStatementCompletion) { + if (parent2 && parent2.kind === 211 /* PropertyAccessExpression */) { + contextToken = parent2; + parent2 = parent2.parent; } - const numberIndexInfo = checker.getIndexInfoOfType(anon2, 1 /* Number */); - if (numberIndexInfo) { - numberIndices.push(numberIndexInfo.type); - numberIndexReadonly = numberIndexReadonly || numberIndexInfo.isReadonly; + if (currentToken.parent === location) { + switch (currentToken.kind) { + case 32 /* GreaterThanToken */: + if (currentToken.parent.kind === 284 /* JsxElement */ || currentToken.parent.kind === 286 /* JsxOpeningElement */) { + location = currentToken; + } + break; + case 44 /* SlashToken */: + if (currentToken.parent.kind === 285 /* JsxSelfClosingElement */) { + location = currentToken; + } + break; + } + } + switch (parent2.kind) { + case 287 /* JsxClosingElement */: + if (contextToken.kind === 44 /* SlashToken */) { + isStartingCloseTag = true; + location = contextToken; + } + break; + case 226 /* BinaryExpression */: + if (!binaryExpressionMayBeOpenTag(parent2)) { + break; + } + case 285 /* JsxSelfClosingElement */: + case 284 /* JsxElement */: + case 286 /* JsxOpeningElement */: + isJsxIdentifierExpected = true; + if (contextToken.kind === 30 /* LessThanToken */) { + isRightOfOpenTag = true; + location = contextToken; + } + break; + case 294 /* JsxExpression */: + case 293 /* JsxSpreadAttribute */: + if (previousToken.kind === 20 /* CloseBraceToken */ || previousToken.kind === 80 /* Identifier */ && previousToken.parent.kind === 291 /* JsxAttribute */) { + isJsxIdentifierExpected = true; + } + break; + case 291 /* JsxAttribute */: + if (parent2.initializer === previousToken && previousToken.end < position) { + isJsxIdentifierExpected = true; + break; + } + switch (previousToken.kind) { + case 64 /* EqualsToken */: + isJsxInitializer = true; + break; + case 80 /* Identifier */: + isJsxIdentifierExpected = true; + if (parent2 !== previousToken.parent && !parent2.initializer && findChildOfKind(parent2, 64 /* EqualsToken */, sourceFile)) { + isJsxInitializer = previousToken; + } + } + break; } } - const members = mapEntries(props, (name, types) => { - const isOptional = types.length < anons.length ? 16777216 /* Optional */ : 0; - const s = checker.createSymbol(4 /* Property */ | isOptional, name); - s.links.type = checker.getUnionType(types); - return [name, s]; - }); - const indexInfos = []; - if (stringIndices.length) - indexInfos.push(checker.createIndexInfo(checker.getStringType(), checker.getUnionType(stringIndices), stringIndexReadonly)); - if (numberIndices.length) - indexInfos.push(checker.createIndexInfo(checker.getNumberType(), checker.getUnionType(numberIndices), numberIndexReadonly)); - return checker.createAnonymousType( - anons[0].symbol, - members, - calls, - constructs, - indexInfos - ); } - function inferTypes(usage) { - var _a, _b, _c; - const types = []; - if (usage.isNumber) { - types.push(checker.getNumberType()); - } - if (usage.isString) { - types.push(checker.getStringType()); - } - if (usage.isNumberOrString) { - types.push(checker.getUnionType([checker.getStringType(), checker.getNumberType()])); - } - if (usage.numberIndex) { - types.push(checker.createArrayType(combineFromUsage(usage.numberIndex))); - } - if (((_a = usage.properties) == null ? void 0 : _a.size) || ((_b = usage.constructs) == null ? void 0 : _b.length) || usage.stringIndex) { - types.push(inferStructuralType(usage)); + const semanticStart = timestamp(); + let completionKind = 5 /* None */; + let isNonContextualObjectLiteral = false; + let hasUnresolvedAutoImports = false; + let symbols = []; + let importSpecifierResolver; + const symbolToOriginInfoMap = []; + const symbolToSortTextMap = []; + const seenPropertySymbols = /* @__PURE__ */ new Map(); + const isTypeOnlyLocation = isTypeOnlyCompletion(); + const getModuleSpecifierResolutionHost = memoizeOne((isFromPackageJson) => { + return createModuleSpecifierResolutionHost(isFromPackageJson ? host.getPackageJsonAutoImportProvider() : program, host); + }); + if (isRightOfDot || isRightOfQuestionDot) { + getTypeScriptMemberSymbols(); + } else if (isRightOfOpenTag) { + symbols = typeChecker.getJsxIntrinsicTagNamesAt(location); + Debug.assertEachIsDefined(symbols, "getJsxIntrinsicTagNames() should all be defined"); + tryGetGlobalSymbols(); + completionKind = 1 /* Global */; + keywordFilters = 0 /* None */; + } else if (isStartingCloseTag) { + const tagName = contextToken.parent.parent.openingElement.tagName; + const tagSymbol = typeChecker.getSymbolAtLocation(tagName); + if (tagSymbol) { + symbols = [tagSymbol]; } - const candidateTypes = (usage.candidateTypes || []).map((t) => checker.getBaseTypeOfLiteralType(t)); - const callsType = ((_c = usage.calls) == null ? void 0 : _c.length) ? inferStructuralType(usage) : void 0; - if (callsType && candidateTypes) { - types.push(checker.getUnionType([callsType, ...candidateTypes], 2 /* Subtype */)); - } else { - if (callsType) { - types.push(callsType); - } - if (length(candidateTypes)) { - types.push(...candidateTypes); - } + completionKind = 1 /* Global */; + keywordFilters = 0 /* None */; + } else { + if (!tryGetGlobalSymbols()) { + return keywordFilters ? keywordCompletionData(keywordFilters, isJsOnlyLocation, isNewIdentifierLocation) : void 0; } - types.push(...inferNamedTypesFromProperties(usage)); - return types; } - function inferStructuralType(usage) { - const members = /* @__PURE__ */ new Map(); - if (usage.properties) { - usage.properties.forEach((u, name) => { - const symbol = checker.createSymbol(4 /* Property */, name); - symbol.links.type = combineFromUsage(u); - members.set(name, symbol); - }); + log("getCompletionData: Semantic work: " + (timestamp() - semanticStart)); + const contextualType = previousToken && getContextualType(previousToken, position, sourceFile, typeChecker); + const isLiteralExpected = !tryCast(previousToken, isStringLiteralLike) && !isJsxIdentifierExpected; + const literals = !isLiteralExpected ? [] : mapDefined( + contextualType && (contextualType.isUnion() ? contextualType.types : [contextualType]), + (t) => t.isLiteral() && !(t.flags & 1024 /* EnumLiteral */) ? t.value : void 0 + ); + const recommendedCompletion = previousToken && contextualType && getRecommendedCompletion(previousToken, contextualType, typeChecker); + return { + kind: 0 /* Data */, + symbols, + completionKind, + isInSnippetScope, + propertyAccessToConvert, + isNewIdentifierLocation, + location, + keywordFilters, + literals, + symbolToOriginInfoMap, + recommendedCompletion, + previousToken, + contextToken, + isJsxInitializer, + insideJsDocTagTypeExpression, + symbolToSortTextMap, + isTypeOnlyLocation, + isJsxIdentifierExpected, + isRightOfOpenTag, + isRightOfDotOrQuestionDot: isRightOfDot || isRightOfQuestionDot, + importStatementCompletion, + hasUnresolvedAutoImports, + flags + }; + function isTagWithTypeExpression(tag) { + switch (tag.kind) { + case 348 /* JSDocParameterTag */: + case 355 /* JSDocPropertyTag */: + case 349 /* JSDocReturnTag */: + case 351 /* JSDocTypeTag */: + case 353 /* JSDocTypedefTag */: + case 356 /* JSDocThrowsTag */: + case 357 /* JSDocSatisfiesTag */: + return true; + case 352 /* JSDocTemplateTag */: + return !!tag.constraint; + default: + return false; } - const callSignatures = usage.calls ? [getSignatureFromCalls(usage.calls)] : []; - const constructSignatures = usage.constructs ? [getSignatureFromCalls(usage.constructs)] : []; - const indexInfos = usage.stringIndex ? [checker.createIndexInfo( - checker.getStringType(), - combineFromUsage(usage.stringIndex), - /*isReadonly*/ - false - )] : []; - return checker.createAnonymousType( - /*symbol*/ - void 0, - members, - callSignatures, - constructSignatures, - indexInfos - ); } - function inferNamedTypesFromProperties(usage) { - if (!usage.properties || !usage.properties.size) - return []; - const types = builtins.filter((t) => allPropertiesAreAssignableToUsage(t, usage)); - if (0 < types.length && types.length < 3) { - return types.map((t) => inferInstantiationFromUsage(t, usage)); + function tryGetTypeExpressionFromTag(tag) { + if (isTagWithTypeExpression(tag)) { + const typeExpression = isJSDocTemplateTag(tag) ? tag.constraint : tag.typeExpression; + return typeExpression && typeExpression.kind === 316 /* JSDocTypeExpression */ ? typeExpression : void 0; } - return []; + if (isJSDocAugmentsTag(tag) || isJSDocImplementsTag(tag)) { + return tag.class; + } + return void 0; } - function allPropertiesAreAssignableToUsage(type, usage) { - if (!usage.properties) - return false; - return !forEachEntry(usage.properties, (propUsage, name) => { - const source = checker.getTypeOfPropertyOfType(type, name); - if (!source) { - return true; + function getTypeScriptMemberSymbols() { + completionKind = 2 /* PropertyAccess */; + const isImportType = isLiteralImportTypeNode(node); + const isTypeLocation = isImportType && !node.isTypeOf || isPartOfTypeNode(node.parent) || isPossiblyTypeArgumentPosition(contextToken, sourceFile, typeChecker); + const isRhsOfImportDeclaration = isInRightSideOfInternalImportEqualsDeclaration(node); + if (isEntityName(node) || isImportType || isPropertyAccessExpression(node)) { + const isNamespaceName = isModuleDeclaration(node.parent); + if (isNamespaceName) + isNewIdentifierLocation = true; + let symbol = typeChecker.getSymbolAtLocation(node); + if (symbol) { + symbol = skipAlias(symbol, typeChecker); + if (symbol.flags & (1536 /* Module */ | 384 /* Enum */)) { + const exportedSymbols = typeChecker.getExportsOfModule(symbol); + Debug.assertEachIsDefined(exportedSymbols, "getExportsOfModule() should all be defined"); + const isValidValueAccess = (symbol2) => typeChecker.isValidPropertyAccess(isImportType ? node : node.parent, symbol2.name); + const isValidTypeAccess = (symbol2) => symbolCanBeReferencedAtTypeLocation(symbol2, typeChecker); + const isValidAccess = isNamespaceName ? (symbol2) => { + var _a; + return !!(symbol2.flags & 1920 /* Namespace */) && !((_a = symbol2.declarations) == null ? void 0 : _a.every((d) => d.parent === node.parent)); + } : isRhsOfImportDeclaration ? ( + // Any kind is allowed when dotting off namespace in internal import equals declaration + (symbol2) => isValidTypeAccess(symbol2) || isValidValueAccess(symbol2) + ) : isTypeLocation || insideJsDocTagTypeExpression ? isValidTypeAccess : isValidValueAccess; + for (const exportedSymbol of exportedSymbols) { + if (isValidAccess(exportedSymbol)) { + symbols.push(exportedSymbol); + } + } + if (!isTypeLocation && !insideJsDocTagTypeExpression && symbol.declarations && symbol.declarations.some((d) => d.kind !== 312 /* SourceFile */ && d.kind !== 267 /* ModuleDeclaration */ && d.kind !== 266 /* EnumDeclaration */)) { + let type = typeChecker.getTypeOfSymbolAtLocation(symbol, node).getNonOptionalType(); + let insertQuestionDot = false; + if (type.isNullableType()) { + const canCorrectToQuestionDot = isRightOfDot && !isRightOfQuestionDot && preferences.includeAutomaticOptionalChainCompletions !== false; + if (canCorrectToQuestionDot || isRightOfQuestionDot) { + type = type.getNonNullableType(); + if (canCorrectToQuestionDot) { + insertQuestionDot = true; + } + } + } + addTypeProperties(type, !!(node.flags & 65536 /* AwaitContext */), insertQuestionDot); + } + return; + } } - if (propUsage.calls) { - const sigs = checker.getSignaturesOfType(source, 0 /* Call */); - return !sigs.length || !checker.isTypeAssignableTo(source, getFunctionFromCalls(propUsage.calls)); + } + if (!isTypeLocation || isInTypeQuery(node)) { + typeChecker.tryGetThisTypeAt( + node, + /*includeGlobalThis*/ + false + ); + let type = typeChecker.getTypeAtLocation(node).getNonOptionalType(); + if (!isTypeLocation) { + let insertQuestionDot = false; + if (type.isNullableType()) { + const canCorrectToQuestionDot = isRightOfDot && !isRightOfQuestionDot && preferences.includeAutomaticOptionalChainCompletions !== false; + if (canCorrectToQuestionDot || isRightOfQuestionDot) { + type = type.getNonNullableType(); + if (canCorrectToQuestionDot) { + insertQuestionDot = true; + } + } + } + addTypeProperties(type, !!(node.flags & 65536 /* AwaitContext */), insertQuestionDot); } else { - return !checker.isTypeAssignableTo(source, combineFromUsage(propUsage)); + addTypeProperties( + type.getNonNullableType(), + /*insertAwait*/ + false, + /*insertQuestionDot*/ + false + ); } - }); - } - function inferInstantiationFromUsage(type, usage) { - if (!(getObjectFlags(type) & 4 /* Reference */) || !usage.properties) { - return type; } - const generic = type.target; - const singleTypeParameter = singleOrUndefined(generic.typeParameters); - if (!singleTypeParameter) - return type; - const types = []; - usage.properties.forEach((propUsage, name) => { - const genericPropertyType = checker.getTypeOfPropertyOfType(generic, name); - Debug.assert(!!genericPropertyType, "generic should have all the properties of its reference."); - types.push(...inferTypeParameters(genericPropertyType, combineFromUsage(propUsage), singleTypeParameter)); - }); - return builtinConstructors[type.symbol.escapedName](combineTypes(types)); } - function inferTypeParameters(genericType, usageType, typeParameter) { - if (genericType === typeParameter) { - return [usageType]; - } else if (genericType.flags & 3145728 /* UnionOrIntersection */) { - return flatMap(genericType.types, (t) => inferTypeParameters(t, usageType, typeParameter)); - } else if (getObjectFlags(genericType) & 4 /* Reference */ && getObjectFlags(usageType) & 4 /* Reference */) { - const genericArgs = checker.getTypeArguments(genericType); - const usageArgs = checker.getTypeArguments(usageType); - const types = []; - if (genericArgs && usageArgs) { - for (let i = 0; i < genericArgs.length; i++) { - if (usageArgs[i]) { - types.push(...inferTypeParameters(genericArgs[i], usageArgs[i], typeParameter)); - } + function addTypeProperties(type, insertAwait, insertQuestionDot) { + isNewIdentifierLocation = !!type.getStringIndexType(); + if (isRightOfQuestionDot && some(type.getCallSignatures())) { + isNewIdentifierLocation = true; + } + const propertyAccess = node.kind === 205 /* ImportType */ ? node : node.parent; + if (inCheckedFile) { + for (const symbol of type.getApparentProperties()) { + if (typeChecker.isValidPropertyAccessForCompletions(propertyAccess, type, symbol)) { + addPropertySymbol( + symbol, + /*insertAwait*/ + false, + insertQuestionDot + ); } } - return types; + } else { + symbols.push(...filter(getPropertiesForCompletion(type, typeChecker), (s) => typeChecker.isValidPropertyAccessForCompletions(propertyAccess, type, s))); } - const genericSigs = checker.getSignaturesOfType(genericType, 0 /* Call */); - const usageSigs = checker.getSignaturesOfType(usageType, 0 /* Call */); - if (genericSigs.length === 1 && usageSigs.length === 1) { - return inferFromSignatures(genericSigs[0], usageSigs[0], typeParameter); + if (insertAwait && preferences.includeCompletionsWithInsertText) { + const promiseType = typeChecker.getPromisedTypeOfPromise(type); + if (promiseType) { + for (const symbol of promiseType.getApparentProperties()) { + if (typeChecker.isValidPropertyAccessForCompletions(propertyAccess, promiseType, symbol)) { + addPropertySymbol( + symbol, + /*insertAwait*/ + true, + insertQuestionDot + ); + } + } + } } - return []; } - function inferFromSignatures(genericSig, usageSig, typeParameter) { + function addPropertySymbol(symbol, insertAwait, insertQuestionDot) { var _a; - const types = []; - for (let i = 0; i < genericSig.parameters.length; i++) { - const genericParam = genericSig.parameters[i]; - const usageParam = usageSig.parameters[i]; - const isRest = genericSig.declaration && isRestParameter(genericSig.declaration.parameters[i]); - if (!usageParam) { - break; - } - let genericParamType = genericParam.valueDeclaration ? checker.getTypeOfSymbolAtLocation(genericParam, genericParam.valueDeclaration) : checker.getAnyType(); - const elementType = isRest && checker.getElementTypeOfArrayType(genericParamType); - if (elementType) { - genericParamType = elementType; + const computedPropertyName = firstDefined(symbol.declarations, (decl) => tryCast(getNameOfDeclaration(decl), isComputedPropertyName)); + if (computedPropertyName) { + const leftMostName = getLeftMostName(computedPropertyName.expression); + const nameSymbol = leftMostName && typeChecker.getSymbolAtLocation(leftMostName); + const firstAccessibleSymbol = nameSymbol && getFirstSymbolInChain(nameSymbol, contextToken, typeChecker); + const firstAccessibleSymbolId = firstAccessibleSymbol && getSymbolId(firstAccessibleSymbol); + if (firstAccessibleSymbolId && addToSeen(seenPropertySymbols, firstAccessibleSymbolId)) { + const index = symbols.length; + symbols.push(firstAccessibleSymbol); + const moduleSymbol = firstAccessibleSymbol.parent; + if (!moduleSymbol || !isExternalModuleSymbol(moduleSymbol) || typeChecker.tryGetMemberInModuleExportsAndProperties(firstAccessibleSymbol.name, moduleSymbol) !== firstAccessibleSymbol) { + symbolToOriginInfoMap[index] = { kind: getNullableSymbolOriginInfoKind(2 /* SymbolMemberNoExport */) }; + } else { + const fileName = isExternalModuleNameRelative(stripQuotes(moduleSymbol.name)) ? (_a = getSourceFileOfModule(moduleSymbol)) == null ? void 0 : _a.fileName : void 0; + const { moduleSpecifier } = (importSpecifierResolver || (importSpecifierResolver = ts_codefix_exports.createImportSpecifierResolver(sourceFile, program, host, preferences))).getModuleSpecifierForBestExportInfo( + [{ + exportKind: 0 /* Named */, + moduleFileName: fileName, + isFromPackageJson: false, + moduleSymbol, + symbol: firstAccessibleSymbol, + targetFlags: skipAlias(firstAccessibleSymbol, typeChecker).flags + }], + position, + isValidTypeOnlyAliasUseSite(location) + ) || {}; + if (moduleSpecifier) { + const origin = { + kind: getNullableSymbolOriginInfoKind(6 /* SymbolMemberExport */), + moduleSymbol, + isDefaultExport: false, + symbolName: firstAccessibleSymbol.name, + exportName: firstAccessibleSymbol.name, + fileName, + moduleSpecifier + }; + symbolToOriginInfoMap[index] = origin; + } + } + } else if (preferences.includeCompletionsWithInsertText) { + if (firstAccessibleSymbolId && seenPropertySymbols.has(firstAccessibleSymbolId)) { + return; + } + addSymbolOriginInfo(symbol); + addSymbolSortInfo(symbol); + symbols.push(symbol); } - const targetType = ((_a = tryCast(usageParam, isTransientSymbol)) == null ? void 0 : _a.links.type) || (usageParam.valueDeclaration ? checker.getTypeOfSymbolAtLocation(usageParam, usageParam.valueDeclaration) : checker.getAnyType()); - types.push(...inferTypeParameters(genericParamType, targetType, typeParameter)); + } else { + addSymbolOriginInfo(symbol); + addSymbolSortInfo(symbol); + symbols.push(symbol); } - const genericReturn = checker.getReturnTypeOfSignature(genericSig); - const usageReturn = checker.getReturnTypeOfSignature(usageSig); - types.push(...inferTypeParameters(genericReturn, usageReturn, typeParameter)); - return types; - } - function getFunctionFromCalls(calls) { - return checker.createAnonymousType( - /*symbol*/ - void 0, - createSymbolTable(), - [getSignatureFromCalls(calls)], - emptyArray, - emptyArray - ); - } - function getSignatureFromCalls(calls) { - const parameters2 = []; - const length2 = Math.max(...calls.map((c) => c.argumentTypes.length)); - for (let i = 0; i < length2; i++) { - const symbol = checker.createSymbol(1 /* FunctionScopedVariable */, escapeLeadingUnderscores(`arg${i}`)); - symbol.links.type = combineTypes(calls.map((call) => call.argumentTypes[i] || checker.getUndefinedType())); - if (calls.some((call) => call.argumentTypes[i] === void 0)) { - symbol.flags |= 16777216 /* Optional */; + function addSymbolSortInfo(symbol2) { + if (isStaticProperty(symbol2)) { + symbolToSortTextMap[getSymbolId(symbol2)] = SortText.LocalDeclarationPriority; } - parameters2.push(symbol); } - const returnType = combineFromUsage(combineUsages(calls.map((call) => call.return_))); - return checker.createSignature( - /*declaration*/ - void 0, - /*typeParameters*/ - void 0, - /*thisParameter*/ - void 0, - parameters2, - returnType, - /*typePredicate*/ - void 0, - length2, - 0 /* None */ - ); - } - function addCandidateType(usage, type) { - if (type && !(type.flags & 1 /* Any */) && !(type.flags & 131072 /* Never */)) { - (usage.candidateTypes || (usage.candidateTypes = [])).push(type); + function addSymbolOriginInfo(symbol2) { + if (preferences.includeCompletionsWithInsertText) { + if (insertAwait && addToSeen(seenPropertySymbols, getSymbolId(symbol2))) { + symbolToOriginInfoMap[symbols.length] = { kind: getNullableSymbolOriginInfoKind(8 /* Promise */) }; + } else if (insertQuestionDot) { + symbolToOriginInfoMap[symbols.length] = { kind: 16 /* Nullable */ }; + } + } } - } - function addCandidateThisType(usage, type) { - if (type && !(type.flags & 1 /* Any */) && !(type.flags & 131072 /* Never */)) { - (usage.candidateThisTypes || (usage.candidateThisTypes = [])).push(type); + function getNullableSymbolOriginInfoKind(kind) { + return insertQuestionDot ? kind | 16 /* Nullable */ : kind; } } - } - var fixId38, errorCodes48; - var init_inferFromUsage = __esm({ - "src/services/codefixes/inferFromUsage.ts"() { - "use strict"; - init_ts4(); - init_ts_codefix(); - fixId38 = "inferFromUsage"; - errorCodes48 = [ - // Variable declarations - Diagnostics.Variable_0_implicitly_has_type_1_in_some_locations_where_its_type_cannot_be_determined.code, - // Variable uses - Diagnostics.Variable_0_implicitly_has_an_1_type.code, - // Parameter declarations - Diagnostics.Parameter_0_implicitly_has_an_1_type.code, - Diagnostics.Rest_parameter_0_implicitly_has_an_any_type.code, - // Get Accessor declarations - Diagnostics.Property_0_implicitly_has_type_any_because_its_get_accessor_lacks_a_return_type_annotation.code, - Diagnostics._0_which_lacks_return_type_annotation_implicitly_has_an_1_return_type.code, - // Set Accessor declarations - Diagnostics.Property_0_implicitly_has_type_any_because_its_set_accessor_lacks_a_parameter_type_annotation.code, - // Property declarations - Diagnostics.Member_0_implicitly_has_an_1_type.code, - //// Suggestions - // Variable declarations - Diagnostics.Variable_0_implicitly_has_type_1_in_some_locations_but_a_better_type_may_be_inferred_from_usage.code, - // Variable uses - Diagnostics.Variable_0_implicitly_has_an_1_type_but_a_better_type_may_be_inferred_from_usage.code, - // Parameter declarations - Diagnostics.Parameter_0_implicitly_has_an_1_type_but_a_better_type_may_be_inferred_from_usage.code, - Diagnostics.Rest_parameter_0_implicitly_has_an_any_type_but_a_better_type_may_be_inferred_from_usage.code, - // Get Accessor declarations - Diagnostics.Property_0_implicitly_has_type_any_but_a_better_type_for_its_get_accessor_may_be_inferred_from_usage.code, - Diagnostics._0_implicitly_has_an_1_return_type_but_a_better_type_may_be_inferred_from_usage.code, - // Set Accessor declarations - Diagnostics.Property_0_implicitly_has_type_any_but_a_better_type_for_its_set_accessor_may_be_inferred_from_usage.code, - // Property declarations - Diagnostics.Member_0_implicitly_has_an_1_type_but_a_better_type_may_be_inferred_from_usage.code, - // Function expressions and declarations - Diagnostics.this_implicitly_has_type_any_because_it_does_not_have_a_type_annotation.code - ]; - registerCodeFix({ - errorCodes: errorCodes48, - getCodeActions(context) { - const { sourceFile, program, span: { start }, errorCode, cancellationToken, host, preferences } = context; - const token = getTokenAtPosition(sourceFile, start); - let declaration; - const changes = ts_textChanges_exports.ChangeTracker.with(context, (changes2) => { - declaration = doChange32( - changes2, - sourceFile, - token, - errorCode, - program, - cancellationToken, - /*markSeen*/ - returnTrue, - host, - preferences - ); - }); - const name = declaration && getNameOfDeclaration(declaration); - return !name || changes.length === 0 ? void 0 : [createCodeFixAction(fixId38, changes, [getDiagnostic(errorCode, token), getTextOfNode(name)], fixId38, Diagnostics.Infer_all_types_from_usage)]; - }, - fixIds: [fixId38], - getAllCodeActions(context) { - const { sourceFile, program, cancellationToken, host, preferences } = context; - const markSeen = nodeSeenTracker(); - return codeFixAll(context, errorCodes48, (changes, err) => { - doChange32(changes, sourceFile, getTokenAtPosition(err.file, err.start), err.code, program, cancellationToken, markSeen, host, preferences); - }); - } - }); - } - }); - - // src/services/codefixes/fixReturnTypeInAsyncFunction.ts - function getInfo15(sourceFile, checker, pos) { - if (isInJSFile(sourceFile)) { - return void 0; + function getLeftMostName(e) { + return isIdentifier(e) ? e : isPropertyAccessExpression(e) ? getLeftMostName(e.expression) : void 0; } - const token = getTokenAtPosition(sourceFile, pos); - const func = findAncestor(token, isFunctionLikeDeclaration); - const returnTypeNode = func == null ? void 0 : func.type; - if (!returnTypeNode) { - return void 0; + function tryGetGlobalSymbols() { + const result = tryGetObjectTypeLiteralInTypeArgumentCompletionSymbols() || tryGetObjectLikeCompletionSymbols() || tryGetImportCompletionSymbols() || tryGetImportOrExportClauseCompletionSymbols() || tryGetLocalNamedExportCompletionSymbols() || tryGetConstructorCompletion() || tryGetClassLikeCompletionSymbols() || tryGetJsxCompletionSymbols() || (getGlobalCompletions(), 1 /* Success */); + return result === 1 /* Success */; } - const returnType = checker.getTypeFromTypeNode(returnTypeNode); - const promisedType = checker.getAwaitedType(returnType) || checker.getVoidType(); - const promisedTypeNode = checker.typeToTypeNode( - promisedType, - /*enclosingDeclaration*/ - returnTypeNode, - /*flags*/ - void 0 - ); - if (promisedTypeNode) { - return { returnTypeNode, returnType, promisedTypeNode, promisedType }; + function tryGetConstructorCompletion() { + if (!tryGetConstructorLikeCompletionContainer(contextToken)) + return 0 /* Continue */; + completionKind = 5 /* None */; + isNewIdentifierLocation = true; + keywordFilters = 4 /* ConstructorParameterKeywords */; + return 1 /* Success */; } - } - function doChange33(changes, sourceFile, returnTypeNode, promisedTypeNode) { - changes.replaceNode(sourceFile, returnTypeNode, factory.createTypeReferenceNode("Promise", [promisedTypeNode])); - } - var fixId39, errorCodes49; - var init_fixReturnTypeInAsyncFunction = __esm({ - "src/services/codefixes/fixReturnTypeInAsyncFunction.ts"() { - "use strict"; - init_ts4(); - init_ts_codefix(); - fixId39 = "fixReturnTypeInAsyncFunction"; - errorCodes49 = [ - Diagnostics.The_return_type_of_an_async_function_or_method_must_be_the_global_Promise_T_type_Did_you_mean_to_write_Promise_0.code - ]; - registerCodeFix({ - errorCodes: errorCodes49, - fixIds: [fixId39], - getCodeActions: function getCodeActionsToFixReturnTypeInAsyncFunction(context) { - const { sourceFile, program, span } = context; - const checker = program.getTypeChecker(); - const info = getInfo15(sourceFile, program.getTypeChecker(), span.start); - if (!info) { - return void 0; - } - const { returnTypeNode, returnType, promisedTypeNode, promisedType } = info; - const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange33(t, sourceFile, returnTypeNode, promisedTypeNode)); - return [createCodeFixAction( - fixId39, - changes, - [ - Diagnostics.Replace_0_with_Promise_1, - checker.typeToString(returnType), - checker.typeToString(promisedType) - ], - fixId39, - Diagnostics.Fix_all_incorrect_return_type_of_an_async_functions - )]; - }, - getAllCodeActions: (context) => codeFixAll(context, errorCodes49, (changes, diag2) => { - const info = getInfo15(diag2.file, context.program.getTypeChecker(), diag2.start); - if (info) { - doChange33(changes, diag2.file, info.returnTypeNode, info.promisedTypeNode); - } - }) - }); + function tryGetJsxCompletionSymbols() { + const jsxContainer = tryGetContainingJsxElement(contextToken); + const attrsType = jsxContainer && typeChecker.getContextualType(jsxContainer.attributes); + if (!attrsType) + return 0 /* Continue */; + const completionsType = jsxContainer && typeChecker.getContextualType(jsxContainer.attributes, 4 /* Completions */); + symbols = concatenate(symbols, filterJsxAttributes(getPropertiesForObjectExpression(attrsType, completionsType, jsxContainer.attributes, typeChecker), jsxContainer.attributes.properties)); + setSortTextToOptionalMember(); + completionKind = 3 /* MemberLike */; + isNewIdentifierLocation = false; + return 1 /* Success */; } - }); - - // src/services/codefixes/disableJsDiagnostics.ts - function makeChange8(changes, sourceFile, position, seenLines) { - const { line: lineNumber } = getLineAndCharacterOfPosition(sourceFile, position); - if (!seenLines || tryAddToSet(seenLines, lineNumber)) { - changes.insertCommentBeforeLine(sourceFile, lineNumber, position, " @ts-ignore"); + function tryGetImportCompletionSymbols() { + if (!importStatementCompletion) + return 0 /* Continue */; + isNewIdentifierLocation = true; + collectAutoImports(); + return 1 /* Success */; } - } - var fixName4, fixId40, errorCodes50; - var init_disableJsDiagnostics = __esm({ - "src/services/codefixes/disableJsDiagnostics.ts"() { - "use strict"; - init_ts4(); - init_ts_codefix(); - fixName4 = "disableJsDiagnostics"; - fixId40 = "disableJsDiagnostics"; - errorCodes50 = mapDefined(Object.keys(Diagnostics), (key) => { - const diag2 = Diagnostics[key]; - return diag2.category === 1 /* Error */ ? diag2.code : void 0; - }); - registerCodeFix({ - errorCodes: errorCodes50, - getCodeActions: function getCodeActionsToDisableJsDiagnostics(context) { - const { sourceFile, program, span, host, formatContext } = context; - if (!isInJSFile(sourceFile) || !isCheckJsEnabledForFile(sourceFile, program.getCompilerOptions())) { - return void 0; + function getGlobalCompletions() { + keywordFilters = tryGetFunctionLikeBodyCompletionContainer(contextToken) ? 5 /* FunctionLikeBodyKeywords */ : 1 /* All */; + completionKind = 1 /* Global */; + isNewIdentifierLocation = isNewIdentifierDefinitionLocation(); + if (previousToken !== contextToken) { + Debug.assert(!!previousToken, "Expected 'contextToken' to be defined when different from 'previousToken'."); + } + const adjustedPosition = previousToken !== contextToken ? previousToken.getStart() : position; + const scopeNode = getScopeNode(contextToken, adjustedPosition, sourceFile) || sourceFile; + isInSnippetScope = isSnippetScope(scopeNode); + const symbolMeanings = (isTypeOnlyLocation ? 0 /* None */ : 111551 /* Value */) | 788968 /* Type */ | 1920 /* Namespace */ | 2097152 /* Alias */; + const typeOnlyAliasNeedsPromotion = previousToken && !isValidTypeOnlyAliasUseSite(previousToken); + symbols = concatenate(symbols, typeChecker.getSymbolsInScope(scopeNode, symbolMeanings)); + Debug.assertEachIsDefined(symbols, "getSymbolsInScope() should all be defined"); + for (let i = 0; i < symbols.length; i++) { + const symbol = symbols[i]; + if (!typeChecker.isArgumentsSymbol(symbol) && !some(symbol.declarations, (d) => d.getSourceFile() === sourceFile)) { + symbolToSortTextMap[getSymbolId(symbol)] = SortText.GlobalsOrKeywords; + } + if (typeOnlyAliasNeedsPromotion && !(symbol.flags & 111551 /* Value */)) { + const typeOnlyAliasDeclaration = symbol.declarations && find(symbol.declarations, isTypeOnlyImportDeclaration); + if (typeOnlyAliasDeclaration) { + const origin = { kind: 64 /* TypeOnlyAlias */, declaration: typeOnlyAliasDeclaration }; + symbolToOriginInfoMap[i] = origin; } - const newLineCharacter = sourceFile.checkJsDirective ? "" : getNewLineOrDefaultFromHost(host, formatContext.options); - const fixes = [ - // fixId unnecessary because adding `// @ts-nocheck` even once will ignore every error in the file. - createCodeFixActionWithoutFixAll( - fixName4, - [createFileTextChanges(sourceFile.fileName, [ - createTextChange(sourceFile.checkJsDirective ? createTextSpanFromBounds(sourceFile.checkJsDirective.pos, sourceFile.checkJsDirective.end) : createTextSpan(0, 0), `// @ts-nocheck${newLineCharacter}`) - ])], - Diagnostics.Disable_checking_for_this_file - ) - ]; - if (ts_textChanges_exports.isValidLocationToAddComment(sourceFile, span.start)) { - fixes.unshift(createCodeFixAction(fixName4, ts_textChanges_exports.ChangeTracker.with(context, (t) => makeChange8(t, sourceFile, span.start)), Diagnostics.Ignore_this_error_message, fixId40, Diagnostics.Add_ts_ignore_to_all_error_messages)); + } + } + if (preferences.includeCompletionsWithInsertText && scopeNode.kind !== 312 /* SourceFile */) { + const thisType = typeChecker.tryGetThisTypeAt( + scopeNode, + /*includeGlobalThis*/ + false, + isClassLike(scopeNode.parent) ? scopeNode : void 0 + ); + if (thisType && !isProbablyGlobalType(thisType, sourceFile, typeChecker)) { + for (const symbol of getPropertiesForCompletion(thisType, typeChecker)) { + symbolToOriginInfoMap[symbols.length] = { kind: 1 /* ThisType */ }; + symbols.push(symbol); + symbolToSortTextMap[getSymbolId(symbol)] = SortText.SuggestedClassMembers; } - return fixes; - }, - fixIds: [fixId40], - getAllCodeActions: (context) => { - const seenLines = /* @__PURE__ */ new Set(); - return codeFixAll(context, errorCodes50, (changes, diag2) => { - if (ts_textChanges_exports.isValidLocationToAddComment(diag2.file, diag2.start)) { - makeChange8(changes, diag2.file, diag2.start, seenLines); - } - }); } - }); + } + collectAutoImports(); + if (isTypeOnlyLocation) { + keywordFilters = contextToken && isAssertionExpression(contextToken.parent) ? 6 /* TypeAssertionKeywords */ : 7 /* TypeKeywords */; + } } - }); - - // src/services/codefixes/helpers.ts - function createMissingMemberNodes(classDeclaration, possiblyMissingSymbols, sourceFile, context, preferences, importAdder, addClassElement) { - const classMembers = classDeclaration.symbol.members; - for (const symbol of possiblyMissingSymbols) { - if (!classMembers.has(symbol.escapedName)) { - addNewNodeForMemberSymbol( - symbol, - classDeclaration, - sourceFile, - context, - preferences, - importAdder, - addClassElement, - /*body*/ - void 0 - ); + function shouldOfferImportCompletions() { + if (importStatementCompletion) + return true; + if (isNonContextualObjectLiteral) + return false; + if (!preferences.includeCompletionsForModuleExports) + return false; + if (sourceFile.externalModuleIndicator || sourceFile.commonJsModuleIndicator) + return true; + if (compilerOptionsIndicateEsModules(program.getCompilerOptions())) + return true; + return programContainsModules(program); + } + function isSnippetScope(scopeNode) { + switch (scopeNode.kind) { + case 312 /* SourceFile */: + case 228 /* TemplateExpression */: + case 294 /* JsxExpression */: + case 241 /* Block */: + return true; + default: + return isStatement(scopeNode); } } - } - function getNoopSymbolTrackerWithResolver(context) { - return { - trackSymbol: () => false, - moduleResolverHost: getModuleSpecifierResolverHost(context.program, context.host) - }; - } - function addNewNodeForMemberSymbol(symbol, enclosingDeclaration, sourceFile, context, preferences, importAdder, addClassElement, body, preserveOptional = 3 /* All */, isAmbient = false) { - const declarations = symbol.getDeclarations(); - const declaration = declarations == null ? void 0 : declarations[0]; - const checker = context.program.getTypeChecker(); - const scriptTarget = getEmitScriptTarget(context.program.getCompilerOptions()); - const kind = (declaration == null ? void 0 : declaration.kind) ?? 170 /* PropertySignature */; - const declarationName = getSynthesizedDeepClone( - getNameOfDeclaration(declaration), - /*includeTrivia*/ - false - ); - const effectiveModifierFlags = declaration ? getEffectiveModifierFlags(declaration) : 0 /* None */; - let modifierFlags = effectiveModifierFlags & 4 /* Public */ ? 4 /* Public */ : effectiveModifierFlags & 16 /* Protected */ ? 16 /* Protected */ : 0 /* None */; - if (declaration && isAutoAccessorPropertyDeclaration(declaration)) { - modifierFlags |= 128 /* Accessor */; + function isTypeOnlyCompletion() { + return insideJsDocTagTypeExpression || !!importStatementCompletion && isTypeOnlyImportOrExportDeclaration(location.parent) || !isContextTokenValueLocation(contextToken) && (isPossiblyTypeArgumentPosition(contextToken, sourceFile, typeChecker) || isPartOfTypeNode(location) || isContextTokenTypeLocation(contextToken)); } - const modifiers = createModifiers(); - const type = checker.getWidenedType(checker.getTypeOfSymbolAtLocation(symbol, enclosingDeclaration)); - const optional = !!(symbol.flags & 16777216 /* Optional */); - const ambient = !!(enclosingDeclaration.flags & 16777216 /* Ambient */) || isAmbient; - const quotePreference = getQuotePreference(sourceFile, preferences); - switch (kind) { - case 170 /* PropertySignature */: - case 171 /* PropertyDeclaration */: - const flags = quotePreference === 0 /* Single */ ? 268435456 /* UseSingleQuotesForStringLiteralType */ : void 0; - let typeNode = checker.typeToTypeNode(type, enclosingDeclaration, flags, getNoopSymbolTrackerWithResolver(context)); - if (importAdder) { - const importableReference = tryGetAutoImportableReferenceFromTypeNode(typeNode, scriptTarget); - if (importableReference) { - typeNode = importableReference.typeNode; - importSymbols(importAdder, importableReference.symbols); - } + function isContextTokenValueLocation(contextToken2) { + return contextToken2 && (contextToken2.kind === 114 /* TypeOfKeyword */ && (contextToken2.parent.kind === 186 /* TypeQuery */ || isTypeOfExpression(contextToken2.parent)) || contextToken2.kind === 131 /* AssertsKeyword */ && contextToken2.parent.kind === 182 /* TypePredicate */); + } + function isContextTokenTypeLocation(contextToken2) { + if (contextToken2) { + const parentKind = contextToken2.parent.kind; + switch (contextToken2.kind) { + case 59 /* ColonToken */: + return parentKind === 172 /* PropertyDeclaration */ || parentKind === 171 /* PropertySignature */ || parentKind === 169 /* Parameter */ || parentKind === 260 /* VariableDeclaration */ || isFunctionLikeKind(parentKind); + case 64 /* EqualsToken */: + return parentKind === 265 /* TypeAliasDeclaration */; + case 130 /* AsKeyword */: + return parentKind === 234 /* AsExpression */; + case 30 /* LessThanToken */: + return parentKind === 183 /* TypeReference */ || parentKind === 216 /* TypeAssertionExpression */; + case 96 /* ExtendsKeyword */: + return parentKind === 168 /* TypeParameter */; + case 152 /* SatisfiesKeyword */: + return parentKind === 238 /* SatisfiesExpression */; } - addClassElement(factory.createPropertyDeclaration( - modifiers, - declaration ? createName(declarationName) : symbol.getName(), - optional && preserveOptional & 2 /* Property */ ? factory.createToken(58 /* QuestionToken */) : void 0, - typeNode, - /*initializer*/ - void 0 - )); - break; - case 176 /* GetAccessor */: - case 177 /* SetAccessor */: { - Debug.assertIsDefined(declarations); - let typeNode2 = checker.typeToTypeNode( - type, - enclosingDeclaration, - /*flags*/ - void 0, - getNoopSymbolTrackerWithResolver(context) - ); - const allAccessors = getAllAccessorDeclarations(declarations, declaration); - const orderedAccessors = allAccessors.secondAccessor ? [allAccessors.firstAccessor, allAccessors.secondAccessor] : [allAccessors.firstAccessor]; - if (importAdder) { - const importableReference = tryGetAutoImportableReferenceFromTypeNode(typeNode2, scriptTarget); - if (importableReference) { - typeNode2 = importableReference.typeNode; - importSymbols(importAdder, importableReference.symbols); - } + } + return false; + } + function collectAutoImports() { + var _a, _b; + if (!shouldOfferImportCompletions()) + return; + Debug.assert(!(detailsEntryId == null ? void 0 : detailsEntryId.data), "Should not run 'collectAutoImports' when faster path is available via `data`"); + if (detailsEntryId && !detailsEntryId.source) { + return; + } + flags |= 1 /* MayIncludeAutoImports */; + const isAfterTypeOnlyImportSpecifierModifier = previousToken === contextToken && importStatementCompletion; + const lowerCaseTokenText = isAfterTypeOnlyImportSpecifierModifier ? "" : previousToken && isIdentifier(previousToken) ? previousToken.text.toLowerCase() : ""; + const moduleSpecifierCache = (_a = host.getModuleSpecifierCache) == null ? void 0 : _a.call(host); + const exportInfo = getExportInfoMap(sourceFile, host, program, preferences, cancellationToken); + const packageJsonAutoImportProvider = (_b = host.getPackageJsonAutoImportProvider) == null ? void 0 : _b.call(host); + const packageJsonFilter = detailsEntryId ? void 0 : createPackageJsonImportFilter(sourceFile, preferences, host); + resolvingModuleSpecifiers( + "collectAutoImports", + host, + importSpecifierResolver || (importSpecifierResolver = ts_codefix_exports.createImportSpecifierResolver(sourceFile, program, host, preferences)), + program, + position, + preferences, + !!importStatementCompletion, + isValidTypeOnlyAliasUseSite(location), + (context) => { + exportInfo.search( + sourceFile.path, + /*preferCapitalized*/ + isRightOfOpenTag, + (symbolName2, targetFlags) => { + if (!isIdentifierText(symbolName2, getEmitScriptTarget(host.getCompilationSettings()))) + return false; + if (!detailsEntryId && isStringANonContextualKeyword(symbolName2)) + return false; + if (!isTypeOnlyLocation && !importStatementCompletion && !(targetFlags & 111551 /* Value */)) + return false; + if (isTypeOnlyLocation && !(targetFlags & (1536 /* Module */ | 788968 /* Type */))) + return false; + const firstChar = symbolName2.charCodeAt(0); + if (isRightOfOpenTag && (firstChar < 65 /* A */ || firstChar > 90 /* Z */)) + return false; + if (detailsEntryId) + return true; + return charactersFuzzyMatchInString(symbolName2, lowerCaseTokenText); + }, + (info, symbolName2, isFromAmbientModule, exportMapKey) => { + if (detailsEntryId && !some(info, (i) => detailsEntryId.source === stripQuotes(i.moduleSymbol.name))) { + return; + } + info = filter(info, isImportableExportInfo); + if (!info.length) { + return; + } + const result = context.tryResolve(info, isFromAmbientModule) || {}; + if (result === "failed") + return; + let exportInfo2 = info[0], moduleSpecifier; + if (result !== "skipped") { + ({ exportInfo: exportInfo2 = info[0], moduleSpecifier } = result); + } + const isDefaultExport = exportInfo2.exportKind === 1 /* Default */; + const symbol = isDefaultExport && getLocalSymbolForExportDefault(exportInfo2.symbol) || exportInfo2.symbol; + pushAutoImportSymbol(symbol, { + kind: moduleSpecifier ? 32 /* ResolvedExport */ : 4 /* Export */, + moduleSpecifier, + symbolName: symbolName2, + exportMapKey, + exportName: exportInfo2.exportKind === 2 /* ExportEquals */ ? "export=" /* ExportEquals */ : exportInfo2.symbol.name, + fileName: exportInfo2.moduleFileName, + isDefaultExport, + moduleSymbol: exportInfo2.moduleSymbol, + isFromPackageJson: exportInfo2.isFromPackageJson + }); + } + ); + hasUnresolvedAutoImports = context.skippedAny(); + flags |= context.resolvedAny() ? 8 /* ResolvedModuleSpecifiers */ : 0; + flags |= context.resolvedBeyondLimit() ? 16 /* ResolvedModuleSpecifiersBeyondLimit */ : 0; } - for (const accessor of orderedAccessors) { - if (isGetAccessorDeclaration(accessor)) { - addClassElement(factory.createGetAccessorDeclaration( - modifiers, - createName(declarationName), - emptyArray, - createTypeNode(typeNode2), - createBody(body, quotePreference, ambient) - )); - } else { - Debug.assertNode(accessor, isSetAccessorDeclaration, "The counterpart to a getter should be a setter"); - const parameter = getSetAccessorValueParameter(accessor); - const parameterName = parameter && isIdentifier(parameter.name) ? idText(parameter.name) : void 0; - addClassElement(factory.createSetAccessorDeclaration( - modifiers, - createName(declarationName), - createDummyParameters( - 1, - [parameterName], - [createTypeNode(typeNode2)], - 1, - /*inJs*/ - false - ), - createBody(body, quotePreference, ambient) - )); + ); + function isImportableExportInfo(info) { + const moduleFile = tryCast(info.moduleSymbol.valueDeclaration, isSourceFile); + if (!moduleFile) { + const moduleName = stripQuotes(info.moduleSymbol.name); + if (ts_JsTyping_exports.nodeCoreModules.has(moduleName) && startsWith(moduleName, "node:") !== shouldUseUriStyleNodeCoreModules(sourceFile, program)) { + return false; } + return packageJsonFilter ? packageJsonFilter.allowsImportingAmbientModule(info.moduleSymbol, getModuleSpecifierResolutionHost(info.isFromPackageJson)) : true; } - break; + return isImportableFile( + info.isFromPackageJson ? packageJsonAutoImportProvider : program, + sourceFile, + moduleFile, + preferences, + packageJsonFilter, + getModuleSpecifierResolutionHost(info.isFromPackageJson), + moduleSpecifierCache + ); } - case 172 /* MethodSignature */: - case 173 /* MethodDeclaration */: - Debug.assertIsDefined(declarations); - const signatures = type.isUnion() ? flatMap(type.types, (t) => t.getCallSignatures()) : type.getCallSignatures(); - if (!some(signatures)) { - break; - } - if (declarations.length === 1) { - Debug.assert(signatures.length === 1, "One declaration implies one signature"); - const signature = signatures[0]; - outputMethod(quotePreference, signature, modifiers, createName(declarationName), createBody(body, quotePreference, ambient)); - break; + } + function pushAutoImportSymbol(symbol, origin) { + const symbolId = getSymbolId(symbol); + if (symbolToSortTextMap[symbolId] === SortText.GlobalsOrKeywords) { + return; + } + symbolToOriginInfoMap[symbols.length] = origin; + symbolToSortTextMap[symbolId] = importStatementCompletion ? SortText.LocationPriority : SortText.AutoImportSuggestions; + symbols.push(symbol); + } + function collectObjectLiteralMethodSymbols(members, enclosingDeclaration) { + if (isInJSFile(location)) { + return; + } + members.forEach((member) => { + if (!isObjectLiteralMethodSymbol(member)) { + return; } - for (const signature of signatures) { - outputMethod(quotePreference, signature, modifiers, createName(declarationName)); + const displayName = getCompletionEntryDisplayNameForSymbol( + member, + getEmitScriptTarget(compilerOptions), + /*origin*/ + void 0, + 0 /* ObjectPropertyDeclaration */, + /*jsxIdentifierExpected*/ + false + ); + if (!displayName) { + return; } - if (!ambient) { - if (declarations.length > signatures.length) { - const signature = checker.getSignatureFromDeclaration(declarations[declarations.length - 1]); - outputMethod(quotePreference, signature, modifiers, createName(declarationName), createBody(body, quotePreference)); - } else { - Debug.assert(declarations.length === signatures.length, "Declarations and signatures should match count"); - addClassElement(createMethodImplementingSignatures(checker, context, enclosingDeclaration, signatures, createName(declarationName), optional && !!(preserveOptional & 1 /* Method */), modifiers, quotePreference, body)); - } + const { name } = displayName; + const entryProps = getEntryForObjectLiteralMethodCompletion( + member, + name, + enclosingDeclaration, + program, + host, + compilerOptions, + preferences, + formatContext + ); + if (!entryProps) { + return; } - break; - } - function outputMethod(quotePreference2, signature, modifiers2, name, body2) { - const method = createSignatureDeclarationFromSignature(173 /* MethodDeclaration */, context, quotePreference2, signature, body2, name, modifiers2, optional && !!(preserveOptional & 1 /* Method */), enclosingDeclaration, importAdder); - if (method) - addClassElement(method); + const origin = { kind: 128 /* ObjectLiteralMethod */, ...entryProps }; + flags |= 32 /* MayIncludeMethodSnippets */; + symbolToOriginInfoMap[symbols.length] = origin; + symbols.push(member); + }); } - function createModifiers() { - let modifiers2; - if (modifierFlags) { - modifiers2 = combine(modifiers2, factory.createModifiersFromModifierFlags(modifierFlags)); + function isObjectLiteralMethodSymbol(symbol) { + if (!(symbol.flags & (4 /* Property */ | 8192 /* Method */))) { + return false; } - if (shouldAddOverrideKeyword()) { - modifiers2 = append(modifiers2, factory.createToken(163 /* OverrideKeyword */)); + return true; + } + function getScopeNode(initialToken, position2, sourceFile2) { + let scope = initialToken; + while (scope && !positionBelongsToNode(scope, position2, sourceFile2)) { + scope = scope.parent; } - return modifiers2 && factory.createNodeArray(modifiers2); + return scope; } - function shouldAddOverrideKeyword() { - return !!(context.program.getCompilerOptions().noImplicitOverride && declaration && hasAbstractModifier(declaration)); + function isCompletionListBlocker(contextToken2) { + const start2 = timestamp(); + const result = isInStringOrRegularExpressionOrTemplateLiteral(contextToken2) || isSolelyIdentifierDefinitionLocation(contextToken2) || isDotOfNumericLiteral(contextToken2) || isInJsxText(contextToken2) || isBigIntLiteral(contextToken2); + log("getCompletionsAtPosition: isCompletionListBlocker: " + (timestamp() - start2)); + return result; } - function createName(node) { - if (isIdentifier(node) && node.escapedText === "constructor") { - return factory.createComputedPropertyName(factory.createStringLiteral(idText(node), quotePreference === 0 /* Single */)); + function isInJsxText(contextToken2) { + if (contextToken2.kind === 12 /* JsxText */) { + return true; } - return getSynthesizedDeepClone( - node, - /*includeTrivia*/ - false - ); + if (contextToken2.kind === 32 /* GreaterThanToken */ && contextToken2.parent) { + if (location === contextToken2.parent && (location.kind === 286 /* JsxOpeningElement */ || location.kind === 285 /* JsxSelfClosingElement */)) { + return false; + } + if (contextToken2.parent.kind === 286 /* JsxOpeningElement */) { + return location.parent.kind !== 286 /* JsxOpeningElement */; + } + if (contextToken2.parent.kind === 287 /* JsxClosingElement */ || contextToken2.parent.kind === 285 /* JsxSelfClosingElement */) { + return !!contextToken2.parent.parent && contextToken2.parent.parent.kind === 284 /* JsxElement */; + } + } + return false; } - function createBody(block, quotePreference2, ambient2) { - return ambient2 ? void 0 : getSynthesizedDeepClone( - block, - /*includeTrivia*/ - false - ) || createStubbedMethodBody(quotePreference2); + function isNewIdentifierDefinitionLocation() { + if (contextToken) { + const containingNodeKind = contextToken.parent.kind; + const tokenKind = keywordForNode(contextToken); + switch (tokenKind) { + case 28 /* CommaToken */: + return containingNodeKind === 213 /* CallExpression */ || containingNodeKind === 176 /* Constructor */ || containingNodeKind === 214 /* NewExpression */ || containingNodeKind === 209 /* ArrayLiteralExpression */ || containingNodeKind === 226 /* BinaryExpression */ || containingNodeKind === 184 /* FunctionType */ || containingNodeKind === 210 /* ObjectLiteralExpression */; + case 21 /* OpenParenToken */: + return containingNodeKind === 213 /* CallExpression */ || containingNodeKind === 176 /* Constructor */ || containingNodeKind === 214 /* NewExpression */ || containingNodeKind === 217 /* ParenthesizedExpression */ || containingNodeKind === 196 /* ParenthesizedType */; + case 23 /* OpenBracketToken */: + return containingNodeKind === 209 /* ArrayLiteralExpression */ || containingNodeKind === 181 /* IndexSignature */ || containingNodeKind === 167 /* ComputedPropertyName */; + case 144 /* ModuleKeyword */: + case 145 /* NamespaceKeyword */: + case 102 /* ImportKeyword */: + return true; + case 25 /* DotToken */: + return containingNodeKind === 267 /* ModuleDeclaration */; + case 19 /* OpenBraceToken */: + return containingNodeKind === 263 /* ClassDeclaration */ || containingNodeKind === 210 /* ObjectLiteralExpression */; + case 64 /* EqualsToken */: + return containingNodeKind === 260 /* VariableDeclaration */ || containingNodeKind === 226 /* BinaryExpression */; + case 16 /* TemplateHead */: + return containingNodeKind === 228 /* TemplateExpression */; + case 17 /* TemplateMiddle */: + return containingNodeKind === 239 /* TemplateSpan */; + case 134 /* AsyncKeyword */: + return containingNodeKind === 174 /* MethodDeclaration */ || containingNodeKind === 304 /* ShorthandPropertyAssignment */; + case 42 /* AsteriskToken */: + return containingNodeKind === 174 /* MethodDeclaration */; + } + if (isClassMemberCompletionKeyword(tokenKind)) { + return true; + } + } + return false; } - function createTypeNode(typeNode) { - return getSynthesizedDeepClone( - typeNode, - /*includeTrivia*/ - false - ); + function isInStringOrRegularExpressionOrTemplateLiteral(contextToken2) { + return (isRegularExpressionLiteral(contextToken2) || isStringTextContainingNode(contextToken2)) && (rangeContainsPositionExclusive(contextToken2, position) || position === contextToken2.end && (!!contextToken2.isUnterminated || isRegularExpressionLiteral(contextToken2))); } - } - function createSignatureDeclarationFromSignature(kind, context, quotePreference, signature, body, name, modifiers, optional, enclosingDeclaration, importAdder) { - const program = context.program; - const checker = program.getTypeChecker(); - const scriptTarget = getEmitScriptTarget(program.getCompilerOptions()); - const isJs = isInJSFile(enclosingDeclaration); - const flags = 1 /* NoTruncation */ | 256 /* SuppressAnyReturnType */ | 524288 /* AllowEmptyTuple */ | (quotePreference === 0 /* Single */ ? 268435456 /* UseSingleQuotesForStringLiteralType */ : 0 /* None */); - const signatureDeclaration = checker.signatureToSignatureDeclaration(signature, kind, enclosingDeclaration, flags, getNoopSymbolTrackerWithResolver(context)); - if (!signatureDeclaration) { - return void 0; + function tryGetObjectTypeLiteralInTypeArgumentCompletionSymbols() { + const typeLiteralNode = tryGetTypeLiteralNode(contextToken); + if (!typeLiteralNode) + return 0 /* Continue */; + const intersectionTypeNode = isIntersectionTypeNode(typeLiteralNode.parent) ? typeLiteralNode.parent : void 0; + const containerTypeNode = intersectionTypeNode || typeLiteralNode; + const containerExpectedType = getConstraintOfTypeArgumentProperty(containerTypeNode, typeChecker); + if (!containerExpectedType) + return 0 /* Continue */; + const containerActualType = typeChecker.getTypeFromTypeNode(containerTypeNode); + const members = getPropertiesForCompletion(containerExpectedType, typeChecker); + const existingMembers = getPropertiesForCompletion(containerActualType, typeChecker); + const existingMemberEscapedNames = /* @__PURE__ */ new Set(); + existingMembers.forEach((s) => existingMemberEscapedNames.add(s.escapedName)); + symbols = concatenate(symbols, filter(members, (s) => !existingMemberEscapedNames.has(s.escapedName))); + completionKind = 0 /* ObjectPropertyDeclaration */; + isNewIdentifierLocation = true; + return 1 /* Success */; } - let typeParameters = isJs ? void 0 : signatureDeclaration.typeParameters; - let parameters = signatureDeclaration.parameters; - let type = isJs ? void 0 : signatureDeclaration.type; - if (importAdder) { - if (typeParameters) { - const newTypeParameters = sameMap(typeParameters, (typeParameterDecl) => { - let constraint = typeParameterDecl.constraint; - let defaultType = typeParameterDecl.default; - if (constraint) { - const importableReference = tryGetAutoImportableReferenceFromTypeNode(constraint, scriptTarget); - if (importableReference) { - constraint = importableReference.typeNode; - importSymbols(importAdder, importableReference.symbols); - } + function tryGetObjectLikeCompletionSymbols() { + const symbolsStartIndex = symbols.length; + const objectLikeContainer = tryGetObjectLikeCompletionContainer(contextToken, position, sourceFile); + if (!objectLikeContainer) + return 0 /* Continue */; + completionKind = 0 /* ObjectPropertyDeclaration */; + let typeMembers; + let existingMembers; + if (objectLikeContainer.kind === 210 /* ObjectLiteralExpression */) { + const instantiatedType = tryGetObjectLiteralContextualType(objectLikeContainer, typeChecker); + if (instantiatedType === void 0) { + if (objectLikeContainer.flags & 67108864 /* InWithStatement */) { + return 2 /* Fail */; } - if (defaultType) { - const importableReference = tryGetAutoImportableReferenceFromTypeNode(defaultType, scriptTarget); - if (importableReference) { - defaultType = importableReference.typeNode; - importSymbols(importAdder, importableReference.symbols); - } + isNonContextualObjectLiteral = true; + return 0 /* Continue */; + } + const completionsType = typeChecker.getContextualType(objectLikeContainer, 4 /* Completions */); + const hasStringIndexType = (completionsType || instantiatedType).getStringIndexType(); + const hasNumberIndextype = (completionsType || instantiatedType).getNumberIndexType(); + isNewIdentifierLocation = !!hasStringIndexType || !!hasNumberIndextype; + typeMembers = getPropertiesForObjectExpression(instantiatedType, completionsType, objectLikeContainer, typeChecker); + existingMembers = objectLikeContainer.properties; + if (typeMembers.length === 0) { + if (!hasNumberIndextype) { + isNonContextualObjectLiteral = true; + return 0 /* Continue */; } - return factory.updateTypeParameterDeclaration( - typeParameterDecl, - typeParameterDecl.modifiers, - typeParameterDecl.name, - constraint, - defaultType - ); - }); - if (typeParameters !== newTypeParameters) { - typeParameters = setTextRange(factory.createNodeArray(newTypeParameters, typeParameters.hasTrailingComma), typeParameters); } - } - const newParameters = sameMap(parameters, (parameterDecl) => { - let type2 = isJs ? void 0 : parameterDecl.type; - if (type2) { - const importableReference = tryGetAutoImportableReferenceFromTypeNode(type2, scriptTarget); - if (importableReference) { - type2 = importableReference.typeNode; - importSymbols(importAdder, importableReference.symbols); + } else { + Debug.assert(objectLikeContainer.kind === 206 /* ObjectBindingPattern */); + isNewIdentifierLocation = false; + const rootDeclaration = getRootDeclaration(objectLikeContainer.parent); + if (!isVariableLike(rootDeclaration)) + return Debug.fail("Root declaration is not variable-like."); + let canGetType = hasInitializer(rootDeclaration) || !!getEffectiveTypeAnnotationNode(rootDeclaration) || rootDeclaration.parent.parent.kind === 250 /* ForOfStatement */; + if (!canGetType && rootDeclaration.kind === 169 /* Parameter */) { + if (isExpression(rootDeclaration.parent)) { + canGetType = !!typeChecker.getContextualType(rootDeclaration.parent); + } else if (rootDeclaration.parent.kind === 174 /* MethodDeclaration */ || rootDeclaration.parent.kind === 178 /* SetAccessor */) { + canGetType = isExpression(rootDeclaration.parent.parent) && !!typeChecker.getContextualType(rootDeclaration.parent.parent); } } - return factory.updateParameterDeclaration( - parameterDecl, - parameterDecl.modifiers, - parameterDecl.dotDotDotToken, - parameterDecl.name, - isJs ? void 0 : parameterDecl.questionToken, - type2, - parameterDecl.initializer - ); - }); - if (parameters !== newParameters) { - parameters = setTextRange(factory.createNodeArray(newParameters, parameters.hasTrailingComma), parameters); + if (canGetType) { + const typeForObject = typeChecker.getTypeAtLocation(objectLikeContainer); + if (!typeForObject) + return 2 /* Fail */; + typeMembers = typeChecker.getPropertiesOfType(typeForObject).filter((propertySymbol) => { + return typeChecker.isPropertyAccessible( + objectLikeContainer, + /*isSuper*/ + false, + /*isWrite*/ + false, + typeForObject, + propertySymbol + ); + }); + existingMembers = objectLikeContainer.elements; + } } - if (type) { - const importableReference = tryGetAutoImportableReferenceFromTypeNode(type, scriptTarget); - if (importableReference) { - type = importableReference.typeNode; - importSymbols(importAdder, importableReference.symbols); + if (typeMembers && typeMembers.length > 0) { + const filteredMembers = filterObjectMembersList(typeMembers, Debug.checkDefined(existingMembers)); + symbols = concatenate(symbols, filteredMembers); + setSortTextToOptionalMember(); + if (objectLikeContainer.kind === 210 /* ObjectLiteralExpression */ && preferences.includeCompletionsWithObjectLiteralMethodSnippets && preferences.includeCompletionsWithInsertText) { + transformObjectLiteralMembersSortText(symbolsStartIndex); + collectObjectLiteralMethodSymbols(filteredMembers, objectLikeContainer); } } + return 1 /* Success */; } - const questionToken = optional ? factory.createToken(58 /* QuestionToken */) : void 0; - const asteriskToken = signatureDeclaration.asteriskToken; - if (isFunctionExpression(signatureDeclaration)) { - return factory.updateFunctionExpression(signatureDeclaration, modifiers, signatureDeclaration.asteriskToken, tryCast(name, isIdentifier), typeParameters, parameters, type, body ?? signatureDeclaration.body); - } - if (isArrowFunction(signatureDeclaration)) { - return factory.updateArrowFunction(signatureDeclaration, modifiers, typeParameters, parameters, type, signatureDeclaration.equalsGreaterThanToken, body ?? signatureDeclaration.body); - } - if (isMethodDeclaration(signatureDeclaration)) { - return factory.updateMethodDeclaration(signatureDeclaration, modifiers, asteriskToken, name ?? factory.createIdentifier(""), questionToken, typeParameters, parameters, type, body); - } - if (isFunctionDeclaration(signatureDeclaration)) { - return factory.updateFunctionDeclaration(signatureDeclaration, modifiers, signatureDeclaration.asteriskToken, tryCast(name, isIdentifier), typeParameters, parameters, type, body ?? signatureDeclaration.body); - } - return void 0; - } - function createSignatureDeclarationFromCallExpression(kind, context, importAdder, call, name, modifierFlags, contextNode) { - const quotePreference = getQuotePreference(context.sourceFile, context.preferences); - const scriptTarget = getEmitScriptTarget(context.program.getCompilerOptions()); - const tracker = getNoopSymbolTrackerWithResolver(context); - const checker = context.program.getTypeChecker(); - const isJs = isInJSFile(contextNode); - const { typeArguments, arguments: args, parent: parent2 } = call; - const contextualType = isJs ? void 0 : checker.getContextualType(call); - const names = map(args, (arg) => isIdentifier(arg) ? arg.text : isPropertyAccessExpression(arg) && isIdentifier(arg.name) ? arg.name.text : void 0); - const instanceTypes = isJs ? [] : map(args, (arg) => checker.getTypeAtLocation(arg)); - const { argumentTypeNodes, argumentTypeParameters } = getArgumentTypesAndTypeParameters( - checker, - importAdder, - instanceTypes, - contextNode, - scriptTarget, - /*flags*/ - void 0, - tracker - ); - const modifiers = modifierFlags ? factory.createNodeArray(factory.createModifiersFromModifierFlags(modifierFlags)) : void 0; - const asteriskToken = isYieldExpression(parent2) ? factory.createToken(42 /* AsteriskToken */) : void 0; - const typeParameters = isJs ? void 0 : createTypeParametersForArguments(checker, argumentTypeParameters, typeArguments); - const parameters = createDummyParameters( - args.length, - names, - argumentTypeNodes, - /*minArgumentCount*/ - void 0, - isJs - ); - const type = isJs || contextualType === void 0 ? void 0 : checker.typeToTypeNode( - contextualType, - contextNode, - /*flags*/ - void 0, - tracker - ); - switch (kind) { - case 173 /* MethodDeclaration */: - return factory.createMethodDeclaration( - modifiers, - asteriskToken, - name, - /*questionToken*/ - void 0, - typeParameters, - parameters, - type, - createStubbedMethodBody(quotePreference) - ); - case 172 /* MethodSignature */: - return factory.createMethodSignature( - modifiers, - name, - /*questionToken*/ - void 0, - typeParameters, - parameters, - type === void 0 ? factory.createKeywordTypeNode(159 /* UnknownKeyword */) : type - ); - case 261 /* FunctionDeclaration */: - return factory.createFunctionDeclaration( - modifiers, - asteriskToken, - name, - typeParameters, - parameters, - type, - createStubbedBody(Diagnostics.Function_not_implemented.message, quotePreference) - ); - default: - Debug.fail("Unexpected kind"); - } - } - function createTypeParametersForArguments(checker, argumentTypeParameters, typeArguments) { - const usedNames = new Set(argumentTypeParameters.map((pair) => pair[0])); - const constraintsByName = new Map(argumentTypeParameters); - if (typeArguments) { - const typeArgumentsWithNewTypes = typeArguments.filter((typeArgument) => !argumentTypeParameters.some((pair) => { - var _a; - return checker.getTypeAtLocation(typeArgument) === ((_a = pair[1]) == null ? void 0 : _a.argumentType); - })); - const targetSize = usedNames.size + typeArgumentsWithNewTypes.length; - for (let i = 0; usedNames.size < targetSize; i += 1) { - usedNames.add(createTypeParameterName(i)); + function tryGetImportOrExportClauseCompletionSymbols() { + if (!contextToken) + return 0 /* Continue */; + const namedImportsOrExports = contextToken.kind === 19 /* OpenBraceToken */ || contextToken.kind === 28 /* CommaToken */ ? tryCast(contextToken.parent, isNamedImportsOrExports) : isTypeKeywordTokenOrIdentifier(contextToken) ? tryCast(contextToken.parent.parent, isNamedImportsOrExports) : void 0; + if (!namedImportsOrExports) + return 0 /* Continue */; + if (!isTypeKeywordTokenOrIdentifier(contextToken)) { + keywordFilters = 8 /* TypeKeyword */; } - } - return arrayFrom( - usedNames.values(), - (usedName) => { - var _a; - return factory.createTypeParameterDeclaration( - /*modifiers*/ - void 0, - usedName, - (_a = constraintsByName.get(usedName)) == null ? void 0 : _a.constraint - ); + const { moduleSpecifier } = namedImportsOrExports.kind === 275 /* NamedImports */ ? namedImportsOrExports.parent.parent : namedImportsOrExports.parent; + if (!moduleSpecifier) { + isNewIdentifierLocation = true; + return namedImportsOrExports.kind === 275 /* NamedImports */ ? 2 /* Fail */ : 0 /* Continue */; } - ); - } - function createTypeParameterName(index) { - return 84 /* T */ + index <= 90 /* Z */ ? String.fromCharCode(84 /* T */ + index) : `T${index}`; - } - function typeToAutoImportableTypeNode(checker, importAdder, type, contextNode, scriptTarget, flags, tracker) { - let typeNode = checker.typeToTypeNode(type, contextNode, flags, tracker); - if (typeNode && isImportTypeNode(typeNode)) { - const importableReference = tryGetAutoImportableReferenceFromTypeNode(typeNode, scriptTarget); - if (importableReference) { - importSymbols(importAdder, importableReference.symbols); - typeNode = importableReference.typeNode; + const moduleSpecifierSymbol = typeChecker.getSymbolAtLocation(moduleSpecifier); + if (!moduleSpecifierSymbol) { + isNewIdentifierLocation = true; + return 2 /* Fail */; + } + completionKind = 3 /* MemberLike */; + isNewIdentifierLocation = false; + const exports = typeChecker.getExportsAndPropertiesOfModule(moduleSpecifierSymbol); + const existing = new Set(namedImportsOrExports.elements.filter((n) => !isCurrentlyEditingNode(n)).map((n) => (n.propertyName || n.name).escapedText)); + const uniques = exports.filter((e) => e.escapedName !== "default" /* Default */ && !existing.has(e.escapedName)); + symbols = concatenate(symbols, uniques); + if (!uniques.length) { + keywordFilters = 0 /* None */; } + return 1 /* Success */; } - return getSynthesizedDeepClone(typeNode); - } - function typeContainsTypeParameter(type) { - if (type.isUnionOrIntersection()) { - return type.types.some(typeContainsTypeParameter); + function tryGetLocalNamedExportCompletionSymbols() { + var _a; + const namedExports = contextToken && (contextToken.kind === 19 /* OpenBraceToken */ || contextToken.kind === 28 /* CommaToken */) ? tryCast(contextToken.parent, isNamedExports) : void 0; + if (!namedExports) { + return 0 /* Continue */; + } + const localsContainer = findAncestor(namedExports, or(isSourceFile, isModuleDeclaration)); + completionKind = 5 /* None */; + isNewIdentifierLocation = false; + (_a = localsContainer.locals) == null ? void 0 : _a.forEach((symbol, name) => { + var _a2, _b; + symbols.push(symbol); + if ((_b = (_a2 = localsContainer.symbol) == null ? void 0 : _a2.exports) == null ? void 0 : _b.has(name)) { + symbolToSortTextMap[getSymbolId(symbol)] = SortText.OptionalMember; + } + }); + return 1 /* Success */; } - return type.flags & 262144 /* TypeParameter */; - } - function getArgumentTypesAndTypeParameters(checker, importAdder, instanceTypes, contextNode, scriptTarget, flags, tracker) { - const argumentTypeNodes = []; - const argumentTypeParameters = /* @__PURE__ */ new Map(); - for (let i = 0; i < instanceTypes.length; i += 1) { - const instanceType = instanceTypes[i]; - if (instanceType.isUnionOrIntersection() && instanceType.types.some(typeContainsTypeParameter)) { - const synthesizedTypeParameterName = createTypeParameterName(i); - argumentTypeNodes.push(factory.createTypeReferenceNode(synthesizedTypeParameterName)); - argumentTypeParameters.set(synthesizedTypeParameterName, void 0); - continue; + function tryGetClassLikeCompletionSymbols() { + const decl = tryGetObjectTypeDeclarationCompletionContainer(sourceFile, contextToken, location, position); + if (!decl) + return 0 /* Continue */; + completionKind = 3 /* MemberLike */; + isNewIdentifierLocation = true; + keywordFilters = contextToken.kind === 42 /* AsteriskToken */ ? 0 /* None */ : isClassLike(decl) ? 2 /* ClassElementKeywords */ : 3 /* InterfaceElementKeywords */; + if (!isClassLike(decl)) + return 1 /* Success */; + const classElement = contextToken.kind === 27 /* SemicolonToken */ ? contextToken.parent.parent : contextToken.parent; + let classElementModifierFlags = isClassElement(classElement) ? getEffectiveModifierFlags(classElement) : 0 /* None */; + if (contextToken.kind === 80 /* Identifier */ && !isCurrentlyEditingNode(contextToken)) { + switch (contextToken.getText()) { + case "private": + classElementModifierFlags = classElementModifierFlags | 2 /* Private */; + break; + case "static": + classElementModifierFlags = classElementModifierFlags | 256 /* Static */; + break; + case "override": + classElementModifierFlags = classElementModifierFlags | 16 /* Override */; + break; + } } - const widenedInstanceType = checker.getBaseTypeOfLiteralType(instanceType); - const argumentTypeNode = typeToAutoImportableTypeNode(checker, importAdder, widenedInstanceType, contextNode, scriptTarget, flags, tracker); - if (!argumentTypeNode) { - continue; + if (isClassStaticBlockDeclaration(classElement)) { + classElementModifierFlags |= 256 /* Static */; } - argumentTypeNodes.push(argumentTypeNode); - const argumentTypeParameter = getFirstTypeParameterName(instanceType); - const instanceTypeConstraint = instanceType.isTypeParameter() && instanceType.constraint && !isAnonymousObjectConstraintType(instanceType.constraint) ? typeToAutoImportableTypeNode(checker, importAdder, instanceType.constraint, contextNode, scriptTarget, flags, tracker) : void 0; - if (argumentTypeParameter) { - argumentTypeParameters.set(argumentTypeParameter, { argumentType: instanceType, constraint: instanceTypeConstraint }); + if (!(classElementModifierFlags & 2 /* Private */)) { + const baseTypeNodes = isClassLike(decl) && classElementModifierFlags & 16 /* Override */ ? singleElementArray(getEffectiveBaseTypeNode(decl)) : getAllSuperTypeNodes(decl); + const baseSymbols = flatMap(baseTypeNodes, (baseTypeNode) => { + const type = typeChecker.getTypeAtLocation(baseTypeNode); + return classElementModifierFlags & 256 /* Static */ ? (type == null ? void 0 : type.symbol) && typeChecker.getPropertiesOfType(typeChecker.getTypeOfSymbolAtLocation(type.symbol, decl)) : type && typeChecker.getPropertiesOfType(type); + }); + symbols = concatenate(symbols, filterClassMembersList(baseSymbols, decl.members, classElementModifierFlags)); + forEach(symbols, (symbol, index) => { + const declaration = symbol == null ? void 0 : symbol.valueDeclaration; + if (declaration && isClassElement(declaration) && declaration.name && isComputedPropertyName(declaration.name)) { + const origin = { + kind: 512 /* ComputedPropertyName */, + symbolName: typeChecker.symbolToString(symbol) + }; + symbolToOriginInfoMap[index] = origin; + } + }); } + return 1 /* Success */; } - return { argumentTypeNodes, argumentTypeParameters: arrayFrom(argumentTypeParameters.entries()) }; - } - function isAnonymousObjectConstraintType(type) { - return type.flags & 524288 /* Object */ && type.objectFlags === 16 /* Anonymous */; - } - function getFirstTypeParameterName(type) { - var _a; - if (type.flags & (1048576 /* Union */ | 2097152 /* Intersection */)) { - for (const subType of type.types) { - const subTypeName = getFirstTypeParameterName(subType); - if (subTypeName) { - return subTypeName; + function isConstructorParameterCompletion(node2) { + return !!node2.parent && isParameter(node2.parent) && isConstructorDeclaration(node2.parent.parent) && (isParameterPropertyModifier(node2.kind) || isDeclarationName(node2)); + } + function tryGetConstructorLikeCompletionContainer(contextToken2) { + if (contextToken2) { + const parent2 = contextToken2.parent; + switch (contextToken2.kind) { + case 21 /* OpenParenToken */: + case 28 /* CommaToken */: + return isConstructorDeclaration(contextToken2.parent) ? contextToken2.parent : void 0; + default: + if (isConstructorParameterCompletion(contextToken2)) { + return parent2.parent; + } } } + return void 0; } - return type.flags & 262144 /* TypeParameter */ ? (_a = type.getSymbol()) == null ? void 0 : _a.getName() : void 0; - } - function createDummyParameters(argCount, names, types, minArgumentCount, inJs) { - const parameters = []; - const parameterNameCounts = /* @__PURE__ */ new Map(); - for (let i = 0; i < argCount; i++) { - const parameterName = (names == null ? void 0 : names[i]) || `arg${i}`; - const parameterNameCount = parameterNameCounts.get(parameterName); - parameterNameCounts.set(parameterName, (parameterNameCount || 0) + 1); - const newParameter = factory.createParameterDeclaration( - /*modifiers*/ - void 0, - /*dotDotDotToken*/ - void 0, - /*name*/ - parameterName + (parameterNameCount || ""), - /*questionToken*/ - minArgumentCount !== void 0 && i >= minArgumentCount ? factory.createToken(58 /* QuestionToken */) : void 0, - /*type*/ - inJs ? void 0 : (types == null ? void 0 : types[i]) || factory.createKeywordTypeNode(159 /* UnknownKeyword */), - /*initializer*/ - void 0 - ); - parameters.push(newParameter); - } - return parameters; - } - function createMethodImplementingSignatures(checker, context, enclosingDeclaration, signatures, name, optional, modifiers, quotePreference, body) { - let maxArgsSignature = signatures[0]; - let minArgumentCount = signatures[0].minArgumentCount; - let someSigHasRestParameter = false; - for (const sig of signatures) { - minArgumentCount = Math.min(sig.minArgumentCount, minArgumentCount); - if (signatureHasRestParameter(sig)) { - someSigHasRestParameter = true; - } - if (sig.parameters.length >= maxArgsSignature.parameters.length && (!signatureHasRestParameter(sig) || signatureHasRestParameter(maxArgsSignature))) { - maxArgsSignature = sig; + function tryGetFunctionLikeBodyCompletionContainer(contextToken2) { + if (contextToken2) { + let prev; + const container = findAncestor(contextToken2.parent, (node2) => { + if (isClassLike(node2)) { + return "quit"; + } + if (isFunctionLikeDeclaration(node2) && prev === node2.body) { + return true; + } + prev = node2; + return false; + }); + return container && container; } } - const maxNonRestArgs = maxArgsSignature.parameters.length - (signatureHasRestParameter(maxArgsSignature) ? 1 : 0); - const maxArgsParameterSymbolNames = maxArgsSignature.parameters.map((symbol) => symbol.name); - const parameters = createDummyParameters( - maxNonRestArgs, - maxArgsParameterSymbolNames, - /*types*/ - void 0, - minArgumentCount, - /*inJs*/ - false - ); - if (someSigHasRestParameter) { - const restParameter = factory.createParameterDeclaration( - /*modifiers*/ - void 0, - factory.createToken(26 /* DotDotDotToken */), - maxArgsParameterSymbolNames[maxNonRestArgs] || "rest", - /*questionToken*/ - maxNonRestArgs >= minArgumentCount ? factory.createToken(58 /* QuestionToken */) : void 0, - factory.createArrayTypeNode(factory.createKeywordTypeNode(159 /* UnknownKeyword */)), - /*initializer*/ - void 0 - ); - parameters.push(restParameter); + function tryGetContainingJsxElement(contextToken2) { + if (contextToken2) { + const parent2 = contextToken2.parent; + switch (contextToken2.kind) { + case 32 /* GreaterThanToken */: + case 31 /* LessThanSlashToken */: + case 44 /* SlashToken */: + case 80 /* Identifier */: + case 211 /* PropertyAccessExpression */: + case 292 /* JsxAttributes */: + case 291 /* JsxAttribute */: + case 293 /* JsxSpreadAttribute */: + if (parent2 && (parent2.kind === 285 /* JsxSelfClosingElement */ || parent2.kind === 286 /* JsxOpeningElement */)) { + if (contextToken2.kind === 32 /* GreaterThanToken */) { + const precedingToken = findPrecedingToken( + contextToken2.pos, + sourceFile, + /*startNode*/ + void 0 + ); + if (!parent2.typeArguments || precedingToken && precedingToken.kind === 44 /* SlashToken */) + break; + } + return parent2; + } else if (parent2.kind === 291 /* JsxAttribute */) { + return parent2.parent.parent; + } + break; + case 11 /* StringLiteral */: + if (parent2 && (parent2.kind === 291 /* JsxAttribute */ || parent2.kind === 293 /* JsxSpreadAttribute */)) { + return parent2.parent.parent; + } + break; + case 20 /* CloseBraceToken */: + if (parent2 && parent2.kind === 294 /* JsxExpression */ && parent2.parent && parent2.parent.kind === 291 /* JsxAttribute */) { + return parent2.parent.parent.parent; + } + if (parent2 && parent2.kind === 293 /* JsxSpreadAttribute */) { + return parent2.parent.parent; + } + break; + } + } + return void 0; } - return createStubbedMethod( - modifiers, - name, - optional, - /*typeParameters*/ - void 0, - parameters, - getReturnTypeFromSignatures(signatures, checker, context, enclosingDeclaration), - quotePreference, - body - ); - } - function getReturnTypeFromSignatures(signatures, checker, context, enclosingDeclaration) { - if (length(signatures)) { - const type = checker.getUnionType(map(signatures, checker.getReturnTypeOfSignature)); - return checker.typeToTypeNode(type, enclosingDeclaration, 1 /* NoTruncation */, getNoopSymbolTrackerWithResolver(context)); + function isSolelyIdentifierDefinitionLocation(contextToken2) { + const parent2 = contextToken2.parent; + const containingNodeKind = parent2.kind; + switch (contextToken2.kind) { + case 28 /* CommaToken */: + return containingNodeKind === 260 /* VariableDeclaration */ || isVariableDeclarationListButNotTypeArgument(contextToken2) || containingNodeKind === 243 /* VariableStatement */ || containingNodeKind === 266 /* EnumDeclaration */ || // enum a { foo, | + isFunctionLikeButNotConstructor(containingNodeKind) || containingNodeKind === 264 /* InterfaceDeclaration */ || // interface A= contextToken2.pos; + case 25 /* DotToken */: + return containingNodeKind === 207 /* ArrayBindingPattern */; + case 59 /* ColonToken */: + return containingNodeKind === 208 /* BindingElement */; + case 23 /* OpenBracketToken */: + return containingNodeKind === 207 /* ArrayBindingPattern */; + case 21 /* OpenParenToken */: + return containingNodeKind === 299 /* CatchClause */ || isFunctionLikeButNotConstructor(containingNodeKind); + case 19 /* OpenBraceToken */: + return containingNodeKind === 266 /* EnumDeclaration */; + case 30 /* LessThanToken */: + return containingNodeKind === 263 /* ClassDeclaration */ || // class A< | + containingNodeKind === 231 /* ClassExpression */ || // var C = class D< | + containingNodeKind === 264 /* InterfaceDeclaration */ || // interface A< | + containingNodeKind === 265 /* TypeAliasDeclaration */ || // type List< | + isFunctionLikeKind(containingNodeKind); + case 126 /* StaticKeyword */: + return containingNodeKind === 172 /* PropertyDeclaration */ && !isClassLike(parent2.parent); + case 26 /* DotDotDotToken */: + return containingNodeKind === 169 /* Parameter */ || !!parent2.parent && parent2.parent.kind === 207 /* ArrayBindingPattern */; + case 125 /* PublicKeyword */: + case 123 /* PrivateKeyword */: + case 124 /* ProtectedKeyword */: + return containingNodeKind === 169 /* Parameter */ && !isConstructorDeclaration(parent2.parent); + case 130 /* AsKeyword */: + return containingNodeKind === 276 /* ImportSpecifier */ || containingNodeKind === 281 /* ExportSpecifier */ || containingNodeKind === 274 /* NamespaceImport */; + case 139 /* GetKeyword */: + case 153 /* SetKeyword */: + return !isFromObjectTypeDeclaration(contextToken2); + case 80 /* Identifier */: + if (containingNodeKind === 276 /* ImportSpecifier */ && contextToken2 === parent2.name && contextToken2.text === "type") { + return false; + } + break; + case 86 /* ClassKeyword */: + case 94 /* EnumKeyword */: + case 120 /* InterfaceKeyword */: + case 100 /* FunctionKeyword */: + case 115 /* VarKeyword */: + case 102 /* ImportKeyword */: + case 121 /* LetKeyword */: + case 87 /* ConstKeyword */: + case 140 /* InferKeyword */: + return true; + case 156 /* TypeKeyword */: + return containingNodeKind !== 276 /* ImportSpecifier */; + case 42 /* AsteriskToken */: + return isFunctionLike(contextToken2.parent) && !isMethodDeclaration(contextToken2.parent); + } + if (isClassMemberCompletionKeyword(keywordForNode(contextToken2)) && isFromObjectTypeDeclaration(contextToken2)) { + return false; + } + if (isConstructorParameterCompletion(contextToken2)) { + if (!isIdentifier(contextToken2) || isParameterPropertyModifier(keywordForNode(contextToken2)) || isCurrentlyEditingNode(contextToken2)) { + return false; + } + } + switch (keywordForNode(contextToken2)) { + case 128 /* AbstractKeyword */: + case 86 /* ClassKeyword */: + case 87 /* ConstKeyword */: + case 138 /* DeclareKeyword */: + case 94 /* EnumKeyword */: + case 100 /* FunctionKeyword */: + case 120 /* InterfaceKeyword */: + case 121 /* LetKeyword */: + case 123 /* PrivateKeyword */: + case 124 /* ProtectedKeyword */: + case 125 /* PublicKeyword */: + case 126 /* StaticKeyword */: + case 115 /* VarKeyword */: + return true; + case 134 /* AsyncKeyword */: + return isPropertyDeclaration(contextToken2.parent); + } + const ancestorClassLike = findAncestor(contextToken2.parent, isClassLike); + if (ancestorClassLike && contextToken2 === previousToken && isPreviousPropertyDeclarationTerminated(contextToken2, position)) { + return false; + } + const ancestorPropertyDeclaraion = getAncestor(contextToken2.parent, 172 /* PropertyDeclaration */); + if (ancestorPropertyDeclaraion && contextToken2 !== previousToken && isClassLike(previousToken.parent.parent) && position <= previousToken.end) { + if (isPreviousPropertyDeclarationTerminated(contextToken2, previousToken.end)) { + return false; + } else if (contextToken2.kind !== 64 /* EqualsToken */ && (isInitializedProperty(ancestorPropertyDeclaraion) || hasType(ancestorPropertyDeclaraion))) { + return true; + } + } + return isDeclarationName(contextToken2) && !isShorthandPropertyAssignment(contextToken2.parent) && !isJsxAttribute(contextToken2.parent) && !((isClassLike(contextToken2.parent) || isInterfaceDeclaration(contextToken2.parent) || isTypeParameterDeclaration(contextToken2.parent)) && (contextToken2 !== previousToken || position > previousToken.end)); } - } - function createStubbedMethod(modifiers, name, optional, typeParameters, parameters, returnType, quotePreference, body) { - return factory.createMethodDeclaration( - modifiers, - /*asteriskToken*/ - void 0, - name, - optional ? factory.createToken(58 /* QuestionToken */) : void 0, - typeParameters, - parameters, - returnType, - body || createStubbedMethodBody(quotePreference) - ); - } - function createStubbedMethodBody(quotePreference) { - return createStubbedBody(Diagnostics.Method_not_implemented.message, quotePreference); - } - function createStubbedBody(text, quotePreference) { - return factory.createBlock( - [factory.createThrowStatement( - factory.createNewExpression( - factory.createIdentifier("Error"), - /*typeArguments*/ - void 0, - // TODO Handle auto quote preference. - [factory.createStringLiteral( - text, - /*isSingleQuote*/ - quotePreference === 0 /* Single */ - )] - ) - )], - /*multiLine*/ - true - ); - } - function setJsonCompilerOptionValues(changeTracker, configFile, options) { - const tsconfigObjectLiteral = getTsConfigObjectLiteralExpression(configFile); - if (!tsconfigObjectLiteral) - return void 0; - const compilerOptionsProperty = findJsonProperty(tsconfigObjectLiteral, "compilerOptions"); - if (compilerOptionsProperty === void 0) { - changeTracker.insertNodeAtObjectStart(configFile, tsconfigObjectLiteral, createJsonPropertyAssignment( - "compilerOptions", - factory.createObjectLiteralExpression( - options.map(([optionName, optionValue]) => createJsonPropertyAssignment(optionName, optionValue)), - /*multiLine*/ - true - ) - )); - return; + function isPreviousPropertyDeclarationTerminated(contextToken2, position2) { + return contextToken2.kind !== 64 /* EqualsToken */ && (contextToken2.kind === 27 /* SemicolonToken */ || !positionsAreOnSameLine(contextToken2.end, position2, sourceFile)); } - const compilerOptions = compilerOptionsProperty.initializer; - if (!isObjectLiteralExpression(compilerOptions)) { - return; + function isFunctionLikeButNotConstructor(kind) { + return isFunctionLikeKind(kind) && kind !== 176 /* Constructor */; } - for (const [optionName, optionValue] of options) { - const optionProperty = findJsonProperty(compilerOptions, optionName); - if (optionProperty === void 0) { - changeTracker.insertNodeAtObjectStart(configFile, compilerOptions, createJsonPropertyAssignment(optionName, optionValue)); - } else { - changeTracker.replaceNode(configFile, optionProperty.initializer, optionValue); + function isDotOfNumericLiteral(contextToken2) { + if (contextToken2.kind === 9 /* NumericLiteral */) { + const text = contextToken2.getFullText(); + return text.charAt(text.length - 1) === "."; } + return false; } - } - function setJsonCompilerOptionValue(changeTracker, configFile, optionName, optionValue) { - setJsonCompilerOptionValues(changeTracker, configFile, [[optionName, optionValue]]); - } - function createJsonPropertyAssignment(name, initializer) { - return factory.createPropertyAssignment(factory.createStringLiteral(name), initializer); - } - function findJsonProperty(obj, name) { - return find(obj.properties, (p) => isPropertyAssignment(p) && !!p.name && isStringLiteral(p.name) && p.name.text === name); - } - function tryGetAutoImportableReferenceFromTypeNode(importTypeNode, scriptTarget) { - let symbols; - const typeNode = visitNode(importTypeNode, visit, isTypeNode); - if (symbols && typeNode) { - return { typeNode, symbols }; + function isVariableDeclarationListButNotTypeArgument(node2) { + return node2.parent.kind === 261 /* VariableDeclarationList */ && !isPossiblyTypeArgumentPosition(node2, sourceFile, typeChecker); } - function visit(node) { - if (isLiteralImportTypeNode(node) && node.qualifier) { - const firstIdentifier = getFirstIdentifier(node.qualifier); - const name = getNameForExportedSymbol(firstIdentifier.symbol, scriptTarget); - const qualifier = name !== firstIdentifier.text ? replaceFirstIdentifierOfEntityName(node.qualifier, factory.createIdentifier(name)) : node.qualifier; - symbols = append(symbols, firstIdentifier.symbol); - const typeArguments = visitNodes2(node.typeArguments, visit, isTypeNode); - return factory.createTypeReferenceNode(qualifier, typeArguments); + function filterObjectMembersList(contextualMemberSymbols, existingMembers) { + if (existingMembers.length === 0) { + return contextualMemberSymbols; } - return visitEachChild(node, visit, nullTransformationContext); - } - } - function replaceFirstIdentifierOfEntityName(name, newIdentifier) { - if (name.kind === 80 /* Identifier */) { - return newIdentifier; + const membersDeclaredBySpreadAssignment = /* @__PURE__ */ new Set(); + const existingMemberNames = /* @__PURE__ */ new Set(); + for (const m of existingMembers) { + if (m.kind !== 303 /* PropertyAssignment */ && m.kind !== 304 /* ShorthandPropertyAssignment */ && m.kind !== 208 /* BindingElement */ && m.kind !== 174 /* MethodDeclaration */ && m.kind !== 177 /* GetAccessor */ && m.kind !== 178 /* SetAccessor */ && m.kind !== 305 /* SpreadAssignment */) { + continue; + } + if (isCurrentlyEditingNode(m)) { + continue; + } + let existingName; + if (isSpreadAssignment(m)) { + setMembersDeclaredBySpreadAssignment(m, membersDeclaredBySpreadAssignment); + } else if (isBindingElement(m) && m.propertyName) { + if (m.propertyName.kind === 80 /* Identifier */) { + existingName = m.propertyName.escapedText; + } + } else { + const name = getNameOfDeclaration(m); + existingName = name && isPropertyNameLiteral(name) ? getEscapedTextOfIdentifierOrLiteral(name) : void 0; + } + if (existingName !== void 0) { + existingMemberNames.add(existingName); + } + } + const filteredSymbols = contextualMemberSymbols.filter((m) => !existingMemberNames.has(m.escapedName)); + setSortTextToMemberDeclaredBySpreadAssignment(membersDeclaredBySpreadAssignment, filteredSymbols); + return filteredSymbols; } - return factory.createQualifiedName(replaceFirstIdentifierOfEntityName(name.left, newIdentifier), name.right); - } - function importSymbols(importAdder, symbols) { - symbols.forEach((s) => importAdder.addImportFromExportedSymbol( - s, - /*isValidTypeOnlyUseSite*/ - true - )); - } - function findAncestorMatchingSpan(sourceFile, span) { - const end = textSpanEnd(span); - let token = getTokenAtPosition(sourceFile, span.start); - while (token.end < end) { - token = token.parent; + function setMembersDeclaredBySpreadAssignment(declaration, membersDeclaredBySpreadAssignment) { + const expression = declaration.expression; + const symbol = typeChecker.getSymbolAtLocation(expression); + const type = symbol && typeChecker.getTypeOfSymbolAtLocation(symbol, expression); + const properties = type && type.properties; + if (properties) { + properties.forEach((property) => { + membersDeclaredBySpreadAssignment.add(property.name); + }); + } } - return token; - } - var PreserveOptionalFlags; - var init_helpers2 = __esm({ - "src/services/codefixes/helpers.ts"() { - "use strict"; - init_ts4(); - PreserveOptionalFlags = /* @__PURE__ */ ((PreserveOptionalFlags2) => { - PreserveOptionalFlags2[PreserveOptionalFlags2["Method"] = 1] = "Method"; - PreserveOptionalFlags2[PreserveOptionalFlags2["Property"] = 2] = "Property"; - PreserveOptionalFlags2[PreserveOptionalFlags2["All"] = 3] = "All"; - return PreserveOptionalFlags2; - })(PreserveOptionalFlags || {}); + function setSortTextToOptionalMember() { + symbols.forEach((m) => { + if (m.flags & 16777216 /* Optional */) { + const symbolId = getSymbolId(m); + symbolToSortTextMap[symbolId] = symbolToSortTextMap[symbolId] ?? SortText.OptionalMember; + } + }); } - }); - - // src/services/codefixes/generateAccessors.ts - function generateAccessorFromProperty(file, program, start, end, context, _actionName) { - const fieldInfo = getAccessorConvertiblePropertyAtPosition(file, program, start, end); - if (!fieldInfo || ts_refactor_exports.isRefactorErrorInfo(fieldInfo)) - return void 0; - const changeTracker = ts_textChanges_exports.ChangeTracker.fromContext(context); - const { isStatic: isStatic2, isReadonly, fieldName, accessorName, originalName, type, container, declaration } = fieldInfo; - suppressLeadingAndTrailingTrivia(fieldName); - suppressLeadingAndTrailingTrivia(accessorName); - suppressLeadingAndTrailingTrivia(declaration); - suppressLeadingAndTrailingTrivia(container); - let accessorModifiers; - let fieldModifiers; - if (isClassLike(container)) { - const modifierFlags = getEffectiveModifierFlags(declaration); - if (isSourceFileJS(file)) { - const modifiers = factory.createModifiersFromModifierFlags(modifierFlags); - accessorModifiers = modifiers; - fieldModifiers = modifiers; - } else { - accessorModifiers = factory.createModifiersFromModifierFlags(prepareModifierFlagsForAccessor(modifierFlags)); - fieldModifiers = factory.createModifiersFromModifierFlags(prepareModifierFlagsForField(modifierFlags)); + function setSortTextToMemberDeclaredBySpreadAssignment(membersDeclaredBySpreadAssignment, contextualMemberSymbols) { + if (membersDeclaredBySpreadAssignment.size === 0) { + return; + } + for (const contextualMemberSymbol of contextualMemberSymbols) { + if (membersDeclaredBySpreadAssignment.has(contextualMemberSymbol.name)) { + symbolToSortTextMap[getSymbolId(contextualMemberSymbol)] = SortText.MemberDeclaredBySpreadAssignment; + } } - if (canHaveDecorators(declaration)) { - fieldModifiers = concatenate(getDecorators(declaration), fieldModifiers); + } + function transformObjectLiteralMembersSortText(start2) { + for (let i = start2; i < symbols.length; i++) { + const symbol = symbols[i]; + const symbolId = getSymbolId(symbol); + const origin = symbolToOriginInfoMap == null ? void 0 : symbolToOriginInfoMap[i]; + const target = getEmitScriptTarget(compilerOptions); + const displayName = getCompletionEntryDisplayNameForSymbol( + symbol, + target, + origin, + 0 /* ObjectPropertyDeclaration */, + /*jsxIdentifierExpected*/ + false + ); + if (displayName) { + const originalSortText = symbolToSortTextMap[symbolId] ?? SortText.LocationPriority; + const { name } = displayName; + symbolToSortTextMap[symbolId] = SortText.ObjectLiteralProperty(originalSortText, name); + } } } - updateFieldDeclaration(changeTracker, file, declaration, type, fieldName, fieldModifiers); - const getAccessor = generateGetAccessor(fieldName, accessorName, type, accessorModifiers, isStatic2, container); - suppressLeadingAndTrailingTrivia(getAccessor); - insertAccessor(changeTracker, file, getAccessor, declaration, container); - if (isReadonly) { - const constructor = getFirstConstructorWithBody(container); - if (constructor) { - updateReadonlyPropertyInitializerStatementConstructor(changeTracker, file, constructor, fieldName.text, originalName); + function filterClassMembersList(baseSymbols, existingMembers, currentClassElementModifierFlags) { + const existingMemberNames = /* @__PURE__ */ new Set(); + for (const m of existingMembers) { + if (m.kind !== 172 /* PropertyDeclaration */ && m.kind !== 174 /* MethodDeclaration */ && m.kind !== 177 /* GetAccessor */ && m.kind !== 178 /* SetAccessor */) { + continue; + } + if (isCurrentlyEditingNode(m)) { + continue; + } + if (hasEffectiveModifier(m, 2 /* Private */)) { + continue; + } + if (isStatic(m) !== !!(currentClassElementModifierFlags & 256 /* Static */)) { + continue; + } + const existingName = getPropertyNameForPropertyNameNode(m.name); + if (existingName) { + existingMemberNames.add(existingName); + } } - } else { - const setAccessor = generateSetAccessor(fieldName, accessorName, type, accessorModifiers, isStatic2, container); - suppressLeadingAndTrailingTrivia(setAccessor); - insertAccessor(changeTracker, file, setAccessor, declaration, container); + return baseSymbols.filter( + (propertySymbol) => !existingMemberNames.has(propertySymbol.escapedName) && !!propertySymbol.declarations && !(getDeclarationModifierFlagsFromSymbol(propertySymbol) & 2 /* Private */) && !(propertySymbol.valueDeclaration && isPrivateIdentifierClassElementDeclaration(propertySymbol.valueDeclaration)) + ); + } + function filterJsxAttributes(symbols2, attributes) { + const seenNames = /* @__PURE__ */ new Set(); + const membersDeclaredBySpreadAssignment = /* @__PURE__ */ new Set(); + for (const attr of attributes) { + if (isCurrentlyEditingNode(attr)) { + continue; + } + if (attr.kind === 291 /* JsxAttribute */) { + seenNames.add(getEscapedTextOfJsxAttributeName(attr.name)); + } else if (isJsxSpreadAttribute(attr)) { + setMembersDeclaredBySpreadAssignment(attr, membersDeclaredBySpreadAssignment); + } + } + const filteredSymbols = symbols2.filter((a) => !seenNames.has(a.escapedName)); + setSortTextToMemberDeclaredBySpreadAssignment(membersDeclaredBySpreadAssignment, filteredSymbols); + return filteredSymbols; + } + function isCurrentlyEditingNode(node2) { + return node2.getStart(sourceFile) <= position && position <= node2.getEnd(); } - return changeTracker.getChanges(); - } - function isConvertibleName(name) { - return isIdentifier(name) || isStringLiteral(name); - } - function isAcceptedDeclaration(node) { - return isParameterPropertyDeclaration(node, node.parent) || isPropertyDeclaration(node) || isPropertyAssignment(node); - } - function createPropertyName(name, originalName) { - return isIdentifier(originalName) ? factory.createIdentifier(name) : factory.createStringLiteral(name); } - function createAccessorAccessExpression(fieldName, isStatic2, container) { - const leftHead = isStatic2 ? container.name : factory.createThis(); - return isIdentifier(fieldName) ? factory.createPropertyAccessExpression(leftHead, fieldName) : factory.createElementAccessExpression(leftHead, factory.createStringLiteralFromNode(fieldName)); + function tryGetObjectLikeCompletionContainer(contextToken, position, sourceFile) { + var _a; + if (contextToken) { + const { parent: parent2 } = contextToken; + switch (contextToken.kind) { + case 19 /* OpenBraceToken */: + case 28 /* CommaToken */: + if (isObjectLiteralExpression(parent2) || isObjectBindingPattern(parent2)) { + return parent2; + } + break; + case 42 /* AsteriskToken */: + return isMethodDeclaration(parent2) ? tryCast(parent2.parent, isObjectLiteralExpression) : void 0; + case 134 /* AsyncKeyword */: + return tryCast(parent2.parent, isObjectLiteralExpression); + case 80 /* Identifier */: + if (contextToken.text === "async" && isShorthandPropertyAssignment(contextToken.parent)) { + return contextToken.parent.parent; + } else { + if (isObjectLiteralExpression(contextToken.parent.parent) && (isSpreadAssignment(contextToken.parent) || isShorthandPropertyAssignment(contextToken.parent) && getLineAndCharacterOfPosition(sourceFile, contextToken.getEnd()).line !== getLineAndCharacterOfPosition(sourceFile, position).line)) { + return contextToken.parent.parent; + } + const ancestorNode2 = findAncestor(parent2, isPropertyAssignment); + if ((ancestorNode2 == null ? void 0 : ancestorNode2.getLastToken(sourceFile)) === contextToken && isObjectLiteralExpression(ancestorNode2.parent)) { + return ancestorNode2.parent; + } + } + break; + default: + if (((_a = parent2.parent) == null ? void 0 : _a.parent) && (isMethodDeclaration(parent2.parent) || isGetAccessorDeclaration(parent2.parent) || isSetAccessorDeclaration(parent2.parent)) && isObjectLiteralExpression(parent2.parent.parent)) { + return parent2.parent.parent; + } + if (isSpreadAssignment(parent2) && isObjectLiteralExpression(parent2.parent)) { + return parent2.parent; + } + const ancestorNode = findAncestor(parent2, isPropertyAssignment); + if (contextToken.kind !== 59 /* ColonToken */ && (ancestorNode == null ? void 0 : ancestorNode.getLastToken(sourceFile)) === contextToken && isObjectLiteralExpression(ancestorNode.parent)) { + return ancestorNode.parent; + } + } + } + return void 0; } - function prepareModifierFlagsForAccessor(modifierFlags) { - modifierFlags &= ~64 /* Readonly */; - modifierFlags &= ~8 /* Private */; - if (!(modifierFlags & 16 /* Protected */)) { - modifierFlags |= 4 /* Public */; + function getRelevantTokens(position, sourceFile) { + const previousToken = findPrecedingToken(position, sourceFile); + if (previousToken && position <= previousToken.end && (isMemberName(previousToken) || isKeyword(previousToken.kind))) { + const contextToken = findPrecedingToken( + previousToken.getFullStart(), + sourceFile, + /*startNode*/ + void 0 + ); + return { contextToken, previousToken }; } - return modifierFlags; + return { contextToken: previousToken, previousToken }; } - function prepareModifierFlagsForField(modifierFlags) { - modifierFlags &= ~4 /* Public */; - modifierFlags &= ~16 /* Protected */; - modifierFlags |= 8 /* Private */; - return modifierFlags; + function getAutoImportSymbolFromCompletionEntryData(name, data, program, host) { + const containingProgram = data.isPackageJsonImport ? host.getPackageJsonAutoImportProvider() : program; + const checker = containingProgram.getTypeChecker(); + const moduleSymbol = data.ambientModuleName ? checker.tryFindAmbientModule(data.ambientModuleName) : data.fileName ? checker.getMergedSymbol(Debug.checkDefined(containingProgram.getSourceFile(data.fileName)).symbol) : void 0; + if (!moduleSymbol) + return void 0; + let symbol = data.exportName === "export=" /* ExportEquals */ ? checker.resolveExternalModuleSymbol(moduleSymbol) : checker.tryGetMemberInModuleExportsAndProperties(data.exportName, moduleSymbol); + if (!symbol) + return void 0; + const isDefaultExport = data.exportName === "default" /* Default */; + symbol = isDefaultExport && getLocalSymbolForExportDefault(symbol) || symbol; + return { symbol, origin: completionEntryDataToSymbolOriginInfo(data, name, moduleSymbol) }; } - function getAccessorConvertiblePropertyAtPosition(file, program, start, end, considerEmptySpans = true) { - const node = getTokenAtPosition(file, start); - const cursorRequest = start === end && considerEmptySpans; - const declaration = findAncestor(node.parent, isAcceptedDeclaration); - const meaning = 28 /* AccessibilityModifier */ | 32 /* Static */ | 64 /* Readonly */; - if (!declaration || !(nodeOverlapsWithStartEnd(declaration.name, file, start, end) || cursorRequest)) { - return { - error: getLocaleSpecificMessage(Diagnostics.Could_not_find_property_for_which_to_generate_accessor) - }; - } - if (!isConvertibleName(declaration.name)) { - return { - error: getLocaleSpecificMessage(Diagnostics.Name_is_not_valid) - }; + function getCompletionEntryDisplayNameForSymbol(symbol, target, origin, kind, jsxIdentifierExpected) { + if (originIsIgnore(origin)) { + return void 0; } - if ((getEffectiveModifierFlags(declaration) & 126975 /* Modifier */ | meaning) !== meaning) { - return { - error: getLocaleSpecificMessage(Diagnostics.Can_only_convert_property_with_modifier) - }; + const name = originIncludesSymbolName(origin) ? origin.symbolName : symbol.name; + if (name === void 0 || symbol.flags & 1536 /* Module */ && isSingleOrDoubleQuote(name.charCodeAt(0)) || isKnownSymbol(symbol)) { + return void 0; } - const name = declaration.name.text; - const startWithUnderscore = startsWithUnderscore(name); - const fieldName = createPropertyName(startWithUnderscore ? name : getUniqueName(`_${name}`, file), declaration.name); - const accessorName = createPropertyName(startWithUnderscore ? getUniqueName(name.substring(1), file) : name, declaration.name); - return { - isStatic: hasStaticModifier(declaration), - isReadonly: hasEffectiveReadonlyModifier(declaration), - type: getDeclarationType(declaration, program), - container: declaration.kind === 168 /* Parameter */ ? declaration.parent.parent : declaration.parent, - originalName: declaration.name.text, - declaration, - fieldName, - accessorName, - renameAccessor: startWithUnderscore - }; - } - function generateGetAccessor(fieldName, accessorName, type, modifiers, isStatic2, container) { - return factory.createGetAccessorDeclaration( - modifiers, - accessorName, - [], - type, - factory.createBlock( - [ - factory.createReturnStatement( - createAccessorAccessExpression(fieldName, isStatic2, container) - ) - ], - /*multiLine*/ - true - ) - ); - } - function generateSetAccessor(fieldName, accessorName, type, modifiers, isStatic2, container) { - return factory.createSetAccessorDeclaration( - modifiers, - accessorName, - [factory.createParameterDeclaration( - /*modifiers*/ - void 0, - /*dotDotDotToken*/ - void 0, - factory.createIdentifier("value"), - /*questionToken*/ - void 0, - type - )], - factory.createBlock( - [ - factory.createExpressionStatement( - factory.createAssignment( - createAccessorAccessExpression(fieldName, isStatic2, container), - factory.createIdentifier("value") - ) - ) - ], - /*multiLine*/ - true - ) - ); - } - function updatePropertyDeclaration(changeTracker, file, declaration, type, fieldName, modifiers) { - const property = factory.updatePropertyDeclaration( - declaration, - modifiers, - fieldName, - declaration.questionToken || declaration.exclamationToken, - type, - declaration.initializer - ); - changeTracker.replaceNode(file, declaration, property); - } - function updatePropertyAssignmentDeclaration(changeTracker, file, declaration, fieldName) { - let assignment = factory.updatePropertyAssignment(declaration, fieldName, declaration.initializer); - if (assignment.modifiers || assignment.questionToken || assignment.exclamationToken) { - if (assignment === declaration) - assignment = factory.cloneNode(assignment); - assignment.modifiers = void 0; - assignment.questionToken = void 0; - assignment.exclamationToken = void 0; + const validNameResult = { name, needsConvertPropertyAccess: false }; + if (isIdentifierText(name, target, jsxIdentifierExpected ? 1 /* JSX */ : 0 /* Standard */) || symbol.valueDeclaration && isPrivateIdentifierClassElementDeclaration(symbol.valueDeclaration)) { + return validNameResult; } - changeTracker.replacePropertyAssignment(file, declaration, assignment); - } - function updateFieldDeclaration(changeTracker, file, declaration, type, fieldName, modifiers) { - if (isPropertyDeclaration(declaration)) { - updatePropertyDeclaration(changeTracker, file, declaration, type, fieldName, modifiers); - } else if (isPropertyAssignment(declaration)) { - updatePropertyAssignmentDeclaration(changeTracker, file, declaration, fieldName); - } else { - changeTracker.replaceNode( - file, - declaration, - factory.updateParameterDeclaration(declaration, modifiers, declaration.dotDotDotToken, cast(fieldName, isIdentifier), declaration.questionToken, declaration.type, declaration.initializer) - ); + switch (kind) { + case 3 /* MemberLike */: + return originIsComputedPropertyName(origin) ? { name: origin.symbolName, needsConvertPropertyAccess: false } : void 0; + case 0 /* ObjectPropertyDeclaration */: + return { name: JSON.stringify(name), needsConvertPropertyAccess: false }; + case 2 /* PropertyAccess */: + case 1 /* Global */: + return name.charCodeAt(0) === 32 /* space */ ? void 0 : { name, needsConvertPropertyAccess: true }; + case 5 /* None */: + case 4 /* String */: + return validNameResult; + default: + Debug.assertNever(kind); } } - function insertAccessor(changeTracker, file, accessor, declaration, container) { - isParameterPropertyDeclaration(declaration, declaration.parent) ? changeTracker.insertMemberAtStart(file, container, accessor) : isPropertyAssignment(declaration) ? changeTracker.insertNodeAfterComma(file, declaration, accessor) : changeTracker.insertNodeAfter(file, declaration, accessor); + function getKeywordCompletions(keywordFilter, filterOutTsOnlyKeywords) { + if (!filterOutTsOnlyKeywords) + return getTypescriptKeywordCompletions(keywordFilter); + const index = keywordFilter + 8 /* Last */ + 1; + return _keywordCompletions[index] || (_keywordCompletions[index] = getTypescriptKeywordCompletions(keywordFilter).filter((entry) => !isTypeScriptOnlyKeyword(stringToToken(entry.name)))); } - function updateReadonlyPropertyInitializerStatementConstructor(changeTracker, file, constructor, fieldName, originalName) { - if (!constructor.body) - return; - constructor.body.forEachChild(function recur(node) { - if (isElementAccessExpression(node) && node.expression.kind === 110 /* ThisKeyword */ && isStringLiteral(node.argumentExpression) && node.argumentExpression.text === originalName && isWriteAccess(node)) { - changeTracker.replaceNode(file, node.argumentExpression, factory.createStringLiteral(fieldName)); - } - if (isPropertyAccessExpression(node) && node.expression.kind === 110 /* ThisKeyword */ && node.name.text === originalName && isWriteAccess(node)) { - changeTracker.replaceNode(file, node.name, factory.createIdentifier(fieldName)); - } - if (!isFunctionLike(node) && !isClassLike(node)) { - node.forEachChild(recur); + function getTypescriptKeywordCompletions(keywordFilter) { + return _keywordCompletions[keywordFilter] || (_keywordCompletions[keywordFilter] = allKeywordsCompletions().filter((entry) => { + const kind = stringToToken(entry.name); + switch (keywordFilter) { + case 0 /* None */: + return false; + case 1 /* All */: + return isFunctionLikeBodyKeyword(kind) || kind === 138 /* DeclareKeyword */ || kind === 144 /* ModuleKeyword */ || kind === 156 /* TypeKeyword */ || kind === 145 /* NamespaceKeyword */ || kind === 128 /* AbstractKeyword */ || isTypeKeyword(kind) && kind !== 157 /* UndefinedKeyword */; + case 5 /* FunctionLikeBodyKeywords */: + return isFunctionLikeBodyKeyword(kind); + case 2 /* ClassElementKeywords */: + return isClassMemberCompletionKeyword(kind); + case 3 /* InterfaceElementKeywords */: + return isInterfaceOrTypeLiteralCompletionKeyword(kind); + case 4 /* ConstructorParameterKeywords */: + return isParameterPropertyModifier(kind); + case 6 /* TypeAssertionKeywords */: + return isTypeKeyword(kind) || kind === 87 /* ConstKeyword */; + case 7 /* TypeKeywords */: + return isTypeKeyword(kind); + case 8 /* TypeKeyword */: + return kind === 156 /* TypeKeyword */; + default: + return Debug.assertNever(keywordFilter); } - }); + })); } - function getDeclarationType(declaration, program) { - const typeNode = getTypeAnnotationNode(declaration); - if (isPropertyDeclaration(declaration) && typeNode && declaration.questionToken) { - const typeChecker = program.getTypeChecker(); - const type = typeChecker.getTypeFromTypeNode(typeNode); - if (!typeChecker.isTypeAssignableTo(typeChecker.getUndefinedType(), type)) { - const types = isUnionTypeNode(typeNode) ? typeNode.types : [typeNode]; - return factory.createUnionTypeNode([...types, factory.createKeywordTypeNode(157 /* UndefinedKeyword */)]); - } + function isTypeScriptOnlyKeyword(kind) { + switch (kind) { + case 128 /* AbstractKeyword */: + case 133 /* AnyKeyword */: + case 163 /* BigIntKeyword */: + case 136 /* BooleanKeyword */: + case 138 /* DeclareKeyword */: + case 94 /* EnumKeyword */: + case 162 /* GlobalKeyword */: + case 119 /* ImplementsKeyword */: + case 140 /* InferKeyword */: + case 120 /* InterfaceKeyword */: + case 142 /* IsKeyword */: + case 143 /* KeyOfKeyword */: + case 144 /* ModuleKeyword */: + case 145 /* NamespaceKeyword */: + case 146 /* NeverKeyword */: + case 150 /* NumberKeyword */: + case 151 /* ObjectKeyword */: + case 164 /* OverrideKeyword */: + case 123 /* PrivateKeyword */: + case 124 /* ProtectedKeyword */: + case 125 /* PublicKeyword */: + case 148 /* ReadonlyKeyword */: + case 154 /* StringKeyword */: + case 155 /* SymbolKeyword */: + case 156 /* TypeKeyword */: + case 158 /* UniqueKeyword */: + case 159 /* UnknownKeyword */: + return true; + default: + return false; } - return typeNode; } - function getAllSupers(decl, checker) { - const res = []; - while (decl) { - const superElement = getClassExtendsHeritageElement(decl); - const superSymbol = superElement && checker.getSymbolAtLocation(superElement.expression); - if (!superSymbol) - break; - const symbol = superSymbol.flags & 2097152 /* Alias */ ? checker.getAliasedSymbol(superSymbol) : superSymbol; - const superDecl = symbol.declarations && find(symbol.declarations, isClassLike); - if (!superDecl) - break; - res.push(superDecl); - decl = superDecl; - } - return res; + function isInterfaceOrTypeLiteralCompletionKeyword(kind) { + return kind === 148 /* ReadonlyKeyword */; } - var init_generateAccessors = __esm({ - "src/services/codefixes/generateAccessors.ts"() { - "use strict"; - init_ts4(); - } - }); - - // src/services/codefixes/fixInvalidImportSyntax.ts - function getCodeFixesForImportDeclaration(context, node) { - const sourceFile = getSourceFileOfNode(node); - const namespace = getNamespaceDeclarationNode(node); - const opts = context.program.getCompilerOptions(); - const variations = []; - variations.push(createAction(context, sourceFile, node, makeImport( - namespace.name, - /*namedImports*/ - void 0, - node.moduleSpecifier, - getQuotePreference(sourceFile, context.preferences) - ))); - if (getEmitModuleKind(opts) === 1 /* CommonJS */) { - variations.push(createAction(context, sourceFile, node, factory.createImportEqualsDeclaration( - /*modifiers*/ - void 0, - /*isTypeOnly*/ - false, - namespace.name, - factory.createExternalModuleReference(node.moduleSpecifier) - ))); + function isClassMemberCompletionKeyword(kind) { + switch (kind) { + case 128 /* AbstractKeyword */: + case 129 /* AccessorKeyword */: + case 137 /* ConstructorKeyword */: + case 139 /* GetKeyword */: + case 153 /* SetKeyword */: + case 134 /* AsyncKeyword */: + case 138 /* DeclareKeyword */: + case 164 /* OverrideKeyword */: + return true; + default: + return isClassMemberModifier(kind); } - return variations; } - function createAction(context, sourceFile, node, replacement) { - const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => t.replaceNode(sourceFile, node, replacement)); - return createCodeFixActionWithoutFixAll(fixName5, changes, [Diagnostics.Replace_import_with_0, changes[0].textChanges[0].newText]); + function isFunctionLikeBodyKeyword(kind) { + return kind === 134 /* AsyncKeyword */ || kind === 135 /* AwaitKeyword */ || kind === 130 /* AsKeyword */ || kind === 152 /* SatisfiesKeyword */ || kind === 156 /* TypeKeyword */ || !isContextualKeyword(kind) && !isClassMemberCompletionKeyword(kind); } - function getActionsForUsageOfInvalidImport(context) { - const sourceFile = context.sourceFile; - const targetKind = Diagnostics.This_expression_is_not_callable.code === context.errorCode ? 212 /* CallExpression */ : 213 /* NewExpression */; - const node = findAncestor(getTokenAtPosition(sourceFile, context.span.start), (a) => a.kind === targetKind); - if (!node) { - return []; - } - const expr = node.expression; - return getImportCodeFixesForExpression(context, expr); + function keywordForNode(node) { + return isIdentifier(node) ? identifierToKeywordKind(node) ?? 0 /* Unknown */ : node.kind; } - function getActionsForInvalidImportLocation(context) { - const sourceFile = context.sourceFile; - const node = findAncestor(getTokenAtPosition(sourceFile, context.span.start), (a) => a.getStart() === context.span.start && a.getEnd() === context.span.start + context.span.length); - if (!node) { - return []; + function getContextualKeywords(contextToken, position) { + const entries = []; + if (contextToken) { + const file = contextToken.getSourceFile(); + const parent2 = contextToken.parent; + const tokenLine = file.getLineAndCharacterOfPosition(contextToken.end).line; + const currentLine = file.getLineAndCharacterOfPosition(position).line; + if ((isImportDeclaration(parent2) || isExportDeclaration(parent2) && parent2.moduleSpecifier) && contextToken === parent2.moduleSpecifier && tokenLine === currentLine) { + entries.push({ + name: tokenToString(132 /* AssertKeyword */), + kind: "keyword" /* keyword */, + kindModifiers: "" /* none */, + sortText: SortText.GlobalsOrKeywords + }); + } } - return getImportCodeFixesForExpression(context, node); + return entries; } - function getImportCodeFixesForExpression(context, expr) { - const type = context.program.getTypeChecker().getTypeAtLocation(expr); - if (!(type.symbol && isTransientSymbol(type.symbol) && type.symbol.links.originatingImport)) { - return []; - } - const fixes = []; - const relatedImport = type.symbol.links.originatingImport; - if (!isImportCall(relatedImport)) { - addRange(fixes, getCodeFixesForImportDeclaration(context, relatedImport)); - } - if (isExpression(expr) && !(isNamedDeclaration(expr.parent) && expr.parent.name === expr)) { - const sourceFile = context.sourceFile; - const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => t.replaceNode(sourceFile, expr, factory.createPropertyAccessExpression(expr, "default"), {})); - fixes.push(createCodeFixActionWithoutFixAll(fixName5, changes, Diagnostics.Use_synthetic_default_member)); - } - return fixes; + function getJsDocTagAtPosition(node, position) { + return findAncestor(node, (n) => isJSDocTag(n) && rangeContainsPosition(n, position) ? true : isJSDoc(n) ? "quit" : false); } - var fixName5; - var init_fixInvalidImportSyntax = __esm({ - "src/services/codefixes/fixInvalidImportSyntax.ts"() { - "use strict"; - init_ts4(); - init_ts_codefix(); - fixName5 = "invalidImportSyntax"; - registerCodeFix({ - errorCodes: [ - Diagnostics.This_expression_is_not_callable.code, - Diagnostics.This_expression_is_not_constructable.code - ], - getCodeActions: getActionsForUsageOfInvalidImport - }); - registerCodeFix({ - errorCodes: [ - // The following error codes cover pretty much all assignability errors that could involve an expression - Diagnostics.Argument_of_type_0_is_not_assignable_to_parameter_of_type_1.code, - Diagnostics.Type_0_does_not_satisfy_the_constraint_1.code, - Diagnostics.Type_0_is_not_assignable_to_type_1.code, - Diagnostics.Type_0_is_not_assignable_to_type_1_Two_different_types_with_this_name_exist_but_they_are_unrelated.code, - Diagnostics.Type_predicate_0_is_not_assignable_to_1.code, - Diagnostics.Property_0_of_type_1_is_not_assignable_to_2_index_type_3.code, - Diagnostics._0_index_type_1_is_not_assignable_to_2_index_type_3.code, - Diagnostics.Property_0_in_type_1_is_not_assignable_to_the_same_property_in_base_type_2.code, - Diagnostics.Property_0_in_type_1_is_not_assignable_to_type_2.code, - Diagnostics.Property_0_of_JSX_spread_attribute_is_not_assignable_to_target_property.code, - Diagnostics.The_this_context_of_type_0_is_not_assignable_to_method_s_this_of_type_1.code - ], - getCodeActions: getActionsForInvalidImportLocation - }); - } - }); - - // src/services/codefixes/fixStrictClassInitialization.ts - function getInfo16(sourceFile, pos) { - const token = getTokenAtPosition(sourceFile, pos); - if (isIdentifier(token) && isPropertyDeclaration(token.parent)) { - const type = getEffectiveTypeAnnotationNode(token.parent); - if (type) { - return { type, prop: token.parent, isJs: isInJSFile(token.parent) }; - } + function getPropertiesForObjectExpression(contextualType, completionsType, obj, checker) { + const hasCompletionsType = completionsType && completionsType !== contextualType; + const type = hasCompletionsType && !(completionsType.flags & 3 /* AnyOrUnknown */) ? checker.getUnionType([contextualType, completionsType]) : contextualType; + const properties = getApparentProperties(type, obj, checker); + return type.isClass() && containsNonPublicProperties(properties) ? [] : hasCompletionsType ? filter(properties, hasDeclarationOtherThanSelf) : properties; + function hasDeclarationOtherThanSelf(member) { + if (!length(member.declarations)) + return true; + return some(member.declarations, (decl) => decl.parent !== obj); } - return void 0; } - function getActionForAddMissingDefiniteAssignmentAssertion(context, info) { - if (info.isJs) - return void 0; - const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => addDefiniteAssignmentAssertion(t, context.sourceFile, info.prop)); - return createCodeFixAction(fixName6, changes, [Diagnostics.Add_definite_assignment_assertion_to_property_0, info.prop.getText()], fixIdAddDefiniteAssignmentAssertions, Diagnostics.Add_definite_assignment_assertions_to_all_uninitialized_properties); + function getApparentProperties(type, node, checker) { + if (!type.isUnion()) + return type.getApparentProperties(); + return checker.getAllPossiblePropertiesOfTypes(filter(type.types, (memberType) => !(memberType.flags & 402784252 /* Primitive */ || checker.isArrayLikeType(memberType) || checker.isTypeInvalidDueToUnionDiscriminant(memberType, node) || checker.typeHasCallOrConstructSignatures(memberType) || memberType.isClass() && containsNonPublicProperties(memberType.getApparentProperties())))); } - function addDefiniteAssignmentAssertion(changeTracker, propertyDeclarationSourceFile, propertyDeclaration) { - suppressLeadingAndTrailingTrivia(propertyDeclaration); - const property = factory.updatePropertyDeclaration( - propertyDeclaration, - propertyDeclaration.modifiers, - propertyDeclaration.name, - factory.createToken(54 /* ExclamationToken */), - propertyDeclaration.type, - propertyDeclaration.initializer - ); - changeTracker.replaceNode(propertyDeclarationSourceFile, propertyDeclaration, property); + function containsNonPublicProperties(props) { + return some(props, (p) => !!(getDeclarationModifierFlagsFromSymbol(p) & 6 /* NonPublicAccessibilityModifier */)); } - function getActionForAddMissingUndefinedType(context, info) { - const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => addUndefinedType(t, context.sourceFile, info)); - return createCodeFixAction(fixName6, changes, [Diagnostics.Add_undefined_type_to_property_0, info.prop.name.getText()], fixIdAddUndefinedType, Diagnostics.Add_undefined_type_to_all_uninitialized_properties); + function getPropertiesForCompletion(type, checker) { + return type.isUnion() ? Debug.checkEachDefined(checker.getAllPossiblePropertiesOfTypes(type.types), "getAllPossiblePropertiesOfTypes() should all be defined") : Debug.checkEachDefined(type.getApparentProperties(), "getApparentProperties() should all be defined"); } - function addUndefinedType(changeTracker, sourceFile, info) { - const undefinedTypeNode = factory.createKeywordTypeNode(157 /* UndefinedKeyword */); - const types = isUnionTypeNode(info.type) ? info.type.types.concat(undefinedTypeNode) : [info.type, undefinedTypeNode]; - const unionTypeNode = factory.createUnionTypeNode(types); - if (info.isJs) { - changeTracker.addJSDocTags(sourceFile, info.prop, [factory.createJSDocTypeTag( - /*tagName*/ - void 0, - factory.createJSDocTypeExpression(unionTypeNode) - )]); - } else { - changeTracker.replaceNode(sourceFile, info.type, unionTypeNode); + function tryGetObjectTypeDeclarationCompletionContainer(sourceFile, contextToken, location, position) { + switch (location.kind) { + case 358 /* SyntaxList */: + return tryCast(location.parent, isObjectTypeDeclaration); + case 1 /* EndOfFileToken */: + const cls = tryCast(lastOrUndefined(cast(location.parent, isSourceFile).statements), isObjectTypeDeclaration); + if (cls && !findChildOfKind(cls, 20 /* CloseBraceToken */, sourceFile)) { + return cls; + } + break; + case 81 /* PrivateIdentifier */: + if (tryCast(location.parent, isPropertyDeclaration)) { + return findAncestor(location, isClassLike); + } + break; + case 80 /* Identifier */: { + const originalKeywordKind = identifierToKeywordKind(location); + if (originalKeywordKind) { + return void 0; + } + if (isPropertyDeclaration(location.parent) && location.parent.initializer === location) { + return void 0; + } + if (isFromObjectTypeDeclaration(location)) { + return findAncestor(location, isObjectTypeDeclaration); + } + } } - } - function getActionForAddMissingInitializer(context, info) { - if (info.isJs) - return void 0; - const checker = context.program.getTypeChecker(); - const initializer = getInitializer(checker, info.prop); - if (!initializer) + if (!contextToken) return void 0; - const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => addInitializer(t, context.sourceFile, info.prop, initializer)); - return createCodeFixAction(fixName6, changes, [Diagnostics.Add_initializer_to_property_0, info.prop.name.getText()], fixIdAddInitializer, Diagnostics.Add_initializers_to_all_uninitialized_properties); - } - function addInitializer(changeTracker, propertyDeclarationSourceFile, propertyDeclaration, initializer) { - suppressLeadingAndTrailingTrivia(propertyDeclaration); - const property = factory.updatePropertyDeclaration( - propertyDeclaration, - propertyDeclaration.modifiers, - propertyDeclaration.name, - propertyDeclaration.questionToken, - propertyDeclaration.type, - initializer - ); - changeTracker.replaceNode(propertyDeclarationSourceFile, propertyDeclaration, property); - } - function getInitializer(checker, propertyDeclaration) { - return getDefaultValueFromType(checker, checker.getTypeFromTypeNode(propertyDeclaration.type)); - } - function getDefaultValueFromType(checker, type) { - if (type.flags & 512 /* BooleanLiteral */) { - return type === checker.getFalseType() || type === checker.getFalseType( - /*fresh*/ - true - ) ? factory.createFalse() : factory.createTrue(); - } else if (type.isStringLiteral()) { - return factory.createStringLiteral(type.value); - } else if (type.isNumberLiteral()) { - return factory.createNumericLiteral(type.value); - } else if (type.flags & 2048 /* BigIntLiteral */) { - return factory.createBigIntLiteral(type.value); - } else if (type.isUnion()) { - return firstDefined(type.types, (t) => getDefaultValueFromType(checker, t)); - } else if (type.isClass()) { - const classDeclaration = getClassLikeDeclarationOfSymbol(type.symbol); - if (!classDeclaration || hasSyntacticModifier(classDeclaration, 256 /* Abstract */)) + if (location.kind === 137 /* ConstructorKeyword */ || isIdentifier(contextToken) && isPropertyDeclaration(contextToken.parent) && isClassLike(location)) { + return findAncestor(contextToken, isClassLike); + } + switch (contextToken.kind) { + case 64 /* EqualsToken */: return void 0; - const constructorDeclaration = getFirstConstructorWithBody(classDeclaration); - if (constructorDeclaration && constructorDeclaration.parameters.length) + case 27 /* SemicolonToken */: + case 20 /* CloseBraceToken */: + return isFromObjectTypeDeclaration(location) && location.parent.name === location ? location.parent.parent : tryCast(location, isObjectTypeDeclaration); + case 19 /* OpenBraceToken */: + case 28 /* CommaToken */: + return tryCast(contextToken.parent, isObjectTypeDeclaration); + default: + if (isObjectTypeDeclaration(location)) { + if (getLineAndCharacterOfPosition(sourceFile, contextToken.getEnd()).line !== getLineAndCharacterOfPosition(sourceFile, position).line) { + return location; + } + const isValidKeyword = isClassLike(contextToken.parent.parent) ? isClassMemberCompletionKeyword : isInterfaceOrTypeLiteralCompletionKeyword; + return isValidKeyword(contextToken.kind) || contextToken.kind === 42 /* AsteriskToken */ || isIdentifier(contextToken) && isValidKeyword(identifierToKeywordKind(contextToken) ?? 0 /* Unknown */) ? contextToken.parent.parent : void 0; + } return void 0; - return factory.createNewExpression( - factory.createIdentifier(type.symbol.name), - /*typeArguments*/ - void 0, - /*argumentsArray*/ - void 0 - ); - } else if (checker.isArrayLikeType(type)) { - return factory.createArrayLiteralExpression(); } - return void 0; } - var fixName6, fixIdAddDefiniteAssignmentAssertions, fixIdAddUndefinedType, fixIdAddInitializer, errorCodes51; - var init_fixStrictClassInitialization = __esm({ - "src/services/codefixes/fixStrictClassInitialization.ts"() { - "use strict"; - init_ts4(); - init_ts_codefix(); - fixName6 = "strictClassInitialization"; - fixIdAddDefiniteAssignmentAssertions = "addMissingPropertyDefiniteAssignmentAssertions"; - fixIdAddUndefinedType = "addMissingPropertyUndefinedType"; - fixIdAddInitializer = "addMissingPropertyInitializer"; - errorCodes51 = [Diagnostics.Property_0_has_no_initializer_and_is_not_definitely_assigned_in_the_constructor.code]; - registerCodeFix({ - errorCodes: errorCodes51, - getCodeActions: function getCodeActionsForStrictClassInitializationErrors(context) { - const info = getInfo16(context.sourceFile, context.span.start); - if (!info) - return; - const result = []; - append(result, getActionForAddMissingUndefinedType(context, info)); - append(result, getActionForAddMissingDefiniteAssignmentAssertion(context, info)); - append(result, getActionForAddMissingInitializer(context, info)); - return result; - }, - fixIds: [fixIdAddDefiniteAssignmentAssertions, fixIdAddUndefinedType, fixIdAddInitializer], - getAllCodeActions: (context) => { - return codeFixAll(context, errorCodes51, (changes, diag2) => { - const info = getInfo16(diag2.file, diag2.start); - if (!info) - return; - switch (context.fixId) { - case fixIdAddDefiniteAssignmentAssertions: - addDefiniteAssignmentAssertion(changes, diag2.file, info.prop); - break; - case fixIdAddUndefinedType: - addUndefinedType(changes, diag2.file, info); - break; - case fixIdAddInitializer: - const checker = context.program.getTypeChecker(); - const initializer = getInitializer(checker, info.prop); - if (!initializer) - return; - addInitializer(changes, diag2.file, info.prop, initializer); - break; - default: - Debug.fail(JSON.stringify(context.fixId)); - } - }); + function tryGetTypeLiteralNode(node) { + if (!node) + return void 0; + const parent2 = node.parent; + switch (node.kind) { + case 19 /* OpenBraceToken */: + if (isTypeLiteralNode(parent2)) { + return parent2; } - }); + break; + case 27 /* SemicolonToken */: + case 28 /* CommaToken */: + case 80 /* Identifier */: + if (parent2.kind === 171 /* PropertySignature */ && isTypeLiteralNode(parent2.parent)) { + return parent2.parent; + } + break; } - }); - - // src/services/codefixes/requireInTs.ts - function doChange34(changes, sourceFile, info) { - const { allowSyntheticDefaults, defaultImportName, namedImports, statement, required } = info; - changes.replaceNode(sourceFile, statement, defaultImportName && !allowSyntheticDefaults ? factory.createImportEqualsDeclaration( - /*modifiers*/ - void 0, - /*isTypeOnly*/ - false, - defaultImportName, - factory.createExternalModuleReference(required) - ) : factory.createImportDeclaration( - /*modifiers*/ - void 0, - factory.createImportClause( - /*isTypeOnly*/ - false, - defaultImportName, - namedImports - ), - required, - /*assertClause*/ - void 0 - )); + return void 0; } - function getInfo17(sourceFile, program, pos) { - const { parent: parent2 } = getTokenAtPosition(sourceFile, pos); - if (!isRequireCall( - parent2, - /*requireStringLiteralLikeArgument*/ - true - )) { - Debug.failBadSyntaxKind(parent2); + function getConstraintOfTypeArgumentProperty(node, checker) { + if (!node) + return void 0; + if (isTypeNode(node) && isTypeReferenceType(node.parent)) { + return checker.getTypeArgumentConstraint(node); } - const decl = cast(parent2.parent, isVariableDeclaration); - const defaultImportName = tryCast(decl.name, isIdentifier); - const namedImports = isObjectBindingPattern(decl.name) ? tryCreateNamedImportsFromObjectBindingPattern(decl.name) : void 0; - if (defaultImportName || namedImports) { - return { - allowSyntheticDefaults: getAllowSyntheticDefaultImports(program.getCompilerOptions()), - defaultImportName, - namedImports, - statement: cast(decl.parent.parent, isVariableStatement), - required: first(parent2.arguments) - }; + const t = getConstraintOfTypeArgumentProperty(node.parent, checker); + if (!t) + return void 0; + switch (node.kind) { + case 171 /* PropertySignature */: + return checker.getTypeOfPropertyOfContextualType(t, node.symbol.escapedName); + case 193 /* IntersectionType */: + case 187 /* TypeLiteral */: + case 192 /* UnionType */: + return t; } } - function tryCreateNamedImportsFromObjectBindingPattern(node) { - const importSpecifiers = []; - for (const element of node.elements) { - if (!isIdentifier(element.name) || element.initializer) { - return void 0; - } - importSpecifiers.push(factory.createImportSpecifier( - /*isTypeOnly*/ - false, - tryCast(element.propertyName, isIdentifier), - element.name - )); - } - if (importSpecifiers.length) { - return factory.createNamedImports(importSpecifiers); - } + function isFromObjectTypeDeclaration(node) { + return node.parent && isClassOrTypeElement(node.parent) && isObjectTypeDeclaration(node.parent.parent); } - var fixId41, errorCodes52; - var init_requireInTs = __esm({ - "src/services/codefixes/requireInTs.ts"() { - "use strict"; - init_ts4(); - init_ts_codefix(); - fixId41 = "requireInTs"; - errorCodes52 = [Diagnostics.require_call_may_be_converted_to_an_import.code]; - registerCodeFix({ - errorCodes: errorCodes52, - getCodeActions(context) { - const info = getInfo17(context.sourceFile, context.program, context.span.start); - if (!info) { - return void 0; - } - const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange34(t, context.sourceFile, info)); - return [createCodeFixAction(fixId41, changes, Diagnostics.Convert_require_to_import, fixId41, Diagnostics.Convert_all_require_to_import)]; - }, - fixIds: [fixId41], - getAllCodeActions: (context) => codeFixAll(context, errorCodes52, (changes, diag2) => { - const info = getInfo17(diag2.file, context.program, diag2.start); - if (info) { - doChange34(changes, context.sourceFile, info); - } - }) - }); - } - }); - - // src/services/codefixes/useDefaultImport.ts - function getInfo18(sourceFile, pos) { - const name = getTokenAtPosition(sourceFile, pos); - if (!isIdentifier(name)) - return void 0; - const { parent: parent2 } = name; - if (isImportEqualsDeclaration(parent2) && isExternalModuleReference(parent2.moduleReference)) { - return { importNode: parent2, name, moduleSpecifier: parent2.moduleReference.expression }; - } else if (isNamespaceImport(parent2)) { - const importNode = parent2.parent.parent; - return { importNode, name, moduleSpecifier: importNode.moduleSpecifier }; + function isValidTrigger(sourceFile, triggerCharacter, contextToken, position) { + switch (triggerCharacter) { + case ".": + case "@": + return true; + case '"': + case "'": + case "`": + return !!contextToken && isStringLiteralOrTemplate(contextToken) && position === contextToken.getStart(sourceFile) + 1; + case "#": + return !!contextToken && isPrivateIdentifier(contextToken) && !!getContainingClass(contextToken); + case "<": + return !!contextToken && contextToken.kind === 30 /* LessThanToken */ && (!isBinaryExpression(contextToken.parent) || binaryExpressionMayBeOpenTag(contextToken.parent)); + case "/": + return !!contextToken && (isStringLiteralLike(contextToken) ? !!tryGetImportFromModuleSpecifier(contextToken) : contextToken.kind === 44 /* SlashToken */ && isJsxClosingElement(contextToken.parent)); + case " ": + return !!contextToken && isImportKeyword(contextToken) && contextToken.parent.kind === 312 /* SourceFile */; + default: + return Debug.assertNever(triggerCharacter); } } - function doChange35(changes, sourceFile, info, preferences) { - changes.replaceNode(sourceFile, info.importNode, makeImport( - info.name, - /*namedImports*/ - void 0, - info.moduleSpecifier, - getQuotePreference(sourceFile, preferences) - )); + function binaryExpressionMayBeOpenTag({ left }) { + return nodeIsMissing(left); } - var fixId42, errorCodes53; - var init_useDefaultImport = __esm({ - "src/services/codefixes/useDefaultImport.ts"() { - "use strict"; - init_ts4(); - init_ts_codefix(); - fixId42 = "useDefaultImport"; - errorCodes53 = [Diagnostics.Import_may_be_converted_to_a_default_import.code]; - registerCodeFix({ - errorCodes: errorCodes53, - getCodeActions(context) { - const { sourceFile, span: { start } } = context; - const info = getInfo18(sourceFile, start); - if (!info) - return void 0; - const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange35(t, sourceFile, info, context.preferences)); - return [createCodeFixAction(fixId42, changes, Diagnostics.Convert_to_default_import, fixId42, Diagnostics.Convert_all_to_default_imports)]; - }, - fixIds: [fixId42], - getAllCodeActions: (context) => codeFixAll(context, errorCodes53, (changes, diag2) => { - const info = getInfo18(diag2.file, diag2.start); - if (info) - doChange35(changes, diag2.file, info, context.preferences); - }) - }); + function isProbablyGlobalType(type, sourceFile, checker) { + const selfSymbol = checker.resolveName( + "self", + /*location*/ + void 0, + 111551 /* Value */, + /*excludeGlobals*/ + false + ); + if (selfSymbol && checker.getTypeOfSymbolAtLocation(selfSymbol, sourceFile) === type) { + return true; } - }); - - // src/services/codefixes/useBigintLiteral.ts - function makeChange9(changeTracker, sourceFile, span) { - const numericLiteral = tryCast(getTokenAtPosition(sourceFile, span.start), isNumericLiteral); - if (!numericLiteral) { - return; + const globalSymbol = checker.resolveName( + "global", + /*location*/ + void 0, + 111551 /* Value */, + /*excludeGlobals*/ + false + ); + if (globalSymbol && checker.getTypeOfSymbolAtLocation(globalSymbol, sourceFile) === type) { + return true; } - const newText = numericLiteral.getText(sourceFile) + "n"; - changeTracker.replaceNode(sourceFile, numericLiteral, factory.createBigIntLiteral(newText)); - } - var fixId43, errorCodes54; - var init_useBigintLiteral = __esm({ - "src/services/codefixes/useBigintLiteral.ts"() { - "use strict"; - init_ts4(); - init_ts_codefix(); - fixId43 = "useBigintLiteral"; - errorCodes54 = [ - Diagnostics.Numeric_literals_with_absolute_values_equal_to_2_53_or_greater_are_too_large_to_be_represented_accurately_as_integers.code - ]; - registerCodeFix({ - errorCodes: errorCodes54, - getCodeActions: function getCodeActionsToUseBigintLiteral(context) { - const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => makeChange9(t, context.sourceFile, context.span)); - if (changes.length > 0) { - return [createCodeFixAction(fixId43, changes, Diagnostics.Convert_to_a_bigint_numeric_literal, fixId43, Diagnostics.Convert_all_to_bigint_numeric_literals)]; - } - }, - fixIds: [fixId43], - getAllCodeActions: (context) => { - return codeFixAll(context, errorCodes54, (changes, diag2) => makeChange9(changes, diag2.file, diag2)); - } - }); + const globalThisSymbol = checker.resolveName( + "globalThis", + /*location*/ + void 0, + 111551 /* Value */, + /*excludeGlobals*/ + false + ); + if (globalThisSymbol && checker.getTypeOfSymbolAtLocation(globalThisSymbol, sourceFile) === type) { + return true; } - }); - - // src/services/codefixes/fixAddModuleReferTypeMissingTypeof.ts - function getImportTypeNode(sourceFile, pos) { - const token = getTokenAtPosition(sourceFile, pos); - Debug.assert(token.kind === 102 /* ImportKeyword */, "This token should be an ImportKeyword"); - Debug.assert(token.parent.kind === 204 /* ImportType */, "Token parent should be an ImportType"); - return token.parent; + return false; } - function doChange36(changes, sourceFile, importType) { - const newTypeNode = factory.updateImportTypeNode( - importType, - importType.argument, - importType.assertions, - importType.qualifier, - importType.typeArguments, - /*isTypeOf*/ - true - ); - changes.replaceNode(sourceFile, importType, newTypeNode); + function isStaticProperty(symbol) { + return !!(symbol.valueDeclaration && getEffectiveModifierFlags(symbol.valueDeclaration) & 256 /* Static */ && isClassLike(symbol.valueDeclaration.parent)); } - var fixIdAddMissingTypeof, fixId44, errorCodes55; - var init_fixAddModuleReferTypeMissingTypeof = __esm({ - "src/services/codefixes/fixAddModuleReferTypeMissingTypeof.ts"() { - "use strict"; - init_ts4(); - init_ts_codefix(); - fixIdAddMissingTypeof = "fixAddModuleReferTypeMissingTypeof"; - fixId44 = fixIdAddMissingTypeof; - errorCodes55 = [Diagnostics.Module_0_does_not_refer_to_a_type_but_is_used_as_a_type_here_Did_you_mean_typeof_import_0.code]; - registerCodeFix({ - errorCodes: errorCodes55, - getCodeActions: function getCodeActionsToAddMissingTypeof(context) { - const { sourceFile, span } = context; - const importType = getImportTypeNode(sourceFile, span.start); - const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange36(t, sourceFile, importType)); - return [createCodeFixAction(fixId44, changes, Diagnostics.Add_missing_typeof, fixId44, Diagnostics.Add_missing_typeof)]; - }, - fixIds: [fixId44], - getAllCodeActions: (context) => codeFixAll(context, errorCodes55, (changes, diag2) => doChange36(changes, context.sourceFile, getImportTypeNode(diag2.file, diag2.start))) - }); + function tryGetObjectLiteralContextualType(node, typeChecker) { + const type = typeChecker.getContextualType(node); + if (type) { + return type; } - }); - - // src/services/codefixes/wrapJsxInFragment.ts - function findNodeToFix(sourceFile, pos) { - const lessThanToken = getTokenAtPosition(sourceFile, pos); - const firstJsxElementOrOpenElement = lessThanToken.parent; - let binaryExpr = firstJsxElementOrOpenElement.parent; - if (!isBinaryExpression(binaryExpr)) { - binaryExpr = binaryExpr.parent; - if (!isBinaryExpression(binaryExpr)) - return void 0; + const parent2 = walkUpParenthesizedExpressions(node.parent); + if (isBinaryExpression(parent2) && parent2.operatorToken.kind === 64 /* EqualsToken */ && node === parent2.left) { + return typeChecker.getTypeAtLocation(parent2); } - if (!nodeIsMissing(binaryExpr.operatorToken)) - return void 0; - return binaryExpr; - } - function doChange37(changeTracker, sf, node) { - const jsx = flattenInvalidBinaryExpr(node); - if (jsx) - changeTracker.replaceNode(sf, node, factory.createJsxFragment(factory.createJsxOpeningFragment(), jsx, factory.createJsxJsxClosingFragment())); + if (isExpression(parent2)) { + return typeChecker.getContextualType(parent2); + } + return void 0; } - function flattenInvalidBinaryExpr(node) { - const children = []; - let current = node; - while (true) { - if (isBinaryExpression(current) && nodeIsMissing(current.operatorToken) && current.operatorToken.kind === 28 /* CommaToken */) { - children.push(current.left); - if (isJsxChild(current.right)) { - children.push(current.right); - return children; - } else if (isBinaryExpression(current.right)) { - current = current.right; - continue; - } else + function getImportStatementCompletionInfo(contextToken, sourceFile) { + var _a, _b, _c; + let keywordCompletion; + let isKeywordOnlyCompletion = false; + const candidate = getCandidate(); + return { + isKeywordOnlyCompletion, + keywordCompletion, + isNewIdentifierLocation: !!(candidate || keywordCompletion === 156 /* TypeKeyword */), + isTopLevelTypeOnly: !!((_b = (_a = tryCast(candidate, isImportDeclaration)) == null ? void 0 : _a.importClause) == null ? void 0 : _b.isTypeOnly) || !!((_c = tryCast(candidate, isImportEqualsDeclaration)) == null ? void 0 : _c.isTypeOnly), + couldBeTypeOnlyImportSpecifier: !!candidate && couldBeTypeOnlyImportSpecifier(candidate, contextToken), + replacementSpan: getSingleLineReplacementSpanForImportCompletionNode(candidate) + }; + function getCandidate() { + const parent2 = contextToken.parent; + if (isImportEqualsDeclaration(parent2)) { + const lastToken = parent2.getLastToken(sourceFile); + if (isIdentifier(contextToken) && lastToken !== contextToken) { + keywordCompletion = 161 /* FromKeyword */; + isKeywordOnlyCompletion = true; return void 0; - } else + } + keywordCompletion = contextToken.kind === 156 /* TypeKeyword */ ? void 0 : 156 /* TypeKeyword */; + return isModuleSpecifierMissingOrEmpty(parent2.moduleReference) ? parent2 : void 0; + } + if (couldBeTypeOnlyImportSpecifier(parent2, contextToken) && canCompleteFromNamedBindings(parent2.parent)) { + return parent2; + } + if (isNamedImports(parent2) || isNamespaceImport(parent2)) { + if (!parent2.parent.isTypeOnly && (contextToken.kind === 19 /* OpenBraceToken */ || contextToken.kind === 102 /* ImportKeyword */ || contextToken.kind === 28 /* CommaToken */)) { + keywordCompletion = 156 /* TypeKeyword */; + } + if (canCompleteFromNamedBindings(parent2)) { + if (contextToken.kind === 20 /* CloseBraceToken */ || contextToken.kind === 80 /* Identifier */) { + isKeywordOnlyCompletion = true; + keywordCompletion = 161 /* FromKeyword */; + } else { + return parent2.parent.parent; + } + } return void 0; + } + if (isImportKeyword(contextToken) && isSourceFile(parent2)) { + keywordCompletion = 156 /* TypeKeyword */; + return contextToken; + } + if (isImportKeyword(contextToken) && isImportDeclaration(parent2)) { + keywordCompletion = 156 /* TypeKeyword */; + return isModuleSpecifierMissingOrEmpty(parent2.moduleSpecifier) ? parent2 : void 0; + } + return void 0; } } - var fixID2, errorCodes56; - var init_wrapJsxInFragment = __esm({ - "src/services/codefixes/wrapJsxInFragment.ts"() { - "use strict"; - init_ts4(); - init_ts_codefix(); - fixID2 = "wrapJsxInFragment"; - errorCodes56 = [Diagnostics.JSX_expressions_must_have_one_parent_element.code]; - registerCodeFix({ - errorCodes: errorCodes56, - getCodeActions: function getCodeActionsToWrapJsxInFragment(context) { - const { sourceFile, span } = context; - const node = findNodeToFix(sourceFile, span.start); - if (!node) - return void 0; - const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange37(t, sourceFile, node)); - return [createCodeFixAction(fixID2, changes, Diagnostics.Wrap_in_JSX_fragment, fixID2, Diagnostics.Wrap_all_unparented_JSX_in_JSX_fragment)]; - }, - fixIds: [fixID2], - getAllCodeActions: (context) => codeFixAll(context, errorCodes56, (changes, diag2) => { - const node = findNodeToFix(context.sourceFile, diag2.start); - if (!node) - return void 0; - doChange37(changes, context.sourceFile, node); - }) - }); - } - }); - - // src/services/codefixes/convertToMappedObjectType.ts - function getInfo19(sourceFile, pos) { - const token = getTokenAtPosition(sourceFile, pos); - const indexSignature = tryCast(token.parent.parent, isIndexSignatureDeclaration); - if (!indexSignature) - return void 0; - const container = isInterfaceDeclaration(indexSignature.parent) ? indexSignature.parent : tryCast(indexSignature.parent.parent, isTypeAliasDeclaration); - if (!container) + function getSingleLineReplacementSpanForImportCompletionNode(node) { + var _a; + if (!node) return void 0; - return { indexSignature, container }; - } - function createTypeAliasFromInterface(declaration, type) { - return factory.createTypeAliasDeclaration(declaration.modifiers, declaration.name, declaration.typeParameters, type); + const top = findAncestor(node, or(isImportDeclaration, isImportEqualsDeclaration)) ?? node; + const sourceFile = top.getSourceFile(); + if (rangeIsOnSingleLine(top, sourceFile)) { + return createTextSpanFromNode(top, sourceFile); + } + Debug.assert(top.kind !== 102 /* ImportKeyword */ && top.kind !== 276 /* ImportSpecifier */); + const potentialSplitPoint = top.kind === 272 /* ImportDeclaration */ ? getPotentiallyInvalidImportSpecifier((_a = top.importClause) == null ? void 0 : _a.namedBindings) ?? top.moduleSpecifier : top.moduleReference; + const withoutModuleSpecifier = { + pos: top.getFirstToken().getStart(), + end: potentialSplitPoint.pos + }; + if (rangeIsOnSingleLine(withoutModuleSpecifier, sourceFile)) { + return createTextSpanFromRange(withoutModuleSpecifier); + } } - function doChange38(changes, sourceFile, { indexSignature, container }) { - const members = isInterfaceDeclaration(container) ? container.members : container.type.members; - const otherMembers = members.filter((member) => !isIndexSignatureDeclaration(member)); - const parameter = first(indexSignature.parameters); - const mappedTypeParameter = factory.createTypeParameterDeclaration( - /*modifiers*/ - void 0, - cast(parameter.name, isIdentifier), - parameter.type - ); - const mappedIntersectionType = factory.createMappedTypeNode( - hasEffectiveReadonlyModifier(indexSignature) ? factory.createModifier(148 /* ReadonlyKeyword */) : void 0, - mappedTypeParameter, - /*nameType*/ - void 0, - indexSignature.questionToken, - indexSignature.type, - /*members*/ - void 0 + function getPotentiallyInvalidImportSpecifier(namedBindings) { + var _a; + return find( + (_a = tryCast(namedBindings, isNamedImports)) == null ? void 0 : _a.elements, + (e) => { + var _a2; + return !e.propertyName && isStringANonContextualKeyword(e.name.text) && ((_a2 = findPrecedingToken(e.name.pos, namedBindings.getSourceFile(), namedBindings)) == null ? void 0 : _a2.kind) !== 28 /* CommaToken */; + } ); - const intersectionType = factory.createIntersectionTypeNode([ - ...getAllSuperTypeNodes(container), - mappedIntersectionType, - ...otherMembers.length ? [factory.createTypeLiteralNode(otherMembers)] : emptyArray - ]); - changes.replaceNode(sourceFile, container, createTypeAliasFromInterface(container, intersectionType)); } - var fixId45, errorCodes57; - var init_convertToMappedObjectType = __esm({ - "src/services/codefixes/convertToMappedObjectType.ts"() { - "use strict"; - init_ts4(); - init_ts_codefix(); - fixId45 = "fixConvertToMappedObjectType"; - errorCodes57 = [Diagnostics.An_index_signature_parameter_type_cannot_be_a_literal_type_or_generic_type_Consider_using_a_mapped_object_type_instead.code]; - registerCodeFix({ - errorCodes: errorCodes57, - getCodeActions: function getCodeActionsToConvertToMappedTypeObject(context) { - const { sourceFile, span } = context; - const info = getInfo19(sourceFile, span.start); - if (!info) - return void 0; - const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange38(t, sourceFile, info)); - const name = idText(info.container.name); - return [createCodeFixAction(fixId45, changes, [Diagnostics.Convert_0_to_mapped_object_type, name], fixId45, [Diagnostics.Convert_0_to_mapped_object_type, name])]; - }, - fixIds: [fixId45], - getAllCodeActions: (context) => codeFixAll(context, errorCodes57, (changes, diag2) => { - const info = getInfo19(diag2.file, diag2.start); - if (info) - doChange38(changes, diag2.file, info); - }) - }); + function couldBeTypeOnlyImportSpecifier(importSpecifier, contextToken) { + return isImportSpecifier(importSpecifier) && (importSpecifier.isTypeOnly || contextToken === importSpecifier.name && isTypeKeywordTokenOrIdentifier(contextToken)); + } + function canCompleteFromNamedBindings(namedBindings) { + if (!isModuleSpecifierMissingOrEmpty(namedBindings.parent.parent.moduleSpecifier) || namedBindings.parent.name) { + return false; } - }); - - // src/services/codefixes/removeAccidentalCallParentheses.ts - var fixId46, errorCodes58; - var init_removeAccidentalCallParentheses = __esm({ - "src/services/codefixes/removeAccidentalCallParentheses.ts"() { - "use strict"; - init_ts4(); - init_ts_codefix(); - fixId46 = "removeAccidentalCallParentheses"; - errorCodes58 = [ - Diagnostics.This_expression_is_not_callable_because_it_is_a_get_accessor_Did_you_mean_to_use_it_without.code - ]; - registerCodeFix({ - errorCodes: errorCodes58, - getCodeActions(context) { - const callExpression = findAncestor(getTokenAtPosition(context.sourceFile, context.span.start), isCallExpression); - if (!callExpression) { - return void 0; - } - const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => { - t.deleteRange(context.sourceFile, { pos: callExpression.expression.end, end: callExpression.end }); - }); - return [createCodeFixActionWithoutFixAll(fixId46, changes, Diagnostics.Remove_parentheses)]; - }, - fixIds: [fixId46] - }); + if (isNamedImports(namedBindings)) { + const invalidNamedImport = getPotentiallyInvalidImportSpecifier(namedBindings); + const validImports = invalidNamedImport ? namedBindings.elements.indexOf(invalidNamedImport) : namedBindings.elements.length; + return validImports < 2; } - }); - - // src/services/codefixes/removeUnnecessaryAwait.ts - function makeChange10(changeTracker, sourceFile, span) { - const awaitKeyword = tryCast(getTokenAtPosition(sourceFile, span.start), (node) => node.kind === 135 /* AwaitKeyword */); - const awaitExpression = awaitKeyword && tryCast(awaitKeyword.parent, isAwaitExpression); - if (!awaitExpression) { + return true; + } + function isModuleSpecifierMissingOrEmpty(specifier) { + var _a; + if (nodeIsMissing(specifier)) + return true; + return !((_a = tryCast(isExternalModuleReference(specifier) ? specifier.expression : specifier, isStringLiteralLike)) == null ? void 0 : _a.text); + } + function getVariableOrParameterDeclaration(contextToken, location) { + if (!contextToken) return; + const possiblyParameterDeclaration = findAncestor(contextToken, (node) => isFunctionBlock(node) || isArrowFunctionBody(node) || isBindingPattern(node) ? "quit" : (isParameter(node) || isTypeParameterDeclaration(node)) && !isIndexSignatureDeclaration(node.parent)); + const possiblyVariableDeclaration = findAncestor(location, (node) => isFunctionBlock(node) || isArrowFunctionBody(node) || isBindingPattern(node) ? "quit" : isVariableDeclaration(node)); + return possiblyParameterDeclaration || possiblyVariableDeclaration; + } + function isArrowFunctionBody(node) { + return node.parent && isArrowFunction(node.parent) && (node.parent.body === node || // const a = () => /**/; + node.kind === 39 /* EqualsGreaterThanToken */); + } + function symbolCanBeReferencedAtTypeLocation(symbol, checker, seenModules = /* @__PURE__ */ new Map()) { + return nonAliasCanBeReferencedAtTypeLocation(symbol) || nonAliasCanBeReferencedAtTypeLocation(skipAlias(symbol.exportSymbol || symbol, checker)); + function nonAliasCanBeReferencedAtTypeLocation(symbol2) { + return !!(symbol2.flags & 788968 /* Type */) || checker.isUnknownSymbol(symbol2) || !!(symbol2.flags & 1536 /* Module */) && addToSeen(seenModules, getSymbolId(symbol2)) && checker.getExportsOfModule(symbol2).some((e) => symbolCanBeReferencedAtTypeLocation(e, checker, seenModules)); } - let expressionToReplace = awaitExpression; - const hasSurroundingParens = isParenthesizedExpression(awaitExpression.parent); - if (hasSurroundingParens) { - const leftMostExpression = getLeftmostExpression( - awaitExpression.expression, - /*stopAtCallExpressions*/ - false - ); - if (isIdentifier(leftMostExpression)) { - const precedingToken = findPrecedingToken(awaitExpression.parent.pos, sourceFile); - if (precedingToken && precedingToken.kind !== 105 /* NewKeyword */) { - expressionToReplace = awaitExpression.parent; + } + function isDeprecated(symbol, checker) { + const declarations = skipAlias(symbol, checker).declarations; + return !!length(declarations) && every(declarations, isDeprecatedDeclaration); + } + function charactersFuzzyMatchInString(identifierString, lowercaseCharacters) { + if (lowercaseCharacters.length === 0) { + return true; + } + let matchedFirstCharacter = false; + let prevChar; + let characterIndex = 0; + const len = identifierString.length; + for (let strIndex = 0; strIndex < len; strIndex++) { + const strChar = identifierString.charCodeAt(strIndex); + const testChar = lowercaseCharacters.charCodeAt(characterIndex); + if (strChar === testChar || strChar === toUpperCharCode(testChar)) { + matchedFirstCharacter || (matchedFirstCharacter = prevChar === void 0 || // Beginning of word + 97 /* a */ <= prevChar && prevChar <= 122 /* z */ && 65 /* A */ <= strChar && strChar <= 90 /* Z */ || // camelCase transition + prevChar === 95 /* _ */ && strChar !== 95 /* _ */); + if (matchedFirstCharacter) { + characterIndex++; + } + if (characterIndex === lowercaseCharacters.length) { + return true; } } + prevChar = strChar; } - changeTracker.replaceNode(sourceFile, expressionToReplace, awaitExpression.expression); + return false; } - var fixId47, errorCodes59; - var init_removeUnnecessaryAwait = __esm({ - "src/services/codefixes/removeUnnecessaryAwait.ts"() { + function toUpperCharCode(charCode) { + if (97 /* a */ <= charCode && charCode <= 122 /* z */) { + return charCode - 32; + } + return charCode; + } + function isContextualKeywordInAutoImportableExpressionSpace(keyword) { + return keyword === "abstract" || keyword === "async" || keyword === "await" || keyword === "declare" || keyword === "module" || keyword === "namespace" || keyword === "type"; + } + var moduleSpecifierResolutionLimit, moduleSpecifierResolutionCacheAttemptLimit, SortText, CompletionSource, SymbolOriginInfoKind, CompletionKind, _keywordCompletions, allKeywordsCompletions; + var init_completions = __esm({ + "src/services/completions.ts"() { "use strict"; init_ts4(); - init_ts_codefix(); - fixId47 = "removeUnnecessaryAwait"; - errorCodes59 = [ - Diagnostics.await_has_no_effect_on_the_type_of_this_expression.code - ]; - registerCodeFix({ - errorCodes: errorCodes59, - getCodeActions: function getCodeActionsToRemoveUnnecessaryAwait(context) { - const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => makeChange10(t, context.sourceFile, context.span)); - if (changes.length > 0) { - return [createCodeFixAction(fixId47, changes, Diagnostics.Remove_unnecessary_await, fixId47, Diagnostics.Remove_all_unnecessary_uses_of_await)]; - } + init_ts_Completions(); + moduleSpecifierResolutionLimit = 100; + moduleSpecifierResolutionCacheAttemptLimit = 1e3; + SortText = { + // Presets + LocalDeclarationPriority: "10", + LocationPriority: "11", + OptionalMember: "12", + MemberDeclaredBySpreadAssignment: "13", + SuggestedClassMembers: "14", + GlobalsOrKeywords: "15", + AutoImportSuggestions: "16", + ClassMemberSnippets: "17", + JavascriptIdentifiers: "18", + // Transformations + Deprecated(sortText) { + return "z" + sortText; }, - fixIds: [fixId47], - getAllCodeActions: (context) => { - return codeFixAll(context, errorCodes59, (changes, diag2) => makeChange10(changes, diag2.file, diag2)); + ObjectLiteralProperty(presetSortText, symbolDisplayName) { + return `${presetSortText}\0${symbolDisplayName}\0`; + }, + SortBelow(sortText) { + return sortText + "1"; + } + }; + CompletionSource = /* @__PURE__ */ ((CompletionSource2) => { + CompletionSource2["ThisProperty"] = "ThisProperty/"; + CompletionSource2["ClassMemberSnippet"] = "ClassMemberSnippet/"; + CompletionSource2["TypeOnlyAlias"] = "TypeOnlyAlias/"; + CompletionSource2["ObjectLiteralMethodSnippet"] = "ObjectLiteralMethodSnippet/"; + CompletionSource2["SwitchCases"] = "SwitchCases/"; + CompletionSource2["ObjectLiteralMemberWithComma"] = "ObjectLiteralMemberWithComma/"; + return CompletionSource2; + })(CompletionSource || {}); + SymbolOriginInfoKind = /* @__PURE__ */ ((SymbolOriginInfoKind2) => { + SymbolOriginInfoKind2[SymbolOriginInfoKind2["ThisType"] = 1] = "ThisType"; + SymbolOriginInfoKind2[SymbolOriginInfoKind2["SymbolMember"] = 2] = "SymbolMember"; + SymbolOriginInfoKind2[SymbolOriginInfoKind2["Export"] = 4] = "Export"; + SymbolOriginInfoKind2[SymbolOriginInfoKind2["Promise"] = 8] = "Promise"; + SymbolOriginInfoKind2[SymbolOriginInfoKind2["Nullable"] = 16] = "Nullable"; + SymbolOriginInfoKind2[SymbolOriginInfoKind2["ResolvedExport"] = 32] = "ResolvedExport"; + SymbolOriginInfoKind2[SymbolOriginInfoKind2["TypeOnlyAlias"] = 64] = "TypeOnlyAlias"; + SymbolOriginInfoKind2[SymbolOriginInfoKind2["ObjectLiteralMethod"] = 128] = "ObjectLiteralMethod"; + SymbolOriginInfoKind2[SymbolOriginInfoKind2["Ignore"] = 256] = "Ignore"; + SymbolOriginInfoKind2[SymbolOriginInfoKind2["ComputedPropertyName"] = 512] = "ComputedPropertyName"; + SymbolOriginInfoKind2[SymbolOriginInfoKind2["SymbolMemberNoExport"] = 2 /* SymbolMember */] = "SymbolMemberNoExport"; + SymbolOriginInfoKind2[SymbolOriginInfoKind2["SymbolMemberExport"] = 6] = "SymbolMemberExport"; + return SymbolOriginInfoKind2; + })(SymbolOriginInfoKind || {}); + CompletionKind = /* @__PURE__ */ ((CompletionKind2) => { + CompletionKind2[CompletionKind2["ObjectPropertyDeclaration"] = 0] = "ObjectPropertyDeclaration"; + CompletionKind2[CompletionKind2["Global"] = 1] = "Global"; + CompletionKind2[CompletionKind2["PropertyAccess"] = 2] = "PropertyAccess"; + CompletionKind2[CompletionKind2["MemberLike"] = 3] = "MemberLike"; + CompletionKind2[CompletionKind2["String"] = 4] = "String"; + CompletionKind2[CompletionKind2["None"] = 5] = "None"; + return CompletionKind2; + })(CompletionKind || {}); + _keywordCompletions = []; + allKeywordsCompletions = memoize(() => { + const res = []; + for (let i = 83 /* FirstKeyword */; i <= 165 /* LastKeyword */; i++) { + res.push({ + name: tokenToString(i), + kind: "keyword" /* keyword */, + kindModifiers: "" /* none */, + sortText: SortText.GlobalsOrKeywords + }); } + return res; }); } }); - // src/services/codefixes/splitTypeOnlyImport.ts - function getImportDeclaration2(sourceFile, span) { - return findAncestor(getTokenAtPosition(sourceFile, span.start), isImportDeclaration); + // src/services/stringCompletions.ts + function createNameAndKindSet() { + const map2 = /* @__PURE__ */ new Map(); + function add(value) { + const existing = map2.get(value.name); + if (!existing || kindPrecedence[existing.kind] < kindPrecedence[value.kind]) { + map2.set(value.name, value); + } + } + return { + add, + has: map2.has.bind(map2), + values: map2.values.bind(map2) + }; } - function splitTypeOnlyImport(changes, importDeclaration, context) { - if (!importDeclaration) { - return; + function getStringLiteralCompletions(sourceFile, position, contextToken, options, host, program, log, preferences, includeSymbol) { + if (isInReferenceComment(sourceFile, position)) { + const entries = getTripleSlashReferenceCompletion(sourceFile, position, options, host); + return entries && convertPathCompletions(entries); + } + if (isInString(sourceFile, position, contextToken)) { + if (!contextToken || !isStringLiteralLike(contextToken)) + return void 0; + const entries = getStringLiteralCompletionEntries(sourceFile, contextToken, position, program.getTypeChecker(), options, host, preferences); + return convertStringLiteralCompletions(entries, contextToken, sourceFile, host, program, log, options, preferences, position, includeSymbol); } - const importClause = Debug.checkDefined(importDeclaration.importClause); - changes.replaceNode(context.sourceFile, importDeclaration, factory.updateImportDeclaration( - importDeclaration, - importDeclaration.modifiers, - factory.updateImportClause( - importClause, - importClause.isTypeOnly, - importClause.name, - /*namedBindings*/ - void 0 - ), - importDeclaration.moduleSpecifier, - importDeclaration.assertClause - )); - changes.insertNodeAfter(context.sourceFile, importDeclaration, factory.createImportDeclaration( - /*modifiers*/ - void 0, - factory.updateImportClause( - importClause, - importClause.isTypeOnly, - /*name*/ - void 0, - importClause.namedBindings - ), - importDeclaration.moduleSpecifier, - importDeclaration.assertClause - )); } - var errorCodes60, fixId48; - var init_splitTypeOnlyImport = __esm({ - "src/services/codefixes/splitTypeOnlyImport.ts"() { - "use strict"; - init_ts4(); - init_ts_codefix(); - errorCodes60 = [Diagnostics.A_type_only_import_can_specify_a_default_import_or_named_bindings_but_not_both.code]; - fixId48 = "splitTypeOnlyImport"; - registerCodeFix({ - errorCodes: errorCodes60, - fixIds: [fixId48], - getCodeActions: function getCodeActionsToSplitTypeOnlyImport(context) { - const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => { - return splitTypeOnlyImport(t, getImportDeclaration2(context.sourceFile, context.span), context); - }); - if (changes.length) { - return [createCodeFixAction(fixId48, changes, Diagnostics.Split_into_two_separate_import_declarations, fixId48, Diagnostics.Split_all_invalid_type_only_imports)]; - } - }, - getAllCodeActions: (context) => codeFixAll(context, errorCodes60, (changes, error) => { - splitTypeOnlyImport(changes, getImportDeclaration2(context.sourceFile, error), context); - }) - }); + function convertStringLiteralCompletions(completion, contextToken, sourceFile, host, program, log, options, preferences, position, includeSymbol) { + if (completion === void 0) { + return void 0; + } + const optionalReplacementSpan = createTextSpanFromStringLiteralLikeContent(contextToken); + switch (completion.kind) { + case 0 /* Paths */: + return convertPathCompletions(completion.paths); + case 1 /* Properties */: { + const entries = createSortedArray(); + getCompletionEntriesFromSymbols( + completion.symbols, + entries, + contextToken, + contextToken, + sourceFile, + position, + sourceFile, + host, + program, + 99 /* ESNext */, + log, + 4 /* String */, + preferences, + options, + /*formatContext*/ + void 0, + /*isTypeOnlyLocation*/ + void 0, + /*propertyAccessToConvert*/ + void 0, + /*jsxIdentifierExpected*/ + void 0, + /*isJsxInitializer*/ + void 0, + /*importStatementCompletion*/ + void 0, + /*recommendedCompletion*/ + void 0, + /*symbolToOriginInfoMap*/ + void 0, + /*symbolToSortTextMap*/ + void 0, + /*isJsxIdentifierExpected*/ + void 0, + /*isRightOfOpenTag*/ + void 0, + includeSymbol + ); + return { isGlobalCompletion: false, isMemberCompletion: true, isNewIdentifierLocation: completion.hasIndexSignature, optionalReplacementSpan, entries }; + } + case 2 /* Types */: { + const quoteChar = contextToken.kind === 15 /* NoSubstitutionTemplateLiteral */ ? 96 /* backtick */ : startsWith(getTextOfNode(contextToken), "'") ? 39 /* singleQuote */ : 34 /* doubleQuote */; + const entries = completion.types.map((type) => ({ + name: escapeString(type.value, quoteChar), + kindModifiers: "" /* none */, + kind: "string" /* string */, + sortText: SortText.LocationPriority, + replacementSpan: getReplacementSpanForContextToken(contextToken) + })); + return { isGlobalCompletion: false, isMemberCompletion: false, isNewIdentifierLocation: completion.isNewIdentifier, optionalReplacementSpan, entries }; + } + default: + return Debug.assertNever(completion); } - }); - - // src/services/codefixes/convertConstToLet.ts - function getInfo20(sourceFile, pos, program) { - var _a; - const checker = program.getTypeChecker(); - const symbol = checker.getSymbolAtLocation(getTokenAtPosition(sourceFile, pos)); - if (symbol === void 0) - return; - const declaration = tryCast((_a = symbol == null ? void 0 : symbol.valueDeclaration) == null ? void 0 : _a.parent, isVariableDeclarationList); - if (declaration === void 0) - return; - const constToken = findChildOfKind(declaration, 87 /* ConstKeyword */, sourceFile); - if (constToken === void 0) - return; - return { symbol, token: constToken }; } - function doChange39(changes, sourceFile, token) { - changes.replaceNode(sourceFile, token, factory.createToken(121 /* LetKeyword */)); + function getStringLiteralCompletionDetails(name, sourceFile, position, contextToken, checker, options, host, cancellationToken, preferences) { + if (!contextToken || !isStringLiteralLike(contextToken)) + return void 0; + const completions = getStringLiteralCompletionEntries(sourceFile, contextToken, position, checker, options, host, preferences); + return completions && stringLiteralCompletionDetails(name, contextToken, completions, sourceFile, checker, cancellationToken); } - var fixId49, errorCodes61; - var init_convertConstToLet = __esm({ - "src/services/codefixes/convertConstToLet.ts"() { - "use strict"; - init_ts4(); - init_ts_codefix(); - fixId49 = "fixConvertConstToLet"; - errorCodes61 = [Diagnostics.Cannot_assign_to_0_because_it_is_a_constant.code]; - registerCodeFix({ - errorCodes: errorCodes61, - getCodeActions: function getCodeActionsToConvertConstToLet(context) { - const { sourceFile, span, program } = context; - const info = getInfo20(sourceFile, span.start, program); - if (info === void 0) - return; - const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange39(t, sourceFile, info.token)); - return [createCodeFixActionMaybeFixAll(fixId49, changes, Diagnostics.Convert_const_to_let, fixId49, Diagnostics.Convert_all_const_to_let)]; - }, - getAllCodeActions: (context) => { - const { program } = context; - const seen = /* @__PURE__ */ new Map(); - return createCombinedCodeActions(ts_textChanges_exports.ChangeTracker.with(context, (changes) => { - eachDiagnostic(context, errorCodes61, (diag2) => { - const info = getInfo20(diag2.file, diag2.start, program); - if (info) { - if (addToSeen(seen, getSymbolId(info.symbol))) { - return doChange39(changes, diag2.file, info.token); - } - } - return void 0; - }); - })); - }, - fixIds: [fixId49] - }); + function stringLiteralCompletionDetails(name, location, completion, sourceFile, checker, cancellationToken) { + switch (completion.kind) { + case 0 /* Paths */: { + const match = find(completion.paths, (p) => p.name === name); + return match && createCompletionDetails(name, kindModifiersFromExtension(match.extension), match.kind, [textPart(name)]); + } + case 1 /* Properties */: { + const match = find(completion.symbols, (s) => s.name === name); + return match && createCompletionDetailsForSymbol(match, match.name, checker, sourceFile, location, cancellationToken); + } + case 2 /* Types */: + return find(completion.types, (t) => t.value === name) ? createCompletionDetails(name, "" /* none */, "string" /* string */, [textPart(name)]) : void 0; + default: + return Debug.assertNever(completion); } - }); - - // src/services/codefixes/fixExpectedComma.ts - function getInfo21(sourceFile, pos, _) { - const node = getTokenAtPosition(sourceFile, pos); - return node.kind === 27 /* SemicolonToken */ && node.parent && (isObjectLiteralExpression(node.parent) || isArrayLiteralExpression(node.parent)) ? { node } : void 0; } - function doChange40(changes, sourceFile, { node }) { - const newNode = factory.createToken(28 /* CommaToken */); - changes.replaceNode(sourceFile, node, newNode); + function convertPathCompletions(pathCompletions) { + const isGlobalCompletion = false; + const isNewIdentifierLocation = true; + const entries = pathCompletions.map(({ name, kind, span, extension }) => ({ name, kind, kindModifiers: kindModifiersFromExtension(extension), sortText: SortText.LocationPriority, replacementSpan: span })); + return { isGlobalCompletion, isMemberCompletion: false, isNewIdentifierLocation, entries }; } - var fixId50, expectedErrorCode, errorCodes62; - var init_fixExpectedComma = __esm({ - "src/services/codefixes/fixExpectedComma.ts"() { - "use strict"; - init_ts4(); - init_ts_codefix(); - fixId50 = "fixExpectedComma"; - expectedErrorCode = Diagnostics._0_expected.code; - errorCodes62 = [expectedErrorCode]; - registerCodeFix({ - errorCodes: errorCodes62, - getCodeActions(context) { - const { sourceFile } = context; - const info = getInfo21(sourceFile, context.span.start, context.errorCode); - if (!info) - return void 0; - const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange40(t, sourceFile, info)); - return [createCodeFixAction( - fixId50, - changes, - [Diagnostics.Change_0_to_1, ";", ","], - fixId50, - [Diagnostics.Change_0_to_1, ";", ","] - )]; - }, - fixIds: [fixId50], - getAllCodeActions: (context) => codeFixAll(context, errorCodes62, (changes, diag2) => { - const info = getInfo21(diag2.file, diag2.start, diag2.code); - if (info) - doChange40(changes, context.sourceFile, info); - }) - }); + function kindModifiersFromExtension(extension) { + switch (extension) { + case ".d.ts" /* Dts */: + return ".d.ts" /* dtsModifier */; + case ".js" /* Js */: + return ".js" /* jsModifier */; + case ".json" /* Json */: + return ".json" /* jsonModifier */; + case ".jsx" /* Jsx */: + return ".jsx" /* jsxModifier */; + case ".ts" /* Ts */: + return ".ts" /* tsModifier */; + case ".tsx" /* Tsx */: + return ".tsx" /* tsxModifier */; + case ".d.mts" /* Dmts */: + return ".d.mts" /* dmtsModifier */; + case ".mjs" /* Mjs */: + return ".mjs" /* mjsModifier */; + case ".mts" /* Mts */: + return ".mts" /* mtsModifier */; + case ".d.cts" /* Dcts */: + return ".d.cts" /* dctsModifier */; + case ".cjs" /* Cjs */: + return ".cjs" /* cjsModifier */; + case ".cts" /* Cts */: + return ".cts" /* ctsModifier */; + case ".tsbuildinfo" /* TsBuildInfo */: + return Debug.fail(`Extension ${".tsbuildinfo" /* TsBuildInfo */} is unsupported.`); + case void 0: + return "" /* none */; + default: + return Debug.assertNever(extension); } - }); - - // src/services/codefixes/fixAddVoidToPromise.ts - function makeChange11(changes, sourceFile, span, program, seen) { - const node = getTokenAtPosition(sourceFile, span.start); - if (!isIdentifier(node) || !isCallExpression(node.parent) || node.parent.expression !== node || node.parent.arguments.length !== 0) - return; - const checker = program.getTypeChecker(); - const symbol = checker.getSymbolAtLocation(node); - const decl = symbol == null ? void 0 : symbol.valueDeclaration; - if (!decl || !isParameter(decl) || !isNewExpression(decl.parent.parent)) - return; - if (seen == null ? void 0 : seen.has(decl)) - return; - seen == null ? void 0 : seen.add(decl); - const typeArguments = getEffectiveTypeArguments(decl.parent.parent); - if (some(typeArguments)) { - const typeArgument = typeArguments[0]; - const needsParens = !isUnionTypeNode(typeArgument) && !isParenthesizedTypeNode(typeArgument) && isParenthesizedTypeNode(factory.createUnionTypeNode([typeArgument, factory.createKeywordTypeNode(116 /* VoidKeyword */)]).types[0]); - if (needsParens) { - changes.insertText(sourceFile, typeArgument.pos, "("); + } + function getStringLiteralCompletionEntries(sourceFile, node, position, typeChecker, compilerOptions, host, preferences) { + const parent2 = walkUpParentheses(node.parent); + switch (parent2.kind) { + case 201 /* LiteralType */: { + const grandParent = walkUpParentheses(parent2.parent); + if (grandParent.kind === 205 /* ImportType */) { + return { kind: 0 /* Paths */, paths: getStringLiteralCompletionsFromModuleNames(sourceFile, node, compilerOptions, host, typeChecker, preferences) }; + } + return fromUnionableLiteralType(grandParent); } - changes.insertText(sourceFile, typeArgument.end, needsParens ? ") | void" : " | void"); - } else { - const signature = checker.getResolvedSignature(node.parent); - const parameter = signature == null ? void 0 : signature.parameters[0]; - const parameterType = parameter && checker.getTypeOfSymbolAtLocation(parameter, decl.parent.parent); - if (isInJSFile(decl)) { - if (!parameterType || parameterType.flags & 3 /* AnyOrUnknown */) { - changes.insertText(sourceFile, decl.parent.parent.end, `)`); - changes.insertText(sourceFile, skipTrivia(sourceFile.text, decl.parent.parent.pos), `/** @type {Promise} */(`); + case 303 /* PropertyAssignment */: + if (isObjectLiteralExpression(parent2.parent) && parent2.name === node) { + return stringLiteralCompletionsForObjectLiteral(typeChecker, parent2.parent); } - } else { - if (!parameterType || parameterType.flags & 2 /* Unknown */) { - changes.insertText(sourceFile, decl.parent.parent.expression.end, ""); + return fromContextualType() || fromContextualType(0 /* None */); + case 212 /* ElementAccessExpression */: { + const { expression, argumentExpression } = parent2; + if (node === skipParentheses(argumentExpression)) { + return stringLiteralCompletionsFromProperties(typeChecker.getTypeAtLocation(expression)); } + return void 0; } - } - } - function getEffectiveTypeArguments(node) { - var _a; - if (isInJSFile(node)) { - if (isParenthesizedExpression(node.parent)) { - const jsDocType = (_a = getJSDocTypeTag(node.parent)) == null ? void 0 : _a.typeExpression.type; - if (jsDocType && isTypeReferenceNode(jsDocType) && isIdentifier(jsDocType.typeName) && idText(jsDocType.typeName) === "Promise") { - return jsDocType.typeArguments; + case 213 /* CallExpression */: + case 214 /* NewExpression */: + case 291 /* JsxAttribute */: + if (!isRequireCallArgument(node) && !isImportCall(parent2)) { + const argumentInfo = ts_SignatureHelp_exports.getArgumentInfoForCompletions(parent2.kind === 291 /* JsxAttribute */ ? parent2.parent : node, position, sourceFile); + return argumentInfo && getStringLiteralCompletionsFromSignature(argumentInfo.invocation, node, argumentInfo, typeChecker) || fromContextualType(0 /* None */); } - } - } else { - return node.typeArguments; + case 272 /* ImportDeclaration */: + case 278 /* ExportDeclaration */: + case 283 /* ExternalModuleReference */: + return { kind: 0 /* Paths */, paths: getStringLiteralCompletionsFromModuleNames(sourceFile, node, compilerOptions, host, typeChecker, preferences) }; + case 296 /* CaseClause */: + const tracker = newCaseClauseTracker(typeChecker, parent2.parent.clauses); + const contextualTypes = fromContextualType(); + if (!contextualTypes) { + return; + } + const literals = contextualTypes.types.filter((literal) => !tracker.hasValue(literal.value)); + return { kind: 2 /* Types */, types: literals, isNewIdentifier: false }; + default: + return fromContextualType() || fromContextualType(0 /* None */); } - } - var fixName7, fixId51, errorCodes63; - var init_fixAddVoidToPromise = __esm({ - "src/services/codefixes/fixAddVoidToPromise.ts"() { - "use strict"; - init_ts4(); - init_ts_codefix(); - fixName7 = "addVoidToPromise"; - fixId51 = "addVoidToPromise"; - errorCodes63 = [ - Diagnostics.Expected_1_argument_but_got_0_new_Promise_needs_a_JSDoc_hint_to_produce_a_resolve_that_can_be_called_without_arguments.code, - Diagnostics.Expected_0_arguments_but_got_1_Did_you_forget_to_include_void_in_your_type_argument_to_Promise.code - ]; - registerCodeFix({ - errorCodes: errorCodes63, - fixIds: [fixId51], - getCodeActions(context) { - const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => makeChange11(t, context.sourceFile, context.span, context.program)); - if (changes.length > 0) { - return [createCodeFixAction(fixName7, changes, Diagnostics.Add_void_to_Promise_resolved_without_a_value, fixId51, Diagnostics.Add_void_to_all_Promises_resolved_without_a_value)]; + function fromUnionableLiteralType(grandParent) { + switch (grandParent.kind) { + case 233 /* ExpressionWithTypeArguments */: + case 183 /* TypeReference */: { + const typeArgument = findAncestor(parent2, (n) => n.parent === grandParent); + if (typeArgument) { + return { kind: 2 /* Types */, types: getStringLiteralTypes(typeChecker.getTypeArgumentConstraint(typeArgument)), isNewIdentifier: false }; } - }, - getAllCodeActions(context) { - return codeFixAll(context, errorCodes63, (changes, diag2) => makeChange11(changes, diag2.file, diag2, context.program, /* @__PURE__ */ new Set())); + return void 0; } - }); + case 199 /* IndexedAccessType */: + const { indexType, objectType } = grandParent; + if (!rangeContainsPosition(indexType, position)) { + return void 0; + } + return stringLiteralCompletionsFromProperties(typeChecker.getTypeFromTypeNode(objectType)); + case 192 /* UnionType */: { + const result = fromUnionableLiteralType(walkUpParentheses(grandParent.parent)); + if (!result) { + return void 0; + } + const alreadyUsedTypes = getAlreadyUsedTypesInStringLiteralUnion(grandParent, parent2); + if (result.kind === 1 /* Properties */) { + return { kind: 1 /* Properties */, symbols: result.symbols.filter((sym) => !contains(alreadyUsedTypes, sym.name)), hasIndexSignature: result.hasIndexSignature }; + } + return { kind: 2 /* Types */, types: result.types.filter((t) => !contains(alreadyUsedTypes, t.value)), isNewIdentifier: false }; + } + default: + return void 0; + } } - }); - - // src/services/_namespaces/ts.codefix.ts - var ts_codefix_exports = {}; - __export(ts_codefix_exports, { - PreserveOptionalFlags: () => PreserveOptionalFlags, - addNewNodeForMemberSymbol: () => addNewNodeForMemberSymbol, - codeFixAll: () => codeFixAll, - createCodeFixAction: () => createCodeFixAction, - createCodeFixActionMaybeFixAll: () => createCodeFixActionMaybeFixAll, - createCodeFixActionWithoutFixAll: () => createCodeFixActionWithoutFixAll, - createCombinedCodeActions: () => createCombinedCodeActions, - createFileTextChanges: () => createFileTextChanges, - createImportAdder: () => createImportAdder, - createImportSpecifierResolver: () => createImportSpecifierResolver, - createJsonPropertyAssignment: () => createJsonPropertyAssignment, - createMissingMemberNodes: () => createMissingMemberNodes, - createSignatureDeclarationFromCallExpression: () => createSignatureDeclarationFromCallExpression, - createSignatureDeclarationFromSignature: () => createSignatureDeclarationFromSignature, - createStubbedBody: () => createStubbedBody, - eachDiagnostic: () => eachDiagnostic, - findAncestorMatchingSpan: () => findAncestorMatchingSpan, - findJsonProperty: () => findJsonProperty, - generateAccessorFromProperty: () => generateAccessorFromProperty, - getAccessorConvertiblePropertyAtPosition: () => getAccessorConvertiblePropertyAtPosition, - getAllFixes: () => getAllFixes, - getAllSupers: () => getAllSupers, - getArgumentTypesAndTypeParameters: () => getArgumentTypesAndTypeParameters, - getFixes: () => getFixes, - getImportCompletionAction: () => getImportCompletionAction, - getImportKind: () => getImportKind, - getJSDocTypedefNode: () => getJSDocTypedefNode, - getNoopSymbolTrackerWithResolver: () => getNoopSymbolTrackerWithResolver, - getPromoteTypeOnlyCompletionAction: () => getPromoteTypeOnlyCompletionAction, - getSupportedErrorCodes: () => getSupportedErrorCodes, - importFixName: () => importFixName, - importSymbols: () => importSymbols, - moduleSpecifierToValidIdentifier: () => moduleSpecifierToValidIdentifier, - moduleSymbolToValidIdentifier: () => moduleSymbolToValidIdentifier, - parameterShouldGetTypeFromJSDoc: () => parameterShouldGetTypeFromJSDoc, - registerCodeFix: () => registerCodeFix, - setJsonCompilerOptionValue: () => setJsonCompilerOptionValue, - setJsonCompilerOptionValues: () => setJsonCompilerOptionValues, - tryGetAutoImportableReferenceFromTypeNode: () => tryGetAutoImportableReferenceFromTypeNode, - typeToAutoImportableTypeNode: () => typeToAutoImportableTypeNode - }); - var init_ts_codefix = __esm({ - "src/services/_namespaces/ts.codefix.ts"() { - "use strict"; - init_codeFixProvider(); - init_addConvertToUnknownForNonOverlappingTypes(); - init_addEmptyExportDeclaration(); - init_addMissingAsync(); - init_addMissingAwait(); - init_addMissingConst(); - init_addMissingDeclareProperty(); - init_addMissingInvocationForDecorator(); - init_addNameToNamelessParameter(); - init_addOptionalPropertyUndefined(); - init_annotateWithTypeFromJSDoc(); - init_convertFunctionToEs6Class(); - init_convertToAsyncFunction(); - init_convertToEsModule(); - init_correctQualifiedNameToIndexedAccessType(); - init_convertToTypeOnlyExport(); - init_convertToTypeOnlyImport(); - init_convertTypedefToType(); - init_convertLiteralTypeToMappedType(); - init_fixClassIncorrectlyImplementsInterface(); - init_importFixes(); - init_fixAddMissingConstraint(); - init_fixOverrideModifier(); - init_fixNoPropertyAccessFromIndexSignature(); - init_fixImplicitThis(); - init_fixImportNonExportedMember(); - init_fixIncorrectNamedTupleSyntax(); - init_fixSpelling(); - init_returnValueCorrect(); - init_fixAddMissingMember(); - init_fixAddMissingNewOperator(); - init_fixCannotFindModule(); - init_fixClassDoesntImplementInheritedAbstractMember(); - init_fixClassSuperMustPrecedeThisAccess(); - init_fixConstructorForDerivedNeedSuperCall(); - init_fixEnableJsxFlag(); - init_fixNaNEquality(); - init_fixModuleAndTargetOptions(); - init_fixPropertyAssignment(); - init_fixExtendsInterfaceBecomesImplements(); - init_fixForgottenThisPropertyAccess(); - init_fixInvalidJsxCharacters(); - init_fixUnmatchedParameter(); - init_fixUnreferenceableDecoratorMetadata(); - init_fixUnusedIdentifier(); - init_fixUnreachableCode(); - init_fixUnusedLabel(); - init_fixJSDocTypes(); - init_fixMissingCallParentheses(); - init_fixAwaitInSyncFunction(); - init_fixPropertyOverrideAccessor(); - init_inferFromUsage(); - init_fixReturnTypeInAsyncFunction(); - init_disableJsDiagnostics(); - init_helpers2(); - init_generateAccessors(); - init_fixInvalidImportSyntax(); - init_fixStrictClassInitialization(); - init_requireInTs(); - init_useDefaultImport(); - init_useBigintLiteral(); - init_fixAddModuleReferTypeMissingTypeof(); - init_wrapJsxInFragment(); - init_convertToMappedObjectType(); - init_removeAccidentalCallParentheses(); - init_removeUnnecessaryAwait(); - init_splitTypeOnlyImport(); - init_convertConstToLet(); - init_fixExpectedComma(); - init_fixAddVoidToPromise(); + function fromContextualType(contextFlags = 4 /* Completions */) { + const types = getStringLiteralTypes(getContextualTypeFromParent(node, typeChecker, contextFlags)); + if (!types.length) { + return; + } + return { kind: 2 /* Types */, types, isNewIdentifier: false }; } - }); - - // src/services/completions.ts - function originIsThisType(origin) { - return !!(origin.kind & 1 /* ThisType */); } - function originIsSymbolMember(origin) { - return !!(origin.kind & 2 /* SymbolMember */); + function walkUpParentheses(node) { + switch (node.kind) { + case 196 /* ParenthesizedType */: + return walkUpParenthesizedTypes(node); + case 217 /* ParenthesizedExpression */: + return walkUpParenthesizedExpressions(node); + default: + return node; + } } - function originIsExport(origin) { - return !!(origin && origin.kind & 4 /* Export */); + function getAlreadyUsedTypesInStringLiteralUnion(union, current) { + return mapDefined(union.types, (type) => type !== current && isLiteralTypeNode(type) && isStringLiteral(type.literal) ? type.literal.text : void 0); } - function originIsResolvedExport(origin) { - return !!(origin && origin.kind === 32 /* ResolvedExport */); + function getStringLiteralCompletionsFromSignature(call, arg, argumentInfo, checker) { + let isNewIdentifier = false; + const uniques = /* @__PURE__ */ new Map(); + const editingArgument = isJsxOpeningLikeElement(call) ? Debug.checkDefined(findAncestor(arg.parent, isJsxAttribute)) : arg; + const candidates = checker.getCandidateSignaturesForStringLiteralCompletions(call, editingArgument); + const types = flatMap(candidates, (candidate) => { + if (!signatureHasRestParameter(candidate) && argumentInfo.argumentCount > candidate.parameters.length) + return; + let type = candidate.getTypeParameterAtPosition(argumentInfo.argumentIndex); + if (isJsxOpeningLikeElement(call)) { + const propType = checker.getTypeOfPropertyOfType(type, getTextOfJsxAttributeName(editingArgument.name)); + if (propType) { + type = propType; + } + } + isNewIdentifier = isNewIdentifier || !!(type.flags & 4 /* String */); + return getStringLiteralTypes(type, uniques); + }); + return length(types) ? { kind: 2 /* Types */, types, isNewIdentifier } : void 0; } - function originIncludesSymbolName(origin) { - return originIsExport(origin) || originIsResolvedExport(origin) || originIsComputedPropertyName(origin); + function stringLiteralCompletionsFromProperties(type) { + return type && { + kind: 1 /* Properties */, + symbols: filter(type.getApparentProperties(), (prop) => !(prop.valueDeclaration && isPrivateIdentifierClassElementDeclaration(prop.valueDeclaration))), + hasIndexSignature: hasIndexSignature(type) + }; } - function originIsPackageJsonImport(origin) { - return (originIsExport(origin) || originIsResolvedExport(origin)) && !!origin.isFromPackageJson; + function stringLiteralCompletionsForObjectLiteral(checker, objectLiteralExpression) { + const contextualType = checker.getContextualType(objectLiteralExpression); + if (!contextualType) + return void 0; + const completionsType = checker.getContextualType(objectLiteralExpression, 4 /* Completions */); + const symbols = getPropertiesForObjectExpression( + contextualType, + completionsType, + objectLiteralExpression, + checker + ); + return { + kind: 1 /* Properties */, + symbols, + hasIndexSignature: hasIndexSignature(contextualType) + }; } - function originIsPromise(origin) { - return !!(origin.kind & 8 /* Promise */); + function getStringLiteralTypes(type, uniques = /* @__PURE__ */ new Map()) { + if (!type) + return emptyArray; + type = skipConstraint(type); + return type.isUnion() ? flatMap(type.types, (t) => getStringLiteralTypes(t, uniques)) : type.isStringLiteral() && !(type.flags & 1024 /* EnumLiteral */) && addToSeen(uniques, type.value) ? [type] : emptyArray; } - function originIsNullableMember(origin) { - return !!(origin.kind & 16 /* Nullable */); + function nameAndKind(name, kind, extension) { + return { name, kind, extension }; } - function originIsTypeOnlyAlias(origin) { - return !!(origin && origin.kind & 64 /* TypeOnlyAlias */); + function directoryResult(name) { + return nameAndKind( + name, + "directory" /* directory */, + /*extension*/ + void 0 + ); } - function originIsObjectLiteralMethod(origin) { - return !!(origin && origin.kind & 128 /* ObjectLiteralMethod */); + function addReplacementSpans(text, textStart, names) { + const span = getDirectoryFragmentTextSpan(text, textStart); + const wholeSpan = text.length === 0 ? void 0 : createTextSpan(textStart, text.length); + return names.map(({ name, kind, extension }) => name.includes(directorySeparator) || name.includes(altDirectorySeparator) ? { name, kind, extension, span: wholeSpan } : { name, kind, extension, span }); } - function originIsIgnore(origin) { - return !!(origin && origin.kind & 256 /* Ignore */); + function getStringLiteralCompletionsFromModuleNames(sourceFile, node, compilerOptions, host, typeChecker, preferences) { + return addReplacementSpans(node.text, node.getStart(sourceFile) + 1, getStringLiteralCompletionsFromModuleNamesWorker(sourceFile, node, compilerOptions, host, typeChecker, preferences)); } - function originIsComputedPropertyName(origin) { - return !!(origin && origin.kind & 512 /* ComputedPropertyName */); + function getStringLiteralCompletionsFromModuleNamesWorker(sourceFile, node, compilerOptions, host, typeChecker, preferences) { + const literalValue = normalizeSlashes(node.text); + const mode = isStringLiteralLike(node) ? getModeForUsageLocation(sourceFile, node) : void 0; + const scriptPath = sourceFile.path; + const scriptDirectory = getDirectoryPath(scriptPath); + const extensionOptions = getExtensionOptions(compilerOptions, 1 /* ModuleSpecifier */, sourceFile, typeChecker, preferences, mode); + return isPathRelativeToScript(literalValue) || !compilerOptions.baseUrl && !compilerOptions.paths && (isRootedDiskPath(literalValue) || isUrl(literalValue)) ? getCompletionEntriesForRelativeModules(literalValue, scriptDirectory, compilerOptions, host, scriptPath, extensionOptions) : getCompletionEntriesForNonRelativeModules(literalValue, scriptDirectory, mode, compilerOptions, host, extensionOptions, typeChecker); } - function resolvingModuleSpecifiers(logPrefix, host, resolver, program, position, preferences, isForImportStatementCompletion, isValidTypeOnlyUseSite, cb) { - var _a, _b, _c; - const start = timestamp(); - const needsFullResolution = isForImportStatementCompletion || moduleResolutionSupportsPackageJsonExportsAndImports(getEmitModuleResolutionKind(program.getCompilerOptions())); - let skippedAny = false; - let ambientCount = 0; - let resolvedCount = 0; - let resolvedFromCacheCount = 0; - let cacheAttemptCount = 0; - const result = cb({ - tryResolve, - skippedAny: () => skippedAny, - resolvedAny: () => resolvedCount > 0, - resolvedBeyondLimit: () => resolvedCount > moduleSpecifierResolutionLimit - }); - const hitRateMessage = cacheAttemptCount ? ` (${(resolvedFromCacheCount / cacheAttemptCount * 100).toFixed(1)}% hit rate)` : ""; - (_a = host.log) == null ? void 0 : _a.call(host, `${logPrefix}: resolved ${resolvedCount} module specifiers, plus ${ambientCount} ambient and ${resolvedFromCacheCount} from cache${hitRateMessage}`); - (_b = host.log) == null ? void 0 : _b.call(host, `${logPrefix}: response is ${skippedAny ? "incomplete" : "complete"}`); - (_c = host.log) == null ? void 0 : _c.call(host, `${logPrefix}: ${timestamp() - start}`); - return result; - function tryResolve(exportInfo, isFromAmbientModule) { - if (isFromAmbientModule) { - const result3 = resolver.getModuleSpecifierForBestExportInfo(exportInfo, position, isValidTypeOnlyUseSite); - if (result3) { - ambientCount++; - } - return result3 || "failed"; - } - const shouldResolveModuleSpecifier = needsFullResolution || preferences.allowIncompleteCompletions && resolvedCount < moduleSpecifierResolutionLimit; - const shouldGetModuleSpecifierFromCache = !shouldResolveModuleSpecifier && preferences.allowIncompleteCompletions && cacheAttemptCount < moduleSpecifierResolutionCacheAttemptLimit; - const result2 = shouldResolveModuleSpecifier || shouldGetModuleSpecifierFromCache ? resolver.getModuleSpecifierForBestExportInfo(exportInfo, position, isValidTypeOnlyUseSite, shouldGetModuleSpecifierFromCache) : void 0; - if (!shouldResolveModuleSpecifier && !shouldGetModuleSpecifierFromCache || shouldGetModuleSpecifierFromCache && !result2) { - skippedAny = true; - } - resolvedCount += (result2 == null ? void 0 : result2.computedWithoutCacheCount) || 0; - resolvedFromCacheCount += exportInfo.length - ((result2 == null ? void 0 : result2.computedWithoutCacheCount) || 0); - if (shouldGetModuleSpecifierFromCache) { - cacheAttemptCount++; - } - return result2 || (needsFullResolution ? "failed" : "skipped"); + function getExtensionOptions(compilerOptions, referenceKind, importingSourceFile, typeChecker, preferences, resolutionMode) { + return { + extensionsToSearch: flatten(getSupportedExtensionsForModuleResolution(compilerOptions, typeChecker)), + referenceKind, + importingSourceFile, + endingPreference: preferences == null ? void 0 : preferences.importModuleSpecifierEnding, + resolutionMode + }; + } + function getCompletionEntriesForRelativeModules(literalValue, scriptDirectory, compilerOptions, host, scriptPath, extensionOptions) { + if (compilerOptions.rootDirs) { + return getCompletionEntriesForDirectoryFragmentWithRootDirs( + compilerOptions.rootDirs, + literalValue, + scriptDirectory, + extensionOptions, + compilerOptions, + host, + scriptPath + ); + } else { + return arrayFrom(getCompletionEntriesForDirectoryFragment( + literalValue, + scriptDirectory, + extensionOptions, + host, + /*moduleSpecifierIsRelative*/ + true, + scriptPath + ).values()); } } - function getCompletionsAtPosition(host, program, log, sourceFile, position, preferences, triggerCharacter, completionKind, cancellationToken, formatContext, includeSymbol = false) { + function getSupportedExtensionsForModuleResolution(compilerOptions, typeChecker) { + const ambientModulesExtensions = !typeChecker ? [] : mapDefined(typeChecker.getAmbientModules(), (module2) => { + const name = module2.name.slice(1, -1); + if (!name.startsWith("*.") || name.includes("/")) + return; + return name.slice(1); + }); + const extensions = [...getSupportedExtensions(compilerOptions), ambientModulesExtensions]; + const moduleResolution = getEmitModuleResolutionKind(compilerOptions); + return moduleResolutionUsesNodeModules(moduleResolution) ? getSupportedExtensionsWithJsonIfResolveJsonModule(compilerOptions, extensions) : extensions; + } + function getBaseDirectoriesFromRootDirs(rootDirs, basePath, scriptDirectory, ignoreCase) { + rootDirs = rootDirs.map((rootDirectory) => ensureTrailingDirectorySeparator(normalizePath(isRootedDiskPath(rootDirectory) ? rootDirectory : combinePaths(basePath, rootDirectory)))); + const relativeDirectory = firstDefined(rootDirs, (rootDirectory) => containsPath(rootDirectory, scriptDirectory, basePath, ignoreCase) ? scriptDirectory.substr(rootDirectory.length) : void 0); + return deduplicate( + [...rootDirs.map((rootDirectory) => combinePaths(rootDirectory, relativeDirectory)), scriptDirectory].map((baseDir) => removeTrailingDirectorySeparator(baseDir)), + equateStringsCaseSensitive, + compareStringsCaseSensitive + ); + } + function getCompletionEntriesForDirectoryFragmentWithRootDirs(rootDirs, fragment, scriptDirectory, extensionOptions, compilerOptions, host, exclude) { + const basePath = compilerOptions.project || host.getCurrentDirectory(); + const ignoreCase = !(host.useCaseSensitiveFileNames && host.useCaseSensitiveFileNames()); + const baseDirectories = getBaseDirectoriesFromRootDirs(rootDirs, basePath, scriptDirectory, ignoreCase); + return flatMap(baseDirectories, (baseDirectory) => arrayFrom(getCompletionEntriesForDirectoryFragment( + fragment, + baseDirectory, + extensionOptions, + host, + /*moduleSpecifierIsRelative*/ + true, + exclude + ).values())); + } + function getCompletionEntriesForDirectoryFragment(fragment, scriptDirectory, extensionOptions, host, moduleSpecifierIsRelative, exclude, result = createNameAndKindSet()) { var _a; - const { previousToken } = getRelevantTokens(position, sourceFile); - if (triggerCharacter && !isInString(sourceFile, position, previousToken) && !isValidTrigger(sourceFile, triggerCharacter, previousToken, position)) { - return void 0; - } - if (triggerCharacter === " ") { - if (preferences.includeCompletionsForImportStatements && preferences.includeCompletionsWithInsertText) { - return { isGlobalCompletion: true, isMemberCompletion: false, isNewIdentifierLocation: true, isIncomplete: true, entries: [] }; - } - return void 0; + if (fragment === void 0) { + fragment = ""; } - const compilerOptions = program.getCompilerOptions(); - const checker = program.getTypeChecker(); - const incompleteCompletionsCache = preferences.allowIncompleteCompletions ? (_a = host.getIncompleteCompletionsCache) == null ? void 0 : _a.call(host) : void 0; - if (incompleteCompletionsCache && completionKind === 3 /* TriggerForIncompleteCompletions */ && previousToken && isIdentifier(previousToken)) { - const incompleteContinuation = continuePreviousIncompleteResponse(incompleteCompletionsCache, sourceFile, previousToken, program, host, preferences, cancellationToken, position); - if (incompleteContinuation) { - return incompleteContinuation; - } - } else { - incompleteCompletionsCache == null ? void 0 : incompleteCompletionsCache.clear(); + fragment = normalizeSlashes(fragment); + if (!hasTrailingDirectorySeparator(fragment)) { + fragment = getDirectoryPath(fragment); } - const stringCompletions = ts_Completions_StringCompletions_exports.getStringLiteralCompletions(sourceFile, position, previousToken, compilerOptions, host, program, log, preferences, includeSymbol); - if (stringCompletions) { - return stringCompletions; + if (fragment === "") { + fragment = "." + directorySeparator; } - if (previousToken && isBreakOrContinueStatement(previousToken.parent) && (previousToken.kind === 83 /* BreakKeyword */ || previousToken.kind === 88 /* ContinueKeyword */ || previousToken.kind === 80 /* Identifier */)) { - return getLabelCompletionAtPosition(previousToken.parent); + fragment = ensureTrailingDirectorySeparator(fragment); + const absolutePath = resolvePath(scriptDirectory, fragment); + const baseDirectory = hasTrailingDirectorySeparator(absolutePath) ? absolutePath : getDirectoryPath(absolutePath); + if (!moduleSpecifierIsRelative) { + const packageJsonPath = findPackageJson(baseDirectory, host); + if (packageJsonPath) { + const packageJson = readJson(packageJsonPath, host); + const typesVersions = packageJson.typesVersions; + if (typeof typesVersions === "object") { + const versionPaths = (_a = getPackageJsonTypesVersionsPaths(typesVersions)) == null ? void 0 : _a.paths; + if (versionPaths) { + const packageDirectory = getDirectoryPath(packageJsonPath); + const pathInPackage = absolutePath.slice(ensureTrailingDirectorySeparator(packageDirectory).length); + if (addCompletionEntriesFromPaths(result, pathInPackage, packageDirectory, extensionOptions, host, versionPaths)) { + return result; + } + } + } + } } - const completionData = getCompletionData( - program, - log, - sourceFile, - compilerOptions, - position, - preferences, - /*detailsEntryId*/ - void 0, + const ignoreCase = !(host.useCaseSensitiveFileNames && host.useCaseSensitiveFileNames()); + if (!tryDirectoryExists(host, baseDirectory)) + return result; + const files = tryReadDirectory( host, - formatContext, - cancellationToken + baseDirectory, + extensionOptions.extensionsToSearch, + /*exclude*/ + void 0, + /*include*/ + ["./*"] ); - if (!completionData) { - return void 0; + if (files) { + for (let filePath of files) { + filePath = normalizePath(filePath); + if (exclude && comparePaths(filePath, exclude, scriptDirectory, ignoreCase) === 0 /* EqualTo */) { + continue; + } + const { name, extension } = getFilenameWithExtensionOption(getBaseFileName(filePath), host.getCompilationSettings(), extensionOptions); + result.add(nameAndKind(name, "script" /* scriptElement */, extension)); + } } - switch (completionData.kind) { - case 0 /* Data */: - const response = completionInfoFromData(sourceFile, host, program, compilerOptions, log, completionData, preferences, formatContext, position, includeSymbol); - if (response == null ? void 0 : response.isIncomplete) { - incompleteCompletionsCache == null ? void 0 : incompleteCompletionsCache.set(response); + const directories = tryGetDirectories(host, baseDirectory); + if (directories) { + for (const directory of directories) { + const directoryName = getBaseFileName(normalizePath(directory)); + if (directoryName !== "@types") { + result.add(directoryResult(directoryName)); } - return response; - case 1 /* JsDocTagName */: - return jsdocCompletionInfo([ - ...ts_JsDoc_exports.getJSDocTagNameCompletions(), - ...getJSDocParameterCompletions( - sourceFile, - position, - checker, - compilerOptions, - preferences, - /*tagNameOnly*/ - true - ) - ]); - case 2 /* JsDocTag */: - return jsdocCompletionInfo([ - ...ts_JsDoc_exports.getJSDocTagCompletions(), - ...getJSDocParameterCompletions( - sourceFile, - position, - checker, - compilerOptions, - preferences, - /*tagNameOnly*/ - false - ) - ]); - case 3 /* JsDocParameterName */: - return jsdocCompletionInfo(ts_JsDoc_exports.getJSDocParameterNameCompletions(completionData.tag)); - case 4 /* Keywords */: - return specificKeywordCompletionInfo(completionData.keywordCompletions, completionData.isNewIdentifierLocation); - default: - return Debug.assertNever(completionData); + } } + return result; } - function compareCompletionEntries(entryInArray, entryToInsert) { - var _a, _b; - let result = compareStringsCaseSensitiveUI(entryInArray.sortText, entryToInsert.sortText); - if (result === 0 /* EqualTo */) { - result = compareStringsCaseSensitiveUI(entryInArray.name, entryToInsert.name); + function getFilenameWithExtensionOption(name, compilerOptions, extensionOptions) { + const nonJsResult = ts_moduleSpecifiers_exports.tryGetRealFileNameForNonJsDeclarationFileName(name); + if (nonJsResult) { + return { name: nonJsResult, extension: tryGetExtensionFromPath2(nonJsResult) }; } - if (result === 0 /* EqualTo */ && ((_a = entryInArray.data) == null ? void 0 : _a.moduleSpecifier) && ((_b = entryToInsert.data) == null ? void 0 : _b.moduleSpecifier)) { - result = compareNumberOfDirectorySeparators( - entryInArray.data.moduleSpecifier, - entryToInsert.data.moduleSpecifier - ); + if (extensionOptions.referenceKind === 0 /* Filename */) { + return { name, extension: tryGetExtensionFromPath2(name) }; } - if (result === 0 /* EqualTo */) { - return -1 /* LessThan */; + const endingPreference = getModuleSpecifierEndingPreference(extensionOptions.endingPreference, extensionOptions.resolutionMode, compilerOptions, extensionOptions.importingSourceFile); + if (endingPreference === 3 /* TsExtension */) { + if (fileExtensionIsOneOf(name, supportedTSImplementationExtensions)) { + return { name, extension: tryGetExtensionFromPath2(name) }; + } + const outputExtension2 = ts_moduleSpecifiers_exports.tryGetJSExtensionForFile(name, compilerOptions); + return outputExtension2 ? { name: changeExtension(name, outputExtension2), extension: outputExtension2 } : { name, extension: tryGetExtensionFromPath2(name) }; } - return result; + if ((endingPreference === 0 /* Minimal */ || endingPreference === 1 /* Index */) && fileExtensionIsOneOf(name, [".js" /* Js */, ".jsx" /* Jsx */, ".ts" /* Ts */, ".tsx" /* Tsx */, ".d.ts" /* Dts */])) { + return { name: removeFileExtension(name), extension: tryGetExtensionFromPath2(name) }; + } + const outputExtension = ts_moduleSpecifiers_exports.tryGetJSExtensionForFile(name, compilerOptions); + return outputExtension ? { name: changeExtension(name, outputExtension), extension: outputExtension } : { name, extension: tryGetExtensionFromPath2(name) }; } - function completionEntryDataIsResolved(data) { - return !!(data == null ? void 0 : data.moduleSpecifier); + function addCompletionEntriesFromPaths(result, fragment, baseDirectory, extensionOptions, host, paths) { + const getPatternsForKey = (key) => paths[key]; + const comparePaths2 = (a, b) => { + const patternA = tryParsePattern(a); + const patternB = tryParsePattern(b); + const lengthA = typeof patternA === "object" ? patternA.prefix.length : a.length; + const lengthB = typeof patternB === "object" ? patternB.prefix.length : b.length; + return compareValues(lengthB, lengthA); + }; + return addCompletionEntriesFromPathsOrExports(result, fragment, baseDirectory, extensionOptions, host, getOwnKeys(paths), getPatternsForKey, comparePaths2); } - function continuePreviousIncompleteResponse(cache, file, location, program, host, preferences, cancellationToken, position) { - const previousResponse = cache.get(); - if (!previousResponse) - return void 0; - const touchNode = getTouchingPropertyName(file, position); - const lowerCaseTokenText = location.text.toLowerCase(); - const exportMap = getExportInfoMap(file, host, program, preferences, cancellationToken); - const newEntries = resolvingModuleSpecifiers( - "continuePreviousIncompleteResponse", - host, - ts_codefix_exports.createImportSpecifierResolver(file, program, host, preferences), - program, - location.getStart(), - preferences, - /*isForImportStatementCompletion*/ - false, - isValidTypeOnlyAliasUseSite(location), - (context) => { - const entries = mapDefined(previousResponse.entries, (entry) => { - var _a; - if (!entry.hasAction || !entry.source || !entry.data || completionEntryDataIsResolved(entry.data)) { - return entry; - } - if (!charactersFuzzyMatchInString(entry.name, lowerCaseTokenText)) { - return void 0; - } - const { origin } = Debug.checkDefined(getAutoImportSymbolFromCompletionEntryData(entry.name, entry.data, program, host)); - const info = exportMap.get(file.path, entry.data.exportMapKey); - const result = info && context.tryResolve(info, !isExternalModuleNameRelative(stripQuotes(origin.moduleSymbol.name))); - if (result === "skipped") - return entry; - if (!result || result === "failed") { - (_a = host.log) == null ? void 0 : _a.call(host, `Unexpected failure resolving auto import for '${entry.name}' from '${entry.source}'`); - return void 0; - } - const newOrigin = { - ...origin, - kind: 32 /* ResolvedExport */, - moduleSpecifier: result.moduleSpecifier - }; - entry.data = originToCompletionEntryData(newOrigin); - entry.source = getSourceFromOrigin(newOrigin); - entry.sourceDisplay = [textPart(newOrigin.moduleSpecifier)]; - return entry; - }); - if (!context.skippedAny()) { - previousResponse.isIncomplete = void 0; + function addCompletionEntriesFromPathsOrExports(result, fragment, baseDirectory, extensionOptions, host, keys, getPatternsForKey, comparePaths2) { + let pathResults = []; + let matchedPath; + for (const key of keys) { + if (key === ".") + continue; + const keyWithoutLeadingDotSlash = key.replace(/^\.\//, ""); + const patterns = getPatternsForKey(key); + if (patterns) { + const pathPattern = tryParsePattern(keyWithoutLeadingDotSlash); + if (!pathPattern) + continue; + const isMatch = typeof pathPattern === "object" && isPatternMatch(pathPattern, fragment); + const isLongestMatch = isMatch && (matchedPath === void 0 || comparePaths2(key, matchedPath) === -1 /* LessThan */); + if (isLongestMatch) { + matchedPath = key; + pathResults = pathResults.filter((r) => !r.matchedPattern); + } + if (typeof pathPattern === "string" || matchedPath === void 0 || comparePaths2(key, matchedPath) !== 1 /* GreaterThan */) { + pathResults.push({ + matchedPattern: isMatch, + results: getCompletionsForPathMapping(keyWithoutLeadingDotSlash, patterns, fragment, baseDirectory, extensionOptions, host).map(({ name, kind, extension }) => nameAndKind(name, kind, extension)) + }); } - return entries; } - ); - previousResponse.entries = newEntries; - previousResponse.flags = (previousResponse.flags || 0) | 4 /* IsContinuation */; - previousResponse.optionalReplacementSpan = getOptionalReplacementSpan(touchNode); - return previousResponse; - } - function jsdocCompletionInfo(entries) { - return { isGlobalCompletion: false, isMemberCompletion: false, isNewIdentifierLocation: false, entries }; + } + pathResults.forEach((pathResult) => pathResult.results.forEach((r) => result.add(r))); + return matchedPath !== void 0; } - function getJSDocParameterCompletions(sourceFile, position, checker, options, preferences, tagNameOnly) { - const currentToken = getTokenAtPosition(sourceFile, position); - if (!isJSDocTag(currentToken) && !isJSDoc(currentToken)) { - return []; + function getCompletionEntriesForNonRelativeModules(fragment, scriptPath, mode, compilerOptions, host, extensionOptions, typeChecker) { + const { baseUrl, paths } = compilerOptions; + const result = createNameAndKindSet(); + const moduleResolution = getEmitModuleResolutionKind(compilerOptions); + if (baseUrl) { + const absolute = normalizePath(combinePaths(host.getCurrentDirectory(), baseUrl)); + getCompletionEntriesForDirectoryFragment( + fragment, + absolute, + extensionOptions, + host, + /*moduleSpecifierIsRelative*/ + false, + /*exclude*/ + void 0, + result + ); } - const jsDoc = isJSDoc(currentToken) ? currentToken : currentToken.parent; - if (!isJSDoc(jsDoc)) { - return []; + if (paths) { + const absolute = getPathsBasePath(compilerOptions, host); + addCompletionEntriesFromPaths(result, fragment, absolute, extensionOptions, host, paths); } - const func = jsDoc.parent; - if (!isFunctionLike(func)) { - return []; + const fragmentDirectory = getFragmentDirectory(fragment); + for (const ambientName of getAmbientModuleCompletions(fragment, fragmentDirectory, typeChecker)) { + result.add(nameAndKind( + ambientName, + "external module name" /* externalModuleName */, + /*extension*/ + void 0 + )); } - const isJs = isSourceFileJS(sourceFile); - const isSnippet = preferences.includeCompletionsWithSnippetText || void 0; - const paramTagCount = countWhere(jsDoc.tags, (tag) => isJSDocParameterTag(tag) && tag.getEnd() <= position); - return mapDefined(func.parameters, (param) => { - if (getJSDocParameterTags(param).length) { - return void 0; - } - if (isIdentifier(param.name)) { - const tabstopCounter = { tabstop: 1 }; - const paramName = param.name.text; - let displayText = getJSDocParamAnnotation( - paramName, - param.initializer, - param.dotDotDotToken, - isJs, - /*isObject*/ - false, - /*isSnippet*/ - false, - checker, - options, - preferences - ); - let snippetText = isSnippet ? getJSDocParamAnnotation( - paramName, - param.initializer, - param.dotDotDotToken, - isJs, - /*isObject*/ - false, - /*isSnippet*/ - true, - checker, - options, - preferences, - tabstopCounter - ) : void 0; - if (tagNameOnly) { - displayText = displayText.slice(1); - if (snippetText) - snippetText = snippetText.slice(1); - } - return { - name: displayText, - kind: "parameter" /* parameterElement */, - sortText: SortText.LocationPriority, - insertText: isSnippet ? snippetText : void 0, - isSnippet - }; - } else if (param.parent.parameters.indexOf(param) === paramTagCount) { - const paramPath = `param${paramTagCount}`; - const displayTextResult = generateJSDocParamTagsForDestructuring( - paramPath, - param.name, - param.initializer, - param.dotDotDotToken, - isJs, - /*isSnippet*/ - false, - checker, - options, - preferences - ); - const snippetTextResult = isSnippet ? generateJSDocParamTagsForDestructuring( - paramPath, - param.name, - param.initializer, - param.dotDotDotToken, - isJs, - /*isSnippet*/ - true, - checker, - options, - preferences - ) : void 0; - let displayText = displayTextResult.join(getNewLineCharacter(options) + "* "); - let snippetText = snippetTextResult == null ? void 0 : snippetTextResult.join(getNewLineCharacter(options) + "* "); - if (tagNameOnly) { - displayText = displayText.slice(1); - if (snippetText) - snippetText = snippetText.slice(1); + getCompletionEntriesFromTypings(host, compilerOptions, scriptPath, fragmentDirectory, extensionOptions, result); + if (moduleResolutionUsesNodeModules(moduleResolution)) { + let foundGlobal = false; + if (fragmentDirectory === void 0) { + for (const moduleName of enumerateNodeModulesVisibleToScript(host, scriptPath)) { + const moduleResult = nameAndKind( + moduleName, + "external module name" /* externalModuleName */, + /*extension*/ + void 0 + ); + if (!result.has(moduleResult.name)) { + foundGlobal = true; + result.add(moduleResult); + } } - return { - name: displayText, - kind: "parameter" /* parameterElement */, - sortText: SortText.LocationPriority, - insertText: isSnippet ? snippetText : void 0, - isSnippet - }; } - }); - } - function generateJSDocParamTagsForDestructuring(path, pattern, initializer, dotDotDotToken, isJs, isSnippet, checker, options, preferences) { - if (!isJs) { - return [ - getJSDocParamAnnotation( - path, - initializer, - dotDotDotToken, - isJs, - /*isObject*/ - false, - isSnippet, - checker, - options, - preferences, - { tabstop: 1 } - ) - ]; - } - return patternWorker(path, pattern, initializer, dotDotDotToken, { tabstop: 1 }); - function patternWorker(path2, pattern2, initializer2, dotDotDotToken2, counter) { - if (isObjectBindingPattern(pattern2) && !dotDotDotToken2) { - const oldTabstop = counter.tabstop; - const childCounter = { tabstop: oldTabstop }; - const rootParam = getJSDocParamAnnotation( - path2, - initializer2, - dotDotDotToken2, - isJs, - /*isObject*/ - true, - isSnippet, - checker, - options, - preferences, - childCounter - ); - let childTags = []; - for (const element of pattern2.elements) { - const elementTags = elementWorker(path2, element, childCounter); - if (!elementTags) { - childTags = void 0; - break; - } else { - childTags.push(...elementTags); + if (!foundGlobal) { + let ancestorLookup = (ancestor) => { + const nodeModules = combinePaths(ancestor, "node_modules"); + if (tryDirectoryExists(host, nodeModules)) { + getCompletionEntriesForDirectoryFragment( + fragment, + nodeModules, + extensionOptions, + host, + /*moduleSpecifierIsRelative*/ + false, + /*exclude*/ + void 0, + result + ); + } + }; + const checkExports = (packageFile, packageDirectory, fragmentSubpath) => { + const packageJson = readJson(packageFile, host); + const exports = packageJson.exports; + if (exports) { + if (typeof exports !== "object" || exports === null) { + return true; + } + const keys = getOwnKeys(exports); + const conditions = getConditions(compilerOptions, mode); + addCompletionEntriesFromPathsOrExports( + result, + fragmentSubpath, + packageDirectory, + extensionOptions, + host, + keys, + (key) => singleElementArray(getPatternFromFirstMatchingCondition(exports[key], conditions)), + comparePatternKeys + ); + return true; } + return false; + }; + const shouldCheckExports = fragmentDirectory && getResolvePackageJsonExports(compilerOptions); + if (shouldCheckExports) { + const nodeModulesDirectoryLookup = ancestorLookup; + ancestorLookup = (ancestor) => { + const components = getPathComponents(fragment); + components.shift(); + let packagePath = components.shift(); + if (!packagePath) { + return nodeModulesDirectoryLookup(ancestor); + } + if (startsWith(packagePath, "@")) { + const subName = components.shift(); + if (!subName) { + return nodeModulesDirectoryLookup(ancestor); + } + packagePath = combinePaths(packagePath, subName); + } + const packageDirectory = combinePaths(ancestor, "node_modules", packagePath); + const packageFile = combinePaths(packageDirectory, "package.json"); + if (tryFileExists(host, packageFile)) { + const fragmentSubpath = components.join("/") + (components.length && hasTrailingDirectorySeparator(fragment) ? "/" : ""); + if (checkExports(packageFile, packageDirectory, fragmentSubpath)) { + return; + } + } + return nodeModulesDirectoryLookup(ancestor); + }; } - if (childTags) { - counter.tabstop = childCounter.tabstop; - return [rootParam, ...childTags]; + const pnpApi = getPnpApi(scriptPath); + if (pnpApi) { + const pathRegExp = /^(?![a-zA-Z]:[\\/]|\\\\|\.{0,2}(?:\/|$))((?:@[^/]+\/)?[^/]+)\/*(.*|)$/; + const dependencyNameMatch = fragment.match(pathRegExp); + if (dependencyNameMatch) { + const [, dependencyName, subPath] = dependencyNameMatch; + let unqualified; + try { + unqualified = pnpApi.resolveToUnqualified(dependencyName, scriptPath, { considerBuiltins: false }); + } catch { + } + if (unqualified) { + const packageDirectory = normalizePath(unqualified); + let shouldGetCompletions = true; + if (shouldCheckExports) { + const packageFile = combinePaths(packageDirectory, "package.json"); + if (tryFileExists(host, packageFile) && checkExports(packageFile, packageDirectory, subPath)) { + shouldGetCompletions = false; + } + } + if (shouldGetCompletions) { + getCompletionEntriesForDirectoryFragment( + subPath, + packageDirectory, + extensionOptions, + host, + /*moduleSpecifierIsRelative*/ + false, + /*exclude*/ + void 0, + result + ); + } + } + } + } else { + forEachAncestorDirectory(scriptPath, ancestorLookup); } } - return [ - getJSDocParamAnnotation( - path2, - initializer2, - dotDotDotToken2, - isJs, - /*isObject*/ - false, - isSnippet, - checker, - options, - preferences, - counter - ) - ]; } - function elementWorker(path2, element, counter) { - if (!element.propertyName && isIdentifier(element.name) || isIdentifier(element.name)) { - const propertyName = element.propertyName ? tryGetTextOfPropertyName(element.propertyName) : element.name.text; - if (!propertyName) { - return void 0; + return arrayFrom(result.values()); + } + function getPatternFromFirstMatchingCondition(target, conditions) { + if (typeof target === "string") { + return target; + } + if (target && typeof target === "object" && !isArray(target)) { + for (const condition in target) { + if (condition === "default" || conditions.includes(condition) || isApplicableVersionedTypesKey(conditions, condition)) { + const pattern = target[condition]; + return getPatternFromFirstMatchingCondition(pattern, conditions); } - const paramName = `${path2}.${propertyName}`; - return [ - getJSDocParamAnnotation( - paramName, - element.initializer, - element.dotDotDotToken, - isJs, - /*isObject*/ - false, - isSnippet, - checker, - options, - preferences, - counter - ) - ]; - } else if (element.propertyName) { - const propertyName = tryGetTextOfPropertyName(element.propertyName); - return propertyName && patternWorker(`${path2}.${propertyName}`, element.name, element.initializer, element.dotDotDotToken, counter); } - return void 0; } } - function getJSDocParamAnnotation(paramName, initializer, dotDotDotToken, isJs, isObject, isSnippet, checker, options, preferences, tabstopCounter) { - if (isSnippet) { - Debug.assertIsDefined(tabstopCounter); + function getFragmentDirectory(fragment) { + return containsSlash(fragment) ? hasTrailingDirectorySeparator(fragment) ? fragment : getDirectoryPath(fragment) : void 0; + } + function getCompletionsForPathMapping(path, patterns, fragment, packageDirectory, extensionOptions, host) { + if (!endsWith(path, "*")) { + return !path.includes("*") ? justPathMappingName(path, "script" /* scriptElement */) : emptyArray; } - if (initializer) { - paramName = getJSDocParamNameWithInitializer(paramName, initializer); + const pathPrefix = path.slice(0, path.length - 1); + const remainingFragment = tryRemovePrefix(fragment, pathPrefix); + if (remainingFragment === void 0) { + const starIsFullPathComponent = path[path.length - 2] === "/"; + return starIsFullPathComponent ? justPathMappingName(pathPrefix, "directory" /* directory */) : flatMap(patterns, (pattern) => { + var _a; + return (_a = getModulesForPathsPattern("", packageDirectory, pattern, extensionOptions, host)) == null ? void 0 : _a.map(({ name, ...rest }) => ({ name: pathPrefix + name, ...rest })); + }); } - if (isSnippet) { - paramName = escapeSnippetText(paramName); + return flatMap(patterns, (pattern) => getModulesForPathsPattern(remainingFragment, packageDirectory, pattern, extensionOptions, host)); + function justPathMappingName(name, kind) { + return startsWith(name, fragment) ? [{ name: removeTrailingDirectorySeparator(name), kind, extension: void 0 }] : emptyArray; } - if (isJs) { - let type = "*"; - if (isObject) { - Debug.assert(!dotDotDotToken, `Cannot annotate a rest parameter with type 'Object'.`); - type = "Object"; - } else { - if (initializer) { - const inferredType = checker.getTypeAtLocation(initializer.parent); - if (!(inferredType.flags & (1 /* Any */ | 16384 /* Void */))) { - const sourceFile = initializer.getSourceFile(); - const quotePreference = getQuotePreference(sourceFile, preferences); - const builderFlags = quotePreference === 0 /* Single */ ? 268435456 /* UseSingleQuotesForStringLiteralType */ : 0 /* None */; - const typeNode = checker.typeToTypeNode(inferredType, findAncestor(initializer, isFunctionLike), builderFlags); - if (typeNode) { - const printer = isSnippet ? createSnippetPrinter({ - removeComments: true, - module: options.module, - target: options.target - }) : createPrinter({ - removeComments: true, - module: options.module, - target: options.target - }); - setEmitFlags(typeNode, 1 /* SingleLine */); - type = printer.printNode(4 /* Unspecified */, typeNode, sourceFile); - } - } - } - if (isSnippet && type === "*") { - type = `\${${tabstopCounter.tabstop++}:${type}}`; + } + function getModulesForPathsPattern(fragment, packageDirectory, pattern, extensionOptions, host) { + if (!host.readDirectory) { + return void 0; + } + const parsed = tryParsePattern(pattern); + if (parsed === void 0 || isString(parsed)) { + return void 0; + } + const normalizedPrefix = resolvePath(parsed.prefix); + const normalizedPrefixDirectory = hasTrailingDirectorySeparator(parsed.prefix) ? normalizedPrefix : getDirectoryPath(normalizedPrefix); + const normalizedPrefixBase = hasTrailingDirectorySeparator(parsed.prefix) ? "" : getBaseFileName(normalizedPrefix); + const fragmentHasPath = containsSlash(fragment); + const fragmentDirectory = fragmentHasPath ? hasTrailingDirectorySeparator(fragment) ? fragment : getDirectoryPath(fragment) : void 0; + const expandedPrefixDirectory = fragmentHasPath ? combinePaths(normalizedPrefixDirectory, normalizedPrefixBase + fragmentDirectory) : normalizedPrefixDirectory; + const normalizedSuffix = normalizePath(parsed.suffix); + const declarationExtension = normalizedSuffix && getDeclarationEmitExtensionForPath("_" + normalizedSuffix); + const matchingSuffixes = declarationExtension ? [changeExtension(normalizedSuffix, declarationExtension), normalizedSuffix] : [normalizedSuffix]; + const baseDirectory = normalizePath(combinePaths(packageDirectory, expandedPrefixDirectory)); + const completePrefix = fragmentHasPath ? baseDirectory : ensureTrailingDirectorySeparator(baseDirectory) + normalizedPrefixBase; + const includeGlobs = normalizedSuffix ? matchingSuffixes.map((suffix) => "**/*" + suffix) : ["./*"]; + const matches = mapDefined(tryReadDirectory( + host, + baseDirectory, + extensionOptions.extensionsToSearch, + /*exclude*/ + void 0, + includeGlobs + ), (match) => { + const trimmedWithPattern = trimPrefixAndSuffix(match); + if (trimmedWithPattern) { + if (containsSlash(trimmedWithPattern)) { + return directoryResult(getPathComponents(removeLeadingDirectorySeparator(trimmedWithPattern))[1]); } + const { name, extension } = getFilenameWithExtensionOption(trimmedWithPattern, host.getCompilationSettings(), extensionOptions); + return nameAndKind(name, "script" /* scriptElement */, extension); } - const dotDotDot = !isObject && dotDotDotToken ? "..." : ""; - const description3 = isSnippet ? `\${${tabstopCounter.tabstop++}}` : ""; - return `@param {${dotDotDot}${type}} ${paramName} ${description3}`; - } else { - const description3 = isSnippet ? `\${${tabstopCounter.tabstop++}}` : ""; - return `@param ${paramName} ${description3}`; - } - } - function getJSDocParamNameWithInitializer(paramName, initializer) { - const initializerText = initializer.getText().trim(); - if (initializerText.includes("\n") || initializerText.length > 80) { - return `[${paramName}]`; + }); + const directories = normalizedSuffix ? emptyArray : mapDefined(tryGetDirectories(host, baseDirectory), (dir) => dir === "node_modules" ? void 0 : directoryResult(dir)); + return [...matches, ...directories]; + function trimPrefixAndSuffix(path) { + return firstDefined(matchingSuffixes, (suffix) => { + const inner = withoutStartAndEnd(normalizePath(path), completePrefix, suffix); + return inner === void 0 ? void 0 : removeLeadingDirectorySeparator(inner); + }); } - return `[${paramName}=${initializerText}]`; - } - function keywordToCompletionEntry(keyword) { - return { - name: tokenToString(keyword), - kind: "keyword" /* keyword */, - kindModifiers: "" /* none */, - sortText: SortText.GlobalsOrKeywords - }; } - function specificKeywordCompletionInfo(entries, isNewIdentifierLocation) { - return { - isGlobalCompletion: false, - isMemberCompletion: false, - isNewIdentifierLocation, - entries: entries.slice() - }; + function withoutStartAndEnd(s, start, end) { + return startsWith(s, start) && endsWith(s, end) ? s.slice(start.length, s.length - end.length) : void 0; } - function keywordCompletionData(keywordFilters, filterOutTsOnlyKeywords, isNewIdentifierLocation) { - return { - kind: 4 /* Keywords */, - keywordCompletions: getKeywordCompletions(keywordFilters, filterOutTsOnlyKeywords), - isNewIdentifierLocation - }; + function removeLeadingDirectorySeparator(path) { + return path[0] === directorySeparator ? path.slice(1) : path; } - function keywordFiltersFromSyntaxKind(keywordCompletion) { - switch (keywordCompletion) { - case 156 /* TypeKeyword */: - return 8 /* TypeKeyword */; - default: - Debug.fail("Unknown mapping from SyntaxKind to KeywordCompletionFilters"); + function getAmbientModuleCompletions(fragment, fragmentDirectory, checker) { + const ambientModules = checker.getAmbientModules().map((sym) => stripQuotes(sym.name)); + const nonRelativeModuleNames = ambientModules.filter((moduleName) => startsWith(moduleName, fragment) && !moduleName.includes("*")); + if (fragmentDirectory !== void 0) { + const moduleNameWithSeparator = ensureTrailingDirectorySeparator(fragmentDirectory); + return nonRelativeModuleNames.map((nonRelativeModuleName) => removePrefix(nonRelativeModuleName, moduleNameWithSeparator)); } + return nonRelativeModuleNames; } - function getOptionalReplacementSpan(location) { - return (location == null ? void 0 : location.kind) === 80 /* Identifier */ ? createTextSpanFromNode(location) : void 0; + function getTripleSlashReferenceCompletion(sourceFile, position, compilerOptions, host) { + const token = getTokenAtPosition(sourceFile, position); + const commentRanges = getLeadingCommentRanges(sourceFile.text, token.pos); + const range = commentRanges && find(commentRanges, (commentRange) => position >= commentRange.pos && position <= commentRange.end); + if (!range) { + return void 0; + } + const text = sourceFile.text.slice(range.pos, position); + const match = tripleSlashDirectiveFragmentRegex.exec(text); + if (!match) { + return void 0; + } + const [, prefix, kind, toComplete] = match; + const scriptPath = getDirectoryPath(sourceFile.path); + const names = kind === "path" ? getCompletionEntriesForDirectoryFragment( + toComplete, + scriptPath, + getExtensionOptions(compilerOptions, 0 /* Filename */, sourceFile), + host, + /*moduleSpecifierIsRelative*/ + true, + sourceFile.path + ) : kind === "types" ? getCompletionEntriesFromTypings(host, compilerOptions, scriptPath, getFragmentDirectory(toComplete), getExtensionOptions(compilerOptions, 1 /* ModuleSpecifier */, sourceFile)) : Debug.fail(); + return addReplacementSpans(toComplete, range.pos + prefix.length, arrayFrom(names.values())); } - function completionInfoFromData(sourceFile, host, program, compilerOptions, log, completionData, preferences, formatContext, position, includeSymbol) { - const { - symbols, - contextToken, - completionKind, - isInSnippetScope, - isNewIdentifierLocation, - location, - propertyAccessToConvert, - keywordFilters, - symbolToOriginInfoMap, - recommendedCompletion, - isJsxInitializer, - isTypeOnlyLocation, - isJsxIdentifierExpected, - isRightOfOpenTag, - isRightOfDotOrQuestionDot, - importStatementCompletion, - insideJsDocTagTypeExpression, - symbolToSortTextMap, - hasUnresolvedAutoImports - } = completionData; - let literals = completionData.literals; - const checker = program.getTypeChecker(); - if (getLanguageVariant(sourceFile.scriptKind) === 1 /* JSX */) { - const completionInfo = getJsxClosingTagCompletion(location, sourceFile); - if (completionInfo) { - return completionInfo; + function getCompletionEntriesFromTypings(host, options, scriptPath, fragmentDirectory, extensionOptions, result = createNameAndKindSet()) { + const seen = /* @__PURE__ */ new Map(); + const typeRoots = tryAndIgnoreErrors(() => getEffectiveTypeRoots(options, host)) || emptyArray; + for (const root of typeRoots) { + getCompletionEntriesFromDirectories(root); + } + if (getPnpApi(scriptPath)) { + for (const root of getPnpTypeRoots(scriptPath)) { + getCompletionEntriesFromDirectories(root); + } + } else { + for (const packageJson of findPackageJsons(scriptPath, host)) { + const typesDir = combinePaths(getDirectoryPath(packageJson), "node_modules/@types"); + getCompletionEntriesFromDirectories(typesDir); } } - const caseClause = findAncestor(contextToken, isCaseClause); - if (caseClause && (isCaseKeyword(contextToken) || isNodeDescendantOf(contextToken, caseClause.expression))) { - const tracker = newCaseClauseTracker(checker, caseClause.parent.clauses); - literals = literals.filter((literal) => !tracker.hasValue(literal)); - symbols.forEach((symbol, i) => { - if (symbol.valueDeclaration && isEnumMember(symbol.valueDeclaration)) { - const value = checker.getConstantValue(symbol.valueDeclaration); - if (value !== void 0 && tracker.hasValue(value)) { - symbolToOriginInfoMap[i] = { kind: 256 /* Ignore */ }; + return result; + function getCompletionEntriesFromDirectories(directory) { + if (!tryDirectoryExists(host, directory)) + return; + for (const typeDirectoryName of tryGetDirectories(host, directory)) { + const packageName = unmangleScopedPackageName(typeDirectoryName); + if (options.types && !contains(options.types, packageName)) + continue; + if (fragmentDirectory === void 0) { + if (!seen.has(packageName)) { + result.add(nameAndKind( + packageName, + "external module name" /* externalModuleName */, + /*extension*/ + void 0 + )); + seen.set(packageName, true); + } + } else { + const baseDirectory = combinePaths(directory, typeDirectoryName); + const remainingFragment = tryRemoveDirectoryPrefix(fragmentDirectory, packageName, hostGetCanonicalFileName(host)); + if (remainingFragment !== void 0) { + getCompletionEntriesForDirectoryFragment( + remainingFragment, + baseDirectory, + extensionOptions, + host, + /*moduleSpecifierIsRelative*/ + false, + /*exclude*/ + void 0, + result + ); } } - }); - } - const entries = createSortedArray(); - const isChecked = isCheckedFile(sourceFile, compilerOptions); - if (isChecked && !isNewIdentifierLocation && (!symbols || symbols.length === 0) && keywordFilters === 0 /* None */) { - return void 0; + } } - const uniqueNames = getCompletionEntriesFromSymbols( - symbols, - entries, - /*replacementToken*/ - void 0, - contextToken, - location, - position, - sourceFile, - host, - program, - getEmitScriptTarget(compilerOptions), - log, - completionKind, - preferences, - compilerOptions, - formatContext, - isTypeOnlyLocation, - propertyAccessToConvert, - isJsxIdentifierExpected, - isJsxInitializer, - importStatementCompletion, - recommendedCompletion, - symbolToOriginInfoMap, - symbolToSortTextMap, - isJsxIdentifierExpected, - isRightOfOpenTag, - includeSymbol - ); - if (keywordFilters !== 0 /* None */) { - for (const keywordEntry of getKeywordCompletions(keywordFilters, !insideJsDocTagTypeExpression && isSourceFileJS(sourceFile))) { - if (isTypeOnlyLocation && isTypeKeyword(stringToToken(keywordEntry.name)) || !uniqueNames.has(keywordEntry.name)) { - uniqueNames.add(keywordEntry.name); - insertSorted( - entries, - keywordEntry, - compareCompletionEntries, - /*allowDuplicates*/ - true - ); + } + function enumerateNodeModulesVisibleToScript(host, scriptPath) { + if (!host.readFile || !host.fileExists) + return emptyArray; + const result = []; + for (const packageJson of findPackageJsons(scriptPath, host)) { + const contents = readJson(packageJson, host); + for (const key of nodeModulesDependencyKeys) { + const dependencies = contents[key]; + if (!dependencies) + continue; + for (const dep in dependencies) { + if (hasProperty(dependencies, dep) && !startsWith(dep, "@types/")) { + result.push(dep); + } } } } - for (const keywordEntry of getContextualKeywords(contextToken, position)) { - if (!uniqueNames.has(keywordEntry.name)) { - uniqueNames.add(keywordEntry.name); - insertSorted( - entries, - keywordEntry, - compareCompletionEntries, - /*allowDuplicates*/ - true - ); - } + return result; + } + function getDirectoryFragmentTextSpan(text, textStart) { + const index = Math.max(text.lastIndexOf(directorySeparator), text.lastIndexOf(altDirectorySeparator)); + const offset = index !== -1 ? index + 1 : 0; + const length2 = text.length - offset; + return length2 === 0 || isIdentifierText(text.substr(offset, length2), 99 /* ESNext */) ? void 0 : createTextSpan(textStart + offset, length2); + } + function isPathRelativeToScript(path) { + if (path && path.length >= 2 && path.charCodeAt(0) === 46 /* dot */) { + const slashIndex = path.length >= 3 && path.charCodeAt(1) === 46 /* dot */ ? 2 : 1; + const slashCharCode = path.charCodeAt(slashIndex); + return slashCharCode === 47 /* slash */ || slashCharCode === 92 /* backslash */; } - for (const literal of literals) { - const literalEntry = createCompletionEntryForLiteral(sourceFile, preferences, literal); - uniqueNames.add(literalEntry.name); - insertSorted( - entries, - literalEntry, - compareCompletionEntries, - /*allowDuplicates*/ - true - ); + return false; + } + function containsSlash(fragment) { + return fragment.includes(directorySeparator); + } + function isRequireCallArgument(node) { + return isCallExpression(node.parent) && firstOrUndefined(node.parent.arguments) === node && isIdentifier(node.parent.expression) && node.parent.expression.escapedText === "require"; + } + var kindPrecedence, tripleSlashDirectiveFragmentRegex, nodeModulesDependencyKeys; + var init_stringCompletions = __esm({ + "src/services/stringCompletions.ts"() { + "use strict"; + init_pnp(); + init_ts4(); + init_ts_Completions(); + kindPrecedence = { + ["directory" /* directory */]: 0, + ["script" /* scriptElement */]: 1, + ["external module name" /* externalModuleName */]: 2 + }; + tripleSlashDirectiveFragmentRegex = /^(\/\/\/\s* getStringLiteralCompletionDetails, + getStringLiteralCompletions: () => getStringLiteralCompletions + }); + var init_ts_Completions_StringCompletions = __esm({ + "src/services/_namespaces/ts.Completions.StringCompletions.ts"() { + "use strict"; + init_stringCompletions(); } - let caseBlock; - if (preferences.includeCompletionsWithInsertText && contextToken && !isRightOfOpenTag && !isRightOfDotOrQuestionDot && (caseBlock = findAncestor(contextToken, isCaseBlock))) { - const cases = getExhaustiveCaseSnippets(caseBlock, sourceFile, preferences, compilerOptions, host, program, formatContext); - if (cases) { - entries.push(cases.entry); - } + }); + + // src/services/_namespaces/ts.Completions.ts + var ts_Completions_exports = {}; + __export(ts_Completions_exports, { + CompletionKind: () => CompletionKind, + CompletionSource: () => CompletionSource, + SortText: () => SortText, + StringCompletions: () => ts_Completions_StringCompletions_exports, + SymbolOriginInfoKind: () => SymbolOriginInfoKind, + createCompletionDetails: () => createCompletionDetails, + createCompletionDetailsForSymbol: () => createCompletionDetailsForSymbol, + getCompletionEntriesFromSymbols: () => getCompletionEntriesFromSymbols, + getCompletionEntryDetails: () => getCompletionEntryDetails, + getCompletionEntrySymbol: () => getCompletionEntrySymbol, + getCompletionsAtPosition: () => getCompletionsAtPosition, + getPropertiesForObjectExpression: () => getPropertiesForObjectExpression, + moduleSpecifierResolutionCacheAttemptLimit: () => moduleSpecifierResolutionCacheAttemptLimit, + moduleSpecifierResolutionLimit: () => moduleSpecifierResolutionLimit + }); + var init_ts_Completions = __esm({ + "src/services/_namespaces/ts.Completions.ts"() { + "use strict"; + init_completions(); + init_ts_Completions_StringCompletions(); } - return { - flags: completionData.flags, - isGlobalCompletion: isInSnippetScope, - isIncomplete: preferences.allowIncompleteCompletions && hasUnresolvedAutoImports ? true : void 0, - isMemberCompletion: isMemberCompletionKind(completionKind), - isNewIdentifierLocation, - optionalReplacementSpan: getOptionalReplacementSpan(location), - entries + }); + + // src/services/importTracker.ts + function createImportTracker(sourceFiles, sourceFilesSet, checker, cancellationToken) { + const allDirectImports = getDirectImportsMap(sourceFiles, checker, cancellationToken); + return (exportSymbol, exportInfo, isForRename) => { + const { directImports, indirectUsers } = getImportersForExport(sourceFiles, sourceFilesSet, allDirectImports, exportInfo, checker, cancellationToken); + return { indirectUsers, ...getSearchesFromDirectImports(directImports, exportSymbol, exportInfo.exportKind, checker, isForRename) }; }; } - function isCheckedFile(sourceFile, compilerOptions) { - return !isSourceFileJS(sourceFile) || !!isCheckJsEnabledForFile(sourceFile, compilerOptions); - } - function getExhaustiveCaseSnippets(caseBlock, sourceFile, preferences, options, host, program, formatContext) { - const clauses = caseBlock.clauses; - const checker = program.getTypeChecker(); - const switchType = checker.getTypeAtLocation(caseBlock.parent.expression); - if (switchType && switchType.isUnion() && every(switchType.types, (type) => type.isLiteral())) { - const tracker = newCaseClauseTracker(checker, clauses); - const target = getEmitScriptTarget(options); - const quotePreference = getQuotePreference(sourceFile, preferences); - const importAdder = ts_codefix_exports.createImportAdder(sourceFile, program, preferences, host); - const elements = []; - for (const type of switchType.types) { - if (type.flags & 1024 /* EnumLiteral */) { - Debug.assert(type.symbol, "An enum member type should have a symbol"); - Debug.assert(type.symbol.parent, "An enum member type should have a parent symbol (the enum symbol)"); - const enumValue = type.symbol.valueDeclaration && checker.getConstantValue(type.symbol.valueDeclaration); - if (enumValue !== void 0) { - if (tracker.hasValue(enumValue)) { - continue; - } - tracker.addValue(enumValue); - } - const typeNode = ts_codefix_exports.typeToAutoImportableTypeNode(checker, importAdder, type, caseBlock, target); - if (!typeNode) { - return void 0; + function getImportersForExport(sourceFiles, sourceFilesSet, allDirectImports, { exportingModuleSymbol, exportKind }, checker, cancellationToken) { + const markSeenDirectImport = nodeSeenTracker(); + const markSeenIndirectUser = nodeSeenTracker(); + const directImports = []; + const isAvailableThroughGlobal = !!exportingModuleSymbol.globalExports; + const indirectUserDeclarations = isAvailableThroughGlobal ? void 0 : []; + handleDirectImports(exportingModuleSymbol); + return { directImports, indirectUsers: getIndirectUsers() }; + function getIndirectUsers() { + if (isAvailableThroughGlobal) { + return sourceFiles; + } + if (exportingModuleSymbol.declarations) { + for (const decl of exportingModuleSymbol.declarations) { + if (isExternalModuleAugmentation(decl) && sourceFilesSet.has(decl.getSourceFile().fileName)) { + addIndirectUser(decl); } - const expr = typeNodeToExpression(typeNode, target, quotePreference); - if (!expr) { - return void 0; + } + } + return indirectUserDeclarations.map(getSourceFileOfNode); + } + function handleDirectImports(exportingModuleSymbol2) { + const theseDirectImports = getDirectImports(exportingModuleSymbol2); + if (theseDirectImports) { + for (const direct of theseDirectImports) { + if (!markSeenDirectImport(direct)) { + continue; } - elements.push(expr); - } else if (!tracker.hasValue(type.value)) { - switch (typeof type.value) { - case "object": - elements.push(type.value.negative ? factory.createPrefixUnaryExpression(41 /* MinusToken */, factory.createBigIntLiteral({ negative: false, base10Value: type.value.base10Value })) : factory.createBigIntLiteral(type.value)); + if (cancellationToken) + cancellationToken.throwIfCancellationRequested(); + switch (direct.kind) { + case 213 /* CallExpression */: + if (isImportCall(direct)) { + handleImportCall(direct); + break; + } + if (!isAvailableThroughGlobal) { + const parent2 = direct.parent; + if (exportKind === 2 /* ExportEquals */ && parent2.kind === 260 /* VariableDeclaration */) { + const { name } = parent2; + if (name.kind === 80 /* Identifier */) { + directImports.push(name); + break; + } + } + } break; - case "number": - elements.push(type.value < 0 ? factory.createPrefixUnaryExpression(41 /* MinusToken */, factory.createNumericLiteral(-type.value)) : factory.createNumericLiteral(type.value)); + case 80 /* Identifier */: break; - case "string": - elements.push(factory.createStringLiteral(type.value, quotePreference === 0 /* Single */)); + case 271 /* ImportEqualsDeclaration */: + handleNamespaceImport( + direct, + direct.name, + hasSyntacticModifier(direct, 32 /* Export */), + /*alreadyAddedDirect*/ + false + ); + break; + case 272 /* ImportDeclaration */: + directImports.push(direct); + const namedBindings = direct.importClause && direct.importClause.namedBindings; + if (namedBindings && namedBindings.kind === 274 /* NamespaceImport */) { + handleNamespaceImport( + direct, + namedBindings.name, + /*isReExport*/ + false, + /*alreadyAddedDirect*/ + true + ); + } else if (!isAvailableThroughGlobal && isDefaultImport(direct)) { + addIndirectUser(getSourceFileLikeForImportDeclaration(direct)); + } + break; + case 278 /* ExportDeclaration */: + if (!direct.exportClause) { + handleDirectImports(getContainingModuleSymbol(direct, checker)); + } else if (direct.exportClause.kind === 280 /* NamespaceExport */) { + addIndirectUser( + getSourceFileLikeForImportDeclaration(direct), + /*addTransitiveDependencies*/ + true + ); + } else { + directImports.push(direct); + } + break; + case 205 /* ImportType */: + if (!isAvailableThroughGlobal && direct.isTypeOf && !direct.qualifier && isExported2(direct)) { + addIndirectUser( + direct.getSourceFile(), + /*addTransitiveDependencies*/ + true + ); + } + directImports.push(direct); break; + default: + Debug.failBadSyntaxKind(direct, "Unexpected import kind."); } } } - if (elements.length === 0) { - return void 0; - } - const newClauses = map(elements, (element) => factory.createCaseClause(element, [])); - const newLineChar = getNewLineOrDefaultFromHost(host, formatContext == null ? void 0 : formatContext.options); - const printer = createSnippetPrinter({ - removeComments: true, - module: options.module, - target: options.target, - newLine: getNewLineKind(newLineChar) + } + function handleImportCall(importCall) { + const top = findAncestor(importCall, isAmbientModuleDeclaration) || importCall.getSourceFile(); + addIndirectUser( + top, + /** addTransitiveDependencies */ + !!isExported2( + importCall, + /*stopAtAmbientModule*/ + true + ) + ); + } + function isExported2(node, stopAtAmbientModule = false) { + return findAncestor(node, (node2) => { + if (stopAtAmbientModule && isAmbientModuleDeclaration(node2)) + return "quit"; + return canHaveModifiers(node2) && some(node2.modifiers, isExportModifier); }); - const printNode = formatContext ? (node) => printer.printAndFormatNode(4 /* Unspecified */, node, sourceFile, formatContext) : (node) => printer.printNode(4 /* Unspecified */, node, sourceFile); - const insertText = map(newClauses, (clause, i) => { - if (preferences.includeCompletionsWithSnippetText) { - return `${printNode(clause)}$${i + 1}`; - } - return `${printNode(clause)}`; - }).join(newLineChar); - const firstClause = printer.printNode(4 /* Unspecified */, newClauses[0], sourceFile); - return { - entry: { - name: `${firstClause} ...`, - kind: "" /* unknown */, - sortText: SortText.GlobalsOrKeywords, - insertText, - hasAction: importAdder.hasFixes() || void 0, - source: "SwitchCases/" /* SwitchCases */, - isSnippet: preferences.includeCompletionsWithSnippetText ? true : void 0 - }, - importAdder - }; } - return void 0; - } - function typeNodeToExpression(typeNode, languageVersion, quotePreference) { - switch (typeNode.kind) { - case 182 /* TypeReference */: - const typeName = typeNode.typeName; - return entityNameToExpression(typeName, languageVersion, quotePreference); - case 198 /* IndexedAccessType */: - const objectExpression = typeNodeToExpression(typeNode.objectType, languageVersion, quotePreference); - const indexExpression = typeNodeToExpression(typeNode.indexType, languageVersion, quotePreference); - return objectExpression && indexExpression && factory.createElementAccessExpression(objectExpression, indexExpression); - case 200 /* LiteralType */: - const literal = typeNode.literal; - switch (literal.kind) { - case 11 /* StringLiteral */: - return factory.createStringLiteral(literal.text, quotePreference === 0 /* Single */); - case 9 /* NumericLiteral */: - return factory.createNumericLiteral(literal.text, literal.numericLiteralFlags); + function handleNamespaceImport(importDeclaration, name, isReExport, alreadyAddedDirect) { + if (exportKind === 2 /* ExportEquals */) { + if (!alreadyAddedDirect) + directImports.push(importDeclaration); + } else if (!isAvailableThroughGlobal) { + const sourceFileLike = getSourceFileLikeForImportDeclaration(importDeclaration); + Debug.assert(sourceFileLike.kind === 312 /* SourceFile */ || sourceFileLike.kind === 267 /* ModuleDeclaration */); + if (isReExport || findNamespaceReExports(sourceFileLike, name, checker)) { + addIndirectUser( + sourceFileLike, + /*addTransitiveDependencies*/ + true + ); + } else { + addIndirectUser(sourceFileLike); } - return void 0; - case 195 /* ParenthesizedType */: - const exp = typeNodeToExpression(typeNode.type, languageVersion, quotePreference); - return exp && (isIdentifier(exp) ? exp : factory.createParenthesizedExpression(exp)); - case 185 /* TypeQuery */: - return entityNameToExpression(typeNode.exprName, languageVersion, quotePreference); - case 204 /* ImportType */: - Debug.fail(`We should not get an import type after calling 'codefix.typeToAutoImportableTypeNode'.`); + } } - return void 0; - } - function entityNameToExpression(entityName, languageVersion, quotePreference) { - if (isIdentifier(entityName)) { - return entityName; + function addIndirectUser(sourceFileLike, addTransitiveDependencies = false) { + Debug.assert(!isAvailableThroughGlobal); + const isNew = markSeenIndirectUser(sourceFileLike); + if (!isNew) + return; + indirectUserDeclarations.push(sourceFileLike); + if (!addTransitiveDependencies) + return; + const moduleSymbol = checker.getMergedSymbol(sourceFileLike.symbol); + if (!moduleSymbol) + return; + Debug.assert(!!(moduleSymbol.flags & 1536 /* Module */)); + const directImports2 = getDirectImports(moduleSymbol); + if (directImports2) { + for (const directImport of directImports2) { + if (!isImportTypeNode(directImport)) { + addIndirectUser( + getSourceFileLikeForImportDeclaration(directImport), + /*addTransitiveDependencies*/ + true + ); + } + } + } } - const unescapedName = unescapeLeadingUnderscores(entityName.right.escapedText); - if (canUsePropertyAccess(unescapedName, languageVersion)) { - return factory.createPropertyAccessExpression( - entityNameToExpression(entityName.left, languageVersion, quotePreference), - unescapedName - ); - } else { - return factory.createElementAccessExpression( - entityNameToExpression(entityName.left, languageVersion, quotePreference), - factory.createStringLiteral(unescapedName, quotePreference === 0 /* Single */) - ); + function getDirectImports(moduleSymbol) { + return allDirectImports.get(getSymbolId(moduleSymbol).toString()); } } - function isMemberCompletionKind(kind) { - switch (kind) { - case 0 /* ObjectPropertyDeclaration */: - case 3 /* MemberLike */: - case 2 /* PropertyAccess */: - return true; - default: - return false; + function getSearchesFromDirectImports(directImports, exportSymbol, exportKind, checker, isForRename) { + const importSearches = []; + const singleReferences = []; + function addSearch(location, symbol) { + importSearches.push([location, symbol]); } - } - function getJsxClosingTagCompletion(location, sourceFile) { - const jsxClosingElement = findAncestor(location, (node) => { - switch (node.kind) { - case 286 /* JsxClosingElement */: - return true; - case 44 /* SlashToken */: - case 32 /* GreaterThanToken */: - case 80 /* Identifier */: - case 210 /* PropertyAccessExpression */: - return false; - default: - return "quit"; + if (directImports) { + for (const decl of directImports) { + handleImport(decl); } - }); - if (jsxClosingElement) { - const hasClosingAngleBracket = !!findChildOfKind(jsxClosingElement, 32 /* GreaterThanToken */, sourceFile); - const tagName = jsxClosingElement.parent.openingElement.tagName; - const closingTag = tagName.getText(sourceFile); - const fullClosingTag = closingTag + (hasClosingAngleBracket ? "" : ">"); - const replacementSpan = createTextSpanFromNode(jsxClosingElement.tagName); - const entry = { - name: fullClosingTag, - kind: "class" /* classElement */, - kindModifiers: void 0, - sortText: SortText.LocationPriority - }; - return { isGlobalCompletion: false, isMemberCompletion: true, isNewIdentifierLocation: false, optionalReplacementSpan: replacementSpan, entries: [entry] }; } - return; - } - function getJSCompletionEntries(sourceFile, position, uniqueNames, target, entries) { - getNameTable(sourceFile).forEach((pos, name) => { - if (pos === position) { + return { importSearches, singleReferences }; + function handleImport(decl) { + if (decl.kind === 271 /* ImportEqualsDeclaration */) { + if (isExternalModuleImportEquals(decl)) { + handleNamespaceImportLike(decl.name); + } return; } - const realName = unescapeLeadingUnderscores(name); - if (!uniqueNames.has(realName) && isIdentifierText(realName, target)) { - uniqueNames.add(realName); - insertSorted(entries, { - name: realName, - kind: "warning" /* warning */, - kindModifiers: "", - sortText: SortText.JavascriptIdentifiers, - isFromUncheckedFile: true - }, compareCompletionEntries); + if (decl.kind === 80 /* Identifier */) { + handleNamespaceImportLike(decl); + return; } - }); - } - function completionNameForLiteral(sourceFile, preferences, literal) { - return typeof literal === "object" ? pseudoBigIntToString(literal) + "n" : isString(literal) ? quote(sourceFile, preferences, literal) : JSON.stringify(literal); - } - function createCompletionEntryForLiteral(sourceFile, preferences, literal) { - return { name: completionNameForLiteral(sourceFile, preferences, literal), kind: "string" /* string */, kindModifiers: "" /* none */, sortText: SortText.LocationPriority }; - } - function createCompletionEntry(symbol, sortText, replacementToken, contextToken, location, position, sourceFile, host, program, name, needsConvertPropertyAccess, origin, recommendedCompletion, propertyAccessToConvert, isJsxInitializer, importStatementCompletion, useSemicolons, options, preferences, completionKind, formatContext, isJsxIdentifierExpected, isRightOfOpenTag, includeSymbol) { - let insertText; - let replacementSpan = getReplacementSpanForContextToken(replacementToken); - let data; - let isSnippet; - let source = getSourceFromOrigin(origin); - let sourceDisplay; - let hasAction; - let labelDetails; - const typeChecker = program.getTypeChecker(); - const insertQuestionDot = origin && originIsNullableMember(origin); - const useBraces = origin && originIsSymbolMember(origin) || needsConvertPropertyAccess; - if (origin && originIsThisType(origin)) { - insertText = needsConvertPropertyAccess ? `this${insertQuestionDot ? "?." : ""}[${quotePropertyName(sourceFile, preferences, name)}]` : `this${insertQuestionDot ? "?." : "."}${name}`; - } else if ((useBraces || insertQuestionDot) && propertyAccessToConvert) { - insertText = useBraces ? needsConvertPropertyAccess ? `[${quotePropertyName(sourceFile, preferences, name)}]` : `[${name}]` : name; - if (insertQuestionDot || propertyAccessToConvert.questionDotToken) { - insertText = `?.${insertText}`; + if (decl.kind === 205 /* ImportType */) { + if (decl.qualifier) { + const firstIdentifier = getFirstIdentifier(decl.qualifier); + if (firstIdentifier.escapedText === symbolName(exportSymbol)) { + singleReferences.push(firstIdentifier); + } + } else if (exportKind === 2 /* ExportEquals */) { + singleReferences.push(decl.argument.literal); + } + return; } - const dot = findChildOfKind(propertyAccessToConvert, 25 /* DotToken */, sourceFile) || findChildOfKind(propertyAccessToConvert, 29 /* QuestionDotToken */, sourceFile); - if (!dot) { - return void 0; + if (decl.moduleSpecifier.kind !== 11 /* StringLiteral */) { + return; } - const end = startsWith(name, propertyAccessToConvert.name.text) ? propertyAccessToConvert.name.end : dot.end; - replacementSpan = createTextSpanFromBounds(dot.getStart(sourceFile), end); - } - if (isJsxInitializer) { - if (insertText === void 0) - insertText = name; - insertText = `{${insertText}}`; - if (typeof isJsxInitializer !== "boolean") { - replacementSpan = createTextSpanFromNode(isJsxInitializer, sourceFile); + if (decl.kind === 278 /* ExportDeclaration */) { + if (decl.exportClause && isNamedExports(decl.exportClause)) { + searchForNamedImport(decl.exportClause); + } + return; } - } - if (origin && originIsPromise(origin) && propertyAccessToConvert) { - if (insertText === void 0) - insertText = name; - const precedingToken = findPrecedingToken(propertyAccessToConvert.pos, sourceFile); - let awaitText = ""; - if (precedingToken && positionIsASICandidate(precedingToken.end, precedingToken.parent, sourceFile)) { - awaitText = ";"; + const { name, namedBindings } = decl.importClause || { name: void 0, namedBindings: void 0 }; + if (namedBindings) { + switch (namedBindings.kind) { + case 274 /* NamespaceImport */: + handleNamespaceImportLike(namedBindings.name); + break; + case 275 /* NamedImports */: + if (exportKind === 0 /* Named */ || exportKind === 1 /* Default */) { + searchForNamedImport(namedBindings); + } + break; + default: + Debug.assertNever(namedBindings); + } } - awaitText += `(await ${propertyAccessToConvert.expression.getText()})`; - insertText = needsConvertPropertyAccess ? `${awaitText}${insertText}` : `${awaitText}${insertQuestionDot ? "?." : "."}${insertText}`; - const isInAwaitExpression = tryCast(propertyAccessToConvert.parent, isAwaitExpression); - const wrapNode = isInAwaitExpression ? propertyAccessToConvert.parent : propertyAccessToConvert.expression; - replacementSpan = createTextSpanFromBounds(wrapNode.getStart(sourceFile), propertyAccessToConvert.end); - } - if (originIsResolvedExport(origin)) { - sourceDisplay = [textPart(origin.moduleSpecifier)]; - if (importStatementCompletion) { - ({ insertText, replacementSpan } = getInsertTextAndReplacementSpanForImportCompletion(name, importStatementCompletion, origin, useSemicolons, sourceFile, options, preferences)); - isSnippet = preferences.includeCompletionsWithSnippetText ? true : void 0; + if (name && (exportKind === 1 /* Default */ || exportKind === 2 /* ExportEquals */) && (!isForRename || name.escapedText === symbolEscapedNameNoDefault(exportSymbol))) { + const defaultImportAlias = checker.getSymbolAtLocation(name); + addSearch(name, defaultImportAlias); } } - if ((origin == null ? void 0 : origin.kind) === 64 /* TypeOnlyAlias */) { - hasAction = true; - } - if (preferences.includeCompletionsWithClassMemberSnippets && preferences.includeCompletionsWithInsertText && completionKind === 3 /* MemberLike */ && isClassLikeMemberCompletion(symbol, location, sourceFile)) { - let importAdder; - ({ insertText, isSnippet, importAdder, replacementSpan } = getEntryForMemberCompletion(host, program, options, preferences, name, symbol, location, position, contextToken, formatContext)); - sortText = SortText.ClassMemberSnippets; - if (importAdder == null ? void 0 : importAdder.hasFixes()) { - hasAction = true; - source = "ClassMemberSnippet/" /* ClassMemberSnippet */; + function handleNamespaceImportLike(importName) { + if (exportKind === 2 /* ExportEquals */ && (!isForRename || isNameMatch(importName.escapedText))) { + addSearch(importName, checker.getSymbolAtLocation(importName)); } } - if (origin && originIsObjectLiteralMethod(origin)) { - ({ insertText, isSnippet, labelDetails } = origin); - if (!preferences.useLabelDetailsInCompletionEntries) { - name = name + labelDetails.detail; - labelDetails = void 0; + function searchForNamedImport(namedBindings) { + if (!namedBindings) { + return; } - source = "ObjectLiteralMethodSnippet/" /* ObjectLiteralMethodSnippet */; - sortText = SortText.SortBelow(sortText); - } - if (isJsxIdentifierExpected && !isRightOfOpenTag && preferences.includeCompletionsWithSnippetText && preferences.jsxAttributeCompletionStyle && preferences.jsxAttributeCompletionStyle !== "none" && !(isJsxAttribute(location.parent) && location.parent.initializer)) { - let useBraces2 = preferences.jsxAttributeCompletionStyle === "braces"; - const type = typeChecker.getTypeOfSymbolAtLocation(symbol, location); - if (preferences.jsxAttributeCompletionStyle === "auto" && !(type.flags & 528 /* BooleanLike */) && !(type.flags & 1048576 /* Union */ && find(type.types, (type2) => !!(type2.flags & 528 /* BooleanLike */)))) { - if (type.flags & 402653316 /* StringLike */ || type.flags & 1048576 /* Union */ && every(type.types, (type2) => !!(type2.flags & (402653316 /* StringLike */ | 32768 /* Undefined */) || isStringAndEmptyAnonymousObjectIntersection(type2)))) { - insertText = `${escapeSnippetText(name)}=${quote(sourceFile, preferences, "$1")}`; - isSnippet = true; + for (const element of namedBindings.elements) { + const { name, propertyName } = element; + if (!isNameMatch((propertyName || name).escapedText)) { + continue; + } + if (propertyName) { + singleReferences.push(propertyName); + if (!isForRename || name.escapedText === exportSymbol.escapedName) { + addSearch(name, checker.getSymbolAtLocation(name)); + } } else { - useBraces2 = true; + const localSymbol = element.kind === 281 /* ExportSpecifier */ && element.propertyName ? checker.getExportSpecifierLocalTargetSymbol(element) : checker.getSymbolAtLocation(name); + addSearch(name, localSymbol); } } - if (useBraces2) { - insertText = `${escapeSnippetText(name)}={$1}`; - isSnippet = true; - } - } - if (insertText !== void 0 && !preferences.includeCompletionsWithInsertText) { - return void 0; } - if (originIsExport(origin) || originIsResolvedExport(origin)) { - data = originToCompletionEntryData(origin); - hasAction = !importStatementCompletion; + function isNameMatch(name) { + return name === exportSymbol.escapedName || exportKind !== 0 /* Named */ && name === "default" /* Default */; } - return { - name, - kind: ts_SymbolDisplay_exports.getSymbolKind(typeChecker, symbol, location), - kindModifiers: ts_SymbolDisplay_exports.getSymbolModifiers(typeChecker, symbol), - sortText, - source, - hasAction: hasAction ? true : void 0, - isRecommended: isRecommendedCompletionMatch(symbol, recommendedCompletion, typeChecker) || void 0, - insertText, - replacementSpan, - sourceDisplay, - labelDetails, - isSnippet, - isPackageJsonImport: originIsPackageJsonImport(origin) || void 0, - isImportStatementCompletion: !!importStatementCompletion || void 0, - data, - ...includeSymbol ? { symbol } : void 0 - }; } - function isClassLikeMemberCompletion(symbol, location, sourceFile) { - if (isInJSFile(location)) { - return false; - } - const memberFlags = 106500 /* ClassMember */ & 900095 /* EnumMemberExcludes */; - return !!(symbol.flags & memberFlags) && (isClassLike(location) || location.parent && location.parent.parent && isClassElement(location.parent) && location === location.parent.name && location.parent.getLastToken(sourceFile) === location.parent.name && isClassLike(location.parent.parent) || location.parent && isSyntaxList(location) && isClassLike(location.parent)); + function findNamespaceReExports(sourceFileLike, name, checker) { + const namespaceImportSymbol = checker.getSymbolAtLocation(name); + return !!forEachPossibleImportOrExportStatement(sourceFileLike, (statement) => { + if (!isExportDeclaration(statement)) + return; + const { exportClause, moduleSpecifier } = statement; + return !moduleSpecifier && exportClause && isNamedExports(exportClause) && exportClause.elements.some((element) => checker.getExportSpecifierLocalTargetSymbol(element) === namespaceImportSymbol); + }); } - function getEntryForMemberCompletion(host, program, options, preferences, name, symbol, location, position, contextToken, formatContext) { - const classLikeDeclaration = findAncestor(location, isClassLike); - if (!classLikeDeclaration) { - return { insertText: name }; - } - let isSnippet; - let replacementSpan; - let insertText = name; + function findModuleReferences(program, sourceFiles, searchModuleSymbol) { + var _a; + const refs = []; const checker = program.getTypeChecker(); - const sourceFile = location.getSourceFile(); - const printer = createSnippetPrinter({ - removeComments: true, - module: options.module, - target: options.target, - omitTrailingSemicolon: false, - newLine: getNewLineKind(getNewLineOrDefaultFromHost(host, formatContext == null ? void 0 : formatContext.options)) - }); - const importAdder = ts_codefix_exports.createImportAdder(sourceFile, program, preferences, host); - let body; - if (preferences.includeCompletionsWithSnippetText) { - isSnippet = true; - const emptyStmt = factory.createEmptyStatement(); - body = factory.createBlock( - [emptyStmt], - /*multiLine*/ - true - ); - setSnippetElement(emptyStmt, { kind: 0 /* TabStop */, order: 0 }); - } else { - body = factory.createBlock( - [], - /*multiLine*/ - true - ); - } - let modifiers = 0 /* None */; - const { modifiers: presentModifiers, span: modifiersSpan } = getPresentModifiers(contextToken, sourceFile, position); - const isAbstract = !!(presentModifiers & 256 /* Abstract */); - const completionNodes = []; - ts_codefix_exports.addNewNodeForMemberSymbol( - symbol, - classLikeDeclaration, - sourceFile, - { program, host }, - preferences, - importAdder, - // `addNewNodeForMemberSymbol` calls this callback function for each new member node - // it adds for the given member symbol. - // We store these member nodes in the `completionNodes` array. - // Note: there might be: - // - No nodes if `addNewNodeForMemberSymbol` cannot figure out a node for the member; - // - One node; - // - More than one node if the member is overloaded (e.g. a method with overload signatures). - (node) => { - let requiredModifiers = 0 /* None */; - if (isAbstract) { - requiredModifiers |= 256 /* Abstract */; - } - if (isClassElement(node) && checker.getMemberOverrideModifierStatus(classLikeDeclaration, node, symbol) === 1 /* NeedsOverride */) { - requiredModifiers |= 16384 /* Override */; + for (const referencingFile of sourceFiles) { + const searchSourceFile = searchModuleSymbol.valueDeclaration; + if ((searchSourceFile == null ? void 0 : searchSourceFile.kind) === 312 /* SourceFile */) { + for (const ref of referencingFile.referencedFiles) { + if (program.getSourceFileFromReference(referencingFile, ref) === searchSourceFile) { + refs.push({ kind: "reference", referencingFile, ref }); + } } - if (!completionNodes.length) { - modifiers = node.modifierFlagsCache | requiredModifiers | presentModifiers; + for (const ref of referencingFile.typeReferenceDirectives) { + const referenced = (_a = program.getResolvedTypeReferenceDirectives().get(ref.fileName, ref.resolutionMode || referencingFile.impliedNodeFormat)) == null ? void 0 : _a.resolvedTypeReferenceDirective; + if (referenced !== void 0 && referenced.resolvedFileName === searchSourceFile.fileName) { + refs.push({ kind: "reference", referencingFile, ref }); + } } - node = factory.updateModifiers(node, modifiers); - completionNodes.push(node); - }, - body, - ts_codefix_exports.PreserveOptionalFlags.Property, - isAbstract - ); - if (completionNodes.length) { - const format = 1 /* MultiLine */ | 131072 /* NoTrailingNewLine */; - replacementSpan = modifiersSpan; - if (formatContext) { - insertText = printer.printAndFormatSnippetList( - format, - factory.createNodeArray(completionNodes), - sourceFile, - formatContext - ); - } else { - insertText = printer.printSnippetList( - format, - factory.createNodeArray(completionNodes), - sourceFile - ); } + forEachImport(referencingFile, (importDecl, moduleSpecifier) => { + const moduleSymbol = checker.getSymbolAtLocation(moduleSpecifier); + if (moduleSymbol === searchModuleSymbol) { + refs.push(nodeIsSynthesized(importDecl) ? { kind: "implicit", literal: moduleSpecifier, referencingFile } : { kind: "import", literal: moduleSpecifier }); + } + }); } - return { insertText, isSnippet, importAdder, replacementSpan }; + return refs; } - function getPresentModifiers(contextToken, sourceFile, position) { - if (!contextToken || getLineAndCharacterOfPosition(sourceFile, position).line > getLineAndCharacterOfPosition(sourceFile, contextToken.getEnd()).line) { - return { modifiers: 0 /* None */ }; - } - let modifiers = 0 /* None */; - let span; - let contextMod; - if (contextMod = isModifierLike2(contextToken)) { - modifiers |= modifierToFlag(contextMod); - span = createTextSpanFromNode(contextToken); - } - if (isPropertyDeclaration(contextToken.parent)) { - modifiers |= modifiersToFlags(contextToken.parent.modifiers) & 126975 /* Modifier */; - span = createTextSpanFromNode(contextToken.parent); + function getDirectImportsMap(sourceFiles, checker, cancellationToken) { + const map2 = /* @__PURE__ */ new Map(); + for (const sourceFile of sourceFiles) { + if (cancellationToken) + cancellationToken.throwIfCancellationRequested(); + forEachImport(sourceFile, (importDecl, moduleSpecifier) => { + const moduleSymbol = checker.getSymbolAtLocation(moduleSpecifier); + if (moduleSymbol) { + const id = getSymbolId(moduleSymbol).toString(); + let imports = map2.get(id); + if (!imports) { + map2.set(id, imports = []); + } + imports.push(importDecl); + } + }); } - return { modifiers, span }; + return map2; } - function isModifierLike2(node) { - if (isModifier(node)) { - return node.kind; - } - if (isIdentifier(node)) { - const originalKeywordKind = identifierToKeywordKind(node); - if (originalKeywordKind && isModifierKind(originalKeywordKind)) { - return originalKeywordKind; - } - } - return void 0; + function forEachPossibleImportOrExportStatement(sourceFileLike, action) { + return forEach(sourceFileLike.kind === 312 /* SourceFile */ ? sourceFileLike.statements : sourceFileLike.body.statements, (statement) => ( + // TODO: GH#18217 + action(statement) || isAmbientModuleDeclaration(statement) && forEach(statement.body && statement.body.statements, action) + )); } - function getEntryForObjectLiteralMethodCompletion(symbol, name, enclosingDeclaration, program, host, options, preferences, formatContext) { - const isSnippet = preferences.includeCompletionsWithSnippetText || void 0; - let insertText = name; - const sourceFile = enclosingDeclaration.getSourceFile(); - const method = createObjectLiteralMethod(symbol, enclosingDeclaration, sourceFile, program, host, preferences); - if (!method) { - return void 0; - } - const printer = createSnippetPrinter({ - removeComments: true, - module: options.module, - target: options.target, - omitTrailingSemicolon: false, - newLine: getNewLineKind(getNewLineOrDefaultFromHost(host, formatContext == null ? void 0 : formatContext.options)) - }); - if (formatContext) { - insertText = printer.printAndFormatSnippetList(16 /* CommaDelimited */ | 64 /* AllowTrailingComma */, factory.createNodeArray( - [method], - /*hasTrailingComma*/ - true - ), sourceFile, formatContext); + function forEachImport(sourceFile, action) { + if (sourceFile.externalModuleIndicator || sourceFile.imports !== void 0) { + for (const i of sourceFile.imports) { + action(importFromModuleSpecifier(i), i); + } } else { - insertText = printer.printSnippetList(16 /* CommaDelimited */ | 64 /* AllowTrailingComma */, factory.createNodeArray( - [method], - /*hasTrailingComma*/ - true - ), sourceFile); + forEachPossibleImportOrExportStatement(sourceFile, (statement) => { + switch (statement.kind) { + case 278 /* ExportDeclaration */: + case 272 /* ImportDeclaration */: { + const decl = statement; + if (decl.moduleSpecifier && isStringLiteral(decl.moduleSpecifier)) { + action(decl, decl.moduleSpecifier); + } + break; + } + case 271 /* ImportEqualsDeclaration */: { + const decl = statement; + if (isExternalModuleImportEquals(decl)) { + action(decl, decl.moduleReference.expression); + } + break; + } + } + }); } - const signaturePrinter = createPrinter({ - removeComments: true, - module: options.module, - target: options.target, - omitTrailingSemicolon: true - }); - const methodSignature = factory.createMethodSignature( - /*modifiers*/ - void 0, - /*name*/ - "", - method.questionToken, - method.typeParameters, - method.parameters, - method.type - ); - const labelDetails = { detail: signaturePrinter.printNode(4 /* Unspecified */, methodSignature, sourceFile) }; - return { isSnippet, insertText, labelDetails }; } - function createObjectLiteralMethod(symbol, enclosingDeclaration, sourceFile, program, host, preferences) { - const declarations = symbol.getDeclarations(); - if (!(declarations && declarations.length)) { - return void 0; - } - const checker = program.getTypeChecker(); - const declaration = declarations[0]; - const name = getSynthesizedDeepClone( - getNameOfDeclaration(declaration), - /*includeTrivia*/ - false - ); - const type = checker.getWidenedType(checker.getTypeOfSymbolAtLocation(symbol, enclosingDeclaration)); - const quotePreference = getQuotePreference(sourceFile, preferences); - const builderFlags = 33554432 /* OmitThisParameter */ | (quotePreference === 0 /* Single */ ? 268435456 /* UseSingleQuotesForStringLiteralType */ : 0 /* None */); - switch (declaration.kind) { - case 170 /* PropertySignature */: - case 171 /* PropertyDeclaration */: - case 172 /* MethodSignature */: - case 173 /* MethodDeclaration */: { - let effectiveType = type.flags & 1048576 /* Union */ && type.types.length < 10 ? checker.getUnionType(type.types, 2 /* Subtype */) : type; - if (effectiveType.flags & 1048576 /* Union */) { - const functionTypes = filter(effectiveType.types, (type2) => checker.getSignaturesOfType(type2, 0 /* Call */).length > 0); - if (functionTypes.length === 1) { - effectiveType = functionTypes[0]; + function getImportOrExportSymbol(node, symbol, checker, comingFromExport) { + return comingFromExport ? getExport() : getExport() || getImport(); + function getExport() { + var _a; + const { parent: parent2 } = node; + const grandparent = parent2.parent; + if (symbol.exportSymbol) { + if (parent2.kind === 211 /* PropertyAccessExpression */) { + return ((_a = symbol.declarations) == null ? void 0 : _a.some((d) => d === parent2)) && isBinaryExpression(grandparent) ? getSpecialPropertyExport( + grandparent, + /*useLhsSymbol*/ + false + ) : void 0; + } else { + return exportInfo(symbol.exportSymbol, getExportKindForDeclaration(parent2)); + } + } else { + const exportNode = getExportNode(parent2, node); + if (exportNode && hasSyntacticModifier(exportNode, 32 /* Export */)) { + if (isImportEqualsDeclaration(exportNode) && exportNode.moduleReference === node) { + if (comingFromExport) { + return void 0; + } + const lhsSymbol = checker.getSymbolAtLocation(exportNode.name); + return { kind: 0 /* Import */, symbol: lhsSymbol }; } else { - return void 0; + return exportInfo(symbol, getExportKindForDeclaration(exportNode)); } - } - const signatures = checker.getSignaturesOfType(effectiveType, 0 /* Call */); - if (signatures.length !== 1) { - return void 0; - } - const typeNode = checker.typeToTypeNode(effectiveType, enclosingDeclaration, builderFlags, ts_codefix_exports.getNoopSymbolTrackerWithResolver({ program, host })); - if (!typeNode || !isFunctionTypeNode(typeNode)) { - return void 0; - } - let body; - if (preferences.includeCompletionsWithSnippetText) { - const emptyStmt = factory.createEmptyStatement(); - body = factory.createBlock( - [emptyStmt], - /*multiLine*/ + } else if (isNamespaceExport(parent2)) { + return exportInfo(symbol, 0 /* Named */); + } else if (isExportAssignment(parent2)) { + return getExportAssignmentExport(parent2); + } else if (isExportAssignment(grandparent)) { + return getExportAssignmentExport(grandparent); + } else if (isBinaryExpression(parent2)) { + return getSpecialPropertyExport( + parent2, + /*useLhsSymbol*/ true ); - setSnippetElement(emptyStmt, { kind: 0 /* TabStop */, order: 0 }); - } else { - body = factory.createBlock( - [], - /*multiLine*/ + } else if (isBinaryExpression(grandparent)) { + return getSpecialPropertyExport( + grandparent, + /*useLhsSymbol*/ true ); + } else if (isJSDocTypedefTag(parent2) || isJSDocCallbackTag(parent2)) { + return exportInfo(symbol, 0 /* Named */); } - const parameters = typeNode.parameters.map((typedParam) => factory.createParameterDeclaration( - /*modifiers*/ - void 0, - typedParam.dotDotDotToken, - typedParam.name, - /*questionToken*/ - void 0, - /*type*/ - void 0, - typedParam.initializer - )); - return factory.createMethodDeclaration( - /*modifiers*/ - void 0, - /*asteriskToken*/ - void 0, - name, - /*questionToken*/ - void 0, - /*typeParameters*/ - void 0, - parameters, - /*type*/ - void 0, - body - ); } - default: - return void 0; - } - } - function createSnippetPrinter(printerOptions) { - let escapes; - const baseWriter = ts_textChanges_exports.createWriter(getNewLineCharacter(printerOptions)); - const printer = createPrinter(printerOptions, baseWriter); - const writer = { - ...baseWriter, - write: (s) => escapingWrite(s, () => baseWriter.write(s)), - nonEscapingWrite: baseWriter.write, - writeLiteral: (s) => escapingWrite(s, () => baseWriter.writeLiteral(s)), - writeStringLiteral: (s) => escapingWrite(s, () => baseWriter.writeStringLiteral(s)), - writeSymbol: (s, symbol) => escapingWrite(s, () => baseWriter.writeSymbol(s, symbol)), - writeParameter: (s) => escapingWrite(s, () => baseWriter.writeParameter(s)), - writeComment: (s) => escapingWrite(s, () => baseWriter.writeComment(s)), - writeProperty: (s) => escapingWrite(s, () => baseWriter.writeProperty(s)) - }; - return { - printSnippetList, - printAndFormatSnippetList, - printNode, - printAndFormatNode - }; - function escapingWrite(s, write) { - const escaped = escapeSnippetText(s); - if (escaped !== s) { - const start = baseWriter.getTextPos(); - write(); - const end = baseWriter.getTextPos(); - escapes = append(escapes || (escapes = []), { newText: escaped, span: { start, length: end - start } }); - } else { - write(); + function getExportAssignmentExport(ex) { + if (!ex.symbol.parent) + return void 0; + const exportKind = ex.isExportEquals ? 2 /* ExportEquals */ : 1 /* Default */; + return { kind: 1 /* Export */, symbol, exportInfo: { exportingModuleSymbol: ex.symbol.parent, exportKind } }; } - } - function printSnippetList(format, list, sourceFile) { - const unescaped = printUnescapedSnippetList(format, list, sourceFile); - return escapes ? ts_textChanges_exports.applyChanges(unescaped, escapes) : unescaped; - } - function printUnescapedSnippetList(format, list, sourceFile) { - escapes = void 0; - writer.clear(); - printer.writeList(format, list, sourceFile, writer); - return writer.getText(); - } - function printAndFormatSnippetList(format, list, sourceFile, formatContext) { - const syntheticFile = { - text: printUnescapedSnippetList( - format, - list, - sourceFile - ), - getLineAndCharacterOfPosition(pos) { - return getLineAndCharacterOfPosition(this, pos); + function getSpecialPropertyExport(node2, useLhsSymbol) { + let kind; + switch (getAssignmentDeclarationKind(node2)) { + case 1 /* ExportsProperty */: + kind = 0 /* Named */; + break; + case 2 /* ModuleExports */: + kind = 2 /* ExportEquals */; + break; + default: + return void 0; } - }; - const formatOptions = getFormatCodeSettingsForWriting(formatContext, sourceFile); - const changes = flatMap(list, (node) => { - const nodeWithPos = ts_textChanges_exports.assignPositionsToNode(node); - return ts_formatting_exports.formatNodeGivenIndentation( - nodeWithPos, - syntheticFile, - sourceFile.languageVariant, - /* indentation */ - 0, - /* delta */ - 0, - { ...formatContext, options: formatOptions } - ); - }); - const allChanges = escapes ? stableSort(concatenate(changes, escapes), (a, b) => compareTextSpans(a.span, b.span)) : changes; - return ts_textChanges_exports.applyChanges(syntheticFile.text, allChanges); + const sym = useLhsSymbol ? checker.getSymbolAtLocation(getNameOfAccessExpression(cast(node2.left, isAccessExpression))) : symbol; + return sym && exportInfo(sym, kind); + } } - function printNode(hint, node, sourceFile) { - const unescaped = printUnescapedNode(hint, node, sourceFile); - return escapes ? ts_textChanges_exports.applyChanges(unescaped, escapes) : unescaped; + function getImport() { + const isImport3 = isNodeImport(node); + if (!isImport3) + return void 0; + let importedSymbol = checker.getImmediateAliasedSymbol(symbol); + if (!importedSymbol) + return void 0; + importedSymbol = skipExportSpecifierSymbol(importedSymbol, checker); + if (importedSymbol.escapedName === "export=") { + importedSymbol = getExportEqualsLocalSymbol(importedSymbol, checker); + if (importedSymbol === void 0) + return void 0; + } + const importedName = symbolEscapedNameNoDefault(importedSymbol); + if (importedName === void 0 || importedName === "default" /* Default */ || importedName === symbol.escapedName) { + return { kind: 0 /* Import */, symbol: importedSymbol }; + } } - function printUnescapedNode(hint, node, sourceFile) { - escapes = void 0; - writer.clear(); - printer.writeNode(hint, node, sourceFile, writer); - return writer.getText(); + function exportInfo(symbol2, kind) { + const exportInfo2 = getExportInfo(symbol2, kind, checker); + return exportInfo2 && { kind: 1 /* Export */, symbol: symbol2, exportInfo: exportInfo2 }; } - function printAndFormatNode(hint, node, sourceFile, formatContext) { - const syntheticFile = { - text: printUnescapedNode( - hint, - node, - sourceFile - ), - getLineAndCharacterOfPosition(pos) { - return getLineAndCharacterOfPosition(this, pos); - } - }; - const formatOptions = getFormatCodeSettingsForWriting(formatContext, sourceFile); - const nodeWithPos = ts_textChanges_exports.assignPositionsToNode(node); - const changes = ts_formatting_exports.formatNodeGivenIndentation( - nodeWithPos, - syntheticFile, - sourceFile.languageVariant, - /* indentation */ - 0, - /* delta */ - 0, - { ...formatContext, options: formatOptions } - ); - const allChanges = escapes ? stableSort(concatenate(changes, escapes), (a, b) => compareTextSpans(a.span, b.span)) : changes; - return ts_textChanges_exports.applyChanges(syntheticFile.text, allChanges); + function getExportKindForDeclaration(node2) { + return hasSyntacticModifier(node2, 2048 /* Default */) ? 1 /* Default */ : 0 /* Named */; } } - function originToCompletionEntryData(origin) { - const ambientModuleName = origin.fileName ? void 0 : stripQuotes(origin.moduleSymbol.name); - const isPackageJsonImport = origin.isFromPackageJson ? true : void 0; - if (originIsResolvedExport(origin)) { - const resolvedData = { - exportName: origin.exportName, - exportMapKey: origin.exportMapKey, - moduleSpecifier: origin.moduleSpecifier, - ambientModuleName, - fileName: origin.fileName, - isPackageJsonImport - }; - return resolvedData; + function getExportEqualsLocalSymbol(importedSymbol, checker) { + var _a, _b; + if (importedSymbol.flags & 2097152 /* Alias */) { + return checker.getImmediateAliasedSymbol(importedSymbol); } - const unresolvedData = { - exportName: origin.exportName, - exportMapKey: origin.exportMapKey, - fileName: origin.fileName, - ambientModuleName: origin.fileName ? void 0 : stripQuotes(origin.moduleSymbol.name), - isPackageJsonImport: origin.isFromPackageJson ? true : void 0 - }; - return unresolvedData; - } - function completionEntryDataToSymbolOriginInfo(data, completionName, moduleSymbol) { - const isDefaultExport = data.exportName === "default" /* Default */; - const isFromPackageJson = !!data.isPackageJsonImport; - if (completionEntryDataIsResolved(data)) { - const resolvedOrigin = { - kind: 32 /* ResolvedExport */, - exportName: data.exportName, - exportMapKey: data.exportMapKey, - moduleSpecifier: data.moduleSpecifier, - symbolName: completionName, - fileName: data.fileName, - moduleSymbol, - isDefaultExport, - isFromPackageJson - }; - return resolvedOrigin; + const decl = Debug.checkDefined(importedSymbol.valueDeclaration); + if (isExportAssignment(decl)) { + return (_a = tryCast(decl.expression, canHaveSymbol)) == null ? void 0 : _a.symbol; + } else if (isBinaryExpression(decl)) { + return (_b = tryCast(decl.right, canHaveSymbol)) == null ? void 0 : _b.symbol; + } else if (isSourceFile(decl)) { + return decl.symbol; } - const unresolvedOrigin = { - kind: 4 /* Export */, - exportName: data.exportName, - exportMapKey: data.exportMapKey, - symbolName: completionName, - fileName: data.fileName, - moduleSymbol, - isDefaultExport, - isFromPackageJson - }; - return unresolvedOrigin; + return void 0; } - function getInsertTextAndReplacementSpanForImportCompletion(name, importStatementCompletion, origin, useSemicolons, sourceFile, options, preferences) { - const replacementSpan = importStatementCompletion.replacementSpan; - const quotedModuleSpecifier = escapeSnippetText(quote(sourceFile, preferences, origin.moduleSpecifier)); - const exportKind = origin.isDefaultExport ? 1 /* Default */ : origin.exportName === "export=" /* ExportEquals */ ? 2 /* ExportEquals */ : 0 /* Named */; - const tabStop = preferences.includeCompletionsWithSnippetText ? "$1" : ""; - const importKind = ts_codefix_exports.getImportKind( - sourceFile, - exportKind, - options, - /*forceImportKeyword*/ - true - ); - const isImportSpecifierTypeOnly = importStatementCompletion.couldBeTypeOnlyImportSpecifier; - const topLevelTypeOnlyText = importStatementCompletion.isTopLevelTypeOnly ? ` ${tokenToString(156 /* TypeKeyword */)} ` : " "; - const importSpecifierTypeOnlyText = isImportSpecifierTypeOnly ? `${tokenToString(156 /* TypeKeyword */)} ` : ""; - const suffix = useSemicolons ? ";" : ""; - switch (importKind) { - case 3 /* CommonJS */: - return { replacementSpan, insertText: `import${topLevelTypeOnlyText}${escapeSnippetText(name)}${tabStop} = require(${quotedModuleSpecifier})${suffix}` }; - case 1 /* Default */: - return { replacementSpan, insertText: `import${topLevelTypeOnlyText}${escapeSnippetText(name)}${tabStop} from ${quotedModuleSpecifier}${suffix}` }; - case 2 /* Namespace */: - return { replacementSpan, insertText: `import${topLevelTypeOnlyText}* as ${escapeSnippetText(name)} from ${quotedModuleSpecifier}${suffix}` }; - case 0 /* Named */: - return { replacementSpan, insertText: `import${topLevelTypeOnlyText}{ ${importSpecifierTypeOnlyText}${escapeSnippetText(name)}${tabStop} } from ${quotedModuleSpecifier}${suffix}` }; + function getExportNode(parent2, node) { + const declaration = isVariableDeclaration(parent2) ? parent2 : isBindingElement(parent2) ? walkUpBindingElementsAndPatterns(parent2) : void 0; + if (declaration) { + return parent2.name !== node ? void 0 : isCatchClause(declaration.parent) ? void 0 : isVariableStatement(declaration.parent.parent) ? declaration.parent.parent : void 0; + } else { + return parent2; } } - function quotePropertyName(sourceFile, preferences, name) { - if (/^\d+$/.test(name)) { - return name; + function isNodeImport(node) { + const { parent: parent2 } = node; + switch (parent2.kind) { + case 271 /* ImportEqualsDeclaration */: + return parent2.name === node && isExternalModuleImportEquals(parent2); + case 276 /* ImportSpecifier */: + return !parent2.propertyName; + case 273 /* ImportClause */: + case 274 /* NamespaceImport */: + Debug.assert(parent2.name === node); + return true; + case 208 /* BindingElement */: + return isInJSFile(node) && isVariableDeclarationInitializedToBareOrAccessedRequire(parent2.parent.parent); + default: + return false; } - return quote(sourceFile, preferences, name); } - function isRecommendedCompletionMatch(localSymbol, recommendedCompletion, checker) { - return localSymbol === recommendedCompletion || !!(localSymbol.flags & 1048576 /* ExportValue */) && checker.getExportSymbolOfSymbol(localSymbol) === recommendedCompletion; + function getExportInfo(exportSymbol, exportKind, checker) { + const moduleSymbol = exportSymbol.parent; + if (!moduleSymbol) + return void 0; + const exportingModuleSymbol = checker.getMergedSymbol(moduleSymbol); + return isExternalModuleSymbol(exportingModuleSymbol) ? { exportingModuleSymbol, exportKind } : void 0; } - function getSourceFromOrigin(origin) { - if (originIsExport(origin)) { - return stripQuotes(origin.moduleSymbol.name); - } - if (originIsResolvedExport(origin)) { - return origin.moduleSpecifier; + function skipExportSpecifierSymbol(symbol, checker) { + if (symbol.declarations) { + for (const declaration of symbol.declarations) { + if (isExportSpecifier(declaration) && !declaration.propertyName && !declaration.parent.parent.moduleSpecifier) { + return checker.getExportSpecifierLocalTargetSymbol(declaration) || symbol; + } else if (isPropertyAccessExpression(declaration) && isModuleExportsAccessExpression(declaration.expression) && !isPrivateIdentifier(declaration.name)) { + return checker.getSymbolAtLocation(declaration); + } else if (isShorthandPropertyAssignment(declaration) && isBinaryExpression(declaration.parent.parent) && getAssignmentDeclarationKind(declaration.parent.parent) === 2 /* ModuleExports */) { + return checker.getExportSpecifierLocalTargetSymbol(declaration.name); + } + } } - if ((origin == null ? void 0 : origin.kind) === 1 /* ThisType */) { - return "ThisProperty/" /* ThisProperty */; + return symbol; + } + function getContainingModuleSymbol(importer, checker) { + return checker.getMergedSymbol(getSourceFileLikeForImportDeclaration(importer).symbol); + } + function getSourceFileLikeForImportDeclaration(node) { + if (node.kind === 213 /* CallExpression */) { + return node.getSourceFile(); } - if ((origin == null ? void 0 : origin.kind) === 64 /* TypeOnlyAlias */) { - return "TypeOnlyAlias/" /* TypeOnlyAlias */; + const { parent: parent2 } = node; + if (parent2.kind === 312 /* SourceFile */) { + return parent2; } + Debug.assert(parent2.kind === 268 /* ModuleBlock */); + return cast(parent2.parent, isAmbientModuleDeclaration); } - function getCompletionEntriesFromSymbols(symbols, entries, replacementToken, contextToken, location, position, sourceFile, host, program, target, log, kind, preferences, compilerOptions, formatContext, isTypeOnlyLocation, propertyAccessToConvert, jsxIdentifierExpected, isJsxInitializer, importStatementCompletion, recommendedCompletion, symbolToOriginInfoMap, symbolToSortTextMap, isJsxIdentifierExpected, isRightOfOpenTag, includeSymbol = false) { - const start = timestamp(); - const variableOrParameterDeclaration = getVariableOrParameterDeclaration(contextToken, location); - const useSemicolons = probablyUsesSemicolons(sourceFile); - const typeChecker = program.getTypeChecker(); - const uniques = /* @__PURE__ */ new Map(); - for (let i = 0; i < symbols.length; i++) { - const symbol = symbols[i]; - const origin = symbolToOriginInfoMap == null ? void 0 : symbolToOriginInfoMap[i]; - const info = getCompletionEntryDisplayNameForSymbol(symbol, target, origin, kind, !!jsxIdentifierExpected); - if (!info || uniques.get(info.name) && (!origin || !originIsObjectLiteralMethod(origin)) || kind === 1 /* Global */ && symbolToSortTextMap && !shouldIncludeSymbol(symbol, symbolToSortTextMap)) { - continue; - } - const { name, needsConvertPropertyAccess } = info; - const originalSortText = (symbolToSortTextMap == null ? void 0 : symbolToSortTextMap[getSymbolId(symbol)]) ?? SortText.LocationPriority; - const sortText = isDeprecated(symbol, typeChecker) ? SortText.Deprecated(originalSortText) : originalSortText; - const entry = createCompletionEntry( - symbol, - sortText, - replacementToken, - contextToken, - location, - position, - sourceFile, - host, - program, - name, - needsConvertPropertyAccess, - origin, - recommendedCompletion, - propertyAccessToConvert, - isJsxInitializer, - importStatementCompletion, - useSemicolons, - compilerOptions, - preferences, - kind, - formatContext, - isJsxIdentifierExpected, - isRightOfOpenTag, - includeSymbol - ); - if (!entry) { - continue; - } - const shouldShadowLaterSymbols = (!origin || originIsTypeOnlyAlias(origin)) && !(symbol.parent === void 0 && !some(symbol.declarations, (d) => d.getSourceFile() === location.getSourceFile())); - uniques.set(name, shouldShadowLaterSymbols); - insertSorted( - entries, - entry, - compareCompletionEntries, - /*allowDuplicates*/ - true - ); + function isAmbientModuleDeclaration(node) { + return node.kind === 267 /* ModuleDeclaration */ && node.name.kind === 11 /* StringLiteral */; + } + function isExternalModuleImportEquals(eq) { + return eq.moduleReference.kind === 283 /* ExternalModuleReference */ && eq.moduleReference.expression.kind === 11 /* StringLiteral */; + } + var ExportKind2, ImportExport; + var init_importTracker = __esm({ + "src/services/importTracker.ts"() { + "use strict"; + init_ts4(); + ExportKind2 = /* @__PURE__ */ ((ExportKind3) => { + ExportKind3[ExportKind3["Named"] = 0] = "Named"; + ExportKind3[ExportKind3["Default"] = 1] = "Default"; + ExportKind3[ExportKind3["ExportEquals"] = 2] = "ExportEquals"; + return ExportKind3; + })(ExportKind2 || {}); + ImportExport = /* @__PURE__ */ ((ImportExport2) => { + ImportExport2[ImportExport2["Import"] = 0] = "Import"; + ImportExport2[ImportExport2["Export"] = 1] = "Export"; + return ImportExport2; + })(ImportExport || {}); } - log("getCompletionsAtPosition: getCompletionEntriesFromSymbols: " + (timestamp() - start)); + }); + + // src/services/findAllReferences.ts + function nodeEntry(node, kind = 1 /* Node */) { return { - has: (name) => uniques.has(name), - add: (name) => uniques.set(name, true) + kind, + node: node.name || node, + context: getContextNodeForNodeEntry(node) }; - function shouldIncludeSymbol(symbol, symbolToSortTextMap2) { - var _a; - let allFlags = symbol.flags; - if (!isSourceFile(location)) { - if (isExportAssignment(location.parent)) { - return true; - } - if (tryCast(variableOrParameterDeclaration, isVariableDeclaration) && symbol.valueDeclaration === variableOrParameterDeclaration) { - return false; - } - const symbolDeclaration = symbol.valueDeclaration ?? ((_a = symbol.declarations) == null ? void 0 : _a[0]); - if (variableOrParameterDeclaration && symbolDeclaration && (isTypeParameterDeclaration(variableOrParameterDeclaration) && isTypeParameterDeclaration(symbolDeclaration) || isParameter(variableOrParameterDeclaration) && isParameter(symbolDeclaration))) { - const symbolDeclarationPos = symbolDeclaration.pos; - const parameters = isParameter(variableOrParameterDeclaration) ? variableOrParameterDeclaration.parent.parameters : isInferTypeNode(variableOrParameterDeclaration.parent) ? void 0 : variableOrParameterDeclaration.parent.typeParameters; - if (symbolDeclarationPos >= variableOrParameterDeclaration.pos && parameters && symbolDeclarationPos < parameters.end) { - return false; - } - } - const symbolOrigin = skipAlias(symbol, typeChecker); - if (!!sourceFile.externalModuleIndicator && !compilerOptions.allowUmdGlobalAccess && symbolToSortTextMap2[getSymbolId(symbol)] === SortText.GlobalsOrKeywords && (symbolToSortTextMap2[getSymbolId(symbolOrigin)] === SortText.AutoImportSuggestions || symbolToSortTextMap2[getSymbolId(symbolOrigin)] === SortText.LocationPriority)) { - return false; - } - allFlags |= getCombinedLocalAndExportSymbolFlags(symbolOrigin); - if (isInRightSideOfInternalImportEqualsDeclaration(location)) { - return !!(allFlags & 1920 /* Namespace */); + } + function isContextWithStartAndEndNode(node) { + return node && node.kind === void 0; + } + function getContextNodeForNodeEntry(node) { + if (isDeclaration(node)) { + return getContextNode(node); + } + if (!node.parent) + return void 0; + if (!isDeclaration(node.parent) && !isExportAssignment(node.parent)) { + if (isInJSFile(node)) { + const binaryExpression = isBinaryExpression(node.parent) ? node.parent : isAccessExpression(node.parent) && isBinaryExpression(node.parent.parent) && node.parent.parent.left === node.parent ? node.parent.parent : void 0; + if (binaryExpression && getAssignmentDeclarationKind(binaryExpression) !== 0 /* None */) { + return getContextNode(binaryExpression); } - if (isTypeOnlyLocation) { - return symbolCanBeReferencedAtTypeLocation(symbol, typeChecker); + } + if (isJsxOpeningElement(node.parent) || isJsxClosingElement(node.parent)) { + return node.parent.parent; + } else if (isJsxSelfClosingElement(node.parent) || isLabeledStatement(node.parent) || isBreakOrContinueStatement(node.parent)) { + return node.parent; + } else if (isStringLiteralLike(node)) { + const validImport = tryGetImportFromModuleSpecifier(node); + if (validImport) { + const declOrStatement = findAncestor(validImport, (node2) => isDeclaration(node2) || isStatement(node2) || isJSDocTag(node2)); + return isDeclaration(declOrStatement) ? getContextNode(declOrStatement) : declOrStatement; } } - return !!(allFlags & 111551 /* Value */); + const propertyName = findAncestor(node, isComputedPropertyName); + return propertyName ? getContextNode(propertyName.parent) : void 0; + } + if (node.parent.name === node || // node is name of declaration, use parent + isConstructorDeclaration(node.parent) || isExportAssignment(node.parent) || // Property name of the import export specifier or binding pattern, use parent + (isImportOrExportSpecifier(node.parent) || isBindingElement(node.parent)) && node.parent.propertyName === node || // Is default export + node.kind === 90 /* DefaultKeyword */ && hasSyntacticModifier(node.parent, 2080 /* ExportDefault */)) { + return getContextNode(node.parent); } + return void 0; } - function getLabelCompletionAtPosition(node) { - const entries = getLabelStatementCompletions(node); - if (entries.length) { - return { isGlobalCompletion: false, isMemberCompletion: false, isNewIdentifierLocation: false, entries }; + function getContextNode(node) { + if (!node) + return void 0; + switch (node.kind) { + case 260 /* VariableDeclaration */: + return !isVariableDeclarationList(node.parent) || node.parent.declarations.length !== 1 ? node : isVariableStatement(node.parent.parent) ? node.parent.parent : isForInOrOfStatement(node.parent.parent) ? getContextNode(node.parent.parent) : node.parent; + case 208 /* BindingElement */: + return getContextNode(node.parent.parent); + case 276 /* ImportSpecifier */: + return node.parent.parent.parent; + case 281 /* ExportSpecifier */: + case 274 /* NamespaceImport */: + return node.parent.parent; + case 273 /* ImportClause */: + case 280 /* NamespaceExport */: + return node.parent; + case 226 /* BinaryExpression */: + return isExpressionStatement(node.parent) ? node.parent : node; + case 250 /* ForOfStatement */: + case 249 /* ForInStatement */: + return { + start: node.initializer, + end: node.expression + }; + case 303 /* PropertyAssignment */: + case 304 /* ShorthandPropertyAssignment */: + return isArrayLiteralOrObjectLiteralDestructuringPattern(node.parent) ? getContextNode( + findAncestor(node.parent, (node2) => isBinaryExpression(node2) || isForInOrOfStatement(node2)) + ) : node; + default: + return node; } } - function getLabelStatementCompletions(node) { - const entries = []; - const uniques = /* @__PURE__ */ new Map(); - let current = node; - while (current) { - if (isFunctionLike(current)) { - break; + function toContextSpan(textSpan, sourceFile, context) { + if (!context) + return void 0; + const contextSpan = isContextWithStartAndEndNode(context) ? getTextSpan(context.start, sourceFile, context.end) : getTextSpan(context, sourceFile); + return contextSpan.start !== textSpan.start || contextSpan.length !== textSpan.length ? { contextSpan } : void 0; + } + function findReferencedSymbols(program, cancellationToken, sourceFiles, sourceFile, position) { + const node = getTouchingPropertyName(sourceFile, position); + const options = { use: 1 /* References */ }; + const referencedSymbols = Core.getReferencedSymbolsForNode(position, node, program, sourceFiles, cancellationToken, options); + const checker = program.getTypeChecker(); + const adjustedNode = Core.getAdjustedNode(node, options); + const symbol = isDefinitionForReference(adjustedNode) ? checker.getSymbolAtLocation(adjustedNode) : void 0; + return !referencedSymbols || !referencedSymbols.length ? void 0 : mapDefined(referencedSymbols, ({ definition, references }) => ( + // Only include referenced symbols that have a valid definition. + definition && { + definition: checker.runWithCancellationToken(cancellationToken, (checker2) => definitionToReferencedSymbolDefinitionInfo(definition, checker2, node)), + references: references.map((r) => toReferencedSymbolEntry(r, symbol)) } - if (isLabeledStatement(current)) { - const name = current.label.text; - if (!uniques.has(name)) { - uniques.set(name, true); - entries.push({ - name, - kindModifiers: "" /* none */, - kind: "label" /* label */, - sortText: SortText.LocationPriority - }); + )); + } + function isDefinitionForReference(node) { + return node.kind === 90 /* DefaultKeyword */ || !!getDeclarationFromName(node) || isLiteralComputedPropertyDeclarationName(node) || node.kind === 137 /* ConstructorKeyword */ && isConstructorDeclaration(node.parent); + } + function getImplementationsAtPosition(program, cancellationToken, sourceFiles, sourceFile, position) { + const node = getTouchingPropertyName(sourceFile, position); + let referenceEntries; + const entries = getImplementationReferenceEntries(program, cancellationToken, sourceFiles, node, position); + if (node.parent.kind === 211 /* PropertyAccessExpression */ || node.parent.kind === 208 /* BindingElement */ || node.parent.kind === 212 /* ElementAccessExpression */ || node.kind === 108 /* SuperKeyword */) { + referenceEntries = entries && [...entries]; + } else if (entries) { + const queue = createQueue(entries); + const seenNodes = /* @__PURE__ */ new Map(); + while (!queue.isEmpty()) { + const entry = queue.dequeue(); + if (!addToSeen(seenNodes, getNodeId(entry.node))) { + continue; + } + referenceEntries = append(referenceEntries, entry); + const entries2 = getImplementationReferenceEntries(program, cancellationToken, sourceFiles, entry.node, entry.node.pos); + if (entries2) { + queue.enqueue(...entries2); } } - current = current.parent; } - return entries; + const checker = program.getTypeChecker(); + return map(referenceEntries, (entry) => toImplementationLocation(entry, checker)); } - function getSymbolCompletionFromEntryId(program, log, sourceFile, position, entryId, host, preferences) { - if (entryId.source === "SwitchCases/" /* SwitchCases */) { - return { type: "cases" }; - } - if (entryId.data) { - const autoImport = getAutoImportSymbolFromCompletionEntryData(entryId.name, entryId.data, program, host); - if (autoImport) { - const { contextToken: contextToken2, previousToken: previousToken2 } = getRelevantTokens(position, sourceFile); - return { - type: "symbol", - symbol: autoImport.symbol, - location: getTouchingPropertyName(sourceFile, position), - previousToken: previousToken2, - contextToken: contextToken2, - isJsxInitializer: false, - isTypeOnlyLocation: false, - origin: autoImport.origin - }; - } - } - const compilerOptions = program.getCompilerOptions(); - const completionData = getCompletionData( - program, - log, - sourceFile, - compilerOptions, - position, - { includeCompletionsForModuleExports: true, includeCompletionsWithInsertText: true }, - entryId, - host, - /*formatContext*/ - void 0 - ); - if (!completionData) { - return { type: "none" }; + function getImplementationReferenceEntries(program, cancellationToken, sourceFiles, node, position) { + if (node.kind === 312 /* SourceFile */) { + return void 0; } - if (completionData.kind !== 0 /* Data */) { - return { type: "request", request: completionData }; + const checker = program.getTypeChecker(); + if (node.parent.kind === 304 /* ShorthandPropertyAssignment */) { + const result = []; + Core.getReferenceEntriesForShorthandPropertyAssignment(node, checker, (node2) => result.push(nodeEntry(node2))); + return result; + } else if (node.kind === 108 /* SuperKeyword */ || isSuperProperty(node.parent)) { + const symbol = checker.getSymbolAtLocation(node); + return symbol.valueDeclaration && [nodeEntry(symbol.valueDeclaration)]; + } else { + return getReferenceEntriesForNode(position, node, program, sourceFiles, cancellationToken, { implementations: true, use: 1 /* References */ }); } - const { symbols, literals, location, completionKind, symbolToOriginInfoMap, contextToken, previousToken, isJsxInitializer, isTypeOnlyLocation } = completionData; - const literal = find(literals, (l) => completionNameForLiteral(sourceFile, preferences, l) === entryId.name); - if (literal !== void 0) - return { type: "literal", literal }; - return firstDefined(symbols, (symbol, index) => { - const origin = symbolToOriginInfoMap[index]; - const info = getCompletionEntryDisplayNameForSymbol(symbol, getEmitScriptTarget(compilerOptions), origin, completionKind, completionData.isJsxIdentifierExpected); - return info && info.name === entryId.name && (entryId.source === "ClassMemberSnippet/" /* ClassMemberSnippet */ && symbol.flags & 106500 /* ClassMember */ || entryId.source === "ObjectLiteralMethodSnippet/" /* ObjectLiteralMethodSnippet */ && symbol.flags & (4 /* Property */ | 8192 /* Method */) || getSourceFromOrigin(origin) === entryId.source) ? { type: "symbol", symbol, location, origin, contextToken, previousToken, isJsxInitializer, isTypeOnlyLocation } : void 0; - }) || { type: "none" }; } - function getCompletionEntryDetails(program, log, sourceFile, position, entryId, host, formatContext, preferences, cancellationToken) { - const typeChecker = program.getTypeChecker(); - const compilerOptions = program.getCompilerOptions(); - const { name, source, data } = entryId; - const { previousToken, contextToken } = getRelevantTokens(position, sourceFile); - if (isInString(sourceFile, position, previousToken)) { - return ts_Completions_StringCompletions_exports.getStringLiteralCompletionDetails(name, sourceFile, position, previousToken, typeChecker, compilerOptions, host, cancellationToken, preferences); - } - const symbolCompletion = getSymbolCompletionFromEntryId(program, log, sourceFile, position, entryId, host, preferences); - switch (symbolCompletion.type) { - case "request": { - const { request } = symbolCompletion; - switch (request.kind) { - case 1 /* JsDocTagName */: - return ts_JsDoc_exports.getJSDocTagNameCompletionDetails(name); - case 2 /* JsDocTag */: - return ts_JsDoc_exports.getJSDocTagCompletionDetails(name); - case 3 /* JsDocParameterName */: - return ts_JsDoc_exports.getJSDocParameterNameCompletionDetails(name); - case 4 /* Keywords */: - return some(request.keywordCompletions, (c) => c.name === name) ? createSimpleDetails(name, "keyword" /* keyword */, 5 /* keyword */) : void 0; - default: - return Debug.assertNever(request); + function findReferenceOrRenameEntries(program, cancellationToken, sourceFiles, node, position, options, convertEntry) { + return map(flattenEntries(Core.getReferencedSymbolsForNode(position, node, program, sourceFiles, cancellationToken, options)), (entry) => convertEntry(entry, node, program.getTypeChecker())); + } + function getReferenceEntriesForNode(position, node, program, sourceFiles, cancellationToken, options = {}, sourceFilesSet = new Set(sourceFiles.map((f) => f.fileName))) { + return flattenEntries(Core.getReferencedSymbolsForNode(position, node, program, sourceFiles, cancellationToken, options, sourceFilesSet)); + } + function flattenEntries(referenceSymbols) { + return referenceSymbols && flatMap(referenceSymbols, (r) => r.references); + } + function definitionToReferencedSymbolDefinitionInfo(def, checker, originalNode) { + const info = (() => { + switch (def.type) { + case 0 /* Symbol */: { + const { symbol } = def; + const { displayParts: displayParts2, kind: kind2 } = getDefinitionKindAndDisplayParts(symbol, checker, originalNode); + const name2 = displayParts2.map((p) => p.text).join(""); + const declaration = symbol.declarations && firstOrUndefined(symbol.declarations); + const node = declaration ? getNameOfDeclaration(declaration) || declaration : originalNode; + return { + ...getFileAndTextSpanFromNode(node), + name: name2, + kind: kind2, + displayParts: displayParts2, + context: getContextNode(declaration) + }; } - } - case "symbol": { - const { symbol, location, contextToken: contextToken2, origin, previousToken: previousToken2 } = symbolCompletion; - const { codeActions, sourceDisplay } = getCompletionEntryCodeActionsAndSourceDisplay(name, location, contextToken2, origin, symbol, program, host, compilerOptions, sourceFile, position, previousToken2, formatContext, preferences, data, source, cancellationToken); - const symbolName2 = originIsComputedPropertyName(origin) ? origin.symbolName : symbol.name; - return createCompletionDetailsForSymbol(symbol, symbolName2, typeChecker, sourceFile, location, cancellationToken, codeActions, sourceDisplay); - } - case "literal": { - const { literal } = symbolCompletion; - return createSimpleDetails(completionNameForLiteral(sourceFile, preferences, literal), "string" /* string */, typeof literal === "string" ? 8 /* stringLiteral */ : 7 /* numericLiteral */); - } - case "cases": { - const { entry, importAdder } = getExhaustiveCaseSnippets( - contextToken.parent, - sourceFile, - preferences, - program.getCompilerOptions(), - host, - program, - /*formatContext*/ - void 0 - ); - if (importAdder.hasFixes()) { - const changes = ts_textChanges_exports.ChangeTracker.with( - { host, formatContext, preferences }, - importAdder.writeFixes - ); + case 1 /* Label */: { + const { node } = def; + return { ...getFileAndTextSpanFromNode(node), name: node.text, kind: "label" /* label */, displayParts: [displayPart(node.text, 17 /* text */)] }; + } + case 2 /* Keyword */: { + const { node } = def; + const name2 = tokenToString(node.kind); + return { ...getFileAndTextSpanFromNode(node), name: name2, kind: "keyword" /* keyword */, displayParts: [{ text: name2, kind: "keyword" /* keyword */ }] }; + } + case 3 /* This */: { + const { node } = def; + const symbol = checker.getSymbolAtLocation(node); + const displayParts2 = symbol && ts_SymbolDisplay_exports.getSymbolDisplayPartsDocumentationAndSymbolKind( + checker, + symbol, + node.getSourceFile(), + getContainerNode(node), + node + ).displayParts || [textPart("this")]; + return { ...getFileAndTextSpanFromNode(node), name: "this", kind: "var" /* variableElement */, displayParts: displayParts2 }; + } + case 4 /* String */: { + const { node } = def; return { - name: entry.name, - kind: "" /* unknown */, - kindModifiers: "", - displayParts: [], - sourceDisplay: void 0, - codeActions: [{ - changes, - description: diagnosticToString([Diagnostics.Includes_imports_of_types_referenced_by_0, name]) - }] + ...getFileAndTextSpanFromNode(node), + name: node.text, + kind: "var" /* variableElement */, + displayParts: [displayPart(getTextOfNode(node), 8 /* stringLiteral */)] }; } - return { - name: entry.name, - kind: "" /* unknown */, - kindModifiers: "", - displayParts: [], - sourceDisplay: void 0 - }; + case 5 /* TripleSlashReference */: { + return { + textSpan: createTextSpanFromRange(def.reference), + sourceFile: def.file, + name: def.reference.fileName, + kind: "string" /* string */, + displayParts: [displayPart(`"${def.reference.fileName}"`, 8 /* stringLiteral */)] + }; + } + default: + return Debug.assertNever(def); } - case "none": - return allKeywordsCompletions().some((c) => c.name === name) ? createSimpleDetails(name, "keyword" /* keyword */, 5 /* keyword */) : void 0; - default: - Debug.assertNever(symbolCompletion); - } + })(); + const { sourceFile, textSpan, name, kind, displayParts, context } = info; + return { + containerKind: "" /* unknown */, + containerName: "", + fileName: sourceFile.fileName, + kind, + name, + textSpan, + displayParts, + ...toContextSpan(textSpan, sourceFile, context) + }; } - function createSimpleDetails(name, kind, kind2) { - return createCompletionDetails(name, "" /* none */, kind, [displayPart(name, kind2)]); + function getFileAndTextSpanFromNode(node) { + const sourceFile = node.getSourceFile(); + return { + sourceFile, + textSpan: getTextSpan(isComputedPropertyName(node) ? node.expression : node, sourceFile) + }; } - function createCompletionDetailsForSymbol(symbol, name, checker, sourceFile, location, cancellationToken, codeActions, sourceDisplay) { - const { displayParts, documentation, symbolKind, tags } = checker.runWithCancellationToken( - cancellationToken, - (checker2) => ts_SymbolDisplay_exports.getSymbolDisplayPartsDocumentationAndSymbolKind(checker2, symbol, sourceFile, location, location, 7 /* All */) - ); - return createCompletionDetails(name, ts_SymbolDisplay_exports.getSymbolModifiers(checker, symbol), symbolKind, displayParts, documentation, tags, codeActions, sourceDisplay); + function getDefinitionKindAndDisplayParts(symbol, checker, node) { + const meaning = Core.getIntersectingMeaningFromDeclarations(node, symbol); + const enclosingDeclaration = symbol.declarations && firstOrUndefined(symbol.declarations) || node; + const { displayParts, symbolKind } = ts_SymbolDisplay_exports.getSymbolDisplayPartsDocumentationAndSymbolKind(checker, symbol, enclosingDeclaration.getSourceFile(), enclosingDeclaration, enclosingDeclaration, meaning); + return { displayParts, kind: symbolKind }; } - function createCompletionDetails(name, kindModifiers, kind, displayParts, documentation, tags, codeActions, source) { - return { name, kindModifiers, kind, displayParts, documentation, tags, codeActions, source, sourceDisplay: source }; + function toRenameLocation(entry, originalNode, checker, providePrefixAndSuffixText, quotePreference) { + return { ...entryToDocumentSpan(entry), ...providePrefixAndSuffixText && getPrefixAndSuffixText(entry, originalNode, checker, quotePreference) }; } - function getCompletionEntryCodeActionsAndSourceDisplay(name, location, contextToken, origin, symbol, program, host, compilerOptions, sourceFile, position, previousToken, formatContext, preferences, data, source, cancellationToken) { - if (data == null ? void 0 : data.moduleSpecifier) { - if (previousToken && getImportStatementCompletionInfo(contextToken || previousToken).replacementSpan) { - return { codeActions: void 0, sourceDisplay: [textPart(data.moduleSpecifier)] }; - } + function toReferencedSymbolEntry(entry, symbol) { + const referenceEntry = toReferenceEntry(entry); + if (!symbol) + return referenceEntry; + return { + ...referenceEntry, + isDefinition: entry.kind !== 0 /* Span */ && isDeclarationOfSymbol(entry.node, symbol) + }; + } + function toReferenceEntry(entry) { + const documentSpan = entryToDocumentSpan(entry); + if (entry.kind === 0 /* Span */) { + return { ...documentSpan, isWriteAccess: false }; } - if (source === "ClassMemberSnippet/" /* ClassMemberSnippet */) { - const { importAdder } = getEntryForMemberCompletion( - host, - program, - compilerOptions, - preferences, - name, - symbol, - location, - position, - contextToken, - formatContext - ); - if (importAdder) { - const changes = ts_textChanges_exports.ChangeTracker.with( - { host, formatContext, preferences }, - importAdder.writeFixes - ); - return { - sourceDisplay: void 0, - codeActions: [{ - changes, - description: diagnosticToString([Diagnostics.Includes_imports_of_types_referenced_by_0, name]) - }] - }; - } + const { kind, node } = entry; + return { + ...documentSpan, + isWriteAccess: isWriteAccessForReference(node), + isInString: kind === 2 /* StringLiteral */ ? true : void 0 + }; + } + function entryToDocumentSpan(entry) { + if (entry.kind === 0 /* Span */) { + return { textSpan: entry.textSpan, fileName: entry.fileName }; + } else { + const sourceFile = entry.node.getSourceFile(); + const textSpan = getTextSpan(entry.node, sourceFile); + return { + textSpan, + fileName: sourceFile.fileName, + ...toContextSpan(textSpan, sourceFile, entry.context) + }; } - if (originIsTypeOnlyAlias(origin)) { - const codeAction2 = ts_codefix_exports.getPromoteTypeOnlyCompletionAction( - sourceFile, - origin.declaration.name, - program, - host, - formatContext, - preferences - ); - Debug.assertIsDefined(codeAction2, "Expected to have a code action for promoting type-only alias"); - return { codeActions: [codeAction2], sourceDisplay: void 0 }; + } + function getPrefixAndSuffixText(entry, originalNode, checker, quotePreference) { + if (entry.kind !== 0 /* Span */ && isIdentifier(originalNode)) { + const { node, kind } = entry; + const parent2 = node.parent; + const name = originalNode.text; + const isShorthandAssignment = isShorthandPropertyAssignment(parent2); + if (isShorthandAssignment || isObjectBindingElementWithoutPropertyName(parent2) && parent2.name === node && parent2.dotDotDotToken === void 0) { + const prefixColon = { prefixText: name + ": " }; + const suffixColon = { suffixText: ": " + name }; + if (kind === 3 /* SearchedLocalFoundProperty */) { + return prefixColon; + } + if (kind === 4 /* SearchedPropertyFoundLocal */) { + return suffixColon; + } + if (isShorthandAssignment) { + const grandParent = parent2.parent; + if (isObjectLiteralExpression(grandParent) && isBinaryExpression(grandParent.parent) && isModuleExportsAccessExpression(grandParent.parent.left)) { + return prefixColon; + } + return suffixColon; + } else { + return prefixColon; + } + } else if (isImportSpecifier(parent2) && !parent2.propertyName) { + const originalSymbol = isExportSpecifier(originalNode.parent) ? checker.getExportSpecifierLocalTargetSymbol(originalNode.parent) : checker.getSymbolAtLocation(originalNode); + return contains(originalSymbol.declarations, parent2) ? { prefixText: name + " as " } : emptyOptions; + } else if (isExportSpecifier(parent2) && !parent2.propertyName) { + return originalNode === entry.node || checker.getSymbolAtLocation(originalNode) === checker.getSymbolAtLocation(entry.node) ? { prefixText: name + " as " } : { suffixText: " as " + name }; + } } - if (!origin || !(originIsExport(origin) || originIsResolvedExport(origin))) { - return { codeActions: void 0, sourceDisplay: void 0 }; + if (entry.kind !== 0 /* Span */ && isNumericLiteral(entry.node) && isAccessExpression(entry.node.parent)) { + const quote2 = getQuoteFromPreference(quotePreference); + return { prefixText: quote2, suffixText: quote2 }; } - const checker = origin.isFromPackageJson ? host.getPackageJsonAutoImportProvider().getTypeChecker() : program.getTypeChecker(); - const { moduleSymbol } = origin; - const targetSymbol = checker.getMergedSymbol(skipAlias(symbol.exportSymbol || symbol, checker)); - const isJsxOpeningTagName = (contextToken == null ? void 0 : contextToken.kind) === 30 /* LessThanToken */ && isJsxOpeningLikeElement(contextToken.parent); - const { moduleSpecifier, codeAction } = ts_codefix_exports.getImportCompletionAction( - targetSymbol, - moduleSymbol, - data == null ? void 0 : data.exportMapKey, - sourceFile, - name, - isJsxOpeningTagName, - host, - program, - formatContext, - previousToken && isIdentifier(previousToken) ? previousToken.getStart(sourceFile) : position, - preferences, - cancellationToken - ); - Debug.assert(!(data == null ? void 0 : data.moduleSpecifier) || moduleSpecifier === data.moduleSpecifier); - return { sourceDisplay: [textPart(moduleSpecifier)], codeActions: [codeAction] }; + return emptyOptions; } - function getCompletionEntrySymbol(program, log, sourceFile, position, entryId, host, preferences) { - const completion = getSymbolCompletionFromEntryId(program, log, sourceFile, position, entryId, host, preferences); - return completion.type === "symbol" ? completion.symbol : void 0; + function toImplementationLocation(entry, checker) { + const documentSpan = entryToDocumentSpan(entry); + if (entry.kind !== 0 /* Span */) { + const { node } = entry; + return { + ...documentSpan, + ...implementationKindDisplayParts(node, checker) + }; + } else { + return { ...documentSpan, kind: "" /* unknown */, displayParts: [] }; + } } - function getRecommendedCompletion(previousToken, contextualType, checker) { - return firstDefined(contextualType && (contextualType.isUnion() ? contextualType.types : [contextualType]), (type) => { - const symbol = type && type.symbol; - return symbol && (symbol.flags & (8 /* EnumMember */ | 384 /* Enum */ | 32 /* Class */) && !isAbstractConstructorSymbol(symbol)) ? getFirstSymbolInChain(symbol, previousToken, checker) : void 0; - }); + function implementationKindDisplayParts(node, checker) { + const symbol = checker.getSymbolAtLocation(isDeclaration(node) && node.name ? node.name : node); + if (symbol) { + return getDefinitionKindAndDisplayParts(symbol, checker, node); + } else if (node.kind === 210 /* ObjectLiteralExpression */) { + return { + kind: "interface" /* interfaceElement */, + displayParts: [punctuationPart(21 /* OpenParenToken */), textPart("object literal"), punctuationPart(22 /* CloseParenToken */)] + }; + } else if (node.kind === 231 /* ClassExpression */) { + return { + kind: "local class" /* localClassElement */, + displayParts: [punctuationPart(21 /* OpenParenToken */), textPart("anonymous local class"), punctuationPart(22 /* CloseParenToken */)] + }; + } else { + return { kind: getNodeKind(node), displayParts: [] }; + } } - function getContextualType(previousToken, position, sourceFile, checker) { - const { parent: parent2 } = previousToken; - switch (previousToken.kind) { - case 80 /* Identifier */: - return getContextualTypeFromParent(previousToken, checker); - case 64 /* EqualsToken */: - switch (parent2.kind) { - case 259 /* VariableDeclaration */: - return checker.getContextualType(parent2.initializer); - case 225 /* BinaryExpression */: - return checker.getTypeAtLocation(parent2.left); - case 290 /* JsxAttribute */: - return checker.getContextualTypeForJsxAttribute(parent2); - default: - return void 0; + function toHighlightSpan(entry) { + const documentSpan = entryToDocumentSpan(entry); + if (entry.kind === 0 /* Span */) { + return { + fileName: documentSpan.fileName, + span: { + textSpan: documentSpan.textSpan, + kind: "reference" /* reference */ } - case 105 /* NewKeyword */: - return checker.getContextualType(parent2); - case 84 /* CaseKeyword */: - const caseClause = tryCast(parent2, isCaseClause); - return caseClause ? getSwitchedType(caseClause, checker) : void 0; - case 19 /* OpenBraceToken */: - return isJsxExpression(parent2) && !isJsxElement(parent2.parent) && !isJsxFragment(parent2.parent) ? checker.getContextualTypeForJsxAttribute(parent2.parent) : void 0; - default: - const argInfo = ts_SignatureHelp_exports.getArgumentInfoForCompletions(previousToken, position, sourceFile); - return argInfo ? ( - // At `,`, treat this as the next argument after the comma. - checker.getContextualTypeForArgumentAtIndex(argInfo.invocation, argInfo.argumentIndex + (previousToken.kind === 28 /* CommaToken */ ? 1 : 0)) - ) : isEqualityOperatorKind(previousToken.kind) && isBinaryExpression(parent2) && isEqualityOperatorKind(parent2.operatorToken.kind) ? ( - // completion at `x ===/**/` should be for the right side - checker.getTypeAtLocation(parent2.left) - ) : checker.getContextualType(previousToken, 4 /* Completions */) || checker.getContextualType(previousToken); + }; + } + const writeAccess = isWriteAccessForReference(entry.node); + const span = { + textSpan: documentSpan.textSpan, + kind: writeAccess ? "writtenReference" /* writtenReference */ : "reference" /* reference */, + isInString: entry.kind === 2 /* StringLiteral */ ? true : void 0, + ...documentSpan.contextSpan && { contextSpan: documentSpan.contextSpan } + }; + return { fileName: documentSpan.fileName, span }; + } + function getTextSpan(node, sourceFile, endNode2) { + let start = node.getStart(sourceFile); + let end = (endNode2 || node).getEnd(); + if (isStringLiteralLike(node) && end - start > 2) { + Debug.assert(endNode2 === void 0); + start += 1; + end -= 1; } + return createTextSpanFromBounds(start, end); } - function getFirstSymbolInChain(symbol, enclosingDeclaration, checker) { - const chain = checker.getAccessibleSymbolChain( - symbol, - enclosingDeclaration, - /*meaning*/ - 67108863 /* All */, - /*useOnlyExternalAliasing*/ - false - ); - if (chain) - return first(chain); - return symbol.parent && (isModuleSymbol(symbol.parent) ? symbol : getFirstSymbolInChain(symbol.parent, enclosingDeclaration, checker)); + function getTextSpanOfEntry(entry) { + return entry.kind === 0 /* Span */ ? entry.textSpan : getTextSpan(entry.node, entry.node.getSourceFile()); } - function isModuleSymbol(symbol) { + function isWriteAccessForReference(node) { + const decl = getDeclarationFromName(node); + return !!decl && declarationIsWriteAccess(decl) || node.kind === 90 /* DefaultKeyword */ || isWriteAccess(node); + } + function isDeclarationOfSymbol(node, target) { var _a; - return !!((_a = symbol.declarations) == null ? void 0 : _a.some((d) => d.kind === 311 /* SourceFile */)); + if (!target) + return false; + const source = getDeclarationFromName(node) || (node.kind === 90 /* DefaultKeyword */ ? node.parent : isLiteralComputedPropertyDeclarationName(node) ? node.parent.parent : node.kind === 137 /* ConstructorKeyword */ && isConstructorDeclaration(node.parent) ? node.parent.parent : void 0); + const commonjsSource = source && isBinaryExpression(source) ? source.left : void 0; + return !!(source && ((_a = target.declarations) == null ? void 0 : _a.some((d) => d === source || d === commonjsSource))); } - function getCompletionData(program, log, sourceFile, compilerOptions, position, preferences, detailsEntryId, host, formatContext, cancellationToken) { - const typeChecker = program.getTypeChecker(); - const inCheckedFile = isCheckedFile(sourceFile, compilerOptions); - let start = timestamp(); - let currentToken = getTokenAtPosition(sourceFile, position); - log("getCompletionData: Get current token: " + (timestamp() - start)); - start = timestamp(); - const insideComment = isInComment(sourceFile, position, currentToken); - log("getCompletionData: Is inside comment: " + (timestamp() - start)); - let insideJsDocTagTypeExpression = false; - let isInSnippetScope = false; - if (insideComment) { - if (hasDocComment(sourceFile, position)) { - if (sourceFile.text.charCodeAt(position - 1) === 64 /* at */) { - return { kind: 1 /* JsDocTagName */ }; - } else { - const lineStart = getLineStartPositionForPosition(position, sourceFile); - if (!/[^\*|\s(/)]/.test(sourceFile.text.substring(lineStart, position))) { - return { kind: 2 /* JsDocTag */ }; + function declarationIsWriteAccess(decl) { + if (!!(decl.flags & 33554432 /* Ambient */)) + return true; + switch (decl.kind) { + case 226 /* BinaryExpression */: + case 208 /* BindingElement */: + case 263 /* ClassDeclaration */: + case 231 /* ClassExpression */: + case 90 /* DefaultKeyword */: + case 266 /* EnumDeclaration */: + case 306 /* EnumMember */: + case 281 /* ExportSpecifier */: + case 273 /* ImportClause */: + case 271 /* ImportEqualsDeclaration */: + case 276 /* ImportSpecifier */: + case 264 /* InterfaceDeclaration */: + case 345 /* JSDocCallbackTag */: + case 353 /* JSDocTypedefTag */: + case 291 /* JsxAttribute */: + case 267 /* ModuleDeclaration */: + case 270 /* NamespaceExportDeclaration */: + case 274 /* NamespaceImport */: + case 280 /* NamespaceExport */: + case 169 /* Parameter */: + case 304 /* ShorthandPropertyAssignment */: + case 265 /* TypeAliasDeclaration */: + case 168 /* TypeParameter */: + return true; + case 303 /* PropertyAssignment */: + return !isArrayLiteralOrObjectLiteralDestructuringPattern(decl.parent); + case 262 /* FunctionDeclaration */: + case 218 /* FunctionExpression */: + case 176 /* Constructor */: + case 174 /* MethodDeclaration */: + case 177 /* GetAccessor */: + case 178 /* SetAccessor */: + return !!decl.body; + case 260 /* VariableDeclaration */: + case 172 /* PropertyDeclaration */: + return !!decl.initializer || isCatchClause(decl.parent); + case 173 /* MethodSignature */: + case 171 /* PropertySignature */: + case 355 /* JSDocPropertyTag */: + case 348 /* JSDocParameterTag */: + return false; + default: + return Debug.failBadSyntaxKind(decl); + } + } + var DefinitionKind, EntryKind, FindReferencesUse, Core; + var init_findAllReferences = __esm({ + "src/services/findAllReferences.ts"() { + "use strict"; + init_ts4(); + init_ts_FindAllReferences(); + DefinitionKind = /* @__PURE__ */ ((DefinitionKind2) => { + DefinitionKind2[DefinitionKind2["Symbol"] = 0] = "Symbol"; + DefinitionKind2[DefinitionKind2["Label"] = 1] = "Label"; + DefinitionKind2[DefinitionKind2["Keyword"] = 2] = "Keyword"; + DefinitionKind2[DefinitionKind2["This"] = 3] = "This"; + DefinitionKind2[DefinitionKind2["String"] = 4] = "String"; + DefinitionKind2[DefinitionKind2["TripleSlashReference"] = 5] = "TripleSlashReference"; + return DefinitionKind2; + })(DefinitionKind || {}); + EntryKind = /* @__PURE__ */ ((EntryKind2) => { + EntryKind2[EntryKind2["Span"] = 0] = "Span"; + EntryKind2[EntryKind2["Node"] = 1] = "Node"; + EntryKind2[EntryKind2["StringLiteral"] = 2] = "StringLiteral"; + EntryKind2[EntryKind2["SearchedLocalFoundProperty"] = 3] = "SearchedLocalFoundProperty"; + EntryKind2[EntryKind2["SearchedPropertyFoundLocal"] = 4] = "SearchedPropertyFoundLocal"; + return EntryKind2; + })(EntryKind || {}); + FindReferencesUse = /* @__PURE__ */ ((FindReferencesUse2) => { + FindReferencesUse2[FindReferencesUse2["Other"] = 0] = "Other"; + FindReferencesUse2[FindReferencesUse2["References"] = 1] = "References"; + FindReferencesUse2[FindReferencesUse2["Rename"] = 2] = "Rename"; + return FindReferencesUse2; + })(FindReferencesUse || {}); + ((Core2) => { + function getReferencedSymbolsForNode(position, node, program, sourceFiles, cancellationToken, options = {}, sourceFilesSet = new Set(sourceFiles.map((f) => f.fileName))) { + var _a, _b; + node = getAdjustedNode2(node, options); + if (isSourceFile(node)) { + const resolvedRef = ts_GoToDefinition_exports.getReferenceAtPosition(node, position, program); + if (!(resolvedRef == null ? void 0 : resolvedRef.file)) { + return void 0; + } + const moduleSymbol = program.getTypeChecker().getMergedSymbol(resolvedRef.file.symbol); + if (moduleSymbol) { + return getReferencedSymbolsForModule( + program, + moduleSymbol, + /*excludeImportTypeOfExportEquals*/ + false, + sourceFiles, + sourceFilesSet + ); + } + const fileIncludeReasons = program.getFileIncludeReasons(); + if (!fileIncludeReasons) { + return void 0; + } + return [{ + definition: { type: 5 /* TripleSlashReference */, reference: resolvedRef.reference, file: node }, + references: getReferencesForNonModule(resolvedRef.file, fileIncludeReasons, program) || emptyArray + }]; + } + if (!options.implementations) { + const special = getReferencedSymbolsSpecial(node, sourceFiles, cancellationToken); + if (special) { + return special; + } + } + const checker = program.getTypeChecker(); + const symbol = checker.getSymbolAtLocation(isConstructorDeclaration(node) && node.parent.name || node); + if (!symbol) { + if (!options.implementations && isStringLiteralLike(node)) { + if (isModuleSpecifierLike(node)) { + const fileIncludeReasons = program.getFileIncludeReasons(); + const referencedFileName = (_b = (_a = program.getResolvedModule(node.getSourceFile(), node.text, getModeForUsageLocation(node.getSourceFile(), node))) == null ? void 0 : _a.resolvedModule) == null ? void 0 : _b.resolvedFileName; + const referencedFile = referencedFileName ? program.getSourceFile(referencedFileName) : void 0; + if (referencedFile) { + return [{ definition: { type: 4 /* String */, node }, references: getReferencesForNonModule(referencedFile, fileIncludeReasons, program) || emptyArray }]; + } + } + return getReferencesForStringLiteral(node, sourceFiles, checker, cancellationToken); + } + return void 0; + } + if (symbol.escapedName === "export=" /* ExportEquals */) { + return getReferencedSymbolsForModule( + program, + symbol.parent, + /*excludeImportTypeOfExportEquals*/ + false, + sourceFiles, + sourceFilesSet + ); + } + const moduleReferences = getReferencedSymbolsForModuleIfDeclaredBySourceFile(symbol, program, sourceFiles, cancellationToken, options, sourceFilesSet); + if (moduleReferences && !(symbol.flags & 33554432 /* Transient */)) { + return moduleReferences; + } + const aliasedSymbol = getMergedAliasedSymbolOfNamespaceExportDeclaration(node, symbol, checker); + const moduleReferencesOfExportTarget = aliasedSymbol && getReferencedSymbolsForModuleIfDeclaredBySourceFile(aliasedSymbol, program, sourceFiles, cancellationToken, options, sourceFilesSet); + const references = getReferencedSymbolsForSymbol(symbol, node, sourceFiles, sourceFilesSet, checker, cancellationToken, options); + return mergeReferences(program, moduleReferences, references, moduleReferencesOfExportTarget); + } + Core2.getReferencedSymbolsForNode = getReferencedSymbolsForNode; + function getAdjustedNode2(node, options) { + if (options.use === 1 /* References */) { + node = getAdjustedReferenceLocation(node); + } else if (options.use === 2 /* Rename */) { + node = getAdjustedRenameLocation(node); + } + return node; + } + Core2.getAdjustedNode = getAdjustedNode2; + function getReferencesForFileName(fileName, program, sourceFiles, sourceFilesSet = new Set(sourceFiles.map((f) => f.fileName))) { + var _a, _b; + const moduleSymbol = (_a = program.getSourceFile(fileName)) == null ? void 0 : _a.symbol; + if (moduleSymbol) { + return ((_b = getReferencedSymbolsForModule( + program, + moduleSymbol, + /*excludeImportTypeOfExportEquals*/ + false, + sourceFiles, + sourceFilesSet + )[0]) == null ? void 0 : _b.references) || emptyArray; + } + const fileIncludeReasons = program.getFileIncludeReasons(); + const referencedFile = program.getSourceFile(fileName); + return referencedFile && fileIncludeReasons && getReferencesForNonModule(referencedFile, fileIncludeReasons, program) || emptyArray; + } + Core2.getReferencesForFileName = getReferencesForFileName; + function getReferencesForNonModule(referencedFile, refFileMap, program) { + let entries; + const references = refFileMap.get(referencedFile.path) || emptyArray; + for (const ref of references) { + if (isReferencedFile(ref)) { + const referencingFile = program.getSourceFileByPath(ref.file); + const location = getReferencedFileLocation(program, ref); + if (isReferenceFileLocation(location)) { + entries = append(entries, { + kind: 0 /* Span */, + fileName: referencingFile.fileName, + textSpan: createTextSpanFromRange(location) + }); + } + } + } + return entries; + } + function getMergedAliasedSymbolOfNamespaceExportDeclaration(node, symbol, checker) { + if (node.parent && isNamespaceExportDeclaration(node.parent)) { + const aliasedSymbol = checker.getAliasedSymbol(symbol); + const targetSymbol = checker.getMergedSymbol(aliasedSymbol); + if (aliasedSymbol !== targetSymbol) { + return targetSymbol; + } + } + return void 0; + } + function getReferencedSymbolsForModuleIfDeclaredBySourceFile(symbol, program, sourceFiles, cancellationToken, options, sourceFilesSet) { + const moduleSourceFile = symbol.flags & 1536 /* Module */ && symbol.declarations && find(symbol.declarations, isSourceFile); + if (!moduleSourceFile) + return void 0; + const exportEquals = symbol.exports.get("export=" /* ExportEquals */); + const moduleReferences = getReferencedSymbolsForModule(program, symbol, !!exportEquals, sourceFiles, sourceFilesSet); + if (!exportEquals || !sourceFilesSet.has(moduleSourceFile.fileName)) + return moduleReferences; + const checker = program.getTypeChecker(); + symbol = skipAlias(exportEquals, checker); + return mergeReferences(program, moduleReferences, getReferencedSymbolsForSymbol( + symbol, + /*node*/ + void 0, + sourceFiles, + sourceFilesSet, + checker, + cancellationToken, + options + )); + } + function mergeReferences(program, ...referencesToMerge) { + let result; + for (const references of referencesToMerge) { + if (!references || !references.length) + continue; + if (!result) { + result = references; + continue; + } + for (const entry of references) { + if (!entry.definition || entry.definition.type !== 0 /* Symbol */) { + result.push(entry); + continue; + } + const symbol = entry.definition.symbol; + const refIndex = findIndex(result, (ref) => !!ref.definition && ref.definition.type === 0 /* Symbol */ && ref.definition.symbol === symbol); + if (refIndex === -1) { + result.push(entry); + continue; + } + const reference = result[refIndex]; + result[refIndex] = { + definition: reference.definition, + references: reference.references.concat(entry.references).sort((entry1, entry2) => { + const entry1File = getSourceFileIndexOfEntry(program, entry1); + const entry2File = getSourceFileIndexOfEntry(program, entry2); + if (entry1File !== entry2File) { + return compareValues(entry1File, entry2File); + } + const entry1Span = getTextSpanOfEntry(entry1); + const entry2Span = getTextSpanOfEntry(entry2); + return entry1Span.start !== entry2Span.start ? compareValues(entry1Span.start, entry2Span.start) : compareValues(entry1Span.length, entry2Span.length); + }) + }; + } + } + return result; + } + function getSourceFileIndexOfEntry(program, entry) { + const sourceFile = entry.kind === 0 /* Span */ ? program.getSourceFile(entry.fileName) : entry.node.getSourceFile(); + return program.getSourceFiles().indexOf(sourceFile); + } + function getReferencedSymbolsForModule(program, symbol, excludeImportTypeOfExportEquals, sourceFiles, sourceFilesSet) { + Debug.assert(!!symbol.valueDeclaration); + const references = mapDefined(findModuleReferences(program, sourceFiles, symbol), (reference) => { + if (reference.kind === "import") { + const parent2 = reference.literal.parent; + if (isLiteralTypeNode(parent2)) { + const importType = cast(parent2.parent, isImportTypeNode); + if (excludeImportTypeOfExportEquals && !importType.qualifier) { + return void 0; + } + } + return nodeEntry(reference.literal); + } else if (reference.kind === "implicit") { + const range = reference.literal.text !== externalHelpersModuleNameText && forEachChildRecursively( + reference.referencingFile, + (n) => !(n.transformFlags & 2 /* ContainsJsx */) ? "skip" : isJsxElement(n) || isJsxSelfClosingElement(n) || isJsxFragment(n) ? n : void 0 + ) || reference.referencingFile.statements[0] || reference.referencingFile; + return nodeEntry(range); + } else { + return { + kind: 0 /* Span */, + fileName: reference.referencingFile.fileName, + textSpan: createTextSpanFromRange(reference.ref) + }; + } + }); + if (symbol.declarations) { + for (const decl of symbol.declarations) { + switch (decl.kind) { + case 312 /* SourceFile */: + break; + case 267 /* ModuleDeclaration */: + if (sourceFilesSet.has(decl.getSourceFile().fileName)) { + references.push(nodeEntry(decl.name)); + } + break; + default: + Debug.assert(!!(symbol.flags & 33554432 /* Transient */), "Expected a module symbol to be declared by a SourceFile or ModuleDeclaration."); + } + } + } + const exported = symbol.exports.get("export=" /* ExportEquals */); + if (exported == null ? void 0 : exported.declarations) { + for (const decl of exported.declarations) { + const sourceFile = decl.getSourceFile(); + if (sourceFilesSet.has(sourceFile.fileName)) { + const node = isBinaryExpression(decl) && isPropertyAccessExpression(decl.left) ? decl.left.expression : isExportAssignment(decl) ? Debug.checkDefined(findChildOfKind(decl, 95 /* ExportKeyword */, sourceFile)) : getNameOfDeclaration(decl) || decl; + references.push(nodeEntry(node)); + } + } } + return references.length ? [{ definition: { type: 0 /* Symbol */, symbol }, references }] : emptyArray; } - } - const tag = getJsDocTagAtPosition(currentToken, position); - if (tag) { - if (tag.tagName.pos <= position && position <= tag.tagName.end) { - return { kind: 1 /* JsDocTagName */ }; + function isReadonlyTypeOperator(node) { + return node.kind === 148 /* ReadonlyKeyword */ && isTypeOperatorNode(node.parent) && node.parent.operator === 148 /* ReadonlyKeyword */; } - const typeExpression = tryGetTypeExpressionFromTag(tag); - if (typeExpression) { - currentToken = getTokenAtPosition(sourceFile, position); - if (!currentToken || !isDeclarationName(currentToken) && (currentToken.parent.kind !== 354 /* JSDocPropertyTag */ || currentToken.parent.name !== currentToken)) { - insideJsDocTagTypeExpression = isCurrentlyEditingNode(typeExpression); + function getReferencedSymbolsSpecial(node, sourceFiles, cancellationToken) { + if (isTypeKeyword(node.kind)) { + if (node.kind === 116 /* VoidKeyword */ && isVoidExpression(node.parent)) { + return void 0; + } + if (node.kind === 148 /* ReadonlyKeyword */ && !isReadonlyTypeOperator(node)) { + return void 0; + } + return getAllReferencesForKeyword( + sourceFiles, + node.kind, + cancellationToken, + node.kind === 148 /* ReadonlyKeyword */ ? isReadonlyTypeOperator : void 0 + ); + } + if (isImportMeta(node.parent) && node.parent.name === node) { + return getAllReferencesForImportMeta(sourceFiles, cancellationToken); + } + if (isStaticModifier(node) && isClassStaticBlockDeclaration(node.parent)) { + return [{ definition: { type: 2 /* Keyword */, node }, references: [nodeEntry(node)] }]; } + if (isJumpStatementTarget(node)) { + const labelDefinition = getTargetLabel(node.parent, node.text); + return labelDefinition && getLabelReferencesInNode(labelDefinition.parent, labelDefinition); + } else if (isLabelOfLabeledStatement(node)) { + return getLabelReferencesInNode(node.parent, node); + } + if (isThis(node)) { + return getReferencesForThisKeyword(node, sourceFiles, cancellationToken); + } + if (node.kind === 108 /* SuperKeyword */) { + return getReferencesForSuperKeyword(node); + } + return void 0; } - if (!insideJsDocTagTypeExpression && isJSDocParameterTag(tag) && (nodeIsMissing(tag.name) || tag.name.pos <= position && position <= tag.name.end)) { - return { kind: 3 /* JsDocParameterName */, tag }; + function getReferencedSymbolsForSymbol(originalSymbol, node, sourceFiles, sourceFilesSet, checker, cancellationToken, options) { + const symbol = node && skipPastExportOrImportSpecifierOrUnion( + originalSymbol, + node, + checker, + /*useLocalSymbolForExportSpecifier*/ + !isForRenameWithPrefixAndSuffixText(options) + ) || originalSymbol; + const searchMeaning = node ? getIntersectingMeaningFromDeclarations(node, symbol) : 7 /* All */; + const result = []; + const state = new State(sourceFiles, sourceFilesSet, node ? getSpecialSearchKind(node) : 0 /* None */, checker, cancellationToken, searchMeaning, options, result); + const exportSpecifier = !isForRenameWithPrefixAndSuffixText(options) || !symbol.declarations ? void 0 : find(symbol.declarations, isExportSpecifier); + if (exportSpecifier) { + getReferencesAtExportSpecifier( + exportSpecifier.name, + symbol, + exportSpecifier, + state.createSearch( + node, + originalSymbol, + /*comingFrom*/ + void 0 + ), + state, + /*addReferencesHere*/ + true, + /*alwaysGetReferences*/ + true + ); + } else if (node && node.kind === 90 /* DefaultKeyword */ && symbol.escapedName === "default" /* Default */ && symbol.parent) { + addReference(node, symbol, state); + searchForImportsOfExport(node, symbol, { exportingModuleSymbol: symbol.parent, exportKind: 1 /* Default */ }, state); + } else { + const search = state.createSearch( + node, + symbol, + /*comingFrom*/ + void 0, + { allSearchSymbols: node ? populateSearchSymbolSet(symbol, node, checker, options.use === 2 /* Rename */, !!options.providePrefixAndSuffixTextForRename, !!options.implementations) : [symbol] } + ); + getReferencesInContainerOrFiles(symbol, state, search); + } + return result; } - } - if (!insideJsDocTagTypeExpression) { - log("Returning an empty list because completion was inside a regular comment or plain text part of a JsDoc comment."); - return void 0; - } - } - start = timestamp(); - const isJsOnlyLocation = !insideJsDocTagTypeExpression && isSourceFileJS(sourceFile); - const tokens = getRelevantTokens(position, sourceFile); - const previousToken = tokens.previousToken; - let contextToken = tokens.contextToken; - log("getCompletionData: Get previous token: " + (timestamp() - start)); - let node = currentToken; - let propertyAccessToConvert; - let isRightOfDot = false; - let isRightOfQuestionDot = false; - let isRightOfOpenTag = false; - let isStartingCloseTag = false; - let isJsxInitializer = false; - let isJsxIdentifierExpected = false; - let importStatementCompletion; - let location = getTouchingPropertyName(sourceFile, position); - let keywordFilters = 0 /* None */; - let isNewIdentifierLocation = false; - let flags = 0 /* None */; - if (contextToken) { - const importStatementCompletionInfo = getImportStatementCompletionInfo(contextToken); - if (importStatementCompletionInfo.keywordCompletion) { - if (importStatementCompletionInfo.isKeywordOnlyCompletion) { - return { - kind: 4 /* Keywords */, - keywordCompletions: [keywordToCompletionEntry(importStatementCompletionInfo.keywordCompletion)], - isNewIdentifierLocation: importStatementCompletionInfo.isNewIdentifierLocation - }; + function getReferencesInContainerOrFiles(symbol, state, search) { + const scope = getSymbolScope(symbol); + if (scope) { + getReferencesInContainer( + scope, + scope.getSourceFile(), + search, + state, + /*addReferencesHere*/ + !(isSourceFile(scope) && !contains(state.sourceFiles, scope)) + ); + } else { + for (const sourceFile of state.sourceFiles) { + state.cancellationToken.throwIfCancellationRequested(); + searchForName(sourceFile, search, state); + } + } } - keywordFilters = keywordFiltersFromSyntaxKind(importStatementCompletionInfo.keywordCompletion); - } - if (importStatementCompletionInfo.replacementSpan && preferences.includeCompletionsForImportStatements && preferences.includeCompletionsWithInsertText) { - flags |= 2 /* IsImportStatementCompletion */; - importStatementCompletion = importStatementCompletionInfo; - isNewIdentifierLocation = importStatementCompletionInfo.isNewIdentifierLocation; - } - if (!importStatementCompletionInfo.replacementSpan && isCompletionListBlocker(contextToken)) { - log("Returning an empty list because completion was requested in an invalid position."); - return keywordFilters ? keywordCompletionData(keywordFilters, isJsOnlyLocation, isNewIdentifierDefinitionLocation()) : void 0; - } - let parent2 = contextToken.parent; - if (contextToken.kind === 25 /* DotToken */ || contextToken.kind === 29 /* QuestionDotToken */) { - isRightOfDot = contextToken.kind === 25 /* DotToken */; - isRightOfQuestionDot = contextToken.kind === 29 /* QuestionDotToken */; - switch (parent2.kind) { - case 210 /* PropertyAccessExpression */: - propertyAccessToConvert = parent2; - node = propertyAccessToConvert.expression; - const leftmostAccessExpression = getLeftmostAccessExpression(propertyAccessToConvert); - if (nodeIsMissing(leftmostAccessExpression) || (isCallExpression(node) || isFunctionLike(node)) && node.end === contextToken.pos && node.getChildCount(sourceFile) && last(node.getChildren(sourceFile)).kind !== 22 /* CloseParenToken */) { - return void 0; + function getSpecialSearchKind(node) { + switch (node.kind) { + case 176 /* Constructor */: + case 137 /* ConstructorKeyword */: + return 1 /* Constructor */; + case 80 /* Identifier */: + if (isClassLike(node.parent)) { + Debug.assert(node.parent.name === node); + return 2 /* Class */; + } + default: + return 0 /* None */; + } + } + function skipPastExportOrImportSpecifierOrUnion(symbol, node, checker, useLocalSymbolForExportSpecifier) { + const { parent: parent2 } = node; + if (isExportSpecifier(parent2) && useLocalSymbolForExportSpecifier) { + return getLocalSymbolForExportSpecifier(node, symbol, parent2, checker); + } + return firstDefined(symbol.declarations, (decl) => { + if (!decl.parent) { + if (symbol.flags & 33554432 /* Transient */) + return void 0; + Debug.fail(`Unexpected symbol at ${Debug.formatSyntaxKind(node.kind)}: ${Debug.formatSymbol(symbol)}`); } - break; - case 165 /* QualifiedName */: - node = parent2.left; - break; - case 266 /* ModuleDeclaration */: - node = parent2.name; - break; - case 204 /* ImportType */: - node = parent2; - break; - case 235 /* MetaProperty */: - node = parent2.getFirstToken(sourceFile); - Debug.assert(node.kind === 102 /* ImportKeyword */ || node.kind === 105 /* NewKeyword */); - break; - default: + return isTypeLiteralNode(decl.parent) && isUnionTypeNode(decl.parent.parent) ? checker.getPropertyOfType(checker.getTypeFromTypeNode(decl.parent.parent), symbol.name) : void 0; + }); + } + let SpecialSearchKind; + ((SpecialSearchKind2) => { + SpecialSearchKind2[SpecialSearchKind2["None"] = 0] = "None"; + SpecialSearchKind2[SpecialSearchKind2["Constructor"] = 1] = "Constructor"; + SpecialSearchKind2[SpecialSearchKind2["Class"] = 2] = "Class"; + })(SpecialSearchKind || (SpecialSearchKind = {})); + function getNonModuleSymbolOfMergedModuleSymbol(symbol) { + if (!(symbol.flags & (1536 /* Module */ | 33554432 /* Transient */))) return void 0; + const decl = symbol.declarations && find(symbol.declarations, (d) => !isSourceFile(d) && !isModuleDeclaration(d)); + return decl && decl.symbol; } - } else if (!importStatementCompletion) { - if (parent2 && parent2.kind === 210 /* PropertyAccessExpression */) { - contextToken = parent2; - parent2 = parent2.parent; + class State { + constructor(sourceFiles, sourceFilesSet, specialSearchKind, checker, cancellationToken, searchMeaning, options, result) { + this.sourceFiles = sourceFiles; + this.sourceFilesSet = sourceFilesSet; + this.specialSearchKind = specialSearchKind; + this.checker = checker; + this.cancellationToken = cancellationToken; + this.searchMeaning = searchMeaning; + this.options = options; + this.result = result; + /** Cache for `explicitlyinheritsFrom`. */ + this.inheritsFromCache = /* @__PURE__ */ new Map(); + /** + * Type nodes can contain multiple references to the same type. For example: + * let x: Foo & (Foo & Bar) = ... + * Because we are returning the implementation locations and not the identifier locations, + * duplicate entries would be returned here as each of the type references is part of + * the same implementation. For that reason, check before we add a new entry. + */ + this.markSeenContainingTypeReference = nodeSeenTracker(); + /** + * It's possible that we will encounter the right side of `export { foo as bar } from "x";` more than once. + * For example: + * // b.ts + * export { foo as bar } from "./a"; + * import { bar } from "./b"; + * + * Normally at `foo as bar` we directly add `foo` and do not locally search for it (since it doesn't declare a local). + * But another reference to it may appear in the same source file. + * See `tests/cases/fourslash/transitiveExportImports3.ts`. + */ + this.markSeenReExportRHS = nodeSeenTracker(); + this.symbolIdToReferences = []; + // Source file ID -> symbol ID -> Whether the symbol has been searched for in the source file. + this.sourceFileToSeenSymbols = []; + } + includesSourceFile(sourceFile) { + return this.sourceFilesSet.has(sourceFile.fileName); + } + /** Gets every place to look for references of an exported symbols. See `ImportsResult` in `importTracker.ts` for more documentation. */ + getImportSearches(exportSymbol, exportInfo) { + if (!this.importTracker) + this.importTracker = createImportTracker(this.sourceFiles, this.sourceFilesSet, this.checker, this.cancellationToken); + return this.importTracker(exportSymbol, exportInfo, this.options.use === 2 /* Rename */); + } + /** @param allSearchSymbols set of additional symbols for use by `includes`. */ + createSearch(location, symbol, comingFrom, searchOptions = {}) { + const { + text = stripQuotes(symbolName(getLocalSymbolForExportDefault(symbol) || getNonModuleSymbolOfMergedModuleSymbol(symbol) || symbol)), + allSearchSymbols = [symbol] + } = searchOptions; + const escapedText = escapeLeadingUnderscores(text); + const parents = this.options.implementations && location ? getParentSymbolsOfPropertyAccess(location, symbol, this.checker) : void 0; + return { symbol, comingFrom, text, escapedText, parents, allSearchSymbols, includes: (sym) => contains(allSearchSymbols, sym) }; + } + /** + * Callback to add references for a particular searched symbol. + * This initializes a reference group, so only call this if you will add at least one reference. + */ + referenceAdder(searchSymbol) { + const symbolId = getSymbolId(searchSymbol); + let references = this.symbolIdToReferences[symbolId]; + if (!references) { + references = this.symbolIdToReferences[symbolId] = []; + this.result.push({ definition: { type: 0 /* Symbol */, symbol: searchSymbol }, references }); + } + return (node, kind) => references.push(nodeEntry(node, kind)); + } + /** Add a reference with no associated definition. */ + addStringOrCommentReference(fileName, textSpan) { + this.result.push({ + definition: void 0, + references: [{ kind: 0 /* Span */, fileName, textSpan }] + }); + } + /** Returns `true` the first time we search for a symbol in a file and `false` afterwards. */ + markSearchedSymbols(sourceFile, symbols) { + const sourceId = getNodeId(sourceFile); + const seenSymbols = this.sourceFileToSeenSymbols[sourceId] || (this.sourceFileToSeenSymbols[sourceId] = /* @__PURE__ */ new Set()); + let anyNewSymbols = false; + for (const sym of symbols) { + anyNewSymbols = tryAddToSet(seenSymbols, getSymbolId(sym)) || anyNewSymbols; + } + return anyNewSymbols; + } } - if (currentToken.parent === location) { - switch (currentToken.kind) { - case 32 /* GreaterThanToken */: - if (currentToken.parent.kind === 283 /* JsxElement */ || currentToken.parent.kind === 285 /* JsxOpeningElement */) { - location = currentToken; + function searchForImportsOfExport(exportLocation, exportSymbol, exportInfo, state) { + const { importSearches, singleReferences, indirectUsers } = state.getImportSearches(exportSymbol, exportInfo); + if (singleReferences.length) { + const addRef = state.referenceAdder(exportSymbol); + for (const singleRef of singleReferences) { + if (shouldAddSingleReference(singleRef, state)) + addRef(singleRef); + } + } + for (const [importLocation, importSymbol] of importSearches) { + getReferencesInSourceFile(importLocation.getSourceFile(), state.createSearch(importLocation, importSymbol, 1 /* Export */), state); + } + if (indirectUsers.length) { + let indirectSearch; + switch (exportInfo.exportKind) { + case 0 /* Named */: + indirectSearch = state.createSearch(exportLocation, exportSymbol, 1 /* Export */); + break; + case 1 /* Default */: + indirectSearch = state.options.use === 2 /* Rename */ ? void 0 : state.createSearch(exportLocation, exportSymbol, 1 /* Export */, { text: "default" }); + break; + case 2 /* ExportEquals */: + break; + } + if (indirectSearch) { + for (const indirectUser of indirectUsers) { + searchForName(indirectUser, indirectSearch, state); } - break; - case 44 /* SlashToken */: - if (currentToken.parent.kind === 284 /* JsxSelfClosingElement */) { - location = currentToken; + } + } + } + function eachExportReference(sourceFiles, checker, cancellationToken, exportSymbol, exportingModuleSymbol, exportName, isDefaultExport, cb) { + const importTracker = createImportTracker(sourceFiles, new Set(sourceFiles.map((f) => f.fileName)), checker, cancellationToken); + const { importSearches, indirectUsers, singleReferences } = importTracker( + exportSymbol, + { exportKind: isDefaultExport ? 1 /* Default */ : 0 /* Named */, exportingModuleSymbol }, + /*isForRename*/ + false + ); + for (const [importLocation] of importSearches) { + cb(importLocation); + } + for (const singleReference of singleReferences) { + if (isIdentifier(singleReference) && isImportTypeNode(singleReference.parent)) { + cb(singleReference); + } + } + for (const indirectUser of indirectUsers) { + for (const node of getPossibleSymbolReferenceNodes(indirectUser, isDefaultExport ? "default" : exportName)) { + const symbol = checker.getSymbolAtLocation(node); + const hasExportAssignmentDeclaration = some(symbol == null ? void 0 : symbol.declarations, (d) => tryCast(d, isExportAssignment) ? true : false); + if (isIdentifier(node) && !isImportOrExportSpecifier(node.parent) && (symbol === exportSymbol || hasExportAssignmentDeclaration)) { + cb(node); } - break; + } } } - switch (parent2.kind) { - case 286 /* JsxClosingElement */: - if (contextToken.kind === 44 /* SlashToken */) { - isStartingCloseTag = true; - location = contextToken; + Core2.eachExportReference = eachExportReference; + function shouldAddSingleReference(singleRef, state) { + if (!hasMatchingMeaning(singleRef, state)) + return false; + if (state.options.use !== 2 /* Rename */) + return true; + if (!isIdentifier(singleRef)) + return false; + return !(isImportOrExportSpecifier(singleRef.parent) && singleRef.escapedText === "default" /* Default */); + } + function searchForImportedSymbol(symbol, state) { + if (!symbol.declarations) + return; + for (const declaration of symbol.declarations) { + const exportingFile = declaration.getSourceFile(); + getReferencesInSourceFile(exportingFile, state.createSearch(declaration, symbol, 0 /* Import */), state, state.includesSourceFile(exportingFile)); + } + } + function searchForName(sourceFile, search, state) { + if (getNameTable(sourceFile).get(search.escapedText) !== void 0) { + getReferencesInSourceFile(sourceFile, search, state); + } + } + function getPropertySymbolOfDestructuringAssignment(location, checker) { + return isArrayLiteralOrObjectLiteralDestructuringPattern(location.parent.parent) ? checker.getPropertySymbolOfDestructuringAssignment(location) : void 0; + } + function getSymbolScope(symbol) { + const { declarations, flags, parent: parent2, valueDeclaration } = symbol; + if (valueDeclaration && (valueDeclaration.kind === 218 /* FunctionExpression */ || valueDeclaration.kind === 231 /* ClassExpression */)) { + return valueDeclaration; + } + if (!declarations) { + return void 0; + } + if (flags & (4 /* Property */ | 8192 /* Method */)) { + const privateDeclaration = find(declarations, (d) => hasEffectiveModifier(d, 2 /* Private */) || isPrivateIdentifierClassElementDeclaration(d)); + if (privateDeclaration) { + return getAncestor(privateDeclaration, 263 /* ClassDeclaration */); } - break; - case 225 /* BinaryExpression */: - if (!binaryExpressionMayBeOpenTag(parent2)) { - break; + return void 0; + } + if (declarations.some(isObjectBindingElementWithoutPropertyName)) { + return void 0; + } + const exposedByParent = parent2 && !(symbol.flags & 262144 /* TypeParameter */); + if (exposedByParent && !(isExternalModuleSymbol(parent2) && !parent2.globalExports)) { + return void 0; + } + let scope; + for (const declaration of declarations) { + const container = getContainerNode(declaration); + if (scope && scope !== container) { + return void 0; } - case 284 /* JsxSelfClosingElement */: - case 283 /* JsxElement */: - case 285 /* JsxOpeningElement */: - isJsxIdentifierExpected = true; - if (contextToken.kind === 30 /* LessThanToken */) { - isRightOfOpenTag = true; - location = contextToken; + if (!container || container.kind === 312 /* SourceFile */ && !isExternalOrCommonJsModule(container)) { + return void 0; } - break; - case 293 /* JsxExpression */: - case 292 /* JsxSpreadAttribute */: - if (previousToken.kind === 20 /* CloseBraceToken */ || previousToken.kind === 80 /* Identifier */ && previousToken.parent.kind === 290 /* JsxAttribute */) { - isJsxIdentifierExpected = true; + scope = container; + if (isFunctionExpression(scope)) { + let next; + while (next = getNextJSDocCommentLocation(scope)) { + scope = next; + } } - break; - case 290 /* JsxAttribute */: - if (parent2.initializer === previousToken && previousToken.end < position) { - isJsxIdentifierExpected = true; - break; + } + return exposedByParent ? scope.getSourceFile() : scope; + } + function isSymbolReferencedInFile(definition, checker, sourceFile, searchContainer = sourceFile) { + return eachSymbolReferenceInFile(definition, checker, sourceFile, () => true, searchContainer) || false; + } + Core2.isSymbolReferencedInFile = isSymbolReferencedInFile; + function eachSymbolReferenceInFile(definition, checker, sourceFile, cb, searchContainer = sourceFile) { + const symbol = isParameterPropertyDeclaration(definition.parent, definition.parent.parent) ? first(checker.getSymbolsOfParameterPropertyDeclaration(definition.parent, definition.text)) : checker.getSymbolAtLocation(definition); + if (!symbol) + return void 0; + for (const token of getPossibleSymbolReferenceNodes(sourceFile, symbol.name, searchContainer)) { + if (!isIdentifier(token) || token === definition || token.escapedText !== definition.escapedText) + continue; + const referenceSymbol = checker.getSymbolAtLocation(token); + if (referenceSymbol === symbol || checker.getShorthandAssignmentValueSymbol(token.parent) === symbol || isExportSpecifier(token.parent) && getLocalSymbolForExportSpecifier(token, referenceSymbol, token.parent, checker) === symbol) { + const res = cb(token); + if (res) + return res; } - switch (previousToken.kind) { - case 64 /* EqualsToken */: - isJsxInitializer = true; - break; - case 80 /* Identifier */: - isJsxIdentifierExpected = true; - if (parent2 !== previousToken.parent && !parent2.initializer && findChildOfKind(parent2, 64 /* EqualsToken */, sourceFile)) { - isJsxInitializer = previousToken; - } + } + } + Core2.eachSymbolReferenceInFile = eachSymbolReferenceInFile; + function getTopMostDeclarationNamesInFile(declarationName, sourceFile) { + const candidates = filter(getPossibleSymbolReferenceNodes(sourceFile, declarationName), (name) => !!getDeclarationFromName(name)); + return candidates.reduce((topMost, decl) => { + const depth = getDepth(decl); + if (!some(topMost.declarationNames) || depth === topMost.depth) { + topMost.declarationNames.push(decl); + topMost.depth = depth; + } else if (depth < topMost.depth) { + topMost.declarationNames = [decl]; + topMost.depth = depth; } - break; + return topMost; + }, { depth: Infinity, declarationNames: [] }).declarationNames; + function getDepth(declaration) { + let depth = 0; + while (declaration) { + declaration = getContainerNode(declaration); + depth++; + } + return depth; + } } - } - } - const semanticStart = timestamp(); - let completionKind = 5 /* None */; - let isNonContextualObjectLiteral = false; - let hasUnresolvedAutoImports = false; - let symbols = []; - let importSpecifierResolver; - const symbolToOriginInfoMap = []; - const symbolToSortTextMap = []; - const seenPropertySymbols = /* @__PURE__ */ new Map(); - const isTypeOnlyLocation = isTypeOnlyCompletion(); - const getModuleSpecifierResolutionHost = memoizeOne((isFromPackageJson) => { - return createModuleSpecifierResolutionHost(isFromPackageJson ? host.getPackageJsonAutoImportProvider() : program, host); - }); - if (isRightOfDot || isRightOfQuestionDot) { - getTypeScriptMemberSymbols(); - } else if (isRightOfOpenTag) { - symbols = typeChecker.getJsxIntrinsicTagNamesAt(location); - Debug.assertEachIsDefined(symbols, "getJsxIntrinsicTagNames() should all be defined"); - tryGetGlobalSymbols(); - completionKind = 1 /* Global */; - keywordFilters = 0 /* None */; - } else if (isStartingCloseTag) { - const tagName = contextToken.parent.parent.openingElement.tagName; - const tagSymbol = typeChecker.getSymbolAtLocation(tagName); - if (tagSymbol) { - symbols = [tagSymbol]; - } - completionKind = 1 /* Global */; - keywordFilters = 0 /* None */; - } else { - if (!tryGetGlobalSymbols()) { - return keywordFilters ? keywordCompletionData(keywordFilters, isJsOnlyLocation, isNewIdentifierLocation) : void 0; - } - } - log("getCompletionData: Semantic work: " + (timestamp() - semanticStart)); - const contextualType = previousToken && getContextualType(previousToken, position, sourceFile, typeChecker); - const isLiteralExpected = !tryCast(previousToken, isStringLiteralLike) && !isJsxIdentifierExpected; - const literals = !isLiteralExpected ? [] : mapDefined( - contextualType && (contextualType.isUnion() ? contextualType.types : [contextualType]), - (t) => t.isLiteral() && !(t.flags & 1024 /* EnumLiteral */) ? t.value : void 0 - ); - const recommendedCompletion = previousToken && contextualType && getRecommendedCompletion(previousToken, contextualType, typeChecker); - return { - kind: 0 /* Data */, - symbols, - completionKind, - isInSnippetScope, - propertyAccessToConvert, - isNewIdentifierLocation, - location, - keywordFilters, - literals, - symbolToOriginInfoMap, - recommendedCompletion, - previousToken, - contextToken, - isJsxInitializer, - insideJsDocTagTypeExpression, - symbolToSortTextMap, - isTypeOnlyLocation, - isJsxIdentifierExpected, - isRightOfOpenTag, - isRightOfDotOrQuestionDot: isRightOfDot || isRightOfQuestionDot, - importStatementCompletion, - hasUnresolvedAutoImports, - flags - }; - function isTagWithTypeExpression(tag) { - switch (tag.kind) { - case 347 /* JSDocParameterTag */: - case 354 /* JSDocPropertyTag */: - case 348 /* JSDocReturnTag */: - case 350 /* JSDocTypeTag */: - case 352 /* JSDocTypedefTag */: - case 355 /* JSDocThrowsTag */: - case 356 /* JSDocSatisfiesTag */: - return true; - case 351 /* JSDocTemplateTag */: - return !!tag.constraint; - default: - return false; - } - } - function tryGetTypeExpressionFromTag(tag) { - if (isTagWithTypeExpression(tag)) { - const typeExpression = isJSDocTemplateTag(tag) ? tag.constraint : tag.typeExpression; - return typeExpression && typeExpression.kind === 315 /* JSDocTypeExpression */ ? typeExpression : void 0; - } - if (isJSDocAugmentsTag(tag) || isJSDocImplementsTag(tag)) { - return tag.class; - } - return void 0; - } - function getTypeScriptMemberSymbols() { - completionKind = 2 /* PropertyAccess */; - const isImportType = isLiteralImportTypeNode(node); - const isTypeLocation = isImportType && !node.isTypeOf || isPartOfTypeNode(node.parent) || isPossiblyTypeArgumentPosition(contextToken, sourceFile, typeChecker); - const isRhsOfImportDeclaration = isInRightSideOfInternalImportEqualsDeclaration(node); - if (isEntityName(node) || isImportType || isPropertyAccessExpression(node)) { - const isNamespaceName = isModuleDeclaration(node.parent); - if (isNamespaceName) - isNewIdentifierLocation = true; - let symbol = typeChecker.getSymbolAtLocation(node); - if (symbol) { - symbol = skipAlias(symbol, typeChecker); - if (symbol.flags & (1536 /* Module */ | 384 /* Enum */)) { - const exportedSymbols = typeChecker.getExportsOfModule(symbol); - Debug.assertEachIsDefined(exportedSymbols, "getExportsOfModule() should all be defined"); - const isValidValueAccess = (symbol2) => typeChecker.isValidPropertyAccess(isImportType ? node : node.parent, symbol2.name); - const isValidTypeAccess = (symbol2) => symbolCanBeReferencedAtTypeLocation(symbol2, typeChecker); - const isValidAccess = isNamespaceName ? (symbol2) => { - var _a; - return !!(symbol2.flags & 1920 /* Namespace */) && !((_a = symbol2.declarations) == null ? void 0 : _a.every((d) => d.parent === node.parent)); - } : isRhsOfImportDeclaration ? ( - // Any kind is allowed when dotting off namespace in internal import equals declaration - (symbol2) => isValidTypeAccess(symbol2) || isValidValueAccess(symbol2) - ) : isTypeLocation || insideJsDocTagTypeExpression ? isValidTypeAccess : isValidValueAccess; - for (const exportedSymbol of exportedSymbols) { - if (isValidAccess(exportedSymbol)) { - symbols.push(exportedSymbol); + Core2.getTopMostDeclarationNamesInFile = getTopMostDeclarationNamesInFile; + function someSignatureUsage(signature, sourceFiles, checker, cb) { + if (!signature.name || !isIdentifier(signature.name)) + return false; + const symbol = Debug.checkDefined(checker.getSymbolAtLocation(signature.name)); + for (const sourceFile of sourceFiles) { + for (const name of getPossibleSymbolReferenceNodes(sourceFile, symbol.name)) { + if (!isIdentifier(name) || name === signature.name || name.escapedText !== signature.name.escapedText) + continue; + const called = climbPastPropertyAccess(name); + const call = isCallExpression(called.parent) && called.parent.expression === called ? called.parent : void 0; + const referenceSymbol = checker.getSymbolAtLocation(name); + if (referenceSymbol && checker.getRootSymbols(referenceSymbol).some((s) => s === symbol)) { + if (cb(name, call)) { + return true; + } } } - if (!isTypeLocation && !insideJsDocTagTypeExpression && symbol.declarations && symbol.declarations.some((d) => d.kind !== 311 /* SourceFile */ && d.kind !== 266 /* ModuleDeclaration */ && d.kind !== 265 /* EnumDeclaration */)) { - let type = typeChecker.getTypeOfSymbolAtLocation(symbol, node).getNonOptionalType(); - let insertQuestionDot = false; - if (type.isNullableType()) { - const canCorrectToQuestionDot = isRightOfDot && !isRightOfQuestionDot && preferences.includeAutomaticOptionalChainCompletions !== false; - if (canCorrectToQuestionDot || isRightOfQuestionDot) { - type = type.getNonNullableType(); - if (canCorrectToQuestionDot) { - insertQuestionDot = true; - } - } + } + return false; + } + Core2.someSignatureUsage = someSignatureUsage; + function getPossibleSymbolReferenceNodes(sourceFile, symbolName2, container = sourceFile) { + return mapDefined(getPossibleSymbolReferencePositions(sourceFile, symbolName2, container), (pos) => { + const referenceLocation = getTouchingPropertyName(sourceFile, pos); + return referenceLocation === sourceFile ? void 0 : referenceLocation; + }); + } + function getPossibleSymbolReferencePositions(sourceFile, symbolName2, container = sourceFile) { + const positions = []; + if (!symbolName2 || !symbolName2.length) { + return positions; + } + const text = sourceFile.text; + const sourceLength = text.length; + const symbolNameLength = symbolName2.length; + let position = text.indexOf(symbolName2, container.pos); + while (position >= 0) { + if (position > container.end) + break; + const endPosition = position + symbolNameLength; + if ((position === 0 || !isIdentifierPart(text.charCodeAt(position - 1), 99 /* Latest */)) && (endPosition === sourceLength || !isIdentifierPart(text.charCodeAt(endPosition), 99 /* Latest */))) { + positions.push(position); + } + position = text.indexOf(symbolName2, position + symbolNameLength + 1); + } + return positions; + } + function getLabelReferencesInNode(container, targetLabel) { + const sourceFile = container.getSourceFile(); + const labelName = targetLabel.text; + const references = mapDefined(getPossibleSymbolReferenceNodes(sourceFile, labelName, container), (node) => ( + // Only pick labels that are either the target label, or have a target that is the target label + node === targetLabel || isJumpStatementTarget(node) && getTargetLabel(node, labelName) === targetLabel ? nodeEntry(node) : void 0 + )); + return [{ definition: { type: 1 /* Label */, node: targetLabel }, references }]; + } + function isValidReferencePosition(node, searchSymbolName) { + switch (node.kind) { + case 81 /* PrivateIdentifier */: + if (isJSDocMemberName(node.parent)) { + return true; } - addTypeProperties(type, !!(node.flags & 32768 /* AwaitContext */), insertQuestionDot); + case 80 /* Identifier */: + return node.text.length === searchSymbolName.length; + case 15 /* NoSubstitutionTemplateLiteral */: + case 11 /* StringLiteral */: { + const str = node; + return (isLiteralNameOfPropertyDeclarationOrIndexAccess(str) || isNameOfModuleDeclaration(node) || isExpressionOfExternalModuleImportEqualsDeclaration(node) || isCallExpression(node.parent) && isBindableObjectDefinePropertyCall(node.parent) && node.parent.arguments[1] === node) && str.text.length === searchSymbolName.length; } + case 9 /* NumericLiteral */: + return isLiteralNameOfPropertyDeclarationOrIndexAccess(node) && node.text.length === searchSymbolName.length; + case 90 /* DefaultKeyword */: + return "default".length === searchSymbolName.length; + default: + return false; + } + } + function getAllReferencesForImportMeta(sourceFiles, cancellationToken) { + const references = flatMap(sourceFiles, (sourceFile) => { + cancellationToken.throwIfCancellationRequested(); + return mapDefined(getPossibleSymbolReferenceNodes(sourceFile, "meta", sourceFile), (node) => { + const parent2 = node.parent; + if (isImportMeta(parent2)) { + return nodeEntry(parent2); + } + }); + }); + return references.length ? [{ definition: { type: 2 /* Keyword */, node: references[0].node }, references }] : void 0; + } + function getAllReferencesForKeyword(sourceFiles, keywordKind, cancellationToken, filter2) { + const references = flatMap(sourceFiles, (sourceFile) => { + cancellationToken.throwIfCancellationRequested(); + return mapDefined(getPossibleSymbolReferenceNodes(sourceFile, tokenToString(keywordKind), sourceFile), (referenceLocation) => { + if (referenceLocation.kind === keywordKind && (!filter2 || filter2(referenceLocation))) { + return nodeEntry(referenceLocation); + } + }); + }); + return references.length ? [{ definition: { type: 2 /* Keyword */, node: references[0].node }, references }] : void 0; + } + function getReferencesInSourceFile(sourceFile, search, state, addReferencesHere = true) { + state.cancellationToken.throwIfCancellationRequested(); + return getReferencesInContainer(sourceFile, sourceFile, search, state, addReferencesHere); + } + function getReferencesInContainer(container, sourceFile, search, state, addReferencesHere) { + if (!state.markSearchedSymbols(sourceFile, search.allSearchSymbols)) { return; } + for (const position of getPossibleSymbolReferencePositions(sourceFile, search.text, container)) { + getReferencesAtLocation(sourceFile, position, search, state, addReferencesHere); + } } - } - if (!isTypeLocation) { - typeChecker.tryGetThisTypeAt( - node, - /*includeGlobalThis*/ - false - ); - let type = typeChecker.getTypeAtLocation(node).getNonOptionalType(); - let insertQuestionDot = false; - if (type.isNullableType()) { - const canCorrectToQuestionDot = isRightOfDot && !isRightOfQuestionDot && preferences.includeAutomaticOptionalChainCompletions !== false; - if (canCorrectToQuestionDot || isRightOfQuestionDot) { - type = type.getNonNullableType(); - if (canCorrectToQuestionDot) { - insertQuestionDot = true; + function hasMatchingMeaning(referenceLocation, state) { + return !!(getMeaningFromLocation(referenceLocation) & state.searchMeaning); + } + function getReferencesAtLocation(sourceFile, position, search, state, addReferencesHere) { + const referenceLocation = getTouchingPropertyName(sourceFile, position); + if (!isValidReferencePosition(referenceLocation, search.text)) { + if (!state.options.implementations && (state.options.findInStrings && isInString(sourceFile, position) || state.options.findInComments && isInNonReferenceComment(sourceFile, position))) { + state.addStringOrCommentReference(sourceFile.fileName, createTextSpan(position, search.text.length)); } + return; } - } - addTypeProperties(type, !!(node.flags & 32768 /* AwaitContext */), insertQuestionDot); - } - } - function addTypeProperties(type, insertAwait, insertQuestionDot) { - isNewIdentifierLocation = !!type.getStringIndexType(); - if (isRightOfQuestionDot && some(type.getCallSignatures())) { - isNewIdentifierLocation = true; - } - const propertyAccess = node.kind === 204 /* ImportType */ ? node : node.parent; - if (inCheckedFile) { - for (const symbol of type.getApparentProperties()) { - if (typeChecker.isValidPropertyAccessForCompletions(propertyAccess, type, symbol)) { - addPropertySymbol( - symbol, - /*insertAwait*/ - false, - insertQuestionDot - ); + if (!hasMatchingMeaning(referenceLocation, state)) + return; + let referenceSymbol = state.checker.getSymbolAtLocation(referenceLocation); + if (!referenceSymbol) { + return; + } + const parent2 = referenceLocation.parent; + if (isImportSpecifier(parent2) && parent2.propertyName === referenceLocation) { + return; + } + if (isExportSpecifier(parent2)) { + Debug.assert(referenceLocation.kind === 80 /* Identifier */); + getReferencesAtExportSpecifier(referenceLocation, referenceSymbol, parent2, search, state, addReferencesHere); + return; + } + const relatedSymbol = getRelatedSymbol(search, referenceSymbol, referenceLocation, state); + if (!relatedSymbol) { + getReferenceForShorthandProperty(referenceSymbol, search, state); + return; + } + switch (state.specialSearchKind) { + case 0 /* None */: + if (addReferencesHere) + addReference(referenceLocation, relatedSymbol, state); + break; + case 1 /* Constructor */: + addConstructorReferences(referenceLocation, sourceFile, search, state); + break; + case 2 /* Class */: + addClassStaticThisReferences(referenceLocation, search, state); + break; + default: + Debug.assertNever(state.specialSearchKind); + } + if (isInJSFile(referenceLocation) && isBindingElement(referenceLocation.parent) && isVariableDeclarationInitializedToBareOrAccessedRequire(referenceLocation.parent.parent.parent)) { + referenceSymbol = referenceLocation.parent.symbol; + if (!referenceSymbol) + return; } + getImportOrExportReferences(referenceLocation, referenceSymbol, search, state); } - } else { - symbols.push(...filter(getPropertiesForCompletion(type, typeChecker), (s) => typeChecker.isValidPropertyAccessForCompletions(propertyAccess, type, s))); - } - if (insertAwait && preferences.includeCompletionsWithInsertText) { - const promiseType = typeChecker.getPromisedTypeOfPromise(type); - if (promiseType) { - for (const symbol of promiseType.getApparentProperties()) { - if (typeChecker.isValidPropertyAccessForCompletions(propertyAccess, promiseType, symbol)) { - addPropertySymbol( - symbol, - /*insertAwait*/ - true, - insertQuestionDot - ); + function getReferencesAtExportSpecifier(referenceLocation, referenceSymbol, exportSpecifier, search, state, addReferencesHere, alwaysGetReferences) { + Debug.assert(!alwaysGetReferences || !!state.options.providePrefixAndSuffixTextForRename, "If alwaysGetReferences is true, then prefix/suffix text must be enabled"); + const { parent: parent2, propertyName, name } = exportSpecifier; + const exportDeclaration = parent2.parent; + const localSymbol = getLocalSymbolForExportSpecifier(referenceLocation, referenceSymbol, exportSpecifier, state.checker); + if (!alwaysGetReferences && !search.includes(localSymbol)) { + return; + } + if (!propertyName) { + if (!(state.options.use === 2 /* Rename */ && name.escapedText === "default" /* Default */)) { + addRef(); + } + } else if (referenceLocation === propertyName) { + if (!exportDeclaration.moduleSpecifier) { + addRef(); + } + if (addReferencesHere && state.options.use !== 2 /* Rename */ && state.markSeenReExportRHS(name)) { + addReference(name, Debug.checkDefined(exportSpecifier.symbol), state); + } + } else { + if (state.markSeenReExportRHS(referenceLocation)) { + addRef(); } } + if (!isForRenameWithPrefixAndSuffixText(state.options) || alwaysGetReferences) { + const isDefaultExport = referenceLocation.escapedText === "default" || exportSpecifier.name.escapedText === "default"; + const exportKind = isDefaultExport ? 1 /* Default */ : 0 /* Named */; + const exportSymbol = Debug.checkDefined(exportSpecifier.symbol); + const exportInfo = getExportInfo(exportSymbol, exportKind, state.checker); + if (exportInfo) { + searchForImportsOfExport(referenceLocation, exportSymbol, exportInfo, state); + } + } + if (search.comingFrom !== 1 /* Export */ && exportDeclaration.moduleSpecifier && !propertyName && !isForRenameWithPrefixAndSuffixText(state.options)) { + const imported = state.checker.getExportSpecifierLocalTargetSymbol(exportSpecifier); + if (imported) + searchForImportedSymbol(imported, state); + } + function addRef() { + if (addReferencesHere) + addReference(referenceLocation, localSymbol, state); + } } - } - } - function addPropertySymbol(symbol, insertAwait, insertQuestionDot) { - var _a; - const computedPropertyName = firstDefined(symbol.declarations, (decl) => tryCast(getNameOfDeclaration(decl), isComputedPropertyName)); - if (computedPropertyName) { - const leftMostName = getLeftMostName(computedPropertyName.expression); - const nameSymbol = leftMostName && typeChecker.getSymbolAtLocation(leftMostName); - const firstAccessibleSymbol = nameSymbol && getFirstSymbolInChain(nameSymbol, contextToken, typeChecker); - if (firstAccessibleSymbol && addToSeen(seenPropertySymbols, getSymbolId(firstAccessibleSymbol))) { - const index = symbols.length; - symbols.push(firstAccessibleSymbol); - const moduleSymbol = firstAccessibleSymbol.parent; - if (!moduleSymbol || !isExternalModuleSymbol(moduleSymbol) || typeChecker.tryGetMemberInModuleExportsAndProperties(firstAccessibleSymbol.name, moduleSymbol) !== firstAccessibleSymbol) { - symbolToOriginInfoMap[index] = { kind: getNullableSymbolOriginInfoKind(2 /* SymbolMemberNoExport */) }; + function getLocalSymbolForExportSpecifier(referenceLocation, referenceSymbol, exportSpecifier, checker) { + return isExportSpecifierAlias(referenceLocation, exportSpecifier) && checker.getExportSpecifierLocalTargetSymbol(exportSpecifier) || referenceSymbol; + } + function isExportSpecifierAlias(referenceLocation, exportSpecifier) { + const { parent: parent2, propertyName, name } = exportSpecifier; + Debug.assert(propertyName === referenceLocation || name === referenceLocation); + if (propertyName) { + return propertyName === referenceLocation; } else { - const fileName = isExternalModuleNameRelative(stripQuotes(moduleSymbol.name)) ? (_a = getSourceFileOfModule(moduleSymbol)) == null ? void 0 : _a.fileName : void 0; - const { moduleSpecifier } = (importSpecifierResolver || (importSpecifierResolver = ts_codefix_exports.createImportSpecifierResolver(sourceFile, program, host, preferences))).getModuleSpecifierForBestExportInfo([{ - exportKind: 0 /* Named */, - moduleFileName: fileName, - isFromPackageJson: false, - moduleSymbol, - symbol: firstAccessibleSymbol, - targetFlags: skipAlias(firstAccessibleSymbol, typeChecker).flags - }], position, isValidTypeOnlyAliasUseSite(location)) || {}; - if (moduleSpecifier) { - const origin = { - kind: getNullableSymbolOriginInfoKind(6 /* SymbolMemberExport */), - moduleSymbol, - isDefaultExport: false, - symbolName: firstAccessibleSymbol.name, - exportName: firstAccessibleSymbol.name, - fileName, - moduleSpecifier - }; - symbolToOriginInfoMap[index] = origin; + return !parent2.parent.moduleSpecifier; + } + } + function getImportOrExportReferences(referenceLocation, referenceSymbol, search, state) { + const importOrExport = getImportOrExportSymbol(referenceLocation, referenceSymbol, state.checker, search.comingFrom === 1 /* Export */); + if (!importOrExport) + return; + const { symbol } = importOrExport; + if (importOrExport.kind === 0 /* Import */) { + if (!isForRenameWithPrefixAndSuffixText(state.options)) { + searchForImportedSymbol(symbol, state); } + } else { + searchForImportsOfExport(referenceLocation, symbol, importOrExport.exportInfo, state); } - } else if (preferences.includeCompletionsWithInsertText) { - addSymbolOriginInfo(symbol); - addSymbolSortInfo(symbol); - symbols.push(symbol); } - } else { - addSymbolOriginInfo(symbol); - addSymbolSortInfo(symbol); - symbols.push(symbol); - } - function addSymbolSortInfo(symbol2) { - if (isStaticProperty(symbol2)) { - symbolToSortTextMap[getSymbolId(symbol2)] = SortText.LocalDeclarationPriority; + function getReferenceForShorthandProperty({ flags, valueDeclaration }, search, state) { + const shorthandValueSymbol = state.checker.getShorthandAssignmentValueSymbol(valueDeclaration); + const name = valueDeclaration && getNameOfDeclaration(valueDeclaration); + if (!(flags & 33554432 /* Transient */) && name && search.includes(shorthandValueSymbol)) { + addReference(name, shorthandValueSymbol, state); + } } - } - function addSymbolOriginInfo(symbol2) { - if (preferences.includeCompletionsWithInsertText) { - if (insertAwait && addToSeen(seenPropertySymbols, getSymbolId(symbol2))) { - symbolToOriginInfoMap[symbols.length] = { kind: getNullableSymbolOriginInfoKind(8 /* Promise */) }; - } else if (insertQuestionDot) { - symbolToOriginInfoMap[symbols.length] = { kind: 16 /* Nullable */ }; + function addReference(referenceLocation, relatedSymbol, state) { + const { kind, symbol } = "kind" in relatedSymbol ? relatedSymbol : { kind: void 0, symbol: relatedSymbol }; + if (state.options.use === 2 /* Rename */ && referenceLocation.kind === 90 /* DefaultKeyword */) { + return; + } + const addRef = state.referenceAdder(symbol); + if (state.options.implementations) { + addImplementationReferences(referenceLocation, addRef, state); + } else { + addRef(referenceLocation, kind); } } - } - function getNullableSymbolOriginInfoKind(kind) { - return insertQuestionDot ? kind | 16 /* Nullable */ : kind; - } - } - function getLeftMostName(e) { - return isIdentifier(e) ? e : isPropertyAccessExpression(e) ? getLeftMostName(e.expression) : void 0; - } - function tryGetGlobalSymbols() { - const result = tryGetObjectTypeLiteralInTypeArgumentCompletionSymbols() || tryGetObjectLikeCompletionSymbols() || tryGetImportCompletionSymbols() || tryGetImportOrExportClauseCompletionSymbols() || tryGetLocalNamedExportCompletionSymbols() || tryGetConstructorCompletion() || tryGetClassLikeCompletionSymbols() || tryGetJsxCompletionSymbols() || (getGlobalCompletions(), 1 /* Success */); - return result === 1 /* Success */; - } - function tryGetConstructorCompletion() { - if (!tryGetConstructorLikeCompletionContainer(contextToken)) - return 0 /* Continue */; - completionKind = 5 /* None */; - isNewIdentifierLocation = true; - keywordFilters = 4 /* ConstructorParameterKeywords */; - return 1 /* Success */; - } - function tryGetJsxCompletionSymbols() { - const jsxContainer = tryGetContainingJsxElement(contextToken); - const attrsType = jsxContainer && typeChecker.getContextualType(jsxContainer.attributes); - if (!attrsType) - return 0 /* Continue */; - const completionsType = jsxContainer && typeChecker.getContextualType(jsxContainer.attributes, 4 /* Completions */); - symbols = concatenate(symbols, filterJsxAttributes(getPropertiesForObjectExpression(attrsType, completionsType, jsxContainer.attributes, typeChecker), jsxContainer.attributes.properties)); - setSortTextToOptionalMember(); - completionKind = 3 /* MemberLike */; - isNewIdentifierLocation = false; - return 1 /* Success */; - } - function tryGetImportCompletionSymbols() { - if (!importStatementCompletion) - return 0 /* Continue */; - isNewIdentifierLocation = true; - collectAutoImports(); - return 1 /* Success */; - } - function getGlobalCompletions() { - keywordFilters = tryGetFunctionLikeBodyCompletionContainer(contextToken) ? 5 /* FunctionLikeBodyKeywords */ : 1 /* All */; - completionKind = 1 /* Global */; - isNewIdentifierLocation = isNewIdentifierDefinitionLocation(); - if (previousToken !== contextToken) { - Debug.assert(!!previousToken, "Expected 'contextToken' to be defined when different from 'previousToken'."); - } - const adjustedPosition = previousToken !== contextToken ? previousToken.getStart() : position; - const scopeNode = getScopeNode(contextToken, adjustedPosition, sourceFile) || sourceFile; - isInSnippetScope = isSnippetScope(scopeNode); - const symbolMeanings = (isTypeOnlyLocation ? 0 /* None */ : 111551 /* Value */) | 788968 /* Type */ | 1920 /* Namespace */ | 2097152 /* Alias */; - const typeOnlyAliasNeedsPromotion = previousToken && !isValidTypeOnlyAliasUseSite(previousToken); - symbols = concatenate(symbols, typeChecker.getSymbolsInScope(scopeNode, symbolMeanings)); - Debug.assertEachIsDefined(symbols, "getSymbolsInScope() should all be defined"); - for (let i = 0; i < symbols.length; i++) { - const symbol = symbols[i]; - if (!typeChecker.isArgumentsSymbol(symbol) && !some(symbol.declarations, (d) => d.getSourceFile() === sourceFile)) { - symbolToSortTextMap[getSymbolId(symbol)] = SortText.GlobalsOrKeywords; + function addConstructorReferences(referenceLocation, sourceFile, search, state) { + if (isNewExpressionTarget(referenceLocation)) { + addReference(referenceLocation, search.symbol, state); + } + const pusher = () => state.referenceAdder(search.symbol); + if (isClassLike(referenceLocation.parent)) { + Debug.assert(referenceLocation.kind === 90 /* DefaultKeyword */ || referenceLocation.parent.name === referenceLocation); + findOwnConstructorReferences(search.symbol, sourceFile, pusher()); + } else { + const classExtending = tryGetClassByExtendingIdentifier(referenceLocation); + if (classExtending) { + findSuperConstructorAccesses(classExtending, pusher()); + findInheritedConstructorReferences(classExtending, state); + } + } } - if (typeOnlyAliasNeedsPromotion && !(symbol.flags & 111551 /* Value */)) { - const typeOnlyAliasDeclaration = symbol.declarations && find(symbol.declarations, isTypeOnlyImportDeclaration); - if (typeOnlyAliasDeclaration) { - const origin = { kind: 64 /* TypeOnlyAlias */, declaration: typeOnlyAliasDeclaration }; - symbolToOriginInfoMap[i] = origin; + function addClassStaticThisReferences(referenceLocation, search, state) { + addReference(referenceLocation, search.symbol, state); + const classLike = referenceLocation.parent; + if (state.options.use === 2 /* Rename */ || !isClassLike(classLike)) + return; + Debug.assert(classLike.name === referenceLocation); + const addRef = state.referenceAdder(search.symbol); + for (const member of classLike.members) { + if (!(isMethodOrAccessor(member) && isStatic(member))) { + continue; + } + if (member.body) { + member.body.forEachChild(function cb(node) { + if (node.kind === 110 /* ThisKeyword */) { + addRef(node); + } else if (!isFunctionLike(node) && !isClassLike(node)) { + node.forEachChild(cb); + } + }); + } } } - } - if (preferences.includeCompletionsWithInsertText && scopeNode.kind !== 311 /* SourceFile */) { - const thisType = typeChecker.tryGetThisTypeAt( - scopeNode, - /*includeGlobalThis*/ - false, - isClassLike(scopeNode.parent) ? scopeNode : void 0 - ); - if (thisType && !isProbablyGlobalType(thisType, sourceFile, typeChecker)) { - for (const symbol of getPropertiesForCompletion(thisType, typeChecker)) { - symbolToOriginInfoMap[symbols.length] = { kind: 1 /* ThisType */ }; - symbols.push(symbol); - symbolToSortTextMap[getSymbolId(symbol)] = SortText.SuggestedClassMembers; + function findOwnConstructorReferences(classSymbol, sourceFile, addNode) { + const constructorSymbol = getClassConstructorSymbol(classSymbol); + if (constructorSymbol && constructorSymbol.declarations) { + for (const decl of constructorSymbol.declarations) { + const ctrKeyword = findChildOfKind(decl, 137 /* ConstructorKeyword */, sourceFile); + Debug.assert(decl.kind === 176 /* Constructor */ && !!ctrKeyword); + addNode(ctrKeyword); + } + } + if (classSymbol.exports) { + classSymbol.exports.forEach((member) => { + const decl = member.valueDeclaration; + if (decl && decl.kind === 174 /* MethodDeclaration */) { + const body = decl.body; + if (body) { + forEachDescendantOfKind(body, 110 /* ThisKeyword */, (thisKeyword) => { + if (isNewExpressionTarget(thisKeyword)) { + addNode(thisKeyword); + } + }); + } + } + }); } } - } - collectAutoImports(); - if (isTypeOnlyLocation) { - keywordFilters = contextToken && isAssertionExpression(contextToken.parent) ? 6 /* TypeAssertionKeywords */ : 7 /* TypeKeywords */; - } - } - function shouldOfferImportCompletions() { - if (importStatementCompletion) - return true; - if (isNonContextualObjectLiteral) - return false; - if (!preferences.includeCompletionsForModuleExports) - return false; - if (sourceFile.externalModuleIndicator || sourceFile.commonJsModuleIndicator) - return true; - if (compilerOptionsIndicateEsModules(program.getCompilerOptions())) - return true; - return programContainsModules(program); - } - function isSnippetScope(scopeNode) { - switch (scopeNode.kind) { - case 311 /* SourceFile */: - case 227 /* TemplateExpression */: - case 293 /* JsxExpression */: - case 240 /* Block */: - return true; - default: - return isStatement(scopeNode); - } - } - function isTypeOnlyCompletion() { - return insideJsDocTagTypeExpression || !!importStatementCompletion && isTypeOnlyImportOrExportDeclaration(location.parent) || !isContextTokenValueLocation(contextToken) && (isPossiblyTypeArgumentPosition(contextToken, sourceFile, typeChecker) || isPartOfTypeNode(location) || isContextTokenTypeLocation(contextToken)); - } - function isContextTokenValueLocation(contextToken2) { - return contextToken2 && (contextToken2.kind === 114 /* TypeOfKeyword */ && (contextToken2.parent.kind === 185 /* TypeQuery */ || isTypeOfExpression(contextToken2.parent)) || contextToken2.kind === 131 /* AssertsKeyword */ && contextToken2.parent.kind === 181 /* TypePredicate */); - } - function isContextTokenTypeLocation(contextToken2) { - if (contextToken2) { - const parentKind = contextToken2.parent.kind; - switch (contextToken2.kind) { - case 59 /* ColonToken */: - return parentKind === 171 /* PropertyDeclaration */ || parentKind === 170 /* PropertySignature */ || parentKind === 168 /* Parameter */ || parentKind === 259 /* VariableDeclaration */ || isFunctionLikeKind(parentKind); - case 64 /* EqualsToken */: - return parentKind === 264 /* TypeAliasDeclaration */; - case 130 /* AsKeyword */: - return parentKind === 233 /* AsExpression */; - case 30 /* LessThanToken */: - return parentKind === 182 /* TypeReference */ || parentKind === 215 /* TypeAssertionExpression */; - case 96 /* ExtendsKeyword */: - return parentKind === 167 /* TypeParameter */; - case 152 /* SatisfiesKeyword */: - return parentKind === 237 /* SatisfiesExpression */; + function getClassConstructorSymbol(classSymbol) { + return classSymbol.members && classSymbol.members.get("__constructor" /* Constructor */); } - } - return false; - } - function collectAutoImports() { - var _a, _b; - if (!shouldOfferImportCompletions()) - return; - Debug.assert(!(detailsEntryId == null ? void 0 : detailsEntryId.data), "Should not run 'collectAutoImports' when faster path is available via `data`"); - if (detailsEntryId && !detailsEntryId.source) { - return; - } - flags |= 1 /* MayIncludeAutoImports */; - const isAfterTypeOnlyImportSpecifierModifier = previousToken === contextToken && importStatementCompletion; - const lowerCaseTokenText = isAfterTypeOnlyImportSpecifierModifier ? "" : previousToken && isIdentifier(previousToken) ? previousToken.text.toLowerCase() : ""; - const moduleSpecifierCache = (_a = host.getModuleSpecifierCache) == null ? void 0 : _a.call(host); - const exportInfo = getExportInfoMap(sourceFile, host, program, preferences, cancellationToken); - const packageJsonAutoImportProvider = (_b = host.getPackageJsonAutoImportProvider) == null ? void 0 : _b.call(host); - const packageJsonFilter = detailsEntryId ? void 0 : createPackageJsonImportFilter(sourceFile, preferences, host); - resolvingModuleSpecifiers( - "collectAutoImports", - host, - importSpecifierResolver || (importSpecifierResolver = ts_codefix_exports.createImportSpecifierResolver(sourceFile, program, host, preferences)), - program, - position, - preferences, - !!importStatementCompletion, - isValidTypeOnlyAliasUseSite(location), - (context) => { - exportInfo.search( - sourceFile.path, - /*preferCapitalized*/ - isRightOfOpenTag, - (symbolName2, targetFlags) => { - if (!isIdentifierText(symbolName2, getEmitScriptTarget(host.getCompilationSettings()))) - return false; - if (!detailsEntryId && isStringANonContextualKeyword(symbolName2)) - return false; - if (!isTypeOnlyLocation && !importStatementCompletion && !(targetFlags & 111551 /* Value */)) - return false; - if (isTypeOnlyLocation && !(targetFlags & (1536 /* Module */ | 788968 /* Type */))) - return false; - const firstChar = symbolName2.charCodeAt(0); - if (isRightOfOpenTag && (firstChar < 65 /* A */ || firstChar > 90 /* Z */)) - return false; - if (detailsEntryId) - return true; - return charactersFuzzyMatchInString(symbolName2, lowerCaseTokenText); - }, - (info, symbolName2, isFromAmbientModule, exportMapKey) => { - if (detailsEntryId && !some(info, (i) => detailsEntryId.source === stripQuotes(i.moduleSymbol.name))) { - return; - } - info = filter(info, isImportableExportInfo); - if (!info.length) { - return; - } - const result = context.tryResolve(info, isFromAmbientModule) || {}; - if (result === "failed") - return; - let exportInfo2 = info[0], moduleSpecifier; - if (result !== "skipped") { - ({ exportInfo: exportInfo2 = info[0], moduleSpecifier } = result); - } - const isDefaultExport = exportInfo2.exportKind === 1 /* Default */; - const symbol = isDefaultExport && getLocalSymbolForExportDefault(exportInfo2.symbol) || exportInfo2.symbol; - pushAutoImportSymbol(symbol, { - kind: moduleSpecifier ? 32 /* ResolvedExport */ : 4 /* Export */, - moduleSpecifier, - symbolName: symbolName2, - exportMapKey, - exportName: exportInfo2.exportKind === 2 /* ExportEquals */ ? "export=" /* ExportEquals */ : exportInfo2.symbol.name, - fileName: exportInfo2.moduleFileName, - isDefaultExport, - moduleSymbol: exportInfo2.moduleSymbol, - isFromPackageJson: exportInfo2.isFromPackageJson + function findSuperConstructorAccesses(classDeclaration, addNode) { + const constructor = getClassConstructorSymbol(classDeclaration.symbol); + if (!(constructor && constructor.declarations)) { + return; + } + for (const decl of constructor.declarations) { + Debug.assert(decl.kind === 176 /* Constructor */); + const body = decl.body; + if (body) { + forEachDescendantOfKind(body, 108 /* SuperKeyword */, (node) => { + if (isCallExpressionTarget(node)) { + addNode(node); + } }); } - ); - hasUnresolvedAutoImports = context.skippedAny(); - flags |= context.resolvedAny() ? 8 /* ResolvedModuleSpecifiers */ : 0; - flags |= context.resolvedBeyondLimit() ? 16 /* ResolvedModuleSpecifiersBeyondLimit */ : 0; - } - ); - function isImportableExportInfo(info) { - const moduleFile = tryCast(info.moduleSymbol.valueDeclaration, isSourceFile); - if (!moduleFile) { - const moduleName = stripQuotes(info.moduleSymbol.name); - if (ts_JsTyping_exports.nodeCoreModules.has(moduleName) && startsWith(moduleName, "node:") !== shouldUseUriStyleNodeCoreModules(sourceFile, program)) { - return false; } - return packageJsonFilter ? packageJsonFilter.allowsImportingAmbientModule(info.moduleSymbol, getModuleSpecifierResolutionHost(info.isFromPackageJson)) : true; - } - return isImportableFile( - info.isFromPackageJson ? packageJsonAutoImportProvider : program, - sourceFile, - moduleFile, - preferences, - packageJsonFilter, - getModuleSpecifierResolutionHost(info.isFromPackageJson), - moduleSpecifierCache - ); - } - } - function pushAutoImportSymbol(symbol, origin) { - const symbolId = getSymbolId(symbol); - if (symbolToSortTextMap[symbolId] === SortText.GlobalsOrKeywords) { - return; - } - symbolToOriginInfoMap[symbols.length] = origin; - symbolToSortTextMap[symbolId] = importStatementCompletion ? SortText.LocationPriority : SortText.AutoImportSuggestions; - symbols.push(symbol); - } - function collectObjectLiteralMethodSymbols(members, enclosingDeclaration) { - if (isInJSFile(location)) { - return; - } - members.forEach((member) => { - if (!isObjectLiteralMethodSymbol(member)) { - return; } - const displayName = getCompletionEntryDisplayNameForSymbol( - member, - getEmitScriptTarget(compilerOptions), - /*origin*/ - void 0, - 0 /* ObjectPropertyDeclaration */, - /*jsxIdentifierExpected*/ - false - ); - if (!displayName) { - return; + function hasOwnConstructor(classDeclaration) { + return !!getClassConstructorSymbol(classDeclaration.symbol); } - const { name } = displayName; - const entryProps = getEntryForObjectLiteralMethodCompletion( - member, - name, - enclosingDeclaration, - program, - host, - compilerOptions, - preferences, - formatContext - ); - if (!entryProps) { - return; + function findInheritedConstructorReferences(classDeclaration, state) { + if (hasOwnConstructor(classDeclaration)) + return; + const classSymbol = classDeclaration.symbol; + const search = state.createSearch( + /*location*/ + void 0, + classSymbol, + /*comingFrom*/ + void 0 + ); + getReferencesInContainerOrFiles(classSymbol, state, search); } - const origin = { kind: 128 /* ObjectLiteralMethod */, ...entryProps }; - flags |= 32 /* MayIncludeMethodSnippets */; - symbolToOriginInfoMap[symbols.length] = origin; - symbols.push(member); - }); - } - function isObjectLiteralMethodSymbol(symbol) { - if (!(symbol.flags & (4 /* Property */ | 8192 /* Method */))) { - return false; - } - return true; - } - function getScopeNode(initialToken, position2, sourceFile2) { - let scope = initialToken; - while (scope && !positionBelongsToNode(scope, position2, sourceFile2)) { - scope = scope.parent; - } - return scope; - } - function isCompletionListBlocker(contextToken2) { - const start2 = timestamp(); - const result = isInStringOrRegularExpressionOrTemplateLiteral(contextToken2) || isSolelyIdentifierDefinitionLocation(contextToken2) || isDotOfNumericLiteral(contextToken2) || isInJsxText(contextToken2) || isBigIntLiteral(contextToken2); - log("getCompletionsAtPosition: isCompletionListBlocker: " + (timestamp() - start2)); - return result; - } - function isInJsxText(contextToken2) { - if (contextToken2.kind === 12 /* JsxText */) { - return true; - } - if (contextToken2.kind === 32 /* GreaterThanToken */ && contextToken2.parent) { - if (location === contextToken2.parent && (location.kind === 285 /* JsxOpeningElement */ || location.kind === 284 /* JsxSelfClosingElement */)) { - return false; + function addImplementationReferences(refNode, addReference2, state) { + if (isDeclarationName(refNode) && isImplementation(refNode.parent)) { + addReference2(refNode); + return; + } + if (refNode.kind !== 80 /* Identifier */) { + return; + } + if (refNode.parent.kind === 304 /* ShorthandPropertyAssignment */) { + getReferenceEntriesForShorthandPropertyAssignment(refNode, state.checker, addReference2); + } + const containingNode = getContainingNodeIfInHeritageClause(refNode); + if (containingNode) { + addReference2(containingNode); + return; + } + const typeNode = findAncestor(refNode, (a) => !isQualifiedName(a.parent) && !isTypeNode(a.parent) && !isTypeElement(a.parent)); + const typeHavingNode = typeNode.parent; + if (hasType(typeHavingNode) && typeHavingNode.type === typeNode && state.markSeenContainingTypeReference(typeHavingNode)) { + if (hasInitializer(typeHavingNode)) { + addIfImplementation(typeHavingNode.initializer); + } else if (isFunctionLike(typeHavingNode) && typeHavingNode.body) { + const body = typeHavingNode.body; + if (body.kind === 241 /* Block */) { + forEachReturnStatement(body, (returnStatement) => { + if (returnStatement.expression) + addIfImplementation(returnStatement.expression); + }); + } else { + addIfImplementation(body); + } + } else if (isAssertionExpression(typeHavingNode)) { + addIfImplementation(typeHavingNode.expression); + } + } + function addIfImplementation(e) { + if (isImplementationExpression(e)) + addReference2(e); + } } - if (contextToken2.parent.kind === 285 /* JsxOpeningElement */) { - return location.parent.kind !== 285 /* JsxOpeningElement */; + function getContainingNodeIfInHeritageClause(node) { + return isIdentifier(node) || isPropertyAccessExpression(node) ? getContainingNodeIfInHeritageClause(node.parent) : isExpressionWithTypeArguments(node) ? tryCast(node.parent.parent, or(isClassLike, isInterfaceDeclaration)) : void 0; } - if (contextToken2.parent.kind === 286 /* JsxClosingElement */ || contextToken2.parent.kind === 284 /* JsxSelfClosingElement */) { - return !!contextToken2.parent.parent && contextToken2.parent.parent.kind === 283 /* JsxElement */; + function isImplementationExpression(node) { + switch (node.kind) { + case 217 /* ParenthesizedExpression */: + return isImplementationExpression(node.expression); + case 219 /* ArrowFunction */: + case 218 /* FunctionExpression */: + case 210 /* ObjectLiteralExpression */: + case 231 /* ClassExpression */: + case 209 /* ArrayLiteralExpression */: + return true; + default: + return false; + } } - } - return false; - } - function isNewIdentifierDefinitionLocation() { - if (contextToken) { - const containingNodeKind = contextToken.parent.kind; - const tokenKind = keywordForNode(contextToken); - switch (tokenKind) { - case 28 /* CommaToken */: - return containingNodeKind === 212 /* CallExpression */ || containingNodeKind === 175 /* Constructor */ || containingNodeKind === 213 /* NewExpression */ || containingNodeKind === 208 /* ArrayLiteralExpression */ || containingNodeKind === 225 /* BinaryExpression */ || containingNodeKind === 183 /* FunctionType */ || containingNodeKind === 209 /* ObjectLiteralExpression */; - case 21 /* OpenParenToken */: - return containingNodeKind === 212 /* CallExpression */ || containingNodeKind === 175 /* Constructor */ || containingNodeKind === 213 /* NewExpression */ || containingNodeKind === 216 /* ParenthesizedExpression */ || containingNodeKind === 195 /* ParenthesizedType */; - case 23 /* OpenBracketToken */: - return containingNodeKind === 208 /* ArrayLiteralExpression */ || containingNodeKind === 180 /* IndexSignature */ || containingNodeKind === 166 /* ComputedPropertyName */; - case 144 /* ModuleKeyword */: - case 145 /* NamespaceKeyword */: - case 102 /* ImportKeyword */: + function explicitlyInheritsFrom(symbol, parent2, cachedResults, checker) { + if (symbol === parent2) { return true; - case 25 /* DotToken */: - return containingNodeKind === 266 /* ModuleDeclaration */; - case 19 /* OpenBraceToken */: - return containingNodeKind === 262 /* ClassDeclaration */ || containingNodeKind === 209 /* ObjectLiteralExpression */; - case 64 /* EqualsToken */: - return containingNodeKind === 259 /* VariableDeclaration */ || containingNodeKind === 225 /* BinaryExpression */; - case 16 /* TemplateHead */: - return containingNodeKind === 227 /* TemplateExpression */; - case 17 /* TemplateMiddle */: - return containingNodeKind === 238 /* TemplateSpan */; - case 134 /* AsyncKeyword */: - return containingNodeKind === 173 /* MethodDeclaration */ || containingNodeKind === 303 /* ShorthandPropertyAssignment */; - case 42 /* AsteriskToken */: - return containingNodeKind === 173 /* MethodDeclaration */; - } - if (isClassMemberCompletionKeyword(tokenKind)) { - return true; - } - } - return false; - } - function isInStringOrRegularExpressionOrTemplateLiteral(contextToken2) { - return (isRegularExpressionLiteral(contextToken2) || isStringTextContainingNode(contextToken2)) && (rangeContainsPositionExclusive(contextToken2, position) || position === contextToken2.end && (!!contextToken2.isUnterminated || isRegularExpressionLiteral(contextToken2))); - } - function tryGetObjectTypeLiteralInTypeArgumentCompletionSymbols() { - const typeLiteralNode = tryGetTypeLiteralNode(contextToken); - if (!typeLiteralNode) - return 0 /* Continue */; - const intersectionTypeNode = isIntersectionTypeNode(typeLiteralNode.parent) ? typeLiteralNode.parent : void 0; - const containerTypeNode = intersectionTypeNode || typeLiteralNode; - const containerExpectedType = getConstraintOfTypeArgumentProperty(containerTypeNode, typeChecker); - if (!containerExpectedType) - return 0 /* Continue */; - const containerActualType = typeChecker.getTypeFromTypeNode(containerTypeNode); - const members = getPropertiesForCompletion(containerExpectedType, typeChecker); - const existingMembers = getPropertiesForCompletion(containerActualType, typeChecker); - const existingMemberEscapedNames = /* @__PURE__ */ new Set(); - existingMembers.forEach((s) => existingMemberEscapedNames.add(s.escapedName)); - symbols = concatenate(symbols, filter(members, (s) => !existingMemberEscapedNames.has(s.escapedName))); - completionKind = 0 /* ObjectPropertyDeclaration */; - isNewIdentifierLocation = true; - return 1 /* Success */; - } - function tryGetObjectLikeCompletionSymbols() { - const symbolsStartIndex = symbols.length; - const objectLikeContainer = tryGetObjectLikeCompletionContainer(contextToken); - if (!objectLikeContainer) - return 0 /* Continue */; - completionKind = 0 /* ObjectPropertyDeclaration */; - let typeMembers; - let existingMembers; - if (objectLikeContainer.kind === 209 /* ObjectLiteralExpression */) { - const instantiatedType = tryGetObjectLiteralContextualType(objectLikeContainer, typeChecker); - if (instantiatedType === void 0) { - if (objectLikeContainer.flags & 33554432 /* InWithStatement */) { - return 2 /* Fail */; } - isNonContextualObjectLiteral = true; - return 0 /* Continue */; - } - const completionsType = typeChecker.getContextualType(objectLikeContainer, 4 /* Completions */); - const hasStringIndexType = (completionsType || instantiatedType).getStringIndexType(); - const hasNumberIndextype = (completionsType || instantiatedType).getNumberIndexType(); - isNewIdentifierLocation = !!hasStringIndexType || !!hasNumberIndextype; - typeMembers = getPropertiesForObjectExpression(instantiatedType, completionsType, objectLikeContainer, typeChecker); - existingMembers = objectLikeContainer.properties; - if (typeMembers.length === 0) { - if (!hasNumberIndextype) { - isNonContextualObjectLiteral = true; - return 0 /* Continue */; + const key = getSymbolId(symbol) + "," + getSymbolId(parent2); + const cached = cachedResults.get(key); + if (cached !== void 0) { + return cached; } + cachedResults.set(key, false); + const inherits = !!symbol.declarations && symbol.declarations.some( + (declaration) => getAllSuperTypeNodes(declaration).some((typeReference) => { + const type = checker.getTypeAtLocation(typeReference); + return !!type && !!type.symbol && explicitlyInheritsFrom(type.symbol, parent2, cachedResults, checker); + }) + ); + cachedResults.set(key, inherits); + return inherits; } - } else { - Debug.assert(objectLikeContainer.kind === 205 /* ObjectBindingPattern */); - isNewIdentifierLocation = false; - const rootDeclaration = getRootDeclaration(objectLikeContainer.parent); - if (!isVariableLike(rootDeclaration)) - return Debug.fail("Root declaration is not variable-like."); - let canGetType = hasInitializer(rootDeclaration) || !!getEffectiveTypeAnnotationNode(rootDeclaration) || rootDeclaration.parent.parent.kind === 249 /* ForOfStatement */; - if (!canGetType && rootDeclaration.kind === 168 /* Parameter */) { - if (isExpression(rootDeclaration.parent)) { - canGetType = !!typeChecker.getContextualType(rootDeclaration.parent); - } else if (rootDeclaration.parent.kind === 173 /* MethodDeclaration */ || rootDeclaration.parent.kind === 177 /* SetAccessor */) { - canGetType = isExpression(rootDeclaration.parent.parent) && !!typeChecker.getContextualType(rootDeclaration.parent.parent); + function getReferencesForSuperKeyword(superKeyword) { + let searchSpaceNode = getSuperContainer( + superKeyword, + /*stopOnFunctions*/ + false + ); + if (!searchSpaceNode) { + return void 0; } - } - if (canGetType) { - const typeForObject = typeChecker.getTypeAtLocation(objectLikeContainer); - if (!typeForObject) - return 2 /* Fail */; - typeMembers = typeChecker.getPropertiesOfType(typeForObject).filter((propertySymbol) => { - return typeChecker.isPropertyAccessible( - objectLikeContainer, - /*isSuper*/ - false, - /*isWrite*/ - false, - typeForObject, - propertySymbol + let staticFlag = 256 /* Static */; + switch (searchSpaceNode.kind) { + case 172 /* PropertyDeclaration */: + case 171 /* PropertySignature */: + case 174 /* MethodDeclaration */: + case 173 /* MethodSignature */: + case 176 /* Constructor */: + case 177 /* GetAccessor */: + case 178 /* SetAccessor */: + staticFlag &= getSyntacticModifierFlags(searchSpaceNode); + searchSpaceNode = searchSpaceNode.parent; + break; + default: + return void 0; + } + const sourceFile = searchSpaceNode.getSourceFile(); + const references = mapDefined(getPossibleSymbolReferenceNodes(sourceFile, "super", searchSpaceNode), (node) => { + if (node.kind !== 108 /* SuperKeyword */) { + return; + } + const container = getSuperContainer( + node, + /*stopOnFunctions*/ + false ); + return container && isStatic(container) === !!staticFlag && container.parent.symbol === searchSpaceNode.symbol ? nodeEntry(node) : void 0; }); - existingMembers = objectLikeContainer.elements; + return [{ definition: { type: 0 /* Symbol */, symbol: searchSpaceNode.symbol }, references }]; } - } - if (typeMembers && typeMembers.length > 0) { - const filteredMembers = filterObjectMembersList(typeMembers, Debug.checkDefined(existingMembers)); - symbols = concatenate(symbols, filteredMembers); - setSortTextToOptionalMember(); - if (objectLikeContainer.kind === 209 /* ObjectLiteralExpression */ && preferences.includeCompletionsWithObjectLiteralMethodSnippets && preferences.includeCompletionsWithInsertText) { - transformObjectLiteralMembersSortText(symbolsStartIndex); - collectObjectLiteralMethodSymbols(filteredMembers, objectLikeContainer); + function isParameterName(node) { + return node.kind === 80 /* Identifier */ && node.parent.kind === 169 /* Parameter */ && node.parent.name === node; } - } - return 1 /* Success */; - } - function tryGetImportOrExportClauseCompletionSymbols() { - if (!contextToken) - return 0 /* Continue */; - const namedImportsOrExports = contextToken.kind === 19 /* OpenBraceToken */ || contextToken.kind === 28 /* CommaToken */ ? tryCast(contextToken.parent, isNamedImportsOrExports) : isTypeKeywordTokenOrIdentifier(contextToken) ? tryCast(contextToken.parent.parent, isNamedImportsOrExports) : void 0; - if (!namedImportsOrExports) - return 0 /* Continue */; - if (!isTypeKeywordTokenOrIdentifier(contextToken)) { - keywordFilters = 8 /* TypeKeyword */; - } - const { moduleSpecifier } = namedImportsOrExports.kind === 274 /* NamedImports */ ? namedImportsOrExports.parent.parent : namedImportsOrExports.parent; - if (!moduleSpecifier) { - isNewIdentifierLocation = true; - return namedImportsOrExports.kind === 274 /* NamedImports */ ? 2 /* Fail */ : 0 /* Continue */; - } - const moduleSpecifierSymbol = typeChecker.getSymbolAtLocation(moduleSpecifier); - if (!moduleSpecifierSymbol) { - isNewIdentifierLocation = true; - return 2 /* Fail */; - } - completionKind = 3 /* MemberLike */; - isNewIdentifierLocation = false; - const exports = typeChecker.getExportsAndPropertiesOfModule(moduleSpecifierSymbol); - const existing = new Set(namedImportsOrExports.elements.filter((n) => !isCurrentlyEditingNode(n)).map((n) => (n.propertyName || n.name).escapedText)); - const uniques = exports.filter((e) => e.escapedName !== "default" /* Default */ && !existing.has(e.escapedName)); - symbols = concatenate(symbols, uniques); - if (!uniques.length) { - keywordFilters = 0 /* None */; - } - return 1 /* Success */; - } - function tryGetLocalNamedExportCompletionSymbols() { - var _a; - const namedExports = contextToken && (contextToken.kind === 19 /* OpenBraceToken */ || contextToken.kind === 28 /* CommaToken */) ? tryCast(contextToken.parent, isNamedExports) : void 0; - if (!namedExports) { - return 0 /* Continue */; - } - const localsContainer = findAncestor(namedExports, or(isSourceFile, isModuleDeclaration)); - completionKind = 5 /* None */; - isNewIdentifierLocation = false; - (_a = localsContainer.locals) == null ? void 0 : _a.forEach((symbol, name) => { - var _a2, _b; - symbols.push(symbol); - if ((_b = (_a2 = localsContainer.symbol) == null ? void 0 : _a2.exports) == null ? void 0 : _b.has(name)) { - symbolToSortTextMap[getSymbolId(symbol)] = SortText.OptionalMember; + function getReferencesForThisKeyword(thisOrSuperKeyword, sourceFiles, cancellationToken) { + let searchSpaceNode = getThisContainer( + thisOrSuperKeyword, + /*includeArrowFunctions*/ + false, + /*includeClassComputedPropertyName*/ + false + ); + let staticFlag = 256 /* Static */; + switch (searchSpaceNode.kind) { + case 174 /* MethodDeclaration */: + case 173 /* MethodSignature */: + if (isObjectLiteralMethod(searchSpaceNode)) { + staticFlag &= getSyntacticModifierFlags(searchSpaceNode); + searchSpaceNode = searchSpaceNode.parent; + break; + } + case 172 /* PropertyDeclaration */: + case 171 /* PropertySignature */: + case 176 /* Constructor */: + case 177 /* GetAccessor */: + case 178 /* SetAccessor */: + staticFlag &= getSyntacticModifierFlags(searchSpaceNode); + searchSpaceNode = searchSpaceNode.parent; + break; + case 312 /* SourceFile */: + if (isExternalModule(searchSpaceNode) || isParameterName(thisOrSuperKeyword)) { + return void 0; + } + case 262 /* FunctionDeclaration */: + case 218 /* FunctionExpression */: + break; + default: + return void 0; + } + const references = flatMap(searchSpaceNode.kind === 312 /* SourceFile */ ? sourceFiles : [searchSpaceNode.getSourceFile()], (sourceFile) => { + cancellationToken.throwIfCancellationRequested(); + return getPossibleSymbolReferenceNodes(sourceFile, "this", isSourceFile(searchSpaceNode) ? sourceFile : searchSpaceNode).filter((node) => { + if (!isThis(node)) { + return false; + } + const container = getThisContainer( + node, + /*includeArrowFunctions*/ + false, + /*includeClassComputedPropertyName*/ + false + ); + if (!canHaveSymbol(container)) + return false; + switch (searchSpaceNode.kind) { + case 218 /* FunctionExpression */: + case 262 /* FunctionDeclaration */: + return searchSpaceNode.symbol === container.symbol; + case 174 /* MethodDeclaration */: + case 173 /* MethodSignature */: + return isObjectLiteralMethod(searchSpaceNode) && searchSpaceNode.symbol === container.symbol; + case 231 /* ClassExpression */: + case 263 /* ClassDeclaration */: + case 210 /* ObjectLiteralExpression */: + return container.parent && canHaveSymbol(container.parent) && searchSpaceNode.symbol === container.parent.symbol && isStatic(container) === !!staticFlag; + case 312 /* SourceFile */: + return container.kind === 312 /* SourceFile */ && !isExternalModule(container) && !isParameterName(node); + } + }); + }).map((n) => nodeEntry(n)); + const thisParameter = firstDefined(references, (r) => isParameter(r.node.parent) ? r.node : void 0); + return [{ + definition: { type: 3 /* This */, node: thisParameter || thisOrSuperKeyword }, + references + }]; } - }); - return 1 /* Success */; - } - function tryGetClassLikeCompletionSymbols() { - const decl = tryGetObjectTypeDeclarationCompletionContainer(sourceFile, contextToken, location, position); - if (!decl) - return 0 /* Continue */; - completionKind = 3 /* MemberLike */; - isNewIdentifierLocation = true; - keywordFilters = contextToken.kind === 42 /* AsteriskToken */ ? 0 /* None */ : isClassLike(decl) ? 2 /* ClassElementKeywords */ : 3 /* InterfaceElementKeywords */; - if (!isClassLike(decl)) - return 1 /* Success */; - const classElement = contextToken.kind === 27 /* SemicolonToken */ ? contextToken.parent.parent : contextToken.parent; - let classElementModifierFlags = isClassElement(classElement) ? getEffectiveModifierFlags(classElement) : 0 /* None */; - if (contextToken.kind === 80 /* Identifier */ && !isCurrentlyEditingNode(contextToken)) { - switch (contextToken.getText()) { - case "private": - classElementModifierFlags = classElementModifierFlags | 8 /* Private */; - break; - case "static": - classElementModifierFlags = classElementModifierFlags | 32 /* Static */; - break; - case "override": - classElementModifierFlags = classElementModifierFlags | 16384 /* Override */; - break; + function getReferencesForStringLiteral(node, sourceFiles, checker, cancellationToken) { + const type = getContextualTypeFromParentOrAncestorTypeNode(node, checker); + const references = flatMap(sourceFiles, (sourceFile) => { + cancellationToken.throwIfCancellationRequested(); + return mapDefined(getPossibleSymbolReferenceNodes(sourceFile, node.text), (ref) => { + if (isStringLiteralLike(ref) && ref.text === node.text) { + if (type) { + const refType = getContextualTypeFromParentOrAncestorTypeNode(ref, checker); + if (type !== checker.getStringType() && type === refType) { + return nodeEntry(ref, 2 /* StringLiteral */); + } + } else { + return isNoSubstitutionTemplateLiteral(ref) && !rangeIsOnSingleLine(ref, sourceFile) ? void 0 : nodeEntry(ref, 2 /* StringLiteral */); + } + } + }); + }); + return [{ + definition: { type: 4 /* String */, node }, + references + }]; } - } - if (isClassStaticBlockDeclaration(classElement)) { - classElementModifierFlags |= 32 /* Static */; - } - if (!(classElementModifierFlags & 8 /* Private */)) { - const baseTypeNodes = isClassLike(decl) && classElementModifierFlags & 16384 /* Override */ ? singleElementArray(getEffectiveBaseTypeNode(decl)) : getAllSuperTypeNodes(decl); - const baseSymbols = flatMap(baseTypeNodes, (baseTypeNode) => { - const type = typeChecker.getTypeAtLocation(baseTypeNode); - return classElementModifierFlags & 32 /* Static */ ? (type == null ? void 0 : type.symbol) && typeChecker.getPropertiesOfType(typeChecker.getTypeOfSymbolAtLocation(type.symbol, decl)) : type && typeChecker.getPropertiesOfType(type); - }); - symbols = concatenate(symbols, filterClassMembersList(baseSymbols, decl.members, classElementModifierFlags)); - forEach(symbols, (symbol, index) => { - const declaration = symbol == null ? void 0 : symbol.valueDeclaration; - if (declaration && isClassElement(declaration) && declaration.name && isComputedPropertyName(declaration.name)) { - const origin = { - kind: 512 /* ComputedPropertyName */, - symbolName: typeChecker.symbolToString(symbol) - }; - symbolToOriginInfoMap[index] = origin; - } - }); - } - return 1 /* Success */; - } - function isConstructorParameterCompletion(node2) { - return !!node2.parent && isParameter(node2.parent) && isConstructorDeclaration(node2.parent.parent) && (isParameterPropertyModifier(node2.kind) || isDeclarationName(node2)); - } - function tryGetConstructorLikeCompletionContainer(contextToken2) { - if (contextToken2) { - const parent2 = contextToken2.parent; - switch (contextToken2.kind) { - case 21 /* OpenParenToken */: - case 28 /* CommaToken */: - return isConstructorDeclaration(contextToken2.parent) ? contextToken2.parent : void 0; - default: - if (isConstructorParameterCompletion(contextToken2)) { - return parent2.parent; - } + function populateSearchSymbolSet(symbol, location, checker, isForRename, providePrefixAndSuffixText, implementations) { + const result = []; + forEachRelatedSymbol( + symbol, + location, + checker, + isForRename, + !(isForRename && providePrefixAndSuffixText), + (sym, root, base) => { + if (base) { + if (isStaticSymbol(symbol) !== isStaticSymbol(base)) { + base = void 0; + } + } + result.push(base || root || sym); + }, + // when try to find implementation, implementations is true, and not allowed to find base class + /*allowBaseTypes*/ + () => !implementations + ); + return result; } - } - return void 0; - } - function tryGetFunctionLikeBodyCompletionContainer(contextToken2) { - if (contextToken2) { - let prev; - const container = findAncestor(contextToken2.parent, (node2) => { - if (isClassLike(node2)) { - return "quit"; + function forEachRelatedSymbol(symbol, location, checker, isForRenamePopulateSearchSymbolSet, onlyIncludeBindingElementAtReferenceLocation, cbSymbol, allowBaseTypes) { + const containingObjectLiteralElement = getContainingObjectLiteralElement(location); + if (containingObjectLiteralElement) { + const shorthandValueSymbol = checker.getShorthandAssignmentValueSymbol(location.parent); + if (shorthandValueSymbol && isForRenamePopulateSearchSymbolSet) { + return cbSymbol( + shorthandValueSymbol, + /*rootSymbol*/ + void 0, + /*baseSymbol*/ + void 0, + 3 /* SearchedLocalFoundProperty */ + ); + } + const contextualType = checker.getContextualType(containingObjectLiteralElement.parent); + const res2 = contextualType && firstDefined( + getPropertySymbolsFromContextualType( + containingObjectLiteralElement, + checker, + contextualType, + /*unionSymbolOk*/ + true + ), + (sym) => fromRoot(sym, 4 /* SearchedPropertyFoundLocal */) + ); + if (res2) + return res2; + const propertySymbol = getPropertySymbolOfDestructuringAssignment(location, checker); + const res1 = propertySymbol && cbSymbol( + propertySymbol, + /*rootSymbol*/ + void 0, + /*baseSymbol*/ + void 0, + 4 /* SearchedPropertyFoundLocal */ + ); + if (res1) + return res1; + const res22 = shorthandValueSymbol && cbSymbol( + shorthandValueSymbol, + /*rootSymbol*/ + void 0, + /*baseSymbol*/ + void 0, + 3 /* SearchedLocalFoundProperty */ + ); + if (res22) + return res22; } - if (isFunctionLikeDeclaration(node2) && prev === node2.body) { - return true; + const aliasedSymbol = getMergedAliasedSymbolOfNamespaceExportDeclaration(location, symbol, checker); + if (aliasedSymbol) { + const res2 = cbSymbol( + aliasedSymbol, + /*rootSymbol*/ + void 0, + /*baseSymbol*/ + void 0, + 1 /* Node */ + ); + if (res2) + return res2; } - prev = node2; - return false; - }); - return container && container; - } - } - function tryGetContainingJsxElement(contextToken2) { - if (contextToken2) { - const parent2 = contextToken2.parent; - switch (contextToken2.kind) { - case 32 /* GreaterThanToken */: - case 31 /* LessThanSlashToken */: - case 44 /* SlashToken */: - case 80 /* Identifier */: - case 210 /* PropertyAccessExpression */: - case 291 /* JsxAttributes */: - case 290 /* JsxAttribute */: - case 292 /* JsxSpreadAttribute */: - if (parent2 && (parent2.kind === 284 /* JsxSelfClosingElement */ || parent2.kind === 285 /* JsxOpeningElement */)) { - if (contextToken2.kind === 32 /* GreaterThanToken */) { - const precedingToken = findPrecedingToken( - contextToken2.pos, - sourceFile, - /*startNode*/ - void 0 - ); - if (!parent2.typeArguments || precedingToken && precedingToken.kind === 44 /* SlashToken */) - break; - } - return parent2; - } else if (parent2.kind === 290 /* JsxAttribute */) { - return parent2.parent.parent; - } - break; - case 11 /* StringLiteral */: - if (parent2 && (parent2.kind === 290 /* JsxAttribute */ || parent2.kind === 292 /* JsxSpreadAttribute */)) { - return parent2.parent.parent; + const res = fromRoot(symbol); + if (res) + return res; + if (symbol.valueDeclaration && isParameterPropertyDeclaration(symbol.valueDeclaration, symbol.valueDeclaration.parent)) { + const paramProps = checker.getSymbolsOfParameterPropertyDeclaration(cast(symbol.valueDeclaration, isParameter), symbol.name); + Debug.assert(paramProps.length === 2 && !!(paramProps[0].flags & 1 /* FunctionScopedVariable */) && !!(paramProps[1].flags & 4 /* Property */)); + return fromRoot(symbol.flags & 1 /* FunctionScopedVariable */ ? paramProps[1] : paramProps[0]); + } + const exportSpecifier = getDeclarationOfKind(symbol, 281 /* ExportSpecifier */); + if (!isForRenamePopulateSearchSymbolSet || exportSpecifier && !exportSpecifier.propertyName) { + const localSymbol = exportSpecifier && checker.getExportSpecifierLocalTargetSymbol(exportSpecifier); + if (localSymbol) { + const res2 = cbSymbol( + localSymbol, + /*rootSymbol*/ + void 0, + /*baseSymbol*/ + void 0, + 1 /* Node */ + ); + if (res2) + return res2; } - break; - case 20 /* CloseBraceToken */: - if (parent2 && parent2.kind === 293 /* JsxExpression */ && parent2.parent && parent2.parent.kind === 290 /* JsxAttribute */) { - return parent2.parent.parent.parent; + } + if (!isForRenamePopulateSearchSymbolSet) { + let bindingElementPropertySymbol; + if (onlyIncludeBindingElementAtReferenceLocation) { + bindingElementPropertySymbol = isObjectBindingElementWithoutPropertyName(location.parent) ? getPropertySymbolFromBindingElement(checker, location.parent) : void 0; + } else { + bindingElementPropertySymbol = getPropertySymbolOfObjectBindingPatternWithoutPropertyName(symbol, checker); } - if (parent2 && parent2.kind === 292 /* JsxSpreadAttribute */) { - return parent2.parent.parent; + return bindingElementPropertySymbol && fromRoot(bindingElementPropertySymbol, 4 /* SearchedPropertyFoundLocal */); + } + Debug.assert(isForRenamePopulateSearchSymbolSet); + const includeOriginalSymbolOfBindingElement = onlyIncludeBindingElementAtReferenceLocation; + if (includeOriginalSymbolOfBindingElement) { + const bindingElementPropertySymbol = getPropertySymbolOfObjectBindingPatternWithoutPropertyName(symbol, checker); + return bindingElementPropertySymbol && fromRoot(bindingElementPropertySymbol, 4 /* SearchedPropertyFoundLocal */); + } + function fromRoot(sym, kind) { + return firstDefined(checker.getRootSymbols(sym), (rootSymbol) => cbSymbol( + sym, + rootSymbol, + /*baseSymbol*/ + void 0, + kind + ) || (rootSymbol.parent && rootSymbol.parent.flags & (32 /* Class */ | 64 /* Interface */) && allowBaseTypes(rootSymbol) ? getPropertySymbolsFromBaseTypes(rootSymbol.parent, rootSymbol.name, checker, (base) => cbSymbol(sym, rootSymbol, base, kind)) : void 0)); + } + function getPropertySymbolOfObjectBindingPatternWithoutPropertyName(symbol2, checker2) { + const bindingElement = getDeclarationOfKind(symbol2, 208 /* BindingElement */); + if (bindingElement && isObjectBindingElementWithoutPropertyName(bindingElement)) { + return getPropertySymbolFromBindingElement(checker2, bindingElement); } - break; + } } - } - return void 0; - } - function isSolelyIdentifierDefinitionLocation(contextToken2) { - const parent2 = contextToken2.parent; - const containingNodeKind = parent2.kind; - switch (contextToken2.kind) { - case 28 /* CommaToken */: - return containingNodeKind === 259 /* VariableDeclaration */ || isVariableDeclarationListButNotTypeArgument(contextToken2) || containingNodeKind === 242 /* VariableStatement */ || containingNodeKind === 265 /* EnumDeclaration */ || // enum a { foo, | - isFunctionLikeButNotConstructor(containingNodeKind) || containingNodeKind === 263 /* InterfaceDeclaration */ || // interface A= contextToken2.pos; - case 25 /* DotToken */: - return containingNodeKind === 206 /* ArrayBindingPattern */; - case 59 /* ColonToken */: - return containingNodeKind === 207 /* BindingElement */; - case 23 /* OpenBracketToken */: - return containingNodeKind === 206 /* ArrayBindingPattern */; - case 21 /* OpenParenToken */: - return containingNodeKind === 298 /* CatchClause */ || isFunctionLikeButNotConstructor(containingNodeKind); - case 19 /* OpenBraceToken */: - return containingNodeKind === 265 /* EnumDeclaration */; - case 30 /* LessThanToken */: - return containingNodeKind === 262 /* ClassDeclaration */ || // class A< | - containingNodeKind === 230 /* ClassExpression */ || // var C = class D< | - containingNodeKind === 263 /* InterfaceDeclaration */ || // interface A< | - containingNodeKind === 264 /* TypeAliasDeclaration */ || // type List< | - isFunctionLikeKind(containingNodeKind); - case 126 /* StaticKeyword */: - return containingNodeKind === 171 /* PropertyDeclaration */ && !isClassLike(parent2.parent); - case 26 /* DotDotDotToken */: - return containingNodeKind === 168 /* Parameter */ || !!parent2.parent && parent2.parent.kind === 206 /* ArrayBindingPattern */; - case 125 /* PublicKeyword */: - case 123 /* PrivateKeyword */: - case 124 /* ProtectedKeyword */: - return containingNodeKind === 168 /* Parameter */ && !isConstructorDeclaration(parent2.parent); - case 130 /* AsKeyword */: - return containingNodeKind === 275 /* ImportSpecifier */ || containingNodeKind === 280 /* ExportSpecifier */ || containingNodeKind === 273 /* NamespaceImport */; - case 139 /* GetKeyword */: - case 153 /* SetKeyword */: - return !isFromObjectTypeDeclaration(contextToken2); - case 80 /* Identifier */: - if (containingNodeKind === 275 /* ImportSpecifier */ && contextToken2 === parent2.name && contextToken2.text === "type") { + function getPropertySymbolsFromBaseTypes(symbol, propertyName, checker, cb) { + const seen = /* @__PURE__ */ new Map(); + return recur(symbol); + function recur(symbol2) { + if (!(symbol2.flags & (32 /* Class */ | 64 /* Interface */)) || !addToSeen(seen, getSymbolId(symbol2))) + return; + return firstDefined(symbol2.declarations, (declaration) => firstDefined(getAllSuperTypeNodes(declaration), (typeReference) => { + const type = checker.getTypeAtLocation(typeReference); + const propertySymbol = type && type.symbol && checker.getPropertyOfType(type, propertyName); + return type && propertySymbol && (firstDefined(checker.getRootSymbols(propertySymbol), cb) || recur(type.symbol)); + })); + } + } + function isStaticSymbol(symbol) { + if (!symbol.valueDeclaration) return false; + const modifierFlags = getEffectiveModifierFlags(symbol.valueDeclaration); + return !!(modifierFlags & 256 /* Static */); + } + function getRelatedSymbol(search, referenceSymbol, referenceLocation, state) { + const { checker } = state; + return forEachRelatedSymbol( + referenceSymbol, + referenceLocation, + checker, + /*isForRenamePopulateSearchSymbolSet*/ + false, + /*onlyIncludeBindingElementAtReferenceLocation*/ + state.options.use !== 2 /* Rename */ || !!state.options.providePrefixAndSuffixTextForRename, + (sym, rootSymbol, baseSymbol, kind) => { + if (baseSymbol) { + if (isStaticSymbol(referenceSymbol) !== isStaticSymbol(baseSymbol)) { + baseSymbol = void 0; + } + } + return search.includes(baseSymbol || rootSymbol || sym) ? { symbol: rootSymbol && !(getCheckFlags(sym) & 6 /* Synthetic */) ? rootSymbol : sym, kind } : void 0; + }, + /*allowBaseTypes*/ + (rootSymbol) => !(search.parents && !search.parents.some((parent2) => explicitlyInheritsFrom(rootSymbol.parent, parent2, state.inheritsFromCache, checker))) + ); + } + function getIntersectingMeaningFromDeclarations(node, symbol) { + let meaning = getMeaningFromLocation(node); + const { declarations } = symbol; + if (declarations) { + let lastIterationMeaning; + do { + lastIterationMeaning = meaning; + for (const declaration of declarations) { + const declarationMeaning = getMeaningFromDeclaration(declaration); + if (declarationMeaning & meaning) { + meaning |= declarationMeaning; + } + } + } while (meaning !== lastIterationMeaning); } - break; - case 86 /* ClassKeyword */: - case 94 /* EnumKeyword */: - case 120 /* InterfaceKeyword */: - case 100 /* FunctionKeyword */: - case 115 /* VarKeyword */: - case 102 /* ImportKeyword */: - case 121 /* LetKeyword */: - case 87 /* ConstKeyword */: - case 140 /* InferKeyword */: - return true; - case 156 /* TypeKeyword */: - return containingNodeKind !== 275 /* ImportSpecifier */; - case 42 /* AsteriskToken */: - return isFunctionLike(contextToken2.parent) && !isMethodDeclaration(contextToken2.parent); - } - if (isClassMemberCompletionKeyword(keywordForNode(contextToken2)) && isFromObjectTypeDeclaration(contextToken2)) { - return false; - } - if (isConstructorParameterCompletion(contextToken2)) { - if (!isIdentifier(contextToken2) || isParameterPropertyModifier(keywordForNode(contextToken2)) || isCurrentlyEditingNode(contextToken2)) { - return false; + return meaning; } - } - switch (keywordForNode(contextToken2)) { - case 128 /* AbstractKeyword */: - case 86 /* ClassKeyword */: - case 87 /* ConstKeyword */: - case 138 /* DeclareKeyword */: - case 94 /* EnumKeyword */: - case 100 /* FunctionKeyword */: - case 120 /* InterfaceKeyword */: - case 121 /* LetKeyword */: - case 123 /* PrivateKeyword */: - case 124 /* ProtectedKeyword */: - case 125 /* PublicKeyword */: - case 126 /* StaticKeyword */: - case 115 /* VarKeyword */: - return true; - case 134 /* AsyncKeyword */: - return isPropertyDeclaration(contextToken2.parent); - } - const ancestorClassLike = findAncestor(contextToken2.parent, isClassLike); - if (ancestorClassLike && contextToken2 === previousToken && isPreviousPropertyDeclarationTerminated(contextToken2, position)) { - return false; - } - const ancestorPropertyDeclaraion = getAncestor(contextToken2.parent, 171 /* PropertyDeclaration */); - if (ancestorPropertyDeclaraion && contextToken2 !== previousToken && isClassLike(previousToken.parent.parent) && position <= previousToken.end) { - if (isPreviousPropertyDeclarationTerminated(contextToken2, previousToken.end)) { - return false; - } else if (contextToken2.kind !== 64 /* EqualsToken */ && (isInitializedProperty(ancestorPropertyDeclaraion) || hasType(ancestorPropertyDeclaraion))) { - return true; + Core2.getIntersectingMeaningFromDeclarations = getIntersectingMeaningFromDeclarations; + function isImplementation(node) { + return !!(node.flags & 33554432 /* Ambient */) ? !(isInterfaceDeclaration(node) || isTypeAliasDeclaration(node)) : isVariableLike(node) ? hasInitializer(node) : isFunctionLikeDeclaration(node) ? !!node.body : isClassLike(node) || isModuleOrEnumDeclaration(node); } - } - return isDeclarationName(contextToken2) && !isShorthandPropertyAssignment(contextToken2.parent) && !isJsxAttribute(contextToken2.parent) && !((isClassLike(contextToken2.parent) || isInterfaceDeclaration(contextToken2.parent) || isTypeParameterDeclaration(contextToken2.parent)) && (contextToken2 !== previousToken || position > previousToken.end)); + function getReferenceEntriesForShorthandPropertyAssignment(node, checker, addReference2) { + const refSymbol = checker.getSymbolAtLocation(node); + const shorthandSymbol = checker.getShorthandAssignmentValueSymbol(refSymbol.valueDeclaration); + if (shorthandSymbol) { + for (const declaration of shorthandSymbol.getDeclarations()) { + if (getMeaningFromDeclaration(declaration) & 1 /* Value */) { + addReference2(declaration); + } + } + } + } + Core2.getReferenceEntriesForShorthandPropertyAssignment = getReferenceEntriesForShorthandPropertyAssignment; + function forEachDescendantOfKind(node, kind, action) { + forEachChild(node, (child) => { + if (child.kind === kind) { + action(child); + } + forEachDescendantOfKind(child, kind, action); + }); + } + function tryGetClassByExtendingIdentifier(node) { + return tryGetClassExtendingExpressionWithTypeArguments(climbPastPropertyAccess(node).parent); + } + function getParentSymbolsOfPropertyAccess(location, symbol, checker) { + const propertyAccessExpression = isRightSideOfPropertyAccess(location) ? location.parent : void 0; + const lhsType = propertyAccessExpression && checker.getTypeAtLocation(propertyAccessExpression.expression); + const res = mapDefined(lhsType && (lhsType.isUnionOrIntersection() ? lhsType.types : lhsType.symbol === symbol.parent ? void 0 : [lhsType]), (t) => t.symbol && t.symbol.flags & (32 /* Class */ | 64 /* Interface */) ? t.symbol : void 0); + return res.length === 0 ? void 0 : res; + } + function isForRenameWithPrefixAndSuffixText(options) { + return options.use === 2 /* Rename */ && options.providePrefixAndSuffixTextForRename; + } + })(Core || (Core = {})); } - function isPreviousPropertyDeclarationTerminated(contextToken2, position2) { - return contextToken2.kind !== 64 /* EqualsToken */ && (contextToken2.kind === 27 /* SemicolonToken */ || !positionsAreOnSameLine(contextToken2.end, position2, sourceFile)); + }); + + // src/services/_namespaces/ts.FindAllReferences.ts + var ts_FindAllReferences_exports = {}; + __export(ts_FindAllReferences_exports, { + Core: () => Core, + DefinitionKind: () => DefinitionKind, + EntryKind: () => EntryKind, + ExportKind: () => ExportKind2, + FindReferencesUse: () => FindReferencesUse, + ImportExport: () => ImportExport, + createImportTracker: () => createImportTracker, + findModuleReferences: () => findModuleReferences, + findReferenceOrRenameEntries: () => findReferenceOrRenameEntries, + findReferencedSymbols: () => findReferencedSymbols, + getContextNode: () => getContextNode, + getExportInfo: () => getExportInfo, + getImplementationsAtPosition: () => getImplementationsAtPosition, + getImportOrExportSymbol: () => getImportOrExportSymbol, + getReferenceEntriesForNode: () => getReferenceEntriesForNode, + getTextSpanOfEntry: () => getTextSpanOfEntry, + isContextWithStartAndEndNode: () => isContextWithStartAndEndNode, + isDeclarationOfSymbol: () => isDeclarationOfSymbol, + isWriteAccessForReference: () => isWriteAccessForReference, + nodeEntry: () => nodeEntry, + toContextSpan: () => toContextSpan, + toHighlightSpan: () => toHighlightSpan, + toReferenceEntry: () => toReferenceEntry, + toRenameLocation: () => toRenameLocation + }); + var init_ts_FindAllReferences = __esm({ + "src/services/_namespaces/ts.FindAllReferences.ts"() { + "use strict"; + init_importTracker(); + init_findAllReferences(); + } + }); + + // src/services/goToDefinition.ts + function getDefinitionAtPosition(program, sourceFile, position, searchOtherFilesOnly, stopAtAlias) { + var _a; + const resolvedRef = getReferenceAtPosition(sourceFile, position, program); + const fileReferenceDefinition = resolvedRef && [getDefinitionInfoForFileReference(resolvedRef.reference.fileName, resolvedRef.fileName, resolvedRef.unverified)] || emptyArray; + if (resolvedRef == null ? void 0 : resolvedRef.file) { + return fileReferenceDefinition; } - function isFunctionLikeButNotConstructor(kind) { - return isFunctionLikeKind(kind) && kind !== 175 /* Constructor */; + const node = getTouchingPropertyName(sourceFile, position); + if (node === sourceFile) { + return void 0; } - function isDotOfNumericLiteral(contextToken2) { - if (contextToken2.kind === 9 /* NumericLiteral */) { - const text = contextToken2.getFullText(); - return text.charAt(text.length - 1) === "."; - } - return false; + const { parent: parent2 } = node; + const typeChecker = program.getTypeChecker(); + if (node.kind === 164 /* OverrideKeyword */ || isIdentifier(node) && isJSDocOverrideTag(parent2) && parent2.tagName === node) { + return getDefinitionFromOverriddenMember(typeChecker, node) || emptyArray; } - function isVariableDeclarationListButNotTypeArgument(node2) { - return node2.parent.kind === 260 /* VariableDeclarationList */ && !isPossiblyTypeArgumentPosition(node2, sourceFile, typeChecker); + if (isJumpStatementTarget(node)) { + const label = getTargetLabel(node.parent, node.text); + return label ? [createDefinitionInfoFromName( + typeChecker, + label, + "label" /* label */, + node.text, + /*containerName*/ + void 0 + )] : void 0; } - function filterObjectMembersList(contextualMemberSymbols, existingMembers) { - if (existingMembers.length === 0) { - return contextualMemberSymbols; - } - const membersDeclaredBySpreadAssignment = /* @__PURE__ */ new Set(); - const existingMemberNames = /* @__PURE__ */ new Set(); - for (const m of existingMembers) { - if (m.kind !== 302 /* PropertyAssignment */ && m.kind !== 303 /* ShorthandPropertyAssignment */ && m.kind !== 207 /* BindingElement */ && m.kind !== 173 /* MethodDeclaration */ && m.kind !== 176 /* GetAccessor */ && m.kind !== 177 /* SetAccessor */ && m.kind !== 304 /* SpreadAssignment */) { - continue; - } - if (isCurrentlyEditingNode(m)) { - continue; - } - let existingName; - if (isSpreadAssignment(m)) { - setMembersDeclaredBySpreadAssignment(m, membersDeclaredBySpreadAssignment); - } else if (isBindingElement(m) && m.propertyName) { - if (m.propertyName.kind === 80 /* Identifier */) { - existingName = m.propertyName.escapedText; - } - } else { - const name = getNameOfDeclaration(m); - existingName = name && isPropertyNameLiteral(name) ? getEscapedTextOfIdentifierOrLiteral(name) : void 0; - } - if (existingName !== void 0) { - existingMemberNames.add(existingName); - } - } - const filteredSymbols = contextualMemberSymbols.filter((m) => !existingMemberNames.has(m.escapedName)); - setSortTextToMemberDeclaredBySpreadAssignment(membersDeclaredBySpreadAssignment, filteredSymbols); - return filteredSymbols; + if (node.kind === 107 /* ReturnKeyword */) { + const functionDeclaration = findAncestor(node.parent, (n) => isClassStaticBlockDeclaration(n) ? "quit" : isFunctionLikeDeclaration(n)); + return functionDeclaration ? [createDefinitionFromSignatureDeclaration(typeChecker, functionDeclaration)] : void 0; } - function setMembersDeclaredBySpreadAssignment(declaration, membersDeclaredBySpreadAssignment) { - const expression = declaration.expression; - const symbol = typeChecker.getSymbolAtLocation(expression); - const type = symbol && typeChecker.getTypeOfSymbolAtLocation(symbol, expression); - const properties = type && type.properties; - if (properties) { - properties.forEach((property) => { - membersDeclaredBySpreadAssignment.add(property.name); - }); - } + if (node.kind === 135 /* AwaitKeyword */) { + const functionDeclaration = findAncestor(node, (n) => isFunctionLikeDeclaration(n)); + const isAsyncFunction2 = functionDeclaration && some(functionDeclaration.modifiers, (node2) => node2.kind === 134 /* AsyncKeyword */); + return isAsyncFunction2 ? [createDefinitionFromSignatureDeclaration(typeChecker, functionDeclaration)] : void 0; } - function setSortTextToOptionalMember() { - symbols.forEach((m) => { - if (m.flags & 16777216 /* Optional */) { - const symbolId = getSymbolId(m); - symbolToSortTextMap[symbolId] = symbolToSortTextMap[symbolId] ?? SortText.OptionalMember; - } + if (node.kind === 127 /* YieldKeyword */) { + const functionDeclaration = findAncestor(node, (n) => isFunctionLikeDeclaration(n)); + const isGeneratorFunction = functionDeclaration && functionDeclaration.asteriskToken; + return isGeneratorFunction ? [createDefinitionFromSignatureDeclaration(typeChecker, functionDeclaration)] : void 0; + } + if (isStaticModifier(node) && isClassStaticBlockDeclaration(node.parent)) { + const classDecl = node.parent.parent; + const { symbol: symbol2, failedAliasResolution: failedAliasResolution2 } = getSymbol(classDecl, typeChecker, stopAtAlias); + const staticBlocks = filter(classDecl.members, isClassStaticBlockDeclaration); + const containerName = symbol2 ? typeChecker.symbolToString(symbol2, classDecl) : ""; + const sourceFile2 = node.getSourceFile(); + return map(staticBlocks, (staticBlock) => { + let { pos } = moveRangePastModifiers(staticBlock); + pos = skipTrivia(sourceFile2.text, pos); + return createDefinitionInfoFromName( + typeChecker, + staticBlock, + "constructor" /* constructorImplementationElement */, + "static {}", + containerName, + /*unverified*/ + false, + failedAliasResolution2, + { start: pos, length: "static".length } + ); }); } - function setSortTextToMemberDeclaredBySpreadAssignment(membersDeclaredBySpreadAssignment, contextualMemberSymbols) { - if (membersDeclaredBySpreadAssignment.size === 0) { - return; - } - for (const contextualMemberSymbol of contextualMemberSymbols) { - if (membersDeclaredBySpreadAssignment.has(contextualMemberSymbol.name)) { - symbolToSortTextMap[getSymbolId(contextualMemberSymbol)] = SortText.MemberDeclaredBySpreadAssignment; - } + let { symbol, failedAliasResolution } = getSymbol(node, typeChecker, stopAtAlias); + let fallbackNode = node; + if (searchOtherFilesOnly && failedAliasResolution) { + const importDeclaration = forEach([node, ...(symbol == null ? void 0 : symbol.declarations) || emptyArray], (n) => findAncestor(n, isAnyImportOrBareOrAccessedRequire)); + const moduleSpecifier = importDeclaration && tryGetModuleSpecifierFromDeclaration(importDeclaration); + if (moduleSpecifier) { + ({ symbol, failedAliasResolution } = getSymbol(moduleSpecifier, typeChecker, stopAtAlias)); + fallbackNode = moduleSpecifier; } } - function transformObjectLiteralMembersSortText(start2) { - for (let i = start2; i < symbols.length; i++) { - const symbol = symbols[i]; - const symbolId = getSymbolId(symbol); - const origin = symbolToOriginInfoMap == null ? void 0 : symbolToOriginInfoMap[i]; - const target = getEmitScriptTarget(compilerOptions); - const displayName = getCompletionEntryDisplayNameForSymbol( - symbol, - target, - origin, - 0 /* ObjectPropertyDeclaration */, - /*jsxIdentifierExpected*/ - false - ); - if (displayName) { - const originalSortText = symbolToSortTextMap[symbolId] ?? SortText.LocationPriority; - const { name } = displayName; - symbolToSortTextMap[symbolId] = SortText.ObjectLiteralProperty(originalSortText, name); - } + if (!symbol && isModuleSpecifierLike(fallbackNode)) { + const ref = (_a = program.getResolvedModule(sourceFile, fallbackNode.text, getModeForUsageLocation(sourceFile, fallbackNode))) == null ? void 0 : _a.resolvedModule; + if (ref) { + return [{ + name: fallbackNode.text, + fileName: ref.resolvedFileName, + containerName: void 0, + containerKind: void 0, + kind: "script" /* scriptElement */, + textSpan: createTextSpan(0, 0), + failedAliasResolution, + isAmbient: isDeclarationFileName(ref.resolvedFileName), + unverified: fallbackNode !== node + }]; } } - function filterClassMembersList(baseSymbols, existingMembers, currentClassElementModifierFlags) { - const existingMemberNames = /* @__PURE__ */ new Set(); - for (const m of existingMembers) { - if (m.kind !== 171 /* PropertyDeclaration */ && m.kind !== 173 /* MethodDeclaration */ && m.kind !== 176 /* GetAccessor */ && m.kind !== 177 /* SetAccessor */) { - continue; - } - if (isCurrentlyEditingNode(m)) { - continue; - } - if (hasEffectiveModifier(m, 8 /* Private */)) { - continue; - } - if (isStatic(m) !== !!(currentClassElementModifierFlags & 32 /* Static */)) { - continue; - } - const existingName = getPropertyNameForPropertyNameNode(m.name); - if (existingName) { - existingMemberNames.add(existingName); - } - } - return baseSymbols.filter((propertySymbol) => !existingMemberNames.has(propertySymbol.escapedName) && !!propertySymbol.declarations && !(getDeclarationModifierFlagsFromSymbol(propertySymbol) & 8 /* Private */) && !(propertySymbol.valueDeclaration && isPrivateIdentifierClassElementDeclaration(propertySymbol.valueDeclaration))); + if (!symbol) { + return concatenate(fileReferenceDefinition, getDefinitionInfoForIndexSignatures(node, typeChecker)); } - function filterJsxAttributes(symbols2, attributes) { - const seenNames = /* @__PURE__ */ new Set(); - const membersDeclaredBySpreadAssignment = /* @__PURE__ */ new Set(); - for (const attr of attributes) { - if (isCurrentlyEditingNode(attr)) { - continue; - } - if (attr.kind === 290 /* JsxAttribute */) { - seenNames.add(getEscapedTextOfJsxAttributeName(attr.name)); - } else if (isJsxSpreadAttribute(attr)) { - setMembersDeclaredBySpreadAssignment(attr, membersDeclaredBySpreadAssignment); - } + if (searchOtherFilesOnly && every(symbol.declarations, (d) => d.getSourceFile().fileName === sourceFile.fileName)) + return void 0; + const calledDeclaration = tryGetSignatureDeclaration(typeChecker, node); + if (calledDeclaration && !(isJsxOpeningLikeElement(node.parent) && isConstructorLike(calledDeclaration))) { + const sigInfo = createDefinitionFromSignatureDeclaration(typeChecker, calledDeclaration, failedAliasResolution); + if (typeChecker.getRootSymbols(symbol).some((s) => symbolMatchesSignature(s, calledDeclaration))) { + return [sigInfo]; + } else { + const defs = getDefinitionFromSymbol(typeChecker, symbol, node, failedAliasResolution, calledDeclaration) || emptyArray; + return node.kind === 108 /* SuperKeyword */ ? [sigInfo, ...defs] : [...defs, sigInfo]; } - const filteredSymbols = symbols2.filter((a) => !seenNames.has(a.escapedName)); - setSortTextToMemberDeclaredBySpreadAssignment(membersDeclaredBySpreadAssignment, filteredSymbols); - return filteredSymbols; } - function isCurrentlyEditingNode(node2) { - return node2.getStart(sourceFile) <= position && position <= node2.getEnd(); + if (node.parent.kind === 304 /* ShorthandPropertyAssignment */) { + const shorthandSymbol = typeChecker.getShorthandAssignmentValueSymbol(symbol.valueDeclaration); + const definitions = (shorthandSymbol == null ? void 0 : shorthandSymbol.declarations) ? shorthandSymbol.declarations.map((decl) => createDefinitionInfo( + decl, + typeChecker, + shorthandSymbol, + node, + /*unverified*/ + false, + failedAliasResolution + )) : emptyArray; + return concatenate(definitions, getDefinitionFromObjectLiteralElement(typeChecker, node)); } - } - function tryGetObjectLikeCompletionContainer(contextToken) { - if (contextToken) { - const { parent: parent2 } = contextToken; - switch (contextToken.kind) { - case 19 /* OpenBraceToken */: - case 28 /* CommaToken */: - if (isObjectLiteralExpression(parent2) || isObjectBindingPattern(parent2)) { - return parent2; - } - break; - case 42 /* AsteriskToken */: - return isMethodDeclaration(parent2) ? tryCast(parent2.parent, isObjectLiteralExpression) : void 0; - case 134 /* AsyncKeyword */: - return tryCast(parent2.parent, isObjectLiteralExpression); - case 80 /* Identifier */: - return contextToken.text === "async" && isShorthandPropertyAssignment(contextToken.parent) ? contextToken.parent.parent : void 0; - } + if (isPropertyName(node) && isBindingElement(parent2) && isObjectBindingPattern(parent2.parent) && node === (parent2.propertyName || parent2.name)) { + const name = getNameFromPropertyName(node); + const type = typeChecker.getTypeAtLocation(parent2.parent); + return name === void 0 ? emptyArray : flatMap(type.isUnion() ? type.types : [type], (t) => { + const prop = t.getProperty(name); + return prop && getDefinitionFromSymbol(typeChecker, prop, node); + }); } - return void 0; + const objectLiteralElementDefinition = getDefinitionFromObjectLiteralElement(typeChecker, node); + return concatenate(fileReferenceDefinition, objectLiteralElementDefinition.length ? objectLiteralElementDefinition : getDefinitionFromSymbol(typeChecker, symbol, node, failedAliasResolution)); } - function getRelevantTokens(position, sourceFile) { - const previousToken = findPrecedingToken(position, sourceFile); - if (previousToken && position <= previousToken.end && (isMemberName(previousToken) || isKeyword(previousToken.kind))) { - const contextToken = findPrecedingToken( - previousToken.getFullStart(), - sourceFile, - /*startNode*/ - void 0 - ); - return { contextToken, previousToken }; + function symbolMatchesSignature(s, calledDeclaration) { + var _a; + return s === calledDeclaration.symbol || s === calledDeclaration.symbol.parent || isAssignmentExpression(calledDeclaration.parent) || !isCallLikeExpression(calledDeclaration.parent) && s === ((_a = tryCast(calledDeclaration.parent, canHaveSymbol)) == null ? void 0 : _a.symbol); + } + function getDefinitionFromObjectLiteralElement(typeChecker, node) { + const element = getContainingObjectLiteralElement(node); + if (element) { + const contextualType = element && typeChecker.getContextualType(element.parent); + if (contextualType) { + return flatMap(getPropertySymbolsFromContextualType( + element, + typeChecker, + contextualType, + /*unionSymbolOk*/ + false + ), (propertySymbol) => getDefinitionFromSymbol(typeChecker, propertySymbol, node)); + } } - return { contextToken: previousToken, previousToken }; + return emptyArray; } - function getAutoImportSymbolFromCompletionEntryData(name, data, program, host) { - const containingProgram = data.isPackageJsonImport ? host.getPackageJsonAutoImportProvider() : program; - const checker = containingProgram.getTypeChecker(); - const moduleSymbol = data.ambientModuleName ? checker.tryFindAmbientModule(data.ambientModuleName) : data.fileName ? checker.getMergedSymbol(Debug.checkDefined(containingProgram.getSourceFile(data.fileName)).symbol) : void 0; - if (!moduleSymbol) - return void 0; - let symbol = data.exportName === "export=" /* ExportEquals */ ? checker.resolveExternalModuleSymbol(moduleSymbol) : checker.tryGetMemberInModuleExportsAndProperties(data.exportName, moduleSymbol); + function getDefinitionFromOverriddenMember(typeChecker, node) { + const classElement = findAncestor(node, isClassElement); + if (!(classElement && classElement.name)) + return; + const baseDeclaration = findAncestor(classElement, isClassLike); + if (!baseDeclaration) + return; + const baseTypeNode = getEffectiveBaseTypeNode(baseDeclaration); + if (!baseTypeNode) + return; + const expression = skipParentheses(baseTypeNode.expression); + const base = isClassExpression(expression) ? expression.symbol : typeChecker.getSymbolAtLocation(expression); + if (!base) + return; + const name = unescapeLeadingUnderscores(getTextOfPropertyName(classElement.name)); + const symbol = hasStaticModifier(classElement) ? typeChecker.getPropertyOfType(typeChecker.getTypeOfSymbol(base), name) : typeChecker.getPropertyOfType(typeChecker.getDeclaredTypeOfSymbol(base), name); if (!symbol) - return void 0; - const isDefaultExport = data.exportName === "default" /* Default */; - symbol = isDefaultExport && getLocalSymbolForExportDefault(symbol) || symbol; - return { symbol, origin: completionEntryDataToSymbolOriginInfo(data, name, moduleSymbol) }; + return; + return getDefinitionFromSymbol(typeChecker, symbol, node); } - function getCompletionEntryDisplayNameForSymbol(symbol, target, origin, kind, jsxIdentifierExpected) { - if (originIsIgnore(origin)) { - return void 0; + function getReferenceAtPosition(sourceFile, position, program) { + var _a, _b; + const referencePath = findReferenceInPosition(sourceFile.referencedFiles, position); + if (referencePath) { + const file = program.getSourceFileFromReference(sourceFile, referencePath); + return file && { reference: referencePath, fileName: file.fileName, file, unverified: false }; } - const name = originIncludesSymbolName(origin) ? origin.symbolName : symbol.name; - if (name === void 0 || symbol.flags & 1536 /* Module */ && isSingleOrDoubleQuote(name.charCodeAt(0)) || isKnownSymbol(symbol)) { - return void 0; + const typeReferenceDirective = findReferenceInPosition(sourceFile.typeReferenceDirectives, position); + if (typeReferenceDirective) { + const reference = (_a = program.getResolvedTypeReferenceDirectives().get(typeReferenceDirective.fileName, typeReferenceDirective.resolutionMode || sourceFile.impliedNodeFormat)) == null ? void 0 : _a.resolvedTypeReferenceDirective; + const file = reference && program.getSourceFile(reference.resolvedFileName); + return file && { reference: typeReferenceDirective, fileName: file.fileName, file, unverified: false }; } - const validNameResult = { name, needsConvertPropertyAccess: false }; - if (isIdentifierText(name, target, jsxIdentifierExpected ? 1 /* JSX */ : 0 /* Standard */) || symbol.valueDeclaration && isPrivateIdentifierClassElementDeclaration(symbol.valueDeclaration)) { - return validNameResult; + const libReferenceDirective = findReferenceInPosition(sourceFile.libReferenceDirectives, position); + if (libReferenceDirective) { + const file = program.getLibFileFromReference(libReferenceDirective); + return file && { reference: libReferenceDirective, fileName: file.fileName, file, unverified: false }; } - switch (kind) { - case 3 /* MemberLike */: - return originIsComputedPropertyName(origin) ? { name: origin.symbolName, needsConvertPropertyAccess: false } : void 0; - case 0 /* ObjectPropertyDeclaration */: - return { name: JSON.stringify(name), needsConvertPropertyAccess: false }; - case 2 /* PropertyAccess */: - case 1 /* Global */: - return name.charCodeAt(0) === 32 /* space */ ? void 0 : { name, needsConvertPropertyAccess: true }; - case 5 /* None */: - case 4 /* String */: - return validNameResult; - default: - Debug.assertNever(kind); + if (sourceFile.imports.length || sourceFile.moduleAugmentations.length) { + const node = getTouchingToken(sourceFile, position); + let resolution; + if (isModuleSpecifierLike(node) && isExternalModuleNameRelative(node.text) && (resolution = program.getResolvedModule(sourceFile, node.text, getModeForUsageLocation(sourceFile, node)))) { + const verifiedFileName = (_b = resolution.resolvedModule) == null ? void 0 : _b.resolvedFileName; + const fileName = verifiedFileName || resolvePath(getDirectoryPath(sourceFile.fileName), node.text); + return { + file: program.getSourceFile(fileName), + fileName, + reference: { + pos: node.getStart(), + end: node.getEnd(), + fileName: node.text + }, + unverified: !verifiedFileName + }; + } } + return void 0; } - function getKeywordCompletions(keywordFilter, filterOutTsOnlyKeywords) { - if (!filterOutTsOnlyKeywords) - return getTypescriptKeywordCompletions(keywordFilter); - const index = keywordFilter + 8 /* Last */ + 1; - return _keywordCompletions[index] || (_keywordCompletions[index] = getTypescriptKeywordCompletions(keywordFilter).filter((entry) => !isTypeScriptOnlyKeyword(stringToToken(entry.name)))); + function shouldUnwrapFirstTypeArgumentTypeDefinitionFromTypeReference(typeChecker, type) { + const referenceName = type.symbol.name; + if (!typesWithUnwrappedTypeArguments.has(referenceName)) { + return false; + } + const globalType = typeChecker.resolveName( + referenceName, + /*location*/ + void 0, + 788968 /* Type */, + /*excludeGlobals*/ + false + ); + return !!globalType && globalType === type.target.symbol; } - function getTypescriptKeywordCompletions(keywordFilter) { - return _keywordCompletions[keywordFilter] || (_keywordCompletions[keywordFilter] = allKeywordsCompletions().filter((entry) => { - const kind = stringToToken(entry.name); - switch (keywordFilter) { - case 0 /* None */: - return false; - case 1 /* All */: - return isFunctionLikeBodyKeyword(kind) || kind === 138 /* DeclareKeyword */ || kind === 144 /* ModuleKeyword */ || kind === 156 /* TypeKeyword */ || kind === 145 /* NamespaceKeyword */ || kind === 128 /* AbstractKeyword */ || isTypeKeyword(kind) && kind !== 157 /* UndefinedKeyword */; - case 5 /* FunctionLikeBodyKeywords */: - return isFunctionLikeBodyKeyword(kind); - case 2 /* ClassElementKeywords */: - return isClassMemberCompletionKeyword(kind); - case 3 /* InterfaceElementKeywords */: - return isInterfaceOrTypeLiteralCompletionKeyword(kind); - case 4 /* ConstructorParameterKeywords */: - return isParameterPropertyModifier(kind); - case 6 /* TypeAssertionKeywords */: - return isTypeKeyword(kind) || kind === 87 /* ConstKeyword */; - case 7 /* TypeKeywords */: - return isTypeKeyword(kind); - case 8 /* TypeKeyword */: - return kind === 156 /* TypeKeyword */; - default: - return Debug.assertNever(keywordFilter); + function shouldUnwrapFirstTypeArgumentTypeDefinitionFromAlias(typeChecker, type) { + if (!type.aliasSymbol) { + return false; + } + const referenceName = type.aliasSymbol.name; + if (!typesWithUnwrappedTypeArguments.has(referenceName)) { + return false; + } + const globalType = typeChecker.resolveName( + referenceName, + /*location*/ + void 0, + 788968 /* Type */, + /*excludeGlobals*/ + false + ); + return !!globalType && globalType === type.aliasSymbol; + } + function getFirstTypeArgumentDefinitions(typeChecker, type, node, failedAliasResolution) { + var _a, _b; + if (!!(getObjectFlags(type) & 4 /* Reference */) && shouldUnwrapFirstTypeArgumentTypeDefinitionFromTypeReference(typeChecker, type)) { + return definitionFromType(typeChecker.getTypeArguments(type)[0], typeChecker, node, failedAliasResolution); + } + if (shouldUnwrapFirstTypeArgumentTypeDefinitionFromAlias(typeChecker, type) && type.aliasTypeArguments) { + return definitionFromType(type.aliasTypeArguments[0], typeChecker, node, failedAliasResolution); + } + if (getObjectFlags(type) & 32 /* Mapped */ && type.target && shouldUnwrapFirstTypeArgumentTypeDefinitionFromAlias(typeChecker, type.target)) { + const declaration = (_b = (_a = type.aliasSymbol) == null ? void 0 : _a.declarations) == null ? void 0 : _b[0]; + if (declaration && isTypeAliasDeclaration(declaration) && isTypeReferenceNode(declaration.type) && declaration.type.typeArguments) { + return definitionFromType(typeChecker.getTypeAtLocation(declaration.type.typeArguments[0]), typeChecker, node, failedAliasResolution); } - })); + } + return []; } - function isTypeScriptOnlyKeyword(kind) { - switch (kind) { - case 128 /* AbstractKeyword */: - case 133 /* AnyKeyword */: - case 162 /* BigIntKeyword */: - case 136 /* BooleanKeyword */: - case 138 /* DeclareKeyword */: - case 94 /* EnumKeyword */: - case 161 /* GlobalKeyword */: - case 119 /* ImplementsKeyword */: - case 140 /* InferKeyword */: - case 120 /* InterfaceKeyword */: - case 142 /* IsKeyword */: - case 143 /* KeyOfKeyword */: - case 144 /* ModuleKeyword */: - case 145 /* NamespaceKeyword */: - case 146 /* NeverKeyword */: - case 150 /* NumberKeyword */: - case 151 /* ObjectKeyword */: - case 163 /* OverrideKeyword */: - case 123 /* PrivateKeyword */: - case 124 /* ProtectedKeyword */: - case 125 /* PublicKeyword */: - case 148 /* ReadonlyKeyword */: - case 154 /* StringKeyword */: - case 155 /* SymbolKeyword */: - case 156 /* TypeKeyword */: - case 158 /* UniqueKeyword */: - case 159 /* UnknownKeyword */: - return true; - default: - return false; + function getTypeDefinitionAtPosition(typeChecker, sourceFile, position) { + const node = getTouchingPropertyName(sourceFile, position); + if (node === sourceFile) { + return void 0; + } + if (isImportMeta(node.parent) && node.parent.name === node) { + return definitionFromType( + typeChecker.getTypeAtLocation(node.parent), + typeChecker, + node.parent, + /*failedAliasResolution*/ + false + ); } + const { symbol, failedAliasResolution } = getSymbol( + node, + typeChecker, + /*stopAtAlias*/ + false + ); + if (!symbol) + return void 0; + const typeAtLocation = typeChecker.getTypeOfSymbolAtLocation(symbol, node); + const returnType = tryGetReturnTypeOfFunction(symbol, typeAtLocation, typeChecker); + const fromReturnType = returnType && definitionFromType(returnType, typeChecker, node, failedAliasResolution); + const [resolvedType, typeDefinitions] = fromReturnType && fromReturnType.length !== 0 ? [returnType, fromReturnType] : [typeAtLocation, definitionFromType(typeAtLocation, typeChecker, node, failedAliasResolution)]; + return typeDefinitions.length ? [...getFirstTypeArgumentDefinitions(typeChecker, resolvedType, node, failedAliasResolution), ...typeDefinitions] : !(symbol.flags & 111551 /* Value */) && symbol.flags & 788968 /* Type */ ? getDefinitionFromSymbol(typeChecker, skipAlias(symbol, typeChecker), node, failedAliasResolution) : void 0; } - function isInterfaceOrTypeLiteralCompletionKeyword(kind) { - return kind === 148 /* ReadonlyKeyword */; + function definitionFromType(type, checker, node, failedAliasResolution) { + return flatMap(type.isUnion() && !(type.flags & 32 /* Enum */) ? type.types : [type], (t) => t.symbol && getDefinitionFromSymbol(checker, t.symbol, node, failedAliasResolution)); } - function isClassMemberCompletionKeyword(kind) { - switch (kind) { - case 128 /* AbstractKeyword */: - case 129 /* AccessorKeyword */: - case 137 /* ConstructorKeyword */: - case 139 /* GetKeyword */: - case 153 /* SetKeyword */: - case 134 /* AsyncKeyword */: - case 138 /* DeclareKeyword */: - case 163 /* OverrideKeyword */: - return true; - default: - return isClassMemberModifier(kind); + function tryGetReturnTypeOfFunction(symbol, type, checker) { + if (type.symbol === symbol || // At `const f = () => {}`, the symbol is `f` and the type symbol is at `() => {}` + symbol.valueDeclaration && type.symbol && isVariableDeclaration(symbol.valueDeclaration) && symbol.valueDeclaration.initializer === type.symbol.valueDeclaration) { + const sigs = type.getCallSignatures(); + if (sigs.length === 1) + return checker.getReturnTypeOfSignature(first(sigs)); } + return void 0; } - function isFunctionLikeBodyKeyword(kind) { - return kind === 134 /* AsyncKeyword */ || kind === 135 /* AwaitKeyword */ || kind === 130 /* AsKeyword */ || kind === 152 /* SatisfiesKeyword */ || kind === 156 /* TypeKeyword */ || !isContextualKeyword(kind) && !isClassMemberCompletionKeyword(kind); + function getDefinitionAndBoundSpan(program, sourceFile, position) { + const definitions = getDefinitionAtPosition(program, sourceFile, position); + if (!definitions || definitions.length === 0) { + return void 0; + } + const comment = findReferenceInPosition(sourceFile.referencedFiles, position) || findReferenceInPosition(sourceFile.typeReferenceDirectives, position) || findReferenceInPosition(sourceFile.libReferenceDirectives, position); + if (comment) { + return { definitions, textSpan: createTextSpanFromRange(comment) }; + } + const node = getTouchingPropertyName(sourceFile, position); + const textSpan = createTextSpan(node.getStart(), node.getWidth()); + return { definitions, textSpan }; } - function keywordForNode(node) { - return isIdentifier(node) ? identifierToKeywordKind(node) ?? 0 /* Unknown */ : node.kind; + function getDefinitionInfoForIndexSignatures(node, checker) { + return mapDefined(checker.getIndexInfosAtLocation(node), (info) => info.declaration && createDefinitionFromSignatureDeclaration(checker, info.declaration)); } - function getContextualKeywords(contextToken, position) { - const entries = []; - if (contextToken) { - const file = contextToken.getSourceFile(); - const parent2 = contextToken.parent; - const tokenLine = file.getLineAndCharacterOfPosition(contextToken.end).line; - const currentLine = file.getLineAndCharacterOfPosition(position).line; - if ((isImportDeclaration(parent2) || isExportDeclaration(parent2) && parent2.moduleSpecifier) && contextToken === parent2.moduleSpecifier && tokenLine === currentLine) { - entries.push({ - name: tokenToString(132 /* AssertKeyword */), - kind: "keyword" /* keyword */, - kindModifiers: "" /* none */, - sortText: SortText.GlobalsOrKeywords - }); + function getSymbol(node, checker, stopAtAlias) { + const symbol = checker.getSymbolAtLocation(node); + let failedAliasResolution = false; + if ((symbol == null ? void 0 : symbol.declarations) && symbol.flags & 2097152 /* Alias */ && !stopAtAlias && shouldSkipAlias(node, symbol.declarations[0])) { + const aliased = checker.getAliasedSymbol(symbol); + if (aliased.declarations) { + return { symbol: aliased }; + } else { + failedAliasResolution = true; } } - return entries; - } - function getJsDocTagAtPosition(node, position) { - return findAncestor(node, (n) => isJSDocTag(n) && rangeContainsPosition(n, position) ? true : isJSDoc(n) ? "quit" : false); + return { symbol, failedAliasResolution }; } - function getPropertiesForObjectExpression(contextualType, completionsType, obj, checker) { - const hasCompletionsType = completionsType && completionsType !== contextualType; - const type = hasCompletionsType && !(completionsType.flags & 3 /* AnyOrUnknown */) ? checker.getUnionType([contextualType, completionsType]) : contextualType; - const properties = getApparentProperties(type, obj, checker); - return type.isClass() && containsNonPublicProperties(properties) ? [] : hasCompletionsType ? filter(properties, hasDeclarationOtherThanSelf) : properties; - function hasDeclarationOtherThanSelf(member) { - if (!length(member.declarations)) - return true; - return some(member.declarations, (decl) => decl.parent !== obj); + function shouldSkipAlias(node, declaration) { + if (node.kind !== 80 /* Identifier */) { + return false; } + if (node.parent === declaration) { + return true; + } + if (declaration.kind === 274 /* NamespaceImport */) { + return false; + } + return true; } - function getApparentProperties(type, node, checker) { - if (!type.isUnion()) - return type.getApparentProperties(); - return checker.getAllPossiblePropertiesOfTypes(filter(type.types, (memberType) => !(memberType.flags & 402784252 /* Primitive */ || checker.isArrayLikeType(memberType) || checker.isTypeInvalidDueToUnionDiscriminant(memberType, node) || checker.typeHasCallOrConstructSignatures(memberType) || memberType.isClass() && containsNonPublicProperties(memberType.getApparentProperties())))); - } - function containsNonPublicProperties(props) { - return some(props, (p) => !!(getDeclarationModifierFlagsFromSymbol(p) & 24 /* NonPublicAccessibilityModifier */)); - } - function getPropertiesForCompletion(type, checker) { - return type.isUnion() ? Debug.checkEachDefined(checker.getAllPossiblePropertiesOfTypes(type.types), "getAllPossiblePropertiesOfTypes() should all be defined") : Debug.checkEachDefined(type.getApparentProperties(), "getApparentProperties() should all be defined"); + function isExpandoDeclaration(node) { + if (!isAssignmentDeclaration(node)) + return false; + const containingAssignment = findAncestor(node, (p) => { + if (isAssignmentExpression(p)) + return true; + if (!isAssignmentDeclaration(p)) + return "quit"; + return false; + }); + return !!containingAssignment && getAssignmentDeclarationKind(containingAssignment) === 5 /* Property */; } - function tryGetObjectTypeDeclarationCompletionContainer(sourceFile, contextToken, location, position) { - switch (location.kind) { - case 357 /* SyntaxList */: - return tryCast(location.parent, isObjectTypeDeclaration); - case 1 /* EndOfFileToken */: - const cls = tryCast(lastOrUndefined(cast(location.parent, isSourceFile).statements), isObjectTypeDeclaration); - if (cls && !findChildOfKind(cls, 20 /* CloseBraceToken */, sourceFile)) { - return cls; - } - break; - case 80 /* Identifier */: { - const originalKeywordKind = identifierToKeywordKind(location); - if (originalKeywordKind) { - return void 0; - } - if (isPropertyDeclaration(location.parent) && location.parent.initializer === location) { - return void 0; - } - if (isFromObjectTypeDeclaration(location)) { - return findAncestor(location, isObjectTypeDeclaration); - } + function getDefinitionFromSymbol(typeChecker, symbol, node, failedAliasResolution, excludeDeclaration) { + const filteredDeclarations = filter(symbol.declarations, (d) => d !== excludeDeclaration); + const withoutExpandos = filter(filteredDeclarations, (d) => !isExpandoDeclaration(d)); + const results = some(withoutExpandos) ? withoutExpandos : filteredDeclarations; + return getConstructSignatureDefinition() || getCallSignatureDefinition() || map(results, (declaration) => createDefinitionInfo( + declaration, + typeChecker, + symbol, + node, + /*unverified*/ + false, + failedAliasResolution + )); + function getConstructSignatureDefinition() { + if (symbol.flags & 32 /* Class */ && !(symbol.flags & (16 /* Function */ | 3 /* Variable */)) && (isNewExpressionTarget(node) || node.kind === 137 /* ConstructorKeyword */)) { + const cls = find(filteredDeclarations, isClassLike) || Debug.fail("Expected declaration to have at least one class-like declaration"); + return getSignatureDefinition( + cls.members, + /*selectConstructors*/ + true + ); } } - if (!contextToken) - return void 0; - if (location.kind === 137 /* ConstructorKeyword */ || isIdentifier(contextToken) && isPropertyDeclaration(contextToken.parent) && isClassLike(location)) { - return findAncestor(contextToken, isClassLike); + function getCallSignatureDefinition() { + return isCallOrNewExpressionTarget(node) || isNameOfFunctionDeclaration(node) ? getSignatureDefinition( + filteredDeclarations, + /*selectConstructors*/ + false + ) : void 0; } - switch (contextToken.kind) { - case 64 /* EqualsToken */: - return void 0; - case 27 /* SemicolonToken */: - case 20 /* CloseBraceToken */: - return isFromObjectTypeDeclaration(location) && location.parent.name === location ? location.parent.parent : tryCast(location, isObjectTypeDeclaration); - case 19 /* OpenBraceToken */: - case 28 /* CommaToken */: - return tryCast(contextToken.parent, isObjectTypeDeclaration); - default: - if (isObjectTypeDeclaration(location)) { - if (getLineAndCharacterOfPosition(sourceFile, contextToken.getEnd()).line !== getLineAndCharacterOfPosition(sourceFile, position).line) { - return location; - } - const isValidKeyword = isClassLike(contextToken.parent.parent) ? isClassMemberCompletionKeyword : isInterfaceOrTypeLiteralCompletionKeyword; - return isValidKeyword(contextToken.kind) || contextToken.kind === 42 /* AsteriskToken */ || isIdentifier(contextToken) && isValidKeyword(identifierToKeywordKind(contextToken) ?? 0 /* Unknown */) ? contextToken.parent.parent : void 0; - } + function getSignatureDefinition(signatureDeclarations, selectConstructors) { + if (!signatureDeclarations) { return void 0; + } + const declarations = signatureDeclarations.filter(selectConstructors ? isConstructorDeclaration : isFunctionLike); + const declarationsWithBody = declarations.filter((d) => !!d.body); + return declarations.length ? declarationsWithBody.length !== 0 ? declarationsWithBody.map((x) => createDefinitionInfo(x, typeChecker, symbol, node)) : [createDefinitionInfo( + last(declarations), + typeChecker, + symbol, + node, + /*unverified*/ + false, + failedAliasResolution + )] : void 0; } } - function tryGetTypeLiteralNode(node) { - if (!node) - return void 0; - const parent2 = node.parent; - switch (node.kind) { - case 19 /* OpenBraceToken */: - if (isTypeLiteralNode(parent2)) { - return parent2; - } - break; - case 27 /* SemicolonToken */: - case 28 /* CommaToken */: - case 80 /* Identifier */: - if (parent2.kind === 170 /* PropertySignature */ && isTypeLiteralNode(parent2.parent)) { - return parent2.parent; - } - break; - } - return void 0; + function createDefinitionInfo(declaration, checker, symbol, node, unverified, failedAliasResolution) { + const symbolName2 = checker.symbolToString(symbol); + const symbolKind = ts_SymbolDisplay_exports.getSymbolKind(checker, symbol, node); + const containerName = symbol.parent ? checker.symbolToString(symbol.parent, node) : ""; + return createDefinitionInfoFromName(checker, declaration, symbolKind, symbolName2, containerName, unverified, failedAliasResolution); } - function getConstraintOfTypeArgumentProperty(node, checker) { - if (!node) - return void 0; - if (isTypeNode(node) && isTypeReferenceType(node.parent)) { - return checker.getTypeArgumentConstraint(node); + function createDefinitionInfoFromName(checker, declaration, symbolKind, symbolName2, containerName, unverified, failedAliasResolution, textSpan) { + const sourceFile = declaration.getSourceFile(); + if (!textSpan) { + const name = getNameOfDeclaration(declaration) || declaration; + textSpan = createTextSpanFromNode(name, sourceFile); } - const t = getConstraintOfTypeArgumentProperty(node.parent, checker); - if (!t) - return void 0; - switch (node.kind) { - case 170 /* PropertySignature */: - return checker.getTypeOfPropertyOfContextualType(t, node.symbol.escapedName); - case 192 /* IntersectionType */: - case 186 /* TypeLiteral */: - case 191 /* UnionType */: - return t; + return { + fileName: sourceFile.fileName, + textSpan, + kind: symbolKind, + name: symbolName2, + containerKind: void 0, + // TODO: GH#18217 + containerName, + ...ts_FindAllReferences_exports.toContextSpan( + textSpan, + sourceFile, + ts_FindAllReferences_exports.getContextNode(declaration) + ), + isLocal: !isDefinitionVisible(checker, declaration), + isAmbient: !!(declaration.flags & 33554432 /* Ambient */), + unverified, + failedAliasResolution + }; + } + function isDefinitionVisible(checker, declaration) { + if (checker.isDeclarationVisible(declaration)) + return true; + if (!declaration.parent) + return false; + if (hasInitializer(declaration.parent) && declaration.parent.initializer === declaration) + return isDefinitionVisible(checker, declaration.parent); + switch (declaration.kind) { + case 172 /* PropertyDeclaration */: + case 177 /* GetAccessor */: + case 178 /* SetAccessor */: + case 174 /* MethodDeclaration */: + if (hasEffectiveModifier(declaration, 2 /* Private */)) + return false; + case 176 /* Constructor */: + case 303 /* PropertyAssignment */: + case 304 /* ShorthandPropertyAssignment */: + case 210 /* ObjectLiteralExpression */: + case 231 /* ClassExpression */: + case 219 /* ArrowFunction */: + case 218 /* FunctionExpression */: + return isDefinitionVisible(checker, declaration.parent); + default: + return false; } } - function isFromObjectTypeDeclaration(node) { - return node.parent && isClassOrTypeElement(node.parent) && isObjectTypeDeclaration(node.parent.parent); + function createDefinitionFromSignatureDeclaration(typeChecker, decl, failedAliasResolution) { + return createDefinitionInfo( + decl, + typeChecker, + decl.symbol, + decl, + /*unverified*/ + false, + failedAliasResolution + ); } - function isValidTrigger(sourceFile, triggerCharacter, contextToken, position) { - switch (triggerCharacter) { - case ".": - case "@": + function findReferenceInPosition(refs, pos) { + return find(refs, (ref) => textRangeContainsPositionInclusive(ref, pos)); + } + function getDefinitionInfoForFileReference(name, targetFileName, unverified) { + return { + fileName: targetFileName, + textSpan: createTextSpanFromBounds(0, 0), + kind: "script" /* scriptElement */, + name, + containerName: void 0, + containerKind: void 0, + // TODO: GH#18217 + unverified + }; + } + function getAncestorCallLikeExpression(node) { + const target = findAncestor(node, (n) => !isRightSideOfPropertyAccess(n)); + const callLike = target == null ? void 0 : target.parent; + return callLike && isCallLikeExpression(callLike) && getInvokedExpression(callLike) === target ? callLike : void 0; + } + function tryGetSignatureDeclaration(typeChecker, node) { + const callLike = getAncestorCallLikeExpression(node); + const signature = callLike && typeChecker.getResolvedSignature(callLike); + return tryCast(signature && signature.declaration, (d) => isFunctionLike(d) && !isFunctionTypeNode(d)); + } + function isConstructorLike(node) { + switch (node.kind) { + case 176 /* Constructor */: + case 185 /* ConstructorType */: + case 180 /* ConstructSignature */: return true; - case '"': - case "'": - case "`": - return !!contextToken && isStringLiteralOrTemplate(contextToken) && position === contextToken.getStart(sourceFile) + 1; - case "#": - return !!contextToken && isPrivateIdentifier(contextToken) && !!getContainingClass(contextToken); - case "<": - return !!contextToken && contextToken.kind === 30 /* LessThanToken */ && (!isBinaryExpression(contextToken.parent) || binaryExpressionMayBeOpenTag(contextToken.parent)); - case "/": - return !!contextToken && (isStringLiteralLike(contextToken) ? !!tryGetImportFromModuleSpecifier(contextToken) : contextToken.kind === 44 /* SlashToken */ && isJsxClosingElement(contextToken.parent)); - case " ": - return !!contextToken && isImportKeyword(contextToken) && contextToken.parent.kind === 311 /* SourceFile */; default: - return Debug.assertNever(triggerCharacter); + return false; } } - function binaryExpressionMayBeOpenTag({ left }) { - return nodeIsMissing(left); - } - function isProbablyGlobalType(type, sourceFile, checker) { - const selfSymbol = checker.resolveName( - "self", - /*location*/ - void 0, - 111551 /* Value */, - /*excludeGlobals*/ - false - ); - if (selfSymbol && checker.getTypeOfSymbolAtLocation(selfSymbol, sourceFile) === type) { - return true; - } - const globalSymbol = checker.resolveName( - "global", - /*location*/ - void 0, - 111551 /* Value */, - /*excludeGlobals*/ - false - ); - if (globalSymbol && checker.getTypeOfSymbolAtLocation(globalSymbol, sourceFile) === type) { - return true; + var typesWithUnwrappedTypeArguments; + var init_goToDefinition = __esm({ + "src/services/goToDefinition.ts"() { + "use strict"; + init_ts4(); + typesWithUnwrappedTypeArguments = /* @__PURE__ */ new Set([ + "Array", + "ArrayLike", + "ReadonlyArray", + "Promise", + "PromiseLike", + "Iterable", + "IterableIterator", + "AsyncIterable", + "Set", + "WeakSet", + "ReadonlySet", + "Map", + "WeakMap", + "ReadonlyMap", + "Partial", + "Required", + "Readonly", + "Pick", + "Omit" + ]); } - const globalThisSymbol = checker.resolveName( - "globalThis", - /*location*/ - void 0, - 111551 /* Value */, - /*excludeGlobals*/ - false - ); - if (globalThisSymbol && checker.getTypeOfSymbolAtLocation(globalThisSymbol, sourceFile) === type) { - return true; + }); + + // src/services/_namespaces/ts.GoToDefinition.ts + var ts_GoToDefinition_exports = {}; + __export(ts_GoToDefinition_exports, { + createDefinitionInfo: () => createDefinitionInfo, + findReferenceInPosition: () => findReferenceInPosition, + getDefinitionAndBoundSpan: () => getDefinitionAndBoundSpan, + getDefinitionAtPosition: () => getDefinitionAtPosition, + getReferenceAtPosition: () => getReferenceAtPosition, + getTypeDefinitionAtPosition: () => getTypeDefinitionAtPosition + }); + var init_ts_GoToDefinition = __esm({ + "src/services/_namespaces/ts.GoToDefinition.ts"() { + "use strict"; + init_goToDefinition(); } - return false; + }); + + // src/services/inlayHints.ts + function shouldShowParameterNameHints(preferences) { + return preferences.includeInlayParameterNameHints === "literals" || preferences.includeInlayParameterNameHints === "all"; } - function isStaticProperty(symbol) { - return !!(symbol.valueDeclaration && getEffectiveModifierFlags(symbol.valueDeclaration) & 32 /* Static */ && isClassLike(symbol.valueDeclaration.parent)); + function shouldShowLiteralParameterNameHintsOnly(preferences) { + return preferences.includeInlayParameterNameHints === "literals"; } - function tryGetObjectLiteralContextualType(node, typeChecker) { - const type = typeChecker.getContextualType(node); - if (type) { - return type; + function shouldUseInteractiveInlayHints(preferences) { + return preferences.interactiveInlayHints === true; + } + function provideInlayHints(context) { + const { file, program, span, cancellationToken, preferences } = context; + const sourceFileText = file.text; + const compilerOptions = program.getCompilerOptions(); + const quotePreference = getQuotePreference(file, preferences); + const checker = program.getTypeChecker(); + const result = []; + visitor(file); + return result; + function visitor(node) { + if (!node || node.getFullWidth() === 0) { + return; + } + switch (node.kind) { + case 267 /* ModuleDeclaration */: + case 263 /* ClassDeclaration */: + case 264 /* InterfaceDeclaration */: + case 262 /* FunctionDeclaration */: + case 231 /* ClassExpression */: + case 218 /* FunctionExpression */: + case 174 /* MethodDeclaration */: + case 219 /* ArrowFunction */: + cancellationToken.throwIfCancellationRequested(); + } + if (!textSpanIntersectsWith(span, node.pos, node.getFullWidth())) { + return; + } + if (isTypeNode(node) && !isExpressionWithTypeArguments(node)) { + return; + } + if (preferences.includeInlayVariableTypeHints && isVariableDeclaration(node)) { + visitVariableLikeDeclaration(node); + } else if (preferences.includeInlayPropertyDeclarationTypeHints && isPropertyDeclaration(node)) { + visitVariableLikeDeclaration(node); + } else if (preferences.includeInlayEnumMemberValueHints && isEnumMember(node)) { + visitEnumMember(node); + } else if (shouldShowParameterNameHints(preferences) && (isCallExpression(node) || isNewExpression(node))) { + visitCallOrNewExpression(node); + } else { + if (preferences.includeInlayFunctionParameterTypeHints && isFunctionLikeDeclaration(node) && hasContextSensitiveParameters(node)) { + visitFunctionLikeForParameterType(node); + } + if (preferences.includeInlayFunctionLikeReturnTypeHints && isSignatureSupportingReturnAnnotation(node)) { + visitFunctionDeclarationLikeForReturnType(node); + } + } + return forEachChild(node, visitor); } - const parent2 = walkUpParenthesizedExpressions(node.parent); - if (isBinaryExpression(parent2) && parent2.operatorToken.kind === 64 /* EqualsToken */ && node === parent2.left) { - return typeChecker.getTypeAtLocation(parent2); + function isSignatureSupportingReturnAnnotation(node) { + return isArrowFunction(node) || isFunctionExpression(node) || isFunctionDeclaration(node) || isMethodDeclaration(node) || isGetAccessorDeclaration(node); } - if (isExpression(parent2)) { - return typeChecker.getContextualType(parent2); + function addParameterHints(text, parameter, position, isFirstVariadicArgument) { + let hintText = `${isFirstVariadicArgument ? "..." : ""}${text}`; + let displayParts; + if (shouldUseInteractiveInlayHints(preferences)) { + displayParts = [getNodeDisplayPart(hintText, parameter), { text: ":" }]; + hintText = ""; + } else { + hintText += ":"; + } + result.push({ + text: hintText, + position, + kind: "Parameter" /* Parameter */, + whitespaceAfter: true, + displayParts + }); } - return void 0; - } - function getImportStatementCompletionInfo(contextToken) { - var _a, _b, _c; - let keywordCompletion; - let isKeywordOnlyCompletion = false; - const candidate = getCandidate(); - return { - isKeywordOnlyCompletion, - keywordCompletion, - isNewIdentifierLocation: !!(candidate || keywordCompletion === 156 /* TypeKeyword */), - isTopLevelTypeOnly: !!((_b = (_a = tryCast(candidate, isImportDeclaration)) == null ? void 0 : _a.importClause) == null ? void 0 : _b.isTypeOnly) || !!((_c = tryCast(candidate, isImportEqualsDeclaration)) == null ? void 0 : _c.isTypeOnly), - couldBeTypeOnlyImportSpecifier: !!candidate && couldBeTypeOnlyImportSpecifier(candidate, contextToken), - replacementSpan: getSingleLineReplacementSpanForImportCompletionNode(candidate) - }; - function getCandidate() { - const parent2 = contextToken.parent; - if (isImportEqualsDeclaration(parent2)) { - keywordCompletion = contextToken.kind === 156 /* TypeKeyword */ ? void 0 : 156 /* TypeKeyword */; - return isModuleSpecifierMissingOrEmpty(parent2.moduleReference) ? parent2 : void 0; + function addTypeHints(hintText, position) { + result.push({ + text: typeof hintText === "string" ? `: ${hintText}` : "", + displayParts: typeof hintText === "string" ? void 0 : [{ text: ": " }, ...hintText], + position, + kind: "Type" /* Type */, + whitespaceBefore: true + }); + } + function addEnumMemberValueHints(text, position) { + result.push({ + text: `= ${text}`, + position, + kind: "Enum" /* Enum */, + whitespaceBefore: true + }); + } + function visitEnumMember(member) { + if (member.initializer) { + return; } - if (couldBeTypeOnlyImportSpecifier(parent2, contextToken) && canCompleteFromNamedBindings(parent2.parent)) { - return parent2; + const enumValue = checker.getConstantValue(member); + if (enumValue !== void 0) { + addEnumMemberValueHints(enumValue.toString(), member.end); } - if (isNamedImports(parent2) || isNamespaceImport(parent2)) { - if (!parent2.parent.isTypeOnly && (contextToken.kind === 19 /* OpenBraceToken */ || contextToken.kind === 102 /* ImportKeyword */ || contextToken.kind === 28 /* CommaToken */)) { - keywordCompletion = 156 /* TypeKeyword */; + } + function isModuleReferenceType(type) { + return type.symbol && type.symbol.flags & 1536 /* Module */; + } + function visitVariableLikeDeclaration(decl) { + if (!decl.initializer || isBindingPattern(decl.name) || isVariableDeclaration(decl) && !isHintableDeclaration(decl)) { + return; + } + const effectiveTypeAnnotation = getEffectiveTypeAnnotationNode(decl); + if (effectiveTypeAnnotation) { + return; + } + const declarationType = checker.getTypeAtLocation(decl); + if (isModuleReferenceType(declarationType)) { + return; + } + const hintParts = typeToInlayHintParts(declarationType); + if (hintParts) { + const hintText = typeof hintParts === "string" ? hintParts : hintParts.map((part) => part.text).join(""); + const isVariableNameMatchesType = preferences.includeInlayVariableTypeHintsWhenTypeMatchesName === false && equateStringsCaseInsensitive(decl.name.getText(), hintText); + if (isVariableNameMatchesType) { + return; } - if (canCompleteFromNamedBindings(parent2)) { - if (contextToken.kind === 20 /* CloseBraceToken */ || contextToken.kind === 80 /* Identifier */) { - isKeywordOnlyCompletion = true; - keywordCompletion = 160 /* FromKeyword */; - } else { - return parent2.parent.parent; + addTypeHints(hintParts, decl.name.end); + } + } + function visitCallOrNewExpression(expr) { + const args = expr.arguments; + if (!args || !args.length) { + return; + } + const candidates = []; + const signature = checker.getResolvedSignatureForSignatureHelp(expr, candidates); + if (!signature || !candidates.length) { + return; + } + let signatureParamPos = 0; + for (const originalArg of args) { + const arg = skipParentheses(originalArg); + if (shouldShowLiteralParameterNameHintsOnly(preferences) && !isHintableLiteral(arg)) { + signatureParamPos++; + continue; + } + let spreadArgs = 0; + if (isSpreadElement(arg)) { + const spreadType = checker.getTypeAtLocation(arg.expression); + if (checker.isTupleType(spreadType)) { + const { elementFlags, fixedLength } = spreadType.target; + if (fixedLength === 0) { + continue; + } + const firstOptionalIndex = findIndex(elementFlags, (f) => !(f & 1 /* Required */)); + const requiredArgs = firstOptionalIndex < 0 ? fixedLength : firstOptionalIndex; + if (requiredArgs > 0) { + spreadArgs = firstOptionalIndex < 0 ? fixedLength : firstOptionalIndex; + } + } + } + const identifierInfo = checker.getParameterIdentifierInfoAtPosition(signature, signatureParamPos); + signatureParamPos = signatureParamPos + (spreadArgs || 1); + if (identifierInfo) { + const { parameter, parameterName, isRestParameter: isFirstVariadicArgument } = identifierInfo; + const isParameterNameNotSameAsArgument = preferences.includeInlayParameterNameHintsWhenArgumentMatchesName || !identifierOrAccessExpressionPostfixMatchesParameterName(arg, parameterName); + if (!isParameterNameNotSameAsArgument && !isFirstVariadicArgument) { + continue; + } + const name = unescapeLeadingUnderscores(parameterName); + if (leadingCommentsContainsParameterName(arg, name)) { + continue; } + addParameterHints(name, parameter, originalArg.getStart(), isFirstVariadicArgument); + } + } + } + function identifierOrAccessExpressionPostfixMatchesParameterName(expr, parameterName) { + if (isIdentifier(expr)) { + return expr.text === parameterName; + } + if (isPropertyAccessExpression(expr)) { + return expr.name.text === parameterName; + } + return false; + } + function leadingCommentsContainsParameterName(node, name) { + if (!isIdentifierText(name, compilerOptions.target, getLanguageVariant(file.scriptKind))) { + return false; + } + const ranges = getLeadingCommentRanges(sourceFileText, node.pos); + if (!(ranges == null ? void 0 : ranges.length)) { + return false; + } + const regex = leadingParameterNameCommentRegexFactory(name); + return some(ranges, (range) => regex.test(sourceFileText.substring(range.pos, range.end))); + } + function isHintableLiteral(node) { + switch (node.kind) { + case 224 /* PrefixUnaryExpression */: { + const operand = node.operand; + return isLiteralExpression(operand) || isIdentifier(operand) && isInfinityOrNaNString(operand.escapedText); + } + case 112 /* TrueKeyword */: + case 97 /* FalseKeyword */: + case 106 /* NullKeyword */: + case 15 /* NoSubstitutionTemplateLiteral */: + case 228 /* TemplateExpression */: + return true; + case 80 /* Identifier */: { + const name = node.escapedText; + return isUndefined(name) || isInfinityOrNaNString(name); + } + } + return isLiteralExpression(node); + } + function visitFunctionDeclarationLikeForReturnType(decl) { + if (isArrowFunction(decl)) { + if (!findChildOfKind(decl, 21 /* OpenParenToken */, file)) { + return; } - return void 0; } - if (isImportKeyword(contextToken) && isSourceFile(parent2)) { - keywordCompletion = 156 /* TypeKeyword */; - return contextToken; + const effectiveTypeAnnotation = getEffectiveReturnTypeNode(decl); + if (effectiveTypeAnnotation || !decl.body) { + return; } - if (isImportKeyword(contextToken) && isImportDeclaration(parent2)) { - keywordCompletion = 156 /* TypeKeyword */; - return isModuleSpecifierMissingOrEmpty(parent2.moduleSpecifier) ? parent2 : void 0; + const signature = checker.getSignatureFromDeclaration(decl); + if (!signature) { + return; + } + const returnType = checker.getReturnTypeOfSignature(signature); + if (isModuleReferenceType(returnType)) { + return; + } + const hintParts = typeToInlayHintParts(returnType); + if (hintParts) { + addTypeHints(hintParts, getTypeAnnotationPosition(decl)); } - return void 0; - } - } - function getSingleLineReplacementSpanForImportCompletionNode(node) { - var _a; - if (!node) - return void 0; - const top = findAncestor(node, or(isImportDeclaration, isImportEqualsDeclaration)) ?? node; - const sourceFile = top.getSourceFile(); - if (rangeIsOnSingleLine(top, sourceFile)) { - return createTextSpanFromNode(top, sourceFile); - } - Debug.assert(top.kind !== 102 /* ImportKeyword */ && top.kind !== 275 /* ImportSpecifier */); - const potentialSplitPoint = top.kind === 271 /* ImportDeclaration */ ? getPotentiallyInvalidImportSpecifier((_a = top.importClause) == null ? void 0 : _a.namedBindings) ?? top.moduleSpecifier : top.moduleReference; - const withoutModuleSpecifier = { - pos: top.getFirstToken().getStart(), - end: potentialSplitPoint.pos - }; - if (rangeIsOnSingleLine(withoutModuleSpecifier, sourceFile)) { - return createTextSpanFromRange(withoutModuleSpecifier); } - } - function getPotentiallyInvalidImportSpecifier(namedBindings) { - var _a; - return find( - (_a = tryCast(namedBindings, isNamedImports)) == null ? void 0 : _a.elements, - (e) => { - var _a2; - return !e.propertyName && isStringANonContextualKeyword(e.name.text) && ((_a2 = findPrecedingToken(e.name.pos, namedBindings.getSourceFile(), namedBindings)) == null ? void 0 : _a2.kind) !== 28 /* CommaToken */; + function getTypeAnnotationPosition(decl) { + const closeParenToken = findChildOfKind(decl, 22 /* CloseParenToken */, file); + if (closeParenToken) { + return closeParenToken.end; } - ); - } - function couldBeTypeOnlyImportSpecifier(importSpecifier, contextToken) { - return isImportSpecifier(importSpecifier) && (importSpecifier.isTypeOnly || contextToken === importSpecifier.name && isTypeKeywordTokenOrIdentifier(contextToken)); - } - function canCompleteFromNamedBindings(namedBindings) { - if (!isModuleSpecifierMissingOrEmpty(namedBindings.parent.parent.moduleSpecifier) || namedBindings.parent.name) { - return false; + return decl.parameters.end; } - if (isNamedImports(namedBindings)) { - const invalidNamedImport = getPotentiallyInvalidImportSpecifier(namedBindings); - const validImports = invalidNamedImport ? namedBindings.elements.indexOf(invalidNamedImport) : namedBindings.elements.length; - return validImports < 2; + function visitFunctionLikeForParameterType(node) { + const signature = checker.getSignatureFromDeclaration(node); + if (!signature) { + return; + } + for (let i = 0; i < node.parameters.length && i < signature.parameters.length; ++i) { + const param = node.parameters[i]; + if (!isHintableDeclaration(param)) { + continue; + } + const effectiveTypeAnnotation = getEffectiveTypeAnnotationNode(param); + if (effectiveTypeAnnotation) { + continue; + } + const typeHints = getParameterDeclarationTypeHints(signature.parameters[i]); + if (!typeHints) { + continue; + } + addTypeHints(typeHints, param.questionToken ? param.questionToken.end : param.name.end); + } } - return true; - } - function isModuleSpecifierMissingOrEmpty(specifier) { - var _a; - if (nodeIsMissing(specifier)) - return true; - return !((_a = tryCast(isExternalModuleReference(specifier) ? specifier.expression : specifier, isStringLiteralLike)) == null ? void 0 : _a.text); - } - function getVariableOrParameterDeclaration(contextToken, location) { - if (!contextToken) - return; - const possiblyParameterDeclaration = findAncestor(contextToken, (node) => isFunctionBlock(node) || isArrowFunctionBody(node) || isBindingPattern(node) ? "quit" : (isParameter(node) || isTypeParameterDeclaration(node)) && !isIndexSignatureDeclaration(node.parent)); - const possiblyVariableDeclaration = findAncestor(location, (node) => isFunctionBlock(node) || isArrowFunctionBody(node) || isBindingPattern(node) ? "quit" : isVariableDeclaration(node)); - return possiblyParameterDeclaration || possiblyVariableDeclaration; - } - function isArrowFunctionBody(node) { - return node.parent && isArrowFunction(node.parent) && (node.parent.body === node || // const a = () => /**/; - node.kind === 39 /* EqualsGreaterThanToken */); - } - function symbolCanBeReferencedAtTypeLocation(symbol, checker, seenModules = /* @__PURE__ */ new Map()) { - return nonAliasCanBeReferencedAtTypeLocation(symbol) || nonAliasCanBeReferencedAtTypeLocation(skipAlias(symbol.exportSymbol || symbol, checker)); - function nonAliasCanBeReferencedAtTypeLocation(symbol2) { - return !!(symbol2.flags & 788968 /* Type */) || checker.isUnknownSymbol(symbol2) || !!(symbol2.flags & 1536 /* Module */) && addToSeen(seenModules, getSymbolId(symbol2)) && checker.getExportsOfModule(symbol2).some((e) => symbolCanBeReferencedAtTypeLocation(e, checker, seenModules)); + function getParameterDeclarationTypeHints(symbol) { + const valueDeclaration = symbol.valueDeclaration; + if (!valueDeclaration || !isParameter(valueDeclaration)) { + return void 0; + } + const signatureParamType = checker.getTypeOfSymbolAtLocation(symbol, valueDeclaration); + if (isModuleReferenceType(signatureParamType)) { + return void 0; + } + return typeToInlayHintParts(signatureParamType); } - } - function isDeprecated(symbol, checker) { - const declarations = skipAlias(symbol, checker).declarations; - return !!length(declarations) && every(declarations, isDeprecatedDeclaration); - } - function charactersFuzzyMatchInString(identifierString, lowercaseCharacters) { - if (lowercaseCharacters.length === 0) { - return true; + function printTypeInSingleLine(type) { + const flags = 70221824 /* IgnoreErrors */ | 1048576 /* AllowUniqueESSymbolType */ | 16384 /* UseAliasDefinedOutsideCurrentScope */; + const printer = createPrinterWithRemoveComments(); + return usingSingleLineStringWriter((writer) => { + const typeNode = checker.typeToTypeNode( + type, + /*enclosingDeclaration*/ + void 0, + flags + ); + Debug.assertIsDefined(typeNode, "should always get typenode"); + printer.writeNode( + 4 /* Unspecified */, + typeNode, + /*sourceFile*/ + file, + writer + ); + }); } - let matchedFirstCharacter = false; - let prevChar; - let characterIndex = 0; - const len = identifierString.length; - for (let strIndex = 0; strIndex < len; strIndex++) { - const strChar = identifierString.charCodeAt(strIndex); - const testChar = lowercaseCharacters.charCodeAt(characterIndex); - if (strChar === testChar || strChar === toUpperCharCode(testChar)) { - matchedFirstCharacter || (matchedFirstCharacter = prevChar === void 0 || // Beginning of word - 97 /* a */ <= prevChar && prevChar <= 122 /* z */ && 65 /* A */ <= strChar && strChar <= 90 /* Z */ || // camelCase transition - prevChar === 95 /* _ */ && strChar !== 95 /* _ */); - if (matchedFirstCharacter) { - characterIndex++; + function typeToInlayHintParts(type) { + if (!shouldUseInteractiveInlayHints(preferences)) { + return printTypeInSingleLine(type); + } + const flags = 70221824 /* IgnoreErrors */ | 1048576 /* AllowUniqueESSymbolType */ | 16384 /* UseAliasDefinedOutsideCurrentScope */; + const typeNode = checker.typeToTypeNode( + type, + /*enclosingDeclaration*/ + void 0, + flags + ); + Debug.assertIsDefined(typeNode, "should always get typenode"); + const parts = []; + visitForDisplayParts(typeNode); + return parts; + function visitForDisplayParts(node) { + if (!node) { + return; } - if (characterIndex === lowercaseCharacters.length) { - return true; + const tokenString = tokenToString(node.kind); + if (tokenString) { + parts.push({ text: tokenString }); + return; + } + if (isLiteralExpression(node)) { + parts.push({ text: getLiteralText2(node) }); + return; + } + switch (node.kind) { + case 80 /* Identifier */: + const identifier = node; + const identifierText = idText(identifier); + const name = identifier.symbol && identifier.symbol.declarations && identifier.symbol.declarations.length && getNameOfDeclaration(identifier.symbol.declarations[0]); + if (name) { + parts.push(getNodeDisplayPart(identifierText, name)); + } else { + parts.push({ text: identifierText }); + } + break; + case 166 /* QualifiedName */: + const qualifiedName = node; + visitForDisplayParts(qualifiedName.left); + parts.push({ text: "." }); + visitForDisplayParts(qualifiedName.right); + break; + case 182 /* TypePredicate */: + const predicate = node; + if (predicate.assertsModifier) { + parts.push({ text: "asserts " }); + } + visitForDisplayParts(predicate.parameterName); + if (predicate.type) { + parts.push({ text: " is " }); + visitForDisplayParts(predicate.type); + } + break; + case 183 /* TypeReference */: + const typeReference = node; + visitForDisplayParts(typeReference.typeName); + if (typeReference.typeArguments) { + parts.push({ text: "<" }); + visitDisplayPartList(typeReference.typeArguments, ", "); + parts.push({ text: ">" }); + } + break; + case 168 /* TypeParameter */: + const typeParameter = node; + if (typeParameter.modifiers) { + visitDisplayPartList(typeParameter.modifiers, " "); + } + visitForDisplayParts(typeParameter.name); + if (typeParameter.constraint) { + parts.push({ text: " extends " }); + visitForDisplayParts(typeParameter.constraint); + } + if (typeParameter.default) { + parts.push({ text: " = " }); + visitForDisplayParts(typeParameter.default); + } + break; + case 169 /* Parameter */: + const parameter = node; + if (parameter.modifiers) { + visitDisplayPartList(parameter.modifiers, " "); + } + if (parameter.dotDotDotToken) { + parts.push({ text: "..." }); + } + visitForDisplayParts(parameter.name); + if (parameter.questionToken) { + parts.push({ text: "?" }); + } + if (parameter.type) { + parts.push({ text: ": " }); + visitForDisplayParts(parameter.type); + } + break; + case 185 /* ConstructorType */: + const constructorType = node; + parts.push({ text: "new " }); + if (constructorType.typeParameters) { + parts.push({ text: "<" }); + visitDisplayPartList(constructorType.typeParameters, ", "); + parts.push({ text: ">" }); + } + parts.push({ text: "(" }); + visitDisplayPartList(constructorType.parameters, ", "); + parts.push({ text: ")" }); + parts.push({ text: " => " }); + visitForDisplayParts(constructorType.type); + break; + case 186 /* TypeQuery */: + const typeQuery = node; + parts.push({ text: "typeof " }); + visitForDisplayParts(typeQuery.exprName); + if (typeQuery.typeArguments) { + parts.push({ text: "<" }); + visitDisplayPartList(typeQuery.typeArguments, ", "); + parts.push({ text: ">" }); + } + break; + case 187 /* TypeLiteral */: + const typeLiteral = node; + parts.push({ text: "{" }); + if (typeLiteral.members.length) { + parts.push({ text: " " }); + visitDisplayPartList(typeLiteral.members, "; "); + parts.push({ text: " " }); + } + parts.push({ text: "}" }); + break; + case 188 /* ArrayType */: + visitForDisplayParts(node.elementType); + parts.push({ text: "[]" }); + break; + case 189 /* TupleType */: + parts.push({ text: "[" }); + visitDisplayPartList(node.elements, ", "); + parts.push({ text: "]" }); + break; + case 202 /* NamedTupleMember */: + const member = node; + if (member.dotDotDotToken) { + parts.push({ text: "..." }); + } + visitForDisplayParts(member.name); + if (member.questionToken) { + parts.push({ text: "?" }); + } + parts.push({ text: ": " }); + visitForDisplayParts(member.type); + break; + case 190 /* OptionalType */: + visitForDisplayParts(node.type); + parts.push({ text: "?" }); + break; + case 191 /* RestType */: + parts.push({ text: "..." }); + visitForDisplayParts(node.type); + break; + case 192 /* UnionType */: + visitDisplayPartList(node.types, " | "); + break; + case 193 /* IntersectionType */: + visitDisplayPartList(node.types, " & "); + break; + case 194 /* ConditionalType */: + const conditionalType = node; + visitForDisplayParts(conditionalType.checkType); + parts.push({ text: " extends " }); + visitForDisplayParts(conditionalType.extendsType); + parts.push({ text: " ? " }); + visitForDisplayParts(conditionalType.trueType); + parts.push({ text: " : " }); + visitForDisplayParts(conditionalType.falseType); + break; + case 195 /* InferType */: + parts.push({ text: "infer " }); + visitForDisplayParts(node.typeParameter); + break; + case 196 /* ParenthesizedType */: + parts.push({ text: "(" }); + visitForDisplayParts(node.type); + parts.push({ text: ")" }); + break; + case 198 /* TypeOperator */: + const typeOperator = node; + parts.push({ text: `${tokenToString(typeOperator.operator)} ` }); + visitForDisplayParts(typeOperator.type); + break; + case 199 /* IndexedAccessType */: + const indexedAccess = node; + visitForDisplayParts(indexedAccess.objectType); + parts.push({ text: "[" }); + visitForDisplayParts(indexedAccess.indexType); + parts.push({ text: "]" }); + break; + case 200 /* MappedType */: + const mappedType = node; + parts.push({ text: "{ " }); + if (mappedType.readonlyToken) { + if (mappedType.readonlyToken.kind === 40 /* PlusToken */) { + parts.push({ text: "+" }); + } else if (mappedType.readonlyToken.kind === 41 /* MinusToken */) { + parts.push({ text: "-" }); + } + parts.push({ text: "readonly " }); + } + parts.push({ text: "[" }); + visitForDisplayParts(mappedType.typeParameter); + if (mappedType.nameType) { + parts.push({ text: " as " }); + visitForDisplayParts(mappedType.nameType); + } + parts.push({ text: "]" }); + if (mappedType.questionToken) { + if (mappedType.questionToken.kind === 40 /* PlusToken */) { + parts.push({ text: "+" }); + } else if (mappedType.questionToken.kind === 41 /* MinusToken */) { + parts.push({ text: "-" }); + } + parts.push({ text: "?" }); + } + parts.push({ text: ": " }); + if (mappedType.type) { + visitForDisplayParts(mappedType.type); + } + parts.push({ text: "; }" }); + break; + case 201 /* LiteralType */: + visitForDisplayParts(node.literal); + break; + case 184 /* FunctionType */: + const functionType = node; + if (functionType.typeParameters) { + parts.push({ text: "<" }); + visitDisplayPartList(functionType.typeParameters, ", "); + parts.push({ text: ">" }); + } + parts.push({ text: "(" }); + visitDisplayPartList(functionType.parameters, ", "); + parts.push({ text: ")" }); + parts.push({ text: " => " }); + visitForDisplayParts(functionType.type); + break; + case 205 /* ImportType */: + const importType = node; + if (importType.isTypeOf) { + parts.push({ text: "typeof " }); + } + parts.push({ text: "import(" }); + visitForDisplayParts(importType.argument); + if (importType.assertions) { + parts.push({ text: ", { assert: " }); + visitDisplayPartList(importType.assertions.assertClause.elements, ", "); + parts.push({ text: " }" }); + } + parts.push({ text: ")" }); + if (importType.qualifier) { + parts.push({ text: "." }); + visitForDisplayParts(importType.qualifier); + } + if (importType.typeArguments) { + parts.push({ text: "<" }); + visitDisplayPartList(importType.typeArguments, ", "); + parts.push({ text: ">" }); + } + break; + case 171 /* PropertySignature */: + const propertySignature = node; + if (propertySignature.modifiers) { + visitDisplayPartList(propertySignature.modifiers, " "); + } + visitForDisplayParts(propertySignature.name); + if (propertySignature.questionToken) { + parts.push({ text: "?" }); + } + if (propertySignature.type) { + parts.push({ text: ": " }); + visitForDisplayParts(propertySignature.type); + } + break; + default: + Debug.failBadSyntaxKind(node); } } - prevChar = strChar; + function visitDisplayPartList(nodes, separator) { + nodes.forEach((node, index) => { + if (index > 0) { + parts.push({ text: separator }); + } + visitForDisplayParts(node); + }); + } + function getLiteralText2(node) { + if (isStringLiteral(node)) { + return quotePreference === 0 /* Single */ ? `'${escapeString(node.text, 39 /* singleQuote */)}'` : `"${escapeString(node.text, 34 /* doubleQuote */)}"`; + } + return node.text; + } } - return false; - } - function toUpperCharCode(charCode) { - if (97 /* a */ <= charCode && charCode <= 122 /* z */) { - return charCode - 32; + function isUndefined(name) { + return name === "undefined"; + } + function isHintableDeclaration(node) { + if ((isParameterDeclaration(node) || isVariableDeclaration(node) && isVarConst(node)) && node.initializer) { + const initializer = skipParentheses(node.initializer); + return !(isHintableLiteral(initializer) || isNewExpression(initializer) || isObjectLiteralExpression(initializer) || isAssertionExpression(initializer)); + } + return true; + } + function getNodeDisplayPart(text, node) { + const sourceFile = node.getSourceFile(); + return { + text, + span: createTextSpanFromNode(node, sourceFile), + file: sourceFile.fileName + }; } - return charCode; } - var moduleSpecifierResolutionLimit, moduleSpecifierResolutionCacheAttemptLimit, SortText, CompletionSource, SymbolOriginInfoKind, CompletionKind, _keywordCompletions, allKeywordsCompletions; - var init_completions = __esm({ - "src/services/completions.ts"() { + var leadingParameterNameCommentRegexFactory; + var init_inlayHints = __esm({ + "src/services/inlayHints.ts"() { "use strict"; init_ts4(); - init_ts_Completions(); - moduleSpecifierResolutionLimit = 100; - moduleSpecifierResolutionCacheAttemptLimit = 1e3; - SortText = { - // Presets - LocalDeclarationPriority: "10", - LocationPriority: "11", - OptionalMember: "12", - MemberDeclaredBySpreadAssignment: "13", - SuggestedClassMembers: "14", - GlobalsOrKeywords: "15", - AutoImportSuggestions: "16", - ClassMemberSnippets: "17", - JavascriptIdentifiers: "18", - // Transformations - Deprecated(sortText) { - return "z" + sortText; - }, - ObjectLiteralProperty(presetSortText, symbolDisplayName) { - return `${presetSortText}\0${symbolDisplayName}\0`; - }, - SortBelow(sortText) { - return sortText + "1"; - } + leadingParameterNameCommentRegexFactory = (name) => { + return new RegExp(`^\\s?/\\*\\*?\\s?${name}\\s?\\*\\/\\s?$`); }; - CompletionSource = /* @__PURE__ */ ((CompletionSource2) => { - CompletionSource2["ThisProperty"] = "ThisProperty/"; - CompletionSource2["ClassMemberSnippet"] = "ClassMemberSnippet/"; - CompletionSource2["TypeOnlyAlias"] = "TypeOnlyAlias/"; - CompletionSource2["ObjectLiteralMethodSnippet"] = "ObjectLiteralMethodSnippet/"; - CompletionSource2["SwitchCases"] = "SwitchCases/"; - return CompletionSource2; - })(CompletionSource || {}); - SymbolOriginInfoKind = /* @__PURE__ */ ((SymbolOriginInfoKind2) => { - SymbolOriginInfoKind2[SymbolOriginInfoKind2["ThisType"] = 1] = "ThisType"; - SymbolOriginInfoKind2[SymbolOriginInfoKind2["SymbolMember"] = 2] = "SymbolMember"; - SymbolOriginInfoKind2[SymbolOriginInfoKind2["Export"] = 4] = "Export"; - SymbolOriginInfoKind2[SymbolOriginInfoKind2["Promise"] = 8] = "Promise"; - SymbolOriginInfoKind2[SymbolOriginInfoKind2["Nullable"] = 16] = "Nullable"; - SymbolOriginInfoKind2[SymbolOriginInfoKind2["ResolvedExport"] = 32] = "ResolvedExport"; - SymbolOriginInfoKind2[SymbolOriginInfoKind2["TypeOnlyAlias"] = 64] = "TypeOnlyAlias"; - SymbolOriginInfoKind2[SymbolOriginInfoKind2["ObjectLiteralMethod"] = 128] = "ObjectLiteralMethod"; - SymbolOriginInfoKind2[SymbolOriginInfoKind2["Ignore"] = 256] = "Ignore"; - SymbolOriginInfoKind2[SymbolOriginInfoKind2["ComputedPropertyName"] = 512] = "ComputedPropertyName"; - SymbolOriginInfoKind2[SymbolOriginInfoKind2["SymbolMemberNoExport"] = 2 /* SymbolMember */] = "SymbolMemberNoExport"; - SymbolOriginInfoKind2[SymbolOriginInfoKind2["SymbolMemberExport"] = 6] = "SymbolMemberExport"; - return SymbolOriginInfoKind2; - })(SymbolOriginInfoKind || {}); - CompletionKind = /* @__PURE__ */ ((CompletionKind2) => { - CompletionKind2[CompletionKind2["ObjectPropertyDeclaration"] = 0] = "ObjectPropertyDeclaration"; - CompletionKind2[CompletionKind2["Global"] = 1] = "Global"; - CompletionKind2[CompletionKind2["PropertyAccess"] = 2] = "PropertyAccess"; - CompletionKind2[CompletionKind2["MemberLike"] = 3] = "MemberLike"; - CompletionKind2[CompletionKind2["String"] = 4] = "String"; - CompletionKind2[CompletionKind2["None"] = 5] = "None"; - return CompletionKind2; - })(CompletionKind || {}); - _keywordCompletions = []; - allKeywordsCompletions = memoize(() => { - const res = []; - for (let i = 83 /* FirstKeyword */; i <= 164 /* LastKeyword */; i++) { - res.push({ - name: tokenToString(i), - kind: "keyword" /* keyword */, - kindModifiers: "" /* none */, - sortText: SortText.GlobalsOrKeywords - }); - } - return res; - }); } }); - // src/services/stringCompletions.ts - function createNameAndKindSet() { - const map2 = /* @__PURE__ */ new Map(); - function add(value) { - const existing = map2.get(value.name); - if (!existing || kindPrecedence[existing.kind] < kindPrecedence[value.kind]) { - map2.set(value.name, value); - } + // src/services/_namespaces/ts.InlayHints.ts + var ts_InlayHints_exports = {}; + __export(ts_InlayHints_exports, { + provideInlayHints: () => provideInlayHints + }); + var init_ts_InlayHints = __esm({ + "src/services/_namespaces/ts.InlayHints.ts"() { + "use strict"; + init_inlayHints(); } - return { - add, - has: map2.has.bind(map2), - values: map2.values.bind(map2) - }; + }); + + // src/services/jsDoc.ts + function getJsDocCommentsFromDeclarations(declarations, checker) { + const parts = []; + forEachUnique(declarations, (declaration) => { + for (const jsdoc of getCommentHavingNodes(declaration)) { + const inheritDoc = isJSDoc(jsdoc) && jsdoc.tags && find(jsdoc.tags, (t) => t.kind === 334 /* JSDocTag */ && (t.tagName.escapedText === "inheritDoc" || t.tagName.escapedText === "inheritdoc")); + if (jsdoc.comment === void 0 && !inheritDoc || isJSDoc(jsdoc) && declaration.kind !== 353 /* JSDocTypedefTag */ && declaration.kind !== 345 /* JSDocCallbackTag */ && jsdoc.tags && jsdoc.tags.some((t) => t.kind === 353 /* JSDocTypedefTag */ || t.kind === 345 /* JSDocCallbackTag */) && !jsdoc.tags.some((t) => t.kind === 348 /* JSDocParameterTag */ || t.kind === 349 /* JSDocReturnTag */)) { + continue; + } + let newparts = jsdoc.comment ? getDisplayPartsFromComment(jsdoc.comment, checker) : []; + if (inheritDoc && inheritDoc.comment) { + newparts = newparts.concat(getDisplayPartsFromComment(inheritDoc.comment, checker)); + } + if (!contains(parts, newparts, isIdenticalListOfDisplayParts)) { + parts.push(newparts); + } + } + }); + return flatten(intersperse(parts, [lineBreakPart()])); } - function getStringLiteralCompletions(sourceFile, position, contextToken, options, host, program, log, preferences, includeSymbol) { - if (isInReferenceComment(sourceFile, position)) { - const entries = getTripleSlashReferenceCompletion(sourceFile, position, options, host); - return entries && convertPathCompletions(entries); - } - if (isInString(sourceFile, position, contextToken)) { - if (!contextToken || !isStringLiteralLike(contextToken)) - return void 0; - const entries = getStringLiteralCompletionEntries(sourceFile, contextToken, position, program.getTypeChecker(), options, host, preferences); - return convertStringLiteralCompletions(entries, contextToken, sourceFile, host, program, log, options, preferences, position, includeSymbol); - } + function isIdenticalListOfDisplayParts(parts1, parts2) { + return arraysEqual(parts1, parts2, (p1, p2) => p1.kind === p2.kind && p1.text === p2.text); } - function convertStringLiteralCompletions(completion, contextToken, sourceFile, host, program, log, options, preferences, position, includeSymbol) { - if (completion === void 0) { - return void 0; - } - const optionalReplacementSpan = createTextSpanFromStringLiteralLikeContent(contextToken); - switch (completion.kind) { - case 0 /* Paths */: - return convertPathCompletions(completion.paths); - case 1 /* Properties */: { - const entries = createSortedArray(); - getCompletionEntriesFromSymbols( - completion.symbols, - entries, - contextToken, - contextToken, - sourceFile, - position, - sourceFile, - host, - program, - 99 /* ESNext */, - log, - 4 /* String */, - preferences, - options, - /*formatContext*/ - void 0, - /*isTypeOnlyLocation*/ - void 0, - /*propertyAccessToConvert*/ - void 0, - /*jsxIdentifierExpected*/ - void 0, - /*isJsxInitializer*/ - void 0, - /*importStatementCompletion*/ - void 0, - /*recommendedCompletion*/ - void 0, - /*symbolToOriginInfoMap*/ - void 0, - /*symbolToSortTextMap*/ - void 0, - /*isJsxIdentifierExpected*/ - void 0, - /*isRightOfOpenTag*/ - void 0, - includeSymbol - ); - return { isGlobalCompletion: false, isMemberCompletion: true, isNewIdentifierLocation: completion.hasIndexSignature, optionalReplacementSpan, entries }; - } - case 2 /* Types */: { - const entries = completion.types.map((type) => ({ - name: type.value, - kindModifiers: "" /* none */, - kind: "string" /* string */, - sortText: SortText.LocationPriority, - replacementSpan: getReplacementSpanForContextToken(contextToken) - })); - return { isGlobalCompletion: false, isMemberCompletion: false, isNewIdentifierLocation: completion.isNewIdentifier, optionalReplacementSpan, entries }; - } + function getCommentHavingNodes(declaration) { + switch (declaration.kind) { + case 348 /* JSDocParameterTag */: + case 355 /* JSDocPropertyTag */: + return [declaration]; + case 345 /* JSDocCallbackTag */: + case 353 /* JSDocTypedefTag */: + return [declaration, declaration.parent]; + case 330 /* JSDocSignature */: + if (isJSDocOverloadTag(declaration.parent)) { + return [declaration.parent.parent]; + } default: - return Debug.assertNever(completion); + return getJSDocCommentsAndTags(declaration); } } - function getStringLiteralCompletionDetails(name, sourceFile, position, contextToken, checker, options, host, cancellationToken, preferences) { - if (!contextToken || !isStringLiteralLike(contextToken)) - return void 0; - const completions = getStringLiteralCompletionEntries(sourceFile, contextToken, position, checker, options, host, preferences); - return completions && stringLiteralCompletionDetails(name, contextToken, completions, sourceFile, checker, cancellationToken); - } - function stringLiteralCompletionDetails(name, location, completion, sourceFile, checker, cancellationToken) { - switch (completion.kind) { - case 0 /* Paths */: { - const match = find(completion.paths, (p) => p.name === name); - return match && createCompletionDetails(name, kindModifiersFromExtension(match.extension), match.kind, [textPart(name)]); + function getJsDocTagsFromDeclarations(declarations, checker) { + const infos = []; + forEachUnique(declarations, (declaration) => { + const tags = getJSDocTags(declaration); + if (tags.some((t) => t.kind === 353 /* JSDocTypedefTag */ || t.kind === 345 /* JSDocCallbackTag */) && !tags.some((t) => t.kind === 348 /* JSDocParameterTag */ || t.kind === 349 /* JSDocReturnTag */)) { + return; } - case 1 /* Properties */: { - const match = find(completion.symbols, (s) => s.name === name); - return match && createCompletionDetailsForSymbol(match, match.name, checker, sourceFile, location, cancellationToken); + for (const tag of tags) { + infos.push({ name: tag.tagName.text, text: getCommentDisplayParts(tag, checker) }); + if (isJSDocPropertyLikeTag(tag) && tag.isNameFirst && tag.typeExpression && isJSDocTypeLiteral(tag.typeExpression.type)) { + forEach(tag.typeExpression.type.jsDocPropertyTags, (propTag) => { + infos.push({ name: propTag.tagName.text, text: getCommentDisplayParts(propTag, checker) }); + }); + } } - case 2 /* Types */: - return find(completion.types, (t) => t.value === name) ? createCompletionDetails(name, "" /* none */, "string" /* string */, [textPart(name)]) : void 0; - default: - return Debug.assertNever(completion); - } - } - function convertPathCompletions(pathCompletions) { - const isGlobalCompletion = false; - const isNewIdentifierLocation = true; - const entries = pathCompletions.map(({ name, kind, span, extension }) => ({ name, kind, kindModifiers: kindModifiersFromExtension(extension), sortText: SortText.LocationPriority, replacementSpan: span })); - return { isGlobalCompletion, isMemberCompletion: false, isNewIdentifierLocation, entries }; + }); + return infos; } - function kindModifiersFromExtension(extension) { - switch (extension) { - case ".d.ts" /* Dts */: - return ".d.ts" /* dtsModifier */; - case ".js" /* Js */: - return ".js" /* jsModifier */; - case ".json" /* Json */: - return ".json" /* jsonModifier */; - case ".jsx" /* Jsx */: - return ".jsx" /* jsxModifier */; - case ".ts" /* Ts */: - return ".ts" /* tsModifier */; - case ".tsx" /* Tsx */: - return ".tsx" /* tsxModifier */; - case ".d.mts" /* Dmts */: - return ".d.mts" /* dmtsModifier */; - case ".mjs" /* Mjs */: - return ".mjs" /* mjsModifier */; - case ".mts" /* Mts */: - return ".mts" /* mtsModifier */; - case ".d.cts" /* Dcts */: - return ".d.cts" /* dctsModifier */; - case ".cjs" /* Cjs */: - return ".cjs" /* cjsModifier */; - case ".cts" /* Cts */: - return ".cts" /* ctsModifier */; - case ".tsbuildinfo" /* TsBuildInfo */: - return Debug.fail(`Extension ${".tsbuildinfo" /* TsBuildInfo */} is unsupported.`); - case void 0: - return "" /* none */; - default: - return Debug.assertNever(extension); + function getDisplayPartsFromComment(comment, checker) { + if (typeof comment === "string") { + return [textPart(comment)]; } + return flatMap( + comment, + (node) => node.kind === 328 /* JSDocText */ ? [textPart(node.text)] : buildLinkParts(node, checker) + ); } - function getStringLiteralCompletionEntries(sourceFile, node, position, typeChecker, compilerOptions, host, preferences) { - const parent2 = walkUpParentheses(node.parent); - switch (parent2.kind) { - case 200 /* LiteralType */: { - const grandParent = walkUpParentheses(parent2.parent); - if (grandParent.kind === 204 /* ImportType */) { - return { kind: 0 /* Paths */, paths: getStringLiteralCompletionsFromModuleNames(sourceFile, node, compilerOptions, host, typeChecker, preferences) }; - } - return fromUnionableLiteralType(grandParent); - } - case 302 /* PropertyAssignment */: - if (isObjectLiteralExpression(parent2.parent) && parent2.name === node) { - return stringLiteralCompletionsForObjectLiteral(typeChecker, parent2.parent); - } - return fromContextualType() || fromContextualType(0 /* None */); - case 211 /* ElementAccessExpression */: { - const { expression, argumentExpression } = parent2; - if (node === skipParentheses(argumentExpression)) { - return stringLiteralCompletionsFromProperties(typeChecker.getTypeAtLocation(expression)); + function getCommentDisplayParts(tag, checker) { + const { comment, kind } = tag; + const namePart = getTagNameDisplayPart(kind); + switch (kind) { + case 356 /* JSDocThrowsTag */: + const typeExpression = tag.typeExpression; + return typeExpression ? withNode(typeExpression) : comment === void 0 ? void 0 : getDisplayPartsFromComment(comment, checker); + case 336 /* JSDocImplementsTag */: + return withNode(tag.class); + case 335 /* JSDocAugmentsTag */: + return withNode(tag.class); + case 352 /* JSDocTemplateTag */: + const templateTag = tag; + const displayParts = []; + if (templateTag.constraint) { + displayParts.push(textPart(templateTag.constraint.getText())); } - return void 0; - } - case 212 /* CallExpression */: - case 213 /* NewExpression */: - case 290 /* JsxAttribute */: - if (!isRequireCallArgument(node) && !isImportCall(parent2)) { - const argumentInfo = ts_SignatureHelp_exports.getArgumentInfoForCompletions(parent2.kind === 290 /* JsxAttribute */ ? parent2.parent : node, position, sourceFile); - return argumentInfo && getStringLiteralCompletionsFromSignature(argumentInfo.invocation, node, argumentInfo, typeChecker) || fromContextualType(0 /* None */); + if (length(templateTag.typeParameters)) { + if (length(displayParts)) { + displayParts.push(spacePart()); + } + const lastTypeParameter = templateTag.typeParameters[templateTag.typeParameters.length - 1]; + forEach(templateTag.typeParameters, (tp) => { + displayParts.push(namePart(tp.getText())); + if (lastTypeParameter !== tp) { + displayParts.push(...[punctuationPart(28 /* CommaToken */), spacePart()]); + } + }); } - case 271 /* ImportDeclaration */: - case 277 /* ExportDeclaration */: - case 282 /* ExternalModuleReference */: - return { kind: 0 /* Paths */, paths: getStringLiteralCompletionsFromModuleNames(sourceFile, node, compilerOptions, host, typeChecker, preferences) }; - case 295 /* CaseClause */: - const tracker = newCaseClauseTracker(typeChecker, parent2.parent.clauses); - const contextualTypes = fromContextualType(); - if (!contextualTypes) { - return; + if (comment) { + displayParts.push(...[spacePart(), ...getDisplayPartsFromComment(comment, checker)]); } - const literals = contextualTypes.types.filter((literal) => !tracker.hasValue(literal.value)); - return { kind: 2 /* Types */, types: literals, isNewIdentifier: false }; + return displayParts; + case 351 /* JSDocTypeTag */: + case 357 /* JSDocSatisfiesTag */: + return withNode(tag.typeExpression); + case 353 /* JSDocTypedefTag */: + case 345 /* JSDocCallbackTag */: + case 355 /* JSDocPropertyTag */: + case 348 /* JSDocParameterTag */: + case 354 /* JSDocSeeTag */: + const { name } = tag; + return name ? withNode(name) : comment === void 0 ? void 0 : getDisplayPartsFromComment(comment, checker); default: - return fromContextualType() || fromContextualType(0 /* None */); + return comment === void 0 ? void 0 : getDisplayPartsFromComment(comment, checker); } - function fromUnionableLiteralType(grandParent) { - switch (grandParent.kind) { - case 232 /* ExpressionWithTypeArguments */: - case 182 /* TypeReference */: { - const typeArgument = findAncestor(parent2, (n) => n.parent === grandParent); - if (typeArgument) { - return { kind: 2 /* Types */, types: getStringLiteralTypes(typeChecker.getTypeArgumentConstraint(typeArgument)), isNewIdentifier: false }; - } - return void 0; - } - case 198 /* IndexedAccessType */: - const { indexType, objectType } = grandParent; - if (!rangeContainsPosition(indexType, position)) { - return void 0; - } - return stringLiteralCompletionsFromProperties(typeChecker.getTypeFromTypeNode(objectType)); - case 191 /* UnionType */: { - const result = fromUnionableLiteralType(walkUpParentheses(grandParent.parent)); - if (!result) { - return void 0; - } - const alreadyUsedTypes = getAlreadyUsedTypesInStringLiteralUnion(grandParent, parent2); - if (result.kind === 1 /* Properties */) { - return { kind: 1 /* Properties */, symbols: result.symbols.filter((sym) => !contains(alreadyUsedTypes, sym.name)), hasIndexSignature: result.hasIndexSignature }; - } - return { kind: 2 /* Types */, types: result.types.filter((t) => !contains(alreadyUsedTypes, t.value)), isNewIdentifier: false }; - } - default: - return void 0; - } + function withNode(node) { + return addComment(node.getText()); } - function fromContextualType(contextFlags = 4 /* Completions */) { - const types = getStringLiteralTypes(getContextualTypeFromParent(node, typeChecker, contextFlags)); - if (!types.length) { - return; + function addComment(s) { + if (comment) { + if (s.match(/^https?$/)) { + return [textPart(s), ...getDisplayPartsFromComment(comment, checker)]; + } else { + return [namePart(s), spacePart(), ...getDisplayPartsFromComment(comment, checker)]; + } + } else { + return [textPart(s)]; } - return { kind: 2 /* Types */, types, isNewIdentifier: false }; } } - function walkUpParentheses(node) { - switch (node.kind) { - case 195 /* ParenthesizedType */: - return walkUpParenthesizedTypes(node); - case 216 /* ParenthesizedExpression */: - return walkUpParenthesizedExpressions(node); + function getTagNameDisplayPart(kind) { + switch (kind) { + case 348 /* JSDocParameterTag */: + return parameterNamePart; + case 355 /* JSDocPropertyTag */: + return propertyNamePart; + case 352 /* JSDocTemplateTag */: + return typeParameterNamePart; + case 353 /* JSDocTypedefTag */: + case 345 /* JSDocCallbackTag */: + return typeAliasNamePart; default: - return node; + return textPart; } } - function getAlreadyUsedTypesInStringLiteralUnion(union, current) { - return mapDefined(union.types, (type) => type !== current && isLiteralTypeNode(type) && isStringLiteral(type.literal) ? type.literal.text : void 0); - } - function getStringLiteralCompletionsFromSignature(call, arg, argumentInfo, checker) { - let isNewIdentifier = false; - const uniques = /* @__PURE__ */ new Map(); - const candidates = []; - const editingArgument = isJsxOpeningLikeElement(call) ? Debug.checkDefined(findAncestor(arg.parent, isJsxAttribute)) : arg; - checker.getResolvedSignatureForStringLiteralCompletions(call, editingArgument, candidates); - const types = flatMap(candidates, (candidate) => { - if (!signatureHasRestParameter(candidate) && argumentInfo.argumentCount > candidate.parameters.length) - return; - let type = candidate.getTypeParameterAtPosition(argumentInfo.argumentIndex); - if (isJsxOpeningLikeElement(call)) { - const propType = checker.getTypeOfPropertyOfType(type, getTextOfJsxAttributeName(editingArgument.name)); - if (propType) { - type = propType; - } - } - isNewIdentifier = isNewIdentifier || !!(type.flags & 4 /* String */); - return getStringLiteralTypes(type, uniques); - }); - return length(types) ? { kind: 2 /* Types */, types, isNewIdentifier } : void 0; + function getJSDocTagNameCompletions() { + return jsDocTagNameCompletionEntries || (jsDocTagNameCompletionEntries = map(jsDocTagNames, (tagName) => { + return { + name: tagName, + kind: "keyword" /* keyword */, + kindModifiers: "", + sortText: ts_Completions_exports.SortText.LocationPriority + }; + })); } - function stringLiteralCompletionsFromProperties(type) { - return type && { - kind: 1 /* Properties */, - symbols: filter(type.getApparentProperties(), (prop) => !(prop.valueDeclaration && isPrivateIdentifierClassElementDeclaration(prop.valueDeclaration))), - hasIndexSignature: hasIndexSignature(type) - }; + function getJSDocTagCompletions() { + return jsDocTagCompletionEntries || (jsDocTagCompletionEntries = map(jsDocTagNames, (tagName) => { + return { + name: `@${tagName}`, + kind: "keyword" /* keyword */, + kindModifiers: "", + sortText: ts_Completions_exports.SortText.LocationPriority + }; + })); } - function stringLiteralCompletionsForObjectLiteral(checker, objectLiteralExpression) { - const contextualType = checker.getContextualType(objectLiteralExpression); - if (!contextualType) - return void 0; - const completionsType = checker.getContextualType(objectLiteralExpression, 4 /* Completions */); - const symbols = getPropertiesForObjectExpression( - contextualType, - completionsType, - objectLiteralExpression, - checker - ); + function getJSDocTagCompletionDetails(name) { return { - kind: 1 /* Properties */, - symbols, - hasIndexSignature: hasIndexSignature(contextualType) + name, + kind: "" /* unknown */, + // TODO: should have its own kind? + kindModifiers: "", + displayParts: [textPart(name)], + documentation: emptyArray, + tags: void 0, + codeActions: void 0 }; } - function getStringLiteralTypes(type, uniques = /* @__PURE__ */ new Map()) { - if (!type) + function getJSDocParameterNameCompletions(tag) { + if (!isIdentifier(tag.name)) { return emptyArray; - type = skipConstraint(type); - return type.isUnion() ? flatMap(type.types, (t) => getStringLiteralTypes(t, uniques)) : type.isStringLiteral() && !(type.flags & 1024 /* EnumLiteral */) && addToSeen(uniques, type.value) ? [type] : emptyArray; - } - function nameAndKind(name, kind, extension) { - return { name, kind, extension }; + } + const nameThusFar = tag.name.text; + const jsdoc = tag.parent; + const fn = jsdoc.parent; + if (!isFunctionLike(fn)) + return []; + return mapDefined(fn.parameters, (param) => { + if (!isIdentifier(param.name)) + return void 0; + const name = param.name.text; + if (jsdoc.tags.some((t) => t !== tag && isJSDocParameterTag(t) && isIdentifier(t.name) && t.name.escapedText === name) || nameThusFar !== void 0 && !startsWith(name, nameThusFar)) { + return void 0; + } + return { name, kind: "parameter" /* parameterElement */, kindModifiers: "", sortText: ts_Completions_exports.SortText.LocationPriority }; + }); } - function directoryResult(name) { - return nameAndKind( + function getJSDocParameterNameCompletionDetails(name) { + return { name, - "directory" /* directory */, - /*extension*/ - void 0 - ); + kind: "parameter" /* parameterElement */, + kindModifiers: "", + displayParts: [textPart(name)], + documentation: emptyArray, + tags: void 0, + codeActions: void 0 + }; } - function addReplacementSpans(text, textStart, names) { - const span = getDirectoryFragmentTextSpan(text, textStart); - const wholeSpan = text.length === 0 ? void 0 : createTextSpan(textStart, text.length); - return names.map(({ name, kind, extension }) => Math.max(name.indexOf(directorySeparator), name.indexOf(altDirectorySeparator)) !== -1 ? { name, kind, extension, span: wholeSpan } : { name, kind, extension, span }); + function getDocCommentTemplateAtPosition(newLine, sourceFile, position, options) { + const tokenAtPos = getTokenAtPosition(sourceFile, position); + const existingDocComment = findAncestor(tokenAtPos, isJSDoc); + if (existingDocComment && (existingDocComment.comment !== void 0 || length(existingDocComment.tags))) { + return void 0; + } + const tokenStart = tokenAtPos.getStart(sourceFile); + if (!existingDocComment && tokenStart < position) { + return void 0; + } + const commentOwnerInfo = getCommentOwnerInfo(tokenAtPos, options); + if (!commentOwnerInfo) { + return void 0; + } + const { commentOwner, parameters, hasReturn: hasReturn2 } = commentOwnerInfo; + const commentOwnerJsDoc = hasJSDocNodes(commentOwner) && commentOwner.jsDoc ? commentOwner.jsDoc : void 0; + const lastJsDoc = lastOrUndefined(commentOwnerJsDoc); + if (commentOwner.getStart(sourceFile) < position || lastJsDoc && existingDocComment && lastJsDoc !== existingDocComment) { + return void 0; + } + const indentationStr = getIndentationStringAtPosition(sourceFile, position); + const isJavaScriptFile = hasJSFileExtension(sourceFile.fileName); + const tags = (parameters ? parameterDocComments(parameters || [], isJavaScriptFile, indentationStr, newLine) : "") + (hasReturn2 ? returnsDocComment(indentationStr, newLine) : ""); + const openComment = "/**"; + const closeComment = " */"; + const hasTag = length(getJSDocTags(commentOwner)) > 0; + if (tags && !hasTag) { + const preamble = openComment + newLine + indentationStr + " * "; + const endLine = tokenStart === position ? newLine + indentationStr : ""; + const result = preamble + newLine + tags + indentationStr + closeComment + endLine; + return { newText: result, caretOffset: preamble.length }; + } + return { newText: openComment + closeComment, caretOffset: 3 }; } - function getStringLiteralCompletionsFromModuleNames(sourceFile, node, compilerOptions, host, typeChecker, preferences) { - return addReplacementSpans(node.text, node.getStart(sourceFile) + 1, getStringLiteralCompletionsFromModuleNamesWorker(sourceFile, node, compilerOptions, host, typeChecker, preferences)); + function getIndentationStringAtPosition(sourceFile, position) { + const { text } = sourceFile; + const lineStart = getLineStartPositionForPosition(position, sourceFile); + let pos = lineStart; + for (; pos <= position && isWhiteSpaceSingleLine(text.charCodeAt(pos)); pos++) + ; + return text.slice(lineStart, pos); } - function getStringLiteralCompletionsFromModuleNamesWorker(sourceFile, node, compilerOptions, host, typeChecker, preferences) { - const literalValue = normalizeSlashes(node.text); - const mode = isStringLiteralLike(node) ? getModeForUsageLocation(sourceFile, node) : void 0; - const scriptPath = sourceFile.path; - const scriptDirectory = getDirectoryPath(scriptPath); - const extensionOptions = getExtensionOptions(compilerOptions, 1 /* ModuleSpecifier */, sourceFile, typeChecker, preferences, mode); - return isPathRelativeToScript(literalValue) || !compilerOptions.baseUrl && !compilerOptions.paths && (isRootedDiskPath(literalValue) || isUrl(literalValue)) ? getCompletionEntriesForRelativeModules(literalValue, scriptDirectory, compilerOptions, host, scriptPath, extensionOptions) : getCompletionEntriesForNonRelativeModules(literalValue, scriptDirectory, mode, compilerOptions, host, extensionOptions, typeChecker); + function parameterDocComments(parameters, isJavaScriptFile, indentationStr, newLine) { + return parameters.map(({ name, dotDotDotToken }, i) => { + const paramName = name.kind === 80 /* Identifier */ ? name.text : "param" + i; + const type = isJavaScriptFile ? dotDotDotToken ? "{...any} " : "{any} " : ""; + return `${indentationStr} * @param ${type}${paramName}${newLine}`; + }).join(""); } - function getExtensionOptions(compilerOptions, referenceKind, importingSourceFile, typeChecker, preferences, resolutionMode) { - return { - extensionsToSearch: flatten(getSupportedExtensionsForModuleResolution(compilerOptions, typeChecker)), - referenceKind, - importingSourceFile, - endingPreference: preferences == null ? void 0 : preferences.importModuleSpecifierEnding, - resolutionMode - }; + function returnsDocComment(indentationStr, newLine) { + return `${indentationStr} * @returns${newLine}`; } - function getCompletionEntriesForRelativeModules(literalValue, scriptDirectory, compilerOptions, host, scriptPath, extensionOptions) { - if (compilerOptions.rootDirs) { - return getCompletionEntriesForDirectoryFragmentWithRootDirs( - compilerOptions.rootDirs, - literalValue, - scriptDirectory, - extensionOptions, - compilerOptions, - host, - scriptPath - ); - } else { - return arrayFrom(getCompletionEntriesForDirectoryFragment( - literalValue, - scriptDirectory, - extensionOptions, - host, - /*moduleSpecifierIsRelative*/ - false, - scriptPath - ).values()); - } + function getCommentOwnerInfo(tokenAtPos, options) { + return forEachAncestor(tokenAtPos, (n) => getCommentOwnerInfoWorker(n, options)); } - function getSupportedExtensionsForModuleResolution(compilerOptions, typeChecker) { - const ambientModulesExtensions = !typeChecker ? [] : mapDefined( - typeChecker.getAmbientModules(), - (module2) => { - const name = module2.name.slice(1, -1); - if (!name.startsWith("*.") || name.includes("/")) - return; - return name.slice(1); + function getCommentOwnerInfoWorker(commentOwner, options) { + switch (commentOwner.kind) { + case 262 /* FunctionDeclaration */: + case 218 /* FunctionExpression */: + case 174 /* MethodDeclaration */: + case 176 /* Constructor */: + case 173 /* MethodSignature */: + case 219 /* ArrowFunction */: + const host = commentOwner; + return { commentOwner, parameters: host.parameters, hasReturn: hasReturn(host, options) }; + case 303 /* PropertyAssignment */: + return getCommentOwnerInfoWorker(commentOwner.initializer, options); + case 263 /* ClassDeclaration */: + case 264 /* InterfaceDeclaration */: + case 266 /* EnumDeclaration */: + case 306 /* EnumMember */: + case 265 /* TypeAliasDeclaration */: + return { commentOwner }; + case 171 /* PropertySignature */: { + const host2 = commentOwner; + return host2.type && isFunctionTypeNode(host2.type) ? { commentOwner, parameters: host2.type.parameters, hasReturn: hasReturn(host2.type, options) } : { commentOwner }; } - ); - const extensions = [...getSupportedExtensions(compilerOptions), ambientModulesExtensions]; - const moduleResolution = getEmitModuleResolutionKind(compilerOptions); - return moduleResolutionUsesNodeModules(moduleResolution) ? getSupportedExtensionsWithJsonIfResolveJsonModule(compilerOptions, extensions) : extensions; + case 243 /* VariableStatement */: { + const varStatement = commentOwner; + const varDeclarations = varStatement.declarationList.declarations; + const host2 = varDeclarations.length === 1 && varDeclarations[0].initializer ? getRightHandSideOfAssignment(varDeclarations[0].initializer) : void 0; + return host2 ? { commentOwner, parameters: host2.parameters, hasReturn: hasReturn(host2, options) } : { commentOwner }; + } + case 312 /* SourceFile */: + return "quit"; + case 267 /* ModuleDeclaration */: + return commentOwner.parent.kind === 267 /* ModuleDeclaration */ ? void 0 : { commentOwner }; + case 244 /* ExpressionStatement */: + return getCommentOwnerInfoWorker(commentOwner.expression, options); + case 226 /* BinaryExpression */: { + const be = commentOwner; + if (getAssignmentDeclarationKind(be) === 0 /* None */) { + return "quit"; + } + return isFunctionLike(be.right) ? { commentOwner, parameters: be.right.parameters, hasReturn: hasReturn(be.right, options) } : { commentOwner }; + } + case 172 /* PropertyDeclaration */: + const init = commentOwner.initializer; + if (init && (isFunctionExpression(init) || isArrowFunction(init))) { + return { commentOwner, parameters: init.parameters, hasReturn: hasReturn(init, options) }; + } + } } - function getBaseDirectoriesFromRootDirs(rootDirs, basePath, scriptDirectory, ignoreCase) { - rootDirs = rootDirs.map((rootDirectory) => normalizePath(isRootedDiskPath(rootDirectory) ? rootDirectory : combinePaths(basePath, rootDirectory))); - const relativeDirectory = firstDefined(rootDirs, (rootDirectory) => containsPath(rootDirectory, scriptDirectory, basePath, ignoreCase) ? scriptDirectory.substr(rootDirectory.length) : void 0); - return deduplicate( - [...rootDirs.map((rootDirectory) => combinePaths(rootDirectory, relativeDirectory)), scriptDirectory], - equateStringsCaseSensitive, - compareStringsCaseSensitive - ); + function hasReturn(node, options) { + return !!(options == null ? void 0 : options.generateReturnInDocTemplate) && (isFunctionTypeNode(node) || isArrowFunction(node) && isExpression(node.body) || isFunctionLikeDeclaration(node) && node.body && isBlock(node.body) && !!forEachReturnStatement(node.body, (n) => n)); } - function getCompletionEntriesForDirectoryFragmentWithRootDirs(rootDirs, fragment, scriptDirectory, extensionOptions, compilerOptions, host, exclude) { - const basePath = compilerOptions.project || host.getCurrentDirectory(); - const ignoreCase = !(host.useCaseSensitiveFileNames && host.useCaseSensitiveFileNames()); - const baseDirectories = getBaseDirectoriesFromRootDirs(rootDirs, basePath, scriptDirectory, ignoreCase); - return flatMap(baseDirectories, (baseDirectory) => arrayFrom(getCompletionEntriesForDirectoryFragment( - fragment, - baseDirectory, - extensionOptions, - host, - /*moduleSpecifierIsRelative*/ - true, - exclude - ).values())); + function getRightHandSideOfAssignment(rightHandSide) { + while (rightHandSide.kind === 217 /* ParenthesizedExpression */) { + rightHandSide = rightHandSide.expression; + } + switch (rightHandSide.kind) { + case 218 /* FunctionExpression */: + case 219 /* ArrowFunction */: + return rightHandSide; + case 231 /* ClassExpression */: + return find(rightHandSide.members, isConstructorDeclaration); + } } - function getCompletionEntriesForDirectoryFragment(fragment, scriptDirectory, extensionOptions, host, moduleSpecifierIsRelative, exclude, result = createNameAndKindSet()) { - var _a; - if (fragment === void 0) { - fragment = ""; + var jsDocTagNames, jsDocTagNameCompletionEntries, jsDocTagCompletionEntries, getJSDocTagNameCompletionDetails; + var init_jsDoc = __esm({ + "src/services/jsDoc.ts"() { + "use strict"; + init_ts4(); + jsDocTagNames = [ + "abstract", + "access", + "alias", + "argument", + "async", + "augments", + "author", + "borrows", + "callback", + "class", + "classdesc", + "constant", + "constructor", + "constructs", + "copyright", + "default", + "deprecated", + "description", + "emits", + "enum", + "event", + "example", + "exports", + "extends", + "external", + "field", + "file", + "fileoverview", + "fires", + "function", + "generator", + "global", + "hideconstructor", + "host", + "ignore", + "implements", + "inheritdoc", + "inner", + "instance", + "interface", + "kind", + "lends", + "license", + "link", + "linkcode", + "linkplain", + "listens", + "member", + "memberof", + "method", + "mixes", + "module", + "name", + "namespace", + "overload", + "override", + "package", + "param", + "private", + "prop", + "property", + "protected", + "public", + "readonly", + "requires", + "returns", + "satisfies", + "see", + "since", + "static", + "summary", + "template", + "this", + "throws", + "todo", + "tutorial", + "type", + "typedef", + "var", + "variation", + "version", + "virtual", + "yields" + ]; + getJSDocTagNameCompletionDetails = getJSDocTagCompletionDetails; } - fragment = normalizeSlashes(fragment); - if (!hasTrailingDirectorySeparator(fragment)) { - fragment = getDirectoryPath(fragment); + }); + + // src/services/_namespaces/ts.JsDoc.ts + var ts_JsDoc_exports = {}; + __export(ts_JsDoc_exports, { + getDocCommentTemplateAtPosition: () => getDocCommentTemplateAtPosition, + getJSDocParameterNameCompletionDetails: () => getJSDocParameterNameCompletionDetails, + getJSDocParameterNameCompletions: () => getJSDocParameterNameCompletions, + getJSDocTagCompletionDetails: () => getJSDocTagCompletionDetails, + getJSDocTagCompletions: () => getJSDocTagCompletions, + getJSDocTagNameCompletionDetails: () => getJSDocTagNameCompletionDetails, + getJSDocTagNameCompletions: () => getJSDocTagNameCompletions, + getJsDocCommentsFromDeclarations: () => getJsDocCommentsFromDeclarations, + getJsDocTagsFromDeclarations: () => getJsDocTagsFromDeclarations + }); + var init_ts_JsDoc = __esm({ + "src/services/_namespaces/ts.JsDoc.ts"() { + "use strict"; + init_jsDoc(); + } + }); + + // src/services/organizeImports.ts + function organizeImports(sourceFile, formatContext, host, program, preferences, mode) { + const changeTracker = ts_textChanges_exports.ChangeTracker.fromContext({ host, formatContext, preferences }); + const shouldSort = mode === "SortAndCombine" /* SortAndCombine */ || mode === "All" /* All */; + const shouldCombine = shouldSort; + const shouldRemove = mode === "RemoveUnused" /* RemoveUnused */ || mode === "All" /* All */; + const topLevelImportGroupDecls = groupByNewlineContiguous(sourceFile, sourceFile.statements.filter(isImportDeclaration)); + const comparer = getOrganizeImportsComparerWithDetection(preferences, shouldSort ? () => detectSortingWorker(topLevelImportGroupDecls, preferences) === 2 /* CaseInsensitive */ : void 0); + const processImportsOfSameModuleSpecifier = (importGroup) => { + if (shouldRemove) + importGroup = removeUnusedImports(importGroup, sourceFile, program); + if (shouldCombine) + importGroup = coalesceImportsWorker(importGroup, comparer, sourceFile); + if (shouldSort) + importGroup = stableSort(importGroup, (s1, s2) => compareImportsOrRequireStatements(s1, s2, comparer)); + return importGroup; + }; + topLevelImportGroupDecls.forEach((importGroupDecl) => organizeImportsWorker(importGroupDecl, processImportsOfSameModuleSpecifier)); + if (mode !== "RemoveUnused" /* RemoveUnused */) { + getTopLevelExportGroups(sourceFile).forEach((exportGroupDecl) => organizeImportsWorker(exportGroupDecl, (group2) => coalesceExportsWorker(group2, comparer))); } - if (fragment === "") { - fragment = "." + directorySeparator; + for (const ambientModule of sourceFile.statements.filter(isAmbientModule)) { + if (!ambientModule.body) + continue; + const ambientModuleImportGroupDecls = groupByNewlineContiguous(sourceFile, ambientModule.body.statements.filter(isImportDeclaration)); + ambientModuleImportGroupDecls.forEach((importGroupDecl) => organizeImportsWorker(importGroupDecl, processImportsOfSameModuleSpecifier)); + if (mode !== "RemoveUnused" /* RemoveUnused */) { + const ambientModuleExportDecls = ambientModule.body.statements.filter(isExportDeclaration); + organizeImportsWorker(ambientModuleExportDecls, (group2) => coalesceExportsWorker(group2, comparer)); + } } - fragment = ensureTrailingDirectorySeparator(fragment); - const absolutePath = resolvePath(scriptDirectory, fragment); - const baseDirectory = hasTrailingDirectorySeparator(absolutePath) ? absolutePath : getDirectoryPath(absolutePath); - if (!moduleSpecifierIsRelative) { - const packageJsonPath = findPackageJson(baseDirectory, host); - if (packageJsonPath) { - const packageJson = readJson(packageJsonPath, host); - const typesVersions = packageJson.typesVersions; - if (typeof typesVersions === "object") { - const versionPaths = (_a = getPackageJsonTypesVersionsPaths(typesVersions)) == null ? void 0 : _a.paths; - if (versionPaths) { - const packageDirectory = getDirectoryPath(packageJsonPath); - const pathInPackage = absolutePath.slice(ensureTrailingDirectorySeparator(packageDirectory).length); - if (addCompletionEntriesFromPaths(result, pathInPackage, packageDirectory, extensionOptions, host, versionPaths)) { - return result; - } - } - } + return changeTracker.getChanges(); + function organizeImportsWorker(oldImportDecls, coalesce) { + if (length(oldImportDecls) === 0) { + return; + } + setEmitFlags(oldImportDecls[0], 1024 /* NoLeadingComments */); + const oldImportGroups = shouldCombine ? group(oldImportDecls, (importDecl) => getExternalModuleName2(importDecl.moduleSpecifier)) : [oldImportDecls]; + const sortedImportGroups = shouldSort ? stableSort(oldImportGroups, (group1, group2) => compareModuleSpecifiersWorker(group1[0].moduleSpecifier, group2[0].moduleSpecifier, comparer)) : oldImportGroups; + const newImportDecls = flatMap(sortedImportGroups, (importGroup) => getExternalModuleName2(importGroup[0].moduleSpecifier) || importGroup[0].moduleSpecifier === void 0 ? coalesce(importGroup) : importGroup); + if (newImportDecls.length === 0) { + changeTracker.deleteNodes( + sourceFile, + oldImportDecls, + { + leadingTriviaOption: ts_textChanges_exports.LeadingTriviaOption.Exclude, + trailingTriviaOption: ts_textChanges_exports.TrailingTriviaOption.Include + }, + /*hasTrailingComment*/ + true + ); + } else { + const replaceOptions = { + leadingTriviaOption: ts_textChanges_exports.LeadingTriviaOption.Exclude, + // Leave header comment in place + trailingTriviaOption: ts_textChanges_exports.TrailingTriviaOption.Include, + suffix: getNewLineOrDefaultFromHost(host, formatContext.options) + }; + changeTracker.replaceNodeWithNodes(sourceFile, oldImportDecls[0], newImportDecls, replaceOptions); + const hasTrailingComment = changeTracker.nodeHasTrailingComment(sourceFile, oldImportDecls[0], replaceOptions); + changeTracker.deleteNodes(sourceFile, oldImportDecls.slice(1), { + trailingTriviaOption: ts_textChanges_exports.TrailingTriviaOption.Include + }, hasTrailingComment); } } - const ignoreCase = !(host.useCaseSensitiveFileNames && host.useCaseSensitiveFileNames()); - if (!tryDirectoryExists(host, baseDirectory)) - return result; - const files = tryReadDirectory( - host, - baseDirectory, - extensionOptions.extensionsToSearch, - /*exclude*/ - void 0, - /*include*/ - ["./*"] + } + function groupByNewlineContiguous(sourceFile, decls) { + const scanner2 = createScanner( + sourceFile.languageVersion, + /*skipTrivia*/ + false, + sourceFile.languageVariant ); - if (files) { - for (let filePath of files) { - filePath = normalizePath(filePath); - if (exclude && comparePaths(filePath, exclude, scriptDirectory, ignoreCase) === 0 /* EqualTo */) { - continue; - } - const { name, extension } = getFilenameWithExtensionOption(getBaseFileName(filePath), host.getCompilationSettings(), extensionOptions); - result.add(nameAndKind(name, "script" /* scriptElement */, extension)); + const group2 = []; + let groupIndex = 0; + for (const decl of decls) { + if (group2[groupIndex] && isNewGroup(sourceFile, decl, scanner2)) { + groupIndex++; } - } - const directories = tryGetDirectories(host, baseDirectory); - if (directories) { - for (const directory of directories) { - const directoryName = getBaseFileName(normalizePath(directory)); - if (directoryName !== "@types") { - result.add(directoryResult(directoryName)); - } + if (!group2[groupIndex]) { + group2[groupIndex] = []; } + group2[groupIndex].push(decl); } - return result; + return group2; } - function getFilenameWithExtensionOption(name, compilerOptions, extensionOptions) { - const nonJsResult = ts_moduleSpecifiers_exports.tryGetRealFileNameForNonJsDeclarationFileName(name); - if (nonJsResult) { - return { name: nonJsResult, extension: tryGetExtensionFromPath2(nonJsResult) }; - } - if (extensionOptions.referenceKind === 0 /* Filename */) { - return { name, extension: tryGetExtensionFromPath2(name) }; - } - const endingPreference = getModuleSpecifierEndingPreference(extensionOptions.endingPreference, extensionOptions.resolutionMode, compilerOptions, extensionOptions.importingSourceFile); - if (endingPreference === 3 /* TsExtension */) { - if (fileExtensionIsOneOf(name, supportedTSImplementationExtensions)) { - return { name, extension: tryGetExtensionFromPath2(name) }; + function isNewGroup(sourceFile, decl, scanner2) { + const startPos = decl.getFullStart(); + const endPos = decl.getStart(); + scanner2.setText(sourceFile.text, startPos, endPos - startPos); + let numberOfNewLines = 0; + while (scanner2.getTokenStart() < endPos) { + const tokenKind = scanner2.scan(); + if (tokenKind === 4 /* NewLineTrivia */) { + numberOfNewLines++; + if (numberOfNewLines >= 2) { + return true; + } } - const outputExtension2 = ts_moduleSpecifiers_exports.tryGetJSExtensionForFile(name, compilerOptions); - return outputExtension2 ? { name: changeExtension(name, outputExtension2), extension: outputExtension2 } : { name, extension: tryGetExtensionFromPath2(name) }; - } - if ((endingPreference === 0 /* Minimal */ || endingPreference === 1 /* Index */) && fileExtensionIsOneOf(name, [".js" /* Js */, ".jsx" /* Jsx */, ".ts" /* Ts */, ".tsx" /* Tsx */, ".d.ts" /* Dts */])) { - return { name: removeFileExtension(name), extension: tryGetExtensionFromPath2(name) }; } - const outputExtension = ts_moduleSpecifiers_exports.tryGetJSExtensionForFile(name, compilerOptions); - return outputExtension ? { name: changeExtension(name, outputExtension), extension: outputExtension } : { name, extension: tryGetExtensionFromPath2(name) }; - } - function addCompletionEntriesFromPaths(result, fragment, baseDirectory, extensionOptions, host, paths) { - const getPatternsForKey = (key) => paths[key]; - const comparePaths2 = (a, b) => { - const patternA = tryParsePattern(a); - const patternB = tryParsePattern(b); - const lengthA = typeof patternA === "object" ? patternA.prefix.length : a.length; - const lengthB = typeof patternB === "object" ? patternB.prefix.length : b.length; - return compareValues(lengthB, lengthA); - }; - return addCompletionEntriesFromPathsOrExports(result, fragment, baseDirectory, extensionOptions, host, getOwnKeys(paths), getPatternsForKey, comparePaths2); + return false; } - function addCompletionEntriesFromPathsOrExports(result, fragment, baseDirectory, extensionOptions, host, keys, getPatternsForKey, comparePaths2) { - let pathResults = []; - let matchedPath; - for (const key of keys) { - if (key === ".") + function removeUnusedImports(oldImports, sourceFile, program) { + const typeChecker = program.getTypeChecker(); + const compilerOptions = program.getCompilerOptions(); + const jsxNamespace = typeChecker.getJsxNamespace(sourceFile); + const jsxFragmentFactory = typeChecker.getJsxFragmentFactory(sourceFile); + const jsxElementsPresent = !!(sourceFile.transformFlags & 2 /* ContainsJsx */); + const usedImports = []; + for (const importDecl of oldImports) { + const { importClause, moduleSpecifier } = importDecl; + if (!importClause) { + usedImports.push(importDecl); continue; - const keyWithoutLeadingDotSlash = key.replace(/^\.\//, ""); - const patterns = getPatternsForKey(key); - if (patterns) { - const pathPattern = tryParsePattern(keyWithoutLeadingDotSlash); - if (!pathPattern) - continue; - const isMatch = typeof pathPattern === "object" && isPatternMatch(pathPattern, fragment); - const isLongestMatch = isMatch && (matchedPath === void 0 || comparePaths2(key, matchedPath) === -1 /* LessThan */); - if (isLongestMatch) { - matchedPath = key; - pathResults = pathResults.filter((r) => !r.matchedPattern); + } + let { name, namedBindings } = importClause; + if (name && !isDeclarationUsed(name)) { + name = void 0; + } + if (namedBindings) { + if (isNamespaceImport(namedBindings)) { + if (!isDeclarationUsed(namedBindings.name)) { + namedBindings = void 0; + } + } else { + const newElements = namedBindings.elements.filter((e) => isDeclarationUsed(e.name)); + if (newElements.length < namedBindings.elements.length) { + namedBindings = newElements.length ? factory.updateNamedImports(namedBindings, newElements) : void 0; + } } - if (typeof pathPattern === "string" || matchedPath === void 0 || comparePaths2(key, matchedPath) !== 1 /* GreaterThan */) { - pathResults.push({ - matchedPattern: isMatch, - results: getCompletionsForPathMapping(keyWithoutLeadingDotSlash, patterns, fragment, baseDirectory, extensionOptions, host).map(({ name, kind, extension }) => nameAndKind(name, kind, extension)) - }); + } + if (name || namedBindings) { + usedImports.push(updateImportDeclarationAndClause(importDecl, name, namedBindings)); + } else if (hasModuleDeclarationMatchingSpecifier(sourceFile, moduleSpecifier)) { + if (sourceFile.isDeclarationFile) { + usedImports.push(factory.createImportDeclaration( + importDecl.modifiers, + /*importClause*/ + void 0, + moduleSpecifier, + /*attributes*/ + void 0 + )); + } else { + usedImports.push(importDecl); } } } - pathResults.forEach((pathResult) => pathResult.results.forEach((r) => result.add(r))); - return matchedPath !== void 0; - } - function getCompletionEntriesForNonRelativeModules(fragment, scriptPath, mode, compilerOptions, host, extensionOptions, typeChecker) { - const { baseUrl, paths } = compilerOptions; - const result = createNameAndKindSet(); - const moduleResolution = getEmitModuleResolutionKind(compilerOptions); - if (baseUrl) { - const absolute = normalizePath(combinePaths(host.getCurrentDirectory(), baseUrl)); - getCompletionEntriesForDirectoryFragment( - fragment, - absolute, - extensionOptions, - host, - /*moduleSpecifierIsRelative*/ - false, - /*exclude*/ - void 0, - result - ); + return usedImports; + function isDeclarationUsed(identifier) { + return jsxElementsPresent && (identifier.text === jsxNamespace || jsxFragmentFactory && identifier.text === jsxFragmentFactory) && jsxModeNeedsExplicitImport(compilerOptions.jsx) || ts_FindAllReferences_exports.Core.isSymbolReferencedInFile(identifier, typeChecker, sourceFile); } - if (paths) { - const absolute = getPathsBasePath(compilerOptions, host); - addCompletionEntriesFromPaths(result, fragment, absolute, extensionOptions, host, paths); + } + function hasModuleDeclarationMatchingSpecifier(sourceFile, moduleSpecifier) { + const moduleSpecifierText = isStringLiteral(moduleSpecifier) && moduleSpecifier.text; + return isString(moduleSpecifierText) && some(sourceFile.moduleAugmentations, (moduleName) => isStringLiteral(moduleName) && moduleName.text === moduleSpecifierText); + } + function getExternalModuleName2(specifier) { + return specifier !== void 0 && isStringLiteralLike(specifier) ? specifier.text : void 0; + } + function coalesceImports(importGroup, ignoreCase, sourceFile) { + const comparer = getOrganizeImportsOrdinalStringComparer(ignoreCase); + return coalesceImportsWorker(importGroup, comparer, sourceFile); + } + function coalesceImportsWorker(importGroup, comparer, sourceFile) { + if (importGroup.length === 0) { + return importGroup; } - const fragmentDirectory = getFragmentDirectory(fragment); - for (const ambientName of getAmbientModuleCompletions(fragment, fragmentDirectory, typeChecker)) { - result.add(nameAndKind( - ambientName, - "external module name" /* externalModuleName */, - /*extension*/ - void 0 - )); + const { importWithoutClause, typeOnlyImports, regularImports } = getCategorizedImports(importGroup); + const coalescedImports = []; + if (importWithoutClause) { + coalescedImports.push(importWithoutClause); } - getCompletionEntriesFromTypings(host, compilerOptions, scriptPath, fragmentDirectory, extensionOptions, result); - if (moduleResolutionUsesNodeModules(moduleResolution)) { - let foundGlobal = false; - if (fragmentDirectory === void 0) { - for (const moduleName of enumerateNodeModulesVisibleToScript(host, scriptPath)) { - const moduleResult = nameAndKind( - moduleName, - "external module name" /* externalModuleName */, - /*extension*/ - void 0 - ); - if (!result.has(moduleResult.name)) { - foundGlobal = true; - result.add(moduleResult); - } - } + for (const group2 of [regularImports, typeOnlyImports]) { + const isTypeOnly = group2 === typeOnlyImports; + const { defaultImports, namespaceImports, namedImports } = group2; + if (!isTypeOnly && defaultImports.length === 1 && namespaceImports.length === 1 && namedImports.length === 0) { + const defaultImport = defaultImports[0]; + coalescedImports.push( + updateImportDeclarationAndClause(defaultImport, defaultImport.importClause.name, namespaceImports[0].importClause.namedBindings) + ); + continue; } - if (!foundGlobal) { - let ancestorLookup = (ancestor) => { - const nodeModules = combinePaths(ancestor, "node_modules"); - if (tryDirectoryExists(host, nodeModules)) { - getCompletionEntriesForDirectoryFragment( - fragment, - nodeModules, - extensionOptions, - host, - /*moduleSpecifierIsRelative*/ + const sortedNamespaceImports = stableSort(namespaceImports, (i1, i2) => comparer(i1.importClause.namedBindings.name.text, i2.importClause.namedBindings.name.text)); + for (const namespaceImport of sortedNamespaceImports) { + coalescedImports.push( + updateImportDeclarationAndClause( + namespaceImport, + /*name*/ + void 0, + namespaceImport.importClause.namedBindings + ) + ); + } + const firstDefaultImport = firstOrUndefined(defaultImports); + const firstNamedImport = firstOrUndefined(namedImports); + const importDecl = firstDefaultImport ?? firstNamedImport; + if (!importDecl) { + continue; + } + let newDefaultImport; + const newImportSpecifiers = []; + if (defaultImports.length === 1) { + newDefaultImport = defaultImports[0].importClause.name; + } else { + for (const defaultImport of defaultImports) { + newImportSpecifiers.push( + factory.createImportSpecifier( + /*isTypeOnly*/ false, - /*exclude*/ - void 0, - result - ); - } - }; - if (fragmentDirectory && getResolvePackageJsonExports(compilerOptions)) { - const nodeModulesDirectoryLookup = ancestorLookup; - ancestorLookup = (ancestor) => { - const components = getPathComponents(fragment); - components.shift(); - let packagePath = components.shift(); - if (!packagePath) { - return nodeModulesDirectoryLookup(ancestor); - } - if (startsWith(packagePath, "@")) { - const subName = components.shift(); - if (!subName) { - return nodeModulesDirectoryLookup(ancestor); - } - packagePath = combinePaths(packagePath, subName); - } - const packageDirectory = combinePaths(ancestor, "node_modules", packagePath); - const packageFile = combinePaths(packageDirectory, "package.json"); - if (tryFileExists(host, packageFile)) { - const packageJson = readJson(packageFile, host); - const exports = packageJson.exports; - if (exports) { - if (typeof exports !== "object" || exports === null) { - return; - } - const keys = getOwnKeys(exports); - const fragmentSubpath = components.join("/") + (components.length && hasTrailingDirectorySeparator(fragment) ? "/" : ""); - const conditions = mode === 99 /* ESNext */ ? ["node", "import", "types"] : ["node", "require", "types"]; - addCompletionEntriesFromPathsOrExports( - result, - fragmentSubpath, - packageDirectory, - extensionOptions, - host, - keys, - (key) => singleElementArray(getPatternFromFirstMatchingCondition(exports[key], conditions)), - comparePatternKeys - ); - return; - } - } - return nodeModulesDirectoryLookup(ancestor); - }; + factory.createIdentifier("default"), + defaultImport.importClause.name + ) + ); } - forEachAncestorDirectory(scriptPath, ancestorLookup); + } + newImportSpecifiers.push(...getNewImportSpecifiers(namedImports)); + const sortedImportSpecifiers = factory.createNodeArray( + sortSpecifiers(newImportSpecifiers, comparer), + firstNamedImport == null ? void 0 : firstNamedImport.importClause.namedBindings.elements.hasTrailingComma + ); + const newNamedImports = sortedImportSpecifiers.length === 0 ? newDefaultImport ? void 0 : factory.createNamedImports(emptyArray) : firstNamedImport ? factory.updateNamedImports(firstNamedImport.importClause.namedBindings, sortedImportSpecifiers) : factory.createNamedImports(sortedImportSpecifiers); + if (sourceFile && newNamedImports && (firstNamedImport == null ? void 0 : firstNamedImport.importClause.namedBindings) && !rangeIsOnSingleLine(firstNamedImport.importClause.namedBindings, sourceFile)) { + setEmitFlags(newNamedImports, 2 /* MultiLine */); + } + if (isTypeOnly && newDefaultImport && newNamedImports) { + coalescedImports.push( + updateImportDeclarationAndClause( + importDecl, + newDefaultImport, + /*namedBindings*/ + void 0 + ) + ); + coalescedImports.push( + updateImportDeclarationAndClause( + firstNamedImport ?? importDecl, + /*name*/ + void 0, + newNamedImports + ) + ); + } else { + coalescedImports.push( + updateImportDeclarationAndClause(importDecl, newDefaultImport, newNamedImports) + ); } } - return arrayFrom(result.values()); + return coalescedImports; } - function getPatternFromFirstMatchingCondition(target, conditions) { - if (typeof target === "string") { - return target; - } - if (target && typeof target === "object" && !isArray(target)) { - for (const condition in target) { - if (condition === "default" || conditions.indexOf(condition) > -1 || isApplicableVersionedTypesKey(conditions, condition)) { - const pattern = target[condition]; - return getPatternFromFirstMatchingCondition(pattern, conditions); + function getCategorizedImports(importGroup) { + let importWithoutClause; + const typeOnlyImports = { defaultImports: [], namespaceImports: [], namedImports: [] }; + const regularImports = { defaultImports: [], namespaceImports: [], namedImports: [] }; + for (const importDeclaration of importGroup) { + if (importDeclaration.importClause === void 0) { + importWithoutClause = importWithoutClause || importDeclaration; + continue; + } + const group2 = importDeclaration.importClause.isTypeOnly ? typeOnlyImports : regularImports; + const { name, namedBindings } = importDeclaration.importClause; + if (name) { + group2.defaultImports.push(importDeclaration); + } + if (namedBindings) { + if (isNamespaceImport(namedBindings)) { + group2.namespaceImports.push(importDeclaration); + } else { + group2.namedImports.push(importDeclaration); } } } + return { + importWithoutClause, + typeOnlyImports, + regularImports + }; } - function getFragmentDirectory(fragment) { - return containsSlash(fragment) ? hasTrailingDirectorySeparator(fragment) ? fragment : getDirectoryPath(fragment) : void 0; + function coalesceExports(exportGroup, ignoreCase) { + const comparer = getOrganizeImportsOrdinalStringComparer(ignoreCase); + return coalesceExportsWorker(exportGroup, comparer); } - function getCompletionsForPathMapping(path, patterns, fragment, packageDirectory, extensionOptions, host) { - if (!endsWith(path, "*")) { - return !stringContains(path, "*") ? justPathMappingName(path, "script" /* scriptElement */) : emptyArray; - } - const pathPrefix = path.slice(0, path.length - 1); - const remainingFragment = tryRemovePrefix(fragment, pathPrefix); - if (remainingFragment === void 0) { - const starIsFullPathComponent = path[path.length - 2] === "/"; - return starIsFullPathComponent ? justPathMappingName(pathPrefix, "directory" /* directory */) : flatMap(patterns, (pattern) => { - var _a; - return (_a = getModulesForPathsPattern("", packageDirectory, pattern, extensionOptions, host)) == null ? void 0 : _a.map(({ name, ...rest }) => ({ name: pathPrefix + name, ...rest })); - }); - } - return flatMap(patterns, (pattern) => getModulesForPathsPattern(remainingFragment, packageDirectory, pattern, extensionOptions, host)); - function justPathMappingName(name, kind) { - return startsWith(name, fragment) ? [{ name: removeTrailingDirectorySeparator(name), kind, extension: void 0 }] : emptyArray; + function coalesceExportsWorker(exportGroup, comparer) { + if (exportGroup.length === 0) { + return exportGroup; } - } - function getModulesForPathsPattern(fragment, packageDirectory, pattern, extensionOptions, host) { - if (!host.readDirectory) { - return void 0; + const { exportWithoutClause, namedExports, typeOnlyExports } = getCategorizedExports(exportGroup); + const coalescedExports = []; + if (exportWithoutClause) { + coalescedExports.push(exportWithoutClause); } - const parsed = tryParsePattern(pattern); - if (parsed === void 0 || isString(parsed)) { - return void 0; + for (const exportGroup2 of [namedExports, typeOnlyExports]) { + if (exportGroup2.length === 0) { + continue; + } + const newExportSpecifiers = []; + newExportSpecifiers.push(...flatMap(exportGroup2, (i) => i.exportClause && isNamedExports(i.exportClause) ? i.exportClause.elements : emptyArray)); + const sortedExportSpecifiers = sortSpecifiers(newExportSpecifiers, comparer); + const exportDecl = exportGroup2[0]; + coalescedExports.push( + factory.updateExportDeclaration( + exportDecl, + exportDecl.modifiers, + exportDecl.isTypeOnly, + exportDecl.exportClause && (isNamedExports(exportDecl.exportClause) ? factory.updateNamedExports(exportDecl.exportClause, sortedExportSpecifiers) : factory.updateNamespaceExport(exportDecl.exportClause, exportDecl.exportClause.name)), + exportDecl.moduleSpecifier, + exportDecl.attributes + ) + ); } - const normalizedPrefix = resolvePath(parsed.prefix); - const normalizedPrefixDirectory = hasTrailingDirectorySeparator(parsed.prefix) ? normalizedPrefix : getDirectoryPath(normalizedPrefix); - const normalizedPrefixBase = hasTrailingDirectorySeparator(parsed.prefix) ? "" : getBaseFileName(normalizedPrefix); - const fragmentHasPath = containsSlash(fragment); - const fragmentDirectory = fragmentHasPath ? hasTrailingDirectorySeparator(fragment) ? fragment : getDirectoryPath(fragment) : void 0; - const expandedPrefixDirectory = fragmentHasPath ? combinePaths(normalizedPrefixDirectory, normalizedPrefixBase + fragmentDirectory) : normalizedPrefixDirectory; - const normalizedSuffix = normalizePath(parsed.suffix); - const baseDirectory = normalizePath(combinePaths(packageDirectory, expandedPrefixDirectory)); - const completePrefix = fragmentHasPath ? baseDirectory : ensureTrailingDirectorySeparator(baseDirectory) + normalizedPrefixBase; - const includeGlob = normalizedSuffix ? "**/*" + normalizedSuffix : "./*"; - const matches = mapDefined(tryReadDirectory( - host, - baseDirectory, - extensionOptions.extensionsToSearch, - /*exclude*/ - void 0, - [includeGlob] - ), (match) => { - const trimmedWithPattern = trimPrefixAndSuffix(match); - if (trimmedWithPattern) { - if (containsSlash(trimmedWithPattern)) { - return directoryResult(getPathComponents(removeLeadingDirectorySeparator(trimmedWithPattern))[1]); + return coalescedExports; + function getCategorizedExports(exportGroup2) { + let exportWithoutClause2; + const namedExports2 = []; + const typeOnlyExports2 = []; + for (const exportDeclaration of exportGroup2) { + if (exportDeclaration.exportClause === void 0) { + exportWithoutClause2 = exportWithoutClause2 || exportDeclaration; + } else if (exportDeclaration.isTypeOnly) { + typeOnlyExports2.push(exportDeclaration); + } else { + namedExports2.push(exportDeclaration); } - const { name, extension } = getFilenameWithExtensionOption(trimmedWithPattern, host.getCompilationSettings(), extensionOptions); - return nameAndKind(name, "script" /* scriptElement */, extension); } - }); - const directories = normalizedSuffix ? emptyArray : mapDefined(tryGetDirectories(host, baseDirectory), (dir) => dir === "node_modules" ? void 0 : directoryResult(dir)); - return [...matches, ...directories]; - function trimPrefixAndSuffix(path) { - const inner = withoutStartAndEnd(normalizePath(path), completePrefix, normalizedSuffix); - return inner === void 0 ? void 0 : removeLeadingDirectorySeparator(inner); + return { + exportWithoutClause: exportWithoutClause2, + namedExports: namedExports2, + typeOnlyExports: typeOnlyExports2 + }; } } - function withoutStartAndEnd(s, start, end) { - return startsWith(s, start) && endsWith(s, end) ? s.slice(start.length, s.length - end.length) : void 0; + function updateImportDeclarationAndClause(importDeclaration, name, namedBindings) { + return factory.updateImportDeclaration( + importDeclaration, + importDeclaration.modifiers, + factory.updateImportClause(importDeclaration.importClause, importDeclaration.importClause.isTypeOnly, name, namedBindings), + // TODO: GH#18217 + importDeclaration.moduleSpecifier, + importDeclaration.attributes + ); } - function removeLeadingDirectorySeparator(path) { - return path[0] === directorySeparator ? path.slice(1) : path; + function sortSpecifiers(specifiers, comparer) { + return stableSort(specifiers, (s1, s2) => compareImportOrExportSpecifiers(s1, s2, comparer)); } - function getAmbientModuleCompletions(fragment, fragmentDirectory, checker) { - const ambientModules = checker.getAmbientModules().map((sym) => stripQuotes(sym.name)); - const nonRelativeModuleNames = ambientModules.filter((moduleName) => startsWith(moduleName, fragment) && moduleName.indexOf("*") < 0); - if (fragmentDirectory !== void 0) { - const moduleNameWithSeparator = ensureTrailingDirectorySeparator(fragmentDirectory); - return nonRelativeModuleNames.map((nonRelativeModuleName) => removePrefix(nonRelativeModuleName, moduleNameWithSeparator)); - } - return nonRelativeModuleNames; + function compareImportOrExportSpecifiers(s1, s2, comparer) { + return compareBooleans(s1.isTypeOnly, s2.isTypeOnly) || comparer(s1.name.text, s2.name.text); } - function getTripleSlashReferenceCompletion(sourceFile, position, compilerOptions, host) { - const token = getTokenAtPosition(sourceFile, position); - const commentRanges = getLeadingCommentRanges(sourceFile.text, token.pos); - const range = commentRanges && find(commentRanges, (commentRange) => position >= commentRange.pos && position <= commentRange.end); - if (!range) { - return void 0; - } - const text = sourceFile.text.slice(range.pos, position); - const match = tripleSlashDirectiveFragmentRegex.exec(text); - if (!match) { - return void 0; - } - const [, prefix, kind, toComplete] = match; - const scriptPath = getDirectoryPath(sourceFile.path); - const names = kind === "path" ? getCompletionEntriesForDirectoryFragment( - toComplete, - scriptPath, - getExtensionOptions(compilerOptions, 0 /* Filename */, sourceFile), - host, - /*moduleSpecifierIsRelative*/ - true, - sourceFile.path - ) : kind === "types" ? getCompletionEntriesFromTypings(host, compilerOptions, scriptPath, getFragmentDirectory(toComplete), getExtensionOptions(compilerOptions, 1 /* ModuleSpecifier */, sourceFile)) : Debug.fail(); - return addReplacementSpans(toComplete, range.pos + prefix.length, arrayFrom(names.values())); + function compareModuleSpecifiers2(m1, m2, ignoreCase) { + const comparer = getOrganizeImportsOrdinalStringComparer(!!ignoreCase); + return compareModuleSpecifiersWorker(m1, m2, comparer); } - function getCompletionEntriesFromTypings(host, options, scriptPath, fragmentDirectory, extensionOptions, result = createNameAndKindSet()) { - const seen = /* @__PURE__ */ new Map(); - const typeRoots = tryAndIgnoreErrors(() => getEffectiveTypeRoots(options, host)) || emptyArray; - for (const root of typeRoots) { - getCompletionEntriesFromDirectories(root); - } - for (const packageJson of findPackageJsons(scriptPath, host)) { - const typesDir = combinePaths(getDirectoryPath(packageJson), "node_modules/@types"); - getCompletionEntriesFromDirectories(typesDir); + function compareModuleSpecifiersWorker(m1, m2, comparer) { + const name1 = m1 === void 0 ? void 0 : getExternalModuleName2(m1); + const name2 = m2 === void 0 ? void 0 : getExternalModuleName2(m2); + return compareBooleans(name1 === void 0, name2 === void 0) || compareBooleans(isExternalModuleNameRelative(name1), isExternalModuleNameRelative(name2)) || comparer(name1, name2); + } + function getModuleSpecifierExpression(declaration) { + var _a; + switch (declaration.kind) { + case 271 /* ImportEqualsDeclaration */: + return (_a = tryCast(declaration.moduleReference, isExternalModuleReference)) == null ? void 0 : _a.expression; + case 272 /* ImportDeclaration */: + return declaration.moduleSpecifier; + case 243 /* VariableStatement */: + return declaration.declarationList.declarations[0].initializer.arguments[0]; } - return result; - function getCompletionEntriesFromDirectories(directory) { - if (!tryDirectoryExists(host, directory)) - return; - for (const typeDirectoryName of tryGetDirectories(host, directory)) { - const packageName = unmangleScopedPackageName(typeDirectoryName); - if (options.types && !contains(options.types, packageName)) - continue; - if (fragmentDirectory === void 0) { - if (!seen.has(packageName)) { - result.add(nameAndKind( - packageName, - "external module name" /* externalModuleName */, - /*extension*/ - void 0 - )); - seen.set(packageName, true); - } - } else { - const baseDirectory = combinePaths(directory, typeDirectoryName); - const remainingFragment = tryRemoveDirectoryPrefix(fragmentDirectory, packageName, hostGetCanonicalFileName(host)); - if (remainingFragment !== void 0) { - getCompletionEntriesForDirectoryFragment( - remainingFragment, - baseDirectory, - extensionOptions, - host, - /*moduleSpecifierIsRelative*/ - false, - /*exclude*/ - void 0, - result - ); - } + } + function detectSorting(sourceFile, preferences) { + return detectSortingWorker( + groupByNewlineContiguous(sourceFile, sourceFile.statements.filter(isImportDeclaration)), + preferences + ); + } + function detectSortingWorker(importGroups, preferences) { + const collateCaseSensitive = getOrganizeImportsComparer( + preferences, + /*ignoreCase*/ + false + ); + const collateCaseInsensitive = getOrganizeImportsComparer( + preferences, + /*ignoreCase*/ + true + ); + let sortState = 3 /* Both */; + let seenUnsortedGroup = false; + for (const importGroup of importGroups) { + if (importGroup.length > 1) { + const moduleSpecifierSort = detectSortCaseSensitivity( + importGroup, + (i) => { + var _a; + return ((_a = tryCast(i.moduleSpecifier, isStringLiteral)) == null ? void 0 : _a.text) ?? ""; + }, + collateCaseSensitive, + collateCaseInsensitive + ); + if (moduleSpecifierSort) { + sortState &= moduleSpecifierSort; + seenUnsortedGroup = true; + } + if (!sortState) { + return sortState; } } - } - } - function enumerateNodeModulesVisibleToScript(host, scriptPath) { - if (!host.readFile || !host.fileExists) - return emptyArray; - const result = []; - for (const packageJson of findPackageJsons(scriptPath, host)) { - const contents = readJson(packageJson, host); - for (const key of nodeModulesDependencyKeys) { - const dependencies = contents[key]; - if (!dependencies) - continue; - for (const dep in dependencies) { - if (hasProperty(dependencies, dep) && !startsWith(dep, "@types/")) { - result.push(dep); - } + const declarationWithNamedImports = find( + importGroup, + (i) => { + var _a, _b; + return ((_b = tryCast((_a = i.importClause) == null ? void 0 : _a.namedBindings, isNamedImports)) == null ? void 0 : _b.elements.length) > 1; + } + ); + if (declarationWithNamedImports) { + const namedImportSort = detectImportSpecifierSorting(declarationWithNamedImports.importClause.namedBindings.elements, preferences); + if (namedImportSort) { + sortState &= namedImportSort; + seenUnsortedGroup = true; } + if (!sortState) { + return sortState; + } + } + if (sortState !== 3 /* Both */) { + return sortState; } } - return result; + return seenUnsortedGroup ? 0 /* None */ : sortState; } - function getDirectoryFragmentTextSpan(text, textStart) { - const index = Math.max(text.lastIndexOf(directorySeparator), text.lastIndexOf(altDirectorySeparator)); - const offset = index !== -1 ? index + 1 : 0; - const length2 = text.length - offset; - return length2 === 0 || isIdentifierText(text.substr(offset, length2), 99 /* ESNext */) ? void 0 : createTextSpan(textStart + offset, length2); + function detectImportDeclarationSorting(imports, preferences) { + const collateCaseSensitive = getOrganizeImportsComparer( + preferences, + /*ignoreCase*/ + false + ); + const collateCaseInsensitive = getOrganizeImportsComparer( + preferences, + /*ignoreCase*/ + true + ); + return detectSortCaseSensitivity( + imports, + (s) => getExternalModuleName2(getModuleSpecifierExpression(s)) || "", + collateCaseSensitive, + collateCaseInsensitive + ); } - function isPathRelativeToScript(path) { - if (path && path.length >= 2 && path.charCodeAt(0) === 46 /* dot */) { - const slashIndex = path.length >= 3 && path.charCodeAt(1) === 46 /* dot */ ? 2 : 1; - const slashCharCode = path.charCodeAt(slashIndex); - return slashCharCode === 47 /* slash */ || slashCharCode === 92 /* backslash */; - } - return false; + function getImportDeclarationInsertionIndex(sortedImports, newImport, comparer) { + const index = binarySearch(sortedImports, newImport, identity, (a, b) => compareImportsOrRequireStatements(a, b, comparer)); + return index < 0 ? ~index : index; } - function containsSlash(fragment) { - return stringContains(fragment, directorySeparator); + function getImportSpecifierInsertionIndex(sortedImports, newImport, comparer) { + const index = binarySearch(sortedImports, newImport, identity, (s1, s2) => compareImportOrExportSpecifiers(s1, s2, comparer)); + return index < 0 ? ~index : index; } - function isRequireCallArgument(node) { - return isCallExpression(node.parent) && firstOrUndefined(node.parent.arguments) === node && isIdentifier(node.parent.expression) && node.parent.expression.escapedText === "require"; + function compareImportsOrRequireStatements(s1, s2, comparer) { + return compareModuleSpecifiersWorker(getModuleSpecifierExpression(s1), getModuleSpecifierExpression(s2), comparer) || compareImportKind(s1, s2); } - var kindPrecedence, tripleSlashDirectiveFragmentRegex, nodeModulesDependencyKeys; - var init_stringCompletions = __esm({ - "src/services/stringCompletions.ts"() { - "use strict"; - init_ts4(); - init_ts_Completions(); - kindPrecedence = { - ["directory" /* directory */]: 0, - ["script" /* scriptElement */]: 1, - ["external module name" /* externalModuleName */]: 2 - }; - tripleSlashDirectiveFragmentRegex = /^(\/\/\/\s* getStringLiteralCompletionDetails, - getStringLiteralCompletions: () => getStringLiteralCompletions - }); - var init_ts_Completions_StringCompletions = __esm({ - "src/services/_namespaces/ts.Completions.StringCompletions.ts"() { - "use strict"; - init_stringCompletions(); - } - }); - - // src/services/_namespaces/ts.Completions.ts - var ts_Completions_exports = {}; - __export(ts_Completions_exports, { - CompletionKind: () => CompletionKind, - CompletionSource: () => CompletionSource, - SortText: () => SortText, - StringCompletions: () => ts_Completions_StringCompletions_exports, - SymbolOriginInfoKind: () => SymbolOriginInfoKind, - createCompletionDetails: () => createCompletionDetails, - createCompletionDetailsForSymbol: () => createCompletionDetailsForSymbol, - getCompletionEntriesFromSymbols: () => getCompletionEntriesFromSymbols, - getCompletionEntryDetails: () => getCompletionEntryDetails, - getCompletionEntrySymbol: () => getCompletionEntrySymbol, - getCompletionsAtPosition: () => getCompletionsAtPosition, - getPropertiesForObjectExpression: () => getPropertiesForObjectExpression, - moduleSpecifierResolutionCacheAttemptLimit: () => moduleSpecifierResolutionCacheAttemptLimit, - moduleSpecifierResolutionLimit: () => moduleSpecifierResolutionLimit - }); - var init_ts_Completions = __esm({ - "src/services/_namespaces/ts.Completions.ts"() { - "use strict"; - init_completions(); - init_ts_Completions_StringCompletions(); - } - }); - - // src/services/importTracker.ts - function createImportTracker(sourceFiles, sourceFilesSet, checker, cancellationToken) { - const allDirectImports = getDirectImportsMap(sourceFiles, checker, cancellationToken); - return (exportSymbol, exportInfo, isForRename) => { - const { directImports, indirectUsers } = getImportersForExport(sourceFiles, sourceFilesSet, allDirectImports, exportInfo, checker, cancellationToken); - return { indirectUsers, ...getSearchesFromDirectImports(directImports, exportSymbol, exportInfo.exportKind, checker, isForRename) }; - }; + function compareImportKind(s1, s2) { + return compareValues(getImportKindOrder(s1), getImportKindOrder(s2)); } - function getImportersForExport(sourceFiles, sourceFilesSet, allDirectImports, { exportingModuleSymbol, exportKind }, checker, cancellationToken) { - const markSeenDirectImport = nodeSeenTracker(); - const markSeenIndirectUser = nodeSeenTracker(); - const directImports = []; - const isAvailableThroughGlobal = !!exportingModuleSymbol.globalExports; - const indirectUserDeclarations = isAvailableThroughGlobal ? void 0 : []; - handleDirectImports(exportingModuleSymbol); - return { directImports, indirectUsers: getIndirectUsers() }; - function getIndirectUsers() { - if (isAvailableThroughGlobal) { - return sourceFiles; - } - if (exportingModuleSymbol.declarations) { - for (const decl of exportingModuleSymbol.declarations) { - if (isExternalModuleAugmentation(decl) && sourceFilesSet.has(decl.getSourceFile().fileName)) { - addIndirectUser(decl); - } - } - } - return indirectUserDeclarations.map(getSourceFileOfNode); - } - function handleDirectImports(exportingModuleSymbol2) { - const theseDirectImports = getDirectImports(exportingModuleSymbol2); - if (theseDirectImports) { - for (const direct of theseDirectImports) { - if (!markSeenDirectImport(direct)) { - continue; - } - if (cancellationToken) - cancellationToken.throwIfCancellationRequested(); - switch (direct.kind) { - case 212 /* CallExpression */: - if (isImportCall(direct)) { - handleImportCall(direct); - break; - } - if (!isAvailableThroughGlobal) { - const parent2 = direct.parent; - if (exportKind === 2 /* ExportEquals */ && parent2.kind === 259 /* VariableDeclaration */) { - const { name } = parent2; - if (name.kind === 80 /* Identifier */) { - directImports.push(name); - break; - } - } - } - break; - case 80 /* Identifier */: - break; - case 270 /* ImportEqualsDeclaration */: - handleNamespaceImport( - direct, - direct.name, - hasSyntacticModifier(direct, 1 /* Export */), - /*alreadyAddedDirect*/ - false - ); - break; - case 271 /* ImportDeclaration */: - directImports.push(direct); - const namedBindings = direct.importClause && direct.importClause.namedBindings; - if (namedBindings && namedBindings.kind === 273 /* NamespaceImport */) { - handleNamespaceImport( - direct, - namedBindings.name, - /*isReExport*/ - false, - /*alreadyAddedDirect*/ - true - ); - } else if (!isAvailableThroughGlobal && isDefaultImport(direct)) { - addIndirectUser(getSourceFileLikeForImportDeclaration(direct)); - } - break; - case 277 /* ExportDeclaration */: - if (!direct.exportClause) { - handleDirectImports(getContainingModuleSymbol(direct, checker)); - } else if (direct.exportClause.kind === 279 /* NamespaceExport */) { - addIndirectUser( - getSourceFileLikeForImportDeclaration(direct), - /*addTransitiveDependencies*/ - true - ); - } else { - directImports.push(direct); - } - break; - case 204 /* ImportType */: - if (!isAvailableThroughGlobal && direct.isTypeOf && !direct.qualifier && isExported2(direct)) { - addIndirectUser( - direct.getSourceFile(), - /*addTransitiveDependencies*/ - true - ); - } - directImports.push(direct); - break; - default: - Debug.failBadSyntaxKind(direct, "Unexpected import kind."); - } - } - } - } - function handleImportCall(importCall) { - const top = findAncestor(importCall, isAmbientModuleDeclaration) || importCall.getSourceFile(); - addIndirectUser( - top, - /** addTransitiveDependencies */ - !!isExported2( - importCall, - /*stopAtAmbientModule*/ - true - ) - ); - } - function isExported2(node, stopAtAmbientModule = false) { - return findAncestor(node, (node2) => { - if (stopAtAmbientModule && isAmbientModuleDeclaration(node2)) - return "quit"; - return canHaveModifiers(node2) && some(node2.modifiers, isExportModifier); - }); + function getImportKindOrder(s1) { + var _a; + switch (s1.kind) { + case 272 /* ImportDeclaration */: + if (!s1.importClause) + return 0; + if (s1.importClause.isTypeOnly) + return 1; + if (((_a = s1.importClause.namedBindings) == null ? void 0 : _a.kind) === 274 /* NamespaceImport */) + return 2; + if (s1.importClause.name) + return 3; + return 4; + case 271 /* ImportEqualsDeclaration */: + return 5; + case 243 /* VariableStatement */: + return 6; } - function handleNamespaceImport(importDeclaration, name, isReExport, alreadyAddedDirect) { - if (exportKind === 2 /* ExportEquals */) { - if (!alreadyAddedDirect) - directImports.push(importDeclaration); - } else if (!isAvailableThroughGlobal) { - const sourceFileLike = getSourceFileLikeForImportDeclaration(importDeclaration); - Debug.assert(sourceFileLike.kind === 311 /* SourceFile */ || sourceFileLike.kind === 266 /* ModuleDeclaration */); - if (isReExport || findNamespaceReExports(sourceFileLike, name, checker)) { - addIndirectUser( - sourceFileLike, - /*addTransitiveDependencies*/ - true - ); - } else { - addIndirectUser(sourceFileLike); + } + function getNewImportSpecifiers(namedImports) { + return flatMap(namedImports, (namedImport) => map(tryGetNamedBindingElements(namedImport), (importSpecifier) => importSpecifier.name && importSpecifier.propertyName && importSpecifier.name.escapedText === importSpecifier.propertyName.escapedText ? factory.updateImportSpecifier( + importSpecifier, + importSpecifier.isTypeOnly, + /*propertyName*/ + void 0, + importSpecifier.name + ) : importSpecifier)); + } + function tryGetNamedBindingElements(namedImport) { + var _a; + return ((_a = namedImport.importClause) == null ? void 0 : _a.namedBindings) && isNamedImports(namedImport.importClause.namedBindings) ? namedImport.importClause.namedBindings.elements : void 0; + } + function getOrganizeImportsOrdinalStringComparer(ignoreCase) { + return ignoreCase ? compareStringsCaseInsensitiveEslintCompatible : compareStringsCaseSensitive; + } + function getOrganizeImportsUnicodeStringComparer(ignoreCase, preferences) { + const resolvedLocale = getOrganizeImportsLocale(preferences); + const caseFirst = preferences.organizeImportsCaseFirst ?? false; + const numeric = preferences.organizeImportsNumericCollation ?? false; + const accents = preferences.organizeImportsAccentCollation ?? true; + const sensitivity = ignoreCase ? accents ? "accent" : "base" : accents ? "variant" : "case"; + const collator = new Intl.Collator(resolvedLocale, { + usage: "sort", + caseFirst: caseFirst || "false", + sensitivity, + numeric + }); + return collator.compare; + } + function getOrganizeImportsLocale(preferences) { + let locale = preferences.organizeImportsLocale; + if (locale === "auto") + locale = getUILocale(); + if (locale === void 0) + locale = "en"; + const supportedLocales = Intl.Collator.supportedLocalesOf(locale); + const resolvedLocale = supportedLocales.length ? supportedLocales[0] : "en"; + return resolvedLocale; + } + function getOrganizeImportsComparer(preferences, ignoreCase) { + const collation = preferences.organizeImportsCollation ?? "ordinal"; + return collation === "unicode" ? getOrganizeImportsUnicodeStringComparer(ignoreCase, preferences) : getOrganizeImportsOrdinalStringComparer(ignoreCase); + } + function getOrganizeImportsComparerWithDetection(preferences, detectIgnoreCase) { + const ignoreCase = typeof preferences.organizeImportsIgnoreCase === "boolean" ? preferences.organizeImportsIgnoreCase : (detectIgnoreCase == null ? void 0 : detectIgnoreCase()) ?? false; + return getOrganizeImportsComparer(preferences, ignoreCase); + } + function getTopLevelExportGroups(sourceFile) { + const topLevelExportGroups = []; + const statements = sourceFile.statements; + const len = length(statements); + let i = 0; + let groupIndex = 0; + while (i < len) { + if (isExportDeclaration(statements[i])) { + if (topLevelExportGroups[groupIndex] === void 0) { + topLevelExportGroups[groupIndex] = []; } - } - } - function addIndirectUser(sourceFileLike, addTransitiveDependencies = false) { - Debug.assert(!isAvailableThroughGlobal); - const isNew = markSeenIndirectUser(sourceFileLike); - if (!isNew) - return; - indirectUserDeclarations.push(sourceFileLike); - if (!addTransitiveDependencies) - return; - const moduleSymbol = checker.getMergedSymbol(sourceFileLike.symbol); - if (!moduleSymbol) - return; - Debug.assert(!!(moduleSymbol.flags & 1536 /* Module */)); - const directImports2 = getDirectImports(moduleSymbol); - if (directImports2) { - for (const directImport of directImports2) { - if (!isImportTypeNode(directImport)) { - addIndirectUser( - getSourceFileLikeForImportDeclaration(directImport), - /*addTransitiveDependencies*/ - true - ); + const exportDecl = statements[i]; + if (exportDecl.moduleSpecifier) { + topLevelExportGroups[groupIndex].push(exportDecl); + i++; + } else { + while (i < len && isExportDeclaration(statements[i])) { + topLevelExportGroups[groupIndex].push(statements[i++]); } + groupIndex++; } + } else { + i++; } } - function getDirectImports(moduleSymbol) { - return allDirectImports.get(getSymbolId(moduleSymbol).toString()); - } + return flatMap(topLevelExportGroups, (exportGroupDecls) => groupByNewlineContiguous(sourceFile, exportGroupDecls)); } - function getSearchesFromDirectImports(directImports, exportSymbol, exportKind, checker, isForRename) { - const importSearches = []; - const singleReferences = []; - function addSearch(location, symbol) { - importSearches.push([location, symbol]); + var ImportSpecifierSortingCache, detectImportSpecifierSorting; + var init_organizeImports = __esm({ + "src/services/organizeImports.ts"() { + "use strict"; + init_ts4(); + ImportSpecifierSortingCache = class { + has([specifiers, preferences]) { + if (this._lastPreferences !== preferences || !this._cache) + return false; + return this._cache.has(specifiers); + } + get([specifiers, preferences]) { + if (this._lastPreferences !== preferences || !this._cache) + return void 0; + return this._cache.get(specifiers); + } + set([specifiers, preferences], value) { + if (this._lastPreferences !== preferences) { + this._lastPreferences = preferences; + this._cache = void 0; + } + this._cache ?? (this._cache = /* @__PURE__ */ new WeakMap()); + this._cache.set(specifiers, value); + } + }; + detectImportSpecifierSorting = memoizeCached((specifiers, preferences) => { + if (!arrayIsSorted(specifiers, (s1, s2) => compareBooleans(s1.isTypeOnly, s2.isTypeOnly))) { + return 0 /* None */; + } + const collateCaseSensitive = getOrganizeImportsComparer( + preferences, + /*ignoreCase*/ + false + ); + const collateCaseInsensitive = getOrganizeImportsComparer( + preferences, + /*ignoreCase*/ + true + ); + return detectSortCaseSensitivity(specifiers, (specifier) => specifier.name.text, collateCaseSensitive, collateCaseInsensitive); + }, new ImportSpecifierSortingCache()); } - if (directImports) { - for (const decl of directImports) { - handleImport(decl); - } + }); + + // src/services/_namespaces/ts.OrganizeImports.ts + var ts_OrganizeImports_exports = {}; + __export(ts_OrganizeImports_exports, { + coalesceExports: () => coalesceExports, + coalesceImports: () => coalesceImports, + compareImportOrExportSpecifiers: () => compareImportOrExportSpecifiers, + compareImportsOrRequireStatements: () => compareImportsOrRequireStatements, + compareModuleSpecifiers: () => compareModuleSpecifiers2, + detectImportDeclarationSorting: () => detectImportDeclarationSorting, + detectImportSpecifierSorting: () => detectImportSpecifierSorting, + detectSorting: () => detectSorting, + getImportDeclarationInsertionIndex: () => getImportDeclarationInsertionIndex, + getImportSpecifierInsertionIndex: () => getImportSpecifierInsertionIndex, + getOrganizeImportsComparer: () => getOrganizeImportsComparer, + organizeImports: () => organizeImports + }); + var init_ts_OrganizeImports = __esm({ + "src/services/_namespaces/ts.OrganizeImports.ts"() { + "use strict"; + init_organizeImports(); } - return { importSearches, singleReferences }; - function handleImport(decl) { - if (decl.kind === 270 /* ImportEqualsDeclaration */) { - if (isExternalModuleImportEquals(decl)) { - handleNamespaceImportLike(decl.name); - } - return; + }); + + // src/services/outliningElementsCollector.ts + function collectElements(sourceFile, cancellationToken) { + const res = []; + addNodeOutliningSpans(sourceFile, cancellationToken, res); + addRegionOutliningSpans(sourceFile, res); + return res.sort((span1, span2) => span1.textSpan.start - span2.textSpan.start); + } + function addNodeOutliningSpans(sourceFile, cancellationToken, out) { + let depthRemaining = 40; + let current = 0; + const statements = [...sourceFile.statements, sourceFile.endOfFileToken]; + const n = statements.length; + while (current < n) { + while (current < n && !isAnyImportSyntax(statements[current])) { + visitNode3(statements[current]); + current++; } - if (decl.kind === 80 /* Identifier */) { - handleNamespaceImportLike(decl); - return; + if (current === n) + break; + const firstImport = current; + while (current < n && isAnyImportSyntax(statements[current])) { + visitNode3(statements[current]); + current++; } - if (decl.kind === 204 /* ImportType */) { - if (decl.qualifier) { - const firstIdentifier = getFirstIdentifier(decl.qualifier); - if (firstIdentifier.escapedText === symbolName(exportSymbol)) { - singleReferences.push(firstIdentifier); - } - } else if (exportKind === 2 /* ExportEquals */) { - singleReferences.push(decl.argument.literal); - } - return; + const lastImport = current - 1; + if (lastImport !== firstImport) { + out.push(createOutliningSpanFromBounds(findChildOfKind(statements[firstImport], 102 /* ImportKeyword */, sourceFile).getStart(sourceFile), statements[lastImport].getEnd(), "imports" /* Imports */)); } - if (decl.moduleSpecifier.kind !== 11 /* StringLiteral */) { + } + function visitNode3(n2) { + var _a; + if (depthRemaining === 0) return; + cancellationToken.throwIfCancellationRequested(); + if (isDeclaration(n2) || isVariableStatement(n2) || isReturnStatement(n2) || isCallOrNewExpression(n2) || n2.kind === 1 /* EndOfFileToken */) { + addOutliningForLeadingCommentsForNode(n2, sourceFile, cancellationToken, out); } - if (decl.kind === 277 /* ExportDeclaration */) { - if (decl.exportClause && isNamedExports(decl.exportClause)) { - searchForNamedImport(decl.exportClause); - } - return; + if (isFunctionLike(n2) && isBinaryExpression(n2.parent) && isPropertyAccessExpression(n2.parent.left)) { + addOutliningForLeadingCommentsForNode(n2.parent.left, sourceFile, cancellationToken, out); } - const { name, namedBindings } = decl.importClause || { name: void 0, namedBindings: void 0 }; - if (namedBindings) { - switch (namedBindings.kind) { - case 273 /* NamespaceImport */: - handleNamespaceImportLike(namedBindings.name); - break; - case 274 /* NamedImports */: - if (exportKind === 0 /* Named */ || exportKind === 1 /* Default */) { - searchForNamedImport(namedBindings); - } - break; - default: - Debug.assertNever(namedBindings); - } + if (isBlock(n2) || isModuleBlock(n2)) { + addOutliningForLeadingCommentsForPos(n2.statements.end, sourceFile, cancellationToken, out); } - if (name && (exportKind === 1 /* Default */ || exportKind === 2 /* ExportEquals */) && (!isForRename || name.escapedText === symbolEscapedNameNoDefault(exportSymbol))) { - const defaultImportAlias = checker.getSymbolAtLocation(name); - addSearch(name, defaultImportAlias); + if (isClassLike(n2) || isInterfaceDeclaration(n2)) { + addOutliningForLeadingCommentsForPos(n2.members.end, sourceFile, cancellationToken, out); } - } - function handleNamespaceImportLike(importName) { - if (exportKind === 2 /* ExportEquals */ && (!isForRename || isNameMatch(importName.escapedText))) { - addSearch(importName, checker.getSymbolAtLocation(importName)); + const span = getOutliningSpanForNode(n2, sourceFile); + if (span) + out.push(span); + depthRemaining--; + if (isCallExpression(n2)) { + depthRemaining++; + visitNode3(n2.expression); + depthRemaining--; + n2.arguments.forEach(visitNode3); + (_a = n2.typeArguments) == null ? void 0 : _a.forEach(visitNode3); + } else if (isIfStatement(n2) && n2.elseStatement && isIfStatement(n2.elseStatement)) { + visitNode3(n2.expression); + visitNode3(n2.thenStatement); + depthRemaining++; + visitNode3(n2.elseStatement); + depthRemaining--; + } else { + n2.forEachChild(visitNode3); } + depthRemaining++; } - function searchForNamedImport(namedBindings) { - if (!namedBindings) { - return; + } + function addRegionOutliningSpans(sourceFile, out) { + const regions = []; + const lineStarts = sourceFile.getLineStarts(); + for (const currentLineStart of lineStarts) { + const lineEnd = sourceFile.getLineEndOfPosition(currentLineStart); + const lineText = sourceFile.text.substring(currentLineStart, lineEnd); + const result = isRegionDelimiter(lineText); + if (!result || isInComment(sourceFile, currentLineStart)) { + continue; } - for (const element of namedBindings.elements) { - const { name, propertyName } = element; - if (!isNameMatch((propertyName || name).escapedText)) { - continue; - } - if (propertyName) { - singleReferences.push(propertyName); - if (!isForRename || name.escapedText === exportSymbol.escapedName) { - addSearch(name, checker.getSymbolAtLocation(name)); - } - } else { - const localSymbol = element.kind === 280 /* ExportSpecifier */ && element.propertyName ? checker.getExportSpecifierLocalTargetSymbol(element) : checker.getSymbolAtLocation(name); - addSearch(name, localSymbol); + if (!result[1]) { + const span = createTextSpanFromBounds(sourceFile.text.indexOf("//", currentLineStart), lineEnd); + regions.push(createOutliningSpan( + span, + "region" /* Region */, + span, + /*autoCollapse*/ + false, + result[2] || "#region" + )); + } else { + const region = regions.pop(); + if (region) { + region.textSpan.length = lineEnd - region.textSpan.start; + region.hintSpan.length = lineEnd - region.textSpan.start; + out.push(region); } } } - function isNameMatch(name) { - return name === exportSymbol.escapedName || exportKind !== 0 /* Named */ && name === "default" /* Default */; - } } - function findNamespaceReExports(sourceFileLike, name, checker) { - const namespaceImportSymbol = checker.getSymbolAtLocation(name); - return !!forEachPossibleImportOrExportStatement(sourceFileLike, (statement) => { - if (!isExportDeclaration(statement)) - return; - const { exportClause, moduleSpecifier } = statement; - return !moduleSpecifier && exportClause && isNamedExports(exportClause) && exportClause.elements.some((element) => checker.getExportSpecifierLocalTargetSymbol(element) === namespaceImportSymbol); - }); + function isRegionDelimiter(lineText) { + lineText = lineText.trimStart(); + if (!startsWith(lineText, "//")) { + return null; + } + lineText = lineText.slice(2).trim(); + return regionDelimiterRegExp.exec(lineText); } - function findModuleReferences(program, sourceFiles, searchModuleSymbol) { - var _a; - const refs = []; - const checker = program.getTypeChecker(); - for (const referencingFile of sourceFiles) { - const searchSourceFile = searchModuleSymbol.valueDeclaration; - if ((searchSourceFile == null ? void 0 : searchSourceFile.kind) === 311 /* SourceFile */) { - for (const ref of referencingFile.referencedFiles) { - if (program.getSourceFileFromReference(referencingFile, ref) === searchSourceFile) { - refs.push({ kind: "reference", referencingFile, ref }); + function addOutliningForLeadingCommentsForPos(pos, sourceFile, cancellationToken, out) { + const comments = getLeadingCommentRanges(sourceFile.text, pos); + if (!comments) + return; + let firstSingleLineCommentStart = -1; + let lastSingleLineCommentEnd = -1; + let singleLineCommentCount = 0; + const sourceText = sourceFile.getFullText(); + for (const { kind, pos: pos2, end } of comments) { + cancellationToken.throwIfCancellationRequested(); + switch (kind) { + case 2 /* SingleLineCommentTrivia */: + const commentText = sourceText.slice(pos2, end); + if (isRegionDelimiter(commentText)) { + combineAndAddMultipleSingleLineComments(); + singleLineCommentCount = 0; + break; } - } - for (const ref of referencingFile.typeReferenceDirectives) { - const referenced = (_a = program.getResolvedTypeReferenceDirectives().get(ref.fileName, ref.resolutionMode || referencingFile.impliedNodeFormat)) == null ? void 0 : _a.resolvedTypeReferenceDirective; - if (referenced !== void 0 && referenced.resolvedFileName === searchSourceFile.fileName) { - refs.push({ kind: "reference", referencingFile, ref }); + if (singleLineCommentCount === 0) { + firstSingleLineCommentStart = pos2; } - } + lastSingleLineCommentEnd = end; + singleLineCommentCount++; + break; + case 3 /* MultiLineCommentTrivia */: + combineAndAddMultipleSingleLineComments(); + out.push(createOutliningSpanFromBounds(pos2, end, "comment" /* Comment */)); + singleLineCommentCount = 0; + break; + default: + Debug.assertNever(kind); } - forEachImport(referencingFile, (importDecl, moduleSpecifier) => { - const moduleSymbol = checker.getSymbolAtLocation(moduleSpecifier); - if (moduleSymbol === searchModuleSymbol) { - refs.push(nodeIsSynthesized(importDecl) ? { kind: "implicit", literal: moduleSpecifier, referencingFile } : { kind: "import", literal: moduleSpecifier }); - } - }); } - return refs; - } - function getDirectImportsMap(sourceFiles, checker, cancellationToken) { - const map2 = /* @__PURE__ */ new Map(); - for (const sourceFile of sourceFiles) { - if (cancellationToken) - cancellationToken.throwIfCancellationRequested(); - forEachImport(sourceFile, (importDecl, moduleSpecifier) => { - const moduleSymbol = checker.getSymbolAtLocation(moduleSpecifier); - if (moduleSymbol) { - const id = getSymbolId(moduleSymbol).toString(); - let imports = map2.get(id); - if (!imports) { - map2.set(id, imports = []); - } - imports.push(importDecl); - } - }); + combineAndAddMultipleSingleLineComments(); + function combineAndAddMultipleSingleLineComments() { + if (singleLineCommentCount > 1) { + out.push(createOutliningSpanFromBounds(firstSingleLineCommentStart, lastSingleLineCommentEnd, "comment" /* Comment */)); + } } - return map2; } - function forEachPossibleImportOrExportStatement(sourceFileLike, action) { - return forEach(sourceFileLike.kind === 311 /* SourceFile */ ? sourceFileLike.statements : sourceFileLike.body.statements, (statement) => ( - // TODO: GH#18217 - action(statement) || isAmbientModuleDeclaration(statement) && forEach(statement.body && statement.body.statements, action) - )); + function addOutliningForLeadingCommentsForNode(n, sourceFile, cancellationToken, out) { + if (isJsxText(n)) + return; + addOutliningForLeadingCommentsForPos(n.pos, sourceFile, cancellationToken, out); } - function forEachImport(sourceFile, action) { - if (sourceFile.externalModuleIndicator || sourceFile.imports !== void 0) { - for (const i of sourceFile.imports) { - action(importFromModuleSpecifier(i), i); - } - } else { - forEachPossibleImportOrExportStatement(sourceFile, (statement) => { - switch (statement.kind) { - case 277 /* ExportDeclaration */: - case 271 /* ImportDeclaration */: { - const decl = statement; - if (decl.moduleSpecifier && isStringLiteral(decl.moduleSpecifier)) { - action(decl, decl.moduleSpecifier); - } - break; - } - case 270 /* ImportEqualsDeclaration */: { - const decl = statement; - if (isExternalModuleImportEquals(decl)) { - action(decl, decl.moduleReference.expression); - } - break; - } - } - }); - } + function createOutliningSpanFromBounds(pos, end, kind) { + return createOutliningSpan(createTextSpanFromBounds(pos, end), kind); } - function getImportOrExportSymbol(node, symbol, checker, comingFromExport) { - return comingFromExport ? getExport() : getExport() || getImport(); - function getExport() { - var _a; - const { parent: parent2 } = node; - const grandparent = parent2.parent; - if (symbol.exportSymbol) { - if (parent2.kind === 210 /* PropertyAccessExpression */) { - return ((_a = symbol.declarations) == null ? void 0 : _a.some((d) => d === parent2)) && isBinaryExpression(grandparent) ? getSpecialPropertyExport( - grandparent, - /*useLhsSymbol*/ - false - ) : void 0; - } else { - return exportInfo(symbol.exportSymbol, getExportKindForDeclaration(parent2)); + function getOutliningSpanForNode(n, sourceFile) { + switch (n.kind) { + case 241 /* Block */: + if (isFunctionLike(n.parent)) { + return functionSpan(n.parent, n, sourceFile); } - } else { - const exportNode = getExportNode(parent2, node); - if (exportNode && hasSyntacticModifier(exportNode, 1 /* Export */)) { - if (isImportEqualsDeclaration(exportNode) && exportNode.moduleReference === node) { - if (comingFromExport) { - return void 0; + switch (n.parent.kind) { + case 246 /* DoStatement */: + case 249 /* ForInStatement */: + case 250 /* ForOfStatement */: + case 248 /* ForStatement */: + case 245 /* IfStatement */: + case 247 /* WhileStatement */: + case 254 /* WithStatement */: + case 299 /* CatchClause */: + return spanForNode(n.parent); + case 258 /* TryStatement */: + const tryStatement = n.parent; + if (tryStatement.tryBlock === n) { + return spanForNode(n.parent); + } else if (tryStatement.finallyBlock === n) { + const node = findChildOfKind(tryStatement, 98 /* FinallyKeyword */, sourceFile); + if (node) + return spanForNode(node); } - const lhsSymbol = checker.getSymbolAtLocation(exportNode.name); - return { kind: 0 /* Import */, symbol: lhsSymbol }; - } else { - return exportInfo(symbol, getExportKindForDeclaration(exportNode)); - } - } else if (isNamespaceExport(parent2)) { - return exportInfo(symbol, 0 /* Named */); - } else if (isExportAssignment(parent2)) { - return getExportAssignmentExport(parent2); - } else if (isExportAssignment(grandparent)) { - return getExportAssignmentExport(grandparent); - } else if (isBinaryExpression(parent2)) { - return getSpecialPropertyExport( - parent2, - /*useLhsSymbol*/ - true - ); - } else if (isBinaryExpression(grandparent)) { - return getSpecialPropertyExport( - grandparent, - /*useLhsSymbol*/ - true - ); - } else if (isJSDocTypedefTag(parent2) || isJSDocCallbackTag(parent2)) { - return exportInfo(symbol, 0 /* Named */); + default: + return createOutliningSpan(createTextSpanFromNode(n, sourceFile), "code" /* Code */); } + case 268 /* ModuleBlock */: + return spanForNode(n.parent); + case 263 /* ClassDeclaration */: + case 231 /* ClassExpression */: + case 264 /* InterfaceDeclaration */: + case 266 /* EnumDeclaration */: + case 269 /* CaseBlock */: + case 187 /* TypeLiteral */: + case 206 /* ObjectBindingPattern */: + return spanForNode(n); + case 189 /* TupleType */: + return spanForNode( + n, + /*autoCollapse*/ + false, + /*useFullStart*/ + !isTupleTypeNode(n.parent), + 23 /* OpenBracketToken */ + ); + case 296 /* CaseClause */: + case 297 /* DefaultClause */: + return spanForNodeArray(n.statements); + case 210 /* ObjectLiteralExpression */: + return spanForObjectOrArrayLiteral(n); + case 209 /* ArrayLiteralExpression */: + return spanForObjectOrArrayLiteral(n, 23 /* OpenBracketToken */); + case 284 /* JsxElement */: + return spanForJSXElement(n); + case 288 /* JsxFragment */: + return spanForJSXFragment(n); + case 285 /* JsxSelfClosingElement */: + case 286 /* JsxOpeningElement */: + return spanForJSXAttributes(n.attributes); + case 228 /* TemplateExpression */: + case 15 /* NoSubstitutionTemplateLiteral */: + return spanForTemplateLiteral(n); + case 207 /* ArrayBindingPattern */: + return spanForNode( + n, + /*autoCollapse*/ + false, + /*useFullStart*/ + !isBindingElement(n.parent), + 23 /* OpenBracketToken */ + ); + case 219 /* ArrowFunction */: + return spanForArrowFunction(n); + case 213 /* CallExpression */: + return spanForCallExpression(n); + case 217 /* ParenthesizedExpression */: + return spanForParenthesizedExpression(n); + case 275 /* NamedImports */: + case 279 /* NamedExports */: + case 300 /* ImportAttributes */: + return spanForImportExportElements(n); + } + function spanForImportExportElements(node) { + if (!node.elements.length) { + return void 0; } - function getExportAssignmentExport(ex) { - if (!ex.symbol.parent) - return void 0; - const exportKind = ex.isExportEquals ? 2 /* ExportEquals */ : 1 /* Default */; - return { kind: 1 /* Export */, symbol, exportInfo: { exportingModuleSymbol: ex.symbol.parent, exportKind } }; + const openToken = findChildOfKind(node, 19 /* OpenBraceToken */, sourceFile); + const closeToken = findChildOfKind(node, 20 /* CloseBraceToken */, sourceFile); + if (!openToken || !closeToken || positionsAreOnSameLine(openToken.pos, closeToken.pos, sourceFile)) { + return void 0; } - function getSpecialPropertyExport(node2, useLhsSymbol) { - let kind; - switch (getAssignmentDeclarationKind(node2)) { - case 1 /* ExportsProperty */: - kind = 0 /* Named */; - break; - case 2 /* ModuleExports */: - kind = 2 /* ExportEquals */; - break; - default: - return void 0; - } - const sym = useLhsSymbol ? checker.getSymbolAtLocation(getNameOfAccessExpression(cast(node2.left, isAccessExpression))) : symbol; - return sym && exportInfo(sym, kind); + return spanBetweenTokens( + openToken, + closeToken, + node, + sourceFile, + /*autoCollapse*/ + false, + /*useFullStart*/ + false + ); + } + function spanForCallExpression(node) { + if (!node.arguments.length) { + return void 0; + } + const openToken = findChildOfKind(node, 21 /* OpenParenToken */, sourceFile); + const closeToken = findChildOfKind(node, 22 /* CloseParenToken */, sourceFile); + if (!openToken || !closeToken || positionsAreOnSameLine(openToken.pos, closeToken.pos, sourceFile)) { + return void 0; } + return spanBetweenTokens( + openToken, + closeToken, + node, + sourceFile, + /*autoCollapse*/ + false, + /*useFullStart*/ + true + ); } - function getImport() { - const isImport3 = isNodeImport(node); - if (!isImport3) + function spanForArrowFunction(node) { + if (isBlock(node.body) || isParenthesizedExpression(node.body) || positionsAreOnSameLine(node.body.getFullStart(), node.body.getEnd(), sourceFile)) { return void 0; - let importedSymbol = checker.getImmediateAliasedSymbol(symbol); - if (!importedSymbol) + } + const textSpan = createTextSpanFromBounds(node.body.getFullStart(), node.body.getEnd()); + return createOutliningSpan(textSpan, "code" /* Code */, createTextSpanFromNode(node)); + } + function spanForJSXElement(node) { + const textSpan = createTextSpanFromBounds(node.openingElement.getStart(sourceFile), node.closingElement.getEnd()); + const tagName = node.openingElement.tagName.getText(sourceFile); + const bannerText = "<" + tagName + ">..."; + return createOutliningSpan( + textSpan, + "code" /* Code */, + textSpan, + /*autoCollapse*/ + false, + bannerText + ); + } + function spanForJSXFragment(node) { + const textSpan = createTextSpanFromBounds(node.openingFragment.getStart(sourceFile), node.closingFragment.getEnd()); + const bannerText = "<>..."; + return createOutliningSpan( + textSpan, + "code" /* Code */, + textSpan, + /*autoCollapse*/ + false, + bannerText + ); + } + function spanForJSXAttributes(node) { + if (node.properties.length === 0) { return void 0; - importedSymbol = skipExportSpecifierSymbol(importedSymbol, checker); - if (importedSymbol.escapedName === "export=") { - importedSymbol = getExportEqualsLocalSymbol(importedSymbol, checker); - if (importedSymbol === void 0) - return void 0; } - const importedName = symbolEscapedNameNoDefault(importedSymbol); - if (importedName === void 0 || importedName === "default" /* Default */ || importedName === symbol.escapedName) { - return { kind: 0 /* Import */, symbol: importedSymbol }; + return createOutliningSpanFromBounds(node.getStart(sourceFile), node.getEnd(), "code" /* Code */); + } + function spanForTemplateLiteral(node) { + if (node.kind === 15 /* NoSubstitutionTemplateLiteral */ && node.text.length === 0) { + return void 0; } + return createOutliningSpanFromBounds(node.getStart(sourceFile), node.getEnd(), "code" /* Code */); } - function exportInfo(symbol2, kind) { - const exportInfo2 = getExportInfo(symbol2, kind, checker); - return exportInfo2 && { kind: 1 /* Export */, symbol: symbol2, exportInfo: exportInfo2 }; + function spanForObjectOrArrayLiteral(node, open = 19 /* OpenBraceToken */) { + return spanForNode( + node, + /*autoCollapse*/ + false, + /*useFullStart*/ + !isArrayLiteralExpression(node.parent) && !isCallExpression(node.parent), + open + ); } - function getExportKindForDeclaration(node2) { - return hasSyntacticModifier(node2, 1024 /* Default */) ? 1 /* Default */ : 0 /* Named */; + function spanForNode(hintSpanNode, autoCollapse = false, useFullStart = true, open = 19 /* OpenBraceToken */, close = open === 19 /* OpenBraceToken */ ? 20 /* CloseBraceToken */ : 24 /* CloseBracketToken */) { + const openToken = findChildOfKind(n, open, sourceFile); + const closeToken = findChildOfKind(n, close, sourceFile); + return openToken && closeToken && spanBetweenTokens(openToken, closeToken, hintSpanNode, sourceFile, autoCollapse, useFullStart); } - } - function getExportEqualsLocalSymbol(importedSymbol, checker) { - var _a, _b; - if (importedSymbol.flags & 2097152 /* Alias */) { - return checker.getImmediateAliasedSymbol(importedSymbol); + function spanForNodeArray(nodeArray) { + return nodeArray.length ? createOutliningSpan(createTextSpanFromRange(nodeArray), "code" /* Code */) : void 0; } - const decl = Debug.checkDefined(importedSymbol.valueDeclaration); - if (isExportAssignment(decl)) { - return (_a = tryCast(decl.expression, canHaveSymbol)) == null ? void 0 : _a.symbol; - } else if (isBinaryExpression(decl)) { - return (_b = tryCast(decl.right, canHaveSymbol)) == null ? void 0 : _b.symbol; - } else if (isSourceFile(decl)) { - return decl.symbol; + function spanForParenthesizedExpression(node) { + if (positionsAreOnSameLine(node.getStart(), node.getEnd(), sourceFile)) + return void 0; + const textSpan = createTextSpanFromBounds(node.getStart(), node.getEnd()); + return createOutliningSpan(textSpan, "code" /* Code */, createTextSpanFromNode(node)); } - return void 0; } - function getExportNode(parent2, node) { - const declaration = isVariableDeclaration(parent2) ? parent2 : isBindingElement(parent2) ? walkUpBindingElementsAndPatterns(parent2) : void 0; - if (declaration) { - return parent2.name !== node ? void 0 : isCatchClause(declaration.parent) ? void 0 : isVariableStatement(declaration.parent.parent) ? declaration.parent.parent : void 0; - } else { - return parent2; + function functionSpan(node, body, sourceFile) { + const openToken = tryGetFunctionOpenToken(node, body, sourceFile); + const closeToken = findChildOfKind(body, 20 /* CloseBraceToken */, sourceFile); + return openToken && closeToken && spanBetweenTokens( + openToken, + closeToken, + node, + sourceFile, + /*autoCollapse*/ + node.kind !== 219 /* ArrowFunction */ + ); + } + function spanBetweenTokens(openToken, closeToken, hintSpanNode, sourceFile, autoCollapse = false, useFullStart = true) { + const textSpan = createTextSpanFromBounds(useFullStart ? openToken.getFullStart() : openToken.getStart(sourceFile), closeToken.getEnd()); + return createOutliningSpan(textSpan, "code" /* Code */, createTextSpanFromNode(hintSpanNode, sourceFile), autoCollapse); + } + function createOutliningSpan(textSpan, kind, hintSpan = textSpan, autoCollapse = false, bannerText = "...") { + return { textSpan, kind, hintSpan, bannerText, autoCollapse }; + } + function tryGetFunctionOpenToken(node, body, sourceFile) { + if (isNodeArrayMultiLine(node.parameters, sourceFile)) { + const openParenToken = findChildOfKind(node, 21 /* OpenParenToken */, sourceFile); + if (openParenToken) { + return openParenToken; + } } + return findChildOfKind(body, 19 /* OpenBraceToken */, sourceFile); } - function isNodeImport(node) { - const { parent: parent2 } = node; - switch (parent2.kind) { - case 270 /* ImportEqualsDeclaration */: - return parent2.name === node && isExternalModuleImportEquals(parent2); - case 275 /* ImportSpecifier */: - return !parent2.propertyName; - case 272 /* ImportClause */: - case 273 /* NamespaceImport */: - Debug.assert(parent2.name === node); - return true; - case 207 /* BindingElement */: - return isInJSFile(node) && isVariableDeclarationInitializedToBareOrAccessedRequire(parent2.parent.parent); - default: - return false; + var regionDelimiterRegExp; + var init_outliningElementsCollector = __esm({ + "src/services/outliningElementsCollector.ts"() { + "use strict"; + init_ts4(); + regionDelimiterRegExp = /^#(end)?region(?:\s+(.*))?(?:\r)?$/; + } + }); + + // src/services/_namespaces/ts.OutliningElementsCollector.ts + var ts_OutliningElementsCollector_exports = {}; + __export(ts_OutliningElementsCollector_exports, { + collectElements: () => collectElements + }); + var init_ts_OutliningElementsCollector = __esm({ + "src/services/_namespaces/ts.OutliningElementsCollector.ts"() { + "use strict"; + init_outliningElementsCollector(); + } + }); + + // src/services/rename.ts + function getRenameInfo(program, sourceFile, position, preferences) { + const node = getAdjustedRenameLocation(getTouchingPropertyName(sourceFile, position)); + if (nodeIsEligibleForRename(node)) { + const renameInfo = getRenameInfoForNode(node, program.getTypeChecker(), sourceFile, program, preferences); + if (renameInfo) { + return renameInfo; + } } + return getRenameInfoError(Diagnostics.You_cannot_rename_this_element); } - function getExportInfo(exportSymbol, exportKind, checker) { - const moduleSymbol = exportSymbol.parent; - if (!moduleSymbol) + function getRenameInfoForNode(node, typeChecker, sourceFile, program, preferences) { + const symbol = typeChecker.getSymbolAtLocation(node); + if (!symbol) { + if (isStringLiteralLike(node)) { + const type = getContextualTypeFromParentOrAncestorTypeNode(node, typeChecker); + if (type && (type.flags & 128 /* StringLiteral */ || type.flags & 1048576 /* Union */ && every(type.types, (type2) => !!(type2.flags & 128 /* StringLiteral */)))) { + return getRenameInfoSuccess(node.text, node.text, "string" /* string */, "", node, sourceFile); + } + } else if (isLabelName(node)) { + const name = getTextOfNode(node); + return getRenameInfoSuccess(name, name, "label" /* label */, "" /* none */, node, sourceFile); + } return void 0; - const exportingModuleSymbol = checker.getMergedSymbol(moduleSymbol); - return isExternalModuleSymbol(exportingModuleSymbol) ? { exportingModuleSymbol, exportKind } : void 0; + } + const { declarations } = symbol; + if (!declarations || declarations.length === 0) + return; + if (declarations.some((declaration) => isDefinedInLibraryFile(program, declaration))) { + return getRenameInfoError(Diagnostics.You_cannot_rename_elements_that_are_defined_in_the_standard_TypeScript_library); + } + if (isIdentifier(node) && node.escapedText === "default" && symbol.parent && symbol.parent.flags & 1536 /* Module */) { + return void 0; + } + if (isStringLiteralLike(node) && tryGetImportFromModuleSpecifier(node)) { + return preferences.allowRenameOfImportPath ? getRenameInfoForModule(node, sourceFile, symbol) : void 0; + } + const wouldRenameNodeModules = wouldRenameInOtherNodeModules(sourceFile, symbol, typeChecker, preferences); + if (wouldRenameNodeModules) { + return getRenameInfoError(wouldRenameNodeModules); + } + const kind = ts_SymbolDisplay_exports.getSymbolKind(typeChecker, symbol, node); + const specifierName = isImportOrExportSpecifierName(node) || isStringOrNumericLiteralLike(node) && node.parent.kind === 167 /* ComputedPropertyName */ ? stripQuotes(getTextOfIdentifierOrLiteral(node)) : void 0; + const displayName = specifierName || typeChecker.symbolToString(symbol); + const fullDisplayName = specifierName || typeChecker.getFullyQualifiedName(symbol); + return getRenameInfoSuccess(displayName, fullDisplayName, kind, ts_SymbolDisplay_exports.getSymbolModifiers(typeChecker, symbol), node, sourceFile); } - function skipExportSpecifierSymbol(symbol, checker) { - if (symbol.declarations) { - for (const declaration of symbol.declarations) { - if (isExportSpecifier(declaration) && !declaration.propertyName && !declaration.parent.parent.moduleSpecifier) { - return checker.getExportSpecifierLocalTargetSymbol(declaration) || symbol; - } else if (isPropertyAccessExpression(declaration) && isModuleExportsAccessExpression(declaration.expression) && !isPrivateIdentifier(declaration.name)) { - return checker.getSymbolAtLocation(declaration); - } else if (isShorthandPropertyAssignment(declaration) && isBinaryExpression(declaration.parent.parent) && getAssignmentDeclarationKind(declaration.parent.parent) === 2 /* ModuleExports */) { - return checker.getExportSpecifierLocalTargetSymbol(declaration.name); + function isDefinedInLibraryFile(program, declaration) { + const sourceFile = declaration.getSourceFile(); + return program.isSourceFileDefaultLibrary(sourceFile) && fileExtensionIs(sourceFile.fileName, ".d.ts" /* Dts */); + } + function wouldRenameInOtherNodeModules(originalFile, symbol, checker, preferences) { + if (!preferences.providePrefixAndSuffixTextForRename && symbol.flags & 2097152 /* Alias */) { + const importSpecifier = symbol.declarations && find(symbol.declarations, (decl) => isImportSpecifier(decl)); + if (importSpecifier && !importSpecifier.propertyName) { + symbol = checker.getAliasedSymbol(symbol); + } + } + const { declarations } = symbol; + if (!declarations) { + return void 0; + } + const originalPackage = getPackagePathComponents(originalFile.path); + if (originalPackage === void 0) { + if (some(declarations, (declaration) => isInsideNodeModules(declaration.getSourceFile().path))) { + return Diagnostics.You_cannot_rename_elements_that_are_defined_in_a_node_modules_folder; + } else { + return void 0; + } + } + for (const declaration of declarations) { + const declPackage = getPackagePathComponents(declaration.getSourceFile().path); + if (declPackage) { + const length2 = Math.min(originalPackage.length, declPackage.length); + for (let i = 0; i <= length2; i++) { + if (compareStringsCaseSensitive(originalPackage[i], declPackage[i]) !== 0 /* EqualTo */) { + return Diagnostics.You_cannot_rename_elements_that_are_defined_in_another_node_modules_folder; + } } } } - return symbol; - } - function getContainingModuleSymbol(importer, checker) { - return checker.getMergedSymbol(getSourceFileLikeForImportDeclaration(importer).symbol); + return void 0; } - function getSourceFileLikeForImportDeclaration(node) { - if (node.kind === 212 /* CallExpression */) { - return node.getSourceFile(); + function getPackagePathComponents(filePath) { + const components = getPathComponents(filePath); + const nodeModulesIdx = components.lastIndexOf("node_modules"); + if (nodeModulesIdx === -1) { + return void 0; } - const { parent: parent2 } = node; - if (parent2.kind === 311 /* SourceFile */) { - return parent2; + return components.slice(0, nodeModulesIdx + 2); + } + function getRenameInfoForModule(node, sourceFile, moduleSymbol) { + if (!isExternalModuleNameRelative(node.text)) { + return getRenameInfoError(Diagnostics.You_cannot_rename_a_module_via_a_global_import); } - Debug.assert(parent2.kind === 267 /* ModuleBlock */); - return cast(parent2.parent, isAmbientModuleDeclaration); + const moduleSourceFile = moduleSymbol.declarations && find(moduleSymbol.declarations, isSourceFile); + if (!moduleSourceFile) + return void 0; + const withoutIndex = endsWith(node.text, "/index") || endsWith(node.text, "/index.js") ? void 0 : tryRemoveSuffix(removeFileExtension(moduleSourceFile.fileName), "/index"); + const name = withoutIndex === void 0 ? moduleSourceFile.fileName : withoutIndex; + const kind = withoutIndex === void 0 ? "module" /* moduleElement */ : "directory" /* directory */; + const indexAfterLastSlash = node.text.lastIndexOf("/") + 1; + const triggerSpan = createTextSpan(node.getStart(sourceFile) + 1 + indexAfterLastSlash, node.text.length - indexAfterLastSlash); + return { + canRename: true, + fileToRename: name, + kind, + displayName: name, + fullDisplayName: name, + kindModifiers: "" /* none */, + triggerSpan + }; } - function isAmbientModuleDeclaration(node) { - return node.kind === 266 /* ModuleDeclaration */ && node.name.kind === 11 /* StringLiteral */; + function getRenameInfoSuccess(displayName, fullDisplayName, kind, kindModifiers, node, sourceFile) { + return { + canRename: true, + fileToRename: void 0, + kind, + displayName, + fullDisplayName, + kindModifiers, + triggerSpan: createTriggerSpanForNode(node, sourceFile) + }; } - function isExternalModuleImportEquals(eq) { - return eq.moduleReference.kind === 282 /* ExternalModuleReference */ && eq.moduleReference.expression.kind === 11 /* StringLiteral */; + function getRenameInfoError(diagnostic) { + return { canRename: false, localizedErrorMessage: getLocaleSpecificMessage(diagnostic) }; } - var ExportKind2, ImportExport; - var init_importTracker = __esm({ - "src/services/importTracker.ts"() { + function createTriggerSpanForNode(node, sourceFile) { + let start = node.getStart(sourceFile); + let width = node.getWidth(sourceFile); + if (isStringLiteralLike(node)) { + start += 1; + width -= 2; + } + return createTextSpan(start, width); + } + function nodeIsEligibleForRename(node) { + switch (node.kind) { + case 80 /* Identifier */: + case 81 /* PrivateIdentifier */: + case 11 /* StringLiteral */: + case 15 /* NoSubstitutionTemplateLiteral */: + case 110 /* ThisKeyword */: + return true; + case 9 /* NumericLiteral */: + return isLiteralNameOfPropertyDeclarationOrIndexAccess(node); + default: + return false; + } + } + var init_rename = __esm({ + "src/services/rename.ts"() { "use strict"; init_ts4(); - ExportKind2 = /* @__PURE__ */ ((ExportKind3) => { - ExportKind3[ExportKind3["Named"] = 0] = "Named"; - ExportKind3[ExportKind3["Default"] = 1] = "Default"; - ExportKind3[ExportKind3["ExportEquals"] = 2] = "ExportEquals"; - return ExportKind3; - })(ExportKind2 || {}); - ImportExport = /* @__PURE__ */ ((ImportExport2) => { - ImportExport2[ImportExport2["Import"] = 0] = "Import"; - ImportExport2[ImportExport2["Export"] = 1] = "Export"; - return ImportExport2; - })(ImportExport || {}); } }); - // src/services/findAllReferences.ts - function nodeEntry(node, kind = 1 /* Node */) { - return { - kind, - node: node.name || node, - context: getContextNodeForNodeEntry(node) - }; - } - function isContextWithStartAndEndNode(node) { - return node && node.kind === void 0; - } - function getContextNodeForNodeEntry(node) { - if (isDeclaration(node)) { - return getContextNode(node); + // src/services/_namespaces/ts.Rename.ts + var ts_Rename_exports = {}; + __export(ts_Rename_exports, { + getRenameInfo: () => getRenameInfo, + nodeIsEligibleForRename: () => nodeIsEligibleForRename + }); + var init_ts_Rename = __esm({ + "src/services/_namespaces/ts.Rename.ts"() { + "use strict"; + init_rename(); } - if (!node.parent) + }); + + // src/services/signatureHelp.ts + function getSignatureHelpItems(program, sourceFile, position, triggerReason, cancellationToken) { + const typeChecker = program.getTypeChecker(); + const startingToken = findTokenOnLeftOfPosition(sourceFile, position); + if (!startingToken) { return void 0; - if (!isDeclaration(node.parent) && !isExportAssignment(node.parent)) { - if (isInJSFile(node)) { - const binaryExpression = isBinaryExpression(node.parent) ? node.parent : isAccessExpression(node.parent) && isBinaryExpression(node.parent.parent) && node.parent.parent.left === node.parent ? node.parent.parent : void 0; - if (binaryExpression && getAssignmentDeclarationKind(binaryExpression) !== 0 /* None */) { - return getContextNode(binaryExpression); + } + const onlyUseSyntacticOwners = !!triggerReason && triggerReason.kind === "characterTyped"; + if (onlyUseSyntacticOwners && (isInString(sourceFile, position, startingToken) || isInComment(sourceFile, position))) { + return void 0; + } + const isManuallyInvoked = !!triggerReason && triggerReason.kind === "invoked"; + const argumentInfo = getContainingArgumentInfo(startingToken, position, sourceFile, typeChecker, isManuallyInvoked); + if (!argumentInfo) + return void 0; + cancellationToken.throwIfCancellationRequested(); + const candidateInfo = getCandidateOrTypeInfo(argumentInfo, typeChecker, sourceFile, startingToken, onlyUseSyntacticOwners); + cancellationToken.throwIfCancellationRequested(); + if (!candidateInfo) { + return isSourceFileJS(sourceFile) ? createJSSignatureHelpItems(argumentInfo, program, cancellationToken) : void 0; + } + return typeChecker.runWithCancellationToken(cancellationToken, (typeChecker2) => candidateInfo.kind === 0 /* Candidate */ ? createSignatureHelpItems(candidateInfo.candidates, candidateInfo.resolvedSignature, argumentInfo, sourceFile, typeChecker2) : createTypeHelpItems(candidateInfo.symbol, argumentInfo, sourceFile, typeChecker2)); + } + function getCandidateOrTypeInfo({ invocation, argumentCount }, checker, sourceFile, startingToken, onlyUseSyntacticOwners) { + switch (invocation.kind) { + case 0 /* Call */: { + if (onlyUseSyntacticOwners && !isSyntacticOwner(startingToken, invocation.node, sourceFile)) { + return void 0; } + const candidates = []; + const resolvedSignature = checker.getResolvedSignatureForSignatureHelp(invocation.node, candidates, argumentCount); + return candidates.length === 0 ? void 0 : { kind: 0 /* Candidate */, candidates, resolvedSignature }; } - if (isJsxOpeningElement(node.parent) || isJsxClosingElement(node.parent)) { - return node.parent.parent; - } else if (isJsxSelfClosingElement(node.parent) || isLabeledStatement(node.parent) || isBreakOrContinueStatement(node.parent)) { - return node.parent; - } else if (isStringLiteralLike(node)) { - const validImport = tryGetImportFromModuleSpecifier(node); - if (validImport) { - const declOrStatement = findAncestor( - validImport, - (node2) => isDeclaration(node2) || isStatement(node2) || isJSDocTag(node2) - ); - return isDeclaration(declOrStatement) ? getContextNode(declOrStatement) : declOrStatement; + case 1 /* TypeArgs */: { + const { called } = invocation; + if (onlyUseSyntacticOwners && !containsPrecedingToken(startingToken, sourceFile, isIdentifier(called) ? called.parent : called)) { + return void 0; } + const candidates = getPossibleGenericSignatures(called, argumentCount, checker); + if (candidates.length !== 0) + return { kind: 0 /* Candidate */, candidates, resolvedSignature: first(candidates) }; + const symbol = checker.getSymbolAtLocation(called); + return symbol && { kind: 1 /* Type */, symbol }; } - const propertyName = findAncestor(node, isComputedPropertyName); - return propertyName ? getContextNode(propertyName.parent) : void 0; - } - if (node.parent.name === node || // node is name of declaration, use parent - isConstructorDeclaration(node.parent) || isExportAssignment(node.parent) || // Property name of the import export specifier or binding pattern, use parent - (isImportOrExportSpecifier(node.parent) || isBindingElement(node.parent)) && node.parent.propertyName === node || // Is default export - node.kind === 90 /* DefaultKeyword */ && hasSyntacticModifier(node.parent, 1025 /* ExportDefault */)) { - return getContextNode(node.parent); + case 2 /* Contextual */: + return { kind: 0 /* Candidate */, candidates: [invocation.signature], resolvedSignature: invocation.signature }; + default: + return Debug.assertNever(invocation); } - return void 0; } - function getContextNode(node) { - if (!node) - return void 0; - switch (node.kind) { - case 259 /* VariableDeclaration */: - return !isVariableDeclarationList(node.parent) || node.parent.declarations.length !== 1 ? node : isVariableStatement(node.parent.parent) ? node.parent.parent : isForInOrOfStatement(node.parent.parent) ? getContextNode(node.parent.parent) : node.parent; - case 207 /* BindingElement */: - return getContextNode(node.parent.parent); - case 275 /* ImportSpecifier */: - return node.parent.parent.parent; - case 280 /* ExportSpecifier */: - case 273 /* NamespaceImport */: - return node.parent.parent; - case 272 /* ImportClause */: - case 279 /* NamespaceExport */: - return node.parent; - case 225 /* BinaryExpression */: - return isExpressionStatement(node.parent) ? node.parent : node; - case 249 /* ForOfStatement */: - case 248 /* ForInStatement */: - return { - start: node.initializer, - end: node.expression - }; - case 302 /* PropertyAssignment */: - case 303 /* ShorthandPropertyAssignment */: - return isArrayLiteralOrObjectLiteralDestructuringPattern(node.parent) ? getContextNode( - findAncestor( - node.parent, - (node2) => isBinaryExpression(node2) || isForInOrOfStatement(node2) - ) - ) : node; + function isSyntacticOwner(startingToken, node, sourceFile) { + if (!isCallOrNewExpression(node)) + return false; + const invocationChildren = node.getChildren(sourceFile); + switch (startingToken.kind) { + case 21 /* OpenParenToken */: + return contains(invocationChildren, startingToken); + case 28 /* CommaToken */: { + const containingList = findContainingList(startingToken); + return !!containingList && contains(invocationChildren, containingList); + } + case 30 /* LessThanToken */: + return containsPrecedingToken(startingToken, sourceFile, node.expression); default: - return node; + return false; } } - function toContextSpan(textSpan, sourceFile, context) { - if (!context) + function createJSSignatureHelpItems(argumentInfo, program, cancellationToken) { + if (argumentInfo.invocation.kind === 2 /* Contextual */) return void 0; - const contextSpan = isContextWithStartAndEndNode(context) ? getTextSpan(context.start, sourceFile, context.end) : getTextSpan(context, sourceFile); - return contextSpan.start !== textSpan.start || contextSpan.length !== textSpan.length ? { contextSpan } : void 0; - } - function findReferencedSymbols(program, cancellationToken, sourceFiles, sourceFile, position) { - const node = getTouchingPropertyName(sourceFile, position); - const options = { use: 1 /* References */ }; - const referencedSymbols = Core.getReferencedSymbolsForNode(position, node, program, sourceFiles, cancellationToken, options); - const checker = program.getTypeChecker(); - const adjustedNode = Core.getAdjustedNode(node, options); - const symbol = isDefinitionForReference(adjustedNode) ? checker.getSymbolAtLocation(adjustedNode) : void 0; - return !referencedSymbols || !referencedSymbols.length ? void 0 : mapDefined(referencedSymbols, ({ definition, references }) => ( - // Only include referenced symbols that have a valid definition. - definition && { - definition: checker.runWithCancellationToken(cancellationToken, (checker2) => definitionToReferencedSymbolDefinitionInfo(definition, checker2, node)), - references: references.map((r) => toReferencedSymbolEntry(r, symbol)) + const expression = getExpressionFromInvocation(argumentInfo.invocation); + const name = isPropertyAccessExpression(expression) ? expression.name.text : void 0; + const typeChecker = program.getTypeChecker(); + return name === void 0 ? void 0 : firstDefined(program.getSourceFiles(), (sourceFile) => firstDefined(sourceFile.getNamedDeclarations().get(name), (declaration) => { + const type = declaration.symbol && typeChecker.getTypeOfSymbolAtLocation(declaration.symbol, declaration); + const callSignatures = type && type.getCallSignatures(); + if (callSignatures && callSignatures.length) { + return typeChecker.runWithCancellationToken( + cancellationToken, + (typeChecker2) => createSignatureHelpItems( + callSignatures, + callSignatures[0], + argumentInfo, + sourceFile, + typeChecker2, + /*useFullPrefix*/ + true + ) + ); } - )); - } - function isDefinitionForReference(node) { - return node.kind === 90 /* DefaultKeyword */ || !!getDeclarationFromName(node) || isLiteralComputedPropertyDeclarationName(node) || node.kind === 137 /* ConstructorKeyword */ && isConstructorDeclaration(node.parent); + })); } - function getImplementationsAtPosition(program, cancellationToken, sourceFiles, sourceFile, position) { - const node = getTouchingPropertyName(sourceFile, position); - let referenceEntries; - const entries = getImplementationReferenceEntries(program, cancellationToken, sourceFiles, node, position); - if (node.parent.kind === 210 /* PropertyAccessExpression */ || node.parent.kind === 207 /* BindingElement */ || node.parent.kind === 211 /* ElementAccessExpression */ || node.kind === 108 /* SuperKeyword */) { - referenceEntries = entries && [...entries]; - } else if (entries) { - const queue = createQueue(entries); - const seenNodes = /* @__PURE__ */ new Map(); - while (!queue.isEmpty()) { - const entry = queue.dequeue(); - if (!addToSeen(seenNodes, getNodeId(entry.node))) { - continue; - } - referenceEntries = append(referenceEntries, entry); - const entries2 = getImplementationReferenceEntries(program, cancellationToken, sourceFiles, entry.node, entry.node.pos); - if (entries2) { - queue.enqueue(...entries2); - } + function containsPrecedingToken(startingToken, sourceFile, container) { + const pos = startingToken.getFullStart(); + let currentParent = startingToken.parent; + while (currentParent) { + const precedingToken = findPrecedingToken( + pos, + sourceFile, + currentParent, + /*excludeJsdoc*/ + true + ); + if (precedingToken) { + return rangeContainsRange(container, precedingToken); } + currentParent = currentParent.parent; } - const checker = program.getTypeChecker(); - return map(referenceEntries, (entry) => toImplementationLocation(entry, checker)); + return Debug.fail("Could not find preceding token"); + } + function getArgumentInfoForCompletions(node, position, sourceFile) { + const info = getImmediatelyContainingArgumentInfo(node, position, sourceFile); + return !info || info.isTypeParameterList || info.invocation.kind !== 0 /* Call */ ? void 0 : { invocation: info.invocation.node, argumentCount: info.argumentCount, argumentIndex: info.argumentIndex }; } - function getImplementationReferenceEntries(program, cancellationToken, sourceFiles, node, position) { - if (node.kind === 311 /* SourceFile */) { + function getArgumentOrParameterListInfo(node, position, sourceFile) { + const info = getArgumentOrParameterListAndIndex(node, sourceFile); + if (!info) return void 0; + const { list, argumentIndex } = info; + const argumentCount = getArgumentCount( + list, + /*ignoreTrailingComma*/ + isInString(sourceFile, position, node) + ); + if (argumentIndex !== 0) { + Debug.assertLessThan(argumentIndex, argumentCount); } - const checker = program.getTypeChecker(); - if (node.parent.kind === 303 /* ShorthandPropertyAssignment */) { - const result = []; - Core.getReferenceEntriesForShorthandPropertyAssignment(node, checker, (node2) => result.push(nodeEntry(node2))); - return result; - } else if (node.kind === 108 /* SuperKeyword */ || isSuperProperty(node.parent)) { - const symbol = checker.getSymbolAtLocation(node); - return symbol.valueDeclaration && [nodeEntry(symbol.valueDeclaration)]; + const argumentsSpan = getApplicableSpanForArguments(list, sourceFile); + return { list, argumentIndex, argumentCount, argumentsSpan }; + } + function getArgumentOrParameterListAndIndex(node, sourceFile) { + if (node.kind === 30 /* LessThanToken */ || node.kind === 21 /* OpenParenToken */) { + return { list: getChildListThatStartsWithOpenerToken(node.parent, node, sourceFile), argumentIndex: 0 }; } else { - return getReferenceEntriesForNode(position, node, program, sourceFiles, cancellationToken, { implementations: true, use: 1 /* References */ }); + const list = findContainingList(node); + return list && { list, argumentIndex: getArgumentIndex(list, node) }; } } - function findReferenceOrRenameEntries(program, cancellationToken, sourceFiles, node, position, options, convertEntry) { - return map(flattenEntries(Core.getReferencedSymbolsForNode(position, node, program, sourceFiles, cancellationToken, options)), (entry) => convertEntry(entry, node, program.getTypeChecker())); - } - function getReferenceEntriesForNode(position, node, program, sourceFiles, cancellationToken, options = {}, sourceFilesSet = new Set(sourceFiles.map((f) => f.fileName))) { - return flattenEntries(Core.getReferencedSymbolsForNode(position, node, program, sourceFiles, cancellationToken, options, sourceFilesSet)); - } - function flattenEntries(referenceSymbols) { - return referenceSymbols && flatMap(referenceSymbols, (r) => r.references); - } - function definitionToReferencedSymbolDefinitionInfo(def, checker, originalNode) { - const info = (() => { - switch (def.type) { - case 0 /* Symbol */: { - const { symbol } = def; - const { displayParts: displayParts2, kind: kind2 } = getDefinitionKindAndDisplayParts(symbol, checker, originalNode); - const name2 = displayParts2.map((p) => p.text).join(""); - const declaration = symbol.declarations && firstOrUndefined(symbol.declarations); - const node = declaration ? getNameOfDeclaration(declaration) || declaration : originalNode; - return { - ...getFileAndTextSpanFromNode(node), - name: name2, - kind: kind2, - displayParts: displayParts2, - context: getContextNode(declaration) - }; - } - case 1 /* Label */: { - const { node } = def; - return { ...getFileAndTextSpanFromNode(node), name: node.text, kind: "label" /* label */, displayParts: [displayPart(node.text, 17 /* text */)] }; - } - case 2 /* Keyword */: { - const { node } = def; - const name2 = tokenToString(node.kind); - return { ...getFileAndTextSpanFromNode(node), name: name2, kind: "keyword" /* keyword */, displayParts: [{ text: name2, kind: "keyword" /* keyword */ }] }; - } - case 3 /* This */: { - const { node } = def; - const symbol = checker.getSymbolAtLocation(node); - const displayParts2 = symbol && ts_SymbolDisplay_exports.getSymbolDisplayPartsDocumentationAndSymbolKind( - checker, - symbol, - node.getSourceFile(), - getContainerNode(node), - node - ).displayParts || [textPart("this")]; - return { ...getFileAndTextSpanFromNode(node), name: "this", kind: "var" /* variableElement */, displayParts: displayParts2 }; - } - case 4 /* String */: { - const { node } = def; - return { - ...getFileAndTextSpanFromNode(node), - name: node.text, - kind: "var" /* variableElement */, - displayParts: [displayPart(getTextOfNode(node), 8 /* stringLiteral */)] - }; - } - case 5 /* TripleSlashReference */: { - return { - textSpan: createTextSpanFromRange(def.reference), - sourceFile: def.file, - name: def.reference.fileName, - kind: "string" /* string */, - displayParts: [displayPart(`"${def.reference.fileName}"`, 8 /* stringLiteral */)] - }; - } - default: - return Debug.assertNever(def); + function getImmediatelyContainingArgumentInfo(node, position, sourceFile) { + const { parent: parent2 } = node; + if (isCallOrNewExpression(parent2)) { + const invocation = parent2; + const info = getArgumentOrParameterListInfo(node, position, sourceFile); + if (!info) + return void 0; + const { list, argumentIndex, argumentCount, argumentsSpan } = info; + const isTypeParameterList = !!parent2.typeArguments && parent2.typeArguments.pos === list.pos; + return { isTypeParameterList, invocation: { kind: 0 /* Call */, node: invocation }, argumentsSpan, argumentIndex, argumentCount }; + } else if (isNoSubstitutionTemplateLiteral(node) && isTaggedTemplateExpression(parent2)) { + if (isInsideTemplateLiteral(node, position, sourceFile)) { + return getArgumentListInfoForTemplate( + parent2, + /*argumentIndex*/ + 0, + sourceFile + ); } - })(); - const { sourceFile, textSpan, name, kind, displayParts, context } = info; - return { - containerKind: "" /* unknown */, - containerName: "", - fileName: sourceFile.fileName, - kind, - name, - textSpan, - displayParts, - ...toContextSpan(textSpan, sourceFile, context) - }; + return void 0; + } else if (isTemplateHead(node) && parent2.parent.kind === 215 /* TaggedTemplateExpression */) { + const templateExpression = parent2; + const tagExpression = templateExpression.parent; + Debug.assert(templateExpression.kind === 228 /* TemplateExpression */); + const argumentIndex = isInsideTemplateLiteral(node, position, sourceFile) ? 0 : 1; + return getArgumentListInfoForTemplate(tagExpression, argumentIndex, sourceFile); + } else if (isTemplateSpan(parent2) && isTaggedTemplateExpression(parent2.parent.parent)) { + const templateSpan = parent2; + const tagExpression = parent2.parent.parent; + if (isTemplateTail(node) && !isInsideTemplateLiteral(node, position, sourceFile)) { + return void 0; + } + const spanIndex = templateSpan.parent.templateSpans.indexOf(templateSpan); + const argumentIndex = getArgumentIndexForTemplatePiece(spanIndex, node, position, sourceFile); + return getArgumentListInfoForTemplate(tagExpression, argumentIndex, sourceFile); + } else if (isJsxOpeningLikeElement(parent2)) { + const attributeSpanStart = parent2.attributes.pos; + const attributeSpanEnd = skipTrivia( + sourceFile.text, + parent2.attributes.end, + /*stopAfterLineBreak*/ + false + ); + return { + isTypeParameterList: false, + invocation: { kind: 0 /* Call */, node: parent2 }, + argumentsSpan: createTextSpan(attributeSpanStart, attributeSpanEnd - attributeSpanStart), + argumentIndex: 0, + argumentCount: 1 + }; + } else { + const typeArgInfo = getPossibleTypeArgumentsInfo(node, sourceFile); + if (typeArgInfo) { + const { called, nTypeArguments } = typeArgInfo; + const invocation = { kind: 1 /* TypeArgs */, called }; + const argumentsSpan = createTextSpanFromBounds(called.getStart(sourceFile), node.end); + return { isTypeParameterList: true, invocation, argumentsSpan, argumentIndex: nTypeArguments, argumentCount: nTypeArguments + 1 }; + } + return void 0; + } } - function getFileAndTextSpanFromNode(node) { - const sourceFile = node.getSourceFile(); - return { - sourceFile, - textSpan: getTextSpan(isComputedPropertyName(node) ? node.expression : node, sourceFile) - }; + function getImmediatelyContainingArgumentOrContextualParameterInfo(node, position, sourceFile, checker) { + return tryGetParameterInfo(node, position, sourceFile, checker) || getImmediatelyContainingArgumentInfo(node, position, sourceFile); } - function getDefinitionKindAndDisplayParts(symbol, checker, node) { - const meaning = Core.getIntersectingMeaningFromDeclarations(node, symbol); - const enclosingDeclaration = symbol.declarations && firstOrUndefined(symbol.declarations) || node; - const { displayParts, symbolKind } = ts_SymbolDisplay_exports.getSymbolDisplayPartsDocumentationAndSymbolKind(checker, symbol, enclosingDeclaration.getSourceFile(), enclosingDeclaration, enclosingDeclaration, meaning); - return { displayParts, kind: symbolKind }; + function getHighestBinary(b) { + return isBinaryExpression(b.parent) ? getHighestBinary(b.parent) : b; } - function toRenameLocation(entry, originalNode, checker, providePrefixAndSuffixText, quotePreference) { - return { ...entryToDocumentSpan(entry), ...providePrefixAndSuffixText && getPrefixAndSuffixText(entry, originalNode, checker, quotePreference) }; + function countBinaryExpressionParameters(b) { + return isBinaryExpression(b.left) ? countBinaryExpressionParameters(b.left) + 1 : 2; } - function toReferencedSymbolEntry(entry, symbol) { - const referenceEntry = toReferenceEntry(entry); - if (!symbol) - return referenceEntry; - return { - ...referenceEntry, - isDefinition: entry.kind !== 0 /* Span */ && isDeclarationOfSymbol(entry.node, symbol) - }; + function tryGetParameterInfo(startingToken, position, sourceFile, checker) { + const node = getAdjustedNode(startingToken); + if (node === void 0) + return void 0; + const info = getContextualSignatureLocationInfo(node, sourceFile, position, checker); + if (info === void 0) + return void 0; + const { contextualType, argumentIndex, argumentCount, argumentsSpan } = info; + const nonNullableContextualType = contextualType.getNonNullableType(); + const symbol = nonNullableContextualType.symbol; + if (symbol === void 0) + return void 0; + const signature = lastOrUndefined(nonNullableContextualType.getCallSignatures()); + if (signature === void 0) + return void 0; + const invocation = { kind: 2 /* Contextual */, signature, node: startingToken, symbol: chooseBetterSymbol(symbol) }; + return { isTypeParameterList: false, invocation, argumentsSpan, argumentIndex, argumentCount }; } - function toReferenceEntry(entry) { - const documentSpan = entryToDocumentSpan(entry); - if (entry.kind === 0 /* Span */) { - return { ...documentSpan, isWriteAccess: false }; + function getAdjustedNode(node) { + switch (node.kind) { + case 21 /* OpenParenToken */: + case 28 /* CommaToken */: + return node; + default: + return findAncestor(node.parent, (n) => isParameter(n) ? true : isBindingElement(n) || isObjectBindingPattern(n) || isArrayBindingPattern(n) ? false : "quit"); } - const { kind, node } = entry; - return { - ...documentSpan, - isWriteAccess: isWriteAccessForReference(node), - isInString: kind === 2 /* StringLiteral */ ? true : void 0 - }; } - function entryToDocumentSpan(entry) { - if (entry.kind === 0 /* Span */) { - return { textSpan: entry.textSpan, fileName: entry.fileName }; - } else { - const sourceFile = entry.node.getSourceFile(); - const textSpan = getTextSpan(entry.node, sourceFile); - return { - textSpan, - fileName: sourceFile.fileName, - ...toContextSpan(textSpan, sourceFile, entry.context) - }; + function getContextualSignatureLocationInfo(node, sourceFile, position, checker) { + const { parent: parent2 } = node; + switch (parent2.kind) { + case 217 /* ParenthesizedExpression */: + case 174 /* MethodDeclaration */: + case 218 /* FunctionExpression */: + case 219 /* ArrowFunction */: + const info = getArgumentOrParameterListInfo(node, position, sourceFile); + if (!info) + return void 0; + const { argumentIndex, argumentCount, argumentsSpan } = info; + const contextualType = isMethodDeclaration(parent2) ? checker.getContextualTypeForObjectLiteralElement(parent2) : checker.getContextualType(parent2); + return contextualType && { contextualType, argumentIndex, argumentCount, argumentsSpan }; + case 226 /* BinaryExpression */: { + const highestBinary = getHighestBinary(parent2); + const contextualType2 = checker.getContextualType(highestBinary); + const argumentIndex2 = node.kind === 21 /* OpenParenToken */ ? 0 : countBinaryExpressionParameters(parent2) - 1; + const argumentCount2 = countBinaryExpressionParameters(highestBinary); + return contextualType2 && { contextualType: contextualType2, argumentIndex: argumentIndex2, argumentCount: argumentCount2, argumentsSpan: createTextSpanFromNode(parent2) }; + } + default: + return void 0; } } - function getPrefixAndSuffixText(entry, originalNode, checker, quotePreference) { - if (entry.kind !== 0 /* Span */ && isIdentifier(originalNode)) { - const { node, kind } = entry; - const parent2 = node.parent; - const name = originalNode.text; - const isShorthandAssignment = isShorthandPropertyAssignment(parent2); - if (isShorthandAssignment || isObjectBindingElementWithoutPropertyName(parent2) && parent2.name === node && parent2.dotDotDotToken === void 0) { - const prefixColon = { prefixText: name + ": " }; - const suffixColon = { suffixText: ": " + name }; - if (kind === 3 /* SearchedLocalFoundProperty */) { - return prefixColon; - } - if (kind === 4 /* SearchedPropertyFoundLocal */) { - return suffixColon; - } - if (isShorthandAssignment) { - const grandParent = parent2.parent; - if (isObjectLiteralExpression(grandParent) && isBinaryExpression(grandParent.parent) && isModuleExportsAccessExpression(grandParent.parent.left)) { - return prefixColon; - } - return suffixColon; - } else { - return prefixColon; - } - } else if (isImportSpecifier(parent2) && !parent2.propertyName) { - const originalSymbol = isExportSpecifier(originalNode.parent) ? checker.getExportSpecifierLocalTargetSymbol(originalNode.parent) : checker.getSymbolAtLocation(originalNode); - return contains(originalSymbol.declarations, parent2) ? { prefixText: name + " as " } : emptyOptions; - } else if (isExportSpecifier(parent2) && !parent2.propertyName) { - return originalNode === entry.node || checker.getSymbolAtLocation(originalNode) === checker.getSymbolAtLocation(entry.node) ? { prefixText: name + " as " } : { suffixText: " as " + name }; + function chooseBetterSymbol(s) { + return s.name === "__type" /* Type */ ? firstDefined(s.declarations, (d) => { + var _a; + return isFunctionTypeNode(d) ? (_a = tryCast(d.parent, canHaveSymbol)) == null ? void 0 : _a.symbol : void 0; + }) || s : s; + } + function getArgumentIndex(argumentsList, node) { + let argumentIndex = 0; + for (const child of argumentsList.getChildren()) { + if (child === node) { + break; + } + if (child.kind !== 28 /* CommaToken */) { + argumentIndex++; } } - if (entry.kind !== 0 /* Span */ && isNumericLiteral(entry.node) && isAccessExpression(entry.node.parent)) { - const quote2 = getQuoteFromPreference(quotePreference); - return { prefixText: quote2, suffixText: quote2 }; - } - return emptyOptions; + return argumentIndex; } - function toImplementationLocation(entry, checker) { - const documentSpan = entryToDocumentSpan(entry); - if (entry.kind !== 0 /* Span */) { - const { node } = entry; - return { - ...documentSpan, - ...implementationKindDisplayParts(node, checker) - }; - } else { - return { ...documentSpan, kind: "" /* unknown */, displayParts: [] }; + function getArgumentCount(argumentsList, ignoreTrailingComma) { + const listChildren = argumentsList.getChildren(); + let argumentCount = countWhere(listChildren, (arg) => arg.kind !== 28 /* CommaToken */); + if (!ignoreTrailingComma && listChildren.length > 0 && last(listChildren).kind === 28 /* CommaToken */) { + argumentCount++; } + return argumentCount; } - function implementationKindDisplayParts(node, checker) { - const symbol = checker.getSymbolAtLocation(isDeclaration(node) && node.name ? node.name : node); - if (symbol) { - return getDefinitionKindAndDisplayParts(symbol, checker, node); - } else if (node.kind === 209 /* ObjectLiteralExpression */) { - return { - kind: "interface" /* interfaceElement */, - displayParts: [punctuationPart(21 /* OpenParenToken */), textPart("object literal"), punctuationPart(22 /* CloseParenToken */)] - }; - } else if (node.kind === 230 /* ClassExpression */) { - return { - kind: "local class" /* localClassElement */, - displayParts: [punctuationPart(21 /* OpenParenToken */), textPart("anonymous local class"), punctuationPart(22 /* CloseParenToken */)] - }; - } else { - return { kind: getNodeKind(node), displayParts: [] }; + function getArgumentIndexForTemplatePiece(spanIndex, node, position, sourceFile) { + Debug.assert(position >= node.getStart(), "Assumed 'position' could not occur before node."); + if (isTemplateLiteralToken(node)) { + if (isInsideTemplateLiteral(node, position, sourceFile)) { + return 0; + } + return spanIndex + 2; } + return spanIndex + 1; } - function toHighlightSpan(entry) { - const documentSpan = entryToDocumentSpan(entry); - if (entry.kind === 0 /* Span */) { - return { - fileName: documentSpan.fileName, - span: { - textSpan: documentSpan.textSpan, - kind: "reference" /* reference */ - } - }; + function getArgumentListInfoForTemplate(tagExpression, argumentIndex, sourceFile) { + const argumentCount = isNoSubstitutionTemplateLiteral(tagExpression.template) ? 1 : tagExpression.template.templateSpans.length + 1; + if (argumentIndex !== 0) { + Debug.assertLessThan(argumentIndex, argumentCount); } - const writeAccess = isWriteAccessForReference(entry.node); - const span = { - textSpan: documentSpan.textSpan, - kind: writeAccess ? "writtenReference" /* writtenReference */ : "reference" /* reference */, - isInString: entry.kind === 2 /* StringLiteral */ ? true : void 0, - ...documentSpan.contextSpan && { contextSpan: documentSpan.contextSpan } + return { + isTypeParameterList: false, + invocation: { kind: 0 /* Call */, node: tagExpression }, + argumentsSpan: getApplicableSpanForTaggedTemplate(tagExpression, sourceFile), + argumentIndex, + argumentCount }; - return { fileName: documentSpan.fileName, span }; } - function getTextSpan(node, sourceFile, endNode2) { - let start = node.getStart(sourceFile); - let end = (endNode2 || node).getEnd(); - if (isStringLiteralLike(node) && end - start > 2) { - Debug.assert(endNode2 === void 0); - start += 1; - end -= 1; - } - return createTextSpanFromBounds(start, end); - } - function getTextSpanOfEntry(entry) { - return entry.kind === 0 /* Span */ ? entry.textSpan : getTextSpan(entry.node, entry.node.getSourceFile()); - } - function isWriteAccessForReference(node) { - const decl = getDeclarationFromName(node); - return !!decl && declarationIsWriteAccess(decl) || node.kind === 90 /* DefaultKeyword */ || isWriteAccess(node); + function getApplicableSpanForArguments(argumentsList, sourceFile) { + const applicableSpanStart = argumentsList.getFullStart(); + const applicableSpanEnd = skipTrivia( + sourceFile.text, + argumentsList.getEnd(), + /*stopAfterLineBreak*/ + false + ); + return createTextSpan(applicableSpanStart, applicableSpanEnd - applicableSpanStart); } - function isDeclarationOfSymbol(node, target) { - var _a; - if (!target) - return false; - const source = getDeclarationFromName(node) || (node.kind === 90 /* DefaultKeyword */ ? node.parent : isLiteralComputedPropertyDeclarationName(node) ? node.parent.parent : node.kind === 137 /* ConstructorKeyword */ && isConstructorDeclaration(node.parent) ? node.parent.parent : void 0); - const commonjsSource = source && isBinaryExpression(source) ? source.left : void 0; - return !!(source && ((_a = target.declarations) == null ? void 0 : _a.some((d) => d === source || d === commonjsSource))); + function getApplicableSpanForTaggedTemplate(taggedTemplate, sourceFile) { + const template = taggedTemplate.template; + const applicableSpanStart = template.getStart(); + let applicableSpanEnd = template.getEnd(); + if (template.kind === 228 /* TemplateExpression */) { + const lastSpan = last(template.templateSpans); + if (lastSpan.literal.getFullWidth() === 0) { + applicableSpanEnd = skipTrivia( + sourceFile.text, + applicableSpanEnd, + /*stopAfterLineBreak*/ + false + ); + } + } + return createTextSpan(applicableSpanStart, applicableSpanEnd - applicableSpanStart); } - function declarationIsWriteAccess(decl) { - if (!!(decl.flags & 16777216 /* Ambient */)) - return true; - switch (decl.kind) { - case 225 /* BinaryExpression */: - case 207 /* BindingElement */: - case 262 /* ClassDeclaration */: - case 230 /* ClassExpression */: - case 90 /* DefaultKeyword */: - case 265 /* EnumDeclaration */: - case 305 /* EnumMember */: - case 280 /* ExportSpecifier */: - case 272 /* ImportClause */: - case 270 /* ImportEqualsDeclaration */: - case 275 /* ImportSpecifier */: - case 263 /* InterfaceDeclaration */: - case 344 /* JSDocCallbackTag */: - case 352 /* JSDocTypedefTag */: - case 290 /* JsxAttribute */: - case 266 /* ModuleDeclaration */: - case 269 /* NamespaceExportDeclaration */: - case 273 /* NamespaceImport */: - case 279 /* NamespaceExport */: - case 168 /* Parameter */: - case 303 /* ShorthandPropertyAssignment */: - case 264 /* TypeAliasDeclaration */: - case 167 /* TypeParameter */: - return true; - case 302 /* PropertyAssignment */: - return !isArrayLiteralOrObjectLiteralDestructuringPattern(decl.parent); - case 261 /* FunctionDeclaration */: - case 217 /* FunctionExpression */: - case 175 /* Constructor */: - case 173 /* MethodDeclaration */: - case 176 /* GetAccessor */: - case 177 /* SetAccessor */: - return !!decl.body; - case 259 /* VariableDeclaration */: - case 171 /* PropertyDeclaration */: - return !!decl.initializer || isCatchClause(decl.parent); - case 172 /* MethodSignature */: - case 170 /* PropertySignature */: - case 354 /* JSDocPropertyTag */: - case 347 /* JSDocParameterTag */: - return false; - default: - return Debug.failBadSyntaxKind(decl); + function getContainingArgumentInfo(node, position, sourceFile, checker, isManuallyInvoked) { + for (let n = node; !isSourceFile(n) && (isManuallyInvoked || !isBlock(n)); n = n.parent) { + Debug.assert(rangeContainsRange(n.parent, n), "Not a subspan", () => `Child: ${Debug.formatSyntaxKind(n.kind)}, parent: ${Debug.formatSyntaxKind(n.parent.kind)}`); + const argumentInfo = getImmediatelyContainingArgumentOrContextualParameterInfo(n, position, sourceFile, checker); + if (argumentInfo) { + return argumentInfo; + } } + return void 0; } - var DefinitionKind, EntryKind, FindReferencesUse, Core; - var init_findAllReferences = __esm({ - "src/services/findAllReferences.ts"() { - "use strict"; - init_ts4(); - init_ts_FindAllReferences(); - DefinitionKind = /* @__PURE__ */ ((DefinitionKind2) => { - DefinitionKind2[DefinitionKind2["Symbol"] = 0] = "Symbol"; - DefinitionKind2[DefinitionKind2["Label"] = 1] = "Label"; - DefinitionKind2[DefinitionKind2["Keyword"] = 2] = "Keyword"; - DefinitionKind2[DefinitionKind2["This"] = 3] = "This"; - DefinitionKind2[DefinitionKind2["String"] = 4] = "String"; - DefinitionKind2[DefinitionKind2["TripleSlashReference"] = 5] = "TripleSlashReference"; - return DefinitionKind2; - })(DefinitionKind || {}); - EntryKind = /* @__PURE__ */ ((EntryKind2) => { - EntryKind2[EntryKind2["Span"] = 0] = "Span"; - EntryKind2[EntryKind2["Node"] = 1] = "Node"; - EntryKind2[EntryKind2["StringLiteral"] = 2] = "StringLiteral"; - EntryKind2[EntryKind2["SearchedLocalFoundProperty"] = 3] = "SearchedLocalFoundProperty"; - EntryKind2[EntryKind2["SearchedPropertyFoundLocal"] = 4] = "SearchedPropertyFoundLocal"; - return EntryKind2; - })(EntryKind || {}); - FindReferencesUse = /* @__PURE__ */ ((FindReferencesUse2) => { - FindReferencesUse2[FindReferencesUse2["Other"] = 0] = "Other"; - FindReferencesUse2[FindReferencesUse2["References"] = 1] = "References"; - FindReferencesUse2[FindReferencesUse2["Rename"] = 2] = "Rename"; - return FindReferencesUse2; - })(FindReferencesUse || {}); - ((Core2) => { - function getReferencedSymbolsForNode(position, node, program, sourceFiles, cancellationToken, options = {}, sourceFilesSet = new Set(sourceFiles.map((f) => f.fileName))) { - var _a, _b, _c; - node = getAdjustedNode2(node, options); - if (isSourceFile(node)) { - const resolvedRef = ts_GoToDefinition_exports.getReferenceAtPosition(node, position, program); - if (!(resolvedRef == null ? void 0 : resolvedRef.file)) { - return void 0; - } - const moduleSymbol = program.getTypeChecker().getMergedSymbol(resolvedRef.file.symbol); - if (moduleSymbol) { - return getReferencedSymbolsForModule( - program, - moduleSymbol, - /*excludeImportTypeOfExportEquals*/ - false, - sourceFiles, - sourceFilesSet - ); - } - const fileIncludeReasons = program.getFileIncludeReasons(); - if (!fileIncludeReasons) { - return void 0; - } - return [{ - definition: { type: 5 /* TripleSlashReference */, reference: resolvedRef.reference, file: node }, - references: getReferencesForNonModule(resolvedRef.file, fileIncludeReasons, program) || emptyArray - }]; - } - if (!options.implementations) { - const special = getReferencedSymbolsSpecial(node, sourceFiles, cancellationToken); - if (special) { - return special; - } - } - const checker = program.getTypeChecker(); - const symbol = checker.getSymbolAtLocation(isConstructorDeclaration(node) && node.parent.name || node); - if (!symbol) { - if (!options.implementations && isStringLiteralLike(node)) { - if (isModuleSpecifierLike(node)) { - const fileIncludeReasons = program.getFileIncludeReasons(); - const referencedFileName = (_c = (_b = (_a = node.getSourceFile().resolvedModules) == null ? void 0 : _a.get(node.text, getModeForUsageLocation(node.getSourceFile(), node))) == null ? void 0 : _b.resolvedModule) == null ? void 0 : _c.resolvedFileName; - const referencedFile = referencedFileName ? program.getSourceFile(referencedFileName) : void 0; - if (referencedFile) { - return [{ definition: { type: 4 /* String */, node }, references: getReferencesForNonModule(referencedFile, fileIncludeReasons, program) || emptyArray }]; - } - } - return getReferencesForStringLiteral(node, sourceFiles, checker, cancellationToken); - } - return void 0; - } - if (symbol.escapedName === "export=" /* ExportEquals */) { - return getReferencedSymbolsForModule( - program, - symbol.parent, - /*excludeImportTypeOfExportEquals*/ - false, - sourceFiles, - sourceFilesSet - ); - } - const moduleReferences = getReferencedSymbolsForModuleIfDeclaredBySourceFile(symbol, program, sourceFiles, cancellationToken, options, sourceFilesSet); - if (moduleReferences && !(symbol.flags & 33554432 /* Transient */)) { - return moduleReferences; - } - const aliasedSymbol = getMergedAliasedSymbolOfNamespaceExportDeclaration(node, symbol, checker); - const moduleReferencesOfExportTarget = aliasedSymbol && getReferencedSymbolsForModuleIfDeclaredBySourceFile(aliasedSymbol, program, sourceFiles, cancellationToken, options, sourceFilesSet); - const references = getReferencedSymbolsForSymbol(symbol, node, sourceFiles, sourceFilesSet, checker, cancellationToken, options); - return mergeReferences(program, moduleReferences, references, moduleReferencesOfExportTarget); - } - Core2.getReferencedSymbolsForNode = getReferencedSymbolsForNode; - function getAdjustedNode2(node, options) { - if (options.use === 1 /* References */) { - node = getAdjustedReferenceLocation(node); - } else if (options.use === 2 /* Rename */) { - node = getAdjustedRenameLocation(node); - } - return node; - } - Core2.getAdjustedNode = getAdjustedNode2; - function getReferencesForFileName(fileName, program, sourceFiles, sourceFilesSet = new Set(sourceFiles.map((f) => f.fileName))) { - var _a, _b; - const moduleSymbol = (_a = program.getSourceFile(fileName)) == null ? void 0 : _a.symbol; - if (moduleSymbol) { - return ((_b = getReferencedSymbolsForModule( - program, - moduleSymbol, - /*excludeImportTypeOfExportEquals*/ - false, - sourceFiles, - sourceFilesSet - )[0]) == null ? void 0 : _b.references) || emptyArray; - } - const fileIncludeReasons = program.getFileIncludeReasons(); - const referencedFile = program.getSourceFile(fileName); - return referencedFile && fileIncludeReasons && getReferencesForNonModule(referencedFile, fileIncludeReasons, program) || emptyArray; - } - Core2.getReferencesForFileName = getReferencesForFileName; - function getReferencesForNonModule(referencedFile, refFileMap, program) { - let entries; - const references = refFileMap.get(referencedFile.path) || emptyArray; - for (const ref of references) { - if (isReferencedFile(ref)) { - const referencingFile = program.getSourceFileByPath(ref.file); - const location = getReferencedFileLocation(program.getSourceFileByPath, ref); - if (isReferenceFileLocation(location)) { - entries = append(entries, { - kind: 0 /* Span */, - fileName: referencingFile.fileName, - textSpan: createTextSpanFromRange(location) - }); - } - } - } - return entries; - } - function getMergedAliasedSymbolOfNamespaceExportDeclaration(node, symbol, checker) { - if (node.parent && isNamespaceExportDeclaration(node.parent)) { - const aliasedSymbol = checker.getAliasedSymbol(symbol); - const targetSymbol = checker.getMergedSymbol(aliasedSymbol); - if (aliasedSymbol !== targetSymbol) { - return targetSymbol; - } - } - return void 0; - } - function getReferencedSymbolsForModuleIfDeclaredBySourceFile(symbol, program, sourceFiles, cancellationToken, options, sourceFilesSet) { - const moduleSourceFile = symbol.flags & 1536 /* Module */ && symbol.declarations && find(symbol.declarations, isSourceFile); - if (!moduleSourceFile) - return void 0; - const exportEquals = symbol.exports.get("export=" /* ExportEquals */); - const moduleReferences = getReferencedSymbolsForModule(program, symbol, !!exportEquals, sourceFiles, sourceFilesSet); - if (!exportEquals || !sourceFilesSet.has(moduleSourceFile.fileName)) - return moduleReferences; - const checker = program.getTypeChecker(); - symbol = skipAlias(exportEquals, checker); - return mergeReferences(program, moduleReferences, getReferencedSymbolsForSymbol( - symbol, - /*node*/ - void 0, - sourceFiles, - sourceFilesSet, - checker, - cancellationToken, - options - )); - } - function mergeReferences(program, ...referencesToMerge) { - let result; - for (const references of referencesToMerge) { - if (!references || !references.length) - continue; - if (!result) { - result = references; - continue; - } - for (const entry of references) { - if (!entry.definition || entry.definition.type !== 0 /* Symbol */) { - result.push(entry); - continue; - } - const symbol = entry.definition.symbol; - const refIndex = findIndex(result, (ref) => !!ref.definition && ref.definition.type === 0 /* Symbol */ && ref.definition.symbol === symbol); - if (refIndex === -1) { - result.push(entry); - continue; - } - const reference = result[refIndex]; - result[refIndex] = { - definition: reference.definition, - references: reference.references.concat(entry.references).sort((entry1, entry2) => { - const entry1File = getSourceFileIndexOfEntry(program, entry1); - const entry2File = getSourceFileIndexOfEntry(program, entry2); - if (entry1File !== entry2File) { - return compareValues(entry1File, entry2File); - } - const entry1Span = getTextSpanOfEntry(entry1); - const entry2Span = getTextSpanOfEntry(entry2); - return entry1Span.start !== entry2Span.start ? compareValues(entry1Span.start, entry2Span.start) : compareValues(entry1Span.length, entry2Span.length); - }) - }; - } - } - return result; - } - function getSourceFileIndexOfEntry(program, entry) { - const sourceFile = entry.kind === 0 /* Span */ ? program.getSourceFile(entry.fileName) : entry.node.getSourceFile(); - return program.getSourceFiles().indexOf(sourceFile); - } - function getReferencedSymbolsForModule(program, symbol, excludeImportTypeOfExportEquals, sourceFiles, sourceFilesSet) { - Debug.assert(!!symbol.valueDeclaration); - const references = mapDefined(findModuleReferences(program, sourceFiles, symbol), (reference) => { - if (reference.kind === "import") { - const parent2 = reference.literal.parent; - if (isLiteralTypeNode(parent2)) { - const importType = cast(parent2.parent, isImportTypeNode); - if (excludeImportTypeOfExportEquals && !importType.qualifier) { - return void 0; - } - } - return nodeEntry(reference.literal); - } else if (reference.kind === "implicit") { - const range = reference.literal.text !== externalHelpersModuleNameText && forEachChildRecursively( - reference.referencingFile, - (n) => !(n.transformFlags & 2 /* ContainsJsx */) ? "skip" : isJsxElement(n) || isJsxSelfClosingElement(n) || isJsxFragment(n) ? n : void 0 - ) || reference.referencingFile.statements[0] || reference.referencingFile; - return nodeEntry(range); - } else { - return { - kind: 0 /* Span */, - fileName: reference.referencingFile.fileName, - textSpan: createTextSpanFromRange(reference.ref) - }; - } - }); - if (symbol.declarations) { - for (const decl of symbol.declarations) { - switch (decl.kind) { - case 311 /* SourceFile */: - break; - case 266 /* ModuleDeclaration */: - if (sourceFilesSet.has(decl.getSourceFile().fileName)) { - references.push(nodeEntry(decl.name)); - } - break; - default: - Debug.assert(!!(symbol.flags & 33554432 /* Transient */), "Expected a module symbol to be declared by a SourceFile or ModuleDeclaration."); - } - } - } - const exported = symbol.exports.get("export=" /* ExportEquals */); - if (exported == null ? void 0 : exported.declarations) { - for (const decl of exported.declarations) { - const sourceFile = decl.getSourceFile(); - if (sourceFilesSet.has(sourceFile.fileName)) { - const node = isBinaryExpression(decl) && isPropertyAccessExpression(decl.left) ? decl.left.expression : isExportAssignment(decl) ? Debug.checkDefined(findChildOfKind(decl, 95 /* ExportKeyword */, sourceFile)) : getNameOfDeclaration(decl) || decl; - references.push(nodeEntry(node)); - } - } - } - return references.length ? [{ definition: { type: 0 /* Symbol */, symbol }, references }] : emptyArray; - } - function isReadonlyTypeOperator(node) { - return node.kind === 148 /* ReadonlyKeyword */ && isTypeOperatorNode(node.parent) && node.parent.operator === 148 /* ReadonlyKeyword */; - } - function getReferencedSymbolsSpecial(node, sourceFiles, cancellationToken) { - if (isTypeKeyword(node.kind)) { - if (node.kind === 116 /* VoidKeyword */ && isVoidExpression(node.parent)) { - return void 0; - } - if (node.kind === 148 /* ReadonlyKeyword */ && !isReadonlyTypeOperator(node)) { - return void 0; - } - return getAllReferencesForKeyword( - sourceFiles, - node.kind, - cancellationToken, - node.kind === 148 /* ReadonlyKeyword */ ? isReadonlyTypeOperator : void 0 - ); - } - if (isImportMeta(node.parent) && node.parent.name === node) { - return getAllReferencesForImportMeta(sourceFiles, cancellationToken); - } - if (isStaticModifier(node) && isClassStaticBlockDeclaration(node.parent)) { - return [{ definition: { type: 2 /* Keyword */, node }, references: [nodeEntry(node)] }]; - } - if (isJumpStatementTarget(node)) { - const labelDefinition = getTargetLabel(node.parent, node.text); - return labelDefinition && getLabelReferencesInNode(labelDefinition.parent, labelDefinition); - } else if (isLabelOfLabeledStatement(node)) { - return getLabelReferencesInNode(node.parent, node); - } - if (isThis(node)) { - return getReferencesForThisKeyword(node, sourceFiles, cancellationToken); - } - if (node.kind === 108 /* SuperKeyword */) { - return getReferencesForSuperKeyword(node); - } - return void 0; - } - function getReferencedSymbolsForSymbol(originalSymbol, node, sourceFiles, sourceFilesSet, checker, cancellationToken, options) { - const symbol = node && skipPastExportOrImportSpecifierOrUnion( - originalSymbol, - node, - checker, - /*useLocalSymbolForExportSpecifier*/ - !isForRenameWithPrefixAndSuffixText(options) - ) || originalSymbol; - const searchMeaning = node ? getIntersectingMeaningFromDeclarations(node, symbol) : 7 /* All */; - const result = []; - const state = new State(sourceFiles, sourceFilesSet, node ? getSpecialSearchKind(node) : 0 /* None */, checker, cancellationToken, searchMeaning, options, result); - const exportSpecifier = !isForRenameWithPrefixAndSuffixText(options) || !symbol.declarations ? void 0 : find(symbol.declarations, isExportSpecifier); - if (exportSpecifier) { - getReferencesAtExportSpecifier( - exportSpecifier.name, - symbol, - exportSpecifier, - state.createSearch( - node, - originalSymbol, - /*comingFrom*/ - void 0 - ), - state, - /*addReferencesHere*/ - true, - /*alwaysGetReferences*/ - true - ); - } else if (node && node.kind === 90 /* DefaultKeyword */ && symbol.escapedName === "default" /* Default */ && symbol.parent) { - addReference(node, symbol, state); - searchForImportsOfExport(node, symbol, { exportingModuleSymbol: symbol.parent, exportKind: 1 /* Default */ }, state); - } else { - const search = state.createSearch( - node, - symbol, - /*comingFrom*/ - void 0, - { allSearchSymbols: node ? populateSearchSymbolSet(symbol, node, checker, options.use === 2 /* Rename */, !!options.providePrefixAndSuffixTextForRename, !!options.implementations) : [symbol] } - ); - getReferencesInContainerOrFiles(symbol, state, search); - } - return result; - } - function getReferencesInContainerOrFiles(symbol, state, search) { - const scope = getSymbolScope(symbol); - if (scope) { - getReferencesInContainer( - scope, - scope.getSourceFile(), - search, - state, - /*addReferencesHere*/ - !(isSourceFile(scope) && !contains(state.sourceFiles, scope)) - ); - } else { - for (const sourceFile of state.sourceFiles) { - state.cancellationToken.throwIfCancellationRequested(); - searchForName(sourceFile, search, state); - } - } - } - function getSpecialSearchKind(node) { - switch (node.kind) { - case 175 /* Constructor */: - case 137 /* ConstructorKeyword */: - return 1 /* Constructor */; - case 80 /* Identifier */: - if (isClassLike(node.parent)) { - Debug.assert(node.parent.name === node); - return 2 /* Class */; - } - default: - return 0 /* None */; - } - } - function skipPastExportOrImportSpecifierOrUnion(symbol, node, checker, useLocalSymbolForExportSpecifier) { - const { parent: parent2 } = node; - if (isExportSpecifier(parent2) && useLocalSymbolForExportSpecifier) { - return getLocalSymbolForExportSpecifier(node, symbol, parent2, checker); - } - return firstDefined(symbol.declarations, (decl) => { - if (!decl.parent) { - if (symbol.flags & 33554432 /* Transient */) - return void 0; - Debug.fail(`Unexpected symbol at ${Debug.formatSyntaxKind(node.kind)}: ${Debug.formatSymbol(symbol)}`); - } - return isTypeLiteralNode(decl.parent) && isUnionTypeNode(decl.parent.parent) ? checker.getPropertyOfType(checker.getTypeFromTypeNode(decl.parent.parent), symbol.name) : void 0; - }); - } - let SpecialSearchKind; - ((SpecialSearchKind2) => { - SpecialSearchKind2[SpecialSearchKind2["None"] = 0] = "None"; - SpecialSearchKind2[SpecialSearchKind2["Constructor"] = 1] = "Constructor"; - SpecialSearchKind2[SpecialSearchKind2["Class"] = 2] = "Class"; - })(SpecialSearchKind || (SpecialSearchKind = {})); - function getNonModuleSymbolOfMergedModuleSymbol(symbol) { - if (!(symbol.flags & (1536 /* Module */ | 33554432 /* Transient */))) - return void 0; - const decl = symbol.declarations && find(symbol.declarations, (d) => !isSourceFile(d) && !isModuleDeclaration(d)); - return decl && decl.symbol; - } - class State { - constructor(sourceFiles, sourceFilesSet, specialSearchKind, checker, cancellationToken, searchMeaning, options, result) { - this.sourceFiles = sourceFiles; - this.sourceFilesSet = sourceFilesSet; - this.specialSearchKind = specialSearchKind; - this.checker = checker; - this.cancellationToken = cancellationToken; - this.searchMeaning = searchMeaning; - this.options = options; - this.result = result; - /** Cache for `explicitlyinheritsFrom`. */ - this.inheritsFromCache = /* @__PURE__ */ new Map(); - /** - * Type nodes can contain multiple references to the same type. For example: - * let x: Foo & (Foo & Bar) = ... - * Because we are returning the implementation locations and not the identifier locations, - * duplicate entries would be returned here as each of the type references is part of - * the same implementation. For that reason, check before we add a new entry. - */ - this.markSeenContainingTypeReference = nodeSeenTracker(); - /** - * It's possible that we will encounter the right side of `export { foo as bar } from "x";` more than once. - * For example: - * // b.ts - * export { foo as bar } from "./a"; - * import { bar } from "./b"; - * - * Normally at `foo as bar` we directly add `foo` and do not locally search for it (since it doesn't declare a local). - * But another reference to it may appear in the same source file. - * See `tests/cases/fourslash/transitiveExportImports3.ts`. - */ - this.markSeenReExportRHS = nodeSeenTracker(); - this.symbolIdToReferences = []; - // Source file ID -> symbol ID -> Whether the symbol has been searched for in the source file. - this.sourceFileToSeenSymbols = []; - } - includesSourceFile(sourceFile) { - return this.sourceFilesSet.has(sourceFile.fileName); - } - /** Gets every place to look for references of an exported symbols. See `ImportsResult` in `importTracker.ts` for more documentation. */ - getImportSearches(exportSymbol, exportInfo) { - if (!this.importTracker) - this.importTracker = createImportTracker(this.sourceFiles, this.sourceFilesSet, this.checker, this.cancellationToken); - return this.importTracker(exportSymbol, exportInfo, this.options.use === 2 /* Rename */); - } - /** @param allSearchSymbols set of additional symbols for use by `includes`. */ - createSearch(location, symbol, comingFrom, searchOptions = {}) { - const { - text = stripQuotes(symbolName(getLocalSymbolForExportDefault(symbol) || getNonModuleSymbolOfMergedModuleSymbol(symbol) || symbol)), - allSearchSymbols = [symbol] - } = searchOptions; - const escapedText = escapeLeadingUnderscores(text); - const parents = this.options.implementations && location ? getParentSymbolsOfPropertyAccess(location, symbol, this.checker) : void 0; - return { symbol, comingFrom, text, escapedText, parents, allSearchSymbols, includes: (sym) => contains(allSearchSymbols, sym) }; - } - /** - * Callback to add references for a particular searched symbol. - * This initializes a reference group, so only call this if you will add at least one reference. - */ - referenceAdder(searchSymbol) { - const symbolId = getSymbolId(searchSymbol); - let references = this.symbolIdToReferences[symbolId]; - if (!references) { - references = this.symbolIdToReferences[symbolId] = []; - this.result.push({ definition: { type: 0 /* Symbol */, symbol: searchSymbol }, references }); - } - return (node, kind) => references.push(nodeEntry(node, kind)); - } - /** Add a reference with no associated definition. */ - addStringOrCommentReference(fileName, textSpan) { - this.result.push({ - definition: void 0, - references: [{ kind: 0 /* Span */, fileName, textSpan }] - }); - } - /** Returns `true` the first time we search for a symbol in a file and `false` afterwards. */ - markSearchedSymbols(sourceFile, symbols) { - const sourceId = getNodeId(sourceFile); - const seenSymbols = this.sourceFileToSeenSymbols[sourceId] || (this.sourceFileToSeenSymbols[sourceId] = /* @__PURE__ */ new Set()); - let anyNewSymbols = false; - for (const sym of symbols) { - anyNewSymbols = tryAddToSet(seenSymbols, getSymbolId(sym)) || anyNewSymbols; - } - return anyNewSymbols; - } - } - function searchForImportsOfExport(exportLocation, exportSymbol, exportInfo, state) { - const { importSearches, singleReferences, indirectUsers } = state.getImportSearches(exportSymbol, exportInfo); - if (singleReferences.length) { - const addRef = state.referenceAdder(exportSymbol); - for (const singleRef of singleReferences) { - if (shouldAddSingleReference(singleRef, state)) - addRef(singleRef); - } - } - for (const [importLocation, importSymbol] of importSearches) { - getReferencesInSourceFile(importLocation.getSourceFile(), state.createSearch(importLocation, importSymbol, 1 /* Export */), state); - } - if (indirectUsers.length) { - let indirectSearch; - switch (exportInfo.exportKind) { - case 0 /* Named */: - indirectSearch = state.createSearch(exportLocation, exportSymbol, 1 /* Export */); - break; - case 1 /* Default */: - indirectSearch = state.options.use === 2 /* Rename */ ? void 0 : state.createSearch(exportLocation, exportSymbol, 1 /* Export */, { text: "default" }); - break; - case 2 /* ExportEquals */: - break; - } - if (indirectSearch) { - for (const indirectUser of indirectUsers) { - searchForName(indirectUser, indirectSearch, state); - } - } - } - } - function eachExportReference(sourceFiles, checker, cancellationToken, exportSymbol, exportingModuleSymbol, exportName, isDefaultExport, cb) { - const importTracker = createImportTracker(sourceFiles, new Set(sourceFiles.map((f) => f.fileName)), checker, cancellationToken); - const { importSearches, indirectUsers, singleReferences } = importTracker( - exportSymbol, - { exportKind: isDefaultExport ? 1 /* Default */ : 0 /* Named */, exportingModuleSymbol }, - /*isForRename*/ - false - ); - for (const [importLocation] of importSearches) { - cb(importLocation); - } - for (const singleReference of singleReferences) { - if (isIdentifier(singleReference) && isImportTypeNode(singleReference.parent)) { - cb(singleReference); - } - } - for (const indirectUser of indirectUsers) { - for (const node of getPossibleSymbolReferenceNodes(indirectUser, isDefaultExport ? "default" : exportName)) { - const symbol = checker.getSymbolAtLocation(node); - const hasExportAssignmentDeclaration = some(symbol == null ? void 0 : symbol.declarations, (d) => tryCast(d, isExportAssignment) ? true : false); - if (isIdentifier(node) && !isImportOrExportSpecifier(node.parent) && (symbol === exportSymbol || hasExportAssignmentDeclaration)) { - cb(node); - } - } - } - } - Core2.eachExportReference = eachExportReference; - function shouldAddSingleReference(singleRef, state) { - if (!hasMatchingMeaning(singleRef, state)) - return false; - if (state.options.use !== 2 /* Rename */) - return true; - if (!isIdentifier(singleRef)) - return false; - return !(isImportOrExportSpecifier(singleRef.parent) && singleRef.escapedText === "default" /* Default */); - } - function searchForImportedSymbol(symbol, state) { - if (!symbol.declarations) - return; - for (const declaration of symbol.declarations) { - const exportingFile = declaration.getSourceFile(); - getReferencesInSourceFile(exportingFile, state.createSearch(declaration, symbol, 0 /* Import */), state, state.includesSourceFile(exportingFile)); - } - } - function searchForName(sourceFile, search, state) { - if (getNameTable(sourceFile).get(search.escapedText) !== void 0) { - getReferencesInSourceFile(sourceFile, search, state); - } - } - function getPropertySymbolOfDestructuringAssignment(location, checker) { - return isArrayLiteralOrObjectLiteralDestructuringPattern(location.parent.parent) ? checker.getPropertySymbolOfDestructuringAssignment(location) : void 0; - } - function getSymbolScope(symbol) { - const { declarations, flags, parent: parent2, valueDeclaration } = symbol; - if (valueDeclaration && (valueDeclaration.kind === 217 /* FunctionExpression */ || valueDeclaration.kind === 230 /* ClassExpression */)) { - return valueDeclaration; - } - if (!declarations) { - return void 0; - } - if (flags & (4 /* Property */ | 8192 /* Method */)) { - const privateDeclaration = find(declarations, (d) => hasEffectiveModifier(d, 8 /* Private */) || isPrivateIdentifierClassElementDeclaration(d)); - if (privateDeclaration) { - return getAncestor(privateDeclaration, 262 /* ClassDeclaration */); + function getChildListThatStartsWithOpenerToken(parent2, openerToken, sourceFile) { + const children = parent2.getChildren(sourceFile); + const indexOfOpenerToken = children.indexOf(openerToken); + Debug.assert(indexOfOpenerToken >= 0 && children.length > indexOfOpenerToken + 1); + return children[indexOfOpenerToken + 1]; + } + function getExpressionFromInvocation(invocation) { + return invocation.kind === 0 /* Call */ ? getInvokedExpression(invocation.node) : invocation.called; + } + function getEnclosingDeclarationFromInvocation(invocation) { + return invocation.kind === 0 /* Call */ ? invocation.node : invocation.kind === 1 /* TypeArgs */ ? invocation.called : invocation.node; + } + function createSignatureHelpItems(candidates, resolvedSignature, { isTypeParameterList, argumentCount, argumentsSpan: applicableSpan, invocation, argumentIndex }, sourceFile, typeChecker, useFullPrefix) { + var _a; + const enclosingDeclaration = getEnclosingDeclarationFromInvocation(invocation); + const callTargetSymbol = invocation.kind === 2 /* Contextual */ ? invocation.symbol : typeChecker.getSymbolAtLocation(getExpressionFromInvocation(invocation)) || useFullPrefix && ((_a = resolvedSignature.declaration) == null ? void 0 : _a.symbol); + const callTargetDisplayParts = callTargetSymbol ? symbolToDisplayParts( + typeChecker, + callTargetSymbol, + useFullPrefix ? sourceFile : void 0, + /*meaning*/ + void 0 + ) : emptyArray; + const items = map(candidates, (candidateSignature) => getSignatureHelpItem(candidateSignature, callTargetDisplayParts, isTypeParameterList, typeChecker, enclosingDeclaration, sourceFile)); + if (argumentIndex !== 0) { + Debug.assertLessThan(argumentIndex, argumentCount); + } + let selectedItemIndex = 0; + let itemsSeen = 0; + for (let i = 0; i < items.length; i++) { + const item = items[i]; + if (candidates[i] === resolvedSignature) { + selectedItemIndex = itemsSeen; + if (item.length > 1) { + let count = 0; + for (const i2 of item) { + if (i2.isVariadic || i2.parameters.length >= argumentCount) { + selectedItemIndex = itemsSeen + count; + break; } - return void 0; + count++; } - if (declarations.some(isObjectBindingElementWithoutPropertyName)) { - return void 0; + } + } + itemsSeen += item.length; + } + Debug.assert(selectedItemIndex !== -1); + const help = { items: flatMapToMutable(items, identity), applicableSpan, selectedItemIndex, argumentIndex, argumentCount }; + const selected = help.items[selectedItemIndex]; + if (selected.isVariadic) { + const firstRest = findIndex(selected.parameters, (p) => !!p.isRest); + if (-1 < firstRest && firstRest < selected.parameters.length - 1) { + help.argumentIndex = selected.parameters.length; + } else { + help.argumentIndex = Math.min(help.argumentIndex, selected.parameters.length - 1); + } + } + return help; + } + function createTypeHelpItems(symbol, { argumentCount, argumentsSpan: applicableSpan, invocation, argumentIndex }, sourceFile, checker) { + const typeParameters = checker.getLocalTypeParametersOfClassOrInterfaceOrTypeAlias(symbol); + if (!typeParameters) + return void 0; + const items = [getTypeHelpItem(symbol, typeParameters, checker, getEnclosingDeclarationFromInvocation(invocation), sourceFile)]; + return { items, applicableSpan, selectedItemIndex: 0, argumentIndex, argumentCount }; + } + function getTypeHelpItem(symbol, typeParameters, checker, enclosingDeclaration, sourceFile) { + const typeSymbolDisplay = symbolToDisplayParts(checker, symbol); + const printer = createPrinterWithRemoveComments(); + const parameters = typeParameters.map((t) => createSignatureHelpParameterForTypeParameter(t, checker, enclosingDeclaration, sourceFile, printer)); + const documentation = symbol.getDocumentationComment(checker); + const tags = symbol.getJsDocTags(checker); + const prefixDisplayParts = [...typeSymbolDisplay, punctuationPart(30 /* LessThanToken */)]; + return { isVariadic: false, prefixDisplayParts, suffixDisplayParts: [punctuationPart(32 /* GreaterThanToken */)], separatorDisplayParts, parameters, documentation, tags }; + } + function getSignatureHelpItem(candidateSignature, callTargetDisplayParts, isTypeParameterList, checker, enclosingDeclaration, sourceFile) { + const infos = (isTypeParameterList ? itemInfoForTypeParameters : itemInfoForParameters)(candidateSignature, checker, enclosingDeclaration, sourceFile); + return map(infos, ({ isVariadic, parameters, prefix, suffix }) => { + const prefixDisplayParts = [...callTargetDisplayParts, ...prefix]; + const suffixDisplayParts = [...suffix, ...returnTypeToDisplayParts(candidateSignature, enclosingDeclaration, checker)]; + const documentation = candidateSignature.getDocumentationComment(checker); + const tags = candidateSignature.getJsDocTags(); + return { isVariadic, prefixDisplayParts, suffixDisplayParts, separatorDisplayParts, parameters, documentation, tags }; + }); + } + function returnTypeToDisplayParts(candidateSignature, enclosingDeclaration, checker) { + return mapToDisplayParts((writer) => { + writer.writePunctuation(":"); + writer.writeSpace(" "); + const predicate = checker.getTypePredicateOfSignature(candidateSignature); + if (predicate) { + checker.writeTypePredicate( + predicate, + enclosingDeclaration, + /*flags*/ + void 0, + writer + ); + } else { + checker.writeType( + checker.getReturnTypeOfSignature(candidateSignature), + enclosingDeclaration, + /*flags*/ + void 0, + writer + ); + } + }); + } + function itemInfoForTypeParameters(candidateSignature, checker, enclosingDeclaration, sourceFile) { + const typeParameters = (candidateSignature.target || candidateSignature).typeParameters; + const printer = createPrinterWithRemoveComments(); + const parameters = (typeParameters || emptyArray).map((t) => createSignatureHelpParameterForTypeParameter(t, checker, enclosingDeclaration, sourceFile, printer)); + const thisParameter = candidateSignature.thisParameter ? [checker.symbolToParameterDeclaration(candidateSignature.thisParameter, enclosingDeclaration, signatureHelpNodeBuilderFlags)] : []; + return checker.getExpandedParameters(candidateSignature).map((paramList) => { + const params = factory.createNodeArray([...thisParameter, ...map(paramList, (param) => checker.symbolToParameterDeclaration(param, enclosingDeclaration, signatureHelpNodeBuilderFlags))]); + const parameterParts = mapToDisplayParts((writer) => { + printer.writeList(2576 /* CallExpressionArguments */, params, sourceFile, writer); + }); + return { isVariadic: false, parameters, prefix: [punctuationPart(30 /* LessThanToken */)], suffix: [punctuationPart(32 /* GreaterThanToken */), ...parameterParts] }; + }); + } + function itemInfoForParameters(candidateSignature, checker, enclosingDeclaration, sourceFile) { + const printer = createPrinterWithRemoveComments(); + const typeParameterParts = mapToDisplayParts((writer) => { + if (candidateSignature.typeParameters && candidateSignature.typeParameters.length) { + const args = factory.createNodeArray(candidateSignature.typeParameters.map((p) => checker.typeParameterToDeclaration(p, enclosingDeclaration, signatureHelpNodeBuilderFlags))); + printer.writeList(53776 /* TypeParameters */, args, sourceFile, writer); + } + }); + const lists = checker.getExpandedParameters(candidateSignature); + const isVariadic = !checker.hasEffectiveRestParameter(candidateSignature) ? (_) => false : lists.length === 1 ? (_) => true : (pList) => { + var _a; + return !!(pList.length && ((_a = tryCast(pList[pList.length - 1], isTransientSymbol)) == null ? void 0 : _a.links.checkFlags) & 32768 /* RestParameter */); + }; + return lists.map((parameterList) => ({ + isVariadic: isVariadic(parameterList), + parameters: parameterList.map((p) => createSignatureHelpParameterForParameter(p, checker, enclosingDeclaration, sourceFile, printer)), + prefix: [...typeParameterParts, punctuationPart(21 /* OpenParenToken */)], + suffix: [punctuationPart(22 /* CloseParenToken */)] + })); + } + function createSignatureHelpParameterForParameter(parameter, checker, enclosingDeclaration, sourceFile, printer) { + const displayParts = mapToDisplayParts((writer) => { + const param = checker.symbolToParameterDeclaration(parameter, enclosingDeclaration, signatureHelpNodeBuilderFlags); + printer.writeNode(4 /* Unspecified */, param, sourceFile, writer); + }); + const isOptional = checker.isOptionalParameter(parameter.valueDeclaration); + const isRest = isTransientSymbol(parameter) && !!(parameter.links.checkFlags & 32768 /* RestParameter */); + return { name: parameter.name, documentation: parameter.getDocumentationComment(checker), displayParts, isOptional, isRest }; + } + function createSignatureHelpParameterForTypeParameter(typeParameter, checker, enclosingDeclaration, sourceFile, printer) { + const displayParts = mapToDisplayParts((writer) => { + const param = checker.typeParameterToDeclaration(typeParameter, enclosingDeclaration, signatureHelpNodeBuilderFlags); + printer.writeNode(4 /* Unspecified */, param, sourceFile, writer); + }); + return { name: typeParameter.symbol.name, documentation: typeParameter.symbol.getDocumentationComment(checker), displayParts, isOptional: false, isRest: false }; + } + var signatureHelpNodeBuilderFlags, separatorDisplayParts; + var init_signatureHelp = __esm({ + "src/services/signatureHelp.ts"() { + "use strict"; + init_ts4(); + signatureHelpNodeBuilderFlags = 8192 /* OmitParameterModifiers */ | 70221824 /* IgnoreErrors */ | 16384 /* UseAliasDefinedOutsideCurrentScope */; + separatorDisplayParts = [punctuationPart(28 /* CommaToken */), spacePart()]; + } + }); + + // src/services/_namespaces/ts.SignatureHelp.ts + var ts_SignatureHelp_exports = {}; + __export(ts_SignatureHelp_exports, { + getArgumentInfoForCompletions: () => getArgumentInfoForCompletions, + getSignatureHelpItems: () => getSignatureHelpItems + }); + var init_ts_SignatureHelp = __esm({ + "src/services/_namespaces/ts.SignatureHelp.ts"() { + "use strict"; + init_signatureHelp(); + } + }); + + // src/services/smartSelection.ts + function getSmartSelectionRange(pos, sourceFile) { + var _a, _b; + let selectionRange = { + textSpan: createTextSpanFromBounds(sourceFile.getFullStart(), sourceFile.getEnd()) + }; + let parentNode = sourceFile; + outer: + while (true) { + const children = getSelectionChildren(parentNode); + if (!children.length) + break; + for (let i = 0; i < children.length; i++) { + const prevNode = children[i - 1]; + const node = children[i]; + const nextNode = children[i + 1]; + if (getTokenPosOfNode( + node, + sourceFile, + /*includeJsDoc*/ + true + ) > pos) { + break outer; } - const exposedByParent = parent2 && !(symbol.flags & 262144 /* TypeParameter */); - if (exposedByParent && !(isExternalModuleSymbol(parent2) && !parent2.globalExports)) { - return void 0; + const comment = singleOrUndefined(getTrailingCommentRanges(sourceFile.text, node.end)); + if (comment && comment.kind === 2 /* SingleLineCommentTrivia */) { + pushSelectionCommentRange(comment.pos, comment.end); } - let scope; - for (const declaration of declarations) { - const container = getContainerNode(declaration); - if (scope && scope !== container) { - return void 0; - } - if (!container || container.kind === 311 /* SourceFile */ && !isExternalOrCommonJsModule(container)) { - return void 0; - } - scope = container; - if (isFunctionExpression(scope)) { - let next; - while (next = getNextJSDocCommentLocation(scope)) { - scope = next; - } + if (positionShouldSnapToNode(sourceFile, pos, node)) { + if (isFunctionBody(node) && isFunctionLikeDeclaration(parentNode) && !positionsAreOnSameLine(node.getStart(sourceFile), node.getEnd(), sourceFile)) { + pushSelectionRange(node.getStart(sourceFile), node.getEnd()); } - } - return exposedByParent ? scope.getSourceFile() : scope; - } - function isSymbolReferencedInFile(definition, checker, sourceFile, searchContainer = sourceFile) { - return eachSymbolReferenceInFile(definition, checker, sourceFile, () => true, searchContainer) || false; - } - Core2.isSymbolReferencedInFile = isSymbolReferencedInFile; - function eachSymbolReferenceInFile(definition, checker, sourceFile, cb, searchContainer = sourceFile) { - const symbol = isParameterPropertyDeclaration(definition.parent, definition.parent.parent) ? first(checker.getSymbolsOfParameterPropertyDeclaration(definition.parent, definition.text)) : checker.getSymbolAtLocation(definition); - if (!symbol) - return void 0; - for (const token of getPossibleSymbolReferenceNodes(sourceFile, symbol.name, searchContainer)) { - if (!isIdentifier(token) || token === definition || token.escapedText !== definition.escapedText) - continue; - const referenceSymbol = checker.getSymbolAtLocation(token); - if (referenceSymbol === symbol || checker.getShorthandAssignmentValueSymbol(token.parent) === symbol || isExportSpecifier(token.parent) && getLocalSymbolForExportSpecifier(token, referenceSymbol, token.parent, checker) === symbol) { - const res = cb(token); - if (res) - return res; + if (isBlock(node) || isTemplateSpan(node) || isTemplateHead(node) || isTemplateTail(node) || prevNode && isTemplateHead(prevNode) || isVariableDeclarationList(node) && isVariableStatement(parentNode) || isSyntaxList(node) && isVariableDeclarationList(parentNode) || isVariableDeclaration(node) && isSyntaxList(parentNode) && children.length === 1 || isJSDocTypeExpression(node) || isJSDocSignature(node) || isJSDocTypeLiteral(node)) { + parentNode = node; + break; } - } - } - Core2.eachSymbolReferenceInFile = eachSymbolReferenceInFile; - function getTopMostDeclarationNamesInFile(declarationName, sourceFile) { - const candidates = filter(getPossibleSymbolReferenceNodes(sourceFile, declarationName), (name) => !!getDeclarationFromName(name)); - return candidates.reduce((topMost, decl) => { - const depth = getDepth(decl); - if (!some(topMost.declarationNames) || depth === topMost.depth) { - topMost.declarationNames.push(decl); - topMost.depth = depth; - } else if (depth < topMost.depth) { - topMost.declarationNames = [decl]; - topMost.depth = depth; + if (isTemplateSpan(parentNode) && nextNode && isTemplateMiddleOrTemplateTail(nextNode)) { + const start2 = node.getFullStart() - "${".length; + const end2 = nextNode.getStart() + "}".length; + pushSelectionRange(start2, end2); } - return topMost; - }, { depth: Infinity, declarationNames: [] }).declarationNames; - function getDepth(declaration) { - let depth = 0; - while (declaration) { - declaration = getContainerNode(declaration); - depth++; + const isBetweenMultiLineBookends = isSyntaxList(node) && isListOpener(prevNode) && isListCloser(nextNode) && !positionsAreOnSameLine(prevNode.getStart(), nextNode.getStart(), sourceFile); + let start = isBetweenMultiLineBookends ? prevNode.getEnd() : node.getStart(); + const end = isBetweenMultiLineBookends ? nextNode.getStart() : getEndPos(sourceFile, node); + if (hasJSDocNodes(node) && ((_a = node.jsDoc) == null ? void 0 : _a.length)) { + pushSelectionRange(first(node.jsDoc).getStart(), end); } - return depth; - } - } - Core2.getTopMostDeclarationNamesInFile = getTopMostDeclarationNamesInFile; - function someSignatureUsage(signature, sourceFiles, checker, cb) { - if (!signature.name || !isIdentifier(signature.name)) - return false; - const symbol = Debug.checkDefined(checker.getSymbolAtLocation(signature.name)); - for (const sourceFile of sourceFiles) { - for (const name of getPossibleSymbolReferenceNodes(sourceFile, symbol.name)) { - if (!isIdentifier(name) || name === signature.name || name.escapedText !== signature.name.escapedText) - continue; - const called = climbPastPropertyAccess(name); - const call = isCallExpression(called.parent) && called.parent.expression === called ? called.parent : void 0; - const referenceSymbol = checker.getSymbolAtLocation(name); - if (referenceSymbol && checker.getRootSymbols(referenceSymbol).some((s) => s === symbol)) { - if (cb(name, call)) { - return true; - } + if (isSyntaxList(node)) { + const firstChild = node.getChildren()[0]; + if (firstChild && hasJSDocNodes(firstChild) && ((_b = firstChild.jsDoc) == null ? void 0 : _b.length) && firstChild.getStart() !== node.pos) { + start = Math.min(start, first(firstChild.jsDoc).getStart()); } } - } - return false; - } - Core2.someSignatureUsage = someSignatureUsage; - function getPossibleSymbolReferenceNodes(sourceFile, symbolName2, container = sourceFile) { - return getPossibleSymbolReferencePositions(sourceFile, symbolName2, container).map((pos) => getTouchingPropertyName(sourceFile, pos)); - } - function getPossibleSymbolReferencePositions(sourceFile, symbolName2, container = sourceFile) { - const positions = []; - if (!symbolName2 || !symbolName2.length) { - return positions; - } - const text = sourceFile.text; - const sourceLength = text.length; - const symbolNameLength = symbolName2.length; - let position = text.indexOf(symbolName2, container.pos); - while (position >= 0) { - if (position > container.end) - break; - const endPosition = position + symbolNameLength; - if ((position === 0 || !isIdentifierPart(text.charCodeAt(position - 1), 99 /* Latest */)) && (endPosition === sourceLength || !isIdentifierPart(text.charCodeAt(endPosition), 99 /* Latest */))) { - positions.push(position); + pushSelectionRange(start, end); + if (isStringLiteral(node) || isTemplateLiteral(node)) { + pushSelectionRange(start + 1, end - 1); } - position = text.indexOf(symbolName2, position + symbolNameLength + 1); + parentNode = node; + break; } - return positions; - } - function getLabelReferencesInNode(container, targetLabel) { - const sourceFile = container.getSourceFile(); - const labelName = targetLabel.text; - const references = mapDefined(getPossibleSymbolReferenceNodes(sourceFile, labelName, container), (node) => ( - // Only pick labels that are either the target label, or have a target that is the target label - node === targetLabel || isJumpStatementTarget(node) && getTargetLabel(node, labelName) === targetLabel ? nodeEntry(node) : void 0 - )); - return [{ definition: { type: 1 /* Label */, node: targetLabel }, references }]; - } - function isValidReferencePosition(node, searchSymbolName) { - switch (node.kind) { - case 81 /* PrivateIdentifier */: - if (isJSDocMemberName(node.parent)) { - return true; - } - case 80 /* Identifier */: - return node.text.length === searchSymbolName.length; - case 15 /* NoSubstitutionTemplateLiteral */: - case 11 /* StringLiteral */: { - const str = node; - return (isLiteralNameOfPropertyDeclarationOrIndexAccess(str) || isNameOfModuleDeclaration(node) || isExpressionOfExternalModuleImportEqualsDeclaration(node) || isCallExpression(node.parent) && isBindableObjectDefinePropertyCall(node.parent) && node.parent.arguments[1] === node) && str.text.length === searchSymbolName.length; - } - case 9 /* NumericLiteral */: - return isLiteralNameOfPropertyDeclarationOrIndexAccess(node) && node.text.length === searchSymbolName.length; - case 90 /* DefaultKeyword */: - return "default".length === searchSymbolName.length; - default: - return false; + if (i === children.length - 1) { + break outer; } } - function getAllReferencesForImportMeta(sourceFiles, cancellationToken) { - const references = flatMap(sourceFiles, (sourceFile) => { - cancellationToken.throwIfCancellationRequested(); - return mapDefined(getPossibleSymbolReferenceNodes(sourceFile, "meta", sourceFile), (node) => { - const parent2 = node.parent; - if (isImportMeta(parent2)) { - return nodeEntry(parent2); - } - }); - }); - return references.length ? [{ definition: { type: 2 /* Keyword */, node: references[0].node }, references }] : void 0; - } - function getAllReferencesForKeyword(sourceFiles, keywordKind, cancellationToken, filter2) { - const references = flatMap(sourceFiles, (sourceFile) => { - cancellationToken.throwIfCancellationRequested(); - return mapDefined(getPossibleSymbolReferenceNodes(sourceFile, tokenToString(keywordKind), sourceFile), (referenceLocation) => { - if (referenceLocation.kind === keywordKind && (!filter2 || filter2(referenceLocation))) { - return nodeEntry(referenceLocation); - } - }); - }); - return references.length ? [{ definition: { type: 2 /* Keyword */, node: references[0].node }, references }] : void 0; + } + return selectionRange; + function pushSelectionRange(start, end) { + if (start !== end) { + const textSpan = createTextSpanFromBounds(start, end); + if (!selectionRange || // Skip ranges that are identical to the parent + !textSpansEqual(textSpan, selectionRange.textSpan) && // Skip ranges that don't contain the original position + textSpanIntersectsWithPosition(textSpan, pos)) { + selectionRange = { textSpan, ...selectionRange && { parent: selectionRange } }; } - function getReferencesInSourceFile(sourceFile, search, state, addReferencesHere = true) { - state.cancellationToken.throwIfCancellationRequested(); - return getReferencesInContainer(sourceFile, sourceFile, search, state, addReferencesHere); + } + } + function pushSelectionCommentRange(start, end) { + pushSelectionRange(start, end); + let pos2 = start; + while (sourceFile.text.charCodeAt(pos2) === 47 /* slash */) { + pos2++; + } + pushSelectionRange(pos2, end); + } + } + function positionShouldSnapToNode(sourceFile, pos, node) { + Debug.assert(node.pos <= pos); + if (pos < node.end) { + return true; + } + const nodeEnd = node.getEnd(); + if (nodeEnd === pos) { + return getTouchingPropertyName(sourceFile, pos).pos < node.end; + } + return false; + } + function getSelectionChildren(node) { + var _a; + if (isSourceFile(node)) { + return groupChildren(node.getChildAt(0).getChildren(), isImport2); + } + if (isMappedTypeNode(node)) { + const [openBraceToken, ...children] = node.getChildren(); + const closeBraceToken = Debug.checkDefined(children.pop()); + Debug.assertEqual(openBraceToken.kind, 19 /* OpenBraceToken */); + Debug.assertEqual(closeBraceToken.kind, 20 /* CloseBraceToken */); + const groupedWithPlusMinusTokens = groupChildren(children, (child) => child === node.readonlyToken || child.kind === 148 /* ReadonlyKeyword */ || child === node.questionToken || child.kind === 58 /* QuestionToken */); + const groupedWithBrackets = groupChildren(groupedWithPlusMinusTokens, ({ kind }) => kind === 23 /* OpenBracketToken */ || kind === 168 /* TypeParameter */ || kind === 24 /* CloseBracketToken */); + return [ + openBraceToken, + // Pivot on `:` + createSyntaxList2(splitChildren(groupedWithBrackets, ({ kind }) => kind === 59 /* ColonToken */)), + closeBraceToken + ]; + } + if (isPropertySignature(node)) { + const children = groupChildren(node.getChildren(), (child) => child === node.name || contains(node.modifiers, child)); + const firstJSDocChild = ((_a = children[0]) == null ? void 0 : _a.kind) === 327 /* JSDoc */ ? children[0] : void 0; + const withJSDocSeparated = firstJSDocChild ? children.slice(1) : children; + const splittedChildren = splitChildren(withJSDocSeparated, ({ kind }) => kind === 59 /* ColonToken */); + return firstJSDocChild ? [firstJSDocChild, createSyntaxList2(splittedChildren)] : splittedChildren; + } + if (isParameter(node)) { + const groupedDotDotDotAndName = groupChildren(node.getChildren(), (child) => child === node.dotDotDotToken || child === node.name); + const groupedWithQuestionToken = groupChildren(groupedDotDotDotAndName, (child) => child === groupedDotDotDotAndName[0] || child === node.questionToken); + return splitChildren(groupedWithQuestionToken, ({ kind }) => kind === 64 /* EqualsToken */); + } + if (isBindingElement(node)) { + return splitChildren(node.getChildren(), ({ kind }) => kind === 64 /* EqualsToken */); + } + return node.getChildren(); + } + function groupChildren(children, groupOn) { + const result = []; + let group2; + for (const child of children) { + if (groupOn(child)) { + group2 = group2 || []; + group2.push(child); + } else { + if (group2) { + result.push(createSyntaxList2(group2)); + group2 = void 0; } - function getReferencesInContainer(container, sourceFile, search, state, addReferencesHere) { - if (!state.markSearchedSymbols(sourceFile, search.allSearchSymbols)) { - return; + result.push(child); + } + } + if (group2) { + result.push(createSyntaxList2(group2)); + } + return result; + } + function splitChildren(children, pivotOn, separateTrailingSemicolon = true) { + if (children.length < 2) { + return children; + } + const splitTokenIndex = findIndex(children, pivotOn); + if (splitTokenIndex === -1) { + return children; + } + const leftChildren = children.slice(0, splitTokenIndex); + const splitToken = children[splitTokenIndex]; + const lastToken = last(children); + const separateLastToken = separateTrailingSemicolon && lastToken.kind === 27 /* SemicolonToken */; + const rightChildren = children.slice(splitTokenIndex + 1, separateLastToken ? children.length - 1 : void 0); + const result = compact([ + leftChildren.length ? createSyntaxList2(leftChildren) : void 0, + splitToken, + rightChildren.length ? createSyntaxList2(rightChildren) : void 0 + ]); + return separateLastToken ? result.concat(lastToken) : result; + } + function createSyntaxList2(children) { + Debug.assertGreaterThanOrEqual(children.length, 1); + return setTextRangePosEnd(parseNodeFactory.createSyntaxList(children), children[0].pos, last(children).end); + } + function isListOpener(token) { + const kind = token && token.kind; + return kind === 19 /* OpenBraceToken */ || kind === 23 /* OpenBracketToken */ || kind === 21 /* OpenParenToken */ || kind === 286 /* JsxOpeningElement */; + } + function isListCloser(token) { + const kind = token && token.kind; + return kind === 20 /* CloseBraceToken */ || kind === 24 /* CloseBracketToken */ || kind === 22 /* CloseParenToken */ || kind === 287 /* JsxClosingElement */; + } + function getEndPos(sourceFile, node) { + switch (node.kind) { + case 348 /* JSDocParameterTag */: + case 345 /* JSDocCallbackTag */: + case 355 /* JSDocPropertyTag */: + case 353 /* JSDocTypedefTag */: + case 350 /* JSDocThisTag */: + return sourceFile.getLineEndOfPosition(node.getStart()); + default: + return node.getEnd(); + } + } + var isImport2; + var init_smartSelection = __esm({ + "src/services/smartSelection.ts"() { + "use strict"; + init_ts4(); + isImport2 = or(isImportDeclaration, isImportEqualsDeclaration); + } + }); + + // src/services/_namespaces/ts.SmartSelectionRange.ts + var ts_SmartSelectionRange_exports = {}; + __export(ts_SmartSelectionRange_exports, { + getSmartSelectionRange: () => getSmartSelectionRange + }); + var init_ts_SmartSelectionRange = __esm({ + "src/services/_namespaces/ts.SmartSelectionRange.ts"() { + "use strict"; + init_smartSelection(); + } + }); + + // src/services/symbolDisplay.ts + function getSymbolKind(typeChecker, symbol, location) { + const result = getSymbolKindOfConstructorPropertyMethodAccessorFunctionOrVar(typeChecker, symbol, location); + if (result !== "" /* unknown */) { + return result; + } + const flags = getCombinedLocalAndExportSymbolFlags(symbol); + if (flags & 32 /* Class */) { + return getDeclarationOfKind(symbol, 231 /* ClassExpression */) ? "local class" /* localClassElement */ : "class" /* classElement */; + } + if (flags & 384 /* Enum */) + return "enum" /* enumElement */; + if (flags & 524288 /* TypeAlias */) + return "type" /* typeElement */; + if (flags & 64 /* Interface */) + return "interface" /* interfaceElement */; + if (flags & 262144 /* TypeParameter */) + return "type parameter" /* typeParameterElement */; + if (flags & 8 /* EnumMember */) + return "enum member" /* enumMemberElement */; + if (flags & 2097152 /* Alias */) + return "alias" /* alias */; + if (flags & 1536 /* Module */) + return "module" /* moduleElement */; + return result; + } + function getSymbolKindOfConstructorPropertyMethodAccessorFunctionOrVar(typeChecker, symbol, location) { + const roots = typeChecker.getRootSymbols(symbol); + if (roots.length === 1 && first(roots).flags & 8192 /* Method */ && typeChecker.getTypeOfSymbolAtLocation(symbol, location).getNonNullableType().getCallSignatures().length !== 0) { + return "method" /* memberFunctionElement */; + } + if (typeChecker.isUndefinedSymbol(symbol)) { + return "var" /* variableElement */; + } + if (typeChecker.isArgumentsSymbol(symbol)) { + return "local var" /* localVariableElement */; + } + if (location.kind === 110 /* ThisKeyword */ && isExpression(location) || isThisInTypeQuery(location)) { + return "parameter" /* parameterElement */; + } + const flags = getCombinedLocalAndExportSymbolFlags(symbol); + if (flags & 3 /* Variable */) { + if (isFirstDeclarationOfSymbolParameter(symbol)) { + return "parameter" /* parameterElement */; + } else if (symbol.valueDeclaration && isVarConst(symbol.valueDeclaration)) { + return "const" /* constElement */; + } else if (symbol.valueDeclaration && isVarUsing(symbol.valueDeclaration)) { + return "using" /* variableUsingElement */; + } else if (symbol.valueDeclaration && isVarAwaitUsing(symbol.valueDeclaration)) { + return "await using" /* variableAwaitUsingElement */; + } else if (forEach(symbol.declarations, isLet)) { + return "let" /* letElement */; + } + return isLocalVariableOrFunction(symbol) ? "local var" /* localVariableElement */ : "var" /* variableElement */; + } + if (flags & 16 /* Function */) + return isLocalVariableOrFunction(symbol) ? "local function" /* localFunctionElement */ : "function" /* functionElement */; + if (flags & 32768 /* GetAccessor */) + return "getter" /* memberGetAccessorElement */; + if (flags & 65536 /* SetAccessor */) + return "setter" /* memberSetAccessorElement */; + if (flags & 8192 /* Method */) + return "method" /* memberFunctionElement */; + if (flags & 16384 /* Constructor */) + return "constructor" /* constructorImplementationElement */; + if (flags & 131072 /* Signature */) + return "index" /* indexSignatureElement */; + if (flags & 4 /* Property */) { + if (flags & 33554432 /* Transient */ && symbol.links.checkFlags & 6 /* Synthetic */) { + const unionPropertyKind = forEach(typeChecker.getRootSymbols(symbol), (rootSymbol) => { + const rootSymbolFlags = rootSymbol.getFlags(); + if (rootSymbolFlags & (98308 /* PropertyOrAccessor */ | 3 /* Variable */)) { + return "property" /* memberVariableElement */; } - for (const position of getPossibleSymbolReferencePositions(sourceFile, search.text, container)) { - getReferencesAtLocation(sourceFile, position, search, state, addReferencesHere); + }); + if (!unionPropertyKind) { + const typeOfUnionProperty = typeChecker.getTypeOfSymbolAtLocation(symbol, location); + if (typeOfUnionProperty.getCallSignatures().length) { + return "method" /* memberFunctionElement */; } + return "property" /* memberVariableElement */; } - function hasMatchingMeaning(referenceLocation, state) { - return !!(getMeaningFromLocation(referenceLocation) & state.searchMeaning); - } - function getReferencesAtLocation(sourceFile, position, search, state, addReferencesHere) { - const referenceLocation = getTouchingPropertyName(sourceFile, position); - if (!isValidReferencePosition(referenceLocation, search.text)) { - if (!state.options.implementations && (state.options.findInStrings && isInString(sourceFile, position) || state.options.findInComments && isInNonReferenceComment(sourceFile, position))) { - state.addStringOrCommentReference(sourceFile.fileName, createTextSpan(position, search.text.length)); - } - return; - } - if (!hasMatchingMeaning(referenceLocation, state)) - return; - let referenceSymbol = state.checker.getSymbolAtLocation(referenceLocation); - if (!referenceSymbol) { - return; - } - const parent2 = referenceLocation.parent; - if (isImportSpecifier(parent2) && parent2.propertyName === referenceLocation) { - return; - } - if (isExportSpecifier(parent2)) { - Debug.assert(referenceLocation.kind === 80 /* Identifier */); - getReferencesAtExportSpecifier(referenceLocation, referenceSymbol, parent2, search, state, addReferencesHere); - return; - } - const relatedSymbol = getRelatedSymbol(search, referenceSymbol, referenceLocation, state); - if (!relatedSymbol) { - getReferenceForShorthandProperty(referenceSymbol, search, state); - return; - } - switch (state.specialSearchKind) { - case 0 /* None */: - if (addReferencesHere) - addReference(referenceLocation, relatedSymbol, state); + return unionPropertyKind; + } + return "property" /* memberVariableElement */; + } + return "" /* unknown */; + } + function getNormalizedSymbolModifiers(symbol) { + if (symbol.declarations && symbol.declarations.length) { + const [declaration, ...declarations] = symbol.declarations; + const excludeFlags = length(declarations) && isDeprecatedDeclaration(declaration) && some(declarations, (d) => !isDeprecatedDeclaration(d)) ? 65536 /* Deprecated */ : 0 /* None */; + const modifiers = getNodeModifiers(declaration, excludeFlags); + if (modifiers) { + return modifiers.split(","); + } + } + return []; + } + function getSymbolModifiers(typeChecker, symbol) { + if (!symbol) { + return "" /* none */; + } + const modifiers = new Set(getNormalizedSymbolModifiers(symbol)); + if (symbol.flags & 2097152 /* Alias */) { + const resolvedSymbol = typeChecker.getAliasedSymbol(symbol); + if (resolvedSymbol !== symbol) { + forEach(getNormalizedSymbolModifiers(resolvedSymbol), (modifier) => { + modifiers.add(modifier); + }); + } + } + if (symbol.flags & 16777216 /* Optional */) { + modifiers.add("optional" /* optionalModifier */); + } + return modifiers.size > 0 ? arrayFrom(modifiers.values()).join(",") : "" /* none */; + } + function getSymbolDisplayPartsDocumentationAndSymbolKindWorker(typeChecker, symbol, sourceFile, enclosingDeclaration, location, type, semanticMeaning, alias) { + var _a; + const displayParts = []; + let documentation = []; + let tags = []; + const symbolFlags = getCombinedLocalAndExportSymbolFlags(symbol); + let symbolKind = semanticMeaning & 1 /* Value */ ? getSymbolKindOfConstructorPropertyMethodAccessorFunctionOrVar(typeChecker, symbol, location) : "" /* unknown */; + let hasAddedSymbolInfo = false; + const isThisExpression = location.kind === 110 /* ThisKeyword */ && isInExpressionContext(location) || isThisInTypeQuery(location); + let documentationFromAlias; + let tagsFromAlias; + let hasMultipleSignatures = false; + if (location.kind === 110 /* ThisKeyword */ && !isThisExpression) { + return { displayParts: [keywordPart(110 /* ThisKeyword */)], documentation: [], symbolKind: "primitive type" /* primitiveType */, tags: void 0 }; + } + if (symbolKind !== "" /* unknown */ || symbolFlags & 32 /* Class */ || symbolFlags & 2097152 /* Alias */) { + if (symbolKind === "getter" /* memberGetAccessorElement */ || symbolKind === "setter" /* memberSetAccessorElement */) { + const declaration = find(symbol.declarations, (declaration2) => declaration2.name === location); + if (declaration) { + switch (declaration.kind) { + case 177 /* GetAccessor */: + symbolKind = "getter" /* memberGetAccessorElement */; break; - case 1 /* Constructor */: - addConstructorReferences(referenceLocation, sourceFile, search, state); + case 178 /* SetAccessor */: + symbolKind = "setter" /* memberSetAccessorElement */; break; - case 2 /* Class */: - addClassStaticThisReferences(referenceLocation, search, state); + case 172 /* PropertyDeclaration */: + symbolKind = "accessor" /* memberAccessorVariableElement */; break; default: - Debug.assertNever(state.specialSearchKind); - } - if (isInJSFile(referenceLocation) && isBindingElement(referenceLocation.parent) && isVariableDeclarationInitializedToBareOrAccessedRequire(referenceLocation.parent.parent.parent)) { - referenceSymbol = referenceLocation.parent.symbol; - if (!referenceSymbol) - return; - } - getImportOrExportReferences(referenceLocation, referenceSymbol, search, state); - } - function getReferencesAtExportSpecifier(referenceLocation, referenceSymbol, exportSpecifier, search, state, addReferencesHere, alwaysGetReferences) { - Debug.assert(!alwaysGetReferences || !!state.options.providePrefixAndSuffixTextForRename, "If alwaysGetReferences is true, then prefix/suffix text must be enabled"); - const { parent: parent2, propertyName, name } = exportSpecifier; - const exportDeclaration = parent2.parent; - const localSymbol = getLocalSymbolForExportSpecifier(referenceLocation, referenceSymbol, exportSpecifier, state.checker); - if (!alwaysGetReferences && !search.includes(localSymbol)) { - return; - } - if (!propertyName) { - if (!(state.options.use === 2 /* Rename */ && name.escapedText === "default" /* Default */)) { - addRef(); - } - } else if (referenceLocation === propertyName) { - if (!exportDeclaration.moduleSpecifier) { - addRef(); - } - if (addReferencesHere && state.options.use !== 2 /* Rename */ && state.markSeenReExportRHS(name)) { - addReference(name, Debug.checkDefined(exportSpecifier.symbol), state); - } - } else { - if (state.markSeenReExportRHS(referenceLocation)) { - addRef(); - } - } - if (!isForRenameWithPrefixAndSuffixText(state.options) || alwaysGetReferences) { - const isDefaultExport = referenceLocation.escapedText === "default" || exportSpecifier.name.escapedText === "default"; - const exportKind = isDefaultExport ? 1 /* Default */ : 0 /* Named */; - const exportSymbol = Debug.checkDefined(exportSpecifier.symbol); - const exportInfo = getExportInfo(exportSymbol, exportKind, state.checker); - if (exportInfo) { - searchForImportsOfExport(referenceLocation, exportSymbol, exportInfo, state); - } - } - if (search.comingFrom !== 1 /* Export */ && exportDeclaration.moduleSpecifier && !propertyName && !isForRenameWithPrefixAndSuffixText(state.options)) { - const imported = state.checker.getExportSpecifierLocalTargetSymbol(exportSpecifier); - if (imported) - searchForImportedSymbol(imported, state); - } - function addRef() { - if (addReferencesHere) - addReference(referenceLocation, localSymbol, state); - } - } - function getLocalSymbolForExportSpecifier(referenceLocation, referenceSymbol, exportSpecifier, checker) { - return isExportSpecifierAlias(referenceLocation, exportSpecifier) && checker.getExportSpecifierLocalTargetSymbol(exportSpecifier) || referenceSymbol; - } - function isExportSpecifierAlias(referenceLocation, exportSpecifier) { - const { parent: parent2, propertyName, name } = exportSpecifier; - Debug.assert(propertyName === referenceLocation || name === referenceLocation); - if (propertyName) { - return propertyName === referenceLocation; - } else { - return !parent2.parent.moduleSpecifier; - } - } - function getImportOrExportReferences(referenceLocation, referenceSymbol, search, state) { - const importOrExport = getImportOrExportSymbol(referenceLocation, referenceSymbol, state.checker, search.comingFrom === 1 /* Export */); - if (!importOrExport) - return; - const { symbol } = importOrExport; - if (importOrExport.kind === 0 /* Import */) { - if (!isForRenameWithPrefixAndSuffixText(state.options)) { - searchForImportedSymbol(symbol, state); - } - } else { - searchForImportsOfExport(referenceLocation, symbol, importOrExport.exportInfo, state); - } - } - function getReferenceForShorthandProperty({ flags, valueDeclaration }, search, state) { - const shorthandValueSymbol = state.checker.getShorthandAssignmentValueSymbol(valueDeclaration); - const name = valueDeclaration && getNameOfDeclaration(valueDeclaration); - if (!(flags & 33554432 /* Transient */) && name && search.includes(shorthandValueSymbol)) { - addReference(name, shorthandValueSymbol, state); - } - } - function addReference(referenceLocation, relatedSymbol, state) { - const { kind, symbol } = "kind" in relatedSymbol ? relatedSymbol : { kind: void 0, symbol: relatedSymbol }; - if (state.options.use === 2 /* Rename */ && referenceLocation.kind === 90 /* DefaultKeyword */) { - return; - } - const addRef = state.referenceAdder(symbol); - if (state.options.implementations) { - addImplementationReferences(referenceLocation, addRef, state); - } else { - addRef(referenceLocation, kind); - } - } - function addConstructorReferences(referenceLocation, sourceFile, search, state) { - if (isNewExpressionTarget(referenceLocation)) { - addReference(referenceLocation, search.symbol, state); - } - const pusher = () => state.referenceAdder(search.symbol); - if (isClassLike(referenceLocation.parent)) { - Debug.assert(referenceLocation.kind === 90 /* DefaultKeyword */ || referenceLocation.parent.name === referenceLocation); - findOwnConstructorReferences(search.symbol, sourceFile, pusher()); - } else { - const classExtending = tryGetClassByExtendingIdentifier(referenceLocation); - if (classExtending) { - findSuperConstructorAccesses(classExtending, pusher()); - findInheritedConstructorReferences(classExtending, state); - } - } - } - function addClassStaticThisReferences(referenceLocation, search, state) { - addReference(referenceLocation, search.symbol, state); - const classLike = referenceLocation.parent; - if (state.options.use === 2 /* Rename */ || !isClassLike(classLike)) - return; - Debug.assert(classLike.name === referenceLocation); - const addRef = state.referenceAdder(search.symbol); - for (const member of classLike.members) { - if (!(isMethodOrAccessor(member) && isStatic(member))) { - continue; - } - if (member.body) { - member.body.forEachChild(function cb(node) { - if (node.kind === 110 /* ThisKeyword */) { - addRef(node); - } else if (!isFunctionLike(node) && !isClassLike(node)) { - node.forEachChild(cb); - } - }); - } - } - } - function findOwnConstructorReferences(classSymbol, sourceFile, addNode) { - const constructorSymbol = getClassConstructorSymbol(classSymbol); - if (constructorSymbol && constructorSymbol.declarations) { - for (const decl of constructorSymbol.declarations) { - const ctrKeyword = findChildOfKind(decl, 137 /* ConstructorKeyword */, sourceFile); - Debug.assert(decl.kind === 175 /* Constructor */ && !!ctrKeyword); - addNode(ctrKeyword); - } - } - if (classSymbol.exports) { - classSymbol.exports.forEach((member) => { - const decl = member.valueDeclaration; - if (decl && decl.kind === 173 /* MethodDeclaration */) { - const body = decl.body; - if (body) { - forEachDescendantOfKind(body, 110 /* ThisKeyword */, (thisKeyword) => { - if (isNewExpressionTarget(thisKeyword)) { - addNode(thisKeyword); - } - }); - } - } - }); - } - } - function getClassConstructorSymbol(classSymbol) { - return classSymbol.members && classSymbol.members.get("__constructor" /* Constructor */); - } - function findSuperConstructorAccesses(classDeclaration, addNode) { - const constructor = getClassConstructorSymbol(classDeclaration.symbol); - if (!(constructor && constructor.declarations)) { - return; - } - for (const decl of constructor.declarations) { - Debug.assert(decl.kind === 175 /* Constructor */); - const body = decl.body; - if (body) { - forEachDescendantOfKind(body, 108 /* SuperKeyword */, (node) => { - if (isCallExpressionTarget(node)) { - addNode(node); - } - }); - } + Debug.assertNever(declaration); } + } else { + symbolKind = "property" /* memberVariableElement */; } - function hasOwnConstructor(classDeclaration) { - return !!getClassConstructorSymbol(classDeclaration.symbol); + } + let signature; + type ?? (type = isThisExpression ? typeChecker.getTypeAtLocation(location) : typeChecker.getTypeOfSymbolAtLocation(symbol, location)); + if (location.parent && location.parent.kind === 211 /* PropertyAccessExpression */) { + const right = location.parent.name; + if (right === location || right && right.getFullWidth() === 0) { + location = location.parent; } - function findInheritedConstructorReferences(classDeclaration, state) { - if (hasOwnConstructor(classDeclaration)) - return; - const classSymbol = classDeclaration.symbol; - const search = state.createSearch( - /*location*/ - void 0, - classSymbol, - /*comingFrom*/ - void 0 - ); - getReferencesInContainerOrFiles(classSymbol, state, search); + } + let callExpressionLike; + if (isCallOrNewExpression(location)) { + callExpressionLike = location; + } else if (isCallExpressionTarget(location) || isNewExpressionTarget(location)) { + callExpressionLike = location.parent; + } else if (location.parent && (isJsxOpeningLikeElement(location.parent) || isTaggedTemplateExpression(location.parent)) && isFunctionLike(symbol.valueDeclaration)) { + callExpressionLike = location.parent; + } + if (callExpressionLike) { + signature = typeChecker.getResolvedSignature(callExpressionLike); + const useConstructSignatures = callExpressionLike.kind === 214 /* NewExpression */ || isCallExpression(callExpressionLike) && callExpressionLike.expression.kind === 108 /* SuperKeyword */; + const allSignatures = useConstructSignatures ? type.getConstructSignatures() : type.getCallSignatures(); + if (signature && !contains(allSignatures, signature.target) && !contains(allSignatures, signature)) { + signature = allSignatures.length ? allSignatures[0] : void 0; } - function addImplementationReferences(refNode, addReference2, state) { - if (isDeclarationName(refNode) && isImplementation(refNode.parent)) { - addReference2(refNode); - return; - } - if (refNode.kind !== 80 /* Identifier */) { - return; - } - if (refNode.parent.kind === 303 /* ShorthandPropertyAssignment */) { - getReferenceEntriesForShorthandPropertyAssignment(refNode, state.checker, addReference2); - } - const containingClass = getContainingClassIfInHeritageClause(refNode); - if (containingClass) { - addReference2(containingClass); - return; - } - const typeNode = findAncestor(refNode, (a) => !isQualifiedName(a.parent) && !isTypeNode(a.parent) && !isTypeElement(a.parent)); - const typeHavingNode = typeNode.parent; - if (hasType(typeHavingNode) && typeHavingNode.type === typeNode && state.markSeenContainingTypeReference(typeHavingNode)) { - if (hasInitializer(typeHavingNode)) { - addIfImplementation(typeHavingNode.initializer); - } else if (isFunctionLike(typeHavingNode) && typeHavingNode.body) { - const body = typeHavingNode.body; - if (body.kind === 240 /* Block */) { - forEachReturnStatement(body, (returnStatement) => { - if (returnStatement.expression) - addIfImplementation(returnStatement.expression); - }); - } else { - addIfImplementation(body); + if (signature) { + if (useConstructSignatures && symbolFlags & 32 /* Class */) { + symbolKind = "constructor" /* constructorImplementationElement */; + addPrefixForAnyFunctionOrVar(type.symbol, symbolKind); + } else if (symbolFlags & 2097152 /* Alias */) { + symbolKind = "alias" /* alias */; + pushSymbolKind(symbolKind); + displayParts.push(spacePart()); + if (useConstructSignatures) { + if (signature.flags & 4 /* Abstract */) { + displayParts.push(keywordPart(128 /* AbstractKeyword */)); + displayParts.push(spacePart()); } - } else if (isAssertionExpression(typeHavingNode)) { - addIfImplementation(typeHavingNode.expression); + displayParts.push(keywordPart(105 /* NewKeyword */)); + displayParts.push(spacePart()); } + addFullSymbolName(symbol); + } else { + addPrefixForAnyFunctionOrVar(symbol, symbolKind); } - function addIfImplementation(e) { - if (isImplementationExpression(e)) - addReference2(e); - } - } - function getContainingClassIfInHeritageClause(node) { - return isIdentifier(node) || isPropertyAccessExpression(node) ? getContainingClassIfInHeritageClause(node.parent) : isExpressionWithTypeArguments(node) ? tryCast(node.parent.parent, isClassLike) : void 0; - } - function isImplementationExpression(node) { - switch (node.kind) { - case 216 /* ParenthesizedExpression */: - return isImplementationExpression(node.expression); - case 218 /* ArrowFunction */: - case 217 /* FunctionExpression */: - case 209 /* ObjectLiteralExpression */: - case 230 /* ClassExpression */: - case 208 /* ArrayLiteralExpression */: - return true; - default: - return false; - } - } - function explicitlyInheritsFrom(symbol, parent2, cachedResults, checker) { - if (symbol === parent2) { - return true; - } - const key = getSymbolId(symbol) + "," + getSymbolId(parent2); - const cached = cachedResults.get(key); - if (cached !== void 0) { - return cached; - } - cachedResults.set(key, false); - const inherits = !!symbol.declarations && symbol.declarations.some((declaration) => getAllSuperTypeNodes(declaration).some((typeReference) => { - const type = checker.getTypeAtLocation(typeReference); - return !!type && !!type.symbol && explicitlyInheritsFrom(type.symbol, parent2, cachedResults, checker); - })); - cachedResults.set(key, inherits); - return inherits; - } - function getReferencesForSuperKeyword(superKeyword) { - let searchSpaceNode = getSuperContainer( - superKeyword, - /*stopOnFunctions*/ - false - ); - if (!searchSpaceNode) { - return void 0; - } - let staticFlag = 32 /* Static */; - switch (searchSpaceNode.kind) { - case 171 /* PropertyDeclaration */: - case 170 /* PropertySignature */: - case 173 /* MethodDeclaration */: - case 172 /* MethodSignature */: - case 175 /* Constructor */: - case 176 /* GetAccessor */: - case 177 /* SetAccessor */: - staticFlag &= getSyntacticModifierFlags(searchSpaceNode); - searchSpaceNode = searchSpaceNode.parent; - break; - default: - return void 0; - } - const sourceFile = searchSpaceNode.getSourceFile(); - const references = mapDefined(getPossibleSymbolReferenceNodes(sourceFile, "super", searchSpaceNode), (node) => { - if (node.kind !== 108 /* SuperKeyword */) { - return; - } - const container = getSuperContainer( - node, - /*stopOnFunctions*/ - false - ); - return container && isStatic(container) === !!staticFlag && container.parent.symbol === searchSpaceNode.symbol ? nodeEntry(node) : void 0; - }); - return [{ definition: { type: 0 /* Symbol */, symbol: searchSpaceNode.symbol }, references }]; - } - function isParameterName(node) { - return node.kind === 80 /* Identifier */ && node.parent.kind === 168 /* Parameter */ && node.parent.name === node; - } - function getReferencesForThisKeyword(thisOrSuperKeyword, sourceFiles, cancellationToken) { - let searchSpaceNode = getThisContainer( - thisOrSuperKeyword, - /*includeArrowFunctions*/ - false, - /*includeClassComputedPropertyName*/ - false - ); - let staticFlag = 32 /* Static */; - switch (searchSpaceNode.kind) { - case 173 /* MethodDeclaration */: - case 172 /* MethodSignature */: - if (isObjectLiteralMethod(searchSpaceNode)) { - staticFlag &= getSyntacticModifierFlags(searchSpaceNode); - searchSpaceNode = searchSpaceNode.parent; - break; + switch (symbolKind) { + case "JSX attribute" /* jsxAttribute */: + case "property" /* memberVariableElement */: + case "var" /* variableElement */: + case "const" /* constElement */: + case "let" /* letElement */: + case "parameter" /* parameterElement */: + case "local var" /* localVariableElement */: + displayParts.push(punctuationPart(59 /* ColonToken */)); + displayParts.push(spacePart()); + if (!(getObjectFlags(type) & 16 /* Anonymous */) && type.symbol) { + addRange(displayParts, symbolToDisplayParts( + typeChecker, + type.symbol, + enclosingDeclaration, + /*meaning*/ + void 0, + 4 /* AllowAnyNodeKind */ | 1 /* WriteTypeParametersOrArguments */ + )); + displayParts.push(lineBreakPart()); } - case 171 /* PropertyDeclaration */: - case 170 /* PropertySignature */: - case 175 /* Constructor */: - case 176 /* GetAccessor */: - case 177 /* SetAccessor */: - staticFlag &= getSyntacticModifierFlags(searchSpaceNode); - searchSpaceNode = searchSpaceNode.parent; - break; - case 311 /* SourceFile */: - if (isExternalModule(searchSpaceNode) || isParameterName(thisOrSuperKeyword)) { - return void 0; + if (useConstructSignatures) { + if (signature.flags & 4 /* Abstract */) { + displayParts.push(keywordPart(128 /* AbstractKeyword */)); + displayParts.push(spacePart()); + } + displayParts.push(keywordPart(105 /* NewKeyword */)); + displayParts.push(spacePart()); } - case 261 /* FunctionDeclaration */: - case 217 /* FunctionExpression */: + addSignatureDisplayParts(signature, allSignatures, 262144 /* WriteArrowStyleSignature */); break; default: - return void 0; + addSignatureDisplayParts(signature, allSignatures); } - const references = flatMap(searchSpaceNode.kind === 311 /* SourceFile */ ? sourceFiles : [searchSpaceNode.getSourceFile()], (sourceFile) => { - cancellationToken.throwIfCancellationRequested(); - return getPossibleSymbolReferenceNodes(sourceFile, "this", isSourceFile(searchSpaceNode) ? sourceFile : searchSpaceNode).filter((node) => { - if (!isThis(node)) { - return false; - } - const container = getThisContainer( - node, - /*includeArrowFunctions*/ - false, - /*includeClassComputedPropertyName*/ - false - ); - if (!canHaveSymbol(container)) - return false; - switch (searchSpaceNode.kind) { - case 217 /* FunctionExpression */: - case 261 /* FunctionDeclaration */: - return searchSpaceNode.symbol === container.symbol; - case 173 /* MethodDeclaration */: - case 172 /* MethodSignature */: - return isObjectLiteralMethod(searchSpaceNode) && searchSpaceNode.symbol === container.symbol; - case 230 /* ClassExpression */: - case 262 /* ClassDeclaration */: - case 209 /* ObjectLiteralExpression */: - return container.parent && canHaveSymbol(container.parent) && searchSpaceNode.symbol === container.parent.symbol && isStatic(container) === !!staticFlag; - case 311 /* SourceFile */: - return container.kind === 311 /* SourceFile */ && !isExternalModule(container) && !isParameterName(node); - } - }); - }).map((n) => nodeEntry(n)); - const thisParameter = firstDefined(references, (r) => isParameter(r.node.parent) ? r.node : void 0); - return [{ - definition: { type: 3 /* This */, node: thisParameter || thisOrSuperKeyword }, - references - }]; - } - function getReferencesForStringLiteral(node, sourceFiles, checker, cancellationToken) { - const type = getContextualTypeFromParentOrAncestorTypeNode(node, checker); - const references = flatMap(sourceFiles, (sourceFile) => { - cancellationToken.throwIfCancellationRequested(); - return mapDefined(getPossibleSymbolReferenceNodes(sourceFile, node.text), (ref) => { - if (isStringLiteralLike(ref) && ref.text === node.text) { - if (type) { - const refType = getContextualTypeFromParentOrAncestorTypeNode(ref, checker); - if (type !== checker.getStringType() && type === refType) { - return nodeEntry(ref, 2 /* StringLiteral */); - } - } else { - return isNoSubstitutionTemplateLiteral(ref) && !rangeIsOnSingleLine(ref, sourceFile) ? void 0 : nodeEntry(ref, 2 /* StringLiteral */); - } - } - }); - }); - return [{ - definition: { type: 4 /* String */, node }, - references - }]; - } - function populateSearchSymbolSet(symbol, location, checker, isForRename, providePrefixAndSuffixText, implementations) { - const result = []; - forEachRelatedSymbol( - symbol, - location, - checker, - isForRename, - !(isForRename && providePrefixAndSuffixText), - (sym, root, base) => { - if (base) { - if (isStaticSymbol(symbol) !== isStaticSymbol(base)) { - base = void 0; - } - } - result.push(base || root || sym); - }, - // when try to find implementation, implementations is true, and not allowed to find base class - /*allowBaseTypes*/ - () => !implementations - ); - return result; + hasAddedSymbolInfo = true; + hasMultipleSignatures = allSignatures.length > 1; } - function forEachRelatedSymbol(symbol, location, checker, isForRenamePopulateSearchSymbolSet, onlyIncludeBindingElementAtReferenceLocation, cbSymbol, allowBaseTypes) { - const containingObjectLiteralElement = getContainingObjectLiteralElement(location); - if (containingObjectLiteralElement) { - const shorthandValueSymbol = checker.getShorthandAssignmentValueSymbol(location.parent); - if (shorthandValueSymbol && isForRenamePopulateSearchSymbolSet) { - return cbSymbol( - shorthandValueSymbol, - /*rootSymbol*/ - void 0, - /*baseSymbol*/ - void 0, - 3 /* SearchedLocalFoundProperty */ - ); - } - const contextualType = checker.getContextualType(containingObjectLiteralElement.parent); - const res2 = contextualType && firstDefined( - getPropertySymbolsFromContextualType( - containingObjectLiteralElement, - checker, - contextualType, - /*unionSymbolOk*/ - true - ), - (sym) => fromRoot(sym, 4 /* SearchedPropertyFoundLocal */) - ); - if (res2) - return res2; - const propertySymbol = getPropertySymbolOfDestructuringAssignment(location, checker); - const res1 = propertySymbol && cbSymbol( - propertySymbol, - /*rootSymbol*/ - void 0, - /*baseSymbol*/ - void 0, - 4 /* SearchedPropertyFoundLocal */ - ); - if (res1) - return res1; - const res22 = shorthandValueSymbol && cbSymbol( - shorthandValueSymbol, - /*rootSymbol*/ - void 0, - /*baseSymbol*/ - void 0, - 3 /* SearchedLocalFoundProperty */ - ); - if (res22) - return res22; + } else if (isNameOfFunctionDeclaration(location) && !(symbolFlags & 98304 /* Accessor */) || // name of function declaration + location.kind === 137 /* ConstructorKeyword */ && location.parent.kind === 176 /* Constructor */) { + const functionDeclaration = location.parent; + const locationIsSymbolDeclaration = symbol.declarations && find(symbol.declarations, (declaration) => declaration === (location.kind === 137 /* ConstructorKeyword */ ? functionDeclaration.parent : functionDeclaration)); + if (locationIsSymbolDeclaration) { + const allSignatures = functionDeclaration.kind === 176 /* Constructor */ ? type.getNonNullableType().getConstructSignatures() : type.getNonNullableType().getCallSignatures(); + if (!typeChecker.isImplementationOfOverload(functionDeclaration)) { + signature = typeChecker.getSignatureFromDeclaration(functionDeclaration); + } else { + signature = allSignatures[0]; } - const aliasedSymbol = getMergedAliasedSymbolOfNamespaceExportDeclaration(location, symbol, checker); - if (aliasedSymbol) { - const res2 = cbSymbol( - aliasedSymbol, - /*rootSymbol*/ - void 0, - /*baseSymbol*/ - void 0, - 1 /* Node */ + if (functionDeclaration.kind === 176 /* Constructor */) { + symbolKind = "constructor" /* constructorImplementationElement */; + addPrefixForAnyFunctionOrVar(type.symbol, symbolKind); + } else { + addPrefixForAnyFunctionOrVar( + functionDeclaration.kind === 179 /* CallSignature */ && !(type.symbol.flags & 2048 /* TypeLiteral */ || type.symbol.flags & 4096 /* ObjectLiteral */) ? type.symbol : symbol, + symbolKind ); - if (res2) - return res2; - } - const res = fromRoot(symbol); - if (res) - return res; - if (symbol.valueDeclaration && isParameterPropertyDeclaration(symbol.valueDeclaration, symbol.valueDeclaration.parent)) { - const paramProps = checker.getSymbolsOfParameterPropertyDeclaration(cast(symbol.valueDeclaration, isParameter), symbol.name); - Debug.assert(paramProps.length === 2 && !!(paramProps[0].flags & 1 /* FunctionScopedVariable */) && !!(paramProps[1].flags & 4 /* Property */)); - return fromRoot(symbol.flags & 1 /* FunctionScopedVariable */ ? paramProps[1] : paramProps[0]); - } - const exportSpecifier = getDeclarationOfKind(symbol, 280 /* ExportSpecifier */); - if (!isForRenamePopulateSearchSymbolSet || exportSpecifier && !exportSpecifier.propertyName) { - const localSymbol = exportSpecifier && checker.getExportSpecifierLocalTargetSymbol(exportSpecifier); - if (localSymbol) { - const res2 = cbSymbol( - localSymbol, - /*rootSymbol*/ - void 0, - /*baseSymbol*/ - void 0, - 1 /* Node */ - ); - if (res2) - return res2; - } - } - if (!isForRenamePopulateSearchSymbolSet) { - let bindingElementPropertySymbol; - if (onlyIncludeBindingElementAtReferenceLocation) { - bindingElementPropertySymbol = isObjectBindingElementWithoutPropertyName(location.parent) ? getPropertySymbolFromBindingElement(checker, location.parent) : void 0; - } else { - bindingElementPropertySymbol = getPropertySymbolOfObjectBindingPatternWithoutPropertyName(symbol, checker); - } - return bindingElementPropertySymbol && fromRoot(bindingElementPropertySymbol, 4 /* SearchedPropertyFoundLocal */); } - Debug.assert(isForRenamePopulateSearchSymbolSet); - const includeOriginalSymbolOfBindingElement = onlyIncludeBindingElementAtReferenceLocation; - if (includeOriginalSymbolOfBindingElement) { - const bindingElementPropertySymbol = getPropertySymbolOfObjectBindingPatternWithoutPropertyName(symbol, checker); - return bindingElementPropertySymbol && fromRoot(bindingElementPropertySymbol, 4 /* SearchedPropertyFoundLocal */); - } - function fromRoot(sym, kind) { - return firstDefined(checker.getRootSymbols(sym), (rootSymbol) => cbSymbol( - sym, - rootSymbol, - /*baseSymbol*/ - void 0, - kind - ) || (rootSymbol.parent && rootSymbol.parent.flags & (32 /* Class */ | 64 /* Interface */) && allowBaseTypes(rootSymbol) ? getPropertySymbolsFromBaseTypes(rootSymbol.parent, rootSymbol.name, checker, (base) => cbSymbol(sym, rootSymbol, base, kind)) : void 0)); - } - function getPropertySymbolOfObjectBindingPatternWithoutPropertyName(symbol2, checker2) { - const bindingElement = getDeclarationOfKind(symbol2, 207 /* BindingElement */); - if (bindingElement && isObjectBindingElementWithoutPropertyName(bindingElement)) { - return getPropertySymbolFromBindingElement(checker2, bindingElement); - } + if (signature) { + addSignatureDisplayParts(signature, allSignatures); } + hasAddedSymbolInfo = true; + hasMultipleSignatures = allSignatures.length > 1; } - function getPropertySymbolsFromBaseTypes(symbol, propertyName, checker, cb) { - const seen = /* @__PURE__ */ new Map(); - return recur(symbol); - function recur(symbol2) { - if (!(symbol2.flags & (32 /* Class */ | 64 /* Interface */)) || !addToSeen(seen, getSymbolId(symbol2))) - return; - return firstDefined(symbol2.declarations, (declaration) => firstDefined(getAllSuperTypeNodes(declaration), (typeReference) => { - const type = checker.getTypeAtLocation(typeReference); - const propertySymbol = type && type.symbol && checker.getPropertyOfType(type, propertyName); - return type && propertySymbol && (firstDefined(checker.getRootSymbols(propertySymbol), cb) || recur(type.symbol)); - })); + } + } + if (symbolFlags & 32 /* Class */ && !hasAddedSymbolInfo && !isThisExpression) { + addAliasPrefixIfNecessary(); + if (getDeclarationOfKind(symbol, 231 /* ClassExpression */)) { + pushSymbolKind("local class" /* localClassElement */); + } else { + displayParts.push(keywordPart(86 /* ClassKeyword */)); + } + displayParts.push(spacePart()); + addFullSymbolName(symbol); + writeTypeParametersOfSymbol(symbol, sourceFile); + } + if (symbolFlags & 64 /* Interface */ && semanticMeaning & 2 /* Type */) { + prefixNextMeaning(); + displayParts.push(keywordPart(120 /* InterfaceKeyword */)); + displayParts.push(spacePart()); + addFullSymbolName(symbol); + writeTypeParametersOfSymbol(symbol, sourceFile); + } + if (symbolFlags & 524288 /* TypeAlias */ && semanticMeaning & 2 /* Type */) { + prefixNextMeaning(); + displayParts.push(keywordPart(156 /* TypeKeyword */)); + displayParts.push(spacePart()); + addFullSymbolName(symbol); + writeTypeParametersOfSymbol(symbol, sourceFile); + displayParts.push(spacePart()); + displayParts.push(operatorPart(64 /* EqualsToken */)); + displayParts.push(spacePart()); + addRange(displayParts, typeToDisplayParts(typeChecker, location.parent && isConstTypeReference(location.parent) ? typeChecker.getTypeAtLocation(location.parent) : typeChecker.getDeclaredTypeOfSymbol(symbol), enclosingDeclaration, 8388608 /* InTypeAlias */)); + } + if (symbolFlags & 384 /* Enum */) { + prefixNextMeaning(); + if (some(symbol.declarations, (d) => isEnumDeclaration(d) && isEnumConst(d))) { + displayParts.push(keywordPart(87 /* ConstKeyword */)); + displayParts.push(spacePart()); + } + displayParts.push(keywordPart(94 /* EnumKeyword */)); + displayParts.push(spacePart()); + addFullSymbolName(symbol); + } + if (symbolFlags & 1536 /* Module */ && !isThisExpression) { + prefixNextMeaning(); + const declaration = getDeclarationOfKind(symbol, 267 /* ModuleDeclaration */); + const isNamespace = declaration && declaration.name && declaration.name.kind === 80 /* Identifier */; + displayParts.push(keywordPart(isNamespace ? 145 /* NamespaceKeyword */ : 144 /* ModuleKeyword */)); + displayParts.push(spacePart()); + addFullSymbolName(symbol); + } + if (symbolFlags & 262144 /* TypeParameter */ && semanticMeaning & 2 /* Type */) { + prefixNextMeaning(); + displayParts.push(punctuationPart(21 /* OpenParenToken */)); + displayParts.push(textPart("type parameter")); + displayParts.push(punctuationPart(22 /* CloseParenToken */)); + displayParts.push(spacePart()); + addFullSymbolName(symbol); + if (symbol.parent) { + addInPrefix(); + addFullSymbolName(symbol.parent, enclosingDeclaration); + writeTypeParametersOfSymbol(symbol.parent, enclosingDeclaration); + } else { + const decl = getDeclarationOfKind(symbol, 168 /* TypeParameter */); + if (decl === void 0) + return Debug.fail(); + const declaration = decl.parent; + if (declaration) { + if (isFunctionLike(declaration)) { + addInPrefix(); + const signature = typeChecker.getSignatureFromDeclaration(declaration); + if (declaration.kind === 180 /* ConstructSignature */) { + displayParts.push(keywordPart(105 /* NewKeyword */)); + displayParts.push(spacePart()); + } else if (declaration.kind !== 179 /* CallSignature */ && declaration.name) { + addFullSymbolName(declaration.symbol); + } + addRange(displayParts, signatureToDisplayParts(typeChecker, signature, sourceFile, 32 /* WriteTypeArgumentsOfSignature */)); + } else if (isTypeAliasDeclaration(declaration)) { + addInPrefix(); + displayParts.push(keywordPart(156 /* TypeKeyword */)); + displayParts.push(spacePart()); + addFullSymbolName(declaration.symbol); + writeTypeParametersOfSymbol(declaration.symbol, sourceFile); } } - function isStaticSymbol(symbol) { - if (!symbol.valueDeclaration) - return false; - const modifierFlags = getEffectiveModifierFlags(symbol.valueDeclaration); - return !!(modifierFlags & 32 /* Static */); - } - function getRelatedSymbol(search, referenceSymbol, referenceLocation, state) { - const { checker } = state; - return forEachRelatedSymbol( - referenceSymbol, - referenceLocation, - checker, - /*isForRenamePopulateSearchSymbolSet*/ - false, - /*onlyIncludeBindingElementAtReferenceLocation*/ - state.options.use !== 2 /* Rename */ || !!state.options.providePrefixAndSuffixTextForRename, - (sym, rootSymbol, baseSymbol, kind) => { - if (baseSymbol) { - if (isStaticSymbol(referenceSymbol) !== isStaticSymbol(baseSymbol)) { - baseSymbol = void 0; - } - } - return search.includes(baseSymbol || rootSymbol || sym) ? { symbol: rootSymbol && !(getCheckFlags(sym) & 6 /* Synthetic */) ? rootSymbol : sym, kind } : void 0; - }, - /*allowBaseTypes*/ - (rootSymbol) => !(search.parents && !search.parents.some((parent2) => explicitlyInheritsFrom(rootSymbol.parent, parent2, state.inheritsFromCache, checker))) - ); + } + } + if (symbolFlags & 8 /* EnumMember */) { + symbolKind = "enum member" /* enumMemberElement */; + addPrefixForAnyFunctionOrVar(symbol, "enum member"); + const declaration = (_a = symbol.declarations) == null ? void 0 : _a[0]; + if ((declaration == null ? void 0 : declaration.kind) === 306 /* EnumMember */) { + const constantValue = typeChecker.getConstantValue(declaration); + if (constantValue !== void 0) { + displayParts.push(spacePart()); + displayParts.push(operatorPart(64 /* EqualsToken */)); + displayParts.push(spacePart()); + displayParts.push(displayPart(getTextOfConstantValue(constantValue), typeof constantValue === "number" ? 7 /* numericLiteral */ : 8 /* stringLiteral */)); } - function getIntersectingMeaningFromDeclarations(node, symbol) { - let meaning = getMeaningFromLocation(node); - const { declarations } = symbol; - if (declarations) { - let lastIterationMeaning; - do { - lastIterationMeaning = meaning; - for (const declaration of declarations) { - const declarationMeaning = getMeaningFromDeclaration(declaration); - if (declarationMeaning & meaning) { - meaning |= declarationMeaning; - } - } - } while (meaning !== lastIterationMeaning); + } + } + if (symbol.flags & 2097152 /* Alias */) { + prefixNextMeaning(); + if (!hasAddedSymbolInfo || documentation.length === 0 && tags.length === 0) { + const resolvedSymbol = typeChecker.getAliasedSymbol(symbol); + if (resolvedSymbol !== symbol && resolvedSymbol.declarations && resolvedSymbol.declarations.length > 0) { + const resolvedNode = resolvedSymbol.declarations[0]; + const declarationName = getNameOfDeclaration(resolvedNode); + if (declarationName && !hasAddedSymbolInfo) { + const isExternalModuleDeclaration = isModuleWithStringLiteralName(resolvedNode) && hasSyntacticModifier(resolvedNode, 128 /* Ambient */); + const shouldUseAliasName = symbol.name !== "default" && !isExternalModuleDeclaration; + const resolvedInfo = getSymbolDisplayPartsDocumentationAndSymbolKindWorker( + typeChecker, + resolvedSymbol, + getSourceFileOfNode(resolvedNode), + resolvedNode, + declarationName, + type, + semanticMeaning, + shouldUseAliasName ? symbol : resolvedSymbol + ); + displayParts.push(...resolvedInfo.displayParts); + displayParts.push(lineBreakPart()); + documentationFromAlias = resolvedInfo.documentation; + tagsFromAlias = resolvedInfo.tags; + } else { + documentationFromAlias = resolvedSymbol.getContextualDocumentationComment(resolvedNode, typeChecker); + tagsFromAlias = resolvedSymbol.getJsDocTags(typeChecker); } - return meaning; } - Core2.getIntersectingMeaningFromDeclarations = getIntersectingMeaningFromDeclarations; - function isImplementation(node) { - return !!(node.flags & 16777216 /* Ambient */) ? !(isInterfaceDeclaration(node) || isTypeAliasDeclaration(node)) : isVariableLike(node) ? hasInitializer(node) : isFunctionLikeDeclaration(node) ? !!node.body : isClassLike(node) || isModuleOrEnumDeclaration(node); + } + if (symbol.declarations) { + switch (symbol.declarations[0].kind) { + case 270 /* NamespaceExportDeclaration */: + displayParts.push(keywordPart(95 /* ExportKeyword */)); + displayParts.push(spacePart()); + displayParts.push(keywordPart(145 /* NamespaceKeyword */)); + break; + case 277 /* ExportAssignment */: + displayParts.push(keywordPart(95 /* ExportKeyword */)); + displayParts.push(spacePart()); + displayParts.push(keywordPart(symbol.declarations[0].isExportEquals ? 64 /* EqualsToken */ : 90 /* DefaultKeyword */)); + break; + case 281 /* ExportSpecifier */: + displayParts.push(keywordPart(95 /* ExportKeyword */)); + break; + default: + displayParts.push(keywordPart(102 /* ImportKeyword */)); } - function getReferenceEntriesForShorthandPropertyAssignment(node, checker, addReference2) { - const refSymbol = checker.getSymbolAtLocation(node); - const shorthandSymbol = checker.getShorthandAssignmentValueSymbol(refSymbol.valueDeclaration); - if (shorthandSymbol) { - for (const declaration of shorthandSymbol.getDeclarations()) { - if (getMeaningFromDeclaration(declaration) & 1 /* Value */) { - addReference2(declaration); - } + } + displayParts.push(spacePart()); + addFullSymbolName(symbol); + forEach(symbol.declarations, (declaration) => { + if (declaration.kind === 271 /* ImportEqualsDeclaration */) { + const importEqualsDeclaration = declaration; + if (isExternalModuleImportEqualsDeclaration(importEqualsDeclaration)) { + displayParts.push(spacePart()); + displayParts.push(operatorPart(64 /* EqualsToken */)); + displayParts.push(spacePart()); + displayParts.push(keywordPart(149 /* RequireKeyword */)); + displayParts.push(punctuationPart(21 /* OpenParenToken */)); + displayParts.push(displayPart(getTextOfNode(getExternalModuleImportEqualsDeclarationExpression(importEqualsDeclaration)), 8 /* stringLiteral */)); + displayParts.push(punctuationPart(22 /* CloseParenToken */)); + } else { + const internalAliasSymbol = typeChecker.getSymbolAtLocation(importEqualsDeclaration.moduleReference); + if (internalAliasSymbol) { + displayParts.push(spacePart()); + displayParts.push(operatorPart(64 /* EqualsToken */)); + displayParts.push(spacePart()); + addFullSymbolName(internalAliasSymbol, enclosingDeclaration); } } + return true; } - Core2.getReferenceEntriesForShorthandPropertyAssignment = getReferenceEntriesForShorthandPropertyAssignment; - function forEachDescendantOfKind(node, kind, action) { - forEachChild(node, (child) => { - if (child.kind === kind) { - action(child); + }); + } + if (!hasAddedSymbolInfo) { + if (symbolKind !== "" /* unknown */) { + if (type) { + if (isThisExpression) { + prefixNextMeaning(); + displayParts.push(keywordPart(110 /* ThisKeyword */)); + } else { + addPrefixForAnyFunctionOrVar(symbol, symbolKind); + } + if (symbolKind === "property" /* memberVariableElement */ || symbolKind === "accessor" /* memberAccessorVariableElement */ || symbolKind === "getter" /* memberGetAccessorElement */ || symbolKind === "setter" /* memberSetAccessorElement */ || symbolKind === "JSX attribute" /* jsxAttribute */ || symbolFlags & 3 /* Variable */ || symbolKind === "local var" /* localVariableElement */ || symbolKind === "index" /* indexSignatureElement */ || symbolKind === "using" /* variableUsingElement */ || symbolKind === "await using" /* variableAwaitUsingElement */ || isThisExpression) { + displayParts.push(punctuationPart(59 /* ColonToken */)); + displayParts.push(spacePart()); + if (type.symbol && type.symbol.flags & 262144 /* TypeParameter */ && symbolKind !== "index" /* indexSignatureElement */) { + const typeParameterParts = mapToDisplayParts((writer) => { + const param = typeChecker.typeParameterToDeclaration(type, enclosingDeclaration, symbolDisplayNodeBuilderFlags); + getPrinter().writeNode(4 /* Unspecified */, param, getSourceFileOfNode(getParseTreeNode(enclosingDeclaration)), writer); + }); + addRange(displayParts, typeParameterParts); + } else { + addRange(displayParts, typeToDisplayParts(typeChecker, type, enclosingDeclaration)); } - forEachDescendantOfKind(child, kind, action); - }); + if (isTransientSymbol(symbol) && symbol.links.target && isTransientSymbol(symbol.links.target) && symbol.links.target.links.tupleLabelDeclaration) { + const labelDecl = symbol.links.target.links.tupleLabelDeclaration; + Debug.assertNode(labelDecl.name, isIdentifier); + displayParts.push(spacePart()); + displayParts.push(punctuationPart(21 /* OpenParenToken */)); + displayParts.push(textPart(idText(labelDecl.name))); + displayParts.push(punctuationPart(22 /* CloseParenToken */)); + } + } else if (symbolFlags & 16 /* Function */ || symbolFlags & 8192 /* Method */ || symbolFlags & 16384 /* Constructor */ || symbolFlags & 131072 /* Signature */ || symbolFlags & 98304 /* Accessor */ || symbolKind === "method" /* memberFunctionElement */) { + const allSignatures = type.getNonNullableType().getCallSignatures(); + if (allSignatures.length) { + addSignatureDisplayParts(allSignatures[0], allSignatures); + hasMultipleSignatures = allSignatures.length > 1; + } + } } - function tryGetClassByExtendingIdentifier(node) { - return tryGetClassExtendingExpressionWithTypeArguments(climbPastPropertyAccess(node).parent); + } else { + symbolKind = getSymbolKind(typeChecker, symbol, location); + } + } + if (documentation.length === 0 && !hasMultipleSignatures) { + documentation = symbol.getContextualDocumentationComment(enclosingDeclaration, typeChecker); + } + if (documentation.length === 0 && symbolFlags & 4 /* Property */) { + if (symbol.parent && symbol.declarations && forEach(symbol.parent.declarations, (declaration) => declaration.kind === 312 /* SourceFile */)) { + for (const declaration of symbol.declarations) { + if (!declaration.parent || declaration.parent.kind !== 226 /* BinaryExpression */) { + continue; + } + const rhsSymbol = typeChecker.getSymbolAtLocation(declaration.parent.right); + if (!rhsSymbol) { + continue; + } + documentation = rhsSymbol.getDocumentationComment(typeChecker); + tags = rhsSymbol.getJsDocTags(typeChecker); + if (documentation.length > 0) { + break; + } } - function getParentSymbolsOfPropertyAccess(location, symbol, checker) { - const propertyAccessExpression = isRightSideOfPropertyAccess(location) ? location.parent : void 0; - const lhsType = propertyAccessExpression && checker.getTypeAtLocation(propertyAccessExpression.expression); - const res = mapDefined(lhsType && (lhsType.isUnionOrIntersection() ? lhsType.types : lhsType.symbol === symbol.parent ? void 0 : [lhsType]), (t) => t.symbol && t.symbol.flags & (32 /* Class */ | 64 /* Interface */) ? t.symbol : void 0); - return res.length === 0 ? void 0 : res; + } + } + if (documentation.length === 0 && isIdentifier(location) && symbol.valueDeclaration && isBindingElement(symbol.valueDeclaration)) { + const declaration = symbol.valueDeclaration; + const parent2 = declaration.parent; + const name = declaration.propertyName || declaration.name; + if (isIdentifier(name) && isObjectBindingPattern(parent2)) { + const propertyName = getTextOfIdentifierOrLiteral(name); + const objectType = typeChecker.getTypeAtLocation(parent2); + documentation = firstDefined(objectType.isUnion() ? objectType.types : [objectType], (t) => { + const prop = t.getProperty(propertyName); + return prop ? prop.getDocumentationComment(typeChecker) : void 0; + }) || emptyArray; + } + } + if (tags.length === 0 && !hasMultipleSignatures) { + tags = symbol.getContextualJsDocTags(enclosingDeclaration, typeChecker); + } + if (documentation.length === 0 && documentationFromAlias) { + documentation = documentationFromAlias; + } + if (tags.length === 0 && tagsFromAlias) { + tags = tagsFromAlias; + } + return { displayParts, documentation, symbolKind, tags: tags.length === 0 ? void 0 : tags }; + function getPrinter() { + return createPrinterWithRemoveComments(); + } + function prefixNextMeaning() { + if (displayParts.length) { + displayParts.push(lineBreakPart()); + } + addAliasPrefixIfNecessary(); + } + function addAliasPrefixIfNecessary() { + if (alias) { + pushSymbolKind("alias" /* alias */); + displayParts.push(spacePart()); + } + } + function addInPrefix() { + displayParts.push(spacePart()); + displayParts.push(keywordPart(103 /* InKeyword */)); + displayParts.push(spacePart()); + } + function addFullSymbolName(symbolToDisplay, enclosingDeclaration2) { + let indexInfos; + if (alias && symbolToDisplay === symbol) { + symbolToDisplay = alias; + } + if (symbolKind === "index" /* indexSignatureElement */) { + indexInfos = typeChecker.getIndexInfosOfIndexSymbol(symbolToDisplay); + } + let fullSymbolDisplayParts = []; + if (symbolToDisplay.flags & 131072 /* Signature */ && indexInfos) { + if (symbolToDisplay.parent) { + fullSymbolDisplayParts = symbolToDisplayParts(typeChecker, symbolToDisplay.parent); } - function isForRenameWithPrefixAndSuffixText(options) { - return options.use === 2 /* Rename */ && options.providePrefixAndSuffixTextForRename; + fullSymbolDisplayParts.push(punctuationPart(23 /* OpenBracketToken */)); + indexInfos.forEach((info, i) => { + fullSymbolDisplayParts.push(...typeToDisplayParts(typeChecker, info.keyType)); + if (i !== indexInfos.length - 1) { + fullSymbolDisplayParts.push(spacePart()); + fullSymbolDisplayParts.push(punctuationPart(52 /* BarToken */)); + fullSymbolDisplayParts.push(spacePart()); + } + }); + fullSymbolDisplayParts.push(punctuationPart(24 /* CloseBracketToken */)); + } else { + fullSymbolDisplayParts = symbolToDisplayParts( + typeChecker, + symbolToDisplay, + enclosingDeclaration2 || sourceFile, + /*meaning*/ + void 0, + 1 /* WriteTypeParametersOrArguments */ | 2 /* UseOnlyExternalAliasing */ | 4 /* AllowAnyNodeKind */ + ); + } + addRange(displayParts, fullSymbolDisplayParts); + if (symbol.flags & 16777216 /* Optional */) { + displayParts.push(punctuationPart(58 /* QuestionToken */)); + } + } + function addPrefixForAnyFunctionOrVar(symbol2, symbolKind2) { + prefixNextMeaning(); + if (symbolKind2) { + pushSymbolKind(symbolKind2); + if (symbol2 && !some(symbol2.declarations, (d) => isArrowFunction(d) || (isFunctionExpression(d) || isClassExpression(d)) && !d.name)) { + displayParts.push(spacePart()); + addFullSymbolName(symbol2); } - })(Core || (Core = {})); + } + } + function pushSymbolKind(symbolKind2) { + switch (symbolKind2) { + case "var" /* variableElement */: + case "function" /* functionElement */: + case "let" /* letElement */: + case "const" /* constElement */: + case "constructor" /* constructorImplementationElement */: + case "using" /* variableUsingElement */: + case "await using" /* variableAwaitUsingElement */: + displayParts.push(textOrKeywordPart(symbolKind2)); + return; + default: + displayParts.push(punctuationPart(21 /* OpenParenToken */)); + displayParts.push(textOrKeywordPart(symbolKind2)); + displayParts.push(punctuationPart(22 /* CloseParenToken */)); + return; + } + } + function addSignatureDisplayParts(signature, allSignatures, flags = 0 /* None */) { + addRange(displayParts, signatureToDisplayParts(typeChecker, signature, enclosingDeclaration, flags | 32 /* WriteTypeArgumentsOfSignature */)); + if (allSignatures.length > 1) { + displayParts.push(spacePart()); + displayParts.push(punctuationPart(21 /* OpenParenToken */)); + displayParts.push(operatorPart(40 /* PlusToken */)); + displayParts.push(displayPart((allSignatures.length - 1).toString(), 7 /* numericLiteral */)); + displayParts.push(spacePart()); + displayParts.push(textPart(allSignatures.length === 2 ? "overload" : "overloads")); + displayParts.push(punctuationPart(22 /* CloseParenToken */)); + } + documentation = signature.getDocumentationComment(typeChecker); + tags = signature.getJsDocTags(); + if (allSignatures.length > 1 && documentation.length === 0 && tags.length === 0) { + documentation = allSignatures[0].getDocumentationComment(typeChecker); + tags = allSignatures[0].getJsDocTags().filter((tag) => tag.name !== "deprecated"); + } + } + function writeTypeParametersOfSymbol(symbol2, enclosingDeclaration2) { + const typeParameterParts = mapToDisplayParts((writer) => { + const params = typeChecker.symbolToTypeParameterDeclarations(symbol2, enclosingDeclaration2, symbolDisplayNodeBuilderFlags); + getPrinter().writeList(53776 /* TypeParameters */, params, getSourceFileOfNode(getParseTreeNode(enclosingDeclaration2)), writer); + }); + addRange(displayParts, typeParameterParts); + } + } + function getSymbolDisplayPartsDocumentationAndSymbolKind(typeChecker, symbol, sourceFile, enclosingDeclaration, location, semanticMeaning = getMeaningFromLocation(location), alias) { + return getSymbolDisplayPartsDocumentationAndSymbolKindWorker( + typeChecker, + symbol, + sourceFile, + enclosingDeclaration, + location, + /*type*/ + void 0, + semanticMeaning, + alias + ); + } + function isLocalVariableOrFunction(symbol) { + if (symbol.parent) { + return false; + } + return forEach(symbol.declarations, (declaration) => { + if (declaration.kind === 218 /* FunctionExpression */) { + return true; + } + if (declaration.kind !== 260 /* VariableDeclaration */ && declaration.kind !== 262 /* FunctionDeclaration */) { + return false; + } + for (let parent2 = declaration.parent; !isFunctionBlock(parent2); parent2 = parent2.parent) { + if (parent2.kind === 312 /* SourceFile */ || parent2.kind === 268 /* ModuleBlock */) { + return false; + } + } + return true; + }); + } + var symbolDisplayNodeBuilderFlags; + var init_symbolDisplay = __esm({ + "src/services/symbolDisplay.ts"() { + "use strict"; + init_ts4(); + symbolDisplayNodeBuilderFlags = 8192 /* OmitParameterModifiers */ | 70221824 /* IgnoreErrors */ | 16384 /* UseAliasDefinedOutsideCurrentScope */; } }); - // src/services/_namespaces/ts.FindAllReferences.ts - var ts_FindAllReferences_exports = {}; - __export(ts_FindAllReferences_exports, { - Core: () => Core, - DefinitionKind: () => DefinitionKind, - EntryKind: () => EntryKind, - ExportKind: () => ExportKind2, - FindReferencesUse: () => FindReferencesUse, - ImportExport: () => ImportExport, - createImportTracker: () => createImportTracker, - findModuleReferences: () => findModuleReferences, - findReferenceOrRenameEntries: () => findReferenceOrRenameEntries, - findReferencedSymbols: () => findReferencedSymbols, - getContextNode: () => getContextNode, - getExportInfo: () => getExportInfo, - getImplementationsAtPosition: () => getImplementationsAtPosition, - getImportOrExportSymbol: () => getImportOrExportSymbol, - getReferenceEntriesForNode: () => getReferenceEntriesForNode, - getTextSpanOfEntry: () => getTextSpanOfEntry, - isContextWithStartAndEndNode: () => isContextWithStartAndEndNode, - isDeclarationOfSymbol: () => isDeclarationOfSymbol, - nodeEntry: () => nodeEntry, - toContextSpan: () => toContextSpan, - toHighlightSpan: () => toHighlightSpan, - toReferenceEntry: () => toReferenceEntry, - toRenameLocation: () => toRenameLocation + // src/services/_namespaces/ts.SymbolDisplay.ts + var ts_SymbolDisplay_exports = {}; + __export(ts_SymbolDisplay_exports, { + getSymbolDisplayPartsDocumentationAndSymbolKind: () => getSymbolDisplayPartsDocumentationAndSymbolKind, + getSymbolKind: () => getSymbolKind, + getSymbolModifiers: () => getSymbolModifiers }); - var init_ts_FindAllReferences = __esm({ - "src/services/_namespaces/ts.FindAllReferences.ts"() { + var init_ts_SymbolDisplay = __esm({ + "src/services/_namespaces/ts.SymbolDisplay.ts"() { "use strict"; - init_importTracker(); - init_findAllReferences(); + init_symbolDisplay(); } }); - // src/services/goToDefinition.ts - function getDefinitionAtPosition(program, sourceFile, position, searchOtherFilesOnly, stopAtAlias) { + // src/services/textChanges.ts + function getPos2(n) { + const result = n.__pos; + Debug.assert(typeof result === "number"); + return result; + } + function setPos(n, pos) { + Debug.assert(typeof pos === "number"); + n.__pos = pos; + } + function getEnd(n) { + const result = n.__end; + Debug.assert(typeof result === "number"); + return result; + } + function setEnd(n, end) { + Debug.assert(typeof end === "number"); + n.__end = end; + } + function skipWhitespacesAndLineBreaks(text, start) { + return skipTrivia( + text, + start, + /*stopAfterLineBreak*/ + false, + /*stopAtComments*/ + true + ); + } + function hasCommentsBeforeLineBreak(text, start) { + let i = start; + while (i < text.length) { + const ch = text.charCodeAt(i); + if (isWhiteSpaceSingleLine(ch)) { + i++; + continue; + } + return ch === 47 /* slash */; + } + return false; + } + function getAdjustedRange(sourceFile, startNode2, endNode2, options) { + return { pos: getAdjustedStartPosition(sourceFile, startNode2, options), end: getAdjustedEndPosition(sourceFile, endNode2, options) }; + } + function getAdjustedStartPosition(sourceFile, node, options, hasTrailingComment = false) { var _a, _b; - const resolvedRef = getReferenceAtPosition(sourceFile, position, program); - const fileReferenceDefinition = resolvedRef && [getDefinitionInfoForFileReference(resolvedRef.reference.fileName, resolvedRef.fileName, resolvedRef.unverified)] || emptyArray; - if (resolvedRef == null ? void 0 : resolvedRef.file) { - return fileReferenceDefinition; + const { leadingTriviaOption } = options; + if (leadingTriviaOption === 0 /* Exclude */) { + return node.getStart(sourceFile); } - const node = getTouchingPropertyName(sourceFile, position); - if (node === sourceFile) { + if (leadingTriviaOption === 3 /* StartLine */) { + const startPos = node.getStart(sourceFile); + const pos = getLineStartPositionForPosition(startPos, sourceFile); + return rangeContainsPosition(node, pos) ? pos : startPos; + } + if (leadingTriviaOption === 2 /* JSDoc */) { + const JSDocComments = getJSDocCommentRanges(node, sourceFile.text); + if (JSDocComments == null ? void 0 : JSDocComments.length) { + return getLineStartPositionForPosition(JSDocComments[0].pos, sourceFile); + } + } + const fullStart = node.getFullStart(); + const start = node.getStart(sourceFile); + if (fullStart === start) { + return start; + } + const fullStartLine = getLineStartPositionForPosition(fullStart, sourceFile); + const startLine = getLineStartPositionForPosition(start, sourceFile); + if (startLine === fullStartLine) { + return leadingTriviaOption === 1 /* IncludeAll */ ? fullStart : start; + } + if (hasTrailingComment) { + const comment = ((_a = getLeadingCommentRanges(sourceFile.text, fullStart)) == null ? void 0 : _a[0]) || ((_b = getTrailingCommentRanges(sourceFile.text, fullStart)) == null ? void 0 : _b[0]); + if (comment) { + return skipTrivia( + sourceFile.text, + comment.end, + /*stopAfterLineBreak*/ + true, + /*stopAtComments*/ + true + ); + } + } + const nextLineStart = fullStart > 0 ? 1 : 0; + let adjustedStartPosition = getStartPositionOfLine(getLineOfLocalPosition(sourceFile, fullStartLine) + nextLineStart, sourceFile); + adjustedStartPosition = skipWhitespacesAndLineBreaks(sourceFile.text, adjustedStartPosition); + return getStartPositionOfLine(getLineOfLocalPosition(sourceFile, adjustedStartPosition), sourceFile); + } + function getEndPositionOfMultilineTrailingComment(sourceFile, node, options) { + const { end } = node; + const { trailingTriviaOption } = options; + if (trailingTriviaOption === 2 /* Include */) { + const comments = getTrailingCommentRanges(sourceFile.text, end); + if (comments) { + const nodeEndLine = getLineOfLocalPosition(sourceFile, node.end); + for (const comment of comments) { + if (comment.kind === 2 /* SingleLineCommentTrivia */ || getLineOfLocalPosition(sourceFile, comment.pos) > nodeEndLine) { + break; + } + const commentEndLine = getLineOfLocalPosition(sourceFile, comment.end); + if (commentEndLine > nodeEndLine) { + return skipTrivia( + sourceFile.text, + comment.end, + /*stopAfterLineBreak*/ + true, + /*stopAtComments*/ + true + ); + } + } + } + } + return void 0; + } + function getAdjustedEndPosition(sourceFile, node, options) { + var _a; + const { end } = node; + const { trailingTriviaOption } = options; + if (trailingTriviaOption === 0 /* Exclude */) { + return end; + } + if (trailingTriviaOption === 1 /* ExcludeWhitespace */) { + const comments = concatenate(getTrailingCommentRanges(sourceFile.text, end), getLeadingCommentRanges(sourceFile.text, end)); + const realEnd = (_a = comments == null ? void 0 : comments[comments.length - 1]) == null ? void 0 : _a.end; + if (realEnd) { + return realEnd; + } + return end; + } + const multilineEndPosition = getEndPositionOfMultilineTrailingComment(sourceFile, node, options); + if (multilineEndPosition) { + return multilineEndPosition; + } + const newEnd = skipTrivia( + sourceFile.text, + end, + /*stopAfterLineBreak*/ + true + ); + return newEnd !== end && (trailingTriviaOption === 2 /* Include */ || isLineBreak(sourceFile.text.charCodeAt(newEnd - 1))) ? newEnd : end; + } + function isSeparator(node, candidate) { + return !!candidate && !!node.parent && (candidate.kind === 28 /* CommaToken */ || candidate.kind === 27 /* SemicolonToken */ && node.parent.kind === 210 /* ObjectLiteralExpression */); + } + function isThisTypeAnnotatable(containingFunction) { + return isFunctionExpression(containingFunction) || isFunctionDeclaration(containingFunction); + } + function updateJSDocHost(parent2) { + if (parent2.kind !== 219 /* ArrowFunction */) { + return parent2; + } + const jsDocNode = parent2.parent.kind === 172 /* PropertyDeclaration */ ? parent2.parent : parent2.parent.parent; + jsDocNode.jsDoc = parent2.jsDoc; + return jsDocNode; + } + function tryMergeJsdocTags(oldTag, newTag) { + if (oldTag.kind !== newTag.kind) { return void 0; } - const { parent: parent2 } = node; - const typeChecker = program.getTypeChecker(); - if (node.kind === 163 /* OverrideKeyword */ || isIdentifier(node) && isJSDocOverrideTag(parent2) && parent2.tagName === node) { - return getDefinitionFromOverriddenMember(typeChecker, node) || emptyArray; + switch (oldTag.kind) { + case 348 /* JSDocParameterTag */: { + const oldParam = oldTag; + const newParam = newTag; + return isIdentifier(oldParam.name) && isIdentifier(newParam.name) && oldParam.name.escapedText === newParam.name.escapedText ? factory.createJSDocParameterTag( + /*tagName*/ + void 0, + newParam.name, + /*isBracketed*/ + false, + newParam.typeExpression, + newParam.isNameFirst, + oldParam.comment + ) : void 0; + } + case 349 /* JSDocReturnTag */: + return factory.createJSDocReturnTag( + /*tagName*/ + void 0, + newTag.typeExpression, + oldTag.comment + ); + case 351 /* JSDocTypeTag */: + return factory.createJSDocTypeTag( + /*tagName*/ + void 0, + newTag.typeExpression, + oldTag.comment + ); } - if (isJumpStatementTarget(node)) { - const label = getTargetLabel(node.parent, node.text); - return label ? [createDefinitionInfoFromName( - typeChecker, - label, - "label" /* label */, - node.text, - /*containerName*/ - void 0 - )] : void 0; + } + function startPositionToDeleteNodeInList(sourceFile, node) { + return skipTrivia( + sourceFile.text, + getAdjustedStartPosition(sourceFile, node, { leadingTriviaOption: 1 /* IncludeAll */ }), + /*stopAfterLineBreak*/ + false, + /*stopAtComments*/ + true + ); + } + function endPositionToDeleteNodeInList(sourceFile, node, prevNode, nextNode) { + const end = startPositionToDeleteNodeInList(sourceFile, nextNode); + if (prevNode === void 0 || positionsAreOnSameLine(getAdjustedEndPosition(sourceFile, node, {}), end, sourceFile)) { + return end; } - if (node.kind === 107 /* ReturnKeyword */) { - const functionDeclaration = findAncestor(node.parent, (n) => isClassStaticBlockDeclaration(n) ? "quit" : isFunctionLikeDeclaration(n)); - return functionDeclaration ? [createDefinitionFromSignatureDeclaration(typeChecker, functionDeclaration)] : void 0; + const token = findPrecedingToken(nextNode.getStart(sourceFile), sourceFile); + if (isSeparator(node, token)) { + const prevToken = findPrecedingToken(node.getStart(sourceFile), sourceFile); + if (isSeparator(prevNode, prevToken)) { + const pos = skipTrivia( + sourceFile.text, + token.getEnd(), + /*stopAfterLineBreak*/ + true, + /*stopAtComments*/ + true + ); + if (positionsAreOnSameLine(prevToken.getStart(sourceFile), token.getStart(sourceFile), sourceFile)) { + return isLineBreak(sourceFile.text.charCodeAt(pos - 1)) ? pos - 1 : pos; + } + if (isLineBreak(sourceFile.text.charCodeAt(pos))) { + return pos; + } + } + } + return end; + } + function getClassOrObjectBraceEnds(cls, sourceFile) { + const open = findChildOfKind(cls, 19 /* OpenBraceToken */, sourceFile); + const close = findChildOfKind(cls, 20 /* CloseBraceToken */, sourceFile); + return [open == null ? void 0 : open.end, close == null ? void 0 : close.end]; + } + function getMembersOrProperties(node) { + return isObjectLiteralExpression(node) ? node.properties : node.members; + } + function applyChanges(text, changes) { + for (let i = changes.length - 1; i >= 0; i--) { + const { span, newText } = changes[i]; + text = `${text.substring(0, span.start)}${newText}${text.substring(textSpanEnd(span))}`; + } + return text; + } + function isTrivia2(s) { + return skipTrivia(s, 0) === s.length; + } + function assignPositionsToNode(node) { + const visited = visitEachChild(node, assignPositionsToNode, textChangesTransformationContext, assignPositionsToNodeArray, assignPositionsToNode); + const newNode = nodeIsSynthesized(visited) ? visited : Object.create(visited); + setTextRangePosEnd(newNode, getPos2(node), getEnd(node)); + return newNode; + } + function assignPositionsToNodeArray(nodes, visitor, test, start, count) { + const visited = visitNodes2(nodes, visitor, test, start, count); + if (!visited) { + return visited; + } + Debug.assert(nodes); + const nodeArray = visited === nodes ? factory.createNodeArray(visited.slice(0)) : visited; + setTextRangePosEnd(nodeArray, getPos2(nodes), getEnd(nodes)); + return nodeArray; + } + function createWriter(newLine) { + let lastNonTriviaPosition = 0; + const writer = createTextWriter(newLine); + const onBeforeEmitNode = (node) => { + if (node) { + setPos(node, lastNonTriviaPosition); + } + }; + const onAfterEmitNode = (node) => { + if (node) { + setEnd(node, lastNonTriviaPosition); + } + }; + const onBeforeEmitNodeArray = (nodes) => { + if (nodes) { + setPos(nodes, lastNonTriviaPosition); + } + }; + const onAfterEmitNodeArray = (nodes) => { + if (nodes) { + setEnd(nodes, lastNonTriviaPosition); + } + }; + const onBeforeEmitToken = (node) => { + if (node) { + setPos(node, lastNonTriviaPosition); + } + }; + const onAfterEmitToken = (node) => { + if (node) { + setEnd(node, lastNonTriviaPosition); + } + }; + function setLastNonTriviaPosition(s, force) { + if (force || !isTrivia2(s)) { + lastNonTriviaPosition = writer.getTextPos(); + let i = 0; + while (isWhiteSpaceLike(s.charCodeAt(s.length - i - 1))) { + i++; + } + lastNonTriviaPosition -= i; + } } - if (node.kind === 135 /* AwaitKeyword */) { - const functionDeclaration = findAncestor(node, (n) => isFunctionLikeDeclaration(n)); - const isAsyncFunction2 = functionDeclaration && some(functionDeclaration.modifiers, (node2) => node2.kind === 134 /* AsyncKeyword */); - return isAsyncFunction2 ? [createDefinitionFromSignatureDeclaration(typeChecker, functionDeclaration)] : void 0; + function write(s) { + writer.write(s); + setLastNonTriviaPosition( + s, + /*force*/ + false + ); } - if (node.kind === 127 /* YieldKeyword */) { - const functionDeclaration = findAncestor(node, (n) => isFunctionLikeDeclaration(n)); - const isGeneratorFunction = functionDeclaration && functionDeclaration.asteriskToken; - return isGeneratorFunction ? [createDefinitionFromSignatureDeclaration(typeChecker, functionDeclaration)] : void 0; + function writeComment(s) { + writer.writeComment(s); } - if (isStaticModifier(node) && isClassStaticBlockDeclaration(node.parent)) { - const classDecl = node.parent.parent; - const { symbol: symbol2, failedAliasResolution: failedAliasResolution2 } = getSymbol(classDecl, typeChecker, stopAtAlias); - const staticBlocks = filter(classDecl.members, isClassStaticBlockDeclaration); - const containerName = symbol2 ? typeChecker.symbolToString(symbol2, classDecl) : ""; - const sourceFile2 = node.getSourceFile(); - return map(staticBlocks, (staticBlock) => { - let { pos } = moveRangePastModifiers(staticBlock); - pos = skipTrivia(sourceFile2.text, pos); - return createDefinitionInfoFromName( - typeChecker, - staticBlock, - "constructor" /* constructorImplementationElement */, - "static {}", - containerName, - /*unverified*/ - false, - failedAliasResolution2, - { start: pos, length: "static".length } - ); - }); + function writeKeyword(s) { + writer.writeKeyword(s); + setLastNonTriviaPosition( + s, + /*force*/ + false + ); } - let { symbol, failedAliasResolution } = getSymbol(node, typeChecker, stopAtAlias); - let fallbackNode = node; - if (searchOtherFilesOnly && failedAliasResolution) { - const importDeclaration = forEach([node, ...(symbol == null ? void 0 : symbol.declarations) || emptyArray], (n) => findAncestor(n, isAnyImportOrBareOrAccessedRequire)); - const moduleSpecifier = importDeclaration && tryGetModuleSpecifierFromDeclaration(importDeclaration); - if (moduleSpecifier) { - ({ symbol, failedAliasResolution } = getSymbol(moduleSpecifier, typeChecker, stopAtAlias)); - fallbackNode = moduleSpecifier; - } + function writeOperator(s) { + writer.writeOperator(s); + setLastNonTriviaPosition( + s, + /*force*/ + false + ); } - if (!symbol && isModuleSpecifierLike(fallbackNode)) { - const ref = (_b = (_a = sourceFile.resolvedModules) == null ? void 0 : _a.get(fallbackNode.text, getModeForUsageLocation(sourceFile, fallbackNode))) == null ? void 0 : _b.resolvedModule; - if (ref) { - return [{ - name: fallbackNode.text, - fileName: ref.resolvedFileName, - containerName: void 0, - containerKind: void 0, - kind: "script" /* scriptElement */, - textSpan: createTextSpan(0, 0), - failedAliasResolution, - isAmbient: isDeclarationFileName(ref.resolvedFileName), - unverified: fallbackNode !== node - }]; - } + function writePunctuation(s) { + writer.writePunctuation(s); + setLastNonTriviaPosition( + s, + /*force*/ + false + ); } - if (!symbol) { - return concatenate(fileReferenceDefinition, getDefinitionInfoForIndexSignatures(node, typeChecker)); + function writeTrailingSemicolon(s) { + writer.writeTrailingSemicolon(s); + setLastNonTriviaPosition( + s, + /*force*/ + false + ); } - if (searchOtherFilesOnly && every(symbol.declarations, (d) => d.getSourceFile().fileName === sourceFile.fileName)) - return void 0; - const calledDeclaration = tryGetSignatureDeclaration(typeChecker, node); - if (calledDeclaration && !(isJsxOpeningLikeElement(node.parent) && isConstructorLike(calledDeclaration))) { - const sigInfo = createDefinitionFromSignatureDeclaration(typeChecker, calledDeclaration, failedAliasResolution); - if (typeChecker.getRootSymbols(symbol).some((s) => symbolMatchesSignature(s, calledDeclaration))) { - return [sigInfo]; - } else { - const defs = getDefinitionFromSymbol(typeChecker, symbol, node, failedAliasResolution, calledDeclaration) || emptyArray; - return node.kind === 108 /* SuperKeyword */ ? [sigInfo, ...defs] : [...defs, sigInfo]; - } + function writeParameter(s) { + writer.writeParameter(s); + setLastNonTriviaPosition( + s, + /*force*/ + false + ); } - if (node.parent.kind === 303 /* ShorthandPropertyAssignment */) { - const shorthandSymbol = typeChecker.getShorthandAssignmentValueSymbol(symbol.valueDeclaration); - const definitions = (shorthandSymbol == null ? void 0 : shorthandSymbol.declarations) ? shorthandSymbol.declarations.map((decl) => createDefinitionInfo( - decl, - typeChecker, - shorthandSymbol, - node, - /*unverified*/ - false, - failedAliasResolution - )) : emptyArray; - return concatenate(definitions, getDefinitionFromObjectLiteralElement(typeChecker, node)); + function writeProperty(s) { + writer.writeProperty(s); + setLastNonTriviaPosition( + s, + /*force*/ + false + ); } - if (isPropertyName(node) && isBindingElement(parent2) && isObjectBindingPattern(parent2.parent) && node === (parent2.propertyName || parent2.name)) { - const name = getNameFromPropertyName(node); - const type = typeChecker.getTypeAtLocation(parent2.parent); - return name === void 0 ? emptyArray : flatMap(type.isUnion() ? type.types : [type], (t) => { - const prop = t.getProperty(name); - return prop && getDefinitionFromSymbol(typeChecker, prop, node); - }); + function writeSpace(s) { + writer.writeSpace(s); + setLastNonTriviaPosition( + s, + /*force*/ + false + ); } - const objectLiteralElementDefinition = getDefinitionFromObjectLiteralElement(typeChecker, node); - return concatenate(fileReferenceDefinition, objectLiteralElementDefinition.length ? objectLiteralElementDefinition : getDefinitionFromSymbol(typeChecker, symbol, node, failedAliasResolution)); - } - function symbolMatchesSignature(s, calledDeclaration) { - var _a; - return s === calledDeclaration.symbol || s === calledDeclaration.symbol.parent || isAssignmentExpression(calledDeclaration.parent) || !isCallLikeExpression(calledDeclaration.parent) && s === ((_a = tryCast(calledDeclaration.parent, canHaveSymbol)) == null ? void 0 : _a.symbol); - } - function getDefinitionFromObjectLiteralElement(typeChecker, node) { - const element = getContainingObjectLiteralElement(node); - if (element) { - const contextualType = element && typeChecker.getContextualType(element.parent); - if (contextualType) { - return flatMap(getPropertySymbolsFromContextualType( - element, - typeChecker, - contextualType, - /*unionSymbolOk*/ - false - ), (propertySymbol) => getDefinitionFromSymbol(typeChecker, propertySymbol, node)); - } + function writeStringLiteral(s) { + writer.writeStringLiteral(s); + setLastNonTriviaPosition( + s, + /*force*/ + false + ); } - return emptyArray; - } - function getDefinitionFromOverriddenMember(typeChecker, node) { - const classElement = findAncestor(node, isClassElement); - if (!(classElement && classElement.name)) - return; - const baseDeclaration = findAncestor(classElement, isClassLike); - if (!baseDeclaration) - return; - const baseTypeNode = getEffectiveBaseTypeNode(baseDeclaration); - if (!baseTypeNode) - return; - const expression = skipParentheses(baseTypeNode.expression); - const base = isClassExpression(expression) ? expression.symbol : typeChecker.getSymbolAtLocation(expression); - if (!base) - return; - const name = unescapeLeadingUnderscores(getTextOfPropertyName(classElement.name)); - const symbol = hasStaticModifier(classElement) ? typeChecker.getPropertyOfType(typeChecker.getTypeOfSymbol(base), name) : typeChecker.getPropertyOfType(typeChecker.getDeclaredTypeOfSymbol(base), name); - if (!symbol) - return; - return getDefinitionFromSymbol(typeChecker, symbol, node); - } - function getReferenceAtPosition(sourceFile, position, program) { - var _a, _b, _c, _d; - const referencePath = findReferenceInPosition(sourceFile.referencedFiles, position); - if (referencePath) { - const file = program.getSourceFileFromReference(sourceFile, referencePath); - return file && { reference: referencePath, fileName: file.fileName, file, unverified: false }; + function writeSymbol(s, sym) { + writer.writeSymbol(s, sym); + setLastNonTriviaPosition( + s, + /*force*/ + false + ); } - const typeReferenceDirective = findReferenceInPosition(sourceFile.typeReferenceDirectives, position); - if (typeReferenceDirective) { - const reference = (_a = program.getResolvedTypeReferenceDirectives().get(typeReferenceDirective.fileName, typeReferenceDirective.resolutionMode || sourceFile.impliedNodeFormat)) == null ? void 0 : _a.resolvedTypeReferenceDirective; - const file = reference && program.getSourceFile(reference.resolvedFileName); - return file && { reference: typeReferenceDirective, fileName: file.fileName, file, unverified: false }; + function writeLine(force) { + writer.writeLine(force); } - const libReferenceDirective = findReferenceInPosition(sourceFile.libReferenceDirectives, position); - if (libReferenceDirective) { - const file = program.getLibFileFromReference(libReferenceDirective); - return file && { reference: libReferenceDirective, fileName: file.fileName, file, unverified: false }; + function increaseIndent() { + writer.increaseIndent(); } - if ((_b = sourceFile.resolvedModules) == null ? void 0 : _b.size()) { - const node = getTouchingToken(sourceFile, position); - if (isModuleSpecifierLike(node) && isExternalModuleNameRelative(node.text) && sourceFile.resolvedModules.has(node.text, getModeForUsageLocation(sourceFile, node))) { - const verifiedFileName = (_d = (_c = sourceFile.resolvedModules.get(node.text, getModeForUsageLocation(sourceFile, node))) == null ? void 0 : _c.resolvedModule) == null ? void 0 : _d.resolvedFileName; - const fileName = verifiedFileName || resolvePath(getDirectoryPath(sourceFile.fileName), node.text); - return { - file: program.getSourceFile(fileName), - fileName, - reference: { - pos: node.getStart(), - end: node.getEnd(), - fileName: node.text - }, - unverified: !verifiedFileName - }; - } + function decreaseIndent() { + writer.decreaseIndent(); } - return void 0; - } - function getTypeDefinitionAtPosition(typeChecker, sourceFile, position) { - const node = getTouchingPropertyName(sourceFile, position); - if (node === sourceFile) { - return void 0; + function getText() { + return writer.getText(); } - if (isImportMeta(node.parent) && node.parent.name === node) { - return definitionFromType( - typeChecker.getTypeAtLocation(node.parent), - typeChecker, - node.parent, - /*failedAliasResolution*/ + function rawWrite(s) { + writer.rawWrite(s); + setLastNonTriviaPosition( + s, + /*force*/ false ); } - const { symbol, failedAliasResolution } = getSymbol( - node, - typeChecker, - /*stopAtAlias*/ - false - ); - if (!symbol) - return void 0; - const typeAtLocation = typeChecker.getTypeOfSymbolAtLocation(symbol, node); - const returnType = tryGetReturnTypeOfFunction(symbol, typeAtLocation, typeChecker); - const fromReturnType = returnType && definitionFromType(returnType, typeChecker, node, failedAliasResolution); - const typeDefinitions = fromReturnType && fromReturnType.length !== 0 ? fromReturnType : definitionFromType(typeAtLocation, typeChecker, node, failedAliasResolution); - return typeDefinitions.length ? typeDefinitions : !(symbol.flags & 111551 /* Value */) && symbol.flags & 788968 /* Type */ ? getDefinitionFromSymbol(typeChecker, skipAlias(symbol, typeChecker), node, failedAliasResolution) : void 0; - } - function definitionFromType(type, checker, node, failedAliasResolution) { - return flatMap(type.isUnion() && !(type.flags & 32 /* Enum */) ? type.types : [type], (t) => t.symbol && getDefinitionFromSymbol(checker, t.symbol, node, failedAliasResolution)); - } - function tryGetReturnTypeOfFunction(symbol, type, checker) { - if (type.symbol === symbol || // At `const f = () => {}`, the symbol is `f` and the type symbol is at `() => {}` - symbol.valueDeclaration && type.symbol && isVariableDeclaration(symbol.valueDeclaration) && symbol.valueDeclaration.initializer === type.symbol.valueDeclaration) { - const sigs = type.getCallSignatures(); - if (sigs.length === 1) - return checker.getReturnTypeOfSignature(first(sigs)); + function writeLiteral(s) { + writer.writeLiteral(s); + setLastNonTriviaPosition( + s, + /*force*/ + true + ); } - return void 0; - } - function getDefinitionAndBoundSpan(program, sourceFile, position) { - const definitions = getDefinitionAtPosition(program, sourceFile, position); - if (!definitions || definitions.length === 0) { - return void 0; + function getTextPos() { + return writer.getTextPos(); } - const comment = findReferenceInPosition(sourceFile.referencedFiles, position) || findReferenceInPosition(sourceFile.typeReferenceDirectives, position) || findReferenceInPosition(sourceFile.libReferenceDirectives, position); - if (comment) { - return { definitions, textSpan: createTextSpanFromRange(comment) }; + function getLine() { + return writer.getLine(); } - const node = getTouchingPropertyName(sourceFile, position); - const textSpan = createTextSpan(node.getStart(), node.getWidth()); - return { definitions, textSpan }; - } - function getDefinitionInfoForIndexSignatures(node, checker) { - return mapDefined(checker.getIndexInfosAtLocation(node), (info) => info.declaration && createDefinitionFromSignatureDeclaration(checker, info.declaration)); - } - function getSymbol(node, checker, stopAtAlias) { - const symbol = checker.getSymbolAtLocation(node); - let failedAliasResolution = false; - if ((symbol == null ? void 0 : symbol.declarations) && symbol.flags & 2097152 /* Alias */ && !stopAtAlias && shouldSkipAlias(node, symbol.declarations[0])) { - const aliased = checker.getAliasedSymbol(symbol); - if (aliased.declarations) { - return { symbol: aliased }; - } else { - failedAliasResolution = true; - } + function getColumn() { + return writer.getColumn(); } - return { symbol, failedAliasResolution }; - } - function shouldSkipAlias(node, declaration) { - if (node.kind !== 80 /* Identifier */) { - return false; + function getIndent() { + return writer.getIndent(); } - if (node.parent === declaration) { - return true; + function isAtStartOfLine() { + return writer.isAtStartOfLine(); } - if (declaration.kind === 273 /* NamespaceImport */) { - return false; + function clear2() { + writer.clear(); + lastNonTriviaPosition = 0; } - return true; - } - function isExpandoDeclaration(node) { - if (!isAssignmentDeclaration(node)) - return false; - const containingAssignment = findAncestor(node, (p) => { - if (isAssignmentExpression(p)) - return true; - if (!isAssignmentDeclaration(p)) - return "quit"; - return false; - }); - return !!containingAssignment && getAssignmentDeclarationKind(containingAssignment) === 5 /* Property */; + return { + onBeforeEmitNode, + onAfterEmitNode, + onBeforeEmitNodeArray, + onAfterEmitNodeArray, + onBeforeEmitToken, + onAfterEmitToken, + write, + writeComment, + writeKeyword, + writeOperator, + writePunctuation, + writeTrailingSemicolon, + writeParameter, + writeProperty, + writeSpace, + writeStringLiteral, + writeSymbol, + writeLine, + increaseIndent, + decreaseIndent, + getText, + rawWrite, + writeLiteral, + getTextPos, + getLine, + getColumn, + getIndent, + isAtStartOfLine, + hasTrailingComment: () => writer.hasTrailingComment(), + hasTrailingWhitespace: () => writer.hasTrailingWhitespace(), + clear: clear2 + }; } - function getDefinitionFromSymbol(typeChecker, symbol, node, failedAliasResolution, excludeDeclaration) { - const filteredDeclarations = filter(symbol.declarations, (d) => d !== excludeDeclaration); - const withoutExpandos = filter(filteredDeclarations, (d) => !isExpandoDeclaration(d)); - const results = some(withoutExpandos) ? withoutExpandos : filteredDeclarations; - return getConstructSignatureDefinition() || getCallSignatureDefinition() || map(results, (declaration) => createDefinitionInfo( - declaration, - typeChecker, - symbol, - node, - /*unverified*/ - false, - failedAliasResolution - )); - function getConstructSignatureDefinition() { - if (symbol.flags & 32 /* Class */ && !(symbol.flags & (16 /* Function */ | 3 /* Variable */)) && (isNewExpressionTarget(node) || node.kind === 137 /* ConstructorKeyword */)) { - const cls = find(filteredDeclarations, isClassLike) || Debug.fail("Expected declaration to have at least one class-like declaration"); - return getSignatureDefinition( - cls.members, - /*selectConstructors*/ - true - ); + function getInsertionPositionAtSourceFileTop(sourceFile) { + let lastPrologue; + for (const node of sourceFile.statements) { + if (isPrologueDirective(node)) { + lastPrologue = node; + } else { + break; } } - function getCallSignatureDefinition() { - return isCallOrNewExpressionTarget(node) || isNameOfFunctionDeclaration(node) ? getSignatureDefinition( - filteredDeclarations, - /*selectConstructors*/ - false - ) : void 0; + let position = 0; + const text = sourceFile.text; + if (lastPrologue) { + position = lastPrologue.end; + advancePastLineBreak(); + return position; } - function getSignatureDefinition(signatureDeclarations, selectConstructors) { - if (!signatureDeclarations) { - return void 0; + const shebang = getShebang(text); + if (shebang !== void 0) { + position = shebang.length; + advancePastLineBreak(); + } + const ranges = getLeadingCommentRanges(text, position); + if (!ranges) + return position; + let lastComment; + let firstNodeLine; + for (const range of ranges) { + if (range.kind === 3 /* MultiLineCommentTrivia */) { + if (isPinnedComment(text, range.pos)) { + lastComment = { range, pinnedOrTripleSlash: true }; + continue; + } + } else if (isRecognizedTripleSlashComment(text, range.pos, range.end)) { + lastComment = { range, pinnedOrTripleSlash: true }; + continue; } - const declarations = signatureDeclarations.filter(selectConstructors ? isConstructorDeclaration : isFunctionLike); - const declarationsWithBody = declarations.filter((d) => !!d.body); - return declarations.length ? declarationsWithBody.length !== 0 ? declarationsWithBody.map((x) => createDefinitionInfo(x, typeChecker, symbol, node)) : [createDefinitionInfo( - last(declarations), - typeChecker, - symbol, - node, - /*unverified*/ - false, - failedAliasResolution - )] : void 0; + if (lastComment) { + if (lastComment.pinnedOrTripleSlash) + break; + const commentLine = sourceFile.getLineAndCharacterOfPosition(range.pos).line; + const lastCommentEndLine = sourceFile.getLineAndCharacterOfPosition(lastComment.range.end).line; + if (commentLine >= lastCommentEndLine + 2) + break; + } + if (sourceFile.statements.length) { + if (firstNodeLine === void 0) + firstNodeLine = sourceFile.getLineAndCharacterOfPosition(sourceFile.statements[0].getStart()).line; + const commentEndLine = sourceFile.getLineAndCharacterOfPosition(range.end).line; + if (firstNodeLine < commentEndLine + 2) + break; + } + lastComment = { range, pinnedOrTripleSlash: false }; } - } - function createDefinitionInfo(declaration, checker, symbol, node, unverified, failedAliasResolution) { - const symbolName2 = checker.symbolToString(symbol); - const symbolKind = ts_SymbolDisplay_exports.getSymbolKind(checker, symbol, node); - const containerName = symbol.parent ? checker.symbolToString(symbol.parent, node) : ""; - return createDefinitionInfoFromName(checker, declaration, symbolKind, symbolName2, containerName, unverified, failedAliasResolution); - } - function createDefinitionInfoFromName(checker, declaration, symbolKind, symbolName2, containerName, unverified, failedAliasResolution, textSpan) { - const sourceFile = declaration.getSourceFile(); - if (!textSpan) { - const name = getNameOfDeclaration(declaration) || declaration; - textSpan = createTextSpanFromNode(name, sourceFile); + if (lastComment) { + position = lastComment.range.end; + advancePastLineBreak(); } - return { - fileName: sourceFile.fileName, - textSpan, - kind: symbolKind, - name: symbolName2, - containerKind: void 0, - // TODO: GH#18217 - containerName, - ...ts_FindAllReferences_exports.toContextSpan( - textSpan, - sourceFile, - ts_FindAllReferences_exports.getContextNode(declaration) - ), - isLocal: !isDefinitionVisible(checker, declaration), - isAmbient: !!(declaration.flags & 16777216 /* Ambient */), - unverified, - failedAliasResolution - }; - } - function isDefinitionVisible(checker, declaration) { - if (checker.isDeclarationVisible(declaration)) - return true; - if (!declaration.parent) - return false; - if (hasInitializer(declaration.parent) && declaration.parent.initializer === declaration) - return isDefinitionVisible(checker, declaration.parent); - switch (declaration.kind) { - case 171 /* PropertyDeclaration */: - case 176 /* GetAccessor */: - case 177 /* SetAccessor */: - case 173 /* MethodDeclaration */: - if (hasEffectiveModifier(declaration, 8 /* Private */)) - return false; - case 175 /* Constructor */: - case 302 /* PropertyAssignment */: - case 303 /* ShorthandPropertyAssignment */: - case 209 /* ObjectLiteralExpression */: - case 230 /* ClassExpression */: - case 218 /* ArrowFunction */: - case 217 /* FunctionExpression */: - return isDefinitionVisible(checker, declaration.parent); - default: - return false; + return position; + function advancePastLineBreak() { + if (position < text.length) { + const charCode = text.charCodeAt(position); + if (isLineBreak(charCode)) { + position++; + if (position < text.length && charCode === 13 /* carriageReturn */ && text.charCodeAt(position) === 10 /* lineFeed */) { + position++; + } + } + } } } - function createDefinitionFromSignatureDeclaration(typeChecker, decl, failedAliasResolution) { - return createDefinitionInfo( - decl, - typeChecker, - decl.symbol, - decl, - /*unverified*/ - false, - failedAliasResolution - ); - } - function findReferenceInPosition(refs, pos) { - return find(refs, (ref) => textRangeContainsPositionInclusive(ref, pos)); + function isValidLocationToAddComment(sourceFile, position) { + return !isInComment(sourceFile, position) && !isInString(sourceFile, position) && !isInTemplateString(sourceFile, position) && !isInJSXText(sourceFile, position); } - function getDefinitionInfoForFileReference(name, targetFileName, unverified) { - return { - fileName: targetFileName, - textSpan: createTextSpanFromBounds(0, 0), - kind: "script" /* scriptElement */, - name, - containerName: void 0, - containerKind: void 0, - // TODO: GH#18217 - unverified - }; + function needSemicolonBetween(a, b) { + return (isPropertySignature(a) || isPropertyDeclaration(a)) && isClassOrTypeElement(b) && b.name.kind === 167 /* ComputedPropertyName */ || isStatementButNotDeclaration(a) && isStatementButNotDeclaration(b); } - function getAncestorCallLikeExpression(node) { - const target = findAncestor(node, (n) => !isRightSideOfPropertyAccess(n)); - const callLike = target == null ? void 0 : target.parent; - return callLike && isCallLikeExpression(callLike) && getInvokedExpression(callLike) === target ? callLike : void 0; + function deleteNode(changes, sourceFile, node, options = { leadingTriviaOption: 1 /* IncludeAll */ }) { + const startPosition = getAdjustedStartPosition(sourceFile, node, options); + const endPosition = getAdjustedEndPosition(sourceFile, node, options); + changes.deleteRange(sourceFile, { pos: startPosition, end: endPosition }); } - function tryGetSignatureDeclaration(typeChecker, node) { - const callLike = getAncestorCallLikeExpression(node); - const signature = callLike && typeChecker.getResolvedSignature(callLike); - return tryCast(signature && signature.declaration, (d) => isFunctionLike(d) && !isFunctionTypeNode(d)); + function deleteNodeInList(changes, deletedNodesInLists, sourceFile, node) { + const containingList = Debug.checkDefined(ts_formatting_exports.SmartIndenter.getContainingList(node, sourceFile)); + const index = indexOfNode(containingList, node); + Debug.assert(index !== -1); + if (containingList.length === 1) { + deleteNode(changes, sourceFile, node); + return; + } + Debug.assert(!deletedNodesInLists.has(node), "Deleting a node twice"); + deletedNodesInLists.add(node); + changes.deleteRange(sourceFile, { + pos: startPositionToDeleteNodeInList(sourceFile, node), + end: index === containingList.length - 1 ? getAdjustedEndPosition(sourceFile, node, {}) : endPositionToDeleteNodeInList(sourceFile, node, containingList[index - 1], containingList[index + 1]) + }); } - function isConstructorLike(node) { - switch (node.kind) { - case 175 /* Constructor */: - case 184 /* ConstructorType */: - case 179 /* ConstructSignature */: - return true; - default: - return false; + var LeadingTriviaOption, TrailingTriviaOption, useNonAdjustedPositions, ChangeTracker, changesToText, textChangesTransformationContext, deleteDeclaration; + var init_textChanges = __esm({ + "src/services/textChanges.ts"() { + "use strict"; + init_ts4(); + LeadingTriviaOption = /* @__PURE__ */ ((LeadingTriviaOption2) => { + LeadingTriviaOption2[LeadingTriviaOption2["Exclude"] = 0] = "Exclude"; + LeadingTriviaOption2[LeadingTriviaOption2["IncludeAll"] = 1] = "IncludeAll"; + LeadingTriviaOption2[LeadingTriviaOption2["JSDoc"] = 2] = "JSDoc"; + LeadingTriviaOption2[LeadingTriviaOption2["StartLine"] = 3] = "StartLine"; + return LeadingTriviaOption2; + })(LeadingTriviaOption || {}); + TrailingTriviaOption = /* @__PURE__ */ ((TrailingTriviaOption2) => { + TrailingTriviaOption2[TrailingTriviaOption2["Exclude"] = 0] = "Exclude"; + TrailingTriviaOption2[TrailingTriviaOption2["ExcludeWhitespace"] = 1] = "ExcludeWhitespace"; + TrailingTriviaOption2[TrailingTriviaOption2["Include"] = 2] = "Include"; + return TrailingTriviaOption2; + })(TrailingTriviaOption || {}); + useNonAdjustedPositions = { + leadingTriviaOption: 0 /* Exclude */, + trailingTriviaOption: 0 /* Exclude */ + }; + ChangeTracker = class _ChangeTracker { + /** Public for tests only. Other callers should use `ChangeTracker.with`. */ + constructor(newLineCharacter, formatContext) { + this.newLineCharacter = newLineCharacter; + this.formatContext = formatContext; + this.changes = []; + this.classesWithNodesInsertedAtStart = /* @__PURE__ */ new Map(); + // Set implemented as Map + this.deletedNodes = []; + } + static fromContext(context) { + return new _ChangeTracker(getNewLineOrDefaultFromHost(context.host, context.formatContext.options), context.formatContext); + } + static with(context, cb) { + const tracker = _ChangeTracker.fromContext(context); + cb(tracker); + return tracker.getChanges(); + } + pushRaw(sourceFile, change) { + Debug.assertEqual(sourceFile.fileName, change.fileName); + for (const c of change.textChanges) { + this.changes.push({ + kind: 3 /* Text */, + sourceFile, + text: c.newText, + range: createTextRangeFromSpan(c.span) + }); + } + } + deleteRange(sourceFile, range) { + this.changes.push({ kind: 0 /* Remove */, sourceFile, range }); + } + delete(sourceFile, node) { + this.deletedNodes.push({ sourceFile, node }); + } + /** Stop! Consider using `delete` instead, which has logic for deleting nodes from delimited lists. */ + deleteNode(sourceFile, node, options = { leadingTriviaOption: 1 /* IncludeAll */ }) { + this.deleteRange(sourceFile, getAdjustedRange(sourceFile, node, node, options)); + } + deleteNodes(sourceFile, nodes, options = { leadingTriviaOption: 1 /* IncludeAll */ }, hasTrailingComment) { + for (const node of nodes) { + const pos = getAdjustedStartPosition(sourceFile, node, options, hasTrailingComment); + const end = getAdjustedEndPosition(sourceFile, node, options); + this.deleteRange(sourceFile, { pos, end }); + hasTrailingComment = !!getEndPositionOfMultilineTrailingComment(sourceFile, node, options); + } + } + deleteModifier(sourceFile, modifier) { + this.deleteRange(sourceFile, { pos: modifier.getStart(sourceFile), end: skipTrivia( + sourceFile.text, + modifier.end, + /*stopAfterLineBreak*/ + true + ) }); + } + deleteNodeRange(sourceFile, startNode2, endNode2, options = { leadingTriviaOption: 1 /* IncludeAll */ }) { + const startPosition = getAdjustedStartPosition(sourceFile, startNode2, options); + const endPosition = getAdjustedEndPosition(sourceFile, endNode2, options); + this.deleteRange(sourceFile, { pos: startPosition, end: endPosition }); + } + deleteNodeRangeExcludingEnd(sourceFile, startNode2, afterEndNode, options = { leadingTriviaOption: 1 /* IncludeAll */ }) { + const startPosition = getAdjustedStartPosition(sourceFile, startNode2, options); + const endPosition = afterEndNode === void 0 ? sourceFile.text.length : getAdjustedStartPosition(sourceFile, afterEndNode, options); + this.deleteRange(sourceFile, { pos: startPosition, end: endPosition }); + } + replaceRange(sourceFile, range, newNode, options = {}) { + this.changes.push({ kind: 1 /* ReplaceWithSingleNode */, sourceFile, range, options, node: newNode }); + } + replaceNode(sourceFile, oldNode, newNode, options = useNonAdjustedPositions) { + this.replaceRange(sourceFile, getAdjustedRange(sourceFile, oldNode, oldNode, options), newNode, options); + } + replaceNodeRange(sourceFile, startNode2, endNode2, newNode, options = useNonAdjustedPositions) { + this.replaceRange(sourceFile, getAdjustedRange(sourceFile, startNode2, endNode2, options), newNode, options); + } + replaceRangeWithNodes(sourceFile, range, newNodes, options = {}) { + this.changes.push({ kind: 2 /* ReplaceWithMultipleNodes */, sourceFile, range, options, nodes: newNodes }); + } + replaceNodeWithNodes(sourceFile, oldNode, newNodes, options = useNonAdjustedPositions) { + this.replaceRangeWithNodes(sourceFile, getAdjustedRange(sourceFile, oldNode, oldNode, options), newNodes, options); + } + replaceNodeWithText(sourceFile, oldNode, text) { + this.replaceRangeWithText(sourceFile, getAdjustedRange(sourceFile, oldNode, oldNode, useNonAdjustedPositions), text); + } + replaceNodeRangeWithNodes(sourceFile, startNode2, endNode2, newNodes, options = useNonAdjustedPositions) { + this.replaceRangeWithNodes(sourceFile, getAdjustedRange(sourceFile, startNode2, endNode2, options), newNodes, options); + } + nodeHasTrailingComment(sourceFile, oldNode, configurableEnd = useNonAdjustedPositions) { + return !!getEndPositionOfMultilineTrailingComment(sourceFile, oldNode, configurableEnd); + } + nextCommaToken(sourceFile, node) { + const next = findNextToken(node, node.parent, sourceFile); + return next && next.kind === 28 /* CommaToken */ ? next : void 0; + } + replacePropertyAssignment(sourceFile, oldNode, newNode) { + const suffix = this.nextCommaToken(sourceFile, oldNode) ? "" : "," + this.newLineCharacter; + this.replaceNode(sourceFile, oldNode, newNode, { suffix }); + } + insertNodeAt(sourceFile, pos, newNode, options = {}) { + this.replaceRange(sourceFile, createRange(pos), newNode, options); + } + insertNodesAt(sourceFile, pos, newNodes, options = {}) { + this.replaceRangeWithNodes(sourceFile, createRange(pos), newNodes, options); + } + insertNodeAtTopOfFile(sourceFile, newNode, blankLineBetween) { + this.insertAtTopOfFile(sourceFile, newNode, blankLineBetween); + } + insertNodesAtTopOfFile(sourceFile, newNodes, blankLineBetween) { + this.insertAtTopOfFile(sourceFile, newNodes, blankLineBetween); + } + insertAtTopOfFile(sourceFile, insert, blankLineBetween) { + const pos = getInsertionPositionAtSourceFileTop(sourceFile); + const options = { + prefix: pos === 0 ? void 0 : this.newLineCharacter, + suffix: (isLineBreak(sourceFile.text.charCodeAt(pos)) ? "" : this.newLineCharacter) + (blankLineBetween ? this.newLineCharacter : "") + }; + if (isArray(insert)) { + this.insertNodesAt(sourceFile, pos, insert, options); + } else { + this.insertNodeAt(sourceFile, pos, insert, options); + } + } + insertNodesAtEndOfFile(sourceFile, newNodes, blankLineBetween) { + this.insertAtEndOfFile(sourceFile, newNodes, blankLineBetween); + } + insertAtEndOfFile(sourceFile, insert, blankLineBetween) { + const pos = sourceFile.end + 1; + const options = { + prefix: this.newLineCharacter, + suffix: this.newLineCharacter + (blankLineBetween ? this.newLineCharacter : "") + }; + this.insertNodesAt(sourceFile, pos, insert, options); + } + insertStatementsInNewFile(fileName, statements, oldFile) { + if (!this.newFileChanges) { + this.newFileChanges = createMultiMap(); + } + this.newFileChanges.add(fileName, { oldFile, statements }); + } + insertFirstParameter(sourceFile, parameters, newParam) { + const p0 = firstOrUndefined(parameters); + if (p0) { + this.insertNodeBefore(sourceFile, p0, newParam); + } else { + this.insertNodeAt(sourceFile, parameters.pos, newParam); + } + } + insertNodeBefore(sourceFile, before, newNode, blankLineBetween = false, options = {}) { + this.insertNodeAt(sourceFile, getAdjustedStartPosition(sourceFile, before, options), newNode, this.getOptionsForInsertNodeBefore(before, newNode, blankLineBetween)); + } + insertNodesBefore(sourceFile, before, newNodes, blankLineBetween = false, options = {}) { + this.insertNodesAt(sourceFile, getAdjustedStartPosition(sourceFile, before, options), newNodes, this.getOptionsForInsertNodeBefore(before, first(newNodes), blankLineBetween)); + } + insertModifierAt(sourceFile, pos, modifier, options = {}) { + this.insertNodeAt(sourceFile, pos, factory.createToken(modifier), options); + } + insertModifierBefore(sourceFile, modifier, before) { + return this.insertModifierAt(sourceFile, before.getStart(sourceFile), modifier, { suffix: " " }); + } + insertCommentBeforeLine(sourceFile, lineNumber, position, commentText) { + const lineStartPosition = getStartPositionOfLine(lineNumber, sourceFile); + const startPosition = getFirstNonSpaceCharacterPosition(sourceFile.text, lineStartPosition); + const insertAtLineStart = isValidLocationToAddComment(sourceFile, startPosition); + const token = getTouchingToken(sourceFile, insertAtLineStart ? startPosition : position); + const indent3 = sourceFile.text.slice(lineStartPosition, startPosition); + const text = `${insertAtLineStart ? "" : this.newLineCharacter}//${commentText}${this.newLineCharacter}${indent3}`; + this.insertText(sourceFile, token.getStart(sourceFile), text); + } + insertJsdocCommentBefore(sourceFile, node, tag) { + const fnStart = node.getStart(sourceFile); + if (node.jsDoc) { + for (const jsdoc of node.jsDoc) { + this.deleteRange(sourceFile, { + pos: getLineStartPositionForPosition(jsdoc.getStart(sourceFile), sourceFile), + end: getAdjustedEndPosition( + sourceFile, + jsdoc, + /*options*/ + {} + ) + }); + } + } + const startPosition = getPrecedingNonSpaceCharacterPosition(sourceFile.text, fnStart - 1); + const indent3 = sourceFile.text.slice(startPosition, fnStart); + this.insertNodeAt(sourceFile, fnStart, tag, { suffix: this.newLineCharacter + indent3 }); + } + createJSDocText(sourceFile, node) { + const comments = flatMap(node.jsDoc, (jsDoc2) => isString(jsDoc2.comment) ? factory.createJSDocText(jsDoc2.comment) : jsDoc2.comment); + const jsDoc = singleOrUndefined(node.jsDoc); + return jsDoc && positionsAreOnSameLine(jsDoc.pos, jsDoc.end, sourceFile) && length(comments) === 0 ? void 0 : factory.createNodeArray(intersperse(comments, factory.createJSDocText("\n"))); + } + replaceJSDocComment(sourceFile, node, tags) { + this.insertJsdocCommentBefore(sourceFile, updateJSDocHost(node), factory.createJSDocComment(this.createJSDocText(sourceFile, node), factory.createNodeArray(tags))); + } + addJSDocTags(sourceFile, parent2, newTags) { + const oldTags = flatMapToMutable(parent2.jsDoc, (j) => j.tags); + const unmergedNewTags = newTags.filter( + (newTag) => !oldTags.some((tag, i) => { + const merged = tryMergeJsdocTags(tag, newTag); + if (merged) + oldTags[i] = merged; + return !!merged; + }) + ); + this.replaceJSDocComment(sourceFile, parent2, [...oldTags, ...unmergedNewTags]); + } + filterJSDocTags(sourceFile, parent2, predicate) { + this.replaceJSDocComment(sourceFile, parent2, filter(flatMapToMutable(parent2.jsDoc, (j) => j.tags), predicate)); + } + replaceRangeWithText(sourceFile, range, text) { + this.changes.push({ kind: 3 /* Text */, sourceFile, range, text }); + } + insertText(sourceFile, pos, text) { + this.replaceRangeWithText(sourceFile, createRange(pos), text); + } + /** Prefer this over replacing a node with another that has a type annotation, as it avoids reformatting the other parts of the node. */ + tryInsertTypeAnnotation(sourceFile, node, type) { + let endNode2; + if (isFunctionLike(node)) { + endNode2 = findChildOfKind(node, 22 /* CloseParenToken */, sourceFile); + if (!endNode2) { + if (!isArrowFunction(node)) + return false; + endNode2 = first(node.parameters); + } + } else { + endNode2 = (node.kind === 260 /* VariableDeclaration */ ? node.exclamationToken : node.questionToken) ?? node.name; + } + this.insertNodeAt(sourceFile, endNode2.end, type, { prefix: ": " }); + return true; + } + tryInsertThisTypeAnnotation(sourceFile, node, type) { + const start = findChildOfKind(node, 21 /* OpenParenToken */, sourceFile).getStart(sourceFile) + 1; + const suffix = node.parameters.length ? ", " : ""; + this.insertNodeAt(sourceFile, start, type, { prefix: "this: ", suffix }); + } + insertTypeParameters(sourceFile, node, typeParameters) { + const start = (findChildOfKind(node, 21 /* OpenParenToken */, sourceFile) || first(node.parameters)).getStart(sourceFile); + this.insertNodesAt(sourceFile, start, typeParameters, { prefix: "<", suffix: ">", joiner: ", " }); + } + getOptionsForInsertNodeBefore(before, inserted, blankLineBetween) { + if (isStatement(before) || isClassElement(before)) { + return { suffix: blankLineBetween ? this.newLineCharacter + this.newLineCharacter : this.newLineCharacter }; + } else if (isVariableDeclaration(before)) { + return { suffix: ", " }; + } else if (isParameter(before)) { + return isParameter(inserted) ? { suffix: ", " } : {}; + } else if (isStringLiteral(before) && isImportDeclaration(before.parent) || isNamedImports(before)) { + return { suffix: ", " }; + } else if (isImportSpecifier(before)) { + return { suffix: "," + (blankLineBetween ? this.newLineCharacter : " ") }; + } + return Debug.failBadSyntaxKind(before); + } + insertNodeAtConstructorStart(sourceFile, ctr, newStatement) { + const firstStatement = firstOrUndefined(ctr.body.statements); + if (!firstStatement || !ctr.body.multiLine) { + this.replaceConstructorBody(sourceFile, ctr, [newStatement, ...ctr.body.statements]); + } else { + this.insertNodeBefore(sourceFile, firstStatement, newStatement); + } + } + insertNodeAtConstructorStartAfterSuperCall(sourceFile, ctr, newStatement) { + const superCallStatement = find(ctr.body.statements, (stmt) => isExpressionStatement(stmt) && isSuperCall(stmt.expression)); + if (!superCallStatement || !ctr.body.multiLine) { + this.replaceConstructorBody(sourceFile, ctr, [...ctr.body.statements, newStatement]); + } else { + this.insertNodeAfter(sourceFile, superCallStatement, newStatement); + } + } + insertNodeAtConstructorEnd(sourceFile, ctr, newStatement) { + const lastStatement = lastOrUndefined(ctr.body.statements); + if (!lastStatement || !ctr.body.multiLine) { + this.replaceConstructorBody(sourceFile, ctr, [...ctr.body.statements, newStatement]); + } else { + this.insertNodeAfter(sourceFile, lastStatement, newStatement); + } + } + replaceConstructorBody(sourceFile, ctr, statements) { + this.replaceNode(sourceFile, ctr.body, factory.createBlock( + statements, + /*multiLine*/ + true + )); + } + insertNodeAtEndOfScope(sourceFile, scope, newNode) { + const pos = getAdjustedStartPosition(sourceFile, scope.getLastToken(), {}); + this.insertNodeAt(sourceFile, pos, newNode, { + prefix: isLineBreak(sourceFile.text.charCodeAt(scope.getLastToken().pos)) ? this.newLineCharacter : this.newLineCharacter + this.newLineCharacter, + suffix: this.newLineCharacter + }); + } + insertMemberAtStart(sourceFile, node, newElement) { + this.insertNodeAtStartWorker(sourceFile, node, newElement); + } + insertNodeAtObjectStart(sourceFile, obj, newElement) { + this.insertNodeAtStartWorker(sourceFile, obj, newElement); + } + insertNodeAtStartWorker(sourceFile, node, newElement) { + const indentation = this.guessIndentationFromExistingMembers(sourceFile, node) ?? this.computeIndentationForNewMember(sourceFile, node); + this.insertNodeAt(sourceFile, getMembersOrProperties(node).pos, newElement, this.getInsertNodeAtStartInsertOptions(sourceFile, node, indentation)); + } + /** + * Tries to guess the indentation from the existing members of a class/interface/object. All members must be on + * new lines and must share the same indentation. + */ + guessIndentationFromExistingMembers(sourceFile, node) { + let indentation; + let lastRange = node; + for (const member of getMembersOrProperties(node)) { + if (rangeStartPositionsAreOnSameLine(lastRange, member, sourceFile)) { + return void 0; + } + const memberStart = member.getStart(sourceFile); + const memberIndentation = ts_formatting_exports.SmartIndenter.findFirstNonWhitespaceColumn(getLineStartPositionForPosition(memberStart, sourceFile), memberStart, sourceFile, this.formatContext.options); + if (indentation === void 0) { + indentation = memberIndentation; + } else if (memberIndentation !== indentation) { + return void 0; + } + lastRange = member; + } + return indentation; + } + computeIndentationForNewMember(sourceFile, node) { + const nodeStart = node.getStart(sourceFile); + return ts_formatting_exports.SmartIndenter.findFirstNonWhitespaceColumn(getLineStartPositionForPosition(nodeStart, sourceFile), nodeStart, sourceFile, this.formatContext.options) + (this.formatContext.options.indentSize ?? 4); + } + getInsertNodeAtStartInsertOptions(sourceFile, node, indentation) { + const members = getMembersOrProperties(node); + const isEmpty = members.length === 0; + const isFirstInsertion = addToSeen(this.classesWithNodesInsertedAtStart, getNodeId(node), { node, sourceFile }); + const insertTrailingComma = isObjectLiteralExpression(node) && (!isJsonSourceFile(sourceFile) || !isEmpty); + const insertLeadingComma = isObjectLiteralExpression(node) && isJsonSourceFile(sourceFile) && isEmpty && !isFirstInsertion; + return { + indentation, + prefix: (insertLeadingComma ? "," : "") + this.newLineCharacter, + suffix: insertTrailingComma ? "," : isInterfaceDeclaration(node) && isEmpty ? ";" : "" + }; + } + insertNodeAfterComma(sourceFile, after, newNode) { + const endPosition = this.insertNodeAfterWorker(sourceFile, this.nextCommaToken(sourceFile, after) || after, newNode); + this.insertNodeAt(sourceFile, endPosition, newNode, this.getInsertNodeAfterOptions(sourceFile, after)); + } + insertNodeAfter(sourceFile, after, newNode) { + const endPosition = this.insertNodeAfterWorker(sourceFile, after, newNode); + this.insertNodeAt(sourceFile, endPosition, newNode, this.getInsertNodeAfterOptions(sourceFile, after)); + } + insertNodeAtEndOfList(sourceFile, list, newNode) { + this.insertNodeAt(sourceFile, list.end, newNode, { prefix: ", " }); + } + insertNodesAfter(sourceFile, after, newNodes) { + const endPosition = this.insertNodeAfterWorker(sourceFile, after, first(newNodes)); + this.insertNodesAt(sourceFile, endPosition, newNodes, this.getInsertNodeAfterOptions(sourceFile, after)); + } + insertNodeAfterWorker(sourceFile, after, newNode) { + if (needSemicolonBetween(after, newNode)) { + if (sourceFile.text.charCodeAt(after.end - 1) !== 59 /* semicolon */) { + this.replaceRange(sourceFile, createRange(after.end), factory.createToken(27 /* SemicolonToken */)); + } + } + const endPosition = getAdjustedEndPosition(sourceFile, after, {}); + return endPosition; + } + getInsertNodeAfterOptions(sourceFile, after) { + const options = this.getInsertNodeAfterOptionsWorker(after); + return { + ...options, + prefix: after.end === sourceFile.end && isStatement(after) ? options.prefix ? ` +${options.prefix}` : "\n" : options.prefix + }; + } + getInsertNodeAfterOptionsWorker(node) { + switch (node.kind) { + case 263 /* ClassDeclaration */: + case 267 /* ModuleDeclaration */: + return { prefix: this.newLineCharacter, suffix: this.newLineCharacter }; + case 260 /* VariableDeclaration */: + case 11 /* StringLiteral */: + case 80 /* Identifier */: + return { prefix: ", " }; + case 303 /* PropertyAssignment */: + return { suffix: "," + this.newLineCharacter }; + case 95 /* ExportKeyword */: + return { prefix: " " }; + case 169 /* Parameter */: + return {}; + default: + Debug.assert(isStatement(node) || isClassOrTypeElement(node)); + return { suffix: this.newLineCharacter }; + } + } + insertName(sourceFile, node, name) { + Debug.assert(!node.name); + if (node.kind === 219 /* ArrowFunction */) { + const arrow = findChildOfKind(node, 39 /* EqualsGreaterThanToken */, sourceFile); + const lparen = findChildOfKind(node, 21 /* OpenParenToken */, sourceFile); + if (lparen) { + this.insertNodesAt(sourceFile, lparen.getStart(sourceFile), [factory.createToken(100 /* FunctionKeyword */), factory.createIdentifier(name)], { joiner: " " }); + deleteNode(this, sourceFile, arrow); + } else { + this.insertText(sourceFile, first(node.parameters).getStart(sourceFile), `function ${name}(`); + this.replaceRange(sourceFile, arrow, factory.createToken(22 /* CloseParenToken */)); + } + if (node.body.kind !== 241 /* Block */) { + this.insertNodesAt(sourceFile, node.body.getStart(sourceFile), [factory.createToken(19 /* OpenBraceToken */), factory.createToken(107 /* ReturnKeyword */)], { joiner: " ", suffix: " " }); + this.insertNodesAt(sourceFile, node.body.end, [factory.createToken(27 /* SemicolonToken */), factory.createToken(20 /* CloseBraceToken */)], { joiner: " " }); + } + } else { + const pos = findChildOfKind(node, node.kind === 218 /* FunctionExpression */ ? 100 /* FunctionKeyword */ : 86 /* ClassKeyword */, sourceFile).end; + this.insertNodeAt(sourceFile, pos, factory.createIdentifier(name), { prefix: " " }); + } + } + insertExportModifier(sourceFile, node) { + this.insertText(sourceFile, node.getStart(sourceFile), "export "); + } + insertImportSpecifierAtIndex(sourceFile, importSpecifier, namedImports, index) { + const prevSpecifier = namedImports.elements[index - 1]; + if (prevSpecifier) { + this.insertNodeInListAfter(sourceFile, prevSpecifier, importSpecifier); + } else { + this.insertNodeBefore( + sourceFile, + namedImports.elements[0], + importSpecifier, + !positionsAreOnSameLine(namedImports.elements[0].getStart(), namedImports.parent.parent.getStart(), sourceFile) + ); + } + } + /** + * This function should be used to insert nodes in lists when nodes don't carry separators as the part of the node range, + * i.e. arguments in arguments lists, parameters in parameter lists etc. + * Note that separators are part of the node in statements and class elements. + */ + insertNodeInListAfter(sourceFile, after, newNode, containingList = ts_formatting_exports.SmartIndenter.getContainingList(after, sourceFile)) { + if (!containingList) { + Debug.fail("node is not a list element"); + return; + } + const index = indexOfNode(containingList, after); + if (index < 0) { + return; + } + const end = after.getEnd(); + if (index !== containingList.length - 1) { + const nextToken = getTokenAtPosition(sourceFile, after.end); + if (nextToken && isSeparator(after, nextToken)) { + const nextNode = containingList[index + 1]; + const startPos = skipWhitespacesAndLineBreaks(sourceFile.text, nextNode.getFullStart()); + const suffix = `${tokenToString(nextToken.kind)}${sourceFile.text.substring(nextToken.end, startPos)}`; + this.insertNodesAt(sourceFile, startPos, [newNode], { suffix }); + } + } else { + const afterStart = after.getStart(sourceFile); + const afterStartLinePosition = getLineStartPositionForPosition(afterStart, sourceFile); + let separator; + let multilineList = false; + if (containingList.length === 1) { + separator = 28 /* CommaToken */; + } else { + const tokenBeforeInsertPosition = findPrecedingToken(after.pos, sourceFile); + separator = isSeparator(after, tokenBeforeInsertPosition) ? tokenBeforeInsertPosition.kind : 28 /* CommaToken */; + const afterMinusOneStartLinePosition = getLineStartPositionForPosition(containingList[index - 1].getStart(sourceFile), sourceFile); + multilineList = afterMinusOneStartLinePosition !== afterStartLinePosition; + } + if (hasCommentsBeforeLineBreak(sourceFile.text, after.end)) { + multilineList = true; + } + if (multilineList) { + this.replaceRange(sourceFile, createRange(end), factory.createToken(separator)); + const indentation = ts_formatting_exports.SmartIndenter.findFirstNonWhitespaceColumn(afterStartLinePosition, afterStart, sourceFile, this.formatContext.options); + let insertPos = skipTrivia( + sourceFile.text, + end, + /*stopAfterLineBreak*/ + true, + /*stopAtComments*/ + false + ); + while (insertPos !== end && isLineBreak(sourceFile.text.charCodeAt(insertPos - 1))) { + insertPos--; + } + this.replaceRange(sourceFile, createRange(insertPos), newNode, { indentation, prefix: this.newLineCharacter }); + } else { + this.replaceRange(sourceFile, createRange(end), newNode, { prefix: `${tokenToString(separator)} ` }); + } + } + } + parenthesizeExpression(sourceFile, expression) { + this.replaceRange(sourceFile, rangeOfNode(expression), factory.createParenthesizedExpression(expression)); + } + finishClassesWithNodesInsertedAtStart() { + this.classesWithNodesInsertedAtStart.forEach(({ node, sourceFile }) => { + const [openBraceEnd, closeBraceEnd] = getClassOrObjectBraceEnds(node, sourceFile); + if (openBraceEnd !== void 0 && closeBraceEnd !== void 0) { + const isEmpty = getMembersOrProperties(node).length === 0; + const isSingleLine = positionsAreOnSameLine(openBraceEnd, closeBraceEnd, sourceFile); + if (isEmpty && isSingleLine && openBraceEnd !== closeBraceEnd - 1) { + this.deleteRange(sourceFile, createRange(openBraceEnd, closeBraceEnd - 1)); + } + if (isSingleLine) { + this.insertText(sourceFile, closeBraceEnd - 1, this.newLineCharacter); + } + } + }); + } + finishDeleteDeclarations() { + const deletedNodesInLists = /* @__PURE__ */ new Set(); + for (const { sourceFile, node } of this.deletedNodes) { + if (!this.deletedNodes.some((d) => d.sourceFile === sourceFile && rangeContainsRangeExclusive(d.node, node))) { + if (isArray(node)) { + this.deleteRange(sourceFile, rangeOfTypeParameters(sourceFile, node)); + } else { + deleteDeclaration.deleteDeclaration(this, deletedNodesInLists, sourceFile, node); + } + } + } + deletedNodesInLists.forEach((node) => { + const sourceFile = node.getSourceFile(); + const list = ts_formatting_exports.SmartIndenter.getContainingList(node, sourceFile); + if (node !== last(list)) + return; + const lastNonDeletedIndex = findLastIndex(list, (n) => !deletedNodesInLists.has(n), list.length - 2); + if (lastNonDeletedIndex !== -1) { + this.deleteRange(sourceFile, { pos: list[lastNonDeletedIndex].end, end: startPositionToDeleteNodeInList(sourceFile, list[lastNonDeletedIndex + 1]) }); + } + }); + } + /** + * Note: after calling this, the TextChanges object must be discarded! + * @param validate only for tests + * The reason we must validate as part of this method is that `getNonFormattedText` changes the node's positions, + * so we can only call this once and can't get the non-formatted text separately. + */ + getChanges(validate) { + this.finishDeleteDeclarations(); + this.finishClassesWithNodesInsertedAtStart(); + const changes = changesToText.getTextChangesFromChanges(this.changes, this.newLineCharacter, this.formatContext, validate); + if (this.newFileChanges) { + this.newFileChanges.forEach((insertions, fileName) => { + changes.push(changesToText.newFileChanges(fileName, insertions, this.newLineCharacter, this.formatContext)); + }); + } + return changes; + } + createNewFile(oldFile, fileName, statements) { + this.insertStatementsInNewFile(fileName, statements, oldFile); + } + }; + ((changesToText2) => { + function getTextChangesFromChanges(changes, newLineCharacter, formatContext, validate) { + return mapDefined(group(changes, (c) => c.sourceFile.path), (changesInFile) => { + const sourceFile = changesInFile[0].sourceFile; + const normalized = stableSort(changesInFile, (a, b) => a.range.pos - b.range.pos || a.range.end - b.range.end); + for (let i = 0; i < normalized.length - 1; i++) { + Debug.assert(normalized[i].range.end <= normalized[i + 1].range.pos, "Changes overlap", () => `${JSON.stringify(normalized[i].range)} and ${JSON.stringify(normalized[i + 1].range)}`); + } + const textChanges2 = mapDefined(normalized, (c) => { + const span = createTextSpanFromRange(c.range); + const targetSourceFile = c.kind === 1 /* ReplaceWithSingleNode */ ? getSourceFileOfNode(getOriginalNode(c.node)) ?? c.sourceFile : c.kind === 2 /* ReplaceWithMultipleNodes */ ? getSourceFileOfNode(getOriginalNode(c.nodes[0])) ?? c.sourceFile : c.sourceFile; + const newText = computeNewText(c, targetSourceFile, sourceFile, newLineCharacter, formatContext, validate); + if (span.length === newText.length && stringContainsAt(targetSourceFile.text, newText, span.start)) { + return void 0; + } + return createTextChange(span, newText); + }); + return textChanges2.length > 0 ? { fileName: sourceFile.fileName, textChanges: textChanges2 } : void 0; + }); + } + changesToText2.getTextChangesFromChanges = getTextChangesFromChanges; + function newFileChanges(fileName, insertions, newLineCharacter, formatContext) { + const text = newFileChangesWorker(getScriptKindFromFileName(fileName), insertions, newLineCharacter, formatContext); + return { fileName, textChanges: [createTextChange(createTextSpan(0, 0), text)], isNewFile: true }; + } + changesToText2.newFileChanges = newFileChanges; + function newFileChangesWorker(scriptKind, insertions, newLineCharacter, formatContext) { + const nonFormattedText = flatMap(insertions, (insertion) => insertion.statements.map((s) => s === 4 /* NewLineTrivia */ ? "" : getNonformattedText(s, insertion.oldFile, newLineCharacter).text)).join(newLineCharacter); + const sourceFile = createSourceFile( + "any file name", + nonFormattedText, + { languageVersion: 99 /* ESNext */, jsDocParsingMode: 1 /* ParseNone */ }, + /*setParentNodes*/ + true, + scriptKind + ); + const changes = ts_formatting_exports.formatDocument(sourceFile, formatContext); + return applyChanges(nonFormattedText, changes) + newLineCharacter; + } + changesToText2.newFileChangesWorker = newFileChangesWorker; + function computeNewText(change, targetSourceFile, sourceFile, newLineCharacter, formatContext, validate) { + var _a; + if (change.kind === 0 /* Remove */) { + return ""; + } + if (change.kind === 3 /* Text */) { + return change.text; + } + const { options = {}, range: { pos } } = change; + const format = (n) => getFormattedTextOfNode(n, targetSourceFile, sourceFile, pos, options, newLineCharacter, formatContext, validate); + const text = change.kind === 2 /* ReplaceWithMultipleNodes */ ? change.nodes.map((n) => removeSuffix(format(n), newLineCharacter)).join(((_a = change.options) == null ? void 0 : _a.joiner) || newLineCharacter) : format(change.node); + const noIndent = options.indentation !== void 0 || getLineStartPositionForPosition(pos, targetSourceFile) === pos ? text : text.replace(/^\s+/, ""); + return (options.prefix || "") + noIndent + (!options.suffix || endsWith(noIndent, options.suffix) ? "" : options.suffix); + } + function getFormattedTextOfNode(nodeIn, targetSourceFile, sourceFile, pos, { indentation, prefix, delta }, newLineCharacter, formatContext, validate) { + const { node, text } = getNonformattedText(nodeIn, targetSourceFile, newLineCharacter); + if (validate) + validate(node, text); + const formatOptions = getFormatCodeSettingsForWriting(formatContext, targetSourceFile); + const initialIndentation = indentation !== void 0 ? indentation : ts_formatting_exports.SmartIndenter.getIndentation(pos, sourceFile, formatOptions, prefix === newLineCharacter || getLineStartPositionForPosition(pos, targetSourceFile) === pos); + if (delta === void 0) { + delta = ts_formatting_exports.SmartIndenter.shouldIndentChildNode(formatOptions, nodeIn) ? formatOptions.indentSize || 0 : 0; + } + const file = { + text, + getLineAndCharacterOfPosition(pos2) { + return getLineAndCharacterOfPosition(this, pos2); + } + }; + const changes = ts_formatting_exports.formatNodeGivenIndentation(node, file, targetSourceFile.languageVariant, initialIndentation, delta, { ...formatContext, options: formatOptions }); + return applyChanges(text, changes); + } + function getNonformattedText(node, sourceFile, newLineCharacter) { + const writer = createWriter(newLineCharacter); + const newLine = getNewLineKind(newLineCharacter); + createPrinter({ + newLine, + neverAsciiEscape: true, + preserveSourceNewlines: true, + terminateUnterminatedLiterals: true + }, writer).writeNode(4 /* Unspecified */, node, sourceFile, writer); + return { text: writer.getText(), node: assignPositionsToNode(node) }; + } + changesToText2.getNonformattedText = getNonformattedText; + })(changesToText || (changesToText = {})); + textChangesTransformationContext = { + ...nullTransformationContext, + factory: createNodeFactory( + nullTransformationContext.factory.flags | 1 /* NoParenthesizerRules */, + nullTransformationContext.factory.baseFactory + ) + }; + ((_deleteDeclaration) => { + function deleteDeclaration2(changes, deletedNodesInLists, sourceFile, node) { + switch (node.kind) { + case 169 /* Parameter */: { + const oldFunction = node.parent; + if (isArrowFunction(oldFunction) && oldFunction.parameters.length === 1 && !findChildOfKind(oldFunction, 21 /* OpenParenToken */, sourceFile)) { + changes.replaceNodeWithText(sourceFile, node, "()"); + } else { + deleteNodeInList(changes, deletedNodesInLists, sourceFile, node); + } + break; + } + case 272 /* ImportDeclaration */: + case 271 /* ImportEqualsDeclaration */: + const isFirstImport = sourceFile.imports.length && node === first(sourceFile.imports).parent || node === find(sourceFile.statements, isAnyImportSyntax); + deleteNode(changes, sourceFile, node, { + leadingTriviaOption: isFirstImport ? 0 /* Exclude */ : hasJSDocNodes(node) ? 2 /* JSDoc */ : 3 /* StartLine */ + }); + break; + case 208 /* BindingElement */: + const pattern = node.parent; + const preserveComma = pattern.kind === 207 /* ArrayBindingPattern */ && node !== last(pattern.elements); + if (preserveComma) { + deleteNode(changes, sourceFile, node); + } else { + deleteNodeInList(changes, deletedNodesInLists, sourceFile, node); + } + break; + case 260 /* VariableDeclaration */: + deleteVariableDeclaration(changes, deletedNodesInLists, sourceFile, node); + break; + case 168 /* TypeParameter */: + deleteNodeInList(changes, deletedNodesInLists, sourceFile, node); + break; + case 276 /* ImportSpecifier */: + const namedImports = node.parent; + if (namedImports.elements.length === 1) { + deleteImportBinding(changes, sourceFile, namedImports); + } else { + deleteNodeInList(changes, deletedNodesInLists, sourceFile, node); + } + break; + case 274 /* NamespaceImport */: + deleteImportBinding(changes, sourceFile, node); + break; + case 27 /* SemicolonToken */: + deleteNode(changes, sourceFile, node, { trailingTriviaOption: 0 /* Exclude */ }); + break; + case 100 /* FunctionKeyword */: + deleteNode(changes, sourceFile, node, { leadingTriviaOption: 0 /* Exclude */ }); + break; + case 263 /* ClassDeclaration */: + case 262 /* FunctionDeclaration */: + deleteNode(changes, sourceFile, node, { leadingTriviaOption: hasJSDocNodes(node) ? 2 /* JSDoc */ : 3 /* StartLine */ }); + break; + default: + if (!node.parent) { + deleteNode(changes, sourceFile, node); + } else if (isImportClause(node.parent) && node.parent.name === node) { + deleteDefaultImport(changes, sourceFile, node.parent); + } else if (isCallExpression(node.parent) && contains(node.parent.arguments, node)) { + deleteNodeInList(changes, deletedNodesInLists, sourceFile, node); + } else { + deleteNode(changes, sourceFile, node); + } + } + } + _deleteDeclaration.deleteDeclaration = deleteDeclaration2; + function deleteDefaultImport(changes, sourceFile, importClause) { + if (!importClause.namedBindings) { + deleteNode(changes, sourceFile, importClause.parent); + } else { + const start = importClause.name.getStart(sourceFile); + const nextToken = getTokenAtPosition(sourceFile, importClause.name.end); + if (nextToken && nextToken.kind === 28 /* CommaToken */) { + const end = skipTrivia( + sourceFile.text, + nextToken.end, + /*stopAfterLineBreak*/ + false, + /*stopAtComments*/ + true + ); + changes.deleteRange(sourceFile, { pos: start, end }); + } else { + deleteNode(changes, sourceFile, importClause.name); + } + } + } + function deleteImportBinding(changes, sourceFile, node) { + if (node.parent.name) { + const previousToken = Debug.checkDefined(getTokenAtPosition(sourceFile, node.pos - 1)); + changes.deleteRange(sourceFile, { pos: previousToken.getStart(sourceFile), end: node.end }); + } else { + const importDecl = getAncestor(node, 272 /* ImportDeclaration */); + deleteNode(changes, sourceFile, importDecl); + } + } + function deleteVariableDeclaration(changes, deletedNodesInLists, sourceFile, node) { + const { parent: parent2 } = node; + if (parent2.kind === 299 /* CatchClause */) { + changes.deleteNodeRange(sourceFile, findChildOfKind(parent2, 21 /* OpenParenToken */, sourceFile), findChildOfKind(parent2, 22 /* CloseParenToken */, sourceFile)); + return; + } + if (parent2.declarations.length !== 1) { + deleteNodeInList(changes, deletedNodesInLists, sourceFile, node); + return; + } + const gp = parent2.parent; + switch (gp.kind) { + case 250 /* ForOfStatement */: + case 249 /* ForInStatement */: + changes.replaceNode(sourceFile, node, factory.createObjectLiteralExpression()); + break; + case 248 /* ForStatement */: + deleteNode(changes, sourceFile, parent2); + break; + case 243 /* VariableStatement */: + deleteNode(changes, sourceFile, gp, { leadingTriviaOption: hasJSDocNodes(gp) ? 2 /* JSDoc */ : 3 /* StartLine */ }); + break; + default: + Debug.assertNever(gp); + } + } + })(deleteDeclaration || (deleteDeclaration = {})); } - } - var init_goToDefinition = __esm({ - "src/services/goToDefinition.ts"() { + }); + + // src/services/_namespaces/ts.textChanges.ts + var ts_textChanges_exports = {}; + __export(ts_textChanges_exports, { + ChangeTracker: () => ChangeTracker, + LeadingTriviaOption: () => LeadingTriviaOption, + TrailingTriviaOption: () => TrailingTriviaOption, + applyChanges: () => applyChanges, + assignPositionsToNode: () => assignPositionsToNode, + createWriter: () => createWriter, + deleteNode: () => deleteNode, + isThisTypeAnnotatable: () => isThisTypeAnnotatable, + isValidLocationToAddComment: () => isValidLocationToAddComment + }); + var init_ts_textChanges = __esm({ + "src/services/_namespaces/ts.textChanges.ts"() { "use strict"; - init_ts4(); + init_textChanges(); } }); - // src/services/_namespaces/ts.GoToDefinition.ts - var ts_GoToDefinition_exports = {}; - __export(ts_GoToDefinition_exports, { - createDefinitionInfo: () => createDefinitionInfo, - findReferenceInPosition: () => findReferenceInPosition, - getDefinitionAndBoundSpan: () => getDefinitionAndBoundSpan, - getDefinitionAtPosition: () => getDefinitionAtPosition, - getReferenceAtPosition: () => getReferenceAtPosition, - getTypeDefinitionAtPosition: () => getTypeDefinitionAtPosition - }); - var init_ts_GoToDefinition = __esm({ - "src/services/_namespaces/ts.GoToDefinition.ts"() { + // src/services/formatting/formattingContext.ts + var FormattingRequestKind, FormattingContext; + var init_formattingContext = __esm({ + "src/services/formatting/formattingContext.ts"() { "use strict"; - init_goToDefinition(); + init_ts4(); + FormattingRequestKind = /* @__PURE__ */ ((FormattingRequestKind2) => { + FormattingRequestKind2[FormattingRequestKind2["FormatDocument"] = 0] = "FormatDocument"; + FormattingRequestKind2[FormattingRequestKind2["FormatSelection"] = 1] = "FormatSelection"; + FormattingRequestKind2[FormattingRequestKind2["FormatOnEnter"] = 2] = "FormatOnEnter"; + FormattingRequestKind2[FormattingRequestKind2["FormatOnSemicolon"] = 3] = "FormatOnSemicolon"; + FormattingRequestKind2[FormattingRequestKind2["FormatOnOpeningCurlyBrace"] = 4] = "FormatOnOpeningCurlyBrace"; + FormattingRequestKind2[FormattingRequestKind2["FormatOnClosingCurlyBrace"] = 5] = "FormatOnClosingCurlyBrace"; + return FormattingRequestKind2; + })(FormattingRequestKind || {}); + FormattingContext = class { + constructor(sourceFile, formattingRequestKind, options) { + this.sourceFile = sourceFile; + this.formattingRequestKind = formattingRequestKind; + this.options = options; + } + updateContext(currentRange, currentTokenParent, nextRange, nextTokenParent, commonParent) { + this.currentTokenSpan = Debug.checkDefined(currentRange); + this.currentTokenParent = Debug.checkDefined(currentTokenParent); + this.nextTokenSpan = Debug.checkDefined(nextRange); + this.nextTokenParent = Debug.checkDefined(nextTokenParent); + this.contextNode = Debug.checkDefined(commonParent); + this.contextNodeAllOnSameLine = void 0; + this.nextNodeAllOnSameLine = void 0; + this.tokensAreOnSameLine = void 0; + this.contextNodeBlockIsOnOneLine = void 0; + this.nextNodeBlockIsOnOneLine = void 0; + } + ContextNodeAllOnSameLine() { + if (this.contextNodeAllOnSameLine === void 0) { + this.contextNodeAllOnSameLine = this.NodeIsOnOneLine(this.contextNode); + } + return this.contextNodeAllOnSameLine; + } + NextNodeAllOnSameLine() { + if (this.nextNodeAllOnSameLine === void 0) { + this.nextNodeAllOnSameLine = this.NodeIsOnOneLine(this.nextTokenParent); + } + return this.nextNodeAllOnSameLine; + } + TokensAreOnSameLine() { + if (this.tokensAreOnSameLine === void 0) { + const startLine = this.sourceFile.getLineAndCharacterOfPosition(this.currentTokenSpan.pos).line; + const endLine = this.sourceFile.getLineAndCharacterOfPosition(this.nextTokenSpan.pos).line; + this.tokensAreOnSameLine = startLine === endLine; + } + return this.tokensAreOnSameLine; + } + ContextNodeBlockIsOnOneLine() { + if (this.contextNodeBlockIsOnOneLine === void 0) { + this.contextNodeBlockIsOnOneLine = this.BlockIsOnOneLine(this.contextNode); + } + return this.contextNodeBlockIsOnOneLine; + } + NextNodeBlockIsOnOneLine() { + if (this.nextNodeBlockIsOnOneLine === void 0) { + this.nextNodeBlockIsOnOneLine = this.BlockIsOnOneLine(this.nextTokenParent); + } + return this.nextNodeBlockIsOnOneLine; + } + NodeIsOnOneLine(node) { + const startLine = this.sourceFile.getLineAndCharacterOfPosition(node.getStart(this.sourceFile)).line; + const endLine = this.sourceFile.getLineAndCharacterOfPosition(node.getEnd()).line; + return startLine === endLine; + } + BlockIsOnOneLine(node) { + const openBrace = findChildOfKind(node, 19 /* OpenBraceToken */, this.sourceFile); + const closeBrace = findChildOfKind(node, 20 /* CloseBraceToken */, this.sourceFile); + if (openBrace && closeBrace) { + const startLine = this.sourceFile.getLineAndCharacterOfPosition(openBrace.getEnd()).line; + const endLine = this.sourceFile.getLineAndCharacterOfPosition(closeBrace.getStart(this.sourceFile)).line; + return startLine === endLine; + } + return false; + } + }; } }); - // src/services/inlayHints.ts - function shouldShowParameterNameHints(preferences) { - return preferences.includeInlayParameterNameHints === "literals" || preferences.includeInlayParameterNameHints === "all"; - } - function shouldShowLiteralParameterNameHintsOnly(preferences) { - return preferences.includeInlayParameterNameHints === "literals"; - } - function provideInlayHints(context) { - const { file, program, span, cancellationToken, preferences } = context; - const sourceFileText = file.text; - const compilerOptions = program.getCompilerOptions(); - const checker = program.getTypeChecker(); - const result = []; - visitor(file); - return result; - function visitor(node) { - if (!node || node.getFullWidth() === 0) { - return; - } - switch (node.kind) { - case 266 /* ModuleDeclaration */: - case 262 /* ClassDeclaration */: - case 263 /* InterfaceDeclaration */: - case 261 /* FunctionDeclaration */: - case 230 /* ClassExpression */: - case 217 /* FunctionExpression */: - case 173 /* MethodDeclaration */: - case 218 /* ArrowFunction */: - cancellationToken.throwIfCancellationRequested(); + // src/services/formatting/formattingScanner.ts + function getFormattingScanner(text, languageVariant, startPos, endPos, cb) { + const scanner2 = languageVariant === 1 /* JSX */ ? jsxScanner : standardScanner; + scanner2.setText(text); + scanner2.resetTokenState(startPos); + let wasNewLine = true; + let leadingTrivia; + let trailingTrivia; + let savedPos; + let lastScanAction; + let lastTokenInfo; + const res = cb({ + advance, + readTokenInfo, + readEOFTokenRange, + isOnToken, + isOnEOF, + getCurrentLeadingTrivia: () => leadingTrivia, + lastTrailingTriviaWasNewLine: () => wasNewLine, + skipToEndOf, + skipToStartOf, + getTokenFullStart: () => (lastTokenInfo == null ? void 0 : lastTokenInfo.token.pos) ?? scanner2.getTokenStart(), + getStartPos: () => (lastTokenInfo == null ? void 0 : lastTokenInfo.token.pos) ?? scanner2.getTokenStart() + }); + lastTokenInfo = void 0; + scanner2.setText(void 0); + return res; + function advance() { + lastTokenInfo = void 0; + const isStarted = scanner2.getTokenFullStart() !== startPos; + if (isStarted) { + wasNewLine = !!trailingTrivia && last(trailingTrivia).kind === 4 /* NewLineTrivia */; + } else { + scanner2.scan(); } - if (!textSpanIntersectsWith(span, node.pos, node.getFullWidth())) { - return; + leadingTrivia = void 0; + trailingTrivia = void 0; + let pos = scanner2.getTokenFullStart(); + while (pos < endPos) { + const t = scanner2.getToken(); + if (!isTrivia(t)) { + break; + } + scanner2.scan(); + const item = { + pos, + end: scanner2.getTokenFullStart(), + kind: t + }; + pos = scanner2.getTokenFullStart(); + leadingTrivia = append(leadingTrivia, item); } - if (isTypeNode(node) && !isExpressionWithTypeArguments(node)) { - return; + savedPos = scanner2.getTokenFullStart(); + } + function shouldRescanGreaterThanToken(node) { + switch (node.kind) { + case 34 /* GreaterThanEqualsToken */: + case 72 /* GreaterThanGreaterThanEqualsToken */: + case 73 /* GreaterThanGreaterThanGreaterThanEqualsToken */: + case 50 /* GreaterThanGreaterThanGreaterThanToken */: + case 49 /* GreaterThanGreaterThanToken */: + return true; } - if (preferences.includeInlayVariableTypeHints && isVariableDeclaration(node)) { - visitVariableLikeDeclaration(node); - } else if (preferences.includeInlayPropertyDeclarationTypeHints && isPropertyDeclaration(node)) { - visitVariableLikeDeclaration(node); - } else if (preferences.includeInlayEnumMemberValueHints && isEnumMember(node)) { - visitEnumMember(node); - } else if (shouldShowParameterNameHints(preferences) && (isCallExpression(node) || isNewExpression(node))) { - visitCallOrNewExpression(node); - } else { - if (preferences.includeInlayFunctionParameterTypeHints && isFunctionLikeDeclaration(node) && hasContextSensitiveParameters(node)) { - visitFunctionLikeForParameterType(node); - } - if (preferences.includeInlayFunctionLikeReturnTypeHints && isSignatureSupportingReturnAnnotation(node)) { - visitFunctionDeclarationLikeForReturnType(node); + return false; + } + function shouldRescanJsxIdentifier(node) { + if (node.parent) { + switch (node.parent.kind) { + case 291 /* JsxAttribute */: + case 286 /* JsxOpeningElement */: + case 287 /* JsxClosingElement */: + case 285 /* JsxSelfClosingElement */: + return isKeyword(node.kind) || node.kind === 80 /* Identifier */; } } - return forEachChild(node, visitor); - } - function isSignatureSupportingReturnAnnotation(node) { - return isArrowFunction(node) || isFunctionExpression(node) || isFunctionDeclaration(node) || isMethodDeclaration(node) || isGetAccessorDeclaration(node); + return false; } - function addParameterHints(text, position, isFirstVariadicArgument) { - result.push({ - text: `${isFirstVariadicArgument ? "..." : ""}${truncation(text, maxHintsLength)}:`, - position, - kind: "Parameter" /* Parameter */, - whitespaceAfter: true - }); + function shouldRescanJsxText(node) { + return isJsxText(node) || isJsxElement(node) && (lastTokenInfo == null ? void 0 : lastTokenInfo.token.kind) === 12 /* JsxText */; } - function addTypeHints(text, position) { - result.push({ - text: `: ${truncation(text, maxHintsLength)}`, - position, - kind: "Type" /* Type */, - whitespaceBefore: true - }); + function shouldRescanSlashToken(container) { + return container.kind === 14 /* RegularExpressionLiteral */; } - function addEnumMemberValueHints(text, position) { - result.push({ - text: `= ${truncation(text, maxHintsLength)}`, - position, - kind: "Enum" /* Enum */, - whitespaceBefore: true - }); + function shouldRescanTemplateToken(container) { + return container.kind === 17 /* TemplateMiddle */ || container.kind === 18 /* TemplateTail */; } - function visitEnumMember(member) { - if (member.initializer) { - return; - } - const enumValue = checker.getConstantValue(member); - if (enumValue !== void 0) { - addEnumMemberValueHints(enumValue.toString(), member.end); - } + function shouldRescanJsxAttributeValue(node) { + return node.parent && isJsxAttribute(node.parent) && node.parent.initializer === node; } - function isModuleReferenceType(type) { - return type.symbol && type.symbol.flags & 1536 /* Module */; + function startsWithSlashToken(t) { + return t === 44 /* SlashToken */ || t === 69 /* SlashEqualsToken */; } - function visitVariableLikeDeclaration(decl) { - if (!decl.initializer || isBindingPattern(decl.name) || isVariableDeclaration(decl) && !isHintableDeclaration(decl)) { - return; + function readTokenInfo(n) { + Debug.assert(isOnToken()); + const expectedScanAction = shouldRescanGreaterThanToken(n) ? 1 /* RescanGreaterThanToken */ : shouldRescanSlashToken(n) ? 2 /* RescanSlashToken */ : shouldRescanTemplateToken(n) ? 3 /* RescanTemplateToken */ : shouldRescanJsxIdentifier(n) ? 4 /* RescanJsxIdentifier */ : shouldRescanJsxText(n) ? 5 /* RescanJsxText */ : shouldRescanJsxAttributeValue(n) ? 6 /* RescanJsxAttributeValue */ : 0 /* Scan */; + if (lastTokenInfo && expectedScanAction === lastScanAction) { + return fixTokenKind(lastTokenInfo, n); } - const effectiveTypeAnnotation = getEffectiveTypeAnnotationNode(decl); - if (effectiveTypeAnnotation) { - return; + if (scanner2.getTokenFullStart() !== savedPos) { + Debug.assert(lastTokenInfo !== void 0); + scanner2.resetTokenState(savedPos); + scanner2.scan(); } - const declarationType = checker.getTypeAtLocation(decl); - if (isModuleReferenceType(declarationType)) { - return; + let currentToken = getNextToken(n, expectedScanAction); + const token = createTextRangeWithKind( + scanner2.getTokenFullStart(), + scanner2.getTokenEnd(), + currentToken + ); + if (trailingTrivia) { + trailingTrivia = void 0; } - const typeDisplayString = printTypeInSingleLine(declarationType); - if (typeDisplayString) { - const isVariableNameMatchesType = preferences.includeInlayVariableTypeHintsWhenTypeMatchesName === false && equateStringsCaseInsensitive(decl.name.getText(), typeDisplayString); - if (isVariableNameMatchesType) { - return; + while (scanner2.getTokenFullStart() < endPos) { + currentToken = scanner2.scan(); + if (!isTrivia(currentToken)) { + break; + } + const trivia = createTextRangeWithKind( + scanner2.getTokenFullStart(), + scanner2.getTokenEnd(), + currentToken + ); + if (!trailingTrivia) { + trailingTrivia = []; + } + trailingTrivia.push(trivia); + if (currentToken === 4 /* NewLineTrivia */) { + scanner2.scan(); + break; } - addTypeHints(typeDisplayString, decl.name.end); } + lastTokenInfo = { leadingTrivia, trailingTrivia, token }; + return fixTokenKind(lastTokenInfo, n); } - function visitCallOrNewExpression(expr) { - const args = expr.arguments; - if (!args || !args.length) { - return; - } - const candidates = []; - const signature = checker.getResolvedSignatureForSignatureHelp(expr, candidates); - if (!signature || !candidates.length) { - return; - } - for (let i = 0; i < args.length; ++i) { - const originalArg = args[i]; - const arg = skipParentheses(originalArg); - if (shouldShowLiteralParameterNameHintsOnly(preferences) && !isHintableLiteral(arg)) { - continue; - } - const identifierNameInfo = checker.getParameterIdentifierNameAtPosition(signature, i); - if (identifierNameInfo) { - const [parameterName, isFirstVariadicArgument] = identifierNameInfo; - const isParameterNameNotSameAsArgument = preferences.includeInlayParameterNameHintsWhenArgumentMatchesName || !identifierOrAccessExpressionPostfixMatchesParameterName(arg, parameterName); - if (!isParameterNameNotSameAsArgument && !isFirstVariadicArgument) { - continue; + function getNextToken(n, expectedScanAction) { + const token = scanner2.getToken(); + lastScanAction = 0 /* Scan */; + switch (expectedScanAction) { + case 1 /* RescanGreaterThanToken */: + if (token === 32 /* GreaterThanToken */) { + lastScanAction = 1 /* RescanGreaterThanToken */; + const newToken = scanner2.reScanGreaterToken(); + Debug.assert(n.kind === newToken); + return newToken; } - const name = unescapeLeadingUnderscores(parameterName); - if (leadingCommentsContainsParameterName(arg, name)) { - continue; + break; + case 2 /* RescanSlashToken */: + if (startsWithSlashToken(token)) { + lastScanAction = 2 /* RescanSlashToken */; + const newToken = scanner2.reScanSlashToken(); + Debug.assert(n.kind === newToken); + return newToken; } - addParameterHints(name, originalArg.getStart(), isFirstVariadicArgument); - } + break; + case 3 /* RescanTemplateToken */: + if (token === 20 /* CloseBraceToken */) { + lastScanAction = 3 /* RescanTemplateToken */; + return scanner2.reScanTemplateToken( + /*isTaggedTemplate*/ + false + ); + } + break; + case 4 /* RescanJsxIdentifier */: + lastScanAction = 4 /* RescanJsxIdentifier */; + return scanner2.scanJsxIdentifier(); + case 5 /* RescanJsxText */: + lastScanAction = 5 /* RescanJsxText */; + return scanner2.reScanJsxToken( + /*allowMultilineJsxText*/ + false + ); + case 6 /* RescanJsxAttributeValue */: + lastScanAction = 6 /* RescanJsxAttributeValue */; + return scanner2.reScanJsxAttributeValue(); + case 0 /* Scan */: + break; + default: + Debug.assertNever(expectedScanAction); } + return token; } - function identifierOrAccessExpressionPostfixMatchesParameterName(expr, parameterName) { - if (isIdentifier(expr)) { - return expr.text === parameterName; - } - if (isPropertyAccessExpression(expr)) { - return expr.name.text === parameterName; - } - return false; + function readEOFTokenRange() { + Debug.assert(isOnEOF()); + return createTextRangeWithKind(scanner2.getTokenFullStart(), scanner2.getTokenEnd(), 1 /* EndOfFileToken */); } - function leadingCommentsContainsParameterName(node, name) { - if (!isIdentifierText(name, compilerOptions.target, getLanguageVariant(file.scriptKind))) { - return false; - } - const ranges = getLeadingCommentRanges(sourceFileText, node.pos); - if (!(ranges == null ? void 0 : ranges.length)) { - return false; - } - const regex = leadingParameterNameCommentRegexFactory(name); - return some(ranges, (range) => regex.test(sourceFileText.substring(range.pos, range.end))); + function isOnToken() { + const current = lastTokenInfo ? lastTokenInfo.token.kind : scanner2.getToken(); + return current !== 1 /* EndOfFileToken */ && !isTrivia(current); } - function isHintableLiteral(node) { - switch (node.kind) { - case 223 /* PrefixUnaryExpression */: { - const operand = node.operand; - return isLiteralExpression(operand) || isIdentifier(operand) && isInfinityOrNaNString(operand.escapedText); - } - case 112 /* TrueKeyword */: - case 97 /* FalseKeyword */: - case 106 /* NullKeyword */: - case 15 /* NoSubstitutionTemplateLiteral */: - case 227 /* TemplateExpression */: - return true; - case 80 /* Identifier */: { - const name = node.escapedText; - return isUndefined(name) || isInfinityOrNaNString(name); - } - } - return isLiteralExpression(node); + function isOnEOF() { + const current = lastTokenInfo ? lastTokenInfo.token.kind : scanner2.getToken(); + return current === 1 /* EndOfFileToken */; } - function visitFunctionDeclarationLikeForReturnType(decl) { - if (isArrowFunction(decl)) { - if (!findChildOfKind(decl, 21 /* OpenParenToken */, file)) { - return; - } - } - const effectiveTypeAnnotation = getEffectiveReturnTypeNode(decl); - if (effectiveTypeAnnotation || !decl.body) { - return; - } - const signature = checker.getSignatureFromDeclaration(decl); - if (!signature) { - return; - } - const returnType = checker.getReturnTypeOfSignature(signature); - if (isModuleReferenceType(returnType)) { - return; - } - const typeDisplayString = printTypeInSingleLine(returnType); - if (!typeDisplayString) { - return; + function fixTokenKind(tokenInfo, container) { + if (isToken(container) && tokenInfo.token.kind !== container.kind) { + tokenInfo.token.kind = container.kind; } - addTypeHints(typeDisplayString, getTypeAnnotationPosition(decl)); + return tokenInfo; } - function getTypeAnnotationPosition(decl) { - const closeParenToken = findChildOfKind(decl, 22 /* CloseParenToken */, file); - if (closeParenToken) { - return closeParenToken.end; - } - return decl.parameters.end; + function skipToEndOf(node) { + scanner2.resetTokenState(node.end); + savedPos = scanner2.getTokenFullStart(); + lastScanAction = void 0; + lastTokenInfo = void 0; + wasNewLine = false; + leadingTrivia = void 0; + trailingTrivia = void 0; } - function visitFunctionLikeForParameterType(node) { - const signature = checker.getSignatureFromDeclaration(node); - if (!signature) { - return; - } - for (let i = 0; i < node.parameters.length && i < signature.parameters.length; ++i) { - const param = node.parameters[i]; - if (!isHintableDeclaration(param)) { - continue; - } - const effectiveTypeAnnotation = getEffectiveTypeAnnotationNode(param); - if (effectiveTypeAnnotation) { - continue; - } - const typeDisplayString = getParameterDeclarationTypeDisplayString(signature.parameters[i]); - if (!typeDisplayString) { - continue; - } - addTypeHints(typeDisplayString, param.questionToken ? param.questionToken.end : param.name.end); - } + function skipToStartOf(node) { + scanner2.resetTokenState(node.pos); + savedPos = scanner2.getTokenFullStart(); + lastScanAction = void 0; + lastTokenInfo = void 0; + wasNewLine = false; + leadingTrivia = void 0; + trailingTrivia = void 0; } - function getParameterDeclarationTypeDisplayString(symbol) { - const valueDeclaration = symbol.valueDeclaration; - if (!valueDeclaration || !isParameter(valueDeclaration)) { - return void 0; - } - const signatureParamType = checker.getTypeOfSymbolAtLocation(symbol, valueDeclaration); - if (isModuleReferenceType(signatureParamType)) { - return void 0; + } + var standardScanner, jsxScanner; + var init_formattingScanner = __esm({ + "src/services/formatting/formattingScanner.ts"() { + "use strict"; + init_ts4(); + init_ts_formatting(); + standardScanner = createScanner( + 99 /* Latest */, + /*skipTrivia*/ + false, + 0 /* Standard */ + ); + jsxScanner = createScanner( + 99 /* Latest */, + /*skipTrivia*/ + false, + 1 /* JSX */ + ); + } + }); + + // src/services/formatting/rule.ts + var anyContext, RuleAction, RuleFlags; + var init_rule = __esm({ + "src/services/formatting/rule.ts"() { + "use strict"; + init_ts4(); + anyContext = emptyArray; + RuleAction = /* @__PURE__ */ ((RuleAction2) => { + RuleAction2[RuleAction2["None"] = 0] = "None"; + RuleAction2[RuleAction2["StopProcessingSpaceActions"] = 1] = "StopProcessingSpaceActions"; + RuleAction2[RuleAction2["StopProcessingTokenActions"] = 2] = "StopProcessingTokenActions"; + RuleAction2[RuleAction2["InsertSpace"] = 4] = "InsertSpace"; + RuleAction2[RuleAction2["InsertNewLine"] = 8] = "InsertNewLine"; + RuleAction2[RuleAction2["DeleteSpace"] = 16] = "DeleteSpace"; + RuleAction2[RuleAction2["DeleteToken"] = 32] = "DeleteToken"; + RuleAction2[RuleAction2["InsertTrailingSemicolon"] = 64] = "InsertTrailingSemicolon"; + RuleAction2[RuleAction2["StopAction"] = 3] = "StopAction"; + RuleAction2[RuleAction2["ModifySpaceAction"] = 28] = "ModifySpaceAction"; + RuleAction2[RuleAction2["ModifyTokenAction"] = 96] = "ModifyTokenAction"; + return RuleAction2; + })(RuleAction || {}); + RuleFlags = /* @__PURE__ */ ((RuleFlags2) => { + RuleFlags2[RuleFlags2["None"] = 0] = "None"; + RuleFlags2[RuleFlags2["CanDeleteNewLines"] = 1] = "CanDeleteNewLines"; + return RuleFlags2; + })(RuleFlags || {}); + } + }); + + // src/services/formatting/rules.ts + function getAllRules() { + const allTokens = []; + for (let token = 0 /* FirstToken */; token <= 165 /* LastToken */; token++) { + if (token !== 1 /* EndOfFileToken */) { + allTokens.push(token); } - return printTypeInSingleLine(signatureParamType); } - function truncation(text, maxLength2) { - if (text.length > maxLength2) { - return text.substr(0, maxLength2 - "...".length) + "..."; + function anyTokenExcept(...tokens) { + return { tokens: allTokens.filter((t) => !tokens.some((t2) => t2 === t)), isSpecific: false }; + } + const anyToken = { tokens: allTokens, isSpecific: false }; + const anyTokenIncludingMultilineComments = tokenRangeFrom([...allTokens, 3 /* MultiLineCommentTrivia */]); + const anyTokenIncludingEOF = tokenRangeFrom([...allTokens, 1 /* EndOfFileToken */]); + const keywords = tokenRangeFromRange(83 /* FirstKeyword */, 165 /* LastKeyword */); + const binaryOperators = tokenRangeFromRange(30 /* FirstBinaryOperator */, 79 /* LastBinaryOperator */); + const binaryKeywordOperators = [ + 103 /* InKeyword */, + 104 /* InstanceOfKeyword */, + 165 /* OfKeyword */, + 130 /* AsKeyword */, + 142 /* IsKeyword */, + 152 /* SatisfiesKeyword */ + ]; + const unaryPrefixOperators = [46 /* PlusPlusToken */, 47 /* MinusMinusToken */, 55 /* TildeToken */, 54 /* ExclamationToken */]; + const unaryPrefixExpressions = [ + 9 /* NumericLiteral */, + 10 /* BigIntLiteral */, + 80 /* Identifier */, + 21 /* OpenParenToken */, + 23 /* OpenBracketToken */, + 19 /* OpenBraceToken */, + 110 /* ThisKeyword */, + 105 /* NewKeyword */ + ]; + const unaryPreincrementExpressions = [80 /* Identifier */, 21 /* OpenParenToken */, 110 /* ThisKeyword */, 105 /* NewKeyword */]; + const unaryPostincrementExpressions = [80 /* Identifier */, 22 /* CloseParenToken */, 24 /* CloseBracketToken */, 105 /* NewKeyword */]; + const unaryPredecrementExpressions = [80 /* Identifier */, 21 /* OpenParenToken */, 110 /* ThisKeyword */, 105 /* NewKeyword */]; + const unaryPostdecrementExpressions = [80 /* Identifier */, 22 /* CloseParenToken */, 24 /* CloseBracketToken */, 105 /* NewKeyword */]; + const comments = [2 /* SingleLineCommentTrivia */, 3 /* MultiLineCommentTrivia */]; + const typeNames = [80 /* Identifier */, ...typeKeywords]; + const functionOpenBraceLeftTokenRange = anyTokenIncludingMultilineComments; + const typeScriptOpenBraceLeftTokenRange = tokenRangeFrom([80 /* Identifier */, 3 /* MultiLineCommentTrivia */, 86 /* ClassKeyword */, 95 /* ExportKeyword */, 102 /* ImportKeyword */]); + const controlOpenBraceLeftTokenRange = tokenRangeFrom([22 /* CloseParenToken */, 3 /* MultiLineCommentTrivia */, 92 /* DoKeyword */, 113 /* TryKeyword */, 98 /* FinallyKeyword */, 93 /* ElseKeyword */]); + const highPriorityCommonRules = [ + // Leave comments alone + rule("IgnoreBeforeComment", anyToken, comments, anyContext, 1 /* StopProcessingSpaceActions */), + rule("IgnoreAfterLineComment", 2 /* SingleLineCommentTrivia */, anyToken, anyContext, 1 /* StopProcessingSpaceActions */), + rule("NotSpaceBeforeColon", anyToken, 59 /* ColonToken */, [isNonJsxSameLineTokenContext, isNotBinaryOpContext, isNotTypeAnnotationContext], 16 /* DeleteSpace */), + rule("SpaceAfterColon", 59 /* ColonToken */, anyToken, [isNonJsxSameLineTokenContext, isNotBinaryOpContext, isNextTokenParentNotJsxNamespacedName], 4 /* InsertSpace */), + rule("NoSpaceBeforeQuestionMark", anyToken, 58 /* QuestionToken */, [isNonJsxSameLineTokenContext, isNotBinaryOpContext, isNotTypeAnnotationContext], 16 /* DeleteSpace */), + // insert space after '?' only when it is used in conditional operator + rule("SpaceAfterQuestionMarkInConditionalOperator", 58 /* QuestionToken */, anyToken, [isNonJsxSameLineTokenContext, isConditionalOperatorContext], 4 /* InsertSpace */), + // in other cases there should be no space between '?' and next token + rule("NoSpaceAfterQuestionMark", 58 /* QuestionToken */, anyToken, [isNonJsxSameLineTokenContext, isNonOptionalPropertyContext], 16 /* DeleteSpace */), + rule("NoSpaceBeforeDot", anyToken, [25 /* DotToken */, 29 /* QuestionDotToken */], [isNonJsxSameLineTokenContext, isNotPropertyAccessOnIntegerLiteral], 16 /* DeleteSpace */), + rule("NoSpaceAfterDot", [25 /* DotToken */, 29 /* QuestionDotToken */], anyToken, [isNonJsxSameLineTokenContext], 16 /* DeleteSpace */), + rule("NoSpaceBetweenImportParenInImportType", 102 /* ImportKeyword */, 21 /* OpenParenToken */, [isNonJsxSameLineTokenContext, isImportTypeContext], 16 /* DeleteSpace */), + // Special handling of unary operators. + // Prefix operators generally shouldn't have a space between + // them and their target unary expression. + rule("NoSpaceAfterUnaryPrefixOperator", unaryPrefixOperators, unaryPrefixExpressions, [isNonJsxSameLineTokenContext, isNotBinaryOpContext], 16 /* DeleteSpace */), + rule("NoSpaceAfterUnaryPreincrementOperator", 46 /* PlusPlusToken */, unaryPreincrementExpressions, [isNonJsxSameLineTokenContext], 16 /* DeleteSpace */), + rule("NoSpaceAfterUnaryPredecrementOperator", 47 /* MinusMinusToken */, unaryPredecrementExpressions, [isNonJsxSameLineTokenContext], 16 /* DeleteSpace */), + rule("NoSpaceBeforeUnaryPostincrementOperator", unaryPostincrementExpressions, 46 /* PlusPlusToken */, [isNonJsxSameLineTokenContext, isNotStatementConditionContext], 16 /* DeleteSpace */), + rule("NoSpaceBeforeUnaryPostdecrementOperator", unaryPostdecrementExpressions, 47 /* MinusMinusToken */, [isNonJsxSameLineTokenContext, isNotStatementConditionContext], 16 /* DeleteSpace */), + // More unary operator special-casing. + // DevDiv 181814: Be careful when removing leading whitespace + // around unary operators. Examples: + // 1 - -2 --X--> 1--2 + // a + ++b --X--> a+++b + rule("SpaceAfterPostincrementWhenFollowedByAdd", 46 /* PlusPlusToken */, 40 /* PlusToken */, [isNonJsxSameLineTokenContext, isBinaryOpContext], 4 /* InsertSpace */), + rule("SpaceAfterAddWhenFollowedByUnaryPlus", 40 /* PlusToken */, 40 /* PlusToken */, [isNonJsxSameLineTokenContext, isBinaryOpContext], 4 /* InsertSpace */), + rule("SpaceAfterAddWhenFollowedByPreincrement", 40 /* PlusToken */, 46 /* PlusPlusToken */, [isNonJsxSameLineTokenContext, isBinaryOpContext], 4 /* InsertSpace */), + rule("SpaceAfterPostdecrementWhenFollowedBySubtract", 47 /* MinusMinusToken */, 41 /* MinusToken */, [isNonJsxSameLineTokenContext, isBinaryOpContext], 4 /* InsertSpace */), + rule("SpaceAfterSubtractWhenFollowedByUnaryMinus", 41 /* MinusToken */, 41 /* MinusToken */, [isNonJsxSameLineTokenContext, isBinaryOpContext], 4 /* InsertSpace */), + rule("SpaceAfterSubtractWhenFollowedByPredecrement", 41 /* MinusToken */, 47 /* MinusMinusToken */, [isNonJsxSameLineTokenContext, isBinaryOpContext], 4 /* InsertSpace */), + rule("NoSpaceAfterCloseBrace", 20 /* CloseBraceToken */, [28 /* CommaToken */, 27 /* SemicolonToken */], [isNonJsxSameLineTokenContext], 16 /* DeleteSpace */), + // For functions and control block place } on a new line [multi-line rule] + rule("NewLineBeforeCloseBraceInBlockContext", anyTokenIncludingMultilineComments, 20 /* CloseBraceToken */, [isMultilineBlockContext], 8 /* InsertNewLine */), + // Space/new line after }. + rule("SpaceAfterCloseBrace", 20 /* CloseBraceToken */, anyTokenExcept(22 /* CloseParenToken */), [isNonJsxSameLineTokenContext, isAfterCodeBlockContext], 4 /* InsertSpace */), + // Special case for (}, else) and (}, while) since else & while tokens are not part of the tree which makes SpaceAfterCloseBrace rule not applied + // Also should not apply to }) + rule("SpaceBetweenCloseBraceAndElse", 20 /* CloseBraceToken */, 93 /* ElseKeyword */, [isNonJsxSameLineTokenContext], 4 /* InsertSpace */), + rule("SpaceBetweenCloseBraceAndWhile", 20 /* CloseBraceToken */, 117 /* WhileKeyword */, [isNonJsxSameLineTokenContext], 4 /* InsertSpace */), + rule("NoSpaceBetweenEmptyBraceBrackets", 19 /* OpenBraceToken */, 20 /* CloseBraceToken */, [isNonJsxSameLineTokenContext, isObjectContext], 16 /* DeleteSpace */), + // Add a space after control dec context if the next character is an open bracket ex: 'if (false)[a, b] = [1, 2];' -> 'if (false) [a, b] = [1, 2];' + rule("SpaceAfterConditionalClosingParen", 22 /* CloseParenToken */, 23 /* OpenBracketToken */, [isControlDeclContext], 4 /* InsertSpace */), + rule("NoSpaceBetweenFunctionKeywordAndStar", 100 /* FunctionKeyword */, 42 /* AsteriskToken */, [isFunctionDeclarationOrFunctionExpressionContext], 16 /* DeleteSpace */), + rule("SpaceAfterStarInGeneratorDeclaration", 42 /* AsteriskToken */, 80 /* Identifier */, [isFunctionDeclarationOrFunctionExpressionContext], 4 /* InsertSpace */), + rule("SpaceAfterFunctionInFuncDecl", 100 /* FunctionKeyword */, anyToken, [isFunctionDeclContext], 4 /* InsertSpace */), + // Insert new line after { and before } in multi-line contexts. + rule("NewLineAfterOpenBraceInBlockContext", 19 /* OpenBraceToken */, anyToken, [isMultilineBlockContext], 8 /* InsertNewLine */), + // For get/set members, we check for (identifier,identifier) since get/set don't have tokens and they are represented as just an identifier token. + // Though, we do extra check on the context to make sure we are dealing with get/set node. Example: + // get x() {} + // set x(val) {} + rule("SpaceAfterGetSetInMember", [139 /* GetKeyword */, 153 /* SetKeyword */], 80 /* Identifier */, [isFunctionDeclContext], 4 /* InsertSpace */), + rule("NoSpaceBetweenYieldKeywordAndStar", 127 /* YieldKeyword */, 42 /* AsteriskToken */, [isNonJsxSameLineTokenContext, isYieldOrYieldStarWithOperand], 16 /* DeleteSpace */), + rule("SpaceBetweenYieldOrYieldStarAndOperand", [127 /* YieldKeyword */, 42 /* AsteriskToken */], anyToken, [isNonJsxSameLineTokenContext, isYieldOrYieldStarWithOperand], 4 /* InsertSpace */), + rule("NoSpaceBetweenReturnAndSemicolon", 107 /* ReturnKeyword */, 27 /* SemicolonToken */, [isNonJsxSameLineTokenContext], 16 /* DeleteSpace */), + rule("SpaceAfterCertainKeywords", [115 /* VarKeyword */, 111 /* ThrowKeyword */, 105 /* NewKeyword */, 91 /* DeleteKeyword */, 107 /* ReturnKeyword */, 114 /* TypeOfKeyword */, 135 /* AwaitKeyword */], anyToken, [isNonJsxSameLineTokenContext], 4 /* InsertSpace */), + rule("SpaceAfterLetConstInVariableDeclaration", [121 /* LetKeyword */, 87 /* ConstKeyword */], anyToken, [isNonJsxSameLineTokenContext, isStartOfVariableDeclarationList], 4 /* InsertSpace */), + rule("NoSpaceBeforeOpenParenInFuncCall", anyToken, 21 /* OpenParenToken */, [isNonJsxSameLineTokenContext, isFunctionCallOrNewContext, isPreviousTokenNotComma], 16 /* DeleteSpace */), + // Special case for binary operators (that are keywords). For these we have to add a space and shouldn't follow any user options. + rule("SpaceBeforeBinaryKeywordOperator", anyToken, binaryKeywordOperators, [isNonJsxSameLineTokenContext, isBinaryOpContext], 4 /* InsertSpace */), + rule("SpaceAfterBinaryKeywordOperator", binaryKeywordOperators, anyToken, [isNonJsxSameLineTokenContext, isBinaryOpContext], 4 /* InsertSpace */), + rule("SpaceAfterVoidOperator", 116 /* VoidKeyword */, anyToken, [isNonJsxSameLineTokenContext, isVoidOpContext], 4 /* InsertSpace */), + // Async-await + rule("SpaceBetweenAsyncAndOpenParen", 134 /* AsyncKeyword */, 21 /* OpenParenToken */, [isArrowFunctionContext, isNonJsxSameLineTokenContext], 4 /* InsertSpace */), + rule("SpaceBetweenAsyncAndFunctionKeyword", 134 /* AsyncKeyword */, [100 /* FunctionKeyword */, 80 /* Identifier */], [isNonJsxSameLineTokenContext], 4 /* InsertSpace */), + // Template string + rule("NoSpaceBetweenTagAndTemplateString", [80 /* Identifier */, 22 /* CloseParenToken */], [15 /* NoSubstitutionTemplateLiteral */, 16 /* TemplateHead */], [isNonJsxSameLineTokenContext], 16 /* DeleteSpace */), + // JSX opening elements + rule("SpaceBeforeJsxAttribute", anyToken, 80 /* Identifier */, [isNextTokenParentJsxAttribute, isNonJsxSameLineTokenContext], 4 /* InsertSpace */), + rule("SpaceBeforeSlashInJsxOpeningElement", anyToken, 44 /* SlashToken */, [isJsxSelfClosingElementContext, isNonJsxSameLineTokenContext], 4 /* InsertSpace */), + rule("NoSpaceBeforeGreaterThanTokenInJsxOpeningElement", 44 /* SlashToken */, 32 /* GreaterThanToken */, [isJsxSelfClosingElementContext, isNonJsxSameLineTokenContext], 16 /* DeleteSpace */), + rule("NoSpaceBeforeEqualInJsxAttribute", anyToken, 64 /* EqualsToken */, [isJsxAttributeContext, isNonJsxSameLineTokenContext], 16 /* DeleteSpace */), + rule("NoSpaceAfterEqualInJsxAttribute", 64 /* EqualsToken */, anyToken, [isJsxAttributeContext, isNonJsxSameLineTokenContext], 16 /* DeleteSpace */), + rule("NoSpaceBeforeJsxNamespaceColon", 80 /* Identifier */, 59 /* ColonToken */, [isNextTokenParentJsxNamespacedName], 16 /* DeleteSpace */), + rule("NoSpaceAfterJsxNamespaceColon", 59 /* ColonToken */, 80 /* Identifier */, [isNextTokenParentJsxNamespacedName], 16 /* DeleteSpace */), + // TypeScript-specific rules + // Use of module as a function call. e.g.: import m2 = module("m2"); + rule("NoSpaceAfterModuleImport", [144 /* ModuleKeyword */, 149 /* RequireKeyword */], 21 /* OpenParenToken */, [isNonJsxSameLineTokenContext], 16 /* DeleteSpace */), + // Add a space around certain TypeScript keywords + rule( + "SpaceAfterCertainTypeScriptKeywords", + [ + 128 /* AbstractKeyword */, + 129 /* AccessorKeyword */, + 86 /* ClassKeyword */, + 138 /* DeclareKeyword */, + 90 /* DefaultKeyword */, + 94 /* EnumKeyword */, + 95 /* ExportKeyword */, + 96 /* ExtendsKeyword */, + 139 /* GetKeyword */, + 119 /* ImplementsKeyword */, + 102 /* ImportKeyword */, + 120 /* InterfaceKeyword */, + 144 /* ModuleKeyword */, + 145 /* NamespaceKeyword */, + 123 /* PrivateKeyword */, + 125 /* PublicKeyword */, + 124 /* ProtectedKeyword */, + 148 /* ReadonlyKeyword */, + 153 /* SetKeyword */, + 126 /* StaticKeyword */, + 156 /* TypeKeyword */, + 161 /* FromKeyword */, + 143 /* KeyOfKeyword */, + 140 /* InferKeyword */ + ], + anyToken, + [isNonJsxSameLineTokenContext], + 4 /* InsertSpace */ + ), + rule( + "SpaceBeforeCertainTypeScriptKeywords", + anyToken, + [96 /* ExtendsKeyword */, 119 /* ImplementsKeyword */, 161 /* FromKeyword */], + [isNonJsxSameLineTokenContext], + 4 /* InsertSpace */ + ), + // Treat string literals in module names as identifiers, and add a space between the literal and the opening Brace braces, e.g.: module "m2" { + rule("SpaceAfterModuleName", 11 /* StringLiteral */, 19 /* OpenBraceToken */, [isModuleDeclContext], 4 /* InsertSpace */), + // Lambda expressions + rule("SpaceBeforeArrow", anyToken, 39 /* EqualsGreaterThanToken */, [isNonJsxSameLineTokenContext], 4 /* InsertSpace */), + rule("SpaceAfterArrow", 39 /* EqualsGreaterThanToken */, anyToken, [isNonJsxSameLineTokenContext], 4 /* InsertSpace */), + // Optional parameters and let args + rule("NoSpaceAfterEllipsis", 26 /* DotDotDotToken */, 80 /* Identifier */, [isNonJsxSameLineTokenContext], 16 /* DeleteSpace */), + rule("NoSpaceAfterOptionalParameters", 58 /* QuestionToken */, [22 /* CloseParenToken */, 28 /* CommaToken */], [isNonJsxSameLineTokenContext, isNotBinaryOpContext], 16 /* DeleteSpace */), + // Remove spaces in empty interface literals. e.g.: x: {} + rule("NoSpaceBetweenEmptyInterfaceBraceBrackets", 19 /* OpenBraceToken */, 20 /* CloseBraceToken */, [isNonJsxSameLineTokenContext, isObjectTypeContext], 16 /* DeleteSpace */), + // generics and type assertions + rule("NoSpaceBeforeOpenAngularBracket", typeNames, 30 /* LessThanToken */, [isNonJsxSameLineTokenContext, isTypeArgumentOrParameterOrAssertionContext], 16 /* DeleteSpace */), + rule("NoSpaceBetweenCloseParenAndAngularBracket", 22 /* CloseParenToken */, 30 /* LessThanToken */, [isNonJsxSameLineTokenContext, isTypeArgumentOrParameterOrAssertionContext], 16 /* DeleteSpace */), + rule("NoSpaceAfterOpenAngularBracket", 30 /* LessThanToken */, anyToken, [isNonJsxSameLineTokenContext, isTypeArgumentOrParameterOrAssertionContext], 16 /* DeleteSpace */), + rule("NoSpaceBeforeCloseAngularBracket", anyToken, 32 /* GreaterThanToken */, [isNonJsxSameLineTokenContext, isTypeArgumentOrParameterOrAssertionContext], 16 /* DeleteSpace */), + rule("NoSpaceAfterCloseAngularBracket", 32 /* GreaterThanToken */, [21 /* OpenParenToken */, 23 /* OpenBracketToken */, 32 /* GreaterThanToken */, 28 /* CommaToken */], [ + isNonJsxSameLineTokenContext, + isTypeArgumentOrParameterOrAssertionContext, + isNotFunctionDeclContext, + /*To prevent an interference with the SpaceBeforeOpenParenInFuncDecl rule*/ + isNonTypeAssertionContext + ], 16 /* DeleteSpace */), + // decorators + rule("SpaceBeforeAt", [22 /* CloseParenToken */, 80 /* Identifier */], 60 /* AtToken */, [isNonJsxSameLineTokenContext], 4 /* InsertSpace */), + rule("NoSpaceAfterAt", 60 /* AtToken */, anyToken, [isNonJsxSameLineTokenContext], 16 /* DeleteSpace */), + // Insert space after @ in decorator + rule( + "SpaceAfterDecorator", + anyToken, + [ + 128 /* AbstractKeyword */, + 80 /* Identifier */, + 95 /* ExportKeyword */, + 90 /* DefaultKeyword */, + 86 /* ClassKeyword */, + 126 /* StaticKeyword */, + 125 /* PublicKeyword */, + 123 /* PrivateKeyword */, + 124 /* ProtectedKeyword */, + 139 /* GetKeyword */, + 153 /* SetKeyword */, + 23 /* OpenBracketToken */, + 42 /* AsteriskToken */ + ], + [isEndOfDecoratorContextOnSameLine], + 4 /* InsertSpace */ + ), + rule("NoSpaceBeforeNonNullAssertionOperator", anyToken, 54 /* ExclamationToken */, [isNonJsxSameLineTokenContext, isNonNullAssertionContext], 16 /* DeleteSpace */), + rule("NoSpaceAfterNewKeywordOnConstructorSignature", 105 /* NewKeyword */, 21 /* OpenParenToken */, [isNonJsxSameLineTokenContext, isConstructorSignatureContext], 16 /* DeleteSpace */), + rule("SpaceLessThanAndNonJSXTypeAnnotation", 30 /* LessThanToken */, 30 /* LessThanToken */, [isNonJsxSameLineTokenContext], 4 /* InsertSpace */) + ]; + const userConfigurableRules = [ + // Treat constructor as an identifier in a function declaration, and remove spaces between constructor and following left parentheses + rule("SpaceAfterConstructor", 137 /* ConstructorKeyword */, 21 /* OpenParenToken */, [isOptionEnabled("insertSpaceAfterConstructor"), isNonJsxSameLineTokenContext], 4 /* InsertSpace */), + rule("NoSpaceAfterConstructor", 137 /* ConstructorKeyword */, 21 /* OpenParenToken */, [isOptionDisabledOrUndefined("insertSpaceAfterConstructor"), isNonJsxSameLineTokenContext], 16 /* DeleteSpace */), + rule("SpaceAfterComma", 28 /* CommaToken */, anyToken, [isOptionEnabled("insertSpaceAfterCommaDelimiter"), isNonJsxSameLineTokenContext, isNonJsxElementOrFragmentContext, isNextTokenNotCloseBracket, isNextTokenNotCloseParen], 4 /* InsertSpace */), + rule("NoSpaceAfterComma", 28 /* CommaToken */, anyToken, [isOptionDisabledOrUndefined("insertSpaceAfterCommaDelimiter"), isNonJsxSameLineTokenContext, isNonJsxElementOrFragmentContext], 16 /* DeleteSpace */), + // Insert space after function keyword for anonymous functions + rule("SpaceAfterAnonymousFunctionKeyword", [100 /* FunctionKeyword */, 42 /* AsteriskToken */], 21 /* OpenParenToken */, [isOptionEnabled("insertSpaceAfterFunctionKeywordForAnonymousFunctions"), isFunctionDeclContext], 4 /* InsertSpace */), + rule("NoSpaceAfterAnonymousFunctionKeyword", [100 /* FunctionKeyword */, 42 /* AsteriskToken */], 21 /* OpenParenToken */, [isOptionDisabledOrUndefined("insertSpaceAfterFunctionKeywordForAnonymousFunctions"), isFunctionDeclContext], 16 /* DeleteSpace */), + // Insert space after keywords in control flow statements + rule("SpaceAfterKeywordInControl", keywords, 21 /* OpenParenToken */, [isOptionEnabled("insertSpaceAfterKeywordsInControlFlowStatements"), isControlDeclContext], 4 /* InsertSpace */), + rule("NoSpaceAfterKeywordInControl", keywords, 21 /* OpenParenToken */, [isOptionDisabledOrUndefined("insertSpaceAfterKeywordsInControlFlowStatements"), isControlDeclContext], 16 /* DeleteSpace */), + // Insert space after opening and before closing nonempty parenthesis + rule("SpaceAfterOpenParen", 21 /* OpenParenToken */, anyToken, [isOptionEnabled("insertSpaceAfterOpeningAndBeforeClosingNonemptyParenthesis"), isNonJsxSameLineTokenContext], 4 /* InsertSpace */), + rule("SpaceBeforeCloseParen", anyToken, 22 /* CloseParenToken */, [isOptionEnabled("insertSpaceAfterOpeningAndBeforeClosingNonemptyParenthesis"), isNonJsxSameLineTokenContext], 4 /* InsertSpace */), + rule("SpaceBetweenOpenParens", 21 /* OpenParenToken */, 21 /* OpenParenToken */, [isOptionEnabled("insertSpaceAfterOpeningAndBeforeClosingNonemptyParenthesis"), isNonJsxSameLineTokenContext], 4 /* InsertSpace */), + rule("NoSpaceBetweenParens", 21 /* OpenParenToken */, 22 /* CloseParenToken */, [isNonJsxSameLineTokenContext], 16 /* DeleteSpace */), + rule("NoSpaceAfterOpenParen", 21 /* OpenParenToken */, anyToken, [isOptionDisabledOrUndefined("insertSpaceAfterOpeningAndBeforeClosingNonemptyParenthesis"), isNonJsxSameLineTokenContext], 16 /* DeleteSpace */), + rule("NoSpaceBeforeCloseParen", anyToken, 22 /* CloseParenToken */, [isOptionDisabledOrUndefined("insertSpaceAfterOpeningAndBeforeClosingNonemptyParenthesis"), isNonJsxSameLineTokenContext], 16 /* DeleteSpace */), + // Insert space after opening and before closing nonempty brackets + rule("SpaceAfterOpenBracket", 23 /* OpenBracketToken */, anyToken, [isOptionEnabled("insertSpaceAfterOpeningAndBeforeClosingNonemptyBrackets"), isNonJsxSameLineTokenContext], 4 /* InsertSpace */), + rule("SpaceBeforeCloseBracket", anyToken, 24 /* CloseBracketToken */, [isOptionEnabled("insertSpaceAfterOpeningAndBeforeClosingNonemptyBrackets"), isNonJsxSameLineTokenContext], 4 /* InsertSpace */), + rule("NoSpaceBetweenBrackets", 23 /* OpenBracketToken */, 24 /* CloseBracketToken */, [isNonJsxSameLineTokenContext], 16 /* DeleteSpace */), + rule("NoSpaceAfterOpenBracket", 23 /* OpenBracketToken */, anyToken, [isOptionDisabledOrUndefined("insertSpaceAfterOpeningAndBeforeClosingNonemptyBrackets"), isNonJsxSameLineTokenContext], 16 /* DeleteSpace */), + rule("NoSpaceBeforeCloseBracket", anyToken, 24 /* CloseBracketToken */, [isOptionDisabledOrUndefined("insertSpaceAfterOpeningAndBeforeClosingNonemptyBrackets"), isNonJsxSameLineTokenContext], 16 /* DeleteSpace */), + // Insert a space after { and before } in single-line contexts, but remove space from empty object literals {}. + rule("SpaceAfterOpenBrace", 19 /* OpenBraceToken */, anyToken, [isOptionEnabledOrUndefined("insertSpaceAfterOpeningAndBeforeClosingNonemptyBraces"), isBraceWrappedContext], 4 /* InsertSpace */), + rule("SpaceBeforeCloseBrace", anyToken, 20 /* CloseBraceToken */, [isOptionEnabledOrUndefined("insertSpaceAfterOpeningAndBeforeClosingNonemptyBraces"), isBraceWrappedContext], 4 /* InsertSpace */), + rule("NoSpaceBetweenEmptyBraceBrackets", 19 /* OpenBraceToken */, 20 /* CloseBraceToken */, [isNonJsxSameLineTokenContext, isObjectContext], 16 /* DeleteSpace */), + rule("NoSpaceAfterOpenBrace", 19 /* OpenBraceToken */, anyToken, [isOptionDisabled("insertSpaceAfterOpeningAndBeforeClosingNonemptyBraces"), isNonJsxSameLineTokenContext], 16 /* DeleteSpace */), + rule("NoSpaceBeforeCloseBrace", anyToken, 20 /* CloseBraceToken */, [isOptionDisabled("insertSpaceAfterOpeningAndBeforeClosingNonemptyBraces"), isNonJsxSameLineTokenContext], 16 /* DeleteSpace */), + // Insert a space after opening and before closing empty brace brackets + rule("SpaceBetweenEmptyBraceBrackets", 19 /* OpenBraceToken */, 20 /* CloseBraceToken */, [isOptionEnabled("insertSpaceAfterOpeningAndBeforeClosingEmptyBraces")], 4 /* InsertSpace */), + rule("NoSpaceBetweenEmptyBraceBrackets", 19 /* OpenBraceToken */, 20 /* CloseBraceToken */, [isOptionDisabled("insertSpaceAfterOpeningAndBeforeClosingEmptyBraces"), isNonJsxSameLineTokenContext], 16 /* DeleteSpace */), + // Insert space after opening and before closing template string braces + rule("SpaceAfterTemplateHeadAndMiddle", [16 /* TemplateHead */, 17 /* TemplateMiddle */], anyToken, [isOptionEnabled("insertSpaceAfterOpeningAndBeforeClosingTemplateStringBraces"), isNonJsxTextContext], 4 /* InsertSpace */, 1 /* CanDeleteNewLines */), + rule("SpaceBeforeTemplateMiddleAndTail", anyToken, [17 /* TemplateMiddle */, 18 /* TemplateTail */], [isOptionEnabled("insertSpaceAfterOpeningAndBeforeClosingTemplateStringBraces"), isNonJsxSameLineTokenContext], 4 /* InsertSpace */), + rule("NoSpaceAfterTemplateHeadAndMiddle", [16 /* TemplateHead */, 17 /* TemplateMiddle */], anyToken, [isOptionDisabledOrUndefined("insertSpaceAfterOpeningAndBeforeClosingTemplateStringBraces"), isNonJsxTextContext], 16 /* DeleteSpace */, 1 /* CanDeleteNewLines */), + rule("NoSpaceBeforeTemplateMiddleAndTail", anyToken, [17 /* TemplateMiddle */, 18 /* TemplateTail */], [isOptionDisabledOrUndefined("insertSpaceAfterOpeningAndBeforeClosingTemplateStringBraces"), isNonJsxSameLineTokenContext], 16 /* DeleteSpace */), + // No space after { and before } in JSX expression + rule("SpaceAfterOpenBraceInJsxExpression", 19 /* OpenBraceToken */, anyToken, [isOptionEnabled("insertSpaceAfterOpeningAndBeforeClosingJsxExpressionBraces"), isNonJsxSameLineTokenContext, isJsxExpressionContext], 4 /* InsertSpace */), + rule("SpaceBeforeCloseBraceInJsxExpression", anyToken, 20 /* CloseBraceToken */, [isOptionEnabled("insertSpaceAfterOpeningAndBeforeClosingJsxExpressionBraces"), isNonJsxSameLineTokenContext, isJsxExpressionContext], 4 /* InsertSpace */), + rule("NoSpaceAfterOpenBraceInJsxExpression", 19 /* OpenBraceToken */, anyToken, [isOptionDisabledOrUndefined("insertSpaceAfterOpeningAndBeforeClosingJsxExpressionBraces"), isNonJsxSameLineTokenContext, isJsxExpressionContext], 16 /* DeleteSpace */), + rule("NoSpaceBeforeCloseBraceInJsxExpression", anyToken, 20 /* CloseBraceToken */, [isOptionDisabledOrUndefined("insertSpaceAfterOpeningAndBeforeClosingJsxExpressionBraces"), isNonJsxSameLineTokenContext, isJsxExpressionContext], 16 /* DeleteSpace */), + // Insert space after semicolon in for statement + rule("SpaceAfterSemicolonInFor", 27 /* SemicolonToken */, anyToken, [isOptionEnabled("insertSpaceAfterSemicolonInForStatements"), isNonJsxSameLineTokenContext, isForContext], 4 /* InsertSpace */), + rule("NoSpaceAfterSemicolonInFor", 27 /* SemicolonToken */, anyToken, [isOptionDisabledOrUndefined("insertSpaceAfterSemicolonInForStatements"), isNonJsxSameLineTokenContext, isForContext], 16 /* DeleteSpace */), + // Insert space before and after binary operators + rule("SpaceBeforeBinaryOperator", anyToken, binaryOperators, [isOptionEnabled("insertSpaceBeforeAndAfterBinaryOperators"), isNonJsxSameLineTokenContext, isBinaryOpContext], 4 /* InsertSpace */), + rule("SpaceAfterBinaryOperator", binaryOperators, anyToken, [isOptionEnabled("insertSpaceBeforeAndAfterBinaryOperators"), isNonJsxSameLineTokenContext, isBinaryOpContext], 4 /* InsertSpace */), + rule("NoSpaceBeforeBinaryOperator", anyToken, binaryOperators, [isOptionDisabledOrUndefined("insertSpaceBeforeAndAfterBinaryOperators"), isNonJsxSameLineTokenContext, isBinaryOpContext], 16 /* DeleteSpace */), + rule("NoSpaceAfterBinaryOperator", binaryOperators, anyToken, [isOptionDisabledOrUndefined("insertSpaceBeforeAndAfterBinaryOperators"), isNonJsxSameLineTokenContext, isBinaryOpContext], 16 /* DeleteSpace */), + rule("SpaceBeforeOpenParenInFuncDecl", anyToken, 21 /* OpenParenToken */, [isOptionEnabled("insertSpaceBeforeFunctionParenthesis"), isNonJsxSameLineTokenContext, isFunctionDeclContext], 4 /* InsertSpace */), + rule("NoSpaceBeforeOpenParenInFuncDecl", anyToken, 21 /* OpenParenToken */, [isOptionDisabledOrUndefined("insertSpaceBeforeFunctionParenthesis"), isNonJsxSameLineTokenContext, isFunctionDeclContext], 16 /* DeleteSpace */), + // Open Brace braces after control block + rule("NewLineBeforeOpenBraceInControl", controlOpenBraceLeftTokenRange, 19 /* OpenBraceToken */, [isOptionEnabled("placeOpenBraceOnNewLineForControlBlocks"), isControlDeclContext, isBeforeMultilineBlockContext], 8 /* InsertNewLine */, 1 /* CanDeleteNewLines */), + // Open Brace braces after function + // TypeScript: Function can have return types, which can be made of tons of different token kinds + rule("NewLineBeforeOpenBraceInFunction", functionOpenBraceLeftTokenRange, 19 /* OpenBraceToken */, [isOptionEnabled("placeOpenBraceOnNewLineForFunctions"), isFunctionDeclContext, isBeforeMultilineBlockContext], 8 /* InsertNewLine */, 1 /* CanDeleteNewLines */), + // Open Brace braces after TypeScript module/class/interface + rule("NewLineBeforeOpenBraceInTypeScriptDeclWithBlock", typeScriptOpenBraceLeftTokenRange, 19 /* OpenBraceToken */, [isOptionEnabled("placeOpenBraceOnNewLineForFunctions"), isTypeScriptDeclWithBlockContext, isBeforeMultilineBlockContext], 8 /* InsertNewLine */, 1 /* CanDeleteNewLines */), + rule("SpaceAfterTypeAssertion", 32 /* GreaterThanToken */, anyToken, [isOptionEnabled("insertSpaceAfterTypeAssertion"), isNonJsxSameLineTokenContext, isTypeAssertionContext], 4 /* InsertSpace */), + rule("NoSpaceAfterTypeAssertion", 32 /* GreaterThanToken */, anyToken, [isOptionDisabledOrUndefined("insertSpaceAfterTypeAssertion"), isNonJsxSameLineTokenContext, isTypeAssertionContext], 16 /* DeleteSpace */), + rule("SpaceBeforeTypeAnnotation", anyToken, [58 /* QuestionToken */, 59 /* ColonToken */], [isOptionEnabled("insertSpaceBeforeTypeAnnotation"), isNonJsxSameLineTokenContext, isTypeAnnotationContext], 4 /* InsertSpace */), + rule("NoSpaceBeforeTypeAnnotation", anyToken, [58 /* QuestionToken */, 59 /* ColonToken */], [isOptionDisabledOrUndefined("insertSpaceBeforeTypeAnnotation"), isNonJsxSameLineTokenContext, isTypeAnnotationContext], 16 /* DeleteSpace */), + rule("NoOptionalSemicolon", 27 /* SemicolonToken */, anyTokenIncludingEOF, [optionEquals("semicolons", "remove" /* Remove */), isSemicolonDeletionContext], 32 /* DeleteToken */), + rule("OptionalSemicolon", anyToken, anyTokenIncludingEOF, [optionEquals("semicolons", "insert" /* Insert */), isSemicolonInsertionContext], 64 /* InsertTrailingSemicolon */) + ]; + const lowPriorityCommonRules = [ + // Space after keyword but not before ; or : or ? + rule("NoSpaceBeforeSemicolon", anyToken, 27 /* SemicolonToken */, [isNonJsxSameLineTokenContext], 16 /* DeleteSpace */), + rule("SpaceBeforeOpenBraceInControl", controlOpenBraceLeftTokenRange, 19 /* OpenBraceToken */, [isOptionDisabledOrUndefinedOrTokensOnSameLine("placeOpenBraceOnNewLineForControlBlocks"), isControlDeclContext, isNotFormatOnEnter, isSameLineTokenOrBeforeBlockContext], 4 /* InsertSpace */, 1 /* CanDeleteNewLines */), + rule("SpaceBeforeOpenBraceInFunction", functionOpenBraceLeftTokenRange, 19 /* OpenBraceToken */, [isOptionDisabledOrUndefinedOrTokensOnSameLine("placeOpenBraceOnNewLineForFunctions"), isFunctionDeclContext, isBeforeBlockContext, isNotFormatOnEnter, isSameLineTokenOrBeforeBlockContext], 4 /* InsertSpace */, 1 /* CanDeleteNewLines */), + rule("SpaceBeforeOpenBraceInTypeScriptDeclWithBlock", typeScriptOpenBraceLeftTokenRange, 19 /* OpenBraceToken */, [isOptionDisabledOrUndefinedOrTokensOnSameLine("placeOpenBraceOnNewLineForFunctions"), isTypeScriptDeclWithBlockContext, isNotFormatOnEnter, isSameLineTokenOrBeforeBlockContext], 4 /* InsertSpace */, 1 /* CanDeleteNewLines */), + rule("NoSpaceBeforeComma", anyToken, 28 /* CommaToken */, [isNonJsxSameLineTokenContext], 16 /* DeleteSpace */), + // No space before and after indexer `x[]` + rule("NoSpaceBeforeOpenBracket", anyTokenExcept(134 /* AsyncKeyword */, 84 /* CaseKeyword */), 23 /* OpenBracketToken */, [isNonJsxSameLineTokenContext], 16 /* DeleteSpace */), + rule("NoSpaceAfterCloseBracket", 24 /* CloseBracketToken */, anyToken, [isNonJsxSameLineTokenContext, isNotBeforeBlockInFunctionDeclarationContext], 16 /* DeleteSpace */), + rule("SpaceAfterSemicolon", 27 /* SemicolonToken */, anyToken, [isNonJsxSameLineTokenContext], 4 /* InsertSpace */), + // Remove extra space between for and await + rule("SpaceBetweenForAndAwaitKeyword", 99 /* ForKeyword */, 135 /* AwaitKeyword */, [isNonJsxSameLineTokenContext], 4 /* InsertSpace */), + // Add a space between statements. All keywords except (do,else,case) has open/close parens after them. + // So, we have a rule to add a space for [),Any], [do,Any], [else,Any], and [case,Any] + rule( + "SpaceBetweenStatements", + [22 /* CloseParenToken */, 92 /* DoKeyword */, 93 /* ElseKeyword */, 84 /* CaseKeyword */], + anyToken, + [isNonJsxSameLineTokenContext, isNonJsxElementOrFragmentContext, isNotForContext], + 4 /* InsertSpace */ + ), + // This low-pri rule takes care of "try {", "catch {" and "finally {" in case the rule SpaceBeforeOpenBraceInControl didn't execute on FormatOnEnter. + rule("SpaceAfterTryCatchFinally", [113 /* TryKeyword */, 85 /* CatchKeyword */, 98 /* FinallyKeyword */], 19 /* OpenBraceToken */, [isNonJsxSameLineTokenContext], 4 /* InsertSpace */) + ]; + return [ + ...highPriorityCommonRules, + ...userConfigurableRules, + ...lowPriorityCommonRules + ]; + } + function rule(debugName, left, right, context, action, flags = 0 /* None */) { + return { leftTokenRange: toTokenRange(left), rightTokenRange: toTokenRange(right), rule: { debugName, context, action, flags } }; + } + function tokenRangeFrom(tokens) { + return { tokens, isSpecific: true }; + } + function toTokenRange(arg) { + return typeof arg === "number" ? tokenRangeFrom([arg]) : isArray(arg) ? tokenRangeFrom(arg) : arg; + } + function tokenRangeFromRange(from, to, except = []) { + const tokens = []; + for (let token = from; token <= to; token++) { + if (!contains(except, token)) { + tokens.push(token); } - return text; - } - function printTypeInSingleLine(type) { - const flags = 70221824 /* IgnoreErrors */ | 1048576 /* AllowUniqueESSymbolType */ | 16384 /* UseAliasDefinedOutsideCurrentScope */; - const printer = createPrinterWithRemoveComments(); - return usingSingleLineStringWriter((writer) => { - const typeNode = checker.typeToTypeNode( - type, - /*enclosingDeclaration*/ - void 0, - flags - ); - Debug.assertIsDefined(typeNode, "should always get typenode"); - printer.writeNode( - 4 /* Unspecified */, - typeNode, - /*sourceFile*/ - file, - writer - ); - }); } - function isUndefined(name) { - return name === "undefined"; + return tokenRangeFrom(tokens); + } + function optionEquals(optionName, optionValue) { + return (context) => context.options && context.options[optionName] === optionValue; + } + function isOptionEnabled(optionName) { + return (context) => context.options && hasProperty(context.options, optionName) && !!context.options[optionName]; + } + function isOptionDisabled(optionName) { + return (context) => context.options && hasProperty(context.options, optionName) && !context.options[optionName]; + } + function isOptionDisabledOrUndefined(optionName) { + return (context) => !context.options || !hasProperty(context.options, optionName) || !context.options[optionName]; + } + function isOptionDisabledOrUndefinedOrTokensOnSameLine(optionName) { + return (context) => !context.options || !hasProperty(context.options, optionName) || !context.options[optionName] || context.TokensAreOnSameLine(); + } + function isOptionEnabledOrUndefined(optionName) { + return (context) => !context.options || !hasProperty(context.options, optionName) || !!context.options[optionName]; + } + function isForContext(context) { + return context.contextNode.kind === 248 /* ForStatement */; + } + function isNotForContext(context) { + return !isForContext(context); + } + function isBinaryOpContext(context) { + switch (context.contextNode.kind) { + case 226 /* BinaryExpression */: + return context.contextNode.operatorToken.kind !== 28 /* CommaToken */; + case 227 /* ConditionalExpression */: + case 194 /* ConditionalType */: + case 234 /* AsExpression */: + case 281 /* ExportSpecifier */: + case 276 /* ImportSpecifier */: + case 182 /* TypePredicate */: + case 192 /* UnionType */: + case 193 /* IntersectionType */: + case 238 /* SatisfiesExpression */: + return true; + case 208 /* BindingElement */: + case 265 /* TypeAliasDeclaration */: + case 271 /* ImportEqualsDeclaration */: + case 277 /* ExportAssignment */: + case 260 /* VariableDeclaration */: + case 169 /* Parameter */: + case 306 /* EnumMember */: + case 172 /* PropertyDeclaration */: + case 171 /* PropertySignature */: + return context.currentTokenSpan.kind === 64 /* EqualsToken */ || context.nextTokenSpan.kind === 64 /* EqualsToken */; + case 249 /* ForInStatement */: + case 168 /* TypeParameter */: + return context.currentTokenSpan.kind === 103 /* InKeyword */ || context.nextTokenSpan.kind === 103 /* InKeyword */ || context.currentTokenSpan.kind === 64 /* EqualsToken */ || context.nextTokenSpan.kind === 64 /* EqualsToken */; + case 250 /* ForOfStatement */: + return context.currentTokenSpan.kind === 165 /* OfKeyword */ || context.nextTokenSpan.kind === 165 /* OfKeyword */; } - function isHintableDeclaration(node) { - if ((isParameterDeclaration(node) || isVariableDeclaration(node) && isVarConst(node)) && node.initializer) { - const initializer = skipParentheses(node.initializer); - return !(isHintableLiteral(initializer) || isNewExpression(initializer) || isObjectLiteralExpression(initializer) || isAssertionExpression(initializer)); - } + return false; + } + function isNotBinaryOpContext(context) { + return !isBinaryOpContext(context); + } + function isNotTypeAnnotationContext(context) { + return !isTypeAnnotationContext(context); + } + function isTypeAnnotationContext(context) { + const contextKind = context.contextNode.kind; + return contextKind === 172 /* PropertyDeclaration */ || contextKind === 171 /* PropertySignature */ || contextKind === 169 /* Parameter */ || contextKind === 260 /* VariableDeclaration */ || isFunctionLikeKind(contextKind); + } + function isOptionalPropertyContext(context) { + return isPropertyDeclaration(context.contextNode) && context.contextNode.questionToken; + } + function isNonOptionalPropertyContext(context) { + return !isOptionalPropertyContext(context); + } + function isConditionalOperatorContext(context) { + return context.contextNode.kind === 227 /* ConditionalExpression */ || context.contextNode.kind === 194 /* ConditionalType */; + } + function isSameLineTokenOrBeforeBlockContext(context) { + return context.TokensAreOnSameLine() || isBeforeBlockContext(context); + } + function isBraceWrappedContext(context) { + return context.contextNode.kind === 206 /* ObjectBindingPattern */ || context.contextNode.kind === 200 /* MappedType */ || isSingleLineBlockContext(context); + } + function isBeforeMultilineBlockContext(context) { + return isBeforeBlockContext(context) && !(context.NextNodeAllOnSameLine() || context.NextNodeBlockIsOnOneLine()); + } + function isMultilineBlockContext(context) { + return isBlockContext(context) && !(context.ContextNodeAllOnSameLine() || context.ContextNodeBlockIsOnOneLine()); + } + function isSingleLineBlockContext(context) { + return isBlockContext(context) && (context.ContextNodeAllOnSameLine() || context.ContextNodeBlockIsOnOneLine()); + } + function isBlockContext(context) { + return nodeIsBlockContext(context.contextNode); + } + function isBeforeBlockContext(context) { + return nodeIsBlockContext(context.nextTokenParent); + } + function nodeIsBlockContext(node) { + if (nodeIsTypeScriptDeclWithBlockContext(node)) { return true; } - } - var maxHintsLength, leadingParameterNameCommentRegexFactory; - var init_inlayHints = __esm({ - "src/services/inlayHints.ts"() { - "use strict"; - init_ts4(); - maxHintsLength = 30; - leadingParameterNameCommentRegexFactory = (name) => { - return new RegExp(`^\\s?/\\*\\*?\\s?${name}\\s?\\*\\/\\s?$`); - }; + switch (node.kind) { + case 241 /* Block */: + case 269 /* CaseBlock */: + case 210 /* ObjectLiteralExpression */: + case 268 /* ModuleBlock */: + return true; } - }); - - // src/services/_namespaces/ts.InlayHints.ts - var ts_InlayHints_exports = {}; - __export(ts_InlayHints_exports, { - provideInlayHints: () => provideInlayHints - }); - var init_ts_InlayHints = __esm({ - "src/services/_namespaces/ts.InlayHints.ts"() { - "use strict"; - init_inlayHints(); + return false; + } + function isFunctionDeclContext(context) { + switch (context.contextNode.kind) { + case 262 /* FunctionDeclaration */: + case 174 /* MethodDeclaration */: + case 173 /* MethodSignature */: + case 177 /* GetAccessor */: + case 178 /* SetAccessor */: + case 179 /* CallSignature */: + case 218 /* FunctionExpression */: + case 176 /* Constructor */: + case 219 /* ArrowFunction */: + case 264 /* InterfaceDeclaration */: + return true; } - }); - - // src/services/jsDoc.ts - function getJsDocCommentsFromDeclarations(declarations, checker) { - const parts = []; - forEachUnique(declarations, (declaration) => { - for (const jsdoc of getCommentHavingNodes(declaration)) { - const inheritDoc = isJSDoc(jsdoc) && jsdoc.tags && find(jsdoc.tags, (t) => t.kind === 333 /* JSDocTag */ && (t.tagName.escapedText === "inheritDoc" || t.tagName.escapedText === "inheritdoc")); - if (jsdoc.comment === void 0 && !inheritDoc || isJSDoc(jsdoc) && declaration.kind !== 352 /* JSDocTypedefTag */ && declaration.kind !== 344 /* JSDocCallbackTag */ && jsdoc.tags && jsdoc.tags.some((t) => t.kind === 352 /* JSDocTypedefTag */ || t.kind === 344 /* JSDocCallbackTag */) && !jsdoc.tags.some((t) => t.kind === 347 /* JSDocParameterTag */ || t.kind === 348 /* JSDocReturnTag */)) { - continue; - } - let newparts = jsdoc.comment ? getDisplayPartsFromComment(jsdoc.comment, checker) : []; - if (inheritDoc && inheritDoc.comment) { - newparts = newparts.concat(getDisplayPartsFromComment(inheritDoc.comment, checker)); - } - if (!contains(parts, newparts, isIdenticalListOfDisplayParts)) { - parts.push(newparts); - } - } - }); - return flatten(intersperse(parts, [lineBreakPart()])); + return false; } - function isIdenticalListOfDisplayParts(parts1, parts2) { - return arraysEqual(parts1, parts2, (p1, p2) => p1.kind === p2.kind && p1.text === p2.text); + function isNotFunctionDeclContext(context) { + return !isFunctionDeclContext(context); } - function getCommentHavingNodes(declaration) { - switch (declaration.kind) { - case 347 /* JSDocParameterTag */: - case 354 /* JSDocPropertyTag */: - return [declaration]; - case 344 /* JSDocCallbackTag */: - case 352 /* JSDocTypedefTag */: - return [declaration, declaration.parent]; - default: - return getJSDocCommentsAndTags(declaration); - } + function isFunctionDeclarationOrFunctionExpressionContext(context) { + return context.contextNode.kind === 262 /* FunctionDeclaration */ || context.contextNode.kind === 218 /* FunctionExpression */; } - function getJsDocTagsFromDeclarations(declarations, checker) { - const infos = []; - forEachUnique(declarations, (declaration) => { - const tags = getJSDocTags(declaration); - if (tags.some((t) => t.kind === 352 /* JSDocTypedefTag */ || t.kind === 344 /* JSDocCallbackTag */) && !tags.some((t) => t.kind === 347 /* JSDocParameterTag */ || t.kind === 348 /* JSDocReturnTag */)) { - return; - } - for (const tag of tags) { - infos.push({ name: tag.tagName.text, text: getCommentDisplayParts(tag, checker) }); - } - }); - return infos; + function isTypeScriptDeclWithBlockContext(context) { + return nodeIsTypeScriptDeclWithBlockContext(context.contextNode); } - function getDisplayPartsFromComment(comment, checker) { - if (typeof comment === "string") { - return [textPart(comment)]; + function nodeIsTypeScriptDeclWithBlockContext(node) { + switch (node.kind) { + case 263 /* ClassDeclaration */: + case 231 /* ClassExpression */: + case 264 /* InterfaceDeclaration */: + case 266 /* EnumDeclaration */: + case 187 /* TypeLiteral */: + case 267 /* ModuleDeclaration */: + case 278 /* ExportDeclaration */: + case 279 /* NamedExports */: + case 272 /* ImportDeclaration */: + case 275 /* NamedImports */: + return true; } - return flatMap( - comment, - (node) => node.kind === 327 /* JSDocText */ ? [textPart(node.text)] : buildLinkParts(node, checker) - ); + return false; } - function getCommentDisplayParts(tag, checker) { - const { comment, kind } = tag; - const namePart = getTagNameDisplayPart(kind); - switch (kind) { - case 355 /* JSDocThrowsTag */: - const typeExpression = tag.typeExpression; - return typeExpression ? withNode(typeExpression) : comment === void 0 ? void 0 : getDisplayPartsFromComment(comment, checker); - case 335 /* JSDocImplementsTag */: - return withNode(tag.class); - case 334 /* JSDocAugmentsTag */: - return withNode(tag.class); - case 351 /* JSDocTemplateTag */: - const templateTag = tag; - const displayParts = []; - if (templateTag.constraint) { - displayParts.push(textPart(templateTag.constraint.getText())); - } - if (length(templateTag.typeParameters)) { - if (length(displayParts)) { - displayParts.push(spacePart()); - } - const lastTypeParameter = templateTag.typeParameters[templateTag.typeParameters.length - 1]; - forEach(templateTag.typeParameters, (tp) => { - displayParts.push(namePart(tp.getText())); - if (lastTypeParameter !== tp) { - displayParts.push(...[punctuationPart(28 /* CommaToken */), spacePart()]); - } - }); - } - if (comment) { - displayParts.push(...[spacePart(), ...getDisplayPartsFromComment(comment, checker)]); - } - return displayParts; - case 350 /* JSDocTypeTag */: - case 356 /* JSDocSatisfiesTag */: - return withNode(tag.typeExpression); - case 352 /* JSDocTypedefTag */: - case 344 /* JSDocCallbackTag */: - case 354 /* JSDocPropertyTag */: - case 347 /* JSDocParameterTag */: - case 353 /* JSDocSeeTag */: - const { name } = tag; - return name ? withNode(name) : comment === void 0 ? void 0 : getDisplayPartsFromComment(comment, checker); - default: - return comment === void 0 ? void 0 : getDisplayPartsFromComment(comment, checker); - } - function withNode(node) { - return addComment(node.getText()); - } - function addComment(s) { - if (comment) { - if (s.match(/^https?$/)) { - return [textPart(s), ...getDisplayPartsFromComment(comment, checker)]; - } else { - return [namePart(s), spacePart(), ...getDisplayPartsFromComment(comment, checker)]; + function isAfterCodeBlockContext(context) { + switch (context.currentTokenParent.kind) { + case 263 /* ClassDeclaration */: + case 267 /* ModuleDeclaration */: + case 266 /* EnumDeclaration */: + case 299 /* CatchClause */: + case 268 /* ModuleBlock */: + case 255 /* SwitchStatement */: + return true; + case 241 /* Block */: { + const blockParent = context.currentTokenParent.parent; + if (!blockParent || blockParent.kind !== 219 /* ArrowFunction */ && blockParent.kind !== 218 /* FunctionExpression */) { + return true; } - } else { - return [textPart(s)]; } } + return false; } - function getTagNameDisplayPart(kind) { - switch (kind) { - case 347 /* JSDocParameterTag */: - return parameterNamePart; - case 354 /* JSDocPropertyTag */: - return propertyNamePart; - case 351 /* JSDocTemplateTag */: - return typeParameterNamePart; - case 352 /* JSDocTypedefTag */: - case 344 /* JSDocCallbackTag */: - return typeAliasNamePart; + function isControlDeclContext(context) { + switch (context.contextNode.kind) { + case 245 /* IfStatement */: + case 255 /* SwitchStatement */: + case 248 /* ForStatement */: + case 249 /* ForInStatement */: + case 250 /* ForOfStatement */: + case 247 /* WhileStatement */: + case 258 /* TryStatement */: + case 246 /* DoStatement */: + case 254 /* WithStatement */: + case 299 /* CatchClause */: + return true; default: - return textPart; + return false; } } - function getJSDocTagNameCompletions() { - return jsDocTagNameCompletionEntries || (jsDocTagNameCompletionEntries = map(jsDocTagNames, (tagName) => { - return { - name: tagName, - kind: "keyword" /* keyword */, - kindModifiers: "", - sortText: ts_Completions_exports.SortText.LocationPriority - }; - })); + function isObjectContext(context) { + return context.contextNode.kind === 210 /* ObjectLiteralExpression */; } - function getJSDocTagCompletions() { - return jsDocTagCompletionEntries || (jsDocTagCompletionEntries = map(jsDocTagNames, (tagName) => { - return { - name: `@${tagName}`, - kind: "keyword" /* keyword */, - kindModifiers: "", - sortText: ts_Completions_exports.SortText.LocationPriority - }; - })); + function isFunctionCallContext(context) { + return context.contextNode.kind === 213 /* CallExpression */; } - function getJSDocTagCompletionDetails(name) { - return { - name, - kind: "" /* unknown */, - // TODO: should have its own kind? - kindModifiers: "", - displayParts: [textPart(name)], - documentation: emptyArray, - tags: void 0, - codeActions: void 0 - }; + function isNewContext(context) { + return context.contextNode.kind === 214 /* NewExpression */; } - function getJSDocParameterNameCompletions(tag) { - if (!isIdentifier(tag.name)) { - return emptyArray; - } - const nameThusFar = tag.name.text; - const jsdoc = tag.parent; - const fn = jsdoc.parent; - if (!isFunctionLike(fn)) - return []; - return mapDefined(fn.parameters, (param) => { - if (!isIdentifier(param.name)) - return void 0; - const name = param.name.text; - if (jsdoc.tags.some((t) => t !== tag && isJSDocParameterTag(t) && isIdentifier(t.name) && t.name.escapedText === name) || nameThusFar !== void 0 && !startsWith(name, nameThusFar)) { - return void 0; - } - return { name, kind: "parameter" /* parameterElement */, kindModifiers: "", sortText: ts_Completions_exports.SortText.LocationPriority }; - }); + function isFunctionCallOrNewContext(context) { + return isFunctionCallContext(context) || isNewContext(context); } - function getJSDocParameterNameCompletionDetails(name) { - return { - name, - kind: "parameter" /* parameterElement */, - kindModifiers: "", - displayParts: [textPart(name)], - documentation: emptyArray, - tags: void 0, - codeActions: void 0 - }; + function isPreviousTokenNotComma(context) { + return context.currentTokenSpan.kind !== 28 /* CommaToken */; } - function getDocCommentTemplateAtPosition(newLine, sourceFile, position, options) { - const tokenAtPos = getTokenAtPosition(sourceFile, position); - const existingDocComment = findAncestor(tokenAtPos, isJSDoc); - if (existingDocComment && (existingDocComment.comment !== void 0 || length(existingDocComment.tags))) { - return void 0; - } - const tokenStart = tokenAtPos.getStart(sourceFile); - if (!existingDocComment && tokenStart < position) { - return void 0; - } - const commentOwnerInfo = getCommentOwnerInfo(tokenAtPos, options); - if (!commentOwnerInfo) { - return void 0; + function isNextTokenNotCloseBracket(context) { + return context.nextTokenSpan.kind !== 24 /* CloseBracketToken */; + } + function isNextTokenNotCloseParen(context) { + return context.nextTokenSpan.kind !== 22 /* CloseParenToken */; + } + function isArrowFunctionContext(context) { + return context.contextNode.kind === 219 /* ArrowFunction */; + } + function isImportTypeContext(context) { + return context.contextNode.kind === 205 /* ImportType */; + } + function isNonJsxSameLineTokenContext(context) { + return context.TokensAreOnSameLine() && context.contextNode.kind !== 12 /* JsxText */; + } + function isNonJsxTextContext(context) { + return context.contextNode.kind !== 12 /* JsxText */; + } + function isNonJsxElementOrFragmentContext(context) { + return context.contextNode.kind !== 284 /* JsxElement */ && context.contextNode.kind !== 288 /* JsxFragment */; + } + function isJsxExpressionContext(context) { + return context.contextNode.kind === 294 /* JsxExpression */ || context.contextNode.kind === 293 /* JsxSpreadAttribute */; + } + function isNextTokenParentJsxAttribute(context) { + return context.nextTokenParent.kind === 291 /* JsxAttribute */ || context.nextTokenParent.kind === 295 /* JsxNamespacedName */ && context.nextTokenParent.parent.kind === 291 /* JsxAttribute */; + } + function isJsxAttributeContext(context) { + return context.contextNode.kind === 291 /* JsxAttribute */; + } + function isNextTokenParentNotJsxNamespacedName(context) { + return context.nextTokenParent.kind !== 295 /* JsxNamespacedName */; + } + function isNextTokenParentJsxNamespacedName(context) { + return context.nextTokenParent.kind === 295 /* JsxNamespacedName */; + } + function isJsxSelfClosingElementContext(context) { + return context.contextNode.kind === 285 /* JsxSelfClosingElement */; + } + function isNotBeforeBlockInFunctionDeclarationContext(context) { + return !isFunctionDeclContext(context) && !isBeforeBlockContext(context); + } + function isEndOfDecoratorContextOnSameLine(context) { + return context.TokensAreOnSameLine() && hasDecorators(context.contextNode) && nodeIsInDecoratorContext(context.currentTokenParent) && !nodeIsInDecoratorContext(context.nextTokenParent); + } + function nodeIsInDecoratorContext(node) { + while (node && isExpression(node)) { + node = node.parent; } - const { commentOwner, parameters, hasReturn: hasReturn2 } = commentOwnerInfo; - const commentOwnerJsDoc = hasJSDocNodes(commentOwner) && commentOwner.jsDoc ? commentOwner.jsDoc : void 0; - const lastJsDoc = lastOrUndefined(commentOwnerJsDoc); - if (commentOwner.getStart(sourceFile) < position || lastJsDoc && existingDocComment && lastJsDoc !== existingDocComment) { - return void 0; + return node && node.kind === 170 /* Decorator */; + } + function isStartOfVariableDeclarationList(context) { + return context.currentTokenParent.kind === 261 /* VariableDeclarationList */ && context.currentTokenParent.getStart(context.sourceFile) === context.currentTokenSpan.pos; + } + function isNotFormatOnEnter(context) { + return context.formattingRequestKind !== 2 /* FormatOnEnter */; + } + function isModuleDeclContext(context) { + return context.contextNode.kind === 267 /* ModuleDeclaration */; + } + function isObjectTypeContext(context) { + return context.contextNode.kind === 187 /* TypeLiteral */; + } + function isConstructorSignatureContext(context) { + return context.contextNode.kind === 180 /* ConstructSignature */; + } + function isTypeArgumentOrParameterOrAssertion(token, parent2) { + if (token.kind !== 30 /* LessThanToken */ && token.kind !== 32 /* GreaterThanToken */) { + return false; } - const indentationStr = getIndentationStringAtPosition(sourceFile, position); - const isJavaScriptFile = hasJSFileExtension(sourceFile.fileName); - const tags = (parameters ? parameterDocComments(parameters || [], isJavaScriptFile, indentationStr, newLine) : "") + (hasReturn2 ? returnsDocComment(indentationStr, newLine) : ""); - const openComment = "/**"; - const closeComment = " */"; - const hasTag = (commentOwnerJsDoc || []).some((jsDoc) => !!jsDoc.tags); - if (tags && !hasTag) { - const preamble = openComment + newLine + indentationStr + " * "; - const endLine = tokenStart === position ? newLine + indentationStr : ""; - const result = preamble + newLine + tags + indentationStr + closeComment + endLine; - return { newText: result, caretOffset: preamble.length }; + switch (parent2.kind) { + case 183 /* TypeReference */: + case 216 /* TypeAssertionExpression */: + case 265 /* TypeAliasDeclaration */: + case 263 /* ClassDeclaration */: + case 231 /* ClassExpression */: + case 264 /* InterfaceDeclaration */: + case 262 /* FunctionDeclaration */: + case 218 /* FunctionExpression */: + case 219 /* ArrowFunction */: + case 174 /* MethodDeclaration */: + case 173 /* MethodSignature */: + case 179 /* CallSignature */: + case 180 /* ConstructSignature */: + case 213 /* CallExpression */: + case 214 /* NewExpression */: + case 233 /* ExpressionWithTypeArguments */: + return true; + default: + return false; } - return { newText: openComment + closeComment, caretOffset: 3 }; } - function getIndentationStringAtPosition(sourceFile, position) { - const { text } = sourceFile; - const lineStart = getLineStartPositionForPosition(position, sourceFile); - let pos = lineStart; - for (; pos <= position && isWhiteSpaceSingleLine(text.charCodeAt(pos)); pos++) - ; - return text.slice(lineStart, pos); + function isTypeArgumentOrParameterOrAssertionContext(context) { + return isTypeArgumentOrParameterOrAssertion(context.currentTokenSpan, context.currentTokenParent) || isTypeArgumentOrParameterOrAssertion(context.nextTokenSpan, context.nextTokenParent); } - function parameterDocComments(parameters, isJavaScriptFile, indentationStr, newLine) { - return parameters.map(({ name, dotDotDotToken }, i) => { - const paramName = name.kind === 80 /* Identifier */ ? name.text : "param" + i; - const type = isJavaScriptFile ? dotDotDotToken ? "{...any} " : "{any} " : ""; - return `${indentationStr} * @param ${type}${paramName}${newLine}`; - }).join(""); + function isTypeAssertionContext(context) { + return context.contextNode.kind === 216 /* TypeAssertionExpression */; } - function returnsDocComment(indentationStr, newLine) { - return `${indentationStr} * @returns${newLine}`; + function isNonTypeAssertionContext(context) { + return !isTypeAssertionContext(context); } - function getCommentOwnerInfo(tokenAtPos, options) { - return forEachAncestor(tokenAtPos, (n) => getCommentOwnerInfoWorker(n, options)); + function isVoidOpContext(context) { + return context.currentTokenSpan.kind === 116 /* VoidKeyword */ && context.currentTokenParent.kind === 222 /* VoidExpression */; } - function getCommentOwnerInfoWorker(commentOwner, options) { - switch (commentOwner.kind) { - case 261 /* FunctionDeclaration */: - case 217 /* FunctionExpression */: - case 173 /* MethodDeclaration */: - case 175 /* Constructor */: - case 172 /* MethodSignature */: - case 218 /* ArrowFunction */: - const host = commentOwner; - return { commentOwner, parameters: host.parameters, hasReturn: hasReturn(host, options) }; - case 302 /* PropertyAssignment */: - return getCommentOwnerInfoWorker(commentOwner.initializer, options); - case 262 /* ClassDeclaration */: - case 263 /* InterfaceDeclaration */: - case 265 /* EnumDeclaration */: - case 305 /* EnumMember */: - case 264 /* TypeAliasDeclaration */: - return { commentOwner }; - case 170 /* PropertySignature */: { - const host2 = commentOwner; - return host2.type && isFunctionTypeNode(host2.type) ? { commentOwner, parameters: host2.type.parameters, hasReturn: hasReturn(host2.type, options) } : { commentOwner }; - } - case 242 /* VariableStatement */: { - const varStatement = commentOwner; - const varDeclarations = varStatement.declarationList.declarations; - const host2 = varDeclarations.length === 1 && varDeclarations[0].initializer ? getRightHandSideOfAssignment(varDeclarations[0].initializer) : void 0; - return host2 ? { commentOwner, parameters: host2.parameters, hasReturn: hasReturn(host2, options) } : { commentOwner }; - } - case 311 /* SourceFile */: - return "quit"; - case 266 /* ModuleDeclaration */: - return commentOwner.parent.kind === 266 /* ModuleDeclaration */ ? void 0 : { commentOwner }; - case 243 /* ExpressionStatement */: - return getCommentOwnerInfoWorker(commentOwner.expression, options); - case 225 /* BinaryExpression */: { - const be = commentOwner; - if (getAssignmentDeclarationKind(be) === 0 /* None */) { - return "quit"; - } - return isFunctionLike(be.right) ? { commentOwner, parameters: be.right.parameters, hasReturn: hasReturn(be.right, options) } : { commentOwner }; - } - case 171 /* PropertyDeclaration */: - const init = commentOwner.initializer; - if (init && (isFunctionExpression(init) || isArrowFunction(init))) { - return { commentOwner, parameters: init.parameters, hasReturn: hasReturn(init, options) }; - } - } + function isYieldOrYieldStarWithOperand(context) { + return context.contextNode.kind === 229 /* YieldExpression */ && context.contextNode.expression !== void 0; } - function hasReturn(node, options) { - return !!(options == null ? void 0 : options.generateReturnInDocTemplate) && (isFunctionTypeNode(node) || isArrowFunction(node) && isExpression(node.body) || isFunctionLikeDeclaration(node) && node.body && isBlock(node.body) && !!forEachReturnStatement(node.body, (n) => n)); + function isNonNullAssertionContext(context) { + return context.contextNode.kind === 235 /* NonNullExpression */; } - function getRightHandSideOfAssignment(rightHandSide) { - while (rightHandSide.kind === 216 /* ParenthesizedExpression */) { - rightHandSide = rightHandSide.expression; - } - switch (rightHandSide.kind) { - case 217 /* FunctionExpression */: - case 218 /* ArrowFunction */: - return rightHandSide; - case 230 /* ClassExpression */: - return find(rightHandSide.members, isConstructorDeclaration); + function isNotStatementConditionContext(context) { + return !isStatementConditionContext(context); + } + function isStatementConditionContext(context) { + switch (context.contextNode.kind) { + case 245 /* IfStatement */: + case 248 /* ForStatement */: + case 249 /* ForInStatement */: + case 250 /* ForOfStatement */: + case 246 /* DoStatement */: + case 247 /* WhileStatement */: + return true; + default: + return false; } } - var jsDocTagNames, jsDocTagNameCompletionEntries, jsDocTagCompletionEntries, getJSDocTagNameCompletionDetails; - var init_jsDoc = __esm({ - "src/services/jsDoc.ts"() { - "use strict"; - init_ts4(); - jsDocTagNames = [ - "abstract", - "access", - "alias", - "argument", - "async", - "augments", - "author", - "borrows", - "callback", - "class", - "classdesc", - "constant", - "constructor", - "constructs", - "copyright", - "default", - "deprecated", - "description", - "emits", - "enum", - "event", - "example", - "exports", - "extends", - "external", - "field", - "file", - "fileoverview", - "fires", - "function", - "generator", - "global", - "hideconstructor", - "host", - "ignore", - "implements", - "inheritdoc", - "inner", - "instance", - "interface", - "kind", - "lends", - "license", - "link", - "linkcode", - "linkplain", - "listens", - "member", - "memberof", - "method", - "mixes", - "module", - "name", - "namespace", - "overload", - "override", - "package", - "param", - "private", - "prop", - "property", - "protected", - "public", - "readonly", - "requires", - "returns", - "satisfies", - "see", - "since", - "static", - "summary", - "template", - "this", - "throws", - "todo", - "tutorial", - "type", - "typedef", - "var", - "variation", - "version", - "virtual", - "yields" - ]; - getJSDocTagNameCompletionDetails = getJSDocTagCompletionDetails; + function isSemicolonDeletionContext(context) { + let nextTokenKind = context.nextTokenSpan.kind; + let nextTokenStart = context.nextTokenSpan.pos; + if (isTrivia(nextTokenKind)) { + const nextRealToken = context.nextTokenParent === context.currentTokenParent ? findNextToken( + context.currentTokenParent, + findAncestor(context.currentTokenParent, (a) => !a.parent), + context.sourceFile + ) : context.nextTokenParent.getFirstToken(context.sourceFile); + if (!nextRealToken) { + return true; + } + nextTokenKind = nextRealToken.kind; + nextTokenStart = nextRealToken.getStart(context.sourceFile); } - }); - - // src/services/_namespaces/ts.JsDoc.ts - var ts_JsDoc_exports = {}; - __export(ts_JsDoc_exports, { - getDocCommentTemplateAtPosition: () => getDocCommentTemplateAtPosition, - getJSDocParameterNameCompletionDetails: () => getJSDocParameterNameCompletionDetails, - getJSDocParameterNameCompletions: () => getJSDocParameterNameCompletions, - getJSDocTagCompletionDetails: () => getJSDocTagCompletionDetails, - getJSDocTagCompletions: () => getJSDocTagCompletions, - getJSDocTagNameCompletionDetails: () => getJSDocTagNameCompletionDetails, - getJSDocTagNameCompletions: () => getJSDocTagNameCompletions, - getJsDocCommentsFromDeclarations: () => getJsDocCommentsFromDeclarations, - getJsDocTagsFromDeclarations: () => getJsDocTagsFromDeclarations - }); - var init_ts_JsDoc = __esm({ - "src/services/_namespaces/ts.JsDoc.ts"() { - "use strict"; - init_jsDoc(); + const startLine = context.sourceFile.getLineAndCharacterOfPosition(context.currentTokenSpan.pos).line; + const endLine = context.sourceFile.getLineAndCharacterOfPosition(nextTokenStart).line; + if (startLine === endLine) { + return nextTokenKind === 20 /* CloseBraceToken */ || nextTokenKind === 1 /* EndOfFileToken */; } - }); - - // src/services/organizeImports.ts - function organizeImports(sourceFile, formatContext, host, program, preferences, mode) { - const changeTracker = ts_textChanges_exports.ChangeTracker.fromContext({ host, formatContext, preferences }); - const shouldSort = mode === "SortAndCombine" /* SortAndCombine */ || mode === "All" /* All */; - const shouldCombine = shouldSort; - const shouldRemove = mode === "RemoveUnused" /* RemoveUnused */ || mode === "All" /* All */; - const topLevelImportGroupDecls = groupByNewlineContiguous(sourceFile, sourceFile.statements.filter(isImportDeclaration)); - const comparer = getOrganizeImportsComparerWithDetection(preferences, shouldSort ? () => detectSortingWorker(topLevelImportGroupDecls, preferences) === 2 /* CaseInsensitive */ : void 0); - const processImportsOfSameModuleSpecifier = (importGroup) => { - if (shouldRemove) - importGroup = removeUnusedImports(importGroup, sourceFile, program); - if (shouldCombine) - importGroup = coalesceImportsWorker(importGroup, comparer, sourceFile); - if (shouldSort) - importGroup = stableSort(importGroup, (s1, s2) => compareImportsOrRequireStatements(s1, s2, comparer)); - return importGroup; - }; - topLevelImportGroupDecls.forEach((importGroupDecl) => organizeImportsWorker(importGroupDecl, processImportsOfSameModuleSpecifier)); - if (mode !== "RemoveUnused" /* RemoveUnused */) { - getTopLevelExportGroups(sourceFile).forEach((exportGroupDecl) => organizeImportsWorker(exportGroupDecl, (group2) => coalesceExportsWorker(group2, comparer))); + if (nextTokenKind === 240 /* SemicolonClassElement */ || nextTokenKind === 27 /* SemicolonToken */) { + return false; } - for (const ambientModule of sourceFile.statements.filter(isAmbientModule)) { - if (!ambientModule.body) - continue; - const ambientModuleImportGroupDecls = groupByNewlineContiguous(sourceFile, ambientModule.body.statements.filter(isImportDeclaration)); - ambientModuleImportGroupDecls.forEach((importGroupDecl) => organizeImportsWorker(importGroupDecl, processImportsOfSameModuleSpecifier)); - if (mode !== "RemoveUnused" /* RemoveUnused */) { - const ambientModuleExportDecls = ambientModule.body.statements.filter(isExportDeclaration); - organizeImportsWorker(ambientModuleExportDecls, (group2) => coalesceExportsWorker(group2, comparer)); - } + if (context.contextNode.kind === 264 /* InterfaceDeclaration */ || context.contextNode.kind === 265 /* TypeAliasDeclaration */) { + return !isPropertySignature(context.currentTokenParent) || !!context.currentTokenParent.type || nextTokenKind !== 21 /* OpenParenToken */; } - return changeTracker.getChanges(); - function organizeImportsWorker(oldImportDecls, coalesce) { - if (length(oldImportDecls) === 0) { - return; - } - suppressLeadingTrivia(oldImportDecls[0]); - const oldImportGroups = shouldCombine ? group(oldImportDecls, (importDecl) => getExternalModuleName2(importDecl.moduleSpecifier)) : [oldImportDecls]; - const sortedImportGroups = shouldSort ? stableSort(oldImportGroups, (group1, group2) => compareModuleSpecifiersWorker(group1[0].moduleSpecifier, group2[0].moduleSpecifier, comparer)) : oldImportGroups; - const newImportDecls = flatMap(sortedImportGroups, (importGroup) => getExternalModuleName2(importGroup[0].moduleSpecifier) || importGroup[0].moduleSpecifier === void 0 ? coalesce(importGroup) : importGroup); - if (newImportDecls.length === 0) { - changeTracker.deleteNodes( - sourceFile, - oldImportDecls, - { - leadingTriviaOption: ts_textChanges_exports.LeadingTriviaOption.Exclude, - trailingTriviaOption: ts_textChanges_exports.TrailingTriviaOption.Include - }, - /*hasTrailingComment*/ - true - ); - } else { - const replaceOptions = { - leadingTriviaOption: ts_textChanges_exports.LeadingTriviaOption.Exclude, - // Leave header comment in place - trailingTriviaOption: ts_textChanges_exports.TrailingTriviaOption.Include, - suffix: getNewLineOrDefaultFromHost(host, formatContext.options) - }; - changeTracker.replaceNodeWithNodes(sourceFile, oldImportDecls[0], newImportDecls, replaceOptions); - const hasTrailingComment = changeTracker.nodeHasTrailingComment(sourceFile, oldImportDecls[0], replaceOptions); - changeTracker.deleteNodes(sourceFile, oldImportDecls.slice(1), { - trailingTriviaOption: ts_textChanges_exports.TrailingTriviaOption.Include - }, hasTrailingComment); - } + if (isPropertyDeclaration(context.currentTokenParent)) { + return !context.currentTokenParent.initializer; } + return context.currentTokenParent.kind !== 248 /* ForStatement */ && context.currentTokenParent.kind !== 242 /* EmptyStatement */ && context.currentTokenParent.kind !== 240 /* SemicolonClassElement */ && nextTokenKind !== 23 /* OpenBracketToken */ && nextTokenKind !== 21 /* OpenParenToken */ && nextTokenKind !== 40 /* PlusToken */ && nextTokenKind !== 41 /* MinusToken */ && nextTokenKind !== 44 /* SlashToken */ && nextTokenKind !== 14 /* RegularExpressionLiteral */ && nextTokenKind !== 28 /* CommaToken */ && nextTokenKind !== 228 /* TemplateExpression */ && nextTokenKind !== 16 /* TemplateHead */ && nextTokenKind !== 15 /* NoSubstitutionTemplateLiteral */ && nextTokenKind !== 25 /* DotToken */; } - function groupByNewlineContiguous(sourceFile, decls) { - const scanner2 = createScanner( - sourceFile.languageVersion, - /*skipTrivia*/ - false, - sourceFile.languageVariant - ); - const group2 = []; - let groupIndex = 0; - for (const decl of decls) { - if (group2[groupIndex] && isNewGroup(sourceFile, decl, scanner2)) { - groupIndex++; - } - if (!group2[groupIndex]) { - group2[groupIndex] = []; - } - group2[groupIndex].push(decl); - } - return group2; + function isSemicolonInsertionContext(context) { + return positionIsASICandidate(context.currentTokenSpan.end, context.currentTokenParent, context.sourceFile); } - function isNewGroup(sourceFile, decl, scanner2) { - const startPos = decl.getFullStart(); - const endPos = decl.getStart(); - scanner2.setText(sourceFile.text, startPos, endPos - startPos); - let numberOfNewLines = 0; - while (scanner2.getTokenStart() < endPos) { - const tokenKind = scanner2.scan(); - if (tokenKind === 4 /* NewLineTrivia */) { - numberOfNewLines++; - if (numberOfNewLines >= 2) { - return true; - } - } - } - return false; + function isNotPropertyAccessOnIntegerLiteral(context) { + return !isPropertyAccessExpression(context.contextNode) || !isNumericLiteral(context.contextNode.expression) || context.contextNode.expression.getText().includes("."); } - function removeUnusedImports(oldImports, sourceFile, program) { - const typeChecker = program.getTypeChecker(); - const compilerOptions = program.getCompilerOptions(); - const jsxNamespace = typeChecker.getJsxNamespace(sourceFile); - const jsxFragmentFactory = typeChecker.getJsxFragmentFactory(sourceFile); - const jsxElementsPresent = !!(sourceFile.transformFlags & 2 /* ContainsJsx */); - const usedImports = []; - for (const importDecl of oldImports) { - const { importClause, moduleSpecifier } = importDecl; - if (!importClause) { - usedImports.push(importDecl); - continue; - } - let { name, namedBindings } = importClause; - if (name && !isDeclarationUsed(name)) { - name = void 0; - } - if (namedBindings) { - if (isNamespaceImport(namedBindings)) { - if (!isDeclarationUsed(namedBindings.name)) { - namedBindings = void 0; - } - } else { - const newElements = namedBindings.elements.filter((e) => isDeclarationUsed(e.name)); - if (newElements.length < namedBindings.elements.length) { - namedBindings = newElements.length ? factory.updateNamedImports(namedBindings, newElements) : void 0; - } - } - } - if (name || namedBindings) { - usedImports.push(updateImportDeclarationAndClause(importDecl, name, namedBindings)); - } else if (hasModuleDeclarationMatchingSpecifier(sourceFile, moduleSpecifier)) { - if (sourceFile.isDeclarationFile) { - usedImports.push(factory.createImportDeclaration( - importDecl.modifiers, - /*importClause*/ - void 0, - moduleSpecifier, - /*assertClause*/ - void 0 - )); - } else { - usedImports.push(importDecl); - } - } - } - return usedImports; - function isDeclarationUsed(identifier) { - return jsxElementsPresent && (identifier.text === jsxNamespace || jsxFragmentFactory && identifier.text === jsxFragmentFactory) && jsxModeNeedsExplicitImport(compilerOptions.jsx) || ts_FindAllReferences_exports.Core.isSymbolReferencedInFile(identifier, typeChecker, sourceFile); + var init_rules = __esm({ + "src/services/formatting/rules.ts"() { + "use strict"; + init_ts4(); + init_ts_formatting(); } + }); + + // src/services/formatting/rulesMap.ts + function getFormatContext(options, host) { + return { options, getRules: getRulesMap(), host }; } - function hasModuleDeclarationMatchingSpecifier(sourceFile, moduleSpecifier) { - const moduleSpecifierText = isStringLiteral(moduleSpecifier) && moduleSpecifier.text; - return isString(moduleSpecifierText) && some(sourceFile.moduleAugmentations, (moduleName) => isStringLiteral(moduleName) && moduleName.text === moduleSpecifierText); - } - function getExternalModuleName2(specifier) { - return specifier !== void 0 && isStringLiteralLike(specifier) ? specifier.text : void 0; - } - function coalesceImports(importGroup, ignoreCase, sourceFile) { - const comparer = getOrganizeImportsOrdinalStringComparer(ignoreCase); - return coalesceImportsWorker(importGroup, comparer, sourceFile); + function getRulesMap() { + if (rulesMapCache === void 0) { + rulesMapCache = createRulesMap(getAllRules()); + } + return rulesMapCache; } - function coalesceImportsWorker(importGroup, comparer, sourceFile) { - if (importGroup.length === 0) { - return importGroup; + function getRuleActionExclusion(ruleAction) { + let mask2 = 0 /* None */; + if (ruleAction & 1 /* StopProcessingSpaceActions */) { + mask2 |= 28 /* ModifySpaceAction */; } - const { importWithoutClause, typeOnlyImports, regularImports } = getCategorizedImports(importGroup); - const coalescedImports = []; - if (importWithoutClause) { - coalescedImports.push(importWithoutClause); + if (ruleAction & 2 /* StopProcessingTokenActions */) { + mask2 |= 96 /* ModifyTokenAction */; } - for (const group2 of [regularImports, typeOnlyImports]) { - const isTypeOnly = group2 === typeOnlyImports; - const { defaultImports, namespaceImports, namedImports } = group2; - if (!isTypeOnly && defaultImports.length === 1 && namespaceImports.length === 1 && namedImports.length === 0) { - const defaultImport = defaultImports[0]; - coalescedImports.push( - updateImportDeclarationAndClause(defaultImport, defaultImport.importClause.name, namespaceImports[0].importClause.namedBindings) - ); - continue; - } - const sortedNamespaceImports = stableSort(namespaceImports, (i1, i2) => comparer(i1.importClause.namedBindings.name.text, i2.importClause.namedBindings.name.text)); - for (const namespaceImport of sortedNamespaceImports) { - coalescedImports.push( - updateImportDeclarationAndClause( - namespaceImport, - /*name*/ - void 0, - namespaceImport.importClause.namedBindings - ) - ); - } - const firstDefaultImport = firstOrUndefined(defaultImports); - const firstNamedImport = firstOrUndefined(namedImports); - const importDecl = firstDefaultImport ?? firstNamedImport; - if (!importDecl) { - continue; - } - let newDefaultImport; - const newImportSpecifiers = []; - if (defaultImports.length === 1) { - newDefaultImport = defaultImports[0].importClause.name; - } else { - for (const defaultImport of defaultImports) { - newImportSpecifiers.push( - factory.createImportSpecifier( - /*isTypeOnly*/ - false, - factory.createIdentifier("default"), - defaultImport.importClause.name - ) - ); - } - } - newImportSpecifiers.push(...getNewImportSpecifiers(namedImports)); - const sortedImportSpecifiers = factory.createNodeArray( - sortSpecifiers(newImportSpecifiers, comparer), - firstNamedImport == null ? void 0 : firstNamedImport.importClause.namedBindings.elements.hasTrailingComma - ); - const newNamedImports = sortedImportSpecifiers.length === 0 ? newDefaultImport ? void 0 : factory.createNamedImports(emptyArray) : firstNamedImport ? factory.updateNamedImports(firstNamedImport.importClause.namedBindings, sortedImportSpecifiers) : factory.createNamedImports(sortedImportSpecifiers); - if (sourceFile && newNamedImports && (firstNamedImport == null ? void 0 : firstNamedImport.importClause.namedBindings) && !rangeIsOnSingleLine(firstNamedImport.importClause.namedBindings, sourceFile)) { - setEmitFlags(newNamedImports, 2 /* MultiLine */); - } - if (isTypeOnly && newDefaultImport && newNamedImports) { - coalescedImports.push( - updateImportDeclarationAndClause( - importDecl, - newDefaultImport, - /*namedBindings*/ - void 0 - ) - ); - coalescedImports.push( - updateImportDeclarationAndClause( - firstNamedImport ?? importDecl, - /*name*/ - void 0, - newNamedImports - ) - ); - } else { - coalescedImports.push( - updateImportDeclarationAndClause(importDecl, newDefaultImport, newNamedImports) - ); - } + if (ruleAction & 28 /* ModifySpaceAction */) { + mask2 |= 28 /* ModifySpaceAction */; } - return coalescedImports; + if (ruleAction & 96 /* ModifyTokenAction */) { + mask2 |= 96 /* ModifyTokenAction */; + } + return mask2; } - function getCategorizedImports(importGroup) { - let importWithoutClause; - const typeOnlyImports = { defaultImports: [], namespaceImports: [], namedImports: [] }; - const regularImports = { defaultImports: [], namespaceImports: [], namedImports: [] }; - for (const importDeclaration of importGroup) { - if (importDeclaration.importClause === void 0) { - importWithoutClause = importWithoutClause || importDeclaration; - continue; - } - const group2 = importDeclaration.importClause.isTypeOnly ? typeOnlyImports : regularImports; - const { name, namedBindings } = importDeclaration.importClause; - if (name) { - group2.defaultImports.push(importDeclaration); - } - if (namedBindings) { - if (isNamespaceImport(namedBindings)) { - group2.namespaceImports.push(importDeclaration); - } else { - group2.namedImports.push(importDeclaration); + function createRulesMap(rules) { + const map2 = buildMap(rules); + return (context) => { + const bucket = map2[getRuleBucketIndex(context.currentTokenSpan.kind, context.nextTokenSpan.kind)]; + if (bucket) { + const rules2 = []; + let ruleActionMask = 0; + for (const rule2 of bucket) { + const acceptRuleActions = ~getRuleActionExclusion(ruleActionMask); + if (rule2.action & acceptRuleActions && every(rule2.context, (c) => c(context))) { + rules2.push(rule2); + ruleActionMask |= rule2.action; + } + } + if (rules2.length) { + return rules2; } } - } - return { - importWithoutClause, - typeOnlyImports, - regularImports }; } - function coalesceExports(exportGroup, ignoreCase) { - const comparer = getOrganizeImportsOrdinalStringComparer(ignoreCase); - return coalesceExportsWorker(exportGroup, comparer); + function buildMap(rules) { + const map2 = new Array(mapRowLength * mapRowLength); + const rulesBucketConstructionStateList = new Array(map2.length); + for (const rule2 of rules) { + const specificRule = rule2.leftTokenRange.isSpecific && rule2.rightTokenRange.isSpecific; + for (const left of rule2.leftTokenRange.tokens) { + for (const right of rule2.rightTokenRange.tokens) { + const index = getRuleBucketIndex(left, right); + let rulesBucket = map2[index]; + if (rulesBucket === void 0) { + rulesBucket = map2[index] = []; + } + addRule(rulesBucket, rule2.rule, specificRule, rulesBucketConstructionStateList, index); + } + } + } + return map2; } - function coalesceExportsWorker(exportGroup, comparer) { - if (exportGroup.length === 0) { - return exportGroup; + function getRuleBucketIndex(row, column) { + Debug.assert(row <= 165 /* LastKeyword */ && column <= 165 /* LastKeyword */, "Must compute formatting context from tokens"); + return row * mapRowLength + column; + } + function addRule(rules, rule2, specificTokens, constructionState, rulesBucketIndex) { + const position = rule2.action & 3 /* StopAction */ ? specificTokens ? 0 /* StopRulesSpecific */ : RulesPosition.StopRulesAny : rule2.context !== anyContext ? specificTokens ? RulesPosition.ContextRulesSpecific : RulesPosition.ContextRulesAny : specificTokens ? RulesPosition.NoContextRulesSpecific : RulesPosition.NoContextRulesAny; + const state = constructionState[rulesBucketIndex] || 0; + rules.splice(getInsertionIndex(state, position), 0, rule2); + constructionState[rulesBucketIndex] = increaseInsertionIndex(state, position); + } + function getInsertionIndex(indexBitmap, maskPosition) { + let index = 0; + for (let pos = 0; pos <= maskPosition; pos += maskBitSize) { + index += indexBitmap & mask; + indexBitmap >>= maskBitSize; } - const { exportWithoutClause, namedExports, typeOnlyExports } = getCategorizedExports(exportGroup); - const coalescedExports = []; - if (exportWithoutClause) { - coalescedExports.push(exportWithoutClause); + return index; + } + function increaseInsertionIndex(indexBitmap, maskPosition) { + const value = (indexBitmap >> maskPosition & mask) + 1; + Debug.assert((value & mask) === value, "Adding more rules into the sub-bucket than allowed. Maximum allowed is 32 rules."); + return indexBitmap & ~(mask << maskPosition) | value << maskPosition; + } + var rulesMapCache, maskBitSize, mask, mapRowLength, RulesPosition; + var init_rulesMap = __esm({ + "src/services/formatting/rulesMap.ts"() { + "use strict"; + init_ts4(); + init_ts_formatting(); + maskBitSize = 5; + mask = 31; + mapRowLength = 165 /* LastToken */ + 1; + RulesPosition = ((RulesPosition2) => { + RulesPosition2[RulesPosition2["StopRulesSpecific"] = 0] = "StopRulesSpecific"; + RulesPosition2[RulesPosition2["StopRulesAny"] = maskBitSize * 1] = "StopRulesAny"; + RulesPosition2[RulesPosition2["ContextRulesSpecific"] = maskBitSize * 2] = "ContextRulesSpecific"; + RulesPosition2[RulesPosition2["ContextRulesAny"] = maskBitSize * 3] = "ContextRulesAny"; + RulesPosition2[RulesPosition2["NoContextRulesSpecific"] = maskBitSize * 4] = "NoContextRulesSpecific"; + RulesPosition2[RulesPosition2["NoContextRulesAny"] = maskBitSize * 5] = "NoContextRulesAny"; + return RulesPosition2; + })(RulesPosition || {}); } - for (const exportGroup2 of [namedExports, typeOnlyExports]) { - if (exportGroup2.length === 0) { - continue; - } - const newExportSpecifiers = []; - newExportSpecifiers.push(...flatMap(exportGroup2, (i) => i.exportClause && isNamedExports(i.exportClause) ? i.exportClause.elements : emptyArray)); - const sortedExportSpecifiers = sortSpecifiers(newExportSpecifiers, comparer); - const exportDecl = exportGroup2[0]; - coalescedExports.push( - factory.updateExportDeclaration( - exportDecl, - exportDecl.modifiers, - exportDecl.isTypeOnly, - exportDecl.exportClause && (isNamedExports(exportDecl.exportClause) ? factory.updateNamedExports(exportDecl.exportClause, sortedExportSpecifiers) : factory.updateNamespaceExport(exportDecl.exportClause, exportDecl.exportClause.name)), - exportDecl.moduleSpecifier, - exportDecl.assertClause - ) - ); + }); + + // src/services/formatting/formatting.ts + function createTextRangeWithKind(pos, end, kind) { + const textRangeWithKind = { pos, end, kind }; + if (Debug.isDebugging) { + Object.defineProperty(textRangeWithKind, "__debugKind", { + get: () => Debug.formatSyntaxKind(kind) + }); } - return coalescedExports; - function getCategorizedExports(exportGroup2) { - let exportWithoutClause2; - const namedExports2 = []; - const typeOnlyExports2 = []; - for (const exportDeclaration of exportGroup2) { - if (exportDeclaration.exportClause === void 0) { - exportWithoutClause2 = exportWithoutClause2 || exportDeclaration; - } else if (exportDeclaration.isTypeOnly) { - typeOnlyExports2.push(exportDeclaration); - } else { - namedExports2.push(exportDeclaration); - } - } - return { - exportWithoutClause: exportWithoutClause2, - namedExports: namedExports2, - typeOnlyExports: typeOnlyExports2 - }; + return textRangeWithKind; + } + function formatOnEnter(position, sourceFile, formatContext) { + const line = sourceFile.getLineAndCharacterOfPosition(position).line; + if (line === 0) { + return []; + } + let endOfFormatSpan = getEndLinePosition(line, sourceFile); + while (isWhiteSpaceSingleLine(sourceFile.text.charCodeAt(endOfFormatSpan))) { + endOfFormatSpan--; + } + if (isLineBreak(sourceFile.text.charCodeAt(endOfFormatSpan))) { + endOfFormatSpan--; } + const span = { + // get start position for the previous line + pos: getStartPositionOfLine(line - 1, sourceFile), + // end value is exclusive so add 1 to the result + end: endOfFormatSpan + 1 + }; + return formatSpan(span, sourceFile, formatContext, 2 /* FormatOnEnter */); } - function updateImportDeclarationAndClause(importDeclaration, name, namedBindings) { - return factory.updateImportDeclaration( - importDeclaration, - importDeclaration.modifiers, - factory.updateImportClause(importDeclaration.importClause, importDeclaration.importClause.isTypeOnly, name, namedBindings), + function formatOnSemicolon(position, sourceFile, formatContext) { + const semicolon = findImmediatelyPrecedingTokenOfKind(position, 27 /* SemicolonToken */, sourceFile); + return formatNodeLines(findOutermostNodeWithinListLevel(semicolon), sourceFile, formatContext, 3 /* FormatOnSemicolon */); + } + function formatOnOpeningCurly(position, sourceFile, formatContext) { + const openingCurly = findImmediatelyPrecedingTokenOfKind(position, 19 /* OpenBraceToken */, sourceFile); + if (!openingCurly) { + return []; + } + const curlyBraceRange = openingCurly.parent; + const outermostNode = findOutermostNodeWithinListLevel(curlyBraceRange); + const textRange = { + pos: getLineStartPositionForPosition(outermostNode.getStart(sourceFile), sourceFile), // TODO: GH#18217 - importDeclaration.moduleSpecifier, - importDeclaration.assertClause - ); + end: position + }; + return formatSpan(textRange, sourceFile, formatContext, 4 /* FormatOnOpeningCurlyBrace */); } - function sortSpecifiers(specifiers, comparer) { - return stableSort(specifiers, (s1, s2) => compareImportOrExportSpecifiers(s1, s2, comparer)); + function formatOnClosingCurly(position, sourceFile, formatContext) { + const precedingToken = findImmediatelyPrecedingTokenOfKind(position, 20 /* CloseBraceToken */, sourceFile); + return formatNodeLines(findOutermostNodeWithinListLevel(precedingToken), sourceFile, formatContext, 5 /* FormatOnClosingCurlyBrace */); } - function compareImportOrExportSpecifiers(s1, s2, comparer) { - return compareBooleans(s1.isTypeOnly, s2.isTypeOnly) || comparer(s1.name.text, s2.name.text); + function formatDocument(sourceFile, formatContext) { + const span = { + pos: 0, + end: sourceFile.text.length + }; + return formatSpan(span, sourceFile, formatContext, 0 /* FormatDocument */); } - function compareModuleSpecifiers2(m1, m2, ignoreCase) { - const comparer = getOrganizeImportsOrdinalStringComparer(!!ignoreCase); - return compareModuleSpecifiersWorker(m1, m2, comparer); + function formatSelection(start, end, sourceFile, formatContext) { + const span = { + pos: getLineStartPositionForPosition(start, sourceFile), + end + }; + return formatSpan(span, sourceFile, formatContext, 1 /* FormatSelection */); } - function compareModuleSpecifiersWorker(m1, m2, comparer) { - const name1 = m1 === void 0 ? void 0 : getExternalModuleName2(m1); - const name2 = m2 === void 0 ? void 0 : getExternalModuleName2(m2); - return compareBooleans(name1 === void 0, name2 === void 0) || compareBooleans(isExternalModuleNameRelative(name1), isExternalModuleNameRelative(name2)) || comparer(name1, name2); + function findImmediatelyPrecedingTokenOfKind(end, expectedTokenKind, sourceFile) { + const precedingToken = findPrecedingToken(end, sourceFile); + return precedingToken && precedingToken.kind === expectedTokenKind && end === precedingToken.getEnd() ? precedingToken : void 0; } - function getModuleSpecifierExpression(declaration) { - var _a; - switch (declaration.kind) { - case 270 /* ImportEqualsDeclaration */: - return (_a = tryCast(declaration.moduleReference, isExternalModuleReference)) == null ? void 0 : _a.expression; - case 271 /* ImportDeclaration */: - return declaration.moduleSpecifier; - case 242 /* VariableStatement */: - return declaration.declarationList.declarations[0].initializer.arguments[0]; + function findOutermostNodeWithinListLevel(node) { + let current = node; + while (current && current.parent && current.parent.end === node.end && !isListElement(current.parent, current)) { + current = current.parent; } + return current; } - function detectSorting(sourceFile, preferences) { - return detectSortingWorker( - groupByNewlineContiguous(sourceFile, sourceFile.statements.filter(isImportDeclaration)), - preferences - ); + function isListElement(parent2, node) { + switch (parent2.kind) { + case 263 /* ClassDeclaration */: + case 264 /* InterfaceDeclaration */: + return rangeContainsRange(parent2.members, node); + case 267 /* ModuleDeclaration */: + const body = parent2.body; + return !!body && body.kind === 268 /* ModuleBlock */ && rangeContainsRange(body.statements, node); + case 312 /* SourceFile */: + case 241 /* Block */: + case 268 /* ModuleBlock */: + return rangeContainsRange(parent2.statements, node); + case 299 /* CatchClause */: + return rangeContainsRange(parent2.block.statements, node); + } + return false; } - function detectSortingWorker(importGroups, preferences) { - const collateCaseSensitive = getOrganizeImportsComparer( - preferences, - /*ignoreCase*/ - false - ); - const collateCaseInsensitive = getOrganizeImportsComparer( - preferences, - /*ignoreCase*/ - true - ); - let sortState = 3 /* Both */; - let seenUnsortedGroup = false; - for (const importGroup of importGroups) { - if (importGroup.length > 1) { - const moduleSpecifierSort = detectSortCaseSensitivity( - importGroup, - (i) => { - var _a; - return ((_a = tryCast(i.moduleSpecifier, isStringLiteral)) == null ? void 0 : _a.text) ?? ""; - }, - collateCaseSensitive, - collateCaseInsensitive - ); - if (moduleSpecifierSort) { - sortState &= moduleSpecifierSort; - seenUnsortedGroup = true; - } - if (!sortState) { - return sortState; + function findEnclosingNode(range, sourceFile) { + return find2(sourceFile); + function find2(n) { + const candidate = forEachChild(n, (c) => startEndContainsRange(c.getStart(sourceFile), c.end, range) && c); + if (candidate) { + const result = find2(candidate); + if (result) { + return result; } } - const declarationWithNamedImports = find( - importGroup, - (i) => { - var _a, _b; - return ((_b = tryCast((_a = i.importClause) == null ? void 0 : _a.namedBindings, isNamedImports)) == null ? void 0 : _b.elements.length) > 1; + return n; + } + } + function prepareRangeContainsErrorFunction(errors, originalRange) { + if (!errors.length) { + return rangeHasNoErrors; + } + const sorted = errors.filter((d) => rangeOverlapsWithStartEnd(originalRange, d.start, d.start + d.length)).sort((e1, e2) => e1.start - e2.start); + if (!sorted.length) { + return rangeHasNoErrors; + } + let index = 0; + return (r) => { + while (true) { + if (index >= sorted.length) { + return false; } - ); - if (declarationWithNamedImports) { - const namedImportSort = detectImportSpecifierSorting(declarationWithNamedImports.importClause.namedBindings.elements, preferences); - if (namedImportSort) { - sortState &= namedImportSort; - seenUnsortedGroup = true; + const error2 = sorted[index]; + if (r.end <= error2.start) { + return false; } - if (!sortState) { - return sortState; + if (startEndOverlapsWithStartEnd(r.pos, r.end, error2.start, error2.start + error2.length)) { + return true; } + index++; } - if (sortState !== 3 /* Both */) { - return sortState; - } + }; + function rangeHasNoErrors() { + return false; } - return seenUnsortedGroup ? 0 /* None */ : sortState; - } - function detectImportDeclarationSorting(imports, preferences) { - const collateCaseSensitive = getOrganizeImportsComparer( - preferences, - /*ignoreCase*/ - false - ); - const collateCaseInsensitive = getOrganizeImportsComparer( - preferences, - /*ignoreCase*/ - true - ); - return detectSortCaseSensitivity( - imports, - (s) => getExternalModuleName2(getModuleSpecifierExpression(s)) || "", - collateCaseSensitive, - collateCaseInsensitive - ); - } - function getImportDeclarationInsertionIndex(sortedImports, newImport, comparer) { - const index = binarySearch(sortedImports, newImport, identity, (a, b) => compareImportsOrRequireStatements(a, b, comparer)); - return index < 0 ? ~index : index; } - function getImportSpecifierInsertionIndex(sortedImports, newImport, comparer) { - const index = binarySearch(sortedImports, newImport, identity, (s1, s2) => compareImportOrExportSpecifiers(s1, s2, comparer)); - return index < 0 ? ~index : index; + function getScanStartPosition(enclosingNode, originalRange, sourceFile) { + const start = enclosingNode.getStart(sourceFile); + if (start === originalRange.pos && enclosingNode.end === originalRange.end) { + return start; + } + const precedingToken = findPrecedingToken(originalRange.pos, sourceFile); + if (!precedingToken) { + return enclosingNode.pos; + } + if (precedingToken.end >= originalRange.pos) { + return enclosingNode.pos; + } + return precedingToken.end; } - function compareImportsOrRequireStatements(s1, s2, comparer) { - return compareModuleSpecifiersWorker(getModuleSpecifierExpression(s1), getModuleSpecifierExpression(s2), comparer) || compareImportKind(s1, s2); + function getOwnOrInheritedDelta(n, options, sourceFile) { + let previousLine = -1 /* Unknown */; + let child; + while (n) { + const line = sourceFile.getLineAndCharacterOfPosition(n.getStart(sourceFile)).line; + if (previousLine !== -1 /* Unknown */ && line !== previousLine) { + break; + } + if (SmartIndenter.shouldIndentChildNode(options, n, child, sourceFile)) { + return options.indentSize; + } + previousLine = line; + child = n; + n = n.parent; + } + return 0; } - function compareImportKind(s1, s2) { - return compareValues(getImportKindOrder(s1), getImportKindOrder(s2)); + function formatNodeGivenIndentation(node, sourceFileLike, languageVariant, initialIndentation, delta, formatContext) { + const range = { pos: node.pos, end: node.end }; + return getFormattingScanner(sourceFileLike.text, languageVariant, range.pos, range.end, (scanner2) => formatSpanWorker( + range, + node, + initialIndentation, + delta, + scanner2, + formatContext, + 1 /* FormatSelection */, + (_) => false, + // assume that node does not have any errors + sourceFileLike + )); } - function getImportKindOrder(s1) { - var _a; - switch (s1.kind) { - case 271 /* ImportDeclaration */: - if (!s1.importClause) - return 0; - if (s1.importClause.isTypeOnly) - return 1; - if (((_a = s1.importClause.namedBindings) == null ? void 0 : _a.kind) === 273 /* NamespaceImport */) - return 2; - if (s1.importClause.name) - return 3; - return 4; - case 270 /* ImportEqualsDeclaration */: - return 5; - case 242 /* VariableStatement */: - return 6; + function formatNodeLines(node, sourceFile, formatContext, requestKind) { + if (!node) { + return []; } + const span = { + pos: getLineStartPositionForPosition(node.getStart(sourceFile), sourceFile), + end: node.end + }; + return formatSpan(span, sourceFile, formatContext, requestKind); } - function getNewImportSpecifiers(namedImports) { - return flatMap( - namedImports, - (namedImport) => map( - tryGetNamedBindingElements(namedImport), - (importSpecifier) => importSpecifier.name && importSpecifier.propertyName && importSpecifier.name.escapedText === importSpecifier.propertyName.escapedText ? factory.updateImportSpecifier( - importSpecifier, - importSpecifier.isTypeOnly, - /*propertyName*/ - void 0, - importSpecifier.name - ) : importSpecifier + function formatSpan(originalRange, sourceFile, formatContext, requestKind) { + const enclosingNode = findEnclosingNode(originalRange, sourceFile); + return getFormattingScanner( + sourceFile.text, + sourceFile.languageVariant, + getScanStartPosition(enclosingNode, originalRange, sourceFile), + originalRange.end, + (scanner2) => formatSpanWorker( + originalRange, + enclosingNode, + SmartIndenter.getIndentationForNode(enclosingNode, originalRange, sourceFile, formatContext.options), + getOwnOrInheritedDelta(enclosingNode, formatContext.options, sourceFile), + scanner2, + formatContext, + requestKind, + prepareRangeContainsErrorFunction(sourceFile.parseDiagnostics, originalRange), + sourceFile ) ); } - function tryGetNamedBindingElements(namedImport) { + function formatSpanWorker(originalRange, enclosingNode, initialIndentation, delta, formattingScanner, { options, getRules, host }, requestKind, rangeContainsError, sourceFile) { var _a; - return ((_a = namedImport.importClause) == null ? void 0 : _a.namedBindings) && isNamedImports(namedImport.importClause.namedBindings) ? namedImport.importClause.namedBindings.elements : void 0; - } - function getOrganizeImportsOrdinalStringComparer(ignoreCase) { - return ignoreCase ? compareStringsCaseInsensitiveEslintCompatible : compareStringsCaseSensitive; - } - function getOrganizeImportsUnicodeStringComparer(ignoreCase, preferences) { - const resolvedLocale = getOrganizeImportsLocale(preferences); - const caseFirst = preferences.organizeImportsCaseFirst ?? false; - const numeric = preferences.organizeImportsNumericCollation ?? false; - const accents = preferences.organizeImportsAccentCollation ?? true; - const sensitivity = ignoreCase ? accents ? "accent" : "base" : accents ? "variant" : "case"; - const collator = new Intl.Collator(resolvedLocale, { - usage: "sort", - caseFirst: caseFirst || "false", - sensitivity, - numeric - }); - return collator.compare; - } - function getOrganizeImportsLocale(preferences) { - let locale = preferences.organizeImportsLocale; - if (locale === "auto") - locale = getUILocale(); - if (locale === void 0) - locale = "en"; - const supportedLocales = Intl.Collator.supportedLocalesOf(locale); - const resolvedLocale = supportedLocales.length ? supportedLocales[0] : "en"; - return resolvedLocale; - } - function getOrganizeImportsComparer(preferences, ignoreCase) { - const collation = preferences.organizeImportsCollation ?? "ordinal"; - return collation === "unicode" ? getOrganizeImportsUnicodeStringComparer(ignoreCase, preferences) : getOrganizeImportsOrdinalStringComparer(ignoreCase); - } - function getOrganizeImportsComparerWithDetection(preferences, detectIgnoreCase) { - const ignoreCase = typeof preferences.organizeImportsIgnoreCase === "boolean" ? preferences.organizeImportsIgnoreCase : (detectIgnoreCase == null ? void 0 : detectIgnoreCase()) ?? false; - return getOrganizeImportsComparer(preferences, ignoreCase); - } - function getTopLevelExportGroups(sourceFile) { - const topLevelExportGroups = []; - const statements = sourceFile.statements; - const len = length(statements); - let i = 0; - let groupIndex = 0; - while (i < len) { - if (isExportDeclaration(statements[i])) { - if (topLevelExportGroups[groupIndex] === void 0) { - topLevelExportGroups[groupIndex] = []; + const formattingContext = new FormattingContext(sourceFile, requestKind, options); + let previousRangeTriviaEnd; + let previousRange; + let previousParent; + let previousRangeStartLine; + let lastIndentedLine; + let indentationOnLastIndentedLine = -1 /* Unknown */; + const edits = []; + formattingScanner.advance(); + if (formattingScanner.isOnToken()) { + const startLine = sourceFile.getLineAndCharacterOfPosition(enclosingNode.getStart(sourceFile)).line; + let undecoratedStartLine = startLine; + if (hasDecorators(enclosingNode)) { + undecoratedStartLine = sourceFile.getLineAndCharacterOfPosition(getNonDecoratorTokenPosOfNode(enclosingNode, sourceFile)).line; + } + processNode(enclosingNode, enclosingNode, startLine, undecoratedStartLine, initialIndentation, delta); + } + const remainingTrivia = formattingScanner.getCurrentLeadingTrivia(); + if (remainingTrivia) { + const indentation = SmartIndenter.nodeWillIndentChild( + options, + enclosingNode, + /*child*/ + void 0, + sourceFile, + /*indentByDefault*/ + false + ) ? initialIndentation + options.indentSize : initialIndentation; + indentTriviaItems( + remainingTrivia, + indentation, + /*indentNextTokenOrTrivia*/ + true, + (item) => { + processRange( + item, + sourceFile.getLineAndCharacterOfPosition(item.pos), + enclosingNode, + enclosingNode, + /*dynamicIndentation*/ + void 0 + ); + insertIndentation( + item.pos, + indentation, + /*lineAdded*/ + false + ); } - const exportDecl = statements[i]; - if (exportDecl.moduleSpecifier) { - topLevelExportGroups[groupIndex].push(exportDecl); - i++; + ); + if (options.trimTrailingWhitespace !== false) { + trimTrailingWhitespacesForRemainingRange(remainingTrivia); + } + } + if (previousRange && formattingScanner.getTokenFullStart() >= originalRange.end) { + const tokenInfo = formattingScanner.isOnEOF() ? formattingScanner.readEOFTokenRange() : formattingScanner.isOnToken() ? formattingScanner.readTokenInfo(enclosingNode).token : void 0; + if (tokenInfo && tokenInfo.pos === previousRangeTriviaEnd) { + const parent2 = ((_a = findPrecedingToken(tokenInfo.end, sourceFile, enclosingNode)) == null ? void 0 : _a.parent) || previousParent; + processPair( + tokenInfo, + sourceFile.getLineAndCharacterOfPosition(tokenInfo.pos).line, + parent2, + previousRange, + previousRangeStartLine, + previousParent, + parent2, + /*dynamicIndentation*/ + void 0 + ); + } + } + return edits; + function tryComputeIndentationForListItem(startPos, endPos, parentStartLine, range, inheritedIndentation) { + if (rangeOverlapsWithStartEnd(range, startPos, endPos) || rangeContainsStartEnd(range, startPos, endPos)) { + if (inheritedIndentation !== -1 /* Unknown */) { + return inheritedIndentation; + } + } else { + const startLine = sourceFile.getLineAndCharacterOfPosition(startPos).line; + const startLinePosition = getLineStartPositionForPosition(startPos, sourceFile); + const column = SmartIndenter.findFirstNonWhitespaceColumn(startLinePosition, startPos, sourceFile, options); + if (startLine !== parentStartLine || startPos === column) { + const baseIndentSize = SmartIndenter.getBaseIndentation(options); + return baseIndentSize > column ? baseIndentSize : column; + } + } + return -1 /* Unknown */; + } + function computeIndentation(node, startLine, inheritedIndentation, parent2, parentDynamicIndentation, effectiveParentStartLine) { + const delta2 = SmartIndenter.shouldIndentChildNode(options, node) ? options.indentSize : 0; + if (effectiveParentStartLine === startLine) { + return { + indentation: startLine === lastIndentedLine ? indentationOnLastIndentedLine : parentDynamicIndentation.getIndentation(), + delta: Math.min(options.indentSize, parentDynamicIndentation.getDelta(node) + delta2) + }; + } else if (inheritedIndentation === -1 /* Unknown */) { + if (node.kind === 21 /* OpenParenToken */ && startLine === lastIndentedLine) { + return { indentation: indentationOnLastIndentedLine, delta: parentDynamicIndentation.getDelta(node) }; + } else if (SmartIndenter.childStartsOnTheSameLineWithElseInIfStatement(parent2, node, startLine, sourceFile) || SmartIndenter.childIsUnindentedBranchOfConditionalExpression(parent2, node, startLine, sourceFile) || SmartIndenter.argumentStartsOnSameLineAsPreviousArgument(parent2, node, startLine, sourceFile)) { + return { indentation: parentDynamicIndentation.getIndentation(), delta: delta2 }; } else { - while (i < len && isExportDeclaration(statements[i])) { - topLevelExportGroups[groupIndex].push(statements[i++]); - } - groupIndex++; + return { indentation: parentDynamicIndentation.getIndentation() + parentDynamicIndentation.getDelta(node), delta: delta2 }; } } else { - i++; + return { indentation: inheritedIndentation, delta: delta2 }; } } - return flatMap(topLevelExportGroups, (exportGroupDecls) => groupByNewlineContiguous(sourceFile, exportGroupDecls)); - } - var ImportSpecifierSortingCache, detectImportSpecifierSorting; - var init_organizeImports = __esm({ - "src/services/organizeImports.ts"() { - "use strict"; - init_ts4(); - ImportSpecifierSortingCache = class { - has([specifiers, preferences]) { - if (this._lastPreferences !== preferences || !this._cache) + function getFirstNonDecoratorTokenOfNode(node) { + if (canHaveModifiers(node)) { + const modifier = find(node.modifiers, isModifier, findIndex(node.modifiers, isDecorator)); + if (modifier) + return modifier.kind; + } + switch (node.kind) { + case 263 /* ClassDeclaration */: + return 86 /* ClassKeyword */; + case 264 /* InterfaceDeclaration */: + return 120 /* InterfaceKeyword */; + case 262 /* FunctionDeclaration */: + return 100 /* FunctionKeyword */; + case 266 /* EnumDeclaration */: + return 266 /* EnumDeclaration */; + case 177 /* GetAccessor */: + return 139 /* GetKeyword */; + case 178 /* SetAccessor */: + return 153 /* SetKeyword */; + case 174 /* MethodDeclaration */: + if (node.asteriskToken) { + return 42 /* AsteriskToken */; + } + case 172 /* PropertyDeclaration */: + case 169 /* Parameter */: + const name = getNameOfDeclaration(node); + if (name) { + return name.kind; + } + } + } + function getDynamicIndentation(node, nodeStartLine, indentation, delta2) { + return { + getIndentationForComment: (kind, tokenIndentation, container) => { + switch (kind) { + case 20 /* CloseBraceToken */: + case 24 /* CloseBracketToken */: + case 22 /* CloseParenToken */: + return indentation + getDelta(container); + } + return tokenIndentation !== -1 /* Unknown */ ? tokenIndentation : indentation; + }, + // if list end token is LessThanToken '>' then its delta should be explicitly suppressed + // so that LessThanToken as a binary operator can still be indented. + // foo.then + // < + // number, + // string, + // >(); + // vs + // var a = xValue + // > yValue; + getIndentationForToken: (line, kind, container, suppressDelta) => !suppressDelta && shouldAddDelta(line, kind, container) ? indentation + getDelta(container) : indentation, + getIndentation: () => indentation, + getDelta, + recomputeIndentation: (lineAdded, parent2) => { + if (SmartIndenter.shouldIndentChildNode(options, parent2, node, sourceFile)) { + indentation += lineAdded ? options.indentSize : -options.indentSize; + delta2 = SmartIndenter.shouldIndentChildNode(options, node) ? options.indentSize : 0; + } + } + }; + function shouldAddDelta(line, kind, container) { + switch (kind) { + case 19 /* OpenBraceToken */: + case 20 /* CloseBraceToken */: + case 22 /* CloseParenToken */: + case 93 /* ElseKeyword */: + case 117 /* WhileKeyword */: + case 60 /* AtToken */: return false; - return this._cache.has(specifiers); + case 44 /* SlashToken */: + case 32 /* GreaterThanToken */: + switch (container.kind) { + case 286 /* JsxOpeningElement */: + case 287 /* JsxClosingElement */: + case 285 /* JsxSelfClosingElement */: + return false; + } + break; + case 23 /* OpenBracketToken */: + case 24 /* CloseBracketToken */: + if (container.kind !== 200 /* MappedType */) { + return false; + } + break; } - get([specifiers, preferences]) { - if (this._lastPreferences !== preferences || !this._cache) - return void 0; - return this._cache.get(specifiers); + return nodeStartLine !== line && !(hasDecorators(node) && kind === getFirstNonDecoratorTokenOfNode(node)); + } + function getDelta(child) { + return SmartIndenter.nodeWillIndentChild( + options, + node, + child, + sourceFile, + /*indentByDefault*/ + true + ) ? delta2 : 0; + } + } + function processNode(node, contextNode, nodeStartLine, undecoratedNodeStartLine, indentation, delta2) { + if (!rangeOverlapsWithStartEnd(originalRange, node.getStart(sourceFile), node.getEnd())) { + return; + } + const nodeDynamicIndentation = getDynamicIndentation(node, nodeStartLine, indentation, delta2); + let childContextNode = contextNode; + forEachChild( + node, + (child) => { + processChildNode( + child, + /*inheritedIndentation*/ + -1 /* Unknown */, + node, + nodeDynamicIndentation, + nodeStartLine, + undecoratedNodeStartLine, + /*isListItem*/ + false + ); + }, + (nodes) => { + processChildNodes(nodes, node, nodeStartLine, nodeDynamicIndentation); } - set([specifiers, preferences], value) { - if (this._lastPreferences !== preferences) { - this._lastPreferences = preferences; - this._cache = void 0; + ); + while (formattingScanner.isOnToken() && formattingScanner.getTokenFullStart() < originalRange.end) { + const tokenInfo = formattingScanner.readTokenInfo(node); + if (tokenInfo.token.end > Math.min(node.end, originalRange.end)) { + break; + } + consumeTokenAndAdvanceScanner(tokenInfo, node, nodeDynamicIndentation, node); + } + function processChildNode(child, inheritedIndentation, parent2, parentDynamicIndentation, parentStartLine, undecoratedParentStartLine, isListItem, isFirstListItem) { + Debug.assert(!nodeIsSynthesized(child)); + if (nodeIsMissing(child) || isGrammarError(parent2, child)) { + return inheritedIndentation; + } + const childStartPos = child.getStart(sourceFile); + const childStartLine = sourceFile.getLineAndCharacterOfPosition(childStartPos).line; + let undecoratedChildStartLine = childStartLine; + if (hasDecorators(child)) { + undecoratedChildStartLine = sourceFile.getLineAndCharacterOfPosition(getNonDecoratorTokenPosOfNode(child, sourceFile)).line; + } + let childIndentationAmount = -1 /* Unknown */; + if (isListItem && rangeContainsRange(originalRange, parent2)) { + childIndentationAmount = tryComputeIndentationForListItem(childStartPos, child.end, parentStartLine, originalRange, inheritedIndentation); + if (childIndentationAmount !== -1 /* Unknown */) { + inheritedIndentation = childIndentationAmount; } - this._cache ?? (this._cache = /* @__PURE__ */ new WeakMap()); - this._cache.set(specifiers, value); } - }; - detectImportSpecifierSorting = memoizeCached((specifiers, preferences) => { - if (!arrayIsSorted(specifiers, (s1, s2) => compareBooleans(s1.isTypeOnly, s2.isTypeOnly))) { - return 0 /* None */; + if (!rangeOverlapsWithStartEnd(originalRange, child.pos, child.end)) { + if (child.end < originalRange.pos) { + formattingScanner.skipToEndOf(child); + } + return inheritedIndentation; } - const collateCaseSensitive = getOrganizeImportsComparer( - preferences, - /*ignoreCase*/ - false - ); - const collateCaseInsensitive = getOrganizeImportsComparer( - preferences, - /*ignoreCase*/ - true - ); - return detectSortCaseSensitivity(specifiers, (specifier) => specifier.name.text, collateCaseSensitive, collateCaseInsensitive); - }, new ImportSpecifierSortingCache()); + if (child.getFullWidth() === 0) { + return inheritedIndentation; + } + while (formattingScanner.isOnToken() && formattingScanner.getTokenFullStart() < originalRange.end) { + const tokenInfo = formattingScanner.readTokenInfo(node); + if (tokenInfo.token.end > originalRange.end) { + return inheritedIndentation; + } + if (tokenInfo.token.end > childStartPos) { + if (tokenInfo.token.pos > childStartPos) { + formattingScanner.skipToStartOf(child); + } + break; + } + consumeTokenAndAdvanceScanner(tokenInfo, node, parentDynamicIndentation, node); + } + if (!formattingScanner.isOnToken() || formattingScanner.getTokenFullStart() >= originalRange.end) { + return inheritedIndentation; + } + if (isToken(child)) { + const tokenInfo = formattingScanner.readTokenInfo(child); + if (child.kind !== 12 /* JsxText */) { + Debug.assert(tokenInfo.token.end === child.end, "Token end is child end"); + consumeTokenAndAdvanceScanner(tokenInfo, node, parentDynamicIndentation, child); + return inheritedIndentation; + } + } + const effectiveParentStartLine = child.kind === 170 /* Decorator */ ? childStartLine : undecoratedParentStartLine; + const childIndentation = computeIndentation(child, childStartLine, childIndentationAmount, node, parentDynamicIndentation, effectiveParentStartLine); + processNode(child, childContextNode, childStartLine, undecoratedChildStartLine, childIndentation.indentation, childIndentation.delta); + childContextNode = node; + if (isFirstListItem && parent2.kind === 209 /* ArrayLiteralExpression */ && inheritedIndentation === -1 /* Unknown */) { + inheritedIndentation = childIndentation.indentation; + } + return inheritedIndentation; + } + function processChildNodes(nodes, parent2, parentStartLine, parentDynamicIndentation) { + Debug.assert(isNodeArray(nodes)); + Debug.assert(!nodeIsSynthesized(nodes)); + const listStartToken = getOpenTokenForList(parent2, nodes); + let listDynamicIndentation = parentDynamicIndentation; + let startLine = parentStartLine; + if (!rangeOverlapsWithStartEnd(originalRange, nodes.pos, nodes.end)) { + if (nodes.end < originalRange.pos) { + formattingScanner.skipToEndOf(nodes); + } + return; + } + if (listStartToken !== 0 /* Unknown */) { + while (formattingScanner.isOnToken() && formattingScanner.getTokenFullStart() < originalRange.end) { + const tokenInfo = formattingScanner.readTokenInfo(parent2); + if (tokenInfo.token.end > nodes.pos) { + break; + } else if (tokenInfo.token.kind === listStartToken) { + startLine = sourceFile.getLineAndCharacterOfPosition(tokenInfo.token.pos).line; + consumeTokenAndAdvanceScanner(tokenInfo, parent2, parentDynamicIndentation, parent2); + let indentationOnListStartToken; + if (indentationOnLastIndentedLine !== -1 /* Unknown */) { + indentationOnListStartToken = indentationOnLastIndentedLine; + } else { + const startLinePosition = getLineStartPositionForPosition(tokenInfo.token.pos, sourceFile); + indentationOnListStartToken = SmartIndenter.findFirstNonWhitespaceColumn(startLinePosition, tokenInfo.token.pos, sourceFile, options); + } + listDynamicIndentation = getDynamicIndentation(parent2, parentStartLine, indentationOnListStartToken, options.indentSize); + } else { + consumeTokenAndAdvanceScanner(tokenInfo, parent2, parentDynamicIndentation, parent2); + } + } + } + let inheritedIndentation = -1 /* Unknown */; + for (let i = 0; i < nodes.length; i++) { + const child = nodes[i]; + inheritedIndentation = processChildNode( + child, + inheritedIndentation, + node, + listDynamicIndentation, + startLine, + startLine, + /*isListItem*/ + true, + /*isFirstListItem*/ + i === 0 + ); + } + const listEndToken = getCloseTokenForOpenToken(listStartToken); + if (listEndToken !== 0 /* Unknown */ && formattingScanner.isOnToken() && formattingScanner.getTokenFullStart() < originalRange.end) { + let tokenInfo = formattingScanner.readTokenInfo(parent2); + if (tokenInfo.token.kind === 28 /* CommaToken */) { + consumeTokenAndAdvanceScanner(tokenInfo, parent2, listDynamicIndentation, parent2); + tokenInfo = formattingScanner.isOnToken() ? formattingScanner.readTokenInfo(parent2) : void 0; + } + if (tokenInfo && tokenInfo.token.kind === listEndToken && rangeContainsRange(parent2, tokenInfo.token)) { + consumeTokenAndAdvanceScanner( + tokenInfo, + parent2, + listDynamicIndentation, + parent2, + /*isListEndToken*/ + true + ); + } + } + } + function consumeTokenAndAdvanceScanner(currentTokenInfo, parent2, dynamicIndentation, container, isListEndToken) { + Debug.assert(rangeContainsRange(parent2, currentTokenInfo.token)); + const lastTriviaWasNewLine = formattingScanner.lastTrailingTriviaWasNewLine(); + let indentToken = false; + if (currentTokenInfo.leadingTrivia) { + processTrivia(currentTokenInfo.leadingTrivia, parent2, childContextNode, dynamicIndentation); + } + let lineAction = 0 /* None */; + const isTokenInRange = rangeContainsRange(originalRange, currentTokenInfo.token); + const tokenStart = sourceFile.getLineAndCharacterOfPosition(currentTokenInfo.token.pos); + if (isTokenInRange) { + const rangeHasError = rangeContainsError(currentTokenInfo.token); + const savePreviousRange = previousRange; + lineAction = processRange(currentTokenInfo.token, tokenStart, parent2, childContextNode, dynamicIndentation); + if (!rangeHasError) { + if (lineAction === 0 /* None */) { + const prevEndLine = savePreviousRange && sourceFile.getLineAndCharacterOfPosition(savePreviousRange.end).line; + indentToken = lastTriviaWasNewLine && tokenStart.line !== prevEndLine; + } else { + indentToken = lineAction === 1 /* LineAdded */; + } + } + } + if (currentTokenInfo.trailingTrivia) { + previousRangeTriviaEnd = last(currentTokenInfo.trailingTrivia).end; + processTrivia(currentTokenInfo.trailingTrivia, parent2, childContextNode, dynamicIndentation); + } + if (indentToken) { + const tokenIndentation = isTokenInRange && !rangeContainsError(currentTokenInfo.token) ? dynamicIndentation.getIndentationForToken(tokenStart.line, currentTokenInfo.token.kind, container, !!isListEndToken) : -1 /* Unknown */; + let indentNextTokenOrTrivia = true; + if (currentTokenInfo.leadingTrivia) { + const commentIndentation = dynamicIndentation.getIndentationForComment(currentTokenInfo.token.kind, tokenIndentation, container); + indentNextTokenOrTrivia = indentTriviaItems(currentTokenInfo.leadingTrivia, commentIndentation, indentNextTokenOrTrivia, (item) => insertIndentation( + item.pos, + commentIndentation, + /*lineAdded*/ + false + )); + } + if (tokenIndentation !== -1 /* Unknown */ && indentNextTokenOrTrivia) { + insertIndentation(currentTokenInfo.token.pos, tokenIndentation, lineAction === 1 /* LineAdded */); + lastIndentedLine = tokenStart.line; + indentationOnLastIndentedLine = tokenIndentation; + } + } + formattingScanner.advance(); + childContextNode = parent2; + } } - }); - - // src/services/_namespaces/ts.OrganizeImports.ts - var ts_OrganizeImports_exports = {}; - __export(ts_OrganizeImports_exports, { - coalesceExports: () => coalesceExports, - coalesceImports: () => coalesceImports, - compareImportOrExportSpecifiers: () => compareImportOrExportSpecifiers, - compareImportsOrRequireStatements: () => compareImportsOrRequireStatements, - compareModuleSpecifiers: () => compareModuleSpecifiers2, - detectImportDeclarationSorting: () => detectImportDeclarationSorting, - detectImportSpecifierSorting: () => detectImportSpecifierSorting, - detectSorting: () => detectSorting, - getImportDeclarationInsertionIndex: () => getImportDeclarationInsertionIndex, - getImportSpecifierInsertionIndex: () => getImportSpecifierInsertionIndex, - getOrganizeImportsComparer: () => getOrganizeImportsComparer, - organizeImports: () => organizeImports - }); - var init_ts_OrganizeImports = __esm({ - "src/services/_namespaces/ts.OrganizeImports.ts"() { - "use strict"; - init_organizeImports(); + function indentTriviaItems(trivia, commentIndentation, indentNextTokenOrTrivia, indentSingleLine) { + for (const triviaItem of trivia) { + const triviaInRange = rangeContainsRange(originalRange, triviaItem); + switch (triviaItem.kind) { + case 3 /* MultiLineCommentTrivia */: + if (triviaInRange) { + indentMultilineComment( + triviaItem, + commentIndentation, + /*firstLineIsIndented*/ + !indentNextTokenOrTrivia + ); + } + indentNextTokenOrTrivia = false; + break; + case 2 /* SingleLineCommentTrivia */: + if (indentNextTokenOrTrivia && triviaInRange) { + indentSingleLine(triviaItem); + } + indentNextTokenOrTrivia = false; + break; + case 4 /* NewLineTrivia */: + indentNextTokenOrTrivia = true; + break; + } + } + return indentNextTokenOrTrivia; } - }); - - // src/services/outliningElementsCollector.ts - function collectElements(sourceFile, cancellationToken) { - const res = []; - addNodeOutliningSpans(sourceFile, cancellationToken, res); - addRegionOutliningSpans(sourceFile, res); - return res.sort((span1, span2) => span1.textSpan.start - span2.textSpan.start); - } - function addNodeOutliningSpans(sourceFile, cancellationToken, out) { - let depthRemaining = 40; - let current = 0; - const statements = [...sourceFile.statements, sourceFile.endOfFileToken]; - const n = statements.length; - while (current < n) { - while (current < n && !isAnyImportSyntax(statements[current])) { - visitNode3(statements[current]); - current++; + function processTrivia(trivia, parent2, contextNode, dynamicIndentation) { + for (const triviaItem of trivia) { + if (isComment(triviaItem.kind) && rangeContainsRange(originalRange, triviaItem)) { + const triviaItemStart = sourceFile.getLineAndCharacterOfPosition(triviaItem.pos); + processRange(triviaItem, triviaItemStart, parent2, contextNode, dynamicIndentation); + } } - if (current === n) - break; - const firstImport = current; - while (current < n && isAnyImportSyntax(statements[current])) { - visitNode3(statements[current]); - current++; + } + function processRange(range, rangeStart, parent2, contextNode, dynamicIndentation) { + const rangeHasError = rangeContainsError(range); + let lineAction = 0 /* None */; + if (!rangeHasError) { + if (!previousRange) { + const originalStart = sourceFile.getLineAndCharacterOfPosition(originalRange.pos); + trimTrailingWhitespacesForLines(originalStart.line, rangeStart.line); + } else { + lineAction = processPair(range, rangeStart.line, parent2, previousRange, previousRangeStartLine, previousParent, contextNode, dynamicIndentation); + } } - const lastImport = current - 1; - if (lastImport !== firstImport) { - out.push(createOutliningSpanFromBounds(findChildOfKind(statements[firstImport], 102 /* ImportKeyword */, sourceFile).getStart(sourceFile), statements[lastImport].getEnd(), "imports" /* Imports */)); + previousRange = range; + previousRangeTriviaEnd = range.end; + previousParent = parent2; + previousRangeStartLine = rangeStart.line; + return lineAction; + } + function processPair(currentItem, currentStartLine, currentParent, previousItem, previousStartLine, previousParent2, contextNode, dynamicIndentation) { + formattingContext.updateContext(previousItem, previousParent2, currentItem, currentParent, contextNode); + const rules = getRules(formattingContext); + let trimTrailingWhitespaces = formattingContext.options.trimTrailingWhitespace !== false; + let lineAction = 0 /* None */; + if (rules) { + forEachRight(rules, (rule2) => { + lineAction = applyRuleEdits(rule2, previousItem, previousStartLine, currentItem, currentStartLine); + if (dynamicIndentation) { + switch (lineAction) { + case 2 /* LineRemoved */: + if (currentParent.getStart(sourceFile) === currentItem.pos) { + dynamicIndentation.recomputeIndentation( + /*lineAddedByFormatting*/ + false, + contextNode + ); + } + break; + case 1 /* LineAdded */: + if (currentParent.getStart(sourceFile) === currentItem.pos) { + dynamicIndentation.recomputeIndentation( + /*lineAddedByFormatting*/ + true, + contextNode + ); + } + break; + default: + Debug.assert(lineAction === 0 /* None */); + } + } + trimTrailingWhitespaces = trimTrailingWhitespaces && !(rule2.action & 16 /* DeleteSpace */) && rule2.flags !== 1 /* CanDeleteNewLines */; + }); + } else { + trimTrailingWhitespaces = trimTrailingWhitespaces && currentItem.kind !== 1 /* EndOfFileToken */; + } + if (currentStartLine !== previousStartLine && trimTrailingWhitespaces) { + trimTrailingWhitespacesForLines(previousStartLine, currentStartLine, previousItem); + } + return lineAction; + } + function insertIndentation(pos, indentation, lineAdded) { + const indentationString = getIndentationString(indentation, options); + if (lineAdded) { + recordReplace(pos, 0, indentationString); + } else { + const tokenStart = sourceFile.getLineAndCharacterOfPosition(pos); + const startLinePosition = getStartPositionOfLine(tokenStart.line, sourceFile); + if (indentation !== characterToColumn(startLinePosition, tokenStart.character) || indentationIsDifferent(indentationString, startLinePosition)) { + recordReplace(startLinePosition, tokenStart.character, indentationString); + } + } + } + function characterToColumn(startLinePosition, characterInLine) { + let column = 0; + for (let i = 0; i < characterInLine; i++) { + if (sourceFile.text.charCodeAt(startLinePosition + i) === 9 /* tab */) { + column += options.tabSize - column % options.tabSize; + } else { + column++; + } } + return column; } - function visitNode3(n2) { - var _a; - if (depthRemaining === 0) + function indentationIsDifferent(indentationString, startLinePosition) { + return indentationString !== sourceFile.text.substr(startLinePosition, indentationString.length); + } + function indentMultilineComment(commentRange, indentation, firstLineIsIndented, indentFinalLine = true) { + let startLine = sourceFile.getLineAndCharacterOfPosition(commentRange.pos).line; + const endLine = sourceFile.getLineAndCharacterOfPosition(commentRange.end).line; + if (startLine === endLine) { + if (!firstLineIsIndented) { + insertIndentation( + commentRange.pos, + indentation, + /*lineAdded*/ + false + ); + } return; - cancellationToken.throwIfCancellationRequested(); - if (isDeclaration(n2) || isVariableStatement(n2) || isReturnStatement(n2) || isCallOrNewExpression(n2) || n2.kind === 1 /* EndOfFileToken */) { - addOutliningForLeadingCommentsForNode(n2, sourceFile, cancellationToken, out); } - if (isFunctionLike(n2) && isBinaryExpression(n2.parent) && isPropertyAccessExpression(n2.parent.left)) { - addOutliningForLeadingCommentsForNode(n2.parent.left, sourceFile, cancellationToken, out); + const parts = []; + let startPos = commentRange.pos; + for (let line = startLine; line < endLine; line++) { + const endOfLine = getEndLinePosition(line, sourceFile); + parts.push({ pos: startPos, end: endOfLine }); + startPos = getStartPositionOfLine(line + 1, sourceFile); } - if (isBlock(n2) || isModuleBlock(n2)) { - addOutliningForLeadingCommentsForPos(n2.statements.end, sourceFile, cancellationToken, out); + if (indentFinalLine) { + parts.push({ pos: startPos, end: commentRange.end }); } - if (isClassLike(n2) || isInterfaceDeclaration(n2)) { - addOutliningForLeadingCommentsForPos(n2.members.end, sourceFile, cancellationToken, out); + if (parts.length === 0) + return; + const startLinePos = getStartPositionOfLine(startLine, sourceFile); + const nonWhitespaceColumnInFirstPart = SmartIndenter.findFirstNonWhitespaceCharacterAndColumn(startLinePos, parts[0].pos, sourceFile, options); + let startIndex = 0; + if (firstLineIsIndented) { + startIndex = 1; + startLine++; } - const span = getOutliningSpanForNode(n2, sourceFile); - if (span) - out.push(span); - depthRemaining--; - if (isCallExpression(n2)) { - depthRemaining++; - visitNode3(n2.expression); - depthRemaining--; - n2.arguments.forEach(visitNode3); - (_a = n2.typeArguments) == null ? void 0 : _a.forEach(visitNode3); - } else if (isIfStatement(n2) && n2.elseStatement && isIfStatement(n2.elseStatement)) { - visitNode3(n2.expression); - visitNode3(n2.thenStatement); - depthRemaining++; - visitNode3(n2.elseStatement); - depthRemaining--; - } else { - n2.forEachChild(visitNode3); + const delta2 = indentation - nonWhitespaceColumnInFirstPart.column; + for (let i = startIndex; i < parts.length; i++, startLine++) { + const startLinePos2 = getStartPositionOfLine(startLine, sourceFile); + const nonWhitespaceCharacterAndColumn = i === 0 ? nonWhitespaceColumnInFirstPart : SmartIndenter.findFirstNonWhitespaceCharacterAndColumn(parts[i].pos, parts[i].end, sourceFile, options); + const newIndentation = nonWhitespaceCharacterAndColumn.column + delta2; + if (newIndentation > 0) { + const indentationString = getIndentationString(newIndentation, options); + recordReplace(startLinePos2, nonWhitespaceCharacterAndColumn.character, indentationString); + } else { + recordDelete(startLinePos2, nonWhitespaceCharacterAndColumn.character); + } } - depthRemaining++; } - } - function addRegionOutliningSpans(sourceFile, out) { - const regions = []; - const lineStarts = sourceFile.getLineStarts(); - for (const currentLineStart of lineStarts) { - const lineEnd = sourceFile.getLineEndOfPosition(currentLineStart); - const lineText = sourceFile.text.substring(currentLineStart, lineEnd); - const result = isRegionDelimiter(lineText); - if (!result || isInComment(sourceFile, currentLineStart)) { - continue; + function trimTrailingWhitespacesForLines(line1, line2, range) { + for (let line = line1; line < line2; line++) { + const lineStartPosition = getStartPositionOfLine(line, sourceFile); + const lineEndPosition = getEndLinePosition(line, sourceFile); + if (range && (isComment(range.kind) || isStringOrRegularExpressionOrTemplateLiteral(range.kind)) && range.pos <= lineEndPosition && range.end > lineEndPosition) { + continue; + } + const whitespaceStart = getTrailingWhitespaceStartPosition(lineStartPosition, lineEndPosition); + if (whitespaceStart !== -1) { + Debug.assert(whitespaceStart === lineStartPosition || !isWhiteSpaceSingleLine(sourceFile.text.charCodeAt(whitespaceStart - 1))); + recordDelete(whitespaceStart, lineEndPosition + 1 - whitespaceStart); + } } - if (!result[1]) { - const span = createTextSpanFromBounds(sourceFile.text.indexOf("//", currentLineStart), lineEnd); - regions.push(createOutliningSpan( - span, - "region" /* Region */, - span, - /*autoCollapse*/ - false, - result[2] || "#region" - )); - } else { - const region = regions.pop(); - if (region) { - region.textSpan.length = lineEnd - region.textSpan.start; - region.hintSpan.length = lineEnd - region.textSpan.start; - out.push(region); + } + function getTrailingWhitespaceStartPosition(start, end) { + let pos = end; + while (pos >= start && isWhiteSpaceSingleLine(sourceFile.text.charCodeAt(pos))) { + pos--; + } + if (pos !== end) { + return pos + 1; + } + return -1; + } + function trimTrailingWhitespacesForRemainingRange(trivias) { + let startPos = previousRange ? previousRange.end : originalRange.pos; + for (const trivia of trivias) { + if (isComment(trivia.kind)) { + if (startPos < trivia.pos) { + trimTrailingWitespacesForPositions(startPos, trivia.pos - 1, previousRange); + } + startPos = trivia.end + 1; } } + if (startPos < originalRange.end) { + trimTrailingWitespacesForPositions(startPos, originalRange.end, previousRange); + } } - } - function isRegionDelimiter(lineText) { - lineText = trimStringStart(lineText); - if (!startsWith(lineText, "//")) { - return null; + function trimTrailingWitespacesForPositions(startPos, endPos, previousRange2) { + const startLine = sourceFile.getLineAndCharacterOfPosition(startPos).line; + const endLine = sourceFile.getLineAndCharacterOfPosition(endPos).line; + trimTrailingWhitespacesForLines(startLine, endLine + 1, previousRange2); } - lineText = trimString(lineText.slice(2)); - return regionDelimiterRegExp.exec(lineText); - } - function addOutliningForLeadingCommentsForPos(pos, sourceFile, cancellationToken, out) { - const comments = getLeadingCommentRanges(sourceFile.text, pos); - if (!comments) - return; - let firstSingleLineCommentStart = -1; - let lastSingleLineCommentEnd = -1; - let singleLineCommentCount = 0; - const sourceText = sourceFile.getFullText(); - for (const { kind, pos: pos2, end } of comments) { - cancellationToken.throwIfCancellationRequested(); - switch (kind) { - case 2 /* SingleLineCommentTrivia */: - const commentText = sourceText.slice(pos2, end); - if (isRegionDelimiter(commentText)) { - combineAndAddMultipleSingleLineComments(); - singleLineCommentCount = 0; - break; + function recordDelete(start, len) { + if (len) { + edits.push(createTextChangeFromStartLength(start, len, "")); + } + } + function recordReplace(start, len, newText) { + if (len || newText) { + edits.push(createTextChangeFromStartLength(start, len, newText)); + } + } + function recordInsert(start, text) { + if (text) { + edits.push(createTextChangeFromStartLength(start, 0, text)); + } + } + function applyRuleEdits(rule2, previousRange2, previousStartLine, currentRange, currentStartLine) { + const onLaterLine = currentStartLine !== previousStartLine; + switch (rule2.action) { + case 1 /* StopProcessingSpaceActions */: + return 0 /* None */; + case 16 /* DeleteSpace */: + if (previousRange2.end !== currentRange.pos) { + recordDelete(previousRange2.end, currentRange.pos - previousRange2.end); + return onLaterLine ? 2 /* LineRemoved */ : 0 /* None */; } - if (singleLineCommentCount === 0) { - firstSingleLineCommentStart = pos2; + break; + case 32 /* DeleteToken */: + recordDelete(previousRange2.pos, previousRange2.end - previousRange2.pos); + break; + case 8 /* InsertNewLine */: + if (rule2.flags !== 1 /* CanDeleteNewLines */ && previousStartLine !== currentStartLine) { + return 0 /* None */; + } + const lineDelta = currentStartLine - previousStartLine; + if (lineDelta !== 1) { + recordReplace(previousRange2.end, currentRange.pos - previousRange2.end, getNewLineOrDefaultFromHost(host, options)); + return onLaterLine ? 0 /* None */ : 1 /* LineAdded */; } - lastSingleLineCommentEnd = end; - singleLineCommentCount++; break; - case 3 /* MultiLineCommentTrivia */: - combineAndAddMultipleSingleLineComments(); - out.push(createOutliningSpanFromBounds(pos2, end, "comment" /* Comment */)); - singleLineCommentCount = 0; + case 4 /* InsertSpace */: + if (rule2.flags !== 1 /* CanDeleteNewLines */ && previousStartLine !== currentStartLine) { + return 0 /* None */; + } + const posDelta = currentRange.pos - previousRange2.end; + if (posDelta !== 1 || sourceFile.text.charCodeAt(previousRange2.end) !== 32 /* space */) { + recordReplace(previousRange2.end, currentRange.pos - previousRange2.end, " "); + return onLaterLine ? 2 /* LineRemoved */ : 0 /* None */; + } break; - default: - Debug.assertNever(kind); - } - } - combineAndAddMultipleSingleLineComments(); - function combineAndAddMultipleSingleLineComments() { - if (singleLineCommentCount > 1) { - out.push(createOutliningSpanFromBounds(firstSingleLineCommentStart, lastSingleLineCommentEnd, "comment" /* Comment */)); + case 64 /* InsertTrailingSemicolon */: + recordInsert(previousRange2.end, ";"); } + return 0 /* None */; } } - function addOutliningForLeadingCommentsForNode(n, sourceFile, cancellationToken, out) { - if (isJsxText(n)) - return; - addOutliningForLeadingCommentsForPos(n.pos, sourceFile, cancellationToken, out); - } - function createOutliningSpanFromBounds(pos, end, kind) { - return createOutliningSpan(createTextSpanFromBounds(pos, end), kind); + function getRangeOfEnclosingComment(sourceFile, position, precedingToken, tokenAtPosition = getTokenAtPosition(sourceFile, position)) { + const jsdoc = findAncestor(tokenAtPosition, isJSDoc); + if (jsdoc) + tokenAtPosition = jsdoc.parent; + const tokenStart = tokenAtPosition.getStart(sourceFile); + if (tokenStart <= position && position < tokenAtPosition.getEnd()) { + return void 0; + } + precedingToken = precedingToken === null ? void 0 : precedingToken === void 0 ? findPrecedingToken(position, sourceFile) : precedingToken; + const trailingRangesOfPreviousToken = precedingToken && getTrailingCommentRanges(sourceFile.text, precedingToken.end); + const leadingCommentRangesOfNextToken = getLeadingCommentRangesOfNode(tokenAtPosition, sourceFile); + const commentRanges = concatenate(trailingRangesOfPreviousToken, leadingCommentRangesOfNextToken); + return commentRanges && find(commentRanges, (range) => rangeContainsPositionExclusive(range, position) || // The end marker of a single-line comment does not include the newline character. + // With caret at `^`, in the following case, we are inside a comment (^ denotes the cursor position): + // + // // asdf ^\n + // + // But for closed multi-line comments, we don't want to be inside the comment in the following case: + // + // /* asdf */^ + // + // However, unterminated multi-line comments *do* contain their end. + // + // Internally, we represent the end of the comment at the newline and closing '/', respectively. + // + position === range.end && (range.kind === 2 /* SingleLineCommentTrivia */ || position === sourceFile.getFullWidth())); } - function getOutliningSpanForNode(n, sourceFile) { - switch (n.kind) { - case 240 /* Block */: - if (isFunctionLike(n.parent)) { - return functionSpan(n.parent, n, sourceFile); + function getOpenTokenForList(node, list) { + switch (node.kind) { + case 176 /* Constructor */: + case 262 /* FunctionDeclaration */: + case 218 /* FunctionExpression */: + case 174 /* MethodDeclaration */: + case 173 /* MethodSignature */: + case 219 /* ArrowFunction */: + case 179 /* CallSignature */: + case 180 /* ConstructSignature */: + case 184 /* FunctionType */: + case 185 /* ConstructorType */: + case 177 /* GetAccessor */: + case 178 /* SetAccessor */: + if (node.typeParameters === list) { + return 30 /* LessThanToken */; + } else if (node.parameters === list) { + return 21 /* OpenParenToken */; } - switch (n.parent.kind) { - case 245 /* DoStatement */: - case 248 /* ForInStatement */: - case 249 /* ForOfStatement */: - case 247 /* ForStatement */: - case 244 /* IfStatement */: - case 246 /* WhileStatement */: - case 253 /* WithStatement */: - case 298 /* CatchClause */: - return spanForNode(n.parent); - case 257 /* TryStatement */: - const tryStatement = n.parent; - if (tryStatement.tryBlock === n) { - return spanForNode(n.parent); - } else if (tryStatement.finallyBlock === n) { - const node = findChildOfKind(tryStatement, 98 /* FinallyKeyword */, sourceFile); - if (node) - return spanForNode(node); - } - default: - return createOutliningSpan(createTextSpanFromNode(n, sourceFile), "code" /* Code */); + break; + case 213 /* CallExpression */: + case 214 /* NewExpression */: + if (node.typeArguments === list) { + return 30 /* LessThanToken */; + } else if (node.arguments === list) { + return 21 /* OpenParenToken */; } - case 267 /* ModuleBlock */: - return spanForNode(n.parent); - case 262 /* ClassDeclaration */: - case 230 /* ClassExpression */: - case 263 /* InterfaceDeclaration */: - case 265 /* EnumDeclaration */: - case 268 /* CaseBlock */: - case 186 /* TypeLiteral */: - case 205 /* ObjectBindingPattern */: - return spanForNode(n); - case 188 /* TupleType */: - return spanForNode( - n, - /*autoCollapse*/ - false, - /*useFullStart*/ - !isTupleTypeNode(n.parent), - 23 /* OpenBracketToken */ - ); - case 295 /* CaseClause */: - case 296 /* DefaultClause */: - return spanForNodeArray(n.statements); - case 209 /* ObjectLiteralExpression */: - return spanForObjectOrArrayLiteral(n); - case 208 /* ArrayLiteralExpression */: - return spanForObjectOrArrayLiteral(n, 23 /* OpenBracketToken */); - case 283 /* JsxElement */: - return spanForJSXElement(n); - case 287 /* JsxFragment */: - return spanForJSXFragment(n); - case 284 /* JsxSelfClosingElement */: - case 285 /* JsxOpeningElement */: - return spanForJSXAttributes(n.attributes); - case 227 /* TemplateExpression */: - case 15 /* NoSubstitutionTemplateLiteral */: - return spanForTemplateLiteral(n); - case 206 /* ArrayBindingPattern */: - return spanForNode( - n, - /*autoCollapse*/ - false, - /*useFullStart*/ - !isBindingElement(n.parent), - 23 /* OpenBracketToken */ - ); - case 218 /* ArrowFunction */: - return spanForArrowFunction(n); - case 212 /* CallExpression */: - return spanForCallExpression(n); - case 216 /* ParenthesizedExpression */: - return spanForParenthesizedExpression(n); - case 274 /* NamedImports */: - case 278 /* NamedExports */: - case 299 /* AssertClause */: - return spanForNamedImportsOrExportsOrAssertClause(n); + break; + case 263 /* ClassDeclaration */: + case 231 /* ClassExpression */: + case 264 /* InterfaceDeclaration */: + case 265 /* TypeAliasDeclaration */: + if (node.typeParameters === list) { + return 30 /* LessThanToken */; + } + break; + case 183 /* TypeReference */: + case 215 /* TaggedTemplateExpression */: + case 186 /* TypeQuery */: + case 233 /* ExpressionWithTypeArguments */: + case 205 /* ImportType */: + if (node.typeArguments === list) { + return 30 /* LessThanToken */; + } + break; + case 187 /* TypeLiteral */: + return 19 /* OpenBraceToken */; } - function spanForNamedImportsOrExportsOrAssertClause(node) { - if (!node.elements.length) { - return void 0; - } - const openToken = findChildOfKind(node, 19 /* OpenBraceToken */, sourceFile); - const closeToken = findChildOfKind(node, 20 /* CloseBraceToken */, sourceFile); - if (!openToken || !closeToken || positionsAreOnSameLine(openToken.pos, closeToken.pos, sourceFile)) { - return void 0; - } - return spanBetweenTokens( - openToken, - closeToken, - node, - sourceFile, - /*autoCollapse*/ - false, - /*useFullStart*/ - false - ); + return 0 /* Unknown */; + } + function getCloseTokenForOpenToken(kind) { + switch (kind) { + case 21 /* OpenParenToken */: + return 22 /* CloseParenToken */; + case 30 /* LessThanToken */: + return 32 /* GreaterThanToken */; + case 19 /* OpenBraceToken */: + return 20 /* CloseBraceToken */; } - function spanForCallExpression(node) { - if (!node.arguments.length) { - return void 0; - } - const openToken = findChildOfKind(node, 21 /* OpenParenToken */, sourceFile); - const closeToken = findChildOfKind(node, 22 /* CloseParenToken */, sourceFile); - if (!openToken || !closeToken || positionsAreOnSameLine(openToken.pos, closeToken.pos, sourceFile)) { - return void 0; - } - return spanBetweenTokens( - openToken, - closeToken, - node, - sourceFile, - /*autoCollapse*/ - false, - /*useFullStart*/ - true - ); + return 0 /* Unknown */; + } + function getIndentationString(indentation, options) { + const resetInternedStrings = !internedSizes || (internedSizes.tabSize !== options.tabSize || internedSizes.indentSize !== options.indentSize); + if (resetInternedStrings) { + internedSizes = { tabSize: options.tabSize, indentSize: options.indentSize }; + internedTabsIndentation = internedSpacesIndentation = void 0; } - function spanForArrowFunction(node) { - if (isBlock(node.body) || isParenthesizedExpression(node.body) || positionsAreOnSameLine(node.body.getFullStart(), node.body.getEnd(), sourceFile)) { - return void 0; + if (!options.convertTabsToSpaces) { + const tabs = Math.floor(indentation / options.tabSize); + const spaces = indentation - tabs * options.tabSize; + let tabString; + if (!internedTabsIndentation) { + internedTabsIndentation = []; } - const textSpan = createTextSpanFromBounds(node.body.getFullStart(), node.body.getEnd()); - return createOutliningSpan(textSpan, "code" /* Code */, createTextSpanFromNode(node)); - } - function spanForJSXElement(node) { - const textSpan = createTextSpanFromBounds(node.openingElement.getStart(sourceFile), node.closingElement.getEnd()); - const tagName = node.openingElement.tagName.getText(sourceFile); - const bannerText = "<" + tagName + ">..."; - return createOutliningSpan( - textSpan, - "code" /* Code */, - textSpan, - /*autoCollapse*/ - false, - bannerText - ); - } - function spanForJSXFragment(node) { - const textSpan = createTextSpanFromBounds(node.openingFragment.getStart(sourceFile), node.closingFragment.getEnd()); - const bannerText = "<>..."; - return createOutliningSpan( - textSpan, - "code" /* Code */, - textSpan, - /*autoCollapse*/ - false, - bannerText - ); - } - function spanForJSXAttributes(node) { - if (node.properties.length === 0) { - return void 0; + if (internedTabsIndentation[tabs] === void 0) { + internedTabsIndentation[tabs] = tabString = repeatString(" ", tabs); + } else { + tabString = internedTabsIndentation[tabs]; } - return createOutliningSpanFromBounds(node.getStart(sourceFile), node.getEnd(), "code" /* Code */); - } - function spanForTemplateLiteral(node) { - if (node.kind === 15 /* NoSubstitutionTemplateLiteral */ && node.text.length === 0) { - return void 0; + return spaces ? tabString + repeatString(" ", spaces) : tabString; + } else { + let spacesString; + const quotient = Math.floor(indentation / options.indentSize); + const remainder = indentation % options.indentSize; + if (!internedSpacesIndentation) { + internedSpacesIndentation = []; } - return createOutliningSpanFromBounds(node.getStart(sourceFile), node.getEnd(), "code" /* Code */); + if (internedSpacesIndentation[quotient] === void 0) { + spacesString = repeatString(" ", options.indentSize * quotient); + internedSpacesIndentation[quotient] = spacesString; + } else { + spacesString = internedSpacesIndentation[quotient]; + } + return remainder ? spacesString + repeatString(" ", remainder) : spacesString; } - function spanForObjectOrArrayLiteral(node, open = 19 /* OpenBraceToken */) { - return spanForNode( - node, - /*autoCollapse*/ - false, - /*useFullStart*/ - !isArrayLiteralExpression(node.parent) && !isCallExpression(node.parent), - open - ); + } + var internedSizes, internedTabsIndentation, internedSpacesIndentation; + var init_formatting = __esm({ + "src/services/formatting/formatting.ts"() { + "use strict"; + init_ts4(); + init_ts_formatting(); } - function spanForNode(hintSpanNode, autoCollapse = false, useFullStart = true, open = 19 /* OpenBraceToken */, close = open === 19 /* OpenBraceToken */ ? 20 /* CloseBraceToken */ : 24 /* CloseBracketToken */) { - const openToken = findChildOfKind(n, open, sourceFile); - const closeToken = findChildOfKind(n, close, sourceFile); - return openToken && closeToken && spanBetweenTokens(openToken, closeToken, hintSpanNode, sourceFile, autoCollapse, useFullStart); + }); + + // src/services/formatting/smartIndenter.ts + var SmartIndenter; + var init_smartIndenter = __esm({ + "src/services/formatting/smartIndenter.ts"() { + "use strict"; + init_ts4(); + init_ts_formatting(); + ((SmartIndenter2) => { + let Value; + ((Value2) => { + Value2[Value2["Unknown"] = -1] = "Unknown"; + })(Value || (Value = {})); + function getIndentation(position, sourceFile, options, assumeNewLineBeforeCloseBrace = false) { + if (position > sourceFile.text.length) { + return getBaseIndentation(options); + } + if (options.indentStyle === 0 /* None */) { + return 0; + } + const precedingToken = findPrecedingToken( + position, + sourceFile, + /*startNode*/ + void 0, + /*excludeJsdoc*/ + true + ); + const enclosingCommentRange = getRangeOfEnclosingComment(sourceFile, position, precedingToken || null); + if (enclosingCommentRange && enclosingCommentRange.kind === 3 /* MultiLineCommentTrivia */) { + return getCommentIndent(sourceFile, position, options, enclosingCommentRange); + } + if (!precedingToken) { + return getBaseIndentation(options); + } + const precedingTokenIsLiteral = isStringOrRegularExpressionOrTemplateLiteral(precedingToken.kind); + if (precedingTokenIsLiteral && precedingToken.getStart(sourceFile) <= position && position < precedingToken.end) { + return 0; + } + const lineAtPosition = sourceFile.getLineAndCharacterOfPosition(position).line; + const currentToken = getTokenAtPosition(sourceFile, position); + const isObjectLiteral = currentToken.kind === 19 /* OpenBraceToken */ && currentToken.parent.kind === 210 /* ObjectLiteralExpression */; + if (options.indentStyle === 1 /* Block */ || isObjectLiteral) { + return getBlockIndent(sourceFile, position, options); + } + if (precedingToken.kind === 28 /* CommaToken */ && precedingToken.parent.kind !== 226 /* BinaryExpression */) { + const actualIndentation = getActualIndentationForListItemBeforeComma(precedingToken, sourceFile, options); + if (actualIndentation !== -1 /* Unknown */) { + return actualIndentation; + } + } + const containerList = getListByPosition(position, precedingToken.parent, sourceFile); + if (containerList && !rangeContainsRange(containerList, precedingToken)) { + const useTheSameBaseIndentation = [218 /* FunctionExpression */, 219 /* ArrowFunction */].includes(currentToken.parent.kind); + const indentSize = useTheSameBaseIndentation ? 0 : options.indentSize; + return getActualIndentationForListStartLine(containerList, sourceFile, options) + indentSize; + } + return getSmartIndent(sourceFile, position, precedingToken, lineAtPosition, assumeNewLineBeforeCloseBrace, options); + } + SmartIndenter2.getIndentation = getIndentation; + function getCommentIndent(sourceFile, position, options, enclosingCommentRange) { + const previousLine = getLineAndCharacterOfPosition(sourceFile, position).line - 1; + const commentStartLine = getLineAndCharacterOfPosition(sourceFile, enclosingCommentRange.pos).line; + Debug.assert(commentStartLine >= 0); + if (previousLine <= commentStartLine) { + return findFirstNonWhitespaceColumn(getStartPositionOfLine(commentStartLine, sourceFile), position, sourceFile, options); + } + const startPositionOfLine = getStartPositionOfLine(previousLine, sourceFile); + const { column, character } = findFirstNonWhitespaceCharacterAndColumn(startPositionOfLine, position, sourceFile, options); + if (column === 0) { + return column; + } + const firstNonWhitespaceCharacterCode = sourceFile.text.charCodeAt(startPositionOfLine + character); + return firstNonWhitespaceCharacterCode === 42 /* asterisk */ ? column - 1 : column; + } + function getBlockIndent(sourceFile, position, options) { + let current = position; + while (current > 0) { + const char = sourceFile.text.charCodeAt(current); + if (!isWhiteSpaceLike(char)) { + break; + } + current--; + } + const lineStart = getLineStartPositionForPosition(current, sourceFile); + return findFirstNonWhitespaceColumn(lineStart, current, sourceFile, options); + } + function getSmartIndent(sourceFile, position, precedingToken, lineAtPosition, assumeNewLineBeforeCloseBrace, options) { + let previous; + let current = precedingToken; + while (current) { + if (positionBelongsToNode(current, position, sourceFile) && shouldIndentChildNode( + options, + current, + previous, + sourceFile, + /*isNextChild*/ + true + )) { + const currentStart = getStartLineAndCharacterForNode(current, sourceFile); + const nextTokenKind = nextTokenIsCurlyBraceOnSameLineAsCursor(precedingToken, current, lineAtPosition, sourceFile); + const indentationDelta = nextTokenKind !== 0 /* Unknown */ ? assumeNewLineBeforeCloseBrace && nextTokenKind === 2 /* CloseBrace */ ? options.indentSize : 0 : lineAtPosition !== currentStart.line ? options.indentSize : 0; + return getIndentationForNodeWorker( + current, + currentStart, + /*ignoreActualIndentationRange*/ + void 0, + indentationDelta, + sourceFile, + /*isNextChild*/ + true, + options + ); + } + const actualIndentation = getActualIndentationForListItem( + current, + sourceFile, + options, + /*listIndentsChild*/ + true + ); + if (actualIndentation !== -1 /* Unknown */) { + return actualIndentation; + } + previous = current; + current = current.parent; + } + return getBaseIndentation(options); + } + function getIndentationForNode(n, ignoreActualIndentationRange, sourceFile, options) { + const start = sourceFile.getLineAndCharacterOfPosition(n.getStart(sourceFile)); + return getIndentationForNodeWorker( + n, + start, + ignoreActualIndentationRange, + /*indentationDelta*/ + 0, + sourceFile, + /*isNextChild*/ + false, + options + ); + } + SmartIndenter2.getIndentationForNode = getIndentationForNode; + function getBaseIndentation(options) { + return options.baseIndentSize || 0; + } + SmartIndenter2.getBaseIndentation = getBaseIndentation; + function getIndentationForNodeWorker(current, currentStart, ignoreActualIndentationRange, indentationDelta, sourceFile, isNextChild, options) { + var _a; + let parent2 = current.parent; + while (parent2) { + let useActualIndentation = true; + if (ignoreActualIndentationRange) { + const start = current.getStart(sourceFile); + useActualIndentation = start < ignoreActualIndentationRange.pos || start > ignoreActualIndentationRange.end; + } + const containingListOrParentStart = getContainingListOrParentStart(parent2, current, sourceFile); + const parentAndChildShareLine = containingListOrParentStart.line === currentStart.line || childStartsOnTheSameLineWithElseInIfStatement(parent2, current, currentStart.line, sourceFile); + if (useActualIndentation) { + const firstListChild = (_a = getContainingList(current, sourceFile)) == null ? void 0 : _a[0]; + const listIndentsChild = !!firstListChild && getStartLineAndCharacterForNode(firstListChild, sourceFile).line > containingListOrParentStart.line; + let actualIndentation = getActualIndentationForListItem(current, sourceFile, options, listIndentsChild); + if (actualIndentation !== -1 /* Unknown */) { + return actualIndentation + indentationDelta; + } + actualIndentation = getActualIndentationForNode(current, parent2, currentStart, parentAndChildShareLine, sourceFile, options); + if (actualIndentation !== -1 /* Unknown */) { + return actualIndentation + indentationDelta; + } + } + if (shouldIndentChildNode(options, parent2, current, sourceFile, isNextChild) && !parentAndChildShareLine) { + indentationDelta += options.indentSize; + } + const useTrueStart = isArgumentAndStartLineOverlapsExpressionBeingCalled(parent2, current, currentStart.line, sourceFile); + current = parent2; + parent2 = current.parent; + currentStart = useTrueStart ? sourceFile.getLineAndCharacterOfPosition(current.getStart(sourceFile)) : containingListOrParentStart; + } + return indentationDelta + getBaseIndentation(options); + } + function getContainingListOrParentStart(parent2, child, sourceFile) { + const containingList = getContainingList(child, sourceFile); + const startPos = containingList ? containingList.pos : parent2.getStart(sourceFile); + return sourceFile.getLineAndCharacterOfPosition(startPos); + } + function getActualIndentationForListItemBeforeComma(commaToken, sourceFile, options) { + const commaItemInfo = findListItemInfo(commaToken); + if (commaItemInfo && commaItemInfo.listItemIndex > 0) { + return deriveActualIndentationFromList(commaItemInfo.list.getChildren(), commaItemInfo.listItemIndex - 1, sourceFile, options); + } else { + return -1 /* Unknown */; + } + } + function getActualIndentationForNode(current, parent2, currentLineAndChar, parentAndChildShareLine, sourceFile, options) { + const useActualIndentation = (isDeclaration(current) || isStatementButNotDeclaration(current)) && (parent2.kind === 312 /* SourceFile */ || !parentAndChildShareLine); + if (!useActualIndentation) { + return -1 /* Unknown */; + } + return findColumnForFirstNonWhitespaceCharacterInLine(currentLineAndChar, sourceFile, options); + } + let NextTokenKind; + ((NextTokenKind2) => { + NextTokenKind2[NextTokenKind2["Unknown"] = 0] = "Unknown"; + NextTokenKind2[NextTokenKind2["OpenBrace"] = 1] = "OpenBrace"; + NextTokenKind2[NextTokenKind2["CloseBrace"] = 2] = "CloseBrace"; + })(NextTokenKind || (NextTokenKind = {})); + function nextTokenIsCurlyBraceOnSameLineAsCursor(precedingToken, current, lineAtPosition, sourceFile) { + const nextToken = findNextToken(precedingToken, current, sourceFile); + if (!nextToken) { + return 0 /* Unknown */; + } + if (nextToken.kind === 19 /* OpenBraceToken */) { + return 1 /* OpenBrace */; + } else if (nextToken.kind === 20 /* CloseBraceToken */) { + const nextTokenStartLine = getStartLineAndCharacterForNode(nextToken, sourceFile).line; + return lineAtPosition === nextTokenStartLine ? 2 /* CloseBrace */ : 0 /* Unknown */; + } + return 0 /* Unknown */; + } + function getStartLineAndCharacterForNode(n, sourceFile) { + return sourceFile.getLineAndCharacterOfPosition(n.getStart(sourceFile)); + } + function isArgumentAndStartLineOverlapsExpressionBeingCalled(parent2, child, childStartLine, sourceFile) { + if (!(isCallExpression(parent2) && contains(parent2.arguments, child))) { + return false; + } + const expressionOfCallExpressionEnd = parent2.expression.getEnd(); + const expressionOfCallExpressionEndLine = getLineAndCharacterOfPosition(sourceFile, expressionOfCallExpressionEnd).line; + return expressionOfCallExpressionEndLine === childStartLine; + } + SmartIndenter2.isArgumentAndStartLineOverlapsExpressionBeingCalled = isArgumentAndStartLineOverlapsExpressionBeingCalled; + function childStartsOnTheSameLineWithElseInIfStatement(parent2, child, childStartLine, sourceFile) { + if (parent2.kind === 245 /* IfStatement */ && parent2.elseStatement === child) { + const elseKeyword = findChildOfKind(parent2, 93 /* ElseKeyword */, sourceFile); + Debug.assert(elseKeyword !== void 0); + const elseKeywordStartLine = getStartLineAndCharacterForNode(elseKeyword, sourceFile).line; + return elseKeywordStartLine === childStartLine; + } + return false; + } + SmartIndenter2.childStartsOnTheSameLineWithElseInIfStatement = childStartsOnTheSameLineWithElseInIfStatement; + function childIsUnindentedBranchOfConditionalExpression(parent2, child, childStartLine, sourceFile) { + if (isConditionalExpression(parent2) && (child === parent2.whenTrue || child === parent2.whenFalse)) { + const conditionEndLine = getLineAndCharacterOfPosition(sourceFile, parent2.condition.end).line; + if (child === parent2.whenTrue) { + return childStartLine === conditionEndLine; + } else { + const trueStartLine = getStartLineAndCharacterForNode(parent2.whenTrue, sourceFile).line; + const trueEndLine = getLineAndCharacterOfPosition(sourceFile, parent2.whenTrue.end).line; + return conditionEndLine === trueStartLine && trueEndLine === childStartLine; + } + } + return false; + } + SmartIndenter2.childIsUnindentedBranchOfConditionalExpression = childIsUnindentedBranchOfConditionalExpression; + function argumentStartsOnSameLineAsPreviousArgument(parent2, child, childStartLine, sourceFile) { + if (isCallOrNewExpression(parent2)) { + if (!parent2.arguments) + return false; + const currentNode = find(parent2.arguments, (arg) => arg.pos === child.pos); + if (!currentNode) + return false; + const currentIndex = parent2.arguments.indexOf(currentNode); + if (currentIndex === 0) + return false; + const previousNode = parent2.arguments[currentIndex - 1]; + const lineOfPreviousNode = getLineAndCharacterOfPosition(sourceFile, previousNode.getEnd()).line; + if (childStartLine === lineOfPreviousNode) { + return true; + } + } + return false; + } + SmartIndenter2.argumentStartsOnSameLineAsPreviousArgument = argumentStartsOnSameLineAsPreviousArgument; + function getContainingList(node, sourceFile) { + return node.parent && getListByRange(node.getStart(sourceFile), node.getEnd(), node.parent, sourceFile); + } + SmartIndenter2.getContainingList = getContainingList; + function getListByPosition(pos, node, sourceFile) { + return node && getListByRange(pos, pos, node, sourceFile); + } + function getListByRange(start, end, node, sourceFile) { + switch (node.kind) { + case 183 /* TypeReference */: + return getList(node.typeArguments); + case 210 /* ObjectLiteralExpression */: + return getList(node.properties); + case 209 /* ArrayLiteralExpression */: + return getList(node.elements); + case 187 /* TypeLiteral */: + return getList(node.members); + case 262 /* FunctionDeclaration */: + case 218 /* FunctionExpression */: + case 219 /* ArrowFunction */: + case 174 /* MethodDeclaration */: + case 173 /* MethodSignature */: + case 179 /* CallSignature */: + case 176 /* Constructor */: + case 185 /* ConstructorType */: + case 180 /* ConstructSignature */: + return getList(node.typeParameters) || getList(node.parameters); + case 177 /* GetAccessor */: + return getList(node.parameters); + case 263 /* ClassDeclaration */: + case 231 /* ClassExpression */: + case 264 /* InterfaceDeclaration */: + case 265 /* TypeAliasDeclaration */: + case 352 /* JSDocTemplateTag */: + return getList(node.typeParameters); + case 214 /* NewExpression */: + case 213 /* CallExpression */: + return getList(node.typeArguments) || getList(node.arguments); + case 261 /* VariableDeclarationList */: + return getList(node.declarations); + case 275 /* NamedImports */: + case 279 /* NamedExports */: + return getList(node.elements); + case 206 /* ObjectBindingPattern */: + case 207 /* ArrayBindingPattern */: + return getList(node.elements); + } + function getList(list) { + return list && rangeContainsStartEnd(getVisualListRange(node, list, sourceFile), start, end) ? list : void 0; + } + } + function getVisualListRange(node, list, sourceFile) { + const children = node.getChildren(sourceFile); + for (let i = 1; i < children.length - 1; i++) { + if (children[i].pos === list.pos && children[i].end === list.end) { + return { pos: children[i - 1].end, end: children[i + 1].getStart(sourceFile) }; + } + } + return list; + } + function getActualIndentationForListStartLine(list, sourceFile, options) { + if (!list) { + return -1 /* Unknown */; + } + return findColumnForFirstNonWhitespaceCharacterInLine(sourceFile.getLineAndCharacterOfPosition(list.pos), sourceFile, options); + } + function getActualIndentationForListItem(node, sourceFile, options, listIndentsChild) { + if (node.parent && node.parent.kind === 261 /* VariableDeclarationList */) { + return -1 /* Unknown */; + } + const containingList = getContainingList(node, sourceFile); + if (containingList) { + const index = containingList.indexOf(node); + if (index !== -1) { + const result = deriveActualIndentationFromList(containingList, index, sourceFile, options); + if (result !== -1 /* Unknown */) { + return result; + } + } + return getActualIndentationForListStartLine(containingList, sourceFile, options) + (listIndentsChild ? options.indentSize : 0); + } + return -1 /* Unknown */; + } + function deriveActualIndentationFromList(list, index, sourceFile, options) { + Debug.assert(index >= 0 && index < list.length); + const node = list[index]; + let lineAndCharacter = getStartLineAndCharacterForNode(node, sourceFile); + for (let i = index - 1; i >= 0; i--) { + if (list[i].kind === 28 /* CommaToken */) { + continue; + } + const prevEndLine = sourceFile.getLineAndCharacterOfPosition(list[i].end).line; + if (prevEndLine !== lineAndCharacter.line) { + return findColumnForFirstNonWhitespaceCharacterInLine(lineAndCharacter, sourceFile, options); + } + lineAndCharacter = getStartLineAndCharacterForNode(list[i], sourceFile); + } + return -1 /* Unknown */; + } + function findColumnForFirstNonWhitespaceCharacterInLine(lineAndCharacter, sourceFile, options) { + const lineStart = sourceFile.getPositionOfLineAndCharacter(lineAndCharacter.line, 0); + return findFirstNonWhitespaceColumn(lineStart, lineStart + lineAndCharacter.character, sourceFile, options); + } + function findFirstNonWhitespaceCharacterAndColumn(startPos, endPos, sourceFile, options) { + let character = 0; + let column = 0; + for (let pos = startPos; pos < endPos; pos++) { + const ch = sourceFile.text.charCodeAt(pos); + if (!isWhiteSpaceSingleLine(ch)) { + break; + } + if (ch === 9 /* tab */) { + column += options.tabSize + column % options.tabSize; + } else { + column++; + } + character++; + } + return { column, character }; + } + SmartIndenter2.findFirstNonWhitespaceCharacterAndColumn = findFirstNonWhitespaceCharacterAndColumn; + function findFirstNonWhitespaceColumn(startPos, endPos, sourceFile, options) { + return findFirstNonWhitespaceCharacterAndColumn(startPos, endPos, sourceFile, options).column; + } + SmartIndenter2.findFirstNonWhitespaceColumn = findFirstNonWhitespaceColumn; + function nodeWillIndentChild(settings, parent2, child, sourceFile, indentByDefault) { + const childKind = child ? child.kind : 0 /* Unknown */; + switch (parent2.kind) { + case 244 /* ExpressionStatement */: + case 263 /* ClassDeclaration */: + case 231 /* ClassExpression */: + case 264 /* InterfaceDeclaration */: + case 266 /* EnumDeclaration */: + case 265 /* TypeAliasDeclaration */: + case 209 /* ArrayLiteralExpression */: + case 241 /* Block */: + case 268 /* ModuleBlock */: + case 210 /* ObjectLiteralExpression */: + case 187 /* TypeLiteral */: + case 200 /* MappedType */: + case 189 /* TupleType */: + case 217 /* ParenthesizedExpression */: + case 211 /* PropertyAccessExpression */: + case 213 /* CallExpression */: + case 214 /* NewExpression */: + case 243 /* VariableStatement */: + case 277 /* ExportAssignment */: + case 253 /* ReturnStatement */: + case 227 /* ConditionalExpression */: + case 207 /* ArrayBindingPattern */: + case 206 /* ObjectBindingPattern */: + case 286 /* JsxOpeningElement */: + case 289 /* JsxOpeningFragment */: + case 285 /* JsxSelfClosingElement */: + case 294 /* JsxExpression */: + case 173 /* MethodSignature */: + case 179 /* CallSignature */: + case 180 /* ConstructSignature */: + case 169 /* Parameter */: + case 184 /* FunctionType */: + case 185 /* ConstructorType */: + case 196 /* ParenthesizedType */: + case 215 /* TaggedTemplateExpression */: + case 223 /* AwaitExpression */: + case 279 /* NamedExports */: + case 275 /* NamedImports */: + case 281 /* ExportSpecifier */: + case 276 /* ImportSpecifier */: + case 172 /* PropertyDeclaration */: + case 296 /* CaseClause */: + case 297 /* DefaultClause */: + return true; + case 269 /* CaseBlock */: + return settings.indentSwitchCase ?? true; + case 260 /* VariableDeclaration */: + case 303 /* PropertyAssignment */: + case 226 /* BinaryExpression */: + if (!settings.indentMultiLineObjectLiteralBeginningOnBlankLine && sourceFile && childKind === 210 /* ObjectLiteralExpression */) { + return rangeIsOnOneLine(sourceFile, child); + } + if (parent2.kind === 226 /* BinaryExpression */ && sourceFile && child && childKind === 284 /* JsxElement */) { + const parentStartLine = sourceFile.getLineAndCharacterOfPosition(skipTrivia(sourceFile.text, parent2.pos)).line; + const childStartLine = sourceFile.getLineAndCharacterOfPosition(skipTrivia(sourceFile.text, child.pos)).line; + return parentStartLine !== childStartLine; + } + if (parent2.kind !== 226 /* BinaryExpression */) { + return true; + } + break; + case 246 /* DoStatement */: + case 247 /* WhileStatement */: + case 249 /* ForInStatement */: + case 250 /* ForOfStatement */: + case 248 /* ForStatement */: + case 245 /* IfStatement */: + case 262 /* FunctionDeclaration */: + case 218 /* FunctionExpression */: + case 174 /* MethodDeclaration */: + case 176 /* Constructor */: + case 177 /* GetAccessor */: + case 178 /* SetAccessor */: + return childKind !== 241 /* Block */; + case 219 /* ArrowFunction */: + if (sourceFile && childKind === 217 /* ParenthesizedExpression */) { + return rangeIsOnOneLine(sourceFile, child); + } + return childKind !== 241 /* Block */; + case 278 /* ExportDeclaration */: + return childKind !== 279 /* NamedExports */; + case 272 /* ImportDeclaration */: + return childKind !== 273 /* ImportClause */ || !!child.namedBindings && child.namedBindings.kind !== 275 /* NamedImports */; + case 284 /* JsxElement */: + return childKind !== 287 /* JsxClosingElement */; + case 288 /* JsxFragment */: + return childKind !== 290 /* JsxClosingFragment */; + case 193 /* IntersectionType */: + case 192 /* UnionType */: + if (childKind === 187 /* TypeLiteral */ || childKind === 189 /* TupleType */) { + return false; + } + break; + } + return indentByDefault; + } + SmartIndenter2.nodeWillIndentChild = nodeWillIndentChild; + function isControlFlowEndingStatement(kind, parent2) { + switch (kind) { + case 253 /* ReturnStatement */: + case 257 /* ThrowStatement */: + case 251 /* ContinueStatement */: + case 252 /* BreakStatement */: + return parent2.kind !== 241 /* Block */; + default: + return false; + } + } + function shouldIndentChildNode(settings, parent2, child, sourceFile, isNextChild = false) { + return nodeWillIndentChild( + settings, + parent2, + child, + sourceFile, + /*indentByDefault*/ + false + ) && !(isNextChild && child && isControlFlowEndingStatement(child.kind, parent2)); + } + SmartIndenter2.shouldIndentChildNode = shouldIndentChildNode; + function rangeIsOnOneLine(sourceFile, range) { + const rangeStart = skipTrivia(sourceFile.text, range.pos); + const startLine = sourceFile.getLineAndCharacterOfPosition(rangeStart).line; + const endLine = sourceFile.getLineAndCharacterOfPosition(range.end).line; + return startLine === endLine; + } + })(SmartIndenter || (SmartIndenter = {})); } - function spanForNodeArray(nodeArray) { - return nodeArray.length ? createOutliningSpan(createTextSpanFromRange(nodeArray), "code" /* Code */) : void 0; + }); + + // src/services/_namespaces/ts.formatting.ts + var ts_formatting_exports = {}; + __export(ts_formatting_exports, { + FormattingContext: () => FormattingContext, + FormattingRequestKind: () => FormattingRequestKind, + RuleAction: () => RuleAction, + RuleFlags: () => RuleFlags, + SmartIndenter: () => SmartIndenter, + anyContext: () => anyContext, + createTextRangeWithKind: () => createTextRangeWithKind, + formatDocument: () => formatDocument, + formatNodeGivenIndentation: () => formatNodeGivenIndentation, + formatOnClosingCurly: () => formatOnClosingCurly, + formatOnEnter: () => formatOnEnter, + formatOnOpeningCurly: () => formatOnOpeningCurly, + formatOnSemicolon: () => formatOnSemicolon, + formatSelection: () => formatSelection, + getAllRules: () => getAllRules, + getFormatContext: () => getFormatContext, + getFormattingScanner: () => getFormattingScanner, + getIndentationString: () => getIndentationString, + getRangeOfEnclosingComment: () => getRangeOfEnclosingComment + }); + var init_ts_formatting = __esm({ + "src/services/_namespaces/ts.formatting.ts"() { + "use strict"; + init_formattingContext(); + init_formattingScanner(); + init_rule(); + init_rules(); + init_rulesMap(); + init_formatting(); + init_smartIndenter(); } - function spanForParenthesizedExpression(node) { - if (positionsAreOnSameLine(node.getStart(), node.getEnd(), sourceFile)) - return void 0; - const textSpan = createTextSpanFromBounds(node.getStart(), node.getEnd()); - return createOutliningSpan(textSpan, "code" /* Code */, createTextSpanFromNode(node)); + }); + + // src/services/_namespaces/ts.ts + var init_ts4 = __esm({ + "src/services/_namespaces/ts.ts"() { + "use strict"; + init_ts2(); + init_ts3(); + init_types3(); + init_utilities4(); + init_exportInfoMap(); + init_classifier(); + init_documentHighlights(); + init_documentRegistry(); + init_getEditsForFileRename(); + init_patternMatcher(); + init_preProcess(); + init_sourcemaps(); + init_suggestionDiagnostics(); + init_transpile(); + init_services(); + init_transform(); + init_ts_BreakpointResolver(); + init_ts_CallHierarchy(); + init_ts_classifier(); + init_ts_codefix(); + init_ts_Completions(); + init_ts_FindAllReferences(); + init_ts_GoToDefinition(); + init_ts_InlayHints(); + init_ts_JsDoc(); + init_ts_NavigateTo(); + init_ts_NavigationBar(); + init_ts_OrganizeImports(); + init_ts_OutliningElementsCollector(); + init_ts_refactor(); + init_ts_Rename(); + init_ts_SignatureHelp(); + init_ts_SmartSelectionRange(); + init_ts_SymbolDisplay(); + init_ts_textChanges(); + init_ts_formatting(); } + }); + + // src/deprecatedCompat/deprecate.ts + function getTypeScriptVersion() { + return typeScriptVersion2 ?? (typeScriptVersion2 = new Version(version)); } - function functionSpan(node, body, sourceFile) { - const openToken = tryGetFunctionOpenToken(node, body, sourceFile); - const closeToken = findChildOfKind(body, 20 /* CloseBraceToken */, sourceFile); - return openToken && closeToken && spanBetweenTokens( - openToken, - closeToken, - node, - sourceFile, - /*autoCollapse*/ - node.kind !== 218 /* ArrowFunction */ + function formatDeprecationMessage(name, error2, errorAfter, since, message) { + let deprecationMessage = error2 ? "DeprecationError: " : "DeprecationWarning: "; + deprecationMessage += `'${name}' `; + deprecationMessage += since ? `has been deprecated since v${since}` : "is deprecated"; + deprecationMessage += error2 ? " and can no longer be used." : errorAfter ? ` and will no longer be usable after v${errorAfter}.` : "."; + deprecationMessage += message ? ` ${formatStringFromArgs(message, [name])}` : ""; + return deprecationMessage; + } + function createErrorDeprecation(name, errorAfter, since, message) { + const deprecationMessage = formatDeprecationMessage( + name, + /*error*/ + true, + errorAfter, + since, + message ); + return () => { + throw new TypeError(deprecationMessage); + }; } - function spanBetweenTokens(openToken, closeToken, hintSpanNode, sourceFile, autoCollapse = false, useFullStart = true) { - const textSpan = createTextSpanFromBounds(useFullStart ? openToken.getFullStart() : openToken.getStart(sourceFile), closeToken.getEnd()); - return createOutliningSpan(textSpan, "code" /* Code */, createTextSpanFromNode(hintSpanNode, sourceFile), autoCollapse); + function createWarningDeprecation(name, errorAfter, since, message) { + let hasWrittenDeprecation = false; + return () => { + if (enableDeprecationWarnings && !hasWrittenDeprecation) { + Debug.log.warn(formatDeprecationMessage( + name, + /*error*/ + false, + errorAfter, + since, + message + )); + hasWrittenDeprecation = true; + } + }; + } + function createDeprecation(name, options = {}) { + const version2 = typeof options.typeScriptVersion === "string" ? new Version(options.typeScriptVersion) : options.typeScriptVersion ?? getTypeScriptVersion(); + const errorAfter = typeof options.errorAfter === "string" ? new Version(options.errorAfter) : options.errorAfter; + const warnAfter = typeof options.warnAfter === "string" ? new Version(options.warnAfter) : options.warnAfter; + const since = typeof options.since === "string" ? new Version(options.since) : options.since ?? warnAfter; + const error2 = options.error || errorAfter && version2.compareTo(errorAfter) >= 0; + const warn = !warnAfter || version2.compareTo(warnAfter) >= 0; + return error2 ? createErrorDeprecation(name, errorAfter, since, options.message) : warn ? createWarningDeprecation(name, errorAfter, since, options.message) : noop; } - function createOutliningSpan(textSpan, kind, hintSpan = textSpan, autoCollapse = false, bannerText = "...") { - return { textSpan, kind, hintSpan, bannerText, autoCollapse }; + function wrapFunction(deprecation, func) { + return function() { + deprecation(); + return func.apply(this, arguments); + }; } - function tryGetFunctionOpenToken(node, body, sourceFile) { - if (isNodeArrayMultiLine(node.parameters, sourceFile)) { - const openParenToken = findChildOfKind(node, 21 /* OpenParenToken */, sourceFile); - if (openParenToken) { - return openParenToken; - } - } - return findChildOfKind(body, 19 /* OpenBraceToken */, sourceFile); + function deprecate(func, options) { + const deprecation = createDeprecation((options == null ? void 0 : options.name) ?? Debug.getFunctionName(func), options); + return wrapFunction(deprecation, func); } - var regionDelimiterRegExp; - var init_outliningElementsCollector = __esm({ - "src/services/outliningElementsCollector.ts"() { - "use strict"; - init_ts4(); - regionDelimiterRegExp = /^#(end)?region(?:\s+(.*))?(?:\r)?$/; - } - }); - - // src/services/_namespaces/ts.OutliningElementsCollector.ts - var ts_OutliningElementsCollector_exports = {}; - __export(ts_OutliningElementsCollector_exports, { - collectElements: () => collectElements - }); - var init_ts_OutliningElementsCollector = __esm({ - "src/services/_namespaces/ts.OutliningElementsCollector.ts"() { + var enableDeprecationWarnings, typeScriptVersion2; + var init_deprecate = __esm({ + "src/deprecatedCompat/deprecate.ts"() { "use strict"; - init_outliningElementsCollector(); + init_ts5(); + enableDeprecationWarnings = true; } }); - // src/services/rename.ts - function getRenameInfo(program, sourceFile, position, preferences) { - const node = getAdjustedRenameLocation(getTouchingPropertyName(sourceFile, position)); - if (nodeIsEligibleForRename(node)) { - const renameInfo = getRenameInfoForNode(node, program.getTypeChecker(), sourceFile, program, preferences); - if (renameInfo) { - return renameInfo; - } - } - return getRenameInfoError(Diagnostics.You_cannot_rename_this_element); - } - function getRenameInfoForNode(node, typeChecker, sourceFile, program, preferences) { - const symbol = typeChecker.getSymbolAtLocation(node); - if (!symbol) { - if (isStringLiteralLike(node)) { - const type = getContextualTypeFromParentOrAncestorTypeNode(node, typeChecker); - if (type && (type.flags & 128 /* StringLiteral */ || type.flags & 1048576 /* Union */ && every(type.types, (type2) => !!(type2.flags & 128 /* StringLiteral */)))) { - return getRenameInfoSuccess(node.text, node.text, "string" /* string */, "", node, sourceFile); + // src/deprecatedCompat/deprecations.ts + function createOverload(name, overloads, binder2, deprecations) { + Object.defineProperty(call, "name", { ...Object.getOwnPropertyDescriptor(call, "name"), value: name }); + if (deprecations) { + for (const key of Object.keys(deprecations)) { + const index = +key; + if (!isNaN(index) && hasProperty(overloads, `${index}`)) { + overloads[index] = deprecate(overloads[index], { ...deprecations[index], name }); } - } else if (isLabelName(node)) { - const name = getTextOfNode(node); - return getRenameInfoSuccess(name, name, "label" /* label */, "" /* none */, node, sourceFile); - } - return void 0; - } - const { declarations } = symbol; - if (!declarations || declarations.length === 0) - return; - if (declarations.some((declaration) => isDefinedInLibraryFile(program, declaration))) { - return getRenameInfoError(Diagnostics.You_cannot_rename_elements_that_are_defined_in_the_standard_TypeScript_library); - } - if (isIdentifier(node) && node.escapedText === "default" && symbol.parent && symbol.parent.flags & 1536 /* Module */) { - return void 0; - } - if (isStringLiteralLike(node) && tryGetImportFromModuleSpecifier(node)) { - return preferences.allowRenameOfImportPath ? getRenameInfoForModule(node, sourceFile, symbol) : void 0; - } - const wouldRenameNodeModules = wouldRenameInOtherNodeModules(sourceFile, symbol, typeChecker, preferences); - if (wouldRenameNodeModules) { - return getRenameInfoError(wouldRenameNodeModules); - } - const kind = ts_SymbolDisplay_exports.getSymbolKind(typeChecker, symbol, node); - const specifierName = isImportOrExportSpecifierName(node) || isStringOrNumericLiteralLike(node) && node.parent.kind === 166 /* ComputedPropertyName */ ? stripQuotes(getTextOfIdentifierOrLiteral(node)) : void 0; - const displayName = specifierName || typeChecker.symbolToString(symbol); - const fullDisplayName = specifierName || typeChecker.getFullyQualifiedName(symbol); - return getRenameInfoSuccess(displayName, fullDisplayName, kind, ts_SymbolDisplay_exports.getSymbolModifiers(typeChecker, symbol), node, sourceFile); - } - function isDefinedInLibraryFile(program, declaration) { - const sourceFile = declaration.getSourceFile(); - return program.isSourceFileDefaultLibrary(sourceFile) && fileExtensionIs(sourceFile.fileName, ".d.ts" /* Dts */); - } - function wouldRenameInOtherNodeModules(originalFile, symbol, checker, preferences) { - if (!preferences.providePrefixAndSuffixTextForRename && symbol.flags & 2097152 /* Alias */) { - const importSpecifier = symbol.declarations && find(symbol.declarations, (decl) => isImportSpecifier(decl)); - if (importSpecifier && !importSpecifier.propertyName) { - symbol = checker.getAliasedSymbol(symbol); } } - const { declarations } = symbol; - if (!declarations) { - return void 0; - } - const originalPackage = getPackagePathComponents(originalFile.path); - if (originalPackage === void 0) { - if (some(declarations, (declaration) => isInsideNodeModules(declaration.getSourceFile().path))) { - return Diagnostics.You_cannot_rename_elements_that_are_defined_in_a_node_modules_folder; - } else { - return void 0; + const bind = createBinder2(overloads, binder2); + return call; + function call(...args) { + const index = bind(args); + const fn = index !== void 0 ? overloads[index] : void 0; + if (typeof fn === "function") { + return fn(...args); } + throw new TypeError("Invalid arguments"); } - for (const declaration of declarations) { - const declPackage = getPackagePathComponents(declaration.getSourceFile().path); - if (declPackage) { - const length2 = Math.min(originalPackage.length, declPackage.length); - for (let i = 0; i <= length2; i++) { - if (compareStringsCaseSensitive(originalPackage[i], declPackage[i]) !== 0 /* EqualTo */) { - return Diagnostics.You_cannot_rename_elements_that_are_defined_in_another_node_modules_folder; - } + } + function createBinder2(overloads, binder2) { + return (args) => { + for (let i = 0; hasProperty(overloads, `${i}`) && hasProperty(binder2, `${i}`); i++) { + const fn = binder2[i]; + if (fn(args)) { + return i; } } - } - return void 0; - } - function getPackagePathComponents(filePath) { - const components = getPathComponents(filePath); - const nodeModulesIdx = components.lastIndexOf("node_modules"); - if (nodeModulesIdx === -1) { - return void 0; - } - return components.slice(0, nodeModulesIdx + 2); - } - function getRenameInfoForModule(node, sourceFile, moduleSymbol) { - if (!isExternalModuleNameRelative(node.text)) { - return getRenameInfoError(Diagnostics.You_cannot_rename_a_module_via_a_global_import); - } - const moduleSourceFile = moduleSymbol.declarations && find(moduleSymbol.declarations, isSourceFile); - if (!moduleSourceFile) - return void 0; - const withoutIndex = endsWith(node.text, "/index") || endsWith(node.text, "/index.js") ? void 0 : tryRemoveSuffix(removeFileExtension(moduleSourceFile.fileName), "/index"); - const name = withoutIndex === void 0 ? moduleSourceFile.fileName : withoutIndex; - const kind = withoutIndex === void 0 ? "module" /* moduleElement */ : "directory" /* directory */; - const indexAfterLastSlash = node.text.lastIndexOf("/") + 1; - const triggerSpan = createTextSpan(node.getStart(sourceFile) + 1 + indexAfterLastSlash, node.text.length - indexAfterLastSlash); - return { - canRename: true, - fileToRename: name, - kind, - displayName: name, - fullDisplayName: name, - kindModifiers: "" /* none */, - triggerSpan }; } - function getRenameInfoSuccess(displayName, fullDisplayName, kind, kindModifiers, node, sourceFile) { + function buildOverload(name) { return { - canRename: true, - fileToRename: void 0, - kind, - displayName, - fullDisplayName, - kindModifiers, - triggerSpan: createTriggerSpanForNode(node, sourceFile) + overload: (overloads) => ({ + bind: (binder2) => ({ + finish: () => createOverload(name, overloads, binder2), + deprecate: (deprecations) => ({ + finish: () => createOverload(name, overloads, binder2, deprecations) + }) + }) + }) }; } - function getRenameInfoError(diagnostic) { - return { canRename: false, localizedErrorMessage: getLocaleSpecificMessage(diagnostic) }; - } - function createTriggerSpanForNode(node, sourceFile) { - let start = node.getStart(sourceFile); - let width = node.getWidth(sourceFile); - if (isStringLiteralLike(node)) { - start += 1; - width -= 2; - } - return createTextSpan(start, width); - } - function nodeIsEligibleForRename(node) { - switch (node.kind) { - case 80 /* Identifier */: - case 81 /* PrivateIdentifier */: - case 11 /* StringLiteral */: - case 15 /* NoSubstitutionTemplateLiteral */: - case 110 /* ThisKeyword */: - return true; - case 9 /* NumericLiteral */: - return isLiteralNameOfPropertyDeclarationOrIndexAccess(node); - default: - return false; - } - } - var init_rename = __esm({ - "src/services/rename.ts"() { + var init_deprecations = __esm({ + "src/deprecatedCompat/deprecations.ts"() { "use strict"; - init_ts4(); + init_ts5(); + init_deprecate(); } }); - // src/services/_namespaces/ts.Rename.ts - var ts_Rename_exports = {}; - __export(ts_Rename_exports, { - getRenameInfo: () => getRenameInfo, - nodeIsEligibleForRename: () => nodeIsEligibleForRename - }); - var init_ts_Rename = __esm({ - "src/services/_namespaces/ts.Rename.ts"() { + // src/deprecatedCompat/5.0/identifierProperties.ts + var init_identifierProperties = __esm({ + "src/deprecatedCompat/5.0/identifierProperties.ts"() { "use strict"; - init_rename(); + init_ts5(); + init_deprecate(); + addObjectAllocatorPatcher((objectAllocator2) => { + const Identifier78 = objectAllocator2.getIdentifierConstructor(); + if (!hasProperty(Identifier78.prototype, "originalKeywordKind")) { + Object.defineProperty(Identifier78.prototype, "originalKeywordKind", { + get: deprecate(function() { + return identifierToKeywordKind(this); + }, { + name: "originalKeywordKind", + since: "5.0", + warnAfter: "5.1", + errorAfter: "5.2", + message: "Use 'identifierToKeywordKind(identifier)' instead." + }) + }); + } + if (!hasProperty(Identifier78.prototype, "isInJSDocNamespace")) { + Object.defineProperty(Identifier78.prototype, "isInJSDocNamespace", { + get: deprecate(function() { + return this.flags & 4096 /* IdentifierIsInJSDocNamespace */ ? true : void 0; + }, { + name: "isInJSDocNamespace", + since: "5.0", + warnAfter: "5.1", + errorAfter: "5.2", + message: "Use '.parent' or the surrounding context to determine this instead." + }) + }); + } + }); } }); - // src/services/signatureHelp.ts - function getSignatureHelpItems(program, sourceFile, position, triggerReason, cancellationToken) { - const typeChecker = program.getTypeChecker(); - const startingToken = findTokenOnLeftOfPosition(sourceFile, position); - if (!startingToken) { - return void 0; + // src/deprecatedCompat/_namespaces/ts.ts + var init_ts5 = __esm({ + "src/deprecatedCompat/_namespaces/ts.ts"() { + "use strict"; + init_ts2(); + init_deprecations(); + init_identifierProperties(); } - const onlyUseSyntacticOwners = !!triggerReason && triggerReason.kind === "characterTyped"; - if (onlyUseSyntacticOwners && (isInString(sourceFile, position, startingToken) || isInComment(sourceFile, position))) { - return void 0; + }); + + // src/typingsInstallerCore/_namespaces/ts.ts + var init_ts6 = __esm({ + "src/typingsInstallerCore/_namespaces/ts.ts"() { + "use strict"; + init_ts2(); + init_ts3(); + init_ts_server2(); } - const isManuallyInvoked = !!triggerReason && triggerReason.kind === "invoked"; - const argumentInfo = getContainingArgumentInfo(startingToken, position, sourceFile, typeChecker, isManuallyInvoked); - if (!argumentInfo) + }); + + // src/typingsInstallerCore/typingsInstaller.ts + function typingToFileName(cachePath, packageName, installTypingHost, log) { + try { + const result = resolveModuleName(packageName, combinePaths(cachePath, "index.d.ts"), { moduleResolution: 2 /* Node10 */ }, installTypingHost); + return result.resolvedModule && result.resolvedModule.resolvedFileName; + } catch (e) { + if (log.isEnabled()) { + log.writeLine(`Failed to resolve ${packageName} in folder '${cachePath}': ${e.message}`); + } return void 0; - cancellationToken.throwIfCancellationRequested(); - const candidateInfo = getCandidateOrTypeInfo(argumentInfo, typeChecker, sourceFile, startingToken, onlyUseSyntacticOwners); - cancellationToken.throwIfCancellationRequested(); - if (!candidateInfo) { - return isSourceFileJS(sourceFile) ? createJSSignatureHelpItems(argumentInfo, program, cancellationToken) : void 0; } - return typeChecker.runWithCancellationToken(cancellationToken, (typeChecker2) => candidateInfo.kind === 0 /* Candidate */ ? createSignatureHelpItems(candidateInfo.candidates, candidateInfo.resolvedSignature, argumentInfo, sourceFile, typeChecker2) : createTypeHelpItems(candidateInfo.symbol, argumentInfo, sourceFile, typeChecker2)); } - function getCandidateOrTypeInfo({ invocation, argumentCount }, checker, sourceFile, startingToken, onlyUseSyntacticOwners) { - switch (invocation.kind) { - case 0 /* Call */: { - if (onlyUseSyntacticOwners && !isSyntacticOwner(startingToken, invocation.node, sourceFile)) { - return void 0; - } - const candidates = []; - const resolvedSignature = checker.getResolvedSignatureForSignatureHelp(invocation.node, candidates, argumentCount); - return candidates.length === 0 ? void 0 : { kind: 0 /* Candidate */, candidates, resolvedSignature }; - } - case 1 /* TypeArgs */: { - const { called } = invocation; - if (onlyUseSyntacticOwners && !containsPrecedingToken(startingToken, sourceFile, isIdentifier(called) ? called.parent : called)) { - return void 0; - } - const candidates = getPossibleGenericSignatures(called, argumentCount, checker); - if (candidates.length !== 0) - return { kind: 0 /* Candidate */, candidates, resolvedSignature: first(candidates) }; - const symbol = checker.getSymbolAtLocation(called); - return symbol && { kind: 1 /* Type */, symbol }; - } - case 2 /* Contextual */: - return { kind: 0 /* Candidate */, candidates: [invocation.signature], resolvedSignature: invocation.signature }; - default: - return Debug.assertNever(invocation); + function installNpmPackages(npmPath, tsVersion, packageNames, install) { + let hasError = false; + for (let remaining = packageNames.length; remaining > 0; ) { + const result = getNpmCommandForInstallation(npmPath, tsVersion, packageNames, remaining); + remaining = result.remaining; + hasError = install(result.command) || hasError; } + return hasError; } - function isSyntacticOwner(startingToken, node, sourceFile) { - if (!isCallOrNewExpression(node)) - return false; - const invocationChildren = node.getChildren(sourceFile); - switch (startingToken.kind) { - case 21 /* OpenParenToken */: - return contains(invocationChildren, startingToken); - case 28 /* CommaToken */: { - const containingList = findContainingList(startingToken); - return !!containingList && contains(invocationChildren, containingList); + function getNpmCommandForInstallation(npmPath, tsVersion, packageNames, remaining) { + const sliceStart = packageNames.length - remaining; + let command, toSlice = remaining; + while (true) { + command = `${npmPath} install --ignore-scripts ${(toSlice === packageNames.length ? packageNames : packageNames.slice(sliceStart, sliceStart + toSlice)).join(" ")} --save-dev --user-agent="typesInstaller/${tsVersion}"`; + if (command.length < 8e3) { + break; } - case 30 /* LessThanToken */: - return containsPrecedingToken(startingToken, sourceFile, node.expression); - default: - return false; + toSlice = toSlice - Math.floor(toSlice / 2); } + return { command, remaining: remaining - toSlice }; } - function createJSSignatureHelpItems(argumentInfo, program, cancellationToken) { - if (argumentInfo.invocation.kind === 2 /* Contextual */) - return void 0; - const expression = getExpressionFromInvocation(argumentInfo.invocation); - const name = isPropertyAccessExpression(expression) ? expression.name.text : void 0; - const typeChecker = program.getTypeChecker(); - return name === void 0 ? void 0 : firstDefined(program.getSourceFiles(), (sourceFile) => firstDefined(sourceFile.getNamedDeclarations().get(name), (declaration) => { - const type = declaration.symbol && typeChecker.getTypeOfSymbolAtLocation(declaration.symbol, declaration); - const callSignatures = type && type.getCallSignatures(); - if (callSignatures && callSignatures.length) { - return typeChecker.runWithCancellationToken( - cancellationToken, - (typeChecker2) => createSignatureHelpItems( - callSignatures, - callSignatures[0], - argumentInfo, - sourceFile, - typeChecker2, - /*useFullPrefix*/ - true - ) - ); - } - })); + function typingsName(packageName) { + return `@types/${packageName}@ts${versionMajorMinor}`; } - function containsPrecedingToken(startingToken, sourceFile, container) { - const pos = startingToken.getFullStart(); - let currentParent = startingToken.parent; - while (currentParent) { - const precedingToken = findPrecedingToken( - pos, - sourceFile, - currentParent, - /*excludeJsdoc*/ - true - ); - if (precedingToken) { - return rangeContainsRange(container, precedingToken); - } - currentParent = currentParent.parent; + var nullLog, TypingsInstaller; + var init_typingsInstaller = __esm({ + "src/typingsInstallerCore/typingsInstaller.ts"() { + "use strict"; + init_ts6(); + init_ts_server2(); + nullLog = { + isEnabled: () => false, + writeLine: noop + }; + TypingsInstaller = class { + constructor(installTypingHost, globalCachePath, safeListPath, typesMapLocation, throttleLimit, log = nullLog) { + this.installTypingHost = installTypingHost; + this.globalCachePath = globalCachePath; + this.safeListPath = safeListPath; + this.typesMapLocation = typesMapLocation; + this.throttleLimit = throttleLimit; + this.log = log; + this.packageNameToTypingLocation = /* @__PURE__ */ new Map(); + this.missingTypingsSet = /* @__PURE__ */ new Set(); + this.knownCachesSet = /* @__PURE__ */ new Set(); + this.projectWatchers = /* @__PURE__ */ new Map(); + /** @internal */ + this.pendingRunRequests = []; + this.installRunCount = 1; + this.inFlightRequestCount = 0; + this.latestDistTag = "latest"; + const isLoggingEnabled = this.log.isEnabled(); + if (isLoggingEnabled) { + this.log.writeLine(`Global cache location '${globalCachePath}', safe file path '${safeListPath}', types map path ${typesMapLocation}`); + } + this.processCacheLocation(this.globalCachePath); + } + closeProject(req) { + this.closeWatchers(req.projectName); + } + closeWatchers(projectName) { + if (this.log.isEnabled()) { + this.log.writeLine(`Closing file watchers for project '${projectName}'`); + } + const watchers = this.projectWatchers.get(projectName); + if (!watchers) { + if (this.log.isEnabled()) { + this.log.writeLine(`No watchers are registered for project '${projectName}'`); + } + return; + } + this.projectWatchers.delete(projectName); + this.sendResponse({ kind: ActionWatchTypingLocations, projectName, files: [] }); + if (this.log.isEnabled()) { + this.log.writeLine(`Closing file watchers for project '${projectName}' - done.`); + } + } + install(req) { + if (this.log.isEnabled()) { + this.log.writeLine(`Got install request${stringifyIndented(req)}`); + } + if (req.cachePath) { + if (this.log.isEnabled()) { + this.log.writeLine(`Request specifies cache path '${req.cachePath}', loading cached information...`); + } + this.processCacheLocation(req.cachePath); + } + if (this.safeList === void 0) { + this.initializeSafeList(); + } + const discoverTypingsResult = ts_JsTyping_exports.discoverTypings( + this.installTypingHost, + this.log.isEnabled() ? (s) => this.log.writeLine(s) : void 0, + req.fileNames, + req.projectRootPath, + this.safeList, + this.packageNameToTypingLocation, + req.typeAcquisition, + req.unresolvedImports, + this.typesRegistry, + req.compilerOptions + ); + this.watchFiles(req.projectName, discoverTypingsResult.filesToWatch); + if (discoverTypingsResult.newTypingNames.length) { + this.installTypings(req, req.cachePath || this.globalCachePath, discoverTypingsResult.cachedTypingPaths, discoverTypingsResult.newTypingNames); + } else { + this.sendResponse(this.createSetTypings(req, discoverTypingsResult.cachedTypingPaths)); + if (this.log.isEnabled()) { + this.log.writeLine(`No new typings were requested as a result of typings discovery`); + } + } + } + initializeSafeList() { + if (this.typesMapLocation) { + const safeListFromMap = ts_JsTyping_exports.loadTypesMap(this.installTypingHost, this.typesMapLocation); + if (safeListFromMap) { + this.log.writeLine(`Loaded safelist from types map file '${this.typesMapLocation}'`); + this.safeList = safeListFromMap; + return; + } + this.log.writeLine(`Failed to load safelist from types map file '${this.typesMapLocation}'`); + } + this.safeList = ts_JsTyping_exports.loadSafeList(this.installTypingHost, this.safeListPath); + } + processCacheLocation(cacheLocation) { + if (this.log.isEnabled()) { + this.log.writeLine(`Processing cache location '${cacheLocation}'`); + } + if (this.knownCachesSet.has(cacheLocation)) { + if (this.log.isEnabled()) { + this.log.writeLine(`Cache location was already processed...`); + } + return; + } + const packageJson = combinePaths(cacheLocation, "package.json"); + const packageLockJson = combinePaths(cacheLocation, "package-lock.json"); + if (this.log.isEnabled()) { + this.log.writeLine(`Trying to find '${packageJson}'...`); + } + if (this.installTypingHost.fileExists(packageJson) && this.installTypingHost.fileExists(packageLockJson)) { + const npmConfig = JSON.parse(this.installTypingHost.readFile(packageJson)); + const npmLock = JSON.parse(this.installTypingHost.readFile(packageLockJson)); + if (this.log.isEnabled()) { + this.log.writeLine(`Loaded content of '${packageJson}':${stringifyIndented(npmConfig)}`); + this.log.writeLine(`Loaded content of '${packageLockJson}':${stringifyIndented(npmLock)}`); + } + if (npmConfig.devDependencies && npmLock.dependencies) { + for (const key in npmConfig.devDependencies) { + if (!hasProperty(npmLock.dependencies, key)) { + continue; + } + const packageName = getBaseFileName(key); + if (!packageName) { + continue; + } + const typingFile = typingToFileName(cacheLocation, packageName, this.installTypingHost, this.log); + if (!typingFile) { + this.missingTypingsSet.add(packageName); + continue; + } + const existingTypingFile = this.packageNameToTypingLocation.get(packageName); + if (existingTypingFile) { + if (existingTypingFile.typingLocation === typingFile) { + continue; + } + if (this.log.isEnabled()) { + this.log.writeLine(`New typing for package ${packageName} from '${typingFile}' conflicts with existing typing file '${existingTypingFile}'`); + } + } + if (this.log.isEnabled()) { + this.log.writeLine(`Adding entry into typings cache: '${packageName}' => '${typingFile}'`); + } + const info = getProperty(npmLock.dependencies, key); + const version2 = info && info.version; + if (!version2) { + continue; + } + const newTyping = { typingLocation: typingFile, version: new Version(version2) }; + this.packageNameToTypingLocation.set(packageName, newTyping); + } + } + } + if (this.log.isEnabled()) { + this.log.writeLine(`Finished processing cache location '${cacheLocation}'`); + } + this.knownCachesSet.add(cacheLocation); + } + filterTypings(typingsToInstall) { + return mapDefined(typingsToInstall, (typing) => { + const typingKey = mangleScopedPackageName(typing); + if (this.missingTypingsSet.has(typingKey)) { + if (this.log.isEnabled()) + this.log.writeLine(`'${typing}':: '${typingKey}' is in missingTypingsSet - skipping...`); + return void 0; + } + const validationResult = ts_JsTyping_exports.validatePackageName(typing); + if (validationResult !== ts_JsTyping_exports.NameValidationResult.Ok) { + this.missingTypingsSet.add(typingKey); + if (this.log.isEnabled()) + this.log.writeLine(ts_JsTyping_exports.renderPackageNameValidationFailure(validationResult, typing)); + return void 0; + } + if (!this.typesRegistry.has(typingKey)) { + if (this.log.isEnabled()) + this.log.writeLine(`'${typing}':: Entry for package '${typingKey}' does not exist in local types registry - skipping...`); + return void 0; + } + if (this.packageNameToTypingLocation.get(typingKey) && ts_JsTyping_exports.isTypingUpToDate(this.packageNameToTypingLocation.get(typingKey), this.typesRegistry.get(typingKey))) { + if (this.log.isEnabled()) + this.log.writeLine(`'${typing}':: '${typingKey}' already has an up-to-date typing - skipping...`); + return void 0; + } + return typingKey; + }); + } + ensurePackageDirectoryExists(directory) { + const npmConfigPath = combinePaths(directory, "package.json"); + if (this.log.isEnabled()) { + this.log.writeLine(`Npm config file: ${npmConfigPath}`); + } + if (!this.installTypingHost.fileExists(npmConfigPath)) { + if (this.log.isEnabled()) { + this.log.writeLine(`Npm config file: '${npmConfigPath}' is missing, creating new one...`); + } + this.ensureDirectoryExists(directory, this.installTypingHost); + this.installTypingHost.writeFile(npmConfigPath, '{ "private": true }'); + } + } + installTypings(req, cachePath, currentlyCachedTypings, typingsToInstall) { + if (this.log.isEnabled()) { + this.log.writeLine(`Installing typings ${JSON.stringify(typingsToInstall)}`); + } + const filteredTypings = this.filterTypings(typingsToInstall); + if (filteredTypings.length === 0) { + if (this.log.isEnabled()) { + this.log.writeLine(`All typings are known to be missing or invalid - no need to install more typings`); + } + this.sendResponse(this.createSetTypings(req, currentlyCachedTypings)); + return; + } + this.ensurePackageDirectoryExists(cachePath); + const requestId = this.installRunCount; + this.installRunCount++; + this.sendResponse({ + kind: EventBeginInstallTypes, + eventId: requestId, + typingsInstallerVersion: version, + projectName: req.projectName + }); + const scopedTypings = filteredTypings.map(typingsName); + this.installTypingsAsync(requestId, scopedTypings, cachePath, (ok) => { + try { + if (!ok) { + if (this.log.isEnabled()) { + this.log.writeLine(`install request failed, marking packages as missing to prevent repeated requests: ${JSON.stringify(filteredTypings)}`); + } + for (const typing of filteredTypings) { + this.missingTypingsSet.add(typing); + } + return; + } + if (this.log.isEnabled()) { + this.log.writeLine(`Installed typings ${JSON.stringify(scopedTypings)}`); + } + const installedTypingFiles = []; + for (const packageName of filteredTypings) { + const typingFile = typingToFileName(cachePath, packageName, this.installTypingHost, this.log); + if (!typingFile) { + this.missingTypingsSet.add(packageName); + continue; + } + const distTags = this.typesRegistry.get(packageName); + const newVersion = new Version(distTags[`ts${versionMajorMinor}`] || distTags[this.latestDistTag]); + const newTyping = { typingLocation: typingFile, version: newVersion }; + this.packageNameToTypingLocation.set(packageName, newTyping); + installedTypingFiles.push(typingFile); + } + if (this.log.isEnabled()) { + this.log.writeLine(`Installed typing files ${JSON.stringify(installedTypingFiles)}`); + } + this.sendResponse(this.createSetTypings(req, currentlyCachedTypings.concat(installedTypingFiles))); + } finally { + const response = { + kind: EventEndInstallTypes, + eventId: requestId, + projectName: req.projectName, + packagesToInstall: scopedTypings, + installSuccess: ok, + typingsInstallerVersion: version + }; + this.sendResponse(response); + } + }); + } + ensureDirectoryExists(directory, host) { + const directoryName = getDirectoryPath(directory); + if (!host.directoryExists(directoryName)) { + this.ensureDirectoryExists(directoryName, host); + } + if (!host.directoryExists(directory)) { + host.createDirectory(directory); + } + } + watchFiles(projectName, files) { + if (!files.length) { + this.closeWatchers(projectName); + return; + } + const existing = this.projectWatchers.get(projectName); + const newSet = new Set(files); + if (!existing || forEachKey(newSet, (s) => !existing.has(s)) || forEachKey(existing, (s) => !newSet.has(s))) { + this.projectWatchers.set(projectName, newSet); + this.sendResponse({ kind: ActionWatchTypingLocations, projectName, files }); + } else { + this.sendResponse({ kind: ActionWatchTypingLocations, projectName, files: void 0 }); + } + } + createSetTypings(request, typings) { + return { + projectName: request.projectName, + typeAcquisition: request.typeAcquisition, + compilerOptions: request.compilerOptions, + typings, + unresolvedImports: request.unresolvedImports, + kind: ActionSet + }; + } + installTypingsAsync(requestId, packageNames, cwd, onRequestCompleted) { + this.pendingRunRequests.unshift({ requestId, packageNames, cwd, onRequestCompleted }); + this.executeWithThrottling(); + } + executeWithThrottling() { + while (this.inFlightRequestCount < this.throttleLimit && this.pendingRunRequests.length) { + this.inFlightRequestCount++; + const request = this.pendingRunRequests.pop(); + this.installWorker(request.requestId, request.packageNames, request.cwd, (ok) => { + this.inFlightRequestCount--; + request.onRequestCompleted(ok); + this.executeWithThrottling(); + }); + } + } + }; } - return Debug.fail("Could not find preceding token"); - } - function getArgumentInfoForCompletions(node, position, sourceFile) { - const info = getImmediatelyContainingArgumentInfo(node, position, sourceFile); - return !info || info.isTypeParameterList || info.invocation.kind !== 0 /* Call */ ? void 0 : { invocation: info.invocation.node, argumentCount: info.argumentCount, argumentIndex: info.argumentIndex }; - } - function getArgumentOrParameterListInfo(node, position, sourceFile) { - const info = getArgumentOrParameterListAndIndex(node, sourceFile); - if (!info) - return void 0; - const { list, argumentIndex } = info; - const argumentCount = getArgumentCount( - list, - /*ignoreTrailingComma*/ - isInString(sourceFile, position, node) - ); - if (argumentIndex !== 0) { - Debug.assertLessThan(argumentIndex, argumentCount); + }); + + // src/typingsInstallerCore/_namespaces/ts.server.typingsInstaller.ts + var ts_server_typingsInstaller_exports = {}; + __export(ts_server_typingsInstaller_exports, { + TypingsInstaller: () => TypingsInstaller, + getNpmCommandForInstallation: () => getNpmCommandForInstallation, + installNpmPackages: () => installNpmPackages, + typingsName: () => typingsName + }); + var init_ts_server_typingsInstaller = __esm({ + "src/typingsInstallerCore/_namespaces/ts.server.typingsInstaller.ts"() { + "use strict"; + init_typingsInstaller(); } - const argumentsSpan = getApplicableSpanForArguments(list, sourceFile); - return { list, argumentIndex, argumentCount, argumentsSpan }; - } - function getArgumentOrParameterListAndIndex(node, sourceFile) { - if (node.kind === 30 /* LessThanToken */ || node.kind === 21 /* OpenParenToken */) { - return { list: getChildListThatStartsWithOpenerToken(node.parent, node, sourceFile), argumentIndex: 0 }; - } else { - const list = findContainingList(node); - return list && { list, argumentIndex: getArgumentIndex(list, node) }; + }); + + // src/typingsInstallerCore/_namespaces/ts.server.ts + var init_ts_server2 = __esm({ + "src/typingsInstallerCore/_namespaces/ts.server.ts"() { + "use strict"; + init_ts_server(); + init_ts_server_typingsInstaller(); } - } - function getImmediatelyContainingArgumentInfo(node, position, sourceFile) { - const { parent: parent2 } = node; - if (isCallOrNewExpression(parent2)) { - const invocation = parent2; - const info = getArgumentOrParameterListInfo(node, position, sourceFile); - if (!info) - return void 0; - const { list, argumentIndex, argumentCount, argumentsSpan } = info; - const isTypeParameterList = !!parent2.typeArguments && parent2.typeArguments.pos === list.pos; - return { isTypeParameterList, invocation: { kind: 0 /* Call */, node: invocation }, argumentsSpan, argumentIndex, argumentCount }; - } else if (isNoSubstitutionTemplateLiteral(node) && isTaggedTemplateExpression(parent2)) { - if (isInsideTemplateLiteral(node, position, sourceFile)) { - return getArgumentListInfoForTemplate( - parent2, - /*argumentIndex*/ - 0, - sourceFile - ); - } - return void 0; - } else if (isTemplateHead(node) && parent2.parent.kind === 214 /* TaggedTemplateExpression */) { - const templateExpression = parent2; - const tagExpression = templateExpression.parent; - Debug.assert(templateExpression.kind === 227 /* TemplateExpression */); - const argumentIndex = isInsideTemplateLiteral(node, position, sourceFile) ? 0 : 1; - return getArgumentListInfoForTemplate(tagExpression, argumentIndex, sourceFile); - } else if (isTemplateSpan(parent2) && isTaggedTemplateExpression(parent2.parent.parent)) { - const templateSpan = parent2; - const tagExpression = parent2.parent.parent; - if (isTemplateTail(node) && !isInsideTemplateLiteral(node, position, sourceFile)) { - return void 0; - } - const spanIndex = templateSpan.parent.templateSpans.indexOf(templateSpan); - const argumentIndex = getArgumentIndexForTemplatePiece(spanIndex, node, position, sourceFile); - return getArgumentListInfoForTemplate(tagExpression, argumentIndex, sourceFile); - } else if (isJsxOpeningLikeElement(parent2)) { - const attributeSpanStart = parent2.attributes.pos; - const attributeSpanEnd = skipTrivia( - sourceFile.text, - parent2.attributes.end, - /*stopAfterLineBreak*/ - false - ); - return { - isTypeParameterList: false, - invocation: { kind: 0 /* Call */, node: parent2 }, - argumentsSpan: createTextSpan(attributeSpanStart, attributeSpanEnd - attributeSpanStart), - argumentIndex: 0, - argumentCount: 1 - }; - } else { - const typeArgInfo = getPossibleTypeArgumentsInfo(node, sourceFile); - if (typeArgInfo) { - const { called, nTypeArguments } = typeArgInfo; - const invocation = { kind: 1 /* TypeArgs */, called }; - const argumentsSpan = createTextSpanFromBounds(called.getStart(sourceFile), node.end); - return { isTypeParameterList: true, invocation, argumentsSpan, argumentIndex: nTypeArguments, argumentCount: nTypeArguments + 1 }; - } - return void 0; + }); + + // src/server/types.ts + var init_types4 = __esm({ + "src/server/types.ts"() { + "use strict"; } + }); + + // src/server/utilitiesPublic.ts + function createInstallTypingsRequest(project, typeAcquisition, unresolvedImports, cachePath) { + return { + projectName: project.getProjectName(), + fileNames: project.getFileNames( + /*excludeFilesFromExternalLibraries*/ + true, + /*excludeConfigFiles*/ + true + ).concat(project.getExcludedFiles()), + compilerOptions: project.getCompilationSettings(), + typeAcquisition, + unresolvedImports, + projectRootPath: project.getCurrentDirectory(), + cachePath, + kind: "discover" + }; } - function getImmediatelyContainingArgumentOrContextualParameterInfo(node, position, sourceFile, checker) { - return tryGetParameterInfo(node, position, sourceFile, checker) || getImmediatelyContainingArgumentInfo(node, position, sourceFile); + function toNormalizedPath(fileName) { + return normalizePath(fileName); } - function getHighestBinary(b) { - return isBinaryExpression(b.parent) ? getHighestBinary(b.parent) : b; + function normalizedPathToPath(normalizedPath, currentDirectory, getCanonicalFileName) { + const f = isRootedDiskPath(normalizedPath) ? normalizedPath : getNormalizedAbsolutePath(normalizedPath, currentDirectory); + return getCanonicalFileName(f); } - function countBinaryExpressionParameters(b) { - return isBinaryExpression(b.left) ? countBinaryExpressionParameters(b.left) + 1 : 2; + function asNormalizedPath(fileName) { + return fileName; } - function tryGetParameterInfo(startingToken, position, sourceFile, checker) { - const node = getAdjustedNode(startingToken); - if (node === void 0) - return void 0; - const info = getContextualSignatureLocationInfo(node, sourceFile, position, checker); - if (info === void 0) - return void 0; - const { contextualType, argumentIndex, argumentCount, argumentsSpan } = info; - const nonNullableContextualType = contextualType.getNonNullableType(); - const symbol = nonNullableContextualType.symbol; - if (symbol === void 0) - return void 0; - const signature = lastOrUndefined(nonNullableContextualType.getCallSignatures()); - if (signature === void 0) - return void 0; - const invocation = { kind: 2 /* Contextual */, signature, node: startingToken, symbol: chooseBetterSymbol(symbol) }; - return { isTypeParameterList: false, invocation, argumentsSpan, argumentIndex, argumentCount }; + function createNormalizedPathMap() { + const map2 = /* @__PURE__ */ new Map(); + return { + get(path) { + return map2.get(path); + }, + set(path, value) { + map2.set(path, value); + }, + contains(path) { + return map2.has(path); + }, + remove(path) { + map2.delete(path); + } + }; } - function getAdjustedNode(node) { - switch (node.kind) { - case 21 /* OpenParenToken */: - case 28 /* CommaToken */: - return node; - default: - return findAncestor(node.parent, (n) => isParameter(n) ? true : isBindingElement(n) || isObjectBindingPattern(n) || isArrayBindingPattern(n) ? false : "quit"); - } + function isInferredProjectName(name) { + return /dev\/null\/inferredProject\d+\*/.test(name); } - function getContextualSignatureLocationInfo(node, sourceFile, position, checker) { - const { parent: parent2 } = node; - switch (parent2.kind) { - case 216 /* ParenthesizedExpression */: - case 173 /* MethodDeclaration */: - case 217 /* FunctionExpression */: - case 218 /* ArrowFunction */: - const info = getArgumentOrParameterListInfo(node, position, sourceFile); - if (!info) - return void 0; - const { argumentIndex, argumentCount, argumentsSpan } = info; - const contextualType = isMethodDeclaration(parent2) ? checker.getContextualTypeForObjectLiteralElement(parent2) : checker.getContextualType(parent2); - return contextualType && { contextualType, argumentIndex, argumentCount, argumentsSpan }; - case 225 /* BinaryExpression */: { - const highestBinary = getHighestBinary(parent2); - const contextualType2 = checker.getContextualType(highestBinary); - const argumentIndex2 = node.kind === 21 /* OpenParenToken */ ? 0 : countBinaryExpressionParameters(parent2) - 1; - const argumentCount2 = countBinaryExpressionParameters(highestBinary); - return contextualType2 && { contextualType: contextualType2, argumentIndex: argumentIndex2, argumentCount: argumentCount2, argumentsSpan: createTextSpanFromNode(parent2) }; - } - default: - return void 0; - } + function makeInferredProjectName(counter) { + return `/dev/null/inferredProject${counter}*`; } - function chooseBetterSymbol(s) { - return s.name === "__type" /* Type */ ? firstDefined(s.declarations, (d) => { - var _a; - return isFunctionTypeNode(d) ? (_a = tryCast(d.parent, canHaveSymbol)) == null ? void 0 : _a.symbol : void 0; - }) || s : s; + function makeAutoImportProviderProjectName(counter) { + return `/dev/null/autoImportProviderProject${counter}*`; } - function getArgumentIndex(argumentsList, node) { - let argumentIndex = 0; - for (const child of argumentsList.getChildren()) { - if (child === node) { - break; - } - if (child.kind !== 28 /* CommaToken */) { - argumentIndex++; - } - } - return argumentIndex; + function makeAuxiliaryProjectName(counter) { + return `/dev/null/auxiliaryProject${counter}*`; } - function getArgumentCount(argumentsList, ignoreTrailingComma) { - const listChildren = argumentsList.getChildren(); - let argumentCount = countWhere(listChildren, (arg) => arg.kind !== 28 /* CommaToken */); - if (!ignoreTrailingComma && listChildren.length > 0 && last(listChildren).kind === 28 /* CommaToken */) { - argumentCount++; - } - return argumentCount; + function createSortedArray2() { + return []; } - function getArgumentIndexForTemplatePiece(spanIndex, node, position, sourceFile) { - Debug.assert(position >= node.getStart(), "Assumed 'position' could not occur before node."); - if (isTemplateLiteralToken(node)) { - if (isInsideTemplateLiteral(node, position, sourceFile)) { - return 0; - } - return spanIndex + 2; + var LogLevel2, emptyArray2, Msg, Errors; + var init_utilitiesPublic3 = __esm({ + "src/server/utilitiesPublic.ts"() { + "use strict"; + init_ts7(); + LogLevel2 = /* @__PURE__ */ ((LogLevel3) => { + LogLevel3[LogLevel3["terse"] = 0] = "terse"; + LogLevel3[LogLevel3["normal"] = 1] = "normal"; + LogLevel3[LogLevel3["requestTime"] = 2] = "requestTime"; + LogLevel3[LogLevel3["verbose"] = 3] = "verbose"; + return LogLevel3; + })(LogLevel2 || {}); + emptyArray2 = createSortedArray2(); + Msg = /* @__PURE__ */ ((Msg2) => { + Msg2["Err"] = "Err"; + Msg2["Info"] = "Info"; + Msg2["Perf"] = "Perf"; + return Msg2; + })(Msg || {}); + ((Errors2) => { + function ThrowNoProject() { + throw new Error("No Project."); + } + Errors2.ThrowNoProject = ThrowNoProject; + function ThrowProjectLanguageServiceDisabled() { + throw new Error("The project's language service is disabled."); + } + Errors2.ThrowProjectLanguageServiceDisabled = ThrowProjectLanguageServiceDisabled; + function ThrowProjectDoesNotContainDocument(fileName, project) { + throw new Error(`Project '${project.getProjectName()}' does not contain document '${fileName}'`); + } + Errors2.ThrowProjectDoesNotContainDocument = ThrowProjectDoesNotContainDocument; + })(Errors || (Errors = {})); } - return spanIndex + 1; + }); + + // src/server/utilities.ts + function getBaseConfigFileName(configFilePath) { + const base = getBaseFileName(configFilePath); + return base === "tsconfig.json" || base === "jsconfig.json" ? base : void 0; } - function getArgumentListInfoForTemplate(tagExpression, argumentIndex, sourceFile) { - const argumentCount = isNoSubstitutionTemplateLiteral(tagExpression.template) ? 1 : tagExpression.template.templateSpans.length + 1; - if (argumentIndex !== 0) { - Debug.assertLessThan(argumentIndex, argumentCount); + function removeSorted(array, remove, compare) { + if (!array || array.length === 0) { + return; } - return { - isTypeParameterList: false, - invocation: { kind: 0 /* Call */, node: tagExpression }, - argumentsSpan: getApplicableSpanForTaggedTemplate(tagExpression, sourceFile), - argumentIndex, - argumentCount - }; - } - function getApplicableSpanForArguments(argumentsList, sourceFile) { - const applicableSpanStart = argumentsList.getFullStart(); - const applicableSpanEnd = skipTrivia( - sourceFile.text, - argumentsList.getEnd(), - /*stopAfterLineBreak*/ - false - ); - return createTextSpan(applicableSpanStart, applicableSpanEnd - applicableSpanStart); - } - function getApplicableSpanForTaggedTemplate(taggedTemplate, sourceFile) { - const template = taggedTemplate.template; - const applicableSpanStart = template.getStart(); - let applicableSpanEnd = template.getEnd(); - if (template.kind === 227 /* TemplateExpression */) { - const lastSpan = last(template.templateSpans); - if (lastSpan.literal.getFullWidth() === 0) { - applicableSpanEnd = skipTrivia( - sourceFile.text, - applicableSpanEnd, - /*stopAfterLineBreak*/ - false - ); - } + if (array[0] === remove) { + array.splice(0, 1); + return; } - return createTextSpan(applicableSpanStart, applicableSpanEnd - applicableSpanStart); - } - function getContainingArgumentInfo(node, position, sourceFile, checker, isManuallyInvoked) { - for (let n = node; !isSourceFile(n) && (isManuallyInvoked || !isBlock(n)); n = n.parent) { - Debug.assert(rangeContainsRange(n.parent, n), "Not a subspan", () => `Child: ${Debug.formatSyntaxKind(n.kind)}, parent: ${Debug.formatSyntaxKind(n.parent.kind)}`); - const argumentInfo = getImmediatelyContainingArgumentOrContextualParameterInfo(n, position, sourceFile, checker); - if (argumentInfo) { - return argumentInfo; - } + const removeIndex = binarySearch(array, remove, identity, compare); + if (removeIndex >= 0) { + array.splice(removeIndex, 1); } - return void 0; - } - function getChildListThatStartsWithOpenerToken(parent2, openerToken, sourceFile) { - const children = parent2.getChildren(sourceFile); - const indexOfOpenerToken = children.indexOf(openerToken); - Debug.assert(indexOfOpenerToken >= 0 && children.length > indexOfOpenerToken + 1); - return children[indexOfOpenerToken + 1]; - } - function getExpressionFromInvocation(invocation) { - return invocation.kind === 0 /* Call */ ? getInvokedExpression(invocation.node) : invocation.called; - } - function getEnclosingDeclarationFromInvocation(invocation) { - return invocation.kind === 0 /* Call */ ? invocation.node : invocation.kind === 1 /* TypeArgs */ ? invocation.called : invocation.node; } - function createSignatureHelpItems(candidates, resolvedSignature, { isTypeParameterList, argumentCount, argumentsSpan: applicableSpan, invocation, argumentIndex }, sourceFile, typeChecker, useFullPrefix) { - var _a; - const enclosingDeclaration = getEnclosingDeclarationFromInvocation(invocation); - const callTargetSymbol = invocation.kind === 2 /* Contextual */ ? invocation.symbol : typeChecker.getSymbolAtLocation(getExpressionFromInvocation(invocation)) || useFullPrefix && ((_a = resolvedSignature.declaration) == null ? void 0 : _a.symbol); - const callTargetDisplayParts = callTargetSymbol ? symbolToDisplayParts( - typeChecker, - callTargetSymbol, - useFullPrefix ? sourceFile : void 0, - /*meaning*/ - void 0 - ) : emptyArray; - const items = map(candidates, (candidateSignature) => getSignatureHelpItem(candidateSignature, callTargetDisplayParts, isTypeParameterList, typeChecker, enclosingDeclaration, sourceFile)); - if (argumentIndex !== 0) { - Debug.assertLessThan(argumentIndex, argumentCount); - } - let selectedItemIndex = 0; - let itemsSeen = 0; - for (let i = 0; i < items.length; i++) { - const item = items[i]; - if (candidates[i] === resolvedSignature) { - selectedItemIndex = itemsSeen; - if (item.length > 1) { - let count = 0; - for (const i2 of item) { - if (i2.isVariadic || i2.parameters.length >= argumentCount) { - selectedItemIndex = itemsSeen + count; - break; - } - count++; + var ThrottledOperations, GcTimer; + var init_utilities5 = __esm({ + "src/server/utilities.ts"() { + "use strict"; + init_ts7(); + init_ts_server3(); + ThrottledOperations = class _ThrottledOperations { + constructor(host, logger) { + this.host = host; + this.pendingTimeouts = /* @__PURE__ */ new Map(); + this.logger = logger.hasLevel(3 /* verbose */) ? logger : void 0; + } + /** + * Wait `number` milliseconds and then invoke `cb`. If, while waiting, schedule + * is called again with the same `operationId`, cancel this operation in favor + * of the new one. (Note that the amount of time the canceled operation had been + * waiting does not affect the amount of time that the new operation waits.) + */ + schedule(operationId, delay, cb) { + const pendingTimeout = this.pendingTimeouts.get(operationId); + if (pendingTimeout) { + this.host.clearTimeout(pendingTimeout); + } + this.pendingTimeouts.set(operationId, this.host.setTimeout(_ThrottledOperations.run, delay, operationId, this, cb)); + if (this.logger) { + this.logger.info(`Scheduled: ${operationId}${pendingTimeout ? ", Cancelled earlier one" : ""}`); } } - } - itemsSeen += item.length; - } - Debug.assert(selectedItemIndex !== -1); - const help = { items: flatMapToMutable(items, identity), applicableSpan, selectedItemIndex, argumentIndex, argumentCount }; - const selected = help.items[selectedItemIndex]; - if (selected.isVariadic) { - const firstRest = findIndex(selected.parameters, (p) => !!p.isRest); - if (-1 < firstRest && firstRest < selected.parameters.length - 1) { - help.argumentIndex = selected.parameters.length; - } else { - help.argumentIndex = Math.min(help.argumentIndex, selected.parameters.length - 1); - } + cancel(operationId) { + const pendingTimeout = this.pendingTimeouts.get(operationId); + if (!pendingTimeout) + return false; + this.host.clearTimeout(pendingTimeout); + return this.pendingTimeouts.delete(operationId); + } + static run(operationId, self, cb) { + var _a, _b; + (_a = perfLogger) == null ? void 0 : _a.logStartScheduledOperation(operationId); + self.pendingTimeouts.delete(operationId); + if (self.logger) { + self.logger.info(`Running: ${operationId}`); + } + cb(); + (_b = perfLogger) == null ? void 0 : _b.logStopScheduledOperation(); + } + }; + GcTimer = class _GcTimer { + constructor(host, delay, logger) { + this.host = host; + this.delay = delay; + this.logger = logger; + } + scheduleCollect() { + if (!this.host.gc || this.timerId !== void 0) { + return; + } + this.timerId = this.host.setTimeout(_GcTimer.run, this.delay, this); + } + static run(self) { + var _a, _b; + self.timerId = void 0; + (_a = perfLogger) == null ? void 0 : _a.logStartScheduledOperation("GC collect"); + const log = self.logger.hasLevel(2 /* requestTime */); + const before = log && self.host.getMemoryUsage(); + self.host.gc(); + if (log) { + const after = self.host.getMemoryUsage(); + self.logger.perftrc(`GC::before ${before}, after ${after}`); + } + (_b = perfLogger) == null ? void 0 : _b.logStopScheduledOperation(); + } + }; } - return help; - } - function createTypeHelpItems(symbol, { argumentCount, argumentsSpan: applicableSpan, invocation, argumentIndex }, sourceFile, checker) { - const typeParameters = checker.getLocalTypeParametersOfClassOrInterfaceOrTypeAlias(symbol); - if (!typeParameters) - return void 0; - const items = [getTypeHelpItem(symbol, typeParameters, checker, getEnclosingDeclarationFromInvocation(invocation), sourceFile)]; - return { items, applicableSpan, selectedItemIndex: 0, argumentIndex, argumentCount }; - } - function getTypeHelpItem(symbol, typeParameters, checker, enclosingDeclaration, sourceFile) { - const typeSymbolDisplay = symbolToDisplayParts(checker, symbol); - const printer = createPrinterWithRemoveComments(); - const parameters = typeParameters.map((t) => createSignatureHelpParameterForTypeParameter(t, checker, enclosingDeclaration, sourceFile, printer)); - const documentation = symbol.getDocumentationComment(checker); - const tags = symbol.getJsDocTags(checker); - const prefixDisplayParts = [...typeSymbolDisplay, punctuationPart(30 /* LessThanToken */)]; - return { isVariadic: false, prefixDisplayParts, suffixDisplayParts: [punctuationPart(32 /* GreaterThanToken */)], separatorDisplayParts, parameters, documentation, tags }; - } - function getSignatureHelpItem(candidateSignature, callTargetDisplayParts, isTypeParameterList, checker, enclosingDeclaration, sourceFile) { - const infos = (isTypeParameterList ? itemInfoForTypeParameters : itemInfoForParameters)(candidateSignature, checker, enclosingDeclaration, sourceFile); - return map(infos, ({ isVariadic, parameters, prefix, suffix }) => { - const prefixDisplayParts = [...callTargetDisplayParts, ...prefix]; - const suffixDisplayParts = [...suffix, ...returnTypeToDisplayParts(candidateSignature, enclosingDeclaration, checker)]; - const documentation = candidateSignature.getDocumentationComment(checker); - const tags = candidateSignature.getJsDocTags(); - return { isVariadic, prefixDisplayParts, suffixDisplayParts, separatorDisplayParts, parameters, documentation, tags }; - }); - } - function returnTypeToDisplayParts(candidateSignature, enclosingDeclaration, checker) { - return mapToDisplayParts((writer) => { - writer.writePunctuation(":"); - writer.writeSpace(" "); - const predicate = checker.getTypePredicateOfSignature(candidateSignature); - if (predicate) { - checker.writeTypePredicate( - predicate, - enclosingDeclaration, - /*flags*/ - void 0, - writer - ); - } else { - checker.writeType( - checker.getReturnTypeOfSignature(candidateSignature), - enclosingDeclaration, - /*flags*/ - void 0, - writer - ); - } - }); - } - function itemInfoForTypeParameters(candidateSignature, checker, enclosingDeclaration, sourceFile) { - const typeParameters = (candidateSignature.target || candidateSignature).typeParameters; - const printer = createPrinterWithRemoveComments(); - const parameters = (typeParameters || emptyArray).map((t) => createSignatureHelpParameterForTypeParameter(t, checker, enclosingDeclaration, sourceFile, printer)); - const thisParameter = candidateSignature.thisParameter ? [checker.symbolToParameterDeclaration(candidateSignature.thisParameter, enclosingDeclaration, signatureHelpNodeBuilderFlags)] : []; - return checker.getExpandedParameters(candidateSignature).map((paramList) => { - const params = factory.createNodeArray([...thisParameter, ...map(paramList, (param) => checker.symbolToParameterDeclaration(param, enclosingDeclaration, signatureHelpNodeBuilderFlags))]); - const parameterParts = mapToDisplayParts((writer) => { - printer.writeList(2576 /* CallExpressionArguments */, params, sourceFile, writer); - }); - return { isVariadic: false, parameters, prefix: [punctuationPart(30 /* LessThanToken */)], suffix: [punctuationPart(32 /* GreaterThanToken */), ...parameterParts] }; - }); - } - function itemInfoForParameters(candidateSignature, checker, enclosingDeclaration, sourceFile) { - const printer = createPrinterWithRemoveComments(); - const typeParameterParts = mapToDisplayParts((writer) => { - if (candidateSignature.typeParameters && candidateSignature.typeParameters.length) { - const args = factory.createNodeArray(candidateSignature.typeParameters.map((p) => checker.typeParameterToDeclaration(p, enclosingDeclaration, signatureHelpNodeBuilderFlags))); - printer.writeList(53776 /* TypeParameters */, args, sourceFile, writer); - } - }); - const lists = checker.getExpandedParameters(candidateSignature); - const isVariadic = !checker.hasEffectiveRestParameter(candidateSignature) ? (_) => false : lists.length === 1 ? (_) => true : (pList) => { - var _a; - return !!(pList.length && ((_a = tryCast(pList[pList.length - 1], isTransientSymbol)) == null ? void 0 : _a.links.checkFlags) & 32768 /* RestParameter */); - }; - return lists.map((parameterList) => ({ - isVariadic: isVariadic(parameterList), - parameters: parameterList.map((p) => createSignatureHelpParameterForParameter(p, checker, enclosingDeclaration, sourceFile, printer)), - prefix: [...typeParameterParts, punctuationPart(21 /* OpenParenToken */)], - suffix: [punctuationPart(22 /* CloseParenToken */)] - })); - } - function createSignatureHelpParameterForParameter(parameter, checker, enclosingDeclaration, sourceFile, printer) { - const displayParts = mapToDisplayParts((writer) => { - const param = checker.symbolToParameterDeclaration(parameter, enclosingDeclaration, signatureHelpNodeBuilderFlags); - printer.writeNode(4 /* Unspecified */, param, sourceFile, writer); - }); - const isOptional = checker.isOptionalParameter(parameter.valueDeclaration); - const isRest = isTransientSymbol(parameter) && !!(parameter.links.checkFlags & 32768 /* RestParameter */); - return { name: parameter.name, documentation: parameter.getDocumentationComment(checker), displayParts, isOptional, isRest }; - } - function createSignatureHelpParameterForTypeParameter(typeParameter, checker, enclosingDeclaration, sourceFile, printer) { - const displayParts = mapToDisplayParts((writer) => { - const param = checker.typeParameterToDeclaration(typeParameter, enclosingDeclaration, signatureHelpNodeBuilderFlags); - printer.writeNode(4 /* Unspecified */, param, sourceFile, writer); - }); - return { name: typeParameter.symbol.name, documentation: typeParameter.symbol.getDocumentationComment(checker), displayParts, isOptional: false, isRest: false }; - } - var signatureHelpNodeBuilderFlags, separatorDisplayParts; - var init_signatureHelp = __esm({ - "src/services/signatureHelp.ts"() { + }); + + // src/server/protocol.ts + var CommandTypes, OrganizeImportsMode2, WatchFileKind2, WatchDirectoryKind2, PollingWatchKind2, CompletionTriggerKind2, IndentStyle2, SemicolonPreference2, JsxEmit2, ModuleKind2, ModuleResolutionKind2, NewLineKind2, ScriptTarget10, ClassificationType2; + var init_protocol = __esm({ + "src/server/protocol.ts"() { "use strict"; - init_ts4(); - signatureHelpNodeBuilderFlags = 8192 /* OmitParameterModifiers */ | 70221824 /* IgnoreErrors */ | 16384 /* UseAliasDefinedOutsideCurrentScope */; - separatorDisplayParts = [punctuationPart(28 /* CommaToken */), spacePart()]; + CommandTypes = /* @__PURE__ */ ((CommandTypes2) => { + CommandTypes2["JsxClosingTag"] = "jsxClosingTag"; + CommandTypes2["LinkedEditingRange"] = "linkedEditingRange"; + CommandTypes2["Brace"] = "brace"; + CommandTypes2["BraceFull"] = "brace-full"; + CommandTypes2["BraceCompletion"] = "braceCompletion"; + CommandTypes2["GetSpanOfEnclosingComment"] = "getSpanOfEnclosingComment"; + CommandTypes2["Change"] = "change"; + CommandTypes2["Close"] = "close"; + CommandTypes2["Completions"] = "completions"; + CommandTypes2["CompletionInfo"] = "completionInfo"; + CommandTypes2["CompletionsFull"] = "completions-full"; + CommandTypes2["CompletionDetails"] = "completionEntryDetails"; + CommandTypes2["CompletionDetailsFull"] = "completionEntryDetails-full"; + CommandTypes2["CompileOnSaveAffectedFileList"] = "compileOnSaveAffectedFileList"; + CommandTypes2["CompileOnSaveEmitFile"] = "compileOnSaveEmitFile"; + CommandTypes2["Configure"] = "configure"; + CommandTypes2["Definition"] = "definition"; + CommandTypes2["DefinitionFull"] = "definition-full"; + CommandTypes2["DefinitionAndBoundSpan"] = "definitionAndBoundSpan"; + CommandTypes2["DefinitionAndBoundSpanFull"] = "definitionAndBoundSpan-full"; + CommandTypes2["Implementation"] = "implementation"; + CommandTypes2["ImplementationFull"] = "implementation-full"; + CommandTypes2["EmitOutput"] = "emit-output"; + CommandTypes2["Exit"] = "exit"; + CommandTypes2["FileReferences"] = "fileReferences"; + CommandTypes2["FileReferencesFull"] = "fileReferences-full"; + CommandTypes2["Format"] = "format"; + CommandTypes2["Formatonkey"] = "formatonkey"; + CommandTypes2["FormatFull"] = "format-full"; + CommandTypes2["FormatonkeyFull"] = "formatonkey-full"; + CommandTypes2["FormatRangeFull"] = "formatRange-full"; + CommandTypes2["Geterr"] = "geterr"; + CommandTypes2["GeterrForProject"] = "geterrForProject"; + CommandTypes2["SemanticDiagnosticsSync"] = "semanticDiagnosticsSync"; + CommandTypes2["SyntacticDiagnosticsSync"] = "syntacticDiagnosticsSync"; + CommandTypes2["SuggestionDiagnosticsSync"] = "suggestionDiagnosticsSync"; + CommandTypes2["NavBar"] = "navbar"; + CommandTypes2["NavBarFull"] = "navbar-full"; + CommandTypes2["Navto"] = "navto"; + CommandTypes2["NavtoFull"] = "navto-full"; + CommandTypes2["NavTree"] = "navtree"; + CommandTypes2["NavTreeFull"] = "navtree-full"; + CommandTypes2["DocumentHighlights"] = "documentHighlights"; + CommandTypes2["DocumentHighlightsFull"] = "documentHighlights-full"; + CommandTypes2["Open"] = "open"; + CommandTypes2["Quickinfo"] = "quickinfo"; + CommandTypes2["QuickinfoFull"] = "quickinfo-full"; + CommandTypes2["References"] = "references"; + CommandTypes2["ReferencesFull"] = "references-full"; + CommandTypes2["Reload"] = "reload"; + CommandTypes2["Rename"] = "rename"; + CommandTypes2["RenameInfoFull"] = "rename-full"; + CommandTypes2["RenameLocationsFull"] = "renameLocations-full"; + CommandTypes2["Saveto"] = "saveto"; + CommandTypes2["SignatureHelp"] = "signatureHelp"; + CommandTypes2["SignatureHelpFull"] = "signatureHelp-full"; + CommandTypes2["FindSourceDefinition"] = "findSourceDefinition"; + CommandTypes2["Status"] = "status"; + CommandTypes2["TypeDefinition"] = "typeDefinition"; + CommandTypes2["ProjectInfo"] = "projectInfo"; + CommandTypes2["ReloadProjects"] = "reloadProjects"; + CommandTypes2["Unknown"] = "unknown"; + CommandTypes2["OpenExternalProject"] = "openExternalProject"; + CommandTypes2["OpenExternalProjects"] = "openExternalProjects"; + CommandTypes2["CloseExternalProject"] = "closeExternalProject"; + CommandTypes2["SynchronizeProjectList"] = "synchronizeProjectList"; + CommandTypes2["ApplyChangedToOpenFiles"] = "applyChangedToOpenFiles"; + CommandTypes2["UpdateOpen"] = "updateOpen"; + CommandTypes2["EncodedSyntacticClassificationsFull"] = "encodedSyntacticClassifications-full"; + CommandTypes2["EncodedSemanticClassificationsFull"] = "encodedSemanticClassifications-full"; + CommandTypes2["Cleanup"] = "cleanup"; + CommandTypes2["GetOutliningSpans"] = "getOutliningSpans"; + CommandTypes2["GetOutliningSpansFull"] = "outliningSpans"; + CommandTypes2["TodoComments"] = "todoComments"; + CommandTypes2["Indentation"] = "indentation"; + CommandTypes2["DocCommentTemplate"] = "docCommentTemplate"; + CommandTypes2["CompilerOptionsDiagnosticsFull"] = "compilerOptionsDiagnostics-full"; + CommandTypes2["NameOrDottedNameSpan"] = "nameOrDottedNameSpan"; + CommandTypes2["BreakpointStatement"] = "breakpointStatement"; + CommandTypes2["CompilerOptionsForInferredProjects"] = "compilerOptionsForInferredProjects"; + CommandTypes2["GetCodeFixes"] = "getCodeFixes"; + CommandTypes2["GetCodeFixesFull"] = "getCodeFixes-full"; + CommandTypes2["GetCombinedCodeFix"] = "getCombinedCodeFix"; + CommandTypes2["GetCombinedCodeFixFull"] = "getCombinedCodeFix-full"; + CommandTypes2["ApplyCodeActionCommand"] = "applyCodeActionCommand"; + CommandTypes2["GetSupportedCodeFixes"] = "getSupportedCodeFixes"; + CommandTypes2["GetApplicableRefactors"] = "getApplicableRefactors"; + CommandTypes2["GetEditsForRefactor"] = "getEditsForRefactor"; + CommandTypes2["GetMoveToRefactoringFileSuggestions"] = "getMoveToRefactoringFileSuggestions"; + CommandTypes2["GetEditsForRefactorFull"] = "getEditsForRefactor-full"; + CommandTypes2["OrganizeImports"] = "organizeImports"; + CommandTypes2["OrganizeImportsFull"] = "organizeImports-full"; + CommandTypes2["GetEditsForFileRename"] = "getEditsForFileRename"; + CommandTypes2["GetEditsForFileRenameFull"] = "getEditsForFileRename-full"; + CommandTypes2["ConfigurePlugin"] = "configurePlugin"; + CommandTypes2["SelectionRange"] = "selectionRange"; + CommandTypes2["SelectionRangeFull"] = "selectionRange-full"; + CommandTypes2["ToggleLineComment"] = "toggleLineComment"; + CommandTypes2["ToggleLineCommentFull"] = "toggleLineComment-full"; + CommandTypes2["ToggleMultilineComment"] = "toggleMultilineComment"; + CommandTypes2["ToggleMultilineCommentFull"] = "toggleMultilineComment-full"; + CommandTypes2["CommentSelection"] = "commentSelection"; + CommandTypes2["CommentSelectionFull"] = "commentSelection-full"; + CommandTypes2["UncommentSelection"] = "uncommentSelection"; + CommandTypes2["UncommentSelectionFull"] = "uncommentSelection-full"; + CommandTypes2["PrepareCallHierarchy"] = "prepareCallHierarchy"; + CommandTypes2["ProvideCallHierarchyIncomingCalls"] = "provideCallHierarchyIncomingCalls"; + CommandTypes2["ProvideCallHierarchyOutgoingCalls"] = "provideCallHierarchyOutgoingCalls"; + CommandTypes2["ProvideInlayHints"] = "provideInlayHints"; + CommandTypes2["WatchChange"] = "watchChange"; + return CommandTypes2; + })(CommandTypes || {}); + OrganizeImportsMode2 = /* @__PURE__ */ ((OrganizeImportsMode3) => { + OrganizeImportsMode3["All"] = "All"; + OrganizeImportsMode3["SortAndCombine"] = "SortAndCombine"; + OrganizeImportsMode3["RemoveUnused"] = "RemoveUnused"; + return OrganizeImportsMode3; + })(OrganizeImportsMode2 || {}); + WatchFileKind2 = /* @__PURE__ */ ((WatchFileKind3) => { + WatchFileKind3["FixedPollingInterval"] = "FixedPollingInterval"; + WatchFileKind3["PriorityPollingInterval"] = "PriorityPollingInterval"; + WatchFileKind3["DynamicPriorityPolling"] = "DynamicPriorityPolling"; + WatchFileKind3["FixedChunkSizePolling"] = "FixedChunkSizePolling"; + WatchFileKind3["UseFsEvents"] = "UseFsEvents"; + WatchFileKind3["UseFsEventsOnParentDirectory"] = "UseFsEventsOnParentDirectory"; + return WatchFileKind3; + })(WatchFileKind2 || {}); + WatchDirectoryKind2 = /* @__PURE__ */ ((WatchDirectoryKind3) => { + WatchDirectoryKind3["UseFsEvents"] = "UseFsEvents"; + WatchDirectoryKind3["FixedPollingInterval"] = "FixedPollingInterval"; + WatchDirectoryKind3["DynamicPriorityPolling"] = "DynamicPriorityPolling"; + WatchDirectoryKind3["FixedChunkSizePolling"] = "FixedChunkSizePolling"; + return WatchDirectoryKind3; + })(WatchDirectoryKind2 || {}); + PollingWatchKind2 = /* @__PURE__ */ ((PollingWatchKind3) => { + PollingWatchKind3["FixedInterval"] = "FixedInterval"; + PollingWatchKind3["PriorityInterval"] = "PriorityInterval"; + PollingWatchKind3["DynamicPriority"] = "DynamicPriority"; + PollingWatchKind3["FixedChunkSize"] = "FixedChunkSize"; + return PollingWatchKind3; + })(PollingWatchKind2 || {}); + CompletionTriggerKind2 = /* @__PURE__ */ ((CompletionTriggerKind4) => { + CompletionTriggerKind4[CompletionTriggerKind4["Invoked"] = 1] = "Invoked"; + CompletionTriggerKind4[CompletionTriggerKind4["TriggerCharacter"] = 2] = "TriggerCharacter"; + CompletionTriggerKind4[CompletionTriggerKind4["TriggerForIncompleteCompletions"] = 3] = "TriggerForIncompleteCompletions"; + return CompletionTriggerKind4; + })(CompletionTriggerKind2 || {}); + IndentStyle2 = /* @__PURE__ */ ((IndentStyle3) => { + IndentStyle3["None"] = "None"; + IndentStyle3["Block"] = "Block"; + IndentStyle3["Smart"] = "Smart"; + return IndentStyle3; + })(IndentStyle2 || {}); + SemicolonPreference2 = /* @__PURE__ */ ((SemicolonPreference3) => { + SemicolonPreference3["Ignore"] = "ignore"; + SemicolonPreference3["Insert"] = "insert"; + SemicolonPreference3["Remove"] = "remove"; + return SemicolonPreference3; + })(SemicolonPreference2 || {}); + JsxEmit2 = /* @__PURE__ */ ((JsxEmit3) => { + JsxEmit3["None"] = "None"; + JsxEmit3["Preserve"] = "Preserve"; + JsxEmit3["ReactNative"] = "ReactNative"; + JsxEmit3["React"] = "React"; + return JsxEmit3; + })(JsxEmit2 || {}); + ModuleKind2 = /* @__PURE__ */ ((ModuleKind3) => { + ModuleKind3["None"] = "None"; + ModuleKind3["CommonJS"] = "CommonJS"; + ModuleKind3["AMD"] = "AMD"; + ModuleKind3["UMD"] = "UMD"; + ModuleKind3["System"] = "System"; + ModuleKind3["ES6"] = "ES6"; + ModuleKind3["ES2015"] = "ES2015"; + ModuleKind3["ESNext"] = "ESNext"; + return ModuleKind3; + })(ModuleKind2 || {}); + ModuleResolutionKind2 = /* @__PURE__ */ ((ModuleResolutionKind3) => { + ModuleResolutionKind3["Classic"] = "Classic"; + ModuleResolutionKind3["Node"] = "Node"; + return ModuleResolutionKind3; + })(ModuleResolutionKind2 || {}); + NewLineKind2 = /* @__PURE__ */ ((NewLineKind3) => { + NewLineKind3["Crlf"] = "Crlf"; + NewLineKind3["Lf"] = "Lf"; + return NewLineKind3; + })(NewLineKind2 || {}); + ScriptTarget10 = /* @__PURE__ */ ((ScriptTarget11) => { + ScriptTarget11["ES3"] = "ES3"; + ScriptTarget11["ES5"] = "ES5"; + ScriptTarget11["ES6"] = "ES6"; + ScriptTarget11["ES2015"] = "ES2015"; + ScriptTarget11["ES2016"] = "ES2016"; + ScriptTarget11["ES2017"] = "ES2017"; + ScriptTarget11["ES2018"] = "ES2018"; + ScriptTarget11["ES2019"] = "ES2019"; + ScriptTarget11["ES2020"] = "ES2020"; + ScriptTarget11["ES2021"] = "ES2021"; + ScriptTarget11["ES2022"] = "ES2022"; + ScriptTarget11["ESNext"] = "ESNext"; + return ScriptTarget11; + })(ScriptTarget10 || {}); + ClassificationType2 = /* @__PURE__ */ ((ClassificationType3) => { + ClassificationType3[ClassificationType3["comment"] = 1] = "comment"; + ClassificationType3[ClassificationType3["identifier"] = 2] = "identifier"; + ClassificationType3[ClassificationType3["keyword"] = 3] = "keyword"; + ClassificationType3[ClassificationType3["numericLiteral"] = 4] = "numericLiteral"; + ClassificationType3[ClassificationType3["operator"] = 5] = "operator"; + ClassificationType3[ClassificationType3["stringLiteral"] = 6] = "stringLiteral"; + ClassificationType3[ClassificationType3["regularExpressionLiteral"] = 7] = "regularExpressionLiteral"; + ClassificationType3[ClassificationType3["whiteSpace"] = 8] = "whiteSpace"; + ClassificationType3[ClassificationType3["text"] = 9] = "text"; + ClassificationType3[ClassificationType3["punctuation"] = 10] = "punctuation"; + ClassificationType3[ClassificationType3["className"] = 11] = "className"; + ClassificationType3[ClassificationType3["enumName"] = 12] = "enumName"; + ClassificationType3[ClassificationType3["interfaceName"] = 13] = "interfaceName"; + ClassificationType3[ClassificationType3["moduleName"] = 14] = "moduleName"; + ClassificationType3[ClassificationType3["typeParameterName"] = 15] = "typeParameterName"; + ClassificationType3[ClassificationType3["typeAliasName"] = 16] = "typeAliasName"; + ClassificationType3[ClassificationType3["parameterName"] = 17] = "parameterName"; + ClassificationType3[ClassificationType3["docCommentTagName"] = 18] = "docCommentTagName"; + ClassificationType3[ClassificationType3["jsxOpenTagName"] = 19] = "jsxOpenTagName"; + ClassificationType3[ClassificationType3["jsxCloseTagName"] = 20] = "jsxCloseTagName"; + ClassificationType3[ClassificationType3["jsxSelfClosingTagName"] = 21] = "jsxSelfClosingTagName"; + ClassificationType3[ClassificationType3["jsxAttribute"] = 22] = "jsxAttribute"; + ClassificationType3[ClassificationType3["jsxText"] = 23] = "jsxText"; + ClassificationType3[ClassificationType3["jsxAttributeStringLiteralValue"] = 24] = "jsxAttributeStringLiteralValue"; + ClassificationType3[ClassificationType3["bigintLiteral"] = 25] = "bigintLiteral"; + return ClassificationType3; + })(ClassificationType2 || {}); } }); - // src/services/_namespaces/ts.SignatureHelp.ts - var ts_SignatureHelp_exports = {}; - __export(ts_SignatureHelp_exports, { - getArgumentInfoForCompletions: () => getArgumentInfoForCompletions, - getSignatureHelpItems: () => getSignatureHelpItems + // src/server/_namespaces/ts.server.protocol.ts + var ts_server_protocol_exports = {}; + __export(ts_server_protocol_exports, { + ClassificationType: () => ClassificationType2, + CommandTypes: () => CommandTypes, + CompletionTriggerKind: () => CompletionTriggerKind2, + IndentStyle: () => IndentStyle2, + JsxEmit: () => JsxEmit2, + ModuleKind: () => ModuleKind2, + ModuleResolutionKind: () => ModuleResolutionKind2, + NewLineKind: () => NewLineKind2, + OrganizeImportsMode: () => OrganizeImportsMode2, + PollingWatchKind: () => PollingWatchKind2, + ScriptTarget: () => ScriptTarget10, + SemicolonPreference: () => SemicolonPreference2, + WatchDirectoryKind: () => WatchDirectoryKind2, + WatchFileKind: () => WatchFileKind2 }); - var init_ts_SignatureHelp = __esm({ - "src/services/_namespaces/ts.SignatureHelp.ts"() { + var init_ts_server_protocol = __esm({ + "src/server/_namespaces/ts.server.protocol.ts"() { "use strict"; - init_signatureHelp(); + init_protocol(); } }); - // src/services/smartSelection.ts - function getSmartSelectionRange(pos, sourceFile) { - var _a, _b; - let selectionRange = { - textSpan: createTextSpanFromBounds(sourceFile.getFullStart(), sourceFile.getEnd()) - }; - let parentNode = sourceFile; - outer: - while (true) { - const children = getSelectionChildren(parentNode); - if (!children.length) - break; - for (let i = 0; i < children.length; i++) { - const prevNode = children[i - 1]; - const node = children[i]; - const nextNode = children[i + 1]; - if (getTokenPosOfNode( - node, - sourceFile, - /*includeJsDoc*/ - true - ) > pos) { - break outer; + // src/server/scriptInfo.ts + function isDynamicFileName(fileName) { + return fileName[0] === "^" || (fileName.includes("walkThroughSnippet:/") || fileName.includes("untitled:/")) && getBaseFileName(fileName)[0] === "^" || fileName.includes(":^") && !fileName.includes(directorySeparator); + } + function ensurePrimaryProjectKind(project) { + if (!project || isBackgroundProject(project)) { + return Errors.ThrowNoProject(); + } + return project; + } + function failIfInvalidPosition(position) { + Debug.assert(typeof position === "number", `Expected position ${position} to be a number.`); + Debug.assert(position >= 0, `Expected position to be non-negative.`); + } + function failIfInvalidLocation(location) { + Debug.assert(typeof location.line === "number", `Expected line ${location.line} to be a number.`); + Debug.assert(typeof location.offset === "number", `Expected offset ${location.offset} to be a number.`); + Debug.assert(location.line > 0, `Expected line to be non-${location.line === 0 ? "zero" : "negative"}`); + Debug.assert(location.offset > 0, `Expected offset to be non-${location.offset === 0 ? "zero" : "negative"}`); + } + var TextStorage, ScriptInfo; + var init_scriptInfo = __esm({ + "src/server/scriptInfo.ts"() { + "use strict"; + init_ts7(); + init_ts_server3(); + TextStorage = class { + constructor(host, info, initialVersion) { + this.host = host; + this.info = info; + /** + * True if the text is for the file thats open in the editor + */ + this.isOpen = false; + /** + * True if the text present is the text from the file on the disk + */ + this.ownFileText = false; + /** + * True when reloading contents of file from the disk is pending + */ + this.pendingReloadFromDisk = false; + this.version = initialVersion || 0; + } + getVersion() { + return this.svc ? `SVC-${this.version}-${this.svc.getSnapshotVersion()}` : `Text-${this.version}`; + } + hasScriptVersionCache_TestOnly() { + return this.svc !== void 0; + } + resetSourceMapInfo() { + this.info.sourceFileLike = void 0; + this.info.closeSourceMapFileWatcher(); + this.info.sourceMapFilePath = void 0; + this.info.declarationInfoPath = void 0; + this.info.sourceInfos = void 0; + this.info.documentPositionMapper = void 0; + } + /** Public for testing */ + useText(newText) { + this.svc = void 0; + this.text = newText; + this.textSnapshot = void 0; + this.lineMap = void 0; + this.fileSize = void 0; + this.resetSourceMapInfo(); + this.version++; + } + edit(start, end, newText) { + this.switchToScriptVersionCache().edit(start, end - start, newText); + this.ownFileText = false; + this.text = void 0; + this.textSnapshot = void 0; + this.lineMap = void 0; + this.fileSize = void 0; + this.resetSourceMapInfo(); + } + /** + * Set the contents as newText + * returns true if text changed + */ + reload(newText) { + Debug.assert(newText !== void 0); + this.pendingReloadFromDisk = false; + if (!this.text && this.svc) { + this.text = getSnapshotText(this.svc.getSnapshot()); + } + if (this.text !== newText) { + this.useText(newText); + this.ownFileText = false; + return true; } - const comment = singleOrUndefined(getTrailingCommentRanges(sourceFile.text, node.end)); - if (comment && comment.kind === 2 /* SingleLineCommentTrivia */) { - pushSelectionCommentRange(comment.pos, comment.end); + return false; + } + /** + * Reads the contents from tempFile(if supplied) or own file and sets it as contents + * returns true if text changed + */ + reloadWithFileText(tempFileName) { + const { text: newText, fileSize } = tempFileName || !this.info.isDynamicOrHasMixedContent() ? this.getFileTextAndSize(tempFileName) : { text: "", fileSize: void 0 }; + const reloaded = this.reload(newText); + this.fileSize = fileSize; + this.ownFileText = !tempFileName || tempFileName === this.info.fileName; + return reloaded; + } + /** + * Schedule reload from the disk if its not already scheduled and its not own text + * returns true when scheduling reload + */ + scheduleReloadIfNeeded() { + return !this.pendingReloadFromDisk && !this.ownFileText ? this.pendingReloadFromDisk = true : false; + } + delayReloadFromFileIntoText() { + this.pendingReloadFromDisk = true; + } + /** + * For telemetry purposes, we would like to be able to report the size of the file. + * However, we do not want telemetry to require extra file I/O so we report a size + * that may be stale (e.g. may not reflect change made on disk since the last reload). + * NB: Will read from disk if the file contents have never been loaded because + * telemetry falsely indicating size 0 would be counter-productive. + */ + getTelemetryFileSize() { + return !!this.fileSize ? this.fileSize : !!this.text ? this.text.length : !!this.svc ? this.svc.getSnapshot().getLength() : this.getSnapshot().getLength(); + } + getSnapshot() { + var _a; + return ((_a = this.tryUseScriptVersionCache()) == null ? void 0 : _a.getSnapshot()) || (this.textSnapshot ?? (this.textSnapshot = ScriptSnapshot.fromString(Debug.checkDefined(this.text)))); + } + getAbsolutePositionAndLineText(oneBasedLine) { + const svc = this.tryUseScriptVersionCache(); + if (svc) + return svc.getAbsolutePositionAndLineText(oneBasedLine); + const lineMap = this.getLineMap(); + return oneBasedLine <= lineMap.length ? { + absolutePosition: lineMap[oneBasedLine - 1], + lineText: this.text.substring(lineMap[oneBasedLine - 1], lineMap[oneBasedLine]) + } : { + absolutePosition: this.text.length, + lineText: void 0 + }; + } + /** + * @param line 0 based index + */ + lineToTextSpan(line) { + const svc = this.tryUseScriptVersionCache(); + if (svc) + return svc.lineToTextSpan(line); + const lineMap = this.getLineMap(); + const start = lineMap[line]; + const end = line + 1 < lineMap.length ? lineMap[line + 1] : this.text.length; + return createTextSpanFromBounds(start, end); + } + /** + * @param line 1 based index + * @param offset 1 based index + */ + lineOffsetToPosition(line, offset, allowEdits) { + const svc = this.tryUseScriptVersionCache(); + return svc ? svc.lineOffsetToPosition(line, offset) : computePositionOfLineAndCharacter(this.getLineMap(), line - 1, offset - 1, this.text, allowEdits); + } + positionToLineOffset(position) { + const svc = this.tryUseScriptVersionCache(); + if (svc) + return svc.positionToLineOffset(position); + const { line, character } = computeLineAndCharacterOfPosition(this.getLineMap(), position); + return { line: line + 1, offset: character + 1 }; + } + getFileTextAndSize(tempFileName) { + let text; + const fileName = tempFileName || this.info.fileName; + const getText = () => text === void 0 ? text = this.host.readFile(fileName) || "" : text; + if (!hasTSFileExtension(this.info.fileName)) { + const fileSize = this.host.getFileSize ? this.host.getFileSize(fileName) : getText().length; + if (fileSize > maxFileSize) { + Debug.assert(!!this.info.containingProjects.length); + const service = this.info.containingProjects[0].projectService; + service.logger.info(`Skipped loading contents of large file ${fileName} for info ${this.info.fileName}: fileSize: ${fileSize}`); + this.info.containingProjects[0].projectService.sendLargeFileReferencedEvent(fileName, fileSize); + return { text: "", fileSize }; + } + } + return { text: getText() }; + } + /** @internal */ + switchToScriptVersionCache() { + if (!this.svc || this.pendingReloadFromDisk) { + this.svc = ScriptVersionCache.fromString(this.getOrLoadText()); + this.textSnapshot = void 0; + this.version++; } - if (positionShouldSnapToNode(sourceFile, pos, node)) { - if (isFunctionBody(node) && isFunctionLikeDeclaration(parentNode) && !positionsAreOnSameLine(node.getStart(sourceFile), node.getEnd(), sourceFile)) { - pushSelectionRange(node.getStart(sourceFile), node.getEnd()); + return this.svc; + } + tryUseScriptVersionCache() { + if (!this.svc || this.pendingReloadFromDisk) { + this.getOrLoadText(); + } + if (this.isOpen) { + if (!this.svc && !this.textSnapshot) { + this.svc = ScriptVersionCache.fromString(Debug.checkDefined(this.text)); + this.textSnapshot = void 0; } - if (isBlock(node) || isTemplateSpan(node) || isTemplateHead(node) || isTemplateTail(node) || prevNode && isTemplateHead(prevNode) || isVariableDeclarationList(node) && isVariableStatement(parentNode) || isSyntaxList(node) && isVariableDeclarationList(parentNode) || isVariableDeclaration(node) && isSyntaxList(parentNode) && children.length === 1 || isJSDocTypeExpression(node) || isJSDocSignature(node) || isJSDocTypeLiteral(node)) { - parentNode = node; - break; + return this.svc; + } + return this.svc; + } + getOrLoadText() { + if (this.text === void 0 || this.pendingReloadFromDisk) { + Debug.assert(!this.svc || this.pendingReloadFromDisk, "ScriptVersionCache should not be set when reloading from disk"); + this.reloadWithFileText(); + } + return this.text; + } + getLineMap() { + Debug.assert(!this.svc, "ScriptVersionCache should not be set"); + return this.lineMap || (this.lineMap = computeLineStarts(Debug.checkDefined(this.text))); + } + getLineInfo() { + const svc = this.tryUseScriptVersionCache(); + if (svc) { + return { + getLineCount: () => svc.getLineCount(), + getLineText: (line) => svc.getAbsolutePositionAndLineText(line + 1).lineText + }; + } + const lineMap = this.getLineMap(); + return getLineInfo(this.text, lineMap); + } + }; + ScriptInfo = class { + constructor(host, fileName, scriptKind, hasMixedContent, path, initialVersion) { + this.host = host; + this.fileName = fileName; + this.scriptKind = scriptKind; + this.hasMixedContent = hasMixedContent; + this.path = path; + /** + * All projects that include this file + */ + this.containingProjects = []; + this.isDynamic = isDynamicFileName(fileName); + this.textStorage = new TextStorage(host, this, initialVersion); + if (hasMixedContent || this.isDynamic) { + this.realpath = this.path; + } + this.scriptKind = scriptKind ? scriptKind : getScriptKindFromFileName(fileName); + } + /** @internal */ + isDynamicOrHasMixedContent() { + return this.hasMixedContent || this.isDynamic; + } + isScriptOpen() { + return this.textStorage.isOpen; + } + open(newText) { + this.textStorage.isOpen = true; + if (newText !== void 0 && this.textStorage.reload(newText)) { + this.markContainingProjectsAsDirty(); + } + } + close(fileExists = true) { + this.textStorage.isOpen = false; + if (fileExists && this.textStorage.scheduleReloadIfNeeded()) { + this.markContainingProjectsAsDirty(); + } + } + getSnapshot() { + return this.textStorage.getSnapshot(); + } + ensureRealPath() { + if (this.realpath === void 0) { + this.realpath = this.path; + if (this.host.realpath) { + Debug.assert(!!this.containingProjects.length); + const project = this.containingProjects[0]; + const realpath = this.host.realpath(this.path); + if (realpath) { + this.realpath = project.toPath(realpath); + if (this.realpath !== this.path) { + project.projectService.realpathToScriptInfos.add(this.realpath, this); + } + } } - if (isTemplateSpan(parentNode) && nextNode && isTemplateMiddleOrTemplateTail(nextNode)) { - const start2 = node.getFullStart() - "${".length; - const end2 = nextNode.getStart() + "}".length; - pushSelectionRange(start2, end2); + } + } + /** @internal */ + getRealpathIfDifferent() { + return this.realpath && this.realpath !== this.path ? this.realpath : void 0; + } + /** + * @internal + * Does not compute realpath; uses precomputed result. Use `ensureRealPath` + * first if a definite result is needed. + */ + isSymlink() { + return this.realpath && this.realpath !== this.path; + } + getFormatCodeSettings() { + return this.formatSettings; + } + getPreferences() { + return this.preferences; + } + attachToProject(project) { + const isNew = !this.isAttached(project); + if (isNew) { + this.containingProjects.push(project); + if (!project.getCompilerOptions().preserveSymlinks) { + this.ensureRealPath(); } - const isBetweenMultiLineBookends = isSyntaxList(node) && isListOpener(prevNode) && isListCloser(nextNode) && !positionsAreOnSameLine(prevNode.getStart(), nextNode.getStart(), sourceFile); - let start = isBetweenMultiLineBookends ? prevNode.getEnd() : node.getStart(); - const end = isBetweenMultiLineBookends ? nextNode.getStart() : getEndPos(sourceFile, node); - if (hasJSDocNodes(node) && ((_a = node.jsDoc) == null ? void 0 : _a.length)) { - pushSelectionRange(first(node.jsDoc).getStart(), end); + project.onFileAddedOrRemoved(this.isSymlink()); + } + return isNew; + } + isAttached(project) { + switch (this.containingProjects.length) { + case 0: + return false; + case 1: + return this.containingProjects[0] === project; + case 2: + return this.containingProjects[0] === project || this.containingProjects[1] === project; + default: + return contains(this.containingProjects, project); + } + } + detachFromProject(project) { + switch (this.containingProjects.length) { + case 0: + return; + case 1: + if (this.containingProjects[0] === project) { + project.onFileAddedOrRemoved(this.isSymlink()); + this.containingProjects.pop(); + } + break; + case 2: + if (this.containingProjects[0] === project) { + project.onFileAddedOrRemoved(this.isSymlink()); + this.containingProjects[0] = this.containingProjects.pop(); + } else if (this.containingProjects[1] === project) { + project.onFileAddedOrRemoved(this.isSymlink()); + this.containingProjects.pop(); + } + break; + default: + if (unorderedRemoveItem(this.containingProjects, project)) { + project.onFileAddedOrRemoved(this.isSymlink()); + } + break; + } + } + detachAllProjects() { + for (const p of this.containingProjects) { + if (isConfiguredProject(p)) { + p.getCachedDirectoryStructureHost().addOrDeleteFile(this.fileName, this.path, 2 /* Deleted */); + } + const existingRoot = p.getRootFilesMap().get(this.path); + p.removeFile( + this, + /*fileExists*/ + false, + /*detachFromProject*/ + false + ); + p.onFileAddedOrRemoved(this.isSymlink()); + if (existingRoot && !isInferredProject(p)) { + p.addMissingFileRoot(existingRoot.fileName); } - if (isSyntaxList(node)) { - const firstChild = node.getChildren()[0]; - if (firstChild && hasJSDocNodes(firstChild) && ((_b = firstChild.jsDoc) == null ? void 0 : _b.length) && firstChild.getStart() !== node.pos) { - start = Math.min(start, first(firstChild.jsDoc).getStart()); + } + clear(this.containingProjects); + } + getDefaultProject() { + switch (this.containingProjects.length) { + case 0: + return Errors.ThrowNoProject(); + case 1: + return ensurePrimaryProjectKind(this.containingProjects[0]); + default: + let firstExternalProject; + let firstConfiguredProject; + let firstInferredProject; + let firstNonSourceOfProjectReferenceRedirect; + let defaultConfiguredProject; + for (let index = 0; index < this.containingProjects.length; index++) { + const project = this.containingProjects[index]; + if (isConfiguredProject(project)) { + if (!project.isSourceOfProjectReferenceRedirect(this.fileName)) { + if (defaultConfiguredProject === void 0 && index !== this.containingProjects.length - 1) { + defaultConfiguredProject = project.projectService.findDefaultConfiguredProject(this) || false; + } + if (defaultConfiguredProject === project) + return project; + if (!firstNonSourceOfProjectReferenceRedirect) + firstNonSourceOfProjectReferenceRedirect = project; + } + if (!firstConfiguredProject) + firstConfiguredProject = project; + } else if (!firstExternalProject && isExternalProject(project)) { + firstExternalProject = project; + } else if (!firstInferredProject && isInferredProject(project)) { + firstInferredProject = project; + } } + return ensurePrimaryProjectKind( + defaultConfiguredProject || firstNonSourceOfProjectReferenceRedirect || firstConfiguredProject || firstExternalProject || firstInferredProject + ); + } + } + registerFileUpdate() { + for (const p of this.containingProjects) { + p.registerFileUpdate(this.path); + } + } + setOptions(formatSettings, preferences) { + if (formatSettings) { + if (!this.formatSettings) { + this.formatSettings = getDefaultFormatCodeSettings(this.host.newLine); + assign(this.formatSettings, formatSettings); + } else { + this.formatSettings = { ...this.formatSettings, ...formatSettings }; } - pushSelectionRange(start, end); - if (isStringLiteral(node) || isTemplateLiteral(node)) { - pushSelectionRange(start + 1, end - 1); + } + if (preferences) { + if (!this.preferences) { + this.preferences = emptyOptions; } - parentNode = node; - break; + this.preferences = { ...this.preferences, ...preferences }; } - if (i === children.length - 1) { - break outer; + } + getLatestVersion() { + this.textStorage.getSnapshot(); + return this.textStorage.getVersion(); + } + saveTo(fileName) { + this.host.writeFile(fileName, getSnapshotText(this.textStorage.getSnapshot())); + } + /** @internal */ + delayReloadNonMixedContentFile() { + Debug.assert(!this.isDynamicOrHasMixedContent()); + this.textStorage.delayReloadFromFileIntoText(); + this.markContainingProjectsAsDirty(); + } + reloadFromFile(tempFileName) { + if (this.textStorage.reloadWithFileText(tempFileName)) { + this.markContainingProjectsAsDirty(); + return true; } + return false; } - } - return selectionRange; - function pushSelectionRange(start, end) { - if (start !== end) { - const textSpan = createTextSpanFromBounds(start, end); - if (!selectionRange || // Skip ranges that are identical to the parent - !textSpansEqual(textSpan, selectionRange.textSpan) && // Skip ranges that don't contain the original position - textSpanIntersectsWithPosition(textSpan, pos)) { - selectionRange = { textSpan, ...selectionRange && { parent: selectionRange } }; + editContent(start, end, newText) { + this.textStorage.edit(start, end, newText); + this.markContainingProjectsAsDirty(); } - } - } - function pushSelectionCommentRange(start, end) { - pushSelectionRange(start, end); - let pos2 = start; - while (sourceFile.text.charCodeAt(pos2) === 47 /* slash */) { - pos2++; - } - pushSelectionRange(pos2, end); + markContainingProjectsAsDirty() { + for (const p of this.containingProjects) { + p.markFileAsDirty(this.path); + } + } + isOrphan() { + return !forEach(this.containingProjects, (p) => !p.isOrphan()); + } + /** @internal */ + isContainedByBackgroundProject() { + return some( + this.containingProjects, + isBackgroundProject + ); + } + /** + * @param line 1 based index + */ + lineToTextSpan(line) { + return this.textStorage.lineToTextSpan(line); + } + // eslint-disable-line @typescript-eslint/unified-signatures + lineOffsetToPosition(line, offset, allowEdits) { + return this.textStorage.lineOffsetToPosition(line, offset, allowEdits); + } + positionToLineOffset(position) { + failIfInvalidPosition(position); + const location = this.textStorage.positionToLineOffset(position); + failIfInvalidLocation(location); + return location; + } + isJavaScript() { + return this.scriptKind === 1 /* JS */ || this.scriptKind === 2 /* JSX */; + } + /** @internal */ + closeSourceMapFileWatcher() { + if (this.sourceMapFilePath && !isString(this.sourceMapFilePath)) { + closeFileWatcherOf(this.sourceMapFilePath); + this.sourceMapFilePath = void 0; + } + } + }; } - } - function positionShouldSnapToNode(sourceFile, pos, node) { - Debug.assert(node.pos <= pos); - if (pos < node.end) { + }); + + // src/server/typingsCache.ts + function setIsEqualTo(arr1, arr2) { + if (arr1 === arr2) { return true; } - const nodeEnd = node.getEnd(); - if (nodeEnd === pos) { - return getTouchingPropertyName(sourceFile, pos).pos < node.end; - } - return false; - } - function getSelectionChildren(node) { - var _a; - if (isSourceFile(node)) { - return groupChildren(node.getChildAt(0).getChildren(), isImport2); - } - if (isMappedTypeNode(node)) { - const [openBraceToken, ...children] = node.getChildren(); - const closeBraceToken = Debug.checkDefined(children.pop()); - Debug.assertEqual(openBraceToken.kind, 19 /* OpenBraceToken */); - Debug.assertEqual(closeBraceToken.kind, 20 /* CloseBraceToken */); - const groupedWithPlusMinusTokens = groupChildren(children, (child) => child === node.readonlyToken || child.kind === 148 /* ReadonlyKeyword */ || child === node.questionToken || child.kind === 58 /* QuestionToken */); - const groupedWithBrackets = groupChildren( - groupedWithPlusMinusTokens, - ({ kind }) => kind === 23 /* OpenBracketToken */ || kind === 167 /* TypeParameter */ || kind === 24 /* CloseBracketToken */ - ); - return [ - openBraceToken, - // Pivot on `:` - createSyntaxList2(splitChildren(groupedWithBrackets, ({ kind }) => kind === 59 /* ColonToken */)), - closeBraceToken - ]; + if ((arr1 || emptyArray2).length === 0 && (arr2 || emptyArray2).length === 0) { + return true; } - if (isPropertySignature(node)) { - const children = groupChildren(node.getChildren(), (child) => child === node.name || contains(node.modifiers, child)); - const firstJSDocChild = ((_a = children[0]) == null ? void 0 : _a.kind) === 326 /* JSDoc */ ? children[0] : void 0; - const withJSDocSeparated = firstJSDocChild ? children.slice(1) : children; - const splittedChildren = splitChildren(withJSDocSeparated, ({ kind }) => kind === 59 /* ColonToken */); - return firstJSDocChild ? [firstJSDocChild, createSyntaxList2(splittedChildren)] : splittedChildren; + const set = /* @__PURE__ */ new Map(); + let unique = 0; + for (const v of arr1) { + if (set.get(v) !== true) { + set.set(v, true); + unique++; + } } - if (isParameter(node)) { - const groupedDotDotDotAndName = groupChildren(node.getChildren(), (child) => child === node.dotDotDotToken || child === node.name); - const groupedWithQuestionToken = groupChildren(groupedDotDotDotAndName, (child) => child === groupedDotDotDotAndName[0] || child === node.questionToken); - return splitChildren(groupedWithQuestionToken, ({ kind }) => kind === 64 /* EqualsToken */); + for (const v of arr2) { + const isSet = set.get(v); + if (isSet === void 0) { + return false; + } + if (isSet === true) { + set.set(v, false); + unique--; + } } - if (isBindingElement(node)) { - return splitChildren(node.getChildren(), ({ kind }) => kind === 64 /* EqualsToken */); + return unique === 0; + } + function typeAcquisitionChanged(opt1, opt2) { + return opt1.enable !== opt2.enable || !setIsEqualTo(opt1.include, opt2.include) || !setIsEqualTo(opt1.exclude, opt2.exclude); + } + function compilerOptionsChanged(opt1, opt2) { + return getAllowJSCompilerOption(opt1) !== getAllowJSCompilerOption(opt2); + } + function unresolvedImportsChanged(imports1, imports2) { + if (imports1 === imports2) { + return false; } - return node.getChildren(); + return !arrayIsEqualTo(imports1, imports2); } - function groupChildren(children, groupOn) { - const result = []; - let group2; - for (const child of children) { - if (groupOn(child)) { - group2 = group2 || []; - group2.push(child); - } else { - if (group2) { - result.push(createSyntaxList2(group2)); - group2 = void 0; + var nullTypingsInstaller, TypingsCache; + var init_typingsCache = __esm({ + "src/server/typingsCache.ts"() { + "use strict"; + init_ts7(); + init_ts_server3(); + nullTypingsInstaller = { + isKnownTypesPackageName: returnFalse, + // Should never be called because we never provide a types registry. + installPackage: notImplemented, + enqueueInstallTypingsRequest: noop, + attach: noop, + onProjectClosed: noop, + globalTypingsCacheLocation: void 0 + // TODO: GH#18217 + }; + TypingsCache = class { + constructor(installer) { + this.installer = installer; + this.perProjectCache = /* @__PURE__ */ new Map(); } - result.push(child); - } + isKnownTypesPackageName(name) { + return this.installer.isKnownTypesPackageName(name); + } + installPackage(options) { + return this.installer.installPackage(options); + } + enqueueInstallTypingsForProject(project, unresolvedImports, forceRefresh) { + const typeAcquisition = project.getTypeAcquisition(); + if (!typeAcquisition || !typeAcquisition.enable) { + return; + } + const entry = this.perProjectCache.get(project.getProjectName()); + if (forceRefresh || !entry || typeAcquisitionChanged(typeAcquisition, entry.typeAcquisition) || compilerOptionsChanged(project.getCompilationSettings(), entry.compilerOptions) || unresolvedImportsChanged(unresolvedImports, entry.unresolvedImports)) { + this.perProjectCache.set(project.getProjectName(), { + compilerOptions: project.getCompilationSettings(), + typeAcquisition, + typings: entry ? entry.typings : emptyArray2, + unresolvedImports, + poisoned: true + }); + this.installer.enqueueInstallTypingsRequest(project, typeAcquisition, unresolvedImports); + } + } + updateTypingsForProject(projectName, compilerOptions, typeAcquisition, unresolvedImports, newTypings) { + const typings = sort(newTypings); + this.perProjectCache.set(projectName, { + compilerOptions, + typeAcquisition, + typings, + unresolvedImports, + poisoned: false + }); + return !typeAcquisition || !typeAcquisition.enable ? emptyArray2 : typings; + } + onProjectClosed(project) { + this.perProjectCache.delete(project.getProjectName()); + this.installer.onProjectClosed(project); + } + }; } - if (group2) { - result.push(createSyntaxList2(group2)); + }); + + // src/server/project.ts + function countEachFileTypes(infos, includeSizes = false) { + const result = { + js: 0, + jsSize: 0, + jsx: 0, + jsxSize: 0, + ts: 0, + tsSize: 0, + tsx: 0, + tsxSize: 0, + dts: 0, + dtsSize: 0, + deferred: 0, + deferredSize: 0 + }; + for (const info of infos) { + const fileSize = includeSizes ? info.textStorage.getTelemetryFileSize() : 0; + switch (info.scriptKind) { + case 1 /* JS */: + result.js += 1; + result.jsSize += fileSize; + break; + case 2 /* JSX */: + result.jsx += 1; + result.jsxSize += fileSize; + break; + case 3 /* TS */: + if (isDeclarationFileName(info.fileName)) { + result.dts += 1; + result.dtsSize += fileSize; + } else { + result.ts += 1; + result.tsSize += fileSize; + } + break; + case 4 /* TSX */: + result.tsx += 1; + result.tsxSize += fileSize; + break; + case 7 /* Deferred */: + result.deferred += 1; + result.deferredSize += fileSize; + break; + } } return result; } - function splitChildren(children, pivotOn, separateTrailingSemicolon = true) { - if (children.length < 2) { - return children; - } - const splitTokenIndex = findIndex(children, pivotOn); - if (splitTokenIndex === -1) { - return children; - } - const leftChildren = children.slice(0, splitTokenIndex); - const splitToken = children[splitTokenIndex]; - const lastToken = last(children); - const separateLastToken = separateTrailingSemicolon && lastToken.kind === 27 /* SemicolonToken */; - const rightChildren = children.slice(splitTokenIndex + 1, separateLastToken ? children.length - 1 : void 0); - const result = compact([ - leftChildren.length ? createSyntaxList2(leftChildren) : void 0, - splitToken, - rightChildren.length ? createSyntaxList2(rightChildren) : void 0 - ]); - return separateLastToken ? result.concat(lastToken) : result; + function hasOneOrMoreJsAndNoTsFiles(project) { + const counts2 = countEachFileTypes(project.getScriptInfos()); + return counts2.js > 0 && counts2.ts === 0 && counts2.tsx === 0; } - function createSyntaxList2(children) { - Debug.assertGreaterThanOrEqual(children.length, 1); - return setTextRangePosEnd(parseNodeFactory.createSyntaxList(children), children[0].pos, last(children).end); + function allRootFilesAreJsOrDts(project) { + const counts2 = countEachFileTypes(project.getRootScriptInfos()); + return counts2.ts === 0 && counts2.tsx === 0; } - function isListOpener(token) { - const kind = token && token.kind; - return kind === 19 /* OpenBraceToken */ || kind === 23 /* OpenBracketToken */ || kind === 21 /* OpenParenToken */ || kind === 285 /* JsxOpeningElement */; + function allFilesAreJsOrDts(project) { + const counts2 = countEachFileTypes(project.getScriptInfos()); + return counts2.ts === 0 && counts2.tsx === 0; } - function isListCloser(token) { - const kind = token && token.kind; - return kind === 20 /* CloseBraceToken */ || kind === 24 /* CloseBracketToken */ || kind === 22 /* CloseParenToken */ || kind === 286 /* JsxClosingElement */; + function hasNoTypeScriptSource(fileNames) { + return !fileNames.some((fileName) => fileExtensionIs(fileName, ".ts" /* Ts */) && !isDeclarationFileName(fileName) || fileExtensionIs(fileName, ".tsx" /* Tsx */)); } - function getEndPos(sourceFile, node) { - switch (node.kind) { - case 347 /* JSDocParameterTag */: - case 344 /* JSDocCallbackTag */: - case 354 /* JSDocPropertyTag */: - case 352 /* JSDocTypedefTag */: - case 349 /* JSDocThisTag */: - return sourceFile.getLineEndOfPosition(node.getStart()); - default: - return node.getEnd(); - } + function isGeneratedFileWatcher(watch) { + return watch.generatedFilePath !== void 0; } - var isImport2; - var init_smartSelection = __esm({ - "src/services/smartSelection.ts"() { - "use strict"; - init_ts4(); - isImport2 = or(isImportDeclaration, isImportEqualsDeclaration); - } - }); - - // src/services/_namespaces/ts.SmartSelectionRange.ts - var ts_SmartSelectionRange_exports = {}; - __export(ts_SmartSelectionRange_exports, { - getSmartSelectionRange: () => getSmartSelectionRange - }); - var init_ts_SmartSelectionRange = __esm({ - "src/services/_namespaces/ts.SmartSelectionRange.ts"() { - "use strict"; - init_smartSelection(); - } - }); - - // src/services/symbolDisplay.ts - function getSymbolKind(typeChecker, symbol, location) { - const result = getSymbolKindOfConstructorPropertyMethodAccessorFunctionOrVar(typeChecker, symbol, location); - if (result !== "" /* unknown */) { - return result; - } - const flags = getCombinedLocalAndExportSymbolFlags(symbol); - if (flags & 32 /* Class */) { - return getDeclarationOfKind(symbol, 230 /* ClassExpression */) ? "local class" /* localClassElement */ : "class" /* classElement */; - } - if (flags & 384 /* Enum */) - return "enum" /* enumElement */; - if (flags & 524288 /* TypeAlias */) - return "type" /* typeElement */; - if (flags & 64 /* Interface */) - return "interface" /* interfaceElement */; - if (flags & 262144 /* TypeParameter */) - return "type parameter" /* typeParameterElement */; - if (flags & 8 /* EnumMember */) - return "enum member" /* enumMemberElement */; - if (flags & 2097152 /* Alias */) - return "alias" /* alias */; - if (flags & 1536 /* Module */) - return "module" /* moduleElement */; + function getUnresolvedImports(program, cachedUnresolvedImportsPerFile) { + var _a, _b; + const sourceFiles = program.getSourceFiles(); + (_a = tracing) == null ? void 0 : _a.push(tracing.Phase.Session, "getUnresolvedImports", { count: sourceFiles.length }); + const ambientModules = program.getTypeChecker().getAmbientModules().map((mod) => stripQuotes(mod.getName())); + const result = sortAndDeduplicate(flatMap(sourceFiles, (sourceFile) => extractUnresolvedImportsFromSourceFile( + program, + sourceFile, + ambientModules, + cachedUnresolvedImportsPerFile + ))); + (_b = tracing) == null ? void 0 : _b.pop(); return result; } - function getSymbolKindOfConstructorPropertyMethodAccessorFunctionOrVar(typeChecker, symbol, location) { - const roots = typeChecker.getRootSymbols(symbol); - if (roots.length === 1 && first(roots).flags & 8192 /* Method */ && typeChecker.getTypeOfSymbolAtLocation(symbol, location).getNonNullableType().getCallSignatures().length !== 0) { - return "method" /* memberFunctionElement */; - } - if (typeChecker.isUndefinedSymbol(symbol)) { - return "var" /* variableElement */; - } - if (typeChecker.isArgumentsSymbol(symbol)) { - return "local var" /* localVariableElement */; - } - if (location.kind === 110 /* ThisKeyword */ && isExpression(location) || isThisInTypeQuery(location)) { - return "parameter" /* parameterElement */; - } - const flags = getCombinedLocalAndExportSymbolFlags(symbol); - if (flags & 3 /* Variable */) { - if (isFirstDeclarationOfSymbolParameter(symbol)) { - return "parameter" /* parameterElement */; - } else if (symbol.valueDeclaration && isVarConst(symbol.valueDeclaration)) { - return "const" /* constElement */; - } else if (forEach(symbol.declarations, isLet)) { - return "let" /* letElement */; - } - return isLocalVariableOrFunction(symbol) ? "local var" /* localVariableElement */ : "var" /* variableElement */; - } - if (flags & 16 /* Function */) - return isLocalVariableOrFunction(symbol) ? "local function" /* localFunctionElement */ : "function" /* functionElement */; - if (flags & 32768 /* GetAccessor */) - return "getter" /* memberGetAccessorElement */; - if (flags & 65536 /* SetAccessor */) - return "setter" /* memberSetAccessorElement */; - if (flags & 8192 /* Method */) - return "method" /* memberFunctionElement */; - if (flags & 16384 /* Constructor */) - return "constructor" /* constructorImplementationElement */; - if (flags & 131072 /* Signature */) - return "index" /* indexSignatureElement */; - if (flags & 4 /* Property */) { - if (flags & 33554432 /* Transient */ && symbol.links.checkFlags & 6 /* Synthetic */) { - const unionPropertyKind = forEach(typeChecker.getRootSymbols(symbol), (rootSymbol) => { - const rootSymbolFlags = rootSymbol.getFlags(); - if (rootSymbolFlags & (98308 /* PropertyOrAccessor */ | 3 /* Variable */)) { - return "property" /* memberVariableElement */; - } - }); - if (!unionPropertyKind) { - const typeOfUnionProperty = typeChecker.getTypeOfSymbolAtLocation(symbol, location); - if (typeOfUnionProperty.getCallSignatures().length) { - return "method" /* memberFunctionElement */; - } - return "property" /* memberVariableElement */; + function extractUnresolvedImportsFromSourceFile(program, file, ambientModules, cachedUnresolvedImportsPerFile) { + return getOrUpdate(cachedUnresolvedImportsPerFile, file.path, () => { + let unresolvedImports; + program.forEachResolvedModule(({ resolvedModule }, name) => { + if ((!resolvedModule || !resolutionExtensionIsTSOrJson(resolvedModule.extension)) && !isExternalModuleNameRelative(name) && !ambientModules.some((m) => m === name)) { + unresolvedImports = append(unresolvedImports, parsePackageName(name).packageName); } - return unionPropertyKind; - } - return "property" /* memberVariableElement */; - } - return "" /* unknown */; + }, file); + return unresolvedImports || emptyArray2; + }); } - function getNormalizedSymbolModifiers(symbol) { - if (symbol.declarations && symbol.declarations.length) { - const [declaration, ...declarations] = symbol.declarations; - const excludeFlags = length(declarations) && isDeprecatedDeclaration(declaration) && some(declarations, (d) => !isDeprecatedDeclaration(d)) ? 8192 /* Deprecated */ : 0 /* None */; - const modifiers = getNodeModifiers(declaration, excludeFlags); - if (modifiers) { - return modifiers.split(","); - } - } - return []; + function isInferredProject(project) { + return project.projectKind === 0 /* Inferred */; } - function getSymbolModifiers(typeChecker, symbol) { - if (!symbol) { - return "" /* none */; - } - const modifiers = new Set(getNormalizedSymbolModifiers(symbol)); - if (symbol.flags & 2097152 /* Alias */) { - const resolvedSymbol = typeChecker.getAliasedSymbol(symbol); - if (resolvedSymbol !== symbol) { - forEach(getNormalizedSymbolModifiers(resolvedSymbol), (modifier) => { - modifiers.add(modifier); - }); - } - } - if (symbol.flags & 16777216 /* Optional */) { - modifiers.add("optional" /* optionalModifier */); - } - return modifiers.size > 0 ? arrayFrom(modifiers.values()).join(",") : "" /* none */; + function isConfiguredProject(project) { + return project.projectKind === 1 /* Configured */; } - function getSymbolDisplayPartsDocumentationAndSymbolKind(typeChecker, symbol, sourceFile, enclosingDeclaration, location, semanticMeaning = getMeaningFromLocation(location), alias) { - var _a; - const displayParts = []; - let documentation = []; - let tags = []; - const symbolFlags = getCombinedLocalAndExportSymbolFlags(symbol); - let symbolKind = semanticMeaning & 1 /* Value */ ? getSymbolKindOfConstructorPropertyMethodAccessorFunctionOrVar(typeChecker, symbol, location) : "" /* unknown */; - let hasAddedSymbolInfo = false; - const isThisExpression = location.kind === 110 /* ThisKeyword */ && isInExpressionContext(location) || isThisInTypeQuery(location); - let type; - let documentationFromAlias; - let tagsFromAlias; - let hasMultipleSignatures = false; - if (location.kind === 110 /* ThisKeyword */ && !isThisExpression) { - return { displayParts: [keywordPart(110 /* ThisKeyword */)], documentation: [], symbolKind: "primitive type" /* primitiveType */, tags: void 0 }; - } - if (symbolKind !== "" /* unknown */ || symbolFlags & 32 /* Class */ || symbolFlags & 2097152 /* Alias */) { - if (symbolKind === "getter" /* memberGetAccessorElement */ || symbolKind === "setter" /* memberSetAccessorElement */) { - const declaration = find(symbol.declarations, (declaration2) => declaration2.name === location); - if (declaration) { - switch (declaration.kind) { - case 176 /* GetAccessor */: - symbolKind = "getter" /* memberGetAccessorElement */; + function isExternalProject(project) { + return project.projectKind === 2 /* External */; + } + function isBackgroundProject(project) { + return project.projectKind === 3 /* AutoImportProvider */ || project.projectKind === 4 /* Auxiliary */; + } + var ProjectKind, Project3, InferredProject2, AuxiliaryProject, _AutoImportProviderProject, AutoImportProviderProject, ConfiguredProject2, ExternalProject2; + var init_project = __esm({ + "src/server/project.ts"() { + "use strict"; + init_pnp(); + init_ts7(); + init_ts7(); + init_ts_server3(); + ProjectKind = /* @__PURE__ */ ((ProjectKind2) => { + ProjectKind2[ProjectKind2["Inferred"] = 0] = "Inferred"; + ProjectKind2[ProjectKind2["Configured"] = 1] = "Configured"; + ProjectKind2[ProjectKind2["External"] = 2] = "External"; + ProjectKind2[ProjectKind2["AutoImportProvider"] = 3] = "AutoImportProvider"; + ProjectKind2[ProjectKind2["Auxiliary"] = 4] = "Auxiliary"; + return ProjectKind2; + })(ProjectKind || {}); + Project3 = class _Project { + /** @internal */ + constructor(projectName, projectKind, projectService, documentRegistry, hasExplicitListOfFiles, lastFileExceededProgramSize, compilerOptions, compileOnSaveEnabled, watchOptions, directoryStructureHost, currentDirectory) { + this.projectKind = projectKind; + this.projectService = projectService; + this.documentRegistry = documentRegistry; + this.compilerOptions = compilerOptions; + this.compileOnSaveEnabled = compileOnSaveEnabled; + this.watchOptions = watchOptions; + this.rootFiles = []; + this.rootFilesMap = /* @__PURE__ */ new Map(); + /** @internal */ + this.plugins = []; + /** + * This is map from files to unresolved imports in it + * Maop does not contain entries for files that do not have unresolved imports + * This helps in containing the set of files to invalidate + * + * @internal + */ + this.cachedUnresolvedImportsPerFile = /* @__PURE__ */ new Map(); + /** @internal */ + this.hasAddedorRemovedFiles = false; + /** @internal */ + this.hasAddedOrRemovedSymlinks = false; + /** + * Last version that was reported. + */ + this.lastReportedVersion = 0; + /** + * Current project's program version. (incremented everytime new program is created that is not complete reuse from the old one) + * This property is changed in 'updateGraph' based on the set of files in program + */ + this.projectProgramVersion = 0; + /** + * Current version of the project state. It is changed when: + * - new root file was added/removed + * - edit happen in some file that is currently included in the project. + * This property is different from projectStructureVersion since in most cases edits don't affect set of files in the project + */ + this.projectStateVersion = 0; + this.isInitialLoadPending = returnFalse; + /** @internal */ + this.dirty = false; + /** @internal */ + this.typingFiles = emptyArray2; + /** @internal */ + this.moduleSpecifierCache = createModuleSpecifierCache(this); + /** @internal */ + this.createHash = maybeBind(this.projectService.host, this.projectService.host.createHash); + /** @internal */ + this.globalCacheResolutionModuleName = ts_JsTyping_exports.nonRelativeModuleNameForTypingCache; + this.projectName = projectName; + this.directoryStructureHost = directoryStructureHost; + this.currentDirectory = this.projectService.getNormalizedAbsolutePath(currentDirectory); + this.getCanonicalFileName = this.projectService.toCanonicalFileName; + this.jsDocParsingMode = this.projectService.jsDocParsingMode; + this.cancellationToken = new ThrottledCancellationToken(this.projectService.cancellationToken, this.projectService.throttleWaitMilliseconds); + if (!this.compilerOptions) { + this.compilerOptions = getDefaultCompilerOptions2(); + this.compilerOptions.allowNonTsExtensions = true; + this.compilerOptions.allowJs = true; + } else if (hasExplicitListOfFiles || getAllowJSCompilerOption(this.compilerOptions) || this.projectService.hasDeferredExtension()) { + this.compilerOptions.allowNonTsExtensions = true; + } + switch (projectService.serverMode) { + case 0 /* Semantic */: + this.languageServiceEnabled = true; break; - case 177 /* SetAccessor */: - symbolKind = "setter" /* memberSetAccessorElement */; + case 1 /* PartialSemantic */: + this.languageServiceEnabled = true; + this.compilerOptions.noResolve = true; + this.compilerOptions.types = []; break; - case 171 /* PropertyDeclaration */: - symbolKind = "accessor" /* memberAccessorVariableElement */; + case 2 /* Syntactic */: + this.languageServiceEnabled = false; + this.compilerOptions.noResolve = true; + this.compilerOptions.types = []; break; default: - Debug.assertNever(declaration); + Debug.assertNever(projectService.serverMode); + } + this.setInternalCompilerOptionsForEmittingJsFiles(); + const host = this.projectService.host; + if (this.projectService.logger.loggingEnabled()) { + this.trace = (s) => this.writeLog(s); + } else if (host.trace) { + this.trace = (s) => host.trace(s); + } + this.realpath = maybeBind(host, host.realpath); + this.resolutionCache = createResolutionCache( + this, + this.currentDirectory, + /*logChangesWhenResolvingModule*/ + true + ); + this.languageService = createLanguageService(this, this.documentRegistry, this.projectService.serverMode); + if (lastFileExceededProgramSize) { + this.disableLanguageService(lastFileExceededProgramSize); } - } else { - symbolKind = "property" /* memberVariableElement */; + this.markAsDirty(); + if (!isBackgroundProject(this)) { + this.projectService.pendingEnsureProjectForOpenFiles = true; + } + this.projectService.onProjectCreation(this); } - } - let signature; - type = isThisExpression ? typeChecker.getTypeAtLocation(location) : typeChecker.getTypeOfSymbolAtLocation(symbol, location); - if (location.parent && location.parent.kind === 210 /* PropertyAccessExpression */) { - const right = location.parent.name; - if (right === location || right && right.getFullWidth() === 0) { - location = location.parent; + /** @internal */ + getResolvedProjectReferenceToRedirect(_fileName) { + return void 0; } - } - let callExpressionLike; - if (isCallOrNewExpression(location)) { - callExpressionLike = location; - } else if (isCallExpressionTarget(location) || isNewExpressionTarget(location)) { - callExpressionLike = location.parent; - } else if (location.parent && (isJsxOpeningLikeElement(location.parent) || isTaggedTemplateExpression(location.parent)) && isFunctionLike(symbol.valueDeclaration)) { - callExpressionLike = location.parent; - } - if (callExpressionLike) { - signature = typeChecker.getResolvedSignature(callExpressionLike); - const useConstructSignatures = callExpressionLike.kind === 213 /* NewExpression */ || isCallExpression(callExpressionLike) && callExpressionLike.expression.kind === 108 /* SuperKeyword */; - const allSignatures = useConstructSignatures ? type.getConstructSignatures() : type.getCallSignatures(); - if (signature && !contains(allSignatures, signature.target) && !contains(allSignatures, signature)) { - signature = allSignatures.length ? allSignatures[0] : void 0; + isNonTsProject() { + updateProjectIfDirty(this); + return allFilesAreJsOrDts(this); } - if (signature) { - if (useConstructSignatures && symbolFlags & 32 /* Class */) { - symbolKind = "constructor" /* constructorImplementationElement */; - addPrefixForAnyFunctionOrVar(type.symbol, symbolKind); - } else if (symbolFlags & 2097152 /* Alias */) { - symbolKind = "alias" /* alias */; - pushSymbolKind(symbolKind); - displayParts.push(spacePart()); - if (useConstructSignatures) { - if (signature.flags & 4 /* Abstract */) { - displayParts.push(keywordPart(128 /* AbstractKeyword */)); - displayParts.push(spacePart()); + isJsOnlyProject() { + updateProjectIfDirty(this); + return hasOneOrMoreJsAndNoTsFiles(this); + } + static resolveModule(moduleName, initialDir, host, log) { + return _Project.importServicePluginSync({ name: moduleName }, [initialDir], host, log).resolvedModule; + } + /** @internal */ + static importServicePluginSync(pluginConfigEntry, searchPaths, host, log) { + Debug.assertIsDefined(host.require); + let errorLogs; + let resolvedModule; + for (const initialDir of searchPaths) { + const resolvedPath = normalizeSlashes(host.resolvePath(combinePaths(initialDir, "node_modules"))); + log(`Loading ${pluginConfigEntry.name} from ${initialDir} (resolved to ${resolvedPath})`); + const result = host.require(resolvedPath, pluginConfigEntry.name); + if (!result.error) { + resolvedModule = result.module; + break; + } + const err = result.error.stack || result.error.message || JSON.stringify(result.error); + (errorLogs ?? (errorLogs = [])).push(`Failed to load module '${pluginConfigEntry.name}' from ${resolvedPath}: ${err}`); + } + return { pluginConfigEntry, resolvedModule, errorLogs }; + } + /** @internal */ + static async importServicePluginAsync(pluginConfigEntry, searchPaths, host, log) { + Debug.assertIsDefined(host.importPlugin); + let errorLogs; + let resolvedModule; + for (const initialDir of searchPaths) { + const resolvedPath = combinePaths(initialDir, "node_modules"); + log(`Dynamically importing ${pluginConfigEntry.name} from ${initialDir} (resolved to ${resolvedPath})`); + let result; + try { + result = await host.importPlugin(resolvedPath, pluginConfigEntry.name); + } catch (e) { + result = { module: void 0, error: e }; + } + if (!result.error) { + resolvedModule = result.module; + break; + } + const err = result.error.stack || result.error.message || JSON.stringify(result.error); + (errorLogs ?? (errorLogs = [])).push(`Failed to dynamically import module '${pluginConfigEntry.name}' from ${resolvedPath}: ${err}`); + } + return { pluginConfigEntry, resolvedModule, errorLogs }; + } + isKnownTypesPackageName(name) { + return this.typingsCache.isKnownTypesPackageName(name); + } + installPackage(options) { + return this.typingsCache.installPackage({ ...options, projectName: this.projectName, projectRootPath: this.toPath(this.currentDirectory) }); + } + /** @internal */ + getGlobalTypingsCacheLocation() { + return this.getGlobalCache(); + } + get typingsCache() { + return this.projectService.typingsCache; + } + /** @internal */ + getSymlinkCache() { + if (!this.symlinks) { + this.symlinks = createSymlinkCache(this.getCurrentDirectory(), this.getCanonicalFileName); + } + if (this.program && !this.symlinks.hasProcessedResolutions()) { + this.symlinks.setSymlinksFromResolutions( + this.program.forEachResolvedModule, + this.program.forEachResolvedTypeReferenceDirective, + this.program.getAutomaticTypeDirectiveResolutions() + ); + } + return this.symlinks; + } + // Method of LanguageServiceHost + getCompilationSettings() { + return this.compilerOptions; + } + // Method to support public API + getCompilerOptions() { + return this.getCompilationSettings(); + } + getNewLine() { + return this.projectService.host.newLine; + } + getProjectVersion() { + return this.projectStateVersion.toString(); + } + getProjectReferences() { + return void 0; + } + getScriptFileNames() { + if (!this.rootFiles) { + return emptyArray; + } + let result; + this.rootFilesMap.forEach((value) => { + if (this.languageServiceEnabled || value.info && value.info.isScriptOpen()) { + (result || (result = [])).push(value.fileName); + } + }); + return addRange(result, this.typingFiles) || emptyArray; + } + getOrCreateScriptInfoAndAttachToProject(fileName) { + const scriptInfo = this.projectService.getOrCreateScriptInfoNotOpenedByClient(fileName, this.currentDirectory, this.directoryStructureHost); + if (scriptInfo) { + const existingValue = this.rootFilesMap.get(scriptInfo.path); + if (existingValue && existingValue.info !== scriptInfo) { + this.rootFiles.push(scriptInfo); + existingValue.info = scriptInfo; + } + scriptInfo.attachToProject(this); + } + return scriptInfo; + } + getScriptKind(fileName) { + const info = this.projectService.getScriptInfoForPath(this.toPath(fileName)); + return info && info.scriptKind; + } + getScriptVersion(filename) { + const info = this.projectService.getOrCreateScriptInfoNotOpenedByClient(filename, this.currentDirectory, this.directoryStructureHost); + return info && info.getLatestVersion(); + } + getScriptSnapshot(filename) { + const scriptInfo = this.getOrCreateScriptInfoAndAttachToProject(filename); + if (scriptInfo) { + return scriptInfo.getSnapshot(); + } + } + getCancellationToken() { + return this.cancellationToken; + } + getCurrentDirectory() { + return this.currentDirectory; + } + getDefaultLibFileName() { + const nodeModuleBinDir = getDirectoryPath(normalizePath(this.projectService.getExecutingFilePath())); + return combinePaths(nodeModuleBinDir, getDefaultLibFileName(this.compilerOptions)); + } + useCaseSensitiveFileNames() { + return this.projectService.host.useCaseSensitiveFileNames; + } + readDirectory(path, extensions, exclude, include, depth) { + return this.directoryStructureHost.readDirectory(path, extensions, exclude, include, depth); + } + readFile(fileName) { + return this.projectService.host.readFile(fileName); + } + writeFile(fileName, content) { + return this.projectService.host.writeFile(fileName, content); + } + fileExists(file) { + const path = this.toPath(file); + return !this.isWatchedMissingFile(path) && this.directoryStructureHost.fileExists(file); + } + /** @internal */ + resolveModuleNameLiterals(moduleLiterals, containingFile, redirectedReference, options, containingSourceFile, reusedNames) { + return this.resolutionCache.resolveModuleNameLiterals(moduleLiterals, containingFile, redirectedReference, options, containingSourceFile, reusedNames); + } + /** @internal */ + getModuleResolutionCache() { + return this.resolutionCache.getModuleResolutionCache(); + } + /** @internal */ + resolveTypeReferenceDirectiveReferences(typeDirectiveReferences, containingFile, redirectedReference, options, containingSourceFile, reusedNames) { + return this.resolutionCache.resolveTypeReferenceDirectiveReferences( + typeDirectiveReferences, + containingFile, + redirectedReference, + options, + containingSourceFile, + reusedNames + ); + } + /** @internal */ + resolveLibrary(libraryName, resolveFrom, options, libFileName) { + return this.resolutionCache.resolveLibrary(libraryName, resolveFrom, options, libFileName); + } + directoryExists(path) { + return this.directoryStructureHost.directoryExists(path); + } + getDirectories(path) { + return this.directoryStructureHost.getDirectories(path); + } + /** @internal */ + getCachedDirectoryStructureHost() { + return void 0; + } + /** @internal */ + toPath(fileName) { + return toPath(fileName, this.currentDirectory, this.projectService.toCanonicalFileName); + } + /** @internal */ + watchDirectoryOfFailedLookupLocation(directory, cb, flags) { + return this.projectService.watchFactory.watchDirectory( + directory, + cb, + flags, + this.projectService.getWatchOptions(this), + WatchType.FailedLookupLocations, + this + ); + } + /** @internal */ + watchAffectingFileLocation(file, cb) { + return this.projectService.watchFactory.watchFile( + file, + cb, + 2e3 /* High */, + this.projectService.getWatchOptions(this), + WatchType.AffectingFileLocation, + this + ); + } + /** @internal */ + clearInvalidateResolutionOfFailedLookupTimer() { + return this.projectService.throttledOperations.cancel(`${this.getProjectName()}FailedLookupInvalidation`); + } + /** @internal */ + scheduleInvalidateResolutionsOfFailedLookupLocations() { + this.projectService.throttledOperations.schedule( + `${this.getProjectName()}FailedLookupInvalidation`, + /*delay*/ + 1e3, + () => { + if (this.resolutionCache.invalidateResolutionsOfFailedLookupLocations()) { + this.projectService.delayUpdateProjectGraphAndEnsureProjectStructureForOpenFiles(this); } - displayParts.push(keywordPart(105 /* NewKeyword */)); - displayParts.push(spacePart()); } - addFullSymbolName(symbol); + ); + } + /** @internal */ + invalidateResolutionsOfFailedLookupLocations() { + if (this.clearInvalidateResolutionOfFailedLookupTimer() && this.resolutionCache.invalidateResolutionsOfFailedLookupLocations()) { + this.markAsDirty(); + this.projectService.delayEnsureProjectForOpenFiles(); + } + } + /** @internal */ + onInvalidatedResolution() { + this.projectService.delayUpdateProjectGraphAndEnsureProjectStructureForOpenFiles(this); + } + /** @internal */ + watchTypeRootsDirectory(directory, cb, flags) { + return this.projectService.watchFactory.watchDirectory( + directory, + cb, + flags, + this.projectService.getWatchOptions(this), + WatchType.TypeRoots, + this + ); + } + /** @internal */ + hasChangedAutomaticTypeDirectiveNames() { + return this.resolutionCache.hasChangedAutomaticTypeDirectiveNames(); + } + /** @internal */ + onChangedAutomaticTypeDirectiveNames() { + this.projectService.delayUpdateProjectGraphAndEnsureProjectStructureForOpenFiles(this); + } + /** @internal */ + getGlobalCache() { + return this.getTypeAcquisition().enable ? this.projectService.typingsInstaller.globalTypingsCacheLocation : void 0; + } + /** @internal */ + fileIsOpen(filePath) { + return this.projectService.openFiles.has(filePath); + } + /** @internal */ + writeLog(s) { + this.projectService.logger.info(s); + } + log(s) { + this.writeLog(s); + } + error(s) { + this.projectService.logger.msg(s, "Err" /* Err */); + } + setInternalCompilerOptionsForEmittingJsFiles() { + if (this.projectKind === 0 /* Inferred */ || this.projectKind === 2 /* External */) { + this.compilerOptions.noEmitForJsFiles = true; + } + } + /** + * Get the errors that dont have any file name associated + */ + getGlobalProjectErrors() { + return filter(this.projectErrors, (diagnostic) => !diagnostic.file) || emptyArray2; + } + /** + * Get all the project errors + */ + getAllProjectErrors() { + return this.projectErrors || emptyArray2; + } + setProjectErrors(projectErrors) { + this.projectErrors = projectErrors; + } + getLanguageService(ensureSynchronized = true) { + if (ensureSynchronized) { + updateProjectIfDirty(this); + } + return this.languageService; + } + /** @internal */ + getSourceMapper() { + return this.getLanguageService().getSourceMapper(); + } + /** @internal */ + clearSourceMapperCache() { + this.languageService.clearSourceMapperCache(); + } + /** @internal */ + getDocumentPositionMapper(generatedFileName, sourceFileName) { + return this.projectService.getDocumentPositionMapper(this, generatedFileName, sourceFileName); + } + /** @internal */ + getSourceFileLike(fileName) { + return this.projectService.getSourceFileLike(fileName, this); + } + /** @internal */ + shouldEmitFile(scriptInfo) { + return scriptInfo && !scriptInfo.isDynamicOrHasMixedContent() && !this.program.isSourceOfProjectReferenceRedirect(scriptInfo.path); + } + getCompileOnSaveAffectedFileList(scriptInfo) { + if (!this.languageServiceEnabled) { + return []; + } + updateProjectIfDirty(this); + this.builderState = BuilderState.create( + this.program, + this.builderState, + /*disableUseFileVersionAsSignature*/ + true + ); + return mapDefined( + BuilderState.getFilesAffectedBy( + this.builderState, + this.program, + scriptInfo.path, + this.cancellationToken, + this.projectService.host + ), + (sourceFile) => this.shouldEmitFile(this.projectService.getScriptInfoForPath(sourceFile.path)) ? sourceFile.fileName : void 0 + ); + } + /** + * Returns true if emit was conducted + */ + emitFile(scriptInfo, writeFile2) { + if (!this.languageServiceEnabled || !this.shouldEmitFile(scriptInfo)) { + return { emitSkipped: true, diagnostics: emptyArray2 }; + } + const { emitSkipped, diagnostics, outputFiles } = this.getLanguageService().getEmitOutput(scriptInfo.fileName); + if (!emitSkipped) { + for (const outputFile of outputFiles) { + const outputFileAbsoluteFileName = getNormalizedAbsolutePath(outputFile.name, this.currentDirectory); + writeFile2(outputFileAbsoluteFileName, outputFile.text, outputFile.writeByteOrderMark); + } + if (this.builderState && getEmitDeclarations(this.compilerOptions)) { + const dtsFiles = outputFiles.filter((f) => isDeclarationFileName(f.name)); + if (dtsFiles.length === 1) { + const sourceFile = this.program.getSourceFile(scriptInfo.fileName); + const signature = this.projectService.host.createHash ? this.projectService.host.createHash(dtsFiles[0].text) : generateDjb2Hash(dtsFiles[0].text); + BuilderState.updateSignatureOfFile(this.builderState, signature, sourceFile.resolvedPath); + } + } + } + return { emitSkipped, diagnostics }; + } + enableLanguageService() { + if (this.languageServiceEnabled || this.projectService.serverMode === 2 /* Syntactic */) { + return; + } + this.languageServiceEnabled = true; + this.lastFileExceededProgramSize = void 0; + this.projectService.onUpdateLanguageServiceStateForProject( + this, + /*languageServiceEnabled*/ + true + ); + } + /** @internal */ + cleanupProgram() { + if (this.program) { + for (const f of this.program.getSourceFiles()) { + this.detachScriptInfoIfNotRoot(f.fileName); + } + this.program.forEachResolvedProjectReference((ref) => this.detachScriptInfoFromProject(ref.sourceFile.fileName)); + this.program = void 0; + } + } + disableLanguageService(lastFileExceededProgramSize) { + if (!this.languageServiceEnabled) { + return; + } + Debug.assert(this.projectService.serverMode !== 2 /* Syntactic */); + this.languageService.cleanupSemanticCache(); + this.languageServiceEnabled = false; + this.cleanupProgram(); + this.lastFileExceededProgramSize = lastFileExceededProgramSize; + this.builderState = void 0; + if (this.autoImportProviderHost) { + this.autoImportProviderHost.close(); + } + this.autoImportProviderHost = void 0; + this.resolutionCache.closeTypeRootsWatch(); + this.clearGeneratedFileWatch(); + this.projectService.verifyDocumentRegistry(); + this.projectService.onUpdateLanguageServiceStateForProject( + this, + /*languageServiceEnabled*/ + false + ); + } + getProjectName() { + return this.projectName; + } + removeLocalTypingsFromTypeAcquisition(newTypeAcquisition) { + if (!newTypeAcquisition || !newTypeAcquisition.include) { + return newTypeAcquisition; + } + return { ...newTypeAcquisition, include: this.removeExistingTypings(newTypeAcquisition.include) }; + } + getExternalFiles(updateLevel) { + return sort(flatMap(this.plugins, (plugin) => { + if (typeof plugin.module.getExternalFiles !== "function") + return; + try { + return plugin.module.getExternalFiles(this, updateLevel || 0 /* Update */); + } catch (e) { + this.projectService.logger.info(`A plugin threw an exception in getExternalFiles: ${e}`); + if (e.stack) { + this.projectService.logger.info(e.stack); + } + } + })); + } + getSourceFile(path) { + if (!this.program) { + return void 0; + } + return this.program.getSourceFileByPath(path); + } + /** @internal */ + getSourceFileOrConfigFile(path) { + const options = this.program.getCompilerOptions(); + return path === options.configFilePath ? options.configFile : this.getSourceFile(path); + } + close() { + this.projectService.typingsCache.onProjectClosed(this); + this.closeWatchingTypingLocations(); + this.cleanupProgram(); + forEach(this.externalFiles, (externalFile) => this.detachScriptInfoIfNotRoot(externalFile)); + for (const root of this.rootFiles) { + root.detachFromProject(this); + } + this.projectService.pendingEnsureProjectForOpenFiles = true; + this.rootFiles = void 0; + this.rootFilesMap = void 0; + this.externalFiles = void 0; + this.program = void 0; + this.builderState = void 0; + this.resolutionCache.clear(); + this.resolutionCache = void 0; + this.cachedUnresolvedImportsPerFile = void 0; + this.moduleSpecifierCache = void 0; + this.directoryStructureHost = void 0; + this.exportMapCache = void 0; + this.projectErrors = void 0; + this.plugins.length = 0; + if (this.missingFilesMap) { + clearMap(this.missingFilesMap, closeFileWatcher); + this.missingFilesMap = void 0; + } + this.clearGeneratedFileWatch(); + this.clearInvalidateResolutionOfFailedLookupTimer(); + if (this.autoImportProviderHost) { + this.autoImportProviderHost.close(); + } + this.autoImportProviderHost = void 0; + if (this.noDtsResolutionProject) { + this.noDtsResolutionProject.close(); + } + this.noDtsResolutionProject = void 0; + this.languageService.dispose(); + this.languageService = void 0; + } + detachScriptInfoIfNotRoot(uncheckedFilename) { + const info = this.projectService.getScriptInfo(uncheckedFilename); + if (info && !this.isRoot(info)) { + info.detachFromProject(this); + } + } + isClosed() { + return this.rootFiles === void 0; + } + hasRoots() { + return this.rootFiles && this.rootFiles.length > 0; + } + /** @internal */ + isOrphan() { + return false; + } + getRootFiles() { + return this.rootFiles && this.rootFiles.map((info) => info.fileName); + } + /** @internal */ + getRootFilesMap() { + return this.rootFilesMap; + } + getRootScriptInfos() { + return this.rootFiles; + } + getScriptInfos() { + if (!this.languageServiceEnabled) { + return this.rootFiles; + } + return map(this.program.getSourceFiles(), (sourceFile) => { + const scriptInfo = this.projectService.getScriptInfoForPath(sourceFile.resolvedPath); + Debug.assert(!!scriptInfo, "getScriptInfo", () => `scriptInfo for a file '${sourceFile.fileName}' Path: '${sourceFile.path}' / '${sourceFile.resolvedPath}' is missing.`); + return scriptInfo; + }); + } + getExcludedFiles() { + return emptyArray2; + } + getFileNames(excludeFilesFromExternalLibraries, excludeConfigFiles) { + if (!this.program) { + return []; + } + if (!this.languageServiceEnabled) { + let rootFiles = this.getRootFiles(); + if (this.compilerOptions) { + const defaultLibrary = getDefaultLibFilePath(this.compilerOptions); + if (defaultLibrary) { + (rootFiles || (rootFiles = [])).push(asNormalizedPath(defaultLibrary)); + } + } + return rootFiles; + } + const result = []; + for (const f of this.program.getSourceFiles()) { + if (excludeFilesFromExternalLibraries && this.program.isSourceFileFromExternalLibrary(f)) { + continue; + } + result.push(asNormalizedPath(f.fileName)); + } + if (!excludeConfigFiles) { + const configFile = this.program.getCompilerOptions().configFile; + if (configFile) { + result.push(asNormalizedPath(configFile.fileName)); + if (configFile.extendedSourceFiles) { + for (const f of configFile.extendedSourceFiles) { + result.push(asNormalizedPath(f)); + } + } + } + } + return result; + } + /** @internal */ + getFileNamesWithRedirectInfo(includeProjectReferenceRedirectInfo) { + return this.getFileNames().map((fileName) => ({ + fileName, + isSourceOfProjectReferenceRedirect: includeProjectReferenceRedirectInfo && this.isSourceOfProjectReferenceRedirect(fileName) + })); + } + hasConfigFile(configFilePath) { + if (this.program && this.languageServiceEnabled) { + const configFile = this.program.getCompilerOptions().configFile; + if (configFile) { + if (configFilePath === asNormalizedPath(configFile.fileName)) { + return true; + } + if (configFile.extendedSourceFiles) { + for (const f of configFile.extendedSourceFiles) { + if (configFilePath === asNormalizedPath(f)) { + return true; + } + } + } + } + } + return false; + } + containsScriptInfo(info) { + if (this.isRoot(info)) + return true; + if (!this.program) + return false; + const file = this.program.getSourceFileByPath(info.path); + return !!file && file.resolvedPath === info.path; + } + containsFile(filename, requireOpen) { + const info = this.projectService.getScriptInfoForNormalizedPath(filename); + if (info && (info.isScriptOpen() || !requireOpen)) { + return this.containsScriptInfo(info); + } + return false; + } + isRoot(info) { + var _a; + return this.rootFilesMap && ((_a = this.rootFilesMap.get(info.path)) == null ? void 0 : _a.info) === info; + } + // add a root file to project + addRoot(info, fileName) { + Debug.assert(!this.isRoot(info)); + this.rootFiles.push(info); + this.rootFilesMap.set(info.path, { fileName: fileName || info.fileName, info }); + info.attachToProject(this); + this.markAsDirty(); + } + // add a root file that doesnt exist on host + addMissingFileRoot(fileName) { + const path = this.projectService.toPath(fileName); + this.rootFilesMap.set(path, { fileName }); + this.markAsDirty(); + } + removeFile(info, fileExists, detachFromProject) { + if (this.isRoot(info)) { + this.removeRoot(info); + } + if (fileExists) { + this.resolutionCache.removeResolutionsOfFile(info.path); } else { - addPrefixForAnyFunctionOrVar(symbol, symbolKind); + this.resolutionCache.invalidateResolutionOfFile(info.path); } - switch (symbolKind) { - case "JSX attribute" /* jsxAttribute */: - case "property" /* memberVariableElement */: - case "var" /* variableElement */: - case "const" /* constElement */: - case "let" /* letElement */: - case "parameter" /* parameterElement */: - case "local var" /* localVariableElement */: - displayParts.push(punctuationPart(59 /* ColonToken */)); - displayParts.push(spacePart()); - if (!(getObjectFlags(type) & 16 /* Anonymous */) && type.symbol) { - addRange(displayParts, symbolToDisplayParts( - typeChecker, - type.symbol, - enclosingDeclaration, - /*meaning*/ - void 0, - 4 /* AllowAnyNodeKind */ | 1 /* WriteTypeParametersOrArguments */ - )); - displayParts.push(lineBreakPart()); + this.cachedUnresolvedImportsPerFile.delete(info.path); + if (detachFromProject) { + info.detachFromProject(this); + } + this.markAsDirty(); + } + registerFileUpdate(fileName) { + (this.updatedFileNames || (this.updatedFileNames = /* @__PURE__ */ new Set())).add(fileName); + } + /** @internal */ + markFileAsDirty(changedFile) { + this.markAsDirty(); + if (this.exportMapCache && !this.exportMapCache.isEmpty()) { + (this.changedFilesForExportMapCache || (this.changedFilesForExportMapCache = /* @__PURE__ */ new Set())).add(changedFile); + } + } + markAsDirty() { + if (!this.dirty) { + this.projectStateVersion++; + this.dirty = true; + } + } + /** @internal */ + onAutoImportProviderSettingsChanged() { + var _a; + if (this.autoImportProviderHost === false) { + this.autoImportProviderHost = void 0; + } else { + (_a = this.autoImportProviderHost) == null ? void 0 : _a.markAsDirty(); + } + } + /** @internal */ + onPackageJsonChange(packageJsonPath) { + var _a; + if ((_a = this.packageJsonsForAutoImport) == null ? void 0 : _a.has(packageJsonPath)) { + this.moduleSpecifierCache.clear(); + if (this.autoImportProviderHost) { + this.autoImportProviderHost.markAsDirty(); + } + } + } + /** @internal */ + onFileAddedOrRemoved(isSymlink) { + this.hasAddedorRemovedFiles = true; + if (isSymlink) { + this.hasAddedOrRemovedSymlinks = true; + } + } + /** @internal */ + onDiscoveredSymlink() { + this.hasAddedOrRemovedSymlinks = true; + } + /** + * Updates set of files that contribute to this project + * @returns: true if set of files in the project stays the same and false - otherwise. + */ + updateGraph() { + var _a, _b, _c, _d, _e; + (_a = tracing) == null ? void 0 : _a.push(tracing.Phase.Session, "updateGraph", { name: this.projectName, kind: ProjectKind[this.projectKind] }); + (_b = perfLogger) == null ? void 0 : _b.logStartUpdateGraph(); + this.resolutionCache.startRecordingFilesWithChangedResolutions(); + const hasNewProgram = this.updateGraphWorker(); + const hasAddedorRemovedFiles = this.hasAddedorRemovedFiles; + this.hasAddedorRemovedFiles = false; + this.hasAddedOrRemovedSymlinks = false; + const changedFiles = this.resolutionCache.finishRecordingFilesWithChangedResolutions() || emptyArray2; + for (const file of changedFiles) { + this.cachedUnresolvedImportsPerFile.delete(file); + } + if (this.languageServiceEnabled && this.projectService.serverMode === 0 /* Semantic */) { + if (hasNewProgram || changedFiles.length) { + this.lastCachedUnresolvedImportsList = getUnresolvedImports(this.program, this.cachedUnresolvedImportsPerFile); + } + this.projectService.typingsCache.enqueueInstallTypingsForProject(this, this.lastCachedUnresolvedImportsList, hasAddedorRemovedFiles); + } else { + this.lastCachedUnresolvedImportsList = void 0; + } + const isFirstProgramLoad = this.projectProgramVersion === 0 && hasNewProgram; + if (hasNewProgram) { + this.projectProgramVersion++; + } + if (hasAddedorRemovedFiles) { + if (!this.autoImportProviderHost) + this.autoImportProviderHost = void 0; + (_c = this.autoImportProviderHost) == null ? void 0 : _c.markAsDirty(); + } + if (isFirstProgramLoad) { + this.getPackageJsonAutoImportProvider(); + } + (_d = perfLogger) == null ? void 0 : _d.logStopUpdateGraph(); + (_e = tracing) == null ? void 0 : _e.pop(); + return !hasNewProgram; + } + /** @internal */ + updateTypingFiles(typingFiles) { + if (enumerateInsertsAndDeletes( + typingFiles, + this.typingFiles, + getStringComparer(!this.useCaseSensitiveFileNames()), + /*inserted*/ + noop, + (removed) => this.detachScriptInfoFromProject(removed) + )) { + this.typingFiles = typingFiles; + this.resolutionCache.setFilesWithInvalidatedNonRelativeUnresolvedImports(this.cachedUnresolvedImportsPerFile); + this.projectService.delayUpdateProjectGraphAndEnsureProjectStructureForOpenFiles(this); + } + } + /** @internal */ + closeWatchingTypingLocations() { + if (this.typingWatchers) + clearMap(this.typingWatchers, closeFileWatcher); + this.typingWatchers = void 0; + } + /** @internal */ + onTypingInstallerWatchInvoke() { + this.typingWatchers.isInvoked = true; + this.projectService.updateTypingsForProject({ projectName: this.getProjectName(), kind: ActionInvalidate }); + } + /** @internal */ + watchTypingLocations(files) { + if (!files) { + this.typingWatchers.isInvoked = false; + return; + } + if (!files.length) { + this.closeWatchingTypingLocations(); + return; + } + const toRemove = new Map(this.typingWatchers); + if (!this.typingWatchers) + this.typingWatchers = /* @__PURE__ */ new Map(); + this.typingWatchers.isInvoked = false; + const createProjectWatcher = (path, typingsWatcherType) => { + const canonicalPath = this.toPath(path); + toRemove.delete(canonicalPath); + if (!this.typingWatchers.has(canonicalPath)) { + this.typingWatchers.set( + canonicalPath, + typingsWatcherType === "FileWatcher" /* FileWatcher */ ? this.projectService.watchFactory.watchFile( + path, + () => !this.typingWatchers.isInvoked ? this.onTypingInstallerWatchInvoke() : this.writeLog(`TypingWatchers already invoked`), + 2e3 /* High */, + this.projectService.getWatchOptions(this), + WatchType.TypingInstallerLocationFile, + this + ) : this.projectService.watchFactory.watchDirectory( + path, + (f) => { + if (this.typingWatchers.isInvoked) + return this.writeLog(`TypingWatchers already invoked`); + if (!fileExtensionIs(f, ".json" /* Json */)) + return this.writeLog(`Ignoring files that are not *.json`); + if (comparePaths(f, combinePaths(this.projectService.typingsInstaller.globalTypingsCacheLocation, "package.json"), !this.useCaseSensitiveFileNames())) + return this.writeLog(`Ignoring package.json change at global typings location`); + this.onTypingInstallerWatchInvoke(); + }, + 1 /* Recursive */, + this.projectService.getWatchOptions(this), + WatchType.TypingInstallerLocationDirectory, + this + ) + ); + } + }; + for (const file of files) { + const basename = getBaseFileName(file); + if (basename === "package.json" || basename === "bower.json") { + createProjectWatcher(file, "FileWatcher" /* FileWatcher */); + continue; + } + if (containsPath(this.currentDirectory, file, this.currentDirectory, !this.useCaseSensitiveFileNames())) { + const subDirectory = file.indexOf(directorySeparator, this.currentDirectory.length + 1); + if (subDirectory !== -1) { + createProjectWatcher(file.substr(0, subDirectory), "DirectoryWatcher" /* DirectoryWatcher */); + } else { + createProjectWatcher(file, "DirectoryWatcher" /* DirectoryWatcher */); } - if (useConstructSignatures) { - if (signature.flags & 4 /* Abstract */) { - displayParts.push(keywordPart(128 /* AbstractKeyword */)); - displayParts.push(spacePart()); + continue; + } + if (containsPath(this.projectService.typingsInstaller.globalTypingsCacheLocation, file, this.currentDirectory, !this.useCaseSensitiveFileNames())) { + createProjectWatcher(this.projectService.typingsInstaller.globalTypingsCacheLocation, "DirectoryWatcher" /* DirectoryWatcher */); + continue; + } + createProjectWatcher(file, "DirectoryWatcher" /* DirectoryWatcher */); + } + toRemove.forEach((watch, path) => { + watch.close(); + this.typingWatchers.delete(path); + }); + } + /** @internal */ + getCurrentProgram() { + return this.program; + } + removeExistingTypings(include) { + const existing = getAutomaticTypeDirectiveNames(this.getCompilerOptions(), this.directoryStructureHost); + return include.filter((i) => !existing.includes(i)); + } + updateGraphWorker() { + var _a, _b; + const oldProgram = this.languageService.getCurrentProgram(); + Debug.assert(oldProgram === this.program); + Debug.assert(!this.isClosed(), "Called update graph worker of closed project"); + this.writeLog(`Starting updateGraphWorker: Project: ${this.getProjectName()}`); + const start = timestamp(); + const { hasInvalidatedResolutions, hasInvalidatedLibResolutions } = this.resolutionCache.createHasInvalidatedResolutions(returnFalse, returnFalse); + this.hasInvalidatedResolutions = hasInvalidatedResolutions; + this.hasInvalidatedLibResolutions = hasInvalidatedLibResolutions; + this.resolutionCache.startCachingPerDirectoryResolution(); + this.program = this.languageService.getProgram(); + this.dirty = false; + (_a = tracing) == null ? void 0 : _a.push(tracing.Phase.Session, "finishCachingPerDirectoryResolution"); + this.resolutionCache.finishCachingPerDirectoryResolution(this.program, oldProgram); + (_b = tracing) == null ? void 0 : _b.pop(); + Debug.assert(oldProgram === void 0 || this.program !== void 0); + let hasNewProgram = false; + if (this.program && (!oldProgram || this.program !== oldProgram && this.program.structureIsReused !== 2 /* Completely */)) { + hasNewProgram = true; + if (oldProgram) { + for (const f of oldProgram.getSourceFiles()) { + const newFile = this.program.getSourceFileByPath(f.resolvedPath); + if (!newFile || f.resolvedPath === f.path && newFile.resolvedPath !== f.path) { + this.detachScriptInfoFromProject( + f.fileName, + !!this.program.getSourceFileByPath(f.path), + /*syncDirWatcherRemove*/ + true + ); } - displayParts.push(keywordPart(105 /* NewKeyword */)); - displayParts.push(spacePart()); } - addSignatureDisplayParts(signature, allSignatures, 262144 /* WriteArrowStyleSignature */); - break; - default: - addSignatureDisplayParts(signature, allSignatures); + oldProgram.forEachResolvedProjectReference((resolvedProjectReference) => { + if (!this.program.getResolvedProjectReferenceByPath(resolvedProjectReference.sourceFile.path)) { + this.detachScriptInfoFromProject( + resolvedProjectReference.sourceFile.fileName, + /*noRemoveResolution*/ + void 0, + /*syncDirWatcherRemove*/ + true + ); + } + }); + } + updateMissingFilePathsWatch( + this.program, + this.missingFilesMap || (this.missingFilesMap = /* @__PURE__ */ new Map()), + // Watch the missing files + (missingFilePath) => this.addMissingFileWatcher(missingFilePath) + ); + if (this.generatedFilesMap) { + const outPath = outFile(this.compilerOptions); + if (isGeneratedFileWatcher(this.generatedFilesMap)) { + if (!outPath || !this.isValidGeneratedFileWatcher( + removeFileExtension(outPath) + ".d.ts" /* Dts */, + this.generatedFilesMap + )) { + this.clearGeneratedFileWatch(); + } + } else { + if (outPath) { + this.clearGeneratedFileWatch(); + } else { + this.generatedFilesMap.forEach((watcher, source) => { + const sourceFile = this.program.getSourceFileByPath(source); + if (!sourceFile || sourceFile.resolvedPath !== source || !this.isValidGeneratedFileWatcher( + getDeclarationEmitOutputFilePathWorker(sourceFile.fileName, this.compilerOptions, this.currentDirectory, this.program.getCommonSourceDirectory(), this.getCanonicalFileName), + watcher + )) { + closeFileWatcherOf(watcher); + this.generatedFilesMap.delete(source); + } + }); + } + } + } + if (this.languageServiceEnabled && this.projectService.serverMode === 0 /* Semantic */) { + this.resolutionCache.updateTypeRootsWatch(); + } + } + this.projectService.verifyProgram(this); + if (this.exportMapCache && !this.exportMapCache.isEmpty()) { + this.exportMapCache.releaseSymbols(); + if (this.hasAddedorRemovedFiles || oldProgram && !this.program.structureIsReused) { + this.exportMapCache.clear(); + } else if (this.changedFilesForExportMapCache && oldProgram && this.program) { + forEachKey(this.changedFilesForExportMapCache, (fileName) => { + const oldSourceFile = oldProgram.getSourceFileByPath(fileName); + const sourceFile = this.program.getSourceFileByPath(fileName); + if (!oldSourceFile || !sourceFile) { + this.exportMapCache.clear(); + return true; + } + return this.exportMapCache.onFileChanged(oldSourceFile, sourceFile, !!this.getTypeAcquisition().enable); + }); + } } - hasAddedSymbolInfo = true; - hasMultipleSignatures = allSignatures.length > 1; + if (this.changedFilesForExportMapCache) { + this.changedFilesForExportMapCache.clear(); + } + if (this.hasAddedOrRemovedSymlinks || this.program && !this.program.structureIsReused && this.getCompilerOptions().preserveSymlinks) { + this.symlinks = void 0; + this.moduleSpecifierCache.clear(); + } + const oldExternalFiles = this.externalFiles || emptyArray2; + this.externalFiles = this.getExternalFiles(); + enumerateInsertsAndDeletes( + this.externalFiles, + oldExternalFiles, + getStringComparer(!this.useCaseSensitiveFileNames()), + // Ensure a ScriptInfo is created for new external files. This is performed indirectly + // by the host for files in the program when the program is retrieved above but + // the program doesn't contain external files so this must be done explicitly. + (inserted) => { + const scriptInfo = this.projectService.getOrCreateScriptInfoNotOpenedByClient(inserted, this.currentDirectory, this.directoryStructureHost); + scriptInfo == null ? void 0 : scriptInfo.attachToProject(this); + }, + (removed) => this.detachScriptInfoFromProject(removed) + ); + const elapsed = timestamp() - start; + this.sendPerformanceEvent("UpdateGraph", elapsed); + this.writeLog(`Finishing updateGraphWorker: Project: ${this.getProjectName()} Version: ${this.getProjectVersion()} structureChanged: ${hasNewProgram}${this.program ? ` structureIsReused:: ${StructureIsReused[this.program.structureIsReused]}` : ""} Elapsed: ${elapsed}ms`); + if (this.projectService.logger.isTestLogger) { + if (this.program !== oldProgram) { + this.print( + /*writeProjectFileNames*/ + true, + this.hasAddedorRemovedFiles, + /*writeFileVersionAndText*/ + true + ); + } else { + this.writeLog(`Same program as before`); + } + } else if (this.hasAddedorRemovedFiles) { + this.print( + /*writeProjectFileNames*/ + true, + /*writeFileExplaination*/ + true, + /*writeFileVersionAndText*/ + false + ); + } else if (this.program !== oldProgram) { + this.writeLog(`Different program with same set of files`); + } + this.projectService.verifyDocumentRegistry(); + return hasNewProgram; } - } else if (isNameOfFunctionDeclaration(location) && !(symbolFlags & 98304 /* Accessor */) || // name of function declaration - location.kind === 137 /* ConstructorKeyword */ && location.parent.kind === 175 /* Constructor */) { - const functionDeclaration = location.parent; - const locationIsSymbolDeclaration = symbol.declarations && find(symbol.declarations, (declaration) => declaration === (location.kind === 137 /* ConstructorKeyword */ ? functionDeclaration.parent : functionDeclaration)); - if (locationIsSymbolDeclaration) { - const allSignatures = functionDeclaration.kind === 175 /* Constructor */ ? type.getNonNullableType().getConstructSignatures() : type.getNonNullableType().getCallSignatures(); - if (!typeChecker.isImplementationOfOverload(functionDeclaration)) { - signature = typeChecker.getSignatureFromDeclaration(functionDeclaration); + /** @internal */ + sendPerformanceEvent(kind, durationMs) { + this.projectService.sendPerformanceEvent(kind, durationMs); + } + detachScriptInfoFromProject(uncheckedFileName, noRemoveResolution, syncDirWatcherRemove) { + const scriptInfoToDetach = this.projectService.getScriptInfo(uncheckedFileName); + if (scriptInfoToDetach) { + scriptInfoToDetach.detachFromProject(this); + if (!noRemoveResolution) { + this.resolutionCache.removeResolutionsOfFile(scriptInfoToDetach.path, syncDirWatcherRemove); + } + } + } + addMissingFileWatcher(missingFilePath) { + var _a; + if (isConfiguredProject(this)) { + const configFileExistenceInfo = this.projectService.configFileExistenceInfoCache.get(missingFilePath); + if ((_a = configFileExistenceInfo == null ? void 0 : configFileExistenceInfo.config) == null ? void 0 : _a.projects.has(this.canonicalConfigFilePath)) + return noopFileWatcher; + } + const fileWatcher = this.projectService.watchFactory.watchFile( + missingFilePath, + (fileName, eventKind) => { + if (isConfiguredProject(this)) { + this.getCachedDirectoryStructureHost().addOrDeleteFile(fileName, missingFilePath, eventKind); + } + if (eventKind === 0 /* Created */ && this.missingFilesMap.has(missingFilePath)) { + this.missingFilesMap.delete(missingFilePath); + fileWatcher.close(); + this.projectService.delayUpdateProjectGraphAndEnsureProjectStructureForOpenFiles(this); + } + }, + 500 /* Medium */, + this.projectService.getWatchOptions(this), + WatchType.MissingFile, + this + ); + return fileWatcher; + } + isWatchedMissingFile(path) { + return !!this.missingFilesMap && this.missingFilesMap.has(path); + } + /** @internal */ + addGeneratedFileWatch(generatedFile, sourceFile) { + if (outFile(this.compilerOptions)) { + if (!this.generatedFilesMap) { + this.generatedFilesMap = this.createGeneratedFileWatcher(generatedFile); + } } else { - signature = allSignatures[0]; + const path = this.toPath(sourceFile); + if (this.generatedFilesMap) { + if (isGeneratedFileWatcher(this.generatedFilesMap)) { + Debug.fail(`${this.projectName} Expected to not have --out watcher for generated file with options: ${JSON.stringify(this.compilerOptions)}`); + return; + } + if (this.generatedFilesMap.has(path)) + return; + } else { + this.generatedFilesMap = /* @__PURE__ */ new Map(); + } + this.generatedFilesMap.set(path, this.createGeneratedFileWatcher(generatedFile)); } - if (functionDeclaration.kind === 175 /* Constructor */) { - symbolKind = "constructor" /* constructorImplementationElement */; - addPrefixForAnyFunctionOrVar(type.symbol, symbolKind); + } + createGeneratedFileWatcher(generatedFile) { + return { + generatedFilePath: this.toPath(generatedFile), + watcher: this.projectService.watchFactory.watchFile( + generatedFile, + () => { + this.clearSourceMapperCache(); + this.projectService.delayUpdateProjectGraphAndEnsureProjectStructureForOpenFiles(this); + }, + 2e3 /* High */, + this.projectService.getWatchOptions(this), + WatchType.MissingGeneratedFile, + this + ) + }; + } + isValidGeneratedFileWatcher(generateFile, watcher) { + return this.toPath(generateFile) === watcher.generatedFilePath; + } + clearGeneratedFileWatch() { + if (this.generatedFilesMap) { + if (isGeneratedFileWatcher(this.generatedFilesMap)) { + closeFileWatcherOf(this.generatedFilesMap); + } else { + clearMap(this.generatedFilesMap, closeFileWatcherOf); + } + this.generatedFilesMap = void 0; + } + } + getScriptInfoForNormalizedPath(fileName) { + const scriptInfo = this.projectService.getScriptInfoForPath(this.toPath(fileName)); + if (scriptInfo && !scriptInfo.isAttached(this)) { + return Errors.ThrowProjectDoesNotContainDocument(fileName, this); + } + return scriptInfo; + } + getScriptInfo(uncheckedFileName) { + return this.projectService.getScriptInfo(uncheckedFileName); + } + filesToString(writeProjectFileNames) { + return this.filesToStringWorker( + writeProjectFileNames, + /*writeFileExplaination*/ + true, + /*writeFileVersionAndText*/ + false + ); + } + /** @internal */ + filesToStringWorker(writeProjectFileNames, writeFileExplaination, writeFileVersionAndText) { + if (this.isInitialLoadPending()) + return " Files (0) InitialLoadPending\n"; + if (!this.program) + return " Files (0) NoProgram\n"; + const sourceFiles = this.program.getSourceFiles(); + let strBuilder = ` Files (${sourceFiles.length}) +`; + if (writeProjectFileNames) { + for (const file of sourceFiles) { + strBuilder += ` ${file.fileName}${writeFileVersionAndText ? ` ${file.version} ${JSON.stringify(file.text)}` : ""} +`; + } + if (writeFileExplaination) { + strBuilder += "\n\n"; + explainFiles(this.program, (s) => strBuilder += ` ${s} +`); + } + } + return strBuilder; + } + /** @internal */ + print(writeProjectFileNames, writeFileExplaination, writeFileVersionAndText) { + this.writeLog(`Project '${this.projectName}' (${ProjectKind[this.projectKind]})`); + this.writeLog(this.filesToStringWorker( + writeProjectFileNames && this.projectService.logger.hasLevel(3 /* verbose */), + writeFileExplaination && this.projectService.logger.hasLevel(3 /* verbose */), + writeFileVersionAndText && this.projectService.logger.hasLevel(3 /* verbose */) + )); + this.writeLog("-----------------------------------------------"); + if (this.autoImportProviderHost) { + this.autoImportProviderHost.print( + /*writeProjectFileNames*/ + false, + /*writeFileExplaination*/ + false, + /*writeFileVersionAndText*/ + false + ); + } + } + setCompilerOptions(compilerOptions) { + var _a; + if (compilerOptions) { + compilerOptions.allowNonTsExtensions = true; + const oldOptions = this.compilerOptions; + this.compilerOptions = compilerOptions; + this.setInternalCompilerOptionsForEmittingJsFiles(); + (_a = this.noDtsResolutionProject) == null ? void 0 : _a.setCompilerOptions(this.getCompilerOptionsForNoDtsResolutionProject()); + if (changesAffectModuleResolution(oldOptions, compilerOptions)) { + this.cachedUnresolvedImportsPerFile.clear(); + this.lastCachedUnresolvedImportsList = void 0; + this.resolutionCache.onChangesAffectModuleResolution(); + this.moduleSpecifierCache.clear(); + } + this.markAsDirty(); + } + } + /** @internal */ + setWatchOptions(watchOptions) { + this.watchOptions = watchOptions; + } + /** @internal */ + getWatchOptions() { + return this.watchOptions; + } + setTypeAcquisition(newTypeAcquisition) { + if (newTypeAcquisition) { + this.typeAcquisition = this.removeLocalTypingsFromTypeAcquisition(newTypeAcquisition); + } + } + getTypeAcquisition() { + return this.typeAcquisition || {}; + } + /** @internal */ + getChangesSinceVersion(lastKnownVersion, includeProjectReferenceRedirectInfo) { + var _a, _b; + const includeProjectReferenceRedirectInfoIfRequested = includeProjectReferenceRedirectInfo ? (files) => arrayFrom(files.entries(), ([fileName, isSourceOfProjectReferenceRedirect]) => ({ + fileName, + isSourceOfProjectReferenceRedirect + })) : (files) => arrayFrom(files.keys()); + if (!this.isInitialLoadPending()) { + updateProjectIfDirty(this); + } + const info = { + projectName: this.getProjectName(), + version: this.projectProgramVersion, + isInferred: isInferredProject(this), + options: this.getCompilationSettings(), + languageServiceDisabled: !this.languageServiceEnabled, + lastFileExceededProgramSize: this.lastFileExceededProgramSize + }; + const updatedFileNames = this.updatedFileNames; + this.updatedFileNames = void 0; + if (this.lastReportedFileNames && lastKnownVersion === this.lastReportedVersion) { + if (this.projectProgramVersion === this.lastReportedVersion && !updatedFileNames) { + return { info, projectErrors: this.getGlobalProjectErrors() }; + } + const lastReportedFileNames = this.lastReportedFileNames; + const externalFiles = ((_a = this.externalFiles) == null ? void 0 : _a.map((f) => ({ + fileName: toNormalizedPath(f), + isSourceOfProjectReferenceRedirect: false + }))) || emptyArray2; + const currentFiles = arrayToMap( + this.getFileNamesWithRedirectInfo(!!includeProjectReferenceRedirectInfo).concat(externalFiles), + (info2) => info2.fileName, + (info2) => info2.isSourceOfProjectReferenceRedirect + ); + const added = /* @__PURE__ */ new Map(); + const removed = /* @__PURE__ */ new Map(); + const updated = updatedFileNames ? arrayFrom(updatedFileNames.keys()) : []; + const updatedRedirects = []; + forEachEntry(currentFiles, (isSourceOfProjectReferenceRedirect, fileName) => { + if (!lastReportedFileNames.has(fileName)) { + added.set(fileName, isSourceOfProjectReferenceRedirect); + } else if (includeProjectReferenceRedirectInfo && isSourceOfProjectReferenceRedirect !== lastReportedFileNames.get(fileName)) { + updatedRedirects.push({ + fileName, + isSourceOfProjectReferenceRedirect + }); + } + }); + forEachEntry(lastReportedFileNames, (isSourceOfProjectReferenceRedirect, fileName) => { + if (!currentFiles.has(fileName)) { + removed.set(fileName, isSourceOfProjectReferenceRedirect); + } + }); + this.lastReportedFileNames = currentFiles; + this.lastReportedVersion = this.projectProgramVersion; + return { + info, + changes: { + added: includeProjectReferenceRedirectInfoIfRequested(added), + removed: includeProjectReferenceRedirectInfoIfRequested(removed), + updated: includeProjectReferenceRedirectInfo ? updated.map((fileName) => ({ + fileName, + isSourceOfProjectReferenceRedirect: this.isSourceOfProjectReferenceRedirect(fileName) + })) : updated, + updatedRedirects: includeProjectReferenceRedirectInfo ? updatedRedirects : void 0 + }, + projectErrors: this.getGlobalProjectErrors() + }; } else { - addPrefixForAnyFunctionOrVar(functionDeclaration.kind === 178 /* CallSignature */ && !(type.symbol.flags & 2048 /* TypeLiteral */ || type.symbol.flags & 4096 /* ObjectLiteral */) ? type.symbol : symbol, symbolKind); + const projectFileNames = this.getFileNamesWithRedirectInfo(!!includeProjectReferenceRedirectInfo); + const externalFiles = ((_b = this.externalFiles) == null ? void 0 : _b.map((f) => ({ + fileName: toNormalizedPath(f), + isSourceOfProjectReferenceRedirect: false + }))) || emptyArray2; + const allFiles = projectFileNames.concat(externalFiles); + this.lastReportedFileNames = arrayToMap( + allFiles, + (info2) => info2.fileName, + (info2) => info2.isSourceOfProjectReferenceRedirect + ); + this.lastReportedVersion = this.projectProgramVersion; + return { + info, + files: includeProjectReferenceRedirectInfo ? allFiles : allFiles.map((f) => f.fileName), + projectErrors: this.getGlobalProjectErrors() + }; } - if (signature) { - addSignatureDisplayParts(signature, allSignatures); + } + // remove a root file from project + removeRoot(info) { + orderedRemoveItem(this.rootFiles, info); + this.rootFilesMap.delete(info.path); + } + /** @internal */ + isSourceOfProjectReferenceRedirect(fileName) { + return !!this.program && this.program.isSourceOfProjectReferenceRedirect(fileName); + } + /** @internal */ + getGlobalPluginSearchPaths() { + return [ + ...this.projectService.pluginProbeLocations, + // ../../.. to walk from X/node_modules/typescript/lib/tsserver.js to X/node_modules/ + combinePaths(this.projectService.getExecutingFilePath(), "../../..") + ]; + } + enableGlobalPlugins(options) { + if (!this.projectService.globalPlugins.length) + return; + const host = this.projectService.host; + if (!host.require && !host.importPlugin) { + this.projectService.logger.info("Plugins were requested but not running in environment that supports 'require'. Nothing will be loaded"); + return; + } + const searchPaths = this.getGlobalPluginSearchPaths(); + for (const globalPluginName of this.projectService.globalPlugins) { + if (!globalPluginName) + continue; + if (options.plugins && options.plugins.some((p) => p.name === globalPluginName)) + continue; + this.projectService.logger.info(`Loading global plugin ${globalPluginName}`); + this.enablePlugin({ name: globalPluginName, global: true }, searchPaths); } - hasAddedSymbolInfo = true; - hasMultipleSignatures = allSignatures.length > 1; } - } - } - if (symbolFlags & 32 /* Class */ && !hasAddedSymbolInfo && !isThisExpression) { - addAliasPrefixIfNecessary(); - if (getDeclarationOfKind(symbol, 230 /* ClassExpression */)) { - pushSymbolKind("local class" /* localClassElement */); - } else { - displayParts.push(keywordPart(86 /* ClassKeyword */)); - } - displayParts.push(spacePart()); - addFullSymbolName(symbol); - writeTypeParametersOfSymbol(symbol, sourceFile); - } - if (symbolFlags & 64 /* Interface */ && semanticMeaning & 2 /* Type */) { - prefixNextMeaning(); - displayParts.push(keywordPart(120 /* InterfaceKeyword */)); - displayParts.push(spacePart()); - addFullSymbolName(symbol); - writeTypeParametersOfSymbol(symbol, sourceFile); - } - if (symbolFlags & 524288 /* TypeAlias */ && semanticMeaning & 2 /* Type */) { - prefixNextMeaning(); - displayParts.push(keywordPart(156 /* TypeKeyword */)); - displayParts.push(spacePart()); - addFullSymbolName(symbol); - writeTypeParametersOfSymbol(symbol, sourceFile); - displayParts.push(spacePart()); - displayParts.push(operatorPart(64 /* EqualsToken */)); - displayParts.push(spacePart()); - addRange(displayParts, typeToDisplayParts(typeChecker, location.parent && isConstTypeReference(location.parent) ? typeChecker.getTypeAtLocation(location.parent) : typeChecker.getDeclaredTypeOfSymbol(symbol), enclosingDeclaration, 8388608 /* InTypeAlias */)); - } - if (symbolFlags & 384 /* Enum */) { - prefixNextMeaning(); - if (some(symbol.declarations, (d) => isEnumDeclaration(d) && isEnumConst(d))) { - displayParts.push(keywordPart(87 /* ConstKeyword */)); - displayParts.push(spacePart()); - } - displayParts.push(keywordPart(94 /* EnumKeyword */)); - displayParts.push(spacePart()); - addFullSymbolName(symbol); - } - if (symbolFlags & 1536 /* Module */ && !isThisExpression) { - prefixNextMeaning(); - const declaration = getDeclarationOfKind(symbol, 266 /* ModuleDeclaration */); - const isNamespace = declaration && declaration.name && declaration.name.kind === 80 /* Identifier */; - displayParts.push(keywordPart(isNamespace ? 145 /* NamespaceKeyword */ : 144 /* ModuleKeyword */)); - displayParts.push(spacePart()); - addFullSymbolName(symbol); - } - if (symbolFlags & 262144 /* TypeParameter */ && semanticMeaning & 2 /* Type */) { - prefixNextMeaning(); - displayParts.push(punctuationPart(21 /* OpenParenToken */)); - displayParts.push(textPart("type parameter")); - displayParts.push(punctuationPart(22 /* CloseParenToken */)); - displayParts.push(spacePart()); - addFullSymbolName(symbol); - if (symbol.parent) { - addInPrefix(); - addFullSymbolName(symbol.parent, enclosingDeclaration); - writeTypeParametersOfSymbol(symbol.parent, enclosingDeclaration); - } else { - const decl = getDeclarationOfKind(symbol, 167 /* TypeParameter */); - if (decl === void 0) - return Debug.fail(); - const declaration = decl.parent; - if (declaration) { - if (isFunctionLike(declaration)) { - addInPrefix(); - const signature = typeChecker.getSignatureFromDeclaration(declaration); - if (declaration.kind === 179 /* ConstructSignature */) { - displayParts.push(keywordPart(105 /* NewKeyword */)); - displayParts.push(spacePart()); - } else if (declaration.kind !== 178 /* CallSignature */ && declaration.name) { - addFullSymbolName(declaration.symbol); + enablePlugin(pluginConfigEntry, searchPaths) { + this.projectService.requestEnablePlugin(this, pluginConfigEntry, searchPaths); + } + /** @internal */ + enableProxy(pluginModuleFactory, configEntry) { + try { + if (typeof pluginModuleFactory !== "function") { + this.projectService.logger.info(`Skipped loading plugin ${configEntry.name} because it did not expose a proper factory function`); + return; } - addRange(displayParts, signatureToDisplayParts(typeChecker, signature, sourceFile, 32 /* WriteTypeArgumentsOfSignature */)); - } else if (isTypeAliasDeclaration(declaration)) { - addInPrefix(); - displayParts.push(keywordPart(156 /* TypeKeyword */)); - displayParts.push(spacePart()); - addFullSymbolName(declaration.symbol); - writeTypeParametersOfSymbol(declaration.symbol, sourceFile); + const info = { + config: configEntry, + project: this, + languageService: this.languageService, + languageServiceHost: this, + serverHost: this.projectService.host, + session: this.projectService.session + }; + const pluginModule = pluginModuleFactory({ typescript: ts_exports2 }); + const newLS = pluginModule.create(info); + for (const k of Object.keys(this.languageService)) { + if (!(k in newLS)) { + this.projectService.logger.info(`Plugin activation warning: Missing proxied method ${k} in created LS. Patching.`); + newLS[k] = this.languageService[k]; + } + } + this.projectService.logger.info(`Plugin validation succeeded`); + this.languageService = newLS; + this.plugins.push({ name: configEntry.name, module: pluginModule }); + } catch (e) { + this.projectService.logger.info(`Plugin activation failed: ${e}`); + } + } + /** @internal */ + onPluginConfigurationChanged(pluginName, configuration) { + this.plugins.filter((plugin) => plugin.name === pluginName).forEach((plugin) => { + if (plugin.module.onConfigurationChanged) { + plugin.module.onConfigurationChanged(configuration); + } + }); + } + /** Starts a new check for diagnostics. Call this if some file has updated that would cause diagnostics to be changed. */ + refreshDiagnostics() { + this.projectService.sendProjectsUpdatedInBackgroundEvent(); + } + /** @internal */ + getPackageJsonsVisibleToFile(fileName, rootDir) { + if (this.projectService.serverMode !== 0 /* Semantic */) + return emptyArray2; + return this.projectService.getPackageJsonsVisibleToFile(fileName, rootDir); + } + /** @internal */ + getNearestAncestorDirectoryWithPackageJson(fileName) { + return this.projectService.getNearestAncestorDirectoryWithPackageJson(fileName); + } + /** @internal */ + getPackageJsonsForAutoImport(rootDir) { + const packageJsons = this.getPackageJsonsVisibleToFile(combinePaths(this.currentDirectory, inferredTypesContainingFile), rootDir); + this.packageJsonsForAutoImport = new Set(packageJsons.map((p) => p.fileName)); + return packageJsons; + } + /** @internal */ + getPackageJsonCache() { + return this.projectService.packageJsonCache; + } + /** @internal */ + getCachedExportInfoMap() { + return this.exportMapCache || (this.exportMapCache = createCacheableExportInfoMap(this)); + } + /** @internal */ + clearCachedExportInfoMap() { + var _a; + (_a = this.exportMapCache) == null ? void 0 : _a.clear(); + } + /** @internal */ + getModuleSpecifierCache() { + return this.moduleSpecifierCache; + } + /** @internal */ + includePackageJsonAutoImports() { + if (this.projectService.includePackageJsonAutoImports() === 0 /* Off */ || !this.languageServiceEnabled || isInsideNodeModules(this.currentDirectory) || !this.isDefaultProjectForOpenFiles()) { + return 0 /* Off */; + } + return this.projectService.includePackageJsonAutoImports(); + } + /** @internal */ + getHostForAutoImportProvider() { + var _a, _b; + if (this.program) { + return { + fileExists: this.program.fileExists, + directoryExists: this.program.directoryExists, + realpath: this.program.realpath || ((_a = this.projectService.host.realpath) == null ? void 0 : _a.bind(this.projectService.host)), + getCurrentDirectory: this.getCurrentDirectory.bind(this), + readFile: this.projectService.host.readFile.bind(this.projectService.host), + getDirectories: this.projectService.host.getDirectories.bind(this.projectService.host), + trace: (_b = this.projectService.host.trace) == null ? void 0 : _b.bind(this.projectService.host), + useCaseSensitiveFileNames: this.program.useCaseSensitiveFileNames(), + readDirectory: this.projectService.host.readDirectory.bind(this.projectService.host) + }; + } + return this.projectService.host; + } + /** @internal */ + getPackageJsonAutoImportProvider() { + var _a, _b, _c; + if (this.autoImportProviderHost === false) { + return void 0; + } + if (this.projectService.serverMode !== 0 /* Semantic */) { + this.autoImportProviderHost = false; + return void 0; + } + if (this.autoImportProviderHost) { + updateProjectIfDirty(this.autoImportProviderHost); + if (this.autoImportProviderHost.isEmpty()) { + this.autoImportProviderHost.close(); + this.autoImportProviderHost = void 0; + return void 0; + } + return this.autoImportProviderHost.getCurrentProgram(); + } + const dependencySelection = this.includePackageJsonAutoImports(); + if (dependencySelection) { + (_a = tracing) == null ? void 0 : _a.push(tracing.Phase.Session, "getPackageJsonAutoImportProvider"); + const start = timestamp(); + this.autoImportProviderHost = AutoImportProviderProject.create(dependencySelection, this, this.getHostForAutoImportProvider(), this.documentRegistry); + if (this.autoImportProviderHost) { + updateProjectIfDirty(this.autoImportProviderHost); + this.sendPerformanceEvent("CreatePackageJsonAutoImportProvider", timestamp() - start); + (_b = tracing) == null ? void 0 : _b.pop(); + return this.autoImportProviderHost.getCurrentProgram(); + } + (_c = tracing) == null ? void 0 : _c.pop(); + } + } + /** @internal */ + isDefaultProjectForOpenFiles() { + return !!forEachEntry( + this.projectService.openFiles, + (_, fileName) => this.projectService.tryGetDefaultProjectForFile(toNormalizedPath(fileName)) === this + ); + } + /** @internal */ + watchNodeModulesForPackageJsonChanges(directoryPath) { + return this.projectService.watchPackageJsonsInNodeModules(this.toPath(directoryPath), this); + } + /** @internal */ + getIncompleteCompletionsCache() { + return this.projectService.getIncompleteCompletionsCache(); + } + /** @internal */ + getNoDtsResolutionProject(rootFile) { + Debug.assert(this.projectService.serverMode === 0 /* Semantic */); + if (!this.noDtsResolutionProject) { + this.noDtsResolutionProject = new AuxiliaryProject(this.projectService, this.documentRegistry, this.getCompilerOptionsForNoDtsResolutionProject(), this.currentDirectory); + } + if (this.noDtsResolutionProject.rootFile !== rootFile) { + this.projectService.setFileNamesOfAutpImportProviderOrAuxillaryProject(this.noDtsResolutionProject, [rootFile]); + this.noDtsResolutionProject.rootFile = rootFile; + } + return this.noDtsResolutionProject; + } + /** @internal */ + getCompilerOptionsForNoDtsResolutionProject() { + return { + ...this.getCompilerOptions(), + noDtsResolution: true, + allowJs: true, + maxNodeModuleJsDepth: 3, + diagnostics: false, + skipLibCheck: true, + sourceMap: false, + types: emptyArray, + lib: emptyArray, + noLib: true + }; + } + }; + InferredProject2 = class extends Project3 { + /** @internal */ + constructor(projectService, documentRegistry, compilerOptions, watchOptions, projectRootPath, currentDirectory, typeAcquisition) { + super( + projectService.newInferredProjectName(), + 0 /* Inferred */, + projectService, + documentRegistry, + // TODO: GH#18217 + /*files*/ + void 0, + /*lastFileExceededProgramSize*/ + void 0, + compilerOptions, + /*compileOnSaveEnabled*/ + false, + watchOptions, + projectService.host, + currentDirectory + ); + this._isJsInferredProject = false; + this.typeAcquisition = typeAcquisition; + this.projectRootPath = projectRootPath && projectService.toCanonicalFileName(projectRootPath); + if (!projectRootPath && !projectService.useSingleInferredProject) { + this.canonicalCurrentDirectory = projectService.toCanonicalFileName(this.currentDirectory); } + this.enableGlobalPlugins(this.getCompilerOptions()); } - } - } - if (symbolFlags & 8 /* EnumMember */) { - symbolKind = "enum member" /* enumMemberElement */; - addPrefixForAnyFunctionOrVar(symbol, "enum member"); - const declaration = (_a = symbol.declarations) == null ? void 0 : _a[0]; - if ((declaration == null ? void 0 : declaration.kind) === 305 /* EnumMember */) { - const constantValue = typeChecker.getConstantValue(declaration); - if (constantValue !== void 0) { - displayParts.push(spacePart()); - displayParts.push(operatorPart(64 /* EqualsToken */)); - displayParts.push(spacePart()); - displayParts.push(displayPart( - getTextOfConstantValue(constantValue), - typeof constantValue === "number" ? 7 /* numericLiteral */ : 8 /* stringLiteral */ - )); + toggleJsInferredProject(isJsInferredProject) { + if (isJsInferredProject !== this._isJsInferredProject) { + this._isJsInferredProject = isJsInferredProject; + this.setCompilerOptions(); + } } - } - } - if (symbol.flags & 2097152 /* Alias */) { - prefixNextMeaning(); - if (!hasAddedSymbolInfo || documentation.length === 0 && tags.length === 0) { - const resolvedSymbol = typeChecker.getAliasedSymbol(symbol); - if (resolvedSymbol !== symbol && resolvedSymbol.declarations && resolvedSymbol.declarations.length > 0) { - const resolvedNode = resolvedSymbol.declarations[0]; - const declarationName = getNameOfDeclaration(resolvedNode); - if (declarationName && !hasAddedSymbolInfo) { - const isExternalModuleDeclaration = isModuleWithStringLiteralName(resolvedNode) && hasSyntacticModifier(resolvedNode, 2 /* Ambient */); - const shouldUseAliasName = symbol.name !== "default" && !isExternalModuleDeclaration; - const resolvedInfo = getSymbolDisplayPartsDocumentationAndSymbolKind( - typeChecker, - resolvedSymbol, - getSourceFileOfNode(resolvedNode), - resolvedNode, - declarationName, - semanticMeaning, - shouldUseAliasName ? symbol : resolvedSymbol + setCompilerOptions(options) { + if (!options && !this.getCompilationSettings()) { + return; + } + const newOptions = cloneCompilerOptions(options || this.getCompilationSettings()); + if (this._isJsInferredProject && typeof newOptions.maxNodeModuleJsDepth !== "number") { + newOptions.maxNodeModuleJsDepth = 2; + } else if (!this._isJsInferredProject) { + newOptions.maxNodeModuleJsDepth = void 0; + } + newOptions.allowJs = true; + super.setCompilerOptions(newOptions); + } + addRoot(info) { + Debug.assert(info.isScriptOpen()); + this.projectService.startWatchingConfigFilesForInferredProjectRoot(info); + if (!this._isJsInferredProject && info.isJavaScript()) { + this.toggleJsInferredProject( + /*isJsInferredProject*/ + true + ); + } else if (this.isOrphan() && this._isJsInferredProject && !info.isJavaScript()) { + this.toggleJsInferredProject( + /*isJsInferredProject*/ + false ); - displayParts.push(...resolvedInfo.displayParts); - displayParts.push(lineBreakPart()); - documentationFromAlias = resolvedInfo.documentation; - tagsFromAlias = resolvedInfo.tags; - } else { - documentationFromAlias = resolvedSymbol.getContextualDocumentationComment(resolvedNode, typeChecker); - tagsFromAlias = resolvedSymbol.getJsDocTags(typeChecker); } + super.addRoot(info); } - } - if (symbol.declarations) { - switch (symbol.declarations[0].kind) { - case 269 /* NamespaceExportDeclaration */: - displayParts.push(keywordPart(95 /* ExportKeyword */)); - displayParts.push(spacePart()); - displayParts.push(keywordPart(145 /* NamespaceKeyword */)); - break; - case 276 /* ExportAssignment */: - displayParts.push(keywordPart(95 /* ExportKeyword */)); - displayParts.push(spacePart()); - displayParts.push(keywordPart(symbol.declarations[0].isExportEquals ? 64 /* EqualsToken */ : 90 /* DefaultKeyword */)); - break; - case 280 /* ExportSpecifier */: - displayParts.push(keywordPart(95 /* ExportKeyword */)); - break; - default: - displayParts.push(keywordPart(102 /* ImportKeyword */)); - } - } - displayParts.push(spacePart()); - addFullSymbolName(symbol); - forEach(symbol.declarations, (declaration) => { - if (declaration.kind === 270 /* ImportEqualsDeclaration */) { - const importEqualsDeclaration = declaration; - if (isExternalModuleImportEqualsDeclaration(importEqualsDeclaration)) { - displayParts.push(spacePart()); - displayParts.push(operatorPart(64 /* EqualsToken */)); - displayParts.push(spacePart()); - displayParts.push(keywordPart(149 /* RequireKeyword */)); - displayParts.push(punctuationPart(21 /* OpenParenToken */)); - displayParts.push(displayPart(getTextOfNode(getExternalModuleImportEqualsDeclarationExpression(importEqualsDeclaration)), 8 /* stringLiteral */)); - displayParts.push(punctuationPart(22 /* CloseParenToken */)); - } else { - const internalAliasSymbol = typeChecker.getSymbolAtLocation(importEqualsDeclaration.moduleReference); - if (internalAliasSymbol) { - displayParts.push(spacePart()); - displayParts.push(operatorPart(64 /* EqualsToken */)); - displayParts.push(spacePart()); - addFullSymbolName(internalAliasSymbol, enclosingDeclaration); + removeRoot(info) { + this.projectService.stopWatchingConfigFilesForInferredProjectRoot(info); + super.removeRoot(info); + if (!this.isOrphan() && this._isJsInferredProject && info.isJavaScript()) { + if (every(this.getRootScriptInfos(), (rootInfo) => !rootInfo.isJavaScript())) { + this.toggleJsInferredProject( + /*isJsInferredProject*/ + false + ); } } + } + /** @internal */ + isOrphan() { + return !this.hasRoots(); + } + isProjectWithSingleRoot() { + return !this.projectRootPath && !this.projectService.useSingleInferredProject || this.getRootScriptInfos().length === 1; + } + close() { + forEach(this.getRootScriptInfos(), (info) => this.projectService.stopWatchingConfigFilesForInferredProjectRoot(info)); + super.close(); + } + getTypeAcquisition() { + return this.typeAcquisition || { + enable: allRootFilesAreJsOrDts(this), + include: emptyArray, + exclude: emptyArray + }; + } + }; + AuxiliaryProject = class extends Project3 { + constructor(projectService, documentRegistry, compilerOptions, currentDirectory) { + super( + projectService.newAuxiliaryProjectName(), + 4 /* Auxiliary */, + projectService, + documentRegistry, + /*hasExplicitListOfFiles*/ + false, + /*lastFileExceededProgramSize*/ + void 0, + compilerOptions, + /*compileOnSaveEnabled*/ + false, + /*watchOptions*/ + void 0, + projectService.host, + currentDirectory + ); + } + isOrphan() { return true; } - }); - } - if (!hasAddedSymbolInfo) { - if (symbolKind !== "" /* unknown */) { - if (type) { - if (isThisExpression) { - prefixNextMeaning(); - displayParts.push(keywordPart(110 /* ThisKeyword */)); - } else { - addPrefixForAnyFunctionOrVar(symbol, symbolKind); + scheduleInvalidateResolutionsOfFailedLookupLocations() { + return; + } + }; + _AutoImportProviderProject = class _AutoImportProviderProject extends Project3 { + /** @internal */ + constructor(hostProject, initialRootNames, documentRegistry, compilerOptions) { + super( + hostProject.projectService.newAutoImportProviderProjectName(), + 3 /* AutoImportProvider */, + hostProject.projectService, + documentRegistry, + /*hasExplicitListOfFiles*/ + false, + /*lastFileExceededProgramSize*/ + void 0, + compilerOptions, + /*compileOnSaveEnabled*/ + false, + hostProject.getWatchOptions(), + hostProject.projectService.host, + hostProject.currentDirectory + ); + this.hostProject = hostProject; + this.rootFileNames = initialRootNames; + this.useSourceOfProjectReferenceRedirect = maybeBind(this.hostProject, this.hostProject.useSourceOfProjectReferenceRedirect); + this.getParsedCommandLine = maybeBind(this.hostProject, this.hostProject.getParsedCommandLine); + } + /** @internal */ + static getRootFileNames(dependencySelection, hostProject, host, compilerOptions) { + var _a, _b; + if (!dependencySelection) { + return emptyArray; } - if (symbolKind === "property" /* memberVariableElement */ || symbolKind === "accessor" /* memberAccessorVariableElement */ || symbolKind === "getter" /* memberGetAccessorElement */ || symbolKind === "setter" /* memberSetAccessorElement */ || symbolKind === "JSX attribute" /* jsxAttribute */ || symbolFlags & 3 /* Variable */ || symbolKind === "local var" /* localVariableElement */ || symbolKind === "index" /* indexSignatureElement */ || isThisExpression) { - displayParts.push(punctuationPart(59 /* ColonToken */)); - displayParts.push(spacePart()); - if (type.symbol && type.symbol.flags & 262144 /* TypeParameter */ && symbolKind !== "index" /* indexSignatureElement */) { - const typeParameterParts = mapToDisplayParts((writer) => { - const param = typeChecker.typeParameterToDeclaration(type, enclosingDeclaration, symbolDisplayNodeBuilderFlags); - getPrinter().writeNode(4 /* Unspecified */, param, getSourceFileOfNode(getParseTreeNode(enclosingDeclaration)), writer); + const program = hostProject.getCurrentProgram(); + if (!program) { + return emptyArray; + } + const start = timestamp(); + let dependencyNames; + let rootNames; + const rootFileName = combinePaths(hostProject.currentDirectory, inferredTypesContainingFile); + const packageJsons = hostProject.getPackageJsonsForAutoImport(combinePaths(hostProject.currentDirectory, rootFileName)); + for (const packageJson of packageJsons) { + (_a = packageJson.dependencies) == null ? void 0 : _a.forEach((_, dependenyName) => addDependency(dependenyName)); + (_b = packageJson.peerDependencies) == null ? void 0 : _b.forEach((_, dependencyName) => addDependency(dependencyName)); + } + let dependenciesAdded = 0; + if (dependencyNames) { + const symlinkCache = hostProject.getSymlinkCache(); + for (const name of arrayFrom(dependencyNames.keys())) { + if (dependencySelection === 2 /* Auto */ && dependenciesAdded > this.maxDependencies) { + hostProject.log(`AutoImportProviderProject: attempted to add more than ${this.maxDependencies} dependencies. Aborting.`); + return emptyArray; + } + const packageJson = resolvePackageNameToPackageJson( + name, + hostProject.currentDirectory, + compilerOptions, + host, + program.getModuleResolutionCache() + ); + if (packageJson) { + const entrypoints = getRootNamesFromPackageJson(packageJson, program, symlinkCache); + if (entrypoints) { + rootNames = concatenate(rootNames, entrypoints); + dependenciesAdded += entrypoints.length ? 1 : 0; + continue; + } + } + const done = forEach([hostProject.currentDirectory, hostProject.getGlobalTypingsCacheLocation()], (directory) => { + if (directory) { + const typesPackageJson = resolvePackageNameToPackageJson( + `@types/${name}`, + directory, + compilerOptions, + host, + program.getModuleResolutionCache() + ); + if (typesPackageJson) { + const entrypoints = getRootNamesFromPackageJson(typesPackageJson, program, symlinkCache); + rootNames = concatenate(rootNames, entrypoints); + dependenciesAdded += (entrypoints == null ? void 0 : entrypoints.length) ? 1 : 0; + return true; + } + } }); - addRange(displayParts, typeParameterParts); - } else { - addRange(displayParts, typeToDisplayParts(typeChecker, type, enclosingDeclaration)); + if (done) + continue; + if (packageJson && compilerOptions.allowJs && compilerOptions.maxNodeModuleJsDepth) { + const entrypoints = getRootNamesFromPackageJson( + packageJson, + program, + symlinkCache, + /*resolveJs*/ + true + ); + rootNames = concatenate(rootNames, entrypoints); + dependenciesAdded += (entrypoints == null ? void 0 : entrypoints.length) ? 1 : 0; + } } - if (isTransientSymbol(symbol) && symbol.links.target && isTransientSymbol(symbol.links.target) && symbol.links.target.links.tupleLabelDeclaration) { - const labelDecl = symbol.links.target.links.tupleLabelDeclaration; - Debug.assertNode(labelDecl.name, isIdentifier); - displayParts.push(spacePart()); - displayParts.push(punctuationPart(21 /* OpenParenToken */)); - displayParts.push(textPart(idText(labelDecl.name))); - displayParts.push(punctuationPart(22 /* CloseParenToken */)); + } + if (rootNames == null ? void 0 : rootNames.length) { + hostProject.log(`AutoImportProviderProject: found ${rootNames.length} root files in ${dependenciesAdded} dependencies in ${timestamp() - start} ms`); + } + return rootNames || emptyArray; + function addDependency(dependency) { + if (!startsWith(dependency, "@types/")) { + (dependencyNames || (dependencyNames = /* @__PURE__ */ new Set())).add(dependency); } - } else if (symbolFlags & 16 /* Function */ || symbolFlags & 8192 /* Method */ || symbolFlags & 16384 /* Constructor */ || symbolFlags & 131072 /* Signature */ || symbolFlags & 98304 /* Accessor */ || symbolKind === "method" /* memberFunctionElement */) { - const allSignatures = type.getNonNullableType().getCallSignatures(); - if (allSignatures.length) { - addSignatureDisplayParts(allSignatures[0], allSignatures); - hasMultipleSignatures = allSignatures.length > 1; + } + function getRootNamesFromPackageJson(packageJson, program2, symlinkCache, resolveJs) { + var _a2; + const entrypoints = getEntrypointsFromPackageJsonInfo( + packageJson, + compilerOptions, + host, + program2.getModuleResolutionCache(), + resolveJs + ); + if (entrypoints) { + const real = (_a2 = host.realpath) == null ? void 0 : _a2.call(host, packageJson.packageDirectory); + const realPath2 = real ? hostProject.toPath(real) : void 0; + const isSymlink = realPath2 && realPath2 !== hostProject.toPath(packageJson.packageDirectory); + if (isSymlink) { + symlinkCache.setSymlinkedDirectory(packageJson.packageDirectory, { + real: ensureTrailingDirectorySeparator(real), + realPath: ensureTrailingDirectorySeparator(realPath2) + }); + } + return mapDefined(entrypoints, (entrypoint) => { + const resolvedFileName = isSymlink ? entrypoint.replace(packageJson.packageDirectory, real) : entrypoint; + if (!program2.getSourceFile(resolvedFileName) && !(isSymlink && program2.getSourceFile(entrypoint))) { + return resolvedFileName; + } + }); } } } - } else { - symbolKind = getSymbolKind(typeChecker, symbol, location); - } - } - if (documentation.length === 0 && !hasMultipleSignatures) { - documentation = symbol.getContextualDocumentationComment(enclosingDeclaration, typeChecker); - } - if (documentation.length === 0 && symbolFlags & 4 /* Property */) { - if (symbol.parent && symbol.declarations && forEach(symbol.parent.declarations, (declaration) => declaration.kind === 311 /* SourceFile */)) { - for (const declaration of symbol.declarations) { - if (!declaration.parent || declaration.parent.kind !== 225 /* BinaryExpression */) { - continue; - } - const rhsSymbol = typeChecker.getSymbolAtLocation(declaration.parent.right); - if (!rhsSymbol) { - continue; + /** @internal */ + static create(dependencySelection, hostProject, host, documentRegistry) { + if (dependencySelection === 0 /* Off */) { + return void 0; } - documentation = rhsSymbol.getDocumentationComment(typeChecker); - tags = rhsSymbol.getJsDocTags(typeChecker); - if (documentation.length > 0) { - break; + const compilerOptions = { + ...hostProject.getCompilerOptions(), + ...this.compilerOptionsOverrides + }; + const rootNames = this.getRootFileNames(dependencySelection, hostProject, host, compilerOptions); + if (!rootNames.length) { + return void 0; } + return new _AutoImportProviderProject(hostProject, rootNames, documentRegistry, compilerOptions); } - } - } - if (documentation.length === 0 && isIdentifier(location) && symbol.valueDeclaration && isBindingElement(symbol.valueDeclaration)) { - const declaration = symbol.valueDeclaration; - const parent2 = declaration.parent; - if (isIdentifier(declaration.name) && isObjectBindingPattern(parent2)) { - const name = getTextOfIdentifierOrLiteral(declaration.name); - const objectType = typeChecker.getTypeAtLocation(parent2); - documentation = firstDefined(objectType.isUnion() ? objectType.types : [objectType], (t) => { - const prop = t.getProperty(name); - return prop ? prop.getDocumentationComment(typeChecker) : void 0; - }) || emptyArray; - } - } - if (tags.length === 0 && !hasMultipleSignatures) { - tags = symbol.getContextualJsDocTags(enclosingDeclaration, typeChecker); - } - if (documentation.length === 0 && documentationFromAlias) { - documentation = documentationFromAlias; - } - if (tags.length === 0 && tagsFromAlias) { - tags = tagsFromAlias; - } - return { displayParts, documentation, symbolKind, tags: tags.length === 0 ? void 0 : tags }; - function getPrinter() { - return createPrinterWithRemoveComments(); - } - function prefixNextMeaning() { - if (displayParts.length) { - displayParts.push(lineBreakPart()); - } - addAliasPrefixIfNecessary(); - } - function addAliasPrefixIfNecessary() { - if (alias) { - pushSymbolKind("alias" /* alias */); - displayParts.push(spacePart()); - } - } - function addInPrefix() { - displayParts.push(spacePart()); - displayParts.push(keywordPart(103 /* InKeyword */)); - displayParts.push(spacePart()); - } - function addFullSymbolName(symbolToDisplay, enclosingDeclaration2) { - let indexInfos; - if (alias && symbolToDisplay === symbol) { - symbolToDisplay = alias; - } - if (symbolKind === "index" /* indexSignatureElement */) { - indexInfos = typeChecker.getIndexInfosOfIndexSymbol(symbolToDisplay); - } - let fullSymbolDisplayParts = []; - if (symbolToDisplay.flags & 131072 /* Signature */ && indexInfos) { - if (symbolToDisplay.parent) { - fullSymbolDisplayParts = symbolToDisplayParts(typeChecker, symbolToDisplay.parent); + /** @internal */ + isEmpty() { + return !some(this.rootFileNames); } - fullSymbolDisplayParts.push(punctuationPart(23 /* OpenBracketToken */)); - indexInfos.forEach((info, i) => { - fullSymbolDisplayParts.push(...typeToDisplayParts(typeChecker, info.keyType)); - if (i !== indexInfos.length - 1) { - fullSymbolDisplayParts.push(spacePart()); - fullSymbolDisplayParts.push(punctuationPart(52 /* BarToken */)); - fullSymbolDisplayParts.push(spacePart()); + isOrphan() { + return true; + } + updateGraph() { + let rootFileNames = this.rootFileNames; + if (!rootFileNames) { + rootFileNames = _AutoImportProviderProject.getRootFileNames( + this.hostProject.includePackageJsonAutoImports(), + this.hostProject, + this.hostProject.getHostForAutoImportProvider(), + this.getCompilationSettings() + ); } - }); - fullSymbolDisplayParts.push(punctuationPart(24 /* CloseBracketToken */)); - } else { - fullSymbolDisplayParts = symbolToDisplayParts( - typeChecker, - symbolToDisplay, - enclosingDeclaration2 || sourceFile, - /*meaning*/ - void 0, - 1 /* WriteTypeParametersOrArguments */ | 2 /* UseOnlyExternalAliasing */ | 4 /* AllowAnyNodeKind */ - ); - } - addRange(displayParts, fullSymbolDisplayParts); - if (symbol.flags & 16777216 /* Optional */) { - displayParts.push(punctuationPart(58 /* QuestionToken */)); - } - } - function addPrefixForAnyFunctionOrVar(symbol2, symbolKind2) { - prefixNextMeaning(); - if (symbolKind2) { - pushSymbolKind(symbolKind2); - if (symbol2 && !some(symbol2.declarations, (d) => isArrowFunction(d) || (isFunctionExpression(d) || isClassExpression(d)) && !d.name)) { - displayParts.push(spacePart()); - addFullSymbolName(symbol2); + this.projectService.setFileNamesOfAutpImportProviderOrAuxillaryProject(this, rootFileNames); + this.rootFileNames = rootFileNames; + const oldProgram = this.getCurrentProgram(); + const hasSameSetOfFiles = super.updateGraph(); + if (oldProgram && oldProgram !== this.getCurrentProgram()) { + this.hostProject.clearCachedExportInfoMap(); + } + return hasSameSetOfFiles; } - } - } - function pushSymbolKind(symbolKind2) { - switch (symbolKind2) { - case "var" /* variableElement */: - case "function" /* functionElement */: - case "let" /* letElement */: - case "const" /* constElement */: - case "constructor" /* constructorImplementationElement */: - displayParts.push(textOrKeywordPart(symbolKind2)); - return; - default: - displayParts.push(punctuationPart(21 /* OpenParenToken */)); - displayParts.push(textOrKeywordPart(symbolKind2)); - displayParts.push(punctuationPart(22 /* CloseParenToken */)); + /** @internal */ + scheduleInvalidateResolutionsOfFailedLookupLocations() { return; - } + } + hasRoots() { + var _a; + return !!((_a = this.rootFileNames) == null ? void 0 : _a.length); + } + markAsDirty() { + this.rootFileNames = void 0; + super.markAsDirty(); + } + getScriptFileNames() { + return this.rootFileNames || emptyArray; + } + getLanguageService() { + throw new Error("AutoImportProviderProject language service should never be used. To get the program, use `project.getCurrentProgram()`."); + } + /** @internal */ + onAutoImportProviderSettingsChanged() { + throw new Error("AutoImportProviderProject is an auto import provider; use `markAsDirty()` instead."); + } + /** @internal */ + onPackageJsonChange() { + throw new Error("package.json changes should be notified on an AutoImportProvider's host project"); + } + getHostForAutoImportProvider() { + throw new Error("AutoImportProviderProject cannot provide its own host; use `hostProject.getModuleResolutionHostForAutomImportProvider()` instead."); + } + getProjectReferences() { + return this.hostProject.getProjectReferences(); + } + /** @internal */ + includePackageJsonAutoImports() { + return 0 /* Off */; + } + /** @internal */ + getSymlinkCache() { + return this.hostProject.getSymlinkCache(); + } + /** @internal */ + getModuleResolutionCache() { + var _a; + return (_a = this.hostProject.getCurrentProgram()) == null ? void 0 : _a.getModuleResolutionCache(); + } + }; + /** @internal */ + _AutoImportProviderProject.maxDependencies = 10; + /** @internal */ + _AutoImportProviderProject.compilerOptionsOverrides = { + diagnostics: false, + skipLibCheck: true, + sourceMap: false, + types: emptyArray, + lib: emptyArray, + noLib: true + }; + AutoImportProviderProject = _AutoImportProviderProject; + ConfiguredProject2 = class extends Project3 { + /** @internal */ + constructor(configFileName, canonicalConfigFilePath, projectService, documentRegistry, cachedDirectoryStructureHost) { + super( + configFileName, + 1 /* Configured */, + projectService, + documentRegistry, + /*hasExplicitListOfFiles*/ + false, + /*lastFileExceededProgramSize*/ + void 0, + /*compilerOptions*/ + {}, + /*compileOnSaveEnabled*/ + false, + /*watchOptions*/ + void 0, + cachedDirectoryStructureHost, + getDirectoryPath(configFileName) + ); + this.canonicalConfigFilePath = canonicalConfigFilePath; + /** @internal */ + this.openFileWatchTriggered = /* @__PURE__ */ new Map(); + /** @internal */ + this.canConfigFileJsonReportNoInputFiles = false; + /** Ref count to the project when opened from external project */ + this.externalProjectRefCount = 0; + /** @internal */ + this.isInitialLoadPending = returnTrue; + /** @internal */ + this.sendLoadingProjectFinish = false; + } + /** @internal */ + setCompilerHost(host) { + this.compilerHost = host; + } + /** @internal */ + getCompilerHost() { + return this.compilerHost; + } + /** @internal */ + useSourceOfProjectReferenceRedirect() { + return this.languageServiceEnabled; + } + /** @internal */ + getParsedCommandLine(fileName) { + const configFileName = asNormalizedPath(normalizePath(fileName)); + const canonicalConfigFilePath = asNormalizedPath(this.projectService.toCanonicalFileName(configFileName)); + let configFileExistenceInfo = this.projectService.configFileExistenceInfoCache.get(canonicalConfigFilePath); + if (!configFileExistenceInfo) { + this.projectService.configFileExistenceInfoCache.set(canonicalConfigFilePath, configFileExistenceInfo = { exists: this.projectService.host.fileExists(configFileName) }); + } + this.projectService.ensureParsedConfigUptoDate(configFileName, canonicalConfigFilePath, configFileExistenceInfo, this); + if (this.languageServiceEnabled && this.projectService.serverMode === 0 /* Semantic */) { + this.projectService.watchWildcards(configFileName, configFileExistenceInfo, this); + } + return configFileExistenceInfo.exists ? configFileExistenceInfo.config.parsedCommandLine : void 0; + } + /** @internal */ + onReleaseParsedCommandLine(fileName) { + this.releaseParsedConfig(asNormalizedPath(this.projectService.toCanonicalFileName(asNormalizedPath(normalizePath(fileName))))); + } + /** @internal */ + releaseParsedConfig(canonicalConfigFilePath) { + this.projectService.stopWatchingWildCards(canonicalConfigFilePath, this); + this.projectService.releaseParsedConfig(canonicalConfigFilePath, this); + } + /** + * If the project has reload from disk pending, it reloads (and then updates graph as part of that) instead of just updating the graph + * @returns: true if set of files in the project stays the same and false - otherwise. + */ + updateGraph() { + const isInitialLoad = this.isInitialLoadPending(); + this.isInitialLoadPending = returnFalse; + const updateLevel = this.pendingUpdateLevel; + this.pendingUpdateLevel = 0 /* Update */; + let result; + switch (updateLevel) { + case 1 /* RootNamesAndUpdate */: + this.openFileWatchTriggered.clear(); + result = this.projectService.reloadFileNamesOfConfiguredProject(this); + break; + case 2 /* Full */: + this.openFileWatchTriggered.clear(); + const reason = Debug.checkDefined(this.pendingUpdateReason); + this.pendingUpdateReason = void 0; + this.projectService.reloadConfiguredProject( + this, + reason, + isInitialLoad, + /*clearSemanticCache*/ + false + ); + result = true; + break; + default: + result = super.updateGraph(); + } + this.compilerHost = void 0; + this.projectService.sendProjectLoadingFinishEvent(this); + this.projectService.sendProjectTelemetry(this); + return result; + } + /** @internal */ + getCachedDirectoryStructureHost() { + return this.directoryStructureHost; + } + getConfigFilePath() { + return asNormalizedPath(this.getProjectName()); + } + getProjectReferences() { + return this.projectReferences; + } + updateReferences(refs) { + if (typeof process.versions.pnp !== `undefined`) { + const basePath = this.getCurrentDirectory(); + const getPnpPath = (path) => { + try { + const pnpApi = getPnpApi(`${path}/`); + if (!pnpApi) { + return path; + } + const targetLocator = pnpApi.findPackageLocator(`${path}/`); + const { packageLocation } = pnpApi.getPackageInformation(targetLocator); + const request = combinePaths(targetLocator.name, getRelativePathFromDirectory( + packageLocation, + path, + /*ignoreCase*/ + false + )); + return pnpApi.resolveToUnqualified(request, `${basePath}/`); + } catch { + return path; + } + }; + refs = refs == null ? void 0 : refs.map((r) => ({ ...r, path: getPnpPath(r.path) })); + } + this.projectReferences = refs; + this.potentialProjectReferences = void 0; + } + /** @internal */ + setPotentialProjectReference(canonicalConfigPath) { + Debug.assert(this.isInitialLoadPending()); + (this.potentialProjectReferences || (this.potentialProjectReferences = /* @__PURE__ */ new Set())).add(canonicalConfigPath); + } + /** @internal */ + getResolvedProjectReferenceToRedirect(fileName) { + const program = this.getCurrentProgram(); + return program && program.getResolvedProjectReferenceToRedirect(fileName); + } + /** @internal */ + forEachResolvedProjectReference(cb) { + var _a; + return (_a = this.getCurrentProgram()) == null ? void 0 : _a.forEachResolvedProjectReference(cb); + } + /** @internal */ + enablePluginsWithOptions(options) { + var _a; + this.plugins.length = 0; + if (!((_a = options.plugins) == null ? void 0 : _a.length) && !this.projectService.globalPlugins.length) + return; + const host = this.projectService.host; + if (!host.require && !host.importPlugin) { + this.projectService.logger.info("Plugins were requested but not running in environment that supports 'require'. Nothing will be loaded"); + return; + } + const searchPaths = this.getGlobalPluginSearchPaths(); + if (this.projectService.allowLocalPluginLoads) { + const local = getDirectoryPath(this.canonicalConfigFilePath); + this.projectService.logger.info(`Local plugin loading enabled; adding ${local} to search paths`); + searchPaths.unshift(local); + } + if (options.plugins) { + for (const pluginConfigEntry of options.plugins) { + this.enablePlugin(pluginConfigEntry, searchPaths); + } + } + return this.enableGlobalPlugins(options); + } + /** + * Get the errors that dont have any file name associated + */ + getGlobalProjectErrors() { + return filter(this.projectErrors, (diagnostic) => !diagnostic.file) || emptyArray2; + } + /** + * Get all the project errors + */ + getAllProjectErrors() { + return this.projectErrors || emptyArray2; + } + setProjectErrors(projectErrors) { + this.projectErrors = projectErrors; + } + close() { + this.projectService.configFileExistenceInfoCache.forEach((_configFileExistenceInfo, canonicalConfigFilePath) => this.releaseParsedConfig(canonicalConfigFilePath)); + this.projectErrors = void 0; + this.openFileWatchTriggered.clear(); + this.compilerHost = void 0; + super.close(); + } + /** @internal */ + addExternalProjectReference() { + this.externalProjectRefCount++; + } + /** @internal */ + deleteExternalProjectReference() { + this.externalProjectRefCount--; + } + /** @internal */ + isSolution() { + return this.getRootFilesMap().size === 0 && !this.canConfigFileJsonReportNoInputFiles; + } + /** + * Find the configured project from the project references in project which contains the info directly + * + * @internal + */ + getDefaultChildProjectFromProjectWithReferences(info) { + return forEachResolvedProjectReferenceProject( + this, + info.path, + (child) => projectContainsInfoDirectly(child, info) ? child : void 0, + 0 /* Find */ + ); + } + /** + * Returns true if the project is needed by any of the open script info/external project + * + * @internal + */ + hasOpenRef() { + var _a; + if (!!this.externalProjectRefCount) { + return true; + } + if (this.isClosed()) { + return false; + } + const configFileExistenceInfo = this.projectService.configFileExistenceInfoCache.get(this.canonicalConfigFilePath); + if (this.projectService.hasPendingProjectUpdate(this)) { + return !!((_a = configFileExistenceInfo.openFilesImpactedByConfigFile) == null ? void 0 : _a.size); + } + return !!configFileExistenceInfo.openFilesImpactedByConfigFile && forEachEntry( + configFileExistenceInfo.openFilesImpactedByConfigFile, + (_value, infoPath) => { + const info = this.projectService.getScriptInfoForPath(infoPath); + return this.containsScriptInfo(info) || !!forEachResolvedProjectReferenceProject( + this, + info.path, + (child) => child.containsScriptInfo(info), + 0 /* Find */ + ); + } + ) || false; + } + /** @internal */ + hasExternalProjectRef() { + return !!this.externalProjectRefCount; + } + getEffectiveTypeRoots() { + return getEffectiveTypeRoots(this.getCompilationSettings(), this) || []; + } + /** @internal */ + updateErrorOnNoInputFiles(fileNames) { + updateErrorForNoInputFiles(fileNames, this.getConfigFilePath(), this.getCompilerOptions().configFile.configFileSpecs, this.projectErrors, this.canConfigFileJsonReportNoInputFiles); + } + }; + ExternalProject2 = class extends Project3 { + /** @internal */ + constructor(externalProjectName, projectService, documentRegistry, compilerOptions, lastFileExceededProgramSize, compileOnSaveEnabled, projectFilePath, watchOptions) { + super( + externalProjectName, + 2 /* External */, + projectService, + documentRegistry, + /*hasExplicitListOfFiles*/ + true, + lastFileExceededProgramSize, + compilerOptions, + compileOnSaveEnabled, + watchOptions, + projectService.host, + getDirectoryPath(projectFilePath || normalizeSlashes(externalProjectName)) + ); + this.externalProjectName = externalProjectName; + this.compileOnSaveEnabled = compileOnSaveEnabled; + this.excludedFiles = []; + this.enableGlobalPlugins(this.getCompilerOptions()); + } + updateGraph() { + const result = super.updateGraph(); + this.projectService.sendProjectTelemetry(this); + return result; + } + getExcludedFiles() { + return this.excludedFiles; + } + }; } - function addSignatureDisplayParts(signature, allSignatures, flags = 0 /* None */) { - addRange(displayParts, signatureToDisplayParts(typeChecker, signature, enclosingDeclaration, flags | 32 /* WriteTypeArgumentsOfSignature */)); - if (allSignatures.length > 1) { - displayParts.push(spacePart()); - displayParts.push(punctuationPart(21 /* OpenParenToken */)); - displayParts.push(operatorPart(40 /* PlusToken */)); - displayParts.push(displayPart((allSignatures.length - 1).toString(), 7 /* numericLiteral */)); - displayParts.push(spacePart()); - displayParts.push(textPart(allSignatures.length === 2 ? "overload" : "overloads")); - displayParts.push(punctuationPart(22 /* CloseParenToken */)); - } - documentation = signature.getDocumentationComment(typeChecker); - tags = signature.getJsDocTags(); - if (allSignatures.length > 1 && documentation.length === 0 && tags.length === 0) { - documentation = allSignatures[0].getDocumentationComment(typeChecker); - tags = allSignatures[0].getJsDocTags().filter((tag) => tag.name !== "deprecated"); + }); + + // src/server/editorServices.ts + function prepareConvertersForEnumLikeCompilerOptions(commandLineOptions) { + const map2 = /* @__PURE__ */ new Map(); + for (const option of commandLineOptions) { + if (typeof option.type === "object") { + const optionMap = option.type; + optionMap.forEach((value) => { + Debug.assert(typeof value === "number"); + }); + map2.set(option.name, optionMap); } } - function writeTypeParametersOfSymbol(symbol2, enclosingDeclaration2) { - const typeParameterParts = mapToDisplayParts((writer) => { - const params = typeChecker.symbolToTypeParameterDeclarations(symbol2, enclosingDeclaration2, symbolDisplayNodeBuilderFlags); - getPrinter().writeList(53776 /* TypeParameters */, params, getSourceFileOfNode(getParseTreeNode(enclosingDeclaration2)), writer); - }); - addRange(displayParts, typeParameterParts); - } + return map2; } - function isLocalVariableOrFunction(symbol) { - if (symbol.parent) { - return false; + function convertFormatOptions(protocolOptions) { + if (isString(protocolOptions.indentStyle)) { + protocolOptions.indentStyle = indentStyle.get(protocolOptions.indentStyle.toLowerCase()); + Debug.assert(protocolOptions.indentStyle !== void 0); } - return forEach(symbol.declarations, (declaration) => { - if (declaration.kind === 217 /* FunctionExpression */) { - return true; - } - if (declaration.kind !== 259 /* VariableDeclaration */ && declaration.kind !== 261 /* FunctionDeclaration */) { - return false; - } - for (let parent2 = declaration.parent; !isFunctionBlock(parent2); parent2 = parent2.parent) { - if (parent2.kind === 311 /* SourceFile */ || parent2.kind === 267 /* ModuleBlock */) { - return false; - } + return protocolOptions; + } + function convertCompilerOptions(protocolOptions) { + compilerOptionConverters.forEach((mappedValues, id) => { + const propertyValue = protocolOptions[id]; + if (isString(propertyValue)) { + protocolOptions[id] = mappedValues.get(propertyValue.toLowerCase()); } - return true; }); + return protocolOptions; } - var symbolDisplayNodeBuilderFlags; - var init_symbolDisplay = __esm({ - "src/services/symbolDisplay.ts"() { - "use strict"; - init_ts4(); - symbolDisplayNodeBuilderFlags = 8192 /* OmitParameterModifiers */ | 70221824 /* IgnoreErrors */ | 16384 /* UseAliasDefinedOutsideCurrentScope */; - } - }); - - // src/services/_namespaces/ts.SymbolDisplay.ts - var ts_SymbolDisplay_exports = {}; - __export(ts_SymbolDisplay_exports, { - getSymbolDisplayPartsDocumentationAndSymbolKind: () => getSymbolDisplayPartsDocumentationAndSymbolKind, - getSymbolKind: () => getSymbolKind, - getSymbolModifiers: () => getSymbolModifiers - }); - var init_ts_SymbolDisplay = __esm({ - "src/services/_namespaces/ts.SymbolDisplay.ts"() { - "use strict"; - init_symbolDisplay(); - } - }); - - // src/services/textChanges.ts - function getPos2(n) { - const result = n.__pos; - Debug.assert(typeof result === "number"); - return result; - } - function setPos(n, pos) { - Debug.assert(typeof pos === "number"); - n.__pos = pos; + function convertWatchOptions(protocolOptions, currentDirectory) { + let watchOptions; + let errors; + optionsForWatch.forEach((option) => { + const propertyValue = protocolOptions[option.name]; + if (propertyValue === void 0) + return; + const mappedValues = watchOptionsConverters.get(option.name); + (watchOptions || (watchOptions = {}))[option.name] = mappedValues ? isString(propertyValue) ? mappedValues.get(propertyValue.toLowerCase()) : propertyValue : convertJsonOption(option, propertyValue, currentDirectory || "", errors || (errors = [])); + }); + return watchOptions && { watchOptions, errors }; } - function getEnd(n) { - const result = n.__end; - Debug.assert(typeof result === "number"); + function convertTypeAcquisition(protocolOptions) { + let result; + typeAcquisitionDeclarations.forEach((option) => { + const propertyValue = protocolOptions[option.name]; + if (propertyValue === void 0) + return; + (result || (result = {}))[option.name] = propertyValue; + }); return result; } - function setEnd(n, end) { - Debug.assert(typeof end === "number"); - n.__end = end; - } - function skipWhitespacesAndLineBreaks(text, start) { - return skipTrivia( - text, - start, - /*stopAfterLineBreak*/ - false, - /*stopAtComments*/ - true - ); + function tryConvertScriptKindName(scriptKindName) { + return isString(scriptKindName) ? convertScriptKindName(scriptKindName) : scriptKindName; } - function hasCommentsBeforeLineBreak(text, start) { - let i = start; - while (i < text.length) { - const ch = text.charCodeAt(i); - if (isWhiteSpaceSingleLine(ch)) { - i++; - continue; - } - return ch === 47 /* slash */; + function convertScriptKindName(scriptKindName) { + switch (scriptKindName) { + case "JS": + return 1 /* JS */; + case "JSX": + return 2 /* JSX */; + case "TS": + return 3 /* TS */; + case "TSX": + return 4 /* TSX */; + default: + return 0 /* Unknown */; } - return false; } - function getAdjustedRange(sourceFile, startNode2, endNode2, options) { - return { pos: getAdjustedStartPosition(sourceFile, startNode2, options), end: getAdjustedEndPosition(sourceFile, endNode2, options) }; + function convertUserPreferences(preferences) { + const { lazyConfiguredProjectsFromExternalProject, ...userPreferences } = preferences; + return userPreferences; } - function getAdjustedStartPosition(sourceFile, node, options, hasTrailingComment = false) { - var _a, _b; - const { leadingTriviaOption } = options; - if (leadingTriviaOption === 0 /* Exclude */) { - return node.getStart(sourceFile); - } - if (leadingTriviaOption === 3 /* StartLine */) { - const startPos = node.getStart(sourceFile); - const pos = getLineStartPositionForPosition(startPos, sourceFile); - return rangeContainsPosition(node, pos) ? pos : startPos; - } - if (leadingTriviaOption === 2 /* JSDoc */) { - const JSDocComments = getJSDocCommentRanges(node, sourceFile.text); - if (JSDocComments == null ? void 0 : JSDocComments.length) { - return getLineStartPositionForPosition(JSDocComments[0].pos, sourceFile); - } - } - const fullStart = node.getFullStart(); - const start = node.getStart(sourceFile); - if (fullStart === start) { - return start; - } - const fullStartLine = getLineStartPositionForPosition(fullStart, sourceFile); - const startLine = getLineStartPositionForPosition(start, sourceFile); - if (startLine === fullStartLine) { - return leadingTriviaOption === 1 /* IncludeAll */ ? fullStart : start; - } - if (hasTrailingComment) { - const comment = ((_a = getLeadingCommentRanges(sourceFile.text, fullStart)) == null ? void 0 : _a[0]) || ((_b = getTrailingCommentRanges(sourceFile.text, fullStart)) == null ? void 0 : _b[0]); - if (comment) { - return skipTrivia( - sourceFile.text, - comment.end, - /*stopAfterLineBreak*/ - true, - /*stopAtComments*/ - true - ); + function findProjectByName(projectName, projects) { + for (const proj of projects) { + if (proj.getProjectName() === projectName) { + return proj; } } - const nextLineStart = fullStart > 0 ? 1 : 0; - let adjustedStartPosition = getStartPositionOfLine(getLineOfLocalPosition(sourceFile, fullStartLine) + nextLineStart, sourceFile); - adjustedStartPosition = skipWhitespacesAndLineBreaks(sourceFile.text, adjustedStartPosition); - return getStartPositionOfLine(getLineOfLocalPosition(sourceFile, adjustedStartPosition), sourceFile); } - function getEndPositionOfMultilineTrailingComment(sourceFile, node, options) { - const { end } = node; - const { trailingTriviaOption } = options; - if (trailingTriviaOption === 2 /* Include */) { - const comments = getTrailingCommentRanges(sourceFile.text, end); - if (comments) { - const nodeEndLine = getLineOfLocalPosition(sourceFile, node.end); - for (const comment of comments) { - if (comment.kind === 2 /* SingleLineCommentTrivia */ || getLineOfLocalPosition(sourceFile, comment.pos) > nodeEndLine) { - break; - } - const commentEndLine = getLineOfLocalPosition(sourceFile, comment.end); - if (commentEndLine > nodeEndLine) { - return skipTrivia( - sourceFile.text, - comment.end, - /*stopAfterLineBreak*/ - true, - /*stopAtComments*/ - true - ); - } - } - } - } - return void 0; + function isOpenScriptInfo(infoOrFileNameOrConfig) { + return !!infoOrFileNameOrConfig.containingProjects; } - function getAdjustedEndPosition(sourceFile, node, options) { + function isAncestorConfigFileInfo(infoOrFileNameOrConfig) { + return !!infoOrFileNameOrConfig.configFileInfo; + } + function forEachResolvedProjectReferenceProject(project, fileName, cb, projectReferenceProjectLoadKind, reason) { var _a; - const { end } = node; - const { trailingTriviaOption } = options; - if (trailingTriviaOption === 0 /* Exclude */) { - return end; - } - if (trailingTriviaOption === 1 /* ExcludeWhitespace */) { - const comments = concatenate(getTrailingCommentRanges(sourceFile.text, end), getLeadingCommentRanges(sourceFile.text, end)); - const realEnd = (_a = comments == null ? void 0 : comments[comments.length - 1]) == null ? void 0 : _a.end; - if (realEnd) { - return realEnd; + const resolvedRefs = (_a = project.getCurrentProgram()) == null ? void 0 : _a.getResolvedProjectReferences(); + if (!resolvedRefs) + return void 0; + let seenResolvedRefs; + const possibleDefaultRef = fileName ? project.getResolvedProjectReferenceToRedirect(fileName) : void 0; + if (possibleDefaultRef) { + const configFileName = toNormalizedPath(possibleDefaultRef.sourceFile.fileName); + const child = project.projectService.findConfiguredProjectByProjectName(configFileName); + if (child) { + const result = cb(child); + if (result) + return result; + } else if (projectReferenceProjectLoadKind !== 0 /* Find */) { + seenResolvedRefs = /* @__PURE__ */ new Map(); + const result = forEachResolvedProjectReferenceProjectWorker( + resolvedRefs, + project.getCompilerOptions(), + (ref, loadKind) => possibleDefaultRef === ref ? callback(ref, loadKind) : void 0, + projectReferenceProjectLoadKind, + project.projectService, + seenResolvedRefs + ); + if (result) + return result; + seenResolvedRefs.clear(); } - return end; - } - const multilineEndPosition = getEndPositionOfMultilineTrailingComment(sourceFile, node, options); - if (multilineEndPosition) { - return multilineEndPosition; } - const newEnd = skipTrivia( - sourceFile.text, - end, - /*stopAfterLineBreak*/ - true + return forEachResolvedProjectReferenceProjectWorker( + resolvedRefs, + project.getCompilerOptions(), + (ref, loadKind) => possibleDefaultRef !== ref ? callback(ref, loadKind) : void 0, + projectReferenceProjectLoadKind, + project.projectService, + seenResolvedRefs ); - return newEnd !== end && (trailingTriviaOption === 2 /* Include */ || isLineBreak(sourceFile.text.charCodeAt(newEnd - 1))) ? newEnd : end; + function callback(ref, loadKind) { + const configFileName = toNormalizedPath(ref.sourceFile.fileName); + const child = project.projectService.findConfiguredProjectByProjectName(configFileName) || (loadKind === 0 /* Find */ ? void 0 : loadKind === 1 /* FindCreate */ ? project.projectService.createConfiguredProject(configFileName) : loadKind === 2 /* FindCreateLoad */ ? project.projectService.createAndLoadConfiguredProject(configFileName, reason) : Debug.assertNever(loadKind)); + return child && cb(child); + } } - function isSeparator(node, candidate) { - return !!candidate && !!node.parent && (candidate.kind === 28 /* CommaToken */ || candidate.kind === 27 /* SemicolonToken */ && node.parent.kind === 209 /* ObjectLiteralExpression */); + function forEachResolvedProjectReferenceProjectWorker(resolvedProjectReferences, parentOptions, cb, projectReferenceProjectLoadKind, projectService, seenResolvedRefs) { + const loadKind = parentOptions.disableReferencedProjectLoad ? 0 /* Find */ : projectReferenceProjectLoadKind; + return forEach(resolvedProjectReferences, (ref) => { + if (!ref) + return void 0; + const configFileName = toNormalizedPath(ref.sourceFile.fileName); + const canonicalPath = projectService.toCanonicalFileName(configFileName); + const seenValue = seenResolvedRefs == null ? void 0 : seenResolvedRefs.get(canonicalPath); + if (seenValue !== void 0 && seenValue >= loadKind) { + return void 0; + } + const result = cb(ref, loadKind); + if (result) { + return result; + } + (seenResolvedRefs || (seenResolvedRefs = /* @__PURE__ */ new Map())).set(canonicalPath, loadKind); + return ref.references && forEachResolvedProjectReferenceProjectWorker(ref.references, ref.commandLine.options, cb, loadKind, projectService, seenResolvedRefs); + }); } - function isThisTypeAnnotatable(containingFunction) { - return isFunctionExpression(containingFunction) || isFunctionDeclaration(containingFunction); + function forEachPotentialProjectReference(project, cb) { + return project.potentialProjectReferences && forEachKey(project.potentialProjectReferences, cb); } - function updateJSDocHost(parent2) { - if (parent2.kind !== 218 /* ArrowFunction */) { - return parent2; - } - const jsDocNode = parent2.parent.kind === 171 /* PropertyDeclaration */ ? parent2.parent : parent2.parent.parent; - jsDocNode.jsDoc = parent2.jsDoc; - return jsDocNode; + function forEachAnyProjectReferenceKind(project, cb, cbProjectRef, cbPotentialProjectRef) { + return project.getCurrentProgram() ? project.forEachResolvedProjectReference(cb) : project.isInitialLoadPending() ? forEachPotentialProjectReference(project, cbPotentialProjectRef) : forEach(project.getProjectReferences(), cbProjectRef); } - function tryMergeJsdocTags(oldTag, newTag) { - if (oldTag.kind !== newTag.kind) { - return void 0; - } - switch (oldTag.kind) { - case 347 /* JSDocParameterTag */: { - const oldParam = oldTag; - const newParam = newTag; - return isIdentifier(oldParam.name) && isIdentifier(newParam.name) && oldParam.name.escapedText === newParam.name.escapedText ? factory.createJSDocParameterTag( - /*tagName*/ - void 0, - newParam.name, - /*isBracketed*/ - false, - newParam.typeExpression, - newParam.isNameFirst, - oldParam.comment - ) : void 0; - } - case 348 /* JSDocReturnTag */: - return factory.createJSDocReturnTag( - /*tagName*/ - void 0, - newTag.typeExpression, - oldTag.comment - ); - case 350 /* JSDocTypeTag */: - return factory.createJSDocTypeTag( - /*tagName*/ - void 0, - newTag.typeExpression, - oldTag.comment - ); - } + function callbackRefProject(project, cb, refPath) { + const refProject = refPath && project.projectService.configuredProjects.get(refPath); + return refProject && cb(refProject); } - function startPositionToDeleteNodeInList(sourceFile, node) { - return skipTrivia( - sourceFile.text, - getAdjustedStartPosition(sourceFile, node, { leadingTriviaOption: 1 /* IncludeAll */ }), - /*stopAfterLineBreak*/ - false, - /*stopAtComments*/ - true + function forEachReferencedProject(project, cb) { + return forEachAnyProjectReferenceKind( + project, + (resolvedRef) => callbackRefProject(project, cb, resolvedRef.sourceFile.path), + (projectRef) => callbackRefProject(project, cb, project.toPath(resolveProjectReferencePath(projectRef))), + (potentialProjectRef) => callbackRefProject(project, cb, potentialProjectRef) ); } - function endPositionToDeleteNodeInList(sourceFile, node, prevNode, nextNode) { - const end = startPositionToDeleteNodeInList(sourceFile, nextNode); - if (prevNode === void 0 || positionsAreOnSameLine(getAdjustedEndPosition(sourceFile, node, {}), end, sourceFile)) { - return end; - } - const token = findPrecedingToken(nextNode.getStart(sourceFile), sourceFile); - if (isSeparator(node, token)) { - const prevToken = findPrecedingToken(node.getStart(sourceFile), sourceFile); - if (isSeparator(prevNode, prevToken)) { - const pos = skipTrivia( - sourceFile.text, - token.getEnd(), - /*stopAfterLineBreak*/ - true, - /*stopAtComments*/ - true - ); - if (positionsAreOnSameLine(prevToken.getStart(sourceFile), token.getStart(sourceFile), sourceFile)) { - return isLineBreak(sourceFile.text.charCodeAt(pos - 1)) ? pos - 1 : pos; - } - if (isLineBreak(sourceFile.text.charCodeAt(pos))) { - return pos; - } - } - } - return end; + function getDetailWatchInfo(watchType, project) { + return `${isString(project) ? `Config: ${project} ` : project ? `Project: ${project.getProjectName()} ` : ""}WatchType: ${watchType}`; } - function getClassOrObjectBraceEnds(cls, sourceFile) { - const open = findChildOfKind(cls, 19 /* OpenBraceToken */, sourceFile); - const close = findChildOfKind(cls, 20 /* CloseBraceToken */, sourceFile); - return [open == null ? void 0 : open.end, close == null ? void 0 : close.end]; + function isScriptInfoWatchedFromNodeModules(info) { + return !info.isScriptOpen() && info.mTime !== void 0; } - function getMembersOrProperties(node) { - return isObjectLiteralExpression(node) ? node.properties : node.members; + function projectContainsInfoDirectly(project, info) { + return project.containsScriptInfo(info) && !project.isSourceOfProjectReferenceRedirect(info.path); } - function applyChanges(text, changes) { - for (let i = changes.length - 1; i >= 0; i--) { - const { span, newText } = changes[i]; - text = `${text.substring(0, span.start)}${newText}${text.substring(textSpanEnd(span))}`; - } - return text; + function updateProjectIfDirty(project) { + project.invalidateResolutionsOfFailedLookupLocations(); + return project.dirty && project.updateGraph(); } - function isTrivia2(s) { - return skipTrivia(s, 0) === s.length; + function setProjectOptionsUsed(project) { + if (isConfiguredProject(project)) { + project.projectOptions = true; + } } - function assignPositionsToNode(node) { - const visited = visitEachChild(node, assignPositionsToNode, textChangesTransformationContext, assignPositionsToNodeArray, assignPositionsToNode); - const newNode = nodeIsSynthesized(visited) ? visited : Object.create(visited); - setTextRangePosEnd(newNode, getPos2(node), getEnd(node)); - return newNode; + function createProjectNameFactoryWithCounter(nameFactory) { + let nextId = 1; + return () => nameFactory(nextId++); } - function assignPositionsToNodeArray(nodes, visitor, test, start, count) { - const visited = visitNodes2(nodes, visitor, test, start, count); - if (!visited) { - return visited; - } - Debug.assert(nodes); - const nodeArray = visited === nodes ? factory.createNodeArray(visited.slice(0)) : visited; - setTextRangePosEnd(nodeArray, getPos2(nodes), getEnd(nodes)); - return nodeArray; + function getHostWatcherMap() { + return { idToCallbacks: /* @__PURE__ */ new Map(), pathToId: /* @__PURE__ */ new Map() }; } - function createWriter(newLine) { - let lastNonTriviaPosition = 0; - const writer = createTextWriter(newLine); - const onBeforeEmitNode = (node) => { - if (node) { - setPos(node, lastNonTriviaPosition); - } - }; - const onAfterEmitNode = (node) => { - if (node) { - setEnd(node, lastNonTriviaPosition); - } - }; - const onBeforeEmitNodeArray = (nodes) => { - if (nodes) { - setPos(nodes, lastNonTriviaPosition); - } - }; - const onAfterEmitNodeArray = (nodes) => { - if (nodes) { - setEnd(nodes, lastNonTriviaPosition); - } - }; - const onBeforeEmitToken = (node) => { - if (node) { - setPos(node, lastNonTriviaPosition); - } - }; - const onAfterEmitToken = (node) => { - if (node) { - setEnd(node, lastNonTriviaPosition); - } + function createWatchFactoryHostUsingWatchEvents(service, canUseWatchEvents) { + if (!canUseWatchEvents || !service.eventHandler || !service.session) + return void 0; + const watchedFiles = getHostWatcherMap(); + const watchedDirectories = getHostWatcherMap(); + const watchedDirectoriesRecursive = getHostWatcherMap(); + let ids = 1; + service.session.addProtocolHandler("watchChange" /* WatchChange */, (req) => { + onWatchChange(req.arguments); + return { responseRequired: false }; + }); + return { + watchFile: watchFile2, + watchDirectory, + getCurrentDirectory: () => service.host.getCurrentDirectory(), + useCaseSensitiveFileNames: service.host.useCaseSensitiveFileNames }; - function setLastNonTriviaPosition(s, force) { - if (force || !isTrivia2(s)) { - lastNonTriviaPosition = writer.getTextPos(); - let i = 0; - while (isWhiteSpaceLike(s.charCodeAt(s.length - i - 1))) { - i++; - } - lastNonTriviaPosition -= i; - } - } - function write(s) { - writer.write(s); - setLastNonTriviaPosition( - s, - /*force*/ - false - ); - } - function writeComment(s) { - writer.writeComment(s); - } - function writeKeyword(s) { - writer.writeKeyword(s); - setLastNonTriviaPosition( - s, - /*force*/ - false - ); - } - function writeOperator(s) { - writer.writeOperator(s); - setLastNonTriviaPosition( - s, - /*force*/ - false - ); - } - function writePunctuation(s) { - writer.writePunctuation(s); - setLastNonTriviaPosition( - s, - /*force*/ - false - ); - } - function writeTrailingSemicolon(s) { - writer.writeTrailingSemicolon(s); - setLastNonTriviaPosition( - s, - /*force*/ - false - ); - } - function writeParameter(s) { - writer.writeParameter(s); - setLastNonTriviaPosition( - s, - /*force*/ - false - ); - } - function writeProperty(s) { - writer.writeProperty(s); - setLastNonTriviaPosition( - s, - /*force*/ - false - ); - } - function writeSpace(s) { - writer.writeSpace(s); - setLastNonTriviaPosition( - s, - /*force*/ - false - ); - } - function writeStringLiteral(s) { - writer.writeStringLiteral(s); - setLastNonTriviaPosition( - s, - /*force*/ - false - ); - } - function writeSymbol(s, sym) { - writer.writeSymbol(s, sym); - setLastNonTriviaPosition( - s, - /*force*/ - false - ); - } - function writeLine(force) { - writer.writeLine(force); - } - function increaseIndent() { - writer.increaseIndent(); - } - function decreaseIndent() { - writer.decreaseIndent(); - } - function getText() { - return writer.getText(); - } - function rawWrite(s) { - writer.rawWrite(s); - setLastNonTriviaPosition( - s, - /*force*/ - false + function watchFile2(path, callback) { + return getOrCreateFileWatcher( + watchedFiles, + path, + callback, + (id) => ({ eventName: CreateFileWatcherEvent, data: { id, path } }) ); } - function writeLiteral(s) { - writer.writeLiteral(s); - setLastNonTriviaPosition( - s, - /*force*/ - true + function watchDirectory(path, callback, recursive) { + return getOrCreateFileWatcher( + recursive ? watchedDirectoriesRecursive : watchedDirectories, + path, + callback, + (id) => ({ eventName: CreateDirectoryWatcherEvent, data: { id, path, recursive: !!recursive } }) ); } - function getTextPos() { - return writer.getTextPos(); - } - function getLine() { - return writer.getLine(); - } - function getColumn() { - return writer.getColumn(); - } - function getIndent() { - return writer.getIndent(); - } - function isAtStartOfLine() { - return writer.isAtStartOfLine(); - } - function clear2() { - writer.clear(); - lastNonTriviaPosition = 0; - } - return { - onBeforeEmitNode, - onAfterEmitNode, - onBeforeEmitNodeArray, - onAfterEmitNodeArray, - onBeforeEmitToken, - onAfterEmitToken, - write, - writeComment, - writeKeyword, - writeOperator, - writePunctuation, - writeTrailingSemicolon, - writeParameter, - writeProperty, - writeSpace, - writeStringLiteral, - writeSymbol, - writeLine, - increaseIndent, - decreaseIndent, - getText, - rawWrite, - writeLiteral, - getTextPos, - getLine, - getColumn, - getIndent, - isAtStartOfLine, - hasTrailingComment: () => writer.hasTrailingComment(), - hasTrailingWhitespace: () => writer.hasTrailingWhitespace(), - clear: clear2 - }; - } - function getInsertionPositionAtSourceFileTop(sourceFile) { - let lastPrologue; - for (const node of sourceFile.statements) { - if (isPrologueDirective(node)) { - lastPrologue = node; - } else { - break; - } - } - let position = 0; - const text = sourceFile.text; - if (lastPrologue) { - position = lastPrologue.end; - advancePastLineBreak(); - return position; - } - const shebang = getShebang(text); - if (shebang !== void 0) { - position = shebang.length; - advancePastLineBreak(); - } - const ranges = getLeadingCommentRanges(text, position); - if (!ranges) - return position; - let lastComment; - let firstNodeLine; - for (const range of ranges) { - if (range.kind === 3 /* MultiLineCommentTrivia */) { - if (isPinnedComment(text, range.pos)) { - lastComment = { range, pinnedOrTripleSlash: true }; - continue; + function getOrCreateFileWatcher({ pathToId, idToCallbacks }, path, callback, event) { + const key = service.toPath(path); + let id = pathToId.get(key); + if (!id) + pathToId.set(key, id = ids++); + let callbacks = idToCallbacks.get(id); + if (!callbacks) { + idToCallbacks.set(id, callbacks = /* @__PURE__ */ new Set()); + service.eventHandler(event(id)); + } + callbacks.add(callback); + return { + close() { + const callbacks2 = idToCallbacks.get(id); + if (!(callbacks2 == null ? void 0 : callbacks2.delete(callback))) + return; + if (callbacks2.size) + return; + idToCallbacks.delete(id); + pathToId.delete(key); + service.eventHandler({ eventName: CloseFileWatcherEvent, data: { id } }); } - } else if (isRecognizedTripleSlashComment(text, range.pos, range.end)) { - lastComment = { range, pinnedOrTripleSlash: true }; - continue; - } - if (lastComment) { - if (lastComment.pinnedOrTripleSlash) - break; - const commentLine = sourceFile.getLineAndCharacterOfPosition(range.pos).line; - const lastCommentEndLine = sourceFile.getLineAndCharacterOfPosition(lastComment.range.end).line; - if (commentLine >= lastCommentEndLine + 2) - break; - } - if (sourceFile.statements.length) { - if (firstNodeLine === void 0) - firstNodeLine = sourceFile.getLineAndCharacterOfPosition(sourceFile.statements[0].getStart()).line; - const commentEndLine = sourceFile.getLineAndCharacterOfPosition(range.end).line; - if (firstNodeLine < commentEndLine + 2) - break; - } - lastComment = { range, pinnedOrTripleSlash: false }; + }; } - if (lastComment) { - position = lastComment.range.end; - advancePastLineBreak(); + function onWatchChange({ id, path, eventType }) { + onFileWatcherCallback(id, path, eventType); + onDirectoryWatcherCallback(watchedDirectories, id, path, eventType); + onDirectoryWatcherCallback(watchedDirectoriesRecursive, id, path, eventType); } - return position; - function advancePastLineBreak() { - if (position < text.length) { - const charCode = text.charCodeAt(position); - if (isLineBreak(charCode)) { - position++; - if (position < text.length && charCode === 13 /* carriageReturn */ && text.charCodeAt(position) === 10 /* lineFeed */) { - position++; - } - } - } + function onFileWatcherCallback(id, eventPath, eventType) { + var _a; + (_a = watchedFiles.idToCallbacks.get(id)) == null ? void 0 : _a.forEach((callback) => { + const eventKind = eventType === "create" ? 0 /* Created */ : eventType === "delete" ? 2 /* Deleted */ : 1 /* Changed */; + callback(eventPath, eventKind); + }); + } + function onDirectoryWatcherCallback({ idToCallbacks }, id, eventPath, eventType) { + var _a; + if (eventType === "update") + return; + (_a = idToCallbacks.get(id)) == null ? void 0 : _a.forEach((callback) => { + callback(eventPath); + }); } } - function isValidLocationToAddComment(sourceFile, position) { - return !isInComment(sourceFile, position) && !isInString(sourceFile, position) && !isInTemplateString(sourceFile, position) && !isInJSXText(sourceFile, position); - } - function needSemicolonBetween(a, b) { - return (isPropertySignature(a) || isPropertyDeclaration(a)) && isClassOrTypeElement(b) && b.name.kind === 166 /* ComputedPropertyName */ || isStatementButNotDeclaration(a) && isStatementButNotDeclaration(b); + function createIncompleteCompletionsCache() { + let info; + return { + get() { + return info; + }, + set(newInfo) { + info = newInfo; + }, + clear() { + info = void 0; + } + }; } - function deleteNode(changes, sourceFile, node, options = { leadingTriviaOption: 1 /* IncludeAll */ }) { - const startPosition = getAdjustedStartPosition(sourceFile, node, options); - const endPosition = getAdjustedEndPosition(sourceFile, node, options); - changes.deleteRange(sourceFile, { pos: startPosition, end: endPosition }); + function isConfigFile(config) { + return config.kind !== void 0; } - function deleteNodeInList(changes, deletedNodesInLists, sourceFile, node) { - const containingList = Debug.checkDefined(ts_formatting_exports.SmartIndenter.getContainingList(node, sourceFile)); - const index = indexOfNode(containingList, node); - Debug.assert(index !== -1); - if (containingList.length === 1) { - deleteNode(changes, sourceFile, node); - return; - } - Debug.assert(!deletedNodesInLists.has(node), "Deleting a node twice"); - deletedNodesInLists.add(node); - changes.deleteRange(sourceFile, { - pos: startPositionToDeleteNodeInList(sourceFile, node), - end: index === containingList.length - 1 ? getAdjustedEndPosition(sourceFile, node, {}) : endPositionToDeleteNodeInList(sourceFile, node, containingList[index - 1], containingList[index + 1]) - }); + function printProjectWithoutFileNames(project) { + project.print( + /*writeProjectFileNames*/ + false, + /*writeFileExplaination*/ + false, + /*writeFileVersionAndText*/ + false + ); } - var LeadingTriviaOption, TrailingTriviaOption, useNonAdjustedPositions, ChangeTracker, changesToText, textChangesTransformationContext, deleteDeclaration; - var init_textChanges = __esm({ - "src/services/textChanges.ts"() { + var maxProgramSizeForNonTsFiles, maxFileSize, ProjectsUpdatedInBackgroundEvent, ProjectLoadingStartEvent, ProjectLoadingFinishEvent, LargeFileReferencedEvent, ConfigFileDiagEvent, ProjectLanguageServiceStateEvent, ProjectInfoTelemetryEvent, OpenFileInfoTelemetryEvent, CreateFileWatcherEvent, CreateDirectoryWatcherEvent, CloseFileWatcherEvent, ensureProjectForOpenFileSchedule, compilerOptionConverters, watchOptionsConverters, indentStyle, defaultTypeSafeList, fileNamePropertyReader, externalFilePropertyReader, noopConfigFileWatcher, ProjectReferenceProjectLoadKind, _ProjectService, ProjectService3; + var init_editorServices = __esm({ + "src/server/editorServices.ts"() { "use strict"; - init_ts4(); - LeadingTriviaOption = /* @__PURE__ */ ((LeadingTriviaOption2) => { - LeadingTriviaOption2[LeadingTriviaOption2["Exclude"] = 0] = "Exclude"; - LeadingTriviaOption2[LeadingTriviaOption2["IncludeAll"] = 1] = "IncludeAll"; - LeadingTriviaOption2[LeadingTriviaOption2["JSDoc"] = 2] = "JSDoc"; - LeadingTriviaOption2[LeadingTriviaOption2["StartLine"] = 3] = "StartLine"; - return LeadingTriviaOption2; - })(LeadingTriviaOption || {}); - TrailingTriviaOption = /* @__PURE__ */ ((TrailingTriviaOption2) => { - TrailingTriviaOption2[TrailingTriviaOption2["Exclude"] = 0] = "Exclude"; - TrailingTriviaOption2[TrailingTriviaOption2["ExcludeWhitespace"] = 1] = "ExcludeWhitespace"; - TrailingTriviaOption2[TrailingTriviaOption2["Include"] = 2] = "Include"; - return TrailingTriviaOption2; - })(TrailingTriviaOption || {}); - useNonAdjustedPositions = { - leadingTriviaOption: 0 /* Exclude */, - trailingTriviaOption: 0 /* Exclude */ + init_pnp(); + init_ts7(); + init_ts_server3(); + init_protocol(); + maxProgramSizeForNonTsFiles = 20 * 1024 * 1024; + maxFileSize = 4 * 1024 * 1024; + ProjectsUpdatedInBackgroundEvent = "projectsUpdatedInBackground"; + ProjectLoadingStartEvent = "projectLoadingStart"; + ProjectLoadingFinishEvent = "projectLoadingFinish"; + LargeFileReferencedEvent = "largeFileReferenced"; + ConfigFileDiagEvent = "configFileDiag"; + ProjectLanguageServiceStateEvent = "projectLanguageServiceState"; + ProjectInfoTelemetryEvent = "projectInfo"; + OpenFileInfoTelemetryEvent = "openFileInfo"; + CreateFileWatcherEvent = "createFileWatcher"; + CreateDirectoryWatcherEvent = "createDirectoryWatcher"; + CloseFileWatcherEvent = "closeFileWatcher"; + ensureProjectForOpenFileSchedule = "*ensureProjectForOpenFiles*"; + compilerOptionConverters = prepareConvertersForEnumLikeCompilerOptions(optionDeclarations); + watchOptionsConverters = prepareConvertersForEnumLikeCompilerOptions(optionsForWatch); + indentStyle = new Map(Object.entries({ + none: 0 /* None */, + block: 1 /* Block */, + smart: 2 /* Smart */ + })); + defaultTypeSafeList = { + "jquery": { + // jquery files can have names like "jquery-1.10.2.min.js" (or "jquery.intellisense.js") + match: /jquery(-[\d.]+)?(\.intellisense)?(\.min)?\.js$/i, + types: ["jquery"] + }, + "WinJS": { + // e.g. c:/temp/UWApp1/lib/winjs-4.0.1/js/base.js + match: /^(.*\/winjs-[.\d]+)\/js\/base\.js$/i, + // If the winjs/base.js file is found.. + exclude: [["^", 1, "/.*"]], + // ..then exclude all files under the winjs folder + types: ["winjs"] + // And fetch the @types package for WinJS + }, + "Kendo": { + // e.g. /Kendo3/wwwroot/lib/kendo/kendo.all.min.js + match: /^(.*\/kendo(-ui)?)\/kendo\.all(\.min)?\.js$/i, + exclude: [["^", 1, "/.*"]], + types: ["kendo-ui"] + }, + "Office Nuget": { + // e.g. /scripts/Office/1/excel-15.debug.js + match: /^(.*\/office\/1)\/excel-\d+\.debug\.js$/i, + // Office NuGet package is installed under a "1/office" folder + exclude: [["^", 1, "/.*"]], + // Exclude that whole folder if the file indicated above is found in it + types: ["office"] + // @types package to fetch instead + }, + "References": { + match: /^(.*\/_references\.js)$/i, + exclude: [["^", 1, "$"]] + } }; - ChangeTracker = class { - /** Public for tests only. Other callers should use `ChangeTracker.with`. */ - constructor(newLineCharacter, formatContext) { - this.newLineCharacter = newLineCharacter; - this.formatContext = formatContext; - this.changes = []; - this.classesWithNodesInsertedAtStart = /* @__PURE__ */ new Map(); - // Set implemented as Map - this.deletedNodes = []; + fileNamePropertyReader = { + getFileName: (x) => x, + getScriptKind: (fileName, extraFileExtensions) => { + let result; + if (extraFileExtensions) { + const fileExtension = getAnyExtensionFromPath(fileName); + if (fileExtension) { + some(extraFileExtensions, (info) => { + if (info.extension === fileExtension) { + result = info.scriptKind; + return true; + } + return false; + }); + } + } + return result; + }, + hasMixedContent: (fileName, extraFileExtensions) => some(extraFileExtensions, (ext) => ext.isMixedContent && fileExtensionIs(fileName, ext.extension)) + }; + externalFilePropertyReader = { + getFileName: (x) => x.fileName, + getScriptKind: (x) => tryConvertScriptKindName(x.scriptKind), + // TODO: GH#18217 + hasMixedContent: (x) => !!x.hasMixedContent + }; + noopConfigFileWatcher = { close: noop }; + ProjectReferenceProjectLoadKind = /* @__PURE__ */ ((ProjectReferenceProjectLoadKind2) => { + ProjectReferenceProjectLoadKind2[ProjectReferenceProjectLoadKind2["Find"] = 0] = "Find"; + ProjectReferenceProjectLoadKind2[ProjectReferenceProjectLoadKind2["FindCreate"] = 1] = "FindCreate"; + ProjectReferenceProjectLoadKind2[ProjectReferenceProjectLoadKind2["FindCreateLoad"] = 2] = "FindCreateLoad"; + return ProjectReferenceProjectLoadKind2; + })(ProjectReferenceProjectLoadKind || {}); + _ProjectService = class _ProjectService { + constructor(opts) { + /** + * Container of all known scripts + * + * @internal + */ + this.filenameToScriptInfo = /* @__PURE__ */ new Map(); + this.nodeModulesWatchers = /* @__PURE__ */ new Map(); + /** + * Contains all the deleted script info's version information so that + * it does not reset when creating script info again + * (and could have potentially collided with version where contents mismatch) + */ + this.filenameToScriptInfoVersion = /* @__PURE__ */ new Map(); + // Set of all '.js' files ever opened. + this.allJsFilesForOpenFileTelemetry = /* @__PURE__ */ new Map(); + /** + * maps external project file name to list of config files that were the part of this project + */ + this.externalProjectToConfiguredProjectMap = /* @__PURE__ */ new Map(); + /** + * external projects (configuration and list of root files is not controlled by tsserver) + */ + this.externalProjects = []; + /** + * projects built from openFileRoots + */ + this.inferredProjects = []; + /** + * projects specified by a tsconfig.json file + */ + this.configuredProjects = /* @__PURE__ */ new Map(); + /** @internal */ + this.newInferredProjectName = createProjectNameFactoryWithCounter(makeInferredProjectName); + /** @internal */ + this.newAutoImportProviderProjectName = createProjectNameFactoryWithCounter(makeAutoImportProviderProjectName); + /** @internal */ + this.newAuxiliaryProjectName = createProjectNameFactoryWithCounter(makeAuxiliaryProjectName); + /** + * Open files: with value being project root path, and key being Path of the file that is open + */ + this.openFiles = /* @__PURE__ */ new Map(); + /** @internal */ + this.configFileForOpenFiles = /* @__PURE__ */ new Map(); + /** + * Map of open files that are opened without complete path but have projectRoot as current directory + */ + this.openFilesWithNonRootedDiskPath = /* @__PURE__ */ new Map(); + this.compilerOptionsForInferredProjectsPerProjectRoot = /* @__PURE__ */ new Map(); + this.watchOptionsForInferredProjectsPerProjectRoot = /* @__PURE__ */ new Map(); + this.typeAcquisitionForInferredProjectsPerProjectRoot = /* @__PURE__ */ new Map(); + /** + * Project size for configured or external projects + */ + this.projectToSizeMap = /* @__PURE__ */ new Map(); + /** + * This is a map of config file paths existence that doesnt need query to disk + * - The entry can be present because there is inferred project that needs to watch addition of config file to directory + * In this case the exists could be true/false based on config file is present or not + * - Or it is present if we have configured project open with config file at that location + * In this case the exists property is always true + * + * @internal + */ + this.configFileExistenceInfoCache = /* @__PURE__ */ new Map(); + this.safelist = defaultTypeSafeList; + this.legacySafelist = /* @__PURE__ */ new Map(); + this.pendingProjectUpdates = /* @__PURE__ */ new Map(); + /** @internal */ + this.pendingEnsureProjectForOpenFiles = false; + /** Tracks projects that we have already sent telemetry for. */ + this.seenProjects = /* @__PURE__ */ new Map(); + /** @internal */ + this.sharedExtendedConfigFileWatchers = /* @__PURE__ */ new Map(); + /** @internal */ + this.extendedConfigCache = /* @__PURE__ */ new Map(); + /** @internal */ + this.verifyDocumentRegistry = noop; + /** @internal */ + this.verifyProgram = noop; + /** @internal */ + this.onProjectCreation = noop; + var _a; + this.host = opts.host; + this.logger = opts.logger; + this.cancellationToken = opts.cancellationToken; + this.useSingleInferredProject = opts.useSingleInferredProject; + this.useInferredProjectPerProjectRoot = opts.useInferredProjectPerProjectRoot; + this.typingsInstaller = opts.typingsInstaller || nullTypingsInstaller; + this.throttleWaitMilliseconds = opts.throttleWaitMilliseconds; + this.eventHandler = opts.eventHandler; + this.suppressDiagnosticEvents = opts.suppressDiagnosticEvents; + this.globalPlugins = opts.globalPlugins || emptyArray2; + this.pluginProbeLocations = opts.pluginProbeLocations || emptyArray2; + this.allowLocalPluginLoads = !!opts.allowLocalPluginLoads; + this.typesMapLocation = opts.typesMapLocation === void 0 ? combinePaths(getDirectoryPath(this.getExecutingFilePath()), "typesMap.json") : opts.typesMapLocation; + this.session = opts.session; + this.jsDocParsingMode = opts.jsDocParsingMode; + if (opts.serverMode !== void 0) { + this.serverMode = opts.serverMode; + } else { + this.serverMode = 0 /* Semantic */; + } + if (this.host.realpath) { + this.realpathToScriptInfos = createMultiMap(); + } + this.currentDirectory = toNormalizedPath(this.host.getCurrentDirectory()); + this.toCanonicalFileName = createGetCanonicalFileName(this.host.useCaseSensitiveFileNames); + this.globalCacheLocationDirectoryPath = this.typingsInstaller.globalTypingsCacheLocation ? ensureTrailingDirectorySeparator(this.toPath(this.typingsInstaller.globalTypingsCacheLocation)) : void 0; + this.throttledOperations = new ThrottledOperations(this.host, this.logger); + if (this.typesMapLocation) { + this.loadTypesMap(); + } else { + this.logger.info("No types map provided; using the default"); + } + this.typingsInstaller.attach(this); + this.typingsCache = new TypingsCache(this.typingsInstaller); + this.hostConfiguration = { + formatCodeOptions: getDefaultFormatCodeSettings(this.host.newLine), + preferences: emptyOptions, + hostInfo: "Unknown host", + extraFileExtensions: [] + }; + this.documentRegistry = createDocumentRegistryInternal(this.host.useCaseSensitiveFileNames, this.currentDirectory, this.jsDocParsingMode, this); + const watchLogLevel = this.logger.hasLevel(3 /* verbose */) ? 2 /* Verbose */ : this.logger.loggingEnabled() ? 1 /* TriggerOnly */ : 0 /* None */; + const log = watchLogLevel !== 0 /* None */ ? (s) => this.logger.info(s) : noop; + this.packageJsonCache = createPackageJsonCache(this); + this.watchFactory = this.serverMode !== 0 /* Semantic */ ? { + watchFile: returnNoopFileWatcher, + watchDirectory: returnNoopFileWatcher + } : getWatchFactory( + createWatchFactoryHostUsingWatchEvents(this, opts.canUseWatchEvents) || this.host, + watchLogLevel, + log, + getDetailWatchInfo + ); + this.pnpWatcher = this.watchPnpFile(); + (_a = opts.incrementalVerifier) == null ? void 0 : _a.call(opts, this); } - static fromContext(context) { - return new ChangeTracker(getNewLineOrDefaultFromHost(context.host, context.formatContext.options), context.formatContext); + toPath(fileName) { + return toPath(fileName, this.currentDirectory, this.toCanonicalFileName); } - static with(context, cb) { - const tracker = ChangeTracker.fromContext(context); - cb(tracker); - return tracker.getChanges(); + /** @internal */ + getExecutingFilePath() { + return this.getNormalizedAbsolutePath(this.host.getExecutingFilePath()); } - pushRaw(sourceFile, change) { - Debug.assertEqual(sourceFile.fileName, change.fileName); - for (const c of change.textChanges) { - this.changes.push({ - kind: 3 /* Text */, - sourceFile, - text: c.newText, - range: createTextRangeFromSpan(c.span) - }); - } + /** @internal */ + getNormalizedAbsolutePath(fileName) { + return getNormalizedAbsolutePath(fileName, this.host.getCurrentDirectory()); } - deleteRange(sourceFile, range) { - this.changes.push({ kind: 0 /* Remove */, sourceFile, range }); + /** @internal */ + setDocument(key, path, sourceFile) { + const info = Debug.checkDefined(this.getScriptInfoForPath(path)); + info.cacheSourceFile = { key, sourceFile }; } - delete(sourceFile, node) { - this.deletedNodes.push({ sourceFile, node }); + /** @internal */ + getDocument(key, path) { + const info = this.getScriptInfoForPath(path); + return info && info.cacheSourceFile && info.cacheSourceFile.key === key ? info.cacheSourceFile.sourceFile : void 0; } - /** Stop! Consider using `delete` instead, which has logic for deleting nodes from delimited lists. */ - deleteNode(sourceFile, node, options = { leadingTriviaOption: 1 /* IncludeAll */ }) { - this.deleteRange(sourceFile, getAdjustedRange(sourceFile, node, node, options)); + /** @internal */ + ensureInferredProjectsUpToDate_TestOnly() { + this.ensureProjectStructuresUptoDate(); } - deleteNodes(sourceFile, nodes, options = { leadingTriviaOption: 1 /* IncludeAll */ }, hasTrailingComment) { - for (const node of nodes) { - const pos = getAdjustedStartPosition(sourceFile, node, options, hasTrailingComment); - const end = getAdjustedEndPosition(sourceFile, node, options); - this.deleteRange(sourceFile, { pos, end }); - hasTrailingComment = !!getEndPositionOfMultilineTrailingComment(sourceFile, node, options); + /** @internal */ + getCompilerOptionsForInferredProjects() { + return this.compilerOptionsForInferredProjects; + } + /** @internal */ + onUpdateLanguageServiceStateForProject(project, languageServiceEnabled) { + if (!this.eventHandler) { + return; } + const event = { + eventName: ProjectLanguageServiceStateEvent, + data: { project, languageServiceEnabled } + }; + this.eventHandler(event); } - deleteModifier(sourceFile, modifier) { - this.deleteRange(sourceFile, { pos: modifier.getStart(sourceFile), end: skipTrivia( - sourceFile.text, - modifier.end, - /*stopAfterLineBreak*/ - true - ) }); + loadTypesMap() { + try { + const fileContent = this.host.readFile(this.typesMapLocation); + if (fileContent === void 0) { + this.logger.info(`Provided types map file "${this.typesMapLocation}" doesn't exist`); + return; + } + const raw = JSON.parse(fileContent); + for (const k of Object.keys(raw.typesMap)) { + raw.typesMap[k].match = new RegExp(raw.typesMap[k].match, "i"); + } + this.safelist = raw.typesMap; + for (const key in raw.simpleMap) { + if (hasProperty(raw.simpleMap, key)) { + this.legacySafelist.set(key, raw.simpleMap[key].toLowerCase()); + } + } + } catch (e) { + this.logger.info(`Error loading types map: ${e}`); + this.safelist = defaultTypeSafeList; + this.legacySafelist.clear(); + } } - deleteNodeRange(sourceFile, startNode2, endNode2, options = { leadingTriviaOption: 1 /* IncludeAll */ }) { - const startPosition = getAdjustedStartPosition(sourceFile, startNode2, options); - const endPosition = getAdjustedEndPosition(sourceFile, endNode2, options); - this.deleteRange(sourceFile, { pos: startPosition, end: endPosition }); + // eslint-disable-line @typescript-eslint/unified-signatures + updateTypingsForProject(response) { + const project = this.findProject(response.projectName); + if (!project) { + return; + } + switch (response.kind) { + case ActionSet: + project.updateTypingFiles(this.typingsCache.updateTypingsForProject(response.projectName, response.compilerOptions, response.typeAcquisition, response.unresolvedImports, response.typings)); + return; + case ActionInvalidate: + this.typingsCache.enqueueInstallTypingsForProject( + project, + project.lastCachedUnresolvedImportsList, + /*forceRefresh*/ + true + ); + return; + } } - deleteNodeRangeExcludingEnd(sourceFile, startNode2, afterEndNode, options = { leadingTriviaOption: 1 /* IncludeAll */ }) { - const startPosition = getAdjustedStartPosition(sourceFile, startNode2, options); - const endPosition = afterEndNode === void 0 ? sourceFile.text.length : getAdjustedStartPosition(sourceFile, afterEndNode, options); - this.deleteRange(sourceFile, { pos: startPosition, end: endPosition }); + /** @internal */ + watchTypingLocations(response) { + var _a; + (_a = this.findProject(response.projectName)) == null ? void 0 : _a.watchTypingLocations(response.files); } - replaceRange(sourceFile, range, newNode, options = {}) { - this.changes.push({ kind: 1 /* ReplaceWithSingleNode */, sourceFile, range, options, node: newNode }); + /** @internal */ + delayEnsureProjectForOpenFiles() { + if (!this.openFiles.size) + return; + this.pendingEnsureProjectForOpenFiles = true; + this.throttledOperations.schedule( + ensureProjectForOpenFileSchedule, + /*delay*/ + 2500, + () => { + if (this.pendingProjectUpdates.size !== 0) { + this.delayEnsureProjectForOpenFiles(); + } else { + if (this.pendingEnsureProjectForOpenFiles) { + this.ensureProjectForOpenFiles(); + this.sendProjectsUpdatedInBackgroundEvent(); + } + } + } + ); } - replaceNode(sourceFile, oldNode, newNode, options = useNonAdjustedPositions) { - this.replaceRange(sourceFile, getAdjustedRange(sourceFile, oldNode, oldNode, options), newNode, options); + delayUpdateProjectGraph(project) { + project.markAsDirty(); + if (isBackgroundProject(project)) + return; + const projectName = project.getProjectName(); + this.pendingProjectUpdates.set(projectName, project); + this.throttledOperations.schedule( + projectName, + /*delay*/ + 250, + () => { + if (this.pendingProjectUpdates.delete(projectName)) { + updateProjectIfDirty(project); + } + } + ); } - replaceNodeRange(sourceFile, startNode2, endNode2, newNode, options = useNonAdjustedPositions) { - this.replaceRange(sourceFile, getAdjustedRange(sourceFile, startNode2, endNode2, options), newNode, options); + /** @internal */ + hasPendingProjectUpdate(project) { + return this.pendingProjectUpdates.has(project.getProjectName()); } - replaceRangeWithNodes(sourceFile, range, newNodes, options = {}) { - this.changes.push({ kind: 2 /* ReplaceWithMultipleNodes */, sourceFile, range, options, nodes: newNodes }); + /** @internal */ + sendProjectsUpdatedInBackgroundEvent() { + if (!this.eventHandler) { + return; + } + const event = { + eventName: ProjectsUpdatedInBackgroundEvent, + data: { + openFiles: arrayFrom(this.openFiles.keys(), (path) => this.getScriptInfoForPath(path).fileName) + } + }; + this.eventHandler(event); } - replaceNodeWithNodes(sourceFile, oldNode, newNodes, options = useNonAdjustedPositions) { - this.replaceRangeWithNodes(sourceFile, getAdjustedRange(sourceFile, oldNode, oldNode, options), newNodes, options); + /** @internal */ + sendLargeFileReferencedEvent(file, fileSize) { + if (!this.eventHandler) { + return; + } + const event = { + eventName: LargeFileReferencedEvent, + data: { file, fileSize, maxFileSize } + }; + this.eventHandler(event); } - replaceNodeWithText(sourceFile, oldNode, text) { - this.replaceRangeWithText(sourceFile, getAdjustedRange(sourceFile, oldNode, oldNode, useNonAdjustedPositions), text); + /** @internal */ + sendProjectLoadingStartEvent(project, reason) { + if (!this.eventHandler) { + return; + } + project.sendLoadingProjectFinish = true; + const event = { + eventName: ProjectLoadingStartEvent, + data: { project, reason } + }; + this.eventHandler(event); } - replaceNodeRangeWithNodes(sourceFile, startNode2, endNode2, newNodes, options = useNonAdjustedPositions) { - this.replaceRangeWithNodes(sourceFile, getAdjustedRange(sourceFile, startNode2, endNode2, options), newNodes, options); + /** @internal */ + sendProjectLoadingFinishEvent(project) { + if (!this.eventHandler || !project.sendLoadingProjectFinish) { + return; + } + project.sendLoadingProjectFinish = false; + const event = { + eventName: ProjectLoadingFinishEvent, + data: { project } + }; + this.eventHandler(event); } - nodeHasTrailingComment(sourceFile, oldNode, configurableEnd = useNonAdjustedPositions) { - return !!getEndPositionOfMultilineTrailingComment(sourceFile, oldNode, configurableEnd); + /** @internal */ + sendPerformanceEvent(kind, durationMs) { + if (this.performanceEventHandler) { + this.performanceEventHandler({ kind, durationMs }); + } } - nextCommaToken(sourceFile, node) { - const next = findNextToken(node, node.parent, sourceFile); - return next && next.kind === 28 /* CommaToken */ ? next : void 0; + /** @internal */ + delayUpdateProjectGraphAndEnsureProjectStructureForOpenFiles(project) { + this.delayUpdateProjectGraph(project); + this.delayEnsureProjectForOpenFiles(); } - replacePropertyAssignment(sourceFile, oldNode, newNode) { - const suffix = this.nextCommaToken(sourceFile, oldNode) ? "" : "," + this.newLineCharacter; - this.replaceNode(sourceFile, oldNode, newNode, { suffix }); + delayUpdateProjectGraphs(projects, clearSourceMapperCache) { + if (projects.length) { + for (const project of projects) { + if (clearSourceMapperCache) + project.clearSourceMapperCache(); + this.delayUpdateProjectGraph(project); + } + this.delayEnsureProjectForOpenFiles(); + } } - insertNodeAt(sourceFile, pos, newNode, options = {}) { - this.replaceRange(sourceFile, createRange(pos), newNode, options); + setCompilerOptionsForInferredProjects(projectCompilerOptions, projectRootPath) { + Debug.assert(projectRootPath === void 0 || this.useInferredProjectPerProjectRoot, "Setting compiler options per project root path is only supported when useInferredProjectPerProjectRoot is enabled"); + const compilerOptions = convertCompilerOptions(projectCompilerOptions); + const watchOptions = convertWatchOptions(projectCompilerOptions, projectRootPath); + const typeAcquisition = convertTypeAcquisition(projectCompilerOptions); + compilerOptions.allowNonTsExtensions = true; + const canonicalProjectRootPath = projectRootPath && this.toCanonicalFileName(projectRootPath); + if (canonicalProjectRootPath) { + this.compilerOptionsForInferredProjectsPerProjectRoot.set(canonicalProjectRootPath, compilerOptions); + this.watchOptionsForInferredProjectsPerProjectRoot.set(canonicalProjectRootPath, watchOptions || false); + this.typeAcquisitionForInferredProjectsPerProjectRoot.set(canonicalProjectRootPath, typeAcquisition); + } else { + this.compilerOptionsForInferredProjects = compilerOptions; + this.watchOptionsForInferredProjects = watchOptions; + this.typeAcquisitionForInferredProjects = typeAcquisition; + } + for (const project of this.inferredProjects) { + if (canonicalProjectRootPath ? project.projectRootPath === canonicalProjectRootPath : !project.projectRootPath || !this.compilerOptionsForInferredProjectsPerProjectRoot.has(project.projectRootPath)) { + project.setCompilerOptions(compilerOptions); + project.setTypeAcquisition(typeAcquisition); + project.setWatchOptions(watchOptions == null ? void 0 : watchOptions.watchOptions); + project.setProjectErrors(watchOptions == null ? void 0 : watchOptions.errors); + project.compileOnSaveEnabled = compilerOptions.compileOnSave; + project.markAsDirty(); + this.delayUpdateProjectGraph(project); + } + } + this.delayEnsureProjectForOpenFiles(); } - insertNodesAt(sourceFile, pos, newNodes, options = {}) { - this.replaceRangeWithNodes(sourceFile, createRange(pos), newNodes, options); + findProject(projectName) { + if (projectName === void 0) { + return void 0; + } + if (isInferredProjectName(projectName)) { + return findProjectByName(projectName, this.inferredProjects); + } + return this.findExternalProjectByProjectName(projectName) || this.findConfiguredProjectByProjectName(toNormalizedPath(projectName)); } - insertNodeAtTopOfFile(sourceFile, newNode, blankLineBetween) { - this.insertAtTopOfFile(sourceFile, newNode, blankLineBetween); + /** @internal */ + forEachProject(cb) { + this.externalProjects.forEach(cb); + this.configuredProjects.forEach(cb); + this.inferredProjects.forEach(cb); } - insertNodesAtTopOfFile(sourceFile, newNodes, blankLineBetween) { - this.insertAtTopOfFile(sourceFile, newNodes, blankLineBetween); + /** @internal */ + forEachEnabledProject(cb) { + this.forEachProject((project) => { + if (!project.isOrphan() && project.languageServiceEnabled) { + cb(project); + } + }); } - insertAtTopOfFile(sourceFile, insert, blankLineBetween) { - const pos = getInsertionPositionAtSourceFileTop(sourceFile); - const options = { - prefix: pos === 0 ? void 0 : this.newLineCharacter, - suffix: (isLineBreak(sourceFile.text.charCodeAt(pos)) ? "" : this.newLineCharacter) + (blankLineBetween ? this.newLineCharacter : "") + getDefaultProjectForFile(fileName, ensureProject) { + return ensureProject ? this.ensureDefaultProjectForFile(fileName) : this.tryGetDefaultProjectForFile(fileName); + } + /** @internal */ + tryGetDefaultProjectForFile(fileNameOrScriptInfo) { + const scriptInfo = isString(fileNameOrScriptInfo) ? this.getScriptInfoForNormalizedPath(fileNameOrScriptInfo) : fileNameOrScriptInfo; + return scriptInfo && !scriptInfo.isOrphan() ? scriptInfo.getDefaultProject() : void 0; + } + /** @internal */ + ensureDefaultProjectForFile(fileNameOrScriptInfo) { + return this.tryGetDefaultProjectForFile(fileNameOrScriptInfo) || this.doEnsureDefaultProjectForFile(fileNameOrScriptInfo); + } + doEnsureDefaultProjectForFile(fileNameOrScriptInfo) { + this.ensureProjectStructuresUptoDate(); + const scriptInfo = isString(fileNameOrScriptInfo) ? this.getScriptInfoForNormalizedPath(fileNameOrScriptInfo) : fileNameOrScriptInfo; + return scriptInfo ? scriptInfo.getDefaultProject() : (this.logErrorForScriptInfoNotFound(isString(fileNameOrScriptInfo) ? fileNameOrScriptInfo : fileNameOrScriptInfo.fileName), Errors.ThrowNoProject()); + } + getScriptInfoEnsuringProjectsUptoDate(uncheckedFileName) { + this.ensureProjectStructuresUptoDate(); + return this.getScriptInfo(uncheckedFileName); + } + /** + * Ensures the project structures are upto date + * This means, + * - we go through all the projects and update them if they are dirty + * - if updates reflect some change in structure or there was pending request to ensure projects for open files + * ensure that each open script info has project + */ + ensureProjectStructuresUptoDate() { + let hasChanges = this.pendingEnsureProjectForOpenFiles; + this.pendingProjectUpdates.clear(); + const updateGraph = (project) => { + hasChanges = updateProjectIfDirty(project) || hasChanges; }; - if (isArray(insert)) { - this.insertNodesAt(sourceFile, pos, insert, options); - } else { - this.insertNodeAt(sourceFile, pos, insert, options); + this.externalProjects.forEach(updateGraph); + this.configuredProjects.forEach(updateGraph); + this.inferredProjects.forEach(updateGraph); + if (hasChanges) { + this.ensureProjectForOpenFiles(); + } + } + getFormatCodeOptions(file) { + const info = this.getScriptInfoForNormalizedPath(file); + return info && info.getFormatCodeSettings() || this.hostConfiguration.formatCodeOptions; + } + getPreferences(file) { + const info = this.getScriptInfoForNormalizedPath(file); + return { ...this.hostConfiguration.preferences, ...info && info.getPreferences() }; + } + getHostFormatCodeOptions() { + return this.hostConfiguration.formatCodeOptions; + } + getHostPreferences() { + return this.hostConfiguration.preferences; + } + onSourceFileChanged(info, eventKind) { + if (eventKind === 2 /* Deleted */) { + this.handleDeletedFile(info); + } else if (!info.isScriptOpen()) { + info.delayReloadNonMixedContentFile(); + this.delayUpdateProjectGraphs( + info.containingProjects, + /*clearSourceMapperCache*/ + false + ); + this.handleSourceMapProjects(info); } } - insertNodesAtEndOfFile(sourceFile, newNodes, blankLineBetween) { - this.insertAtEndOfFile(sourceFile, newNodes, blankLineBetween); + handleSourceMapProjects(info) { + if (info.sourceMapFilePath) { + if (isString(info.sourceMapFilePath)) { + const sourceMapFileInfo = this.getScriptInfoForPath(info.sourceMapFilePath); + this.delayUpdateSourceInfoProjects(sourceMapFileInfo && sourceMapFileInfo.sourceInfos); + } else { + this.delayUpdateSourceInfoProjects(info.sourceMapFilePath.sourceInfos); + } + } + this.delayUpdateSourceInfoProjects(info.sourceInfos); + if (info.declarationInfoPath) { + this.delayUpdateProjectsOfScriptInfoPath(info.declarationInfoPath); + } } - insertAtEndOfFile(sourceFile, insert, blankLineBetween) { - const pos = sourceFile.end + 1; - const options = { - prefix: this.newLineCharacter, - suffix: this.newLineCharacter + (blankLineBetween ? this.newLineCharacter : "") - }; - this.insertNodesAt(sourceFile, pos, insert, options); + delayUpdateSourceInfoProjects(sourceInfos) { + if (sourceInfos) { + sourceInfos.forEach((_value, path) => this.delayUpdateProjectsOfScriptInfoPath(path)); + } } - insertStatementsInNewFile(fileName, statements, oldFile) { - if (!this.newFileChanges) { - this.newFileChanges = createMultiMap(); + delayUpdateProjectsOfScriptInfoPath(path) { + const info = this.getScriptInfoForPath(path); + if (info) { + this.delayUpdateProjectGraphs( + info.containingProjects, + /*clearSourceMapperCache*/ + true + ); } - this.newFileChanges.add(fileName, { oldFile, statements }); } - insertFirstParameter(sourceFile, parameters, newParam) { - const p0 = firstOrUndefined(parameters); - if (p0) { - this.insertNodeBefore(sourceFile, p0, newParam); + handleDeletedFile(info) { + this.stopWatchingScriptInfo(info); + if (!info.isScriptOpen()) { + this.deleteScriptInfo(info); + const containingProjects = info.containingProjects.slice(); + info.detachAllProjects(); + this.delayUpdateProjectGraphs( + containingProjects, + /*clearSourceMapperCache*/ + false + ); + this.handleSourceMapProjects(info); + info.closeSourceMapFileWatcher(); + if (info.declarationInfoPath) { + const declarationInfo = this.getScriptInfoForPath(info.declarationInfoPath); + if (declarationInfo) { + declarationInfo.sourceMapFilePath = void 0; + } + } + } + } + /** + * This is to watch whenever files are added or removed to the wildcard directories + * + * @internal + */ + watchWildcardDirectory(directory, flags, configFileName, config) { + return this.watchFactory.watchDirectory( + directory, + (fileOrDirectory) => { + const fileOrDirectoryPath = this.toPath(fileOrDirectory); + const fsResult = config.cachedDirectoryStructureHost.addOrDeleteFileOrDirectory(fileOrDirectory, fileOrDirectoryPath); + if (getBaseFileName(fileOrDirectoryPath) === "package.json" && !isInsideNodeModules(fileOrDirectoryPath) && (fsResult && fsResult.fileExists || !fsResult && this.host.fileExists(fileOrDirectoryPath))) { + this.logger.info(`Config: ${configFileName} Detected new package.json: ${fileOrDirectory}`); + this.onAddPackageJson(fileOrDirectoryPath); + } + const configuredProjectForConfig = this.findConfiguredProjectByProjectName(configFileName); + if (isIgnoredFileFromWildCardWatching({ + watchedDirPath: directory, + fileOrDirectory, + fileOrDirectoryPath, + configFileName, + extraFileExtensions: this.hostConfiguration.extraFileExtensions, + currentDirectory: this.currentDirectory, + options: config.parsedCommandLine.options, + program: (configuredProjectForConfig == null ? void 0 : configuredProjectForConfig.getCurrentProgram()) || config.parsedCommandLine.fileNames, + useCaseSensitiveFileNames: this.host.useCaseSensitiveFileNames, + writeLog: (s) => this.logger.info(s), + toPath: (s) => this.toPath(s), + getScriptKind: configuredProjectForConfig ? (fileName) => configuredProjectForConfig.getScriptKind(fileName) : void 0 + })) + return; + if (config.updateLevel !== 2 /* Full */) + config.updateLevel = 1 /* RootNamesAndUpdate */; + config.projects.forEach((watchWildcardDirectories, projectCanonicalPath) => { + if (!watchWildcardDirectories) + return; + const project = this.getConfiguredProjectByCanonicalConfigFilePath(projectCanonicalPath); + if (!project) + return; + const updateLevel = configuredProjectForConfig === project ? 1 /* RootNamesAndUpdate */ : 0 /* Update */; + if (project.pendingUpdateLevel !== void 0 && project.pendingUpdateLevel > updateLevel) + return; + if (this.openFiles.has(fileOrDirectoryPath)) { + const info = Debug.checkDefined(this.getScriptInfoForPath(fileOrDirectoryPath)); + if (info.isAttached(project)) { + const loadLevelToSet = Math.max(updateLevel, project.openFileWatchTriggered.get(fileOrDirectoryPath) || 0 /* Update */); + project.openFileWatchTriggered.set(fileOrDirectoryPath, loadLevelToSet); + } else { + project.pendingUpdateLevel = updateLevel; + this.delayUpdateProjectGraphAndEnsureProjectStructureForOpenFiles(project); + } + } else { + project.pendingUpdateLevel = updateLevel; + this.delayUpdateProjectGraphAndEnsureProjectStructureForOpenFiles(project); + } + }); + }, + flags, + this.getWatchOptionsFromProjectWatchOptions(config.parsedCommandLine.watchOptions), + WatchType.WildcardDirectory, + configFileName + ); + } + /** @internal */ + delayUpdateProjectsFromParsedConfigOnConfigFileChange(canonicalConfigFilePath, loadReason) { + const configFileExistenceInfo = this.configFileExistenceInfoCache.get(canonicalConfigFilePath); + if (!(configFileExistenceInfo == null ? void 0 : configFileExistenceInfo.config)) + return false; + let scheduledAnyProjectUpdate = false; + configFileExistenceInfo.config.updateLevel = 2 /* Full */; + configFileExistenceInfo.config.projects.forEach((_watchWildcardDirectories, projectCanonicalPath) => { + const project = this.getConfiguredProjectByCanonicalConfigFilePath(projectCanonicalPath); + if (!project) + return; + scheduledAnyProjectUpdate = true; + if (projectCanonicalPath === canonicalConfigFilePath) { + if (project.isInitialLoadPending()) + return; + project.pendingUpdateLevel = 2 /* Full */; + project.pendingUpdateReason = loadReason; + this.delayUpdateProjectGraph(project); + } else { + project.resolutionCache.removeResolutionsFromProjectReferenceRedirects(this.toPath(canonicalConfigFilePath)); + this.delayUpdateProjectGraph(project); + } + }); + return scheduledAnyProjectUpdate; + } + /** @internal */ + onConfigFileChanged(canonicalConfigFilePath, eventKind) { + var _a; + const configFileExistenceInfo = this.configFileExistenceInfoCache.get(canonicalConfigFilePath); + if (eventKind === 2 /* Deleted */) { + configFileExistenceInfo.exists = false; + const project = ((_a = configFileExistenceInfo.config) == null ? void 0 : _a.projects.has(canonicalConfigFilePath)) ? this.getConfiguredProjectByCanonicalConfigFilePath(canonicalConfigFilePath) : void 0; + if (project) + this.removeProject(project); } else { - this.insertNodeAt(sourceFile, parameters.pos, newParam); + configFileExistenceInfo.exists = true; } + this.delayUpdateProjectsFromParsedConfigOnConfigFileChange(canonicalConfigFilePath, "Change in config file detected"); + this.reloadConfiguredProjectForFiles( + configFileExistenceInfo.openFilesImpactedByConfigFile, + /*clearSemanticCache*/ + false, + /*delayReload*/ + true, + eventKind !== 2 /* Deleted */ ? identity : ( + // Reload open files if they are root of inferred project + returnTrue + ), + // Reload all the open files impacted by config file + "Change in config file detected" + ); + this.delayEnsureProjectForOpenFiles(); } - insertNodeBefore(sourceFile, before, newNode, blankLineBetween = false, options = {}) { - this.insertNodeAt(sourceFile, getAdjustedStartPosition(sourceFile, before, options), newNode, this.getOptionsForInsertNodeBefore(before, newNode, blankLineBetween)); + removeProject(project) { + this.logger.info("`remove Project::"); + project.print( + /*writeProjectFileNames*/ + true, + /*writeFileExplaination*/ + true, + /*writeFileVersionAndText*/ + false + ); + project.close(); + if (Debug.shouldAssert(1 /* Normal */)) { + this.filenameToScriptInfo.forEach( + (info) => Debug.assert( + !info.isAttached(project), + "Found script Info still attached to project", + () => `${project.projectName}: ScriptInfos still attached: ${JSON.stringify( + arrayFrom( + mapDefinedIterator( + this.filenameToScriptInfo.values(), + (info2) => info2.isAttached(project) ? { + fileName: info2.fileName, + projects: info2.containingProjects.map((p) => p.projectName), + hasMixedContent: info2.hasMixedContent + } : void 0 + ) + ), + /*replacer*/ + void 0, + " " + )}` + ) + ); + } + this.pendingProjectUpdates.delete(project.getProjectName()); + switch (project.projectKind) { + case 2 /* External */: + unorderedRemoveItem(this.externalProjects, project); + this.projectToSizeMap.delete(project.getProjectName()); + break; + case 1 /* Configured */: + this.configuredProjects.delete(project.canonicalConfigFilePath); + this.projectToSizeMap.delete(project.canonicalConfigFilePath); + break; + case 0 /* Inferred */: + unorderedRemoveItem(this.inferredProjects, project); + break; + } } - insertModifierAt(sourceFile, pos, modifier, options = {}) { - this.insertNodeAt(sourceFile, pos, factory.createToken(modifier), options); + /** @internal */ + assignOrphanScriptInfoToInferredProject(info, projectRootPath) { + Debug.assert(info.isOrphan()); + const project = this.getOrCreateInferredProjectForProjectRootPathIfEnabled(info, projectRootPath) || this.getOrCreateSingleInferredProjectIfEnabled() || this.getOrCreateSingleInferredWithoutProjectRoot( + info.isDynamic ? projectRootPath || this.currentDirectory : getDirectoryPath( + isRootedDiskPath(info.fileName) ? info.fileName : getNormalizedAbsolutePath( + info.fileName, + projectRootPath ? this.getNormalizedAbsolutePath(projectRootPath) : this.currentDirectory + ) + ) + ); + project.addRoot(info); + if (info.containingProjects[0] !== project) { + info.detachFromProject(project); + info.containingProjects.unshift(project); + } + project.updateGraph(); + if (!this.useSingleInferredProject && !project.projectRootPath) { + for (const inferredProject of this.inferredProjects) { + if (inferredProject === project || inferredProject.isOrphan()) { + continue; + } + const roots = inferredProject.getRootScriptInfos(); + Debug.assert(roots.length === 1 || !!inferredProject.projectRootPath); + if (roots.length === 1 && forEach(roots[0].containingProjects, (p) => p !== roots[0].containingProjects[0] && !p.isOrphan())) { + inferredProject.removeFile( + roots[0], + /*fileExists*/ + true, + /*detachFromProject*/ + true + ); + } + } + } + return project; } - insertModifierBefore(sourceFile, modifier, before) { - return this.insertModifierAt(sourceFile, before.getStart(sourceFile), modifier, { suffix: " " }); + assignOrphanScriptInfosToInferredProject() { + this.openFiles.forEach((projectRootPath, path) => { + const info = this.getScriptInfoForPath(path); + if (info.isOrphan()) { + this.assignOrphanScriptInfoToInferredProject(info, projectRootPath); + } + }); } - insertCommentBeforeLine(sourceFile, lineNumber, position, commentText) { - const lineStartPosition = getStartPositionOfLine(lineNumber, sourceFile); - const startPosition = getFirstNonSpaceCharacterPosition(sourceFile.text, lineStartPosition); - const insertAtLineStart = isValidLocationToAddComment(sourceFile, startPosition); - const token = getTouchingToken(sourceFile, insertAtLineStart ? startPosition : position); - const indent2 = sourceFile.text.slice(lineStartPosition, startPosition); - const text = `${insertAtLineStart ? "" : this.newLineCharacter}//${commentText}${this.newLineCharacter}${indent2}`; - this.insertText(sourceFile, token.getStart(sourceFile), text); + /** + * Remove this file from the set of open, non-configured files. + * @param info The file that has been closed or newly configured + */ + closeOpenFile(info, skipAssignOrphanScriptInfosToInferredProject) { + const fileExists = info.isDynamic ? false : this.host.fileExists(info.fileName); + info.close(fileExists); + this.stopWatchingConfigFilesForClosedScriptInfo(info); + const canonicalFileName = this.toCanonicalFileName(info.fileName); + if (this.openFilesWithNonRootedDiskPath.get(canonicalFileName) === info) { + this.openFilesWithNonRootedDiskPath.delete(canonicalFileName); + } + let ensureProjectsForOpenFiles = false; + for (const p of info.containingProjects) { + if (isConfiguredProject(p)) { + if (info.hasMixedContent) { + info.registerFileUpdate(); + } + const updateLevel = p.openFileWatchTriggered.get(info.path); + if (updateLevel !== void 0) { + p.openFileWatchTriggered.delete(info.path); + if (p.pendingUpdateLevel !== void 0 && p.pendingUpdateLevel < updateLevel) { + p.pendingUpdateLevel = updateLevel; + p.markFileAsDirty(info.path); + } + } + } else if (isInferredProject(p) && p.isRoot(info)) { + if (p.isProjectWithSingleRoot()) { + ensureProjectsForOpenFiles = true; + } + p.removeFile( + info, + fileExists, + /*detachFromProject*/ + true + ); + } + if (!p.languageServiceEnabled) { + p.markAsDirty(); + } + } + this.openFiles.delete(info.path); + this.configFileForOpenFiles.delete(info.path); + if (!skipAssignOrphanScriptInfosToInferredProject && ensureProjectsForOpenFiles) { + this.assignOrphanScriptInfosToInferredProject(); + } + if (fileExists) { + this.watchClosedScriptInfo(info); + } else { + this.handleDeletedFile(info); + } + return ensureProjectsForOpenFiles; } - insertJsdocCommentBefore(sourceFile, node, tag) { - const fnStart = node.getStart(sourceFile); - if (node.jsDoc) { - for (const jsdoc of node.jsDoc) { - this.deleteRange(sourceFile, { - pos: getLineStartPositionForPosition(jsdoc.getStart(sourceFile), sourceFile), - end: getAdjustedEndPosition( - sourceFile, - jsdoc, - /*options*/ - {} - ) - }); + deleteScriptInfo(info) { + this.filenameToScriptInfo.delete(info.path); + this.filenameToScriptInfoVersion.set(info.path, info.textStorage.version); + const realpath = info.getRealpathIfDifferent(); + if (realpath) { + this.realpathToScriptInfos.remove(realpath, info); + } + } + configFileExists(configFileName, canonicalConfigFilePath, info) { + var _a; + let configFileExistenceInfo = this.configFileExistenceInfoCache.get(canonicalConfigFilePath); + if (configFileExistenceInfo) { + if (isOpenScriptInfo(info) && !((_a = configFileExistenceInfo.openFilesImpactedByConfigFile) == null ? void 0 : _a.has(info.path))) { + (configFileExistenceInfo.openFilesImpactedByConfigFile || (configFileExistenceInfo.openFilesImpactedByConfigFile = /* @__PURE__ */ new Map())).set(info.path, false); } + return configFileExistenceInfo.exists; } - const startPosition = getPrecedingNonSpaceCharacterPosition(sourceFile.text, fnStart - 1); - const indent2 = sourceFile.text.slice(startPosition, fnStart); - this.insertNodeAt(sourceFile, fnStart, tag, { suffix: this.newLineCharacter + indent2 }); + const exists = this.host.fileExists(configFileName); + let openFilesImpactedByConfigFile; + if (isOpenScriptInfo(info)) { + (openFilesImpactedByConfigFile || (openFilesImpactedByConfigFile = /* @__PURE__ */ new Map())).set(info.path, false); + } + configFileExistenceInfo = { exists, openFilesImpactedByConfigFile }; + this.configFileExistenceInfoCache.set(canonicalConfigFilePath, configFileExistenceInfo); + return exists; } - createJSDocText(sourceFile, node) { - const comments = flatMap(node.jsDoc, (jsDoc2) => isString(jsDoc2.comment) ? factory.createJSDocText(jsDoc2.comment) : jsDoc2.comment); - const jsDoc = singleOrUndefined(node.jsDoc); - return jsDoc && positionsAreOnSameLine(jsDoc.pos, jsDoc.end, sourceFile) && length(comments) === 0 ? void 0 : factory.createNodeArray(intersperse(comments, factory.createJSDocText("\n"))); + /** @internal */ + createConfigFileWatcherForParsedConfig(configFileName, canonicalConfigFilePath, forProject) { + var _a, _b; + const configFileExistenceInfo = this.configFileExistenceInfoCache.get(canonicalConfigFilePath); + if (!configFileExistenceInfo.watcher || configFileExistenceInfo.watcher === noopConfigFileWatcher) { + configFileExistenceInfo.watcher = this.watchFactory.watchFile( + configFileName, + (_fileName, eventKind) => this.onConfigFileChanged(canonicalConfigFilePath, eventKind), + 2e3 /* High */, + this.getWatchOptionsFromProjectWatchOptions((_b = (_a = configFileExistenceInfo == null ? void 0 : configFileExistenceInfo.config) == null ? void 0 : _a.parsedCommandLine) == null ? void 0 : _b.watchOptions), + WatchType.ConfigFile, + forProject + ); + } + const projects = configFileExistenceInfo.config.projects; + projects.set(forProject.canonicalConfigFilePath, projects.get(forProject.canonicalConfigFilePath) || false); } - replaceJSDocComment(sourceFile, node, tags) { - this.insertJsdocCommentBefore(sourceFile, updateJSDocHost(node), factory.createJSDocComment(this.createJSDocText(sourceFile, node), factory.createNodeArray(tags))); + /** + * Returns true if the configFileExistenceInfo is needed/impacted by open files that are root of inferred project + */ + configFileExistenceImpactsRootOfInferredProject(configFileExistenceInfo) { + return configFileExistenceInfo.openFilesImpactedByConfigFile && forEachEntry(configFileExistenceInfo.openFilesImpactedByConfigFile, identity); } - addJSDocTags(sourceFile, parent2, newTags) { - const oldTags = flatMapToMutable(parent2.jsDoc, (j) => j.tags); - const unmergedNewTags = newTags.filter((newTag) => !oldTags.some((tag, i) => { - const merged = tryMergeJsdocTags(tag, newTag); - if (merged) - oldTags[i] = merged; - return !!merged; - })); - this.replaceJSDocComment(sourceFile, parent2, [...oldTags, ...unmergedNewTags]); + /** @internal */ + releaseParsedConfig(canonicalConfigFilePath, forProject) { + var _a, _b, _c; + const configFileExistenceInfo = this.configFileExistenceInfoCache.get(canonicalConfigFilePath); + if (!((_a = configFileExistenceInfo.config) == null ? void 0 : _a.projects.delete(forProject.canonicalConfigFilePath))) + return; + if ((_b = configFileExistenceInfo.config) == null ? void 0 : _b.projects.size) + return; + configFileExistenceInfo.config = void 0; + clearSharedExtendedConfigFileWatcher(canonicalConfigFilePath, this.sharedExtendedConfigFileWatchers); + Debug.checkDefined(configFileExistenceInfo.watcher); + if ((_c = configFileExistenceInfo.openFilesImpactedByConfigFile) == null ? void 0 : _c.size) { + if (this.configFileExistenceImpactsRootOfInferredProject(configFileExistenceInfo)) { + if (!canWatchDirectoryOrFile(getPathComponents(getDirectoryPath(canonicalConfigFilePath)))) { + configFileExistenceInfo.watcher.close(); + configFileExistenceInfo.watcher = noopConfigFileWatcher; + } + } else { + configFileExistenceInfo.watcher.close(); + configFileExistenceInfo.watcher = void 0; + } + } else { + configFileExistenceInfo.watcher.close(); + this.configFileExistenceInfoCache.delete(canonicalConfigFilePath); + } } - filterJSDocTags(sourceFile, parent2, predicate) { - this.replaceJSDocComment(sourceFile, parent2, filter(flatMapToMutable(parent2.jsDoc, (j) => j.tags), predicate)); + /** + * Close the config file watcher in the cached ConfigFileExistenceInfo + * if there arent any open files that are root of inferred project and there is no parsed config held by any project + * + * @internal + */ + closeConfigFileWatcherOnReleaseOfOpenFile(configFileExistenceInfo) { + if (configFileExistenceInfo.watcher && !configFileExistenceInfo.config && !this.configFileExistenceImpactsRootOfInferredProject(configFileExistenceInfo)) { + configFileExistenceInfo.watcher.close(); + configFileExistenceInfo.watcher = void 0; + } } - replaceRangeWithText(sourceFile, range, text) { - this.changes.push({ kind: 3 /* Text */, sourceFile, range, text }); + /** + * This is called on file close, so that we stop watching the config file for this script info + */ + stopWatchingConfigFilesForClosedScriptInfo(info) { + Debug.assert(!info.isScriptOpen()); + this.forEachConfigFileLocation(info, (canonicalConfigFilePath) => { + var _a, _b, _c; + const configFileExistenceInfo = this.configFileExistenceInfoCache.get(canonicalConfigFilePath); + if (configFileExistenceInfo) { + const infoIsRootOfInferredProject = (_a = configFileExistenceInfo.openFilesImpactedByConfigFile) == null ? void 0 : _a.get(info.path); + (_b = configFileExistenceInfo.openFilesImpactedByConfigFile) == null ? void 0 : _b.delete(info.path); + if (infoIsRootOfInferredProject) { + this.closeConfigFileWatcherOnReleaseOfOpenFile(configFileExistenceInfo); + } + if (!((_c = configFileExistenceInfo.openFilesImpactedByConfigFile) == null ? void 0 : _c.size) && !configFileExistenceInfo.config) { + Debug.assert(!configFileExistenceInfo.watcher); + this.configFileExistenceInfoCache.delete(canonicalConfigFilePath); + } + } + }); } - insertText(sourceFile, pos, text) { - this.replaceRangeWithText(sourceFile, createRange(pos), text); + /** + * This is called by inferred project whenever script info is added as a root + * + * @internal + */ + startWatchingConfigFilesForInferredProjectRoot(info) { + Debug.assert(info.isScriptOpen()); + this.forEachConfigFileLocation(info, (canonicalConfigFilePath, configFileName) => { + let configFileExistenceInfo = this.configFileExistenceInfoCache.get(canonicalConfigFilePath); + if (!configFileExistenceInfo) { + configFileExistenceInfo = { exists: this.host.fileExists(configFileName) }; + this.configFileExistenceInfoCache.set(canonicalConfigFilePath, configFileExistenceInfo); + } + (configFileExistenceInfo.openFilesImpactedByConfigFile || (configFileExistenceInfo.openFilesImpactedByConfigFile = /* @__PURE__ */ new Map())).set(info.path, true); + configFileExistenceInfo.watcher || (configFileExistenceInfo.watcher = canWatchDirectoryOrFile(getPathComponents(getDirectoryPath(canonicalConfigFilePath))) ? this.watchFactory.watchFile( + configFileName, + (_filename, eventKind) => this.onConfigFileChanged(canonicalConfigFilePath, eventKind), + 2e3 /* High */, + this.hostConfiguration.watchOptions, + WatchType.ConfigFileForInferredRoot + ) : noopConfigFileWatcher); + }); } - /** Prefer this over replacing a node with another that has a type annotation, as it avoids reformatting the other parts of the node. */ - tryInsertTypeAnnotation(sourceFile, node, type) { - let endNode2; - if (isFunctionLike(node)) { - endNode2 = findChildOfKind(node, 22 /* CloseParenToken */, sourceFile); - if (!endNode2) { - if (!isArrowFunction(node)) - return false; - endNode2 = first(node.parameters); + /** + * This is called by inferred project whenever root script info is removed from it + * + * @internal + */ + stopWatchingConfigFilesForInferredProjectRoot(info) { + this.forEachConfigFileLocation(info, (canonicalConfigFilePath) => { + var _a; + const configFileExistenceInfo = this.configFileExistenceInfoCache.get(canonicalConfigFilePath); + if ((_a = configFileExistenceInfo == null ? void 0 : configFileExistenceInfo.openFilesImpactedByConfigFile) == null ? void 0 : _a.has(info.path)) { + Debug.assert(info.isScriptOpen()); + configFileExistenceInfo.openFilesImpactedByConfigFile.set(info.path, false); + this.closeConfigFileWatcherOnReleaseOfOpenFile(configFileExistenceInfo); + } + }); + } + /** + * This function tries to search for a tsconfig.json for the given file. + * This is different from the method the compiler uses because + * the compiler can assume it will always start searching in the + * current directory (the directory in which tsc was invoked). + * The server must start searching from the directory containing + * the newly opened file. + */ + forEachConfigFileLocation(info, action) { + if (this.serverMode !== 0 /* Semantic */) { + return void 0; + } + Debug.assert(!isOpenScriptInfo(info) || this.openFiles.has(info.path)); + const projectRootPath = this.openFiles.get(info.path); + const scriptInfo = Debug.checkDefined(this.getScriptInfo(info.path)); + if (scriptInfo.isDynamic) + return void 0; + let searchPath = asNormalizedPath(getDirectoryPath(info.fileName)); + const isSearchPathInProjectRoot = () => containsPath(projectRootPath, searchPath, this.currentDirectory, !this.host.useCaseSensitiveFileNames); + const anySearchPathOk = !projectRootPath || !isSearchPathInProjectRoot(); + let searchInDirectory = !isAncestorConfigFileInfo(info); + do { + if (searchInDirectory) { + const canonicalSearchPath = normalizedPathToPath(searchPath, this.currentDirectory, this.toCanonicalFileName); + const tsconfigFileName = asNormalizedPath(combinePaths(searchPath, "tsconfig.json")); + let result = action(combinePaths(canonicalSearchPath, "tsconfig.json"), tsconfigFileName); + if (result) + return tsconfigFileName; + const jsconfigFileName = asNormalizedPath(combinePaths(searchPath, "jsconfig.json")); + result = action(combinePaths(canonicalSearchPath, "jsconfig.json"), jsconfigFileName); + if (result) + return jsconfigFileName; + if (isNodeModulesDirectory(canonicalSearchPath)) { + break; + } } + const parentPath = asNormalizedPath(getDirectoryPath(searchPath)); + if (parentPath === searchPath) + break; + searchPath = parentPath; + searchInDirectory = true; + } while (anySearchPathOk || isSearchPathInProjectRoot()); + return void 0; + } + /** @internal */ + findDefaultConfiguredProject(info) { + if (!info.isScriptOpen()) + return void 0; + const configFileName = this.getConfigFileNameForFile(info); + const project = configFileName && this.findConfiguredProjectByProjectName(configFileName); + return project && projectContainsInfoDirectly(project, info) ? project : project == null ? void 0 : project.getDefaultChildProjectFromProjectWithReferences(info); + } + /** + * This function tries to search for a tsconfig.json for the given file. + * This is different from the method the compiler uses because + * the compiler can assume it will always start searching in the + * current directory (the directory in which tsc was invoked). + * The server must start searching from the directory containing + * the newly opened file. + * If script info is passed in, it is asserted to be open script info + * otherwise just file name + */ + getConfigFileNameForFile(info) { + if (isOpenScriptInfo(info)) { + Debug.assert(info.isScriptOpen()); + const result = this.configFileForOpenFiles.get(info.path); + if (result !== void 0) + return result || void 0; + } + this.logger.info(`Search path: ${getDirectoryPath(info.fileName)}`); + const configFileName = this.forEachConfigFileLocation(info, (canonicalConfigFilePath, configFileName2) => this.configFileExists(configFileName2, canonicalConfigFilePath, info)); + if (configFileName) { + this.logger.info(`For info: ${info.fileName} :: Config file name: ${configFileName}`); } else { - endNode2 = (node.kind === 259 /* VariableDeclaration */ ? node.exclamationToken : node.questionToken) ?? node.name; + this.logger.info(`For info: ${info.fileName} :: No config files found.`); } - this.insertNodeAt(sourceFile, endNode2.end, type, { prefix: ": " }); - return true; + if (isOpenScriptInfo(info)) { + this.configFileForOpenFiles.set(info.path, configFileName || false); + } + return configFileName; } - tryInsertThisTypeAnnotation(sourceFile, node, type) { - const start = findChildOfKind(node, 21 /* OpenParenToken */, sourceFile).getStart(sourceFile) + 1; - const suffix = node.parameters.length ? ", " : ""; - this.insertNodeAt(sourceFile, start, type, { prefix: "this: ", suffix }); + printProjects() { + if (!this.logger.hasLevel(1 /* normal */)) { + return; + } + this.logger.startGroup(); + this.externalProjects.forEach(printProjectWithoutFileNames); + this.configuredProjects.forEach(printProjectWithoutFileNames); + this.inferredProjects.forEach(printProjectWithoutFileNames); + this.logger.info("Open files: "); + this.openFiles.forEach((projectRootPath, path) => { + const info = this.getScriptInfoForPath(path); + this.logger.info(` FileName: ${info.fileName} ProjectRootPath: ${projectRootPath}`); + this.logger.info(` Projects: ${info.containingProjects.map((p) => p.getProjectName())}`); + }); + this.logger.endGroup(); } - insertTypeParameters(sourceFile, node, typeParameters) { - const start = (findChildOfKind(node, 21 /* OpenParenToken */, sourceFile) || first(node.parameters)).getStart(sourceFile); - this.insertNodesAt(sourceFile, start, typeParameters, { prefix: "<", suffix: ">", joiner: ", " }); + /** @internal */ + findConfiguredProjectByProjectName(configFileName) { + const canonicalConfigFilePath = asNormalizedPath(this.toCanonicalFileName(configFileName)); + return this.getConfiguredProjectByCanonicalConfigFilePath(canonicalConfigFilePath); } - getOptionsForInsertNodeBefore(before, inserted, blankLineBetween) { - if (isStatement(before) || isClassElement(before)) { - return { suffix: blankLineBetween ? this.newLineCharacter + this.newLineCharacter : this.newLineCharacter }; - } else if (isVariableDeclaration(before)) { - return { suffix: ", " }; - } else if (isParameter(before)) { - return isParameter(inserted) ? { suffix: ", " } : {}; - } else if (isStringLiteral(before) && isImportDeclaration(before.parent) || isNamedImports(before)) { - return { suffix: ", " }; - } else if (isImportSpecifier(before)) { - return { suffix: "," + (blankLineBetween ? this.newLineCharacter : " ") }; + getConfiguredProjectByCanonicalConfigFilePath(canonicalConfigFilePath) { + return this.configuredProjects.get(canonicalConfigFilePath); + } + findExternalProjectByProjectName(projectFileName) { + return findProjectByName(projectFileName, this.externalProjects); + } + /** Get a filename if the language service exceeds the maximum allowed program size; otherwise returns undefined. */ + getFilenameForExceededTotalSizeLimitForNonTsFiles(name, options, fileNames, propertyReader) { + if (options && options.disableSizeLimit || !this.host.getFileSize) { + return; } - return Debug.failBadSyntaxKind(before); + let availableSpace = maxProgramSizeForNonTsFiles; + this.projectToSizeMap.set(name, 0); + this.projectToSizeMap.forEach((val) => availableSpace -= val || 0); + let totalNonTsFileSize = 0; + for (const f of fileNames) { + const fileName = propertyReader.getFileName(f); + if (hasTSFileExtension(fileName)) { + continue; + } + totalNonTsFileSize += this.host.getFileSize(fileName); + if (totalNonTsFileSize > maxProgramSizeForNonTsFiles || totalNonTsFileSize > availableSpace) { + const top5LargestFiles = fileNames.map((f2) => propertyReader.getFileName(f2)).filter((name2) => !hasTSFileExtension(name2)).map((name2) => ({ name: name2, size: this.host.getFileSize(name2) })).sort((a, b) => b.size - a.size).slice(0, 5); + this.logger.info(`Non TS file size exceeded limit (${totalNonTsFileSize}). Largest files: ${top5LargestFiles.map((file) => `${file.name}:${file.size}`).join(", ")}`); + return fileName; + } + } + this.projectToSizeMap.set(name, totalNonTsFileSize); } - insertNodeAtConstructorStart(sourceFile, ctr, newStatement) { - const firstStatement = firstOrUndefined(ctr.body.statements); - if (!firstStatement || !ctr.body.multiLine) { - this.replaceConstructorBody(sourceFile, ctr, [newStatement, ...ctr.body.statements]); + createExternalProject(projectFileName, files, options, typeAcquisition, excludedFiles) { + const compilerOptions = convertCompilerOptions(options); + const watchOptionsAndErrors = convertWatchOptions(options, getDirectoryPath(normalizeSlashes(projectFileName))); + const project = new ExternalProject2( + projectFileName, + this, + this.documentRegistry, + compilerOptions, + /*lastFileExceededProgramSize*/ + this.getFilenameForExceededTotalSizeLimitForNonTsFiles(projectFileName, compilerOptions, files, externalFilePropertyReader), + options.compileOnSave === void 0 ? true : options.compileOnSave, + /*projectFilePath*/ + void 0, + watchOptionsAndErrors == null ? void 0 : watchOptionsAndErrors.watchOptions + ); + project.setProjectErrors(watchOptionsAndErrors == null ? void 0 : watchOptionsAndErrors.errors); + project.excludedFiles = excludedFiles; + this.addFilesToNonInferredProject(project, files, externalFilePropertyReader, typeAcquisition); + this.externalProjects.push(project); + return project; + } + /** @internal */ + sendProjectTelemetry(project) { + if (this.seenProjects.has(project.projectName)) { + setProjectOptionsUsed(project); + return; + } + this.seenProjects.set(project.projectName, true); + if (!this.eventHandler || !this.host.createSHA256Hash) { + setProjectOptionsUsed(project); + return; + } + const projectOptions = isConfiguredProject(project) ? project.projectOptions : void 0; + setProjectOptionsUsed(project); + const data = { + projectId: this.host.createSHA256Hash(project.projectName), + fileStats: countEachFileTypes( + project.getScriptInfos(), + /*includeSizes*/ + true + ), + compilerOptions: convertCompilerOptionsForTelemetry(project.getCompilationSettings()), + typeAcquisition: convertTypeAcquisition2(project.getTypeAcquisition()), + extends: projectOptions && projectOptions.configHasExtendsProperty, + files: projectOptions && projectOptions.configHasFilesProperty, + include: projectOptions && projectOptions.configHasIncludeProperty, + exclude: projectOptions && projectOptions.configHasExcludeProperty, + compileOnSave: project.compileOnSaveEnabled, + configFileName: configFileName(), + projectType: project instanceof ExternalProject2 ? "external" : "configured", + languageServiceEnabled: project.languageServiceEnabled, + version + }; + this.eventHandler({ eventName: ProjectInfoTelemetryEvent, data }); + function configFileName() { + if (!isConfiguredProject(project)) { + return "other"; + } + return getBaseConfigFileName(project.getConfigFilePath()) || "other"; + } + function convertTypeAcquisition2({ enable: enable2, include, exclude }) { + return { + enable: enable2, + include: include !== void 0 && include.length !== 0, + exclude: exclude !== void 0 && exclude.length !== 0 + }; + } + } + addFilesToNonInferredProject(project, files, propertyReader, typeAcquisition) { + this.updateNonInferredProjectFiles(project, files, propertyReader); + project.setTypeAcquisition(typeAcquisition); + project.markAsDirty(); + } + /** @internal */ + createConfiguredProject(configFileName) { + var _a; + (_a = tracing) == null ? void 0 : _a.instant(tracing.Phase.Session, "createConfiguredProject", { configFilePath: configFileName }); + this.logger.info(`Creating configuration project ${configFileName}`); + const canonicalConfigFilePath = asNormalizedPath(this.toCanonicalFileName(configFileName)); + let configFileExistenceInfo = this.configFileExistenceInfoCache.get(canonicalConfigFilePath); + if (!configFileExistenceInfo) { + this.configFileExistenceInfoCache.set(canonicalConfigFilePath, configFileExistenceInfo = { exists: true }); } else { - this.insertNodeBefore(sourceFile, firstStatement, newStatement); + configFileExistenceInfo.exists = true; + } + if (!configFileExistenceInfo.config) { + configFileExistenceInfo.config = { + cachedDirectoryStructureHost: createCachedDirectoryStructureHost(this.host, this.host.getCurrentDirectory(), this.host.useCaseSensitiveFileNames), + projects: /* @__PURE__ */ new Map(), + updateLevel: 2 /* Full */ + }; } + const project = new ConfiguredProject2( + configFileName, + canonicalConfigFilePath, + this, + this.documentRegistry, + configFileExistenceInfo.config.cachedDirectoryStructureHost + ); + this.configuredProjects.set(canonicalConfigFilePath, project); + this.createConfigFileWatcherForParsedConfig(configFileName, canonicalConfigFilePath, project); + return project; } - insertNodeAtConstructorStartAfterSuperCall(sourceFile, ctr, newStatement) { - const superCallStatement = find(ctr.body.statements, (stmt) => isExpressionStatement(stmt) && isSuperCall(stmt.expression)); - if (!superCallStatement || !ctr.body.multiLine) { - this.replaceConstructorBody(sourceFile, ctr, [...ctr.body.statements, newStatement]); + /** @internal */ + createConfiguredProjectWithDelayLoad(configFileName, reason) { + const project = this.createConfiguredProject(configFileName); + project.pendingUpdateLevel = 2 /* Full */; + project.pendingUpdateReason = reason; + return project; + } + /** @internal */ + createAndLoadConfiguredProject(configFileName, reason) { + const project = this.createConfiguredProject(configFileName); + this.loadConfiguredProject(project, reason); + return project; + } + /** @internal */ + createLoadAndUpdateConfiguredProject(configFileName, reason) { + const project = this.createAndLoadConfiguredProject(configFileName, reason); + project.updateGraph(); + return project; + } + /** + * Read the config file of the project, and update the project root file names. + * + * @internal + */ + loadConfiguredProject(project, reason) { + var _a, _b; + (_a = tracing) == null ? void 0 : _a.push(tracing.Phase.Session, "loadConfiguredProject", { configFilePath: project.canonicalConfigFilePath }); + this.sendProjectLoadingStartEvent(project, reason); + const configFilename = asNormalizedPath(normalizePath(project.getConfigFilePath())); + const configFileExistenceInfo = this.ensureParsedConfigUptoDate( + configFilename, + project.canonicalConfigFilePath, + this.configFileExistenceInfoCache.get(project.canonicalConfigFilePath), + project + ); + const parsedCommandLine = configFileExistenceInfo.config.parsedCommandLine; + Debug.assert(!!parsedCommandLine.fileNames); + const compilerOptions = parsedCommandLine.options; + if (!project.projectOptions) { + project.projectOptions = { + configHasExtendsProperty: parsedCommandLine.raw.extends !== void 0, + configHasFilesProperty: parsedCommandLine.raw.files !== void 0, + configHasIncludeProperty: parsedCommandLine.raw.include !== void 0, + configHasExcludeProperty: parsedCommandLine.raw.exclude !== void 0 + }; + } + project.canConfigFileJsonReportNoInputFiles = canJsonReportNoInputFiles(parsedCommandLine.raw); + project.setProjectErrors(parsedCommandLine.options.configFile.parseDiagnostics); + project.updateReferences(parsedCommandLine.projectReferences); + const lastFileExceededProgramSize = this.getFilenameForExceededTotalSizeLimitForNonTsFiles(project.canonicalConfigFilePath, compilerOptions, parsedCommandLine.fileNames, fileNamePropertyReader); + if (lastFileExceededProgramSize) { + project.disableLanguageService(lastFileExceededProgramSize); + this.configFileExistenceInfoCache.forEach((_configFileExistenceInfo, canonicalConfigFilePath) => this.stopWatchingWildCards(canonicalConfigFilePath, project)); } else { - this.insertNodeAfter(sourceFile, superCallStatement, newStatement); + project.setCompilerOptions(compilerOptions); + project.setWatchOptions(parsedCommandLine.watchOptions); + project.enableLanguageService(); + this.watchWildcards(configFilename, configFileExistenceInfo, project); } + project.enablePluginsWithOptions(compilerOptions); + const filesToAdd = parsedCommandLine.fileNames.concat(project.getExternalFiles(2 /* Full */)); + this.updateRootAndOptionsOfNonInferredProject(project, filesToAdd, fileNamePropertyReader, compilerOptions, parsedCommandLine.typeAcquisition, parsedCommandLine.compileOnSave, parsedCommandLine.watchOptions); + (_b = tracing) == null ? void 0 : _b.pop(); } - insertNodeAtConstructorEnd(sourceFile, ctr, newStatement) { - const lastStatement = lastOrUndefined(ctr.body.statements); - if (!lastStatement || !ctr.body.multiLine) { - this.replaceConstructorBody(sourceFile, ctr, [...ctr.body.statements, newStatement]); + /** @internal */ + ensureParsedConfigUptoDate(configFilename, canonicalConfigFilePath, configFileExistenceInfo, forProject) { + var _a, _b, _c; + if (configFileExistenceInfo.config) { + if (!configFileExistenceInfo.config.updateLevel) + return configFileExistenceInfo; + if (configFileExistenceInfo.config.updateLevel === 1 /* RootNamesAndUpdate */) { + this.reloadFileNamesOfParsedConfig(configFilename, configFileExistenceInfo.config); + return configFileExistenceInfo; + } + } + const cachedDirectoryStructureHost = ((_a = configFileExistenceInfo.config) == null ? void 0 : _a.cachedDirectoryStructureHost) || createCachedDirectoryStructureHost(this.host, this.host.getCurrentDirectory(), this.host.useCaseSensitiveFileNames); + const configFileContent = tryReadFile(configFilename, (fileName) => this.host.readFile(fileName)); + const configFile = parseJsonText(configFilename, isString(configFileContent) ? configFileContent : ""); + const configFileErrors = configFile.parseDiagnostics; + if (!isString(configFileContent)) + configFileErrors.push(configFileContent); + const parsedCommandLine = parseJsonSourceFileConfigFileContent( + configFile, + cachedDirectoryStructureHost, + getDirectoryPath(configFilename), + /*existingOptions*/ + {}, + configFilename, + /*resolutionStack*/ + [], + this.hostConfiguration.extraFileExtensions, + this.extendedConfigCache + ); + if (parsedCommandLine.errors.length) { + configFileErrors.push(...parsedCommandLine.errors); + } + this.logger.info(`Config: ${configFilename} : ${JSON.stringify( + { + rootNames: parsedCommandLine.fileNames, + options: parsedCommandLine.options, + watchOptions: parsedCommandLine.watchOptions, + projectReferences: parsedCommandLine.projectReferences + }, + /*replacer*/ + void 0, + " " + )}`); + const oldCommandLine = (_b = configFileExistenceInfo.config) == null ? void 0 : _b.parsedCommandLine; + if (!configFileExistenceInfo.config) { + configFileExistenceInfo.config = { parsedCommandLine, cachedDirectoryStructureHost, projects: /* @__PURE__ */ new Map() }; } else { - this.insertNodeAfter(sourceFile, lastStatement, newStatement); + configFileExistenceInfo.config.parsedCommandLine = parsedCommandLine; + configFileExistenceInfo.config.watchedDirectoriesStale = true; + configFileExistenceInfo.config.updateLevel = void 0; + } + if (!oldCommandLine && !isJsonEqual( + // Old options + this.getWatchOptionsFromProjectWatchOptions( + /*projectOptions*/ + void 0 + ), + // New options + this.getWatchOptionsFromProjectWatchOptions(parsedCommandLine.watchOptions) + )) { + (_c = configFileExistenceInfo.watcher) == null ? void 0 : _c.close(); + configFileExistenceInfo.watcher = void 0; + } + this.createConfigFileWatcherForParsedConfig(configFilename, canonicalConfigFilePath, forProject); + updateSharedExtendedConfigFileWatcher( + canonicalConfigFilePath, + parsedCommandLine.options, + this.sharedExtendedConfigFileWatchers, + (extendedConfigFileName, extendedConfigFilePath) => this.watchFactory.watchFile( + extendedConfigFileName, + () => { + var _a2; + cleanExtendedConfigCache(this.extendedConfigCache, extendedConfigFilePath, (fileName) => this.toPath(fileName)); + let ensureProjectsForOpenFiles = false; + (_a2 = this.sharedExtendedConfigFileWatchers.get(extendedConfigFilePath)) == null ? void 0 : _a2.projects.forEach((canonicalPath) => { + ensureProjectsForOpenFiles = this.delayUpdateProjectsFromParsedConfigOnConfigFileChange(canonicalPath, `Change in extended config file ${extendedConfigFileName} detected`) || ensureProjectsForOpenFiles; + }); + if (ensureProjectsForOpenFiles) + this.delayEnsureProjectForOpenFiles(); + }, + 2e3 /* High */, + this.hostConfiguration.watchOptions, + WatchType.ExtendedConfigFile, + configFilename + ), + (fileName) => this.toPath(fileName) + ); + return configFileExistenceInfo; + } + /** @internal */ + watchWildcards(configFileName, { exists, config }, forProject) { + config.projects.set(forProject.canonicalConfigFilePath, true); + if (exists) { + if (config.watchedDirectories && !config.watchedDirectoriesStale) + return; + config.watchedDirectoriesStale = false; + updateWatchingWildcardDirectories( + config.watchedDirectories || (config.watchedDirectories = /* @__PURE__ */ new Map()), + new Map(Object.entries(config.parsedCommandLine.wildcardDirectories)), + // Create new directory watcher + (directory, flags) => this.watchWildcardDirectory(directory, flags, configFileName, config) + ); + } else { + config.watchedDirectoriesStale = false; + if (!config.watchedDirectories) + return; + clearMap(config.watchedDirectories, closeFileWatcherOf); + config.watchedDirectories = void 0; } } - replaceConstructorBody(sourceFile, ctr, statements) { - this.replaceNode(sourceFile, ctr.body, factory.createBlock( - statements, - /*multiLine*/ - true - )); + /** @internal */ + stopWatchingWildCards(canonicalConfigFilePath, forProject) { + const configFileExistenceInfo = this.configFileExistenceInfoCache.get(canonicalConfigFilePath); + if (!configFileExistenceInfo.config || !configFileExistenceInfo.config.projects.get(forProject.canonicalConfigFilePath)) { + return; + } + configFileExistenceInfo.config.projects.set(forProject.canonicalConfigFilePath, false); + if (forEachEntry(configFileExistenceInfo.config.projects, identity)) + return; + if (configFileExistenceInfo.config.watchedDirectories) { + clearMap(configFileExistenceInfo.config.watchedDirectories, closeFileWatcherOf); + configFileExistenceInfo.config.watchedDirectories = void 0; + } + configFileExistenceInfo.config.watchedDirectoriesStale = void 0; + } + updateNonInferredProjectFiles(project, files, propertyReader) { + const projectRootFilesMap = project.getRootFilesMap(); + const newRootScriptInfoMap = /* @__PURE__ */ new Map(); + for (const f of files) { + const newRootFile = propertyReader.getFileName(f); + const fileName = toNormalizedPath(newRootFile); + const isDynamic = isDynamicFileName(fileName); + let path; + if (!isDynamic && !project.fileExists(newRootFile)) { + path = normalizedPathToPath(fileName, this.currentDirectory, this.toCanonicalFileName); + const existingValue = projectRootFilesMap.get(path); + if (existingValue) { + if (existingValue.info) { + project.removeFile( + existingValue.info, + /*fileExists*/ + false, + /*detachFromProject*/ + true + ); + existingValue.info = void 0; + } + existingValue.fileName = fileName; + } else { + projectRootFilesMap.set(path, { fileName }); + } + } else { + const scriptKind = propertyReader.getScriptKind(f, this.hostConfiguration.extraFileExtensions); + const hasMixedContent = propertyReader.hasMixedContent(f, this.hostConfiguration.extraFileExtensions); + const scriptInfo = Debug.checkDefined(this.getOrCreateScriptInfoNotOpenedByClientForNormalizedPath( + fileName, + project.currentDirectory, + scriptKind, + hasMixedContent, + project.directoryStructureHost + )); + path = scriptInfo.path; + const existingValue = projectRootFilesMap.get(path); + if (!existingValue || existingValue.info !== scriptInfo) { + project.addRoot(scriptInfo, fileName); + if (scriptInfo.isScriptOpen()) { + this.removeRootOfInferredProjectIfNowPartOfOtherProject(scriptInfo); + } + } else { + existingValue.fileName = fileName; + } + } + newRootScriptInfoMap.set(path, true); + } + if (projectRootFilesMap.size > newRootScriptInfoMap.size) { + projectRootFilesMap.forEach((value, path) => { + if (!newRootScriptInfoMap.has(path)) { + if (value.info) { + project.removeFile( + value.info, + project.fileExists(path), + /*detachFromProject*/ + true + ); + } else { + projectRootFilesMap.delete(path); + } + } + }); + } } - insertNodeAtEndOfScope(sourceFile, scope, newNode) { - const pos = getAdjustedStartPosition(sourceFile, scope.getLastToken(), {}); - this.insertNodeAt(sourceFile, pos, newNode, { - prefix: isLineBreak(sourceFile.text.charCodeAt(scope.getLastToken().pos)) ? this.newLineCharacter : this.newLineCharacter + this.newLineCharacter, - suffix: this.newLineCharacter - }); + updateRootAndOptionsOfNonInferredProject(project, newUncheckedFiles, propertyReader, newOptions, newTypeAcquisition, compileOnSave, watchOptions) { + project.setCompilerOptions(newOptions); + project.setWatchOptions(watchOptions); + if (compileOnSave !== void 0) { + project.compileOnSaveEnabled = compileOnSave; + } + this.addFilesToNonInferredProject(project, newUncheckedFiles, propertyReader, newTypeAcquisition); } - insertMemberAtStart(sourceFile, node, newElement) { - this.insertNodeAtStartWorker(sourceFile, node, newElement); + /** + * Reload the file names from config file specs and update the project graph + * + * @internal + */ + reloadFileNamesOfConfiguredProject(project) { + const fileNames = this.reloadFileNamesOfParsedConfig(project.getConfigFilePath(), this.configFileExistenceInfoCache.get(project.canonicalConfigFilePath).config); + project.updateErrorOnNoInputFiles(fileNames); + this.updateNonInferredProjectFiles(project, fileNames.concat(project.getExternalFiles(1 /* RootNamesAndUpdate */)), fileNamePropertyReader); + project.markAsDirty(); + return project.updateGraph(); } - insertNodeAtObjectStart(sourceFile, obj, newElement) { - this.insertNodeAtStartWorker(sourceFile, obj, newElement); + /** @internal */ + reloadFileNamesOfParsedConfig(configFileName, config) { + if (config.updateLevel === void 0) + return config.parsedCommandLine.fileNames; + Debug.assert(config.updateLevel === 1 /* RootNamesAndUpdate */); + const configFileSpecs = config.parsedCommandLine.options.configFile.configFileSpecs; + const fileNames = getFileNamesFromConfigSpecs( + configFileSpecs, + getDirectoryPath(configFileName), + config.parsedCommandLine.options, + config.cachedDirectoryStructureHost, + this.hostConfiguration.extraFileExtensions + ); + config.parsedCommandLine = { ...config.parsedCommandLine, fileNames }; + return fileNames; } - insertNodeAtStartWorker(sourceFile, node, newElement) { - const indentation = this.guessIndentationFromExistingMembers(sourceFile, node) ?? this.computeIndentationForNewMember(sourceFile, node); - this.insertNodeAt(sourceFile, getMembersOrProperties(node).pos, newElement, this.getInsertNodeAtStartInsertOptions(sourceFile, node, indentation)); + /** @internal */ + setFileNamesOfAutpImportProviderOrAuxillaryProject(project, fileNames) { + this.updateNonInferredProjectFiles(project, fileNames, fileNamePropertyReader); } /** - * Tries to guess the indentation from the existing members of a class/interface/object. All members must be on - * new lines and must share the same indentation. + * Read the config file of the project again by clearing the cache and update the project graph + * + * @internal */ - guessIndentationFromExistingMembers(sourceFile, node) { - let indentation; - let lastRange = node; - for (const member of getMembersOrProperties(node)) { - if (rangeStartPositionsAreOnSameLine(lastRange, member, sourceFile)) { - return void 0; + reloadConfiguredProject(project, reason, isInitialLoad, clearSemanticCache) { + const host = project.getCachedDirectoryStructureHost(); + if (clearSemanticCache) + this.clearSemanticCache(project); + host.clearCache(); + const configFileName = project.getConfigFilePath(); + this.logger.info(`${isInitialLoad ? "Loading" : "Reloading"} configured project ${configFileName}`); + this.loadConfiguredProject(project, reason); + project.updateGraph(); + this.sendConfigFileDiagEvent(project, configFileName); + } + /** @internal */ + clearSemanticCache(project) { + project.resolutionCache.clear(); + project.getLanguageService( + /*ensureSynchronized*/ + false + ).cleanupSemanticCache(); + project.cleanupProgram(); + project.markAsDirty(); + } + sendConfigFileDiagEvent(project, triggerFile) { + if (!this.eventHandler || this.suppressDiagnosticEvents) { + return; + } + const diagnostics = project.getLanguageService().getCompilerOptionsDiagnostics(); + diagnostics.push(...project.getAllProjectErrors()); + this.eventHandler( + { + eventName: ConfigFileDiagEvent, + data: { configFileName: project.getConfigFilePath(), diagnostics, triggerFile } } - const memberStart = member.getStart(sourceFile); - const memberIndentation = ts_formatting_exports.SmartIndenter.findFirstNonWhitespaceColumn(getLineStartPositionForPosition(memberStart, sourceFile), memberStart, sourceFile, this.formatContext.options); - if (indentation === void 0) { - indentation = memberIndentation; - } else if (memberIndentation !== indentation) { - return void 0; + ); + } + getOrCreateInferredProjectForProjectRootPathIfEnabled(info, projectRootPath) { + if (!this.useInferredProjectPerProjectRoot || // Its a dynamic info opened without project root + info.isDynamic && projectRootPath === void 0) { + return void 0; + } + if (projectRootPath) { + const canonicalProjectRootPath = this.toCanonicalFileName(projectRootPath); + for (const project of this.inferredProjects) { + if (project.projectRootPath === canonicalProjectRootPath) { + return project; + } } - lastRange = member; + return this.createInferredProject( + projectRootPath, + /*isSingleInferredProject*/ + false, + projectRootPath + ); } - return indentation; + let bestMatch; + for (const project of this.inferredProjects) { + if (!project.projectRootPath) + continue; + if (!containsPath(project.projectRootPath, info.path, this.host.getCurrentDirectory(), !this.host.useCaseSensitiveFileNames)) + continue; + if (bestMatch && bestMatch.projectRootPath.length > project.projectRootPath.length) + continue; + bestMatch = project; + } + return bestMatch; } - computeIndentationForNewMember(sourceFile, node) { - const nodeStart = node.getStart(sourceFile); - return ts_formatting_exports.SmartIndenter.findFirstNonWhitespaceColumn(getLineStartPositionForPosition(nodeStart, sourceFile), nodeStart, sourceFile, this.formatContext.options) + (this.formatContext.options.indentSize ?? 4); + getOrCreateSingleInferredProjectIfEnabled() { + if (!this.useSingleInferredProject) { + return void 0; + } + if (this.inferredProjects.length > 0 && this.inferredProjects[0].projectRootPath === void 0) { + return this.inferredProjects[0]; + } + return this.createInferredProject( + "", + /*isSingleInferredProject*/ + true + ); } - getInsertNodeAtStartInsertOptions(sourceFile, node, indentation) { - const members = getMembersOrProperties(node); - const isEmpty = members.length === 0; - const isFirstInsertion = addToSeen(this.classesWithNodesInsertedAtStart, getNodeId(node), { node, sourceFile }); - const insertTrailingComma = isObjectLiteralExpression(node) && (!isJsonSourceFile(sourceFile) || !isEmpty); - const insertLeadingComma = isObjectLiteralExpression(node) && isJsonSourceFile(sourceFile) && isEmpty && !isFirstInsertion; - return { - indentation, - prefix: (insertLeadingComma ? "," : "") + this.newLineCharacter, - suffix: insertTrailingComma ? "," : isInterfaceDeclaration(node) && isEmpty ? ";" : "" - }; + getOrCreateSingleInferredWithoutProjectRoot(currentDirectory) { + Debug.assert(!this.useSingleInferredProject); + const expectedCurrentDirectory = this.toCanonicalFileName(this.getNormalizedAbsolutePath(currentDirectory)); + for (const inferredProject of this.inferredProjects) { + if (!inferredProject.projectRootPath && inferredProject.isOrphan() && inferredProject.canonicalCurrentDirectory === expectedCurrentDirectory) { + return inferredProject; + } + } + return this.createInferredProject(currentDirectory); } - insertNodeAfterComma(sourceFile, after, newNode) { - const endPosition = this.insertNodeAfterWorker(sourceFile, this.nextCommaToken(sourceFile, after) || after, newNode); - this.insertNodeAt(sourceFile, endPosition, newNode, this.getInsertNodeAfterOptions(sourceFile, after)); + createInferredProject(currentDirectory, isSingleInferredProject, projectRootPath) { + const compilerOptions = projectRootPath && this.compilerOptionsForInferredProjectsPerProjectRoot.get(projectRootPath) || this.compilerOptionsForInferredProjects; + let watchOptionsAndErrors; + let typeAcquisition; + if (projectRootPath) { + watchOptionsAndErrors = this.watchOptionsForInferredProjectsPerProjectRoot.get(projectRootPath); + typeAcquisition = this.typeAcquisitionForInferredProjectsPerProjectRoot.get(projectRootPath); + } + if (watchOptionsAndErrors === void 0) { + watchOptionsAndErrors = this.watchOptionsForInferredProjects; + } + if (typeAcquisition === void 0) { + typeAcquisition = this.typeAcquisitionForInferredProjects; + } + watchOptionsAndErrors = watchOptionsAndErrors || void 0; + const project = new InferredProject2(this, this.documentRegistry, compilerOptions, watchOptionsAndErrors == null ? void 0 : watchOptionsAndErrors.watchOptions, projectRootPath, currentDirectory, typeAcquisition); + project.setProjectErrors(watchOptionsAndErrors == null ? void 0 : watchOptionsAndErrors.errors); + if (isSingleInferredProject) { + this.inferredProjects.unshift(project); + } else { + this.inferredProjects.push(project); + } + return project; } - insertNodeAfter(sourceFile, after, newNode) { - const endPosition = this.insertNodeAfterWorker(sourceFile, after, newNode); - this.insertNodeAt(sourceFile, endPosition, newNode, this.getInsertNodeAfterOptions(sourceFile, after)); + /** @internal */ + getOrCreateScriptInfoNotOpenedByClient(uncheckedFileName, currentDirectory, hostToQueryFileExistsOn) { + return this.getOrCreateScriptInfoNotOpenedByClientForNormalizedPath( + toNormalizedPath(uncheckedFileName), + currentDirectory, + /*scriptKind*/ + void 0, + /*hasMixedContent*/ + void 0, + hostToQueryFileExistsOn + ); } - insertNodeAtEndOfList(sourceFile, list, newNode) { - this.insertNodeAt(sourceFile, list.end, newNode, { prefix: ", " }); + getScriptInfo(uncheckedFileName) { + return this.getScriptInfoForNormalizedPath(toNormalizedPath(uncheckedFileName)); } - insertNodesAfter(sourceFile, after, newNodes) { - const endPosition = this.insertNodeAfterWorker(sourceFile, after, first(newNodes)); - this.insertNodesAt(sourceFile, endPosition, newNodes, this.getInsertNodeAfterOptions(sourceFile, after)); + /** @internal */ + getScriptInfoOrConfig(uncheckedFileName) { + const path = toNormalizedPath(uncheckedFileName); + const info = this.getScriptInfoForNormalizedPath(path); + if (info) + return info; + const configProject = this.configuredProjects.get(this.toPath(uncheckedFileName)); + return configProject && configProject.getCompilerOptions().configFile; } - insertNodeAfterWorker(sourceFile, after, newNode) { - if (needSemicolonBetween(after, newNode)) { - if (sourceFile.text.charCodeAt(after.end - 1) !== 59 /* semicolon */) { - this.replaceRange(sourceFile, createRange(after.end), factory.createToken(27 /* SemicolonToken */)); + /** @internal */ + logErrorForScriptInfoNotFound(fileName) { + const names = arrayFrom(this.filenameToScriptInfo.entries(), ([path, scriptInfo]) => ({ path, fileName: scriptInfo.fileName })); + this.logger.msg(`Could not find file ${JSON.stringify(fileName)}. +All files are: ${JSON.stringify(names)}`, "Err" /* Err */); + } + /** + * Returns the projects that contain script info through SymLink + * Note that this does not return projects in info.containingProjects + * + * @internal + */ + getSymlinkedProjects(info) { + let projects; + if (this.realpathToScriptInfos) { + const realpath = info.getRealpathIfDifferent(); + if (realpath) { + forEach(this.realpathToScriptInfos.get(realpath), combineProjects); + } + forEach(this.realpathToScriptInfos.get(info.path), combineProjects); + } + return projects; + function combineProjects(toAddInfo) { + if (toAddInfo !== info) { + for (const project of toAddInfo.containingProjects) { + if (project.languageServiceEnabled && !project.isOrphan() && !project.getCompilerOptions().preserveSymlinks && !info.isAttached(project)) { + if (!projects) { + projects = createMultiMap(); + projects.add(toAddInfo.path, project); + } else if (!forEachEntry(projects, (projs, path) => path === toAddInfo.path ? false : contains(projs, project))) { + projects.add(toAddInfo.path, project); + } + } + } } } - const endPosition = getAdjustedEndPosition(sourceFile, after, {}); - return endPosition; } - getInsertNodeAfterOptions(sourceFile, after) { - const options = this.getInsertNodeAfterOptionsWorker(after); + watchClosedScriptInfo(info) { + Debug.assert(!info.fileWatcher); + if (!info.isDynamicOrHasMixedContent() && (!this.globalCacheLocationDirectoryPath || !startsWith(info.path, this.globalCacheLocationDirectoryPath))) { + const indexOfNodeModules = info.path.indexOf("/node_modules/"); + if (!this.host.getModifiedTime || indexOfNodeModules === -1) { + info.fileWatcher = this.watchFactory.watchFile( + info.fileName, + (_fileName, eventKind) => this.onSourceFileChanged(info, eventKind), + 500 /* Medium */, + this.hostConfiguration.watchOptions, + WatchType.ClosedScriptInfo + ); + } else { + info.mTime = this.getModifiedTime(info); + info.fileWatcher = this.watchClosedScriptInfoInNodeModules(info.path.substr(0, indexOfNodeModules)); + } + } + } + createNodeModulesWatcher(dir) { + const watcher = this.watchFactory.watchDirectory( + dir, + (fileOrDirectory) => { + var _a; + const fileOrDirectoryPath = removeIgnoredPath(this.toPath(fileOrDirectory)); + if (!fileOrDirectoryPath) + return; + const basename = getBaseFileName(fileOrDirectoryPath); + if (((_a = result.affectedModuleSpecifierCacheProjects) == null ? void 0 : _a.size) && (basename === "package.json" || basename === "node_modules")) { + result.affectedModuleSpecifierCacheProjects.forEach((projectName) => { + var _a2, _b; + (_b = (_a2 = this.findProject(projectName)) == null ? void 0 : _a2.getModuleSpecifierCache()) == null ? void 0 : _b.clear(); + }); + } + if (result.refreshScriptInfoRefCount) { + if (dir === fileOrDirectoryPath) { + this.refreshScriptInfosInDirectory(dir); + } else { + const info = this.getScriptInfoForPath(fileOrDirectoryPath); + if (info) { + if (isScriptInfoWatchedFromNodeModules(info)) { + this.refreshScriptInfo(info); + } + } else if (!hasExtension(fileOrDirectoryPath)) { + this.refreshScriptInfosInDirectory(fileOrDirectoryPath); + } + } + } + }, + 1 /* Recursive */, + this.hostConfiguration.watchOptions, + WatchType.NodeModules + ); + const result = { + refreshScriptInfoRefCount: 0, + affectedModuleSpecifierCacheProjects: void 0, + close: () => { + var _a; + if (!result.refreshScriptInfoRefCount && !((_a = result.affectedModuleSpecifierCacheProjects) == null ? void 0 : _a.size)) { + watcher.close(); + this.nodeModulesWatchers.delete(dir); + } + } + }; + this.nodeModulesWatchers.set(dir, result); + return result; + } + /** @internal */ + watchPackageJsonsInNodeModules(dir, project) { + const watcher = this.nodeModulesWatchers.get(dir) || this.createNodeModulesWatcher(dir); + (watcher.affectedModuleSpecifierCacheProjects || (watcher.affectedModuleSpecifierCacheProjects = /* @__PURE__ */ new Set())).add(project.getProjectName()); return { - ...options, - prefix: after.end === sourceFile.end && isStatement(after) ? options.prefix ? ` -${options.prefix}` : "\n" : options.prefix + close: () => { + var _a; + (_a = watcher.affectedModuleSpecifierCacheProjects) == null ? void 0 : _a.delete(project.getProjectName()); + watcher.close(); + } }; } - getInsertNodeAfterOptionsWorker(node) { - switch (node.kind) { - case 262 /* ClassDeclaration */: - case 266 /* ModuleDeclaration */: - return { prefix: this.newLineCharacter, suffix: this.newLineCharacter }; - case 259 /* VariableDeclaration */: - case 11 /* StringLiteral */: - case 80 /* Identifier */: - return { prefix: ", " }; - case 302 /* PropertyAssignment */: - return { suffix: "," + this.newLineCharacter }; - case 95 /* ExportKeyword */: - return { prefix: " " }; - case 168 /* Parameter */: - return {}; - default: - Debug.assert(isStatement(node) || isClassOrTypeElement(node)); - return { suffix: this.newLineCharacter }; + watchClosedScriptInfoInNodeModules(dir) { + const watchDir = dir + "/node_modules"; + const watcher = this.nodeModulesWatchers.get(watchDir) || this.createNodeModulesWatcher(watchDir); + watcher.refreshScriptInfoRefCount++; + return { + close: () => { + watcher.refreshScriptInfoRefCount--; + watcher.close(); + } + }; + } + getModifiedTime(info) { + return (this.host.getModifiedTime(info.path) || missingFileModifiedTime).getTime(); + } + refreshScriptInfo(info) { + const mTime = this.getModifiedTime(info); + if (mTime !== info.mTime) { + const eventKind = getFileWatcherEventKind(info.mTime, mTime); + info.mTime = mTime; + this.onSourceFileChanged(info, eventKind); } } - insertName(sourceFile, node, name) { - Debug.assert(!node.name); - if (node.kind === 218 /* ArrowFunction */) { - const arrow = findChildOfKind(node, 39 /* EqualsGreaterThanToken */, sourceFile); - const lparen = findChildOfKind(node, 21 /* OpenParenToken */, sourceFile); - if (lparen) { - this.insertNodesAt(sourceFile, lparen.getStart(sourceFile), [factory.createToken(100 /* FunctionKeyword */), factory.createIdentifier(name)], { joiner: " " }); - deleteNode(this, sourceFile, arrow); - } else { - this.insertText(sourceFile, first(node.parameters).getStart(sourceFile), `function ${name}(`); - this.replaceRange(sourceFile, arrow, factory.createToken(22 /* CloseParenToken */)); + refreshScriptInfosInDirectory(dir) { + dir = dir + directorySeparator; + this.filenameToScriptInfo.forEach((info) => { + if (isScriptInfoWatchedFromNodeModules(info) && startsWith(info.path, dir)) { + this.refreshScriptInfo(info); } - if (node.body.kind !== 240 /* Block */) { - this.insertNodesAt(sourceFile, node.body.getStart(sourceFile), [factory.createToken(19 /* OpenBraceToken */), factory.createToken(107 /* ReturnKeyword */)], { joiner: " ", suffix: " " }); - this.insertNodesAt(sourceFile, node.body.end, [factory.createToken(27 /* SemicolonToken */), factory.createToken(20 /* CloseBraceToken */)], { joiner: " " }); - } - } else { - const pos = findChildOfKind(node, node.kind === 217 /* FunctionExpression */ ? 100 /* FunctionKeyword */ : 86 /* ClassKeyword */, sourceFile).end; - this.insertNodeAt(sourceFile, pos, factory.createIdentifier(name), { prefix: " " }); - } + }); } - insertExportModifier(sourceFile, node) { - this.insertText(sourceFile, node.getStart(sourceFile), "export "); + stopWatchingScriptInfo(info) { + if (info.fileWatcher) { + info.fileWatcher.close(); + info.fileWatcher = void 0; + } } - insertImportSpecifierAtIndex(sourceFile, importSpecifier, namedImports, index) { - const prevSpecifier = namedImports.elements[index - 1]; - if (prevSpecifier) { - this.insertNodeInListAfter(sourceFile, prevSpecifier, importSpecifier); - } else { - this.insertNodeBefore( - sourceFile, - namedImports.elements[0], - importSpecifier, - !positionsAreOnSameLine(namedImports.elements[0].getStart(), namedImports.parent.parent.getStart(), sourceFile) + getOrCreateScriptInfoNotOpenedByClientForNormalizedPath(fileName, currentDirectory, scriptKind, hasMixedContent, hostToQueryFileExistsOn) { + if (isRootedDiskPath(fileName) || isDynamicFileName(fileName)) { + return this.getOrCreateScriptInfoWorker( + fileName, + currentDirectory, + /*openedByClient*/ + false, + /*fileContent*/ + void 0, + scriptKind, + hasMixedContent, + hostToQueryFileExistsOn ); } + const info = this.openFilesWithNonRootedDiskPath.get(this.toCanonicalFileName(fileName)); + if (info) { + return info; + } + return void 0; + } + getOrCreateScriptInfoOpenedByClientForNormalizedPath(fileName, currentDirectory, fileContent, scriptKind, hasMixedContent) { + return this.getOrCreateScriptInfoWorker( + fileName, + currentDirectory, + /*openedByClient*/ + true, + fileContent, + scriptKind, + hasMixedContent + ); + } + getOrCreateScriptInfoForNormalizedPath(fileName, openedByClient, fileContent, scriptKind, hasMixedContent, hostToQueryFileExistsOn) { + return this.getOrCreateScriptInfoWorker(fileName, this.currentDirectory, openedByClient, fileContent, scriptKind, hasMixedContent, hostToQueryFileExistsOn); + } + getOrCreateScriptInfoWorker(fileName, currentDirectory, openedByClient, fileContent, scriptKind, hasMixedContent, hostToQueryFileExistsOn) { + Debug.assert(fileContent === void 0 || openedByClient, "ScriptInfo needs to be opened by client to be able to set its user defined content"); + const path = normalizedPathToPath(fileName, currentDirectory, this.toCanonicalFileName); + let info = this.getScriptInfoForPath(path); + if (!info) { + const isDynamic = isDynamicFileName(fileName); + Debug.assert(isRootedDiskPath(fileName) || isDynamic || openedByClient, "", () => `${JSON.stringify({ fileName, currentDirectory, hostCurrentDirectory: this.currentDirectory, openKeys: arrayFrom(this.openFilesWithNonRootedDiskPath.keys()) })} +Script info with non-dynamic relative file name can only be open script info or in context of host currentDirectory`); + Debug.assert(!isRootedDiskPath(fileName) || this.currentDirectory === currentDirectory || !this.openFilesWithNonRootedDiskPath.has(this.toCanonicalFileName(fileName)), "", () => `${JSON.stringify({ fileName, currentDirectory, hostCurrentDirectory: this.currentDirectory, openKeys: arrayFrom(this.openFilesWithNonRootedDiskPath.keys()) })} +Open script files with non rooted disk path opened with current directory context cannot have same canonical names`); + Debug.assert(!isDynamic || this.currentDirectory === currentDirectory || this.useInferredProjectPerProjectRoot, "", () => `${JSON.stringify({ fileName, currentDirectory, hostCurrentDirectory: this.currentDirectory, openKeys: arrayFrom(this.openFilesWithNonRootedDiskPath.keys()) })} +Dynamic files must always be opened with service's current directory or service should support inferred project per projectRootPath.`); + if (!openedByClient && !isDynamic && !(hostToQueryFileExistsOn || this.host).fileExists(fileName)) { + return; + } + info = new ScriptInfo(this.host, fileName, scriptKind, !!hasMixedContent, path, this.filenameToScriptInfoVersion.get(path)); + this.filenameToScriptInfo.set(info.path, info); + this.filenameToScriptInfoVersion.delete(info.path); + if (!openedByClient) { + this.watchClosedScriptInfo(info); + } else if (!isRootedDiskPath(fileName) && (!isDynamic || this.currentDirectory !== currentDirectory)) { + this.openFilesWithNonRootedDiskPath.set(this.toCanonicalFileName(fileName), info); + } + } + if (openedByClient) { + this.stopWatchingScriptInfo(info); + info.open(fileContent); + if (hasMixedContent) { + info.registerFileUpdate(); + } + } + return info; } /** - * This function should be used to insert nodes in lists when nodes don't carry separators as the part of the node range, - * i.e. arguments in arguments lists, parameters in parameter lists etc. - * Note that separators are part of the node in statements and class elements. + * This gets the script info for the normalized path. If the path is not rooted disk path then the open script info with project root context is preferred */ - insertNodeInListAfter(sourceFile, after, newNode, containingList = ts_formatting_exports.SmartIndenter.getContainingList(after, sourceFile)) { - if (!containingList) { - Debug.fail("node is not a list element"); - return; + getScriptInfoForNormalizedPath(fileName) { + return !isRootedDiskPath(fileName) && this.openFilesWithNonRootedDiskPath.get(this.toCanonicalFileName(fileName)) || this.getScriptInfoForPath(normalizedPathToPath(fileName, this.currentDirectory, this.toCanonicalFileName)); + } + getScriptInfoForPath(fileName) { + return this.filenameToScriptInfo.get(fileName); + } + /** @internal */ + getDocumentPositionMapper(project, generatedFileName, sourceFileName) { + const declarationInfo = this.getOrCreateScriptInfoNotOpenedByClient(generatedFileName, project.currentDirectory, this.host); + if (!declarationInfo) { + if (sourceFileName) { + project.addGeneratedFileWatch(generatedFileName, sourceFileName); + } + return void 0; } - const index = indexOfNode(containingList, after); - if (index < 0) { - return; + declarationInfo.getSnapshot(); + if (isString(declarationInfo.sourceMapFilePath)) { + const sourceMapFileInfo2 = this.getScriptInfoForPath(declarationInfo.sourceMapFilePath); + if (sourceMapFileInfo2) { + sourceMapFileInfo2.getSnapshot(); + if (sourceMapFileInfo2.documentPositionMapper !== void 0) { + sourceMapFileInfo2.sourceInfos = this.addSourceInfoToSourceMap(sourceFileName, project, sourceMapFileInfo2.sourceInfos); + return sourceMapFileInfo2.documentPositionMapper ? sourceMapFileInfo2.documentPositionMapper : void 0; + } + } + declarationInfo.sourceMapFilePath = void 0; + } else if (declarationInfo.sourceMapFilePath) { + declarationInfo.sourceMapFilePath.sourceInfos = this.addSourceInfoToSourceMap(sourceFileName, project, declarationInfo.sourceMapFilePath.sourceInfos); + return void 0; + } else if (declarationInfo.sourceMapFilePath !== void 0) { + return void 0; } - const end = after.getEnd(); - if (index !== containingList.length - 1) { - const nextToken = getTokenAtPosition(sourceFile, after.end); - if (nextToken && isSeparator(after, nextToken)) { - const nextNode = containingList[index + 1]; - const startPos = skipWhitespacesAndLineBreaks(sourceFile.text, nextNode.getFullStart()); - const suffix = `${tokenToString(nextToken.kind)}${sourceFile.text.substring(nextToken.end, startPos)}`; - this.insertNodesAt(sourceFile, startPos, [newNode], { suffix }); + let sourceMapFileInfo; + let mapFileNameFromDeclarationInfo; + let readMapFile = (mapFileName, mapFileNameFromDts) => { + const mapInfo = this.getOrCreateScriptInfoNotOpenedByClient(mapFileName, project.currentDirectory, this.host); + if (!mapInfo) { + mapFileNameFromDeclarationInfo = mapFileNameFromDts; + return void 0; + } + sourceMapFileInfo = mapInfo; + const snap = mapInfo.getSnapshot(); + if (mapInfo.documentPositionMapper !== void 0) + return mapInfo.documentPositionMapper; + return getSnapshotText(snap); + }; + const projectName = project.projectName; + const documentPositionMapper = getDocumentPositionMapper( + { getCanonicalFileName: this.toCanonicalFileName, log: (s) => this.logger.info(s), getSourceFileLike: (f) => this.getSourceFileLike(f, projectName, declarationInfo) }, + declarationInfo.fileName, + declarationInfo.textStorage.getLineInfo(), + readMapFile + ); + readMapFile = void 0; + if (sourceMapFileInfo) { + declarationInfo.sourceMapFilePath = sourceMapFileInfo.path; + sourceMapFileInfo.declarationInfoPath = declarationInfo.path; + sourceMapFileInfo.documentPositionMapper = documentPositionMapper || false; + sourceMapFileInfo.sourceInfos = this.addSourceInfoToSourceMap(sourceFileName, project, sourceMapFileInfo.sourceInfos); + } else if (mapFileNameFromDeclarationInfo) { + declarationInfo.sourceMapFilePath = { + watcher: this.addMissingSourceMapFile( + project.currentDirectory === this.currentDirectory ? mapFileNameFromDeclarationInfo : getNormalizedAbsolutePath(mapFileNameFromDeclarationInfo, project.currentDirectory), + declarationInfo.path + ), + sourceInfos: this.addSourceInfoToSourceMap(sourceFileName, project) + }; + } else { + declarationInfo.sourceMapFilePath = false; + } + return documentPositionMapper; + } + addSourceInfoToSourceMap(sourceFileName, project, sourceInfos) { + if (sourceFileName) { + const sourceInfo = this.getOrCreateScriptInfoNotOpenedByClient(sourceFileName, project.currentDirectory, project.directoryStructureHost); + (sourceInfos || (sourceInfos = /* @__PURE__ */ new Set())).add(sourceInfo.path); + } + return sourceInfos; + } + addMissingSourceMapFile(mapFileName, declarationInfoPath) { + const fileWatcher = this.watchFactory.watchFile( + mapFileName, + () => { + const declarationInfo = this.getScriptInfoForPath(declarationInfoPath); + if (declarationInfo && declarationInfo.sourceMapFilePath && !isString(declarationInfo.sourceMapFilePath)) { + this.delayUpdateProjectGraphs( + declarationInfo.containingProjects, + /*clearSourceMapperCache*/ + true + ); + this.delayUpdateSourceInfoProjects(declarationInfo.sourceMapFilePath.sourceInfos); + declarationInfo.closeSourceMapFileWatcher(); + } + }, + 2e3 /* High */, + this.hostConfiguration.watchOptions, + WatchType.MissingSourceMapFile + ); + return fileWatcher; + } + /** @internal */ + getSourceFileLike(fileName, projectNameOrProject, declarationInfo) { + const project = projectNameOrProject.projectName ? projectNameOrProject : this.findProject(projectNameOrProject); + if (project) { + const path = project.toPath(fileName); + const sourceFile = project.getSourceFile(path); + if (sourceFile && sourceFile.resolvedPath === path) + return sourceFile; + } + const info = this.getOrCreateScriptInfoNotOpenedByClient(fileName, (project || this).currentDirectory, project ? project.directoryStructureHost : this.host); + if (!info) + return void 0; + if (declarationInfo && isString(declarationInfo.sourceMapFilePath) && info !== declarationInfo) { + const sourceMapInfo = this.getScriptInfoForPath(declarationInfo.sourceMapFilePath); + if (sourceMapInfo) { + (sourceMapInfo.sourceInfos || (sourceMapInfo.sourceInfos = /* @__PURE__ */ new Set())).add(info.path); + } + } + if (info.cacheSourceFile) + return info.cacheSourceFile.sourceFile; + if (!info.sourceFileLike) { + info.sourceFileLike = { + get text() { + Debug.fail("shouldnt need text"); + return ""; + }, + getLineAndCharacterOfPosition: (pos) => { + const lineOffset = info.positionToLineOffset(pos); + return { line: lineOffset.line - 1, character: lineOffset.offset - 1 }; + }, + getPositionOfLineAndCharacter: (line, character, allowEdits) => info.lineOffsetToPosition(line + 1, character + 1, allowEdits) + }; + } + return info.sourceFileLike; + } + /** @internal */ + setPerformanceEventHandler(performanceEventHandler) { + this.performanceEventHandler = performanceEventHandler; + } + setHostConfiguration(args) { + var _a, _b; + if (args.file) { + const info = this.getScriptInfoForNormalizedPath(toNormalizedPath(args.file)); + if (info) { + info.setOptions(convertFormatOptions(args.formatOptions), args.preferences); + this.logger.info(`Host configuration update for file ${args.file}`); } } else { - const afterStart = after.getStart(sourceFile); - const afterStartLinePosition = getLineStartPositionForPosition(afterStart, sourceFile); - let separator; - let multilineList = false; - if (containingList.length === 1) { - separator = 28 /* CommaToken */; - } else { - const tokenBeforeInsertPosition = findPrecedingToken(after.pos, sourceFile); - separator = isSeparator(after, tokenBeforeInsertPosition) ? tokenBeforeInsertPosition.kind : 28 /* CommaToken */; - const afterMinusOneStartLinePosition = getLineStartPositionForPosition(containingList[index - 1].getStart(sourceFile), sourceFile); - multilineList = afterMinusOneStartLinePosition !== afterStartLinePosition; + if (args.hostInfo !== void 0) { + this.hostConfiguration.hostInfo = args.hostInfo; + this.logger.info(`Host information ${args.hostInfo}`); + } + if (args.formatOptions) { + this.hostConfiguration.formatCodeOptions = { ...this.hostConfiguration.formatCodeOptions, ...convertFormatOptions(args.formatOptions) }; + this.logger.info("Format host information updated"); + } + if (args.preferences) { + const { + lazyConfiguredProjectsFromExternalProject, + includePackageJsonAutoImports + } = this.hostConfiguration.preferences; + this.hostConfiguration.preferences = { ...this.hostConfiguration.preferences, ...args.preferences }; + if (lazyConfiguredProjectsFromExternalProject && !this.hostConfiguration.preferences.lazyConfiguredProjectsFromExternalProject) { + this.configuredProjects.forEach((project) => { + if (project.hasExternalProjectRef() && project.pendingUpdateLevel === 2 /* Full */ && !this.pendingProjectUpdates.has(project.getProjectName())) { + project.updateGraph(); + } + }); + } + if (includePackageJsonAutoImports !== args.preferences.includePackageJsonAutoImports) { + this.invalidateProjectPackageJson( + /*packageJsonPath*/ + void 0 + ); + } } - if (hasCommentsBeforeLineBreak(sourceFile.text, after.end)) { - multilineList = true; + if (args.extraFileExtensions) { + this.hostConfiguration.extraFileExtensions = args.extraFileExtensions; + this.reloadProjects(); + this.logger.info("Host file extension mappings updated"); } - if (multilineList) { - this.replaceRange(sourceFile, createRange(end), factory.createToken(separator)); - const indentation = ts_formatting_exports.SmartIndenter.findFirstNonWhitespaceColumn(afterStartLinePosition, afterStart, sourceFile, this.formatContext.options); - let insertPos = skipTrivia( - sourceFile.text, - end, - /*stopAfterLineBreak*/ - true, - /*stopAtComments*/ - false + if (args.watchOptions) { + this.hostConfiguration.watchOptions = (_a = convertWatchOptions(args.watchOptions)) == null ? void 0 : _a.watchOptions; + this.logger.info(`Host watch options changed to ${JSON.stringify(this.hostConfiguration.watchOptions)}, it will be take effect for next watches.`); + (_b = this.pnpWatcher) == null ? void 0 : _b.close(); + this.watchPnpFile(); + } + } + } + /** @internal */ + getWatchOptions(project) { + return this.getWatchOptionsFromProjectWatchOptions(project.getWatchOptions()); + } + /** @internal */ + getWatchOptionsFromProjectWatchOptions(projectOptions) { + return projectOptions && this.hostConfiguration.watchOptions ? { ...this.hostConfiguration.watchOptions, ...projectOptions } : projectOptions || this.hostConfiguration.watchOptions; + } + closeLog() { + this.logger.close(); + } + /** + * This function rebuilds the project for every file opened by the client + * This does not reload contents of open files from disk. But we could do that if needed + */ + reloadProjects() { + this.logger.info("reload projects."); + this.filenameToScriptInfo.forEach((info) => { + if (this.openFiles.has(info.path)) + return; + if (!info.fileWatcher) + return; + this.onSourceFileChanged(info, this.host.fileExists(info.fileName) ? 1 /* Changed */ : 2 /* Deleted */); + }); + this.pendingProjectUpdates.forEach((_project, projectName) => { + this.throttledOperations.cancel(projectName); + this.pendingProjectUpdates.delete(projectName); + }); + this.throttledOperations.cancel(ensureProjectForOpenFileSchedule); + this.pendingEnsureProjectForOpenFiles = false; + this.configFileExistenceInfoCache.forEach((info) => { + if (info.config) + info.config.updateLevel = 2 /* Full */; + }); + this.reloadConfiguredProjectForFiles( + this.openFiles, + /*clearSemanticCache*/ + true, + /*delayReload*/ + false, + returnTrue, + "User requested reload projects" + ); + this.externalProjects.forEach((project) => { + this.clearSemanticCache(project); + project.updateGraph(); + }); + this.inferredProjects.forEach((project) => this.clearSemanticCache(project)); + this.ensureProjectForOpenFiles(); + } + /** + * This function goes through all the openFiles and tries to file the config file for them. + * If the config file is found and it refers to existing project, it reloads it either immediately + * or schedules it for reload depending on delayReload option + * If there is no existing project it just opens the configured project for the config file + * reloadForInfo provides a way to filter out files to reload configured project for + */ + reloadConfiguredProjectForFiles(openFiles, clearSemanticCache, delayReload, shouldReloadProjectFor, reason) { + const updatedProjects = /* @__PURE__ */ new Map(); + const reloadChildProject = (child) => { + if (!updatedProjects.has(child.canonicalConfigFilePath)) { + updatedProjects.set(child.canonicalConfigFilePath, true); + this.reloadConfiguredProject( + child, + reason, + /*isInitialLoad*/ + false, + clearSemanticCache ); - while (insertPos !== end && isLineBreak(sourceFile.text.charCodeAt(insertPos - 1))) { - insertPos--; + } + }; + openFiles == null ? void 0 : openFiles.forEach((openFileValue, path) => { + this.configFileForOpenFiles.delete(path); + if (!shouldReloadProjectFor(openFileValue)) { + return; + } + const info = this.getScriptInfoForPath(path); + Debug.assert(info.isScriptOpen()); + const configFileName = this.getConfigFileNameForFile(info); + if (configFileName) { + const project = this.findConfiguredProjectByProjectName(configFileName) || this.createConfiguredProject(configFileName); + if (!updatedProjects.has(project.canonicalConfigFilePath)) { + updatedProjects.set(project.canonicalConfigFilePath, true); + if (delayReload) { + project.pendingUpdateLevel = 2 /* Full */; + project.pendingUpdateReason = reason; + if (clearSemanticCache) + this.clearSemanticCache(project); + this.delayUpdateProjectGraph(project); + } else { + this.reloadConfiguredProject( + project, + reason, + /*isInitialLoad*/ + false, + clearSemanticCache + ); + if (!projectContainsInfoDirectly(project, info)) { + const referencedProject = forEachResolvedProjectReferenceProject( + project, + info.path, + (child) => { + reloadChildProject(child); + return projectContainsInfoDirectly(child, info); + }, + 1 /* FindCreate */ + ); + if (referencedProject) { + forEachResolvedProjectReferenceProject( + project, + /*fileName*/ + void 0, + reloadChildProject, + 0 /* Find */ + ); + } + } + } } - this.replaceRange(sourceFile, createRange(insertPos), newNode, { indentation, prefix: this.newLineCharacter }); + } + }); + } + /** + * Remove the root of inferred project if script info is part of another project + */ + removeRootOfInferredProjectIfNowPartOfOtherProject(info) { + Debug.assert(info.containingProjects.length > 0); + const firstProject = info.containingProjects[0]; + if (!firstProject.isOrphan() && isInferredProject(firstProject) && firstProject.isRoot(info) && forEach(info.containingProjects, (p) => p !== firstProject && !p.isOrphan())) { + firstProject.removeFile( + info, + /*fileExists*/ + true, + /*detachFromProject*/ + true + ); + } + } + /** + * This function is to update the project structure for every inferred project. + * It is called on the premise that all the configured projects are + * up to date. + * This will go through open files and assign them to inferred project if open file is not part of any other project + * After that all the inferred project graphs are updated + */ + ensureProjectForOpenFiles() { + this.logger.info("Before ensureProjectForOpenFiles:"); + this.printProjects(); + this.openFiles.forEach((projectRootPath, path) => { + const info = this.getScriptInfoForPath(path); + if (info.isOrphan()) { + this.assignOrphanScriptInfoToInferredProject(info, projectRootPath); } else { - this.replaceRange(sourceFile, createRange(end), newNode, { prefix: `${tokenToString(separator)} ` }); + this.removeRootOfInferredProjectIfNowPartOfOtherProject(info); + } + }); + this.pendingEnsureProjectForOpenFiles = false; + this.inferredProjects.forEach(updateProjectIfDirty); + this.logger.info("After ensureProjectForOpenFiles:"); + this.printProjects(); + } + /** + * Open file whose contents is managed by the client + * @param filename is absolute pathname + * @param fileContent is a known version of the file content that is more up to date than the one on disk + */ + openClientFile(fileName, fileContent, scriptKind, projectRootPath) { + return this.openClientFileWithNormalizedPath( + toNormalizedPath(fileName), + fileContent, + scriptKind, + /*hasMixedContent*/ + false, + projectRootPath ? toNormalizedPath(projectRootPath) : void 0 + ); + } + /** @internal */ + getOriginalLocationEnsuringConfiguredProject(project, location) { + const isSourceOfProjectReferenceRedirect = project.isSourceOfProjectReferenceRedirect(location.fileName); + const originalLocation = isSourceOfProjectReferenceRedirect ? location : project.getSourceMapper().tryGetSourcePosition(location); + if (!originalLocation) + return void 0; + const { fileName } = originalLocation; + const scriptInfo = this.getScriptInfo(fileName); + if (!scriptInfo && !this.host.fileExists(fileName)) + return void 0; + const originalFileInfo = { fileName: toNormalizedPath(fileName), path: this.toPath(fileName) }; + const configFileName = this.getConfigFileNameForFile(originalFileInfo); + if (!configFileName) + return void 0; + let configuredProject = this.findConfiguredProjectByProjectName(configFileName); + if (!configuredProject) { + if (project.getCompilerOptions().disableReferencedProjectLoad) { + if (isSourceOfProjectReferenceRedirect) { + return location; + } + return (scriptInfo == null ? void 0 : scriptInfo.containingProjects.length) ? originalLocation : location; + } + configuredProject = this.createAndLoadConfiguredProject(configFileName, `Creating project for original file: ${originalFileInfo.fileName}${location !== originalLocation ? " for location: " + location.fileName : ""}`); + } + updateProjectIfDirty(configuredProject); + const projectContainsOriginalInfo = (project2) => { + const info = this.getScriptInfo(fileName); + return info && projectContainsInfoDirectly(project2, info); + }; + if (configuredProject.isSolution() || !projectContainsOriginalInfo(configuredProject)) { + configuredProject = forEachResolvedProjectReferenceProject( + configuredProject, + fileName, + (child) => { + updateProjectIfDirty(child); + return projectContainsOriginalInfo(child) ? child : void 0; + }, + 2 /* FindCreateLoad */, + `Creating project referenced in solution ${configuredProject.projectName} to find possible configured project for original file: ${originalFileInfo.fileName}${location !== originalLocation ? " for location: " + location.fileName : ""}` + ); + if (!configuredProject) + return void 0; + if (configuredProject === project) + return originalLocation; + } + addOriginalConfiguredProject(configuredProject); + const originalScriptInfo = this.getScriptInfo(fileName); + if (!originalScriptInfo || !originalScriptInfo.containingProjects.length) + return void 0; + originalScriptInfo.containingProjects.forEach((project2) => { + if (isConfiguredProject(project2)) { + addOriginalConfiguredProject(project2); + } + }); + return originalLocation; + function addOriginalConfiguredProject(originalProject) { + if (!project.originalConfiguredProjects) { + project.originalConfiguredProjects = /* @__PURE__ */ new Set(); } + project.originalConfiguredProjects.add(originalProject.canonicalConfigFilePath); } } - parenthesizeExpression(sourceFile, expression) { - this.replaceRange(sourceFile, rangeOfNode(expression), factory.createParenthesizedExpression(expression)); + /** @internal */ + fileExists(fileName) { + return !!this.getScriptInfoForNormalizedPath(fileName) || this.host.fileExists(fileName); } - finishClassesWithNodesInsertedAtStart() { - this.classesWithNodesInsertedAtStart.forEach(({ node, sourceFile }) => { - const [openBraceEnd, closeBraceEnd] = getClassOrObjectBraceEnds(node, sourceFile); - if (openBraceEnd !== void 0 && closeBraceEnd !== void 0) { - const isEmpty = getMembersOrProperties(node).length === 0; - const isSingleLine = positionsAreOnSameLine(openBraceEnd, closeBraceEnd, sourceFile); - if (isEmpty && isSingleLine && openBraceEnd !== closeBraceEnd - 1) { - this.deleteRange(sourceFile, createRange(openBraceEnd, closeBraceEnd - 1)); - } - if (isSingleLine) { - this.insertText(sourceFile, closeBraceEnd - 1, this.newLineCharacter); - } - } + findExternalProjectContainingOpenScriptInfo(info) { + return find(this.externalProjects, (proj) => { + updateProjectIfDirty(proj); + return proj.containsScriptInfo(info); }); } - finishDeleteDeclarations() { - const deletedNodesInLists = /* @__PURE__ */ new Set(); - for (const { sourceFile, node } of this.deletedNodes) { - if (!this.deletedNodes.some((d) => d.sourceFile === sourceFile && rangeContainsRangeExclusive(d.node, node))) { - if (isArray(node)) { - this.deleteRange(sourceFile, rangeOfTypeParameters(sourceFile, node)); + getOrCreateOpenScriptInfo(fileName, fileContent, scriptKind, hasMixedContent, projectRootPath) { + const info = this.getOrCreateScriptInfoOpenedByClientForNormalizedPath(fileName, projectRootPath ? this.getNormalizedAbsolutePath(projectRootPath) : this.currentDirectory, fileContent, scriptKind, hasMixedContent); + this.openFiles.set(info.path, projectRootPath); + return info; + } + assignProjectToOpenedScriptInfo(info) { + let configFileName; + let configFileErrors; + let project = this.findExternalProjectContainingOpenScriptInfo(info); + let retainProjects; + let projectForConfigFileDiag; + let defaultConfigProjectIsCreated = false; + if (!project && this.serverMode === 0 /* Semantic */) { + configFileName = this.getConfigFileNameForFile(info); + if (configFileName) { + project = this.findConfiguredProjectByProjectName(configFileName); + if (!project) { + project = this.createLoadAndUpdateConfiguredProject(configFileName, `Creating possible configured project for ${info.fileName} to open`); + defaultConfigProjectIsCreated = true; } else { - deleteDeclaration.deleteDeclaration(this, deletedNodesInLists, sourceFile, node); + updateProjectIfDirty(project); + } + projectForConfigFileDiag = project.containsScriptInfo(info) ? project : void 0; + retainProjects = project; + if (!projectContainsInfoDirectly(project, info)) { + forEachResolvedProjectReferenceProject( + project, + info.path, + (child) => { + updateProjectIfDirty(child); + if (!isArray(retainProjects)) { + retainProjects = [project, child]; + } else { + retainProjects.push(child); + } + if (projectContainsInfoDirectly(child, info)) { + projectForConfigFileDiag = child; + return child; + } + if (!projectForConfigFileDiag && child.containsScriptInfo(info)) { + projectForConfigFileDiag = child; + } + }, + 2 /* FindCreateLoad */, + `Creating project referenced in solution ${project.projectName} to find possible configured project for ${info.fileName} to open` + ); + } + if (projectForConfigFileDiag) { + configFileName = projectForConfigFileDiag.getConfigFilePath(); + if (projectForConfigFileDiag !== project || defaultConfigProjectIsCreated) { + configFileErrors = projectForConfigFileDiag.getAllProjectErrors(); + this.sendConfigFileDiagEvent(projectForConfigFileDiag, info.fileName); + } + } else { + configFileName = void 0; } + this.createAncestorProjects(info, project); } } - deletedNodesInLists.forEach((node) => { - const sourceFile = node.getSourceFile(); - const list = ts_formatting_exports.SmartIndenter.getContainingList(node, sourceFile); - if (node !== last(list)) - return; - const lastNonDeletedIndex = findLastIndex(list, (n) => !deletedNodesInLists.has(n), list.length - 2); - if (lastNonDeletedIndex !== -1) { - this.deleteRange(sourceFile, { pos: list[lastNonDeletedIndex].end, end: startPositionToDeleteNodeInList(sourceFile, list[lastNonDeletedIndex + 1]) }); + info.containingProjects.forEach(updateProjectIfDirty); + if (info.isOrphan()) { + if (isArray(retainProjects)) { + retainProjects.forEach((project2) => this.sendConfigFileDiagEvent(project2, info.fileName)); + } else if (retainProjects) { + this.sendConfigFileDiagEvent(retainProjects, info.fileName); } - }); - } - /** - * Note: after calling this, the TextChanges object must be discarded! - * @param validate only for tests - * The reason we must validate as part of this method is that `getNonFormattedText` changes the node's positions, - * so we can only call this once and can't get the non-formatted text separately. - */ - getChanges(validate) { - this.finishDeleteDeclarations(); - this.finishClassesWithNodesInsertedAtStart(); - const changes = changesToText.getTextChangesFromChanges(this.changes, this.newLineCharacter, this.formatContext, validate); - if (this.newFileChanges) { - this.newFileChanges.forEach((insertions, fileName) => { - changes.push(changesToText.newFileChanges(fileName, insertions, this.newLineCharacter, this.formatContext)); - }); + Debug.assert(this.openFiles.has(info.path)); + this.assignOrphanScriptInfoToInferredProject(info, this.openFiles.get(info.path)); } - return changes; - } - createNewFile(oldFile, fileName, statements) { - this.insertStatementsInNewFile(fileName, statements, oldFile); + Debug.assert(!info.isOrphan()); + return { configFileName, configFileErrors, retainProjects }; } - }; - ((changesToText2) => { - function getTextChangesFromChanges(changes, newLineCharacter, formatContext, validate) { - return mapDefined(group(changes, (c) => c.sourceFile.path), (changesInFile) => { - const sourceFile = changesInFile[0].sourceFile; - const normalized = stableSort(changesInFile, (a, b) => a.range.pos - b.range.pos || a.range.end - b.range.end); - for (let i = 0; i < normalized.length - 1; i++) { - Debug.assert(normalized[i].range.end <= normalized[i + 1].range.pos, "Changes overlap", () => `${JSON.stringify(normalized[i].range)} and ${JSON.stringify(normalized[i + 1].range)}`); - } - const textChanges2 = mapDefined(normalized, (c) => { - const span = createTextSpanFromRange(c.range); - const targetSourceFile = c.kind === 1 /* ReplaceWithSingleNode */ ? getSourceFileOfNode(getOriginalNode(c.node)) ?? c.sourceFile : c.kind === 2 /* ReplaceWithMultipleNodes */ ? getSourceFileOfNode(getOriginalNode(c.nodes[0])) ?? c.sourceFile : c.sourceFile; - const newText = computeNewText(c, targetSourceFile, sourceFile, newLineCharacter, formatContext, validate); - if (span.length === newText.length && stringContainsAt(targetSourceFile.text, newText, span.start)) { - return void 0; - } - return createTextChange(span, newText); + createAncestorProjects(info, project) { + if (!info.isAttached(project)) + return; + while (true) { + if (!project.isInitialLoadPending() && (!project.getCompilerOptions().composite || project.getCompilerOptions().disableSolutionSearching)) + return; + const configFileName = this.getConfigFileNameForFile({ + fileName: project.getConfigFilePath(), + path: info.path, + configFileInfo: true }); - return textChanges2.length > 0 ? { fileName: sourceFile.fileName, textChanges: textChanges2 } : void 0; - }); - } - changesToText2.getTextChangesFromChanges = getTextChangesFromChanges; - function newFileChanges(fileName, insertions, newLineCharacter, formatContext) { - const text = newFileChangesWorker(getScriptKindFromFileName(fileName), insertions, newLineCharacter, formatContext); - return { fileName, textChanges: [createTextChange(createTextSpan(0, 0), text)], isNewFile: true }; + if (!configFileName) + return; + const ancestor = this.findConfiguredProjectByProjectName(configFileName) || this.createConfiguredProjectWithDelayLoad(configFileName, `Creating project possibly referencing default composite project ${project.getProjectName()} of open file ${info.fileName}`); + if (ancestor.isInitialLoadPending()) { + ancestor.setPotentialProjectReference(project.canonicalConfigFilePath); + } + project = ancestor; + } } - changesToText2.newFileChanges = newFileChanges; - function newFileChangesWorker(scriptKind, insertions, newLineCharacter, formatContext) { - const nonFormattedText = flatMap(insertions, (insertion) => insertion.statements.map((s) => s === 4 /* NewLineTrivia */ ? "" : getNonformattedText(s, insertion.oldFile, newLineCharacter).text)).join(newLineCharacter); - const sourceFile = createSourceFile( - "any file name", - nonFormattedText, - 99 /* ESNext */, - /*setParentNodes*/ - true, - scriptKind + /** @internal */ + loadAncestorProjectTree(forProjects) { + forProjects = forProjects || mapDefinedEntries( + this.configuredProjects, + (key, project) => !project.isInitialLoadPending() ? [key, true] : void 0 ); - const changes = ts_formatting_exports.formatDocument(sourceFile, formatContext); - return applyChanges(nonFormattedText, changes) + newLineCharacter; + const seenProjects = /* @__PURE__ */ new Set(); + for (const project of arrayFrom(this.configuredProjects.values())) { + if (forEachPotentialProjectReference(project, (potentialRefPath) => forProjects.has(potentialRefPath))) { + updateProjectIfDirty(project); + } + this.ensureProjectChildren(project, forProjects, seenProjects); + } } - changesToText2.newFileChangesWorker = newFileChangesWorker; - function computeNewText(change, targetSourceFile, sourceFile, newLineCharacter, formatContext, validate) { + ensureProjectChildren(project, forProjects, seenProjects) { var _a; - if (change.kind === 0 /* Remove */) { - return ""; - } - if (change.kind === 3 /* Text */) { - return change.text; + if (!tryAddToSet(seenProjects, project.canonicalConfigFilePath)) + return; + if (project.getCompilerOptions().disableReferencedProjectLoad) + return; + const children = (_a = project.getCurrentProgram()) == null ? void 0 : _a.getResolvedProjectReferences(); + if (!children) + return; + for (const child of children) { + if (!child) + continue; + const referencedProject = forEachResolvedProjectReference(child.references, (ref) => forProjects.has(ref.sourceFile.path) ? ref : void 0); + if (!referencedProject) + continue; + const configFileName = toNormalizedPath(child.sourceFile.fileName); + const childProject = project.projectService.findConfiguredProjectByProjectName(configFileName) || project.projectService.createAndLoadConfiguredProject(configFileName, `Creating project referenced by : ${project.projectName} as it references project ${referencedProject.sourceFile.fileName}`); + updateProjectIfDirty(childProject); + this.ensureProjectChildren(childProject, forProjects, seenProjects); } - const { options = {}, range: { pos } } = change; - const format = (n) => getFormattedTextOfNode(n, targetSourceFile, sourceFile, pos, options, newLineCharacter, formatContext, validate); - const text = change.kind === 2 /* ReplaceWithMultipleNodes */ ? change.nodes.map((n) => removeSuffix(format(n), newLineCharacter)).join(((_a = change.options) == null ? void 0 : _a.joiner) || newLineCharacter) : format(change.node); - const noIndent = options.indentation !== void 0 || getLineStartPositionForPosition(pos, targetSourceFile) === pos ? text : text.replace(/^\s+/, ""); - return (options.prefix || "") + noIndent + (!options.suffix || endsWith(noIndent, options.suffix) ? "" : options.suffix); } - function getFormattedTextOfNode(nodeIn, targetSourceFile, sourceFile, pos, { indentation, prefix, delta }, newLineCharacter, formatContext, validate) { - const { node, text } = getNonformattedText(nodeIn, targetSourceFile, newLineCharacter); - if (validate) - validate(node, text); - const formatOptions = getFormatCodeSettingsForWriting(formatContext, targetSourceFile); - const initialIndentation = indentation !== void 0 ? indentation : ts_formatting_exports.SmartIndenter.getIndentation(pos, sourceFile, formatOptions, prefix === newLineCharacter || getLineStartPositionForPosition(pos, targetSourceFile) === pos); - if (delta === void 0) { - delta = ts_formatting_exports.SmartIndenter.shouldIndentChildNode(formatOptions, nodeIn) ? formatOptions.indentSize || 0 : 0; + cleanupAfterOpeningFile(toRetainConfigProjects) { + this.removeOrphanConfiguredProjects(toRetainConfigProjects); + for (const inferredProject of this.inferredProjects.slice()) { + if (inferredProject.isOrphan()) { + this.removeProject(inferredProject); + } } - const file = { - text, - getLineAndCharacterOfPosition(pos2) { - return getLineAndCharacterOfPosition(this, pos2); + this.removeOrphanScriptInfos(); + } + openClientFileWithNormalizedPath(fileName, fileContent, scriptKind, hasMixedContent, projectRootPath) { + const info = this.getOrCreateOpenScriptInfo(fileName, fileContent, scriptKind, hasMixedContent, projectRootPath); + const { retainProjects, ...result } = this.assignProjectToOpenedScriptInfo(info); + this.cleanupAfterOpeningFile(retainProjects); + this.telemetryOnOpenFile(info); + this.printProjects(); + return result; + } + removeOrphanConfiguredProjects(toRetainConfiguredProjects) { + const toRemoveConfiguredProjects = new Map(this.configuredProjects); + const markOriginalProjectsAsUsed = (project) => { + if (!project.isOrphan() && project.originalConfiguredProjects) { + project.originalConfiguredProjects.forEach( + (_value, configuredProjectPath) => { + const project2 = this.getConfiguredProjectByCanonicalConfigFilePath(configuredProjectPath); + return project2 && retainConfiguredProject(project2); + } + ); } }; - const changes = ts_formatting_exports.formatNodeGivenIndentation(node, file, targetSourceFile.languageVariant, initialIndentation, delta, { ...formatContext, options: formatOptions }); - return applyChanges(text, changes); - } - function getNonformattedText(node, sourceFile, newLineCharacter) { - const writer = createWriter(newLineCharacter); - const newLine = getNewLineKind(newLineCharacter); - createPrinter({ - newLine, - neverAsciiEscape: true, - preserveSourceNewlines: true, - terminateUnterminatedLiterals: true - }, writer).writeNode(4 /* Unspecified */, node, sourceFile, writer); - return { text: writer.getText(), node: assignPositionsToNode(node) }; + if (toRetainConfiguredProjects) { + if (isArray(toRetainConfiguredProjects)) { + toRetainConfiguredProjects.forEach(retainConfiguredProject); + } else { + retainConfiguredProject(toRetainConfiguredProjects); + } + } + this.inferredProjects.forEach(markOriginalProjectsAsUsed); + this.externalProjects.forEach(markOriginalProjectsAsUsed); + this.configuredProjects.forEach((project) => { + if (project.hasOpenRef()) { + retainConfiguredProject(project); + } else if (toRemoveConfiguredProjects.has(project.canonicalConfigFilePath)) { + forEachReferencedProject( + project, + (ref) => isRetained(ref) && retainConfiguredProject(project) + ); + } + }); + toRemoveConfiguredProjects.forEach((project) => this.removeProject(project)); + function isRetained(project) { + return project.hasOpenRef() || !toRemoveConfiguredProjects.has(project.canonicalConfigFilePath); + } + function retainConfiguredProject(project) { + if (toRemoveConfiguredProjects.delete(project.canonicalConfigFilePath)) { + markOriginalProjectsAsUsed(project); + forEachReferencedProject(project, retainConfiguredProject); + } + } } - changesToText2.getNonformattedText = getNonformattedText; - })(changesToText || (changesToText = {})); - textChangesTransformationContext = { - ...nullTransformationContext, - factory: createNodeFactory( - nullTransformationContext.factory.flags | 1 /* NoParenthesizerRules */, - nullTransformationContext.factory.baseFactory - ) - }; - ((_deleteDeclaration) => { - function deleteDeclaration2(changes, deletedNodesInLists, sourceFile, node) { - switch (node.kind) { - case 168 /* Parameter */: { - const oldFunction = node.parent; - if (isArrowFunction(oldFunction) && oldFunction.parameters.length === 1 && !findChildOfKind(oldFunction, 21 /* OpenParenToken */, sourceFile)) { - changes.replaceNodeWithText(sourceFile, node, "()"); + removeOrphanScriptInfos() { + const toRemoveScriptInfos = new Map(this.filenameToScriptInfo); + this.filenameToScriptInfo.forEach((info) => { + if (!info.isScriptOpen() && info.isOrphan() && !info.isContainedByBackgroundProject()) { + if (!info.sourceMapFilePath) + return; + let sourceInfos; + if (isString(info.sourceMapFilePath)) { + const sourceMapInfo = this.getScriptInfoForPath(info.sourceMapFilePath); + sourceInfos = sourceMapInfo && sourceMapInfo.sourceInfos; } else { - deleteNodeInList(changes, deletedNodesInLists, sourceFile, node); + sourceInfos = info.sourceMapFilePath.sourceInfos; } - break; - } - case 271 /* ImportDeclaration */: - case 270 /* ImportEqualsDeclaration */: - const isFirstImport = sourceFile.imports.length && node === first(sourceFile.imports).parent || node === find(sourceFile.statements, isAnyImportSyntax); - deleteNode(changes, sourceFile, node, { - leadingTriviaOption: isFirstImport ? 0 /* Exclude */ : hasJSDocNodes(node) ? 2 /* JSDoc */ : 3 /* StartLine */ - }); - break; - case 207 /* BindingElement */: - const pattern = node.parent; - const preserveComma = pattern.kind === 206 /* ArrayBindingPattern */ && node !== last(pattern.elements); - if (preserveComma) { - deleteNode(changes, sourceFile, node); - } else { - deleteNodeInList(changes, deletedNodesInLists, sourceFile, node); + if (!sourceInfos) + return; + if (!forEachKey(sourceInfos, (path) => { + const info2 = this.getScriptInfoForPath(path); + return !!info2 && (info2.isScriptOpen() || !info2.isOrphan()); + })) { + return; } - break; - case 259 /* VariableDeclaration */: - deleteVariableDeclaration(changes, deletedNodesInLists, sourceFile, node); - break; - case 167 /* TypeParameter */: - deleteNodeInList(changes, deletedNodesInLists, sourceFile, node); - break; - case 275 /* ImportSpecifier */: - const namedImports = node.parent; - if (namedImports.elements.length === 1) { - deleteImportBinding(changes, sourceFile, namedImports); + } + toRemoveScriptInfos.delete(info.path); + if (info.sourceMapFilePath) { + let sourceInfos; + if (isString(info.sourceMapFilePath)) { + toRemoveScriptInfos.delete(info.sourceMapFilePath); + const sourceMapInfo = this.getScriptInfoForPath(info.sourceMapFilePath); + sourceInfos = sourceMapInfo && sourceMapInfo.sourceInfos; } else { - deleteNodeInList(changes, deletedNodesInLists, sourceFile, node); + sourceInfos = info.sourceMapFilePath.sourceInfos; } - break; - case 273 /* NamespaceImport */: - deleteImportBinding(changes, sourceFile, node); - break; - case 27 /* SemicolonToken */: - deleteNode(changes, sourceFile, node, { trailingTriviaOption: 0 /* Exclude */ }); - break; - case 100 /* FunctionKeyword */: - deleteNode(changes, sourceFile, node, { leadingTriviaOption: 0 /* Exclude */ }); - break; - case 262 /* ClassDeclaration */: - case 261 /* FunctionDeclaration */: - deleteNode(changes, sourceFile, node, { leadingTriviaOption: hasJSDocNodes(node) ? 2 /* JSDoc */ : 3 /* StartLine */ }); - break; - default: - if (!node.parent) { - deleteNode(changes, sourceFile, node); - } else if (isImportClause(node.parent) && node.parent.name === node) { - deleteDefaultImport(changes, sourceFile, node.parent); - } else if (isCallExpression(node.parent) && contains(node.parent.arguments, node)) { - deleteNodeInList(changes, deletedNodesInLists, sourceFile, node); - } else { - deleteNode(changes, sourceFile, node); + if (sourceInfos) { + sourceInfos.forEach((_value, path) => toRemoveScriptInfos.delete(path)); } - } - } - _deleteDeclaration.deleteDeclaration = deleteDeclaration2; - function deleteDefaultImport(changes, sourceFile, importClause) { - if (!importClause.namedBindings) { - deleteNode(changes, sourceFile, importClause.parent); - } else { - const start = importClause.name.getStart(sourceFile); - const nextToken = getTokenAtPosition(sourceFile, importClause.name.end); - if (nextToken && nextToken.kind === 28 /* CommaToken */) { - const end = skipTrivia( - sourceFile.text, - nextToken.end, - /*stopAfterLineBreak*/ - false, - /*stopAtComments*/ - true - ); - changes.deleteRange(sourceFile, { pos: start, end }); - } else { - deleteNode(changes, sourceFile, importClause.name); } - } - } - function deleteImportBinding(changes, sourceFile, node) { - if (node.parent.name) { - const previousToken = Debug.checkDefined(getTokenAtPosition(sourceFile, node.pos - 1)); - changes.deleteRange(sourceFile, { pos: previousToken.getStart(sourceFile), end: node.end }); - } else { - const importDecl = getAncestor(node, 271 /* ImportDeclaration */); - deleteNode(changes, sourceFile, importDecl); - } + }); + toRemoveScriptInfos.forEach((info) => { + this.stopWatchingScriptInfo(info); + this.deleteScriptInfo(info); + info.closeSourceMapFileWatcher(); + }); } - function deleteVariableDeclaration(changes, deletedNodesInLists, sourceFile, node) { - const { parent: parent2 } = node; - if (parent2.kind === 298 /* CatchClause */) { - changes.deleteNodeRange(sourceFile, findChildOfKind(parent2, 21 /* OpenParenToken */, sourceFile), findChildOfKind(parent2, 22 /* CloseParenToken */, sourceFile)); + telemetryOnOpenFile(scriptInfo) { + if (this.serverMode !== 0 /* Semantic */ || !this.eventHandler || !scriptInfo.isJavaScript() || !addToSeen(this.allJsFilesForOpenFileTelemetry, scriptInfo.path)) { return; } - if (parent2.declarations.length !== 1) { - deleteNodeInList(changes, deletedNodesInLists, sourceFile, node); + const project = this.ensureDefaultProjectForFile(scriptInfo); + if (!project.languageServiceEnabled) { return; } - const gp = parent2.parent; - switch (gp.kind) { - case 249 /* ForOfStatement */: - case 248 /* ForInStatement */: - changes.replaceNode(sourceFile, node, factory.createObjectLiteralExpression()); - break; - case 247 /* ForStatement */: - deleteNode(changes, sourceFile, parent2); - break; - case 242 /* VariableStatement */: - deleteNode(changes, sourceFile, gp, { leadingTriviaOption: hasJSDocNodes(gp) ? 2 /* JSDoc */ : 3 /* StartLine */ }); - break; - default: - Debug.assertNever(gp); + const sourceFile = project.getSourceFile(scriptInfo.path); + const checkJs = !!sourceFile && !!sourceFile.checkJsDirective; + this.eventHandler({ eventName: OpenFileInfoTelemetryEvent, data: { info: { checkJs } } }); + } + closeClientFile(uncheckedFileName, skipAssignOrphanScriptInfosToInferredProject) { + const info = this.getScriptInfoForNormalizedPath(toNormalizedPath(uncheckedFileName)); + const result = info ? this.closeOpenFile(info, skipAssignOrphanScriptInfosToInferredProject) : false; + if (!skipAssignOrphanScriptInfosToInferredProject) { + this.printProjects(); } + return result; } - })(deleteDeclaration || (deleteDeclaration = {})); - } - }); - - // src/services/_namespaces/ts.textChanges.ts - var ts_textChanges_exports = {}; - __export(ts_textChanges_exports, { - ChangeTracker: () => ChangeTracker, - LeadingTriviaOption: () => LeadingTriviaOption, - TrailingTriviaOption: () => TrailingTriviaOption, - applyChanges: () => applyChanges, - assignPositionsToNode: () => assignPositionsToNode, - createWriter: () => createWriter, - deleteNode: () => deleteNode, - isThisTypeAnnotatable: () => isThisTypeAnnotatable, - isValidLocationToAddComment: () => isValidLocationToAddComment - }); - var init_ts_textChanges = __esm({ - "src/services/_namespaces/ts.textChanges.ts"() { - "use strict"; - init_textChanges(); - } - }); - - // src/services/formatting/formattingContext.ts - var FormattingRequestKind, FormattingContext; - var init_formattingContext = __esm({ - "src/services/formatting/formattingContext.ts"() { - "use strict"; - init_ts4(); - FormattingRequestKind = /* @__PURE__ */ ((FormattingRequestKind2) => { - FormattingRequestKind2[FormattingRequestKind2["FormatDocument"] = 0] = "FormatDocument"; - FormattingRequestKind2[FormattingRequestKind2["FormatSelection"] = 1] = "FormatSelection"; - FormattingRequestKind2[FormattingRequestKind2["FormatOnEnter"] = 2] = "FormatOnEnter"; - FormattingRequestKind2[FormattingRequestKind2["FormatOnSemicolon"] = 3] = "FormatOnSemicolon"; - FormattingRequestKind2[FormattingRequestKind2["FormatOnOpeningCurlyBrace"] = 4] = "FormatOnOpeningCurlyBrace"; - FormattingRequestKind2[FormattingRequestKind2["FormatOnClosingCurlyBrace"] = 5] = "FormatOnClosingCurlyBrace"; - return FormattingRequestKind2; - })(FormattingRequestKind || {}); - FormattingContext = class { - constructor(sourceFile, formattingRequestKind, options) { - this.sourceFile = sourceFile; - this.formattingRequestKind = formattingRequestKind; - this.options = options; + collectChanges(lastKnownProjectVersions, currentProjects, includeProjectReferenceRedirectInfo, result) { + for (const proj of currentProjects) { + const knownProject = find(lastKnownProjectVersions, (p) => p.projectName === proj.getProjectName()); + result.push(proj.getChangesSinceVersion(knownProject && knownProject.version, includeProjectReferenceRedirectInfo)); + } } - updateContext(currentRange, currentTokenParent, nextRange, nextTokenParent, commonParent) { - this.currentTokenSpan = Debug.checkDefined(currentRange); - this.currentTokenParent = Debug.checkDefined(currentTokenParent); - this.nextTokenSpan = Debug.checkDefined(nextRange); - this.nextTokenParent = Debug.checkDefined(nextTokenParent); - this.contextNode = Debug.checkDefined(commonParent); - this.contextNodeAllOnSameLine = void 0; - this.nextNodeAllOnSameLine = void 0; - this.tokensAreOnSameLine = void 0; - this.contextNodeBlockIsOnOneLine = void 0; - this.nextNodeBlockIsOnOneLine = void 0; + /** @internal */ + synchronizeProjectList(knownProjects, includeProjectReferenceRedirectInfo) { + const files = []; + this.collectChanges(knownProjects, this.externalProjects, includeProjectReferenceRedirectInfo, files); + this.collectChanges(knownProjects, this.configuredProjects.values(), includeProjectReferenceRedirectInfo, files); + this.collectChanges(knownProjects, this.inferredProjects, includeProjectReferenceRedirectInfo, files); + return files; } - ContextNodeAllOnSameLine() { - if (this.contextNodeAllOnSameLine === void 0) { - this.contextNodeAllOnSameLine = this.NodeIsOnOneLine(this.contextNode); + /** @internal */ + applyChangesInOpenFiles(openFiles, changedFiles, closedFiles) { + let openScriptInfos; + let assignOrphanScriptInfosToInferredProject = false; + if (openFiles) { + for (const file of openFiles) { + const info = this.getOrCreateOpenScriptInfo( + toNormalizedPath(file.fileName), + file.content, + tryConvertScriptKindName(file.scriptKind), + file.hasMixedContent, + file.projectRootPath ? toNormalizedPath(file.projectRootPath) : void 0 + ); + (openScriptInfos || (openScriptInfos = [])).push(info); + } } - return this.contextNodeAllOnSameLine; - } - NextNodeAllOnSameLine() { - if (this.nextNodeAllOnSameLine === void 0) { - this.nextNodeAllOnSameLine = this.NodeIsOnOneLine(this.nextTokenParent); + if (changedFiles) { + for (const file of changedFiles) { + const scriptInfo = this.getScriptInfo(file.fileName); + Debug.assert(!!scriptInfo); + this.applyChangesToFile(scriptInfo, file.changes); + } } - return this.nextNodeAllOnSameLine; - } - TokensAreOnSameLine() { - if (this.tokensAreOnSameLine === void 0) { - const startLine = this.sourceFile.getLineAndCharacterOfPosition(this.currentTokenSpan.pos).line; - const endLine = this.sourceFile.getLineAndCharacterOfPosition(this.nextTokenSpan.pos).line; - this.tokensAreOnSameLine = startLine === endLine; + if (closedFiles) { + for (const file of closedFiles) { + assignOrphanScriptInfosToInferredProject = this.closeClientFile( + file, + /*skipAssignOrphanScriptInfosToInferredProject*/ + true + ) || assignOrphanScriptInfosToInferredProject; + } } - return this.tokensAreOnSameLine; - } - ContextNodeBlockIsOnOneLine() { - if (this.contextNodeBlockIsOnOneLine === void 0) { - this.contextNodeBlockIsOnOneLine = this.BlockIsOnOneLine(this.contextNode); + let retainProjects; + if (openScriptInfos) { + retainProjects = flatMap(openScriptInfos, (info) => this.assignProjectToOpenedScriptInfo(info).retainProjects); } - return this.contextNodeBlockIsOnOneLine; - } - NextNodeBlockIsOnOneLine() { - if (this.nextNodeBlockIsOnOneLine === void 0) { - this.nextNodeBlockIsOnOneLine = this.BlockIsOnOneLine(this.nextTokenParent); + if (assignOrphanScriptInfosToInferredProject) { + this.assignOrphanScriptInfosToInferredProject(); + } + if (openScriptInfos) { + this.cleanupAfterOpeningFile(retainProjects); + openScriptInfos.forEach((info) => this.telemetryOnOpenFile(info)); + this.printProjects(); + } else if (length(closedFiles)) { + this.printProjects(); } - return this.nextNodeBlockIsOnOneLine; - } - NodeIsOnOneLine(node) { - const startLine = this.sourceFile.getLineAndCharacterOfPosition(node.getStart(this.sourceFile)).line; - const endLine = this.sourceFile.getLineAndCharacterOfPosition(node.getEnd()).line; - return startLine === endLine; } - BlockIsOnOneLine(node) { - const openBrace = findChildOfKind(node, 19 /* OpenBraceToken */, this.sourceFile); - const closeBrace = findChildOfKind(node, 20 /* CloseBraceToken */, this.sourceFile); - if (openBrace && closeBrace) { - const startLine = this.sourceFile.getLineAndCharacterOfPosition(openBrace.getEnd()).line; - const endLine = this.sourceFile.getLineAndCharacterOfPosition(closeBrace.getStart(this.sourceFile)).line; - return startLine === endLine; + /** @internal */ + applyChangesToFile(scriptInfo, changes) { + for (const change of changes) { + scriptInfo.editContent(change.span.start, change.span.start + change.span.length, change.newText); } - return false; } - }; - } - }); - - // src/services/formatting/formattingScanner.ts - function getFormattingScanner(text, languageVariant, startPos, endPos, cb) { - const scanner2 = languageVariant === 1 /* JSX */ ? jsxScanner : standardScanner; - scanner2.setText(text); - scanner2.resetTokenState(startPos); - let wasNewLine = true; - let leadingTrivia; - let trailingTrivia; - let savedPos; - let lastScanAction; - let lastTokenInfo; - const res = cb({ - advance, - readTokenInfo, - readEOFTokenRange, - isOnToken, - isOnEOF, - getCurrentLeadingTrivia: () => leadingTrivia, - lastTrailingTriviaWasNewLine: () => wasNewLine, - skipToEndOf, - skipToStartOf, - getTokenFullStart: () => (lastTokenInfo == null ? void 0 : lastTokenInfo.token.pos) ?? scanner2.getTokenStart(), - getStartPos: () => (lastTokenInfo == null ? void 0 : lastTokenInfo.token.pos) ?? scanner2.getTokenStart() - }); - lastTokenInfo = void 0; - scanner2.setText(void 0); - return res; - function advance() { - lastTokenInfo = void 0; - const isStarted = scanner2.getTokenFullStart() !== startPos; - if (isStarted) { - wasNewLine = !!trailingTrivia && last(trailingTrivia).kind === 4 /* NewLineTrivia */; - } else { - scanner2.scan(); - } - leadingTrivia = void 0; - trailingTrivia = void 0; - let pos = scanner2.getTokenFullStart(); - while (pos < endPos) { - const t = scanner2.getToken(); - if (!isTrivia(t)) { - break; + closeConfiguredProjectReferencedFromExternalProject(configFile) { + const configuredProject = this.findConfiguredProjectByProjectName(configFile); + if (configuredProject) { + configuredProject.deleteExternalProjectReference(); + if (!configuredProject.hasOpenRef()) { + this.removeProject(configuredProject); + return; + } + } } - scanner2.scan(); - const item = { - pos, - end: scanner2.getTokenFullStart(), - kind: t - }; - pos = scanner2.getTokenFullStart(); - leadingTrivia = append(leadingTrivia, item); - } - savedPos = scanner2.getTokenFullStart(); - } - function shouldRescanGreaterThanToken(node) { - switch (node.kind) { - case 34 /* GreaterThanEqualsToken */: - case 72 /* GreaterThanGreaterThanEqualsToken */: - case 73 /* GreaterThanGreaterThanGreaterThanEqualsToken */: - case 50 /* GreaterThanGreaterThanGreaterThanToken */: - case 49 /* GreaterThanGreaterThanToken */: - return true; - } - return false; - } - function shouldRescanJsxIdentifier(node) { - if (node.parent) { - switch (node.parent.kind) { - case 290 /* JsxAttribute */: - case 285 /* JsxOpeningElement */: - case 286 /* JsxClosingElement */: - case 284 /* JsxSelfClosingElement */: - return isKeyword(node.kind) || node.kind === 80 /* Identifier */; + closeExternalProject(uncheckedFileName) { + const fileName = toNormalizedPath(uncheckedFileName); + const configFiles = this.externalProjectToConfiguredProjectMap.get(fileName); + if (configFiles) { + for (const configFile of configFiles) { + this.closeConfiguredProjectReferencedFromExternalProject(configFile); + } + this.externalProjectToConfiguredProjectMap.delete(fileName); + } else { + const externalProject = this.findExternalProjectByProjectName(uncheckedFileName); + if (externalProject) { + this.removeProject(externalProject); + } + } } - } - return false; - } - function shouldRescanJsxText(node) { - return isJsxText(node) || isJsxElement(node) && (lastTokenInfo == null ? void 0 : lastTokenInfo.token.kind) === 12 /* JsxText */; - } - function shouldRescanSlashToken(container) { - return container.kind === 14 /* RegularExpressionLiteral */; - } - function shouldRescanTemplateToken(container) { - return container.kind === 17 /* TemplateMiddle */ || container.kind === 18 /* TemplateTail */; - } - function shouldRescanJsxAttributeValue(node) { - return node.parent && isJsxAttribute(node.parent) && node.parent.initializer === node; - } - function startsWithSlashToken(t) { - return t === 44 /* SlashToken */ || t === 69 /* SlashEqualsToken */; - } - function readTokenInfo(n) { - Debug.assert(isOnToken()); - const expectedScanAction = shouldRescanGreaterThanToken(n) ? 1 /* RescanGreaterThanToken */ : shouldRescanSlashToken(n) ? 2 /* RescanSlashToken */ : shouldRescanTemplateToken(n) ? 3 /* RescanTemplateToken */ : shouldRescanJsxIdentifier(n) ? 4 /* RescanJsxIdentifier */ : shouldRescanJsxText(n) ? 5 /* RescanJsxText */ : shouldRescanJsxAttributeValue(n) ? 6 /* RescanJsxAttributeValue */ : 0 /* Scan */; - if (lastTokenInfo && expectedScanAction === lastScanAction) { - return fixTokenKind(lastTokenInfo, n); - } - if (scanner2.getTokenFullStart() !== savedPos) { - Debug.assert(lastTokenInfo !== void 0); - scanner2.resetTokenState(savedPos); - scanner2.scan(); - } - let currentToken = getNextToken(n, expectedScanAction); - const token = createTextRangeWithKind( - scanner2.getTokenFullStart(), - scanner2.getTokenEnd(), - currentToken - ); - if (trailingTrivia) { - trailingTrivia = void 0; - } - while (scanner2.getTokenFullStart() < endPos) { - currentToken = scanner2.scan(); - if (!isTrivia(currentToken)) { - break; + openExternalProjects(projects) { + const projectsToClose = arrayToMap(this.externalProjects, (p) => p.getProjectName(), (_) => true); + forEachKey(this.externalProjectToConfiguredProjectMap, (externalProjectName) => { + projectsToClose.set(externalProjectName, true); + }); + for (const externalProject of projects) { + this.openExternalProject(externalProject); + projectsToClose.delete(externalProject.projectFileName); + } + forEachKey(projectsToClose, (externalProjectName) => { + this.closeExternalProject(externalProjectName); + }); } - const trivia = createTextRangeWithKind( - scanner2.getTokenFullStart(), - scanner2.getTokenEnd(), - currentToken - ); - if (!trailingTrivia) { - trailingTrivia = []; + static escapeFilenameForRegex(filename) { + return filename.replace(this.filenameEscapeRegexp, "\\$&"); } - trailingTrivia.push(trivia); - if (currentToken === 4 /* NewLineTrivia */) { - scanner2.scan(); - break; + resetSafeList() { + this.safelist = defaultTypeSafeList; } - } - lastTokenInfo = { leadingTrivia, trailingTrivia, token }; - return fixTokenKind(lastTokenInfo, n); - } - function getNextToken(n, expectedScanAction) { - const token = scanner2.getToken(); - lastScanAction = 0 /* Scan */; - switch (expectedScanAction) { - case 1 /* RescanGreaterThanToken */: - if (token === 32 /* GreaterThanToken */) { - lastScanAction = 1 /* RescanGreaterThanToken */; - const newToken = scanner2.reScanGreaterToken(); - Debug.assert(n.kind === newToken); - return newToken; + applySafeList(proj) { + const { rootFiles } = proj; + const typeAcquisition = proj.typeAcquisition; + Debug.assert(!!typeAcquisition, "proj.typeAcquisition should be set by now"); + if (typeAcquisition.enable === false || typeAcquisition.disableFilenameBasedTypeAcquisition) { + return []; } - break; - case 2 /* RescanSlashToken */: - if (startsWithSlashToken(token)) { - lastScanAction = 2 /* RescanSlashToken */; - const newToken = scanner2.reScanSlashToken(); - Debug.assert(n.kind === newToken); - return newToken; + const typeAcqInclude = typeAcquisition.include || (typeAcquisition.include = []); + const excludeRules = []; + const normalizedNames = rootFiles.map((f) => normalizeSlashes(f.fileName)); + const excludedFiles = []; + for (const name of Object.keys(this.safelist)) { + const rule2 = this.safelist[name]; + for (const root of normalizedNames) { + if (rule2.match.test(root)) { + this.logger.info(`Excluding files based on rule ${name} matching file '${root}'`); + if (rule2.types) { + for (const type of rule2.types) { + if (!typeAcqInclude.includes(type)) { + typeAcqInclude.push(type); + } + } + } + if (rule2.exclude) { + for (const exclude of rule2.exclude) { + const processedRule = root.replace(rule2.match, (...groups) => { + return exclude.map((groupNumberOrString) => { + if (typeof groupNumberOrString === "number") { + if (!isString(groups[groupNumberOrString])) { + this.logger.info(`Incorrect RegExp specification in safelist rule ${name} - not enough groups`); + return "\\*"; + } + return _ProjectService.escapeFilenameForRegex(groups[groupNumberOrString]); + } + return groupNumberOrString; + }).join(""); + }); + if (!excludeRules.includes(processedRule)) { + excludeRules.push(processedRule); + } + } + } else { + const escaped = _ProjectService.escapeFilenameForRegex(root); + if (!excludeRules.includes(escaped)) { + excludeRules.push(escaped); + } + } + } + } } - break; - case 3 /* RescanTemplateToken */: - if (token === 20 /* CloseBraceToken */) { - lastScanAction = 3 /* RescanTemplateToken */; - return scanner2.reScanTemplateToken( - /*isTaggedTemplate*/ - false - ); + const excludeRegexes = excludeRules.map((e) => new RegExp(e, "i")); + const filesToKeep = []; + for (let i = 0; i < proj.rootFiles.length; i++) { + if (excludeRegexes.some((re) => re.test(normalizedNames[i]))) { + excludedFiles.push(normalizedNames[i]); + } else { + let exclude = false; + if (typeAcquisition.enable) { + const baseName = getBaseFileName(toFileNameLowerCase(normalizedNames[i])); + if (fileExtensionIs(baseName, "js")) { + const inferredTypingName = removeFileExtension(baseName); + const cleanedTypingName = removeMinAndVersionNumbers(inferredTypingName); + const typeName = this.legacySafelist.get(cleanedTypingName); + if (typeName !== void 0) { + this.logger.info(`Excluded '${normalizedNames[i]}' because it matched ${cleanedTypingName} from the legacy safelist`); + excludedFiles.push(normalizedNames[i]); + exclude = true; + if (!typeAcqInclude.includes(typeName)) { + typeAcqInclude.push(typeName); + } + } + } + } + if (!exclude) { + if (/^.+[.-]min\.js$/.test(normalizedNames[i])) { + excludedFiles.push(normalizedNames[i]); + } else { + filesToKeep.push(proj.rootFiles[i]); + } + } + } } - break; - case 4 /* RescanJsxIdentifier */: - lastScanAction = 4 /* RescanJsxIdentifier */; - return scanner2.scanJsxIdentifier(); - case 5 /* RescanJsxText */: - lastScanAction = 5 /* RescanJsxText */; - return scanner2.reScanJsxToken( - /*allowMultilineJsxText*/ - false - ); - case 6 /* RescanJsxAttributeValue */: - lastScanAction = 6 /* RescanJsxAttributeValue */; - return scanner2.reScanJsxAttributeValue(); - case 0 /* Scan */: - break; - default: - Debug.assertNever(expectedScanAction); - } - return token; - } - function readEOFTokenRange() { - Debug.assert(isOnEOF()); - return createTextRangeWithKind(scanner2.getTokenFullStart(), scanner2.getTokenEnd(), 1 /* EndOfFileToken */); - } - function isOnToken() { - const current = lastTokenInfo ? lastTokenInfo.token.kind : scanner2.getToken(); - return current !== 1 /* EndOfFileToken */ && !isTrivia(current); - } - function isOnEOF() { - const current = lastTokenInfo ? lastTokenInfo.token.kind : scanner2.getToken(); - return current === 1 /* EndOfFileToken */; - } - function fixTokenKind(tokenInfo, container) { - if (isToken(container) && tokenInfo.token.kind !== container.kind) { - tokenInfo.token.kind = container.kind; - } - return tokenInfo; - } - function skipToEndOf(node) { - scanner2.resetTokenState(node.end); - savedPos = scanner2.getTokenFullStart(); - lastScanAction = void 0; - lastTokenInfo = void 0; - wasNewLine = false; - leadingTrivia = void 0; - trailingTrivia = void 0; - } - function skipToStartOf(node) { - scanner2.resetTokenState(node.pos); - savedPos = scanner2.getTokenFullStart(); - lastScanAction = void 0; - lastTokenInfo = void 0; - wasNewLine = false; - leadingTrivia = void 0; - trailingTrivia = void 0; - } - } - var standardScanner, jsxScanner; - var init_formattingScanner = __esm({ - "src/services/formatting/formattingScanner.ts"() { - "use strict"; - init_ts4(); - init_ts_formatting(); - standardScanner = createScanner( - 99 /* Latest */, - /*skipTrivia*/ - false, - 0 /* Standard */ - ); - jsxScanner = createScanner( - 99 /* Latest */, - /*skipTrivia*/ - false, - 1 /* JSX */ - ); - } - }); - - // src/services/formatting/rule.ts - var anyContext, RuleAction, RuleFlags; - var init_rule = __esm({ - "src/services/formatting/rule.ts"() { - "use strict"; - init_ts4(); - anyContext = emptyArray; - RuleAction = /* @__PURE__ */ ((RuleAction2) => { - RuleAction2[RuleAction2["None"] = 0] = "None"; - RuleAction2[RuleAction2["StopProcessingSpaceActions"] = 1] = "StopProcessingSpaceActions"; - RuleAction2[RuleAction2["StopProcessingTokenActions"] = 2] = "StopProcessingTokenActions"; - RuleAction2[RuleAction2["InsertSpace"] = 4] = "InsertSpace"; - RuleAction2[RuleAction2["InsertNewLine"] = 8] = "InsertNewLine"; - RuleAction2[RuleAction2["DeleteSpace"] = 16] = "DeleteSpace"; - RuleAction2[RuleAction2["DeleteToken"] = 32] = "DeleteToken"; - RuleAction2[RuleAction2["InsertTrailingSemicolon"] = 64] = "InsertTrailingSemicolon"; - RuleAction2[RuleAction2["StopAction"] = 3] = "StopAction"; - RuleAction2[RuleAction2["ModifySpaceAction"] = 28] = "ModifySpaceAction"; - RuleAction2[RuleAction2["ModifyTokenAction"] = 96] = "ModifyTokenAction"; - return RuleAction2; - })(RuleAction || {}); - RuleFlags = /* @__PURE__ */ ((RuleFlags2) => { - RuleFlags2[RuleFlags2["None"] = 0] = "None"; - RuleFlags2[RuleFlags2["CanDeleteNewLines"] = 1] = "CanDeleteNewLines"; - return RuleFlags2; - })(RuleFlags || {}); - } - }); - - // src/services/formatting/rules.ts - function getAllRules() { - const allTokens = []; - for (let token = 0 /* FirstToken */; token <= 164 /* LastToken */; token++) { - if (token !== 1 /* EndOfFileToken */) { - allTokens.push(token); - } - } - function anyTokenExcept(...tokens) { - return { tokens: allTokens.filter((t) => !tokens.some((t2) => t2 === t)), isSpecific: false }; - } - const anyToken = { tokens: allTokens, isSpecific: false }; - const anyTokenIncludingMultilineComments = tokenRangeFrom([...allTokens, 3 /* MultiLineCommentTrivia */]); - const anyTokenIncludingEOF = tokenRangeFrom([...allTokens, 1 /* EndOfFileToken */]); - const keywords = tokenRangeFromRange(83 /* FirstKeyword */, 164 /* LastKeyword */); - const binaryOperators = tokenRangeFromRange(30 /* FirstBinaryOperator */, 79 /* LastBinaryOperator */); - const binaryKeywordOperators = [ - 103 /* InKeyword */, - 104 /* InstanceOfKeyword */, - 164 /* OfKeyword */, - 130 /* AsKeyword */, - 142 /* IsKeyword */, - 152 /* SatisfiesKeyword */ - ]; - const unaryPrefixOperators = [46 /* PlusPlusToken */, 47 /* MinusMinusToken */, 55 /* TildeToken */, 54 /* ExclamationToken */]; - const unaryPrefixExpressions = [ - 9 /* NumericLiteral */, - 10 /* BigIntLiteral */, - 80 /* Identifier */, - 21 /* OpenParenToken */, - 23 /* OpenBracketToken */, - 19 /* OpenBraceToken */, - 110 /* ThisKeyword */, - 105 /* NewKeyword */ - ]; - const unaryPreincrementExpressions = [80 /* Identifier */, 21 /* OpenParenToken */, 110 /* ThisKeyword */, 105 /* NewKeyword */]; - const unaryPostincrementExpressions = [80 /* Identifier */, 22 /* CloseParenToken */, 24 /* CloseBracketToken */, 105 /* NewKeyword */]; - const unaryPredecrementExpressions = [80 /* Identifier */, 21 /* OpenParenToken */, 110 /* ThisKeyword */, 105 /* NewKeyword */]; - const unaryPostdecrementExpressions = [80 /* Identifier */, 22 /* CloseParenToken */, 24 /* CloseBracketToken */, 105 /* NewKeyword */]; - const comments = [2 /* SingleLineCommentTrivia */, 3 /* MultiLineCommentTrivia */]; - const typeNames = [80 /* Identifier */, ...typeKeywords]; - const functionOpenBraceLeftTokenRange = anyTokenIncludingMultilineComments; - const typeScriptOpenBraceLeftTokenRange = tokenRangeFrom([80 /* Identifier */, 3 /* MultiLineCommentTrivia */, 86 /* ClassKeyword */, 95 /* ExportKeyword */, 102 /* ImportKeyword */]); - const controlOpenBraceLeftTokenRange = tokenRangeFrom([22 /* CloseParenToken */, 3 /* MultiLineCommentTrivia */, 92 /* DoKeyword */, 113 /* TryKeyword */, 98 /* FinallyKeyword */, 93 /* ElseKeyword */]); - const highPriorityCommonRules = [ - // Leave comments alone - rule("IgnoreBeforeComment", anyToken, comments, anyContext, 1 /* StopProcessingSpaceActions */), - rule("IgnoreAfterLineComment", 2 /* SingleLineCommentTrivia */, anyToken, anyContext, 1 /* StopProcessingSpaceActions */), - rule("NotSpaceBeforeColon", anyToken, 59 /* ColonToken */, [isNonJsxSameLineTokenContext, isNotBinaryOpContext, isNotTypeAnnotationContext], 16 /* DeleteSpace */), - rule("SpaceAfterColon", 59 /* ColonToken */, anyToken, [isNonJsxSameLineTokenContext, isNotBinaryOpContext], 4 /* InsertSpace */), - rule("NoSpaceBeforeQuestionMark", anyToken, 58 /* QuestionToken */, [isNonJsxSameLineTokenContext, isNotBinaryOpContext, isNotTypeAnnotationContext], 16 /* DeleteSpace */), - // insert space after '?' only when it is used in conditional operator - rule("SpaceAfterQuestionMarkInConditionalOperator", 58 /* QuestionToken */, anyToken, [isNonJsxSameLineTokenContext, isConditionalOperatorContext], 4 /* InsertSpace */), - // in other cases there should be no space between '?' and next token - rule("NoSpaceAfterQuestionMark", 58 /* QuestionToken */, anyToken, [isNonJsxSameLineTokenContext], 16 /* DeleteSpace */), - rule("NoSpaceBeforeDot", anyToken, [25 /* DotToken */, 29 /* QuestionDotToken */], [isNonJsxSameLineTokenContext, isNotPropertyAccessOnIntegerLiteral], 16 /* DeleteSpace */), - rule("NoSpaceAfterDot", [25 /* DotToken */, 29 /* QuestionDotToken */], anyToken, [isNonJsxSameLineTokenContext], 16 /* DeleteSpace */), - rule("NoSpaceBetweenImportParenInImportType", 102 /* ImportKeyword */, 21 /* OpenParenToken */, [isNonJsxSameLineTokenContext, isImportTypeContext], 16 /* DeleteSpace */), - // Special handling of unary operators. - // Prefix operators generally shouldn't have a space between - // them and their target unary expression. - rule("NoSpaceAfterUnaryPrefixOperator", unaryPrefixOperators, unaryPrefixExpressions, [isNonJsxSameLineTokenContext, isNotBinaryOpContext], 16 /* DeleteSpace */), - rule("NoSpaceAfterUnaryPreincrementOperator", 46 /* PlusPlusToken */, unaryPreincrementExpressions, [isNonJsxSameLineTokenContext], 16 /* DeleteSpace */), - rule("NoSpaceAfterUnaryPredecrementOperator", 47 /* MinusMinusToken */, unaryPredecrementExpressions, [isNonJsxSameLineTokenContext], 16 /* DeleteSpace */), - rule("NoSpaceBeforeUnaryPostincrementOperator", unaryPostincrementExpressions, 46 /* PlusPlusToken */, [isNonJsxSameLineTokenContext, isNotStatementConditionContext], 16 /* DeleteSpace */), - rule("NoSpaceBeforeUnaryPostdecrementOperator", unaryPostdecrementExpressions, 47 /* MinusMinusToken */, [isNonJsxSameLineTokenContext, isNotStatementConditionContext], 16 /* DeleteSpace */), - // More unary operator special-casing. - // DevDiv 181814: Be careful when removing leading whitespace - // around unary operators. Examples: - // 1 - -2 --X--> 1--2 - // a + ++b --X--> a+++b - rule("SpaceAfterPostincrementWhenFollowedByAdd", 46 /* PlusPlusToken */, 40 /* PlusToken */, [isNonJsxSameLineTokenContext, isBinaryOpContext], 4 /* InsertSpace */), - rule("SpaceAfterAddWhenFollowedByUnaryPlus", 40 /* PlusToken */, 40 /* PlusToken */, [isNonJsxSameLineTokenContext, isBinaryOpContext], 4 /* InsertSpace */), - rule("SpaceAfterAddWhenFollowedByPreincrement", 40 /* PlusToken */, 46 /* PlusPlusToken */, [isNonJsxSameLineTokenContext, isBinaryOpContext], 4 /* InsertSpace */), - rule("SpaceAfterPostdecrementWhenFollowedBySubtract", 47 /* MinusMinusToken */, 41 /* MinusToken */, [isNonJsxSameLineTokenContext, isBinaryOpContext], 4 /* InsertSpace */), - rule("SpaceAfterSubtractWhenFollowedByUnaryMinus", 41 /* MinusToken */, 41 /* MinusToken */, [isNonJsxSameLineTokenContext, isBinaryOpContext], 4 /* InsertSpace */), - rule("SpaceAfterSubtractWhenFollowedByPredecrement", 41 /* MinusToken */, 47 /* MinusMinusToken */, [isNonJsxSameLineTokenContext, isBinaryOpContext], 4 /* InsertSpace */), - rule("NoSpaceAfterCloseBrace", 20 /* CloseBraceToken */, [28 /* CommaToken */, 27 /* SemicolonToken */], [isNonJsxSameLineTokenContext], 16 /* DeleteSpace */), - // For functions and control block place } on a new line [multi-line rule] - rule("NewLineBeforeCloseBraceInBlockContext", anyTokenIncludingMultilineComments, 20 /* CloseBraceToken */, [isMultilineBlockContext], 8 /* InsertNewLine */), - // Space/new line after }. - rule("SpaceAfterCloseBrace", 20 /* CloseBraceToken */, anyTokenExcept(22 /* CloseParenToken */), [isNonJsxSameLineTokenContext, isAfterCodeBlockContext], 4 /* InsertSpace */), - // Special case for (}, else) and (}, while) since else & while tokens are not part of the tree which makes SpaceAfterCloseBrace rule not applied - // Also should not apply to }) - rule("SpaceBetweenCloseBraceAndElse", 20 /* CloseBraceToken */, 93 /* ElseKeyword */, [isNonJsxSameLineTokenContext], 4 /* InsertSpace */), - rule("SpaceBetweenCloseBraceAndWhile", 20 /* CloseBraceToken */, 117 /* WhileKeyword */, [isNonJsxSameLineTokenContext], 4 /* InsertSpace */), - rule("NoSpaceBetweenEmptyBraceBrackets", 19 /* OpenBraceToken */, 20 /* CloseBraceToken */, [isNonJsxSameLineTokenContext, isObjectContext], 16 /* DeleteSpace */), - // Add a space after control dec context if the next character is an open bracket ex: 'if (false)[a, b] = [1, 2];' -> 'if (false) [a, b] = [1, 2];' - rule("SpaceAfterConditionalClosingParen", 22 /* CloseParenToken */, 23 /* OpenBracketToken */, [isControlDeclContext], 4 /* InsertSpace */), - rule("NoSpaceBetweenFunctionKeywordAndStar", 100 /* FunctionKeyword */, 42 /* AsteriskToken */, [isFunctionDeclarationOrFunctionExpressionContext], 16 /* DeleteSpace */), - rule("SpaceAfterStarInGeneratorDeclaration", 42 /* AsteriskToken */, 80 /* Identifier */, [isFunctionDeclarationOrFunctionExpressionContext], 4 /* InsertSpace */), - rule("SpaceAfterFunctionInFuncDecl", 100 /* FunctionKeyword */, anyToken, [isFunctionDeclContext], 4 /* InsertSpace */), - // Insert new line after { and before } in multi-line contexts. - rule("NewLineAfterOpenBraceInBlockContext", 19 /* OpenBraceToken */, anyToken, [isMultilineBlockContext], 8 /* InsertNewLine */), - // For get/set members, we check for (identifier,identifier) since get/set don't have tokens and they are represented as just an identifier token. - // Though, we do extra check on the context to make sure we are dealing with get/set node. Example: - // get x() {} - // set x(val) {} - rule("SpaceAfterGetSetInMember", [139 /* GetKeyword */, 153 /* SetKeyword */], 80 /* Identifier */, [isFunctionDeclContext], 4 /* InsertSpace */), - rule("NoSpaceBetweenYieldKeywordAndStar", 127 /* YieldKeyword */, 42 /* AsteriskToken */, [isNonJsxSameLineTokenContext, isYieldOrYieldStarWithOperand], 16 /* DeleteSpace */), - rule("SpaceBetweenYieldOrYieldStarAndOperand", [127 /* YieldKeyword */, 42 /* AsteriskToken */], anyToken, [isNonJsxSameLineTokenContext, isYieldOrYieldStarWithOperand], 4 /* InsertSpace */), - rule("NoSpaceBetweenReturnAndSemicolon", 107 /* ReturnKeyword */, 27 /* SemicolonToken */, [isNonJsxSameLineTokenContext], 16 /* DeleteSpace */), - rule("SpaceAfterCertainKeywords", [115 /* VarKeyword */, 111 /* ThrowKeyword */, 105 /* NewKeyword */, 91 /* DeleteKeyword */, 107 /* ReturnKeyword */, 114 /* TypeOfKeyword */, 135 /* AwaitKeyword */], anyToken, [isNonJsxSameLineTokenContext], 4 /* InsertSpace */), - rule("SpaceAfterLetConstInVariableDeclaration", [121 /* LetKeyword */, 87 /* ConstKeyword */], anyToken, [isNonJsxSameLineTokenContext, isStartOfVariableDeclarationList], 4 /* InsertSpace */), - rule("NoSpaceBeforeOpenParenInFuncCall", anyToken, 21 /* OpenParenToken */, [isNonJsxSameLineTokenContext, isFunctionCallOrNewContext, isPreviousTokenNotComma], 16 /* DeleteSpace */), - // Special case for binary operators (that are keywords). For these we have to add a space and shouldn't follow any user options. - rule("SpaceBeforeBinaryKeywordOperator", anyToken, binaryKeywordOperators, [isNonJsxSameLineTokenContext, isBinaryOpContext], 4 /* InsertSpace */), - rule("SpaceAfterBinaryKeywordOperator", binaryKeywordOperators, anyToken, [isNonJsxSameLineTokenContext, isBinaryOpContext], 4 /* InsertSpace */), - rule("SpaceAfterVoidOperator", 116 /* VoidKeyword */, anyToken, [isNonJsxSameLineTokenContext, isVoidOpContext], 4 /* InsertSpace */), - // Async-await - rule("SpaceBetweenAsyncAndOpenParen", 134 /* AsyncKeyword */, 21 /* OpenParenToken */, [isArrowFunctionContext, isNonJsxSameLineTokenContext], 4 /* InsertSpace */), - rule("SpaceBetweenAsyncAndFunctionKeyword", 134 /* AsyncKeyword */, [100 /* FunctionKeyword */, 80 /* Identifier */], [isNonJsxSameLineTokenContext], 4 /* InsertSpace */), - // Template string - rule("NoSpaceBetweenTagAndTemplateString", [80 /* Identifier */, 22 /* CloseParenToken */], [15 /* NoSubstitutionTemplateLiteral */, 16 /* TemplateHead */], [isNonJsxSameLineTokenContext], 16 /* DeleteSpace */), - // JSX opening elements - rule("SpaceBeforeJsxAttribute", anyToken, 80 /* Identifier */, [isNextTokenParentJsxAttribute, isNonJsxSameLineTokenContext], 4 /* InsertSpace */), - rule("SpaceBeforeSlashInJsxOpeningElement", anyToken, 44 /* SlashToken */, [isJsxSelfClosingElementContext, isNonJsxSameLineTokenContext], 4 /* InsertSpace */), - rule("NoSpaceBeforeGreaterThanTokenInJsxOpeningElement", 44 /* SlashToken */, 32 /* GreaterThanToken */, [isJsxSelfClosingElementContext, isNonJsxSameLineTokenContext], 16 /* DeleteSpace */), - rule("NoSpaceBeforeEqualInJsxAttribute", anyToken, 64 /* EqualsToken */, [isJsxAttributeContext, isNonJsxSameLineTokenContext], 16 /* DeleteSpace */), - rule("NoSpaceAfterEqualInJsxAttribute", 64 /* EqualsToken */, anyToken, [isJsxAttributeContext, isNonJsxSameLineTokenContext], 16 /* DeleteSpace */), - // TypeScript-specific rules - // Use of module as a function call. e.g.: import m2 = module("m2"); - rule("NoSpaceAfterModuleImport", [144 /* ModuleKeyword */, 149 /* RequireKeyword */], 21 /* OpenParenToken */, [isNonJsxSameLineTokenContext], 16 /* DeleteSpace */), - // Add a space around certain TypeScript keywords - rule( - "SpaceAfterCertainTypeScriptKeywords", - [ - 128 /* AbstractKeyword */, - 129 /* AccessorKeyword */, - 86 /* ClassKeyword */, - 138 /* DeclareKeyword */, - 90 /* DefaultKeyword */, - 94 /* EnumKeyword */, - 95 /* ExportKeyword */, - 96 /* ExtendsKeyword */, - 139 /* GetKeyword */, - 119 /* ImplementsKeyword */, - 102 /* ImportKeyword */, - 120 /* InterfaceKeyword */, - 144 /* ModuleKeyword */, - 145 /* NamespaceKeyword */, - 123 /* PrivateKeyword */, - 125 /* PublicKeyword */, - 124 /* ProtectedKeyword */, - 148 /* ReadonlyKeyword */, - 153 /* SetKeyword */, - 126 /* StaticKeyword */, - 156 /* TypeKeyword */, - 160 /* FromKeyword */, - 143 /* KeyOfKeyword */, - 140 /* InferKeyword */ - ], - anyToken, - [isNonJsxSameLineTokenContext], - 4 /* InsertSpace */ - ), - rule( - "SpaceBeforeCertainTypeScriptKeywords", - anyToken, - [96 /* ExtendsKeyword */, 119 /* ImplementsKeyword */, 160 /* FromKeyword */], - [isNonJsxSameLineTokenContext], - 4 /* InsertSpace */ - ), - // Treat string literals in module names as identifiers, and add a space between the literal and the opening Brace braces, e.g.: module "m2" { - rule("SpaceAfterModuleName", 11 /* StringLiteral */, 19 /* OpenBraceToken */, [isModuleDeclContext], 4 /* InsertSpace */), - // Lambda expressions - rule("SpaceBeforeArrow", anyToken, 39 /* EqualsGreaterThanToken */, [isNonJsxSameLineTokenContext], 4 /* InsertSpace */), - rule("SpaceAfterArrow", 39 /* EqualsGreaterThanToken */, anyToken, [isNonJsxSameLineTokenContext], 4 /* InsertSpace */), - // Optional parameters and let args - rule("NoSpaceAfterEllipsis", 26 /* DotDotDotToken */, 80 /* Identifier */, [isNonJsxSameLineTokenContext], 16 /* DeleteSpace */), - rule("NoSpaceAfterOptionalParameters", 58 /* QuestionToken */, [22 /* CloseParenToken */, 28 /* CommaToken */], [isNonJsxSameLineTokenContext, isNotBinaryOpContext], 16 /* DeleteSpace */), - // Remove spaces in empty interface literals. e.g.: x: {} - rule("NoSpaceBetweenEmptyInterfaceBraceBrackets", 19 /* OpenBraceToken */, 20 /* CloseBraceToken */, [isNonJsxSameLineTokenContext, isObjectTypeContext], 16 /* DeleteSpace */), - // generics and type assertions - rule("NoSpaceBeforeOpenAngularBracket", typeNames, 30 /* LessThanToken */, [isNonJsxSameLineTokenContext, isTypeArgumentOrParameterOrAssertionContext], 16 /* DeleteSpace */), - rule("NoSpaceBetweenCloseParenAndAngularBracket", 22 /* CloseParenToken */, 30 /* LessThanToken */, [isNonJsxSameLineTokenContext, isTypeArgumentOrParameterOrAssertionContext], 16 /* DeleteSpace */), - rule("NoSpaceAfterOpenAngularBracket", 30 /* LessThanToken */, anyToken, [isNonJsxSameLineTokenContext, isTypeArgumentOrParameterOrAssertionContext], 16 /* DeleteSpace */), - rule("NoSpaceBeforeCloseAngularBracket", anyToken, 32 /* GreaterThanToken */, [isNonJsxSameLineTokenContext, isTypeArgumentOrParameterOrAssertionContext], 16 /* DeleteSpace */), - rule("NoSpaceAfterCloseAngularBracket", 32 /* GreaterThanToken */, [21 /* OpenParenToken */, 23 /* OpenBracketToken */, 32 /* GreaterThanToken */, 28 /* CommaToken */], [ - isNonJsxSameLineTokenContext, - isTypeArgumentOrParameterOrAssertionContext, - isNotFunctionDeclContext, - isNonTypeAssertionContext - ], 16 /* DeleteSpace */), - // decorators - rule("SpaceBeforeAt", [22 /* CloseParenToken */, 80 /* Identifier */], 60 /* AtToken */, [isNonJsxSameLineTokenContext], 4 /* InsertSpace */), - rule("NoSpaceAfterAt", 60 /* AtToken */, anyToken, [isNonJsxSameLineTokenContext], 16 /* DeleteSpace */), - // Insert space after @ in decorator - rule( - "SpaceAfterDecorator", - anyToken, - [ - 128 /* AbstractKeyword */, - 80 /* Identifier */, - 95 /* ExportKeyword */, - 90 /* DefaultKeyword */, - 86 /* ClassKeyword */, - 126 /* StaticKeyword */, - 125 /* PublicKeyword */, - 123 /* PrivateKeyword */, - 124 /* ProtectedKeyword */, - 139 /* GetKeyword */, - 153 /* SetKeyword */, - 23 /* OpenBracketToken */, - 42 /* AsteriskToken */ - ], - [isEndOfDecoratorContextOnSameLine], - 4 /* InsertSpace */ - ), - rule("NoSpaceBeforeNonNullAssertionOperator", anyToken, 54 /* ExclamationToken */, [isNonJsxSameLineTokenContext, isNonNullAssertionContext], 16 /* DeleteSpace */), - rule("NoSpaceAfterNewKeywordOnConstructorSignature", 105 /* NewKeyword */, 21 /* OpenParenToken */, [isNonJsxSameLineTokenContext, isConstructorSignatureContext], 16 /* DeleteSpace */), - rule("SpaceLessThanAndNonJSXTypeAnnotation", 30 /* LessThanToken */, 30 /* LessThanToken */, [isNonJsxSameLineTokenContext], 4 /* InsertSpace */) - ]; - const userConfigurableRules = [ - // Treat constructor as an identifier in a function declaration, and remove spaces between constructor and following left parentheses - rule("SpaceAfterConstructor", 137 /* ConstructorKeyword */, 21 /* OpenParenToken */, [isOptionEnabled("insertSpaceAfterConstructor"), isNonJsxSameLineTokenContext], 4 /* InsertSpace */), - rule("NoSpaceAfterConstructor", 137 /* ConstructorKeyword */, 21 /* OpenParenToken */, [isOptionDisabledOrUndefined("insertSpaceAfterConstructor"), isNonJsxSameLineTokenContext], 16 /* DeleteSpace */), - rule("SpaceAfterComma", 28 /* CommaToken */, anyToken, [isOptionEnabled("insertSpaceAfterCommaDelimiter"), isNonJsxSameLineTokenContext, isNonJsxElementOrFragmentContext, isNextTokenNotCloseBracket, isNextTokenNotCloseParen], 4 /* InsertSpace */), - rule("NoSpaceAfterComma", 28 /* CommaToken */, anyToken, [isOptionDisabledOrUndefined("insertSpaceAfterCommaDelimiter"), isNonJsxSameLineTokenContext, isNonJsxElementOrFragmentContext], 16 /* DeleteSpace */), - // Insert space after function keyword for anonymous functions - rule("SpaceAfterAnonymousFunctionKeyword", [100 /* FunctionKeyword */, 42 /* AsteriskToken */], 21 /* OpenParenToken */, [isOptionEnabled("insertSpaceAfterFunctionKeywordForAnonymousFunctions"), isFunctionDeclContext], 4 /* InsertSpace */), - rule("NoSpaceAfterAnonymousFunctionKeyword", [100 /* FunctionKeyword */, 42 /* AsteriskToken */], 21 /* OpenParenToken */, [isOptionDisabledOrUndefined("insertSpaceAfterFunctionKeywordForAnonymousFunctions"), isFunctionDeclContext], 16 /* DeleteSpace */), - // Insert space after keywords in control flow statements - rule("SpaceAfterKeywordInControl", keywords, 21 /* OpenParenToken */, [isOptionEnabled("insertSpaceAfterKeywordsInControlFlowStatements"), isControlDeclContext], 4 /* InsertSpace */), - rule("NoSpaceAfterKeywordInControl", keywords, 21 /* OpenParenToken */, [isOptionDisabledOrUndefined("insertSpaceAfterKeywordsInControlFlowStatements"), isControlDeclContext], 16 /* DeleteSpace */), - // Insert space after opening and before closing nonempty parenthesis - rule("SpaceAfterOpenParen", 21 /* OpenParenToken */, anyToken, [isOptionEnabled("insertSpaceAfterOpeningAndBeforeClosingNonemptyParenthesis"), isNonJsxSameLineTokenContext], 4 /* InsertSpace */), - rule("SpaceBeforeCloseParen", anyToken, 22 /* CloseParenToken */, [isOptionEnabled("insertSpaceAfterOpeningAndBeforeClosingNonemptyParenthesis"), isNonJsxSameLineTokenContext], 4 /* InsertSpace */), - rule("SpaceBetweenOpenParens", 21 /* OpenParenToken */, 21 /* OpenParenToken */, [isOptionEnabled("insertSpaceAfterOpeningAndBeforeClosingNonemptyParenthesis"), isNonJsxSameLineTokenContext], 4 /* InsertSpace */), - rule("NoSpaceBetweenParens", 21 /* OpenParenToken */, 22 /* CloseParenToken */, [isNonJsxSameLineTokenContext], 16 /* DeleteSpace */), - rule("NoSpaceAfterOpenParen", 21 /* OpenParenToken */, anyToken, [isOptionDisabledOrUndefined("insertSpaceAfterOpeningAndBeforeClosingNonemptyParenthesis"), isNonJsxSameLineTokenContext], 16 /* DeleteSpace */), - rule("NoSpaceBeforeCloseParen", anyToken, 22 /* CloseParenToken */, [isOptionDisabledOrUndefined("insertSpaceAfterOpeningAndBeforeClosingNonemptyParenthesis"), isNonJsxSameLineTokenContext], 16 /* DeleteSpace */), - // Insert space after opening and before closing nonempty brackets - rule("SpaceAfterOpenBracket", 23 /* OpenBracketToken */, anyToken, [isOptionEnabled("insertSpaceAfterOpeningAndBeforeClosingNonemptyBrackets"), isNonJsxSameLineTokenContext], 4 /* InsertSpace */), - rule("SpaceBeforeCloseBracket", anyToken, 24 /* CloseBracketToken */, [isOptionEnabled("insertSpaceAfterOpeningAndBeforeClosingNonemptyBrackets"), isNonJsxSameLineTokenContext], 4 /* InsertSpace */), - rule("NoSpaceBetweenBrackets", 23 /* OpenBracketToken */, 24 /* CloseBracketToken */, [isNonJsxSameLineTokenContext], 16 /* DeleteSpace */), - rule("NoSpaceAfterOpenBracket", 23 /* OpenBracketToken */, anyToken, [isOptionDisabledOrUndefined("insertSpaceAfterOpeningAndBeforeClosingNonemptyBrackets"), isNonJsxSameLineTokenContext], 16 /* DeleteSpace */), - rule("NoSpaceBeforeCloseBracket", anyToken, 24 /* CloseBracketToken */, [isOptionDisabledOrUndefined("insertSpaceAfterOpeningAndBeforeClosingNonemptyBrackets"), isNonJsxSameLineTokenContext], 16 /* DeleteSpace */), - // Insert a space after { and before } in single-line contexts, but remove space from empty object literals {}. - rule("SpaceAfterOpenBrace", 19 /* OpenBraceToken */, anyToken, [isOptionEnabledOrUndefined("insertSpaceAfterOpeningAndBeforeClosingNonemptyBraces"), isBraceWrappedContext], 4 /* InsertSpace */), - rule("SpaceBeforeCloseBrace", anyToken, 20 /* CloseBraceToken */, [isOptionEnabledOrUndefined("insertSpaceAfterOpeningAndBeforeClosingNonemptyBraces"), isBraceWrappedContext], 4 /* InsertSpace */), - rule("NoSpaceBetweenEmptyBraceBrackets", 19 /* OpenBraceToken */, 20 /* CloseBraceToken */, [isNonJsxSameLineTokenContext, isObjectContext], 16 /* DeleteSpace */), - rule("NoSpaceAfterOpenBrace", 19 /* OpenBraceToken */, anyToken, [isOptionDisabled("insertSpaceAfterOpeningAndBeforeClosingNonemptyBraces"), isNonJsxSameLineTokenContext], 16 /* DeleteSpace */), - rule("NoSpaceBeforeCloseBrace", anyToken, 20 /* CloseBraceToken */, [isOptionDisabled("insertSpaceAfterOpeningAndBeforeClosingNonemptyBraces"), isNonJsxSameLineTokenContext], 16 /* DeleteSpace */), - // Insert a space after opening and before closing empty brace brackets - rule("SpaceBetweenEmptyBraceBrackets", 19 /* OpenBraceToken */, 20 /* CloseBraceToken */, [isOptionEnabled("insertSpaceAfterOpeningAndBeforeClosingEmptyBraces")], 4 /* InsertSpace */), - rule("NoSpaceBetweenEmptyBraceBrackets", 19 /* OpenBraceToken */, 20 /* CloseBraceToken */, [isOptionDisabled("insertSpaceAfterOpeningAndBeforeClosingEmptyBraces"), isNonJsxSameLineTokenContext], 16 /* DeleteSpace */), - // Insert space after opening and before closing template string braces - rule("SpaceAfterTemplateHeadAndMiddle", [16 /* TemplateHead */, 17 /* TemplateMiddle */], anyToken, [isOptionEnabled("insertSpaceAfterOpeningAndBeforeClosingTemplateStringBraces"), isNonJsxTextContext], 4 /* InsertSpace */, 1 /* CanDeleteNewLines */), - rule("SpaceBeforeTemplateMiddleAndTail", anyToken, [17 /* TemplateMiddle */, 18 /* TemplateTail */], [isOptionEnabled("insertSpaceAfterOpeningAndBeforeClosingTemplateStringBraces"), isNonJsxSameLineTokenContext], 4 /* InsertSpace */), - rule("NoSpaceAfterTemplateHeadAndMiddle", [16 /* TemplateHead */, 17 /* TemplateMiddle */], anyToken, [isOptionDisabledOrUndefined("insertSpaceAfterOpeningAndBeforeClosingTemplateStringBraces"), isNonJsxTextContext], 16 /* DeleteSpace */, 1 /* CanDeleteNewLines */), - rule("NoSpaceBeforeTemplateMiddleAndTail", anyToken, [17 /* TemplateMiddle */, 18 /* TemplateTail */], [isOptionDisabledOrUndefined("insertSpaceAfterOpeningAndBeforeClosingTemplateStringBraces"), isNonJsxSameLineTokenContext], 16 /* DeleteSpace */), - // No space after { and before } in JSX expression - rule("SpaceAfterOpenBraceInJsxExpression", 19 /* OpenBraceToken */, anyToken, [isOptionEnabled("insertSpaceAfterOpeningAndBeforeClosingJsxExpressionBraces"), isNonJsxSameLineTokenContext, isJsxExpressionContext], 4 /* InsertSpace */), - rule("SpaceBeforeCloseBraceInJsxExpression", anyToken, 20 /* CloseBraceToken */, [isOptionEnabled("insertSpaceAfterOpeningAndBeforeClosingJsxExpressionBraces"), isNonJsxSameLineTokenContext, isJsxExpressionContext], 4 /* InsertSpace */), - rule("NoSpaceAfterOpenBraceInJsxExpression", 19 /* OpenBraceToken */, anyToken, [isOptionDisabledOrUndefined("insertSpaceAfterOpeningAndBeforeClosingJsxExpressionBraces"), isNonJsxSameLineTokenContext, isJsxExpressionContext], 16 /* DeleteSpace */), - rule("NoSpaceBeforeCloseBraceInJsxExpression", anyToken, 20 /* CloseBraceToken */, [isOptionDisabledOrUndefined("insertSpaceAfterOpeningAndBeforeClosingJsxExpressionBraces"), isNonJsxSameLineTokenContext, isJsxExpressionContext], 16 /* DeleteSpace */), - // Insert space after semicolon in for statement - rule("SpaceAfterSemicolonInFor", 27 /* SemicolonToken */, anyToken, [isOptionEnabled("insertSpaceAfterSemicolonInForStatements"), isNonJsxSameLineTokenContext, isForContext], 4 /* InsertSpace */), - rule("NoSpaceAfterSemicolonInFor", 27 /* SemicolonToken */, anyToken, [isOptionDisabledOrUndefined("insertSpaceAfterSemicolonInForStatements"), isNonJsxSameLineTokenContext, isForContext], 16 /* DeleteSpace */), - // Insert space before and after binary operators - rule("SpaceBeforeBinaryOperator", anyToken, binaryOperators, [isOptionEnabled("insertSpaceBeforeAndAfterBinaryOperators"), isNonJsxSameLineTokenContext, isBinaryOpContext], 4 /* InsertSpace */), - rule("SpaceAfterBinaryOperator", binaryOperators, anyToken, [isOptionEnabled("insertSpaceBeforeAndAfterBinaryOperators"), isNonJsxSameLineTokenContext, isBinaryOpContext], 4 /* InsertSpace */), - rule("NoSpaceBeforeBinaryOperator", anyToken, binaryOperators, [isOptionDisabledOrUndefined("insertSpaceBeforeAndAfterBinaryOperators"), isNonJsxSameLineTokenContext, isBinaryOpContext], 16 /* DeleteSpace */), - rule("NoSpaceAfterBinaryOperator", binaryOperators, anyToken, [isOptionDisabledOrUndefined("insertSpaceBeforeAndAfterBinaryOperators"), isNonJsxSameLineTokenContext, isBinaryOpContext], 16 /* DeleteSpace */), - rule("SpaceBeforeOpenParenInFuncDecl", anyToken, 21 /* OpenParenToken */, [isOptionEnabled("insertSpaceBeforeFunctionParenthesis"), isNonJsxSameLineTokenContext, isFunctionDeclContext], 4 /* InsertSpace */), - rule("NoSpaceBeforeOpenParenInFuncDecl", anyToken, 21 /* OpenParenToken */, [isOptionDisabledOrUndefined("insertSpaceBeforeFunctionParenthesis"), isNonJsxSameLineTokenContext, isFunctionDeclContext], 16 /* DeleteSpace */), - // Open Brace braces after control block - rule("NewLineBeforeOpenBraceInControl", controlOpenBraceLeftTokenRange, 19 /* OpenBraceToken */, [isOptionEnabled("placeOpenBraceOnNewLineForControlBlocks"), isControlDeclContext, isBeforeMultilineBlockContext], 8 /* InsertNewLine */, 1 /* CanDeleteNewLines */), - // Open Brace braces after function - // TypeScript: Function can have return types, which can be made of tons of different token kinds - rule("NewLineBeforeOpenBraceInFunction", functionOpenBraceLeftTokenRange, 19 /* OpenBraceToken */, [isOptionEnabled("placeOpenBraceOnNewLineForFunctions"), isFunctionDeclContext, isBeforeMultilineBlockContext], 8 /* InsertNewLine */, 1 /* CanDeleteNewLines */), - // Open Brace braces after TypeScript module/class/interface - rule("NewLineBeforeOpenBraceInTypeScriptDeclWithBlock", typeScriptOpenBraceLeftTokenRange, 19 /* OpenBraceToken */, [isOptionEnabled("placeOpenBraceOnNewLineForFunctions"), isTypeScriptDeclWithBlockContext, isBeforeMultilineBlockContext], 8 /* InsertNewLine */, 1 /* CanDeleteNewLines */), - rule("SpaceAfterTypeAssertion", 32 /* GreaterThanToken */, anyToken, [isOptionEnabled("insertSpaceAfterTypeAssertion"), isNonJsxSameLineTokenContext, isTypeAssertionContext], 4 /* InsertSpace */), - rule("NoSpaceAfterTypeAssertion", 32 /* GreaterThanToken */, anyToken, [isOptionDisabledOrUndefined("insertSpaceAfterTypeAssertion"), isNonJsxSameLineTokenContext, isTypeAssertionContext], 16 /* DeleteSpace */), - rule("SpaceBeforeTypeAnnotation", anyToken, [58 /* QuestionToken */, 59 /* ColonToken */], [isOptionEnabled("insertSpaceBeforeTypeAnnotation"), isNonJsxSameLineTokenContext, isTypeAnnotationContext], 4 /* InsertSpace */), - rule("NoSpaceBeforeTypeAnnotation", anyToken, [58 /* QuestionToken */, 59 /* ColonToken */], [isOptionDisabledOrUndefined("insertSpaceBeforeTypeAnnotation"), isNonJsxSameLineTokenContext, isTypeAnnotationContext], 16 /* DeleteSpace */), - rule("NoOptionalSemicolon", 27 /* SemicolonToken */, anyTokenIncludingEOF, [optionEquals("semicolons", "remove" /* Remove */), isSemicolonDeletionContext], 32 /* DeleteToken */), - rule("OptionalSemicolon", anyToken, anyTokenIncludingEOF, [optionEquals("semicolons", "insert" /* Insert */), isSemicolonInsertionContext], 64 /* InsertTrailingSemicolon */) - ]; - const lowPriorityCommonRules = [ - // Space after keyword but not before ; or : or ? - rule("NoSpaceBeforeSemicolon", anyToken, 27 /* SemicolonToken */, [isNonJsxSameLineTokenContext], 16 /* DeleteSpace */), - rule("SpaceBeforeOpenBraceInControl", controlOpenBraceLeftTokenRange, 19 /* OpenBraceToken */, [isOptionDisabledOrUndefinedOrTokensOnSameLine("placeOpenBraceOnNewLineForControlBlocks"), isControlDeclContext, isNotFormatOnEnter, isSameLineTokenOrBeforeBlockContext], 4 /* InsertSpace */, 1 /* CanDeleteNewLines */), - rule("SpaceBeforeOpenBraceInFunction", functionOpenBraceLeftTokenRange, 19 /* OpenBraceToken */, [isOptionDisabledOrUndefinedOrTokensOnSameLine("placeOpenBraceOnNewLineForFunctions"), isFunctionDeclContext, isBeforeBlockContext, isNotFormatOnEnter, isSameLineTokenOrBeforeBlockContext], 4 /* InsertSpace */, 1 /* CanDeleteNewLines */), - rule("SpaceBeforeOpenBraceInTypeScriptDeclWithBlock", typeScriptOpenBraceLeftTokenRange, 19 /* OpenBraceToken */, [isOptionDisabledOrUndefinedOrTokensOnSameLine("placeOpenBraceOnNewLineForFunctions"), isTypeScriptDeclWithBlockContext, isNotFormatOnEnter, isSameLineTokenOrBeforeBlockContext], 4 /* InsertSpace */, 1 /* CanDeleteNewLines */), - rule("NoSpaceBeforeComma", anyToken, 28 /* CommaToken */, [isNonJsxSameLineTokenContext], 16 /* DeleteSpace */), - // No space before and after indexer `x[]` - rule("NoSpaceBeforeOpenBracket", anyTokenExcept(134 /* AsyncKeyword */, 84 /* CaseKeyword */), 23 /* OpenBracketToken */, [isNonJsxSameLineTokenContext], 16 /* DeleteSpace */), - rule("NoSpaceAfterCloseBracket", 24 /* CloseBracketToken */, anyToken, [isNonJsxSameLineTokenContext, isNotBeforeBlockInFunctionDeclarationContext], 16 /* DeleteSpace */), - rule("SpaceAfterSemicolon", 27 /* SemicolonToken */, anyToken, [isNonJsxSameLineTokenContext], 4 /* InsertSpace */), - // Remove extra space between for and await - rule("SpaceBetweenForAndAwaitKeyword", 99 /* ForKeyword */, 135 /* AwaitKeyword */, [isNonJsxSameLineTokenContext], 4 /* InsertSpace */), - // Add a space between statements. All keywords except (do,else,case) has open/close parens after them. - // So, we have a rule to add a space for [),Any], [do,Any], [else,Any], and [case,Any] - rule( - "SpaceBetweenStatements", - [22 /* CloseParenToken */, 92 /* DoKeyword */, 93 /* ElseKeyword */, 84 /* CaseKeyword */], - anyToken, - [isNonJsxSameLineTokenContext, isNonJsxElementOrFragmentContext, isNotForContext], - 4 /* InsertSpace */ - ), - // This low-pri rule takes care of "try {", "catch {" and "finally {" in case the rule SpaceBeforeOpenBraceInControl didn't execute on FormatOnEnter. - rule("SpaceAfterTryCatchFinally", [113 /* TryKeyword */, 85 /* CatchKeyword */, 98 /* FinallyKeyword */], 19 /* OpenBraceToken */, [isNonJsxSameLineTokenContext], 4 /* InsertSpace */) - ]; - return [ - ...highPriorityCommonRules, - ...userConfigurableRules, - ...lowPriorityCommonRules - ]; - } - function rule(debugName, left, right, context, action, flags = 0 /* None */) { - return { leftTokenRange: toTokenRange(left), rightTokenRange: toTokenRange(right), rule: { debugName, context, action, flags } }; - } - function tokenRangeFrom(tokens) { - return { tokens, isSpecific: true }; - } - function toTokenRange(arg) { - return typeof arg === "number" ? tokenRangeFrom([arg]) : isArray(arg) ? tokenRangeFrom(arg) : arg; - } - function tokenRangeFromRange(from, to, except = []) { - const tokens = []; - for (let token = from; token <= to; token++) { - if (!contains(except, token)) { - tokens.push(token); - } + proj.rootFiles = filesToKeep; + return excludedFiles; + } + openExternalProject(proj) { + proj.typeAcquisition = proj.typeAcquisition || {}; + proj.typeAcquisition.include = proj.typeAcquisition.include || []; + proj.typeAcquisition.exclude = proj.typeAcquisition.exclude || []; + if (proj.typeAcquisition.enable === void 0) { + proj.typeAcquisition.enable = hasNoTypeScriptSource(proj.rootFiles.map((f) => f.fileName)); + } + const excludedFiles = this.applySafeList(proj); + let tsConfigFiles; + const rootFiles = []; + for (const file of proj.rootFiles) { + const normalized = toNormalizedPath(file.fileName); + if (getBaseConfigFileName(normalized)) { + if (this.serverMode === 0 /* Semantic */ && this.host.fileExists(normalized)) { + (tsConfigFiles || (tsConfigFiles = [])).push(normalized); + } + } else { + rootFiles.push(file); + } + } + if (tsConfigFiles) { + tsConfigFiles.sort(); + } + const externalProject = this.findExternalProjectByProjectName(proj.projectFileName); + let exisingConfigFiles; + if (externalProject) { + externalProject.excludedFiles = excludedFiles; + if (!tsConfigFiles) { + const compilerOptions = convertCompilerOptions(proj.options); + const watchOptionsAndErrors = convertWatchOptions(proj.options, externalProject.getCurrentDirectory()); + const lastFileExceededProgramSize = this.getFilenameForExceededTotalSizeLimitForNonTsFiles(proj.projectFileName, compilerOptions, proj.rootFiles, externalFilePropertyReader); + if (lastFileExceededProgramSize) { + externalProject.disableLanguageService(lastFileExceededProgramSize); + } else { + externalProject.enableLanguageService(); + } + externalProject.setProjectErrors(watchOptionsAndErrors == null ? void 0 : watchOptionsAndErrors.errors); + this.updateRootAndOptionsOfNonInferredProject(externalProject, proj.rootFiles, externalFilePropertyReader, compilerOptions, proj.typeAcquisition, proj.options.compileOnSave, watchOptionsAndErrors == null ? void 0 : watchOptionsAndErrors.watchOptions); + externalProject.updateGraph(); + return; + } + this.closeExternalProject(proj.projectFileName); + } else if (this.externalProjectToConfiguredProjectMap.get(proj.projectFileName)) { + if (!tsConfigFiles) { + this.closeExternalProject(proj.projectFileName); + } else { + const oldConfigFiles = this.externalProjectToConfiguredProjectMap.get(proj.projectFileName); + let iNew = 0; + let iOld = 0; + while (iNew < tsConfigFiles.length && iOld < oldConfigFiles.length) { + const newConfig = tsConfigFiles[iNew]; + const oldConfig = oldConfigFiles[iOld]; + if (oldConfig < newConfig) { + this.closeConfiguredProjectReferencedFromExternalProject(oldConfig); + iOld++; + } else if (oldConfig > newConfig) { + iNew++; + } else { + (exisingConfigFiles || (exisingConfigFiles = [])).push(oldConfig); + iOld++; + iNew++; + } + } + for (let i = iOld; i < oldConfigFiles.length; i++) { + this.closeConfiguredProjectReferencedFromExternalProject(oldConfigFiles[i]); + } + } + } + if (tsConfigFiles) { + this.externalProjectToConfiguredProjectMap.set(proj.projectFileName, tsConfigFiles); + for (const tsconfigFile of tsConfigFiles) { + let project = this.findConfiguredProjectByProjectName(tsconfigFile); + if (!project) { + project = this.getHostPreferences().lazyConfiguredProjectsFromExternalProject ? this.createConfiguredProjectWithDelayLoad(tsconfigFile, `Creating configured project in external project: ${proj.projectFileName}`) : this.createLoadAndUpdateConfiguredProject(tsconfigFile, `Creating configured project in external project: ${proj.projectFileName}`); + } + if (project && !contains(exisingConfigFiles, tsconfigFile)) { + project.addExternalProjectReference(); + } + } + } else { + this.externalProjectToConfiguredProjectMap.delete(proj.projectFileName); + const project = this.createExternalProject(proj.projectFileName, rootFiles, proj.options, proj.typeAcquisition, excludedFiles); + project.updateGraph(); + } + } + hasDeferredExtension() { + for (const extension of this.hostConfiguration.extraFileExtensions) { + if (extension.scriptKind === 7 /* Deferred */) { + return true; + } + } + return false; + } + /** + * Performs the initial steps of enabling a plugin by finding and instantiating the module for a plugin either asynchronously or synchronously + * @internal + */ + requestEnablePlugin(project, pluginConfigEntry, searchPaths) { + if (!this.host.importPlugin && !this.host.require) { + this.logger.info("Plugins were requested but not running in environment that supports 'require'. Nothing will be loaded"); + return; + } + this.logger.info(`Enabling plugin ${pluginConfigEntry.name} from candidate paths: ${searchPaths.join(",")}`); + if (!pluginConfigEntry.name || parsePackageName(pluginConfigEntry.name).rest) { + this.logger.info(`Skipped loading plugin ${pluginConfigEntry.name || JSON.stringify(pluginConfigEntry)} because only package name is allowed plugin name`); + return; + } + if (this.host.importPlugin) { + const importPromise = Project3.importServicePluginAsync( + pluginConfigEntry, + searchPaths, + this.host, + (s) => this.logger.info(s) + ); + this.pendingPluginEnablements ?? (this.pendingPluginEnablements = /* @__PURE__ */ new Map()); + let promises = this.pendingPluginEnablements.get(project); + if (!promises) + this.pendingPluginEnablements.set(project, promises = []); + promises.push(importPromise); + return; + } + this.endEnablePlugin( + project, + Project3.importServicePluginSync( + pluginConfigEntry, + searchPaths, + this.host, + (s) => this.logger.info(s) + ) + ); + } + /** + * Performs the remaining steps of enabling a plugin after its module has been instantiated. + * @internal + */ + endEnablePlugin(project, { pluginConfigEntry, resolvedModule, errorLogs }) { + var _a; + if (resolvedModule) { + const configurationOverride = (_a = this.currentPluginConfigOverrides) == null ? void 0 : _a.get(pluginConfigEntry.name); + if (configurationOverride) { + const pluginName = pluginConfigEntry.name; + pluginConfigEntry = configurationOverride; + pluginConfigEntry.name = pluginName; + } + project.enableProxy(resolvedModule, pluginConfigEntry); + } else { + forEach(errorLogs, (message) => this.logger.info(message)); + this.logger.info(`Couldn't find ${pluginConfigEntry.name}`); + } + } + /** @internal */ + hasNewPluginEnablementRequests() { + return !!this.pendingPluginEnablements; + } + /** @internal */ + hasPendingPluginEnablements() { + return !!this.currentPluginEnablementPromise; + } + /** + * Waits for any ongoing plugin enablement requests to complete. + * + * @internal + */ + async waitForPendingPlugins() { + while (this.currentPluginEnablementPromise) { + await this.currentPluginEnablementPromise; + } + } + /** + * Starts enabling any requested plugins without waiting for the result. + * + * @internal + */ + enableRequestedPlugins() { + if (this.pendingPluginEnablements) { + void this.enableRequestedPluginsAsync(); + } + } + async enableRequestedPluginsAsync() { + if (this.currentPluginEnablementPromise) { + await this.waitForPendingPlugins(); + } + if (!this.pendingPluginEnablements) { + return; + } + const entries = arrayFrom(this.pendingPluginEnablements.entries()); + this.pendingPluginEnablements = void 0; + this.currentPluginEnablementPromise = this.enableRequestedPluginsWorker(entries); + await this.currentPluginEnablementPromise; + } + async enableRequestedPluginsWorker(pendingPlugins) { + Debug.assert(this.currentPluginEnablementPromise === void 0); + await Promise.all(map(pendingPlugins, ([project, promises]) => this.enableRequestedPluginsForProjectAsync(project, promises))); + this.currentPluginEnablementPromise = void 0; + this.sendProjectsUpdatedInBackgroundEvent(); + } + async enableRequestedPluginsForProjectAsync(project, promises) { + const results = await Promise.all(promises); + if (project.isClosed()) { + return; + } + for (const result of results) { + this.endEnablePlugin(project, result); + } + this.delayUpdateProjectGraph(project); + } + configurePlugin(args) { + this.forEachEnabledProject((project) => project.onPluginConfigurationChanged(args.pluginName, args.configuration)); + this.currentPluginConfigOverrides = this.currentPluginConfigOverrides || /* @__PURE__ */ new Map(); + this.currentPluginConfigOverrides.set(args.pluginName, args.configuration); + } + /** @internal */ + getPackageJsonsVisibleToFile(fileName, rootDir) { + const packageJsonCache = this.packageJsonCache; + const rootPath = rootDir && this.toPath(rootDir); + const filePath = this.toPath(fileName); + const result = []; + const processDirectory = (directory) => { + switch (packageJsonCache.directoryHasPackageJson(directory)) { + case 3 /* Maybe */: + packageJsonCache.searchDirectoryAndAncestors(directory); + return processDirectory(directory); + case -1 /* True */: + const packageJsonFileName = combinePaths(directory, "package.json"); + this.watchPackageJsonFile(packageJsonFileName); + const info = packageJsonCache.getInDirectory(directory); + if (info) + result.push(info); + } + if (rootPath && rootPath === directory) { + return true; + } + }; + forEachAncestorDirectory(getDirectoryPath(filePath), processDirectory); + return result; + } + /** @internal */ + getNearestAncestorDirectoryWithPackageJson(fileName) { + return forEachAncestorDirectory(fileName, (directory) => { + switch (this.packageJsonCache.directoryHasPackageJson(this.toPath(directory))) { + case -1 /* True */: + return directory; + case 0 /* False */: + return void 0; + case 3 /* Maybe */: + return this.host.fileExists(combinePaths(directory, "package.json")) ? directory : void 0; + } + }); + } + /** @internal */ + watchPnpFile() { + const pnpApiPath = getPnpApiPath(__filename); + if (!pnpApiPath) { + return; + } + return this.watchFactory.watchFile( + pnpApiPath, + () => { + this.forEachProject((project) => { + for (const info of project.getScriptInfos()) { + project.resolutionCache.invalidateResolutionOfFile(info.path); + } + project.markAsDirty(); + updateProjectIfDirty(project); + }); + this.delayEnsureProjectForOpenFiles(); + }, + 250 /* Low */, + this.hostConfiguration.watchOptions, + WatchType.ConfigFile + ); + } + /** @internal */ + watchPackageJsonFile(path) { + const watchers = this.packageJsonFilesMap || (this.packageJsonFilesMap = /* @__PURE__ */ new Map()); + if (!watchers.has(path)) { + this.invalidateProjectPackageJson(path); + watchers.set( + path, + this.watchFactory.watchFile( + path, + (fileName, eventKind) => { + const path2 = this.toPath(fileName); + switch (eventKind) { + case 0 /* Created */: + return Debug.fail(); + case 1 /* Changed */: + this.packageJsonCache.addOrUpdate(path2); + this.invalidateProjectPackageJson(path2); + break; + case 2 /* Deleted */: + this.packageJsonCache.delete(path2); + this.invalidateProjectPackageJson(path2); + watchers.get(path2).close(); + watchers.delete(path2); + } + }, + 250 /* Low */, + this.hostConfiguration.watchOptions, + WatchType.PackageJson + ) + ); + } + } + /** @internal */ + onAddPackageJson(path) { + this.packageJsonCache.addOrUpdate(path); + this.watchPackageJsonFile(path); + } + /** @internal */ + includePackageJsonAutoImports() { + switch (this.hostConfiguration.preferences.includePackageJsonAutoImports) { + case "on": + return 1 /* On */; + case "off": + return 0 /* Off */; + default: + return 2 /* Auto */; + } + } + /** @internal */ + invalidateProjectPackageJson(packageJsonPath) { + this.configuredProjects.forEach(invalidate); + this.inferredProjects.forEach(invalidate); + this.externalProjects.forEach(invalidate); + function invalidate(project) { + if (packageJsonPath) { + project.onPackageJsonChange(packageJsonPath); + } else { + project.onAutoImportProviderSettingsChanged(); + } + } + } + /** @internal */ + getIncompleteCompletionsCache() { + return this.incompleteCompletionsCache || (this.incompleteCompletionsCache = createIncompleteCompletionsCache()); + } + }; + /** Makes a filename safe to insert in a RegExp */ + _ProjectService.filenameEscapeRegexp = /[-/\\^$*+?.()|[\]{}]/g; + ProjectService3 = _ProjectService; } - return tokenRangeFrom(tokens); - } - function optionEquals(optionName, optionValue) { - return (context) => context.options && context.options[optionName] === optionValue; - } - function isOptionEnabled(optionName) { - return (context) => context.options && hasProperty(context.options, optionName) && !!context.options[optionName]; - } - function isOptionDisabled(optionName) { - return (context) => context.options && hasProperty(context.options, optionName) && !context.options[optionName]; - } - function isOptionDisabledOrUndefined(optionName) { - return (context) => !context.options || !hasProperty(context.options, optionName) || !context.options[optionName]; - } - function isOptionDisabledOrUndefinedOrTokensOnSameLine(optionName) { - return (context) => !context.options || !hasProperty(context.options, optionName) || !context.options[optionName] || context.TokensAreOnSameLine(); - } - function isOptionEnabledOrUndefined(optionName) { - return (context) => !context.options || !hasProperty(context.options, optionName) || !!context.options[optionName]; - } - function isForContext(context) { - return context.contextNode.kind === 247 /* ForStatement */; - } - function isNotForContext(context) { - return !isForContext(context); - } - function isBinaryOpContext(context) { - switch (context.contextNode.kind) { - case 225 /* BinaryExpression */: - return context.contextNode.operatorToken.kind !== 28 /* CommaToken */; - case 226 /* ConditionalExpression */: - case 193 /* ConditionalType */: - case 233 /* AsExpression */: - case 280 /* ExportSpecifier */: - case 275 /* ImportSpecifier */: - case 181 /* TypePredicate */: - case 191 /* UnionType */: - case 192 /* IntersectionType */: - case 237 /* SatisfiesExpression */: - return true; - case 207 /* BindingElement */: - case 264 /* TypeAliasDeclaration */: - case 270 /* ImportEqualsDeclaration */: - case 276 /* ExportAssignment */: - case 259 /* VariableDeclaration */: - case 168 /* Parameter */: - case 305 /* EnumMember */: - case 171 /* PropertyDeclaration */: - case 170 /* PropertySignature */: - return context.currentTokenSpan.kind === 64 /* EqualsToken */ || context.nextTokenSpan.kind === 64 /* EqualsToken */; - case 248 /* ForInStatement */: - case 167 /* TypeParameter */: - return context.currentTokenSpan.kind === 103 /* InKeyword */ || context.nextTokenSpan.kind === 103 /* InKeyword */ || context.currentTokenSpan.kind === 64 /* EqualsToken */ || context.nextTokenSpan.kind === 64 /* EqualsToken */; - case 249 /* ForOfStatement */: - return context.currentTokenSpan.kind === 164 /* OfKeyword */ || context.nextTokenSpan.kind === 164 /* OfKeyword */; + }); + + // src/server/moduleSpecifierCache.ts + function createModuleSpecifierCache(host) { + let containedNodeModulesWatchers; + let cache; + let currentKey; + const result = { + get(fromFileName, toFileName2, preferences, options) { + if (!cache || currentKey !== key(fromFileName, preferences, options)) + return void 0; + return cache.get(toFileName2); + }, + set(fromFileName, toFileName2, preferences, options, modulePaths, moduleSpecifiers) { + ensureCache(fromFileName, preferences, options).set(toFileName2, createInfo( + modulePaths, + moduleSpecifiers, + /*isBlockedByPackageJsonDependencies*/ + false + )); + if (moduleSpecifiers) { + for (const p of modulePaths) { + if (p.isInNodeModules) { + const nodeModulesPath = p.path.substring(0, p.path.indexOf(nodeModulesPathPart) + nodeModulesPathPart.length - 1); + if (!(containedNodeModulesWatchers == null ? void 0 : containedNodeModulesWatchers.has(nodeModulesPath))) { + (containedNodeModulesWatchers || (containedNodeModulesWatchers = /* @__PURE__ */ new Map())).set( + nodeModulesPath, + host.watchNodeModulesForPackageJsonChanges(nodeModulesPath) + ); + } + } + } + } + }, + setModulePaths(fromFileName, toFileName2, preferences, options, modulePaths) { + const cache2 = ensureCache(fromFileName, preferences, options); + const info = cache2.get(toFileName2); + if (info) { + info.modulePaths = modulePaths; + } else { + cache2.set(toFileName2, createInfo( + modulePaths, + /*moduleSpecifiers*/ + void 0, + /*isBlockedByPackageJsonDependencies*/ + void 0 + )); + } + }, + setBlockedByPackageJsonDependencies(fromFileName, toFileName2, preferences, options, isBlockedByPackageJsonDependencies) { + const cache2 = ensureCache(fromFileName, preferences, options); + const info = cache2.get(toFileName2); + if (info) { + info.isBlockedByPackageJsonDependencies = isBlockedByPackageJsonDependencies; + } else { + cache2.set(toFileName2, createInfo( + /*modulePaths*/ + void 0, + /*moduleSpecifiers*/ + void 0, + isBlockedByPackageJsonDependencies + )); + } + }, + clear() { + containedNodeModulesWatchers == null ? void 0 : containedNodeModulesWatchers.forEach((watcher) => watcher.close()); + cache == null ? void 0 : cache.clear(); + containedNodeModulesWatchers == null ? void 0 : containedNodeModulesWatchers.clear(); + currentKey = void 0; + }, + count() { + return cache ? cache.size : 0; + } + }; + if (Debug.isDebugging) { + Object.defineProperty(result, "__cache", { get: () => cache }); } - return false; - } - function isNotBinaryOpContext(context) { - return !isBinaryOpContext(context); - } - function isNotTypeAnnotationContext(context) { - return !isTypeAnnotationContext(context); - } - function isTypeAnnotationContext(context) { - const contextKind = context.contextNode.kind; - return contextKind === 171 /* PropertyDeclaration */ || contextKind === 170 /* PropertySignature */ || contextKind === 168 /* Parameter */ || contextKind === 259 /* VariableDeclaration */ || isFunctionLikeKind(contextKind); - } - function isConditionalOperatorContext(context) { - return context.contextNode.kind === 226 /* ConditionalExpression */ || context.contextNode.kind === 193 /* ConditionalType */; - } - function isSameLineTokenOrBeforeBlockContext(context) { - return context.TokensAreOnSameLine() || isBeforeBlockContext(context); - } - function isBraceWrappedContext(context) { - return context.contextNode.kind === 205 /* ObjectBindingPattern */ || context.contextNode.kind === 199 /* MappedType */ || isSingleLineBlockContext(context); - } - function isBeforeMultilineBlockContext(context) { - return isBeforeBlockContext(context) && !(context.NextNodeAllOnSameLine() || context.NextNodeBlockIsOnOneLine()); - } - function isMultilineBlockContext(context) { - return isBlockContext(context) && !(context.ContextNodeAllOnSameLine() || context.ContextNodeBlockIsOnOneLine()); - } - function isSingleLineBlockContext(context) { - return isBlockContext(context) && (context.ContextNodeAllOnSameLine() || context.ContextNodeBlockIsOnOneLine()); - } - function isBlockContext(context) { - return nodeIsBlockContext(context.contextNode); - } - function isBeforeBlockContext(context) { - return nodeIsBlockContext(context.nextTokenParent); - } - function nodeIsBlockContext(node) { - if (nodeIsTypeScriptDeclWithBlockContext(node)) { - return true; + return result; + function ensureCache(fromFileName, preferences, options) { + const newKey = key(fromFileName, preferences, options); + if (cache && currentKey !== newKey) { + result.clear(); + } + currentKey = newKey; + return cache || (cache = /* @__PURE__ */ new Map()); } - switch (node.kind) { - case 240 /* Block */: - case 268 /* CaseBlock */: - case 209 /* ObjectLiteralExpression */: - case 267 /* ModuleBlock */: - return true; + function key(fromFileName, preferences, options) { + return `${fromFileName},${preferences.importModuleSpecifierEnding},${preferences.importModuleSpecifierPreference},${options.overrideImportMode}`; } - return false; - } - function isFunctionDeclContext(context) { - switch (context.contextNode.kind) { - case 261 /* FunctionDeclaration */: - case 173 /* MethodDeclaration */: - case 172 /* MethodSignature */: - case 176 /* GetAccessor */: - case 177 /* SetAccessor */: - case 178 /* CallSignature */: - case 217 /* FunctionExpression */: - case 175 /* Constructor */: - case 218 /* ArrowFunction */: - case 263 /* InterfaceDeclaration */: - return true; + function createInfo(modulePaths, moduleSpecifiers, isBlockedByPackageJsonDependencies) { + return { modulePaths, moduleSpecifiers, isBlockedByPackageJsonDependencies }; } - return false; - } - function isNotFunctionDeclContext(context) { - return !isFunctionDeclContext(context); - } - function isFunctionDeclarationOrFunctionExpressionContext(context) { - return context.contextNode.kind === 261 /* FunctionDeclaration */ || context.contextNode.kind === 217 /* FunctionExpression */; - } - function isTypeScriptDeclWithBlockContext(context) { - return nodeIsTypeScriptDeclWithBlockContext(context.contextNode); } - function nodeIsTypeScriptDeclWithBlockContext(node) { - switch (node.kind) { - case 262 /* ClassDeclaration */: - case 230 /* ClassExpression */: - case 263 /* InterfaceDeclaration */: - case 265 /* EnumDeclaration */: - case 186 /* TypeLiteral */: - case 266 /* ModuleDeclaration */: - case 277 /* ExportDeclaration */: - case 278 /* NamedExports */: - case 271 /* ImportDeclaration */: - case 274 /* NamedImports */: - return true; + var init_moduleSpecifierCache = __esm({ + "src/server/moduleSpecifierCache.ts"() { + "use strict"; + init_ts7(); } - return false; - } - function isAfterCodeBlockContext(context) { - switch (context.currentTokenParent.kind) { - case 262 /* ClassDeclaration */: - case 266 /* ModuleDeclaration */: - case 265 /* EnumDeclaration */: - case 298 /* CatchClause */: - case 267 /* ModuleBlock */: - case 254 /* SwitchStatement */: - return true; - case 240 /* Block */: { - const blockParent = context.currentTokenParent.parent; - if (!blockParent || blockParent.kind !== 218 /* ArrowFunction */ && blockParent.kind !== 217 /* FunctionExpression */) { - return true; - } + }); + + // src/server/packageJsonCache.ts + function createPackageJsonCache(host) { + const packageJsons = /* @__PURE__ */ new Map(); + const directoriesWithoutPackageJson = /* @__PURE__ */ new Map(); + return { + addOrUpdate, + forEach: packageJsons.forEach.bind(packageJsons), + get: packageJsons.get.bind(packageJsons), + delete: (fileName) => { + packageJsons.delete(fileName); + directoriesWithoutPackageJson.set(getDirectoryPath(fileName), true); + }, + getInDirectory: (directory) => { + return packageJsons.get(combinePaths(directory, "package.json")) || void 0; + }, + directoryHasPackageJson, + searchDirectoryAndAncestors: (directory) => { + forEachAncestorDirectory(directory, (ancestor) => { + if (directoryHasPackageJson(ancestor) !== 3 /* Maybe */) { + return true; + } + const packageJsonFileName = host.toPath(combinePaths(ancestor, "package.json")); + if (tryFileExists(host, packageJsonFileName)) { + addOrUpdate(packageJsonFileName); + } else { + directoriesWithoutPackageJson.set(ancestor, true); + } + }); } + }; + function addOrUpdate(fileName) { + const packageJsonInfo = Debug.checkDefined(createPackageJsonInfo(fileName, host.host)); + packageJsons.set(fileName, packageJsonInfo); + directoriesWithoutPackageJson.delete(getDirectoryPath(fileName)); } - return false; - } - function isControlDeclContext(context) { - switch (context.contextNode.kind) { - case 244 /* IfStatement */: - case 254 /* SwitchStatement */: - case 247 /* ForStatement */: - case 248 /* ForInStatement */: - case 249 /* ForOfStatement */: - case 246 /* WhileStatement */: - case 257 /* TryStatement */: - case 245 /* DoStatement */: - case 253 /* WithStatement */: - case 298 /* CatchClause */: - return true; - default: - return false; + function directoryHasPackageJson(directory) { + return packageJsons.has(combinePaths(directory, "package.json")) ? -1 /* True */ : directoriesWithoutPackageJson.has(directory) ? 0 /* False */ : 3 /* Maybe */; } } - function isObjectContext(context) { - return context.contextNode.kind === 209 /* ObjectLiteralExpression */; - } - function isFunctionCallContext(context) { - return context.contextNode.kind === 212 /* CallExpression */; - } - function isNewContext(context) { - return context.contextNode.kind === 213 /* NewExpression */; - } - function isFunctionCallOrNewContext(context) { - return isFunctionCallContext(context) || isNewContext(context); - } - function isPreviousTokenNotComma(context) { - return context.currentTokenSpan.kind !== 28 /* CommaToken */; - } - function isNextTokenNotCloseBracket(context) { - return context.nextTokenSpan.kind !== 24 /* CloseBracketToken */; - } - function isNextTokenNotCloseParen(context) { - return context.nextTokenSpan.kind !== 22 /* CloseParenToken */; - } - function isArrowFunctionContext(context) { - return context.contextNode.kind === 218 /* ArrowFunction */; - } - function isImportTypeContext(context) { - return context.contextNode.kind === 204 /* ImportType */; - } - function isNonJsxSameLineTokenContext(context) { - return context.TokensAreOnSameLine() && context.contextNode.kind !== 12 /* JsxText */; - } - function isNonJsxTextContext(context) { - return context.contextNode.kind !== 12 /* JsxText */; - } - function isNonJsxElementOrFragmentContext(context) { - return context.contextNode.kind !== 283 /* JsxElement */ && context.contextNode.kind !== 287 /* JsxFragment */; - } - function isJsxExpressionContext(context) { - return context.contextNode.kind === 293 /* JsxExpression */ || context.contextNode.kind === 292 /* JsxSpreadAttribute */; - } - function isNextTokenParentJsxAttribute(context) { - return context.nextTokenParent.kind === 290 /* JsxAttribute */; - } - function isJsxAttributeContext(context) { - return context.contextNode.kind === 290 /* JsxAttribute */; - } - function isJsxSelfClosingElementContext(context) { - return context.contextNode.kind === 284 /* JsxSelfClosingElement */; - } - function isNotBeforeBlockInFunctionDeclarationContext(context) { - return !isFunctionDeclContext(context) && !isBeforeBlockContext(context); - } - function isEndOfDecoratorContextOnSameLine(context) { - return context.TokensAreOnSameLine() && hasDecorators(context.contextNode) && nodeIsInDecoratorContext(context.currentTokenParent) && !nodeIsInDecoratorContext(context.nextTokenParent); - } - function nodeIsInDecoratorContext(node) { - while (node && isExpression(node)) { - node = node.parent; + var init_packageJsonCache = __esm({ + "src/server/packageJsonCache.ts"() { + "use strict"; + init_ts7(); } - return node && node.kind === 169 /* Decorator */; - } - function isStartOfVariableDeclarationList(context) { - return context.currentTokenParent.kind === 260 /* VariableDeclarationList */ && context.currentTokenParent.getStart(context.sourceFile) === context.currentTokenSpan.pos; - } - function isNotFormatOnEnter(context) { - return context.formattingRequestKind !== 2 /* FormatOnEnter */; + }); + + // src/server/session.ts + function hrTimeToMilliseconds(time) { + const seconds = time[0]; + const nanoseconds = time[1]; + return (1e9 * seconds + nanoseconds) / 1e6; } - function isModuleDeclContext(context) { - return context.contextNode.kind === 266 /* ModuleDeclaration */; + function isDeclarationFileInJSOnlyNonConfiguredProject(project, file) { + if ((isInferredProject(project) || isExternalProject(project)) && project.isJsOnlyProject()) { + const scriptInfo = project.getScriptInfoForNormalizedPath(file); + return scriptInfo && !scriptInfo.isJavaScript(); + } + return false; } - function isObjectTypeContext(context) { - return context.contextNode.kind === 186 /* TypeLiteral */; + function dtsChangeCanAffectEmit(compilationSettings) { + return getEmitDeclarations(compilationSettings) || !!compilationSettings.emitDecoratorMetadata; } - function isConstructorSignatureContext(context) { - return context.contextNode.kind === 179 /* ConstructSignature */; + function formatDiag(fileName, project, diag2) { + const scriptInfo = project.getScriptInfoForNormalizedPath(fileName); + return { + start: scriptInfo.positionToLineOffset(diag2.start), + end: scriptInfo.positionToLineOffset(diag2.start + diag2.length), + // TODO: GH#18217 + text: flattenDiagnosticMessageText(diag2.messageText, "\n"), + code: diag2.code, + category: diagnosticCategoryName(diag2), + reportsUnnecessary: diag2.reportsUnnecessary, + reportsDeprecated: diag2.reportsDeprecated, + source: diag2.source, + relatedInformation: map(diag2.relatedInformation, formatRelatedInformation) + }; } - function isTypeArgumentOrParameterOrAssertion(token, parent2) { - if (token.kind !== 30 /* LessThanToken */ && token.kind !== 32 /* GreaterThanToken */) { - return false; - } - switch (parent2.kind) { - case 182 /* TypeReference */: - case 215 /* TypeAssertionExpression */: - case 264 /* TypeAliasDeclaration */: - case 262 /* ClassDeclaration */: - case 230 /* ClassExpression */: - case 263 /* InterfaceDeclaration */: - case 261 /* FunctionDeclaration */: - case 217 /* FunctionExpression */: - case 218 /* ArrowFunction */: - case 173 /* MethodDeclaration */: - case 172 /* MethodSignature */: - case 178 /* CallSignature */: - case 179 /* ConstructSignature */: - case 212 /* CallExpression */: - case 213 /* NewExpression */: - case 232 /* ExpressionWithTypeArguments */: - return true; - default: - return false; + function formatRelatedInformation(info) { + if (!info.file) { + return { + message: flattenDiagnosticMessageText(info.messageText, "\n"), + category: diagnosticCategoryName(info), + code: info.code + }; } + return { + span: { + start: convertToLocation(getLineAndCharacterOfPosition(info.file, info.start)), + end: convertToLocation(getLineAndCharacterOfPosition(info.file, info.start + info.length)), + // TODO: GH#18217 + file: info.file.fileName + }, + message: flattenDiagnosticMessageText(info.messageText, "\n"), + category: diagnosticCategoryName(info), + code: info.code + }; } - function isTypeArgumentOrParameterOrAssertionContext(context) { - return isTypeArgumentOrParameterOrAssertion(context.currentTokenSpan, context.currentTokenParent) || isTypeArgumentOrParameterOrAssertion(context.nextTokenSpan, context.nextTokenParent); + function convertToLocation(lineAndCharacter) { + return { line: lineAndCharacter.line + 1, offset: lineAndCharacter.character + 1 }; } - function isTypeAssertionContext(context) { - return context.contextNode.kind === 215 /* TypeAssertionExpression */; + function formatDiagnosticToProtocol(diag2, includeFileName) { + const start = diag2.file && convertToLocation(getLineAndCharacterOfPosition(diag2.file, diag2.start)); + const end = diag2.file && convertToLocation(getLineAndCharacterOfPosition(diag2.file, diag2.start + diag2.length)); + const text = flattenDiagnosticMessageText(diag2.messageText, "\n"); + const { code, source } = diag2; + const category = diagnosticCategoryName(diag2); + const common = { + start, + end, + text, + code, + category, + reportsUnnecessary: diag2.reportsUnnecessary, + reportsDeprecated: diag2.reportsDeprecated, + source, + relatedInformation: map(diag2.relatedInformation, formatRelatedInformation) + }; + return includeFileName ? { ...common, fileName: diag2.file && diag2.file.fileName } : common; } - function isNonTypeAssertionContext(context) { - return !isTypeAssertionContext(context); + function allEditsBeforePos(edits, pos) { + return edits.every((edit) => textSpanEnd(edit.span) < pos); } - function isVoidOpContext(context) { - return context.currentTokenSpan.kind === 116 /* VoidKeyword */ && context.currentTokenParent.kind === 221 /* VoidExpression */; + function formatMessage2(msg, logger, byteLength, newLine) { + const verboseLogging = logger.hasLevel(3 /* verbose */); + const json = JSON.stringify(msg); + if (verboseLogging) { + logger.info(`${msg.type}:${stringifyIndented(msg)}`); + } + const len = byteLength(json, "utf8"); + return `Content-Length: ${1 + len}\r +\r +${json}${newLine}`; } - function isYieldOrYieldStarWithOperand(context) { - return context.contextNode.kind === 228 /* YieldExpression */ && context.contextNode.expression !== void 0; + function toEvent(eventName, body) { + return { + seq: 0, + type: "event", + event: eventName, + body + }; } - function isNonNullAssertionContext(context) { - return context.contextNode.kind === 234 /* NonNullExpression */; + function combineProjectOutput(defaultValue, getValue, projects, action) { + const outputs = flatMapToMutable(isArray(projects) ? projects : projects.projects, (project) => action(project, defaultValue)); + if (!isArray(projects) && projects.symLinkedProjects) { + projects.symLinkedProjects.forEach((projects2, path) => { + const value = getValue(path); + outputs.push(...flatMap(projects2, (project) => action(project, value))); + }); + } + return deduplicate(outputs, equateValues); } - function isNotStatementConditionContext(context) { - return !isStatementConditionContext(context); + function createDocumentSpanSet() { + return createSet(({ textSpan }) => textSpan.start + 100003 * textSpan.length, documentSpansEqual); } - function isStatementConditionContext(context) { - switch (context.contextNode.kind) { - case 244 /* IfStatement */: - case 247 /* ForStatement */: - case 248 /* ForInStatement */: - case 249 /* ForOfStatement */: - case 245 /* DoStatement */: - case 246 /* WhileStatement */: - return true; - default: - return false; + function getRenameLocationsWorker(projects, defaultProject, initialLocation, findInStrings, findInComments, preferences) { + const perProjectResults = getPerProjectReferences( + projects, + defaultProject, + initialLocation, + /*isForRename*/ + true, + (project, position) => project.getLanguageService().findRenameLocations(position.fileName, position.pos, findInStrings, findInComments, preferences), + (renameLocation, cb) => cb(documentSpanLocation(renameLocation)) + ); + if (isArray(perProjectResults)) { + return perProjectResults; } - } - function isSemicolonDeletionContext(context) { - let nextTokenKind = context.nextTokenSpan.kind; - let nextTokenStart = context.nextTokenSpan.pos; - if (isTrivia(nextTokenKind)) { - const nextRealToken = context.nextTokenParent === context.currentTokenParent ? findNextToken( - context.currentTokenParent, - findAncestor(context.currentTokenParent, (a) => !a.parent), - context.sourceFile - ) : context.nextTokenParent.getFirstToken(context.sourceFile); - if (!nextRealToken) { - return true; + const results = []; + const seen = createDocumentSpanSet(); + perProjectResults.forEach((projectResults, project) => { + for (const result of projectResults) { + if (!seen.has(result) && !getMappedLocationForProject(documentSpanLocation(result), project)) { + results.push(result); + seen.add(result); + } } - nextTokenKind = nextRealToken.kind; - nextTokenStart = nextRealToken.getStart(context.sourceFile); - } - const startLine = context.sourceFile.getLineAndCharacterOfPosition(context.currentTokenSpan.pos).line; - const endLine = context.sourceFile.getLineAndCharacterOfPosition(nextTokenStart).line; - if (startLine === endLine) { - return nextTokenKind === 20 /* CloseBraceToken */ || nextTokenKind === 1 /* EndOfFileToken */; - } - if (nextTokenKind === 239 /* SemicolonClassElement */ || nextTokenKind === 27 /* SemicolonToken */) { - return false; - } - if (context.contextNode.kind === 263 /* InterfaceDeclaration */ || context.contextNode.kind === 264 /* TypeAliasDeclaration */) { - return !isPropertySignature(context.currentTokenParent) || !!context.currentTokenParent.type || nextTokenKind !== 21 /* OpenParenToken */; - } - if (isPropertyDeclaration(context.currentTokenParent)) { - return !context.currentTokenParent.initializer; - } - return context.currentTokenParent.kind !== 247 /* ForStatement */ && context.currentTokenParent.kind !== 241 /* EmptyStatement */ && context.currentTokenParent.kind !== 239 /* SemicolonClassElement */ && nextTokenKind !== 23 /* OpenBracketToken */ && nextTokenKind !== 21 /* OpenParenToken */ && nextTokenKind !== 40 /* PlusToken */ && nextTokenKind !== 41 /* MinusToken */ && nextTokenKind !== 44 /* SlashToken */ && nextTokenKind !== 14 /* RegularExpressionLiteral */ && nextTokenKind !== 28 /* CommaToken */ && nextTokenKind !== 227 /* TemplateExpression */ && nextTokenKind !== 16 /* TemplateHead */ && nextTokenKind !== 15 /* NoSubstitutionTemplateLiteral */ && nextTokenKind !== 25 /* DotToken */; - } - function isSemicolonInsertionContext(context) { - return positionIsASICandidate(context.currentTokenSpan.end, context.currentTokenParent, context.sourceFile); + }); + return results; } - function isNotPropertyAccessOnIntegerLiteral(context) { - return !isPropertyAccessExpression(context.contextNode) || !isNumericLiteral(context.contextNode.expression) || context.contextNode.expression.getText().indexOf(".") !== -1; + function getDefinitionLocation(defaultProject, initialLocation, isForRename) { + const infos = defaultProject.getLanguageService().getDefinitionAtPosition( + initialLocation.fileName, + initialLocation.pos, + /*searchOtherFilesOnly*/ + false, + /*stopAtAlias*/ + isForRename + ); + const info = infos && firstOrUndefined(infos); + return info && !info.isLocal ? { fileName: info.fileName, pos: info.textSpan.start } : void 0; } - var init_rules = __esm({ - "src/services/formatting/rules.ts"() { - "use strict"; - init_ts4(); - init_ts_formatting(); + function getReferencesWorker(projects, defaultProject, initialLocation, logger) { + var _a, _b; + const perProjectResults = getPerProjectReferences( + projects, + defaultProject, + initialLocation, + /*isForRename*/ + false, + (project, position) => { + logger.info(`Finding references to ${position.fileName} position ${position.pos} in project ${project.getProjectName()}`); + return project.getLanguageService().findReferences(position.fileName, position.pos); + }, + (referencedSymbol, cb) => { + cb(documentSpanLocation(referencedSymbol.definition)); + for (const ref of referencedSymbol.references) { + cb(documentSpanLocation(ref)); + } + } + ); + if (isArray(perProjectResults)) { + return perProjectResults; } - }); - - // src/services/formatting/rulesMap.ts - function getFormatContext(options, host) { - return { options, getRules: getRulesMap(), host }; - } - function getRulesMap() { - if (rulesMapCache === void 0) { - rulesMapCache = createRulesMap(getAllRules()); + const defaultProjectResults = perProjectResults.get(defaultProject); + if (((_b = (_a = defaultProjectResults == null ? void 0 : defaultProjectResults[0]) == null ? void 0 : _a.references[0]) == null ? void 0 : _b.isDefinition) === void 0) { + perProjectResults.forEach((projectResults) => { + for (const referencedSymbol of projectResults) { + for (const ref of referencedSymbol.references) { + delete ref.isDefinition; + } + } + }); + } else { + const knownSymbolSpans = createDocumentSpanSet(); + for (const referencedSymbol of defaultProjectResults) { + for (const ref of referencedSymbol.references) { + if (ref.isDefinition) { + knownSymbolSpans.add(ref); + break; + } + } + } + const updatedProjects = /* @__PURE__ */ new Set(); + while (true) { + let progress = false; + perProjectResults.forEach((referencedSymbols, project) => { + if (updatedProjects.has(project)) + return; + const updated = project.getLanguageService().updateIsDefinitionOfReferencedSymbols(referencedSymbols, knownSymbolSpans); + if (updated) { + updatedProjects.add(project); + progress = true; + } + }); + if (!progress) + break; + } + perProjectResults.forEach((referencedSymbols, project) => { + if (updatedProjects.has(project)) + return; + for (const referencedSymbol of referencedSymbols) { + for (const ref of referencedSymbol.references) { + ref.isDefinition = false; + } + } + }); } - return rulesMapCache; + const results = []; + const seenRefs = createDocumentSpanSet(); + perProjectResults.forEach((projectResults, project) => { + for (const referencedSymbol of projectResults) { + const mappedDefinitionFile = getMappedLocationForProject(documentSpanLocation(referencedSymbol.definition), project); + const definition = mappedDefinitionFile === void 0 ? referencedSymbol.definition : { + ...referencedSymbol.definition, + textSpan: createTextSpan(mappedDefinitionFile.pos, referencedSymbol.definition.textSpan.length), + // Why would the length be the same in the original? + fileName: mappedDefinitionFile.fileName, + contextSpan: getMappedContextSpanForProject(referencedSymbol.definition, project) + }; + let symbolToAddTo = find(results, (o) => documentSpansEqual(o.definition, definition)); + if (!symbolToAddTo) { + symbolToAddTo = { definition, references: [] }; + results.push(symbolToAddTo); + } + for (const ref of referencedSymbol.references) { + if (!seenRefs.has(ref) && !getMappedLocationForProject(documentSpanLocation(ref), project)) { + seenRefs.add(ref); + symbolToAddTo.references.push(ref); + } + } + } + }); + return results.filter((o) => o.references.length !== 0); } - function getRuleActionExclusion(ruleAction) { - let mask2 = 0 /* None */; - if (ruleAction & 1 /* StopProcessingSpaceActions */) { - mask2 |= 28 /* ModifySpaceAction */; + function forEachProjectInProjects(projects, path, cb) { + for (const project of isArray(projects) ? projects : projects.projects) { + cb(project, path); } - if (ruleAction & 2 /* StopProcessingTokenActions */) { - mask2 |= 96 /* ModifyTokenAction */; - } - if (ruleAction & 28 /* ModifySpaceAction */) { - mask2 |= 28 /* ModifySpaceAction */; - } - if (ruleAction & 96 /* ModifyTokenAction */) { - mask2 |= 96 /* ModifyTokenAction */; + if (!isArray(projects) && projects.symLinkedProjects) { + projects.symLinkedProjects.forEach((symlinkedProjects, symlinkedPath) => { + for (const project of symlinkedProjects) { + cb(project, symlinkedPath); + } + }); } - return mask2; } - function createRulesMap(rules) { - const map2 = buildMap(rules); - return (context) => { - const bucket = map2[getRuleBucketIndex(context.currentTokenSpan.kind, context.nextTokenSpan.kind)]; - if (bucket) { - const rules2 = []; - let ruleActionMask = 0; - for (const rule2 of bucket) { - const acceptRuleActions = ~getRuleActionExclusion(ruleActionMask); - if (rule2.action & acceptRuleActions && every(rule2.context, (c) => c(context))) { - rules2.push(rule2); - ruleActionMask |= rule2.action; + function getPerProjectReferences(projects, defaultProject, initialLocation, isForRename, getResultsForPosition, forPositionInResult) { + const resultsMap = /* @__PURE__ */ new Map(); + const queue = createQueue(); + queue.enqueue({ project: defaultProject, location: initialLocation }); + forEachProjectInProjects(projects, initialLocation.fileName, (project, path) => { + const location = { fileName: path, pos: initialLocation.pos }; + queue.enqueue({ project, location }); + }); + const projectService = defaultProject.projectService; + const cancellationToken = defaultProject.getCancellationToken(); + const defaultDefinition = getDefinitionLocation(defaultProject, initialLocation, isForRename); + const getGeneratedDefinition = memoize( + () => defaultProject.isSourceOfProjectReferenceRedirect(defaultDefinition.fileName) ? defaultDefinition : defaultProject.getLanguageService().getSourceMapper().tryGetGeneratedPosition(defaultDefinition) + ); + const getSourceDefinition = memoize( + () => defaultProject.isSourceOfProjectReferenceRedirect(defaultDefinition.fileName) ? defaultDefinition : defaultProject.getLanguageService().getSourceMapper().tryGetSourcePosition(defaultDefinition) + ); + const searchedProjectKeys = /* @__PURE__ */ new Set(); + onCancellation: + while (!queue.isEmpty()) { + while (!queue.isEmpty()) { + if (cancellationToken.isCancellationRequested()) + break onCancellation; + const { project, location } = queue.dequeue(); + if (resultsMap.has(project)) + continue; + if (isLocationProjectReferenceRedirect(project, location)) + continue; + updateProjectIfDirty(project); + if (!project.containsFile(toNormalizedPath(location.fileName))) { + continue; } + const projectResults = searchPosition(project, location); + resultsMap.set(project, projectResults ?? emptyArray2); + searchedProjectKeys.add(getProjectKey(project)); } - if (rules2.length) { - return rules2; + if (defaultDefinition) { + projectService.loadAncestorProjectTree(searchedProjectKeys); + projectService.forEachEnabledProject((project) => { + if (cancellationToken.isCancellationRequested()) + return; + if (resultsMap.has(project)) + return; + const location = mapDefinitionInProject(defaultDefinition, project, getGeneratedDefinition, getSourceDefinition); + if (location) { + queue.enqueue({ project, location }); + } + }); } } - }; - } - function buildMap(rules) { - const map2 = new Array(mapRowLength * mapRowLength); - const rulesBucketConstructionStateList = new Array(map2.length); - for (const rule2 of rules) { - const specificRule = rule2.leftTokenRange.isSpecific && rule2.rightTokenRange.isSpecific; - for (const left of rule2.leftTokenRange.tokens) { - for (const right of rule2.rightTokenRange.tokens) { - const index = getRuleBucketIndex(left, right); - let rulesBucket = map2[index]; - if (rulesBucket === void 0) { - rulesBucket = map2[index] = []; + if (resultsMap.size === 1) { + return firstIterator(resultsMap.values()); + } + return resultsMap; + function searchPosition(project, location) { + const projectResults = getResultsForPosition(project, location); + if (!projectResults) + return void 0; + for (const result of projectResults) { + forPositionInResult(result, (position) => { + const originalLocation = projectService.getOriginalLocationEnsuringConfiguredProject(project, position); + if (!originalLocation) + return; + const originalScriptInfo = projectService.getScriptInfo(originalLocation.fileName); + for (const project2 of originalScriptInfo.containingProjects) { + if (!project2.isOrphan() && !resultsMap.has(project2)) { + queue.enqueue({ project: project2, location: originalLocation }); + } + } + const symlinkedProjectsMap = projectService.getSymlinkedProjects(originalScriptInfo); + if (symlinkedProjectsMap) { + symlinkedProjectsMap.forEach((symlinkedProjects, symlinkedPath) => { + for (const symlinkedProject of symlinkedProjects) { + if (!symlinkedProject.isOrphan() && !resultsMap.has(symlinkedProject)) { + queue.enqueue({ project: symlinkedProject, location: { fileName: symlinkedPath, pos: originalLocation.pos } }); + } + } + }); } - addRule(rulesBucket, rule2.rule, specificRule, rulesBucketConstructionStateList, index); - } + }); } + return projectResults; } - return map2; - } - function getRuleBucketIndex(row, column) { - Debug.assert(row <= 164 /* LastKeyword */ && column <= 164 /* LastKeyword */, "Must compute formatting context from tokens"); - return row * mapRowLength + column; - } - function addRule(rules, rule2, specificTokens, constructionState, rulesBucketIndex) { - const position = rule2.action & 3 /* StopAction */ ? specificTokens ? 0 /* StopRulesSpecific */ : RulesPosition.StopRulesAny : rule2.context !== anyContext ? specificTokens ? RulesPosition.ContextRulesSpecific : RulesPosition.ContextRulesAny : specificTokens ? RulesPosition.NoContextRulesSpecific : RulesPosition.NoContextRulesAny; - const state = constructionState[rulesBucketIndex] || 0; - rules.splice(getInsertionIndex(state, position), 0, rule2); - constructionState[rulesBucketIndex] = increaseInsertionIndex(state, position); } - function getInsertionIndex(indexBitmap, maskPosition) { - let index = 0; - for (let pos = 0; pos <= maskPosition; pos += maskBitSize) { - index += indexBitmap & mask; - indexBitmap >>= maskBitSize; + function mapDefinitionInProject(definition, project, getGeneratedDefinition, getSourceDefinition) { + if (project.containsFile(toNormalizedPath(definition.fileName)) && !isLocationProjectReferenceRedirect(project, definition)) { + return definition; } - return index; - } - function increaseInsertionIndex(indexBitmap, maskPosition) { - const value = (indexBitmap >> maskPosition & mask) + 1; - Debug.assert((value & mask) === value, "Adding more rules into the sub-bucket than allowed. Maximum allowed is 32 rules."); - return indexBitmap & ~(mask << maskPosition) | value << maskPosition; + const generatedDefinition = getGeneratedDefinition(); + if (generatedDefinition && project.containsFile(toNormalizedPath(generatedDefinition.fileName))) + return generatedDefinition; + const sourceDefinition = getSourceDefinition(); + return sourceDefinition && project.containsFile(toNormalizedPath(sourceDefinition.fileName)) ? sourceDefinition : void 0; } - var rulesMapCache, maskBitSize, mask, mapRowLength, RulesPosition; - var init_rulesMap = __esm({ - "src/services/formatting/rulesMap.ts"() { - "use strict"; - init_ts4(); - init_ts_formatting(); - maskBitSize = 5; - mask = 31; - mapRowLength = 164 /* LastToken */ + 1; - RulesPosition = ((RulesPosition2) => { - RulesPosition2[RulesPosition2["StopRulesSpecific"] = 0] = "StopRulesSpecific"; - RulesPosition2[RulesPosition2["StopRulesAny"] = maskBitSize * 1] = "StopRulesAny"; - RulesPosition2[RulesPosition2["ContextRulesSpecific"] = maskBitSize * 2] = "ContextRulesSpecific"; - RulesPosition2[RulesPosition2["ContextRulesAny"] = maskBitSize * 3] = "ContextRulesAny"; - RulesPosition2[RulesPosition2["NoContextRulesSpecific"] = maskBitSize * 4] = "NoContextRulesSpecific"; - RulesPosition2[RulesPosition2["NoContextRulesAny"] = maskBitSize * 5] = "NoContextRulesAny"; - return RulesPosition2; - })(RulesPosition || {}); - } - }); - - // src/services/formatting/formatting.ts - function createTextRangeWithKind(pos, end, kind) { - const textRangeWithKind = { pos, end, kind }; - if (Debug.isDebugging) { - Object.defineProperty(textRangeWithKind, "__debugKind", { - get: () => Debug.formatSyntaxKind(kind) - }); - } - return textRangeWithKind; + function isLocationProjectReferenceRedirect(project, location) { + if (!location) + return false; + const program = project.getLanguageService().getProgram(); + if (!program) + return false; + const sourceFile = program.getSourceFile(location.fileName); + return !!sourceFile && sourceFile.resolvedPath !== sourceFile.path && sourceFile.resolvedPath !== project.toPath(location.fileName); } - function formatOnEnter(position, sourceFile, formatContext) { - const line = sourceFile.getLineAndCharacterOfPosition(position).line; - if (line === 0) { - return []; - } - let endOfFormatSpan = getEndLinePosition(line, sourceFile); - while (isWhiteSpaceSingleLine(sourceFile.text.charCodeAt(endOfFormatSpan))) { - endOfFormatSpan--; - } - if (isLineBreak(sourceFile.text.charCodeAt(endOfFormatSpan))) { - endOfFormatSpan--; - } - const span = { - // get start position for the previous line - pos: getStartPositionOfLine(line - 1, sourceFile), - // end value is exclusive so add 1 to the result - end: endOfFormatSpan + 1 - }; - return formatSpan(span, sourceFile, formatContext, 2 /* FormatOnEnter */); + function getProjectKey(project) { + return isConfiguredProject(project) ? project.canonicalConfigFilePath : project.getProjectName(); } - function formatOnSemicolon(position, sourceFile, formatContext) { - const semicolon = findImmediatelyPrecedingTokenOfKind(position, 27 /* SemicolonToken */, sourceFile); - return formatNodeLines(findOutermostNodeWithinListLevel(semicolon), sourceFile, formatContext, 3 /* FormatOnSemicolon */); + function documentSpanLocation({ fileName, textSpan }) { + return { fileName, pos: textSpan.start }; } - function formatOnOpeningCurly(position, sourceFile, formatContext) { - const openingCurly = findImmediatelyPrecedingTokenOfKind(position, 19 /* OpenBraceToken */, sourceFile); - if (!openingCurly) { - return []; - } - const curlyBraceRange = openingCurly.parent; - const outermostNode = findOutermostNodeWithinListLevel(curlyBraceRange); - const textRange = { - pos: getLineStartPositionForPosition(outermostNode.getStart(sourceFile), sourceFile), - // TODO: GH#18217 - end: position - }; - return formatSpan(textRange, sourceFile, formatContext, 4 /* FormatOnOpeningCurlyBrace */); + function getMappedLocationForProject(location, project) { + return getMappedLocation(location, project.getSourceMapper(), (p) => project.projectService.fileExists(p)); } - function formatOnClosingCurly(position, sourceFile, formatContext) { - const precedingToken = findImmediatelyPrecedingTokenOfKind(position, 20 /* CloseBraceToken */, sourceFile); - return formatNodeLines(findOutermostNodeWithinListLevel(precedingToken), sourceFile, formatContext, 5 /* FormatOnClosingCurlyBrace */); + function getMappedDocumentSpanForProject(documentSpan, project) { + return getMappedDocumentSpan(documentSpan, project.getSourceMapper(), (p) => project.projectService.fileExists(p)); } - function formatDocument(sourceFile, formatContext) { - const span = { - pos: 0, - end: sourceFile.text.length - }; - return formatSpan(span, sourceFile, formatContext, 0 /* FormatDocument */); + function getMappedContextSpanForProject(documentSpan, project) { + return getMappedContextSpan(documentSpan, project.getSourceMapper(), (p) => project.projectService.fileExists(p)); } - function formatSelection(start, end, sourceFile, formatContext) { - const span = { - pos: getLineStartPositionForPosition(start, sourceFile), - end + function toProtocolTextSpan(textSpan, scriptInfo) { + return { + start: scriptInfo.positionToLineOffset(textSpan.start), + end: scriptInfo.positionToLineOffset(textSpanEnd(textSpan)) }; - return formatSpan(span, sourceFile, formatContext, 1 /* FormatSelection */); } - function findImmediatelyPrecedingTokenOfKind(end, expectedTokenKind, sourceFile) { - const precedingToken = findPrecedingToken(end, sourceFile); - return precedingToken && precedingToken.kind === expectedTokenKind && end === precedingToken.getEnd() ? precedingToken : void 0; + function toProtocolTextSpanWithContext(span, contextSpan, scriptInfo) { + const textSpan = toProtocolTextSpan(span, scriptInfo); + const contextTextSpan = contextSpan && toProtocolTextSpan(contextSpan, scriptInfo); + return contextTextSpan ? { ...textSpan, contextStart: contextTextSpan.start, contextEnd: contextTextSpan.end } : textSpan; } - function findOutermostNodeWithinListLevel(node) { - let current = node; - while (current && current.parent && current.parent.end === node.end && !isListElement(current.parent, current)) { - current = current.parent; - } - return current; + function convertTextChangeToCodeEdit(change, scriptInfo) { + return { start: positionToLineOffset(scriptInfo, change.span.start), end: positionToLineOffset(scriptInfo, textSpanEnd(change.span)), newText: change.newText }; } - function isListElement(parent2, node) { - switch (parent2.kind) { - case 262 /* ClassDeclaration */: - case 263 /* InterfaceDeclaration */: - return rangeContainsRange(parent2.members, node); - case 266 /* ModuleDeclaration */: - const body = parent2.body; - return !!body && body.kind === 267 /* ModuleBlock */ && rangeContainsRange(body.statements, node); - case 311 /* SourceFile */: - case 240 /* Block */: - case 267 /* ModuleBlock */: - return rangeContainsRange(parent2.statements, node); - case 298 /* CatchClause */: - return rangeContainsRange(parent2.block.statements, node); - } - return false; + function positionToLineOffset(info, position) { + return isConfigFile(info) ? locationFromLineAndCharacter(info.getLineAndCharacterOfPosition(position)) : info.positionToLineOffset(position); } - function findEnclosingNode(range, sourceFile) { - return find2(sourceFile); - function find2(n) { - const candidate = forEachChild(n, (c) => startEndContainsRange(c.getStart(sourceFile), c.end, range) && c); - if (candidate) { - const result = find2(candidate); - if (result) { - return result; - } + function convertLinkedEditInfoToRanges(linkedEdit, scriptInfo) { + const ranges = linkedEdit.ranges.map( + (r) => { + return { + start: scriptInfo.positionToLineOffset(r.start), + end: scriptInfo.positionToLineOffset(r.start + r.length) + }; } - return n; - } + ); + if (!linkedEdit.wordPattern) + return { ranges }; + return { ranges, wordPattern: linkedEdit.wordPattern }; } - function prepareRangeContainsErrorFunction(errors, originalRange) { - if (!errors.length) { - return rangeHasNoErrors; - } - const sorted = errors.filter((d) => rangeOverlapsWithStartEnd(originalRange, d.start, d.start + d.length)).sort((e1, e2) => e1.start - e2.start); - if (!sorted.length) { - return rangeHasNoErrors; - } - let index = 0; - return (r) => { - while (true) { - if (index >= sorted.length) { - return false; - } - const error = sorted[index]; - if (r.end <= error.start) { - return false; - } - if (startEndOverlapsWithStartEnd(r.pos, r.end, error.start, error.start + error.length)) { - return true; - } - index++; - } - }; - function rangeHasNoErrors() { - return false; - } + function locationFromLineAndCharacter(lc) { + return { line: lc.line + 1, offset: lc.character + 1 }; } - function getScanStartPosition(enclosingNode, originalRange, sourceFile) { - const start = enclosingNode.getStart(sourceFile); - if (start === originalRange.pos && enclosingNode.end === originalRange.end) { - return start; - } - const precedingToken = findPrecedingToken(originalRange.pos, sourceFile); - if (!precedingToken) { - return enclosingNode.pos; - } - if (precedingToken.end >= originalRange.pos) { - return enclosingNode.pos; - } - return precedingToken.end; + function convertNewFileTextChangeToCodeEdit(textChanges2) { + Debug.assert(textChanges2.textChanges.length === 1); + const change = first(textChanges2.textChanges); + Debug.assert(change.span.start === 0 && change.span.length === 0); + return { fileName: textChanges2.fileName, textChanges: [{ start: { line: 0, offset: 0 }, end: { line: 0, offset: 0 }, newText: change.newText }] }; } - function getOwnOrInheritedDelta(n, options, sourceFile) { - let previousLine = -1 /* Unknown */; - let child; - while (n) { - const line = sourceFile.getLineAndCharacterOfPosition(n.getStart(sourceFile)).line; - if (previousLine !== -1 /* Unknown */ && line !== previousLine) { - break; + function getLocationInNewDocument(oldText, renameFilename, renameLocation, edits) { + const newText = applyEdits(oldText, renameFilename, edits); + const { line, character } = computeLineAndCharacterOfPosition(computeLineStarts(newText), renameLocation); + return { line: line + 1, offset: character + 1 }; + } + function applyEdits(text, textFilename, edits) { + for (const { fileName, textChanges: textChanges2 } of edits) { + if (fileName !== textFilename) { + continue; } - if (SmartIndenter.shouldIndentChildNode(options, n, child, sourceFile)) { - return options.indentSize; + for (let i = textChanges2.length - 1; i >= 0; i--) { + const { newText, span: { start, length: length2 } } = textChanges2[i]; + text = text.slice(0, start) + newText + text.slice(start + length2); } - previousLine = line; - child = n; - n = n.parent; } - return 0; - } - function formatNodeGivenIndentation(node, sourceFileLike, languageVariant, initialIndentation, delta, formatContext) { - const range = { pos: node.pos, end: node.end }; - return getFormattingScanner(sourceFileLike.text, languageVariant, range.pos, range.end, (scanner2) => formatSpanWorker( - range, - node, - initialIndentation, - delta, - scanner2, - formatContext, - 1 /* FormatSelection */, - (_) => false, - // assume that node does not have any errors - sourceFileLike - )); + return text; } - function formatNodeLines(node, sourceFile, formatContext, requestKind) { - if (!node) { - return []; - } - const span = { - pos: getLineStartPositionForPosition(node.getStart(sourceFile), sourceFile), - end: node.end + function referenceEntryToReferencesResponseItem(projectService, { fileName, textSpan, contextSpan, isWriteAccess: isWriteAccess2, isDefinition }, { disableLineTextInReferences }) { + const scriptInfo = Debug.checkDefined(projectService.getScriptInfo(fileName)); + const span = toProtocolTextSpanWithContext(textSpan, contextSpan, scriptInfo); + const lineText = disableLineTextInReferences ? void 0 : getLineText(scriptInfo, span); + return { + file: fileName, + ...span, + lineText, + isWriteAccess: isWriteAccess2, + isDefinition }; - return formatSpan(span, sourceFile, formatContext, requestKind); } - function formatSpan(originalRange, sourceFile, formatContext, requestKind) { - const enclosingNode = findEnclosingNode(originalRange, sourceFile); - return getFormattingScanner( - sourceFile.text, - sourceFile.languageVariant, - getScanStartPosition(enclosingNode, originalRange, sourceFile), - originalRange.end, - (scanner2) => formatSpanWorker( - originalRange, - enclosingNode, - SmartIndenter.getIndentationForNode(enclosingNode, originalRange, sourceFile, formatContext.options), - getOwnOrInheritedDelta(enclosingNode, formatContext.options, sourceFile), - scanner2, - formatContext, - requestKind, - prepareRangeContainsErrorFunction(sourceFile.parseDiagnostics, originalRange), - sourceFile - ) - ); + function getLineText(scriptInfo, span) { + const lineSpan = scriptInfo.lineToTextSpan(span.start.line - 1); + return scriptInfo.getSnapshot().getText(lineSpan.start, textSpanEnd(lineSpan)).replace(/\r|\n/g, ""); } - function formatSpanWorker(originalRange, enclosingNode, initialIndentation, delta, formattingScanner, { options, getRules, host }, requestKind, rangeContainsError, sourceFile) { - var _a; - const formattingContext = new FormattingContext(sourceFile, requestKind, options); - let previousRangeTriviaEnd; - let previousRange; - let previousParent; - let previousRangeStartLine; - let lastIndentedLine; - let indentationOnLastIndentedLine = -1 /* Unknown */; - const edits = []; - formattingScanner.advance(); - if (formattingScanner.isOnToken()) { - const startLine = sourceFile.getLineAndCharacterOfPosition(enclosingNode.getStart(sourceFile)).line; - let undecoratedStartLine = startLine; - if (hasDecorators(enclosingNode)) { - undecoratedStartLine = sourceFile.getLineAndCharacterOfPosition(getNonDecoratorTokenPosOfNode(enclosingNode, sourceFile)).line; - } - processNode(enclosingNode, enclosingNode, startLine, undecoratedStartLine, initialIndentation, delta); - } - if (!formattingScanner.isOnToken()) { - const indentation = SmartIndenter.nodeWillIndentChild( - options, - enclosingNode, - /*child*/ - void 0, - sourceFile, - /*indentByDefault*/ - false - ) ? initialIndentation + options.indentSize : initialIndentation; - const leadingTrivia = formattingScanner.getCurrentLeadingTrivia(); - if (leadingTrivia) { - indentTriviaItems( - leadingTrivia, - indentation, - /*indentNextTokenOrTrivia*/ - false, - (item) => processRange( - item, - sourceFile.getLineAndCharacterOfPosition(item.pos), - enclosingNode, - enclosingNode, - /*dynamicIndentation*/ - void 0 - ) - ); - if (options.trimTrailingWhitespace !== false) { - trimTrailingWhitespacesForRemainingRange(leadingTrivia); + function isCompletionEntryData(data) { + return data === void 0 || data && typeof data === "object" && typeof data.exportName === "string" && (data.fileName === void 0 || typeof data.fileName === "string") && (data.ambientModuleName === void 0 || typeof data.ambientModuleName === "string" && (data.isPackageJsonImport === void 0 || typeof data.isPackageJsonImport === "boolean")); + } + var nullCancellationToken, CommandNames, MultistepOperation, invalidPartialSemanticModeCommands, invalidSyntacticModeCommands, Session3; + var init_session = __esm({ + "src/server/session.ts"() { + "use strict"; + init_ts7(); + init_ts_server3(); + init_protocol(); + nullCancellationToken = { + isCancellationRequested: () => false, + setRequest: () => void 0, + resetRequest: () => void 0 + }; + CommandNames = CommandTypes; + MultistepOperation = class { + constructor(operationHost) { + this.operationHost = operationHost; + } + startNew(action) { + this.complete(); + this.requestId = this.operationHost.getCurrentRequestId(); + this.executeAction(action); + } + complete() { + if (this.requestId !== void 0) { + this.operationHost.sendRequestCompletedEvent(this.requestId); + this.requestId = void 0; + } + this.setTimerHandle(void 0); + this.setImmediateId(void 0); + } + immediate(actionType, action) { + const requestId = this.requestId; + Debug.assert(requestId === this.operationHost.getCurrentRequestId(), "immediate: incorrect request id"); + this.setImmediateId( + this.operationHost.getServerHost().setImmediate(() => { + this.immediateId = void 0; + this.operationHost.executeWithRequestId(requestId, () => this.executeAction(action)); + }, actionType) + ); } - } - } - if (previousRange && formattingScanner.getTokenFullStart() >= originalRange.end) { - const tokenInfo = formattingScanner.isOnEOF() ? formattingScanner.readEOFTokenRange() : formattingScanner.isOnToken() ? formattingScanner.readTokenInfo(enclosingNode).token : void 0; - if (tokenInfo && tokenInfo.pos === previousRangeTriviaEnd) { - const parent2 = ((_a = findPrecedingToken(tokenInfo.end, sourceFile, enclosingNode)) == null ? void 0 : _a.parent) || previousParent; - processPair( - tokenInfo, - sourceFile.getLineAndCharacterOfPosition(tokenInfo.pos).line, - parent2, - previousRange, - previousRangeStartLine, - previousParent, - parent2, - /*dynamicIndentation*/ - void 0 - ); - } - } - return edits; - function tryComputeIndentationForListItem(startPos, endPos, parentStartLine, range, inheritedIndentation) { - if (rangeOverlapsWithStartEnd(range, startPos, endPos) || rangeContainsStartEnd(range, startPos, endPos)) { - if (inheritedIndentation !== -1 /* Unknown */) { - return inheritedIndentation; + delay(actionType, ms, action) { + const requestId = this.requestId; + Debug.assert(requestId === this.operationHost.getCurrentRequestId(), "delay: incorrect request id"); + this.setTimerHandle( + this.operationHost.getServerHost().setTimeout( + () => { + this.timerHandle = void 0; + this.operationHost.executeWithRequestId(requestId, () => this.executeAction(action)); + }, + ms, + actionType + ) + ); } - } else { - const startLine = sourceFile.getLineAndCharacterOfPosition(startPos).line; - const startLinePosition = getLineStartPositionForPosition(startPos, sourceFile); - const column = SmartIndenter.findFirstNonWhitespaceColumn(startLinePosition, startPos, sourceFile, options); - if (startLine !== parentStartLine || startPos === column) { - const baseIndentSize = SmartIndenter.getBaseIndentation(options); - return baseIndentSize > column ? baseIndentSize : column; + executeAction(action) { + var _a, _b, _c, _d, _e, _f; + let stop = false; + try { + if (this.operationHost.isCancellationRequested()) { + stop = true; + (_a = tracing) == null ? void 0 : _a.instant(tracing.Phase.Session, "stepCanceled", { seq: this.requestId, early: true }); + } else { + (_b = tracing) == null ? void 0 : _b.push(tracing.Phase.Session, "stepAction", { seq: this.requestId }); + action(this); + (_c = tracing) == null ? void 0 : _c.pop(); + } + } catch (e) { + (_d = tracing) == null ? void 0 : _d.popAll(); + stop = true; + if (e instanceof OperationCanceledException) { + (_e = tracing) == null ? void 0 : _e.instant(tracing.Phase.Session, "stepCanceled", { seq: this.requestId }); + } else { + (_f = tracing) == null ? void 0 : _f.instant(tracing.Phase.Session, "stepError", { seq: this.requestId, message: e.message }); + this.operationHost.logError(e, `delayed processing of request ${this.requestId}`); + } + } + if (stop || !this.hasPendingWork()) { + this.complete(); + } + } + setTimerHandle(timerHandle) { + if (this.timerHandle !== void 0) { + this.operationHost.getServerHost().clearTimeout(this.timerHandle); + } + this.timerHandle = timerHandle; + } + setImmediateId(immediateId) { + if (this.immediateId !== void 0) { + this.operationHost.getServerHost().clearImmediate(this.immediateId); + } + this.immediateId = immediateId; + } + hasPendingWork() { + return !!this.timerHandle || !!this.immediateId; + } + }; + invalidPartialSemanticModeCommands = [ + "openExternalProject" /* OpenExternalProject */, + "openExternalProjects" /* OpenExternalProjects */, + "closeExternalProject" /* CloseExternalProject */, + "synchronizeProjectList" /* SynchronizeProjectList */, + "emit-output" /* EmitOutput */, + "compileOnSaveAffectedFileList" /* CompileOnSaveAffectedFileList */, + "compileOnSaveEmitFile" /* CompileOnSaveEmitFile */, + "compilerOptionsDiagnostics-full" /* CompilerOptionsDiagnosticsFull */, + "encodedSemanticClassifications-full" /* EncodedSemanticClassificationsFull */, + "semanticDiagnosticsSync" /* SemanticDiagnosticsSync */, + "suggestionDiagnosticsSync" /* SuggestionDiagnosticsSync */, + "geterrForProject" /* GeterrForProject */, + "reload" /* Reload */, + "reloadProjects" /* ReloadProjects */, + "getCodeFixes" /* GetCodeFixes */, + "getCodeFixes-full" /* GetCodeFixesFull */, + "getCombinedCodeFix" /* GetCombinedCodeFix */, + "getCombinedCodeFix-full" /* GetCombinedCodeFixFull */, + "applyCodeActionCommand" /* ApplyCodeActionCommand */, + "getSupportedCodeFixes" /* GetSupportedCodeFixes */, + "getApplicableRefactors" /* GetApplicableRefactors */, + "getMoveToRefactoringFileSuggestions" /* GetMoveToRefactoringFileSuggestions */, + "getEditsForRefactor" /* GetEditsForRefactor */, + "getEditsForRefactor-full" /* GetEditsForRefactorFull */, + "organizeImports" /* OrganizeImports */, + "organizeImports-full" /* OrganizeImportsFull */, + "getEditsForFileRename" /* GetEditsForFileRename */, + "getEditsForFileRename-full" /* GetEditsForFileRenameFull */, + "prepareCallHierarchy" /* PrepareCallHierarchy */, + "provideCallHierarchyIncomingCalls" /* ProvideCallHierarchyIncomingCalls */, + "provideCallHierarchyOutgoingCalls" /* ProvideCallHierarchyOutgoingCalls */ + ]; + invalidSyntacticModeCommands = [ + ...invalidPartialSemanticModeCommands, + "definition" /* Definition */, + "definition-full" /* DefinitionFull */, + "definitionAndBoundSpan" /* DefinitionAndBoundSpan */, + "definitionAndBoundSpan-full" /* DefinitionAndBoundSpanFull */, + "typeDefinition" /* TypeDefinition */, + "implementation" /* Implementation */, + "implementation-full" /* ImplementationFull */, + "references" /* References */, + "references-full" /* ReferencesFull */, + "rename" /* Rename */, + "renameLocations-full" /* RenameLocationsFull */, + "rename-full" /* RenameInfoFull */, + "quickinfo" /* Quickinfo */, + "quickinfo-full" /* QuickinfoFull */, + "completionInfo" /* CompletionInfo */, + "completions" /* Completions */, + "completions-full" /* CompletionsFull */, + "completionEntryDetails" /* CompletionDetails */, + "completionEntryDetails-full" /* CompletionDetailsFull */, + "signatureHelp" /* SignatureHelp */, + "signatureHelp-full" /* SignatureHelpFull */, + "navto" /* Navto */, + "navto-full" /* NavtoFull */, + "documentHighlights" /* DocumentHighlights */, + "documentHighlights-full" /* DocumentHighlightsFull */ + ]; + Session3 = class _Session { + constructor(opts) { + this.changeSeq = 0; + this.handlers = new Map(Object.entries({ + // TODO(jakebailey): correctly type the handlers + ["status" /* Status */]: () => { + const response = { version }; + return this.requiredResponse(response); + }, + ["openExternalProject" /* OpenExternalProject */]: (request) => { + this.projectService.openExternalProject(request.arguments); + return this.requiredResponse( + /*response*/ + true + ); + }, + ["openExternalProjects" /* OpenExternalProjects */]: (request) => { + this.projectService.openExternalProjects(request.arguments.projects); + return this.requiredResponse( + /*response*/ + true + ); + }, + ["closeExternalProject" /* CloseExternalProject */]: (request) => { + this.projectService.closeExternalProject(request.arguments.projectFileName); + return this.requiredResponse( + /*response*/ + true + ); + }, + ["synchronizeProjectList" /* SynchronizeProjectList */]: (request) => { + const result = this.projectService.synchronizeProjectList(request.arguments.knownProjects, request.arguments.includeProjectReferenceRedirectInfo); + if (!result.some((p) => p.projectErrors && p.projectErrors.length !== 0)) { + return this.requiredResponse(result); + } + const converted = map(result, (p) => { + if (!p.projectErrors || p.projectErrors.length === 0) { + return p; + } + return { + info: p.info, + changes: p.changes, + files: p.files, + projectErrors: this.convertToDiagnosticsWithLinePosition( + p.projectErrors, + /*scriptInfo*/ + void 0 + ) + }; + }); + return this.requiredResponse(converted); + }, + ["updateOpen" /* UpdateOpen */]: (request) => { + this.changeSeq++; + this.projectService.applyChangesInOpenFiles( + request.arguments.openFiles && mapIterator(request.arguments.openFiles, (file) => ({ + fileName: file.file, + content: file.fileContent, + scriptKind: file.scriptKindName, + projectRootPath: file.projectRootPath + })), + request.arguments.changedFiles && mapIterator(request.arguments.changedFiles, (file) => ({ + fileName: file.fileName, + changes: mapDefinedIterator(arrayReverseIterator(file.textChanges), (change) => { + const scriptInfo = Debug.checkDefined(this.projectService.getScriptInfo(file.fileName)); + const start = scriptInfo.lineOffsetToPosition(change.start.line, change.start.offset); + const end = scriptInfo.lineOffsetToPosition(change.end.line, change.end.offset); + return start >= 0 ? { span: { start, length: end - start }, newText: change.newText } : void 0; + }) + })), + request.arguments.closedFiles + ); + return this.requiredResponse( + /*response*/ + true + ); + }, + ["applyChangedToOpenFiles" /* ApplyChangedToOpenFiles */]: (request) => { + this.changeSeq++; + this.projectService.applyChangesInOpenFiles( + request.arguments.openFiles, + request.arguments.changedFiles && mapIterator(request.arguments.changedFiles, (file) => ({ + fileName: file.fileName, + // apply changes in reverse order + changes: arrayReverseIterator(file.changes) + })), + request.arguments.closedFiles + ); + return this.requiredResponse( + /*response*/ + true + ); + }, + ["exit" /* Exit */]: () => { + this.exit(); + return this.notRequired(); + }, + ["definition" /* Definition */]: (request) => { + return this.requiredResponse(this.getDefinition( + request.arguments, + /*simplifiedResult*/ + true + )); + }, + ["definition-full" /* DefinitionFull */]: (request) => { + return this.requiredResponse(this.getDefinition( + request.arguments, + /*simplifiedResult*/ + false + )); + }, + ["definitionAndBoundSpan" /* DefinitionAndBoundSpan */]: (request) => { + return this.requiredResponse(this.getDefinitionAndBoundSpan( + request.arguments, + /*simplifiedResult*/ + true + )); + }, + ["definitionAndBoundSpan-full" /* DefinitionAndBoundSpanFull */]: (request) => { + return this.requiredResponse(this.getDefinitionAndBoundSpan( + request.arguments, + /*simplifiedResult*/ + false + )); + }, + ["findSourceDefinition" /* FindSourceDefinition */]: (request) => { + return this.requiredResponse(this.findSourceDefinition(request.arguments)); + }, + ["emit-output" /* EmitOutput */]: (request) => { + return this.requiredResponse(this.getEmitOutput(request.arguments)); + }, + ["typeDefinition" /* TypeDefinition */]: (request) => { + return this.requiredResponse(this.getTypeDefinition(request.arguments)); + }, + ["implementation" /* Implementation */]: (request) => { + return this.requiredResponse(this.getImplementation( + request.arguments, + /*simplifiedResult*/ + true + )); + }, + ["implementation-full" /* ImplementationFull */]: (request) => { + return this.requiredResponse(this.getImplementation( + request.arguments, + /*simplifiedResult*/ + false + )); + }, + ["references" /* References */]: (request) => { + return this.requiredResponse(this.getReferences( + request.arguments, + /*simplifiedResult*/ + true + )); + }, + ["references-full" /* ReferencesFull */]: (request) => { + return this.requiredResponse(this.getReferences( + request.arguments, + /*simplifiedResult*/ + false + )); + }, + ["rename" /* Rename */]: (request) => { + return this.requiredResponse(this.getRenameLocations( + request.arguments, + /*simplifiedResult*/ + true + )); + }, + ["renameLocations-full" /* RenameLocationsFull */]: (request) => { + return this.requiredResponse(this.getRenameLocations( + request.arguments, + /*simplifiedResult*/ + false + )); + }, + ["rename-full" /* RenameInfoFull */]: (request) => { + return this.requiredResponse(this.getRenameInfo(request.arguments)); + }, + ["open" /* Open */]: (request) => { + this.openClientFile( + toNormalizedPath(request.arguments.file), + request.arguments.fileContent, + convertScriptKindName(request.arguments.scriptKindName), + // TODO: GH#18217 + request.arguments.projectRootPath ? toNormalizedPath(request.arguments.projectRootPath) : void 0 + ); + return this.notRequired(); + }, + ["quickinfo" /* Quickinfo */]: (request) => { + return this.requiredResponse(this.getQuickInfoWorker( + request.arguments, + /*simplifiedResult*/ + true + )); + }, + ["quickinfo-full" /* QuickinfoFull */]: (request) => { + return this.requiredResponse(this.getQuickInfoWorker( + request.arguments, + /*simplifiedResult*/ + false + )); + }, + ["getOutliningSpans" /* GetOutliningSpans */]: (request) => { + return this.requiredResponse(this.getOutliningSpans( + request.arguments, + /*simplifiedResult*/ + true + )); + }, + ["outliningSpans" /* GetOutliningSpansFull */]: (request) => { + return this.requiredResponse(this.getOutliningSpans( + request.arguments, + /*simplifiedResult*/ + false + )); + }, + ["todoComments" /* TodoComments */]: (request) => { + return this.requiredResponse(this.getTodoComments(request.arguments)); + }, + ["indentation" /* Indentation */]: (request) => { + return this.requiredResponse(this.getIndentation(request.arguments)); + }, + ["nameOrDottedNameSpan" /* NameOrDottedNameSpan */]: (request) => { + return this.requiredResponse(this.getNameOrDottedNameSpan(request.arguments)); + }, + ["breakpointStatement" /* BreakpointStatement */]: (request) => { + return this.requiredResponse(this.getBreakpointStatement(request.arguments)); + }, + ["braceCompletion" /* BraceCompletion */]: (request) => { + return this.requiredResponse(this.isValidBraceCompletion(request.arguments)); + }, + ["docCommentTemplate" /* DocCommentTemplate */]: (request) => { + return this.requiredResponse(this.getDocCommentTemplate(request.arguments)); + }, + ["getSpanOfEnclosingComment" /* GetSpanOfEnclosingComment */]: (request) => { + return this.requiredResponse(this.getSpanOfEnclosingComment(request.arguments)); + }, + ["fileReferences" /* FileReferences */]: (request) => { + return this.requiredResponse(this.getFileReferences( + request.arguments, + /*simplifiedResult*/ + true + )); + }, + ["fileReferences-full" /* FileReferencesFull */]: (request) => { + return this.requiredResponse(this.getFileReferences( + request.arguments, + /*simplifiedResult*/ + false + )); + }, + ["format" /* Format */]: (request) => { + return this.requiredResponse(this.getFormattingEditsForRange(request.arguments)); + }, + ["formatonkey" /* Formatonkey */]: (request) => { + return this.requiredResponse(this.getFormattingEditsAfterKeystroke(request.arguments)); + }, + ["format-full" /* FormatFull */]: (request) => { + return this.requiredResponse(this.getFormattingEditsForDocumentFull(request.arguments)); + }, + ["formatonkey-full" /* FormatonkeyFull */]: (request) => { + return this.requiredResponse(this.getFormattingEditsAfterKeystrokeFull(request.arguments)); + }, + ["formatRange-full" /* FormatRangeFull */]: (request) => { + return this.requiredResponse(this.getFormattingEditsForRangeFull(request.arguments)); + }, + ["completionInfo" /* CompletionInfo */]: (request) => { + return this.requiredResponse(this.getCompletions(request.arguments, "completionInfo" /* CompletionInfo */)); + }, + ["completions" /* Completions */]: (request) => { + return this.requiredResponse(this.getCompletions(request.arguments, "completions" /* Completions */)); + }, + ["completions-full" /* CompletionsFull */]: (request) => { + return this.requiredResponse(this.getCompletions(request.arguments, "completions-full" /* CompletionsFull */)); + }, + ["completionEntryDetails" /* CompletionDetails */]: (request) => { + return this.requiredResponse(this.getCompletionEntryDetails( + request.arguments, + /*fullResult*/ + false + )); + }, + ["completionEntryDetails-full" /* CompletionDetailsFull */]: (request) => { + return this.requiredResponse(this.getCompletionEntryDetails( + request.arguments, + /*fullResult*/ + true + )); + }, + ["compileOnSaveAffectedFileList" /* CompileOnSaveAffectedFileList */]: (request) => { + return this.requiredResponse(this.getCompileOnSaveAffectedFileList(request.arguments)); + }, + ["compileOnSaveEmitFile" /* CompileOnSaveEmitFile */]: (request) => { + return this.requiredResponse(this.emitFile(request.arguments)); + }, + ["signatureHelp" /* SignatureHelp */]: (request) => { + return this.requiredResponse(this.getSignatureHelpItems( + request.arguments, + /*simplifiedResult*/ + true + )); + }, + ["signatureHelp-full" /* SignatureHelpFull */]: (request) => { + return this.requiredResponse(this.getSignatureHelpItems( + request.arguments, + /*simplifiedResult*/ + false + )); + }, + ["compilerOptionsDiagnostics-full" /* CompilerOptionsDiagnosticsFull */]: (request) => { + return this.requiredResponse(this.getCompilerOptionsDiagnostics(request.arguments)); + }, + ["encodedSyntacticClassifications-full" /* EncodedSyntacticClassificationsFull */]: (request) => { + return this.requiredResponse(this.getEncodedSyntacticClassifications(request.arguments)); + }, + ["encodedSemanticClassifications-full" /* EncodedSemanticClassificationsFull */]: (request) => { + return this.requiredResponse(this.getEncodedSemanticClassifications(request.arguments)); + }, + ["cleanup" /* Cleanup */]: () => { + this.cleanup(); + return this.requiredResponse( + /*response*/ + true + ); + }, + ["semanticDiagnosticsSync" /* SemanticDiagnosticsSync */]: (request) => { + return this.requiredResponse(this.getSemanticDiagnosticsSync(request.arguments)); + }, + ["syntacticDiagnosticsSync" /* SyntacticDiagnosticsSync */]: (request) => { + return this.requiredResponse(this.getSyntacticDiagnosticsSync(request.arguments)); + }, + ["suggestionDiagnosticsSync" /* SuggestionDiagnosticsSync */]: (request) => { + return this.requiredResponse(this.getSuggestionDiagnosticsSync(request.arguments)); + }, + ["geterr" /* Geterr */]: (request) => { + this.errorCheck.startNew((next) => this.getDiagnostics(next, request.arguments.delay, request.arguments.files)); + return this.notRequired(); + }, + ["geterrForProject" /* GeterrForProject */]: (request) => { + this.errorCheck.startNew((next) => this.getDiagnosticsForProject(next, request.arguments.delay, request.arguments.file)); + return this.notRequired(); + }, + ["change" /* Change */]: (request) => { + this.change(request.arguments); + return this.notRequired(); + }, + ["configure" /* Configure */]: (request) => { + this.projectService.setHostConfiguration(request.arguments); + this.doOutput( + /*info*/ + void 0, + "configure" /* Configure */, + request.seq, + /*success*/ + true + ); + return this.notRequired(); + }, + ["reload" /* Reload */]: (request) => { + this.reload(request.arguments, request.seq); + return this.requiredResponse({ reloadFinished: true }); + }, + ["saveto" /* Saveto */]: (request) => { + const savetoArgs = request.arguments; + this.saveToTmp(savetoArgs.file, savetoArgs.tmpfile); + return this.notRequired(); + }, + ["close" /* Close */]: (request) => { + const closeArgs = request.arguments; + this.closeClientFile(closeArgs.file); + return this.notRequired(); + }, + ["navto" /* Navto */]: (request) => { + return this.requiredResponse(this.getNavigateToItems( + request.arguments, + /*simplifiedResult*/ + true + )); + }, + ["navto-full" /* NavtoFull */]: (request) => { + return this.requiredResponse(this.getNavigateToItems( + request.arguments, + /*simplifiedResult*/ + false + )); + }, + ["brace" /* Brace */]: (request) => { + return this.requiredResponse(this.getBraceMatching( + request.arguments, + /*simplifiedResult*/ + true + )); + }, + ["brace-full" /* BraceFull */]: (request) => { + return this.requiredResponse(this.getBraceMatching( + request.arguments, + /*simplifiedResult*/ + false + )); + }, + ["navbar" /* NavBar */]: (request) => { + return this.requiredResponse(this.getNavigationBarItems( + request.arguments, + /*simplifiedResult*/ + true + )); + }, + ["navbar-full" /* NavBarFull */]: (request) => { + return this.requiredResponse(this.getNavigationBarItems( + request.arguments, + /*simplifiedResult*/ + false + )); + }, + ["navtree" /* NavTree */]: (request) => { + return this.requiredResponse(this.getNavigationTree( + request.arguments, + /*simplifiedResult*/ + true + )); + }, + ["navtree-full" /* NavTreeFull */]: (request) => { + return this.requiredResponse(this.getNavigationTree( + request.arguments, + /*simplifiedResult*/ + false + )); + }, + ["documentHighlights" /* DocumentHighlights */]: (request) => { + return this.requiredResponse(this.getDocumentHighlights( + request.arguments, + /*simplifiedResult*/ + true + )); + }, + ["documentHighlights-full" /* DocumentHighlightsFull */]: (request) => { + return this.requiredResponse(this.getDocumentHighlights( + request.arguments, + /*simplifiedResult*/ + false + )); + }, + ["compilerOptionsForInferredProjects" /* CompilerOptionsForInferredProjects */]: (request) => { + this.setCompilerOptionsForInferredProjects(request.arguments); + return this.requiredResponse( + /*response*/ + true + ); + }, + ["projectInfo" /* ProjectInfo */]: (request) => { + return this.requiredResponse(this.getProjectInfo(request.arguments)); + }, + ["reloadProjects" /* ReloadProjects */]: () => { + this.projectService.reloadProjects(); + return this.notRequired(); + }, + ["jsxClosingTag" /* JsxClosingTag */]: (request) => { + return this.requiredResponse(this.getJsxClosingTag(request.arguments)); + }, + ["linkedEditingRange" /* LinkedEditingRange */]: (request) => { + return this.requiredResponse(this.getLinkedEditingRange(request.arguments)); + }, + ["getCodeFixes" /* GetCodeFixes */]: (request) => { + return this.requiredResponse(this.getCodeFixes( + request.arguments, + /*simplifiedResult*/ + true + )); + }, + ["getCodeFixes-full" /* GetCodeFixesFull */]: (request) => { + return this.requiredResponse(this.getCodeFixes( + request.arguments, + /*simplifiedResult*/ + false + )); + }, + ["getCombinedCodeFix" /* GetCombinedCodeFix */]: (request) => { + return this.requiredResponse(this.getCombinedCodeFix( + request.arguments, + /*simplifiedResult*/ + true + )); + }, + ["getCombinedCodeFix-full" /* GetCombinedCodeFixFull */]: (request) => { + return this.requiredResponse(this.getCombinedCodeFix( + request.arguments, + /*simplifiedResult*/ + false + )); + }, + ["applyCodeActionCommand" /* ApplyCodeActionCommand */]: (request) => { + return this.requiredResponse(this.applyCodeActionCommand(request.arguments)); + }, + ["getSupportedCodeFixes" /* GetSupportedCodeFixes */]: (request) => { + return this.requiredResponse(this.getSupportedCodeFixes(request.arguments)); + }, + ["getApplicableRefactors" /* GetApplicableRefactors */]: (request) => { + return this.requiredResponse(this.getApplicableRefactors(request.arguments)); + }, + ["getEditsForRefactor" /* GetEditsForRefactor */]: (request) => { + return this.requiredResponse(this.getEditsForRefactor( + request.arguments, + /*simplifiedResult*/ + true + )); + }, + ["getMoveToRefactoringFileSuggestions" /* GetMoveToRefactoringFileSuggestions */]: (request) => { + return this.requiredResponse(this.getMoveToRefactoringFileSuggestions(request.arguments)); + }, + ["getEditsForRefactor-full" /* GetEditsForRefactorFull */]: (request) => { + return this.requiredResponse(this.getEditsForRefactor( + request.arguments, + /*simplifiedResult*/ + false + )); + }, + ["organizeImports" /* OrganizeImports */]: (request) => { + return this.requiredResponse(this.organizeImports( + request.arguments, + /*simplifiedResult*/ + true + )); + }, + ["organizeImports-full" /* OrganizeImportsFull */]: (request) => { + return this.requiredResponse(this.organizeImports( + request.arguments, + /*simplifiedResult*/ + false + )); + }, + ["getEditsForFileRename" /* GetEditsForFileRename */]: (request) => { + return this.requiredResponse(this.getEditsForFileRename( + request.arguments, + /*simplifiedResult*/ + true + )); + }, + ["getEditsForFileRename-full" /* GetEditsForFileRenameFull */]: (request) => { + return this.requiredResponse(this.getEditsForFileRename( + request.arguments, + /*simplifiedResult*/ + false + )); + }, + ["configurePlugin" /* ConfigurePlugin */]: (request) => { + this.configurePlugin(request.arguments); + this.doOutput( + /*info*/ + void 0, + "configurePlugin" /* ConfigurePlugin */, + request.seq, + /*success*/ + true + ); + return this.notRequired(); + }, + ["selectionRange" /* SelectionRange */]: (request) => { + return this.requiredResponse(this.getSmartSelectionRange( + request.arguments, + /*simplifiedResult*/ + true + )); + }, + ["selectionRange-full" /* SelectionRangeFull */]: (request) => { + return this.requiredResponse(this.getSmartSelectionRange( + request.arguments, + /*simplifiedResult*/ + false + )); + }, + ["prepareCallHierarchy" /* PrepareCallHierarchy */]: (request) => { + return this.requiredResponse(this.prepareCallHierarchy(request.arguments)); + }, + ["provideCallHierarchyIncomingCalls" /* ProvideCallHierarchyIncomingCalls */]: (request) => { + return this.requiredResponse(this.provideCallHierarchyIncomingCalls(request.arguments)); + }, + ["provideCallHierarchyOutgoingCalls" /* ProvideCallHierarchyOutgoingCalls */]: (request) => { + return this.requiredResponse(this.provideCallHierarchyOutgoingCalls(request.arguments)); + }, + ["toggleLineComment" /* ToggleLineComment */]: (request) => { + return this.requiredResponse(this.toggleLineComment( + request.arguments, + /*simplifiedResult*/ + true + )); + }, + ["toggleLineComment-full" /* ToggleLineCommentFull */]: (request) => { + return this.requiredResponse(this.toggleLineComment( + request.arguments, + /*simplifiedResult*/ + false + )); + }, + ["toggleMultilineComment" /* ToggleMultilineComment */]: (request) => { + return this.requiredResponse(this.toggleMultilineComment( + request.arguments, + /*simplifiedResult*/ + true + )); + }, + ["toggleMultilineComment-full" /* ToggleMultilineCommentFull */]: (request) => { + return this.requiredResponse(this.toggleMultilineComment( + request.arguments, + /*simplifiedResult*/ + false + )); + }, + ["commentSelection" /* CommentSelection */]: (request) => { + return this.requiredResponse(this.commentSelection( + request.arguments, + /*simplifiedResult*/ + true + )); + }, + ["commentSelection-full" /* CommentSelectionFull */]: (request) => { + return this.requiredResponse(this.commentSelection( + request.arguments, + /*simplifiedResult*/ + false + )); + }, + ["uncommentSelection" /* UncommentSelection */]: (request) => { + return this.requiredResponse(this.uncommentSelection( + request.arguments, + /*simplifiedResult*/ + true + )); + }, + ["uncommentSelection-full" /* UncommentSelectionFull */]: (request) => { + return this.requiredResponse(this.uncommentSelection( + request.arguments, + /*simplifiedResult*/ + false + )); + }, + ["provideInlayHints" /* ProvideInlayHints */]: (request) => { + return this.requiredResponse(this.provideInlayHints(request.arguments)); + } + })); + this.host = opts.host; + this.cancellationToken = opts.cancellationToken; + this.typingsInstaller = opts.typingsInstaller || nullTypingsInstaller; + this.byteLength = opts.byteLength; + this.hrtime = opts.hrtime; + this.logger = opts.logger; + this.canUseEvents = opts.canUseEvents; + this.suppressDiagnosticEvents = opts.suppressDiagnosticEvents; + this.noGetErrOnBackgroundUpdate = opts.noGetErrOnBackgroundUpdate; + const { throttleWaitMilliseconds } = opts; + this.eventHandler = this.canUseEvents ? opts.eventHandler || ((event) => this.defaultEventHandler(event)) : void 0; + const multistepOperationHost = { + executeWithRequestId: (requestId, action) => this.executeWithRequestId(requestId, action), + getCurrentRequestId: () => this.currentRequestId, + getServerHost: () => this.host, + logError: (err, cmd) => this.logError(err, cmd), + sendRequestCompletedEvent: (requestId) => this.sendRequestCompletedEvent(requestId), + isCancellationRequested: () => this.cancellationToken.isCancellationRequested() + }; + this.errorCheck = new MultistepOperation(multistepOperationHost); + const settings = { + host: this.host, + logger: this.logger, + cancellationToken: this.cancellationToken, + useSingleInferredProject: opts.useSingleInferredProject, + useInferredProjectPerProjectRoot: opts.useInferredProjectPerProjectRoot, + typingsInstaller: this.typingsInstaller, + throttleWaitMilliseconds, + eventHandler: this.eventHandler, + suppressDiagnosticEvents: this.suppressDiagnosticEvents, + globalPlugins: opts.globalPlugins, + pluginProbeLocations: opts.pluginProbeLocations, + allowLocalPluginLoads: opts.allowLocalPluginLoads, + typesMapLocation: opts.typesMapLocation, + serverMode: opts.serverMode, + session: this, + canUseWatchEvents: opts.canUseWatchEvents, + incrementalVerifier: opts.incrementalVerifier + }; + this.projectService = new ProjectService3(settings); + this.projectService.setPerformanceEventHandler(this.performanceEventHandler.bind(this)); + this.gcTimer = new GcTimer( + this.host, + /*delay*/ + 7e3, + this.logger + ); + switch (this.projectService.serverMode) { + case 0 /* Semantic */: + break; + case 1 /* PartialSemantic */: + invalidPartialSemanticModeCommands.forEach( + (commandName) => this.handlers.set(commandName, (request) => { + throw new Error(`Request: ${request.command} not allowed in LanguageServiceMode.PartialSemantic`); + }) + ); + break; + case 2 /* Syntactic */: + invalidSyntacticModeCommands.forEach( + (commandName) => this.handlers.set(commandName, (request) => { + throw new Error(`Request: ${request.command} not allowed in LanguageServiceMode.Syntactic`); + }) + ); + break; + default: + Debug.assertNever(this.projectService.serverMode); + } } - } - return -1 /* Unknown */; - } - function computeIndentation(node, startLine, inheritedIndentation, parent2, parentDynamicIndentation, effectiveParentStartLine) { - const delta2 = SmartIndenter.shouldIndentChildNode(options, node) ? options.indentSize : 0; - if (effectiveParentStartLine === startLine) { - return { - indentation: startLine === lastIndentedLine ? indentationOnLastIndentedLine : parentDynamicIndentation.getIndentation(), - delta: Math.min(options.indentSize, parentDynamicIndentation.getDelta(node) + delta2) - }; - } else if (inheritedIndentation === -1 /* Unknown */) { - if (node.kind === 21 /* OpenParenToken */ && startLine === lastIndentedLine) { - return { indentation: indentationOnLastIndentedLine, delta: parentDynamicIndentation.getDelta(node) }; - } else if (SmartIndenter.childStartsOnTheSameLineWithElseInIfStatement(parent2, node, startLine, sourceFile) || SmartIndenter.childIsUnindentedBranchOfConditionalExpression(parent2, node, startLine, sourceFile) || SmartIndenter.argumentStartsOnSameLineAsPreviousArgument(parent2, node, startLine, sourceFile)) { - return { indentation: parentDynamicIndentation.getIndentation(), delta: delta2 }; - } else { - return { indentation: parentDynamicIndentation.getIndentation() + parentDynamicIndentation.getDelta(node), delta: delta2 }; + sendRequestCompletedEvent(requestId) { + this.event({ request_seq: requestId }, "requestCompleted"); } - } else { - return { indentation: inheritedIndentation, delta: delta2 }; - } - } - function getFirstNonDecoratorTokenOfNode(node) { - if (canHaveModifiers(node)) { - const modifier = find(node.modifiers, isModifier, findIndex(node.modifiers, isDecorator)); - if (modifier) - return modifier.kind; - } - switch (node.kind) { - case 262 /* ClassDeclaration */: - return 86 /* ClassKeyword */; - case 263 /* InterfaceDeclaration */: - return 120 /* InterfaceKeyword */; - case 261 /* FunctionDeclaration */: - return 100 /* FunctionKeyword */; - case 265 /* EnumDeclaration */: - return 265 /* EnumDeclaration */; - case 176 /* GetAccessor */: - return 139 /* GetKeyword */; - case 177 /* SetAccessor */: - return 153 /* SetKeyword */; - case 173 /* MethodDeclaration */: - if (node.asteriskToken) { - return 42 /* AsteriskToken */; + addPerformanceData(key, value) { + if (!this.performanceData) { + this.performanceData = {}; } - case 171 /* PropertyDeclaration */: - case 168 /* Parameter */: - const name = getNameOfDeclaration(node); - if (name) { - return name.kind; + this.performanceData[key] = (this.performanceData[key] ?? 0) + value; + } + performanceEventHandler(event) { + switch (event.kind) { + case "UpdateGraph": + this.addPerformanceData("updateGraphDurationMs", event.durationMs); + break; + case "CreatePackageJsonAutoImportProvider": + this.addPerformanceData("createAutoImportProviderProgramDurationMs", event.durationMs); + break; } - } - } - function getDynamicIndentation(node, nodeStartLine, indentation, delta2) { - return { - getIndentationForComment: (kind, tokenIndentation, container) => { - switch (kind) { - case 20 /* CloseBraceToken */: - case 24 /* CloseBracketToken */: - case 22 /* CloseParenToken */: - return indentation + getDelta(container); + } + defaultEventHandler(event) { + switch (event.eventName) { + case ProjectsUpdatedInBackgroundEvent: + this.projectsUpdatedInBackgroundEvent(event.data.openFiles); + break; + case ProjectLoadingStartEvent: + this.event({ + projectName: event.data.project.getProjectName(), + reason: event.data.reason + }, event.eventName); + break; + case ProjectLoadingFinishEvent: + this.event({ + projectName: event.data.project.getProjectName() + }, event.eventName); + break; + case LargeFileReferencedEvent: + case CreateFileWatcherEvent: + case CreateDirectoryWatcherEvent: + case CloseFileWatcherEvent: + this.event(event.data, event.eventName); + break; + case ConfigFileDiagEvent: + this.event({ + triggerFile: event.data.triggerFile, + configFile: event.data.configFileName, + diagnostics: map(event.data.diagnostics, (diagnostic) => formatDiagnosticToProtocol( + diagnostic, + /*includeFileName*/ + true + )) + }, event.eventName); + break; + case ProjectLanguageServiceStateEvent: { + this.event({ + projectName: event.data.project.getProjectName(), + languageServiceEnabled: event.data.languageServiceEnabled + }, event.eventName); + break; + } + case ProjectInfoTelemetryEvent: { + const eventName = "telemetry"; + this.event({ + telemetryEventName: event.eventName, + payload: event.data + }, eventName); + break; + } } - return tokenIndentation !== -1 /* Unknown */ ? tokenIndentation : indentation; - }, - // if list end token is LessThanToken '>' then its delta should be explicitly suppressed - // so that LessThanToken as a binary operator can still be indented. - // foo.then - // < - // number, - // string, - // >(); - // vs - // var a = xValue - // > yValue; - getIndentationForToken: (line, kind, container, suppressDelta) => !suppressDelta && shouldAddDelta(line, kind, container) ? indentation + getDelta(container) : indentation, - getIndentation: () => indentation, - getDelta, - recomputeIndentation: (lineAdded, parent2) => { - if (SmartIndenter.shouldIndentChildNode(options, parent2, node, sourceFile)) { - indentation += lineAdded ? options.indentSize : -options.indentSize; - delta2 = SmartIndenter.shouldIndentChildNode(options, node) ? options.indentSize : 0; + } + projectsUpdatedInBackgroundEvent(openFiles) { + this.projectService.logger.info(`got projects updated in background, updating diagnostics for ${openFiles}`); + if (openFiles.length) { + if (!this.suppressDiagnosticEvents && !this.noGetErrOnBackgroundUpdate) { + this.errorCheck.startNew((next) => this.updateErrorCheck( + next, + openFiles, + 100, + /*requireOpen*/ + true + )); + } + this.event({ + openFiles + }, ProjectsUpdatedInBackgroundEvent); } } - }; - function shouldAddDelta(line, kind, container) { - switch (kind) { - case 19 /* OpenBraceToken */: - case 20 /* CloseBraceToken */: - case 22 /* CloseParenToken */: - case 93 /* ElseKeyword */: - case 117 /* WhileKeyword */: - case 60 /* AtToken */: - return false; - case 44 /* SlashToken */: - case 32 /* GreaterThanToken */: - switch (container.kind) { - case 285 /* JsxOpeningElement */: - case 286 /* JsxClosingElement */: - case 284 /* JsxSelfClosingElement */: - return false; + logError(err, cmd) { + this.logErrorWorker(err, cmd); + } + logErrorWorker(err, cmd, fileRequest) { + let msg = "Exception on executing command " + cmd; + if (err.message) { + msg += ":\n" + indent2(err.message); + if (err.stack) { + msg += "\n" + indent2(err.stack); } - break; - case 23 /* OpenBracketToken */: - case 24 /* CloseBracketToken */: - if (container.kind !== 199 /* MappedType */) { - return false; + } + if (this.logger.hasLevel(3 /* verbose */)) { + if (fileRequest) { + try { + const { file, project } = this.getFileAndProject(fileRequest); + const scriptInfo = project.getScriptInfoForNormalizedPath(file); + if (scriptInfo) { + const text = getSnapshotText(scriptInfo.getSnapshot()); + msg += ` + +File text of ${fileRequest.file}:${indent2(text)} +`; + } + } catch { + } } - break; - } - return nodeStartLine !== line && !(hasDecorators(node) && kind === getFirstNonDecoratorTokenOfNode(node)); - } - function getDelta(child) { - return SmartIndenter.nodeWillIndentChild( - options, - node, - child, - sourceFile, - /*indentByDefault*/ - true - ) ? delta2 : 0; - } - } - function processNode(node, contextNode, nodeStartLine, undecoratedNodeStartLine, indentation, delta2) { - if (!rangeOverlapsWithStartEnd(originalRange, node.getStart(sourceFile), node.getEnd())) { - return; - } - const nodeDynamicIndentation = getDynamicIndentation(node, nodeStartLine, indentation, delta2); - let childContextNode = contextNode; - forEachChild( - node, - (child) => { - processChildNode( - child, - /*inheritedIndentation*/ - -1 /* Unknown */, - node, - nodeDynamicIndentation, - nodeStartLine, - undecoratedNodeStartLine, - /*isListItem*/ - false - ); - }, - (nodes) => { - processChildNodes(nodes, node, nodeStartLine, nodeDynamicIndentation); + if (err.ProgramFiles) { + msg += ` + +Program files: ${JSON.stringify(err.ProgramFiles)} +`; + msg += ` + +Projects:: +`; + let counter = 0; + const addProjectInfo = (project) => { + msg += ` +Project '${project.projectName}' (${ProjectKind[project.projectKind]}) ${counter} +`; + msg += project.filesToString( + /*writeProjectFileNames*/ + true + ); + msg += "\n-----------------------------------------------\n"; + counter++; + }; + this.projectService.externalProjects.forEach(addProjectInfo); + this.projectService.configuredProjects.forEach(addProjectInfo); + this.projectService.inferredProjects.forEach(addProjectInfo); + } + } + this.logger.msg(msg, "Err" /* Err */); } - ); - while (formattingScanner.isOnToken() && formattingScanner.getTokenFullStart() < originalRange.end) { - const tokenInfo = formattingScanner.readTokenInfo(node); - if (tokenInfo.token.end > Math.min(node.end, originalRange.end)) { - break; + send(msg) { + if (msg.type === "event" && !this.canUseEvents) { + if (this.logger.hasLevel(3 /* verbose */)) { + this.logger.info(`Session does not support events: ignored event: ${JSON.stringify(msg)}`); + } + return; + } + this.writeMessage(msg); } - consumeTokenAndAdvanceScanner(tokenInfo, node, nodeDynamicIndentation, node); - } - function processChildNode(child, inheritedIndentation, parent2, parentDynamicIndentation, parentStartLine, undecoratedParentStartLine, isListItem, isFirstListItem) { - Debug.assert(!nodeIsSynthesized(child)); - if (nodeIsMissing(child) || isGrammarError(parent2, child)) { - return inheritedIndentation; + writeMessage(msg) { + var _a; + const msgText = formatMessage2(msg, this.logger, this.byteLength, this.host.newLine); + (_a = perfLogger) == null ? void 0 : _a.logEvent(`Response message size: ${msgText.length}`); + this.host.write(msgText); } - const childStartPos = child.getStart(sourceFile); - const childStartLine = sourceFile.getLineAndCharacterOfPosition(childStartPos).line; - let undecoratedChildStartLine = childStartLine; - if (hasDecorators(child)) { - undecoratedChildStartLine = sourceFile.getLineAndCharacterOfPosition(getNonDecoratorTokenPosOfNode(child, sourceFile)).line; + event(body, eventName) { + this.send(toEvent(eventName, body)); } - let childIndentationAmount = -1 /* Unknown */; - if (isListItem && rangeContainsRange(originalRange, parent2)) { - childIndentationAmount = tryComputeIndentationForListItem(childStartPos, child.end, parentStartLine, originalRange, inheritedIndentation); - if (childIndentationAmount !== -1 /* Unknown */) { - inheritedIndentation = childIndentationAmount; + /** @internal */ + doOutput(info, cmdName, reqSeq, success, message) { + const res = { + seq: 0, + type: "response", + command: cmdName, + request_seq: reqSeq, + success, + performanceData: this.performanceData + }; + if (success) { + let metadata; + if (isArray(info)) { + res.body = info; + metadata = info.metadata; + delete info.metadata; + } else if (typeof info === "object") { + if (info.metadata) { + const { metadata: infoMetadata, ...body } = info; + res.body = body; + metadata = infoMetadata; + } else { + res.body = info; + } + } else { + res.body = info; + } + if (metadata) + res.metadata = metadata; + } else { + Debug.assert(info === void 0); } - } - if (!rangeOverlapsWithStartEnd(originalRange, child.pos, child.end)) { - if (child.end < originalRange.pos) { - formattingScanner.skipToEndOf(child); + if (message) { + res.message = message; } - return inheritedIndentation; + this.send(res); } - if (child.getFullWidth() === 0) { - return inheritedIndentation; + semanticCheck(file, project) { + var _a, _b; + (_a = tracing) == null ? void 0 : _a.push(tracing.Phase.Session, "semanticCheck", { file, configFilePath: project.canonicalConfigFilePath }); + const diags = isDeclarationFileInJSOnlyNonConfiguredProject(project, file) ? emptyArray2 : project.getLanguageService().getSemanticDiagnostics(file).filter((d) => !!d.file); + this.sendDiagnosticsEvent(file, project, diags, "semanticDiag"); + (_b = tracing) == null ? void 0 : _b.pop(); } - while (formattingScanner.isOnToken() && formattingScanner.getTokenFullStart() < originalRange.end) { - const tokenInfo = formattingScanner.readTokenInfo(node); - if (tokenInfo.token.end > originalRange.end) { - return inheritedIndentation; + syntacticCheck(file, project) { + var _a, _b; + (_a = tracing) == null ? void 0 : _a.push(tracing.Phase.Session, "syntacticCheck", { file, configFilePath: project.canonicalConfigFilePath }); + this.sendDiagnosticsEvent(file, project, project.getLanguageService().getSyntacticDiagnostics(file), "syntaxDiag"); + (_b = tracing) == null ? void 0 : _b.pop(); + } + suggestionCheck(file, project) { + var _a, _b; + (_a = tracing) == null ? void 0 : _a.push(tracing.Phase.Session, "suggestionCheck", { file, configFilePath: project.canonicalConfigFilePath }); + this.sendDiagnosticsEvent(file, project, project.getLanguageService().getSuggestionDiagnostics(file), "suggestionDiag"); + (_b = tracing) == null ? void 0 : _b.pop(); + } + sendDiagnosticsEvent(file, project, diagnostics, kind) { + try { + this.event({ file, diagnostics: diagnostics.map((diag2) => formatDiag(file, project, diag2)) }, kind); + } catch (err) { + this.logError(err, kind); } - if (tokenInfo.token.end > childStartPos) { - if (tokenInfo.token.pos > childStartPos) { - formattingScanner.skipToStartOf(child); + } + /** It is the caller's responsibility to verify that `!this.suppressDiagnosticEvents`. */ + updateErrorCheck(next, checkList, ms, requireOpen = true) { + Debug.assert(!this.suppressDiagnosticEvents); + const seq = this.changeSeq; + const followMs = Math.min(ms, 200); + let index = 0; + const goNext = () => { + index++; + if (checkList.length > index) { + next.delay("checkOne", followMs, checkOne); } - break; + }; + const checkOne = () => { + if (this.changeSeq !== seq) { + return; + } + let item = checkList[index]; + if (isString(item)) { + item = this.toPendingErrorCheck(item); + if (!item) { + goNext(); + return; + } + } + const { fileName, project } = item; + updateProjectIfDirty(project); + if (!project.containsFile(fileName, requireOpen)) { + return; + } + this.syntacticCheck(fileName, project); + if (this.changeSeq !== seq) { + return; + } + if (project.projectService.serverMode !== 0 /* Semantic */) { + goNext(); + return; + } + next.immediate("semanticCheck", () => { + this.semanticCheck(fileName, project); + if (this.changeSeq !== seq) { + return; + } + if (this.getPreferences(fileName).disableSuggestions) { + goNext(); + return; + } + next.immediate("suggestionCheck", () => { + this.suggestionCheck(fileName, project); + goNext(); + }); + }); + }; + if (checkList.length > index && this.changeSeq === seq) { + next.delay("checkOne", ms, checkOne); } - consumeTokenAndAdvanceScanner(tokenInfo, node, parentDynamicIndentation, node); } - if (!formattingScanner.isOnToken() || formattingScanner.getTokenFullStart() >= originalRange.end) { - return inheritedIndentation; + cleanProjects(caption, projects) { + if (!projects) { + return; + } + this.logger.info(`cleaning ${caption}`); + for (const p of projects) { + p.getLanguageService( + /*ensureSynchronized*/ + false + ).cleanupSemanticCache(); + p.cleanupProgram(); + } } - if (isToken(child)) { - const tokenInfo = formattingScanner.readTokenInfo(child); - if (child.kind !== 12 /* JsxText */) { - Debug.assert(tokenInfo.token.end === child.end, "Token end is child end"); - consumeTokenAndAdvanceScanner(tokenInfo, node, parentDynamicIndentation, child); - return inheritedIndentation; + cleanup() { + this.cleanProjects("inferred projects", this.projectService.inferredProjects); + this.cleanProjects("configured projects", arrayFrom(this.projectService.configuredProjects.values())); + this.cleanProjects("external projects", this.projectService.externalProjects); + if (this.host.gc) { + this.logger.info(`host.gc()`); + this.host.gc(); } } - const effectiveParentStartLine = child.kind === 169 /* Decorator */ ? childStartLine : undecoratedParentStartLine; - const childIndentation = computeIndentation(child, childStartLine, childIndentationAmount, node, parentDynamicIndentation, effectiveParentStartLine); - processNode(child, childContextNode, childStartLine, undecoratedChildStartLine, childIndentation.indentation, childIndentation.delta); - childContextNode = node; - if (isFirstListItem && parent2.kind === 208 /* ArrayLiteralExpression */ && inheritedIndentation === -1 /* Unknown */) { - inheritedIndentation = childIndentation.indentation; + getEncodedSyntacticClassifications(args) { + const { file, languageService } = this.getFileAndLanguageServiceForSyntacticOperation(args); + return languageService.getEncodedSyntacticClassifications(file, args); } - return inheritedIndentation; - } - function processChildNodes(nodes, parent2, parentStartLine, parentDynamicIndentation) { - Debug.assert(isNodeArray(nodes)); - Debug.assert(!nodeIsSynthesized(nodes)); - const listStartToken = getOpenTokenForList(parent2, nodes); - let listDynamicIndentation = parentDynamicIndentation; - let startLine = parentStartLine; - if (!rangeOverlapsWithStartEnd(originalRange, nodes.pos, nodes.end)) { - if (nodes.end < originalRange.pos) { - formattingScanner.skipToEndOf(nodes); + getEncodedSemanticClassifications(args) { + const { file, project } = this.getFileAndProject(args); + const format = args.format === "2020" ? "2020" /* TwentyTwenty */ : "original" /* Original */; + return project.getLanguageService().getEncodedSemanticClassifications(file, args, format); + } + getProject(projectFileName) { + return projectFileName === void 0 ? void 0 : this.projectService.findProject(projectFileName); + } + getConfigFileAndProject(args) { + const project = this.getProject(args.projectFileName); + const file = toNormalizedPath(args.file); + return { + configFile: project && project.hasConfigFile(file) ? file : void 0, + project + }; + } + getConfigFileDiagnostics(configFile, project, includeLinePosition) { + const projectErrors = project.getAllProjectErrors(); + const optionsErrors = project.getLanguageService().getCompilerOptionsDiagnostics(); + const diagnosticsForConfigFile = filter( + concatenate(projectErrors, optionsErrors), + (diagnostic) => !!diagnostic.file && diagnostic.file.fileName === configFile + ); + return includeLinePosition ? this.convertToDiagnosticsWithLinePositionFromDiagnosticFile(diagnosticsForConfigFile) : map( + diagnosticsForConfigFile, + (diagnostic) => formatDiagnosticToProtocol( + diagnostic, + /*includeFileName*/ + false + ) + ); + } + convertToDiagnosticsWithLinePositionFromDiagnosticFile(diagnostics) { + return diagnostics.map((d) => ({ + message: flattenDiagnosticMessageText(d.messageText, this.host.newLine), + start: d.start, + // TODO: GH#18217 + length: d.length, + // TODO: GH#18217 + category: diagnosticCategoryName(d), + code: d.code, + source: d.source, + startLocation: d.file && convertToLocation(getLineAndCharacterOfPosition(d.file, d.start)), + // TODO: GH#18217 + endLocation: d.file && convertToLocation(getLineAndCharacterOfPosition(d.file, d.start + d.length)), + // TODO: GH#18217 + reportsUnnecessary: d.reportsUnnecessary, + reportsDeprecated: d.reportsDeprecated, + relatedInformation: map(d.relatedInformation, formatRelatedInformation) + })); + } + getCompilerOptionsDiagnostics(args) { + const project = this.getProject(args.projectFileName); + return this.convertToDiagnosticsWithLinePosition( + filter( + project.getLanguageService().getCompilerOptionsDiagnostics(), + (diagnostic) => !diagnostic.file + ), + /*scriptInfo*/ + void 0 + ); + } + convertToDiagnosticsWithLinePosition(diagnostics, scriptInfo) { + return diagnostics.map( + (d) => ({ + message: flattenDiagnosticMessageText(d.messageText, this.host.newLine), + start: d.start, + length: d.length, + category: diagnosticCategoryName(d), + code: d.code, + source: d.source, + startLocation: scriptInfo && scriptInfo.positionToLineOffset(d.start), + // TODO: GH#18217 + endLocation: scriptInfo && scriptInfo.positionToLineOffset(d.start + d.length), + reportsUnnecessary: d.reportsUnnecessary, + reportsDeprecated: d.reportsDeprecated, + relatedInformation: map(d.relatedInformation, formatRelatedInformation) + }) + ); + } + getDiagnosticsWorker(args, isSemantic, selector, includeLinePosition) { + const { project, file } = this.getFileAndProject(args); + if (isSemantic && isDeclarationFileInJSOnlyNonConfiguredProject(project, file)) { + return emptyArray2; + } + const scriptInfo = project.getScriptInfoForNormalizedPath(file); + const diagnostics = selector(project, file); + return includeLinePosition ? this.convertToDiagnosticsWithLinePosition(diagnostics, scriptInfo) : diagnostics.map((d) => formatDiag(file, project, d)); + } + getDefinition(args, simplifiedResult) { + const { file, project } = this.getFileAndProject(args); + const position = this.getPositionInFile(args, file); + const definitions = this.mapDefinitionInfoLocations(project.getLanguageService().getDefinitionAtPosition(file, position) || emptyArray2, project); + return simplifiedResult ? this.mapDefinitionInfo(definitions, project) : definitions.map(_Session.mapToOriginalLocation); + } + mapDefinitionInfoLocations(definitions, project) { + return definitions.map((info) => { + const newDocumentSpan = getMappedDocumentSpanForProject(info, project); + return !newDocumentSpan ? info : { + ...newDocumentSpan, + containerKind: info.containerKind, + containerName: info.containerName, + kind: info.kind, + name: info.name, + failedAliasResolution: info.failedAliasResolution, + ...info.unverified && { unverified: info.unverified } + }; + }); + } + getDefinitionAndBoundSpan(args, simplifiedResult) { + const { file, project } = this.getFileAndProject(args); + const position = this.getPositionInFile(args, file); + const scriptInfo = Debug.checkDefined(project.getScriptInfo(file)); + const unmappedDefinitionAndBoundSpan = project.getLanguageService().getDefinitionAndBoundSpan(file, position); + if (!unmappedDefinitionAndBoundSpan || !unmappedDefinitionAndBoundSpan.definitions) { + return { + definitions: emptyArray2, + textSpan: void 0 + // TODO: GH#18217 + }; } - return; + const definitions = this.mapDefinitionInfoLocations(unmappedDefinitionAndBoundSpan.definitions, project); + const { textSpan } = unmappedDefinitionAndBoundSpan; + if (simplifiedResult) { + return { + definitions: this.mapDefinitionInfo(definitions, project), + textSpan: toProtocolTextSpan(textSpan, scriptInfo) + }; + } + return { + definitions: definitions.map(_Session.mapToOriginalLocation), + textSpan + }; } - if (listStartToken !== 0 /* Unknown */) { - while (formattingScanner.isOnToken() && formattingScanner.getTokenFullStart() < originalRange.end) { - const tokenInfo = formattingScanner.readTokenInfo(parent2); - if (tokenInfo.token.end > nodes.pos) { - break; - } else if (tokenInfo.token.kind === listStartToken) { - startLine = sourceFile.getLineAndCharacterOfPosition(tokenInfo.token.pos).line; - consumeTokenAndAdvanceScanner(tokenInfo, parent2, parentDynamicIndentation, parent2); - let indentationOnListStartToken; - if (indentationOnLastIndentedLine !== -1 /* Unknown */) { - indentationOnListStartToken = indentationOnLastIndentedLine; - } else { - const startLinePosition = getLineStartPositionForPosition(tokenInfo.token.pos, sourceFile); - indentationOnListStartToken = SmartIndenter.findFirstNonWhitespaceColumn(startLinePosition, tokenInfo.token.pos, sourceFile, options); + findSourceDefinition(args) { + var _a; + const { file, project } = this.getFileAndProject(args); + const position = this.getPositionInFile(args, file); + const unmappedDefinitions = project.getLanguageService().getDefinitionAtPosition(file, position); + let definitions = this.mapDefinitionInfoLocations(unmappedDefinitions || emptyArray2, project).slice(); + const needsJsResolution = this.projectService.serverMode === 0 /* Semantic */ && (!some(definitions, (d) => toNormalizedPath(d.fileName) !== file && !d.isAmbient) || some(definitions, (d) => !!d.failedAliasResolution)); + if (needsJsResolution) { + const definitionSet = createSet((d) => d.textSpan.start, documentSpansEqual); + definitions == null ? void 0 : definitions.forEach((d) => definitionSet.add(d)); + const noDtsProject = project.getNoDtsResolutionProject(file); + const ls = noDtsProject.getLanguageService(); + const jsDefinitions = (_a = ls.getDefinitionAtPosition( + file, + position, + /*searchOtherFilesOnly*/ + true, + /*stopAtAlias*/ + false + )) == null ? void 0 : _a.filter((d) => toNormalizedPath(d.fileName) !== file); + if (some(jsDefinitions)) { + for (const jsDefinition of jsDefinitions) { + if (jsDefinition.unverified) { + const refined = tryRefineDefinition(jsDefinition, project.getLanguageService().getProgram(), ls.getProgram()); + if (some(refined)) { + for (const def of refined) { + definitionSet.add(def); + } + continue; + } + } + definitionSet.add(jsDefinition); } - listDynamicIndentation = getDynamicIndentation(parent2, parentStartLine, indentationOnListStartToken, options.indentSize); } else { - consumeTokenAndAdvanceScanner(tokenInfo, parent2, parentDynamicIndentation, parent2); + const ambientCandidates = definitions.filter((d) => toNormalizedPath(d.fileName) !== file && d.isAmbient); + for (const candidate of some(ambientCandidates) ? ambientCandidates : getAmbientCandidatesByClimbingAccessChain()) { + const fileNameToSearch = findImplementationFileFromDtsFileName(candidate.fileName, file, noDtsProject); + if (!fileNameToSearch) + continue; + const info = this.projectService.getOrCreateScriptInfoNotOpenedByClient( + fileNameToSearch, + noDtsProject.currentDirectory, + noDtsProject.directoryStructureHost + ); + if (!info) + continue; + if (!noDtsProject.containsScriptInfo(info)) { + noDtsProject.addRoot(info); + noDtsProject.updateGraph(); + } + const noDtsProgram = ls.getProgram(); + const fileToSearch = Debug.checkDefined(noDtsProgram.getSourceFile(fileNameToSearch)); + for (const match of searchForDeclaration(candidate.name, fileToSearch, noDtsProgram)) { + definitionSet.add(match); + } + } + } + definitions = arrayFrom(definitionSet.values()); + } + definitions = definitions.filter((d) => !d.isAmbient && !d.failedAliasResolution); + return this.mapDefinitionInfo(definitions, project); + function findImplementationFileFromDtsFileName(fileName, resolveFromFile, auxiliaryProject) { + var _a2, _b, _c; + const nodeModulesPathParts = getNodeModulePathParts(fileName); + if (nodeModulesPathParts && fileName.lastIndexOf(nodeModulesPathPart) === nodeModulesPathParts.topLevelNodeModulesIndex) { + const packageDirectory = fileName.substring(0, nodeModulesPathParts.packageRootIndex); + const packageJsonCache = (_a2 = project.getModuleResolutionCache()) == null ? void 0 : _a2.getPackageJsonInfoCache(); + const compilerOptions = project.getCompilationSettings(); + const packageJson = getPackageScopeForPath(getNormalizedAbsolutePath(packageDirectory + "/package.json", project.getCurrentDirectory()), getTemporaryModuleResolutionState(packageJsonCache, project, compilerOptions)); + if (!packageJson) + return void 0; + const entrypoints = getEntrypointsFromPackageJsonInfo( + packageJson, + { moduleResolution: 2 /* Node10 */ }, + project, + project.getModuleResolutionCache() + ); + const packageNamePathPart = fileName.substring( + nodeModulesPathParts.topLevelPackageNameIndex + 1, + nodeModulesPathParts.packageRootIndex + ); + const packageName = getPackageNameFromTypesPackageName(unmangleScopedPackageName(packageNamePathPart)); + const path = project.toPath(fileName); + if (entrypoints && some(entrypoints, (e) => project.toPath(e) === path)) { + return (_b = auxiliaryProject.resolutionCache.resolveSingleModuleNameWithoutWatching(packageName, resolveFromFile).resolvedModule) == null ? void 0 : _b.resolvedFileName; + } else { + const pathToFileInPackage = fileName.substring(nodeModulesPathParts.packageRootIndex + 1); + const specifier = `${packageName}/${removeFileExtension(pathToFileInPackage)}`; + return (_c = auxiliaryProject.resolutionCache.resolveSingleModuleNameWithoutWatching(specifier, resolveFromFile).resolvedModule) == null ? void 0 : _c.resolvedFileName; + } } + return void 0; + } + function getAmbientCandidatesByClimbingAccessChain() { + const ls = project.getLanguageService(); + const program = ls.getProgram(); + const initialNode = getTouchingPropertyName(program.getSourceFile(file), position); + if ((isStringLiteralLike(initialNode) || isIdentifier(initialNode)) && isAccessExpression(initialNode.parent)) { + return forEachNameInAccessChainWalkingLeft(initialNode, (nameInChain) => { + var _a2; + if (nameInChain === initialNode) + return void 0; + const candidates = (_a2 = ls.getDefinitionAtPosition( + file, + nameInChain.getStart(), + /*searchOtherFilesOnly*/ + true, + /*stopAtAlias*/ + false + )) == null ? void 0 : _a2.filter((d) => toNormalizedPath(d.fileName) !== file && d.isAmbient).map((d) => ({ + fileName: d.fileName, + name: getTextOfIdentifierOrLiteral(initialNode) + })); + if (some(candidates)) { + return candidates; + } + }) || emptyArray2; + } + return emptyArray2; + } + function tryRefineDefinition(definition, program, noDtsProgram) { + var _a2; + const fileToSearch = noDtsProgram.getSourceFile(definition.fileName); + if (!fileToSearch) { + return void 0; + } + const initialNode = getTouchingPropertyName(program.getSourceFile(file), position); + const symbol = program.getTypeChecker().getSymbolAtLocation(initialNode); + const importSpecifier = symbol && getDeclarationOfKind(symbol, 276 /* ImportSpecifier */); + if (!importSpecifier) + return void 0; + const nameToSearch = ((_a2 = importSpecifier.propertyName) == null ? void 0 : _a2.text) || importSpecifier.name.text; + return searchForDeclaration(nameToSearch, fileToSearch, noDtsProgram); + } + function searchForDeclaration(declarationName, fileToSearch, noDtsProgram) { + const matches = ts_FindAllReferences_exports.Core.getTopMostDeclarationNamesInFile(declarationName, fileToSearch); + return mapDefined(matches, (match) => { + const symbol = noDtsProgram.getTypeChecker().getSymbolAtLocation(match); + const decl = getDeclarationFromName(match); + if (symbol && decl) { + return ts_GoToDefinition_exports.createDefinitionInfo( + decl, + noDtsProgram.getTypeChecker(), + symbol, + decl, + /*unverified*/ + true + ); + } + }); } } - let inheritedIndentation = -1 /* Unknown */; - for (let i = 0; i < nodes.length; i++) { - const child = nodes[i]; - inheritedIndentation = processChildNode( - child, - inheritedIndentation, - node, - listDynamicIndentation, - startLine, - startLine, - /*isListItem*/ - true, - /*isFirstListItem*/ - i === 0 - ); - } - const listEndToken = getCloseTokenForOpenToken(listStartToken); - if (listEndToken !== 0 /* Unknown */ && formattingScanner.isOnToken() && formattingScanner.getTokenFullStart() < originalRange.end) { - let tokenInfo = formattingScanner.readTokenInfo(parent2); - if (tokenInfo.token.kind === 28 /* CommaToken */) { - consumeTokenAndAdvanceScanner(tokenInfo, parent2, listDynamicIndentation, parent2); - tokenInfo = formattingScanner.isOnToken() ? formattingScanner.readTokenInfo(parent2) : void 0; + getEmitOutput(args) { + const { file, project } = this.getFileAndProject(args); + if (!project.shouldEmitFile(project.getScriptInfo(file))) { + return { emitSkipped: true, outputFiles: [], diagnostics: [] }; } - if (tokenInfo && tokenInfo.token.kind === listEndToken && rangeContainsRange(parent2, tokenInfo.token)) { - consumeTokenAndAdvanceScanner( - tokenInfo, - parent2, - listDynamicIndentation, - parent2, - /*isListEndToken*/ + const result = project.getLanguageService().getEmitOutput(file); + return args.richResponse ? { + ...result, + diagnostics: args.includeLinePosition ? this.convertToDiagnosticsWithLinePositionFromDiagnosticFile(result.diagnostics) : result.diagnostics.map((d) => formatDiagnosticToProtocol( + d, + /*includeFileName*/ true - ); - } + )) + } : result; } - } - function consumeTokenAndAdvanceScanner(currentTokenInfo, parent2, dynamicIndentation, container, isListEndToken) { - Debug.assert(rangeContainsRange(parent2, currentTokenInfo.token)); - const lastTriviaWasNewLine = formattingScanner.lastTrailingTriviaWasNewLine(); - let indentToken = false; - if (currentTokenInfo.leadingTrivia) { - processTrivia(currentTokenInfo.leadingTrivia, parent2, childContextNode, dynamicIndentation); + mapJSDocTagInfo(tags, project, richResponse) { + return tags ? tags.map((tag) => { + var _a; + return { + ...tag, + text: richResponse ? this.mapDisplayParts(tag.text, project) : (_a = tag.text) == null ? void 0 : _a.map((part) => part.text).join("") + }; + }) : []; } - let lineAction = 0 /* None */; - const isTokenInRange = rangeContainsRange(originalRange, currentTokenInfo.token); - const tokenStart = sourceFile.getLineAndCharacterOfPosition(currentTokenInfo.token.pos); - if (isTokenInRange) { - const rangeHasError = rangeContainsError(currentTokenInfo.token); - const savePreviousRange = previousRange; - lineAction = processRange(currentTokenInfo.token, tokenStart, parent2, childContextNode, dynamicIndentation); - if (!rangeHasError) { - if (lineAction === 0 /* None */) { - const prevEndLine = savePreviousRange && sourceFile.getLineAndCharacterOfPosition(savePreviousRange.end).line; - indentToken = lastTriviaWasNewLine && tokenStart.line !== prevEndLine; - } else { - indentToken = lineAction === 1 /* LineAdded */; + mapDisplayParts(parts, project) { + if (!parts) { + return []; + } + return parts.map( + (part) => part.kind !== "linkName" ? part : { + ...part, + target: this.toFileSpan(part.target.fileName, part.target.textSpan, project) } + ); + } + mapSignatureHelpItems(items, project, richResponse) { + return items.map((item) => ({ + ...item, + documentation: this.mapDisplayParts(item.documentation, project), + parameters: item.parameters.map((p) => ({ ...p, documentation: this.mapDisplayParts(p.documentation, project) })), + tags: this.mapJSDocTagInfo(item.tags, project, richResponse) + })); + } + mapDefinitionInfo(definitions, project) { + return definitions.map((def) => ({ ...this.toFileSpanWithContext(def.fileName, def.textSpan, def.contextSpan, project), ...def.unverified && { unverified: def.unverified } })); + } + /* + * When we map a .d.ts location to .ts, Visual Studio gets confused because there's no associated Roslyn Document in + * the same project which corresponds to the file. VS Code has no problem with this, and luckily we have two protocols. + * This retains the existing behavior for the "simplified" (VS Code) protocol but stores the .d.ts location in a + * set of additional fields, and does the reverse for VS (store the .d.ts location where + * it used to be and stores the .ts location in the additional fields). + */ + static mapToOriginalLocation(def) { + if (def.originalFileName) { + Debug.assert(def.originalTextSpan !== void 0, "originalTextSpan should be present if originalFileName is"); + return { + ...def, + fileName: def.originalFileName, + textSpan: def.originalTextSpan, + targetFileName: def.fileName, + targetTextSpan: def.textSpan, + contextSpan: def.originalContextSpan, + targetContextSpan: def.contextSpan + }; } + return def; } - if (currentTokenInfo.trailingTrivia) { - previousRangeTriviaEnd = last(currentTokenInfo.trailingTrivia).end; - processTrivia(currentTokenInfo.trailingTrivia, parent2, childContextNode, dynamicIndentation); + toFileSpan(fileName, textSpan, project) { + const ls = project.getLanguageService(); + const start = ls.toLineColumnOffset(fileName, textSpan.start); + const end = ls.toLineColumnOffset(fileName, textSpanEnd(textSpan)); + return { + file: fileName, + start: { line: start.line + 1, offset: start.character + 1 }, + end: { line: end.line + 1, offset: end.character + 1 } + }; } - if (indentToken) { - const tokenIndentation = isTokenInRange && !rangeContainsError(currentTokenInfo.token) ? dynamicIndentation.getIndentationForToken(tokenStart.line, currentTokenInfo.token.kind, container, !!isListEndToken) : -1 /* Unknown */; - let indentNextTokenOrTrivia = true; - if (currentTokenInfo.leadingTrivia) { - const commentIndentation = dynamicIndentation.getIndentationForComment(currentTokenInfo.token.kind, tokenIndentation, container); - indentNextTokenOrTrivia = indentTriviaItems( - currentTokenInfo.leadingTrivia, - commentIndentation, - indentNextTokenOrTrivia, - (item) => insertIndentation( - item.pos, - commentIndentation, - /*lineAdded*/ - false - ) - ); + toFileSpanWithContext(fileName, textSpan, contextSpan, project) { + const fileSpan = this.toFileSpan(fileName, textSpan, project); + const context = contextSpan && this.toFileSpan(fileName, contextSpan, project); + return context ? { ...fileSpan, contextStart: context.start, contextEnd: context.end } : fileSpan; + } + getTypeDefinition(args) { + const { file, project } = this.getFileAndProject(args); + const position = this.getPositionInFile(args, file); + const definitions = this.mapDefinitionInfoLocations(project.getLanguageService().getTypeDefinitionAtPosition(file, position) || emptyArray2, project); + return this.mapDefinitionInfo(definitions, project); + } + mapImplementationLocations(implementations, project) { + return implementations.map((info) => { + const newDocumentSpan = getMappedDocumentSpanForProject(info, project); + return !newDocumentSpan ? info : { + ...newDocumentSpan, + kind: info.kind, + displayParts: info.displayParts + }; + }); + } + getImplementation(args, simplifiedResult) { + const { file, project } = this.getFileAndProject(args); + const position = this.getPositionInFile(args, file); + const implementations = this.mapImplementationLocations(project.getLanguageService().getImplementationAtPosition(file, position) || emptyArray2, project); + return simplifiedResult ? implementations.map(({ fileName, textSpan, contextSpan }) => this.toFileSpanWithContext(fileName, textSpan, contextSpan, project)) : implementations.map(_Session.mapToOriginalLocation); + } + getSyntacticDiagnosticsSync(args) { + const { configFile } = this.getConfigFileAndProject(args); + if (configFile) { + return emptyArray2; } - if (tokenIndentation !== -1 /* Unknown */ && indentNextTokenOrTrivia) { - insertIndentation(currentTokenInfo.token.pos, tokenIndentation, lineAction === 1 /* LineAdded */); - lastIndentedLine = tokenStart.line; - indentationOnLastIndentedLine = tokenIndentation; + return this.getDiagnosticsWorker( + args, + /*isSemantic*/ + false, + (project, file) => project.getLanguageService().getSyntacticDiagnostics(file), + !!args.includeLinePosition + ); + } + getSemanticDiagnosticsSync(args) { + const { configFile, project } = this.getConfigFileAndProject(args); + if (configFile) { + return this.getConfigFileDiagnostics(configFile, project, !!args.includeLinePosition); } + return this.getDiagnosticsWorker( + args, + /*isSemantic*/ + true, + (project2, file) => project2.getLanguageService().getSemanticDiagnostics(file).filter((d) => !!d.file), + !!args.includeLinePosition + ); } - formattingScanner.advance(); - childContextNode = parent2; - } - } - function indentTriviaItems(trivia, commentIndentation, indentNextTokenOrTrivia, indentSingleLine) { - for (const triviaItem of trivia) { - const triviaInRange = rangeContainsRange(originalRange, triviaItem); - switch (triviaItem.kind) { - case 3 /* MultiLineCommentTrivia */: - if (triviaInRange) { - indentMultilineComment( - triviaItem, - commentIndentation, - /*firstLineIsIndented*/ - !indentNextTokenOrTrivia - ); + getSuggestionDiagnosticsSync(args) { + const { configFile } = this.getConfigFileAndProject(args); + if (configFile) { + return emptyArray2; + } + return this.getDiagnosticsWorker( + args, + /*isSemantic*/ + true, + (project, file) => project.getLanguageService().getSuggestionDiagnostics(file), + !!args.includeLinePosition + ); + } + getJsxClosingTag(args) { + const { file, languageService } = this.getFileAndLanguageServiceForSyntacticOperation(args); + const position = this.getPositionInFile(args, file); + const tag = languageService.getJsxClosingTagAtPosition(file, position); + return tag === void 0 ? void 0 : { newText: tag.newText, caretOffset: 0 }; + } + getLinkedEditingRange(args) { + const { file, languageService } = this.getFileAndLanguageServiceForSyntacticOperation(args); + const position = this.getPositionInFile(args, file); + const linkedEditInfo = languageService.getLinkedEditingRangeAtPosition(file, position); + const scriptInfo = this.projectService.getScriptInfoForNormalizedPath(file); + if (scriptInfo === void 0 || linkedEditInfo === void 0) + return void 0; + return convertLinkedEditInfoToRanges(linkedEditInfo, scriptInfo); + } + getDocumentHighlights(args, simplifiedResult) { + const { file, project } = this.getFileAndProject(args); + const position = this.getPositionInFile(args, file); + const documentHighlights = project.getLanguageService().getDocumentHighlights(file, position, args.filesToSearch); + if (!documentHighlights) + return emptyArray2; + if (!simplifiedResult) + return documentHighlights; + return documentHighlights.map(({ fileName, highlightSpans }) => { + const scriptInfo = project.getScriptInfo(fileName); + return { + file: fileName, + highlightSpans: highlightSpans.map(({ textSpan, kind, contextSpan }) => ({ + ...toProtocolTextSpanWithContext(textSpan, contextSpan, scriptInfo), + kind + })) + }; + }); + } + provideInlayHints(args) { + const { file, project } = this.getFileAndProject(args); + const scriptInfo = this.projectService.getScriptInfoForNormalizedPath(file); + const hints = project.getLanguageService().provideInlayHints(file, args, this.getPreferences(file)); + return hints.map((hint) => { + const { position, displayParts } = hint; + return { + ...hint, + position: scriptInfo.positionToLineOffset(position), + displayParts: displayParts == null ? void 0 : displayParts.map(({ text, span, file: file2 }) => { + if (span) { + Debug.assertIsDefined(file2, "Target file should be defined together with its span."); + const scriptInfo2 = this.projectService.getScriptInfo(file2); + return { + text, + span: { + start: scriptInfo2.positionToLineOffset(span.start), + end: scriptInfo2.positionToLineOffset(span.start + span.length), + file: file2 + } + }; + } else { + return { text }; + } + }) + }; + }); + } + setCompilerOptionsForInferredProjects(args) { + this.projectService.setCompilerOptionsForInferredProjects(args.options, args.projectRootPath); + } + getProjectInfo(args) { + return this.getProjectInfoWorker( + args.file, + args.projectFileName, + args.needFileNameList, + /*excludeConfigFiles*/ + false + ); + } + getProjectInfoWorker(uncheckedFileName, projectFileName, needFileNameList, excludeConfigFiles) { + const { project } = this.getFileAndProjectWorker(uncheckedFileName, projectFileName); + updateProjectIfDirty(project); + const projectInfo = { + configFileName: project.getProjectName(), + languageServiceDisabled: !project.languageServiceEnabled, + fileNames: needFileNameList ? project.getFileNames( + /*excludeFilesFromExternalLibraries*/ + false, + excludeConfigFiles + ) : void 0 + }; + return projectInfo; + } + getRenameInfo(args) { + const { file, project } = this.getFileAndProject(args); + const position = this.getPositionInFile(args, file); + const preferences = this.getPreferences(file); + return project.getLanguageService().getRenameInfo(file, position, preferences); + } + getProjects(args, getScriptInfoEnsuringProjectsUptoDate, ignoreNoProjectError) { + let projects; + let symLinkedProjects; + if (args.projectFileName) { + const project = this.getProject(args.projectFileName); + if (project) { + projects = [project]; } - indentNextTokenOrTrivia = false; - break; - case 2 /* SingleLineCommentTrivia */: - if (indentNextTokenOrTrivia && triviaInRange) { - indentSingleLine(triviaItem); + } else { + const scriptInfo = getScriptInfoEnsuringProjectsUptoDate ? this.projectService.getScriptInfoEnsuringProjectsUptoDate(args.file) : this.projectService.getScriptInfo(args.file); + if (!scriptInfo) { + if (ignoreNoProjectError) + return emptyArray2; + this.projectService.logErrorForScriptInfoNotFound(args.file); + return Errors.ThrowNoProject(); + } else if (!getScriptInfoEnsuringProjectsUptoDate) { + this.projectService.ensureDefaultProjectForFile(scriptInfo); + } + projects = scriptInfo.containingProjects; + symLinkedProjects = this.projectService.getSymlinkedProjects(scriptInfo); + } + projects = filter(projects, (p) => p.languageServiceEnabled && !p.isOrphan()); + if (!ignoreNoProjectError && (!projects || !projects.length) && !symLinkedProjects) { + this.projectService.logErrorForScriptInfoNotFound(args.file ?? args.projectFileName); + return Errors.ThrowNoProject(); + } + return symLinkedProjects ? { projects, symLinkedProjects } : projects; + } + getDefaultProject(args) { + if (args.projectFileName) { + const project = this.getProject(args.projectFileName); + if (project) { + return project; + } + if (!args.file) { + return Errors.ThrowNoProject(); + } + } + const info = this.projectService.getScriptInfo(args.file); + return info.getDefaultProject(); + } + getRenameLocations(args, simplifiedResult) { + const file = toNormalizedPath(args.file); + const position = this.getPositionInFile(args, file); + const projects = this.getProjects(args); + const defaultProject = this.getDefaultProject(args); + const preferences = this.getPreferences(file); + const renameInfo = this.mapRenameInfo( + defaultProject.getLanguageService().getRenameInfo(file, position, preferences), + Debug.checkDefined(this.projectService.getScriptInfo(file)) + ); + if (!renameInfo.canRename) + return simplifiedResult ? { info: renameInfo, locs: [] } : []; + const locations = getRenameLocationsWorker( + projects, + defaultProject, + { fileName: args.file, pos: position }, + !!args.findInStrings, + !!args.findInComments, + preferences + ); + if (!simplifiedResult) + return locations; + return { info: renameInfo, locs: this.toSpanGroups(locations) }; + } + mapRenameInfo(info, scriptInfo) { + if (info.canRename) { + const { canRename, fileToRename, displayName, fullDisplayName, kind, kindModifiers, triggerSpan } = info; + return identity( + { canRename, fileToRename, displayName, fullDisplayName, kind, kindModifiers, triggerSpan: toProtocolTextSpan(triggerSpan, scriptInfo) } + ); + } else { + return info; + } + } + toSpanGroups(locations) { + const map2 = /* @__PURE__ */ new Map(); + for (const { fileName, textSpan, contextSpan, originalContextSpan: _2, originalTextSpan: _, originalFileName: _1, ...prefixSuffixText } of locations) { + let group2 = map2.get(fileName); + if (!group2) + map2.set(fileName, group2 = { file: fileName, locs: [] }); + const scriptInfo = Debug.checkDefined(this.projectService.getScriptInfo(fileName)); + group2.locs.push({ ...toProtocolTextSpanWithContext(textSpan, contextSpan, scriptInfo), ...prefixSuffixText }); + } + return arrayFrom(map2.values()); + } + getReferences(args, simplifiedResult) { + const file = toNormalizedPath(args.file); + const projects = this.getProjects(args); + const position = this.getPositionInFile(args, file); + const references = getReferencesWorker( + projects, + this.getDefaultProject(args), + { fileName: args.file, pos: position }, + this.logger + ); + if (!simplifiedResult) + return references; + const preferences = this.getPreferences(file); + const defaultProject = this.getDefaultProject(args); + const scriptInfo = defaultProject.getScriptInfoForNormalizedPath(file); + const nameInfo = defaultProject.getLanguageService().getQuickInfoAtPosition(file, position); + const symbolDisplayString = nameInfo ? displayPartsToString(nameInfo.displayParts) : ""; + const nameSpan = nameInfo && nameInfo.textSpan; + const symbolStartOffset = nameSpan ? scriptInfo.positionToLineOffset(nameSpan.start).offset : 0; + const symbolName2 = nameSpan ? scriptInfo.getSnapshot().getText(nameSpan.start, textSpanEnd(nameSpan)) : ""; + const refs = flatMap(references, (referencedSymbol) => { + return referencedSymbol.references.map((entry) => referenceEntryToReferencesResponseItem(this.projectService, entry, preferences)); + }); + return { refs, symbolName: symbolName2, symbolStartOffset, symbolDisplayString }; + } + getFileReferences(args, simplifiedResult) { + const projects = this.getProjects(args); + const fileName = args.file; + const preferences = this.getPreferences(toNormalizedPath(fileName)); + const references = []; + const seen = createDocumentSpanSet(); + forEachProjectInProjects( + projects, + /*path*/ + void 0, + (project) => { + if (project.getCancellationToken().isCancellationRequested()) + return; + const projectOutputs = project.getLanguageService().getFileReferences(fileName); + if (projectOutputs) { + for (const referenceEntry of projectOutputs) { + if (!seen.has(referenceEntry)) { + references.push(referenceEntry); + seen.add(referenceEntry); + } + } + } } - indentNextTokenOrTrivia = false; - break; - case 4 /* NewLineTrivia */: - indentNextTokenOrTrivia = true; - break; + ); + if (!simplifiedResult) + return references; + const refs = references.map((entry) => referenceEntryToReferencesResponseItem(this.projectService, entry, preferences)); + return { + refs, + symbolName: `"${args.file}"` + }; } - } - return indentNextTokenOrTrivia; - } - function processTrivia(trivia, parent2, contextNode, dynamicIndentation) { - for (const triviaItem of trivia) { - if (isComment(triviaItem.kind) && rangeContainsRange(originalRange, triviaItem)) { - const triviaItemStart = sourceFile.getLineAndCharacterOfPosition(triviaItem.pos); - processRange(triviaItem, triviaItemStart, parent2, contextNode, dynamicIndentation); + /** + * @param fileName is the name of the file to be opened + * @param fileContent is a version of the file content that is known to be more up to date than the one on disk + */ + openClientFile(fileName, fileContent, scriptKind, projectRootPath) { + this.projectService.openClientFileWithNormalizedPath( + fileName, + fileContent, + scriptKind, + /*hasMixedContent*/ + false, + projectRootPath + ); } - } - } - function processRange(range, rangeStart, parent2, contextNode, dynamicIndentation) { - const rangeHasError = rangeContainsError(range); - let lineAction = 0 /* None */; - if (!rangeHasError) { - if (!previousRange) { - const originalStart = sourceFile.getLineAndCharacterOfPosition(originalRange.pos); - trimTrailingWhitespacesForLines(originalStart.line, rangeStart.line); - } else { - lineAction = processPair(range, rangeStart.line, parent2, previousRange, previousRangeStartLine, previousParent, contextNode, dynamicIndentation); + getPosition(args, scriptInfo) { + return args.position !== void 0 ? args.position : scriptInfo.lineOffsetToPosition(args.line, args.offset); } - } - previousRange = range; - previousRangeTriviaEnd = range.end; - previousParent = parent2; - previousRangeStartLine = rangeStart.line; - return lineAction; - } - function processPair(currentItem, currentStartLine, currentParent, previousItem, previousStartLine, previousParent2, contextNode, dynamicIndentation) { - formattingContext.updateContext(previousItem, previousParent2, currentItem, currentParent, contextNode); - const rules = getRules(formattingContext); - let trimTrailingWhitespaces = formattingContext.options.trimTrailingWhitespace !== false; - let lineAction = 0 /* None */; - if (rules) { - forEachRight(rules, (rule2) => { - lineAction = applyRuleEdits(rule2, previousItem, previousStartLine, currentItem, currentStartLine); - if (dynamicIndentation) { - switch (lineAction) { - case 2 /* LineRemoved */: - if (currentParent.getStart(sourceFile) === currentItem.pos) { - dynamicIndentation.recomputeIndentation( - /*lineAddedByFormatting*/ - false, - contextNode - ); - } - break; - case 1 /* LineAdded */: - if (currentParent.getStart(sourceFile) === currentItem.pos) { - dynamicIndentation.recomputeIndentation( - /*lineAddedByFormatting*/ - true, - contextNode - ); + getPositionInFile(args, file) { + const scriptInfo = this.projectService.getScriptInfoForNormalizedPath(file); + return this.getPosition(args, scriptInfo); + } + getFileAndProject(args) { + return this.getFileAndProjectWorker(args.file, args.projectFileName); + } + getFileAndLanguageServiceForSyntacticOperation(args) { + const { file, project } = this.getFileAndProject(args); + return { + file, + languageService: project.getLanguageService( + /*ensureSynchronized*/ + false + ) + }; + } + getFileAndProjectWorker(uncheckedFileName, projectFileName) { + const file = toNormalizedPath(uncheckedFileName); + const project = this.getProject(projectFileName) || this.projectService.ensureDefaultProjectForFile(file); + return { file, project }; + } + getOutliningSpans(args, simplifiedResult) { + const { file, languageService } = this.getFileAndLanguageServiceForSyntacticOperation(args); + const spans = languageService.getOutliningSpans(file); + if (simplifiedResult) { + const scriptInfo = this.projectService.getScriptInfoForNormalizedPath(file); + return spans.map((s) => ({ + textSpan: toProtocolTextSpan(s.textSpan, scriptInfo), + hintSpan: toProtocolTextSpan(s.hintSpan, scriptInfo), + bannerText: s.bannerText, + autoCollapse: s.autoCollapse, + kind: s.kind + })); + } else { + return spans; + } + } + getTodoComments(args) { + const { file, project } = this.getFileAndProject(args); + return project.getLanguageService().getTodoComments(file, args.descriptors); + } + getDocCommentTemplate(args) { + const { file, languageService } = this.getFileAndLanguageServiceForSyntacticOperation(args); + const position = this.getPositionInFile(args, file); + return languageService.getDocCommentTemplateAtPosition(file, position, this.getPreferences(file), this.getFormatOptions(file)); + } + getSpanOfEnclosingComment(args) { + const { file, languageService } = this.getFileAndLanguageServiceForSyntacticOperation(args); + const onlyMultiLine = args.onlyMultiLine; + const position = this.getPositionInFile(args, file); + return languageService.getSpanOfEnclosingComment(file, position, onlyMultiLine); + } + getIndentation(args) { + const { file, languageService } = this.getFileAndLanguageServiceForSyntacticOperation(args); + const position = this.getPositionInFile(args, file); + const options = args.options ? convertFormatOptions(args.options) : this.getFormatOptions(file); + const indentation = languageService.getIndentationAtPosition(file, position, options); + return { position, indentation }; + } + getBreakpointStatement(args) { + const { file, languageService } = this.getFileAndLanguageServiceForSyntacticOperation(args); + const position = this.getPositionInFile(args, file); + return languageService.getBreakpointStatementAtPosition(file, position); + } + getNameOrDottedNameSpan(args) { + const { file, languageService } = this.getFileAndLanguageServiceForSyntacticOperation(args); + const position = this.getPositionInFile(args, file); + return languageService.getNameOrDottedNameSpan(file, position, position); + } + isValidBraceCompletion(args) { + const { file, languageService } = this.getFileAndLanguageServiceForSyntacticOperation(args); + const position = this.getPositionInFile(args, file); + return languageService.isValidBraceCompletionAtPosition(file, position, args.openingBrace.charCodeAt(0)); + } + getQuickInfoWorker(args, simplifiedResult) { + const { file, project } = this.getFileAndProject(args); + const scriptInfo = this.projectService.getScriptInfoForNormalizedPath(file); + const quickInfo = project.getLanguageService().getQuickInfoAtPosition(file, this.getPosition(args, scriptInfo)); + if (!quickInfo) { + return void 0; + } + const useDisplayParts = !!this.getPreferences(file).displayPartsForJSDoc; + if (simplifiedResult) { + const displayString = displayPartsToString(quickInfo.displayParts); + return { + kind: quickInfo.kind, + kindModifiers: quickInfo.kindModifiers, + start: scriptInfo.positionToLineOffset(quickInfo.textSpan.start), + end: scriptInfo.positionToLineOffset(textSpanEnd(quickInfo.textSpan)), + displayString, + documentation: useDisplayParts ? this.mapDisplayParts(quickInfo.documentation, project) : displayPartsToString(quickInfo.documentation), + tags: this.mapJSDocTagInfo(quickInfo.tags, project, useDisplayParts) + }; + } else { + return useDisplayParts ? quickInfo : { + ...quickInfo, + tags: this.mapJSDocTagInfo( + quickInfo.tags, + project, + /*richResponse*/ + false + ) + }; + } + } + getFormattingEditsForRange(args) { + const { file, languageService } = this.getFileAndLanguageServiceForSyntacticOperation(args); + const scriptInfo = this.projectService.getScriptInfoForNormalizedPath(file); + const startPosition = scriptInfo.lineOffsetToPosition(args.line, args.offset); + const endPosition = scriptInfo.lineOffsetToPosition(args.endLine, args.endOffset); + const edits = languageService.getFormattingEditsForRange(file, startPosition, endPosition, this.getFormatOptions(file)); + if (!edits) { + return void 0; + } + return edits.map((edit) => this.convertTextChangeToCodeEdit(edit, scriptInfo)); + } + getFormattingEditsForRangeFull(args) { + const { file, languageService } = this.getFileAndLanguageServiceForSyntacticOperation(args); + const options = args.options ? convertFormatOptions(args.options) : this.getFormatOptions(file); + return languageService.getFormattingEditsForRange(file, args.position, args.endPosition, options); + } + getFormattingEditsForDocumentFull(args) { + const { file, languageService } = this.getFileAndLanguageServiceForSyntacticOperation(args); + const options = args.options ? convertFormatOptions(args.options) : this.getFormatOptions(file); + return languageService.getFormattingEditsForDocument(file, options); + } + getFormattingEditsAfterKeystrokeFull(args) { + const { file, languageService } = this.getFileAndLanguageServiceForSyntacticOperation(args); + const options = args.options ? convertFormatOptions(args.options) : this.getFormatOptions(file); + return languageService.getFormattingEditsAfterKeystroke(file, args.position, args.key, options); + } + getFormattingEditsAfterKeystroke(args) { + const { file, languageService } = this.getFileAndLanguageServiceForSyntacticOperation(args); + const scriptInfo = this.projectService.getScriptInfoForNormalizedPath(file); + const position = scriptInfo.lineOffsetToPosition(args.line, args.offset); + const formatOptions = this.getFormatOptions(file); + const edits = languageService.getFormattingEditsAfterKeystroke(file, position, args.key, formatOptions); + if (args.key === "\n" && (!edits || edits.length === 0 || allEditsBeforePos(edits, position))) { + const { lineText, absolutePosition } = scriptInfo.textStorage.getAbsolutePositionAndLineText(args.line); + if (lineText && lineText.search("\\S") < 0) { + const preferredIndent = languageService.getIndentationAtPosition(file, position, formatOptions); + let hasIndent = 0; + let i, len; + for (i = 0, len = lineText.length; i < len; i++) { + if (lineText.charAt(i) === " ") { + hasIndent++; + } else if (lineText.charAt(i) === " ") { + hasIndent += formatOptions.tabSize; + } else { + break; } - break; - default: - Debug.assert(lineAction === 0 /* None */); + } + if (preferredIndent !== hasIndent) { + const firstNoWhiteSpacePosition = absolutePosition + i; + edits.push({ + span: createTextSpanFromBounds(absolutePosition, firstNoWhiteSpacePosition), + newText: ts_formatting_exports.getIndentationString(preferredIndent, formatOptions) + }); + } } } - trimTrailingWhitespaces = trimTrailingWhitespaces && !(rule2.action & 16 /* DeleteSpace */) && rule2.flags !== 1 /* CanDeleteNewLines */; - }); - } else { - trimTrailingWhitespaces = trimTrailingWhitespaces && currentItem.kind !== 1 /* EndOfFileToken */; - } - if (currentStartLine !== previousStartLine && trimTrailingWhitespaces) { - trimTrailingWhitespacesForLines(previousStartLine, currentStartLine, previousItem); - } - return lineAction; - } - function insertIndentation(pos, indentation, lineAdded) { - const indentationString = getIndentationString(indentation, options); - if (lineAdded) { - recordReplace(pos, 0, indentationString); - } else { - const tokenStart = sourceFile.getLineAndCharacterOfPosition(pos); - const startLinePosition = getStartPositionOfLine(tokenStart.line, sourceFile); - if (indentation !== characterToColumn(startLinePosition, tokenStart.character) || indentationIsDifferent(indentationString, startLinePosition)) { - recordReplace(startLinePosition, tokenStart.character, indentationString); + if (!edits) { + return void 0; + } + return edits.map((edit) => { + return { + start: scriptInfo.positionToLineOffset(edit.span.start), + end: scriptInfo.positionToLineOffset(textSpanEnd(edit.span)), + newText: edit.newText ? edit.newText : "" + }; + }); } - } - } - function characterToColumn(startLinePosition, characterInLine) { - let column = 0; - for (let i = 0; i < characterInLine; i++) { - if (sourceFile.text.charCodeAt(startLinePosition + i) === 9 /* tab */) { - column += options.tabSize - column % options.tabSize; - } else { - column++; + getCompletions(args, kind) { + const { file, project } = this.getFileAndProject(args); + const scriptInfo = this.projectService.getScriptInfoForNormalizedPath(file); + const position = this.getPosition(args, scriptInfo); + const completions = project.getLanguageService().getCompletionsAtPosition( + file, + position, + { + ...convertUserPreferences(this.getPreferences(file)), + triggerCharacter: args.triggerCharacter, + triggerKind: args.triggerKind, + includeExternalModuleExports: args.includeExternalModuleExports, + includeInsertTextCompletions: args.includeInsertTextCompletions + }, + project.projectService.getFormatCodeOptions(file) + ); + if (completions === void 0) + return void 0; + if (kind === "completions-full" /* CompletionsFull */) + return completions; + const prefix = args.prefix || ""; + const entries = mapDefined(completions.entries, (entry) => { + if (completions.isMemberCompletion || startsWith(entry.name.toLowerCase(), prefix.toLowerCase())) { + const { + name, + kind: kind2, + kindModifiers, + sortText, + insertText, + filterText, + replacementSpan, + hasAction, + source, + sourceDisplay, + labelDetails, + isSnippet, + isRecommended, + isPackageJsonImport, + isImportStatementCompletion, + data + } = entry; + const convertedSpan = replacementSpan ? toProtocolTextSpan(replacementSpan, scriptInfo) : void 0; + return { + name, + kind: kind2, + kindModifiers, + sortText, + insertText, + filterText, + replacementSpan: convertedSpan, + isSnippet, + hasAction: hasAction || void 0, + source, + sourceDisplay, + labelDetails, + isRecommended, + isPackageJsonImport, + isImportStatementCompletion, + data + }; + } + }); + if (kind === "completions" /* Completions */) { + if (completions.metadata) + entries.metadata = completions.metadata; + return entries; + } + const res = { + ...completions, + optionalReplacementSpan: completions.optionalReplacementSpan && toProtocolTextSpan(completions.optionalReplacementSpan, scriptInfo), + entries + }; + return res; } - } - return column; - } - function indentationIsDifferent(indentationString, startLinePosition) { - return indentationString !== sourceFile.text.substr(startLinePosition, indentationString.length); - } - function indentMultilineComment(commentRange, indentation, firstLineIsIndented, indentFinalLine = true) { - let startLine = sourceFile.getLineAndCharacterOfPosition(commentRange.pos).line; - const endLine = sourceFile.getLineAndCharacterOfPosition(commentRange.end).line; - if (startLine === endLine) { - if (!firstLineIsIndented) { - insertIndentation( - commentRange.pos, - indentation, - /*lineAdded*/ + getCompletionEntryDetails(args, fullResult) { + const { file, project } = this.getFileAndProject(args); + const scriptInfo = this.projectService.getScriptInfoForNormalizedPath(file); + const position = this.getPosition(args, scriptInfo); + const formattingOptions = project.projectService.getFormatCodeOptions(file); + const useDisplayParts = !!this.getPreferences(file).displayPartsForJSDoc; + const result = mapDefined(args.entryNames, (entryName) => { + const { name, source, data } = typeof entryName === "string" ? { name: entryName, source: void 0, data: void 0 } : entryName; + return project.getLanguageService().getCompletionEntryDetails(file, position, name, formattingOptions, source, this.getPreferences(file), data ? cast(data, isCompletionEntryData) : void 0); + }); + return fullResult ? useDisplayParts ? result : result.map((details) => ({ ...details, tags: this.mapJSDocTagInfo( + details.tags, + project, + /*richResponse*/ false + ) })) : result.map((details) => ({ + ...details, + codeActions: map(details.codeActions, (action) => this.mapCodeAction(action)), + documentation: this.mapDisplayParts(details.documentation, project), + tags: this.mapJSDocTagInfo(details.tags, project, useDisplayParts) + })); + } + getCompileOnSaveAffectedFileList(args) { + const projects = this.getProjects( + args, + /*getScriptInfoEnsuringProjectsUptoDate*/ + true, + /*ignoreNoProjectError*/ + true + ); + const info = this.projectService.getScriptInfo(args.file); + if (!info) { + return emptyArray2; + } + return combineProjectOutput( + info, + (path) => this.projectService.getScriptInfoForPath(path), + projects, + (project, info2) => { + if (!project.compileOnSaveEnabled || !project.languageServiceEnabled || project.isOrphan()) { + return void 0; + } + const compilationSettings = project.getCompilationSettings(); + if (!!compilationSettings.noEmit || isDeclarationFileName(info2.fileName) && !dtsChangeCanAffectEmit(compilationSettings)) { + return void 0; + } + return { + projectFileName: project.getProjectName(), + fileNames: project.getCompileOnSaveAffectedFileList(info2), + projectUsesOutFile: !!outFile(compilationSettings) + }; + } ); } - return; - } - const parts = []; - let startPos = commentRange.pos; - for (let line = startLine; line < endLine; line++) { - const endOfLine = getEndLinePosition(line, sourceFile); - parts.push({ pos: startPos, end: endOfLine }); - startPos = getStartPositionOfLine(line + 1, sourceFile); - } - if (indentFinalLine) { - parts.push({ pos: startPos, end: commentRange.end }); - } - if (parts.length === 0) - return; - const startLinePos = getStartPositionOfLine(startLine, sourceFile); - const nonWhitespaceColumnInFirstPart = SmartIndenter.findFirstNonWhitespaceCharacterAndColumn(startLinePos, parts[0].pos, sourceFile, options); - let startIndex = 0; - if (firstLineIsIndented) { - startIndex = 1; - startLine++; - } - const delta2 = indentation - nonWhitespaceColumnInFirstPart.column; - for (let i = startIndex; i < parts.length; i++, startLine++) { - const startLinePos2 = getStartPositionOfLine(startLine, sourceFile); - const nonWhitespaceCharacterAndColumn = i === 0 ? nonWhitespaceColumnInFirstPart : SmartIndenter.findFirstNonWhitespaceCharacterAndColumn(parts[i].pos, parts[i].end, sourceFile, options); - const newIndentation = nonWhitespaceCharacterAndColumn.column + delta2; - if (newIndentation > 0) { - const indentationString = getIndentationString(newIndentation, options); - recordReplace(startLinePos2, nonWhitespaceCharacterAndColumn.character, indentationString); - } else { - recordDelete(startLinePos2, nonWhitespaceCharacterAndColumn.character); + emitFile(args) { + const { file, project } = this.getFileAndProject(args); + if (!project) { + Errors.ThrowNoProject(); + } + if (!project.languageServiceEnabled) { + return args.richResponse ? { emitSkipped: true, diagnostics: [] } : false; + } + const scriptInfo = project.getScriptInfo(file); + const { emitSkipped, diagnostics } = project.emitFile(scriptInfo, (path, data, writeByteOrderMark) => this.host.writeFile(path, data, writeByteOrderMark)); + return args.richResponse ? { + emitSkipped, + diagnostics: args.includeLinePosition ? this.convertToDiagnosticsWithLinePositionFromDiagnosticFile(diagnostics) : diagnostics.map((d) => formatDiagnosticToProtocol( + d, + /*includeFileName*/ + true + )) + } : !emitSkipped; + } + getSignatureHelpItems(args, simplifiedResult) { + const { file, project } = this.getFileAndProject(args); + const scriptInfo = this.projectService.getScriptInfoForNormalizedPath(file); + const position = this.getPosition(args, scriptInfo); + const helpItems = project.getLanguageService().getSignatureHelpItems(file, position, args); + const useDisplayParts = !!this.getPreferences(file).displayPartsForJSDoc; + if (helpItems && simplifiedResult) { + const span = helpItems.applicableSpan; + return { + ...helpItems, + applicableSpan: { + start: scriptInfo.positionToLineOffset(span.start), + end: scriptInfo.positionToLineOffset(span.start + span.length) + }, + items: this.mapSignatureHelpItems(helpItems.items, project, useDisplayParts) + }; + } else if (useDisplayParts || !helpItems) { + return helpItems; + } else { + return { + ...helpItems, + items: helpItems.items.map((item) => ({ ...item, tags: this.mapJSDocTagInfo( + item.tags, + project, + /*richResponse*/ + false + ) })) + }; + } } - } - } - function trimTrailingWhitespacesForLines(line1, line2, range) { - for (let line = line1; line < line2; line++) { - const lineStartPosition = getStartPositionOfLine(line, sourceFile); - const lineEndPosition = getEndLinePosition(line, sourceFile); - if (range && (isComment(range.kind) || isStringOrRegularExpressionOrTemplateLiteral(range.kind)) && range.pos <= lineEndPosition && range.end > lineEndPosition) { - continue; + toPendingErrorCheck(uncheckedFileName) { + const fileName = toNormalizedPath(uncheckedFileName); + const project = this.projectService.tryGetDefaultProjectForFile(fileName); + return project && { fileName, project }; } - const whitespaceStart = getTrailingWhitespaceStartPosition(lineStartPosition, lineEndPosition); - if (whitespaceStart !== -1) { - Debug.assert(whitespaceStart === lineStartPosition || !isWhiteSpaceSingleLine(sourceFile.text.charCodeAt(whitespaceStart - 1))); - recordDelete(whitespaceStart, lineEndPosition + 1 - whitespaceStart); + getDiagnostics(next, delay, fileNames) { + if (this.suppressDiagnosticEvents) { + return; + } + if (fileNames.length > 0) { + this.updateErrorCheck(next, fileNames, delay); + } + } + change(args) { + const scriptInfo = this.projectService.getScriptInfo(args.file); + Debug.assert(!!scriptInfo); + scriptInfo.textStorage.switchToScriptVersionCache(); + const start = scriptInfo.lineOffsetToPosition(args.line, args.offset); + const end = scriptInfo.lineOffsetToPosition(args.endLine, args.endOffset); + if (start >= 0) { + this.changeSeq++; + this.projectService.applyChangesToFile( + scriptInfo, + singleIterator({ + span: { start, length: end - start }, + newText: args.insertString + // TODO: GH#18217 + }) + ); + } } - } - } - function getTrailingWhitespaceStartPosition(start, end) { - let pos = end; - while (pos >= start && isWhiteSpaceSingleLine(sourceFile.text.charCodeAt(pos))) { - pos--; - } - if (pos !== end) { - return pos + 1; - } - return -1; - } - function trimTrailingWhitespacesForRemainingRange(trivias) { - let startPos = previousRange ? previousRange.end : originalRange.pos; - for (const trivia of trivias) { - if (isComment(trivia.kind)) { - if (startPos < trivia.pos) { - trimTrailingWitespacesForPositions(startPos, trivia.pos - 1, previousRange); + reload(args, reqSeq) { + const file = toNormalizedPath(args.file); + const tempFileName = args.tmpfile === void 0 ? void 0 : toNormalizedPath(args.tmpfile); + const info = this.projectService.getScriptInfoForNormalizedPath(file); + if (info) { + this.changeSeq++; + if (info.reloadFromFile(tempFileName)) { + this.doOutput( + /*info*/ + void 0, + "reload" /* Reload */, + reqSeq, + /*success*/ + true + ); + } } - startPos = trivia.end + 1; } - } - if (startPos < originalRange.end) { - trimTrailingWitespacesForPositions(startPos, originalRange.end, previousRange); - } - } - function trimTrailingWitespacesForPositions(startPos, endPos, previousRange2) { - const startLine = sourceFile.getLineAndCharacterOfPosition(startPos).line; - const endLine = sourceFile.getLineAndCharacterOfPosition(endPos).line; - trimTrailingWhitespacesForLines(startLine, endLine + 1, previousRange2); - } - function recordDelete(start, len) { - if (len) { - edits.push(createTextChangeFromStartLength(start, len, "")); - } - } - function recordReplace(start, len, newText) { - if (len || newText) { - edits.push(createTextChangeFromStartLength(start, len, newText)); - } - } - function recordInsert(start, text) { - if (text) { - edits.push(createTextChangeFromStartLength(start, 0, text)); - } - } - function applyRuleEdits(rule2, previousRange2, previousStartLine, currentRange, currentStartLine) { - const onLaterLine = currentStartLine !== previousStartLine; - switch (rule2.action) { - case 1 /* StopProcessingSpaceActions */: - return 0 /* None */; - case 16 /* DeleteSpace */: - if (previousRange2.end !== currentRange.pos) { - recordDelete(previousRange2.end, currentRange.pos - previousRange2.end); - return onLaterLine ? 2 /* LineRemoved */ : 0 /* None */; + saveToTmp(fileName, tempFileName) { + const scriptInfo = this.projectService.getScriptInfo(fileName); + if (scriptInfo) { + scriptInfo.saveTo(tempFileName); } - break; - case 32 /* DeleteToken */: - recordDelete(previousRange2.pos, previousRange2.end - previousRange2.pos); - break; - case 8 /* InsertNewLine */: - if (rule2.flags !== 1 /* CanDeleteNewLines */ && previousStartLine !== currentStartLine) { - return 0 /* None */; + } + closeClientFile(fileName) { + if (!fileName) { + return; } - const lineDelta = currentStartLine - previousStartLine; - if (lineDelta !== 1) { - recordReplace(previousRange2.end, currentRange.pos - previousRange2.end, getNewLineOrDefaultFromHost(host, options)); - return onLaterLine ? 0 /* None */ : 1 /* LineAdded */; + const file = normalizePath(fileName); + this.projectService.closeClientFile(file); + } + mapLocationNavigationBarItems(items, scriptInfo) { + return map(items, (item) => ({ + text: item.text, + kind: item.kind, + kindModifiers: item.kindModifiers, + spans: item.spans.map((span) => toProtocolTextSpan(span, scriptInfo)), + childItems: this.mapLocationNavigationBarItems(item.childItems, scriptInfo), + indent: item.indent + })); + } + getNavigationBarItems(args, simplifiedResult) { + const { file, languageService } = this.getFileAndLanguageServiceForSyntacticOperation(args); + const items = languageService.getNavigationBarItems(file); + return !items ? void 0 : simplifiedResult ? this.mapLocationNavigationBarItems(items, this.projectService.getScriptInfoForNormalizedPath(file)) : items; + } + toLocationNavigationTree(tree, scriptInfo) { + return { + text: tree.text, + kind: tree.kind, + kindModifiers: tree.kindModifiers, + spans: tree.spans.map((span) => toProtocolTextSpan(span, scriptInfo)), + nameSpan: tree.nameSpan && toProtocolTextSpan(tree.nameSpan, scriptInfo), + childItems: map(tree.childItems, (item) => this.toLocationNavigationTree(item, scriptInfo)) + }; + } + getNavigationTree(args, simplifiedResult) { + const { file, languageService } = this.getFileAndLanguageServiceForSyntacticOperation(args); + const tree = languageService.getNavigationTree(file); + return !tree ? void 0 : simplifiedResult ? this.toLocationNavigationTree(tree, this.projectService.getScriptInfoForNormalizedPath(file)) : tree; + } + getNavigateToItems(args, simplifiedResult) { + const full = this.getFullNavigateToItems(args); + return !simplifiedResult ? flatMap(full, ({ navigateToItems }) => navigateToItems) : flatMap( + full, + ({ project, navigateToItems }) => navigateToItems.map((navItem) => { + const scriptInfo = project.getScriptInfo(navItem.fileName); + const bakedItem = { + name: navItem.name, + kind: navItem.kind, + kindModifiers: navItem.kindModifiers, + isCaseSensitive: navItem.isCaseSensitive, + matchKind: navItem.matchKind, + file: navItem.fileName, + start: scriptInfo.positionToLineOffset(navItem.textSpan.start), + end: scriptInfo.positionToLineOffset(textSpanEnd(navItem.textSpan)) + }; + if (navItem.kindModifiers && navItem.kindModifiers !== "") { + bakedItem.kindModifiers = navItem.kindModifiers; + } + if (navItem.containerName && navItem.containerName.length > 0) { + bakedItem.containerName = navItem.containerName; + } + if (navItem.containerKind && navItem.containerKind.length > 0) { + bakedItem.containerKind = navItem.containerKind; + } + return bakedItem; + }) + ); + } + getFullNavigateToItems(args) { + const { currentFileOnly, searchValue, maxResultCount, projectFileName } = args; + if (currentFileOnly) { + Debug.assertIsDefined(args.file); + const { file, project } = this.getFileAndProject(args); + return [{ project, navigateToItems: project.getLanguageService().getNavigateToItems(searchValue, maxResultCount, file) }]; + } + const preferences = this.getHostPreferences(); + const outputs = []; + const seenItems = /* @__PURE__ */ new Map(); + if (!args.file && !projectFileName) { + this.projectService.loadAncestorProjectTree(); + this.projectService.forEachEnabledProject((project) => addItemsForProject(project)); + } else { + const projects = this.getProjects(args); + forEachProjectInProjects( + projects, + /*path*/ + void 0, + (project) => addItemsForProject(project) + ); } - break; - case 4 /* InsertSpace */: - if (rule2.flags !== 1 /* CanDeleteNewLines */ && previousStartLine !== currentStartLine) { - return 0 /* None */; + return outputs; + function addItemsForProject(project) { + const projectItems = project.getLanguageService().getNavigateToItems( + searchValue, + maxResultCount, + /*fileName*/ + void 0, + /*excludeDts*/ + project.isNonTsProject(), + /*excludeLibFiles*/ + preferences.excludeLibrarySymbolsInNavTo + ); + const unseenItems = filter(projectItems, (item) => tryAddSeenItem(item) && !getMappedLocationForProject(documentSpanLocation(item), project)); + if (unseenItems.length) { + outputs.push({ project, navigateToItems: unseenItems }); + } } - const posDelta = currentRange.pos - previousRange2.end; - if (posDelta !== 1 || sourceFile.text.charCodeAt(previousRange2.end) !== 32 /* space */) { - recordReplace(previousRange2.end, currentRange.pos - previousRange2.end, " "); - return onLaterLine ? 2 /* LineRemoved */ : 0 /* None */; + function tryAddSeenItem(item) { + const name = item.name; + if (!seenItems.has(name)) { + seenItems.set(name, [item]); + return true; + } + const seen = seenItems.get(name); + for (const seenItem of seen) { + if (navigateToItemIsEqualTo(seenItem, item)) { + return false; + } + } + seen.push(item); + return true; + } + function navigateToItemIsEqualTo(a, b) { + if (a === b) { + return true; + } + if (!a || !b) { + return false; + } + return a.containerKind === b.containerKind && a.containerName === b.containerName && a.fileName === b.fileName && a.isCaseSensitive === b.isCaseSensitive && a.kind === b.kind && a.kindModifiers === b.kindModifiers && a.matchKind === b.matchKind && a.name === b.name && a.textSpan.start === b.textSpan.start && a.textSpan.length === b.textSpan.length; } - break; - case 64 /* InsertTrailingSemicolon */: - recordInsert(previousRange2.end, ";"); - } - return 0 /* None */; - } - } - function getRangeOfEnclosingComment(sourceFile, position, precedingToken, tokenAtPosition = getTokenAtPosition(sourceFile, position)) { - const jsdoc = findAncestor(tokenAtPosition, isJSDoc); - if (jsdoc) - tokenAtPosition = jsdoc.parent; - const tokenStart = tokenAtPosition.getStart(sourceFile); - if (tokenStart <= position && position < tokenAtPosition.getEnd()) { - return void 0; - } - precedingToken = precedingToken === null ? void 0 : precedingToken === void 0 ? findPrecedingToken(position, sourceFile) : precedingToken; - const trailingRangesOfPreviousToken = precedingToken && getTrailingCommentRanges(sourceFile.text, precedingToken.end); - const leadingCommentRangesOfNextToken = getLeadingCommentRangesOfNode(tokenAtPosition, sourceFile); - const commentRanges = concatenate(trailingRangesOfPreviousToken, leadingCommentRangesOfNextToken); - return commentRanges && find(commentRanges, (range) => rangeContainsPositionExclusive(range, position) || // The end marker of a single-line comment does not include the newline character. - // With caret at `^`, in the following case, we are inside a comment (^ denotes the cursor position): - // - // // asdf ^\n - // - // But for closed multi-line comments, we don't want to be inside the comment in the following case: - // - // /* asdf */^ - // - // However, unterminated multi-line comments *do* contain their end. - // - // Internally, we represent the end of the comment at the newline and closing '/', respectively. - // - position === range.end && (range.kind === 2 /* SingleLineCommentTrivia */ || position === sourceFile.getFullWidth())); - } - function getOpenTokenForList(node, list) { - switch (node.kind) { - case 175 /* Constructor */: - case 261 /* FunctionDeclaration */: - case 217 /* FunctionExpression */: - case 173 /* MethodDeclaration */: - case 172 /* MethodSignature */: - case 218 /* ArrowFunction */: - case 178 /* CallSignature */: - case 179 /* ConstructSignature */: - case 183 /* FunctionType */: - case 184 /* ConstructorType */: - case 176 /* GetAccessor */: - case 177 /* SetAccessor */: - if (node.typeParameters === list) { - return 30 /* LessThanToken */; - } else if (node.parameters === list) { - return 21 /* OpenParenToken */; } - break; - case 212 /* CallExpression */: - case 213 /* NewExpression */: - if (node.typeArguments === list) { - return 30 /* LessThanToken */; - } else if (node.arguments === list) { - return 21 /* OpenParenToken */; + getSupportedCodeFixes(args) { + if (!args) + return getSupportedCodeFixes(); + if (args.file) { + const { file, project: project2 } = this.getFileAndProject(args); + return project2.getLanguageService().getSupportedCodeFixes(file); + } + const project = this.getProject(args.projectFileName); + if (!project) + Errors.ThrowNoProject(); + return project.getLanguageService().getSupportedCodeFixes(); } - break; - case 262 /* ClassDeclaration */: - case 230 /* ClassExpression */: - case 263 /* InterfaceDeclaration */: - case 264 /* TypeAliasDeclaration */: - if (node.typeParameters === list) { - return 30 /* LessThanToken */; + isLocation(locationOrSpan) { + return locationOrSpan.line !== void 0; } - break; - case 182 /* TypeReference */: - case 214 /* TaggedTemplateExpression */: - case 185 /* TypeQuery */: - case 232 /* ExpressionWithTypeArguments */: - case 204 /* ImportType */: - if (node.typeArguments === list) { - return 30 /* LessThanToken */; + extractPositionOrRange(args, scriptInfo) { + let position; + let textRange; + if (this.isLocation(args)) { + position = getPosition(args); + } else { + textRange = this.getRange(args, scriptInfo); + } + return Debug.checkDefined(position === void 0 ? textRange : position); + function getPosition(loc) { + return loc.position !== void 0 ? loc.position : scriptInfo.lineOffsetToPosition(loc.line, loc.offset); + } } - break; - case 186 /* TypeLiteral */: - return 19 /* OpenBraceToken */; - } - return 0 /* Unknown */; - } - function getCloseTokenForOpenToken(kind) { - switch (kind) { - case 21 /* OpenParenToken */: - return 22 /* CloseParenToken */; - case 30 /* LessThanToken */: - return 32 /* GreaterThanToken */; - case 19 /* OpenBraceToken */: - return 20 /* CloseBraceToken */; - } - return 0 /* Unknown */; - } - function getIndentationString(indentation, options) { - const resetInternedStrings = !internedSizes || (internedSizes.tabSize !== options.tabSize || internedSizes.indentSize !== options.indentSize); - if (resetInternedStrings) { - internedSizes = { tabSize: options.tabSize, indentSize: options.indentSize }; - internedTabsIndentation = internedSpacesIndentation = void 0; - } - if (!options.convertTabsToSpaces) { - const tabs = Math.floor(indentation / options.tabSize); - const spaces = indentation - tabs * options.tabSize; - let tabString; - if (!internedTabsIndentation) { - internedTabsIndentation = []; - } - if (internedTabsIndentation[tabs] === void 0) { - internedTabsIndentation[tabs] = tabString = repeatString(" ", tabs); - } else { - tabString = internedTabsIndentation[tabs]; - } - return spaces ? tabString + repeatString(" ", spaces) : tabString; - } else { - let spacesString; - const quotient = Math.floor(indentation / options.indentSize); - const remainder = indentation % options.indentSize; - if (!internedSpacesIndentation) { - internedSpacesIndentation = []; - } - if (internedSpacesIndentation[quotient] === void 0) { - spacesString = repeatString(" ", options.indentSize * quotient); - internedSpacesIndentation[quotient] = spacesString; - } else { - spacesString = internedSpacesIndentation[quotient]; - } - return remainder ? spacesString + repeatString(" ", remainder) : spacesString; - } - } - var internedSizes, internedTabsIndentation, internedSpacesIndentation; - var init_formatting = __esm({ - "src/services/formatting/formatting.ts"() { - "use strict"; - init_ts4(); - init_ts_formatting(); - } - }); - - // src/services/formatting/smartIndenter.ts - var SmartIndenter; - var init_smartIndenter = __esm({ - "src/services/formatting/smartIndenter.ts"() { - "use strict"; - init_ts4(); - init_ts_formatting(); - ((SmartIndenter2) => { - let Value; - ((Value2) => { - Value2[Value2["Unknown"] = -1] = "Unknown"; - })(Value || (Value = {})); - function getIndentation(position, sourceFile, options, assumeNewLineBeforeCloseBrace = false) { - if (position > sourceFile.text.length) { - return getBaseIndentation(options); + getRange(args, scriptInfo) { + const { startPosition, endPosition } = this.getStartAndEndPosition(args, scriptInfo); + return { pos: startPosition, end: endPosition }; + } + getApplicableRefactors(args) { + const { file, project } = this.getFileAndProject(args); + const scriptInfo = project.getScriptInfoForNormalizedPath(file); + return project.getLanguageService().getApplicableRefactors(file, this.extractPositionOrRange(args, scriptInfo), this.getPreferences(file), args.triggerReason, args.kind, args.includeInteractiveActions); + } + getEditsForRefactor(args, simplifiedResult) { + const { file, project } = this.getFileAndProject(args); + const scriptInfo = project.getScriptInfoForNormalizedPath(file); + const result = project.getLanguageService().getEditsForRefactor( + file, + this.getFormatOptions(file), + this.extractPositionOrRange(args, scriptInfo), + args.refactor, + args.action, + this.getPreferences(file), + args.interactiveRefactorArguments + ); + if (result === void 0) { + return { + edits: [] + }; } - if (options.indentStyle === 0 /* None */) { - return 0; + if (simplifiedResult) { + const { renameFilename, renameLocation, edits } = result; + let mappedRenameLocation; + if (renameFilename !== void 0 && renameLocation !== void 0) { + const renameScriptInfo = project.getScriptInfoForNormalizedPath(toNormalizedPath(renameFilename)); + mappedRenameLocation = getLocationInNewDocument(getSnapshotText(renameScriptInfo.getSnapshot()), renameFilename, renameLocation, edits); + } + return { + renameLocation: mappedRenameLocation, + renameFilename, + edits: this.mapTextChangesToCodeEdits(edits), + notApplicableReason: result.notApplicableReason + }; } - const precedingToken = findPrecedingToken( - position, - sourceFile, - /*startNode*/ + return result; + } + getMoveToRefactoringFileSuggestions(args) { + const { file, project } = this.getFileAndProject(args); + const scriptInfo = project.getScriptInfoForNormalizedPath(file); + return project.getLanguageService().getMoveToRefactoringFileSuggestions(file, this.extractPositionOrRange(args, scriptInfo), this.getPreferences(file)); + } + organizeImports(args, simplifiedResult) { + Debug.assert(args.scope.type === "file"); + const { file, project } = this.getFileAndProject(args.scope.args); + const changes = project.getLanguageService().organizeImports( + { + fileName: file, + mode: args.mode ?? (args.skipDestructiveCodeActions ? "SortAndCombine" /* SortAndCombine */ : void 0), + type: "file" + }, + this.getFormatOptions(file), + this.getPreferences(file) + ); + if (simplifiedResult) { + return this.mapTextChangesToCodeEdits(changes); + } else { + return changes; + } + } + getEditsForFileRename(args, simplifiedResult) { + const oldPath = toNormalizedPath(args.oldFilePath); + const newPath = toNormalizedPath(args.newFilePath); + const formatOptions = this.getHostFormatOptions(); + const preferences = this.getHostPreferences(); + const seenFiles = /* @__PURE__ */ new Set(); + const textChanges2 = []; + this.projectService.loadAncestorProjectTree(); + this.projectService.forEachEnabledProject((project) => { + const projectTextChanges = project.getLanguageService().getEditsForFileRename(oldPath, newPath, formatOptions, preferences); + const projectFiles = []; + for (const textChange of projectTextChanges) { + if (!seenFiles.has(textChange.fileName)) { + textChanges2.push(textChange); + projectFiles.push(textChange.fileName); + } + } + for (const file of projectFiles) { + seenFiles.add(file); + } + }); + return simplifiedResult ? textChanges2.map((c) => this.mapTextChangeToCodeEdit(c)) : textChanges2; + } + getCodeFixes(args, simplifiedResult) { + const { file, project } = this.getFileAndProject(args); + const scriptInfo = project.getScriptInfoForNormalizedPath(file); + const { startPosition, endPosition } = this.getStartAndEndPosition(args, scriptInfo); + let codeActions; + try { + codeActions = project.getLanguageService().getCodeFixesAtPosition(file, startPosition, endPosition, args.errorCodes, this.getFormatOptions(file), this.getPreferences(file)); + } catch (e) { + const ls = project.getLanguageService(); + const existingDiagCodes = [ + ...ls.getSyntacticDiagnostics(file), + ...ls.getSemanticDiagnostics(file), + ...ls.getSuggestionDiagnostics(file) + ].map( + (d) => decodedTextSpanIntersectsWith(startPosition, endPosition - startPosition, d.start, d.length) && d.code + ); + const badCode = args.errorCodes.find((c) => !existingDiagCodes.includes(c)); + if (badCode !== void 0) { + e.message = `BADCLIENT: Bad error code, ${badCode} not found in range ${startPosition}..${endPosition} (found: ${existingDiagCodes.join(", ")}); could have caused this error: +${e.message}`; + } + throw e; + } + return simplifiedResult ? codeActions.map((codeAction) => this.mapCodeFixAction(codeAction)) : codeActions; + } + getCombinedCodeFix({ scope, fixId: fixId52 }, simplifiedResult) { + Debug.assert(scope.type === "file"); + const { file, project } = this.getFileAndProject(scope.args); + const res = project.getLanguageService().getCombinedCodeFix({ type: "file", fileName: file }, fixId52, this.getFormatOptions(file), this.getPreferences(file)); + if (simplifiedResult) { + return { changes: this.mapTextChangesToCodeEdits(res.changes), commands: res.commands }; + } else { + return res; + } + } + applyCodeActionCommand(args) { + const commands = args.command; + for (const command of toArray(commands)) { + const { file, project } = this.getFileAndProject(command); + project.getLanguageService().applyCodeActionCommand(command, this.getFormatOptions(file)).then( + (_result) => { + }, + (_error) => { + } + ); + } + return {}; + } + getStartAndEndPosition(args, scriptInfo) { + let startPosition, endPosition; + if (args.startPosition !== void 0) { + startPosition = args.startPosition; + } else { + startPosition = scriptInfo.lineOffsetToPosition(args.startLine, args.startOffset); + args.startPosition = startPosition; + } + if (args.endPosition !== void 0) { + endPosition = args.endPosition; + } else { + endPosition = scriptInfo.lineOffsetToPosition(args.endLine, args.endOffset); + args.endPosition = endPosition; + } + return { startPosition, endPosition }; + } + mapCodeAction({ description: description3, changes, commands }) { + return { description: description3, changes: this.mapTextChangesToCodeEdits(changes), commands }; + } + mapCodeFixAction({ fixName: fixName8, description: description3, changes, commands, fixId: fixId52, fixAllDescription }) { + return { fixName: fixName8, description: description3, changes: this.mapTextChangesToCodeEdits(changes), commands, fixId: fixId52, fixAllDescription }; + } + mapTextChangesToCodeEdits(textChanges2) { + return textChanges2.map((change) => this.mapTextChangeToCodeEdit(change)); + } + mapTextChangeToCodeEdit(textChanges2) { + const scriptInfo = this.projectService.getScriptInfoOrConfig(textChanges2.fileName); + if (!!textChanges2.isNewFile === !!scriptInfo) { + if (!scriptInfo) { + this.projectService.logErrorForScriptInfoNotFound(textChanges2.fileName); + } + Debug.fail("Expected isNewFile for (only) new files. " + JSON.stringify({ isNewFile: !!textChanges2.isNewFile, hasScriptInfo: !!scriptInfo })); + } + return scriptInfo ? { fileName: textChanges2.fileName, textChanges: textChanges2.textChanges.map((textChange) => convertTextChangeToCodeEdit(textChange, scriptInfo)) } : convertNewFileTextChangeToCodeEdit(textChanges2); + } + convertTextChangeToCodeEdit(change, scriptInfo) { + return { + start: scriptInfo.positionToLineOffset(change.span.start), + end: scriptInfo.positionToLineOffset(change.span.start + change.span.length), + newText: change.newText ? change.newText : "" + }; + } + getBraceMatching(args, simplifiedResult) { + const { file, languageService } = this.getFileAndLanguageServiceForSyntacticOperation(args); + const scriptInfo = this.projectService.getScriptInfoForNormalizedPath(file); + const position = this.getPosition(args, scriptInfo); + const spans = languageService.getBraceMatchingAtPosition(file, position); + return !spans ? void 0 : simplifiedResult ? spans.map((span) => toProtocolTextSpan(span, scriptInfo)) : spans; + } + getDiagnosticsForProject(next, delay, fileName) { + if (this.suppressDiagnosticEvents) { + return; + } + const { fileNames, languageServiceDisabled } = this.getProjectInfoWorker( + fileName, + /*projectFileName*/ void 0, - /*excludeJsdoc*/ + /*needFileNameList*/ + true, + /*excludeConfigFiles*/ true ); - const enclosingCommentRange = getRangeOfEnclosingComment(sourceFile, position, precedingToken || null); - if (enclosingCommentRange && enclosingCommentRange.kind === 3 /* MultiLineCommentTrivia */) { - return getCommentIndent(sourceFile, position, options, enclosingCommentRange); + if (languageServiceDisabled) { + return; } - if (!precedingToken) { - return getBaseIndentation(options); + const fileNamesInProject = fileNames.filter((value) => !value.includes("lib.d.ts")); + if (fileNamesInProject.length === 0) { + return; } - const precedingTokenIsLiteral = isStringOrRegularExpressionOrTemplateLiteral(precedingToken.kind); - if (precedingTokenIsLiteral && precedingToken.getStart(sourceFile) <= position && position < precedingToken.end) { - return 0; + const highPriorityFiles = []; + const mediumPriorityFiles = []; + const lowPriorityFiles = []; + const veryLowPriorityFiles = []; + const normalizedFileName = toNormalizedPath(fileName); + const project = this.projectService.ensureDefaultProjectForFile(normalizedFileName); + for (const fileNameInProject of fileNamesInProject) { + if (this.getCanonicalFileName(fileNameInProject) === this.getCanonicalFileName(fileName)) { + highPriorityFiles.push(fileNameInProject); + } else { + const info = this.projectService.getScriptInfo(fileNameInProject); + if (!info.isScriptOpen()) { + if (isDeclarationFileName(fileNameInProject)) { + veryLowPriorityFiles.push(fileNameInProject); + } else { + lowPriorityFiles.push(fileNameInProject); + } + } else { + mediumPriorityFiles.push(fileNameInProject); + } + } } - const lineAtPosition = sourceFile.getLineAndCharacterOfPosition(position).line; - const currentToken = getTokenAtPosition(sourceFile, position); - const isObjectLiteral = currentToken.kind === 19 /* OpenBraceToken */ && currentToken.parent.kind === 209 /* ObjectLiteralExpression */; - if (options.indentStyle === 1 /* Block */ || isObjectLiteral) { - return getBlockIndent(sourceFile, position, options); + const sortedFiles = [...highPriorityFiles, ...mediumPriorityFiles, ...lowPriorityFiles, ...veryLowPriorityFiles]; + const checkList = sortedFiles.map((fileName2) => ({ fileName: fileName2, project })); + this.updateErrorCheck( + next, + checkList, + delay, + /*requireOpen*/ + false + ); + } + configurePlugin(args) { + this.projectService.configurePlugin(args); + } + getSmartSelectionRange(args, simplifiedResult) { + const { locations } = args; + const { file, languageService } = this.getFileAndLanguageServiceForSyntacticOperation(args); + const scriptInfo = Debug.checkDefined(this.projectService.getScriptInfo(file)); + return map(locations, (location) => { + const pos = this.getPosition(location, scriptInfo); + const selectionRange = languageService.getSmartSelectionRange(file, pos); + return simplifiedResult ? this.mapSelectionRange(selectionRange, scriptInfo) : selectionRange; + }); + } + toggleLineComment(args, simplifiedResult) { + const { file, languageService } = this.getFileAndLanguageServiceForSyntacticOperation(args); + const scriptInfo = this.projectService.getScriptInfo(file); + const textRange = this.getRange(args, scriptInfo); + const textChanges2 = languageService.toggleLineComment(file, textRange); + if (simplifiedResult) { + const scriptInfo2 = this.projectService.getScriptInfoForNormalizedPath(file); + return textChanges2.map((textChange) => this.convertTextChangeToCodeEdit(textChange, scriptInfo2)); + } + return textChanges2; + } + toggleMultilineComment(args, simplifiedResult) { + const { file, languageService } = this.getFileAndLanguageServiceForSyntacticOperation(args); + const scriptInfo = this.projectService.getScriptInfoForNormalizedPath(file); + const textRange = this.getRange(args, scriptInfo); + const textChanges2 = languageService.toggleMultilineComment(file, textRange); + if (simplifiedResult) { + const scriptInfo2 = this.projectService.getScriptInfoForNormalizedPath(file); + return textChanges2.map((textChange) => this.convertTextChangeToCodeEdit(textChange, scriptInfo2)); + } + return textChanges2; + } + commentSelection(args, simplifiedResult) { + const { file, languageService } = this.getFileAndLanguageServiceForSyntacticOperation(args); + const scriptInfo = this.projectService.getScriptInfoForNormalizedPath(file); + const textRange = this.getRange(args, scriptInfo); + const textChanges2 = languageService.commentSelection(file, textRange); + if (simplifiedResult) { + const scriptInfo2 = this.projectService.getScriptInfoForNormalizedPath(file); + return textChanges2.map((textChange) => this.convertTextChangeToCodeEdit(textChange, scriptInfo2)); + } + return textChanges2; + } + uncommentSelection(args, simplifiedResult) { + const { file, languageService } = this.getFileAndLanguageServiceForSyntacticOperation(args); + const scriptInfo = this.projectService.getScriptInfoForNormalizedPath(file); + const textRange = this.getRange(args, scriptInfo); + const textChanges2 = languageService.uncommentSelection(file, textRange); + if (simplifiedResult) { + const scriptInfo2 = this.projectService.getScriptInfoForNormalizedPath(file); + return textChanges2.map((textChange) => this.convertTextChangeToCodeEdit(textChange, scriptInfo2)); + } + return textChanges2; + } + mapSelectionRange(selectionRange, scriptInfo) { + const result = { + textSpan: toProtocolTextSpan(selectionRange.textSpan, scriptInfo) + }; + if (selectionRange.parent) { + result.parent = this.mapSelectionRange(selectionRange.parent, scriptInfo); } - if (precedingToken.kind === 28 /* CommaToken */ && precedingToken.parent.kind !== 225 /* BinaryExpression */) { - const actualIndentation = getActualIndentationForListItemBeforeComma(precedingToken, sourceFile, options); - if (actualIndentation !== -1 /* Unknown */) { - return actualIndentation; - } + return result; + } + getScriptInfoFromProjectService(file) { + const normalizedFile = toNormalizedPath(file); + const scriptInfo = this.projectService.getScriptInfoForNormalizedPath(normalizedFile); + if (!scriptInfo) { + this.projectService.logErrorForScriptInfoNotFound(normalizedFile); + return Errors.ThrowNoProject(); } - const containerList = getListByPosition(position, precedingToken.parent, sourceFile); - if (containerList && !rangeContainsRange(containerList, precedingToken)) { - const useTheSameBaseIndentation = [217 /* FunctionExpression */, 218 /* ArrowFunction */].indexOf(currentToken.parent.kind) !== -1; - const indentSize = useTheSameBaseIndentation ? 0 : options.indentSize; - return getActualIndentationForListStartLine(containerList, sourceFile, options) + indentSize; + return scriptInfo; + } + toProtocolCallHierarchyItem(item) { + const scriptInfo = this.getScriptInfoFromProjectService(item.file); + return { + name: item.name, + kind: item.kind, + kindModifiers: item.kindModifiers, + file: item.file, + containerName: item.containerName, + span: toProtocolTextSpan(item.span, scriptInfo), + selectionSpan: toProtocolTextSpan(item.selectionSpan, scriptInfo) + }; + } + toProtocolCallHierarchyIncomingCall(incomingCall) { + const scriptInfo = this.getScriptInfoFromProjectService(incomingCall.from.file); + return { + from: this.toProtocolCallHierarchyItem(incomingCall.from), + fromSpans: incomingCall.fromSpans.map((fromSpan) => toProtocolTextSpan(fromSpan, scriptInfo)) + }; + } + toProtocolCallHierarchyOutgoingCall(outgoingCall, scriptInfo) { + return { + to: this.toProtocolCallHierarchyItem(outgoingCall.to), + fromSpans: outgoingCall.fromSpans.map((fromSpan) => toProtocolTextSpan(fromSpan, scriptInfo)) + }; + } + prepareCallHierarchy(args) { + const { file, project } = this.getFileAndProject(args); + const scriptInfo = this.projectService.getScriptInfoForNormalizedPath(file); + if (scriptInfo) { + const position = this.getPosition(args, scriptInfo); + const result = project.getLanguageService().prepareCallHierarchy(file, position); + return result && mapOneOrMany(result, (item) => this.toProtocolCallHierarchyItem(item)); } - return getSmartIndent(sourceFile, position, precedingToken, lineAtPosition, assumeNewLineBeforeCloseBrace, options); + return void 0; } - SmartIndenter2.getIndentation = getIndentation; - function getCommentIndent(sourceFile, position, options, enclosingCommentRange) { - const previousLine = getLineAndCharacterOfPosition(sourceFile, position).line - 1; - const commentStartLine = getLineAndCharacterOfPosition(sourceFile, enclosingCommentRange.pos).line; - Debug.assert(commentStartLine >= 0); - if (previousLine <= commentStartLine) { - return findFirstNonWhitespaceColumn(getStartPositionOfLine(commentStartLine, sourceFile), position, sourceFile, options); + provideCallHierarchyIncomingCalls(args) { + const { file, project } = this.getFileAndProject(args); + const scriptInfo = this.getScriptInfoFromProjectService(file); + const incomingCalls = project.getLanguageService().provideCallHierarchyIncomingCalls(file, this.getPosition(args, scriptInfo)); + return incomingCalls.map((call) => this.toProtocolCallHierarchyIncomingCall(call)); + } + provideCallHierarchyOutgoingCalls(args) { + const { file, project } = this.getFileAndProject(args); + const scriptInfo = this.getScriptInfoFromProjectService(file); + const outgoingCalls = project.getLanguageService().provideCallHierarchyOutgoingCalls(file, this.getPosition(args, scriptInfo)); + return outgoingCalls.map((call) => this.toProtocolCallHierarchyOutgoingCall(call, scriptInfo)); + } + getCanonicalFileName(fileName) { + const name = this.host.useCaseSensitiveFileNames ? fileName : toFileNameLowerCase(fileName); + return normalizePath(name); + } + exit() { + } + notRequired() { + return { responseRequired: false }; + } + requiredResponse(response) { + return { response, responseRequired: true }; + } + addProtocolHandler(command, handler) { + if (this.handlers.has(command)) { + throw new Error(`Protocol handler already exists for command "${command}"`); } - const startPositionOfLine = getStartPositionOfLine(previousLine, sourceFile); - const { column, character } = findFirstNonWhitespaceCharacterAndColumn(startPositionOfLine, position, sourceFile, options); - if (column === 0) { - return column; + this.handlers.set(command, handler); + } + setCurrentRequest(requestId) { + Debug.assert(this.currentRequestId === void 0); + this.currentRequestId = requestId; + this.cancellationToken.setRequest(requestId); + } + resetCurrentRequest(requestId) { + Debug.assert(this.currentRequestId === requestId); + this.currentRequestId = void 0; + this.cancellationToken.resetRequest(requestId); + } + executeWithRequestId(requestId, f) { + try { + this.setCurrentRequest(requestId); + return f(); + } finally { + this.resetCurrentRequest(requestId); } - const firstNonWhitespaceCharacterCode = sourceFile.text.charCodeAt(startPositionOfLine + character); - return firstNonWhitespaceCharacterCode === 42 /* asterisk */ ? column - 1 : column; } - function getBlockIndent(sourceFile, position, options) { - let current = position; - while (current > 0) { - const char = sourceFile.text.charCodeAt(current); - if (!isWhiteSpaceLike(char)) { - break; - } - current--; + executeCommand(request) { + const handler = this.handlers.get(request.command); + if (handler) { + const response = this.executeWithRequestId(request.seq, () => handler(request)); + this.projectService.enableRequestedPlugins(); + return response; + } else { + this.logger.msg(`Unrecognized JSON command:${stringifyIndented(request)}`, "Err" /* Err */); + this.doOutput( + /*info*/ + void 0, + "unknown" /* Unknown */, + request.seq, + /*success*/ + false, + `Unrecognized JSON command: ${request.command}` + ); + return { responseRequired: false }; } - const lineStart = getLineStartPositionForPosition(current, sourceFile); - return findFirstNonWhitespaceColumn(lineStart, current, sourceFile, options); } - function getSmartIndent(sourceFile, position, precedingToken, lineAtPosition, assumeNewLineBeforeCloseBrace, options) { - let previous; - let current = precedingToken; - while (current) { - if (positionBelongsToNode(current, position, sourceFile) && shouldIndentChildNode( - options, - current, - previous, - sourceFile, - /*isNextChild*/ + onMessage(message) { + var _a, _b, _c, _d, _e, _f, _g, _h, _i, _j, _k; + this.gcTimer.scheduleCollect(); + this.performanceData = void 0; + let start; + if (this.logger.hasLevel(2 /* requestTime */)) { + start = this.hrtime(); + if (this.logger.hasLevel(3 /* verbose */)) { + this.logger.info(`request:${indent2(this.toStringMessage(message))}`); + } + } + let request; + let relevantFile; + try { + request = this.parseMessage(message); + relevantFile = request.arguments && request.arguments.file ? request.arguments : void 0; + (_a = tracing) == null ? void 0 : _a.instant(tracing.Phase.Session, "request", { seq: request.seq, command: request.command }); + (_b = perfLogger) == null ? void 0 : _b.logStartCommand("" + request.command, this.toStringMessage(message).substring(0, 100)); + (_c = tracing) == null ? void 0 : _c.push( + tracing.Phase.Session, + "executeCommand", + { seq: request.seq, command: request.command }, + /*separateBeginAndEnd*/ true - )) { - const currentStart = getStartLineAndCharacterForNode(current, sourceFile); - const nextTokenKind = nextTokenIsCurlyBraceOnSameLineAsCursor(precedingToken, current, lineAtPosition, sourceFile); - const indentationDelta = nextTokenKind !== 0 /* Unknown */ ? assumeNewLineBeforeCloseBrace && nextTokenKind === 2 /* CloseBrace */ ? options.indentSize : 0 : lineAtPosition !== currentStart.line ? options.indentSize : 0; - return getIndentationForNodeWorker( - current, - currentStart, - /*ignoreActualIndentationRange*/ + ); + const { response, responseRequired } = this.executeCommand(request); + (_d = tracing) == null ? void 0 : _d.pop(); + if (this.logger.hasLevel(2 /* requestTime */)) { + const elapsedTime = hrTimeToMilliseconds(this.hrtime(start)).toFixed(4); + if (responseRequired) { + this.logger.perftrc(`${request.seq}::${request.command}: elapsed time (in milliseconds) ${elapsedTime}`); + } else { + this.logger.perftrc(`${request.seq}::${request.command}: async elapsed time (in milliseconds) ${elapsedTime}`); + } + } + (_e = perfLogger) == null ? void 0 : _e.logStopCommand("" + request.command, "Success"); + (_f = tracing) == null ? void 0 : _f.instant(tracing.Phase.Session, "response", { seq: request.seq, command: request.command, success: !!response }); + if (response) { + this.doOutput( + response, + request.command, + request.seq, + /*success*/ + true + ); + } else if (responseRequired) { + this.doOutput( + /*info*/ void 0, - indentationDelta, - sourceFile, - /*isNextChild*/ - true, - options + request.command, + request.seq, + /*success*/ + false, + "No content available." ); } - const actualIndentation = getActualIndentationForListItem( - current, - sourceFile, - options, - /*listIndentsChild*/ - true - ); - if (actualIndentation !== -1 /* Unknown */) { - return actualIndentation; + } catch (err) { + (_g = tracing) == null ? void 0 : _g.popAll(); + if (err instanceof OperationCanceledException) { + (_h = perfLogger) == null ? void 0 : _h.logStopCommand("" + (request && request.command), "Canceled: " + err); + (_i = tracing) == null ? void 0 : _i.instant(tracing.Phase.Session, "commandCanceled", { seq: request == null ? void 0 : request.seq, command: request == null ? void 0 : request.command }); + this.doOutput( + { canceled: true }, + request.command, + request.seq, + /*success*/ + true + ); + return; } - previous = current; - current = current.parent; + this.logErrorWorker(err, this.toStringMessage(message), relevantFile); + (_j = perfLogger) == null ? void 0 : _j.logStopCommand("" + (request && request.command), "Error: " + err); + (_k = tracing) == null ? void 0 : _k.instant(tracing.Phase.Session, "commandError", { seq: request == null ? void 0 : request.seq, command: request == null ? void 0 : request.command, message: err.message }); + this.doOutput( + /*info*/ + void 0, + request ? request.command : "unknown" /* Unknown */, + request ? request.seq : 0, + /*success*/ + false, + "Error processing request. " + err.message + "\n" + err.stack + ); } - return getBaseIndentation(options); } - function getIndentationForNode(n, ignoreActualIndentationRange, sourceFile, options) { - const start = sourceFile.getLineAndCharacterOfPosition(n.getStart(sourceFile)); - return getIndentationForNodeWorker( - n, - start, - ignoreActualIndentationRange, - /*indentationDelta*/ - 0, - sourceFile, - /*isNextChild*/ - false, - options - ); + parseMessage(message) { + return JSON.parse(message); } - SmartIndenter2.getIndentationForNode = getIndentationForNode; - function getBaseIndentation(options) { - return options.baseIndentSize || 0; + toStringMessage(message) { + return message; } - SmartIndenter2.getBaseIndentation = getBaseIndentation; - function getIndentationForNodeWorker(current, currentStart, ignoreActualIndentationRange, indentationDelta, sourceFile, isNextChild, options) { - var _a; - let parent2 = current.parent; - while (parent2) { - let useActualIndentation = true; - if (ignoreActualIndentationRange) { - const start = current.getStart(sourceFile); - useActualIndentation = start < ignoreActualIndentationRange.pos || start > ignoreActualIndentationRange.end; + getFormatOptions(file) { + return this.projectService.getFormatCodeOptions(file); + } + getPreferences(file) { + return this.projectService.getPreferences(file); + } + getHostFormatOptions() { + return this.projectService.getHostFormatCodeOptions(); + } + getHostPreferences() { + return this.projectService.getHostPreferences(); + } + }; + } + }); + + // src/server/scriptVersionCache.ts + var lineCollectionCapacity, CharRangeSection, EditWalker, TextChange9, _ScriptVersionCache, ScriptVersionCache, LineIndexSnapshot, LineIndex, LineNode, LineLeaf; + var init_scriptVersionCache = __esm({ + "src/server/scriptVersionCache.ts"() { + "use strict"; + init_ts7(); + init_ts_server3(); + lineCollectionCapacity = 4; + CharRangeSection = /* @__PURE__ */ ((CharRangeSection2) => { + CharRangeSection2[CharRangeSection2["PreStart"] = 0] = "PreStart"; + CharRangeSection2[CharRangeSection2["Start"] = 1] = "Start"; + CharRangeSection2[CharRangeSection2["Entire"] = 2] = "Entire"; + CharRangeSection2[CharRangeSection2["Mid"] = 3] = "Mid"; + CharRangeSection2[CharRangeSection2["End"] = 4] = "End"; + CharRangeSection2[CharRangeSection2["PostEnd"] = 5] = "PostEnd"; + return CharRangeSection2; + })(CharRangeSection || {}); + EditWalker = class { + constructor() { + this.goSubtree = true; + this.lineIndex = new LineIndex(); + this.endBranch = []; + this.state = 2 /* Entire */; + this.initialText = ""; + this.trailingText = ""; + this.lineIndex.root = new LineNode(); + this.startPath = [this.lineIndex.root]; + this.stack = [this.lineIndex.root]; + } + get done() { + return false; + } + insertLines(insertedText, suppressTrailingText) { + if (suppressTrailingText) { + this.trailingText = ""; + } + if (insertedText) { + insertedText = this.initialText + insertedText + this.trailingText; + } else { + insertedText = this.initialText + this.trailingText; + } + const lm = LineIndex.linesFromText(insertedText); + const lines = lm.lines; + if (lines.length > 1 && lines[lines.length - 1] === "") { + lines.pop(); + } + let branchParent; + let lastZeroCount; + for (let k = this.endBranch.length - 1; k >= 0; k--) { + this.endBranch[k].updateCounts(); + if (this.endBranch[k].charCount() === 0) { + lastZeroCount = this.endBranch[k]; + if (k > 0) { + branchParent = this.endBranch[k - 1]; + } else { + branchParent = this.branchNode; + } } - const containingListOrParentStart = getContainingListOrParentStart(parent2, current, sourceFile); - const parentAndChildShareLine = containingListOrParentStart.line === currentStart.line || childStartsOnTheSameLineWithElseInIfStatement(parent2, current, currentStart.line, sourceFile); - if (useActualIndentation) { - const firstListChild = (_a = getContainingList(current, sourceFile)) == null ? void 0 : _a[0]; - const listIndentsChild = !!firstListChild && getStartLineAndCharacterForNode(firstListChild, sourceFile).line > containingListOrParentStart.line; - let actualIndentation = getActualIndentationForListItem(current, sourceFile, options, listIndentsChild); - if (actualIndentation !== -1 /* Unknown */) { - return actualIndentation + indentationDelta; + } + if (lastZeroCount) { + branchParent.remove(lastZeroCount); + } + const leafNode = this.startPath[this.startPath.length - 1]; + if (lines.length > 0) { + leafNode.text = lines[0]; + if (lines.length > 1) { + let insertedNodes = new Array(lines.length - 1); + let startNode2 = leafNode; + for (let i = 1; i < lines.length; i++) { + insertedNodes[i - 1] = new LineLeaf(lines[i]); } - actualIndentation = getActualIndentationForNode(current, parent2, currentStart, parentAndChildShareLine, sourceFile, options); - if (actualIndentation !== -1 /* Unknown */) { - return actualIndentation + indentationDelta; + let pathIndex = this.startPath.length - 2; + while (pathIndex >= 0) { + const insertionNode = this.startPath[pathIndex]; + insertedNodes = insertionNode.insertAt(startNode2, insertedNodes); + pathIndex--; + startNode2 = insertionNode; + } + let insertedNodesLen = insertedNodes.length; + while (insertedNodesLen > 0) { + const newRoot = new LineNode(); + newRoot.add(this.lineIndex.root); + insertedNodes = newRoot.insertAt(this.lineIndex.root, insertedNodes); + insertedNodesLen = insertedNodes.length; + this.lineIndex.root = newRoot; + } + this.lineIndex.root.updateCounts(); + } else { + for (let j = this.startPath.length - 2; j >= 0; j--) { + this.startPath[j].updateCounts(); } } - if (shouldIndentChildNode(options, parent2, current, sourceFile, isNextChild) && !parentAndChildShareLine) { - indentationDelta += options.indentSize; - } - const useTrueStart = isArgumentAndStartLineOverlapsExpressionBeingCalled(parent2, current, currentStart.line, sourceFile); - current = parent2; - parent2 = current.parent; - currentStart = useTrueStart ? sourceFile.getLineAndCharacterOfPosition(current.getStart(sourceFile)) : containingListOrParentStart; + } else { + const insertionNode = this.startPath[this.startPath.length - 2]; + insertionNode.remove(leafNode); + for (let j = this.startPath.length - 2; j >= 0; j--) { + this.startPath[j].updateCounts(); + } + } + return this.lineIndex; + } + post(_relativeStart, _relativeLength, lineCollection) { + if (lineCollection === this.lineCollectionAtBranch) { + this.state = 4 /* End */; + } + this.stack.pop(); + } + pre(_relativeStart, _relativeLength, lineCollection, _parent, nodeType) { + const currentNode = this.stack[this.stack.length - 1]; + if (this.state === 2 /* Entire */ && nodeType === 1 /* Start */) { + this.state = 1 /* Start */; + this.branchNode = currentNode; + this.lineCollectionAtBranch = lineCollection; + } + let child; + function fresh(node) { + if (node.isLeaf()) { + return new LineLeaf(""); + } else + return new LineNode(); + } + switch (nodeType) { + case 0 /* PreStart */: + this.goSubtree = false; + if (this.state !== 4 /* End */) { + currentNode.add(lineCollection); + } + break; + case 1 /* Start */: + if (this.state === 4 /* End */) { + this.goSubtree = false; + } else { + child = fresh(lineCollection); + currentNode.add(child); + this.startPath.push(child); + } + break; + case 2 /* Entire */: + if (this.state !== 4 /* End */) { + child = fresh(lineCollection); + currentNode.add(child); + this.startPath.push(child); + } else { + if (!lineCollection.isLeaf()) { + child = fresh(lineCollection); + currentNode.add(child); + this.endBranch.push(child); + } + } + break; + case 3 /* Mid */: + this.goSubtree = false; + break; + case 4 /* End */: + if (this.state !== 4 /* End */) { + this.goSubtree = false; + } else { + if (!lineCollection.isLeaf()) { + child = fresh(lineCollection); + currentNode.add(child); + this.endBranch.push(child); + } + } + break; + case 5 /* PostEnd */: + this.goSubtree = false; + if (this.state !== 1 /* Start */) { + currentNode.add(lineCollection); + } + break; + } + if (this.goSubtree) { + this.stack.push(child); } - return indentationDelta + getBaseIndentation(options); - } - function getContainingListOrParentStart(parent2, child, sourceFile) { - const containingList = getContainingList(child, sourceFile); - const startPos = containingList ? containingList.pos : parent2.getStart(sourceFile); - return sourceFile.getLineAndCharacterOfPosition(startPos); } - function getActualIndentationForListItemBeforeComma(commaToken, sourceFile, options) { - const commaItemInfo = findListItemInfo(commaToken); - if (commaItemInfo && commaItemInfo.listItemIndex > 0) { - return deriveActualIndentationFromList(commaItemInfo.list.getChildren(), commaItemInfo.listItemIndex - 1, sourceFile, options); + // just gather text from the leaves + leaf(relativeStart, relativeLength, ll) { + if (this.state === 1 /* Start */) { + this.initialText = ll.text.substring(0, relativeStart); + } else if (this.state === 2 /* Entire */) { + this.initialText = ll.text.substring(0, relativeStart); + this.trailingText = ll.text.substring(relativeStart + relativeLength); } else { - return -1 /* Unknown */; + this.trailingText = ll.text.substring(relativeStart + relativeLength); } } - function getActualIndentationForNode(current, parent2, currentLineAndChar, parentAndChildShareLine, sourceFile, options) { - const useActualIndentation = (isDeclaration(current) || isStatementButNotDeclaration(current)) && (parent2.kind === 311 /* SourceFile */ || !parentAndChildShareLine); - if (!useActualIndentation) { - return -1 /* Unknown */; - } - return findColumnForFirstNonWhitespaceCharacterInLine(currentLineAndChar, sourceFile, options); + }; + TextChange9 = class { + constructor(pos, deleteLen, insertedText) { + this.pos = pos; + this.deleteLen = deleteLen; + this.insertedText = insertedText; } - let NextTokenKind; - ((NextTokenKind2) => { - NextTokenKind2[NextTokenKind2["Unknown"] = 0] = "Unknown"; - NextTokenKind2[NextTokenKind2["OpenBrace"] = 1] = "OpenBrace"; - NextTokenKind2[NextTokenKind2["CloseBrace"] = 2] = "CloseBrace"; - })(NextTokenKind || (NextTokenKind = {})); - function nextTokenIsCurlyBraceOnSameLineAsCursor(precedingToken, current, lineAtPosition, sourceFile) { - const nextToken = findNextToken(precedingToken, current, sourceFile); - if (!nextToken) { - return 0 /* Unknown */; - } - if (nextToken.kind === 19 /* OpenBraceToken */) { - return 1 /* OpenBrace */; - } else if (nextToken.kind === 20 /* CloseBraceToken */) { - const nextTokenStartLine = getStartLineAndCharacterForNode(nextToken, sourceFile).line; - return lineAtPosition === nextTokenStartLine ? 2 /* CloseBrace */ : 0 /* Unknown */; + getTextChangeRange() { + return createTextChangeRange(createTextSpan(this.pos, this.deleteLen), this.insertedText ? this.insertedText.length : 0); + } + }; + _ScriptVersionCache = class _ScriptVersionCache { + constructor() { + this.changes = []; + this.versions = new Array(_ScriptVersionCache.maxVersions); + this.minVersion = 0; + // no versions earlier than min version will maintain change history + this.currentVersion = 0; + } + versionToIndex(version2) { + if (version2 < this.minVersion || version2 > this.currentVersion) { + return void 0; } - return 0 /* Unknown */; + return version2 % _ScriptVersionCache.maxVersions; } - function getStartLineAndCharacterForNode(n, sourceFile) { - return sourceFile.getLineAndCharacterOfPosition(n.getStart(sourceFile)); + currentVersionToIndex() { + return this.currentVersion % _ScriptVersionCache.maxVersions; } - function isArgumentAndStartLineOverlapsExpressionBeingCalled(parent2, child, childStartLine, sourceFile) { - if (!(isCallExpression(parent2) && contains(parent2.arguments, child))) { - return false; + // REVIEW: can optimize by coalescing simple edits + edit(pos, deleteLen, insertedText) { + this.changes.push(new TextChange9(pos, deleteLen, insertedText)); + if (this.changes.length > _ScriptVersionCache.changeNumberThreshold || deleteLen > _ScriptVersionCache.changeLengthThreshold || insertedText && insertedText.length > _ScriptVersionCache.changeLengthThreshold) { + this.getSnapshot(); } - const expressionOfCallExpressionEnd = parent2.expression.getEnd(); - const expressionOfCallExpressionEndLine = getLineAndCharacterOfPosition(sourceFile, expressionOfCallExpressionEnd).line; - return expressionOfCallExpressionEndLine === childStartLine; } - SmartIndenter2.isArgumentAndStartLineOverlapsExpressionBeingCalled = isArgumentAndStartLineOverlapsExpressionBeingCalled; - function childStartsOnTheSameLineWithElseInIfStatement(parent2, child, childStartLine, sourceFile) { - if (parent2.kind === 244 /* IfStatement */ && parent2.elseStatement === child) { - const elseKeyword = findChildOfKind(parent2, 93 /* ElseKeyword */, sourceFile); - Debug.assert(elseKeyword !== void 0); - const elseKeywordStartLine = getStartLineAndCharacterForNode(elseKeyword, sourceFile).line; - return elseKeywordStartLine === childStartLine; + getSnapshot() { + return this._getSnapshot(); + } + _getSnapshot() { + let snap = this.versions[this.currentVersionToIndex()]; + if (this.changes.length > 0) { + let snapIndex = snap.index; + for (const change of this.changes) { + snapIndex = snapIndex.edit(change.pos, change.deleteLen, change.insertedText); + } + snap = new LineIndexSnapshot(this.currentVersion + 1, this, snapIndex, this.changes); + this.currentVersion = snap.version; + this.versions[this.currentVersionToIndex()] = snap; + this.changes = []; + if (this.currentVersion - this.minVersion >= _ScriptVersionCache.maxVersions) { + this.minVersion = this.currentVersion - _ScriptVersionCache.maxVersions + 1; + } } - return false; + return snap; } - SmartIndenter2.childStartsOnTheSameLineWithElseInIfStatement = childStartsOnTheSameLineWithElseInIfStatement; - function childIsUnindentedBranchOfConditionalExpression(parent2, child, childStartLine, sourceFile) { - if (isConditionalExpression(parent2) && (child === parent2.whenTrue || child === parent2.whenFalse)) { - const conditionEndLine = getLineAndCharacterOfPosition(sourceFile, parent2.condition.end).line; - if (child === parent2.whenTrue) { - return childStartLine === conditionEndLine; + getSnapshotVersion() { + return this._getSnapshot().version; + } + getAbsolutePositionAndLineText(oneBasedLine) { + return this._getSnapshot().index.lineNumberToInfo(oneBasedLine); + } + lineOffsetToPosition(line, column) { + return this._getSnapshot().index.absolutePositionOfStartOfLine(line) + (column - 1); + } + positionToLineOffset(position) { + return this._getSnapshot().index.positionToLineOffset(position); + } + lineToTextSpan(line) { + const index = this._getSnapshot().index; + const { lineText, absolutePosition } = index.lineNumberToInfo(line + 1); + const len = lineText !== void 0 ? lineText.length : index.absolutePositionOfStartOfLine(line + 2) - absolutePosition; + return createTextSpan(absolutePosition, len); + } + getTextChangesBetweenVersions(oldVersion, newVersion) { + if (oldVersion < newVersion) { + if (oldVersion >= this.minVersion) { + const textChangeRanges = []; + for (let i = oldVersion + 1; i <= newVersion; i++) { + const snap = this.versions[this.versionToIndex(i)]; + for (const textChange of snap.changesSincePreviousVersion) { + textChangeRanges.push(textChange.getTextChangeRange()); + } + } + return collapseTextChangeRangesAcrossMultipleVersions(textChangeRanges); } else { - const trueStartLine = getStartLineAndCharacterForNode(parent2.whenTrue, sourceFile).line; - const trueEndLine = getLineAndCharacterOfPosition(sourceFile, parent2.whenTrue.end).line; - return conditionEndLine === trueStartLine && trueEndLine === childStartLine; + return void 0; } + } else { + return unchangedTextChangeRange; } - return false; } - SmartIndenter2.childIsUnindentedBranchOfConditionalExpression = childIsUnindentedBranchOfConditionalExpression; - function argumentStartsOnSameLineAsPreviousArgument(parent2, child, childStartLine, sourceFile) { - if (isCallOrNewExpression(parent2)) { - if (!parent2.arguments) - return false; - const currentNode = find(parent2.arguments, (arg) => arg.pos === child.pos); - if (!currentNode) - return false; - const currentIndex = parent2.arguments.indexOf(currentNode); - if (currentIndex === 0) - return false; - const previousNode = parent2.arguments[currentIndex - 1]; - const lineOfPreviousNode = getLineAndCharacterOfPosition(sourceFile, previousNode.getEnd()).line; - if (childStartLine === lineOfPreviousNode) { - return true; + getLineCount() { + return this._getSnapshot().index.getLineCount(); + } + static fromString(script) { + const svc = new _ScriptVersionCache(); + const snap = new LineIndexSnapshot(0, svc, new LineIndex()); + svc.versions[svc.currentVersion] = snap; + const lm = LineIndex.linesFromText(script); + snap.index.load(lm.lines); + return svc; + } + }; + _ScriptVersionCache.changeNumberThreshold = 8; + _ScriptVersionCache.changeLengthThreshold = 256; + _ScriptVersionCache.maxVersions = 8; + ScriptVersionCache = _ScriptVersionCache; + LineIndexSnapshot = class _LineIndexSnapshot { + constructor(version2, cache, index, changesSincePreviousVersion = emptyArray2) { + this.version = version2; + this.cache = cache; + this.index = index; + this.changesSincePreviousVersion = changesSincePreviousVersion; + } + getText(rangeStart, rangeEnd) { + return this.index.getText(rangeStart, rangeEnd - rangeStart); + } + getLength() { + return this.index.getLength(); + } + getChangeRange(oldSnapshot) { + if (oldSnapshot instanceof _LineIndexSnapshot && this.cache === oldSnapshot.cache) { + if (this.version <= oldSnapshot.version) { + return unchangedTextChangeRange; + } else { + return this.cache.getTextChangesBetweenVersions(oldSnapshot.version, this.version); } } - return false; } - SmartIndenter2.argumentStartsOnSameLineAsPreviousArgument = argumentStartsOnSameLineAsPreviousArgument; - function getContainingList(node, sourceFile) { - return node.parent && getListByRange(node.getStart(sourceFile), node.getEnd(), node.parent, sourceFile); + }; + LineIndex = class _LineIndex { + constructor() { + // set this to true to check each edit for accuracy + this.checkEdits = false; } - SmartIndenter2.getContainingList = getContainingList; - function getListByPosition(pos, node, sourceFile) { - return node && getListByRange(pos, pos, node, sourceFile); + absolutePositionOfStartOfLine(oneBasedLine) { + return this.lineNumberToInfo(oneBasedLine).absolutePosition; } - function getListByRange(start, end, node, sourceFile) { - switch (node.kind) { - case 182 /* TypeReference */: - return getList(node.typeArguments); - case 209 /* ObjectLiteralExpression */: - return getList(node.properties); - case 208 /* ArrayLiteralExpression */: - return getList(node.elements); - case 186 /* TypeLiteral */: - return getList(node.members); - case 261 /* FunctionDeclaration */: - case 217 /* FunctionExpression */: - case 218 /* ArrowFunction */: - case 173 /* MethodDeclaration */: - case 172 /* MethodSignature */: - case 178 /* CallSignature */: - case 175 /* Constructor */: - case 184 /* ConstructorType */: - case 179 /* ConstructSignature */: - return getList(node.typeParameters) || getList(node.parameters); - case 176 /* GetAccessor */: - return getList(node.parameters); - case 262 /* ClassDeclaration */: - case 230 /* ClassExpression */: - case 263 /* InterfaceDeclaration */: - case 264 /* TypeAliasDeclaration */: - case 351 /* JSDocTemplateTag */: - return getList(node.typeParameters); - case 213 /* NewExpression */: - case 212 /* CallExpression */: - return getList(node.typeArguments) || getList(node.arguments); - case 260 /* VariableDeclarationList */: - return getList(node.declarations); - case 274 /* NamedImports */: - case 278 /* NamedExports */: - return getList(node.elements); - case 205 /* ObjectBindingPattern */: - case 206 /* ArrayBindingPattern */: - return getList(node.elements); - } - function getList(list) { - return list && rangeContainsStartEnd(getVisualListRange(node, list, sourceFile), start, end) ? list : void 0; + positionToLineOffset(position) { + const { oneBasedLine, zeroBasedColumn } = this.root.charOffsetToLineInfo(1, position); + return { line: oneBasedLine, offset: zeroBasedColumn + 1 }; + } + positionToColumnAndLineText(position) { + return this.root.charOffsetToLineInfo(1, position); + } + getLineCount() { + return this.root.lineCount(); + } + lineNumberToInfo(oneBasedLine) { + const lineCount = this.getLineCount(); + if (oneBasedLine <= lineCount) { + const { position, leaf } = this.root.lineNumberToInfo(oneBasedLine, 0); + return { absolutePosition: position, lineText: leaf && leaf.text }; + } else { + return { absolutePosition: this.root.charCount(), lineText: void 0 }; } } - function getVisualListRange(node, list, sourceFile) { - const children = node.getChildren(sourceFile); - for (let i = 1; i < children.length - 1; i++) { - if (children[i].pos === list.pos && children[i].end === list.end) { - return { pos: children[i - 1].end, end: children[i + 1].getStart(sourceFile) }; + load(lines) { + if (lines.length > 0) { + const leaves = []; + for (let i = 0; i < lines.length; i++) { + leaves[i] = new LineLeaf(lines[i]); } + this.root = _LineIndex.buildTreeFromBottom(leaves); + } else { + this.root = new LineNode(); } - return list; } - function getActualIndentationForListStartLine(list, sourceFile, options) { - if (!list) { - return -1 /* Unknown */; - } - return findColumnForFirstNonWhitespaceCharacterInLine(sourceFile.getLineAndCharacterOfPosition(list.pos), sourceFile, options); + walk(rangeStart, rangeLength, walkFns) { + this.root.walk(rangeStart, rangeLength, walkFns); } - function getActualIndentationForListItem(node, sourceFile, options, listIndentsChild) { - if (node.parent && node.parent.kind === 260 /* VariableDeclarationList */) { - return -1 /* Unknown */; + getText(rangeStart, rangeLength) { + let accum = ""; + if (rangeLength > 0 && rangeStart < this.root.charCount()) { + this.walk(rangeStart, rangeLength, { + goSubtree: true, + done: false, + leaf: (relativeStart, relativeLength, ll) => { + accum = accum.concat(ll.text.substring(relativeStart, relativeStart + relativeLength)); + } + }); } - const containingList = getContainingList(node, sourceFile); - if (containingList) { - const index = containingList.indexOf(node); - if (index !== -1) { - const result = deriveActualIndentationFromList(containingList, index, sourceFile, options); - if (result !== -1 /* Unknown */) { - return result; + return accum; + } + getLength() { + return this.root.charCount(); + } + every(f, rangeStart, rangeEnd) { + if (!rangeEnd) { + rangeEnd = this.root.charCount(); + } + const walkFns = { + goSubtree: true, + done: false, + leaf(relativeStart, relativeLength, ll) { + if (!f(ll, relativeStart, relativeLength)) { + this.done = true; } } - return getActualIndentationForListStartLine(containingList, sourceFile, options) + (listIndentsChild ? options.indentSize : 0); - } - return -1 /* Unknown */; + }; + this.walk(rangeStart, rangeEnd - rangeStart, walkFns); + return !walkFns.done; } - function deriveActualIndentationFromList(list, index, sourceFile, options) { - Debug.assert(index >= 0 && index < list.length); - const node = list[index]; - let lineAndCharacter = getStartLineAndCharacterForNode(node, sourceFile); - for (let i = index - 1; i >= 0; i--) { - if (list[i].kind === 28 /* CommaToken */) { - continue; + edit(pos, deleteLength, newText) { + if (this.root.charCount() === 0) { + Debug.assert(deleteLength === 0); + if (newText !== void 0) { + this.load(_LineIndex.linesFromText(newText).lines); + return this; } - const prevEndLine = sourceFile.getLineAndCharacterOfPosition(list[i].end).line; - if (prevEndLine !== lineAndCharacter.line) { - return findColumnForFirstNonWhitespaceCharacterInLine(lineAndCharacter, sourceFile, options); + return void 0; + } else { + let checkText; + if (this.checkEdits) { + const source = this.getText(0, this.root.charCount()); + checkText = source.slice(0, pos) + newText + source.slice(pos + deleteLength); + } + const walker = new EditWalker(); + let suppressTrailingText = false; + if (pos >= this.root.charCount()) { + pos = this.root.charCount() - 1; + const endString = this.getText(pos, 1); + if (newText) { + newText = endString + newText; + } else { + newText = endString; + } + deleteLength = 0; + suppressTrailingText = true; + } else if (deleteLength > 0) { + const e = pos + deleteLength; + const { zeroBasedColumn, lineText } = this.positionToColumnAndLineText(e); + if (zeroBasedColumn === 0) { + deleteLength += lineText.length; + newText = newText ? newText + lineText : lineText; + } } - lineAndCharacter = getStartLineAndCharacterForNode(list[i], sourceFile); + this.root.walk(pos, deleteLength, walker); + walker.insertLines(newText, suppressTrailingText); + if (this.checkEdits) { + const updatedText = walker.lineIndex.getText(0, walker.lineIndex.getLength()); + Debug.assert(checkText === updatedText, "buffer edit mismatch"); + } + return walker.lineIndex; } - return -1 /* Unknown */; } - function findColumnForFirstNonWhitespaceCharacterInLine(lineAndCharacter, sourceFile, options) { - const lineStart = sourceFile.getPositionOfLineAndCharacter(lineAndCharacter.line, 0); - return findFirstNonWhitespaceColumn(lineStart, lineStart + lineAndCharacter.character, sourceFile, options); + static buildTreeFromBottom(nodes) { + if (nodes.length < lineCollectionCapacity) { + return new LineNode(nodes); + } + const interiorNodes = new Array(Math.ceil(nodes.length / lineCollectionCapacity)); + let nodeIndex = 0; + for (let i = 0; i < interiorNodes.length; i++) { + const end = Math.min(nodeIndex + lineCollectionCapacity, nodes.length); + interiorNodes[i] = new LineNode(nodes.slice(nodeIndex, end)); + nodeIndex = end; + } + return this.buildTreeFromBottom(interiorNodes); } - function findFirstNonWhitespaceCharacterAndColumn(startPos, endPos, sourceFile, options) { - let character = 0; - let column = 0; - for (let pos = startPos; pos < endPos; pos++) { - const ch = sourceFile.text.charCodeAt(pos); - if (!isWhiteSpaceSingleLine(ch)) { - break; - } - if (ch === 9 /* tab */) { - column += options.tabSize + column % options.tabSize; - } else { - column++; + static linesFromText(text) { + const lineMap = computeLineStarts(text); + if (lineMap.length === 0) { + return { lines: [], lineMap }; + } + const lines = new Array(lineMap.length); + const lc = lineMap.length - 1; + for (let lmi = 0; lmi < lc; lmi++) { + lines[lmi] = text.substring(lineMap[lmi], lineMap[lmi + 1]); + } + const endText = text.substring(lineMap[lc]); + if (endText.length > 0) { + lines[lc] = endText; + } else { + lines.pop(); + } + return { lines, lineMap }; + } + }; + LineNode = class _LineNode { + constructor(children = []) { + this.children = children; + this.totalChars = 0; + this.totalLines = 0; + if (children.length) + this.updateCounts(); + } + isLeaf() { + return false; + } + updateCounts() { + this.totalChars = 0; + this.totalLines = 0; + for (const child of this.children) { + this.totalChars += child.charCount(); + this.totalLines += child.lineCount(); + } + } + execWalk(rangeStart, rangeLength, walkFns, childIndex, nodeType) { + if (walkFns.pre) { + walkFns.pre(rangeStart, rangeLength, this.children[childIndex], this, nodeType); + } + if (walkFns.goSubtree) { + this.children[childIndex].walk(rangeStart, rangeLength, walkFns); + if (walkFns.post) { + walkFns.post(rangeStart, rangeLength, this.children[childIndex], this, nodeType); } - character++; + } else { + walkFns.goSubtree = true; } - return { column, character }; + return walkFns.done; } - SmartIndenter2.findFirstNonWhitespaceCharacterAndColumn = findFirstNonWhitespaceCharacterAndColumn; - function findFirstNonWhitespaceColumn(startPos, endPos, sourceFile, options) { - return findFirstNonWhitespaceCharacterAndColumn(startPos, endPos, sourceFile, options).column; + skipChild(relativeStart, relativeLength, childIndex, walkFns, nodeType) { + if (walkFns.pre && !walkFns.done) { + walkFns.pre(relativeStart, relativeLength, this.children[childIndex], this, nodeType); + walkFns.goSubtree = true; + } } - SmartIndenter2.findFirstNonWhitespaceColumn = findFirstNonWhitespaceColumn; - function nodeWillIndentChild(settings, parent2, child, sourceFile, indentByDefault) { - const childKind = child ? child.kind : 0 /* Unknown */; - switch (parent2.kind) { - case 243 /* ExpressionStatement */: - case 262 /* ClassDeclaration */: - case 230 /* ClassExpression */: - case 263 /* InterfaceDeclaration */: - case 265 /* EnumDeclaration */: - case 264 /* TypeAliasDeclaration */: - case 208 /* ArrayLiteralExpression */: - case 240 /* Block */: - case 267 /* ModuleBlock */: - case 209 /* ObjectLiteralExpression */: - case 186 /* TypeLiteral */: - case 199 /* MappedType */: - case 188 /* TupleType */: - case 216 /* ParenthesizedExpression */: - case 210 /* PropertyAccessExpression */: - case 212 /* CallExpression */: - case 213 /* NewExpression */: - case 242 /* VariableStatement */: - case 276 /* ExportAssignment */: - case 252 /* ReturnStatement */: - case 226 /* ConditionalExpression */: - case 206 /* ArrayBindingPattern */: - case 205 /* ObjectBindingPattern */: - case 285 /* JsxOpeningElement */: - case 288 /* JsxOpeningFragment */: - case 284 /* JsxSelfClosingElement */: - case 293 /* JsxExpression */: - case 172 /* MethodSignature */: - case 178 /* CallSignature */: - case 179 /* ConstructSignature */: - case 168 /* Parameter */: - case 183 /* FunctionType */: - case 184 /* ConstructorType */: - case 195 /* ParenthesizedType */: - case 214 /* TaggedTemplateExpression */: - case 222 /* AwaitExpression */: - case 278 /* NamedExports */: - case 274 /* NamedImports */: - case 280 /* ExportSpecifier */: - case 275 /* ImportSpecifier */: - case 171 /* PropertyDeclaration */: - case 295 /* CaseClause */: - case 296 /* DefaultClause */: - return true; - case 268 /* CaseBlock */: - return settings.indentSwitchCase ?? true; - case 259 /* VariableDeclaration */: - case 302 /* PropertyAssignment */: - case 225 /* BinaryExpression */: - if (!settings.indentMultiLineObjectLiteralBeginningOnBlankLine && sourceFile && childKind === 209 /* ObjectLiteralExpression */) { - return rangeIsOnOneLine(sourceFile, child); - } - if (parent2.kind === 225 /* BinaryExpression */ && sourceFile && child && childKind === 283 /* JsxElement */) { - const parentStartLine = sourceFile.getLineAndCharacterOfPosition(skipTrivia(sourceFile.text, parent2.pos)).line; - const childStartLine = sourceFile.getLineAndCharacterOfPosition(skipTrivia(sourceFile.text, child.pos)).line; - return parentStartLine !== childStartLine; + walk(rangeStart, rangeLength, walkFns) { + let childIndex = 0; + let childCharCount = this.children[childIndex].charCount(); + let adjustedStart = rangeStart; + while (adjustedStart >= childCharCount) { + this.skipChild(adjustedStart, rangeLength, childIndex, walkFns, 0 /* PreStart */); + adjustedStart -= childCharCount; + childIndex++; + childCharCount = this.children[childIndex].charCount(); + } + if (adjustedStart + rangeLength <= childCharCount) { + if (this.execWalk(adjustedStart, rangeLength, walkFns, childIndex, 2 /* Entire */)) { + return; + } + } else { + if (this.execWalk(adjustedStart, childCharCount - adjustedStart, walkFns, childIndex, 1 /* Start */)) { + return; + } + let adjustedLength = rangeLength - (childCharCount - adjustedStart); + childIndex++; + const child = this.children[childIndex]; + childCharCount = child.charCount(); + while (adjustedLength > childCharCount) { + if (this.execWalk(0, childCharCount, walkFns, childIndex, 3 /* Mid */)) { + return; } - if (parent2.kind !== 225 /* BinaryExpression */) { - return true; + adjustedLength -= childCharCount; + childIndex++; + childCharCount = this.children[childIndex].charCount(); + } + if (adjustedLength > 0) { + if (this.execWalk(0, adjustedLength, walkFns, childIndex, 4 /* End */)) { + return; } - break; - case 245 /* DoStatement */: - case 246 /* WhileStatement */: - case 248 /* ForInStatement */: - case 249 /* ForOfStatement */: - case 247 /* ForStatement */: - case 244 /* IfStatement */: - case 261 /* FunctionDeclaration */: - case 217 /* FunctionExpression */: - case 173 /* MethodDeclaration */: - case 175 /* Constructor */: - case 176 /* GetAccessor */: - case 177 /* SetAccessor */: - return childKind !== 240 /* Block */; - case 218 /* ArrowFunction */: - if (sourceFile && childKind === 216 /* ParenthesizedExpression */) { - return rangeIsOnOneLine(sourceFile, child); + } + } + if (walkFns.pre) { + const clen = this.children.length; + if (childIndex < clen - 1) { + for (let ej = childIndex + 1; ej < clen; ej++) { + this.skipChild(0, 0, ej, walkFns, 5 /* PostEnd */); } - return childKind !== 240 /* Block */; - case 277 /* ExportDeclaration */: - return childKind !== 278 /* NamedExports */; - case 271 /* ImportDeclaration */: - return childKind !== 272 /* ImportClause */ || !!child.namedBindings && child.namedBindings.kind !== 274 /* NamedImports */; - case 283 /* JsxElement */: - return childKind !== 286 /* JsxClosingElement */; - case 287 /* JsxFragment */: - return childKind !== 289 /* JsxClosingFragment */; - case 192 /* IntersectionType */: - case 191 /* UnionType */: - if (childKind === 186 /* TypeLiteral */ || childKind === 188 /* TupleType */) { - return false; + } + } + } + // Input position is relative to the start of this node. + // Output line number is absolute. + charOffsetToLineInfo(lineNumberAccumulator, relativePosition) { + if (this.children.length === 0) { + return { oneBasedLine: lineNumberAccumulator, zeroBasedColumn: relativePosition, lineText: void 0 }; + } + for (const child of this.children) { + if (child.charCount() > relativePosition) { + if (child.isLeaf()) { + return { oneBasedLine: lineNumberAccumulator, zeroBasedColumn: relativePosition, lineText: child.text }; + } else { + return child.charOffsetToLineInfo(lineNumberAccumulator, relativePosition); } - break; + } else { + relativePosition -= child.charCount(); + lineNumberAccumulator += child.lineCount(); + } } - return indentByDefault; + const lineCount = this.lineCount(); + if (lineCount === 0) { + return { oneBasedLine: 1, zeroBasedColumn: 0, lineText: void 0 }; + } + const leaf = Debug.checkDefined(this.lineNumberToInfo(lineCount, 0).leaf); + return { oneBasedLine: lineCount, zeroBasedColumn: leaf.charCount(), lineText: void 0 }; } - SmartIndenter2.nodeWillIndentChild = nodeWillIndentChild; - function isControlFlowEndingStatement(kind, parent2) { - switch (kind) { - case 252 /* ReturnStatement */: - case 256 /* ThrowStatement */: - case 250 /* ContinueStatement */: - case 251 /* BreakStatement */: - return parent2.kind !== 240 /* Block */; - default: - return false; + /** + * Input line number is relative to the start of this node. + * Output line number is relative to the child. + * positionAccumulator will be an absolute position once relativeLineNumber reaches 0. + */ + lineNumberToInfo(relativeOneBasedLine, positionAccumulator) { + for (const child of this.children) { + const childLineCount = child.lineCount(); + if (childLineCount >= relativeOneBasedLine) { + return child.isLeaf() ? { position: positionAccumulator, leaf: child } : child.lineNumberToInfo(relativeOneBasedLine, positionAccumulator); + } else { + relativeOneBasedLine -= childLineCount; + positionAccumulator += child.charCount(); + } + } + return { position: positionAccumulator, leaf: void 0 }; + } + splitAfter(childIndex) { + let splitNode; + const clen = this.children.length; + childIndex++; + const endLength = childIndex; + if (childIndex < clen) { + splitNode = new _LineNode(); + while (childIndex < clen) { + splitNode.add(this.children[childIndex]); + childIndex++; + } + splitNode.updateCounts(); + } + this.children.length = endLength; + return splitNode; + } + remove(child) { + const childIndex = this.findChildIndex(child); + const clen = this.children.length; + if (childIndex < clen - 1) { + for (let i = childIndex; i < clen - 1; i++) { + this.children[i] = this.children[i + 1]; + } + } + this.children.pop(); + } + findChildIndex(child) { + const childIndex = this.children.indexOf(child); + Debug.assert(childIndex !== -1); + return childIndex; + } + insertAt(child, nodes) { + let childIndex = this.findChildIndex(child); + const clen = this.children.length; + const nodeCount = nodes.length; + if (clen < lineCollectionCapacity && childIndex === clen - 1 && nodeCount === 1) { + this.add(nodes[0]); + this.updateCounts(); + return []; + } else { + const shiftNode = this.splitAfter(childIndex); + let nodeIndex = 0; + childIndex++; + while (childIndex < lineCollectionCapacity && nodeIndex < nodeCount) { + this.children[childIndex] = nodes[nodeIndex]; + childIndex++; + nodeIndex++; + } + let splitNodes = []; + let splitNodeCount = 0; + if (nodeIndex < nodeCount) { + splitNodeCount = Math.ceil((nodeCount - nodeIndex) / lineCollectionCapacity); + splitNodes = new Array(splitNodeCount); + let splitNodeIndex = 0; + for (let i = 0; i < splitNodeCount; i++) { + splitNodes[i] = new _LineNode(); + } + let splitNode = splitNodes[0]; + while (nodeIndex < nodeCount) { + splitNode.add(nodes[nodeIndex]); + nodeIndex++; + if (splitNode.children.length === lineCollectionCapacity) { + splitNodeIndex++; + splitNode = splitNodes[splitNodeIndex]; + } + } + for (let i = splitNodes.length - 1; i >= 0; i--) { + if (splitNodes[i].children.length === 0) { + splitNodes.pop(); + } + } + } + if (shiftNode) { + splitNodes.push(shiftNode); + } + this.updateCounts(); + for (let i = 0; i < splitNodeCount; i++) { + splitNodes[i].updateCounts(); + } + return splitNodes; } } - function shouldIndentChildNode(settings, parent2, child, sourceFile, isNextChild = false) { - return nodeWillIndentChild( - settings, - parent2, - child, - sourceFile, - /*indentByDefault*/ - false - ) && !(isNextChild && child && isControlFlowEndingStatement(child.kind, parent2)); + // assume there is room for the item; return true if more room + add(collection) { + this.children.push(collection); + Debug.assert(this.children.length <= lineCollectionCapacity); } - SmartIndenter2.shouldIndentChildNode = shouldIndentChildNode; - function rangeIsOnOneLine(sourceFile, range) { - const rangeStart = skipTrivia(sourceFile.text, range.pos); - const startLine = sourceFile.getLineAndCharacterOfPosition(rangeStart).line; - const endLine = sourceFile.getLineAndCharacterOfPosition(range.end).line; - return startLine === endLine; + charCount() { + return this.totalChars; } - })(SmartIndenter || (SmartIndenter = {})); + lineCount() { + return this.totalLines; + } + }; + LineLeaf = class { + constructor(text) { + this.text = text; + } + isLeaf() { + return true; + } + walk(rangeStart, rangeLength, walkFns) { + walkFns.leaf(rangeStart, rangeLength, this); + } + charCount() { + return this.text.length; + } + lineCount() { + return 1; + } + }; } }); - // src/services/_namespaces/ts.formatting.ts - var ts_formatting_exports = {}; - __export(ts_formatting_exports, { - FormattingContext: () => FormattingContext, - FormattingRequestKind: () => FormattingRequestKind, - RuleAction: () => RuleAction, - RuleFlags: () => RuleFlags, - SmartIndenter: () => SmartIndenter, - anyContext: () => anyContext, - createTextRangeWithKind: () => createTextRangeWithKind, - formatDocument: () => formatDocument, - formatNodeGivenIndentation: () => formatNodeGivenIndentation, - formatOnClosingCurly: () => formatOnClosingCurly, - formatOnEnter: () => formatOnEnter, - formatOnOpeningCurly: () => formatOnOpeningCurly, - formatOnSemicolon: () => formatOnSemicolon, - formatSelection: () => formatSelection, - getAllRules: () => getAllRules, - getFormatContext: () => getFormatContext, - getFormattingScanner: () => getFormattingScanner, - getIndentationString: () => getIndentationString, - getRangeOfEnclosingComment: () => getRangeOfEnclosingComment + // src/server/_namespaces/ts.server.ts + var ts_server_exports3 = {}; + __export(ts_server_exports3, { + ActionInvalidate: () => ActionInvalidate, + ActionPackageInstalled: () => ActionPackageInstalled, + ActionSet: () => ActionSet, + ActionWatchTypingLocations: () => ActionWatchTypingLocations, + Arguments: () => Arguments, + AutoImportProviderProject: () => AutoImportProviderProject, + AuxiliaryProject: () => AuxiliaryProject, + CharRangeSection: () => CharRangeSection, + CloseFileWatcherEvent: () => CloseFileWatcherEvent, + CommandNames: () => CommandNames, + ConfigFileDiagEvent: () => ConfigFileDiagEvent, + ConfiguredProject: () => ConfiguredProject2, + CreateDirectoryWatcherEvent: () => CreateDirectoryWatcherEvent, + CreateFileWatcherEvent: () => CreateFileWatcherEvent, + Errors: () => Errors, + EventBeginInstallTypes: () => EventBeginInstallTypes, + EventEndInstallTypes: () => EventEndInstallTypes, + EventInitializationFailed: () => EventInitializationFailed, + EventTypesRegistry: () => EventTypesRegistry, + ExternalProject: () => ExternalProject2, + GcTimer: () => GcTimer, + InferredProject: () => InferredProject2, + LargeFileReferencedEvent: () => LargeFileReferencedEvent, + LineIndex: () => LineIndex, + LineLeaf: () => LineLeaf, + LineNode: () => LineNode, + LogLevel: () => LogLevel2, + Msg: () => Msg, + OpenFileInfoTelemetryEvent: () => OpenFileInfoTelemetryEvent, + Project: () => Project3, + ProjectInfoTelemetryEvent: () => ProjectInfoTelemetryEvent, + ProjectKind: () => ProjectKind, + ProjectLanguageServiceStateEvent: () => ProjectLanguageServiceStateEvent, + ProjectLoadingFinishEvent: () => ProjectLoadingFinishEvent, + ProjectLoadingStartEvent: () => ProjectLoadingStartEvent, + ProjectReferenceProjectLoadKind: () => ProjectReferenceProjectLoadKind, + ProjectService: () => ProjectService3, + ProjectsUpdatedInBackgroundEvent: () => ProjectsUpdatedInBackgroundEvent, + ScriptInfo: () => ScriptInfo, + ScriptVersionCache: () => ScriptVersionCache, + Session: () => Session3, + TextStorage: () => TextStorage, + ThrottledOperations: () => ThrottledOperations, + TypingsCache: () => TypingsCache, + allFilesAreJsOrDts: () => allFilesAreJsOrDts, + allRootFilesAreJsOrDts: () => allRootFilesAreJsOrDts, + asNormalizedPath: () => asNormalizedPath, + convertCompilerOptions: () => convertCompilerOptions, + convertFormatOptions: () => convertFormatOptions, + convertScriptKindName: () => convertScriptKindName, + convertTypeAcquisition: () => convertTypeAcquisition, + convertUserPreferences: () => convertUserPreferences, + convertWatchOptions: () => convertWatchOptions, + countEachFileTypes: () => countEachFileTypes, + createInstallTypingsRequest: () => createInstallTypingsRequest, + createModuleSpecifierCache: () => createModuleSpecifierCache, + createNormalizedPathMap: () => createNormalizedPathMap, + createPackageJsonCache: () => createPackageJsonCache, + createSortedArray: () => createSortedArray2, + emptyArray: () => emptyArray2, + findArgument: () => findArgument, + forEachResolvedProjectReferenceProject: () => forEachResolvedProjectReferenceProject, + formatDiagnosticToProtocol: () => formatDiagnosticToProtocol, + formatMessage: () => formatMessage2, + getBaseConfigFileName: () => getBaseConfigFileName, + getLocationInNewDocument: () => getLocationInNewDocument, + hasArgument: () => hasArgument, + hasNoTypeScriptSource: () => hasNoTypeScriptSource, + indent: () => indent2, + isBackgroundProject: () => isBackgroundProject, + isConfigFile: () => isConfigFile, + isConfiguredProject: () => isConfiguredProject, + isDynamicFileName: () => isDynamicFileName, + isExternalProject: () => isExternalProject, + isInferredProject: () => isInferredProject, + isInferredProjectName: () => isInferredProjectName, + makeAutoImportProviderProjectName: () => makeAutoImportProviderProjectName, + makeAuxiliaryProjectName: () => makeAuxiliaryProjectName, + makeInferredProjectName: () => makeInferredProjectName, + maxFileSize: () => maxFileSize, + maxProgramSizeForNonTsFiles: () => maxProgramSizeForNonTsFiles, + normalizedPathToPath: () => normalizedPathToPath, + nowString: () => nowString, + nullCancellationToken: () => nullCancellationToken, + nullTypingsInstaller: () => nullTypingsInstaller, + projectContainsInfoDirectly: () => projectContainsInfoDirectly, + protocol: () => ts_server_protocol_exports, + removeSorted: () => removeSorted, + stringifyIndented: () => stringifyIndented, + toEvent: () => toEvent, + toNormalizedPath: () => toNormalizedPath, + tryConvertScriptKindName: () => tryConvertScriptKindName, + typingsInstaller: () => ts_server_typingsInstaller_exports, + updateProjectIfDirty: () => updateProjectIfDirty }); - var init_ts_formatting = __esm({ - "src/services/_namespaces/ts.formatting.ts"() { + var init_ts_server3 = __esm({ + "src/server/_namespaces/ts.server.ts"() { "use strict"; - init_formattingContext(); - init_formattingScanner(); - init_rule(); - init_rules(); - init_rulesMap(); - init_formatting(); - init_smartIndenter(); + init_ts_server(); + init_ts_server2(); + init_types4(); + init_utilitiesPublic3(); + init_utilities5(); + init_ts_server_protocol(); + init_scriptInfo(); + init_typingsCache(); + init_project(); + init_editorServices(); + init_moduleSpecifierCache(); + init_packageJsonCache(); + init_session(); + init_scriptVersionCache(); } }); - - // src/services/_namespaces/ts.ts - var init_ts4 = __esm({ - "src/services/_namespaces/ts.ts"() { + + // src/server/_namespaces/ts.ts + var ts_exports2 = {}; + __export(ts_exports2, { + ANONYMOUS: () => ANONYMOUS, + AccessFlags: () => AccessFlags, + AssertionLevel: () => AssertionLevel, + AssignmentDeclarationKind: () => AssignmentDeclarationKind, + AssignmentKind: () => AssignmentKind, + Associativity: () => Associativity, + BreakpointResolver: () => ts_BreakpointResolver_exports, + BuilderFileEmit: () => BuilderFileEmit, + BuilderProgramKind: () => BuilderProgramKind, + BuilderState: () => BuilderState, + BundleFileSectionKind: () => BundleFileSectionKind, + CallHierarchy: () => ts_CallHierarchy_exports, + CharacterCodes: () => CharacterCodes, + CheckFlags: () => CheckFlags, + CheckMode: () => CheckMode, + ClassificationType: () => ClassificationType, + ClassificationTypeNames: () => ClassificationTypeNames, + CommentDirectiveType: () => CommentDirectiveType, + Comparison: () => Comparison, + CompletionInfoFlags: () => CompletionInfoFlags, + CompletionTriggerKind: () => CompletionTriggerKind, + Completions: () => ts_Completions_exports, + ContainerFlags: () => ContainerFlags, + ContextFlags: () => ContextFlags, + Debug: () => Debug, + DiagnosticCategory: () => DiagnosticCategory, + Diagnostics: () => Diagnostics, + DocumentHighlights: () => DocumentHighlights, + ElementFlags: () => ElementFlags, + EmitFlags: () => EmitFlags, + EmitHint: () => EmitHint, + EmitOnly: () => EmitOnly, + EndOfLineState: () => EndOfLineState, + EnumKind: () => EnumKind, + ExitStatus: () => ExitStatus, + ExportKind: () => ExportKind, + Extension: () => Extension, + ExternalEmitHelpers: () => ExternalEmitHelpers, + FileIncludeKind: () => FileIncludeKind, + FilePreprocessingDiagnosticsKind: () => FilePreprocessingDiagnosticsKind, + FileSystemEntryKind: () => FileSystemEntryKind, + FileWatcherEventKind: () => FileWatcherEventKind, + FindAllReferences: () => ts_FindAllReferences_exports, + FlattenLevel: () => FlattenLevel, + FlowFlags: () => FlowFlags, + ForegroundColorEscapeSequences: () => ForegroundColorEscapeSequences, + FunctionFlags: () => FunctionFlags, + GeneratedIdentifierFlags: () => GeneratedIdentifierFlags, + GetLiteralTextFlags: () => GetLiteralTextFlags, + GoToDefinition: () => ts_GoToDefinition_exports, + HighlightSpanKind: () => HighlightSpanKind, + IdentifierNameMap: () => IdentifierNameMap, + IdentifierNameMultiMap: () => IdentifierNameMultiMap, + ImportKind: () => ImportKind, + ImportsNotUsedAsValues: () => ImportsNotUsedAsValues, + IndentStyle: () => IndentStyle, + IndexFlags: () => IndexFlags, + IndexKind: () => IndexKind, + InferenceFlags: () => InferenceFlags, + InferencePriority: () => InferencePriority, + InlayHintKind: () => InlayHintKind, + InlayHints: () => ts_InlayHints_exports, + InternalEmitFlags: () => InternalEmitFlags, + InternalSymbolName: () => InternalSymbolName, + InvalidatedProjectKind: () => InvalidatedProjectKind, + JSDocParsingMode: () => JSDocParsingMode, + JsDoc: () => ts_JsDoc_exports, + JsTyping: () => ts_JsTyping_exports, + JsxEmit: () => JsxEmit, + JsxFlags: () => JsxFlags, + JsxReferenceKind: () => JsxReferenceKind, + LanguageServiceMode: () => LanguageServiceMode, + LanguageVariant: () => LanguageVariant, + LexicalEnvironmentFlags: () => LexicalEnvironmentFlags, + ListFormat: () => ListFormat, + LogLevel: () => LogLevel, + MemberOverrideStatus: () => MemberOverrideStatus, + ModifierFlags: () => ModifierFlags, + ModuleDetectionKind: () => ModuleDetectionKind, + ModuleInstanceState: () => ModuleInstanceState, + ModuleKind: () => ModuleKind, + ModuleResolutionKind: () => ModuleResolutionKind, + ModuleSpecifierEnding: () => ModuleSpecifierEnding, + NavigateTo: () => ts_NavigateTo_exports, + NavigationBar: () => ts_NavigationBar_exports, + NewLineKind: () => NewLineKind, + NodeBuilderFlags: () => NodeBuilderFlags, + NodeCheckFlags: () => NodeCheckFlags, + NodeFactoryFlags: () => NodeFactoryFlags, + NodeFlags: () => NodeFlags, + NodeResolutionFeatures: () => NodeResolutionFeatures, + ObjectFlags: () => ObjectFlags, + OperationCanceledException: () => OperationCanceledException, + OperatorPrecedence: () => OperatorPrecedence, + OrganizeImports: () => ts_OrganizeImports_exports, + OrganizeImportsMode: () => OrganizeImportsMode, + OuterExpressionKinds: () => OuterExpressionKinds, + OutliningElementsCollector: () => ts_OutliningElementsCollector_exports, + OutliningSpanKind: () => OutliningSpanKind, + OutputFileType: () => OutputFileType, + PackageJsonAutoImportPreference: () => PackageJsonAutoImportPreference, + PackageJsonDependencyGroup: () => PackageJsonDependencyGroup, + PatternMatchKind: () => PatternMatchKind, + PollingInterval: () => PollingInterval, + PollingWatchKind: () => PollingWatchKind, + PragmaKindFlags: () => PragmaKindFlags, + PrivateIdentifierKind: () => PrivateIdentifierKind, + ProcessLevel: () => ProcessLevel, + ProgramUpdateLevel: () => ProgramUpdateLevel, + QuotePreference: () => QuotePreference, + RelationComparisonResult: () => RelationComparisonResult, + Rename: () => ts_Rename_exports, + ScriptElementKind: () => ScriptElementKind, + ScriptElementKindModifier: () => ScriptElementKindModifier, + ScriptKind: () => ScriptKind, + ScriptSnapshot: () => ScriptSnapshot, + ScriptTarget: () => ScriptTarget, + SemanticClassificationFormat: () => SemanticClassificationFormat, + SemanticMeaning: () => SemanticMeaning, + SemicolonPreference: () => SemicolonPreference, + SignatureCheckMode: () => SignatureCheckMode, + SignatureFlags: () => SignatureFlags, + SignatureHelp: () => ts_SignatureHelp_exports, + SignatureKind: () => SignatureKind, + SmartSelectionRange: () => ts_SmartSelectionRange_exports, + SnippetKind: () => SnippetKind, + SortKind: () => SortKind, + StructureIsReused: () => StructureIsReused, + SymbolAccessibility: () => SymbolAccessibility, + SymbolDisplay: () => ts_SymbolDisplay_exports, + SymbolDisplayPartKind: () => SymbolDisplayPartKind, + SymbolFlags: () => SymbolFlags, + SymbolFormatFlags: () => SymbolFormatFlags, + SyntaxKind: () => SyntaxKind, + SyntheticSymbolKind: () => SyntheticSymbolKind, + Ternary: () => Ternary, + ThrottledCancellationToken: () => ThrottledCancellationToken, + TokenClass: () => TokenClass, + TokenFlags: () => TokenFlags, + TransformFlags: () => TransformFlags, + TypeFacts: () => TypeFacts, + TypeFlags: () => TypeFlags, + TypeFormatFlags: () => TypeFormatFlags, + TypeMapKind: () => TypeMapKind, + TypePredicateKind: () => TypePredicateKind, + TypeReferenceSerializationKind: () => TypeReferenceSerializationKind, + UnionReduction: () => UnionReduction, + UpToDateStatusType: () => UpToDateStatusType, + VarianceFlags: () => VarianceFlags, + Version: () => Version, + VersionRange: () => VersionRange, + WatchDirectoryFlags: () => WatchDirectoryFlags, + WatchDirectoryKind: () => WatchDirectoryKind, + WatchFileKind: () => WatchFileKind, + WatchLogLevel: () => WatchLogLevel, + WatchType: () => WatchType, + accessPrivateIdentifier: () => accessPrivateIdentifier, + addDisposableResourceHelper: () => addDisposableResourceHelper, + addEmitFlags: () => addEmitFlags, + addEmitHelper: () => addEmitHelper, + addEmitHelpers: () => addEmitHelpers, + addInternalEmitFlags: () => addInternalEmitFlags, + addNodeFactoryPatcher: () => addNodeFactoryPatcher, + addObjectAllocatorPatcher: () => addObjectAllocatorPatcher, + addRange: () => addRange, + addRelatedInfo: () => addRelatedInfo, + addSyntheticLeadingComment: () => addSyntheticLeadingComment, + addSyntheticTrailingComment: () => addSyntheticTrailingComment, + addToSeen: () => addToSeen, + advancedAsyncSuperHelper: () => advancedAsyncSuperHelper, + affectsDeclarationPathOptionDeclarations: () => affectsDeclarationPathOptionDeclarations, + affectsEmitOptionDeclarations: () => affectsEmitOptionDeclarations, + allKeysStartWithDot: () => allKeysStartWithDot, + altDirectorySeparator: () => altDirectorySeparator, + and: () => and, + append: () => append, + appendIfUnique: () => appendIfUnique, + arrayFrom: () => arrayFrom, + arrayIsEqualTo: () => arrayIsEqualTo, + arrayIsHomogeneous: () => arrayIsHomogeneous, + arrayIsSorted: () => arrayIsSorted, + arrayOf: () => arrayOf, + arrayReverseIterator: () => arrayReverseIterator, + arrayToMap: () => arrayToMap, + arrayToMultiMap: () => arrayToMultiMap, + arrayToNumericMap: () => arrayToNumericMap, + arraysEqual: () => arraysEqual, + assertType: () => assertType, + assign: () => assign, + assignHelper: () => assignHelper, + asyncDelegator: () => asyncDelegator, + asyncGeneratorHelper: () => asyncGeneratorHelper, + asyncSuperHelper: () => asyncSuperHelper, + asyncValues: () => asyncValues, + attachFileToDiagnostics: () => attachFileToDiagnostics, + awaitHelper: () => awaitHelper, + awaiterHelper: () => awaiterHelper, + base64decode: () => base64decode, + base64encode: () => base64encode, + binarySearch: () => binarySearch, + binarySearchKey: () => binarySearchKey, + bindSourceFile: () => bindSourceFile, + breakIntoCharacterSpans: () => breakIntoCharacterSpans, + breakIntoWordSpans: () => breakIntoWordSpans, + buildLinkParts: () => buildLinkParts, + buildOpts: () => buildOpts, + buildOverload: () => buildOverload, + bundlerModuleNameResolver: () => bundlerModuleNameResolver, + canBeConvertedToAsync: () => canBeConvertedToAsync, + canHaveDecorators: () => canHaveDecorators, + canHaveExportModifier: () => canHaveExportModifier, + canHaveFlowNode: () => canHaveFlowNode, + canHaveIllegalDecorators: () => canHaveIllegalDecorators, + canHaveIllegalModifiers: () => canHaveIllegalModifiers, + canHaveIllegalType: () => canHaveIllegalType, + canHaveIllegalTypeParameters: () => canHaveIllegalTypeParameters, + canHaveJSDoc: () => canHaveJSDoc, + canHaveLocals: () => canHaveLocals, + canHaveModifiers: () => canHaveModifiers, + canHaveSymbol: () => canHaveSymbol, + canJsonReportNoInputFiles: () => canJsonReportNoInputFiles, + canProduceDiagnostics: () => canProduceDiagnostics, + canUsePropertyAccess: () => canUsePropertyAccess, + canWatchAffectingLocation: () => canWatchAffectingLocation, + canWatchAtTypes: () => canWatchAtTypes, + canWatchDirectoryOrFile: () => canWatchDirectoryOrFile, + cartesianProduct: () => cartesianProduct, + cast: () => cast, + chainBundle: () => chainBundle, + chainDiagnosticMessages: () => chainDiagnosticMessages, + changeAnyExtension: () => changeAnyExtension, + changeCompilerHostLikeToUseCache: () => changeCompilerHostLikeToUseCache, + changeExtension: () => changeExtension, + changesAffectModuleResolution: () => changesAffectModuleResolution, + changesAffectingProgramStructure: () => changesAffectingProgramStructure, + childIsDecorated: () => childIsDecorated, + classElementOrClassElementParameterIsDecorated: () => classElementOrClassElementParameterIsDecorated, + classHasClassThisAssignment: () => classHasClassThisAssignment, + classHasDeclaredOrExplicitlyAssignedName: () => classHasDeclaredOrExplicitlyAssignedName, + classHasExplicitlyAssignedName: () => classHasExplicitlyAssignedName, + classOrConstructorParameterIsDecorated: () => classOrConstructorParameterIsDecorated, + classPrivateFieldGetHelper: () => classPrivateFieldGetHelper, + classPrivateFieldInHelper: () => classPrivateFieldInHelper, + classPrivateFieldSetHelper: () => classPrivateFieldSetHelper, + classicNameResolver: () => classicNameResolver, + classifier: () => ts_classifier_exports, + cleanExtendedConfigCache: () => cleanExtendedConfigCache, + clear: () => clear, + clearMap: () => clearMap, + clearSharedExtendedConfigFileWatcher: () => clearSharedExtendedConfigFileWatcher, + climbPastPropertyAccess: () => climbPastPropertyAccess, + climbPastPropertyOrElementAccess: () => climbPastPropertyOrElementAccess, + clone: () => clone, + cloneCompilerOptions: () => cloneCompilerOptions, + closeFileWatcher: () => closeFileWatcher, + closeFileWatcherOf: () => closeFileWatcherOf, + codefix: () => ts_codefix_exports, + collapseTextChangeRangesAcrossMultipleVersions: () => collapseTextChangeRangesAcrossMultipleVersions, + collectExternalModuleInfo: () => collectExternalModuleInfo, + combine: () => combine, + combinePaths: () => combinePaths, + commentPragmas: () => commentPragmas, + commonOptionsWithBuild: () => commonOptionsWithBuild, + commonPackageFolders: () => commonPackageFolders, + compact: () => compact, + compareBooleans: () => compareBooleans, + compareDataObjects: () => compareDataObjects, + compareDiagnostics: () => compareDiagnostics, + compareDiagnosticsSkipRelatedInformation: () => compareDiagnosticsSkipRelatedInformation, + compareEmitHelpers: () => compareEmitHelpers, + compareNumberOfDirectorySeparators: () => compareNumberOfDirectorySeparators, + comparePaths: () => comparePaths, + comparePathsCaseInsensitive: () => comparePathsCaseInsensitive, + comparePathsCaseSensitive: () => comparePathsCaseSensitive, + comparePatternKeys: () => comparePatternKeys, + compareProperties: () => compareProperties, + compareStringsCaseInsensitive: () => compareStringsCaseInsensitive, + compareStringsCaseInsensitiveEslintCompatible: () => compareStringsCaseInsensitiveEslintCompatible, + compareStringsCaseSensitive: () => compareStringsCaseSensitive, + compareStringsCaseSensitiveUI: () => compareStringsCaseSensitiveUI, + compareTextSpans: () => compareTextSpans, + compareValues: () => compareValues, + compileOnSaveCommandLineOption: () => compileOnSaveCommandLineOption, + compilerOptionsAffectDeclarationPath: () => compilerOptionsAffectDeclarationPath, + compilerOptionsAffectEmit: () => compilerOptionsAffectEmit, + compilerOptionsAffectSemanticDiagnostics: () => compilerOptionsAffectSemanticDiagnostics, + compilerOptionsDidYouMeanDiagnostics: () => compilerOptionsDidYouMeanDiagnostics, + compilerOptionsIndicateEsModules: () => compilerOptionsIndicateEsModules, + compose: () => compose, + computeCommonSourceDirectoryOfFilenames: () => computeCommonSourceDirectoryOfFilenames, + computeLineAndCharacterOfPosition: () => computeLineAndCharacterOfPosition, + computeLineOfPosition: () => computeLineOfPosition, + computeLineStarts: () => computeLineStarts, + computePositionOfLineAndCharacter: () => computePositionOfLineAndCharacter, + computeSignature: () => computeSignature, + computeSignatureWithDiagnostics: () => computeSignatureWithDiagnostics, + computeSuggestionDiagnostics: () => computeSuggestionDiagnostics, + concatenate: () => concatenate, + concatenateDiagnosticMessageChains: () => concatenateDiagnosticMessageChains, + consumesNodeCoreModules: () => consumesNodeCoreModules, + contains: () => contains, + containsIgnoredPath: () => containsIgnoredPath, + containsObjectRestOrSpread: () => containsObjectRestOrSpread, + containsParseError: () => containsParseError, + containsPath: () => containsPath, + convertCompilerOptionsForTelemetry: () => convertCompilerOptionsForTelemetry, + convertCompilerOptionsFromJson: () => convertCompilerOptionsFromJson, + convertJsonOption: () => convertJsonOption, + convertToBase64: () => convertToBase64, + convertToJson: () => convertToJson, + convertToObject: () => convertToObject, + convertToOptionsWithAbsolutePaths: () => convertToOptionsWithAbsolutePaths, + convertToRelativePath: () => convertToRelativePath, + convertToTSConfig: () => convertToTSConfig, + convertTypeAcquisitionFromJson: () => convertTypeAcquisitionFromJson, + copyComments: () => copyComments, + copyEntries: () => copyEntries, + copyLeadingComments: () => copyLeadingComments, + copyProperties: () => copyProperties, + copyTrailingAsLeadingComments: () => copyTrailingAsLeadingComments, + copyTrailingComments: () => copyTrailingComments, + couldStartTrivia: () => couldStartTrivia, + countWhere: () => countWhere, + createAbstractBuilder: () => createAbstractBuilder, + createAccessorPropertyBackingField: () => createAccessorPropertyBackingField, + createAccessorPropertyGetRedirector: () => createAccessorPropertyGetRedirector, + createAccessorPropertySetRedirector: () => createAccessorPropertySetRedirector, + createBaseNodeFactory: () => createBaseNodeFactory, + createBinaryExpressionTrampoline: () => createBinaryExpressionTrampoline, + createBindingHelper: () => createBindingHelper, + createBuildInfo: () => createBuildInfo, + createBuilderProgram: () => createBuilderProgram, + createBuilderProgramUsingProgramBuildInfo: () => createBuilderProgramUsingProgramBuildInfo, + createBuilderStatusReporter: () => createBuilderStatusReporter, + createCacheWithRedirects: () => createCacheWithRedirects, + createCacheableExportInfoMap: () => createCacheableExportInfoMap, + createCachedDirectoryStructureHost: () => createCachedDirectoryStructureHost, + createClassNamedEvaluationHelperBlock: () => createClassNamedEvaluationHelperBlock, + createClassThisAssignmentBlock: () => createClassThisAssignmentBlock, + createClassifier: () => createClassifier, + createCommentDirectivesMap: () => createCommentDirectivesMap, + createCompilerDiagnostic: () => createCompilerDiagnostic, + createCompilerDiagnosticForInvalidCustomType: () => createCompilerDiagnosticForInvalidCustomType, + createCompilerDiagnosticFromMessageChain: () => createCompilerDiagnosticFromMessageChain, + createCompilerHost: () => createCompilerHost, + createCompilerHostFromProgramHost: () => createCompilerHostFromProgramHost, + createCompilerHostWorker: () => createCompilerHostWorker, + createDetachedDiagnostic: () => createDetachedDiagnostic, + createDiagnosticCollection: () => createDiagnosticCollection, + createDiagnosticForFileFromMessageChain: () => createDiagnosticForFileFromMessageChain, + createDiagnosticForNode: () => createDiagnosticForNode, + createDiagnosticForNodeArray: () => createDiagnosticForNodeArray, + createDiagnosticForNodeArrayFromMessageChain: () => createDiagnosticForNodeArrayFromMessageChain, + createDiagnosticForNodeFromMessageChain: () => createDiagnosticForNodeFromMessageChain, + createDiagnosticForNodeInSourceFile: () => createDiagnosticForNodeInSourceFile, + createDiagnosticForRange: () => createDiagnosticForRange, + createDiagnosticMessageChainFromDiagnostic: () => createDiagnosticMessageChainFromDiagnostic, + createDiagnosticReporter: () => createDiagnosticReporter, + createDocumentPositionMapper: () => createDocumentPositionMapper, + createDocumentRegistry: () => createDocumentRegistry, + createDocumentRegistryInternal: () => createDocumentRegistryInternal, + createEmitAndSemanticDiagnosticsBuilderProgram: () => createEmitAndSemanticDiagnosticsBuilderProgram, + createEmitHelperFactory: () => createEmitHelperFactory, + createEmptyExports: () => createEmptyExports, + createExpressionForJsxElement: () => createExpressionForJsxElement, + createExpressionForJsxFragment: () => createExpressionForJsxFragment, + createExpressionForObjectLiteralElementLike: () => createExpressionForObjectLiteralElementLike, + createExpressionForPropertyName: () => createExpressionForPropertyName, + createExpressionFromEntityName: () => createExpressionFromEntityName, + createExternalHelpersImportDeclarationIfNeeded: () => createExternalHelpersImportDeclarationIfNeeded, + createFileDiagnostic: () => createFileDiagnostic, + createFileDiagnosticFromMessageChain: () => createFileDiagnosticFromMessageChain, + createForOfBindingStatement: () => createForOfBindingStatement, + createGetCanonicalFileName: () => createGetCanonicalFileName, + createGetSourceFile: () => createGetSourceFile, + createGetSymbolAccessibilityDiagnosticForNode: () => createGetSymbolAccessibilityDiagnosticForNode, + createGetSymbolAccessibilityDiagnosticForNodeName: () => createGetSymbolAccessibilityDiagnosticForNodeName, + createGetSymbolWalker: () => createGetSymbolWalker, + createIncrementalCompilerHost: () => createIncrementalCompilerHost, + createIncrementalProgram: () => createIncrementalProgram, + createInputFiles: () => createInputFiles, + createInputFilesWithFilePaths: () => createInputFilesWithFilePaths, + createInputFilesWithFileTexts: () => createInputFilesWithFileTexts, + createJsxFactoryExpression: () => createJsxFactoryExpression, + createLanguageService: () => createLanguageService, + createLanguageServiceSourceFile: () => createLanguageServiceSourceFile, + createMemberAccessForPropertyName: () => createMemberAccessForPropertyName, + createModeAwareCache: () => createModeAwareCache, + createModeAwareCacheKey: () => createModeAwareCacheKey, + createModuleNotFoundChain: () => createModuleNotFoundChain, + createModuleResolutionCache: () => createModuleResolutionCache, + createModuleResolutionLoader: () => createModuleResolutionLoader, + createModuleResolutionLoaderUsingGlobalCache: () => createModuleResolutionLoaderUsingGlobalCache, + createModuleSpecifierResolutionHost: () => createModuleSpecifierResolutionHost, + createMultiMap: () => createMultiMap, + createNodeConverters: () => createNodeConverters, + createNodeFactory: () => createNodeFactory, + createOptionNameMap: () => createOptionNameMap, + createOverload: () => createOverload, + createPackageJsonImportFilter: () => createPackageJsonImportFilter, + createPackageJsonInfo: () => createPackageJsonInfo, + createParenthesizerRules: () => createParenthesizerRules, + createPatternMatcher: () => createPatternMatcher, + createPrependNodes: () => createPrependNodes, + createPrinter: () => createPrinter, + createPrinterWithDefaults: () => createPrinterWithDefaults, + createPrinterWithRemoveComments: () => createPrinterWithRemoveComments, + createPrinterWithRemoveCommentsNeverAsciiEscape: () => createPrinterWithRemoveCommentsNeverAsciiEscape, + createPrinterWithRemoveCommentsOmitTrailingSemicolon: () => createPrinterWithRemoveCommentsOmitTrailingSemicolon, + createProgram: () => createProgram, + createProgramHost: () => createProgramHost, + createPropertyNameNodeForIdentifierOrLiteral: () => createPropertyNameNodeForIdentifierOrLiteral, + createQueue: () => createQueue, + createRange: () => createRange, + createRedirectedBuilderProgram: () => createRedirectedBuilderProgram, + createResolutionCache: () => createResolutionCache, + createRuntimeTypeSerializer: () => createRuntimeTypeSerializer, + createScanner: () => createScanner, + createSemanticDiagnosticsBuilderProgram: () => createSemanticDiagnosticsBuilderProgram, + createSet: () => createSet, + createSolutionBuilder: () => createSolutionBuilder, + createSolutionBuilderHost: () => createSolutionBuilderHost, + createSolutionBuilderWithWatch: () => createSolutionBuilderWithWatch, + createSolutionBuilderWithWatchHost: () => createSolutionBuilderWithWatchHost, + createSortedArray: () => createSortedArray, + createSourceFile: () => createSourceFile, + createSourceMapGenerator: () => createSourceMapGenerator, + createSourceMapSource: () => createSourceMapSource, + createSuperAccessVariableStatement: () => createSuperAccessVariableStatement, + createSymbolTable: () => createSymbolTable, + createSymlinkCache: () => createSymlinkCache, + createSystemWatchFunctions: () => createSystemWatchFunctions, + createTextChange: () => createTextChange, + createTextChangeFromStartLength: () => createTextChangeFromStartLength, + createTextChangeRange: () => createTextChangeRange, + createTextRangeFromNode: () => createTextRangeFromNode, + createTextRangeFromSpan: () => createTextRangeFromSpan, + createTextSpan: () => createTextSpan, + createTextSpanFromBounds: () => createTextSpanFromBounds, + createTextSpanFromNode: () => createTextSpanFromNode, + createTextSpanFromRange: () => createTextSpanFromRange, + createTextSpanFromStringLiteralLikeContent: () => createTextSpanFromStringLiteralLikeContent, + createTextWriter: () => createTextWriter, + createTokenRange: () => createTokenRange, + createTypeChecker: () => createTypeChecker, + createTypeReferenceDirectiveResolutionCache: () => createTypeReferenceDirectiveResolutionCache, + createTypeReferenceResolutionLoader: () => createTypeReferenceResolutionLoader, + createUnparsedSourceFile: () => createUnparsedSourceFile, + createWatchCompilerHost: () => createWatchCompilerHost2, + createWatchCompilerHostOfConfigFile: () => createWatchCompilerHostOfConfigFile, + createWatchCompilerHostOfFilesAndCompilerOptions: () => createWatchCompilerHostOfFilesAndCompilerOptions, + createWatchFactory: () => createWatchFactory, + createWatchHost: () => createWatchHost, + createWatchProgram: () => createWatchProgram, + createWatchStatusReporter: () => createWatchStatusReporter, + createWriteFileMeasuringIO: () => createWriteFileMeasuringIO, + declarationNameToString: () => declarationNameToString, + decodeMappings: () => decodeMappings, + decodedTextSpanIntersectsWith: () => decodedTextSpanIntersectsWith, + decorateHelper: () => decorateHelper, + deduplicate: () => deduplicate, + defaultIncludeSpec: () => defaultIncludeSpec, + defaultInitCompilerOptions: () => defaultInitCompilerOptions, + defaultMaximumTruncationLength: () => defaultMaximumTruncationLength, + detectSortCaseSensitivity: () => detectSortCaseSensitivity, + diagnosticCategoryName: () => diagnosticCategoryName, + diagnosticToString: () => diagnosticToString, + directoryProbablyExists: () => directoryProbablyExists, + directorySeparator: () => directorySeparator, + displayPart: () => displayPart, + displayPartsToString: () => displayPartsToString, + disposeEmitNodes: () => disposeEmitNodes, + disposeResourcesHelper: () => disposeResourcesHelper, + documentSpansEqual: () => documentSpansEqual, + dumpTracingLegend: () => dumpTracingLegend, + elementAt: () => elementAt, + elideNodes: () => elideNodes, + emitComments: () => emitComments, + emitDetachedComments: () => emitDetachedComments, + emitFiles: () => emitFiles, + emitFilesAndReportErrors: () => emitFilesAndReportErrors, + emitFilesAndReportErrorsAndGetExitStatus: () => emitFilesAndReportErrorsAndGetExitStatus, + emitModuleKindIsNonNodeESM: () => emitModuleKindIsNonNodeESM, + emitNewLineBeforeLeadingCommentOfPosition: () => emitNewLineBeforeLeadingCommentOfPosition, + emitNewLineBeforeLeadingComments: () => emitNewLineBeforeLeadingComments, + emitNewLineBeforeLeadingCommentsOfPosition: () => emitNewLineBeforeLeadingCommentsOfPosition, + emitSkippedWithNoDiagnostics: () => emitSkippedWithNoDiagnostics, + emitUsingBuildInfo: () => emitUsingBuildInfo, + emptyArray: () => emptyArray, + emptyFileSystemEntries: () => emptyFileSystemEntries, + emptyMap: () => emptyMap, + emptyOptions: () => emptyOptions, + emptySet: () => emptySet, + endsWith: () => endsWith, + ensurePathIsNonModuleName: () => ensurePathIsNonModuleName, + ensureScriptKind: () => ensureScriptKind, + ensureTrailingDirectorySeparator: () => ensureTrailingDirectorySeparator, + entityNameToString: () => entityNameToString, + enumerateInsertsAndDeletes: () => enumerateInsertsAndDeletes, + equalOwnProperties: () => equalOwnProperties, + equateStringsCaseInsensitive: () => equateStringsCaseInsensitive, + equateStringsCaseSensitive: () => equateStringsCaseSensitive, + equateValues: () => equateValues, + esDecorateHelper: () => esDecorateHelper, + escapeJsxAttributeString: () => escapeJsxAttributeString, + escapeLeadingUnderscores: () => escapeLeadingUnderscores, + escapeNonAsciiString: () => escapeNonAsciiString, + escapeSnippetText: () => escapeSnippetText, + escapeString: () => escapeString, + every: () => every, + expandPreOrPostfixIncrementOrDecrementExpression: () => expandPreOrPostfixIncrementOrDecrementExpression, + explainFiles: () => explainFiles, + explainIfFileIsRedirectAndImpliedFormat: () => explainIfFileIsRedirectAndImpliedFormat, + exportAssignmentIsAlias: () => exportAssignmentIsAlias, + exportStarHelper: () => exportStarHelper, + expressionResultIsUnused: () => expressionResultIsUnused, + extend: () => extend, + extendsHelper: () => extendsHelper, + extensionFromPath: () => extensionFromPath, + extensionIsTS: () => extensionIsTS, + extensionsNotSupportingExtensionlessResolution: () => extensionsNotSupportingExtensionlessResolution, + externalHelpersModuleNameText: () => externalHelpersModuleNameText, + factory: () => factory, + fileExtensionIs: () => fileExtensionIs, + fileExtensionIsOneOf: () => fileExtensionIsOneOf, + fileIncludeReasonToDiagnostics: () => fileIncludeReasonToDiagnostics, + fileShouldUseJavaScriptRequire: () => fileShouldUseJavaScriptRequire, + filter: () => filter, + filterMutate: () => filterMutate, + filterSemanticDiagnostics: () => filterSemanticDiagnostics, + find: () => find, + findAncestor: () => findAncestor, + findBestPatternMatch: () => findBestPatternMatch, + findChildOfKind: () => findChildOfKind, + findComputedPropertyNameCacheAssignment: () => findComputedPropertyNameCacheAssignment, + findConfigFile: () => findConfigFile, + findContainingList: () => findContainingList, + findDiagnosticForNode: () => findDiagnosticForNode, + findFirstNonJsxWhitespaceToken: () => findFirstNonJsxWhitespaceToken, + findIndex: () => findIndex, + findLast: () => findLast, + findLastIndex: () => findLastIndex, + findListItemInfo: () => findListItemInfo, + findMap: () => findMap, + findModifier: () => findModifier, + findNextToken: () => findNextToken, + findPackageJson: () => findPackageJson, + findPackageJsons: () => findPackageJsons, + findPrecedingMatchingToken: () => findPrecedingMatchingToken, + findPrecedingToken: () => findPrecedingToken, + findSuperStatementIndexPath: () => findSuperStatementIndexPath, + findTokenOnLeftOfPosition: () => findTokenOnLeftOfPosition, + findUseStrictPrologue: () => findUseStrictPrologue, + first: () => first, + firstDefined: () => firstDefined, + firstDefinedIterator: () => firstDefinedIterator, + firstIterator: () => firstIterator, + firstOrOnly: () => firstOrOnly, + firstOrUndefined: () => firstOrUndefined, + firstOrUndefinedIterator: () => firstOrUndefinedIterator, + fixupCompilerOptions: () => fixupCompilerOptions, + flatMap: () => flatMap, + flatMapIterator: () => flatMapIterator, + flatMapToMutable: () => flatMapToMutable, + flatten: () => flatten, + flattenCommaList: () => flattenCommaList, + flattenDestructuringAssignment: () => flattenDestructuringAssignment, + flattenDestructuringBinding: () => flattenDestructuringBinding, + flattenDiagnosticMessageText: () => flattenDiagnosticMessageText, + forEach: () => forEach, + forEachAncestor: () => forEachAncestor, + forEachAncestorDirectory: () => forEachAncestorDirectory, + forEachChild: () => forEachChild, + forEachChildRecursively: () => forEachChildRecursively, + forEachEmittedFile: () => forEachEmittedFile, + forEachEnclosingBlockScopeContainer: () => forEachEnclosingBlockScopeContainer, + forEachEntry: () => forEachEntry, + forEachExternalModuleToImportFrom: () => forEachExternalModuleToImportFrom, + forEachImportClauseDeclaration: () => forEachImportClauseDeclaration, + forEachKey: () => forEachKey, + forEachLeadingCommentRange: () => forEachLeadingCommentRange, + forEachNameInAccessChainWalkingLeft: () => forEachNameInAccessChainWalkingLeft, + forEachPropertyAssignment: () => forEachPropertyAssignment, + forEachResolvedProjectReference: () => forEachResolvedProjectReference, + forEachReturnStatement: () => forEachReturnStatement, + forEachRight: () => forEachRight, + forEachTrailingCommentRange: () => forEachTrailingCommentRange, + forEachTsConfigPropArray: () => forEachTsConfigPropArray, + forEachUnique: () => forEachUnique, + forEachYieldExpression: () => forEachYieldExpression, + forSomeAncestorDirectory: () => forSomeAncestorDirectory, + formatColorAndReset: () => formatColorAndReset, + formatDiagnostic: () => formatDiagnostic, + formatDiagnostics: () => formatDiagnostics, + formatDiagnosticsWithColorAndContext: () => formatDiagnosticsWithColorAndContext, + formatGeneratedName: () => formatGeneratedName, + formatGeneratedNamePart: () => formatGeneratedNamePart, + formatLocation: () => formatLocation, + formatMessage: () => formatMessage, + formatStringFromArgs: () => formatStringFromArgs, + formatting: () => ts_formatting_exports, + fullTripleSlashAMDReferencePathRegEx: () => fullTripleSlashAMDReferencePathRegEx, + fullTripleSlashReferencePathRegEx: () => fullTripleSlashReferencePathRegEx, + generateDjb2Hash: () => generateDjb2Hash, + generateTSConfig: () => generateTSConfig, + generatorHelper: () => generatorHelper, + getAdjustedReferenceLocation: () => getAdjustedReferenceLocation, + getAdjustedRenameLocation: () => getAdjustedRenameLocation, + getAliasDeclarationFromName: () => getAliasDeclarationFromName, + getAllAccessorDeclarations: () => getAllAccessorDeclarations, + getAllDecoratorsOfClass: () => getAllDecoratorsOfClass, + getAllDecoratorsOfClassElement: () => getAllDecoratorsOfClassElement, + getAllJSDocTags: () => getAllJSDocTags, + getAllJSDocTagsOfKind: () => getAllJSDocTagsOfKind, + getAllKeys: () => getAllKeys, + getAllProjectOutputs: () => getAllProjectOutputs, + getAllSuperTypeNodes: () => getAllSuperTypeNodes, + getAllUnscopedEmitHelpers: () => getAllUnscopedEmitHelpers, + getAllowJSCompilerOption: () => getAllowJSCompilerOption, + getAllowSyntheticDefaultImports: () => getAllowSyntheticDefaultImports, + getAncestor: () => getAncestor, + getAnyExtensionFromPath: () => getAnyExtensionFromPath, + getAreDeclarationMapsEnabled: () => getAreDeclarationMapsEnabled, + getAssignedExpandoInitializer: () => getAssignedExpandoInitializer, + getAssignedName: () => getAssignedName, + getAssignedNameOfIdentifier: () => getAssignedNameOfIdentifier, + getAssignmentDeclarationKind: () => getAssignmentDeclarationKind, + getAssignmentDeclarationPropertyAccessKind: () => getAssignmentDeclarationPropertyAccessKind, + getAssignmentTargetKind: () => getAssignmentTargetKind, + getAutomaticTypeDirectiveNames: () => getAutomaticTypeDirectiveNames, + getBaseFileName: () => getBaseFileName, + getBinaryOperatorPrecedence: () => getBinaryOperatorPrecedence, + getBuildInfo: () => getBuildInfo, + getBuildInfoFileVersionMap: () => getBuildInfoFileVersionMap, + getBuildInfoText: () => getBuildInfoText, + getBuildOrderFromAnyBuildOrder: () => getBuildOrderFromAnyBuildOrder, + getBuilderCreationParameters: () => getBuilderCreationParameters, + getBuilderFileEmit: () => getBuilderFileEmit, + getCheckFlags: () => getCheckFlags, + getClassExtendsHeritageElement: () => getClassExtendsHeritageElement, + getClassLikeDeclarationOfSymbol: () => getClassLikeDeclarationOfSymbol, + getCombinedLocalAndExportSymbolFlags: () => getCombinedLocalAndExportSymbolFlags, + getCombinedModifierFlags: () => getCombinedModifierFlags, + getCombinedNodeFlags: () => getCombinedNodeFlags, + getCombinedNodeFlagsAlwaysIncludeJSDoc: () => getCombinedNodeFlagsAlwaysIncludeJSDoc, + getCommentRange: () => getCommentRange, + getCommonSourceDirectory: () => getCommonSourceDirectory, + getCommonSourceDirectoryOfConfig: () => getCommonSourceDirectoryOfConfig, + getCompilerOptionValue: () => getCompilerOptionValue, + getCompilerOptionsDiffValue: () => getCompilerOptionsDiffValue, + getConditions: () => getConditions, + getConfigFileParsingDiagnostics: () => getConfigFileParsingDiagnostics, + getConstantValue: () => getConstantValue, + getContainerFlags: () => getContainerFlags, + getContainerNode: () => getContainerNode, + getContainingClass: () => getContainingClass, + getContainingClassExcludingClassDecorators: () => getContainingClassExcludingClassDecorators, + getContainingClassStaticBlock: () => getContainingClassStaticBlock, + getContainingFunction: () => getContainingFunction, + getContainingFunctionDeclaration: () => getContainingFunctionDeclaration, + getContainingFunctionOrClassStaticBlock: () => getContainingFunctionOrClassStaticBlock, + getContainingNodeArray: () => getContainingNodeArray, + getContainingObjectLiteralElement: () => getContainingObjectLiteralElement, + getContextualTypeFromParent: () => getContextualTypeFromParent, + getContextualTypeFromParentOrAncestorTypeNode: () => getContextualTypeFromParentOrAncestorTypeNode, + getCurrentTime: () => getCurrentTime, + getDeclarationDiagnostics: () => getDeclarationDiagnostics, + getDeclarationEmitExtensionForPath: () => getDeclarationEmitExtensionForPath, + getDeclarationEmitOutputFilePath: () => getDeclarationEmitOutputFilePath, + getDeclarationEmitOutputFilePathWorker: () => getDeclarationEmitOutputFilePathWorker, + getDeclarationFromName: () => getDeclarationFromName, + getDeclarationModifierFlagsFromSymbol: () => getDeclarationModifierFlagsFromSymbol, + getDeclarationOfKind: () => getDeclarationOfKind, + getDeclarationsOfKind: () => getDeclarationsOfKind, + getDeclaredExpandoInitializer: () => getDeclaredExpandoInitializer, + getDecorators: () => getDecorators, + getDefaultCompilerOptions: () => getDefaultCompilerOptions2, + getDefaultExportInfoWorker: () => getDefaultExportInfoWorker, + getDefaultFormatCodeSettings: () => getDefaultFormatCodeSettings, + getDefaultLibFileName: () => getDefaultLibFileName, + getDefaultLibFilePath: () => getDefaultLibFilePath, + getDefaultLikeExportInfo: () => getDefaultLikeExportInfo, + getDiagnosticText: () => getDiagnosticText, + getDiagnosticsWithinSpan: () => getDiagnosticsWithinSpan, + getDirectoryPath: () => getDirectoryPath, + getDirectoryToWatchFailedLookupLocation: () => getDirectoryToWatchFailedLookupLocation, + getDirectoryToWatchFailedLookupLocationFromTypeRoot: () => getDirectoryToWatchFailedLookupLocationFromTypeRoot, + getDocumentPositionMapper: () => getDocumentPositionMapper, + getESModuleInterop: () => getESModuleInterop, + getEditsForFileRename: () => getEditsForFileRename, + getEffectiveBaseTypeNode: () => getEffectiveBaseTypeNode, + getEffectiveConstraintOfTypeParameter: () => getEffectiveConstraintOfTypeParameter, + getEffectiveContainerForJSDocTemplateTag: () => getEffectiveContainerForJSDocTemplateTag, + getEffectiveImplementsTypeNodes: () => getEffectiveImplementsTypeNodes, + getEffectiveInitializer: () => getEffectiveInitializer, + getEffectiveJSDocHost: () => getEffectiveJSDocHost, + getEffectiveModifierFlags: () => getEffectiveModifierFlags, + getEffectiveModifierFlagsAlwaysIncludeJSDoc: () => getEffectiveModifierFlagsAlwaysIncludeJSDoc, + getEffectiveModifierFlagsNoCache: () => getEffectiveModifierFlagsNoCache, + getEffectiveReturnTypeNode: () => getEffectiveReturnTypeNode, + getEffectiveSetAccessorTypeAnnotationNode: () => getEffectiveSetAccessorTypeAnnotationNode, + getEffectiveTypeAnnotationNode: () => getEffectiveTypeAnnotationNode, + getEffectiveTypeParameterDeclarations: () => getEffectiveTypeParameterDeclarations, + getEffectiveTypeRoots: () => getEffectiveTypeRoots, + getElementOrPropertyAccessArgumentExpressionOrName: () => getElementOrPropertyAccessArgumentExpressionOrName, + getElementOrPropertyAccessName: () => getElementOrPropertyAccessName, + getElementsOfBindingOrAssignmentPattern: () => getElementsOfBindingOrAssignmentPattern, + getEmitDeclarations: () => getEmitDeclarations, + getEmitFlags: () => getEmitFlags, + getEmitHelpers: () => getEmitHelpers, + getEmitModuleDetectionKind: () => getEmitModuleDetectionKind, + getEmitModuleKind: () => getEmitModuleKind, + getEmitModuleResolutionKind: () => getEmitModuleResolutionKind, + getEmitScriptTarget: () => getEmitScriptTarget, + getEmitStandardClassFields: () => getEmitStandardClassFields, + getEnclosingBlockScopeContainer: () => getEnclosingBlockScopeContainer, + getEnclosingContainer: () => getEnclosingContainer, + getEncodedSemanticClassifications: () => getEncodedSemanticClassifications, + getEncodedSyntacticClassifications: () => getEncodedSyntacticClassifications, + getEndLinePosition: () => getEndLinePosition, + getEntityNameFromTypeNode: () => getEntityNameFromTypeNode, + getEntrypointsFromPackageJsonInfo: () => getEntrypointsFromPackageJsonInfo, + getErrorCountForSummary: () => getErrorCountForSummary, + getErrorSpanForNode: () => getErrorSpanForNode, + getErrorSummaryText: () => getErrorSummaryText, + getEscapedTextOfIdentifierOrLiteral: () => getEscapedTextOfIdentifierOrLiteral, + getEscapedTextOfJsxAttributeName: () => getEscapedTextOfJsxAttributeName, + getEscapedTextOfJsxNamespacedName: () => getEscapedTextOfJsxNamespacedName, + getExpandoInitializer: () => getExpandoInitializer, + getExportAssignmentExpression: () => getExportAssignmentExpression, + getExportInfoMap: () => getExportInfoMap, + getExportNeedsImportStarHelper: () => getExportNeedsImportStarHelper, + getExpressionAssociativity: () => getExpressionAssociativity, + getExpressionPrecedence: () => getExpressionPrecedence, + getExternalHelpersModuleName: () => getExternalHelpersModuleName, + getExternalModuleImportEqualsDeclarationExpression: () => getExternalModuleImportEqualsDeclarationExpression, + getExternalModuleName: () => getExternalModuleName, + getExternalModuleNameFromDeclaration: () => getExternalModuleNameFromDeclaration, + getExternalModuleNameFromPath: () => getExternalModuleNameFromPath, + getExternalModuleNameLiteral: () => getExternalModuleNameLiteral, + getExternalModuleRequireArgument: () => getExternalModuleRequireArgument, + getFallbackOptions: () => getFallbackOptions, + getFileEmitOutput: () => getFileEmitOutput, + getFileMatcherPatterns: () => getFileMatcherPatterns, + getFileNamesFromConfigSpecs: () => getFileNamesFromConfigSpecs, + getFileWatcherEventKind: () => getFileWatcherEventKind, + getFilesInErrorForSummary: () => getFilesInErrorForSummary, + getFirstConstructorWithBody: () => getFirstConstructorWithBody, + getFirstIdentifier: () => getFirstIdentifier, + getFirstNonSpaceCharacterPosition: () => getFirstNonSpaceCharacterPosition, + getFirstProjectOutput: () => getFirstProjectOutput, + getFixableErrorSpanExpression: () => getFixableErrorSpanExpression, + getFormatCodeSettingsForWriting: () => getFormatCodeSettingsForWriting, + getFullWidth: () => getFullWidth, + getFunctionFlags: () => getFunctionFlags, + getHeritageClause: () => getHeritageClause, + getHostSignatureFromJSDoc: () => getHostSignatureFromJSDoc, + getIdentifierAutoGenerate: () => getIdentifierAutoGenerate, + getIdentifierGeneratedImportReference: () => getIdentifierGeneratedImportReference, + getIdentifierTypeArguments: () => getIdentifierTypeArguments, + getImmediatelyInvokedFunctionExpression: () => getImmediatelyInvokedFunctionExpression, + getImpliedNodeFormatForFile: () => getImpliedNodeFormatForFile, + getImpliedNodeFormatForFileWorker: () => getImpliedNodeFormatForFileWorker, + getImportNeedsImportDefaultHelper: () => getImportNeedsImportDefaultHelper, + getImportNeedsImportStarHelper: () => getImportNeedsImportStarHelper, + getIndentSize: () => getIndentSize, + getIndentString: () => getIndentString, + getInferredLibraryNameResolveFrom: () => getInferredLibraryNameResolveFrom, + getInitializedVariables: () => getInitializedVariables, + getInitializerOfBinaryExpression: () => getInitializerOfBinaryExpression, + getInitializerOfBindingOrAssignmentElement: () => getInitializerOfBindingOrAssignmentElement, + getInterfaceBaseTypeNodes: () => getInterfaceBaseTypeNodes, + getInternalEmitFlags: () => getInternalEmitFlags, + getInvokedExpression: () => getInvokedExpression, + getIsolatedModules: () => getIsolatedModules, + getJSDocAugmentsTag: () => getJSDocAugmentsTag, + getJSDocClassTag: () => getJSDocClassTag, + getJSDocCommentRanges: () => getJSDocCommentRanges, + getJSDocCommentsAndTags: () => getJSDocCommentsAndTags, + getJSDocDeprecatedTag: () => getJSDocDeprecatedTag, + getJSDocDeprecatedTagNoCache: () => getJSDocDeprecatedTagNoCache, + getJSDocEnumTag: () => getJSDocEnumTag, + getJSDocHost: () => getJSDocHost, + getJSDocImplementsTags: () => getJSDocImplementsTags, + getJSDocOverrideTagNoCache: () => getJSDocOverrideTagNoCache, + getJSDocParameterTags: () => getJSDocParameterTags, + getJSDocParameterTagsNoCache: () => getJSDocParameterTagsNoCache, + getJSDocPrivateTag: () => getJSDocPrivateTag, + getJSDocPrivateTagNoCache: () => getJSDocPrivateTagNoCache, + getJSDocProtectedTag: () => getJSDocProtectedTag, + getJSDocProtectedTagNoCache: () => getJSDocProtectedTagNoCache, + getJSDocPublicTag: () => getJSDocPublicTag, + getJSDocPublicTagNoCache: () => getJSDocPublicTagNoCache, + getJSDocReadonlyTag: () => getJSDocReadonlyTag, + getJSDocReadonlyTagNoCache: () => getJSDocReadonlyTagNoCache, + getJSDocReturnTag: () => getJSDocReturnTag, + getJSDocReturnType: () => getJSDocReturnType, + getJSDocRoot: () => getJSDocRoot, + getJSDocSatisfiesExpressionType: () => getJSDocSatisfiesExpressionType, + getJSDocSatisfiesTag: () => getJSDocSatisfiesTag, + getJSDocTags: () => getJSDocTags, + getJSDocTagsNoCache: () => getJSDocTagsNoCache, + getJSDocTemplateTag: () => getJSDocTemplateTag, + getJSDocThisTag: () => getJSDocThisTag, + getJSDocType: () => getJSDocType, + getJSDocTypeAliasName: () => getJSDocTypeAliasName, + getJSDocTypeAssertionType: () => getJSDocTypeAssertionType, + getJSDocTypeParameterDeclarations: () => getJSDocTypeParameterDeclarations, + getJSDocTypeParameterTags: () => getJSDocTypeParameterTags, + getJSDocTypeParameterTagsNoCache: () => getJSDocTypeParameterTagsNoCache, + getJSDocTypeTag: () => getJSDocTypeTag, + getJSXImplicitImportBase: () => getJSXImplicitImportBase, + getJSXRuntimeImport: () => getJSXRuntimeImport, + getJSXTransformEnabled: () => getJSXTransformEnabled, + getKeyForCompilerOptions: () => getKeyForCompilerOptions, + getLanguageVariant: () => getLanguageVariant, + getLastChild: () => getLastChild, + getLeadingCommentRanges: () => getLeadingCommentRanges, + getLeadingCommentRangesOfNode: () => getLeadingCommentRangesOfNode, + getLeftmostAccessExpression: () => getLeftmostAccessExpression, + getLeftmostExpression: () => getLeftmostExpression, + getLibraryNameFromLibFileName: () => getLibraryNameFromLibFileName, + getLineAndCharacterOfPosition: () => getLineAndCharacterOfPosition, + getLineInfo: () => getLineInfo, + getLineOfLocalPosition: () => getLineOfLocalPosition, + getLineOfLocalPositionFromLineMap: () => getLineOfLocalPositionFromLineMap, + getLineStartPositionForPosition: () => getLineStartPositionForPosition, + getLineStarts: () => getLineStarts, + getLinesBetweenPositionAndNextNonWhitespaceCharacter: () => getLinesBetweenPositionAndNextNonWhitespaceCharacter, + getLinesBetweenPositionAndPrecedingNonWhitespaceCharacter: () => getLinesBetweenPositionAndPrecedingNonWhitespaceCharacter, + getLinesBetweenPositions: () => getLinesBetweenPositions, + getLinesBetweenRangeEndAndRangeStart: () => getLinesBetweenRangeEndAndRangeStart, + getLinesBetweenRangeEndPositions: () => getLinesBetweenRangeEndPositions, + getLiteralText: () => getLiteralText, + getLocalNameForExternalImport: () => getLocalNameForExternalImport, + getLocalSymbolForExportDefault: () => getLocalSymbolForExportDefault, + getLocaleSpecificMessage: () => getLocaleSpecificMessage, + getLocaleTimeString: () => getLocaleTimeString, + getMappedContextSpan: () => getMappedContextSpan, + getMappedDocumentSpan: () => getMappedDocumentSpan, + getMappedLocation: () => getMappedLocation, + getMatchedFileSpec: () => getMatchedFileSpec, + getMatchedIncludeSpec: () => getMatchedIncludeSpec, + getMeaningFromDeclaration: () => getMeaningFromDeclaration, + getMeaningFromLocation: () => getMeaningFromLocation, + getMembersOfDeclaration: () => getMembersOfDeclaration, + getModeForFileReference: () => getModeForFileReference, + getModeForResolutionAtIndex: () => getModeForResolutionAtIndex, + getModeForUsageLocation: () => getModeForUsageLocation, + getModifiedTime: () => getModifiedTime, + getModifiers: () => getModifiers, + getModuleInstanceState: () => getModuleInstanceState, + getModuleNameStringLiteralAt: () => getModuleNameStringLiteralAt, + getModuleSpecifierEndingPreference: () => getModuleSpecifierEndingPreference, + getModuleSpecifierResolverHost: () => getModuleSpecifierResolverHost, + getNameForExportedSymbol: () => getNameForExportedSymbol, + getNameFromIndexInfo: () => getNameFromIndexInfo, + getNameFromPropertyName: () => getNameFromPropertyName, + getNameOfAccessExpression: () => getNameOfAccessExpression, + getNameOfCompilerOptionValue: () => getNameOfCompilerOptionValue, + getNameOfDeclaration: () => getNameOfDeclaration, + getNameOfExpando: () => getNameOfExpando, + getNameOfJSDocTypedef: () => getNameOfJSDocTypedef, + getNameOrArgument: () => getNameOrArgument, + getNameTable: () => getNameTable, + getNamesForExportedSymbol: () => getNamesForExportedSymbol, + getNamespaceDeclarationNode: () => getNamespaceDeclarationNode, + getNewLineCharacter: () => getNewLineCharacter, + getNewLineKind: () => getNewLineKind, + getNewLineOrDefaultFromHost: () => getNewLineOrDefaultFromHost, + getNewTargetContainer: () => getNewTargetContainer, + getNextJSDocCommentLocation: () => getNextJSDocCommentLocation, + getNodeForGeneratedName: () => getNodeForGeneratedName, + getNodeId: () => getNodeId, + getNodeKind: () => getNodeKind, + getNodeModifiers: () => getNodeModifiers, + getNodeModulePathParts: () => getNodeModulePathParts, + getNonAssignedNameOfDeclaration: () => getNonAssignedNameOfDeclaration, + getNonAssignmentOperatorForCompoundAssignment: () => getNonAssignmentOperatorForCompoundAssignment, + getNonAugmentationDeclaration: () => getNonAugmentationDeclaration, + getNonDecoratorTokenPosOfNode: () => getNonDecoratorTokenPosOfNode, + getNormalizedAbsolutePath: () => getNormalizedAbsolutePath, + getNormalizedAbsolutePathWithoutRoot: () => getNormalizedAbsolutePathWithoutRoot, + getNormalizedPathComponents: () => getNormalizedPathComponents, + getObjectFlags: () => getObjectFlags, + getOperator: () => getOperator, + getOperatorAssociativity: () => getOperatorAssociativity, + getOperatorPrecedence: () => getOperatorPrecedence, + getOptionFromName: () => getOptionFromName, + getOptionsForLibraryResolution: () => getOptionsForLibraryResolution, + getOptionsNameMap: () => getOptionsNameMap, + getOrCreateEmitNode: () => getOrCreateEmitNode, + getOrCreateExternalHelpersModuleNameIfNeeded: () => getOrCreateExternalHelpersModuleNameIfNeeded, + getOrUpdate: () => getOrUpdate, + getOriginalNode: () => getOriginalNode, + getOriginalNodeId: () => getOriginalNodeId, + getOriginalSourceFile: () => getOriginalSourceFile, + getOutputDeclarationFileName: () => getOutputDeclarationFileName, + getOutputExtension: () => getOutputExtension, + getOutputFileNames: () => getOutputFileNames, + getOutputPathsFor: () => getOutputPathsFor, + getOutputPathsForBundle: () => getOutputPathsForBundle, + getOwnEmitOutputFilePath: () => getOwnEmitOutputFilePath, + getOwnKeys: () => getOwnKeys, + getOwnValues: () => getOwnValues, + getPackageJsonInfo: () => getPackageJsonInfo, + getPackageJsonTypesVersionsPaths: () => getPackageJsonTypesVersionsPaths, + getPackageJsonsVisibleToFile: () => getPackageJsonsVisibleToFile, + getPackageNameFromTypesPackageName: () => getPackageNameFromTypesPackageName, + getPackageScopeForPath: () => getPackageScopeForPath, + getParameterSymbolFromJSDoc: () => getParameterSymbolFromJSDoc, + getParameterTypeNode: () => getParameterTypeNode, + getParentNodeInSpan: () => getParentNodeInSpan, + getParseTreeNode: () => getParseTreeNode, + getParsedCommandLineOfConfigFile: () => getParsedCommandLineOfConfigFile, + getPathComponents: () => getPathComponents, + getPathComponentsRelativeTo: () => getPathComponentsRelativeTo, + getPathFromPathComponents: () => getPathFromPathComponents, + getPathUpdater: () => getPathUpdater, + getPathsBasePath: () => getPathsBasePath, + getPatternFromSpec: () => getPatternFromSpec, + getPendingEmitKind: () => getPendingEmitKind, + getPositionOfLineAndCharacter: () => getPositionOfLineAndCharacter, + getPossibleGenericSignatures: () => getPossibleGenericSignatures, + getPossibleOriginalInputExtensionForExtension: () => getPossibleOriginalInputExtensionForExtension, + getPossibleTypeArgumentsInfo: () => getPossibleTypeArgumentsInfo, + getPreEmitDiagnostics: () => getPreEmitDiagnostics, + getPrecedingNonSpaceCharacterPosition: () => getPrecedingNonSpaceCharacterPosition, + getPrivateIdentifier: () => getPrivateIdentifier, + getProperties: () => getProperties, + getProperty: () => getProperty, + getPropertyArrayElementValue: () => getPropertyArrayElementValue, + getPropertyAssignmentAliasLikeExpression: () => getPropertyAssignmentAliasLikeExpression, + getPropertyNameForPropertyNameNode: () => getPropertyNameForPropertyNameNode, + getPropertyNameForUniqueESSymbol: () => getPropertyNameForUniqueESSymbol, + getPropertyNameFromType: () => getPropertyNameFromType, + getPropertyNameOfBindingOrAssignmentElement: () => getPropertyNameOfBindingOrAssignmentElement, + getPropertySymbolFromBindingElement: () => getPropertySymbolFromBindingElement, + getPropertySymbolsFromContextualType: () => getPropertySymbolsFromContextualType, + getQuoteFromPreference: () => getQuoteFromPreference, + getQuotePreference: () => getQuotePreference, + getRangesWhere: () => getRangesWhere, + getRefactorContextSpan: () => getRefactorContextSpan, + getReferencedFileLocation: () => getReferencedFileLocation, + getRegexFromPattern: () => getRegexFromPattern, + getRegularExpressionForWildcard: () => getRegularExpressionForWildcard, + getRegularExpressionsForWildcards: () => getRegularExpressionsForWildcards, + getRelativePathFromDirectory: () => getRelativePathFromDirectory, + getRelativePathFromFile: () => getRelativePathFromFile, + getRelativePathToDirectoryOrUrl: () => getRelativePathToDirectoryOrUrl, + getRenameLocation: () => getRenameLocation, + getReplacementSpanForContextToken: () => getReplacementSpanForContextToken, + getResolutionDiagnostic: () => getResolutionDiagnostic, + getResolutionModeOverride: () => getResolutionModeOverride, + getResolveJsonModule: () => getResolveJsonModule, + getResolvePackageJsonExports: () => getResolvePackageJsonExports, + getResolvePackageJsonImports: () => getResolvePackageJsonImports, + getResolvedExternalModuleName: () => getResolvedExternalModuleName, + getRestIndicatorOfBindingOrAssignmentElement: () => getRestIndicatorOfBindingOrAssignmentElement, + getRestParameterElementType: () => getRestParameterElementType, + getRightMostAssignedExpression: () => getRightMostAssignedExpression, + getRootDeclaration: () => getRootDeclaration, + getRootDirectoryOfResolutionCache: () => getRootDirectoryOfResolutionCache, + getRootLength: () => getRootLength, + getRootPathSplitLength: () => getRootPathSplitLength, + getScriptKind: () => getScriptKind, + getScriptKindFromFileName: () => getScriptKindFromFileName, + getScriptTargetFeatures: () => getScriptTargetFeatures, + getSelectedEffectiveModifierFlags: () => getSelectedEffectiveModifierFlags, + getSelectedSyntacticModifierFlags: () => getSelectedSyntacticModifierFlags, + getSemanticClassifications: () => getSemanticClassifications, + getSemanticJsxChildren: () => getSemanticJsxChildren, + getSetAccessorTypeAnnotationNode: () => getSetAccessorTypeAnnotationNode, + getSetAccessorValueParameter: () => getSetAccessorValueParameter, + getSetExternalModuleIndicator: () => getSetExternalModuleIndicator, + getShebang: () => getShebang, + getSingleInitializerOfVariableStatementOrPropertyDeclaration: () => getSingleInitializerOfVariableStatementOrPropertyDeclaration, + getSingleVariableOfVariableStatement: () => getSingleVariableOfVariableStatement, + getSnapshotText: () => getSnapshotText, + getSnippetElement: () => getSnippetElement, + getSourceFileOfModule: () => getSourceFileOfModule, + getSourceFileOfNode: () => getSourceFileOfNode, + getSourceFilePathInNewDir: () => getSourceFilePathInNewDir, + getSourceFilePathInNewDirWorker: () => getSourceFilePathInNewDirWorker, + getSourceFileVersionAsHashFromText: () => getSourceFileVersionAsHashFromText, + getSourceFilesToEmit: () => getSourceFilesToEmit, + getSourceMapRange: () => getSourceMapRange, + getSourceMapper: () => getSourceMapper, + getSourceTextOfNodeFromSourceFile: () => getSourceTextOfNodeFromSourceFile, + getSpanOfTokenAtPosition: () => getSpanOfTokenAtPosition, + getSpellingSuggestion: () => getSpellingSuggestion, + getStartPositionOfLine: () => getStartPositionOfLine, + getStartPositionOfRange: () => getStartPositionOfRange, + getStartsOnNewLine: () => getStartsOnNewLine, + getStaticPropertiesAndClassStaticBlock: () => getStaticPropertiesAndClassStaticBlock, + getStrictOptionValue: () => getStrictOptionValue, + getStringComparer: () => getStringComparer, + getSuperCallFromStatement: () => getSuperCallFromStatement, + getSuperContainer: () => getSuperContainer, + getSupportedCodeFixes: () => getSupportedCodeFixes, + getSupportedExtensions: () => getSupportedExtensions, + getSupportedExtensionsWithJsonIfResolveJsonModule: () => getSupportedExtensionsWithJsonIfResolveJsonModule, + getSwitchedType: () => getSwitchedType, + getSymbolId: () => getSymbolId, + getSymbolNameForPrivateIdentifier: () => getSymbolNameForPrivateIdentifier, + getSymbolTarget: () => getSymbolTarget, + getSyntacticClassifications: () => getSyntacticClassifications, + getSyntacticModifierFlags: () => getSyntacticModifierFlags, + getSyntacticModifierFlagsNoCache: () => getSyntacticModifierFlagsNoCache, + getSynthesizedDeepClone: () => getSynthesizedDeepClone, + getSynthesizedDeepCloneWithReplacements: () => getSynthesizedDeepCloneWithReplacements, + getSynthesizedDeepClones: () => getSynthesizedDeepClones, + getSynthesizedDeepClonesWithReplacements: () => getSynthesizedDeepClonesWithReplacements, + getSyntheticLeadingComments: () => getSyntheticLeadingComments, + getSyntheticTrailingComments: () => getSyntheticTrailingComments, + getTargetLabel: () => getTargetLabel, + getTargetOfBindingOrAssignmentElement: () => getTargetOfBindingOrAssignmentElement, + getTemporaryModuleResolutionState: () => getTemporaryModuleResolutionState, + getTextOfConstantValue: () => getTextOfConstantValue, + getTextOfIdentifierOrLiteral: () => getTextOfIdentifierOrLiteral, + getTextOfJSDocComment: () => getTextOfJSDocComment, + getTextOfJsxAttributeName: () => getTextOfJsxAttributeName, + getTextOfJsxNamespacedName: () => getTextOfJsxNamespacedName, + getTextOfNode: () => getTextOfNode, + getTextOfNodeFromSourceText: () => getTextOfNodeFromSourceText, + getTextOfPropertyName: () => getTextOfPropertyName, + getThisContainer: () => getThisContainer, + getThisParameter: () => getThisParameter, + getTokenAtPosition: () => getTokenAtPosition, + getTokenPosOfNode: () => getTokenPosOfNode, + getTokenSourceMapRange: () => getTokenSourceMapRange, + getTouchingPropertyName: () => getTouchingPropertyName, + getTouchingToken: () => getTouchingToken, + getTrailingCommentRanges: () => getTrailingCommentRanges, + getTrailingSemicolonDeferringWriter: () => getTrailingSemicolonDeferringWriter, + getTransformFlagsSubtreeExclusions: () => getTransformFlagsSubtreeExclusions, + getTransformers: () => getTransformers, + getTsBuildInfoEmitOutputFilePath: () => getTsBuildInfoEmitOutputFilePath, + getTsConfigObjectLiteralExpression: () => getTsConfigObjectLiteralExpression, + getTsConfigPropArrayElementValue: () => getTsConfigPropArrayElementValue, + getTypeAnnotationNode: () => getTypeAnnotationNode, + getTypeArgumentOrTypeParameterList: () => getTypeArgumentOrTypeParameterList, + getTypeKeywordOfTypeOnlyImport: () => getTypeKeywordOfTypeOnlyImport, + getTypeNode: () => getTypeNode, + getTypeNodeIfAccessible: () => getTypeNodeIfAccessible, + getTypeParameterFromJsDoc: () => getTypeParameterFromJsDoc, + getTypeParameterOwner: () => getTypeParameterOwner, + getTypesPackageName: () => getTypesPackageName, + getUILocale: () => getUILocale, + getUniqueName: () => getUniqueName, + getUniqueSymbolId: () => getUniqueSymbolId, + getUseDefineForClassFields: () => getUseDefineForClassFields, + getWatchErrorSummaryDiagnosticMessage: () => getWatchErrorSummaryDiagnosticMessage, + getWatchFactory: () => getWatchFactory, + group: () => group, + groupBy: () => groupBy, + guessIndentation: () => guessIndentation, + handleNoEmitOptions: () => handleNoEmitOptions, + hasAbstractModifier: () => hasAbstractModifier, + hasAccessorModifier: () => hasAccessorModifier, + hasAmbientModifier: () => hasAmbientModifier, + hasChangesInResolutions: () => hasChangesInResolutions, + hasChildOfKind: () => hasChildOfKind, + hasContextSensitiveParameters: () => hasContextSensitiveParameters, + hasDecorators: () => hasDecorators, + hasDocComment: () => hasDocComment, + hasDynamicName: () => hasDynamicName, + hasEffectiveModifier: () => hasEffectiveModifier, + hasEffectiveModifiers: () => hasEffectiveModifiers, + hasEffectiveReadonlyModifier: () => hasEffectiveReadonlyModifier, + hasExtension: () => hasExtension, + hasIndexSignature: () => hasIndexSignature, + hasInitializer: () => hasInitializer, + hasInvalidEscape: () => hasInvalidEscape, + hasJSDocNodes: () => hasJSDocNodes, + hasJSDocParameterTags: () => hasJSDocParameterTags, + hasJSFileExtension: () => hasJSFileExtension, + hasJsonModuleEmitEnabled: () => hasJsonModuleEmitEnabled, + hasOnlyExpressionInitializer: () => hasOnlyExpressionInitializer, + hasOverrideModifier: () => hasOverrideModifier, + hasPossibleExternalModuleReference: () => hasPossibleExternalModuleReference, + hasProperty: () => hasProperty, + hasPropertyAccessExpressionWithName: () => hasPropertyAccessExpressionWithName, + hasQuestionToken: () => hasQuestionToken, + hasRecordedExternalHelpers: () => hasRecordedExternalHelpers, + hasResolutionModeOverride: () => hasResolutionModeOverride, + hasRestParameter: () => hasRestParameter, + hasScopeMarker: () => hasScopeMarker, + hasStaticModifier: () => hasStaticModifier, + hasSyntacticModifier: () => hasSyntacticModifier, + hasSyntacticModifiers: () => hasSyntacticModifiers, + hasTSFileExtension: () => hasTSFileExtension, + hasTabstop: () => hasTabstop, + hasTrailingDirectorySeparator: () => hasTrailingDirectorySeparator, + hasType: () => hasType, + hasTypeArguments: () => hasTypeArguments, + hasZeroOrOneAsteriskCharacter: () => hasZeroOrOneAsteriskCharacter, + helperString: () => helperString, + hostGetCanonicalFileName: () => hostGetCanonicalFileName, + hostUsesCaseSensitiveFileNames: () => hostUsesCaseSensitiveFileNames, + idText: () => idText, + identifierIsThisKeyword: () => identifierIsThisKeyword, + identifierToKeywordKind: () => identifierToKeywordKind, + identity: () => identity, + identitySourceMapConsumer: () => identitySourceMapConsumer, + ignoreSourceNewlines: () => ignoreSourceNewlines, + ignoredPaths: () => ignoredPaths, + importDefaultHelper: () => importDefaultHelper, + importFromModuleSpecifier: () => importFromModuleSpecifier, + importNameElisionDisabled: () => importNameElisionDisabled, + importStarHelper: () => importStarHelper, + indexOfAnyCharCode: () => indexOfAnyCharCode, + indexOfNode: () => indexOfNode, + indicesOf: () => indicesOf, + inferredTypesContainingFile: () => inferredTypesContainingFile, + injectClassNamedEvaluationHelperBlockIfMissing: () => injectClassNamedEvaluationHelperBlockIfMissing, + injectClassThisAssignmentIfMissing: () => injectClassThisAssignmentIfMissing, + insertImports: () => insertImports, + insertLeadingStatement: () => insertLeadingStatement, + insertSorted: () => insertSorted, + insertStatementAfterCustomPrologue: () => insertStatementAfterCustomPrologue, + insertStatementAfterStandardPrologue: () => insertStatementAfterStandardPrologue, + insertStatementsAfterCustomPrologue: () => insertStatementsAfterCustomPrologue, + insertStatementsAfterStandardPrologue: () => insertStatementsAfterStandardPrologue, + intersperse: () => intersperse, + intrinsicTagNameToString: () => intrinsicTagNameToString, + introducesArgumentsExoticObject: () => introducesArgumentsExoticObject, + inverseJsxOptionMap: () => inverseJsxOptionMap, + isAbstractConstructorSymbol: () => isAbstractConstructorSymbol, + isAbstractModifier: () => isAbstractModifier, + isAccessExpression: () => isAccessExpression, + isAccessibilityModifier: () => isAccessibilityModifier, + isAccessor: () => isAccessor, + isAccessorModifier: () => isAccessorModifier, + isAliasSymbolDeclaration: () => isAliasSymbolDeclaration, + isAliasableExpression: () => isAliasableExpression, + isAmbientModule: () => isAmbientModule, + isAmbientPropertyDeclaration: () => isAmbientPropertyDeclaration, + isAnonymousFunctionDefinition: () => isAnonymousFunctionDefinition, + isAnyDirectorySeparator: () => isAnyDirectorySeparator, + isAnyImportOrBareOrAccessedRequire: () => isAnyImportOrBareOrAccessedRequire, + isAnyImportOrReExport: () => isAnyImportOrReExport, + isAnyImportSyntax: () => isAnyImportSyntax, + isAnySupportedFileExtension: () => isAnySupportedFileExtension, + isApplicableVersionedTypesKey: () => isApplicableVersionedTypesKey, + isArgumentExpressionOfElementAccess: () => isArgumentExpressionOfElementAccess, + isArray: () => isArray, + isArrayBindingElement: () => isArrayBindingElement, + isArrayBindingOrAssignmentElement: () => isArrayBindingOrAssignmentElement, + isArrayBindingOrAssignmentPattern: () => isArrayBindingOrAssignmentPattern, + isArrayBindingPattern: () => isArrayBindingPattern, + isArrayLiteralExpression: () => isArrayLiteralExpression, + isArrayLiteralOrObjectLiteralDestructuringPattern: () => isArrayLiteralOrObjectLiteralDestructuringPattern, + isArrayTypeNode: () => isArrayTypeNode, + isArrowFunction: () => isArrowFunction, + isAsExpression: () => isAsExpression, + isAssertClause: () => isAssertClause, + isAssertEntry: () => isAssertEntry, + isAssertionExpression: () => isAssertionExpression, + isAssertsKeyword: () => isAssertsKeyword, + isAssignmentDeclaration: () => isAssignmentDeclaration, + isAssignmentExpression: () => isAssignmentExpression, + isAssignmentOperator: () => isAssignmentOperator, + isAssignmentPattern: () => isAssignmentPattern, + isAssignmentTarget: () => isAssignmentTarget, + isAsteriskToken: () => isAsteriskToken, + isAsyncFunction: () => isAsyncFunction, + isAsyncModifier: () => isAsyncModifier, + isAutoAccessorPropertyDeclaration: () => isAutoAccessorPropertyDeclaration, + isAwaitExpression: () => isAwaitExpression, + isAwaitKeyword: () => isAwaitKeyword, + isBigIntLiteral: () => isBigIntLiteral, + isBinaryExpression: () => isBinaryExpression, + isBinaryOperatorToken: () => isBinaryOperatorToken, + isBindableObjectDefinePropertyCall: () => isBindableObjectDefinePropertyCall, + isBindableStaticAccessExpression: () => isBindableStaticAccessExpression, + isBindableStaticElementAccessExpression: () => isBindableStaticElementAccessExpression, + isBindableStaticNameExpression: () => isBindableStaticNameExpression, + isBindingElement: () => isBindingElement, + isBindingElementOfBareOrAccessedRequire: () => isBindingElementOfBareOrAccessedRequire, + isBindingName: () => isBindingName, + isBindingOrAssignmentElement: () => isBindingOrAssignmentElement, + isBindingOrAssignmentPattern: () => isBindingOrAssignmentPattern, + isBindingPattern: () => isBindingPattern, + isBlock: () => isBlock, + isBlockOrCatchScoped: () => isBlockOrCatchScoped, + isBlockScope: () => isBlockScope, + isBlockScopedContainerTopLevel: () => isBlockScopedContainerTopLevel, + isBooleanLiteral: () => isBooleanLiteral, + isBreakOrContinueStatement: () => isBreakOrContinueStatement, + isBreakStatement: () => isBreakStatement, + isBuildInfoFile: () => isBuildInfoFile, + isBuilderProgram: () => isBuilderProgram2, + isBundle: () => isBundle, + isBundleFileTextLike: () => isBundleFileTextLike, + isCallChain: () => isCallChain, + isCallExpression: () => isCallExpression, + isCallExpressionTarget: () => isCallExpressionTarget, + isCallLikeExpression: () => isCallLikeExpression, + isCallLikeOrFunctionLikeExpression: () => isCallLikeOrFunctionLikeExpression, + isCallOrNewExpression: () => isCallOrNewExpression, + isCallOrNewExpressionTarget: () => isCallOrNewExpressionTarget, + isCallSignatureDeclaration: () => isCallSignatureDeclaration, + isCallToHelper: () => isCallToHelper, + isCaseBlock: () => isCaseBlock, + isCaseClause: () => isCaseClause, + isCaseKeyword: () => isCaseKeyword, + isCaseOrDefaultClause: () => isCaseOrDefaultClause, + isCatchClause: () => isCatchClause, + isCatchClauseVariableDeclaration: () => isCatchClauseVariableDeclaration, + isCatchClauseVariableDeclarationOrBindingElement: () => isCatchClauseVariableDeclarationOrBindingElement, + isCheckJsEnabledForFile: () => isCheckJsEnabledForFile, + isChildOfNodeWithKind: () => isChildOfNodeWithKind, + isCircularBuildOrder: () => isCircularBuildOrder, + isClassDeclaration: () => isClassDeclaration, + isClassElement: () => isClassElement, + isClassExpression: () => isClassExpression, + isClassInstanceProperty: () => isClassInstanceProperty, + isClassLike: () => isClassLike, + isClassMemberModifier: () => isClassMemberModifier, + isClassNamedEvaluationHelperBlock: () => isClassNamedEvaluationHelperBlock, + isClassOrTypeElement: () => isClassOrTypeElement, + isClassStaticBlockDeclaration: () => isClassStaticBlockDeclaration, + isClassThisAssignmentBlock: () => isClassThisAssignmentBlock, + isCollapsedRange: () => isCollapsedRange, + isColonToken: () => isColonToken, + isCommaExpression: () => isCommaExpression, + isCommaListExpression: () => isCommaListExpression, + isCommaSequence: () => isCommaSequence, + isCommaToken: () => isCommaToken, + isComment: () => isComment, + isCommonJsExportPropertyAssignment: () => isCommonJsExportPropertyAssignment, + isCommonJsExportedExpression: () => isCommonJsExportedExpression, + isCompoundAssignment: () => isCompoundAssignment, + isComputedNonLiteralName: () => isComputedNonLiteralName, + isComputedPropertyName: () => isComputedPropertyName, + isConciseBody: () => isConciseBody, + isConditionalExpression: () => isConditionalExpression, + isConditionalTypeNode: () => isConditionalTypeNode, + isConstTypeReference: () => isConstTypeReference, + isConstructSignatureDeclaration: () => isConstructSignatureDeclaration, + isConstructorDeclaration: () => isConstructorDeclaration, + isConstructorTypeNode: () => isConstructorTypeNode, + isContextualKeyword: () => isContextualKeyword, + isContinueStatement: () => isContinueStatement, + isCustomPrologue: () => isCustomPrologue, + isDebuggerStatement: () => isDebuggerStatement, + isDeclaration: () => isDeclaration, + isDeclarationBindingElement: () => isDeclarationBindingElement, + isDeclarationFileName: () => isDeclarationFileName, + isDeclarationName: () => isDeclarationName, + isDeclarationNameOfEnumOrNamespace: () => isDeclarationNameOfEnumOrNamespace, + isDeclarationReadonly: () => isDeclarationReadonly, + isDeclarationStatement: () => isDeclarationStatement, + isDeclarationWithTypeParameterChildren: () => isDeclarationWithTypeParameterChildren, + isDeclarationWithTypeParameters: () => isDeclarationWithTypeParameters, + isDecorator: () => isDecorator, + isDecoratorTarget: () => isDecoratorTarget, + isDefaultClause: () => isDefaultClause, + isDefaultImport: () => isDefaultImport, + isDefaultModifier: () => isDefaultModifier, + isDefaultedExpandoInitializer: () => isDefaultedExpandoInitializer, + isDeleteExpression: () => isDeleteExpression, + isDeleteTarget: () => isDeleteTarget, + isDeprecatedDeclaration: () => isDeprecatedDeclaration, + isDestructuringAssignment: () => isDestructuringAssignment, + isDiagnosticWithLocation: () => isDiagnosticWithLocation, + isDiskPathRoot: () => isDiskPathRoot, + isDoStatement: () => isDoStatement, + isDocumentRegistryEntry: () => isDocumentRegistryEntry, + isDotDotDotToken: () => isDotDotDotToken, + isDottedName: () => isDottedName, + isDynamicName: () => isDynamicName, + isESSymbolIdentifier: () => isESSymbolIdentifier, + isEffectiveExternalModule: () => isEffectiveExternalModule, + isEffectiveModuleDeclaration: () => isEffectiveModuleDeclaration, + isEffectiveStrictModeSourceFile: () => isEffectiveStrictModeSourceFile, + isElementAccessChain: () => isElementAccessChain, + isElementAccessExpression: () => isElementAccessExpression, + isEmittedFileOfProgram: () => isEmittedFileOfProgram, + isEmptyArrayLiteral: () => isEmptyArrayLiteral, + isEmptyBindingElement: () => isEmptyBindingElement, + isEmptyBindingPattern: () => isEmptyBindingPattern, + isEmptyObjectLiteral: () => isEmptyObjectLiteral, + isEmptyStatement: () => isEmptyStatement, + isEmptyStringLiteral: () => isEmptyStringLiteral, + isEntityName: () => isEntityName, + isEntityNameExpression: () => isEntityNameExpression, + isEnumConst: () => isEnumConst, + isEnumDeclaration: () => isEnumDeclaration, + isEnumMember: () => isEnumMember, + isEqualityOperatorKind: () => isEqualityOperatorKind, + isEqualsGreaterThanToken: () => isEqualsGreaterThanToken, + isExclamationToken: () => isExclamationToken, + isExcludedFile: () => isExcludedFile, + isExclusivelyTypeOnlyImportOrExport: () => isExclusivelyTypeOnlyImportOrExport, + isExpandoPropertyDeclaration: () => isExpandoPropertyDeclaration, + isExportAssignment: () => isExportAssignment, + isExportDeclaration: () => isExportDeclaration, + isExportModifier: () => isExportModifier, + isExportName: () => isExportName, + isExportNamespaceAsDefaultDeclaration: () => isExportNamespaceAsDefaultDeclaration, + isExportOrDefaultModifier: () => isExportOrDefaultModifier, + isExportSpecifier: () => isExportSpecifier, + isExportsIdentifier: () => isExportsIdentifier, + isExportsOrModuleExportsOrAlias: () => isExportsOrModuleExportsOrAlias, + isExpression: () => isExpression, + isExpressionNode: () => isExpressionNode, + isExpressionOfExternalModuleImportEqualsDeclaration: () => isExpressionOfExternalModuleImportEqualsDeclaration, + isExpressionOfOptionalChainRoot: () => isExpressionOfOptionalChainRoot, + isExpressionStatement: () => isExpressionStatement, + isExpressionWithTypeArguments: () => isExpressionWithTypeArguments, + isExpressionWithTypeArgumentsInClassExtendsClause: () => isExpressionWithTypeArgumentsInClassExtendsClause, + isExternalModule: () => isExternalModule, + isExternalModuleAugmentation: () => isExternalModuleAugmentation, + isExternalModuleImportEqualsDeclaration: () => isExternalModuleImportEqualsDeclaration, + isExternalModuleIndicator: () => isExternalModuleIndicator, + isExternalModuleNameRelative: () => isExternalModuleNameRelative, + isExternalModuleReference: () => isExternalModuleReference, + isExternalModuleSymbol: () => isExternalModuleSymbol, + isExternalOrCommonJsModule: () => isExternalOrCommonJsModule, + isFileLevelReservedGeneratedIdentifier: () => isFileLevelReservedGeneratedIdentifier, + isFileLevelUniqueName: () => isFileLevelUniqueName, + isFileProbablyExternalModule: () => isFileProbablyExternalModule, + isFirstDeclarationOfSymbolParameter: () => isFirstDeclarationOfSymbolParameter, + isFixablePromiseHandler: () => isFixablePromiseHandler, + isForInOrOfStatement: () => isForInOrOfStatement, + isForInStatement: () => isForInStatement, + isForInitializer: () => isForInitializer, + isForOfStatement: () => isForOfStatement, + isForStatement: () => isForStatement, + isFunctionBlock: () => isFunctionBlock, + isFunctionBody: () => isFunctionBody, + isFunctionDeclaration: () => isFunctionDeclaration, + isFunctionExpression: () => isFunctionExpression, + isFunctionExpressionOrArrowFunction: () => isFunctionExpressionOrArrowFunction, + isFunctionLike: () => isFunctionLike, + isFunctionLikeDeclaration: () => isFunctionLikeDeclaration, + isFunctionLikeKind: () => isFunctionLikeKind, + isFunctionLikeOrClassStaticBlockDeclaration: () => isFunctionLikeOrClassStaticBlockDeclaration, + isFunctionOrConstructorTypeNode: () => isFunctionOrConstructorTypeNode, + isFunctionOrModuleBlock: () => isFunctionOrModuleBlock, + isFunctionSymbol: () => isFunctionSymbol, + isFunctionTypeNode: () => isFunctionTypeNode, + isFutureReservedKeyword: () => isFutureReservedKeyword, + isGeneratedIdentifier: () => isGeneratedIdentifier, + isGeneratedPrivateIdentifier: () => isGeneratedPrivateIdentifier, + isGetAccessor: () => isGetAccessor, + isGetAccessorDeclaration: () => isGetAccessorDeclaration, + isGetOrSetAccessorDeclaration: () => isGetOrSetAccessorDeclaration, + isGlobalDeclaration: () => isGlobalDeclaration, + isGlobalScopeAugmentation: () => isGlobalScopeAugmentation, + isGrammarError: () => isGrammarError, + isHeritageClause: () => isHeritageClause, + isHoistedFunction: () => isHoistedFunction, + isHoistedVariableStatement: () => isHoistedVariableStatement, + isIdentifier: () => isIdentifier, + isIdentifierANonContextualKeyword: () => isIdentifierANonContextualKeyword, + isIdentifierName: () => isIdentifierName, + isIdentifierOrThisTypeNode: () => isIdentifierOrThisTypeNode, + isIdentifierPart: () => isIdentifierPart, + isIdentifierStart: () => isIdentifierStart, + isIdentifierText: () => isIdentifierText, + isIdentifierTypePredicate: () => isIdentifierTypePredicate, + isIdentifierTypeReference: () => isIdentifierTypeReference, + isIfStatement: () => isIfStatement, + isIgnoredFileFromWildCardWatching: () => isIgnoredFileFromWildCardWatching, + isImplicitGlob: () => isImplicitGlob, + isImportAttribute: () => isImportAttribute, + isImportAttributeName: () => isImportAttributeName, + isImportAttributes: () => isImportAttributes, + isImportCall: () => isImportCall, + isImportClause: () => isImportClause, + isImportDeclaration: () => isImportDeclaration, + isImportEqualsDeclaration: () => isImportEqualsDeclaration, + isImportKeyword: () => isImportKeyword, + isImportMeta: () => isImportMeta, + isImportOrExportSpecifier: () => isImportOrExportSpecifier, + isImportOrExportSpecifierName: () => isImportOrExportSpecifierName, + isImportSpecifier: () => isImportSpecifier, + isImportTypeAssertionContainer: () => isImportTypeAssertionContainer, + isImportTypeNode: () => isImportTypeNode, + isImportableFile: () => isImportableFile, + isInComment: () => isInComment, + isInCompoundLikeAssignment: () => isInCompoundLikeAssignment, + isInExpressionContext: () => isInExpressionContext, + isInJSDoc: () => isInJSDoc, + isInJSFile: () => isInJSFile, + isInJSXText: () => isInJSXText, + isInJsonFile: () => isInJsonFile, + isInNonReferenceComment: () => isInNonReferenceComment, + isInReferenceComment: () => isInReferenceComment, + isInRightSideOfInternalImportEqualsDeclaration: () => isInRightSideOfInternalImportEqualsDeclaration, + isInString: () => isInString, + isInTemplateString: () => isInTemplateString, + isInTopLevelContext: () => isInTopLevelContext, + isInTypeQuery: () => isInTypeQuery, + isIncrementalCompilation: () => isIncrementalCompilation, + isIndexSignatureDeclaration: () => isIndexSignatureDeclaration, + isIndexedAccessTypeNode: () => isIndexedAccessTypeNode, + isInferTypeNode: () => isInferTypeNode, + isInfinityOrNaNString: () => isInfinityOrNaNString, + isInitializedProperty: () => isInitializedProperty, + isInitializedVariable: () => isInitializedVariable, + isInsideJsxElement: () => isInsideJsxElement, + isInsideJsxElementOrAttribute: () => isInsideJsxElementOrAttribute, + isInsideNodeModules: () => isInsideNodeModules, + isInsideTemplateLiteral: () => isInsideTemplateLiteral, + isInstanceOfExpression: () => isInstanceOfExpression, + isInstantiatedModule: () => isInstantiatedModule, + isInterfaceDeclaration: () => isInterfaceDeclaration, + isInternalDeclaration: () => isInternalDeclaration, + isInternalModuleImportEqualsDeclaration: () => isInternalModuleImportEqualsDeclaration, + isInternalName: () => isInternalName, + isIntersectionTypeNode: () => isIntersectionTypeNode, + isIntrinsicJsxName: () => isIntrinsicJsxName, + isIterationStatement: () => isIterationStatement, + isJSDoc: () => isJSDoc, + isJSDocAllType: () => isJSDocAllType, + isJSDocAugmentsTag: () => isJSDocAugmentsTag, + isJSDocAuthorTag: () => isJSDocAuthorTag, + isJSDocCallbackTag: () => isJSDocCallbackTag, + isJSDocClassTag: () => isJSDocClassTag, + isJSDocCommentContainingNode: () => isJSDocCommentContainingNode, + isJSDocConstructSignature: () => isJSDocConstructSignature, + isJSDocDeprecatedTag: () => isJSDocDeprecatedTag, + isJSDocEnumTag: () => isJSDocEnumTag, + isJSDocFunctionType: () => isJSDocFunctionType, + isJSDocImplementsTag: () => isJSDocImplementsTag, + isJSDocIndexSignature: () => isJSDocIndexSignature, + isJSDocLikeText: () => isJSDocLikeText, + isJSDocLink: () => isJSDocLink, + isJSDocLinkCode: () => isJSDocLinkCode, + isJSDocLinkLike: () => isJSDocLinkLike, + isJSDocLinkPlain: () => isJSDocLinkPlain, + isJSDocMemberName: () => isJSDocMemberName, + isJSDocNameReference: () => isJSDocNameReference, + isJSDocNamepathType: () => isJSDocNamepathType, + isJSDocNamespaceBody: () => isJSDocNamespaceBody, + isJSDocNode: () => isJSDocNode, + isJSDocNonNullableType: () => isJSDocNonNullableType, + isJSDocNullableType: () => isJSDocNullableType, + isJSDocOptionalParameter: () => isJSDocOptionalParameter, + isJSDocOptionalType: () => isJSDocOptionalType, + isJSDocOverloadTag: () => isJSDocOverloadTag, + isJSDocOverrideTag: () => isJSDocOverrideTag, + isJSDocParameterTag: () => isJSDocParameterTag, + isJSDocPrivateTag: () => isJSDocPrivateTag, + isJSDocPropertyLikeTag: () => isJSDocPropertyLikeTag, + isJSDocPropertyTag: () => isJSDocPropertyTag, + isJSDocProtectedTag: () => isJSDocProtectedTag, + isJSDocPublicTag: () => isJSDocPublicTag, + isJSDocReadonlyTag: () => isJSDocReadonlyTag, + isJSDocReturnTag: () => isJSDocReturnTag, + isJSDocSatisfiesExpression: () => isJSDocSatisfiesExpression, + isJSDocSatisfiesTag: () => isJSDocSatisfiesTag, + isJSDocSeeTag: () => isJSDocSeeTag, + isJSDocSignature: () => isJSDocSignature, + isJSDocTag: () => isJSDocTag, + isJSDocTemplateTag: () => isJSDocTemplateTag, + isJSDocThisTag: () => isJSDocThisTag, + isJSDocThrowsTag: () => isJSDocThrowsTag, + isJSDocTypeAlias: () => isJSDocTypeAlias, + isJSDocTypeAssertion: () => isJSDocTypeAssertion, + isJSDocTypeExpression: () => isJSDocTypeExpression, + isJSDocTypeLiteral: () => isJSDocTypeLiteral, + isJSDocTypeTag: () => isJSDocTypeTag, + isJSDocTypedefTag: () => isJSDocTypedefTag, + isJSDocUnknownTag: () => isJSDocUnknownTag, + isJSDocUnknownType: () => isJSDocUnknownType, + isJSDocVariadicType: () => isJSDocVariadicType, + isJSXTagName: () => isJSXTagName, + isJsonEqual: () => isJsonEqual, + isJsonSourceFile: () => isJsonSourceFile, + isJsxAttribute: () => isJsxAttribute, + isJsxAttributeLike: () => isJsxAttributeLike, + isJsxAttributeName: () => isJsxAttributeName, + isJsxAttributes: () => isJsxAttributes, + isJsxChild: () => isJsxChild, + isJsxClosingElement: () => isJsxClosingElement, + isJsxClosingFragment: () => isJsxClosingFragment, + isJsxElement: () => isJsxElement, + isJsxExpression: () => isJsxExpression, + isJsxFragment: () => isJsxFragment, + isJsxNamespacedName: () => isJsxNamespacedName, + isJsxOpeningElement: () => isJsxOpeningElement, + isJsxOpeningFragment: () => isJsxOpeningFragment, + isJsxOpeningLikeElement: () => isJsxOpeningLikeElement, + isJsxOpeningLikeElementTagName: () => isJsxOpeningLikeElementTagName, + isJsxSelfClosingElement: () => isJsxSelfClosingElement, + isJsxSpreadAttribute: () => isJsxSpreadAttribute, + isJsxTagNameExpression: () => isJsxTagNameExpression, + isJsxText: () => isJsxText, + isJumpStatementTarget: () => isJumpStatementTarget, + isKeyword: () => isKeyword, + isKeywordOrPunctuation: () => isKeywordOrPunctuation, + isKnownSymbol: () => isKnownSymbol, + isLabelName: () => isLabelName, + isLabelOfLabeledStatement: () => isLabelOfLabeledStatement, + isLabeledStatement: () => isLabeledStatement, + isLateVisibilityPaintedStatement: () => isLateVisibilityPaintedStatement, + isLeftHandSideExpression: () => isLeftHandSideExpression, + isLeftHandSideOfAssignment: () => isLeftHandSideOfAssignment, + isLet: () => isLet, + isLineBreak: () => isLineBreak, + isLiteralComputedPropertyDeclarationName: () => isLiteralComputedPropertyDeclarationName, + isLiteralExpression: () => isLiteralExpression, + isLiteralExpressionOfObject: () => isLiteralExpressionOfObject, + isLiteralImportTypeNode: () => isLiteralImportTypeNode, + isLiteralKind: () => isLiteralKind, + isLiteralLikeAccess: () => isLiteralLikeAccess, + isLiteralLikeElementAccess: () => isLiteralLikeElementAccess, + isLiteralNameOfPropertyDeclarationOrIndexAccess: () => isLiteralNameOfPropertyDeclarationOrIndexAccess, + isLiteralTypeLikeExpression: () => isLiteralTypeLikeExpression, + isLiteralTypeLiteral: () => isLiteralTypeLiteral, + isLiteralTypeNode: () => isLiteralTypeNode, + isLocalName: () => isLocalName, + isLogicalOperator: () => isLogicalOperator, + isLogicalOrCoalescingAssignmentExpression: () => isLogicalOrCoalescingAssignmentExpression, + isLogicalOrCoalescingAssignmentOperator: () => isLogicalOrCoalescingAssignmentOperator, + isLogicalOrCoalescingBinaryExpression: () => isLogicalOrCoalescingBinaryExpression, + isLogicalOrCoalescingBinaryOperator: () => isLogicalOrCoalescingBinaryOperator, + isMappedTypeNode: () => isMappedTypeNode, + isMemberName: () => isMemberName, + isMetaProperty: () => isMetaProperty, + isMethodDeclaration: () => isMethodDeclaration, + isMethodOrAccessor: () => isMethodOrAccessor, + isMethodSignature: () => isMethodSignature, + isMinusToken: () => isMinusToken, + isMissingDeclaration: () => isMissingDeclaration, + isModifier: () => isModifier, + isModifierKind: () => isModifierKind, + isModifierLike: () => isModifierLike, + isModuleAugmentationExternal: () => isModuleAugmentationExternal, + isModuleBlock: () => isModuleBlock, + isModuleBody: () => isModuleBody, + isModuleDeclaration: () => isModuleDeclaration, + isModuleExportsAccessExpression: () => isModuleExportsAccessExpression, + isModuleIdentifier: () => isModuleIdentifier, + isModuleName: () => isModuleName, + isModuleOrEnumDeclaration: () => isModuleOrEnumDeclaration, + isModuleReference: () => isModuleReference, + isModuleSpecifierLike: () => isModuleSpecifierLike, + isModuleWithStringLiteralName: () => isModuleWithStringLiteralName, + isNameOfFunctionDeclaration: () => isNameOfFunctionDeclaration, + isNameOfModuleDeclaration: () => isNameOfModuleDeclaration, + isNamedClassElement: () => isNamedClassElement, + isNamedDeclaration: () => isNamedDeclaration, + isNamedEvaluation: () => isNamedEvaluation, + isNamedEvaluationSource: () => isNamedEvaluationSource, + isNamedExportBindings: () => isNamedExportBindings, + isNamedExports: () => isNamedExports, + isNamedImportBindings: () => isNamedImportBindings, + isNamedImports: () => isNamedImports, + isNamedImportsOrExports: () => isNamedImportsOrExports, + isNamedTupleMember: () => isNamedTupleMember, + isNamespaceBody: () => isNamespaceBody, + isNamespaceExport: () => isNamespaceExport, + isNamespaceExportDeclaration: () => isNamespaceExportDeclaration, + isNamespaceImport: () => isNamespaceImport, + isNamespaceReexportDeclaration: () => isNamespaceReexportDeclaration, + isNewExpression: () => isNewExpression, + isNewExpressionTarget: () => isNewExpressionTarget, + isNoSubstitutionTemplateLiteral: () => isNoSubstitutionTemplateLiteral, + isNode: () => isNode, + isNodeArray: () => isNodeArray, + isNodeArrayMultiLine: () => isNodeArrayMultiLine, + isNodeDescendantOf: () => isNodeDescendantOf, + isNodeKind: () => isNodeKind, + isNodeLikeSystem: () => isNodeLikeSystem, + isNodeModulesDirectory: () => isNodeModulesDirectory, + isNodeWithPossibleHoistedDeclaration: () => isNodeWithPossibleHoistedDeclaration, + isNonContextualKeyword: () => isNonContextualKeyword, + isNonExportDefaultModifier: () => isNonExportDefaultModifier, + isNonGlobalAmbientModule: () => isNonGlobalAmbientModule, + isNonGlobalDeclaration: () => isNonGlobalDeclaration, + isNonNullAccess: () => isNonNullAccess, + isNonNullChain: () => isNonNullChain, + isNonNullExpression: () => isNonNullExpression, + isNonStaticMethodOrAccessorWithPrivateName: () => isNonStaticMethodOrAccessorWithPrivateName, + isNotEmittedOrPartiallyEmittedNode: () => isNotEmittedOrPartiallyEmittedNode, + isNotEmittedStatement: () => isNotEmittedStatement, + isNullishCoalesce: () => isNullishCoalesce, + isNumber: () => isNumber, + isNumericLiteral: () => isNumericLiteral, + isNumericLiteralName: () => isNumericLiteralName, + isObjectBindingElementWithoutPropertyName: () => isObjectBindingElementWithoutPropertyName, + isObjectBindingOrAssignmentElement: () => isObjectBindingOrAssignmentElement, + isObjectBindingOrAssignmentPattern: () => isObjectBindingOrAssignmentPattern, + isObjectBindingPattern: () => isObjectBindingPattern, + isObjectLiteralElement: () => isObjectLiteralElement, + isObjectLiteralElementLike: () => isObjectLiteralElementLike, + isObjectLiteralExpression: () => isObjectLiteralExpression, + isObjectLiteralMethod: () => isObjectLiteralMethod, + isObjectLiteralOrClassExpressionMethodOrAccessor: () => isObjectLiteralOrClassExpressionMethodOrAccessor, + isObjectTypeDeclaration: () => isObjectTypeDeclaration, + isOctalDigit: () => isOctalDigit, + isOmittedExpression: () => isOmittedExpression, + isOptionalChain: () => isOptionalChain, + isOptionalChainRoot: () => isOptionalChainRoot, + isOptionalDeclaration: () => isOptionalDeclaration, + isOptionalJSDocPropertyLikeTag: () => isOptionalJSDocPropertyLikeTag, + isOptionalTypeNode: () => isOptionalTypeNode, + isOuterExpression: () => isOuterExpression, + isOutermostOptionalChain: () => isOutermostOptionalChain, + isOverrideModifier: () => isOverrideModifier, + isPackedArrayLiteral: () => isPackedArrayLiteral, + isParameter: () => isParameter, + isParameterDeclaration: () => isParameterDeclaration, + isParameterOrCatchClauseVariable: () => isParameterOrCatchClauseVariable, + isParameterPropertyDeclaration: () => isParameterPropertyDeclaration, + isParameterPropertyModifier: () => isParameterPropertyModifier, + isParenthesizedExpression: () => isParenthesizedExpression, + isParenthesizedTypeNode: () => isParenthesizedTypeNode, + isParseTreeNode: () => isParseTreeNode, + isPartOfTypeNode: () => isPartOfTypeNode, + isPartOfTypeQuery: () => isPartOfTypeQuery, + isPartiallyEmittedExpression: () => isPartiallyEmittedExpression, + isPatternMatch: () => isPatternMatch, + isPinnedComment: () => isPinnedComment, + isPlainJsFile: () => isPlainJsFile, + isPlusToken: () => isPlusToken, + isPossiblyTypeArgumentPosition: () => isPossiblyTypeArgumentPosition, + isPostfixUnaryExpression: () => isPostfixUnaryExpression, + isPrefixUnaryExpression: () => isPrefixUnaryExpression, + isPrivateIdentifier: () => isPrivateIdentifier, + isPrivateIdentifierClassElementDeclaration: () => isPrivateIdentifierClassElementDeclaration, + isPrivateIdentifierPropertyAccessExpression: () => isPrivateIdentifierPropertyAccessExpression, + isPrivateIdentifierSymbol: () => isPrivateIdentifierSymbol, + isProgramBundleEmitBuildInfo: () => isProgramBundleEmitBuildInfo, + isProgramUptoDate: () => isProgramUptoDate, + isPrologueDirective: () => isPrologueDirective, + isPropertyAccessChain: () => isPropertyAccessChain, + isPropertyAccessEntityNameExpression: () => isPropertyAccessEntityNameExpression, + isPropertyAccessExpression: () => isPropertyAccessExpression, + isPropertyAccessOrQualifiedName: () => isPropertyAccessOrQualifiedName, + isPropertyAccessOrQualifiedNameOrImportTypeNode: () => isPropertyAccessOrQualifiedNameOrImportTypeNode, + isPropertyAssignment: () => isPropertyAssignment, + isPropertyDeclaration: () => isPropertyDeclaration, + isPropertyName: () => isPropertyName, + isPropertyNameLiteral: () => isPropertyNameLiteral, + isPropertySignature: () => isPropertySignature, + isProtoSetter: () => isProtoSetter, + isPrototypeAccess: () => isPrototypeAccess, + isPrototypePropertyAssignment: () => isPrototypePropertyAssignment, + isPunctuation: () => isPunctuation, + isPushOrUnshiftIdentifier: () => isPushOrUnshiftIdentifier, + isQualifiedName: () => isQualifiedName, + isQuestionDotToken: () => isQuestionDotToken, + isQuestionOrExclamationToken: () => isQuestionOrExclamationToken, + isQuestionOrPlusOrMinusToken: () => isQuestionOrPlusOrMinusToken, + isQuestionToken: () => isQuestionToken, + isRawSourceMap: () => isRawSourceMap, + isReadonlyKeyword: () => isReadonlyKeyword, + isReadonlyKeywordOrPlusOrMinusToken: () => isReadonlyKeywordOrPlusOrMinusToken, + isRecognizedTripleSlashComment: () => isRecognizedTripleSlashComment, + isReferenceFileLocation: () => isReferenceFileLocation, + isReferencedFile: () => isReferencedFile, + isRegularExpressionLiteral: () => isRegularExpressionLiteral, + isRequireCall: () => isRequireCall, + isRequireVariableStatement: () => isRequireVariableStatement, + isRestParameter: () => isRestParameter, + isRestTypeNode: () => isRestTypeNode, + isReturnStatement: () => isReturnStatement, + isReturnStatementWithFixablePromiseHandler: () => isReturnStatementWithFixablePromiseHandler, + isRightSideOfAccessExpression: () => isRightSideOfAccessExpression, + isRightSideOfInstanceofExpression: () => isRightSideOfInstanceofExpression, + isRightSideOfPropertyAccess: () => isRightSideOfPropertyAccess, + isRightSideOfQualifiedName: () => isRightSideOfQualifiedName, + isRightSideOfQualifiedNameOrPropertyAccess: () => isRightSideOfQualifiedNameOrPropertyAccess, + isRightSideOfQualifiedNameOrPropertyAccessOrJSDocMemberName: () => isRightSideOfQualifiedNameOrPropertyAccessOrJSDocMemberName, + isRootedDiskPath: () => isRootedDiskPath, + isSameEntityName: () => isSameEntityName, + isSatisfiesExpression: () => isSatisfiesExpression, + isScopeMarker: () => isScopeMarker, + isSemicolonClassElement: () => isSemicolonClassElement, + isSetAccessor: () => isSetAccessor, + isSetAccessorDeclaration: () => isSetAccessorDeclaration, + isShebangTrivia: () => isShebangTrivia, + isShiftOperatorOrHigher: () => isShiftOperatorOrHigher, + isShorthandAmbientModuleSymbol: () => isShorthandAmbientModuleSymbol, + isShorthandPropertyAssignment: () => isShorthandPropertyAssignment, + isSignedNumericLiteral: () => isSignedNumericLiteral, + isSimpleCopiableExpression: () => isSimpleCopiableExpression, + isSimpleInlineableExpression: () => isSimpleInlineableExpression, + isSingleOrDoubleQuote: () => isSingleOrDoubleQuote, + isSourceFile: () => isSourceFile, + isSourceFileFromLibrary: () => isSourceFileFromLibrary, + isSourceFileJS: () => isSourceFileJS, + isSourceFileNotJS: () => isSourceFileNotJS, + isSourceFileNotJson: () => isSourceFileNotJson, + isSourceMapping: () => isSourceMapping, + isSpecialPropertyDeclaration: () => isSpecialPropertyDeclaration, + isSpreadAssignment: () => isSpreadAssignment, + isSpreadElement: () => isSpreadElement, + isStatement: () => isStatement, + isStatementButNotDeclaration: () => isStatementButNotDeclaration, + isStatementOrBlock: () => isStatementOrBlock, + isStatementWithLocals: () => isStatementWithLocals, + isStatic: () => isStatic, + isStaticModifier: () => isStaticModifier, + isString: () => isString, + isStringAKeyword: () => isStringAKeyword, + isStringANonContextualKeyword: () => isStringANonContextualKeyword, + isStringAndEmptyAnonymousObjectIntersection: () => isStringAndEmptyAnonymousObjectIntersection, + isStringDoubleQuoted: () => isStringDoubleQuoted, + isStringLiteral: () => isStringLiteral, + isStringLiteralLike: () => isStringLiteralLike, + isStringLiteralOrJsxExpression: () => isStringLiteralOrJsxExpression, + isStringLiteralOrTemplate: () => isStringLiteralOrTemplate, + isStringOrNumericLiteralLike: () => isStringOrNumericLiteralLike, + isStringOrRegularExpressionOrTemplateLiteral: () => isStringOrRegularExpressionOrTemplateLiteral, + isStringTextContainingNode: () => isStringTextContainingNode, + isSuperCall: () => isSuperCall, + isSuperKeyword: () => isSuperKeyword, + isSuperOrSuperProperty: () => isSuperOrSuperProperty, + isSuperProperty: () => isSuperProperty, + isSupportedSourceFileName: () => isSupportedSourceFileName, + isSwitchStatement: () => isSwitchStatement, + isSyntaxList: () => isSyntaxList, + isSyntheticExpression: () => isSyntheticExpression, + isSyntheticReference: () => isSyntheticReference, + isTagName: () => isTagName, + isTaggedTemplateExpression: () => isTaggedTemplateExpression, + isTaggedTemplateTag: () => isTaggedTemplateTag, + isTemplateExpression: () => isTemplateExpression, + isTemplateHead: () => isTemplateHead, + isTemplateLiteral: () => isTemplateLiteral, + isTemplateLiteralKind: () => isTemplateLiteralKind, + isTemplateLiteralToken: () => isTemplateLiteralToken, + isTemplateLiteralTypeNode: () => isTemplateLiteralTypeNode, + isTemplateLiteralTypeSpan: () => isTemplateLiteralTypeSpan, + isTemplateMiddle: () => isTemplateMiddle, + isTemplateMiddleOrTemplateTail: () => isTemplateMiddleOrTemplateTail, + isTemplateSpan: () => isTemplateSpan, + isTemplateTail: () => isTemplateTail, + isTextWhiteSpaceLike: () => isTextWhiteSpaceLike, + isThis: () => isThis, + isThisContainerOrFunctionBlock: () => isThisContainerOrFunctionBlock, + isThisIdentifier: () => isThisIdentifier, + isThisInTypeQuery: () => isThisInTypeQuery, + isThisInitializedDeclaration: () => isThisInitializedDeclaration, + isThisInitializedObjectBindingExpression: () => isThisInitializedObjectBindingExpression, + isThisProperty: () => isThisProperty, + isThisTypeNode: () => isThisTypeNode, + isThisTypeParameter: () => isThisTypeParameter, + isThisTypePredicate: () => isThisTypePredicate, + isThrowStatement: () => isThrowStatement, + isToken: () => isToken, + isTokenKind: () => isTokenKind, + isTraceEnabled: () => isTraceEnabled, + isTransientSymbol: () => isTransientSymbol, + isTrivia: () => isTrivia, + isTryStatement: () => isTryStatement, + isTupleTypeNode: () => isTupleTypeNode, + isTypeAlias: () => isTypeAlias, + isTypeAliasDeclaration: () => isTypeAliasDeclaration, + isTypeAssertionExpression: () => isTypeAssertionExpression, + isTypeDeclaration: () => isTypeDeclaration, + isTypeElement: () => isTypeElement, + isTypeKeyword: () => isTypeKeyword, + isTypeKeywordToken: () => isTypeKeywordToken, + isTypeKeywordTokenOrIdentifier: () => isTypeKeywordTokenOrIdentifier, + isTypeLiteralNode: () => isTypeLiteralNode, + isTypeNode: () => isTypeNode, + isTypeNodeKind: () => isTypeNodeKind, + isTypeOfExpression: () => isTypeOfExpression, + isTypeOnlyExportDeclaration: () => isTypeOnlyExportDeclaration, + isTypeOnlyImportDeclaration: () => isTypeOnlyImportDeclaration, + isTypeOnlyImportOrExportDeclaration: () => isTypeOnlyImportOrExportDeclaration, + isTypeOperatorNode: () => isTypeOperatorNode, + isTypeParameterDeclaration: () => isTypeParameterDeclaration, + isTypePredicateNode: () => isTypePredicateNode, + isTypeQueryNode: () => isTypeQueryNode, + isTypeReferenceNode: () => isTypeReferenceNode, + isTypeReferenceType: () => isTypeReferenceType, + isTypeUsableAsPropertyName: () => isTypeUsableAsPropertyName, + isUMDExportSymbol: () => isUMDExportSymbol, + isUnaryExpression: () => isUnaryExpression, + isUnaryExpressionWithWrite: () => isUnaryExpressionWithWrite, + isUnicodeIdentifierStart: () => isUnicodeIdentifierStart, + isUnionTypeNode: () => isUnionTypeNode, + isUnparsedNode: () => isUnparsedNode, + isUnparsedPrepend: () => isUnparsedPrepend, + isUnparsedSource: () => isUnparsedSource, + isUnparsedTextLike: () => isUnparsedTextLike, + isUrl: () => isUrl, + isValidBigIntString: () => isValidBigIntString, + isValidESSymbolDeclaration: () => isValidESSymbolDeclaration, + isValidTypeOnlyAliasUseSite: () => isValidTypeOnlyAliasUseSite, + isValueSignatureDeclaration: () => isValueSignatureDeclaration, + isVarAwaitUsing: () => isVarAwaitUsing, + isVarConst: () => isVarConst, + isVarUsing: () => isVarUsing, + isVariableDeclaration: () => isVariableDeclaration, + isVariableDeclarationInVariableStatement: () => isVariableDeclarationInVariableStatement, + isVariableDeclarationInitializedToBareOrAccessedRequire: () => isVariableDeclarationInitializedToBareOrAccessedRequire, + isVariableDeclarationInitializedToRequire: () => isVariableDeclarationInitializedToRequire, + isVariableDeclarationList: () => isVariableDeclarationList, + isVariableLike: () => isVariableLike, + isVariableLikeOrAccessor: () => isVariableLikeOrAccessor, + isVariableStatement: () => isVariableStatement, + isVoidExpression: () => isVoidExpression, + isWatchSet: () => isWatchSet, + isWhileStatement: () => isWhileStatement, + isWhiteSpaceLike: () => isWhiteSpaceLike, + isWhiteSpaceSingleLine: () => isWhiteSpaceSingleLine, + isWithStatement: () => isWithStatement, + isWriteAccess: () => isWriteAccess, + isWriteOnlyAccess: () => isWriteOnlyAccess, + isYieldExpression: () => isYieldExpression, + jsxModeNeedsExplicitImport: () => jsxModeNeedsExplicitImport, + keywordPart: () => keywordPart, + last: () => last, + lastOrUndefined: () => lastOrUndefined, + length: () => length, + libMap: () => libMap, + libs: () => libs, + lineBreakPart: () => lineBreakPart, + linkNamePart: () => linkNamePart, + linkPart: () => linkPart, + linkTextPart: () => linkTextPart, + listFiles: () => listFiles, + loadModuleFromGlobalCache: () => loadModuleFromGlobalCache, + loadWithModeAwareCache: () => loadWithModeAwareCache, + makeIdentifierFromModuleName: () => makeIdentifierFromModuleName, + makeImport: () => makeImport, + makeImportIfNecessary: () => makeImportIfNecessary, + makeStringLiteral: () => makeStringLiteral, + mangleScopedPackageName: () => mangleScopedPackageName, + map: () => map, + mapAllOrFail: () => mapAllOrFail, + mapDefined: () => mapDefined, + mapDefinedEntries: () => mapDefinedEntries, + mapDefinedIterator: () => mapDefinedIterator, + mapEntries: () => mapEntries, + mapIterator: () => mapIterator, + mapOneOrMany: () => mapOneOrMany, + mapToDisplayParts: () => mapToDisplayParts, + matchFiles: () => matchFiles, + matchPatternOrExact: () => matchPatternOrExact, + matchedText: () => matchedText, + matchesExclude: () => matchesExclude, + maybeBind: () => maybeBind, + maybeSetLocalizedDiagnosticMessages: () => maybeSetLocalizedDiagnosticMessages, + memoize: () => memoize, + memoizeCached: () => memoizeCached, + memoizeOne: () => memoizeOne, + memoizeWeak: () => memoizeWeak, + metadataHelper: () => metadataHelper, + min: () => min, + minAndMax: () => minAndMax, + missingFileModifiedTime: () => missingFileModifiedTime, + modifierToFlag: () => modifierToFlag, + modifiersToFlags: () => modifiersToFlags, + moduleOptionDeclaration: () => moduleOptionDeclaration, + moduleResolutionIsEqualTo: () => moduleResolutionIsEqualTo, + moduleResolutionNameAndModeGetter: () => moduleResolutionNameAndModeGetter, + moduleResolutionOptionDeclarations: () => moduleResolutionOptionDeclarations, + moduleResolutionSupportsPackageJsonExportsAndImports: () => moduleResolutionSupportsPackageJsonExportsAndImports, + moduleResolutionUsesNodeModules: () => moduleResolutionUsesNodeModules, + moduleSpecifiers: () => ts_moduleSpecifiers_exports, + moveEmitHelpers: () => moveEmitHelpers, + moveRangeEnd: () => moveRangeEnd, + moveRangePastDecorators: () => moveRangePastDecorators, + moveRangePastModifiers: () => moveRangePastModifiers, + moveRangePos: () => moveRangePos, + moveSyntheticComments: () => moveSyntheticComments, + mutateMap: () => mutateMap, + mutateMapSkippingNewValues: () => mutateMapSkippingNewValues, + needsParentheses: () => needsParentheses, + needsScopeMarker: () => needsScopeMarker, + newCaseClauseTracker: () => newCaseClauseTracker, + newPrivateEnvironment: () => newPrivateEnvironment, + noEmitNotification: () => noEmitNotification, + noEmitSubstitution: () => noEmitSubstitution, + noTransformers: () => noTransformers, + noTruncationMaximumTruncationLength: () => noTruncationMaximumTruncationLength, + nodeCanBeDecorated: () => nodeCanBeDecorated, + nodeHasName: () => nodeHasName, + nodeIsDecorated: () => nodeIsDecorated, + nodeIsMissing: () => nodeIsMissing, + nodeIsPresent: () => nodeIsPresent, + nodeIsSynthesized: () => nodeIsSynthesized, + nodeModuleNameResolver: () => nodeModuleNameResolver, + nodeModulesPathPart: () => nodeModulesPathPart, + nodeNextJsonConfigResolver: () => nodeNextJsonConfigResolver, + nodeOrChildIsDecorated: () => nodeOrChildIsDecorated, + nodeOverlapsWithStartEnd: () => nodeOverlapsWithStartEnd, + nodePosToString: () => nodePosToString, + nodeSeenTracker: () => nodeSeenTracker, + nodeStartsNewLexicalEnvironment: () => nodeStartsNewLexicalEnvironment, + nodeToDisplayParts: () => nodeToDisplayParts, + noop: () => noop, + noopFileWatcher: () => noopFileWatcher, + normalizePath: () => normalizePath, + normalizeSlashes: () => normalizeSlashes, + not: () => not, + notImplemented: () => notImplemented, + notImplementedResolver: () => notImplementedResolver, + nullNodeConverters: () => nullNodeConverters, + nullParenthesizerRules: () => nullParenthesizerRules, + nullTransformationContext: () => nullTransformationContext, + objectAllocator: () => objectAllocator, + operatorPart: () => operatorPart, + optionDeclarations: () => optionDeclarations, + optionMapToObject: () => optionMapToObject, + optionsAffectingProgramStructure: () => optionsAffectingProgramStructure, + optionsForBuild: () => optionsForBuild, + optionsForWatch: () => optionsForWatch, + optionsHaveChanges: () => optionsHaveChanges, + optionsHaveModuleResolutionChanges: () => optionsHaveModuleResolutionChanges, + or: () => or, + orderedRemoveItem: () => orderedRemoveItem, + orderedRemoveItemAt: () => orderedRemoveItemAt, + outFile: () => outFile, + packageIdToPackageName: () => packageIdToPackageName, + packageIdToString: () => packageIdToString, + paramHelper: () => paramHelper, + parameterIsThisKeyword: () => parameterIsThisKeyword, + parameterNamePart: () => parameterNamePart, + parseBaseNodeFactory: () => parseBaseNodeFactory, + parseBigInt: () => parseBigInt, + parseBuildCommand: () => parseBuildCommand, + parseCommandLine: () => parseCommandLine, + parseCommandLineWorker: () => parseCommandLineWorker, + parseConfigFileTextToJson: () => parseConfigFileTextToJson, + parseConfigFileWithSystem: () => parseConfigFileWithSystem, + parseConfigHostFromCompilerHostLike: () => parseConfigHostFromCompilerHostLike, + parseCustomTypeOption: () => parseCustomTypeOption, + parseIsolatedEntityName: () => parseIsolatedEntityName, + parseIsolatedJSDocComment: () => parseIsolatedJSDocComment, + parseJSDocTypeExpressionForTests: () => parseJSDocTypeExpressionForTests, + parseJsonConfigFileContent: () => parseJsonConfigFileContent, + parseJsonSourceFileConfigFileContent: () => parseJsonSourceFileConfigFileContent, + parseJsonText: () => parseJsonText, + parseListTypeOption: () => parseListTypeOption, + parseNodeFactory: () => parseNodeFactory, + parseNodeModuleFromPath: () => parseNodeModuleFromPath, + parsePackageName: () => parsePackageName, + parsePseudoBigInt: () => parsePseudoBigInt, + parseValidBigInt: () => parseValidBigInt, + patchWriteFileEnsuringDirectory: () => patchWriteFileEnsuringDirectory, + pathContainsNodeModules: () => pathContainsNodeModules, + pathIsAbsolute: () => pathIsAbsolute, + pathIsBareSpecifier: () => pathIsBareSpecifier, + pathIsRelative: () => pathIsRelative, + patternText: () => patternText, + perfLogger: () => perfLogger, + performIncrementalCompilation: () => performIncrementalCompilation, + performance: () => ts_performance_exports, + plainJSErrors: () => plainJSErrors, + positionBelongsToNode: () => positionBelongsToNode, + positionIsASICandidate: () => positionIsASICandidate, + positionIsSynthesized: () => positionIsSynthesized, + positionsAreOnSameLine: () => positionsAreOnSameLine, + preProcessFile: () => preProcessFile, + probablyUsesSemicolons: () => probablyUsesSemicolons, + processCommentPragmas: () => processCommentPragmas, + processPragmasIntoFields: () => processPragmasIntoFields, + processTaggedTemplateExpression: () => processTaggedTemplateExpression, + programContainsEsModules: () => programContainsEsModules, + programContainsModules: () => programContainsModules, + projectReferenceIsEqualTo: () => projectReferenceIsEqualTo, + propKeyHelper: () => propKeyHelper, + propertyNamePart: () => propertyNamePart, + pseudoBigIntToString: () => pseudoBigIntToString, + punctuationPart: () => punctuationPart, + pushIfUnique: () => pushIfUnique, + quote: () => quote, + quotePreferenceFromString: () => quotePreferenceFromString, + rangeContainsPosition: () => rangeContainsPosition, + rangeContainsPositionExclusive: () => rangeContainsPositionExclusive, + rangeContainsRange: () => rangeContainsRange, + rangeContainsRangeExclusive: () => rangeContainsRangeExclusive, + rangeContainsStartEnd: () => rangeContainsStartEnd, + rangeEndIsOnSameLineAsRangeStart: () => rangeEndIsOnSameLineAsRangeStart, + rangeEndPositionsAreOnSameLine: () => rangeEndPositionsAreOnSameLine, + rangeEquals: () => rangeEquals, + rangeIsOnSingleLine: () => rangeIsOnSingleLine, + rangeOfNode: () => rangeOfNode, + rangeOfTypeParameters: () => rangeOfTypeParameters, + rangeOverlapsWithStartEnd: () => rangeOverlapsWithStartEnd, + rangeStartIsOnSameLineAsRangeEnd: () => rangeStartIsOnSameLineAsRangeEnd, + rangeStartPositionsAreOnSameLine: () => rangeStartPositionsAreOnSameLine, + readBuilderProgram: () => readBuilderProgram, + readConfigFile: () => readConfigFile, + readHelper: () => readHelper, + readJson: () => readJson, + readJsonConfigFile: () => readJsonConfigFile, + readJsonOrUndefined: () => readJsonOrUndefined, + reduceEachLeadingCommentRange: () => reduceEachLeadingCommentRange, + reduceEachTrailingCommentRange: () => reduceEachTrailingCommentRange, + reduceLeft: () => reduceLeft, + reduceLeftIterator: () => reduceLeftIterator, + reducePathComponents: () => reducePathComponents, + refactor: () => ts_refactor_exports, + regExpEscape: () => regExpEscape, + relativeComplement: () => relativeComplement, + removeAllComments: () => removeAllComments, + removeEmitHelper: () => removeEmitHelper, + removeExtension: () => removeExtension, + removeFileExtension: () => removeFileExtension, + removeIgnoredPath: () => removeIgnoredPath, + removeMinAndVersionNumbers: () => removeMinAndVersionNumbers, + removeOptionality: () => removeOptionality, + removePrefix: () => removePrefix, + removeSuffix: () => removeSuffix, + removeTrailingDirectorySeparator: () => removeTrailingDirectorySeparator, + repeatString: () => repeatString, + replaceElement: () => replaceElement, + resolutionExtensionIsTSOrJson: () => resolutionExtensionIsTSOrJson, + resolveConfigFileProjectName: () => resolveConfigFileProjectName, + resolveJSModule: () => resolveJSModule, + resolveLibrary: () => resolveLibrary, + resolveModuleName: () => resolveModuleName, + resolveModuleNameFromCache: () => resolveModuleNameFromCache, + resolvePackageNameToPackageJson: () => resolvePackageNameToPackageJson, + resolvePath: () => resolvePath, + resolveProjectReferencePath: () => resolveProjectReferencePath, + resolveTripleslashReference: () => resolveTripleslashReference, + resolveTypeReferenceDirective: () => resolveTypeReferenceDirective, + resolvingEmptyArray: () => resolvingEmptyArray, + restHelper: () => restHelper, + returnFalse: () => returnFalse, + returnNoopFileWatcher: () => returnNoopFileWatcher, + returnTrue: () => returnTrue, + returnUndefined: () => returnUndefined, + returnsPromise: () => returnsPromise, + runInitializersHelper: () => runInitializersHelper, + sameFlatMap: () => sameFlatMap, + sameMap: () => sameMap, + sameMapping: () => sameMapping, + scanShebangTrivia: () => scanShebangTrivia, + scanTokenAtPosition: () => scanTokenAtPosition, + scanner: () => scanner, + screenStartingMessageCodes: () => screenStartingMessageCodes, + semanticDiagnosticsOptionDeclarations: () => semanticDiagnosticsOptionDeclarations, + serializeCompilerOptions: () => serializeCompilerOptions, + server: () => ts_server_exports3, + servicesVersion: () => servicesVersion, + setCommentRange: () => setCommentRange, + setConfigFileInOptions: () => setConfigFileInOptions, + setConstantValue: () => setConstantValue, + setEachParent: () => setEachParent, + setEmitFlags: () => setEmitFlags, + setFunctionNameHelper: () => setFunctionNameHelper, + setGetSourceFileAsHashVersioned: () => setGetSourceFileAsHashVersioned, + setIdentifierAutoGenerate: () => setIdentifierAutoGenerate, + setIdentifierGeneratedImportReference: () => setIdentifierGeneratedImportReference, + setIdentifierTypeArguments: () => setIdentifierTypeArguments, + setInternalEmitFlags: () => setInternalEmitFlags, + setLocalizedDiagnosticMessages: () => setLocalizedDiagnosticMessages, + setModuleDefaultHelper: () => setModuleDefaultHelper, + setNodeFlags: () => setNodeFlags, + setObjectAllocator: () => setObjectAllocator, + setOriginalNode: () => setOriginalNode, + setParent: () => setParent, + setParentRecursive: () => setParentRecursive, + setPrivateIdentifier: () => setPrivateIdentifier, + setSnippetElement: () => setSnippetElement, + setSourceMapRange: () => setSourceMapRange, + setStackTraceLimit: () => setStackTraceLimit, + setStartsOnNewLine: () => setStartsOnNewLine, + setSyntheticLeadingComments: () => setSyntheticLeadingComments, + setSyntheticTrailingComments: () => setSyntheticTrailingComments, + setSys: () => setSys, + setSysLog: () => setSysLog, + setTextRange: () => setTextRange, + setTextRangeEnd: () => setTextRangeEnd, + setTextRangePos: () => setTextRangePos, + setTextRangePosEnd: () => setTextRangePosEnd, + setTextRangePosWidth: () => setTextRangePosWidth, + setTokenSourceMapRange: () => setTokenSourceMapRange, + setTypeNode: () => setTypeNode, + setUILocale: () => setUILocale, + setValueDeclaration: () => setValueDeclaration, + shouldAllowImportingTsExtension: () => shouldAllowImportingTsExtension, + shouldPreserveConstEnums: () => shouldPreserveConstEnums, + shouldResolveJsRequire: () => shouldResolveJsRequire, + shouldUseUriStyleNodeCoreModules: () => shouldUseUriStyleNodeCoreModules, + showModuleSpecifier: () => showModuleSpecifier, + signatureHasLiteralTypes: () => signatureHasLiteralTypes, + signatureHasRestParameter: () => signatureHasRestParameter, + signatureToDisplayParts: () => signatureToDisplayParts, + single: () => single, + singleElementArray: () => singleElementArray, + singleIterator: () => singleIterator, + singleOrMany: () => singleOrMany, + singleOrUndefined: () => singleOrUndefined, + skipAlias: () => skipAlias, + skipAssertions: () => skipAssertions, + skipConstraint: () => skipConstraint, + skipOuterExpressions: () => skipOuterExpressions, + skipParentheses: () => skipParentheses, + skipPartiallyEmittedExpressions: () => skipPartiallyEmittedExpressions, + skipTrivia: () => skipTrivia, + skipTypeChecking: () => skipTypeChecking, + skipTypeParentheses: () => skipTypeParentheses, + skipWhile: () => skipWhile, + sliceAfter: () => sliceAfter, + some: () => some, + sort: () => sort, + sortAndDeduplicate: () => sortAndDeduplicate, + sortAndDeduplicateDiagnostics: () => sortAndDeduplicateDiagnostics, + sourceFileAffectingCompilerOptions: () => sourceFileAffectingCompilerOptions, + sourceFileMayBeEmitted: () => sourceFileMayBeEmitted, + sourceMapCommentRegExp: () => sourceMapCommentRegExp, + sourceMapCommentRegExpDontCareLineStart: () => sourceMapCommentRegExpDontCareLineStart, + spacePart: () => spacePart, + spanMap: () => spanMap, + spreadArrayHelper: () => spreadArrayHelper, + stableSort: () => stableSort, + startEndContainsRange: () => startEndContainsRange, + startEndOverlapsWithStartEnd: () => startEndOverlapsWithStartEnd, + startOnNewLine: () => startOnNewLine, + startTracing: () => startTracing, + startsWith: () => startsWith, + startsWithDirectory: () => startsWithDirectory, + startsWithUnderscore: () => startsWithUnderscore, + startsWithUseStrict: () => startsWithUseStrict, + stringContainsAt: () => stringContainsAt, + stringToToken: () => stringToToken, + stripQuotes: () => stripQuotes, + supportedDeclarationExtensions: () => supportedDeclarationExtensions, + supportedJSExtensions: () => supportedJSExtensions, + supportedJSExtensionsFlat: () => supportedJSExtensionsFlat, + supportedLocaleDirectories: () => supportedLocaleDirectories, + supportedTSExtensions: () => supportedTSExtensions, + supportedTSExtensionsFlat: () => supportedTSExtensionsFlat, + supportedTSImplementationExtensions: () => supportedTSImplementationExtensions, + suppressLeadingAndTrailingTrivia: () => suppressLeadingAndTrailingTrivia, + suppressLeadingTrivia: () => suppressLeadingTrivia, + suppressTrailingTrivia: () => suppressTrailingTrivia, + symbolEscapedNameNoDefault: () => symbolEscapedNameNoDefault, + symbolName: () => symbolName, + symbolNameNoDefault: () => symbolNameNoDefault, + symbolPart: () => symbolPart, + symbolToDisplayParts: () => symbolToDisplayParts, + syntaxMayBeASICandidate: () => syntaxMayBeASICandidate, + syntaxRequiresTrailingSemicolonOrASI: () => syntaxRequiresTrailingSemicolonOrASI, + sys: () => sys, + sysLog: () => sysLog, + tagNamesAreEquivalent: () => tagNamesAreEquivalent, + takeWhile: () => takeWhile, + targetOptionDeclaration: () => targetOptionDeclaration, + templateObjectHelper: () => templateObjectHelper, + testFormatSettings: () => testFormatSettings, + textChangeRangeIsUnchanged: () => textChangeRangeIsUnchanged, + textChangeRangeNewSpan: () => textChangeRangeNewSpan, + textChanges: () => ts_textChanges_exports, + textOrKeywordPart: () => textOrKeywordPart, + textPart: () => textPart, + textRangeContainsPositionInclusive: () => textRangeContainsPositionInclusive, + textSpanContainsPosition: () => textSpanContainsPosition, + textSpanContainsTextSpan: () => textSpanContainsTextSpan, + textSpanEnd: () => textSpanEnd, + textSpanIntersection: () => textSpanIntersection, + textSpanIntersectsWith: () => textSpanIntersectsWith, + textSpanIntersectsWithPosition: () => textSpanIntersectsWithPosition, + textSpanIntersectsWithTextSpan: () => textSpanIntersectsWithTextSpan, + textSpanIsEmpty: () => textSpanIsEmpty, + textSpanOverlap: () => textSpanOverlap, + textSpanOverlapsWith: () => textSpanOverlapsWith, + textSpansEqual: () => textSpansEqual, + textToKeywordObj: () => textToKeywordObj, + timestamp: () => timestamp, + toArray: () => toArray, + toBuilderFileEmit: () => toBuilderFileEmit, + toBuilderStateFileInfoForMultiEmit: () => toBuilderStateFileInfoForMultiEmit, + toEditorSettings: () => toEditorSettings, + toFileNameLowerCase: () => toFileNameLowerCase, + toLowerCase: () => toLowerCase, + toPath: () => toPath, + toProgramEmitPending: () => toProgramEmitPending, + tokenIsIdentifierOrKeyword: () => tokenIsIdentifierOrKeyword, + tokenIsIdentifierOrKeywordOrGreaterThan: () => tokenIsIdentifierOrKeywordOrGreaterThan, + tokenToString: () => tokenToString, + trace: () => trace, + tracing: () => tracing, + tracingEnabled: () => tracingEnabled, + transform: () => transform, + transformClassFields: () => transformClassFields, + transformDeclarations: () => transformDeclarations, + transformECMAScriptModule: () => transformECMAScriptModule, + transformES2015: () => transformES2015, + transformES2016: () => transformES2016, + transformES2017: () => transformES2017, + transformES2018: () => transformES2018, + transformES2019: () => transformES2019, + transformES2020: () => transformES2020, + transformES2021: () => transformES2021, + transformES5: () => transformES5, + transformESDecorators: () => transformESDecorators, + transformESNext: () => transformESNext, + transformGenerators: () => transformGenerators, + transformJsx: () => transformJsx, + transformLegacyDecorators: () => transformLegacyDecorators, + transformModule: () => transformModule, + transformNamedEvaluation: () => transformNamedEvaluation, + transformNodeModule: () => transformNodeModule, + transformNodes: () => transformNodes, + transformSystemModule: () => transformSystemModule, + transformTypeScript: () => transformTypeScript, + transpile: () => transpile, + transpileModule: () => transpileModule, + transpileOptionValueCompilerOptions: () => transpileOptionValueCompilerOptions, + tryAddToSet: () => tryAddToSet, + tryAndIgnoreErrors: () => tryAndIgnoreErrors, + tryCast: () => tryCast, + tryDirectoryExists: () => tryDirectoryExists, + tryExtractTSExtension: () => tryExtractTSExtension, + tryFileExists: () => tryFileExists, + tryGetClassExtendingExpressionWithTypeArguments: () => tryGetClassExtendingExpressionWithTypeArguments, + tryGetClassImplementingOrExtendingExpressionWithTypeArguments: () => tryGetClassImplementingOrExtendingExpressionWithTypeArguments, + tryGetDirectories: () => tryGetDirectories, + tryGetExtensionFromPath: () => tryGetExtensionFromPath2, + tryGetImportFromModuleSpecifier: () => tryGetImportFromModuleSpecifier, + tryGetJSDocSatisfiesTypeNode: () => tryGetJSDocSatisfiesTypeNode, + tryGetModuleNameFromFile: () => tryGetModuleNameFromFile, + tryGetModuleSpecifierFromDeclaration: () => tryGetModuleSpecifierFromDeclaration, + tryGetNativePerformanceHooks: () => tryGetNativePerformanceHooks, + tryGetPropertyAccessOrIdentifierToString: () => tryGetPropertyAccessOrIdentifierToString, + tryGetPropertyNameOfBindingOrAssignmentElement: () => tryGetPropertyNameOfBindingOrAssignmentElement, + tryGetSourceMappingURL: () => tryGetSourceMappingURL, + tryGetTextOfPropertyName: () => tryGetTextOfPropertyName, + tryIOAndConsumeErrors: () => tryIOAndConsumeErrors, + tryParsePattern: () => tryParsePattern, + tryParsePatterns: () => tryParsePatterns, + tryParseRawSourceMap: () => tryParseRawSourceMap, + tryReadDirectory: () => tryReadDirectory, + tryReadFile: () => tryReadFile, + tryRemoveDirectoryPrefix: () => tryRemoveDirectoryPrefix, + tryRemoveExtension: () => tryRemoveExtension, + tryRemovePrefix: () => tryRemovePrefix, + tryRemoveSuffix: () => tryRemoveSuffix, + typeAcquisitionDeclarations: () => typeAcquisitionDeclarations, + typeAliasNamePart: () => typeAliasNamePart, + typeDirectiveIsEqualTo: () => typeDirectiveIsEqualTo, + typeKeywords: () => typeKeywords, + typeParameterNamePart: () => typeParameterNamePart, + typeReferenceResolutionNameAndModeGetter: () => typeReferenceResolutionNameAndModeGetter, + typeToDisplayParts: () => typeToDisplayParts, + unchangedPollThresholds: () => unchangedPollThresholds, + unchangedTextChangeRange: () => unchangedTextChangeRange, + unescapeLeadingUnderscores: () => unescapeLeadingUnderscores, + unmangleScopedPackageName: () => unmangleScopedPackageName, + unorderedRemoveItem: () => unorderedRemoveItem, + unorderedRemoveItemAt: () => unorderedRemoveItemAt, + unreachableCodeIsError: () => unreachableCodeIsError, + unusedLabelIsError: () => unusedLabelIsError, + unwrapInnermostStatementOfLabel: () => unwrapInnermostStatementOfLabel, + updateErrorForNoInputFiles: () => updateErrorForNoInputFiles, + updateLanguageServiceSourceFile: () => updateLanguageServiceSourceFile, + updateMissingFilePathsWatch: () => updateMissingFilePathsWatch, + updatePackageJsonWatch: () => updatePackageJsonWatch, + updateResolutionField: () => updateResolutionField, + updateSharedExtendedConfigFileWatcher: () => updateSharedExtendedConfigFileWatcher, + updateSourceFile: () => updateSourceFile, + updateWatchingWildcardDirectories: () => updateWatchingWildcardDirectories, + usesExtensionsOnImports: () => usesExtensionsOnImports, + usingSingleLineStringWriter: () => usingSingleLineStringWriter, + utf16EncodeAsString: () => utf16EncodeAsString, + validateLocaleAndSetLanguage: () => validateLocaleAndSetLanguage, + valuesHelper: () => valuesHelper, + version: () => version, + versionMajorMinor: () => versionMajorMinor, + visitArray: () => visitArray, + visitCommaListElements: () => visitCommaListElements, + visitEachChild: () => visitEachChild, + visitFunctionBody: () => visitFunctionBody, + visitIterationBody: () => visitIterationBody, + visitLexicalEnvironment: () => visitLexicalEnvironment, + visitNode: () => visitNode, + visitNodes: () => visitNodes2, + visitParameterList: () => visitParameterList, + walkUpBindingElementsAndPatterns: () => walkUpBindingElementsAndPatterns, + walkUpLexicalEnvironments: () => walkUpLexicalEnvironments, + walkUpOuterExpressions: () => walkUpOuterExpressions, + walkUpParenthesizedExpressions: () => walkUpParenthesizedExpressions, + walkUpParenthesizedTypes: () => walkUpParenthesizedTypes, + walkUpParenthesizedTypesAndGetParentAndChild: () => walkUpParenthesizedTypesAndGetParentAndChild, + whitespaceOrMapCommentRegExp: () => whitespaceOrMapCommentRegExp, + writeCommentRange: () => writeCommentRange, + writeFile: () => writeFile, + writeFileEnsuringDirectories: () => writeFileEnsuringDirectories, + zipWith: () => zipWith + }); + var init_ts7 = __esm({ + "src/server/_namespaces/ts.ts"() { "use strict"; init_ts2(); init_ts3(); - init_types3(); - init_utilities4(); - init_exportInfoMap(); - init_classifier(); - init_documentHighlights(); - init_documentRegistry(); - init_getEditsForFileRename(); - init_patternMatcher(); - init_preProcess(); - init_sourcemaps(); - init_suggestionDiagnostics(); - init_transpile(); - init_services(); - init_transform(); - init_shims(); - init_ts_BreakpointResolver(); - init_ts_CallHierarchy(); - init_ts_classifier(); - init_ts_codefix(); - init_ts_Completions(); - init_ts_FindAllReferences(); - init_ts_GoToDefinition(); - init_ts_InlayHints(); - init_ts_JsDoc(); - init_ts_NavigateTo(); - init_ts_NavigationBar(); - init_ts_OrganizeImports(); - init_ts_OutliningElementsCollector(); - init_ts_refactor(); - init_ts_Rename(); - init_ts_SignatureHelp(); - init_ts_SmartSelectionRange(); - init_ts_SymbolDisplay(); - init_ts_textChanges(); - init_ts_formatting(); - } - }); - - // src/deprecatedCompat/deprecate.ts - function getTypeScriptVersion() { - return typeScriptVersion2 ?? (typeScriptVersion2 = new Version(version)); - } - function formatDeprecationMessage(name, error, errorAfter, since, message) { - let deprecationMessage = error ? "DeprecationError: " : "DeprecationWarning: "; - deprecationMessage += `'${name}' `; - deprecationMessage += since ? `has been deprecated since v${since}` : "is deprecated"; - deprecationMessage += error ? " and can no longer be used." : errorAfter ? ` and will no longer be usable after v${errorAfter}.` : "."; - deprecationMessage += message ? ` ${formatStringFromArgs(message, [name], 0)}` : ""; - return deprecationMessage; - } - function createErrorDeprecation(name, errorAfter, since, message) { - const deprecationMessage = formatDeprecationMessage( - name, - /*error*/ - true, - errorAfter, - since, - message - ); - return () => { - throw new TypeError(deprecationMessage); - }; - } - function createWarningDeprecation(name, errorAfter, since, message) { - let hasWrittenDeprecation = false; - return () => { - if (enableDeprecationWarnings && !hasWrittenDeprecation) { - Debug.log.warn(formatDeprecationMessage( - name, - /*error*/ - false, - errorAfter, - since, - message - )); - hasWrittenDeprecation = true; - } - }; - } - function createDeprecation(name, options = {}) { - const version2 = typeof options.typeScriptVersion === "string" ? new Version(options.typeScriptVersion) : options.typeScriptVersion ?? getTypeScriptVersion(); - const errorAfter = typeof options.errorAfter === "string" ? new Version(options.errorAfter) : options.errorAfter; - const warnAfter = typeof options.warnAfter === "string" ? new Version(options.warnAfter) : options.warnAfter; - const since = typeof options.since === "string" ? new Version(options.since) : options.since ?? warnAfter; - const error = options.error || errorAfter && version2.compareTo(errorAfter) >= 0; - const warn = !warnAfter || version2.compareTo(warnAfter) >= 0; - return error ? createErrorDeprecation(name, errorAfter, since, options.message) : warn ? createWarningDeprecation(name, errorAfter, since, options.message) : noop; - } - function wrapFunction(deprecation, func) { - return function() { - deprecation(); - return func.apply(this, arguments); - }; - } - function deprecate(func, options) { - const deprecation = createDeprecation((options == null ? void 0 : options.name) ?? Debug.getFunctionName(func), options); - return wrapFunction(deprecation, func); - } - var enableDeprecationWarnings, typeScriptVersion2; - var init_deprecate = __esm({ - "src/deprecatedCompat/deprecate.ts"() { - "use strict"; - init_ts5(); - enableDeprecationWarnings = true; - } - }); - - // src/deprecatedCompat/deprecations.ts - function createOverload(name, overloads, binder2, deprecations) { - Object.defineProperty(call, "name", { ...Object.getOwnPropertyDescriptor(call, "name"), value: name }); - if (deprecations) { - for (const key of Object.keys(deprecations)) { - const index = +key; - if (!isNaN(index) && hasProperty(overloads, `${index}`)) { - overloads[index] = deprecate(overloads[index], { ...deprecations[index], name }); - } - } - } - const bind = createBinder2(overloads, binder2); - return call; - function call(...args) { - const index = bind(args); - const fn = index !== void 0 ? overloads[index] : void 0; - if (typeof fn === "function") { - return fn(...args); - } - throw new TypeError("Invalid arguments"); - } - } - function createBinder2(overloads, binder2) { - return (args) => { - for (let i = 0; hasProperty(overloads, `${i}`) && hasProperty(binder2, `${i}`); i++) { - const fn = binder2[i]; - if (fn(args)) { - return i; - } - } - }; - } - function buildOverload(name) { - return { - overload: (overloads) => ({ - bind: (binder2) => ({ - finish: () => createOverload(name, overloads, binder2), - deprecate: (deprecations) => ({ - finish: () => createOverload(name, overloads, binder2, deprecations) - }) - }) - }) - }; - } - var init_deprecations = __esm({ - "src/deprecatedCompat/deprecations.ts"() { - "use strict"; + init_ts4(); init_ts5(); - init_deprecate(); + init_ts_server3(); } }); - // src/deprecatedCompat/5.0/identifierProperties.ts - var init_identifierProperties = __esm({ - "src/deprecatedCompat/5.0/identifierProperties.ts"() { - "use strict"; - init_ts5(); - init_deprecate(); - addObjectAllocatorPatcher((objectAllocator2) => { - const Identifier74 = objectAllocator2.getIdentifierConstructor(); - if (!hasProperty(Identifier74.prototype, "originalKeywordKind")) { - Object.defineProperty(Identifier74.prototype, "originalKeywordKind", { - get: deprecate(function() { - return identifierToKeywordKind(this); - }, { - name: "originalKeywordKind", - since: "5.0", - warnAfter: "5.1", - errorAfter: "5.2", - message: "Use 'identifierToKeywordKind(identifier)' instead." - }) - }); - } - if (!hasProperty(Identifier74.prototype, "isInJSDocNamespace")) { - Object.defineProperty(Identifier74.prototype, "isInJSDocNamespace", { - get: deprecate(function() { - return this.flags & 2048 /* IdentifierIsInJSDocNamespace */ ? true : void 0; - }, { - name: "isInJSDocNamespace", - since: "5.0", - warnAfter: "5.1", - errorAfter: "5.2", - message: "Use '.parent' or the surrounding context to determine this instead." - }) - }); - } - }); - } + // src/typescript/_namespaces/ts.server.ts + var ts_server_exports4 = {}; + __export(ts_server_exports4, { + ActionInvalidate: () => ActionInvalidate, + ActionPackageInstalled: () => ActionPackageInstalled, + ActionSet: () => ActionSet, + ActionWatchTypingLocations: () => ActionWatchTypingLocations, + Arguments: () => Arguments, + AutoImportProviderProject: () => AutoImportProviderProject, + AuxiliaryProject: () => AuxiliaryProject, + CharRangeSection: () => CharRangeSection, + CloseFileWatcherEvent: () => CloseFileWatcherEvent, + CommandNames: () => CommandNames, + ConfigFileDiagEvent: () => ConfigFileDiagEvent, + ConfiguredProject: () => ConfiguredProject2, + CreateDirectoryWatcherEvent: () => CreateDirectoryWatcherEvent, + CreateFileWatcherEvent: () => CreateFileWatcherEvent, + Errors: () => Errors, + EventBeginInstallTypes: () => EventBeginInstallTypes, + EventEndInstallTypes: () => EventEndInstallTypes, + EventInitializationFailed: () => EventInitializationFailed, + EventTypesRegistry: () => EventTypesRegistry, + ExternalProject: () => ExternalProject2, + GcTimer: () => GcTimer, + InferredProject: () => InferredProject2, + LargeFileReferencedEvent: () => LargeFileReferencedEvent, + LineIndex: () => LineIndex, + LineLeaf: () => LineLeaf, + LineNode: () => LineNode, + LogLevel: () => LogLevel2, + Msg: () => Msg, + OpenFileInfoTelemetryEvent: () => OpenFileInfoTelemetryEvent, + Project: () => Project3, + ProjectInfoTelemetryEvent: () => ProjectInfoTelemetryEvent, + ProjectKind: () => ProjectKind, + ProjectLanguageServiceStateEvent: () => ProjectLanguageServiceStateEvent, + ProjectLoadingFinishEvent: () => ProjectLoadingFinishEvent, + ProjectLoadingStartEvent: () => ProjectLoadingStartEvent, + ProjectReferenceProjectLoadKind: () => ProjectReferenceProjectLoadKind, + ProjectService: () => ProjectService3, + ProjectsUpdatedInBackgroundEvent: () => ProjectsUpdatedInBackgroundEvent, + ScriptInfo: () => ScriptInfo, + ScriptVersionCache: () => ScriptVersionCache, + Session: () => Session3, + TextStorage: () => TextStorage, + ThrottledOperations: () => ThrottledOperations, + TypingsCache: () => TypingsCache, + allFilesAreJsOrDts: () => allFilesAreJsOrDts, + allRootFilesAreJsOrDts: () => allRootFilesAreJsOrDts, + asNormalizedPath: () => asNormalizedPath, + convertCompilerOptions: () => convertCompilerOptions, + convertFormatOptions: () => convertFormatOptions, + convertScriptKindName: () => convertScriptKindName, + convertTypeAcquisition: () => convertTypeAcquisition, + convertUserPreferences: () => convertUserPreferences, + convertWatchOptions: () => convertWatchOptions, + countEachFileTypes: () => countEachFileTypes, + createInstallTypingsRequest: () => createInstallTypingsRequest, + createModuleSpecifierCache: () => createModuleSpecifierCache, + createNormalizedPathMap: () => createNormalizedPathMap, + createPackageJsonCache: () => createPackageJsonCache, + createSortedArray: () => createSortedArray2, + emptyArray: () => emptyArray2, + findArgument: () => findArgument, + forEachResolvedProjectReferenceProject: () => forEachResolvedProjectReferenceProject, + formatDiagnosticToProtocol: () => formatDiagnosticToProtocol, + formatMessage: () => formatMessage2, + getBaseConfigFileName: () => getBaseConfigFileName, + getLocationInNewDocument: () => getLocationInNewDocument, + hasArgument: () => hasArgument, + hasNoTypeScriptSource: () => hasNoTypeScriptSource, + indent: () => indent2, + isBackgroundProject: () => isBackgroundProject, + isConfigFile: () => isConfigFile, + isConfiguredProject: () => isConfiguredProject, + isDynamicFileName: () => isDynamicFileName, + isExternalProject: () => isExternalProject, + isInferredProject: () => isInferredProject, + isInferredProjectName: () => isInferredProjectName, + makeAutoImportProviderProjectName: () => makeAutoImportProviderProjectName, + makeAuxiliaryProjectName: () => makeAuxiliaryProjectName, + makeInferredProjectName: () => makeInferredProjectName, + maxFileSize: () => maxFileSize, + maxProgramSizeForNonTsFiles: () => maxProgramSizeForNonTsFiles, + normalizedPathToPath: () => normalizedPathToPath, + nowString: () => nowString, + nullCancellationToken: () => nullCancellationToken, + nullTypingsInstaller: () => nullTypingsInstaller, + projectContainsInfoDirectly: () => projectContainsInfoDirectly, + protocol: () => ts_server_protocol_exports, + removeSorted: () => removeSorted, + stringifyIndented: () => stringifyIndented, + toEvent: () => toEvent, + toNormalizedPath: () => toNormalizedPath, + tryConvertScriptKindName: () => tryConvertScriptKindName, + typingsInstaller: () => ts_server_typingsInstaller_exports, + updateProjectIfDirty: () => updateProjectIfDirty }); - - // src/deprecatedCompat/_namespaces/ts.ts - var init_ts5 = __esm({ - "src/deprecatedCompat/_namespaces/ts.ts"() { + var init_ts_server4 = __esm({ + "src/typescript/_namespaces/ts.server.ts"() { "use strict"; - init_ts2(); - init_deprecations(); - init_identifierProperties(); + init_ts_server(); + init_ts_server3(); } }); // src/typescript/_namespaces/ts.ts - var ts_exports2 = {}; - __export(ts_exports2, { + var ts_exports3 = {}; + __export(ts_exports3, { ANONYMOUS: () => ANONYMOUS, AccessFlags: () => AccessFlags, AssertionLevel: () => AssertionLevel, @@ -268449,9 +268152,8 @@ ${options.prefix}` : "\n" : options.prefix CompletionInfoFlags: () => CompletionInfoFlags, CompletionTriggerKind: () => CompletionTriggerKind, Completions: () => ts_Completions_exports, - ConfigFileProgramReloadLevel: () => ConfigFileProgramReloadLevel, + ContainerFlags: () => ContainerFlags, ContextFlags: () => ContextFlags, - CoreServicesShimHostAdapter: () => CoreServicesShimHostAdapter, Debug: () => Debug, DiagnosticCategory: () => DiagnosticCategory, Diagnostics: () => Diagnostics, @@ -268479,6 +268181,8 @@ ${options.prefix}` : "\n" : options.prefix GetLiteralTextFlags: () => GetLiteralTextFlags, GoToDefinition: () => ts_GoToDefinition_exports, HighlightSpanKind: () => HighlightSpanKind, + IdentifierNameMap: () => IdentifierNameMap, + IdentifierNameMultiMap: () => IdentifierNameMultiMap, ImportKind: () => ImportKind, ImportsNotUsedAsValues: () => ImportsNotUsedAsValues, IndentStyle: () => IndentStyle, @@ -268491,13 +268195,13 @@ ${options.prefix}` : "\n" : options.prefix InternalEmitFlags: () => InternalEmitFlags, InternalSymbolName: () => InternalSymbolName, InvalidatedProjectKind: () => InvalidatedProjectKind, + JSDocParsingMode: () => JSDocParsingMode, JsDoc: () => ts_JsDoc_exports, JsTyping: () => ts_JsTyping_exports, JsxEmit: () => JsxEmit, JsxFlags: () => JsxFlags, JsxReferenceKind: () => JsxReferenceKind, LanguageServiceMode: () => LanguageServiceMode, - LanguageServiceShimHostAdapter: () => LanguageServiceShimHostAdapter, LanguageVariant: () => LanguageVariant, LexicalEnvironmentFlags: () => LexicalEnvironmentFlags, ListFormat: () => ListFormat, @@ -268534,6 +268238,7 @@ ${options.prefix}` : "\n" : options.prefix PragmaKindFlags: () => PragmaKindFlags, PrivateIdentifierKind: () => PrivateIdentifierKind, ProcessLevel: () => ProcessLevel, + ProgramUpdateLevel: () => ProgramUpdateLevel, QuotePreference: () => QuotePreference, RelationComparisonResult: () => RelationComparisonResult, Rename: () => ts_Rename_exports, @@ -268571,7 +268276,6 @@ ${options.prefix}` : "\n" : options.prefix TypeMapKind: () => TypeMapKind, TypePredicateKind: () => TypePredicateKind, TypeReferenceSerializationKind: () => TypeReferenceSerializationKind, - TypeScriptServicesFactory: () => TypeScriptServicesFactory, UnionReduction: () => UnionReduction, UpToDateStatusType: () => UpToDateStatusType, VarianceFlags: () => VarianceFlags, @@ -268583,6 +268287,7 @@ ${options.prefix}` : "\n" : options.prefix WatchLogLevel: () => WatchLogLevel, WatchType: () => WatchType, accessPrivateIdentifier: () => accessPrivateIdentifier, + addDisposableResourceHelper: () => addDisposableResourceHelper, addEmitFlags: () => addEmitFlags, addEmitHelper: () => addEmitHelper, addEmitHelpers: () => addEmitHelpers, @@ -268662,6 +268367,9 @@ ${options.prefix}` : "\n" : options.prefix changesAffectingProgramStructure: () => changesAffectingProgramStructure, childIsDecorated: () => childIsDecorated, classElementOrClassElementParameterIsDecorated: () => classElementOrClassElementParameterIsDecorated, + classHasClassThisAssignment: () => classHasClassThisAssignment, + classHasDeclaredOrExplicitlyAssignedName: () => classHasDeclaredOrExplicitlyAssignedName, + classHasExplicitlyAssignedName: () => classHasExplicitlyAssignedName, classOrConstructorParameterIsDecorated: () => classOrConstructorParameterIsDecorated, classPrivateFieldGetHelper: () => classPrivateFieldGetHelper, classPrivateFieldInHelper: () => classPrivateFieldInHelper, @@ -268759,6 +268467,8 @@ ${options.prefix}` : "\n" : options.prefix createCacheWithRedirects: () => createCacheWithRedirects, createCacheableExportInfoMap: () => createCacheableExportInfoMap, createCachedDirectoryStructureHost: () => createCachedDirectoryStructureHost, + createClassNamedEvaluationHelperBlock: () => createClassNamedEvaluationHelperBlock, + createClassThisAssignmentBlock: () => createClassThisAssignmentBlock, createClassifier: () => createClassifier, createCommentDirectivesMap: () => createCommentDirectivesMap, createCompilerDiagnostic: () => createCompilerDiagnostic, @@ -268812,6 +268522,7 @@ ${options.prefix}` : "\n" : options.prefix createModuleNotFoundChain: () => createModuleNotFoundChain, createModuleResolutionCache: () => createModuleResolutionCache, createModuleResolutionLoader: () => createModuleResolutionLoader, + createModuleResolutionLoaderUsingGlobalCache: () => createModuleResolutionLoaderUsingGlobalCache, createModuleSpecifierResolutionHost: () => createModuleSpecifierResolutionHost, createMultiMap: () => createMultiMap, createNodeConverters: () => createNodeConverters, @@ -268891,6 +268602,7 @@ ${options.prefix}` : "\n" : options.prefix displayPart: () => displayPart, displayPartsToString: () => displayPartsToString, disposeEmitNodes: () => disposeEmitNodes, + disposeResourcesHelper: () => disposeResourcesHelper, documentSpansEqual: () => documentSpansEqual, dumpTracingLegend: () => dumpTracingLegend, elementAt: () => elementAt, @@ -268968,7 +268680,7 @@ ${options.prefix}` : "\n" : options.prefix findPackageJsons: () => findPackageJsons, findPrecedingMatchingToken: () => findPrecedingMatchingToken, findPrecedingToken: () => findPrecedingToken, - findSuperStatementIndex: () => findSuperStatementIndex, + findSuperStatementIndexPath: () => findSuperStatementIndexPath, findTokenOnLeftOfPosition: () => findTokenOnLeftOfPosition, findUseStrictPrologue: () => findUseStrictPrologue, first: () => first, @@ -269043,6 +268755,7 @@ ${options.prefix}` : "\n" : options.prefix getAreDeclarationMapsEnabled: () => getAreDeclarationMapsEnabled, getAssignedExpandoInitializer: () => getAssignedExpandoInitializer, getAssignedName: () => getAssignedName, + getAssignedNameOfIdentifier: () => getAssignedNameOfIdentifier, getAssignmentDeclarationKind: () => getAssignmentDeclarationKind, getAssignmentDeclarationPropertyAccessKind: () => getAssignmentDeclarationPropertyAccessKind, getAssignmentTargetKind: () => getAssignmentTargetKind, @@ -269070,8 +268783,10 @@ ${options.prefix}` : "\n" : options.prefix getConditions: () => getConditions, getConfigFileParsingDiagnostics: () => getConfigFileParsingDiagnostics, getConstantValue: () => getConstantValue, + getContainerFlags: () => getContainerFlags, getContainerNode: () => getContainerNode, getContainingClass: () => getContainingClass, + getContainingClassExcludingClassDecorators: () => getContainingClassExcludingClassDecorators, getContainingClassStaticBlock: () => getContainingClassStaticBlock, getContainingFunction: () => getContainingFunction, getContainingFunctionDeclaration: () => getContainingFunctionDeclaration, @@ -269129,7 +268844,9 @@ ${options.prefix}` : "\n" : options.prefix getEmitModuleKind: () => getEmitModuleKind, getEmitModuleResolutionKind: () => getEmitModuleResolutionKind, getEmitScriptTarget: () => getEmitScriptTarget, + getEmitStandardClassFields: () => getEmitStandardClassFields, getEnclosingBlockScopeContainer: () => getEnclosingBlockScopeContainer, + getEnclosingContainer: () => getEnclosingContainer, getEncodedSemanticClassifications: () => getEncodedSemanticClassifications, getEncodedSyntacticClassifications: () => getEncodedSyntacticClassifications, getEndLinePosition: () => getEndLinePosition, @@ -269234,6 +268951,7 @@ ${options.prefix}` : "\n" : options.prefix getLeadingCommentRangesOfNode: () => getLeadingCommentRangesOfNode, getLeftmostAccessExpression: () => getLeftmostAccessExpression, getLeftmostExpression: () => getLeftmostExpression, + getLibraryNameFromLibFileName: () => getLibraryNameFromLibFileName, getLineAndCharacterOfPosition: () => getLineAndCharacterOfPosition, getLineInfo: () => getLineInfo, getLineOfLocalPosition: () => getLineOfLocalPosition, @@ -269347,6 +269065,7 @@ ${options.prefix}` : "\n" : options.prefix getPropertyAssignmentAliasLikeExpression: () => getPropertyAssignmentAliasLikeExpression, getPropertyNameForPropertyNameNode: () => getPropertyNameForPropertyNameNode, getPropertyNameForUniqueESSymbol: () => getPropertyNameForUniqueESSymbol, + getPropertyNameFromType: () => getPropertyNameFromType, getPropertyNameOfBindingOrAssignmentElement: () => getPropertyNameOfBindingOrAssignmentElement, getPropertySymbolFromBindingElement: () => getPropertySymbolFromBindingElement, getPropertySymbolsFromContextualType: () => getPropertySymbolsFromContextualType, @@ -269364,13 +269083,11 @@ ${options.prefix}` : "\n" : options.prefix getRenameLocation: () => getRenameLocation, getReplacementSpanForContextToken: () => getReplacementSpanForContextToken, getResolutionDiagnostic: () => getResolutionDiagnostic, - getResolutionModeOverrideForClause: () => getResolutionModeOverrideForClause, + getResolutionModeOverride: () => getResolutionModeOverride, getResolveJsonModule: () => getResolveJsonModule, getResolvePackageJsonExports: () => getResolvePackageJsonExports, getResolvePackageJsonImports: () => getResolvePackageJsonImports, getResolvedExternalModuleName: () => getResolvedExternalModuleName, - getResolvedModule: () => getResolvedModule, - getResolvedTypeReferenceDirective: () => getResolvedTypeReferenceDirective, getRestIndicatorOfBindingOrAssignmentElement: () => getRestIndicatorOfBindingOrAssignmentElement, getRestParameterElementType: () => getRestParameterElementType, getRightMostAssignedExpression: () => getRightMostAssignedExpression, @@ -269498,6 +269215,7 @@ ${options.prefix}` : "\n" : options.prefix hasPropertyAccessExpressionWithName: () => hasPropertyAccessExpressionWithName, hasQuestionToken: () => hasQuestionToken, hasRecordedExternalHelpers: () => hasRecordedExternalHelpers, + hasResolutionModeOverride: () => hasResolutionModeOverride, hasRestParameter: () => hasRestParameter, hasScopeMarker: () => hasScopeMarker, hasStaticModifier: () => hasStaticModifier, @@ -269527,6 +269245,8 @@ ${options.prefix}` : "\n" : options.prefix indexOfNode: () => indexOfNode, indicesOf: () => indicesOf, inferredTypesContainingFile: () => inferredTypesContainingFile, + injectClassNamedEvaluationHelperBlockIfMissing: () => injectClassNamedEvaluationHelperBlockIfMissing, + injectClassThisAssignmentIfMissing: () => injectClassThisAssignmentIfMissing, insertImports: () => insertImports, insertLeadingStatement: () => insertLeadingStatement, insertSorted: () => insertSorted, @@ -269569,7 +269289,6 @@ ${options.prefix}` : "\n" : options.prefix isAssertClause: () => isAssertClause, isAssertEntry: () => isAssertEntry, isAssertionExpression: () => isAssertionExpression, - isAssertionKey: () => isAssertionKey, isAssertsKeyword: () => isAssertsKeyword, isAssignmentDeclaration: () => isAssignmentDeclaration, isAssignmentExpression: () => isAssignmentExpression, @@ -269610,6 +269329,7 @@ ${options.prefix}` : "\n" : options.prefix isCallExpression: () => isCallExpression, isCallExpressionTarget: () => isCallExpressionTarget, isCallLikeExpression: () => isCallLikeExpression, + isCallLikeOrFunctionLikeExpression: () => isCallLikeOrFunctionLikeExpression, isCallOrNewExpression: () => isCallOrNewExpression, isCallOrNewExpressionTarget: () => isCallOrNewExpressionTarget, isCallSignatureDeclaration: () => isCallSignatureDeclaration, @@ -269627,10 +269347,13 @@ ${options.prefix}` : "\n" : options.prefix isClassDeclaration: () => isClassDeclaration, isClassElement: () => isClassElement, isClassExpression: () => isClassExpression, + isClassInstanceProperty: () => isClassInstanceProperty, isClassLike: () => isClassLike, isClassMemberModifier: () => isClassMemberModifier, + isClassNamedEvaluationHelperBlock: () => isClassNamedEvaluationHelperBlock, isClassOrTypeElement: () => isClassOrTypeElement, isClassStaticBlockDeclaration: () => isClassStaticBlockDeclaration, + isClassThisAssignmentBlock: () => isClassThisAssignmentBlock, isCollapsedRange: () => isCollapsedRange, isColonToken: () => isColonToken, isCommaExpression: () => isCommaExpression, @@ -269676,6 +269399,7 @@ ${options.prefix}` : "\n" : options.prefix isDiagnosticWithLocation: () => isDiagnosticWithLocation, isDiskPathRoot: () => isDiskPathRoot, isDoStatement: () => isDoStatement, + isDocumentRegistryEntry: () => isDocumentRegistryEntry, isDotDotDotToken: () => isDotDotDotToken, isDottedName: () => isDottedName, isDynamicName: () => isDynamicName, @@ -269702,6 +269426,7 @@ ${options.prefix}` : "\n" : options.prefix isExclamationToken: () => isExclamationToken, isExcludedFile: () => isExcludedFile, isExclusivelyTypeOnlyImportOrExport: () => isExclusivelyTypeOnlyImportOrExport, + isExpandoPropertyDeclaration: () => isExpandoPropertyDeclaration, isExportAssignment: () => isExportAssignment, isExportDeclaration: () => isExportDeclaration, isExportModifier: () => isExportModifier, @@ -269726,6 +269451,7 @@ ${options.prefix}` : "\n" : options.prefix isExternalModuleReference: () => isExternalModuleReference, isExternalModuleSymbol: () => isExternalModuleSymbol, isExternalOrCommonJsModule: () => isExternalOrCommonJsModule, + isFileLevelReservedGeneratedIdentifier: () => isFileLevelReservedGeneratedIdentifier, isFileLevelUniqueName: () => isFileLevelUniqueName, isFileProbablyExternalModule: () => isFileProbablyExternalModule, isFirstDeclarationOfSymbolParameter: () => isFirstDeclarationOfSymbolParameter, @@ -269772,6 +269498,9 @@ ${options.prefix}` : "\n" : options.prefix isIfStatement: () => isIfStatement, isIgnoredFileFromWildCardWatching: () => isIgnoredFileFromWildCardWatching, isImplicitGlob: () => isImplicitGlob, + isImportAttribute: () => isImportAttribute, + isImportAttributeName: () => isImportAttributeName, + isImportAttributes: () => isImportAttributes, isImportCall: () => isImportCall, isImportClause: () => isImportClause, isImportDeclaration: () => isImportDeclaration, @@ -269785,6 +269514,7 @@ ${options.prefix}` : "\n" : options.prefix isImportTypeNode: () => isImportTypeNode, isImportableFile: () => isImportableFile, isInComment: () => isInComment, + isInCompoundLikeAssignment: () => isInCompoundLikeAssignment, isInExpressionContext: () => isInExpressionContext, isInJSDoc: () => isInJSDoc, isInJSFile: () => isInJSFile, @@ -269796,6 +269526,7 @@ ${options.prefix}` : "\n" : options.prefix isInString: () => isInString, isInTemplateString: () => isInTemplateString, isInTopLevelContext: () => isInTopLevelContext, + isInTypeQuery: () => isInTypeQuery, isIncrementalCompilation: () => isIncrementalCompilation, isIndexSignatureDeclaration: () => isIndexSignatureDeclaration, isIndexedAccessTypeNode: () => isIndexedAccessTypeNode, @@ -269807,6 +269538,7 @@ ${options.prefix}` : "\n" : options.prefix isInsideJsxElementOrAttribute: () => isInsideJsxElementOrAttribute, isInsideNodeModules: () => isInsideNodeModules, isInsideTemplateLiteral: () => isInsideTemplateLiteral, + isInstanceOfExpression: () => isInstanceOfExpression, isInstantiatedModule: () => isInstantiatedModule, isInterfaceDeclaration: () => isInterfaceDeclaration, isInternalDeclaration: () => isInternalDeclaration, @@ -269961,7 +269693,6 @@ ${options.prefix}` : "\n" : options.prefix isNamespaceReexportDeclaration: () => isNamespaceReexportDeclaration, isNewExpression: () => isNewExpression, isNewExpressionTarget: () => isNewExpressionTarget, - isNightly: () => isNightly, isNoSubstitutionTemplateLiteral: () => isNoSubstitutionTemplateLiteral, isNode: () => isNode, isNodeArray: () => isNodeArray, @@ -270065,6 +269796,7 @@ ${options.prefix}` : "\n" : options.prefix isReturnStatement: () => isReturnStatement, isReturnStatementWithFixablePromiseHandler: () => isReturnStatementWithFixablePromiseHandler, isRightSideOfAccessExpression: () => isRightSideOfAccessExpression, + isRightSideOfInstanceofExpression: () => isRightSideOfInstanceofExpression, isRightSideOfPropertyAccess: () => isRightSideOfPropertyAccess, isRightSideOfQualifiedName: () => isRightSideOfQualifiedName, isRightSideOfQualifiedNameOrPropertyAccess: () => isRightSideOfQualifiedNameOrPropertyAccess, @@ -270077,6 +269809,7 @@ ${options.prefix}` : "\n" : options.prefix isSetAccessor: () => isSetAccessor, isSetAccessorDeclaration: () => isSetAccessorDeclaration, isShebangTrivia: () => isShebangTrivia, + isShiftOperatorOrHigher: () => isShiftOperatorOrHigher, isShorthandAmbientModuleSymbol: () => isShorthandAmbientModuleSymbol, isShorthandPropertyAssignment: () => isShorthandPropertyAssignment, isSignedNumericLiteral: () => isSignedNumericLiteral, @@ -270173,6 +269906,7 @@ ${options.prefix}` : "\n" : options.prefix isTypeQueryNode: () => isTypeQueryNode, isTypeReferenceNode: () => isTypeReferenceNode, isTypeReferenceType: () => isTypeReferenceType, + isTypeUsableAsPropertyName: () => isTypeUsableAsPropertyName, isUMDExportSymbol: () => isUMDExportSymbol, isUnaryExpression: () => isUnaryExpression, isUnaryExpressionWithWrite: () => isUnaryExpressionWithWrite, @@ -270187,7 +269921,9 @@ ${options.prefix}` : "\n" : options.prefix isValidESSymbolDeclaration: () => isValidESSymbolDeclaration, isValidTypeOnlyAliasUseSite: () => isValidTypeOnlyAliasUseSite, isValueSignatureDeclaration: () => isValueSignatureDeclaration, + isVarAwaitUsing: () => isVarAwaitUsing, isVarConst: () => isVarConst, + isVarUsing: () => isVarUsing, isVariableDeclaration: () => isVariableDeclaration, isVariableDeclarationInVariableStatement: () => isVariableDeclarationInVariableStatement, isVariableDeclarationInitializedToBareOrAccessedRequire: () => isVariableDeclarationInitializedToBareOrAccessedRequire, @@ -270312,8 +270048,6 @@ ${options.prefix}` : "\n" : options.prefix outFile: () => outFile, packageIdToPackageName: () => packageIdToPackageName, packageIdToString: () => packageIdToString, - padLeft: () => padLeft, - padRight: () => padRight, paramHelper: () => paramHelper, parameterIsThisKeyword: () => parameterIsThisKeyword, parameterNamePart: () => parameterNamePart, @@ -270387,7 +270121,6 @@ ${options.prefix}` : "\n" : options.prefix readJson: () => readJson, readJsonConfigFile: () => readJsonConfigFile, readJsonOrUndefined: () => readJsonOrUndefined, - realizeDiagnostics: () => realizeDiagnostics, reduceEachLeadingCommentRange: () => reduceEachLeadingCommentRange, reduceEachTrailingCommentRange: () => reduceEachTrailingCommentRange, reduceLeft: () => reduceLeft, @@ -270436,7 +270169,7 @@ ${options.prefix}` : "\n" : options.prefix screenStartingMessageCodes: () => screenStartingMessageCodes, semanticDiagnosticsOptionDeclarations: () => semanticDiagnosticsOptionDeclarations, serializeCompilerOptions: () => serializeCompilerOptions, - server: () => ts_server_exports, + server: () => ts_server_exports4, servicesVersion: () => servicesVersion, setCommentRange: () => setCommentRange, setConfigFileInOptions: () => setConfigFileInOptions, @@ -270457,8 +270190,6 @@ ${options.prefix}` : "\n" : options.prefix setParent: () => setParent, setParentRecursive: () => setParentRecursive, setPrivateIdentifier: () => setPrivateIdentifier, - setResolvedModule: () => setResolvedModule, - setResolvedTypeReferenceDirective: () => setResolvedTypeReferenceDirective, setSnippetElement: () => setSnippetElement, setSourceMapRange: () => setSourceMapRange, setStackTraceLimit: () => setStackTraceLimit, @@ -270520,7 +270251,6 @@ ${options.prefix}` : "\n" : options.prefix startsWithDirectory: () => startsWithDirectory, startsWithUnderscore: () => startsWithUnderscore, startsWithUseStrict: () => startsWithUseStrict, - stringContains: () => stringContains, stringContainsAt: () => stringContainsAt, stringToToken: () => stringToToken, stripQuotes: () => stripQuotes, @@ -270599,6 +270329,7 @@ ${options.prefix}` : "\n" : options.prefix transformJsx: () => transformJsx, transformLegacyDecorators: () => transformLegacyDecorators, transformModule: () => transformModule, + transformNamedEvaluation: () => transformNamedEvaluation, transformNodeModule: () => transformNodeModule, transformNodes: () => transformNodes, transformSystemModule: () => transformSystemModule, @@ -270606,9 +270337,6 @@ ${options.prefix}` : "\n" : options.prefix transpile: () => transpile, transpileModule: () => transpileModule, transpileOptionValueCompilerOptions: () => transpileOptionValueCompilerOptions, - trimString: () => trimString, - trimStringEnd: () => trimStringEnd, - trimStringStart: () => trimStringStart, tryAddToSet: () => tryAddToSet, tryAndIgnoreErrors: () => tryAndIgnoreErrors, tryCast: () => tryCast, @@ -270688,2568 +270416,14470 @@ ${options.prefix}` : "\n" : options.prefix writeCommentRange: () => writeCommentRange, writeFile: () => writeFile, writeFileEnsuringDirectories: () => writeFileEnsuringDirectories, - zipToModeAwareCache: () => zipToModeAwareCache, zipWith: () => zipWith }); - var init_ts6 = __esm({ + var init_ts8 = __esm({ "src/typescript/_namespaces/ts.ts"() { "use strict"; init_ts2(); init_ts3(); init_ts4(); - init_ts5(); + init_ts7(); + init_ts_server4(); + } + }); + + // src/typescript/typescript.ts + var require_typescript = __commonJS({ + "src/typescript/typescript.ts"(exports, module2) { + init_ts8(); + init_ts8(); + if (typeof console !== "undefined") { + Debug.loggingHost = { + log(level, s) { + switch (level) { + case 1 /* Error */: + return console.error(s); + case 2 /* Warning */: + return console.warn(s); + case 3 /* Info */: + return console.log(s); + case 4 /* Verbose */: + return console.log(s); + } + } + }; + } + module2.exports = ts_exports3; + } + }); + return require_typescript(); +})(); + +if ( true && module.exports) { module.exports = ts; } +//# sourceMappingURL=typescript.js.map + + +/***/ }), + +/***/ 63931: +/***/ ((__unused_webpack_module, exports) => { + +"use strict"; + + +exports.fromCallback = function (fn) { + return Object.defineProperty(function (...args) { + if (typeof args[args.length - 1] === 'function') fn.apply(this, args) + else { + return new Promise((resolve, reject) => { + fn.call( + this, + ...args, + (err, res) => (err != null) ? reject(err) : resolve(res) + ) + }) + } + }, 'name', { value: fn.name }) +} + +exports.fromPromise = function (fn) { + return Object.defineProperty(function (...args) { + const cb = args[args.length - 1] + if (typeof cb !== 'function') return fn.apply(this, args) + else fn.apply(this, args.slice(0, -1)).then(r => cb(null, r), cb) + }, 'name', { value: fn.name }) +} + + +/***/ }), + +/***/ 96083: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + + +/** + * For Node.js, simply re-export the core `util.deprecate` function. + */ + +module.exports = __nccwpck_require__(73837).deprecate; + + +/***/ }), + +/***/ 37515: +/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { + +"use strict"; + + +Object.defineProperty(exports, "__esModule", ({ + value: true +})); +Object.defineProperty(exports, "v1", ({ + enumerable: true, + get: function () { + return _v.default; + } +})); +Object.defineProperty(exports, "v3", ({ + enumerable: true, + get: function () { + return _v2.default; + } +})); +Object.defineProperty(exports, "v4", ({ + enumerable: true, + get: function () { + return _v3.default; + } +})); +Object.defineProperty(exports, "v5", ({ + enumerable: true, + get: function () { + return _v4.default; + } +})); +Object.defineProperty(exports, "NIL", ({ + enumerable: true, + get: function () { + return _nil.default; + } +})); +Object.defineProperty(exports, "version", ({ + enumerable: true, + get: function () { + return _version.default; + } +})); +Object.defineProperty(exports, "validate", ({ + enumerable: true, + get: function () { + return _validate.default; + } +})); +Object.defineProperty(exports, "stringify", ({ + enumerable: true, + get: function () { + return _stringify.default; + } +})); +Object.defineProperty(exports, "parse", ({ + enumerable: true, + get: function () { + return _parse.default; + } +})); + +var _v = _interopRequireDefault(__nccwpck_require__(57635)); + +var _v2 = _interopRequireDefault(__nccwpck_require__(82839)); + +var _v3 = _interopRequireDefault(__nccwpck_require__(83189)); + +var _v4 = _interopRequireDefault(__nccwpck_require__(9798)); + +var _nil = _interopRequireDefault(__nccwpck_require__(33017)); + +var _version = _interopRequireDefault(__nccwpck_require__(92450)); + +var _validate = _interopRequireDefault(__nccwpck_require__(8021)); + +var _stringify = _interopRequireDefault(__nccwpck_require__(83377)); + +var _parse = _interopRequireDefault(__nccwpck_require__(41810)); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/***/ }), + +/***/ 11923: +/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { + +"use strict"; + + +Object.defineProperty(exports, "__esModule", ({ + value: true +})); +exports["default"] = void 0; + +var _crypto = _interopRequireDefault(__nccwpck_require__(6113)); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +function md5(bytes) { + if (Array.isArray(bytes)) { + bytes = Buffer.from(bytes); + } else if (typeof bytes === 'string') { + bytes = Buffer.from(bytes, 'utf8'); + } + + return _crypto.default.createHash('md5').update(bytes).digest(); +} + +var _default = md5; +exports["default"] = _default; + +/***/ }), + +/***/ 33017: +/***/ ((__unused_webpack_module, exports) => { + +"use strict"; + + +Object.defineProperty(exports, "__esModule", ({ + value: true +})); +exports["default"] = void 0; +var _default = '00000000-0000-0000-0000-000000000000'; +exports["default"] = _default; + +/***/ }), + +/***/ 41810: +/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { + +"use strict"; + + +Object.defineProperty(exports, "__esModule", ({ + value: true +})); +exports["default"] = void 0; + +var _validate = _interopRequireDefault(__nccwpck_require__(8021)); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +function parse(uuid) { + if (!(0, _validate.default)(uuid)) { + throw TypeError('Invalid UUID'); + } + + let v; + const arr = new Uint8Array(16); // Parse ########-....-....-....-............ + + arr[0] = (v = parseInt(uuid.slice(0, 8), 16)) >>> 24; + arr[1] = v >>> 16 & 0xff; + arr[2] = v >>> 8 & 0xff; + arr[3] = v & 0xff; // Parse ........-####-....-....-............ + + arr[4] = (v = parseInt(uuid.slice(9, 13), 16)) >>> 8; + arr[5] = v & 0xff; // Parse ........-....-####-....-............ + + arr[6] = (v = parseInt(uuid.slice(14, 18), 16)) >>> 8; + arr[7] = v & 0xff; // Parse ........-....-....-####-............ + + arr[8] = (v = parseInt(uuid.slice(19, 23), 16)) >>> 8; + arr[9] = v & 0xff; // Parse ........-....-....-....-############ + // (Use "/" to avoid 32-bit truncation when bit-shifting high-order bytes) + + arr[10] = (v = parseInt(uuid.slice(24, 36), 16)) / 0x10000000000 & 0xff; + arr[11] = v / 0x100000000 & 0xff; + arr[12] = v >>> 24 & 0xff; + arr[13] = v >>> 16 & 0xff; + arr[14] = v >>> 8 & 0xff; + arr[15] = v & 0xff; + return arr; +} + +var _default = parse; +exports["default"] = _default; + +/***/ }), + +/***/ 44818: +/***/ ((__unused_webpack_module, exports) => { + +"use strict"; + + +Object.defineProperty(exports, "__esModule", ({ + value: true +})); +exports["default"] = void 0; +var _default = /^(?:[0-9a-f]{8}-[0-9a-f]{4}-[1-5][0-9a-f]{3}-[89ab][0-9a-f]{3}-[0-9a-f]{12}|00000000-0000-0000-0000-000000000000)$/i; +exports["default"] = _default; + +/***/ }), + +/***/ 76983: +/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { + +"use strict"; + + +Object.defineProperty(exports, "__esModule", ({ + value: true +})); +exports["default"] = rng; + +var _crypto = _interopRequireDefault(__nccwpck_require__(6113)); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +const rnds8Pool = new Uint8Array(256); // # of random values to pre-allocate + +let poolPtr = rnds8Pool.length; + +function rng() { + if (poolPtr > rnds8Pool.length - 16) { + _crypto.default.randomFillSync(rnds8Pool); + + poolPtr = 0; + } + + return rnds8Pool.slice(poolPtr, poolPtr += 16); +} + +/***/ }), + +/***/ 41033: +/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { + +"use strict"; + + +Object.defineProperty(exports, "__esModule", ({ + value: true +})); +exports["default"] = void 0; + +var _crypto = _interopRequireDefault(__nccwpck_require__(6113)); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +function sha1(bytes) { + if (Array.isArray(bytes)) { + bytes = Buffer.from(bytes); + } else if (typeof bytes === 'string') { + bytes = Buffer.from(bytes, 'utf8'); + } + + return _crypto.default.createHash('sha1').update(bytes).digest(); +} + +var _default = sha1; +exports["default"] = _default; + +/***/ }), + +/***/ 83377: +/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { + +"use strict"; + + +Object.defineProperty(exports, "__esModule", ({ + value: true +})); +exports["default"] = void 0; + +var _validate = _interopRequireDefault(__nccwpck_require__(8021)); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * Convert array of 16 byte values to UUID string format of the form: + * XXXXXXXX-XXXX-XXXX-XXXX-XXXXXXXXXXXX + */ +const byteToHex = []; + +for (let i = 0; i < 256; ++i) { + byteToHex.push((i + 0x100).toString(16).substr(1)); +} + +function stringify(arr, offset = 0) { + // Note: Be careful editing this code! It's been tuned for performance + // and works in ways you may not expect. See https://github.com/uuidjs/uuid/pull/434 + const uuid = (byteToHex[arr[offset + 0]] + byteToHex[arr[offset + 1]] + byteToHex[arr[offset + 2]] + byteToHex[arr[offset + 3]] + '-' + byteToHex[arr[offset + 4]] + byteToHex[arr[offset + 5]] + '-' + byteToHex[arr[offset + 6]] + byteToHex[arr[offset + 7]] + '-' + byteToHex[arr[offset + 8]] + byteToHex[arr[offset + 9]] + '-' + byteToHex[arr[offset + 10]] + byteToHex[arr[offset + 11]] + byteToHex[arr[offset + 12]] + byteToHex[arr[offset + 13]] + byteToHex[arr[offset + 14]] + byteToHex[arr[offset + 15]]).toLowerCase(); // Consistency check for valid UUID. If this throws, it's likely due to one + // of the following: + // - One or more input array values don't map to a hex octet (leading to + // "undefined" in the uuid) + // - Invalid input values for the RFC `version` or `variant` fields + + if (!(0, _validate.default)(uuid)) { + throw TypeError('Stringified UUID is invalid'); + } + + return uuid; +} + +var _default = stringify; +exports["default"] = _default; + +/***/ }), + +/***/ 57635: +/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { + +"use strict"; + + +Object.defineProperty(exports, "__esModule", ({ + value: true +})); +exports["default"] = void 0; + +var _rng = _interopRequireDefault(__nccwpck_require__(76983)); + +var _stringify = _interopRequireDefault(__nccwpck_require__(83377)); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +// **`v1()` - Generate time-based UUID** +// +// Inspired by https://github.com/LiosK/UUID.js +// and http://docs.python.org/library/uuid.html +let _nodeId; + +let _clockseq; // Previous uuid creation time + + +let _lastMSecs = 0; +let _lastNSecs = 0; // See https://github.com/uuidjs/uuid for API details + +function v1(options, buf, offset) { + let i = buf && offset || 0; + const b = buf || new Array(16); + options = options || {}; + let node = options.node || _nodeId; + let clockseq = options.clockseq !== undefined ? options.clockseq : _clockseq; // node and clockseq need to be initialized to random values if they're not + // specified. We do this lazily to minimize issues related to insufficient + // system entropy. See #189 + + if (node == null || clockseq == null) { + const seedBytes = options.random || (options.rng || _rng.default)(); + + if (node == null) { + // Per 4.5, create and 48-bit node id, (47 random bits + multicast bit = 1) + node = _nodeId = [seedBytes[0] | 0x01, seedBytes[1], seedBytes[2], seedBytes[3], seedBytes[4], seedBytes[5]]; + } + + if (clockseq == null) { + // Per 4.2.2, randomize (14 bit) clockseq + clockseq = _clockseq = (seedBytes[6] << 8 | seedBytes[7]) & 0x3fff; + } + } // UUID timestamps are 100 nano-second units since the Gregorian epoch, + // (1582-10-15 00:00). JSNumbers aren't precise enough for this, so + // time is handled internally as 'msecs' (integer milliseconds) and 'nsecs' + // (100-nanoseconds offset from msecs) since unix epoch, 1970-01-01 00:00. + + + let msecs = options.msecs !== undefined ? options.msecs : Date.now(); // Per 4.2.1.2, use count of uuid's generated during the current clock + // cycle to simulate higher resolution clock + + let nsecs = options.nsecs !== undefined ? options.nsecs : _lastNSecs + 1; // Time since last uuid creation (in msecs) + + const dt = msecs - _lastMSecs + (nsecs - _lastNSecs) / 10000; // Per 4.2.1.2, Bump clockseq on clock regression + + if (dt < 0 && options.clockseq === undefined) { + clockseq = clockseq + 1 & 0x3fff; + } // Reset nsecs if clock regresses (new clockseq) or we've moved onto a new + // time interval + + + if ((dt < 0 || msecs > _lastMSecs) && options.nsecs === undefined) { + nsecs = 0; + } // Per 4.2.1.2 Throw error if too many uuids are requested + + + if (nsecs >= 10000) { + throw new Error("uuid.v1(): Can't create more than 10M uuids/sec"); + } + + _lastMSecs = msecs; + _lastNSecs = nsecs; + _clockseq = clockseq; // Per 4.1.4 - Convert from unix epoch to Gregorian epoch + + msecs += 12219292800000; // `time_low` + + const tl = ((msecs & 0xfffffff) * 10000 + nsecs) % 0x100000000; + b[i++] = tl >>> 24 & 0xff; + b[i++] = tl >>> 16 & 0xff; + b[i++] = tl >>> 8 & 0xff; + b[i++] = tl & 0xff; // `time_mid` + + const tmh = msecs / 0x100000000 * 10000 & 0xfffffff; + b[i++] = tmh >>> 8 & 0xff; + b[i++] = tmh & 0xff; // `time_high_and_version` + + b[i++] = tmh >>> 24 & 0xf | 0x10; // include version + + b[i++] = tmh >>> 16 & 0xff; // `clock_seq_hi_and_reserved` (Per 4.2.2 - include variant) + + b[i++] = clockseq >>> 8 | 0x80; // `clock_seq_low` + + b[i++] = clockseq & 0xff; // `node` + + for (let n = 0; n < 6; ++n) { + b[i + n] = node[n]; + } + + return buf || (0, _stringify.default)(b); +} + +var _default = v1; +exports["default"] = _default; + +/***/ }), + +/***/ 82839: +/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { + +"use strict"; + + +Object.defineProperty(exports, "__esModule", ({ + value: true +})); +exports["default"] = void 0; + +var _v = _interopRequireDefault(__nccwpck_require__(43127)); + +var _md = _interopRequireDefault(__nccwpck_require__(11923)); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +const v3 = (0, _v.default)('v3', 0x30, _md.default); +var _default = v3; +exports["default"] = _default; + +/***/ }), + +/***/ 43127: +/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { + +"use strict"; + + +Object.defineProperty(exports, "__esModule", ({ + value: true +})); +exports["default"] = _default; +exports.URL = exports.DNS = void 0; + +var _stringify = _interopRequireDefault(__nccwpck_require__(83377)); + +var _parse = _interopRequireDefault(__nccwpck_require__(41810)); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +function stringToBytes(str) { + str = unescape(encodeURIComponent(str)); // UTF8 escape + + const bytes = []; + + for (let i = 0; i < str.length; ++i) { + bytes.push(str.charCodeAt(i)); + } + + return bytes; +} + +const DNS = '6ba7b810-9dad-11d1-80b4-00c04fd430c8'; +exports.DNS = DNS; +const URL = '6ba7b811-9dad-11d1-80b4-00c04fd430c8'; +exports.URL = URL; + +function _default(name, version, hashfunc) { + function generateUUID(value, namespace, buf, offset) { + if (typeof value === 'string') { + value = stringToBytes(value); + } + + if (typeof namespace === 'string') { + namespace = (0, _parse.default)(namespace); + } + + if (namespace.length !== 16) { + throw TypeError('Namespace must be array-like (16 iterable integer values, 0-255)'); + } // Compute hash of namespace and value, Per 4.3 + // Future: Use spread syntax when supported on all platforms, e.g. `bytes = + // hashfunc([...namespace, ... value])` + + + let bytes = new Uint8Array(16 + value.length); + bytes.set(namespace); + bytes.set(value, namespace.length); + bytes = hashfunc(bytes); + bytes[6] = bytes[6] & 0x0f | version; + bytes[8] = bytes[8] & 0x3f | 0x80; + + if (buf) { + offset = offset || 0; + + for (let i = 0; i < 16; ++i) { + buf[offset + i] = bytes[i]; + } + + return buf; + } + + return (0, _stringify.default)(bytes); + } // Function#name is not settable on some platforms (#270) + + + try { + generateUUID.name = name; // eslint-disable-next-line no-empty + } catch (err) {} // For CommonJS default export support + + + generateUUID.DNS = DNS; + generateUUID.URL = URL; + return generateUUID; +} + +/***/ }), + +/***/ 83189: +/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { + +"use strict"; + + +Object.defineProperty(exports, "__esModule", ({ + value: true +})); +exports["default"] = void 0; + +var _rng = _interopRequireDefault(__nccwpck_require__(76983)); + +var _stringify = _interopRequireDefault(__nccwpck_require__(83377)); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +function v4(options, buf, offset) { + options = options || {}; + + const rnds = options.random || (options.rng || _rng.default)(); // Per 4.4, set bits for version and `clock_seq_hi_and_reserved` + + + rnds[6] = rnds[6] & 0x0f | 0x40; + rnds[8] = rnds[8] & 0x3f | 0x80; // Copy bytes to buffer, if provided + + if (buf) { + offset = offset || 0; + + for (let i = 0; i < 16; ++i) { + buf[offset + i] = rnds[i]; + } + + return buf; + } + + return (0, _stringify.default)(rnds); +} + +var _default = v4; +exports["default"] = _default; + +/***/ }), + +/***/ 9798: +/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { + +"use strict"; + + +Object.defineProperty(exports, "__esModule", ({ + value: true +})); +exports["default"] = void 0; + +var _v = _interopRequireDefault(__nccwpck_require__(43127)); + +var _sha = _interopRequireDefault(__nccwpck_require__(41033)); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +const v5 = (0, _v.default)('v5', 0x50, _sha.default); +var _default = v5; +exports["default"] = _default; + +/***/ }), + +/***/ 8021: +/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { + +"use strict"; + + +Object.defineProperty(exports, "__esModule", ({ + value: true +})); +exports["default"] = void 0; + +var _regex = _interopRequireDefault(__nccwpck_require__(44818)); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +function validate(uuid) { + return typeof uuid === 'string' && _regex.default.test(uuid); +} + +var _default = validate; +exports["default"] = _default; + +/***/ }), + +/***/ 92450: +/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { + +"use strict"; + + +Object.defineProperty(exports, "__esModule", ({ + value: true +})); +exports["default"] = void 0; + +var _validate = _interopRequireDefault(__nccwpck_require__(8021)); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +function version(uuid) { + if (!(0, _validate.default)(uuid)) { + throw TypeError('Invalid UUID'); + } + + return parseInt(uuid.substr(14, 1), 16); +} + +var _default = version; +exports["default"] = _default; + +/***/ }), + +/***/ 26669: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + +"use strict"; + + +const Module = __nccwpck_require__(98188); +const crypto = __nccwpck_require__(6113); +const fs = __nccwpck_require__(57147); +const path = __nccwpck_require__(71017); +const vm = __nccwpck_require__(26144); +const os = __nccwpck_require__(22037); + +const hasOwnProperty = Object.prototype.hasOwnProperty; + +//------------------------------------------------------------------------------ +// FileSystemBlobStore +//------------------------------------------------------------------------------ + +class FileSystemBlobStore { + constructor(directory, prefix) { + const name = prefix ? slashEscape(prefix + '.') : ''; + this._blobFilename = path.join(directory, name + 'BLOB'); + this._mapFilename = path.join(directory, name + 'MAP'); + this._lockFilename = path.join(directory, name + 'LOCK'); + this._directory = directory; + this._load(); + } + + has(key, invalidationKey) { + if (hasOwnProperty.call(this._memoryBlobs, key)) { + return this._invalidationKeys[key] === invalidationKey; + } else if (hasOwnProperty.call(this._storedMap, key)) { + return this._storedMap[key][0] === invalidationKey; + } + return false; + } + + get(key, invalidationKey) { + if (hasOwnProperty.call(this._memoryBlobs, key)) { + if (this._invalidationKeys[key] === invalidationKey) { + return this._memoryBlobs[key]; + } + } else if (hasOwnProperty.call(this._storedMap, key)) { + const mapping = this._storedMap[key]; + if (mapping[0] === invalidationKey) { + return this._storedBlob.slice(mapping[1], mapping[2]); + } + } + } + + set(key, invalidationKey, buffer) { + this._invalidationKeys[key] = invalidationKey; + this._memoryBlobs[key] = buffer; + this._dirty = true; + } + + delete(key) { + if (hasOwnProperty.call(this._memoryBlobs, key)) { + this._dirty = true; + delete this._memoryBlobs[key]; + } + if (hasOwnProperty.call(this._invalidationKeys, key)) { + this._dirty = true; + delete this._invalidationKeys[key]; + } + if (hasOwnProperty.call(this._storedMap, key)) { + this._dirty = true; + delete this._storedMap[key]; + } + } + + isDirty() { + return this._dirty; + } + + save() { + const dump = this._getDump(); + const blobToStore = Buffer.concat(dump[0]); + const mapToStore = JSON.stringify(dump[1]); + + try { + mkdirpSync(this._directory); + fs.writeFileSync(this._lockFilename, 'LOCK', {flag: 'wx'}); + } catch (error) { + // Swallow the exception if we fail to acquire the lock. + return false; + } + + try { + fs.writeFileSync(this._blobFilename, blobToStore); + fs.writeFileSync(this._mapFilename, mapToStore); + } finally { + fs.unlinkSync(this._lockFilename); + } + + return true; + } + + _load() { + try { + this._storedBlob = fs.readFileSync(this._blobFilename); + this._storedMap = JSON.parse(fs.readFileSync(this._mapFilename)); + } catch (e) { + this._storedBlob = Buffer.alloc(0); + this._storedMap = {}; + } + this._dirty = false; + this._memoryBlobs = {}; + this._invalidationKeys = {}; + } + + _getDump() { + const buffers = []; + const newMap = {}; + let offset = 0; + + function push(key, invalidationKey, buffer) { + buffers.push(buffer); + newMap[key] = [invalidationKey, offset, offset + buffer.length]; + offset += buffer.length; + } + + for (const key of Object.keys(this._memoryBlobs)) { + const buffer = this._memoryBlobs[key]; + const invalidationKey = this._invalidationKeys[key]; + push(key, invalidationKey, buffer); + } + + for (const key of Object.keys(this._storedMap)) { + if (hasOwnProperty.call(newMap, key)) continue; + const mapping = this._storedMap[key]; + const buffer = this._storedBlob.slice(mapping[1], mapping[2]); + push(key, mapping[0], buffer); + } + + return [buffers, newMap]; + } +} + +//------------------------------------------------------------------------------ +// NativeCompileCache +//------------------------------------------------------------------------------ + +class NativeCompileCache { + constructor() { + this._cacheStore = null; + this._previousModuleCompile = null; + } + + setCacheStore(cacheStore) { + this._cacheStore = cacheStore; + } + + install() { + const self = this; + const hasRequireResolvePaths = typeof require.resolve.paths === 'function'; + this._previousModuleCompile = Module.prototype._compile; + Module.prototype._compile = this._ownModuleCompile = _ownModuleCompile; + self.enabled = true; + function _ownModuleCompile(content, filename) { + if(!self.enabled) return this._previousModuleCompile.apply(this, arguments); + const mod = this; + + function require(id) { + return mod.require(id); + } + + // https://github.com/nodejs/node/blob/v10.15.3/lib/internal/modules/cjs/helpers.js#L28 + function resolve(request, options) { + return Module._resolveFilename(request, mod, false, options); + } + require.resolve = resolve; + + // https://github.com/nodejs/node/blob/v10.15.3/lib/internal/modules/cjs/helpers.js#L37 + // resolve.resolve.paths was added in v8.9.0 + if (hasRequireResolvePaths) { + resolve.paths = function paths(request) { + return Module._resolveLookupPaths(request, mod, true); + }; + } + + require.main = process.mainModule; + + // Enable support to add extra extension types + require.extensions = Module._extensions; + require.cache = Module._cache; + + const dirname = path.dirname(filename); + + const compiledWrapper = self._moduleCompile(filename, content); + + // We skip the debugger setup because by the time we run, node has already + // done that itself. + + // `Buffer` is included for Electron. + // See https://github.com/zertosh/v8-compile-cache/pull/10#issuecomment-518042543 + const args = [mod.exports, require, mod, filename, dirname, process, global, Buffer]; + return compiledWrapper.apply(mod.exports, args); + } + } + + uninstall() { + this.enabled = false; + // If something else has since been installed on top of us, we cannot overwrite it. + if(Module.prototype._compile === this._ownModuleCompile) { + Module.prototype._compile = this._previousModuleCompile; + } + } + + _moduleCompile(filename, content) { + // https://github.com/nodejs/node/blob/v7.5.0/lib/module.js#L511 + + // Remove shebang + var contLen = content.length; + if (contLen >= 2) { + if (content.charCodeAt(0) === 35/*#*/ && + content.charCodeAt(1) === 33/*!*/) { + if (contLen === 2) { + // Exact match + content = ''; + } else { + // Find end of shebang line and slice it off + var i = 2; + for (; i < contLen; ++i) { + var code = content.charCodeAt(i); + if (code === 10/*\n*/ || code === 13/*\r*/) break; + } + if (i === contLen) { + content = ''; + } else { + // Note that this actually includes the newline character(s) in the + // new output. This duplicates the behavior of the regular + // expression that was previously used to replace the shebang line + content = content.slice(i); + } + } + } + } + + // create wrapper function + var wrapper = Module.wrap(content); + + var invalidationKey = crypto + .createHash('sha1') + .update(content, 'utf8') + .digest('hex'); + + var buffer = this._cacheStore.get(filename, invalidationKey); + + var script = new vm.Script(wrapper, { + filename: filename, + lineOffset: 0, + displayErrors: true, + cachedData: buffer, + produceCachedData: true, + }); + + if (script.cachedDataProduced) { + this._cacheStore.set(filename, invalidationKey, script.cachedData); + } else if (script.cachedDataRejected) { + this._cacheStore.delete(filename); + } + + var compiledWrapper = script.runInThisContext({ + filename: filename, + lineOffset: 0, + columnOffset: 0, + displayErrors: true, + }); + + return compiledWrapper; + } +} + +//------------------------------------------------------------------------------ +// utilities +// +// https://github.com/substack/node-mkdirp/blob/f2003bb/index.js#L55-L98 +// https://github.com/zertosh/slash-escape/blob/e7ebb99/slash-escape.js +//------------------------------------------------------------------------------ + +function mkdirpSync(p_) { + _mkdirpSync(path.resolve(p_), 0o777); +} + +function _mkdirpSync(p, mode) { + try { + fs.mkdirSync(p, mode); + } catch (err0) { + if (err0.code === 'ENOENT') { + _mkdirpSync(path.dirname(p)); + _mkdirpSync(p); + } else { + try { + const stat = fs.statSync(p); + if (!stat.isDirectory()) { throw err0; } + } catch (err1) { + throw err0; + } + } + } +} + +function slashEscape(str) { + const ESCAPE_LOOKUP = { + '\\': 'zB', + ':': 'zC', + '/': 'zS', + '\x00': 'z0', + 'z': 'zZ', + }; + const ESCAPE_REGEX = /[\\:/\x00z]/g; // eslint-disable-line no-control-regex + return str.replace(ESCAPE_REGEX, match => ESCAPE_LOOKUP[match]); +} + +function supportsCachedData() { + const script = new vm.Script('""', {produceCachedData: true}); + // chakracore, as of v1.7.1.0, returns `false`. + return script.cachedDataProduced === true; +} + +function getCacheDir() { + const v8_compile_cache_cache_dir = process.env.V8_COMPILE_CACHE_CACHE_DIR; + if (v8_compile_cache_cache_dir) { + return v8_compile_cache_cache_dir; + } + + // Avoid cache ownership issues on POSIX systems. + const dirname = typeof process.getuid === 'function' + ? 'v8-compile-cache-' + process.getuid() + : 'v8-compile-cache'; + const version = typeof process.versions.v8 === 'string' + ? process.versions.v8 + : typeof process.versions.chakracore === 'string' + ? 'chakracore-' + process.versions.chakracore + : 'node-' + process.version; + const cacheDir = path.join(os.tmpdir(), dirname, version); + return cacheDir; +} + +function getMainName() { + // `require.main.filename` is undefined or null when: + // * node -e 'require("v8-compile-cache")' + // * node -r 'v8-compile-cache' + // * Or, requiring from the REPL. + const mainName = require.main && typeof require.main.filename === 'string' + ? require.main.filename + : process.cwd(); + return mainName; +} + +function install(opts) { + if (!process.env.DISABLE_V8_COMPILE_CACHE && supportsCachedData()) { + if(typeof opts === 'undefined') opts = {} + let cacheDir = opts.cacheDir + if(typeof cacheDir === 'undefined') cacheDir = getCacheDir(); + let prefix = opts.prefix + if(typeof prefix === 'undefined') prefix = getMainName(); + const blobStore = new FileSystemBlobStore(cacheDir, prefix); + + const nativeCompileCache = new NativeCompileCache(); + nativeCompileCache.setCacheStore(blobStore); + nativeCompileCache.install(); + + let uninstalled = false; + const uninstall = () => { + if(uninstalled) return; + uninstalled = true; + process.removeListener('exit', uninstall); + if (blobStore.isDirty()) { + blobStore.save(); + } + nativeCompileCache.uninstall(); + } + process.once('exit', uninstall); + return {uninstall}; + } +} + +//------------------------------------------------------------------------------ +// main +//------------------------------------------------------------------------------ + +module.exports.install = install; + +module.exports.__TEST__ = { + FileSystemBlobStore, + NativeCompileCache, + mkdirpSync, + slashEscape, + supportsCachedData, + getCacheDir, + getMainName, +}; + + +/***/ }), + +/***/ 65173: +/***/ ((module) => { + +// Returns a wrapper function that returns a wrapped callback +// The wrapper function should do some stuff, and return a +// presumably different callback function. +// This makes sure that own properties are retained, so that +// decorations and such are not lost along the way. +module.exports = wrappy +function wrappy (fn, cb) { + if (fn && cb) return wrappy(fn)(cb) + + if (typeof fn !== 'function') + throw new TypeError('need wrapper function') + + Object.keys(fn).forEach(function (k) { + wrapper[k] = fn[k] + }) + + return wrapper + + function wrapper() { + var args = new Array(arguments.length) + for (var i = 0; i < args.length; i++) { + args[i] = arguments[i] + } + var ret = fn.apply(this, args) + var cb = args[args.length-1] + if (typeof ret === 'function' && ret !== cb) { + Object.keys(cb).forEach(function (k) { + ret[k] = cb[k] + }) + } + return ret + } +} + + +/***/ }), + +/***/ 89222: +/***/ ((module) => { + +"use strict"; + +module.exports = function (Yallist) { + Yallist.prototype[Symbol.iterator] = function* () { + for (let walker = this.head; walker; walker = walker.next) { + yield walker.value + } + } +} + + +/***/ }), + +/***/ 83278: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + +"use strict"; + +module.exports = Yallist + +Yallist.Node = Node +Yallist.create = Yallist + +function Yallist (list) { + var self = this + if (!(self instanceof Yallist)) { + self = new Yallist() + } + + self.tail = null + self.head = null + self.length = 0 + + if (list && typeof list.forEach === 'function') { + list.forEach(function (item) { + self.push(item) + }) + } else if (arguments.length > 0) { + for (var i = 0, l = arguments.length; i < l; i++) { + self.push(arguments[i]) + } + } + + return self +} + +Yallist.prototype.removeNode = function (node) { + if (node.list !== this) { + throw new Error('removing node which does not belong to this list') + } + + var next = node.next + var prev = node.prev + + if (next) { + next.prev = prev + } + + if (prev) { + prev.next = next + } + + if (node === this.head) { + this.head = next + } + if (node === this.tail) { + this.tail = prev + } + + node.list.length-- + node.next = null + node.prev = null + node.list = null + + return next +} + +Yallist.prototype.unshiftNode = function (node) { + if (node === this.head) { + return + } + + if (node.list) { + node.list.removeNode(node) + } + + var head = this.head + node.list = this + node.next = head + if (head) { + head.prev = node + } + + this.head = node + if (!this.tail) { + this.tail = node + } + this.length++ +} + +Yallist.prototype.pushNode = function (node) { + if (node === this.tail) { + return + } + + if (node.list) { + node.list.removeNode(node) + } + + var tail = this.tail + node.list = this + node.prev = tail + if (tail) { + tail.next = node + } + + this.tail = node + if (!this.head) { + this.head = node + } + this.length++ +} + +Yallist.prototype.push = function () { + for (var i = 0, l = arguments.length; i < l; i++) { + push(this, arguments[i]) + } + return this.length +} + +Yallist.prototype.unshift = function () { + for (var i = 0, l = arguments.length; i < l; i++) { + unshift(this, arguments[i]) + } + return this.length +} + +Yallist.prototype.pop = function () { + if (!this.tail) { + return undefined + } + + var res = this.tail.value + this.tail = this.tail.prev + if (this.tail) { + this.tail.next = null + } else { + this.head = null + } + this.length-- + return res +} + +Yallist.prototype.shift = function () { + if (!this.head) { + return undefined + } + + var res = this.head.value + this.head = this.head.next + if (this.head) { + this.head.prev = null + } else { + this.tail = null + } + this.length-- + return res +} + +Yallist.prototype.forEach = function (fn, thisp) { + thisp = thisp || this + for (var walker = this.head, i = 0; walker !== null; i++) { + fn.call(thisp, walker.value, i, this) + walker = walker.next + } +} + +Yallist.prototype.forEachReverse = function (fn, thisp) { + thisp = thisp || this + for (var walker = this.tail, i = this.length - 1; walker !== null; i--) { + fn.call(thisp, walker.value, i, this) + walker = walker.prev + } +} + +Yallist.prototype.get = function (n) { + for (var i = 0, walker = this.head; walker !== null && i < n; i++) { + // abort out of the list early if we hit a cycle + walker = walker.next + } + if (i === n && walker !== null) { + return walker.value + } +} + +Yallist.prototype.getReverse = function (n) { + for (var i = 0, walker = this.tail; walker !== null && i < n; i++) { + // abort out of the list early if we hit a cycle + walker = walker.prev + } + if (i === n && walker !== null) { + return walker.value + } +} + +Yallist.prototype.map = function (fn, thisp) { + thisp = thisp || this + var res = new Yallist() + for (var walker = this.head; walker !== null;) { + res.push(fn.call(thisp, walker.value, this)) + walker = walker.next + } + return res +} + +Yallist.prototype.mapReverse = function (fn, thisp) { + thisp = thisp || this + var res = new Yallist() + for (var walker = this.tail; walker !== null;) { + res.push(fn.call(thisp, walker.value, this)) + walker = walker.prev + } + return res +} + +Yallist.prototype.reduce = function (fn, initial) { + var acc + var walker = this.head + if (arguments.length > 1) { + acc = initial + } else if (this.head) { + walker = this.head.next + acc = this.head.value + } else { + throw new TypeError('Reduce of empty list with no initial value') + } + + for (var i = 0; walker !== null; i++) { + acc = fn(acc, walker.value, i) + walker = walker.next + } + + return acc +} + +Yallist.prototype.reduceReverse = function (fn, initial) { + var acc + var walker = this.tail + if (arguments.length > 1) { + acc = initial + } else if (this.tail) { + walker = this.tail.prev + acc = this.tail.value + } else { + throw new TypeError('Reduce of empty list with no initial value') + } + + for (var i = this.length - 1; walker !== null; i--) { + acc = fn(acc, walker.value, i) + walker = walker.prev + } + + return acc +} + +Yallist.prototype.toArray = function () { + var arr = new Array(this.length) + for (var i = 0, walker = this.head; walker !== null; i++) { + arr[i] = walker.value + walker = walker.next + } + return arr +} + +Yallist.prototype.toArrayReverse = function () { + var arr = new Array(this.length) + for (var i = 0, walker = this.tail; walker !== null; i++) { + arr[i] = walker.value + walker = walker.prev + } + return arr +} + +Yallist.prototype.slice = function (from, to) { + to = to || this.length + if (to < 0) { + to += this.length + } + from = from || 0 + if (from < 0) { + from += this.length + } + var ret = new Yallist() + if (to < from || to < 0) { + return ret + } + if (from < 0) { + from = 0 + } + if (to > this.length) { + to = this.length + } + for (var i = 0, walker = this.head; walker !== null && i < from; i++) { + walker = walker.next + } + for (; walker !== null && i < to; i++, walker = walker.next) { + ret.push(walker.value) + } + return ret +} + +Yallist.prototype.sliceReverse = function (from, to) { + to = to || this.length + if (to < 0) { + to += this.length + } + from = from || 0 + if (from < 0) { + from += this.length + } + var ret = new Yallist() + if (to < from || to < 0) { + return ret + } + if (from < 0) { + from = 0 + } + if (to > this.length) { + to = this.length + } + for (var i = this.length, walker = this.tail; walker !== null && i > to; i--) { + walker = walker.prev + } + for (; walker !== null && i > from; i--, walker = walker.prev) { + ret.push(walker.value) + } + return ret +} + +Yallist.prototype.splice = function (start, deleteCount, ...nodes) { + if (start > this.length) { + start = this.length - 1 + } + if (start < 0) { + start = this.length + start; + } + + for (var i = 0, walker = this.head; walker !== null && i < start; i++) { + walker = walker.next + } + + var ret = [] + for (var i = 0; walker && i < deleteCount; i++) { + ret.push(walker.value) + walker = this.removeNode(walker) + } + if (walker === null) { + walker = this.tail + } + + if (walker !== this.head && walker !== this.tail) { + walker = walker.prev + } + + for (var i = 0; i < nodes.length; i++) { + walker = insert(this, walker, nodes[i]) + } + return ret; +} + +Yallist.prototype.reverse = function () { + var head = this.head + var tail = this.tail + for (var walker = head; walker !== null; walker = walker.prev) { + var p = walker.prev + walker.prev = walker.next + walker.next = p + } + this.head = tail + this.tail = head + return this +} + +function insert (self, node, value) { + var inserted = node === self.head ? + new Node(value, null, node, self) : + new Node(value, node, node.next, self) + + if (inserted.next === null) { + self.tail = inserted + } + if (inserted.prev === null) { + self.head = inserted + } + + self.length++ + + return inserted +} + +function push (self, item) { + self.tail = new Node(item, self.tail, null, self) + if (!self.head) { + self.head = self.tail + } + self.length++ +} + +function unshift (self, item) { + self.head = new Node(item, null, self.head, self) + if (!self.tail) { + self.tail = self.head + } + self.length++ +} + +function Node (value, prev, next, list) { + if (!(this instanceof Node)) { + return new Node(value, prev, next, list) + } + + this.list = list + this.value = value + + if (prev) { + prev.next = this + this.prev = prev + } else { + this.prev = null + } + + if (next) { + next.prev = this + this.next = next + } else { + this.next = null + } +} + +try { + // add if support for Symbol.iterator is present + __nccwpck_require__(89222)(Yallist) +} catch (er) {} + + +/***/ }), + +/***/ 45001: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + +"use strict"; + +const lenient = __nccwpck_require__(88081); + +const yn = (input, options) => { + input = String(input).trim(); + + options = Object.assign({ + lenient: false, + default: null + }, options); + + if (options.default !== null && typeof options.default !== 'boolean') { + throw new TypeError(`Expected the \`default\` option to be of type \`boolean\`, got \`${typeof options.default}\``); + } + + if (/^(?:y|yes|true|1)$/i.test(input)) { + return true; + } + + if (/^(?:n|no|false|0)$/i.test(input)) { + return false; + } + + if (options.lenient === true) { + return lenient(input, options); + } + + return options.default; +}; + +module.exports = yn; +// TODO: Remove this for the next major release +module.exports["default"] = yn; + + +/***/ }), + +/***/ 88081: +/***/ ((module) => { + +"use strict"; + + +const YES_MATCH_SCORE_THRESHOLD = 2; +const NO_MATCH_SCORE_THRESHOLD = 1.25; + +const yMatch = new Map([ + [5, 0.25], + [6, 0.25], + [7, 0.25], + ['t', 0.75], + ['y', 1], + ['u', 0.75], + ['g', 0.25], + ['h', 0.25], + ['j', 0.25] +]); + +const eMatch = new Map([ + [2, 0.25], + [3, 0.25], + [4, 0.25], + ['w', 0.75], + ['e', 1], + ['r', 0.75], + ['s', 0.25], + ['d', 0.25], + ['f', 0.25] +]); + +const sMatch = new Map([ + ['q', 0.25], + ['w', 0.25], + ['e', 0.25], + ['a', 0.75], + ['s', 1], + ['d', 0.75], + ['z', 0.25], + ['x', 0.25], + ['c', 0.25] +]); + +const nMatch = new Map([ + ['h', 0.25], + ['j', 0.25], + ['k', 0.25], + ['b', 0.75], + ['n', 1], + ['m', 0.75] +]); + +const oMatch = new Map([ + [9, 0.25], + [0, 0.25], + ['i', 0.75], + ['o', 1], + ['p', 0.75], + ['k', 0.25], + ['l', 0.25] +]); + +function getYesMatchScore(value) { + const [y, e, s] = value; + let score = 0; + + if (yMatch.has(y)) { + score += yMatch.get(y); + } + + if (eMatch.has(e)) { + score += eMatch.get(e); + } + + if (sMatch.has(s)) { + score += sMatch.get(s); + } + + return score; +} + +function getNoMatchScore(value) { + const [n, o] = value; + let score = 0; + + if (nMatch.has(n)) { + score += nMatch.get(n); + } + + if (oMatch.has(o)) { + score += oMatch.get(o); + } + + return score; +} + +module.exports = (input, options) => { + if (getYesMatchScore(input) >= YES_MATCH_SCORE_THRESHOLD) { + return true; + } + + if (getNoMatchScore(input) >= NO_MATCH_SCORE_THRESHOLD) { + return false; + } + + return options.default; +}; + + +/***/ }), + +/***/ 11298: +/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { + +"use strict"; + +Object.defineProperty(exports, "__esModule", ({ value: true })); +exports.execCommand = exports.ChildProcess = void 0; +const tslib_1 = __nccwpck_require__(41464); +const child_process_1 = __nccwpck_require__(32081); +Object.defineProperty(exports, "ChildProcess", ({ enumerable: true, get: function () { return child_process_1.ChildProcess; } })); +const shell = tslib_1.__importStar(__nccwpck_require__(26877)); +const execCommand = (command, options = { + asString: false, + asJSON: false +}) => { + if (!options.silent) { + console.log('\nRunning: ', command); + } + const result = shell.exec(command, options); + if (options.asJSON) { + return JSON.parse(result.toString()); + } + if (options.asString) { + // eslint-disable-next-line @typescript-eslint/ban-ts-comment + // @ts-ignore + return result.toString(); + } + // eslint-disable-next-line @typescript-eslint/ban-ts-comment + // @ts-ignore + return { + success: result['code'] === 0, + output: result.stdout + }; +}; +exports.execCommand = execCommand; + + +/***/ }), + +/***/ 28328: +/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { + +"use strict"; + +Object.defineProperty(exports, "__esModule", ({ value: true })); +exports.hasOneOfRequiredTags = exports.cleanLogConditions = void 0; +const tslib_1 = __nccwpck_require__(41464); +const core = tslib_1.__importStar(__nccwpck_require__(44712)); +function hasTagMatchingCondition(condition, tags) { + if (condition.includes('=')) { + // If it includes a "," it's a AND condition + if (condition.includes(',')) { + const subConditions = condition.split(',').map((subCondition) => subCondition.trim()); + // It should match all the conditions + return subConditions.every((subCondition) => { + return hasTagMatchingCondition(subCondition, tags); + }); + } + if (condition.includes('!=')) { + const [conditionKey, conditionValue] = condition.split('!='); + const useTags = tags.filter((tag) => tag.startsWith(`${conditionKey}=`)); + // If the project does not have any tags with the condition key it's allowed + if (useTags.length === 0) { + return true; + } + return useTags.some((tag) => { + return tag.split('=').pop().trim() !== conditionValue.trim(); + }, []); + } + else { + const [conditionKey, conditionValue] = condition.split('='); + return tags.some((tag) => { + const [key, value] = tag.split('='); + if (conditionKey !== key) { + return false; + } + return conditionValue.trim() === value.trim(); + }); + } + } + else { + return tags.some((tag) => tag === condition); + } +} +function cleanLogConditions(conditions) { + return conditions.map((condition) => { + if (condition.includes(',')) { + return condition.split(',').map((subCondition) => subCondition.trim()) + .join(' AND '); + } + return condition; + }).join(' OR '); +} +exports.cleanLogConditions = cleanLogConditions; +function hasOneOfRequiredTags(projectName, tags, requiresOnOfTheseTagConditions) { + if (!requiresOnOfTheseTagConditions || requiresOnOfTheseTagConditions.length === 0) { + return true; + } + if (!tags || tags.length === 0) { + return false; + } + const hasMatch = requiresOnOfTheseTagConditions.some((condition) => hasTagMatchingCondition(condition, tags)); + if (!hasMatch) { + core.debug(`[${projectName}]: Does not match any of the provided condition "${cleanLogConditions(requiresOnOfTheseTagConditions)}"`); + } + return hasMatch; +} +exports.hasOneOfRequiredTags = hasOneOfRequiredTags; + + +/***/ }), + +/***/ 74067: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + +module.exports = require(__nccwpck_require__.ab + "nx.darwin-arm64.node") + +/***/ }), + +/***/ 67754: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + +module.exports = require(__nccwpck_require__.ab + "swc.darwin-arm64.node") + +/***/ }), + +/***/ 17377: +/***/ ((module) => { + +module.exports = eval("require")("./nx.android-arm-eabi.node"); + + +/***/ }), + +/***/ 35137: +/***/ ((module) => { + +module.exports = eval("require")("./nx.android-arm64.node"); + + +/***/ }), + +/***/ 46502: +/***/ ((module) => { + +module.exports = eval("require")("./nx.darwin-arm64.node"); + + +/***/ }), + +/***/ 52701: +/***/ ((module) => { + +module.exports = eval("require")("./nx.darwin-universal.node"); + + +/***/ }), + +/***/ 1322: +/***/ ((module) => { + +module.exports = eval("require")("./nx.darwin-x64.node"); + + +/***/ }), + +/***/ 35488: +/***/ ((module) => { + +module.exports = eval("require")("./nx.freebsd-x64.node"); + + +/***/ }), + +/***/ 56986: +/***/ ((module) => { + +module.exports = eval("require")("./nx.linux-arm-gnueabihf.node"); + + +/***/ }), + +/***/ 69480: +/***/ ((module) => { + +module.exports = eval("require")("./nx.linux-arm64-gnu.node"); + + +/***/ }), + +/***/ 76818: +/***/ ((module) => { + +module.exports = eval("require")("./nx.linux-arm64-musl.node"); + + +/***/ }), + +/***/ 37202: +/***/ ((module) => { + +module.exports = eval("require")("./nx.linux-x64-gnu.node"); + + +/***/ }), + +/***/ 76200: +/***/ ((module) => { + +module.exports = eval("require")("./nx.linux-x64-musl.node"); + + +/***/ }), + +/***/ 16320: +/***/ ((module) => { + +module.exports = eval("require")("./nx.win32-arm64-msvc.node"); + + +/***/ }), + +/***/ 33821: +/***/ ((module) => { + +module.exports = eval("require")("./nx.win32-ia32-msvc.node"); + + +/***/ }), + +/***/ 82472: +/***/ ((module) => { + +module.exports = eval("require")("./nx.win32-x64-msvc.node"); + + +/***/ }), + +/***/ 84384: +/***/ ((module) => { + +module.exports = eval("require")("./swc.android-arm-eabi.node"); + + +/***/ }), + +/***/ 27607: +/***/ ((module) => { + +module.exports = eval("require")("./swc.android-arm64.node"); + + +/***/ }), + +/***/ 23827: +/***/ ((module) => { + +module.exports = eval("require")("./swc.darwin-arm64.node"); + + +/***/ }), + +/***/ 29232: +/***/ ((module) => { + +module.exports = eval("require")("./swc.darwin-universal.node"); + + +/***/ }), + +/***/ 71110: +/***/ ((module) => { + +module.exports = eval("require")("./swc.darwin-x64.node"); + + +/***/ }), + +/***/ 96182: +/***/ ((module) => { + +module.exports = eval("require")("./swc.freebsd-x64.node"); + + +/***/ }), + +/***/ 10645: +/***/ ((module) => { + +module.exports = eval("require")("./swc.linux-arm-gnueabihf.node"); + + +/***/ }), + +/***/ 7458: +/***/ ((module) => { + +module.exports = eval("require")("./swc.linux-arm64-gnu.node"); + + +/***/ }), + +/***/ 52614: +/***/ ((module) => { + +module.exports = eval("require")("./swc.linux-arm64-musl.node"); + + +/***/ }), + +/***/ 79306: +/***/ ((module) => { + +module.exports = eval("require")("./swc.linux-riscv64-gnu.node"); + + +/***/ }), + +/***/ 899: +/***/ ((module) => { + +module.exports = eval("require")("./swc.linux-riscv64-musl.node"); + + +/***/ }), + +/***/ 93305: +/***/ ((module) => { + +module.exports = eval("require")("./swc.linux-x64-gnu.node"); + + +/***/ }), + +/***/ 76885: +/***/ ((module) => { + +module.exports = eval("require")("./swc.linux-x64-musl.node"); + + +/***/ }), + +/***/ 42395: +/***/ ((module) => { + +module.exports = eval("require")("./swc.win32-arm64-msvc.node"); + + +/***/ }), + +/***/ 56637: +/***/ ((module) => { + +module.exports = eval("require")("./swc.win32-ia32-msvc.node"); + + +/***/ }), + +/***/ 48865: +/***/ ((module) => { + +module.exports = eval("require")("./swc.win32-x64-msvc.node"); + + +/***/ }), + +/***/ 63582: +/***/ ((module) => { + +module.exports = eval("require")("@nx/nx-android-arm-eabi"); + + +/***/ }), + +/***/ 89581: +/***/ ((module) => { + +module.exports = eval("require")("@nx/nx-android-arm64"); + + +/***/ }), + +/***/ 18912: +/***/ ((module) => { + +module.exports = eval("require")("@nx/nx-darwin-universal"); + + +/***/ }), + +/***/ 59194: +/***/ ((module) => { + +module.exports = eval("require")("@nx/nx-darwin-x64"); + + +/***/ }), + +/***/ 63818: +/***/ ((module) => { + +module.exports = eval("require")("@nx/nx-freebsd-x64"); + + +/***/ }), + +/***/ 56362: +/***/ ((module) => { + +module.exports = eval("require")("@nx/nx-linux-arm-gnueabihf"); + + +/***/ }), + +/***/ 99909: +/***/ ((module) => { + +module.exports = eval("require")("@nx/nx-linux-arm64-gnu"); + + +/***/ }), + +/***/ 67629: +/***/ ((module) => { + +module.exports = eval("require")("@nx/nx-linux-arm64-musl"); + + +/***/ }), + +/***/ 91136: +/***/ ((module) => { + +module.exports = eval("require")("@nx/nx-linux-x64-gnu"); + + +/***/ }), + +/***/ 91817: +/***/ ((module) => { + +module.exports = eval("require")("@nx/nx-linux-x64-musl"); + + +/***/ }), + +/***/ 18146: +/***/ ((module) => { + +module.exports = eval("require")("@nx/nx-win32-arm64-msvc"); + + +/***/ }), + +/***/ 85420: +/***/ ((module) => { + +module.exports = eval("require")("@nx/nx-win32-ia32-msvc"); + + +/***/ }), + +/***/ 19959: +/***/ ((module) => { + +module.exports = eval("require")("@nx/nx-win32-x64-msvc"); + + +/***/ }), + +/***/ 89373: +/***/ ((module) => { + +module.exports = eval("require")("@nx/vue"); + + +/***/ }), + +/***/ 86670: +/***/ ((module) => { + +module.exports = eval("require")("@swc/core-android-arm-eabi"); + + +/***/ }), + +/***/ 73543: +/***/ ((module) => { + +module.exports = eval("require")("@swc/core-android-arm64"); + + +/***/ }), + +/***/ 66749: +/***/ ((module) => { + +module.exports = eval("require")("@swc/core-darwin-universal"); + + +/***/ }), + +/***/ 62659: +/***/ ((module) => { + +module.exports = eval("require")("@swc/core-darwin-x64"); + + +/***/ }), + +/***/ 26640: +/***/ ((module) => { + +module.exports = eval("require")("@swc/core-freebsd-x64"); + + +/***/ }), + +/***/ 19505: +/***/ ((module) => { + +module.exports = eval("require")("@swc/core-linux-arm-gnueabihf"); + + +/***/ }), + +/***/ 13520: +/***/ ((module) => { + +module.exports = eval("require")("@swc/core-linux-arm64-gnu"); + + +/***/ }), + +/***/ 93346: +/***/ ((module) => { + +module.exports = eval("require")("@swc/core-linux-arm64-musl"); + + +/***/ }), + +/***/ 32636: +/***/ ((module) => { + +module.exports = eval("require")("@swc/core-linux-riscv64-gnu"); + + +/***/ }), + +/***/ 81873: +/***/ ((module) => { + +module.exports = eval("require")("@swc/core-linux-riscv64-musl"); + + +/***/ }), + +/***/ 69653: +/***/ ((module) => { + +module.exports = eval("require")("@swc/core-linux-x64-gnu"); + + +/***/ }), + +/***/ 27110: +/***/ ((module) => { + +module.exports = eval("require")("@swc/core-linux-x64-musl"); + + +/***/ }), + +/***/ 7470: +/***/ ((module) => { + +module.exports = eval("require")("@swc/core-win32-arm64-msvc"); + + +/***/ }), + +/***/ 46924: +/***/ ((module) => { + +module.exports = eval("require")("@swc/core-win32-ia32-msvc"); + + +/***/ }), + +/***/ 66995: +/***/ ((module) => { + +module.exports = eval("require")("@swc/core-win32-x64-msvc"); + + +/***/ }), + +/***/ 7343: +/***/ ((module) => { + +module.exports = eval("require")("@swc/wasm"); + + +/***/ }), + +/***/ 72939: +/***/ ((module) => { + +function webpackEmptyContext(req) { + var e = new Error("Cannot find module '" + req + "'"); + e.code = 'MODULE_NOT_FOUND'; + throw e; +} +webpackEmptyContext.keys = () => ([]); +webpackEmptyContext.resolve = webpackEmptyContext; +webpackEmptyContext.id = 72939; +module.exports = webpackEmptyContext; + +/***/ }), + +/***/ 3833: +/***/ ((module) => { + +function webpackEmptyContext(req) { + var e = new Error("Cannot find module '" + req + "'"); + e.code = 'MODULE_NOT_FOUND'; + throw e; +} +webpackEmptyContext.keys = () => ([]); +webpackEmptyContext.resolve = webpackEmptyContext; +webpackEmptyContext.id = 3833; +module.exports = webpackEmptyContext; + +/***/ }), + +/***/ 39491: +/***/ ((module) => { + +"use strict"; +module.exports = require("assert"); + +/***/ }), + +/***/ 14300: +/***/ ((module) => { + +"use strict"; +module.exports = require("buffer"); + +/***/ }), + +/***/ 32081: +/***/ ((module) => { + +"use strict"; +module.exports = require("child_process"); + +/***/ }), + +/***/ 96206: +/***/ ((module) => { + +"use strict"; +module.exports = require("console"); + +/***/ }), + +/***/ 22057: +/***/ ((module) => { + +"use strict"; +module.exports = require("constants"); + +/***/ }), + +/***/ 6113: +/***/ ((module) => { + +"use strict"; +module.exports = require("crypto"); + +/***/ }), + +/***/ 82361: +/***/ ((module) => { + +"use strict"; +module.exports = require("events"); + +/***/ }), + +/***/ 57147: +/***/ ((module) => { + +"use strict"; +module.exports = require("fs"); + +/***/ }), + +/***/ 73292: +/***/ ((module) => { + +"use strict"; +module.exports = require("fs/promises"); + +/***/ }), + +/***/ 13685: +/***/ ((module) => { + +"use strict"; +module.exports = require("http"); + +/***/ }), + +/***/ 95687: +/***/ ((module) => { + +"use strict"; +module.exports = require("https"); + +/***/ }), + +/***/ 31405: +/***/ ((module) => { + +"use strict"; +module.exports = require("inspector"); + +/***/ }), + +/***/ 98188: +/***/ ((module) => { + +"use strict"; +module.exports = require("module"); + +/***/ }), + +/***/ 41808: +/***/ ((module) => { + +"use strict"; +module.exports = require("net"); + +/***/ }), + +/***/ 87561: +/***/ ((module) => { + +"use strict"; +module.exports = require("node:fs"); + +/***/ }), + +/***/ 82033: +/***/ ((module) => { + +"use strict"; +module.exports = require("node:module"); + +/***/ }), + +/***/ 49411: +/***/ ((module) => { + +"use strict"; +module.exports = require("node:path"); + +/***/ }), + +/***/ 41041: +/***/ ((module) => { + +"use strict"; +module.exports = require("node:url"); + +/***/ }), + +/***/ 22037: +/***/ ((module) => { + +"use strict"; +module.exports = require("os"); + +/***/ }), + +/***/ 71017: +/***/ ((module) => { + +"use strict"; +module.exports = require("path"); + +/***/ }), + +/***/ 4074: +/***/ ((module) => { + +"use strict"; +module.exports = require("perf_hooks"); + +/***/ }), + +/***/ 14521: +/***/ ((module) => { + +"use strict"; +module.exports = require("readline"); + +/***/ }), + +/***/ 38102: +/***/ ((module) => { + +"use strict"; +module.exports = require("repl"); + +/***/ }), + +/***/ 12781: +/***/ ((module) => { + +"use strict"; +module.exports = require("stream"); + +/***/ }), + +/***/ 71576: +/***/ ((module) => { + +"use strict"; +module.exports = require("string_decoder"); + +/***/ }), + +/***/ 24404: +/***/ ((module) => { + +"use strict"; +module.exports = require("tls"); + +/***/ }), + +/***/ 76224: +/***/ ((module) => { + +"use strict"; +module.exports = require("tty"); + +/***/ }), + +/***/ 57310: +/***/ ((module) => { + +"use strict"; +module.exports = require("url"); + +/***/ }), + +/***/ 73837: +/***/ ((module) => { + +"use strict"; +module.exports = require("util"); + +/***/ }), + +/***/ 26144: +/***/ ((module) => { + +"use strict"; +module.exports = require("vm"); + +/***/ }), + +/***/ 59796: +/***/ ((module) => { + +"use strict"; +module.exports = require("zlib"); + +/***/ }), + +/***/ 63305: +/***/ ((__unused_webpack_module, exports) => { + +"use strict"; + +Object.defineProperty(exports, "__esModule", ({ value: true })); +exports.assertValidPattern = void 0; +const MAX_PATTERN_LENGTH = 1024 * 64; +const assertValidPattern = (pattern) => { + if (typeof pattern !== 'string') { + throw new TypeError('invalid pattern'); + } + if (pattern.length > MAX_PATTERN_LENGTH) { + throw new TypeError('pattern is too long'); + } +}; +exports.assertValidPattern = assertValidPattern; +//# sourceMappingURL=assert-valid-pattern.js.map + +/***/ }), + +/***/ 50249: +/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { + +"use strict"; + +// parse a single path portion +Object.defineProperty(exports, "__esModule", ({ value: true })); +exports.AST = void 0; +const brace_expressions_js_1 = __nccwpck_require__(53211); +const unescape_js_1 = __nccwpck_require__(43612); +const types = new Set(['!', '?', '+', '*', '@']); +const isExtglobType = (c) => types.has(c); +// Patterns that get prepended to bind to the start of either the +// entire string, or just a single path portion, to prevent dots +// and/or traversal patterns, when needed. +// Exts don't need the ^ or / bit, because the root binds that already. +const startNoTraversal = '(?!(?:^|/)\\.\\.?(?:$|/))'; +const startNoDot = '(?!\\.)'; +// characters that indicate a start of pattern needs the "no dots" bit, +// because a dot *might* be matched. ( is not in the list, because in +// the case of a child extglob, it will handle the prevention itself. +const addPatternStart = new Set(['[', '.']); +// cases where traversal is A-OK, no dot prevention needed +const justDots = new Set(['..', '.']); +const reSpecials = new Set('().*{}+?[]^$\\!'); +const regExpEscape = (s) => s.replace(/[-[\]{}()*+?.,\\^$|#\s]/g, '\\$&'); +// any single thing other than / +const qmark = '[^/]'; +// * => any number of characters +const star = qmark + '*?'; +// use + when we need to ensure that *something* matches, because the * is +// the only thing in the path portion. +const starNoEmpty = qmark + '+?'; +// remove the \ chars that we added if we end up doing a nonmagic compare +// const deslash = (s: string) => s.replace(/\\(.)/g, '$1') +class AST { + type; + #root; + #hasMagic; + #uflag = false; + #parts = []; + #parent; + #parentIndex; + #negs; + #filledNegs = false; + #options; + #toString; + // set to true if it's an extglob with no children + // (which really means one child of '') + #emptyExt = false; + constructor(type, parent, options = {}) { + this.type = type; + // extglobs are inherently magical + if (type) + this.#hasMagic = true; + this.#parent = parent; + this.#root = this.#parent ? this.#parent.#root : this; + this.#options = this.#root === this ? options : this.#root.#options; + this.#negs = this.#root === this ? [] : this.#root.#negs; + if (type === '!' && !this.#root.#filledNegs) + this.#negs.push(this); + this.#parentIndex = this.#parent ? this.#parent.#parts.length : 0; + } + get hasMagic() { + /* c8 ignore start */ + if (this.#hasMagic !== undefined) + return this.#hasMagic; + /* c8 ignore stop */ + for (const p of this.#parts) { + if (typeof p === 'string') + continue; + if (p.type || p.hasMagic) + return (this.#hasMagic = true); + } + // note: will be undefined until we generate the regexp src and find out + return this.#hasMagic; + } + // reconstructs the pattern + toString() { + if (this.#toString !== undefined) + return this.#toString; + if (!this.type) { + return (this.#toString = this.#parts.map(p => String(p)).join('')); + } + else { + return (this.#toString = + this.type + '(' + this.#parts.map(p => String(p)).join('|') + ')'); + } + } + #fillNegs() { + /* c8 ignore start */ + if (this !== this.#root) + throw new Error('should only call on root'); + if (this.#filledNegs) + return this; + /* c8 ignore stop */ + // call toString() once to fill this out + this.toString(); + this.#filledNegs = true; + let n; + while ((n = this.#negs.pop())) { + if (n.type !== '!') + continue; + // walk up the tree, appending everthing that comes AFTER parentIndex + let p = n; + let pp = p.#parent; + while (pp) { + for (let i = p.#parentIndex + 1; !pp.type && i < pp.#parts.length; i++) { + for (const part of n.#parts) { + /* c8 ignore start */ + if (typeof part === 'string') { + throw new Error('string part in extglob AST??'); + } + /* c8 ignore stop */ + part.copyIn(pp.#parts[i]); + } + } + p = pp; + pp = p.#parent; + } + } + return this; + } + push(...parts) { + for (const p of parts) { + if (p === '') + continue; + /* c8 ignore start */ + if (typeof p !== 'string' && !(p instanceof AST && p.#parent === this)) { + throw new Error('invalid part: ' + p); + } + /* c8 ignore stop */ + this.#parts.push(p); + } + } + toJSON() { + const ret = this.type === null + ? this.#parts.slice().map(p => (typeof p === 'string' ? p : p.toJSON())) + : [this.type, ...this.#parts.map(p => p.toJSON())]; + if (this.isStart() && !this.type) + ret.unshift([]); + if (this.isEnd() && + (this === this.#root || + (this.#root.#filledNegs && this.#parent?.type === '!'))) { + ret.push({}); + } + return ret; + } + isStart() { + if (this.#root === this) + return true; + // if (this.type) return !!this.#parent?.isStart() + if (!this.#parent?.isStart()) + return false; + if (this.#parentIndex === 0) + return true; + // if everything AHEAD of this is a negation, then it's still the "start" + const p = this.#parent; + for (let i = 0; i < this.#parentIndex; i++) { + const pp = p.#parts[i]; + if (!(pp instanceof AST && pp.type === '!')) { + return false; + } + } + return true; + } + isEnd() { + if (this.#root === this) + return true; + if (this.#parent?.type === '!') + return true; + if (!this.#parent?.isEnd()) + return false; + if (!this.type) + return this.#parent?.isEnd(); + // if not root, it'll always have a parent + /* c8 ignore start */ + const pl = this.#parent ? this.#parent.#parts.length : 0; + /* c8 ignore stop */ + return this.#parentIndex === pl - 1; + } + copyIn(part) { + if (typeof part === 'string') + this.push(part); + else + this.push(part.clone(this)); + } + clone(parent) { + const c = new AST(this.type, parent); + for (const p of this.#parts) { + c.copyIn(p); + } + return c; + } + static #parseAST(str, ast, pos, opt) { + let escaping = false; + let inBrace = false; + let braceStart = -1; + let braceNeg = false; + if (ast.type === null) { + // outside of a extglob, append until we find a start + let i = pos; + let acc = ''; + while (i < str.length) { + const c = str.charAt(i++); + // still accumulate escapes at this point, but we do ignore + // starts that are escaped + if (escaping || c === '\\') { + escaping = !escaping; + acc += c; + continue; + } + if (inBrace) { + if (i === braceStart + 1) { + if (c === '^' || c === '!') { + braceNeg = true; + } + } + else if (c === ']' && !(i === braceStart + 2 && braceNeg)) { + inBrace = false; + } + acc += c; + continue; + } + else if (c === '[') { + inBrace = true; + braceStart = i; + braceNeg = false; + acc += c; + continue; + } + if (!opt.noext && isExtglobType(c) && str.charAt(i) === '(') { + ast.push(acc); + acc = ''; + const ext = new AST(c, ast); + i = AST.#parseAST(str, ext, i, opt); + ast.push(ext); + continue; + } + acc += c; + } + ast.push(acc); + return i; + } + // some kind of extglob, pos is at the ( + // find the next | or ) + let i = pos + 1; + let part = new AST(null, ast); + const parts = []; + let acc = ''; + while (i < str.length) { + const c = str.charAt(i++); + // still accumulate escapes at this point, but we do ignore + // starts that are escaped + if (escaping || c === '\\') { + escaping = !escaping; + acc += c; + continue; + } + if (inBrace) { + if (i === braceStart + 1) { + if (c === '^' || c === '!') { + braceNeg = true; + } + } + else if (c === ']' && !(i === braceStart + 2 && braceNeg)) { + inBrace = false; + } + acc += c; + continue; + } + else if (c === '[') { + inBrace = true; + braceStart = i; + braceNeg = false; + acc += c; + continue; + } + if (isExtglobType(c) && str.charAt(i) === '(') { + part.push(acc); + acc = ''; + const ext = new AST(c, part); + part.push(ext); + i = AST.#parseAST(str, ext, i, opt); + continue; + } + if (c === '|') { + part.push(acc); + acc = ''; + parts.push(part); + part = new AST(null, ast); + continue; + } + if (c === ')') { + if (acc === '' && ast.#parts.length === 0) { + ast.#emptyExt = true; + } + part.push(acc); + acc = ''; + ast.push(...parts, part); + return i; + } + acc += c; + } + // unfinished extglob + // if we got here, it was a malformed extglob! not an extglob, but + // maybe something else in there. + ast.type = null; + ast.#hasMagic = undefined; + ast.#parts = [str.substring(pos - 1)]; + return i; + } + static fromGlob(pattern, options = {}) { + const ast = new AST(null, undefined, options); + AST.#parseAST(pattern, ast, 0, options); + return ast; + } + // returns the regular expression if there's magic, or the unescaped + // string if not. + toMMPattern() { + // should only be called on root + /* c8 ignore start */ + if (this !== this.#root) + return this.#root.toMMPattern(); + /* c8 ignore stop */ + const glob = this.toString(); + const [re, body, hasMagic, uflag] = this.toRegExpSource(); + // if we're in nocase mode, and not nocaseMagicOnly, then we do + // still need a regular expression if we have to case-insensitively + // match capital/lowercase characters. + const anyMagic = hasMagic || + this.#hasMagic || + (this.#options.nocase && + !this.#options.nocaseMagicOnly && + glob.toUpperCase() !== glob.toLowerCase()); + if (!anyMagic) { + return body; + } + const flags = (this.#options.nocase ? 'i' : '') + (uflag ? 'u' : ''); + return Object.assign(new RegExp(`^${re}$`, flags), { + _src: re, + _glob: glob, + }); + } + // returns the string match, the regexp source, whether there's magic + // in the regexp (so a regular expression is required) and whether or + // not the uflag is needed for the regular expression (for posix classes) + // TODO: instead of injecting the start/end at this point, just return + // the BODY of the regexp, along with the start/end portions suitable + // for binding the start/end in either a joined full-path makeRe context + // (where we bind to (^|/), or a standalone matchPart context (where + // we bind to ^, and not /). Otherwise slashes get duped! + // + // In part-matching mode, the start is: + // - if not isStart: nothing + // - if traversal possible, but not allowed: ^(?!\.\.?$) + // - if dots allowed or not possible: ^ + // - if dots possible and not allowed: ^(?!\.) + // end is: + // - if not isEnd(): nothing + // - else: $ + // + // In full-path matching mode, we put the slash at the START of the + // pattern, so start is: + // - if first pattern: same as part-matching mode + // - if not isStart(): nothing + // - if traversal possible, but not allowed: /(?!\.\.?(?:$|/)) + // - if dots allowed or not possible: / + // - if dots possible and not allowed: /(?!\.) + // end is: + // - if last pattern, same as part-matching mode + // - else nothing + // + // Always put the (?:$|/) on negated tails, though, because that has to be + // there to bind the end of the negated pattern portion, and it's easier to + // just stick it in now rather than try to inject it later in the middle of + // the pattern. + // + // We can just always return the same end, and leave it up to the caller + // to know whether it's going to be used joined or in parts. + // And, if the start is adjusted slightly, can do the same there: + // - if not isStart: nothing + // - if traversal possible, but not allowed: (?:/|^)(?!\.\.?$) + // - if dots allowed or not possible: (?:/|^) + // - if dots possible and not allowed: (?:/|^)(?!\.) + // + // But it's better to have a simpler binding without a conditional, for + // performance, so probably better to return both start options. + // + // Then the caller just ignores the end if it's not the first pattern, + // and the start always gets applied. + // + // But that's always going to be $ if it's the ending pattern, or nothing, + // so the caller can just attach $ at the end of the pattern when building. + // + // So the todo is: + // - better detect what kind of start is needed + // - return both flavors of starting pattern + // - attach $ at the end of the pattern when creating the actual RegExp + // + // Ah, but wait, no, that all only applies to the root when the first pattern + // is not an extglob. If the first pattern IS an extglob, then we need all + // that dot prevention biz to live in the extglob portions, because eg + // +(*|.x*) can match .xy but not .yx. + // + // So, return the two flavors if it's #root and the first child is not an + // AST, otherwise leave it to the child AST to handle it, and there, + // use the (?:^|/) style of start binding. + // + // Even simplified further: + // - Since the start for a join is eg /(?!\.) and the start for a part + // is ^(?!\.), we can just prepend (?!\.) to the pattern (either root + // or start or whatever) and prepend ^ or / at the Regexp construction. + toRegExpSource(allowDot) { + const dot = allowDot ?? !!this.#options.dot; + if (this.#root === this) + this.#fillNegs(); + if (!this.type) { + const noEmpty = this.isStart() && this.isEnd(); + const src = this.#parts + .map(p => { + const [re, _, hasMagic, uflag] = typeof p === 'string' + ? AST.#parseGlob(p, this.#hasMagic, noEmpty) + : p.toRegExpSource(allowDot); + this.#hasMagic = this.#hasMagic || hasMagic; + this.#uflag = this.#uflag || uflag; + return re; + }) + .join(''); + let start = ''; + if (this.isStart()) { + if (typeof this.#parts[0] === 'string') { + // this is the string that will match the start of the pattern, + // so we need to protect against dots and such. + // '.' and '..' cannot match unless the pattern is that exactly, + // even if it starts with . or dot:true is set. + const dotTravAllowed = this.#parts.length === 1 && justDots.has(this.#parts[0]); + if (!dotTravAllowed) { + const aps = addPatternStart; + // check if we have a possibility of matching . or .., + // and prevent that. + const needNoTrav = + // dots are allowed, and the pattern starts with [ or . + (dot && aps.has(src.charAt(0))) || + // the pattern starts with \., and then [ or . + (src.startsWith('\\.') && aps.has(src.charAt(2))) || + // the pattern starts with \.\., and then [ or . + (src.startsWith('\\.\\.') && aps.has(src.charAt(4))); + // no need to prevent dots if it can't match a dot, or if a + // sub-pattern will be preventing it anyway. + const needNoDot = !dot && !allowDot && aps.has(src.charAt(0)); + start = needNoTrav ? startNoTraversal : needNoDot ? startNoDot : ''; + } + } + } + // append the "end of path portion" pattern to negation tails + let end = ''; + if (this.isEnd() && + this.#root.#filledNegs && + this.#parent?.type === '!') { + end = '(?:$|\\/)'; + } + const final = start + src + end; + return [ + final, + (0, unescape_js_1.unescape)(src), + (this.#hasMagic = !!this.#hasMagic), + this.#uflag, + ]; + } + // We need to calculate the body *twice* if it's a repeat pattern + // at the start, once in nodot mode, then again in dot mode, so a + // pattern like *(?) can match 'x.y' + const repeated = this.type === '*' || this.type === '+'; + // some kind of extglob + const start = this.type === '!' ? '(?:(?!(?:' : '(?:'; + let body = this.#partsToRegExp(dot); + if (this.isStart() && this.isEnd() && !body && this.type !== '!') { + // invalid extglob, has to at least be *something* present, if it's + // the entire path portion. + const s = this.toString(); + this.#parts = [s]; + this.type = null; + this.#hasMagic = undefined; + return [s, (0, unescape_js_1.unescape)(this.toString()), false, false]; + } + // XXX abstract out this map method + let bodyDotAllowed = !repeated || allowDot || dot || !startNoDot + ? '' + : this.#partsToRegExp(true); + if (bodyDotAllowed === body) { + bodyDotAllowed = ''; + } + if (bodyDotAllowed) { + body = `(?:${body})(?:${bodyDotAllowed})*?`; + } + // an empty !() is exactly equivalent to a starNoEmpty + let final = ''; + if (this.type === '!' && this.#emptyExt) { + final = (this.isStart() && !dot ? startNoDot : '') + starNoEmpty; + } + else { + const close = this.type === '!' + ? // !() must match something,but !(x) can match '' + '))' + + (this.isStart() && !dot && !allowDot ? startNoDot : '') + + star + + ')' + : this.type === '@' + ? ')' + : this.type === '?' + ? ')?' + : this.type === '+' && bodyDotAllowed + ? ')' + : this.type === '*' && bodyDotAllowed + ? `)?` + : `)${this.type}`; + final = start + body + close; + } + return [ + final, + (0, unescape_js_1.unescape)(body), + (this.#hasMagic = !!this.#hasMagic), + this.#uflag, + ]; + } + #partsToRegExp(dot) { + return this.#parts + .map(p => { + // extglob ASTs should only contain parent ASTs + /* c8 ignore start */ + if (typeof p === 'string') { + throw new Error('string type in extglob ast??'); + } + /* c8 ignore stop */ + // can ignore hasMagic, because extglobs are already always magic + const [re, _, _hasMagic, uflag] = p.toRegExpSource(dot); + this.#uflag = this.#uflag || uflag; + return re; + }) + .filter(p => !(this.isStart() && this.isEnd()) || !!p) + .join('|'); + } + static #parseGlob(glob, hasMagic, noEmpty = false) { + let escaping = false; + let re = ''; + let uflag = false; + for (let i = 0; i < glob.length; i++) { + const c = glob.charAt(i); + if (escaping) { + escaping = false; + re += (reSpecials.has(c) ? '\\' : '') + c; + continue; + } + if (c === '\\') { + if (i === glob.length - 1) { + re += '\\\\'; + } + else { + escaping = true; + } + continue; + } + if (c === '[') { + const [src, needUflag, consumed, magic] = (0, brace_expressions_js_1.parseClass)(glob, i); + if (consumed) { + re += src; + uflag = uflag || needUflag; + i += consumed - 1; + hasMagic = hasMagic || magic; + continue; + } + } + if (c === '*') { + if (noEmpty && glob === '*') + re += starNoEmpty; + else + re += star; + hasMagic = true; + continue; + } + if (c === '?') { + re += qmark; + hasMagic = true; + continue; + } + re += regExpEscape(c); + } + return [re, (0, unescape_js_1.unescape)(glob), !!hasMagic, uflag]; + } +} +exports.AST = AST; +//# sourceMappingURL=ast.js.map + +/***/ }), + +/***/ 53211: +/***/ ((__unused_webpack_module, exports) => { + +"use strict"; + +// translate the various posix character classes into unicode properties +// this works across all unicode locales +Object.defineProperty(exports, "__esModule", ({ value: true })); +exports.parseClass = void 0; +// { : [, /u flag required, negated] +const posixClasses = { + '[:alnum:]': ['\\p{L}\\p{Nl}\\p{Nd}', true], + '[:alpha:]': ['\\p{L}\\p{Nl}', true], + '[:ascii:]': ['\\x' + '00-\\x' + '7f', false], + '[:blank:]': ['\\p{Zs}\\t', true], + '[:cntrl:]': ['\\p{Cc}', true], + '[:digit:]': ['\\p{Nd}', true], + '[:graph:]': ['\\p{Z}\\p{C}', true, true], + '[:lower:]': ['\\p{Ll}', true], + '[:print:]': ['\\p{C}', true], + '[:punct:]': ['\\p{P}', true], + '[:space:]': ['\\p{Z}\\t\\r\\n\\v\\f', true], + '[:upper:]': ['\\p{Lu}', true], + '[:word:]': ['\\p{L}\\p{Nl}\\p{Nd}\\p{Pc}', true], + '[:xdigit:]': ['A-Fa-f0-9', false], +}; +// only need to escape a few things inside of brace expressions +// escapes: [ \ ] - +const braceEscape = (s) => s.replace(/[[\]\\-]/g, '\\$&'); +// escape all regexp magic characters +const regexpEscape = (s) => s.replace(/[-[\]{}()*+?.,\\^$|#\s]/g, '\\$&'); +// everything has already been escaped, we just have to join +const rangesToString = (ranges) => ranges.join(''); +// takes a glob string at a posix brace expression, and returns +// an equivalent regular expression source, and boolean indicating +// whether the /u flag needs to be applied, and the number of chars +// consumed to parse the character class. +// This also removes out of order ranges, and returns ($.) if the +// entire class just no good. +const parseClass = (glob, position) => { + const pos = position; + /* c8 ignore start */ + if (glob.charAt(pos) !== '[') { + throw new Error('not in a brace expression'); + } + /* c8 ignore stop */ + const ranges = []; + const negs = []; + let i = pos + 1; + let sawStart = false; + let uflag = false; + let escaping = false; + let negate = false; + let endPos = pos; + let rangeStart = ''; + WHILE: while (i < glob.length) { + const c = glob.charAt(i); + if ((c === '!' || c === '^') && i === pos + 1) { + negate = true; + i++; + continue; + } + if (c === ']' && sawStart && !escaping) { + endPos = i + 1; + break; + } + sawStart = true; + if (c === '\\') { + if (!escaping) { + escaping = true; + i++; + continue; + } + // escaped \ char, fall through and treat like normal char + } + if (c === '[' && !escaping) { + // either a posix class, a collation equivalent, or just a [ + for (const [cls, [unip, u, neg]] of Object.entries(posixClasses)) { + if (glob.startsWith(cls, i)) { + // invalid, [a-[] is fine, but not [a-[:alpha]] + if (rangeStart) { + return ['$.', false, glob.length - pos, true]; + } + i += cls.length; + if (neg) + negs.push(unip); + else + ranges.push(unip); + uflag = uflag || u; + continue WHILE; + } + } + } + // now it's just a normal character, effectively + escaping = false; + if (rangeStart) { + // throw this range away if it's not valid, but others + // can still match. + if (c > rangeStart) { + ranges.push(braceEscape(rangeStart) + '-' + braceEscape(c)); + } + else if (c === rangeStart) { + ranges.push(braceEscape(c)); + } + rangeStart = ''; + i++; + continue; + } + // now might be the start of a range. + // can be either c-d or c-] or c] or c] at this point + if (glob.startsWith('-]', i + 1)) { + ranges.push(braceEscape(c + '-')); + i += 2; + continue; + } + if (glob.startsWith('-', i + 1)) { + rangeStart = c; + i += 2; + continue; + } + // not the start of a range, just a single character + ranges.push(braceEscape(c)); + i++; + } + if (endPos < i) { + // didn't see the end of the class, not a valid class, + // but might still be valid as a literal match. + return ['', false, 0, false]; + } + // if we got no ranges and no negates, then we have a range that + // cannot possibly match anything, and that poisons the whole glob + if (!ranges.length && !negs.length) { + return ['$.', false, glob.length - pos, true]; + } + // if we got one positive range, and it's a single character, then that's + // not actually a magic pattern, it's just that one literal character. + // we should not treat that as "magic", we should just return the literal + // character. [_] is a perfectly valid way to escape glob magic chars. + if (negs.length === 0 && + ranges.length === 1 && + /^\\?.$/.test(ranges[0]) && + !negate) { + const r = ranges[0].length === 2 ? ranges[0].slice(-1) : ranges[0]; + return [regexpEscape(r), false, endPos - pos, false]; + } + const sranges = '[' + (negate ? '^' : '') + rangesToString(ranges) + ']'; + const snegs = '[' + (negate ? '' : '^') + rangesToString(negs) + ']'; + const comb = ranges.length && negs.length + ? '(' + sranges + '|' + snegs + ')' + : ranges.length + ? sranges + : snegs; + return [comb, uflag, endPos - pos, true]; +}; +exports.parseClass = parseClass; +//# sourceMappingURL=brace-expressions.js.map + +/***/ }), + +/***/ 9549: +/***/ ((__unused_webpack_module, exports) => { + +"use strict"; + +Object.defineProperty(exports, "__esModule", ({ value: true })); +exports.escape = void 0; +/** + * Escape all magic characters in a glob pattern. + * + * If the {@link windowsPathsNoEscape | GlobOptions.windowsPathsNoEscape} + * option is used, then characters are escaped by wrapping in `[]`, because + * a magic character wrapped in a character class can only be satisfied by + * that exact character. In this mode, `\` is _not_ escaped, because it is + * not interpreted as a magic character, but instead as a path separator. + */ +const escape = (s, { windowsPathsNoEscape = false, } = {}) => { + // don't need to escape +@! because we escape the parens + // that make those magic, and escaping ! as [!] isn't valid, + // because [!]] is a valid glob class meaning not ']'. + return windowsPathsNoEscape + ? s.replace(/[?*()[\]]/g, '[$&]') + : s.replace(/[?*()[\]\\]/g, '\\$&'); +}; +exports.escape = escape; +//# sourceMappingURL=escape.js.map + +/***/ }), + +/***/ 55224: +/***/ (function(__unused_webpack_module, exports, __nccwpck_require__) { + +"use strict"; + +var __importDefault = (this && this.__importDefault) || function (mod) { + return (mod && mod.__esModule) ? mod : { "default": mod }; +}; +Object.defineProperty(exports, "__esModule", ({ value: true })); +exports.unescape = exports.escape = exports.AST = exports.Minimatch = exports.match = exports.makeRe = exports.braceExpand = exports.defaults = exports.filter = exports.GLOBSTAR = exports.sep = exports.minimatch = void 0; +const brace_expansion_1 = __importDefault(__nccwpck_require__(82548)); +const assert_valid_pattern_js_1 = __nccwpck_require__(63305); +const ast_js_1 = __nccwpck_require__(50249); +const escape_js_1 = __nccwpck_require__(9549); +const unescape_js_1 = __nccwpck_require__(43612); +const minimatch = (p, pattern, options = {}) => { + (0, assert_valid_pattern_js_1.assertValidPattern)(pattern); + // shortcut: comments match nothing. + if (!options.nocomment && pattern.charAt(0) === '#') { + return false; + } + return new Minimatch(pattern, options).match(p); +}; +exports.minimatch = minimatch; +// Optimized checking for the most common glob patterns. +const starDotExtRE = /^\*+([^+@!?\*\[\(]*)$/; +const starDotExtTest = (ext) => (f) => !f.startsWith('.') && f.endsWith(ext); +const starDotExtTestDot = (ext) => (f) => f.endsWith(ext); +const starDotExtTestNocase = (ext) => { + ext = ext.toLowerCase(); + return (f) => !f.startsWith('.') && f.toLowerCase().endsWith(ext); +}; +const starDotExtTestNocaseDot = (ext) => { + ext = ext.toLowerCase(); + return (f) => f.toLowerCase().endsWith(ext); +}; +const starDotStarRE = /^\*+\.\*+$/; +const starDotStarTest = (f) => !f.startsWith('.') && f.includes('.'); +const starDotStarTestDot = (f) => f !== '.' && f !== '..' && f.includes('.'); +const dotStarRE = /^\.\*+$/; +const dotStarTest = (f) => f !== '.' && f !== '..' && f.startsWith('.'); +const starRE = /^\*+$/; +const starTest = (f) => f.length !== 0 && !f.startsWith('.'); +const starTestDot = (f) => f.length !== 0 && f !== '.' && f !== '..'; +const qmarksRE = /^\?+([^+@!?\*\[\(]*)?$/; +const qmarksTestNocase = ([$0, ext = '']) => { + const noext = qmarksTestNoExt([$0]); + if (!ext) + return noext; + ext = ext.toLowerCase(); + return (f) => noext(f) && f.toLowerCase().endsWith(ext); +}; +const qmarksTestNocaseDot = ([$0, ext = '']) => { + const noext = qmarksTestNoExtDot([$0]); + if (!ext) + return noext; + ext = ext.toLowerCase(); + return (f) => noext(f) && f.toLowerCase().endsWith(ext); +}; +const qmarksTestDot = ([$0, ext = '']) => { + const noext = qmarksTestNoExtDot([$0]); + return !ext ? noext : (f) => noext(f) && f.endsWith(ext); +}; +const qmarksTest = ([$0, ext = '']) => { + const noext = qmarksTestNoExt([$0]); + return !ext ? noext : (f) => noext(f) && f.endsWith(ext); +}; +const qmarksTestNoExt = ([$0]) => { + const len = $0.length; + return (f) => f.length === len && !f.startsWith('.'); +}; +const qmarksTestNoExtDot = ([$0]) => { + const len = $0.length; + return (f) => f.length === len && f !== '.' && f !== '..'; +}; +/* c8 ignore start */ +const defaultPlatform = (typeof process === 'object' && process + ? (typeof process.env === 'object' && + process.env && + process.env.__MINIMATCH_TESTING_PLATFORM__) || + process.platform + : 'posix'); +const path = { + win32: { sep: '\\' }, + posix: { sep: '/' }, +}; +/* c8 ignore stop */ +exports.sep = defaultPlatform === 'win32' ? path.win32.sep : path.posix.sep; +exports.minimatch.sep = exports.sep; +exports.GLOBSTAR = Symbol('globstar **'); +exports.minimatch.GLOBSTAR = exports.GLOBSTAR; +// any single thing other than / +// don't need to escape / when using new RegExp() +const qmark = '[^/]'; +// * => any number of characters +const star = qmark + '*?'; +// ** when dots are allowed. Anything goes, except .. and . +// not (^ or / followed by one or two dots followed by $ or /), +// followed by anything, any number of times. +const twoStarDot = '(?:(?!(?:\\/|^)(?:\\.{1,2})($|\\/)).)*?'; +// not a ^ or / followed by a dot, +// followed by anything, any number of times. +const twoStarNoDot = '(?:(?!(?:\\/|^)\\.).)*?'; +const filter = (pattern, options = {}) => (p) => (0, exports.minimatch)(p, pattern, options); +exports.filter = filter; +exports.minimatch.filter = exports.filter; +const ext = (a, b = {}) => Object.assign({}, a, b); +const defaults = (def) => { + if (!def || typeof def !== 'object' || !Object.keys(def).length) { + return exports.minimatch; + } + const orig = exports.minimatch; + const m = (p, pattern, options = {}) => orig(p, pattern, ext(def, options)); + return Object.assign(m, { + Minimatch: class Minimatch extends orig.Minimatch { + constructor(pattern, options = {}) { + super(pattern, ext(def, options)); + } + static defaults(options) { + return orig.defaults(ext(def, options)).Minimatch; + } + }, + AST: class AST extends orig.AST { + /* c8 ignore start */ + constructor(type, parent, options = {}) { + super(type, parent, ext(def, options)); + } + /* c8 ignore stop */ + static fromGlob(pattern, options = {}) { + return orig.AST.fromGlob(pattern, ext(def, options)); + } + }, + unescape: (s, options = {}) => orig.unescape(s, ext(def, options)), + escape: (s, options = {}) => orig.escape(s, ext(def, options)), + filter: (pattern, options = {}) => orig.filter(pattern, ext(def, options)), + defaults: (options) => orig.defaults(ext(def, options)), + makeRe: (pattern, options = {}) => orig.makeRe(pattern, ext(def, options)), + braceExpand: (pattern, options = {}) => orig.braceExpand(pattern, ext(def, options)), + match: (list, pattern, options = {}) => orig.match(list, pattern, ext(def, options)), + sep: orig.sep, + GLOBSTAR: exports.GLOBSTAR, + }); +}; +exports.defaults = defaults; +exports.minimatch.defaults = exports.defaults; +// Brace expansion: +// a{b,c}d -> abd acd +// a{b,}c -> abc ac +// a{0..3}d -> a0d a1d a2d a3d +// a{b,c{d,e}f}g -> abg acdfg acefg +// a{b,c}d{e,f}g -> abdeg acdeg abdeg abdfg +// +// Invalid sets are not expanded. +// a{2..}b -> a{2..}b +// a{b}c -> a{b}c +const braceExpand = (pattern, options = {}) => { + (0, assert_valid_pattern_js_1.assertValidPattern)(pattern); + // Thanks to Yeting Li for + // improving this regexp to avoid a ReDOS vulnerability. + if (options.nobrace || !/\{(?:(?!\{).)*\}/.test(pattern)) { + // shortcut. no need to expand. + return [pattern]; + } + return (0, brace_expansion_1.default)(pattern); +}; +exports.braceExpand = braceExpand; +exports.minimatch.braceExpand = exports.braceExpand; +// parse a component of the expanded set. +// At this point, no pattern may contain "/" in it +// so we're going to return a 2d array, where each entry is the full +// pattern, split on '/', and then turned into a regular expression. +// A regexp is made at the end which joins each array with an +// escaped /, and another full one which joins each regexp with |. +// +// Following the lead of Bash 4.1, note that "**" only has special meaning +// when it is the *only* thing in a path portion. Otherwise, any series +// of * is equivalent to a single *. Globstar behavior is enabled by +// default, and can be disabled by setting options.noglobstar. +const makeRe = (pattern, options = {}) => new Minimatch(pattern, options).makeRe(); +exports.makeRe = makeRe; +exports.minimatch.makeRe = exports.makeRe; +const match = (list, pattern, options = {}) => { + const mm = new Minimatch(pattern, options); + list = list.filter(f => mm.match(f)); + if (mm.options.nonull && !list.length) { + list.push(pattern); + } + return list; +}; +exports.match = match; +exports.minimatch.match = exports.match; +// replace stuff like \* with * +const globMagic = /[?*]|[+@!]\(.*?\)|\[|\]/; +const regExpEscape = (s) => s.replace(/[-[\]{}()*+?.,\\^$|#\s]/g, '\\$&'); +class Minimatch { + options; + set; + pattern; + windowsPathsNoEscape; + nonegate; + negate; + comment; + empty; + preserveMultipleSlashes; + partial; + globSet; + globParts; + nocase; + isWindows; + platform; + windowsNoMagicRoot; + regexp; + constructor(pattern, options = {}) { + (0, assert_valid_pattern_js_1.assertValidPattern)(pattern); + options = options || {}; + this.options = options; + this.pattern = pattern; + this.platform = options.platform || defaultPlatform; + this.isWindows = this.platform === 'win32'; + this.windowsPathsNoEscape = + !!options.windowsPathsNoEscape || options.allowWindowsEscape === false; + if (this.windowsPathsNoEscape) { + this.pattern = this.pattern.replace(/\\/g, '/'); + } + this.preserveMultipleSlashes = !!options.preserveMultipleSlashes; + this.regexp = null; + this.negate = false; + this.nonegate = !!options.nonegate; + this.comment = false; + this.empty = false; + this.partial = !!options.partial; + this.nocase = !!this.options.nocase; + this.windowsNoMagicRoot = + options.windowsNoMagicRoot !== undefined + ? options.windowsNoMagicRoot + : !!(this.isWindows && this.nocase); + this.globSet = []; + this.globParts = []; + this.set = []; + // make the set of regexps etc. + this.make(); + } + hasMagic() { + if (this.options.magicalBraces && this.set.length > 1) { + return true; + } + for (const pattern of this.set) { + for (const part of pattern) { + if (typeof part !== 'string') + return true; + } + } + return false; + } + debug(..._) { } + make() { + const pattern = this.pattern; + const options = this.options; + // empty patterns and comments match nothing. + if (!options.nocomment && pattern.charAt(0) === '#') { + this.comment = true; + return; + } + if (!pattern) { + this.empty = true; + return; + } + // step 1: figure out negation, etc. + this.parseNegate(); + // step 2: expand braces + this.globSet = [...new Set(this.braceExpand())]; + if (options.debug) { + this.debug = (...args) => console.error(...args); + } + this.debug(this.pattern, this.globSet); + // step 3: now we have a set, so turn each one into a series of + // path-portion matching patterns. + // These will be regexps, except in the case of "**", which is + // set to the GLOBSTAR object for globstar behavior, + // and will not contain any / characters + // + // First, we preprocess to make the glob pattern sets a bit simpler + // and deduped. There are some perf-killing patterns that can cause + // problems with a glob walk, but we can simplify them down a bit. + const rawGlobParts = this.globSet.map(s => this.slashSplit(s)); + this.globParts = this.preprocess(rawGlobParts); + this.debug(this.pattern, this.globParts); + // glob --> regexps + let set = this.globParts.map((s, _, __) => { + if (this.isWindows && this.windowsNoMagicRoot) { + // check if it's a drive or unc path. + const isUNC = s[0] === '' && + s[1] === '' && + (s[2] === '?' || !globMagic.test(s[2])) && + !globMagic.test(s[3]); + const isDrive = /^[a-z]:/i.test(s[0]); + if (isUNC) { + return [...s.slice(0, 4), ...s.slice(4).map(ss => this.parse(ss))]; + } + else if (isDrive) { + return [s[0], ...s.slice(1).map(ss => this.parse(ss))]; + } + } + return s.map(ss => this.parse(ss)); + }); + this.debug(this.pattern, set); + // filter out everything that didn't compile properly. + this.set = set.filter(s => s.indexOf(false) === -1); + // do not treat the ? in UNC paths as magic + if (this.isWindows) { + for (let i = 0; i < this.set.length; i++) { + const p = this.set[i]; + if (p[0] === '' && + p[1] === '' && + this.globParts[i][2] === '?' && + typeof p[3] === 'string' && + /^[a-z]:$/i.test(p[3])) { + p[2] = '?'; + } + } + } + this.debug(this.pattern, this.set); + } + // various transforms to equivalent pattern sets that are + // faster to process in a filesystem walk. The goal is to + // eliminate what we can, and push all ** patterns as far + // to the right as possible, even if it increases the number + // of patterns that we have to process. + preprocess(globParts) { + // if we're not in globstar mode, then turn all ** into * + if (this.options.noglobstar) { + for (let i = 0; i < globParts.length; i++) { + for (let j = 0; j < globParts[i].length; j++) { + if (globParts[i][j] === '**') { + globParts[i][j] = '*'; + } + } + } + } + const { optimizationLevel = 1 } = this.options; + if (optimizationLevel >= 2) { + // aggressive optimization for the purpose of fs walking + globParts = this.firstPhasePreProcess(globParts); + globParts = this.secondPhasePreProcess(globParts); + } + else if (optimizationLevel >= 1) { + // just basic optimizations to remove some .. parts + globParts = this.levelOneOptimize(globParts); + } + else { + globParts = this.adjascentGlobstarOptimize(globParts); + } + return globParts; + } + // just get rid of adjascent ** portions + adjascentGlobstarOptimize(globParts) { + return globParts.map(parts => { + let gs = -1; + while (-1 !== (gs = parts.indexOf('**', gs + 1))) { + let i = gs; + while (parts[i + 1] === '**') { + i++; + } + if (i !== gs) { + parts.splice(gs, i - gs); + } + } + return parts; + }); + } + // get rid of adjascent ** and resolve .. portions + levelOneOptimize(globParts) { + return globParts.map(parts => { + parts = parts.reduce((set, part) => { + const prev = set[set.length - 1]; + if (part === '**' && prev === '**') { + return set; + } + if (part === '..') { + if (prev && prev !== '..' && prev !== '.' && prev !== '**') { + set.pop(); + return set; + } + } + set.push(part); + return set; + }, []); + return parts.length === 0 ? [''] : parts; + }); + } + levelTwoFileOptimize(parts) { + if (!Array.isArray(parts)) { + parts = this.slashSplit(parts); + } + let didSomething = false; + do { + didSomething = false; + //
// -> 
/
+            if (!this.preserveMultipleSlashes) {
+                for (let i = 1; i < parts.length - 1; i++) {
+                    const p = parts[i];
+                    // don't squeeze out UNC patterns
+                    if (i === 1 && p === '' && parts[0] === '')
+                        continue;
+                    if (p === '.' || p === '') {
+                        didSomething = true;
+                        parts.splice(i, 1);
+                        i--;
+                    }
+                }
+                if (parts[0] === '.' &&
+                    parts.length === 2 &&
+                    (parts[1] === '.' || parts[1] === '')) {
+                    didSomething = true;
+                    parts.pop();
+                }
+            }
+            // 
/

/../ ->

/
+            let dd = 0;
+            while (-1 !== (dd = parts.indexOf('..', dd + 1))) {
+                const p = parts[dd - 1];
+                if (p && p !== '.' && p !== '..' && p !== '**') {
+                    didSomething = true;
+                    parts.splice(dd - 1, 2);
+                    dd -= 2;
+                }
+            }
+        } while (didSomething);
+        return parts.length === 0 ? [''] : parts;
+    }
+    // First phase: single-pattern processing
+    // 
 is 1 or more portions
+    //  is 1 or more portions
+    // 

is any portion other than ., .., '', or ** + // is . or '' + // + // **/.. is *brutal* for filesystem walking performance, because + // it effectively resets the recursive walk each time it occurs, + // and ** cannot be reduced out by a .. pattern part like a regexp + // or most strings (other than .., ., and '') can be. + // + //

/**/../

/

/ -> {

/../

/

/,

/**/

/

/} + //

// -> 
/
+    // 
/

/../ ->

/
+    // **/**/ -> **/
+    //
+    // **/*/ -> */**/ <== not valid because ** doesn't follow
+    // this WOULD be allowed if ** did follow symlinks, or * didn't
+    firstPhasePreProcess(globParts) {
+        let didSomething = false;
+        do {
+            didSomething = false;
+            // 
/**/../

/

/ -> {

/../

/

/,

/**/

/

/} + for (let parts of globParts) { + let gs = -1; + while (-1 !== (gs = parts.indexOf('**', gs + 1))) { + let gss = gs; + while (parts[gss + 1] === '**') { + //

/**/**/ -> 
/**/
+                        gss++;
+                    }
+                    // eg, if gs is 2 and gss is 4, that means we have 3 **
+                    // parts, and can remove 2 of them.
+                    if (gss > gs) {
+                        parts.splice(gs + 1, gss - gs);
+                    }
+                    let next = parts[gs + 1];
+                    const p = parts[gs + 2];
+                    const p2 = parts[gs + 3];
+                    if (next !== '..')
+                        continue;
+                    if (!p ||
+                        p === '.' ||
+                        p === '..' ||
+                        !p2 ||
+                        p2 === '.' ||
+                        p2 === '..') {
+                        continue;
+                    }
+                    didSomething = true;
+                    // edit parts in place, and push the new one
+                    parts.splice(gs, 1);
+                    const other = parts.slice(0);
+                    other[gs] = '**';
+                    globParts.push(other);
+                    gs--;
+                }
+                // 
// -> 
/
+                if (!this.preserveMultipleSlashes) {
+                    for (let i = 1; i < parts.length - 1; i++) {
+                        const p = parts[i];
+                        // don't squeeze out UNC patterns
+                        if (i === 1 && p === '' && parts[0] === '')
+                            continue;
+                        if (p === '.' || p === '') {
+                            didSomething = true;
+                            parts.splice(i, 1);
+                            i--;
+                        }
+                    }
+                    if (parts[0] === '.' &&
+                        parts.length === 2 &&
+                        (parts[1] === '.' || parts[1] === '')) {
+                        didSomething = true;
+                        parts.pop();
+                    }
+                }
+                // 
/

/../ ->

/
+                let dd = 0;
+                while (-1 !== (dd = parts.indexOf('..', dd + 1))) {
+                    const p = parts[dd - 1];
+                    if (p && p !== '.' && p !== '..' && p !== '**') {
+                        didSomething = true;
+                        const needDot = dd === 1 && parts[dd + 1] === '**';
+                        const splin = needDot ? ['.'] : [];
+                        parts.splice(dd - 1, 2, ...splin);
+                        if (parts.length === 0)
+                            parts.push('');
+                        dd -= 2;
+                    }
+                }
+            }
+        } while (didSomething);
+        return globParts;
+    }
+    // second phase: multi-pattern dedupes
+    // {
/*/,
/

/} ->

/*/
+    // {
/,
/} -> 
/
+    // {
/**/,
/} -> 
/**/
+    //
+    // {
/**/,
/**/

/} ->

/**/
+    // ^-- not valid because ** doens't follow symlinks
+    secondPhasePreProcess(globParts) {
+        for (let i = 0; i < globParts.length - 1; i++) {
+            for (let j = i + 1; j < globParts.length; j++) {
+                const matched = this.partsMatch(globParts[i], globParts[j], !this.preserveMultipleSlashes);
+                if (!matched)
+                    continue;
+                globParts[i] = matched;
+                globParts[j] = [];
+            }
+        }
+        return globParts.filter(gs => gs.length);
+    }
+    partsMatch(a, b, emptyGSMatch = false) {
+        let ai = 0;
+        let bi = 0;
+        let result = [];
+        let which = '';
+        while (ai < a.length && bi < b.length) {
+            if (a[ai] === b[bi]) {
+                result.push(which === 'b' ? b[bi] : a[ai]);
+                ai++;
+                bi++;
+            }
+            else if (emptyGSMatch && a[ai] === '**' && b[bi] === a[ai + 1]) {
+                result.push(a[ai]);
+                ai++;
+            }
+            else if (emptyGSMatch && b[bi] === '**' && a[ai] === b[bi + 1]) {
+                result.push(b[bi]);
+                bi++;
+            }
+            else if (a[ai] === '*' &&
+                b[bi] &&
+                (this.options.dot || !b[bi].startsWith('.')) &&
+                b[bi] !== '**') {
+                if (which === 'b')
+                    return false;
+                which = 'a';
+                result.push(a[ai]);
+                ai++;
+                bi++;
+            }
+            else if (b[bi] === '*' &&
+                a[ai] &&
+                (this.options.dot || !a[ai].startsWith('.')) &&
+                a[ai] !== '**') {
+                if (which === 'a')
+                    return false;
+                which = 'b';
+                result.push(b[bi]);
+                ai++;
+                bi++;
+            }
+            else {
+                return false;
+            }
+        }
+        // if we fall out of the loop, it means they two are identical
+        // as long as their lengths match
+        return a.length === b.length && result;
+    }
+    parseNegate() {
+        if (this.nonegate)
+            return;
+        const pattern = this.pattern;
+        let negate = false;
+        let negateOffset = 0;
+        for (let i = 0; i < pattern.length && pattern.charAt(i) === '!'; i++) {
+            negate = !negate;
+            negateOffset++;
+        }
+        if (negateOffset)
+            this.pattern = pattern.slice(negateOffset);
+        this.negate = negate;
+    }
+    // set partial to true to test if, for example,
+    // "/a/b" matches the start of "/*/b/*/d"
+    // Partial means, if you run out of file before you run
+    // out of pattern, then that's fine, as long as all
+    // the parts match.
+    matchOne(file, pattern, partial = false) {
+        const options = this.options;
+        // UNC paths like //?/X:/... can match X:/... and vice versa
+        // Drive letters in absolute drive or unc paths are always compared
+        // case-insensitively.
+        if (this.isWindows) {
+            const fileDrive = typeof file[0] === 'string' && /^[a-z]:$/i.test(file[0]);
+            const fileUNC = !fileDrive &&
+                file[0] === '' &&
+                file[1] === '' &&
+                file[2] === '?' &&
+                /^[a-z]:$/i.test(file[3]);
+            const patternDrive = typeof pattern[0] === 'string' && /^[a-z]:$/i.test(pattern[0]);
+            const patternUNC = !patternDrive &&
+                pattern[0] === '' &&
+                pattern[1] === '' &&
+                pattern[2] === '?' &&
+                typeof pattern[3] === 'string' &&
+                /^[a-z]:$/i.test(pattern[3]);
+            const fdi = fileUNC ? 3 : fileDrive ? 0 : undefined;
+            const pdi = patternUNC ? 3 : patternDrive ? 0 : undefined;
+            if (typeof fdi === 'number' && typeof pdi === 'number') {
+                const [fd, pd] = [file[fdi], pattern[pdi]];
+                if (fd.toLowerCase() === pd.toLowerCase()) {
+                    pattern[pdi] = fd;
+                    if (pdi > fdi) {
+                        pattern = pattern.slice(pdi);
+                    }
+                    else if (fdi > pdi) {
+                        file = file.slice(fdi);
+                    }
+                }
+            }
+        }
+        // resolve and reduce . and .. portions in the file as well.
+        // dont' need to do the second phase, because it's only one string[]
+        const { optimizationLevel = 1 } = this.options;
+        if (optimizationLevel >= 2) {
+            file = this.levelTwoFileOptimize(file);
+        }
+        this.debug('matchOne', this, { file, pattern });
+        this.debug('matchOne', file.length, pattern.length);
+        for (var fi = 0, pi = 0, fl = file.length, pl = pattern.length; fi < fl && pi < pl; fi++, pi++) {
+            this.debug('matchOne loop');
+            var p = pattern[pi];
+            var f = file[fi];
+            this.debug(pattern, p, f);
+            // should be impossible.
+            // some invalid regexp stuff in the set.
+            /* c8 ignore start */
+            if (p === false) {
+                return false;
+            }
+            /* c8 ignore stop */
+            if (p === exports.GLOBSTAR) {
+                this.debug('GLOBSTAR', [pattern, p, f]);
+                // "**"
+                // a/**/b/**/c would match the following:
+                // a/b/x/y/z/c
+                // a/x/y/z/b/c
+                // a/b/x/b/x/c
+                // a/b/c
+                // To do this, take the rest of the pattern after
+                // the **, and see if it would match the file remainder.
+                // If so, return success.
+                // If not, the ** "swallows" a segment, and try again.
+                // This is recursively awful.
+                //
+                // a/**/b/**/c matching a/b/x/y/z/c
+                // - a matches a
+                // - doublestar
+                //   - matchOne(b/x/y/z/c, b/**/c)
+                //     - b matches b
+                //     - doublestar
+                //       - matchOne(x/y/z/c, c) -> no
+                //       - matchOne(y/z/c, c) -> no
+                //       - matchOne(z/c, c) -> no
+                //       - matchOne(c, c) yes, hit
+                var fr = fi;
+                var pr = pi + 1;
+                if (pr === pl) {
+                    this.debug('** at the end');
+                    // a ** at the end will just swallow the rest.
+                    // We have found a match.
+                    // however, it will not swallow /.x, unless
+                    // options.dot is set.
+                    // . and .. are *never* matched by **, for explosively
+                    // exponential reasons.
+                    for (; fi < fl; fi++) {
+                        if (file[fi] === '.' ||
+                            file[fi] === '..' ||
+                            (!options.dot && file[fi].charAt(0) === '.'))
+                            return false;
+                    }
+                    return true;
+                }
+                // ok, let's see if we can swallow whatever we can.
+                while (fr < fl) {
+                    var swallowee = file[fr];
+                    this.debug('\nglobstar while', file, fr, pattern, pr, swallowee);
+                    // XXX remove this slice.  Just pass the start index.
+                    if (this.matchOne(file.slice(fr), pattern.slice(pr), partial)) {
+                        this.debug('globstar found match!', fr, fl, swallowee);
+                        // found a match.
+                        return true;
+                    }
+                    else {
+                        // can't swallow "." or ".." ever.
+                        // can only swallow ".foo" when explicitly asked.
+                        if (swallowee === '.' ||
+                            swallowee === '..' ||
+                            (!options.dot && swallowee.charAt(0) === '.')) {
+                            this.debug('dot detected!', file, fr, pattern, pr);
+                            break;
+                        }
+                        // ** swallows a segment, and continue.
+                        this.debug('globstar swallow a segment, and continue');
+                        fr++;
+                    }
+                }
+                // no match was found.
+                // However, in partial mode, we can't say this is necessarily over.
+                /* c8 ignore start */
+                if (partial) {
+                    // ran out of file
+                    this.debug('\n>>> no match, partial?', file, fr, pattern, pr);
+                    if (fr === fl) {
+                        return true;
+                    }
+                }
+                /* c8 ignore stop */
+                return false;
+            }
+            // something other than **
+            // non-magic patterns just have to match exactly
+            // patterns with magic have been turned into regexps.
+            let hit;
+            if (typeof p === 'string') {
+                hit = f === p;
+                this.debug('string match', p, f, hit);
+            }
+            else {
+                hit = p.test(f);
+                this.debug('pattern match', p, f, hit);
+            }
+            if (!hit)
+                return false;
+        }
+        // Note: ending in / means that we'll get a final ""
+        // at the end of the pattern.  This can only match a
+        // corresponding "" at the end of the file.
+        // If the file ends in /, then it can only match a
+        // a pattern that ends in /, unless the pattern just
+        // doesn't have any more for it. But, a/b/ should *not*
+        // match "a/b/*", even though "" matches against the
+        // [^/]*? pattern, except in partial mode, where it might
+        // simply not be reached yet.
+        // However, a/b/ should still satisfy a/*
+        // now either we fell off the end of the pattern, or we're done.
+        if (fi === fl && pi === pl) {
+            // ran out of pattern and filename at the same time.
+            // an exact hit!
+            return true;
+        }
+        else if (fi === fl) {
+            // ran out of file, but still had pattern left.
+            // this is ok if we're doing the match as part of
+            // a glob fs traversal.
+            return partial;
+        }
+        else if (pi === pl) {
+            // ran out of pattern, still have file left.
+            // this is only acceptable if we're on the very last
+            // empty segment of a file with a trailing slash.
+            // a/* should match a/b/
+            return fi === fl - 1 && file[fi] === '';
+            /* c8 ignore start */
+        }
+        else {
+            // should be unreachable.
+            throw new Error('wtf?');
+        }
+        /* c8 ignore stop */
+    }
+    braceExpand() {
+        return (0, exports.braceExpand)(this.pattern, this.options);
+    }
+    parse(pattern) {
+        (0, assert_valid_pattern_js_1.assertValidPattern)(pattern);
+        const options = this.options;
+        // shortcuts
+        if (pattern === '**')
+            return exports.GLOBSTAR;
+        if (pattern === '')
+            return '';
+        // far and away, the most common glob pattern parts are
+        // *, *.*, and *.  Add a fast check method for those.
+        let m;
+        let fastTest = null;
+        if ((m = pattern.match(starRE))) {
+            fastTest = options.dot ? starTestDot : starTest;
+        }
+        else if ((m = pattern.match(starDotExtRE))) {
+            fastTest = (options.nocase
+                ? options.dot
+                    ? starDotExtTestNocaseDot
+                    : starDotExtTestNocase
+                : options.dot
+                    ? starDotExtTestDot
+                    : starDotExtTest)(m[1]);
+        }
+        else if ((m = pattern.match(qmarksRE))) {
+            fastTest = (options.nocase
+                ? options.dot
+                    ? qmarksTestNocaseDot
+                    : qmarksTestNocase
+                : options.dot
+                    ? qmarksTestDot
+                    : qmarksTest)(m);
+        }
+        else if ((m = pattern.match(starDotStarRE))) {
+            fastTest = options.dot ? starDotStarTestDot : starDotStarTest;
+        }
+        else if ((m = pattern.match(dotStarRE))) {
+            fastTest = dotStarTest;
+        }
+        const re = ast_js_1.AST.fromGlob(pattern, this.options).toMMPattern();
+        return fastTest ? Object.assign(re, { test: fastTest }) : re;
+    }
+    makeRe() {
+        if (this.regexp || this.regexp === false)
+            return this.regexp;
+        // at this point, this.set is a 2d array of partial
+        // pattern strings, or "**".
+        //
+        // It's better to use .match().  This function shouldn't
+        // be used, really, but it's pretty convenient sometimes,
+        // when you just want to work with a regex.
+        const set = this.set;
+        if (!set.length) {
+            this.regexp = false;
+            return this.regexp;
+        }
+        const options = this.options;
+        const twoStar = options.noglobstar
+            ? star
+            : options.dot
+                ? twoStarDot
+                : twoStarNoDot;
+        const flags = new Set(options.nocase ? ['i'] : []);
+        // regexpify non-globstar patterns
+        // if ** is only item, then we just do one twoStar
+        // if ** is first, and there are more, prepend (\/|twoStar\/)? to next
+        // if ** is last, append (\/twoStar|) to previous
+        // if ** is in the middle, append (\/|\/twoStar\/) to previous
+        // then filter out GLOBSTAR symbols
+        let re = set
+            .map(pattern => {
+            const pp = pattern.map(p => {
+                if (p instanceof RegExp) {
+                    for (const f of p.flags.split(''))
+                        flags.add(f);
+                }
+                return typeof p === 'string'
+                    ? regExpEscape(p)
+                    : p === exports.GLOBSTAR
+                        ? exports.GLOBSTAR
+                        : p._src;
+            });
+            pp.forEach((p, i) => {
+                const next = pp[i + 1];
+                const prev = pp[i - 1];
+                if (p !== exports.GLOBSTAR || prev === exports.GLOBSTAR) {
+                    return;
+                }
+                if (prev === undefined) {
+                    if (next !== undefined && next !== exports.GLOBSTAR) {
+                        pp[i + 1] = '(?:\\/|' + twoStar + '\\/)?' + next;
+                    }
+                    else {
+                        pp[i] = twoStar;
+                    }
+                }
+                else if (next === undefined) {
+                    pp[i - 1] = prev + '(?:\\/|' + twoStar + ')?';
+                }
+                else if (next !== exports.GLOBSTAR) {
+                    pp[i - 1] = prev + '(?:\\/|\\/' + twoStar + '\\/)' + next;
+                    pp[i + 1] = exports.GLOBSTAR;
+                }
+            });
+            return pp.filter(p => p !== exports.GLOBSTAR).join('/');
+        })
+            .join('|');
+        // need to wrap in parens if we had more than one thing with |,
+        // otherwise only the first will be anchored to ^ and the last to $
+        const [open, close] = set.length > 1 ? ['(?:', ')'] : ['', ''];
+        // must match entire pattern
+        // ending in a * or ** will make it less strict.
+        re = '^' + open + re + close + '$';
+        // can match anything, as long as it's not this.
+        if (this.negate)
+            re = '^(?!' + re + ').+$';
+        try {
+            this.regexp = new RegExp(re, [...flags].join(''));
+            /* c8 ignore start */
+        }
+        catch (ex) {
+            // should be impossible
+            this.regexp = false;
+        }
+        /* c8 ignore stop */
+        return this.regexp;
+    }
+    slashSplit(p) {
+        // if p starts with // on windows, we preserve that
+        // so that UNC paths aren't broken.  Otherwise, any number of
+        // / characters are coalesced into one, unless
+        // preserveMultipleSlashes is set to true.
+        if (this.preserveMultipleSlashes) {
+            return p.split('/');
+        }
+        else if (this.isWindows && /^\/\/[^\/]+/.test(p)) {
+            // add an extra '' for the one we lose
+            return ['', ...p.split(/\/+/)];
+        }
+        else {
+            return p.split(/\/+/);
+        }
+    }
+    match(f, partial = this.partial) {
+        this.debug('match', f, this.pattern);
+        // short-circuit in the case of busted things.
+        // comments, etc.
+        if (this.comment) {
+            return false;
+        }
+        if (this.empty) {
+            return f === '';
+        }
+        if (f === '/' && partial) {
+            return true;
+        }
+        const options = this.options;
+        // windows: need to use /, not \
+        if (this.isWindows) {
+            f = f.split('\\').join('/');
+        }
+        // treat the test path as a set of pathparts.
+        const ff = this.slashSplit(f);
+        this.debug(this.pattern, 'split', ff);
+        // just ONE of the pattern sets in this.set needs to match
+        // in order for it to be valid.  If negating, then just one
+        // match means that we have failed.
+        // Either way, return on the first hit.
+        const set = this.set;
+        this.debug(this.pattern, 'set', set);
+        // Find the basename of the path by looking for the last non-empty segment
+        let filename = ff[ff.length - 1];
+        if (!filename) {
+            for (let i = ff.length - 2; !filename && i >= 0; i--) {
+                filename = ff[i];
+            }
+        }
+        for (let i = 0; i < set.length; i++) {
+            const pattern = set[i];
+            let file = ff;
+            if (options.matchBase && pattern.length === 1) {
+                file = [filename];
+            }
+            const hit = this.matchOne(file, pattern, partial);
+            if (hit) {
+                if (options.flipNegate) {
+                    return true;
+                }
+                return !this.negate;
+            }
+        }
+        // didn't get any hits.  this is success if it's a negative
+        // pattern, failure otherwise.
+        if (options.flipNegate) {
+            return false;
+        }
+        return this.negate;
+    }
+    static defaults(def) {
+        return exports.minimatch.defaults(def).Minimatch;
+    }
+}
+exports.Minimatch = Minimatch;
+/* c8 ignore start */
+var ast_js_2 = __nccwpck_require__(50249);
+Object.defineProperty(exports, "AST", ({ enumerable: true, get: function () { return ast_js_2.AST; } }));
+var escape_js_2 = __nccwpck_require__(9549);
+Object.defineProperty(exports, "escape", ({ enumerable: true, get: function () { return escape_js_2.escape; } }));
+var unescape_js_2 = __nccwpck_require__(43612);
+Object.defineProperty(exports, "unescape", ({ enumerable: true, get: function () { return unescape_js_2.unescape; } }));
+/* c8 ignore stop */
+exports.minimatch.AST = ast_js_1.AST;
+exports.minimatch.Minimatch = Minimatch;
+exports.minimatch.escape = escape_js_1.escape;
+exports.minimatch.unescape = unescape_js_1.unescape;
+//# sourceMappingURL=index.js.map
+
+/***/ }),
+
+/***/ 43612:
+/***/ ((__unused_webpack_module, exports) => {
+
+"use strict";
+
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.unescape = void 0;
+/**
+ * Un-escape a string that has been escaped with {@link escape}.
+ *
+ * If the {@link windowsPathsNoEscape} option is used, then square-brace
+ * escapes are removed, but not backslash escapes.  For example, it will turn
+ * the string `'[*]'` into `*`, but it will not turn `'\\*'` into `'*'`,
+ * becuase `\` is a path separator in `windowsPathsNoEscape` mode.
+ *
+ * When `windowsPathsNoEscape` is not set, then both brace escapes and
+ * backslash escapes are removed.
+ *
+ * Slashes (and backslashes in `windowsPathsNoEscape` mode) cannot be escaped
+ * or unescaped.
+ */
+const unescape = (s, { windowsPathsNoEscape = false, } = {}) => {
+    return windowsPathsNoEscape
+        ? s.replace(/\[([^\/\\])\]/g, '$1')
+        : s.replace(/((?!\\).|^)\[([^\/\\])\]/g, '$1$2').replace(/\\([^\/])/g, '$1');
+};
+exports.unescape = unescape;
+//# sourceMappingURL=unescape.js.map
+
+/***/ }),
+
+/***/ 44050:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
+
+"use strict";
+
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.renamePropertyWithStableKeys = exports.toOldFormat = exports.toNewFormat = exports.isAngularPluginInstalled = exports.shouldMergeAngularProjects = exports.NxAngularJsonPlugin = exports.NX_ANGULAR_JSON_PLUGIN_NAME = void 0;
+const fs_1 = __nccwpck_require__(57147);
+const path = __nccwpck_require__(71017);
+const fileutils_1 = __nccwpck_require__(83851);
+exports.NX_ANGULAR_JSON_PLUGIN_NAME = 'nx-angular-json-plugin';
+exports.NxAngularJsonPlugin = {
+    name: exports.NX_ANGULAR_JSON_PLUGIN_NAME,
+    createNodes: [
+        'angular.json',
+        (f, _, ctx) => ({
+            projects: readAngularJson(ctx.workspaceRoot),
+        }),
+    ],
+};
+function shouldMergeAngularProjects(root, includeProjectsFromAngularJson) {
+    if ((0, fs_1.existsSync)(path.join(root, 'angular.json')) &&
+        // Include projects from angular.json if explicitly required.
+        // e.g. when invoked from `packages/devkit/src/utils/convert-nx-executor.ts`
+        (includeProjectsFromAngularJson ||
+            // Or if a workspace has `@nrwl/angular`/`@nx/angular` installed then projects from `angular.json` to be considered by Nx.
+            isAngularPluginInstalled())) {
+        return true;
+    }
+    else {
+        return false;
+    }
+}
+exports.shouldMergeAngularProjects = shouldMergeAngularProjects;
+function isAngularPluginInstalled() {
+    try {
+        // nx-ignore-next-line
+        require.resolve('@nx/angular');
+        return true;
+    }
+    catch {
+        try {
+            require.resolve('@nrwl/angular');
+            return true;
+        }
+        catch {
+            return false;
+        }
+    }
+}
+exports.isAngularPluginInstalled = isAngularPluginInstalled;
+function readAngularJson(angularCliWorkspaceRoot) {
+    return toNewFormat((0, fileutils_1.readJsonFile)(path.join(angularCliWorkspaceRoot, 'angular.json'))).projects;
+}
+function toNewFormat(w) {
+    if (!w.projects) {
+        return w;
+    }
+    for (const name in w.projects ?? {}) {
+        const projectConfig = w.projects[name];
+        if (projectConfig.architect) {
+            renamePropertyWithStableKeys(projectConfig, 'architect', 'targets');
+        }
+        if (projectConfig.schematics) {
+            renamePropertyWithStableKeys(projectConfig, 'schematics', 'generators');
+        }
+        if (!projectConfig.name) {
+            projectConfig.name = name;
+        }
+        Object.values(projectConfig.targets || {}).forEach((target) => {
+            if (target.builder !== undefined) {
+                renamePropertyWithStableKeys(target, 'builder', 'executor');
+            }
+        });
+    }
+    if (w.schematics) {
+        renamePropertyWithStableKeys(w, 'schematics', 'generators');
+    }
+    if (w.version !== 2) {
+        w.version = 2;
+    }
+    return w;
+}
+exports.toNewFormat = toNewFormat;
+function toOldFormat(w) {
+    if (w.projects) {
+        for (const name in w.projects) {
+            const projectConfig = w.projects[name];
+            if (typeof projectConfig === 'string') {
+                throw new Error("'project.json' files are incompatible with version 1 workspace schemas.");
+            }
+            if (projectConfig.targets) {
+                renamePropertyWithStableKeys(projectConfig, 'targets', 'architect');
+            }
+            if (projectConfig.generators) {
+                renamePropertyWithStableKeys(projectConfig, 'generators', 'schematics');
+            }
+            delete projectConfig.name;
+            Object.values(projectConfig.architect || {}).forEach((target) => {
+                if (target.executor !== undefined) {
+                    renamePropertyWithStableKeys(target, 'executor', 'builder');
+                }
+            });
+        }
+    }
+    if (w.generators) {
+        renamePropertyWithStableKeys(w, 'generators', 'schematics');
+    }
+    if (w.version !== 1) {
+        w.version = 1;
+    }
+    return w;
+}
+exports.toOldFormat = toOldFormat;
+// we have to do it this way to preserve the order of properties
+// not to screw up the formatting
+function renamePropertyWithStableKeys(obj, from, to) {
+    const copy = { ...obj };
+    Object.keys(obj).forEach((k) => {
+        delete obj[k];
+    });
+    Object.keys(copy).forEach((k) => {
+        if (k === from) {
+            obj[to] = copy[k];
+        }
+        else {
+            obj[k] = copy[k];
+        }
+    });
+}
+exports.renamePropertyWithStableKeys = renamePropertyWithStableKeys;
+
+
+/***/ }),
+
+/***/ 38777:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
+
+"use strict";
+
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.readNxJson = exports.workspaceLayout = void 0;
+const nx_json_1 = __nccwpck_require__(53619);
+/**
+ * Returns information about where apps and libs will be created.
+ */
+function workspaceLayout() {
+    const nxJson = (0, nx_json_1.readNxJson)();
+    return {
+        appsDir: nxJson.workspaceLayout?.appsDir ?? 'apps',
+        libsDir: nxJson.workspaceLayout?.libsDir ?? 'libs',
+    };
+}
+exports.workspaceLayout = workspaceLayout;
+var nx_json_2 = __nccwpck_require__(53619);
+Object.defineProperty(exports, "readNxJson", ({ enumerable: true, get: function () { return nx_json_2.readNxJson; } }));
+
+
+/***/ }),
+
+/***/ 53619:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
+
+"use strict";
+
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.hasNxJson = exports.readNxJson = void 0;
+const fs_1 = __nccwpck_require__(57147);
+const path_1 = __nccwpck_require__(71017);
+const fileutils_1 = __nccwpck_require__(83851);
+const workspace_root_1 = __nccwpck_require__(86708);
+function readNxJson(root = workspace_root_1.workspaceRoot) {
+    const nxJson = (0, path_1.join)(root, 'nx.json');
+    if ((0, fs_1.existsSync)(nxJson)) {
+        const nxJsonConfiguration = (0, fileutils_1.readJsonFile)(nxJson);
+        if (nxJsonConfiguration.extends) {
+            const extendedNxJsonPath = require.resolve(nxJsonConfiguration.extends, {
+                paths: [(0, path_1.dirname)(nxJson)],
+            });
+            const baseNxJson = (0, fileutils_1.readJsonFile)(extendedNxJsonPath);
+            return {
+                ...baseNxJson,
+                ...nxJsonConfiguration,
+            };
+        }
+        else {
+            return nxJsonConfiguration;
+        }
+    }
+    else {
+        try {
+            return (0, fileutils_1.readJsonFile)((0, path_1.join)(__dirname, '..', '..', 'presets', 'core.json'));
+        }
+        catch (e) {
+            return {};
+        }
+    }
+}
+exports.readNxJson = readNxJson;
+function hasNxJson(root) {
+    const nxJson = (0, path_1.join)(root, 'nx.json');
+    return (0, fs_1.existsSync)(nxJson);
+}
+exports.hasNxJson = hasNxJson;
+
+
+/***/ }),
+
+/***/ 2184:
+/***/ ((__unused_webpack_module, exports) => {
+
+"use strict";
+
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.DependencyType = exports.fileDataDepType = exports.fileDataDepTarget = void 0;
+function fileDataDepTarget(dep) {
+    return typeof dep === 'string'
+        ? dep
+        : Array.isArray(dep) && dep.length === 2
+            ? dep[0]
+            : dep[1];
+}
+exports.fileDataDepTarget = fileDataDepTarget;
+function fileDataDepType(dep) {
+    return typeof dep === 'string'
+        ? 'static'
+        : Array.isArray(dep) && dep.length === 2
+            ? dep[1]
+            : dep[2];
+}
+exports.fileDataDepType = fileDataDepType;
+/**
+ * Type of dependency between projects
+ */
+var DependencyType;
+(function (DependencyType) {
+    /**
+     * Static dependencies are tied to the loading of the module
+     */
+    DependencyType["static"] = "static";
+    /**
+     * Dynamic dependencies are brought in by the module at run time
+     */
+    DependencyType["dynamic"] = "dynamic";
+    /**
+     * Implicit dependencies are inferred
+     */
+    DependencyType["implicit"] = "implicit";
+})(DependencyType || (exports.DependencyType = DependencyType = {}));
+
+
+/***/ }),
+
+/***/ 26546:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
+
+"use strict";
+
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.toProjectName = exports.Workspaces = void 0;
+const path_1 = __nccwpck_require__(71017);
+const project_graph_1 = __nccwpck_require__(61371);
+const nx_json_1 = __nccwpck_require__(53619);
+// TODO(v19): remove this class
+/**
+ * @deprecated This will be removed in v19. Use {@link readProjectsConfigurationFromProjectGraph} instead.
+ */
+class Workspaces {
+    constructor(root) {
+        this.root = root;
+    }
+    /**
+     * @deprecated Use {@link readProjectsConfigurationFromProjectGraph} instead.
+     */
+    readWorkspaceConfiguration() {
+        const nxJson = (0, nx_json_1.readNxJson)(this.root);
+        return {
+            ...(0, project_graph_1.readProjectsConfigurationFromProjectGraph)((0, project_graph_1.readCachedProjectGraph)()),
+            ...nxJson,
+        };
+    }
+}
+exports.Workspaces = Workspaces;
+/**
+ * Pulled from toFileName in names from @nx/devkit.
+ * Todo: Should refactor, not duplicate.
+ */
+function toProjectName(fileName) {
+    const parts = (0, path_1.dirname)(fileName).split(/[\/\\]/g);
+    return parts[parts.length - 1].toLowerCase();
+}
+exports.toProjectName = toProjectName;
+
+
+/***/ }),
+
+/***/ 94849:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
+
+"use strict";
+
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.getDaemonProcessIdSync = exports.safelyCleanUpExistingProcess = exports.writeDaemonJsonProcessCache = exports.deleteDaemonJsonProcessCache = exports.readDaemonProcessJsonCache = exports.serverProcessJsonPath = void 0;
+const fs_extra_1 = __nccwpck_require__(27475);
+const path_1 = __nccwpck_require__(71017);
+const tmp_dir_1 = __nccwpck_require__(78543);
+exports.serverProcessJsonPath = (0, path_1.join)(tmp_dir_1.DAEMON_DIR_FOR_CURRENT_WORKSPACE, 'server-process.json');
+async function readDaemonProcessJsonCache() {
+    if (!(0, fs_extra_1.existsSync)(exports.serverProcessJsonPath)) {
+        return null;
+    }
+    return await (0, fs_extra_1.readJson)(exports.serverProcessJsonPath);
+}
+exports.readDaemonProcessJsonCache = readDaemonProcessJsonCache;
+function deleteDaemonJsonProcessCache() {
+    try {
+        if (getDaemonProcessIdSync() === process.pid) {
+            (0, fs_extra_1.unlinkSync)(exports.serverProcessJsonPath);
+        }
+    }
+    catch { }
+}
+exports.deleteDaemonJsonProcessCache = deleteDaemonJsonProcessCache;
+async function writeDaemonJsonProcessCache(daemonJson) {
+    await (0, fs_extra_1.writeJson)(exports.serverProcessJsonPath, daemonJson);
+}
+exports.writeDaemonJsonProcessCache = writeDaemonJsonProcessCache;
+async function safelyCleanUpExistingProcess() {
+    const daemonProcessJson = await readDaemonProcessJsonCache();
+    if (daemonProcessJson && daemonProcessJson.processId) {
+        try {
+            process.kill(daemonProcessJson.processId);
+        }
+        catch { }
+    }
+    deleteDaemonJsonProcessCache();
+}
+exports.safelyCleanUpExistingProcess = safelyCleanUpExistingProcess;
+// Must be sync for the help output use case
+function getDaemonProcessIdSync() {
+    if (!(0, fs_extra_1.existsSync)(exports.serverProcessJsonPath)) {
+        return null;
+    }
+    try {
+        const daemonProcessJson = (0, fs_extra_1.readJsonSync)(exports.serverProcessJsonPath);
+        return daemonProcessJson.processId;
+    }
+    catch {
+        return null;
+    }
+}
+exports.getDaemonProcessIdSync = getDaemonProcessIdSync;
+
+
+/***/ }),
+
+/***/ 36638:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
+
+"use strict";
+
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.daemonClient = exports.DaemonClient = void 0;
+const workspace_root_1 = __nccwpck_require__(86708);
+const child_process_1 = __nccwpck_require__(32081);
+const fs_1 = __nccwpck_require__(57147);
+const promises_1 = __nccwpck_require__(73292);
+const fs_extra_1 = __nccwpck_require__(27475);
+const net_1 = __nccwpck_require__(41808);
+const path_1 = __nccwpck_require__(71017);
+const perf_hooks_1 = __nccwpck_require__(4074);
+const output_1 = __nccwpck_require__(1737);
+const socket_utils_1 = __nccwpck_require__(10023);
+const tmp_dir_1 = __nccwpck_require__(78543);
+const is_ci_1 = __nccwpck_require__(15284);
+const configuration_1 = __nccwpck_require__(38777);
+const promised_based_queue_1 = __nccwpck_require__(71067);
+const nx_json_1 = __nccwpck_require__(53619);
+const daemon_socket_messenger_1 = __nccwpck_require__(30386);
+const cache_1 = __nccwpck_require__(94849);
+const DAEMON_ENV_SETTINGS = {
+    ...process.env,
+    NX_PROJECT_GLOB_CACHE: 'false',
+    NX_CACHE_PROJECTS_CONFIG: 'false',
+};
+var DaemonStatus;
+(function (DaemonStatus) {
+    DaemonStatus[DaemonStatus["CONNECTING"] = 0] = "CONNECTING";
+    DaemonStatus[DaemonStatus["DISCONNECTED"] = 1] = "DISCONNECTED";
+    DaemonStatus[DaemonStatus["CONNECTED"] = 2] = "CONNECTED";
+})(DaemonStatus || (DaemonStatus = {}));
+class DaemonClient {
+    constructor(nxJson) {
+        this.nxJson = nxJson;
+        this._daemonStatus = DaemonStatus.DISCONNECTED;
+        this._waitForDaemonReady = null;
+        this._daemonReady = null;
+        this._out = null;
+        this._err = null;
+        this.reset();
+    }
+    enabled() {
+        if (this._enabled === undefined) {
+            // TODO(v19): Add migration to move it out of existing configs and remove the ?? here.
+            const useDaemonProcessOption = this.nxJson.useDaemonProcess ??
+                this.nxJson.tasksRunnerOptions?.['default']?.options?.useDaemonProcess;
+            const env = process.env.NX_DAEMON;
+            // env takes precedence
+            // option=true,env=false => no daemon
+            // option=false,env=undefined => no daemon
+            // option=false,env=false => no daemon
+            // option=undefined,env=undefined => daemon
+            // option=true,env=true => daemon
+            // option=false,env=true => daemon
+            // CI=true,env=undefined => no daemon
+            // CI=true,env=false => no daemon
+            // CI=true,env=true => daemon
+            if (((0, is_ci_1.isCI)() && env !== 'true') ||
+                isDocker() ||
+                (0, tmp_dir_1.isDaemonDisabled)() ||
+                nxJsonIsNotPresent() ||
+                (useDaemonProcessOption === undefined && env === 'false') ||
+                (useDaemonProcessOption === true && env === 'false') ||
+                (useDaemonProcessOption === false && env === undefined) ||
+                (useDaemonProcessOption === false && env === 'false')) {
+                this._enabled = false;
+            }
+            else {
+                this._enabled = true;
+            }
+        }
+        return this._enabled;
+    }
+    reset() {
+        this.socketMessenger?.close();
+        this.socketMessenger = null;
+        this.queue = new promised_based_queue_1.PromisedBasedQueue();
+        this.currentMessage = null;
+        this.currentResolve = null;
+        this.currentReject = null;
+        this._enabled = undefined;
+        this._out?.close();
+        this._err?.close();
+        this._out = null;
+        this._err = null;
+        this._daemonStatus = DaemonStatus.DISCONNECTED;
+        this._waitForDaemonReady = new Promise((resolve) => (this._daemonReady = resolve));
+    }
+    async requestShutdown() {
+        return this.sendToDaemonViaQueue({ type: 'REQUEST_SHUTDOWN' });
+    }
+    async getProjectGraphAndSourceMaps() {
+        const response = await this.sendToDaemonViaQueue({
+            type: 'REQUEST_PROJECT_GRAPH',
+        });
+        return {
+            projectGraph: response.projectGraph,
+            sourceMaps: response.sourceMaps,
+        };
+    }
+    async getAllFileData() {
+        return await this.sendToDaemonViaQueue({ type: 'REQUEST_FILE_DATA' });
+    }
+    hashTasks(runnerOptions, tasks, taskGraph, env) {
+        return this.sendToDaemonViaQueue({
+            type: 'HASH_TASKS',
+            runnerOptions,
+            env,
+            tasks,
+            taskGraph,
+        });
+    }
+    async registerFileWatcher(config, callback) {
+        await this.getProjectGraphAndSourceMaps();
+        let messenger;
+        await this.queue.sendToQueue(() => {
+            messenger = new daemon_socket_messenger_1.DaemonSocketMessenger((0, net_1.connect)(socket_utils_1.FULL_OS_SOCKET_PATH)).listen((message) => {
+                try {
+                    const parsedMessage = JSON.parse(message);
+                    callback(null, parsedMessage);
+                }
+                catch (e) {
+                    callback(e, null);
+                }
+            }, () => {
+                callback('closed', null);
+            }, (err) => callback(err, null));
+            return messenger.sendMessage({ type: 'REGISTER_FILE_WATCHER', config });
+        });
+        return () => {
+            messenger?.close();
+        };
+    }
+    processInBackground(requirePath, data) {
+        return this.sendToDaemonViaQueue({
+            type: 'PROCESS_IN_BACKGROUND',
+            requirePath,
+            data,
+        });
+    }
+    recordOutputsHash(outputs, hash) {
+        return this.sendToDaemonViaQueue({
+            type: 'RECORD_OUTPUTS_HASH',
+            data: {
+                outputs,
+                hash,
+            },
+        });
+    }
+    outputsHashesMatch(outputs, hash) {
+        return this.sendToDaemonViaQueue({
+            type: 'OUTPUTS_HASHES_MATCH',
+            data: {
+                outputs,
+                hash,
+            },
+        });
+    }
+    async isServerAvailable() {
+        return new Promise((resolve) => {
+            try {
+                const socket = (0, net_1.connect)(socket_utils_1.FULL_OS_SOCKET_PATH, () => {
+                    socket.destroy();
+                    resolve(true);
+                });
+                socket.once('error', () => {
+                    resolve(false);
+                });
+            }
+            catch (err) {
+                resolve(false);
+            }
+        });
+    }
+    async sendToDaemonViaQueue(messageToDaemon) {
+        return this.queue.sendToQueue(() => this.sendMessageToDaemon(messageToDaemon));
+    }
+    setUpConnection() {
+        this.socketMessenger = new daemon_socket_messenger_1.DaemonSocketMessenger((0, net_1.connect)(socket_utils_1.FULL_OS_SOCKET_PATH)).listen((message) => this.handleMessage(message), () => {
+            // it's ok for the daemon to terminate if the client doesn't wait on
+            // any messages from the daemon
+            if (this.queue.isEmpty()) {
+                this.reset();
+            }
+            else {
+                output_1.output.error({
+                    title: 'Daemon process terminated and closed the connection',
+                    bodyLines: [
+                        'Please rerun the command, which will restart the daemon.',
+                        `If you get this error again, check for any errors in the daemon process logs found in: ${tmp_dir_1.DAEMON_OUTPUT_LOG_FILE}`,
+                    ],
+                });
+                this._daemonStatus = DaemonStatus.DISCONNECTED;
+                this.currentReject?.(daemonProcessException('Daemon process terminated and closed the connection'));
+                process.exit(1);
+            }
+        }, (err) => {
+            if (!err.message) {
+                return this.currentReject(daemonProcessException(err.toString()));
+            }
+            if (err.message.startsWith('LOCK-FILES-CHANGED')) {
+                // retry the current message
+                // we cannot send it via the queue because we are in the middle of processing
+                // a message from the queue
+                return this.sendMessageToDaemon(this.currentMessage).then(this.currentResolve, this.currentReject);
+            }
+            let error;
+            if (err.message.startsWith('connect ENOENT')) {
+                error = daemonProcessException('The Daemon Server is not running');
+            }
+            else if (err.message.startsWith('connect ECONNREFUSED')) {
+                error = daemonProcessException(`A server instance had not been fully shut down. Please try running the command again.`);
+                (0, socket_utils_1.killSocketOrPath)();
+            }
+            else if (err.message.startsWith('read ECONNRESET')) {
+                error = daemonProcessException(`Unable to connect to the daemon process.`);
+            }
+            else {
+                error = daemonProcessException(err.toString());
+            }
+            return this.currentReject(error);
+        });
+    }
+    async sendMessageToDaemon(message) {
+        if (this._daemonStatus == DaemonStatus.DISCONNECTED) {
+            this._daemonStatus = DaemonStatus.CONNECTING;
+            if (!(await this.isServerAvailable())) {
+                await this.startInBackground();
+            }
+            this.setUpConnection();
+            this._daemonStatus = DaemonStatus.CONNECTED;
+            this._daemonReady();
+        }
+        else if (this._daemonStatus == DaemonStatus.CONNECTING) {
+            await this._waitForDaemonReady;
+        }
+        return new Promise((resolve, reject) => {
+            perf_hooks_1.performance.mark('sendMessageToDaemon-start');
+            this.currentMessage = message;
+            this.currentResolve = resolve;
+            this.currentReject = reject;
+            this.socketMessenger.sendMessage(message);
+        });
+    }
+    handleMessage(serializedResult) {
+        try {
+            perf_hooks_1.performance.mark('json-parse-start');
+            const parsedResult = JSON.parse(serializedResult);
+            perf_hooks_1.performance.mark('json-parse-end');
+            perf_hooks_1.performance.measure('deserialize daemon response', 'json-parse-start', 'json-parse-end');
+            if (parsedResult.error) {
+                this.currentReject(parsedResult.error);
+            }
+            else {
+                perf_hooks_1.performance.measure('total for sendMessageToDaemon()', 'sendMessageToDaemon-start', 'json-parse-end');
+                return this.currentResolve(parsedResult);
+            }
+        }
+        catch (e) {
+            const endOfResponse = serializedResult.length > 300
+                ? serializedResult.substring(serializedResult.length - 300)
+                : serializedResult;
+            this.currentReject(daemonProcessException([
+                'Could not deserialize response from Nx daemon.',
+                `Message: ${e.message}`,
+                '\n',
+                `Received:`,
+                endOfResponse,
+                '\n',
+            ].join('\n')));
+        }
+    }
+    async startInBackground() {
+        (0, fs_extra_1.ensureDirSync)(tmp_dir_1.DAEMON_DIR_FOR_CURRENT_WORKSPACE);
+        (0, fs_extra_1.ensureFileSync)(tmp_dir_1.DAEMON_OUTPUT_LOG_FILE);
+        this._out = await (0, promises_1.open)(tmp_dir_1.DAEMON_OUTPUT_LOG_FILE, 'a');
+        this._err = await (0, promises_1.open)(tmp_dir_1.DAEMON_OUTPUT_LOG_FILE, 'a');
+        const backgroundProcess = (0, child_process_1.spawn)(process.execPath, [(0, path_1.join)(__dirname, '../server/start.js')], {
+            cwd: workspace_root_1.workspaceRoot,
+            stdio: ['ignore', this._out.fd, this._err.fd],
+            detached: true,
+            windowsHide: true,
+            shell: false,
+            env: DAEMON_ENV_SETTINGS,
+        });
+        backgroundProcess.unref();
+        /**
+         * Ensure the server is actually available to connect to via IPC before resolving
+         */
+        let attempts = 0;
+        return new Promise((resolve, reject) => {
+            const id = setInterval(async () => {
+                if (await this.isServerAvailable()) {
+                    clearInterval(id);
+                    resolve(backgroundProcess.pid);
+                }
+                else if (attempts > 6000) {
+                    // daemon fails to start, the process probably exited
+                    // we print the logs and exit the client
+                    reject(daemonProcessException('Failed to start or connect to the Nx Daemon process.'));
+                }
+                else {
+                    attempts++;
+                }
+            }, 10);
+        });
+    }
+    async stop() {
+        try {
+            await (0, cache_1.safelyCleanUpExistingProcess)();
+        }
+        catch (err) {
+            output_1.output.error({
+                title: err?.message ||
+                    'Something unexpected went wrong when stopping the server',
+            });
+        }
+        (0, tmp_dir_1.removeSocketDir)();
+    }
+}
+exports.DaemonClient = DaemonClient;
+exports.daemonClient = new DaemonClient((0, configuration_1.readNxJson)());
+function isDocker() {
+    try {
+        (0, fs_1.statSync)('/.dockerenv');
+        return true;
     }
-  });
+    catch {
+        try {
+            return (0, fs_1.readFileSync)('/proc/self/cgroup', 'utf8')?.includes('docker');
+        }
+        catch { }
+        return false;
+    }
+}
+function nxJsonIsNotPresent() {
+    return !(0, nx_json_1.hasNxJson)(workspace_root_1.workspaceRoot);
+}
+function daemonProcessException(message) {
+    try {
+        let log = (0, fs_1.readFileSync)(tmp_dir_1.DAEMON_OUTPUT_LOG_FILE).toString().split('\n');
+        if (log.length > 20) {
+            log = log.slice(log.length - 20);
+        }
+        const error = new Error([
+            message,
+            '',
+            'Messages from the log:',
+            ...log,
+            '\n',
+            `More information: ${tmp_dir_1.DAEMON_OUTPUT_LOG_FILE}`,
+        ].join('\n'));
+        error.internalDaemonError = true;
+        return error;
+    }
+    catch (e) {
+        return new Error(message);
+    }
+}
 
-  // src/typescript/typescript.ts
-  var require_typescript = __commonJS({
-    "src/typescript/typescript.ts"(exports, module2) {
-      init_ts6();
-      init_ts6();
-      if (typeof console !== "undefined") {
-        Debug.loggingHost = {
-          log(level, s) {
-            switch (level) {
-              case 1 /* Error */:
-                return console.error(s);
-              case 2 /* Warning */:
-                return console.warn(s);
-              case 3 /* Info */:
-                return console.log(s);
-              case 4 /* Verbose */:
-                return console.log(s);
+
+/***/ }),
+
+/***/ 30386:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
+
+"use strict";
+
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.DaemonSocketMessenger = void 0;
+const consume_messages_from_socket_1 = __nccwpck_require__(22214);
+class DaemonSocketMessenger {
+    constructor(socket) {
+        this.socket = socket;
+    }
+    async sendMessage(messageToDaemon) {
+        this.socket.write(JSON.stringify(messageToDaemon));
+        // send EOT to indicate that the message has been fully written
+        this.socket.write(String.fromCodePoint(4));
+    }
+    listen(onData, onClose = () => { }, onError = (err) => { }) {
+        this.socket.on('data', (0, consume_messages_from_socket_1.consumeMessagesFromSocket)(async (message) => {
+            onData(message);
+        }));
+        this.socket.on('close', onClose);
+        this.socket.on('error', onError);
+        return this;
+    }
+    close() {
+        this.socket.destroy();
+    }
+}
+exports.DaemonSocketMessenger = DaemonSocketMessenger;
+
+
+/***/ }),
+
+/***/ 10023:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
+
+"use strict";
+
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.serializeResult = exports.killSocketOrPath = exports.FORKED_PROCESS_OS_SOCKET_PATH = exports.FULL_OS_SOCKET_PATH = exports.isWindows = void 0;
+const fs_1 = __nccwpck_require__(57147);
+const os_1 = __nccwpck_require__(22037);
+const path_1 = __nccwpck_require__(71017);
+const tmp_dir_1 = __nccwpck_require__(78543);
+exports.isWindows = (0, os_1.platform)() === 'win32';
+/**
+ * For IPC with the daemon server we use unix sockets or windows named pipes, depending on the user's operating system.
+ *
+ * See https://nodejs.org/dist/latest-v14.x/docs/api/net.html#net_identifying_paths_for_ipc_connections for a full breakdown
+ * of OS differences between Unix domain sockets and named pipes.
+ */
+exports.FULL_OS_SOCKET_PATH = exports.isWindows
+    ? '\\\\.\\pipe\\nx\\' + (0, path_1.resolve)(tmp_dir_1.DAEMON_SOCKET_PATH)
+    : (0, path_1.resolve)(tmp_dir_1.DAEMON_SOCKET_PATH);
+const FORKED_PROCESS_OS_SOCKET_PATH = (id) => {
+    let path = (0, path_1.resolve)((0, path_1.join)(tmp_dir_1.socketDir, 'fp' + id + '.sock'));
+    return exports.isWindows ? '\\\\.\\pipe\\nx\\' + (0, path_1.resolve)(path) : (0, path_1.resolve)(path);
+};
+exports.FORKED_PROCESS_OS_SOCKET_PATH = FORKED_PROCESS_OS_SOCKET_PATH;
+function killSocketOrPath() {
+    try {
+        (0, fs_1.unlinkSync)(exports.FULL_OS_SOCKET_PATH);
+    }
+    catch { }
+}
+exports.killSocketOrPath = killSocketOrPath;
+// Include the original stack trace within the serialized error so that the client can show it to the user.
+function serializeError(error) {
+    if (!error) {
+        return null;
+    }
+    return JSON.stringify(error, Object.getOwnPropertyNames(error));
+}
+// Prepare a serialized project graph result for sending over IPC from the server to the client
+function serializeResult(error, serializedProjectGraph, serializedSourceMaps) {
+    // We do not want to repeat work `JSON.stringify`ing an object containing the potentially large project graph so merge as strings
+    return `{ "error": ${serializeError(error)}, "projectGraph": ${serializedProjectGraph}, "sourceMaps": ${serializedSourceMaps} }`;
+}
+exports.serializeResult = serializeResult;
+
+
+/***/ }),
+
+/***/ 78543:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
+
+"use strict";
+
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.removeSocketDir = exports.isDaemonDisabled = exports.markDaemonAsDisabled = exports.writeDaemonLogs = exports.DAEMON_SOCKET_PATH = exports.socketDir = exports.DAEMON_OUTPUT_LOG_FILE = exports.DAEMON_DIR_FOR_CURRENT_WORKSPACE = void 0;
+/**
+ * Per workspace (to avoid subtle differences and issues), we want to have a deterministic
+ * location within the OS's tmp directory where we write log files for background processes
+ * and where we create the actual unix socket/named pipe for the daemon.
+ */
+const fs_1 = __nccwpck_require__(57147);
+const fs_extra_1 = __nccwpck_require__(27475);
+const path_1 = __nccwpck_require__(71017);
+const cache_directory_1 = __nccwpck_require__(15120);
+const crypto_1 = __nccwpck_require__(6113);
+const tmp_1 = __nccwpck_require__(81866);
+const workspace_root_1 = __nccwpck_require__(86708);
+exports.DAEMON_DIR_FOR_CURRENT_WORKSPACE = (0, path_1.join)(cache_directory_1.projectGraphCacheDirectory, 'd');
+exports.DAEMON_OUTPUT_LOG_FILE = (0, path_1.join)(exports.DAEMON_DIR_FOR_CURRENT_WORKSPACE, 'daemon.log');
+exports.socketDir = process.env.NX_DAEMON_SOCKET_DIR || createSocketDir();
+exports.DAEMON_SOCKET_PATH = (0, path_1.join)(exports.socketDir, 
+// As per notes above on socket/named pipe length limitations, we keep this intentionally short
+'d.sock');
+function writeDaemonLogs(error) {
+    const file = (0, path_1.join)(exports.DAEMON_DIR_FOR_CURRENT_WORKSPACE, 'daemon-error.log');
+    (0, fs_1.writeFileSync)(file, error);
+    return file;
+}
+exports.writeDaemonLogs = writeDaemonLogs;
+function markDaemonAsDisabled() {
+    (0, fs_1.writeFileSync)((0, path_1.join)(exports.DAEMON_DIR_FOR_CURRENT_WORKSPACE, 'disabled'), 'true');
+}
+exports.markDaemonAsDisabled = markDaemonAsDisabled;
+function isDaemonDisabled() {
+    try {
+        (0, fs_1.statSync)((0, path_1.join)(exports.DAEMON_DIR_FOR_CURRENT_WORKSPACE, 'disabled'));
+        return true;
+    }
+    catch (e) {
+        return false;
+    }
+}
+exports.isDaemonDisabled = isDaemonDisabled;
+function socketDirName() {
+    const hasher = (0, crypto_1.createHash)('sha256');
+    hasher.update(workspace_root_1.workspaceRoot.toLowerCase());
+    const unique = hasher.digest('hex').substring(0, 20);
+    return (0, path_1.join)(tmp_1.tmpdir, unique);
+}
+/**
+ * We try to create a socket file in a tmp dir, but if it doesn't work because
+ * for instance we don't have permissions, we create it in DAEMON_DIR_FOR_CURRENT_WORKSPACE
+ */
+function createSocketDir() {
+    try {
+        const dir = socketDirName();
+        (0, fs_extra_1.ensureDirSync)(dir);
+        return dir;
+    }
+    catch (e) {
+        return exports.DAEMON_DIR_FOR_CURRENT_WORKSPACE;
+    }
+}
+function removeSocketDir() {
+    try {
+        (0, fs_extra_1.rmSync)(exports.socketDir, { recursive: true, force: true });
+    }
+    catch (e) { }
+}
+exports.removeSocketDir = removeSocketDir;
+
+
+/***/ }),
+
+/***/ 11385:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
+
+"use strict";
+
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.printChanges = exports.flushChanges = exports.FsTree = void 0;
+const fs_extra_1 = __nccwpck_require__(27475);
+const logger_1 = __nccwpck_require__(39299);
+const output_1 = __nccwpck_require__(1737);
+const path_1 = __nccwpck_require__(71017);
+const chalk = __nccwpck_require__(36662);
+class FsTree {
+    constructor(root, isVerbose, logOperationId) {
+        this.root = root;
+        this.isVerbose = isVerbose;
+        this.logOperationId = logOperationId;
+        this.recordedChanges = {};
+        /**
+         * Signifies if operations on the tree instance
+         * are allowed. Set to false after changes are written
+         * to disk, to prevent someone trying to use the tree to update
+         * files when the tree is no longer effective.
+         */
+        this.locked = false;
+    }
+    read(filePath, encoding) {
+        filePath = this.normalize(filePath);
+        try {
+            let content;
+            if (this.recordedChanges[this.rp(filePath)]) {
+                content = this.recordedChanges[this.rp(filePath)].content;
             }
-          }
+            else {
+                content = this.fsReadFile(filePath);
+            }
+            return encoding ? content.toString(encoding) : content;
+        }
+        catch (e) {
+            if (this.isVerbose) {
+                logger_1.logger.error(e);
+            }
+            return null;
+        }
+    }
+    write(filePath, content, options) {
+        this.assertUnlocked();
+        filePath = this.normalize(filePath);
+        // Remove any recorded changes where a parent directory has been
+        // deleted when writing a new file within the directory.
+        let parent = (0, path_1.dirname)(this.rp(filePath));
+        while (parent !== '.') {
+            if (this.recordedChanges[parent]?.isDeleted) {
+                delete this.recordedChanges[parent];
+            }
+            parent = (0, path_1.dirname)(parent);
+        }
+        if (this.fsExists(this.rp(filePath)) &&
+            Buffer.from(content).equals(this.fsReadFile(filePath))) {
+            // Remove recorded change because the file has been restored to it's original contents
+            delete this.recordedChanges[this.rp(filePath)];
+            return;
+        }
+        try {
+            this.recordedChanges[this.rp(filePath)] = {
+                content: Buffer.from(content),
+                isDeleted: false,
+                options,
+            };
+        }
+        catch (e) {
+            if (this.isVerbose) {
+                logger_1.logger.error(e);
+            }
+        }
+    }
+    overwrite(filePath, content, options) {
+        filePath = this.normalize(filePath);
+        this.write(filePath, content, options);
+    }
+    delete(filePath) {
+        this.assertUnlocked();
+        filePath = this.normalize(filePath);
+        if (this.filesForDir(this.rp(filePath)).length > 0) {
+            this.filesForDir(this.rp(filePath)).forEach((f) => (this.recordedChanges[f] = { content: null, isDeleted: true }));
+        }
+        this.recordedChanges[this.rp(filePath)] = {
+            content: null,
+            isDeleted: true,
         };
-      }
-      module2.exports = ts_exports2;
+        // Delete directory when is not root and there are no children
+        if (filePath !== '' &&
+            this.children((0, path_1.dirname)(this.rp(filePath))).length < 1) {
+            this.delete((0, path_1.dirname)(this.rp(filePath)));
+        }
     }
-  });
-  return require_typescript();
-})();
-
-if ( true && module.exports) { module.exports = ts; }
-//# sourceMappingURL=typescript.js.map
+    exists(filePath) {
+        filePath = this.normalize(filePath);
+        try {
+            if (this.recordedChanges[this.rp(filePath)]) {
+                return !this.recordedChanges[this.rp(filePath)].isDeleted;
+            }
+            else if (this.filesForDir(this.rp(filePath)).length > 0) {
+                return true;
+            }
+            else {
+                return this.fsExists(filePath);
+            }
+        }
+        catch {
+            return false;
+        }
+    }
+    rename(from, to) {
+        this.assertUnlocked();
+        from = this.normalize(from);
+        to = this.normalize(to);
+        if (from === to) {
+            return;
+        }
+        if (this.isFile(from)) {
+            const content = this.read(this.rp(from));
+            this.write(this.rp(to), content);
+            this.delete(this.rp(from));
+        }
+        else {
+            for (const child of this.children(from)) {
+                this.rename((0, path_1.join)(from, child), (0, path_1.join)(to, child));
+            }
+        }
+    }
+    isFile(filePath) {
+        filePath = this.normalize(filePath);
+        try {
+            if (this.recordedChanges[this.rp(filePath)]) {
+                return !this.recordedChanges[this.rp(filePath)].isDeleted;
+            }
+            else {
+                return this.fsIsFile(filePath);
+            }
+        }
+        catch {
+            return false;
+        }
+    }
+    children(dirPath) {
+        dirPath = this.normalize(dirPath);
+        let res = this.fsReadDir(dirPath);
+        res = [...res, ...this.directChildrenOfDir(this.rp(dirPath))];
+        res = res.filter((q) => {
+            const r = this.recordedChanges[this.normalize((0, path_1.join)(this.rp(dirPath), q))];
+            return !r?.isDeleted;
+        });
+        // Dedupe
+        return Array.from(new Set(res));
+    }
+    listChanges() {
+        const res = [];
+        Object.keys(this.recordedChanges).forEach((f) => {
+            if (this.recordedChanges[f].isDeleted) {
+                if (this.fsExists(f)) {
+                    res.push({ path: f, type: 'DELETE', content: null });
+                }
+            }
+            else {
+                if (this.fsExists(f)) {
+                    res.push({
+                        path: f,
+                        type: 'UPDATE',
+                        content: this.recordedChanges[f].content,
+                        options: this.recordedChanges[f].options,
+                    });
+                }
+                else {
+                    res.push({
+                        path: f,
+                        type: 'CREATE',
+                        content: this.recordedChanges[f].content,
+                        options: this.recordedChanges[f].options,
+                    });
+                }
+            }
+        });
+        return res;
+    }
+    changePermissions(filePath, mode) {
+        this.assertUnlocked();
+        filePath = this.normalize(filePath);
+        const filePathChangeKey = this.rp(filePath);
+        if (this.recordedChanges[filePathChangeKey]) {
+            if (this.recordedChanges[filePathChangeKey].isDeleted) {
+                throw new Error(`Cannot change permissions of deleted file ${filePath}.`);
+            }
+            this.recordedChanges[filePathChangeKey].options = { mode };
+        }
+        else if (!this.fsExists(filePath)) {
+            throw new Error(`Cannot change permissions of non-existing file ${filePath}.`);
+        }
+        else if (!this.fsIsFile(filePath)) {
+            // To fully support directories we'd need to change how we store
+            // changes to keep a record of directories so we can associate
+            // permissions to them.
+            throw new Error(`Cannot change permissions of non-file ${filePath}.`);
+        }
+        else {
+            this.recordedChanges[filePathChangeKey] = {
+                content: this.fsReadFile(filePath),
+                isDeleted: false,
+                options: { mode },
+            };
+        }
+    }
+    // Marks FsTree as final.
+    lock() {
+        this.locked = true;
+    }
+    assertUnlocked() {
+        if (this.locked) {
+            output_1.output.error({
+                title: `File changes have already been written to disk. Further changes were attempted ${this.logOperationId ? ` while running ${this.logOperationId}.` : '.'}`,
+                bodyLines: [
+                    'The file system can no longer be modified. This commonly happens when a generator attempts to make further changes in its callback, or an asynchronous operation is still running after the generator completes.',
+                ],
+            });
+            throw new Error('Tree changed after commit to disk.');
+        }
+    }
+    normalize(path) {
+        return (0, path_1.relative)(this.root, (0, path_1.join)(this.root, path)).split(path_1.sep).join('/');
+    }
+    fsReadDir(dirPath) {
+        try {
+            return (0, fs_extra_1.readdirSync)((0, path_1.join)(this.root, dirPath));
+        }
+        catch {
+            return [];
+        }
+    }
+    fsIsFile(filePath) {
+        const stat = (0, fs_extra_1.statSync)((0, path_1.join)(this.root, filePath));
+        return stat.isFile();
+    }
+    fsReadFile(filePath) {
+        return (0, fs_extra_1.readFileSync)((0, path_1.join)(this.root, filePath));
+    }
+    fsExists(filePath) {
+        try {
+            const stat = (0, fs_extra_1.statSync)((0, path_1.join)(this.root, filePath));
+            return stat.isFile() || stat.isDirectory();
+        }
+        catch {
+            return false;
+        }
+    }
+    filesForDir(path) {
+        return Object.keys(this.recordedChanges).filter((f) => f.startsWith(`${path}/`) && !this.recordedChanges[f].isDeleted);
+    }
+    directChildrenOfDir(path) {
+        const res = {};
+        if (path === '') {
+            return Object.keys(this.recordedChanges).map((file) => file.split('/')[0]);
+        }
+        Object.keys(this.recordedChanges).forEach((f) => {
+            if (f.startsWith(`${path}/`)) {
+                // Remove the current folder's path from the directory
+                const file = f.substring(path.length + 1);
+                // Split the path on segments, and take the first one
+                const basePath = file.split('/')[0];
+                // Mark it as a child of the current directory
+                res[basePath] = true;
+            }
+        });
+        return Object.keys(res);
+    }
+    rp(pp) {
+        return pp.startsWith('/') ? pp.substring(1) : pp;
+    }
+}
+exports.FsTree = FsTree;
+function flushChanges(root, fileChanges) {
+    fileChanges.forEach((f) => {
+        const fpath = (0, path_1.join)(root, f.path);
+        if (f.type === 'CREATE') {
+            (0, fs_extra_1.ensureDirSync)((0, path_1.dirname)(fpath));
+            (0, fs_extra_1.writeFileSync)(fpath, f.content);
+            if (f.options?.mode)
+                (0, fs_extra_1.chmodSync)(fpath, f.options.mode);
+        }
+        else if (f.type === 'UPDATE') {
+            (0, fs_extra_1.writeFileSync)(fpath, f.content);
+            if (f.options?.mode)
+                (0, fs_extra_1.chmodSync)(fpath, f.options.mode);
+        }
+        else if (f.type === 'DELETE') {
+            (0, fs_extra_1.removeSync)(fpath);
+        }
+    });
+}
+exports.flushChanges = flushChanges;
+function printChanges(fileChanges, indent = '') {
+    fileChanges.forEach((f) => {
+        if (f.type === 'CREATE') {
+            console.log(`${indent}${chalk.green('CREATE')} ${f.path}`);
+        }
+        else if (f.type === 'UPDATE') {
+            console.log(`${indent}${chalk.white('UPDATE')} ${f.path}`);
+        }
+        else if (f.type === 'DELETE') {
+            console.log(`${indent}${chalk.yellow('DELETE')} ${f.path}`);
+        }
+    });
+}
+exports.printChanges = printChanges;
 
 
 /***/ }),
 
-/***/ 82787:
-/***/ ((__unused_webpack_module, exports) => {
+/***/ 29855:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
 "use strict";
 
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.updateJson = exports.writeJson = exports.readJson = void 0;
+const json_1 = __nccwpck_require__(8314);
+/**
+ * Reads a json file, removes all comments and parses JSON.
+ *
+ * @param tree - file system tree
+ * @param path - file path
+ * @param options - Optional JSON Parse Options
+ */
+function readJson(tree, path, options) {
+    if (!tree.exists(path)) {
+        throw new Error(`Cannot find ${path}`);
+    }
+    try {
+        return (0, json_1.parseJson)(tree.read(path, 'utf-8'), options);
+    }
+    catch (e) {
+        throw new Error(`Cannot parse ${path}: ${e.message}`);
+    }
+}
+exports.readJson = readJson;
+/**
+ * Writes a JSON value to the file system tree
+
+ * @param tree File system tree
+ * @param path Path of JSON file in the Tree
+ * @param value Serializable value to write
+ * @param options Optional JSON Serialize Options
+ */
+function writeJson(tree, path, value, options) {
+    tree.write(path, (0, json_1.serializeJson)(value, options));
+}
+exports.writeJson = writeJson;
+/**
+ * Updates a JSON value to the file system tree
+ *
+ * @param tree File system tree
+ * @param path Path of JSON file in the Tree
+ * @param updater Function that maps the current value of a JSON document to a new value to be written to the document
+ * @param options Optional JSON Parse and Serialize Options
+ */
+function updateJson(tree, path, updater, options) {
+    const updatedValue = updater(readJson(tree, path, options));
+    writeJson(tree, path, updatedValue, options);
+}
+exports.updateJson = updateJson;
+
 
-exports.fromCallback = function (fn) {
-  return Object.defineProperty(function (...args) {
-    if (typeof args[args.length - 1] === 'function') fn.apply(this, args)
+/***/ }),
+
+/***/ 82938:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
+
+"use strict";
+
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.updateNxJson = exports.readNxJson = void 0;
+const path_1 = __nccwpck_require__(71017);
+const json_1 = __nccwpck_require__(29855);
+const nx_json_1 = __nccwpck_require__(53619);
+/**
+ * Reads nx.json
+ */
+function readNxJson(tree) {
+    if (tree) {
+        if (!tree.exists('nx.json')) {
+            return null;
+        }
+        let nxJson = (0, json_1.readJson)(tree, 'nx.json');
+        if (nxJson.extends) {
+            nxJson = { ...readNxJsonExtends(tree, nxJson.extends), ...nxJson };
+        }
+        return nxJson;
+    }
     else {
-      return new Promise((resolve, reject) => {
-        fn.call(
-          this,
-          ...args,
-          (err, res) => (err != null) ? reject(err) : resolve(res)
-        )
-      })
+        return (0, nx_json_1.readNxJson)();
+    }
+}
+exports.readNxJson = readNxJson;
+/**
+ * Update nx.json
+ */
+function updateNxJson(tree, nxJson) {
+    if (tree.exists('nx.json')) {
+        (0, json_1.updateJson)(tree, 'nx.json', (json) => {
+            if (json.extends) {
+                const nxJsonExtends = readNxJsonExtends(tree, json.extends);
+                const changedPropsOfNxJson = {};
+                Object.keys(nxJson).forEach((prop) => {
+                    if (JSON.stringify(nxJson[prop], null, 2) !=
+                        JSON.stringify(nxJsonExtends[prop], null, 2)) {
+                        changedPropsOfNxJson[prop] = nxJson[prop];
+                    }
+                });
+                return changedPropsOfNxJson;
+            }
+            else {
+                return nxJson;
+            }
+        });
+    }
+}
+exports.updateNxJson = updateNxJson;
+function readNxJsonExtends(tree, extendsPath) {
+    try {
+        return (0, json_1.readJson)(tree, (0, path_1.relative)(tree.root, require.resolve(extendsPath, {
+            paths: [tree.root],
+        })));
+    }
+    catch (e) {
+        throw new Error(`Unable to resolve nx.json extends. Error: ${e.message}`);
     }
-  }, 'name', { value: fn.name })
 }
 
-exports.fromPromise = function (fn) {
-  return Object.defineProperty(function (...args) {
-    const cb = args[args.length - 1]
-    if (typeof cb !== 'function') return fn.apply(this, args)
-    else fn.apply(this, args.slice(0, -1)).then(r => cb(null, r), cb)
-  }, 'name', { value: fn.name })
+
+/***/ }),
+
+/***/ 1934:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
+
+"use strict";
+
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.getRelativeProjectJsonSchemaPath = exports.getProjects = exports.readProjectConfiguration = exports.removeProjectConfiguration = exports.updateProjectConfiguration = exports.addProjectConfiguration = exports.updateNxJson = exports.readNxJson = void 0;
+const minimatch_1 = __nccwpck_require__(55224);
+const path_1 = __nccwpck_require__(71017);
+const package_json_workspaces_1 = __nccwpck_require__(65286);
+const project_json_1 = __nccwpck_require__(76877);
+const angular_json_1 = __nccwpck_require__(44050);
+const project_configuration_utils_1 = __nccwpck_require__(33190);
+const retrieve_workspace_files_1 = __nccwpck_require__(14249);
+const workspace_context_1 = __nccwpck_require__(302);
+const output_1 = __nccwpck_require__(1737);
+const path_2 = __nccwpck_require__(38270);
+const json_1 = __nccwpck_require__(29855);
+const nx_json_1 = __nccwpck_require__(82938);
+var nx_json_2 = __nccwpck_require__(82938);
+Object.defineProperty(exports, "readNxJson", ({ enumerable: true, get: function () { return nx_json_2.readNxJson; } }));
+Object.defineProperty(exports, "updateNxJson", ({ enumerable: true, get: function () { return nx_json_2.updateNxJson; } }));
+/**
+ * Adds project configuration to the Nx workspace.
+ *
+ * @param tree - the file system tree
+ * @param projectName - unique name. Often directories are part of the name (e.g., mydir-mylib)
+ * @param projectConfiguration - project configuration
+ * @param standalone - whether the project is configured in workspace.json or not
+ */
+function addProjectConfiguration(tree, projectName, projectConfiguration, standalone = true) {
+    const projectConfigFile = (0, path_2.joinPathFragments)(projectConfiguration.root, 'project.json');
+    if (!standalone) {
+        output_1.output.warn({
+            title: 'Nx only supports standalone projects. Setting standalone to false is ignored.',
+        });
+    }
+    if (tree.exists(projectConfigFile)) {
+        throw new Error(`Cannot create a new project ${projectName} at ${projectConfiguration.root}. A project already exists in this directory.`);
+    }
+    delete projectConfiguration.$schema;
+    (0, json_1.writeJson)(tree, projectConfigFile, {
+        name: projectName,
+        $schema: getRelativeProjectJsonSchemaPath(tree, projectConfiguration),
+        ...projectConfiguration,
+        root: undefined,
+    });
+}
+exports.addProjectConfiguration = addProjectConfiguration;
+/**
+ * Updates the configuration of an existing project.
+ *
+ * @param tree - the file system tree
+ * @param projectName - unique name. Often directories are part of the name (e.g., mydir-mylib)
+ * @param projectConfiguration - project configuration
+ */
+function updateProjectConfiguration(tree, projectName, projectConfiguration) {
+    const projectConfigFile = (0, path_2.joinPathFragments)(projectConfiguration.root, 'project.json');
+    if (!tree.exists(projectConfigFile)) {
+        throw new Error(`Cannot update Project ${projectName} at ${projectConfiguration.root}. It either doesn't exist yet, or may not use project.json for configuration. Use \`addProjectConfiguration()\` instead if you want to create a new project.`);
+    }
+    (0, json_1.writeJson)(tree, projectConfigFile, {
+        name: projectConfiguration.name ?? projectName,
+        $schema: getRelativeProjectJsonSchemaPath(tree, projectConfiguration),
+        ...projectConfiguration,
+        root: undefined,
+    });
+}
+exports.updateProjectConfiguration = updateProjectConfiguration;
+/**
+ * Removes the configuration of an existing project.
+ *
+ * @param tree - the file system tree
+ * @param projectName - unique name. Often directories are part of the name (e.g., mydir-mylib)
+ */
+function removeProjectConfiguration(tree, projectName) {
+    const projectConfiguration = readProjectConfiguration(tree, projectName);
+    if (!projectConfiguration) {
+        throw new Error(`Cannot delete Project ${projectName}`);
+    }
+    const projectConfigFile = (0, path_2.joinPathFragments)(projectConfiguration.root, 'project.json');
+    if (tree.exists(projectConfigFile)) {
+        tree.delete(projectConfigFile);
+    }
+}
+exports.removeProjectConfiguration = removeProjectConfiguration;
+/**
+ * Reads a project configuration.
+ *
+ * @param tree - the file system tree
+ * @param projectName - unique name. Often directories are part of the name (e.g., mydir-mylib)
+ * @throws If supplied projectName cannot be found
+ */
+function readProjectConfiguration(tree, projectName) {
+    const allProjects = readAndCombineAllProjectConfigurations(tree);
+    if (!allProjects[projectName]) {
+        // temporary polyfill to make sure our generators work for existing angularcli workspaces
+        if (tree.exists('angular.json')) {
+            const angularJson = toNewFormat((0, json_1.readJson)(tree, 'angular.json'));
+            if (angularJson.projects[projectName])
+                return angularJson.projects[projectName];
+        }
+        throw new Error(`Cannot find configuration for '${projectName}'`);
+    }
+    return allProjects[projectName];
+}
+exports.readProjectConfiguration = readProjectConfiguration;
+/**
+ * Get a map of all projects in a workspace.
+ *
+ * Use {@link readProjectConfiguration} if only one project is needed.
+ */
+function getProjects(tree) {
+    let allProjects = readAndCombineAllProjectConfigurations(tree);
+    // temporary polyfill to make sure our generators work for existing angularcli workspaces
+    if (tree.exists('angular.json')) {
+        const angularJson = toNewFormat((0, json_1.readJson)(tree, 'angular.json'));
+        allProjects = { ...allProjects, ...angularJson.projects };
+    }
+    return new Map(Object.keys(allProjects || {}).map((projectName) => {
+        return [projectName, allProjects[projectName]];
+    }));
+}
+exports.getProjects = getProjects;
+function getRelativeProjectJsonSchemaPath(tree, project) {
+    return (0, path_2.normalizePath)((0, path_1.relative)((0, path_1.join)(tree.root, project.root), (0, path_1.join)(tree.root, 'node_modules/nx/schemas/project-schema.json')));
+}
+exports.getRelativeProjectJsonSchemaPath = getRelativeProjectJsonSchemaPath;
+function readAndCombineAllProjectConfigurations(tree) {
+    /**
+     * We can't update projects that come from plugins anyways, so we are going
+     * to ignore them for now. Plugins should add their own add/create/update methods
+     * if they would like to use devkit to update inferred projects.
+     */
+    const patterns = [
+        '**/project.json',
+        'project.json',
+        ...(0, package_json_workspaces_1.getGlobPatternsFromPackageManagerWorkspaces)(tree.root, (p) => (0, json_1.readJson)(tree, p)),
+    ];
+    const projectGlobPatterns = (0, retrieve_workspace_files_1.configurationGlobs)([
+        { plugin: project_json_1.ProjectJsonProjectsPlugin },
+        { plugin: (0, package_json_workspaces_1.getNxPackageJsonWorkspacesPlugin)(tree.root) },
+    ]);
+    const globbedFiles = (0, workspace_context_1.globWithWorkspaceContext)(tree.root, projectGlobPatterns);
+    const createdFiles = findCreatedProjectFiles(tree, patterns);
+    const deletedFiles = findDeletedProjectFiles(tree, patterns);
+    const projectFiles = [...globbedFiles, ...createdFiles].filter((r) => deletedFiles.indexOf(r) === -1);
+    const rootMap = new Map();
+    for (const projectFile of projectFiles) {
+        if ((0, path_1.basename)(projectFile) === 'project.json') {
+            const json = (0, json_1.readJson)(tree, projectFile);
+            const config = (0, project_json_1.buildProjectFromProjectJson)(json, projectFile);
+            (0, project_configuration_utils_1.mergeProjectConfigurationIntoRootMap)(rootMap, config, undefined, undefined, true);
+        }
+        else if ((0, path_1.basename)(projectFile) === 'package.json') {
+            const packageJson = (0, json_1.readJson)(tree, projectFile);
+            const config = (0, package_json_workspaces_1.buildProjectConfigurationFromPackageJson)(packageJson, projectFile, (0, nx_json_1.readNxJson)(tree));
+            if (!rootMap.has(config.root)) {
+                (0, project_configuration_utils_1.mergeProjectConfigurationIntoRootMap)(rootMap, 
+                // Inferred targets, tags, etc don't show up when running generators
+                // This is to help avoid running into issues when trying to update the workspace
+                {
+                    name: config.name,
+                    root: config.root,
+                }, undefined, undefined, true);
+            }
+        }
+    }
+    return (0, project_configuration_utils_1.readProjectConfigurationsFromRootMap)(rootMap);
+}
+/**
+ * Used to ensure that projects created during
+ * the same devkit generator run show up when
+ * there is no project.json file, as `glob`
+ * cannot find them.
+ *
+ * We exclude the root `package.json` from this list unless
+ * considered a project during workspace generation
+ */
+function findCreatedProjectFiles(tree, globPatterns) {
+    const createdProjectFiles = [];
+    for (const change of tree.listChanges()) {
+        if (change.type === 'CREATE') {
+            const fileName = (0, path_1.basename)(change.path);
+            if (globPatterns.some((pattern) => (0, minimatch_1.minimatch)(change.path, pattern, { dot: true }))) {
+                createdProjectFiles.push(change.path);
+            }
+            else if (fileName === 'package.json') {
+                try {
+                    const contents = JSON.parse(change.content.toString());
+                    if (contents.nx) {
+                        createdProjectFiles.push(change.path);
+                    }
+                }
+                catch { }
+            }
+        }
+    }
+    return createdProjectFiles.map(path_2.normalizePath);
+}
+/**
+ * Used to ensure that projects created during
+ * the same devkit generator run show up when
+ * there is no project.json file, as `glob`
+ * cannot find them.
+ */
+function findDeletedProjectFiles(tree, globPatterns) {
+    return tree
+        .listChanges()
+        .filter((f) => {
+        return (f.type === 'DELETE' &&
+            globPatterns.some((pattern) => (0, minimatch_1.minimatch)(f.path, pattern)));
+    })
+        .map((r) => r.path);
+}
+function toNewFormat(w) {
+    const projects = {};
+    Object.keys(w.projects || {}).forEach((name) => {
+        if (typeof w.projects[name] === 'string')
+            return;
+        const projectConfig = w.projects[name];
+        if (projectConfig.architect) {
+            (0, angular_json_1.renamePropertyWithStableKeys)(projectConfig, 'architect', 'targets');
+        }
+        if (projectConfig.schematics) {
+            (0, angular_json_1.renamePropertyWithStableKeys)(projectConfig, 'schematics', 'generators');
+        }
+        Object.values(projectConfig.targets || {}).forEach((target) => {
+            if (target.builder !== undefined) {
+                (0, angular_json_1.renamePropertyWithStableKeys)(target, 'builder', 'executor');
+            }
+        });
+        projects[name] = projectConfig;
+    });
+    w.projects = projects;
+    if (w.schematics) {
+        (0, angular_json_1.renamePropertyWithStableKeys)(w, 'schematics', 'generators');
+    }
+    if (w.version !== 2) {
+        w.version = 2;
+    }
+    return w;
+}
+
+
+/***/ }),
+
+/***/ 50180:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
+
+"use strict";
+
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.hashObject = exports.hashArray = void 0;
+function hashArray(content) {
+    // Import as needed. There is also an issue running unit tests in Nx repo if this is a top-level import.
+    const { hashArray } = __nccwpck_require__(74424);
+    return hashArray(content);
+}
+exports.hashArray = hashArray;
+function hashObject(obj) {
+    const { hashArray } = __nccwpck_require__(74424);
+    const parts = [];
+    for (const key of Object.keys(obj).sort()) {
+        parts.push(key);
+        parts.push(JSON.stringify(obj[key]));
+    }
+    return hashArray(parts);
 }
+exports.hashObject = hashObject;
 
 
 /***/ }),
 
-/***/ 40538:
+/***/ 74424:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
+const { existsSync, readFileSync } = __nccwpck_require__(57147)
+const { join } = __nccwpck_require__(71017)
+
+const { platform, arch } = process
+
+let nativeBinding = null
+let localFileExisted = false
+let loadError = null
+
+function isMusl() {
+  // For Node 10
+  if (!process.report || typeof process.report.getReport !== 'function') {
+    try {
+      const lddPath = (__nccwpck_require__(32081).execSync)('which ldd').toString().trim();
+      return readFileSync(lddPath, 'utf8').includes('musl')
+    } catch (e) {
+      return true
+    }
+  } else {
+    const { glibcVersionRuntime } = process.report.getReport().header
+    return !glibcVersionRuntime
+  }
+}
+
+switch (platform) {
+  case 'android':
+    switch (arch) {
+      case 'arm64':
+        localFileExisted = existsSync(join(__dirname, 'nx.android-arm64.node'))
+        try {
+          if (localFileExisted) {
+            nativeBinding = __nccwpck_require__(35137)
+          } else {
+            nativeBinding = __nccwpck_require__(89581)
+          }
+        } catch (e) {
+          loadError = e
+        }
+        break
+      case 'arm':
+        localFileExisted = existsSync(join(__dirname, 'nx.android-arm-eabi.node'))
+        try {
+          if (localFileExisted) {
+            nativeBinding = __nccwpck_require__(17377)
+          } else {
+            nativeBinding = __nccwpck_require__(63582)
+          }
+        } catch (e) {
+          loadError = e
+        }
+        break
+      default:
+        throw new Error(`Unsupported architecture on Android ${arch}`)
+    }
+    break
+  case 'win32':
+    switch (arch) {
+      case 'x64':
+        localFileExisted = existsSync(
+          join(__dirname, 'nx.win32-x64-msvc.node')
+        )
+        try {
+          if (localFileExisted) {
+            nativeBinding = __nccwpck_require__(82472)
+          } else {
+            nativeBinding = __nccwpck_require__(19959)
+          }
+        } catch (e) {
+          loadError = e
+        }
+        break
+      case 'ia32':
+        localFileExisted = existsSync(
+          join(__dirname, 'nx.win32-ia32-msvc.node')
+        )
+        try {
+          if (localFileExisted) {
+            nativeBinding = __nccwpck_require__(33821)
+          } else {
+            nativeBinding = __nccwpck_require__(85420)
+          }
+        } catch (e) {
+          loadError = e
+        }
+        break
+      case 'arm64':
+        localFileExisted = existsSync(
+          join(__dirname, 'nx.win32-arm64-msvc.node')
+        )
+        try {
+          if (localFileExisted) {
+            nativeBinding = __nccwpck_require__(16320)
+          } else {
+            nativeBinding = __nccwpck_require__(18146)
+          }
+        } catch (e) {
+          loadError = e
+        }
+        break
+      default:
+        throw new Error(`Unsupported architecture on Windows: ${arch}`)
+    }
+    break
+  case 'darwin':
+    localFileExisted = existsSync(join(__dirname, 'nx.darwin-universal.node'))
+    try {
+      if (localFileExisted) {
+        nativeBinding = __nccwpck_require__(52701)
+      } else {
+        nativeBinding = __nccwpck_require__(18912)
+      }
+      break
+    } catch {}
+    switch (arch) {
+      case 'x64':
+        localFileExisted = existsSync(join(__dirname, 'nx.darwin-x64.node'))
+        try {
+          if (localFileExisted) {
+            nativeBinding = __nccwpck_require__(1322)
+          } else {
+            nativeBinding = __nccwpck_require__(59194)
+          }
+        } catch (e) {
+          loadError = e
+        }
+        break
+      case 'arm64':
+        localFileExisted = existsSync(
+          join(__dirname, 'nx.darwin-arm64.node')
+        )
+        try {
+          if (localFileExisted) {
+            nativeBinding = __nccwpck_require__(46502)
+          } else {
+            nativeBinding = __nccwpck_require__(74067)
+          }
+        } catch (e) {
+          loadError = e
+        }
+        break
+      default:
+        throw new Error(`Unsupported architecture on macOS: ${arch}`)
+    }
+    break
+  case 'freebsd':
+    if (arch !== 'x64') {
+      throw new Error(`Unsupported architecture on FreeBSD: ${arch}`)
+    }
+    localFileExisted = existsSync(join(__dirname, 'nx.freebsd-x64.node'))
+    try {
+      if (localFileExisted) {
+        nativeBinding = __nccwpck_require__(35488)
+      } else {
+        nativeBinding = __nccwpck_require__(63818)
+      }
+    } catch (e) {
+      loadError = e
+    }
+    break
+  case 'linux':
+    switch (arch) {
+      case 'x64':
+        if (isMusl()) {
+          localFileExisted = existsSync(
+            join(__dirname, 'nx.linux-x64-musl.node')
+          )
+          try {
+            if (localFileExisted) {
+              nativeBinding = __nccwpck_require__(76200)
+            } else {
+              nativeBinding = __nccwpck_require__(91817)
+            }
+          } catch (e) {
+            loadError = e
+          }
+        } else {
+          localFileExisted = existsSync(
+            join(__dirname, 'nx.linux-x64-gnu.node')
+          )
+          try {
+            if (localFileExisted) {
+              nativeBinding = __nccwpck_require__(37202)
+            } else {
+              nativeBinding = __nccwpck_require__(91136)
+            }
+          } catch (e) {
+            loadError = e
+          }
+        }
+        break
+      case 'arm64':
+        if (isMusl()) {
+          localFileExisted = existsSync(
+            join(__dirname, 'nx.linux-arm64-musl.node')
+          )
+          try {
+            if (localFileExisted) {
+              nativeBinding = __nccwpck_require__(76818)
+            } else {
+              nativeBinding = __nccwpck_require__(67629)
+            }
+          } catch (e) {
+            loadError = e
+          }
+        } else {
+          localFileExisted = existsSync(
+            join(__dirname, 'nx.linux-arm64-gnu.node')
+          )
+          try {
+            if (localFileExisted) {
+              nativeBinding = __nccwpck_require__(69480)
+            } else {
+              nativeBinding = __nccwpck_require__(99909)
+            }
+          } catch (e) {
+            loadError = e
+          }
+        }
+        break
+      case 'arm':
+        localFileExisted = existsSync(
+          join(__dirname, 'nx.linux-arm-gnueabihf.node')
+        )
+        try {
+          if (localFileExisted) {
+            nativeBinding = __nccwpck_require__(56986)
+          } else {
+            nativeBinding = __nccwpck_require__(56362)
+          }
+        } catch (e) {
+          loadError = e
+        }
+        break
+      default:
+        throw new Error(`Unsupported architecture on Linux: ${arch}`)
+    }
+    break
+  default:
+    throw new Error(`Unsupported OS: ${platform}, architecture: ${arch}`)
+}
+
+if (!nativeBinding) {
+  if (loadError) {
+    throw loadError
+  }
+  throw new Error(`Failed to load native binding`)
+}
 
-/**
- * For Node.js, simply re-export the core `util.deprecate` function.
- */
+const { expandOutputs, getFilesForOutputs, remove, copy, ChildProcess, runCommand, nxFork, hashArray, hashFile, ImportResult, findImports, transferProjectGraph, HashPlanner, TaskHasher, EventType, Watcher, WorkspaceContext, WorkspaceErrors, testOnlyTransferFileMap } = nativeBinding
 
-module.exports = __nccwpck_require__(73837).deprecate;
+module.exports.expandOutputs = expandOutputs
+module.exports.getFilesForOutputs = getFilesForOutputs
+module.exports.remove = remove
+module.exports.copy = copy
+module.exports.ChildProcess = ChildProcess
+module.exports.runCommand = runCommand
+module.exports.nxFork = nxFork
+module.exports.hashArray = hashArray
+module.exports.hashFile = hashFile
+module.exports.ImportResult = ImportResult
+module.exports.findImports = findImports
+module.exports.transferProjectGraph = transferProjectGraph
+module.exports.HashPlanner = HashPlanner
+module.exports.TaskHasher = TaskHasher
+module.exports.EventType = EventType
+module.exports.Watcher = Watcher
+module.exports.WorkspaceContext = WorkspaceContext
+module.exports.WorkspaceErrors = WorkspaceErrors
+module.exports.testOnlyTransferFileMap = testOnlyTransferFileMap
 
 
 /***/ }),
 
-/***/ 10580:
+/***/ 17797:
 /***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
 "use strict";
 
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.createDependencies = exports.createNodes = exports.name = void 0;
+const fs_1 = __nccwpck_require__(57147);
+const fs_extra_1 = __nccwpck_require__(27475);
+const path_1 = __nccwpck_require__(71017);
+const perf_hooks_1 = __nccwpck_require__(4074);
+const cache_directory_1 = __nccwpck_require__(15120);
+const globs_1 = __nccwpck_require__(94865);
+const lock_file_1 = __nccwpck_require__(55333);
+const build_dependencies_1 = __nccwpck_require__(37158);
+const config_1 = __nccwpck_require__(13770);
+const file_hasher_1 = __nccwpck_require__(50180);
+const package_manager_1 = __nccwpck_require__(18142);
+const workspace_root_1 = __nccwpck_require__(86708);
+const versions_1 = __nccwpck_require__(92941);
+exports.name = 'nx/js/dependencies-and-lockfile';
+let parsedLockFile = {};
+exports.createNodes = [
+    // Look for all lockfiles
+    (0, globs_1.combineGlobPatterns)(lock_file_1.LOCKFILES),
+    (lockFile, _, context) => {
+        const pluginConfig = (0, config_1.jsPluginConfig)(context.nxJsonConfiguration);
+        if (!pluginConfig.analyzeLockfile) {
+            return {};
+        }
+        const packageManager = (0, package_manager_1.detectPackageManager)(workspace_root_1.workspaceRoot);
+        // Only process the correct lockfile
+        if (lockFile !== (0, lock_file_1.getLockFileName)(packageManager)) {
+            return {};
+        }
+        const lockFilePath = (0, path_1.join)(workspace_root_1.workspaceRoot, lockFile);
+        const lockFileContents = (0, fs_1.readFileSync)(lockFilePath).toString();
+        const lockFileHash = getLockFileHash(lockFileContents);
+        if (!lockFileNeedsReprocessing(lockFileHash)) {
+            const nodes = readCachedParsedLockFile().externalNodes;
+            parsedLockFile.externalNodes = nodes;
+            return {
+                externalNodes: nodes,
+            };
+        }
+        const externalNodes = (0, lock_file_1.getLockFileNodes)(packageManager, lockFileContents, lockFileHash);
+        parsedLockFile.externalNodes = externalNodes;
+        return {
+            externalNodes,
+        };
+    },
+];
+const createDependencies = (_, ctx) => {
+    const pluginConfig = (0, config_1.jsPluginConfig)(ctx.nxJsonConfiguration);
+    const packageManager = (0, package_manager_1.detectPackageManager)(workspace_root_1.workspaceRoot);
+    let lockfileDependencies = [];
+    // lockfile may not exist yet
+    if (pluginConfig.analyzeLockfile &&
+        (0, lock_file_1.lockFileExists)(packageManager) &&
+        parsedLockFile) {
+        const lockFilePath = (0, path_1.join)(workspace_root_1.workspaceRoot, (0, lock_file_1.getLockFileName)(packageManager));
+        const lockFileContents = (0, fs_1.readFileSync)(lockFilePath).toString();
+        const lockFileHash = getLockFileHash(lockFileContents);
+        if (!lockFileNeedsReprocessing(lockFileHash)) {
+            lockfileDependencies = readCachedParsedLockFile().dependencies ?? [];
+        }
+        else {
+            lockfileDependencies = (0, lock_file_1.getLockFileDependencies)(packageManager, lockFileContents, lockFileHash, ctx);
+            parsedLockFile.dependencies = lockfileDependencies;
+            writeLastProcessedLockfileHash(lockFileHash, parsedLockFile);
+        }
+    }
+    perf_hooks_1.performance.mark('build typescript dependencies - start');
+    const explicitProjectDependencies = (0, build_dependencies_1.buildExplicitDependencies)(pluginConfig, ctx);
+    perf_hooks_1.performance.mark('build typescript dependencies - end');
+    perf_hooks_1.performance.measure('build typescript dependencies', 'build typescript dependencies - start', 'build typescript dependencies - end');
+    return lockfileDependencies.concat(explicitProjectDependencies);
+};
+exports.createDependencies = createDependencies;
+function getLockFileHash(lockFileContents) {
+    return (0, file_hasher_1.hashArray)([versions_1.nxVersion, lockFileContents]);
+}
+function lockFileNeedsReprocessing(lockHash) {
+    try {
+        return (0, fs_1.readFileSync)(lockFileHashFile).toString() !== lockHash;
+    }
+    catch {
+        return true;
+    }
+}
+function writeLastProcessedLockfileHash(hash, lockFile) {
+    (0, fs_extra_1.ensureDirSync)((0, path_1.dirname)(lockFileHashFile));
+    (0, fs_1.writeFileSync)(cachedParsedLockFile, JSON.stringify(lockFile, null, 2));
+    (0, fs_1.writeFileSync)(lockFileHashFile, hash);
+}
+function readCachedParsedLockFile() {
+    return JSON.parse((0, fs_1.readFileSync)(cachedParsedLockFile).toString());
+}
+const lockFileHashFile = (0, path_1.join)(cache_directory_1.projectGraphCacheDirectory, 'lockfile.hash');
+const cachedParsedLockFile = (0, path_1.join)(cache_directory_1.projectGraphCacheDirectory, 'parsed-lock-file.json');
 
-Object.defineProperty(exports, "__esModule", ({
-  value: true
-}));
-Object.defineProperty(exports, "v1", ({
-  enumerable: true,
-  get: function () {
-    return _v.default;
-  }
-}));
-Object.defineProperty(exports, "v3", ({
-  enumerable: true,
-  get: function () {
-    return _v2.default;
-  }
-}));
-Object.defineProperty(exports, "v4", ({
-  enumerable: true,
-  get: function () {
-    return _v3.default;
-  }
-}));
-Object.defineProperty(exports, "v5", ({
-  enumerable: true,
-  get: function () {
-    return _v4.default;
-  }
-}));
-Object.defineProperty(exports, "NIL", ({
-  enumerable: true,
-  get: function () {
-    return _nil.default;
-  }
-}));
-Object.defineProperty(exports, "version", ({
-  enumerable: true,
-  get: function () {
-    return _version.default;
-  }
-}));
-Object.defineProperty(exports, "validate", ({
-  enumerable: true,
-  get: function () {
-    return _validate.default;
-  }
-}));
-Object.defineProperty(exports, "stringify", ({
-  enumerable: true,
-  get: function () {
-    return _stringify.default;
-  }
-}));
-Object.defineProperty(exports, "parse", ({
-  enumerable: true,
-  get: function () {
-    return _parse.default;
-  }
-}));
-
-var _v = _interopRequireDefault(__nccwpck_require__(85618));
-
-var _v2 = _interopRequireDefault(__nccwpck_require__(34643));
-
-var _v3 = _interopRequireDefault(__nccwpck_require__(39370));
-
-var _v4 = _interopRequireDefault(__nccwpck_require__(93249));
-
-var _nil = _interopRequireDefault(__nccwpck_require__(64829));
-
-var _version = _interopRequireDefault(__nccwpck_require__(14698));
-
-var _validate = _interopRequireDefault(__nccwpck_require__(63498));
-
-var _stringify = _interopRequireDefault(__nccwpck_require__(82332));
-
-var _parse = _interopRequireDefault(__nccwpck_require__(9869));
-
-function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
 
 /***/ }),
 
-/***/ 37342:
+/***/ 55333:
 /***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
 "use strict";
 
-
-Object.defineProperty(exports, "__esModule", ({
-  value: true
-}));
-exports["default"] = void 0;
-
-var _crypto = _interopRequireDefault(__nccwpck_require__(6113));
-
-function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
-
-function md5(bytes) {
-  if (Array.isArray(bytes)) {
-    bytes = Buffer.from(bytes);
-  } else if (typeof bytes === 'string') {
-    bytes = Buffer.from(bytes, 'utf8');
-  }
-
-  return _crypto.default.createHash('md5').update(bytes).digest();
+/**
+ * This is the main API for accessing the lock file functionality.
+ * It encapsulates the package manager specific logic and implementation details.
+ */
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.createLockFile = exports.getLockFileName = exports.lockFileExists = exports.getLockFileDependencies = exports.getLockFileNodes = exports.LOCKFILES = void 0;
+const fs_1 = __nccwpck_require__(57147);
+const path_1 = __nccwpck_require__(71017);
+const package_manager_1 = __nccwpck_require__(18142);
+const workspace_root_1 = __nccwpck_require__(86708);
+const output_1 = __nccwpck_require__(1737);
+const npm_parser_1 = __nccwpck_require__(1443);
+const pnpm_parser_1 = __nccwpck_require__(24573);
+const yarn_parser_1 = __nccwpck_require__(83243);
+const project_graph_pruning_1 = __nccwpck_require__(35765);
+const package_json_1 = __nccwpck_require__(20992);
+const fileutils_1 = __nccwpck_require__(83851);
+const YARN_LOCK_FILE = 'yarn.lock';
+const NPM_LOCK_FILE = 'package-lock.json';
+const PNPM_LOCK_FILE = 'pnpm-lock.yaml';
+exports.LOCKFILES = [YARN_LOCK_FILE, NPM_LOCK_FILE, PNPM_LOCK_FILE];
+const YARN_LOCK_PATH = (0, path_1.join)(workspace_root_1.workspaceRoot, YARN_LOCK_FILE);
+const NPM_LOCK_PATH = (0, path_1.join)(workspace_root_1.workspaceRoot, NPM_LOCK_FILE);
+const PNPM_LOCK_PATH = (0, path_1.join)(workspace_root_1.workspaceRoot, PNPM_LOCK_FILE);
+/**
+ * Parses lock file and maps dependencies and metadata to {@link LockFileGraph}
+ */
+function getLockFileNodes(packageManager, contents, lockFileHash) {
+    try {
+        if (packageManager === 'yarn') {
+            const packageJson = (0, fileutils_1.readJsonFile)('package.json');
+            return (0, yarn_parser_1.getYarnLockfileNodes)(contents, lockFileHash, packageJson);
+        }
+        if (packageManager === 'pnpm') {
+            return (0, pnpm_parser_1.getPnpmLockfileNodes)(contents, lockFileHash);
+        }
+        if (packageManager === 'npm') {
+            return (0, npm_parser_1.getNpmLockfileNodes)(contents, lockFileHash);
+        }
+    }
+    catch (e) {
+        if (!isPostInstallProcess()) {
+            output_1.output.error({
+                title: `Failed to parse ${packageManager} lockfile`,
+                bodyLines: errorBodyLines(e),
+            });
+        }
+        throw e;
+    }
+    throw new Error(`Unknown package manager: ${packageManager}`);
+}
+exports.getLockFileNodes = getLockFileNodes;
+/**
+ * Parses lock file and maps dependencies and metadata to {@link LockFileGraph}
+ */
+function getLockFileDependencies(packageManager, contents, lockFileHash, context) {
+    try {
+        if (packageManager === 'yarn') {
+            return (0, yarn_parser_1.getYarnLockfileDependencies)(contents, lockFileHash, context);
+        }
+        if (packageManager === 'pnpm') {
+            return (0, pnpm_parser_1.getPnpmLockfileDependencies)(contents, lockFileHash, context);
+        }
+        if (packageManager === 'npm') {
+            return (0, npm_parser_1.getNpmLockfileDependencies)(contents, lockFileHash, context);
+        }
+    }
+    catch (e) {
+        if (!isPostInstallProcess()) {
+            output_1.output.error({
+                title: `Failed to parse ${packageManager} lockfile`,
+                bodyLines: errorBodyLines(e),
+            });
+        }
+        throw e;
+    }
+    throw new Error(`Unknown package manager: ${packageManager}`);
+}
+exports.getLockFileDependencies = getLockFileDependencies;
+function lockFileExists(packageManager) {
+    if (packageManager === 'yarn') {
+        return (0, fs_1.existsSync)(YARN_LOCK_PATH);
+    }
+    if (packageManager === 'pnpm') {
+        return (0, fs_1.existsSync)(PNPM_LOCK_PATH);
+    }
+    if (packageManager === 'npm') {
+        return (0, fs_1.existsSync)(NPM_LOCK_PATH);
+    }
+    throw new Error(`Unknown package manager ${packageManager} or lock file missing`);
+}
+exports.lockFileExists = lockFileExists;
+/**
+ * Returns lock file name based on the detected package manager in the root
+ * @param packageManager
+ * @returns
+ */
+function getLockFileName(packageManager) {
+    if (packageManager === 'yarn') {
+        return YARN_LOCK_FILE;
+    }
+    if (packageManager === 'pnpm') {
+        return PNPM_LOCK_FILE;
+    }
+    if (packageManager === 'npm') {
+        return NPM_LOCK_FILE;
+    }
+    throw new Error(`Unknown package manager: ${packageManager}`);
+}
+exports.getLockFileName = getLockFileName;
+/**
+ * Create lock file based on the root level lock file and (pruned) package.json
+ *
+ * @param packageJson
+ * @param isProduction
+ * @param packageManager
+ * @returns
+ */
+function createLockFile(packageJson, graph, packageManager = (0, package_manager_1.detectPackageManager)(workspace_root_1.workspaceRoot)) {
+    const normalizedPackageJson = (0, package_json_1.normalizePackageJson)(packageJson);
+    const content = (0, fs_1.readFileSync)(getLockFileName(packageManager), 'utf8');
+    try {
+        if (packageManager === 'yarn') {
+            const prunedGraph = (0, project_graph_pruning_1.pruneProjectGraph)(graph, packageJson);
+            return (0, yarn_parser_1.stringifyYarnLockfile)(prunedGraph, content, normalizedPackageJson);
+        }
+        if (packageManager === 'pnpm') {
+            const prunedGraph = (0, project_graph_pruning_1.pruneProjectGraph)(graph, packageJson);
+            return (0, pnpm_parser_1.stringifyPnpmLockfile)(prunedGraph, content, normalizedPackageJson);
+        }
+        if (packageManager === 'npm') {
+            const prunedGraph = (0, project_graph_pruning_1.pruneProjectGraph)(graph, packageJson);
+            return (0, npm_parser_1.stringifyNpmLockfile)(prunedGraph, content, normalizedPackageJson);
+        }
+    }
+    catch (e) {
+        if (!isPostInstallProcess()) {
+            const additionalInfo = [
+                'To prevent the build from breaking we are returning the root lock file.',
+            ];
+            if (packageManager === 'npm') {
+                additionalInfo.push('If you run `npm install --package-lock-only` in your output folder it will regenerate the correct pruned lockfile.');
+            }
+            if (packageManager === 'pnpm') {
+                additionalInfo.push('If you run `pnpm install --lockfile-only` in your output folder it will regenerate the correct pruned lockfile.');
+            }
+            output_1.output.error({
+                title: 'An error occured while creating pruned lockfile',
+                bodyLines: errorBodyLines(e, additionalInfo),
+            });
+        }
+        return content;
+    }
+}
+exports.createLockFile = createLockFile;
+// generate body lines for error message
+function errorBodyLines(originalError, additionalInfo = []) {
+    return [
+        'Please open an issue at `https://github.com/nrwl/nx/issues/new?template=1-bug.yml` and provide a reproduction.',
+        ...additionalInfo,
+        `\nOriginal error: ${originalError.message}\n\n`,
+        originalError.stack,
+    ];
+}
+function isPostInstallProcess() {
+    return (process.env.npm_command === 'install' &&
+        process.env.npm_lifecycle_event === 'postinstall');
 }
 
-var _default = md5;
-exports["default"] = _default;
 
 /***/ }),
 
-/***/ 64829:
-/***/ ((__unused_webpack_module, exports) => {
+/***/ 1443:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
 "use strict";
 
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.stringifyNpmLockfile = exports.getNpmLockfileDependencies = exports.getNpmLockfileNodes = void 0;
+const fs_1 = __nccwpck_require__(57147);
+const semver_1 = __nccwpck_require__(66195);
+const workspace_root_1 = __nccwpck_require__(86708);
+const operators_1 = __nccwpck_require__(5959);
+const project_graph_builder_1 = __nccwpck_require__(80862);
+const project_graph_1 = __nccwpck_require__(2184);
+const file_hasher_1 = __nccwpck_require__(50180);
+// we use key => node map to avoid duplicate work when parsing keys
+let keyMap = new Map();
+let currentLockFileHash;
+let parsedLockFile;
+function parsePackageLockFile(lockFileContent, lockFileHash) {
+    if (lockFileHash === currentLockFileHash) {
+        return parsedLockFile;
+    }
+    keyMap.clear();
+    const results = JSON.parse(lockFileContent);
+    parsedLockFile = results;
+    currentLockFileHash = lockFileHash;
+    return results;
+}
+function getNpmLockfileNodes(lockFileContent, lockFileHash) {
+    const data = parsePackageLockFile(lockFileContent, lockFileHash);
+    // we use key => node map to avoid duplicate work when parsing keys
+    return getNodes(data, keyMap);
+}
+exports.getNpmLockfileNodes = getNpmLockfileNodes;
+function getNpmLockfileDependencies(lockFileContent, lockFileHash, ctx) {
+    const data = parsePackageLockFile(lockFileContent, lockFileHash);
+    return getDependencies(data, keyMap, ctx);
+}
+exports.getNpmLockfileDependencies = getNpmLockfileDependencies;
+function getNodes(data, keyMap) {
+    const nodes = new Map();
+    if (data.lockfileVersion > 1) {
+        Object.entries(data.packages).forEach(([path, snapshot]) => {
+            // skip workspaces packages
+            if (path === '' || !path.includes('node_modules') || snapshot.link) {
+                return;
+            }
+            const packageName = path.split('node_modules/').pop();
+            const version = findV3Version(snapshot, packageName);
+            createNode(packageName, version, path, nodes, keyMap, snapshot);
+        });
+    }
+    else {
+        Object.entries(data.dependencies).forEach(([packageName, snapshot]) => {
+            // we only care about dependencies of workspace packages
+            if (snapshot.version?.startsWith('file:')) {
+                if (snapshot.dependencies) {
+                    Object.entries(snapshot.dependencies).forEach(([depName, depSnapshot]) => {
+                        addV1Node(depName, depSnapshot, `${snapshot.version.slice(5)}/node_modules/${depName}`, nodes, keyMap);
+                    });
+                }
+            }
+            else {
+                addV1Node(packageName, snapshot, `node_modules/${packageName}`, nodes, keyMap);
+            }
+        });
+    }
+    const results = {};
+    // some packages can be both hoisted and nested
+    // so we need to run this check once we have all the nodes and paths
+    for (const [packageName, versionMap] of nodes.entries()) {
+        const hoistedNode = keyMap.get(`node_modules/${packageName}`);
+        if (hoistedNode) {
+            hoistedNode.name = `npm:${packageName}`;
+        }
+        versionMap.forEach((node) => {
+            results[node.name] = node;
+        });
+    }
+    return results;
+}
+function addV1Node(packageName, snapshot, path, nodes, keyMap) {
+    createNode(packageName, snapshot.version, path, nodes, keyMap, snapshot);
+    // traverse nested dependencies
+    if (snapshot.dependencies) {
+        Object.entries(snapshot.dependencies).forEach(([depName, depSnapshot]) => {
+            addV1Node(depName, depSnapshot, `${path}/node_modules/${depName}`, nodes, keyMap);
+        });
+    }
+}
+function createNode(packageName, version, key, nodes, keyMap, snapshot) {
+    const existingNode = nodes.get(packageName)?.get(version);
+    if (existingNode) {
+        keyMap.set(key, existingNode);
+        return;
+    }
+    const node = {
+        type: 'npm',
+        name: version ? `npm:${packageName}@${version}` : `npm:${packageName}`,
+        data: {
+            version,
+            packageName,
+            hash: snapshot.integrity ||
+                (0, file_hasher_1.hashArray)(snapshot.resolved
+                    ? [snapshot.resolved]
+                    : version
+                        ? [packageName, version]
+                        : [packageName]),
+        },
+    };
+    keyMap.set(key, node);
+    if (!nodes.has(packageName)) {
+        nodes.set(packageName, new Map([[version, node]]));
+    }
+    else {
+        nodes.get(packageName).set(version, node);
+    }
+}
+function findV3Version(snapshot, packageName) {
+    let version = snapshot.version;
+    const resolved = snapshot.resolved;
+    // for tarball packages version might not exist or be useless
+    if (!version || (resolved && !resolved.includes(version))) {
+        version = resolved;
+    }
+    // for alias packages name is set
+    if (snapshot.name && snapshot.name !== packageName) {
+        if (version) {
+            version = `npm:${snapshot.name}@${version}`;
+        }
+        else {
+            version = `npm:${snapshot.name}`;
+        }
+    }
+    return version;
+}
+function getDependencies(data, keyMap, ctx) {
+    const dependencies = [];
+    if (data.lockfileVersion > 1) {
+        Object.entries(data.packages).forEach(([path, snapshot]) => {
+            // we are skipping workspaces packages
+            if (!keyMap.has(path)) {
+                return;
+            }
+            const sourceName = keyMap.get(path).name;
+            [
+                snapshot.peerDependencies,
+                snapshot.dependencies,
+                snapshot.optionalDependencies,
+            ].forEach((section) => {
+                if (section) {
+                    Object.entries(section).forEach(([name, versionRange]) => {
+                        const target = findTarget(path, keyMap, name, versionRange);
+                        if (target) {
+                            const dep = {
+                                source: sourceName,
+                                target: target.name,
+                                type: project_graph_1.DependencyType.static,
+                            };
+                            (0, project_graph_builder_1.validateDependency)(dep, ctx);
+                            dependencies.push(dep);
+                        }
+                    });
+                }
+            });
+        });
+    }
+    else {
+        Object.entries(data.dependencies).forEach(([packageName, snapshot]) => {
+            addV1NodeDependencies(`node_modules/${packageName}`, snapshot, dependencies, keyMap, ctx);
+        });
+    }
+    return dependencies;
+}
+function findTarget(sourcePath, keyMap, targetName, versionRange) {
+    if (sourcePath && !sourcePath.endsWith('/')) {
+        sourcePath = `${sourcePath}/`;
+    }
+    const searchPath = `${sourcePath}node_modules/${targetName}`;
+    if (keyMap.has(searchPath)) {
+        const child = keyMap.get(searchPath);
+        if (child.data.version === versionRange ||
+            (0, semver_1.satisfies)(child.data.version, versionRange)) {
+            return child;
+        }
+    }
+    // the hoisted package did not match, this dependency is missing
+    if (!sourcePath) {
+        return;
+    }
+    return findTarget(sourcePath.split('node_modules/').slice(0, -1).join('node_modules/'), keyMap, targetName, versionRange);
+}
+function addV1NodeDependencies(path, snapshot, dependencies, keyMap, ctx) {
+    if (keyMap.has(path) && snapshot.requires) {
+        const source = keyMap.get(path).name;
+        Object.entries(snapshot.requires).forEach(([name, versionRange]) => {
+            const target = findTarget(path, keyMap, name, versionRange);
+            if (target) {
+                const dep = {
+                    source: source,
+                    target: target.name,
+                    type: project_graph_1.DependencyType.static,
+                };
+                (0, project_graph_builder_1.validateDependency)(dep, ctx);
+                dependencies.push(dep);
+            }
+        });
+    }
+    if (snapshot.dependencies) {
+        Object.entries(snapshot.dependencies).forEach(([depName, depSnapshot]) => {
+            addV1NodeDependencies(`${path}/node_modules/${depName}`, depSnapshot, dependencies, keyMap, ctx);
+        });
+    }
+    const { peerDependencies } = getPeerDependencies(path);
+    if (peerDependencies) {
+        const node = keyMap.get(path);
+        Object.entries(peerDependencies).forEach(([depName, depSpec]) => {
+            const target = findTarget(path, keyMap, depName, depSpec);
+            if (target) {
+                const dep = {
+                    source: node.name,
+                    target: target.name,
+                    type: project_graph_1.DependencyType.static,
+                };
+                (0, project_graph_builder_1.validateDependency)(dep, ctx);
+                dependencies.push(dep);
+            }
+        });
+    }
+}
+function stringifyNpmLockfile(graph, rootLockFileContent, packageJson) {
+    const rootLockFile = JSON.parse(rootLockFileContent);
+    const { lockfileVersion } = JSON.parse(rootLockFileContent);
+    const mappedPackages = mapSnapshots(rootLockFile, graph);
+    const output = {
+        name: packageJson.name || rootLockFile.name,
+        version: packageJson.version || '0.0.1',
+        lockfileVersion: rootLockFile.lockfileVersion,
+    };
+    if (rootLockFile.requires) {
+        output.requires = rootLockFile.requires;
+    }
+    if (lockfileVersion > 1) {
+        output.packages = mapV3Snapshots(mappedPackages, packageJson);
+    }
+    if (lockfileVersion < 3) {
+        output.dependencies = mapV1Snapshots(mappedPackages);
+    }
+    return JSON.stringify(output, null, 2);
+}
+exports.stringifyNpmLockfile = stringifyNpmLockfile;
+function mapV3Snapshots(mappedPackages, packageJson) {
+    const output = {};
+    output[''] = packageJson;
+    mappedPackages.forEach((p) => {
+        output[p.path] = p.valueV3;
+    });
+    return output;
+}
+function mapV1Snapshots(mappedPackages) {
+    const output = {};
+    mappedPackages.forEach((p) => {
+        getPackageParent(p.path, output)[p.name] = p.valueV1;
+    });
+    return output;
+}
+function getPackageParent(path, packages) {
+    const segments = path.split(/\/?node_modules\//).slice(1, -1);
+    if (!segments.length) {
+        return packages;
+    }
+    let parent = packages[segments.shift()];
+    if (!parent.dependencies) {
+        parent.dependencies = {};
+    }
+    while (segments.length) {
+        parent = parent.dependencies[segments.shift()];
+        if (!parent.dependencies) {
+            parent.dependencies = {};
+        }
+    }
+    return parent.dependencies;
+}
+function mapSnapshots(rootLockFile, graph) {
+    const nestedNodes = new Set();
+    const visitedNodes = new Map();
+    const visitedPaths = new Set();
+    const remappedPackages = new Map();
+    // add first level children
+    Object.values(graph.externalNodes).forEach((node) => {
+        if (node.name === `npm:${node.data.packageName}`) {
+            const mappedPackage = mapPackage(rootLockFile, node.data.packageName, node.data.version);
+            remappedPackages.set(mappedPackage.path, mappedPackage);
+            visitedNodes.set(node, new Set([mappedPackage.path]));
+            visitedPaths.add(mappedPackage.path);
+        }
+        else {
+            nestedNodes.add(node);
+        }
+    });
+    let remappedPackagesArray;
+    if (nestedNodes.size) {
+        const invertedGraph = (0, operators_1.reverse)(graph);
+        nestMappedPackages(invertedGraph, remappedPackages, nestedNodes, visitedNodes, visitedPaths, rootLockFile);
+        // initially we naively map package paths to topParent/../parent/child
+        // but some of those should be nested higher up the tree
+        remappedPackagesArray = elevateNestedPaths(remappedPackages);
+    }
+    else {
+        remappedPackagesArray = Array.from(remappedPackages.values());
+    }
+    return remappedPackagesArray.sort((a, b) => a.path.localeCompare(b.path));
+}
+function mapPackage(rootLockFile, packageName, version, parentPath = '') {
+    const lockfileVersion = rootLockFile.lockfileVersion;
+    let valueV3, valueV1;
+    if (lockfileVersion < 3) {
+        valueV1 = findMatchingPackageV1(rootLockFile.dependencies, packageName, version);
+    }
+    if (lockfileVersion > 1) {
+        valueV3 = findMatchingPackageV3(rootLockFile.packages, packageName, version);
+    }
+    return {
+        path: parentPath + `node_modules/${packageName}`,
+        name: packageName,
+        valueV1,
+        valueV3,
+    };
+}
+function nestMappedPackages(invertedGraph, result, nestedNodes, visitedNodes, visitedPaths, rootLockFile) {
+    const initialSize = nestedNodes.size;
+    if (!initialSize) {
+        return;
+    }
+    nestedNodes.forEach((node) => {
+        let unresolvedParents = invertedGraph.dependencies[node.name].length;
+        invertedGraph.dependencies[node.name].forEach(({ target }) => {
+            const targetNode = invertedGraph.externalNodes[target];
+            if (visitedNodes.has(targetNode)) {
+                visitedNodes.get(targetNode).forEach((path) => {
+                    const mappedPackage = mapPackage(rootLockFile, node.data.packageName, node.data.version, path + '/');
+                    result.set(mappedPackage.path, mappedPackage);
+                    if (visitedNodes.has(node)) {
+                        visitedNodes.get(node).add(mappedPackage.path);
+                    }
+                    else {
+                        visitedNodes.set(node, new Set([mappedPackage.path]));
+                    }
+                    visitedPaths.add(mappedPackage.path);
+                });
+                unresolvedParents--;
+            }
+        });
+        if (!unresolvedParents) {
+            nestedNodes.delete(node);
+        }
+    });
+    if (initialSize === nestedNodes.size) {
+        throw new Error([
+            'Following packages could not be mapped to the NPM lockfile:',
+            ...Array.from(nestedNodes).map((n) => `- ${n.name}`),
+        ].join('\n'));
+    }
+    else {
+        nestMappedPackages(invertedGraph, result, nestedNodes, visitedNodes, visitedPaths, rootLockFile);
+    }
+}
+// sort paths by number of segments and then alphabetically
+function sortMappedPackagesPaths(mappedPackages) {
+    return Array.from(mappedPackages.keys()).sort((a, b) => {
+        const aLength = a.split('/node_modules/').length;
+        const bLength = b.split('/node_modules/').length;
+        if (aLength > bLength) {
+            return 1;
+        }
+        if (aLength < bLength) {
+            return -1;
+        }
+        return a.localeCompare(b);
+    });
+}
+function elevateNestedPaths(remappedPackages) {
+    const result = new Map();
+    const sortedPaths = sortMappedPackagesPaths(remappedPackages);
+    sortedPaths.forEach((path) => {
+        const segments = path.split('/node_modules/');
+        const mappedPackage = remappedPackages.get(path);
+        // we keep hoisted packages intact
+        if (segments.length === 1) {
+            result.set(path, mappedPackage);
+            return;
+        }
+        const packageName = segments.pop();
+        const getNewPath = (segs) => `${segs.join('/node_modules/')}/node_modules/${packageName}`;
+        // check if grandparent has the same package
+        const shouldElevate = (segs) => {
+            const elevatedPath = getNewPath(segs.slice(0, -1));
+            if (result.has(elevatedPath)) {
+                const match = result.get(elevatedPath);
+                return (match.valueV1?.version === mappedPackage.valueV1?.version &&
+                    match.valueV3?.version === mappedPackage.valueV3?.version);
+            }
+            return true;
+        };
+        while (segments.length > 1 && shouldElevate(segments)) {
+            segments.pop();
+        }
+        const newPath = getNewPath(segments);
+        if (path !== newPath) {
+            if (!result.has(newPath)) {
+                mappedPackage.path = newPath;
+                result.set(newPath, mappedPackage);
+            }
+        }
+        else {
+            result.set(path, mappedPackage);
+        }
+    });
+    return Array.from(result.values());
+}
+function findMatchingPackageV3(packages, name, version) {
+    for (const [key, { dev, peer, ...snapshot }] of Object.entries(packages)) {
+        if (key.endsWith(`node_modules/${name}`)) {
+            if ([
+                snapshot.version,
+                snapshot.resolved,
+                `npm:${snapshot.name}@${snapshot.version}`,
+            ].includes(version)) {
+                return snapshot;
+            }
+        }
+    }
+}
+function findMatchingPackageV1(packages, name, version) {
+    for (const [packageName, { dev, peer, dependencies, ...snapshot },] of Object.entries(packages)) {
+        if (packageName === name) {
+            if (snapshot.version === version) {
+                return snapshot;
+            }
+        }
+        if (dependencies) {
+            const found = findMatchingPackageV1(dependencies, name, version);
+            if (found) {
+                return found;
+            }
+        }
+    }
+}
+// NPM V1 does not track the peer dependencies in the lock file
+// so we need to parse them directly from the package.json
+function getPeerDependencies(path) {
+    const fullPath = `${workspace_root_1.workspaceRoot}/${path}/package.json`;
+    if ((0, fs_1.existsSync)(fullPath)) {
+        const content = (0, fs_1.readFileSync)(fullPath, 'utf-8');
+        const { peerDependencies, peerDependenciesMeta } = JSON.parse(content);
+        return {
+            ...(peerDependencies && { peerDependencies }),
+            ...(peerDependenciesMeta && { peerDependenciesMeta }),
+        };
+    }
+    else {
+        if (process.env.NX_VERBOSE_LOGGING === 'true') {
+            console.warn(`Could not find package.json at "${path}"`);
+        }
+        return {};
+    }
+}
 
-Object.defineProperty(exports, "__esModule", ({
-  value: true
-}));
-exports["default"] = void 0;
-var _default = '00000000-0000-0000-0000-000000000000';
-exports["default"] = _default;
 
 /***/ }),
 
-/***/ 9869:
+/***/ 24573:
 /***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
 "use strict";
 
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.stringifyPnpmLockfile = exports.getPnpmLockfileDependencies = exports.getPnpmLockfileNodes = void 0;
+const pnpm_normalizer_1 = __nccwpck_require__(93434);
+const package_json_1 = __nccwpck_require__(20992);
+const object_sort_1 = __nccwpck_require__(84110);
+const project_graph_builder_1 = __nccwpck_require__(80862);
+const project_graph_1 = __nccwpck_require__(2184);
+const file_hasher_1 = __nccwpck_require__(50180);
+// we use key => node map to avoid duplicate work when parsing keys
+let keyMap = new Map();
+let currentLockFileHash;
+let parsedLockFile;
+function parsePnpmLockFile(lockFileContent, lockFileHash) {
+    if (lockFileHash === currentLockFileHash) {
+        return parsedLockFile;
+    }
+    keyMap.clear();
+    const results = (0, pnpm_normalizer_1.parseAndNormalizePnpmLockfile)(lockFileContent);
+    parsedLockFile = results;
+    currentLockFileHash = lockFileHash;
+    return results;
+}
+function getPnpmLockfileNodes(lockFileContent, lockFileHash) {
+    const data = parsePnpmLockFile(lockFileContent, lockFileHash);
+    const isV6 = (0, pnpm_normalizer_1.isV6Lockfile)(data);
+    return getNodes(data, keyMap, isV6);
+}
+exports.getPnpmLockfileNodes = getPnpmLockfileNodes;
+function getPnpmLockfileDependencies(lockFileContent, lockFileHash, ctx) {
+    const data = parsePnpmLockFile(lockFileContent, lockFileHash);
+    const isV6 = (0, pnpm_normalizer_1.isV6Lockfile)(data);
+    return getDependencies(data, keyMap, isV6, ctx);
+}
+exports.getPnpmLockfileDependencies = getPnpmLockfileDependencies;
+function getNodes(data, keyMap, isV6) {
+    const nodes = new Map();
+    Object.entries(data.packages).forEach(([key, snapshot]) => {
+        findPackageNames(key, snapshot, data).forEach((packageName) => {
+            const rawVersion = findVersion(key, packageName);
+            const version = parseBaseVersion(rawVersion, isV6);
+            // we don't need to keep duplicates, we can just track the keys
+            const existingNode = nodes.get(packageName)?.get(version);
+            if (existingNode) {
+                keyMap.set(key, existingNode);
+                return;
+            }
+            const node = {
+                type: 'npm',
+                name: version ? `npm:${packageName}@${version}` : `npm:${packageName}`,
+                data: {
+                    version,
+                    packageName,
+                    hash: snapshot.resolution?.['integrity'] ||
+                        (0, file_hasher_1.hashArray)(snapshot.resolution?.['tarball']
+                            ? [snapshot.resolution['tarball']]
+                            : [packageName, version]),
+                },
+            };
+            keyMap.set(key, node);
+            if (!nodes.has(packageName)) {
+                nodes.set(packageName, new Map([[version, node]]));
+            }
+            else {
+                nodes.get(packageName).set(version, node);
+            }
+        });
+    });
+    const hoistedDeps = (0, pnpm_normalizer_1.loadPnpmHoistedDepsDefinition)();
+    const results = {};
+    for (const [packageName, versionMap] of nodes.entries()) {
+        let hoistedNode;
+        if (versionMap.size === 1) {
+            hoistedNode = versionMap.values().next().value;
+        }
+        else {
+            const hoistedVersion = getHoistedVersion(hoistedDeps, packageName, isV6);
+            hoistedNode = versionMap.get(hoistedVersion);
+        }
+        if (hoistedNode) {
+            hoistedNode.name = `npm:${packageName}`;
+        }
+        versionMap.forEach((node) => {
+            results[node.name] = node;
+        });
+    }
+    return results;
+}
+function getHoistedVersion(hoistedDependencies, packageName, isV6) {
+    let version = (0, package_json_1.getHoistedPackageVersion)(packageName);
+    if (!version) {
+        const key = Object.keys(hoistedDependencies).find((k) => k.startsWith(`/${packageName}/`));
+        if (key) {
+            version = parseBaseVersion(getVersion(key, packageName), isV6);
+        }
+        else {
+            // pnpm might not hoist every package
+            // similarly those packages will not be available to be used via import
+            return;
+        }
+    }
+    return version;
+}
+function getDependencies(data, keyMap, isV6, ctx) {
+    const results = [];
+    Object.entries(data.packages).forEach(([key, snapshot]) => {
+        const node = keyMap.get(key);
+        [snapshot.dependencies, snapshot.optionalDependencies].forEach((section) => {
+            if (section) {
+                Object.entries(section).forEach(([name, versionRange]) => {
+                    const version = parseBaseVersion(findVersion(versionRange, name), isV6);
+                    const target = ctx.externalNodes[`npm:${name}@${version}`] ||
+                        ctx.externalNodes[`npm:${name}`];
+                    if (target) {
+                        const dep = {
+                            source: node.name,
+                            target: target.name,
+                            type: project_graph_1.DependencyType.static,
+                        };
+                        (0, project_graph_builder_1.validateDependency)(dep, ctx);
+                        results.push(dep);
+                    }
+                });
+            }
+        });
+    });
+    return results;
+}
+function parseBaseVersion(rawVersion, isV6) {
+    return isV6 ? rawVersion.split('(')[0] : rawVersion.split('_')[0];
+}
+function stringifyPnpmLockfile(graph, rootLockFileContent, packageJson) {
+    const data = (0, pnpm_normalizer_1.parseAndNormalizePnpmLockfile)(rootLockFileContent);
+    const { lockfileVersion, packages } = data;
+    const output = {
+        lockfileVersion,
+        importers: {
+            '.': mapRootSnapshot(packageJson, packages, graph.externalNodes),
+        },
+        packages: (0, object_sort_1.sortObjectByKeys)(mapSnapshots(data.packages, graph.externalNodes)),
+    };
+    return (0, pnpm_normalizer_1.stringifyToPnpmYaml)(output);
+}
+exports.stringifyPnpmLockfile = stringifyPnpmLockfile;
+function mapSnapshots(packages, nodes) {
+    const result = {};
+    Object.values(nodes).forEach((node) => {
+        const matchedKeys = findOriginalKeys(packages, node, {
+            returnFullKey: true,
+        });
+        // the package manager doesn't check for types of dependencies
+        // so we can safely set all to prod
+        matchedKeys.forEach(([key, snapshot]) => {
+            snapshot.dev = false;
+            result[key] = snapshot;
+        });
+    });
+    return result;
+}
+function findOriginalKeys(packages, { data: { packageName, version } }, { returnFullKey } = {}) {
+    const matchedKeys = [];
+    for (const key of Object.keys(packages)) {
+        const snapshot = packages[key];
+        // standard package
+        if (key.startsWith(`/${packageName}/${version}`)) {
+            matchedKeys.push([
+                returnFullKey ? key : getVersion(key, packageName),
+                snapshot,
+            ]);
+        }
+        // tarball package
+        if (key === version) {
+            matchedKeys.push([version, snapshot]);
+        }
+        // alias package
+        if (versionIsAlias(key, version)) {
+            matchedKeys.push([key, snapshot]);
+        }
+    }
+    return matchedKeys;
+}
+// check if version has a form of npm:packageName@version and
+// key starts with /packageName/version
+function versionIsAlias(key, versionExpr) {
+    const PREFIX = 'npm:';
+    if (!versionExpr.startsWith(PREFIX))
+        return false;
+    const indexOfVersionSeparator = versionExpr.indexOf('@', PREFIX.length + 1);
+    const packageName = versionExpr.slice(PREFIX.length, indexOfVersionSeparator);
+    const version = versionExpr.slice(indexOfVersionSeparator + 1);
+    return key.startsWith(`/${packageName}/${version}`);
+}
+function mapRootSnapshot(packageJson, packages, nodes) {
+    const snapshot = { specifiers: {} };
+    [
+        'dependencies',
+        'optionalDependencies',
+        'devDependencies',
+        'peerDependencies',
+    ].forEach((depType) => {
+        if (packageJson[depType]) {
+            Object.keys(packageJson[depType]).forEach((packageName) => {
+                const version = packageJson[depType][packageName];
+                const node = nodes[`npm:${packageName}@${version}`] || nodes[`npm:${packageName}`];
+                snapshot.specifiers[packageName] = version;
+                // peer dependencies are mapped to dependencies
+                let section = depType === 'peerDependencies' ? 'dependencies' : depType;
+                snapshot[section] = snapshot[section] || {};
+                snapshot[section][packageName] = findOriginalKeys(packages, node)[0][0];
+            });
+        }
+    });
+    Object.keys(snapshot).forEach((key) => {
+        snapshot[key] = (0, object_sort_1.sortObjectByKeys)(snapshot[key]);
+    });
+    return snapshot;
+}
+function findVersion(key, packageName) {
+    if (key.startsWith(`/${packageName}/`)) {
+        return getVersion(key, packageName);
+    }
+    // for alias packages prepend with "npm:"
+    if (key.startsWith('/')) {
+        const aliasName = key.slice(1, key.lastIndexOf('/'));
+        const version = getVersion(key, aliasName);
+        return `npm:${aliasName}@${version}`;
+    }
+    // for tarball package the entire key is the version spec
+    return key;
+}
+function findPackageNames(key, snapshot, data) {
+    const packageNames = new Set();
+    const originalPackageName = extractNameFromKey(key);
+    const matchPropValue = (record) => {
+        if (!record) {
+            return undefined;
+        }
+        const index = Object.values(record).findIndex((version) => version === key);
+        if (index > -1) {
+            return Object.keys(record)[index];
+        }
+        // check if non aliased name is found
+        if (record[originalPackageName] &&
+            key.startsWith(`/${originalPackageName}/${record[originalPackageName]}`)) {
+            return originalPackageName;
+        }
+    };
+    const matchedDependencyName = (importer) => {
+        return (matchPropValue(importer.dependencies) ||
+            matchPropValue(importer.optionalDependencies) ||
+            matchPropValue(importer.peerDependencies));
+    };
+    // snapshot already has a name
+    if (snapshot.name) {
+        packageNames.add(snapshot.name);
+    }
+    // it'a a root dependency
+    const rootDependencyName = matchedDependencyName(data.importers['.']) ||
+        // only root importers have devDependencies
+        matchPropValue(data.importers['.'].devDependencies);
+    if (rootDependencyName) {
+        packageNames.add(rootDependencyName);
+    }
+    // find a snapshot that has a dependency that points to this snapshot
+    const snapshots = Object.values(data.packages);
+    for (let i = 0; i < snapshots.length; i++) {
+        const dependencyName = matchedDependencyName(snapshots[i]);
+        if (dependencyName) {
+            packageNames.add(dependencyName);
+        }
+    }
+    if (packageNames.size === 0) {
+        packageNames.add(originalPackageName);
+    }
+    return Array.from(packageNames);
+}
+function getVersion(key, packageName) {
+    const KEY_NAME_SEPARATOR_LENGTH = 2; // leading and trailing slash
+    return key.slice(packageName.length + KEY_NAME_SEPARATOR_LENGTH);
+}
+function extractNameFromKey(key) {
+    // if package name contains org e.g. "/@babel/runtime/7.12.5"
+    // we want slice until the third slash
+    if (key.startsWith('/@')) {
+        // find the position of the '/' after org name
+        const startFrom = key.indexOf('/', 1);
+        return key.slice(1, key.indexOf('/', startFrom + 1));
+    }
+    if (key.startsWith('/')) {
+        // if package has just a name e.g. "/react/7.12.5..."
+        return key.slice(1, key.indexOf('/', 1));
+    }
+    return key;
+}
 
-Object.defineProperty(exports, "__esModule", ({
-  value: true
-}));
-exports["default"] = void 0;
-
-var _validate = _interopRequireDefault(__nccwpck_require__(63498));
-
-function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
-
-function parse(uuid) {
-  if (!(0, _validate.default)(uuid)) {
-    throw TypeError('Invalid UUID');
-  }
-
-  let v;
-  const arr = new Uint8Array(16); // Parse ########-....-....-....-............
-
-  arr[0] = (v = parseInt(uuid.slice(0, 8), 16)) >>> 24;
-  arr[1] = v >>> 16 & 0xff;
-  arr[2] = v >>> 8 & 0xff;
-  arr[3] = v & 0xff; // Parse ........-####-....-....-............
 
-  arr[4] = (v = parseInt(uuid.slice(9, 13), 16)) >>> 8;
-  arr[5] = v & 0xff; // Parse ........-....-####-....-............
+/***/ }),
 
-  arr[6] = (v = parseInt(uuid.slice(14, 18), 16)) >>> 8;
-  arr[7] = v & 0xff; // Parse ........-....-....-####-............
+/***/ 35765:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
-  arr[8] = (v = parseInt(uuid.slice(19, 23), 16)) >>> 8;
-  arr[9] = v & 0xff; // Parse ........-....-....-....-############
-  // (Use "/" to avoid 32-bit truncation when bit-shifting high-order bytes)
+"use strict";
 
-  arr[10] = (v = parseInt(uuid.slice(24, 36), 16)) / 0x10000000000 & 0xff;
-  arr[11] = v / 0x100000000 & 0xff;
-  arr[12] = v >>> 24 & 0xff;
-  arr[13] = v >>> 16 & 0xff;
-  arr[14] = v >>> 8 & 0xff;
-  arr[15] = v & 0xff;
-  return arr;
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.pruneProjectGraph = void 0;
+const semver_1 = __nccwpck_require__(66195);
+const project_graph_builder_1 = __nccwpck_require__(80862);
+const operators_1 = __nccwpck_require__(5959);
+/**
+ * Prune project graph's external nodes and their dependencies
+ * based on the pruned package.json
+ */
+function pruneProjectGraph(graph, prunedPackageJson) {
+    const builder = new project_graph_builder_1.ProjectGraphBuilder();
+    const combinedDependencies = normalizeDependencies(prunedPackageJson, graph);
+    addNodesAndDependencies(graph, combinedDependencies, builder);
+    // for NPM (as well as the graph consistency)
+    // we need to distinguish between hoisted and non-hoisted dependencies
+    rehoistNodes(graph, combinedDependencies, builder);
+    return builder.getUpdatedProjectGraph();
+}
+exports.pruneProjectGraph = pruneProjectGraph;
+// ensure that dependency ranges from package.json (e.g. ^1.0.0)
+// are replaced with the actual version based on the available nodes (e.g. 1.0.1)
+function normalizeDependencies(packageJson, graph) {
+    const { dependencies, devDependencies, optionalDependencies, peerDependencies, } = packageJson;
+    const combinedDependencies = {
+        ...dependencies,
+        ...devDependencies,
+        ...optionalDependencies,
+        ...peerDependencies,
+    };
+    Object.entries(combinedDependencies).forEach(([packageName, versionRange]) => {
+        if (graph.externalNodes[`npm:${packageName}@${versionRange}`]) {
+            return;
+        }
+        if (graph.externalNodes[`npm:${packageName}`] &&
+            graph.externalNodes[`npm:${packageName}`].data.version === versionRange) {
+            return;
+        }
+        // otherwise we need to find the correct version
+        const node = findNodeMatchingVersion(graph, packageName, versionRange);
+        if (node) {
+            combinedDependencies[packageName] = node.data.version;
+        }
+        else {
+            throw new Error(`Pruned lock file creation failed. The following package was not found in the root lock file: ${packageName}@${versionRange}`);
+        }
+    });
+    return combinedDependencies;
+}
+function findNodeMatchingVersion(graph, packageName, versionExpr) {
+    if (versionExpr === '*') {
+        return graph.externalNodes[`npm:${packageName}`];
+    }
+    const nodes = Object.values(graph.externalNodes)
+        .filter((n) => n.data.packageName === packageName)
+        .sort((a, b) => ((0, semver_1.gte)(b.data.version, a.data.version) ? 1 : -1));
+    if (versionExpr === 'latest') {
+        return nodes.sort((a, b) => +(0, semver_1.gte)(b.data.version, a.data.version))[0];
+    }
+    if (graph.externalNodes[`npm:${packageName}`] &&
+        (0, semver_1.satisfies)(graph.externalNodes[`npm:${packageName}`].data.version, versionExpr)) {
+        return graph.externalNodes[`npm:${packageName}`];
+    }
+    return nodes.find((n) => (0, semver_1.satisfies)(n.data.version, versionExpr));
+}
+function addNodesAndDependencies(graph, packageJsonDeps, builder) {
+    Object.entries(packageJsonDeps).forEach(([name, version]) => {
+        const node = graph.externalNodes[`npm:${name}@${version}`] ||
+            graph.externalNodes[`npm:${name}`];
+        traverseNode(graph, builder, node);
+    });
+}
+function traverseNode(graph, builder, node) {
+    if (builder.graph.externalNodes[node.name]) {
+        return;
+    }
+    builder.addExternalNode(node);
+    graph.dependencies[node.name]?.forEach((dep) => {
+        const depNode = graph.externalNodes[dep.target];
+        traverseNode(graph, builder, depNode);
+        builder.addStaticDependency(node.name, dep.target);
+    });
+}
+function rehoistNodes(graph, packageJsonDeps, builder) {
+    const packagesToRehoist = new Map();
+    // find all packages that need to be rehoisted
+    Object.values(graph.externalNodes).forEach((node) => {
+        if (node.name === `npm:${node.data.packageName}` &&
+            !builder.graph.externalNodes[node.name]) {
+            const nestedNodes = Object.values(builder.graph.externalNodes).filter((n) => n.data.packageName === node.data.packageName);
+            if (nestedNodes.length > 0) {
+                packagesToRehoist.set(node.data.packageName, nestedNodes);
+            }
+        }
+    });
+    // invert dependencies for easier traversal back
+    const invertedGraph = (0, operators_1.reverse)(builder.graph);
+    const invBuilder = new project_graph_builder_1.ProjectGraphBuilder(invertedGraph, {});
+    // find new hoisted version
+    packagesToRehoist.forEach((nestedNodes) => {
+        if (nestedNodes.length === 1) {
+            switchNodeToHoisted(nestedNodes[0], builder, invBuilder);
+        }
+        else {
+            let minDistance = Infinity;
+            let closest;
+            nestedNodes.forEach((node) => {
+                const distance = pathLengthToIncoming(node, packageJsonDeps, builder, invertedGraph);
+                if (distance < minDistance) {
+                    minDistance = distance;
+                    closest = node;
+                }
+            });
+            switchNodeToHoisted(closest, builder, invBuilder);
+        }
+    });
 }
-
-var _default = parse;
-exports["default"] = _default;
-
-/***/ }),
-
-/***/ 65409:
-/***/ ((__unused_webpack_module, exports) => {
-
-"use strict";
-
-
-Object.defineProperty(exports, "__esModule", ({
-  value: true
-}));
-exports["default"] = void 0;
-var _default = /^(?:[0-9a-f]{8}-[0-9a-f]{4}-[1-5][0-9a-f]{3}-[89ab][0-9a-f]{3}-[0-9a-f]{12}|00000000-0000-0000-0000-000000000000)$/i;
-exports["default"] = _default;
-
-/***/ }),
-
-/***/ 64315:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
-
-"use strict";
-
-
-Object.defineProperty(exports, "__esModule", ({
-  value: true
-}));
-exports["default"] = rng;
-
-var _crypto = _interopRequireDefault(__nccwpck_require__(6113));
-
-function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
-
-const rnds8Pool = new Uint8Array(256); // # of random values to pre-allocate
-
-let poolPtr = rnds8Pool.length;
-
-function rng() {
-  if (poolPtr > rnds8Pool.length - 16) {
-    _crypto.default.randomFillSync(rnds8Pool);
-
-    poolPtr = 0;
-  }
-
-  return rnds8Pool.slice(poolPtr, poolPtr += 16);
+function switchNodeToHoisted(node, builder, invBuilder) {
+    // make a copy of current name, all the dependencies and dependents
+    const previousName = node.name;
+    const targets = (builder.graph.dependencies[node.name] || []).map((d) => d.target);
+    const sources = Object.keys(builder.graph.dependencies).filter((name) => builder.graph.dependencies[name].some((d) => d.target === previousName));
+    builder.removeNode(node.name);
+    invBuilder.removeNode(node.name);
+    // modify the node and re-add it
+    node.name = `npm:${node.data.packageName}`;
+    builder.addExternalNode(node);
+    invBuilder.addExternalNode(node);
+    targets.forEach((target) => {
+        builder.addStaticDependency(node.name, target);
+        invBuilder.addStaticDependency(target, node.name);
+    });
+    sources.forEach((source) => {
+        builder.addStaticDependency(source, node.name);
+        invBuilder.addStaticDependency(node.name, source);
+    });
 }
-
-/***/ }),
-
-/***/ 19843:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
-
-"use strict";
-
-
-Object.defineProperty(exports, "__esModule", ({
-  value: true
-}));
-exports["default"] = void 0;
-
-var _crypto = _interopRequireDefault(__nccwpck_require__(6113));
-
-function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
-
-function sha1(bytes) {
-  if (Array.isArray(bytes)) {
-    bytes = Buffer.from(bytes);
-  } else if (typeof bytes === 'string') {
-    bytes = Buffer.from(bytes, 'utf8');
-  }
-
-  return _crypto.default.createHash('sha1').update(bytes).digest();
+// BFS to find the shortest path to a dependency specified in package.json
+// package version with the shortest path is the one that should be hoisted
+function pathLengthToIncoming(node, packageJsonDeps, builder, invertedGraph) {
+    const visited = new Set([node.name]);
+    const queue = [[node, 0]];
+    while (queue.length > 0) {
+        const [current, distance] = queue.shift();
+        if (packageJsonDeps[current.data.packageName] === current.data.version) {
+            return distance;
+        }
+        for (let { target } of invertedGraph.dependencies[current.name] || []) {
+            if (!visited.has(target)) {
+                visited.add(target);
+                queue.push([builder.graph.externalNodes[target], distance + 1]);
+            }
+        }
+    }
 }
 
-var _default = sha1;
-exports["default"] = _default;
 
 /***/ }),
 
-/***/ 82332:
+/***/ 20992:
 /***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
 "use strict";
 
-
-Object.defineProperty(exports, "__esModule", ({
-  value: true
-}));
-exports["default"] = void 0;
-
-var _validate = _interopRequireDefault(__nccwpck_require__(63498));
-
-function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
-
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.normalizePackageJson = exports.getHoistedPackageVersion = void 0;
+const fs_1 = __nccwpck_require__(57147);
+const workspace_root_1 = __nccwpck_require__(86708);
 /**
- * Convert array of 16 byte values to UUID string format of the form:
- * XXXXXXXX-XXXX-XXXX-XXXX-XXXXXXXXXXXX
+ * Get version of hoisted package if available
  */
-const byteToHex = [];
-
-for (let i = 0; i < 256; ++i) {
-  byteToHex.push((i + 0x100).toString(16).substr(1));
+function getHoistedPackageVersion(packageName) {
+    const fullPath = `${workspace_root_1.workspaceRoot}/node_modules/${packageName}/package.json`;
+    if ((0, fs_1.existsSync)(fullPath)) {
+        const content = (0, fs_1.readFileSync)(fullPath, 'utf-8');
+        return JSON.parse(content)?.version;
+    }
+    return;
 }
-
-function stringify(arr, offset = 0) {
-  // Note: Be careful editing this code!  It's been tuned for performance
-  // and works in ways you may not expect. See https://github.com/uuidjs/uuid/pull/434
-  const uuid = (byteToHex[arr[offset + 0]] + byteToHex[arr[offset + 1]] + byteToHex[arr[offset + 2]] + byteToHex[arr[offset + 3]] + '-' + byteToHex[arr[offset + 4]] + byteToHex[arr[offset + 5]] + '-' + byteToHex[arr[offset + 6]] + byteToHex[arr[offset + 7]] + '-' + byteToHex[arr[offset + 8]] + byteToHex[arr[offset + 9]] + '-' + byteToHex[arr[offset + 10]] + byteToHex[arr[offset + 11]] + byteToHex[arr[offset + 12]] + byteToHex[arr[offset + 13]] + byteToHex[arr[offset + 14]] + byteToHex[arr[offset + 15]]).toLowerCase(); // Consistency check for valid UUID.  If this throws, it's likely due to one
-  // of the following:
-  // - One or more input array values don't map to a hex octet (leading to
-  // "undefined" in the uuid)
-  // - Invalid input values for the RFC `version` or `variant` fields
-
-  if (!(0, _validate.default)(uuid)) {
-    throw TypeError('Stringified UUID is invalid');
-  }
-
-  return uuid;
+exports.getHoistedPackageVersion = getHoistedPackageVersion;
+/**
+ * Strip off non-pruning related fields from package.json
+ */
+function normalizePackageJson(packageJson) {
+    const { name, version, license, dependencies, devDependencies, peerDependencies, peerDependenciesMeta, optionalDependencies, } = packageJson;
+    return {
+        name,
+        version,
+        license,
+        dependencies,
+        devDependencies,
+        peerDependencies,
+        peerDependenciesMeta,
+        optionalDependencies,
+    };
 }
+exports.normalizePackageJson = normalizePackageJson;
 
-var _default = stringify;
-exports["default"] = _default;
 
 /***/ }),
 
-/***/ 85618:
+/***/ 93434:
 /***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
 "use strict";
 
-
-Object.defineProperty(exports, "__esModule", ({
-  value: true
-}));
-exports["default"] = void 0;
-
-var _rng = _interopRequireDefault(__nccwpck_require__(64315));
-
-var _stringify = _interopRequireDefault(__nccwpck_require__(82332));
-
-function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
-
-// **`v1()` - Generate time-based UUID**
-//
-// Inspired by https://github.com/LiosK/UUID.js
-// and http://docs.python.org/library/uuid.html
-let _nodeId;
-
-let _clockseq; // Previous uuid creation time
-
-
-let _lastMSecs = 0;
-let _lastNSecs = 0; // See https://github.com/uuidjs/uuid for API details
-
-function v1(options, buf, offset) {
-  let i = buf && offset || 0;
-  const b = buf || new Array(16);
-  options = options || {};
-  let node = options.node || _nodeId;
-  let clockseq = options.clockseq !== undefined ? options.clockseq : _clockseq; // node and clockseq need to be initialized to random values if they're not
-  // specified.  We do this lazily to minimize issues related to insufficient
-  // system entropy.  See #189
-
-  if (node == null || clockseq == null) {
-    const seedBytes = options.random || (options.rng || _rng.default)();
-
-    if (node == null) {
-      // Per 4.5, create and 48-bit node id, (47 random bits + multicast bit = 1)
-      node = _nodeId = [seedBytes[0] | 0x01, seedBytes[1], seedBytes[2], seedBytes[3], seedBytes[4], seedBytes[5]];
+/**
+ * This file contains the logic to convert pnpm lockfile to a standard format.
+ * It will convert inline specifiers to the separate specifiers format and ensure importers are present.
+ */
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.stringifyToPnpmYaml = exports.parseAndNormalizePnpmLockfile = exports.loadPnpmHoistedDepsDefinition = exports.isV6Lockfile = void 0;
+const fs_1 = __nccwpck_require__(57147);
+const workspace_root_1 = __nccwpck_require__(86708);
+const semver_1 = __nccwpck_require__(66195);
+function isV6Lockfile(data) {
+    return data.lockfileVersion.toString().startsWith('6.');
+}
+exports.isV6Lockfile = isV6Lockfile;
+function loadPnpmHoistedDepsDefinition() {
+    const fullPath = `${workspace_root_1.workspaceRoot}/node_modules/.modules.yaml`;
+    if ((0, fs_1.existsSync)(fullPath)) {
+        const content = (0, fs_1.readFileSync)(fullPath, 'utf-8');
+        const { load } = __nccwpck_require__(74529);
+        return load(content)?.hoistedDependencies ?? {};
     }
-
-    if (clockseq == null) {
-      // Per 4.2.2, randomize (14 bit) clockseq
-      clockseq = _clockseq = (seedBytes[6] << 8 | seedBytes[7]) & 0x3fff;
+    else {
+        throw new Error(`Could not find ".modules.yaml" at "${fullPath}"`);
     }
-  } // UUID timestamps are 100 nano-second units since the Gregorian epoch,
-  // (1582-10-15 00:00).  JSNumbers aren't precise enough for this, so
-  // time is handled internally as 'msecs' (integer milliseconds) and 'nsecs'
-  // (100-nanoseconds offset from msecs) since unix epoch, 1970-01-01 00:00.
-
-
-  let msecs = options.msecs !== undefined ? options.msecs : Date.now(); // Per 4.2.1.2, use count of uuid's generated during the current clock
-  // cycle to simulate higher resolution clock
-
-  let nsecs = options.nsecs !== undefined ? options.nsecs : _lastNSecs + 1; // Time since last uuid creation (in msecs)
-
-  const dt = msecs - _lastMSecs + (nsecs - _lastNSecs) / 10000; // Per 4.2.1.2, Bump clockseq on clock regression
-
-  if (dt < 0 && options.clockseq === undefined) {
-    clockseq = clockseq + 1 & 0x3fff;
-  } // Reset nsecs if clock regresses (new clockseq) or we've moved onto a new
-  // time interval
-
-
-  if ((dt < 0 || msecs > _lastMSecs) && options.nsecs === undefined) {
-    nsecs = 0;
-  } // Per 4.2.1.2 Throw error if too many uuids are requested
-
-
-  if (nsecs >= 10000) {
-    throw new Error("uuid.v1(): Can't create more than 10M uuids/sec");
-  }
-
-  _lastMSecs = msecs;
-  _lastNSecs = nsecs;
-  _clockseq = clockseq; // Per 4.1.4 - Convert from unix epoch to Gregorian epoch
-
-  msecs += 12219292800000; // `time_low`
-
-  const tl = ((msecs & 0xfffffff) * 10000 + nsecs) % 0x100000000;
-  b[i++] = tl >>> 24 & 0xff;
-  b[i++] = tl >>> 16 & 0xff;
-  b[i++] = tl >>> 8 & 0xff;
-  b[i++] = tl & 0xff; // `time_mid`
-
-  const tmh = msecs / 0x100000000 * 10000 & 0xfffffff;
-  b[i++] = tmh >>> 8 & 0xff;
-  b[i++] = tmh & 0xff; // `time_high_and_version`
-
-  b[i++] = tmh >>> 24 & 0xf | 0x10; // include version
-
-  b[i++] = tmh >>> 16 & 0xff; // `clock_seq_hi_and_reserved` (Per 4.2.2 - include variant)
-
-  b[i++] = clockseq >>> 8 | 0x80; // `clock_seq_low`
-
-  b[i++] = clockseq & 0xff; // `node`
-
-  for (let n = 0; n < 6; ++n) {
-    b[i + n] = node[n];
-  }
-
-  return buf || (0, _stringify.default)(b);
+}
+exports.loadPnpmHoistedDepsDefinition = loadPnpmHoistedDepsDefinition;
+/*************************************************************************
+ * THE FOLLOWING CODE IS COPIED & simplified FROM @pnpm/lockfile-file for convenience
+ *************************************************************************/
+/**
+ * Parsing and mapping logic from pnpm lockfile `read` function
+ * https://github.com/pnpm/pnpm/blob/af3e5559d377870d4c3d303429b3ed1a4e64fedc/lockfile/lockfile-file/src/read.ts#L91
+ */
+function parseAndNormalizePnpmLockfile(content) {
+    const { load } = __nccwpck_require__(74529);
+    const lockFileData = load(content);
+    return revertFromInlineSpecifiersFormatIfNecessary(convertFromLockfileFileMutable(lockFileData));
+}
+exports.parseAndNormalizePnpmLockfile = parseAndNormalizePnpmLockfile;
+/**
+ * Reverts changes from the "forceSharedFormat" write option if necessary.
+ * https://github.com/pnpm/pnpm/blob/af3e5559d377870d4c3d303429b3ed1a4e64fedc/lockfile/lockfile-file/src/read.ts#L234
+ */
+function convertFromLockfileFileMutable(lockfileFile) {
+    if (typeof lockfileFile?.['importers'] === 'undefined') {
+        lockfileFile.importers = {
+            '.': {
+                specifiers: lockfileFile['specifiers'] ?? {},
+                dependenciesMeta: lockfileFile['dependenciesMeta'],
+                publishDirectory: lockfileFile['publishDirectory'],
+            },
+        };
+        delete lockfileFile.specifiers;
+        for (const depType of DEPENDENCIES_FIELDS) {
+            if (lockfileFile[depType] != null) {
+                lockfileFile.importers['.'][depType] = lockfileFile[depType];
+                delete lockfileFile[depType];
+            }
+        }
+    }
+    return lockfileFile;
+}
+// https://github.com/pnpm/pnpm/blob/af3e5559d377870d4c3d303429b3ed1a4e64fedc/lockfile/lockfile-file/src/write.ts#L27
+const LOCKFILE_YAML_FORMAT = {
+    blankLines: true,
+    lineWidth: 1000,
+    noCompatMode: true,
+    noRefs: true,
+    sortKeys: false,
+};
+/**
+ * Mapping and writing logic from pnpm lockfile `write` function
+ * https://github.com/pnpm/pnpm/blob/af3e5559d377870d4c3d303429b3ed1a4e64fedc/lockfile/lockfile-file/src/write.ts#L77
+ */
+function stringifyToPnpmYaml(lockfile) {
+    const isLockfileV6 = isV6Lockfile(lockfile);
+    const adaptedLockfile = isLockfileV6
+        ? convertToInlineSpecifiersFormat(lockfile)
+        : lockfile;
+    const { dump } = __nccwpck_require__(74529);
+    return dump(sortLockfileKeys(normalizeLockfile(adaptedLockfile, isLockfileV6)), LOCKFILE_YAML_FORMAT);
+}
+exports.stringifyToPnpmYaml = stringifyToPnpmYaml;
+// https://github.com/pnpm/pnpm/blob/af3e5559d377870d4c3d303429b3ed1a4e64fedc/lockfile/lockfile-file/src/write.ts#L106
+function normalizeLockfile(lockfile, isLockfileV6) {
+    let lockfileToSave;
+    if (Object.keys(lockfile.importers).length === 1 && lockfile.importers['.']) {
+        lockfileToSave = {
+            ...lockfile,
+            ...lockfile.importers['.'],
+        };
+        delete lockfileToSave.importers;
+        for (const depType of DEPENDENCIES_FIELDS) {
+            if (isEmpty(lockfileToSave[depType])) {
+                delete lockfileToSave[depType];
+            }
+        }
+        if (isEmpty(lockfileToSave.packages) || lockfileToSave.packages == null) {
+            delete lockfileToSave.packages;
+        }
+    }
+    else {
+        lockfileToSave = {
+            ...lockfile,
+            importers: mapValues(lockfile.importers, (importer) => {
+                const normalizedImporter = {};
+                if (!isEmpty(importer.specifiers ?? {}) || !isLockfileV6) {
+                    normalizedImporter['specifiers'] = importer.specifiers ?? {};
+                }
+                if (importer.dependenciesMeta != null &&
+                    !isEmpty(importer.dependenciesMeta)) {
+                    normalizedImporter['dependenciesMeta'] = importer.dependenciesMeta;
+                }
+                for (const depType of DEPENDENCIES_FIELDS) {
+                    if (!isEmpty(importer[depType] ?? {})) {
+                        normalizedImporter[depType] = importer[depType];
+                    }
+                }
+                if (importer.publishDirectory) {
+                    normalizedImporter.publishDirectory = importer.publishDirectory;
+                }
+                return normalizedImporter;
+            }),
+        };
+        if (isEmpty(lockfileToSave.packages) || lockfileToSave.packages == null) {
+            delete lockfileToSave.packages;
+        }
+    }
+    if (lockfileToSave.time) {
+        lockfileToSave.time = (isLockfileV6 ? pruneTimeInLockfileV6 : pruneTime)(lockfileToSave.time, lockfile.importers);
+    }
+    if (lockfileToSave.overrides != null && isEmpty(lockfileToSave.overrides)) {
+        delete lockfileToSave.overrides;
+    }
+    if (lockfileToSave.patchedDependencies != null &&
+        isEmpty(lockfileToSave.patchedDependencies)) {
+        delete lockfileToSave.patchedDependencies;
+    }
+    if (lockfileToSave.neverBuiltDependencies != null) {
+        if (isEmpty(lockfileToSave.neverBuiltDependencies)) {
+            delete lockfileToSave.neverBuiltDependencies;
+        }
+        else {
+            lockfileToSave.neverBuiltDependencies =
+                lockfileToSave.neverBuiltDependencies.sort();
+        }
+    }
+    if (lockfileToSave.onlyBuiltDependencies != null) {
+        lockfileToSave.onlyBuiltDependencies =
+            lockfileToSave.onlyBuiltDependencies.sort();
+    }
+    if (!lockfileToSave.packageExtensionsChecksum) {
+        delete lockfileToSave.packageExtensionsChecksum;
+    }
+    return lockfileToSave;
+}
+// https://github.com/pnpm/pnpm/blob/af3e5559d377870d4c3d303429b3ed1a4e64fedc/lockfile/lockfile-file/src/write.ts#L173
+function pruneTimeInLockfileV6(time, importers) {
+    const rootDepPaths = new Set();
+    for (const importer of Object.values(importers)) {
+        for (const depType of DEPENDENCIES_FIELDS) {
+            for (let [depName, ref] of Object.entries(importer[depType] ?? {})) {
+                let version;
+                if (ref['version']) {
+                    version = ref['version'];
+                }
+                else {
+                    version = ref;
+                }
+                const suffixStart = version.indexOf('(');
+                const refWithoutPeerSuffix = suffixStart === -1 ? version : version.slice(0, suffixStart);
+                const depPath = refToRelative(refWithoutPeerSuffix, depName);
+                if (!depPath)
+                    continue;
+                rootDepPaths.add(depPath);
+            }
+        }
+    }
+    return pickBy((prop) => rootDepPaths.has(prop), time);
+}
+// https://github.com/pnpm/pnpm/blob/af3e5559d377870d4c3d303429b3ed1a4e64fedc/lockfile/lockfile-file/src/write.ts#L191
+function refToRelative(reference, pkgName) {
+    if (reference.startsWith('link:')) {
+        return null;
+    }
+    if (reference.startsWith('file:')) {
+        return reference;
+    }
+    if (!reference.includes('/') ||
+        !reference.replace(/(\([^)]+\))+$/, '').includes('/')) {
+        return `/${pkgName}@${reference}`;
+    }
+    return reference;
+}
+// https://github.com/pnpm/pnpm/blob/af3e5559d377870d4c3d303429b3ed1a4e64fedc/lockfile/lockfile-file/src/write.ts#L207
+function pruneTime(time, importers) {
+    const rootDepPaths = new Set();
+    for (const importer of Object.values(importers)) {
+        for (const depType of DEPENDENCIES_FIELDS) {
+            for (let [depName, ref] of Object.entries(importer[depType] ?? {})) {
+                let version;
+                if (ref['version']) {
+                    version = ref['version'];
+                }
+                else {
+                    version = ref;
+                }
+                const suffixStart = version.indexOf('_');
+                const refWithoutPeerSuffix = suffixStart === -1 ? version : version.slice(0, suffixStart);
+                const depPath = dpRefToRelative(refWithoutPeerSuffix, depName);
+                if (!depPath)
+                    continue;
+                rootDepPaths.add(depPath);
+            }
+        }
+    }
+    return pickBy((depPath) => rootDepPaths.has(depPath), time);
+}
+// https://github.com/pnpm/pnpm/blob/af3e5559d377870d4c3d303429b3ed1a4e64fedc/lockfile/lockfile-file/src/sortLockfileKeys.ts#L34
+const ROOT_KEYS_ORDER = {
+    lockfileVersion: 1,
+    // only and never are conflict options.
+    neverBuiltDependencies: 2,
+    onlyBuiltDependencies: 2,
+    overrides: 3,
+    packageExtensionsChecksum: 4,
+    patchedDependencies: 5,
+    specifiers: 10,
+    dependencies: 11,
+    optionalDependencies: 12,
+    devDependencies: 13,
+    dependenciesMeta: 14,
+    importers: 15,
+    packages: 16,
+};
+// https://github.com/pnpm/pnpm/blob/af3e5559d377870d4c3d303429b3ed1a4e64fedc/lockfile/lockfile-file/src/sortLockfileKeys.ts#L60
+function sortLockfileKeys(lockfile) {
+    let sortedLockfile = {};
+    const sortedKeys = Object.keys(lockfile).sort((a, b) => ROOT_KEYS_ORDER[a] - ROOT_KEYS_ORDER[b]);
+    for (const key of sortedKeys) {
+        sortedLockfile[key] = lockfile[key];
+    }
+    return sortedLockfile;
+}
+/**
+ * Types from https://github.com/pnpm/pnpm/blob/af3e5559d377870d4c3d303429b3ed1a4e64fedc/lockfile/lockfile-file/src/experiments/InlineSpecifiersLockfile.ts
+ */
+const INLINE_SPECIFIERS_FORMAT_LOCKFILE_VERSION_SUFFIX = '-inlineSpecifiers';
+// https://github.com/pnpm/pnpm/blob/af3e5559d377870d4c3d303429b3ed1a4e64fedc/lockfile/lockfile-file/src/experiments/inlineSpecifiersLockfileConverters.ts#L10
+function isExperimentalInlineSpecifiersFormat(lockfile) {
+    const { lockfileVersion } = lockfile;
+    return (lockfileVersion.toString().startsWith('6.') ||
+        (typeof lockfileVersion === 'string' &&
+            lockfileVersion.endsWith(INLINE_SPECIFIERS_FORMAT_LOCKFILE_VERSION_SUFFIX)));
+}
+// https://github.com/pnpm/pnpm/blob/af3e5559d377870d4c3d303429b3ed1a4e64fedc/lockfile/lockfile-file/src/experiments/inlineSpecifiersLockfileConverters.ts#L17
+function convertToInlineSpecifiersFormat(lockfile) {
+    let importers = lockfile.importers;
+    let packages = lockfile.packages;
+    if (isV6Lockfile(lockfile)) {
+        importers = Object.fromEntries(Object.entries(lockfile.importers ?? {}).map(([importerId, pkgSnapshot]) => {
+            const newSnapshot = { ...pkgSnapshot };
+            if (newSnapshot.dependencies != null) {
+                newSnapshot.dependencies = mapValues(newSnapshot.dependencies, convertOldRefToNewRef);
+            }
+            if (newSnapshot.optionalDependencies != null) {
+                newSnapshot.optionalDependencies = mapValues(newSnapshot.optionalDependencies, convertOldRefToNewRef);
+            }
+            if (newSnapshot.devDependencies != null) {
+                newSnapshot.devDependencies = mapValues(newSnapshot.devDependencies, convertOldRefToNewRef);
+            }
+            return [importerId, newSnapshot];
+        }));
+        packages = Object.fromEntries(Object.entries(lockfile.packages ?? {}).map(([depPath, pkgSnapshot]) => {
+            const newSnapshot = { ...pkgSnapshot };
+            if (newSnapshot.dependencies != null) {
+                newSnapshot.dependencies = mapValues(newSnapshot.dependencies, convertOldRefToNewRef);
+            }
+            if (newSnapshot.optionalDependencies != null) {
+                newSnapshot.optionalDependencies = mapValues(newSnapshot.optionalDependencies, convertOldRefToNewRef);
+            }
+            return [convertOldDepPathToNewDepPath(depPath), newSnapshot];
+        }));
+    }
+    const newLockfile = {
+        ...lockfile,
+        packages,
+        lockfileVersion: isV6Lockfile(lockfile)
+            ? lockfile.lockfileVersion.toString()
+            : lockfile.lockfileVersion
+                .toString()
+                .endsWith(INLINE_SPECIFIERS_FORMAT_LOCKFILE_VERSION_SUFFIX)
+                ? lockfile.lockfileVersion.toString()
+                : `${lockfile.lockfileVersion}${INLINE_SPECIFIERS_FORMAT_LOCKFILE_VERSION_SUFFIX}`,
+        importers: mapValues(importers, convertProjectSnapshotToInlineSpecifiersFormat),
+    };
+    if (isV6Lockfile(lockfile) && newLockfile.time) {
+        newLockfile.time = Object.fromEntries(Object.entries(newLockfile.time).map(([depPath, time]) => [
+            convertOldDepPathToNewDepPath(depPath),
+            time,
+        ]));
+    }
+    return newLockfile;
+}
+// https://github.com/pnpm/pnpm/blob/af3e5559d377870d4c3d303429b3ed1a4e64fedc/lockfile/lockfile-file/src/experiments/inlineSpecifiersLockfileConverters.ts#L72
+function convertOldDepPathToNewDepPath(oldDepPath) {
+    const parsedDepPath = dpParse(oldDepPath);
+    if (!parsedDepPath.name || !parsedDepPath.version)
+        return oldDepPath;
+    let newDepPath = `/${parsedDepPath.name}@${parsedDepPath.version}`;
+    if (parsedDepPath.peersSuffix) {
+        if (parsedDepPath.peersSuffix.startsWith('(')) {
+            newDepPath += parsedDepPath.peersSuffix;
+        }
+        else {
+            newDepPath += `_${parsedDepPath.peersSuffix}`;
+        }
+    }
+    if (parsedDepPath.host) {
+        newDepPath = `${parsedDepPath.host}${newDepPath}`;
+    }
+    return newDepPath;
+}
+// https://github.com/pnpm/pnpm/blob/af3e5559d377870d4c3d303429b3ed1a4e64fedc/lockfile/lockfile-file/src/experiments/inlineSpecifiersLockfileConverters.ts#L89
+function convertOldRefToNewRef(oldRef) {
+    if (oldRef.startsWith('link:') || oldRef.startsWith('file:')) {
+        return oldRef;
+    }
+    if (oldRef.includes('/')) {
+        return convertOldDepPathToNewDepPath(oldRef);
+    }
+    return oldRef;
+}
+// https://github.com/pnpm/pnpm/blob/af3e5559d377870d4c3d303429b3ed1a4e64fedc/lockfile/lockfile-file/src/experiments/inlineSpecifiersLockfileConverters.ts#L99
+function revertFromInlineSpecifiersFormatIfNecessary(lockfile) {
+    return isExperimentalInlineSpecifiersFormat(lockfile)
+        ? revertFromInlineSpecifiersFormat(lockfile)
+        : lockfile;
+}
+// https://github.com/pnpm/pnpm/blob/af3e5559d377870d4c3d303429b3ed1a4e64fedc/lockfile/lockfile-file/src/experiments/inlineSpecifiersLockfileConverters.ts#L105
+function revertFromInlineSpecifiersFormat(lockfile) {
+    const { lockfileVersion, importers, ...rest } = lockfile;
+    const originalVersionStr = lockfileVersion.replace(INLINE_SPECIFIERS_FORMAT_LOCKFILE_VERSION_SUFFIX, '');
+    const originalVersion = Number(originalVersionStr);
+    if (isNaN(originalVersion)) {
+        throw new Error(`Unable to revert lockfile from inline specifiers format. Invalid version parsed: ${originalVersionStr}`);
+    }
+    let revertedImporters = mapValues(importers, revertProjectSnapshot);
+    let packages = lockfile.packages;
+    if (originalVersionStr.startsWith('6.')) {
+        revertedImporters = Object.fromEntries(Object.entries(revertedImporters ?? {}).map(([importerId, pkgSnapshot]) => {
+            const newSnapshot = { ...pkgSnapshot };
+            if (newSnapshot.dependencies != null) {
+                newSnapshot.dependencies = mapValues(newSnapshot.dependencies, convertNewRefToOldRef);
+            }
+            if (newSnapshot.optionalDependencies != null) {
+                newSnapshot.optionalDependencies = mapValues(newSnapshot.optionalDependencies, convertNewRefToOldRef);
+            }
+            if (newSnapshot.devDependencies != null) {
+                newSnapshot.devDependencies = mapValues(newSnapshot.devDependencies, convertNewRefToOldRef);
+            }
+            return [importerId, newSnapshot];
+        }));
+        packages = Object.fromEntries(Object.entries(lockfile.packages ?? {}).map(([depPath, pkgSnapshot]) => {
+            const newSnapshot = { ...pkgSnapshot };
+            if (newSnapshot.dependencies != null) {
+                newSnapshot.dependencies = mapValues(newSnapshot.dependencies, convertNewRefToOldRef);
+            }
+            if (newSnapshot.optionalDependencies != null) {
+                newSnapshot.optionalDependencies = mapValues(newSnapshot.optionalDependencies, convertNewRefToOldRef);
+            }
+            return [convertNewDepPathToOldDepPath(depPath), newSnapshot];
+        }));
+    }
+    const newLockfile = {
+        ...rest,
+        lockfileVersion: lockfileVersion.endsWith(INLINE_SPECIFIERS_FORMAT_LOCKFILE_VERSION_SUFFIX)
+            ? originalVersion
+            : lockfileVersion,
+        packages,
+        importers: revertedImporters,
+    };
+    if (originalVersionStr.startsWith('6.') && newLockfile.time) {
+        newLockfile.time = Object.fromEntries(Object.entries(newLockfile.time).map(([depPath, time]) => [
+            convertNewDepPathToOldDepPath(depPath),
+            time,
+        ]));
+    }
+    return newLockfile;
+}
+// https://github.com/pnpm/pnpm/blob/af3e5559d377870d4c3d303429b3ed1a4e64fedc/lockfile/lockfile-file/src/experiments/inlineSpecifiersLockfileConverters.ts#L162
+function convertNewDepPathToOldDepPath(oldDepPath) {
+    if (!oldDepPath.includes('@', 2))
+        return oldDepPath;
+    const index = oldDepPath.indexOf('@', oldDepPath.indexOf('/@') + 2);
+    if (oldDepPath.includes('(') && index > oldDepPath.indexOf('('))
+        return oldDepPath;
+    return `${oldDepPath.substring(0, index)}/${oldDepPath.substring(index + 1)}`;
+}
+// https://github.com/pnpm/pnpm/blob/af3e5559d377870d4c3d303429b3ed1a4e64fedc/lockfile/lockfile-file/src/experiments/inlineSpecifiersLockfileConverters.ts#L169
+function convertNewRefToOldRef(oldRef) {
+    if (oldRef.startsWith('link:') || oldRef.startsWith('file:')) {
+        return oldRef;
+    }
+    if (oldRef.includes('@')) {
+        return convertNewDepPathToOldDepPath(oldRef);
+    }
+    return oldRef;
+}
+// https://github.com/pnpm/pnpm/blob/af3e5559d377870d4c3d303429b3ed1a4e64fedc/lockfile/lockfile-file/src/experiments/inlineSpecifiersLockfileConverters.ts#L179
+function convertProjectSnapshotToInlineSpecifiersFormat(projectSnapshot) {
+    const { specifiers, ...rest } = projectSnapshot;
+    const convertBlock = (block) => block != null
+        ? convertResolvedDependenciesToInlineSpecifiersFormat(block, {
+            specifiers,
+        })
+        : block;
+    return {
+        ...rest,
+        dependencies: convertBlock(projectSnapshot.dependencies),
+        optionalDependencies: convertBlock(projectSnapshot.optionalDependencies),
+        devDependencies: convertBlock(projectSnapshot.devDependencies),
+    };
+}
+// https://github.com/pnpm/pnpm/blob/af3e5559d377870d4c3d303429b3ed1a4e64fedc/lockfile/lockfile-file/src/experiments/inlineSpecifiersLockfileConverters.ts#L195
+function convertResolvedDependenciesToInlineSpecifiersFormat(resolvedDependencies, { specifiers }) {
+    return mapValues(resolvedDependencies, (version, depName) => ({
+        specifier: specifiers[depName],
+        version,
+    }));
+}
+// https://github.com/pnpm/pnpm/blob/af3e5559d377870d4c3d303429b3ed1a4e64fedc/lockfile/lockfile-file/src/experiments/inlineSpecifiersLockfileConverters.ts#L205
+function revertProjectSnapshot(from) {
+    const specifiers = {};
+    function moveSpecifiers(from) {
+        const resolvedDependencies = {};
+        for (const [depName, { specifier, version }] of Object.entries(from)) {
+            const existingValue = specifiers[depName];
+            if (existingValue != null && existingValue !== specifier) {
+                throw new Error(`Project snapshot lists the same dependency more than once with conflicting versions: ${depName}`);
+            }
+            specifiers[depName] = specifier;
+            resolvedDependencies[depName] = version;
+        }
+        return resolvedDependencies;
+    }
+    const dependencies = from.dependencies
+        ? moveSpecifiers(from.dependencies)
+        : null;
+    const devDependencies = from.devDependencies
+        ? moveSpecifiers(from.devDependencies)
+        : null;
+    const optionalDependencies = from.optionalDependencies
+        ? moveSpecifiers(from.optionalDependencies)
+        : null;
+    return {
+        ...from,
+        specifiers,
+        dependencies,
+        devDependencies,
+        optionalDependencies,
+    };
+}
+// https://github.com/pnpm/pnpm/blob/af3e5559d377870d4c3d303429b3ed1a4e64fedc/lockfile/lockfile-file/src/experiments/inlineSpecifiersLockfileConverters.ts#L241
+function mapValues(obj, mapper) {
+    const result = {};
+    for (const [key, value] of Object.entries(obj)) {
+        result[key] = mapper(value, key);
+    }
+    return result;
+}
+/*************************************************************************
+ * THE FOLLOWING CODE IS COPIED FROM @pnpm/types for convenience
+ *************************************************************************/
+// https://github.com/pnpm/pnpm/blob/af3e5559d377870d4c3d303429b3ed1a4e64fedc/packages/types/src/misc.ts#L6
+const DEPENDENCIES_FIELDS = [
+    'optionalDependencies',
+    'dependencies',
+    'devDependencies',
+];
+/*************************************************************************
+ * THE FOLLOWING CODE IS COPIED FROM @pnpm/dependency-path for convenience
+ *************************************************************************/
+// https://github.com/pnpm/pnpm/blob/af3e5559d377870d4c3d303429b3ed1a4e64fedc/packages/dependency-path/src/index.ts#L6
+function isAbsolute(dependencyPath) {
+    return dependencyPath[0] !== '/';
+}
+// https://github.com/pnpm/pnpm/blob/af3e5559d377870d4c3d303429b3ed1a4e64fedc/packages/dependency-path/src/index.ts#L80
+function dpRefToRelative(reference, pkgName) {
+    if (reference.startsWith('link:')) {
+        return null;
+    }
+    if (reference.startsWith('file:')) {
+        return reference;
+    }
+    if (!reference.includes('/') ||
+        (reference.includes('(') &&
+            reference.lastIndexOf('/', reference.indexOf('(')) === -1)) {
+        return `/${pkgName}/${reference}`;
+    }
+    return reference;
+}
+// https://github.com/pnpm/pnpm/blob/af3e5559d377870d4c3d303429b3ed1a4e64fedc/packages/dependency-path/src/index.ts#L96
+function dpParse(dependencyPath) {
+    // eslint-disable-next-line: strict-type-predicates
+    if (typeof dependencyPath !== 'string') {
+        throw new TypeError(`Expected \`dependencyPath\` to be of type \`string\`, got \`${
+        // eslint-disable-next-line: strict-type-predicates
+        dependencyPath === null ? 'null' : typeof dependencyPath}\``);
+    }
+    const _isAbsolute = isAbsolute(dependencyPath);
+    const parts = dependencyPath.split('/');
+    if (!_isAbsolute)
+        parts.shift();
+    const host = _isAbsolute ? parts.shift() : undefined;
+    if (parts.length === 0)
+        return {
+            host,
+            isAbsolute: _isAbsolute,
+        };
+    const name = parts[0].startsWith('@')
+        ? `${parts.shift()}/${parts.shift()}` // eslint-disable-line @typescript-eslint/restrict-template-expressions
+        : parts.shift();
+    let version = parts.join('/');
+    if (version) {
+        let peerSepIndex;
+        let peersSuffix;
+        if (version.includes('(') && version.endsWith(')')) {
+            peerSepIndex = version.indexOf('(');
+            if (peerSepIndex !== -1) {
+                peersSuffix = version.substring(peerSepIndex);
+                version = version.substring(0, peerSepIndex);
+            }
+        }
+        else {
+            peerSepIndex = version.indexOf('_');
+            if (peerSepIndex !== -1) {
+                peersSuffix = version.substring(peerSepIndex + 1);
+                version = version.substring(0, peerSepIndex);
+            }
+        }
+        if ((0, semver_1.valid)(version)) {
+            return {
+                host,
+                isAbsolute: _isAbsolute,
+                name,
+                peersSuffix,
+                version,
+            };
+        }
+    }
+    if (!_isAbsolute)
+        throw new Error(`${dependencyPath} is an invalid relative dependency path`);
+    return {
+        host,
+        isAbsolute: _isAbsolute,
+    };
+}
+/********************************************************************************
+ * THE FOLLOWING CODE IS COPIED AND SIMPLIFIED FROM @pnpm/ramda for convenience
+ *******************************************************************************/
+// https://github.com/pnpm/ramda/blob/50c6b57110b2f3631ed8633141f12012b7768d85/source/pickBy.js#L24
+function pickBy(test, obj) {
+    let result = {};
+    for (const prop in obj) {
+        if (test(obj[prop])) {
+            result[prop] = obj[prop];
+        }
+    }
+    return result;
+}
+// https://github.com/pnpm/ramda/blob/50c6b57110b2f3631ed8633141f12012b7768d85/source/isEmpty.js#L28
+function isEmpty(obj) {
+    return obj != null && Object.keys(obj).length === 0;
 }
 
-var _default = v1;
-exports["default"] = _default;
-
-/***/ }),
-
-/***/ 34643:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
-
-"use strict";
-
-
-Object.defineProperty(exports, "__esModule", ({
-  value: true
-}));
-exports["default"] = void 0;
-
-var _v = _interopRequireDefault(__nccwpck_require__(70181));
-
-var _md = _interopRequireDefault(__nccwpck_require__(37342));
-
-function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
-
-const v3 = (0, _v.default)('v3', 0x30, _md.default);
-var _default = v3;
-exports["default"] = _default;
 
 /***/ }),
 
-/***/ 70181:
+/***/ 83243:
 /***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
 "use strict";
 
-
-Object.defineProperty(exports, "__esModule", ({
-  value: true
-}));
-exports["default"] = _default;
-exports.URL = exports.DNS = void 0;
-
-var _stringify = _interopRequireDefault(__nccwpck_require__(82332));
-
-var _parse = _interopRequireDefault(__nccwpck_require__(9869));
-
-function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
-
-function stringToBytes(str) {
-  str = unescape(encodeURIComponent(str)); // UTF8 escape
-
-  const bytes = [];
-
-  for (let i = 0; i < str.length; ++i) {
-    bytes.push(str.charCodeAt(i));
-  }
-
-  return bytes;
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.stringifyYarnLockfile = exports.getYarnLockfileDependencies = exports.getYarnLockfileNodes = void 0;
+const package_json_1 = __nccwpck_require__(20992);
+const project_graph_builder_1 = __nccwpck_require__(80862);
+const semver_1 = __nccwpck_require__(66195);
+const project_graph_1 = __nccwpck_require__(2184);
+const file_hasher_1 = __nccwpck_require__(50180);
+const object_sort_1 = __nccwpck_require__(84110);
+let currentLockFileHash;
+let cachedParsedLockFile;
+// we use key => node map to avoid duplicate work when parsing keys
+let keyMap = new Map();
+function parseLockFile(lockFileContent, lockFileHash) {
+    if (currentLockFileHash === lockFileHash) {
+        return cachedParsedLockFile;
+    }
+    const { parseSyml } = __nccwpck_require__(2877);
+    keyMap.clear();
+    const result = parseSyml(lockFileContent);
+    cachedParsedLockFile = result;
+    currentLockFileHash = lockFileHash;
+    return result;
+}
+function getYarnLockfileNodes(lockFileContent, lockFileHash, packageJson) {
+    const { __metadata, ...dependencies } = parseLockFile(lockFileContent, lockFileHash);
+    const isBerry = !!__metadata;
+    // yarn classic splits keys when parsing so we need to stich them back together
+    const groupedDependencies = groupDependencies(dependencies, isBerry);
+    return getNodes(groupedDependencies, packageJson, keyMap, isBerry);
+}
+exports.getYarnLockfileNodes = getYarnLockfileNodes;
+function getYarnLockfileDependencies(lockFileContent, lockFileHash, ctx) {
+    const { __metadata, ...dependencies } = parseLockFile(lockFileContent, lockFileHash);
+    const isBerry = !!__metadata;
+    // yarn classic splits keys when parsing so we need to stich them back together
+    const groupedDependencies = groupDependencies(dependencies, isBerry);
+    return getDependencies(groupedDependencies, keyMap, ctx);
+}
+exports.getYarnLockfileDependencies = getYarnLockfileDependencies;
+function getPackageNameKeyPairs(keys) {
+    const result = new Map();
+    keys.split(', ').forEach((key) => {
+        const packageName = key.slice(0, key.indexOf('@', 1));
+        if (result.has(packageName)) {
+            result.get(packageName).add(key);
+        }
+        else {
+            result.set(packageName, new Set([key]));
+        }
+    });
+    return result;
+}
+function getNodes(dependencies, packageJson, keyMap, isBerry) {
+    const nodes = new Map();
+    const combinedDeps = {
+        ...packageJson.dependencies,
+        ...packageJson.devDependencies,
+        ...packageJson.peerDependencies,
+        ...packageJson.optionalDependencies,
+    };
+    Object.entries(dependencies).forEach(([keys, snapshot]) => {
+        // ignore workspace projects & patches
+        if (snapshot.linkType === 'soft' || keys.includes('@patch:')) {
+            return;
+        }
+        const nameKeyPairs = getPackageNameKeyPairs(keys);
+        nameKeyPairs.forEach((keySet, packageName) => {
+            const keysArray = Array.from(keySet);
+            // use key relevant to the package name
+            const version = findVersion(packageName, keysArray[0], snapshot, isBerry);
+            // use keys linked to the extracted package name
+            keysArray.forEach((key) => {
+                // we don't need to keep duplicates, we can just track the keys
+                const existingNode = nodes.get(packageName)?.get(version);
+                if (existingNode) {
+                    keyMap.set(key, existingNode);
+                    return;
+                }
+                const node = {
+                    type: 'npm',
+                    name: version
+                        ? `npm:${packageName}@${version}`
+                        : `npm:${packageName}`,
+                    data: {
+                        version,
+                        packageName,
+                        hash: snapshot.integrity ||
+                            snapshot.checksum ||
+                            (0, file_hasher_1.hashArray)([packageName, version]),
+                    },
+                };
+                keyMap.set(key, node);
+                // use actual version so we can detect it later based on npm package's version
+                const mapKey = snapshot.version && version !== snapshot.version
+                    ? snapshot.version
+                    : version;
+                if (!nodes.has(packageName)) {
+                    nodes.set(packageName, new Map([[mapKey, node]]));
+                }
+                else {
+                    nodes.get(packageName).set(mapKey, node);
+                }
+            });
+        });
+    });
+    const externalNodes = {};
+    for (const [packageName, versionMap] of nodes.entries()) {
+        const hoistedNode = findHoistedNode(packageName, versionMap, combinedDeps);
+        if (hoistedNode) {
+            hoistedNode.name = `npm:${packageName}`;
+        }
+        versionMap.forEach((node) => {
+            externalNodes[node.name] = node;
+        });
+    }
+    return externalNodes;
+}
+function findHoistedNode(packageName, versionMap, combinedDeps) {
+    const hoistedVersion = getHoistedVersion(packageName);
+    if (hoistedVersion) {
+        return versionMap.get(hoistedVersion);
+    }
+    const rootVersionSpecifier = combinedDeps[packageName];
+    if (!rootVersionSpecifier) {
+        return;
+    }
+    const versions = Array.from(versionMap.keys()).sort((a, b) => (0, semver_1.gt)(a, b) ? -1 : 1);
+    // take the highest version found
+    if (rootVersionSpecifier === '*') {
+        return versionMap.get(versions[0]);
+    }
+    // take version that satisfies the root version specifier
+    let version = versions.find((v) => (0, semver_1.satisfies)(v, rootVersionSpecifier));
+    if (!version) {
+        // try to find alias version
+        version = versions.find((v) => versionMap.get(v).name === `npm:${packageName}@${rootVersionSpecifier}`);
+    }
+    if (!version) {
+        // try to find tarball package
+        version = versions.find((v) => versionMap.get(v).data.version !== v);
+    }
+    if (version) {
+        return versionMap.get(version);
+    }
+}
+function findVersion(packageName, key, snapshot, isBerry) {
+    const versionRange = key.slice(key.indexOf('@', 1) + 1);
+    // check for alias packages
+    const isAlias = isBerry
+        ? snapshot.resolution && !snapshot.resolution.startsWith(`${packageName}@`)
+        : versionRange.startsWith('npm:');
+    if (isAlias) {
+        return versionRange;
+    }
+    // check for berry tarball packages
+    if (isBerry &&
+        snapshot.resolution &&
+        // different registry would yield suffix following '::' which we don't need
+        snapshot.resolution.split('::')[0] !==
+            `${packageName}@npm:${snapshot.version}`) {
+        return snapshot.resolution.slice(packageName.length + 1);
+    }
+    if (!isBerry && isTarballPackage(versionRange, snapshot)) {
+        return snapshot.resolved;
+    }
+    // otherwise it's a standard version
+    return snapshot.version;
+}
+// check if snapshot represents tarball package
+function isTarballPackage(versionRange, snapshot) {
+    // if resolved is missing it's internal link
+    if (!snapshot.resolved) {
+        return false;
+    }
+    // tarballs have no integrity
+    if (snapshot.integrity) {
+        return false;
+    }
+    try {
+        new semver_1.Range(versionRange);
+        // range is a valid semver
+        return false;
+    }
+    catch {
+        // range is not a valid semver, it can be an npm tag or url part of a tarball
+        return snapshot.version && !snapshot.resolved.includes(snapshot.version);
+    }
+}
+function getHoistedVersion(packageName) {
+    const version = (0, package_json_1.getHoistedPackageVersion)(packageName);
+    if (version) {
+        return version;
+    }
+}
+function getDependencies(dependencies, keyMap, ctx) {
+    const projectGraphDependencies = [];
+    Object.keys(dependencies).forEach((keys) => {
+        const snapshot = dependencies[keys];
+        keys.split(', ').forEach((key) => {
+            if (keyMap.has(key)) {
+                const node = keyMap.get(key);
+                [snapshot.dependencies, snapshot.optionalDependencies].forEach((section) => {
+                    if (section) {
+                        Object.entries(section).forEach(([name, versionRange]) => {
+                            const target = keyMap.get(`${name}@npm:${versionRange}`) ||
+                                keyMap.get(`${name}@${versionRange}`);
+                            if (target) {
+                                const dep = {
+                                    source: node.name,
+                                    target: target.name,
+                                    type: project_graph_1.DependencyType.static,
+                                };
+                                (0, project_graph_builder_1.validateDependency)(dep, ctx);
+                                projectGraphDependencies.push(dep);
+                            }
+                        });
+                    }
+                });
+            }
+        });
+    });
+    return projectGraphDependencies;
+}
+function stringifyYarnLockfile(graph, rootLockFileContent, packageJson) {
+    const { parseSyml, stringifySyml } = __nccwpck_require__(2877);
+    const { __metadata, ...dependencies } = parseSyml(rootLockFileContent);
+    const isBerry = !!__metadata;
+    const snapshots = mapSnapshots(dependencies, graph.externalNodes, packageJson, isBerry);
+    if (isBerry) {
+        // add root workspace package
+        const workspacePackage = generateRootWorkspacePackage(packageJson);
+        snapshots[workspacePackage.resolution] = workspacePackage;
+        return (BERRY_LOCK_FILE_DISCLAIMER +
+            stringifySyml({
+                __metadata,
+                ...(0, object_sort_1.sortObjectByKeys)(snapshots),
+            }));
+    }
+    else {
+        const { stringify } = __nccwpck_require__(4694);
+        return stringify((0, object_sort_1.sortObjectByKeys)(snapshots));
+    }
+}
+exports.stringifyYarnLockfile = stringifyYarnLockfile;
+function groupDependencies(dependencies, isBerry) {
+    if (isBerry) {
+        return dependencies;
+    }
+    let groupedDependencies;
+    const resolutionMap = new Map();
+    const snapshotMap = new Map();
+    Object.entries(dependencies).forEach(([key, snapshot]) => {
+        const resolutionKey = `${snapshot.resolved}${snapshot.integrity}`;
+        if (resolutionMap.has(resolutionKey)) {
+            const existingSnapshot = resolutionMap.get(resolutionKey);
+            snapshotMap.get(existingSnapshot).add(key);
+        }
+        else {
+            resolutionMap.set(resolutionKey, snapshot);
+            snapshotMap.set(snapshot, new Set([key]));
+        }
+    });
+    groupedDependencies = {};
+    snapshotMap.forEach((keys, snapshot) => {
+        groupedDependencies[Array.from(keys).join(', ')] = snapshot;
+    });
+    return groupedDependencies;
+}
+function addPackageVersion(packageName, version, collection, isBerry) {
+    if (!collection.has(packageName)) {
+        collection.set(packageName, new Set());
+    }
+    collection.get(packageName).add(`${packageName}@${version}`);
+    if (isBerry && !version.startsWith('npm:')) {
+        collection.get(packageName).add(`${packageName}@npm:${version}`);
+    }
+}
+function mapSnapshots(dependencies, nodes, packageJson, isBerry) {
+    // map snapshot to set of keys (e.g. `eslint@^7.0.0, eslint@npm:^7.0.0`)
+    const snapshotMap = new Map();
+    // track all existing dependencies's keys
+    const existingKeys = new Map();
+    const combinedDependencies = {
+        ...packageJson.dependencies,
+        ...packageJson.devDependencies,
+        ...packageJson.optionalDependencies,
+        ...packageJson.peerDependencies,
+    };
+    // yarn classic splits keys when parsing so we need to stich them back together
+    const groupedDependencies = groupDependencies(dependencies, isBerry);
+    // collect snapshots and their matching keys
+    Object.values(nodes).forEach((node) => {
+        const foundOriginalKeys = findOriginalKeys(groupedDependencies, node);
+        if (!foundOriginalKeys) {
+            throw new Error(`Original key(s) not found for "${node.data.packageName}@${node.data.version}" while pruning yarn.lock.`);
+        }
+        const [matchedKeys, snapshot] = foundOriginalKeys;
+        snapshotMap.set(snapshot, new Set(matchedKeys));
+        // separately save keys that still exist
+        [snapshot.dependencies, snapshot.optionalDependencies].forEach((section) => {
+            Object.entries(section || {}).forEach(([name, versionSpec]) => addPackageVersion(name, versionSpec, existingKeys, isBerry));
+        });
+        // add package.json requested version to keys
+        const requestedVersion = getPackageJsonVersion(combinedDependencies, node);
+        if (requestedVersion) {
+            addPackageVersion(node.data.packageName, requestedVersion, existingKeys, isBerry);
+            const requestedKey = isBerry
+                ? reverseMapBerryKey(node, requestedVersion, snapshot)
+                : `${node.data.packageName}@${requestedVersion}`;
+            if (!snapshotMap.get(snapshot).has(requestedKey)) {
+                snapshotMap.get(snapshot).add(requestedKey);
+            }
+        }
+        if (isBerry) {
+            // look for patched versions
+            const patch = findPatchedKeys(groupedDependencies, node);
+            if (patch) {
+                const [matchedKeys, snapshot] = patch;
+                snapshotMap.set(snapshot, new Set(matchedKeys));
+            }
+        }
+    });
+    // remove keys that match version ranges that have been pruned away
+    snapshotMap.forEach((snapshotValue, snapshotKey) => {
+        for (const key of snapshotValue.values()) {
+            const packageName = key.slice(0, key.indexOf('@', 1));
+            let normalizedKey = key;
+            if (isBerry && key.includes('@patch:') && key.includes('#')) {
+                normalizedKey = key
+                    .slice(0, key.indexOf('#'))
+                    .replace(`@patch:${packageName}@`, '@npm:');
+            }
+            if (!existingKeys.get(packageName) ||
+                !existingKeys.get(packageName).has(normalizedKey)) {
+                snapshotValue.delete(key);
+            }
+        }
+    });
+    // join mapped snapshots to lock json file
+    const result = {};
+    snapshotMap.forEach((keysSet, snapshot) => {
+        if (isBerry) {
+            result[Array.from(keysSet).sort().join(', ')] = snapshot;
+        }
+        else {
+            for (const key of keysSet.values()) {
+                result[key] = snapshot;
+            }
+        }
+    });
+    return result;
 }
-
-const DNS = '6ba7b810-9dad-11d1-80b4-00c04fd430c8';
-exports.DNS = DNS;
-const URL = '6ba7b811-9dad-11d1-80b4-00c04fd430c8';
-exports.URL = URL;
-
-function _default(name, version, hashfunc) {
-  function generateUUID(value, namespace, buf, offset) {
-    if (typeof value === 'string') {
-      value = stringToBytes(value);
+function reverseMapBerryKey(node, version, snapshot) {
+    // alias packages already have version
+    if (version.startsWith('npm:')) {
+        `${node.data.packageName}@${version}`;
     }
-
-    if (typeof namespace === 'string') {
-      namespace = (0, _parse.default)(namespace);
+    // check for berry tarball packages
+    if (snapshot.resolution &&
+        snapshot.resolution === `${node.data.packageName}@${version}`) {
+        return snapshot.resolution;
     }
-
-    if (namespace.length !== 16) {
-      throw TypeError('Namespace must be array-like (16 iterable integer values, 0-255)');
-    } // Compute hash of namespace and value, Per 4.3
-    // Future: Use spread syntax when supported on all platforms, e.g. `bytes =
-    // hashfunc([...namespace, ... value])`
-
-
-    let bytes = new Uint8Array(16 + value.length);
-    bytes.set(namespace);
-    bytes.set(value, namespace.length);
-    bytes = hashfunc(bytes);
-    bytes[6] = bytes[6] & 0x0f | version;
-    bytes[8] = bytes[8] & 0x3f | 0x80;
-
-    if (buf) {
-      offset = offset || 0;
-
-      for (let i = 0; i < 16; ++i) {
-        buf[offset + i] = bytes[i];
-      }
-
-      return buf;
+    return `${node.data.packageName}@npm:${version}`;
+}
+function getPackageJsonVersion(combinedDependencies, node) {
+    const { packageName, version } = node.data;
+    if (combinedDependencies[packageName]) {
+        if (combinedDependencies[packageName] === version ||
+            (0, semver_1.satisfies)(version, combinedDependencies[packageName])) {
+            return combinedDependencies[packageName];
+        }
     }
-
-    return (0, _stringify.default)(bytes);
-  } // Function#name is not settable on some platforms (#270)
-
-
-  try {
-    generateUUID.name = name; // eslint-disable-next-line no-empty
-  } catch (err) {} // For CommonJS default export support
-
-
-  generateUUID.DNS = DNS;
-  generateUUID.URL = URL;
-  return generateUUID;
 }
-
-/***/ }),
-
-/***/ 39370:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
-
-"use strict";
-
-
-Object.defineProperty(exports, "__esModule", ({
-  value: true
-}));
-exports["default"] = void 0;
-
-var _rng = _interopRequireDefault(__nccwpck_require__(64315));
-
-var _stringify = _interopRequireDefault(__nccwpck_require__(82332));
-
-function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
-
-function v4(options, buf, offset) {
-  options = options || {};
-
-  const rnds = options.random || (options.rng || _rng.default)(); // Per 4.4, set bits for version and `clock_seq_hi_and_reserved`
-
-
-  rnds[6] = rnds[6] & 0x0f | 0x40;
-  rnds[8] = rnds[8] & 0x3f | 0x80; // Copy bytes to buffer, if provided
-
-  if (buf) {
-    offset = offset || 0;
-
-    for (let i = 0; i < 16; ++i) {
-      buf[offset + i] = rnds[i];
+function findOriginalKeys(dependencies, node) {
+    for (const keyExpr of Object.keys(dependencies)) {
+        const snapshot = dependencies[keyExpr];
+        const keys = keyExpr.split(', ');
+        if (!keys.some((k) => k.startsWith(`${node.data.packageName}@`))) {
+            continue;
+        }
+        // standard package
+        if (snapshot.version === node.data.version) {
+            return [keys, snapshot];
+        }
+        // berry alias package
+        if (snapshot.resolution &&
+            `npm:${snapshot.resolution}` === node.data.version) {
+            return [keys, snapshot];
+        }
+        // classic alias
+        if (node.data.version.startsWith('npm:') &&
+            keys.some((k) => k === `${node.data.packageName}@${node.data.version}`)) {
+            return [keys, snapshot];
+        }
+        // tarball package
+        if (snapshot.resolved === node.data.version ||
+            snapshot.resolution === `${node.data.packageName}@${node.data.version}`) {
+            return [keys, snapshot];
+        }
     }
-
-    return buf;
-  }
-
-  return (0, _stringify.default)(rnds);
+}
+function findPatchedKeys(dependencies, node) {
+    for (const keyExpr of Object.keys(dependencies)) {
+        const snapshot = dependencies[keyExpr];
+        const keys = keyExpr.split(', ');
+        if (!keys[0].startsWith(`${node.data.packageName}@patch:`)) {
+            continue;
+        }
+        // local patches are currently not supported
+        if (keys[0].includes('.yarn/patches')) {
+            continue;
+        }
+        if (snapshot.version === node.data.version) {
+            return [keys, snapshot];
+        }
+    }
+}
+const BERRY_LOCK_FILE_DISCLAIMER = `# This file is generated by running "yarn install" inside your project.\n# Manual changes might be lost - proceed with caution!\n\n`;
+function generateRootWorkspacePackage(packageJson) {
+    return {
+        version: '0.0.0-use.local',
+        resolution: `${packageJson.name}@workspace:.`,
+        ...(packageJson.dependencies && { dependencies: packageJson.dependencies }),
+        ...(packageJson.peerDependencies && {
+            peerDependencies: packageJson.peerDependencies,
+        }),
+        ...(packageJson.devDependencies && {
+            devDependencies: packageJson.devDependencies,
+        }),
+        ...(packageJson.optionalDependencies && {
+            optionalDependencies: packageJson.optionalDependencies,
+        }),
+        languageName: 'unknown',
+        linkType: 'soft',
+    };
 }
 
-var _default = v4;
-exports["default"] = _default;
 
 /***/ }),
 
-/***/ 93249:
+/***/ 37158:
 /***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
 "use strict";
 
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.buildExplicitDependencies = void 0;
+const explicit_project_dependencies_1 = __nccwpck_require__(14674);
+const explicit_package_json_dependencies_1 = __nccwpck_require__(17403);
+function buildExplicitDependencies(jsPluginConfig, ctx) {
+    if (totalNumberOfFilesToProcess(ctx) === 0)
+        return [];
+    let dependencies = [];
+    if (jsPluginConfig.analyzeSourceFiles === undefined ||
+        jsPluginConfig.analyzeSourceFiles === true) {
+        let tsExists = false;
+        try {
+            __nccwpck_require__.ab + "typescript.js"
+            tsExists = true;
+        }
+        catch { }
+        if (tsExists) {
+            dependencies = dependencies.concat((0, explicit_project_dependencies_1.buildExplicitTypeScriptDependencies)(ctx));
+        }
+    }
+    if (jsPluginConfig.analyzePackageJson === undefined ||
+        jsPluginConfig.analyzePackageJson === true) {
+        dependencies = dependencies.concat((0, explicit_package_json_dependencies_1.buildExplicitPackageJsonDependencies)(ctx));
+    }
+    return dependencies;
+}
+exports.buildExplicitDependencies = buildExplicitDependencies;
+function totalNumberOfFilesToProcess(ctx) {
+    let totalNumOfFilesToProcess = 0;
+    Object.values(ctx.filesToProcess.projectFileMap).forEach((t) => (totalNumOfFilesToProcess += t.length));
+    return totalNumOfFilesToProcess;
+}
 
-Object.defineProperty(exports, "__esModule", ({
-  value: true
-}));
-exports["default"] = void 0;
-
-var _v = _interopRequireDefault(__nccwpck_require__(70181));
-
-var _sha = _interopRequireDefault(__nccwpck_require__(19843));
-
-function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
-
-const v5 = (0, _v.default)('v5', 0x50, _sha.default);
-var _default = v5;
-exports["default"] = _default;
 
 /***/ }),
 
-/***/ 63498:
+/***/ 17403:
 /***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
 "use strict";
 
-
-Object.defineProperty(exports, "__esModule", ({
-  value: true
-}));
-exports["default"] = void 0;
-
-var _regex = _interopRequireDefault(__nccwpck_require__(65409));
-
-function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
-
-function validate(uuid) {
-  return typeof uuid === 'string' && _regex.default.test(uuid);
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.buildExplicitPackageJsonDependencies = void 0;
+const file_utils_1 = __nccwpck_require__(63260);
+const path_1 = __nccwpck_require__(71017);
+const project_graph_1 = __nccwpck_require__(2184);
+const json_1 = __nccwpck_require__(8314);
+const path_2 = __nccwpck_require__(38270);
+const project_graph_builder_1 = __nccwpck_require__(80862);
+function buildExplicitPackageJsonDependencies(ctx) {
+    const res = [];
+    let packageNameMap = undefined;
+    const nodes = Object.values(ctx.projects);
+    Object.keys(ctx.filesToProcess.projectFileMap).forEach((source) => {
+        Object.values(ctx.filesToProcess.projectFileMap[source]).forEach((f) => {
+            if (isPackageJsonAtProjectRoot(nodes, f.file)) {
+                // we only create the package name map once and only if a package.json file changes
+                packageNameMap = packageNameMap || createPackageNameMap(ctx.projects);
+                processPackageJson(source, f.file, ctx, res, packageNameMap);
+            }
+        });
+    });
+    return res;
+}
+exports.buildExplicitPackageJsonDependencies = buildExplicitPackageJsonDependencies;
+function createPackageNameMap(projects) {
+    const res = {};
+    for (let projectName of Object.keys(projects)) {
+        try {
+            const packageJson = (0, json_1.parseJson)((0, file_utils_1.defaultFileRead)((0, path_1.join)(projects[projectName].root, 'package.json')));
+            res[packageJson.name ?? projectName] = projectName;
+        }
+        catch (e) { }
+    }
+    return res;
+}
+function isPackageJsonAtProjectRoot(nodes, fileName) {
+    return (fileName.endsWith('package.json') &&
+        nodes.find((projectNode) => (0, path_2.joinPathFragments)(projectNode.root, 'package.json') === fileName));
+}
+function processPackageJson(sourceProject, fileName, ctx, collectedDeps, packageNameMap) {
+    try {
+        const deps = readDeps((0, json_1.parseJson)((0, file_utils_1.defaultFileRead)(fileName)));
+        // the name matches the import path
+        deps.forEach((d) => {
+            // package.json refers to another project in the monorepo
+            if (packageNameMap[d]) {
+                const dependency = {
+                    source: sourceProject,
+                    target: packageNameMap[d],
+                    sourceFile: fileName,
+                    type: project_graph_1.DependencyType.static,
+                };
+                (0, project_graph_builder_1.validateDependency)(dependency, ctx);
+                collectedDeps.push(dependency);
+            }
+            else if (ctx.externalNodes[`npm:${d}`]) {
+                const dependency = {
+                    source: sourceProject,
+                    target: `npm:${d}`,
+                    sourceFile: fileName,
+                    type: project_graph_1.DependencyType.static,
+                };
+                (0, project_graph_builder_1.validateDependency)(dependency, ctx);
+                collectedDeps.push(dependency);
+            }
+        });
+    }
+    catch (e) {
+        if (process.env.NX_VERBOSE_LOGGING === 'true') {
+            console.log(e);
+        }
+    }
+}
+function readDeps(packageJson) {
+    return [
+        ...Object.keys(packageJson?.dependencies ?? {}),
+        ...Object.keys(packageJson?.devDependencies ?? {}),
+        ...Object.keys(packageJson?.peerDependencies ?? {}),
+        ...Object.keys(packageJson?.optionalDependencies ?? {}),
+    ];
 }
 
-var _default = validate;
-exports["default"] = _default;
 
 /***/ }),
 
-/***/ 14698:
+/***/ 14674:
 /***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
 "use strict";
 
-
-Object.defineProperty(exports, "__esModule", ({
-  value: true
-}));
-exports["default"] = void 0;
-
-var _validate = _interopRequireDefault(__nccwpck_require__(63498));
-
-function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
-
-function version(uuid) {
-  if (!(0, _validate.default)(uuid)) {
-    throw TypeError('Invalid UUID');
-  }
-
-  return parseInt(uuid.substr(14, 1), 16);
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.buildExplicitTypeScriptDependencies = void 0;
+const target_project_locator_1 = __nccwpck_require__(91259);
+const project_graph_1 = __nccwpck_require__(2184);
+const path_1 = __nccwpck_require__(71017);
+const workspace_root_1 = __nccwpck_require__(86708);
+const path_2 = __nccwpck_require__(38270);
+const project_graph_builder_1 = __nccwpck_require__(80862);
+function isRoot(projects, projectName) {
+    return projects[projectName]?.root === '.';
+}
+function convertImportToDependency(importExpr, sourceFile, source, type, targetProjectLocator) {
+    const target = targetProjectLocator.findProjectWithImport(importExpr, sourceFile) ??
+        `npm:${importExpr}`;
+    return {
+        source,
+        target,
+        sourceFile,
+        type,
+    };
 }
-
-var _default = version;
-exports["default"] = _default;
-
-/***/ }),
-
-/***/ 25476:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
-
-"use strict";
-
-
-const Module = __nccwpck_require__(98188);
-const crypto = __nccwpck_require__(6113);
-const fs = __nccwpck_require__(57147);
-const path = __nccwpck_require__(71017);
-const vm = __nccwpck_require__(26144);
-const os = __nccwpck_require__(22037);
-
-const hasOwnProperty = Object.prototype.hasOwnProperty;
-
-//------------------------------------------------------------------------------
-// FileSystemBlobStore
-//------------------------------------------------------------------------------
-
-class FileSystemBlobStore {
-  constructor(directory, prefix) {
-    const name = prefix ? slashEscape(prefix + '.') : '';
-    this._blobFilename = path.join(directory, name + 'BLOB');
-    this._mapFilename = path.join(directory, name + 'MAP');
-    this._lockFilename = path.join(directory, name + 'LOCK');
-    this._directory = directory;
-    this._load();
-  }
-
-  has(key, invalidationKey) {
-    if (hasOwnProperty.call(this._memoryBlobs, key)) {
-      return this._invalidationKeys[key] === invalidationKey;
-    } else if (hasOwnProperty.call(this._storedMap, key)) {
-      return this._storedMap[key][0] === invalidationKey;
+function buildExplicitTypeScriptDependencies(ctx) {
+    // TODO: TargetProjectLocator is a public API, so we can't change the shape of it
+    // We should eventually let it accept Record s.t. we
+    // don't have to reshape the CreateDependenciesContext here.
+    const nodes = Object.fromEntries(Object.entries(ctx.projects).map(([key, config]) => [
+        key,
+        {
+            name: key,
+            type: null,
+            data: config,
+        },
+    ]));
+    const targetProjectLocator = new target_project_locator_1.TargetProjectLocator(nodes, ctx.externalNodes);
+    const res = [];
+    const filesToProcess = {};
+    const moduleExtensions = [
+        '.ts',
+        '.js',
+        '.tsx',
+        '.jsx',
+        '.mts',
+        '.mjs',
+        '.cjs',
+        '.cts',
+    ];
+    // TODO: This can be removed when vue is stable
+    if (isVuePluginInstalled()) {
+        moduleExtensions.push('.vue');
     }
-    return false;
-  }
-
-  get(key, invalidationKey) {
-    if (hasOwnProperty.call(this._memoryBlobs, key)) {
-      if (this._invalidationKeys[key] === invalidationKey) {
-        return this._memoryBlobs[key];
-      }
-    } else if (hasOwnProperty.call(this._storedMap, key)) {
-      const mapping = this._storedMap[key];
-      if (mapping[0] === invalidationKey) {
-        return this._storedBlob.slice(mapping[1], mapping[2]);
-      }
+    for (const [project, fileData] of Object.entries(ctx.fileMap.projectFileMap)) {
+        filesToProcess[project] ??= [];
+        for (const { file } of fileData) {
+            if (moduleExtensions.some((ext) => file.endsWith(ext))) {
+                filesToProcess[project].push((0, path_1.join)(workspace_root_1.workspaceRoot, file));
+            }
+        }
     }
-  }
-
-  set(key, invalidationKey, buffer) {
-    this._invalidationKeys[key] = invalidationKey;
-    this._memoryBlobs[key] = buffer;
-    this._dirty = true;
-  }
-
-  delete(key) {
-    if (hasOwnProperty.call(this._memoryBlobs, key)) {
-      this._dirty = true;
-      delete this._memoryBlobs[key];
+    const { findImports } = __nccwpck_require__(74424);
+    const imports = findImports(filesToProcess);
+    for (const { sourceProject, file, staticImportExpressions, dynamicImportExpressions, } of imports) {
+        const normalizedFilePath = (0, path_2.normalizePath)((0, path_1.relative)(workspace_root_1.workspaceRoot, file));
+        for (const importExpr of staticImportExpressions) {
+            const dependency = convertImportToDependency(importExpr, normalizedFilePath, sourceProject, project_graph_1.DependencyType.static, targetProjectLocator);
+            // TODO: These edges technically should be allowed but we need to figure out how to separate config files out from root
+            if (isRoot(ctx.projects, dependency.source) ||
+                !isRoot(ctx.projects, dependency.target)) {
+                res.push(dependency);
+            }
+        }
+        for (const importExpr of dynamicImportExpressions) {
+            const dependency = convertImportToDependency(importExpr, normalizedFilePath, sourceProject, project_graph_1.DependencyType.dynamic, targetProjectLocator);
+            // TODO: These edges technically should be allowed but we need to figure out how to separate config files out from root
+            if (isRoot(ctx.projects, dependency.source) ||
+                !isRoot(ctx.projects, dependency.target)) {
+                (0, project_graph_builder_1.validateDependency)(dependency, ctx);
+                res.push(dependency);
+            }
+        }
     }
-    if (hasOwnProperty.call(this._invalidationKeys, key)) {
-      this._dirty = true;
-      delete this._invalidationKeys[key];
+    return res;
+}
+exports.buildExplicitTypeScriptDependencies = buildExplicitTypeScriptDependencies;
+function isVuePluginInstalled() {
+    try {
+        // nx-ignore-next-line
+        /*require.resolve*/(89373);
+        return true;
     }
-    if (hasOwnProperty.call(this._storedMap, key)) {
-      this._dirty = true;
-      delete this._storedMap[key];
+    catch {
+        return false;
     }
-  }
-
-  isDirty() {
-    return this._dirty;
-  }
+}
 
-  save() {
-    const dump = this._getDump();
-    const blobToStore = Buffer.concat(dump[0]);
-    const mapToStore = JSON.stringify(dump[1]);
 
-    try {
-      mkdirpSync(this._directory);
-      fs.writeFileSync(this._lockFilename, 'LOCK', {flag: 'wx'});
-    } catch (error) {
-      // Swallow the exception if we fail to acquire the lock.
-      return false;
-    }
+/***/ }),
 
-    try {
-      fs.writeFileSync(this._blobFilename, blobToStore);
-      fs.writeFileSync(this._mapFilename, mapToStore);
-    } finally {
-      fs.unlinkSync(this._lockFilename);
-    }
+/***/ 91259:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
-    return true;
-  }
+"use strict";
 
-  _load() {
-    try {
-      this._storedBlob = fs.readFileSync(this._blobFilename);
-      this._storedMap = JSON.parse(fs.readFileSync(this._mapFilename));
-    } catch (e) {
-      this._storedBlob = Buffer.alloc(0);
-      this._storedMap = {};
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.TargetProjectLocator = void 0;
+const typescript_1 = __nccwpck_require__(37650);
+const fileutils_1 = __nccwpck_require__(83851);
+const path_1 = __nccwpck_require__(71017);
+const workspace_root_1 = __nccwpck_require__(86708);
+const module_1 = __nccwpck_require__(98188);
+const find_project_for_path_1 = __nccwpck_require__(46329);
+const builtInModuleSet = new Set([
+    ...module_1.builtinModules,
+    ...module_1.builtinModules.map((x) => `node:${x}`),
+]);
+class TargetProjectLocator {
+    constructor(nodes, externalNodes) {
+        this.nodes = nodes;
+        this.externalNodes = externalNodes;
+        this.projectRootMappings = (0, find_project_for_path_1.createProjectRootMappings)(this.nodes);
+        this.npmProjects = filterRootExternalDependencies(this.externalNodes);
+        this.tsConfig = this.getRootTsConfig();
+        this.paths = this.tsConfig.config?.compilerOptions?.paths;
+        this.typescriptResolutionCache = new Map();
+        this.npmResolutionCache = new Map();
     }
-    this._dirty = false;
-    this._memoryBlobs = {};
-    this._invalidationKeys = {};
-  }
-
-  _getDump() {
-    const buffers = [];
-    const newMap = {};
-    let offset = 0;
-
-    function push(key, invalidationKey, buffer) {
-      buffers.push(buffer);
-      newMap[key] = [invalidationKey, offset, offset + buffer.length];
-      offset += buffer.length;
+    /**
+     * Find a project based on its import
+     *
+     * @param importExpr
+     * @param filePath
+     */
+    findProjectWithImport(importExpr, filePath) {
+        if ((0, fileutils_1.isRelativePath)(importExpr)) {
+            const resolvedModule = path_1.posix.join((0, path_1.dirname)(filePath), importExpr);
+            return this.findProjectOfResolvedModule(resolvedModule);
+        }
+        // find project using tsconfig paths
+        const results = this.findPaths(importExpr);
+        if (results) {
+            const [path, paths] = results;
+            for (let p of paths) {
+                const r = p.endsWith('/*')
+                    ? (0, path_1.join)((0, path_1.dirname)(p), (0, path_1.relative)(path.replace(/\*$/, ''), importExpr))
+                    : p;
+                const maybeResolvedProject = this.findProjectOfResolvedModule(r);
+                if (maybeResolvedProject) {
+                    return maybeResolvedProject;
+                }
+            }
+        }
+        if (builtInModuleSet.has(importExpr)) {
+            this.npmResolutionCache.set(importExpr, null);
+            return null;
+        }
+        // try to find npm package before using expensive typescript resolution
+        const npmProject = this.findNpmPackage(importExpr);
+        if (npmProject) {
+            return npmProject;
+        }
+        if (this.tsConfig.config) {
+            // TODO(meeroslav): this block is probably obsolete
+            // and existed only because of the incomplete `paths` matching
+            // if import cannot be matched using tsconfig `paths` the compilation would fail anyway
+            const resolvedProject = this.resolveImportWithTypescript(importExpr, filePath);
+            if (resolvedProject) {
+                return resolvedProject;
+            }
+        }
+        try {
+            const resolvedModule = this.resolveImportWithRequire(importExpr, filePath);
+            return this.findProjectOfResolvedModule(resolvedModule);
+        }
+        catch { }
+        // nothing found, cache for later
+        this.npmResolutionCache.set(importExpr, null);
+        return null;
     }
-
-    for (const key of Object.keys(this._memoryBlobs)) {
-      const buffer = this._memoryBlobs[key];
-      const invalidationKey = this._invalidationKeys[key];
-      push(key, invalidationKey, buffer);
+    /**
+     * Return file paths matching the import relative to the repo root
+     * @param normalizedImportExpr
+     * @returns
+     */
+    findPaths(normalizedImportExpr) {
+        if (!this.paths) {
+            return undefined;
+        }
+        if (this.paths[normalizedImportExpr]) {
+            return [normalizedImportExpr, this.paths[normalizedImportExpr]];
+        }
+        const wildcardPath = Object.keys(this.paths).find((path) => path.endsWith('/*') &&
+            (normalizedImportExpr.startsWith(path.replace(/\*$/, '')) ||
+                normalizedImportExpr === path.replace(/\/\*$/, '')));
+        if (wildcardPath) {
+            return [wildcardPath, this.paths[wildcardPath]];
+        }
+        return undefined;
     }
-
-    for (const key of Object.keys(this._storedMap)) {
-      if (hasOwnProperty.call(newMap, key)) continue;
-      const mapping = this._storedMap[key];
-      const buffer = this._storedBlob.slice(mapping[1], mapping[2]);
-      push(key, mapping[0], buffer);
+    resolveImportWithTypescript(normalizedImportExpr, filePath) {
+        let resolvedModule;
+        if (this.typescriptResolutionCache.has(normalizedImportExpr)) {
+            resolvedModule = this.typescriptResolutionCache.get(normalizedImportExpr);
+        }
+        else {
+            resolvedModule = (0, typescript_1.resolveModuleByImport)(normalizedImportExpr, filePath, this.tsConfig.absolutePath);
+            this.typescriptResolutionCache.set(normalizedImportExpr, resolvedModule ? resolvedModule : null);
+        }
+        // TODO: vsavkin temporary workaround. Remove it once we reworking handling of npm packages.
+        if (resolvedModule && resolvedModule.indexOf('node_modules/') === -1) {
+            const resolvedProject = this.findProjectOfResolvedModule(resolvedModule);
+            if (resolvedProject) {
+                return resolvedProject;
+            }
+        }
+        return;
     }
-
-    return [buffers, newMap];
-  }
-}
-
-//------------------------------------------------------------------------------
-// NativeCompileCache
-//------------------------------------------------------------------------------
-
-class NativeCompileCache {
-  constructor() {
-    this._cacheStore = null;
-    this._previousModuleCompile = null;
-  }
-
-  setCacheStore(cacheStore) {
-    this._cacheStore = cacheStore;
-  }
-
-  install() {
-    const self = this;
-    const hasRequireResolvePaths = typeof require.resolve.paths === 'function';
-    this._previousModuleCompile = Module.prototype._compile;
-    Module.prototype._compile = this._ownModuleCompile = _ownModuleCompile;
-    self.enabled = true;
-    function _ownModuleCompile(content, filename) {
-      if(!self.enabled) return this._previousModuleCompile.apply(this, arguments);
-      const mod = this;
-
-      function require(id) {
-        return mod.require(id);
-      }
-
-      // https://github.com/nodejs/node/blob/v10.15.3/lib/internal/modules/cjs/helpers.js#L28
-      function resolve(request, options) {
-        return Module._resolveFilename(request, mod, false, options);
-      }
-      require.resolve = resolve;
-
-      // https://github.com/nodejs/node/blob/v10.15.3/lib/internal/modules/cjs/helpers.js#L37
-      // resolve.resolve.paths was added in v8.9.0
-      if (hasRequireResolvePaths) {
-        resolve.paths = function paths(request) {
-          return Module._resolveLookupPaths(request, mod, true);
-        };
-      }
-
-      require.main = process.mainModule;
-
-      // Enable support to add extra extension types
-      require.extensions = Module._extensions;
-      require.cache = Module._cache;
-
-      const dirname = path.dirname(filename);
-
-      const compiledWrapper = self._moduleCompile(filename, content);
-
-      // We skip the debugger setup because by the time we run, node has already
-      // done that itself.
-
-      // `Buffer` is included for Electron.
-      // See https://github.com/zertosh/v8-compile-cache/pull/10#issuecomment-518042543
-      const args = [mod.exports, require, mod, filename, dirname, process, global, Buffer];
-      return compiledWrapper.apply(mod.exports, args);
+    resolveImportWithRequire(normalizedImportExpr, filePath) {
+        return path_1.posix.relative(workspace_root_1.workspaceRoot, require.resolve(normalizedImportExpr, {
+            paths: [(0, path_1.dirname)(filePath)],
+        }));
     }
-  }
-
-  uninstall() {
-    this.enabled = false;
-    // If something else has since been installed on top of us, we cannot overwrite it.
-    if(Module.prototype._compile === this._ownModuleCompile) {
-      Module.prototype._compile = this._previousModuleCompile;
+    findNpmPackage(npmImport) {
+        if (this.npmResolutionCache.has(npmImport)) {
+            return this.npmResolutionCache.get(npmImport);
+        }
+        else {
+            const pkg = this.npmProjects.find((pkg) => npmImport === pkg.data.packageName ||
+                npmImport.startsWith(`${pkg.data.packageName}/`));
+            if (pkg) {
+                this.npmResolutionCache.set(npmImport, pkg.name);
+                return pkg.name;
+            }
+        }
     }
-  }
-
-  _moduleCompile(filename, content) {
-    // https://github.com/nodejs/node/blob/v7.5.0/lib/module.js#L511
-
-    // Remove shebang
-    var contLen = content.length;
-    if (contLen >= 2) {
-      if (content.charCodeAt(0) === 35/*#*/ &&
-          content.charCodeAt(1) === 33/*!*/) {
-        if (contLen === 2) {
-          // Exact match
-          content = '';
-        } else {
-          // Find end of shebang line and slice it off
-          var i = 2;
-          for (; i < contLen; ++i) {
-            var code = content.charCodeAt(i);
-            if (code === 10/*\n*/ || code === 13/*\r*/) break;
-          }
-          if (i === contLen) {
-            content = '';
-          } else {
-            // Note that this actually includes the newline character(s) in the
-            // new output. This duplicates the behavior of the regular
-            // expression that was previously used to replace the shebang line
-            content = content.slice(i);
-          }
+    findProjectOfResolvedModule(resolvedModule) {
+        if (resolvedModule.startsWith('node_modules/') ||
+            resolvedModule.includes('/node_modules/')) {
+            return undefined;
         }
-      }
+        const normalizedResolvedModule = resolvedModule.startsWith('./')
+            ? resolvedModule.substring(2)
+            : resolvedModule;
+        const importedProject = this.findMatchingProjectFiles(normalizedResolvedModule);
+        return importedProject ? importedProject.name : void 0;
     }
-
-    // create wrapper function
-    var wrapper = Module.wrap(content);
-
-    var invalidationKey = crypto
-      .createHash('sha1')
-      .update(content, 'utf8')
-      .digest('hex');
-
-    var buffer = this._cacheStore.get(filename, invalidationKey);
-
-    var script = new vm.Script(wrapper, {
-      filename: filename,
-      lineOffset: 0,
-      displayErrors: true,
-      cachedData: buffer,
-      produceCachedData: true,
-    });
-
-    if (script.cachedDataProduced) {
-      this._cacheStore.set(filename, invalidationKey, script.cachedData);
-    } else if (script.cachedDataRejected) {
-      this._cacheStore.delete(filename);
+    getAbsolutePath(path) {
+        return (0, path_1.join)(workspace_root_1.workspaceRoot, path);
     }
-
-    var compiledWrapper = script.runInThisContext({
-      filename: filename,
-      lineOffset: 0,
-      columnOffset: 0,
-      displayErrors: true,
-    });
-
-    return compiledWrapper;
-  }
-}
-
-//------------------------------------------------------------------------------
-// utilities
-//
-// https://github.com/substack/node-mkdirp/blob/f2003bb/index.js#L55-L98
-// https://github.com/zertosh/slash-escape/blob/e7ebb99/slash-escape.js
-//------------------------------------------------------------------------------
-
-function mkdirpSync(p_) {
-  _mkdirpSync(path.resolve(p_), 0o777);
-}
-
-function _mkdirpSync(p, mode) {
-  try {
-    fs.mkdirSync(p, mode);
-  } catch (err0) {
-    if (err0.code === 'ENOENT') {
-      _mkdirpSync(path.dirname(p));
-      _mkdirpSync(p);
-    } else {
-      try {
-        const stat = fs.statSync(p);
-        if (!stat.isDirectory()) { throw err0; }
-      } catch (err1) {
-        throw err0;
-      }
+    getRootTsConfig() {
+        const path = (0, typescript_1.getRootTsConfigFileName)();
+        if (!path) {
+            return {
+                path: null,
+                absolutePath: null,
+                config: null,
+            };
+        }
+        const absolutePath = this.getAbsolutePath(path);
+        return {
+            absolutePath,
+            path,
+            config: (0, fileutils_1.readJsonFile)(absolutePath),
+        };
     }
-  }
-}
-
-function slashEscape(str) {
-  const ESCAPE_LOOKUP = {
-    '\\': 'zB',
-    ':': 'zC',
-    '/': 'zS',
-    '\x00': 'z0',
-    'z': 'zZ',
-  };
-  const ESCAPE_REGEX = /[\\:/\x00z]/g; // eslint-disable-line no-control-regex
-  return str.replace(ESCAPE_REGEX, match => ESCAPE_LOOKUP[match]);
-}
-
-function supportsCachedData() {
-  const script = new vm.Script('""', {produceCachedData: true});
-  // chakracore, as of v1.7.1.0, returns `false`.
-  return script.cachedDataProduced === true;
-}
-
-function getCacheDir() {
-  const v8_compile_cache_cache_dir = process.env.V8_COMPILE_CACHE_CACHE_DIR;
-  if (v8_compile_cache_cache_dir) {
-    return v8_compile_cache_cache_dir;
-  }
-
-  // Avoid cache ownership issues on POSIX systems.
-  const dirname = typeof process.getuid === 'function'
-    ? 'v8-compile-cache-' + process.getuid()
-    : 'v8-compile-cache';
-  const version = typeof process.versions.v8 === 'string'
-    ? process.versions.v8
-    : typeof process.versions.chakracore === 'string'
-      ? 'chakracore-' + process.versions.chakracore
-      : 'node-' + process.version;
-  const cacheDir = path.join(os.tmpdir(), dirname, version);
-  return cacheDir;
-}
-
-function getMainName() {
-  // `require.main.filename` is undefined or null when:
-  //    * node -e 'require("v8-compile-cache")'
-  //    * node -r 'v8-compile-cache'
-  //    * Or, requiring from the REPL.
-  const mainName = require.main && typeof require.main.filename === 'string'
-    ? require.main.filename
-    : process.cwd();
-  return mainName;
-}
-
-function install(opts) {
-  if (!process.env.DISABLE_V8_COMPILE_CACHE && supportsCachedData()) {
-    if(typeof opts === 'undefined') opts = {}
-    let cacheDir = opts.cacheDir
-    if(typeof cacheDir === 'undefined') cacheDir = getCacheDir();
-    let prefix = opts.prefix
-    if(typeof prefix === 'undefined') prefix = getMainName();
-    const blobStore = new FileSystemBlobStore(cacheDir, prefix);
-
-    const nativeCompileCache = new NativeCompileCache();
-    nativeCompileCache.setCacheStore(blobStore);
-    nativeCompileCache.install();
-
-    let uninstalled = false;
-    const uninstall = () => {
-      if(uninstalled) return;
-      uninstalled = true;
-      process.removeListener('exit', uninstall);
-      if (blobStore.isDirty()) {
-        blobStore.save();
-      }
-      nativeCompileCache.uninstall();
+    findMatchingProjectFiles(file) {
+        const project = (0, find_project_for_path_1.findProjectForPath)(file, this.projectRootMappings);
+        return this.nodes[project];
     }
-    process.once('exit', uninstall);
-    return {uninstall};
-  }
 }
-
-//------------------------------------------------------------------------------
-// main
-//------------------------------------------------------------------------------
-
-module.exports.install = install;
-
-module.exports.__TEST__ = {
-  FileSystemBlobStore,
-  NativeCompileCache,
-  mkdirpSync,
-  slashEscape,
-  supportsCachedData,
-  getCacheDir,
-  getMainName,
-};
-
-
-/***/ }),
-
-/***/ 63180:
-/***/ ((module) => {
-
-// Returns a wrapper function that returns a wrapped callback
-// The wrapper function should do some stuff, and return a
-// presumably different callback function.
-// This makes sure that own properties are retained, so that
-// decorations and such are not lost along the way.
-module.exports = wrappy
-function wrappy (fn, cb) {
-  if (fn && cb) return wrappy(fn)(cb)
-
-  if (typeof fn !== 'function')
-    throw new TypeError('need wrapper function')
-
-  Object.keys(fn).forEach(function (k) {
-    wrapper[k] = fn[k]
-  })
-
-  return wrapper
-
-  function wrapper() {
-    var args = new Array(arguments.length)
-    for (var i = 0; i < args.length; i++) {
-      args[i] = arguments[i]
+exports.TargetProjectLocator = TargetProjectLocator;
+// matches `npm:@scope/name`, `npm:name` but not `npm:@scope/name@version` and `npm:name@version`
+const ROOT_VERSION_PACKAGE_NAME_REGEX = /^npm:(?!.+@.+)/;
+function filterRootExternalDependencies(externalNodes) {
+    if (!externalNodes) {
+        return [];
     }
-    var ret = fn.apply(this, args)
-    var cb = args[args.length-1]
-    if (typeof ret === 'function' && ret !== cb) {
-      Object.keys(cb).forEach(function (k) {
-        ret[k] = cb[k]
-      })
+    const keys = Object.keys(externalNodes);
+    const nodes = [];
+    for (let i = 0; i < keys.length; i++) {
+        if (keys[i].match(ROOT_VERSION_PACKAGE_NAME_REGEX)) {
+            nodes.push(externalNodes[keys[i]]);
+        }
     }
-    return ret
-  }
+    return nodes;
 }
 
 
 /***/ }),
 
-/***/ 17005:
-/***/ ((module) => {
+/***/ 13770:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
 "use strict";
 
-module.exports = function (Yallist) {
-  Yallist.prototype[Symbol.iterator] = function* () {
-    for (let walker = this.head; walker; walker = walker.next) {
-      yield walker.value
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.jsPluginConfig = void 0;
+const node_path_1 = __nccwpck_require__(49411);
+const fileutils_1 = __nccwpck_require__(83851);
+const workspace_root_1 = __nccwpck_require__(86708);
+const fs_1 = __nccwpck_require__(57147);
+function jsPluginConfig(nxJson) {
+    const nxJsonConfig = nxJson?.pluginsConfig?.['@nx/js'] ?? nxJson?.pluginsConfig?.['@nrwl/js'];
+    // using lerna _before_ installing deps is causing an issue when parsing lockfile.
+    // See: https://github.com/lerna/lerna/issues/3807
+    // Note that previous attempt to fix this caused issues with Nx itself, thus we're checking
+    // for Lerna explicitly.
+    // See: https://github.com/nrwl/nx/pull/18784/commits/5416138e1ddc1945d5b289672dfb468e8c544e14
+    const analyzeLockfile = !(0, fs_1.existsSync)((0, node_path_1.join)(workspace_root_1.workspaceRoot, 'lerna.json')) ||
+        (0, fs_1.existsSync)((0, node_path_1.join)(workspace_root_1.workspaceRoot, 'nx.json'));
+    if (nxJsonConfig) {
+        return {
+            analyzePackageJson: true,
+            analyzeSourceFiles: true,
+            analyzeLockfile,
+            ...nxJsonConfig,
+        };
+    }
+    if (!(0, fileutils_1.fileExists)((0, node_path_1.join)(workspace_root_1.workspaceRoot, 'package.json'))) {
+        return {
+            analyzeLockfile: false,
+            analyzePackageJson: false,
+            analyzeSourceFiles: false,
+        };
+    }
+    const packageJson = (0, fileutils_1.readJsonFile)((0, node_path_1.join)(workspace_root_1.workspaceRoot, 'package.json'));
+    const packageJsonDeps = {
+        ...packageJson.dependencies,
+        ...packageJson.devDependencies,
+    };
+    if (packageJsonDeps['@nx/workspace'] ||
+        packageJsonDeps['@nx/js'] ||
+        packageJsonDeps['@nx/node'] ||
+        packageJsonDeps['@nx/next'] ||
+        packageJsonDeps['@nx/react'] ||
+        packageJsonDeps['@nx/angular'] ||
+        packageJsonDeps['@nx/web'] ||
+        packageJsonDeps['@nrwl/workspace'] ||
+        packageJsonDeps['@nrwl/js'] ||
+        packageJsonDeps['@nrwl/node'] ||
+        packageJsonDeps['@nrwl/next'] ||
+        packageJsonDeps['@nrwl/react'] ||
+        packageJsonDeps['@nrwl/angular'] ||
+        packageJsonDeps['@nrwl/web']) {
+        return {
+            analyzePackageJson: true,
+            analyzeLockfile,
+            analyzeSourceFiles: true,
+        };
+    }
+    else {
+        return {
+            analyzePackageJson: true,
+            analyzeLockfile,
+            analyzeSourceFiles: false,
+        };
     }
-  }
 }
+exports.jsPluginConfig = jsPluginConfig;
 
 
 /***/ }),
 
-/***/ 19385:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+/***/ 44321:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
 "use strict";
 
-module.exports = Yallist
-
-Yallist.Node = Node
-Yallist.create = Yallist
-
-function Yallist (list) {
-  var self = this
-  if (!(self instanceof Yallist)) {
-    self = new Yallist()
-  }
-
-  self.tail = null
-  self.head = null
-  self.length = 0
-
-  if (list && typeof list.forEach === 'function') {
-    list.forEach(function (item) {
-      self.push(item)
-    })
-  } else if (arguments.length > 0) {
-    for (var i = 0, l = arguments.length; i < l; i++) {
-      self.push(arguments[i])
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.getTsNodeCompilerOptions = exports.registerTsConfigPaths = exports.registerTranspiler = exports.getTranspiler = exports.getTsNodeTranspiler = exports.getSwcTranspiler = exports.registerTsProject = void 0;
+const path_1 = __nccwpck_require__(71017);
+const logger_1 = __nccwpck_require__(39299);
+const fs_1 = __nccwpck_require__(57147);
+const workspace_root_1 = __nccwpck_require__(86708);
+const swcNodeInstalled = packageIsInstalled('@swc-node/register');
+const tsNodeInstalled = packageIsInstalled('ts-node/register');
+let ts;
+let isTsEsmLoaderRegistered = false;
+function registerTsProject(path, configFilename, 
+/**
+ * @deprecated Do not use this.. it's a 1-off exception
+ */
+useForSwcEnvironmentVariable) {
+    const tsConfigPath = configFilename ? (0, path_1.join)(path, configFilename) : path;
+    const compilerOptions = readCompilerOptions(tsConfigPath);
+    const cleanupFunctions = [
+        registerTsConfigPaths(tsConfigPath),
+        registerTranspiler(compilerOptions, useForSwcEnvironmentVariable ? tsConfigPath : undefined),
+    ];
+    // Add ESM support for `.ts` files.
+    // NOTE: There is no cleanup function for this, as it's not possible to unregister the loader.
+    //       Based on limited testing, it doesn't seem to matter if we register it multiple times, but just in
+    //       case let's keep a flag to prevent it.
+    if (!isTsEsmLoaderRegistered) {
+        const module = __nccwpck_require__(82033);
+        if (module.register && packageIsInstalled('ts-node/esm')) {
+            const url = __nccwpck_require__(41041);
+            module.register(url.pathToFileURL(require.resolve('ts-node/esm')));
+        }
+        isTsEsmLoaderRegistered = true;
     }
-  }
-
-  return self
+    return () => {
+        for (const fn of cleanupFunctions) {
+            fn();
+        }
+    };
 }
-
-Yallist.prototype.removeNode = function (node) {
-  if (node.list !== this) {
-    throw new Error('removing node which does not belong to this list')
-  }
-
-  var next = node.next
-  var prev = node.prev
-
-  if (next) {
-    next.prev = prev
-  }
-
-  if (prev) {
-    prev.next = next
-  }
-
-  if (node === this.head) {
-    this.head = next
-  }
-  if (node === this.tail) {
-    this.tail = prev
-  }
-
-  node.list.length--
-  node.next = null
-  node.prev = null
-  node.list = null
-
-  return next
+exports.registerTsProject = registerTsProject;
+function getSwcTranspiler(compilerOptions, tsConfigPath) {
+    // These are requires to prevent it from registering when it shouldn't
+    const register = (__nccwpck_require__(55204).register);
+    if (tsConfigPath) {
+        process.env.SWC_NODE_PROJECT = tsConfigPath;
+    }
+    else {
+        let rootTsConfig = (0, path_1.join)(workspace_root_1.workspaceRoot, 'tsconfig.base.json');
+        if ((0, fs_1.existsSync)(rootTsConfig)) {
+            process.env.SWC_NODE_PROJECT = rootTsConfig;
+        }
+    }
+    const cleanupFn = register(compilerOptions);
+    return typeof cleanupFn === 'function' ? cleanupFn : () => { };
 }
-
-Yallist.prototype.unshiftNode = function (node) {
-  if (node === this.head) {
-    return
-  }
-
-  if (node.list) {
-    node.list.removeNode(node)
-  }
-
-  var head = this.head
-  node.list = this
-  node.next = head
-  if (head) {
-    head.prev = node
-  }
-
-  this.head = node
-  if (!this.tail) {
-    this.tail = node
-  }
-  this.length++
+exports.getSwcTranspiler = getSwcTranspiler;
+function getTsNodeTranspiler(compilerOptions) {
+    const { register } = __nccwpck_require__(94828);
+    // ts-node doesn't provide a cleanup method
+    const service = register({
+        transpileOnly: true,
+        compilerOptions: getTsNodeCompilerOptions(compilerOptions),
+        // we already read and provide the compiler options, so prevent ts-node from reading them again
+        skipProject: true,
+    });
+    const { transpiler, swc } = service.options;
+    // Don't warn if a faster transpiler is enabled
+    if (!transpiler && !swc) {
+        warnTsNodeUsage();
+    }
+    return () => {
+        service.enabled(false);
+    };
 }
-
-Yallist.prototype.pushNode = function (node) {
-  if (node === this.tail) {
-    return
-  }
-
-  if (node.list) {
-    node.list.removeNode(node)
-  }
-
-  var tail = this.tail
-  node.list = this
-  node.prev = tail
-  if (tail) {
-    tail.next = node
-  }
-
-  this.tail = node
-  if (!this.head) {
-    this.head = node
-  }
-  this.length++
+exports.getTsNodeTranspiler = getTsNodeTranspiler;
+function getTranspiler(compilerOptions, tsConfigPath) {
+    const preferTsNode = process.env.NX_PREFER_TS_NODE === 'true';
+    if (!ts) {
+        ts = __nccwpck_require__(81151);
+    }
+    compilerOptions.lib = ['es2021'];
+    compilerOptions.module = ts.ModuleKind.CommonJS;
+    compilerOptions.target = ts.ScriptTarget.ES2021;
+    compilerOptions.inlineSourceMap = true;
+    compilerOptions.skipLibCheck = true;
+    if (swcNodeInstalled && !preferTsNode) {
+        return () => getSwcTranspiler(compilerOptions, tsConfigPath);
+    }
+    // We can fall back on ts-node if it's available
+    if (tsNodeInstalled) {
+        return () => getTsNodeTranspiler(compilerOptions);
+    }
 }
-
-Yallist.prototype.push = function () {
-  for (var i = 0, l = arguments.length; i < l; i++) {
-    push(this, arguments[i])
-  }
-  return this.length
+exports.getTranspiler = getTranspiler;
+/**
+ * Register ts-node or swc-node given a set of compiler options.
+ *
+ * Note: Several options require enums from typescript. To avoid importing typescript,
+ * use import type + raw values
+ *
+ * @returns cleanup method
+ */
+function registerTranspiler(compilerOptions, tsConfigPath) {
+    // Function to register transpiler that returns cleanup function
+    const transpiler = getTranspiler(compilerOptions, tsConfigPath);
+    if (!transpiler) {
+        warnNoTranspiler();
+        return () => { };
+    }
+    return transpiler();
 }
-
-Yallist.prototype.unshift = function () {
-  for (var i = 0, l = arguments.length; i < l; i++) {
-    unshift(this, arguments[i])
-  }
-  return this.length
+exports.registerTranspiler = registerTranspiler;
+/**
+ * @param tsConfigPath Adds the paths from a tsconfig file into node resolutions
+ * @returns cleanup function
+ */
+function registerTsConfigPaths(tsConfigPath) {
+    try {
+        /**
+         * Load the ts config from the source project
+         */
+        const tsconfigPaths = loadTsConfigPaths();
+        const tsConfigResult = tsconfigPaths.loadConfig(tsConfigPath);
+        /**
+         * Register the custom workspace path mappings with node so that workspace libraries
+         * can be imported and used within project
+         */
+        if (tsConfigResult.resultType === 'success') {
+            return tsconfigPaths.register({
+                baseUrl: tsConfigResult.absoluteBaseUrl,
+                paths: tsConfigResult.paths,
+            });
+        }
+    }
+    catch (err) {
+        if (err instanceof Error) {
+            throw new Error(`Unable to load ${tsConfigPath}: ` + err.message);
+        }
+    }
+    throw new Error(`Unable to load ${tsConfigPath}`);
 }
-
-Yallist.prototype.pop = function () {
-  if (!this.tail) {
-    return undefined
-  }
-
-  var res = this.tail.value
-  this.tail = this.tail.prev
-  if (this.tail) {
-    this.tail.next = null
-  } else {
-    this.head = null
-  }
-  this.length--
-  return res
+exports.registerTsConfigPaths = registerTsConfigPaths;
+function readCompilerOptions(tsConfigPath) {
+    const preferTsNode = process.env.NX_PREFER_TS_NODE === 'true';
+    if (swcNodeInstalled && !preferTsNode) {
+        const { readDefaultTsConfig, } = __nccwpck_require__(66357);
+        return readDefaultTsConfig(tsConfigPath);
+    }
+    else {
+        return readCompilerOptionsWithTypescript(tsConfigPath);
+    }
 }
-
-Yallist.prototype.shift = function () {
-  if (!this.head) {
-    return undefined
-  }
-
-  var res = this.head.value
-  this.head = this.head.next
-  if (this.head) {
-    this.head.prev = null
-  } else {
-    this.tail = null
-  }
-  this.length--
-  return res
+function readCompilerOptionsWithTypescript(tsConfigPath) {
+    if (!ts) {
+        ts = __nccwpck_require__(81151);
+    }
+    const { readConfigFile, parseJsonConfigFileContent, sys } = ts;
+    const jsonContent = readConfigFile(tsConfigPath, sys.readFile);
+    const { options } = parseJsonConfigFileContent(jsonContent.config, sys, (0, path_1.dirname)(tsConfigPath));
+    // This property is returned in compiler options for some reason, but not part of the typings.
+    // ts-node fails on unknown props, so we have to remove it.
+    delete options.configFilePath;
+    return options;
 }
-
-Yallist.prototype.forEach = function (fn, thisp) {
-  thisp = thisp || this
-  for (var walker = this.head, i = 0; walker !== null; i++) {
-    fn.call(thisp, walker.value, i, this)
-    walker = walker.next
-  }
+function loadTsConfigPaths() {
+    try {
+        return __nccwpck_require__(24961);
+    }
+    catch {
+        warnNoTsconfigPaths();
+    }
 }
-
-Yallist.prototype.forEachReverse = function (fn, thisp) {
-  thisp = thisp || this
-  for (var walker = this.tail, i = this.length - 1; walker !== null; i--) {
-    fn.call(thisp, walker.value, i, this)
-    walker = walker.prev
-  }
+function warnTsNodeUsage() {
+    logger_1.logger.warn((0, logger_1.stripIndent)(`${logger_1.NX_PREFIX} Falling back to ts-node for local typescript execution. This may be a little slower.
+  - To fix this, ensure @swc-node/register and @swc/core have been installed`));
 }
-
-Yallist.prototype.get = function (n) {
-  for (var i = 0, walker = this.head; walker !== null && i < n; i++) {
-    // abort out of the list early if we hit a cycle
-    walker = walker.next
-  }
-  if (i === n && walker !== null) {
-    return walker.value
-  }
+function warnNoTsconfigPaths() {
+    logger_1.logger.warn((0, logger_1.stripIndent)(`${logger_1.NX_PREFIX} Unable to load tsconfig-paths, workspace libraries may be inaccessible.
+  - To fix this, install tsconfig-paths with npm/yarn/pnpm`));
 }
-
-Yallist.prototype.getReverse = function (n) {
-  for (var i = 0, walker = this.tail; walker !== null && i < n; i++) {
-    // abort out of the list early if we hit a cycle
-    walker = walker.prev
-  }
-  if (i === n && walker !== null) {
-    return walker.value
-  }
+function warnNoTranspiler() {
+    logger_1.logger.warn((0, logger_1.stripIndent)(`${logger_1.NX_PREFIX} Unable to locate swc-node or ts-node. Nx will be unable to run local ts files without transpiling.
+  - To fix this, ensure @swc-node/register and @swc/core have been installed`));
 }
-
-Yallist.prototype.map = function (fn, thisp) {
-  thisp = thisp || this
-  var res = new Yallist()
-  for (var walker = this.head; walker !== null;) {
-    res.push(fn.call(thisp, walker.value, this))
-    walker = walker.next
-  }
-  return res
+function packageIsInstalled(m) {
+    try {
+        const p = require.resolve(m);
+        return true;
+    }
+    catch {
+        return false;
+    }
 }
-
-Yallist.prototype.mapReverse = function (fn, thisp) {
-  thisp = thisp || this
-  var res = new Yallist()
-  for (var walker = this.tail; walker !== null;) {
-    res.push(fn.call(thisp, walker.value, this))
-    walker = walker.prev
-  }
-  return res
+/**
+ * ts-node requires string values for enum based typescript options.
+ * `register`'s signature just types the field as `object`, so we
+ * unfortunately do not get any kind of type safety on this.
+ */
+function getTsNodeCompilerOptions(compilerOptions) {
+    if (!ts) {
+        ts = __nccwpck_require__(81151);
+    }
+    const flagMap = {
+        module: 'ModuleKind',
+        target: 'ScriptTarget',
+        moduleDetection: 'ModuleDetectionKind',
+        newLine: 'NewLineKind',
+        moduleResolution: 'ModuleResolutionKind',
+        importsNotUsedAsValues: 'ImportsNotUsedAsValues',
+    };
+    const result = {
+        ...compilerOptions,
+    };
+    for (const flag in flagMap) {
+        if (compilerOptions[flag]) {
+            result[flag] = ts[flagMap[flag]][compilerOptions[flag]];
+        }
+    }
+    delete result.pathsBasePath;
+    delete result.configFilePath;
+    // instead of mapping to enum value we just remove it as it shouldn't ever need to be set for ts-node
+    delete result.jsx;
+    // lib option is in the format `lib.es2022.d.ts`, so we need to remove the leading `lib.` and trailing `.d.ts` to make it valid
+    result.lib = result.lib?.map((value) => {
+        return value.replace(/^lib\./, '').replace(/\.d\.ts$/, '');
+    });
+    if (result.moduleResolution) {
+        result.moduleResolution =
+            result.moduleResolution === 'NodeJs'
+                ? 'node'
+                : result.moduleResolution.toLowerCase();
+    }
+    return result;
 }
+exports.getTsNodeCompilerOptions = getTsNodeCompilerOptions;
 
-Yallist.prototype.reduce = function (fn, initial) {
-  var acc
-  var walker = this.head
-  if (arguments.length > 1) {
-    acc = initial
-  } else if (this.head) {
-    walker = this.head.next
-    acc = this.head.value
-  } else {
-    throw new TypeError('Reduce of empty list with no initial value')
-  }
-
-  for (var i = 0; walker !== null; i++) {
-    acc = fn(acc, walker.value, i)
-    walker = walker.next
-  }
 
-  return acc
-}
+/***/ }),
 
-Yallist.prototype.reduceReverse = function (fn, initial) {
-  var acc
-  var walker = this.tail
-  if (arguments.length > 1) {
-    acc = initial
-  } else if (this.tail) {
-    walker = this.tail.prev
-    acc = this.tail.value
-  } else {
-    throw new TypeError('Reduce of empty list with no initial value')
-  }
+/***/ 37650:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
-  for (var i = this.length - 1; walker !== null; i--) {
-    acc = fn(acc, walker.value, i)
-    walker = walker.prev
-  }
+"use strict";
 
-  return acc
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.findNodes = exports.getRootTsConfigPath = exports.getRootTsConfigFileName = exports.resolveModuleByImport = exports.readTsConfig = void 0;
+const workspace_root_1 = __nccwpck_require__(86708);
+const fs_1 = __nccwpck_require__(57147);
+const path_1 = __nccwpck_require__(71017);
+const normalizedAppRoot = workspace_root_1.workspaceRoot.replace(/\\/g, '/');
+let tsModule;
+function readTsConfig(tsConfigPath) {
+    if (!tsModule) {
+        tsModule = __nccwpck_require__(81151);
+    }
+    const readResult = tsModule.readConfigFile(tsConfigPath, tsModule.sys.readFile);
+    return tsModule.parseJsonConfigFileContent(readResult.config, tsModule.sys, (0, path_1.dirname)(tsConfigPath));
 }
-
-Yallist.prototype.toArray = function () {
-  var arr = new Array(this.length)
-  for (var i = 0, walker = this.head; walker !== null; i++) {
-    arr[i] = walker.value
-    walker = walker.next
-  }
-  return arr
+exports.readTsConfig = readTsConfig;
+function readTsConfigOptions(tsConfigPath) {
+    if (!tsModule) {
+        tsModule = __nccwpck_require__(81151);
+    }
+    const readResult = tsModule.readConfigFile(tsConfigPath, tsModule.sys.readFile);
+    // we don't need to scan the files, we only care about options
+    const host = {
+        readDirectory: () => [],
+        readFile: () => '',
+        fileExists: tsModule.sys.fileExists,
+    };
+    return tsModule.parseJsonConfigFileContent(readResult.config, host, (0, path_1.dirname)(tsConfigPath)).options;
 }
-
-Yallist.prototype.toArrayReverse = function () {
-  var arr = new Array(this.length)
-  for (var i = 0, walker = this.tail; walker !== null; i++) {
-    arr[i] = walker.value
-    walker = walker.prev
-  }
-  return arr
+let compilerHost;
+/**
+ * Find a module based on its import
+ *
+ * @param importExpr Import used to resolve to a module
+ * @param filePath
+ * @param tsConfigPath
+ */
+function resolveModuleByImport(importExpr, filePath, tsConfigPath) {
+    compilerHost = compilerHost || getCompilerHost(tsConfigPath);
+    const { options, host, moduleResolutionCache } = compilerHost;
+    const { resolvedModule } = tsModule.resolveModuleName(importExpr, filePath, options, host, moduleResolutionCache);
+    if (!resolvedModule) {
+        return;
+    }
+    else {
+        return resolvedModule.resolvedFileName.replace(`${normalizedAppRoot}/`, '');
+    }
 }
-
-Yallist.prototype.slice = function (from, to) {
-  to = to || this.length
-  if (to < 0) {
-    to += this.length
-  }
-  from = from || 0
-  if (from < 0) {
-    from += this.length
-  }
-  var ret = new Yallist()
-  if (to < from || to < 0) {
-    return ret
-  }
-  if (from < 0) {
-    from = 0
-  }
-  if (to > this.length) {
-    to = this.length
-  }
-  for (var i = 0, walker = this.head; walker !== null && i < from; i++) {
-    walker = walker.next
-  }
-  for (; walker !== null && i < to; i++, walker = walker.next) {
-    ret.push(walker.value)
-  }
-  return ret
+exports.resolveModuleByImport = resolveModuleByImport;
+function getCompilerHost(tsConfigPath) {
+    const options = readTsConfigOptions(tsConfigPath);
+    const host = tsModule.createCompilerHost(options, true);
+    const moduleResolutionCache = tsModule.createModuleResolutionCache(workspace_root_1.workspaceRoot, host.getCanonicalFileName);
+    return { options, host, moduleResolutionCache };
 }
-
-Yallist.prototype.sliceReverse = function (from, to) {
-  to = to || this.length
-  if (to < 0) {
-    to += this.length
-  }
-  from = from || 0
-  if (from < 0) {
-    from += this.length
-  }
-  var ret = new Yallist()
-  if (to < from || to < 0) {
-    return ret
-  }
-  if (from < 0) {
-    from = 0
-  }
-  if (to > this.length) {
-    to = this.length
-  }
-  for (var i = this.length, walker = this.tail; walker !== null && i > to; i--) {
-    walker = walker.prev
-  }
-  for (; walker !== null && i > from; i--, walker = walker.prev) {
-    ret.push(walker.value)
-  }
-  return ret
+function getRootTsConfigFileName() {
+    for (const tsConfigName of ['tsconfig.base.json', 'tsconfig.json']) {
+        const tsConfigPath = (0, path_1.join)(workspace_root_1.workspaceRoot, tsConfigName);
+        if ((0, fs_1.existsSync)(tsConfigPath)) {
+            return tsConfigName;
+        }
+    }
+    return null;
+}
+exports.getRootTsConfigFileName = getRootTsConfigFileName;
+function getRootTsConfigPath() {
+    const tsConfigFileName = getRootTsConfigFileName();
+    return tsConfigFileName ? (0, path_1.join)(workspace_root_1.workspaceRoot, tsConfigFileName) : null;
+}
+exports.getRootTsConfigPath = getRootTsConfigPath;
+function findNodes(node, kind, max = Infinity) {
+    if (!node || max == 0) {
+        return [];
+    }
+    const arr = [];
+    const hasMatch = Array.isArray(kind)
+        ? kind.includes(node.kind)
+        : node.kind === kind;
+    if (hasMatch) {
+        arr.push(node);
+        max--;
+    }
+    if (max > 0) {
+        for (const child of node.getChildren()) {
+            findNodes(child, kind, max).forEach((node) => {
+                if (max > 0) {
+                    arr.push(node);
+                }
+                max--;
+            });
+            if (max <= 0) {
+                break;
+            }
+        }
+    }
+    return arr;
 }
+exports.findNodes = findNodes;
 
-Yallist.prototype.splice = function (start, deleteCount, ...nodes) {
-  if (start > this.length) {
-    start = this.length - 1
-  }
-  if (start < 0) {
-    start = this.length + start;
-  }
 
-  for (var i = 0, walker = this.head; walker !== null && i < start; i++) {
-    walker = walker.next
-  }
+/***/ }),
 
-  var ret = []
-  for (var i = 0; walker && i < deleteCount; i++) {
-    ret.push(walker.value)
-    walker = this.removeNode(walker)
-  }
-  if (walker === null) {
-    walker = this.tail
-  }
+/***/ 26391:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
-  if (walker !== this.head && walker !== this.tail) {
-    walker = walker.prev
-  }
+"use strict";
 
-  for (var i = 0; i < nodes.length; i++) {
-    walker = insert(this, walker, nodes[i])
-  }
-  return ret;
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.getGlobPatternsFromPackageManagerWorkspaces = exports.buildProjectConfigurationFromPackageJson = exports.createNodeFromPackageJson = exports.getNxPackageJsonWorkspacesPlugin = void 0;
+const minimatch_1 = __nccwpck_require__(55224);
+const node_fs_1 = __nccwpck_require__(87561);
+const node_path_1 = __nccwpck_require__(49411);
+const nx_json_1 = __nccwpck_require__(53619);
+const workspaces_1 = __nccwpck_require__(26546);
+const fileutils_1 = __nccwpck_require__(83851);
+const globs_1 = __nccwpck_require__(94865);
+const logger_1 = __nccwpck_require__(39299);
+const output_1 = __nccwpck_require__(1737);
+const package_json_1 = __nccwpck_require__(4014);
+const path_1 = __nccwpck_require__(38270);
+function getNxPackageJsonWorkspacesPlugin(root) {
+    const readJson = (f) => (0, fileutils_1.readJsonFile)((0, node_path_1.join)(root, f));
+    const patterns = getGlobPatternsFromPackageManagerWorkspaces(root, readJson);
+    // If the user only specified a negative pattern, we should find all package.json
+    // files and only return those that don't match a negative pattern.
+    const negativePatterns = patterns.filter((p) => p.startsWith('!'));
+    let positivePatterns = patterns.filter((p) => !p.startsWith('!'));
+    if (
+    // There are some negative patterns
+    negativePatterns.length > 0 &&
+        // No positive patterns
+        (positivePatterns.length === 0 ||
+            // Or only a single positive pattern that is the default coming from root package
+            (positivePatterns.length === 1 && positivePatterns[0] === 'package.json'))) {
+        positivePatterns.push('**/package.json');
+    }
+    return {
+        name: 'nx/core/package-json-workspaces',
+        createNodes: [
+            (0, globs_1.combineGlobPatterns)(positivePatterns),
+            (p) => {
+                if (!negativePatterns.some((negative) => (0, minimatch_1.minimatch)(p, negative))) {
+                    return createNodeFromPackageJson(p, root);
+                }
+                // A negative pattern matched, so we should not create a node for this package.json
+                return {};
+            },
+        ],
+    };
 }
-
-Yallist.prototype.reverse = function () {
-  var head = this.head
-  var tail = this.tail
-  for (var walker = head; walker !== null; walker = walker.prev) {
-    var p = walker.prev
-    walker.prev = walker.next
-    walker.next = p
-  }
-  this.head = tail
-  this.tail = head
-  return this
+exports.getNxPackageJsonWorkspacesPlugin = getNxPackageJsonWorkspacesPlugin;
+function createNodeFromPackageJson(pkgJsonPath, root) {
+    const json = (0, fileutils_1.readJsonFile)((0, node_path_1.join)(root, pkgJsonPath));
+    const project = buildProjectConfigurationFromPackageJson(json, pkgJsonPath, (0, nx_json_1.readNxJson)(root));
+    return {
+        projects: {
+            [project.root]: project,
+        },
+    };
 }
-
-function insert (self, node, value) {
-  var inserted = node === self.head ?
-    new Node(value, null, node, self) :
-    new Node(value, node, node.next, self)
-
-  if (inserted.next === null) {
-    self.tail = inserted
-  }
-  if (inserted.prev === null) {
-    self.head = inserted
-  }
-
-  self.length++
-
-  return inserted
+exports.createNodeFromPackageJson = createNodeFromPackageJson;
+function buildProjectConfigurationFromPackageJson(packageJson, path, nxJson) {
+    const normalizedPath = path.split('\\').join('/');
+    const directory = (0, node_path_1.dirname)(normalizedPath);
+    if (!packageJson.name && directory === '.') {
+        throw new Error('Nx requires the root package.json to specify a name if it is being used as an Nx project.');
+    }
+    let name = packageJson.name ?? (0, workspaces_1.toProjectName)(normalizedPath);
+    const projectType = nxJson?.workspaceLayout?.appsDir != nxJson?.workspaceLayout?.libsDir &&
+        nxJson?.workspaceLayout?.appsDir &&
+        directory.startsWith(nxJson.workspaceLayout.appsDir)
+        ? 'application'
+        : 'library';
+    return {
+        root: directory,
+        sourceRoot: directory,
+        name,
+        projectType,
+        ...packageJson.nx,
+        targets: (0, package_json_1.readTargetsFromPackageJson)(packageJson),
+    };
 }
-
-function push (self, item) {
-  self.tail = new Node(item, self.tail, null, self)
-  if (!self.head) {
-    self.head = self.tail
-  }
-  self.length++
+exports.buildProjectConfigurationFromPackageJson = buildProjectConfigurationFromPackageJson;
+/**
+ * Get the package.json globs from package manager workspaces
+ */
+function getGlobPatternsFromPackageManagerWorkspaces(root, readJson = (path) => (0, fileutils_1.readJsonFile)((0, node_path_1.join)(root, path)) // making this an arg allows us to reuse in devkit
+) {
+    try {
+        const patterns = [];
+        const packageJson = readJson('package.json');
+        patterns.push(...normalizePatterns(Array.isArray(packageJson.workspaces)
+            ? packageJson.workspaces
+            : packageJson.workspaces?.packages ?? []));
+        if ((0, node_fs_1.existsSync)((0, node_path_1.join)(root, 'pnpm-workspace.yaml'))) {
+            try {
+                const { packages } = (0, fileutils_1.readYamlFile)((0, node_path_1.join)(root, 'pnpm-workspace.yaml'));
+                patterns.push(...normalizePatterns(packages || []));
+            }
+            catch (e) {
+                output_1.output.warn({
+                    title: `${logger_1.NX_PREFIX} Unable to parse pnpm-workspace.yaml`,
+                    bodyLines: [e.toString()],
+                });
+            }
+        }
+        if ((0, node_fs_1.existsSync)((0, node_path_1.join)(root, 'lerna.json'))) {
+            try {
+                const { packages } = readJson('lerna.json');
+                patterns.push(...normalizePatterns(packages?.length > 0 ? packages : ['packages/*']));
+            }
+            catch (e) {
+                output_1.output.warn({
+                    title: `${logger_1.NX_PREFIX} Unable to parse lerna.json`,
+                    bodyLines: [e.toString()],
+                });
+            }
+        }
+        // Merge patterns from workspaces definitions
+        // TODO(@AgentEnder): update logic after better way to determine root project inclusion
+        // Include the root project
+        return packageJson.nx ? patterns.concat('package.json') : patterns;
+    }
+    catch {
+        return [];
+    }
 }
-
-function unshift (self, item) {
-  self.head = new Node(item, null, self.head, self)
-  if (!self.tail) {
-    self.tail = self.head
-  }
-  self.length++
+exports.getGlobPatternsFromPackageManagerWorkspaces = getGlobPatternsFromPackageManagerWorkspaces;
+function normalizePatterns(patterns) {
+    return patterns.map((pattern) => removeRelativePath(pattern.endsWith('/package.json')
+        ? pattern
+        : (0, path_1.joinPathFragments)(pattern, 'package.json')));
 }
-
-function Node (value, prev, next, list) {
-  if (!(this instanceof Node)) {
-    return new Node(value, prev, next, list)
-  }
-
-  this.list = list
-  this.value = value
-
-  if (prev) {
-    prev.next = this
-    this.prev = prev
-  } else {
-    this.prev = null
-  }
-
-  if (next) {
-    next.prev = this
-    this.next = next
-  } else {
-    this.next = null
-  }
+function removeRelativePath(pattern) {
+    return pattern.startsWith('./') ? pattern.substring(2) : pattern;
 }
 
-try {
-  // add if support for Symbol.iterator is present
-  __nccwpck_require__(17005)(Yallist)
-} catch (er) {}
-
 
 /***/ }),
 
-/***/ 22287:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+/***/ 65286:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
 "use strict";
 
-const lenient = __nccwpck_require__(48234);
-
-const yn = (input, options) => {
-	input = String(input).trim();
-
-	options = Object.assign({
-		lenient: false,
-		default: null
-	}, options);
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+const tslib_1 = __nccwpck_require__(57265);
+tslib_1.__exportStar(__nccwpck_require__(26391), exports);
 
-	if (options.default !== null && typeof options.default !== 'boolean') {
-		throw new TypeError(`Expected the \`default\` option to be of type \`boolean\`, got \`${typeof options.default}\``);
-	}
 
-	if (/^(?:y|yes|true|1)$/i.test(input)) {
-		return true;
-	}
+/***/ }),
 
-	if (/^(?:n|no|false|0)$/i.test(input)) {
-		return false;
-	}
+/***/ 1215:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
-	if (options.lenient === true) {
-		return lenient(input, options);
-	}
+"use strict";
 
-	return options.default;
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.PackageJsonProjectsNextToProjectJsonPlugin = void 0;
+const path_1 = __nccwpck_require__(71017);
+const fs_1 = __nccwpck_require__(57147);
+const fileutils_1 = __nccwpck_require__(83851);
+const package_json_1 = __nccwpck_require__(4014);
+// TODO: Remove this one day, this should not need to be done.
+exports.PackageJsonProjectsNextToProjectJsonPlugin = {
+    // Its not a problem if plugins happen to have same name, and this
+    // will look least confusing in the source map.
+    name: 'nx/core/package-json',
+    createNodes: [
+        '{project.json,**/project.json}',
+        (file, _, { workspaceRoot }) => {
+            const project = createProjectFromPackageJsonNextToProjectJson(file, workspaceRoot);
+            return project
+                ? {
+                    projects: {
+                        [project.name]: project,
+                    },
+                }
+                : {};
+        },
+    ],
 };
-
-module.exports = yn;
-// TODO: Remove this for the next major release
-module.exports["default"] = yn;
+function createProjectFromPackageJsonNextToProjectJson(projectJsonPath, workspaceRoot) {
+    const root = (0, path_1.dirname)(projectJsonPath);
+    const packageJsonPath = (0, path_1.join)(workspaceRoot, root, 'package.json');
+    if (!(0, fs_1.existsSync)(packageJsonPath)) {
+        return null;
+    }
+    try {
+        const packageJson = (0, fileutils_1.readJsonFile)(packageJsonPath);
+        let { nx, name } = packageJson;
+        return {
+            ...nx,
+            name,
+            root,
+            targets: (0, package_json_1.readTargetsFromPackageJson)(packageJson),
+        };
+    }
+    catch (e) {
+        console.log(e);
+        return null;
+    }
+}
 
 
 /***/ }),
 
-/***/ 48234:
-/***/ ((module) => {
+/***/ 76877:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
 "use strict";
 
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.buildProjectFromProjectJson = exports.ProjectJsonProjectsPlugin = void 0;
+const node_path_1 = __nccwpck_require__(49411);
+const workspaces_1 = __nccwpck_require__(26546);
+const fileutils_1 = __nccwpck_require__(83851);
+exports.ProjectJsonProjectsPlugin = {
+    name: 'nx/core/project-json',
+    createNodes: [
+        '{project.json,**/project.json}',
+        (file, _, { workspaceRoot }) => {
+            const json = (0, fileutils_1.readJsonFile)((0, node_path_1.join)(workspaceRoot, file));
+            const project = buildProjectFromProjectJson(json, file);
+            return {
+                projects: {
+                    [project.root]: project,
+                },
+            };
+        },
+    ],
+};
+function buildProjectFromProjectJson(json, path) {
+    return {
+        name: (0, workspaces_1.toProjectName)(path),
+        root: (0, node_path_1.dirname)(path),
+        ...json,
+    };
+}
+exports.buildProjectFromProjectJson = buildProjectFromProjectJson;
 
-const YES_MATCH_SCORE_THRESHOLD = 2;
-const NO_MATCH_SCORE_THRESHOLD = 1.25;
-
-const yMatch = new Map([
-	[5, 0.25],
-	[6, 0.25],
-	[7, 0.25],
-	['t', 0.75],
-	['y', 1],
-	['u', 0.75],
-	['g', 0.25],
-	['h', 0.25],
-	['j', 0.25]
-]);
 
-const eMatch = new Map([
-	[2, 0.25],
-	[3, 0.25],
-	[4, 0.25],
-	['w', 0.75],
-	['e', 1],
-	['r', 0.75],
-	['s', 0.25],
-	['d', 0.25],
-	['f', 0.25]
-]);
+/***/ }),
 
-const sMatch = new Map([
-	['q', 0.25],
-	['w', 0.25],
-	['e', 0.25],
-	['a', 0.75],
-	['s', 1],
-	['d', 0.75],
-	['z', 0.25],
-	['x', 0.25],
-	['c', 0.25]
-]);
+/***/ 50280:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
-const nMatch = new Map([
-	['h', 0.25],
-	['j', 0.25],
-	['k', 0.25],
-	['b', 0.75],
-	['n', 1],
-	['m', 0.75]
-]);
+"use strict";
 
-const oMatch = new Map([
-	[9, 0.25],
-	[0, 0.25],
-	['i', 0.75],
-	['o', 1],
-	['p', 0.75],
-	['k', 0.25],
-	['l', 0.25]
-]);
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.getTargetInfo = exports.TargetDefaultsPlugin = exports.ONLY_MODIFIES_EXISTING_TARGET = void 0;
+const minimatch_1 = __nccwpck_require__(55224);
+const node_fs_1 = __nccwpck_require__(87561);
+const node_path_1 = __nccwpck_require__(49411);
+const fileutils_1 = __nccwpck_require__(83851);
+const globs_1 = __nccwpck_require__(94865);
+const package_json_workspaces_1 = __nccwpck_require__(65286);
+/**
+ * This symbol marks that a target provides information which should modify a target already registered
+ * on the project via other plugins. If the target has not already been registered, and this symbol is true,
+ * the information provided by it will be discarded.
+ */
+exports.ONLY_MODIFIES_EXISTING_TARGET = Symbol('ONLY_MODIFIES_EXISTING_TARGET');
+exports.TargetDefaultsPlugin = {
+    name: 'nx/core/target-defaults',
+    createNodes: [
+        '{package.json,**/package.json,project.json,**/project.json}',
+        (configFile, _, ctx) => {
+            const fileName = (0, node_path_1.basename)(configFile);
+            const root = (0, node_path_1.dirname)(configFile);
+            const packageManagerWorkspacesGlob = (0, globs_1.combineGlobPatterns)((0, package_json_workspaces_1.getGlobPatternsFromPackageManagerWorkspaces)(ctx.workspaceRoot));
+            // Only process once if package.json + project.json both exist
+            if (fileName === 'package.json' &&
+                (0, node_fs_1.existsSync)((0, node_path_1.join)(ctx.workspaceRoot, root, 'project.json'))) {
+                return {};
+            }
+            else if (fileName === 'package.json' &&
+                !(0, minimatch_1.minimatch)(configFile, packageManagerWorkspacesGlob)) {
+                return {};
+            }
+            // If no target defaults, this does nothing
+            const targetDefaults = ctx.nxJsonConfiguration?.targetDefaults;
+            if (!targetDefaults) {
+                return {};
+            }
+            const projectJson = readJsonOrNull((0, node_path_1.join)(ctx.workspaceRoot, root, 'project.json'));
+            const packageJson = readJsonOrNull((0, node_path_1.join)(ctx.workspaceRoot, root, 'package.json'));
+            const includedScripts = packageJson?.nx?.includedScripts;
+            const projectDefinedTargets = new Set([
+                ...Object.keys(packageJson?.scripts ?? {}).filter((script) => {
+                    if (includedScripts) {
+                        return includedScripts.includes(script);
+                    }
+                    return true;
+                }),
+                ...Object.keys(projectJson?.targets ?? {}),
+                ...Object.keys(packageJson?.nx?.targets ?? {}),
+            ]);
+            const executorToTargetMap = getExecutorToTargetMap(packageJson, projectJson);
+            const modifiedTargets = {};
+            for (const defaultSpecifier in targetDefaults) {
+                const targetNames = executorToTargetMap.get(defaultSpecifier) ?? new Set();
+                targetNames.add(defaultSpecifier);
+                for (const targetName of targetNames) {
+                    // Prevents `build` from overwriting `@nx/js:tsc` if both are present
+                    // and build is specified later in the ordering.
+                    if (!modifiedTargets[targetName] || targetName !== defaultSpecifier) {
+                        const defaults = JSON.parse(JSON.stringify(targetDefaults[defaultSpecifier]));
+                        modifiedTargets[targetName] = {
+                            ...getTargetInfo(targetName, projectJson, packageJson),
+                            ...defaults,
+                        };
+                    }
+                    // TODO: Remove this after we figure out a way to define new targets
+                    // in target defaults
+                    if (!projectDefinedTargets.has(targetName)) {
+                        modifiedTargets[targetName][exports.ONLY_MODIFIES_EXISTING_TARGET] = true;
+                    }
+                }
+            }
+            return {
+                projects: {
+                    [root]: {
+                        targets: modifiedTargets,
+                    },
+                },
+            };
+        },
+    ],
+};
+function getExecutorToTargetMap(packageJson, projectJson) {
+    const executorToTargetMap = new Map();
+    const targets = Object.keys({
+        ...projectJson?.targets,
+        ...packageJson?.scripts,
+        ...packageJson?.nx?.targets,
+    });
+    for (const target of targets) {
+        const executor = projectJson?.targets?.[target]?.executor ??
+            packageJson?.nx?.targets?.[target]?.executor ??
+            'nx:run-script';
+        const targetsForExecutor = executorToTargetMap.get(executor) ?? new Set();
+        targetsForExecutor.add(target);
+        executorToTargetMap.set(executor, targetsForExecutor);
+    }
+    return executorToTargetMap;
+}
+function readJsonOrNull(path) {
+    if ((0, node_fs_1.existsSync)(path)) {
+        return (0, fileutils_1.readJsonFile)(path);
+    }
+    else {
+        return null;
+    }
+}
+/**
+ * This fn gets target info that would make a target uniquely compatible
+ * with what is described by project.json or package.json. As the merge process
+ * for config happens, without this, the target defaults may be compatible
+ * with a config from a plugin and then that combined target be incompatible
+ * with the project json configuration resulting in the target default values
+ * being scrapped. By adding enough information from the project.json / package.json,
+ * we can make sure that the target after merging is compatible with the defined target.
+ */
+function getTargetInfo(target, projectJson, packageJson) {
+    const projectJsonTarget = projectJson?.targets?.[target];
+    const packageJsonTarget = packageJson?.nx?.targets?.[target];
+    const executor = getTargetExecutor(target, projectJson, packageJson);
+    const targetOptions = {
+        ...packageJsonTarget?.options,
+        ...projectJsonTarget?.options,
+    };
+    if (projectJsonTarget?.command) {
+        return {
+            command: projectJsonTarget?.command,
+        };
+    }
+    if (executor === 'nx:run-commands') {
+        if (targetOptions?.command) {
+            return {
+                executor: 'nx:run-commands',
+                options: {
+                    command: projectJsonTarget.options?.command,
+                },
+            };
+        }
+        else if (targetOptions?.commands) {
+            return {
+                executor: 'nx:run-commands',
+                options: {
+                    commands: targetOptions.commands,
+                },
+            };
+        }
+        return {
+            executor: 'nx:run-commands',
+        };
+    }
+    if (executor === 'nx:run-script') {
+        return {
+            executor: 'nx:run-script',
+            options: {
+                script: targetOptions?.script ?? target,
+            },
+        };
+    }
+    if (executor) {
+        return { executor };
+    }
+    return {};
+}
+exports.getTargetInfo = getTargetInfo;
+function getTargetExecutor(target, projectJson, packageJson) {
+    const projectJsonTarget = projectJson?.targets?.[target];
+    const packageJsonTarget = packageJson?.nx?.targets?.[target];
+    const packageJsonScript = packageJson?.scripts?.[target];
+    if (projectJsonTarget?.command) {
+        return 'nx:run-commands';
+    }
+    if (!projectJsonTarget?.executor &&
+        !packageJsonTarget?.executor &&
+        packageJsonScript) {
+        return 'nx:run-script';
+    }
+    return projectJsonTarget?.executor ?? packageJsonTarget?.executor;
+}
 
-function getYesMatchScore(value) {
-	const [y, e, s] = value;
-	let score = 0;
 
-	if (yMatch.has(y)) {
-		score += yMatch.get(y);
-	}
+/***/ }),
 
-	if (eMatch.has(e)) {
-		score += eMatch.get(e);
-	}
+/***/ 71553:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
-	if (sMatch.has(s)) {
-		score += sMatch.get(s);
-	}
+"use strict";
 
-	return score;
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.buildProjectGraphUsingProjectFileMap = exports.getFileMap = void 0;
+const workspace_root_1 = __nccwpck_require__(86708);
+const path_1 = __nccwpck_require__(71017);
+const perf_hooks_1 = __nccwpck_require__(4074);
+const assert_workspace_validity_1 = __nccwpck_require__(89208);
+const nx_deps_cache_1 = __nccwpck_require__(57074);
+const implicit_project_dependencies_1 = __nccwpck_require__(85251);
+const normalize_project_nodes_1 = __nccwpck_require__(44852);
+const nx_plugin_1 = __nccwpck_require__(84141);
+const typescript_1 = __nccwpck_require__(37650);
+const fileutils_1 = __nccwpck_require__(83851);
+const project_graph_builder_1 = __nccwpck_require__(80862);
+const configuration_1 = __nccwpck_require__(38777);
+const fs_1 = __nccwpck_require__(57147);
+const installation_directory_1 = __nccwpck_require__(98584);
+const output_1 = __nccwpck_require__(1737);
+let storedFileMap = null;
+let storedAllWorkspaceFiles = null;
+let storedRustReferences = null;
+function getFileMap() {
+    if (!!storedFileMap) {
+        return {
+            fileMap: storedFileMap,
+            allWorkspaceFiles: storedAllWorkspaceFiles,
+            rustReferences: storedRustReferences,
+        };
+    }
+    else {
+        return {
+            fileMap: {
+                nonProjectFiles: [],
+                projectFileMap: {},
+            },
+            allWorkspaceFiles: [],
+            rustReferences: null,
+        };
+    }
 }
-
-function getNoMatchScore(value) {
-	const [n, o] = value;
-	let score = 0;
-
-	if (nMatch.has(n)) {
-		score += nMatch.get(n);
-	}
-
-	if (oMatch.has(o)) {
-		score += oMatch.get(o);
-	}
-
-	return score;
+exports.getFileMap = getFileMap;
+async function buildProjectGraphUsingProjectFileMap(projects, externalNodes, fileMap, allWorkspaceFiles, rustReferences, fileMapCache, shouldWriteCache) {
+    storedFileMap = fileMap;
+    storedAllWorkspaceFiles = allWorkspaceFiles;
+    storedRustReferences = rustReferences;
+    const nxJson = (0, configuration_1.readNxJson)();
+    const projectGraphVersion = '6.0';
+    (0, assert_workspace_validity_1.assertWorkspaceValidity)(projects, nxJson);
+    const packageJsonDeps = readCombinedDeps();
+    const rootTsConfig = readRootTsConfig();
+    let filesToProcess;
+    let cachedFileData;
+    const useCacheData = fileMapCache &&
+        !(0, nx_deps_cache_1.shouldRecomputeWholeGraph)(fileMapCache, packageJsonDeps, projects, nxJson, rootTsConfig);
+    if (useCacheData) {
+        const fromCache = (0, nx_deps_cache_1.extractCachedFileData)(fileMap, fileMapCache);
+        filesToProcess = fromCache.filesToProcess;
+        cachedFileData = fromCache.cachedFileData;
+    }
+    else {
+        filesToProcess = fileMap;
+        cachedFileData = {
+            nonProjectFiles: {},
+            projectFileMap: {},
+        };
+    }
+    const context = createContext(projects, nxJson, externalNodes, fileMap, filesToProcess);
+    let projectGraph = await buildProjectGraphUsingContext(nxJson, externalNodes, context, cachedFileData, projectGraphVersion);
+    const projectFileMapCache = (0, nx_deps_cache_1.createProjectFileMapCache)(nxJson, packageJsonDeps, fileMap, rootTsConfig);
+    if (shouldWriteCache) {
+        (0, nx_deps_cache_1.writeCache)(projectFileMapCache, projectGraph);
+    }
+    return {
+        projectGraph,
+        projectFileMapCache,
+    };
+}
+exports.buildProjectGraphUsingProjectFileMap = buildProjectGraphUsingProjectFileMap;
+function readCombinedDeps() {
+    const installationPackageJsonPath = (0, path_1.join)(workspace_root_1.workspaceRoot, '.nx', 'installation', 'package.json');
+    const installationPackageJson = (0, fs_1.existsSync)(installationPackageJsonPath)
+        ? (0, fileutils_1.readJsonFile)(installationPackageJsonPath)
+        : {};
+    const rootPackageJsonPath = (0, path_1.join)(workspace_root_1.workspaceRoot, 'package.json');
+    const rootPackageJson = (0, fs_1.existsSync)(rootPackageJsonPath)
+        ? (0, fileutils_1.readJsonFile)(rootPackageJsonPath)
+        : {};
+    return {
+        ...rootPackageJson.dependencies,
+        ...rootPackageJson.devDependencies,
+        ...installationPackageJson.dependencies,
+        ...installationPackageJson.devDependencies,
+    };
+}
+async function buildProjectGraphUsingContext(nxJson, knownExternalNodes, ctx, cachedFileData, projectGraphVersion) {
+    perf_hooks_1.performance.mark('build project graph:start');
+    const builder = new project_graph_builder_1.ProjectGraphBuilder(null, ctx.fileMap.projectFileMap);
+    builder.setVersion(projectGraphVersion);
+    for (const node in knownExternalNodes) {
+        builder.addExternalNode(knownExternalNodes[node]);
+    }
+    await (0, normalize_project_nodes_1.normalizeProjectNodes)(ctx, builder);
+    const initProjectGraph = builder.getUpdatedProjectGraph();
+    const r = await updateProjectGraphWithPlugins(ctx, initProjectGraph);
+    const updatedBuilder = new project_graph_builder_1.ProjectGraphBuilder(r, ctx.fileMap.projectFileMap);
+    for (const proj of Object.keys(cachedFileData.projectFileMap)) {
+        for (const f of ctx.fileMap.projectFileMap[proj] || []) {
+            const cached = cachedFileData.projectFileMap[proj][f.file];
+            if (cached && cached.deps) {
+                f.deps = [...cached.deps];
+            }
+        }
+    }
+    for (const file of ctx.fileMap.nonProjectFiles) {
+        const cached = cachedFileData.nonProjectFiles[file.file];
+        if (cached?.deps) {
+            file.deps = [...cached.deps];
+        }
+    }
+    (0, implicit_project_dependencies_1.applyImplicitDependencies)(ctx.projects, updatedBuilder);
+    const finalGraph = updatedBuilder.getUpdatedProjectGraph();
+    perf_hooks_1.performance.mark('build project graph:end');
+    perf_hooks_1.performance.measure('build project graph', 'build project graph:start', 'build project graph:end');
+    return finalGraph;
+}
+function createContext(projects, nxJson, externalNodes, fileMap, filesToProcess) {
+    const clonedProjects = Object.keys(projects).reduce((map, projectName) => {
+        map[projectName] = {
+            ...projects[projectName],
+        };
+        return map;
+    }, {});
+    return {
+        nxJsonConfiguration: nxJson,
+        projects: clonedProjects,
+        externalNodes,
+        workspaceRoot: workspace_root_1.workspaceRoot,
+        fileMap,
+        filesToProcess,
+    };
+}
+async function updateProjectGraphWithPlugins(context, initProjectGraph) {
+    const plugins = await (0, nx_plugin_1.loadNxPlugins)(context.nxJsonConfiguration?.plugins, (0, installation_directory_1.getNxRequirePaths)(), context.workspaceRoot, context.projects);
+    let graph = initProjectGraph;
+    for (const { plugin } of plugins) {
+        try {
+            if ((0, nx_plugin_1.isNxPluginV1)(plugin) &&
+                plugin.processProjectGraph &&
+                !plugin.createDependencies) {
+                output_1.output.warn({
+                    title: `${plugin.name} is a v1 plugin.`,
+                    bodyLines: [
+                        'Nx has recently released a v2 model for project graph plugins. The `processProjectGraph` method is deprecated. Plugins should use some combination of `createNodes` and `createDependencies` instead.',
+                    ],
+                });
+                perf_hooks_1.performance.mark(`${plugin.name}:processProjectGraph - start`);
+                graph = await plugin.processProjectGraph(graph, {
+                    ...context,
+                    projectsConfigurations: {
+                        projects: context.projects,
+                        version: 2,
+                    },
+                    fileMap: context.fileMap.projectFileMap,
+                    filesToProcess: context.filesToProcess.projectFileMap,
+                    workspace: {
+                        version: 2,
+                        projects: context.projects,
+                        ...context.nxJsonConfiguration,
+                    },
+                });
+                perf_hooks_1.performance.mark(`${plugin.name}:processProjectGraph - end`);
+                perf_hooks_1.performance.measure(`${plugin.name}:processProjectGraph`, `${plugin.name}:processProjectGraph - start`, `${plugin.name}:processProjectGraph - end`);
+            }
+        }
+        catch (e) {
+            let message = `Failed to process the project graph with "${plugin.name}".`;
+            if (e instanceof Error) {
+                e.message = message + '\n' + e.message;
+                throw e;
+            }
+            throw new Error(message);
+        }
+    }
+    const builder = new project_graph_builder_1.ProjectGraphBuilder(graph, context.fileMap.projectFileMap, context.fileMap.nonProjectFiles);
+    const createDependencyPlugins = plugins.filter(({ plugin }) => (0, nx_plugin_1.isNxPluginV2)(plugin) && plugin.createDependencies);
+    await Promise.all(createDependencyPlugins.map(async ({ plugin, options }) => {
+        perf_hooks_1.performance.mark(`${plugin.name}:createDependencies - start`);
+        // Set this globally to allow plugins to know if they are being called from the project graph creation
+        global.NX_GRAPH_CREATION = true;
+        try {
+            const dependencies = await plugin.createDependencies(options, {
+                ...context,
+            });
+            for (const dep of dependencies) {
+                builder.addDependency(dep.source, dep.target, dep.type, 'sourceFile' in dep ? dep.sourceFile : null);
+            }
+        }
+        catch (e) {
+            let message = `Failed to process project dependencies with "${plugin.name}".`;
+            if (e instanceof Error) {
+                e.message = message + '\n' + e.message;
+                throw e;
+            }
+            throw new Error(message);
+        }
+        delete global.NX_GRAPH_CREATION;
+        perf_hooks_1.performance.mark(`${plugin.name}:createDependencies - end`);
+        perf_hooks_1.performance.measure(`${plugin.name}:createDependencies`, `${plugin.name}:createDependencies - start`, `${plugin.name}:createDependencies - end`);
+    }));
+    return builder.getUpdatedProjectGraph();
+}
+function readRootTsConfig() {
+    try {
+        const tsConfigPath = (0, typescript_1.getRootTsConfigPath)();
+        if (tsConfigPath) {
+            return (0, fileutils_1.readJsonFile)(tsConfigPath, { expectComments: true });
+        }
+    }
+    catch (e) {
+        return {};
+    }
 }
-
-module.exports = (input, options) => {
-	if (getYesMatchScore(input) >= YES_MATCH_SCORE_THRESHOLD) {
-		return true;
-	}
-
-	if (getNoMatchScore(input) >= NO_MATCH_SCORE_THRESHOLD) {
-		return false;
-	}
-
-	return options.default;
-};
 
 
 /***/ }),
 
-/***/ 33882:
+/***/ 63260:
 /***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
 "use strict";
 
 Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.execCommand = exports.ChildProcess = void 0;
-const tslib_1 = __nccwpck_require__(65315);
+exports.workspaceLayout = exports.readNxJson = exports.readPackageJson = exports.defaultFileRead = exports.readWorkspaceConfig = exports.TEN_MEGABYTES = exports.calculateFileChanges = exports.isDeletedFileChange = exports.isWholeFileChange = exports.DeletedFileChange = exports.WholeFileChange = void 0;
 const child_process_1 = __nccwpck_require__(32081);
-Object.defineProperty(exports, "ChildProcess", ({ enumerable: true, get: function () { return child_process_1.ChildProcess; } }));
-const shell = tslib_1.__importStar(__nccwpck_require__(54572));
-const execCommand = (command, options = {
-    asString: false,
-    asJSON: false
-}) => {
-    if (!options.silent) {
-        console.log('\nRunning: ', command);
+const fs_1 = __nccwpck_require__(57147);
+const path_1 = __nccwpck_require__(71017);
+const configuration_1 = __nccwpck_require__(38777);
+const workspace_root_1 = __nccwpck_require__(86708);
+const fileutils_1 = __nccwpck_require__(83851);
+const json_diff_1 = __nccwpck_require__(72517);
+const project_graph_1 = __nccwpck_require__(61371);
+const angular_json_1 = __nccwpck_require__(44050);
+const ignore_1 = __nccwpck_require__(77098);
+const retrieve_workspace_files_1 = __nccwpck_require__(14249);
+const project_configuration_utils_1 = __nccwpck_require__(33190);
+const nx_plugin_deprecated_1 = __nccwpck_require__(32256);
+const minimatch_1 = __nccwpck_require__(55224);
+const package_json_next_to_project_json_1 = __nccwpck_require__(1215);
+class WholeFileChange {
+    constructor() {
+        this.type = 'WholeFileChange';
+    }
+}
+exports.WholeFileChange = WholeFileChange;
+class DeletedFileChange {
+    constructor() {
+        this.type = 'WholeFileDeleted';
+    }
+}
+exports.DeletedFileChange = DeletedFileChange;
+function isWholeFileChange(change) {
+    return change.type === 'WholeFileChange';
+}
+exports.isWholeFileChange = isWholeFileChange;
+function isDeletedFileChange(change) {
+    return change.type === 'WholeFileDeleted';
+}
+exports.isDeletedFileChange = isDeletedFileChange;
+function calculateFileChanges(files, allWorkspaceFiles, nxArgs, readFileAtRevision = defaultReadFileAtRevision, ignore = (0, ignore_1.getIgnoreObject)()) {
+    files = files.filter((f) => !ignore.ignores(f));
+    return files.map((f) => {
+        const ext = (0, path_1.extname)(f);
+        const file = allWorkspaceFiles.find((fileData) => fileData.file == f);
+        const hash = file?.hash;
+        return {
+            file: f,
+            ext,
+            hash,
+            getChanges: () => {
+                if (!(0, fs_1.existsSync)((0, path_1.join)(workspace_root_1.workspaceRoot, f))) {
+                    return [new DeletedFileChange()];
+                }
+                if (!nxArgs) {
+                    return [new WholeFileChange()];
+                }
+                if (nxArgs.files && nxArgs.files.includes(f)) {
+                    return [new WholeFileChange()];
+                }
+                switch (ext) {
+                    case '.json':
+                        try {
+                            const atBase = readFileAtRevision(f, nxArgs.base);
+                            const atHead = readFileAtRevision(f, nxArgs.head);
+                            return (0, json_diff_1.jsonDiff)(JSON.parse(atBase), JSON.parse(atHead));
+                        }
+                        catch (e) {
+                            return [new WholeFileChange()];
+                        }
+                    default:
+                        return [new WholeFileChange()];
+                }
+            },
+        };
+    });
+}
+exports.calculateFileChanges = calculateFileChanges;
+exports.TEN_MEGABYTES = 1024 * 10000;
+function defaultReadFileAtRevision(file, revision) {
+    try {
+        const fileFullPath = `${workspace_root_1.workspaceRoot}${path_1.sep}${file}`;
+        const gitRepositoryPath = (0, child_process_1.execSync)('git rev-parse --show-toplevel')
+            .toString()
+            .trim();
+        const filePathInGitRepository = (0, path_1.relative)(gitRepositoryPath, fileFullPath)
+            .split(path_1.sep)
+            .join('/');
+        return !revision
+            ? (0, fs_1.readFileSync)(file, 'utf-8')
+            : (0, child_process_1.execSync)(`git show ${revision}:${filePathInGitRepository}`, {
+                maxBuffer: exports.TEN_MEGABYTES,
+                stdio: ['pipe', 'pipe', 'ignore'],
+            })
+                .toString()
+                .trim();
+    }
+    catch {
+        return '';
+    }
+}
+/**
+ * TODO(v19): Remove this function
+ * @deprecated To get projects use {@link retrieveProjectConfigurations} instead
+ */
+function readWorkspaceConfig(opts) {
+    let configuration = null;
+    const root = opts.path || process.cwd();
+    const nxJson = (0, configuration_1.readNxJson)(root);
+    try {
+        const projectGraph = (0, project_graph_1.readCachedProjectGraph)();
+        configuration = {
+            ...nxJson,
+            ...(0, project_graph_1.readProjectsConfigurationFromProjectGraph)(projectGraph),
+        };
+    }
+    catch {
+        configuration = {
+            version: 2,
+            projects: getProjectsSyncNoInference(root, nxJson).projects,
+        };
+    }
+    if (opts.format === 'angularCli') {
+        return (0, angular_json_1.toOldFormat)(configuration);
+    }
+    else {
+        return configuration;
+    }
+}
+exports.readWorkspaceConfig = readWorkspaceConfig;
+function defaultFileRead(filePath) {
+    return (0, fs_1.readFileSync)((0, path_1.join)(workspace_root_1.workspaceRoot, filePath), 'utf-8');
+}
+exports.defaultFileRead = defaultFileRead;
+function readPackageJson() {
+    try {
+        return (0, fileutils_1.readJsonFile)(`${workspace_root_1.workspaceRoot}/package.json`);
     }
-    const result = shell.exec(command, options);
-    if (options.asJSON) {
-        return JSON.parse(result.toString());
+    catch {
+        return {}; // if package.json doesn't exist
     }
-    if (options.asString) {
-        // eslint-disable-next-line @typescript-eslint/ban-ts-comment
-        // @ts-ignore
-        return result.toString();
+}
+exports.readPackageJson = readPackageJson;
+// TODO(17): Remove these exports
+var configuration_2 = __nccwpck_require__(38777);
+Object.defineProperty(exports, "readNxJson", ({ enumerable: true, get: function () { return configuration_2.readNxJson; } }));
+Object.defineProperty(exports, "workspaceLayout", ({ enumerable: true, get: function () { return configuration_2.workspaceLayout; } }));
+/**
+ * TODO(v19): Remove this function.
+ */
+function getProjectsSyncNoInference(root, nxJson) {
+    const projectFiles = (0, retrieve_workspace_files_1.retrieveProjectConfigurationPaths)(root, (0, nx_plugin_deprecated_1.getDefaultPluginsSync)(root));
+    const plugins = [
+        { plugin: package_json_next_to_project_json_1.PackageJsonProjectsNextToProjectJsonPlugin },
+        ...(0, nx_plugin_deprecated_1.getDefaultPluginsSync)(root),
+    ];
+    const projectRootMap = new Map();
+    // We iterate over plugins first - this ensures that plugins specified first take precedence.
+    for (const { plugin, options } of plugins) {
+        const [pattern, createNodes] = plugin.createNodes ?? [];
+        if (!pattern) {
+            continue;
+        }
+        for (const file of projectFiles) {
+            if ((0, minimatch_1.minimatch)(file, pattern, { dot: true })) {
+                let r = createNodes(file, options, {
+                    nxJsonConfiguration: nxJson,
+                    workspaceRoot: root,
+                });
+                for (const node in r.projects) {
+                    const project = {
+                        root: node,
+                        ...r.projects[node],
+                    };
+                    (0, project_configuration_utils_1.mergeProjectConfigurationIntoRootMap)(projectRootMap, project);
+                }
+            }
+        }
     }
-    // eslint-disable-next-line @typescript-eslint/ban-ts-comment
-    // @ts-ignore
     return {
-        success: result['code'] === 0,
-        output: result.stdout
+        projects: (0, project_configuration_utils_1.readProjectConfigurationsFromRootMap)(projectRootMap),
     };
-};
-exports.execCommand = execCommand;
+}
 
 
 /***/ }),
 
-/***/ 47777:
+/***/ 57074:
 /***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
 "use strict";
 
 Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.hasOneOfRequiredTags = exports.cleanLogConditions = void 0;
-const tslib_1 = __nccwpck_require__(65315);
-const core = tslib_1.__importStar(__nccwpck_require__(57896));
-function hasTagMatchingCondition(condition, tags) {
-    if (condition.includes('=')) {
-        // If it includes a "," it's a AND condition
-        if (condition.includes(',')) {
-            const subConditions = condition.split(',').map((subCondition) => subCondition.trim());
-            // It should match all the conditions
-            return subConditions.every((subCondition) => {
-                return hasTagMatchingCondition(subCondition, tags);
-            });
+exports.extractCachedFileData = exports.shouldRecomputeWholeGraph = exports.writeCache = exports.createProjectFileMapCache = exports.readProjectGraphCache = exports.readFileMapCache = exports.ensureCacheDirectory = exports.nxFileMap = exports.nxProjectGraph = void 0;
+const fs_1 = __nccwpck_require__(57147);
+const fs_extra_1 = __nccwpck_require__(27475);
+const path_1 = __nccwpck_require__(71017);
+const perf_hooks_1 = __nccwpck_require__(4074);
+const cache_directory_1 = __nccwpck_require__(15120);
+const fileutils_1 = __nccwpck_require__(83851);
+const versions_1 = __nccwpck_require__(92941);
+exports.nxProjectGraph = (0, path_1.join)(cache_directory_1.projectGraphCacheDirectory, 'project-graph.json');
+exports.nxFileMap = (0, path_1.join)(cache_directory_1.projectGraphCacheDirectory, 'file-map.json');
+function ensureCacheDirectory() {
+    try {
+        if (!(0, fs_1.existsSync)(cache_directory_1.projectGraphCacheDirectory)) {
+            (0, fs_extra_1.ensureDirSync)(cache_directory_1.projectGraphCacheDirectory);
         }
-        if (condition.includes('!=')) {
-            const [conditionKey, conditionValue] = condition.split('!=');
-            const useTags = tags.filter((tag) => tag.startsWith(`${conditionKey}=`));
-            // If the project does not have any tags with the condition key it's allowed
-            if (useTags.length === 0) {
-                return true;
-            }
-            return useTags.some((tag) => {
-                return tag.split('=').pop().trim() !== conditionValue.trim();
-            }, []);
+    }
+    catch (e) {
+        /*
+         * @jeffbcross: Node JS docs recommend against checking for existence of directory immediately before creating it.
+         * Instead, just try to create the directory and handle the error.
+         *
+         * We ran into race conditions when running scripts concurrently, where multiple scripts were
+         * arriving here simultaneously, checking for directory existence, then trying to create the directory simultaneously.
+         *
+         * In this case, we're creating the directory. If the operation failed, we ensure that the directory
+         * exists before continuing (or raise an exception).
+         */
+        if (!(0, fileutils_1.directoryExists)(cache_directory_1.projectGraphCacheDirectory)) {
+            throw new Error(`Failed to create directory: ${cache_directory_1.projectGraphCacheDirectory}`);
         }
-        else {
-            const [conditionKey, conditionValue] = condition.split('=');
-            return tags.some((tag) => {
-                const [key, value] = tag.split('=');
-                if (conditionKey !== key) {
-                    return false;
-                }
-                return conditionValue.trim() === value.trim();
-            });
+    }
+}
+exports.ensureCacheDirectory = ensureCacheDirectory;
+function readFileMapCache() {
+    perf_hooks_1.performance.mark('read cache:start');
+    ensureCacheDirectory();
+    let data = null;
+    try {
+        if ((0, fileutils_1.fileExists)(exports.nxFileMap)) {
+            data = (0, fileutils_1.readJsonFile)(exports.nxFileMap);
         }
     }
-    else {
-        return tags.some((tag) => tag === condition);
+    catch (error) {
+        console.log(`Error reading '${exports.nxFileMap}'. Continue the process without the cache.`);
+        console.log(error);
     }
+    perf_hooks_1.performance.mark('read cache:end');
+    perf_hooks_1.performance.measure('read cache', 'read cache:start', 'read cache:end');
+    return data ?? null;
 }
-function cleanLogConditions(conditions) {
-    return conditions.map((condition) => {
-        if (condition.includes(',')) {
-            return condition.split(',').map((subCondition) => subCondition.trim())
-                .join(' AND ');
+exports.readFileMapCache = readFileMapCache;
+function readProjectGraphCache() {
+    perf_hooks_1.performance.mark('read project-graph:start');
+    ensureCacheDirectory();
+    let data = null;
+    try {
+        if ((0, fileutils_1.fileExists)(exports.nxProjectGraph)) {
+            data = (0, fileutils_1.readJsonFile)(exports.nxProjectGraph);
         }
-        return condition;
-    }).join(' OR ');
+    }
+    catch (error) {
+        console.log(`Error reading '${exports.nxProjectGraph}'. Continue the process without the cache.`);
+        console.log(error);
+    }
+    perf_hooks_1.performance.mark('read project-graph:end');
+    perf_hooks_1.performance.measure('read cache', 'read project-graph:start', 'read project-graph:end');
+    return data ?? null;
 }
-exports.cleanLogConditions = cleanLogConditions;
-function hasOneOfRequiredTags(projectName, tags, requiresOnOfTheseTagConditions) {
-    if (!requiresOnOfTheseTagConditions || requiresOnOfTheseTagConditions.length === 0) {
+exports.readProjectGraphCache = readProjectGraphCache;
+function createProjectFileMapCache(nxJson, packageJsonDeps, fileMap, tsConfig) {
+    const nxJsonPlugins = getNxJsonPluginsData(nxJson, packageJsonDeps);
+    const newValue = {
+        version: '6.0',
+        nxVersion: versions_1.nxVersion,
+        deps: packageJsonDeps, // TODO(v19): We can remove this in favor of nxVersion
+        // compilerOptions may not exist, especially for package-based repos
+        pathMappings: tsConfig?.compilerOptions?.paths || {},
+        nxJsonPlugins,
+        pluginsConfig: nxJson?.pluginsConfig,
+        fileMap,
+    };
+    return newValue;
+}
+exports.createProjectFileMapCache = createProjectFileMapCache;
+function writeCache(cache, projectGraph) {
+    perf_hooks_1.performance.mark('write cache:start');
+    let retry = 1;
+    let done = false;
+    do {
+        // write first to a unique temporary filename and then do a
+        // rename of the file to the correct filename
+        // this is to avoid any problems with half-written files
+        // in case of crash and/or partially written files due
+        // to multiple parallel processes reading and writing this file
+        const unique = (Math.random().toString(16) + '0000000').slice(2, 10);
+        const tmpProjectGraphPath = `${exports.nxProjectGraph}~${unique}`;
+        const tmpFileMapPath = `${exports.nxFileMap}~${unique}`;
+        try {
+            (0, fileutils_1.writeJsonFile)(tmpProjectGraphPath, projectGraph);
+            (0, fs_extra_1.renameSync)(tmpProjectGraphPath, exports.nxProjectGraph);
+            (0, fileutils_1.writeJsonFile)(tmpFileMapPath, cache);
+            (0, fs_extra_1.renameSync)(tmpFileMapPath, exports.nxFileMap);
+            done = true;
+        }
+        catch (err) {
+            if (err instanceof Error) {
+                console.log(`ERROR (${retry}) when writing \n${err.message}\n${err.stack}`);
+            }
+            else {
+                console.log(`ERROR  (${retry}) unknown error when writing ${exports.nxProjectGraph} and ${exports.nxFileMap}`);
+            }
+            ++retry;
+        }
+    } while (!done && retry < 5);
+    perf_hooks_1.performance.mark('write cache:end');
+    perf_hooks_1.performance.measure('write cache', 'write cache:start', 'write cache:end');
+}
+exports.writeCache = writeCache;
+function shouldRecomputeWholeGraph(cache, packageJsonDeps, projects, nxJson, tsConfig) {
+    if (cache.version !== '6.0') {
         return true;
     }
-    if (!tags || tags.length === 0) {
-        return false;
+    if (cache.nxVersion !== versions_1.nxVersion) {
+        return true;
     }
-    const hasMatch = requiresOnOfTheseTagConditions.some((condition) => hasTagMatchingCondition(condition, tags));
-    if (!hasMatch) {
-        core.debug(`[${projectName}]: Does not match any of the provided condition "${cleanLogConditions(requiresOnOfTheseTagConditions)}"`);
+    // we have a cached project that is no longer present
+    const cachedNodes = Object.keys(cache.fileMap.projectFileMap);
+    if (cachedNodes.some((p) => projects[p] === undefined)) {
+        return true;
     }
-    return hasMatch;
+    // a path mapping for an existing project has changed
+    if (Object.keys(cache.pathMappings).some((t) => {
+        const cached = cache.pathMappings && cache.pathMappings[t]
+            ? JSON.stringify(cache.pathMappings[t])
+            : undefined;
+        const notCached = tsConfig?.compilerOptions?.paths && tsConfig?.compilerOptions?.paths[t]
+            ? JSON.stringify(tsConfig.compilerOptions.paths[t])
+            : undefined;
+        return cached !== notCached;
+    })) {
+        return true;
+    }
+    // a new plugin has been added
+    if (JSON.stringify(getNxJsonPluginsData(nxJson, packageJsonDeps)) !==
+        JSON.stringify(cache.nxJsonPlugins)) {
+        return true;
+    }
+    if (JSON.stringify(nxJson?.pluginsConfig) !==
+        JSON.stringify(cache.pluginsConfig)) {
+        return true;
+    }
+    return false;
+}
+exports.shouldRecomputeWholeGraph = shouldRecomputeWholeGraph;
+/*
+This can only be invoked when the list of projects is either the same
+or new projects have been added, so every project in the cache has a corresponding
+project in fileMap
+*/
+function extractCachedFileData(fileMap, c) {
+    const filesToProcess = {
+        nonProjectFiles: [],
+        projectFileMap: {},
+    };
+    const cachedFileData = {
+        nonProjectFiles: {},
+        projectFileMap: {},
+    };
+    const currentProjects = Object.keys(fileMap.projectFileMap).filter((name) => fileMap.projectFileMap[name].length > 0);
+    currentProjects.forEach((p) => {
+        processProjectNode(p, c.fileMap.projectFileMap, cachedFileData.projectFileMap, filesToProcess.projectFileMap, fileMap);
+    });
+    processNonProjectFiles(c.fileMap.nonProjectFiles, fileMap.nonProjectFiles, filesToProcess.nonProjectFiles, cachedFileData.nonProjectFiles);
+    return {
+        filesToProcess,
+        cachedFileData,
+    };
+}
+exports.extractCachedFileData = extractCachedFileData;
+function processNonProjectFiles(cachedFiles, nonProjectFiles, filesToProcess, cachedFileData) {
+    const cachedHashMap = new Map(cachedFiles.map((f) => [f.file, f]));
+    for (const f of nonProjectFiles) {
+        const cachedFile = cachedHashMap.get(f.file);
+        if (!cachedFile || cachedFile.hash !== f.hash) {
+            filesToProcess.push(f);
+        }
+        else {
+            cachedFileData[f.file] = cachedFile;
+        }
+    }
+}
+function processProjectNode(projectName, cachedFileMap, cachedFileData, filesToProcess, { projectFileMap }) {
+    if (!cachedFileMap[projectName]) {
+        filesToProcess[projectName] = projectFileMap[projectName];
+        return;
+    }
+    const fileDataFromCache = {};
+    for (let f of cachedFileMap[projectName]) {
+        fileDataFromCache[f.file] = f;
+    }
+    if (!cachedFileData[projectName]) {
+        cachedFileData[projectName] = {};
+    }
+    for (let f of projectFileMap[projectName]) {
+        const fromCache = fileDataFromCache[f.file];
+        if (fromCache && fromCache.hash == f.hash) {
+            cachedFileData[projectName][f.file] = fromCache;
+        }
+        else {
+            if (!filesToProcess[projectName]) {
+                filesToProcess[projectName] = [];
+            }
+            filesToProcess[projectName].push(f);
+        }
+    }
+}
+function getNxJsonPluginsData(nxJson, packageJsonDeps) {
+    return (nxJson?.plugins || []).map((p) => {
+        const [plugin, options] = typeof p === 'string' ? [p] : [p.plugin, p.options];
+        return {
+            name: plugin,
+            version: packageJsonDeps[plugin],
+            options,
+        };
+    });
 }
-exports.hasOneOfRequiredTags = hasOneOfRequiredTags;
-
-
-/***/ }),
-
-/***/ 10498:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
-
-module.exports = require(__nccwpck_require__.ab + "nx.darwin-arm64.node")
-
-/***/ }),
-
-/***/ 40679:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
-
-module.exports = require(__nccwpck_require__.ab + "swc.darwin-arm64.node")
-
-/***/ }),
-
-/***/ 3479:
-/***/ ((module) => {
-
-module.exports = eval("require")("./nx.android-arm-eabi.node");
-
-
-/***/ }),
-
-/***/ 68615:
-/***/ ((module) => {
-
-module.exports = eval("require")("./nx.android-arm64.node");
-
-
-/***/ }),
-
-/***/ 64639:
-/***/ ((module) => {
-
-module.exports = eval("require")("./nx.darwin-arm64.node");
-
-
-/***/ }),
-
-/***/ 99829:
-/***/ ((module) => {
-
-module.exports = eval("require")("./nx.darwin-universal.node");
-
-
-/***/ }),
-
-/***/ 79412:
-/***/ ((module) => {
-
-module.exports = eval("require")("./nx.darwin-x64.node");
-
-
-/***/ }),
-
-/***/ 7678:
-/***/ ((module) => {
-
-module.exports = eval("require")("./nx.freebsd-x64.node");
-
-
-/***/ }),
-
-/***/ 50050:
-/***/ ((module) => {
-
-module.exports = eval("require")("./nx.linux-arm-gnueabihf.node");
-
-
-/***/ }),
-
-/***/ 90179:
-/***/ ((module) => {
-
-module.exports = eval("require")("./nx.linux-arm64-gnu.node");
-
-
-/***/ }),
-
-/***/ 32938:
-/***/ ((module) => {
-
-module.exports = eval("require")("./nx.linux-arm64-musl.node");
-
-
-/***/ }),
-
-/***/ 46888:
-/***/ ((module) => {
-
-module.exports = eval("require")("./nx.linux-x64-gnu.node");
-
-
-/***/ }),
-
-/***/ 67479:
-/***/ ((module) => {
-
-module.exports = eval("require")("./nx.linux-x64-musl.node");
-
-
-/***/ }),
-
-/***/ 80491:
-/***/ ((module) => {
-
-module.exports = eval("require")("./nx.win32-arm64-msvc.node");
-
-
-/***/ }),
-
-/***/ 75836:
-/***/ ((module) => {
-
-module.exports = eval("require")("./nx.win32-ia32-msvc.node");
-
-
-/***/ }),
-
-/***/ 23186:
-/***/ ((module) => {
-
-module.exports = eval("require")("./nx.win32-x64-msvc.node");
-
-
-/***/ }),
-
-/***/ 70243:
-/***/ ((module) => {
-
-module.exports = eval("require")("./swc.android-arm-eabi.node");
-
-
-/***/ }),
-
-/***/ 10849:
-/***/ ((module) => {
-
-module.exports = eval("require")("./swc.android-arm64.node");
 
 
 /***/ }),
 
-/***/ 37969:
-/***/ ((module) => {
-
-module.exports = eval("require")("./swc.darwin-arm64.node");
-
-
-/***/ }),
+/***/ 5959:
+/***/ ((__unused_webpack_module, exports) => {
 
-/***/ 9172:
-/***/ ((module) => {
+"use strict";
 
-module.exports = eval("require")("./swc.darwin-x64.node");
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.withDeps = exports.pruneExternalNodes = exports.isNpmProject = exports.filterNodes = exports.reverse = void 0;
+const reverseMemo = new Map();
+/**
+ * Returns a new project graph where all the edges are reversed.
+ *
+ * For instance, if project A depends on B, in the reversed graph
+ * B will depend on A.
+ */
+function reverse(graph) {
+    const resultFromMemo = reverseMemo.get(graph);
+    if (resultFromMemo) {
+        return resultFromMemo;
+    }
+    const result = {
+        ...graph,
+        nodes: { ...graph.nodes },
+        externalNodes: { ...graph.externalNodes },
+        dependencies: {},
+    };
+    Object.keys(graph.nodes).forEach((n) => (result.dependencies[n] = []));
+    // we need to keep external node's reverse dependencies to trace our route back
+    if (graph.externalNodes) {
+        Object.keys(graph.externalNodes).forEach((n) => (result.dependencies[n] = []));
+    }
+    Object.values(graph.dependencies).forEach((byProject) => {
+        byProject.forEach((dep) => {
+            const dependency = result.dependencies[dep.target];
+            if (dependency) {
+                dependency.push({
+                    type: dep.type,
+                    source: dep.target,
+                    target: dep.source,
+                });
+            }
+        });
+    });
+    reverseMemo.set(graph, result);
+    reverseMemo.set(result, graph);
+    return result;
+}
+exports.reverse = reverse;
+function filterNodes(predicate) {
+    return (original) => {
+        const graph = { nodes: {}, dependencies: {} };
+        const added = new Set();
+        Object.values(original.nodes).forEach((n) => {
+            if (!predicate || predicate(n)) {
+                graph.nodes[n.name] = n;
+                graph.dependencies[n.name] = [];
+                added.add(n.name);
+            }
+        });
+        Object.values(original.dependencies).forEach((ds) => {
+            ds.forEach((d) => {
+                if (added.has(d.source) && added.has(d.target)) {
+                    graph.dependencies[d.source].push(d);
+                }
+            });
+        });
+        return graph;
+    };
+}
+exports.filterNodes = filterNodes;
+function isNpmProject(project) {
+    return project?.type === 'npm';
+}
+exports.isNpmProject = isNpmProject;
+exports.pruneExternalNodes = filterNodes();
+function withDeps(original, subsetNodes) {
+    const res = { nodes: {}, dependencies: {} };
+    const visitedNodes = [];
+    const visitedEdges = [];
+    Object.values(subsetNodes).forEach(recurNodes);
+    Object.values(subsetNodes).forEach(recurEdges);
+    return res;
+    // ---------------------------------------------------------------------------
+    function recurNodes(node) {
+        if (visitedNodes.indexOf(node.name) > -1)
+            return;
+        res.nodes[node.name] = node;
+        if (!res.dependencies[node.name]) {
+            res.dependencies[node.name] = [];
+        }
+        visitedNodes.push(node.name);
+        original.dependencies[node.name].forEach((n) => {
+            if (original.nodes[n.target]) {
+                recurNodes(original.nodes[n.target]);
+            }
+        });
+    }
+    function recurEdges(node) {
+        if (visitedEdges.indexOf(node.name) > -1)
+            return;
+        visitedEdges.push(node.name);
+        const ds = original.dependencies[node.name];
+        ds.forEach((n) => {
+            if (!original.nodes[n.target]) {
+                return;
+            }
+            if (!res.dependencies[n.source]) {
+                res.dependencies[n.source] = [];
+            }
+            res.dependencies[n.source].push(n);
+        });
+        ds.forEach((n) => {
+            if (original.nodes[n.target]) {
+                recurEdges(original.nodes[n.target]);
+            }
+        });
+    }
+}
+exports.withDeps = withDeps;
 
 
 /***/ }),
 
-/***/ 71487:
-/***/ ((module) => {
-
-module.exports = eval("require")("./swc.freebsd-x64.node");
-
-
-/***/ }),
+/***/ 80862:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
-/***/ 21651:
-/***/ ((module) => {
+"use strict";
 
-module.exports = eval("require")("./swc.linux-arm-gnueabihf.node");
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.validateDependency = exports.ProjectGraphBuilder = void 0;
+/**
+ * Builder for adding nodes and dependencies to a {@link ProjectGraph}
+ */
+const project_graph_1 = __nccwpck_require__(2184);
+const build_project_graph_1 = __nccwpck_require__(71553);
+/**
+ * A class which builds up a project graph
+ * @deprecated The {@link ProjectGraphProcessor} has been deprecated. Use a {@link CreateNodes} and/or a {@link CreateDependencies} instead. This will be removed in Nx 19.
+ */
+class ProjectGraphBuilder {
+    constructor(graph, projectFileMap, nonProjectFiles) {
+        this.removedEdges = {};
+        if (!projectFileMap || !nonProjectFiles) {
+            const fileMap = (0, build_project_graph_1.getFileMap)().fileMap;
+            projectFileMap ??= fileMap.projectFileMap;
+            nonProjectFiles ??= fileMap.nonProjectFiles;
+        }
+        if (graph) {
+            this.graph = graph;
+            this.projectFileMap = projectFileMap;
+            this.nonProjectFiles = nonProjectFiles;
+        }
+        else {
+            this.graph = {
+                nodes: {},
+                externalNodes: {},
+                dependencies: {},
+            };
+            this.projectFileMap = projectFileMap || {};
+            this.nonProjectFiles = nonProjectFiles || [];
+        }
+    }
+    /**
+     * Merges the nodes and dependencies of p into the built project graph.
+     */
+    mergeProjectGraph(p) {
+        this.graph.nodes = { ...this.graph.nodes, ...p.nodes };
+        this.graph.externalNodes = {
+            ...this.graph.externalNodes,
+            ...p.externalNodes,
+        };
+        this.graph.dependencies = { ...this.graph.dependencies, ...p.dependencies };
+    }
+    /**
+     * Adds a project node to the project graph
+     */
+    addNode(node) {
+        // Check if project with the same name already exists
+        if (this.graph.nodes[node.name]) {
+            // Throw if existing project is of a different type
+            if (this.graph.nodes[node.name].type !== node.type) {
+                throw new Error(`Multiple projects are named "${node.name}". One is of type "${node.type}" and the other is of type "${this.graph.nodes[node.name].type}". Please resolve the conflicting project names.`);
+            }
+        }
+        this.graph.nodes[node.name] = node;
+    }
+    /**
+     * Removes a node and all of its dependency edges from the graph
+     */
+    removeNode(name) {
+        if (!this.graph.nodes[name] && !this.graph.externalNodes[name]) {
+            throw new Error(`There is no node named: "${name}"`);
+        }
+        this.removeDependenciesWithNode(name);
+        if (this.graph.nodes[name]) {
+            delete this.graph.nodes[name];
+        }
+        else {
+            delete this.graph.externalNodes[name];
+        }
+    }
+    /**
+     * Adds a external node to the project graph
+     */
+    addExternalNode(node) {
+        // Check if project with the same name already exists
+        if (this.graph.externalNodes[node.name]) {
+            throw new Error(`Multiple projects are named "${node.name}". One has version "${node.data.version}" and the other has version "${this.graph.externalNodes[node.name].data.version}". Please resolve the conflicting package names.`);
+        }
+        this.graph.externalNodes[node.name] = node;
+    }
+    /**
+     * Adds static dependency from source project to target project
+     */
+    addStaticDependency(sourceProjectName, targetProjectName, sourceProjectFile) {
+        this.addDependency(sourceProjectName, targetProjectName, project_graph_1.DependencyType.static, sourceProjectFile);
+    }
+    /**
+     * Adds dynamic dependency from source project to target project
+     */
+    addDynamicDependency(sourceProjectName, targetProjectName, sourceProjectFile) {
+        this.addDependency(sourceProjectName, targetProjectName, project_graph_1.DependencyType.dynamic, sourceProjectFile);
+    }
+    /**
+     * Adds implicit dependency from source project to target project
+     */
+    addImplicitDependency(sourceProjectName, targetProjectName) {
+        this.addDependency(sourceProjectName, targetProjectName, project_graph_1.DependencyType.implicit);
+    }
+    /**
+     * Removes a dependency from source project to target project
+     */
+    removeDependency(sourceProjectName, targetProjectName) {
+        if (sourceProjectName === targetProjectName) {
+            return;
+        }
+        if (!this.graph.nodes[sourceProjectName]) {
+            throw new Error(`Source project does not exist: ${sourceProjectName}`);
+        }
+        if (!this.graph.nodes[targetProjectName] &&
+            !this.graph.externalNodes[targetProjectName]) {
+            throw new Error(`Target project does not exist: ${targetProjectName}`);
+        }
+        // this.graph.dependencies[sourceProjectName] = this.graph.dependencies[
+        //   sourceProjectName
+        // ].filter((d) => d.target !== targetProjectName);
+        if (!this.removedEdges[sourceProjectName]) {
+            this.removedEdges[sourceProjectName] = new Set();
+        }
+        this.removedEdges[sourceProjectName].add(targetProjectName);
+    }
+    /**
+     * Add an explicit dependency from a file in source project to target project
+     * @deprecated this method will be removed in v17. Use {@link addStaticDependency} or {@link addDynamicDependency} instead
+     */
+    addExplicitDependency(sourceProjectName, sourceProjectFile, targetProjectName) {
+        this.addStaticDependency(sourceProjectName, targetProjectName, sourceProjectFile);
+    }
+    /**
+     * Set version of the project graph
+     */
+    setVersion(version) {
+        this.graph.version = version;
+    }
+    getUpdatedProjectGraph() {
+        for (const sourceProject of Object.keys(this.graph.nodes)) {
+            const alreadySetTargetProjects = this.calculateAlreadySetTargetDeps(sourceProject);
+            this.graph.dependencies[sourceProject] = [
+                ...alreadySetTargetProjects.values(),
+            ].flatMap((depsMap) => [...depsMap.values()]);
+            const fileDeps = this.calculateTargetDepsFromFiles(sourceProject);
+            for (const [targetProject, types] of fileDeps.entries()) {
+                // only add known nodes
+                if (!this.graph.nodes[targetProject] &&
+                    !this.graph.externalNodes[targetProject]) {
+                    continue;
+                }
+                for (const type of types.values()) {
+                    if (!alreadySetTargetProjects.has(targetProject) ||
+                        !alreadySetTargetProjects.get(targetProject).has(type)) {
+                        if (!this.removedEdges[sourceProject] ||
+                            !this.removedEdges[sourceProject].has(targetProject)) {
+                            this.graph.dependencies[sourceProject].push({
+                                source: sourceProject,
+                                target: targetProject,
+                                type,
+                            });
+                        }
+                    }
+                }
+            }
+        }
+        for (const file of this.nonProjectFiles) {
+            if (file.deps) {
+                for (const dep of file.deps) {
+                    if (!Array.isArray(dep)) {
+                        throw new Error('Cached data on non project files should be a tuple');
+                    }
+                    const [source, target, type] = dep;
+                    if (!source || !target || !type) {
+                        throw new Error('Cached dependencies for non project files should be a tuple of length 3.');
+                    }
+                    this.graph.dependencies[source].push({
+                        source,
+                        target,
+                        type,
+                    });
+                }
+            }
+        }
+        return this.graph;
+    }
+    addDependency(source, target, type, sourceFile) {
+        if (source === target) {
+            return;
+        }
+        validateDependency({
+            source,
+            target,
+            type,
+            sourceFile,
+        }, {
+            externalNodes: this.graph.externalNodes,
+            fileMap: {
+                projectFileMap: this.projectFileMap,
+                nonProjectFiles: this.nonProjectFiles,
+            },
+            // the validators only really care about the keys on this.
+            projects: this.graph.nodes,
+            filesToProcess: null,
+            nxJsonConfiguration: null,
+            workspaceRoot: null,
+        });
+        if (!this.graph.dependencies[source]) {
+            this.graph.dependencies[source] = [];
+        }
+        const isDuplicate = !!this.graph.dependencies[source].find((d) => d.target === target && d.type === type);
+        if (sourceFile) {
+            let fileData = getProjectFileData(source, sourceFile, this.projectFileMap);
+            const isProjectFileData = !!fileData;
+            fileData ??= getNonProjectFileData(sourceFile, this.nonProjectFiles);
+            if (!fileData.deps) {
+                fileData.deps = [];
+            }
+            if (!fileData.deps.find((t) => (0, project_graph_1.fileDataDepTarget)(t) === target && (0, project_graph_1.fileDataDepType)(t) === type)) {
+                const dep = isProjectFileData
+                    ? type === 'static'
+                        ? target
+                        : [target, type]
+                    : [source, target, type];
+                fileData.deps.push(dep);
+            }
+        }
+        else if (!isDuplicate) {
+            // only add to dependencies section if the source file is not specified
+            // and not already added
+            this.graph.dependencies[source].push({
+                source: source,
+                target: target,
+                type,
+            });
+        }
+    }
+    removeDependenciesWithNode(name) {
+        // remove all source dependencies
+        delete this.graph.dependencies[name];
+        // remove all target dependencies
+        for (const dependencies of Object.values(this.graph.dependencies)) {
+            for (const [index, { source, target }] of dependencies.entries()) {
+                if (target === name) {
+                    const deps = this.graph.dependencies[source];
+                    this.graph.dependencies[source] = [
+                        ...deps.slice(0, index),
+                        ...deps.slice(index + 1),
+                    ];
+                    if (this.graph.dependencies[source].length === 0) {
+                        delete this.graph.dependencies[source];
+                    }
+                }
+            }
+        }
+    }
+    calculateTargetDepsFromFiles(sourceProject) {
+        const fileDeps = new Map();
+        const files = this.projectFileMap[sourceProject] || [];
+        if (!files) {
+            return fileDeps;
+        }
+        for (let f of files) {
+            if (f.deps) {
+                for (let d of f.deps) {
+                    const target = (0, project_graph_1.fileDataDepTarget)(d);
+                    if (!fileDeps.has(target)) {
+                        fileDeps.set(target, new Set([(0, project_graph_1.fileDataDepType)(d)]));
+                    }
+                    else {
+                        fileDeps.get(target).add((0, project_graph_1.fileDataDepType)(d));
+                    }
+                }
+            }
+        }
+        return fileDeps;
+    }
+    calculateAlreadySetTargetDeps(sourceProject) {
+        const alreadySetTargetProjects = new Map();
+        if (this.graph.dependencies[sourceProject]) {
+            const removed = this.removedEdges[sourceProject];
+            for (const d of this.graph.dependencies[sourceProject]) {
+                // static and dynamic dependencies of internal projects
+                // will be rebuilt based on the file dependencies
+                // we only need to keep the implicit dependencies
+                if (d.type === project_graph_1.DependencyType.implicit && !removed?.has(d.target)) {
+                    if (!alreadySetTargetProjects.has(d.target)) {
+                        alreadySetTargetProjects.set(d.target, new Map([[d.type, d]]));
+                    }
+                    else {
+                        alreadySetTargetProjects.get(d.target).set(d.type, d);
+                    }
+                }
+            }
+        }
+        return alreadySetTargetProjects;
+    }
+}
+exports.ProjectGraphBuilder = ProjectGraphBuilder;
+/**
+ * A function to validate dependencies in a {@link CreateDependencies} function
+ * @throws If the dependency is invalid.
+ */
+function validateDependency(dependency, ctx) {
+    if (dependency.type === project_graph_1.DependencyType.implicit) {
+        validateImplicitDependency(dependency, ctx);
+    }
+    else if (dependency.type === project_graph_1.DependencyType.dynamic) {
+        validateDynamicDependency(dependency, ctx);
+    }
+    else if (dependency.type === project_graph_1.DependencyType.static) {
+        validateStaticDependency(dependency, ctx);
+    }
+    validateCommonDependencyRules(dependency, ctx);
+}
+exports.validateDependency = validateDependency;
+function validateCommonDependencyRules(d, { externalNodes, projects, fileMap }) {
+    if (!projects[d.source] && !externalNodes[d.source]) {
+        throw new Error(`Source project does not exist: ${d.source}`);
+    }
+    if (!projects[d.target] &&
+        !externalNodes[d.target] &&
+        !('sourceFile' in d && d.sourceFile)) {
+        throw new Error(`Target project does not exist: ${d.target}`);
+    }
+    if (externalNodes[d.source] && projects[d.target]) {
+        throw new Error(`External projects can't depend on internal projects`);
+    }
+    if ('sourceFile' in d && d.sourceFile) {
+        if (projects[d.source]) {
+            // Throws if source file is not a valid file within the source project.
+            // We can pass empty array for all workspace files here, since its not checked by the impl.
+            // We need all workspace files in here for the TODO comment though, so lets figure that out.
+            getFileData(d.source, d.sourceFile, projects, externalNodes, fileMap.projectFileMap, fileMap.nonProjectFiles);
+        }
+    }
+}
+function validateImplicitDependency(d, { externalNodes }) {
+    if (externalNodes[d.source]) {
+        throw new Error(`External projects can't have "implicit" dependencies`);
+    }
+}
+function validateDynamicDependency(d, { externalNodes }) {
+    if (externalNodes[d.source]) {
+        throw new Error(`External projects can't have "dynamic" dependencies`);
+    }
+    // dynamic dependency is always bound to a file
+    if (!d.sourceFile) {
+        throw new Error(`Source project file is required for "dynamic" dependencies`);
+    }
+}
+function validateStaticDependency(d, { projects }) {
+    // internal nodes must provide sourceProjectFile when creating static dependency
+    // externalNodes do not have sourceProjectFile
+    if (projects[d.source] && !d.sourceFile) {
+        throw new Error(`Source project file is required`);
+    }
+}
+function getProjectFileData(source, sourceFile, fileMap) {
+    let fileData = (fileMap[source] || []).find((f) => f.file === sourceFile);
+    if (fileData) {
+        return fileData;
+    }
+}
+function getNonProjectFileData(sourceFile, files) {
+    const fileData = files.find((f) => f.file === sourceFile);
+    if (!fileData) {
+        throw new Error(`Source file "${sourceFile}" does not exist in the workspace.`);
+    }
+    return fileData;
+}
+function getFileData(source, sourceFile, projects, externalNodes, fileMap, nonProjectFiles) {
+    const sourceProject = projects[source];
+    const matchingExternalNode = externalNodes[source];
+    if (!sourceProject && !matchingExternalNode) {
+        throw new Error(`Source project is not a project node: ${sourceProject}`);
+    }
+    return (getProjectFileData(source, sourceFile, fileMap) ??
+        getNonProjectFileData(sourceFile, nonProjectFiles));
+}
 
 
 /***/ }),
 
-/***/ 37857:
-/***/ ((module) => {
+/***/ 61371:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
-module.exports = eval("require")("./swc.linux-arm64-gnu.node");
+"use strict";
 
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.createProjectGraphAndSourceMapsAsync = exports.createProjectGraphAsync = exports.buildProjectGraphAndSourceMapsWithoutDaemon = exports.readProjectsConfigurationFromProjectGraph = exports.readCachedProjectConfiguration = exports.readCachedProjectGraph = void 0;
+const nx_deps_cache_1 = __nccwpck_require__(57074);
+const build_project_graph_1 = __nccwpck_require__(71553);
+const output_1 = __nccwpck_require__(1737);
+const tmp_dir_1 = __nccwpck_require__(78543);
+const strip_indents_1 = __nccwpck_require__(98487);
+const client_1 = __nccwpck_require__(36638);
+const fileutils_1 = __nccwpck_require__(83851);
+const workspace_root_1 = __nccwpck_require__(86708);
+const perf_hooks_1 = __nccwpck_require__(4074);
+const retrieve_workspace_files_1 = __nccwpck_require__(14249);
+const nx_json_1 = __nccwpck_require__(53619);
+const nx_plugin_1 = __nccwpck_require__(84141);
+/**
+ * Synchronously reads the latest cached copy of the workspace's ProjectGraph.
+ * @throws {Error} if there is no cached ProjectGraph to read from
+ */
+function readCachedProjectGraph() {
+    const projectGraphCache = (0, nx_deps_cache_1.readProjectGraphCache)();
+    if (!projectGraphCache) {
+        const angularSpecificError = (0, fileutils_1.fileExists)(`${workspace_root_1.workspaceRoot}/angular.json`)
+            ? (0, strip_indents_1.stripIndents) `
+      Make sure invoke 'node ./decorate-angular-cli.js' in your postinstall script.
+      The decorated CLI will compute the project graph.
+      'ng --help' should say 'Smart Monorepos · Fast CI'.
+      `
+            : '';
+        throw new Error((0, strip_indents_1.stripIndents) `
+      [readCachedProjectGraph] ERROR: No cached ProjectGraph is available.
 
-/***/ }),
+      If you are leveraging \`readCachedProjectGraph()\` directly then you will need to refactor your usage to first ensure that
+      the ProjectGraph is created by calling \`await createProjectGraphAsync()\` somewhere before attempting to read the data.
 
-/***/ 2168:
-/***/ ((module) => {
+      If you encounter this error as part of running standard \`nx\` commands then please open an issue on https://github.com/nrwl/nx
 
-module.exports = eval("require")("./swc.linux-arm64-musl.node");
+      ${angularSpecificError}
+    `);
+    }
+    return projectGraphCache;
+}
+exports.readCachedProjectGraph = readCachedProjectGraph;
+function readCachedProjectConfiguration(projectName) {
+    const graph = readCachedProjectGraph();
+    const node = graph.nodes[projectName];
+    try {
+        return node.data;
+    }
+    catch (e) {
+        throw new Error(`Cannot find project: '${projectName}' in your workspace.`);
+    }
+}
+exports.readCachedProjectConfiguration = readCachedProjectConfiguration;
+/**
+ * Get the {@link ProjectsConfigurations} from the {@link ProjectGraph}
+ */
+function readProjectsConfigurationFromProjectGraph(projectGraph) {
+    return {
+        projects: Object.fromEntries(Object.entries(projectGraph.nodes).map(([project, { data }]) => [
+            project,
+            data,
+        ])),
+        version: 2,
+    };
+}
+exports.readProjectsConfigurationFromProjectGraph = readProjectsConfigurationFromProjectGraph;
+async function buildProjectGraphAndSourceMapsWithoutDaemon() {
+    const nxJson = (0, nx_json_1.readNxJson)();
+    perf_hooks_1.performance.mark('retrieve-project-configurations:start');
+    const { projects, externalNodes, sourceMaps, projectRootMap } = await (0, retrieve_workspace_files_1.retrieveProjectConfigurations)(workspace_root_1.workspaceRoot, nxJson);
+    perf_hooks_1.performance.mark('retrieve-project-configurations:end');
+    perf_hooks_1.performance.mark('retrieve-workspace-files:start');
+    const { allWorkspaceFiles, fileMap, rustReferences } = await (0, retrieve_workspace_files_1.retrieveWorkspaceFiles)(workspace_root_1.workspaceRoot, projectRootMap);
+    perf_hooks_1.performance.mark('retrieve-workspace-files:end');
+    const cacheEnabled = process.env.NX_CACHE_PROJECT_GRAPH !== 'false';
+    perf_hooks_1.performance.mark('build-project-graph-using-project-file-map:start');
+    const projectGraph = (await (0, build_project_graph_1.buildProjectGraphUsingProjectFileMap)(projects, externalNodes, fileMap, allWorkspaceFiles, rustReferences, cacheEnabled ? (0, nx_deps_cache_1.readFileMapCache)() : null, cacheEnabled)).projectGraph;
+    perf_hooks_1.performance.mark('build-project-graph-using-project-file-map:end');
+    (0, nx_plugin_1.unregisterPluginTSTranspiler)();
+    return { projectGraph, sourceMaps };
+}
+exports.buildProjectGraphAndSourceMapsWithoutDaemon = buildProjectGraphAndSourceMapsWithoutDaemon;
+function handleProjectGraphError(opts, e) {
+    if (opts.exitOnError) {
+        const lines = e.message.split('\n');
+        output_1.output.error({
+            title: lines[0],
+            bodyLines: lines.slice(1),
+        });
+        if (process.env.NX_VERBOSE_LOGGING === 'true') {
+            console.error(e);
+        }
+        process.exit(1);
+    }
+    else {
+        throw e;
+    }
+}
+/**
+ * Computes and returns a ProjectGraph.
+ *
+ * Nx will compute the graph either in a daemon process or in the current process.
+ *
+ * Nx will compute it in the current process if:
+ * * The process is running in CI (CI env variable is to true or other common variables used by CI providers are set).
+ * * It is running in the docker container.
+ * * The daemon process is disabled because of the previous error when starting the daemon.
+ * * `NX_DAEMON` is set to `false`.
+ * * `useDaemonProcess` is set to false in the options of the tasks runner inside `nx.json`
+ *
+ * `NX_DAEMON` env variable takes precedence:
+ * * If it is set to true, the daemon will always be used.
+ * * If it is set to false, the graph will always be computed in the current process.
+ *
+ * Tip: If you want to debug project graph creation, run your command with NX_DAEMON=false.
+ *
+ * Nx uses two layers of caching: the information about explicit dependencies stored on the disk and the information
+ * stored in the daemon process. To reset both run: `nx reset`.
+ */
+async function createProjectGraphAsync(opts = {
+    exitOnError: false,
+    resetDaemonClient: false,
+}) {
+    const projectGraphAndSourceMaps = await createProjectGraphAndSourceMapsAsync(opts);
+    return projectGraphAndSourceMaps.projectGraph;
+}
+exports.createProjectGraphAsync = createProjectGraphAsync;
+async function createProjectGraphAndSourceMapsAsync(opts = {
+    exitOnError: false,
+    resetDaemonClient: false,
+}) {
+    perf_hooks_1.performance.mark('create-project-graph-async:start');
+    if (!client_1.daemonClient.enabled()) {
+        try {
+            const res = await buildProjectGraphAndSourceMapsWithoutDaemon();
+            perf_hooks_1.performance.measure('create-project-graph-async >> retrieve-project-configurations', 'retrieve-project-configurations:start', 'retrieve-project-configurations:end');
+            perf_hooks_1.performance.measure('create-project-graph-async >> retrieve-workspace-files', 'retrieve-workspace-files:start', 'retrieve-workspace-files:end');
+            perf_hooks_1.performance.measure('create-project-graph-async >> build-project-graph-using-project-file-map', 'build-project-graph-using-project-file-map:start', 'build-project-graph-using-project-file-map:end');
+            perf_hooks_1.performance.mark('create-project-graph-async:end');
+            perf_hooks_1.performance.measure('create-project-graph-async', 'create-project-graph-async:start', 'create-project-graph-async:end');
+            return res;
+        }
+        catch (e) {
+            handleProjectGraphError(opts, e);
+        }
+    }
+    else {
+        try {
+            const projectGraphAndSourceMaps = await client_1.daemonClient.getProjectGraphAndSourceMaps();
+            if (opts.resetDaemonClient) {
+                client_1.daemonClient.reset();
+            }
+            perf_hooks_1.performance.mark('create-project-graph-async:end');
+            perf_hooks_1.performance.measure('create-project-graph-async', 'create-project-graph-async:start', 'create-project-graph-async:end');
+            return projectGraphAndSourceMaps;
+        }
+        catch (e) {
+            if (e.message.indexOf('inotify_add_watch') > -1) {
+                // common errors with the daemon due to OS settings (cannot watch all the files available)
+                output_1.output.note({
+                    title: `Unable to start Nx Daemon due to the limited amount of inotify watches, continuing without the daemon.`,
+                    bodyLines: [
+                        'For more information read: https://askubuntu.com/questions/1088272/inotify-add-watch-failed-no-space-left-on-device',
+                        'Nx Daemon is going to be disabled until you run "nx reset".',
+                    ],
+                });
+                (0, tmp_dir_1.markDaemonAsDisabled)();
+                return buildProjectGraphAndSourceMapsWithoutDaemon();
+            }
+            if (e.internalDaemonError) {
+                const errorLogFile = (0, tmp_dir_1.writeDaemonLogs)(e.message);
+                output_1.output.warn({
+                    title: `Nx Daemon was not able to compute the project graph.`,
+                    bodyLines: [
+                        `Log file with the error: ${errorLogFile}`,
+                        `Please file an issue at https://github.com/nrwl/nx`,
+                        'Nx Daemon is going to be disabled until you run "nx reset".',
+                    ],
+                });
+                (0, tmp_dir_1.markDaemonAsDisabled)();
+                return buildProjectGraphAndSourceMapsWithoutDaemon();
+            }
+            handleProjectGraphError(opts, e);
+        }
+    }
+}
+exports.createProjectGraphAndSourceMapsAsync = createProjectGraphAndSourceMapsAsync;
 
 
 /***/ }),
 
-/***/ 13546:
-/***/ ((module) => {
-
-module.exports = eval("require")("./swc.linux-x64-gnu.node");
-
-
-/***/ }),
+/***/ 71074:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
-/***/ 3394:
-/***/ ((module) => {
+"use strict";
 
-module.exports = eval("require")("./swc.linux-x64-musl.node");
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.buildAllWorkspaceFiles = void 0;
+const perf_hooks_1 = __nccwpck_require__(4074);
+function buildAllWorkspaceFiles(projectFileMap, globalFiles) {
+    perf_hooks_1.performance.mark('get-all-workspace-files:start');
+    let fileData = Object.values(projectFileMap).flat();
+    fileData = fileData
+        .concat(globalFiles)
+        .sort((a, b) => a.file.localeCompare(b.file));
+    perf_hooks_1.performance.mark('get-all-workspace-files:end');
+    perf_hooks_1.performance.measure('get-all-workspace-files', 'get-all-workspace-files:start', 'get-all-workspace-files:end');
+    return fileData;
+}
+exports.buildAllWorkspaceFiles = buildAllWorkspaceFiles;
 
 
 /***/ }),
 
-/***/ 91156:
-/***/ ((module) => {
-
-module.exports = eval("require")("./swc.win32-arm64-msvc.node");
-
-
-/***/ }),
+/***/ 46329:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
-/***/ 12445:
-/***/ ((module) => {
+"use strict";
 
-module.exports = eval("require")("./swc.win32-ia32-msvc.node");
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.normalizeProjectRoot = exports.findProjectForPath = exports.createProjectRootMappings = exports.createProjectRootMappingsFromProjectConfigurations = void 0;
+const path_1 = __nccwpck_require__(71017);
+const path_2 = __nccwpck_require__(38270);
+/**
+ * This creates a map of project roots to project names to easily look up the project of a file
+ * @param projects This is the map of project configurations commonly found in "workspace.json"
+ */
+function createProjectRootMappingsFromProjectConfigurations(projects) {
+    const projectRootMappings = new Map();
+    for (const projectName of Object.keys(projects)) {
+        const root = projects[projectName].root;
+        projectRootMappings.set(normalizeProjectRoot(root), projectName);
+    }
+    return projectRootMappings;
+}
+exports.createProjectRootMappingsFromProjectConfigurations = createProjectRootMappingsFromProjectConfigurations;
+/**
+ * This creates a map of project roots to project names to easily look up the project of a file
+ * @param nodes This is the nodes from the project graph
+ */
+function createProjectRootMappings(nodes) {
+    const projectRootMappings = new Map();
+    for (const projectName of Object.keys(nodes)) {
+        let root = nodes[projectName].data.root;
+        projectRootMappings.set(normalizeProjectRoot(root), projectName);
+    }
+    return projectRootMappings;
+}
+exports.createProjectRootMappings = createProjectRootMappings;
+/**
+ * Locates a project in projectRootMap based on a file within it
+ * @param filePath path that is inside of projectName. This should be relative from the workspace root
+ * @param projectRootMap Map Use {@link createProjectRootMappings} to create this
+ */
+function findProjectForPath(filePath, projectRootMap) {
+    /**
+     * Project Mappings are in UNIX-style file paths
+     * Windows may pass Win-style file paths
+     * Ensure filePath is in UNIX-style
+     */
+    let currentPath = (0, path_2.normalizePath)(filePath);
+    for (; currentPath != (0, path_1.dirname)(currentPath); currentPath = (0, path_1.dirname)(currentPath)) {
+        const p = projectRootMap.get(currentPath);
+        if (p) {
+            return p;
+        }
+    }
+    return projectRootMap.get(currentPath);
+}
+exports.findProjectForPath = findProjectForPath;
+function normalizeProjectRoot(root) {
+    root = root === '' ? '.' : root;
+    return root && root.endsWith('/') ? root.substring(0, root.length - 1) : root;
+}
+exports.normalizeProjectRoot = normalizeProjectRoot;
 
 
 /***/ }),
 
-/***/ 1779:
-/***/ ((module) => {
-
-module.exports = eval("require")("./swc.win32-x64-msvc.node");
-
-
-/***/ }),
+/***/ 85251:
+/***/ ((__unused_webpack_module, exports) => {
 
-/***/ 63182:
-/***/ ((module) => {
+"use strict";
 
-module.exports = eval("require")("@nx/nx-android-arm-eabi");
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.applyImplicitDependencies = void 0;
+function applyImplicitDependencies(projects, builder) {
+    Object.keys(projects).forEach((source) => {
+        const p = projects[source];
+        if (p.implicitDependencies && p.implicitDependencies.length > 0) {
+            p.implicitDependencies.forEach((target) => {
+                if (target.startsWith('!')) {
+                    builder.removeDependency(source, target.slice(1));
+                }
+                else {
+                    builder.addImplicitDependency(source, target);
+                }
+            });
+        }
+    });
+}
+exports.applyImplicitDependencies = applyImplicitDependencies;
 
 
 /***/ }),
 
-/***/ 96024:
-/***/ ((module) => {
-
-module.exports = eval("require")("@nx/nx-android-arm64");
-
-
-/***/ }),
+/***/ 44852:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
-/***/ 51641:
-/***/ ((module) => {
+"use strict";
 
-module.exports = eval("require")("@nx/nx-darwin-universal");
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.normalizeImplicitDependencies = exports.normalizeProjectTargets = exports.normalizeProjectNodes = void 0;
+const find_matching_projects_1 = __nccwpck_require__(21521);
+const project_configuration_utils_1 = __nccwpck_require__(33190);
+async function normalizeProjectNodes(ctx, builder) {
+    const toAdd = [];
+    // Sorting projects by name to make sure that the order of projects in the graph is deterministic.
+    // This is important to ensure that expanded properties referencing projects (e.g. implicit dependencies)
+    // are also deterministic, and thus don't cause the calculated project configuration hash to shift.
+    const projects = Object.keys(ctx.projects).sort();
+    // Used for expanding implicit dependencies (e.g. `@proj/*` or `tag:foo`)
+    const partialProjectGraphNodes = projects.reduce((graph, project) => {
+        const projectConfiguration = ctx.projects[project];
+        graph[project] = {
+            name: project,
+            type: projectConfiguration.projectType === 'library' ? 'lib' : 'app', // missing fallback to `e2e`
+            data: {
+                ...projectConfiguration,
+            },
+        };
+        return graph;
+    }, {});
+    for (const key of projects) {
+        const p = ctx.projects[key];
+        p.implicitDependencies = normalizeImplicitDependencies(key, p.implicitDependencies, partialProjectGraphNodes);
+        p.targets = normalizeProjectTargets(p, key);
+        // TODO: remove in v16
+        const projectType = p.projectType === 'application'
+            ? key.endsWith('-e2e') || key === 'e2e'
+                ? 'e2e'
+                : 'app'
+            : 'lib';
+        const tags = ctx.projects?.[key]?.tags || [];
+        toAdd.push({
+            name: key,
+            type: projectType,
+            data: {
+                ...p,
+                tags,
+            },
+        });
+    }
+    // Sort by root directory length (do we need this?)
+    toAdd.sort((a, b) => {
+        if (!a.data.root)
+            return -1;
+        if (!b.data.root)
+            return -1;
+        return a.data.root.length > b.data.root.length ? -1 : 1;
+    });
+    toAdd.forEach((n) => {
+        builder.addNode({
+            name: n.name,
+            type: n.type,
+            data: n.data,
+        });
+    });
+}
+exports.normalizeProjectNodes = normalizeProjectNodes;
+/**
+ * Apply target defaults and normalization
+ */
+function normalizeProjectTargets(project, projectName) {
+    // Any node on the graph will have a targets object, it just may be empty
+    const targets = project.targets ?? {};
+    for (const target in targets) {
+        if (!targets[target].command && !targets[target].executor) {
+            delete targets[target];
+            continue;
+        }
+        targets[target].options = (0, project_configuration_utils_1.resolveNxTokensInOptions)(targets[target].options, project, `${projectName}:${target}`);
+        targets[target].configurations ??= {};
+        for (const configuration in targets[target].configurations) {
+            targets[target].configurations[configuration] = (0, project_configuration_utils_1.resolveNxTokensInOptions)(targets[target].configurations[configuration], project, `${projectName}:${target}:${configuration}`);
+        }
+    }
+    return targets;
+}
+exports.normalizeProjectTargets = normalizeProjectTargets;
+function normalizeImplicitDependencies(source, implicitDependencies, projects) {
+    if (!implicitDependencies?.length) {
+        return implicitDependencies ?? [];
+    }
+    const matches = (0, find_matching_projects_1.findMatchingProjects)(implicitDependencies, projects);
+    return (matches
+        .filter((x) => x !== source)
+        // implicit dependencies that start with ! should hang around, to be processed by
+        // implicit-project-dependencies.ts after explicit deps are added to graph.
+        .concat(implicitDependencies.filter((x) => x.startsWith('!'))));
+}
+exports.normalizeImplicitDependencies = normalizeImplicitDependencies;
 
 
 /***/ }),
 
-/***/ 85775:
-/***/ ((module) => {
-
-module.exports = eval("require")("@nx/nx-darwin-x64");
-
-
-/***/ }),
+/***/ 33190:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
-/***/ 64160:
-/***/ ((module) => {
+"use strict";
 
-module.exports = eval("require")("@nx/nx-freebsd-x64");
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.readTargetDefaultsForTarget = exports.resolveNxTokensInOptions = exports.isCompatibleTarget = exports.mergeTargetConfigurations = exports.readProjectConfigurationsFromRootMap = exports.buildProjectsConfigurationsFromProjectPathsAndPlugins = exports.mergeProjectConfigurationIntoRootMap = void 0;
+const logger_1 = __nccwpck_require__(39299);
+const fileutils_1 = __nccwpck_require__(83851);
+const workspace_root_1 = __nccwpck_require__(86708);
+const target_defaults_plugin_1 = __nccwpck_require__(50280);
+const minimatch_1 = __nccwpck_require__(55224);
+const path_1 = __nccwpck_require__(71017);
+function mergeProjectConfigurationIntoRootMap(projectRootMap, project, configurationSourceMaps, sourceInformation, 
+// This function is used when reading project configuration
+// in generators, where we don't want to do this.
+skipCommandNormalization) {
+    if (configurationSourceMaps && !configurationSourceMaps[project.root]) {
+        configurationSourceMaps[project.root] = {};
+    }
+    const sourceMap = configurationSourceMaps?.[project.root];
+    let matchingProject = projectRootMap.get(project.root);
+    if (!matchingProject) {
+        projectRootMap.set(project.root, {
+            root: project.root,
+        });
+        matchingProject = projectRootMap.get(project.root);
+        if (sourceMap) {
+            sourceMap[`root`] = sourceInformation;
+        }
+    }
+    // This handles top level properties that are overwritten.
+    // e.g. `srcRoot`, `projectType`, or other fields that shouldn't be extended
+    // Note: `name` is set specifically here to keep it from changing. The name is
+    // always determined by the first inference plugin to ID a project, unless it has
+    // a project.json in which case it was already updated above.
+    const updatedProjectConfiguration = {
+        ...matchingProject,
+        ...project,
+    };
+    if (sourceMap) {
+        for (const property in project) {
+            sourceMap[`${property}`] = sourceInformation;
+        }
+    }
+    // The next blocks handle properties that should be themselves merged (e.g. targets, tags, and implicit dependencies)
+    if (project.tags) {
+        updatedProjectConfiguration.tags = Array.from(new Set((matchingProject.tags ?? []).concat(project.tags)));
+        if (sourceMap) {
+            project.tags.forEach((tag) => {
+                sourceMap[`tags.${tag}`] = sourceInformation;
+            });
+        }
+    }
+    if (project.implicitDependencies) {
+        updatedProjectConfiguration.implicitDependencies = (matchingProject.implicitDependencies ?? []).concat(project.implicitDependencies);
+        if (sourceMap) {
+            project.implicitDependencies.forEach((implicitDependency) => {
+                sourceMap[`implicitDependencies.${implicitDependency}`] =
+                    sourceInformation;
+            });
+        }
+    }
+    if (project.generators) {
+        // Start with generators config in new project.
+        updatedProjectConfiguration.generators = { ...project.generators };
+        if (sourceMap) {
+            for (const generator in project.generators) {
+                sourceMap[`generators.${generator}`] = sourceInformation;
+                for (const property in project.generators[generator]) {
+                    sourceMap[`generators.${generator}.${property}`] = sourceInformation;
+                }
+            }
+        }
+        if (matchingProject.generators) {
+            // For each generator that was already defined, shallow merge the options.
+            // Project contains the new info, so it has higher priority.
+            for (const generator in matchingProject.generators) {
+                updatedProjectConfiguration.generators[generator] = {
+                    ...matchingProject.generators[generator],
+                    ...project.generators[generator],
+                };
+            }
+        }
+    }
+    if (project.namedInputs) {
+        updatedProjectConfiguration.namedInputs = {
+            ...matchingProject.namedInputs,
+            ...project.namedInputs,
+        };
+        if (sourceMap) {
+            for (const namedInput in project.namedInputs) {
+                sourceMap[`namedInputs.${namedInput}`] = sourceInformation;
+            }
+        }
+    }
+    if (project.targets) {
+        // We merge the targets with special handling, so clear this back to the
+        // targets as defined originally before merging.
+        updatedProjectConfiguration.targets = matchingProject?.targets ?? {};
+        // For each target defined in the new config
+        for (const targetName in project.targets) {
+            // Always set source map info for the target, but don't overwrite info already there
+            // if augmenting an existing target.
+            const target = project.targets?.[targetName];
+            if (sourceMap && !target?.[target_defaults_plugin_1.ONLY_MODIFIES_EXISTING_TARGET]) {
+                sourceMap[`targets.${targetName}`] = sourceInformation;
+            }
+            // If ONLY_MODIFIES_EXISTING_TARGET is true, and its not on the matching project
+            // we shouldn't merge its info into the graph
+            if (target?.[target_defaults_plugin_1.ONLY_MODIFIES_EXISTING_TARGET] &&
+                !matchingProject.targets?.[targetName]) {
+                continue;
+            }
+            // We don't want the symbol to live on past the merge process
+            if (target?.[target_defaults_plugin_1.ONLY_MODIFIES_EXISTING_TARGET])
+                delete target?.[target_defaults_plugin_1.ONLY_MODIFIES_EXISTING_TARGET];
+            updatedProjectConfiguration.targets[targetName] =
+                mergeTargetConfigurations(skipCommandNormalization
+                    ? target
+                    : resolveCommandSyntacticSugar(target, project.root), matchingProject.targets?.[targetName], sourceMap, sourceInformation, `targets.${targetName}`);
+        }
+    }
+    projectRootMap.set(updatedProjectConfiguration.root, updatedProjectConfiguration);
+}
+exports.mergeProjectConfigurationIntoRootMap = mergeProjectConfigurationIntoRootMap;
+/**
+ * Transforms a list of project paths into a map of project configurations.
+ *
+ * @param nxJson The NxJson configuration
+ * @param projectFiles A list of files identified as projects
+ * @param plugins The plugins that should be used to infer project configuration
+ * @param root The workspace root
+ */
+function buildProjectsConfigurationsFromProjectPathsAndPlugins(nxJson, projectFiles, // making this parameter allows devkit to pick up newly created projects
+plugins, root = workspace_root_1.workspaceRoot) {
+    const results = [];
+    // We iterate over plugins first - this ensures that plugins specified first take precedence.
+    for (const { plugin, options } of plugins) {
+        const [pattern, createNodes] = plugin.createNodes ?? [];
+        const pluginResults = [];
+        performance.mark(`${plugin.name}:createNodes - start`);
+        if (!pattern) {
+            continue;
+        }
+        // Set this globally to allow plugins to know if they are being called from the project graph creation
+        global.NX_GRAPH_CREATION = true;
+        for (const file of projectFiles) {
+            performance.mark(`${plugin.name}:createNodes:${file} - start`);
+            if ((0, minimatch_1.minimatch)(file, pattern, { dot: true })) {
+                try {
+                    let r = createNodes(file, options, {
+                        nxJsonConfiguration: nxJson,
+                        workspaceRoot: root,
+                    });
+                    if (r instanceof Promise) {
+                        pluginResults.push(r
+                            .catch((e) => {
+                            performance.mark(`${plugin.name}:createNodes:${file} - end`);
+                            throw new CreateNodesError(`Unable to create nodes for ${file} using plugin ${plugin.name}.`, e);
+                        })
+                            .then((r) => {
+                            performance.mark(`${plugin.name}:createNodes:${file} - end`);
+                            performance.measure(`${plugin.name}:createNodes:${file}`, `${plugin.name}:createNodes:${file} - start`, `${plugin.name}:createNodes:${file} - end`);
+                            return { ...r, file, pluginName: plugin.name };
+                        }));
+                    }
+                    else {
+                        performance.mark(`${plugin.name}:createNodes:${file} - end`);
+                        performance.measure(`${plugin.name}:createNodes:${file}`, `${plugin.name}:createNodes:${file} - start`, `${plugin.name}:createNodes:${file} - end`);
+                        pluginResults.push({
+                            ...r,
+                            file,
+                            pluginName: plugin.name,
+                        });
+                    }
+                }
+                catch (e) {
+                    throw new CreateNodesError(`Unable to create nodes for ${file} using plugin ${plugin.name}.`, e);
+                }
+            }
+        }
+        // If there are no promises (counter undefined) or all promises have resolved (counter === 0)
+        results.push(Promise.all(pluginResults).then((results) => {
+            delete global.NX_GRAPH_CREATION;
+            performance.mark(`${plugin.name}:createNodes - end`);
+            performance.measure(`${plugin.name}:createNodes`, `${plugin.name}:createNodes - start`, `${plugin.name}:createNodes - end`);
+            return results;
+        }));
+    }
+    return Promise.all(results).then((results) => {
+        performance.mark('createNodes:merge - start');
+        const projectRootMap = new Map();
+        const externalNodes = {};
+        const configurationSourceMaps = {};
+        for (const result of results.flat()) {
+            const { projects: projectNodes, externalNodes: pluginExternalNodes, file, pluginName, } = result;
+            for (const node in projectNodes) {
+                const project = {
+                    root: node,
+                    ...projectNodes[node],
+                };
+                try {
+                    mergeProjectConfigurationIntoRootMap(projectRootMap, project, configurationSourceMaps, [file, pluginName]);
+                }
+                catch (e) {
+                    throw new CreateNodesError(`Unable to merge project information for "${project.root}" from ${result.file} using plugin ${result.pluginName}.`, e);
+                }
+            }
+            Object.assign(externalNodes, pluginExternalNodes);
+        }
+        const projects = readProjectConfigurationsFromRootMap(projectRootMap);
+        const rootMap = createRootMap(projectRootMap);
+        performance.mark('createNodes:merge - end');
+        performance.measure('createNodes:merge', 'createNodes:merge - start', 'createNodes:merge - end');
+        return {
+            projects,
+            externalNodes,
+            rootMap,
+            sourceMaps: configurationSourceMaps,
+        };
+    });
+}
+exports.buildProjectsConfigurationsFromProjectPathsAndPlugins = buildProjectsConfigurationsFromProjectPathsAndPlugins;
+function readProjectConfigurationsFromRootMap(projectRootMap) {
+    const projects = {};
+    // If there are projects that have the same name, that is an error.
+    // This object tracks name -> (all roots of projects with that name)
+    // to provide better error messaging.
+    const errors = new Map();
+    for (const [root, configuration] of projectRootMap.entries()) {
+        if (!configuration.name) {
+            try {
+                const { name } = (0, fileutils_1.readJsonFile)((0, path_1.join)(root, 'package.json'));
+                configuration.name = name;
+            }
+            catch {
+                throw new Error(`Project at ${root} has no name provided.`);
+            }
+        }
+        if (configuration.name in projects) {
+            let rootErrors = errors.get(configuration.name) ?? [
+                projects[configuration.name].root,
+            ];
+            rootErrors.push(root);
+            errors.set(configuration.name, rootErrors);
+        }
+        else {
+            projects[configuration.name] = configuration;
+        }
+    }
+    if (errors.size > 0) {
+        throw new Error([
+            `The following projects are defined in multiple locations:`,
+            ...Array.from(errors.entries()).map(([project, roots]) => [`- ${project}: `, ...roots.map((r) => `  - ${r}`)].join('\n')),
+            '',
+            "To fix this, set a unique name for each project in a project.json inside the project's root. If the project does not currently have a project.json, you can create one that contains only a name.",
+        ].join('\n'));
+    }
+    return projects;
+}
+exports.readProjectConfigurationsFromRootMap = readProjectConfigurationsFromRootMap;
+class CreateNodesError extends Error {
+    constructor(msg, cause) {
+        const message = `${msg} ${!cause
+            ? ''
+            : cause instanceof Error
+                ? `\n\n\t Inner Error: ${cause.stack}`
+                : cause}`;
+        // These errors are thrown during a JS callback which is invoked via rust.
+        // The errors messaging gets lost in the rust -> js -> rust transition, but
+        // logging the error here will ensure that it is visible in the console.
+        console.error(message);
+        super(message, { cause });
+    }
+}
+/**
+ * Merges two targets.
+ *
+ * Most properties from `target` will overwrite any properties from `baseTarget`.
+ * Options and configurations are treated differently - they are merged together if the executor definition is compatible.
+ *
+ * @param target The target definition with higher priority
+ * @param baseTarget The target definition that should be overwritten. Can be undefined, in which case the target is returned as-is.
+ * @param projectConfigSourceMap The source map to be filled with metadata about where each property came from
+ * @param sourceInformation The metadata about where the new target was defined
+ * @param targetIdentifier The identifier for the target to merge, used for source map
+ * @returns A merged target configuration
+ */
+function mergeTargetConfigurations(target, baseTarget, projectConfigSourceMap, sourceInformation, targetIdentifier) {
+    const { configurations: defaultConfigurations, options: defaultOptions, ...baseTargetProperties } = baseTarget ?? {};
+    // Target is "compatible", e.g. executor is defined only once or is the same
+    // in both places. This means that it is likely safe to merge
+    const isCompatible = isCompatibleTarget(baseTargetProperties, target);
+    if (!isCompatible && projectConfigSourceMap) {
+        // if the target is not compatible, we will simply override the options
+        // we have to delete old entries from the source map
+        for (const key in projectConfigSourceMap) {
+            if (key.startsWith(`${targetIdentifier}`)) {
+                delete projectConfigSourceMap[key];
+            }
+        }
+    }
+    // merge top level properties if they're compatible
+    const result = {
+        ...(isCompatible ? baseTargetProperties : {}),
+        ...target,
+    };
+    // record top level properties in source map
+    if (projectConfigSourceMap) {
+        projectConfigSourceMap[targetIdentifier] = sourceInformation;
+        // record root level target properties to source map
+        for (const targetProperty in target) {
+            const targetPropertyId = `${targetIdentifier}.${targetProperty}`;
+            projectConfigSourceMap[targetPropertyId] = sourceInformation;
+        }
+    }
+    // merge options if there are any
+    // if the targets aren't compatible, we simply discard the old options during the merge
+    if (target.options || defaultOptions) {
+        result.options = mergeOptions(target.options, isCompatible ? defaultOptions : undefined, projectConfigSourceMap, sourceInformation, targetIdentifier);
+    }
+    // merge configurations if there are any
+    // if the targets aren't compatible, we simply discard the old configurations during the merge
+    if (target.configurations || defaultConfigurations) {
+        result.configurations = mergeConfigurations(target.configurations, isCompatible ? defaultConfigurations : undefined, projectConfigSourceMap, sourceInformation, targetIdentifier);
+    }
+    return result;
+}
+exports.mergeTargetConfigurations = mergeTargetConfigurations;
+/**
+ * Checks if targets options are compatible - used when merging configurations
+ * to avoid merging options for @nx/js:tsc into something like @nx/webpack:webpack.
+ *
+ * If the executors are both specified and don't match, the options aren't considered
+ * "compatible" and shouldn't be merged.
+ */
+function isCompatibleTarget(a, b) {
+    const oneHasNoExecutor = !a.executor || !b.executor;
+    const bothHaveSameExecutor = a.executor === b.executor;
+    if (oneHasNoExecutor)
+        return true;
+    if (!bothHaveSameExecutor)
+        return false;
+    const isRunCommands = a.executor === 'nx:run-commands';
+    if (isRunCommands) {
+        const aCommand = a.options?.command ?? a.options?.commands.join(' && ');
+        const bCommand = b.options?.command ?? b.options?.commands.join(' && ');
+        const oneHasNoCommand = !aCommand || !bCommand;
+        const hasSameCommand = aCommand === bCommand;
+        return oneHasNoCommand || hasSameCommand;
+    }
+    const isRunScript = a.executor === 'nx:run-script';
+    if (isRunScript) {
+        const aScript = a.options?.script;
+        const bScript = b.options?.script;
+        const oneHasNoScript = !aScript || !bScript;
+        const hasSameScript = aScript === bScript;
+        return oneHasNoScript || hasSameScript;
+    }
+    return true;
+}
+exports.isCompatibleTarget = isCompatibleTarget;
+function mergeConfigurations(newConfigurations, baseConfigurations, projectConfigSourceMap, sourceInformation, targetIdentifier) {
+    const mergedConfigurations = {};
+    const configurations = new Set([
+        ...Object.keys(baseConfigurations ?? {}),
+        ...Object.keys(newConfigurations ?? {}),
+    ]);
+    for (const configuration of configurations) {
+        mergedConfigurations[configuration] = {
+            ...(baseConfigurations?.[configuration] ?? {}),
+            ...(newConfigurations?.[configuration] ?? {}),
+        };
+    }
+    // record new configurations & configuration properties in source map
+    if (projectConfigSourceMap) {
+        for (const newConfiguration in newConfigurations) {
+            projectConfigSourceMap[`${targetIdentifier}.configurations.${newConfiguration}`] = sourceInformation;
+            for (const configurationProperty in newConfigurations[newConfiguration]) {
+                projectConfigSourceMap[`${targetIdentifier}.configurations.${newConfiguration}.${configurationProperty}`] = sourceInformation;
+            }
+        }
+    }
+    return mergedConfigurations;
+}
+function mergeOptions(newOptions, baseOptions, projectConfigSourceMap, sourceInformation, targetIdentifier) {
+    const mergedOptions = {
+        ...(baseOptions ?? {}),
+        ...(newOptions ?? {}),
+    };
+    // record new options & option properties in source map
+    if (projectConfigSourceMap) {
+        for (const newOption in newOptions) {
+            projectConfigSourceMap[`${targetIdentifier}.options.${newOption}`] =
+                sourceInformation;
+        }
+    }
+    return mergedOptions;
+}
+function resolveNxTokensInOptions(object, project, key) {
+    const result = Array.isArray(object) ? [...object] : { ...object };
+    for (let [opt, value] of Object.entries(object ?? {})) {
+        if (typeof value === 'string') {
+            const workspaceRootMatch = /^(\{workspaceRoot\}\/?)/.exec(value);
+            if (workspaceRootMatch?.length) {
+                value = value.replace(workspaceRootMatch[0], '');
+            }
+            if (value.includes('{workspaceRoot}')) {
+                throw new Error(`${logger_1.NX_PREFIX} The {workspaceRoot} token is only valid at the beginning of an option. (${key})`);
+            }
+            value = value.replace(/\{projectRoot\}/g, project.root);
+            result[opt] = value.replace(/\{projectName\}/g, project.name);
+        }
+        else if (typeof value === 'object' && value) {
+            result[opt] = resolveNxTokensInOptions(value, project, [key, opt].join('.'));
+        }
+    }
+    return result;
+}
+exports.resolveNxTokensInOptions = resolveNxTokensInOptions;
+function readTargetDefaultsForTarget(targetName, targetDefaults, executor) {
+    if (executor) {
+        // If an executor is defined in project.json, defaults should be read
+        // from the most specific key that matches that executor.
+        // e.g. If executor === run-commands, and the target is named build:
+        // Use, use nx:run-commands if it is present
+        // If not, use build if it is present.
+        const key = [executor, targetName].find((x) => targetDefaults?.[x]);
+        return key ? targetDefaults?.[key] : null;
+    }
+    else {
+        // If the executor is not defined, the only key we have is the target name.
+        return targetDefaults?.[targetName];
+    }
+}
+exports.readTargetDefaultsForTarget = readTargetDefaultsForTarget;
+function createRootMap(projectRootMap) {
+    const map = {};
+    for (const [projectRoot, { name: projectName }] of projectRootMap) {
+        map[projectRoot] = projectName;
+    }
+    return map;
+}
+function resolveCommandSyntacticSugar(target, key) {
+    const { command, ...config } = target ?? {};
+    if (!command) {
+        return target;
+    }
+    if (config.executor) {
+        throw new Error(`${logger_1.NX_PREFIX} Project at ${key} should not have executor and command both configured.`);
+    }
+    else {
+        return {
+            ...config,
+            executor: 'nx:run-commands',
+            options: {
+                ...config.options,
+                command: command,
+            },
+        };
+    }
+}
 
 
 /***/ }),
 
-/***/ 8429:
-/***/ ((module) => {
-
-module.exports = eval("require")("@nx/nx-linux-arm-gnueabihf");
-
-
-/***/ }),
+/***/ 14249:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
-/***/ 36708:
-/***/ ((module) => {
+"use strict";
 
-module.exports = eval("require")("@nx/nx-linux-arm64-gnu");
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.configurationGlobs = exports.createProjectConfigurations = exports.retrieveProjectConfigurationsWithoutPluginInference = exports.retrieveProjectConfigurationPaths = exports.retrieveProjectConfigurationsWithAngularProjects = exports.retrieveProjectConfigurations = exports.retrieveWorkspaceFiles = void 0;
+const perf_hooks_1 = __nccwpck_require__(4074);
+const installation_directory_1 = __nccwpck_require__(98584);
+const angular_json_1 = __nccwpck_require__(44050);
+const nx_json_1 = __nccwpck_require__(53619);
+const package_json_workspaces_1 = __nccwpck_require__(65286);
+const project_configuration_utils_1 = __nccwpck_require__(33190);
+const nx_plugin_1 = __nccwpck_require__(84141);
+const project_json_1 = __nccwpck_require__(76877);
+const workspace_context_1 = __nccwpck_require__(302);
+const build_all_workspace_files_1 = __nccwpck_require__(71074);
+/**
+ * Walks the workspace directory to create the `projectFileMap`, `ProjectConfigurations` and `allWorkspaceFiles`
+ * @throws
+ * @param workspaceRoot
+ * @param nxJson
+ */
+async function retrieveWorkspaceFiles(workspaceRoot, projectRootMap) {
+    perf_hooks_1.performance.mark('native-file-deps:start');
+    perf_hooks_1.performance.mark('native-file-deps:end');
+    perf_hooks_1.performance.measure('native-file-deps', 'native-file-deps:start', 'native-file-deps:end');
+    perf_hooks_1.performance.mark('get-workspace-files:start');
+    const { projectFileMap, globalFiles, externalReferences } = (0, workspace_context_1.getNxWorkspaceFilesFromContext)(workspaceRoot, projectRootMap);
+    perf_hooks_1.performance.mark('get-workspace-files:end');
+    perf_hooks_1.performance.measure('get-workspace-files', 'get-workspace-files:start', 'get-workspace-files:end');
+    return {
+        allWorkspaceFiles: (0, build_all_workspace_files_1.buildAllWorkspaceFiles)(projectFileMap, globalFiles),
+        fileMap: {
+            projectFileMap,
+            nonProjectFiles: globalFiles,
+        },
+        rustReferences: externalReferences,
+    };
+}
+exports.retrieveWorkspaceFiles = retrieveWorkspaceFiles;
+/**
+ * Walk through the workspace and return `ProjectConfigurations`. Only use this if the projectFileMap is not needed.
+ *
+ * @param workspaceRoot
+ * @param nxJson
+ */
+async function retrieveProjectConfigurations(workspaceRoot, nxJson) {
+    const plugins = await (0, nx_plugin_1.loadNxPlugins)(nxJson?.plugins ?? [], (0, installation_directory_1.getNxRequirePaths)(workspaceRoot), workspaceRoot);
+    return _retrieveProjectConfigurations(workspaceRoot, nxJson, plugins);
+}
+exports.retrieveProjectConfigurations = retrieveProjectConfigurations;
+async function retrieveProjectConfigurationsWithAngularProjects(workspaceRoot, nxJson) {
+    const plugins = await (0, nx_plugin_1.loadNxPlugins)(nxJson?.plugins ?? [], (0, installation_directory_1.getNxRequirePaths)(workspaceRoot), workspaceRoot);
+    if ((0, angular_json_1.shouldMergeAngularProjects)(workspaceRoot, true) &&
+        !plugins.some((p) => p.plugin.name === angular_json_1.NX_ANGULAR_JSON_PLUGIN_NAME)) {
+        plugins.push({ plugin: angular_json_1.NxAngularJsonPlugin });
+    }
+    return _retrieveProjectConfigurations(workspaceRoot, nxJson, plugins);
+}
+exports.retrieveProjectConfigurationsWithAngularProjects = retrieveProjectConfigurationsWithAngularProjects;
+function _retrieveProjectConfigurations(workspaceRoot, nxJson, plugins) {
+    const globPatterns = configurationGlobs(plugins);
+    const projectFiles = (0, workspace_context_1.globWithWorkspaceContext)(workspaceRoot, globPatterns);
+    return createProjectConfigurations(workspaceRoot, nxJson, projectFiles, plugins);
+}
+function retrieveProjectConfigurationPaths(root, plugins) {
+    const projectGlobPatterns = configurationGlobs(plugins);
+    return (0, workspace_context_1.globWithWorkspaceContext)(root, projectGlobPatterns);
+}
+exports.retrieveProjectConfigurationPaths = retrieveProjectConfigurationPaths;
+const projectsWithoutPluginCache = new Map();
+// TODO: This function is called way too often, it should be optimized without this cache
+async function retrieveProjectConfigurationsWithoutPluginInference(root) {
+    const nxJson = (0, nx_json_1.readNxJson)(root);
+    const plugins = await (0, nx_plugin_1.getDefaultPlugins)(root);
+    const projectGlobPatterns = retrieveProjectConfigurationPaths(root, plugins);
+    const cacheKey = root + ',' + projectGlobPatterns.join(',');
+    if (projectsWithoutPluginCache.has(cacheKey)) {
+        return projectsWithoutPluginCache.get(cacheKey);
+    }
+    const projectFiles = (0, workspace_context_1.globWithWorkspaceContext)(root, projectGlobPatterns);
+    const { projects } = await createProjectConfigurations(root, nxJson, projectFiles, [
+        { plugin: (0, package_json_workspaces_1.getNxPackageJsonWorkspacesPlugin)(root) },
+        { plugin: project_json_1.ProjectJsonProjectsPlugin },
+    ]);
+    projectsWithoutPluginCache.set(cacheKey, projects);
+    return projects;
+}
+exports.retrieveProjectConfigurationsWithoutPluginInference = retrieveProjectConfigurationsWithoutPluginInference;
+async function createProjectConfigurations(workspaceRoot, nxJson, configFiles, plugins) {
+    perf_hooks_1.performance.mark('build-project-configs:start');
+    const { projects, externalNodes, rootMap, sourceMaps } = await (0, project_configuration_utils_1.buildProjectsConfigurationsFromProjectPathsAndPlugins)(nxJson, configFiles, plugins, workspaceRoot);
+    perf_hooks_1.performance.mark('build-project-configs:end');
+    perf_hooks_1.performance.measure('build-project-configs', 'build-project-configs:start', 'build-project-configs:end');
+    return {
+        projects,
+        externalNodes,
+        projectRootMap: rootMap,
+        sourceMaps,
+    };
+}
+exports.createProjectConfigurations = createProjectConfigurations;
+function configurationGlobs(plugins) {
+    const globPatterns = [];
+    for (const { plugin } of plugins) {
+        if (plugin.createNodes) {
+            globPatterns.push(plugin.createNodes[0]);
+        }
+    }
+    return globPatterns;
+}
+exports.configurationGlobs = configurationGlobs;
 
 
 /***/ }),
 
-/***/ 67311:
-/***/ ((module) => {
-
-module.exports = eval("require")("@nx/nx-linux-arm64-musl");
-
-
-/***/ }),
+/***/ 89208:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
-/***/ 94444:
-/***/ ((module) => {
+"use strict";
 
-module.exports = eval("require")("@nx/nx-linux-x64-gnu");
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.assertWorkspaceValidity = void 0;
+const find_matching_projects_1 = __nccwpck_require__(21521);
+const output_1 = __nccwpck_require__(1737);
+function assertWorkspaceValidity(projects, nxJson) {
+    const projectNames = Object.keys(projects);
+    const projectGraphNodes = projectNames.reduce((graph, project) => {
+        const projectConfiguration = projects[project];
+        graph[project] = {
+            name: project,
+            type: projectConfiguration.projectType === 'library' ? 'lib' : 'app', // missing fallback to `e2e`
+            data: {
+                ...projectConfiguration,
+            },
+        };
+        return graph;
+    }, {});
+    const invalidImplicitDependencies = new Map();
+    if (nxJson.implicitDependencies) {
+        output_1.output.warn({
+            title: 'Using `implicitDependencies` for global implicit dependencies configuration is no longer supported.',
+            bodyLines: [
+                'Use "namedInputs" instead. You can run "nx repair" to automatically migrate your configuration.',
+                'For more information about the usage of "namedInputs" see https://nx.dev/deprecated/global-implicit-dependencies#global-implicit-dependencies',
+            ],
+        });
+    }
+    const projectsWithNonArrayImplicitDependencies = new Map();
+    projectNames
+        .filter((projectName) => {
+        const project = projects[projectName];
+        // Report if for whatever reason, a project is configured to use implicitDependencies but it is not an array
+        if (!!project.implicitDependencies &&
+            !Array.isArray(project.implicitDependencies)) {
+            projectsWithNonArrayImplicitDependencies.set(projectName, project.implicitDependencies);
+        }
+        return (!!project.implicitDependencies &&
+            Array.isArray(project.implicitDependencies));
+    })
+        .reduce((map, projectName) => {
+        const project = projects[projectName];
+        detectAndSetInvalidProjectGlobValues(map, projectName, project.implicitDependencies, projects, projectGraphNodes);
+        return map;
+    }, invalidImplicitDependencies);
+    if (projectsWithNonArrayImplicitDependencies.size === 0 &&
+        invalidImplicitDependencies.size === 0) {
+        // No issues
+        return;
+    }
+    let message = '';
+    if (projectsWithNonArrayImplicitDependencies.size > 0) {
+        message += `The following implicitDependencies should be an array of strings:\n`;
+        projectsWithNonArrayImplicitDependencies.forEach((implicitDependencies, projectName) => {
+            message += `  ${projectName}.implicitDependencies: "${implicitDependencies}"\n`;
+        });
+        message += '\n';
+    }
+    if (invalidImplicitDependencies.size > 0) {
+        message += `The following implicitDependencies point to non-existent project(s):\n`;
+        message += [...invalidImplicitDependencies.keys()]
+            .map((key) => {
+            const projectNames = invalidImplicitDependencies.get(key);
+            return `  ${key}\n${projectNames
+                .map((projectName) => `    ${projectName}`)
+                .join('\n')}`;
+        })
+            .join('\n\n');
+    }
+    throw new Error(`Configuration Error\n${message}`);
+}
+exports.assertWorkspaceValidity = assertWorkspaceValidity;
+function detectAndSetInvalidProjectGlobValues(map, sourceName, desiredImplicitDeps, projectConfigurations, projects) {
+    const invalidProjectsOrGlobs = desiredImplicitDeps.filter((implicit) => {
+        const projectName = implicit.startsWith('!')
+            ? implicit.substring(1)
+            : implicit;
+        return !(projectConfigurations[projectName] ||
+            (0, find_matching_projects_1.findMatchingProjects)([implicit], projects).length);
+    });
+    if (invalidProjectsOrGlobs.length > 0) {
+        map.set(sourceName, invalidProjectsOrGlobs);
+    }
+}
 
 
 /***/ }),
 
-/***/ 93490:
-/***/ ((module) => {
-
-module.exports = eval("require")("@nx/nx-linux-x64-musl");
-
-
-/***/ }),
+/***/ 15120:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
-/***/ 48358:
-/***/ ((module) => {
+"use strict";
 
-module.exports = eval("require")("@nx/nx-win32-arm64-msvc");
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.projectGraphCacheDirectory = exports.cacheDirectoryForWorkspace = exports.cacheDir = void 0;
+const fs_1 = __nccwpck_require__(57147);
+const path_1 = __nccwpck_require__(71017);
+const fileutils_1 = __nccwpck_require__(83851);
+const workspace_root_1 = __nccwpck_require__(86708);
+function readCacheDirectoryProperty(root) {
+    try {
+        const nxJson = (0, fileutils_1.readJsonFile)((0, path_1.join)(root, 'nx.json'));
+        return (nxJson.cacheDirectory ??
+            nxJson.tasksRunnerOptions?.default.options.cacheDirectory);
+    }
+    catch {
+        return undefined;
+    }
+}
+function absolutePath(root, path) {
+    if ((0, path_1.isAbsolute)(path)) {
+        return path;
+    }
+    else {
+        return (0, path_1.join)(root, path);
+    }
+}
+function cacheDirectory(root, cacheDirectory) {
+    const cacheDirFromEnv = process.env.NX_CACHE_DIRECTORY;
+    if (cacheDirFromEnv) {
+        cacheDirectory = cacheDirFromEnv;
+    }
+    if (cacheDirectory) {
+        return absolutePath(root, cacheDirectory);
+    }
+    else {
+        return defaultCacheDirectory(root);
+    }
+}
+function defaultCacheDirectory(root) {
+    // If nx.json doesn't exist the repo can't utilize
+    // caching, so .nx/cache is less relevant. Lerna users
+    // that don't want to fully opt in to Nx at this time
+    // may also be caught off guard by the appearance of
+    // a .nx directory, so we are going to special case
+    // this for the time being.
+    if ((0, fs_1.existsSync)((0, path_1.join)(root, 'lerna.json')) &&
+        !(0, fs_1.existsSync)((0, path_1.join)(root, 'nx.json'))) {
+        return (0, path_1.join)(root, 'node_modules', '.cache', 'nx');
+    }
+    return (0, path_1.join)(root, '.nx', 'cache');
+}
+/**
+ * Path to the directory where Nx stores its cache and daemon-related files.
+ */
+exports.cacheDir = cacheDirectory(workspace_root_1.workspaceRoot, readCacheDirectoryProperty(workspace_root_1.workspaceRoot));
+function cacheDirectoryForWorkspace(workspaceRoot) {
+    return cacheDirectory(workspaceRoot, readCacheDirectoryProperty(workspaceRoot));
+}
+exports.cacheDirectoryForWorkspace = cacheDirectoryForWorkspace;
+exports.projectGraphCacheDirectory = absolutePath(workspace_root_1.workspaceRoot, process.env.NX_PROJECT_GRAPH_CACHE_DIRECTORY ??
+    defaultCacheDirectory(workspace_root_1.workspaceRoot));
 
 
 /***/ }),
 
-/***/ 75323:
-/***/ ((module) => {
-
-module.exports = eval("require")("@nx/nx-win32-ia32-msvc");
-
-
-/***/ }),
+/***/ 24622:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
-/***/ 37840:
-/***/ ((module) => {
+"use strict";
 
-module.exports = eval("require")("@nx/nx-win32-x64-msvc");
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.codeFrameColumns = void 0;
+// Adapted from https://raw.githubusercontent.com/babel/babel/4108524/packages/babel-code-frame/src/index.js
+const chalk = __nccwpck_require__(36662);
+/**
+ * Chalk styles for code frame token types.
+ */
+function getDefs(chalk) {
+    return {
+        gutter: chalk.grey,
+        marker: chalk.red.bold,
+        message: chalk.red.bold,
+    };
+}
+/**
+ * RegExp to test for newlines in terminal.
+ */
+const NEWLINE = /\r\n|[\n\r\u2028\u2029]/;
+/**
+ * Extract what lines should be marked and highlighted.
+ */
+function getMarkerLines(loc, source, opts = {}) {
+    const startLoc = {
+        column: 0,
+        line: -1,
+        ...loc.start,
+    };
+    const endLoc = {
+        ...startLoc,
+        ...loc.end,
+    };
+    const { linesAbove = 2, linesBelow = 3 } = opts || {};
+    const startLine = startLoc.line;
+    const startColumn = startLoc.column;
+    const endLine = endLoc.line;
+    const endColumn = endLoc.column;
+    let start = Math.max(startLine - (linesAbove + 1), 0);
+    let end = Math.min(source.length, endLine + linesBelow);
+    if (startLine === -1) {
+        start = 0;
+    }
+    if (endLine === -1) {
+        end = source.length;
+    }
+    const lineDiff = endLine - startLine;
+    const markerLines = {};
+    if (lineDiff) {
+        for (let i = 0; i <= lineDiff; i++) {
+            const lineNumber = i + startLine;
+            if (!startColumn) {
+                markerLines[lineNumber] = true;
+            }
+            else if (i === 0) {
+                const sourceLength = source[lineNumber - 1].length;
+                markerLines[lineNumber] = [startColumn, sourceLength - startColumn + 1];
+            }
+            else if (i === lineDiff) {
+                markerLines[lineNumber] = [0, endColumn];
+            }
+            else {
+                const sourceLength = source[lineNumber - i].length;
+                markerLines[lineNumber] = [0, sourceLength];
+            }
+        }
+    }
+    else {
+        if (startColumn === endColumn) {
+            if (startColumn) {
+                markerLines[startLine] = [startColumn, 0];
+            }
+            else {
+                markerLines[startLine] = true;
+            }
+        }
+        else {
+            markerLines[startLine] = [startColumn, endColumn - startColumn];
+        }
+    }
+    return { start, end, markerLines };
+}
+function codeFrameColumns(rawLines, loc, opts = {}) {
+    const defs = getDefs(chalk);
+    const lines = rawLines.split(NEWLINE);
+    const { start, end, markerLines } = getMarkerLines(loc, lines, opts);
+    const numberMaxWidth = String(end).length;
+    const highlightedLines = opts.highlight ? opts.highlight(rawLines) : rawLines;
+    let frame = highlightedLines
+        .split(NEWLINE)
+        .slice(start, end)
+        .map((line, index) => {
+        const number = start + 1 + index;
+        const paddedNumber = ` ${number}`.slice(-numberMaxWidth);
+        const gutter = ` ${paddedNumber} | `;
+        const hasMarker = markerLines[number];
+        if (hasMarker) {
+            let markerLine = '';
+            if (Array.isArray(hasMarker)) {
+                const markerSpacing = line
+                    .slice(0, Math.max(hasMarker[0] - 1, 0))
+                    .replace(/[^\t]/g, ' ');
+                const numberOfMarkers = hasMarker[1] || 1;
+                markerLine = [
+                    '\n ',
+                    defs.gutter(gutter.replace(/\d/g, ' ')),
+                    markerSpacing,
+                    defs.marker('^').repeat(numberOfMarkers),
+                ].join('');
+            }
+            return [defs.marker('>'), defs.gutter(gutter), line, markerLine].join('');
+        }
+        else {
+            return ` ${defs.gutter(gutter)}${line}`;
+        }
+    })
+        .join('\n');
+    return chalk.reset(frame);
+}
+exports.codeFrameColumns = codeFrameColumns;
 
 
 /***/ }),
 
-/***/ 39423:
-/***/ ((module) => {
-
-module.exports = eval("require")("@swc/core-android-arm-eabi");
-
-
-/***/ }),
+/***/ 22214:
+/***/ ((__unused_webpack_module, exports) => {
 
-/***/ 95833:
-/***/ ((module) => {
+"use strict";
 
-module.exports = eval("require")("@swc/core-android-arm64");
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.consumeMessagesFromSocket = void 0;
+function consumeMessagesFromSocket(callback) {
+    let message = '';
+    return (data) => {
+        const chunk = data.toString();
+        if (chunk.codePointAt(chunk.length - 1) === 4) {
+            message += chunk.substring(0, chunk.length - 1);
+            // Server may send multiple messages in one chunk, so splitting by 0x4
+            const messages = message.split('');
+            for (const splitMessage of messages) {
+                callback(splitMessage);
+            }
+            message = '';
+        }
+        else {
+            message += chunk;
+        }
+    };
+}
+exports.consumeMessagesFromSocket = consumeMessagesFromSocket;
 
 
 /***/ }),
 
-/***/ 5829:
-/***/ ((module) => {
-
-module.exports = eval("require")("@swc/core-darwin-x64");
-
-
-/***/ }),
+/***/ 83851:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
-/***/ 95212:
-/***/ ((module) => {
+"use strict";
 
-module.exports = eval("require")("@swc/core-freebsd-x64");
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.readFileIfExisting = exports.extractFileFromTarball = exports.isRelativePath = exports.createDirectory = exports.fileExists = exports.directoryExists = exports.writeJsonFile = exports.readYamlFile = exports.readJsonFile = void 0;
+const json_1 = __nccwpck_require__(8314);
+const fs_1 = __nccwpck_require__(57147);
+const path_1 = __nccwpck_require__(71017);
+const tar = __nccwpck_require__(18571);
+const zlib_1 = __nccwpck_require__(59796);
+/**
+ * Reads a JSON file and returns the object the JSON content represents.
+ *
+ * @param path A path to a file.
+ * @param options JSON parse options
+ * @returns Object the JSON content of the file represents
+ */
+function readJsonFile(path, options) {
+    const content = (0, fs_1.readFileSync)(path, 'utf-8');
+    if (options) {
+        options.endsWithNewline = content.charCodeAt(content.length - 1) === 10;
+    }
+    try {
+        return (0, json_1.parseJson)(content, options);
+    }
+    catch (e) {
+        e.message = e.message.replace('JSON', path);
+        throw e;
+    }
+}
+exports.readJsonFile = readJsonFile;
+/**
+ * Reads a YAML file and returns the object the YAML content represents.
+ *
+ * @param path A path to a file.
+ * @returns
+ */
+function readYamlFile(path, options) {
+    const content = (0, fs_1.readFileSync)(path, 'utf-8');
+    const { load } = __nccwpck_require__(45126);
+    return load(content, { ...options, filename: path });
+}
+exports.readYamlFile = readYamlFile;
+/**
+ * Serializes the given data to JSON and writes it to a file.
+ *
+ * @param path A path to a file.
+ * @param data data which should be serialized to JSON and written to the file
+ * @param options JSON serialize options
+ */
+function writeJsonFile(path, data, options) {
+    (0, fs_1.mkdirSync)((0, path_1.dirname)(path), { recursive: true });
+    const serializedJson = (0, json_1.serializeJson)(data, options);
+    const content = options?.appendNewLine
+        ? `${serializedJson}\n`
+        : serializedJson;
+    (0, fs_1.writeFileSync)(path, content, { encoding: 'utf-8' });
+}
+exports.writeJsonFile = writeJsonFile;
+/**
+ * Check if a directory exists
+ * @param path Path to directory
+ */
+function directoryExists(path) {
+    try {
+        return (0, fs_1.statSync)(path).isDirectory();
+    }
+    catch {
+        return false;
+    }
+}
+exports.directoryExists = directoryExists;
+/**
+ * Check if a file exists.
+ * @param path Path to file
+ */
+function fileExists(path) {
+    try {
+        return (0, fs_1.statSync)(path).isFile();
+    }
+    catch {
+        return false;
+    }
+}
+exports.fileExists = fileExists;
+function createDirectory(path) {
+    (0, fs_1.mkdirSync)(path, { recursive: true });
+}
+exports.createDirectory = createDirectory;
+function isRelativePath(path) {
+    return (path === '.' ||
+        path === '..' ||
+        path.startsWith('./') ||
+        path.startsWith('../'));
+}
+exports.isRelativePath = isRelativePath;
+/**
+ * Extracts a file from a given tarball to the specified destination.
+ * @param tarballPath The path to the tarball from where the file should be extracted.
+ * @param file The path to the file inside the tarball.
+ * @param destinationFilePath The destination file path.
+ * @returns True if the file was extracted successfully, false otherwise.
+ */
+async function extractFileFromTarball(tarballPath, file, destinationFilePath) {
+    return new Promise((resolve, reject) => {
+        (0, fs_1.mkdirSync)((0, path_1.dirname)(destinationFilePath), { recursive: true });
+        var tarExtractStream = tar.extract();
+        const destinationFileStream = (0, fs_1.createWriteStream)(destinationFilePath);
+        let isFileExtracted = false;
+        tarExtractStream.on('entry', function (header, stream, next) {
+            if (header.name === file) {
+                stream.pipe(destinationFileStream);
+                stream.on('end', () => {
+                    isFileExtracted = true;
+                });
+                destinationFileStream.on('close', () => {
+                    resolve(destinationFilePath);
+                });
+            }
+            stream.on('end', function () {
+                next();
+            });
+            stream.resume();
+        });
+        tarExtractStream.on('finish', function () {
+            if (!isFileExtracted) {
+                reject();
+            }
+        });
+        (0, fs_1.createReadStream)(tarballPath).pipe((0, zlib_1.createGunzip)()).pipe(tarExtractStream);
+    });
+}
+exports.extractFileFromTarball = extractFileFromTarball;
+function readFileIfExisting(path) {
+    return (0, fs_1.existsSync)(path) ? (0, fs_1.readFileSync)(path, 'utf-8') : '';
+}
+exports.readFileIfExisting = readFileIfExisting;
 
 
 /***/ }),
 
-/***/ 70593:
-/***/ ((module) => {
-
-module.exports = eval("require")("@swc/core-linux-arm-gnueabihf");
-
-
-/***/ }),
+/***/ 21521:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
-/***/ 25670:
-/***/ ((module) => {
+"use strict";
 
-module.exports = eval("require")("@swc/core-linux-arm64-gnu");
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.getMatchingStringsWithCache = exports.findMatchingProjects = void 0;
+const minimatch_1 = __nccwpck_require__(55224);
+const validPatternTypes = [
+    'name', // Pattern is based on the project's name
+    'tag', // Pattern is based on the project's tags
+    'directory', // Pattern is based on the project's root directory
+    'unlabeled', // Pattern was passed without specifying a type
+];
+const globCharacters = ['*', '|', '{', '}', '(', ')'];
+/**
+ * Find matching project names given a list of potential project names or globs.
+ *
+ * @param patterns A list of project names or globs to match against.
+ * @param projects A map of {@link ProjectGraphProjectNode} by project name.
+ * @returns
+ */
+function findMatchingProjects(patterns = [], projects) {
+    if (!patterns.length || patterns.filter((p) => p.length).length === 0) {
+        return []; // Short circuit if called with no patterns
+    }
+    const projectNames = Object.keys(projects);
+    const matchedProjects = new Set();
+    for (const stringPattern of patterns) {
+        if (!stringPattern.length) {
+            continue;
+        }
+        const pattern = parseStringPattern(stringPattern, projects);
+        // Handle wildcard with short-circuit, as its a common case with potentially
+        // large project sets and we can avoid the more expensive glob matching.
+        if (pattern.value === '*') {
+            for (const projectName of projectNames) {
+                if (pattern.exclude) {
+                    matchedProjects.delete(projectName);
+                }
+                else {
+                    matchedProjects.add(projectName);
+                }
+            }
+            continue;
+        }
+        switch (pattern.type) {
+            case 'tag': {
+                addMatchingProjectsByTag(projectNames, projects, pattern, matchedProjects);
+                continue;
+            }
+            case 'name': {
+                addMatchingProjectsByName(projectNames, projects, pattern, matchedProjects);
+                continue;
+            }
+            case 'directory': {
+                addMatchingProjectsByDirectory(projectNames, projects, pattern, matchedProjects);
+                continue;
+            }
+            // Same thing as `type:unlabeled`. If no specific type is set,
+            // we can waterfall through the different types until we find a match
+            default: {
+                // The size of the selected and excluded projects set, before we
+                // start updating it with this pattern. If the size changes, we
+                // know we found a match and can skip the other types.
+                const originalSize = matchedProjects.size;
+                addMatchingProjectsByName(projectNames, projects, pattern, matchedProjects);
+                if (matchedProjects.size !== originalSize) {
+                    // There was some match by name, don't check other types
+                    continue;
+                }
+                addMatchingProjectsByDirectory(projectNames, projects, pattern, matchedProjects);
+                if (matchedProjects.size !== originalSize) {
+                    // There was some match by directory, don't check other types
+                    // Note - this doesn't do anything currently, but preps for future
+                    // types
+                    continue;
+                }
+            }
+        }
+    }
+    return Array.from(matchedProjects);
+}
+exports.findMatchingProjects = findMatchingProjects;
+function addMatchingProjectsByDirectory(projectNames, projects, pattern, matchedProjects) {
+    for (const projectName of projectNames) {
+        const root = projects[projectName].data.root;
+        if ((0, exports.getMatchingStringsWithCache)(pattern.value, [root]).length > 0) {
+            if (pattern.exclude) {
+                matchedProjects.delete(projectName);
+            }
+            else {
+                matchedProjects.add(projectName);
+            }
+        }
+    }
+}
+function addMatchingProjectsByName(projectNames, projects, pattern, matchedProjects) {
+    if (projects[pattern.value]) {
+        if (pattern.exclude) {
+            matchedProjects.delete(pattern.value);
+        }
+        else {
+            matchedProjects.add(pattern.value);
+        }
+        return;
+    }
+    if (!globCharacters.some((c) => pattern.value.includes(c))) {
+        return;
+    }
+    const matchedProjectNames = (0, exports.getMatchingStringsWithCache)(pattern.value, projectNames);
+    for (const projectName of matchedProjectNames) {
+        if (pattern.exclude) {
+            matchedProjects.delete(projectName);
+        }
+        else {
+            matchedProjects.add(projectName);
+        }
+    }
+}
+function addMatchingProjectsByTag(projectNames, projects, pattern, matchedProjects) {
+    for (const projectName of projectNames) {
+        const tags = projects[projectName].data.tags || [];
+        if (tags.includes(pattern.value)) {
+            if (pattern.exclude) {
+                matchedProjects.delete(projectName);
+            }
+            else {
+                matchedProjects.add(projectName);
+            }
+            continue;
+        }
+        if (!globCharacters.some((c) => pattern.value.includes(c))) {
+            continue;
+        }
+        if ((0, exports.getMatchingStringsWithCache)(pattern.value, tags).length) {
+            if (pattern.exclude) {
+                matchedProjects.delete(projectName);
+            }
+            else {
+                matchedProjects.add(projectName);
+            }
+        }
+    }
+}
+function parseStringPattern(pattern, projects) {
+    const isExclude = pattern.startsWith('!');
+    // Support for things like: `!{type}:value`
+    if (isExclude) {
+        pattern = pattern.substring(1);
+    }
+    const indexOfFirstPotentialSeparator = pattern.indexOf(':');
+    // There is a project that matches directly
+    if (projects[pattern]) {
+        return { type: 'name', value: pattern, exclude: isExclude };
+        // The pattern does not contain a label
+    }
+    else if (indexOfFirstPotentialSeparator === -1) {
+        return { type: 'unlabeled', value: pattern, exclude: isExclude };
+        // The pattern may contain a label
+    }
+    else {
+        const potentialType = pattern.substring(0, indexOfFirstPotentialSeparator);
+        return {
+            type: isValidPatternType(potentialType) ? potentialType : 'unlabeled',
+            value: pattern.substring(indexOfFirstPotentialSeparator + 1),
+            exclude: isExclude,
+        };
+    }
+}
+function isValidPatternType(type) {
+    return validPatternTypes.includes(type);
+}
+exports.getMatchingStringsWithCache = (() => {
+    // Map< Pattern, Map< Item, Result >>
+    const minimatchCache = new Map();
+    const regexCache = new Map();
+    return (pattern, items) => {
+        if (!minimatchCache.has(pattern)) {
+            minimatchCache.set(pattern, new Map());
+        }
+        const patternCache = minimatchCache.get(pattern);
+        if (!regexCache.has(pattern)) {
+            const regex = minimatch_1.minimatch.makeRe(pattern, { dot: true });
+            if (regex) {
+                regexCache.set(pattern, regex);
+            }
+            else {
+                throw new Error('Invalid glob pattern ' + pattern);
+            }
+        }
+        const matcher = regexCache.get(pattern);
+        return items.filter((item) => {
+            let entry = patternCache.get(item);
+            if (entry === undefined || entry === null) {
+                entry = item === pattern ? true : matcher.test(item);
+                patternCache.set(item, entry);
+            }
+            return entry;
+        });
+    };
+})();
 
 
 /***/ }),
 
-/***/ 79914:
-/***/ ((module) => {
-
-module.exports = eval("require")("@swc/core-linux-arm64-musl");
-
-
-/***/ }),
+/***/ 94865:
+/***/ ((__unused_webpack_module, exports) => {
 
-/***/ 47663:
-/***/ ((module) => {
+"use strict";
 
-module.exports = eval("require")("@swc/core-linux-x64-gnu");
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.combineGlobPatterns = void 0;
+function combineGlobPatterns(...patterns) {
+    const p = patterns.flat();
+    return p.length > 1 ? '{' + p.join(',') + '}' : p.length === 1 ? p[0] : '';
+}
+exports.combineGlobPatterns = combineGlobPatterns;
 
 
 /***/ }),
 
-/***/ 35887:
-/***/ ((module) => {
-
-module.exports = eval("require")("@swc/core-linux-x64-musl");
-
-
-/***/ }),
+/***/ 77098:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
-/***/ 89962:
-/***/ ((module) => {
+"use strict";
 
-module.exports = eval("require")("@swc/core-win32-arm64-msvc");
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.getIgnoreObject = exports.getAlwaysIgnore = exports.getIgnoredGlobs = exports.ALWAYS_IGNORE = void 0;
+const fs_extra_1 = __nccwpck_require__(27475);
+const ignore_1 = __nccwpck_require__(56508);
+const fileutils_1 = __nccwpck_require__(83851);
+const path_1 = __nccwpck_require__(38270);
+const workspace_root_1 = __nccwpck_require__(86708);
+/**
+ * An array of glob patterns that should always be ignored.
+ */
+exports.ALWAYS_IGNORE = getAlwaysIgnore();
+function getIgnoredGlobs(root = workspace_root_1.workspaceRoot, prependRoot = true) {
+    const files = ['.gitignore', '.nxignore'];
+    if (prependRoot) {
+        return [
+            ...getAlwaysIgnore(root),
+            ...files.flatMap((f) => getIgnoredGlobsFromFile((0, path_1.joinPathFragments)(root, f), root)),
+        ];
+    }
+    else {
+        return [
+            ...getAlwaysIgnore(),
+            ...files.flatMap((f) => getIgnoredGlobsFromFile((0, path_1.joinPathFragments)(root, f))),
+        ];
+    }
+}
+exports.getIgnoredGlobs = getIgnoredGlobs;
+function getAlwaysIgnore(root) {
+    const paths = ['node_modules', '**/node_modules', '.git'];
+    return root ? paths.map((x) => (0, path_1.joinPathFragments)(root, x)) : paths;
+}
+exports.getAlwaysIgnore = getAlwaysIgnore;
+function getIgnoreObject(root = workspace_root_1.workspaceRoot) {
+    const ig = (0, ignore_1.default)();
+    ig.add((0, fileutils_1.readFileIfExisting)(`${root}/.gitignore`));
+    ig.add((0, fileutils_1.readFileIfExisting)(`${root}/.nxignore`));
+    return ig;
+}
+exports.getIgnoreObject = getIgnoreObject;
+function getIgnoredGlobsFromFile(file, root) {
+    try {
+        const results = [];
+        const contents = (0, fs_extra_1.readFileSync)(file, 'utf-8');
+        const lines = contents.split('\n');
+        for (const line of lines) {
+            const trimmed = line.trim();
+            if (!trimmed || trimmed.startsWith('#')) {
+                continue;
+            }
+            else if (trimmed.startsWith('/')) {
+                if (root) {
+                    results.push((0, path_1.joinPathFragments)(root, trimmed));
+                }
+                else {
+                    results.push((0, path_1.joinPathFragments)('.', trimmed));
+                }
+            }
+            else {
+                results.push(trimmed);
+            }
+        }
+        return results;
+    }
+    catch (e) {
+        return [];
+    }
+}
 
 
 /***/ }),
 
-/***/ 48333:
-/***/ ((module) => {
+/***/ 98584:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
-module.exports = eval("require")("@swc/core-win32-ia32-msvc");
+"use strict";
+
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.getNxRequirePaths = exports.getNxInstallationPath = void 0;
+const path_1 = __nccwpck_require__(71017);
+const workspace_root_1 = __nccwpck_require__(86708);
+function getNxInstallationPath(root = workspace_root_1.workspaceRoot) {
+    return (0, path_1.join)(root, '.nx', 'installation');
+}
+exports.getNxInstallationPath = getNxInstallationPath;
+function getNxRequirePaths(root = workspace_root_1.workspaceRoot) {
+    return [root, getNxInstallationPath(root)];
+}
+exports.getNxRequirePaths = getNxRequirePaths;
 
 
 /***/ }),
 
-/***/ 20250:
-/***/ ((module) => {
+/***/ 15284:
+/***/ ((__unused_webpack_module, exports) => {
 
-module.exports = eval("require")("@swc/core-win32-x64-msvc");
+"use strict";
+
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.isCI = void 0;
+function isCI() {
+    return (process.env.CI === 'true' ||
+        process.env.TF_BUILD === 'true' ||
+        process.env.GITHUB_ACTIONS === 'true' ||
+        process.env.BUILDKITE === 'true' ||
+        process.env.CIRCLECI === 'true' ||
+        process.env.CIRRUS_CI === 'true' ||
+        process.env.TRAVIS === 'true' ||
+        !!process.env['bamboo.buildKey'] ||
+        !!process.env.CODEBUILD_BUILD_ID ||
+        !!process.env.GITLAB_CI ||
+        !!process.env.HEROKU_TEST_RUN_ID ||
+        !!process.env.BUILD_ID ||
+        !!process.env.BUILD_BUILDID ||
+        !!process.env.TEAMCITY_VERSION);
+}
+exports.isCI = isCI;
 
 
 /***/ }),
 
-/***/ 80083:
-/***/ ((module) => {
+/***/ 72517:
+/***/ ((__unused_webpack_module, exports) => {
 
-module.exports = eval("require")("@swc/wasm");
+"use strict";
+
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.deepEquals = exports.walkJsonTree = exports.jsonDiff = exports.isJsonChange = exports.JsonDiffType = void 0;
+var JsonDiffType;
+(function (JsonDiffType) {
+    JsonDiffType["Deleted"] = "JsonPropertyDeleted";
+    JsonDiffType["Added"] = "JsonPropertyAdded";
+    JsonDiffType["Modified"] = "JsonPropertyModified";
+})(JsonDiffType || (exports.JsonDiffType = JsonDiffType = {}));
+function isJsonChange(change) {
+    return (change.type === JsonDiffType.Added ||
+        change.type === JsonDiffType.Deleted ||
+        change.type === JsonDiffType.Modified);
+}
+exports.isJsonChange = isJsonChange;
+function jsonDiff(lhs, rhs) {
+    const result = [];
+    const seenInLhs = new Set();
+    walkJsonTree(lhs, [], (path, lhsValue) => {
+        seenInLhs.add(hashArray(path));
+        const rhsValue = getJsonValue(path, rhs);
+        if (rhsValue === undefined) {
+            result.push({
+                type: JsonDiffType.Deleted,
+                path,
+                value: {
+                    lhs: lhsValue,
+                    rhs: undefined,
+                },
+            });
+        }
+        else if (!deepEquals(lhsValue, rhsValue)) {
+            result.push({
+                type: JsonDiffType.Modified,
+                path,
+                value: {
+                    lhs: lhsValue,
+                    rhs: rhsValue,
+                },
+            });
+        }
+        return typeof lhsValue === 'object' || Array.isArray(lhsValue);
+    });
+    walkJsonTree(rhs, [], (path, rhsValue) => {
+        const addedInRhs = !seenInLhs.has(hashArray(path));
+        if (addedInRhs) {
+            result.push({
+                type: JsonDiffType.Added,
+                path,
+                value: {
+                    lhs: undefined,
+                    rhs: rhsValue,
+                },
+            });
+        }
+        return typeof rhsValue === 'object' || Array.isArray(rhsValue);
+    });
+    return result;
+}
+exports.jsonDiff = jsonDiff;
+// Depth-first walk down JSON tree.
+function walkJsonTree(json, currPath, visitor) {
+    if (!json || typeof json !== 'object') {
+        return;
+    }
+    Object.keys(json).forEach((key) => {
+        const path = currPath.concat([key]);
+        const shouldContinue = visitor(path, json[key]);
+        if (shouldContinue) {
+            walkJsonTree(json[key], path, visitor);
+        }
+    });
+}
+exports.walkJsonTree = walkJsonTree;
+function hashArray(ary) {
+    return JSON.stringify(ary);
+}
+function getJsonValue(path, json) {
+    let curr = json;
+    for (const k of path) {
+        curr = curr[k];
+        if (curr === undefined) {
+            break;
+        }
+    }
+    return curr;
+}
+function deepEquals(a, b) {
+    if (a === b) {
+        return true;
+    }
+    // Values do not need to be checked for deep equality and the above is false
+    if (
+    // Values are different types
+    typeof a !== typeof b ||
+        // Values are the same type but not an object or array
+        (typeof a !== 'object' && !Array.isArray(a)) ||
+        // Objects are the same type, objects or arrays, but do not have the same number of keys
+        Object.keys(a).length !== Object.keys(b).length) {
+        return false;
+    }
+    // Values need to be checked for deep equality
+    return Object.entries(a).reduce((equal, [key, aValue]) => {
+        // Skip other keys if it is already not equal.
+        if (!equal) {
+            return equal;
+        }
+        // Traverse the object
+        return deepEquals(aValue, b[key]);
+    }, true);
+}
+exports.deepEquals = deepEquals;
 
 
 /***/ }),
 
-/***/ 3833:
-/***/ ((module) => {
+/***/ 8314:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
-function webpackEmptyContext(req) {
-	var e = new Error("Cannot find module '" + req + "'");
-	e.code = 'MODULE_NOT_FOUND';
-	throw e;
+"use strict";
+
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.serializeJson = exports.parseJson = exports.stripJsonComments = void 0;
+const jsonc_parser_1 = __nccwpck_require__(18875);
+Object.defineProperty(exports, "stripJsonComments", ({ enumerable: true, get: function () { return jsonc_parser_1.stripComments; } }));
+const lines_and_columns_1 = __nccwpck_require__(16106);
+const code_frames_1 = __nccwpck_require__(24622);
+/**
+ * Parses the given JSON string and returns the object the JSON content represents.
+ * By default javascript-style comments and trailing commas are allowed.
+ *
+ * @param input JSON content as string
+ * @param options JSON parse options
+ * @returns Object the JSON content represents
+ */
+function parseJson(input, options) {
+    try {
+        return JSON.parse(input);
+    }
+    catch { }
+    options = { allowTrailingComma: true, ...options };
+    const errors = [];
+    const result = (0, jsonc_parser_1.parse)(input, errors, options);
+    if (errors.length > 0) {
+        throw new Error(formatParseError(input, errors[0]));
+    }
+    return result;
+}
+exports.parseJson = parseJson;
+/**
+ * Nicely formats a JSON error with context
+ *
+ * @param input JSON content as string
+ * @param parseError jsonc ParseError
+ * @returns
+ */
+function formatParseError(input, parseError) {
+    const { error, offset, length } = parseError;
+    let { line, column } = new lines_and_columns_1.LinesAndColumns(input).locationForIndex(offset);
+    line++;
+    column++;
+    return (`${(0, jsonc_parser_1.printParseErrorCode)(error)} in JSON at ${line}:${column}\n` +
+        (0, code_frames_1.codeFrameColumns)(input, {
+            start: { line, column },
+            end: { line, column: column + length },
+        }) +
+        '\n');
+}
+/**
+ * Serializes the given data to a JSON string.
+ * By default the JSON string is formatted with a 2 space indentation to be easy readable.
+ *
+ * @param input Object which should be serialized to JSON
+ * @param options JSON serialize options
+ * @returns the formatted JSON representation of the object
+ */
+function serializeJson(input, options) {
+    return JSON.stringify(input, null, options?.spaces ?? 2) + '\n';
 }
-webpackEmptyContext.keys = () => ([]);
-webpackEmptyContext.resolve = webpackEmptyContext;
-webpackEmptyContext.id = 3833;
-module.exports = webpackEmptyContext;
-
-/***/ }),
-
-/***/ 39491:
-/***/ ((module) => {
+exports.serializeJson = serializeJson;
 
-"use strict";
-module.exports = require("assert");
 
 /***/ }),
 
-/***/ 14300:
-/***/ ((module) => {
+/***/ 39299:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
 "use strict";
-module.exports = require("buffer");
 
-/***/ }),
-
-/***/ 32081:
-/***/ ((module) => {
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.stripIndent = exports.logger = exports.NX_ERROR = exports.NX_PREFIX = void 0;
+const chalk = __nccwpck_require__(36662);
+exports.NX_PREFIX = `${chalk.cyan('>')} ${chalk.inverse(chalk.bold(chalk.cyan(' NX ')))}`;
+exports.NX_ERROR = chalk.inverse(chalk.bold(chalk.red(' ERROR ')));
+exports.logger = {
+    warn: (s) => console.warn(chalk.bold(chalk.yellow(s))),
+    error: (s) => {
+        if (typeof s === 'string' && s.startsWith('NX ')) {
+            console.error(`\n${exports.NX_ERROR} ${chalk.bold(chalk.red(s.slice(3)))}\n`);
+        }
+        else if (s instanceof Error && s.stack) {
+            console.error(chalk.bold(chalk.red(s.stack)));
+        }
+        else {
+            console.error(chalk.bold(chalk.red(s)));
+        }
+    },
+    info: (s) => {
+        if (typeof s === 'string' && s.startsWith('NX ')) {
+            console.info(`\n${exports.NX_PREFIX} ${chalk.bold(s.slice(3))}\n`);
+        }
+        else {
+            console.info(s);
+        }
+    },
+    log: (...s) => {
+        console.log(...s);
+    },
+    debug: (...s) => {
+        console.debug(...s);
+    },
+    fatal: (...s) => {
+        console.error(...s);
+    },
+};
+function stripIndent(str) {
+    const match = str.match(/^[ \t]*(?=\S)/gm);
+    if (!match) {
+        return str;
+    }
+    const indent = match.reduce((r, a) => Math.min(r, a.length), Infinity);
+    const regex = new RegExp(`^[ \\t]{${indent}}`, 'gm');
+    return str.replace(regex, '');
+}
+exports.stripIndent = stripIndent;
 
-"use strict";
-module.exports = require("child_process");
 
 /***/ }),
 
-/***/ 96206:
-/***/ ((module) => {
+/***/ 32256:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
 "use strict";
-module.exports = require("console");
-
-/***/ }),
 
-/***/ 22057:
-/***/ ((module) => {
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.getDefaultPluginsSync = void 0;
+const angular_json_1 = __nccwpck_require__(44050);
+const project_json_1 = __nccwpck_require__(76877);
+const target_defaults_plugin_1 = __nccwpck_require__(50280);
+const package_json_workspaces_1 = __nccwpck_require__(65286);
+/**
+ * @todo(@agentender) v19: Remove this fn when we remove readWorkspaceConfig
+ */
+function getDefaultPluginsSync(root) {
+    const plugins = [
+        __nccwpck_require__(17797),
+        ...((0, angular_json_1.shouldMergeAngularProjects)(root, false)
+            ? [(__nccwpck_require__(44050).NxAngularJsonPlugin)]
+            : []),
+        target_defaults_plugin_1.TargetDefaultsPlugin,
+        (0, package_json_workspaces_1.getNxPackageJsonWorkspacesPlugin)(root),
+        project_json_1.ProjectJsonProjectsPlugin,
+    ];
+    return plugins.map((p) => ({
+        plugin: p,
+    }));
+}
+exports.getDefaultPluginsSync = getDefaultPluginsSync;
 
-"use strict";
-module.exports = require("constants");
 
 /***/ }),
 
-/***/ 6113:
-/***/ ((module) => {
+/***/ 84141:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
 "use strict";
-module.exports = require("crypto");
-
-/***/ }),
 
-/***/ 82361:
-/***/ ((module) => {
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.getDefaultPlugins = exports.unregisterPluginTSTranspiler = exports.registerPluginTSTranspiler = exports.resolveLocalNxPlugin = exports.readPluginPackageJson = exports.isNxPluginV1 = exports.isNxPluginV2 = exports.ensurePluginIsV2 = exports.loadNxPlugins = exports.loadNxPluginAsync = exports.getPluginPathAndName = exports.nxPluginCache = void 0;
+const tslib_1 = __nccwpck_require__(57265);
+const fs_1 = __nccwpck_require__(57147);
+const path = __nccwpck_require__(71017);
+const workspaces_1 = __nccwpck_require__(26546);
+const workspace_root_1 = __nccwpck_require__(86708);
+const fileutils_1 = __nccwpck_require__(83851);
+const package_json_1 = __nccwpck_require__(4014);
+const register_1 = __nccwpck_require__(44321);
+const logger_1 = __nccwpck_require__(39299);
+const find_project_for_path_1 = __nccwpck_require__(46329);
+const path_1 = __nccwpck_require__(38270);
+const path_2 = __nccwpck_require__(71017);
+const installation_directory_1 = __nccwpck_require__(98584);
+const typescript_1 = __nccwpck_require__(37650);
+const nx_json_1 = __nccwpck_require__(53619);
+const globs_1 = __nccwpck_require__(94865);
+const angular_json_1 = __nccwpck_require__(44050);
+const package_json_workspaces_1 = __nccwpck_require__(65286);
+const project_json_1 = __nccwpck_require__(76877);
+const package_json_next_to_project_json_1 = __nccwpck_require__(1215);
+const retrieve_workspace_files_1 = __nccwpck_require__(14249);
+const target_defaults_plugin_1 = __nccwpck_require__(50280);
+tslib_1.__exportStar(__nccwpck_require__(32256), exports);
+// Short lived cache (cleared between cmd runs)
+// holding resolved nx plugin objects.
+// Allows loadNxPlugins to be called multiple times w/o
+// executing resolution mulitple times.
+exports.nxPluginCache = new Map();
+function getPluginPathAndName(moduleName, paths, projects, root) {
+    let pluginPath;
+    try {
+        pluginPath = __nccwpck_require__(72939).resolve(moduleName, {
+            paths,
+        });
+    }
+    catch (e) {
+        if (e.code === 'MODULE_NOT_FOUND') {
+            const plugin = resolveLocalNxPlugin(moduleName, (0, nx_json_1.readNxJson)(root), projects, root);
+            if (plugin) {
+                const main = readPluginMainFromProjectConfiguration(plugin.projectConfig);
+                pluginPath = main ? path.join(root, main) : plugin.path;
+            }
+            else {
+                logger_1.logger.error(`Plugin listed in \`nx.json\` not found: ${moduleName}`);
+                throw e;
+            }
+        }
+        else {
+            throw e;
+        }
+    }
+    const packageJsonPath = path.join(pluginPath, 'package.json');
+    const extension = path.extname(pluginPath);
+    // Register the ts-transpiler if we are pointing to a
+    // plain ts file that's not part of a plugin project
+    if (extension === '.ts' && !tsNodeAndPathsUnregisterCallback) {
+        registerPluginTSTranspiler();
+    }
+    const { name } = !['.ts', '.js'].some((x) => x === extension) && // Not trying to point to a ts or js file
+        (0, fs_1.existsSync)(packageJsonPath) // plugin has a package.json
+        ? (0, fileutils_1.readJsonFile)(packageJsonPath) // read name from package.json
+        : { name: moduleName };
+    return { pluginPath, name };
+}
+exports.getPluginPathAndName = getPluginPathAndName;
+async function loadNxPluginAsync(pluginConfiguration, paths, projects, root) {
+    const { plugin: moduleName, options } = typeof pluginConfiguration === 'object'
+        ? pluginConfiguration
+        : { plugin: pluginConfiguration, options: undefined };
+    let pluginModule = exports.nxPluginCache.get(moduleName);
+    if (pluginModule) {
+        return { plugin: pluginModule, options };
+    }
+    performance.mark(`Load Nx Plugin: ${moduleName} - start`);
+    let { pluginPath, name } = await getPluginPathAndName(moduleName, paths, projects, root);
+    const plugin = ensurePluginIsV2((await Promise.resolve(`${pluginPath}`).then(s => __nccwpck_require__(72939)(s))));
+    plugin.name ??= name;
+    exports.nxPluginCache.set(moduleName, plugin);
+    performance.mark(`Load Nx Plugin: ${moduleName} - end`);
+    performance.measure(`Load Nx Plugin: ${moduleName}`, `Load Nx Plugin: ${moduleName} - start`, `Load Nx Plugin: ${moduleName} - end`);
+    return { plugin, options };
+}
+exports.loadNxPluginAsync = loadNxPluginAsync;
+async function loadNxPlugins(plugins, paths = (0, installation_directory_1.getNxRequirePaths)(), root = workspace_root_1.workspaceRoot, projects) {
+    const result = [
+        { plugin: package_json_next_to_project_json_1.PackageJsonProjectsNextToProjectJsonPlugin },
+    ];
+    plugins ??= [];
+    // When loading plugins for `createNodes`, we don't know what projects exist yet.
+    // Try resolving plugins
+    for (const plugin of plugins) {
+        try {
+            /*require.resolve*/(typeof plugin === 'string' ? __nccwpck_require__(72939).resolve(plugin) : __nccwpck_require__(72939).resolve(plugin.plugin));
+        }
+        catch {
+            // If a plugin cannot be resolved, we will need projects to resolve it
+            projects ??= await (0, retrieve_workspace_files_1.retrieveProjectConfigurationsWithoutPluginInference)(root);
+            break;
+        }
+    }
+    for (const plugin of plugins) {
+        result.push(await loadNxPluginAsync(plugin, paths, projects, root));
+    }
+    // We push the nx core node plugins onto the end, s.t. it overwrites any other plugins
+    result.push(...(await getDefaultPlugins(root)));
+    return result;
+}
+exports.loadNxPlugins = loadNxPlugins;
+function ensurePluginIsV2(plugin) {
+    if (isNxPluginV2(plugin)) {
+        return plugin;
+    }
+    if (isNxPluginV1(plugin) && plugin.projectFilePatterns) {
+        return {
+            ...plugin,
+            createNodes: [
+                `*/**/${(0, globs_1.combineGlobPatterns)(plugin.projectFilePatterns)}`,
+                (configFilePath) => {
+                    const root = (0, path_2.dirname)(configFilePath);
+                    return {
+                        projects: {
+                            [root]: {
+                                name: (0, workspaces_1.toProjectName)(configFilePath),
+                                root,
+                                targets: plugin.registerProjectTargets?.(configFilePath),
+                            },
+                        },
+                    };
+                },
+            ],
+        };
+    }
+    return plugin;
+}
+exports.ensurePluginIsV2 = ensurePluginIsV2;
+function isNxPluginV2(plugin) {
+    return 'createNodes' in plugin || 'createDependencies' in plugin;
+}
+exports.isNxPluginV2 = isNxPluginV2;
+function isNxPluginV1(plugin) {
+    return 'processProjectGraph' in plugin || 'projectFilePatterns' in plugin;
+}
+exports.isNxPluginV1 = isNxPluginV1;
+function readPluginPackageJson(pluginName, projects, paths = (0, installation_directory_1.getNxRequirePaths)()) {
+    try {
+        const result = (0, package_json_1.readModulePackageJsonWithoutFallbacks)(pluginName, paths);
+        return {
+            json: result.packageJson,
+            path: result.path,
+        };
+    }
+    catch (e) {
+        if (e.code === 'MODULE_NOT_FOUND') {
+            const nxJson = (0, nx_json_1.readNxJson)();
+            const localPluginPath = resolveLocalNxPlugin(pluginName, nxJson, projects);
+            if (localPluginPath) {
+                const localPluginPackageJson = path.join(localPluginPath.path, 'package.json');
+                return {
+                    path: localPluginPackageJson,
+                    json: (0, fileutils_1.readJsonFile)(localPluginPackageJson),
+                };
+            }
+        }
+        throw e;
+    }
+}
+exports.readPluginPackageJson = readPluginPackageJson;
+/**
+ * Builds a plugin package and returns the path to output
+ * @param importPath What is the import path that refers to a potential plugin?
+ * @returns The path to the built plugin, or null if it doesn't exist
+ */
+const localPluginCache = {};
+function resolveLocalNxPlugin(importPath, nxJsonConfiguration, projects, root = workspace_root_1.workspaceRoot) {
+    localPluginCache[importPath] ??= lookupLocalPlugin(importPath, nxJsonConfiguration, projects, root);
+    return localPluginCache[importPath];
+}
+exports.resolveLocalNxPlugin = resolveLocalNxPlugin;
+let tsNodeAndPathsUnregisterCallback = undefined;
+/**
+ * Register swc-node or ts-node if they are not currently registered
+ * with some default settings which work well for Nx plugins.
+ */
+function registerPluginTSTranspiler() {
+    if (!tsNodeAndPathsUnregisterCallback) {
+        // nx-ignore-next-line
+        const ts = __nccwpck_require__(81151);
+        // Get the first tsconfig that matches the allowed set
+        const tsConfigName = [
+            (0, path_2.join)(workspace_root_1.workspaceRoot, 'tsconfig.base.json'),
+            (0, path_2.join)(workspace_root_1.workspaceRoot, 'tsconfig.json'),
+        ].find((x) => (0, fs_1.existsSync)(x));
+        const tsConfig = tsConfigName
+            ? (0, typescript_1.readTsConfig)(tsConfigName)
+            : {};
+        const unregisterTsConfigPaths = (0, register_1.registerTsConfigPaths)(tsConfigName);
+        const unregisterTranspiler = (0, register_1.registerTranspiler)({
+            experimentalDecorators: true,
+            emitDecoratorMetadata: true,
+            ...tsConfig.options,
+        });
+        tsNodeAndPathsUnregisterCallback = () => {
+            unregisterTsConfigPaths();
+            unregisterTranspiler();
+        };
+    }
+}
+exports.registerPluginTSTranspiler = registerPluginTSTranspiler;
+/**
+ * Unregister the ts-node transpiler if it is registered
+ */
+function unregisterPluginTSTranspiler() {
+    if (tsNodeAndPathsUnregisterCallback) {
+        tsNodeAndPathsUnregisterCallback();
+        tsNodeAndPathsUnregisterCallback = undefined;
+    }
+}
+exports.unregisterPluginTSTranspiler = unregisterPluginTSTranspiler;
+function lookupLocalPlugin(importPath, nxJsonConfiguration, projects, root = workspace_root_1.workspaceRoot) {
+    const plugin = findNxProjectForImportPath(importPath, projects, root);
+    if (!plugin) {
+        return null;
+    }
+    if (!tsNodeAndPathsUnregisterCallback) {
+        registerPluginTSTranspiler();
+    }
+    const projectConfig = projects[plugin];
+    return { path: path.join(root, projectConfig.root), projectConfig };
+}
+function findNxProjectForImportPath(importPath, projects, root = workspace_root_1.workspaceRoot) {
+    const tsConfigPaths = readTsConfigPaths(root);
+    const possiblePaths = tsConfigPaths[importPath]?.map((p) => (0, path_1.normalizePath)(path.relative(root, path.join(root, p))));
+    if (possiblePaths?.length) {
+        const projectRootMappings = (0, find_project_for_path_1.createProjectRootMappingsFromProjectConfigurations)(projects);
+        for (const tsConfigPath of possiblePaths) {
+            const nxProject = (0, find_project_for_path_1.findProjectForPath)(tsConfigPath, projectRootMappings);
+            if (nxProject) {
+                return nxProject;
+            }
+        }
+        if (process.env.NX_VERBOSE_LOGGING) {
+            console.log('Unable to find local plugin', possiblePaths, projectRootMappings);
+        }
+        throw new Error('Unable to resolve local plugin with import path ' + importPath);
+    }
+}
+let tsconfigPaths;
+function readTsConfigPaths(root = workspace_root_1.workspaceRoot) {
+    if (!tsconfigPaths) {
+        const tsconfigPath = ['tsconfig.base.json', 'tsconfig.json']
+            .map((x) => path.join(root, x))
+            .filter((x) => (0, fs_1.existsSync)(x))[0];
+        if (!tsconfigPath) {
+            throw new Error('unable to find tsconfig.base.json or tsconfig.json');
+        }
+        const { compilerOptions } = (0, fileutils_1.readJsonFile)(tsconfigPath);
+        tsconfigPaths = compilerOptions?.paths;
+    }
+    return tsconfigPaths ?? {};
+}
+function readPluginMainFromProjectConfiguration(plugin) {
+    const { main } = Object.values(plugin.targets).find((x) => [
+        '@nx/js:tsc',
+        '@nrwl/js:tsc',
+        '@nx/js:swc',
+        '@nrwl/js:swc',
+        '@nx/node:package',
+        '@nrwl/node:package',
+    ].includes(x.executor))?.options ||
+        plugin.targets?.build?.options ||
+        {};
+    return main;
+}
+async function getDefaultPlugins(root) {
+    const plugins = [
+        await Promise.resolve().then(() => __nccwpck_require__(17797)),
+        target_defaults_plugin_1.TargetDefaultsPlugin,
+        ...((0, angular_json_1.shouldMergeAngularProjects)(root, false)
+            ? [
+                await Promise.resolve().then(() => __nccwpck_require__(44050)).then((m) => m.NxAngularJsonPlugin),
+            ]
+            : []),
+        (0, package_json_workspaces_1.getNxPackageJsonWorkspacesPlugin)(root),
+        project_json_1.ProjectJsonProjectsPlugin,
+    ];
+    return plugins.map((p) => ({
+        plugin: p,
+    }));
+}
+exports.getDefaultPlugins = getDefaultPlugins;
 
-"use strict";
-module.exports = require("events");
 
 /***/ }),
 
-/***/ 57147:
-/***/ ((module) => {
+/***/ 84110:
+/***/ ((__unused_webpack_module, exports) => {
 
 "use strict";
-module.exports = require("fs");
-
-/***/ }),
 
-/***/ 73292:
-/***/ ((module) => {
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.sortObjectByKeys = void 0;
+function sortObjectByKeys(originalObject) {
+    const keys = Object.keys(originalObject).sort();
+    const sortedObject = {};
+    keys.forEach((key) => (sortedObject[key] = originalObject[key]));
+    return sortedObject;
+}
+exports.sortObjectByKeys = sortObjectByKeys;
 
-"use strict";
-module.exports = require("fs/promises");
 
 /***/ }),
 
-/***/ 13685:
-/***/ ((module) => {
+/***/ 1737:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
 "use strict";
-module.exports = require("http");
-
-/***/ }),
 
-/***/ 95687:
-/***/ ((module) => {
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.output = void 0;
+const chalk = __nccwpck_require__(36662);
+const os_1 = __nccwpck_require__(22037);
+const readline = __nccwpck_require__(14521);
+const is_ci_1 = __nccwpck_require__(15284);
+const GH_GROUP_PREFIX = '::group::';
+const GH_GROUP_SUFFIX = '::endgroup::';
+/**
+ * Automatically disable styling applied by chalk if CI=true
+ */
+const forceColor = process.env.FORCE_COLOR === '' || process.env.FORCE_COLOR === 'true';
+if ((0, is_ci_1.isCI)() && !forceColor) {
+    chalk.level = 0;
+}
+class CLIOutput {
+    constructor() {
+        this.X_PADDING = ' ';
+        this.cliName = 'NX';
+        this.formatCommand = (taskId) => `${chalk.dim('nx run')} ${taskId}`;
+        /**
+         * Expose some color and other utility functions so that other parts of the codebase that need
+         * more fine-grained control of message bodies are still using a centralized
+         * implementation.
+         */
+        this.colors = {
+            gray: chalk.gray,
+            green: chalk.green,
+            red: chalk.red,
+            cyan: chalk.cyan,
+            white: chalk.white,
+        };
+        this.bold = chalk.bold;
+        this.underline = chalk.underline;
+        this.dim = chalk.dim;
+    }
+    /**
+     * Longer dash character which forms more of a continuous line when place side to side
+     * with itself, unlike the standard dash character
+     */
+    get VERTICAL_SEPARATOR() {
+        let divider = '';
+        for (let i = 0; i < process.stdout.columns - this.X_PADDING.length * 2; i++) {
+            divider += '\u2014';
+        }
+        return divider;
+    }
+    writeToStdOut(str) {
+        process.stdout.write(str);
+    }
+    overwriteLine(lineText = '') {
+        // this replaces the existing text up to the new line length
+        process.stdout.write(lineText);
+        // clear whatever text might be left to the right of the cursor (happens
+        // when existing text was longer than new one)
+        readline.clearLine(process.stdout, 1);
+        process.stdout.write(os_1.EOL);
+    }
+    writeOutputTitle({ color, title, }) {
+        this.writeToStdOut(` ${this.applyNxPrefix(color, title)}${os_1.EOL}`);
+    }
+    writeOptionalOutputBody(bodyLines) {
+        if (!bodyLines) {
+            return;
+        }
+        this.addNewline();
+        bodyLines.forEach((bodyLine) => this.writeToStdOut(`   ${bodyLine}${os_1.EOL}`));
+    }
+    applyNxPrefix(color = 'cyan', text) {
+        let nxPrefix = '';
+        if (chalk[color]) {
+            nxPrefix = `${chalk[color]('>')} ${chalk.reset.inverse.bold[color](` ${this.cliName} `)}`;
+        }
+        else {
+            nxPrefix = `${chalk.keyword(color)('>')} ${chalk.reset.inverse.bold.keyword(color)(` ${this.cliName} `)}`;
+        }
+        return `${nxPrefix}  ${text}`;
+    }
+    addNewline() {
+        this.writeToStdOut(os_1.EOL);
+    }
+    addVerticalSeparator(color = 'gray') {
+        this.addNewline();
+        this.addVerticalSeparatorWithoutNewLines(color);
+        this.addNewline();
+    }
+    addVerticalSeparatorWithoutNewLines(color = 'gray') {
+        this.writeToStdOut(`${this.getVerticalSeparator(color)}${os_1.EOL}`);
+    }
+    getVerticalSeparatorLines(color = 'gray') {
+        return ['', this.getVerticalSeparator(color), ''];
+    }
+    getVerticalSeparator(color) {
+        return `${this.X_PADDING}${chalk.dim[color](this.VERTICAL_SEPARATOR)}`;
+    }
+    error({ title, slug, bodyLines }) {
+        this.addNewline();
+        this.writeOutputTitle({
+            color: 'red',
+            title: chalk.red(title),
+        });
+        this.writeOptionalOutputBody(bodyLines);
+        /**
+         * Optional slug to be used in an Nx error message redirect URL
+         */
+        if (slug && typeof slug === 'string') {
+            this.addNewline();
+            this.writeToStdOut(`${chalk.grey('  Learn more about this error: ')}https://errors.nx.dev/${slug}${os_1.EOL}`);
+        }
+        this.addNewline();
+    }
+    warn({ title, slug, bodyLines }) {
+        this.addNewline();
+        this.writeOutputTitle({
+            color: 'yellow',
+            title: chalk.yellow(title),
+        });
+        this.writeOptionalOutputBody(bodyLines);
+        /**
+         * Optional slug to be used in an Nx warning message redirect URL
+         */
+        if (slug && typeof slug === 'string') {
+            this.addNewline();
+            this.writeToStdOut(`${chalk.grey('  Learn more about this warning: ')}https://errors.nx.dev/${slug}${os_1.EOL}`);
+        }
+        this.addNewline();
+    }
+    note({ title, bodyLines }) {
+        this.addNewline();
+        this.writeOutputTitle({
+            color: 'orange',
+            title: chalk.keyword('orange')(title),
+        });
+        this.writeOptionalOutputBody(bodyLines);
+        this.addNewline();
+    }
+    success({ title, bodyLines }) {
+        this.addNewline();
+        this.writeOutputTitle({
+            color: 'green',
+            title: chalk.green(title),
+        });
+        this.writeOptionalOutputBody(bodyLines);
+        this.addNewline();
+    }
+    logSingleLine(message) {
+        this.addNewline();
+        this.writeOutputTitle({
+            color: 'gray',
+            title: message,
+        });
+        this.addNewline();
+    }
+    logCommand(message, taskStatus) {
+        this.addNewline();
+        this.writeToStdOut(this.getCommandWithStatus(message, taskStatus));
+        this.addNewline();
+        this.addNewline();
+    }
+    logCommandOutput(message, taskStatus, output) {
+        let commandOutputWithStatus = this.getCommandWithStatus(message, taskStatus);
+        if (process.env.GITHUB_ACTIONS) {
+            const icon = this.getStatusIcon(taskStatus);
+            commandOutputWithStatus = `${GH_GROUP_PREFIX}${icon} ${commandOutputWithStatus}`;
+        }
+        this.addNewline();
+        this.writeToStdOut(commandOutputWithStatus);
+        this.addNewline();
+        this.addNewline();
+        this.writeToStdOut(output);
+        if (process.env.GITHUB_ACTIONS) {
+            this.writeToStdOut(GH_GROUP_SUFFIX);
+        }
+    }
+    getCommandWithStatus(message, taskStatus) {
+        const commandOutput = chalk.dim('> ') + this.formatCommand(this.normalizeMessage(message));
+        return this.addTaskStatus(taskStatus, commandOutput);
+    }
+    getStatusIcon(taskStatus) {
+        switch (taskStatus) {
+            case 'success':
+                return '✔️';
+            case 'failure':
+                return '❌';
+            case 'skipped':
+            case 'local-cache-kept-existing':
+                return '⏩';
+            case 'local-cache':
+            case 'remote-cache':
+                return '🔁';
+        }
+    }
+    normalizeMessage(message) {
+        if (message.startsWith('nx run ')) {
+            return message.substring('nx run '.length);
+        }
+        else if (message.startsWith('run ')) {
+            return message.substring('run '.length);
+        }
+        else {
+            return message;
+        }
+    }
+    addTaskStatus(taskStatus, commandOutput) {
+        if (taskStatus === 'local-cache') {
+            return `${commandOutput}  ${chalk.dim('[local cache]')}`;
+        }
+        else if (taskStatus === 'remote-cache') {
+            return `${commandOutput}  ${chalk.dim('[remote cache]')}`;
+        }
+        else if (taskStatus === 'local-cache-kept-existing') {
+            return `${commandOutput}  ${chalk.dim('[existing outputs match the cache, left as is]')}`;
+        }
+        else {
+            return commandOutput;
+        }
+    }
+    log({ title, bodyLines, color }) {
+        this.addNewline();
+        this.writeOutputTitle({
+            color: 'cyan',
+            title: color ? chalk[color](title) : title,
+        });
+        this.writeOptionalOutputBody(bodyLines);
+        this.addNewline();
+    }
+    drain() {
+        return new Promise((resolve) => {
+            if (process.stdout.writableNeedDrain) {
+                process.stdout.once('drain', resolve);
+            }
+            else {
+                resolve();
+            }
+        });
+    }
+}
+exports.output = new CLIOutput();
 
-"use strict";
-module.exports = require("https");
 
 /***/ }),
 
-/***/ 31405:
-/***/ ((module) => {
+/***/ 4014:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
 "use strict";
-module.exports = require("inspector");
 
-/***/ }),
-
-/***/ 98188:
-/***/ ((module) => {
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.readModulePackageJson = exports.readModulePackageJsonWithoutFallbacks = exports.readTargetsFromPackageJson = exports.buildTargetFromScript = exports.readNxMigrateConfig = exports.normalizePackageGroup = void 0;
+const fs_1 = __nccwpck_require__(57147);
+const path_1 = __nccwpck_require__(71017);
+const fileutils_1 = __nccwpck_require__(83851);
+const installation_directory_1 = __nccwpck_require__(98584);
+function normalizePackageGroup(packageGroup) {
+    return Array.isArray(packageGroup)
+        ? packageGroup.map((x) => typeof x === 'string' ? { package: x, version: '*' } : x)
+        : Object.entries(packageGroup).map(([pkg, version]) => ({
+            package: pkg,
+            version,
+        }));
+}
+exports.normalizePackageGroup = normalizePackageGroup;
+function readNxMigrateConfig(json) {
+    const parseNxMigrationsConfig = (fromJson) => {
+        if (!fromJson) {
+            return {};
+        }
+        if (typeof fromJson === 'string') {
+            return { migrations: fromJson, packageGroup: [] };
+        }
+        return {
+            ...(fromJson.migrations ? { migrations: fromJson.migrations } : {}),
+            ...(fromJson.packageGroup
+                ? { packageGroup: normalizePackageGroup(fromJson.packageGroup) }
+                : {}),
+        };
+    };
+    return {
+        ...parseNxMigrationsConfig(json['ng-update']),
+        ...parseNxMigrationsConfig(json['nx-migrations']),
+        // In case there's a `migrations` field in `package.json`
+        ...parseNxMigrationsConfig(json),
+    };
+}
+exports.readNxMigrateConfig = readNxMigrateConfig;
+function buildTargetFromScript(script, nx) {
+    const nxTargetConfiguration = nx?.targets?.[script] || {};
+    return {
+        ...nxTargetConfiguration,
+        executor: 'nx:run-script',
+        options: {
+            ...(nxTargetConfiguration.options || {}),
+            script,
+        },
+    };
+}
+exports.buildTargetFromScript = buildTargetFromScript;
+function readTargetsFromPackageJson(packageJson) {
+    const { scripts, nx } = packageJson;
+    const res = {};
+    Object.keys(scripts || {}).forEach((script) => {
+        if (!nx?.includedScripts || nx?.includedScripts.includes(script)) {
+            res[script] = buildTargetFromScript(script, nx);
+        }
+    });
+    /**
+     * Add implicit nx-release-publish target for all package.json files that are
+     * not marked as `"private": true` to allow for lightweight configuration for
+     * package based repos.
+     */
+    if (!packageJson.private && !res['nx-release-publish']) {
+        res['nx-release-publish'] = {
+            dependsOn: ['^nx-release-publish'],
+            executor: '@nx/js:release-publish',
+            options: {},
+        };
+    }
+    return res;
+}
+exports.readTargetsFromPackageJson = readTargetsFromPackageJson;
+/**
+ * Uses `require.resolve` to read the package.json for a module.
+ *
+ * This will fail if the module doesn't export package.json
+ *
+ * @returns package json contents and path
+ */
+function readModulePackageJsonWithoutFallbacks(moduleSpecifier, requirePaths = (0, installation_directory_1.getNxRequirePaths)()) {
+    const packageJsonPath = require.resolve(`${moduleSpecifier}/package.json`, {
+        paths: requirePaths,
+    });
+    const packageJson = (0, fileutils_1.readJsonFile)(packageJsonPath);
+    return {
+        path: packageJsonPath,
+        packageJson,
+    };
+}
+exports.readModulePackageJsonWithoutFallbacks = readModulePackageJsonWithoutFallbacks;
+/**
+ * Reads the package.json file for a specified module.
+ *
+ * Includes a fallback that accounts for modules that don't export package.json
+ *
+ * @param {string} moduleSpecifier The module to look up
+ * @param {string[]} requirePaths List of paths look in. Pass `module.paths` to ensure non-hoisted dependencies are found.
+ *
+ * @example
+ * // Use the caller's lookup paths for non-hoisted dependencies
+ * readModulePackageJson('http-server', module.paths);
+ *
+ * @returns package json contents and path
+ */
+function readModulePackageJson(moduleSpecifier, requirePaths = (0, installation_directory_1.getNxRequirePaths)()) {
+    let packageJsonPath;
+    let packageJson;
+    try {
+        ({ path: packageJsonPath, packageJson } =
+            readModulePackageJsonWithoutFallbacks(moduleSpecifier, requirePaths));
+    }
+    catch {
+        const entryPoint = require.resolve(moduleSpecifier, {
+            paths: requirePaths,
+        });
+        let moduleRootPath = (0, path_1.dirname)(entryPoint);
+        packageJsonPath = (0, path_1.join)(moduleRootPath, 'package.json');
+        while (!(0, fs_1.existsSync)(packageJsonPath)) {
+            moduleRootPath = (0, path_1.dirname)(moduleRootPath);
+            packageJsonPath = (0, path_1.join)(moduleRootPath, 'package.json');
+        }
+        packageJson = (0, fileutils_1.readJsonFile)(packageJsonPath);
+        if (packageJson.name && packageJson.name !== moduleSpecifier) {
+            throw new Error(`Found module ${packageJson.name} while trying to locate ${moduleSpecifier}/package.json`);
+        }
+    }
+    return {
+        packageJson,
+        path: packageJsonPath,
+    };
+}
+exports.readModulePackageJson = readModulePackageJson;
 
-"use strict";
-module.exports = require("module");
 
 /***/ }),
 
-/***/ 41808:
-/***/ ((module) => {
+/***/ 18142:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
 "use strict";
-module.exports = require("net");
-
-/***/ }),
 
-/***/ 22037:
-/***/ ((module) => {
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.packageRegistryPack = exports.packageRegistryView = exports.resolvePackageVersionUsingInstallation = exports.resolvePackageVersionUsingRegistry = exports.createTempNpmDirectory = exports.copyPackageManagerConfigurationFiles = exports.modifyYarnRcToFitNewDirectory = exports.modifyYarnRcYmlToFitNewDirectory = exports.findFileInPackageJsonDirectory = exports.getPackageManagerVersion = exports.getPackageManagerCommand = exports.detectPackageManager = void 0;
+const child_process_1 = __nccwpck_require__(32081);
+const fs_1 = __nccwpck_require__(57147);
+const fs_extra_1 = __nccwpck_require__(27475);
+const path_1 = __nccwpck_require__(71017);
+const semver_1 = __nccwpck_require__(66195);
+const tmp_1 = __nccwpck_require__(81866);
+const util_1 = __nccwpck_require__(73837);
+const configuration_1 = __nccwpck_require__(38777);
+const fileutils_1 = __nccwpck_require__(83851);
+const package_json_1 = __nccwpck_require__(4014);
+const workspace_root_1 = __nccwpck_require__(86708);
+const execAsync = (0, util_1.promisify)(child_process_1.exec);
+/**
+ * Detects which package manager is used in the workspace based on the lock file.
+ */
+function detectPackageManager(dir = '') {
+    const nxJson = (0, configuration_1.readNxJson)();
+    return (nxJson.cli?.packageManager ??
+        ((0, fs_1.existsSync)((0, path_1.join)(dir, 'yarn.lock'))
+            ? 'yarn'
+            : (0, fs_1.existsSync)((0, path_1.join)(dir, 'pnpm-lock.yaml'))
+                ? 'pnpm'
+                : 'npm'));
+}
+exports.detectPackageManager = detectPackageManager;
+/**
+ * Returns commands for the package manager used in the workspace.
+ * By default, the package manager is derived based on the lock file,
+ * but it can also be passed in explicitly.
+ *
+ * Example:
+ *
+ * ```javascript
+ * execSync(`${getPackageManagerCommand().addDev} my-dev-package`);
+ * ```
+ *
+ * @param packageManager The package manager to use. If not provided, it will be detected based on the lock file.
+ * @param root The directory the commands will be ran inside of. Defaults to the current workspace's root.
+ */
+function getPackageManagerCommand(packageManager = detectPackageManager(), root = workspace_root_1.workspaceRoot) {
+    const commands = {
+        yarn: () => {
+            const yarnVersion = getPackageManagerVersion('yarn', root);
+            const useBerry = (0, semver_1.gte)(yarnVersion, '2.0.0');
+            return {
+                preInstall: `yarn set version ${yarnVersion}`,
+                install: 'yarn',
+                ciInstall: useBerry
+                    ? 'yarn install --immutable'
+                    : 'yarn install --frozen-lockfile',
+                updateLockFile: useBerry
+                    ? 'yarn install --mode update-lockfile'
+                    : 'yarn install',
+                add: useBerry ? 'yarn add' : 'yarn add -W',
+                addDev: useBerry ? 'yarn add -D' : 'yarn add -D -W',
+                rm: 'yarn remove',
+                exec: 'yarn',
+                dlx: useBerry ? 'yarn dlx' : 'yarn',
+                run: (script, args) => `yarn ${script} ${args}`,
+                list: useBerry ? 'yarn info --name-only' : 'yarn list',
+            };
+        },
+        pnpm: () => {
+            const pnpmVersion = getPackageManagerVersion('pnpm', root);
+            const modernPnpm = (0, semver_1.gte)(pnpmVersion, '6.13.0');
+            const includeDoubleDashBeforeArgs = (0, semver_1.lt)(pnpmVersion, '7.0.0');
+            const isPnpmWorkspace = (0, fs_1.existsSync)((0, path_1.join)(root, 'pnpm-workspace.yaml'));
+            return {
+                install: 'pnpm install --no-frozen-lockfile', // explicitly disable in case of CI
+                ciInstall: 'pnpm install --frozen-lockfile',
+                updateLockFile: 'pnpm install --lockfile-only',
+                add: isPnpmWorkspace ? 'pnpm add -w' : 'pnpm add',
+                addDev: isPnpmWorkspace ? 'pnpm add -Dw' : 'pnpm add -D',
+                rm: 'pnpm rm',
+                exec: modernPnpm ? 'pnpm exec' : 'pnpx',
+                dlx: modernPnpm ? 'pnpm dlx' : 'pnpx',
+                run: (script, args) => includeDoubleDashBeforeArgs
+                    ? `pnpm run ${script} -- ${args}`
+                    : `pnpm run ${script} ${args}`,
+                list: 'pnpm ls --depth 100',
+            };
+        },
+        npm: () => {
+            // TODO: Remove this
+            process.env.npm_config_legacy_peer_deps ??= 'true';
+            return {
+                install: 'npm install',
+                ciInstall: 'npm ci',
+                updateLockFile: 'npm install --package-lock-only',
+                add: 'npm install',
+                addDev: 'npm install -D',
+                rm: 'npm rm',
+                exec: 'npx',
+                dlx: 'npx',
+                run: (script, args) => `npm run ${script} -- ${args}`,
+                list: 'npm ls',
+            };
+        },
+    };
+    return commands[packageManager]();
+}
+exports.getPackageManagerCommand = getPackageManagerCommand;
+/**
+ * Returns the version of the package manager used in the workspace.
+ * By default, the package manager is derived based on the lock file,
+ * but it can also be passed in explicitly.
+ */
+function getPackageManagerVersion(packageManager = detectPackageManager(), cwd = process.cwd()) {
+    return (0, child_process_1.execSync)(`${packageManager} --version`, {
+        cwd,
+        encoding: 'utf-8',
+    }).trim();
+}
+exports.getPackageManagerVersion = getPackageManagerVersion;
+/**
+ * Checks for a project level npmrc file by crawling up the file tree until
+ * hitting a package.json file, as this is how npm finds them as well.
+ */
+function findFileInPackageJsonDirectory(file, directory = process.cwd()) {
+    while (!(0, fs_1.existsSync)((0, path_1.join)(directory, 'package.json'))) {
+        directory = (0, path_1.dirname)(directory);
+    }
+    const path = (0, path_1.join)(directory, file);
+    return (0, fs_1.existsSync)(path) ? path : null;
+}
+exports.findFileInPackageJsonDirectory = findFileInPackageJsonDirectory;
+/**
+ * We copy yarnrc.yml to the temporary directory to ensure things like the specified
+ * package registry are still used. However, there are a few relative paths that can
+ * cause issues, so we modify them to fit the new directory.
+ *
+ * Exported for testing - not meant to be used outside of this file.
+ *
+ * @param contents The string contents of the yarnrc.yml file
+ * @returns Updated string contents of the yarnrc.yml file
+ */
+function modifyYarnRcYmlToFitNewDirectory(contents) {
+    const { parseSyml, stringifySyml } = __nccwpck_require__(2877);
+    const parsed = parseSyml(contents);
+    if (parsed.yarnPath) {
+        // yarnPath is relative to the workspace root, so we need to make it relative
+        // to the new directory s.t. it still points to the same yarn binary.
+        delete parsed.yarnPath;
+    }
+    if (parsed.plugins) {
+        // Plugins specified by a string are relative paths from workspace root.
+        // ex: https://yarnpkg.com/advanced/plugin-tutorial#writing-our-first-plugin
+        delete parsed.plugins;
+    }
+    return stringifySyml(parsed);
+}
+exports.modifyYarnRcYmlToFitNewDirectory = modifyYarnRcYmlToFitNewDirectory;
+/**
+ * We copy .yarnrc to the temporary directory to ensure things like the specified
+ * package registry are still used. However, there are a few relative paths that can
+ * cause issues, so we modify them to fit the new directory.
+ *
+ * Exported for testing - not meant to be used outside of this file.
+ *
+ * @param contents The string contents of the yarnrc.yml file
+ * @returns Updated string contents of the yarnrc.yml file
+ */
+function modifyYarnRcToFitNewDirectory(contents) {
+    const lines = contents.split('\n');
+    const yarnPathIndex = lines.findIndex((line) => line.startsWith('yarn-path'));
+    if (yarnPathIndex !== -1) {
+        lines.splice(yarnPathIndex, 1);
+    }
+    return lines.join('\n');
+}
+exports.modifyYarnRcToFitNewDirectory = modifyYarnRcToFitNewDirectory;
+function copyPackageManagerConfigurationFiles(root, destination) {
+    for (const packageManagerConfigFile of ['.npmrc', '.yarnrc', '.yarnrc.yml']) {
+        // f is an absolute path, including the {workspaceRoot}.
+        const f = findFileInPackageJsonDirectory(packageManagerConfigFile, root);
+        if (f) {
+            // Destination should be the same relative path from the {workspaceRoot},
+            // but now relative to the destination. `relative` makes `{workspaceRoot}/some/path`
+            // look like `./some/path`, and joining that gets us `{destination}/some/path
+            const destinationPath = (0, path_1.join)(destination, (0, path_1.relative)(root, f));
+            switch (packageManagerConfigFile) {
+                case '.npmrc': {
+                    (0, fs_1.copyFileSync)(f, destinationPath);
+                    break;
+                }
+                case '.yarnrc': {
+                    const updated = modifyYarnRcToFitNewDirectory((0, fileutils_1.readFileIfExisting)(f));
+                    (0, fs_1.writeFileSync)(destinationPath, updated);
+                    break;
+                }
+                case '.yarnrc.yml': {
+                    const updated = modifyYarnRcYmlToFitNewDirectory((0, fileutils_1.readFileIfExisting)(f));
+                    (0, fs_1.writeFileSync)(destinationPath, updated);
+                    break;
+                }
+            }
+        }
+    }
+}
+exports.copyPackageManagerConfigurationFiles = copyPackageManagerConfigurationFiles;
+/**
+ * Creates a temporary directory where you can run package manager commands safely.
+ *
+ * For cases where you'd want to install packages that require an `.npmrc` set up,
+ * this function looks up for the nearest `.npmrc` (if exists) and copies it over to the
+ * temp directory.
+ */
+function createTempNpmDirectory() {
+    const dir = (0, tmp_1.dirSync)().name;
+    // A package.json is needed for pnpm pack and for .npmrc to resolve
+    (0, fileutils_1.writeJsonFile)(`${dir}/package.json`, {});
+    copyPackageManagerConfigurationFiles(workspace_root_1.workspaceRoot, dir);
+    const cleanup = async () => {
+        try {
+            await (0, fs_extra_1.remove)(dir);
+        }
+        catch {
+            // It's okay if this fails, the OS will clean it up eventually
+        }
+    };
+    return { dir, cleanup };
+}
+exports.createTempNpmDirectory = createTempNpmDirectory;
+/**
+ * Returns the resolved version for a given package and version tag using the
+ * NPM registry (when using Yarn it will fall back to NPM to fetch the info).
+ */
+async function resolvePackageVersionUsingRegistry(packageName, version) {
+    try {
+        const result = await packageRegistryView(packageName, version, 'version');
+        if (!result) {
+            throw new Error(`Unable to resolve version ${packageName}@${version}.`);
+        }
+        // get the last line of the output, strip the package version and quotes
+        const resolvedVersion = result
+            .split('\n')
+            .pop()
+            .split(' ')
+            .pop()
+            .replace(/'/g, '');
+        return resolvedVersion;
+    }
+    catch {
+        throw new Error(`Unable to resolve version ${packageName}@${version}.`);
+    }
+}
+exports.resolvePackageVersionUsingRegistry = resolvePackageVersionUsingRegistry;
+/**
+ * Return the resolved version for a given package and version tag using by
+ * installing it in a temporary directory and fetching the version from the
+ * package.json.
+ */
+async function resolvePackageVersionUsingInstallation(packageName, version) {
+    const { dir, cleanup } = createTempNpmDirectory();
+    try {
+        const pmc = getPackageManagerCommand();
+        await execAsync(`${pmc.add} ${packageName}@${version}`, { cwd: dir });
+        const { packageJson } = (0, package_json_1.readModulePackageJson)(packageName, [dir]);
+        return packageJson.version;
+    }
+    finally {
+        await cleanup();
+    }
+}
+exports.resolvePackageVersionUsingInstallation = resolvePackageVersionUsingInstallation;
+async function packageRegistryView(pkg, version, args) {
+    let pm = detectPackageManager();
+    if (pm === 'yarn') {
+        /**
+         * yarn has `yarn info` but it behaves differently than (p)npm,
+         * which makes it's usage unreliable
+         *
+         * @see https://github.com/nrwl/nx/pull/9667#discussion_r842553994
+         */
+        pm = 'npm';
+    }
+    const { stdout } = await execAsync(`${pm} view ${pkg}@${version} ${args}`);
+    return stdout.toString().trim();
+}
+exports.packageRegistryView = packageRegistryView;
+async function packageRegistryPack(cwd, pkg, version) {
+    let pm = detectPackageManager();
+    if (pm === 'yarn') {
+        /**
+         * `(p)npm pack` will download a tarball of the specified version,
+         * whereas `yarn` pack creates a tarball of the active workspace, so it
+         * does not work for getting the content of a library.
+         *
+         * @see https://github.com/nrwl/nx/pull/9667#discussion_r842553994
+         */
+        pm = 'npm';
+    }
+    const { stdout } = await execAsync(`${pm} pack ${pkg}@${version}`, { cwd });
+    const tarballPath = stdout.trim();
+    return { tarballPath };
+}
+exports.packageRegistryPack = packageRegistryPack;
 
-"use strict";
-module.exports = require("os");
 
 /***/ }),
 
-/***/ 71017:
-/***/ ((module) => {
+/***/ 38270:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
 "use strict";
-module.exports = require("path");
 
-/***/ }),
-
-/***/ 4074:
-/***/ ((module) => {
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.getCwd = exports.joinPathFragments = exports.normalizePath = void 0;
+const path = __nccwpck_require__(71017);
+const workspace_root_1 = __nccwpck_require__(86708);
+function removeWindowsDriveLetter(osSpecificPath) {
+    return osSpecificPath.replace(/^[A-Z]:/, '');
+}
+/**
+ * Coverts an os specific path to a unix style path. Use this when writing paths to config files.
+ * This should not be used to read files on disk because of the removal of Windows drive letters.
+ */
+function normalizePath(osSpecificPath) {
+    return removeWindowsDriveLetter(osSpecificPath).split('\\').join('/');
+}
+exports.normalizePath = normalizePath;
+/**
+ * Normalized path fragments and joins them. Use this when writing paths to config files.
+ * This should not be used to read files on disk because of the removal of Windows drive letters.
+ */
+function joinPathFragments(...fragments) {
+    return normalizePath(path.join(...fragments));
+}
+exports.joinPathFragments = joinPathFragments;
+/**
+ * When running a script with the package manager (e.g. `npm run`), the package manager will
+ * traverse the directory tree upwards until it finds a `package.json` and will set `process.cwd()`
+ * to the folder where it found it. The actual working directory is stored in the INIT_CWD
+ * environment variable (see here: https://docs.npmjs.com/cli/v9/commands/npm-run-script#description).
+ *
+ * @returns The path to the current working directory.
+ */
+function getCwd() {
+    return process.env.INIT_CWD?.startsWith(workspace_root_1.workspaceRoot)
+        ? process.env.INIT_CWD
+        : process.cwd();
+}
+exports.getCwd = getCwd;
 
-"use strict";
-module.exports = require("perf_hooks");
 
 /***/ }),
 
-/***/ 38102:
-/***/ ((module) => {
+/***/ 71067:
+/***/ ((__unused_webpack_module, exports) => {
 
 "use strict";
-module.exports = require("repl");
-
-/***/ }),
 
-/***/ 12781:
-/***/ ((module) => {
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.PromisedBasedQueue = void 0;
+class PromisedBasedQueue {
+    constructor() {
+        this.counter = 0;
+        this.promise = Promise.resolve(null);
+    }
+    sendToQueue(fn) {
+        this.counter++;
+        let res, rej;
+        const r = new Promise((_res, _rej) => {
+            res = _res;
+            rej = _rej;
+        });
+        this.promise = this.promise
+            .then(async () => {
+            try {
+                res(await fn());
+                this.counter--;
+            }
+            catch (e) {
+                rej(e);
+                this.counter--;
+            }
+        })
+            .catch(async () => {
+            try {
+                res(await fn());
+                this.counter--;
+            }
+            catch (e) {
+                rej(e);
+                this.counter--;
+            }
+        });
+        return r;
+    }
+    isEmpty() {
+        return this.counter === 0;
+    }
+}
+exports.PromisedBasedQueue = PromisedBasedQueue;
 
-"use strict";
-module.exports = require("stream");
 
 /***/ }),
 
-/***/ 71576:
-/***/ ((module) => {
+/***/ 98487:
+/***/ ((__unused_webpack_module, exports) => {
 
 "use strict";
-module.exports = require("string_decoder");
-
-/***/ }),
 
-/***/ 24404:
-/***/ ((module) => {
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.stripIndents = void 0;
+/**
+ * Removes indents, which is useful for printing warning and messages.
+ *
+ * Example:
+ *
+ * ```typescript
+ * stripIndents`
+ *  Options:
+ *  - option1
+ *  - option2
+ * `
+ * ```
+ */
+function stripIndents(strings, ...values) {
+    return String.raw(strings, ...values)
+        .split('\n')
+        .map((line) => line.trim())
+        .join('\n')
+        .trim();
+}
+exports.stripIndents = stripIndents;
 
-"use strict";
-module.exports = require("tls");
 
 /***/ }),
 
-/***/ 76224:
-/***/ ((module) => {
+/***/ 92941:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
 "use strict";
-module.exports = require("tty");
 
-/***/ }),
-
-/***/ 57310:
-/***/ ((module) => {
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.nxVersion = void 0;
+exports.nxVersion = __nccwpck_require__(89617).version;
 
-"use strict";
-module.exports = require("url");
 
 /***/ }),
 
-/***/ 73837:
-/***/ ((module) => {
+/***/ 302:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
 "use strict";
-module.exports = require("util");
-
-/***/ }),
 
-/***/ 26144:
-/***/ ((module) => {
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.resetWorkspaceContext = exports.updateProjectFiles = exports.getFilesInDirectoryUsingContext = exports.getAllFileDataInContext = exports.updateFilesInContext = exports.hashWithWorkspaceContext = exports.globWithWorkspaceContext = exports.getNxWorkspaceFilesFromContext = exports.setupWorkspaceContext = void 0;
+const perf_hooks_1 = __nccwpck_require__(4074);
+const cache_directory_1 = __nccwpck_require__(15120);
+let workspaceContext;
+function setupWorkspaceContext(workspaceRoot) {
+    const { WorkspaceContext } = __nccwpck_require__(74424);
+    perf_hooks_1.performance.mark('workspace-context');
+    workspaceContext = new WorkspaceContext(workspaceRoot, (0, cache_directory_1.cacheDirectoryForWorkspace)(workspaceRoot));
+    perf_hooks_1.performance.mark('workspace-context:end');
+    perf_hooks_1.performance.measure('workspace context init', 'workspace-context', 'workspace-context:end');
+}
+exports.setupWorkspaceContext = setupWorkspaceContext;
+function getNxWorkspaceFilesFromContext(workspaceRoot, projectRootMap) {
+    ensureContextAvailable(workspaceRoot);
+    return workspaceContext.getWorkspaceFiles(projectRootMap);
+}
+exports.getNxWorkspaceFilesFromContext = getNxWorkspaceFilesFromContext;
+function globWithWorkspaceContext(workspaceRoot, globs, exclude) {
+    ensureContextAvailable(workspaceRoot);
+    return workspaceContext.glob(globs, exclude);
+}
+exports.globWithWorkspaceContext = globWithWorkspaceContext;
+function hashWithWorkspaceContext(workspaceRoot, globs, exclude) {
+    ensureContextAvailable(workspaceRoot);
+    return workspaceContext.hashFilesMatchingGlob(globs, exclude);
+}
+exports.hashWithWorkspaceContext = hashWithWorkspaceContext;
+function updateFilesInContext(updatedFiles, deletedFiles) {
+    return workspaceContext?.incrementalUpdate(updatedFiles, deletedFiles);
+}
+exports.updateFilesInContext = updateFilesInContext;
+function getAllFileDataInContext(workspaceRoot) {
+    ensureContextAvailable(workspaceRoot);
+    return workspaceContext.allFileData();
+}
+exports.getAllFileDataInContext = getAllFileDataInContext;
+function getFilesInDirectoryUsingContext(workspaceRoot, dir) {
+    ensureContextAvailable(workspaceRoot);
+    return workspaceContext.getFilesInDirectory(dir);
+}
+exports.getFilesInDirectoryUsingContext = getFilesInDirectoryUsingContext;
+function updateProjectFiles(projectRootMappings, rustReferences, updatedFiles, deletedFiles) {
+    return workspaceContext?.updateProjectFiles(projectRootMappings, rustReferences.projectFiles, rustReferences.globalFiles, updatedFiles, deletedFiles);
+}
+exports.updateProjectFiles = updateProjectFiles;
+function ensureContextAvailable(workspaceRoot) {
+    if (!workspaceContext || workspaceContext?.workspaceRoot !== workspaceRoot) {
+        setupWorkspaceContext(workspaceRoot);
+    }
+}
+function resetWorkspaceContext() {
+    workspaceContext = undefined;
+}
+exports.resetWorkspaceContext = resetWorkspaceContext;
 
-"use strict";
-module.exports = require("vm");
 
 /***/ }),
 
-/***/ 71267:
-/***/ ((module) => {
+/***/ 86708:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
 "use strict";
-module.exports = require("worker_threads");
-
-/***/ }),
 
-/***/ 59796:
-/***/ ((module) => {
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.workspaceRootInner = exports.setWorkspaceRoot = exports.workspaceRoot = void 0;
+const path = __nccwpck_require__(71017);
+const fileutils_1 = __nccwpck_require__(83851);
+/**
+ * The root of the workspace
+ */
+exports.workspaceRoot = workspaceRootInner(process.cwd(), process.cwd());
+// Required for integration tests in projects which depend on Nx at runtime, such as lerna and angular-eslint
+function setWorkspaceRoot(root) {
+    exports.workspaceRoot = root;
+}
+exports.setWorkspaceRoot = setWorkspaceRoot;
+function workspaceRootInner(dir, candidateRoot) {
+    if (process.env.NX_WORKSPACE_ROOT_PATH)
+        return process.env.NX_WORKSPACE_ROOT_PATH;
+    if (path.dirname(dir) === dir)
+        return candidateRoot;
+    const matches = [
+        path.join(dir, 'nx.json'),
+        path.join(dir, 'nx'),
+        path.join(dir, 'nx.bat'),
+    ];
+    if (matches.some((x) => (0, fileutils_1.fileExists)(x))) {
+        return dir;
+        // This handles the case where we have a workspace which uses npm / yarn / pnpm
+        // workspaces, and has a project which contains Nx in its dependency tree.
+        // e.g. packages/my-lib/package.json contains @nx/devkit, which references Nx and is
+        // thus located in //packages/my-lib/node_modules/nx/package.json
+    }
+    else if ((0, fileutils_1.fileExists)(path.join(dir, 'node_modules', 'nx', 'package.json'))) {
+        return workspaceRootInner(path.dirname(dir), dir);
+    }
+    else {
+        return workspaceRootInner(path.dirname(dir), candidateRoot);
+    }
+}
+exports.workspaceRootInner = workspaceRootInner;
 
-"use strict";
-module.exports = require("zlib");
 
 /***/ }),
 
-/***/ 90583:
+/***/ 6613:
 /***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
 "use strict";
@@ -273475,7 +285105,7 @@ exports.yellowBright = yellowBright;
 
 /***/ }),
 
-/***/ 74570:
+/***/ 16106:
 /***/ ((__unused_webpack_module, exports) => {
 
 "use strict";
@@ -273548,7 +285178,7 @@ exports.LinesAndColumns = LinesAndColumns;
 /***/ ((module) => {
 
 "use strict";
-module.exports = {"version":"1.3.73"};
+module.exports = {"version":"1.4.0"};
 
 /***/ }),
 
@@ -273588,7 +285218,7 @@ module.exports = JSON.parse('{"$schema":"https://json.schemastore.org/tsconfig",
 /***/ ((module) => {
 
 "use strict";
-module.exports = {"version":"16.3.2"};
+module.exports = {"version":"18.0.2"};
 
 /***/ }),
 
@@ -273596,7 +285226,7 @@ module.exports = {"version":"16.3.2"};
 /***/ ((module) => {
 
 "use strict";
-module.exports = {"version":"10.9.1"};
+module.exports = {"version":"10.9.2"};
 
 /***/ })
 
@@ -273662,13 +285292,13 @@ var __webpack_exports__ = {};
 var exports = __webpack_exports__;
 
 Object.defineProperty(exports, "__esModule", ({ value: true }));
-const tslib_1 = __nccwpck_require__(65315);
-const core = tslib_1.__importStar(__nccwpck_require__(57896));
-const tree_1 = __nccwpck_require__(75138);
-const project_configuration_1 = __nccwpck_require__(41172);
+const tslib_1 = __nccwpck_require__(41464);
+const core = tslib_1.__importStar(__nccwpck_require__(44712));
+const tree_1 = __nccwpck_require__(11385);
+const project_configuration_1 = __nccwpck_require__(1934);
 const path_1 = __nccwpck_require__(71017);
-const exec_1 = __nccwpck_require__(33882);
-const has_one_of_required_tags_1 = __nccwpck_require__(47777);
+const exec_1 = __nccwpck_require__(11298);
+const has_one_of_required_tags_1 = __nccwpck_require__(28328);
 function run() {
     return tslib_1.__awaiter(this, void 0, void 0, function* () {
         try {
diff --git a/actions/plan/dist/nx.darwin-arm64.node b/actions/plan/dist/nx.darwin-arm64.node
deleted file mode 100644
index 5092a17c..00000000
Binary files a/actions/plan/dist/nx.darwin-arm64.node and /dev/null differ
diff --git a/actions/plan/dist/register.js b/actions/plan/dist/register.js
deleted file mode 100644
index 4f68e67d..00000000
--- a/actions/plan/dist/register.js
+++ /dev/null
@@ -1 +0,0 @@
-require('./').install();
diff --git a/actions/plan/dist/src/plan.d.ts b/actions/plan/dist/src/plan.d.ts
deleted file mode 100644
index cb0ff5c3..00000000
--- a/actions/plan/dist/src/plan.d.ts
+++ /dev/null
@@ -1 +0,0 @@
-export {};
diff --git a/actions/plan/dist/src/utils/exec.d.ts b/actions/plan/dist/src/utils/exec.d.ts
deleted file mode 100644
index b7becd36..00000000
--- a/actions/plan/dist/src/utils/exec.d.ts
+++ /dev/null
@@ -1,12 +0,0 @@
-import { ChildProcess } from 'child_process';
-import type { ExecOptions, ShellString } from 'shelljs';
-export interface Options extends ExecOptions {
-    asString?: boolean;
-    asJSON?: boolean;
-}
-export { ShellString, ChildProcess };
-export type Result = Output extends string ? string : Output;
-export declare const execCommand: (command: any, options?: Options) => Output;
diff --git a/actions/plan/dist/src/utils/has-one-of-required-tags.d.ts b/actions/plan/dist/src/utils/has-one-of-required-tags.d.ts
deleted file mode 100644
index 71f51c9d..00000000
--- a/actions/plan/dist/src/utils/has-one-of-required-tags.d.ts
+++ /dev/null
@@ -1,2 +0,0 @@
-export declare function cleanLogConditions(conditions: string[]): string;
-export declare function hasOneOfRequiredTags(projectName: string, tags?: string[], requiresOnOfTheseTagConditions?: string[]): boolean;
diff --git a/actions/plan/dist/swc.darwin-arm64.node b/actions/plan/dist/swc.darwin-arm64.node
deleted file mode 100644
index b0233853..00000000
Binary files a/actions/plan/dist/swc.darwin-arm64.node and /dev/null differ
diff --git a/actions/plan/dist/swc.js b/actions/plan/dist/swc.js
deleted file mode 100644
index eeddd4fb..00000000
--- a/actions/plan/dist/swc.js
+++ /dev/null
@@ -1,212 +0,0 @@
-"use strict";
-Object.defineProperty(exports, "__esModule", { value: true });
-exports.createSwcOptions = exports.targetMapping = exports.create = void 0;
-function create(createOptions) {
-    const { swc, service: { config, projectLocalResolveHelper }, transpilerConfigLocalResolveHelper, nodeModuleEmitKind, } = createOptions;
-    // Load swc compiler
-    let swcInstance;
-    // Used later in diagnostics; merely needs to be human-readable.
-    let swcDepName = 'swc';
-    if (typeof swc === 'string') {
-        swcDepName = swc;
-        swcInstance = require(transpilerConfigLocalResolveHelper(swc, true));
-    }
-    else if (swc == null) {
-        let swcResolved;
-        try {
-            swcDepName = '@swc/core';
-            swcResolved = transpilerConfigLocalResolveHelper(swcDepName, true);
-        }
-        catch (e) {
-            try {
-                swcDepName = '@swc/wasm';
-                swcResolved = transpilerConfigLocalResolveHelper(swcDepName, true);
-            }
-            catch (e) {
-                throw new Error('swc compiler requires either @swc/core or @swc/wasm to be installed as a dependency.  See https://typestrong.org/ts-node/docs/transpilers');
-            }
-        }
-        swcInstance = require(swcResolved);
-    }
-    else {
-        swcInstance = swc;
-    }
-    // Prepare SWC options derived from typescript compiler options
-    const { nonTsxOptions, tsxOptions } = createSwcOptions(config.options, nodeModuleEmitKind, swcInstance, swcDepName);
-    const transpile = (input, transpileOptions) => {
-        const { fileName } = transpileOptions;
-        const swcOptions = fileName.endsWith('.tsx') || fileName.endsWith('.jsx')
-            ? tsxOptions
-            : nonTsxOptions;
-        const { code, map } = swcInstance.transformSync(input, {
-            ...swcOptions,
-            filename: fileName,
-        });
-        return { outputText: code, sourceMapText: map };
-    };
-    return {
-        transpile,
-    };
-}
-exports.create = create;
-/** @internal */
-exports.targetMapping = new Map();
-exports.targetMapping.set(/* ts.ScriptTarget.ES3 */ 0, 'es3');
-exports.targetMapping.set(/* ts.ScriptTarget.ES5 */ 1, 'es5');
-exports.targetMapping.set(/* ts.ScriptTarget.ES2015 */ 2, 'es2015');
-exports.targetMapping.set(/* ts.ScriptTarget.ES2016 */ 3, 'es2016');
-exports.targetMapping.set(/* ts.ScriptTarget.ES2017 */ 4, 'es2017');
-exports.targetMapping.set(/* ts.ScriptTarget.ES2018 */ 5, 'es2018');
-exports.targetMapping.set(/* ts.ScriptTarget.ES2019 */ 6, 'es2019');
-exports.targetMapping.set(/* ts.ScriptTarget.ES2020 */ 7, 'es2020');
-exports.targetMapping.set(/* ts.ScriptTarget.ES2021 */ 8, 'es2021');
-exports.targetMapping.set(/* ts.ScriptTarget.ES2022 */ 9, 'es2022');
-exports.targetMapping.set(/* ts.ScriptTarget.ESNext */ 99, 'es2022');
-/**
- * @internal
- * We use this list to downgrade to a prior target when we probe swc to detect if it supports a particular target
- */
-const swcTargets = [
-    'es3',
-    'es5',
-    'es2015',
-    'es2016',
-    'es2017',
-    'es2018',
-    'es2019',
-    'es2020',
-    'es2021',
-    'es2022',
-];
-const ModuleKind = {
-    None: 0,
-    CommonJS: 1,
-    AMD: 2,
-    UMD: 3,
-    System: 4,
-    ES2015: 5,
-    ES2020: 6,
-    ESNext: 99,
-    Node16: 100,
-    NodeNext: 199,
-};
-const JsxEmit = {
-    ReactJSX: /* ts.JsxEmit.ReactJSX */ 4,
-    ReactJSXDev: /* ts.JsxEmit.ReactJSXDev */ 5,
-};
-/**
- * Prepare SWC options derived from typescript compiler options.
- * @internal exported for testing
- */
-function createSwcOptions(compilerOptions, nodeModuleEmitKind, swcInstance, swcDepName) {
-    var _a;
-    const { esModuleInterop, sourceMap, importHelpers, experimentalDecorators, emitDecoratorMetadata, target, module, jsx, jsxFactory, jsxFragmentFactory, strict, alwaysStrict, noImplicitUseStrict, } = compilerOptions;
-    let swcTarget = (_a = exports.targetMapping.get(target)) !== null && _a !== void 0 ? _a : 'es3';
-    // Downgrade to lower target if swc does not support the selected target.
-    // Perhaps project has an older version of swc.
-    // TODO cache the results of this; slightly faster
-    let swcTargetIndex = swcTargets.indexOf(swcTarget);
-    for (; swcTargetIndex >= 0; swcTargetIndex--) {
-        try {
-            swcInstance.transformSync('', {
-                jsc: { target: swcTargets[swcTargetIndex] },
-            });
-            break;
-        }
-        catch (e) { }
-    }
-    swcTarget = swcTargets[swcTargetIndex];
-    const keepClassNames = target >= /* ts.ScriptTarget.ES2016 */ 3;
-    const isNodeModuleKind = module === ModuleKind.Node16 || module === ModuleKind.NodeNext;
-    // swc only supports these 4x module options [MUST_UPDATE_FOR_NEW_MODULEKIND]
-    const moduleType = module === ModuleKind.CommonJS
-        ? 'commonjs'
-        : module === ModuleKind.AMD
-            ? 'amd'
-            : module === ModuleKind.UMD
-                ? 'umd'
-                : isNodeModuleKind && nodeModuleEmitKind === 'nodecjs'
-                    ? 'commonjs'
-                    : isNodeModuleKind && nodeModuleEmitKind === 'nodeesm'
-                        ? 'es6'
-                        : 'es6';
-    // In swc:
-    //   strictMode means `"use strict"` is *always* emitted for non-ES module, *never* for ES module where it is assumed it can be omitted.
-    //   (this assumption is invalid, but that's the way swc behaves)
-    // tsc is a bit more complex:
-    //   alwaysStrict will force emitting it always unless `import`/`export` syntax is emitted which implies it per the JS spec.
-    //   if not alwaysStrict, will emit implicitly whenever module target is non-ES *and* transformed module syntax is emitted.
-    // For node, best option is to assume that all scripts are modules (commonjs or esm) and thus should get tsc's implicit strict behavior.
-    // Always set strictMode, *unless* alwaysStrict is disabled and noImplicitUseStrict is enabled
-    const strictMode = 
-    // if `alwaysStrict` is disabled, remembering that `strict` defaults `alwaysStrict` to true
-    (alwaysStrict === false || (alwaysStrict !== true && strict !== true)) &&
-        // if noImplicitUseStrict is enabled
-        noImplicitUseStrict === true
-        ? false
-        : true;
-    const jsxRuntime = jsx === JsxEmit.ReactJSX || jsx === JsxEmit.ReactJSXDev
-        ? 'automatic'
-        : undefined;
-    const jsxDevelopment = jsx === JsxEmit.ReactJSXDev ? true : undefined;
-    const nonTsxOptions = createVariant(false);
-    const tsxOptions = createVariant(true);
-    return { nonTsxOptions, tsxOptions };
-    function createVariant(isTsx) {
-        const swcOptions = {
-            sourceMaps: sourceMap,
-            // isModule: true,
-            module: moduleType
-                ? {
-                    noInterop: !esModuleInterop,
-                    type: moduleType,
-                    strictMode,
-                    // For NodeNext and Node12, emit as CJS but do not transform dynamic imports
-                    ignoreDynamic: nodeModuleEmitKind === 'nodecjs',
-                }
-                : undefined,
-            swcrc: false,
-            jsc: {
-                externalHelpers: importHelpers,
-                parser: {
-                    syntax: 'typescript',
-                    tsx: isTsx,
-                    decorators: experimentalDecorators,
-                    dynamicImport: true,
-                    importAssertions: true,
-                },
-                target: swcTarget,
-                transform: {
-                    decoratorMetadata: emitDecoratorMetadata,
-                    legacyDecorator: true,
-                    react: {
-                        throwIfNamespace: false,
-                        development: jsxDevelopment,
-                        useBuiltins: false,
-                        pragma: jsxFactory,
-                        pragmaFrag: jsxFragmentFactory,
-                        runtime: jsxRuntime,
-                    },
-                },
-                keepClassNames,
-                experimental: {
-                    keepImportAssertions: true,
-                },
-            },
-        };
-        // Throw a helpful error if swc version is old, for example, if it rejects `ignoreDynamic`
-        try {
-            swcInstance.transformSync('', swcOptions);
-        }
-        catch (e) {
-            throw new Error(`${swcDepName} threw an error when attempting to validate swc compiler options.\n` +
-                'You may be using an old version of swc which does not support the options used by ts-node.\n' +
-                'Try upgrading to the latest version of swc.\n' +
-                'Error message from swc:\n' +
-                (e === null || e === void 0 ? void 0 : e.message));
-        }
-        return swcOptions;
-    }
-}
-exports.createSwcOptions = createSwcOptions;
-//# sourceMappingURL=swc.js.map
\ No newline at end of file
diff --git a/actions/plan/dist/typescript.js b/actions/plan/dist/typescript.js
deleted file mode 100644
index 589e2c2e..00000000
--- a/actions/plan/dist/typescript.js
+++ /dev/null
@@ -1,171676 +0,0 @@
-/*! *****************************************************************************
-Copyright (c) Microsoft Corporation. All rights reserved.
-Licensed under the Apache License, Version 2.0 (the "License"); you may not use
-this file except in compliance with the License. You may obtain a copy of the
-License at http://www.apache.org/licenses/LICENSE-2.0
-
-THIS CODE IS PROVIDED ON AN *AS IS* BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
-KIND, EITHER EXPRESS OR IMPLIED, INCLUDING WITHOUT LIMITATION ANY IMPLIED
-WARRANTIES OR CONDITIONS OF TITLE, FITNESS FOR A PARTICULAR PURPOSE,
-MERCHANTABLITY OR NON-INFRINGEMENT.
-
-See the Apache Version 2.0 License for specific language governing permissions
-and limitations under the License.
-***************************************************************************** */
-
-
-"use strict";
-var ts = (() => {
-  var __defProp = Object.defineProperty;
-  var __getOwnPropNames = Object.getOwnPropertyNames;
-  var __esm = (fn, res) => function __init() {
-    return fn && (res = (0, fn[__getOwnPropNames(fn)[0]])(fn = 0)), res;
-  };
-  var __commonJS = (cb, mod) => function __require() {
-    return mod || (0, cb[__getOwnPropNames(cb)[0]])((mod = { exports: {} }).exports, mod), mod.exports;
-  };
-  var __export = (target, all) => {
-    for (var name in all)
-      __defProp(target, name, { get: all[name], enumerable: true });
-  };
-
-  // src/compiler/corePublic.ts
-  var versionMajorMinor, version, Comparison;
-  var init_corePublic = __esm({
-    "src/compiler/corePublic.ts"() {
-      "use strict";
-      versionMajorMinor = "5.1";
-      version = "5.1.6";
-      Comparison = /* @__PURE__ */ ((Comparison3) => {
-        Comparison3[Comparison3["LessThan"] = -1] = "LessThan";
-        Comparison3[Comparison3["EqualTo"] = 0] = "EqualTo";
-        Comparison3[Comparison3["GreaterThan"] = 1] = "GreaterThan";
-        return Comparison3;
-      })(Comparison || {});
-    }
-  });
-
-  // src/compiler/core.ts
-  function length(array) {
-    return array ? array.length : 0;
-  }
-  function forEach(array, callback) {
-    if (array) {
-      for (let i = 0; i < array.length; i++) {
-        const result = callback(array[i], i);
-        if (result) {
-          return result;
-        }
-      }
-    }
-    return void 0;
-  }
-  function forEachRight(array, callback) {
-    if (array) {
-      for (let i = array.length - 1; i >= 0; i--) {
-        const result = callback(array[i], i);
-        if (result) {
-          return result;
-        }
-      }
-    }
-    return void 0;
-  }
-  function firstDefined(array, callback) {
-    if (array === void 0) {
-      return void 0;
-    }
-    for (let i = 0; i < array.length; i++) {
-      const result = callback(array[i], i);
-      if (result !== void 0) {
-        return result;
-      }
-    }
-    return void 0;
-  }
-  function firstDefinedIterator(iter, callback) {
-    for (const value of iter) {
-      const result = callback(value);
-      if (result !== void 0) {
-        return result;
-      }
-    }
-    return void 0;
-  }
-  function reduceLeftIterator(iterator, f, initial) {
-    let result = initial;
-    if (iterator) {
-      let pos = 0;
-      for (const value of iterator) {
-        result = f(result, value, pos);
-        pos++;
-      }
-    }
-    return result;
-  }
-  function zipWith(arrayA, arrayB, callback) {
-    const result = [];
-    Debug.assertEqual(arrayA.length, arrayB.length);
-    for (let i = 0; i < arrayA.length; i++) {
-      result.push(callback(arrayA[i], arrayB[i], i));
-    }
-    return result;
-  }
-  function intersperse(input, element) {
-    if (input.length <= 1) {
-      return input;
-    }
-    const result = [];
-    for (let i = 0, n = input.length; i < n; i++) {
-      if (i)
-        result.push(element);
-      result.push(input[i]);
-    }
-    return result;
-  }
-  function every(array, callback) {
-    if (array) {
-      for (let i = 0; i < array.length; i++) {
-        if (!callback(array[i], i)) {
-          return false;
-        }
-      }
-    }
-    return true;
-  }
-  function find(array, predicate, startIndex) {
-    if (array === void 0)
-      return void 0;
-    for (let i = startIndex ?? 0; i < array.length; i++) {
-      const value = array[i];
-      if (predicate(value, i)) {
-        return value;
-      }
-    }
-    return void 0;
-  }
-  function findLast(array, predicate, startIndex) {
-    if (array === void 0)
-      return void 0;
-    for (let i = startIndex ?? array.length - 1; i >= 0; i--) {
-      const value = array[i];
-      if (predicate(value, i)) {
-        return value;
-      }
-    }
-    return void 0;
-  }
-  function findIndex(array, predicate, startIndex) {
-    if (array === void 0)
-      return -1;
-    for (let i = startIndex ?? 0; i < array.length; i++) {
-      if (predicate(array[i], i)) {
-        return i;
-      }
-    }
-    return -1;
-  }
-  function findLastIndex(array, predicate, startIndex) {
-    if (array === void 0)
-      return -1;
-    for (let i = startIndex ?? array.length - 1; i >= 0; i--) {
-      if (predicate(array[i], i)) {
-        return i;
-      }
-    }
-    return -1;
-  }
-  function findMap(array, callback) {
-    for (let i = 0; i < array.length; i++) {
-      const result = callback(array[i], i);
-      if (result) {
-        return result;
-      }
-    }
-    return Debug.fail();
-  }
-  function contains(array, value, equalityComparer = equateValues) {
-    if (array) {
-      for (const v of array) {
-        if (equalityComparer(v, value)) {
-          return true;
-        }
-      }
-    }
-    return false;
-  }
-  function arraysEqual(a, b, equalityComparer = equateValues) {
-    return a.length === b.length && a.every((x, i) => equalityComparer(x, b[i]));
-  }
-  function indexOfAnyCharCode(text, charCodes, start) {
-    for (let i = start || 0; i < text.length; i++) {
-      if (contains(charCodes, text.charCodeAt(i))) {
-        return i;
-      }
-    }
-    return -1;
-  }
-  function countWhere(array, predicate) {
-    let count = 0;
-    if (array) {
-      for (let i = 0; i < array.length; i++) {
-        const v = array[i];
-        if (predicate(v, i)) {
-          count++;
-        }
-      }
-    }
-    return count;
-  }
-  function filter(array, f) {
-    if (array) {
-      const len = array.length;
-      let i = 0;
-      while (i < len && f(array[i]))
-        i++;
-      if (i < len) {
-        const result = array.slice(0, i);
-        i++;
-        while (i < len) {
-          const item = array[i];
-          if (f(item)) {
-            result.push(item);
-          }
-          i++;
-        }
-        return result;
-      }
-    }
-    return array;
-  }
-  function filterMutate(array, f) {
-    let outIndex = 0;
-    for (let i = 0; i < array.length; i++) {
-      if (f(array[i], i, array)) {
-        array[outIndex] = array[i];
-        outIndex++;
-      }
-    }
-    array.length = outIndex;
-  }
-  function clear(array) {
-    array.length = 0;
-  }
-  function map(array, f) {
-    let result;
-    if (array) {
-      result = [];
-      for (let i = 0; i < array.length; i++) {
-        result.push(f(array[i], i));
-      }
-    }
-    return result;
-  }
-  function* mapIterator(iter, mapFn) {
-    for (const x of iter) {
-      yield mapFn(x);
-    }
-  }
-  function sameMap(array, f) {
-    if (array) {
-      for (let i = 0; i < array.length; i++) {
-        const item = array[i];
-        const mapped = f(item, i);
-        if (item !== mapped) {
-          const result = array.slice(0, i);
-          result.push(mapped);
-          for (i++; i < array.length; i++) {
-            result.push(f(array[i], i));
-          }
-          return result;
-        }
-      }
-    }
-    return array;
-  }
-  function flatten(array) {
-    const result = [];
-    for (const v of array) {
-      if (v) {
-        if (isArray(v)) {
-          addRange(result, v);
-        } else {
-          result.push(v);
-        }
-      }
-    }
-    return result;
-  }
-  function flatMap(array, mapfn) {
-    let result;
-    if (array) {
-      for (let i = 0; i < array.length; i++) {
-        const v = mapfn(array[i], i);
-        if (v) {
-          if (isArray(v)) {
-            result = addRange(result, v);
-          } else {
-            result = append(result, v);
-          }
-        }
-      }
-    }
-    return result || emptyArray;
-  }
-  function flatMapToMutable(array, mapfn) {
-    const result = [];
-    if (array) {
-      for (let i = 0; i < array.length; i++) {
-        const v = mapfn(array[i], i);
-        if (v) {
-          if (isArray(v)) {
-            addRange(result, v);
-          } else {
-            result.push(v);
-          }
-        }
-      }
-    }
-    return result;
-  }
-  function* flatMapIterator(iter, mapfn) {
-    for (const x of iter) {
-      const iter2 = mapfn(x);
-      if (!iter2)
-        continue;
-      yield* iter2;
-    }
-  }
-  function sameFlatMap(array, mapfn) {
-    let result;
-    if (array) {
-      for (let i = 0; i < array.length; i++) {
-        const item = array[i];
-        const mapped = mapfn(item, i);
-        if (result || item !== mapped || isArray(mapped)) {
-          if (!result) {
-            result = array.slice(0, i);
-          }
-          if (isArray(mapped)) {
-            addRange(result, mapped);
-          } else {
-            result.push(mapped);
-          }
-        }
-      }
-    }
-    return result || array;
-  }
-  function mapAllOrFail(array, mapFn) {
-    const result = [];
-    for (let i = 0; i < array.length; i++) {
-      const mapped = mapFn(array[i], i);
-      if (mapped === void 0) {
-        return void 0;
-      }
-      result.push(mapped);
-    }
-    return result;
-  }
-  function mapDefined(array, mapFn) {
-    const result = [];
-    if (array) {
-      for (let i = 0; i < array.length; i++) {
-        const mapped = mapFn(array[i], i);
-        if (mapped !== void 0) {
-          result.push(mapped);
-        }
-      }
-    }
-    return result;
-  }
-  function* mapDefinedIterator(iter, mapFn) {
-    for (const x of iter) {
-      const value = mapFn(x);
-      if (value !== void 0) {
-        yield value;
-      }
-    }
-  }
-  function mapDefinedEntries(map2, f) {
-    if (!map2) {
-      return void 0;
-    }
-    const result = /* @__PURE__ */ new Map();
-    map2.forEach((value, key) => {
-      const entry = f(key, value);
-      if (entry !== void 0) {
-        const [newKey, newValue] = entry;
-        if (newKey !== void 0 && newValue !== void 0) {
-          result.set(newKey, newValue);
-        }
-      }
-    });
-    return result;
-  }
-  function getOrUpdate(map2, key, callback) {
-    if (map2.has(key)) {
-      return map2.get(key);
-    }
-    const value = callback();
-    map2.set(key, value);
-    return value;
-  }
-  function tryAddToSet(set, value) {
-    if (!set.has(value)) {
-      set.add(value);
-      return true;
-    }
-    return false;
-  }
-  function* singleIterator(value) {
-    yield value;
-  }
-  function spanMap(array, keyfn, mapfn) {
-    let result;
-    if (array) {
-      result = [];
-      const len = array.length;
-      let previousKey;
-      let key;
-      let start = 0;
-      let pos = 0;
-      while (start < len) {
-        while (pos < len) {
-          const value = array[pos];
-          key = keyfn(value, pos);
-          if (pos === 0) {
-            previousKey = key;
-          } else if (key !== previousKey) {
-            break;
-          }
-          pos++;
-        }
-        if (start < pos) {
-          const v = mapfn(array.slice(start, pos), previousKey, start, pos);
-          if (v) {
-            result.push(v);
-          }
-          start = pos;
-        }
-        previousKey = key;
-        pos++;
-      }
-    }
-    return result;
-  }
-  function mapEntries(map2, f) {
-    if (!map2) {
-      return void 0;
-    }
-    const result = /* @__PURE__ */ new Map();
-    map2.forEach((value, key) => {
-      const [newKey, newValue] = f(key, value);
-      result.set(newKey, newValue);
-    });
-    return result;
-  }
-  function some(array, predicate) {
-    if (array) {
-      if (predicate) {
-        for (const v of array) {
-          if (predicate(v)) {
-            return true;
-          }
-        }
-      } else {
-        return array.length > 0;
-      }
-    }
-    return false;
-  }
-  function getRangesWhere(arr, pred, cb) {
-    let start;
-    for (let i = 0; i < arr.length; i++) {
-      if (pred(arr[i])) {
-        start = start === void 0 ? i : start;
-      } else {
-        if (start !== void 0) {
-          cb(start, i);
-          start = void 0;
-        }
-      }
-    }
-    if (start !== void 0)
-      cb(start, arr.length);
-  }
-  function concatenate(array1, array2) {
-    if (!some(array2))
-      return array1;
-    if (!some(array1))
-      return array2;
-    return [...array1, ...array2];
-  }
-  function selectIndex(_, i) {
-    return i;
-  }
-  function indicesOf(array) {
-    return array.map(selectIndex);
-  }
-  function deduplicateRelational(array, equalityComparer, comparer) {
-    const indices = indicesOf(array);
-    stableSortIndices(array, indices, comparer);
-    let last2 = array[indices[0]];
-    const deduplicated = [indices[0]];
-    for (let i = 1; i < indices.length; i++) {
-      const index = indices[i];
-      const item = array[index];
-      if (!equalityComparer(last2, item)) {
-        deduplicated.push(index);
-        last2 = item;
-      }
-    }
-    deduplicated.sort();
-    return deduplicated.map((i) => array[i]);
-  }
-  function deduplicateEquality(array, equalityComparer) {
-    const result = [];
-    for (const item of array) {
-      pushIfUnique(result, item, equalityComparer);
-    }
-    return result;
-  }
-  function deduplicate(array, equalityComparer, comparer) {
-    return array.length === 0 ? [] : array.length === 1 ? array.slice() : comparer ? deduplicateRelational(array, equalityComparer, comparer) : deduplicateEquality(array, equalityComparer);
-  }
-  function deduplicateSorted(array, comparer) {
-    if (array.length === 0)
-      return emptyArray;
-    let last2 = array[0];
-    const deduplicated = [last2];
-    for (let i = 1; i < array.length; i++) {
-      const next = array[i];
-      switch (comparer(next, last2)) {
-        case true:
-        case 0 /* EqualTo */:
-          continue;
-        case -1 /* LessThan */:
-          return Debug.fail("Array is unsorted.");
-      }
-      deduplicated.push(last2 = next);
-    }
-    return deduplicated;
-  }
-  function createSortedArray() {
-    return [];
-  }
-  function insertSorted(array, insert, compare, allowDuplicates) {
-    if (array.length === 0) {
-      array.push(insert);
-      return true;
-    }
-    const insertIndex = binarySearch(array, insert, identity, compare);
-    if (insertIndex < 0) {
-      array.splice(~insertIndex, 0, insert);
-      return true;
-    }
-    if (allowDuplicates) {
-      array.splice(insertIndex, 0, insert);
-      return true;
-    }
-    return false;
-  }
-  function sortAndDeduplicate(array, comparer, equalityComparer) {
-    return deduplicateSorted(sort(array, comparer), equalityComparer || comparer || compareStringsCaseSensitive);
-  }
-  function arrayIsSorted(array, comparer) {
-    if (array.length < 2)
-      return true;
-    for (let i = 1, len = array.length; i < len; i++) {
-      if (comparer(array[i - 1], array[i]) === 1 /* GreaterThan */) {
-        return false;
-      }
-    }
-    return true;
-  }
-  function detectSortCaseSensitivity(array, getString, compareStringsCaseSensitive2, compareStringsCaseInsensitive2) {
-    let kind = 3 /* Both */;
-    if (array.length < 2)
-      return kind;
-    let prevElement = getString(array[0]);
-    for (let i = 1, len = array.length; i < len && kind !== 0 /* None */; i++) {
-      const element = getString(array[i]);
-      if (kind & 1 /* CaseSensitive */ && compareStringsCaseSensitive2(prevElement, element) > 0) {
-        kind &= ~1 /* CaseSensitive */;
-      }
-      if (kind & 2 /* CaseInsensitive */ && compareStringsCaseInsensitive2(prevElement, element) > 0) {
-        kind &= ~2 /* CaseInsensitive */;
-      }
-      prevElement = element;
-    }
-    return kind;
-  }
-  function arrayIsEqualTo(array1, array2, equalityComparer = equateValues) {
-    if (!array1 || !array2) {
-      return array1 === array2;
-    }
-    if (array1.length !== array2.length) {
-      return false;
-    }
-    for (let i = 0; i < array1.length; i++) {
-      if (!equalityComparer(array1[i], array2[i], i)) {
-        return false;
-      }
-    }
-    return true;
-  }
-  function compact(array) {
-    let result;
-    if (array) {
-      for (let i = 0; i < array.length; i++) {
-        const v = array[i];
-        if (result || !v) {
-          if (!result) {
-            result = array.slice(0, i);
-          }
-          if (v) {
-            result.push(v);
-          }
-        }
-      }
-    }
-    return result || array;
-  }
-  function relativeComplement(arrayA, arrayB, comparer) {
-    if (!arrayB || !arrayA || arrayB.length === 0 || arrayA.length === 0)
-      return arrayB;
-    const result = [];
-    loopB:
-      for (let offsetA = 0, offsetB = 0; offsetB < arrayB.length; offsetB++) {
-        if (offsetB > 0) {
-          Debug.assertGreaterThanOrEqual(comparer(arrayB[offsetB], arrayB[offsetB - 1]), 0 /* EqualTo */);
-        }
-        loopA:
-          for (const startA = offsetA; offsetA < arrayA.length; offsetA++) {
-            if (offsetA > startA) {
-              Debug.assertGreaterThanOrEqual(comparer(arrayA[offsetA], arrayA[offsetA - 1]), 0 /* EqualTo */);
-            }
-            switch (comparer(arrayB[offsetB], arrayA[offsetA])) {
-              case -1 /* LessThan */:
-                result.push(arrayB[offsetB]);
-                continue loopB;
-              case 0 /* EqualTo */:
-                continue loopB;
-              case 1 /* GreaterThan */:
-                continue loopA;
-            }
-          }
-      }
-    return result;
-  }
-  function append(to, value) {
-    if (value === void 0)
-      return to;
-    if (to === void 0)
-      return [value];
-    to.push(value);
-    return to;
-  }
-  function combine(xs, ys) {
-    if (xs === void 0)
-      return ys;
-    if (ys === void 0)
-      return xs;
-    if (isArray(xs))
-      return isArray(ys) ? concatenate(xs, ys) : append(xs, ys);
-    if (isArray(ys))
-      return append(ys, xs);
-    return [xs, ys];
-  }
-  function toOffset(array, offset) {
-    return offset < 0 ? array.length + offset : offset;
-  }
-  function addRange(to, from, start, end) {
-    if (from === void 0 || from.length === 0)
-      return to;
-    if (to === void 0)
-      return from.slice(start, end);
-    start = start === void 0 ? 0 : toOffset(from, start);
-    end = end === void 0 ? from.length : toOffset(from, end);
-    for (let i = start; i < end && i < from.length; i++) {
-      if (from[i] !== void 0) {
-        to.push(from[i]);
-      }
-    }
-    return to;
-  }
-  function pushIfUnique(array, toAdd, equalityComparer) {
-    if (contains(array, toAdd, equalityComparer)) {
-      return false;
-    } else {
-      array.push(toAdd);
-      return true;
-    }
-  }
-  function appendIfUnique(array, toAdd, equalityComparer) {
-    if (array) {
-      pushIfUnique(array, toAdd, equalityComparer);
-      return array;
-    } else {
-      return [toAdd];
-    }
-  }
-  function stableSortIndices(array, indices, comparer) {
-    indices.sort((x, y) => comparer(array[x], array[y]) || compareValues(x, y));
-  }
-  function sort(array, comparer) {
-    return array.length === 0 ? array : array.slice().sort(comparer);
-  }
-  function* arrayReverseIterator(array) {
-    for (let i = array.length - 1; i >= 0; i--) {
-      yield array[i];
-    }
-  }
-  function stableSort(array, comparer) {
-    const indices = indicesOf(array);
-    stableSortIndices(array, indices, comparer);
-    return indices.map((i) => array[i]);
-  }
-  function rangeEquals(array1, array2, pos, end) {
-    while (pos < end) {
-      if (array1[pos] !== array2[pos]) {
-        return false;
-      }
-      pos++;
-    }
-    return true;
-  }
-  function firstOrUndefined(array) {
-    return array === void 0 || array.length === 0 ? void 0 : array[0];
-  }
-  function firstOrUndefinedIterator(iter) {
-    if (iter) {
-      for (const value of iter) {
-        return value;
-      }
-    }
-    return void 0;
-  }
-  function first(array) {
-    Debug.assert(array.length !== 0);
-    return array[0];
-  }
-  function firstIterator(iter) {
-    for (const value of iter) {
-      return value;
-    }
-    Debug.fail("iterator is empty");
-  }
-  function lastOrUndefined(array) {
-    return array === void 0 || array.length === 0 ? void 0 : array[array.length - 1];
-  }
-  function last(array) {
-    Debug.assert(array.length !== 0);
-    return array[array.length - 1];
-  }
-  function singleOrUndefined(array) {
-    return array && array.length === 1 ? array[0] : void 0;
-  }
-  function single(array) {
-    return Debug.checkDefined(singleOrUndefined(array));
-  }
-  function singleOrMany(array) {
-    return array && array.length === 1 ? array[0] : array;
-  }
-  function replaceElement(array, index, value) {
-    const result = array.slice(0);
-    result[index] = value;
-    return result;
-  }
-  function binarySearch(array, value, keySelector, keyComparer, offset) {
-    return binarySearchKey(array, keySelector(value), keySelector, keyComparer, offset);
-  }
-  function binarySearchKey(array, key, keySelector, keyComparer, offset) {
-    if (!some(array)) {
-      return -1;
-    }
-    let low = offset || 0;
-    let high = array.length - 1;
-    while (low <= high) {
-      const middle = low + (high - low >> 1);
-      const midKey = keySelector(array[middle], middle);
-      switch (keyComparer(midKey, key)) {
-        case -1 /* LessThan */:
-          low = middle + 1;
-          break;
-        case 0 /* EqualTo */:
-          return middle;
-        case 1 /* GreaterThan */:
-          high = middle - 1;
-          break;
-      }
-    }
-    return ~low;
-  }
-  function reduceLeft(array, f, initial, start, count) {
-    if (array && array.length > 0) {
-      const size = array.length;
-      if (size > 0) {
-        let pos = start === void 0 || start < 0 ? 0 : start;
-        const end = count === void 0 || pos + count > size - 1 ? size - 1 : pos + count;
-        let result;
-        if (arguments.length <= 2) {
-          result = array[pos];
-          pos++;
-        } else {
-          result = initial;
-        }
-        while (pos <= end) {
-          result = f(result, array[pos], pos);
-          pos++;
-        }
-        return result;
-      }
-    }
-    return initial;
-  }
-  function hasProperty(map2, key) {
-    return hasOwnProperty.call(map2, key);
-  }
-  function getProperty(map2, key) {
-    return hasOwnProperty.call(map2, key) ? map2[key] : void 0;
-  }
-  function getOwnKeys(map2) {
-    const keys = [];
-    for (const key in map2) {
-      if (hasOwnProperty.call(map2, key)) {
-        keys.push(key);
-      }
-    }
-    return keys;
-  }
-  function getAllKeys(obj) {
-    const result = [];
-    do {
-      const names = Object.getOwnPropertyNames(obj);
-      for (const name of names) {
-        pushIfUnique(result, name);
-      }
-    } while (obj = Object.getPrototypeOf(obj));
-    return result;
-  }
-  function getOwnValues(collection) {
-    const values = [];
-    for (const key in collection) {
-      if (hasOwnProperty.call(collection, key)) {
-        values.push(collection[key]);
-      }
-    }
-    return values;
-  }
-  function arrayOf(count, f) {
-    const result = new Array(count);
-    for (let i = 0; i < count; i++) {
-      result[i] = f(i);
-    }
-    return result;
-  }
-  function arrayFrom(iterator, map2) {
-    const result = [];
-    for (const value of iterator) {
-      result.push(map2 ? map2(value) : value);
-    }
-    return result;
-  }
-  function assign(t, ...args) {
-    for (const arg of args) {
-      if (arg === void 0)
-        continue;
-      for (const p in arg) {
-        if (hasProperty(arg, p)) {
-          t[p] = arg[p];
-        }
-      }
-    }
-    return t;
-  }
-  function equalOwnProperties(left, right, equalityComparer = equateValues) {
-    if (left === right)
-      return true;
-    if (!left || !right)
-      return false;
-    for (const key in left) {
-      if (hasOwnProperty.call(left, key)) {
-        if (!hasOwnProperty.call(right, key))
-          return false;
-        if (!equalityComparer(left[key], right[key]))
-          return false;
-      }
-    }
-    for (const key in right) {
-      if (hasOwnProperty.call(right, key)) {
-        if (!hasOwnProperty.call(left, key))
-          return false;
-      }
-    }
-    return true;
-  }
-  function arrayToMap(array, makeKey, makeValue = identity) {
-    const result = /* @__PURE__ */ new Map();
-    for (const value of array) {
-      const key = makeKey(value);
-      if (key !== void 0)
-        result.set(key, makeValue(value));
-    }
-    return result;
-  }
-  function arrayToNumericMap(array, makeKey, makeValue = identity) {
-    const result = [];
-    for (const value of array) {
-      result[makeKey(value)] = makeValue(value);
-    }
-    return result;
-  }
-  function arrayToMultiMap(values, makeKey, makeValue = identity) {
-    const result = createMultiMap();
-    for (const value of values) {
-      result.add(makeKey(value), makeValue(value));
-    }
-    return result;
-  }
-  function group(values, getGroupId, resultSelector = identity) {
-    return arrayFrom(arrayToMultiMap(values, getGroupId).values(), resultSelector);
-  }
-  function groupBy(values, keySelector) {
-    const result = {};
-    if (values) {
-      for (const value of values) {
-        const key = `${keySelector(value)}`;
-        const array = result[key] ?? (result[key] = []);
-        array.push(value);
-      }
-    }
-    return result;
-  }
-  function clone(object) {
-    const result = {};
-    for (const id in object) {
-      if (hasOwnProperty.call(object, id)) {
-        result[id] = object[id];
-      }
-    }
-    return result;
-  }
-  function extend(first2, second) {
-    const result = {};
-    for (const id in second) {
-      if (hasOwnProperty.call(second, id)) {
-        result[id] = second[id];
-      }
-    }
-    for (const id in first2) {
-      if (hasOwnProperty.call(first2, id)) {
-        result[id] = first2[id];
-      }
-    }
-    return result;
-  }
-  function copyProperties(first2, second) {
-    for (const id in second) {
-      if (hasOwnProperty.call(second, id)) {
-        first2[id] = second[id];
-      }
-    }
-  }
-  function maybeBind(obj, fn) {
-    return fn ? fn.bind(obj) : void 0;
-  }
-  function createMultiMap() {
-    const map2 = /* @__PURE__ */ new Map();
-    map2.add = multiMapAdd;
-    map2.remove = multiMapRemove;
-    return map2;
-  }
-  function multiMapAdd(key, value) {
-    let values = this.get(key);
-    if (values) {
-      values.push(value);
-    } else {
-      this.set(key, values = [value]);
-    }
-    return values;
-  }
-  function multiMapRemove(key, value) {
-    const values = this.get(key);
-    if (values) {
-      unorderedRemoveItem(values, value);
-      if (!values.length) {
-        this.delete(key);
-      }
-    }
-  }
-  function createQueue(items) {
-    const elements = (items == null ? void 0 : items.slice()) || [];
-    let headIndex = 0;
-    function isEmpty() {
-      return headIndex === elements.length;
-    }
-    function enqueue(...items2) {
-      elements.push(...items2);
-    }
-    function dequeue() {
-      if (isEmpty()) {
-        throw new Error("Queue is empty");
-      }
-      const result = elements[headIndex];
-      elements[headIndex] = void 0;
-      headIndex++;
-      if (headIndex > 100 && headIndex > elements.length >> 1) {
-        const newLength = elements.length - headIndex;
-        elements.copyWithin(
-          /*target*/
-          0,
-          /*start*/
-          headIndex
-        );
-        elements.length = newLength;
-        headIndex = 0;
-      }
-      return result;
-    }
-    return {
-      enqueue,
-      dequeue,
-      isEmpty
-    };
-  }
-  function createSet(getHashCode, equals) {
-    const multiMap = /* @__PURE__ */ new Map();
-    let size = 0;
-    function* getElementIterator() {
-      for (const value of multiMap.values()) {
-        if (isArray(value)) {
-          yield* value;
-        } else {
-          yield value;
-        }
-      }
-    }
-    const set = {
-      has(element) {
-        const hash = getHashCode(element);
-        if (!multiMap.has(hash))
-          return false;
-        const candidates = multiMap.get(hash);
-        if (!isArray(candidates))
-          return equals(candidates, element);
-        for (const candidate of candidates) {
-          if (equals(candidate, element)) {
-            return true;
-          }
-        }
-        return false;
-      },
-      add(element) {
-        const hash = getHashCode(element);
-        if (multiMap.has(hash)) {
-          const values = multiMap.get(hash);
-          if (isArray(values)) {
-            if (!contains(values, element, equals)) {
-              values.push(element);
-              size++;
-            }
-          } else {
-            const value = values;
-            if (!equals(value, element)) {
-              multiMap.set(hash, [value, element]);
-              size++;
-            }
-          }
-        } else {
-          multiMap.set(hash, element);
-          size++;
-        }
-        return this;
-      },
-      delete(element) {
-        const hash = getHashCode(element);
-        if (!multiMap.has(hash))
-          return false;
-        const candidates = multiMap.get(hash);
-        if (isArray(candidates)) {
-          for (let i = 0; i < candidates.length; i++) {
-            if (equals(candidates[i], element)) {
-              if (candidates.length === 1) {
-                multiMap.delete(hash);
-              } else if (candidates.length === 2) {
-                multiMap.set(hash, candidates[1 - i]);
-              } else {
-                unorderedRemoveItemAt(candidates, i);
-              }
-              size--;
-              return true;
-            }
-          }
-        } else {
-          const candidate = candidates;
-          if (equals(candidate, element)) {
-            multiMap.delete(hash);
-            size--;
-            return true;
-          }
-        }
-        return false;
-      },
-      clear() {
-        multiMap.clear();
-        size = 0;
-      },
-      get size() {
-        return size;
-      },
-      forEach(action) {
-        for (const elements of arrayFrom(multiMap.values())) {
-          if (isArray(elements)) {
-            for (const element of elements) {
-              action(element, element, set);
-            }
-          } else {
-            const element = elements;
-            action(element, element, set);
-          }
-        }
-      },
-      keys() {
-        return getElementIterator();
-      },
-      values() {
-        return getElementIterator();
-      },
-      *entries() {
-        for (const value of getElementIterator()) {
-          yield [value, value];
-        }
-      },
-      [Symbol.iterator]: () => {
-        return getElementIterator();
-      },
-      [Symbol.toStringTag]: multiMap[Symbol.toStringTag]
-    };
-    return set;
-  }
-  function isArray(value) {
-    return Array.isArray(value);
-  }
-  function toArray(value) {
-    return isArray(value) ? value : [value];
-  }
-  function isString(text) {
-    return typeof text === "string";
-  }
-  function isNumber(x) {
-    return typeof x === "number";
-  }
-  function tryCast(value, test) {
-    return value !== void 0 && test(value) ? value : void 0;
-  }
-  function cast(value, test) {
-    if (value !== void 0 && test(value))
-      return value;
-    return Debug.fail(`Invalid cast. The supplied value ${value} did not pass the test '${Debug.getFunctionName(test)}'.`);
-  }
-  function noop(_) {
-  }
-  function returnFalse() {
-    return false;
-  }
-  function returnTrue() {
-    return true;
-  }
-  function returnUndefined() {
-    return void 0;
-  }
-  function identity(x) {
-    return x;
-  }
-  function toLowerCase(x) {
-    return x.toLowerCase();
-  }
-  function toFileNameLowerCase(x) {
-    return fileNameLowerCaseRegExp.test(x) ? x.replace(fileNameLowerCaseRegExp, toLowerCase) : x;
-  }
-  function notImplemented() {
-    throw new Error("Not implemented");
-  }
-  function memoize(callback) {
-    let value;
-    return () => {
-      if (callback) {
-        value = callback();
-        callback = void 0;
-      }
-      return value;
-    };
-  }
-  function memoizeOne(callback) {
-    const map2 = /* @__PURE__ */ new Map();
-    return (arg) => {
-      const key = `${typeof arg}:${arg}`;
-      let value = map2.get(key);
-      if (value === void 0 && !map2.has(key)) {
-        value = callback(arg);
-        map2.set(key, value);
-      }
-      return value;
-    };
-  }
-  function memoizeWeak(callback) {
-    const map2 = /* @__PURE__ */ new WeakMap();
-    return (arg) => {
-      let value = map2.get(arg);
-      if (value === void 0 && !map2.has(arg)) {
-        value = callback(arg);
-        map2.set(arg, value);
-      }
-      return value;
-    };
-  }
-  function memoizeCached(callback, cache) {
-    return (...args) => {
-      let value = cache.get(args);
-      if (value === void 0 && !cache.has(args)) {
-        value = callback(...args);
-        cache.set(args, value);
-      }
-      return value;
-    };
-  }
-  function compose(a, b, c, d, e) {
-    if (!!e) {
-      const args = [];
-      for (let i = 0; i < arguments.length; i++) {
-        args[i] = arguments[i];
-      }
-      return (t) => reduceLeft(args, (u, f) => f(u), t);
-    } else if (d) {
-      return (t) => d(c(b(a(t))));
-    } else if (c) {
-      return (t) => c(b(a(t)));
-    } else if (b) {
-      return (t) => b(a(t));
-    } else if (a) {
-      return (t) => a(t);
-    } else {
-      return (t) => t;
-    }
-  }
-  function equateValues(a, b) {
-    return a === b;
-  }
-  function equateStringsCaseInsensitive(a, b) {
-    return a === b || a !== void 0 && b !== void 0 && a.toUpperCase() === b.toUpperCase();
-  }
-  function equateStringsCaseSensitive(a, b) {
-    return equateValues(a, b);
-  }
-  function compareComparableValues(a, b) {
-    return a === b ? 0 /* EqualTo */ : a === void 0 ? -1 /* LessThan */ : b === void 0 ? 1 /* GreaterThan */ : a < b ? -1 /* LessThan */ : 1 /* GreaterThan */;
-  }
-  function compareValues(a, b) {
-    return compareComparableValues(a, b);
-  }
-  function compareTextSpans(a, b) {
-    return compareValues(a == null ? void 0 : a.start, b == null ? void 0 : b.start) || compareValues(a == null ? void 0 : a.length, b == null ? void 0 : b.length);
-  }
-  function min(items, compare) {
-    return reduceLeft(items, (x, y) => compare(x, y) === -1 /* LessThan */ ? x : y);
-  }
-  function compareStringsCaseInsensitive(a, b) {
-    if (a === b)
-      return 0 /* EqualTo */;
-    if (a === void 0)
-      return -1 /* LessThan */;
-    if (b === void 0)
-      return 1 /* GreaterThan */;
-    a = a.toUpperCase();
-    b = b.toUpperCase();
-    return a < b ? -1 /* LessThan */ : a > b ? 1 /* GreaterThan */ : 0 /* EqualTo */;
-  }
-  function compareStringsCaseInsensitiveEslintCompatible(a, b) {
-    if (a === b)
-      return 0 /* EqualTo */;
-    if (a === void 0)
-      return -1 /* LessThan */;
-    if (b === void 0)
-      return 1 /* GreaterThan */;
-    a = a.toLowerCase();
-    b = b.toLowerCase();
-    return a < b ? -1 /* LessThan */ : a > b ? 1 /* GreaterThan */ : 0 /* EqualTo */;
-  }
-  function compareStringsCaseSensitive(a, b) {
-    return compareComparableValues(a, b);
-  }
-  function getStringComparer(ignoreCase) {
-    return ignoreCase ? compareStringsCaseInsensitive : compareStringsCaseSensitive;
-  }
-  function getUILocale() {
-    return uiLocale;
-  }
-  function setUILocale(value) {
-    if (uiLocale !== value) {
-      uiLocale = value;
-      uiComparerCaseSensitive = void 0;
-    }
-  }
-  function compareStringsCaseSensitiveUI(a, b) {
-    const comparer = uiComparerCaseSensitive || (uiComparerCaseSensitive = createUIStringComparer(uiLocale));
-    return comparer(a, b);
-  }
-  function compareProperties(a, b, key, comparer) {
-    return a === b ? 0 /* EqualTo */ : a === void 0 ? -1 /* LessThan */ : b === void 0 ? 1 /* GreaterThan */ : comparer(a[key], b[key]);
-  }
-  function compareBooleans(a, b) {
-    return compareValues(a ? 1 : 0, b ? 1 : 0);
-  }
-  function getSpellingSuggestion(name, candidates, getName) {
-    const maximumLengthDifference = Math.max(2, Math.floor(name.length * 0.34));
-    let bestDistance = Math.floor(name.length * 0.4) + 1;
-    let bestCandidate;
-    for (const candidate of candidates) {
-      const candidateName = getName(candidate);
-      if (candidateName !== void 0 && Math.abs(candidateName.length - name.length) <= maximumLengthDifference) {
-        if (candidateName === name) {
-          continue;
-        }
-        if (candidateName.length < 3 && candidateName.toLowerCase() !== name.toLowerCase()) {
-          continue;
-        }
-        const distance = levenshteinWithMax(name, candidateName, bestDistance - 0.1);
-        if (distance === void 0) {
-          continue;
-        }
-        Debug.assert(distance < bestDistance);
-        bestDistance = distance;
-        bestCandidate = candidate;
-      }
-    }
-    return bestCandidate;
-  }
-  function levenshteinWithMax(s1, s2, max) {
-    let previous = new Array(s2.length + 1);
-    let current = new Array(s2.length + 1);
-    const big = max + 0.01;
-    for (let i = 0; i <= s2.length; i++) {
-      previous[i] = i;
-    }
-    for (let i = 1; i <= s1.length; i++) {
-      const c1 = s1.charCodeAt(i - 1);
-      const minJ = Math.ceil(i > max ? i - max : 1);
-      const maxJ = Math.floor(s2.length > max + i ? max + i : s2.length);
-      current[0] = i;
-      let colMin = i;
-      for (let j = 1; j < minJ; j++) {
-        current[j] = big;
-      }
-      for (let j = minJ; j <= maxJ; j++) {
-        const substitutionDistance = s1[i - 1].toLowerCase() === s2[j - 1].toLowerCase() ? previous[j - 1] + 0.1 : previous[j - 1] + 2;
-        const dist = c1 === s2.charCodeAt(j - 1) ? previous[j - 1] : Math.min(
-          /*delete*/
-          previous[j] + 1,
-          /*insert*/
-          current[j - 1] + 1,
-          /*substitute*/
-          substitutionDistance
-        );
-        current[j] = dist;
-        colMin = Math.min(colMin, dist);
-      }
-      for (let j = maxJ + 1; j <= s2.length; j++) {
-        current[j] = big;
-      }
-      if (colMin > max) {
-        return void 0;
-      }
-      const temp = previous;
-      previous = current;
-      current = temp;
-    }
-    const res = previous[s2.length];
-    return res > max ? void 0 : res;
-  }
-  function endsWith(str, suffix) {
-    const expectedPos = str.length - suffix.length;
-    return expectedPos >= 0 && str.indexOf(suffix, expectedPos) === expectedPos;
-  }
-  function removeSuffix(str, suffix) {
-    return endsWith(str, suffix) ? str.slice(0, str.length - suffix.length) : str;
-  }
-  function tryRemoveSuffix(str, suffix) {
-    return endsWith(str, suffix) ? str.slice(0, str.length - suffix.length) : void 0;
-  }
-  function stringContains(str, substring) {
-    return str.indexOf(substring) !== -1;
-  }
-  function removeMinAndVersionNumbers(fileName) {
-    let end = fileName.length;
-    for (let pos = end - 1; pos > 0; pos--) {
-      let ch = fileName.charCodeAt(pos);
-      if (ch >= 48 /* _0 */ && ch <= 57 /* _9 */) {
-        do {
-          --pos;
-          ch = fileName.charCodeAt(pos);
-        } while (pos > 0 && ch >= 48 /* _0 */ && ch <= 57 /* _9 */);
-      } else if (pos > 4 && (ch === 110 /* n */ || ch === 78 /* N */)) {
-        --pos;
-        ch = fileName.charCodeAt(pos);
-        if (ch !== 105 /* i */ && ch !== 73 /* I */) {
-          break;
-        }
-        --pos;
-        ch = fileName.charCodeAt(pos);
-        if (ch !== 109 /* m */ && ch !== 77 /* M */) {
-          break;
-        }
-        --pos;
-        ch = fileName.charCodeAt(pos);
-      } else {
-        break;
-      }
-      if (ch !== 45 /* minus */ && ch !== 46 /* dot */) {
-        break;
-      }
-      end = pos;
-    }
-    return end === fileName.length ? fileName : fileName.slice(0, end);
-  }
-  function orderedRemoveItem(array, item) {
-    for (let i = 0; i < array.length; i++) {
-      if (array[i] === item) {
-        orderedRemoveItemAt(array, i);
-        return true;
-      }
-    }
-    return false;
-  }
-  function orderedRemoveItemAt(array, index) {
-    for (let i = index; i < array.length - 1; i++) {
-      array[i] = array[i + 1];
-    }
-    array.pop();
-  }
-  function unorderedRemoveItemAt(array, index) {
-    array[index] = array[array.length - 1];
-    array.pop();
-  }
-  function unorderedRemoveItem(array, item) {
-    return unorderedRemoveFirstItemWhere(array, (element) => element === item);
-  }
-  function unorderedRemoveFirstItemWhere(array, predicate) {
-    for (let i = 0; i < array.length; i++) {
-      if (predicate(array[i])) {
-        unorderedRemoveItemAt(array, i);
-        return true;
-      }
-    }
-    return false;
-  }
-  function createGetCanonicalFileName(useCaseSensitiveFileNames) {
-    return useCaseSensitiveFileNames ? identity : toFileNameLowerCase;
-  }
-  function patternText({ prefix, suffix }) {
-    return `${prefix}*${suffix}`;
-  }
-  function matchedText(pattern, candidate) {
-    Debug.assert(isPatternMatch(pattern, candidate));
-    return candidate.substring(pattern.prefix.length, candidate.length - pattern.suffix.length);
-  }
-  function findBestPatternMatch(values, getPattern, candidate) {
-    let matchedValue;
-    let longestMatchPrefixLength = -1;
-    for (const v of values) {
-      const pattern = getPattern(v);
-      if (isPatternMatch(pattern, candidate) && pattern.prefix.length > longestMatchPrefixLength) {
-        longestMatchPrefixLength = pattern.prefix.length;
-        matchedValue = v;
-      }
-    }
-    return matchedValue;
-  }
-  function startsWith(str, prefix) {
-    return str.lastIndexOf(prefix, 0) === 0;
-  }
-  function removePrefix(str, prefix) {
-    return startsWith(str, prefix) ? str.substr(prefix.length) : str;
-  }
-  function tryRemovePrefix(str, prefix, getCanonicalFileName = identity) {
-    return startsWith(getCanonicalFileName(str), getCanonicalFileName(prefix)) ? str.substring(prefix.length) : void 0;
-  }
-  function isPatternMatch({ prefix, suffix }, candidate) {
-    return candidate.length >= prefix.length + suffix.length && startsWith(candidate, prefix) && endsWith(candidate, suffix);
-  }
-  function and(f, g) {
-    return (arg) => f(arg) && g(arg);
-  }
-  function or(...fs) {
-    return (...args) => {
-      let lastResult;
-      for (const f of fs) {
-        lastResult = f(...args);
-        if (lastResult) {
-          return lastResult;
-        }
-      }
-      return lastResult;
-    };
-  }
-  function not(fn) {
-    return (...args) => !fn(...args);
-  }
-  function assertType(_) {
-  }
-  function singleElementArray(t) {
-    return t === void 0 ? void 0 : [t];
-  }
-  function enumerateInsertsAndDeletes(newItems, oldItems, comparer, inserted, deleted, unchanged) {
-    unchanged = unchanged || noop;
-    let newIndex = 0;
-    let oldIndex = 0;
-    const newLen = newItems.length;
-    const oldLen = oldItems.length;
-    let hasChanges = false;
-    while (newIndex < newLen && oldIndex < oldLen) {
-      const newItem = newItems[newIndex];
-      const oldItem = oldItems[oldIndex];
-      const compareResult = comparer(newItem, oldItem);
-      if (compareResult === -1 /* LessThan */) {
-        inserted(newItem);
-        newIndex++;
-        hasChanges = true;
-      } else if (compareResult === 1 /* GreaterThan */) {
-        deleted(oldItem);
-        oldIndex++;
-        hasChanges = true;
-      } else {
-        unchanged(oldItem, newItem);
-        newIndex++;
-        oldIndex++;
-      }
-    }
-    while (newIndex < newLen) {
-      inserted(newItems[newIndex++]);
-      hasChanges = true;
-    }
-    while (oldIndex < oldLen) {
-      deleted(oldItems[oldIndex++]);
-      hasChanges = true;
-    }
-    return hasChanges;
-  }
-  function cartesianProduct(arrays) {
-    const result = [];
-    cartesianProductWorker(
-      arrays,
-      result,
-      /*outer*/
-      void 0,
-      0
-    );
-    return result;
-  }
-  function cartesianProductWorker(arrays, result, outer, index) {
-    for (const element of arrays[index]) {
-      let inner;
-      if (outer) {
-        inner = outer.slice();
-        inner.push(element);
-      } else {
-        inner = [element];
-      }
-      if (index === arrays.length - 1) {
-        result.push(inner);
-      } else {
-        cartesianProductWorker(arrays, result, inner, index + 1);
-      }
-    }
-  }
-  function padLeft(s, length2, padString = " ") {
-    return length2 <= s.length ? s : padString.repeat(length2 - s.length) + s;
-  }
-  function padRight(s, length2, padString = " ") {
-    return length2 <= s.length ? s : s + padString.repeat(length2 - s.length);
-  }
-  function takeWhile(array, predicate) {
-    if (array) {
-      const len = array.length;
-      let index = 0;
-      while (index < len && predicate(array[index])) {
-        index++;
-      }
-      return array.slice(0, index);
-    }
-  }
-  function skipWhile(array, predicate) {
-    if (array) {
-      const len = array.length;
-      let index = 0;
-      while (index < len && predicate(array[index])) {
-        index++;
-      }
-      return array.slice(index);
-    }
-  }
-  function trimEndImpl(s) {
-    let end = s.length - 1;
-    while (end >= 0) {
-      if (!isWhiteSpaceLike(s.charCodeAt(end)))
-        break;
-      end--;
-    }
-    return s.slice(0, end + 1);
-  }
-  function isNodeLikeSystem() {
-    return typeof process !== "undefined" && !!process.nextTick && !process.browser && typeof module === "object";
-  }
-  var emptyArray, emptyMap, emptySet, SortKind, elementAt, hasOwnProperty, fileNameLowerCaseRegExp, AssertionLevel, createUIStringComparer, uiComparerCaseSensitive, uiLocale, trimString, trimStringEnd, trimStringStart;
-  var init_core = __esm({
-    "src/compiler/core.ts"() {
-      "use strict";
-      init_ts2();
-      emptyArray = [];
-      emptyMap = /* @__PURE__ */ new Map();
-      emptySet = /* @__PURE__ */ new Set();
-      SortKind = /* @__PURE__ */ ((SortKind2) => {
-        SortKind2[SortKind2["None"] = 0] = "None";
-        SortKind2[SortKind2["CaseSensitive"] = 1] = "CaseSensitive";
-        SortKind2[SortKind2["CaseInsensitive"] = 2] = "CaseInsensitive";
-        SortKind2[SortKind2["Both"] = 3] = "Both";
-        return SortKind2;
-      })(SortKind || {});
-      elementAt = !!Array.prototype.at ? (array, offset) => array == null ? void 0 : array.at(offset) : (array, offset) => {
-        if (array) {
-          offset = toOffset(array, offset);
-          if (offset < array.length) {
-            return array[offset];
-          }
-        }
-        return void 0;
-      };
-      hasOwnProperty = Object.prototype.hasOwnProperty;
-      fileNameLowerCaseRegExp = /[^\u0130\u0131\u00DFa-z0-9\\/:\-_\. ]+/g;
-      AssertionLevel = /* @__PURE__ */ ((AssertionLevel2) => {
-        AssertionLevel2[AssertionLevel2["None"] = 0] = "None";
-        AssertionLevel2[AssertionLevel2["Normal"] = 1] = "Normal";
-        AssertionLevel2[AssertionLevel2["Aggressive"] = 2] = "Aggressive";
-        AssertionLevel2[AssertionLevel2["VeryAggressive"] = 3] = "VeryAggressive";
-        return AssertionLevel2;
-      })(AssertionLevel || {});
-      createUIStringComparer = (() => {
-        let defaultComparer;
-        let enUSComparer;
-        const stringComparerFactory = getStringComparerFactory();
-        return createStringComparer;
-        function compareWithCallback(a, b, comparer) {
-          if (a === b)
-            return 0 /* EqualTo */;
-          if (a === void 0)
-            return -1 /* LessThan */;
-          if (b === void 0)
-            return 1 /* GreaterThan */;
-          const value = comparer(a, b);
-          return value < 0 ? -1 /* LessThan */ : value > 0 ? 1 /* GreaterThan */ : 0 /* EqualTo */;
-        }
-        function createIntlCollatorStringComparer(locale) {
-          const comparer = new Intl.Collator(locale, { usage: "sort", sensitivity: "variant" }).compare;
-          return (a, b) => compareWithCallback(a, b, comparer);
-        }
-        function createLocaleCompareStringComparer(locale) {
-          if (locale !== void 0)
-            return createFallbackStringComparer();
-          return (a, b) => compareWithCallback(a, b, compareStrings);
-          function compareStrings(a, b) {
-            return a.localeCompare(b);
-          }
-        }
-        function createFallbackStringComparer() {
-          return (a, b) => compareWithCallback(a, b, compareDictionaryOrder);
-          function compareDictionaryOrder(a, b) {
-            return compareStrings(a.toUpperCase(), b.toUpperCase()) || compareStrings(a, b);
-          }
-          function compareStrings(a, b) {
-            return a < b ? -1 /* LessThan */ : a > b ? 1 /* GreaterThan */ : 0 /* EqualTo */;
-          }
-        }
-        function getStringComparerFactory() {
-          if (typeof Intl === "object" && typeof Intl.Collator === "function") {
-            return createIntlCollatorStringComparer;
-          }
-          if (typeof String.prototype.localeCompare === "function" && typeof String.prototype.toLocaleUpperCase === "function" && "a".localeCompare("B") < 0) {
-            return createLocaleCompareStringComparer;
-          }
-          return createFallbackStringComparer;
-        }
-        function createStringComparer(locale) {
-          if (locale === void 0) {
-            return defaultComparer || (defaultComparer = stringComparerFactory(locale));
-          } else if (locale === "en-US") {
-            return enUSComparer || (enUSComparer = stringComparerFactory(locale));
-          } else {
-            return stringComparerFactory(locale);
-          }
-        }
-      })();
-      trimString = !!String.prototype.trim ? (s) => s.trim() : (s) => trimStringEnd(trimStringStart(s));
-      trimStringEnd = !!String.prototype.trimEnd ? (s) => s.trimEnd() : trimEndImpl;
-      trimStringStart = !!String.prototype.trimStart ? (s) => s.trimStart() : (s) => s.replace(/^\s+/g, "");
-    }
-  });
-
-  // src/compiler/debug.ts
-  var LogLevel, Debug;
-  var init_debug = __esm({
-    "src/compiler/debug.ts"() {
-      "use strict";
-      init_ts2();
-      init_ts2();
-      LogLevel = /* @__PURE__ */ ((LogLevel2) => {
-        LogLevel2[LogLevel2["Off"] = 0] = "Off";
-        LogLevel2[LogLevel2["Error"] = 1] = "Error";
-        LogLevel2[LogLevel2["Warning"] = 2] = "Warning";
-        LogLevel2[LogLevel2["Info"] = 3] = "Info";
-        LogLevel2[LogLevel2["Verbose"] = 4] = "Verbose";
-        return LogLevel2;
-      })(LogLevel || {});
-      ((Debug2) => {
-        let currentAssertionLevel = 0 /* None */;
-        Debug2.currentLogLevel = 2 /* Warning */;
-        Debug2.isDebugging = false;
-        function shouldLog(level) {
-          return Debug2.currentLogLevel <= level;
-        }
-        Debug2.shouldLog = shouldLog;
-        function logMessage(level, s) {
-          if (Debug2.loggingHost && shouldLog(level)) {
-            Debug2.loggingHost.log(level, s);
-          }
-        }
-        function log(s) {
-          logMessage(3 /* Info */, s);
-        }
-        Debug2.log = log;
-        ((_log) => {
-          function error(s) {
-            logMessage(1 /* Error */, s);
-          }
-          _log.error = error;
-          function warn(s) {
-            logMessage(2 /* Warning */, s);
-          }
-          _log.warn = warn;
-          function log2(s) {
-            logMessage(3 /* Info */, s);
-          }
-          _log.log = log2;
-          function trace2(s) {
-            logMessage(4 /* Verbose */, s);
-          }
-          _log.trace = trace2;
-        })(log = Debug2.log || (Debug2.log = {}));
-        const assertionCache = {};
-        function getAssertionLevel() {
-          return currentAssertionLevel;
-        }
-        Debug2.getAssertionLevel = getAssertionLevel;
-        function setAssertionLevel(level) {
-          const prevAssertionLevel = currentAssertionLevel;
-          currentAssertionLevel = level;
-          if (level > prevAssertionLevel) {
-            for (const key of getOwnKeys(assertionCache)) {
-              const cachedFunc = assertionCache[key];
-              if (cachedFunc !== void 0 && Debug2[key] !== cachedFunc.assertion && level >= cachedFunc.level) {
-                Debug2[key] = cachedFunc;
-                assertionCache[key] = void 0;
-              }
-            }
-          }
-        }
-        Debug2.setAssertionLevel = setAssertionLevel;
-        function shouldAssert(level) {
-          return currentAssertionLevel >= level;
-        }
-        Debug2.shouldAssert = shouldAssert;
-        function shouldAssertFunction(level, name) {
-          if (!shouldAssert(level)) {
-            assertionCache[name] = { level, assertion: Debug2[name] };
-            Debug2[name] = noop;
-            return false;
-          }
-          return true;
-        }
-        function fail(message, stackCrawlMark) {
-          debugger;
-          const e = new Error(message ? `Debug Failure. ${message}` : "Debug Failure.");
-          if (Error.captureStackTrace) {
-            Error.captureStackTrace(e, stackCrawlMark || fail);
-          }
-          throw e;
-        }
-        Debug2.fail = fail;
-        function failBadSyntaxKind(node, message, stackCrawlMark) {
-          return fail(
-            `${message || "Unexpected node."}\r
-Node ${formatSyntaxKind(node.kind)} was unexpected.`,
-            stackCrawlMark || failBadSyntaxKind
-          );
-        }
-        Debug2.failBadSyntaxKind = failBadSyntaxKind;
-        function assert(expression, message, verboseDebugInfo, stackCrawlMark) {
-          if (!expression) {
-            message = message ? `False expression: ${message}` : "False expression.";
-            if (verboseDebugInfo) {
-              message += "\r\nVerbose Debug Information: " + (typeof verboseDebugInfo === "string" ? verboseDebugInfo : verboseDebugInfo());
-            }
-            fail(message, stackCrawlMark || assert);
-          }
-        }
-        Debug2.assert = assert;
-        function assertEqual(a, b, msg, msg2, stackCrawlMark) {
-          if (a !== b) {
-            const message = msg ? msg2 ? `${msg} ${msg2}` : msg : "";
-            fail(`Expected ${a} === ${b}. ${message}`, stackCrawlMark || assertEqual);
-          }
-        }
-        Debug2.assertEqual = assertEqual;
-        function assertLessThan(a, b, msg, stackCrawlMark) {
-          if (a >= b) {
-            fail(`Expected ${a} < ${b}. ${msg || ""}`, stackCrawlMark || assertLessThan);
-          }
-        }
-        Debug2.assertLessThan = assertLessThan;
-        function assertLessThanOrEqual(a, b, stackCrawlMark) {
-          if (a > b) {
-            fail(`Expected ${a} <= ${b}`, stackCrawlMark || assertLessThanOrEqual);
-          }
-        }
-        Debug2.assertLessThanOrEqual = assertLessThanOrEqual;
-        function assertGreaterThanOrEqual(a, b, stackCrawlMark) {
-          if (a < b) {
-            fail(`Expected ${a} >= ${b}`, stackCrawlMark || assertGreaterThanOrEqual);
-          }
-        }
-        Debug2.assertGreaterThanOrEqual = assertGreaterThanOrEqual;
-        function assertIsDefined(value, message, stackCrawlMark) {
-          if (value === void 0 || value === null) {
-            fail(message, stackCrawlMark || assertIsDefined);
-          }
-        }
-        Debug2.assertIsDefined = assertIsDefined;
-        function checkDefined(value, message, stackCrawlMark) {
-          assertIsDefined(value, message, stackCrawlMark || checkDefined);
-          return value;
-        }
-        Debug2.checkDefined = checkDefined;
-        function assertEachIsDefined(value, message, stackCrawlMark) {
-          for (const v of value) {
-            assertIsDefined(v, message, stackCrawlMark || assertEachIsDefined);
-          }
-        }
-        Debug2.assertEachIsDefined = assertEachIsDefined;
-        function checkEachDefined(value, message, stackCrawlMark) {
-          assertEachIsDefined(value, message, stackCrawlMark || checkEachDefined);
-          return value;
-        }
-        Debug2.checkEachDefined = checkEachDefined;
-        function assertNever(member, message = "Illegal value:", stackCrawlMark) {
-          const detail = typeof member === "object" && hasProperty(member, "kind") && hasProperty(member, "pos") ? "SyntaxKind: " + formatSyntaxKind(member.kind) : JSON.stringify(member);
-          return fail(`${message} ${detail}`, stackCrawlMark || assertNever);
-        }
-        Debug2.assertNever = assertNever;
-        function assertEachNode(nodes, test, message, stackCrawlMark) {
-          if (shouldAssertFunction(1 /* Normal */, "assertEachNode")) {
-            assert(
-              test === void 0 || every(nodes, test),
-              message || "Unexpected node.",
-              () => `Node array did not pass test '${getFunctionName(test)}'.`,
-              stackCrawlMark || assertEachNode
-            );
-          }
-        }
-        Debug2.assertEachNode = assertEachNode;
-        function assertNode(node, test, message, stackCrawlMark) {
-          if (shouldAssertFunction(1 /* Normal */, "assertNode")) {
-            assert(
-              node !== void 0 && (test === void 0 || test(node)),
-              message || "Unexpected node.",
-              () => `Node ${formatSyntaxKind(node == null ? void 0 : node.kind)} did not pass test '${getFunctionName(test)}'.`,
-              stackCrawlMark || assertNode
-            );
-          }
-        }
-        Debug2.assertNode = assertNode;
-        function assertNotNode(node, test, message, stackCrawlMark) {
-          if (shouldAssertFunction(1 /* Normal */, "assertNotNode")) {
-            assert(
-              node === void 0 || test === void 0 || !test(node),
-              message || "Unexpected node.",
-              () => `Node ${formatSyntaxKind(node.kind)} should not have passed test '${getFunctionName(test)}'.`,
-              stackCrawlMark || assertNotNode
-            );
-          }
-        }
-        Debug2.assertNotNode = assertNotNode;
-        function assertOptionalNode(node, test, message, stackCrawlMark) {
-          if (shouldAssertFunction(1 /* Normal */, "assertOptionalNode")) {
-            assert(
-              test === void 0 || node === void 0 || test(node),
-              message || "Unexpected node.",
-              () => `Node ${formatSyntaxKind(node == null ? void 0 : node.kind)} did not pass test '${getFunctionName(test)}'.`,
-              stackCrawlMark || assertOptionalNode
-            );
-          }
-        }
-        Debug2.assertOptionalNode = assertOptionalNode;
-        function assertOptionalToken(node, kind, message, stackCrawlMark) {
-          if (shouldAssertFunction(1 /* Normal */, "assertOptionalToken")) {
-            assert(
-              kind === void 0 || node === void 0 || node.kind === kind,
-              message || "Unexpected node.",
-              () => `Node ${formatSyntaxKind(node == null ? void 0 : node.kind)} was not a '${formatSyntaxKind(kind)}' token.`,
-              stackCrawlMark || assertOptionalToken
-            );
-          }
-        }
-        Debug2.assertOptionalToken = assertOptionalToken;
-        function assertMissingNode(node, message, stackCrawlMark) {
-          if (shouldAssertFunction(1 /* Normal */, "assertMissingNode")) {
-            assert(
-              node === void 0,
-              message || "Unexpected node.",
-              () => `Node ${formatSyntaxKind(node.kind)} was unexpected'.`,
-              stackCrawlMark || assertMissingNode
-            );
-          }
-        }
-        Debug2.assertMissingNode = assertMissingNode;
-        function type(_value) {
-        }
-        Debug2.type = type;
-        function getFunctionName(func) {
-          if (typeof func !== "function") {
-            return "";
-          } else if (hasProperty(func, "name")) {
-            return func.name;
-          } else {
-            const text = Function.prototype.toString.call(func);
-            const match = /^function\s+([\w\$]+)\s*\(/.exec(text);
-            return match ? match[1] : "";
-          }
-        }
-        Debug2.getFunctionName = getFunctionName;
-        function formatSymbol(symbol) {
-          return `{ name: ${unescapeLeadingUnderscores(symbol.escapedName)}; flags: ${formatSymbolFlags(symbol.flags)}; declarations: ${map(symbol.declarations, (node) => formatSyntaxKind(node.kind))} }`;
-        }
-        Debug2.formatSymbol = formatSymbol;
-        function formatEnum(value = 0, enumObject, isFlags) {
-          const members = getEnumMembers(enumObject);
-          if (value === 0) {
-            return members.length > 0 && members[0][0] === 0 ? members[0][1] : "0";
-          }
-          if (isFlags) {
-            const result = [];
-            let remainingFlags = value;
-            for (const [enumValue, enumName] of members) {
-              if (enumValue > value) {
-                break;
-              }
-              if (enumValue !== 0 && enumValue & value) {
-                result.push(enumName);
-                remainingFlags &= ~enumValue;
-              }
-            }
-            if (remainingFlags === 0) {
-              return result.join("|");
-            }
-          } else {
-            for (const [enumValue, enumName] of members) {
-              if (enumValue === value) {
-                return enumName;
-              }
-            }
-          }
-          return value.toString();
-        }
-        Debug2.formatEnum = formatEnum;
-        const enumMemberCache = /* @__PURE__ */ new Map();
-        function getEnumMembers(enumObject) {
-          const existing = enumMemberCache.get(enumObject);
-          if (existing) {
-            return existing;
-          }
-          const result = [];
-          for (const name in enumObject) {
-            const value = enumObject[name];
-            if (typeof value === "number") {
-              result.push([value, name]);
-            }
-          }
-          const sorted = stableSort(result, (x, y) => compareValues(x[0], y[0]));
-          enumMemberCache.set(enumObject, sorted);
-          return sorted;
-        }
-        function formatSyntaxKind(kind) {
-          return formatEnum(
-            kind,
-            SyntaxKind,
-            /*isFlags*/
-            false
-          );
-        }
-        Debug2.formatSyntaxKind = formatSyntaxKind;
-        function formatSnippetKind(kind) {
-          return formatEnum(
-            kind,
-            SnippetKind,
-            /*isFlags*/
-            false
-          );
-        }
-        Debug2.formatSnippetKind = formatSnippetKind;
-        function formatNodeFlags(flags) {
-          return formatEnum(
-            flags,
-            NodeFlags,
-            /*isFlags*/
-            true
-          );
-        }
-        Debug2.formatNodeFlags = formatNodeFlags;
-        function formatModifierFlags(flags) {
-          return formatEnum(
-            flags,
-            ModifierFlags,
-            /*isFlags*/
-            true
-          );
-        }
-        Debug2.formatModifierFlags = formatModifierFlags;
-        function formatTransformFlags(flags) {
-          return formatEnum(
-            flags,
-            TransformFlags,
-            /*isFlags*/
-            true
-          );
-        }
-        Debug2.formatTransformFlags = formatTransformFlags;
-        function formatEmitFlags(flags) {
-          return formatEnum(
-            flags,
-            EmitFlags,
-            /*isFlags*/
-            true
-          );
-        }
-        Debug2.formatEmitFlags = formatEmitFlags;
-        function formatSymbolFlags(flags) {
-          return formatEnum(
-            flags,
-            SymbolFlags,
-            /*isFlags*/
-            true
-          );
-        }
-        Debug2.formatSymbolFlags = formatSymbolFlags;
-        function formatTypeFlags(flags) {
-          return formatEnum(
-            flags,
-            TypeFlags,
-            /*isFlags*/
-            true
-          );
-        }
-        Debug2.formatTypeFlags = formatTypeFlags;
-        function formatSignatureFlags(flags) {
-          return formatEnum(
-            flags,
-            SignatureFlags,
-            /*isFlags*/
-            true
-          );
-        }
-        Debug2.formatSignatureFlags = formatSignatureFlags;
-        function formatObjectFlags(flags) {
-          return formatEnum(
-            flags,
-            ObjectFlags,
-            /*isFlags*/
-            true
-          );
-        }
-        Debug2.formatObjectFlags = formatObjectFlags;
-        function formatFlowFlags(flags) {
-          return formatEnum(
-            flags,
-            FlowFlags,
-            /*isFlags*/
-            true
-          );
-        }
-        Debug2.formatFlowFlags = formatFlowFlags;
-        function formatRelationComparisonResult(result) {
-          return formatEnum(
-            result,
-            RelationComparisonResult,
-            /*isFlags*/
-            true
-          );
-        }
-        Debug2.formatRelationComparisonResult = formatRelationComparisonResult;
-        function formatCheckMode(mode) {
-          return formatEnum(
-            mode,
-            CheckMode,
-            /*isFlags*/
-            true
-          );
-        }
-        Debug2.formatCheckMode = formatCheckMode;
-        function formatSignatureCheckMode(mode) {
-          return formatEnum(
-            mode,
-            SignatureCheckMode,
-            /*isFlags*/
-            true
-          );
-        }
-        Debug2.formatSignatureCheckMode = formatSignatureCheckMode;
-        function formatTypeFacts(facts) {
-          return formatEnum(
-            facts,
-            TypeFacts,
-            /*isFlags*/
-            true
-          );
-        }
-        Debug2.formatTypeFacts = formatTypeFacts;
-        let isDebugInfoEnabled = false;
-        let flowNodeProto;
-        function attachFlowNodeDebugInfoWorker(flowNode) {
-          if (!("__debugFlowFlags" in flowNode)) {
-            Object.defineProperties(flowNode, {
-              // for use with vscode-js-debug's new customDescriptionGenerator in launch.json
-              __tsDebuggerDisplay: {
-                value() {
-                  const flowHeader = this.flags & 2 /* Start */ ? "FlowStart" : this.flags & 4 /* BranchLabel */ ? "FlowBranchLabel" : this.flags & 8 /* LoopLabel */ ? "FlowLoopLabel" : this.flags & 16 /* Assignment */ ? "FlowAssignment" : this.flags & 32 /* TrueCondition */ ? "FlowTrueCondition" : this.flags & 64 /* FalseCondition */ ? "FlowFalseCondition" : this.flags & 128 /* SwitchClause */ ? "FlowSwitchClause" : this.flags & 256 /* ArrayMutation */ ? "FlowArrayMutation" : this.flags & 512 /* Call */ ? "FlowCall" : this.flags & 1024 /* ReduceLabel */ ? "FlowReduceLabel" : this.flags & 1 /* Unreachable */ ? "FlowUnreachable" : "UnknownFlow";
-                  const remainingFlags = this.flags & ~(2048 /* Referenced */ - 1);
-                  return `${flowHeader}${remainingFlags ? ` (${formatFlowFlags(remainingFlags)})` : ""}`;
-                }
-              },
-              __debugFlowFlags: { get() {
-                return formatEnum(
-                  this.flags,
-                  FlowFlags,
-                  /*isFlags*/
-                  true
-                );
-              } },
-              __debugToString: { value() {
-                return formatControlFlowGraph(this);
-              } }
-            });
-          }
-        }
-        function attachFlowNodeDebugInfo(flowNode) {
-          if (isDebugInfoEnabled) {
-            if (typeof Object.setPrototypeOf === "function") {
-              if (!flowNodeProto) {
-                flowNodeProto = Object.create(Object.prototype);
-                attachFlowNodeDebugInfoWorker(flowNodeProto);
-              }
-              Object.setPrototypeOf(flowNode, flowNodeProto);
-            } else {
-              attachFlowNodeDebugInfoWorker(flowNode);
-            }
-          }
-        }
-        Debug2.attachFlowNodeDebugInfo = attachFlowNodeDebugInfo;
-        let nodeArrayProto;
-        function attachNodeArrayDebugInfoWorker(array) {
-          if (!("__tsDebuggerDisplay" in array)) {
-            Object.defineProperties(array, {
-              __tsDebuggerDisplay: {
-                value(defaultValue) {
-                  defaultValue = String(defaultValue).replace(/(?:,[\s\w\d_]+:[^,]+)+\]$/, "]");
-                  return `NodeArray ${defaultValue}`;
-                }
-              }
-            });
-          }
-        }
-        function attachNodeArrayDebugInfo(array) {
-          if (isDebugInfoEnabled) {
-            if (typeof Object.setPrototypeOf === "function") {
-              if (!nodeArrayProto) {
-                nodeArrayProto = Object.create(Array.prototype);
-                attachNodeArrayDebugInfoWorker(nodeArrayProto);
-              }
-              Object.setPrototypeOf(array, nodeArrayProto);
-            } else {
-              attachNodeArrayDebugInfoWorker(array);
-            }
-          }
-        }
-        Debug2.attachNodeArrayDebugInfo = attachNodeArrayDebugInfo;
-        function enableDebugInfo() {
-          if (isDebugInfoEnabled)
-            return;
-          const weakTypeTextMap = /* @__PURE__ */ new WeakMap();
-          const weakNodeTextMap = /* @__PURE__ */ new WeakMap();
-          Object.defineProperties(objectAllocator.getSymbolConstructor().prototype, {
-            // for use with vscode-js-debug's new customDescriptionGenerator in launch.json
-            __tsDebuggerDisplay: {
-              value() {
-                const symbolHeader = this.flags & 33554432 /* Transient */ ? "TransientSymbol" : "Symbol";
-                const remainingSymbolFlags = this.flags & ~33554432 /* Transient */;
-                return `${symbolHeader} '${symbolName(this)}'${remainingSymbolFlags ? ` (${formatSymbolFlags(remainingSymbolFlags)})` : ""}`;
-              }
-            },
-            __debugFlags: { get() {
-              return formatSymbolFlags(this.flags);
-            } }
-          });
-          Object.defineProperties(objectAllocator.getTypeConstructor().prototype, {
-            // for use with vscode-js-debug's new customDescriptionGenerator in launch.json
-            __tsDebuggerDisplay: {
-              value() {
-                const typeHeader = this.flags & 98304 /* Nullable */ ? "NullableType" : this.flags & 384 /* StringOrNumberLiteral */ ? `LiteralType ${JSON.stringify(this.value)}` : this.flags & 2048 /* BigIntLiteral */ ? `LiteralType ${this.value.negative ? "-" : ""}${this.value.base10Value}n` : this.flags & 8192 /* UniqueESSymbol */ ? "UniqueESSymbolType" : this.flags & 32 /* Enum */ ? "EnumType" : this.flags & 67359327 /* Intrinsic */ ? `IntrinsicType ${this.intrinsicName}` : this.flags & 1048576 /* Union */ ? "UnionType" : this.flags & 2097152 /* Intersection */ ? "IntersectionType" : this.flags & 4194304 /* Index */ ? "IndexType" : this.flags & 8388608 /* IndexedAccess */ ? "IndexedAccessType" : this.flags & 16777216 /* Conditional */ ? "ConditionalType" : this.flags & 33554432 /* Substitution */ ? "SubstitutionType" : this.flags & 262144 /* TypeParameter */ ? "TypeParameter" : this.flags & 524288 /* Object */ ? this.objectFlags & 3 /* ClassOrInterface */ ? "InterfaceType" : this.objectFlags & 4 /* Reference */ ? "TypeReference" : this.objectFlags & 8 /* Tuple */ ? "TupleType" : this.objectFlags & 16 /* Anonymous */ ? "AnonymousType" : this.objectFlags & 32 /* Mapped */ ? "MappedType" : this.objectFlags & 1024 /* ReverseMapped */ ? "ReverseMappedType" : this.objectFlags & 256 /* EvolvingArray */ ? "EvolvingArrayType" : "ObjectType" : "Type";
-                const remainingObjectFlags = this.flags & 524288 /* Object */ ? this.objectFlags & ~1343 /* ObjectTypeKindMask */ : 0;
-                return `${typeHeader}${this.symbol ? ` '${symbolName(this.symbol)}'` : ""}${remainingObjectFlags ? ` (${formatObjectFlags(remainingObjectFlags)})` : ""}`;
-              }
-            },
-            __debugFlags: { get() {
-              return formatTypeFlags(this.flags);
-            } },
-            __debugObjectFlags: { get() {
-              return this.flags & 524288 /* Object */ ? formatObjectFlags(this.objectFlags) : "";
-            } },
-            __debugTypeToString: {
-              value() {
-                let text = weakTypeTextMap.get(this);
-                if (text === void 0) {
-                  text = this.checker.typeToString(this);
-                  weakTypeTextMap.set(this, text);
-                }
-                return text;
-              }
-            }
-          });
-          Object.defineProperties(objectAllocator.getSignatureConstructor().prototype, {
-            __debugFlags: { get() {
-              return formatSignatureFlags(this.flags);
-            } },
-            __debugSignatureToString: { value() {
-              var _a;
-              return (_a = this.checker) == null ? void 0 : _a.signatureToString(this);
-            } }
-          });
-          const nodeConstructors = [
-            objectAllocator.getNodeConstructor(),
-            objectAllocator.getIdentifierConstructor(),
-            objectAllocator.getTokenConstructor(),
-            objectAllocator.getSourceFileConstructor()
-          ];
-          for (const ctor of nodeConstructors) {
-            if (!hasProperty(ctor.prototype, "__debugKind")) {
-              Object.defineProperties(ctor.prototype, {
-                // for use with vscode-js-debug's new customDescriptionGenerator in launch.json
-                __tsDebuggerDisplay: {
-                  value() {
-                    const nodeHeader = isGeneratedIdentifier(this) ? "GeneratedIdentifier" : isIdentifier(this) ? `Identifier '${idText(this)}'` : isPrivateIdentifier(this) ? `PrivateIdentifier '${idText(this)}'` : isStringLiteral(this) ? `StringLiteral ${JSON.stringify(this.text.length < 10 ? this.text : this.text.slice(10) + "...")}` : isNumericLiteral(this) ? `NumericLiteral ${this.text}` : isBigIntLiteral(this) ? `BigIntLiteral ${this.text}n` : isTypeParameterDeclaration(this) ? "TypeParameterDeclaration" : isParameter(this) ? "ParameterDeclaration" : isConstructorDeclaration(this) ? "ConstructorDeclaration" : isGetAccessorDeclaration(this) ? "GetAccessorDeclaration" : isSetAccessorDeclaration(this) ? "SetAccessorDeclaration" : isCallSignatureDeclaration(this) ? "CallSignatureDeclaration" : isConstructSignatureDeclaration(this) ? "ConstructSignatureDeclaration" : isIndexSignatureDeclaration(this) ? "IndexSignatureDeclaration" : isTypePredicateNode(this) ? "TypePredicateNode" : isTypeReferenceNode(this) ? "TypeReferenceNode" : isFunctionTypeNode(this) ? "FunctionTypeNode" : isConstructorTypeNode(this) ? "ConstructorTypeNode" : isTypeQueryNode(this) ? "TypeQueryNode" : isTypeLiteralNode(this) ? "TypeLiteralNode" : isArrayTypeNode(this) ? "ArrayTypeNode" : isTupleTypeNode(this) ? "TupleTypeNode" : isOptionalTypeNode(this) ? "OptionalTypeNode" : isRestTypeNode(this) ? "RestTypeNode" : isUnionTypeNode(this) ? "UnionTypeNode" : isIntersectionTypeNode(this) ? "IntersectionTypeNode" : isConditionalTypeNode(this) ? "ConditionalTypeNode" : isInferTypeNode(this) ? "InferTypeNode" : isParenthesizedTypeNode(this) ? "ParenthesizedTypeNode" : isThisTypeNode(this) ? "ThisTypeNode" : isTypeOperatorNode(this) ? "TypeOperatorNode" : isIndexedAccessTypeNode(this) ? "IndexedAccessTypeNode" : isMappedTypeNode(this) ? "MappedTypeNode" : isLiteralTypeNode(this) ? "LiteralTypeNode" : isNamedTupleMember(this) ? "NamedTupleMember" : isImportTypeNode(this) ? "ImportTypeNode" : formatSyntaxKind(this.kind);
-                    return `${nodeHeader}${this.flags ? ` (${formatNodeFlags(this.flags)})` : ""}`;
-                  }
-                },
-                __debugKind: { get() {
-                  return formatSyntaxKind(this.kind);
-                } },
-                __debugNodeFlags: { get() {
-                  return formatNodeFlags(this.flags);
-                } },
-                __debugModifierFlags: { get() {
-                  return formatModifierFlags(getEffectiveModifierFlagsNoCache(this));
-                } },
-                __debugTransformFlags: { get() {
-                  return formatTransformFlags(this.transformFlags);
-                } },
-                __debugIsParseTreeNode: { get() {
-                  return isParseTreeNode(this);
-                } },
-                __debugEmitFlags: { get() {
-                  return formatEmitFlags(getEmitFlags(this));
-                } },
-                __debugGetText: {
-                  value(includeTrivia) {
-                    if (nodeIsSynthesized(this))
-                      return "";
-                    let text = weakNodeTextMap.get(this);
-                    if (text === void 0) {
-                      const parseNode = getParseTreeNode(this);
-                      const sourceFile = parseNode && getSourceFileOfNode(parseNode);
-                      text = sourceFile ? getSourceTextOfNodeFromSourceFile(sourceFile, parseNode, includeTrivia) : "";
-                      weakNodeTextMap.set(this, text);
-                    }
-                    return text;
-                  }
-                }
-              });
-            }
-          }
-          isDebugInfoEnabled = true;
-        }
-        Debug2.enableDebugInfo = enableDebugInfo;
-        function formatVariance(varianceFlags) {
-          const variance = varianceFlags & 7 /* VarianceMask */;
-          let result = variance === 0 /* Invariant */ ? "in out" : variance === 3 /* Bivariant */ ? "[bivariant]" : variance === 2 /* Contravariant */ ? "in" : variance === 1 /* Covariant */ ? "out" : variance === 4 /* Independent */ ? "[independent]" : "";
-          if (varianceFlags & 8 /* Unmeasurable */) {
-            result += " (unmeasurable)";
-          } else if (varianceFlags & 16 /* Unreliable */) {
-            result += " (unreliable)";
-          }
-          return result;
-        }
-        Debug2.formatVariance = formatVariance;
-        class DebugTypeMapper {
-          __debugToString() {
-            var _a;
-            type(this);
-            switch (this.kind) {
-              case 3 /* Function */:
-                return ((_a = this.debugInfo) == null ? void 0 : _a.call(this)) || "(function mapper)";
-              case 0 /* Simple */:
-                return `${this.source.__debugTypeToString()} -> ${this.target.__debugTypeToString()}`;
-              case 1 /* Array */:
-                return zipWith(
-                  this.sources,
-                  this.targets || map(this.sources, () => "any"),
-                  (s, t) => `${s.__debugTypeToString()} -> ${typeof t === "string" ? t : t.__debugTypeToString()}`
-                ).join(", ");
-              case 2 /* Deferred */:
-                return zipWith(
-                  this.sources,
-                  this.targets,
-                  (s, t) => `${s.__debugTypeToString()} -> ${t().__debugTypeToString()}`
-                ).join(", ");
-              case 5 /* Merged */:
-              case 4 /* Composite */:
-                return `m1: ${this.mapper1.__debugToString().split("\n").join("\n    ")}
-m2: ${this.mapper2.__debugToString().split("\n").join("\n    ")}`;
-              default:
-                return assertNever(this);
-            }
-          }
-        }
-        Debug2.DebugTypeMapper = DebugTypeMapper;
-        function attachDebugPrototypeIfDebug(mapper) {
-          if (Debug2.isDebugging) {
-            return Object.setPrototypeOf(mapper, DebugTypeMapper.prototype);
-          }
-          return mapper;
-        }
-        Debug2.attachDebugPrototypeIfDebug = attachDebugPrototypeIfDebug;
-        function printControlFlowGraph(flowNode) {
-          return console.log(formatControlFlowGraph(flowNode));
-        }
-        Debug2.printControlFlowGraph = printControlFlowGraph;
-        function formatControlFlowGraph(flowNode) {
-          let nextDebugFlowId = -1;
-          function getDebugFlowNodeId(f) {
-            if (!f.id) {
-              f.id = nextDebugFlowId;
-              nextDebugFlowId--;
-            }
-            return f.id;
-          }
-          let BoxCharacter;
-          ((BoxCharacter2) => {
-            BoxCharacter2["lr"] = "\u2500";
-            BoxCharacter2["ud"] = "\u2502";
-            BoxCharacter2["dr"] = "\u256D";
-            BoxCharacter2["dl"] = "\u256E";
-            BoxCharacter2["ul"] = "\u256F";
-            BoxCharacter2["ur"] = "\u2570";
-            BoxCharacter2["udr"] = "\u251C";
-            BoxCharacter2["udl"] = "\u2524";
-            BoxCharacter2["dlr"] = "\u252C";
-            BoxCharacter2["ulr"] = "\u2534";
-            BoxCharacter2["udlr"] = "\u256B";
-          })(BoxCharacter || (BoxCharacter = {}));
-          let Connection;
-          ((Connection2) => {
-            Connection2[Connection2["None"] = 0] = "None";
-            Connection2[Connection2["Up"] = 1] = "Up";
-            Connection2[Connection2["Down"] = 2] = "Down";
-            Connection2[Connection2["Left"] = 4] = "Left";
-            Connection2[Connection2["Right"] = 8] = "Right";
-            Connection2[Connection2["UpDown"] = 3] = "UpDown";
-            Connection2[Connection2["LeftRight"] = 12] = "LeftRight";
-            Connection2[Connection2["UpLeft"] = 5] = "UpLeft";
-            Connection2[Connection2["UpRight"] = 9] = "UpRight";
-            Connection2[Connection2["DownLeft"] = 6] = "DownLeft";
-            Connection2[Connection2["DownRight"] = 10] = "DownRight";
-            Connection2[Connection2["UpDownLeft"] = 7] = "UpDownLeft";
-            Connection2[Connection2["UpDownRight"] = 11] = "UpDownRight";
-            Connection2[Connection2["UpLeftRight"] = 13] = "UpLeftRight";
-            Connection2[Connection2["DownLeftRight"] = 14] = "DownLeftRight";
-            Connection2[Connection2["UpDownLeftRight"] = 15] = "UpDownLeftRight";
-            Connection2[Connection2["NoChildren"] = 16] = "NoChildren";
-          })(Connection || (Connection = {}));
-          const hasAntecedentFlags = 16 /* Assignment */ | 96 /* Condition */ | 128 /* SwitchClause */ | 256 /* ArrayMutation */ | 512 /* Call */ | 1024 /* ReduceLabel */;
-          const hasNodeFlags = 2 /* Start */ | 16 /* Assignment */ | 512 /* Call */ | 96 /* Condition */ | 256 /* ArrayMutation */;
-          const links = /* @__PURE__ */ Object.create(
-            /*o*/
-            null
-          );
-          const nodes = [];
-          const edges = [];
-          const root = buildGraphNode(flowNode, /* @__PURE__ */ new Set());
-          for (const node of nodes) {
-            node.text = renderFlowNode(node.flowNode, node.circular);
-            computeLevel(node);
-          }
-          const height = computeHeight(root);
-          const columnWidths = computeColumnWidths(height);
-          computeLanes(root, 0);
-          return renderGraph();
-          function isFlowSwitchClause(f) {
-            return !!(f.flags & 128 /* SwitchClause */);
-          }
-          function hasAntecedents(f) {
-            return !!(f.flags & 12 /* Label */) && !!f.antecedents;
-          }
-          function hasAntecedent(f) {
-            return !!(f.flags & hasAntecedentFlags);
-          }
-          function hasNode(f) {
-            return !!(f.flags & hasNodeFlags);
-          }
-          function getChildren(node) {
-            const children = [];
-            for (const edge of node.edges) {
-              if (edge.source === node) {
-                children.push(edge.target);
-              }
-            }
-            return children;
-          }
-          function getParents(node) {
-            const parents = [];
-            for (const edge of node.edges) {
-              if (edge.target === node) {
-                parents.push(edge.source);
-              }
-            }
-            return parents;
-          }
-          function buildGraphNode(flowNode2, seen) {
-            const id = getDebugFlowNodeId(flowNode2);
-            let graphNode = links[id];
-            if (graphNode && seen.has(flowNode2)) {
-              graphNode.circular = true;
-              graphNode = {
-                id: -1,
-                flowNode: flowNode2,
-                edges: [],
-                text: "",
-                lane: -1,
-                endLane: -1,
-                level: -1,
-                circular: "circularity"
-              };
-              nodes.push(graphNode);
-              return graphNode;
-            }
-            seen.add(flowNode2);
-            if (!graphNode) {
-              links[id] = graphNode = { id, flowNode: flowNode2, edges: [], text: "", lane: -1, endLane: -1, level: -1, circular: false };
-              nodes.push(graphNode);
-              if (hasAntecedents(flowNode2)) {
-                for (const antecedent of flowNode2.antecedents) {
-                  buildGraphEdge(graphNode, antecedent, seen);
-                }
-              } else if (hasAntecedent(flowNode2)) {
-                buildGraphEdge(graphNode, flowNode2.antecedent, seen);
-              }
-            }
-            seen.delete(flowNode2);
-            return graphNode;
-          }
-          function buildGraphEdge(source, antecedent, seen) {
-            const target = buildGraphNode(antecedent, seen);
-            const edge = { source, target };
-            edges.push(edge);
-            source.edges.push(edge);
-            target.edges.push(edge);
-          }
-          function computeLevel(node) {
-            if (node.level !== -1) {
-              return node.level;
-            }
-            let level = 0;
-            for (const parent2 of getParents(node)) {
-              level = Math.max(level, computeLevel(parent2) + 1);
-            }
-            return node.level = level;
-          }
-          function computeHeight(node) {
-            let height2 = 0;
-            for (const child of getChildren(node)) {
-              height2 = Math.max(height2, computeHeight(child));
-            }
-            return height2 + 1;
-          }
-          function computeColumnWidths(height2) {
-            const columns = fill(Array(height2), 0);
-            for (const node of nodes) {
-              columns[node.level] = Math.max(columns[node.level], node.text.length);
-            }
-            return columns;
-          }
-          function computeLanes(node, lane) {
-            if (node.lane === -1) {
-              node.lane = lane;
-              node.endLane = lane;
-              const children = getChildren(node);
-              for (let i = 0; i < children.length; i++) {
-                if (i > 0)
-                  lane++;
-                const child = children[i];
-                computeLanes(child, lane);
-                if (child.endLane > node.endLane) {
-                  lane = child.endLane;
-                }
-              }
-              node.endLane = lane;
-            }
-          }
-          function getHeader(flags) {
-            if (flags & 2 /* Start */)
-              return "Start";
-            if (flags & 4 /* BranchLabel */)
-              return "Branch";
-            if (flags & 8 /* LoopLabel */)
-              return "Loop";
-            if (flags & 16 /* Assignment */)
-              return "Assignment";
-            if (flags & 32 /* TrueCondition */)
-              return "True";
-            if (flags & 64 /* FalseCondition */)
-              return "False";
-            if (flags & 128 /* SwitchClause */)
-              return "SwitchClause";
-            if (flags & 256 /* ArrayMutation */)
-              return "ArrayMutation";
-            if (flags & 512 /* Call */)
-              return "Call";
-            if (flags & 1024 /* ReduceLabel */)
-              return "ReduceLabel";
-            if (flags & 1 /* Unreachable */)
-              return "Unreachable";
-            throw new Error();
-          }
-          function getNodeText(node) {
-            const sourceFile = getSourceFileOfNode(node);
-            return getSourceTextOfNodeFromSourceFile(
-              sourceFile,
-              node,
-              /*includeTrivia*/
-              false
-            );
-          }
-          function renderFlowNode(flowNode2, circular) {
-            let text = getHeader(flowNode2.flags);
-            if (circular) {
-              text = `${text}#${getDebugFlowNodeId(flowNode2)}`;
-            }
-            if (hasNode(flowNode2)) {
-              if (flowNode2.node) {
-                text += ` (${getNodeText(flowNode2.node)})`;
-              }
-            } else if (isFlowSwitchClause(flowNode2)) {
-              const clauses = [];
-              for (let i = flowNode2.clauseStart; i < flowNode2.clauseEnd; i++) {
-                const clause = flowNode2.switchStatement.caseBlock.clauses[i];
-                if (isDefaultClause(clause)) {
-                  clauses.push("default");
-                } else {
-                  clauses.push(getNodeText(clause.expression));
-                }
-              }
-              text += ` (${clauses.join(", ")})`;
-            }
-            return circular === "circularity" ? `Circular(${text})` : text;
-          }
-          function renderGraph() {
-            const columnCount = columnWidths.length;
-            const laneCount = nodes.reduce((x, n) => Math.max(x, n.lane), 0) + 1;
-            const lanes = fill(Array(laneCount), "");
-            const grid = columnWidths.map(() => Array(laneCount));
-            const connectors = columnWidths.map(() => fill(Array(laneCount), 0));
-            for (const node of nodes) {
-              grid[node.level][node.lane] = node;
-              const children = getChildren(node);
-              for (let i = 0; i < children.length; i++) {
-                const child = children[i];
-                let connector = 8 /* Right */;
-                if (child.lane === node.lane)
-                  connector |= 4 /* Left */;
-                if (i > 0)
-                  connector |= 1 /* Up */;
-                if (i < children.length - 1)
-                  connector |= 2 /* Down */;
-                connectors[node.level][child.lane] |= connector;
-              }
-              if (children.length === 0) {
-                connectors[node.level][node.lane] |= 16 /* NoChildren */;
-              }
-              const parents = getParents(node);
-              for (let i = 0; i < parents.length; i++) {
-                const parent2 = parents[i];
-                let connector = 4 /* Left */;
-                if (i > 0)
-                  connector |= 1 /* Up */;
-                if (i < parents.length - 1)
-                  connector |= 2 /* Down */;
-                connectors[node.level - 1][parent2.lane] |= connector;
-              }
-            }
-            for (let column = 0; column < columnCount; column++) {
-              for (let lane = 0; lane < laneCount; lane++) {
-                const left = column > 0 ? connectors[column - 1][lane] : 0;
-                const above = lane > 0 ? connectors[column][lane - 1] : 0;
-                let connector = connectors[column][lane];
-                if (!connector) {
-                  if (left & 8 /* Right */)
-                    connector |= 12 /* LeftRight */;
-                  if (above & 2 /* Down */)
-                    connector |= 3 /* UpDown */;
-                  connectors[column][lane] = connector;
-                }
-              }
-            }
-            for (let column = 0; column < columnCount; column++) {
-              for (let lane = 0; lane < lanes.length; lane++) {
-                const connector = connectors[column][lane];
-                const fill2 = connector & 4 /* Left */ ? "\u2500" /* lr */ : " ";
-                const node = grid[column][lane];
-                if (!node) {
-                  if (column < columnCount - 1) {
-                    writeLane(lane, repeat(fill2, columnWidths[column] + 1));
-                  }
-                } else {
-                  writeLane(lane, node.text);
-                  if (column < columnCount - 1) {
-                    writeLane(lane, " ");
-                    writeLane(lane, repeat(fill2, columnWidths[column] - node.text.length));
-                  }
-                }
-                writeLane(lane, getBoxCharacter(connector));
-                writeLane(lane, connector & 8 /* Right */ && column < columnCount - 1 && !grid[column + 1][lane] ? "\u2500" /* lr */ : " ");
-              }
-            }
-            return `
-${lanes.join("\n")}
-`;
-            function writeLane(lane, text) {
-              lanes[lane] += text;
-            }
-          }
-          function getBoxCharacter(connector) {
-            switch (connector) {
-              case 3 /* UpDown */:
-                return "\u2502" /* ud */;
-              case 12 /* LeftRight */:
-                return "\u2500" /* lr */;
-              case 5 /* UpLeft */:
-                return "\u256F" /* ul */;
-              case 9 /* UpRight */:
-                return "\u2570" /* ur */;
-              case 6 /* DownLeft */:
-                return "\u256E" /* dl */;
-              case 10 /* DownRight */:
-                return "\u256D" /* dr */;
-              case 7 /* UpDownLeft */:
-                return "\u2524" /* udl */;
-              case 11 /* UpDownRight */:
-                return "\u251C" /* udr */;
-              case 13 /* UpLeftRight */:
-                return "\u2534" /* ulr */;
-              case 14 /* DownLeftRight */:
-                return "\u252C" /* dlr */;
-              case 15 /* UpDownLeftRight */:
-                return "\u256B" /* udlr */;
-            }
-            return " ";
-          }
-          function fill(array, value) {
-            if (array.fill) {
-              array.fill(value);
-            } else {
-              for (let i = 0; i < array.length; i++) {
-                array[i] = value;
-              }
-            }
-            return array;
-          }
-          function repeat(ch, length2) {
-            if (ch.repeat) {
-              return length2 > 0 ? ch.repeat(length2) : "";
-            }
-            let s = "";
-            while (s.length < length2) {
-              s += ch;
-            }
-            return s;
-          }
-        }
-        Debug2.formatControlFlowGraph = formatControlFlowGraph;
-      })(Debug || (Debug = {}));
-    }
-  });
-
-  // src/compiler/semver.ts
-  function tryParseComponents(text) {
-    const match = versionRegExp.exec(text);
-    if (!match)
-      return void 0;
-    const [, major, minor = "0", patch = "0", prerelease = "", build2 = ""] = match;
-    if (prerelease && !prereleaseRegExp.test(prerelease))
-      return void 0;
-    if (build2 && !buildRegExp.test(build2))
-      return void 0;
-    return {
-      major: parseInt(major, 10),
-      minor: parseInt(minor, 10),
-      patch: parseInt(patch, 10),
-      prerelease,
-      build: build2
-    };
-  }
-  function comparePrereleaseIdentifiers(left, right) {
-    if (left === right)
-      return 0 /* EqualTo */;
-    if (left.length === 0)
-      return right.length === 0 ? 0 /* EqualTo */ : 1 /* GreaterThan */;
-    if (right.length === 0)
-      return -1 /* LessThan */;
-    const length2 = Math.min(left.length, right.length);
-    for (let i = 0; i < length2; i++) {
-      const leftIdentifier = left[i];
-      const rightIdentifier = right[i];
-      if (leftIdentifier === rightIdentifier)
-        continue;
-      const leftIsNumeric = numericIdentifierRegExp.test(leftIdentifier);
-      const rightIsNumeric = numericIdentifierRegExp.test(rightIdentifier);
-      if (leftIsNumeric || rightIsNumeric) {
-        if (leftIsNumeric !== rightIsNumeric)
-          return leftIsNumeric ? -1 /* LessThan */ : 1 /* GreaterThan */;
-        const result = compareValues(+leftIdentifier, +rightIdentifier);
-        if (result)
-          return result;
-      } else {
-        const result = compareStringsCaseSensitive(leftIdentifier, rightIdentifier);
-        if (result)
-          return result;
-      }
-    }
-    return compareValues(left.length, right.length);
-  }
-  function parseRange(text) {
-    const alternatives = [];
-    for (let range of trimString(text).split(logicalOrRegExp)) {
-      if (!range)
-        continue;
-      const comparators = [];
-      range = trimString(range);
-      const match = hyphenRegExp.exec(range);
-      if (match) {
-        if (!parseHyphen(match[1], match[2], comparators))
-          return void 0;
-      } else {
-        for (const simple of range.split(whitespaceRegExp)) {
-          const match2 = rangeRegExp.exec(trimString(simple));
-          if (!match2 || !parseComparator(match2[1], match2[2], comparators))
-            return void 0;
-        }
-      }
-      alternatives.push(comparators);
-    }
-    return alternatives;
-  }
-  function parsePartial(text) {
-    const match = partialRegExp.exec(text);
-    if (!match)
-      return void 0;
-    const [, major, minor = "*", patch = "*", prerelease, build2] = match;
-    const version2 = new Version(
-      isWildcard(major) ? 0 : parseInt(major, 10),
-      isWildcard(major) || isWildcard(minor) ? 0 : parseInt(minor, 10),
-      isWildcard(major) || isWildcard(minor) || isWildcard(patch) ? 0 : parseInt(patch, 10),
-      prerelease,
-      build2
-    );
-    return { version: version2, major, minor, patch };
-  }
-  function parseHyphen(left, right, comparators) {
-    const leftResult = parsePartial(left);
-    if (!leftResult)
-      return false;
-    const rightResult = parsePartial(right);
-    if (!rightResult)
-      return false;
-    if (!isWildcard(leftResult.major)) {
-      comparators.push(createComparator(">=", leftResult.version));
-    }
-    if (!isWildcard(rightResult.major)) {
-      comparators.push(
-        isWildcard(rightResult.minor) ? createComparator("<", rightResult.version.increment("major")) : isWildcard(rightResult.patch) ? createComparator("<", rightResult.version.increment("minor")) : createComparator("<=", rightResult.version)
-      );
-    }
-    return true;
-  }
-  function parseComparator(operator, text, comparators) {
-    const result = parsePartial(text);
-    if (!result)
-      return false;
-    const { version: version2, major, minor, patch } = result;
-    if (!isWildcard(major)) {
-      switch (operator) {
-        case "~":
-          comparators.push(createComparator(">=", version2));
-          comparators.push(createComparator("<", version2.increment(
-            isWildcard(minor) ? "major" : "minor"
-          )));
-          break;
-        case "^":
-          comparators.push(createComparator(">=", version2));
-          comparators.push(createComparator("<", version2.increment(
-            version2.major > 0 || isWildcard(minor) ? "major" : version2.minor > 0 || isWildcard(patch) ? "minor" : "patch"
-          )));
-          break;
-        case "<":
-        case ">=":
-          comparators.push(
-            isWildcard(minor) || isWildcard(patch) ? createComparator(operator, version2.with({ prerelease: "0" })) : createComparator(operator, version2)
-          );
-          break;
-        case "<=":
-        case ">":
-          comparators.push(
-            isWildcard(minor) ? createComparator(operator === "<=" ? "<" : ">=", version2.increment("major").with({ prerelease: "0" })) : isWildcard(patch) ? createComparator(operator === "<=" ? "<" : ">=", version2.increment("minor").with({ prerelease: "0" })) : createComparator(operator, version2)
-          );
-          break;
-        case "=":
-        case void 0:
-          if (isWildcard(minor) || isWildcard(patch)) {
-            comparators.push(createComparator(">=", version2.with({ prerelease: "0" })));
-            comparators.push(createComparator("<", version2.increment(isWildcard(minor) ? "major" : "minor").with({ prerelease: "0" })));
-          } else {
-            comparators.push(createComparator("=", version2));
-          }
-          break;
-        default:
-          return false;
-      }
-    } else if (operator === "<" || operator === ">") {
-      comparators.push(createComparator("<", Version.zero));
-    }
-    return true;
-  }
-  function isWildcard(part) {
-    return part === "*" || part === "x" || part === "X";
-  }
-  function createComparator(operator, operand) {
-    return { operator, operand };
-  }
-  function testDisjunction(version2, alternatives) {
-    if (alternatives.length === 0)
-      return true;
-    for (const alternative of alternatives) {
-      if (testAlternative(version2, alternative))
-        return true;
-    }
-    return false;
-  }
-  function testAlternative(version2, comparators) {
-    for (const comparator of comparators) {
-      if (!testComparator(version2, comparator.operator, comparator.operand))
-        return false;
-    }
-    return true;
-  }
-  function testComparator(version2, operator, operand) {
-    const cmp = version2.compareTo(operand);
-    switch (operator) {
-      case "<":
-        return cmp < 0;
-      case "<=":
-        return cmp <= 0;
-      case ">":
-        return cmp > 0;
-      case ">=":
-        return cmp >= 0;
-      case "=":
-        return cmp === 0;
-      default:
-        return Debug.assertNever(operator);
-    }
-  }
-  function formatDisjunction(alternatives) {
-    return map(alternatives, formatAlternative).join(" || ") || "*";
-  }
-  function formatAlternative(comparators) {
-    return map(comparators, formatComparator).join(" ");
-  }
-  function formatComparator(comparator) {
-    return `${comparator.operator}${comparator.operand}`;
-  }
-  var versionRegExp, prereleaseRegExp, prereleasePartRegExp, buildRegExp, buildPartRegExp, numericIdentifierRegExp, _Version, Version, VersionRange, logicalOrRegExp, whitespaceRegExp, partialRegExp, hyphenRegExp, rangeRegExp;
-  var init_semver = __esm({
-    "src/compiler/semver.ts"() {
-      "use strict";
-      init_ts2();
-      versionRegExp = /^(0|[1-9]\d*)(?:\.(0|[1-9]\d*)(?:\.(0|[1-9]\d*)(?:\-([a-z0-9-.]+))?(?:\+([a-z0-9-.]+))?)?)?$/i;
-      prereleaseRegExp = /^(?:0|[1-9]\d*|[a-z-][a-z0-9-]*)(?:\.(?:0|[1-9]\d*|[a-z-][a-z0-9-]*))*$/i;
-      prereleasePartRegExp = /^(?:0|[1-9]\d*|[a-z-][a-z0-9-]*)$/i;
-      buildRegExp = /^[a-z0-9-]+(?:\.[a-z0-9-]+)*$/i;
-      buildPartRegExp = /^[a-z0-9-]+$/i;
-      numericIdentifierRegExp = /^(0|[1-9]\d*)$/;
-      _Version = class {
-        constructor(major, minor = 0, patch = 0, prerelease = "", build2 = "") {
-          if (typeof major === "string") {
-            const result = Debug.checkDefined(tryParseComponents(major), "Invalid version");
-            ({ major, minor, patch, prerelease, build: build2 } = result);
-          }
-          Debug.assert(major >= 0, "Invalid argument: major");
-          Debug.assert(minor >= 0, "Invalid argument: minor");
-          Debug.assert(patch >= 0, "Invalid argument: patch");
-          const prereleaseArray = prerelease ? isArray(prerelease) ? prerelease : prerelease.split(".") : emptyArray;
-          const buildArray = build2 ? isArray(build2) ? build2 : build2.split(".") : emptyArray;
-          Debug.assert(every(prereleaseArray, (s) => prereleasePartRegExp.test(s)), "Invalid argument: prerelease");
-          Debug.assert(every(buildArray, (s) => buildPartRegExp.test(s)), "Invalid argument: build");
-          this.major = major;
-          this.minor = minor;
-          this.patch = patch;
-          this.prerelease = prereleaseArray;
-          this.build = buildArray;
-        }
-        static tryParse(text) {
-          const result = tryParseComponents(text);
-          if (!result)
-            return void 0;
-          const { major, minor, patch, prerelease, build: build2 } = result;
-          return new _Version(major, minor, patch, prerelease, build2);
-        }
-        compareTo(other) {
-          if (this === other)
-            return 0 /* EqualTo */;
-          if (other === void 0)
-            return 1 /* GreaterThan */;
-          return compareValues(this.major, other.major) || compareValues(this.minor, other.minor) || compareValues(this.patch, other.patch) || comparePrereleaseIdentifiers(this.prerelease, other.prerelease);
-        }
-        increment(field) {
-          switch (field) {
-            case "major":
-              return new _Version(this.major + 1, 0, 0);
-            case "minor":
-              return new _Version(this.major, this.minor + 1, 0);
-            case "patch":
-              return new _Version(this.major, this.minor, this.patch + 1);
-            default:
-              return Debug.assertNever(field);
-          }
-        }
-        with(fields) {
-          const {
-            major = this.major,
-            minor = this.minor,
-            patch = this.patch,
-            prerelease = this.prerelease,
-            build: build2 = this.build
-          } = fields;
-          return new _Version(major, minor, patch, prerelease, build2);
-        }
-        toString() {
-          let result = `${this.major}.${this.minor}.${this.patch}`;
-          if (some(this.prerelease))
-            result += `-${this.prerelease.join(".")}`;
-          if (some(this.build))
-            result += `+${this.build.join(".")}`;
-          return result;
-        }
-      };
-      Version = _Version;
-      Version.zero = new _Version(0, 0, 0, ["0"]);
-      VersionRange = class {
-        constructor(spec) {
-          this._alternatives = spec ? Debug.checkDefined(parseRange(spec), "Invalid range spec.") : emptyArray;
-        }
-        static tryParse(text) {
-          const sets = parseRange(text);
-          if (sets) {
-            const range = new VersionRange("");
-            range._alternatives = sets;
-            return range;
-          }
-          return void 0;
-        }
-        /**
-         * Tests whether a version matches the range. This is equivalent to `satisfies(version, range, { includePrerelease: true })`.
-         * in `node-semver`.
-         */
-        test(version2) {
-          if (typeof version2 === "string")
-            version2 = new Version(version2);
-          return testDisjunction(version2, this._alternatives);
-        }
-        toString() {
-          return formatDisjunction(this._alternatives);
-        }
-      };
-      logicalOrRegExp = /\|\|/g;
-      whitespaceRegExp = /\s+/g;
-      partialRegExp = /^([xX*0]|[1-9]\d*)(?:\.([xX*0]|[1-9]\d*)(?:\.([xX*0]|[1-9]\d*)(?:-([a-z0-9-.]+))?(?:\+([a-z0-9-.]+))?)?)?$/i;
-      hyphenRegExp = /^\s*([a-z0-9-+.*]+)\s+-\s+([a-z0-9-+.*]+)\s*$/i;
-      rangeRegExp = /^(~|\^|<|<=|>|>=|=)?\s*([a-z0-9-+.*]+)$/i;
-    }
-  });
-
-  // src/compiler/performanceCore.ts
-  function hasRequiredAPI(performance2, PerformanceObserver2) {
-    return typeof performance2 === "object" && typeof performance2.timeOrigin === "number" && typeof performance2.mark === "function" && typeof performance2.measure === "function" && typeof performance2.now === "function" && typeof performance2.clearMarks === "function" && typeof performance2.clearMeasures === "function" && typeof PerformanceObserver2 === "function";
-  }
-  function tryGetWebPerformanceHooks() {
-    if (typeof performance === "object" && typeof PerformanceObserver === "function" && hasRequiredAPI(performance, PerformanceObserver)) {
-      return {
-        // For now we always write native performance events when running in the browser. We may
-        // make this conditional in the future if we find that native web performance hooks
-        // in the browser also slow down compilation.
-        shouldWriteNativeEvents: true,
-        performance,
-        PerformanceObserver
-      };
-    }
-  }
-  function tryGetNodePerformanceHooks() {
-    if (isNodeLikeSystem()) {
-      try {
-        const { performance: performance2, PerformanceObserver: PerformanceObserver2 } =   require("perf_hooks");
-        if (hasRequiredAPI(performance2, PerformanceObserver2)) {
-          return {
-            // By default, only write native events when generating a cpu profile or using the v8 profiler.
-            shouldWriteNativeEvents: false,
-            performance: performance2,
-            PerformanceObserver: PerformanceObserver2
-          };
-        }
-      } catch {
-      }
-    }
-  }
-  function tryGetNativePerformanceHooks() {
-    return nativePerformanceHooks;
-  }
-  var nativePerformanceHooks, nativePerformance, timestamp;
-  var init_performanceCore = __esm({
-    "src/compiler/performanceCore.ts"() {
-      "use strict";
-      init_ts2();
-      nativePerformanceHooks = tryGetWebPerformanceHooks() || tryGetNodePerformanceHooks();
-      nativePerformance = nativePerformanceHooks == null ? void 0 : nativePerformanceHooks.performance;
-      timestamp = nativePerformance ? () => nativePerformance.now() : Date.now ? Date.now : () => +/* @__PURE__ */ new Date();
-    }
-  });
-
-  // src/compiler/perfLogger.ts
-  var etwModule, perfLogger;
-  var init_perfLogger = __esm({
-    "src/compiler/perfLogger.ts"() {
-      "use strict";
-      try {
-        const etwModulePath = process.env.TS_ETW_MODULE_PATH ?? "./node_modules/@microsoft/typescript-etw";
-        etwModule =   require(etwModulePath);
-      } catch (e) {
-        etwModule = void 0;
-      }
-      perfLogger = (etwModule == null ? void 0 : etwModule.logEvent) ? etwModule : void 0;
-    }
-  });
-
-  // src/compiler/performance.ts
-  function createTimerIf(condition, measureName, startMarkName, endMarkName) {
-    return condition ? createTimer(measureName, startMarkName, endMarkName) : nullTimer;
-  }
-  function createTimer(measureName, startMarkName, endMarkName) {
-    let enterCount = 0;
-    return {
-      enter,
-      exit
-    };
-    function enter() {
-      if (++enterCount === 1) {
-        mark(startMarkName);
-      }
-    }
-    function exit() {
-      if (--enterCount === 0) {
-        mark(endMarkName);
-        measure(measureName, startMarkName, endMarkName);
-      } else if (enterCount < 0) {
-        Debug.fail("enter/exit count does not match.");
-      }
-    }
-  }
-  function mark(markName) {
-    if (enabled) {
-      const count = counts.get(markName) ?? 0;
-      counts.set(markName, count + 1);
-      marks.set(markName, timestamp());
-      performanceImpl == null ? void 0 : performanceImpl.mark(markName);
-      if (typeof onProfilerEvent === "function") {
-        onProfilerEvent(markName);
-      }
-    }
-  }
-  function measure(measureName, startMarkName, endMarkName) {
-    if (enabled) {
-      const end = (endMarkName !== void 0 ? marks.get(endMarkName) : void 0) ?? timestamp();
-      const start = (startMarkName !== void 0 ? marks.get(startMarkName) : void 0) ?? timeorigin;
-      const previousDuration = durations.get(measureName) || 0;
-      durations.set(measureName, previousDuration + (end - start));
-      performanceImpl == null ? void 0 : performanceImpl.measure(measureName, startMarkName, endMarkName);
-    }
-  }
-  function getCount(markName) {
-    return counts.get(markName) || 0;
-  }
-  function getDuration(measureName) {
-    return durations.get(measureName) || 0;
-  }
-  function forEachMeasure(cb) {
-    durations.forEach((duration, measureName) => cb(measureName, duration));
-  }
-  function forEachMark(cb) {
-    marks.forEach((_time, markName) => cb(markName));
-  }
-  function clearMeasures(name) {
-    if (name !== void 0)
-      durations.delete(name);
-    else
-      durations.clear();
-    performanceImpl == null ? void 0 : performanceImpl.clearMeasures(name);
-  }
-  function clearMarks(name) {
-    if (name !== void 0) {
-      counts.delete(name);
-      marks.delete(name);
-    } else {
-      counts.clear();
-      marks.clear();
-    }
-    performanceImpl == null ? void 0 : performanceImpl.clearMarks(name);
-  }
-  function isEnabled() {
-    return enabled;
-  }
-  function enable(system = sys) {
-    var _a;
-    if (!enabled) {
-      enabled = true;
-      perfHooks || (perfHooks = tryGetNativePerformanceHooks());
-      if (perfHooks) {
-        timeorigin = perfHooks.performance.timeOrigin;
-        if (perfHooks.shouldWriteNativeEvents || ((_a = system == null ? void 0 : system.cpuProfilingEnabled) == null ? void 0 : _a.call(system)) || (system == null ? void 0 : system.debugMode)) {
-          performanceImpl = perfHooks.performance;
-        }
-      }
-    }
-    return true;
-  }
-  function disable() {
-    if (enabled) {
-      marks.clear();
-      counts.clear();
-      durations.clear();
-      performanceImpl = void 0;
-      enabled = false;
-    }
-  }
-  var perfHooks, performanceImpl, nullTimer, enabled, timeorigin, marks, counts, durations;
-  var init_performance = __esm({
-    "src/compiler/performance.ts"() {
-      "use strict";
-      init_ts2();
-      nullTimer = { enter: noop, exit: noop };
-      enabled = false;
-      timeorigin = timestamp();
-      marks = /* @__PURE__ */ new Map();
-      counts = /* @__PURE__ */ new Map();
-      durations = /* @__PURE__ */ new Map();
-    }
-  });
-
-  // src/compiler/_namespaces/ts.performance.ts
-  var ts_performance_exports = {};
-  __export(ts_performance_exports, {
-    clearMarks: () => clearMarks,
-    clearMeasures: () => clearMeasures,
-    createTimer: () => createTimer,
-    createTimerIf: () => createTimerIf,
-    disable: () => disable,
-    enable: () => enable,
-    forEachMark: () => forEachMark,
-    forEachMeasure: () => forEachMeasure,
-    getCount: () => getCount,
-    getDuration: () => getDuration,
-    isEnabled: () => isEnabled,
-    mark: () => mark,
-    measure: () => measure,
-    nullTimer: () => nullTimer
-  });
-  var init_ts_performance = __esm({
-    "src/compiler/_namespaces/ts.performance.ts"() {
-      "use strict";
-      init_performance();
-    }
-  });
-
-  // src/compiler/tracing.ts
-  var tracing, tracingEnabled, startTracing, dumpTracingLegend;
-  var init_tracing = __esm({
-    "src/compiler/tracing.ts"() {
-      "use strict";
-      init_ts2();
-      init_ts_performance();
-      ((tracingEnabled2) => {
-        let fs;
-        let traceCount = 0;
-        let traceFd = 0;
-        let mode;
-        const typeCatalog = [];
-        let legendPath;
-        const legend = [];
-        function startTracing2(tracingMode, traceDir, configFilePath) {
-          Debug.assert(!tracing, "Tracing already started");
-          if (fs === void 0) {
-            try {
-              fs =   require("fs");
-            } catch (e) {
-              throw new Error(`tracing requires having fs
-(original error: ${e.message || e})`);
-            }
-          }
-          mode = tracingMode;
-          typeCatalog.length = 0;
-          if (legendPath === void 0) {
-            legendPath = combinePaths(traceDir, "legend.json");
-          }
-          if (!fs.existsSync(traceDir)) {
-            fs.mkdirSync(traceDir, { recursive: true });
-          }
-          const countPart = mode === "build" ? `.${process.pid}-${++traceCount}` : mode === "server" ? `.${process.pid}` : ``;
-          const tracePath = combinePaths(traceDir, `trace${countPart}.json`);
-          const typesPath = combinePaths(traceDir, `types${countPart}.json`);
-          legend.push({
-            configFilePath,
-            tracePath,
-            typesPath
-          });
-          traceFd = fs.openSync(tracePath, "w");
-          tracing = tracingEnabled2;
-          const meta = { cat: "__metadata", ph: "M", ts: 1e3 * timestamp(), pid: 1, tid: 1 };
-          fs.writeSync(
-            traceFd,
-            "[\n" + [
-              { name: "process_name", args: { name: "tsc" }, ...meta },
-              { name: "thread_name", args: { name: "Main" }, ...meta },
-              { name: "TracingStartedInBrowser", ...meta, cat: "disabled-by-default-devtools.timeline" }
-            ].map((v) => JSON.stringify(v)).join(",\n")
-          );
-        }
-        tracingEnabled2.startTracing = startTracing2;
-        function stopTracing() {
-          Debug.assert(tracing, "Tracing is not in progress");
-          Debug.assert(!!typeCatalog.length === (mode !== "server"));
-          fs.writeSync(traceFd, `
-]
-`);
-          fs.closeSync(traceFd);
-          tracing = void 0;
-          if (typeCatalog.length) {
-            dumpTypes(typeCatalog);
-          } else {
-            legend[legend.length - 1].typesPath = void 0;
-          }
-        }
-        tracingEnabled2.stopTracing = stopTracing;
-        function recordType(type) {
-          if (mode !== "server") {
-            typeCatalog.push(type);
-          }
-        }
-        tracingEnabled2.recordType = recordType;
-        let Phase;
-        ((Phase2) => {
-          Phase2["Parse"] = "parse";
-          Phase2["Program"] = "program";
-          Phase2["Bind"] = "bind";
-          Phase2["Check"] = "check";
-          Phase2["CheckTypes"] = "checkTypes";
-          Phase2["Emit"] = "emit";
-          Phase2["Session"] = "session";
-        })(Phase = tracingEnabled2.Phase || (tracingEnabled2.Phase = {}));
-        function instant(phase, name, args) {
-          writeEvent("I", phase, name, args, `"s":"g"`);
-        }
-        tracingEnabled2.instant = instant;
-        const eventStack = [];
-        function push(phase, name, args, separateBeginAndEnd = false) {
-          if (separateBeginAndEnd) {
-            writeEvent("B", phase, name, args);
-          }
-          eventStack.push({ phase, name, args, time: 1e3 * timestamp(), separateBeginAndEnd });
-        }
-        tracingEnabled2.push = push;
-        function pop(results) {
-          Debug.assert(eventStack.length > 0);
-          writeStackEvent(eventStack.length - 1, 1e3 * timestamp(), results);
-          eventStack.length--;
-        }
-        tracingEnabled2.pop = pop;
-        function popAll() {
-          const endTime = 1e3 * timestamp();
-          for (let i = eventStack.length - 1; i >= 0; i--) {
-            writeStackEvent(i, endTime);
-          }
-          eventStack.length = 0;
-        }
-        tracingEnabled2.popAll = popAll;
-        const sampleInterval = 1e3 * 10;
-        function writeStackEvent(index, endTime, results) {
-          const { phase, name, args, time, separateBeginAndEnd } = eventStack[index];
-          if (separateBeginAndEnd) {
-            Debug.assert(!results, "`results` are not supported for events with `separateBeginAndEnd`");
-            writeEvent(
-              "E",
-              phase,
-              name,
-              args,
-              /*extras*/
-              void 0,
-              endTime
-            );
-          } else if (sampleInterval - time % sampleInterval <= endTime - time) {
-            writeEvent("X", phase, name, { ...args, results }, `"dur":${endTime - time}`, time);
-          }
-        }
-        function writeEvent(eventType, phase, name, args, extras, time = 1e3 * timestamp()) {
-          if (mode === "server" && phase === "checkTypes" /* CheckTypes */)
-            return;
-          mark("beginTracing");
-          fs.writeSync(traceFd, `,
-{"pid":1,"tid":1,"ph":"${eventType}","cat":"${phase}","ts":${time},"name":"${name}"`);
-          if (extras)
-            fs.writeSync(traceFd, `,${extras}`);
-          if (args)
-            fs.writeSync(traceFd, `,"args":${JSON.stringify(args)}`);
-          fs.writeSync(traceFd, `}`);
-          mark("endTracing");
-          measure("Tracing", "beginTracing", "endTracing");
-        }
-        function getLocation(node) {
-          const file = getSourceFileOfNode(node);
-          return !file ? void 0 : {
-            path: file.path,
-            start: indexFromOne(getLineAndCharacterOfPosition(file, node.pos)),
-            end: indexFromOne(getLineAndCharacterOfPosition(file, node.end))
-          };
-          function indexFromOne(lc) {
-            return {
-              line: lc.line + 1,
-              character: lc.character + 1
-            };
-          }
-        }
-        function dumpTypes(types) {
-          var _a, _b, _c, _d, _e, _f, _g, _h, _i, _j, _k, _l, _m, _n, _o, _p, _q, _r, _s;
-          mark("beginDumpTypes");
-          const typesPath = legend[legend.length - 1].typesPath;
-          const typesFd = fs.openSync(typesPath, "w");
-          const recursionIdentityMap = /* @__PURE__ */ new Map();
-          fs.writeSync(typesFd, "[");
-          const numTypes = types.length;
-          for (let i = 0; i < numTypes; i++) {
-            const type = types[i];
-            const objectFlags = type.objectFlags;
-            const symbol = type.aliasSymbol ?? type.symbol;
-            let display;
-            if (objectFlags & 16 /* Anonymous */ | type.flags & 2944 /* Literal */) {
-              try {
-                display = (_a = type.checker) == null ? void 0 : _a.typeToString(type);
-              } catch {
-                display = void 0;
-              }
-            }
-            let indexedAccessProperties = {};
-            if (type.flags & 8388608 /* IndexedAccess */) {
-              const indexedAccessType = type;
-              indexedAccessProperties = {
-                indexedAccessObjectType: (_b = indexedAccessType.objectType) == null ? void 0 : _b.id,
-                indexedAccessIndexType: (_c = indexedAccessType.indexType) == null ? void 0 : _c.id
-              };
-            }
-            let referenceProperties = {};
-            if (objectFlags & 4 /* Reference */) {
-              const referenceType = type;
-              referenceProperties = {
-                instantiatedType: (_d = referenceType.target) == null ? void 0 : _d.id,
-                typeArguments: (_e = referenceType.resolvedTypeArguments) == null ? void 0 : _e.map((t) => t.id),
-                referenceLocation: getLocation(referenceType.node)
-              };
-            }
-            let conditionalProperties = {};
-            if (type.flags & 16777216 /* Conditional */) {
-              const conditionalType = type;
-              conditionalProperties = {
-                conditionalCheckType: (_f = conditionalType.checkType) == null ? void 0 : _f.id,
-                conditionalExtendsType: (_g = conditionalType.extendsType) == null ? void 0 : _g.id,
-                conditionalTrueType: ((_h = conditionalType.resolvedTrueType) == null ? void 0 : _h.id) ?? -1,
-                conditionalFalseType: ((_i = conditionalType.resolvedFalseType) == null ? void 0 : _i.id) ?? -1
-              };
-            }
-            let substitutionProperties = {};
-            if (type.flags & 33554432 /* Substitution */) {
-              const substitutionType = type;
-              substitutionProperties = {
-                substitutionBaseType: (_j = substitutionType.baseType) == null ? void 0 : _j.id,
-                constraintType: (_k = substitutionType.constraint) == null ? void 0 : _k.id
-              };
-            }
-            let reverseMappedProperties = {};
-            if (objectFlags & 1024 /* ReverseMapped */) {
-              const reverseMappedType = type;
-              reverseMappedProperties = {
-                reverseMappedSourceType: (_l = reverseMappedType.source) == null ? void 0 : _l.id,
-                reverseMappedMappedType: (_m = reverseMappedType.mappedType) == null ? void 0 : _m.id,
-                reverseMappedConstraintType: (_n = reverseMappedType.constraintType) == null ? void 0 : _n.id
-              };
-            }
-            let evolvingArrayProperties = {};
-            if (objectFlags & 256 /* EvolvingArray */) {
-              const evolvingArrayType = type;
-              evolvingArrayProperties = {
-                evolvingArrayElementType: evolvingArrayType.elementType.id,
-                evolvingArrayFinalType: (_o = evolvingArrayType.finalArrayType) == null ? void 0 : _o.id
-              };
-            }
-            let recursionToken;
-            const recursionIdentity = type.checker.getRecursionIdentity(type);
-            if (recursionIdentity) {
-              recursionToken = recursionIdentityMap.get(recursionIdentity);
-              if (!recursionToken) {
-                recursionToken = recursionIdentityMap.size;
-                recursionIdentityMap.set(recursionIdentity, recursionToken);
-              }
-            }
-            const descriptor = {
-              id: type.id,
-              intrinsicName: type.intrinsicName,
-              symbolName: (symbol == null ? void 0 : symbol.escapedName) && unescapeLeadingUnderscores(symbol.escapedName),
-              recursionId: recursionToken,
-              isTuple: objectFlags & 8 /* Tuple */ ? true : void 0,
-              unionTypes: type.flags & 1048576 /* Union */ ? (_p = type.types) == null ? void 0 : _p.map((t) => t.id) : void 0,
-              intersectionTypes: type.flags & 2097152 /* Intersection */ ? type.types.map((t) => t.id) : void 0,
-              aliasTypeArguments: (_q = type.aliasTypeArguments) == null ? void 0 : _q.map((t) => t.id),
-              keyofType: type.flags & 4194304 /* Index */ ? (_r = type.type) == null ? void 0 : _r.id : void 0,
-              ...indexedAccessProperties,
-              ...referenceProperties,
-              ...conditionalProperties,
-              ...substitutionProperties,
-              ...reverseMappedProperties,
-              ...evolvingArrayProperties,
-              destructuringPattern: getLocation(type.pattern),
-              firstDeclaration: getLocation((_s = symbol == null ? void 0 : symbol.declarations) == null ? void 0 : _s[0]),
-              flags: Debug.formatTypeFlags(type.flags).split("|"),
-              display
-            };
-            fs.writeSync(typesFd, JSON.stringify(descriptor));
-            if (i < numTypes - 1) {
-              fs.writeSync(typesFd, ",\n");
-            }
-          }
-          fs.writeSync(typesFd, "]\n");
-          fs.closeSync(typesFd);
-          mark("endDumpTypes");
-          measure("Dump types", "beginDumpTypes", "endDumpTypes");
-        }
-        function dumpLegend() {
-          if (!legendPath) {
-            return;
-          }
-          fs.writeFileSync(legendPath, JSON.stringify(legend));
-        }
-        tracingEnabled2.dumpLegend = dumpLegend;
-      })(tracingEnabled || (tracingEnabled = {}));
-      startTracing = tracingEnabled.startTracing;
-      dumpTracingLegend = tracingEnabled.dumpLegend;
-    }
-  });
-
-  // src/compiler/types.ts
-  function diagnosticCategoryName(d, lowerCase = true) {
-    const name = DiagnosticCategory[d.category];
-    return lowerCase ? name.toLowerCase() : name;
-  }
-  var SyntaxKind, NodeFlags, ModifierFlags, JsxFlags, RelationComparisonResult, GeneratedIdentifierFlags, TokenFlags, FlowFlags, CommentDirectiveType, OperationCanceledException, FileIncludeKind, FilePreprocessingDiagnosticsKind, EmitOnly, StructureIsReused, ExitStatus, MemberOverrideStatus, UnionReduction, ContextFlags, NodeBuilderFlags, TypeFormatFlags, SymbolFormatFlags, SymbolAccessibility, SyntheticSymbolKind, TypePredicateKind, TypeReferenceSerializationKind, SymbolFlags, EnumKind, CheckFlags, InternalSymbolName, NodeCheckFlags, TypeFlags, ObjectFlags, VarianceFlags, ElementFlags, AccessFlags, IndexFlags, JsxReferenceKind, SignatureKind, SignatureFlags, IndexKind, TypeMapKind, InferencePriority, InferenceFlags, Ternary, AssignmentDeclarationKind, DiagnosticCategory, ModuleResolutionKind, ModuleDetectionKind, WatchFileKind, WatchDirectoryKind, PollingWatchKind, ModuleKind, JsxEmit, ImportsNotUsedAsValues, NewLineKind, ScriptKind, ScriptTarget, LanguageVariant, WatchDirectoryFlags, CharacterCodes, Extension, TransformFlags, SnippetKind, EmitFlags, InternalEmitFlags, ExternalEmitHelpers, EmitHint, OuterExpressionKinds, LexicalEnvironmentFlags, BundleFileSectionKind, ListFormat, PragmaKindFlags, commentPragmas;
-  var init_types = __esm({
-    "src/compiler/types.ts"() {
-      "use strict";
-      SyntaxKind = /* @__PURE__ */ ((SyntaxKind5) => {
-        SyntaxKind5[SyntaxKind5["Unknown"] = 0] = "Unknown";
-        SyntaxKind5[SyntaxKind5["EndOfFileToken"] = 1] = "EndOfFileToken";
-        SyntaxKind5[SyntaxKind5["SingleLineCommentTrivia"] = 2] = "SingleLineCommentTrivia";
-        SyntaxKind5[SyntaxKind5["MultiLineCommentTrivia"] = 3] = "MultiLineCommentTrivia";
-        SyntaxKind5[SyntaxKind5["NewLineTrivia"] = 4] = "NewLineTrivia";
-        SyntaxKind5[SyntaxKind5["WhitespaceTrivia"] = 5] = "WhitespaceTrivia";
-        SyntaxKind5[SyntaxKind5["ShebangTrivia"] = 6] = "ShebangTrivia";
-        SyntaxKind5[SyntaxKind5["ConflictMarkerTrivia"] = 7] = "ConflictMarkerTrivia";
-        SyntaxKind5[SyntaxKind5["NonTextFileMarkerTrivia"] = 8] = "NonTextFileMarkerTrivia";
-        SyntaxKind5[SyntaxKind5["NumericLiteral"] = 9] = "NumericLiteral";
-        SyntaxKind5[SyntaxKind5["BigIntLiteral"] = 10] = "BigIntLiteral";
-        SyntaxKind5[SyntaxKind5["StringLiteral"] = 11] = "StringLiteral";
-        SyntaxKind5[SyntaxKind5["JsxText"] = 12] = "JsxText";
-        SyntaxKind5[SyntaxKind5["JsxTextAllWhiteSpaces"] = 13] = "JsxTextAllWhiteSpaces";
-        SyntaxKind5[SyntaxKind5["RegularExpressionLiteral"] = 14] = "RegularExpressionLiteral";
-        SyntaxKind5[SyntaxKind5["NoSubstitutionTemplateLiteral"] = 15] = "NoSubstitutionTemplateLiteral";
-        SyntaxKind5[SyntaxKind5["TemplateHead"] = 16] = "TemplateHead";
-        SyntaxKind5[SyntaxKind5["TemplateMiddle"] = 17] = "TemplateMiddle";
-        SyntaxKind5[SyntaxKind5["TemplateTail"] = 18] = "TemplateTail";
-        SyntaxKind5[SyntaxKind5["OpenBraceToken"] = 19] = "OpenBraceToken";
-        SyntaxKind5[SyntaxKind5["CloseBraceToken"] = 20] = "CloseBraceToken";
-        SyntaxKind5[SyntaxKind5["OpenParenToken"] = 21] = "OpenParenToken";
-        SyntaxKind5[SyntaxKind5["CloseParenToken"] = 22] = "CloseParenToken";
-        SyntaxKind5[SyntaxKind5["OpenBracketToken"] = 23] = "OpenBracketToken";
-        SyntaxKind5[SyntaxKind5["CloseBracketToken"] = 24] = "CloseBracketToken";
-        SyntaxKind5[SyntaxKind5["DotToken"] = 25] = "DotToken";
-        SyntaxKind5[SyntaxKind5["DotDotDotToken"] = 26] = "DotDotDotToken";
-        SyntaxKind5[SyntaxKind5["SemicolonToken"] = 27] = "SemicolonToken";
-        SyntaxKind5[SyntaxKind5["CommaToken"] = 28] = "CommaToken";
-        SyntaxKind5[SyntaxKind5["QuestionDotToken"] = 29] = "QuestionDotToken";
-        SyntaxKind5[SyntaxKind5["LessThanToken"] = 30] = "LessThanToken";
-        SyntaxKind5[SyntaxKind5["LessThanSlashToken"] = 31] = "LessThanSlashToken";
-        SyntaxKind5[SyntaxKind5["GreaterThanToken"] = 32] = "GreaterThanToken";
-        SyntaxKind5[SyntaxKind5["LessThanEqualsToken"] = 33] = "LessThanEqualsToken";
-        SyntaxKind5[SyntaxKind5["GreaterThanEqualsToken"] = 34] = "GreaterThanEqualsToken";
-        SyntaxKind5[SyntaxKind5["EqualsEqualsToken"] = 35] = "EqualsEqualsToken";
-        SyntaxKind5[SyntaxKind5["ExclamationEqualsToken"] = 36] = "ExclamationEqualsToken";
-        SyntaxKind5[SyntaxKind5["EqualsEqualsEqualsToken"] = 37] = "EqualsEqualsEqualsToken";
-        SyntaxKind5[SyntaxKind5["ExclamationEqualsEqualsToken"] = 38] = "ExclamationEqualsEqualsToken";
-        SyntaxKind5[SyntaxKind5["EqualsGreaterThanToken"] = 39] = "EqualsGreaterThanToken";
-        SyntaxKind5[SyntaxKind5["PlusToken"] = 40] = "PlusToken";
-        SyntaxKind5[SyntaxKind5["MinusToken"] = 41] = "MinusToken";
-        SyntaxKind5[SyntaxKind5["AsteriskToken"] = 42] = "AsteriskToken";
-        SyntaxKind5[SyntaxKind5["AsteriskAsteriskToken"] = 43] = "AsteriskAsteriskToken";
-        SyntaxKind5[SyntaxKind5["SlashToken"] = 44] = "SlashToken";
-        SyntaxKind5[SyntaxKind5["PercentToken"] = 45] = "PercentToken";
-        SyntaxKind5[SyntaxKind5["PlusPlusToken"] = 46] = "PlusPlusToken";
-        SyntaxKind5[SyntaxKind5["MinusMinusToken"] = 47] = "MinusMinusToken";
-        SyntaxKind5[SyntaxKind5["LessThanLessThanToken"] = 48] = "LessThanLessThanToken";
-        SyntaxKind5[SyntaxKind5["GreaterThanGreaterThanToken"] = 49] = "GreaterThanGreaterThanToken";
-        SyntaxKind5[SyntaxKind5["GreaterThanGreaterThanGreaterThanToken"] = 50] = "GreaterThanGreaterThanGreaterThanToken";
-        SyntaxKind5[SyntaxKind5["AmpersandToken"] = 51] = "AmpersandToken";
-        SyntaxKind5[SyntaxKind5["BarToken"] = 52] = "BarToken";
-        SyntaxKind5[SyntaxKind5["CaretToken"] = 53] = "CaretToken";
-        SyntaxKind5[SyntaxKind5["ExclamationToken"] = 54] = "ExclamationToken";
-        SyntaxKind5[SyntaxKind5["TildeToken"] = 55] = "TildeToken";
-        SyntaxKind5[SyntaxKind5["AmpersandAmpersandToken"] = 56] = "AmpersandAmpersandToken";
-        SyntaxKind5[SyntaxKind5["BarBarToken"] = 57] = "BarBarToken";
-        SyntaxKind5[SyntaxKind5["QuestionToken"] = 58] = "QuestionToken";
-        SyntaxKind5[SyntaxKind5["ColonToken"] = 59] = "ColonToken";
-        SyntaxKind5[SyntaxKind5["AtToken"] = 60] = "AtToken";
-        SyntaxKind5[SyntaxKind5["QuestionQuestionToken"] = 61] = "QuestionQuestionToken";
-        SyntaxKind5[SyntaxKind5["BacktickToken"] = 62] = "BacktickToken";
-        SyntaxKind5[SyntaxKind5["HashToken"] = 63] = "HashToken";
-        SyntaxKind5[SyntaxKind5["EqualsToken"] = 64] = "EqualsToken";
-        SyntaxKind5[SyntaxKind5["PlusEqualsToken"] = 65] = "PlusEqualsToken";
-        SyntaxKind5[SyntaxKind5["MinusEqualsToken"] = 66] = "MinusEqualsToken";
-        SyntaxKind5[SyntaxKind5["AsteriskEqualsToken"] = 67] = "AsteriskEqualsToken";
-        SyntaxKind5[SyntaxKind5["AsteriskAsteriskEqualsToken"] = 68] = "AsteriskAsteriskEqualsToken";
-        SyntaxKind5[SyntaxKind5["SlashEqualsToken"] = 69] = "SlashEqualsToken";
-        SyntaxKind5[SyntaxKind5["PercentEqualsToken"] = 70] = "PercentEqualsToken";
-        SyntaxKind5[SyntaxKind5["LessThanLessThanEqualsToken"] = 71] = "LessThanLessThanEqualsToken";
-        SyntaxKind5[SyntaxKind5["GreaterThanGreaterThanEqualsToken"] = 72] = "GreaterThanGreaterThanEqualsToken";
-        SyntaxKind5[SyntaxKind5["GreaterThanGreaterThanGreaterThanEqualsToken"] = 73] = "GreaterThanGreaterThanGreaterThanEqualsToken";
-        SyntaxKind5[SyntaxKind5["AmpersandEqualsToken"] = 74] = "AmpersandEqualsToken";
-        SyntaxKind5[SyntaxKind5["BarEqualsToken"] = 75] = "BarEqualsToken";
-        SyntaxKind5[SyntaxKind5["BarBarEqualsToken"] = 76] = "BarBarEqualsToken";
-        SyntaxKind5[SyntaxKind5["AmpersandAmpersandEqualsToken"] = 77] = "AmpersandAmpersandEqualsToken";
-        SyntaxKind5[SyntaxKind5["QuestionQuestionEqualsToken"] = 78] = "QuestionQuestionEqualsToken";
-        SyntaxKind5[SyntaxKind5["CaretEqualsToken"] = 79] = "CaretEqualsToken";
-        SyntaxKind5[SyntaxKind5["Identifier"] = 80] = "Identifier";
-        SyntaxKind5[SyntaxKind5["PrivateIdentifier"] = 81] = "PrivateIdentifier";
-        SyntaxKind5[SyntaxKind5["JSDocCommentTextToken"] = 82] = "JSDocCommentTextToken";
-        SyntaxKind5[SyntaxKind5["BreakKeyword"] = 83] = "BreakKeyword";
-        SyntaxKind5[SyntaxKind5["CaseKeyword"] = 84] = "CaseKeyword";
-        SyntaxKind5[SyntaxKind5["CatchKeyword"] = 85] = "CatchKeyword";
-        SyntaxKind5[SyntaxKind5["ClassKeyword"] = 86] = "ClassKeyword";
-        SyntaxKind5[SyntaxKind5["ConstKeyword"] = 87] = "ConstKeyword";
-        SyntaxKind5[SyntaxKind5["ContinueKeyword"] = 88] = "ContinueKeyword";
-        SyntaxKind5[SyntaxKind5["DebuggerKeyword"] = 89] = "DebuggerKeyword";
-        SyntaxKind5[SyntaxKind5["DefaultKeyword"] = 90] = "DefaultKeyword";
-        SyntaxKind5[SyntaxKind5["DeleteKeyword"] = 91] = "DeleteKeyword";
-        SyntaxKind5[SyntaxKind5["DoKeyword"] = 92] = "DoKeyword";
-        SyntaxKind5[SyntaxKind5["ElseKeyword"] = 93] = "ElseKeyword";
-        SyntaxKind5[SyntaxKind5["EnumKeyword"] = 94] = "EnumKeyword";
-        SyntaxKind5[SyntaxKind5["ExportKeyword"] = 95] = "ExportKeyword";
-        SyntaxKind5[SyntaxKind5["ExtendsKeyword"] = 96] = "ExtendsKeyword";
-        SyntaxKind5[SyntaxKind5["FalseKeyword"] = 97] = "FalseKeyword";
-        SyntaxKind5[SyntaxKind5["FinallyKeyword"] = 98] = "FinallyKeyword";
-        SyntaxKind5[SyntaxKind5["ForKeyword"] = 99] = "ForKeyword";
-        SyntaxKind5[SyntaxKind5["FunctionKeyword"] = 100] = "FunctionKeyword";
-        SyntaxKind5[SyntaxKind5["IfKeyword"] = 101] = "IfKeyword";
-        SyntaxKind5[SyntaxKind5["ImportKeyword"] = 102] = "ImportKeyword";
-        SyntaxKind5[SyntaxKind5["InKeyword"] = 103] = "InKeyword";
-        SyntaxKind5[SyntaxKind5["InstanceOfKeyword"] = 104] = "InstanceOfKeyword";
-        SyntaxKind5[SyntaxKind5["NewKeyword"] = 105] = "NewKeyword";
-        SyntaxKind5[SyntaxKind5["NullKeyword"] = 106] = "NullKeyword";
-        SyntaxKind5[SyntaxKind5["ReturnKeyword"] = 107] = "ReturnKeyword";
-        SyntaxKind5[SyntaxKind5["SuperKeyword"] = 108] = "SuperKeyword";
-        SyntaxKind5[SyntaxKind5["SwitchKeyword"] = 109] = "SwitchKeyword";
-        SyntaxKind5[SyntaxKind5["ThisKeyword"] = 110] = "ThisKeyword";
-        SyntaxKind5[SyntaxKind5["ThrowKeyword"] = 111] = "ThrowKeyword";
-        SyntaxKind5[SyntaxKind5["TrueKeyword"] = 112] = "TrueKeyword";
-        SyntaxKind5[SyntaxKind5["TryKeyword"] = 113] = "TryKeyword";
-        SyntaxKind5[SyntaxKind5["TypeOfKeyword"] = 114] = "TypeOfKeyword";
-        SyntaxKind5[SyntaxKind5["VarKeyword"] = 115] = "VarKeyword";
-        SyntaxKind5[SyntaxKind5["VoidKeyword"] = 116] = "VoidKeyword";
-        SyntaxKind5[SyntaxKind5["WhileKeyword"] = 117] = "WhileKeyword";
-        SyntaxKind5[SyntaxKind5["WithKeyword"] = 118] = "WithKeyword";
-        SyntaxKind5[SyntaxKind5["ImplementsKeyword"] = 119] = "ImplementsKeyword";
-        SyntaxKind5[SyntaxKind5["InterfaceKeyword"] = 120] = "InterfaceKeyword";
-        SyntaxKind5[SyntaxKind5["LetKeyword"] = 121] = "LetKeyword";
-        SyntaxKind5[SyntaxKind5["PackageKeyword"] = 122] = "PackageKeyword";
-        SyntaxKind5[SyntaxKind5["PrivateKeyword"] = 123] = "PrivateKeyword";
-        SyntaxKind5[SyntaxKind5["ProtectedKeyword"] = 124] = "ProtectedKeyword";
-        SyntaxKind5[SyntaxKind5["PublicKeyword"] = 125] = "PublicKeyword";
-        SyntaxKind5[SyntaxKind5["StaticKeyword"] = 126] = "StaticKeyword";
-        SyntaxKind5[SyntaxKind5["YieldKeyword"] = 127] = "YieldKeyword";
-        SyntaxKind5[SyntaxKind5["AbstractKeyword"] = 128] = "AbstractKeyword";
-        SyntaxKind5[SyntaxKind5["AccessorKeyword"] = 129] = "AccessorKeyword";
-        SyntaxKind5[SyntaxKind5["AsKeyword"] = 130] = "AsKeyword";
-        SyntaxKind5[SyntaxKind5["AssertsKeyword"] = 131] = "AssertsKeyword";
-        SyntaxKind5[SyntaxKind5["AssertKeyword"] = 132] = "AssertKeyword";
-        SyntaxKind5[SyntaxKind5["AnyKeyword"] = 133] = "AnyKeyword";
-        SyntaxKind5[SyntaxKind5["AsyncKeyword"] = 134] = "AsyncKeyword";
-        SyntaxKind5[SyntaxKind5["AwaitKeyword"] = 135] = "AwaitKeyword";
-        SyntaxKind5[SyntaxKind5["BooleanKeyword"] = 136] = "BooleanKeyword";
-        SyntaxKind5[SyntaxKind5["ConstructorKeyword"] = 137] = "ConstructorKeyword";
-        SyntaxKind5[SyntaxKind5["DeclareKeyword"] = 138] = "DeclareKeyword";
-        SyntaxKind5[SyntaxKind5["GetKeyword"] = 139] = "GetKeyword";
-        SyntaxKind5[SyntaxKind5["InferKeyword"] = 140] = "InferKeyword";
-        SyntaxKind5[SyntaxKind5["IntrinsicKeyword"] = 141] = "IntrinsicKeyword";
-        SyntaxKind5[SyntaxKind5["IsKeyword"] = 142] = "IsKeyword";
-        SyntaxKind5[SyntaxKind5["KeyOfKeyword"] = 143] = "KeyOfKeyword";
-        SyntaxKind5[SyntaxKind5["ModuleKeyword"] = 144] = "ModuleKeyword";
-        SyntaxKind5[SyntaxKind5["NamespaceKeyword"] = 145] = "NamespaceKeyword";
-        SyntaxKind5[SyntaxKind5["NeverKeyword"] = 146] = "NeverKeyword";
-        SyntaxKind5[SyntaxKind5["OutKeyword"] = 147] = "OutKeyword";
-        SyntaxKind5[SyntaxKind5["ReadonlyKeyword"] = 148] = "ReadonlyKeyword";
-        SyntaxKind5[SyntaxKind5["RequireKeyword"] = 149] = "RequireKeyword";
-        SyntaxKind5[SyntaxKind5["NumberKeyword"] = 150] = "NumberKeyword";
-        SyntaxKind5[SyntaxKind5["ObjectKeyword"] = 151] = "ObjectKeyword";
-        SyntaxKind5[SyntaxKind5["SatisfiesKeyword"] = 152] = "SatisfiesKeyword";
-        SyntaxKind5[SyntaxKind5["SetKeyword"] = 153] = "SetKeyword";
-        SyntaxKind5[SyntaxKind5["StringKeyword"] = 154] = "StringKeyword";
-        SyntaxKind5[SyntaxKind5["SymbolKeyword"] = 155] = "SymbolKeyword";
-        SyntaxKind5[SyntaxKind5["TypeKeyword"] = 156] = "TypeKeyword";
-        SyntaxKind5[SyntaxKind5["UndefinedKeyword"] = 157] = "UndefinedKeyword";
-        SyntaxKind5[SyntaxKind5["UniqueKeyword"] = 158] = "UniqueKeyword";
-        SyntaxKind5[SyntaxKind5["UnknownKeyword"] = 159] = "UnknownKeyword";
-        SyntaxKind5[SyntaxKind5["FromKeyword"] = 160] = "FromKeyword";
-        SyntaxKind5[SyntaxKind5["GlobalKeyword"] = 161] = "GlobalKeyword";
-        SyntaxKind5[SyntaxKind5["BigIntKeyword"] = 162] = "BigIntKeyword";
-        SyntaxKind5[SyntaxKind5["OverrideKeyword"] = 163] = "OverrideKeyword";
-        SyntaxKind5[SyntaxKind5["OfKeyword"] = 164] = "OfKeyword";
-        SyntaxKind5[SyntaxKind5["QualifiedName"] = 165] = "QualifiedName";
-        SyntaxKind5[SyntaxKind5["ComputedPropertyName"] = 166] = "ComputedPropertyName";
-        SyntaxKind5[SyntaxKind5["TypeParameter"] = 167] = "TypeParameter";
-        SyntaxKind5[SyntaxKind5["Parameter"] = 168] = "Parameter";
-        SyntaxKind5[SyntaxKind5["Decorator"] = 169] = "Decorator";
-        SyntaxKind5[SyntaxKind5["PropertySignature"] = 170] = "PropertySignature";
-        SyntaxKind5[SyntaxKind5["PropertyDeclaration"] = 171] = "PropertyDeclaration";
-        SyntaxKind5[SyntaxKind5["MethodSignature"] = 172] = "MethodSignature";
-        SyntaxKind5[SyntaxKind5["MethodDeclaration"] = 173] = "MethodDeclaration";
-        SyntaxKind5[SyntaxKind5["ClassStaticBlockDeclaration"] = 174] = "ClassStaticBlockDeclaration";
-        SyntaxKind5[SyntaxKind5["Constructor"] = 175] = "Constructor";
-        SyntaxKind5[SyntaxKind5["GetAccessor"] = 176] = "GetAccessor";
-        SyntaxKind5[SyntaxKind5["SetAccessor"] = 177] = "SetAccessor";
-        SyntaxKind5[SyntaxKind5["CallSignature"] = 178] = "CallSignature";
-        SyntaxKind5[SyntaxKind5["ConstructSignature"] = 179] = "ConstructSignature";
-        SyntaxKind5[SyntaxKind5["IndexSignature"] = 180] = "IndexSignature";
-        SyntaxKind5[SyntaxKind5["TypePredicate"] = 181] = "TypePredicate";
-        SyntaxKind5[SyntaxKind5["TypeReference"] = 182] = "TypeReference";
-        SyntaxKind5[SyntaxKind5["FunctionType"] = 183] = "FunctionType";
-        SyntaxKind5[SyntaxKind5["ConstructorType"] = 184] = "ConstructorType";
-        SyntaxKind5[SyntaxKind5["TypeQuery"] = 185] = "TypeQuery";
-        SyntaxKind5[SyntaxKind5["TypeLiteral"] = 186] = "TypeLiteral";
-        SyntaxKind5[SyntaxKind5["ArrayType"] = 187] = "ArrayType";
-        SyntaxKind5[SyntaxKind5["TupleType"] = 188] = "TupleType";
-        SyntaxKind5[SyntaxKind5["OptionalType"] = 189] = "OptionalType";
-        SyntaxKind5[SyntaxKind5["RestType"] = 190] = "RestType";
-        SyntaxKind5[SyntaxKind5["UnionType"] = 191] = "UnionType";
-        SyntaxKind5[SyntaxKind5["IntersectionType"] = 192] = "IntersectionType";
-        SyntaxKind5[SyntaxKind5["ConditionalType"] = 193] = "ConditionalType";
-        SyntaxKind5[SyntaxKind5["InferType"] = 194] = "InferType";
-        SyntaxKind5[SyntaxKind5["ParenthesizedType"] = 195] = "ParenthesizedType";
-        SyntaxKind5[SyntaxKind5["ThisType"] = 196] = "ThisType";
-        SyntaxKind5[SyntaxKind5["TypeOperator"] = 197] = "TypeOperator";
-        SyntaxKind5[SyntaxKind5["IndexedAccessType"] = 198] = "IndexedAccessType";
-        SyntaxKind5[SyntaxKind5["MappedType"] = 199] = "MappedType";
-        SyntaxKind5[SyntaxKind5["LiteralType"] = 200] = "LiteralType";
-        SyntaxKind5[SyntaxKind5["NamedTupleMember"] = 201] = "NamedTupleMember";
-        SyntaxKind5[SyntaxKind5["TemplateLiteralType"] = 202] = "TemplateLiteralType";
-        SyntaxKind5[SyntaxKind5["TemplateLiteralTypeSpan"] = 203] = "TemplateLiteralTypeSpan";
-        SyntaxKind5[SyntaxKind5["ImportType"] = 204] = "ImportType";
-        SyntaxKind5[SyntaxKind5["ObjectBindingPattern"] = 205] = "ObjectBindingPattern";
-        SyntaxKind5[SyntaxKind5["ArrayBindingPattern"] = 206] = "ArrayBindingPattern";
-        SyntaxKind5[SyntaxKind5["BindingElement"] = 207] = "BindingElement";
-        SyntaxKind5[SyntaxKind5["ArrayLiteralExpression"] = 208] = "ArrayLiteralExpression";
-        SyntaxKind5[SyntaxKind5["ObjectLiteralExpression"] = 209] = "ObjectLiteralExpression";
-        SyntaxKind5[SyntaxKind5["PropertyAccessExpression"] = 210] = "PropertyAccessExpression";
-        SyntaxKind5[SyntaxKind5["ElementAccessExpression"] = 211] = "ElementAccessExpression";
-        SyntaxKind5[SyntaxKind5["CallExpression"] = 212] = "CallExpression";
-        SyntaxKind5[SyntaxKind5["NewExpression"] = 213] = "NewExpression";
-        SyntaxKind5[SyntaxKind5["TaggedTemplateExpression"] = 214] = "TaggedTemplateExpression";
-        SyntaxKind5[SyntaxKind5["TypeAssertionExpression"] = 215] = "TypeAssertionExpression";
-        SyntaxKind5[SyntaxKind5["ParenthesizedExpression"] = 216] = "ParenthesizedExpression";
-        SyntaxKind5[SyntaxKind5["FunctionExpression"] = 217] = "FunctionExpression";
-        SyntaxKind5[SyntaxKind5["ArrowFunction"] = 218] = "ArrowFunction";
-        SyntaxKind5[SyntaxKind5["DeleteExpression"] = 219] = "DeleteExpression";
-        SyntaxKind5[SyntaxKind5["TypeOfExpression"] = 220] = "TypeOfExpression";
-        SyntaxKind5[SyntaxKind5["VoidExpression"] = 221] = "VoidExpression";
-        SyntaxKind5[SyntaxKind5["AwaitExpression"] = 222] = "AwaitExpression";
-        SyntaxKind5[SyntaxKind5["PrefixUnaryExpression"] = 223] = "PrefixUnaryExpression";
-        SyntaxKind5[SyntaxKind5["PostfixUnaryExpression"] = 224] = "PostfixUnaryExpression";
-        SyntaxKind5[SyntaxKind5["BinaryExpression"] = 225] = "BinaryExpression";
-        SyntaxKind5[SyntaxKind5["ConditionalExpression"] = 226] = "ConditionalExpression";
-        SyntaxKind5[SyntaxKind5["TemplateExpression"] = 227] = "TemplateExpression";
-        SyntaxKind5[SyntaxKind5["YieldExpression"] = 228] = "YieldExpression";
-        SyntaxKind5[SyntaxKind5["SpreadElement"] = 229] = "SpreadElement";
-        SyntaxKind5[SyntaxKind5["ClassExpression"] = 230] = "ClassExpression";
-        SyntaxKind5[SyntaxKind5["OmittedExpression"] = 231] = "OmittedExpression";
-        SyntaxKind5[SyntaxKind5["ExpressionWithTypeArguments"] = 232] = "ExpressionWithTypeArguments";
-        SyntaxKind5[SyntaxKind5["AsExpression"] = 233] = "AsExpression";
-        SyntaxKind5[SyntaxKind5["NonNullExpression"] = 234] = "NonNullExpression";
-        SyntaxKind5[SyntaxKind5["MetaProperty"] = 235] = "MetaProperty";
-        SyntaxKind5[SyntaxKind5["SyntheticExpression"] = 236] = "SyntheticExpression";
-        SyntaxKind5[SyntaxKind5["SatisfiesExpression"] = 237] = "SatisfiesExpression";
-        SyntaxKind5[SyntaxKind5["TemplateSpan"] = 238] = "TemplateSpan";
-        SyntaxKind5[SyntaxKind5["SemicolonClassElement"] = 239] = "SemicolonClassElement";
-        SyntaxKind5[SyntaxKind5["Block"] = 240] = "Block";
-        SyntaxKind5[SyntaxKind5["EmptyStatement"] = 241] = "EmptyStatement";
-        SyntaxKind5[SyntaxKind5["VariableStatement"] = 242] = "VariableStatement";
-        SyntaxKind5[SyntaxKind5["ExpressionStatement"] = 243] = "ExpressionStatement";
-        SyntaxKind5[SyntaxKind5["IfStatement"] = 244] = "IfStatement";
-        SyntaxKind5[SyntaxKind5["DoStatement"] = 245] = "DoStatement";
-        SyntaxKind5[SyntaxKind5["WhileStatement"] = 246] = "WhileStatement";
-        SyntaxKind5[SyntaxKind5["ForStatement"] = 247] = "ForStatement";
-        SyntaxKind5[SyntaxKind5["ForInStatement"] = 248] = "ForInStatement";
-        SyntaxKind5[SyntaxKind5["ForOfStatement"] = 249] = "ForOfStatement";
-        SyntaxKind5[SyntaxKind5["ContinueStatement"] = 250] = "ContinueStatement";
-        SyntaxKind5[SyntaxKind5["BreakStatement"] = 251] = "BreakStatement";
-        SyntaxKind5[SyntaxKind5["ReturnStatement"] = 252] = "ReturnStatement";
-        SyntaxKind5[SyntaxKind5["WithStatement"] = 253] = "WithStatement";
-        SyntaxKind5[SyntaxKind5["SwitchStatement"] = 254] = "SwitchStatement";
-        SyntaxKind5[SyntaxKind5["LabeledStatement"] = 255] = "LabeledStatement";
-        SyntaxKind5[SyntaxKind5["ThrowStatement"] = 256] = "ThrowStatement";
-        SyntaxKind5[SyntaxKind5["TryStatement"] = 257] = "TryStatement";
-        SyntaxKind5[SyntaxKind5["DebuggerStatement"] = 258] = "DebuggerStatement";
-        SyntaxKind5[SyntaxKind5["VariableDeclaration"] = 259] = "VariableDeclaration";
-        SyntaxKind5[SyntaxKind5["VariableDeclarationList"] = 260] = "VariableDeclarationList";
-        SyntaxKind5[SyntaxKind5["FunctionDeclaration"] = 261] = "FunctionDeclaration";
-        SyntaxKind5[SyntaxKind5["ClassDeclaration"] = 262] = "ClassDeclaration";
-        SyntaxKind5[SyntaxKind5["InterfaceDeclaration"] = 263] = "InterfaceDeclaration";
-        SyntaxKind5[SyntaxKind5["TypeAliasDeclaration"] = 264] = "TypeAliasDeclaration";
-        SyntaxKind5[SyntaxKind5["EnumDeclaration"] = 265] = "EnumDeclaration";
-        SyntaxKind5[SyntaxKind5["ModuleDeclaration"] = 266] = "ModuleDeclaration";
-        SyntaxKind5[SyntaxKind5["ModuleBlock"] = 267] = "ModuleBlock";
-        SyntaxKind5[SyntaxKind5["CaseBlock"] = 268] = "CaseBlock";
-        SyntaxKind5[SyntaxKind5["NamespaceExportDeclaration"] = 269] = "NamespaceExportDeclaration";
-        SyntaxKind5[SyntaxKind5["ImportEqualsDeclaration"] = 270] = "ImportEqualsDeclaration";
-        SyntaxKind5[SyntaxKind5["ImportDeclaration"] = 271] = "ImportDeclaration";
-        SyntaxKind5[SyntaxKind5["ImportClause"] = 272] = "ImportClause";
-        SyntaxKind5[SyntaxKind5["NamespaceImport"] = 273] = "NamespaceImport";
-        SyntaxKind5[SyntaxKind5["NamedImports"] = 274] = "NamedImports";
-        SyntaxKind5[SyntaxKind5["ImportSpecifier"] = 275] = "ImportSpecifier";
-        SyntaxKind5[SyntaxKind5["ExportAssignment"] = 276] = "ExportAssignment";
-        SyntaxKind5[SyntaxKind5["ExportDeclaration"] = 277] = "ExportDeclaration";
-        SyntaxKind5[SyntaxKind5["NamedExports"] = 278] = "NamedExports";
-        SyntaxKind5[SyntaxKind5["NamespaceExport"] = 279] = "NamespaceExport";
-        SyntaxKind5[SyntaxKind5["ExportSpecifier"] = 280] = "ExportSpecifier";
-        SyntaxKind5[SyntaxKind5["MissingDeclaration"] = 281] = "MissingDeclaration";
-        SyntaxKind5[SyntaxKind5["ExternalModuleReference"] = 282] = "ExternalModuleReference";
-        SyntaxKind5[SyntaxKind5["JsxElement"] = 283] = "JsxElement";
-        SyntaxKind5[SyntaxKind5["JsxSelfClosingElement"] = 284] = "JsxSelfClosingElement";
-        SyntaxKind5[SyntaxKind5["JsxOpeningElement"] = 285] = "JsxOpeningElement";
-        SyntaxKind5[SyntaxKind5["JsxClosingElement"] = 286] = "JsxClosingElement";
-        SyntaxKind5[SyntaxKind5["JsxFragment"] = 287] = "JsxFragment";
-        SyntaxKind5[SyntaxKind5["JsxOpeningFragment"] = 288] = "JsxOpeningFragment";
-        SyntaxKind5[SyntaxKind5["JsxClosingFragment"] = 289] = "JsxClosingFragment";
-        SyntaxKind5[SyntaxKind5["JsxAttribute"] = 290] = "JsxAttribute";
-        SyntaxKind5[SyntaxKind5["JsxAttributes"] = 291] = "JsxAttributes";
-        SyntaxKind5[SyntaxKind5["JsxSpreadAttribute"] = 292] = "JsxSpreadAttribute";
-        SyntaxKind5[SyntaxKind5["JsxExpression"] = 293] = "JsxExpression";
-        SyntaxKind5[SyntaxKind5["JsxNamespacedName"] = 294] = "JsxNamespacedName";
-        SyntaxKind5[SyntaxKind5["CaseClause"] = 295] = "CaseClause";
-        SyntaxKind5[SyntaxKind5["DefaultClause"] = 296] = "DefaultClause";
-        SyntaxKind5[SyntaxKind5["HeritageClause"] = 297] = "HeritageClause";
-        SyntaxKind5[SyntaxKind5["CatchClause"] = 298] = "CatchClause";
-        SyntaxKind5[SyntaxKind5["AssertClause"] = 299] = "AssertClause";
-        SyntaxKind5[SyntaxKind5["AssertEntry"] = 300] = "AssertEntry";
-        SyntaxKind5[SyntaxKind5["ImportTypeAssertionContainer"] = 301] = "ImportTypeAssertionContainer";
-        SyntaxKind5[SyntaxKind5["PropertyAssignment"] = 302] = "PropertyAssignment";
-        SyntaxKind5[SyntaxKind5["ShorthandPropertyAssignment"] = 303] = "ShorthandPropertyAssignment";
-        SyntaxKind5[SyntaxKind5["SpreadAssignment"] = 304] = "SpreadAssignment";
-        SyntaxKind5[SyntaxKind5["EnumMember"] = 305] = "EnumMember";
-        SyntaxKind5[SyntaxKind5["UnparsedPrologue"] = 306] = "UnparsedPrologue";
-        SyntaxKind5[SyntaxKind5["UnparsedPrepend"] = 307] = "UnparsedPrepend";
-        SyntaxKind5[SyntaxKind5["UnparsedText"] = 308] = "UnparsedText";
-        SyntaxKind5[SyntaxKind5["UnparsedInternalText"] = 309] = "UnparsedInternalText";
-        SyntaxKind5[SyntaxKind5["UnparsedSyntheticReference"] = 310] = "UnparsedSyntheticReference";
-        SyntaxKind5[SyntaxKind5["SourceFile"] = 311] = "SourceFile";
-        SyntaxKind5[SyntaxKind5["Bundle"] = 312] = "Bundle";
-        SyntaxKind5[SyntaxKind5["UnparsedSource"] = 313] = "UnparsedSource";
-        SyntaxKind5[SyntaxKind5["InputFiles"] = 314] = "InputFiles";
-        SyntaxKind5[SyntaxKind5["JSDocTypeExpression"] = 315] = "JSDocTypeExpression";
-        SyntaxKind5[SyntaxKind5["JSDocNameReference"] = 316] = "JSDocNameReference";
-        SyntaxKind5[SyntaxKind5["JSDocMemberName"] = 317] = "JSDocMemberName";
-        SyntaxKind5[SyntaxKind5["JSDocAllType"] = 318] = "JSDocAllType";
-        SyntaxKind5[SyntaxKind5["JSDocUnknownType"] = 319] = "JSDocUnknownType";
-        SyntaxKind5[SyntaxKind5["JSDocNullableType"] = 320] = "JSDocNullableType";
-        SyntaxKind5[SyntaxKind5["JSDocNonNullableType"] = 321] = "JSDocNonNullableType";
-        SyntaxKind5[SyntaxKind5["JSDocOptionalType"] = 322] = "JSDocOptionalType";
-        SyntaxKind5[SyntaxKind5["JSDocFunctionType"] = 323] = "JSDocFunctionType";
-        SyntaxKind5[SyntaxKind5["JSDocVariadicType"] = 324] = "JSDocVariadicType";
-        SyntaxKind5[SyntaxKind5["JSDocNamepathType"] = 325] = "JSDocNamepathType";
-        SyntaxKind5[SyntaxKind5["JSDoc"] = 326] = "JSDoc";
-        SyntaxKind5[SyntaxKind5["JSDocComment"] = 326 /* JSDoc */] = "JSDocComment";
-        SyntaxKind5[SyntaxKind5["JSDocText"] = 327] = "JSDocText";
-        SyntaxKind5[SyntaxKind5["JSDocTypeLiteral"] = 328] = "JSDocTypeLiteral";
-        SyntaxKind5[SyntaxKind5["JSDocSignature"] = 329] = "JSDocSignature";
-        SyntaxKind5[SyntaxKind5["JSDocLink"] = 330] = "JSDocLink";
-        SyntaxKind5[SyntaxKind5["JSDocLinkCode"] = 331] = "JSDocLinkCode";
-        SyntaxKind5[SyntaxKind5["JSDocLinkPlain"] = 332] = "JSDocLinkPlain";
-        SyntaxKind5[SyntaxKind5["JSDocTag"] = 333] = "JSDocTag";
-        SyntaxKind5[SyntaxKind5["JSDocAugmentsTag"] = 334] = "JSDocAugmentsTag";
-        SyntaxKind5[SyntaxKind5["JSDocImplementsTag"] = 335] = "JSDocImplementsTag";
-        SyntaxKind5[SyntaxKind5["JSDocAuthorTag"] = 336] = "JSDocAuthorTag";
-        SyntaxKind5[SyntaxKind5["JSDocDeprecatedTag"] = 337] = "JSDocDeprecatedTag";
-        SyntaxKind5[SyntaxKind5["JSDocClassTag"] = 338] = "JSDocClassTag";
-        SyntaxKind5[SyntaxKind5["JSDocPublicTag"] = 339] = "JSDocPublicTag";
-        SyntaxKind5[SyntaxKind5["JSDocPrivateTag"] = 340] = "JSDocPrivateTag";
-        SyntaxKind5[SyntaxKind5["JSDocProtectedTag"] = 341] = "JSDocProtectedTag";
-        SyntaxKind5[SyntaxKind5["JSDocReadonlyTag"] = 342] = "JSDocReadonlyTag";
-        SyntaxKind5[SyntaxKind5["JSDocOverrideTag"] = 343] = "JSDocOverrideTag";
-        SyntaxKind5[SyntaxKind5["JSDocCallbackTag"] = 344] = "JSDocCallbackTag";
-        SyntaxKind5[SyntaxKind5["JSDocOverloadTag"] = 345] = "JSDocOverloadTag";
-        SyntaxKind5[SyntaxKind5["JSDocEnumTag"] = 346] = "JSDocEnumTag";
-        SyntaxKind5[SyntaxKind5["JSDocParameterTag"] = 347] = "JSDocParameterTag";
-        SyntaxKind5[SyntaxKind5["JSDocReturnTag"] = 348] = "JSDocReturnTag";
-        SyntaxKind5[SyntaxKind5["JSDocThisTag"] = 349] = "JSDocThisTag";
-        SyntaxKind5[SyntaxKind5["JSDocTypeTag"] = 350] = "JSDocTypeTag";
-        SyntaxKind5[SyntaxKind5["JSDocTemplateTag"] = 351] = "JSDocTemplateTag";
-        SyntaxKind5[SyntaxKind5["JSDocTypedefTag"] = 352] = "JSDocTypedefTag";
-        SyntaxKind5[SyntaxKind5["JSDocSeeTag"] = 353] = "JSDocSeeTag";
-        SyntaxKind5[SyntaxKind5["JSDocPropertyTag"] = 354] = "JSDocPropertyTag";
-        SyntaxKind5[SyntaxKind5["JSDocThrowsTag"] = 355] = "JSDocThrowsTag";
-        SyntaxKind5[SyntaxKind5["JSDocSatisfiesTag"] = 356] = "JSDocSatisfiesTag";
-        SyntaxKind5[SyntaxKind5["SyntaxList"] = 357] = "SyntaxList";
-        SyntaxKind5[SyntaxKind5["NotEmittedStatement"] = 358] = "NotEmittedStatement";
-        SyntaxKind5[SyntaxKind5["PartiallyEmittedExpression"] = 359] = "PartiallyEmittedExpression";
-        SyntaxKind5[SyntaxKind5["CommaListExpression"] = 360] = "CommaListExpression";
-        SyntaxKind5[SyntaxKind5["SyntheticReferenceExpression"] = 361] = "SyntheticReferenceExpression";
-        SyntaxKind5[SyntaxKind5["Count"] = 362] = "Count";
-        SyntaxKind5[SyntaxKind5["FirstAssignment"] = 64 /* EqualsToken */] = "FirstAssignment";
-        SyntaxKind5[SyntaxKind5["LastAssignment"] = 79 /* CaretEqualsToken */] = "LastAssignment";
-        SyntaxKind5[SyntaxKind5["FirstCompoundAssignment"] = 65 /* PlusEqualsToken */] = "FirstCompoundAssignment";
-        SyntaxKind5[SyntaxKind5["LastCompoundAssignment"] = 79 /* CaretEqualsToken */] = "LastCompoundAssignment";
-        SyntaxKind5[SyntaxKind5["FirstReservedWord"] = 83 /* BreakKeyword */] = "FirstReservedWord";
-        SyntaxKind5[SyntaxKind5["LastReservedWord"] = 118 /* WithKeyword */] = "LastReservedWord";
-        SyntaxKind5[SyntaxKind5["FirstKeyword"] = 83 /* BreakKeyword */] = "FirstKeyword";
-        SyntaxKind5[SyntaxKind5["LastKeyword"] = 164 /* OfKeyword */] = "LastKeyword";
-        SyntaxKind5[SyntaxKind5["FirstFutureReservedWord"] = 119 /* ImplementsKeyword */] = "FirstFutureReservedWord";
-        SyntaxKind5[SyntaxKind5["LastFutureReservedWord"] = 127 /* YieldKeyword */] = "LastFutureReservedWord";
-        SyntaxKind5[SyntaxKind5["FirstTypeNode"] = 181 /* TypePredicate */] = "FirstTypeNode";
-        SyntaxKind5[SyntaxKind5["LastTypeNode"] = 204 /* ImportType */] = "LastTypeNode";
-        SyntaxKind5[SyntaxKind5["FirstPunctuation"] = 19 /* OpenBraceToken */] = "FirstPunctuation";
-        SyntaxKind5[SyntaxKind5["LastPunctuation"] = 79 /* CaretEqualsToken */] = "LastPunctuation";
-        SyntaxKind5[SyntaxKind5["FirstToken"] = 0 /* Unknown */] = "FirstToken";
-        SyntaxKind5[SyntaxKind5["LastToken"] = 164 /* LastKeyword */] = "LastToken";
-        SyntaxKind5[SyntaxKind5["FirstTriviaToken"] = 2 /* SingleLineCommentTrivia */] = "FirstTriviaToken";
-        SyntaxKind5[SyntaxKind5["LastTriviaToken"] = 7 /* ConflictMarkerTrivia */] = "LastTriviaToken";
-        SyntaxKind5[SyntaxKind5["FirstLiteralToken"] = 9 /* NumericLiteral */] = "FirstLiteralToken";
-        SyntaxKind5[SyntaxKind5["LastLiteralToken"] = 15 /* NoSubstitutionTemplateLiteral */] = "LastLiteralToken";
-        SyntaxKind5[SyntaxKind5["FirstTemplateToken"] = 15 /* NoSubstitutionTemplateLiteral */] = "FirstTemplateToken";
-        SyntaxKind5[SyntaxKind5["LastTemplateToken"] = 18 /* TemplateTail */] = "LastTemplateToken";
-        SyntaxKind5[SyntaxKind5["FirstBinaryOperator"] = 30 /* LessThanToken */] = "FirstBinaryOperator";
-        SyntaxKind5[SyntaxKind5["LastBinaryOperator"] = 79 /* CaretEqualsToken */] = "LastBinaryOperator";
-        SyntaxKind5[SyntaxKind5["FirstStatement"] = 242 /* VariableStatement */] = "FirstStatement";
-        SyntaxKind5[SyntaxKind5["LastStatement"] = 258 /* DebuggerStatement */] = "LastStatement";
-        SyntaxKind5[SyntaxKind5["FirstNode"] = 165 /* QualifiedName */] = "FirstNode";
-        SyntaxKind5[SyntaxKind5["FirstJSDocNode"] = 315 /* JSDocTypeExpression */] = "FirstJSDocNode";
-        SyntaxKind5[SyntaxKind5["LastJSDocNode"] = 356 /* JSDocSatisfiesTag */] = "LastJSDocNode";
-        SyntaxKind5[SyntaxKind5["FirstJSDocTagNode"] = 333 /* JSDocTag */] = "FirstJSDocTagNode";
-        SyntaxKind5[SyntaxKind5["LastJSDocTagNode"] = 356 /* JSDocSatisfiesTag */] = "LastJSDocTagNode";
-        SyntaxKind5[SyntaxKind5["FirstContextualKeyword"] = 128 /* AbstractKeyword */] = "FirstContextualKeyword";
-        SyntaxKind5[SyntaxKind5["LastContextualKeyword"] = 164 /* OfKeyword */] = "LastContextualKeyword";
-        return SyntaxKind5;
-      })(SyntaxKind || {});
-      NodeFlags = /* @__PURE__ */ ((NodeFlags3) => {
-        NodeFlags3[NodeFlags3["None"] = 0] = "None";
-        NodeFlags3[NodeFlags3["Let"] = 1] = "Let";
-        NodeFlags3[NodeFlags3["Const"] = 2] = "Const";
-        NodeFlags3[NodeFlags3["NestedNamespace"] = 4] = "NestedNamespace";
-        NodeFlags3[NodeFlags3["Synthesized"] = 8] = "Synthesized";
-        NodeFlags3[NodeFlags3["Namespace"] = 16] = "Namespace";
-        NodeFlags3[NodeFlags3["OptionalChain"] = 32] = "OptionalChain";
-        NodeFlags3[NodeFlags3["ExportContext"] = 64] = "ExportContext";
-        NodeFlags3[NodeFlags3["ContainsThis"] = 128] = "ContainsThis";
-        NodeFlags3[NodeFlags3["HasImplicitReturn"] = 256] = "HasImplicitReturn";
-        NodeFlags3[NodeFlags3["HasExplicitReturn"] = 512] = "HasExplicitReturn";
-        NodeFlags3[NodeFlags3["GlobalAugmentation"] = 1024] = "GlobalAugmentation";
-        NodeFlags3[NodeFlags3["HasAsyncFunctions"] = 2048] = "HasAsyncFunctions";
-        NodeFlags3[NodeFlags3["DisallowInContext"] = 4096] = "DisallowInContext";
-        NodeFlags3[NodeFlags3["YieldContext"] = 8192] = "YieldContext";
-        NodeFlags3[NodeFlags3["DecoratorContext"] = 16384] = "DecoratorContext";
-        NodeFlags3[NodeFlags3["AwaitContext"] = 32768] = "AwaitContext";
-        NodeFlags3[NodeFlags3["DisallowConditionalTypesContext"] = 65536] = "DisallowConditionalTypesContext";
-        NodeFlags3[NodeFlags3["ThisNodeHasError"] = 131072] = "ThisNodeHasError";
-        NodeFlags3[NodeFlags3["JavaScriptFile"] = 262144] = "JavaScriptFile";
-        NodeFlags3[NodeFlags3["ThisNodeOrAnySubNodesHasError"] = 524288] = "ThisNodeOrAnySubNodesHasError";
-        NodeFlags3[NodeFlags3["HasAggregatedChildData"] = 1048576] = "HasAggregatedChildData";
-        NodeFlags3[NodeFlags3["PossiblyContainsDynamicImport"] = 2097152] = "PossiblyContainsDynamicImport";
-        NodeFlags3[NodeFlags3["PossiblyContainsImportMeta"] = 4194304] = "PossiblyContainsImportMeta";
-        NodeFlags3[NodeFlags3["JSDoc"] = 8388608] = "JSDoc";
-        NodeFlags3[NodeFlags3["Ambient"] = 16777216] = "Ambient";
-        NodeFlags3[NodeFlags3["InWithStatement"] = 33554432] = "InWithStatement";
-        NodeFlags3[NodeFlags3["JsonFile"] = 67108864] = "JsonFile";
-        NodeFlags3[NodeFlags3["TypeCached"] = 134217728] = "TypeCached";
-        NodeFlags3[NodeFlags3["Deprecated"] = 268435456] = "Deprecated";
-        NodeFlags3[NodeFlags3["BlockScoped"] = 3] = "BlockScoped";
-        NodeFlags3[NodeFlags3["ReachabilityCheckFlags"] = 768] = "ReachabilityCheckFlags";
-        NodeFlags3[NodeFlags3["ReachabilityAndEmitFlags"] = 2816] = "ReachabilityAndEmitFlags";
-        NodeFlags3[NodeFlags3["ContextFlags"] = 50720768] = "ContextFlags";
-        NodeFlags3[NodeFlags3["TypeExcludesFlags"] = 40960] = "TypeExcludesFlags";
-        NodeFlags3[NodeFlags3["PermanentlySetIncrementalFlags"] = 6291456] = "PermanentlySetIncrementalFlags";
-        NodeFlags3[NodeFlags3["IdentifierHasExtendedUnicodeEscape"] = 128 /* ContainsThis */] = "IdentifierHasExtendedUnicodeEscape";
-        NodeFlags3[NodeFlags3["IdentifierIsInJSDocNamespace"] = 2048 /* HasAsyncFunctions */] = "IdentifierIsInJSDocNamespace";
-        return NodeFlags3;
-      })(NodeFlags || {});
-      ModifierFlags = /* @__PURE__ */ ((ModifierFlags3) => {
-        ModifierFlags3[ModifierFlags3["None"] = 0] = "None";
-        ModifierFlags3[ModifierFlags3["Export"] = 1] = "Export";
-        ModifierFlags3[ModifierFlags3["Ambient"] = 2] = "Ambient";
-        ModifierFlags3[ModifierFlags3["Public"] = 4] = "Public";
-        ModifierFlags3[ModifierFlags3["Private"] = 8] = "Private";
-        ModifierFlags3[ModifierFlags3["Protected"] = 16] = "Protected";
-        ModifierFlags3[ModifierFlags3["Static"] = 32] = "Static";
-        ModifierFlags3[ModifierFlags3["Readonly"] = 64] = "Readonly";
-        ModifierFlags3[ModifierFlags3["Accessor"] = 128] = "Accessor";
-        ModifierFlags3[ModifierFlags3["Abstract"] = 256] = "Abstract";
-        ModifierFlags3[ModifierFlags3["Async"] = 512] = "Async";
-        ModifierFlags3[ModifierFlags3["Default"] = 1024] = "Default";
-        ModifierFlags3[ModifierFlags3["Const"] = 2048] = "Const";
-        ModifierFlags3[ModifierFlags3["HasComputedJSDocModifiers"] = 4096] = "HasComputedJSDocModifiers";
-        ModifierFlags3[ModifierFlags3["Deprecated"] = 8192] = "Deprecated";
-        ModifierFlags3[ModifierFlags3["Override"] = 16384] = "Override";
-        ModifierFlags3[ModifierFlags3["In"] = 32768] = "In";
-        ModifierFlags3[ModifierFlags3["Out"] = 65536] = "Out";
-        ModifierFlags3[ModifierFlags3["Decorator"] = 131072] = "Decorator";
-        ModifierFlags3[ModifierFlags3["HasComputedFlags"] = 536870912] = "HasComputedFlags";
-        ModifierFlags3[ModifierFlags3["AccessibilityModifier"] = 28] = "AccessibilityModifier";
-        ModifierFlags3[ModifierFlags3["ParameterPropertyModifier"] = 16476] = "ParameterPropertyModifier";
-        ModifierFlags3[ModifierFlags3["NonPublicAccessibilityModifier"] = 24] = "NonPublicAccessibilityModifier";
-        ModifierFlags3[ModifierFlags3["TypeScriptModifier"] = 117086] = "TypeScriptModifier";
-        ModifierFlags3[ModifierFlags3["ExportDefault"] = 1025] = "ExportDefault";
-        ModifierFlags3[ModifierFlags3["All"] = 258047] = "All";
-        ModifierFlags3[ModifierFlags3["Modifier"] = 126975] = "Modifier";
-        return ModifierFlags3;
-      })(ModifierFlags || {});
-      JsxFlags = /* @__PURE__ */ ((JsxFlags2) => {
-        JsxFlags2[JsxFlags2["None"] = 0] = "None";
-        JsxFlags2[JsxFlags2["IntrinsicNamedElement"] = 1] = "IntrinsicNamedElement";
-        JsxFlags2[JsxFlags2["IntrinsicIndexedElement"] = 2] = "IntrinsicIndexedElement";
-        JsxFlags2[JsxFlags2["IntrinsicElement"] = 3] = "IntrinsicElement";
-        return JsxFlags2;
-      })(JsxFlags || {});
-      RelationComparisonResult = /* @__PURE__ */ ((RelationComparisonResult3) => {
-        RelationComparisonResult3[RelationComparisonResult3["Succeeded"] = 1] = "Succeeded";
-        RelationComparisonResult3[RelationComparisonResult3["Failed"] = 2] = "Failed";
-        RelationComparisonResult3[RelationComparisonResult3["Reported"] = 4] = "Reported";
-        RelationComparisonResult3[RelationComparisonResult3["ReportsUnmeasurable"] = 8] = "ReportsUnmeasurable";
-        RelationComparisonResult3[RelationComparisonResult3["ReportsUnreliable"] = 16] = "ReportsUnreliable";
-        RelationComparisonResult3[RelationComparisonResult3["ReportsMask"] = 24] = "ReportsMask";
-        return RelationComparisonResult3;
-      })(RelationComparisonResult || {});
-      GeneratedIdentifierFlags = /* @__PURE__ */ ((GeneratedIdentifierFlags2) => {
-        GeneratedIdentifierFlags2[GeneratedIdentifierFlags2["None"] = 0] = "None";
-        GeneratedIdentifierFlags2[GeneratedIdentifierFlags2["Auto"] = 1] = "Auto";
-        GeneratedIdentifierFlags2[GeneratedIdentifierFlags2["Loop"] = 2] = "Loop";
-        GeneratedIdentifierFlags2[GeneratedIdentifierFlags2["Unique"] = 3] = "Unique";
-        GeneratedIdentifierFlags2[GeneratedIdentifierFlags2["Node"] = 4] = "Node";
-        GeneratedIdentifierFlags2[GeneratedIdentifierFlags2["KindMask"] = 7] = "KindMask";
-        GeneratedIdentifierFlags2[GeneratedIdentifierFlags2["ReservedInNestedScopes"] = 8] = "ReservedInNestedScopes";
-        GeneratedIdentifierFlags2[GeneratedIdentifierFlags2["Optimistic"] = 16] = "Optimistic";
-        GeneratedIdentifierFlags2[GeneratedIdentifierFlags2["FileLevel"] = 32] = "FileLevel";
-        GeneratedIdentifierFlags2[GeneratedIdentifierFlags2["AllowNameSubstitution"] = 64] = "AllowNameSubstitution";
-        return GeneratedIdentifierFlags2;
-      })(GeneratedIdentifierFlags || {});
-      TokenFlags = /* @__PURE__ */ ((TokenFlags2) => {
-        TokenFlags2[TokenFlags2["None"] = 0] = "None";
-        TokenFlags2[TokenFlags2["PrecedingLineBreak"] = 1] = "PrecedingLineBreak";
-        TokenFlags2[TokenFlags2["PrecedingJSDocComment"] = 2] = "PrecedingJSDocComment";
-        TokenFlags2[TokenFlags2["Unterminated"] = 4] = "Unterminated";
-        TokenFlags2[TokenFlags2["ExtendedUnicodeEscape"] = 8] = "ExtendedUnicodeEscape";
-        TokenFlags2[TokenFlags2["Scientific"] = 16] = "Scientific";
-        TokenFlags2[TokenFlags2["Octal"] = 32] = "Octal";
-        TokenFlags2[TokenFlags2["HexSpecifier"] = 64] = "HexSpecifier";
-        TokenFlags2[TokenFlags2["BinarySpecifier"] = 128] = "BinarySpecifier";
-        TokenFlags2[TokenFlags2["OctalSpecifier"] = 256] = "OctalSpecifier";
-        TokenFlags2[TokenFlags2["ContainsSeparator"] = 512] = "ContainsSeparator";
-        TokenFlags2[TokenFlags2["UnicodeEscape"] = 1024] = "UnicodeEscape";
-        TokenFlags2[TokenFlags2["ContainsInvalidEscape"] = 2048] = "ContainsInvalidEscape";
-        TokenFlags2[TokenFlags2["HexEscape"] = 4096] = "HexEscape";
-        TokenFlags2[TokenFlags2["ContainsLeadingZero"] = 8192] = "ContainsLeadingZero";
-        TokenFlags2[TokenFlags2["ContainsInvalidSeparator"] = 16384] = "ContainsInvalidSeparator";
-        TokenFlags2[TokenFlags2["BinaryOrOctalSpecifier"] = 384] = "BinaryOrOctalSpecifier";
-        TokenFlags2[TokenFlags2["WithSpecifier"] = 448] = "WithSpecifier";
-        TokenFlags2[TokenFlags2["StringLiteralFlags"] = 7176] = "StringLiteralFlags";
-        TokenFlags2[TokenFlags2["NumericLiteralFlags"] = 25584] = "NumericLiteralFlags";
-        TokenFlags2[TokenFlags2["TemplateLiteralLikeFlags"] = 7176] = "TemplateLiteralLikeFlags";
-        TokenFlags2[TokenFlags2["IsInvalid"] = 26656] = "IsInvalid";
-        return TokenFlags2;
-      })(TokenFlags || {});
-      FlowFlags = /* @__PURE__ */ ((FlowFlags2) => {
-        FlowFlags2[FlowFlags2["Unreachable"] = 1] = "Unreachable";
-        FlowFlags2[FlowFlags2["Start"] = 2] = "Start";
-        FlowFlags2[FlowFlags2["BranchLabel"] = 4] = "BranchLabel";
-        FlowFlags2[FlowFlags2["LoopLabel"] = 8] = "LoopLabel";
-        FlowFlags2[FlowFlags2["Assignment"] = 16] = "Assignment";
-        FlowFlags2[FlowFlags2["TrueCondition"] = 32] = "TrueCondition";
-        FlowFlags2[FlowFlags2["FalseCondition"] = 64] = "FalseCondition";
-        FlowFlags2[FlowFlags2["SwitchClause"] = 128] = "SwitchClause";
-        FlowFlags2[FlowFlags2["ArrayMutation"] = 256] = "ArrayMutation";
-        FlowFlags2[FlowFlags2["Call"] = 512] = "Call";
-        FlowFlags2[FlowFlags2["ReduceLabel"] = 1024] = "ReduceLabel";
-        FlowFlags2[FlowFlags2["Referenced"] = 2048] = "Referenced";
-        FlowFlags2[FlowFlags2["Shared"] = 4096] = "Shared";
-        FlowFlags2[FlowFlags2["Label"] = 12] = "Label";
-        FlowFlags2[FlowFlags2["Condition"] = 96] = "Condition";
-        return FlowFlags2;
-      })(FlowFlags || {});
-      CommentDirectiveType = /* @__PURE__ */ ((CommentDirectiveType2) => {
-        CommentDirectiveType2[CommentDirectiveType2["ExpectError"] = 0] = "ExpectError";
-        CommentDirectiveType2[CommentDirectiveType2["Ignore"] = 1] = "Ignore";
-        return CommentDirectiveType2;
-      })(CommentDirectiveType || {});
-      OperationCanceledException = class {
-      };
-      FileIncludeKind = /* @__PURE__ */ ((FileIncludeKind2) => {
-        FileIncludeKind2[FileIncludeKind2["RootFile"] = 0] = "RootFile";
-        FileIncludeKind2[FileIncludeKind2["SourceFromProjectReference"] = 1] = "SourceFromProjectReference";
-        FileIncludeKind2[FileIncludeKind2["OutputFromProjectReference"] = 2] = "OutputFromProjectReference";
-        FileIncludeKind2[FileIncludeKind2["Import"] = 3] = "Import";
-        FileIncludeKind2[FileIncludeKind2["ReferenceFile"] = 4] = "ReferenceFile";
-        FileIncludeKind2[FileIncludeKind2["TypeReferenceDirective"] = 5] = "TypeReferenceDirective";
-        FileIncludeKind2[FileIncludeKind2["LibFile"] = 6] = "LibFile";
-        FileIncludeKind2[FileIncludeKind2["LibReferenceDirective"] = 7] = "LibReferenceDirective";
-        FileIncludeKind2[FileIncludeKind2["AutomaticTypeDirectiveFile"] = 8] = "AutomaticTypeDirectiveFile";
-        return FileIncludeKind2;
-      })(FileIncludeKind || {});
-      FilePreprocessingDiagnosticsKind = /* @__PURE__ */ ((FilePreprocessingDiagnosticsKind2) => {
-        FilePreprocessingDiagnosticsKind2[FilePreprocessingDiagnosticsKind2["FilePreprocessingReferencedDiagnostic"] = 0] = "FilePreprocessingReferencedDiagnostic";
-        FilePreprocessingDiagnosticsKind2[FilePreprocessingDiagnosticsKind2["FilePreprocessingFileExplainingDiagnostic"] = 1] = "FilePreprocessingFileExplainingDiagnostic";
-        FilePreprocessingDiagnosticsKind2[FilePreprocessingDiagnosticsKind2["ResolutionDiagnostics"] = 2] = "ResolutionDiagnostics";
-        return FilePreprocessingDiagnosticsKind2;
-      })(FilePreprocessingDiagnosticsKind || {});
-      EmitOnly = /* @__PURE__ */ ((EmitOnly4) => {
-        EmitOnly4[EmitOnly4["Js"] = 0] = "Js";
-        EmitOnly4[EmitOnly4["Dts"] = 1] = "Dts";
-        return EmitOnly4;
-      })(EmitOnly || {});
-      StructureIsReused = /* @__PURE__ */ ((StructureIsReused2) => {
-        StructureIsReused2[StructureIsReused2["Not"] = 0] = "Not";
-        StructureIsReused2[StructureIsReused2["SafeModules"] = 1] = "SafeModules";
-        StructureIsReused2[StructureIsReused2["Completely"] = 2] = "Completely";
-        return StructureIsReused2;
-      })(StructureIsReused || {});
-      ExitStatus = /* @__PURE__ */ ((ExitStatus2) => {
-        ExitStatus2[ExitStatus2["Success"] = 0] = "Success";
-        ExitStatus2[ExitStatus2["DiagnosticsPresent_OutputsSkipped"] = 1] = "DiagnosticsPresent_OutputsSkipped";
-        ExitStatus2[ExitStatus2["DiagnosticsPresent_OutputsGenerated"] = 2] = "DiagnosticsPresent_OutputsGenerated";
-        ExitStatus2[ExitStatus2["InvalidProject_OutputsSkipped"] = 3] = "InvalidProject_OutputsSkipped";
-        ExitStatus2[ExitStatus2["ProjectReferenceCycle_OutputsSkipped"] = 4] = "ProjectReferenceCycle_OutputsSkipped";
-        return ExitStatus2;
-      })(ExitStatus || {});
-      MemberOverrideStatus = /* @__PURE__ */ ((MemberOverrideStatus2) => {
-        MemberOverrideStatus2[MemberOverrideStatus2["Ok"] = 0] = "Ok";
-        MemberOverrideStatus2[MemberOverrideStatus2["NeedsOverride"] = 1] = "NeedsOverride";
-        MemberOverrideStatus2[MemberOverrideStatus2["HasInvalidOverride"] = 2] = "HasInvalidOverride";
-        return MemberOverrideStatus2;
-      })(MemberOverrideStatus || {});
-      UnionReduction = /* @__PURE__ */ ((UnionReduction2) => {
-        UnionReduction2[UnionReduction2["None"] = 0] = "None";
-        UnionReduction2[UnionReduction2["Literal"] = 1] = "Literal";
-        UnionReduction2[UnionReduction2["Subtype"] = 2] = "Subtype";
-        return UnionReduction2;
-      })(UnionReduction || {});
-      ContextFlags = /* @__PURE__ */ ((ContextFlags3) => {
-        ContextFlags3[ContextFlags3["None"] = 0] = "None";
-        ContextFlags3[ContextFlags3["Signature"] = 1] = "Signature";
-        ContextFlags3[ContextFlags3["NoConstraints"] = 2] = "NoConstraints";
-        ContextFlags3[ContextFlags3["Completions"] = 4] = "Completions";
-        ContextFlags3[ContextFlags3["SkipBindingPatterns"] = 8] = "SkipBindingPatterns";
-        return ContextFlags3;
-      })(ContextFlags || {});
-      NodeBuilderFlags = /* @__PURE__ */ ((NodeBuilderFlags2) => {
-        NodeBuilderFlags2[NodeBuilderFlags2["None"] = 0] = "None";
-        NodeBuilderFlags2[NodeBuilderFlags2["NoTruncation"] = 1] = "NoTruncation";
-        NodeBuilderFlags2[NodeBuilderFlags2["WriteArrayAsGenericType"] = 2] = "WriteArrayAsGenericType";
-        NodeBuilderFlags2[NodeBuilderFlags2["GenerateNamesForShadowedTypeParams"] = 4] = "GenerateNamesForShadowedTypeParams";
-        NodeBuilderFlags2[NodeBuilderFlags2["UseStructuralFallback"] = 8] = "UseStructuralFallback";
-        NodeBuilderFlags2[NodeBuilderFlags2["ForbidIndexedAccessSymbolReferences"] = 16] = "ForbidIndexedAccessSymbolReferences";
-        NodeBuilderFlags2[NodeBuilderFlags2["WriteTypeArgumentsOfSignature"] = 32] = "WriteTypeArgumentsOfSignature";
-        NodeBuilderFlags2[NodeBuilderFlags2["UseFullyQualifiedType"] = 64] = "UseFullyQualifiedType";
-        NodeBuilderFlags2[NodeBuilderFlags2["UseOnlyExternalAliasing"] = 128] = "UseOnlyExternalAliasing";
-        NodeBuilderFlags2[NodeBuilderFlags2["SuppressAnyReturnType"] = 256] = "SuppressAnyReturnType";
-        NodeBuilderFlags2[NodeBuilderFlags2["WriteTypeParametersInQualifiedName"] = 512] = "WriteTypeParametersInQualifiedName";
-        NodeBuilderFlags2[NodeBuilderFlags2["MultilineObjectLiterals"] = 1024] = "MultilineObjectLiterals";
-        NodeBuilderFlags2[NodeBuilderFlags2["WriteClassExpressionAsTypeLiteral"] = 2048] = "WriteClassExpressionAsTypeLiteral";
-        NodeBuilderFlags2[NodeBuilderFlags2["UseTypeOfFunction"] = 4096] = "UseTypeOfFunction";
-        NodeBuilderFlags2[NodeBuilderFlags2["OmitParameterModifiers"] = 8192] = "OmitParameterModifiers";
-        NodeBuilderFlags2[NodeBuilderFlags2["UseAliasDefinedOutsideCurrentScope"] = 16384] = "UseAliasDefinedOutsideCurrentScope";
-        NodeBuilderFlags2[NodeBuilderFlags2["UseSingleQuotesForStringLiteralType"] = 268435456] = "UseSingleQuotesForStringLiteralType";
-        NodeBuilderFlags2[NodeBuilderFlags2["NoTypeReduction"] = 536870912] = "NoTypeReduction";
-        NodeBuilderFlags2[NodeBuilderFlags2["OmitThisParameter"] = 33554432] = "OmitThisParameter";
-        NodeBuilderFlags2[NodeBuilderFlags2["AllowThisInObjectLiteral"] = 32768] = "AllowThisInObjectLiteral";
-        NodeBuilderFlags2[NodeBuilderFlags2["AllowQualifiedNameInPlaceOfIdentifier"] = 65536] = "AllowQualifiedNameInPlaceOfIdentifier";
-        NodeBuilderFlags2[NodeBuilderFlags2["AllowAnonymousIdentifier"] = 131072] = "AllowAnonymousIdentifier";
-        NodeBuilderFlags2[NodeBuilderFlags2["AllowEmptyUnionOrIntersection"] = 262144] = "AllowEmptyUnionOrIntersection";
-        NodeBuilderFlags2[NodeBuilderFlags2["AllowEmptyTuple"] = 524288] = "AllowEmptyTuple";
-        NodeBuilderFlags2[NodeBuilderFlags2["AllowUniqueESSymbolType"] = 1048576] = "AllowUniqueESSymbolType";
-        NodeBuilderFlags2[NodeBuilderFlags2["AllowEmptyIndexInfoType"] = 2097152] = "AllowEmptyIndexInfoType";
-        NodeBuilderFlags2[NodeBuilderFlags2["WriteComputedProps"] = 1073741824] = "WriteComputedProps";
-        NodeBuilderFlags2[NodeBuilderFlags2["AllowNodeModulesRelativePaths"] = 67108864] = "AllowNodeModulesRelativePaths";
-        NodeBuilderFlags2[NodeBuilderFlags2["DoNotIncludeSymbolChain"] = 134217728] = "DoNotIncludeSymbolChain";
-        NodeBuilderFlags2[NodeBuilderFlags2["IgnoreErrors"] = 70221824] = "IgnoreErrors";
-        NodeBuilderFlags2[NodeBuilderFlags2["InObjectTypeLiteral"] = 4194304] = "InObjectTypeLiteral";
-        NodeBuilderFlags2[NodeBuilderFlags2["InTypeAlias"] = 8388608] = "InTypeAlias";
-        NodeBuilderFlags2[NodeBuilderFlags2["InInitialEntityName"] = 16777216] = "InInitialEntityName";
-        return NodeBuilderFlags2;
-      })(NodeBuilderFlags || {});
-      TypeFormatFlags = /* @__PURE__ */ ((TypeFormatFlags2) => {
-        TypeFormatFlags2[TypeFormatFlags2["None"] = 0] = "None";
-        TypeFormatFlags2[TypeFormatFlags2["NoTruncation"] = 1] = "NoTruncation";
-        TypeFormatFlags2[TypeFormatFlags2["WriteArrayAsGenericType"] = 2] = "WriteArrayAsGenericType";
-        TypeFormatFlags2[TypeFormatFlags2["UseStructuralFallback"] = 8] = "UseStructuralFallback";
-        TypeFormatFlags2[TypeFormatFlags2["WriteTypeArgumentsOfSignature"] = 32] = "WriteTypeArgumentsOfSignature";
-        TypeFormatFlags2[TypeFormatFlags2["UseFullyQualifiedType"] = 64] = "UseFullyQualifiedType";
-        TypeFormatFlags2[TypeFormatFlags2["SuppressAnyReturnType"] = 256] = "SuppressAnyReturnType";
-        TypeFormatFlags2[TypeFormatFlags2["MultilineObjectLiterals"] = 1024] = "MultilineObjectLiterals";
-        TypeFormatFlags2[TypeFormatFlags2["WriteClassExpressionAsTypeLiteral"] = 2048] = "WriteClassExpressionAsTypeLiteral";
-        TypeFormatFlags2[TypeFormatFlags2["UseTypeOfFunction"] = 4096] = "UseTypeOfFunction";
-        TypeFormatFlags2[TypeFormatFlags2["OmitParameterModifiers"] = 8192] = "OmitParameterModifiers";
-        TypeFormatFlags2[TypeFormatFlags2["UseAliasDefinedOutsideCurrentScope"] = 16384] = "UseAliasDefinedOutsideCurrentScope";
-        TypeFormatFlags2[TypeFormatFlags2["UseSingleQuotesForStringLiteralType"] = 268435456] = "UseSingleQuotesForStringLiteralType";
-        TypeFormatFlags2[TypeFormatFlags2["NoTypeReduction"] = 536870912] = "NoTypeReduction";
-        TypeFormatFlags2[TypeFormatFlags2["OmitThisParameter"] = 33554432] = "OmitThisParameter";
-        TypeFormatFlags2[TypeFormatFlags2["AllowUniqueESSymbolType"] = 1048576] = "AllowUniqueESSymbolType";
-        TypeFormatFlags2[TypeFormatFlags2["AddUndefined"] = 131072] = "AddUndefined";
-        TypeFormatFlags2[TypeFormatFlags2["WriteArrowStyleSignature"] = 262144] = "WriteArrowStyleSignature";
-        TypeFormatFlags2[TypeFormatFlags2["InArrayType"] = 524288] = "InArrayType";
-        TypeFormatFlags2[TypeFormatFlags2["InElementType"] = 2097152] = "InElementType";
-        TypeFormatFlags2[TypeFormatFlags2["InFirstTypeArgument"] = 4194304] = "InFirstTypeArgument";
-        TypeFormatFlags2[TypeFormatFlags2["InTypeAlias"] = 8388608] = "InTypeAlias";
-        TypeFormatFlags2[TypeFormatFlags2["NodeBuilderFlagsMask"] = 848330091] = "NodeBuilderFlagsMask";
-        return TypeFormatFlags2;
-      })(TypeFormatFlags || {});
-      SymbolFormatFlags = /* @__PURE__ */ ((SymbolFormatFlags2) => {
-        SymbolFormatFlags2[SymbolFormatFlags2["None"] = 0] = "None";
-        SymbolFormatFlags2[SymbolFormatFlags2["WriteTypeParametersOrArguments"] = 1] = "WriteTypeParametersOrArguments";
-        SymbolFormatFlags2[SymbolFormatFlags2["UseOnlyExternalAliasing"] = 2] = "UseOnlyExternalAliasing";
-        SymbolFormatFlags2[SymbolFormatFlags2["AllowAnyNodeKind"] = 4] = "AllowAnyNodeKind";
-        SymbolFormatFlags2[SymbolFormatFlags2["UseAliasDefinedOutsideCurrentScope"] = 8] = "UseAliasDefinedOutsideCurrentScope";
-        SymbolFormatFlags2[SymbolFormatFlags2["WriteComputedProps"] = 16] = "WriteComputedProps";
-        SymbolFormatFlags2[SymbolFormatFlags2["DoNotIncludeSymbolChain"] = 32] = "DoNotIncludeSymbolChain";
-        return SymbolFormatFlags2;
-      })(SymbolFormatFlags || {});
-      SymbolAccessibility = /* @__PURE__ */ ((SymbolAccessibility2) => {
-        SymbolAccessibility2[SymbolAccessibility2["Accessible"] = 0] = "Accessible";
-        SymbolAccessibility2[SymbolAccessibility2["NotAccessible"] = 1] = "NotAccessible";
-        SymbolAccessibility2[SymbolAccessibility2["CannotBeNamed"] = 2] = "CannotBeNamed";
-        return SymbolAccessibility2;
-      })(SymbolAccessibility || {});
-      SyntheticSymbolKind = /* @__PURE__ */ ((SyntheticSymbolKind2) => {
-        SyntheticSymbolKind2[SyntheticSymbolKind2["UnionOrIntersection"] = 0] = "UnionOrIntersection";
-        SyntheticSymbolKind2[SyntheticSymbolKind2["Spread"] = 1] = "Spread";
-        return SyntheticSymbolKind2;
-      })(SyntheticSymbolKind || {});
-      TypePredicateKind = /* @__PURE__ */ ((TypePredicateKind2) => {
-        TypePredicateKind2[TypePredicateKind2["This"] = 0] = "This";
-        TypePredicateKind2[TypePredicateKind2["Identifier"] = 1] = "Identifier";
-        TypePredicateKind2[TypePredicateKind2["AssertsThis"] = 2] = "AssertsThis";
-        TypePredicateKind2[TypePredicateKind2["AssertsIdentifier"] = 3] = "AssertsIdentifier";
-        return TypePredicateKind2;
-      })(TypePredicateKind || {});
-      TypeReferenceSerializationKind = /* @__PURE__ */ ((TypeReferenceSerializationKind2) => {
-        TypeReferenceSerializationKind2[TypeReferenceSerializationKind2["Unknown"] = 0] = "Unknown";
-        TypeReferenceSerializationKind2[TypeReferenceSerializationKind2["TypeWithConstructSignatureAndValue"] = 1] = "TypeWithConstructSignatureAndValue";
-        TypeReferenceSerializationKind2[TypeReferenceSerializationKind2["VoidNullableOrNeverType"] = 2] = "VoidNullableOrNeverType";
-        TypeReferenceSerializationKind2[TypeReferenceSerializationKind2["NumberLikeType"] = 3] = "NumberLikeType";
-        TypeReferenceSerializationKind2[TypeReferenceSerializationKind2["BigIntLikeType"] = 4] = "BigIntLikeType";
-        TypeReferenceSerializationKind2[TypeReferenceSerializationKind2["StringLikeType"] = 5] = "StringLikeType";
-        TypeReferenceSerializationKind2[TypeReferenceSerializationKind2["BooleanType"] = 6] = "BooleanType";
-        TypeReferenceSerializationKind2[TypeReferenceSerializationKind2["ArrayLikeType"] = 7] = "ArrayLikeType";
-        TypeReferenceSerializationKind2[TypeReferenceSerializationKind2["ESSymbolType"] = 8] = "ESSymbolType";
-        TypeReferenceSerializationKind2[TypeReferenceSerializationKind2["Promise"] = 9] = "Promise";
-        TypeReferenceSerializationKind2[TypeReferenceSerializationKind2["TypeWithCallSignature"] = 10] = "TypeWithCallSignature";
-        TypeReferenceSerializationKind2[TypeReferenceSerializationKind2["ObjectType"] = 11] = "ObjectType";
-        return TypeReferenceSerializationKind2;
-      })(TypeReferenceSerializationKind || {});
-      SymbolFlags = /* @__PURE__ */ ((SymbolFlags3) => {
-        SymbolFlags3[SymbolFlags3["None"] = 0] = "None";
-        SymbolFlags3[SymbolFlags3["FunctionScopedVariable"] = 1] = "FunctionScopedVariable";
-        SymbolFlags3[SymbolFlags3["BlockScopedVariable"] = 2] = "BlockScopedVariable";
-        SymbolFlags3[SymbolFlags3["Property"] = 4] = "Property";
-        SymbolFlags3[SymbolFlags3["EnumMember"] = 8] = "EnumMember";
-        SymbolFlags3[SymbolFlags3["Function"] = 16] = "Function";
-        SymbolFlags3[SymbolFlags3["Class"] = 32] = "Class";
-        SymbolFlags3[SymbolFlags3["Interface"] = 64] = "Interface";
-        SymbolFlags3[SymbolFlags3["ConstEnum"] = 128] = "ConstEnum";
-        SymbolFlags3[SymbolFlags3["RegularEnum"] = 256] = "RegularEnum";
-        SymbolFlags3[SymbolFlags3["ValueModule"] = 512] = "ValueModule";
-        SymbolFlags3[SymbolFlags3["NamespaceModule"] = 1024] = "NamespaceModule";
-        SymbolFlags3[SymbolFlags3["TypeLiteral"] = 2048] = "TypeLiteral";
-        SymbolFlags3[SymbolFlags3["ObjectLiteral"] = 4096] = "ObjectLiteral";
-        SymbolFlags3[SymbolFlags3["Method"] = 8192] = "Method";
-        SymbolFlags3[SymbolFlags3["Constructor"] = 16384] = "Constructor";
-        SymbolFlags3[SymbolFlags3["GetAccessor"] = 32768] = "GetAccessor";
-        SymbolFlags3[SymbolFlags3["SetAccessor"] = 65536] = "SetAccessor";
-        SymbolFlags3[SymbolFlags3["Signature"] = 131072] = "Signature";
-        SymbolFlags3[SymbolFlags3["TypeParameter"] = 262144] = "TypeParameter";
-        SymbolFlags3[SymbolFlags3["TypeAlias"] = 524288] = "TypeAlias";
-        SymbolFlags3[SymbolFlags3["ExportValue"] = 1048576] = "ExportValue";
-        SymbolFlags3[SymbolFlags3["Alias"] = 2097152] = "Alias";
-        SymbolFlags3[SymbolFlags3["Prototype"] = 4194304] = "Prototype";
-        SymbolFlags3[SymbolFlags3["ExportStar"] = 8388608] = "ExportStar";
-        SymbolFlags3[SymbolFlags3["Optional"] = 16777216] = "Optional";
-        SymbolFlags3[SymbolFlags3["Transient"] = 33554432] = "Transient";
-        SymbolFlags3[SymbolFlags3["Assignment"] = 67108864] = "Assignment";
-        SymbolFlags3[SymbolFlags3["ModuleExports"] = 134217728] = "ModuleExports";
-        SymbolFlags3[SymbolFlags3["All"] = 67108863] = "All";
-        SymbolFlags3[SymbolFlags3["Enum"] = 384] = "Enum";
-        SymbolFlags3[SymbolFlags3["Variable"] = 3] = "Variable";
-        SymbolFlags3[SymbolFlags3["Value"] = 111551] = "Value";
-        SymbolFlags3[SymbolFlags3["Type"] = 788968] = "Type";
-        SymbolFlags3[SymbolFlags3["Namespace"] = 1920] = "Namespace";
-        SymbolFlags3[SymbolFlags3["Module"] = 1536] = "Module";
-        SymbolFlags3[SymbolFlags3["Accessor"] = 98304] = "Accessor";
-        SymbolFlags3[SymbolFlags3["FunctionScopedVariableExcludes"] = 111550] = "FunctionScopedVariableExcludes";
-        SymbolFlags3[SymbolFlags3["BlockScopedVariableExcludes"] = 111551 /* Value */] = "BlockScopedVariableExcludes";
-        SymbolFlags3[SymbolFlags3["ParameterExcludes"] = 111551 /* Value */] = "ParameterExcludes";
-        SymbolFlags3[SymbolFlags3["PropertyExcludes"] = 0 /* None */] = "PropertyExcludes";
-        SymbolFlags3[SymbolFlags3["EnumMemberExcludes"] = 900095] = "EnumMemberExcludes";
-        SymbolFlags3[SymbolFlags3["FunctionExcludes"] = 110991] = "FunctionExcludes";
-        SymbolFlags3[SymbolFlags3["ClassExcludes"] = 899503] = "ClassExcludes";
-        SymbolFlags3[SymbolFlags3["InterfaceExcludes"] = 788872] = "InterfaceExcludes";
-        SymbolFlags3[SymbolFlags3["RegularEnumExcludes"] = 899327] = "RegularEnumExcludes";
-        SymbolFlags3[SymbolFlags3["ConstEnumExcludes"] = 899967] = "ConstEnumExcludes";
-        SymbolFlags3[SymbolFlags3["ValueModuleExcludes"] = 110735] = "ValueModuleExcludes";
-        SymbolFlags3[SymbolFlags3["NamespaceModuleExcludes"] = 0] = "NamespaceModuleExcludes";
-        SymbolFlags3[SymbolFlags3["MethodExcludes"] = 103359] = "MethodExcludes";
-        SymbolFlags3[SymbolFlags3["GetAccessorExcludes"] = 46015] = "GetAccessorExcludes";
-        SymbolFlags3[SymbolFlags3["SetAccessorExcludes"] = 78783] = "SetAccessorExcludes";
-        SymbolFlags3[SymbolFlags3["AccessorExcludes"] = 13247] = "AccessorExcludes";
-        SymbolFlags3[SymbolFlags3["TypeParameterExcludes"] = 526824] = "TypeParameterExcludes";
-        SymbolFlags3[SymbolFlags3["TypeAliasExcludes"] = 788968 /* Type */] = "TypeAliasExcludes";
-        SymbolFlags3[SymbolFlags3["AliasExcludes"] = 2097152 /* Alias */] = "AliasExcludes";
-        SymbolFlags3[SymbolFlags3["ModuleMember"] = 2623475] = "ModuleMember";
-        SymbolFlags3[SymbolFlags3["ExportHasLocal"] = 944] = "ExportHasLocal";
-        SymbolFlags3[SymbolFlags3["BlockScoped"] = 418] = "BlockScoped";
-        SymbolFlags3[SymbolFlags3["PropertyOrAccessor"] = 98308] = "PropertyOrAccessor";
-        SymbolFlags3[SymbolFlags3["ClassMember"] = 106500] = "ClassMember";
-        SymbolFlags3[SymbolFlags3["ExportSupportsDefaultModifier"] = 112] = "ExportSupportsDefaultModifier";
-        SymbolFlags3[SymbolFlags3["ExportDoesNotSupportDefaultModifier"] = -113] = "ExportDoesNotSupportDefaultModifier";
-        SymbolFlags3[SymbolFlags3["Classifiable"] = 2885600] = "Classifiable";
-        SymbolFlags3[SymbolFlags3["LateBindingContainer"] = 6256] = "LateBindingContainer";
-        return SymbolFlags3;
-      })(SymbolFlags || {});
-      EnumKind = /* @__PURE__ */ ((EnumKind2) => {
-        EnumKind2[EnumKind2["Numeric"] = 0] = "Numeric";
-        EnumKind2[EnumKind2["Literal"] = 1] = "Literal";
-        return EnumKind2;
-      })(EnumKind || {});
-      CheckFlags = /* @__PURE__ */ ((CheckFlags2) => {
-        CheckFlags2[CheckFlags2["None"] = 0] = "None";
-        CheckFlags2[CheckFlags2["Instantiated"] = 1] = "Instantiated";
-        CheckFlags2[CheckFlags2["SyntheticProperty"] = 2] = "SyntheticProperty";
-        CheckFlags2[CheckFlags2["SyntheticMethod"] = 4] = "SyntheticMethod";
-        CheckFlags2[CheckFlags2["Readonly"] = 8] = "Readonly";
-        CheckFlags2[CheckFlags2["ReadPartial"] = 16] = "ReadPartial";
-        CheckFlags2[CheckFlags2["WritePartial"] = 32] = "WritePartial";
-        CheckFlags2[CheckFlags2["HasNonUniformType"] = 64] = "HasNonUniformType";
-        CheckFlags2[CheckFlags2["HasLiteralType"] = 128] = "HasLiteralType";
-        CheckFlags2[CheckFlags2["ContainsPublic"] = 256] = "ContainsPublic";
-        CheckFlags2[CheckFlags2["ContainsProtected"] = 512] = "ContainsProtected";
-        CheckFlags2[CheckFlags2["ContainsPrivate"] = 1024] = "ContainsPrivate";
-        CheckFlags2[CheckFlags2["ContainsStatic"] = 2048] = "ContainsStatic";
-        CheckFlags2[CheckFlags2["Late"] = 4096] = "Late";
-        CheckFlags2[CheckFlags2["ReverseMapped"] = 8192] = "ReverseMapped";
-        CheckFlags2[CheckFlags2["OptionalParameter"] = 16384] = "OptionalParameter";
-        CheckFlags2[CheckFlags2["RestParameter"] = 32768] = "RestParameter";
-        CheckFlags2[CheckFlags2["DeferredType"] = 65536] = "DeferredType";
-        CheckFlags2[CheckFlags2["HasNeverType"] = 131072] = "HasNeverType";
-        CheckFlags2[CheckFlags2["Mapped"] = 262144] = "Mapped";
-        CheckFlags2[CheckFlags2["StripOptional"] = 524288] = "StripOptional";
-        CheckFlags2[CheckFlags2["Unresolved"] = 1048576] = "Unresolved";
-        CheckFlags2[CheckFlags2["Synthetic"] = 6] = "Synthetic";
-        CheckFlags2[CheckFlags2["Discriminant"] = 192] = "Discriminant";
-        CheckFlags2[CheckFlags2["Partial"] = 48] = "Partial";
-        return CheckFlags2;
-      })(CheckFlags || {});
-      InternalSymbolName = /* @__PURE__ */ ((InternalSymbolName2) => {
-        InternalSymbolName2["Call"] = "__call";
-        InternalSymbolName2["Constructor"] = "__constructor";
-        InternalSymbolName2["New"] = "__new";
-        InternalSymbolName2["Index"] = "__index";
-        InternalSymbolName2["ExportStar"] = "__export";
-        InternalSymbolName2["Global"] = "__global";
-        InternalSymbolName2["Missing"] = "__missing";
-        InternalSymbolName2["Type"] = "__type";
-        InternalSymbolName2["Object"] = "__object";
-        InternalSymbolName2["JSXAttributes"] = "__jsxAttributes";
-        InternalSymbolName2["Class"] = "__class";
-        InternalSymbolName2["Function"] = "__function";
-        InternalSymbolName2["Computed"] = "__computed";
-        InternalSymbolName2["Resolving"] = "__resolving__";
-        InternalSymbolName2["ExportEquals"] = "export=";
-        InternalSymbolName2["Default"] = "default";
-        InternalSymbolName2["This"] = "this";
-        return InternalSymbolName2;
-      })(InternalSymbolName || {});
-      NodeCheckFlags = /* @__PURE__ */ ((NodeCheckFlags2) => {
-        NodeCheckFlags2[NodeCheckFlags2["None"] = 0] = "None";
-        NodeCheckFlags2[NodeCheckFlags2["TypeChecked"] = 1] = "TypeChecked";
-        NodeCheckFlags2[NodeCheckFlags2["LexicalThis"] = 2] = "LexicalThis";
-        NodeCheckFlags2[NodeCheckFlags2["CaptureThis"] = 4] = "CaptureThis";
-        NodeCheckFlags2[NodeCheckFlags2["CaptureNewTarget"] = 8] = "CaptureNewTarget";
-        NodeCheckFlags2[NodeCheckFlags2["SuperInstance"] = 16] = "SuperInstance";
-        NodeCheckFlags2[NodeCheckFlags2["SuperStatic"] = 32] = "SuperStatic";
-        NodeCheckFlags2[NodeCheckFlags2["ContextChecked"] = 64] = "ContextChecked";
-        NodeCheckFlags2[NodeCheckFlags2["MethodWithSuperPropertyAccessInAsync"] = 128] = "MethodWithSuperPropertyAccessInAsync";
-        NodeCheckFlags2[NodeCheckFlags2["MethodWithSuperPropertyAssignmentInAsync"] = 256] = "MethodWithSuperPropertyAssignmentInAsync";
-        NodeCheckFlags2[NodeCheckFlags2["CaptureArguments"] = 512] = "CaptureArguments";
-        NodeCheckFlags2[NodeCheckFlags2["EnumValuesComputed"] = 1024] = "EnumValuesComputed";
-        NodeCheckFlags2[NodeCheckFlags2["LexicalModuleMergesWithClass"] = 2048] = "LexicalModuleMergesWithClass";
-        NodeCheckFlags2[NodeCheckFlags2["LoopWithCapturedBlockScopedBinding"] = 4096] = "LoopWithCapturedBlockScopedBinding";
-        NodeCheckFlags2[NodeCheckFlags2["ContainsCapturedBlockScopeBinding"] = 8192] = "ContainsCapturedBlockScopeBinding";
-        NodeCheckFlags2[NodeCheckFlags2["CapturedBlockScopedBinding"] = 16384] = "CapturedBlockScopedBinding";
-        NodeCheckFlags2[NodeCheckFlags2["BlockScopedBindingInLoop"] = 32768] = "BlockScopedBindingInLoop";
-        NodeCheckFlags2[NodeCheckFlags2["ClassWithBodyScopedClassBinding"] = 65536] = "ClassWithBodyScopedClassBinding";
-        NodeCheckFlags2[NodeCheckFlags2["BodyScopedClassBinding"] = 131072] = "BodyScopedClassBinding";
-        NodeCheckFlags2[NodeCheckFlags2["NeedsLoopOutParameter"] = 262144] = "NeedsLoopOutParameter";
-        NodeCheckFlags2[NodeCheckFlags2["AssignmentsMarked"] = 524288] = "AssignmentsMarked";
-        NodeCheckFlags2[NodeCheckFlags2["ClassWithConstructorReference"] = 1048576] = "ClassWithConstructorReference";
-        NodeCheckFlags2[NodeCheckFlags2["ConstructorReferenceInClass"] = 2097152] = "ConstructorReferenceInClass";
-        NodeCheckFlags2[NodeCheckFlags2["ContainsClassWithPrivateIdentifiers"] = 4194304] = "ContainsClassWithPrivateIdentifiers";
-        NodeCheckFlags2[NodeCheckFlags2["ContainsSuperPropertyInStaticInitializer"] = 8388608] = "ContainsSuperPropertyInStaticInitializer";
-        NodeCheckFlags2[NodeCheckFlags2["InCheckIdentifier"] = 16777216] = "InCheckIdentifier";
-        return NodeCheckFlags2;
-      })(NodeCheckFlags || {});
-      TypeFlags = /* @__PURE__ */ ((TypeFlags2) => {
-        TypeFlags2[TypeFlags2["Any"] = 1] = "Any";
-        TypeFlags2[TypeFlags2["Unknown"] = 2] = "Unknown";
-        TypeFlags2[TypeFlags2["String"] = 4] = "String";
-        TypeFlags2[TypeFlags2["Number"] = 8] = "Number";
-        TypeFlags2[TypeFlags2["Boolean"] = 16] = "Boolean";
-        TypeFlags2[TypeFlags2["Enum"] = 32] = "Enum";
-        TypeFlags2[TypeFlags2["BigInt"] = 64] = "BigInt";
-        TypeFlags2[TypeFlags2["StringLiteral"] = 128] = "StringLiteral";
-        TypeFlags2[TypeFlags2["NumberLiteral"] = 256] = "NumberLiteral";
-        TypeFlags2[TypeFlags2["BooleanLiteral"] = 512] = "BooleanLiteral";
-        TypeFlags2[TypeFlags2["EnumLiteral"] = 1024] = "EnumLiteral";
-        TypeFlags2[TypeFlags2["BigIntLiteral"] = 2048] = "BigIntLiteral";
-        TypeFlags2[TypeFlags2["ESSymbol"] = 4096] = "ESSymbol";
-        TypeFlags2[TypeFlags2["UniqueESSymbol"] = 8192] = "UniqueESSymbol";
-        TypeFlags2[TypeFlags2["Void"] = 16384] = "Void";
-        TypeFlags2[TypeFlags2["Undefined"] = 32768] = "Undefined";
-        TypeFlags2[TypeFlags2["Null"] = 65536] = "Null";
-        TypeFlags2[TypeFlags2["Never"] = 131072] = "Never";
-        TypeFlags2[TypeFlags2["TypeParameter"] = 262144] = "TypeParameter";
-        TypeFlags2[TypeFlags2["Object"] = 524288] = "Object";
-        TypeFlags2[TypeFlags2["Union"] = 1048576] = "Union";
-        TypeFlags2[TypeFlags2["Intersection"] = 2097152] = "Intersection";
-        TypeFlags2[TypeFlags2["Index"] = 4194304] = "Index";
-        TypeFlags2[TypeFlags2["IndexedAccess"] = 8388608] = "IndexedAccess";
-        TypeFlags2[TypeFlags2["Conditional"] = 16777216] = "Conditional";
-        TypeFlags2[TypeFlags2["Substitution"] = 33554432] = "Substitution";
-        TypeFlags2[TypeFlags2["NonPrimitive"] = 67108864] = "NonPrimitive";
-        TypeFlags2[TypeFlags2["TemplateLiteral"] = 134217728] = "TemplateLiteral";
-        TypeFlags2[TypeFlags2["StringMapping"] = 268435456] = "StringMapping";
-        TypeFlags2[TypeFlags2["AnyOrUnknown"] = 3] = "AnyOrUnknown";
-        TypeFlags2[TypeFlags2["Nullable"] = 98304] = "Nullable";
-        TypeFlags2[TypeFlags2["Literal"] = 2944] = "Literal";
-        TypeFlags2[TypeFlags2["Unit"] = 109472] = "Unit";
-        TypeFlags2[TypeFlags2["Freshable"] = 2976] = "Freshable";
-        TypeFlags2[TypeFlags2["StringOrNumberLiteral"] = 384] = "StringOrNumberLiteral";
-        TypeFlags2[TypeFlags2["StringOrNumberLiteralOrUnique"] = 8576] = "StringOrNumberLiteralOrUnique";
-        TypeFlags2[TypeFlags2["DefinitelyFalsy"] = 117632] = "DefinitelyFalsy";
-        TypeFlags2[TypeFlags2["PossiblyFalsy"] = 117724] = "PossiblyFalsy";
-        TypeFlags2[TypeFlags2["Intrinsic"] = 67359327] = "Intrinsic";
-        TypeFlags2[TypeFlags2["StringLike"] = 402653316] = "StringLike";
-        TypeFlags2[TypeFlags2["NumberLike"] = 296] = "NumberLike";
-        TypeFlags2[TypeFlags2["BigIntLike"] = 2112] = "BigIntLike";
-        TypeFlags2[TypeFlags2["BooleanLike"] = 528] = "BooleanLike";
-        TypeFlags2[TypeFlags2["EnumLike"] = 1056] = "EnumLike";
-        TypeFlags2[TypeFlags2["ESSymbolLike"] = 12288] = "ESSymbolLike";
-        TypeFlags2[TypeFlags2["VoidLike"] = 49152] = "VoidLike";
-        TypeFlags2[TypeFlags2["Primitive"] = 402784252] = "Primitive";
-        TypeFlags2[TypeFlags2["DefinitelyNonNullable"] = 470302716] = "DefinitelyNonNullable";
-        TypeFlags2[TypeFlags2["DisjointDomains"] = 469892092] = "DisjointDomains";
-        TypeFlags2[TypeFlags2["UnionOrIntersection"] = 3145728] = "UnionOrIntersection";
-        TypeFlags2[TypeFlags2["StructuredType"] = 3670016] = "StructuredType";
-        TypeFlags2[TypeFlags2["TypeVariable"] = 8650752] = "TypeVariable";
-        TypeFlags2[TypeFlags2["InstantiableNonPrimitive"] = 58982400] = "InstantiableNonPrimitive";
-        TypeFlags2[TypeFlags2["InstantiablePrimitive"] = 406847488] = "InstantiablePrimitive";
-        TypeFlags2[TypeFlags2["Instantiable"] = 465829888] = "Instantiable";
-        TypeFlags2[TypeFlags2["StructuredOrInstantiable"] = 469499904] = "StructuredOrInstantiable";
-        TypeFlags2[TypeFlags2["ObjectFlagsType"] = 138117121] = "ObjectFlagsType";
-        TypeFlags2[TypeFlags2["Simplifiable"] = 25165824] = "Simplifiable";
-        TypeFlags2[TypeFlags2["Singleton"] = 67358815] = "Singleton";
-        TypeFlags2[TypeFlags2["Narrowable"] = 536624127] = "Narrowable";
-        TypeFlags2[TypeFlags2["IncludesMask"] = 473694207] = "IncludesMask";
-        TypeFlags2[TypeFlags2["IncludesMissingType"] = 262144 /* TypeParameter */] = "IncludesMissingType";
-        TypeFlags2[TypeFlags2["IncludesNonWideningType"] = 4194304 /* Index */] = "IncludesNonWideningType";
-        TypeFlags2[TypeFlags2["IncludesWildcard"] = 8388608 /* IndexedAccess */] = "IncludesWildcard";
-        TypeFlags2[TypeFlags2["IncludesEmptyObject"] = 16777216 /* Conditional */] = "IncludesEmptyObject";
-        TypeFlags2[TypeFlags2["IncludesInstantiable"] = 33554432 /* Substitution */] = "IncludesInstantiable";
-        TypeFlags2[TypeFlags2["NotPrimitiveUnion"] = 36323331] = "NotPrimitiveUnion";
-        return TypeFlags2;
-      })(TypeFlags || {});
-      ObjectFlags = /* @__PURE__ */ ((ObjectFlags3) => {
-        ObjectFlags3[ObjectFlags3["None"] = 0] = "None";
-        ObjectFlags3[ObjectFlags3["Class"] = 1] = "Class";
-        ObjectFlags3[ObjectFlags3["Interface"] = 2] = "Interface";
-        ObjectFlags3[ObjectFlags3["Reference"] = 4] = "Reference";
-        ObjectFlags3[ObjectFlags3["Tuple"] = 8] = "Tuple";
-        ObjectFlags3[ObjectFlags3["Anonymous"] = 16] = "Anonymous";
-        ObjectFlags3[ObjectFlags3["Mapped"] = 32] = "Mapped";
-        ObjectFlags3[ObjectFlags3["Instantiated"] = 64] = "Instantiated";
-        ObjectFlags3[ObjectFlags3["ObjectLiteral"] = 128] = "ObjectLiteral";
-        ObjectFlags3[ObjectFlags3["EvolvingArray"] = 256] = "EvolvingArray";
-        ObjectFlags3[ObjectFlags3["ObjectLiteralPatternWithComputedProperties"] = 512] = "ObjectLiteralPatternWithComputedProperties";
-        ObjectFlags3[ObjectFlags3["ReverseMapped"] = 1024] = "ReverseMapped";
-        ObjectFlags3[ObjectFlags3["JsxAttributes"] = 2048] = "JsxAttributes";
-        ObjectFlags3[ObjectFlags3["JSLiteral"] = 4096] = "JSLiteral";
-        ObjectFlags3[ObjectFlags3["FreshLiteral"] = 8192] = "FreshLiteral";
-        ObjectFlags3[ObjectFlags3["ArrayLiteral"] = 16384] = "ArrayLiteral";
-        ObjectFlags3[ObjectFlags3["PrimitiveUnion"] = 32768] = "PrimitiveUnion";
-        ObjectFlags3[ObjectFlags3["ContainsWideningType"] = 65536] = "ContainsWideningType";
-        ObjectFlags3[ObjectFlags3["ContainsObjectOrArrayLiteral"] = 131072] = "ContainsObjectOrArrayLiteral";
-        ObjectFlags3[ObjectFlags3["NonInferrableType"] = 262144] = "NonInferrableType";
-        ObjectFlags3[ObjectFlags3["CouldContainTypeVariablesComputed"] = 524288] = "CouldContainTypeVariablesComputed";
-        ObjectFlags3[ObjectFlags3["CouldContainTypeVariables"] = 1048576] = "CouldContainTypeVariables";
-        ObjectFlags3[ObjectFlags3["ClassOrInterface"] = 3] = "ClassOrInterface";
-        ObjectFlags3[ObjectFlags3["RequiresWidening"] = 196608] = "RequiresWidening";
-        ObjectFlags3[ObjectFlags3["PropagatingFlags"] = 458752] = "PropagatingFlags";
-        ObjectFlags3[ObjectFlags3["ObjectTypeKindMask"] = 1343] = "ObjectTypeKindMask";
-        ObjectFlags3[ObjectFlags3["ContainsSpread"] = 2097152] = "ContainsSpread";
-        ObjectFlags3[ObjectFlags3["ObjectRestType"] = 4194304] = "ObjectRestType";
-        ObjectFlags3[ObjectFlags3["InstantiationExpressionType"] = 8388608] = "InstantiationExpressionType";
-        ObjectFlags3[ObjectFlags3["IsClassInstanceClone"] = 16777216] = "IsClassInstanceClone";
-        ObjectFlags3[ObjectFlags3["IdenticalBaseTypeCalculated"] = 33554432] = "IdenticalBaseTypeCalculated";
-        ObjectFlags3[ObjectFlags3["IdenticalBaseTypeExists"] = 67108864] = "IdenticalBaseTypeExists";
-        ObjectFlags3[ObjectFlags3["IsGenericTypeComputed"] = 2097152] = "IsGenericTypeComputed";
-        ObjectFlags3[ObjectFlags3["IsGenericObjectType"] = 4194304] = "IsGenericObjectType";
-        ObjectFlags3[ObjectFlags3["IsGenericIndexType"] = 8388608] = "IsGenericIndexType";
-        ObjectFlags3[ObjectFlags3["IsGenericType"] = 12582912] = "IsGenericType";
-        ObjectFlags3[ObjectFlags3["ContainsIntersections"] = 16777216] = "ContainsIntersections";
-        ObjectFlags3[ObjectFlags3["IsUnknownLikeUnionComputed"] = 33554432] = "IsUnknownLikeUnionComputed";
-        ObjectFlags3[ObjectFlags3["IsUnknownLikeUnion"] = 67108864] = "IsUnknownLikeUnion";
-        ObjectFlags3[ObjectFlags3["IsNeverIntersectionComputed"] = 16777216] = "IsNeverIntersectionComputed";
-        ObjectFlags3[ObjectFlags3["IsNeverIntersection"] = 33554432] = "IsNeverIntersection";
-        return ObjectFlags3;
-      })(ObjectFlags || {});
-      VarianceFlags = /* @__PURE__ */ ((VarianceFlags2) => {
-        VarianceFlags2[VarianceFlags2["Invariant"] = 0] = "Invariant";
-        VarianceFlags2[VarianceFlags2["Covariant"] = 1] = "Covariant";
-        VarianceFlags2[VarianceFlags2["Contravariant"] = 2] = "Contravariant";
-        VarianceFlags2[VarianceFlags2["Bivariant"] = 3] = "Bivariant";
-        VarianceFlags2[VarianceFlags2["Independent"] = 4] = "Independent";
-        VarianceFlags2[VarianceFlags2["VarianceMask"] = 7] = "VarianceMask";
-        VarianceFlags2[VarianceFlags2["Unmeasurable"] = 8] = "Unmeasurable";
-        VarianceFlags2[VarianceFlags2["Unreliable"] = 16] = "Unreliable";
-        VarianceFlags2[VarianceFlags2["AllowsStructuralFallback"] = 24] = "AllowsStructuralFallback";
-        return VarianceFlags2;
-      })(VarianceFlags || {});
-      ElementFlags = /* @__PURE__ */ ((ElementFlags2) => {
-        ElementFlags2[ElementFlags2["Required"] = 1] = "Required";
-        ElementFlags2[ElementFlags2["Optional"] = 2] = "Optional";
-        ElementFlags2[ElementFlags2["Rest"] = 4] = "Rest";
-        ElementFlags2[ElementFlags2["Variadic"] = 8] = "Variadic";
-        ElementFlags2[ElementFlags2["Fixed"] = 3] = "Fixed";
-        ElementFlags2[ElementFlags2["Variable"] = 12] = "Variable";
-        ElementFlags2[ElementFlags2["NonRequired"] = 14] = "NonRequired";
-        ElementFlags2[ElementFlags2["NonRest"] = 11] = "NonRest";
-        return ElementFlags2;
-      })(ElementFlags || {});
-      AccessFlags = /* @__PURE__ */ ((AccessFlags2) => {
-        AccessFlags2[AccessFlags2["None"] = 0] = "None";
-        AccessFlags2[AccessFlags2["IncludeUndefined"] = 1] = "IncludeUndefined";
-        AccessFlags2[AccessFlags2["NoIndexSignatures"] = 2] = "NoIndexSignatures";
-        AccessFlags2[AccessFlags2["Writing"] = 4] = "Writing";
-        AccessFlags2[AccessFlags2["CacheSymbol"] = 8] = "CacheSymbol";
-        AccessFlags2[AccessFlags2["NoTupleBoundsCheck"] = 16] = "NoTupleBoundsCheck";
-        AccessFlags2[AccessFlags2["ExpressionPosition"] = 32] = "ExpressionPosition";
-        AccessFlags2[AccessFlags2["ReportDeprecated"] = 64] = "ReportDeprecated";
-        AccessFlags2[AccessFlags2["SuppressNoImplicitAnyError"] = 128] = "SuppressNoImplicitAnyError";
-        AccessFlags2[AccessFlags2["Contextual"] = 256] = "Contextual";
-        AccessFlags2[AccessFlags2["Persistent"] = 1 /* IncludeUndefined */] = "Persistent";
-        return AccessFlags2;
-      })(AccessFlags || {});
-      IndexFlags = /* @__PURE__ */ ((IndexFlags2) => {
-        IndexFlags2[IndexFlags2["None"] = 0] = "None";
-        IndexFlags2[IndexFlags2["StringsOnly"] = 1] = "StringsOnly";
-        IndexFlags2[IndexFlags2["NoIndexSignatures"] = 2] = "NoIndexSignatures";
-        IndexFlags2[IndexFlags2["NoReducibleCheck"] = 4] = "NoReducibleCheck";
-        return IndexFlags2;
-      })(IndexFlags || {});
-      JsxReferenceKind = /* @__PURE__ */ ((JsxReferenceKind2) => {
-        JsxReferenceKind2[JsxReferenceKind2["Component"] = 0] = "Component";
-        JsxReferenceKind2[JsxReferenceKind2["Function"] = 1] = "Function";
-        JsxReferenceKind2[JsxReferenceKind2["Mixed"] = 2] = "Mixed";
-        return JsxReferenceKind2;
-      })(JsxReferenceKind || {});
-      SignatureKind = /* @__PURE__ */ ((SignatureKind2) => {
-        SignatureKind2[SignatureKind2["Call"] = 0] = "Call";
-        SignatureKind2[SignatureKind2["Construct"] = 1] = "Construct";
-        return SignatureKind2;
-      })(SignatureKind || {});
-      SignatureFlags = /* @__PURE__ */ ((SignatureFlags5) => {
-        SignatureFlags5[SignatureFlags5["None"] = 0] = "None";
-        SignatureFlags5[SignatureFlags5["HasRestParameter"] = 1] = "HasRestParameter";
-        SignatureFlags5[SignatureFlags5["HasLiteralTypes"] = 2] = "HasLiteralTypes";
-        SignatureFlags5[SignatureFlags5["Abstract"] = 4] = "Abstract";
-        SignatureFlags5[SignatureFlags5["IsInnerCallChain"] = 8] = "IsInnerCallChain";
-        SignatureFlags5[SignatureFlags5["IsOuterCallChain"] = 16] = "IsOuterCallChain";
-        SignatureFlags5[SignatureFlags5["IsUntypedSignatureInJSFile"] = 32] = "IsUntypedSignatureInJSFile";
-        SignatureFlags5[SignatureFlags5["IsNonInferrable"] = 64] = "IsNonInferrable";
-        SignatureFlags5[SignatureFlags5["PropagatingFlags"] = 39] = "PropagatingFlags";
-        SignatureFlags5[SignatureFlags5["CallChainFlags"] = 24] = "CallChainFlags";
-        return SignatureFlags5;
-      })(SignatureFlags || {});
-      IndexKind = /* @__PURE__ */ ((IndexKind2) => {
-        IndexKind2[IndexKind2["String"] = 0] = "String";
-        IndexKind2[IndexKind2["Number"] = 1] = "Number";
-        return IndexKind2;
-      })(IndexKind || {});
-      TypeMapKind = /* @__PURE__ */ ((TypeMapKind2) => {
-        TypeMapKind2[TypeMapKind2["Simple"] = 0] = "Simple";
-        TypeMapKind2[TypeMapKind2["Array"] = 1] = "Array";
-        TypeMapKind2[TypeMapKind2["Deferred"] = 2] = "Deferred";
-        TypeMapKind2[TypeMapKind2["Function"] = 3] = "Function";
-        TypeMapKind2[TypeMapKind2["Composite"] = 4] = "Composite";
-        TypeMapKind2[TypeMapKind2["Merged"] = 5] = "Merged";
-        return TypeMapKind2;
-      })(TypeMapKind || {});
-      InferencePriority = /* @__PURE__ */ ((InferencePriority2) => {
-        InferencePriority2[InferencePriority2["None"] = 0] = "None";
-        InferencePriority2[InferencePriority2["NakedTypeVariable"] = 1] = "NakedTypeVariable";
-        InferencePriority2[InferencePriority2["SpeculativeTuple"] = 2] = "SpeculativeTuple";
-        InferencePriority2[InferencePriority2["SubstituteSource"] = 4] = "SubstituteSource";
-        InferencePriority2[InferencePriority2["HomomorphicMappedType"] = 8] = "HomomorphicMappedType";
-        InferencePriority2[InferencePriority2["PartialHomomorphicMappedType"] = 16] = "PartialHomomorphicMappedType";
-        InferencePriority2[InferencePriority2["MappedTypeConstraint"] = 32] = "MappedTypeConstraint";
-        InferencePriority2[InferencePriority2["ContravariantConditional"] = 64] = "ContravariantConditional";
-        InferencePriority2[InferencePriority2["ReturnType"] = 128] = "ReturnType";
-        InferencePriority2[InferencePriority2["LiteralKeyof"] = 256] = "LiteralKeyof";
-        InferencePriority2[InferencePriority2["NoConstraints"] = 512] = "NoConstraints";
-        InferencePriority2[InferencePriority2["AlwaysStrict"] = 1024] = "AlwaysStrict";
-        InferencePriority2[InferencePriority2["MaxValue"] = 2048] = "MaxValue";
-        InferencePriority2[InferencePriority2["PriorityImpliesCombination"] = 416] = "PriorityImpliesCombination";
-        InferencePriority2[InferencePriority2["Circularity"] = -1] = "Circularity";
-        return InferencePriority2;
-      })(InferencePriority || {});
-      InferenceFlags = /* @__PURE__ */ ((InferenceFlags2) => {
-        InferenceFlags2[InferenceFlags2["None"] = 0] = "None";
-        InferenceFlags2[InferenceFlags2["NoDefault"] = 1] = "NoDefault";
-        InferenceFlags2[InferenceFlags2["AnyDefault"] = 2] = "AnyDefault";
-        InferenceFlags2[InferenceFlags2["SkippedGenericFunction"] = 4] = "SkippedGenericFunction";
-        return InferenceFlags2;
-      })(InferenceFlags || {});
-      Ternary = /* @__PURE__ */ ((Ternary2) => {
-        Ternary2[Ternary2["False"] = 0] = "False";
-        Ternary2[Ternary2["Unknown"] = 1] = "Unknown";
-        Ternary2[Ternary2["Maybe"] = 3] = "Maybe";
-        Ternary2[Ternary2["True"] = -1] = "True";
-        return Ternary2;
-      })(Ternary || {});
-      AssignmentDeclarationKind = /* @__PURE__ */ ((AssignmentDeclarationKind2) => {
-        AssignmentDeclarationKind2[AssignmentDeclarationKind2["None"] = 0] = "None";
-        AssignmentDeclarationKind2[AssignmentDeclarationKind2["ExportsProperty"] = 1] = "ExportsProperty";
-        AssignmentDeclarationKind2[AssignmentDeclarationKind2["ModuleExports"] = 2] = "ModuleExports";
-        AssignmentDeclarationKind2[AssignmentDeclarationKind2["PrototypeProperty"] = 3] = "PrototypeProperty";
-        AssignmentDeclarationKind2[AssignmentDeclarationKind2["ThisProperty"] = 4] = "ThisProperty";
-        AssignmentDeclarationKind2[AssignmentDeclarationKind2["Property"] = 5] = "Property";
-        AssignmentDeclarationKind2[AssignmentDeclarationKind2["Prototype"] = 6] = "Prototype";
-        AssignmentDeclarationKind2[AssignmentDeclarationKind2["ObjectDefinePropertyValue"] = 7] = "ObjectDefinePropertyValue";
-        AssignmentDeclarationKind2[AssignmentDeclarationKind2["ObjectDefinePropertyExports"] = 8] = "ObjectDefinePropertyExports";
-        AssignmentDeclarationKind2[AssignmentDeclarationKind2["ObjectDefinePrototypeProperty"] = 9] = "ObjectDefinePrototypeProperty";
-        return AssignmentDeclarationKind2;
-      })(AssignmentDeclarationKind || {});
-      DiagnosticCategory = /* @__PURE__ */ ((DiagnosticCategory2) => {
-        DiagnosticCategory2[DiagnosticCategory2["Warning"] = 0] = "Warning";
-        DiagnosticCategory2[DiagnosticCategory2["Error"] = 1] = "Error";
-        DiagnosticCategory2[DiagnosticCategory2["Suggestion"] = 2] = "Suggestion";
-        DiagnosticCategory2[DiagnosticCategory2["Message"] = 3] = "Message";
-        return DiagnosticCategory2;
-      })(DiagnosticCategory || {});
-      ModuleResolutionKind = /* @__PURE__ */ ((ModuleResolutionKind2) => {
-        ModuleResolutionKind2[ModuleResolutionKind2["Classic"] = 1] = "Classic";
-        ModuleResolutionKind2[ModuleResolutionKind2["NodeJs"] = 2] = "NodeJs";
-        ModuleResolutionKind2[ModuleResolutionKind2["Node10"] = 2] = "Node10";
-        ModuleResolutionKind2[ModuleResolutionKind2["Node16"] = 3] = "Node16";
-        ModuleResolutionKind2[ModuleResolutionKind2["NodeNext"] = 99] = "NodeNext";
-        ModuleResolutionKind2[ModuleResolutionKind2["Bundler"] = 100] = "Bundler";
-        return ModuleResolutionKind2;
-      })(ModuleResolutionKind || {});
-      ModuleDetectionKind = /* @__PURE__ */ ((ModuleDetectionKind2) => {
-        ModuleDetectionKind2[ModuleDetectionKind2["Legacy"] = 1] = "Legacy";
-        ModuleDetectionKind2[ModuleDetectionKind2["Auto"] = 2] = "Auto";
-        ModuleDetectionKind2[ModuleDetectionKind2["Force"] = 3] = "Force";
-        return ModuleDetectionKind2;
-      })(ModuleDetectionKind || {});
-      WatchFileKind = /* @__PURE__ */ ((WatchFileKind2) => {
-        WatchFileKind2[WatchFileKind2["FixedPollingInterval"] = 0] = "FixedPollingInterval";
-        WatchFileKind2[WatchFileKind2["PriorityPollingInterval"] = 1] = "PriorityPollingInterval";
-        WatchFileKind2[WatchFileKind2["DynamicPriorityPolling"] = 2] = "DynamicPriorityPolling";
-        WatchFileKind2[WatchFileKind2["FixedChunkSizePolling"] = 3] = "FixedChunkSizePolling";
-        WatchFileKind2[WatchFileKind2["UseFsEvents"] = 4] = "UseFsEvents";
-        WatchFileKind2[WatchFileKind2["UseFsEventsOnParentDirectory"] = 5] = "UseFsEventsOnParentDirectory";
-        return WatchFileKind2;
-      })(WatchFileKind || {});
-      WatchDirectoryKind = /* @__PURE__ */ ((WatchDirectoryKind2) => {
-        WatchDirectoryKind2[WatchDirectoryKind2["UseFsEvents"] = 0] = "UseFsEvents";
-        WatchDirectoryKind2[WatchDirectoryKind2["FixedPollingInterval"] = 1] = "FixedPollingInterval";
-        WatchDirectoryKind2[WatchDirectoryKind2["DynamicPriorityPolling"] = 2] = "DynamicPriorityPolling";
-        WatchDirectoryKind2[WatchDirectoryKind2["FixedChunkSizePolling"] = 3] = "FixedChunkSizePolling";
-        return WatchDirectoryKind2;
-      })(WatchDirectoryKind || {});
-      PollingWatchKind = /* @__PURE__ */ ((PollingWatchKind2) => {
-        PollingWatchKind2[PollingWatchKind2["FixedInterval"] = 0] = "FixedInterval";
-        PollingWatchKind2[PollingWatchKind2["PriorityInterval"] = 1] = "PriorityInterval";
-        PollingWatchKind2[PollingWatchKind2["DynamicPriority"] = 2] = "DynamicPriority";
-        PollingWatchKind2[PollingWatchKind2["FixedChunkSize"] = 3] = "FixedChunkSize";
-        return PollingWatchKind2;
-      })(PollingWatchKind || {});
-      ModuleKind = /* @__PURE__ */ ((ModuleKind2) => {
-        ModuleKind2[ModuleKind2["None"] = 0] = "None";
-        ModuleKind2[ModuleKind2["CommonJS"] = 1] = "CommonJS";
-        ModuleKind2[ModuleKind2["AMD"] = 2] = "AMD";
-        ModuleKind2[ModuleKind2["UMD"] = 3] = "UMD";
-        ModuleKind2[ModuleKind2["System"] = 4] = "System";
-        ModuleKind2[ModuleKind2["ES2015"] = 5] = "ES2015";
-        ModuleKind2[ModuleKind2["ES2020"] = 6] = "ES2020";
-        ModuleKind2[ModuleKind2["ES2022"] = 7] = "ES2022";
-        ModuleKind2[ModuleKind2["ESNext"] = 99] = "ESNext";
-        ModuleKind2[ModuleKind2["Node16"] = 100] = "Node16";
-        ModuleKind2[ModuleKind2["NodeNext"] = 199] = "NodeNext";
-        return ModuleKind2;
-      })(ModuleKind || {});
-      JsxEmit = /* @__PURE__ */ ((JsxEmit2) => {
-        JsxEmit2[JsxEmit2["None"] = 0] = "None";
-        JsxEmit2[JsxEmit2["Preserve"] = 1] = "Preserve";
-        JsxEmit2[JsxEmit2["React"] = 2] = "React";
-        JsxEmit2[JsxEmit2["ReactNative"] = 3] = "ReactNative";
-        JsxEmit2[JsxEmit2["ReactJSX"] = 4] = "ReactJSX";
-        JsxEmit2[JsxEmit2["ReactJSXDev"] = 5] = "ReactJSXDev";
-        return JsxEmit2;
-      })(JsxEmit || {});
-      ImportsNotUsedAsValues = /* @__PURE__ */ ((ImportsNotUsedAsValues2) => {
-        ImportsNotUsedAsValues2[ImportsNotUsedAsValues2["Remove"] = 0] = "Remove";
-        ImportsNotUsedAsValues2[ImportsNotUsedAsValues2["Preserve"] = 1] = "Preserve";
-        ImportsNotUsedAsValues2[ImportsNotUsedAsValues2["Error"] = 2] = "Error";
-        return ImportsNotUsedAsValues2;
-      })(ImportsNotUsedAsValues || {});
-      NewLineKind = /* @__PURE__ */ ((NewLineKind2) => {
-        NewLineKind2[NewLineKind2["CarriageReturnLineFeed"] = 0] = "CarriageReturnLineFeed";
-        NewLineKind2[NewLineKind2["LineFeed"] = 1] = "LineFeed";
-        return NewLineKind2;
-      })(NewLineKind || {});
-      ScriptKind = /* @__PURE__ */ ((ScriptKind5) => {
-        ScriptKind5[ScriptKind5["Unknown"] = 0] = "Unknown";
-        ScriptKind5[ScriptKind5["JS"] = 1] = "JS";
-        ScriptKind5[ScriptKind5["JSX"] = 2] = "JSX";
-        ScriptKind5[ScriptKind5["TS"] = 3] = "TS";
-        ScriptKind5[ScriptKind5["TSX"] = 4] = "TSX";
-        ScriptKind5[ScriptKind5["External"] = 5] = "External";
-        ScriptKind5[ScriptKind5["JSON"] = 6] = "JSON";
-        ScriptKind5[ScriptKind5["Deferred"] = 7] = "Deferred";
-        return ScriptKind5;
-      })(ScriptKind || {});
-      ScriptTarget = /* @__PURE__ */ ((ScriptTarget10) => {
-        ScriptTarget10[ScriptTarget10["ES3"] = 0] = "ES3";
-        ScriptTarget10[ScriptTarget10["ES5"] = 1] = "ES5";
-        ScriptTarget10[ScriptTarget10["ES2015"] = 2] = "ES2015";
-        ScriptTarget10[ScriptTarget10["ES2016"] = 3] = "ES2016";
-        ScriptTarget10[ScriptTarget10["ES2017"] = 4] = "ES2017";
-        ScriptTarget10[ScriptTarget10["ES2018"] = 5] = "ES2018";
-        ScriptTarget10[ScriptTarget10["ES2019"] = 6] = "ES2019";
-        ScriptTarget10[ScriptTarget10["ES2020"] = 7] = "ES2020";
-        ScriptTarget10[ScriptTarget10["ES2021"] = 8] = "ES2021";
-        ScriptTarget10[ScriptTarget10["ES2022"] = 9] = "ES2022";
-        ScriptTarget10[ScriptTarget10["ESNext"] = 99] = "ESNext";
-        ScriptTarget10[ScriptTarget10["JSON"] = 100] = "JSON";
-        ScriptTarget10[ScriptTarget10["Latest"] = 99 /* ESNext */] = "Latest";
-        return ScriptTarget10;
-      })(ScriptTarget || {});
-      LanguageVariant = /* @__PURE__ */ ((LanguageVariant4) => {
-        LanguageVariant4[LanguageVariant4["Standard"] = 0] = "Standard";
-        LanguageVariant4[LanguageVariant4["JSX"] = 1] = "JSX";
-        return LanguageVariant4;
-      })(LanguageVariant || {});
-      WatchDirectoryFlags = /* @__PURE__ */ ((WatchDirectoryFlags3) => {
-        WatchDirectoryFlags3[WatchDirectoryFlags3["None"] = 0] = "None";
-        WatchDirectoryFlags3[WatchDirectoryFlags3["Recursive"] = 1] = "Recursive";
-        return WatchDirectoryFlags3;
-      })(WatchDirectoryFlags || {});
-      CharacterCodes = /* @__PURE__ */ ((CharacterCodes2) => {
-        CharacterCodes2[CharacterCodes2["nullCharacter"] = 0] = "nullCharacter";
-        CharacterCodes2[CharacterCodes2["maxAsciiCharacter"] = 127] = "maxAsciiCharacter";
-        CharacterCodes2[CharacterCodes2["lineFeed"] = 10] = "lineFeed";
-        CharacterCodes2[CharacterCodes2["carriageReturn"] = 13] = "carriageReturn";
-        CharacterCodes2[CharacterCodes2["lineSeparator"] = 8232] = "lineSeparator";
-        CharacterCodes2[CharacterCodes2["paragraphSeparator"] = 8233] = "paragraphSeparator";
-        CharacterCodes2[CharacterCodes2["nextLine"] = 133] = "nextLine";
-        CharacterCodes2[CharacterCodes2["space"] = 32] = "space";
-        CharacterCodes2[CharacterCodes2["nonBreakingSpace"] = 160] = "nonBreakingSpace";
-        CharacterCodes2[CharacterCodes2["enQuad"] = 8192] = "enQuad";
-        CharacterCodes2[CharacterCodes2["emQuad"] = 8193] = "emQuad";
-        CharacterCodes2[CharacterCodes2["enSpace"] = 8194] = "enSpace";
-        CharacterCodes2[CharacterCodes2["emSpace"] = 8195] = "emSpace";
-        CharacterCodes2[CharacterCodes2["threePerEmSpace"] = 8196] = "threePerEmSpace";
-        CharacterCodes2[CharacterCodes2["fourPerEmSpace"] = 8197] = "fourPerEmSpace";
-        CharacterCodes2[CharacterCodes2["sixPerEmSpace"] = 8198] = "sixPerEmSpace";
-        CharacterCodes2[CharacterCodes2["figureSpace"] = 8199] = "figureSpace";
-        CharacterCodes2[CharacterCodes2["punctuationSpace"] = 8200] = "punctuationSpace";
-        CharacterCodes2[CharacterCodes2["thinSpace"] = 8201] = "thinSpace";
-        CharacterCodes2[CharacterCodes2["hairSpace"] = 8202] = "hairSpace";
-        CharacterCodes2[CharacterCodes2["zeroWidthSpace"] = 8203] = "zeroWidthSpace";
-        CharacterCodes2[CharacterCodes2["narrowNoBreakSpace"] = 8239] = "narrowNoBreakSpace";
-        CharacterCodes2[CharacterCodes2["ideographicSpace"] = 12288] = "ideographicSpace";
-        CharacterCodes2[CharacterCodes2["mathematicalSpace"] = 8287] = "mathematicalSpace";
-        CharacterCodes2[CharacterCodes2["ogham"] = 5760] = "ogham";
-        CharacterCodes2[CharacterCodes2["replacementCharacter"] = 65533] = "replacementCharacter";
-        CharacterCodes2[CharacterCodes2["_"] = 95] = "_";
-        CharacterCodes2[CharacterCodes2["$"] = 36] = "$";
-        CharacterCodes2[CharacterCodes2["_0"] = 48] = "_0";
-        CharacterCodes2[CharacterCodes2["_1"] = 49] = "_1";
-        CharacterCodes2[CharacterCodes2["_2"] = 50] = "_2";
-        CharacterCodes2[CharacterCodes2["_3"] = 51] = "_3";
-        CharacterCodes2[CharacterCodes2["_4"] = 52] = "_4";
-        CharacterCodes2[CharacterCodes2["_5"] = 53] = "_5";
-        CharacterCodes2[CharacterCodes2["_6"] = 54] = "_6";
-        CharacterCodes2[CharacterCodes2["_7"] = 55] = "_7";
-        CharacterCodes2[CharacterCodes2["_8"] = 56] = "_8";
-        CharacterCodes2[CharacterCodes2["_9"] = 57] = "_9";
-        CharacterCodes2[CharacterCodes2["a"] = 97] = "a";
-        CharacterCodes2[CharacterCodes2["b"] = 98] = "b";
-        CharacterCodes2[CharacterCodes2["c"] = 99] = "c";
-        CharacterCodes2[CharacterCodes2["d"] = 100] = "d";
-        CharacterCodes2[CharacterCodes2["e"] = 101] = "e";
-        CharacterCodes2[CharacterCodes2["f"] = 102] = "f";
-        CharacterCodes2[CharacterCodes2["g"] = 103] = "g";
-        CharacterCodes2[CharacterCodes2["h"] = 104] = "h";
-        CharacterCodes2[CharacterCodes2["i"] = 105] = "i";
-        CharacterCodes2[CharacterCodes2["j"] = 106] = "j";
-        CharacterCodes2[CharacterCodes2["k"] = 107] = "k";
-        CharacterCodes2[CharacterCodes2["l"] = 108] = "l";
-        CharacterCodes2[CharacterCodes2["m"] = 109] = "m";
-        CharacterCodes2[CharacterCodes2["n"] = 110] = "n";
-        CharacterCodes2[CharacterCodes2["o"] = 111] = "o";
-        CharacterCodes2[CharacterCodes2["p"] = 112] = "p";
-        CharacterCodes2[CharacterCodes2["q"] = 113] = "q";
-        CharacterCodes2[CharacterCodes2["r"] = 114] = "r";
-        CharacterCodes2[CharacterCodes2["s"] = 115] = "s";
-        CharacterCodes2[CharacterCodes2["t"] = 116] = "t";
-        CharacterCodes2[CharacterCodes2["u"] = 117] = "u";
-        CharacterCodes2[CharacterCodes2["v"] = 118] = "v";
-        CharacterCodes2[CharacterCodes2["w"] = 119] = "w";
-        CharacterCodes2[CharacterCodes2["x"] = 120] = "x";
-        CharacterCodes2[CharacterCodes2["y"] = 121] = "y";
-        CharacterCodes2[CharacterCodes2["z"] = 122] = "z";
-        CharacterCodes2[CharacterCodes2["A"] = 65] = "A";
-        CharacterCodes2[CharacterCodes2["B"] = 66] = "B";
-        CharacterCodes2[CharacterCodes2["C"] = 67] = "C";
-        CharacterCodes2[CharacterCodes2["D"] = 68] = "D";
-        CharacterCodes2[CharacterCodes2["E"] = 69] = "E";
-        CharacterCodes2[CharacterCodes2["F"] = 70] = "F";
-        CharacterCodes2[CharacterCodes2["G"] = 71] = "G";
-        CharacterCodes2[CharacterCodes2["H"] = 72] = "H";
-        CharacterCodes2[CharacterCodes2["I"] = 73] = "I";
-        CharacterCodes2[CharacterCodes2["J"] = 74] = "J";
-        CharacterCodes2[CharacterCodes2["K"] = 75] = "K";
-        CharacterCodes2[CharacterCodes2["L"] = 76] = "L";
-        CharacterCodes2[CharacterCodes2["M"] = 77] = "M";
-        CharacterCodes2[CharacterCodes2["N"] = 78] = "N";
-        CharacterCodes2[CharacterCodes2["O"] = 79] = "O";
-        CharacterCodes2[CharacterCodes2["P"] = 80] = "P";
-        CharacterCodes2[CharacterCodes2["Q"] = 81] = "Q";
-        CharacterCodes2[CharacterCodes2["R"] = 82] = "R";
-        CharacterCodes2[CharacterCodes2["S"] = 83] = "S";
-        CharacterCodes2[CharacterCodes2["T"] = 84] = "T";
-        CharacterCodes2[CharacterCodes2["U"] = 85] = "U";
-        CharacterCodes2[CharacterCodes2["V"] = 86] = "V";
-        CharacterCodes2[CharacterCodes2["W"] = 87] = "W";
-        CharacterCodes2[CharacterCodes2["X"] = 88] = "X";
-        CharacterCodes2[CharacterCodes2["Y"] = 89] = "Y";
-        CharacterCodes2[CharacterCodes2["Z"] = 90] = "Z";
-        CharacterCodes2[CharacterCodes2["ampersand"] = 38] = "ampersand";
-        CharacterCodes2[CharacterCodes2["asterisk"] = 42] = "asterisk";
-        CharacterCodes2[CharacterCodes2["at"] = 64] = "at";
-        CharacterCodes2[CharacterCodes2["backslash"] = 92] = "backslash";
-        CharacterCodes2[CharacterCodes2["backtick"] = 96] = "backtick";
-        CharacterCodes2[CharacterCodes2["bar"] = 124] = "bar";
-        CharacterCodes2[CharacterCodes2["caret"] = 94] = "caret";
-        CharacterCodes2[CharacterCodes2["closeBrace"] = 125] = "closeBrace";
-        CharacterCodes2[CharacterCodes2["closeBracket"] = 93] = "closeBracket";
-        CharacterCodes2[CharacterCodes2["closeParen"] = 41] = "closeParen";
-        CharacterCodes2[CharacterCodes2["colon"] = 58] = "colon";
-        CharacterCodes2[CharacterCodes2["comma"] = 44] = "comma";
-        CharacterCodes2[CharacterCodes2["dot"] = 46] = "dot";
-        CharacterCodes2[CharacterCodes2["doubleQuote"] = 34] = "doubleQuote";
-        CharacterCodes2[CharacterCodes2["equals"] = 61] = "equals";
-        CharacterCodes2[CharacterCodes2["exclamation"] = 33] = "exclamation";
-        CharacterCodes2[CharacterCodes2["greaterThan"] = 62] = "greaterThan";
-        CharacterCodes2[CharacterCodes2["hash"] = 35] = "hash";
-        CharacterCodes2[CharacterCodes2["lessThan"] = 60] = "lessThan";
-        CharacterCodes2[CharacterCodes2["minus"] = 45] = "minus";
-        CharacterCodes2[CharacterCodes2["openBrace"] = 123] = "openBrace";
-        CharacterCodes2[CharacterCodes2["openBracket"] = 91] = "openBracket";
-        CharacterCodes2[CharacterCodes2["openParen"] = 40] = "openParen";
-        CharacterCodes2[CharacterCodes2["percent"] = 37] = "percent";
-        CharacterCodes2[CharacterCodes2["plus"] = 43] = "plus";
-        CharacterCodes2[CharacterCodes2["question"] = 63] = "question";
-        CharacterCodes2[CharacterCodes2["semicolon"] = 59] = "semicolon";
-        CharacterCodes2[CharacterCodes2["singleQuote"] = 39] = "singleQuote";
-        CharacterCodes2[CharacterCodes2["slash"] = 47] = "slash";
-        CharacterCodes2[CharacterCodes2["tilde"] = 126] = "tilde";
-        CharacterCodes2[CharacterCodes2["backspace"] = 8] = "backspace";
-        CharacterCodes2[CharacterCodes2["formFeed"] = 12] = "formFeed";
-        CharacterCodes2[CharacterCodes2["byteOrderMark"] = 65279] = "byteOrderMark";
-        CharacterCodes2[CharacterCodes2["tab"] = 9] = "tab";
-        CharacterCodes2[CharacterCodes2["verticalTab"] = 11] = "verticalTab";
-        return CharacterCodes2;
-      })(CharacterCodes || {});
-      Extension = /* @__PURE__ */ ((Extension2) => {
-        Extension2["Ts"] = ".ts";
-        Extension2["Tsx"] = ".tsx";
-        Extension2["Dts"] = ".d.ts";
-        Extension2["Js"] = ".js";
-        Extension2["Jsx"] = ".jsx";
-        Extension2["Json"] = ".json";
-        Extension2["TsBuildInfo"] = ".tsbuildinfo";
-        Extension2["Mjs"] = ".mjs";
-        Extension2["Mts"] = ".mts";
-        Extension2["Dmts"] = ".d.mts";
-        Extension2["Cjs"] = ".cjs";
-        Extension2["Cts"] = ".cts";
-        Extension2["Dcts"] = ".d.cts";
-        return Extension2;
-      })(Extension || {});
-      TransformFlags = /* @__PURE__ */ ((TransformFlags3) => {
-        TransformFlags3[TransformFlags3["None"] = 0] = "None";
-        TransformFlags3[TransformFlags3["ContainsTypeScript"] = 1] = "ContainsTypeScript";
-        TransformFlags3[TransformFlags3["ContainsJsx"] = 2] = "ContainsJsx";
-        TransformFlags3[TransformFlags3["ContainsESNext"] = 4] = "ContainsESNext";
-        TransformFlags3[TransformFlags3["ContainsES2022"] = 8] = "ContainsES2022";
-        TransformFlags3[TransformFlags3["ContainsES2021"] = 16] = "ContainsES2021";
-        TransformFlags3[TransformFlags3["ContainsES2020"] = 32] = "ContainsES2020";
-        TransformFlags3[TransformFlags3["ContainsES2019"] = 64] = "ContainsES2019";
-        TransformFlags3[TransformFlags3["ContainsES2018"] = 128] = "ContainsES2018";
-        TransformFlags3[TransformFlags3["ContainsES2017"] = 256] = "ContainsES2017";
-        TransformFlags3[TransformFlags3["ContainsES2016"] = 512] = "ContainsES2016";
-        TransformFlags3[TransformFlags3["ContainsES2015"] = 1024] = "ContainsES2015";
-        TransformFlags3[TransformFlags3["ContainsGenerator"] = 2048] = "ContainsGenerator";
-        TransformFlags3[TransformFlags3["ContainsDestructuringAssignment"] = 4096] = "ContainsDestructuringAssignment";
-        TransformFlags3[TransformFlags3["ContainsTypeScriptClassSyntax"] = 8192] = "ContainsTypeScriptClassSyntax";
-        TransformFlags3[TransformFlags3["ContainsLexicalThis"] = 16384] = "ContainsLexicalThis";
-        TransformFlags3[TransformFlags3["ContainsRestOrSpread"] = 32768] = "ContainsRestOrSpread";
-        TransformFlags3[TransformFlags3["ContainsObjectRestOrSpread"] = 65536] = "ContainsObjectRestOrSpread";
-        TransformFlags3[TransformFlags3["ContainsComputedPropertyName"] = 131072] = "ContainsComputedPropertyName";
-        TransformFlags3[TransformFlags3["ContainsBlockScopedBinding"] = 262144] = "ContainsBlockScopedBinding";
-        TransformFlags3[TransformFlags3["ContainsBindingPattern"] = 524288] = "ContainsBindingPattern";
-        TransformFlags3[TransformFlags3["ContainsYield"] = 1048576] = "ContainsYield";
-        TransformFlags3[TransformFlags3["ContainsAwait"] = 2097152] = "ContainsAwait";
-        TransformFlags3[TransformFlags3["ContainsHoistedDeclarationOrCompletion"] = 4194304] = "ContainsHoistedDeclarationOrCompletion";
-        TransformFlags3[TransformFlags3["ContainsDynamicImport"] = 8388608] = "ContainsDynamicImport";
-        TransformFlags3[TransformFlags3["ContainsClassFields"] = 16777216] = "ContainsClassFields";
-        TransformFlags3[TransformFlags3["ContainsDecorators"] = 33554432] = "ContainsDecorators";
-        TransformFlags3[TransformFlags3["ContainsPossibleTopLevelAwait"] = 67108864] = "ContainsPossibleTopLevelAwait";
-        TransformFlags3[TransformFlags3["ContainsLexicalSuper"] = 134217728] = "ContainsLexicalSuper";
-        TransformFlags3[TransformFlags3["ContainsUpdateExpressionForIdentifier"] = 268435456] = "ContainsUpdateExpressionForIdentifier";
-        TransformFlags3[TransformFlags3["ContainsPrivateIdentifierInExpression"] = 536870912] = "ContainsPrivateIdentifierInExpression";
-        TransformFlags3[TransformFlags3["HasComputedFlags"] = -2147483648] = "HasComputedFlags";
-        TransformFlags3[TransformFlags3["AssertTypeScript"] = 1 /* ContainsTypeScript */] = "AssertTypeScript";
-        TransformFlags3[TransformFlags3["AssertJsx"] = 2 /* ContainsJsx */] = "AssertJsx";
-        TransformFlags3[TransformFlags3["AssertESNext"] = 4 /* ContainsESNext */] = "AssertESNext";
-        TransformFlags3[TransformFlags3["AssertES2022"] = 8 /* ContainsES2022 */] = "AssertES2022";
-        TransformFlags3[TransformFlags3["AssertES2021"] = 16 /* ContainsES2021 */] = "AssertES2021";
-        TransformFlags3[TransformFlags3["AssertES2020"] = 32 /* ContainsES2020 */] = "AssertES2020";
-        TransformFlags3[TransformFlags3["AssertES2019"] = 64 /* ContainsES2019 */] = "AssertES2019";
-        TransformFlags3[TransformFlags3["AssertES2018"] = 128 /* ContainsES2018 */] = "AssertES2018";
-        TransformFlags3[TransformFlags3["AssertES2017"] = 256 /* ContainsES2017 */] = "AssertES2017";
-        TransformFlags3[TransformFlags3["AssertES2016"] = 512 /* ContainsES2016 */] = "AssertES2016";
-        TransformFlags3[TransformFlags3["AssertES2015"] = 1024 /* ContainsES2015 */] = "AssertES2015";
-        TransformFlags3[TransformFlags3["AssertGenerator"] = 2048 /* ContainsGenerator */] = "AssertGenerator";
-        TransformFlags3[TransformFlags3["AssertDestructuringAssignment"] = 4096 /* ContainsDestructuringAssignment */] = "AssertDestructuringAssignment";
-        TransformFlags3[TransformFlags3["OuterExpressionExcludes"] = -2147483648 /* HasComputedFlags */] = "OuterExpressionExcludes";
-        TransformFlags3[TransformFlags3["PropertyAccessExcludes"] = -2147483648 /* OuterExpressionExcludes */] = "PropertyAccessExcludes";
-        TransformFlags3[TransformFlags3["NodeExcludes"] = -2147483648 /* PropertyAccessExcludes */] = "NodeExcludes";
-        TransformFlags3[TransformFlags3["ArrowFunctionExcludes"] = -2072174592] = "ArrowFunctionExcludes";
-        TransformFlags3[TransformFlags3["FunctionExcludes"] = -1937940480] = "FunctionExcludes";
-        TransformFlags3[TransformFlags3["ConstructorExcludes"] = -1937948672] = "ConstructorExcludes";
-        TransformFlags3[TransformFlags3["MethodOrAccessorExcludes"] = -2005057536] = "MethodOrAccessorExcludes";
-        TransformFlags3[TransformFlags3["PropertyExcludes"] = -2013249536] = "PropertyExcludes";
-        TransformFlags3[TransformFlags3["ClassExcludes"] = -2147344384] = "ClassExcludes";
-        TransformFlags3[TransformFlags3["ModuleExcludes"] = -1941676032] = "ModuleExcludes";
-        TransformFlags3[TransformFlags3["TypeExcludes"] = -2] = "TypeExcludes";
-        TransformFlags3[TransformFlags3["ObjectLiteralExcludes"] = -2147278848] = "ObjectLiteralExcludes";
-        TransformFlags3[TransformFlags3["ArrayLiteralOrCallOrNewExcludes"] = -2147450880] = "ArrayLiteralOrCallOrNewExcludes";
-        TransformFlags3[TransformFlags3["VariableDeclarationListExcludes"] = -2146893824] = "VariableDeclarationListExcludes";
-        TransformFlags3[TransformFlags3["ParameterExcludes"] = -2147483648 /* NodeExcludes */] = "ParameterExcludes";
-        TransformFlags3[TransformFlags3["CatchClauseExcludes"] = -2147418112] = "CatchClauseExcludes";
-        TransformFlags3[TransformFlags3["BindingPatternExcludes"] = -2147450880] = "BindingPatternExcludes";
-        TransformFlags3[TransformFlags3["ContainsLexicalThisOrSuper"] = 134234112] = "ContainsLexicalThisOrSuper";
-        TransformFlags3[TransformFlags3["PropertyNamePropagatingFlags"] = 134234112] = "PropertyNamePropagatingFlags";
-        return TransformFlags3;
-      })(TransformFlags || {});
-      SnippetKind = /* @__PURE__ */ ((SnippetKind3) => {
-        SnippetKind3[SnippetKind3["TabStop"] = 0] = "TabStop";
-        SnippetKind3[SnippetKind3["Placeholder"] = 1] = "Placeholder";
-        SnippetKind3[SnippetKind3["Choice"] = 2] = "Choice";
-        SnippetKind3[SnippetKind3["Variable"] = 3] = "Variable";
-        return SnippetKind3;
-      })(SnippetKind || {});
-      EmitFlags = /* @__PURE__ */ ((EmitFlags3) => {
-        EmitFlags3[EmitFlags3["None"] = 0] = "None";
-        EmitFlags3[EmitFlags3["SingleLine"] = 1] = "SingleLine";
-        EmitFlags3[EmitFlags3["MultiLine"] = 2] = "MultiLine";
-        EmitFlags3[EmitFlags3["AdviseOnEmitNode"] = 4] = "AdviseOnEmitNode";
-        EmitFlags3[EmitFlags3["NoSubstitution"] = 8] = "NoSubstitution";
-        EmitFlags3[EmitFlags3["CapturesThis"] = 16] = "CapturesThis";
-        EmitFlags3[EmitFlags3["NoLeadingSourceMap"] = 32] = "NoLeadingSourceMap";
-        EmitFlags3[EmitFlags3["NoTrailingSourceMap"] = 64] = "NoTrailingSourceMap";
-        EmitFlags3[EmitFlags3["NoSourceMap"] = 96] = "NoSourceMap";
-        EmitFlags3[EmitFlags3["NoNestedSourceMaps"] = 128] = "NoNestedSourceMaps";
-        EmitFlags3[EmitFlags3["NoTokenLeadingSourceMaps"] = 256] = "NoTokenLeadingSourceMaps";
-        EmitFlags3[EmitFlags3["NoTokenTrailingSourceMaps"] = 512] = "NoTokenTrailingSourceMaps";
-        EmitFlags3[EmitFlags3["NoTokenSourceMaps"] = 768] = "NoTokenSourceMaps";
-        EmitFlags3[EmitFlags3["NoLeadingComments"] = 1024] = "NoLeadingComments";
-        EmitFlags3[EmitFlags3["NoTrailingComments"] = 2048] = "NoTrailingComments";
-        EmitFlags3[EmitFlags3["NoComments"] = 3072] = "NoComments";
-        EmitFlags3[EmitFlags3["NoNestedComments"] = 4096] = "NoNestedComments";
-        EmitFlags3[EmitFlags3["HelperName"] = 8192] = "HelperName";
-        EmitFlags3[EmitFlags3["ExportName"] = 16384] = "ExportName";
-        EmitFlags3[EmitFlags3["LocalName"] = 32768] = "LocalName";
-        EmitFlags3[EmitFlags3["InternalName"] = 65536] = "InternalName";
-        EmitFlags3[EmitFlags3["Indented"] = 131072] = "Indented";
-        EmitFlags3[EmitFlags3["NoIndentation"] = 262144] = "NoIndentation";
-        EmitFlags3[EmitFlags3["AsyncFunctionBody"] = 524288] = "AsyncFunctionBody";
-        EmitFlags3[EmitFlags3["ReuseTempVariableScope"] = 1048576] = "ReuseTempVariableScope";
-        EmitFlags3[EmitFlags3["CustomPrologue"] = 2097152] = "CustomPrologue";
-        EmitFlags3[EmitFlags3["NoHoisting"] = 4194304] = "NoHoisting";
-        EmitFlags3[EmitFlags3["Iterator"] = 8388608] = "Iterator";
-        EmitFlags3[EmitFlags3["NoAsciiEscaping"] = 16777216] = "NoAsciiEscaping";
-        return EmitFlags3;
-      })(EmitFlags || {});
-      InternalEmitFlags = /* @__PURE__ */ ((InternalEmitFlags3) => {
-        InternalEmitFlags3[InternalEmitFlags3["None"] = 0] = "None";
-        InternalEmitFlags3[InternalEmitFlags3["TypeScriptClassWrapper"] = 1] = "TypeScriptClassWrapper";
-        InternalEmitFlags3[InternalEmitFlags3["NeverApplyImportHelper"] = 2] = "NeverApplyImportHelper";
-        InternalEmitFlags3[InternalEmitFlags3["IgnoreSourceNewlines"] = 4] = "IgnoreSourceNewlines";
-        InternalEmitFlags3[InternalEmitFlags3["Immutable"] = 8] = "Immutable";
-        InternalEmitFlags3[InternalEmitFlags3["IndirectCall"] = 16] = "IndirectCall";
-        InternalEmitFlags3[InternalEmitFlags3["TransformPrivateStaticElements"] = 32] = "TransformPrivateStaticElements";
-        return InternalEmitFlags3;
-      })(InternalEmitFlags || {});
-      ExternalEmitHelpers = /* @__PURE__ */ ((ExternalEmitHelpers2) => {
-        ExternalEmitHelpers2[ExternalEmitHelpers2["Extends"] = 1] = "Extends";
-        ExternalEmitHelpers2[ExternalEmitHelpers2["Assign"] = 2] = "Assign";
-        ExternalEmitHelpers2[ExternalEmitHelpers2["Rest"] = 4] = "Rest";
-        ExternalEmitHelpers2[ExternalEmitHelpers2["Decorate"] = 8] = "Decorate";
-        ExternalEmitHelpers2[ExternalEmitHelpers2["ESDecorateAndRunInitializers"] = 8 /* Decorate */] = "ESDecorateAndRunInitializers";
-        ExternalEmitHelpers2[ExternalEmitHelpers2["Metadata"] = 16] = "Metadata";
-        ExternalEmitHelpers2[ExternalEmitHelpers2["Param"] = 32] = "Param";
-        ExternalEmitHelpers2[ExternalEmitHelpers2["Awaiter"] = 64] = "Awaiter";
-        ExternalEmitHelpers2[ExternalEmitHelpers2["Generator"] = 128] = "Generator";
-        ExternalEmitHelpers2[ExternalEmitHelpers2["Values"] = 256] = "Values";
-        ExternalEmitHelpers2[ExternalEmitHelpers2["Read"] = 512] = "Read";
-        ExternalEmitHelpers2[ExternalEmitHelpers2["SpreadArray"] = 1024] = "SpreadArray";
-        ExternalEmitHelpers2[ExternalEmitHelpers2["Await"] = 2048] = "Await";
-        ExternalEmitHelpers2[ExternalEmitHelpers2["AsyncGenerator"] = 4096] = "AsyncGenerator";
-        ExternalEmitHelpers2[ExternalEmitHelpers2["AsyncDelegator"] = 8192] = "AsyncDelegator";
-        ExternalEmitHelpers2[ExternalEmitHelpers2["AsyncValues"] = 16384] = "AsyncValues";
-        ExternalEmitHelpers2[ExternalEmitHelpers2["ExportStar"] = 32768] = "ExportStar";
-        ExternalEmitHelpers2[ExternalEmitHelpers2["ImportStar"] = 65536] = "ImportStar";
-        ExternalEmitHelpers2[ExternalEmitHelpers2["ImportDefault"] = 131072] = "ImportDefault";
-        ExternalEmitHelpers2[ExternalEmitHelpers2["MakeTemplateObject"] = 262144] = "MakeTemplateObject";
-        ExternalEmitHelpers2[ExternalEmitHelpers2["ClassPrivateFieldGet"] = 524288] = "ClassPrivateFieldGet";
-        ExternalEmitHelpers2[ExternalEmitHelpers2["ClassPrivateFieldSet"] = 1048576] = "ClassPrivateFieldSet";
-        ExternalEmitHelpers2[ExternalEmitHelpers2["ClassPrivateFieldIn"] = 2097152] = "ClassPrivateFieldIn";
-        ExternalEmitHelpers2[ExternalEmitHelpers2["CreateBinding"] = 4194304] = "CreateBinding";
-        ExternalEmitHelpers2[ExternalEmitHelpers2["SetFunctionName"] = 8388608] = "SetFunctionName";
-        ExternalEmitHelpers2[ExternalEmitHelpers2["PropKey"] = 16777216] = "PropKey";
-        ExternalEmitHelpers2[ExternalEmitHelpers2["FirstEmitHelper"] = 1 /* Extends */] = "FirstEmitHelper";
-        ExternalEmitHelpers2[ExternalEmitHelpers2["LastEmitHelper"] = 16777216 /* PropKey */] = "LastEmitHelper";
-        ExternalEmitHelpers2[ExternalEmitHelpers2["ForOfIncludes"] = 256 /* Values */] = "ForOfIncludes";
-        ExternalEmitHelpers2[ExternalEmitHelpers2["ForAwaitOfIncludes"] = 16384 /* AsyncValues */] = "ForAwaitOfIncludes";
-        ExternalEmitHelpers2[ExternalEmitHelpers2["AsyncGeneratorIncludes"] = 6144] = "AsyncGeneratorIncludes";
-        ExternalEmitHelpers2[ExternalEmitHelpers2["AsyncDelegatorIncludes"] = 26624] = "AsyncDelegatorIncludes";
-        ExternalEmitHelpers2[ExternalEmitHelpers2["SpreadIncludes"] = 1536] = "SpreadIncludes";
-        return ExternalEmitHelpers2;
-      })(ExternalEmitHelpers || {});
-      EmitHint = /* @__PURE__ */ ((EmitHint6) => {
-        EmitHint6[EmitHint6["SourceFile"] = 0] = "SourceFile";
-        EmitHint6[EmitHint6["Expression"] = 1] = "Expression";
-        EmitHint6[EmitHint6["IdentifierName"] = 2] = "IdentifierName";
-        EmitHint6[EmitHint6["MappedTypeParameter"] = 3] = "MappedTypeParameter";
-        EmitHint6[EmitHint6["Unspecified"] = 4] = "Unspecified";
-        EmitHint6[EmitHint6["EmbeddedStatement"] = 5] = "EmbeddedStatement";
-        EmitHint6[EmitHint6["JsxAttributeValue"] = 6] = "JsxAttributeValue";
-        return EmitHint6;
-      })(EmitHint || {});
-      OuterExpressionKinds = /* @__PURE__ */ ((OuterExpressionKinds2) => {
-        OuterExpressionKinds2[OuterExpressionKinds2["Parentheses"] = 1] = "Parentheses";
-        OuterExpressionKinds2[OuterExpressionKinds2["TypeAssertions"] = 2] = "TypeAssertions";
-        OuterExpressionKinds2[OuterExpressionKinds2["NonNullAssertions"] = 4] = "NonNullAssertions";
-        OuterExpressionKinds2[OuterExpressionKinds2["PartiallyEmittedExpressions"] = 8] = "PartiallyEmittedExpressions";
-        OuterExpressionKinds2[OuterExpressionKinds2["Assertions"] = 6] = "Assertions";
-        OuterExpressionKinds2[OuterExpressionKinds2["All"] = 15] = "All";
-        OuterExpressionKinds2[OuterExpressionKinds2["ExcludeJSDocTypeAssertion"] = 16] = "ExcludeJSDocTypeAssertion";
-        return OuterExpressionKinds2;
-      })(OuterExpressionKinds || {});
-      LexicalEnvironmentFlags = /* @__PURE__ */ ((LexicalEnvironmentFlags2) => {
-        LexicalEnvironmentFlags2[LexicalEnvironmentFlags2["None"] = 0] = "None";
-        LexicalEnvironmentFlags2[LexicalEnvironmentFlags2["InParameters"] = 1] = "InParameters";
-        LexicalEnvironmentFlags2[LexicalEnvironmentFlags2["VariablesHoistedInParameters"] = 2] = "VariablesHoistedInParameters";
-        return LexicalEnvironmentFlags2;
-      })(LexicalEnvironmentFlags || {});
-      BundleFileSectionKind = /* @__PURE__ */ ((BundleFileSectionKind2) => {
-        BundleFileSectionKind2["Prologue"] = "prologue";
-        BundleFileSectionKind2["EmitHelpers"] = "emitHelpers";
-        BundleFileSectionKind2["NoDefaultLib"] = "no-default-lib";
-        BundleFileSectionKind2["Reference"] = "reference";
-        BundleFileSectionKind2["Type"] = "type";
-        BundleFileSectionKind2["TypeResolutionModeRequire"] = "type-require";
-        BundleFileSectionKind2["TypeResolutionModeImport"] = "type-import";
-        BundleFileSectionKind2["Lib"] = "lib";
-        BundleFileSectionKind2["Prepend"] = "prepend";
-        BundleFileSectionKind2["Text"] = "text";
-        BundleFileSectionKind2["Internal"] = "internal";
-        return BundleFileSectionKind2;
-      })(BundleFileSectionKind || {});
-      ListFormat = /* @__PURE__ */ ((ListFormat2) => {
-        ListFormat2[ListFormat2["None"] = 0] = "None";
-        ListFormat2[ListFormat2["SingleLine"] = 0] = "SingleLine";
-        ListFormat2[ListFormat2["MultiLine"] = 1] = "MultiLine";
-        ListFormat2[ListFormat2["PreserveLines"] = 2] = "PreserveLines";
-        ListFormat2[ListFormat2["LinesMask"] = 3] = "LinesMask";
-        ListFormat2[ListFormat2["NotDelimited"] = 0] = "NotDelimited";
-        ListFormat2[ListFormat2["BarDelimited"] = 4] = "BarDelimited";
-        ListFormat2[ListFormat2["AmpersandDelimited"] = 8] = "AmpersandDelimited";
-        ListFormat2[ListFormat2["CommaDelimited"] = 16] = "CommaDelimited";
-        ListFormat2[ListFormat2["AsteriskDelimited"] = 32] = "AsteriskDelimited";
-        ListFormat2[ListFormat2["DelimitersMask"] = 60] = "DelimitersMask";
-        ListFormat2[ListFormat2["AllowTrailingComma"] = 64] = "AllowTrailingComma";
-        ListFormat2[ListFormat2["Indented"] = 128] = "Indented";
-        ListFormat2[ListFormat2["SpaceBetweenBraces"] = 256] = "SpaceBetweenBraces";
-        ListFormat2[ListFormat2["SpaceBetweenSiblings"] = 512] = "SpaceBetweenSiblings";
-        ListFormat2[ListFormat2["Braces"] = 1024] = "Braces";
-        ListFormat2[ListFormat2["Parenthesis"] = 2048] = "Parenthesis";
-        ListFormat2[ListFormat2["AngleBrackets"] = 4096] = "AngleBrackets";
-        ListFormat2[ListFormat2["SquareBrackets"] = 8192] = "SquareBrackets";
-        ListFormat2[ListFormat2["BracketsMask"] = 15360] = "BracketsMask";
-        ListFormat2[ListFormat2["OptionalIfUndefined"] = 16384] = "OptionalIfUndefined";
-        ListFormat2[ListFormat2["OptionalIfEmpty"] = 32768] = "OptionalIfEmpty";
-        ListFormat2[ListFormat2["Optional"] = 49152] = "Optional";
-        ListFormat2[ListFormat2["PreferNewLine"] = 65536] = "PreferNewLine";
-        ListFormat2[ListFormat2["NoTrailingNewLine"] = 131072] = "NoTrailingNewLine";
-        ListFormat2[ListFormat2["NoInterveningComments"] = 262144] = "NoInterveningComments";
-        ListFormat2[ListFormat2["NoSpaceIfEmpty"] = 524288] = "NoSpaceIfEmpty";
-        ListFormat2[ListFormat2["SingleElement"] = 1048576] = "SingleElement";
-        ListFormat2[ListFormat2["SpaceAfterList"] = 2097152] = "SpaceAfterList";
-        ListFormat2[ListFormat2["Modifiers"] = 2359808] = "Modifiers";
-        ListFormat2[ListFormat2["HeritageClauses"] = 512] = "HeritageClauses";
-        ListFormat2[ListFormat2["SingleLineTypeLiteralMembers"] = 768] = "SingleLineTypeLiteralMembers";
-        ListFormat2[ListFormat2["MultiLineTypeLiteralMembers"] = 32897] = "MultiLineTypeLiteralMembers";
-        ListFormat2[ListFormat2["SingleLineTupleTypeElements"] = 528] = "SingleLineTupleTypeElements";
-        ListFormat2[ListFormat2["MultiLineTupleTypeElements"] = 657] = "MultiLineTupleTypeElements";
-        ListFormat2[ListFormat2["UnionTypeConstituents"] = 516] = "UnionTypeConstituents";
-        ListFormat2[ListFormat2["IntersectionTypeConstituents"] = 520] = "IntersectionTypeConstituents";
-        ListFormat2[ListFormat2["ObjectBindingPatternElements"] = 525136] = "ObjectBindingPatternElements";
-        ListFormat2[ListFormat2["ArrayBindingPatternElements"] = 524880] = "ArrayBindingPatternElements";
-        ListFormat2[ListFormat2["ObjectLiteralExpressionProperties"] = 526226] = "ObjectLiteralExpressionProperties";
-        ListFormat2[ListFormat2["ImportClauseEntries"] = 526226] = "ImportClauseEntries";
-        ListFormat2[ListFormat2["ArrayLiteralExpressionElements"] = 8914] = "ArrayLiteralExpressionElements";
-        ListFormat2[ListFormat2["CommaListElements"] = 528] = "CommaListElements";
-        ListFormat2[ListFormat2["CallExpressionArguments"] = 2576] = "CallExpressionArguments";
-        ListFormat2[ListFormat2["NewExpressionArguments"] = 18960] = "NewExpressionArguments";
-        ListFormat2[ListFormat2["TemplateExpressionSpans"] = 262144] = "TemplateExpressionSpans";
-        ListFormat2[ListFormat2["SingleLineBlockStatements"] = 768] = "SingleLineBlockStatements";
-        ListFormat2[ListFormat2["MultiLineBlockStatements"] = 129] = "MultiLineBlockStatements";
-        ListFormat2[ListFormat2["VariableDeclarationList"] = 528] = "VariableDeclarationList";
-        ListFormat2[ListFormat2["SingleLineFunctionBodyStatements"] = 768] = "SingleLineFunctionBodyStatements";
-        ListFormat2[ListFormat2["MultiLineFunctionBodyStatements"] = 1 /* MultiLine */] = "MultiLineFunctionBodyStatements";
-        ListFormat2[ListFormat2["ClassHeritageClauses"] = 0 /* SingleLine */] = "ClassHeritageClauses";
-        ListFormat2[ListFormat2["ClassMembers"] = 129] = "ClassMembers";
-        ListFormat2[ListFormat2["InterfaceMembers"] = 129] = "InterfaceMembers";
-        ListFormat2[ListFormat2["EnumMembers"] = 145] = "EnumMembers";
-        ListFormat2[ListFormat2["CaseBlockClauses"] = 129] = "CaseBlockClauses";
-        ListFormat2[ListFormat2["NamedImportsOrExportsElements"] = 525136] = "NamedImportsOrExportsElements";
-        ListFormat2[ListFormat2["JsxElementOrFragmentChildren"] = 262144] = "JsxElementOrFragmentChildren";
-        ListFormat2[ListFormat2["JsxElementAttributes"] = 262656] = "JsxElementAttributes";
-        ListFormat2[ListFormat2["CaseOrDefaultClauseStatements"] = 163969] = "CaseOrDefaultClauseStatements";
-        ListFormat2[ListFormat2["HeritageClauseTypes"] = 528] = "HeritageClauseTypes";
-        ListFormat2[ListFormat2["SourceFileStatements"] = 131073] = "SourceFileStatements";
-        ListFormat2[ListFormat2["Decorators"] = 2146305] = "Decorators";
-        ListFormat2[ListFormat2["TypeArguments"] = 53776] = "TypeArguments";
-        ListFormat2[ListFormat2["TypeParameters"] = 53776] = "TypeParameters";
-        ListFormat2[ListFormat2["Parameters"] = 2576] = "Parameters";
-        ListFormat2[ListFormat2["IndexSignatureParameters"] = 8848] = "IndexSignatureParameters";
-        ListFormat2[ListFormat2["JSDocComment"] = 33] = "JSDocComment";
-        return ListFormat2;
-      })(ListFormat || {});
-      PragmaKindFlags = /* @__PURE__ */ ((PragmaKindFlags2) => {
-        PragmaKindFlags2[PragmaKindFlags2["None"] = 0] = "None";
-        PragmaKindFlags2[PragmaKindFlags2["TripleSlashXML"] = 1] = "TripleSlashXML";
-        PragmaKindFlags2[PragmaKindFlags2["SingleLine"] = 2] = "SingleLine";
-        PragmaKindFlags2[PragmaKindFlags2["MultiLine"] = 4] = "MultiLine";
-        PragmaKindFlags2[PragmaKindFlags2["All"] = 7] = "All";
-        PragmaKindFlags2[PragmaKindFlags2["Default"] = 7 /* All */] = "Default";
-        return PragmaKindFlags2;
-      })(PragmaKindFlags || {});
-      commentPragmas = {
-        "reference": {
-          args: [
-            { name: "types", optional: true, captureSpan: true },
-            { name: "lib", optional: true, captureSpan: true },
-            { name: "path", optional: true, captureSpan: true },
-            { name: "no-default-lib", optional: true },
-            { name: "resolution-mode", optional: true }
-          ],
-          kind: 1 /* TripleSlashXML */
-        },
-        "amd-dependency": {
-          args: [{ name: "path" }, { name: "name", optional: true }],
-          kind: 1 /* TripleSlashXML */
-        },
-        "amd-module": {
-          args: [{ name: "name" }],
-          kind: 1 /* TripleSlashXML */
-        },
-        "ts-check": {
-          kind: 2 /* SingleLine */
-        },
-        "ts-nocheck": {
-          kind: 2 /* SingleLine */
-        },
-        "jsx": {
-          args: [{ name: "factory" }],
-          kind: 4 /* MultiLine */
-        },
-        "jsxfrag": {
-          args: [{ name: "factory" }],
-          kind: 4 /* MultiLine */
-        },
-        "jsximportsource": {
-          args: [{ name: "factory" }],
-          kind: 4 /* MultiLine */
-        },
-        "jsxruntime": {
-          args: [{ name: "factory" }],
-          kind: 4 /* MultiLine */
-        }
-      };
-    }
-  });
-
-  // src/compiler/sys.ts
-  function generateDjb2Hash(data) {
-    let acc = 5381;
-    for (let i = 0; i < data.length; i++) {
-      acc = (acc << 5) + acc + data.charCodeAt(i);
-    }
-    return acc.toString();
-  }
-  function setStackTraceLimit() {
-    if (Error.stackTraceLimit < 100) {
-      Error.stackTraceLimit = 100;
-    }
-  }
-  function getModifiedTime(host, fileName) {
-    return host.getModifiedTime(fileName) || missingFileModifiedTime;
-  }
-  function createPollingIntervalBasedLevels(levels) {
-    return {
-      [250 /* Low */]: levels.Low,
-      [500 /* Medium */]: levels.Medium,
-      [2e3 /* High */]: levels.High
-    };
-  }
-  function setCustomPollingValues(system) {
-    if (!system.getEnvironmentVariable) {
-      return;
-    }
-    const pollingIntervalChanged = setCustomLevels("TSC_WATCH_POLLINGINTERVAL", PollingInterval);
-    pollingChunkSize = getCustomPollingBasedLevels("TSC_WATCH_POLLINGCHUNKSIZE", defaultChunkLevels) || pollingChunkSize;
-    unchangedPollThresholds = getCustomPollingBasedLevels("TSC_WATCH_UNCHANGEDPOLLTHRESHOLDS", defaultChunkLevels) || unchangedPollThresholds;
-    function getLevel(envVar, level) {
-      return system.getEnvironmentVariable(`${envVar}_${level.toUpperCase()}`);
-    }
-    function getCustomLevels(baseVariable) {
-      let customLevels;
-      setCustomLevel("Low");
-      setCustomLevel("Medium");
-      setCustomLevel("High");
-      return customLevels;
-      function setCustomLevel(level) {
-        const customLevel = getLevel(baseVariable, level);
-        if (customLevel) {
-          (customLevels || (customLevels = {}))[level] = Number(customLevel);
-        }
-      }
-    }
-    function setCustomLevels(baseVariable, levels) {
-      const customLevels = getCustomLevels(baseVariable);
-      if (customLevels) {
-        setLevel("Low");
-        setLevel("Medium");
-        setLevel("High");
-        return true;
-      }
-      return false;
-      function setLevel(level) {
-        levels[level] = customLevels[level] || levels[level];
-      }
-    }
-    function getCustomPollingBasedLevels(baseVariable, defaultLevels) {
-      const customLevels = getCustomLevels(baseVariable);
-      return (pollingIntervalChanged || customLevels) && createPollingIntervalBasedLevels(customLevels ? { ...defaultLevels, ...customLevels } : defaultLevels);
-    }
-  }
-  function pollWatchedFileQueue(host, queue, pollIndex, chunkSize, callbackOnWatchFileStat) {
-    let definedValueCopyToIndex = pollIndex;
-    for (let canVisit = queue.length; chunkSize && canVisit; nextPollIndex(), canVisit--) {
-      const watchedFile = queue[pollIndex];
-      if (!watchedFile) {
-        continue;
-      } else if (watchedFile.isClosed) {
-        queue[pollIndex] = void 0;
-        continue;
-      }
-      chunkSize--;
-      const fileChanged = onWatchedFileStat(watchedFile, getModifiedTime(host, watchedFile.fileName));
-      if (watchedFile.isClosed) {
-        queue[pollIndex] = void 0;
-        continue;
-      }
-      callbackOnWatchFileStat == null ? void 0 : callbackOnWatchFileStat(watchedFile, pollIndex, fileChanged);
-      if (queue[pollIndex]) {
-        if (definedValueCopyToIndex < pollIndex) {
-          queue[definedValueCopyToIndex] = watchedFile;
-          queue[pollIndex] = void 0;
-        }
-        definedValueCopyToIndex++;
-      }
-    }
-    return pollIndex;
-    function nextPollIndex() {
-      pollIndex++;
-      if (pollIndex === queue.length) {
-        if (definedValueCopyToIndex < pollIndex) {
-          queue.length = definedValueCopyToIndex;
-        }
-        pollIndex = 0;
-        definedValueCopyToIndex = 0;
-      }
-    }
-  }
-  function createDynamicPriorityPollingWatchFile(host) {
-    const watchedFiles = [];
-    const changedFilesInLastPoll = [];
-    const lowPollingIntervalQueue = createPollingIntervalQueue(250 /* Low */);
-    const mediumPollingIntervalQueue = createPollingIntervalQueue(500 /* Medium */);
-    const highPollingIntervalQueue = createPollingIntervalQueue(2e3 /* High */);
-    return watchFile2;
-    function watchFile2(fileName, callback, defaultPollingInterval) {
-      const file = {
-        fileName,
-        callback,
-        unchangedPolls: 0,
-        mtime: getModifiedTime(host, fileName)
-      };
-      watchedFiles.push(file);
-      addToPollingIntervalQueue(file, defaultPollingInterval);
-      return {
-        close: () => {
-          file.isClosed = true;
-          unorderedRemoveItem(watchedFiles, file);
-        }
-      };
-    }
-    function createPollingIntervalQueue(pollingInterval) {
-      const queue = [];
-      queue.pollingInterval = pollingInterval;
-      queue.pollIndex = 0;
-      queue.pollScheduled = false;
-      return queue;
-    }
-    function pollPollingIntervalQueue(_timeoutType, queue) {
-      queue.pollIndex = pollQueue(queue, queue.pollingInterval, queue.pollIndex, pollingChunkSize[queue.pollingInterval]);
-      if (queue.length) {
-        scheduleNextPoll(queue.pollingInterval);
-      } else {
-        Debug.assert(queue.pollIndex === 0);
-        queue.pollScheduled = false;
-      }
-    }
-    function pollLowPollingIntervalQueue(_timeoutType, queue) {
-      pollQueue(
-        changedFilesInLastPoll,
-        250 /* Low */,
-        /*pollIndex*/
-        0,
-        changedFilesInLastPoll.length
-      );
-      pollPollingIntervalQueue(_timeoutType, queue);
-      if (!queue.pollScheduled && changedFilesInLastPoll.length) {
-        scheduleNextPoll(250 /* Low */);
-      }
-    }
-    function pollQueue(queue, pollingInterval, pollIndex, chunkSize) {
-      return pollWatchedFileQueue(
-        host,
-        queue,
-        pollIndex,
-        chunkSize,
-        onWatchFileStat
-      );
-      function onWatchFileStat(watchedFile, pollIndex2, fileChanged) {
-        if (fileChanged) {
-          watchedFile.unchangedPolls = 0;
-          if (queue !== changedFilesInLastPoll) {
-            queue[pollIndex2] = void 0;
-            addChangedFileToLowPollingIntervalQueue(watchedFile);
-          }
-        } else if (watchedFile.unchangedPolls !== unchangedPollThresholds[pollingInterval]) {
-          watchedFile.unchangedPolls++;
-        } else if (queue === changedFilesInLastPoll) {
-          watchedFile.unchangedPolls = 1;
-          queue[pollIndex2] = void 0;
-          addToPollingIntervalQueue(watchedFile, 250 /* Low */);
-        } else if (pollingInterval !== 2e3 /* High */) {
-          watchedFile.unchangedPolls++;
-          queue[pollIndex2] = void 0;
-          addToPollingIntervalQueue(watchedFile, pollingInterval === 250 /* Low */ ? 500 /* Medium */ : 2e3 /* High */);
-        }
-      }
-    }
-    function pollingIntervalQueue(pollingInterval) {
-      switch (pollingInterval) {
-        case 250 /* Low */:
-          return lowPollingIntervalQueue;
-        case 500 /* Medium */:
-          return mediumPollingIntervalQueue;
-        case 2e3 /* High */:
-          return highPollingIntervalQueue;
-      }
-    }
-    function addToPollingIntervalQueue(file, pollingInterval) {
-      pollingIntervalQueue(pollingInterval).push(file);
-      scheduleNextPollIfNotAlreadyScheduled(pollingInterval);
-    }
-    function addChangedFileToLowPollingIntervalQueue(file) {
-      changedFilesInLastPoll.push(file);
-      scheduleNextPollIfNotAlreadyScheduled(250 /* Low */);
-    }
-    function scheduleNextPollIfNotAlreadyScheduled(pollingInterval) {
-      if (!pollingIntervalQueue(pollingInterval).pollScheduled) {
-        scheduleNextPoll(pollingInterval);
-      }
-    }
-    function scheduleNextPoll(pollingInterval) {
-      pollingIntervalQueue(pollingInterval).pollScheduled = host.setTimeout(pollingInterval === 250 /* Low */ ? pollLowPollingIntervalQueue : pollPollingIntervalQueue, pollingInterval, pollingInterval === 250 /* Low */ ? "pollLowPollingIntervalQueue" : "pollPollingIntervalQueue", pollingIntervalQueue(pollingInterval));
-    }
-  }
-  function createUseFsEventsOnParentDirectoryWatchFile(fsWatch, useCaseSensitiveFileNames) {
-    const fileWatcherCallbacks = createMultiMap();
-    const dirWatchers = /* @__PURE__ */ new Map();
-    const toCanonicalName = createGetCanonicalFileName(useCaseSensitiveFileNames);
-    return nonPollingWatchFile;
-    function nonPollingWatchFile(fileName, callback, _pollingInterval, fallbackOptions) {
-      const filePath = toCanonicalName(fileName);
-      fileWatcherCallbacks.add(filePath, callback);
-      const dirPath = getDirectoryPath(filePath) || ".";
-      const watcher = dirWatchers.get(dirPath) || createDirectoryWatcher(getDirectoryPath(fileName) || ".", dirPath, fallbackOptions);
-      watcher.referenceCount++;
-      return {
-        close: () => {
-          if (watcher.referenceCount === 1) {
-            watcher.close();
-            dirWatchers.delete(dirPath);
-          } else {
-            watcher.referenceCount--;
-          }
-          fileWatcherCallbacks.remove(filePath, callback);
-        }
-      };
-    }
-    function createDirectoryWatcher(dirName, dirPath, fallbackOptions) {
-      const watcher = fsWatch(
-        dirName,
-        1 /* Directory */,
-        (_eventName, relativeFileName, modifiedTime) => {
-          if (!isString(relativeFileName))
-            return;
-          const fileName = getNormalizedAbsolutePath(relativeFileName, dirName);
-          const callbacks = fileName && fileWatcherCallbacks.get(toCanonicalName(fileName));
-          if (callbacks) {
-            for (const fileCallback of callbacks) {
-              fileCallback(fileName, 1 /* Changed */, modifiedTime);
-            }
-          }
-        },
-        /*recursive*/
-        false,
-        500 /* Medium */,
-        fallbackOptions
-      );
-      watcher.referenceCount = 0;
-      dirWatchers.set(dirPath, watcher);
-      return watcher;
-    }
-  }
-  function createFixedChunkSizePollingWatchFile(host) {
-    const watchedFiles = [];
-    let pollIndex = 0;
-    let pollScheduled;
-    return watchFile2;
-    function watchFile2(fileName, callback) {
-      const file = {
-        fileName,
-        callback,
-        mtime: getModifiedTime(host, fileName)
-      };
-      watchedFiles.push(file);
-      scheduleNextPoll();
-      return {
-        close: () => {
-          file.isClosed = true;
-          unorderedRemoveItem(watchedFiles, file);
-        }
-      };
-    }
-    function pollQueue() {
-      pollScheduled = void 0;
-      pollIndex = pollWatchedFileQueue(host, watchedFiles, pollIndex, pollingChunkSize[250 /* Low */]);
-      scheduleNextPoll();
-    }
-    function scheduleNextPoll() {
-      if (!watchedFiles.length || pollScheduled)
-        return;
-      pollScheduled = host.setTimeout(pollQueue, 2e3 /* High */, "pollQueue");
-    }
-  }
-  function createSingleWatcherPerName(cache, useCaseSensitiveFileNames, name, callback, createWatcher) {
-    const toCanonicalFileName = createGetCanonicalFileName(useCaseSensitiveFileNames);
-    const path = toCanonicalFileName(name);
-    const existing = cache.get(path);
-    if (existing) {
-      existing.callbacks.push(callback);
-    } else {
-      cache.set(path, {
-        watcher: createWatcher(
-          // Cant infer types correctly so lets satisfy checker
-          (param1, param2, param3) => {
-            var _a;
-            return (_a = cache.get(path)) == null ? void 0 : _a.callbacks.slice().forEach((cb) => cb(param1, param2, param3));
-          }
-        ),
-        callbacks: [callback]
-      });
-    }
-    return {
-      close: () => {
-        const watcher = cache.get(path);
-        if (!watcher)
-          return;
-        if (!orderedRemoveItem(watcher.callbacks, callback) || watcher.callbacks.length)
-          return;
-        cache.delete(path);
-        closeFileWatcherOf(watcher);
-      }
-    };
-  }
-  function onWatchedFileStat(watchedFile, modifiedTime) {
-    const oldTime = watchedFile.mtime.getTime();
-    const newTime = modifiedTime.getTime();
-    if (oldTime !== newTime) {
-      watchedFile.mtime = modifiedTime;
-      watchedFile.callback(watchedFile.fileName, getFileWatcherEventKind(oldTime, newTime), modifiedTime);
-      return true;
-    }
-    return false;
-  }
-  function getFileWatcherEventKind(oldTime, newTime) {
-    return oldTime === 0 ? 0 /* Created */ : newTime === 0 ? 2 /* Deleted */ : 1 /* Changed */;
-  }
-  function sysLog(s) {
-    return curSysLog(s);
-  }
-  function setSysLog(logger) {
-    curSysLog = logger;
-  }
-  function createDirectoryWatcherSupportingRecursive({
-    watchDirectory,
-    useCaseSensitiveFileNames,
-    getCurrentDirectory,
-    getAccessibleSortedChildDirectories,
-    fileSystemEntryExists,
-    realpath,
-    setTimeout: setTimeout2,
-    clearTimeout: clearTimeout2
-  }) {
-    const cache = /* @__PURE__ */ new Map();
-    const callbackCache = createMultiMap();
-    const cacheToUpdateChildWatches = /* @__PURE__ */ new Map();
-    let timerToUpdateChildWatches;
-    const filePathComparer = getStringComparer(!useCaseSensitiveFileNames);
-    const toCanonicalFilePath = createGetCanonicalFileName(useCaseSensitiveFileNames);
-    return (dirName, callback, recursive, options) => recursive ? createDirectoryWatcher(dirName, options, callback) : watchDirectory(dirName, callback, recursive, options);
-    function createDirectoryWatcher(dirName, options, callback) {
-      const dirPath = toCanonicalFilePath(dirName);
-      let directoryWatcher = cache.get(dirPath);
-      if (directoryWatcher) {
-        directoryWatcher.refCount++;
-      } else {
-        directoryWatcher = {
-          watcher: watchDirectory(
-            dirName,
-            (fileName) => {
-              if (isIgnoredPath(fileName, options))
-                return;
-              if (options == null ? void 0 : options.synchronousWatchDirectory) {
-                invokeCallbacks(dirPath, fileName);
-                updateChildWatches(dirName, dirPath, options);
-              } else {
-                nonSyncUpdateChildWatches(dirName, dirPath, fileName, options);
-              }
-            },
-            /*recursive*/
-            false,
-            options
-          ),
-          refCount: 1,
-          childWatches: emptyArray
-        };
-        cache.set(dirPath, directoryWatcher);
-        updateChildWatches(dirName, dirPath, options);
-      }
-      const callbackToAdd = callback && { dirName, callback };
-      if (callbackToAdd) {
-        callbackCache.add(dirPath, callbackToAdd);
-      }
-      return {
-        dirName,
-        close: () => {
-          const directoryWatcher2 = Debug.checkDefined(cache.get(dirPath));
-          if (callbackToAdd)
-            callbackCache.remove(dirPath, callbackToAdd);
-          directoryWatcher2.refCount--;
-          if (directoryWatcher2.refCount)
-            return;
-          cache.delete(dirPath);
-          closeFileWatcherOf(directoryWatcher2);
-          directoryWatcher2.childWatches.forEach(closeFileWatcher);
-        }
-      };
-    }
-    function invokeCallbacks(dirPath, fileNameOrInvokeMap, fileNames) {
-      let fileName;
-      let invokeMap;
-      if (isString(fileNameOrInvokeMap)) {
-        fileName = fileNameOrInvokeMap;
-      } else {
-        invokeMap = fileNameOrInvokeMap;
-      }
-      callbackCache.forEach((callbacks, rootDirName) => {
-        if (invokeMap && invokeMap.get(rootDirName) === true)
-          return;
-        if (rootDirName === dirPath || startsWith(dirPath, rootDirName) && dirPath[rootDirName.length] === directorySeparator) {
-          if (invokeMap) {
-            if (fileNames) {
-              const existing = invokeMap.get(rootDirName);
-              if (existing) {
-                existing.push(...fileNames);
-              } else {
-                invokeMap.set(rootDirName, fileNames.slice());
-              }
-            } else {
-              invokeMap.set(rootDirName, true);
-            }
-          } else {
-            callbacks.forEach(({ callback }) => callback(fileName));
-          }
-        }
-      });
-    }
-    function nonSyncUpdateChildWatches(dirName, dirPath, fileName, options) {
-      const parentWatcher = cache.get(dirPath);
-      if (parentWatcher && fileSystemEntryExists(dirName, 1 /* Directory */)) {
-        scheduleUpdateChildWatches(dirName, dirPath, fileName, options);
-        return;
-      }
-      invokeCallbacks(dirPath, fileName);
-      removeChildWatches(parentWatcher);
-    }
-    function scheduleUpdateChildWatches(dirName, dirPath, fileName, options) {
-      const existing = cacheToUpdateChildWatches.get(dirPath);
-      if (existing) {
-        existing.fileNames.push(fileName);
-      } else {
-        cacheToUpdateChildWatches.set(dirPath, { dirName, options, fileNames: [fileName] });
-      }
-      if (timerToUpdateChildWatches) {
-        clearTimeout2(timerToUpdateChildWatches);
-        timerToUpdateChildWatches = void 0;
-      }
-      timerToUpdateChildWatches = setTimeout2(onTimerToUpdateChildWatches, 1e3, "timerToUpdateChildWatches");
-    }
-    function onTimerToUpdateChildWatches() {
-      timerToUpdateChildWatches = void 0;
-      sysLog(`sysLog:: onTimerToUpdateChildWatches:: ${cacheToUpdateChildWatches.size}`);
-      const start = timestamp();
-      const invokeMap = /* @__PURE__ */ new Map();
-      while (!timerToUpdateChildWatches && cacheToUpdateChildWatches.size) {
-        const result = cacheToUpdateChildWatches.entries().next();
-        Debug.assert(!result.done);
-        const { value: [dirPath, { dirName, options, fileNames }] } = result;
-        cacheToUpdateChildWatches.delete(dirPath);
-        const hasChanges = updateChildWatches(dirName, dirPath, options);
-        invokeCallbacks(dirPath, invokeMap, hasChanges ? void 0 : fileNames);
-      }
-      sysLog(`sysLog:: invokingWatchers:: Elapsed:: ${timestamp() - start}ms:: ${cacheToUpdateChildWatches.size}`);
-      callbackCache.forEach((callbacks, rootDirName) => {
-        const existing = invokeMap.get(rootDirName);
-        if (existing) {
-          callbacks.forEach(({ callback, dirName }) => {
-            if (isArray(existing)) {
-              existing.forEach(callback);
-            } else {
-              callback(dirName);
-            }
-          });
-        }
-      });
-      const elapsed = timestamp() - start;
-      sysLog(`sysLog:: Elapsed:: ${elapsed}ms:: onTimerToUpdateChildWatches:: ${cacheToUpdateChildWatches.size} ${timerToUpdateChildWatches}`);
-    }
-    function removeChildWatches(parentWatcher) {
-      if (!parentWatcher)
-        return;
-      const existingChildWatches = parentWatcher.childWatches;
-      parentWatcher.childWatches = emptyArray;
-      for (const childWatcher of existingChildWatches) {
-        childWatcher.close();
-        removeChildWatches(cache.get(toCanonicalFilePath(childWatcher.dirName)));
-      }
-    }
-    function updateChildWatches(parentDir, parentDirPath, options) {
-      const parentWatcher = cache.get(parentDirPath);
-      if (!parentWatcher)
-        return false;
-      let newChildWatches;
-      const hasChanges = enumerateInsertsAndDeletes(
-        fileSystemEntryExists(parentDir, 1 /* Directory */) ? mapDefined(getAccessibleSortedChildDirectories(parentDir), (child) => {
-          const childFullName = getNormalizedAbsolutePath(child, parentDir);
-          return !isIgnoredPath(childFullName, options) && filePathComparer(childFullName, normalizePath(realpath(childFullName))) === 0 /* EqualTo */ ? childFullName : void 0;
-        }) : emptyArray,
-        parentWatcher.childWatches,
-        (child, childWatcher) => filePathComparer(child, childWatcher.dirName),
-        createAndAddChildDirectoryWatcher,
-        closeFileWatcher,
-        addChildDirectoryWatcher
-      );
-      parentWatcher.childWatches = newChildWatches || emptyArray;
-      return hasChanges;
-      function createAndAddChildDirectoryWatcher(childName) {
-        const result = createDirectoryWatcher(childName, options);
-        addChildDirectoryWatcher(result);
-      }
-      function addChildDirectoryWatcher(childWatcher) {
-        (newChildWatches || (newChildWatches = [])).push(childWatcher);
-      }
-    }
-    function isIgnoredPath(path, options) {
-      return some(ignoredPaths, (searchPath) => isInPath(path, searchPath)) || isIgnoredByWatchOptions(path, options, useCaseSensitiveFileNames, getCurrentDirectory);
-    }
-    function isInPath(path, searchPath) {
-      if (stringContains(path, searchPath))
-        return true;
-      if (useCaseSensitiveFileNames)
-        return false;
-      return stringContains(toCanonicalFilePath(path), searchPath);
-    }
-  }
-  function createFileWatcherCallback(callback) {
-    return (_fileName, eventKind, modifiedTime) => callback(eventKind === 1 /* Changed */ ? "change" : "rename", "", modifiedTime);
-  }
-  function createFsWatchCallbackForFileWatcherCallback(fileName, callback, getModifiedTime3) {
-    return (eventName, _relativeFileName, modifiedTime) => {
-      if (eventName === "rename") {
-        modifiedTime || (modifiedTime = getModifiedTime3(fileName) || missingFileModifiedTime);
-        callback(fileName, modifiedTime !== missingFileModifiedTime ? 0 /* Created */ : 2 /* Deleted */, modifiedTime);
-      } else {
-        callback(fileName, 1 /* Changed */, modifiedTime);
-      }
-    };
-  }
-  function isIgnoredByWatchOptions(pathToCheck, options, useCaseSensitiveFileNames, getCurrentDirectory) {
-    return ((options == null ? void 0 : options.excludeDirectories) || (options == null ? void 0 : options.excludeFiles)) && (matchesExclude(pathToCheck, options == null ? void 0 : options.excludeFiles, useCaseSensitiveFileNames, getCurrentDirectory()) || matchesExclude(pathToCheck, options == null ? void 0 : options.excludeDirectories, useCaseSensitiveFileNames, getCurrentDirectory()));
-  }
-  function createFsWatchCallbackForDirectoryWatcherCallback(directoryName, callback, options, useCaseSensitiveFileNames, getCurrentDirectory) {
-    return (eventName, relativeFileName) => {
-      if (eventName === "rename") {
-        const fileName = !relativeFileName ? directoryName : normalizePath(combinePaths(directoryName, relativeFileName));
-        if (!relativeFileName || !isIgnoredByWatchOptions(fileName, options, useCaseSensitiveFileNames, getCurrentDirectory)) {
-          callback(fileName);
-        }
-      }
-    };
-  }
-  function createSystemWatchFunctions({
-    pollingWatchFileWorker,
-    getModifiedTime: getModifiedTime3,
-    setTimeout: setTimeout2,
-    clearTimeout: clearTimeout2,
-    fsWatchWorker,
-    fileSystemEntryExists,
-    useCaseSensitiveFileNames,
-    getCurrentDirectory,
-    fsSupportsRecursiveFsWatch,
-    getAccessibleSortedChildDirectories,
-    realpath,
-    tscWatchFile,
-    useNonPollingWatchers,
-    tscWatchDirectory,
-    inodeWatching,
-    sysLog: sysLog2
-  }) {
-    const pollingWatches = /* @__PURE__ */ new Map();
-    const fsWatches = /* @__PURE__ */ new Map();
-    const fsWatchesRecursive = /* @__PURE__ */ new Map();
-    let dynamicPollingWatchFile;
-    let fixedChunkSizePollingWatchFile;
-    let nonPollingWatchFile;
-    let hostRecursiveDirectoryWatcher;
-    let hitSystemWatcherLimit = false;
-    return {
-      watchFile: watchFile2,
-      watchDirectory
-    };
-    function watchFile2(fileName, callback, pollingInterval, options) {
-      options = updateOptionsForWatchFile(options, useNonPollingWatchers);
-      const watchFileKind = Debug.checkDefined(options.watchFile);
-      switch (watchFileKind) {
-        case 0 /* FixedPollingInterval */:
-          return pollingWatchFile(
-            fileName,
-            callback,
-            250 /* Low */,
-            /*options*/
-            void 0
-          );
-        case 1 /* PriorityPollingInterval */:
-          return pollingWatchFile(
-            fileName,
-            callback,
-            pollingInterval,
-            /*options*/
-            void 0
-          );
-        case 2 /* DynamicPriorityPolling */:
-          return ensureDynamicPollingWatchFile()(
-            fileName,
-            callback,
-            pollingInterval,
-            /*options*/
-            void 0
-          );
-        case 3 /* FixedChunkSizePolling */:
-          return ensureFixedChunkSizePollingWatchFile()(
-            fileName,
-            callback,
-            /* pollingInterval */
-            void 0,
-            /*options*/
-            void 0
-          );
-        case 4 /* UseFsEvents */:
-          return fsWatch(
-            fileName,
-            0 /* File */,
-            createFsWatchCallbackForFileWatcherCallback(fileName, callback, getModifiedTime3),
-            /*recursive*/
-            false,
-            pollingInterval,
-            getFallbackOptions(options)
-          );
-        case 5 /* UseFsEventsOnParentDirectory */:
-          if (!nonPollingWatchFile) {
-            nonPollingWatchFile = createUseFsEventsOnParentDirectoryWatchFile(fsWatch, useCaseSensitiveFileNames);
-          }
-          return nonPollingWatchFile(fileName, callback, pollingInterval, getFallbackOptions(options));
-        default:
-          Debug.assertNever(watchFileKind);
-      }
-    }
-    function ensureDynamicPollingWatchFile() {
-      return dynamicPollingWatchFile || (dynamicPollingWatchFile = createDynamicPriorityPollingWatchFile({ getModifiedTime: getModifiedTime3, setTimeout: setTimeout2 }));
-    }
-    function ensureFixedChunkSizePollingWatchFile() {
-      return fixedChunkSizePollingWatchFile || (fixedChunkSizePollingWatchFile = createFixedChunkSizePollingWatchFile({ getModifiedTime: getModifiedTime3, setTimeout: setTimeout2 }));
-    }
-    function updateOptionsForWatchFile(options, useNonPollingWatchers2) {
-      if (options && options.watchFile !== void 0)
-        return options;
-      switch (tscWatchFile) {
-        case "PriorityPollingInterval":
-          return { watchFile: 1 /* PriorityPollingInterval */ };
-        case "DynamicPriorityPolling":
-          return { watchFile: 2 /* DynamicPriorityPolling */ };
-        case "UseFsEvents":
-          return generateWatchFileOptions(4 /* UseFsEvents */, 1 /* PriorityInterval */, options);
-        case "UseFsEventsWithFallbackDynamicPolling":
-          return generateWatchFileOptions(4 /* UseFsEvents */, 2 /* DynamicPriority */, options);
-        case "UseFsEventsOnParentDirectory":
-          useNonPollingWatchers2 = true;
-        default:
-          return useNonPollingWatchers2 ? (
-            // Use notifications from FS to watch with falling back to fs.watchFile
-            generateWatchFileOptions(5 /* UseFsEventsOnParentDirectory */, 1 /* PriorityInterval */, options)
-          ) : (
-            // Default to using fs events
-            { watchFile: 4 /* UseFsEvents */ }
-          );
-      }
-    }
-    function generateWatchFileOptions(watchFile3, fallbackPolling, options) {
-      const defaultFallbackPolling = options == null ? void 0 : options.fallbackPolling;
-      return {
-        watchFile: watchFile3,
-        fallbackPolling: defaultFallbackPolling === void 0 ? fallbackPolling : defaultFallbackPolling
-      };
-    }
-    function watchDirectory(directoryName, callback, recursive, options) {
-      if (fsSupportsRecursiveFsWatch) {
-        return fsWatch(
-          directoryName,
-          1 /* Directory */,
-          createFsWatchCallbackForDirectoryWatcherCallback(directoryName, callback, options, useCaseSensitiveFileNames, getCurrentDirectory),
-          recursive,
-          500 /* Medium */,
-          getFallbackOptions(options)
-        );
-      }
-      if (!hostRecursiveDirectoryWatcher) {
-        hostRecursiveDirectoryWatcher = createDirectoryWatcherSupportingRecursive({
-          useCaseSensitiveFileNames,
-          getCurrentDirectory,
-          fileSystemEntryExists,
-          getAccessibleSortedChildDirectories,
-          watchDirectory: nonRecursiveWatchDirectory,
-          realpath,
-          setTimeout: setTimeout2,
-          clearTimeout: clearTimeout2
-        });
-      }
-      return hostRecursiveDirectoryWatcher(directoryName, callback, recursive, options);
-    }
-    function nonRecursiveWatchDirectory(directoryName, callback, recursive, options) {
-      Debug.assert(!recursive);
-      const watchDirectoryOptions = updateOptionsForWatchDirectory(options);
-      const watchDirectoryKind = Debug.checkDefined(watchDirectoryOptions.watchDirectory);
-      switch (watchDirectoryKind) {
-        case 1 /* FixedPollingInterval */:
-          return pollingWatchFile(
-            directoryName,
-            () => callback(directoryName),
-            500 /* Medium */,
-            /*options*/
-            void 0
-          );
-        case 2 /* DynamicPriorityPolling */:
-          return ensureDynamicPollingWatchFile()(
-            directoryName,
-            () => callback(directoryName),
-            500 /* Medium */,
-            /*options*/
-            void 0
-          );
-        case 3 /* FixedChunkSizePolling */:
-          return ensureFixedChunkSizePollingWatchFile()(
-            directoryName,
-            () => callback(directoryName),
-            /* pollingInterval */
-            void 0,
-            /*options*/
-            void 0
-          );
-        case 0 /* UseFsEvents */:
-          return fsWatch(
-            directoryName,
-            1 /* Directory */,
-            createFsWatchCallbackForDirectoryWatcherCallback(directoryName, callback, options, useCaseSensitiveFileNames, getCurrentDirectory),
-            recursive,
-            500 /* Medium */,
-            getFallbackOptions(watchDirectoryOptions)
-          );
-        default:
-          Debug.assertNever(watchDirectoryKind);
-      }
-    }
-    function updateOptionsForWatchDirectory(options) {
-      if (options && options.watchDirectory !== void 0)
-        return options;
-      switch (tscWatchDirectory) {
-        case "RecursiveDirectoryUsingFsWatchFile":
-          return { watchDirectory: 1 /* FixedPollingInterval */ };
-        case "RecursiveDirectoryUsingDynamicPriorityPolling":
-          return { watchDirectory: 2 /* DynamicPriorityPolling */ };
-        default:
-          const defaultFallbackPolling = options == null ? void 0 : options.fallbackPolling;
-          return {
-            watchDirectory: 0 /* UseFsEvents */,
-            fallbackPolling: defaultFallbackPolling !== void 0 ? defaultFallbackPolling : void 0
-          };
-      }
-    }
-    function pollingWatchFile(fileName, callback, pollingInterval, options) {
-      return createSingleWatcherPerName(
-        pollingWatches,
-        useCaseSensitiveFileNames,
-        fileName,
-        callback,
-        (cb) => pollingWatchFileWorker(fileName, cb, pollingInterval, options)
-      );
-    }
-    function fsWatch(fileOrDirectory, entryKind, callback, recursive, fallbackPollingInterval, fallbackOptions) {
-      return createSingleWatcherPerName(
-        recursive ? fsWatchesRecursive : fsWatches,
-        useCaseSensitiveFileNames,
-        fileOrDirectory,
-        callback,
-        (cb) => fsWatchHandlingExistenceOnHost(fileOrDirectory, entryKind, cb, recursive, fallbackPollingInterval, fallbackOptions)
-      );
-    }
-    function fsWatchHandlingExistenceOnHost(fileOrDirectory, entryKind, callback, recursive, fallbackPollingInterval, fallbackOptions) {
-      let lastDirectoryPartWithDirectorySeparator;
-      let lastDirectoryPart;
-      if (inodeWatching) {
-        lastDirectoryPartWithDirectorySeparator = fileOrDirectory.substring(fileOrDirectory.lastIndexOf(directorySeparator));
-        lastDirectoryPart = lastDirectoryPartWithDirectorySeparator.slice(directorySeparator.length);
-      }
-      let watcher = !fileSystemEntryExists(fileOrDirectory, entryKind) ? watchMissingFileSystemEntry() : watchPresentFileSystemEntry();
-      return {
-        close: () => {
-          if (watcher) {
-            watcher.close();
-            watcher = void 0;
-          }
-        }
-      };
-      function updateWatcher(createWatcher) {
-        if (watcher) {
-          sysLog2(`sysLog:: ${fileOrDirectory}:: Changing watcher to ${createWatcher === watchPresentFileSystemEntry ? "Present" : "Missing"}FileSystemEntryWatcher`);
-          watcher.close();
-          watcher = createWatcher();
-        }
-      }
-      function watchPresentFileSystemEntry() {
-        if (hitSystemWatcherLimit) {
-          sysLog2(`sysLog:: ${fileOrDirectory}:: Defaulting to watchFile`);
-          return watchPresentFileSystemEntryWithFsWatchFile();
-        }
-        try {
-          const presentWatcher = fsWatchWorker(
-            fileOrDirectory,
-            recursive,
-            inodeWatching ? callbackChangingToMissingFileSystemEntry : callback
-          );
-          presentWatcher.on("error", () => {
-            callback("rename", "");
-            updateWatcher(watchMissingFileSystemEntry);
-          });
-          return presentWatcher;
-        } catch (e) {
-          hitSystemWatcherLimit || (hitSystemWatcherLimit = e.code === "ENOSPC");
-          sysLog2(`sysLog:: ${fileOrDirectory}:: Changing to watchFile`);
-          return watchPresentFileSystemEntryWithFsWatchFile();
-        }
-      }
-      function callbackChangingToMissingFileSystemEntry(event, relativeName) {
-        let originalRelativeName;
-        if (relativeName && endsWith(relativeName, "~")) {
-          originalRelativeName = relativeName;
-          relativeName = relativeName.slice(0, relativeName.length - 1);
-        }
-        if (event === "rename" && (!relativeName || relativeName === lastDirectoryPart || endsWith(relativeName, lastDirectoryPartWithDirectorySeparator))) {
-          const modifiedTime = getModifiedTime3(fileOrDirectory) || missingFileModifiedTime;
-          if (originalRelativeName)
-            callback(event, originalRelativeName, modifiedTime);
-          callback(event, relativeName, modifiedTime);
-          if (inodeWatching) {
-            updateWatcher(modifiedTime === missingFileModifiedTime ? watchMissingFileSystemEntry : watchPresentFileSystemEntry);
-          } else if (modifiedTime === missingFileModifiedTime) {
-            updateWatcher(watchMissingFileSystemEntry);
-          }
-        } else {
-          if (originalRelativeName)
-            callback(event, originalRelativeName);
-          callback(event, relativeName);
-        }
-      }
-      function watchPresentFileSystemEntryWithFsWatchFile() {
-        return watchFile2(
-          fileOrDirectory,
-          createFileWatcherCallback(callback),
-          fallbackPollingInterval,
-          fallbackOptions
-        );
-      }
-      function watchMissingFileSystemEntry() {
-        return watchFile2(
-          fileOrDirectory,
-          (_fileName, eventKind, modifiedTime) => {
-            if (eventKind === 0 /* Created */) {
-              modifiedTime || (modifiedTime = getModifiedTime3(fileOrDirectory) || missingFileModifiedTime);
-              if (modifiedTime !== missingFileModifiedTime) {
-                callback("rename", "", modifiedTime);
-                updateWatcher(watchPresentFileSystemEntry);
-              }
-            }
-          },
-          fallbackPollingInterval,
-          fallbackOptions
-        );
-      }
-    }
-  }
-  function patchWriteFileEnsuringDirectory(sys2) {
-    const originalWriteFile = sys2.writeFile;
-    sys2.writeFile = (path, data, writeBom) => writeFileEnsuringDirectories(
-      path,
-      data,
-      !!writeBom,
-      (path2, data2, writeByteOrderMark) => originalWriteFile.call(sys2, path2, data2, writeByteOrderMark),
-      (path2) => sys2.createDirectory(path2),
-      (path2) => sys2.directoryExists(path2)
-    );
-  }
-  function setSys(s) {
-    sys = s;
-  }
-  var FileWatcherEventKind, PollingInterval, missingFileModifiedTime, defaultChunkLevels, pollingChunkSize, unchangedPollThresholds, ignoredPaths, curSysLog, FileSystemEntryKind, sys;
-  var init_sys = __esm({
-    "src/compiler/sys.ts"() {
-      "use strict";
-      init_ts2();
-      FileWatcherEventKind = /* @__PURE__ */ ((FileWatcherEventKind2) => {
-        FileWatcherEventKind2[FileWatcherEventKind2["Created"] = 0] = "Created";
-        FileWatcherEventKind2[FileWatcherEventKind2["Changed"] = 1] = "Changed";
-        FileWatcherEventKind2[FileWatcherEventKind2["Deleted"] = 2] = "Deleted";
-        return FileWatcherEventKind2;
-      })(FileWatcherEventKind || {});
-      PollingInterval = /* @__PURE__ */ ((PollingInterval3) => {
-        PollingInterval3[PollingInterval3["High"] = 2e3] = "High";
-        PollingInterval3[PollingInterval3["Medium"] = 500] = "Medium";
-        PollingInterval3[PollingInterval3["Low"] = 250] = "Low";
-        return PollingInterval3;
-      })(PollingInterval || {});
-      missingFileModifiedTime = /* @__PURE__ */ new Date(0);
-      defaultChunkLevels = { Low: 32, Medium: 64, High: 256 };
-      pollingChunkSize = createPollingIntervalBasedLevels(defaultChunkLevels);
-      unchangedPollThresholds = createPollingIntervalBasedLevels(defaultChunkLevels);
-      ignoredPaths = ["/node_modules/.", "/.git", "/.#"];
-      curSysLog = noop;
-      FileSystemEntryKind = /* @__PURE__ */ ((FileSystemEntryKind2) => {
-        FileSystemEntryKind2[FileSystemEntryKind2["File"] = 0] = "File";
-        FileSystemEntryKind2[FileSystemEntryKind2["Directory"] = 1] = "Directory";
-        return FileSystemEntryKind2;
-      })(FileSystemEntryKind || {});
-      sys = (() => {
-        const byteOrderMarkIndicator = "\uFEFF";
-        function getNodeSystem() {
-          const nativePattern = /^native |^\([^)]+\)$|^(internal[\\/]|[a-zA-Z0-9_\s]+(\.js)?$)/;
-          const _fs =   require("fs");
-          const _path =   require("path");
-          const _os =   require("os");
-          let _crypto;
-          try {
-            _crypto =   require("crypto");
-          } catch {
-            _crypto = void 0;
-          }
-          let activeSession;
-          let profilePath = "./profile.cpuprofile";
-          const Buffer2 =   require("buffer").Buffer;
-          const isLinuxOrMacOs = process.platform === "linux" || process.platform === "darwin";
-          const platform = _os.platform();
-          const useCaseSensitiveFileNames = isFileSystemCaseSensitive();
-          const fsRealpath = !!_fs.realpathSync.native ? process.platform === "win32" ? fsRealPathHandlingLongPath : _fs.realpathSync.native : _fs.realpathSync;
-          const executingFilePath = __filename.endsWith("sys.js") ? _path.join(_path.dirname(__dirname), "__fake__.js") : __filename;
-          const fsSupportsRecursiveFsWatch = process.platform === "win32" || process.platform === "darwin";
-          const getCurrentDirectory = memoize(() => process.cwd());
-          const { watchFile: watchFile2, watchDirectory } = createSystemWatchFunctions({
-            pollingWatchFileWorker: fsWatchFileWorker,
-            getModifiedTime: getModifiedTime3,
-            setTimeout,
-            clearTimeout,
-            fsWatchWorker,
-            useCaseSensitiveFileNames,
-            getCurrentDirectory,
-            fileSystemEntryExists,
-            // Node 4.0 `fs.watch` function supports the "recursive" option on both OSX and Windows
-            // (ref: https://github.com/nodejs/node/pull/2649 and https://github.com/Microsoft/TypeScript/issues/4643)
-            fsSupportsRecursiveFsWatch,
-            getAccessibleSortedChildDirectories: (path) => getAccessibleFileSystemEntries(path).directories,
-            realpath,
-            tscWatchFile: process.env.TSC_WATCHFILE,
-            useNonPollingWatchers: !!process.env.TSC_NONPOLLING_WATCHER,
-            tscWatchDirectory: process.env.TSC_WATCHDIRECTORY,
-            inodeWatching: isLinuxOrMacOs,
-            sysLog
-          });
-          const nodeSystem = {
-            args: process.argv.slice(2),
-            newLine: _os.EOL,
-            useCaseSensitiveFileNames,
-            write(s) {
-              process.stdout.write(s);
-            },
-            getWidthOfTerminal() {
-              return process.stdout.columns;
-            },
-            writeOutputIsTTY() {
-              return process.stdout.isTTY;
-            },
-            readFile,
-            writeFile: writeFile2,
-            watchFile: watchFile2,
-            watchDirectory,
-            resolvePath: (path) => _path.resolve(path),
-            fileExists,
-            directoryExists,
-            createDirectory(directoryName) {
-              if (!nodeSystem.directoryExists(directoryName)) {
-                try {
-                  _fs.mkdirSync(directoryName);
-                } catch (e) {
-                  if (e.code !== "EEXIST") {
-                    throw e;
-                  }
-                }
-              }
-            },
-            getExecutingFilePath() {
-              return executingFilePath;
-            },
-            getCurrentDirectory,
-            getDirectories,
-            getEnvironmentVariable(name) {
-              return process.env[name] || "";
-            },
-            readDirectory,
-            getModifiedTime: getModifiedTime3,
-            setModifiedTime,
-            deleteFile,
-            createHash: _crypto ? createSHA256Hash : generateDjb2Hash,
-            createSHA256Hash: _crypto ? createSHA256Hash : void 0,
-            getMemoryUsage() {
-              if (global.gc) {
-                global.gc();
-              }
-              return process.memoryUsage().heapUsed;
-            },
-            getFileSize(path) {
-              try {
-                const stat = statSync(path);
-                if (stat == null ? void 0 : stat.isFile()) {
-                  return stat.size;
-                }
-              } catch {
-              }
-              return 0;
-            },
-            exit(exitCode) {
-              disableCPUProfiler(() => process.exit(exitCode));
-            },
-            enableCPUProfiler,
-            disableCPUProfiler,
-            cpuProfilingEnabled: () => !!activeSession || contains(process.execArgv, "--cpu-prof") || contains(process.execArgv, "--prof"),
-            realpath,
-            debugMode: !!process.env.NODE_INSPECTOR_IPC || !!process.env.VSCODE_INSPECTOR_OPTIONS || some(process.execArgv, (arg) => /^--(inspect|debug)(-brk)?(=\d+)?$/i.test(arg)),
-            tryEnableSourceMapsForHost() {
-              try {
-                  require("source-map-support").install();
-              } catch {
-              }
-            },
-            setTimeout,
-            clearTimeout,
-            clearScreen: () => {
-              process.stdout.write("\x1Bc");
-            },
-            setBlocking: () => {
-              var _a;
-              const handle = (_a = process.stdout) == null ? void 0 : _a._handle;
-              if (handle && handle.setBlocking) {
-                handle.setBlocking(true);
-              }
-            },
-            bufferFrom,
-            base64decode: (input) => bufferFrom(input, "base64").toString("utf8"),
-            base64encode: (input) => bufferFrom(input).toString("base64"),
-            require: (baseDir, moduleName) => {
-              try {
-                const modulePath = resolveJSModule(moduleName, baseDir, nodeSystem);
-                return { module:   require(modulePath), modulePath, error: void 0 };
-              } catch (error) {
-                return { module: void 0, modulePath: void 0, error };
-              }
-            }
-          };
-          return nodeSystem;
-          function statSync(path) {
-            return _fs.statSync(path, { throwIfNoEntry: false });
-          }
-          function enableCPUProfiler(path, cb) {
-            if (activeSession) {
-              cb();
-              return false;
-            }
-            const inspector =   require("inspector");
-            if (!inspector || !inspector.Session) {
-              cb();
-              return false;
-            }
-            const session = new inspector.Session();
-            session.connect();
-            session.post("Profiler.enable", () => {
-              session.post("Profiler.start", () => {
-                activeSession = session;
-                profilePath = path;
-                cb();
-              });
-            });
-            return true;
-          }
-          function cleanupPaths(profile) {
-            let externalFileCounter = 0;
-            const remappedPaths = /* @__PURE__ */ new Map();
-            const normalizedDir = normalizeSlashes(_path.dirname(executingFilePath));
-            const fileUrlRoot = `file://${getRootLength(normalizedDir) === 1 ? "" : "/"}${normalizedDir}`;
-            for (const node of profile.nodes) {
-              if (node.callFrame.url) {
-                const url = normalizeSlashes(node.callFrame.url);
-                if (containsPath(fileUrlRoot, url, useCaseSensitiveFileNames)) {
-                  node.callFrame.url = getRelativePathToDirectoryOrUrl(
-                    fileUrlRoot,
-                    url,
-                    fileUrlRoot,
-                    createGetCanonicalFileName(useCaseSensitiveFileNames),
-                    /*isAbsolutePathAnUrl*/
-                    true
-                  );
-                } else if (!nativePattern.test(url)) {
-                  node.callFrame.url = (remappedPaths.has(url) ? remappedPaths : remappedPaths.set(url, `external${externalFileCounter}.js`)).get(url);
-                  externalFileCounter++;
-                }
-              }
-            }
-            return profile;
-          }
-          function disableCPUProfiler(cb) {
-            if (activeSession && activeSession !== "stopping") {
-              const s = activeSession;
-              activeSession.post("Profiler.stop", (err, { profile }) => {
-                var _a;
-                if (!err) {
-                  try {
-                    if ((_a = statSync(profilePath)) == null ? void 0 : _a.isDirectory()) {
-                      profilePath = _path.join(profilePath, `${(/* @__PURE__ */ new Date()).toISOString().replace(/:/g, "-")}+P${process.pid}.cpuprofile`);
-                    }
-                  } catch {
-                  }
-                  try {
-                    _fs.mkdirSync(_path.dirname(profilePath), { recursive: true });
-                  } catch {
-                  }
-                  _fs.writeFileSync(profilePath, JSON.stringify(cleanupPaths(profile)));
-                }
-                activeSession = void 0;
-                s.disconnect();
-                cb();
-              });
-              activeSession = "stopping";
-              return true;
-            } else {
-              cb();
-              return false;
-            }
-          }
-          function bufferFrom(input, encoding) {
-            return Buffer2.from && Buffer2.from !== Int8Array.from ? Buffer2.from(input, encoding) : new Buffer2(input, encoding);
-          }
-          function isFileSystemCaseSensitive() {
-            if (platform === "win32" || platform === "win64") {
-              return false;
-            }
-            return !fileExists(swapCase(__filename));
-          }
-          function swapCase(s) {
-            return s.replace(/\w/g, (ch) => {
-              const up = ch.toUpperCase();
-              return ch === up ? ch.toLowerCase() : up;
-            });
-          }
-          function fsWatchFileWorker(fileName, callback, pollingInterval) {
-            _fs.watchFile(fileName, { persistent: true, interval: pollingInterval }, fileChanged);
-            let eventKind;
-            return {
-              close: () => _fs.unwatchFile(fileName, fileChanged)
-            };
-            function fileChanged(curr, prev) {
-              const isPreviouslyDeleted = +prev.mtime === 0 || eventKind === 2 /* Deleted */;
-              if (+curr.mtime === 0) {
-                if (isPreviouslyDeleted) {
-                  return;
-                }
-                eventKind = 2 /* Deleted */;
-              } else if (isPreviouslyDeleted) {
-                eventKind = 0 /* Created */;
-              } else if (+curr.mtime === +prev.mtime) {
-                return;
-              } else {
-                eventKind = 1 /* Changed */;
-              }
-              callback(fileName, eventKind, curr.mtime);
-            }
-          }
-          function fsWatchWorker(fileOrDirectory, recursive, callback) {
-            return _fs.watch(
-              fileOrDirectory,
-              fsSupportsRecursiveFsWatch ? { persistent: true, recursive: !!recursive } : { persistent: true },
-              callback
-            );
-          }
-          function readFileWorker(fileName, _encoding) {
-            let buffer;
-            try {
-              buffer = _fs.readFileSync(fileName);
-            } catch (e) {
-              return void 0;
-            }
-            let len = buffer.length;
-            if (len >= 2 && buffer[0] === 254 && buffer[1] === 255) {
-              len &= ~1;
-              for (let i = 0; i < len; i += 2) {
-                const temp = buffer[i];
-                buffer[i] = buffer[i + 1];
-                buffer[i + 1] = temp;
-              }
-              return buffer.toString("utf16le", 2);
-            }
-            if (len >= 2 && buffer[0] === 255 && buffer[1] === 254) {
-              return buffer.toString("utf16le", 2);
-            }
-            if (len >= 3 && buffer[0] === 239 && buffer[1] === 187 && buffer[2] === 191) {
-              return buffer.toString("utf8", 3);
-            }
-            return buffer.toString("utf8");
-          }
-          function readFile(fileName, _encoding) {
-            var _a, _b;
-            (_a = perfLogger) == null ? void 0 : _a.logStartReadFile(fileName);
-            const file = readFileWorker(fileName, _encoding);
-            (_b = perfLogger) == null ? void 0 : _b.logStopReadFile();
-            return file;
-          }
-          function writeFile2(fileName, data, writeByteOrderMark) {
-            var _a;
-            (_a = perfLogger) == null ? void 0 : _a.logEvent("WriteFile: " + fileName);
-            if (writeByteOrderMark) {
-              data = byteOrderMarkIndicator + data;
-            }
-            let fd;
-            try {
-              fd = _fs.openSync(fileName, "w");
-              _fs.writeSync(
-                fd,
-                data,
-                /*position*/
-                void 0,
-                "utf8"
-              );
-            } finally {
-              if (fd !== void 0) {
-                _fs.closeSync(fd);
-              }
-            }
-          }
-          function getAccessibleFileSystemEntries(path) {
-            var _a;
-            (_a = perfLogger) == null ? void 0 : _a.logEvent("ReadDir: " + (path || "."));
-            try {
-              const entries = _fs.readdirSync(path || ".", { withFileTypes: true });
-              const files = [];
-              const directories = [];
-              for (const dirent of entries) {
-                const entry = typeof dirent === "string" ? dirent : dirent.name;
-                if (entry === "." || entry === "..") {
-                  continue;
-                }
-                let stat;
-                if (typeof dirent === "string" || dirent.isSymbolicLink()) {
-                  const name = combinePaths(path, entry);
-                  try {
-                    stat = statSync(name);
-                    if (!stat) {
-                      continue;
-                    }
-                  } catch (e) {
-                    continue;
-                  }
-                } else {
-                  stat = dirent;
-                }
-                if (stat.isFile()) {
-                  files.push(entry);
-                } else if (stat.isDirectory()) {
-                  directories.push(entry);
-                }
-              }
-              files.sort();
-              directories.sort();
-              return { files, directories };
-            } catch (e) {
-              return emptyFileSystemEntries;
-            }
-          }
-          function readDirectory(path, extensions, excludes, includes, depth) {
-            return matchFiles(path, extensions, excludes, includes, useCaseSensitiveFileNames, process.cwd(), depth, getAccessibleFileSystemEntries, realpath);
-          }
-          function fileSystemEntryExists(path, entryKind) {
-            const originalStackTraceLimit = Error.stackTraceLimit;
-            Error.stackTraceLimit = 0;
-            try {
-              const stat = statSync(path);
-              if (!stat) {
-                return false;
-              }
-              switch (entryKind) {
-                case 0 /* File */:
-                  return stat.isFile();
-                case 1 /* Directory */:
-                  return stat.isDirectory();
-                default:
-                  return false;
-              }
-            } catch (e) {
-              return false;
-            } finally {
-              Error.stackTraceLimit = originalStackTraceLimit;
-            }
-          }
-          function fileExists(path) {
-            return fileSystemEntryExists(path, 0 /* File */);
-          }
-          function directoryExists(path) {
-            return fileSystemEntryExists(path, 1 /* Directory */);
-          }
-          function getDirectories(path) {
-            return getAccessibleFileSystemEntries(path).directories.slice();
-          }
-          function fsRealPathHandlingLongPath(path) {
-            return path.length < 260 ? _fs.realpathSync.native(path) : _fs.realpathSync(path);
-          }
-          function realpath(path) {
-            try {
-              return fsRealpath(path);
-            } catch {
-              return path;
-            }
-          }
-          function getModifiedTime3(path) {
-            var _a;
-            const originalStackTraceLimit = Error.stackTraceLimit;
-            Error.stackTraceLimit = 0;
-            try {
-              return (_a = statSync(path)) == null ? void 0 : _a.mtime;
-            } catch (e) {
-              return void 0;
-            } finally {
-              Error.stackTraceLimit = originalStackTraceLimit;
-            }
-          }
-          function setModifiedTime(path, time) {
-            try {
-              _fs.utimesSync(path, time, time);
-            } catch (e) {
-              return;
-            }
-          }
-          function deleteFile(path) {
-            try {
-              return _fs.unlinkSync(path);
-            } catch (e) {
-              return;
-            }
-          }
-          function createSHA256Hash(data) {
-            const hash = _crypto.createHash("sha256");
-            hash.update(data);
-            return hash.digest("hex");
-          }
-        }
-        let sys2;
-        if (isNodeLikeSystem()) {
-          sys2 = getNodeSystem();
-        }
-        if (sys2) {
-          patchWriteFileEnsuringDirectory(sys2);
-        }
-        return sys2;
-      })();
-      if (sys && sys.getEnvironmentVariable) {
-        setCustomPollingValues(sys);
-        Debug.setAssertionLevel(/^development$/i.test(sys.getEnvironmentVariable("NODE_ENV")) ? 1 /* Normal */ : 0 /* None */);
-      }
-      if (sys && sys.debugMode) {
-        Debug.isDebugging = true;
-      }
-    }
-  });
-
-  // src/compiler/path.ts
-  function isAnyDirectorySeparator(charCode) {
-    return charCode === 47 /* slash */ || charCode === 92 /* backslash */;
-  }
-  function isUrl(path) {
-    return getEncodedRootLength(path) < 0;
-  }
-  function isRootedDiskPath(path) {
-    return getEncodedRootLength(path) > 0;
-  }
-  function isDiskPathRoot(path) {
-    const rootLength = getEncodedRootLength(path);
-    return rootLength > 0 && rootLength === path.length;
-  }
-  function pathIsAbsolute(path) {
-    return getEncodedRootLength(path) !== 0;
-  }
-  function pathIsRelative(path) {
-    return /^\.\.?($|[\\/])/.test(path);
-  }
-  function pathIsBareSpecifier(path) {
-    return !pathIsAbsolute(path) && !pathIsRelative(path);
-  }
-  function hasExtension(fileName) {
-    return stringContains(getBaseFileName(fileName), ".");
-  }
-  function fileExtensionIs(path, extension) {
-    return path.length > extension.length && endsWith(path, extension);
-  }
-  function fileExtensionIsOneOf(path, extensions) {
-    for (const extension of extensions) {
-      if (fileExtensionIs(path, extension)) {
-        return true;
-      }
-    }
-    return false;
-  }
-  function hasTrailingDirectorySeparator(path) {
-    return path.length > 0 && isAnyDirectorySeparator(path.charCodeAt(path.length - 1));
-  }
-  function isVolumeCharacter(charCode) {
-    return charCode >= 97 /* a */ && charCode <= 122 /* z */ || charCode >= 65 /* A */ && charCode <= 90 /* Z */;
-  }
-  function getFileUrlVolumeSeparatorEnd(url, start) {
-    const ch0 = url.charCodeAt(start);
-    if (ch0 === 58 /* colon */)
-      return start + 1;
-    if (ch0 === 37 /* percent */ && url.charCodeAt(start + 1) === 51 /* _3 */) {
-      const ch2 = url.charCodeAt(start + 2);
-      if (ch2 === 97 /* a */ || ch2 === 65 /* A */)
-        return start + 3;
-    }
-    return -1;
-  }
-  function getEncodedRootLength(path) {
-    if (!path)
-      return 0;
-    const ch0 = path.charCodeAt(0);
-    if (ch0 === 47 /* slash */ || ch0 === 92 /* backslash */) {
-      if (path.charCodeAt(1) !== ch0)
-        return 1;
-      const p1 = path.indexOf(ch0 === 47 /* slash */ ? directorySeparator : altDirectorySeparator, 2);
-      if (p1 < 0)
-        return path.length;
-      return p1 + 1;
-    }
-    if (isVolumeCharacter(ch0) && path.charCodeAt(1) === 58 /* colon */) {
-      const ch2 = path.charCodeAt(2);
-      if (ch2 === 47 /* slash */ || ch2 === 92 /* backslash */)
-        return 3;
-      if (path.length === 2)
-        return 2;
-    }
-    const schemeEnd = path.indexOf(urlSchemeSeparator);
-    if (schemeEnd !== -1) {
-      const authorityStart = schemeEnd + urlSchemeSeparator.length;
-      const authorityEnd = path.indexOf(directorySeparator, authorityStart);
-      if (authorityEnd !== -1) {
-        const scheme = path.slice(0, schemeEnd);
-        const authority = path.slice(authorityStart, authorityEnd);
-        if (scheme === "file" && (authority === "" || authority === "localhost") && isVolumeCharacter(path.charCodeAt(authorityEnd + 1))) {
-          const volumeSeparatorEnd = getFileUrlVolumeSeparatorEnd(path, authorityEnd + 2);
-          if (volumeSeparatorEnd !== -1) {
-            if (path.charCodeAt(volumeSeparatorEnd) === 47 /* slash */) {
-              return ~(volumeSeparatorEnd + 1);
-            }
-            if (volumeSeparatorEnd === path.length) {
-              return ~volumeSeparatorEnd;
-            }
-          }
-        }
-        return ~(authorityEnd + 1);
-      }
-      return ~path.length;
-    }
-    return 0;
-  }
-  function getRootLength(path) {
-    const rootLength = getEncodedRootLength(path);
-    return rootLength < 0 ? ~rootLength : rootLength;
-  }
-  function getDirectoryPath(path) {
-    path = normalizeSlashes(path);
-    const rootLength = getRootLength(path);
-    if (rootLength === path.length)
-      return path;
-    path = removeTrailingDirectorySeparator(path);
-    return path.slice(0, Math.max(rootLength, path.lastIndexOf(directorySeparator)));
-  }
-  function getBaseFileName(path, extensions, ignoreCase) {
-    path = normalizeSlashes(path);
-    const rootLength = getRootLength(path);
-    if (rootLength === path.length)
-      return "";
-    path = removeTrailingDirectorySeparator(path);
-    const name = path.slice(Math.max(getRootLength(path), path.lastIndexOf(directorySeparator) + 1));
-    const extension = extensions !== void 0 && ignoreCase !== void 0 ? getAnyExtensionFromPath(name, extensions, ignoreCase) : void 0;
-    return extension ? name.slice(0, name.length - extension.length) : name;
-  }
-  function tryGetExtensionFromPath(path, extension, stringEqualityComparer) {
-    if (!startsWith(extension, "."))
-      extension = "." + extension;
-    if (path.length >= extension.length && path.charCodeAt(path.length - extension.length) === 46 /* dot */) {
-      const pathExtension = path.slice(path.length - extension.length);
-      if (stringEqualityComparer(pathExtension, extension)) {
-        return pathExtension;
-      }
-    }
-  }
-  function getAnyExtensionFromPathWorker(path, extensions, stringEqualityComparer) {
-    if (typeof extensions === "string") {
-      return tryGetExtensionFromPath(path, extensions, stringEqualityComparer) || "";
-    }
-    for (const extension of extensions) {
-      const result = tryGetExtensionFromPath(path, extension, stringEqualityComparer);
-      if (result)
-        return result;
-    }
-    return "";
-  }
-  function getAnyExtensionFromPath(path, extensions, ignoreCase) {
-    if (extensions) {
-      return getAnyExtensionFromPathWorker(removeTrailingDirectorySeparator(path), extensions, ignoreCase ? equateStringsCaseInsensitive : equateStringsCaseSensitive);
-    }
-    const baseFileName = getBaseFileName(path);
-    const extensionIndex = baseFileName.lastIndexOf(".");
-    if (extensionIndex >= 0) {
-      return baseFileName.substring(extensionIndex);
-    }
-    return "";
-  }
-  function pathComponents(path, rootLength) {
-    const root = path.substring(0, rootLength);
-    const rest = path.substring(rootLength).split(directorySeparator);
-    if (rest.length && !lastOrUndefined(rest))
-      rest.pop();
-    return [root, ...rest];
-  }
-  function getPathComponents(path, currentDirectory = "") {
-    path = combinePaths(currentDirectory, path);
-    return pathComponents(path, getRootLength(path));
-  }
-  function getPathFromPathComponents(pathComponents2, length2) {
-    if (pathComponents2.length === 0)
-      return "";
-    const root = pathComponents2[0] && ensureTrailingDirectorySeparator(pathComponents2[0]);
-    return root + pathComponents2.slice(1, length2).join(directorySeparator);
-  }
-  function normalizeSlashes(path) {
-    return path.indexOf("\\") !== -1 ? path.replace(backslashRegExp, directorySeparator) : path;
-  }
-  function reducePathComponents(components) {
-    if (!some(components))
-      return [];
-    const reduced = [components[0]];
-    for (let i = 1; i < components.length; i++) {
-      const component = components[i];
-      if (!component)
-        continue;
-      if (component === ".")
-        continue;
-      if (component === "..") {
-        if (reduced.length > 1) {
-          if (reduced[reduced.length - 1] !== "..") {
-            reduced.pop();
-            continue;
-          }
-        } else if (reduced[0])
-          continue;
-      }
-      reduced.push(component);
-    }
-    return reduced;
-  }
-  function combinePaths(path, ...paths) {
-    if (path)
-      path = normalizeSlashes(path);
-    for (let relativePath of paths) {
-      if (!relativePath)
-        continue;
-      relativePath = normalizeSlashes(relativePath);
-      if (!path || getRootLength(relativePath) !== 0) {
-        path = relativePath;
-      } else {
-        path = ensureTrailingDirectorySeparator(path) + relativePath;
-      }
-    }
-    return path;
-  }
-  function resolvePath(path, ...paths) {
-    return normalizePath(some(paths) ? combinePaths(path, ...paths) : normalizeSlashes(path));
-  }
-  function getNormalizedPathComponents(path, currentDirectory) {
-    return reducePathComponents(getPathComponents(path, currentDirectory));
-  }
-  function getNormalizedAbsolutePath(fileName, currentDirectory) {
-    return getPathFromPathComponents(getNormalizedPathComponents(fileName, currentDirectory));
-  }
-  function normalizePath(path) {
-    path = normalizeSlashes(path);
-    if (!relativePathSegmentRegExp.test(path)) {
-      return path;
-    }
-    const simplified = path.replace(/\/\.\//g, "/").replace(/^\.\//, "");
-    if (simplified !== path) {
-      path = simplified;
-      if (!relativePathSegmentRegExp.test(path)) {
-        return path;
-      }
-    }
-    const normalized = getPathFromPathComponents(reducePathComponents(getPathComponents(path)));
-    return normalized && hasTrailingDirectorySeparator(path) ? ensureTrailingDirectorySeparator(normalized) : normalized;
-  }
-  function getPathWithoutRoot(pathComponents2) {
-    if (pathComponents2.length === 0)
-      return "";
-    return pathComponents2.slice(1).join(directorySeparator);
-  }
-  function getNormalizedAbsolutePathWithoutRoot(fileName, currentDirectory) {
-    return getPathWithoutRoot(getNormalizedPathComponents(fileName, currentDirectory));
-  }
-  function toPath(fileName, basePath, getCanonicalFileName) {
-    const nonCanonicalizedPath = isRootedDiskPath(fileName) ? normalizePath(fileName) : getNormalizedAbsolutePath(fileName, basePath);
-    return getCanonicalFileName(nonCanonicalizedPath);
-  }
-  function removeTrailingDirectorySeparator(path) {
-    if (hasTrailingDirectorySeparator(path)) {
-      return path.substr(0, path.length - 1);
-    }
-    return path;
-  }
-  function ensureTrailingDirectorySeparator(path) {
-    if (!hasTrailingDirectorySeparator(path)) {
-      return path + directorySeparator;
-    }
-    return path;
-  }
-  function ensurePathIsNonModuleName(path) {
-    return !pathIsAbsolute(path) && !pathIsRelative(path) ? "./" + path : path;
-  }
-  function changeAnyExtension(path, ext, extensions, ignoreCase) {
-    const pathext = extensions !== void 0 && ignoreCase !== void 0 ? getAnyExtensionFromPath(path, extensions, ignoreCase) : getAnyExtensionFromPath(path);
-    return pathext ? path.slice(0, path.length - pathext.length) + (startsWith(ext, ".") ? ext : "." + ext) : path;
-  }
-  function comparePathsWorker(a, b, componentComparer) {
-    if (a === b)
-      return 0 /* EqualTo */;
-    if (a === void 0)
-      return -1 /* LessThan */;
-    if (b === void 0)
-      return 1 /* GreaterThan */;
-    const aRoot = a.substring(0, getRootLength(a));
-    const bRoot = b.substring(0, getRootLength(b));
-    const result = compareStringsCaseInsensitive(aRoot, bRoot);
-    if (result !== 0 /* EqualTo */) {
-      return result;
-    }
-    const aRest = a.substring(aRoot.length);
-    const bRest = b.substring(bRoot.length);
-    if (!relativePathSegmentRegExp.test(aRest) && !relativePathSegmentRegExp.test(bRest)) {
-      return componentComparer(aRest, bRest);
-    }
-    const aComponents = reducePathComponents(getPathComponents(a));
-    const bComponents = reducePathComponents(getPathComponents(b));
-    const sharedLength = Math.min(aComponents.length, bComponents.length);
-    for (let i = 1; i < sharedLength; i++) {
-      const result2 = componentComparer(aComponents[i], bComponents[i]);
-      if (result2 !== 0 /* EqualTo */) {
-        return result2;
-      }
-    }
-    return compareValues(aComponents.length, bComponents.length);
-  }
-  function comparePathsCaseSensitive(a, b) {
-    return comparePathsWorker(a, b, compareStringsCaseSensitive);
-  }
-  function comparePathsCaseInsensitive(a, b) {
-    return comparePathsWorker(a, b, compareStringsCaseInsensitive);
-  }
-  function comparePaths(a, b, currentDirectory, ignoreCase) {
-    if (typeof currentDirectory === "string") {
-      a = combinePaths(currentDirectory, a);
-      b = combinePaths(currentDirectory, b);
-    } else if (typeof currentDirectory === "boolean") {
-      ignoreCase = currentDirectory;
-    }
-    return comparePathsWorker(a, b, getStringComparer(ignoreCase));
-  }
-  function containsPath(parent2, child, currentDirectory, ignoreCase) {
-    if (typeof currentDirectory === "string") {
-      parent2 = combinePaths(currentDirectory, parent2);
-      child = combinePaths(currentDirectory, child);
-    } else if (typeof currentDirectory === "boolean") {
-      ignoreCase = currentDirectory;
-    }
-    if (parent2 === void 0 || child === void 0)
-      return false;
-    if (parent2 === child)
-      return true;
-    const parentComponents = reducePathComponents(getPathComponents(parent2));
-    const childComponents = reducePathComponents(getPathComponents(child));
-    if (childComponents.length < parentComponents.length) {
-      return false;
-    }
-    const componentEqualityComparer = ignoreCase ? equateStringsCaseInsensitive : equateStringsCaseSensitive;
-    for (let i = 0; i < parentComponents.length; i++) {
-      const equalityComparer = i === 0 ? equateStringsCaseInsensitive : componentEqualityComparer;
-      if (!equalityComparer(parentComponents[i], childComponents[i])) {
-        return false;
-      }
-    }
-    return true;
-  }
-  function startsWithDirectory(fileName, directoryName, getCanonicalFileName) {
-    const canonicalFileName = getCanonicalFileName(fileName);
-    const canonicalDirectoryName = getCanonicalFileName(directoryName);
-    return startsWith(canonicalFileName, canonicalDirectoryName + "/") || startsWith(canonicalFileName, canonicalDirectoryName + "\\");
-  }
-  function getPathComponentsRelativeTo(from, to, stringEqualityComparer, getCanonicalFileName) {
-    const fromComponents = reducePathComponents(getPathComponents(from));
-    const toComponents = reducePathComponents(getPathComponents(to));
-    let start;
-    for (start = 0; start < fromComponents.length && start < toComponents.length; start++) {
-      const fromComponent = getCanonicalFileName(fromComponents[start]);
-      const toComponent = getCanonicalFileName(toComponents[start]);
-      const comparer = start === 0 ? equateStringsCaseInsensitive : stringEqualityComparer;
-      if (!comparer(fromComponent, toComponent))
-        break;
-    }
-    if (start === 0) {
-      return toComponents;
-    }
-    const components = toComponents.slice(start);
-    const relative = [];
-    for (; start < fromComponents.length; start++) {
-      relative.push("..");
-    }
-    return ["", ...relative, ...components];
-  }
-  function getRelativePathFromDirectory(fromDirectory, to, getCanonicalFileNameOrIgnoreCase) {
-    Debug.assert(getRootLength(fromDirectory) > 0 === getRootLength(to) > 0, "Paths must either both be absolute or both be relative");
-    const getCanonicalFileName = typeof getCanonicalFileNameOrIgnoreCase === "function" ? getCanonicalFileNameOrIgnoreCase : identity;
-    const ignoreCase = typeof getCanonicalFileNameOrIgnoreCase === "boolean" ? getCanonicalFileNameOrIgnoreCase : false;
-    const pathComponents2 = getPathComponentsRelativeTo(fromDirectory, to, ignoreCase ? equateStringsCaseInsensitive : equateStringsCaseSensitive, getCanonicalFileName);
-    return getPathFromPathComponents(pathComponents2);
-  }
-  function convertToRelativePath(absoluteOrRelativePath, basePath, getCanonicalFileName) {
-    return !isRootedDiskPath(absoluteOrRelativePath) ? absoluteOrRelativePath : getRelativePathToDirectoryOrUrl(
-      basePath,
-      absoluteOrRelativePath,
-      basePath,
-      getCanonicalFileName,
-      /*isAbsolutePathAnUrl*/
-      false
-    );
-  }
-  function getRelativePathFromFile(from, to, getCanonicalFileName) {
-    return ensurePathIsNonModuleName(getRelativePathFromDirectory(getDirectoryPath(from), to, getCanonicalFileName));
-  }
-  function getRelativePathToDirectoryOrUrl(directoryPathOrUrl, relativeOrAbsolutePath, currentDirectory, getCanonicalFileName, isAbsolutePathAnUrl) {
-    const pathComponents2 = getPathComponentsRelativeTo(
-      resolvePath(currentDirectory, directoryPathOrUrl),
-      resolvePath(currentDirectory, relativeOrAbsolutePath),
-      equateStringsCaseSensitive,
-      getCanonicalFileName
-    );
-    const firstComponent = pathComponents2[0];
-    if (isAbsolutePathAnUrl && isRootedDiskPath(firstComponent)) {
-      const prefix = firstComponent.charAt(0) === directorySeparator ? "file://" : "file:///";
-      pathComponents2[0] = prefix + firstComponent;
-    }
-    return getPathFromPathComponents(pathComponents2);
-  }
-  function forEachAncestorDirectory(directory, callback) {
-    while (true) {
-      const result = callback(directory);
-      if (result !== void 0) {
-        return result;
-      }
-      const parentPath = getDirectoryPath(directory);
-      if (parentPath === directory) {
-        return void 0;
-      }
-      directory = parentPath;
-    }
-  }
-  function isNodeModulesDirectory(dirPath) {
-    return endsWith(dirPath, "/node_modules");
-  }
-  var directorySeparator, altDirectorySeparator, urlSchemeSeparator, backslashRegExp, relativePathSegmentRegExp;
-  var init_path = __esm({
-    "src/compiler/path.ts"() {
-      "use strict";
-      init_ts2();
-      directorySeparator = "/";
-      altDirectorySeparator = "\\";
-      urlSchemeSeparator = "://";
-      backslashRegExp = /\\/g;
-      relativePathSegmentRegExp = /(?:\/\/)|(?:^|\/)\.\.?(?:$|\/)/;
-    }
-  });
-
-  // src/compiler/diagnosticInformationMap.generated.ts
-  function diag(code, category, key, message, reportsUnnecessary, elidedInCompatabilityPyramid, reportsDeprecated) {
-    return { code, category, key, message, reportsUnnecessary, elidedInCompatabilityPyramid, reportsDeprecated };
-  }
-  var Diagnostics;
-  var init_diagnosticInformationMap_generated = __esm({
-    "src/compiler/diagnosticInformationMap.generated.ts"() {
-      "use strict";
-      init_types();
-      Diagnostics = {
-        Unterminated_string_literal: diag(1002, 1 /* Error */, "Unterminated_string_literal_1002", "Unterminated string literal."),
-        Identifier_expected: diag(1003, 1 /* Error */, "Identifier_expected_1003", "Identifier expected."),
-        _0_expected: diag(1005, 1 /* Error */, "_0_expected_1005", "'{0}' expected."),
-        A_file_cannot_have_a_reference_to_itself: diag(1006, 1 /* Error */, "A_file_cannot_have_a_reference_to_itself_1006", "A file cannot have a reference to itself."),
-        The_parser_expected_to_find_a_1_to_match_the_0_token_here: diag(1007, 1 /* Error */, "The_parser_expected_to_find_a_1_to_match_the_0_token_here_1007", "The parser expected to find a '{1}' to match the '{0}' token here."),
-        Trailing_comma_not_allowed: diag(1009, 1 /* Error */, "Trailing_comma_not_allowed_1009", "Trailing comma not allowed."),
-        Asterisk_Slash_expected: diag(1010, 1 /* Error */, "Asterisk_Slash_expected_1010", "'*/' expected."),
-        An_element_access_expression_should_take_an_argument: diag(1011, 1 /* Error */, "An_element_access_expression_should_take_an_argument_1011", "An element access expression should take an argument."),
-        Unexpected_token: diag(1012, 1 /* Error */, "Unexpected_token_1012", "Unexpected token."),
-        A_rest_parameter_or_binding_pattern_may_not_have_a_trailing_comma: diag(1013, 1 /* Error */, "A_rest_parameter_or_binding_pattern_may_not_have_a_trailing_comma_1013", "A rest parameter or binding pattern may not have a trailing comma."),
-        A_rest_parameter_must_be_last_in_a_parameter_list: diag(1014, 1 /* Error */, "A_rest_parameter_must_be_last_in_a_parameter_list_1014", "A rest parameter must be last in a parameter list."),
-        Parameter_cannot_have_question_mark_and_initializer: diag(1015, 1 /* Error */, "Parameter_cannot_have_question_mark_and_initializer_1015", "Parameter cannot have question mark and initializer."),
-        A_required_parameter_cannot_follow_an_optional_parameter: diag(1016, 1 /* Error */, "A_required_parameter_cannot_follow_an_optional_parameter_1016", "A required parameter cannot follow an optional parameter."),
-        An_index_signature_cannot_have_a_rest_parameter: diag(1017, 1 /* Error */, "An_index_signature_cannot_have_a_rest_parameter_1017", "An index signature cannot have a rest parameter."),
-        An_index_signature_parameter_cannot_have_an_accessibility_modifier: diag(1018, 1 /* Error */, "An_index_signature_parameter_cannot_have_an_accessibility_modifier_1018", "An index signature parameter cannot have an accessibility modifier."),
-        An_index_signature_parameter_cannot_have_a_question_mark: diag(1019, 1 /* Error */, "An_index_signature_parameter_cannot_have_a_question_mark_1019", "An index signature parameter cannot have a question mark."),
-        An_index_signature_parameter_cannot_have_an_initializer: diag(1020, 1 /* Error */, "An_index_signature_parameter_cannot_have_an_initializer_1020", "An index signature parameter cannot have an initializer."),
-        An_index_signature_must_have_a_type_annotation: diag(1021, 1 /* Error */, "An_index_signature_must_have_a_type_annotation_1021", "An index signature must have a type annotation."),
-        An_index_signature_parameter_must_have_a_type_annotation: diag(1022, 1 /* Error */, "An_index_signature_parameter_must_have_a_type_annotation_1022", "An index signature parameter must have a type annotation."),
-        readonly_modifier_can_only_appear_on_a_property_declaration_or_index_signature: diag(1024, 1 /* Error */, "readonly_modifier_can_only_appear_on_a_property_declaration_or_index_signature_1024", "'readonly' modifier can only appear on a property declaration or index signature."),
-        An_index_signature_cannot_have_a_trailing_comma: diag(1025, 1 /* Error */, "An_index_signature_cannot_have_a_trailing_comma_1025", "An index signature cannot have a trailing comma."),
-        Accessibility_modifier_already_seen: diag(1028, 1 /* Error */, "Accessibility_modifier_already_seen_1028", "Accessibility modifier already seen."),
-        _0_modifier_must_precede_1_modifier: diag(1029, 1 /* Error */, "_0_modifier_must_precede_1_modifier_1029", "'{0}' modifier must precede '{1}' modifier."),
-        _0_modifier_already_seen: diag(1030, 1 /* Error */, "_0_modifier_already_seen_1030", "'{0}' modifier already seen."),
-        _0_modifier_cannot_appear_on_class_elements_of_this_kind: diag(1031, 1 /* Error */, "_0_modifier_cannot_appear_on_class_elements_of_this_kind_1031", "'{0}' modifier cannot appear on class elements of this kind."),
-        super_must_be_followed_by_an_argument_list_or_member_access: diag(1034, 1 /* Error */, "super_must_be_followed_by_an_argument_list_or_member_access_1034", "'super' must be followed by an argument list or member access."),
-        Only_ambient_modules_can_use_quoted_names: diag(1035, 1 /* Error */, "Only_ambient_modules_can_use_quoted_names_1035", "Only ambient modules can use quoted names."),
-        Statements_are_not_allowed_in_ambient_contexts: diag(1036, 1 /* Error */, "Statements_are_not_allowed_in_ambient_contexts_1036", "Statements are not allowed in ambient contexts."),
-        A_declare_modifier_cannot_be_used_in_an_already_ambient_context: diag(1038, 1 /* Error */, "A_declare_modifier_cannot_be_used_in_an_already_ambient_context_1038", "A 'declare' modifier cannot be used in an already ambient context."),
-        Initializers_are_not_allowed_in_ambient_contexts: diag(1039, 1 /* Error */, "Initializers_are_not_allowed_in_ambient_contexts_1039", "Initializers are not allowed in ambient contexts."),
-        _0_modifier_cannot_be_used_in_an_ambient_context: diag(1040, 1 /* Error */, "_0_modifier_cannot_be_used_in_an_ambient_context_1040", "'{0}' modifier cannot be used in an ambient context."),
-        _0_modifier_cannot_be_used_here: diag(1042, 1 /* Error */, "_0_modifier_cannot_be_used_here_1042", "'{0}' modifier cannot be used here."),
-        _0_modifier_cannot_appear_on_a_module_or_namespace_element: diag(1044, 1 /* Error */, "_0_modifier_cannot_appear_on_a_module_or_namespace_element_1044", "'{0}' modifier cannot appear on a module or namespace element."),
-        Top_level_declarations_in_d_ts_files_must_start_with_either_a_declare_or_export_modifier: diag(1046, 1 /* Error */, "Top_level_declarations_in_d_ts_files_must_start_with_either_a_declare_or_export_modifier_1046", "Top-level declarations in .d.ts files must start with either a 'declare' or 'export' modifier."),
-        A_rest_parameter_cannot_be_optional: diag(1047, 1 /* Error */, "A_rest_parameter_cannot_be_optional_1047", "A rest parameter cannot be optional."),
-        A_rest_parameter_cannot_have_an_initializer: diag(1048, 1 /* Error */, "A_rest_parameter_cannot_have_an_initializer_1048", "A rest parameter cannot have an initializer."),
-        A_set_accessor_must_have_exactly_one_parameter: diag(1049, 1 /* Error */, "A_set_accessor_must_have_exactly_one_parameter_1049", "A 'set' accessor must have exactly one parameter."),
-        A_set_accessor_cannot_have_an_optional_parameter: diag(1051, 1 /* Error */, "A_set_accessor_cannot_have_an_optional_parameter_1051", "A 'set' accessor cannot have an optional parameter."),
-        A_set_accessor_parameter_cannot_have_an_initializer: diag(1052, 1 /* Error */, "A_set_accessor_parameter_cannot_have_an_initializer_1052", "A 'set' accessor parameter cannot have an initializer."),
-        A_set_accessor_cannot_have_rest_parameter: diag(1053, 1 /* Error */, "A_set_accessor_cannot_have_rest_parameter_1053", "A 'set' accessor cannot have rest parameter."),
-        A_get_accessor_cannot_have_parameters: diag(1054, 1 /* Error */, "A_get_accessor_cannot_have_parameters_1054", "A 'get' accessor cannot have parameters."),
-        Type_0_is_not_a_valid_async_function_return_type_in_ES5_SlashES3_because_it_does_not_refer_to_a_Promise_compatible_constructor_value: diag(1055, 1 /* Error */, "Type_0_is_not_a_valid_async_function_return_type_in_ES5_SlashES3_because_it_does_not_refer_to_a_Prom_1055", "Type '{0}' is not a valid async function return type in ES5/ES3 because it does not refer to a Promise-compatible constructor value."),
-        Accessors_are_only_available_when_targeting_ECMAScript_5_and_higher: diag(1056, 1 /* Error */, "Accessors_are_only_available_when_targeting_ECMAScript_5_and_higher_1056", "Accessors are only available when targeting ECMAScript 5 and higher."),
-        The_return_type_of_an_async_function_must_either_be_a_valid_promise_or_must_not_contain_a_callable_then_member: diag(1058, 1 /* Error */, "The_return_type_of_an_async_function_must_either_be_a_valid_promise_or_must_not_contain_a_callable_t_1058", "The return type of an async function must either be a valid promise or must not contain a callable 'then' member."),
-        A_promise_must_have_a_then_method: diag(1059, 1 /* Error */, "A_promise_must_have_a_then_method_1059", "A promise must have a 'then' method."),
-        The_first_parameter_of_the_then_method_of_a_promise_must_be_a_callback: diag(1060, 1 /* Error */, "The_first_parameter_of_the_then_method_of_a_promise_must_be_a_callback_1060", "The first parameter of the 'then' method of a promise must be a callback."),
-        Enum_member_must_have_initializer: diag(1061, 1 /* Error */, "Enum_member_must_have_initializer_1061", "Enum member must have initializer."),
-        Type_is_referenced_directly_or_indirectly_in_the_fulfillment_callback_of_its_own_then_method: diag(1062, 1 /* Error */, "Type_is_referenced_directly_or_indirectly_in_the_fulfillment_callback_of_its_own_then_method_1062", "Type is referenced directly or indirectly in the fulfillment callback of its own 'then' method."),
-        An_export_assignment_cannot_be_used_in_a_namespace: diag(1063, 1 /* Error */, "An_export_assignment_cannot_be_used_in_a_namespace_1063", "An export assignment cannot be used in a namespace."),
-        The_return_type_of_an_async_function_or_method_must_be_the_global_Promise_T_type_Did_you_mean_to_write_Promise_0: diag(1064, 1 /* Error */, "The_return_type_of_an_async_function_or_method_must_be_the_global_Promise_T_type_Did_you_mean_to_wri_1064", "The return type of an async function or method must be the global Promise type. Did you mean to write 'Promise<{0}>'?"),
-        In_ambient_enum_declarations_member_initializer_must_be_constant_expression: diag(1066, 1 /* Error */, "In_ambient_enum_declarations_member_initializer_must_be_constant_expression_1066", "In ambient enum declarations member initializer must be constant expression."),
-        Unexpected_token_A_constructor_method_accessor_or_property_was_expected: diag(1068, 1 /* Error */, "Unexpected_token_A_constructor_method_accessor_or_property_was_expected_1068", "Unexpected token. A constructor, method, accessor, or property was expected."),
-        Unexpected_token_A_type_parameter_name_was_expected_without_curly_braces: diag(1069, 1 /* Error */, "Unexpected_token_A_type_parameter_name_was_expected_without_curly_braces_1069", "Unexpected token. A type parameter name was expected without curly braces."),
-        _0_modifier_cannot_appear_on_a_type_member: diag(1070, 1 /* Error */, "_0_modifier_cannot_appear_on_a_type_member_1070", "'{0}' modifier cannot appear on a type member."),
-        _0_modifier_cannot_appear_on_an_index_signature: diag(1071, 1 /* Error */, "_0_modifier_cannot_appear_on_an_index_signature_1071", "'{0}' modifier cannot appear on an index signature."),
-        A_0_modifier_cannot_be_used_with_an_import_declaration: diag(1079, 1 /* Error */, "A_0_modifier_cannot_be_used_with_an_import_declaration_1079", "A '{0}' modifier cannot be used with an import declaration."),
-        Invalid_reference_directive_syntax: diag(1084, 1 /* Error */, "Invalid_reference_directive_syntax_1084", "Invalid 'reference' directive syntax."),
-        _0_modifier_cannot_appear_on_a_constructor_declaration: diag(1089, 1 /* Error */, "_0_modifier_cannot_appear_on_a_constructor_declaration_1089", "'{0}' modifier cannot appear on a constructor declaration."),
-        _0_modifier_cannot_appear_on_a_parameter: diag(1090, 1 /* Error */, "_0_modifier_cannot_appear_on_a_parameter_1090", "'{0}' modifier cannot appear on a parameter."),
-        Only_a_single_variable_declaration_is_allowed_in_a_for_in_statement: diag(1091, 1 /* Error */, "Only_a_single_variable_declaration_is_allowed_in_a_for_in_statement_1091", "Only a single variable declaration is allowed in a 'for...in' statement."),
-        Type_parameters_cannot_appear_on_a_constructor_declaration: diag(1092, 1 /* Error */, "Type_parameters_cannot_appear_on_a_constructor_declaration_1092", "Type parameters cannot appear on a constructor declaration."),
-        Type_annotation_cannot_appear_on_a_constructor_declaration: diag(1093, 1 /* Error */, "Type_annotation_cannot_appear_on_a_constructor_declaration_1093", "Type annotation cannot appear on a constructor declaration."),
-        An_accessor_cannot_have_type_parameters: diag(1094, 1 /* Error */, "An_accessor_cannot_have_type_parameters_1094", "An accessor cannot have type parameters."),
-        A_set_accessor_cannot_have_a_return_type_annotation: diag(1095, 1 /* Error */, "A_set_accessor_cannot_have_a_return_type_annotation_1095", "A 'set' accessor cannot have a return type annotation."),
-        An_index_signature_must_have_exactly_one_parameter: diag(1096, 1 /* Error */, "An_index_signature_must_have_exactly_one_parameter_1096", "An index signature must have exactly one parameter."),
-        _0_list_cannot_be_empty: diag(1097, 1 /* Error */, "_0_list_cannot_be_empty_1097", "'{0}' list cannot be empty."),
-        Type_parameter_list_cannot_be_empty: diag(1098, 1 /* Error */, "Type_parameter_list_cannot_be_empty_1098", "Type parameter list cannot be empty."),
-        Type_argument_list_cannot_be_empty: diag(1099, 1 /* Error */, "Type_argument_list_cannot_be_empty_1099", "Type argument list cannot be empty."),
-        Invalid_use_of_0_in_strict_mode: diag(1100, 1 /* Error */, "Invalid_use_of_0_in_strict_mode_1100", "Invalid use of '{0}' in strict mode."),
-        with_statements_are_not_allowed_in_strict_mode: diag(1101, 1 /* Error */, "with_statements_are_not_allowed_in_strict_mode_1101", "'with' statements are not allowed in strict mode."),
-        delete_cannot_be_called_on_an_identifier_in_strict_mode: diag(1102, 1 /* Error */, "delete_cannot_be_called_on_an_identifier_in_strict_mode_1102", "'delete' cannot be called on an identifier in strict mode."),
-        for_await_loops_are_only_allowed_within_async_functions_and_at_the_top_levels_of_modules: diag(1103, 1 /* Error */, "for_await_loops_are_only_allowed_within_async_functions_and_at_the_top_levels_of_modules_1103", "'for await' loops are only allowed within async functions and at the top levels of modules."),
-        A_continue_statement_can_only_be_used_within_an_enclosing_iteration_statement: diag(1104, 1 /* Error */, "A_continue_statement_can_only_be_used_within_an_enclosing_iteration_statement_1104", "A 'continue' statement can only be used within an enclosing iteration statement."),
-        A_break_statement_can_only_be_used_within_an_enclosing_iteration_or_switch_statement: diag(1105, 1 /* Error */, "A_break_statement_can_only_be_used_within_an_enclosing_iteration_or_switch_statement_1105", "A 'break' statement can only be used within an enclosing iteration or switch statement."),
-        The_left_hand_side_of_a_for_of_statement_may_not_be_async: diag(1106, 1 /* Error */, "The_left_hand_side_of_a_for_of_statement_may_not_be_async_1106", "The left-hand side of a 'for...of' statement may not be 'async'."),
-        Jump_target_cannot_cross_function_boundary: diag(1107, 1 /* Error */, "Jump_target_cannot_cross_function_boundary_1107", "Jump target cannot cross function boundary."),
-        A_return_statement_can_only_be_used_within_a_function_body: diag(1108, 1 /* Error */, "A_return_statement_can_only_be_used_within_a_function_body_1108", "A 'return' statement can only be used within a function body."),
-        Expression_expected: diag(1109, 1 /* Error */, "Expression_expected_1109", "Expression expected."),
-        Type_expected: diag(1110, 1 /* Error */, "Type_expected_1110", "Type expected."),
-        A_default_clause_cannot_appear_more_than_once_in_a_switch_statement: diag(1113, 1 /* Error */, "A_default_clause_cannot_appear_more_than_once_in_a_switch_statement_1113", "A 'default' clause cannot appear more than once in a 'switch' statement."),
-        Duplicate_label_0: diag(1114, 1 /* Error */, "Duplicate_label_0_1114", "Duplicate label '{0}'."),
-        A_continue_statement_can_only_jump_to_a_label_of_an_enclosing_iteration_statement: diag(1115, 1 /* Error */, "A_continue_statement_can_only_jump_to_a_label_of_an_enclosing_iteration_statement_1115", "A 'continue' statement can only jump to a label of an enclosing iteration statement."),
-        A_break_statement_can_only_jump_to_a_label_of_an_enclosing_statement: diag(1116, 1 /* Error */, "A_break_statement_can_only_jump_to_a_label_of_an_enclosing_statement_1116", "A 'break' statement can only jump to a label of an enclosing statement."),
-        An_object_literal_cannot_have_multiple_properties_with_the_same_name: diag(1117, 1 /* Error */, "An_object_literal_cannot_have_multiple_properties_with_the_same_name_1117", "An object literal cannot have multiple properties with the same name."),
-        An_object_literal_cannot_have_multiple_get_Slashset_accessors_with_the_same_name: diag(1118, 1 /* Error */, "An_object_literal_cannot_have_multiple_get_Slashset_accessors_with_the_same_name_1118", "An object literal cannot have multiple get/set accessors with the same name."),
-        An_object_literal_cannot_have_property_and_accessor_with_the_same_name: diag(1119, 1 /* Error */, "An_object_literal_cannot_have_property_and_accessor_with_the_same_name_1119", "An object literal cannot have property and accessor with the same name."),
-        An_export_assignment_cannot_have_modifiers: diag(1120, 1 /* Error */, "An_export_assignment_cannot_have_modifiers_1120", "An export assignment cannot have modifiers."),
-        Octal_literals_are_not_allowed_Use_the_syntax_0: diag(1121, 1 /* Error */, "Octal_literals_are_not_allowed_Use_the_syntax_0_1121", "Octal literals are not allowed. Use the syntax '{0}'."),
-        Variable_declaration_list_cannot_be_empty: diag(1123, 1 /* Error */, "Variable_declaration_list_cannot_be_empty_1123", "Variable declaration list cannot be empty."),
-        Digit_expected: diag(1124, 1 /* Error */, "Digit_expected_1124", "Digit expected."),
-        Hexadecimal_digit_expected: diag(1125, 1 /* Error */, "Hexadecimal_digit_expected_1125", "Hexadecimal digit expected."),
-        Unexpected_end_of_text: diag(1126, 1 /* Error */, "Unexpected_end_of_text_1126", "Unexpected end of text."),
-        Invalid_character: diag(1127, 1 /* Error */, "Invalid_character_1127", "Invalid character."),
-        Declaration_or_statement_expected: diag(1128, 1 /* Error */, "Declaration_or_statement_expected_1128", "Declaration or statement expected."),
-        Statement_expected: diag(1129, 1 /* Error */, "Statement_expected_1129", "Statement expected."),
-        case_or_default_expected: diag(1130, 1 /* Error */, "case_or_default_expected_1130", "'case' or 'default' expected."),
-        Property_or_signature_expected: diag(1131, 1 /* Error */, "Property_or_signature_expected_1131", "Property or signature expected."),
-        Enum_member_expected: diag(1132, 1 /* Error */, "Enum_member_expected_1132", "Enum member expected."),
-        Variable_declaration_expected: diag(1134, 1 /* Error */, "Variable_declaration_expected_1134", "Variable declaration expected."),
-        Argument_expression_expected: diag(1135, 1 /* Error */, "Argument_expression_expected_1135", "Argument expression expected."),
-        Property_assignment_expected: diag(1136, 1 /* Error */, "Property_assignment_expected_1136", "Property assignment expected."),
-        Expression_or_comma_expected: diag(1137, 1 /* Error */, "Expression_or_comma_expected_1137", "Expression or comma expected."),
-        Parameter_declaration_expected: diag(1138, 1 /* Error */, "Parameter_declaration_expected_1138", "Parameter declaration expected."),
-        Type_parameter_declaration_expected: diag(1139, 1 /* Error */, "Type_parameter_declaration_expected_1139", "Type parameter declaration expected."),
-        Type_argument_expected: diag(1140, 1 /* Error */, "Type_argument_expected_1140", "Type argument expected."),
-        String_literal_expected: diag(1141, 1 /* Error */, "String_literal_expected_1141", "String literal expected."),
-        Line_break_not_permitted_here: diag(1142, 1 /* Error */, "Line_break_not_permitted_here_1142", "Line break not permitted here."),
-        or_expected: diag(1144, 1 /* Error */, "or_expected_1144", "'{' or ';' expected."),
-        or_JSX_element_expected: diag(1145, 1 /* Error */, "or_JSX_element_expected_1145", "'{' or JSX element expected."),
-        Declaration_expected: diag(1146, 1 /* Error */, "Declaration_expected_1146", "Declaration expected."),
-        Import_declarations_in_a_namespace_cannot_reference_a_module: diag(1147, 1 /* Error */, "Import_declarations_in_a_namespace_cannot_reference_a_module_1147", "Import declarations in a namespace cannot reference a module."),
-        Cannot_use_imports_exports_or_module_augmentations_when_module_is_none: diag(1148, 1 /* Error */, "Cannot_use_imports_exports_or_module_augmentations_when_module_is_none_1148", "Cannot use imports, exports, or module augmentations when '--module' is 'none'."),
-        File_name_0_differs_from_already_included_file_name_1_only_in_casing: diag(1149, 1 /* Error */, "File_name_0_differs_from_already_included_file_name_1_only_in_casing_1149", "File name '{0}' differs from already included file name '{1}' only in casing."),
-        const_declarations_must_be_initialized: diag(1155, 1 /* Error */, "const_declarations_must_be_initialized_1155", "'const' declarations must be initialized."),
-        const_declarations_can_only_be_declared_inside_a_block: diag(1156, 1 /* Error */, "const_declarations_can_only_be_declared_inside_a_block_1156", "'const' declarations can only be declared inside a block."),
-        let_declarations_can_only_be_declared_inside_a_block: diag(1157, 1 /* Error */, "let_declarations_can_only_be_declared_inside_a_block_1157", "'let' declarations can only be declared inside a block."),
-        Unterminated_template_literal: diag(1160, 1 /* Error */, "Unterminated_template_literal_1160", "Unterminated template literal."),
-        Unterminated_regular_expression_literal: diag(1161, 1 /* Error */, "Unterminated_regular_expression_literal_1161", "Unterminated regular expression literal."),
-        An_object_member_cannot_be_declared_optional: diag(1162, 1 /* Error */, "An_object_member_cannot_be_declared_optional_1162", "An object member cannot be declared optional."),
-        A_yield_expression_is_only_allowed_in_a_generator_body: diag(1163, 1 /* Error */, "A_yield_expression_is_only_allowed_in_a_generator_body_1163", "A 'yield' expression is only allowed in a generator body."),
-        Computed_property_names_are_not_allowed_in_enums: diag(1164, 1 /* Error */, "Computed_property_names_are_not_allowed_in_enums_1164", "Computed property names are not allowed in enums."),
-        A_computed_property_name_in_an_ambient_context_must_refer_to_an_expression_whose_type_is_a_literal_type_or_a_unique_symbol_type: diag(1165, 1 /* Error */, "A_computed_property_name_in_an_ambient_context_must_refer_to_an_expression_whose_type_is_a_literal_t_1165", "A computed property name in an ambient context must refer to an expression whose type is a literal type or a 'unique symbol' type."),
-        A_computed_property_name_in_a_class_property_declaration_must_have_a_simple_literal_type_or_a_unique_symbol_type: diag(1166, 1 /* Error */, "A_computed_property_name_in_a_class_property_declaration_must_have_a_simple_literal_type_or_a_unique_1166", "A computed property name in a class property declaration must have a simple literal type or a 'unique symbol' type."),
-        A_computed_property_name_in_a_method_overload_must_refer_to_an_expression_whose_type_is_a_literal_type_or_a_unique_symbol_type: diag(1168, 1 /* Error */, "A_computed_property_name_in_a_method_overload_must_refer_to_an_expression_whose_type_is_a_literal_ty_1168", "A computed property name in a method overload must refer to an expression whose type is a literal type or a 'unique symbol' type."),
-        A_computed_property_name_in_an_interface_must_refer_to_an_expression_whose_type_is_a_literal_type_or_a_unique_symbol_type: diag(1169, 1 /* Error */, "A_computed_property_name_in_an_interface_must_refer_to_an_expression_whose_type_is_a_literal_type_or_1169", "A computed property name in an interface must refer to an expression whose type is a literal type or a 'unique symbol' type."),
-        A_computed_property_name_in_a_type_literal_must_refer_to_an_expression_whose_type_is_a_literal_type_or_a_unique_symbol_type: diag(1170, 1 /* Error */, "A_computed_property_name_in_a_type_literal_must_refer_to_an_expression_whose_type_is_a_literal_type__1170", "A computed property name in a type literal must refer to an expression whose type is a literal type or a 'unique symbol' type."),
-        A_comma_expression_is_not_allowed_in_a_computed_property_name: diag(1171, 1 /* Error */, "A_comma_expression_is_not_allowed_in_a_computed_property_name_1171", "A comma expression is not allowed in a computed property name."),
-        extends_clause_already_seen: diag(1172, 1 /* Error */, "extends_clause_already_seen_1172", "'extends' clause already seen."),
-        extends_clause_must_precede_implements_clause: diag(1173, 1 /* Error */, "extends_clause_must_precede_implements_clause_1173", "'extends' clause must precede 'implements' clause."),
-        Classes_can_only_extend_a_single_class: diag(1174, 1 /* Error */, "Classes_can_only_extend_a_single_class_1174", "Classes can only extend a single class."),
-        implements_clause_already_seen: diag(1175, 1 /* Error */, "implements_clause_already_seen_1175", "'implements' clause already seen."),
-        Interface_declaration_cannot_have_implements_clause: diag(1176, 1 /* Error */, "Interface_declaration_cannot_have_implements_clause_1176", "Interface declaration cannot have 'implements' clause."),
-        Binary_digit_expected: diag(1177, 1 /* Error */, "Binary_digit_expected_1177", "Binary digit expected."),
-        Octal_digit_expected: diag(1178, 1 /* Error */, "Octal_digit_expected_1178", "Octal digit expected."),
-        Unexpected_token_expected: diag(1179, 1 /* Error */, "Unexpected_token_expected_1179", "Unexpected token. '{' expected."),
-        Property_destructuring_pattern_expected: diag(1180, 1 /* Error */, "Property_destructuring_pattern_expected_1180", "Property destructuring pattern expected."),
-        Array_element_destructuring_pattern_expected: diag(1181, 1 /* Error */, "Array_element_destructuring_pattern_expected_1181", "Array element destructuring pattern expected."),
-        A_destructuring_declaration_must_have_an_initializer: diag(1182, 1 /* Error */, "A_destructuring_declaration_must_have_an_initializer_1182", "A destructuring declaration must have an initializer."),
-        An_implementation_cannot_be_declared_in_ambient_contexts: diag(1183, 1 /* Error */, "An_implementation_cannot_be_declared_in_ambient_contexts_1183", "An implementation cannot be declared in ambient contexts."),
-        Modifiers_cannot_appear_here: diag(1184, 1 /* Error */, "Modifiers_cannot_appear_here_1184", "Modifiers cannot appear here."),
-        Merge_conflict_marker_encountered: diag(1185, 1 /* Error */, "Merge_conflict_marker_encountered_1185", "Merge conflict marker encountered."),
-        A_rest_element_cannot_have_an_initializer: diag(1186, 1 /* Error */, "A_rest_element_cannot_have_an_initializer_1186", "A rest element cannot have an initializer."),
-        A_parameter_property_may_not_be_declared_using_a_binding_pattern: diag(1187, 1 /* Error */, "A_parameter_property_may_not_be_declared_using_a_binding_pattern_1187", "A parameter property may not be declared using a binding pattern."),
-        Only_a_single_variable_declaration_is_allowed_in_a_for_of_statement: diag(1188, 1 /* Error */, "Only_a_single_variable_declaration_is_allowed_in_a_for_of_statement_1188", "Only a single variable declaration is allowed in a 'for...of' statement."),
-        The_variable_declaration_of_a_for_in_statement_cannot_have_an_initializer: diag(1189, 1 /* Error */, "The_variable_declaration_of_a_for_in_statement_cannot_have_an_initializer_1189", "The variable declaration of a 'for...in' statement cannot have an initializer."),
-        The_variable_declaration_of_a_for_of_statement_cannot_have_an_initializer: diag(1190, 1 /* Error */, "The_variable_declaration_of_a_for_of_statement_cannot_have_an_initializer_1190", "The variable declaration of a 'for...of' statement cannot have an initializer."),
-        An_import_declaration_cannot_have_modifiers: diag(1191, 1 /* Error */, "An_import_declaration_cannot_have_modifiers_1191", "An import declaration cannot have modifiers."),
-        Module_0_has_no_default_export: diag(1192, 1 /* Error */, "Module_0_has_no_default_export_1192", "Module '{0}' has no default export."),
-        An_export_declaration_cannot_have_modifiers: diag(1193, 1 /* Error */, "An_export_declaration_cannot_have_modifiers_1193", "An export declaration cannot have modifiers."),
-        Export_declarations_are_not_permitted_in_a_namespace: diag(1194, 1 /* Error */, "Export_declarations_are_not_permitted_in_a_namespace_1194", "Export declarations are not permitted in a namespace."),
-        export_Asterisk_does_not_re_export_a_default: diag(1195, 1 /* Error */, "export_Asterisk_does_not_re_export_a_default_1195", "'export *' does not re-export a default."),
-        Catch_clause_variable_type_annotation_must_be_any_or_unknown_if_specified: diag(1196, 1 /* Error */, "Catch_clause_variable_type_annotation_must_be_any_or_unknown_if_specified_1196", "Catch clause variable type annotation must be 'any' or 'unknown' if specified."),
-        Catch_clause_variable_cannot_have_an_initializer: diag(1197, 1 /* Error */, "Catch_clause_variable_cannot_have_an_initializer_1197", "Catch clause variable cannot have an initializer."),
-        An_extended_Unicode_escape_value_must_be_between_0x0_and_0x10FFFF_inclusive: diag(1198, 1 /* Error */, "An_extended_Unicode_escape_value_must_be_between_0x0_and_0x10FFFF_inclusive_1198", "An extended Unicode escape value must be between 0x0 and 0x10FFFF inclusive."),
-        Unterminated_Unicode_escape_sequence: diag(1199, 1 /* Error */, "Unterminated_Unicode_escape_sequence_1199", "Unterminated Unicode escape sequence."),
-        Line_terminator_not_permitted_before_arrow: diag(1200, 1 /* Error */, "Line_terminator_not_permitted_before_arrow_1200", "Line terminator not permitted before arrow."),
-        Import_assignment_cannot_be_used_when_targeting_ECMAScript_modules_Consider_using_import_Asterisk_as_ns_from_mod_import_a_from_mod_import_d_from_mod_or_another_module_format_instead: diag(1202, 1 /* Error */, "Import_assignment_cannot_be_used_when_targeting_ECMAScript_modules_Consider_using_import_Asterisk_as_1202", `Import assignment cannot be used when targeting ECMAScript modules. Consider using 'import * as ns from "mod"', 'import {a} from "mod"', 'import d from "mod"', or another module format instead.`),
-        Export_assignment_cannot_be_used_when_targeting_ECMAScript_modules_Consider_using_export_default_or_another_module_format_instead: diag(1203, 1 /* Error */, "Export_assignment_cannot_be_used_when_targeting_ECMAScript_modules_Consider_using_export_default_or__1203", "Export assignment cannot be used when targeting ECMAScript modules. Consider using 'export default' or another module format instead."),
-        Re_exporting_a_type_when_0_is_enabled_requires_using_export_type: diag(1205, 1 /* Error */, "Re_exporting_a_type_when_0_is_enabled_requires_using_export_type_1205", "Re-exporting a type when '{0}' is enabled requires using 'export type'."),
-        Decorators_are_not_valid_here: diag(1206, 1 /* Error */, "Decorators_are_not_valid_here_1206", "Decorators are not valid here."),
-        Decorators_cannot_be_applied_to_multiple_get_Slashset_accessors_of_the_same_name: diag(1207, 1 /* Error */, "Decorators_cannot_be_applied_to_multiple_get_Slashset_accessors_of_the_same_name_1207", "Decorators cannot be applied to multiple get/set accessors of the same name."),
-        Invalid_optional_chain_from_new_expression_Did_you_mean_to_call_0: diag(1209, 1 /* Error */, "Invalid_optional_chain_from_new_expression_Did_you_mean_to_call_0_1209", "Invalid optional chain from new expression. Did you mean to call '{0}()'?"),
-        Code_contained_in_a_class_is_evaluated_in_JavaScript_s_strict_mode_which_does_not_allow_this_use_of_0_For_more_information_see_https_Colon_Slash_Slashdeveloper_mozilla_org_Slashen_US_Slashdocs_SlashWeb_SlashJavaScript_SlashReference_SlashStrict_mode: diag(1210, 1 /* Error */, "Code_contained_in_a_class_is_evaluated_in_JavaScript_s_strict_mode_which_does_not_allow_this_use_of__1210", "Code contained in a class is evaluated in JavaScript's strict mode which does not allow this use of '{0}'. For more information, see https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Strict_mode."),
-        A_class_declaration_without_the_default_modifier_must_have_a_name: diag(1211, 1 /* Error */, "A_class_declaration_without_the_default_modifier_must_have_a_name_1211", "A class declaration without the 'default' modifier must have a name."),
-        Identifier_expected_0_is_a_reserved_word_in_strict_mode: diag(1212, 1 /* Error */, "Identifier_expected_0_is_a_reserved_word_in_strict_mode_1212", "Identifier expected. '{0}' is a reserved word in strict mode."),
-        Identifier_expected_0_is_a_reserved_word_in_strict_mode_Class_definitions_are_automatically_in_strict_mode: diag(1213, 1 /* Error */, "Identifier_expected_0_is_a_reserved_word_in_strict_mode_Class_definitions_are_automatically_in_stric_1213", "Identifier expected. '{0}' is a reserved word in strict mode. Class definitions are automatically in strict mode."),
-        Identifier_expected_0_is_a_reserved_word_in_strict_mode_Modules_are_automatically_in_strict_mode: diag(1214, 1 /* Error */, "Identifier_expected_0_is_a_reserved_word_in_strict_mode_Modules_are_automatically_in_strict_mode_1214", "Identifier expected. '{0}' is a reserved word in strict mode. Modules are automatically in strict mode."),
-        Invalid_use_of_0_Modules_are_automatically_in_strict_mode: diag(1215, 1 /* Error */, "Invalid_use_of_0_Modules_are_automatically_in_strict_mode_1215", "Invalid use of '{0}'. Modules are automatically in strict mode."),
-        Identifier_expected_esModule_is_reserved_as_an_exported_marker_when_transforming_ECMAScript_modules: diag(1216, 1 /* Error */, "Identifier_expected_esModule_is_reserved_as_an_exported_marker_when_transforming_ECMAScript_modules_1216", "Identifier expected. '__esModule' is reserved as an exported marker when transforming ECMAScript modules."),
-        Export_assignment_is_not_supported_when_module_flag_is_system: diag(1218, 1 /* Error */, "Export_assignment_is_not_supported_when_module_flag_is_system_1218", "Export assignment is not supported when '--module' flag is 'system'."),
-        Generators_are_not_allowed_in_an_ambient_context: diag(1221, 1 /* Error */, "Generators_are_not_allowed_in_an_ambient_context_1221", "Generators are not allowed in an ambient context."),
-        An_overload_signature_cannot_be_declared_as_a_generator: diag(1222, 1 /* Error */, "An_overload_signature_cannot_be_declared_as_a_generator_1222", "An overload signature cannot be declared as a generator."),
-        _0_tag_already_specified: diag(1223, 1 /* Error */, "_0_tag_already_specified_1223", "'{0}' tag already specified."),
-        Signature_0_must_be_a_type_predicate: diag(1224, 1 /* Error */, "Signature_0_must_be_a_type_predicate_1224", "Signature '{0}' must be a type predicate."),
-        Cannot_find_parameter_0: diag(1225, 1 /* Error */, "Cannot_find_parameter_0_1225", "Cannot find parameter '{0}'."),
-        Type_predicate_0_is_not_assignable_to_1: diag(1226, 1 /* Error */, "Type_predicate_0_is_not_assignable_to_1_1226", "Type predicate '{0}' is not assignable to '{1}'."),
-        Parameter_0_is_not_in_the_same_position_as_parameter_1: diag(1227, 1 /* Error */, "Parameter_0_is_not_in_the_same_position_as_parameter_1_1227", "Parameter '{0}' is not in the same position as parameter '{1}'."),
-        A_type_predicate_is_only_allowed_in_return_type_position_for_functions_and_methods: diag(1228, 1 /* Error */, "A_type_predicate_is_only_allowed_in_return_type_position_for_functions_and_methods_1228", "A type predicate is only allowed in return type position for functions and methods."),
-        A_type_predicate_cannot_reference_a_rest_parameter: diag(1229, 1 /* Error */, "A_type_predicate_cannot_reference_a_rest_parameter_1229", "A type predicate cannot reference a rest parameter."),
-        A_type_predicate_cannot_reference_element_0_in_a_binding_pattern: diag(1230, 1 /* Error */, "A_type_predicate_cannot_reference_element_0_in_a_binding_pattern_1230", "A type predicate cannot reference element '{0}' in a binding pattern."),
-        An_export_assignment_must_be_at_the_top_level_of_a_file_or_module_declaration: diag(1231, 1 /* Error */, "An_export_assignment_must_be_at_the_top_level_of_a_file_or_module_declaration_1231", "An export assignment must be at the top level of a file or module declaration."),
-        An_import_declaration_can_only_be_used_at_the_top_level_of_a_namespace_or_module: diag(1232, 1 /* Error */, "An_import_declaration_can_only_be_used_at_the_top_level_of_a_namespace_or_module_1232", "An import declaration can only be used at the top level of a namespace or module."),
-        An_export_declaration_can_only_be_used_at_the_top_level_of_a_namespace_or_module: diag(1233, 1 /* Error */, "An_export_declaration_can_only_be_used_at_the_top_level_of_a_namespace_or_module_1233", "An export declaration can only be used at the top level of a namespace or module."),
-        An_ambient_module_declaration_is_only_allowed_at_the_top_level_in_a_file: diag(1234, 1 /* Error */, "An_ambient_module_declaration_is_only_allowed_at_the_top_level_in_a_file_1234", "An ambient module declaration is only allowed at the top level in a file."),
-        A_namespace_declaration_is_only_allowed_at_the_top_level_of_a_namespace_or_module: diag(1235, 1 /* Error */, "A_namespace_declaration_is_only_allowed_at_the_top_level_of_a_namespace_or_module_1235", "A namespace declaration is only allowed at the top level of a namespace or module."),
-        The_return_type_of_a_property_decorator_function_must_be_either_void_or_any: diag(1236, 1 /* Error */, "The_return_type_of_a_property_decorator_function_must_be_either_void_or_any_1236", "The return type of a property decorator function must be either 'void' or 'any'."),
-        The_return_type_of_a_parameter_decorator_function_must_be_either_void_or_any: diag(1237, 1 /* Error */, "The_return_type_of_a_parameter_decorator_function_must_be_either_void_or_any_1237", "The return type of a parameter decorator function must be either 'void' or 'any'."),
-        Unable_to_resolve_signature_of_class_decorator_when_called_as_an_expression: diag(1238, 1 /* Error */, "Unable_to_resolve_signature_of_class_decorator_when_called_as_an_expression_1238", "Unable to resolve signature of class decorator when called as an expression."),
-        Unable_to_resolve_signature_of_parameter_decorator_when_called_as_an_expression: diag(1239, 1 /* Error */, "Unable_to_resolve_signature_of_parameter_decorator_when_called_as_an_expression_1239", "Unable to resolve signature of parameter decorator when called as an expression."),
-        Unable_to_resolve_signature_of_property_decorator_when_called_as_an_expression: diag(1240, 1 /* Error */, "Unable_to_resolve_signature_of_property_decorator_when_called_as_an_expression_1240", "Unable to resolve signature of property decorator when called as an expression."),
-        Unable_to_resolve_signature_of_method_decorator_when_called_as_an_expression: diag(1241, 1 /* Error */, "Unable_to_resolve_signature_of_method_decorator_when_called_as_an_expression_1241", "Unable to resolve signature of method decorator when called as an expression."),
-        abstract_modifier_can_only_appear_on_a_class_method_or_property_declaration: diag(1242, 1 /* Error */, "abstract_modifier_can_only_appear_on_a_class_method_or_property_declaration_1242", "'abstract' modifier can only appear on a class, method, or property declaration."),
-        _0_modifier_cannot_be_used_with_1_modifier: diag(1243, 1 /* Error */, "_0_modifier_cannot_be_used_with_1_modifier_1243", "'{0}' modifier cannot be used with '{1}' modifier."),
-        Abstract_methods_can_only_appear_within_an_abstract_class: diag(1244, 1 /* Error */, "Abstract_methods_can_only_appear_within_an_abstract_class_1244", "Abstract methods can only appear within an abstract class."),
-        Method_0_cannot_have_an_implementation_because_it_is_marked_abstract: diag(1245, 1 /* Error */, "Method_0_cannot_have_an_implementation_because_it_is_marked_abstract_1245", "Method '{0}' cannot have an implementation because it is marked abstract."),
-        An_interface_property_cannot_have_an_initializer: diag(1246, 1 /* Error */, "An_interface_property_cannot_have_an_initializer_1246", "An interface property cannot have an initializer."),
-        A_type_literal_property_cannot_have_an_initializer: diag(1247, 1 /* Error */, "A_type_literal_property_cannot_have_an_initializer_1247", "A type literal property cannot have an initializer."),
-        A_class_member_cannot_have_the_0_keyword: diag(1248, 1 /* Error */, "A_class_member_cannot_have_the_0_keyword_1248", "A class member cannot have the '{0}' keyword."),
-        A_decorator_can_only_decorate_a_method_implementation_not_an_overload: diag(1249, 1 /* Error */, "A_decorator_can_only_decorate_a_method_implementation_not_an_overload_1249", "A decorator can only decorate a method implementation, not an overload."),
-        Function_declarations_are_not_allowed_inside_blocks_in_strict_mode_when_targeting_ES3_or_ES5: diag(1250, 1 /* Error */, "Function_declarations_are_not_allowed_inside_blocks_in_strict_mode_when_targeting_ES3_or_ES5_1250", "Function declarations are not allowed inside blocks in strict mode when targeting 'ES3' or 'ES5'."),
-        Function_declarations_are_not_allowed_inside_blocks_in_strict_mode_when_targeting_ES3_or_ES5_Class_definitions_are_automatically_in_strict_mode: diag(1251, 1 /* Error */, "Function_declarations_are_not_allowed_inside_blocks_in_strict_mode_when_targeting_ES3_or_ES5_Class_d_1251", "Function declarations are not allowed inside blocks in strict mode when targeting 'ES3' or 'ES5'. Class definitions are automatically in strict mode."),
-        Function_declarations_are_not_allowed_inside_blocks_in_strict_mode_when_targeting_ES3_or_ES5_Modules_are_automatically_in_strict_mode: diag(1252, 1 /* Error */, "Function_declarations_are_not_allowed_inside_blocks_in_strict_mode_when_targeting_ES3_or_ES5_Modules_1252", "Function declarations are not allowed inside blocks in strict mode when targeting 'ES3' or 'ES5'. Modules are automatically in strict mode."),
-        Abstract_properties_can_only_appear_within_an_abstract_class: diag(1253, 1 /* Error */, "Abstract_properties_can_only_appear_within_an_abstract_class_1253", "Abstract properties can only appear within an abstract class."),
-        A_const_initializer_in_an_ambient_context_must_be_a_string_or_numeric_literal_or_literal_enum_reference: diag(1254, 1 /* Error */, "A_const_initializer_in_an_ambient_context_must_be_a_string_or_numeric_literal_or_literal_enum_refere_1254", "A 'const' initializer in an ambient context must be a string or numeric literal or literal enum reference."),
-        A_definite_assignment_assertion_is_not_permitted_in_this_context: diag(1255, 1 /* Error */, "A_definite_assignment_assertion_is_not_permitted_in_this_context_1255", "A definite assignment assertion '!' is not permitted in this context."),
-        A_required_element_cannot_follow_an_optional_element: diag(1257, 1 /* Error */, "A_required_element_cannot_follow_an_optional_element_1257", "A required element cannot follow an optional element."),
-        A_default_export_must_be_at_the_top_level_of_a_file_or_module_declaration: diag(1258, 1 /* Error */, "A_default_export_must_be_at_the_top_level_of_a_file_or_module_declaration_1258", "A default export must be at the top level of a file or module declaration."),
-        Module_0_can_only_be_default_imported_using_the_1_flag: diag(1259, 1 /* Error */, "Module_0_can_only_be_default_imported_using_the_1_flag_1259", "Module '{0}' can only be default-imported using the '{1}' flag"),
-        Keywords_cannot_contain_escape_characters: diag(1260, 1 /* Error */, "Keywords_cannot_contain_escape_characters_1260", "Keywords cannot contain escape characters."),
-        Already_included_file_name_0_differs_from_file_name_1_only_in_casing: diag(1261, 1 /* Error */, "Already_included_file_name_0_differs_from_file_name_1_only_in_casing_1261", "Already included file name '{0}' differs from file name '{1}' only in casing."),
-        Identifier_expected_0_is_a_reserved_word_at_the_top_level_of_a_module: diag(1262, 1 /* Error */, "Identifier_expected_0_is_a_reserved_word_at_the_top_level_of_a_module_1262", "Identifier expected. '{0}' is a reserved word at the top-level of a module."),
-        Declarations_with_initializers_cannot_also_have_definite_assignment_assertions: diag(1263, 1 /* Error */, "Declarations_with_initializers_cannot_also_have_definite_assignment_assertions_1263", "Declarations with initializers cannot also have definite assignment assertions."),
-        Declarations_with_definite_assignment_assertions_must_also_have_type_annotations: diag(1264, 1 /* Error */, "Declarations_with_definite_assignment_assertions_must_also_have_type_annotations_1264", "Declarations with definite assignment assertions must also have type annotations."),
-        A_rest_element_cannot_follow_another_rest_element: diag(1265, 1 /* Error */, "A_rest_element_cannot_follow_another_rest_element_1265", "A rest element cannot follow another rest element."),
-        An_optional_element_cannot_follow_a_rest_element: diag(1266, 1 /* Error */, "An_optional_element_cannot_follow_a_rest_element_1266", "An optional element cannot follow a rest element."),
-        Property_0_cannot_have_an_initializer_because_it_is_marked_abstract: diag(1267, 1 /* Error */, "Property_0_cannot_have_an_initializer_because_it_is_marked_abstract_1267", "Property '{0}' cannot have an initializer because it is marked abstract."),
-        An_index_signature_parameter_type_must_be_string_number_symbol_or_a_template_literal_type: diag(1268, 1 /* Error */, "An_index_signature_parameter_type_must_be_string_number_symbol_or_a_template_literal_type_1268", "An index signature parameter type must be 'string', 'number', 'symbol', or a template literal type."),
-        Cannot_use_export_import_on_a_type_or_type_only_namespace_when_0_is_enabled: diag(1269, 1 /* Error */, "Cannot_use_export_import_on_a_type_or_type_only_namespace_when_0_is_enabled_1269", "Cannot use 'export import' on a type or type-only namespace when '{0}' is enabled."),
-        Decorator_function_return_type_0_is_not_assignable_to_type_1: diag(1270, 1 /* Error */, "Decorator_function_return_type_0_is_not_assignable_to_type_1_1270", "Decorator function return type '{0}' is not assignable to type '{1}'."),
-        Decorator_function_return_type_is_0_but_is_expected_to_be_void_or_any: diag(1271, 1 /* Error */, "Decorator_function_return_type_is_0_but_is_expected_to_be_void_or_any_1271", "Decorator function return type is '{0}' but is expected to be 'void' or 'any'."),
-        A_type_referenced_in_a_decorated_signature_must_be_imported_with_import_type_or_a_namespace_import_when_isolatedModules_and_emitDecoratorMetadata_are_enabled: diag(1272, 1 /* Error */, "A_type_referenced_in_a_decorated_signature_must_be_imported_with_import_type_or_a_namespace_import_w_1272", "A type referenced in a decorated signature must be imported with 'import type' or a namespace import when 'isolatedModules' and 'emitDecoratorMetadata' are enabled."),
-        _0_modifier_cannot_appear_on_a_type_parameter: diag(1273, 1 /* Error */, "_0_modifier_cannot_appear_on_a_type_parameter_1273", "'{0}' modifier cannot appear on a type parameter"),
-        _0_modifier_can_only_appear_on_a_type_parameter_of_a_class_interface_or_type_alias: diag(1274, 1 /* Error */, "_0_modifier_can_only_appear_on_a_type_parameter_of_a_class_interface_or_type_alias_1274", "'{0}' modifier can only appear on a type parameter of a class, interface or type alias"),
-        accessor_modifier_can_only_appear_on_a_property_declaration: diag(1275, 1 /* Error */, "accessor_modifier_can_only_appear_on_a_property_declaration_1275", "'accessor' modifier can only appear on a property declaration."),
-        An_accessor_property_cannot_be_declared_optional: diag(1276, 1 /* Error */, "An_accessor_property_cannot_be_declared_optional_1276", "An 'accessor' property cannot be declared optional."),
-        _0_modifier_can_only_appear_on_a_type_parameter_of_a_function_method_or_class: diag(1277, 1 /* Error */, "_0_modifier_can_only_appear_on_a_type_parameter_of_a_function_method_or_class_1277", "'{0}' modifier can only appear on a type parameter of a function, method or class"),
-        The_runtime_will_invoke_the_decorator_with_1_arguments_but_the_decorator_expects_0: diag(1278, 1 /* Error */, "The_runtime_will_invoke_the_decorator_with_1_arguments_but_the_decorator_expects_0_1278", "The runtime will invoke the decorator with {1} arguments, but the decorator expects {0}."),
-        The_runtime_will_invoke_the_decorator_with_1_arguments_but_the_decorator_expects_at_least_0: diag(1279, 1 /* Error */, "The_runtime_will_invoke_the_decorator_with_1_arguments_but_the_decorator_expects_at_least_0_1279", "The runtime will invoke the decorator with {1} arguments, but the decorator expects at least {0}."),
-        Namespaces_are_not_allowed_in_global_script_files_when_0_is_enabled_If_this_file_is_not_intended_to_be_a_global_script_set_moduleDetection_to_force_or_add_an_empty_export_statement: diag(1280, 1 /* Error */, "Namespaces_are_not_allowed_in_global_script_files_when_0_is_enabled_If_this_file_is_not_intended_to__1280", "Namespaces are not allowed in global script files when '{0}' is enabled. If this file is not intended to be a global script, set 'moduleDetection' to 'force' or add an empty 'export {}' statement."),
-        Cannot_access_0_from_another_file_without_qualification_when_1_is_enabled_Use_2_instead: diag(1281, 1 /* Error */, "Cannot_access_0_from_another_file_without_qualification_when_1_is_enabled_Use_2_instead_1281", "Cannot access '{0}' from another file without qualification when '{1}' is enabled. Use '{2}' instead."),
-        An_export_declaration_must_reference_a_value_when_verbatimModuleSyntax_is_enabled_but_0_only_refers_to_a_type: diag(1282, 1 /* Error */, "An_export_declaration_must_reference_a_value_when_verbatimModuleSyntax_is_enabled_but_0_only_refers__1282", "An 'export =' declaration must reference a value when 'verbatimModuleSyntax' is enabled, but '{0}' only refers to a type."),
-        An_export_declaration_must_reference_a_real_value_when_verbatimModuleSyntax_is_enabled_but_0_resolves_to_a_type_only_declaration: diag(1283, 1 /* Error */, "An_export_declaration_must_reference_a_real_value_when_verbatimModuleSyntax_is_enabled_but_0_resolve_1283", "An 'export =' declaration must reference a real value when 'verbatimModuleSyntax' is enabled, but '{0}' resolves to a type-only declaration."),
-        An_export_default_must_reference_a_value_when_verbatimModuleSyntax_is_enabled_but_0_only_refers_to_a_type: diag(1284, 1 /* Error */, "An_export_default_must_reference_a_value_when_verbatimModuleSyntax_is_enabled_but_0_only_refers_to_a_1284", "An 'export default' must reference a value when 'verbatimModuleSyntax' is enabled, but '{0}' only refers to a type."),
-        An_export_default_must_reference_a_real_value_when_verbatimModuleSyntax_is_enabled_but_0_resolves_to_a_type_only_declaration: diag(1285, 1 /* Error */, "An_export_default_must_reference_a_real_value_when_verbatimModuleSyntax_is_enabled_but_0_resolves_to_1285", "An 'export default' must reference a real value when 'verbatimModuleSyntax' is enabled, but '{0}' resolves to a type-only declaration."),
-        ESM_syntax_is_not_allowed_in_a_CommonJS_module_when_verbatimModuleSyntax_is_enabled: diag(1286, 1 /* Error */, "ESM_syntax_is_not_allowed_in_a_CommonJS_module_when_verbatimModuleSyntax_is_enabled_1286", "ESM syntax is not allowed in a CommonJS module when 'verbatimModuleSyntax' is enabled."),
-        A_top_level_export_modifier_cannot_be_used_on_value_declarations_in_a_CommonJS_module_when_verbatimModuleSyntax_is_enabled: diag(1287, 1 /* Error */, "A_top_level_export_modifier_cannot_be_used_on_value_declarations_in_a_CommonJS_module_when_verbatimM_1287", "A top-level 'export' modifier cannot be used on value declarations in a CommonJS module when 'verbatimModuleSyntax' is enabled."),
-        An_import_alias_cannot_resolve_to_a_type_or_type_only_declaration_when_verbatimModuleSyntax_is_enabled: diag(1288, 1 /* Error */, "An_import_alias_cannot_resolve_to_a_type_or_type_only_declaration_when_verbatimModuleSyntax_is_enabl_1288", "An import alias cannot resolve to a type or type-only declaration when 'verbatimModuleSyntax' is enabled."),
-        with_statements_are_not_allowed_in_an_async_function_block: diag(1300, 1 /* Error */, "with_statements_are_not_allowed_in_an_async_function_block_1300", "'with' statements are not allowed in an async function block."),
-        await_expressions_are_only_allowed_within_async_functions_and_at_the_top_levels_of_modules: diag(1308, 1 /* Error */, "await_expressions_are_only_allowed_within_async_functions_and_at_the_top_levels_of_modules_1308", "'await' expressions are only allowed within async functions and at the top levels of modules."),
-        The_current_file_is_a_CommonJS_module_and_cannot_use_await_at_the_top_level: diag(1309, 1 /* Error */, "The_current_file_is_a_CommonJS_module_and_cannot_use_await_at_the_top_level_1309", "The current file is a CommonJS module and cannot use 'await' at the top level."),
-        Did_you_mean_to_use_a_Colon_An_can_only_follow_a_property_name_when_the_containing_object_literal_is_part_of_a_destructuring_pattern: diag(1312, 1 /* Error */, "Did_you_mean_to_use_a_Colon_An_can_only_follow_a_property_name_when_the_containing_object_literal_is_1312", "Did you mean to use a ':'? An '=' can only follow a property name when the containing object literal is part of a destructuring pattern."),
-        The_body_of_an_if_statement_cannot_be_the_empty_statement: diag(1313, 1 /* Error */, "The_body_of_an_if_statement_cannot_be_the_empty_statement_1313", "The body of an 'if' statement cannot be the empty statement."),
-        Global_module_exports_may_only_appear_in_module_files: diag(1314, 1 /* Error */, "Global_module_exports_may_only_appear_in_module_files_1314", "Global module exports may only appear in module files."),
-        Global_module_exports_may_only_appear_in_declaration_files: diag(1315, 1 /* Error */, "Global_module_exports_may_only_appear_in_declaration_files_1315", "Global module exports may only appear in declaration files."),
-        Global_module_exports_may_only_appear_at_top_level: diag(1316, 1 /* Error */, "Global_module_exports_may_only_appear_at_top_level_1316", "Global module exports may only appear at top level."),
-        A_parameter_property_cannot_be_declared_using_a_rest_parameter: diag(1317, 1 /* Error */, "A_parameter_property_cannot_be_declared_using_a_rest_parameter_1317", "A parameter property cannot be declared using a rest parameter."),
-        An_abstract_accessor_cannot_have_an_implementation: diag(1318, 1 /* Error */, "An_abstract_accessor_cannot_have_an_implementation_1318", "An abstract accessor cannot have an implementation."),
-        A_default_export_can_only_be_used_in_an_ECMAScript_style_module: diag(1319, 1 /* Error */, "A_default_export_can_only_be_used_in_an_ECMAScript_style_module_1319", "A default export can only be used in an ECMAScript-style module."),
-        Type_of_await_operand_must_either_be_a_valid_promise_or_must_not_contain_a_callable_then_member: diag(1320, 1 /* Error */, "Type_of_await_operand_must_either_be_a_valid_promise_or_must_not_contain_a_callable_then_member_1320", "Type of 'await' operand must either be a valid promise or must not contain a callable 'then' member."),
-        Type_of_yield_operand_in_an_async_generator_must_either_be_a_valid_promise_or_must_not_contain_a_callable_then_member: diag(1321, 1 /* Error */, "Type_of_yield_operand_in_an_async_generator_must_either_be_a_valid_promise_or_must_not_contain_a_cal_1321", "Type of 'yield' operand in an async generator must either be a valid promise or must not contain a callable 'then' member."),
-        Type_of_iterated_elements_of_a_yield_Asterisk_operand_must_either_be_a_valid_promise_or_must_not_contain_a_callable_then_member: diag(1322, 1 /* Error */, "Type_of_iterated_elements_of_a_yield_Asterisk_operand_must_either_be_a_valid_promise_or_must_not_con_1322", "Type of iterated elements of a 'yield*' operand must either be a valid promise or must not contain a callable 'then' member."),
-        Dynamic_imports_are_only_supported_when_the_module_flag_is_set_to_es2020_es2022_esnext_commonjs_amd_system_umd_node16_or_nodenext: diag(1323, 1 /* Error */, "Dynamic_imports_are_only_supported_when_the_module_flag_is_set_to_es2020_es2022_esnext_commonjs_amd__1323", "Dynamic imports are only supported when the '--module' flag is set to 'es2020', 'es2022', 'esnext', 'commonjs', 'amd', 'system', 'umd', 'node16', or 'nodenext'."),
-        Dynamic_imports_only_support_a_second_argument_when_the_module_option_is_set_to_esnext_node16_or_nodenext: diag(1324, 1 /* Error */, "Dynamic_imports_only_support_a_second_argument_when_the_module_option_is_set_to_esnext_node16_or_nod_1324", "Dynamic imports only support a second argument when the '--module' option is set to 'esnext', 'node16', or 'nodenext'."),
-        Argument_of_dynamic_import_cannot_be_spread_element: diag(1325, 1 /* Error */, "Argument_of_dynamic_import_cannot_be_spread_element_1325", "Argument of dynamic import cannot be spread element."),
-        This_use_of_import_is_invalid_import_calls_can_be_written_but_they_must_have_parentheses_and_cannot_have_type_arguments: diag(1326, 1 /* Error */, "This_use_of_import_is_invalid_import_calls_can_be_written_but_they_must_have_parentheses_and_cannot__1326", "This use of 'import' is invalid. 'import()' calls can be written, but they must have parentheses and cannot have type arguments."),
-        String_literal_with_double_quotes_expected: diag(1327, 1 /* Error */, "String_literal_with_double_quotes_expected_1327", "String literal with double quotes expected."),
-        Property_value_can_only_be_string_literal_numeric_literal_true_false_null_object_literal_or_array_literal: diag(1328, 1 /* Error */, "Property_value_can_only_be_string_literal_numeric_literal_true_false_null_object_literal_or_array_li_1328", "Property value can only be string literal, numeric literal, 'true', 'false', 'null', object literal or array literal."),
-        _0_accepts_too_few_arguments_to_be_used_as_a_decorator_here_Did_you_mean_to_call_it_first_and_write_0: diag(1329, 1 /* Error */, "_0_accepts_too_few_arguments_to_be_used_as_a_decorator_here_Did_you_mean_to_call_it_first_and_write__1329", "'{0}' accepts too few arguments to be used as a decorator here. Did you mean to call it first and write '@{0}()'?"),
-        A_property_of_an_interface_or_type_literal_whose_type_is_a_unique_symbol_type_must_be_readonly: diag(1330, 1 /* Error */, "A_property_of_an_interface_or_type_literal_whose_type_is_a_unique_symbol_type_must_be_readonly_1330", "A property of an interface or type literal whose type is a 'unique symbol' type must be 'readonly'."),
-        A_property_of_a_class_whose_type_is_a_unique_symbol_type_must_be_both_static_and_readonly: diag(1331, 1 /* Error */, "A_property_of_a_class_whose_type_is_a_unique_symbol_type_must_be_both_static_and_readonly_1331", "A property of a class whose type is a 'unique symbol' type must be both 'static' and 'readonly'."),
-        A_variable_whose_type_is_a_unique_symbol_type_must_be_const: diag(1332, 1 /* Error */, "A_variable_whose_type_is_a_unique_symbol_type_must_be_const_1332", "A variable whose type is a 'unique symbol' type must be 'const'."),
-        unique_symbol_types_may_not_be_used_on_a_variable_declaration_with_a_binding_name: diag(1333, 1 /* Error */, "unique_symbol_types_may_not_be_used_on_a_variable_declaration_with_a_binding_name_1333", "'unique symbol' types may not be used on a variable declaration with a binding name."),
-        unique_symbol_types_are_only_allowed_on_variables_in_a_variable_statement: diag(1334, 1 /* Error */, "unique_symbol_types_are_only_allowed_on_variables_in_a_variable_statement_1334", "'unique symbol' types are only allowed on variables in a variable statement."),
-        unique_symbol_types_are_not_allowed_here: diag(1335, 1 /* Error */, "unique_symbol_types_are_not_allowed_here_1335", "'unique symbol' types are not allowed here."),
-        An_index_signature_parameter_type_cannot_be_a_literal_type_or_generic_type_Consider_using_a_mapped_object_type_instead: diag(1337, 1 /* Error */, "An_index_signature_parameter_type_cannot_be_a_literal_type_or_generic_type_Consider_using_a_mapped_o_1337", "An index signature parameter type cannot be a literal type or generic type. Consider using a mapped object type instead."),
-        infer_declarations_are_only_permitted_in_the_extends_clause_of_a_conditional_type: diag(1338, 1 /* Error */, "infer_declarations_are_only_permitted_in_the_extends_clause_of_a_conditional_type_1338", "'infer' declarations are only permitted in the 'extends' clause of a conditional type."),
-        Module_0_does_not_refer_to_a_value_but_is_used_as_a_value_here: diag(1339, 1 /* Error */, "Module_0_does_not_refer_to_a_value_but_is_used_as_a_value_here_1339", "Module '{0}' does not refer to a value, but is used as a value here."),
-        Module_0_does_not_refer_to_a_type_but_is_used_as_a_type_here_Did_you_mean_typeof_import_0: diag(1340, 1 /* Error */, "Module_0_does_not_refer_to_a_type_but_is_used_as_a_type_here_Did_you_mean_typeof_import_0_1340", "Module '{0}' does not refer to a type, but is used as a type here. Did you mean 'typeof import('{0}')'?"),
-        Class_constructor_may_not_be_an_accessor: diag(1341, 1 /* Error */, "Class_constructor_may_not_be_an_accessor_1341", "Class constructor may not be an accessor."),
-        The_import_meta_meta_property_is_only_allowed_when_the_module_option_is_es2020_es2022_esnext_system_node16_or_nodenext: diag(1343, 1 /* Error */, "The_import_meta_meta_property_is_only_allowed_when_the_module_option_is_es2020_es2022_esnext_system__1343", "The 'import.meta' meta-property is only allowed when the '--module' option is 'es2020', 'es2022', 'esnext', 'system', 'node16', or 'nodenext'."),
-        A_label_is_not_allowed_here: diag(1344, 1 /* Error */, "A_label_is_not_allowed_here_1344", "'A label is not allowed here."),
-        An_expression_of_type_void_cannot_be_tested_for_truthiness: diag(1345, 1 /* Error */, "An_expression_of_type_void_cannot_be_tested_for_truthiness_1345", "An expression of type 'void' cannot be tested for truthiness."),
-        This_parameter_is_not_allowed_with_use_strict_directive: diag(1346, 1 /* Error */, "This_parameter_is_not_allowed_with_use_strict_directive_1346", "This parameter is not allowed with 'use strict' directive."),
-        use_strict_directive_cannot_be_used_with_non_simple_parameter_list: diag(1347, 1 /* Error */, "use_strict_directive_cannot_be_used_with_non_simple_parameter_list_1347", "'use strict' directive cannot be used with non-simple parameter list."),
-        Non_simple_parameter_declared_here: diag(1348, 1 /* Error */, "Non_simple_parameter_declared_here_1348", "Non-simple parameter declared here."),
-        use_strict_directive_used_here: diag(1349, 1 /* Error */, "use_strict_directive_used_here_1349", "'use strict' directive used here."),
-        Print_the_final_configuration_instead_of_building: diag(1350, 3 /* Message */, "Print_the_final_configuration_instead_of_building_1350", "Print the final configuration instead of building."),
-        An_identifier_or_keyword_cannot_immediately_follow_a_numeric_literal: diag(1351, 1 /* Error */, "An_identifier_or_keyword_cannot_immediately_follow_a_numeric_literal_1351", "An identifier or keyword cannot immediately follow a numeric literal."),
-        A_bigint_literal_cannot_use_exponential_notation: diag(1352, 1 /* Error */, "A_bigint_literal_cannot_use_exponential_notation_1352", "A bigint literal cannot use exponential notation."),
-        A_bigint_literal_must_be_an_integer: diag(1353, 1 /* Error */, "A_bigint_literal_must_be_an_integer_1353", "A bigint literal must be an integer."),
-        readonly_type_modifier_is_only_permitted_on_array_and_tuple_literal_types: diag(1354, 1 /* Error */, "readonly_type_modifier_is_only_permitted_on_array_and_tuple_literal_types_1354", "'readonly' type modifier is only permitted on array and tuple literal types."),
-        A_const_assertions_can_only_be_applied_to_references_to_enum_members_or_string_number_boolean_array_or_object_literals: diag(1355, 1 /* Error */, "A_const_assertions_can_only_be_applied_to_references_to_enum_members_or_string_number_boolean_array__1355", "A 'const' assertions can only be applied to references to enum members, or string, number, boolean, array, or object literals."),
-        Did_you_mean_to_mark_this_function_as_async: diag(1356, 1 /* Error */, "Did_you_mean_to_mark_this_function_as_async_1356", "Did you mean to mark this function as 'async'?"),
-        An_enum_member_name_must_be_followed_by_a_or: diag(1357, 1 /* Error */, "An_enum_member_name_must_be_followed_by_a_or_1357", "An enum member name must be followed by a ',', '=', or '}'."),
-        Tagged_template_expressions_are_not_permitted_in_an_optional_chain: diag(1358, 1 /* Error */, "Tagged_template_expressions_are_not_permitted_in_an_optional_chain_1358", "Tagged template expressions are not permitted in an optional chain."),
-        Identifier_expected_0_is_a_reserved_word_that_cannot_be_used_here: diag(1359, 1 /* Error */, "Identifier_expected_0_is_a_reserved_word_that_cannot_be_used_here_1359", "Identifier expected. '{0}' is a reserved word that cannot be used here."),
-        Type_0_does_not_satisfy_the_expected_type_1: diag(1360, 1 /* Error */, "Type_0_does_not_satisfy_the_expected_type_1_1360", "Type '{0}' does not satisfy the expected type '{1}'."),
-        _0_cannot_be_used_as_a_value_because_it_was_imported_using_import_type: diag(1361, 1 /* Error */, "_0_cannot_be_used_as_a_value_because_it_was_imported_using_import_type_1361", "'{0}' cannot be used as a value because it was imported using 'import type'."),
-        _0_cannot_be_used_as_a_value_because_it_was_exported_using_export_type: diag(1362, 1 /* Error */, "_0_cannot_be_used_as_a_value_because_it_was_exported_using_export_type_1362", "'{0}' cannot be used as a value because it was exported using 'export type'."),
-        A_type_only_import_can_specify_a_default_import_or_named_bindings_but_not_both: diag(1363, 1 /* Error */, "A_type_only_import_can_specify_a_default_import_or_named_bindings_but_not_both_1363", "A type-only import can specify a default import or named bindings, but not both."),
-        Convert_to_type_only_export: diag(1364, 3 /* Message */, "Convert_to_type_only_export_1364", "Convert to type-only export"),
-        Convert_all_re_exported_types_to_type_only_exports: diag(1365, 3 /* Message */, "Convert_all_re_exported_types_to_type_only_exports_1365", "Convert all re-exported types to type-only exports"),
-        Split_into_two_separate_import_declarations: diag(1366, 3 /* Message */, "Split_into_two_separate_import_declarations_1366", "Split into two separate import declarations"),
-        Split_all_invalid_type_only_imports: diag(1367, 3 /* Message */, "Split_all_invalid_type_only_imports_1367", "Split all invalid type-only imports"),
-        Class_constructor_may_not_be_a_generator: diag(1368, 1 /* Error */, "Class_constructor_may_not_be_a_generator_1368", "Class constructor may not be a generator."),
-        Did_you_mean_0: diag(1369, 3 /* Message */, "Did_you_mean_0_1369", "Did you mean '{0}'?"),
-        This_import_is_never_used_as_a_value_and_must_use_import_type_because_importsNotUsedAsValues_is_set_to_error: diag(1371, 1 /* Error */, "This_import_is_never_used_as_a_value_and_must_use_import_type_because_importsNotUsedAsValues_is_set__1371", "This import is never used as a value and must use 'import type' because 'importsNotUsedAsValues' is set to 'error'."),
-        Convert_to_type_only_import: diag(1373, 3 /* Message */, "Convert_to_type_only_import_1373", "Convert to type-only import"),
-        Convert_all_imports_not_used_as_a_value_to_type_only_imports: diag(1374, 3 /* Message */, "Convert_all_imports_not_used_as_a_value_to_type_only_imports_1374", "Convert all imports not used as a value to type-only imports"),
-        await_expressions_are_only_allowed_at_the_top_level_of_a_file_when_that_file_is_a_module_but_this_file_has_no_imports_or_exports_Consider_adding_an_empty_export_to_make_this_file_a_module: diag(1375, 1 /* Error */, "await_expressions_are_only_allowed_at_the_top_level_of_a_file_when_that_file_is_a_module_but_this_fi_1375", "'await' expressions are only allowed at the top level of a file when that file is a module, but this file has no imports or exports. Consider adding an empty 'export {}' to make this file a module."),
-        _0_was_imported_here: diag(1376, 3 /* Message */, "_0_was_imported_here_1376", "'{0}' was imported here."),
-        _0_was_exported_here: diag(1377, 3 /* Message */, "_0_was_exported_here_1377", "'{0}' was exported here."),
-        Top_level_await_expressions_are_only_allowed_when_the_module_option_is_set_to_es2022_esnext_system_node16_or_nodenext_and_the_target_option_is_set_to_es2017_or_higher: diag(1378, 1 /* Error */, "Top_level_await_expressions_are_only_allowed_when_the_module_option_is_set_to_es2022_esnext_system_n_1378", "Top-level 'await' expressions are only allowed when the 'module' option is set to 'es2022', 'esnext', 'system', 'node16', or 'nodenext', and the 'target' option is set to 'es2017' or higher."),
-        An_import_alias_cannot_reference_a_declaration_that_was_exported_using_export_type: diag(1379, 1 /* Error */, "An_import_alias_cannot_reference_a_declaration_that_was_exported_using_export_type_1379", "An import alias cannot reference a declaration that was exported using 'export type'."),
-        An_import_alias_cannot_reference_a_declaration_that_was_imported_using_import_type: diag(1380, 1 /* Error */, "An_import_alias_cannot_reference_a_declaration_that_was_imported_using_import_type_1380", "An import alias cannot reference a declaration that was imported using 'import type'."),
-        Unexpected_token_Did_you_mean_or_rbrace: diag(1381, 1 /* Error */, "Unexpected_token_Did_you_mean_or_rbrace_1381", "Unexpected token. Did you mean `{'}'}` or `}`?"),
-        Unexpected_token_Did_you_mean_or_gt: diag(1382, 1 /* Error */, "Unexpected_token_Did_you_mean_or_gt_1382", "Unexpected token. Did you mean `{'>'}` or `>`?"),
-        Function_type_notation_must_be_parenthesized_when_used_in_a_union_type: diag(1385, 1 /* Error */, "Function_type_notation_must_be_parenthesized_when_used_in_a_union_type_1385", "Function type notation must be parenthesized when used in a union type."),
-        Constructor_type_notation_must_be_parenthesized_when_used_in_a_union_type: diag(1386, 1 /* Error */, "Constructor_type_notation_must_be_parenthesized_when_used_in_a_union_type_1386", "Constructor type notation must be parenthesized when used in a union type."),
-        Function_type_notation_must_be_parenthesized_when_used_in_an_intersection_type: diag(1387, 1 /* Error */, "Function_type_notation_must_be_parenthesized_when_used_in_an_intersection_type_1387", "Function type notation must be parenthesized when used in an intersection type."),
-        Constructor_type_notation_must_be_parenthesized_when_used_in_an_intersection_type: diag(1388, 1 /* Error */, "Constructor_type_notation_must_be_parenthesized_when_used_in_an_intersection_type_1388", "Constructor type notation must be parenthesized when used in an intersection type."),
-        _0_is_not_allowed_as_a_variable_declaration_name: diag(1389, 1 /* Error */, "_0_is_not_allowed_as_a_variable_declaration_name_1389", "'{0}' is not allowed as a variable declaration name."),
-        _0_is_not_allowed_as_a_parameter_name: diag(1390, 1 /* Error */, "_0_is_not_allowed_as_a_parameter_name_1390", "'{0}' is not allowed as a parameter name."),
-        An_import_alias_cannot_use_import_type: diag(1392, 1 /* Error */, "An_import_alias_cannot_use_import_type_1392", "An import alias cannot use 'import type'"),
-        Imported_via_0_from_file_1: diag(1393, 3 /* Message */, "Imported_via_0_from_file_1_1393", "Imported via {0} from file '{1}'"),
-        Imported_via_0_from_file_1_with_packageId_2: diag(1394, 3 /* Message */, "Imported_via_0_from_file_1_with_packageId_2_1394", "Imported via {0} from file '{1}' with packageId '{2}'"),
-        Imported_via_0_from_file_1_to_import_importHelpers_as_specified_in_compilerOptions: diag(1395, 3 /* Message */, "Imported_via_0_from_file_1_to_import_importHelpers_as_specified_in_compilerOptions_1395", "Imported via {0} from file '{1}' to import 'importHelpers' as specified in compilerOptions"),
-        Imported_via_0_from_file_1_with_packageId_2_to_import_importHelpers_as_specified_in_compilerOptions: diag(1396, 3 /* Message */, "Imported_via_0_from_file_1_with_packageId_2_to_import_importHelpers_as_specified_in_compilerOptions_1396", "Imported via {0} from file '{1}' with packageId '{2}' to import 'importHelpers' as specified in compilerOptions"),
-        Imported_via_0_from_file_1_to_import_jsx_and_jsxs_factory_functions: diag(1397, 3 /* Message */, "Imported_via_0_from_file_1_to_import_jsx_and_jsxs_factory_functions_1397", "Imported via {0} from file '{1}' to import 'jsx' and 'jsxs' factory functions"),
-        Imported_via_0_from_file_1_with_packageId_2_to_import_jsx_and_jsxs_factory_functions: diag(1398, 3 /* Message */, "Imported_via_0_from_file_1_with_packageId_2_to_import_jsx_and_jsxs_factory_functions_1398", "Imported via {0} from file '{1}' with packageId '{2}' to import 'jsx' and 'jsxs' factory functions"),
-        File_is_included_via_import_here: diag(1399, 3 /* Message */, "File_is_included_via_import_here_1399", "File is included via import here."),
-        Referenced_via_0_from_file_1: diag(1400, 3 /* Message */, "Referenced_via_0_from_file_1_1400", "Referenced via '{0}' from file '{1}'"),
-        File_is_included_via_reference_here: diag(1401, 3 /* Message */, "File_is_included_via_reference_here_1401", "File is included via reference here."),
-        Type_library_referenced_via_0_from_file_1: diag(1402, 3 /* Message */, "Type_library_referenced_via_0_from_file_1_1402", "Type library referenced via '{0}' from file '{1}'"),
-        Type_library_referenced_via_0_from_file_1_with_packageId_2: diag(1403, 3 /* Message */, "Type_library_referenced_via_0_from_file_1_with_packageId_2_1403", "Type library referenced via '{0}' from file '{1}' with packageId '{2}'"),
-        File_is_included_via_type_library_reference_here: diag(1404, 3 /* Message */, "File_is_included_via_type_library_reference_here_1404", "File is included via type library reference here."),
-        Library_referenced_via_0_from_file_1: diag(1405, 3 /* Message */, "Library_referenced_via_0_from_file_1_1405", "Library referenced via '{0}' from file '{1}'"),
-        File_is_included_via_library_reference_here: diag(1406, 3 /* Message */, "File_is_included_via_library_reference_here_1406", "File is included via library reference here."),
-        Matched_by_include_pattern_0_in_1: diag(1407, 3 /* Message */, "Matched_by_include_pattern_0_in_1_1407", "Matched by include pattern '{0}' in '{1}'"),
-        File_is_matched_by_include_pattern_specified_here: diag(1408, 3 /* Message */, "File_is_matched_by_include_pattern_specified_here_1408", "File is matched by include pattern specified here."),
-        Part_of_files_list_in_tsconfig_json: diag(1409, 3 /* Message */, "Part_of_files_list_in_tsconfig_json_1409", "Part of 'files' list in tsconfig.json"),
-        File_is_matched_by_files_list_specified_here: diag(1410, 3 /* Message */, "File_is_matched_by_files_list_specified_here_1410", "File is matched by 'files' list specified here."),
-        Output_from_referenced_project_0_included_because_1_specified: diag(1411, 3 /* Message */, "Output_from_referenced_project_0_included_because_1_specified_1411", "Output from referenced project '{0}' included because '{1}' specified"),
-        Output_from_referenced_project_0_included_because_module_is_specified_as_none: diag(1412, 3 /* Message */, "Output_from_referenced_project_0_included_because_module_is_specified_as_none_1412", "Output from referenced project '{0}' included because '--module' is specified as 'none'"),
-        File_is_output_from_referenced_project_specified_here: diag(1413, 3 /* Message */, "File_is_output_from_referenced_project_specified_here_1413", "File is output from referenced project specified here."),
-        Source_from_referenced_project_0_included_because_1_specified: diag(1414, 3 /* Message */, "Source_from_referenced_project_0_included_because_1_specified_1414", "Source from referenced project '{0}' included because '{1}' specified"),
-        Source_from_referenced_project_0_included_because_module_is_specified_as_none: diag(1415, 3 /* Message */, "Source_from_referenced_project_0_included_because_module_is_specified_as_none_1415", "Source from referenced project '{0}' included because '--module' is specified as 'none'"),
-        File_is_source_from_referenced_project_specified_here: diag(1416, 3 /* Message */, "File_is_source_from_referenced_project_specified_here_1416", "File is source from referenced project specified here."),
-        Entry_point_of_type_library_0_specified_in_compilerOptions: diag(1417, 3 /* Message */, "Entry_point_of_type_library_0_specified_in_compilerOptions_1417", "Entry point of type library '{0}' specified in compilerOptions"),
-        Entry_point_of_type_library_0_specified_in_compilerOptions_with_packageId_1: diag(1418, 3 /* Message */, "Entry_point_of_type_library_0_specified_in_compilerOptions_with_packageId_1_1418", "Entry point of type library '{0}' specified in compilerOptions with packageId '{1}'"),
-        File_is_entry_point_of_type_library_specified_here: diag(1419, 3 /* Message */, "File_is_entry_point_of_type_library_specified_here_1419", "File is entry point of type library specified here."),
-        Entry_point_for_implicit_type_library_0: diag(1420, 3 /* Message */, "Entry_point_for_implicit_type_library_0_1420", "Entry point for implicit type library '{0}'"),
-        Entry_point_for_implicit_type_library_0_with_packageId_1: diag(1421, 3 /* Message */, "Entry_point_for_implicit_type_library_0_with_packageId_1_1421", "Entry point for implicit type library '{0}' with packageId '{1}'"),
-        Library_0_specified_in_compilerOptions: diag(1422, 3 /* Message */, "Library_0_specified_in_compilerOptions_1422", "Library '{0}' specified in compilerOptions"),
-        File_is_library_specified_here: diag(1423, 3 /* Message */, "File_is_library_specified_here_1423", "File is library specified here."),
-        Default_library: diag(1424, 3 /* Message */, "Default_library_1424", "Default library"),
-        Default_library_for_target_0: diag(1425, 3 /* Message */, "Default_library_for_target_0_1425", "Default library for target '{0}'"),
-        File_is_default_library_for_target_specified_here: diag(1426, 3 /* Message */, "File_is_default_library_for_target_specified_here_1426", "File is default library for target specified here."),
-        Root_file_specified_for_compilation: diag(1427, 3 /* Message */, "Root_file_specified_for_compilation_1427", "Root file specified for compilation"),
-        File_is_output_of_project_reference_source_0: diag(1428, 3 /* Message */, "File_is_output_of_project_reference_source_0_1428", "File is output of project reference source '{0}'"),
-        File_redirects_to_file_0: diag(1429, 3 /* Message */, "File_redirects_to_file_0_1429", "File redirects to file '{0}'"),
-        The_file_is_in_the_program_because_Colon: diag(1430, 3 /* Message */, "The_file_is_in_the_program_because_Colon_1430", "The file is in the program because:"),
-        for_await_loops_are_only_allowed_at_the_top_level_of_a_file_when_that_file_is_a_module_but_this_file_has_no_imports_or_exports_Consider_adding_an_empty_export_to_make_this_file_a_module: diag(1431, 1 /* Error */, "for_await_loops_are_only_allowed_at_the_top_level_of_a_file_when_that_file_is_a_module_but_this_file_1431", "'for await' loops are only allowed at the top level of a file when that file is a module, but this file has no imports or exports. Consider adding an empty 'export {}' to make this file a module."),
-        Top_level_for_await_loops_are_only_allowed_when_the_module_option_is_set_to_es2022_esnext_system_node16_or_nodenext_and_the_target_option_is_set_to_es2017_or_higher: diag(1432, 1 /* Error */, "Top_level_for_await_loops_are_only_allowed_when_the_module_option_is_set_to_es2022_esnext_system_nod_1432", "Top-level 'for await' loops are only allowed when the 'module' option is set to 'es2022', 'esnext', 'system', 'node16', or 'nodenext', and the 'target' option is set to 'es2017' or higher."),
-        Neither_decorators_nor_modifiers_may_be_applied_to_this_parameters: diag(1433, 1 /* Error */, "Neither_decorators_nor_modifiers_may_be_applied_to_this_parameters_1433", "Neither decorators nor modifiers may be applied to 'this' parameters."),
-        Unexpected_keyword_or_identifier: diag(1434, 1 /* Error */, "Unexpected_keyword_or_identifier_1434", "Unexpected keyword or identifier."),
-        Unknown_keyword_or_identifier_Did_you_mean_0: diag(1435, 1 /* Error */, "Unknown_keyword_or_identifier_Did_you_mean_0_1435", "Unknown keyword or identifier. Did you mean '{0}'?"),
-        Decorators_must_precede_the_name_and_all_keywords_of_property_declarations: diag(1436, 1 /* Error */, "Decorators_must_precede_the_name_and_all_keywords_of_property_declarations_1436", "Decorators must precede the name and all keywords of property declarations."),
-        Namespace_must_be_given_a_name: diag(1437, 1 /* Error */, "Namespace_must_be_given_a_name_1437", "Namespace must be given a name."),
-        Interface_must_be_given_a_name: diag(1438, 1 /* Error */, "Interface_must_be_given_a_name_1438", "Interface must be given a name."),
-        Type_alias_must_be_given_a_name: diag(1439, 1 /* Error */, "Type_alias_must_be_given_a_name_1439", "Type alias must be given a name."),
-        Variable_declaration_not_allowed_at_this_location: diag(1440, 1 /* Error */, "Variable_declaration_not_allowed_at_this_location_1440", "Variable declaration not allowed at this location."),
-        Cannot_start_a_function_call_in_a_type_annotation: diag(1441, 1 /* Error */, "Cannot_start_a_function_call_in_a_type_annotation_1441", "Cannot start a function call in a type annotation."),
-        Expected_for_property_initializer: diag(1442, 1 /* Error */, "Expected_for_property_initializer_1442", "Expected '=' for property initializer."),
-        Module_declaration_names_may_only_use_or_quoted_strings: diag(1443, 1 /* Error */, "Module_declaration_names_may_only_use_or_quoted_strings_1443", `Module declaration names may only use ' or " quoted strings.`),
-        _0_is_a_type_and_must_be_imported_using_a_type_only_import_when_preserveValueImports_and_isolatedModules_are_both_enabled: diag(1444, 1 /* Error */, "_0_is_a_type_and_must_be_imported_using_a_type_only_import_when_preserveValueImports_and_isolatedMod_1444", "'{0}' is a type and must be imported using a type-only import when 'preserveValueImports' and 'isolatedModules' are both enabled."),
-        _0_resolves_to_a_type_only_declaration_and_must_be_imported_using_a_type_only_import_when_preserveValueImports_and_isolatedModules_are_both_enabled: diag(1446, 1 /* Error */, "_0_resolves_to_a_type_only_declaration_and_must_be_imported_using_a_type_only_import_when_preserveVa_1446", "'{0}' resolves to a type-only declaration and must be imported using a type-only import when 'preserveValueImports' and 'isolatedModules' are both enabled."),
-        _0_resolves_to_a_type_only_declaration_and_must_be_re_exported_using_a_type_only_re_export_when_1_is_enabled: diag(1448, 1 /* Error */, "_0_resolves_to_a_type_only_declaration_and_must_be_re_exported_using_a_type_only_re_export_when_1_is_1448", "'{0}' resolves to a type-only declaration and must be re-exported using a type-only re-export when '{1}' is enabled."),
-        Preserve_unused_imported_values_in_the_JavaScript_output_that_would_otherwise_be_removed: diag(1449, 3 /* Message */, "Preserve_unused_imported_values_in_the_JavaScript_output_that_would_otherwise_be_removed_1449", "Preserve unused imported values in the JavaScript output that would otherwise be removed."),
-        Dynamic_imports_can_only_accept_a_module_specifier_and_an_optional_assertion_as_arguments: diag(1450, 3 /* Message */, "Dynamic_imports_can_only_accept_a_module_specifier_and_an_optional_assertion_as_arguments_1450", "Dynamic imports can only accept a module specifier and an optional assertion as arguments"),
-        Private_identifiers_are_only_allowed_in_class_bodies_and_may_only_be_used_as_part_of_a_class_member_declaration_property_access_or_on_the_left_hand_side_of_an_in_expression: diag(1451, 1 /* Error */, "Private_identifiers_are_only_allowed_in_class_bodies_and_may_only_be_used_as_part_of_a_class_member__1451", "Private identifiers are only allowed in class bodies and may only be used as part of a class member declaration, property access, or on the left-hand-side of an 'in' expression"),
-        resolution_mode_assertions_are_only_supported_when_moduleResolution_is_node16_or_nodenext: diag(1452, 1 /* Error */, "resolution_mode_assertions_are_only_supported_when_moduleResolution_is_node16_or_nodenext_1452", "'resolution-mode' assertions are only supported when `moduleResolution` is `node16` or `nodenext`."),
-        resolution_mode_should_be_either_require_or_import: diag(1453, 1 /* Error */, "resolution_mode_should_be_either_require_or_import_1453", "`resolution-mode` should be either `require` or `import`."),
-        resolution_mode_can_only_be_set_for_type_only_imports: diag(1454, 1 /* Error */, "resolution_mode_can_only_be_set_for_type_only_imports_1454", "`resolution-mode` can only be set for type-only imports."),
-        resolution_mode_is_the_only_valid_key_for_type_import_assertions: diag(1455, 1 /* Error */, "resolution_mode_is_the_only_valid_key_for_type_import_assertions_1455", "`resolution-mode` is the only valid key for type import assertions."),
-        Type_import_assertions_should_have_exactly_one_key_resolution_mode_with_value_import_or_require: diag(1456, 1 /* Error */, "Type_import_assertions_should_have_exactly_one_key_resolution_mode_with_value_import_or_require_1456", "Type import assertions should have exactly one key - `resolution-mode` - with value `import` or `require`."),
-        Matched_by_default_include_pattern_Asterisk_Asterisk_Slash_Asterisk: diag(1457, 3 /* Message */, "Matched_by_default_include_pattern_Asterisk_Asterisk_Slash_Asterisk_1457", "Matched by default include pattern '**/*'"),
-        File_is_ECMAScript_module_because_0_has_field_type_with_value_module: diag(1458, 3 /* Message */, "File_is_ECMAScript_module_because_0_has_field_type_with_value_module_1458", `File is ECMAScript module because '{0}' has field "type" with value "module"`),
-        File_is_CommonJS_module_because_0_has_field_type_whose_value_is_not_module: diag(1459, 3 /* Message */, "File_is_CommonJS_module_because_0_has_field_type_whose_value_is_not_module_1459", `File is CommonJS module because '{0}' has field "type" whose value is not "module"`),
-        File_is_CommonJS_module_because_0_does_not_have_field_type: diag(1460, 3 /* Message */, "File_is_CommonJS_module_because_0_does_not_have_field_type_1460", `File is CommonJS module because '{0}' does not have field "type"`),
-        File_is_CommonJS_module_because_package_json_was_not_found: diag(1461, 3 /* Message */, "File_is_CommonJS_module_because_package_json_was_not_found_1461", "File is CommonJS module because 'package.json' was not found"),
-        The_import_meta_meta_property_is_not_allowed_in_files_which_will_build_into_CommonJS_output: diag(1470, 1 /* Error */, "The_import_meta_meta_property_is_not_allowed_in_files_which_will_build_into_CommonJS_output_1470", "The 'import.meta' meta-property is not allowed in files which will build into CommonJS output."),
-        Module_0_cannot_be_imported_using_this_construct_The_specifier_only_resolves_to_an_ES_module_which_cannot_be_imported_with_require_Use_an_ECMAScript_import_instead: diag(1471, 1 /* Error */, "Module_0_cannot_be_imported_using_this_construct_The_specifier_only_resolves_to_an_ES_module_which_c_1471", "Module '{0}' cannot be imported using this construct. The specifier only resolves to an ES module, which cannot be imported with 'require'. Use an ECMAScript import instead."),
-        catch_or_finally_expected: diag(1472, 1 /* Error */, "catch_or_finally_expected_1472", "'catch' or 'finally' expected."),
-        An_import_declaration_can_only_be_used_at_the_top_level_of_a_module: diag(1473, 1 /* Error */, "An_import_declaration_can_only_be_used_at_the_top_level_of_a_module_1473", "An import declaration can only be used at the top level of a module."),
-        An_export_declaration_can_only_be_used_at_the_top_level_of_a_module: diag(1474, 1 /* Error */, "An_export_declaration_can_only_be_used_at_the_top_level_of_a_module_1474", "An export declaration can only be used at the top level of a module."),
-        Control_what_method_is_used_to_detect_module_format_JS_files: diag(1475, 3 /* Message */, "Control_what_method_is_used_to_detect_module_format_JS_files_1475", "Control what method is used to detect module-format JS files."),
-        auto_Colon_Treat_files_with_imports_exports_import_meta_jsx_with_jsx_Colon_react_jsx_or_esm_format_with_module_Colon_node16_as_modules: diag(1476, 3 /* Message */, "auto_Colon_Treat_files_with_imports_exports_import_meta_jsx_with_jsx_Colon_react_jsx_or_esm_format_w_1476", '"auto": Treat files with imports, exports, import.meta, jsx (with jsx: react-jsx), or esm format (with module: node16+) as modules.'),
-        An_instantiation_expression_cannot_be_followed_by_a_property_access: diag(1477, 1 /* Error */, "An_instantiation_expression_cannot_be_followed_by_a_property_access_1477", "An instantiation expression cannot be followed by a property access."),
-        Identifier_or_string_literal_expected: diag(1478, 1 /* Error */, "Identifier_or_string_literal_expected_1478", "Identifier or string literal expected."),
-        The_current_file_is_a_CommonJS_module_whose_imports_will_produce_require_calls_however_the_referenced_file_is_an_ECMAScript_module_and_cannot_be_imported_with_require_Consider_writing_a_dynamic_import_0_call_instead: diag(1479, 1 /* Error */, "The_current_file_is_a_CommonJS_module_whose_imports_will_produce_require_calls_however_the_reference_1479", `The current file is a CommonJS module whose imports will produce 'require' calls; however, the referenced file is an ECMAScript module and cannot be imported with 'require'. Consider writing a dynamic 'import("{0}")' call instead.`),
-        To_convert_this_file_to_an_ECMAScript_module_change_its_file_extension_to_0_or_create_a_local_package_json_file_with_type_Colon_module: diag(1480, 3 /* Message */, "To_convert_this_file_to_an_ECMAScript_module_change_its_file_extension_to_0_or_create_a_local_packag_1480", 'To convert this file to an ECMAScript module, change its file extension to \'{0}\' or create a local package.json file with `{ "type": "module" }`.'),
-        To_convert_this_file_to_an_ECMAScript_module_change_its_file_extension_to_0_or_add_the_field_type_Colon_module_to_1: diag(1481, 3 /* Message */, "To_convert_this_file_to_an_ECMAScript_module_change_its_file_extension_to_0_or_add_the_field_type_Co_1481", `To convert this file to an ECMAScript module, change its file extension to '{0}', or add the field \`"type": "module"\` to '{1}'.`),
-        To_convert_this_file_to_an_ECMAScript_module_add_the_field_type_Colon_module_to_0: diag(1482, 3 /* Message */, "To_convert_this_file_to_an_ECMAScript_module_add_the_field_type_Colon_module_to_0_1482", 'To convert this file to an ECMAScript module, add the field `"type": "module"` to \'{0}\'.'),
-        To_convert_this_file_to_an_ECMAScript_module_create_a_local_package_json_file_with_type_Colon_module: diag(1483, 3 /* Message */, "To_convert_this_file_to_an_ECMAScript_module_create_a_local_package_json_file_with_type_Colon_module_1483", 'To convert this file to an ECMAScript module, create a local package.json file with `{ "type": "module" }`.'),
-        _0_is_a_type_and_must_be_imported_using_a_type_only_import_when_verbatimModuleSyntax_is_enabled: diag(1484, 1 /* Error */, "_0_is_a_type_and_must_be_imported_using_a_type_only_import_when_verbatimModuleSyntax_is_enabled_1484", "'{0}' is a type and must be imported using a type-only import when 'verbatimModuleSyntax' is enabled."),
-        _0_resolves_to_a_type_only_declaration_and_must_be_imported_using_a_type_only_import_when_verbatimModuleSyntax_is_enabled: diag(1485, 1 /* Error */, "_0_resolves_to_a_type_only_declaration_and_must_be_imported_using_a_type_only_import_when_verbatimMo_1485", "'{0}' resolves to a type-only declaration and must be imported using a type-only import when 'verbatimModuleSyntax' is enabled."),
-        Decorator_used_before_export_here: diag(1486, 1 /* Error */, "Decorator_used_before_export_here_1486", "Decorator used before 'export' here."),
-        Octal_escape_sequences_are_not_allowed_Use_the_syntax_0: diag(1487, 1 /* Error */, "Octal_escape_sequences_are_not_allowed_Use_the_syntax_0_1487", "Octal escape sequences are not allowed. Use the syntax '{0}'."),
-        Escape_sequence_0_is_not_allowed: diag(1488, 1 /* Error */, "Escape_sequence_0_is_not_allowed_1488", "Escape sequence '{0}' is not allowed."),
-        Decimals_with_leading_zeros_are_not_allowed: diag(1489, 1 /* Error */, "Decimals_with_leading_zeros_are_not_allowed_1489", "Decimals with leading zeros are not allowed."),
-        File_appears_to_be_binary: diag(1490, 1 /* Error */, "File_appears_to_be_binary_1490", "File appears to be binary."),
-        The_types_of_0_are_incompatible_between_these_types: diag(2200, 1 /* Error */, "The_types_of_0_are_incompatible_between_these_types_2200", "The types of '{0}' are incompatible between these types."),
-        The_types_returned_by_0_are_incompatible_between_these_types: diag(2201, 1 /* Error */, "The_types_returned_by_0_are_incompatible_between_these_types_2201", "The types returned by '{0}' are incompatible between these types."),
-        Call_signature_return_types_0_and_1_are_incompatible: diag(
-          2202,
-          1 /* Error */,
-          "Call_signature_return_types_0_and_1_are_incompatible_2202",
-          "Call signature return types '{0}' and '{1}' are incompatible.",
-          /*reportsUnnecessary*/
-          void 0,
-          /*elidedInCompatabilityPyramid*/
-          true
-        ),
-        Construct_signature_return_types_0_and_1_are_incompatible: diag(
-          2203,
-          1 /* Error */,
-          "Construct_signature_return_types_0_and_1_are_incompatible_2203",
-          "Construct signature return types '{0}' and '{1}' are incompatible.",
-          /*reportsUnnecessary*/
-          void 0,
-          /*elidedInCompatabilityPyramid*/
-          true
-        ),
-        Call_signatures_with_no_arguments_have_incompatible_return_types_0_and_1: diag(
-          2204,
-          1 /* Error */,
-          "Call_signatures_with_no_arguments_have_incompatible_return_types_0_and_1_2204",
-          "Call signatures with no arguments have incompatible return types '{0}' and '{1}'.",
-          /*reportsUnnecessary*/
-          void 0,
-          /*elidedInCompatabilityPyramid*/
-          true
-        ),
-        Construct_signatures_with_no_arguments_have_incompatible_return_types_0_and_1: diag(
-          2205,
-          1 /* Error */,
-          "Construct_signatures_with_no_arguments_have_incompatible_return_types_0_and_1_2205",
-          "Construct signatures with no arguments have incompatible return types '{0}' and '{1}'.",
-          /*reportsUnnecessary*/
-          void 0,
-          /*elidedInCompatabilityPyramid*/
-          true
-        ),
-        The_type_modifier_cannot_be_used_on_a_named_import_when_import_type_is_used_on_its_import_statement: diag(2206, 1 /* Error */, "The_type_modifier_cannot_be_used_on_a_named_import_when_import_type_is_used_on_its_import_statement_2206", "The 'type' modifier cannot be used on a named import when 'import type' is used on its import statement."),
-        The_type_modifier_cannot_be_used_on_a_named_export_when_export_type_is_used_on_its_export_statement: diag(2207, 1 /* Error */, "The_type_modifier_cannot_be_used_on_a_named_export_when_export_type_is_used_on_its_export_statement_2207", "The 'type' modifier cannot be used on a named export when 'export type' is used on its export statement."),
-        This_type_parameter_might_need_an_extends_0_constraint: diag(2208, 1 /* Error */, "This_type_parameter_might_need_an_extends_0_constraint_2208", "This type parameter might need an `extends {0}` constraint."),
-        The_project_root_is_ambiguous_but_is_required_to_resolve_export_map_entry_0_in_file_1_Supply_the_rootDir_compiler_option_to_disambiguate: diag(2209, 1 /* Error */, "The_project_root_is_ambiguous_but_is_required_to_resolve_export_map_entry_0_in_file_1_Supply_the_roo_2209", "The project root is ambiguous, but is required to resolve export map entry '{0}' in file '{1}'. Supply the `rootDir` compiler option to disambiguate."),
-        The_project_root_is_ambiguous_but_is_required_to_resolve_import_map_entry_0_in_file_1_Supply_the_rootDir_compiler_option_to_disambiguate: diag(2210, 1 /* Error */, "The_project_root_is_ambiguous_but_is_required_to_resolve_import_map_entry_0_in_file_1_Supply_the_roo_2210", "The project root is ambiguous, but is required to resolve import map entry '{0}' in file '{1}'. Supply the `rootDir` compiler option to disambiguate."),
-        Add_extends_constraint: diag(2211, 3 /* Message */, "Add_extends_constraint_2211", "Add `extends` constraint."),
-        Add_extends_constraint_to_all_type_parameters: diag(2212, 3 /* Message */, "Add_extends_constraint_to_all_type_parameters_2212", "Add `extends` constraint to all type parameters"),
-        Duplicate_identifier_0: diag(2300, 1 /* Error */, "Duplicate_identifier_0_2300", "Duplicate identifier '{0}'."),
-        Initializer_of_instance_member_variable_0_cannot_reference_identifier_1_declared_in_the_constructor: diag(2301, 1 /* Error */, "Initializer_of_instance_member_variable_0_cannot_reference_identifier_1_declared_in_the_constructor_2301", "Initializer of instance member variable '{0}' cannot reference identifier '{1}' declared in the constructor."),
-        Static_members_cannot_reference_class_type_parameters: diag(2302, 1 /* Error */, "Static_members_cannot_reference_class_type_parameters_2302", "Static members cannot reference class type parameters."),
-        Circular_definition_of_import_alias_0: diag(2303, 1 /* Error */, "Circular_definition_of_import_alias_0_2303", "Circular definition of import alias '{0}'."),
-        Cannot_find_name_0: diag(2304, 1 /* Error */, "Cannot_find_name_0_2304", "Cannot find name '{0}'."),
-        Module_0_has_no_exported_member_1: diag(2305, 1 /* Error */, "Module_0_has_no_exported_member_1_2305", "Module '{0}' has no exported member '{1}'."),
-        File_0_is_not_a_module: diag(2306, 1 /* Error */, "File_0_is_not_a_module_2306", "File '{0}' is not a module."),
-        Cannot_find_module_0_or_its_corresponding_type_declarations: diag(2307, 1 /* Error */, "Cannot_find_module_0_or_its_corresponding_type_declarations_2307", "Cannot find module '{0}' or its corresponding type declarations."),
-        Module_0_has_already_exported_a_member_named_1_Consider_explicitly_re_exporting_to_resolve_the_ambiguity: diag(2308, 1 /* Error */, "Module_0_has_already_exported_a_member_named_1_Consider_explicitly_re_exporting_to_resolve_the_ambig_2308", "Module {0} has already exported a member named '{1}'. Consider explicitly re-exporting to resolve the ambiguity."),
-        An_export_assignment_cannot_be_used_in_a_module_with_other_exported_elements: diag(2309, 1 /* Error */, "An_export_assignment_cannot_be_used_in_a_module_with_other_exported_elements_2309", "An export assignment cannot be used in a module with other exported elements."),
-        Type_0_recursively_references_itself_as_a_base_type: diag(2310, 1 /* Error */, "Type_0_recursively_references_itself_as_a_base_type_2310", "Type '{0}' recursively references itself as a base type."),
-        Cannot_find_name_0_Did_you_mean_to_write_this_in_an_async_function: diag(2311, 1 /* Error */, "Cannot_find_name_0_Did_you_mean_to_write_this_in_an_async_function_2311", "Cannot find name '{0}'. Did you mean to write this in an async function?"),
-        An_interface_can_only_extend_an_object_type_or_intersection_of_object_types_with_statically_known_members: diag(2312, 1 /* Error */, "An_interface_can_only_extend_an_object_type_or_intersection_of_object_types_with_statically_known_me_2312", "An interface can only extend an object type or intersection of object types with statically known members."),
-        Type_parameter_0_has_a_circular_constraint: diag(2313, 1 /* Error */, "Type_parameter_0_has_a_circular_constraint_2313", "Type parameter '{0}' has a circular constraint."),
-        Generic_type_0_requires_1_type_argument_s: diag(2314, 1 /* Error */, "Generic_type_0_requires_1_type_argument_s_2314", "Generic type '{0}' requires {1} type argument(s)."),
-        Type_0_is_not_generic: diag(2315, 1 /* Error */, "Type_0_is_not_generic_2315", "Type '{0}' is not generic."),
-        Global_type_0_must_be_a_class_or_interface_type: diag(2316, 1 /* Error */, "Global_type_0_must_be_a_class_or_interface_type_2316", "Global type '{0}' must be a class or interface type."),
-        Global_type_0_must_have_1_type_parameter_s: diag(2317, 1 /* Error */, "Global_type_0_must_have_1_type_parameter_s_2317", "Global type '{0}' must have {1} type parameter(s)."),
-        Cannot_find_global_type_0: diag(2318, 1 /* Error */, "Cannot_find_global_type_0_2318", "Cannot find global type '{0}'."),
-        Named_property_0_of_types_1_and_2_are_not_identical: diag(2319, 1 /* Error */, "Named_property_0_of_types_1_and_2_are_not_identical_2319", "Named property '{0}' of types '{1}' and '{2}' are not identical."),
-        Interface_0_cannot_simultaneously_extend_types_1_and_2: diag(2320, 1 /* Error */, "Interface_0_cannot_simultaneously_extend_types_1_and_2_2320", "Interface '{0}' cannot simultaneously extend types '{1}' and '{2}'."),
-        Excessive_stack_depth_comparing_types_0_and_1: diag(2321, 1 /* Error */, "Excessive_stack_depth_comparing_types_0_and_1_2321", "Excessive stack depth comparing types '{0}' and '{1}'."),
-        Type_0_is_not_assignable_to_type_1: diag(2322, 1 /* Error */, "Type_0_is_not_assignable_to_type_1_2322", "Type '{0}' is not assignable to type '{1}'."),
-        Cannot_redeclare_exported_variable_0: diag(2323, 1 /* Error */, "Cannot_redeclare_exported_variable_0_2323", "Cannot redeclare exported variable '{0}'."),
-        Property_0_is_missing_in_type_1: diag(2324, 1 /* Error */, "Property_0_is_missing_in_type_1_2324", "Property '{0}' is missing in type '{1}'."),
-        Property_0_is_private_in_type_1_but_not_in_type_2: diag(2325, 1 /* Error */, "Property_0_is_private_in_type_1_but_not_in_type_2_2325", "Property '{0}' is private in type '{1}' but not in type '{2}'."),
-        Types_of_property_0_are_incompatible: diag(2326, 1 /* Error */, "Types_of_property_0_are_incompatible_2326", "Types of property '{0}' are incompatible."),
-        Property_0_is_optional_in_type_1_but_required_in_type_2: diag(2327, 1 /* Error */, "Property_0_is_optional_in_type_1_but_required_in_type_2_2327", "Property '{0}' is optional in type '{1}' but required in type '{2}'."),
-        Types_of_parameters_0_and_1_are_incompatible: diag(2328, 1 /* Error */, "Types_of_parameters_0_and_1_are_incompatible_2328", "Types of parameters '{0}' and '{1}' are incompatible."),
-        Index_signature_for_type_0_is_missing_in_type_1: diag(2329, 1 /* Error */, "Index_signature_for_type_0_is_missing_in_type_1_2329", "Index signature for type '{0}' is missing in type '{1}'."),
-        _0_and_1_index_signatures_are_incompatible: diag(2330, 1 /* Error */, "_0_and_1_index_signatures_are_incompatible_2330", "'{0}' and '{1}' index signatures are incompatible."),
-        this_cannot_be_referenced_in_a_module_or_namespace_body: diag(2331, 1 /* Error */, "this_cannot_be_referenced_in_a_module_or_namespace_body_2331", "'this' cannot be referenced in a module or namespace body."),
-        this_cannot_be_referenced_in_current_location: diag(2332, 1 /* Error */, "this_cannot_be_referenced_in_current_location_2332", "'this' cannot be referenced in current location."),
-        this_cannot_be_referenced_in_constructor_arguments: diag(2333, 1 /* Error */, "this_cannot_be_referenced_in_constructor_arguments_2333", "'this' cannot be referenced in constructor arguments."),
-        this_cannot_be_referenced_in_a_static_property_initializer: diag(2334, 1 /* Error */, "this_cannot_be_referenced_in_a_static_property_initializer_2334", "'this' cannot be referenced in a static property initializer."),
-        super_can_only_be_referenced_in_a_derived_class: diag(2335, 1 /* Error */, "super_can_only_be_referenced_in_a_derived_class_2335", "'super' can only be referenced in a derived class."),
-        super_cannot_be_referenced_in_constructor_arguments: diag(2336, 1 /* Error */, "super_cannot_be_referenced_in_constructor_arguments_2336", "'super' cannot be referenced in constructor arguments."),
-        Super_calls_are_not_permitted_outside_constructors_or_in_nested_functions_inside_constructors: diag(2337, 1 /* Error */, "Super_calls_are_not_permitted_outside_constructors_or_in_nested_functions_inside_constructors_2337", "Super calls are not permitted outside constructors or in nested functions inside constructors."),
-        super_property_access_is_permitted_only_in_a_constructor_member_function_or_member_accessor_of_a_derived_class: diag(2338, 1 /* Error */, "super_property_access_is_permitted_only_in_a_constructor_member_function_or_member_accessor_of_a_der_2338", "'super' property access is permitted only in a constructor, member function, or member accessor of a derived class."),
-        Property_0_does_not_exist_on_type_1: diag(2339, 1 /* Error */, "Property_0_does_not_exist_on_type_1_2339", "Property '{0}' does not exist on type '{1}'."),
-        Only_public_and_protected_methods_of_the_base_class_are_accessible_via_the_super_keyword: diag(2340, 1 /* Error */, "Only_public_and_protected_methods_of_the_base_class_are_accessible_via_the_super_keyword_2340", "Only public and protected methods of the base class are accessible via the 'super' keyword."),
-        Property_0_is_private_and_only_accessible_within_class_1: diag(2341, 1 /* Error */, "Property_0_is_private_and_only_accessible_within_class_1_2341", "Property '{0}' is private and only accessible within class '{1}'."),
-        This_syntax_requires_an_imported_helper_named_1_which_does_not_exist_in_0_Consider_upgrading_your_version_of_0: diag(2343, 1 /* Error */, "This_syntax_requires_an_imported_helper_named_1_which_does_not_exist_in_0_Consider_upgrading_your_ve_2343", "This syntax requires an imported helper named '{1}' which does not exist in '{0}'. Consider upgrading your version of '{0}'."),
-        Type_0_does_not_satisfy_the_constraint_1: diag(2344, 1 /* Error */, "Type_0_does_not_satisfy_the_constraint_1_2344", "Type '{0}' does not satisfy the constraint '{1}'."),
-        Argument_of_type_0_is_not_assignable_to_parameter_of_type_1: diag(2345, 1 /* Error */, "Argument_of_type_0_is_not_assignable_to_parameter_of_type_1_2345", "Argument of type '{0}' is not assignable to parameter of type '{1}'."),
-        Call_target_does_not_contain_any_signatures: diag(2346, 1 /* Error */, "Call_target_does_not_contain_any_signatures_2346", "Call target does not contain any signatures."),
-        Untyped_function_calls_may_not_accept_type_arguments: diag(2347, 1 /* Error */, "Untyped_function_calls_may_not_accept_type_arguments_2347", "Untyped function calls may not accept type arguments."),
-        Value_of_type_0_is_not_callable_Did_you_mean_to_include_new: diag(2348, 1 /* Error */, "Value_of_type_0_is_not_callable_Did_you_mean_to_include_new_2348", "Value of type '{0}' is not callable. Did you mean to include 'new'?"),
-        This_expression_is_not_callable: diag(2349, 1 /* Error */, "This_expression_is_not_callable_2349", "This expression is not callable."),
-        Only_a_void_function_can_be_called_with_the_new_keyword: diag(2350, 1 /* Error */, "Only_a_void_function_can_be_called_with_the_new_keyword_2350", "Only a void function can be called with the 'new' keyword."),
-        This_expression_is_not_constructable: diag(2351, 1 /* Error */, "This_expression_is_not_constructable_2351", "This expression is not constructable."),
-        Conversion_of_type_0_to_type_1_may_be_a_mistake_because_neither_type_sufficiently_overlaps_with_the_other_If_this_was_intentional_convert_the_expression_to_unknown_first: diag(2352, 1 /* Error */, "Conversion_of_type_0_to_type_1_may_be_a_mistake_because_neither_type_sufficiently_overlaps_with_the__2352", "Conversion of type '{0}' to type '{1}' may be a mistake because neither type sufficiently overlaps with the other. If this was intentional, convert the expression to 'unknown' first."),
-        Object_literal_may_only_specify_known_properties_and_0_does_not_exist_in_type_1: diag(2353, 1 /* Error */, "Object_literal_may_only_specify_known_properties_and_0_does_not_exist_in_type_1_2353", "Object literal may only specify known properties, and '{0}' does not exist in type '{1}'."),
-        This_syntax_requires_an_imported_helper_but_module_0_cannot_be_found: diag(2354, 1 /* Error */, "This_syntax_requires_an_imported_helper_but_module_0_cannot_be_found_2354", "This syntax requires an imported helper but module '{0}' cannot be found."),
-        A_function_whose_declared_type_is_neither_undefined_void_nor_any_must_return_a_value: diag(2355, 1 /* Error */, "A_function_whose_declared_type_is_neither_undefined_void_nor_any_must_return_a_value_2355", "A function whose declared type is neither 'undefined', 'void', nor 'any' must return a value."),
-        An_arithmetic_operand_must_be_of_type_any_number_bigint_or_an_enum_type: diag(2356, 1 /* Error */, "An_arithmetic_operand_must_be_of_type_any_number_bigint_or_an_enum_type_2356", "An arithmetic operand must be of type 'any', 'number', 'bigint' or an enum type."),
-        The_operand_of_an_increment_or_decrement_operator_must_be_a_variable_or_a_property_access: diag(2357, 1 /* Error */, "The_operand_of_an_increment_or_decrement_operator_must_be_a_variable_or_a_property_access_2357", "The operand of an increment or decrement operator must be a variable or a property access."),
-        The_left_hand_side_of_an_instanceof_expression_must_be_of_type_any_an_object_type_or_a_type_parameter: diag(2358, 1 /* Error */, "The_left_hand_side_of_an_instanceof_expression_must_be_of_type_any_an_object_type_or_a_type_paramete_2358", "The left-hand side of an 'instanceof' expression must be of type 'any', an object type or a type parameter."),
-        The_right_hand_side_of_an_instanceof_expression_must_be_of_type_any_or_of_a_type_assignable_to_the_Function_interface_type: diag(2359, 1 /* Error */, "The_right_hand_side_of_an_instanceof_expression_must_be_of_type_any_or_of_a_type_assignable_to_the_F_2359", "The right-hand side of an 'instanceof' expression must be of type 'any' or of a type assignable to the 'Function' interface type."),
-        The_left_hand_side_of_an_arithmetic_operation_must_be_of_type_any_number_bigint_or_an_enum_type: diag(2362, 1 /* Error */, "The_left_hand_side_of_an_arithmetic_operation_must_be_of_type_any_number_bigint_or_an_enum_type_2362", "The left-hand side of an arithmetic operation must be of type 'any', 'number', 'bigint' or an enum type."),
-        The_right_hand_side_of_an_arithmetic_operation_must_be_of_type_any_number_bigint_or_an_enum_type: diag(2363, 1 /* Error */, "The_right_hand_side_of_an_arithmetic_operation_must_be_of_type_any_number_bigint_or_an_enum_type_2363", "The right-hand side of an arithmetic operation must be of type 'any', 'number', 'bigint' or an enum type."),
-        The_left_hand_side_of_an_assignment_expression_must_be_a_variable_or_a_property_access: diag(2364, 1 /* Error */, "The_left_hand_side_of_an_assignment_expression_must_be_a_variable_or_a_property_access_2364", "The left-hand side of an assignment expression must be a variable or a property access."),
-        Operator_0_cannot_be_applied_to_types_1_and_2: diag(2365, 1 /* Error */, "Operator_0_cannot_be_applied_to_types_1_and_2_2365", "Operator '{0}' cannot be applied to types '{1}' and '{2}'."),
-        Function_lacks_ending_return_statement_and_return_type_does_not_include_undefined: diag(2366, 1 /* Error */, "Function_lacks_ending_return_statement_and_return_type_does_not_include_undefined_2366", "Function lacks ending return statement and return type does not include 'undefined'."),
-        This_comparison_appears_to_be_unintentional_because_the_types_0_and_1_have_no_overlap: diag(2367, 1 /* Error */, "This_comparison_appears_to_be_unintentional_because_the_types_0_and_1_have_no_overlap_2367", "This comparison appears to be unintentional because the types '{0}' and '{1}' have no overlap."),
-        Type_parameter_name_cannot_be_0: diag(2368, 1 /* Error */, "Type_parameter_name_cannot_be_0_2368", "Type parameter name cannot be '{0}'."),
-        A_parameter_property_is_only_allowed_in_a_constructor_implementation: diag(2369, 1 /* Error */, "A_parameter_property_is_only_allowed_in_a_constructor_implementation_2369", "A parameter property is only allowed in a constructor implementation."),
-        A_rest_parameter_must_be_of_an_array_type: diag(2370, 1 /* Error */, "A_rest_parameter_must_be_of_an_array_type_2370", "A rest parameter must be of an array type."),
-        A_parameter_initializer_is_only_allowed_in_a_function_or_constructor_implementation: diag(2371, 1 /* Error */, "A_parameter_initializer_is_only_allowed_in_a_function_or_constructor_implementation_2371", "A parameter initializer is only allowed in a function or constructor implementation."),
-        Parameter_0_cannot_reference_itself: diag(2372, 1 /* Error */, "Parameter_0_cannot_reference_itself_2372", "Parameter '{0}' cannot reference itself."),
-        Parameter_0_cannot_reference_identifier_1_declared_after_it: diag(2373, 1 /* Error */, "Parameter_0_cannot_reference_identifier_1_declared_after_it_2373", "Parameter '{0}' cannot reference identifier '{1}' declared after it."),
-        Duplicate_index_signature_for_type_0: diag(2374, 1 /* Error */, "Duplicate_index_signature_for_type_0_2374", "Duplicate index signature for type '{0}'."),
-        Type_0_is_not_assignable_to_type_1_with_exactOptionalPropertyTypes_Colon_true_Consider_adding_undefined_to_the_types_of_the_target_s_properties: diag(2375, 1 /* Error */, "Type_0_is_not_assignable_to_type_1_with_exactOptionalPropertyTypes_Colon_true_Consider_adding_undefi_2375", "Type '{0}' is not assignable to type '{1}' with 'exactOptionalPropertyTypes: true'. Consider adding 'undefined' to the types of the target's properties."),
-        A_super_call_must_be_the_first_statement_in_the_constructor_to_refer_to_super_or_this_when_a_derived_class_contains_initialized_properties_parameter_properties_or_private_identifiers: diag(2376, 1 /* Error */, "A_super_call_must_be_the_first_statement_in_the_constructor_to_refer_to_super_or_this_when_a_derived_2376", "A 'super' call must be the first statement in the constructor to refer to 'super' or 'this' when a derived class contains initialized properties, parameter properties, or private identifiers."),
-        Constructors_for_derived_classes_must_contain_a_super_call: diag(2377, 1 /* Error */, "Constructors_for_derived_classes_must_contain_a_super_call_2377", "Constructors for derived classes must contain a 'super' call."),
-        A_get_accessor_must_return_a_value: diag(2378, 1 /* Error */, "A_get_accessor_must_return_a_value_2378", "A 'get' accessor must return a value."),
-        Argument_of_type_0_is_not_assignable_to_parameter_of_type_1_with_exactOptionalPropertyTypes_Colon_true_Consider_adding_undefined_to_the_types_of_the_target_s_properties: diag(2379, 1 /* Error */, "Argument_of_type_0_is_not_assignable_to_parameter_of_type_1_with_exactOptionalPropertyTypes_Colon_tr_2379", "Argument of type '{0}' is not assignable to parameter of type '{1}' with 'exactOptionalPropertyTypes: true'. Consider adding 'undefined' to the types of the target's properties."),
-        Overload_signatures_must_all_be_exported_or_non_exported: diag(2383, 1 /* Error */, "Overload_signatures_must_all_be_exported_or_non_exported_2383", "Overload signatures must all be exported or non-exported."),
-        Overload_signatures_must_all_be_ambient_or_non_ambient: diag(2384, 1 /* Error */, "Overload_signatures_must_all_be_ambient_or_non_ambient_2384", "Overload signatures must all be ambient or non-ambient."),
-        Overload_signatures_must_all_be_public_private_or_protected: diag(2385, 1 /* Error */, "Overload_signatures_must_all_be_public_private_or_protected_2385", "Overload signatures must all be public, private or protected."),
-        Overload_signatures_must_all_be_optional_or_required: diag(2386, 1 /* Error */, "Overload_signatures_must_all_be_optional_or_required_2386", "Overload signatures must all be optional or required."),
-        Function_overload_must_be_static: diag(2387, 1 /* Error */, "Function_overload_must_be_static_2387", "Function overload must be static."),
-        Function_overload_must_not_be_static: diag(2388, 1 /* Error */, "Function_overload_must_not_be_static_2388", "Function overload must not be static."),
-        Function_implementation_name_must_be_0: diag(2389, 1 /* Error */, "Function_implementation_name_must_be_0_2389", "Function implementation name must be '{0}'."),
-        Constructor_implementation_is_missing: diag(2390, 1 /* Error */, "Constructor_implementation_is_missing_2390", "Constructor implementation is missing."),
-        Function_implementation_is_missing_or_not_immediately_following_the_declaration: diag(2391, 1 /* Error */, "Function_implementation_is_missing_or_not_immediately_following_the_declaration_2391", "Function implementation is missing or not immediately following the declaration."),
-        Multiple_constructor_implementations_are_not_allowed: diag(2392, 1 /* Error */, "Multiple_constructor_implementations_are_not_allowed_2392", "Multiple constructor implementations are not allowed."),
-        Duplicate_function_implementation: diag(2393, 1 /* Error */, "Duplicate_function_implementation_2393", "Duplicate function implementation."),
-        This_overload_signature_is_not_compatible_with_its_implementation_signature: diag(2394, 1 /* Error */, "This_overload_signature_is_not_compatible_with_its_implementation_signature_2394", "This overload signature is not compatible with its implementation signature."),
-        Individual_declarations_in_merged_declaration_0_must_be_all_exported_or_all_local: diag(2395, 1 /* Error */, "Individual_declarations_in_merged_declaration_0_must_be_all_exported_or_all_local_2395", "Individual declarations in merged declaration '{0}' must be all exported or all local."),
-        Duplicate_identifier_arguments_Compiler_uses_arguments_to_initialize_rest_parameters: diag(2396, 1 /* Error */, "Duplicate_identifier_arguments_Compiler_uses_arguments_to_initialize_rest_parameters_2396", "Duplicate identifier 'arguments'. Compiler uses 'arguments' to initialize rest parameters."),
-        Declaration_name_conflicts_with_built_in_global_identifier_0: diag(2397, 1 /* Error */, "Declaration_name_conflicts_with_built_in_global_identifier_0_2397", "Declaration name conflicts with built-in global identifier '{0}'."),
-        constructor_cannot_be_used_as_a_parameter_property_name: diag(2398, 1 /* Error */, "constructor_cannot_be_used_as_a_parameter_property_name_2398", "'constructor' cannot be used as a parameter property name."),
-        Duplicate_identifier_this_Compiler_uses_variable_declaration_this_to_capture_this_reference: diag(2399, 1 /* Error */, "Duplicate_identifier_this_Compiler_uses_variable_declaration_this_to_capture_this_reference_2399", "Duplicate identifier '_this'. Compiler uses variable declaration '_this' to capture 'this' reference."),
-        Expression_resolves_to_variable_declaration_this_that_compiler_uses_to_capture_this_reference: diag(2400, 1 /* Error */, "Expression_resolves_to_variable_declaration_this_that_compiler_uses_to_capture_this_reference_2400", "Expression resolves to variable declaration '_this' that compiler uses to capture 'this' reference."),
-        A_super_call_must_be_a_root_level_statement_within_a_constructor_of_a_derived_class_that_contains_initialized_properties_parameter_properties_or_private_identifiers: diag(2401, 1 /* Error */, "A_super_call_must_be_a_root_level_statement_within_a_constructor_of_a_derived_class_that_contains_in_2401", "A 'super' call must be a root-level statement within a constructor of a derived class that contains initialized properties, parameter properties, or private identifiers."),
-        Expression_resolves_to_super_that_compiler_uses_to_capture_base_class_reference: diag(2402, 1 /* Error */, "Expression_resolves_to_super_that_compiler_uses_to_capture_base_class_reference_2402", "Expression resolves to '_super' that compiler uses to capture base class reference."),
-        Subsequent_variable_declarations_must_have_the_same_type_Variable_0_must_be_of_type_1_but_here_has_type_2: diag(2403, 1 /* Error */, "Subsequent_variable_declarations_must_have_the_same_type_Variable_0_must_be_of_type_1_but_here_has_t_2403", "Subsequent variable declarations must have the same type.  Variable '{0}' must be of type '{1}', but here has type '{2}'."),
-        The_left_hand_side_of_a_for_in_statement_cannot_use_a_type_annotation: diag(2404, 1 /* Error */, "The_left_hand_side_of_a_for_in_statement_cannot_use_a_type_annotation_2404", "The left-hand side of a 'for...in' statement cannot use a type annotation."),
-        The_left_hand_side_of_a_for_in_statement_must_be_of_type_string_or_any: diag(2405, 1 /* Error */, "The_left_hand_side_of_a_for_in_statement_must_be_of_type_string_or_any_2405", "The left-hand side of a 'for...in' statement must be of type 'string' or 'any'."),
-        The_left_hand_side_of_a_for_in_statement_must_be_a_variable_or_a_property_access: diag(2406, 1 /* Error */, "The_left_hand_side_of_a_for_in_statement_must_be_a_variable_or_a_property_access_2406", "The left-hand side of a 'for...in' statement must be a variable or a property access."),
-        The_right_hand_side_of_a_for_in_statement_must_be_of_type_any_an_object_type_or_a_type_parameter_but_here_has_type_0: diag(2407, 1 /* Error */, "The_right_hand_side_of_a_for_in_statement_must_be_of_type_any_an_object_type_or_a_type_parameter_but_2407", "The right-hand side of a 'for...in' statement must be of type 'any', an object type or a type parameter, but here has type '{0}'."),
-        Setters_cannot_return_a_value: diag(2408, 1 /* Error */, "Setters_cannot_return_a_value_2408", "Setters cannot return a value."),
-        Return_type_of_constructor_signature_must_be_assignable_to_the_instance_type_of_the_class: diag(2409, 1 /* Error */, "Return_type_of_constructor_signature_must_be_assignable_to_the_instance_type_of_the_class_2409", "Return type of constructor signature must be assignable to the instance type of the class."),
-        The_with_statement_is_not_supported_All_symbols_in_a_with_block_will_have_type_any: diag(2410, 1 /* Error */, "The_with_statement_is_not_supported_All_symbols_in_a_with_block_will_have_type_any_2410", "The 'with' statement is not supported. All symbols in a 'with' block will have type 'any'."),
-        Type_0_is_not_assignable_to_type_1_with_exactOptionalPropertyTypes_Colon_true_Consider_adding_undefined_to_the_type_of_the_target: diag(2412, 1 /* Error */, "Type_0_is_not_assignable_to_type_1_with_exactOptionalPropertyTypes_Colon_true_Consider_adding_undefi_2412", "Type '{0}' is not assignable to type '{1}' with 'exactOptionalPropertyTypes: true'. Consider adding 'undefined' to the type of the target."),
-        Property_0_of_type_1_is_not_assignable_to_2_index_type_3: diag(2411, 1 /* Error */, "Property_0_of_type_1_is_not_assignable_to_2_index_type_3_2411", "Property '{0}' of type '{1}' is not assignable to '{2}' index type '{3}'."),
-        _0_index_type_1_is_not_assignable_to_2_index_type_3: diag(2413, 1 /* Error */, "_0_index_type_1_is_not_assignable_to_2_index_type_3_2413", "'{0}' index type '{1}' is not assignable to '{2}' index type '{3}'."),
-        Class_name_cannot_be_0: diag(2414, 1 /* Error */, "Class_name_cannot_be_0_2414", "Class name cannot be '{0}'."),
-        Class_0_incorrectly_extends_base_class_1: diag(2415, 1 /* Error */, "Class_0_incorrectly_extends_base_class_1_2415", "Class '{0}' incorrectly extends base class '{1}'."),
-        Property_0_in_type_1_is_not_assignable_to_the_same_property_in_base_type_2: diag(2416, 1 /* Error */, "Property_0_in_type_1_is_not_assignable_to_the_same_property_in_base_type_2_2416", "Property '{0}' in type '{1}' is not assignable to the same property in base type '{2}'."),
-        Class_static_side_0_incorrectly_extends_base_class_static_side_1: diag(2417, 1 /* Error */, "Class_static_side_0_incorrectly_extends_base_class_static_side_1_2417", "Class static side '{0}' incorrectly extends base class static side '{1}'."),
-        Type_of_computed_property_s_value_is_0_which_is_not_assignable_to_type_1: diag(2418, 1 /* Error */, "Type_of_computed_property_s_value_is_0_which_is_not_assignable_to_type_1_2418", "Type of computed property's value is '{0}', which is not assignable to type '{1}'."),
-        Types_of_construct_signatures_are_incompatible: diag(2419, 1 /* Error */, "Types_of_construct_signatures_are_incompatible_2419", "Types of construct signatures are incompatible."),
-        Class_0_incorrectly_implements_interface_1: diag(2420, 1 /* Error */, "Class_0_incorrectly_implements_interface_1_2420", "Class '{0}' incorrectly implements interface '{1}'."),
-        A_class_can_only_implement_an_object_type_or_intersection_of_object_types_with_statically_known_members: diag(2422, 1 /* Error */, "A_class_can_only_implement_an_object_type_or_intersection_of_object_types_with_statically_known_memb_2422", "A class can only implement an object type or intersection of object types with statically known members."),
-        Class_0_defines_instance_member_function_1_but_extended_class_2_defines_it_as_instance_member_accessor: diag(2423, 1 /* Error */, "Class_0_defines_instance_member_function_1_but_extended_class_2_defines_it_as_instance_member_access_2423", "Class '{0}' defines instance member function '{1}', but extended class '{2}' defines it as instance member accessor."),
-        Class_0_defines_instance_member_property_1_but_extended_class_2_defines_it_as_instance_member_function: diag(2425, 1 /* Error */, "Class_0_defines_instance_member_property_1_but_extended_class_2_defines_it_as_instance_member_functi_2425", "Class '{0}' defines instance member property '{1}', but extended class '{2}' defines it as instance member function."),
-        Class_0_defines_instance_member_accessor_1_but_extended_class_2_defines_it_as_instance_member_function: diag(2426, 1 /* Error */, "Class_0_defines_instance_member_accessor_1_but_extended_class_2_defines_it_as_instance_member_functi_2426", "Class '{0}' defines instance member accessor '{1}', but extended class '{2}' defines it as instance member function."),
-        Interface_name_cannot_be_0: diag(2427, 1 /* Error */, "Interface_name_cannot_be_0_2427", "Interface name cannot be '{0}'."),
-        All_declarations_of_0_must_have_identical_type_parameters: diag(2428, 1 /* Error */, "All_declarations_of_0_must_have_identical_type_parameters_2428", "All declarations of '{0}' must have identical type parameters."),
-        Interface_0_incorrectly_extends_interface_1: diag(2430, 1 /* Error */, "Interface_0_incorrectly_extends_interface_1_2430", "Interface '{0}' incorrectly extends interface '{1}'."),
-        Enum_name_cannot_be_0: diag(2431, 1 /* Error */, "Enum_name_cannot_be_0_2431", "Enum name cannot be '{0}'."),
-        In_an_enum_with_multiple_declarations_only_one_declaration_can_omit_an_initializer_for_its_first_enum_element: diag(2432, 1 /* Error */, "In_an_enum_with_multiple_declarations_only_one_declaration_can_omit_an_initializer_for_its_first_enu_2432", "In an enum with multiple declarations, only one declaration can omit an initializer for its first enum element."),
-        A_namespace_declaration_cannot_be_in_a_different_file_from_a_class_or_function_with_which_it_is_merged: diag(2433, 1 /* Error */, "A_namespace_declaration_cannot_be_in_a_different_file_from_a_class_or_function_with_which_it_is_merg_2433", "A namespace declaration cannot be in a different file from a class or function with which it is merged."),
-        A_namespace_declaration_cannot_be_located_prior_to_a_class_or_function_with_which_it_is_merged: diag(2434, 1 /* Error */, "A_namespace_declaration_cannot_be_located_prior_to_a_class_or_function_with_which_it_is_merged_2434", "A namespace declaration cannot be located prior to a class or function with which it is merged."),
-        Ambient_modules_cannot_be_nested_in_other_modules_or_namespaces: diag(2435, 1 /* Error */, "Ambient_modules_cannot_be_nested_in_other_modules_or_namespaces_2435", "Ambient modules cannot be nested in other modules or namespaces."),
-        Ambient_module_declaration_cannot_specify_relative_module_name: diag(2436, 1 /* Error */, "Ambient_module_declaration_cannot_specify_relative_module_name_2436", "Ambient module declaration cannot specify relative module name."),
-        Module_0_is_hidden_by_a_local_declaration_with_the_same_name: diag(2437, 1 /* Error */, "Module_0_is_hidden_by_a_local_declaration_with_the_same_name_2437", "Module '{0}' is hidden by a local declaration with the same name."),
-        Import_name_cannot_be_0: diag(2438, 1 /* Error */, "Import_name_cannot_be_0_2438", "Import name cannot be '{0}'."),
-        Import_or_export_declaration_in_an_ambient_module_declaration_cannot_reference_module_through_relative_module_name: diag(2439, 1 /* Error */, "Import_or_export_declaration_in_an_ambient_module_declaration_cannot_reference_module_through_relati_2439", "Import or export declaration in an ambient module declaration cannot reference module through relative module name."),
-        Import_declaration_conflicts_with_local_declaration_of_0: diag(2440, 1 /* Error */, "Import_declaration_conflicts_with_local_declaration_of_0_2440", "Import declaration conflicts with local declaration of '{0}'."),
-        Duplicate_identifier_0_Compiler_reserves_name_1_in_top_level_scope_of_a_module: diag(2441, 1 /* Error */, "Duplicate_identifier_0_Compiler_reserves_name_1_in_top_level_scope_of_a_module_2441", "Duplicate identifier '{0}'. Compiler reserves name '{1}' in top level scope of a module."),
-        Types_have_separate_declarations_of_a_private_property_0: diag(2442, 1 /* Error */, "Types_have_separate_declarations_of_a_private_property_0_2442", "Types have separate declarations of a private property '{0}'."),
-        Property_0_is_protected_but_type_1_is_not_a_class_derived_from_2: diag(2443, 1 /* Error */, "Property_0_is_protected_but_type_1_is_not_a_class_derived_from_2_2443", "Property '{0}' is protected but type '{1}' is not a class derived from '{2}'."),
-        Property_0_is_protected_in_type_1_but_public_in_type_2: diag(2444, 1 /* Error */, "Property_0_is_protected_in_type_1_but_public_in_type_2_2444", "Property '{0}' is protected in type '{1}' but public in type '{2}'."),
-        Property_0_is_protected_and_only_accessible_within_class_1_and_its_subclasses: diag(2445, 1 /* Error */, "Property_0_is_protected_and_only_accessible_within_class_1_and_its_subclasses_2445", "Property '{0}' is protected and only accessible within class '{1}' and its subclasses."),
-        Property_0_is_protected_and_only_accessible_through_an_instance_of_class_1_This_is_an_instance_of_class_2: diag(2446, 1 /* Error */, "Property_0_is_protected_and_only_accessible_through_an_instance_of_class_1_This_is_an_instance_of_cl_2446", "Property '{0}' is protected and only accessible through an instance of class '{1}'. This is an instance of class '{2}'."),
-        The_0_operator_is_not_allowed_for_boolean_types_Consider_using_1_instead: diag(2447, 1 /* Error */, "The_0_operator_is_not_allowed_for_boolean_types_Consider_using_1_instead_2447", "The '{0}' operator is not allowed for boolean types. Consider using '{1}' instead."),
-        Block_scoped_variable_0_used_before_its_declaration: diag(2448, 1 /* Error */, "Block_scoped_variable_0_used_before_its_declaration_2448", "Block-scoped variable '{0}' used before its declaration."),
-        Class_0_used_before_its_declaration: diag(2449, 1 /* Error */, "Class_0_used_before_its_declaration_2449", "Class '{0}' used before its declaration."),
-        Enum_0_used_before_its_declaration: diag(2450, 1 /* Error */, "Enum_0_used_before_its_declaration_2450", "Enum '{0}' used before its declaration."),
-        Cannot_redeclare_block_scoped_variable_0: diag(2451, 1 /* Error */, "Cannot_redeclare_block_scoped_variable_0_2451", "Cannot redeclare block-scoped variable '{0}'."),
-        An_enum_member_cannot_have_a_numeric_name: diag(2452, 1 /* Error */, "An_enum_member_cannot_have_a_numeric_name_2452", "An enum member cannot have a numeric name."),
-        Variable_0_is_used_before_being_assigned: diag(2454, 1 /* Error */, "Variable_0_is_used_before_being_assigned_2454", "Variable '{0}' is used before being assigned."),
-        Type_alias_0_circularly_references_itself: diag(2456, 1 /* Error */, "Type_alias_0_circularly_references_itself_2456", "Type alias '{0}' circularly references itself."),
-        Type_alias_name_cannot_be_0: diag(2457, 1 /* Error */, "Type_alias_name_cannot_be_0_2457", "Type alias name cannot be '{0}'."),
-        An_AMD_module_cannot_have_multiple_name_assignments: diag(2458, 1 /* Error */, "An_AMD_module_cannot_have_multiple_name_assignments_2458", "An AMD module cannot have multiple name assignments."),
-        Module_0_declares_1_locally_but_it_is_not_exported: diag(2459, 1 /* Error */, "Module_0_declares_1_locally_but_it_is_not_exported_2459", "Module '{0}' declares '{1}' locally, but it is not exported."),
-        Module_0_declares_1_locally_but_it_is_exported_as_2: diag(2460, 1 /* Error */, "Module_0_declares_1_locally_but_it_is_exported_as_2_2460", "Module '{0}' declares '{1}' locally, but it is exported as '{2}'."),
-        Type_0_is_not_an_array_type: diag(2461, 1 /* Error */, "Type_0_is_not_an_array_type_2461", "Type '{0}' is not an array type."),
-        A_rest_element_must_be_last_in_a_destructuring_pattern: diag(2462, 1 /* Error */, "A_rest_element_must_be_last_in_a_destructuring_pattern_2462", "A rest element must be last in a destructuring pattern."),
-        A_binding_pattern_parameter_cannot_be_optional_in_an_implementation_signature: diag(2463, 1 /* Error */, "A_binding_pattern_parameter_cannot_be_optional_in_an_implementation_signature_2463", "A binding pattern parameter cannot be optional in an implementation signature."),
-        A_computed_property_name_must_be_of_type_string_number_symbol_or_any: diag(2464, 1 /* Error */, "A_computed_property_name_must_be_of_type_string_number_symbol_or_any_2464", "A computed property name must be of type 'string', 'number', 'symbol', or 'any'."),
-        this_cannot_be_referenced_in_a_computed_property_name: diag(2465, 1 /* Error */, "this_cannot_be_referenced_in_a_computed_property_name_2465", "'this' cannot be referenced in a computed property name."),
-        super_cannot_be_referenced_in_a_computed_property_name: diag(2466, 1 /* Error */, "super_cannot_be_referenced_in_a_computed_property_name_2466", "'super' cannot be referenced in a computed property name."),
-        A_computed_property_name_cannot_reference_a_type_parameter_from_its_containing_type: diag(2467, 1 /* Error */, "A_computed_property_name_cannot_reference_a_type_parameter_from_its_containing_type_2467", "A computed property name cannot reference a type parameter from its containing type."),
-        Cannot_find_global_value_0: diag(2468, 1 /* Error */, "Cannot_find_global_value_0_2468", "Cannot find global value '{0}'."),
-        The_0_operator_cannot_be_applied_to_type_symbol: diag(2469, 1 /* Error */, "The_0_operator_cannot_be_applied_to_type_symbol_2469", "The '{0}' operator cannot be applied to type 'symbol'."),
-        Spread_operator_in_new_expressions_is_only_available_when_targeting_ECMAScript_5_and_higher: diag(2472, 1 /* Error */, "Spread_operator_in_new_expressions_is_only_available_when_targeting_ECMAScript_5_and_higher_2472", "Spread operator in 'new' expressions is only available when targeting ECMAScript 5 and higher."),
-        Enum_declarations_must_all_be_const_or_non_const: diag(2473, 1 /* Error */, "Enum_declarations_must_all_be_const_or_non_const_2473", "Enum declarations must all be const or non-const."),
-        const_enum_member_initializers_must_be_constant_expressions: diag(2474, 1 /* Error */, "const_enum_member_initializers_must_be_constant_expressions_2474", "const enum member initializers must be constant expressions."),
-        const_enums_can_only_be_used_in_property_or_index_access_expressions_or_the_right_hand_side_of_an_import_declaration_or_export_assignment_or_type_query: diag(2475, 1 /* Error */, "const_enums_can_only_be_used_in_property_or_index_access_expressions_or_the_right_hand_side_of_an_im_2475", "'const' enums can only be used in property or index access expressions or the right hand side of an import declaration or export assignment or type query."),
-        A_const_enum_member_can_only_be_accessed_using_a_string_literal: diag(2476, 1 /* Error */, "A_const_enum_member_can_only_be_accessed_using_a_string_literal_2476", "A const enum member can only be accessed using a string literal."),
-        const_enum_member_initializer_was_evaluated_to_a_non_finite_value: diag(2477, 1 /* Error */, "const_enum_member_initializer_was_evaluated_to_a_non_finite_value_2477", "'const' enum member initializer was evaluated to a non-finite value."),
-        const_enum_member_initializer_was_evaluated_to_disallowed_value_NaN: diag(2478, 1 /* Error */, "const_enum_member_initializer_was_evaluated_to_disallowed_value_NaN_2478", "'const' enum member initializer was evaluated to disallowed value 'NaN'."),
-        let_is_not_allowed_to_be_used_as_a_name_in_let_or_const_declarations: diag(2480, 1 /* Error */, "let_is_not_allowed_to_be_used_as_a_name_in_let_or_const_declarations_2480", "'let' is not allowed to be used as a name in 'let' or 'const' declarations."),
-        Cannot_initialize_outer_scoped_variable_0_in_the_same_scope_as_block_scoped_declaration_1: diag(2481, 1 /* Error */, "Cannot_initialize_outer_scoped_variable_0_in_the_same_scope_as_block_scoped_declaration_1_2481", "Cannot initialize outer scoped variable '{0}' in the same scope as block scoped declaration '{1}'."),
-        The_left_hand_side_of_a_for_of_statement_cannot_use_a_type_annotation: diag(2483, 1 /* Error */, "The_left_hand_side_of_a_for_of_statement_cannot_use_a_type_annotation_2483", "The left-hand side of a 'for...of' statement cannot use a type annotation."),
-        Export_declaration_conflicts_with_exported_declaration_of_0: diag(2484, 1 /* Error */, "Export_declaration_conflicts_with_exported_declaration_of_0_2484", "Export declaration conflicts with exported declaration of '{0}'."),
-        The_left_hand_side_of_a_for_of_statement_must_be_a_variable_or_a_property_access: diag(2487, 1 /* Error */, "The_left_hand_side_of_a_for_of_statement_must_be_a_variable_or_a_property_access_2487", "The left-hand side of a 'for...of' statement must be a variable or a property access."),
-        Type_0_must_have_a_Symbol_iterator_method_that_returns_an_iterator: diag(2488, 1 /* Error */, "Type_0_must_have_a_Symbol_iterator_method_that_returns_an_iterator_2488", "Type '{0}' must have a '[Symbol.iterator]()' method that returns an iterator."),
-        An_iterator_must_have_a_next_method: diag(2489, 1 /* Error */, "An_iterator_must_have_a_next_method_2489", "An iterator must have a 'next()' method."),
-        The_type_returned_by_the_0_method_of_an_iterator_must_have_a_value_property: diag(2490, 1 /* Error */, "The_type_returned_by_the_0_method_of_an_iterator_must_have_a_value_property_2490", "The type returned by the '{0}()' method of an iterator must have a 'value' property."),
-        The_left_hand_side_of_a_for_in_statement_cannot_be_a_destructuring_pattern: diag(2491, 1 /* Error */, "The_left_hand_side_of_a_for_in_statement_cannot_be_a_destructuring_pattern_2491", "The left-hand side of a 'for...in' statement cannot be a destructuring pattern."),
-        Cannot_redeclare_identifier_0_in_catch_clause: diag(2492, 1 /* Error */, "Cannot_redeclare_identifier_0_in_catch_clause_2492", "Cannot redeclare identifier '{0}' in catch clause."),
-        Tuple_type_0_of_length_1_has_no_element_at_index_2: diag(2493, 1 /* Error */, "Tuple_type_0_of_length_1_has_no_element_at_index_2_2493", "Tuple type '{0}' of length '{1}' has no element at index '{2}'."),
-        Using_a_string_in_a_for_of_statement_is_only_supported_in_ECMAScript_5_and_higher: diag(2494, 1 /* Error */, "Using_a_string_in_a_for_of_statement_is_only_supported_in_ECMAScript_5_and_higher_2494", "Using a string in a 'for...of' statement is only supported in ECMAScript 5 and higher."),
-        Type_0_is_not_an_array_type_or_a_string_type: diag(2495, 1 /* Error */, "Type_0_is_not_an_array_type_or_a_string_type_2495", "Type '{0}' is not an array type or a string type."),
-        The_arguments_object_cannot_be_referenced_in_an_arrow_function_in_ES3_and_ES5_Consider_using_a_standard_function_expression: diag(2496, 1 /* Error */, "The_arguments_object_cannot_be_referenced_in_an_arrow_function_in_ES3_and_ES5_Consider_using_a_stand_2496", "The 'arguments' object cannot be referenced in an arrow function in ES3 and ES5. Consider using a standard function expression."),
-        This_module_can_only_be_referenced_with_ECMAScript_imports_Slashexports_by_turning_on_the_0_flag_and_referencing_its_default_export: diag(2497, 1 /* Error */, "This_module_can_only_be_referenced_with_ECMAScript_imports_Slashexports_by_turning_on_the_0_flag_and_2497", "This module can only be referenced with ECMAScript imports/exports by turning on the '{0}' flag and referencing its default export."),
-        Module_0_uses_export_and_cannot_be_used_with_export_Asterisk: diag(2498, 1 /* Error */, "Module_0_uses_export_and_cannot_be_used_with_export_Asterisk_2498", "Module '{0}' uses 'export =' and cannot be used with 'export *'."),
-        An_interface_can_only_extend_an_identifier_Slashqualified_name_with_optional_type_arguments: diag(2499, 1 /* Error */, "An_interface_can_only_extend_an_identifier_Slashqualified_name_with_optional_type_arguments_2499", "An interface can only extend an identifier/qualified-name with optional type arguments."),
-        A_class_can_only_implement_an_identifier_Slashqualified_name_with_optional_type_arguments: diag(2500, 1 /* Error */, "A_class_can_only_implement_an_identifier_Slashqualified_name_with_optional_type_arguments_2500", "A class can only implement an identifier/qualified-name with optional type arguments."),
-        A_rest_element_cannot_contain_a_binding_pattern: diag(2501, 1 /* Error */, "A_rest_element_cannot_contain_a_binding_pattern_2501", "A rest element cannot contain a binding pattern."),
-        _0_is_referenced_directly_or_indirectly_in_its_own_type_annotation: diag(2502, 1 /* Error */, "_0_is_referenced_directly_or_indirectly_in_its_own_type_annotation_2502", "'{0}' is referenced directly or indirectly in its own type annotation."),
-        Cannot_find_namespace_0: diag(2503, 1 /* Error */, "Cannot_find_namespace_0_2503", "Cannot find namespace '{0}'."),
-        Type_0_must_have_a_Symbol_asyncIterator_method_that_returns_an_async_iterator: diag(2504, 1 /* Error */, "Type_0_must_have_a_Symbol_asyncIterator_method_that_returns_an_async_iterator_2504", "Type '{0}' must have a '[Symbol.asyncIterator]()' method that returns an async iterator."),
-        A_generator_cannot_have_a_void_type_annotation: diag(2505, 1 /* Error */, "A_generator_cannot_have_a_void_type_annotation_2505", "A generator cannot have a 'void' type annotation."),
-        _0_is_referenced_directly_or_indirectly_in_its_own_base_expression: diag(2506, 1 /* Error */, "_0_is_referenced_directly_or_indirectly_in_its_own_base_expression_2506", "'{0}' is referenced directly or indirectly in its own base expression."),
-        Type_0_is_not_a_constructor_function_type: diag(2507, 1 /* Error */, "Type_0_is_not_a_constructor_function_type_2507", "Type '{0}' is not a constructor function type."),
-        No_base_constructor_has_the_specified_number_of_type_arguments: diag(2508, 1 /* Error */, "No_base_constructor_has_the_specified_number_of_type_arguments_2508", "No base constructor has the specified number of type arguments."),
-        Base_constructor_return_type_0_is_not_an_object_type_or_intersection_of_object_types_with_statically_known_members: diag(2509, 1 /* Error */, "Base_constructor_return_type_0_is_not_an_object_type_or_intersection_of_object_types_with_statically_2509", "Base constructor return type '{0}' is not an object type or intersection of object types with statically known members."),
-        Base_constructors_must_all_have_the_same_return_type: diag(2510, 1 /* Error */, "Base_constructors_must_all_have_the_same_return_type_2510", "Base constructors must all have the same return type."),
-        Cannot_create_an_instance_of_an_abstract_class: diag(2511, 1 /* Error */, "Cannot_create_an_instance_of_an_abstract_class_2511", "Cannot create an instance of an abstract class."),
-        Overload_signatures_must_all_be_abstract_or_non_abstract: diag(2512, 1 /* Error */, "Overload_signatures_must_all_be_abstract_or_non_abstract_2512", "Overload signatures must all be abstract or non-abstract."),
-        Abstract_method_0_in_class_1_cannot_be_accessed_via_super_expression: diag(2513, 1 /* Error */, "Abstract_method_0_in_class_1_cannot_be_accessed_via_super_expression_2513", "Abstract method '{0}' in class '{1}' cannot be accessed via super expression."),
-        A_tuple_type_cannot_be_indexed_with_a_negative_value: diag(2514, 1 /* Error */, "A_tuple_type_cannot_be_indexed_with_a_negative_value_2514", "A tuple type cannot be indexed with a negative value."),
-        Non_abstract_class_0_does_not_implement_inherited_abstract_member_1_from_class_2: diag(2515, 1 /* Error */, "Non_abstract_class_0_does_not_implement_inherited_abstract_member_1_from_class_2_2515", "Non-abstract class '{0}' does not implement inherited abstract member '{1}' from class '{2}'."),
-        All_declarations_of_an_abstract_method_must_be_consecutive: diag(2516, 1 /* Error */, "All_declarations_of_an_abstract_method_must_be_consecutive_2516", "All declarations of an abstract method must be consecutive."),
-        Cannot_assign_an_abstract_constructor_type_to_a_non_abstract_constructor_type: diag(2517, 1 /* Error */, "Cannot_assign_an_abstract_constructor_type_to_a_non_abstract_constructor_type_2517", "Cannot assign an abstract constructor type to a non-abstract constructor type."),
-        A_this_based_type_guard_is_not_compatible_with_a_parameter_based_type_guard: diag(2518, 1 /* Error */, "A_this_based_type_guard_is_not_compatible_with_a_parameter_based_type_guard_2518", "A 'this'-based type guard is not compatible with a parameter-based type guard."),
-        An_async_iterator_must_have_a_next_method: diag(2519, 1 /* Error */, "An_async_iterator_must_have_a_next_method_2519", "An async iterator must have a 'next()' method."),
-        Duplicate_identifier_0_Compiler_uses_declaration_1_to_support_async_functions: diag(2520, 1 /* Error */, "Duplicate_identifier_0_Compiler_uses_declaration_1_to_support_async_functions_2520", "Duplicate identifier '{0}'. Compiler uses declaration '{1}' to support async functions."),
-        The_arguments_object_cannot_be_referenced_in_an_async_function_or_method_in_ES3_and_ES5_Consider_using_a_standard_function_or_method: diag(2522, 1 /* Error */, "The_arguments_object_cannot_be_referenced_in_an_async_function_or_method_in_ES3_and_ES5_Consider_usi_2522", "The 'arguments' object cannot be referenced in an async function or method in ES3 and ES5. Consider using a standard function or method."),
-        yield_expressions_cannot_be_used_in_a_parameter_initializer: diag(2523, 1 /* Error */, "yield_expressions_cannot_be_used_in_a_parameter_initializer_2523", "'yield' expressions cannot be used in a parameter initializer."),
-        await_expressions_cannot_be_used_in_a_parameter_initializer: diag(2524, 1 /* Error */, "await_expressions_cannot_be_used_in_a_parameter_initializer_2524", "'await' expressions cannot be used in a parameter initializer."),
-        Initializer_provides_no_value_for_this_binding_element_and_the_binding_element_has_no_default_value: diag(2525, 1 /* Error */, "Initializer_provides_no_value_for_this_binding_element_and_the_binding_element_has_no_default_value_2525", "Initializer provides no value for this binding element and the binding element has no default value."),
-        A_this_type_is_available_only_in_a_non_static_member_of_a_class_or_interface: diag(2526, 1 /* Error */, "A_this_type_is_available_only_in_a_non_static_member_of_a_class_or_interface_2526", "A 'this' type is available only in a non-static member of a class or interface."),
-        The_inferred_type_of_0_references_an_inaccessible_1_type_A_type_annotation_is_necessary: diag(2527, 1 /* Error */, "The_inferred_type_of_0_references_an_inaccessible_1_type_A_type_annotation_is_necessary_2527", "The inferred type of '{0}' references an inaccessible '{1}' type. A type annotation is necessary."),
-        A_module_cannot_have_multiple_default_exports: diag(2528, 1 /* Error */, "A_module_cannot_have_multiple_default_exports_2528", "A module cannot have multiple default exports."),
-        Duplicate_identifier_0_Compiler_reserves_name_1_in_top_level_scope_of_a_module_containing_async_functions: diag(2529, 1 /* Error */, "Duplicate_identifier_0_Compiler_reserves_name_1_in_top_level_scope_of_a_module_containing_async_func_2529", "Duplicate identifier '{0}'. Compiler reserves name '{1}' in top level scope of a module containing async functions."),
-        Property_0_is_incompatible_with_index_signature: diag(2530, 1 /* Error */, "Property_0_is_incompatible_with_index_signature_2530", "Property '{0}' is incompatible with index signature."),
-        Object_is_possibly_null: diag(2531, 1 /* Error */, "Object_is_possibly_null_2531", "Object is possibly 'null'."),
-        Object_is_possibly_undefined: diag(2532, 1 /* Error */, "Object_is_possibly_undefined_2532", "Object is possibly 'undefined'."),
-        Object_is_possibly_null_or_undefined: diag(2533, 1 /* Error */, "Object_is_possibly_null_or_undefined_2533", "Object is possibly 'null' or 'undefined'."),
-        A_function_returning_never_cannot_have_a_reachable_end_point: diag(2534, 1 /* Error */, "A_function_returning_never_cannot_have_a_reachable_end_point_2534", "A function returning 'never' cannot have a reachable end point."),
-        Type_0_cannot_be_used_to_index_type_1: diag(2536, 1 /* Error */, "Type_0_cannot_be_used_to_index_type_1_2536", "Type '{0}' cannot be used to index type '{1}'."),
-        Type_0_has_no_matching_index_signature_for_type_1: diag(2537, 1 /* Error */, "Type_0_has_no_matching_index_signature_for_type_1_2537", "Type '{0}' has no matching index signature for type '{1}'."),
-        Type_0_cannot_be_used_as_an_index_type: diag(2538, 1 /* Error */, "Type_0_cannot_be_used_as_an_index_type_2538", "Type '{0}' cannot be used as an index type."),
-        Cannot_assign_to_0_because_it_is_not_a_variable: diag(2539, 1 /* Error */, "Cannot_assign_to_0_because_it_is_not_a_variable_2539", "Cannot assign to '{0}' because it is not a variable."),
-        Cannot_assign_to_0_because_it_is_a_read_only_property: diag(2540, 1 /* Error */, "Cannot_assign_to_0_because_it_is_a_read_only_property_2540", "Cannot assign to '{0}' because it is a read-only property."),
-        Index_signature_in_type_0_only_permits_reading: diag(2542, 1 /* Error */, "Index_signature_in_type_0_only_permits_reading_2542", "Index signature in type '{0}' only permits reading."),
-        Duplicate_identifier_newTarget_Compiler_uses_variable_declaration_newTarget_to_capture_new_target_meta_property_reference: diag(2543, 1 /* Error */, "Duplicate_identifier_newTarget_Compiler_uses_variable_declaration_newTarget_to_capture_new_target_me_2543", "Duplicate identifier '_newTarget'. Compiler uses variable declaration '_newTarget' to capture 'new.target' meta-property reference."),
-        Expression_resolves_to_variable_declaration_newTarget_that_compiler_uses_to_capture_new_target_meta_property_reference: diag(2544, 1 /* Error */, "Expression_resolves_to_variable_declaration_newTarget_that_compiler_uses_to_capture_new_target_meta__2544", "Expression resolves to variable declaration '_newTarget' that compiler uses to capture 'new.target' meta-property reference."),
-        A_mixin_class_must_have_a_constructor_with_a_single_rest_parameter_of_type_any: diag(2545, 1 /* Error */, "A_mixin_class_must_have_a_constructor_with_a_single_rest_parameter_of_type_any_2545", "A mixin class must have a constructor with a single rest parameter of type 'any[]'."),
-        The_type_returned_by_the_0_method_of_an_async_iterator_must_be_a_promise_for_a_type_with_a_value_property: diag(2547, 1 /* Error */, "The_type_returned_by_the_0_method_of_an_async_iterator_must_be_a_promise_for_a_type_with_a_value_pro_2547", "The type returned by the '{0}()' method of an async iterator must be a promise for a type with a 'value' property."),
-        Type_0_is_not_an_array_type_or_does_not_have_a_Symbol_iterator_method_that_returns_an_iterator: diag(2548, 1 /* Error */, "Type_0_is_not_an_array_type_or_does_not_have_a_Symbol_iterator_method_that_returns_an_iterator_2548", "Type '{0}' is not an array type or does not have a '[Symbol.iterator]()' method that returns an iterator."),
-        Type_0_is_not_an_array_type_or_a_string_type_or_does_not_have_a_Symbol_iterator_method_that_returns_an_iterator: diag(2549, 1 /* Error */, "Type_0_is_not_an_array_type_or_a_string_type_or_does_not_have_a_Symbol_iterator_method_that_returns__2549", "Type '{0}' is not an array type or a string type or does not have a '[Symbol.iterator]()' method that returns an iterator."),
-        Property_0_does_not_exist_on_type_1_Do_you_need_to_change_your_target_library_Try_changing_the_lib_compiler_option_to_2_or_later: diag(2550, 1 /* Error */, "Property_0_does_not_exist_on_type_1_Do_you_need_to_change_your_target_library_Try_changing_the_lib_c_2550", "Property '{0}' does not exist on type '{1}'. Do you need to change your target library? Try changing the 'lib' compiler option to '{2}' or later."),
-        Property_0_does_not_exist_on_type_1_Did_you_mean_2: diag(2551, 1 /* Error */, "Property_0_does_not_exist_on_type_1_Did_you_mean_2_2551", "Property '{0}' does not exist on type '{1}'. Did you mean '{2}'?"),
-        Cannot_find_name_0_Did_you_mean_1: diag(2552, 1 /* Error */, "Cannot_find_name_0_Did_you_mean_1_2552", "Cannot find name '{0}'. Did you mean '{1}'?"),
-        Computed_values_are_not_permitted_in_an_enum_with_string_valued_members: diag(2553, 1 /* Error */, "Computed_values_are_not_permitted_in_an_enum_with_string_valued_members_2553", "Computed values are not permitted in an enum with string valued members."),
-        Expected_0_arguments_but_got_1: diag(2554, 1 /* Error */, "Expected_0_arguments_but_got_1_2554", "Expected {0} arguments, but got {1}."),
-        Expected_at_least_0_arguments_but_got_1: diag(2555, 1 /* Error */, "Expected_at_least_0_arguments_but_got_1_2555", "Expected at least {0} arguments, but got {1}."),
-        A_spread_argument_must_either_have_a_tuple_type_or_be_passed_to_a_rest_parameter: diag(2556, 1 /* Error */, "A_spread_argument_must_either_have_a_tuple_type_or_be_passed_to_a_rest_parameter_2556", "A spread argument must either have a tuple type or be passed to a rest parameter."),
-        Expected_0_type_arguments_but_got_1: diag(2558, 1 /* Error */, "Expected_0_type_arguments_but_got_1_2558", "Expected {0} type arguments, but got {1}."),
-        Type_0_has_no_properties_in_common_with_type_1: diag(2559, 1 /* Error */, "Type_0_has_no_properties_in_common_with_type_1_2559", "Type '{0}' has no properties in common with type '{1}'."),
-        Value_of_type_0_has_no_properties_in_common_with_type_1_Did_you_mean_to_call_it: diag(2560, 1 /* Error */, "Value_of_type_0_has_no_properties_in_common_with_type_1_Did_you_mean_to_call_it_2560", "Value of type '{0}' has no properties in common with type '{1}'. Did you mean to call it?"),
-        Object_literal_may_only_specify_known_properties_but_0_does_not_exist_in_type_1_Did_you_mean_to_write_2: diag(2561, 1 /* Error */, "Object_literal_may_only_specify_known_properties_but_0_does_not_exist_in_type_1_Did_you_mean_to_writ_2561", "Object literal may only specify known properties, but '{0}' does not exist in type '{1}'. Did you mean to write '{2}'?"),
-        Base_class_expressions_cannot_reference_class_type_parameters: diag(2562, 1 /* Error */, "Base_class_expressions_cannot_reference_class_type_parameters_2562", "Base class expressions cannot reference class type parameters."),
-        The_containing_function_or_module_body_is_too_large_for_control_flow_analysis: diag(2563, 1 /* Error */, "The_containing_function_or_module_body_is_too_large_for_control_flow_analysis_2563", "The containing function or module body is too large for control flow analysis."),
-        Property_0_has_no_initializer_and_is_not_definitely_assigned_in_the_constructor: diag(2564, 1 /* Error */, "Property_0_has_no_initializer_and_is_not_definitely_assigned_in_the_constructor_2564", "Property '{0}' has no initializer and is not definitely assigned in the constructor."),
-        Property_0_is_used_before_being_assigned: diag(2565, 1 /* Error */, "Property_0_is_used_before_being_assigned_2565", "Property '{0}' is used before being assigned."),
-        A_rest_element_cannot_have_a_property_name: diag(2566, 1 /* Error */, "A_rest_element_cannot_have_a_property_name_2566", "A rest element cannot have a property name."),
-        Enum_declarations_can_only_merge_with_namespace_or_other_enum_declarations: diag(2567, 1 /* Error */, "Enum_declarations_can_only_merge_with_namespace_or_other_enum_declarations_2567", "Enum declarations can only merge with namespace or other enum declarations."),
-        Property_0_may_not_exist_on_type_1_Did_you_mean_2: diag(2568, 1 /* Error */, "Property_0_may_not_exist_on_type_1_Did_you_mean_2_2568", "Property '{0}' may not exist on type '{1}'. Did you mean '{2}'?"),
-        Could_not_find_name_0_Did_you_mean_1: diag(2570, 1 /* Error */, "Could_not_find_name_0_Did_you_mean_1_2570", "Could not find name '{0}'. Did you mean '{1}'?"),
-        Object_is_of_type_unknown: diag(2571, 1 /* Error */, "Object_is_of_type_unknown_2571", "Object is of type 'unknown'."),
-        A_rest_element_type_must_be_an_array_type: diag(2574, 1 /* Error */, "A_rest_element_type_must_be_an_array_type_2574", "A rest element type must be an array type."),
-        No_overload_expects_0_arguments_but_overloads_do_exist_that_expect_either_1_or_2_arguments: diag(2575, 1 /* Error */, "No_overload_expects_0_arguments_but_overloads_do_exist_that_expect_either_1_or_2_arguments_2575", "No overload expects {0} arguments, but overloads do exist that expect either {1} or {2} arguments."),
-        Property_0_does_not_exist_on_type_1_Did_you_mean_to_access_the_static_member_2_instead: diag(2576, 1 /* Error */, "Property_0_does_not_exist_on_type_1_Did_you_mean_to_access_the_static_member_2_instead_2576", "Property '{0}' does not exist on type '{1}'. Did you mean to access the static member '{2}' instead?"),
-        Return_type_annotation_circularly_references_itself: diag(2577, 1 /* Error */, "Return_type_annotation_circularly_references_itself_2577", "Return type annotation circularly references itself."),
-        Unused_ts_expect_error_directive: diag(2578, 1 /* Error */, "Unused_ts_expect_error_directive_2578", "Unused '@ts-expect-error' directive."),
-        Cannot_find_name_0_Do_you_need_to_install_type_definitions_for_node_Try_npm_i_save_dev_types_Slashnode: diag(2580, 1 /* Error */, "Cannot_find_name_0_Do_you_need_to_install_type_definitions_for_node_Try_npm_i_save_dev_types_Slashno_2580", "Cannot find name '{0}'. Do you need to install type definitions for node? Try `npm i --save-dev @types/node`."),
-        Cannot_find_name_0_Do_you_need_to_install_type_definitions_for_jQuery_Try_npm_i_save_dev_types_Slashjquery: diag(2581, 1 /* Error */, "Cannot_find_name_0_Do_you_need_to_install_type_definitions_for_jQuery_Try_npm_i_save_dev_types_Slash_2581", "Cannot find name '{0}'. Do you need to install type definitions for jQuery? Try `npm i --save-dev @types/jquery`."),
-        Cannot_find_name_0_Do_you_need_to_install_type_definitions_for_a_test_runner_Try_npm_i_save_dev_types_Slashjest_or_npm_i_save_dev_types_Slashmocha: diag(2582, 1 /* Error */, "Cannot_find_name_0_Do_you_need_to_install_type_definitions_for_a_test_runner_Try_npm_i_save_dev_type_2582", "Cannot find name '{0}'. Do you need to install type definitions for a test runner? Try `npm i --save-dev @types/jest` or `npm i --save-dev @types/mocha`."),
-        Cannot_find_name_0_Do_you_need_to_change_your_target_library_Try_changing_the_lib_compiler_option_to_1_or_later: diag(2583, 1 /* Error */, "Cannot_find_name_0_Do_you_need_to_change_your_target_library_Try_changing_the_lib_compiler_option_to_2583", "Cannot find name '{0}'. Do you need to change your target library? Try changing the 'lib' compiler option to '{1}' or later."),
-        Cannot_find_name_0_Do_you_need_to_change_your_target_library_Try_changing_the_lib_compiler_option_to_include_dom: diag(2584, 1 /* Error */, "Cannot_find_name_0_Do_you_need_to_change_your_target_library_Try_changing_the_lib_compiler_option_to_2584", "Cannot find name '{0}'. Do you need to change your target library? Try changing the 'lib' compiler option to include 'dom'."),
-        _0_only_refers_to_a_type_but_is_being_used_as_a_value_here_Do_you_need_to_change_your_target_library_Try_changing_the_lib_compiler_option_to_es2015_or_later: diag(2585, 1 /* Error */, "_0_only_refers_to_a_type_but_is_being_used_as_a_value_here_Do_you_need_to_change_your_target_library_2585", "'{0}' only refers to a type, but is being used as a value here. Do you need to change your target library? Try changing the 'lib' compiler option to es2015 or later."),
-        Cannot_assign_to_0_because_it_is_a_constant: diag(2588, 1 /* Error */, "Cannot_assign_to_0_because_it_is_a_constant_2588", "Cannot assign to '{0}' because it is a constant."),
-        Type_instantiation_is_excessively_deep_and_possibly_infinite: diag(2589, 1 /* Error */, "Type_instantiation_is_excessively_deep_and_possibly_infinite_2589", "Type instantiation is excessively deep and possibly infinite."),
-        Expression_produces_a_union_type_that_is_too_complex_to_represent: diag(2590, 1 /* Error */, "Expression_produces_a_union_type_that_is_too_complex_to_represent_2590", "Expression produces a union type that is too complex to represent."),
-        Cannot_find_name_0_Do_you_need_to_install_type_definitions_for_node_Try_npm_i_save_dev_types_Slashnode_and_then_add_node_to_the_types_field_in_your_tsconfig: diag(2591, 1 /* Error */, "Cannot_find_name_0_Do_you_need_to_install_type_definitions_for_node_Try_npm_i_save_dev_types_Slashno_2591", "Cannot find name '{0}'. Do you need to install type definitions for node? Try `npm i --save-dev @types/node` and then add 'node' to the types field in your tsconfig."),
-        Cannot_find_name_0_Do_you_need_to_install_type_definitions_for_jQuery_Try_npm_i_save_dev_types_Slashjquery_and_then_add_jquery_to_the_types_field_in_your_tsconfig: diag(2592, 1 /* Error */, "Cannot_find_name_0_Do_you_need_to_install_type_definitions_for_jQuery_Try_npm_i_save_dev_types_Slash_2592", "Cannot find name '{0}'. Do you need to install type definitions for jQuery? Try `npm i --save-dev @types/jquery` and then add 'jquery' to the types field in your tsconfig."),
-        Cannot_find_name_0_Do_you_need_to_install_type_definitions_for_a_test_runner_Try_npm_i_save_dev_types_Slashjest_or_npm_i_save_dev_types_Slashmocha_and_then_add_jest_or_mocha_to_the_types_field_in_your_tsconfig: diag(2593, 1 /* Error */, "Cannot_find_name_0_Do_you_need_to_install_type_definitions_for_a_test_runner_Try_npm_i_save_dev_type_2593", "Cannot find name '{0}'. Do you need to install type definitions for a test runner? Try `npm i --save-dev @types/jest` or `npm i --save-dev @types/mocha` and then add 'jest' or 'mocha' to the types field in your tsconfig."),
-        This_module_is_declared_with_export_and_can_only_be_used_with_a_default_import_when_using_the_0_flag: diag(2594, 1 /* Error */, "This_module_is_declared_with_export_and_can_only_be_used_with_a_default_import_when_using_the_0_flag_2594", "This module is declared with 'export =', and can only be used with a default import when using the '{0}' flag."),
-        _0_can_only_be_imported_by_using_a_default_import: diag(2595, 1 /* Error */, "_0_can_only_be_imported_by_using_a_default_import_2595", "'{0}' can only be imported by using a default import."),
-        _0_can_only_be_imported_by_turning_on_the_esModuleInterop_flag_and_using_a_default_import: diag(2596, 1 /* Error */, "_0_can_only_be_imported_by_turning_on_the_esModuleInterop_flag_and_using_a_default_import_2596", "'{0}' can only be imported by turning on the 'esModuleInterop' flag and using a default import."),
-        _0_can_only_be_imported_by_using_a_require_call_or_by_using_a_default_import: diag(2597, 1 /* Error */, "_0_can_only_be_imported_by_using_a_require_call_or_by_using_a_default_import_2597", "'{0}' can only be imported by using a 'require' call or by using a default import."),
-        _0_can_only_be_imported_by_using_a_require_call_or_by_turning_on_the_esModuleInterop_flag_and_using_a_default_import: diag(2598, 1 /* Error */, "_0_can_only_be_imported_by_using_a_require_call_or_by_turning_on_the_esModuleInterop_flag_and_using__2598", "'{0}' can only be imported by using a 'require' call or by turning on the 'esModuleInterop' flag and using a default import."),
-        JSX_element_implicitly_has_type_any_because_the_global_type_JSX_Element_does_not_exist: diag(2602, 1 /* Error */, "JSX_element_implicitly_has_type_any_because_the_global_type_JSX_Element_does_not_exist_2602", "JSX element implicitly has type 'any' because the global type 'JSX.Element' does not exist."),
-        Property_0_in_type_1_is_not_assignable_to_type_2: diag(2603, 1 /* Error */, "Property_0_in_type_1_is_not_assignable_to_type_2_2603", "Property '{0}' in type '{1}' is not assignable to type '{2}'."),
-        JSX_element_type_0_does_not_have_any_construct_or_call_signatures: diag(2604, 1 /* Error */, "JSX_element_type_0_does_not_have_any_construct_or_call_signatures_2604", "JSX element type '{0}' does not have any construct or call signatures."),
-        Property_0_of_JSX_spread_attribute_is_not_assignable_to_target_property: diag(2606, 1 /* Error */, "Property_0_of_JSX_spread_attribute_is_not_assignable_to_target_property_2606", "Property '{0}' of JSX spread attribute is not assignable to target property."),
-        JSX_element_class_does_not_support_attributes_because_it_does_not_have_a_0_property: diag(2607, 1 /* Error */, "JSX_element_class_does_not_support_attributes_because_it_does_not_have_a_0_property_2607", "JSX element class does not support attributes because it does not have a '{0}' property."),
-        The_global_type_JSX_0_may_not_have_more_than_one_property: diag(2608, 1 /* Error */, "The_global_type_JSX_0_may_not_have_more_than_one_property_2608", "The global type 'JSX.{0}' may not have more than one property."),
-        JSX_spread_child_must_be_an_array_type: diag(2609, 1 /* Error */, "JSX_spread_child_must_be_an_array_type_2609", "JSX spread child must be an array type."),
-        _0_is_defined_as_an_accessor_in_class_1_but_is_overridden_here_in_2_as_an_instance_property: diag(2610, 1 /* Error */, "_0_is_defined_as_an_accessor_in_class_1_but_is_overridden_here_in_2_as_an_instance_property_2610", "'{0}' is defined as an accessor in class '{1}', but is overridden here in '{2}' as an instance property."),
-        _0_is_defined_as_a_property_in_class_1_but_is_overridden_here_in_2_as_an_accessor: diag(2611, 1 /* Error */, "_0_is_defined_as_a_property_in_class_1_but_is_overridden_here_in_2_as_an_accessor_2611", "'{0}' is defined as a property in class '{1}', but is overridden here in '{2}' as an accessor."),
-        Property_0_will_overwrite_the_base_property_in_1_If_this_is_intentional_add_an_initializer_Otherwise_add_a_declare_modifier_or_remove_the_redundant_declaration: diag(2612, 1 /* Error */, "Property_0_will_overwrite_the_base_property_in_1_If_this_is_intentional_add_an_initializer_Otherwise_2612", "Property '{0}' will overwrite the base property in '{1}'. If this is intentional, add an initializer. Otherwise, add a 'declare' modifier or remove the redundant declaration."),
-        Module_0_has_no_default_export_Did_you_mean_to_use_import_1_from_0_instead: diag(2613, 1 /* Error */, "Module_0_has_no_default_export_Did_you_mean_to_use_import_1_from_0_instead_2613", "Module '{0}' has no default export. Did you mean to use 'import { {1} } from {0}' instead?"),
-        Module_0_has_no_exported_member_1_Did_you_mean_to_use_import_1_from_0_instead: diag(2614, 1 /* Error */, "Module_0_has_no_exported_member_1_Did_you_mean_to_use_import_1_from_0_instead_2614", "Module '{0}' has no exported member '{1}'. Did you mean to use 'import {1} from {0}' instead?"),
-        Type_of_property_0_circularly_references_itself_in_mapped_type_1: diag(2615, 1 /* Error */, "Type_of_property_0_circularly_references_itself_in_mapped_type_1_2615", "Type of property '{0}' circularly references itself in mapped type '{1}'."),
-        _0_can_only_be_imported_by_using_import_1_require_2_or_a_default_import: diag(2616, 1 /* Error */, "_0_can_only_be_imported_by_using_import_1_require_2_or_a_default_import_2616", "'{0}' can only be imported by using 'import {1} = require({2})' or a default import."),
-        _0_can_only_be_imported_by_using_import_1_require_2_or_by_turning_on_the_esModuleInterop_flag_and_using_a_default_import: diag(2617, 1 /* Error */, "_0_can_only_be_imported_by_using_import_1_require_2_or_by_turning_on_the_esModuleInterop_flag_and_us_2617", "'{0}' can only be imported by using 'import {1} = require({2})' or by turning on the 'esModuleInterop' flag and using a default import."),
-        Source_has_0_element_s_but_target_requires_1: diag(2618, 1 /* Error */, "Source_has_0_element_s_but_target_requires_1_2618", "Source has {0} element(s) but target requires {1}."),
-        Source_has_0_element_s_but_target_allows_only_1: diag(2619, 1 /* Error */, "Source_has_0_element_s_but_target_allows_only_1_2619", "Source has {0} element(s) but target allows only {1}."),
-        Target_requires_0_element_s_but_source_may_have_fewer: diag(2620, 1 /* Error */, "Target_requires_0_element_s_but_source_may_have_fewer_2620", "Target requires {0} element(s) but source may have fewer."),
-        Target_allows_only_0_element_s_but_source_may_have_more: diag(2621, 1 /* Error */, "Target_allows_only_0_element_s_but_source_may_have_more_2621", "Target allows only {0} element(s) but source may have more."),
-        Source_provides_no_match_for_required_element_at_position_0_in_target: diag(2623, 1 /* Error */, "Source_provides_no_match_for_required_element_at_position_0_in_target_2623", "Source provides no match for required element at position {0} in target."),
-        Source_provides_no_match_for_variadic_element_at_position_0_in_target: diag(2624, 1 /* Error */, "Source_provides_no_match_for_variadic_element_at_position_0_in_target_2624", "Source provides no match for variadic element at position {0} in target."),
-        Variadic_element_at_position_0_in_source_does_not_match_element_at_position_1_in_target: diag(2625, 1 /* Error */, "Variadic_element_at_position_0_in_source_does_not_match_element_at_position_1_in_target_2625", "Variadic element at position {0} in source does not match element at position {1} in target."),
-        Type_at_position_0_in_source_is_not_compatible_with_type_at_position_1_in_target: diag(2626, 1 /* Error */, "Type_at_position_0_in_source_is_not_compatible_with_type_at_position_1_in_target_2626", "Type at position {0} in source is not compatible with type at position {1} in target."),
-        Type_at_positions_0_through_1_in_source_is_not_compatible_with_type_at_position_2_in_target: diag(2627, 1 /* Error */, "Type_at_positions_0_through_1_in_source_is_not_compatible_with_type_at_position_2_in_target_2627", "Type at positions {0} through {1} in source is not compatible with type at position {2} in target."),
-        Cannot_assign_to_0_because_it_is_an_enum: diag(2628, 1 /* Error */, "Cannot_assign_to_0_because_it_is_an_enum_2628", "Cannot assign to '{0}' because it is an enum."),
-        Cannot_assign_to_0_because_it_is_a_class: diag(2629, 1 /* Error */, "Cannot_assign_to_0_because_it_is_a_class_2629", "Cannot assign to '{0}' because it is a class."),
-        Cannot_assign_to_0_because_it_is_a_function: diag(2630, 1 /* Error */, "Cannot_assign_to_0_because_it_is_a_function_2630", "Cannot assign to '{0}' because it is a function."),
-        Cannot_assign_to_0_because_it_is_a_namespace: diag(2631, 1 /* Error */, "Cannot_assign_to_0_because_it_is_a_namespace_2631", "Cannot assign to '{0}' because it is a namespace."),
-        Cannot_assign_to_0_because_it_is_an_import: diag(2632, 1 /* Error */, "Cannot_assign_to_0_because_it_is_an_import_2632", "Cannot assign to '{0}' because it is an import."),
-        JSX_property_access_expressions_cannot_include_JSX_namespace_names: diag(2633, 1 /* Error */, "JSX_property_access_expressions_cannot_include_JSX_namespace_names_2633", "JSX property access expressions cannot include JSX namespace names"),
-        _0_index_signatures_are_incompatible: diag(2634, 1 /* Error */, "_0_index_signatures_are_incompatible_2634", "'{0}' index signatures are incompatible."),
-        Type_0_has_no_signatures_for_which_the_type_argument_list_is_applicable: diag(2635, 1 /* Error */, "Type_0_has_no_signatures_for_which_the_type_argument_list_is_applicable_2635", "Type '{0}' has no signatures for which the type argument list is applicable."),
-        Type_0_is_not_assignable_to_type_1_as_implied_by_variance_annotation: diag(2636, 1 /* Error */, "Type_0_is_not_assignable_to_type_1_as_implied_by_variance_annotation_2636", "Type '{0}' is not assignable to type '{1}' as implied by variance annotation."),
-        Variance_annotations_are_only_supported_in_type_aliases_for_object_function_constructor_and_mapped_types: diag(2637, 1 /* Error */, "Variance_annotations_are_only_supported_in_type_aliases_for_object_function_constructor_and_mapped_t_2637", "Variance annotations are only supported in type aliases for object, function, constructor, and mapped types."),
-        Type_0_may_represent_a_primitive_value_which_is_not_permitted_as_the_right_operand_of_the_in_operator: diag(2638, 1 /* Error */, "Type_0_may_represent_a_primitive_value_which_is_not_permitted_as_the_right_operand_of_the_in_operato_2638", "Type '{0}' may represent a primitive value, which is not permitted as the right operand of the 'in' operator."),
-        React_components_cannot_include_JSX_namespace_names: diag(2639, 1 /* Error */, "React_components_cannot_include_JSX_namespace_names_2639", "React components cannot include JSX namespace names"),
-        Cannot_augment_module_0_with_value_exports_because_it_resolves_to_a_non_module_entity: diag(2649, 1 /* Error */, "Cannot_augment_module_0_with_value_exports_because_it_resolves_to_a_non_module_entity_2649", "Cannot augment module '{0}' with value exports because it resolves to a non-module entity."),
-        A_member_initializer_in_a_enum_declaration_cannot_reference_members_declared_after_it_including_members_defined_in_other_enums: diag(2651, 1 /* Error */, "A_member_initializer_in_a_enum_declaration_cannot_reference_members_declared_after_it_including_memb_2651", "A member initializer in a enum declaration cannot reference members declared after it, including members defined in other enums."),
-        Merged_declaration_0_cannot_include_a_default_export_declaration_Consider_adding_a_separate_export_default_0_declaration_instead: diag(2652, 1 /* Error */, "Merged_declaration_0_cannot_include_a_default_export_declaration_Consider_adding_a_separate_export_d_2652", "Merged declaration '{0}' cannot include a default export declaration. Consider adding a separate 'export default {0}' declaration instead."),
-        Non_abstract_class_expression_does_not_implement_inherited_abstract_member_0_from_class_1: diag(2653, 1 /* Error */, "Non_abstract_class_expression_does_not_implement_inherited_abstract_member_0_from_class_1_2653", "Non-abstract class expression does not implement inherited abstract member '{0}' from class '{1}'."),
-        JSX_expressions_must_have_one_parent_element: diag(2657, 1 /* Error */, "JSX_expressions_must_have_one_parent_element_2657", "JSX expressions must have one parent element."),
-        Type_0_provides_no_match_for_the_signature_1: diag(2658, 1 /* Error */, "Type_0_provides_no_match_for_the_signature_1_2658", "Type '{0}' provides no match for the signature '{1}'."),
-        super_is_only_allowed_in_members_of_object_literal_expressions_when_option_target_is_ES2015_or_higher: diag(2659, 1 /* Error */, "super_is_only_allowed_in_members_of_object_literal_expressions_when_option_target_is_ES2015_or_highe_2659", "'super' is only allowed in members of object literal expressions when option 'target' is 'ES2015' or higher."),
-        super_can_only_be_referenced_in_members_of_derived_classes_or_object_literal_expressions: diag(2660, 1 /* Error */, "super_can_only_be_referenced_in_members_of_derived_classes_or_object_literal_expressions_2660", "'super' can only be referenced in members of derived classes or object literal expressions."),
-        Cannot_export_0_Only_local_declarations_can_be_exported_from_a_module: diag(2661, 1 /* Error */, "Cannot_export_0_Only_local_declarations_can_be_exported_from_a_module_2661", "Cannot export '{0}'. Only local declarations can be exported from a module."),
-        Cannot_find_name_0_Did_you_mean_the_static_member_1_0: diag(2662, 1 /* Error */, "Cannot_find_name_0_Did_you_mean_the_static_member_1_0_2662", "Cannot find name '{0}'. Did you mean the static member '{1}.{0}'?"),
-        Cannot_find_name_0_Did_you_mean_the_instance_member_this_0: diag(2663, 1 /* Error */, "Cannot_find_name_0_Did_you_mean_the_instance_member_this_0_2663", "Cannot find name '{0}'. Did you mean the instance member 'this.{0}'?"),
-        Invalid_module_name_in_augmentation_module_0_cannot_be_found: diag(2664, 1 /* Error */, "Invalid_module_name_in_augmentation_module_0_cannot_be_found_2664", "Invalid module name in augmentation, module '{0}' cannot be found."),
-        Invalid_module_name_in_augmentation_Module_0_resolves_to_an_untyped_module_at_1_which_cannot_be_augmented: diag(2665, 1 /* Error */, "Invalid_module_name_in_augmentation_Module_0_resolves_to_an_untyped_module_at_1_which_cannot_be_augm_2665", "Invalid module name in augmentation. Module '{0}' resolves to an untyped module at '{1}', which cannot be augmented."),
-        Exports_and_export_assignments_are_not_permitted_in_module_augmentations: diag(2666, 1 /* Error */, "Exports_and_export_assignments_are_not_permitted_in_module_augmentations_2666", "Exports and export assignments are not permitted in module augmentations."),
-        Imports_are_not_permitted_in_module_augmentations_Consider_moving_them_to_the_enclosing_external_module: diag(2667, 1 /* Error */, "Imports_are_not_permitted_in_module_augmentations_Consider_moving_them_to_the_enclosing_external_mod_2667", "Imports are not permitted in module augmentations. Consider moving them to the enclosing external module."),
-        export_modifier_cannot_be_applied_to_ambient_modules_and_module_augmentations_since_they_are_always_visible: diag(2668, 1 /* Error */, "export_modifier_cannot_be_applied_to_ambient_modules_and_module_augmentations_since_they_are_always__2668", "'export' modifier cannot be applied to ambient modules and module augmentations since they are always visible."),
-        Augmentations_for_the_global_scope_can_only_be_directly_nested_in_external_modules_or_ambient_module_declarations: diag(2669, 1 /* Error */, "Augmentations_for_the_global_scope_can_only_be_directly_nested_in_external_modules_or_ambient_module_2669", "Augmentations for the global scope can only be directly nested in external modules or ambient module declarations."),
-        Augmentations_for_the_global_scope_should_have_declare_modifier_unless_they_appear_in_already_ambient_context: diag(2670, 1 /* Error */, "Augmentations_for_the_global_scope_should_have_declare_modifier_unless_they_appear_in_already_ambien_2670", "Augmentations for the global scope should have 'declare' modifier unless they appear in already ambient context."),
-        Cannot_augment_module_0_because_it_resolves_to_a_non_module_entity: diag(2671, 1 /* Error */, "Cannot_augment_module_0_because_it_resolves_to_a_non_module_entity_2671", "Cannot augment module '{0}' because it resolves to a non-module entity."),
-        Cannot_assign_a_0_constructor_type_to_a_1_constructor_type: diag(2672, 1 /* Error */, "Cannot_assign_a_0_constructor_type_to_a_1_constructor_type_2672", "Cannot assign a '{0}' constructor type to a '{1}' constructor type."),
-        Constructor_of_class_0_is_private_and_only_accessible_within_the_class_declaration: diag(2673, 1 /* Error */, "Constructor_of_class_0_is_private_and_only_accessible_within_the_class_declaration_2673", "Constructor of class '{0}' is private and only accessible within the class declaration."),
-        Constructor_of_class_0_is_protected_and_only_accessible_within_the_class_declaration: diag(2674, 1 /* Error */, "Constructor_of_class_0_is_protected_and_only_accessible_within_the_class_declaration_2674", "Constructor of class '{0}' is protected and only accessible within the class declaration."),
-        Cannot_extend_a_class_0_Class_constructor_is_marked_as_private: diag(2675, 1 /* Error */, "Cannot_extend_a_class_0_Class_constructor_is_marked_as_private_2675", "Cannot extend a class '{0}'. Class constructor is marked as private."),
-        Accessors_must_both_be_abstract_or_non_abstract: diag(2676, 1 /* Error */, "Accessors_must_both_be_abstract_or_non_abstract_2676", "Accessors must both be abstract or non-abstract."),
-        A_type_predicate_s_type_must_be_assignable_to_its_parameter_s_type: diag(2677, 1 /* Error */, "A_type_predicate_s_type_must_be_assignable_to_its_parameter_s_type_2677", "A type predicate's type must be assignable to its parameter's type."),
-        Type_0_is_not_comparable_to_type_1: diag(2678, 1 /* Error */, "Type_0_is_not_comparable_to_type_1_2678", "Type '{0}' is not comparable to type '{1}'."),
-        A_function_that_is_called_with_the_new_keyword_cannot_have_a_this_type_that_is_void: diag(2679, 1 /* Error */, "A_function_that_is_called_with_the_new_keyword_cannot_have_a_this_type_that_is_void_2679", "A function that is called with the 'new' keyword cannot have a 'this' type that is 'void'."),
-        A_0_parameter_must_be_the_first_parameter: diag(2680, 1 /* Error */, "A_0_parameter_must_be_the_first_parameter_2680", "A '{0}' parameter must be the first parameter."),
-        A_constructor_cannot_have_a_this_parameter: diag(2681, 1 /* Error */, "A_constructor_cannot_have_a_this_parameter_2681", "A constructor cannot have a 'this' parameter."),
-        this_implicitly_has_type_any_because_it_does_not_have_a_type_annotation: diag(2683, 1 /* Error */, "this_implicitly_has_type_any_because_it_does_not_have_a_type_annotation_2683", "'this' implicitly has type 'any' because it does not have a type annotation."),
-        The_this_context_of_type_0_is_not_assignable_to_method_s_this_of_type_1: diag(2684, 1 /* Error */, "The_this_context_of_type_0_is_not_assignable_to_method_s_this_of_type_1_2684", "The 'this' context of type '{0}' is not assignable to method's 'this' of type '{1}'."),
-        The_this_types_of_each_signature_are_incompatible: diag(2685, 1 /* Error */, "The_this_types_of_each_signature_are_incompatible_2685", "The 'this' types of each signature are incompatible."),
-        _0_refers_to_a_UMD_global_but_the_current_file_is_a_module_Consider_adding_an_import_instead: diag(2686, 1 /* Error */, "_0_refers_to_a_UMD_global_but_the_current_file_is_a_module_Consider_adding_an_import_instead_2686", "'{0}' refers to a UMD global, but the current file is a module. Consider adding an import instead."),
-        All_declarations_of_0_must_have_identical_modifiers: diag(2687, 1 /* Error */, "All_declarations_of_0_must_have_identical_modifiers_2687", "All declarations of '{0}' must have identical modifiers."),
-        Cannot_find_type_definition_file_for_0: diag(2688, 1 /* Error */, "Cannot_find_type_definition_file_for_0_2688", "Cannot find type definition file for '{0}'."),
-        Cannot_extend_an_interface_0_Did_you_mean_implements: diag(2689, 1 /* Error */, "Cannot_extend_an_interface_0_Did_you_mean_implements_2689", "Cannot extend an interface '{0}'. Did you mean 'implements'?"),
-        _0_only_refers_to_a_type_but_is_being_used_as_a_value_here_Did_you_mean_to_use_1_in_0: diag(2690, 1 /* Error */, "_0_only_refers_to_a_type_but_is_being_used_as_a_value_here_Did_you_mean_to_use_1_in_0_2690", "'{0}' only refers to a type, but is being used as a value here. Did you mean to use '{1} in {0}'?"),
-        _0_is_a_primitive_but_1_is_a_wrapper_object_Prefer_using_0_when_possible: diag(2692, 1 /* Error */, "_0_is_a_primitive_but_1_is_a_wrapper_object_Prefer_using_0_when_possible_2692", "'{0}' is a primitive, but '{1}' is a wrapper object. Prefer using '{0}' when possible."),
-        _0_only_refers_to_a_type_but_is_being_used_as_a_value_here: diag(2693, 1 /* Error */, "_0_only_refers_to_a_type_but_is_being_used_as_a_value_here_2693", "'{0}' only refers to a type, but is being used as a value here."),
-        Namespace_0_has_no_exported_member_1: diag(2694, 1 /* Error */, "Namespace_0_has_no_exported_member_1_2694", "Namespace '{0}' has no exported member '{1}'."),
-        Left_side_of_comma_operator_is_unused_and_has_no_side_effects: diag(
-          2695,
-          1 /* Error */,
-          "Left_side_of_comma_operator_is_unused_and_has_no_side_effects_2695",
-          "Left side of comma operator is unused and has no side effects.",
-          /*reportsUnnecessary*/
-          true
-        ),
-        The_Object_type_is_assignable_to_very_few_other_types_Did_you_mean_to_use_the_any_type_instead: diag(2696, 1 /* Error */, "The_Object_type_is_assignable_to_very_few_other_types_Did_you_mean_to_use_the_any_type_instead_2696", "The 'Object' type is assignable to very few other types. Did you mean to use the 'any' type instead?"),
-        An_async_function_or_method_must_return_a_Promise_Make_sure_you_have_a_declaration_for_Promise_or_include_ES2015_in_your_lib_option: diag(2697, 1 /* Error */, "An_async_function_or_method_must_return_a_Promise_Make_sure_you_have_a_declaration_for_Promise_or_in_2697", "An async function or method must return a 'Promise'. Make sure you have a declaration for 'Promise' or include 'ES2015' in your '--lib' option."),
-        Spread_types_may_only_be_created_from_object_types: diag(2698, 1 /* Error */, "Spread_types_may_only_be_created_from_object_types_2698", "Spread types may only be created from object types."),
-        Static_property_0_conflicts_with_built_in_property_Function_0_of_constructor_function_1: diag(2699, 1 /* Error */, "Static_property_0_conflicts_with_built_in_property_Function_0_of_constructor_function_1_2699", "Static property '{0}' conflicts with built-in property 'Function.{0}' of constructor function '{1}'."),
-        Rest_types_may_only_be_created_from_object_types: diag(2700, 1 /* Error */, "Rest_types_may_only_be_created_from_object_types_2700", "Rest types may only be created from object types."),
-        The_target_of_an_object_rest_assignment_must_be_a_variable_or_a_property_access: diag(2701, 1 /* Error */, "The_target_of_an_object_rest_assignment_must_be_a_variable_or_a_property_access_2701", "The target of an object rest assignment must be a variable or a property access."),
-        _0_only_refers_to_a_type_but_is_being_used_as_a_namespace_here: diag(2702, 1 /* Error */, "_0_only_refers_to_a_type_but_is_being_used_as_a_namespace_here_2702", "'{0}' only refers to a type, but is being used as a namespace here."),
-        The_operand_of_a_delete_operator_must_be_a_property_reference: diag(2703, 1 /* Error */, "The_operand_of_a_delete_operator_must_be_a_property_reference_2703", "The operand of a 'delete' operator must be a property reference."),
-        The_operand_of_a_delete_operator_cannot_be_a_read_only_property: diag(2704, 1 /* Error */, "The_operand_of_a_delete_operator_cannot_be_a_read_only_property_2704", "The operand of a 'delete' operator cannot be a read-only property."),
-        An_async_function_or_method_in_ES5_SlashES3_requires_the_Promise_constructor_Make_sure_you_have_a_declaration_for_the_Promise_constructor_or_include_ES2015_in_your_lib_option: diag(2705, 1 /* Error */, "An_async_function_or_method_in_ES5_SlashES3_requires_the_Promise_constructor_Make_sure_you_have_a_de_2705", "An async function or method in ES5/ES3 requires the 'Promise' constructor.  Make sure you have a declaration for the 'Promise' constructor or include 'ES2015' in your '--lib' option."),
-        Required_type_parameters_may_not_follow_optional_type_parameters: diag(2706, 1 /* Error */, "Required_type_parameters_may_not_follow_optional_type_parameters_2706", "Required type parameters may not follow optional type parameters."),
-        Generic_type_0_requires_between_1_and_2_type_arguments: diag(2707, 1 /* Error */, "Generic_type_0_requires_between_1_and_2_type_arguments_2707", "Generic type '{0}' requires between {1} and {2} type arguments."),
-        Cannot_use_namespace_0_as_a_value: diag(2708, 1 /* Error */, "Cannot_use_namespace_0_as_a_value_2708", "Cannot use namespace '{0}' as a value."),
-        Cannot_use_namespace_0_as_a_type: diag(2709, 1 /* Error */, "Cannot_use_namespace_0_as_a_type_2709", "Cannot use namespace '{0}' as a type."),
-        _0_are_specified_twice_The_attribute_named_0_will_be_overwritten: diag(2710, 1 /* Error */, "_0_are_specified_twice_The_attribute_named_0_will_be_overwritten_2710", "'{0}' are specified twice. The attribute named '{0}' will be overwritten."),
-        A_dynamic_import_call_returns_a_Promise_Make_sure_you_have_a_declaration_for_Promise_or_include_ES2015_in_your_lib_option: diag(2711, 1 /* Error */, "A_dynamic_import_call_returns_a_Promise_Make_sure_you_have_a_declaration_for_Promise_or_include_ES20_2711", "A dynamic import call returns a 'Promise'. Make sure you have a declaration for 'Promise' or include 'ES2015' in your '--lib' option."),
-        A_dynamic_import_call_in_ES5_SlashES3_requires_the_Promise_constructor_Make_sure_you_have_a_declaration_for_the_Promise_constructor_or_include_ES2015_in_your_lib_option: diag(2712, 1 /* Error */, "A_dynamic_import_call_in_ES5_SlashES3_requires_the_Promise_constructor_Make_sure_you_have_a_declarat_2712", "A dynamic import call in ES5/ES3 requires the 'Promise' constructor.  Make sure you have a declaration for the 'Promise' constructor or include 'ES2015' in your '--lib' option."),
-        Cannot_access_0_1_because_0_is_a_type_but_not_a_namespace_Did_you_mean_to_retrieve_the_type_of_the_property_1_in_0_with_0_1: diag(2713, 1 /* Error */, "Cannot_access_0_1_because_0_is_a_type_but_not_a_namespace_Did_you_mean_to_retrieve_the_type_of_the_p_2713", `Cannot access '{0}.{1}' because '{0}' is a type, but not a namespace. Did you mean to retrieve the type of the property '{1}' in '{0}' with '{0}["{1}"]'?`),
-        The_expression_of_an_export_assignment_must_be_an_identifier_or_qualified_name_in_an_ambient_context: diag(2714, 1 /* Error */, "The_expression_of_an_export_assignment_must_be_an_identifier_or_qualified_name_in_an_ambient_context_2714", "The expression of an export assignment must be an identifier or qualified name in an ambient context."),
-        Abstract_property_0_in_class_1_cannot_be_accessed_in_the_constructor: diag(2715, 1 /* Error */, "Abstract_property_0_in_class_1_cannot_be_accessed_in_the_constructor_2715", "Abstract property '{0}' in class '{1}' cannot be accessed in the constructor."),
-        Type_parameter_0_has_a_circular_default: diag(2716, 1 /* Error */, "Type_parameter_0_has_a_circular_default_2716", "Type parameter '{0}' has a circular default."),
-        Subsequent_property_declarations_must_have_the_same_type_Property_0_must_be_of_type_1_but_here_has_type_2: diag(2717, 1 /* Error */, "Subsequent_property_declarations_must_have_the_same_type_Property_0_must_be_of_type_1_but_here_has_t_2717", "Subsequent property declarations must have the same type.  Property '{0}' must be of type '{1}', but here has type '{2}'."),
-        Duplicate_property_0: diag(2718, 1 /* Error */, "Duplicate_property_0_2718", "Duplicate property '{0}'."),
-        Type_0_is_not_assignable_to_type_1_Two_different_types_with_this_name_exist_but_they_are_unrelated: diag(2719, 1 /* Error */, "Type_0_is_not_assignable_to_type_1_Two_different_types_with_this_name_exist_but_they_are_unrelated_2719", "Type '{0}' is not assignable to type '{1}'. Two different types with this name exist, but they are unrelated."),
-        Class_0_incorrectly_implements_class_1_Did_you_mean_to_extend_1_and_inherit_its_members_as_a_subclass: diag(2720, 1 /* Error */, "Class_0_incorrectly_implements_class_1_Did_you_mean_to_extend_1_and_inherit_its_members_as_a_subclas_2720", "Class '{0}' incorrectly implements class '{1}'. Did you mean to extend '{1}' and inherit its members as a subclass?"),
-        Cannot_invoke_an_object_which_is_possibly_null: diag(2721, 1 /* Error */, "Cannot_invoke_an_object_which_is_possibly_null_2721", "Cannot invoke an object which is possibly 'null'."),
-        Cannot_invoke_an_object_which_is_possibly_undefined: diag(2722, 1 /* Error */, "Cannot_invoke_an_object_which_is_possibly_undefined_2722", "Cannot invoke an object which is possibly 'undefined'."),
-        Cannot_invoke_an_object_which_is_possibly_null_or_undefined: diag(2723, 1 /* Error */, "Cannot_invoke_an_object_which_is_possibly_null_or_undefined_2723", "Cannot invoke an object which is possibly 'null' or 'undefined'."),
-        _0_has_no_exported_member_named_1_Did_you_mean_2: diag(2724, 1 /* Error */, "_0_has_no_exported_member_named_1_Did_you_mean_2_2724", "'{0}' has no exported member named '{1}'. Did you mean '{2}'?"),
-        Class_name_cannot_be_Object_when_targeting_ES5_with_module_0: diag(2725, 1 /* Error */, "Class_name_cannot_be_Object_when_targeting_ES5_with_module_0_2725", "Class name cannot be 'Object' when targeting ES5 with module {0}."),
-        Cannot_find_lib_definition_for_0: diag(2726, 1 /* Error */, "Cannot_find_lib_definition_for_0_2726", "Cannot find lib definition for '{0}'."),
-        Cannot_find_lib_definition_for_0_Did_you_mean_1: diag(2727, 1 /* Error */, "Cannot_find_lib_definition_for_0_Did_you_mean_1_2727", "Cannot find lib definition for '{0}'. Did you mean '{1}'?"),
-        _0_is_declared_here: diag(2728, 3 /* Message */, "_0_is_declared_here_2728", "'{0}' is declared here."),
-        Property_0_is_used_before_its_initialization: diag(2729, 1 /* Error */, "Property_0_is_used_before_its_initialization_2729", "Property '{0}' is used before its initialization."),
-        An_arrow_function_cannot_have_a_this_parameter: diag(2730, 1 /* Error */, "An_arrow_function_cannot_have_a_this_parameter_2730", "An arrow function cannot have a 'this' parameter."),
-        Implicit_conversion_of_a_symbol_to_a_string_will_fail_at_runtime_Consider_wrapping_this_expression_in_String: diag(2731, 1 /* Error */, "Implicit_conversion_of_a_symbol_to_a_string_will_fail_at_runtime_Consider_wrapping_this_expression_i_2731", "Implicit conversion of a 'symbol' to a 'string' will fail at runtime. Consider wrapping this expression in 'String(...)'."),
-        Cannot_find_module_0_Consider_using_resolveJsonModule_to_import_module_with_json_extension: diag(2732, 1 /* Error */, "Cannot_find_module_0_Consider_using_resolveJsonModule_to_import_module_with_json_extension_2732", "Cannot find module '{0}'. Consider using '--resolveJsonModule' to import module with '.json' extension."),
-        Property_0_was_also_declared_here: diag(2733, 1 /* Error */, "Property_0_was_also_declared_here_2733", "Property '{0}' was also declared here."),
-        Are_you_missing_a_semicolon: diag(2734, 1 /* Error */, "Are_you_missing_a_semicolon_2734", "Are you missing a semicolon?"),
-        Did_you_mean_for_0_to_be_constrained_to_type_new_args_Colon_any_1: diag(2735, 1 /* Error */, "Did_you_mean_for_0_to_be_constrained_to_type_new_args_Colon_any_1_2735", "Did you mean for '{0}' to be constrained to type 'new (...args: any[]) => {1}'?"),
-        Operator_0_cannot_be_applied_to_type_1: diag(2736, 1 /* Error */, "Operator_0_cannot_be_applied_to_type_1_2736", "Operator '{0}' cannot be applied to type '{1}'."),
-        BigInt_literals_are_not_available_when_targeting_lower_than_ES2020: diag(2737, 1 /* Error */, "BigInt_literals_are_not_available_when_targeting_lower_than_ES2020_2737", "BigInt literals are not available when targeting lower than ES2020."),
-        An_outer_value_of_this_is_shadowed_by_this_container: diag(2738, 3 /* Message */, "An_outer_value_of_this_is_shadowed_by_this_container_2738", "An outer value of 'this' is shadowed by this container."),
-        Type_0_is_missing_the_following_properties_from_type_1_Colon_2: diag(2739, 1 /* Error */, "Type_0_is_missing_the_following_properties_from_type_1_Colon_2_2739", "Type '{0}' is missing the following properties from type '{1}': {2}"),
-        Type_0_is_missing_the_following_properties_from_type_1_Colon_2_and_3_more: diag(2740, 1 /* Error */, "Type_0_is_missing_the_following_properties_from_type_1_Colon_2_and_3_more_2740", "Type '{0}' is missing the following properties from type '{1}': {2}, and {3} more."),
-        Property_0_is_missing_in_type_1_but_required_in_type_2: diag(2741, 1 /* Error */, "Property_0_is_missing_in_type_1_but_required_in_type_2_2741", "Property '{0}' is missing in type '{1}' but required in type '{2}'."),
-        The_inferred_type_of_0_cannot_be_named_without_a_reference_to_1_This_is_likely_not_portable_A_type_annotation_is_necessary: diag(2742, 1 /* Error */, "The_inferred_type_of_0_cannot_be_named_without_a_reference_to_1_This_is_likely_not_portable_A_type_a_2742", "The inferred type of '{0}' cannot be named without a reference to '{1}'. This is likely not portable. A type annotation is necessary."),
-        No_overload_expects_0_type_arguments_but_overloads_do_exist_that_expect_either_1_or_2_type_arguments: diag(2743, 1 /* Error */, "No_overload_expects_0_type_arguments_but_overloads_do_exist_that_expect_either_1_or_2_type_arguments_2743", "No overload expects {0} type arguments, but overloads do exist that expect either {1} or {2} type arguments."),
-        Type_parameter_defaults_can_only_reference_previously_declared_type_parameters: diag(2744, 1 /* Error */, "Type_parameter_defaults_can_only_reference_previously_declared_type_parameters_2744", "Type parameter defaults can only reference previously declared type parameters."),
-        This_JSX_tag_s_0_prop_expects_type_1_which_requires_multiple_children_but_only_a_single_child_was_provided: diag(2745, 1 /* Error */, "This_JSX_tag_s_0_prop_expects_type_1_which_requires_multiple_children_but_only_a_single_child_was_pr_2745", "This JSX tag's '{0}' prop expects type '{1}' which requires multiple children, but only a single child was provided."),
-        This_JSX_tag_s_0_prop_expects_a_single_child_of_type_1_but_multiple_children_were_provided: diag(2746, 1 /* Error */, "This_JSX_tag_s_0_prop_expects_a_single_child_of_type_1_but_multiple_children_were_provided_2746", "This JSX tag's '{0}' prop expects a single child of type '{1}', but multiple children were provided."),
-        _0_components_don_t_accept_text_as_child_elements_Text_in_JSX_has_the_type_string_but_the_expected_type_of_1_is_2: diag(2747, 1 /* Error */, "_0_components_don_t_accept_text_as_child_elements_Text_in_JSX_has_the_type_string_but_the_expected_t_2747", "'{0}' components don't accept text as child elements. Text in JSX has the type 'string', but the expected type of '{1}' is '{2}'."),
-        Cannot_access_ambient_const_enums_when_0_is_enabled: diag(2748, 1 /* Error */, "Cannot_access_ambient_const_enums_when_0_is_enabled_2748", "Cannot access ambient const enums when '{0}' is enabled."),
-        _0_refers_to_a_value_but_is_being_used_as_a_type_here_Did_you_mean_typeof_0: diag(2749, 1 /* Error */, "_0_refers_to_a_value_but_is_being_used_as_a_type_here_Did_you_mean_typeof_0_2749", "'{0}' refers to a value, but is being used as a type here. Did you mean 'typeof {0}'?"),
-        The_implementation_signature_is_declared_here: diag(2750, 1 /* Error */, "The_implementation_signature_is_declared_here_2750", "The implementation signature is declared here."),
-        Circularity_originates_in_type_at_this_location: diag(2751, 1 /* Error */, "Circularity_originates_in_type_at_this_location_2751", "Circularity originates in type at this location."),
-        The_first_export_default_is_here: diag(2752, 1 /* Error */, "The_first_export_default_is_here_2752", "The first export default is here."),
-        Another_export_default_is_here: diag(2753, 1 /* Error */, "Another_export_default_is_here_2753", "Another export default is here."),
-        super_may_not_use_type_arguments: diag(2754, 1 /* Error */, "super_may_not_use_type_arguments_2754", "'super' may not use type arguments."),
-        No_constituent_of_type_0_is_callable: diag(2755, 1 /* Error */, "No_constituent_of_type_0_is_callable_2755", "No constituent of type '{0}' is callable."),
-        Not_all_constituents_of_type_0_are_callable: diag(2756, 1 /* Error */, "Not_all_constituents_of_type_0_are_callable_2756", "Not all constituents of type '{0}' are callable."),
-        Type_0_has_no_call_signatures: diag(2757, 1 /* Error */, "Type_0_has_no_call_signatures_2757", "Type '{0}' has no call signatures."),
-        Each_member_of_the_union_type_0_has_signatures_but_none_of_those_signatures_are_compatible_with_each_other: diag(2758, 1 /* Error */, "Each_member_of_the_union_type_0_has_signatures_but_none_of_those_signatures_are_compatible_with_each_2758", "Each member of the union type '{0}' has signatures, but none of those signatures are compatible with each other."),
-        No_constituent_of_type_0_is_constructable: diag(2759, 1 /* Error */, "No_constituent_of_type_0_is_constructable_2759", "No constituent of type '{0}' is constructable."),
-        Not_all_constituents_of_type_0_are_constructable: diag(2760, 1 /* Error */, "Not_all_constituents_of_type_0_are_constructable_2760", "Not all constituents of type '{0}' are constructable."),
-        Type_0_has_no_construct_signatures: diag(2761, 1 /* Error */, "Type_0_has_no_construct_signatures_2761", "Type '{0}' has no construct signatures."),
-        Each_member_of_the_union_type_0_has_construct_signatures_but_none_of_those_signatures_are_compatible_with_each_other: diag(2762, 1 /* Error */, "Each_member_of_the_union_type_0_has_construct_signatures_but_none_of_those_signatures_are_compatible_2762", "Each member of the union type '{0}' has construct signatures, but none of those signatures are compatible with each other."),
-        Cannot_iterate_value_because_the_next_method_of_its_iterator_expects_type_1_but_for_of_will_always_send_0: diag(2763, 1 /* Error */, "Cannot_iterate_value_because_the_next_method_of_its_iterator_expects_type_1_but_for_of_will_always_s_2763", "Cannot iterate value because the 'next' method of its iterator expects type '{1}', but for-of will always send '{0}'."),
-        Cannot_iterate_value_because_the_next_method_of_its_iterator_expects_type_1_but_array_spread_will_always_send_0: diag(2764, 1 /* Error */, "Cannot_iterate_value_because_the_next_method_of_its_iterator_expects_type_1_but_array_spread_will_al_2764", "Cannot iterate value because the 'next' method of its iterator expects type '{1}', but array spread will always send '{0}'."),
-        Cannot_iterate_value_because_the_next_method_of_its_iterator_expects_type_1_but_array_destructuring_will_always_send_0: diag(2765, 1 /* Error */, "Cannot_iterate_value_because_the_next_method_of_its_iterator_expects_type_1_but_array_destructuring__2765", "Cannot iterate value because the 'next' method of its iterator expects type '{1}', but array destructuring will always send '{0}'."),
-        Cannot_delegate_iteration_to_value_because_the_next_method_of_its_iterator_expects_type_1_but_the_containing_generator_will_always_send_0: diag(2766, 1 /* Error */, "Cannot_delegate_iteration_to_value_because_the_next_method_of_its_iterator_expects_type_1_but_the_co_2766", "Cannot delegate iteration to value because the 'next' method of its iterator expects type '{1}', but the containing generator will always send '{0}'."),
-        The_0_property_of_an_iterator_must_be_a_method: diag(2767, 1 /* Error */, "The_0_property_of_an_iterator_must_be_a_method_2767", "The '{0}' property of an iterator must be a method."),
-        The_0_property_of_an_async_iterator_must_be_a_method: diag(2768, 1 /* Error */, "The_0_property_of_an_async_iterator_must_be_a_method_2768", "The '{0}' property of an async iterator must be a method."),
-        No_overload_matches_this_call: diag(2769, 1 /* Error */, "No_overload_matches_this_call_2769", "No overload matches this call."),
-        The_last_overload_gave_the_following_error: diag(2770, 1 /* Error */, "The_last_overload_gave_the_following_error_2770", "The last overload gave the following error."),
-        The_last_overload_is_declared_here: diag(2771, 1 /* Error */, "The_last_overload_is_declared_here_2771", "The last overload is declared here."),
-        Overload_0_of_1_2_gave_the_following_error: diag(2772, 1 /* Error */, "Overload_0_of_1_2_gave_the_following_error_2772", "Overload {0} of {1}, '{2}', gave the following error."),
-        Did_you_forget_to_use_await: diag(2773, 1 /* Error */, "Did_you_forget_to_use_await_2773", "Did you forget to use 'await'?"),
-        This_condition_will_always_return_true_since_this_function_is_always_defined_Did_you_mean_to_call_it_instead: diag(2774, 1 /* Error */, "This_condition_will_always_return_true_since_this_function_is_always_defined_Did_you_mean_to_call_it_2774", "This condition will always return true since this function is always defined. Did you mean to call it instead?"),
-        Assertions_require_every_name_in_the_call_target_to_be_declared_with_an_explicit_type_annotation: diag(2775, 1 /* Error */, "Assertions_require_every_name_in_the_call_target_to_be_declared_with_an_explicit_type_annotation_2775", "Assertions require every name in the call target to be declared with an explicit type annotation."),
-        Assertions_require_the_call_target_to_be_an_identifier_or_qualified_name: diag(2776, 1 /* Error */, "Assertions_require_the_call_target_to_be_an_identifier_or_qualified_name_2776", "Assertions require the call target to be an identifier or qualified name."),
-        The_operand_of_an_increment_or_decrement_operator_may_not_be_an_optional_property_access: diag(2777, 1 /* Error */, "The_operand_of_an_increment_or_decrement_operator_may_not_be_an_optional_property_access_2777", "The operand of an increment or decrement operator may not be an optional property access."),
-        The_target_of_an_object_rest_assignment_may_not_be_an_optional_property_access: diag(2778, 1 /* Error */, "The_target_of_an_object_rest_assignment_may_not_be_an_optional_property_access_2778", "The target of an object rest assignment may not be an optional property access."),
-        The_left_hand_side_of_an_assignment_expression_may_not_be_an_optional_property_access: diag(2779, 1 /* Error */, "The_left_hand_side_of_an_assignment_expression_may_not_be_an_optional_property_access_2779", "The left-hand side of an assignment expression may not be an optional property access."),
-        The_left_hand_side_of_a_for_in_statement_may_not_be_an_optional_property_access: diag(2780, 1 /* Error */, "The_left_hand_side_of_a_for_in_statement_may_not_be_an_optional_property_access_2780", "The left-hand side of a 'for...in' statement may not be an optional property access."),
-        The_left_hand_side_of_a_for_of_statement_may_not_be_an_optional_property_access: diag(2781, 1 /* Error */, "The_left_hand_side_of_a_for_of_statement_may_not_be_an_optional_property_access_2781", "The left-hand side of a 'for...of' statement may not be an optional property access."),
-        _0_needs_an_explicit_type_annotation: diag(2782, 3 /* Message */, "_0_needs_an_explicit_type_annotation_2782", "'{0}' needs an explicit type annotation."),
-        _0_is_specified_more_than_once_so_this_usage_will_be_overwritten: diag(2783, 1 /* Error */, "_0_is_specified_more_than_once_so_this_usage_will_be_overwritten_2783", "'{0}' is specified more than once, so this usage will be overwritten."),
-        get_and_set_accessors_cannot_declare_this_parameters: diag(2784, 1 /* Error */, "get_and_set_accessors_cannot_declare_this_parameters_2784", "'get' and 'set' accessors cannot declare 'this' parameters."),
-        This_spread_always_overwrites_this_property: diag(2785, 1 /* Error */, "This_spread_always_overwrites_this_property_2785", "This spread always overwrites this property."),
-        _0_cannot_be_used_as_a_JSX_component: diag(2786, 1 /* Error */, "_0_cannot_be_used_as_a_JSX_component_2786", "'{0}' cannot be used as a JSX component."),
-        Its_return_type_0_is_not_a_valid_JSX_element: diag(2787, 1 /* Error */, "Its_return_type_0_is_not_a_valid_JSX_element_2787", "Its return type '{0}' is not a valid JSX element."),
-        Its_instance_type_0_is_not_a_valid_JSX_element: diag(2788, 1 /* Error */, "Its_instance_type_0_is_not_a_valid_JSX_element_2788", "Its instance type '{0}' is not a valid JSX element."),
-        Its_element_type_0_is_not_a_valid_JSX_element: diag(2789, 1 /* Error */, "Its_element_type_0_is_not_a_valid_JSX_element_2789", "Its element type '{0}' is not a valid JSX element."),
-        The_operand_of_a_delete_operator_must_be_optional: diag(2790, 1 /* Error */, "The_operand_of_a_delete_operator_must_be_optional_2790", "The operand of a 'delete' operator must be optional."),
-        Exponentiation_cannot_be_performed_on_bigint_values_unless_the_target_option_is_set_to_es2016_or_later: diag(2791, 1 /* Error */, "Exponentiation_cannot_be_performed_on_bigint_values_unless_the_target_option_is_set_to_es2016_or_lat_2791", "Exponentiation cannot be performed on 'bigint' values unless the 'target' option is set to 'es2016' or later."),
-        Cannot_find_module_0_Did_you_mean_to_set_the_moduleResolution_option_to_nodenext_or_to_add_aliases_to_the_paths_option: diag(2792, 1 /* Error */, "Cannot_find_module_0_Did_you_mean_to_set_the_moduleResolution_option_to_nodenext_or_to_add_aliases_t_2792", "Cannot find module '{0}'. Did you mean to set the 'moduleResolution' option to 'nodenext', or to add aliases to the 'paths' option?"),
-        The_call_would_have_succeeded_against_this_implementation_but_implementation_signatures_of_overloads_are_not_externally_visible: diag(2793, 1 /* Error */, "The_call_would_have_succeeded_against_this_implementation_but_implementation_signatures_of_overloads_2793", "The call would have succeeded against this implementation, but implementation signatures of overloads are not externally visible."),
-        Expected_0_arguments_but_got_1_Did_you_forget_to_include_void_in_your_type_argument_to_Promise: diag(2794, 1 /* Error */, "Expected_0_arguments_but_got_1_Did_you_forget_to_include_void_in_your_type_argument_to_Promise_2794", "Expected {0} arguments, but got {1}. Did you forget to include 'void' in your type argument to 'Promise'?"),
-        The_intrinsic_keyword_can_only_be_used_to_declare_compiler_provided_intrinsic_types: diag(2795, 1 /* Error */, "The_intrinsic_keyword_can_only_be_used_to_declare_compiler_provided_intrinsic_types_2795", "The 'intrinsic' keyword can only be used to declare compiler provided intrinsic types."),
-        It_is_likely_that_you_are_missing_a_comma_to_separate_these_two_template_expressions_They_form_a_tagged_template_expression_which_cannot_be_invoked: diag(2796, 1 /* Error */, "It_is_likely_that_you_are_missing_a_comma_to_separate_these_two_template_expressions_They_form_a_tag_2796", "It is likely that you are missing a comma to separate these two template expressions. They form a tagged template expression which cannot be invoked."),
-        A_mixin_class_that_extends_from_a_type_variable_containing_an_abstract_construct_signature_must_also_be_declared_abstract: diag(2797, 1 /* Error */, "A_mixin_class_that_extends_from_a_type_variable_containing_an_abstract_construct_signature_must_also_2797", "A mixin class that extends from a type variable containing an abstract construct signature must also be declared 'abstract'."),
-        The_declaration_was_marked_as_deprecated_here: diag(2798, 1 /* Error */, "The_declaration_was_marked_as_deprecated_here_2798", "The declaration was marked as deprecated here."),
-        Type_produces_a_tuple_type_that_is_too_large_to_represent: diag(2799, 1 /* Error */, "Type_produces_a_tuple_type_that_is_too_large_to_represent_2799", "Type produces a tuple type that is too large to represent."),
-        Expression_produces_a_tuple_type_that_is_too_large_to_represent: diag(2800, 1 /* Error */, "Expression_produces_a_tuple_type_that_is_too_large_to_represent_2800", "Expression produces a tuple type that is too large to represent."),
-        This_condition_will_always_return_true_since_this_0_is_always_defined: diag(2801, 1 /* Error */, "This_condition_will_always_return_true_since_this_0_is_always_defined_2801", "This condition will always return true since this '{0}' is always defined."),
-        Type_0_can_only_be_iterated_through_when_using_the_downlevelIteration_flag_or_with_a_target_of_es2015_or_higher: diag(2802, 1 /* Error */, "Type_0_can_only_be_iterated_through_when_using_the_downlevelIteration_flag_or_with_a_target_of_es201_2802", "Type '{0}' can only be iterated through when using the '--downlevelIteration' flag or with a '--target' of 'es2015' or higher."),
-        Cannot_assign_to_private_method_0_Private_methods_are_not_writable: diag(2803, 1 /* Error */, "Cannot_assign_to_private_method_0_Private_methods_are_not_writable_2803", "Cannot assign to private method '{0}'. Private methods are not writable."),
-        Duplicate_identifier_0_Static_and_instance_elements_cannot_share_the_same_private_name: diag(2804, 1 /* Error */, "Duplicate_identifier_0_Static_and_instance_elements_cannot_share_the_same_private_name_2804", "Duplicate identifier '{0}'. Static and instance elements cannot share the same private name."),
-        Private_accessor_was_defined_without_a_getter: diag(2806, 1 /* Error */, "Private_accessor_was_defined_without_a_getter_2806", "Private accessor was defined without a getter."),
-        This_syntax_requires_an_imported_helper_named_1_with_2_parameters_which_is_not_compatible_with_the_one_in_0_Consider_upgrading_your_version_of_0: diag(2807, 1 /* Error */, "This_syntax_requires_an_imported_helper_named_1_with_2_parameters_which_is_not_compatible_with_the_o_2807", "This syntax requires an imported helper named '{1}' with {2} parameters, which is not compatible with the one in '{0}'. Consider upgrading your version of '{0}'."),
-        A_get_accessor_must_be_at_least_as_accessible_as_the_setter: diag(2808, 1 /* Error */, "A_get_accessor_must_be_at_least_as_accessible_as_the_setter_2808", "A get accessor must be at least as accessible as the setter"),
-        Declaration_or_statement_expected_This_follows_a_block_of_statements_so_if_you_intended_to_write_a_destructuring_assignment_you_might_need_to_wrap_the_whole_assignment_in_parentheses: diag(2809, 1 /* Error */, "Declaration_or_statement_expected_This_follows_a_block_of_statements_so_if_you_intended_to_write_a_d_2809", "Declaration or statement expected. This '=' follows a block of statements, so if you intended to write a destructuring assignment, you might need to wrap the whole assignment in parentheses."),
-        Expected_1_argument_but_got_0_new_Promise_needs_a_JSDoc_hint_to_produce_a_resolve_that_can_be_called_without_arguments: diag(2810, 1 /* Error */, "Expected_1_argument_but_got_0_new_Promise_needs_a_JSDoc_hint_to_produce_a_resolve_that_can_be_called_2810", "Expected 1 argument, but got 0. 'new Promise()' needs a JSDoc hint to produce a 'resolve' that can be called without arguments."),
-        Initializer_for_property_0: diag(2811, 1 /* Error */, "Initializer_for_property_0_2811", "Initializer for property '{0}'"),
-        Property_0_does_not_exist_on_type_1_Try_changing_the_lib_compiler_option_to_include_dom: diag(2812, 1 /* Error */, "Property_0_does_not_exist_on_type_1_Try_changing_the_lib_compiler_option_to_include_dom_2812", "Property '{0}' does not exist on type '{1}'. Try changing the 'lib' compiler option to include 'dom'."),
-        Class_declaration_cannot_implement_overload_list_for_0: diag(2813, 1 /* Error */, "Class_declaration_cannot_implement_overload_list_for_0_2813", "Class declaration cannot implement overload list for '{0}'."),
-        Function_with_bodies_can_only_merge_with_classes_that_are_ambient: diag(2814, 1 /* Error */, "Function_with_bodies_can_only_merge_with_classes_that_are_ambient_2814", "Function with bodies can only merge with classes that are ambient."),
-        arguments_cannot_be_referenced_in_property_initializers: diag(2815, 1 /* Error */, "arguments_cannot_be_referenced_in_property_initializers_2815", "'arguments' cannot be referenced in property initializers."),
-        Cannot_use_this_in_a_static_property_initializer_of_a_decorated_class: diag(2816, 1 /* Error */, "Cannot_use_this_in_a_static_property_initializer_of_a_decorated_class_2816", "Cannot use 'this' in a static property initializer of a decorated class."),
-        Property_0_has_no_initializer_and_is_not_definitely_assigned_in_a_class_static_block: diag(2817, 1 /* Error */, "Property_0_has_no_initializer_and_is_not_definitely_assigned_in_a_class_static_block_2817", "Property '{0}' has no initializer and is not definitely assigned in a class static block."),
-        Duplicate_identifier_0_Compiler_reserves_name_1_when_emitting_super_references_in_static_initializers: diag(2818, 1 /* Error */, "Duplicate_identifier_0_Compiler_reserves_name_1_when_emitting_super_references_in_static_initializer_2818", "Duplicate identifier '{0}'. Compiler reserves name '{1}' when emitting 'super' references in static initializers."),
-        Namespace_name_cannot_be_0: diag(2819, 1 /* Error */, "Namespace_name_cannot_be_0_2819", "Namespace name cannot be '{0}'."),
-        Type_0_is_not_assignable_to_type_1_Did_you_mean_2: diag(2820, 1 /* Error */, "Type_0_is_not_assignable_to_type_1_Did_you_mean_2_2820", "Type '{0}' is not assignable to type '{1}'. Did you mean '{2}'?"),
-        Import_assertions_are_only_supported_when_the_module_option_is_set_to_esnext_or_nodenext: diag(2821, 1 /* Error */, "Import_assertions_are_only_supported_when_the_module_option_is_set_to_esnext_or_nodenext_2821", "Import assertions are only supported when the '--module' option is set to 'esnext' or 'nodenext'."),
-        Import_assertions_cannot_be_used_with_type_only_imports_or_exports: diag(2822, 1 /* Error */, "Import_assertions_cannot_be_used_with_type_only_imports_or_exports_2822", "Import assertions cannot be used with type-only imports or exports."),
-        Cannot_find_namespace_0_Did_you_mean_1: diag(2833, 1 /* Error */, "Cannot_find_namespace_0_Did_you_mean_1_2833", "Cannot find namespace '{0}'. Did you mean '{1}'?"),
-        Relative_import_paths_need_explicit_file_extensions_in_EcmaScript_imports_when_moduleResolution_is_node16_or_nodenext_Consider_adding_an_extension_to_the_import_path: diag(2834, 1 /* Error */, "Relative_import_paths_need_explicit_file_extensions_in_EcmaScript_imports_when_moduleResolution_is_n_2834", "Relative import paths need explicit file extensions in EcmaScript imports when '--moduleResolution' is 'node16' or 'nodenext'. Consider adding an extension to the import path."),
-        Relative_import_paths_need_explicit_file_extensions_in_EcmaScript_imports_when_moduleResolution_is_node16_or_nodenext_Did_you_mean_0: diag(2835, 1 /* Error */, "Relative_import_paths_need_explicit_file_extensions_in_EcmaScript_imports_when_moduleResolution_is_n_2835", "Relative import paths need explicit file extensions in EcmaScript imports when '--moduleResolution' is 'node16' or 'nodenext'. Did you mean '{0}'?"),
-        Import_assertions_are_not_allowed_on_statements_that_transpile_to_commonjs_require_calls: diag(2836, 1 /* Error */, "Import_assertions_are_not_allowed_on_statements_that_transpile_to_commonjs_require_calls_2836", "Import assertions are not allowed on statements that transpile to commonjs 'require' calls."),
-        Import_assertion_values_must_be_string_literal_expressions: diag(2837, 1 /* Error */, "Import_assertion_values_must_be_string_literal_expressions_2837", "Import assertion values must be string literal expressions."),
-        All_declarations_of_0_must_have_identical_constraints: diag(2838, 1 /* Error */, "All_declarations_of_0_must_have_identical_constraints_2838", "All declarations of '{0}' must have identical constraints."),
-        This_condition_will_always_return_0_since_JavaScript_compares_objects_by_reference_not_value: diag(2839, 1 /* Error */, "This_condition_will_always_return_0_since_JavaScript_compares_objects_by_reference_not_value_2839", "This condition will always return '{0}' since JavaScript compares objects by reference, not value."),
-        An_interface_cannot_extend_a_primitive_type_like_0_an_interface_can_only_extend_named_types_and_classes: diag(2840, 1 /* Error */, "An_interface_cannot_extend_a_primitive_type_like_0_an_interface_can_only_extend_named_types_and_clas_2840", "An interface cannot extend a primitive type like '{0}'; an interface can only extend named types and classes"),
-        The_type_of_this_expression_cannot_be_named_without_a_resolution_mode_assertion_which_is_an_unstable_feature_Use_nightly_TypeScript_to_silence_this_error_Try_updating_with_npm_install_D_typescript_next: diag(2841, 1 /* Error */, "The_type_of_this_expression_cannot_be_named_without_a_resolution_mode_assertion_which_is_an_unstable_2841", "The type of this expression cannot be named without a 'resolution-mode' assertion, which is an unstable feature. Use nightly TypeScript to silence this error. Try updating with 'npm install -D typescript@next'."),
-        _0_is_an_unused_renaming_of_1_Did_you_intend_to_use_it_as_a_type_annotation: diag(2842, 1 /* Error */, "_0_is_an_unused_renaming_of_1_Did_you_intend_to_use_it_as_a_type_annotation_2842", "'{0}' is an unused renaming of '{1}'. Did you intend to use it as a type annotation?"),
-        We_can_only_write_a_type_for_0_by_adding_a_type_for_the_entire_parameter_here: diag(2843, 1 /* Error */, "We_can_only_write_a_type_for_0_by_adding_a_type_for_the_entire_parameter_here_2843", "We can only write a type for '{0}' by adding a type for the entire parameter here."),
-        Type_of_instance_member_variable_0_cannot_reference_identifier_1_declared_in_the_constructor: diag(2844, 1 /* Error */, "Type_of_instance_member_variable_0_cannot_reference_identifier_1_declared_in_the_constructor_2844", "Type of instance member variable '{0}' cannot reference identifier '{1}' declared in the constructor."),
-        This_condition_will_always_return_0: diag(2845, 1 /* Error */, "This_condition_will_always_return_0_2845", "This condition will always return '{0}'."),
-        A_declaration_file_cannot_be_imported_without_import_type_Did_you_mean_to_import_an_implementation_file_0_instead: diag(2846, 1 /* Error */, "A_declaration_file_cannot_be_imported_without_import_type_Did_you_mean_to_import_an_implementation_f_2846", "A declaration file cannot be imported without 'import type'. Did you mean to import an implementation file '{0}' instead?"),
-        The_right_hand_side_of_an_instanceof_expression_must_not_be_an_instantiation_expression: diag(2848, 1 /* Error */, "The_right_hand_side_of_an_instanceof_expression_must_not_be_an_instantiation_expression_2848", "The right-hand side of an 'instanceof' expression must not be an instantiation expression."),
-        Target_signature_provides_too_few_arguments_Expected_0_or_more_but_got_1: diag(2849, 1 /* Error */, "Target_signature_provides_too_few_arguments_Expected_0_or_more_but_got_1_2849", "Target signature provides too few arguments. Expected {0} or more, but got {1}."),
-        Import_declaration_0_is_using_private_name_1: diag(4e3, 1 /* Error */, "Import_declaration_0_is_using_private_name_1_4000", "Import declaration '{0}' is using private name '{1}'."),
-        Type_parameter_0_of_exported_class_has_or_is_using_private_name_1: diag(4002, 1 /* Error */, "Type_parameter_0_of_exported_class_has_or_is_using_private_name_1_4002", "Type parameter '{0}' of exported class has or is using private name '{1}'."),
-        Type_parameter_0_of_exported_interface_has_or_is_using_private_name_1: diag(4004, 1 /* Error */, "Type_parameter_0_of_exported_interface_has_or_is_using_private_name_1_4004", "Type parameter '{0}' of exported interface has or is using private name '{1}'."),
-        Type_parameter_0_of_constructor_signature_from_exported_interface_has_or_is_using_private_name_1: diag(4006, 1 /* Error */, "Type_parameter_0_of_constructor_signature_from_exported_interface_has_or_is_using_private_name_1_4006", "Type parameter '{0}' of constructor signature from exported interface has or is using private name '{1}'."),
-        Type_parameter_0_of_call_signature_from_exported_interface_has_or_is_using_private_name_1: diag(4008, 1 /* Error */, "Type_parameter_0_of_call_signature_from_exported_interface_has_or_is_using_private_name_1_4008", "Type parameter '{0}' of call signature from exported interface has or is using private name '{1}'."),
-        Type_parameter_0_of_public_static_method_from_exported_class_has_or_is_using_private_name_1: diag(4010, 1 /* Error */, "Type_parameter_0_of_public_static_method_from_exported_class_has_or_is_using_private_name_1_4010", "Type parameter '{0}' of public static method from exported class has or is using private name '{1}'."),
-        Type_parameter_0_of_public_method_from_exported_class_has_or_is_using_private_name_1: diag(4012, 1 /* Error */, "Type_parameter_0_of_public_method_from_exported_class_has_or_is_using_private_name_1_4012", "Type parameter '{0}' of public method from exported class has or is using private name '{1}'."),
-        Type_parameter_0_of_method_from_exported_interface_has_or_is_using_private_name_1: diag(4014, 1 /* Error */, "Type_parameter_0_of_method_from_exported_interface_has_or_is_using_private_name_1_4014", "Type parameter '{0}' of method from exported interface has or is using private name '{1}'."),
-        Type_parameter_0_of_exported_function_has_or_is_using_private_name_1: diag(4016, 1 /* Error */, "Type_parameter_0_of_exported_function_has_or_is_using_private_name_1_4016", "Type parameter '{0}' of exported function has or is using private name '{1}'."),
-        Implements_clause_of_exported_class_0_has_or_is_using_private_name_1: diag(4019, 1 /* Error */, "Implements_clause_of_exported_class_0_has_or_is_using_private_name_1_4019", "Implements clause of exported class '{0}' has or is using private name '{1}'."),
-        extends_clause_of_exported_class_0_has_or_is_using_private_name_1: diag(4020, 1 /* Error */, "extends_clause_of_exported_class_0_has_or_is_using_private_name_1_4020", "'extends' clause of exported class '{0}' has or is using private name '{1}'."),
-        extends_clause_of_exported_class_has_or_is_using_private_name_0: diag(4021, 1 /* Error */, "extends_clause_of_exported_class_has_or_is_using_private_name_0_4021", "'extends' clause of exported class has or is using private name '{0}'."),
-        extends_clause_of_exported_interface_0_has_or_is_using_private_name_1: diag(4022, 1 /* Error */, "extends_clause_of_exported_interface_0_has_or_is_using_private_name_1_4022", "'extends' clause of exported interface '{0}' has or is using private name '{1}'."),
-        Exported_variable_0_has_or_is_using_name_1_from_external_module_2_but_cannot_be_named: diag(4023, 1 /* Error */, "Exported_variable_0_has_or_is_using_name_1_from_external_module_2_but_cannot_be_named_4023", "Exported variable '{0}' has or is using name '{1}' from external module {2} but cannot be named."),
-        Exported_variable_0_has_or_is_using_name_1_from_private_module_2: diag(4024, 1 /* Error */, "Exported_variable_0_has_or_is_using_name_1_from_private_module_2_4024", "Exported variable '{0}' has or is using name '{1}' from private module '{2}'."),
-        Exported_variable_0_has_or_is_using_private_name_1: diag(4025, 1 /* Error */, "Exported_variable_0_has_or_is_using_private_name_1_4025", "Exported variable '{0}' has or is using private name '{1}'."),
-        Public_static_property_0_of_exported_class_has_or_is_using_name_1_from_external_module_2_but_cannot_be_named: diag(4026, 1 /* Error */, "Public_static_property_0_of_exported_class_has_or_is_using_name_1_from_external_module_2_but_cannot__4026", "Public static property '{0}' of exported class has or is using name '{1}' from external module {2} but cannot be named."),
-        Public_static_property_0_of_exported_class_has_or_is_using_name_1_from_private_module_2: diag(4027, 1 /* Error */, "Public_static_property_0_of_exported_class_has_or_is_using_name_1_from_private_module_2_4027", "Public static property '{0}' of exported class has or is using name '{1}' from private module '{2}'."),
-        Public_static_property_0_of_exported_class_has_or_is_using_private_name_1: diag(4028, 1 /* Error */, "Public_static_property_0_of_exported_class_has_or_is_using_private_name_1_4028", "Public static property '{0}' of exported class has or is using private name '{1}'."),
-        Public_property_0_of_exported_class_has_or_is_using_name_1_from_external_module_2_but_cannot_be_named: diag(4029, 1 /* Error */, "Public_property_0_of_exported_class_has_or_is_using_name_1_from_external_module_2_but_cannot_be_name_4029", "Public property '{0}' of exported class has or is using name '{1}' from external module {2} but cannot be named."),
-        Public_property_0_of_exported_class_has_or_is_using_name_1_from_private_module_2: diag(4030, 1 /* Error */, "Public_property_0_of_exported_class_has_or_is_using_name_1_from_private_module_2_4030", "Public property '{0}' of exported class has or is using name '{1}' from private module '{2}'."),
-        Public_property_0_of_exported_class_has_or_is_using_private_name_1: diag(4031, 1 /* Error */, "Public_property_0_of_exported_class_has_or_is_using_private_name_1_4031", "Public property '{0}' of exported class has or is using private name '{1}'."),
-        Property_0_of_exported_interface_has_or_is_using_name_1_from_private_module_2: diag(4032, 1 /* Error */, "Property_0_of_exported_interface_has_or_is_using_name_1_from_private_module_2_4032", "Property '{0}' of exported interface has or is using name '{1}' from private module '{2}'."),
-        Property_0_of_exported_interface_has_or_is_using_private_name_1: diag(4033, 1 /* Error */, "Property_0_of_exported_interface_has_or_is_using_private_name_1_4033", "Property '{0}' of exported interface has or is using private name '{1}'."),
-        Parameter_type_of_public_static_setter_0_from_exported_class_has_or_is_using_name_1_from_private_module_2: diag(4034, 1 /* Error */, "Parameter_type_of_public_static_setter_0_from_exported_class_has_or_is_using_name_1_from_private_mod_4034", "Parameter type of public static setter '{0}' from exported class has or is using name '{1}' from private module '{2}'."),
-        Parameter_type_of_public_static_setter_0_from_exported_class_has_or_is_using_private_name_1: diag(4035, 1 /* Error */, "Parameter_type_of_public_static_setter_0_from_exported_class_has_or_is_using_private_name_1_4035", "Parameter type of public static setter '{0}' from exported class has or is using private name '{1}'."),
-        Parameter_type_of_public_setter_0_from_exported_class_has_or_is_using_name_1_from_private_module_2: diag(4036, 1 /* Error */, "Parameter_type_of_public_setter_0_from_exported_class_has_or_is_using_name_1_from_private_module_2_4036", "Parameter type of public setter '{0}' from exported class has or is using name '{1}' from private module '{2}'."),
-        Parameter_type_of_public_setter_0_from_exported_class_has_or_is_using_private_name_1: diag(4037, 1 /* Error */, "Parameter_type_of_public_setter_0_from_exported_class_has_or_is_using_private_name_1_4037", "Parameter type of public setter '{0}' from exported class has or is using private name '{1}'."),
-        Return_type_of_public_static_getter_0_from_exported_class_has_or_is_using_name_1_from_external_module_2_but_cannot_be_named: diag(4038, 1 /* Error */, "Return_type_of_public_static_getter_0_from_exported_class_has_or_is_using_name_1_from_external_modul_4038", "Return type of public static getter '{0}' from exported class has or is using name '{1}' from external module {2} but cannot be named."),
-        Return_type_of_public_static_getter_0_from_exported_class_has_or_is_using_name_1_from_private_module_2: diag(4039, 1 /* Error */, "Return_type_of_public_static_getter_0_from_exported_class_has_or_is_using_name_1_from_private_module_4039", "Return type of public static getter '{0}' from exported class has or is using name '{1}' from private module '{2}'."),
-        Return_type_of_public_static_getter_0_from_exported_class_has_or_is_using_private_name_1: diag(4040, 1 /* Error */, "Return_type_of_public_static_getter_0_from_exported_class_has_or_is_using_private_name_1_4040", "Return type of public static getter '{0}' from exported class has or is using private name '{1}'."),
-        Return_type_of_public_getter_0_from_exported_class_has_or_is_using_name_1_from_external_module_2_but_cannot_be_named: diag(4041, 1 /* Error */, "Return_type_of_public_getter_0_from_exported_class_has_or_is_using_name_1_from_external_module_2_but_4041", "Return type of public getter '{0}' from exported class has or is using name '{1}' from external module {2} but cannot be named."),
-        Return_type_of_public_getter_0_from_exported_class_has_or_is_using_name_1_from_private_module_2: diag(4042, 1 /* Error */, "Return_type_of_public_getter_0_from_exported_class_has_or_is_using_name_1_from_private_module_2_4042", "Return type of public getter '{0}' from exported class has or is using name '{1}' from private module '{2}'."),
-        Return_type_of_public_getter_0_from_exported_class_has_or_is_using_private_name_1: diag(4043, 1 /* Error */, "Return_type_of_public_getter_0_from_exported_class_has_or_is_using_private_name_1_4043", "Return type of public getter '{0}' from exported class has or is using private name '{1}'."),
-        Return_type_of_constructor_signature_from_exported_interface_has_or_is_using_name_0_from_private_module_1: diag(4044, 1 /* Error */, "Return_type_of_constructor_signature_from_exported_interface_has_or_is_using_name_0_from_private_mod_4044", "Return type of constructor signature from exported interface has or is using name '{0}' from private module '{1}'."),
-        Return_type_of_constructor_signature_from_exported_interface_has_or_is_using_private_name_0: diag(4045, 1 /* Error */, "Return_type_of_constructor_signature_from_exported_interface_has_or_is_using_private_name_0_4045", "Return type of constructor signature from exported interface has or is using private name '{0}'."),
-        Return_type_of_call_signature_from_exported_interface_has_or_is_using_name_0_from_private_module_1: diag(4046, 1 /* Error */, "Return_type_of_call_signature_from_exported_interface_has_or_is_using_name_0_from_private_module_1_4046", "Return type of call signature from exported interface has or is using name '{0}' from private module '{1}'."),
-        Return_type_of_call_signature_from_exported_interface_has_or_is_using_private_name_0: diag(4047, 1 /* Error */, "Return_type_of_call_signature_from_exported_interface_has_or_is_using_private_name_0_4047", "Return type of call signature from exported interface has or is using private name '{0}'."),
-        Return_type_of_index_signature_from_exported_interface_has_or_is_using_name_0_from_private_module_1: diag(4048, 1 /* Error */, "Return_type_of_index_signature_from_exported_interface_has_or_is_using_name_0_from_private_module_1_4048", "Return type of index signature from exported interface has or is using name '{0}' from private module '{1}'."),
-        Return_type_of_index_signature_from_exported_interface_has_or_is_using_private_name_0: diag(4049, 1 /* Error */, "Return_type_of_index_signature_from_exported_interface_has_or_is_using_private_name_0_4049", "Return type of index signature from exported interface has or is using private name '{0}'."),
-        Return_type_of_public_static_method_from_exported_class_has_or_is_using_name_0_from_external_module_1_but_cannot_be_named: diag(4050, 1 /* Error */, "Return_type_of_public_static_method_from_exported_class_has_or_is_using_name_0_from_external_module__4050", "Return type of public static method from exported class has or is using name '{0}' from external module {1} but cannot be named."),
-        Return_type_of_public_static_method_from_exported_class_has_or_is_using_name_0_from_private_module_1: diag(4051, 1 /* Error */, "Return_type_of_public_static_method_from_exported_class_has_or_is_using_name_0_from_private_module_1_4051", "Return type of public static method from exported class has or is using name '{0}' from private module '{1}'."),
-        Return_type_of_public_static_method_from_exported_class_has_or_is_using_private_name_0: diag(4052, 1 /* Error */, "Return_type_of_public_static_method_from_exported_class_has_or_is_using_private_name_0_4052", "Return type of public static method from exported class has or is using private name '{0}'."),
-        Return_type_of_public_method_from_exported_class_has_or_is_using_name_0_from_external_module_1_but_cannot_be_named: diag(4053, 1 /* Error */, "Return_type_of_public_method_from_exported_class_has_or_is_using_name_0_from_external_module_1_but_c_4053", "Return type of public method from exported class has or is using name '{0}' from external module {1} but cannot be named."),
-        Return_type_of_public_method_from_exported_class_has_or_is_using_name_0_from_private_module_1: diag(4054, 1 /* Error */, "Return_type_of_public_method_from_exported_class_has_or_is_using_name_0_from_private_module_1_4054", "Return type of public method from exported class has or is using name '{0}' from private module '{1}'."),
-        Return_type_of_public_method_from_exported_class_has_or_is_using_private_name_0: diag(4055, 1 /* Error */, "Return_type_of_public_method_from_exported_class_has_or_is_using_private_name_0_4055", "Return type of public method from exported class has or is using private name '{0}'."),
-        Return_type_of_method_from_exported_interface_has_or_is_using_name_0_from_private_module_1: diag(4056, 1 /* Error */, "Return_type_of_method_from_exported_interface_has_or_is_using_name_0_from_private_module_1_4056", "Return type of method from exported interface has or is using name '{0}' from private module '{1}'."),
-        Return_type_of_method_from_exported_interface_has_or_is_using_private_name_0: diag(4057, 1 /* Error */, "Return_type_of_method_from_exported_interface_has_or_is_using_private_name_0_4057", "Return type of method from exported interface has or is using private name '{0}'."),
-        Return_type_of_exported_function_has_or_is_using_name_0_from_external_module_1_but_cannot_be_named: diag(4058, 1 /* Error */, "Return_type_of_exported_function_has_or_is_using_name_0_from_external_module_1_but_cannot_be_named_4058", "Return type of exported function has or is using name '{0}' from external module {1} but cannot be named."),
-        Return_type_of_exported_function_has_or_is_using_name_0_from_private_module_1: diag(4059, 1 /* Error */, "Return_type_of_exported_function_has_or_is_using_name_0_from_private_module_1_4059", "Return type of exported function has or is using name '{0}' from private module '{1}'."),
-        Return_type_of_exported_function_has_or_is_using_private_name_0: diag(4060, 1 /* Error */, "Return_type_of_exported_function_has_or_is_using_private_name_0_4060", "Return type of exported function has or is using private name '{0}'."),
-        Parameter_0_of_constructor_from_exported_class_has_or_is_using_name_1_from_external_module_2_but_cannot_be_named: diag(4061, 1 /* Error */, "Parameter_0_of_constructor_from_exported_class_has_or_is_using_name_1_from_external_module_2_but_can_4061", "Parameter '{0}' of constructor from exported class has or is using name '{1}' from external module {2} but cannot be named."),
-        Parameter_0_of_constructor_from_exported_class_has_or_is_using_name_1_from_private_module_2: diag(4062, 1 /* Error */, "Parameter_0_of_constructor_from_exported_class_has_or_is_using_name_1_from_private_module_2_4062", "Parameter '{0}' of constructor from exported class has or is using name '{1}' from private module '{2}'."),
-        Parameter_0_of_constructor_from_exported_class_has_or_is_using_private_name_1: diag(4063, 1 /* Error */, "Parameter_0_of_constructor_from_exported_class_has_or_is_using_private_name_1_4063", "Parameter '{0}' of constructor from exported class has or is using private name '{1}'."),
-        Parameter_0_of_constructor_signature_from_exported_interface_has_or_is_using_name_1_from_private_module_2: diag(4064, 1 /* Error */, "Parameter_0_of_constructor_signature_from_exported_interface_has_or_is_using_name_1_from_private_mod_4064", "Parameter '{0}' of constructor signature from exported interface has or is using name '{1}' from private module '{2}'."),
-        Parameter_0_of_constructor_signature_from_exported_interface_has_or_is_using_private_name_1: diag(4065, 1 /* Error */, "Parameter_0_of_constructor_signature_from_exported_interface_has_or_is_using_private_name_1_4065", "Parameter '{0}' of constructor signature from exported interface has or is using private name '{1}'."),
-        Parameter_0_of_call_signature_from_exported_interface_has_or_is_using_name_1_from_private_module_2: diag(4066, 1 /* Error */, "Parameter_0_of_call_signature_from_exported_interface_has_or_is_using_name_1_from_private_module_2_4066", "Parameter '{0}' of call signature from exported interface has or is using name '{1}' from private module '{2}'."),
-        Parameter_0_of_call_signature_from_exported_interface_has_or_is_using_private_name_1: diag(4067, 1 /* Error */, "Parameter_0_of_call_signature_from_exported_interface_has_or_is_using_private_name_1_4067", "Parameter '{0}' of call signature from exported interface has or is using private name '{1}'."),
-        Parameter_0_of_public_static_method_from_exported_class_has_or_is_using_name_1_from_external_module_2_but_cannot_be_named: diag(4068, 1 /* Error */, "Parameter_0_of_public_static_method_from_exported_class_has_or_is_using_name_1_from_external_module__4068", "Parameter '{0}' of public static method from exported class has or is using name '{1}' from external module {2} but cannot be named."),
-        Parameter_0_of_public_static_method_from_exported_class_has_or_is_using_name_1_from_private_module_2: diag(4069, 1 /* Error */, "Parameter_0_of_public_static_method_from_exported_class_has_or_is_using_name_1_from_private_module_2_4069", "Parameter '{0}' of public static method from exported class has or is using name '{1}' from private module '{2}'."),
-        Parameter_0_of_public_static_method_from_exported_class_has_or_is_using_private_name_1: diag(4070, 1 /* Error */, "Parameter_0_of_public_static_method_from_exported_class_has_or_is_using_private_name_1_4070", "Parameter '{0}' of public static method from exported class has or is using private name '{1}'."),
-        Parameter_0_of_public_method_from_exported_class_has_or_is_using_name_1_from_external_module_2_but_cannot_be_named: diag(4071, 1 /* Error */, "Parameter_0_of_public_method_from_exported_class_has_or_is_using_name_1_from_external_module_2_but_c_4071", "Parameter '{0}' of public method from exported class has or is using name '{1}' from external module {2} but cannot be named."),
-        Parameter_0_of_public_method_from_exported_class_has_or_is_using_name_1_from_private_module_2: diag(4072, 1 /* Error */, "Parameter_0_of_public_method_from_exported_class_has_or_is_using_name_1_from_private_module_2_4072", "Parameter '{0}' of public method from exported class has or is using name '{1}' from private module '{2}'."),
-        Parameter_0_of_public_method_from_exported_class_has_or_is_using_private_name_1: diag(4073, 1 /* Error */, "Parameter_0_of_public_method_from_exported_class_has_or_is_using_private_name_1_4073", "Parameter '{0}' of public method from exported class has or is using private name '{1}'."),
-        Parameter_0_of_method_from_exported_interface_has_or_is_using_name_1_from_private_module_2: diag(4074, 1 /* Error */, "Parameter_0_of_method_from_exported_interface_has_or_is_using_name_1_from_private_module_2_4074", "Parameter '{0}' of method from exported interface has or is using name '{1}' from private module '{2}'."),
-        Parameter_0_of_method_from_exported_interface_has_or_is_using_private_name_1: diag(4075, 1 /* Error */, "Parameter_0_of_method_from_exported_interface_has_or_is_using_private_name_1_4075", "Parameter '{0}' of method from exported interface has or is using private name '{1}'."),
-        Parameter_0_of_exported_function_has_or_is_using_name_1_from_external_module_2_but_cannot_be_named: diag(4076, 1 /* Error */, "Parameter_0_of_exported_function_has_or_is_using_name_1_from_external_module_2_but_cannot_be_named_4076", "Parameter '{0}' of exported function has or is using name '{1}' from external module {2} but cannot be named."),
-        Parameter_0_of_exported_function_has_or_is_using_name_1_from_private_module_2: diag(4077, 1 /* Error */, "Parameter_0_of_exported_function_has_or_is_using_name_1_from_private_module_2_4077", "Parameter '{0}' of exported function has or is using name '{1}' from private module '{2}'."),
-        Parameter_0_of_exported_function_has_or_is_using_private_name_1: diag(4078, 1 /* Error */, "Parameter_0_of_exported_function_has_or_is_using_private_name_1_4078", "Parameter '{0}' of exported function has or is using private name '{1}'."),
-        Exported_type_alias_0_has_or_is_using_private_name_1: diag(4081, 1 /* Error */, "Exported_type_alias_0_has_or_is_using_private_name_1_4081", "Exported type alias '{0}' has or is using private name '{1}'."),
-        Default_export_of_the_module_has_or_is_using_private_name_0: diag(4082, 1 /* Error */, "Default_export_of_the_module_has_or_is_using_private_name_0_4082", "Default export of the module has or is using private name '{0}'."),
-        Type_parameter_0_of_exported_type_alias_has_or_is_using_private_name_1: diag(4083, 1 /* Error */, "Type_parameter_0_of_exported_type_alias_has_or_is_using_private_name_1_4083", "Type parameter '{0}' of exported type alias has or is using private name '{1}'."),
-        Exported_type_alias_0_has_or_is_using_private_name_1_from_module_2: diag(4084, 1 /* Error */, "Exported_type_alias_0_has_or_is_using_private_name_1_from_module_2_4084", "Exported type alias '{0}' has or is using private name '{1}' from module {2}."),
-        Extends_clause_for_inferred_type_0_has_or_is_using_private_name_1: diag(4085, 1 /* Error */, "Extends_clause_for_inferred_type_0_has_or_is_using_private_name_1_4085", "Extends clause for inferred type '{0}' has or is using private name '{1}'."),
-        Conflicting_definitions_for_0_found_at_1_and_2_Consider_installing_a_specific_version_of_this_library_to_resolve_the_conflict: diag(4090, 1 /* Error */, "Conflicting_definitions_for_0_found_at_1_and_2_Consider_installing_a_specific_version_of_this_librar_4090", "Conflicting definitions for '{0}' found at '{1}' and '{2}'. Consider installing a specific version of this library to resolve the conflict."),
-        Parameter_0_of_index_signature_from_exported_interface_has_or_is_using_name_1_from_private_module_2: diag(4091, 1 /* Error */, "Parameter_0_of_index_signature_from_exported_interface_has_or_is_using_name_1_from_private_module_2_4091", "Parameter '{0}' of index signature from exported interface has or is using name '{1}' from private module '{2}'."),
-        Parameter_0_of_index_signature_from_exported_interface_has_or_is_using_private_name_1: diag(4092, 1 /* Error */, "Parameter_0_of_index_signature_from_exported_interface_has_or_is_using_private_name_1_4092", "Parameter '{0}' of index signature from exported interface has or is using private name '{1}'."),
-        Property_0_of_exported_class_expression_may_not_be_private_or_protected: diag(4094, 1 /* Error */, "Property_0_of_exported_class_expression_may_not_be_private_or_protected_4094", "Property '{0}' of exported class expression may not be private or protected."),
-        Public_static_method_0_of_exported_class_has_or_is_using_name_1_from_external_module_2_but_cannot_be_named: diag(4095, 1 /* Error */, "Public_static_method_0_of_exported_class_has_or_is_using_name_1_from_external_module_2_but_cannot_be_4095", "Public static method '{0}' of exported class has or is using name '{1}' from external module {2} but cannot be named."),
-        Public_static_method_0_of_exported_class_has_or_is_using_name_1_from_private_module_2: diag(4096, 1 /* Error */, "Public_static_method_0_of_exported_class_has_or_is_using_name_1_from_private_module_2_4096", "Public static method '{0}' of exported class has or is using name '{1}' from private module '{2}'."),
-        Public_static_method_0_of_exported_class_has_or_is_using_private_name_1: diag(4097, 1 /* Error */, "Public_static_method_0_of_exported_class_has_or_is_using_private_name_1_4097", "Public static method '{0}' of exported class has or is using private name '{1}'."),
-        Public_method_0_of_exported_class_has_or_is_using_name_1_from_external_module_2_but_cannot_be_named: diag(4098, 1 /* Error */, "Public_method_0_of_exported_class_has_or_is_using_name_1_from_external_module_2_but_cannot_be_named_4098", "Public method '{0}' of exported class has or is using name '{1}' from external module {2} but cannot be named."),
-        Public_method_0_of_exported_class_has_or_is_using_name_1_from_private_module_2: diag(4099, 1 /* Error */, "Public_method_0_of_exported_class_has_or_is_using_name_1_from_private_module_2_4099", "Public method '{0}' of exported class has or is using name '{1}' from private module '{2}'."),
-        Public_method_0_of_exported_class_has_or_is_using_private_name_1: diag(4100, 1 /* Error */, "Public_method_0_of_exported_class_has_or_is_using_private_name_1_4100", "Public method '{0}' of exported class has or is using private name '{1}'."),
-        Method_0_of_exported_interface_has_or_is_using_name_1_from_private_module_2: diag(4101, 1 /* Error */, "Method_0_of_exported_interface_has_or_is_using_name_1_from_private_module_2_4101", "Method '{0}' of exported interface has or is using name '{1}' from private module '{2}'."),
-        Method_0_of_exported_interface_has_or_is_using_private_name_1: diag(4102, 1 /* Error */, "Method_0_of_exported_interface_has_or_is_using_private_name_1_4102", "Method '{0}' of exported interface has or is using private name '{1}'."),
-        Type_parameter_0_of_exported_mapped_object_type_is_using_private_name_1: diag(4103, 1 /* Error */, "Type_parameter_0_of_exported_mapped_object_type_is_using_private_name_1_4103", "Type parameter '{0}' of exported mapped object type is using private name '{1}'."),
-        The_type_0_is_readonly_and_cannot_be_assigned_to_the_mutable_type_1: diag(4104, 1 /* Error */, "The_type_0_is_readonly_and_cannot_be_assigned_to_the_mutable_type_1_4104", "The type '{0}' is 'readonly' and cannot be assigned to the mutable type '{1}'."),
-        Private_or_protected_member_0_cannot_be_accessed_on_a_type_parameter: diag(4105, 1 /* Error */, "Private_or_protected_member_0_cannot_be_accessed_on_a_type_parameter_4105", "Private or protected member '{0}' cannot be accessed on a type parameter."),
-        Parameter_0_of_accessor_has_or_is_using_private_name_1: diag(4106, 1 /* Error */, "Parameter_0_of_accessor_has_or_is_using_private_name_1_4106", "Parameter '{0}' of accessor has or is using private name '{1}'."),
-        Parameter_0_of_accessor_has_or_is_using_name_1_from_private_module_2: diag(4107, 1 /* Error */, "Parameter_0_of_accessor_has_or_is_using_name_1_from_private_module_2_4107", "Parameter '{0}' of accessor has or is using name '{1}' from private module '{2}'."),
-        Parameter_0_of_accessor_has_or_is_using_name_1_from_external_module_2_but_cannot_be_named: diag(4108, 1 /* Error */, "Parameter_0_of_accessor_has_or_is_using_name_1_from_external_module_2_but_cannot_be_named_4108", "Parameter '{0}' of accessor has or is using name '{1}' from external module '{2}' but cannot be named."),
-        Type_arguments_for_0_circularly_reference_themselves: diag(4109, 1 /* Error */, "Type_arguments_for_0_circularly_reference_themselves_4109", "Type arguments for '{0}' circularly reference themselves."),
-        Tuple_type_arguments_circularly_reference_themselves: diag(4110, 1 /* Error */, "Tuple_type_arguments_circularly_reference_themselves_4110", "Tuple type arguments circularly reference themselves."),
-        Property_0_comes_from_an_index_signature_so_it_must_be_accessed_with_0: diag(4111, 1 /* Error */, "Property_0_comes_from_an_index_signature_so_it_must_be_accessed_with_0_4111", "Property '{0}' comes from an index signature, so it must be accessed with ['{0}']."),
-        This_member_cannot_have_an_override_modifier_because_its_containing_class_0_does_not_extend_another_class: diag(4112, 1 /* Error */, "This_member_cannot_have_an_override_modifier_because_its_containing_class_0_does_not_extend_another__4112", "This member cannot have an 'override' modifier because its containing class '{0}' does not extend another class."),
-        This_member_cannot_have_an_override_modifier_because_it_is_not_declared_in_the_base_class_0: diag(4113, 1 /* Error */, "This_member_cannot_have_an_override_modifier_because_it_is_not_declared_in_the_base_class_0_4113", "This member cannot have an 'override' modifier because it is not declared in the base class '{0}'."),
-        This_member_must_have_an_override_modifier_because_it_overrides_a_member_in_the_base_class_0: diag(4114, 1 /* Error */, "This_member_must_have_an_override_modifier_because_it_overrides_a_member_in_the_base_class_0_4114", "This member must have an 'override' modifier because it overrides a member in the base class '{0}'."),
-        This_parameter_property_must_have_an_override_modifier_because_it_overrides_a_member_in_base_class_0: diag(4115, 1 /* Error */, "This_parameter_property_must_have_an_override_modifier_because_it_overrides_a_member_in_base_class_0_4115", "This parameter property must have an 'override' modifier because it overrides a member in base class '{0}'."),
-        This_member_must_have_an_override_modifier_because_it_overrides_an_abstract_method_that_is_declared_in_the_base_class_0: diag(4116, 1 /* Error */, "This_member_must_have_an_override_modifier_because_it_overrides_an_abstract_method_that_is_declared__4116", "This member must have an 'override' modifier because it overrides an abstract method that is declared in the base class '{0}'."),
-        This_member_cannot_have_an_override_modifier_because_it_is_not_declared_in_the_base_class_0_Did_you_mean_1: diag(4117, 1 /* Error */, "This_member_cannot_have_an_override_modifier_because_it_is_not_declared_in_the_base_class_0_Did_you__4117", "This member cannot have an 'override' modifier because it is not declared in the base class '{0}'. Did you mean '{1}'?"),
-        The_type_of_this_node_cannot_be_serialized_because_its_property_0_cannot_be_serialized: diag(4118, 1 /* Error */, "The_type_of_this_node_cannot_be_serialized_because_its_property_0_cannot_be_serialized_4118", "The type of this node cannot be serialized because its property '{0}' cannot be serialized."),
-        This_member_must_have_a_JSDoc_comment_with_an_override_tag_because_it_overrides_a_member_in_the_base_class_0: diag(4119, 1 /* Error */, "This_member_must_have_a_JSDoc_comment_with_an_override_tag_because_it_overrides_a_member_in_the_base_4119", "This member must have a JSDoc comment with an '@override' tag because it overrides a member in the base class '{0}'."),
-        This_parameter_property_must_have_a_JSDoc_comment_with_an_override_tag_because_it_overrides_a_member_in_the_base_class_0: diag(4120, 1 /* Error */, "This_parameter_property_must_have_a_JSDoc_comment_with_an_override_tag_because_it_overrides_a_member_4120", "This parameter property must have a JSDoc comment with an '@override' tag because it overrides a member in the base class '{0}'."),
-        This_member_cannot_have_a_JSDoc_comment_with_an_override_tag_because_its_containing_class_0_does_not_extend_another_class: diag(4121, 1 /* Error */, "This_member_cannot_have_a_JSDoc_comment_with_an_override_tag_because_its_containing_class_0_does_not_4121", "This member cannot have a JSDoc comment with an '@override' tag because its containing class '{0}' does not extend another class."),
-        This_member_cannot_have_a_JSDoc_comment_with_an_override_tag_because_it_is_not_declared_in_the_base_class_0: diag(4122, 1 /* Error */, "This_member_cannot_have_a_JSDoc_comment_with_an_override_tag_because_it_is_not_declared_in_the_base__4122", "This member cannot have a JSDoc comment with an '@override' tag because it is not declared in the base class '{0}'."),
-        This_member_cannot_have_a_JSDoc_comment_with_an_override_tag_because_it_is_not_declared_in_the_base_class_0_Did_you_mean_1: diag(4123, 1 /* Error */, "This_member_cannot_have_a_JSDoc_comment_with_an_override_tag_because_it_is_not_declared_in_the_base__4123", "This member cannot have a JSDoc comment with an 'override' tag because it is not declared in the base class '{0}'. Did you mean '{1}'?"),
-        Compiler_option_0_of_value_1_is_unstable_Use_nightly_TypeScript_to_silence_this_error_Try_updating_with_npm_install_D_typescript_next: diag(4124, 1 /* Error */, "Compiler_option_0_of_value_1_is_unstable_Use_nightly_TypeScript_to_silence_this_error_Try_updating_w_4124", "Compiler option '{0}' of value '{1}' is unstable. Use nightly TypeScript to silence this error. Try updating with 'npm install -D typescript@next'."),
-        resolution_mode_assertions_are_unstable_Use_nightly_TypeScript_to_silence_this_error_Try_updating_with_npm_install_D_typescript_next: diag(4125, 1 /* Error */, "resolution_mode_assertions_are_unstable_Use_nightly_TypeScript_to_silence_this_error_Try_updating_wi_4125", "'resolution-mode' assertions are unstable. Use nightly TypeScript to silence this error. Try updating with 'npm install -D typescript@next'."),
-        The_current_host_does_not_support_the_0_option: diag(5001, 1 /* Error */, "The_current_host_does_not_support_the_0_option_5001", "The current host does not support the '{0}' option."),
-        Cannot_find_the_common_subdirectory_path_for_the_input_files: diag(5009, 1 /* Error */, "Cannot_find_the_common_subdirectory_path_for_the_input_files_5009", "Cannot find the common subdirectory path for the input files."),
-        File_specification_cannot_end_in_a_recursive_directory_wildcard_Asterisk_Asterisk_Colon_0: diag(5010, 1 /* Error */, "File_specification_cannot_end_in_a_recursive_directory_wildcard_Asterisk_Asterisk_Colon_0_5010", "File specification cannot end in a recursive directory wildcard ('**'): '{0}'."),
-        Cannot_read_file_0_Colon_1: diag(5012, 1 /* Error */, "Cannot_read_file_0_Colon_1_5012", "Cannot read file '{0}': {1}."),
-        Failed_to_parse_file_0_Colon_1: diag(5014, 1 /* Error */, "Failed_to_parse_file_0_Colon_1_5014", "Failed to parse file '{0}': {1}."),
-        Unknown_compiler_option_0: diag(5023, 1 /* Error */, "Unknown_compiler_option_0_5023", "Unknown compiler option '{0}'."),
-        Compiler_option_0_requires_a_value_of_type_1: diag(5024, 1 /* Error */, "Compiler_option_0_requires_a_value_of_type_1_5024", "Compiler option '{0}' requires a value of type {1}."),
-        Unknown_compiler_option_0_Did_you_mean_1: diag(5025, 1 /* Error */, "Unknown_compiler_option_0_Did_you_mean_1_5025", "Unknown compiler option '{0}'. Did you mean '{1}'?"),
-        Could_not_write_file_0_Colon_1: diag(5033, 1 /* Error */, "Could_not_write_file_0_Colon_1_5033", "Could not write file '{0}': {1}."),
-        Option_project_cannot_be_mixed_with_source_files_on_a_command_line: diag(5042, 1 /* Error */, "Option_project_cannot_be_mixed_with_source_files_on_a_command_line_5042", "Option 'project' cannot be mixed with source files on a command line."),
-        Option_isolatedModules_can_only_be_used_when_either_option_module_is_provided_or_option_target_is_ES2015_or_higher: diag(5047, 1 /* Error */, "Option_isolatedModules_can_only_be_used_when_either_option_module_is_provided_or_option_target_is_ES_5047", "Option 'isolatedModules' can only be used when either option '--module' is provided or option 'target' is 'ES2015' or higher."),
-        Option_0_cannot_be_specified_when_option_target_is_ES3: diag(5048, 1 /* Error */, "Option_0_cannot_be_specified_when_option_target_is_ES3_5048", "Option '{0}' cannot be specified when option 'target' is 'ES3'."),
-        Option_0_can_only_be_used_when_either_option_inlineSourceMap_or_option_sourceMap_is_provided: diag(5051, 1 /* Error */, "Option_0_can_only_be_used_when_either_option_inlineSourceMap_or_option_sourceMap_is_provided_5051", "Option '{0} can only be used when either option '--inlineSourceMap' or option '--sourceMap' is provided."),
-        Option_0_cannot_be_specified_without_specifying_option_1: diag(5052, 1 /* Error */, "Option_0_cannot_be_specified_without_specifying_option_1_5052", "Option '{0}' cannot be specified without specifying option '{1}'."),
-        Option_0_cannot_be_specified_with_option_1: diag(5053, 1 /* Error */, "Option_0_cannot_be_specified_with_option_1_5053", "Option '{0}' cannot be specified with option '{1}'."),
-        A_tsconfig_json_file_is_already_defined_at_Colon_0: diag(5054, 1 /* Error */, "A_tsconfig_json_file_is_already_defined_at_Colon_0_5054", "A 'tsconfig.json' file is already defined at: '{0}'."),
-        Cannot_write_file_0_because_it_would_overwrite_input_file: diag(5055, 1 /* Error */, "Cannot_write_file_0_because_it_would_overwrite_input_file_5055", "Cannot write file '{0}' because it would overwrite input file."),
-        Cannot_write_file_0_because_it_would_be_overwritten_by_multiple_input_files: diag(5056, 1 /* Error */, "Cannot_write_file_0_because_it_would_be_overwritten_by_multiple_input_files_5056", "Cannot write file '{0}' because it would be overwritten by multiple input files."),
-        Cannot_find_a_tsconfig_json_file_at_the_specified_directory_Colon_0: diag(5057, 1 /* Error */, "Cannot_find_a_tsconfig_json_file_at_the_specified_directory_Colon_0_5057", "Cannot find a tsconfig.json file at the specified directory: '{0}'."),
-        The_specified_path_does_not_exist_Colon_0: diag(5058, 1 /* Error */, "The_specified_path_does_not_exist_Colon_0_5058", "The specified path does not exist: '{0}'."),
-        Invalid_value_for_reactNamespace_0_is_not_a_valid_identifier: diag(5059, 1 /* Error */, "Invalid_value_for_reactNamespace_0_is_not_a_valid_identifier_5059", "Invalid value for '--reactNamespace'. '{0}' is not a valid identifier."),
-        Pattern_0_can_have_at_most_one_Asterisk_character: diag(5061, 1 /* Error */, "Pattern_0_can_have_at_most_one_Asterisk_character_5061", "Pattern '{0}' can have at most one '*' character."),
-        Substitution_0_in_pattern_1_can_have_at_most_one_Asterisk_character: diag(5062, 1 /* Error */, "Substitution_0_in_pattern_1_can_have_at_most_one_Asterisk_character_5062", "Substitution '{0}' in pattern '{1}' can have at most one '*' character."),
-        Substitutions_for_pattern_0_should_be_an_array: diag(5063, 1 /* Error */, "Substitutions_for_pattern_0_should_be_an_array_5063", "Substitutions for pattern '{0}' should be an array."),
-        Substitution_0_for_pattern_1_has_incorrect_type_expected_string_got_2: diag(5064, 1 /* Error */, "Substitution_0_for_pattern_1_has_incorrect_type_expected_string_got_2_5064", "Substitution '{0}' for pattern '{1}' has incorrect type, expected 'string', got '{2}'."),
-        File_specification_cannot_contain_a_parent_directory_that_appears_after_a_recursive_directory_wildcard_Asterisk_Asterisk_Colon_0: diag(5065, 1 /* Error */, "File_specification_cannot_contain_a_parent_directory_that_appears_after_a_recursive_directory_wildca_5065", "File specification cannot contain a parent directory ('..') that appears after a recursive directory wildcard ('**'): '{0}'."),
-        Substitutions_for_pattern_0_shouldn_t_be_an_empty_array: diag(5066, 1 /* Error */, "Substitutions_for_pattern_0_shouldn_t_be_an_empty_array_5066", "Substitutions for pattern '{0}' shouldn't be an empty array."),
-        Invalid_value_for_jsxFactory_0_is_not_a_valid_identifier_or_qualified_name: diag(5067, 1 /* Error */, "Invalid_value_for_jsxFactory_0_is_not_a_valid_identifier_or_qualified_name_5067", "Invalid value for 'jsxFactory'. '{0}' is not a valid identifier or qualified-name."),
-        Adding_a_tsconfig_json_file_will_help_organize_projects_that_contain_both_TypeScript_and_JavaScript_files_Learn_more_at_https_Colon_Slash_Slashaka_ms_Slashtsconfig: diag(5068, 1 /* Error */, "Adding_a_tsconfig_json_file_will_help_organize_projects_that_contain_both_TypeScript_and_JavaScript__5068", "Adding a tsconfig.json file will help organize projects that contain both TypeScript and JavaScript files. Learn more at https://aka.ms/tsconfig."),
-        Option_0_cannot_be_specified_without_specifying_option_1_or_option_2: diag(5069, 1 /* Error */, "Option_0_cannot_be_specified_without_specifying_option_1_or_option_2_5069", "Option '{0}' cannot be specified without specifying option '{1}' or option '{2}'."),
-        Option_resolveJsonModule_cannot_be_specified_when_moduleResolution_is_set_to_classic: diag(5070, 1 /* Error */, "Option_resolveJsonModule_cannot_be_specified_when_moduleResolution_is_set_to_classic_5070", "Option '--resolveJsonModule' cannot be specified when 'moduleResolution' is set to 'classic'."),
-        Option_resolveJsonModule_can_only_be_specified_when_module_code_generation_is_commonjs_amd_es2015_or_esNext: diag(5071, 1 /* Error */, "Option_resolveJsonModule_can_only_be_specified_when_module_code_generation_is_commonjs_amd_es2015_or_5071", "Option '--resolveJsonModule' can only be specified when module code generation is 'commonjs', 'amd', 'es2015' or 'esNext'."),
-        Unknown_build_option_0: diag(5072, 1 /* Error */, "Unknown_build_option_0_5072", "Unknown build option '{0}'."),
-        Build_option_0_requires_a_value_of_type_1: diag(5073, 1 /* Error */, "Build_option_0_requires_a_value_of_type_1_5073", "Build option '{0}' requires a value of type {1}."),
-        Option_incremental_can_only_be_specified_using_tsconfig_emitting_to_single_file_or_when_option_tsBuildInfoFile_is_specified: diag(5074, 1 /* Error */, "Option_incremental_can_only_be_specified_using_tsconfig_emitting_to_single_file_or_when_option_tsBui_5074", "Option '--incremental' can only be specified using tsconfig, emitting to single file or when option '--tsBuildInfoFile' is specified."),
-        _0_is_assignable_to_the_constraint_of_type_1_but_1_could_be_instantiated_with_a_different_subtype_of_constraint_2: diag(5075, 1 /* Error */, "_0_is_assignable_to_the_constraint_of_type_1_but_1_could_be_instantiated_with_a_different_subtype_of_5075", "'{0}' is assignable to the constraint of type '{1}', but '{1}' could be instantiated with a different subtype of constraint '{2}'."),
-        _0_and_1_operations_cannot_be_mixed_without_parentheses: diag(5076, 1 /* Error */, "_0_and_1_operations_cannot_be_mixed_without_parentheses_5076", "'{0}' and '{1}' operations cannot be mixed without parentheses."),
-        Unknown_build_option_0_Did_you_mean_1: diag(5077, 1 /* Error */, "Unknown_build_option_0_Did_you_mean_1_5077", "Unknown build option '{0}'. Did you mean '{1}'?"),
-        Unknown_watch_option_0: diag(5078, 1 /* Error */, "Unknown_watch_option_0_5078", "Unknown watch option '{0}'."),
-        Unknown_watch_option_0_Did_you_mean_1: diag(5079, 1 /* Error */, "Unknown_watch_option_0_Did_you_mean_1_5079", "Unknown watch option '{0}'. Did you mean '{1}'?"),
-        Watch_option_0_requires_a_value_of_type_1: diag(5080, 1 /* Error */, "Watch_option_0_requires_a_value_of_type_1_5080", "Watch option '{0}' requires a value of type {1}."),
-        Cannot_find_a_tsconfig_json_file_at_the_current_directory_Colon_0: diag(5081, 1 /* Error */, "Cannot_find_a_tsconfig_json_file_at_the_current_directory_Colon_0_5081", "Cannot find a tsconfig.json file at the current directory: {0}."),
-        _0_could_be_instantiated_with_an_arbitrary_type_which_could_be_unrelated_to_1: diag(5082, 1 /* Error */, "_0_could_be_instantiated_with_an_arbitrary_type_which_could_be_unrelated_to_1_5082", "'{0}' could be instantiated with an arbitrary type which could be unrelated to '{1}'."),
-        Cannot_read_file_0: diag(5083, 1 /* Error */, "Cannot_read_file_0_5083", "Cannot read file '{0}'."),
-        Tuple_members_must_all_have_names_or_all_not_have_names: diag(5084, 1 /* Error */, "Tuple_members_must_all_have_names_or_all_not_have_names_5084", "Tuple members must all have names or all not have names."),
-        A_tuple_member_cannot_be_both_optional_and_rest: diag(5085, 1 /* Error */, "A_tuple_member_cannot_be_both_optional_and_rest_5085", "A tuple member cannot be both optional and rest."),
-        A_labeled_tuple_element_is_declared_as_optional_with_a_question_mark_after_the_name_and_before_the_colon_rather_than_after_the_type: diag(5086, 1 /* Error */, "A_labeled_tuple_element_is_declared_as_optional_with_a_question_mark_after_the_name_and_before_the_c_5086", "A labeled tuple element is declared as optional with a question mark after the name and before the colon, rather than after the type."),
-        A_labeled_tuple_element_is_declared_as_rest_with_a_before_the_name_rather_than_before_the_type: diag(5087, 1 /* Error */, "A_labeled_tuple_element_is_declared_as_rest_with_a_before_the_name_rather_than_before_the_type_5087", "A labeled tuple element is declared as rest with a '...' before the name, rather than before the type."),
-        The_inferred_type_of_0_references_a_type_with_a_cyclic_structure_which_cannot_be_trivially_serialized_A_type_annotation_is_necessary: diag(5088, 1 /* Error */, "The_inferred_type_of_0_references_a_type_with_a_cyclic_structure_which_cannot_be_trivially_serialize_5088", "The inferred type of '{0}' references a type with a cyclic structure which cannot be trivially serialized. A type annotation is necessary."),
-        Option_0_cannot_be_specified_when_option_jsx_is_1: diag(5089, 1 /* Error */, "Option_0_cannot_be_specified_when_option_jsx_is_1_5089", "Option '{0}' cannot be specified when option 'jsx' is '{1}'."),
-        Non_relative_paths_are_not_allowed_when_baseUrl_is_not_set_Did_you_forget_a_leading_Slash: diag(5090, 1 /* Error */, "Non_relative_paths_are_not_allowed_when_baseUrl_is_not_set_Did_you_forget_a_leading_Slash_5090", "Non-relative paths are not allowed when 'baseUrl' is not set. Did you forget a leading './'?"),
-        Option_preserveConstEnums_cannot_be_disabled_when_0_is_enabled: diag(5091, 1 /* Error */, "Option_preserveConstEnums_cannot_be_disabled_when_0_is_enabled_5091", "Option 'preserveConstEnums' cannot be disabled when '{0}' is enabled."),
-        The_root_value_of_a_0_file_must_be_an_object: diag(5092, 1 /* Error */, "The_root_value_of_a_0_file_must_be_an_object_5092", "The root value of a '{0}' file must be an object."),
-        Compiler_option_0_may_only_be_used_with_build: diag(5093, 1 /* Error */, "Compiler_option_0_may_only_be_used_with_build_5093", "Compiler option '--{0}' may only be used with '--build'."),
-        Compiler_option_0_may_not_be_used_with_build: diag(5094, 1 /* Error */, "Compiler_option_0_may_not_be_used_with_build_5094", "Compiler option '--{0}' may not be used with '--build'."),
-        Option_0_can_only_be_used_when_module_is_set_to_es2015_or_later: diag(5095, 1 /* Error */, "Option_0_can_only_be_used_when_module_is_set_to_es2015_or_later_5095", "Option '{0}' can only be used when 'module' is set to 'es2015' or later."),
-        Option_allowImportingTsExtensions_can_only_be_used_when_either_noEmit_or_emitDeclarationOnly_is_set: diag(5096, 1 /* Error */, "Option_allowImportingTsExtensions_can_only_be_used_when_either_noEmit_or_emitDeclarationOnly_is_set_5096", "Option 'allowImportingTsExtensions' can only be used when either 'noEmit' or 'emitDeclarationOnly' is set."),
-        An_import_path_can_only_end_with_a_0_extension_when_allowImportingTsExtensions_is_enabled: diag(5097, 1 /* Error */, "An_import_path_can_only_end_with_a_0_extension_when_allowImportingTsExtensions_is_enabled_5097", "An import path can only end with a '{0}' extension when 'allowImportingTsExtensions' is enabled."),
-        Option_0_can_only_be_used_when_moduleResolution_is_set_to_node16_nodenext_or_bundler: diag(5098, 1 /* Error */, "Option_0_can_only_be_used_when_moduleResolution_is_set_to_node16_nodenext_or_bundler_5098", "Option '{0}' can only be used when 'moduleResolution' is set to 'node16', 'nodenext', or 'bundler'."),
-        Option_0_is_deprecated_and_will_stop_functioning_in_TypeScript_1_Specify_compilerOption_ignoreDeprecations_Colon_2_to_silence_this_error: diag(5101, 1 /* Error */, "Option_0_is_deprecated_and_will_stop_functioning_in_TypeScript_1_Specify_compilerOption_ignoreDeprec_5101", `Option '{0}' is deprecated and will stop functioning in TypeScript {1}. Specify compilerOption '"ignoreDeprecations": "{2}"' to silence this error.`),
-        Option_0_has_been_removed_Please_remove_it_from_your_configuration: diag(5102, 1 /* Error */, "Option_0_has_been_removed_Please_remove_it_from_your_configuration_5102", "Option '{0}' has been removed. Please remove it from your configuration."),
-        Invalid_value_for_ignoreDeprecations: diag(5103, 1 /* Error */, "Invalid_value_for_ignoreDeprecations_5103", "Invalid value for '--ignoreDeprecations'."),
-        Option_0_is_redundant_and_cannot_be_specified_with_option_1: diag(5104, 1 /* Error */, "Option_0_is_redundant_and_cannot_be_specified_with_option_1_5104", "Option '{0}' is redundant and cannot be specified with option '{1}'."),
-        Option_verbatimModuleSyntax_cannot_be_used_when_module_is_set_to_UMD_AMD_or_System: diag(5105, 1 /* Error */, "Option_verbatimModuleSyntax_cannot_be_used_when_module_is_set_to_UMD_AMD_or_System_5105", "Option 'verbatimModuleSyntax' cannot be used when 'module' is set to 'UMD', 'AMD', or 'System'."),
-        Use_0_instead: diag(5106, 3 /* Message */, "Use_0_instead_5106", "Use '{0}' instead."),
-        Option_0_1_is_deprecated_and_will_stop_functioning_in_TypeScript_2_Specify_compilerOption_ignoreDeprecations_Colon_3_to_silence_this_error: diag(5107, 1 /* Error */, "Option_0_1_is_deprecated_and_will_stop_functioning_in_TypeScript_2_Specify_compilerOption_ignoreDepr_5107", `Option '{0}={1}' is deprecated and will stop functioning in TypeScript {2}. Specify compilerOption '"ignoreDeprecations": "{3}"' to silence this error.`),
-        Option_0_1_has_been_removed_Please_remove_it_from_your_configuration: diag(5108, 1 /* Error */, "Option_0_1_has_been_removed_Please_remove_it_from_your_configuration_5108", "Option '{0}={1}' has been removed. Please remove it from your configuration."),
-        Generates_a_sourcemap_for_each_corresponding_d_ts_file: diag(6e3, 3 /* Message */, "Generates_a_sourcemap_for_each_corresponding_d_ts_file_6000", "Generates a sourcemap for each corresponding '.d.ts' file."),
-        Concatenate_and_emit_output_to_single_file: diag(6001, 3 /* Message */, "Concatenate_and_emit_output_to_single_file_6001", "Concatenate and emit output to single file."),
-        Generates_corresponding_d_ts_file: diag(6002, 3 /* Message */, "Generates_corresponding_d_ts_file_6002", "Generates corresponding '.d.ts' file."),
-        Specify_the_location_where_debugger_should_locate_TypeScript_files_instead_of_source_locations: diag(6004, 3 /* Message */, "Specify_the_location_where_debugger_should_locate_TypeScript_files_instead_of_source_locations_6004", "Specify the location where debugger should locate TypeScript files instead of source locations."),
-        Watch_input_files: diag(6005, 3 /* Message */, "Watch_input_files_6005", "Watch input files."),
-        Redirect_output_structure_to_the_directory: diag(6006, 3 /* Message */, "Redirect_output_structure_to_the_directory_6006", "Redirect output structure to the directory."),
-        Do_not_erase_const_enum_declarations_in_generated_code: diag(6007, 3 /* Message */, "Do_not_erase_const_enum_declarations_in_generated_code_6007", "Do not erase const enum declarations in generated code."),
-        Do_not_emit_outputs_if_any_errors_were_reported: diag(6008, 3 /* Message */, "Do_not_emit_outputs_if_any_errors_were_reported_6008", "Do not emit outputs if any errors were reported."),
-        Do_not_emit_comments_to_output: diag(6009, 3 /* Message */, "Do_not_emit_comments_to_output_6009", "Do not emit comments to output."),
-        Do_not_emit_outputs: diag(6010, 3 /* Message */, "Do_not_emit_outputs_6010", "Do not emit outputs."),
-        Allow_default_imports_from_modules_with_no_default_export_This_does_not_affect_code_emit_just_typechecking: diag(6011, 3 /* Message */, "Allow_default_imports_from_modules_with_no_default_export_This_does_not_affect_code_emit_just_typech_6011", "Allow default imports from modules with no default export. This does not affect code emit, just typechecking."),
-        Skip_type_checking_of_declaration_files: diag(6012, 3 /* Message */, "Skip_type_checking_of_declaration_files_6012", "Skip type checking of declaration files."),
-        Do_not_resolve_the_real_path_of_symlinks: diag(6013, 3 /* Message */, "Do_not_resolve_the_real_path_of_symlinks_6013", "Do not resolve the real path of symlinks."),
-        Only_emit_d_ts_declaration_files: diag(6014, 3 /* Message */, "Only_emit_d_ts_declaration_files_6014", "Only emit '.d.ts' declaration files."),
-        Specify_ECMAScript_target_version: diag(6015, 3 /* Message */, "Specify_ECMAScript_target_version_6015", "Specify ECMAScript target version."),
-        Specify_module_code_generation: diag(6016, 3 /* Message */, "Specify_module_code_generation_6016", "Specify module code generation."),
-        Print_this_message: diag(6017, 3 /* Message */, "Print_this_message_6017", "Print this message."),
-        Print_the_compiler_s_version: diag(6019, 3 /* Message */, "Print_the_compiler_s_version_6019", "Print the compiler's version."),
-        Compile_the_project_given_the_path_to_its_configuration_file_or_to_a_folder_with_a_tsconfig_json: diag(6020, 3 /* Message */, "Compile_the_project_given_the_path_to_its_configuration_file_or_to_a_folder_with_a_tsconfig_json_6020", "Compile the project given the path to its configuration file, or to a folder with a 'tsconfig.json'."),
-        Syntax_Colon_0: diag(6023, 3 /* Message */, "Syntax_Colon_0_6023", "Syntax: {0}"),
-        options: diag(6024, 3 /* Message */, "options_6024", "options"),
-        file: diag(6025, 3 /* Message */, "file_6025", "file"),
-        Examples_Colon_0: diag(6026, 3 /* Message */, "Examples_Colon_0_6026", "Examples: {0}"),
-        Options_Colon: diag(6027, 3 /* Message */, "Options_Colon_6027", "Options:"),
-        Version_0: diag(6029, 3 /* Message */, "Version_0_6029", "Version {0}"),
-        Insert_command_line_options_and_files_from_a_file: diag(6030, 3 /* Message */, "Insert_command_line_options_and_files_from_a_file_6030", "Insert command line options and files from a file."),
-        Starting_compilation_in_watch_mode: diag(6031, 3 /* Message */, "Starting_compilation_in_watch_mode_6031", "Starting compilation in watch mode..."),
-        File_change_detected_Starting_incremental_compilation: diag(6032, 3 /* Message */, "File_change_detected_Starting_incremental_compilation_6032", "File change detected. Starting incremental compilation..."),
-        KIND: diag(6034, 3 /* Message */, "KIND_6034", "KIND"),
-        FILE: diag(6035, 3 /* Message */, "FILE_6035", "FILE"),
-        VERSION: diag(6036, 3 /* Message */, "VERSION_6036", "VERSION"),
-        LOCATION: diag(6037, 3 /* Message */, "LOCATION_6037", "LOCATION"),
-        DIRECTORY: diag(6038, 3 /* Message */, "DIRECTORY_6038", "DIRECTORY"),
-        STRATEGY: diag(6039, 3 /* Message */, "STRATEGY_6039", "STRATEGY"),
-        FILE_OR_DIRECTORY: diag(6040, 3 /* Message */, "FILE_OR_DIRECTORY_6040", "FILE OR DIRECTORY"),
-        Errors_Files: diag(6041, 3 /* Message */, "Errors_Files_6041", "Errors  Files"),
-        Generates_corresponding_map_file: diag(6043, 3 /* Message */, "Generates_corresponding_map_file_6043", "Generates corresponding '.map' file."),
-        Compiler_option_0_expects_an_argument: diag(6044, 1 /* Error */, "Compiler_option_0_expects_an_argument_6044", "Compiler option '{0}' expects an argument."),
-        Unterminated_quoted_string_in_response_file_0: diag(6045, 1 /* Error */, "Unterminated_quoted_string_in_response_file_0_6045", "Unterminated quoted string in response file '{0}'."),
-        Argument_for_0_option_must_be_Colon_1: diag(6046, 1 /* Error */, "Argument_for_0_option_must_be_Colon_1_6046", "Argument for '{0}' option must be: {1}."),
-        Locale_must_be_of_the_form_language_or_language_territory_For_example_0_or_1: diag(6048, 1 /* Error */, "Locale_must_be_of_the_form_language_or_language_territory_For_example_0_or_1_6048", "Locale must be of the form  or -. For example '{0}' or '{1}'."),
-        Unable_to_open_file_0: diag(6050, 1 /* Error */, "Unable_to_open_file_0_6050", "Unable to open file '{0}'."),
-        Corrupted_locale_file_0: diag(6051, 1 /* Error */, "Corrupted_locale_file_0_6051", "Corrupted locale file {0}."),
-        Raise_error_on_expressions_and_declarations_with_an_implied_any_type: diag(6052, 3 /* Message */, "Raise_error_on_expressions_and_declarations_with_an_implied_any_type_6052", "Raise error on expressions and declarations with an implied 'any' type."),
-        File_0_not_found: diag(6053, 1 /* Error */, "File_0_not_found_6053", "File '{0}' not found."),
-        File_0_has_an_unsupported_extension_The_only_supported_extensions_are_1: diag(6054, 1 /* Error */, "File_0_has_an_unsupported_extension_The_only_supported_extensions_are_1_6054", "File '{0}' has an unsupported extension. The only supported extensions are {1}."),
-        Suppress_noImplicitAny_errors_for_indexing_objects_lacking_index_signatures: diag(6055, 3 /* Message */, "Suppress_noImplicitAny_errors_for_indexing_objects_lacking_index_signatures_6055", "Suppress noImplicitAny errors for indexing objects lacking index signatures."),
-        Do_not_emit_declarations_for_code_that_has_an_internal_annotation: diag(6056, 3 /* Message */, "Do_not_emit_declarations_for_code_that_has_an_internal_annotation_6056", "Do not emit declarations for code that has an '@internal' annotation."),
-        Specify_the_root_directory_of_input_files_Use_to_control_the_output_directory_structure_with_outDir: diag(6058, 3 /* Message */, "Specify_the_root_directory_of_input_files_Use_to_control_the_output_directory_structure_with_outDir_6058", "Specify the root directory of input files. Use to control the output directory structure with --outDir."),
-        File_0_is_not_under_rootDir_1_rootDir_is_expected_to_contain_all_source_files: diag(6059, 1 /* Error */, "File_0_is_not_under_rootDir_1_rootDir_is_expected_to_contain_all_source_files_6059", "File '{0}' is not under 'rootDir' '{1}'. 'rootDir' is expected to contain all source files."),
-        Specify_the_end_of_line_sequence_to_be_used_when_emitting_files_Colon_CRLF_dos_or_LF_unix: diag(6060, 3 /* Message */, "Specify_the_end_of_line_sequence_to_be_used_when_emitting_files_Colon_CRLF_dos_or_LF_unix_6060", "Specify the end of line sequence to be used when emitting files: 'CRLF' (dos) or 'LF' (unix)."),
-        NEWLINE: diag(6061, 3 /* Message */, "NEWLINE_6061", "NEWLINE"),
-        Option_0_can_only_be_specified_in_tsconfig_json_file_or_set_to_null_on_command_line: diag(6064, 1 /* Error */, "Option_0_can_only_be_specified_in_tsconfig_json_file_or_set_to_null_on_command_line_6064", "Option '{0}' can only be specified in 'tsconfig.json' file or set to 'null' on command line."),
-        Enables_experimental_support_for_ES7_decorators: diag(6065, 3 /* Message */, "Enables_experimental_support_for_ES7_decorators_6065", "Enables experimental support for ES7 decorators."),
-        Enables_experimental_support_for_emitting_type_metadata_for_decorators: diag(6066, 3 /* Message */, "Enables_experimental_support_for_emitting_type_metadata_for_decorators_6066", "Enables experimental support for emitting type metadata for decorators."),
-        Initializes_a_TypeScript_project_and_creates_a_tsconfig_json_file: diag(6070, 3 /* Message */, "Initializes_a_TypeScript_project_and_creates_a_tsconfig_json_file_6070", "Initializes a TypeScript project and creates a tsconfig.json file."),
-        Successfully_created_a_tsconfig_json_file: diag(6071, 3 /* Message */, "Successfully_created_a_tsconfig_json_file_6071", "Successfully created a tsconfig.json file."),
-        Suppress_excess_property_checks_for_object_literals: diag(6072, 3 /* Message */, "Suppress_excess_property_checks_for_object_literals_6072", "Suppress excess property checks for object literals."),
-        Stylize_errors_and_messages_using_color_and_context_experimental: diag(6073, 3 /* Message */, "Stylize_errors_and_messages_using_color_and_context_experimental_6073", "Stylize errors and messages using color and context (experimental)."),
-        Do_not_report_errors_on_unused_labels: diag(6074, 3 /* Message */, "Do_not_report_errors_on_unused_labels_6074", "Do not report errors on unused labels."),
-        Report_error_when_not_all_code_paths_in_function_return_a_value: diag(6075, 3 /* Message */, "Report_error_when_not_all_code_paths_in_function_return_a_value_6075", "Report error when not all code paths in function return a value."),
-        Report_errors_for_fallthrough_cases_in_switch_statement: diag(6076, 3 /* Message */, "Report_errors_for_fallthrough_cases_in_switch_statement_6076", "Report errors for fallthrough cases in switch statement."),
-        Do_not_report_errors_on_unreachable_code: diag(6077, 3 /* Message */, "Do_not_report_errors_on_unreachable_code_6077", "Do not report errors on unreachable code."),
-        Disallow_inconsistently_cased_references_to_the_same_file: diag(6078, 3 /* Message */, "Disallow_inconsistently_cased_references_to_the_same_file_6078", "Disallow inconsistently-cased references to the same file."),
-        Specify_library_files_to_be_included_in_the_compilation: diag(6079, 3 /* Message */, "Specify_library_files_to_be_included_in_the_compilation_6079", "Specify library files to be included in the compilation."),
-        Specify_JSX_code_generation: diag(6080, 3 /* Message */, "Specify_JSX_code_generation_6080", "Specify JSX code generation."),
-        File_0_has_an_unsupported_extension_so_skipping_it: diag(6081, 3 /* Message */, "File_0_has_an_unsupported_extension_so_skipping_it_6081", "File '{0}' has an unsupported extension, so skipping it."),
-        Only_amd_and_system_modules_are_supported_alongside_0: diag(6082, 1 /* Error */, "Only_amd_and_system_modules_are_supported_alongside_0_6082", "Only 'amd' and 'system' modules are supported alongside --{0}."),
-        Base_directory_to_resolve_non_absolute_module_names: diag(6083, 3 /* Message */, "Base_directory_to_resolve_non_absolute_module_names_6083", "Base directory to resolve non-absolute module names."),
-        Deprecated_Use_jsxFactory_instead_Specify_the_object_invoked_for_createElement_when_targeting_react_JSX_emit: diag(6084, 3 /* Message */, "Deprecated_Use_jsxFactory_instead_Specify_the_object_invoked_for_createElement_when_targeting_react__6084", "[Deprecated] Use '--jsxFactory' instead. Specify the object invoked for createElement when targeting 'react' JSX emit"),
-        Enable_tracing_of_the_name_resolution_process: diag(6085, 3 /* Message */, "Enable_tracing_of_the_name_resolution_process_6085", "Enable tracing of the name resolution process."),
-        Resolving_module_0_from_1: diag(6086, 3 /* Message */, "Resolving_module_0_from_1_6086", "======== Resolving module '{0}' from '{1}'. ========"),
-        Explicitly_specified_module_resolution_kind_Colon_0: diag(6087, 3 /* Message */, "Explicitly_specified_module_resolution_kind_Colon_0_6087", "Explicitly specified module resolution kind: '{0}'."),
-        Module_resolution_kind_is_not_specified_using_0: diag(6088, 3 /* Message */, "Module_resolution_kind_is_not_specified_using_0_6088", "Module resolution kind is not specified, using '{0}'."),
-        Module_name_0_was_successfully_resolved_to_1: diag(6089, 3 /* Message */, "Module_name_0_was_successfully_resolved_to_1_6089", "======== Module name '{0}' was successfully resolved to '{1}'. ========"),
-        Module_name_0_was_not_resolved: diag(6090, 3 /* Message */, "Module_name_0_was_not_resolved_6090", "======== Module name '{0}' was not resolved. ========"),
-        paths_option_is_specified_looking_for_a_pattern_to_match_module_name_0: diag(6091, 3 /* Message */, "paths_option_is_specified_looking_for_a_pattern_to_match_module_name_0_6091", "'paths' option is specified, looking for a pattern to match module name '{0}'."),
-        Module_name_0_matched_pattern_1: diag(6092, 3 /* Message */, "Module_name_0_matched_pattern_1_6092", "Module name '{0}', matched pattern '{1}'."),
-        Trying_substitution_0_candidate_module_location_Colon_1: diag(6093, 3 /* Message */, "Trying_substitution_0_candidate_module_location_Colon_1_6093", "Trying substitution '{0}', candidate module location: '{1}'."),
-        Resolving_module_name_0_relative_to_base_url_1_2: diag(6094, 3 /* Message */, "Resolving_module_name_0_relative_to_base_url_1_2_6094", "Resolving module name '{0}' relative to base url '{1}' - '{2}'."),
-        Loading_module_as_file_Slash_folder_candidate_module_location_0_target_file_types_Colon_1: diag(6095, 3 /* Message */, "Loading_module_as_file_Slash_folder_candidate_module_location_0_target_file_types_Colon_1_6095", "Loading module as file / folder, candidate module location '{0}', target file types: {1}."),
-        File_0_does_not_exist: diag(6096, 3 /* Message */, "File_0_does_not_exist_6096", "File '{0}' does not exist."),
-        File_0_exists_use_it_as_a_name_resolution_result: diag(6097, 3 /* Message */, "File_0_exists_use_it_as_a_name_resolution_result_6097", "File '{0}' exists - use it as a name resolution result."),
-        Loading_module_0_from_node_modules_folder_target_file_types_Colon_1: diag(6098, 3 /* Message */, "Loading_module_0_from_node_modules_folder_target_file_types_Colon_1_6098", "Loading module '{0}' from 'node_modules' folder, target file types: {1}."),
-        Found_package_json_at_0: diag(6099, 3 /* Message */, "Found_package_json_at_0_6099", "Found 'package.json' at '{0}'."),
-        package_json_does_not_have_a_0_field: diag(6100, 3 /* Message */, "package_json_does_not_have_a_0_field_6100", "'package.json' does not have a '{0}' field."),
-        package_json_has_0_field_1_that_references_2: diag(6101, 3 /* Message */, "package_json_has_0_field_1_that_references_2_6101", "'package.json' has '{0}' field '{1}' that references '{2}'."),
-        Allow_javascript_files_to_be_compiled: diag(6102, 3 /* Message */, "Allow_javascript_files_to_be_compiled_6102", "Allow javascript files to be compiled."),
-        Checking_if_0_is_the_longest_matching_prefix_for_1_2: diag(6104, 3 /* Message */, "Checking_if_0_is_the_longest_matching_prefix_for_1_2_6104", "Checking if '{0}' is the longest matching prefix for '{1}' - '{2}'."),
-        Expected_type_of_0_field_in_package_json_to_be_1_got_2: diag(6105, 3 /* Message */, "Expected_type_of_0_field_in_package_json_to_be_1_got_2_6105", "Expected type of '{0}' field in 'package.json' to be '{1}', got '{2}'."),
-        baseUrl_option_is_set_to_0_using_this_value_to_resolve_non_relative_module_name_1: diag(6106, 3 /* Message */, "baseUrl_option_is_set_to_0_using_this_value_to_resolve_non_relative_module_name_1_6106", "'baseUrl' option is set to '{0}', using this value to resolve non-relative module name '{1}'."),
-        rootDirs_option_is_set_using_it_to_resolve_relative_module_name_0: diag(6107, 3 /* Message */, "rootDirs_option_is_set_using_it_to_resolve_relative_module_name_0_6107", "'rootDirs' option is set, using it to resolve relative module name '{0}'."),
-        Longest_matching_prefix_for_0_is_1: diag(6108, 3 /* Message */, "Longest_matching_prefix_for_0_is_1_6108", "Longest matching prefix for '{0}' is '{1}'."),
-        Loading_0_from_the_root_dir_1_candidate_location_2: diag(6109, 3 /* Message */, "Loading_0_from_the_root_dir_1_candidate_location_2_6109", "Loading '{0}' from the root dir '{1}', candidate location '{2}'."),
-        Trying_other_entries_in_rootDirs: diag(6110, 3 /* Message */, "Trying_other_entries_in_rootDirs_6110", "Trying other entries in 'rootDirs'."),
-        Module_resolution_using_rootDirs_has_failed: diag(6111, 3 /* Message */, "Module_resolution_using_rootDirs_has_failed_6111", "Module resolution using 'rootDirs' has failed."),
-        Do_not_emit_use_strict_directives_in_module_output: diag(6112, 3 /* Message */, "Do_not_emit_use_strict_directives_in_module_output_6112", "Do not emit 'use strict' directives in module output."),
-        Enable_strict_null_checks: diag(6113, 3 /* Message */, "Enable_strict_null_checks_6113", "Enable strict null checks."),
-        Unknown_option_excludes_Did_you_mean_exclude: diag(6114, 1 /* Error */, "Unknown_option_excludes_Did_you_mean_exclude_6114", "Unknown option 'excludes'. Did you mean 'exclude'?"),
-        Raise_error_on_this_expressions_with_an_implied_any_type: diag(6115, 3 /* Message */, "Raise_error_on_this_expressions_with_an_implied_any_type_6115", "Raise error on 'this' expressions with an implied 'any' type."),
-        Resolving_type_reference_directive_0_containing_file_1_root_directory_2: diag(6116, 3 /* Message */, "Resolving_type_reference_directive_0_containing_file_1_root_directory_2_6116", "======== Resolving type reference directive '{0}', containing file '{1}', root directory '{2}'. ========"),
-        Type_reference_directive_0_was_successfully_resolved_to_1_primary_Colon_2: diag(6119, 3 /* Message */, "Type_reference_directive_0_was_successfully_resolved_to_1_primary_Colon_2_6119", "======== Type reference directive '{0}' was successfully resolved to '{1}', primary: {2}. ========"),
-        Type_reference_directive_0_was_not_resolved: diag(6120, 3 /* Message */, "Type_reference_directive_0_was_not_resolved_6120", "======== Type reference directive '{0}' was not resolved. ========"),
-        Resolving_with_primary_search_path_0: diag(6121, 3 /* Message */, "Resolving_with_primary_search_path_0_6121", "Resolving with primary search path '{0}'."),
-        Root_directory_cannot_be_determined_skipping_primary_search_paths: diag(6122, 3 /* Message */, "Root_directory_cannot_be_determined_skipping_primary_search_paths_6122", "Root directory cannot be determined, skipping primary search paths."),
-        Resolving_type_reference_directive_0_containing_file_1_root_directory_not_set: diag(6123, 3 /* Message */, "Resolving_type_reference_directive_0_containing_file_1_root_directory_not_set_6123", "======== Resolving type reference directive '{0}', containing file '{1}', root directory not set. ========"),
-        Type_declaration_files_to_be_included_in_compilation: diag(6124, 3 /* Message */, "Type_declaration_files_to_be_included_in_compilation_6124", "Type declaration files to be included in compilation."),
-        Looking_up_in_node_modules_folder_initial_location_0: diag(6125, 3 /* Message */, "Looking_up_in_node_modules_folder_initial_location_0_6125", "Looking up in 'node_modules' folder, initial location '{0}'."),
-        Containing_file_is_not_specified_and_root_directory_cannot_be_determined_skipping_lookup_in_node_modules_folder: diag(6126, 3 /* Message */, "Containing_file_is_not_specified_and_root_directory_cannot_be_determined_skipping_lookup_in_node_mod_6126", "Containing file is not specified and root directory cannot be determined, skipping lookup in 'node_modules' folder."),
-        Resolving_type_reference_directive_0_containing_file_not_set_root_directory_1: diag(6127, 3 /* Message */, "Resolving_type_reference_directive_0_containing_file_not_set_root_directory_1_6127", "======== Resolving type reference directive '{0}', containing file not set, root directory '{1}'. ========"),
-        Resolving_type_reference_directive_0_containing_file_not_set_root_directory_not_set: diag(6128, 3 /* Message */, "Resolving_type_reference_directive_0_containing_file_not_set_root_directory_not_set_6128", "======== Resolving type reference directive '{0}', containing file not set, root directory not set. ========"),
-        Resolving_real_path_for_0_result_1: diag(6130, 3 /* Message */, "Resolving_real_path_for_0_result_1_6130", "Resolving real path for '{0}', result '{1}'."),
-        Cannot_compile_modules_using_option_0_unless_the_module_flag_is_amd_or_system: diag(6131, 1 /* Error */, "Cannot_compile_modules_using_option_0_unless_the_module_flag_is_amd_or_system_6131", "Cannot compile modules using option '{0}' unless the '--module' flag is 'amd' or 'system'."),
-        File_name_0_has_a_1_extension_stripping_it: diag(6132, 3 /* Message */, "File_name_0_has_a_1_extension_stripping_it_6132", "File name '{0}' has a '{1}' extension - stripping it."),
-        _0_is_declared_but_its_value_is_never_read: diag(
-          6133,
-          1 /* Error */,
-          "_0_is_declared_but_its_value_is_never_read_6133",
-          "'{0}' is declared but its value is never read.",
-          /*reportsUnnecessary*/
-          true
-        ),
-        Report_errors_on_unused_locals: diag(6134, 3 /* Message */, "Report_errors_on_unused_locals_6134", "Report errors on unused locals."),
-        Report_errors_on_unused_parameters: diag(6135, 3 /* Message */, "Report_errors_on_unused_parameters_6135", "Report errors on unused parameters."),
-        The_maximum_dependency_depth_to_search_under_node_modules_and_load_JavaScript_files: diag(6136, 3 /* Message */, "The_maximum_dependency_depth_to_search_under_node_modules_and_load_JavaScript_files_6136", "The maximum dependency depth to search under node_modules and load JavaScript files."),
-        Cannot_import_type_declaration_files_Consider_importing_0_instead_of_1: diag(6137, 1 /* Error */, "Cannot_import_type_declaration_files_Consider_importing_0_instead_of_1_6137", "Cannot import type declaration files. Consider importing '{0}' instead of '{1}'."),
-        Property_0_is_declared_but_its_value_is_never_read: diag(
-          6138,
-          1 /* Error */,
-          "Property_0_is_declared_but_its_value_is_never_read_6138",
-          "Property '{0}' is declared but its value is never read.",
-          /*reportsUnnecessary*/
-          true
-        ),
-        Import_emit_helpers_from_tslib: diag(6139, 3 /* Message */, "Import_emit_helpers_from_tslib_6139", "Import emit helpers from 'tslib'."),
-        Auto_discovery_for_typings_is_enabled_in_project_0_Running_extra_resolution_pass_for_module_1_using_cache_location_2: diag(6140, 1 /* Error */, "Auto_discovery_for_typings_is_enabled_in_project_0_Running_extra_resolution_pass_for_module_1_using__6140", "Auto discovery for typings is enabled in project '{0}'. Running extra resolution pass for module '{1}' using cache location '{2}'."),
-        Parse_in_strict_mode_and_emit_use_strict_for_each_source_file: diag(6141, 3 /* Message */, "Parse_in_strict_mode_and_emit_use_strict_for_each_source_file_6141", 'Parse in strict mode and emit "use strict" for each source file.'),
-        Module_0_was_resolved_to_1_but_jsx_is_not_set: diag(6142, 1 /* Error */, "Module_0_was_resolved_to_1_but_jsx_is_not_set_6142", "Module '{0}' was resolved to '{1}', but '--jsx' is not set."),
-        Module_0_was_resolved_as_locally_declared_ambient_module_in_file_1: diag(6144, 3 /* Message */, "Module_0_was_resolved_as_locally_declared_ambient_module_in_file_1_6144", "Module '{0}' was resolved as locally declared ambient module in file '{1}'."),
-        Module_0_was_resolved_as_ambient_module_declared_in_1_since_this_file_was_not_modified: diag(6145, 3 /* Message */, "Module_0_was_resolved_as_ambient_module_declared_in_1_since_this_file_was_not_modified_6145", "Module '{0}' was resolved as ambient module declared in '{1}' since this file was not modified."),
-        Specify_the_JSX_factory_function_to_use_when_targeting_react_JSX_emit_e_g_React_createElement_or_h: diag(6146, 3 /* Message */, "Specify_the_JSX_factory_function_to_use_when_targeting_react_JSX_emit_e_g_React_createElement_or_h_6146", "Specify the JSX factory function to use when targeting 'react' JSX emit, e.g. 'React.createElement' or 'h'."),
-        Resolution_for_module_0_was_found_in_cache_from_location_1: diag(6147, 3 /* Message */, "Resolution_for_module_0_was_found_in_cache_from_location_1_6147", "Resolution for module '{0}' was found in cache from location '{1}'."),
-        Directory_0_does_not_exist_skipping_all_lookups_in_it: diag(6148, 3 /* Message */, "Directory_0_does_not_exist_skipping_all_lookups_in_it_6148", "Directory '{0}' does not exist, skipping all lookups in it."),
-        Show_diagnostic_information: diag(6149, 3 /* Message */, "Show_diagnostic_information_6149", "Show diagnostic information."),
-        Show_verbose_diagnostic_information: diag(6150, 3 /* Message */, "Show_verbose_diagnostic_information_6150", "Show verbose diagnostic information."),
-        Emit_a_single_file_with_source_maps_instead_of_having_a_separate_file: diag(6151, 3 /* Message */, "Emit_a_single_file_with_source_maps_instead_of_having_a_separate_file_6151", "Emit a single file with source maps instead of having a separate file."),
-        Emit_the_source_alongside_the_sourcemaps_within_a_single_file_requires_inlineSourceMap_or_sourceMap_to_be_set: diag(6152, 3 /* Message */, "Emit_the_source_alongside_the_sourcemaps_within_a_single_file_requires_inlineSourceMap_or_sourceMap__6152", "Emit the source alongside the sourcemaps within a single file; requires '--inlineSourceMap' or '--sourceMap' to be set."),
-        Transpile_each_file_as_a_separate_module_similar_to_ts_transpileModule: diag(6153, 3 /* Message */, "Transpile_each_file_as_a_separate_module_similar_to_ts_transpileModule_6153", "Transpile each file as a separate module (similar to 'ts.transpileModule')."),
-        Print_names_of_generated_files_part_of_the_compilation: diag(6154, 3 /* Message */, "Print_names_of_generated_files_part_of_the_compilation_6154", "Print names of generated files part of the compilation."),
-        Print_names_of_files_part_of_the_compilation: diag(6155, 3 /* Message */, "Print_names_of_files_part_of_the_compilation_6155", "Print names of files part of the compilation."),
-        The_locale_used_when_displaying_messages_to_the_user_e_g_en_us: diag(6156, 3 /* Message */, "The_locale_used_when_displaying_messages_to_the_user_e_g_en_us_6156", "The locale used when displaying messages to the user (e.g. 'en-us')"),
-        Do_not_generate_custom_helper_functions_like_extends_in_compiled_output: diag(6157, 3 /* Message */, "Do_not_generate_custom_helper_functions_like_extends_in_compiled_output_6157", "Do not generate custom helper functions like '__extends' in compiled output."),
-        Do_not_include_the_default_library_file_lib_d_ts: diag(6158, 3 /* Message */, "Do_not_include_the_default_library_file_lib_d_ts_6158", "Do not include the default library file (lib.d.ts)."),
-        Do_not_add_triple_slash_references_or_imported_modules_to_the_list_of_compiled_files: diag(6159, 3 /* Message */, "Do_not_add_triple_slash_references_or_imported_modules_to_the_list_of_compiled_files_6159", "Do not add triple-slash references or imported modules to the list of compiled files."),
-        Deprecated_Use_skipLibCheck_instead_Skip_type_checking_of_default_library_declaration_files: diag(6160, 3 /* Message */, "Deprecated_Use_skipLibCheck_instead_Skip_type_checking_of_default_library_declaration_files_6160", "[Deprecated] Use '--skipLibCheck' instead. Skip type checking of default library declaration files."),
-        List_of_folders_to_include_type_definitions_from: diag(6161, 3 /* Message */, "List_of_folders_to_include_type_definitions_from_6161", "List of folders to include type definitions from."),
-        Disable_size_limitations_on_JavaScript_projects: diag(6162, 3 /* Message */, "Disable_size_limitations_on_JavaScript_projects_6162", "Disable size limitations on JavaScript projects."),
-        The_character_set_of_the_input_files: diag(6163, 3 /* Message */, "The_character_set_of_the_input_files_6163", "The character set of the input files."),
-        Skipping_module_0_that_looks_like_an_absolute_URI_target_file_types_Colon_1: diag(6164, 3 /* Message */, "Skipping_module_0_that_looks_like_an_absolute_URI_target_file_types_Colon_1_6164", "Skipping module '{0}' that looks like an absolute URI, target file types: {1}."),
-        Do_not_truncate_error_messages: diag(6165, 3 /* Message */, "Do_not_truncate_error_messages_6165", "Do not truncate error messages."),
-        Output_directory_for_generated_declaration_files: diag(6166, 3 /* Message */, "Output_directory_for_generated_declaration_files_6166", "Output directory for generated declaration files."),
-        A_series_of_entries_which_re_map_imports_to_lookup_locations_relative_to_the_baseUrl: diag(6167, 3 /* Message */, "A_series_of_entries_which_re_map_imports_to_lookup_locations_relative_to_the_baseUrl_6167", "A series of entries which re-map imports to lookup locations relative to the 'baseUrl'."),
-        List_of_root_folders_whose_combined_content_represents_the_structure_of_the_project_at_runtime: diag(6168, 3 /* Message */, "List_of_root_folders_whose_combined_content_represents_the_structure_of_the_project_at_runtime_6168", "List of root folders whose combined content represents the structure of the project at runtime."),
-        Show_all_compiler_options: diag(6169, 3 /* Message */, "Show_all_compiler_options_6169", "Show all compiler options."),
-        Deprecated_Use_outFile_instead_Concatenate_and_emit_output_to_single_file: diag(6170, 3 /* Message */, "Deprecated_Use_outFile_instead_Concatenate_and_emit_output_to_single_file_6170", "[Deprecated] Use '--outFile' instead. Concatenate and emit output to single file"),
-        Command_line_Options: diag(6171, 3 /* Message */, "Command_line_Options_6171", "Command-line Options"),
-        Provide_full_support_for_iterables_in_for_of_spread_and_destructuring_when_targeting_ES5_or_ES3: diag(6179, 3 /* Message */, "Provide_full_support_for_iterables_in_for_of_spread_and_destructuring_when_targeting_ES5_or_ES3_6179", "Provide full support for iterables in 'for-of', spread, and destructuring when targeting 'ES5' or 'ES3'."),
-        Enable_all_strict_type_checking_options: diag(6180, 3 /* Message */, "Enable_all_strict_type_checking_options_6180", "Enable all strict type-checking options."),
-        Scoped_package_detected_looking_in_0: diag(6182, 3 /* Message */, "Scoped_package_detected_looking_in_0_6182", "Scoped package detected, looking in '{0}'"),
-        Reusing_resolution_of_module_0_from_1_of_old_program_it_was_successfully_resolved_to_2: diag(6183, 3 /* Message */, "Reusing_resolution_of_module_0_from_1_of_old_program_it_was_successfully_resolved_to_2_6183", "Reusing resolution of module '{0}' from '{1}' of old program, it was successfully resolved to '{2}'."),
-        Reusing_resolution_of_module_0_from_1_of_old_program_it_was_successfully_resolved_to_2_with_Package_ID_3: diag(6184, 3 /* Message */, "Reusing_resolution_of_module_0_from_1_of_old_program_it_was_successfully_resolved_to_2_with_Package__6184", "Reusing resolution of module '{0}' from '{1}' of old program, it was successfully resolved to '{2}' with Package ID '{3}'."),
-        Enable_strict_checking_of_function_types: diag(6186, 3 /* Message */, "Enable_strict_checking_of_function_types_6186", "Enable strict checking of function types."),
-        Enable_strict_checking_of_property_initialization_in_classes: diag(6187, 3 /* Message */, "Enable_strict_checking_of_property_initialization_in_classes_6187", "Enable strict checking of property initialization in classes."),
-        Numeric_separators_are_not_allowed_here: diag(6188, 1 /* Error */, "Numeric_separators_are_not_allowed_here_6188", "Numeric separators are not allowed here."),
-        Multiple_consecutive_numeric_separators_are_not_permitted: diag(6189, 1 /* Error */, "Multiple_consecutive_numeric_separators_are_not_permitted_6189", "Multiple consecutive numeric separators are not permitted."),
-        Whether_to_keep_outdated_console_output_in_watch_mode_instead_of_clearing_the_screen: diag(6191, 3 /* Message */, "Whether_to_keep_outdated_console_output_in_watch_mode_instead_of_clearing_the_screen_6191", "Whether to keep outdated console output in watch mode instead of clearing the screen."),
-        All_imports_in_import_declaration_are_unused: diag(
-          6192,
-          1 /* Error */,
-          "All_imports_in_import_declaration_are_unused_6192",
-          "All imports in import declaration are unused.",
-          /*reportsUnnecessary*/
-          true
-        ),
-        Found_1_error_Watching_for_file_changes: diag(6193, 3 /* Message */, "Found_1_error_Watching_for_file_changes_6193", "Found 1 error. Watching for file changes."),
-        Found_0_errors_Watching_for_file_changes: diag(6194, 3 /* Message */, "Found_0_errors_Watching_for_file_changes_6194", "Found {0} errors. Watching for file changes."),
-        Resolve_keyof_to_string_valued_property_names_only_no_numbers_or_symbols: diag(6195, 3 /* Message */, "Resolve_keyof_to_string_valued_property_names_only_no_numbers_or_symbols_6195", "Resolve 'keyof' to string valued property names only (no numbers or symbols)."),
-        _0_is_declared_but_never_used: diag(
-          6196,
-          1 /* Error */,
-          "_0_is_declared_but_never_used_6196",
-          "'{0}' is declared but never used.",
-          /*reportsUnnecessary*/
-          true
-        ),
-        Include_modules_imported_with_json_extension: diag(6197, 3 /* Message */, "Include_modules_imported_with_json_extension_6197", "Include modules imported with '.json' extension"),
-        All_destructured_elements_are_unused: diag(
-          6198,
-          1 /* Error */,
-          "All_destructured_elements_are_unused_6198",
-          "All destructured elements are unused.",
-          /*reportsUnnecessary*/
-          true
-        ),
-        All_variables_are_unused: diag(
-          6199,
-          1 /* Error */,
-          "All_variables_are_unused_6199",
-          "All variables are unused.",
-          /*reportsUnnecessary*/
-          true
-        ),
-        Definitions_of_the_following_identifiers_conflict_with_those_in_another_file_Colon_0: diag(6200, 1 /* Error */, "Definitions_of_the_following_identifiers_conflict_with_those_in_another_file_Colon_0_6200", "Definitions of the following identifiers conflict with those in another file: {0}"),
-        Conflicts_are_in_this_file: diag(6201, 3 /* Message */, "Conflicts_are_in_this_file_6201", "Conflicts are in this file."),
-        Project_references_may_not_form_a_circular_graph_Cycle_detected_Colon_0: diag(6202, 1 /* Error */, "Project_references_may_not_form_a_circular_graph_Cycle_detected_Colon_0_6202", "Project references may not form a circular graph. Cycle detected: {0}"),
-        _0_was_also_declared_here: diag(6203, 3 /* Message */, "_0_was_also_declared_here_6203", "'{0}' was also declared here."),
-        and_here: diag(6204, 3 /* Message */, "and_here_6204", "and here."),
-        All_type_parameters_are_unused: diag(6205, 1 /* Error */, "All_type_parameters_are_unused_6205", "All type parameters are unused."),
-        package_json_has_a_typesVersions_field_with_version_specific_path_mappings: diag(6206, 3 /* Message */, "package_json_has_a_typesVersions_field_with_version_specific_path_mappings_6206", "'package.json' has a 'typesVersions' field with version-specific path mappings."),
-        package_json_does_not_have_a_typesVersions_entry_that_matches_version_0: diag(6207, 3 /* Message */, "package_json_does_not_have_a_typesVersions_entry_that_matches_version_0_6207", "'package.json' does not have a 'typesVersions' entry that matches version '{0}'."),
-        package_json_has_a_typesVersions_entry_0_that_matches_compiler_version_1_looking_for_a_pattern_to_match_module_name_2: diag(6208, 3 /* Message */, "package_json_has_a_typesVersions_entry_0_that_matches_compiler_version_1_looking_for_a_pattern_to_ma_6208", "'package.json' has a 'typesVersions' entry '{0}' that matches compiler version '{1}', looking for a pattern to match module name '{2}'."),
-        package_json_has_a_typesVersions_entry_0_that_is_not_a_valid_semver_range: diag(6209, 3 /* Message */, "package_json_has_a_typesVersions_entry_0_that_is_not_a_valid_semver_range_6209", "'package.json' has a 'typesVersions' entry '{0}' that is not a valid semver range."),
-        An_argument_for_0_was_not_provided: diag(6210, 3 /* Message */, "An_argument_for_0_was_not_provided_6210", "An argument for '{0}' was not provided."),
-        An_argument_matching_this_binding_pattern_was_not_provided: diag(6211, 3 /* Message */, "An_argument_matching_this_binding_pattern_was_not_provided_6211", "An argument matching this binding pattern was not provided."),
-        Did_you_mean_to_call_this_expression: diag(6212, 3 /* Message */, "Did_you_mean_to_call_this_expression_6212", "Did you mean to call this expression?"),
-        Did_you_mean_to_use_new_with_this_expression: diag(6213, 3 /* Message */, "Did_you_mean_to_use_new_with_this_expression_6213", "Did you mean to use 'new' with this expression?"),
-        Enable_strict_bind_call_and_apply_methods_on_functions: diag(6214, 3 /* Message */, "Enable_strict_bind_call_and_apply_methods_on_functions_6214", "Enable strict 'bind', 'call', and 'apply' methods on functions."),
-        Using_compiler_options_of_project_reference_redirect_0: diag(6215, 3 /* Message */, "Using_compiler_options_of_project_reference_redirect_0_6215", "Using compiler options of project reference redirect '{0}'."),
-        Found_1_error: diag(6216, 3 /* Message */, "Found_1_error_6216", "Found 1 error."),
-        Found_0_errors: diag(6217, 3 /* Message */, "Found_0_errors_6217", "Found {0} errors."),
-        Module_name_0_was_successfully_resolved_to_1_with_Package_ID_2: diag(6218, 3 /* Message */, "Module_name_0_was_successfully_resolved_to_1_with_Package_ID_2_6218", "======== Module name '{0}' was successfully resolved to '{1}' with Package ID '{2}'. ========"),
-        Type_reference_directive_0_was_successfully_resolved_to_1_with_Package_ID_2_primary_Colon_3: diag(6219, 3 /* Message */, "Type_reference_directive_0_was_successfully_resolved_to_1_with_Package_ID_2_primary_Colon_3_6219", "======== Type reference directive '{0}' was successfully resolved to '{1}' with Package ID '{2}', primary: {3}. ========"),
-        package_json_had_a_falsy_0_field: diag(6220, 3 /* Message */, "package_json_had_a_falsy_0_field_6220", "'package.json' had a falsy '{0}' field."),
-        Disable_use_of_source_files_instead_of_declaration_files_from_referenced_projects: diag(6221, 3 /* Message */, "Disable_use_of_source_files_instead_of_declaration_files_from_referenced_projects_6221", "Disable use of source files instead of declaration files from referenced projects."),
-        Emit_class_fields_with_Define_instead_of_Set: diag(6222, 3 /* Message */, "Emit_class_fields_with_Define_instead_of_Set_6222", "Emit class fields with Define instead of Set."),
-        Generates_a_CPU_profile: diag(6223, 3 /* Message */, "Generates_a_CPU_profile_6223", "Generates a CPU profile."),
-        Disable_solution_searching_for_this_project: diag(6224, 3 /* Message */, "Disable_solution_searching_for_this_project_6224", "Disable solution searching for this project."),
-        Specify_strategy_for_watching_file_Colon_FixedPollingInterval_default_PriorityPollingInterval_DynamicPriorityPolling_FixedChunkSizePolling_UseFsEvents_UseFsEventsOnParentDirectory: diag(6225, 3 /* Message */, "Specify_strategy_for_watching_file_Colon_FixedPollingInterval_default_PriorityPollingInterval_Dynami_6225", "Specify strategy for watching file: 'FixedPollingInterval' (default), 'PriorityPollingInterval', 'DynamicPriorityPolling', 'FixedChunkSizePolling', 'UseFsEvents', 'UseFsEventsOnParentDirectory'."),
-        Specify_strategy_for_watching_directory_on_platforms_that_don_t_support_recursive_watching_natively_Colon_UseFsEvents_default_FixedPollingInterval_DynamicPriorityPolling_FixedChunkSizePolling: diag(6226, 3 /* Message */, "Specify_strategy_for_watching_directory_on_platforms_that_don_t_support_recursive_watching_natively__6226", "Specify strategy for watching directory on platforms that don't support recursive watching natively: 'UseFsEvents' (default), 'FixedPollingInterval', 'DynamicPriorityPolling', 'FixedChunkSizePolling'."),
-        Specify_strategy_for_creating_a_polling_watch_when_it_fails_to_create_using_file_system_events_Colon_FixedInterval_default_PriorityInterval_DynamicPriority_FixedChunkSize: diag(6227, 3 /* Message */, "Specify_strategy_for_creating_a_polling_watch_when_it_fails_to_create_using_file_system_events_Colon_6227", "Specify strategy for creating a polling watch when it fails to create using file system events: 'FixedInterval' (default), 'PriorityInterval', 'DynamicPriority', 'FixedChunkSize'."),
-        Tag_0_expects_at_least_1_arguments_but_the_JSX_factory_2_provides_at_most_3: diag(6229, 1 /* Error */, "Tag_0_expects_at_least_1_arguments_but_the_JSX_factory_2_provides_at_most_3_6229", "Tag '{0}' expects at least '{1}' arguments, but the JSX factory '{2}' provides at most '{3}'."),
-        Option_0_can_only_be_specified_in_tsconfig_json_file_or_set_to_false_or_null_on_command_line: diag(6230, 1 /* Error */, "Option_0_can_only_be_specified_in_tsconfig_json_file_or_set_to_false_or_null_on_command_line_6230", "Option '{0}' can only be specified in 'tsconfig.json' file or set to 'false' or 'null' on command line."),
-        Could_not_resolve_the_path_0_with_the_extensions_Colon_1: diag(6231, 1 /* Error */, "Could_not_resolve_the_path_0_with_the_extensions_Colon_1_6231", "Could not resolve the path '{0}' with the extensions: {1}."),
-        Declaration_augments_declaration_in_another_file_This_cannot_be_serialized: diag(6232, 1 /* Error */, "Declaration_augments_declaration_in_another_file_This_cannot_be_serialized_6232", "Declaration augments declaration in another file. This cannot be serialized."),
-        This_is_the_declaration_being_augmented_Consider_moving_the_augmenting_declaration_into_the_same_file: diag(6233, 1 /* Error */, "This_is_the_declaration_being_augmented_Consider_moving_the_augmenting_declaration_into_the_same_fil_6233", "This is the declaration being augmented. Consider moving the augmenting declaration into the same file."),
-        This_expression_is_not_callable_because_it_is_a_get_accessor_Did_you_mean_to_use_it_without: diag(6234, 1 /* Error */, "This_expression_is_not_callable_because_it_is_a_get_accessor_Did_you_mean_to_use_it_without_6234", "This expression is not callable because it is a 'get' accessor. Did you mean to use it without '()'?"),
-        Disable_loading_referenced_projects: diag(6235, 3 /* Message */, "Disable_loading_referenced_projects_6235", "Disable loading referenced projects."),
-        Arguments_for_the_rest_parameter_0_were_not_provided: diag(6236, 1 /* Error */, "Arguments_for_the_rest_parameter_0_were_not_provided_6236", "Arguments for the rest parameter '{0}' were not provided."),
-        Generates_an_event_trace_and_a_list_of_types: diag(6237, 3 /* Message */, "Generates_an_event_trace_and_a_list_of_types_6237", "Generates an event trace and a list of types."),
-        Specify_the_module_specifier_to_be_used_to_import_the_jsx_and_jsxs_factory_functions_from_eg_react: diag(6238, 1 /* Error */, "Specify_the_module_specifier_to_be_used_to_import_the_jsx_and_jsxs_factory_functions_from_eg_react_6238", "Specify the module specifier to be used to import the 'jsx' and 'jsxs' factory functions from. eg, react"),
-        File_0_exists_according_to_earlier_cached_lookups: diag(6239, 3 /* Message */, "File_0_exists_according_to_earlier_cached_lookups_6239", "File '{0}' exists according to earlier cached lookups."),
-        File_0_does_not_exist_according_to_earlier_cached_lookups: diag(6240, 3 /* Message */, "File_0_does_not_exist_according_to_earlier_cached_lookups_6240", "File '{0}' does not exist according to earlier cached lookups."),
-        Resolution_for_type_reference_directive_0_was_found_in_cache_from_location_1: diag(6241, 3 /* Message */, "Resolution_for_type_reference_directive_0_was_found_in_cache_from_location_1_6241", "Resolution for type reference directive '{0}' was found in cache from location '{1}'."),
-        Resolving_type_reference_directive_0_containing_file_1: diag(6242, 3 /* Message */, "Resolving_type_reference_directive_0_containing_file_1_6242", "======== Resolving type reference directive '{0}', containing file '{1}'. ========"),
-        Interpret_optional_property_types_as_written_rather_than_adding_undefined: diag(6243, 3 /* Message */, "Interpret_optional_property_types_as_written_rather_than_adding_undefined_6243", "Interpret optional property types as written, rather than adding 'undefined'."),
-        Modules: diag(6244, 3 /* Message */, "Modules_6244", "Modules"),
-        File_Management: diag(6245, 3 /* Message */, "File_Management_6245", "File Management"),
-        Emit: diag(6246, 3 /* Message */, "Emit_6246", "Emit"),
-        JavaScript_Support: diag(6247, 3 /* Message */, "JavaScript_Support_6247", "JavaScript Support"),
-        Type_Checking: diag(6248, 3 /* Message */, "Type_Checking_6248", "Type Checking"),
-        Editor_Support: diag(6249, 3 /* Message */, "Editor_Support_6249", "Editor Support"),
-        Watch_and_Build_Modes: diag(6250, 3 /* Message */, "Watch_and_Build_Modes_6250", "Watch and Build Modes"),
-        Compiler_Diagnostics: diag(6251, 3 /* Message */, "Compiler_Diagnostics_6251", "Compiler Diagnostics"),
-        Interop_Constraints: diag(6252, 3 /* Message */, "Interop_Constraints_6252", "Interop Constraints"),
-        Backwards_Compatibility: diag(6253, 3 /* Message */, "Backwards_Compatibility_6253", "Backwards Compatibility"),
-        Language_and_Environment: diag(6254, 3 /* Message */, "Language_and_Environment_6254", "Language and Environment"),
-        Projects: diag(6255, 3 /* Message */, "Projects_6255", "Projects"),
-        Output_Formatting: diag(6256, 3 /* Message */, "Output_Formatting_6256", "Output Formatting"),
-        Completeness: diag(6257, 3 /* Message */, "Completeness_6257", "Completeness"),
-        _0_should_be_set_inside_the_compilerOptions_object_of_the_config_json_file: diag(6258, 1 /* Error */, "_0_should_be_set_inside_the_compilerOptions_object_of_the_config_json_file_6258", "'{0}' should be set inside the 'compilerOptions' object of the config json file"),
-        Found_1_error_in_0: diag(6259, 3 /* Message */, "Found_1_error_in_0_6259", "Found 1 error in {0}"),
-        Found_0_errors_in_the_same_file_starting_at_Colon_1: diag(6260, 3 /* Message */, "Found_0_errors_in_the_same_file_starting_at_Colon_1_6260", "Found {0} errors in the same file, starting at: {1}"),
-        Found_0_errors_in_1_files: diag(6261, 3 /* Message */, "Found_0_errors_in_1_files_6261", "Found {0} errors in {1} files."),
-        File_name_0_has_a_1_extension_looking_up_2_instead: diag(6262, 3 /* Message */, "File_name_0_has_a_1_extension_looking_up_2_instead_6262", "File name '{0}' has a '{1}' extension - looking up '{2}' instead."),
-        Module_0_was_resolved_to_1_but_allowArbitraryExtensions_is_not_set: diag(6263, 1 /* Error */, "Module_0_was_resolved_to_1_but_allowArbitraryExtensions_is_not_set_6263", "Module '{0}' was resolved to '{1}', but '--allowArbitraryExtensions' is not set."),
-        Enable_importing_files_with_any_extension_provided_a_declaration_file_is_present: diag(6264, 3 /* Message */, "Enable_importing_files_with_any_extension_provided_a_declaration_file_is_present_6264", "Enable importing files with any extension, provided a declaration file is present."),
-        Resolving_type_reference_directive_for_program_that_specifies_custom_typeRoots_skipping_lookup_in_node_modules_folder: diag(6265, 3 /* Message */, "Resolving_type_reference_directive_for_program_that_specifies_custom_typeRoots_skipping_lookup_in_no_6265", "Resolving type reference directive for program that specifies custom typeRoots, skipping lookup in 'node_modules' folder."),
-        Option_0_can_only_be_specified_on_command_line: diag(6266, 1 /* Error */, "Option_0_can_only_be_specified_on_command_line_6266", "Option '{0}' can only be specified on command line."),
-        Directory_0_has_no_containing_package_json_scope_Imports_will_not_resolve: diag(6270, 3 /* Message */, "Directory_0_has_no_containing_package_json_scope_Imports_will_not_resolve_6270", "Directory '{0}' has no containing package.json scope. Imports will not resolve."),
-        Import_specifier_0_does_not_exist_in_package_json_scope_at_path_1: diag(6271, 3 /* Message */, "Import_specifier_0_does_not_exist_in_package_json_scope_at_path_1_6271", "Import specifier '{0}' does not exist in package.json scope at path '{1}'."),
-        Invalid_import_specifier_0_has_no_possible_resolutions: diag(6272, 3 /* Message */, "Invalid_import_specifier_0_has_no_possible_resolutions_6272", "Invalid import specifier '{0}' has no possible resolutions."),
-        package_json_scope_0_has_no_imports_defined: diag(6273, 3 /* Message */, "package_json_scope_0_has_no_imports_defined_6273", "package.json scope '{0}' has no imports defined."),
-        package_json_scope_0_explicitly_maps_specifier_1_to_null: diag(6274, 3 /* Message */, "package_json_scope_0_explicitly_maps_specifier_1_to_null_6274", "package.json scope '{0}' explicitly maps specifier '{1}' to null."),
-        package_json_scope_0_has_invalid_type_for_target_of_specifier_1: diag(6275, 3 /* Message */, "package_json_scope_0_has_invalid_type_for_target_of_specifier_1_6275", "package.json scope '{0}' has invalid type for target of specifier '{1}'"),
-        Export_specifier_0_does_not_exist_in_package_json_scope_at_path_1: diag(6276, 3 /* Message */, "Export_specifier_0_does_not_exist_in_package_json_scope_at_path_1_6276", "Export specifier '{0}' does not exist in package.json scope at path '{1}'."),
-        Resolution_of_non_relative_name_failed_trying_with_modern_Node_resolution_features_disabled_to_see_if_npm_library_needs_configuration_update: diag(6277, 3 /* Message */, "Resolution_of_non_relative_name_failed_trying_with_modern_Node_resolution_features_disabled_to_see_i_6277", "Resolution of non-relative name failed; trying with modern Node resolution features disabled to see if npm library needs configuration update."),
-        There_are_types_at_0_but_this_result_could_not_be_resolved_when_respecting_package_json_exports_The_1_library_may_need_to_update_its_package_json_or_typings: diag(6278, 3 /* Message */, "There_are_types_at_0_but_this_result_could_not_be_resolved_when_respecting_package_json_exports_The__6278", `There are types at '{0}', but this result could not be resolved when respecting package.json "exports". The '{1}' library may need to update its package.json or typings.`),
-        Enable_project_compilation: diag(6302, 3 /* Message */, "Enable_project_compilation_6302", "Enable project compilation"),
-        Composite_projects_may_not_disable_declaration_emit: diag(6304, 1 /* Error */, "Composite_projects_may_not_disable_declaration_emit_6304", "Composite projects may not disable declaration emit."),
-        Output_file_0_has_not_been_built_from_source_file_1: diag(6305, 1 /* Error */, "Output_file_0_has_not_been_built_from_source_file_1_6305", "Output file '{0}' has not been built from source file '{1}'."),
-        Referenced_project_0_must_have_setting_composite_Colon_true: diag(6306, 1 /* Error */, "Referenced_project_0_must_have_setting_composite_Colon_true_6306", `Referenced project '{0}' must have setting "composite": true.`),
-        File_0_is_not_listed_within_the_file_list_of_project_1_Projects_must_list_all_files_or_use_an_include_pattern: diag(6307, 1 /* Error */, "File_0_is_not_listed_within_the_file_list_of_project_1_Projects_must_list_all_files_or_use_an_includ_6307", "File '{0}' is not listed within the file list of project '{1}'. Projects must list all files or use an 'include' pattern."),
-        Cannot_prepend_project_0_because_it_does_not_have_outFile_set: diag(6308, 1 /* Error */, "Cannot_prepend_project_0_because_it_does_not_have_outFile_set_6308", "Cannot prepend project '{0}' because it does not have 'outFile' set"),
-        Output_file_0_from_project_1_does_not_exist: diag(6309, 1 /* Error */, "Output_file_0_from_project_1_does_not_exist_6309", "Output file '{0}' from project '{1}' does not exist"),
-        Referenced_project_0_may_not_disable_emit: diag(6310, 1 /* Error */, "Referenced_project_0_may_not_disable_emit_6310", "Referenced project '{0}' may not disable emit."),
-        Project_0_is_out_of_date_because_output_1_is_older_than_input_2: diag(6350, 3 /* Message */, "Project_0_is_out_of_date_because_output_1_is_older_than_input_2_6350", "Project '{0}' is out of date because output '{1}' is older than input '{2}'"),
-        Project_0_is_up_to_date_because_newest_input_1_is_older_than_output_2: diag(6351, 3 /* Message */, "Project_0_is_up_to_date_because_newest_input_1_is_older_than_output_2_6351", "Project '{0}' is up to date because newest input '{1}' is older than output '{2}'"),
-        Project_0_is_out_of_date_because_output_file_1_does_not_exist: diag(6352, 3 /* Message */, "Project_0_is_out_of_date_because_output_file_1_does_not_exist_6352", "Project '{0}' is out of date because output file '{1}' does not exist"),
-        Project_0_is_out_of_date_because_its_dependency_1_is_out_of_date: diag(6353, 3 /* Message */, "Project_0_is_out_of_date_because_its_dependency_1_is_out_of_date_6353", "Project '{0}' is out of date because its dependency '{1}' is out of date"),
-        Project_0_is_up_to_date_with_d_ts_files_from_its_dependencies: diag(6354, 3 /* Message */, "Project_0_is_up_to_date_with_d_ts_files_from_its_dependencies_6354", "Project '{0}' is up to date with .d.ts files from its dependencies"),
-        Projects_in_this_build_Colon_0: diag(6355, 3 /* Message */, "Projects_in_this_build_Colon_0_6355", "Projects in this build: {0}"),
-        A_non_dry_build_would_delete_the_following_files_Colon_0: diag(6356, 3 /* Message */, "A_non_dry_build_would_delete_the_following_files_Colon_0_6356", "A non-dry build would delete the following files: {0}"),
-        A_non_dry_build_would_build_project_0: diag(6357, 3 /* Message */, "A_non_dry_build_would_build_project_0_6357", "A non-dry build would build project '{0}'"),
-        Building_project_0: diag(6358, 3 /* Message */, "Building_project_0_6358", "Building project '{0}'..."),
-        Updating_output_timestamps_of_project_0: diag(6359, 3 /* Message */, "Updating_output_timestamps_of_project_0_6359", "Updating output timestamps of project '{0}'..."),
-        Project_0_is_up_to_date: diag(6361, 3 /* Message */, "Project_0_is_up_to_date_6361", "Project '{0}' is up to date"),
-        Skipping_build_of_project_0_because_its_dependency_1_has_errors: diag(6362, 3 /* Message */, "Skipping_build_of_project_0_because_its_dependency_1_has_errors_6362", "Skipping build of project '{0}' because its dependency '{1}' has errors"),
-        Project_0_can_t_be_built_because_its_dependency_1_has_errors: diag(6363, 3 /* Message */, "Project_0_can_t_be_built_because_its_dependency_1_has_errors_6363", "Project '{0}' can't be built because its dependency '{1}' has errors"),
-        Build_one_or_more_projects_and_their_dependencies_if_out_of_date: diag(6364, 3 /* Message */, "Build_one_or_more_projects_and_their_dependencies_if_out_of_date_6364", "Build one or more projects and their dependencies, if out of date"),
-        Delete_the_outputs_of_all_projects: diag(6365, 3 /* Message */, "Delete_the_outputs_of_all_projects_6365", "Delete the outputs of all projects."),
-        Show_what_would_be_built_or_deleted_if_specified_with_clean: diag(6367, 3 /* Message */, "Show_what_would_be_built_or_deleted_if_specified_with_clean_6367", "Show what would be built (or deleted, if specified with '--clean')"),
-        Option_build_must_be_the_first_command_line_argument: diag(6369, 1 /* Error */, "Option_build_must_be_the_first_command_line_argument_6369", "Option '--build' must be the first command line argument."),
-        Options_0_and_1_cannot_be_combined: diag(6370, 1 /* Error */, "Options_0_and_1_cannot_be_combined_6370", "Options '{0}' and '{1}' cannot be combined."),
-        Updating_unchanged_output_timestamps_of_project_0: diag(6371, 3 /* Message */, "Updating_unchanged_output_timestamps_of_project_0_6371", "Updating unchanged output timestamps of project '{0}'..."),
-        Project_0_is_out_of_date_because_output_of_its_dependency_1_has_changed: diag(6372, 3 /* Message */, "Project_0_is_out_of_date_because_output_of_its_dependency_1_has_changed_6372", "Project '{0}' is out of date because output of its dependency '{1}' has changed"),
-        Updating_output_of_project_0: diag(6373, 3 /* Message */, "Updating_output_of_project_0_6373", "Updating output of project '{0}'..."),
-        A_non_dry_build_would_update_timestamps_for_output_of_project_0: diag(6374, 3 /* Message */, "A_non_dry_build_would_update_timestamps_for_output_of_project_0_6374", "A non-dry build would update timestamps for output of project '{0}'"),
-        A_non_dry_build_would_update_output_of_project_0: diag(6375, 3 /* Message */, "A_non_dry_build_would_update_output_of_project_0_6375", "A non-dry build would update output of project '{0}'"),
-        Cannot_update_output_of_project_0_because_there_was_error_reading_file_1: diag(6376, 3 /* Message */, "Cannot_update_output_of_project_0_because_there_was_error_reading_file_1_6376", "Cannot update output of project '{0}' because there was error reading file '{1}'"),
-        Cannot_write_file_0_because_it_will_overwrite_tsbuildinfo_file_generated_by_referenced_project_1: diag(6377, 1 /* Error */, "Cannot_write_file_0_because_it_will_overwrite_tsbuildinfo_file_generated_by_referenced_project_1_6377", "Cannot write file '{0}' because it will overwrite '.tsbuildinfo' file generated by referenced project '{1}'"),
-        Composite_projects_may_not_disable_incremental_compilation: diag(6379, 1 /* Error */, "Composite_projects_may_not_disable_incremental_compilation_6379", "Composite projects may not disable incremental compilation."),
-        Specify_file_to_store_incremental_compilation_information: diag(6380, 3 /* Message */, "Specify_file_to_store_incremental_compilation_information_6380", "Specify file to store incremental compilation information"),
-        Project_0_is_out_of_date_because_output_for_it_was_generated_with_version_1_that_differs_with_current_version_2: diag(6381, 3 /* Message */, "Project_0_is_out_of_date_because_output_for_it_was_generated_with_version_1_that_differs_with_curren_6381", "Project '{0}' is out of date because output for it was generated with version '{1}' that differs with current version '{2}'"),
-        Skipping_build_of_project_0_because_its_dependency_1_was_not_built: diag(6382, 3 /* Message */, "Skipping_build_of_project_0_because_its_dependency_1_was_not_built_6382", "Skipping build of project '{0}' because its dependency '{1}' was not built"),
-        Project_0_can_t_be_built_because_its_dependency_1_was_not_built: diag(6383, 3 /* Message */, "Project_0_can_t_be_built_because_its_dependency_1_was_not_built_6383", "Project '{0}' can't be built because its dependency '{1}' was not built"),
-        Have_recompiles_in_incremental_and_watch_assume_that_changes_within_a_file_will_only_affect_files_directly_depending_on_it: diag(6384, 3 /* Message */, "Have_recompiles_in_incremental_and_watch_assume_that_changes_within_a_file_will_only_affect_files_di_6384", "Have recompiles in '--incremental' and '--watch' assume that changes within a file will only affect files directly depending on it."),
-        _0_is_deprecated: diag(
-          6385,
-          2 /* Suggestion */,
-          "_0_is_deprecated_6385",
-          "'{0}' is deprecated.",
-          /*reportsUnnecessary*/
-          void 0,
-          /*elidedInCompatabilityPyramid*/
-          void 0,
-          /*reportsDeprecated*/
-          true
-        ),
-        Performance_timings_for_diagnostics_or_extendedDiagnostics_are_not_available_in_this_session_A_native_implementation_of_the_Web_Performance_API_could_not_be_found: diag(6386, 3 /* Message */, "Performance_timings_for_diagnostics_or_extendedDiagnostics_are_not_available_in_this_session_A_nativ_6386", "Performance timings for '--diagnostics' or '--extendedDiagnostics' are not available in this session. A native implementation of the Web Performance API could not be found."),
-        The_signature_0_of_1_is_deprecated: diag(
-          6387,
-          2 /* Suggestion */,
-          "The_signature_0_of_1_is_deprecated_6387",
-          "The signature '{0}' of '{1}' is deprecated.",
-          /*reportsUnnecessary*/
-          void 0,
-          /*elidedInCompatabilityPyramid*/
-          void 0,
-          /*reportsDeprecated*/
-          true
-        ),
-        Project_0_is_being_forcibly_rebuilt: diag(6388, 3 /* Message */, "Project_0_is_being_forcibly_rebuilt_6388", "Project '{0}' is being forcibly rebuilt"),
-        Reusing_resolution_of_module_0_from_1_of_old_program_it_was_not_resolved: diag(6389, 3 /* Message */, "Reusing_resolution_of_module_0_from_1_of_old_program_it_was_not_resolved_6389", "Reusing resolution of module '{0}' from '{1}' of old program, it was not resolved."),
-        Reusing_resolution_of_type_reference_directive_0_from_1_of_old_program_it_was_successfully_resolved_to_2: diag(6390, 3 /* Message */, "Reusing_resolution_of_type_reference_directive_0_from_1_of_old_program_it_was_successfully_resolved__6390", "Reusing resolution of type reference directive '{0}' from '{1}' of old program, it was successfully resolved to '{2}'."),
-        Reusing_resolution_of_type_reference_directive_0_from_1_of_old_program_it_was_successfully_resolved_to_2_with_Package_ID_3: diag(6391, 3 /* Message */, "Reusing_resolution_of_type_reference_directive_0_from_1_of_old_program_it_was_successfully_resolved__6391", "Reusing resolution of type reference directive '{0}' from '{1}' of old program, it was successfully resolved to '{2}' with Package ID '{3}'."),
-        Reusing_resolution_of_type_reference_directive_0_from_1_of_old_program_it_was_not_resolved: diag(6392, 3 /* Message */, "Reusing_resolution_of_type_reference_directive_0_from_1_of_old_program_it_was_not_resolved_6392", "Reusing resolution of type reference directive '{0}' from '{1}' of old program, it was not resolved."),
-        Reusing_resolution_of_module_0_from_1_found_in_cache_from_location_2_it_was_successfully_resolved_to_3: diag(6393, 3 /* Message */, "Reusing_resolution_of_module_0_from_1_found_in_cache_from_location_2_it_was_successfully_resolved_to_6393", "Reusing resolution of module '{0}' from '{1}' found in cache from location '{2}', it was successfully resolved to '{3}'."),
-        Reusing_resolution_of_module_0_from_1_found_in_cache_from_location_2_it_was_successfully_resolved_to_3_with_Package_ID_4: diag(6394, 3 /* Message */, "Reusing_resolution_of_module_0_from_1_found_in_cache_from_location_2_it_was_successfully_resolved_to_6394", "Reusing resolution of module '{0}' from '{1}' found in cache from location '{2}', it was successfully resolved to '{3}' with Package ID '{4}'."),
-        Reusing_resolution_of_module_0_from_1_found_in_cache_from_location_2_it_was_not_resolved: diag(6395, 3 /* Message */, "Reusing_resolution_of_module_0_from_1_found_in_cache_from_location_2_it_was_not_resolved_6395", "Reusing resolution of module '{0}' from '{1}' found in cache from location '{2}', it was not resolved."),
-        Reusing_resolution_of_type_reference_directive_0_from_1_found_in_cache_from_location_2_it_was_successfully_resolved_to_3: diag(6396, 3 /* Message */, "Reusing_resolution_of_type_reference_directive_0_from_1_found_in_cache_from_location_2_it_was_succes_6396", "Reusing resolution of type reference directive '{0}' from '{1}' found in cache from location '{2}', it was successfully resolved to '{3}'."),
-        Reusing_resolution_of_type_reference_directive_0_from_1_found_in_cache_from_location_2_it_was_successfully_resolved_to_3_with_Package_ID_4: diag(6397, 3 /* Message */, "Reusing_resolution_of_type_reference_directive_0_from_1_found_in_cache_from_location_2_it_was_succes_6397", "Reusing resolution of type reference directive '{0}' from '{1}' found in cache from location '{2}', it was successfully resolved to '{3}' with Package ID '{4}'."),
-        Reusing_resolution_of_type_reference_directive_0_from_1_found_in_cache_from_location_2_it_was_not_resolved: diag(6398, 3 /* Message */, "Reusing_resolution_of_type_reference_directive_0_from_1_found_in_cache_from_location_2_it_was_not_re_6398", "Reusing resolution of type reference directive '{0}' from '{1}' found in cache from location '{2}', it was not resolved."),
-        Project_0_is_out_of_date_because_buildinfo_file_1_indicates_that_some_of_the_changes_were_not_emitted: diag(6399, 3 /* Message */, "Project_0_is_out_of_date_because_buildinfo_file_1_indicates_that_some_of_the_changes_were_not_emitte_6399", "Project '{0}' is out of date because buildinfo file '{1}' indicates that some of the changes were not emitted"),
-        Project_0_is_up_to_date_but_needs_to_update_timestamps_of_output_files_that_are_older_than_input_files: diag(6400, 3 /* Message */, "Project_0_is_up_to_date_but_needs_to_update_timestamps_of_output_files_that_are_older_than_input_fil_6400", "Project '{0}' is up to date but needs to update timestamps of output files that are older than input files"),
-        Project_0_is_out_of_date_because_there_was_error_reading_file_1: diag(6401, 3 /* Message */, "Project_0_is_out_of_date_because_there_was_error_reading_file_1_6401", "Project '{0}' is out of date because there was error reading file '{1}'"),
-        Resolving_in_0_mode_with_conditions_1: diag(6402, 3 /* Message */, "Resolving_in_0_mode_with_conditions_1_6402", "Resolving in {0} mode with conditions {1}."),
-        Matched_0_condition_1: diag(6403, 3 /* Message */, "Matched_0_condition_1_6403", "Matched '{0}' condition '{1}'."),
-        Using_0_subpath_1_with_target_2: diag(6404, 3 /* Message */, "Using_0_subpath_1_with_target_2_6404", "Using '{0}' subpath '{1}' with target '{2}'."),
-        Saw_non_matching_condition_0: diag(6405, 3 /* Message */, "Saw_non_matching_condition_0_6405", "Saw non-matching condition '{0}'."),
-        Project_0_is_out_of_date_because_buildinfo_file_1_indicates_there_is_change_in_compilerOptions: diag(6406, 3 /* Message */, "Project_0_is_out_of_date_because_buildinfo_file_1_indicates_there_is_change_in_compilerOptions_6406", "Project '{0}' is out of date because buildinfo file '{1}' indicates there is change in compilerOptions"),
-        Allow_imports_to_include_TypeScript_file_extensions_Requires_moduleResolution_bundler_and_either_noEmit_or_emitDeclarationOnly_to_be_set: diag(6407, 3 /* Message */, "Allow_imports_to_include_TypeScript_file_extensions_Requires_moduleResolution_bundler_and_either_noE_6407", "Allow imports to include TypeScript file extensions. Requires '--moduleResolution bundler' and either '--noEmit' or '--emitDeclarationOnly' to be set."),
-        Use_the_package_json_exports_field_when_resolving_package_imports: diag(6408, 3 /* Message */, "Use_the_package_json_exports_field_when_resolving_package_imports_6408", "Use the package.json 'exports' field when resolving package imports."),
-        Use_the_package_json_imports_field_when_resolving_imports: diag(6409, 3 /* Message */, "Use_the_package_json_imports_field_when_resolving_imports_6409", "Use the package.json 'imports' field when resolving imports."),
-        Conditions_to_set_in_addition_to_the_resolver_specific_defaults_when_resolving_imports: diag(6410, 3 /* Message */, "Conditions_to_set_in_addition_to_the_resolver_specific_defaults_when_resolving_imports_6410", "Conditions to set in addition to the resolver-specific defaults when resolving imports."),
-        true_when_moduleResolution_is_node16_nodenext_or_bundler_otherwise_false: diag(6411, 3 /* Message */, "true_when_moduleResolution_is_node16_nodenext_or_bundler_otherwise_false_6411", "`true` when 'moduleResolution' is 'node16', 'nodenext', or 'bundler'; otherwise `false`."),
-        Project_0_is_out_of_date_because_buildinfo_file_1_indicates_that_file_2_was_root_file_of_compilation_but_not_any_more: diag(6412, 3 /* Message */, "Project_0_is_out_of_date_because_buildinfo_file_1_indicates_that_file_2_was_root_file_of_compilation_6412", "Project '{0}' is out of date because buildinfo file '{1}' indicates that file '{2}' was root file of compilation but not any more."),
-        Entering_conditional_exports: diag(6413, 3 /* Message */, "Entering_conditional_exports_6413", "Entering conditional exports."),
-        Resolved_under_condition_0: diag(6414, 3 /* Message */, "Resolved_under_condition_0_6414", "Resolved under condition '{0}'."),
-        Failed_to_resolve_under_condition_0: diag(6415, 3 /* Message */, "Failed_to_resolve_under_condition_0_6415", "Failed to resolve under condition '{0}'."),
-        Exiting_conditional_exports: diag(6416, 3 /* Message */, "Exiting_conditional_exports_6416", "Exiting conditional exports."),
-        The_expected_type_comes_from_property_0_which_is_declared_here_on_type_1: diag(6500, 3 /* Message */, "The_expected_type_comes_from_property_0_which_is_declared_here_on_type_1_6500", "The expected type comes from property '{0}' which is declared here on type '{1}'"),
-        The_expected_type_comes_from_this_index_signature: diag(6501, 3 /* Message */, "The_expected_type_comes_from_this_index_signature_6501", "The expected type comes from this index signature."),
-        The_expected_type_comes_from_the_return_type_of_this_signature: diag(6502, 3 /* Message */, "The_expected_type_comes_from_the_return_type_of_this_signature_6502", "The expected type comes from the return type of this signature."),
-        Print_names_of_files_that_are_part_of_the_compilation_and_then_stop_processing: diag(6503, 3 /* Message */, "Print_names_of_files_that_are_part_of_the_compilation_and_then_stop_processing_6503", "Print names of files that are part of the compilation and then stop processing."),
-        File_0_is_a_JavaScript_file_Did_you_mean_to_enable_the_allowJs_option: diag(6504, 1 /* Error */, "File_0_is_a_JavaScript_file_Did_you_mean_to_enable_the_allowJs_option_6504", "File '{0}' is a JavaScript file. Did you mean to enable the 'allowJs' option?"),
-        Print_names_of_files_and_the_reason_they_are_part_of_the_compilation: diag(6505, 3 /* Message */, "Print_names_of_files_and_the_reason_they_are_part_of_the_compilation_6505", "Print names of files and the reason they are part of the compilation."),
-        Consider_adding_a_declare_modifier_to_this_class: diag(6506, 3 /* Message */, "Consider_adding_a_declare_modifier_to_this_class_6506", "Consider adding a 'declare' modifier to this class."),
-        Allow_JavaScript_files_to_be_a_part_of_your_program_Use_the_checkJS_option_to_get_errors_from_these_files: diag(6600, 3 /* Message */, "Allow_JavaScript_files_to_be_a_part_of_your_program_Use_the_checkJS_option_to_get_errors_from_these__6600", "Allow JavaScript files to be a part of your program. Use the 'checkJS' option to get errors from these files."),
-        Allow_import_x_from_y_when_a_module_doesn_t_have_a_default_export: diag(6601, 3 /* Message */, "Allow_import_x_from_y_when_a_module_doesn_t_have_a_default_export_6601", "Allow 'import x from y' when a module doesn't have a default export."),
-        Allow_accessing_UMD_globals_from_modules: diag(6602, 3 /* Message */, "Allow_accessing_UMD_globals_from_modules_6602", "Allow accessing UMD globals from modules."),
-        Disable_error_reporting_for_unreachable_code: diag(6603, 3 /* Message */, "Disable_error_reporting_for_unreachable_code_6603", "Disable error reporting for unreachable code."),
-        Disable_error_reporting_for_unused_labels: diag(6604, 3 /* Message */, "Disable_error_reporting_for_unused_labels_6604", "Disable error reporting for unused labels."),
-        Ensure_use_strict_is_always_emitted: diag(6605, 3 /* Message */, "Ensure_use_strict_is_always_emitted_6605", "Ensure 'use strict' is always emitted."),
-        Have_recompiles_in_projects_that_use_incremental_and_watch_mode_assume_that_changes_within_a_file_will_only_affect_files_directly_depending_on_it: diag(6606, 3 /* Message */, "Have_recompiles_in_projects_that_use_incremental_and_watch_mode_assume_that_changes_within_a_file_wi_6606", "Have recompiles in projects that use 'incremental' and 'watch' mode assume that changes within a file will only affect files directly depending on it."),
-        Specify_the_base_directory_to_resolve_non_relative_module_names: diag(6607, 3 /* Message */, "Specify_the_base_directory_to_resolve_non_relative_module_names_6607", "Specify the base directory to resolve non-relative module names."),
-        No_longer_supported_In_early_versions_manually_set_the_text_encoding_for_reading_files: diag(6608, 3 /* Message */, "No_longer_supported_In_early_versions_manually_set_the_text_encoding_for_reading_files_6608", "No longer supported. In early versions, manually set the text encoding for reading files."),
-        Enable_error_reporting_in_type_checked_JavaScript_files: diag(6609, 3 /* Message */, "Enable_error_reporting_in_type_checked_JavaScript_files_6609", "Enable error reporting in type-checked JavaScript files."),
-        Enable_constraints_that_allow_a_TypeScript_project_to_be_used_with_project_references: diag(6611, 3 /* Message */, "Enable_constraints_that_allow_a_TypeScript_project_to_be_used_with_project_references_6611", "Enable constraints that allow a TypeScript project to be used with project references."),
-        Generate_d_ts_files_from_TypeScript_and_JavaScript_files_in_your_project: diag(6612, 3 /* Message */, "Generate_d_ts_files_from_TypeScript_and_JavaScript_files_in_your_project_6612", "Generate .d.ts files from TypeScript and JavaScript files in your project."),
-        Specify_the_output_directory_for_generated_declaration_files: diag(6613, 3 /* Message */, "Specify_the_output_directory_for_generated_declaration_files_6613", "Specify the output directory for generated declaration files."),
-        Create_sourcemaps_for_d_ts_files: diag(6614, 3 /* Message */, "Create_sourcemaps_for_d_ts_files_6614", "Create sourcemaps for d.ts files."),
-        Output_compiler_performance_information_after_building: diag(6615, 3 /* Message */, "Output_compiler_performance_information_after_building_6615", "Output compiler performance information after building."),
-        Disables_inference_for_type_acquisition_by_looking_at_filenames_in_a_project: diag(6616, 3 /* Message */, "Disables_inference_for_type_acquisition_by_looking_at_filenames_in_a_project_6616", "Disables inference for type acquisition by looking at filenames in a project."),
-        Reduce_the_number_of_projects_loaded_automatically_by_TypeScript: diag(6617, 3 /* Message */, "Reduce_the_number_of_projects_loaded_automatically_by_TypeScript_6617", "Reduce the number of projects loaded automatically by TypeScript."),
-        Remove_the_20mb_cap_on_total_source_code_size_for_JavaScript_files_in_the_TypeScript_language_server: diag(6618, 3 /* Message */, "Remove_the_20mb_cap_on_total_source_code_size_for_JavaScript_files_in_the_TypeScript_language_server_6618", "Remove the 20mb cap on total source code size for JavaScript files in the TypeScript language server."),
-        Opt_a_project_out_of_multi_project_reference_checking_when_editing: diag(6619, 3 /* Message */, "Opt_a_project_out_of_multi_project_reference_checking_when_editing_6619", "Opt a project out of multi-project reference checking when editing."),
-        Disable_preferring_source_files_instead_of_declaration_files_when_referencing_composite_projects: diag(6620, 3 /* Message */, "Disable_preferring_source_files_instead_of_declaration_files_when_referencing_composite_projects_6620", "Disable preferring source files instead of declaration files when referencing composite projects."),
-        Emit_more_compliant_but_verbose_and_less_performant_JavaScript_for_iteration: diag(6621, 3 /* Message */, "Emit_more_compliant_but_verbose_and_less_performant_JavaScript_for_iteration_6621", "Emit more compliant, but verbose and less performant JavaScript for iteration."),
-        Emit_a_UTF_8_Byte_Order_Mark_BOM_in_the_beginning_of_output_files: diag(6622, 3 /* Message */, "Emit_a_UTF_8_Byte_Order_Mark_BOM_in_the_beginning_of_output_files_6622", "Emit a UTF-8 Byte Order Mark (BOM) in the beginning of output files."),
-        Only_output_d_ts_files_and_not_JavaScript_files: diag(6623, 3 /* Message */, "Only_output_d_ts_files_and_not_JavaScript_files_6623", "Only output d.ts files and not JavaScript files."),
-        Emit_design_type_metadata_for_decorated_declarations_in_source_files: diag(6624, 3 /* Message */, "Emit_design_type_metadata_for_decorated_declarations_in_source_files_6624", "Emit design-type metadata for decorated declarations in source files."),
-        Disable_the_type_acquisition_for_JavaScript_projects: diag(6625, 3 /* Message */, "Disable_the_type_acquisition_for_JavaScript_projects_6625", "Disable the type acquisition for JavaScript projects"),
-        Emit_additional_JavaScript_to_ease_support_for_importing_CommonJS_modules_This_enables_allowSyntheticDefaultImports_for_type_compatibility: diag(6626, 3 /* Message */, "Emit_additional_JavaScript_to_ease_support_for_importing_CommonJS_modules_This_enables_allowSyntheti_6626", "Emit additional JavaScript to ease support for importing CommonJS modules. This enables 'allowSyntheticDefaultImports' for type compatibility."),
-        Filters_results_from_the_include_option: diag(6627, 3 /* Message */, "Filters_results_from_the_include_option_6627", "Filters results from the `include` option."),
-        Remove_a_list_of_directories_from_the_watch_process: diag(6628, 3 /* Message */, "Remove_a_list_of_directories_from_the_watch_process_6628", "Remove a list of directories from the watch process."),
-        Remove_a_list_of_files_from_the_watch_mode_s_processing: diag(6629, 3 /* Message */, "Remove_a_list_of_files_from_the_watch_mode_s_processing_6629", "Remove a list of files from the watch mode's processing."),
-        Enable_experimental_support_for_legacy_experimental_decorators: diag(6630, 3 /* Message */, "Enable_experimental_support_for_legacy_experimental_decorators_6630", "Enable experimental support for legacy experimental decorators."),
-        Print_files_read_during_the_compilation_including_why_it_was_included: diag(6631, 3 /* Message */, "Print_files_read_during_the_compilation_including_why_it_was_included_6631", "Print files read during the compilation including why it was included."),
-        Output_more_detailed_compiler_performance_information_after_building: diag(6632, 3 /* Message */, "Output_more_detailed_compiler_performance_information_after_building_6632", "Output more detailed compiler performance information after building."),
-        Specify_one_or_more_path_or_node_module_references_to_base_configuration_files_from_which_settings_are_inherited: diag(6633, 3 /* Message */, "Specify_one_or_more_path_or_node_module_references_to_base_configuration_files_from_which_settings_a_6633", "Specify one or more path or node module references to base configuration files from which settings are inherited."),
-        Specify_what_approach_the_watcher_should_use_if_the_system_runs_out_of_native_file_watchers: diag(6634, 3 /* Message */, "Specify_what_approach_the_watcher_should_use_if_the_system_runs_out_of_native_file_watchers_6634", "Specify what approach the watcher should use if the system runs out of native file watchers."),
-        Include_a_list_of_files_This_does_not_support_glob_patterns_as_opposed_to_include: diag(6635, 3 /* Message */, "Include_a_list_of_files_This_does_not_support_glob_patterns_as_opposed_to_include_6635", "Include a list of files. This does not support glob patterns, as opposed to `include`."),
-        Build_all_projects_including_those_that_appear_to_be_up_to_date: diag(6636, 3 /* Message */, "Build_all_projects_including_those_that_appear_to_be_up_to_date_6636", "Build all projects, including those that appear to be up to date."),
-        Ensure_that_casing_is_correct_in_imports: diag(6637, 3 /* Message */, "Ensure_that_casing_is_correct_in_imports_6637", "Ensure that casing is correct in imports."),
-        Emit_a_v8_CPU_profile_of_the_compiler_run_for_debugging: diag(6638, 3 /* Message */, "Emit_a_v8_CPU_profile_of_the_compiler_run_for_debugging_6638", "Emit a v8 CPU profile of the compiler run for debugging."),
-        Allow_importing_helper_functions_from_tslib_once_per_project_instead_of_including_them_per_file: diag(6639, 3 /* Message */, "Allow_importing_helper_functions_from_tslib_once_per_project_instead_of_including_them_per_file_6639", "Allow importing helper functions from tslib once per project, instead of including them per-file."),
-        Specify_a_list_of_glob_patterns_that_match_files_to_be_included_in_compilation: diag(6641, 3 /* Message */, "Specify_a_list_of_glob_patterns_that_match_files_to_be_included_in_compilation_6641", "Specify a list of glob patterns that match files to be included in compilation."),
-        Save_tsbuildinfo_files_to_allow_for_incremental_compilation_of_projects: diag(6642, 3 /* Message */, "Save_tsbuildinfo_files_to_allow_for_incremental_compilation_of_projects_6642", "Save .tsbuildinfo files to allow for incremental compilation of projects."),
-        Include_sourcemap_files_inside_the_emitted_JavaScript: diag(6643, 3 /* Message */, "Include_sourcemap_files_inside_the_emitted_JavaScript_6643", "Include sourcemap files inside the emitted JavaScript."),
-        Include_source_code_in_the_sourcemaps_inside_the_emitted_JavaScript: diag(6644, 3 /* Message */, "Include_source_code_in_the_sourcemaps_inside_the_emitted_JavaScript_6644", "Include source code in the sourcemaps inside the emitted JavaScript."),
-        Ensure_that_each_file_can_be_safely_transpiled_without_relying_on_other_imports: diag(6645, 3 /* Message */, "Ensure_that_each_file_can_be_safely_transpiled_without_relying_on_other_imports_6645", "Ensure that each file can be safely transpiled without relying on other imports."),
-        Specify_what_JSX_code_is_generated: diag(6646, 3 /* Message */, "Specify_what_JSX_code_is_generated_6646", "Specify what JSX code is generated."),
-        Specify_the_JSX_factory_function_used_when_targeting_React_JSX_emit_e_g_React_createElement_or_h: diag(6647, 3 /* Message */, "Specify_the_JSX_factory_function_used_when_targeting_React_JSX_emit_e_g_React_createElement_or_h_6647", "Specify the JSX factory function used when targeting React JSX emit, e.g. 'React.createElement' or 'h'."),
-        Specify_the_JSX_Fragment_reference_used_for_fragments_when_targeting_React_JSX_emit_e_g_React_Fragment_or_Fragment: diag(6648, 3 /* Message */, "Specify_the_JSX_Fragment_reference_used_for_fragments_when_targeting_React_JSX_emit_e_g_React_Fragme_6648", "Specify the JSX Fragment reference used for fragments when targeting React JSX emit e.g. 'React.Fragment' or 'Fragment'."),
-        Specify_module_specifier_used_to_import_the_JSX_factory_functions_when_using_jsx_Colon_react_jsx_Asterisk: diag(6649, 3 /* Message */, "Specify_module_specifier_used_to_import_the_JSX_factory_functions_when_using_jsx_Colon_react_jsx_Ast_6649", "Specify module specifier used to import the JSX factory functions when using 'jsx: react-jsx*'."),
-        Make_keyof_only_return_strings_instead_of_string_numbers_or_symbols_Legacy_option: diag(6650, 3 /* Message */, "Make_keyof_only_return_strings_instead_of_string_numbers_or_symbols_Legacy_option_6650", "Make keyof only return strings instead of string, numbers or symbols. Legacy option."),
-        Specify_a_set_of_bundled_library_declaration_files_that_describe_the_target_runtime_environment: diag(6651, 3 /* Message */, "Specify_a_set_of_bundled_library_declaration_files_that_describe_the_target_runtime_environment_6651", "Specify a set of bundled library declaration files that describe the target runtime environment."),
-        Print_the_names_of_emitted_files_after_a_compilation: diag(6652, 3 /* Message */, "Print_the_names_of_emitted_files_after_a_compilation_6652", "Print the names of emitted files after a compilation."),
-        Print_all_of_the_files_read_during_the_compilation: diag(6653, 3 /* Message */, "Print_all_of_the_files_read_during_the_compilation_6653", "Print all of the files read during the compilation."),
-        Set_the_language_of_the_messaging_from_TypeScript_This_does_not_affect_emit: diag(6654, 3 /* Message */, "Set_the_language_of_the_messaging_from_TypeScript_This_does_not_affect_emit_6654", "Set the language of the messaging from TypeScript. This does not affect emit."),
-        Specify_the_location_where_debugger_should_locate_map_files_instead_of_generated_locations: diag(6655, 3 /* Message */, "Specify_the_location_where_debugger_should_locate_map_files_instead_of_generated_locations_6655", "Specify the location where debugger should locate map files instead of generated locations."),
-        Specify_the_maximum_folder_depth_used_for_checking_JavaScript_files_from_node_modules_Only_applicable_with_allowJs: diag(6656, 3 /* Message */, "Specify_the_maximum_folder_depth_used_for_checking_JavaScript_files_from_node_modules_Only_applicabl_6656", "Specify the maximum folder depth used for checking JavaScript files from 'node_modules'. Only applicable with 'allowJs'."),
-        Specify_what_module_code_is_generated: diag(6657, 3 /* Message */, "Specify_what_module_code_is_generated_6657", "Specify what module code is generated."),
-        Specify_how_TypeScript_looks_up_a_file_from_a_given_module_specifier: diag(6658, 3 /* Message */, "Specify_how_TypeScript_looks_up_a_file_from_a_given_module_specifier_6658", "Specify how TypeScript looks up a file from a given module specifier."),
-        Set_the_newline_character_for_emitting_files: diag(6659, 3 /* Message */, "Set_the_newline_character_for_emitting_files_6659", "Set the newline character for emitting files."),
-        Disable_emitting_files_from_a_compilation: diag(6660, 3 /* Message */, "Disable_emitting_files_from_a_compilation_6660", "Disable emitting files from a compilation."),
-        Disable_generating_custom_helper_functions_like_extends_in_compiled_output: diag(6661, 3 /* Message */, "Disable_generating_custom_helper_functions_like_extends_in_compiled_output_6661", "Disable generating custom helper functions like '__extends' in compiled output."),
-        Disable_emitting_files_if_any_type_checking_errors_are_reported: diag(6662, 3 /* Message */, "Disable_emitting_files_if_any_type_checking_errors_are_reported_6662", "Disable emitting files if any type checking errors are reported."),
-        Disable_truncating_types_in_error_messages: diag(6663, 3 /* Message */, "Disable_truncating_types_in_error_messages_6663", "Disable truncating types in error messages."),
-        Enable_error_reporting_for_fallthrough_cases_in_switch_statements: diag(6664, 3 /* Message */, "Enable_error_reporting_for_fallthrough_cases_in_switch_statements_6664", "Enable error reporting for fallthrough cases in switch statements."),
-        Enable_error_reporting_for_expressions_and_declarations_with_an_implied_any_type: diag(6665, 3 /* Message */, "Enable_error_reporting_for_expressions_and_declarations_with_an_implied_any_type_6665", "Enable error reporting for expressions and declarations with an implied 'any' type."),
-        Ensure_overriding_members_in_derived_classes_are_marked_with_an_override_modifier: diag(6666, 3 /* Message */, "Ensure_overriding_members_in_derived_classes_are_marked_with_an_override_modifier_6666", "Ensure overriding members in derived classes are marked with an override modifier."),
-        Enable_error_reporting_for_codepaths_that_do_not_explicitly_return_in_a_function: diag(6667, 3 /* Message */, "Enable_error_reporting_for_codepaths_that_do_not_explicitly_return_in_a_function_6667", "Enable error reporting for codepaths that do not explicitly return in a function."),
-        Enable_error_reporting_when_this_is_given_the_type_any: diag(6668, 3 /* Message */, "Enable_error_reporting_when_this_is_given_the_type_any_6668", "Enable error reporting when 'this' is given the type 'any'."),
-        Disable_adding_use_strict_directives_in_emitted_JavaScript_files: diag(6669, 3 /* Message */, "Disable_adding_use_strict_directives_in_emitted_JavaScript_files_6669", "Disable adding 'use strict' directives in emitted JavaScript files."),
-        Disable_including_any_library_files_including_the_default_lib_d_ts: diag(6670, 3 /* Message */, "Disable_including_any_library_files_including_the_default_lib_d_ts_6670", "Disable including any library files, including the default lib.d.ts."),
-        Enforces_using_indexed_accessors_for_keys_declared_using_an_indexed_type: diag(6671, 3 /* Message */, "Enforces_using_indexed_accessors_for_keys_declared_using_an_indexed_type_6671", "Enforces using indexed accessors for keys declared using an indexed type."),
-        Disallow_import_s_require_s_or_reference_s_from_expanding_the_number_of_files_TypeScript_should_add_to_a_project: diag(6672, 3 /* Message */, "Disallow_import_s_require_s_or_reference_s_from_expanding_the_number_of_files_TypeScript_should_add__6672", "Disallow 'import's, 'require's or ''s from expanding the number of files TypeScript should add to a project."),
-        Disable_strict_checking_of_generic_signatures_in_function_types: diag(6673, 3 /* Message */, "Disable_strict_checking_of_generic_signatures_in_function_types_6673", "Disable strict checking of generic signatures in function types."),
-        Add_undefined_to_a_type_when_accessed_using_an_index: diag(6674, 3 /* Message */, "Add_undefined_to_a_type_when_accessed_using_an_index_6674", "Add 'undefined' to a type when accessed using an index."),
-        Enable_error_reporting_when_local_variables_aren_t_read: diag(6675, 3 /* Message */, "Enable_error_reporting_when_local_variables_aren_t_read_6675", "Enable error reporting when local variables aren't read."),
-        Raise_an_error_when_a_function_parameter_isn_t_read: diag(6676, 3 /* Message */, "Raise_an_error_when_a_function_parameter_isn_t_read_6676", "Raise an error when a function parameter isn't read."),
-        Deprecated_setting_Use_outFile_instead: diag(6677, 3 /* Message */, "Deprecated_setting_Use_outFile_instead_6677", "Deprecated setting. Use 'outFile' instead."),
-        Specify_an_output_folder_for_all_emitted_files: diag(6678, 3 /* Message */, "Specify_an_output_folder_for_all_emitted_files_6678", "Specify an output folder for all emitted files."),
-        Specify_a_file_that_bundles_all_outputs_into_one_JavaScript_file_If_declaration_is_true_also_designates_a_file_that_bundles_all_d_ts_output: diag(6679, 3 /* Message */, "Specify_a_file_that_bundles_all_outputs_into_one_JavaScript_file_If_declaration_is_true_also_designa_6679", "Specify a file that bundles all outputs into one JavaScript file. If 'declaration' is true, also designates a file that bundles all .d.ts output."),
-        Specify_a_set_of_entries_that_re_map_imports_to_additional_lookup_locations: diag(6680, 3 /* Message */, "Specify_a_set_of_entries_that_re_map_imports_to_additional_lookup_locations_6680", "Specify a set of entries that re-map imports to additional lookup locations."),
-        Specify_a_list_of_language_service_plugins_to_include: diag(6681, 3 /* Message */, "Specify_a_list_of_language_service_plugins_to_include_6681", "Specify a list of language service plugins to include."),
-        Disable_erasing_const_enum_declarations_in_generated_code: diag(6682, 3 /* Message */, "Disable_erasing_const_enum_declarations_in_generated_code_6682", "Disable erasing 'const enum' declarations in generated code."),
-        Disable_resolving_symlinks_to_their_realpath_This_correlates_to_the_same_flag_in_node: diag(6683, 3 /* Message */, "Disable_resolving_symlinks_to_their_realpath_This_correlates_to_the_same_flag_in_node_6683", "Disable resolving symlinks to their realpath. This correlates to the same flag in node."),
-        Disable_wiping_the_console_in_watch_mode: diag(6684, 3 /* Message */, "Disable_wiping_the_console_in_watch_mode_6684", "Disable wiping the console in watch mode."),
-        Enable_color_and_formatting_in_TypeScript_s_output_to_make_compiler_errors_easier_to_read: diag(6685, 3 /* Message */, "Enable_color_and_formatting_in_TypeScript_s_output_to_make_compiler_errors_easier_to_read_6685", "Enable color and formatting in TypeScript's output to make compiler errors easier to read."),
-        Specify_the_object_invoked_for_createElement_This_only_applies_when_targeting_react_JSX_emit: diag(6686, 3 /* Message */, "Specify_the_object_invoked_for_createElement_This_only_applies_when_targeting_react_JSX_emit_6686", "Specify the object invoked for 'createElement'. This only applies when targeting 'react' JSX emit."),
-        Specify_an_array_of_objects_that_specify_paths_for_projects_Used_in_project_references: diag(6687, 3 /* Message */, "Specify_an_array_of_objects_that_specify_paths_for_projects_Used_in_project_references_6687", "Specify an array of objects that specify paths for projects. Used in project references."),
-        Disable_emitting_comments: diag(6688, 3 /* Message */, "Disable_emitting_comments_6688", "Disable emitting comments."),
-        Enable_importing_json_files: diag(6689, 3 /* Message */, "Enable_importing_json_files_6689", "Enable importing .json files."),
-        Specify_the_root_folder_within_your_source_files: diag(6690, 3 /* Message */, "Specify_the_root_folder_within_your_source_files_6690", "Specify the root folder within your source files."),
-        Allow_multiple_folders_to_be_treated_as_one_when_resolving_modules: diag(6691, 3 /* Message */, "Allow_multiple_folders_to_be_treated_as_one_when_resolving_modules_6691", "Allow multiple folders to be treated as one when resolving modules."),
-        Skip_type_checking_d_ts_files_that_are_included_with_TypeScript: diag(6692, 3 /* Message */, "Skip_type_checking_d_ts_files_that_are_included_with_TypeScript_6692", "Skip type checking .d.ts files that are included with TypeScript."),
-        Skip_type_checking_all_d_ts_files: diag(6693, 3 /* Message */, "Skip_type_checking_all_d_ts_files_6693", "Skip type checking all .d.ts files."),
-        Create_source_map_files_for_emitted_JavaScript_files: diag(6694, 3 /* Message */, "Create_source_map_files_for_emitted_JavaScript_files_6694", "Create source map files for emitted JavaScript files."),
-        Specify_the_root_path_for_debuggers_to_find_the_reference_source_code: diag(6695, 3 /* Message */, "Specify_the_root_path_for_debuggers_to_find_the_reference_source_code_6695", "Specify the root path for debuggers to find the reference source code."),
-        Check_that_the_arguments_for_bind_call_and_apply_methods_match_the_original_function: diag(6697, 3 /* Message */, "Check_that_the_arguments_for_bind_call_and_apply_methods_match_the_original_function_6697", "Check that the arguments for 'bind', 'call', and 'apply' methods match the original function."),
-        When_assigning_functions_check_to_ensure_parameters_and_the_return_values_are_subtype_compatible: diag(6698, 3 /* Message */, "When_assigning_functions_check_to_ensure_parameters_and_the_return_values_are_subtype_compatible_6698", "When assigning functions, check to ensure parameters and the return values are subtype-compatible."),
-        When_type_checking_take_into_account_null_and_undefined: diag(6699, 3 /* Message */, "When_type_checking_take_into_account_null_and_undefined_6699", "When type checking, take into account 'null' and 'undefined'."),
-        Check_for_class_properties_that_are_declared_but_not_set_in_the_constructor: diag(6700, 3 /* Message */, "Check_for_class_properties_that_are_declared_but_not_set_in_the_constructor_6700", "Check for class properties that are declared but not set in the constructor."),
-        Disable_emitting_declarations_that_have_internal_in_their_JSDoc_comments: diag(6701, 3 /* Message */, "Disable_emitting_declarations_that_have_internal_in_their_JSDoc_comments_6701", "Disable emitting declarations that have '@internal' in their JSDoc comments."),
-        Disable_reporting_of_excess_property_errors_during_the_creation_of_object_literals: diag(6702, 3 /* Message */, "Disable_reporting_of_excess_property_errors_during_the_creation_of_object_literals_6702", "Disable reporting of excess property errors during the creation of object literals."),
-        Suppress_noImplicitAny_errors_when_indexing_objects_that_lack_index_signatures: diag(6703, 3 /* Message */, "Suppress_noImplicitAny_errors_when_indexing_objects_that_lack_index_signatures_6703", "Suppress 'noImplicitAny' errors when indexing objects that lack index signatures."),
-        Synchronously_call_callbacks_and_update_the_state_of_directory_watchers_on_platforms_that_don_t_support_recursive_watching_natively: diag(6704, 3 /* Message */, "Synchronously_call_callbacks_and_update_the_state_of_directory_watchers_on_platforms_that_don_t_supp_6704", "Synchronously call callbacks and update the state of directory watchers on platforms that don`t support recursive watching natively."),
-        Set_the_JavaScript_language_version_for_emitted_JavaScript_and_include_compatible_library_declarations: diag(6705, 3 /* Message */, "Set_the_JavaScript_language_version_for_emitted_JavaScript_and_include_compatible_library_declaratio_6705", "Set the JavaScript language version for emitted JavaScript and include compatible library declarations."),
-        Log_paths_used_during_the_moduleResolution_process: diag(6706, 3 /* Message */, "Log_paths_used_during_the_moduleResolution_process_6706", "Log paths used during the 'moduleResolution' process."),
-        Specify_the_path_to_tsbuildinfo_incremental_compilation_file: diag(6707, 3 /* Message */, "Specify_the_path_to_tsbuildinfo_incremental_compilation_file_6707", "Specify the path to .tsbuildinfo incremental compilation file."),
-        Specify_options_for_automatic_acquisition_of_declaration_files: diag(6709, 3 /* Message */, "Specify_options_for_automatic_acquisition_of_declaration_files_6709", "Specify options for automatic acquisition of declaration files."),
-        Specify_multiple_folders_that_act_like_Slashnode_modules_Slash_types: diag(6710, 3 /* Message */, "Specify_multiple_folders_that_act_like_Slashnode_modules_Slash_types_6710", "Specify multiple folders that act like './node_modules/@types'."),
-        Specify_type_package_names_to_be_included_without_being_referenced_in_a_source_file: diag(6711, 3 /* Message */, "Specify_type_package_names_to_be_included_without_being_referenced_in_a_source_file_6711", "Specify type package names to be included without being referenced in a source file."),
-        Emit_ECMAScript_standard_compliant_class_fields: diag(6712, 3 /* Message */, "Emit_ECMAScript_standard_compliant_class_fields_6712", "Emit ECMAScript-standard-compliant class fields."),
-        Enable_verbose_logging: diag(6713, 3 /* Message */, "Enable_verbose_logging_6713", "Enable verbose logging."),
-        Specify_how_directories_are_watched_on_systems_that_lack_recursive_file_watching_functionality: diag(6714, 3 /* Message */, "Specify_how_directories_are_watched_on_systems_that_lack_recursive_file_watching_functionality_6714", "Specify how directories are watched on systems that lack recursive file-watching functionality."),
-        Specify_how_the_TypeScript_watch_mode_works: diag(6715, 3 /* Message */, "Specify_how_the_TypeScript_watch_mode_works_6715", "Specify how the TypeScript watch mode works."),
-        Require_undeclared_properties_from_index_signatures_to_use_element_accesses: diag(6717, 3 /* Message */, "Require_undeclared_properties_from_index_signatures_to_use_element_accesses_6717", "Require undeclared properties from index signatures to use element accesses."),
-        Specify_emit_Slashchecking_behavior_for_imports_that_are_only_used_for_types: diag(6718, 3 /* Message */, "Specify_emit_Slashchecking_behavior_for_imports_that_are_only_used_for_types_6718", "Specify emit/checking behavior for imports that are only used for types."),
-        Default_catch_clause_variables_as_unknown_instead_of_any: diag(6803, 3 /* Message */, "Default_catch_clause_variables_as_unknown_instead_of_any_6803", "Default catch clause variables as 'unknown' instead of 'any'."),
-        Do_not_transform_or_elide_any_imports_or_exports_not_marked_as_type_only_ensuring_they_are_written_in_the_output_file_s_format_based_on_the_module_setting: diag(6804, 3 /* Message */, "Do_not_transform_or_elide_any_imports_or_exports_not_marked_as_type_only_ensuring_they_are_written_i_6804", "Do not transform or elide any imports or exports not marked as type-only, ensuring they are written in the output file's format based on the 'module' setting."),
-        one_of_Colon: diag(6900, 3 /* Message */, "one_of_Colon_6900", "one of:"),
-        one_or_more_Colon: diag(6901, 3 /* Message */, "one_or_more_Colon_6901", "one or more:"),
-        type_Colon: diag(6902, 3 /* Message */, "type_Colon_6902", "type:"),
-        default_Colon: diag(6903, 3 /* Message */, "default_Colon_6903", "default:"),
-        module_system_or_esModuleInterop: diag(6904, 3 /* Message */, "module_system_or_esModuleInterop_6904", 'module === "system" or esModuleInterop'),
-        false_unless_strict_is_set: diag(6905, 3 /* Message */, "false_unless_strict_is_set_6905", "`false`, unless `strict` is set"),
-        false_unless_composite_is_set: diag(6906, 3 /* Message */, "false_unless_composite_is_set_6906", "`false`, unless `composite` is set"),
-        node_modules_bower_components_jspm_packages_plus_the_value_of_outDir_if_one_is_specified: diag(6907, 3 /* Message */, "node_modules_bower_components_jspm_packages_plus_the_value_of_outDir_if_one_is_specified_6907", '`["node_modules", "bower_components", "jspm_packages"]`, plus the value of `outDir` if one is specified.'),
-        if_files_is_specified_otherwise_Asterisk_Asterisk_Slash_Asterisk: diag(6908, 3 /* Message */, "if_files_is_specified_otherwise_Asterisk_Asterisk_Slash_Asterisk_6908", '`[]` if `files` is specified, otherwise `["**/*"]`'),
-        true_if_composite_false_otherwise: diag(6909, 3 /* Message */, "true_if_composite_false_otherwise_6909", "`true` if `composite`, `false` otherwise"),
-        module_AMD_or_UMD_or_System_or_ES6_then_Classic_Otherwise_Node: diag(69010, 3 /* Message */, "module_AMD_or_UMD_or_System_or_ES6_then_Classic_Otherwise_Node_69010", "module === `AMD` or `UMD` or `System` or `ES6`, then `Classic`, Otherwise `Node`"),
-        Computed_from_the_list_of_input_files: diag(6911, 3 /* Message */, "Computed_from_the_list_of_input_files_6911", "Computed from the list of input files"),
-        Platform_specific: diag(6912, 3 /* Message */, "Platform_specific_6912", "Platform specific"),
-        You_can_learn_about_all_of_the_compiler_options_at_0: diag(6913, 3 /* Message */, "You_can_learn_about_all_of_the_compiler_options_at_0_6913", "You can learn about all of the compiler options at {0}"),
-        Including_watch_w_will_start_watching_the_current_project_for_the_file_changes_Once_set_you_can_config_watch_mode_with_Colon: diag(6914, 3 /* Message */, "Including_watch_w_will_start_watching_the_current_project_for_the_file_changes_Once_set_you_can_conf_6914", "Including --watch, -w will start watching the current project for the file changes. Once set, you can config watch mode with:"),
-        Using_build_b_will_make_tsc_behave_more_like_a_build_orchestrator_than_a_compiler_This_is_used_to_trigger_building_composite_projects_which_you_can_learn_more_about_at_0: diag(6915, 3 /* Message */, "Using_build_b_will_make_tsc_behave_more_like_a_build_orchestrator_than_a_compiler_This_is_used_to_tr_6915", "Using --build, -b will make tsc behave more like a build orchestrator than a compiler. This is used to trigger building composite projects which you can learn more about at {0}"),
-        COMMON_COMMANDS: diag(6916, 3 /* Message */, "COMMON_COMMANDS_6916", "COMMON COMMANDS"),
-        ALL_COMPILER_OPTIONS: diag(6917, 3 /* Message */, "ALL_COMPILER_OPTIONS_6917", "ALL COMPILER OPTIONS"),
-        WATCH_OPTIONS: diag(6918, 3 /* Message */, "WATCH_OPTIONS_6918", "WATCH OPTIONS"),
-        BUILD_OPTIONS: diag(6919, 3 /* Message */, "BUILD_OPTIONS_6919", "BUILD OPTIONS"),
-        COMMON_COMPILER_OPTIONS: diag(6920, 3 /* Message */, "COMMON_COMPILER_OPTIONS_6920", "COMMON COMPILER OPTIONS"),
-        COMMAND_LINE_FLAGS: diag(6921, 3 /* Message */, "COMMAND_LINE_FLAGS_6921", "COMMAND LINE FLAGS"),
-        tsc_Colon_The_TypeScript_Compiler: diag(6922, 3 /* Message */, "tsc_Colon_The_TypeScript_Compiler_6922", "tsc: The TypeScript Compiler"),
-        Compiles_the_current_project_tsconfig_json_in_the_working_directory: diag(6923, 3 /* Message */, "Compiles_the_current_project_tsconfig_json_in_the_working_directory_6923", "Compiles the current project (tsconfig.json in the working directory.)"),
-        Ignoring_tsconfig_json_compiles_the_specified_files_with_default_compiler_options: diag(6924, 3 /* Message */, "Ignoring_tsconfig_json_compiles_the_specified_files_with_default_compiler_options_6924", "Ignoring tsconfig.json, compiles the specified files with default compiler options."),
-        Build_a_composite_project_in_the_working_directory: diag(6925, 3 /* Message */, "Build_a_composite_project_in_the_working_directory_6925", "Build a composite project in the working directory."),
-        Creates_a_tsconfig_json_with_the_recommended_settings_in_the_working_directory: diag(6926, 3 /* Message */, "Creates_a_tsconfig_json_with_the_recommended_settings_in_the_working_directory_6926", "Creates a tsconfig.json with the recommended settings in the working directory."),
-        Compiles_the_TypeScript_project_located_at_the_specified_path: diag(6927, 3 /* Message */, "Compiles_the_TypeScript_project_located_at_the_specified_path_6927", "Compiles the TypeScript project located at the specified path."),
-        An_expanded_version_of_this_information_showing_all_possible_compiler_options: diag(6928, 3 /* Message */, "An_expanded_version_of_this_information_showing_all_possible_compiler_options_6928", "An expanded version of this information, showing all possible compiler options"),
-        Compiles_the_current_project_with_additional_settings: diag(6929, 3 /* Message */, "Compiles_the_current_project_with_additional_settings_6929", "Compiles the current project, with additional settings."),
-        true_for_ES2022_and_above_including_ESNext: diag(6930, 3 /* Message */, "true_for_ES2022_and_above_including_ESNext_6930", "`true` for ES2022 and above, including ESNext."),
-        List_of_file_name_suffixes_to_search_when_resolving_a_module: diag(6931, 1 /* Error */, "List_of_file_name_suffixes_to_search_when_resolving_a_module_6931", "List of file name suffixes to search when resolving a module."),
-        Variable_0_implicitly_has_an_1_type: diag(7005, 1 /* Error */, "Variable_0_implicitly_has_an_1_type_7005", "Variable '{0}' implicitly has an '{1}' type."),
-        Parameter_0_implicitly_has_an_1_type: diag(7006, 1 /* Error */, "Parameter_0_implicitly_has_an_1_type_7006", "Parameter '{0}' implicitly has an '{1}' type."),
-        Member_0_implicitly_has_an_1_type: diag(7008, 1 /* Error */, "Member_0_implicitly_has_an_1_type_7008", "Member '{0}' implicitly has an '{1}' type."),
-        new_expression_whose_target_lacks_a_construct_signature_implicitly_has_an_any_type: diag(7009, 1 /* Error */, "new_expression_whose_target_lacks_a_construct_signature_implicitly_has_an_any_type_7009", "'new' expression, whose target lacks a construct signature, implicitly has an 'any' type."),
-        _0_which_lacks_return_type_annotation_implicitly_has_an_1_return_type: diag(7010, 1 /* Error */, "_0_which_lacks_return_type_annotation_implicitly_has_an_1_return_type_7010", "'{0}', which lacks return-type annotation, implicitly has an '{1}' return type."),
-        Function_expression_which_lacks_return_type_annotation_implicitly_has_an_0_return_type: diag(7011, 1 /* Error */, "Function_expression_which_lacks_return_type_annotation_implicitly_has_an_0_return_type_7011", "Function expression, which lacks return-type annotation, implicitly has an '{0}' return type."),
-        This_overload_implicitly_returns_the_type_0_because_it_lacks_a_return_type_annotation: diag(7012, 1 /* Error */, "This_overload_implicitly_returns_the_type_0_because_it_lacks_a_return_type_annotation_7012", "This overload implicitly returns the type '{0}' because it lacks a return type annotation."),
-        Construct_signature_which_lacks_return_type_annotation_implicitly_has_an_any_return_type: diag(7013, 1 /* Error */, "Construct_signature_which_lacks_return_type_annotation_implicitly_has_an_any_return_type_7013", "Construct signature, which lacks return-type annotation, implicitly has an 'any' return type."),
-        Function_type_which_lacks_return_type_annotation_implicitly_has_an_0_return_type: diag(7014, 1 /* Error */, "Function_type_which_lacks_return_type_annotation_implicitly_has_an_0_return_type_7014", "Function type, which lacks return-type annotation, implicitly has an '{0}' return type."),
-        Element_implicitly_has_an_any_type_because_index_expression_is_not_of_type_number: diag(7015, 1 /* Error */, "Element_implicitly_has_an_any_type_because_index_expression_is_not_of_type_number_7015", "Element implicitly has an 'any' type because index expression is not of type 'number'."),
-        Could_not_find_a_declaration_file_for_module_0_1_implicitly_has_an_any_type: diag(7016, 1 /* Error */, "Could_not_find_a_declaration_file_for_module_0_1_implicitly_has_an_any_type_7016", "Could not find a declaration file for module '{0}'. '{1}' implicitly has an 'any' type."),
-        Element_implicitly_has_an_any_type_because_type_0_has_no_index_signature: diag(7017, 1 /* Error */, "Element_implicitly_has_an_any_type_because_type_0_has_no_index_signature_7017", "Element implicitly has an 'any' type because type '{0}' has no index signature."),
-        Object_literal_s_property_0_implicitly_has_an_1_type: diag(7018, 1 /* Error */, "Object_literal_s_property_0_implicitly_has_an_1_type_7018", "Object literal's property '{0}' implicitly has an '{1}' type."),
-        Rest_parameter_0_implicitly_has_an_any_type: diag(7019, 1 /* Error */, "Rest_parameter_0_implicitly_has_an_any_type_7019", "Rest parameter '{0}' implicitly has an 'any[]' type."),
-        Call_signature_which_lacks_return_type_annotation_implicitly_has_an_any_return_type: diag(7020, 1 /* Error */, "Call_signature_which_lacks_return_type_annotation_implicitly_has_an_any_return_type_7020", "Call signature, which lacks return-type annotation, implicitly has an 'any' return type."),
-        _0_implicitly_has_type_any_because_it_does_not_have_a_type_annotation_and_is_referenced_directly_or_indirectly_in_its_own_initializer: diag(7022, 1 /* Error */, "_0_implicitly_has_type_any_because_it_does_not_have_a_type_annotation_and_is_referenced_directly_or__7022", "'{0}' implicitly has type 'any' because it does not have a type annotation and is referenced directly or indirectly in its own initializer."),
-        _0_implicitly_has_return_type_any_because_it_does_not_have_a_return_type_annotation_and_is_referenced_directly_or_indirectly_in_one_of_its_return_expressions: diag(7023, 1 /* Error */, "_0_implicitly_has_return_type_any_because_it_does_not_have_a_return_type_annotation_and_is_reference_7023", "'{0}' implicitly has return type 'any' because it does not have a return type annotation and is referenced directly or indirectly in one of its return expressions."),
-        Function_implicitly_has_return_type_any_because_it_does_not_have_a_return_type_annotation_and_is_referenced_directly_or_indirectly_in_one_of_its_return_expressions: diag(7024, 1 /* Error */, "Function_implicitly_has_return_type_any_because_it_does_not_have_a_return_type_annotation_and_is_ref_7024", "Function implicitly has return type 'any' because it does not have a return type annotation and is referenced directly or indirectly in one of its return expressions."),
-        Generator_implicitly_has_yield_type_0_because_it_does_not_yield_any_values_Consider_supplying_a_return_type_annotation: diag(7025, 1 /* Error */, "Generator_implicitly_has_yield_type_0_because_it_does_not_yield_any_values_Consider_supplying_a_retu_7025", "Generator implicitly has yield type '{0}' because it does not yield any values. Consider supplying a return type annotation."),
-        JSX_element_implicitly_has_type_any_because_no_interface_JSX_0_exists: diag(7026, 1 /* Error */, "JSX_element_implicitly_has_type_any_because_no_interface_JSX_0_exists_7026", "JSX element implicitly has type 'any' because no interface 'JSX.{0}' exists."),
-        Unreachable_code_detected: diag(
-          7027,
-          1 /* Error */,
-          "Unreachable_code_detected_7027",
-          "Unreachable code detected.",
-          /*reportsUnnecessary*/
-          true
-        ),
-        Unused_label: diag(
-          7028,
-          1 /* Error */,
-          "Unused_label_7028",
-          "Unused label.",
-          /*reportsUnnecessary*/
-          true
-        ),
-        Fallthrough_case_in_switch: diag(7029, 1 /* Error */, "Fallthrough_case_in_switch_7029", "Fallthrough case in switch."),
-        Not_all_code_paths_return_a_value: diag(7030, 1 /* Error */, "Not_all_code_paths_return_a_value_7030", "Not all code paths return a value."),
-        Binding_element_0_implicitly_has_an_1_type: diag(7031, 1 /* Error */, "Binding_element_0_implicitly_has_an_1_type_7031", "Binding element '{0}' implicitly has an '{1}' type."),
-        Property_0_implicitly_has_type_any_because_its_set_accessor_lacks_a_parameter_type_annotation: diag(7032, 1 /* Error */, "Property_0_implicitly_has_type_any_because_its_set_accessor_lacks_a_parameter_type_annotation_7032", "Property '{0}' implicitly has type 'any', because its set accessor lacks a parameter type annotation."),
-        Property_0_implicitly_has_type_any_because_its_get_accessor_lacks_a_return_type_annotation: diag(7033, 1 /* Error */, "Property_0_implicitly_has_type_any_because_its_get_accessor_lacks_a_return_type_annotation_7033", "Property '{0}' implicitly has type 'any', because its get accessor lacks a return type annotation."),
-        Variable_0_implicitly_has_type_1_in_some_locations_where_its_type_cannot_be_determined: diag(7034, 1 /* Error */, "Variable_0_implicitly_has_type_1_in_some_locations_where_its_type_cannot_be_determined_7034", "Variable '{0}' implicitly has type '{1}' in some locations where its type cannot be determined."),
-        Try_npm_i_save_dev_types_Slash_1_if_it_exists_or_add_a_new_declaration_d_ts_file_containing_declare_module_0: diag(7035, 1 /* Error */, "Try_npm_i_save_dev_types_Slash_1_if_it_exists_or_add_a_new_declaration_d_ts_file_containing_declare__7035", "Try `npm i --save-dev @types/{1}` if it exists or add a new declaration (.d.ts) file containing `declare module '{0}';`"),
-        Dynamic_import_s_specifier_must_be_of_type_string_but_here_has_type_0: diag(7036, 1 /* Error */, "Dynamic_import_s_specifier_must_be_of_type_string_but_here_has_type_0_7036", "Dynamic import's specifier must be of type 'string', but here has type '{0}'."),
-        Enables_emit_interoperability_between_CommonJS_and_ES_Modules_via_creation_of_namespace_objects_for_all_imports_Implies_allowSyntheticDefaultImports: diag(7037, 3 /* Message */, "Enables_emit_interoperability_between_CommonJS_and_ES_Modules_via_creation_of_namespace_objects_for__7037", "Enables emit interoperability between CommonJS and ES Modules via creation of namespace objects for all imports. Implies 'allowSyntheticDefaultImports'."),
-        Type_originates_at_this_import_A_namespace_style_import_cannot_be_called_or_constructed_and_will_cause_a_failure_at_runtime_Consider_using_a_default_import_or_import_require_here_instead: diag(7038, 3 /* Message */, "Type_originates_at_this_import_A_namespace_style_import_cannot_be_called_or_constructed_and_will_cau_7038", "Type originates at this import. A namespace-style import cannot be called or constructed, and will cause a failure at runtime. Consider using a default import or import require here instead."),
-        Mapped_object_type_implicitly_has_an_any_template_type: diag(7039, 1 /* Error */, "Mapped_object_type_implicitly_has_an_any_template_type_7039", "Mapped object type implicitly has an 'any' template type."),
-        If_the_0_package_actually_exposes_this_module_consider_sending_a_pull_request_to_amend_https_Colon_Slash_Slashgithub_com_SlashDefinitelyTyped_SlashDefinitelyTyped_Slashtree_Slashmaster_Slashtypes_Slash_1: diag(7040, 1 /* Error */, "If_the_0_package_actually_exposes_this_module_consider_sending_a_pull_request_to_amend_https_Colon_S_7040", "If the '{0}' package actually exposes this module, consider sending a pull request to amend 'https://github.com/DefinitelyTyped/DefinitelyTyped/tree/master/types/{1}'"),
-        The_containing_arrow_function_captures_the_global_value_of_this: diag(7041, 1 /* Error */, "The_containing_arrow_function_captures_the_global_value_of_this_7041", "The containing arrow function captures the global value of 'this'."),
-        Module_0_was_resolved_to_1_but_resolveJsonModule_is_not_used: diag(7042, 1 /* Error */, "Module_0_was_resolved_to_1_but_resolveJsonModule_is_not_used_7042", "Module '{0}' was resolved to '{1}', but '--resolveJsonModule' is not used."),
-        Variable_0_implicitly_has_an_1_type_but_a_better_type_may_be_inferred_from_usage: diag(7043, 2 /* Suggestion */, "Variable_0_implicitly_has_an_1_type_but_a_better_type_may_be_inferred_from_usage_7043", "Variable '{0}' implicitly has an '{1}' type, but a better type may be inferred from usage."),
-        Parameter_0_implicitly_has_an_1_type_but_a_better_type_may_be_inferred_from_usage: diag(7044, 2 /* Suggestion */, "Parameter_0_implicitly_has_an_1_type_but_a_better_type_may_be_inferred_from_usage_7044", "Parameter '{0}' implicitly has an '{1}' type, but a better type may be inferred from usage."),
-        Member_0_implicitly_has_an_1_type_but_a_better_type_may_be_inferred_from_usage: diag(7045, 2 /* Suggestion */, "Member_0_implicitly_has_an_1_type_but_a_better_type_may_be_inferred_from_usage_7045", "Member '{0}' implicitly has an '{1}' type, but a better type may be inferred from usage."),
-        Variable_0_implicitly_has_type_1_in_some_locations_but_a_better_type_may_be_inferred_from_usage: diag(7046, 2 /* Suggestion */, "Variable_0_implicitly_has_type_1_in_some_locations_but_a_better_type_may_be_inferred_from_usage_7046", "Variable '{0}' implicitly has type '{1}' in some locations, but a better type may be inferred from usage."),
-        Rest_parameter_0_implicitly_has_an_any_type_but_a_better_type_may_be_inferred_from_usage: diag(7047, 2 /* Suggestion */, "Rest_parameter_0_implicitly_has_an_any_type_but_a_better_type_may_be_inferred_from_usage_7047", "Rest parameter '{0}' implicitly has an 'any[]' type, but a better type may be inferred from usage."),
-        Property_0_implicitly_has_type_any_but_a_better_type_for_its_get_accessor_may_be_inferred_from_usage: diag(7048, 2 /* Suggestion */, "Property_0_implicitly_has_type_any_but_a_better_type_for_its_get_accessor_may_be_inferred_from_usage_7048", "Property '{0}' implicitly has type 'any', but a better type for its get accessor may be inferred from usage."),
-        Property_0_implicitly_has_type_any_but_a_better_type_for_its_set_accessor_may_be_inferred_from_usage: diag(7049, 2 /* Suggestion */, "Property_0_implicitly_has_type_any_but_a_better_type_for_its_set_accessor_may_be_inferred_from_usage_7049", "Property '{0}' implicitly has type 'any', but a better type for its set accessor may be inferred from usage."),
-        _0_implicitly_has_an_1_return_type_but_a_better_type_may_be_inferred_from_usage: diag(7050, 2 /* Suggestion */, "_0_implicitly_has_an_1_return_type_but_a_better_type_may_be_inferred_from_usage_7050", "'{0}' implicitly has an '{1}' return type, but a better type may be inferred from usage."),
-        Parameter_has_a_name_but_no_type_Did_you_mean_0_Colon_1: diag(7051, 1 /* Error */, "Parameter_has_a_name_but_no_type_Did_you_mean_0_Colon_1_7051", "Parameter has a name but no type. Did you mean '{0}: {1}'?"),
-        Element_implicitly_has_an_any_type_because_type_0_has_no_index_signature_Did_you_mean_to_call_1: diag(7052, 1 /* Error */, "Element_implicitly_has_an_any_type_because_type_0_has_no_index_signature_Did_you_mean_to_call_1_7052", "Element implicitly has an 'any' type because type '{0}' has no index signature. Did you mean to call '{1}'?"),
-        Element_implicitly_has_an_any_type_because_expression_of_type_0_can_t_be_used_to_index_type_1: diag(7053, 1 /* Error */, "Element_implicitly_has_an_any_type_because_expression_of_type_0_can_t_be_used_to_index_type_1_7053", "Element implicitly has an 'any' type because expression of type '{0}' can't be used to index type '{1}'."),
-        No_index_signature_with_a_parameter_of_type_0_was_found_on_type_1: diag(7054, 1 /* Error */, "No_index_signature_with_a_parameter_of_type_0_was_found_on_type_1_7054", "No index signature with a parameter of type '{0}' was found on type '{1}'."),
-        _0_which_lacks_return_type_annotation_implicitly_has_an_1_yield_type: diag(7055, 1 /* Error */, "_0_which_lacks_return_type_annotation_implicitly_has_an_1_yield_type_7055", "'{0}', which lacks return-type annotation, implicitly has an '{1}' yield type."),
-        The_inferred_type_of_this_node_exceeds_the_maximum_length_the_compiler_will_serialize_An_explicit_type_annotation_is_needed: diag(7056, 1 /* Error */, "The_inferred_type_of_this_node_exceeds_the_maximum_length_the_compiler_will_serialize_An_explicit_ty_7056", "The inferred type of this node exceeds the maximum length the compiler will serialize. An explicit type annotation is needed."),
-        yield_expression_implicitly_results_in_an_any_type_because_its_containing_generator_lacks_a_return_type_annotation: diag(7057, 1 /* Error */, "yield_expression_implicitly_results_in_an_any_type_because_its_containing_generator_lacks_a_return_t_7057", "'yield' expression implicitly results in an 'any' type because its containing generator lacks a return-type annotation."),
-        If_the_0_package_actually_exposes_this_module_try_adding_a_new_declaration_d_ts_file_containing_declare_module_1: diag(7058, 1 /* Error */, "If_the_0_package_actually_exposes_this_module_try_adding_a_new_declaration_d_ts_file_containing_decl_7058", "If the '{0}' package actually exposes this module, try adding a new declaration (.d.ts) file containing `declare module '{1}';`"),
-        This_syntax_is_reserved_in_files_with_the_mts_or_cts_extension_Use_an_as_expression_instead: diag(7059, 1 /* Error */, "This_syntax_is_reserved_in_files_with_the_mts_or_cts_extension_Use_an_as_expression_instead_7059", "This syntax is reserved in files with the .mts or .cts extension. Use an `as` expression instead."),
-        This_syntax_is_reserved_in_files_with_the_mts_or_cts_extension_Add_a_trailing_comma_or_explicit_constraint: diag(7060, 1 /* Error */, "This_syntax_is_reserved_in_files_with_the_mts_or_cts_extension_Add_a_trailing_comma_or_explicit_cons_7060", "This syntax is reserved in files with the .mts or .cts extension. Add a trailing comma or explicit constraint."),
-        A_mapped_type_may_not_declare_properties_or_methods: diag(7061, 1 /* Error */, "A_mapped_type_may_not_declare_properties_or_methods_7061", "A mapped type may not declare properties or methods."),
-        You_cannot_rename_this_element: diag(8e3, 1 /* Error */, "You_cannot_rename_this_element_8000", "You cannot rename this element."),
-        You_cannot_rename_elements_that_are_defined_in_the_standard_TypeScript_library: diag(8001, 1 /* Error */, "You_cannot_rename_elements_that_are_defined_in_the_standard_TypeScript_library_8001", "You cannot rename elements that are defined in the standard TypeScript library."),
-        import_can_only_be_used_in_TypeScript_files: diag(8002, 1 /* Error */, "import_can_only_be_used_in_TypeScript_files_8002", "'import ... =' can only be used in TypeScript files."),
-        export_can_only_be_used_in_TypeScript_files: diag(8003, 1 /* Error */, "export_can_only_be_used_in_TypeScript_files_8003", "'export =' can only be used in TypeScript files."),
-        Type_parameter_declarations_can_only_be_used_in_TypeScript_files: diag(8004, 1 /* Error */, "Type_parameter_declarations_can_only_be_used_in_TypeScript_files_8004", "Type parameter declarations can only be used in TypeScript files."),
-        implements_clauses_can_only_be_used_in_TypeScript_files: diag(8005, 1 /* Error */, "implements_clauses_can_only_be_used_in_TypeScript_files_8005", "'implements' clauses can only be used in TypeScript files."),
-        _0_declarations_can_only_be_used_in_TypeScript_files: diag(8006, 1 /* Error */, "_0_declarations_can_only_be_used_in_TypeScript_files_8006", "'{0}' declarations can only be used in TypeScript files."),
-        Type_aliases_can_only_be_used_in_TypeScript_files: diag(8008, 1 /* Error */, "Type_aliases_can_only_be_used_in_TypeScript_files_8008", "Type aliases can only be used in TypeScript files."),
-        The_0_modifier_can_only_be_used_in_TypeScript_files: diag(8009, 1 /* Error */, "The_0_modifier_can_only_be_used_in_TypeScript_files_8009", "The '{0}' modifier can only be used in TypeScript files."),
-        Type_annotations_can_only_be_used_in_TypeScript_files: diag(8010, 1 /* Error */, "Type_annotations_can_only_be_used_in_TypeScript_files_8010", "Type annotations can only be used in TypeScript files."),
-        Type_arguments_can_only_be_used_in_TypeScript_files: diag(8011, 1 /* Error */, "Type_arguments_can_only_be_used_in_TypeScript_files_8011", "Type arguments can only be used in TypeScript files."),
-        Parameter_modifiers_can_only_be_used_in_TypeScript_files: diag(8012, 1 /* Error */, "Parameter_modifiers_can_only_be_used_in_TypeScript_files_8012", "Parameter modifiers can only be used in TypeScript files."),
-        Non_null_assertions_can_only_be_used_in_TypeScript_files: diag(8013, 1 /* Error */, "Non_null_assertions_can_only_be_used_in_TypeScript_files_8013", "Non-null assertions can only be used in TypeScript files."),
-        Type_assertion_expressions_can_only_be_used_in_TypeScript_files: diag(8016, 1 /* Error */, "Type_assertion_expressions_can_only_be_used_in_TypeScript_files_8016", "Type assertion expressions can only be used in TypeScript files."),
-        Report_errors_in_js_files: diag(8019, 3 /* Message */, "Report_errors_in_js_files_8019", "Report errors in .js files."),
-        JSDoc_types_can_only_be_used_inside_documentation_comments: diag(8020, 1 /* Error */, "JSDoc_types_can_only_be_used_inside_documentation_comments_8020", "JSDoc types can only be used inside documentation comments."),
-        JSDoc_typedef_tag_should_either_have_a_type_annotation_or_be_followed_by_property_or_member_tags: diag(8021, 1 /* Error */, "JSDoc_typedef_tag_should_either_have_a_type_annotation_or_be_followed_by_property_or_member_tags_8021", "JSDoc '@typedef' tag should either have a type annotation or be followed by '@property' or '@member' tags."),
-        JSDoc_0_is_not_attached_to_a_class: diag(8022, 1 /* Error */, "JSDoc_0_is_not_attached_to_a_class_8022", "JSDoc '@{0}' is not attached to a class."),
-        JSDoc_0_1_does_not_match_the_extends_2_clause: diag(8023, 1 /* Error */, "JSDoc_0_1_does_not_match_the_extends_2_clause_8023", "JSDoc '@{0} {1}' does not match the 'extends {2}' clause."),
-        JSDoc_param_tag_has_name_0_but_there_is_no_parameter_with_that_name: diag(8024, 1 /* Error */, "JSDoc_param_tag_has_name_0_but_there_is_no_parameter_with_that_name_8024", "JSDoc '@param' tag has name '{0}', but there is no parameter with that name."),
-        Class_declarations_cannot_have_more_than_one_augments_or_extends_tag: diag(8025, 1 /* Error */, "Class_declarations_cannot_have_more_than_one_augments_or_extends_tag_8025", "Class declarations cannot have more than one '@augments' or '@extends' tag."),
-        Expected_0_type_arguments_provide_these_with_an_extends_tag: diag(8026, 1 /* Error */, "Expected_0_type_arguments_provide_these_with_an_extends_tag_8026", "Expected {0} type arguments; provide these with an '@extends' tag."),
-        Expected_0_1_type_arguments_provide_these_with_an_extends_tag: diag(8027, 1 /* Error */, "Expected_0_1_type_arguments_provide_these_with_an_extends_tag_8027", "Expected {0}-{1} type arguments; provide these with an '@extends' tag."),
-        JSDoc_may_only_appear_in_the_last_parameter_of_a_signature: diag(8028, 1 /* Error */, "JSDoc_may_only_appear_in_the_last_parameter_of_a_signature_8028", "JSDoc '...' may only appear in the last parameter of a signature."),
-        JSDoc_param_tag_has_name_0_but_there_is_no_parameter_with_that_name_It_would_match_arguments_if_it_had_an_array_type: diag(8029, 1 /* Error */, "JSDoc_param_tag_has_name_0_but_there_is_no_parameter_with_that_name_It_would_match_arguments_if_it_h_8029", "JSDoc '@param' tag has name '{0}', but there is no parameter with that name. It would match 'arguments' if it had an array type."),
-        The_type_of_a_function_declaration_must_match_the_function_s_signature: diag(8030, 1 /* Error */, "The_type_of_a_function_declaration_must_match_the_function_s_signature_8030", "The type of a function declaration must match the function's signature."),
-        You_cannot_rename_a_module_via_a_global_import: diag(8031, 1 /* Error */, "You_cannot_rename_a_module_via_a_global_import_8031", "You cannot rename a module via a global import."),
-        Qualified_name_0_is_not_allowed_without_a_leading_param_object_1: diag(8032, 1 /* Error */, "Qualified_name_0_is_not_allowed_without_a_leading_param_object_1_8032", "Qualified name '{0}' is not allowed without a leading '@param {object} {1}'."),
-        A_JSDoc_typedef_comment_may_not_contain_multiple_type_tags: diag(8033, 1 /* Error */, "A_JSDoc_typedef_comment_may_not_contain_multiple_type_tags_8033", "A JSDoc '@typedef' comment may not contain multiple '@type' tags."),
-        The_tag_was_first_specified_here: diag(8034, 1 /* Error */, "The_tag_was_first_specified_here_8034", "The tag was first specified here."),
-        You_cannot_rename_elements_that_are_defined_in_a_node_modules_folder: diag(8035, 1 /* Error */, "You_cannot_rename_elements_that_are_defined_in_a_node_modules_folder_8035", "You cannot rename elements that are defined in a 'node_modules' folder."),
-        You_cannot_rename_elements_that_are_defined_in_another_node_modules_folder: diag(8036, 1 /* Error */, "You_cannot_rename_elements_that_are_defined_in_another_node_modules_folder_8036", "You cannot rename elements that are defined in another 'node_modules' folder."),
-        Type_satisfaction_expressions_can_only_be_used_in_TypeScript_files: diag(8037, 1 /* Error */, "Type_satisfaction_expressions_can_only_be_used_in_TypeScript_files_8037", "Type satisfaction expressions can only be used in TypeScript files."),
-        Decorators_may_not_appear_after_export_or_export_default_if_they_also_appear_before_export: diag(8038, 1 /* Error */, "Decorators_may_not_appear_after_export_or_export_default_if_they_also_appear_before_export_8038", "Decorators may not appear after 'export' or 'export default' if they also appear before 'export'."),
-        A_JSDoc_template_tag_may_not_follow_a_typedef_callback_or_overload_tag: diag(8039, 1 /* Error */, "A_JSDoc_template_tag_may_not_follow_a_typedef_callback_or_overload_tag_8039", "A JSDoc '@template' tag may not follow a '@typedef', '@callback', or '@overload' tag"),
-        Declaration_emit_for_this_file_requires_using_private_name_0_An_explicit_type_annotation_may_unblock_declaration_emit: diag(9005, 1 /* Error */, "Declaration_emit_for_this_file_requires_using_private_name_0_An_explicit_type_annotation_may_unblock_9005", "Declaration emit for this file requires using private name '{0}'. An explicit type annotation may unblock declaration emit."),
-        Declaration_emit_for_this_file_requires_using_private_name_0_from_module_1_An_explicit_type_annotation_may_unblock_declaration_emit: diag(9006, 1 /* Error */, "Declaration_emit_for_this_file_requires_using_private_name_0_from_module_1_An_explicit_type_annotati_9006", "Declaration emit for this file requires using private name '{0}' from module '{1}'. An explicit type annotation may unblock declaration emit."),
-        JSX_attributes_must_only_be_assigned_a_non_empty_expression: diag(17e3, 1 /* Error */, "JSX_attributes_must_only_be_assigned_a_non_empty_expression_17000", "JSX attributes must only be assigned a non-empty 'expression'."),
-        JSX_elements_cannot_have_multiple_attributes_with_the_same_name: diag(17001, 1 /* Error */, "JSX_elements_cannot_have_multiple_attributes_with_the_same_name_17001", "JSX elements cannot have multiple attributes with the same name."),
-        Expected_corresponding_JSX_closing_tag_for_0: diag(17002, 1 /* Error */, "Expected_corresponding_JSX_closing_tag_for_0_17002", "Expected corresponding JSX closing tag for '{0}'."),
-        Cannot_use_JSX_unless_the_jsx_flag_is_provided: diag(17004, 1 /* Error */, "Cannot_use_JSX_unless_the_jsx_flag_is_provided_17004", "Cannot use JSX unless the '--jsx' flag is provided."),
-        A_constructor_cannot_contain_a_super_call_when_its_class_extends_null: diag(17005, 1 /* Error */, "A_constructor_cannot_contain_a_super_call_when_its_class_extends_null_17005", "A constructor cannot contain a 'super' call when its class extends 'null'."),
-        An_unary_expression_with_the_0_operator_is_not_allowed_in_the_left_hand_side_of_an_exponentiation_expression_Consider_enclosing_the_expression_in_parentheses: diag(17006, 1 /* Error */, "An_unary_expression_with_the_0_operator_is_not_allowed_in_the_left_hand_side_of_an_exponentiation_ex_17006", "An unary expression with the '{0}' operator is not allowed in the left-hand side of an exponentiation expression. Consider enclosing the expression in parentheses."),
-        A_type_assertion_expression_is_not_allowed_in_the_left_hand_side_of_an_exponentiation_expression_Consider_enclosing_the_expression_in_parentheses: diag(17007, 1 /* Error */, "A_type_assertion_expression_is_not_allowed_in_the_left_hand_side_of_an_exponentiation_expression_Con_17007", "A type assertion expression is not allowed in the left-hand side of an exponentiation expression. Consider enclosing the expression in parentheses."),
-        JSX_element_0_has_no_corresponding_closing_tag: diag(17008, 1 /* Error */, "JSX_element_0_has_no_corresponding_closing_tag_17008", "JSX element '{0}' has no corresponding closing tag."),
-        super_must_be_called_before_accessing_this_in_the_constructor_of_a_derived_class: diag(17009, 1 /* Error */, "super_must_be_called_before_accessing_this_in_the_constructor_of_a_derived_class_17009", "'super' must be called before accessing 'this' in the constructor of a derived class."),
-        Unknown_type_acquisition_option_0: diag(17010, 1 /* Error */, "Unknown_type_acquisition_option_0_17010", "Unknown type acquisition option '{0}'."),
-        super_must_be_called_before_accessing_a_property_of_super_in_the_constructor_of_a_derived_class: diag(17011, 1 /* Error */, "super_must_be_called_before_accessing_a_property_of_super_in_the_constructor_of_a_derived_class_17011", "'super' must be called before accessing a property of 'super' in the constructor of a derived class."),
-        _0_is_not_a_valid_meta_property_for_keyword_1_Did_you_mean_2: diag(17012, 1 /* Error */, "_0_is_not_a_valid_meta_property_for_keyword_1_Did_you_mean_2_17012", "'{0}' is not a valid meta-property for keyword '{1}'. Did you mean '{2}'?"),
-        Meta_property_0_is_only_allowed_in_the_body_of_a_function_declaration_function_expression_or_constructor: diag(17013, 1 /* Error */, "Meta_property_0_is_only_allowed_in_the_body_of_a_function_declaration_function_expression_or_constru_17013", "Meta-property '{0}' is only allowed in the body of a function declaration, function expression, or constructor."),
-        JSX_fragment_has_no_corresponding_closing_tag: diag(17014, 1 /* Error */, "JSX_fragment_has_no_corresponding_closing_tag_17014", "JSX fragment has no corresponding closing tag."),
-        Expected_corresponding_closing_tag_for_JSX_fragment: diag(17015, 1 /* Error */, "Expected_corresponding_closing_tag_for_JSX_fragment_17015", "Expected corresponding closing tag for JSX fragment."),
-        The_jsxFragmentFactory_compiler_option_must_be_provided_to_use_JSX_fragments_with_the_jsxFactory_compiler_option: diag(17016, 1 /* Error */, "The_jsxFragmentFactory_compiler_option_must_be_provided_to_use_JSX_fragments_with_the_jsxFactory_com_17016", "The 'jsxFragmentFactory' compiler option must be provided to use JSX fragments with the 'jsxFactory' compiler option."),
-        An_jsxFrag_pragma_is_required_when_using_an_jsx_pragma_with_JSX_fragments: diag(17017, 1 /* Error */, "An_jsxFrag_pragma_is_required_when_using_an_jsx_pragma_with_JSX_fragments_17017", "An @jsxFrag pragma is required when using an @jsx pragma with JSX fragments."),
-        Unknown_type_acquisition_option_0_Did_you_mean_1: diag(17018, 1 /* Error */, "Unknown_type_acquisition_option_0_Did_you_mean_1_17018", "Unknown type acquisition option '{0}'. Did you mean '{1}'?"),
-        _0_at_the_end_of_a_type_is_not_valid_TypeScript_syntax_Did_you_mean_to_write_1: diag(17019, 1 /* Error */, "_0_at_the_end_of_a_type_is_not_valid_TypeScript_syntax_Did_you_mean_to_write_1_17019", "'{0}' at the end of a type is not valid TypeScript syntax. Did you mean to write '{1}'?"),
-        _0_at_the_start_of_a_type_is_not_valid_TypeScript_syntax_Did_you_mean_to_write_1: diag(17020, 1 /* Error */, "_0_at_the_start_of_a_type_is_not_valid_TypeScript_syntax_Did_you_mean_to_write_1_17020", "'{0}' at the start of a type is not valid TypeScript syntax. Did you mean to write '{1}'?"),
-        Circularity_detected_while_resolving_configuration_Colon_0: diag(18e3, 1 /* Error */, "Circularity_detected_while_resolving_configuration_Colon_0_18000", "Circularity detected while resolving configuration: {0}"),
-        The_files_list_in_config_file_0_is_empty: diag(18002, 1 /* Error */, "The_files_list_in_config_file_0_is_empty_18002", "The 'files' list in config file '{0}' is empty."),
-        No_inputs_were_found_in_config_file_0_Specified_include_paths_were_1_and_exclude_paths_were_2: diag(18003, 1 /* Error */, "No_inputs_were_found_in_config_file_0_Specified_include_paths_were_1_and_exclude_paths_were_2_18003", "No inputs were found in config file '{0}'. Specified 'include' paths were '{1}' and 'exclude' paths were '{2}'."),
-        File_is_a_CommonJS_module_it_may_be_converted_to_an_ES_module: diag(80001, 2 /* Suggestion */, "File_is_a_CommonJS_module_it_may_be_converted_to_an_ES_module_80001", "File is a CommonJS module; it may be converted to an ES module."),
-        This_constructor_function_may_be_converted_to_a_class_declaration: diag(80002, 2 /* Suggestion */, "This_constructor_function_may_be_converted_to_a_class_declaration_80002", "This constructor function may be converted to a class declaration."),
-        Import_may_be_converted_to_a_default_import: diag(80003, 2 /* Suggestion */, "Import_may_be_converted_to_a_default_import_80003", "Import may be converted to a default import."),
-        JSDoc_types_may_be_moved_to_TypeScript_types: diag(80004, 2 /* Suggestion */, "JSDoc_types_may_be_moved_to_TypeScript_types_80004", "JSDoc types may be moved to TypeScript types."),
-        require_call_may_be_converted_to_an_import: diag(80005, 2 /* Suggestion */, "require_call_may_be_converted_to_an_import_80005", "'require' call may be converted to an import."),
-        This_may_be_converted_to_an_async_function: diag(80006, 2 /* Suggestion */, "This_may_be_converted_to_an_async_function_80006", "This may be converted to an async function."),
-        await_has_no_effect_on_the_type_of_this_expression: diag(80007, 2 /* Suggestion */, "await_has_no_effect_on_the_type_of_this_expression_80007", "'await' has no effect on the type of this expression."),
-        Numeric_literals_with_absolute_values_equal_to_2_53_or_greater_are_too_large_to_be_represented_accurately_as_integers: diag(80008, 2 /* Suggestion */, "Numeric_literals_with_absolute_values_equal_to_2_53_or_greater_are_too_large_to_be_represented_accur_80008", "Numeric literals with absolute values equal to 2^53 or greater are too large to be represented accurately as integers."),
-        JSDoc_typedef_may_be_converted_to_TypeScript_type: diag(80009, 2 /* Suggestion */, "JSDoc_typedef_may_be_converted_to_TypeScript_type_80009", "JSDoc typedef may be converted to TypeScript type."),
-        JSDoc_typedefs_may_be_converted_to_TypeScript_types: diag(80010, 2 /* Suggestion */, "JSDoc_typedefs_may_be_converted_to_TypeScript_types_80010", "JSDoc typedefs may be converted to TypeScript types."),
-        Add_missing_super_call: diag(90001, 3 /* Message */, "Add_missing_super_call_90001", "Add missing 'super()' call"),
-        Make_super_call_the_first_statement_in_the_constructor: diag(90002, 3 /* Message */, "Make_super_call_the_first_statement_in_the_constructor_90002", "Make 'super()' call the first statement in the constructor"),
-        Change_extends_to_implements: diag(90003, 3 /* Message */, "Change_extends_to_implements_90003", "Change 'extends' to 'implements'"),
-        Remove_unused_declaration_for_Colon_0: diag(90004, 3 /* Message */, "Remove_unused_declaration_for_Colon_0_90004", "Remove unused declaration for: '{0}'"),
-        Remove_import_from_0: diag(90005, 3 /* Message */, "Remove_import_from_0_90005", "Remove import from '{0}'"),
-        Implement_interface_0: diag(90006, 3 /* Message */, "Implement_interface_0_90006", "Implement interface '{0}'"),
-        Implement_inherited_abstract_class: diag(90007, 3 /* Message */, "Implement_inherited_abstract_class_90007", "Implement inherited abstract class"),
-        Add_0_to_unresolved_variable: diag(90008, 3 /* Message */, "Add_0_to_unresolved_variable_90008", "Add '{0}.' to unresolved variable"),
-        Remove_variable_statement: diag(90010, 3 /* Message */, "Remove_variable_statement_90010", "Remove variable statement"),
-        Remove_template_tag: diag(90011, 3 /* Message */, "Remove_template_tag_90011", "Remove template tag"),
-        Remove_type_parameters: diag(90012, 3 /* Message */, "Remove_type_parameters_90012", "Remove type parameters"),
-        Import_0_from_1: diag(90013, 3 /* Message */, "Import_0_from_1_90013", `Import '{0}' from "{1}"`),
-        Change_0_to_1: diag(90014, 3 /* Message */, "Change_0_to_1_90014", "Change '{0}' to '{1}'"),
-        Declare_property_0: diag(90016, 3 /* Message */, "Declare_property_0_90016", "Declare property '{0}'"),
-        Add_index_signature_for_property_0: diag(90017, 3 /* Message */, "Add_index_signature_for_property_0_90017", "Add index signature for property '{0}'"),
-        Disable_checking_for_this_file: diag(90018, 3 /* Message */, "Disable_checking_for_this_file_90018", "Disable checking for this file"),
-        Ignore_this_error_message: diag(90019, 3 /* Message */, "Ignore_this_error_message_90019", "Ignore this error message"),
-        Initialize_property_0_in_the_constructor: diag(90020, 3 /* Message */, "Initialize_property_0_in_the_constructor_90020", "Initialize property '{0}' in the constructor"),
-        Initialize_static_property_0: diag(90021, 3 /* Message */, "Initialize_static_property_0_90021", "Initialize static property '{0}'"),
-        Change_spelling_to_0: diag(90022, 3 /* Message */, "Change_spelling_to_0_90022", "Change spelling to '{0}'"),
-        Declare_method_0: diag(90023, 3 /* Message */, "Declare_method_0_90023", "Declare method '{0}'"),
-        Declare_static_method_0: diag(90024, 3 /* Message */, "Declare_static_method_0_90024", "Declare static method '{0}'"),
-        Prefix_0_with_an_underscore: diag(90025, 3 /* Message */, "Prefix_0_with_an_underscore_90025", "Prefix '{0}' with an underscore"),
-        Rewrite_as_the_indexed_access_type_0: diag(90026, 3 /* Message */, "Rewrite_as_the_indexed_access_type_0_90026", "Rewrite as the indexed access type '{0}'"),
-        Declare_static_property_0: diag(90027, 3 /* Message */, "Declare_static_property_0_90027", "Declare static property '{0}'"),
-        Call_decorator_expression: diag(90028, 3 /* Message */, "Call_decorator_expression_90028", "Call decorator expression"),
-        Add_async_modifier_to_containing_function: diag(90029, 3 /* Message */, "Add_async_modifier_to_containing_function_90029", "Add async modifier to containing function"),
-        Replace_infer_0_with_unknown: diag(90030, 3 /* Message */, "Replace_infer_0_with_unknown_90030", "Replace 'infer {0}' with 'unknown'"),
-        Replace_all_unused_infer_with_unknown: diag(90031, 3 /* Message */, "Replace_all_unused_infer_with_unknown_90031", "Replace all unused 'infer' with 'unknown'"),
-        Add_parameter_name: diag(90034, 3 /* Message */, "Add_parameter_name_90034", "Add parameter name"),
-        Declare_private_property_0: diag(90035, 3 /* Message */, "Declare_private_property_0_90035", "Declare private property '{0}'"),
-        Replace_0_with_Promise_1: diag(90036, 3 /* Message */, "Replace_0_with_Promise_1_90036", "Replace '{0}' with 'Promise<{1}>'"),
-        Fix_all_incorrect_return_type_of_an_async_functions: diag(90037, 3 /* Message */, "Fix_all_incorrect_return_type_of_an_async_functions_90037", "Fix all incorrect return type of an async functions"),
-        Declare_private_method_0: diag(90038, 3 /* Message */, "Declare_private_method_0_90038", "Declare private method '{0}'"),
-        Remove_unused_destructuring_declaration: diag(90039, 3 /* Message */, "Remove_unused_destructuring_declaration_90039", "Remove unused destructuring declaration"),
-        Remove_unused_declarations_for_Colon_0: diag(90041, 3 /* Message */, "Remove_unused_declarations_for_Colon_0_90041", "Remove unused declarations for: '{0}'"),
-        Declare_a_private_field_named_0: diag(90053, 3 /* Message */, "Declare_a_private_field_named_0_90053", "Declare a private field named '{0}'."),
-        Includes_imports_of_types_referenced_by_0: diag(90054, 3 /* Message */, "Includes_imports_of_types_referenced_by_0_90054", "Includes imports of types referenced by '{0}'"),
-        Remove_type_from_import_declaration_from_0: diag(90055, 3 /* Message */, "Remove_type_from_import_declaration_from_0_90055", `Remove 'type' from import declaration from "{0}"`),
-        Remove_type_from_import_of_0_from_1: diag(90056, 3 /* Message */, "Remove_type_from_import_of_0_from_1_90056", `Remove 'type' from import of '{0}' from "{1}"`),
-        Add_import_from_0: diag(90057, 3 /* Message */, "Add_import_from_0_90057", 'Add import from "{0}"'),
-        Update_import_from_0: diag(90058, 3 /* Message */, "Update_import_from_0_90058", 'Update import from "{0}"'),
-        Export_0_from_module_1: diag(90059, 3 /* Message */, "Export_0_from_module_1_90059", "Export '{0}' from module '{1}'"),
-        Export_all_referenced_locals: diag(90060, 3 /* Message */, "Export_all_referenced_locals_90060", "Export all referenced locals"),
-        Convert_function_to_an_ES2015_class: diag(95001, 3 /* Message */, "Convert_function_to_an_ES2015_class_95001", "Convert function to an ES2015 class"),
-        Convert_0_to_1_in_0: diag(95003, 3 /* Message */, "Convert_0_to_1_in_0_95003", "Convert '{0}' to '{1} in {0}'"),
-        Extract_to_0_in_1: diag(95004, 3 /* Message */, "Extract_to_0_in_1_95004", "Extract to {0} in {1}"),
-        Extract_function: diag(95005, 3 /* Message */, "Extract_function_95005", "Extract function"),
-        Extract_constant: diag(95006, 3 /* Message */, "Extract_constant_95006", "Extract constant"),
-        Extract_to_0_in_enclosing_scope: diag(95007, 3 /* Message */, "Extract_to_0_in_enclosing_scope_95007", "Extract to {0} in enclosing scope"),
-        Extract_to_0_in_1_scope: diag(95008, 3 /* Message */, "Extract_to_0_in_1_scope_95008", "Extract to {0} in {1} scope"),
-        Annotate_with_type_from_JSDoc: diag(95009, 3 /* Message */, "Annotate_with_type_from_JSDoc_95009", "Annotate with type from JSDoc"),
-        Infer_type_of_0_from_usage: diag(95011, 3 /* Message */, "Infer_type_of_0_from_usage_95011", "Infer type of '{0}' from usage"),
-        Infer_parameter_types_from_usage: diag(95012, 3 /* Message */, "Infer_parameter_types_from_usage_95012", "Infer parameter types from usage"),
-        Convert_to_default_import: diag(95013, 3 /* Message */, "Convert_to_default_import_95013", "Convert to default import"),
-        Install_0: diag(95014, 3 /* Message */, "Install_0_95014", "Install '{0}'"),
-        Replace_import_with_0: diag(95015, 3 /* Message */, "Replace_import_with_0_95015", "Replace import with '{0}'."),
-        Use_synthetic_default_member: diag(95016, 3 /* Message */, "Use_synthetic_default_member_95016", "Use synthetic 'default' member."),
-        Convert_to_ES_module: diag(95017, 3 /* Message */, "Convert_to_ES_module_95017", "Convert to ES module"),
-        Add_undefined_type_to_property_0: diag(95018, 3 /* Message */, "Add_undefined_type_to_property_0_95018", "Add 'undefined' type to property '{0}'"),
-        Add_initializer_to_property_0: diag(95019, 3 /* Message */, "Add_initializer_to_property_0_95019", "Add initializer to property '{0}'"),
-        Add_definite_assignment_assertion_to_property_0: diag(95020, 3 /* Message */, "Add_definite_assignment_assertion_to_property_0_95020", "Add definite assignment assertion to property '{0}'"),
-        Convert_all_type_literals_to_mapped_type: diag(95021, 3 /* Message */, "Convert_all_type_literals_to_mapped_type_95021", "Convert all type literals to mapped type"),
-        Add_all_missing_members: diag(95022, 3 /* Message */, "Add_all_missing_members_95022", "Add all missing members"),
-        Infer_all_types_from_usage: diag(95023, 3 /* Message */, "Infer_all_types_from_usage_95023", "Infer all types from usage"),
-        Delete_all_unused_declarations: diag(95024, 3 /* Message */, "Delete_all_unused_declarations_95024", "Delete all unused declarations"),
-        Prefix_all_unused_declarations_with_where_possible: diag(95025, 3 /* Message */, "Prefix_all_unused_declarations_with_where_possible_95025", "Prefix all unused declarations with '_' where possible"),
-        Fix_all_detected_spelling_errors: diag(95026, 3 /* Message */, "Fix_all_detected_spelling_errors_95026", "Fix all detected spelling errors"),
-        Add_initializers_to_all_uninitialized_properties: diag(95027, 3 /* Message */, "Add_initializers_to_all_uninitialized_properties_95027", "Add initializers to all uninitialized properties"),
-        Add_definite_assignment_assertions_to_all_uninitialized_properties: diag(95028, 3 /* Message */, "Add_definite_assignment_assertions_to_all_uninitialized_properties_95028", "Add definite assignment assertions to all uninitialized properties"),
-        Add_undefined_type_to_all_uninitialized_properties: diag(95029, 3 /* Message */, "Add_undefined_type_to_all_uninitialized_properties_95029", "Add undefined type to all uninitialized properties"),
-        Change_all_jsdoc_style_types_to_TypeScript: diag(95030, 3 /* Message */, "Change_all_jsdoc_style_types_to_TypeScript_95030", "Change all jsdoc-style types to TypeScript"),
-        Change_all_jsdoc_style_types_to_TypeScript_and_add_undefined_to_nullable_types: diag(95031, 3 /* Message */, "Change_all_jsdoc_style_types_to_TypeScript_and_add_undefined_to_nullable_types_95031", "Change all jsdoc-style types to TypeScript (and add '| undefined' to nullable types)"),
-        Implement_all_unimplemented_interfaces: diag(95032, 3 /* Message */, "Implement_all_unimplemented_interfaces_95032", "Implement all unimplemented interfaces"),
-        Install_all_missing_types_packages: diag(95033, 3 /* Message */, "Install_all_missing_types_packages_95033", "Install all missing types packages"),
-        Rewrite_all_as_indexed_access_types: diag(95034, 3 /* Message */, "Rewrite_all_as_indexed_access_types_95034", "Rewrite all as indexed access types"),
-        Convert_all_to_default_imports: diag(95035, 3 /* Message */, "Convert_all_to_default_imports_95035", "Convert all to default imports"),
-        Make_all_super_calls_the_first_statement_in_their_constructor: diag(95036, 3 /* Message */, "Make_all_super_calls_the_first_statement_in_their_constructor_95036", "Make all 'super()' calls the first statement in their constructor"),
-        Add_qualifier_to_all_unresolved_variables_matching_a_member_name: diag(95037, 3 /* Message */, "Add_qualifier_to_all_unresolved_variables_matching_a_member_name_95037", "Add qualifier to all unresolved variables matching a member name"),
-        Change_all_extended_interfaces_to_implements: diag(95038, 3 /* Message */, "Change_all_extended_interfaces_to_implements_95038", "Change all extended interfaces to 'implements'"),
-        Add_all_missing_super_calls: diag(95039, 3 /* Message */, "Add_all_missing_super_calls_95039", "Add all missing super calls"),
-        Implement_all_inherited_abstract_classes: diag(95040, 3 /* Message */, "Implement_all_inherited_abstract_classes_95040", "Implement all inherited abstract classes"),
-        Add_all_missing_async_modifiers: diag(95041, 3 /* Message */, "Add_all_missing_async_modifiers_95041", "Add all missing 'async' modifiers"),
-        Add_ts_ignore_to_all_error_messages: diag(95042, 3 /* Message */, "Add_ts_ignore_to_all_error_messages_95042", "Add '@ts-ignore' to all error messages"),
-        Annotate_everything_with_types_from_JSDoc: diag(95043, 3 /* Message */, "Annotate_everything_with_types_from_JSDoc_95043", "Annotate everything with types from JSDoc"),
-        Add_to_all_uncalled_decorators: diag(95044, 3 /* Message */, "Add_to_all_uncalled_decorators_95044", "Add '()' to all uncalled decorators"),
-        Convert_all_constructor_functions_to_classes: diag(95045, 3 /* Message */, "Convert_all_constructor_functions_to_classes_95045", "Convert all constructor functions to classes"),
-        Generate_get_and_set_accessors: diag(95046, 3 /* Message */, "Generate_get_and_set_accessors_95046", "Generate 'get' and 'set' accessors"),
-        Convert_require_to_import: diag(95047, 3 /* Message */, "Convert_require_to_import_95047", "Convert 'require' to 'import'"),
-        Convert_all_require_to_import: diag(95048, 3 /* Message */, "Convert_all_require_to_import_95048", "Convert all 'require' to 'import'"),
-        Move_to_a_new_file: diag(95049, 3 /* Message */, "Move_to_a_new_file_95049", "Move to a new file"),
-        Remove_unreachable_code: diag(95050, 3 /* Message */, "Remove_unreachable_code_95050", "Remove unreachable code"),
-        Remove_all_unreachable_code: diag(95051, 3 /* Message */, "Remove_all_unreachable_code_95051", "Remove all unreachable code"),
-        Add_missing_typeof: diag(95052, 3 /* Message */, "Add_missing_typeof_95052", "Add missing 'typeof'"),
-        Remove_unused_label: diag(95053, 3 /* Message */, "Remove_unused_label_95053", "Remove unused label"),
-        Remove_all_unused_labels: diag(95054, 3 /* Message */, "Remove_all_unused_labels_95054", "Remove all unused labels"),
-        Convert_0_to_mapped_object_type: diag(95055, 3 /* Message */, "Convert_0_to_mapped_object_type_95055", "Convert '{0}' to mapped object type"),
-        Convert_namespace_import_to_named_imports: diag(95056, 3 /* Message */, "Convert_namespace_import_to_named_imports_95056", "Convert namespace import to named imports"),
-        Convert_named_imports_to_namespace_import: diag(95057, 3 /* Message */, "Convert_named_imports_to_namespace_import_95057", "Convert named imports to namespace import"),
-        Add_or_remove_braces_in_an_arrow_function: diag(95058, 3 /* Message */, "Add_or_remove_braces_in_an_arrow_function_95058", "Add or remove braces in an arrow function"),
-        Add_braces_to_arrow_function: diag(95059, 3 /* Message */, "Add_braces_to_arrow_function_95059", "Add braces to arrow function"),
-        Remove_braces_from_arrow_function: diag(95060, 3 /* Message */, "Remove_braces_from_arrow_function_95060", "Remove braces from arrow function"),
-        Convert_default_export_to_named_export: diag(95061, 3 /* Message */, "Convert_default_export_to_named_export_95061", "Convert default export to named export"),
-        Convert_named_export_to_default_export: diag(95062, 3 /* Message */, "Convert_named_export_to_default_export_95062", "Convert named export to default export"),
-        Add_missing_enum_member_0: diag(95063, 3 /* Message */, "Add_missing_enum_member_0_95063", "Add missing enum member '{0}'"),
-        Add_all_missing_imports: diag(95064, 3 /* Message */, "Add_all_missing_imports_95064", "Add all missing imports"),
-        Convert_to_async_function: diag(95065, 3 /* Message */, "Convert_to_async_function_95065", "Convert to async function"),
-        Convert_all_to_async_functions: diag(95066, 3 /* Message */, "Convert_all_to_async_functions_95066", "Convert all to async functions"),
-        Add_missing_call_parentheses: diag(95067, 3 /* Message */, "Add_missing_call_parentheses_95067", "Add missing call parentheses"),
-        Add_all_missing_call_parentheses: diag(95068, 3 /* Message */, "Add_all_missing_call_parentheses_95068", "Add all missing call parentheses"),
-        Add_unknown_conversion_for_non_overlapping_types: diag(95069, 3 /* Message */, "Add_unknown_conversion_for_non_overlapping_types_95069", "Add 'unknown' conversion for non-overlapping types"),
-        Add_unknown_to_all_conversions_of_non_overlapping_types: diag(95070, 3 /* Message */, "Add_unknown_to_all_conversions_of_non_overlapping_types_95070", "Add 'unknown' to all conversions of non-overlapping types"),
-        Add_missing_new_operator_to_call: diag(95071, 3 /* Message */, "Add_missing_new_operator_to_call_95071", "Add missing 'new' operator to call"),
-        Add_missing_new_operator_to_all_calls: diag(95072, 3 /* Message */, "Add_missing_new_operator_to_all_calls_95072", "Add missing 'new' operator to all calls"),
-        Add_names_to_all_parameters_without_names: diag(95073, 3 /* Message */, "Add_names_to_all_parameters_without_names_95073", "Add names to all parameters without names"),
-        Enable_the_experimentalDecorators_option_in_your_configuration_file: diag(95074, 3 /* Message */, "Enable_the_experimentalDecorators_option_in_your_configuration_file_95074", "Enable the 'experimentalDecorators' option in your configuration file"),
-        Convert_parameters_to_destructured_object: diag(95075, 3 /* Message */, "Convert_parameters_to_destructured_object_95075", "Convert parameters to destructured object"),
-        Extract_type: diag(95077, 3 /* Message */, "Extract_type_95077", "Extract type"),
-        Extract_to_type_alias: diag(95078, 3 /* Message */, "Extract_to_type_alias_95078", "Extract to type alias"),
-        Extract_to_typedef: diag(95079, 3 /* Message */, "Extract_to_typedef_95079", "Extract to typedef"),
-        Infer_this_type_of_0_from_usage: diag(95080, 3 /* Message */, "Infer_this_type_of_0_from_usage_95080", "Infer 'this' type of '{0}' from usage"),
-        Add_const_to_unresolved_variable: diag(95081, 3 /* Message */, "Add_const_to_unresolved_variable_95081", "Add 'const' to unresolved variable"),
-        Add_const_to_all_unresolved_variables: diag(95082, 3 /* Message */, "Add_const_to_all_unresolved_variables_95082", "Add 'const' to all unresolved variables"),
-        Add_await: diag(95083, 3 /* Message */, "Add_await_95083", "Add 'await'"),
-        Add_await_to_initializer_for_0: diag(95084, 3 /* Message */, "Add_await_to_initializer_for_0_95084", "Add 'await' to initializer for '{0}'"),
-        Fix_all_expressions_possibly_missing_await: diag(95085, 3 /* Message */, "Fix_all_expressions_possibly_missing_await_95085", "Fix all expressions possibly missing 'await'"),
-        Remove_unnecessary_await: diag(95086, 3 /* Message */, "Remove_unnecessary_await_95086", "Remove unnecessary 'await'"),
-        Remove_all_unnecessary_uses_of_await: diag(95087, 3 /* Message */, "Remove_all_unnecessary_uses_of_await_95087", "Remove all unnecessary uses of 'await'"),
-        Enable_the_jsx_flag_in_your_configuration_file: diag(95088, 3 /* Message */, "Enable_the_jsx_flag_in_your_configuration_file_95088", "Enable the '--jsx' flag in your configuration file"),
-        Add_await_to_initializers: diag(95089, 3 /* Message */, "Add_await_to_initializers_95089", "Add 'await' to initializers"),
-        Extract_to_interface: diag(95090, 3 /* Message */, "Extract_to_interface_95090", "Extract to interface"),
-        Convert_to_a_bigint_numeric_literal: diag(95091, 3 /* Message */, "Convert_to_a_bigint_numeric_literal_95091", "Convert to a bigint numeric literal"),
-        Convert_all_to_bigint_numeric_literals: diag(95092, 3 /* Message */, "Convert_all_to_bigint_numeric_literals_95092", "Convert all to bigint numeric literals"),
-        Convert_const_to_let: diag(95093, 3 /* Message */, "Convert_const_to_let_95093", "Convert 'const' to 'let'"),
-        Prefix_with_declare: diag(95094, 3 /* Message */, "Prefix_with_declare_95094", "Prefix with 'declare'"),
-        Prefix_all_incorrect_property_declarations_with_declare: diag(95095, 3 /* Message */, "Prefix_all_incorrect_property_declarations_with_declare_95095", "Prefix all incorrect property declarations with 'declare'"),
-        Convert_to_template_string: diag(95096, 3 /* Message */, "Convert_to_template_string_95096", "Convert to template string"),
-        Add_export_to_make_this_file_into_a_module: diag(95097, 3 /* Message */, "Add_export_to_make_this_file_into_a_module_95097", "Add 'export {}' to make this file into a module"),
-        Set_the_target_option_in_your_configuration_file_to_0: diag(95098, 3 /* Message */, "Set_the_target_option_in_your_configuration_file_to_0_95098", "Set the 'target' option in your configuration file to '{0}'"),
-        Set_the_module_option_in_your_configuration_file_to_0: diag(95099, 3 /* Message */, "Set_the_module_option_in_your_configuration_file_to_0_95099", "Set the 'module' option in your configuration file to '{0}'"),
-        Convert_invalid_character_to_its_html_entity_code: diag(95100, 3 /* Message */, "Convert_invalid_character_to_its_html_entity_code_95100", "Convert invalid character to its html entity code"),
-        Convert_all_invalid_characters_to_HTML_entity_code: diag(95101, 3 /* Message */, "Convert_all_invalid_characters_to_HTML_entity_code_95101", "Convert all invalid characters to HTML entity code"),
-        Convert_all_const_to_let: diag(95102, 3 /* Message */, "Convert_all_const_to_let_95102", "Convert all 'const' to 'let'"),
-        Convert_function_expression_0_to_arrow_function: diag(95105, 3 /* Message */, "Convert_function_expression_0_to_arrow_function_95105", "Convert function expression '{0}' to arrow function"),
-        Convert_function_declaration_0_to_arrow_function: diag(95106, 3 /* Message */, "Convert_function_declaration_0_to_arrow_function_95106", "Convert function declaration '{0}' to arrow function"),
-        Fix_all_implicit_this_errors: diag(95107, 3 /* Message */, "Fix_all_implicit_this_errors_95107", "Fix all implicit-'this' errors"),
-        Wrap_invalid_character_in_an_expression_container: diag(95108, 3 /* Message */, "Wrap_invalid_character_in_an_expression_container_95108", "Wrap invalid character in an expression container"),
-        Wrap_all_invalid_characters_in_an_expression_container: diag(95109, 3 /* Message */, "Wrap_all_invalid_characters_in_an_expression_container_95109", "Wrap all invalid characters in an expression container"),
-        Visit_https_Colon_Slash_Slashaka_ms_Slashtsconfig_to_read_more_about_this_file: diag(95110, 3 /* Message */, "Visit_https_Colon_Slash_Slashaka_ms_Slashtsconfig_to_read_more_about_this_file_95110", "Visit https://aka.ms/tsconfig to read more about this file"),
-        Add_a_return_statement: diag(95111, 3 /* Message */, "Add_a_return_statement_95111", "Add a return statement"),
-        Remove_braces_from_arrow_function_body: diag(95112, 3 /* Message */, "Remove_braces_from_arrow_function_body_95112", "Remove braces from arrow function body"),
-        Wrap_the_following_body_with_parentheses_which_should_be_an_object_literal: diag(95113, 3 /* Message */, "Wrap_the_following_body_with_parentheses_which_should_be_an_object_literal_95113", "Wrap the following body with parentheses which should be an object literal"),
-        Add_all_missing_return_statement: diag(95114, 3 /* Message */, "Add_all_missing_return_statement_95114", "Add all missing return statement"),
-        Remove_braces_from_all_arrow_function_bodies_with_relevant_issues: diag(95115, 3 /* Message */, "Remove_braces_from_all_arrow_function_bodies_with_relevant_issues_95115", "Remove braces from all arrow function bodies with relevant issues"),
-        Wrap_all_object_literal_with_parentheses: diag(95116, 3 /* Message */, "Wrap_all_object_literal_with_parentheses_95116", "Wrap all object literal with parentheses"),
-        Move_labeled_tuple_element_modifiers_to_labels: diag(95117, 3 /* Message */, "Move_labeled_tuple_element_modifiers_to_labels_95117", "Move labeled tuple element modifiers to labels"),
-        Convert_overload_list_to_single_signature: diag(95118, 3 /* Message */, "Convert_overload_list_to_single_signature_95118", "Convert overload list to single signature"),
-        Generate_get_and_set_accessors_for_all_overriding_properties: diag(95119, 3 /* Message */, "Generate_get_and_set_accessors_for_all_overriding_properties_95119", "Generate 'get' and 'set' accessors for all overriding properties"),
-        Wrap_in_JSX_fragment: diag(95120, 3 /* Message */, "Wrap_in_JSX_fragment_95120", "Wrap in JSX fragment"),
-        Wrap_all_unparented_JSX_in_JSX_fragment: diag(95121, 3 /* Message */, "Wrap_all_unparented_JSX_in_JSX_fragment_95121", "Wrap all unparented JSX in JSX fragment"),
-        Convert_arrow_function_or_function_expression: diag(95122, 3 /* Message */, "Convert_arrow_function_or_function_expression_95122", "Convert arrow function or function expression"),
-        Convert_to_anonymous_function: diag(95123, 3 /* Message */, "Convert_to_anonymous_function_95123", "Convert to anonymous function"),
-        Convert_to_named_function: diag(95124, 3 /* Message */, "Convert_to_named_function_95124", "Convert to named function"),
-        Convert_to_arrow_function: diag(95125, 3 /* Message */, "Convert_to_arrow_function_95125", "Convert to arrow function"),
-        Remove_parentheses: diag(95126, 3 /* Message */, "Remove_parentheses_95126", "Remove parentheses"),
-        Could_not_find_a_containing_arrow_function: diag(95127, 3 /* Message */, "Could_not_find_a_containing_arrow_function_95127", "Could not find a containing arrow function"),
-        Containing_function_is_not_an_arrow_function: diag(95128, 3 /* Message */, "Containing_function_is_not_an_arrow_function_95128", "Containing function is not an arrow function"),
-        Could_not_find_export_statement: diag(95129, 3 /* Message */, "Could_not_find_export_statement_95129", "Could not find export statement"),
-        This_file_already_has_a_default_export: diag(95130, 3 /* Message */, "This_file_already_has_a_default_export_95130", "This file already has a default export"),
-        Could_not_find_import_clause: diag(95131, 3 /* Message */, "Could_not_find_import_clause_95131", "Could not find import clause"),
-        Could_not_find_namespace_import_or_named_imports: diag(95132, 3 /* Message */, "Could_not_find_namespace_import_or_named_imports_95132", "Could not find namespace import or named imports"),
-        Selection_is_not_a_valid_type_node: diag(95133, 3 /* Message */, "Selection_is_not_a_valid_type_node_95133", "Selection is not a valid type node"),
-        No_type_could_be_extracted_from_this_type_node: diag(95134, 3 /* Message */, "No_type_could_be_extracted_from_this_type_node_95134", "No type could be extracted from this type node"),
-        Could_not_find_property_for_which_to_generate_accessor: diag(95135, 3 /* Message */, "Could_not_find_property_for_which_to_generate_accessor_95135", "Could not find property for which to generate accessor"),
-        Name_is_not_valid: diag(95136, 3 /* Message */, "Name_is_not_valid_95136", "Name is not valid"),
-        Can_only_convert_property_with_modifier: diag(95137, 3 /* Message */, "Can_only_convert_property_with_modifier_95137", "Can only convert property with modifier"),
-        Switch_each_misused_0_to_1: diag(95138, 3 /* Message */, "Switch_each_misused_0_to_1_95138", "Switch each misused '{0}' to '{1}'"),
-        Convert_to_optional_chain_expression: diag(95139, 3 /* Message */, "Convert_to_optional_chain_expression_95139", "Convert to optional chain expression"),
-        Could_not_find_convertible_access_expression: diag(95140, 3 /* Message */, "Could_not_find_convertible_access_expression_95140", "Could not find convertible access expression"),
-        Could_not_find_matching_access_expressions: diag(95141, 3 /* Message */, "Could_not_find_matching_access_expressions_95141", "Could not find matching access expressions"),
-        Can_only_convert_logical_AND_access_chains: diag(95142, 3 /* Message */, "Can_only_convert_logical_AND_access_chains_95142", "Can only convert logical AND access chains"),
-        Add_void_to_Promise_resolved_without_a_value: diag(95143, 3 /* Message */, "Add_void_to_Promise_resolved_without_a_value_95143", "Add 'void' to Promise resolved without a value"),
-        Add_void_to_all_Promises_resolved_without_a_value: diag(95144, 3 /* Message */, "Add_void_to_all_Promises_resolved_without_a_value_95144", "Add 'void' to all Promises resolved without a value"),
-        Use_element_access_for_0: diag(95145, 3 /* Message */, "Use_element_access_for_0_95145", "Use element access for '{0}'"),
-        Use_element_access_for_all_undeclared_properties: diag(95146, 3 /* Message */, "Use_element_access_for_all_undeclared_properties_95146", "Use element access for all undeclared properties."),
-        Delete_all_unused_imports: diag(95147, 3 /* Message */, "Delete_all_unused_imports_95147", "Delete all unused imports"),
-        Infer_function_return_type: diag(95148, 3 /* Message */, "Infer_function_return_type_95148", "Infer function return type"),
-        Return_type_must_be_inferred_from_a_function: diag(95149, 3 /* Message */, "Return_type_must_be_inferred_from_a_function_95149", "Return type must be inferred from a function"),
-        Could_not_determine_function_return_type: diag(95150, 3 /* Message */, "Could_not_determine_function_return_type_95150", "Could not determine function return type"),
-        Could_not_convert_to_arrow_function: diag(95151, 3 /* Message */, "Could_not_convert_to_arrow_function_95151", "Could not convert to arrow function"),
-        Could_not_convert_to_named_function: diag(95152, 3 /* Message */, "Could_not_convert_to_named_function_95152", "Could not convert to named function"),
-        Could_not_convert_to_anonymous_function: diag(95153, 3 /* Message */, "Could_not_convert_to_anonymous_function_95153", "Could not convert to anonymous function"),
-        Can_only_convert_string_concatenation: diag(95154, 3 /* Message */, "Can_only_convert_string_concatenation_95154", "Can only convert string concatenation"),
-        Selection_is_not_a_valid_statement_or_statements: diag(95155, 3 /* Message */, "Selection_is_not_a_valid_statement_or_statements_95155", "Selection is not a valid statement or statements"),
-        Add_missing_function_declaration_0: diag(95156, 3 /* Message */, "Add_missing_function_declaration_0_95156", "Add missing function declaration '{0}'"),
-        Add_all_missing_function_declarations: diag(95157, 3 /* Message */, "Add_all_missing_function_declarations_95157", "Add all missing function declarations"),
-        Method_not_implemented: diag(95158, 3 /* Message */, "Method_not_implemented_95158", "Method not implemented."),
-        Function_not_implemented: diag(95159, 3 /* Message */, "Function_not_implemented_95159", "Function not implemented."),
-        Add_override_modifier: diag(95160, 3 /* Message */, "Add_override_modifier_95160", "Add 'override' modifier"),
-        Remove_override_modifier: diag(95161, 3 /* Message */, "Remove_override_modifier_95161", "Remove 'override' modifier"),
-        Add_all_missing_override_modifiers: diag(95162, 3 /* Message */, "Add_all_missing_override_modifiers_95162", "Add all missing 'override' modifiers"),
-        Remove_all_unnecessary_override_modifiers: diag(95163, 3 /* Message */, "Remove_all_unnecessary_override_modifiers_95163", "Remove all unnecessary 'override' modifiers"),
-        Can_only_convert_named_export: diag(95164, 3 /* Message */, "Can_only_convert_named_export_95164", "Can only convert named export"),
-        Add_missing_properties: diag(95165, 3 /* Message */, "Add_missing_properties_95165", "Add missing properties"),
-        Add_all_missing_properties: diag(95166, 3 /* Message */, "Add_all_missing_properties_95166", "Add all missing properties"),
-        Add_missing_attributes: diag(95167, 3 /* Message */, "Add_missing_attributes_95167", "Add missing attributes"),
-        Add_all_missing_attributes: diag(95168, 3 /* Message */, "Add_all_missing_attributes_95168", "Add all missing attributes"),
-        Add_undefined_to_optional_property_type: diag(95169, 3 /* Message */, "Add_undefined_to_optional_property_type_95169", "Add 'undefined' to optional property type"),
-        Convert_named_imports_to_default_import: diag(95170, 3 /* Message */, "Convert_named_imports_to_default_import_95170", "Convert named imports to default import"),
-        Delete_unused_param_tag_0: diag(95171, 3 /* Message */, "Delete_unused_param_tag_0_95171", "Delete unused '@param' tag '{0}'"),
-        Delete_all_unused_param_tags: diag(95172, 3 /* Message */, "Delete_all_unused_param_tags_95172", "Delete all unused '@param' tags"),
-        Rename_param_tag_name_0_to_1: diag(95173, 3 /* Message */, "Rename_param_tag_name_0_to_1_95173", "Rename '@param' tag name '{0}' to '{1}'"),
-        Use_0: diag(95174, 3 /* Message */, "Use_0_95174", "Use `{0}`."),
-        Use_Number_isNaN_in_all_conditions: diag(95175, 3 /* Message */, "Use_Number_isNaN_in_all_conditions_95175", "Use `Number.isNaN` in all conditions."),
-        Convert_typedef_to_TypeScript_type: diag(95176, 3 /* Message */, "Convert_typedef_to_TypeScript_type_95176", "Convert typedef to TypeScript type."),
-        Convert_all_typedef_to_TypeScript_types: diag(95177, 3 /* Message */, "Convert_all_typedef_to_TypeScript_types_95177", "Convert all typedef to TypeScript types."),
-        Move_to_file: diag(95178, 3 /* Message */, "Move_to_file_95178", "Move to file"),
-        Cannot_move_to_file_selected_file_is_invalid: diag(95179, 3 /* Message */, "Cannot_move_to_file_selected_file_is_invalid_95179", "Cannot move to file, selected file is invalid"),
-        No_value_exists_in_scope_for_the_shorthand_property_0_Either_declare_one_or_provide_an_initializer: diag(18004, 1 /* Error */, "No_value_exists_in_scope_for_the_shorthand_property_0_Either_declare_one_or_provide_an_initializer_18004", "No value exists in scope for the shorthand property '{0}'. Either declare one or provide an initializer."),
-        Classes_may_not_have_a_field_named_constructor: diag(18006, 1 /* Error */, "Classes_may_not_have_a_field_named_constructor_18006", "Classes may not have a field named 'constructor'."),
-        JSX_expressions_may_not_use_the_comma_operator_Did_you_mean_to_write_an_array: diag(18007, 1 /* Error */, "JSX_expressions_may_not_use_the_comma_operator_Did_you_mean_to_write_an_array_18007", "JSX expressions may not use the comma operator. Did you mean to write an array?"),
-        Private_identifiers_cannot_be_used_as_parameters: diag(18009, 1 /* Error */, "Private_identifiers_cannot_be_used_as_parameters_18009", "Private identifiers cannot be used as parameters."),
-        An_accessibility_modifier_cannot_be_used_with_a_private_identifier: diag(18010, 1 /* Error */, "An_accessibility_modifier_cannot_be_used_with_a_private_identifier_18010", "An accessibility modifier cannot be used with a private identifier."),
-        The_operand_of_a_delete_operator_cannot_be_a_private_identifier: diag(18011, 1 /* Error */, "The_operand_of_a_delete_operator_cannot_be_a_private_identifier_18011", "The operand of a 'delete' operator cannot be a private identifier."),
-        constructor_is_a_reserved_word: diag(18012, 1 /* Error */, "constructor_is_a_reserved_word_18012", "'#constructor' is a reserved word."),
-        Property_0_is_not_accessible_outside_class_1_because_it_has_a_private_identifier: diag(18013, 1 /* Error */, "Property_0_is_not_accessible_outside_class_1_because_it_has_a_private_identifier_18013", "Property '{0}' is not accessible outside class '{1}' because it has a private identifier."),
-        The_property_0_cannot_be_accessed_on_type_1_within_this_class_because_it_is_shadowed_by_another_private_identifier_with_the_same_spelling: diag(18014, 1 /* Error */, "The_property_0_cannot_be_accessed_on_type_1_within_this_class_because_it_is_shadowed_by_another_priv_18014", "The property '{0}' cannot be accessed on type '{1}' within this class because it is shadowed by another private identifier with the same spelling."),
-        Property_0_in_type_1_refers_to_a_different_member_that_cannot_be_accessed_from_within_type_2: diag(18015, 1 /* Error */, "Property_0_in_type_1_refers_to_a_different_member_that_cannot_be_accessed_from_within_type_2_18015", "Property '{0}' in type '{1}' refers to a different member that cannot be accessed from within type '{2}'."),
-        Private_identifiers_are_not_allowed_outside_class_bodies: diag(18016, 1 /* Error */, "Private_identifiers_are_not_allowed_outside_class_bodies_18016", "Private identifiers are not allowed outside class bodies."),
-        The_shadowing_declaration_of_0_is_defined_here: diag(18017, 1 /* Error */, "The_shadowing_declaration_of_0_is_defined_here_18017", "The shadowing declaration of '{0}' is defined here"),
-        The_declaration_of_0_that_you_probably_intended_to_use_is_defined_here: diag(18018, 1 /* Error */, "The_declaration_of_0_that_you_probably_intended_to_use_is_defined_here_18018", "The declaration of '{0}' that you probably intended to use is defined here"),
-        _0_modifier_cannot_be_used_with_a_private_identifier: diag(18019, 1 /* Error */, "_0_modifier_cannot_be_used_with_a_private_identifier_18019", "'{0}' modifier cannot be used with a private identifier."),
-        An_enum_member_cannot_be_named_with_a_private_identifier: diag(18024, 1 /* Error */, "An_enum_member_cannot_be_named_with_a_private_identifier_18024", "An enum member cannot be named with a private identifier."),
-        can_only_be_used_at_the_start_of_a_file: diag(18026, 1 /* Error */, "can_only_be_used_at_the_start_of_a_file_18026", "'#!' can only be used at the start of a file."),
-        Compiler_reserves_name_0_when_emitting_private_identifier_downlevel: diag(18027, 1 /* Error */, "Compiler_reserves_name_0_when_emitting_private_identifier_downlevel_18027", "Compiler reserves name '{0}' when emitting private identifier downlevel."),
-        Private_identifiers_are_only_available_when_targeting_ECMAScript_2015_and_higher: diag(18028, 1 /* Error */, "Private_identifiers_are_only_available_when_targeting_ECMAScript_2015_and_higher_18028", "Private identifiers are only available when targeting ECMAScript 2015 and higher."),
-        Private_identifiers_are_not_allowed_in_variable_declarations: diag(18029, 1 /* Error */, "Private_identifiers_are_not_allowed_in_variable_declarations_18029", "Private identifiers are not allowed in variable declarations."),
-        An_optional_chain_cannot_contain_private_identifiers: diag(18030, 1 /* Error */, "An_optional_chain_cannot_contain_private_identifiers_18030", "An optional chain cannot contain private identifiers."),
-        The_intersection_0_was_reduced_to_never_because_property_1_has_conflicting_types_in_some_constituents: diag(18031, 1 /* Error */, "The_intersection_0_was_reduced_to_never_because_property_1_has_conflicting_types_in_some_constituent_18031", "The intersection '{0}' was reduced to 'never' because property '{1}' has conflicting types in some constituents."),
-        The_intersection_0_was_reduced_to_never_because_property_1_exists_in_multiple_constituents_and_is_private_in_some: diag(18032, 1 /* Error */, "The_intersection_0_was_reduced_to_never_because_property_1_exists_in_multiple_constituents_and_is_pr_18032", "The intersection '{0}' was reduced to 'never' because property '{1}' exists in multiple constituents and is private in some."),
-        Type_0_is_not_assignable_to_type_1_as_required_for_computed_enum_member_values: diag(18033, 1 /* Error */, "Type_0_is_not_assignable_to_type_1_as_required_for_computed_enum_member_values_18033", "Type '{0}' is not assignable to type '{1}' as required for computed enum member values."),
-        Specify_the_JSX_fragment_factory_function_to_use_when_targeting_react_JSX_emit_with_jsxFactory_compiler_option_is_specified_e_g_Fragment: diag(18034, 3 /* Message */, "Specify_the_JSX_fragment_factory_function_to_use_when_targeting_react_JSX_emit_with_jsxFactory_compi_18034", "Specify the JSX fragment factory function to use when targeting 'react' JSX emit with 'jsxFactory' compiler option is specified, e.g. 'Fragment'."),
-        Invalid_value_for_jsxFragmentFactory_0_is_not_a_valid_identifier_or_qualified_name: diag(18035, 1 /* Error */, "Invalid_value_for_jsxFragmentFactory_0_is_not_a_valid_identifier_or_qualified_name_18035", "Invalid value for 'jsxFragmentFactory'. '{0}' is not a valid identifier or qualified-name."),
-        Class_decorators_can_t_be_used_with_static_private_identifier_Consider_removing_the_experimental_decorator: diag(18036, 1 /* Error */, "Class_decorators_can_t_be_used_with_static_private_identifier_Consider_removing_the_experimental_dec_18036", "Class decorators can't be used with static private identifier. Consider removing the experimental decorator."),
-        Await_expression_cannot_be_used_inside_a_class_static_block: diag(18037, 1 /* Error */, "Await_expression_cannot_be_used_inside_a_class_static_block_18037", "Await expression cannot be used inside a class static block."),
-        For_await_loops_cannot_be_used_inside_a_class_static_block: diag(18038, 1 /* Error */, "For_await_loops_cannot_be_used_inside_a_class_static_block_18038", "'For await' loops cannot be used inside a class static block."),
-        Invalid_use_of_0_It_cannot_be_used_inside_a_class_static_block: diag(18039, 1 /* Error */, "Invalid_use_of_0_It_cannot_be_used_inside_a_class_static_block_18039", "Invalid use of '{0}'. It cannot be used inside a class static block."),
-        A_return_statement_cannot_be_used_inside_a_class_static_block: diag(18041, 1 /* Error */, "A_return_statement_cannot_be_used_inside_a_class_static_block_18041", "A 'return' statement cannot be used inside a class static block."),
-        _0_is_a_type_and_cannot_be_imported_in_JavaScript_files_Use_1_in_a_JSDoc_type_annotation: diag(18042, 1 /* Error */, "_0_is_a_type_and_cannot_be_imported_in_JavaScript_files_Use_1_in_a_JSDoc_type_annotation_18042", "'{0}' is a type and cannot be imported in JavaScript files. Use '{1}' in a JSDoc type annotation."),
-        Types_cannot_appear_in_export_declarations_in_JavaScript_files: diag(18043, 1 /* Error */, "Types_cannot_appear_in_export_declarations_in_JavaScript_files_18043", "Types cannot appear in export declarations in JavaScript files."),
-        _0_is_automatically_exported_here: diag(18044, 3 /* Message */, "_0_is_automatically_exported_here_18044", "'{0}' is automatically exported here."),
-        Properties_with_the_accessor_modifier_are_only_available_when_targeting_ECMAScript_2015_and_higher: diag(18045, 1 /* Error */, "Properties_with_the_accessor_modifier_are_only_available_when_targeting_ECMAScript_2015_and_higher_18045", "Properties with the 'accessor' modifier are only available when targeting ECMAScript 2015 and higher."),
-        _0_is_of_type_unknown: diag(18046, 1 /* Error */, "_0_is_of_type_unknown_18046", "'{0}' is of type 'unknown'."),
-        _0_is_possibly_null: diag(18047, 1 /* Error */, "_0_is_possibly_null_18047", "'{0}' is possibly 'null'."),
-        _0_is_possibly_undefined: diag(18048, 1 /* Error */, "_0_is_possibly_undefined_18048", "'{0}' is possibly 'undefined'."),
-        _0_is_possibly_null_or_undefined: diag(18049, 1 /* Error */, "_0_is_possibly_null_or_undefined_18049", "'{0}' is possibly 'null' or 'undefined'."),
-        The_value_0_cannot_be_used_here: diag(18050, 1 /* Error */, "The_value_0_cannot_be_used_here_18050", "The value '{0}' cannot be used here."),
-        Compiler_option_0_cannot_be_given_an_empty_string: diag(18051, 1 /* Error */, "Compiler_option_0_cannot_be_given_an_empty_string_18051", "Compiler option '{0}' cannot be given an empty string."),
-        Non_abstract_class_0_does_not_implement_all_abstract_members_of_1: diag(18052, 1 /* Error */, "Non_abstract_class_0_does_not_implement_all_abstract_members_of_1_18052", "Non-abstract class '{0}' does not implement all abstract members of '{1}'"),
-        Its_type_0_is_not_a_valid_JSX_element_type: diag(18053, 1 /* Error */, "Its_type_0_is_not_a_valid_JSX_element_type_18053", "Its type '{0}' is not a valid JSX element type.")
-      };
-    }
-  });
-
-  // src/compiler/scanner.ts
-  function tokenIsIdentifierOrKeyword(token) {
-    return token >= 80 /* Identifier */;
-  }
-  function tokenIsIdentifierOrKeywordOrGreaterThan(token) {
-    return token === 32 /* GreaterThanToken */ || tokenIsIdentifierOrKeyword(token);
-  }
-  function lookupInUnicodeMap(code, map2) {
-    if (code < map2[0]) {
-      return false;
-    }
-    let lo = 0;
-    let hi = map2.length;
-    let mid;
-    while (lo + 1 < hi) {
-      mid = lo + (hi - lo) / 2;
-      mid -= mid % 2;
-      if (map2[mid] <= code && code <= map2[mid + 1]) {
-        return true;
-      }
-      if (code < map2[mid]) {
-        hi = mid;
-      } else {
-        lo = mid + 2;
-      }
-    }
-    return false;
-  }
-  function isUnicodeIdentifierStart(code, languageVersion) {
-    return languageVersion >= 2 /* ES2015 */ ? lookupInUnicodeMap(code, unicodeESNextIdentifierStart) : languageVersion === 1 /* ES5 */ ? lookupInUnicodeMap(code, unicodeES5IdentifierStart) : lookupInUnicodeMap(code, unicodeES3IdentifierStart);
-  }
-  function isUnicodeIdentifierPart(code, languageVersion) {
-    return languageVersion >= 2 /* ES2015 */ ? lookupInUnicodeMap(code, unicodeESNextIdentifierPart) : languageVersion === 1 /* ES5 */ ? lookupInUnicodeMap(code, unicodeES5IdentifierPart) : lookupInUnicodeMap(code, unicodeES3IdentifierPart);
-  }
-  function makeReverseMap(source) {
-    const result = [];
-    source.forEach((value, name) => {
-      result[value] = name;
-    });
-    return result;
-  }
-  function tokenToString(t) {
-    return tokenStrings[t];
-  }
-  function stringToToken(s) {
-    return textToToken.get(s);
-  }
-  function computeLineStarts(text) {
-    const result = [];
-    let pos = 0;
-    let lineStart = 0;
-    while (pos < text.length) {
-      const ch = text.charCodeAt(pos);
-      pos++;
-      switch (ch) {
-        case 13 /* carriageReturn */:
-          if (text.charCodeAt(pos) === 10 /* lineFeed */) {
-            pos++;
-          }
-        case 10 /* lineFeed */:
-          result.push(lineStart);
-          lineStart = pos;
-          break;
-        default:
-          if (ch > 127 /* maxAsciiCharacter */ && isLineBreak(ch)) {
-            result.push(lineStart);
-            lineStart = pos;
-          }
-          break;
-      }
-    }
-    result.push(lineStart);
-    return result;
-  }
-  function getPositionOfLineAndCharacter(sourceFile, line, character, allowEdits) {
-    return sourceFile.getPositionOfLineAndCharacter ? sourceFile.getPositionOfLineAndCharacter(line, character, allowEdits) : computePositionOfLineAndCharacter(getLineStarts(sourceFile), line, character, sourceFile.text, allowEdits);
-  }
-  function computePositionOfLineAndCharacter(lineStarts, line, character, debugText, allowEdits) {
-    if (line < 0 || line >= lineStarts.length) {
-      if (allowEdits) {
-        line = line < 0 ? 0 : line >= lineStarts.length ? lineStarts.length - 1 : line;
-      } else {
-        Debug.fail(`Bad line number. Line: ${line}, lineStarts.length: ${lineStarts.length} , line map is correct? ${debugText !== void 0 ? arraysEqual(lineStarts, computeLineStarts(debugText)) : "unknown"}`);
-      }
-    }
-    const res = lineStarts[line] + character;
-    if (allowEdits) {
-      return res > lineStarts[line + 1] ? lineStarts[line + 1] : typeof debugText === "string" && res > debugText.length ? debugText.length : res;
-    }
-    if (line < lineStarts.length - 1) {
-      Debug.assert(res < lineStarts[line + 1]);
-    } else if (debugText !== void 0) {
-      Debug.assert(res <= debugText.length);
-    }
-    return res;
-  }
-  function getLineStarts(sourceFile) {
-    return sourceFile.lineMap || (sourceFile.lineMap = computeLineStarts(sourceFile.text));
-  }
-  function computeLineAndCharacterOfPosition(lineStarts, position) {
-    const lineNumber = computeLineOfPosition(lineStarts, position);
-    return {
-      line: lineNumber,
-      character: position - lineStarts[lineNumber]
-    };
-  }
-  function computeLineOfPosition(lineStarts, position, lowerBound) {
-    let lineNumber = binarySearch(lineStarts, position, identity, compareValues, lowerBound);
-    if (lineNumber < 0) {
-      lineNumber = ~lineNumber - 1;
-      Debug.assert(lineNumber !== -1, "position cannot precede the beginning of the file");
-    }
-    return lineNumber;
-  }
-  function getLinesBetweenPositions(sourceFile, pos1, pos2) {
-    if (pos1 === pos2)
-      return 0;
-    const lineStarts = getLineStarts(sourceFile);
-    const lower = Math.min(pos1, pos2);
-    const isNegative = lower === pos2;
-    const upper = isNegative ? pos1 : pos2;
-    const lowerLine = computeLineOfPosition(lineStarts, lower);
-    const upperLine = computeLineOfPosition(lineStarts, upper, lowerLine);
-    return isNegative ? lowerLine - upperLine : upperLine - lowerLine;
-  }
-  function getLineAndCharacterOfPosition(sourceFile, position) {
-    return computeLineAndCharacterOfPosition(getLineStarts(sourceFile), position);
-  }
-  function isWhiteSpaceLike(ch) {
-    return isWhiteSpaceSingleLine(ch) || isLineBreak(ch);
-  }
-  function isWhiteSpaceSingleLine(ch) {
-    return ch === 32 /* space */ || ch === 9 /* tab */ || ch === 11 /* verticalTab */ || ch === 12 /* formFeed */ || ch === 160 /* nonBreakingSpace */ || ch === 133 /* nextLine */ || ch === 5760 /* ogham */ || ch >= 8192 /* enQuad */ && ch <= 8203 /* zeroWidthSpace */ || ch === 8239 /* narrowNoBreakSpace */ || ch === 8287 /* mathematicalSpace */ || ch === 12288 /* ideographicSpace */ || ch === 65279 /* byteOrderMark */;
-  }
-  function isLineBreak(ch) {
-    return ch === 10 /* lineFeed */ || ch === 13 /* carriageReturn */ || ch === 8232 /* lineSeparator */ || ch === 8233 /* paragraphSeparator */;
-  }
-  function isDigit(ch) {
-    return ch >= 48 /* _0 */ && ch <= 57 /* _9 */;
-  }
-  function isHexDigit(ch) {
-    return isDigit(ch) || ch >= 65 /* A */ && ch <= 70 /* F */ || ch >= 97 /* a */ && ch <= 102 /* f */;
-  }
-  function isCodePoint(code) {
-    return code <= 1114111;
-  }
-  function isOctalDigit(ch) {
-    return ch >= 48 /* _0 */ && ch <= 55 /* _7 */;
-  }
-  function couldStartTrivia(text, pos) {
-    const ch = text.charCodeAt(pos);
-    switch (ch) {
-      case 13 /* carriageReturn */:
-      case 10 /* lineFeed */:
-      case 9 /* tab */:
-      case 11 /* verticalTab */:
-      case 12 /* formFeed */:
-      case 32 /* space */:
-      case 47 /* slash */:
-      case 60 /* lessThan */:
-      case 124 /* bar */:
-      case 61 /* equals */:
-      case 62 /* greaterThan */:
-        return true;
-      case 35 /* hash */:
-        return pos === 0;
-      default:
-        return ch > 127 /* maxAsciiCharacter */;
-    }
-  }
-  function skipTrivia(text, pos, stopAfterLineBreak, stopAtComments, inJSDoc) {
-    if (positionIsSynthesized(pos)) {
-      return pos;
-    }
-    let canConsumeStar = false;
-    while (true) {
-      const ch = text.charCodeAt(pos);
-      switch (ch) {
-        case 13 /* carriageReturn */:
-          if (text.charCodeAt(pos + 1) === 10 /* lineFeed */) {
-            pos++;
-          }
-        case 10 /* lineFeed */:
-          pos++;
-          if (stopAfterLineBreak) {
-            return pos;
-          }
-          canConsumeStar = !!inJSDoc;
-          continue;
-        case 9 /* tab */:
-        case 11 /* verticalTab */:
-        case 12 /* formFeed */:
-        case 32 /* space */:
-          pos++;
-          continue;
-        case 47 /* slash */:
-          if (stopAtComments) {
-            break;
-          }
-          if (text.charCodeAt(pos + 1) === 47 /* slash */) {
-            pos += 2;
-            while (pos < text.length) {
-              if (isLineBreak(text.charCodeAt(pos))) {
-                break;
-              }
-              pos++;
-            }
-            canConsumeStar = false;
-            continue;
-          }
-          if (text.charCodeAt(pos + 1) === 42 /* asterisk */) {
-            pos += 2;
-            while (pos < text.length) {
-              if (text.charCodeAt(pos) === 42 /* asterisk */ && text.charCodeAt(pos + 1) === 47 /* slash */) {
-                pos += 2;
-                break;
-              }
-              pos++;
-            }
-            canConsumeStar = false;
-            continue;
-          }
-          break;
-        case 60 /* lessThan */:
-        case 124 /* bar */:
-        case 61 /* equals */:
-        case 62 /* greaterThan */:
-          if (isConflictMarkerTrivia(text, pos)) {
-            pos = scanConflictMarkerTrivia(text, pos);
-            canConsumeStar = false;
-            continue;
-          }
-          break;
-        case 35 /* hash */:
-          if (pos === 0 && isShebangTrivia(text, pos)) {
-            pos = scanShebangTrivia(text, pos);
-            canConsumeStar = false;
-            continue;
-          }
-          break;
-        case 42 /* asterisk */:
-          if (canConsumeStar) {
-            pos++;
-            canConsumeStar = false;
-            continue;
-          }
-          break;
-        default:
-          if (ch > 127 /* maxAsciiCharacter */ && isWhiteSpaceLike(ch)) {
-            pos++;
-            continue;
-          }
-          break;
-      }
-      return pos;
-    }
-  }
-  function isConflictMarkerTrivia(text, pos) {
-    Debug.assert(pos >= 0);
-    if (pos === 0 || isLineBreak(text.charCodeAt(pos - 1))) {
-      const ch = text.charCodeAt(pos);
-      if (pos + mergeConflictMarkerLength < text.length) {
-        for (let i = 0; i < mergeConflictMarkerLength; i++) {
-          if (text.charCodeAt(pos + i) !== ch) {
-            return false;
-          }
-        }
-        return ch === 61 /* equals */ || text.charCodeAt(pos + mergeConflictMarkerLength) === 32 /* space */;
-      }
-    }
-    return false;
-  }
-  function scanConflictMarkerTrivia(text, pos, error) {
-    if (error) {
-      error(Diagnostics.Merge_conflict_marker_encountered, pos, mergeConflictMarkerLength);
-    }
-    const ch = text.charCodeAt(pos);
-    const len = text.length;
-    if (ch === 60 /* lessThan */ || ch === 62 /* greaterThan */) {
-      while (pos < len && !isLineBreak(text.charCodeAt(pos))) {
-        pos++;
-      }
-    } else {
-      Debug.assert(ch === 124 /* bar */ || ch === 61 /* equals */);
-      while (pos < len) {
-        const currentChar = text.charCodeAt(pos);
-        if ((currentChar === 61 /* equals */ || currentChar === 62 /* greaterThan */) && currentChar !== ch && isConflictMarkerTrivia(text, pos)) {
-          break;
-        }
-        pos++;
-      }
-    }
-    return pos;
-  }
-  function isShebangTrivia(text, pos) {
-    Debug.assert(pos === 0);
-    return shebangTriviaRegex.test(text);
-  }
-  function scanShebangTrivia(text, pos) {
-    const shebang = shebangTriviaRegex.exec(text)[0];
-    pos = pos + shebang.length;
-    return pos;
-  }
-  function iterateCommentRanges(reduce, text, pos, trailing, cb, state, initial) {
-    let pendingPos;
-    let pendingEnd;
-    let pendingKind;
-    let pendingHasTrailingNewLine;
-    let hasPendingCommentRange = false;
-    let collecting = trailing;
-    let accumulator = initial;
-    if (pos === 0) {
-      collecting = true;
-      const shebang = getShebang(text);
-      if (shebang) {
-        pos = shebang.length;
-      }
-    }
-    scan:
-      while (pos >= 0 && pos < text.length) {
-        const ch = text.charCodeAt(pos);
-        switch (ch) {
-          case 13 /* carriageReturn */:
-            if (text.charCodeAt(pos + 1) === 10 /* lineFeed */) {
-              pos++;
-            }
-          case 10 /* lineFeed */:
-            pos++;
-            if (trailing) {
-              break scan;
-            }
-            collecting = true;
-            if (hasPendingCommentRange) {
-              pendingHasTrailingNewLine = true;
-            }
-            continue;
-          case 9 /* tab */:
-          case 11 /* verticalTab */:
-          case 12 /* formFeed */:
-          case 32 /* space */:
-            pos++;
-            continue;
-          case 47 /* slash */:
-            const nextChar = text.charCodeAt(pos + 1);
-            let hasTrailingNewLine = false;
-            if (nextChar === 47 /* slash */ || nextChar === 42 /* asterisk */) {
-              const kind = nextChar === 47 /* slash */ ? 2 /* SingleLineCommentTrivia */ : 3 /* MultiLineCommentTrivia */;
-              const startPos = pos;
-              pos += 2;
-              if (nextChar === 47 /* slash */) {
-                while (pos < text.length) {
-                  if (isLineBreak(text.charCodeAt(pos))) {
-                    hasTrailingNewLine = true;
-                    break;
-                  }
-                  pos++;
-                }
-              } else {
-                while (pos < text.length) {
-                  if (text.charCodeAt(pos) === 42 /* asterisk */ && text.charCodeAt(pos + 1) === 47 /* slash */) {
-                    pos += 2;
-                    break;
-                  }
-                  pos++;
-                }
-              }
-              if (collecting) {
-                if (hasPendingCommentRange) {
-                  accumulator = cb(pendingPos, pendingEnd, pendingKind, pendingHasTrailingNewLine, state, accumulator);
-                  if (!reduce && accumulator) {
-                    return accumulator;
-                  }
-                }
-                pendingPos = startPos;
-                pendingEnd = pos;
-                pendingKind = kind;
-                pendingHasTrailingNewLine = hasTrailingNewLine;
-                hasPendingCommentRange = true;
-              }
-              continue;
-            }
-            break scan;
-          default:
-            if (ch > 127 /* maxAsciiCharacter */ && isWhiteSpaceLike(ch)) {
-              if (hasPendingCommentRange && isLineBreak(ch)) {
-                pendingHasTrailingNewLine = true;
-              }
-              pos++;
-              continue;
-            }
-            break scan;
-        }
-      }
-    if (hasPendingCommentRange) {
-      accumulator = cb(pendingPos, pendingEnd, pendingKind, pendingHasTrailingNewLine, state, accumulator);
-    }
-    return accumulator;
-  }
-  function forEachLeadingCommentRange(text, pos, cb, state) {
-    return iterateCommentRanges(
-      /*reduce*/
-      false,
-      text,
-      pos,
-      /*trailing*/
-      false,
-      cb,
-      state
-    );
-  }
-  function forEachTrailingCommentRange(text, pos, cb, state) {
-    return iterateCommentRanges(
-      /*reduce*/
-      false,
-      text,
-      pos,
-      /*trailing*/
-      true,
-      cb,
-      state
-    );
-  }
-  function reduceEachLeadingCommentRange(text, pos, cb, state, initial) {
-    return iterateCommentRanges(
-      /*reduce*/
-      true,
-      text,
-      pos,
-      /*trailing*/
-      false,
-      cb,
-      state,
-      initial
-    );
-  }
-  function reduceEachTrailingCommentRange(text, pos, cb, state, initial) {
-    return iterateCommentRanges(
-      /*reduce*/
-      true,
-      text,
-      pos,
-      /*trailing*/
-      true,
-      cb,
-      state,
-      initial
-    );
-  }
-  function appendCommentRange(pos, end, kind, hasTrailingNewLine, _state, comments = []) {
-    comments.push({ kind, pos, end, hasTrailingNewLine });
-    return comments;
-  }
-  function getLeadingCommentRanges(text, pos) {
-    return reduceEachLeadingCommentRange(
-      text,
-      pos,
-      appendCommentRange,
-      /*state*/
-      void 0,
-      /*initial*/
-      void 0
-    );
-  }
-  function getTrailingCommentRanges(text, pos) {
-    return reduceEachTrailingCommentRange(
-      text,
-      pos,
-      appendCommentRange,
-      /*state*/
-      void 0,
-      /*initial*/
-      void 0
-    );
-  }
-  function getShebang(text) {
-    const match = shebangTriviaRegex.exec(text);
-    if (match) {
-      return match[0];
-    }
-  }
-  function isIdentifierStart(ch, languageVersion) {
-    return ch >= 65 /* A */ && ch <= 90 /* Z */ || ch >= 97 /* a */ && ch <= 122 /* z */ || ch === 36 /* $ */ || ch === 95 /* _ */ || ch > 127 /* maxAsciiCharacter */ && isUnicodeIdentifierStart(ch, languageVersion);
-  }
-  function isIdentifierPart(ch, languageVersion, identifierVariant) {
-    return ch >= 65 /* A */ && ch <= 90 /* Z */ || ch >= 97 /* a */ && ch <= 122 /* z */ || ch >= 48 /* _0 */ && ch <= 57 /* _9 */ || ch === 36 /* $ */ || ch === 95 /* _ */ || // "-" and ":" are valid in JSX Identifiers
-    (identifierVariant === 1 /* JSX */ ? ch === 45 /* minus */ || ch === 58 /* colon */ : false) || ch > 127 /* maxAsciiCharacter */ && isUnicodeIdentifierPart(ch, languageVersion);
-  }
-  function isIdentifierText(name, languageVersion, identifierVariant) {
-    let ch = codePointAt(name, 0);
-    if (!isIdentifierStart(ch, languageVersion)) {
-      return false;
-    }
-    for (let i = charSize(ch); i < name.length; i += charSize(ch)) {
-      if (!isIdentifierPart(ch = codePointAt(name, i), languageVersion, identifierVariant)) {
-        return false;
-      }
-    }
-    return true;
-  }
-  function createScanner(languageVersion, skipTrivia2, languageVariant = 0 /* Standard */, textInitial, onError, start, length2) {
-    var text = textInitial;
-    var pos;
-    var end;
-    var fullStartPos;
-    var tokenStart;
-    var token;
-    var tokenValue;
-    var tokenFlags;
-    var commentDirectives;
-    var inJSDocType = 0;
-    setText(text, start, length2);
-    var scanner2 = {
-      getTokenFullStart: () => fullStartPos,
-      getStartPos: () => fullStartPos,
-      getTokenEnd: () => pos,
-      getTextPos: () => pos,
-      getToken: () => token,
-      getTokenStart: () => tokenStart,
-      getTokenPos: () => tokenStart,
-      getTokenText: () => text.substring(tokenStart, pos),
-      getTokenValue: () => tokenValue,
-      hasUnicodeEscape: () => (tokenFlags & 1024 /* UnicodeEscape */) !== 0,
-      hasExtendedUnicodeEscape: () => (tokenFlags & 8 /* ExtendedUnicodeEscape */) !== 0,
-      hasPrecedingLineBreak: () => (tokenFlags & 1 /* PrecedingLineBreak */) !== 0,
-      hasPrecedingJSDocComment: () => (tokenFlags & 2 /* PrecedingJSDocComment */) !== 0,
-      isIdentifier: () => token === 80 /* Identifier */ || token > 118 /* LastReservedWord */,
-      isReservedWord: () => token >= 83 /* FirstReservedWord */ && token <= 118 /* LastReservedWord */,
-      isUnterminated: () => (tokenFlags & 4 /* Unterminated */) !== 0,
-      getCommentDirectives: () => commentDirectives,
-      getNumericLiteralFlags: () => tokenFlags & 25584 /* NumericLiteralFlags */,
-      getTokenFlags: () => tokenFlags,
-      reScanGreaterToken,
-      reScanAsteriskEqualsToken,
-      reScanSlashToken,
-      reScanTemplateToken,
-      reScanTemplateHeadOrNoSubstitutionTemplate,
-      scanJsxIdentifier,
-      scanJsxAttributeValue,
-      reScanJsxAttributeValue,
-      reScanJsxToken,
-      reScanLessThanToken,
-      reScanHashToken,
-      reScanQuestionToken,
-      reScanInvalidIdentifier,
-      scanJsxToken,
-      scanJsDocToken,
-      scanJSDocCommentTextToken,
-      scan,
-      getText,
-      clearCommentDirectives,
-      setText,
-      setScriptTarget,
-      setLanguageVariant,
-      setOnError,
-      resetTokenState,
-      setTextPos: resetTokenState,
-      setInJSDocType,
-      tryScan,
-      lookAhead,
-      scanRange
-    };
-    if (Debug.isDebugging) {
-      Object.defineProperty(scanner2, "__debugShowCurrentPositionInText", {
-        get: () => {
-          const text2 = scanner2.getText();
-          return text2.slice(0, scanner2.getTokenFullStart()) + "\u2551" + text2.slice(scanner2.getTokenFullStart());
-        }
-      });
-    }
-    return scanner2;
-    function error(message, errPos = pos, length3, arg0) {
-      if (onError) {
-        const oldPos = pos;
-        pos = errPos;
-        onError(message, length3 || 0, arg0);
-        pos = oldPos;
-      }
-    }
-    function scanNumberFragment() {
-      let start2 = pos;
-      let allowSeparator = false;
-      let isPreviousTokenSeparator = false;
-      let result = "";
-      while (true) {
-        const ch = text.charCodeAt(pos);
-        if (ch === 95 /* _ */) {
-          tokenFlags |= 512 /* ContainsSeparator */;
-          if (allowSeparator) {
-            allowSeparator = false;
-            isPreviousTokenSeparator = true;
-            result += text.substring(start2, pos);
-          } else {
-            tokenFlags |= 16384 /* ContainsInvalidSeparator */;
-            if (isPreviousTokenSeparator) {
-              error(Diagnostics.Multiple_consecutive_numeric_separators_are_not_permitted, pos, 1);
-            } else {
-              error(Diagnostics.Numeric_separators_are_not_allowed_here, pos, 1);
-            }
-          }
-          pos++;
-          start2 = pos;
-          continue;
-        }
-        if (isDigit(ch)) {
-          allowSeparator = true;
-          isPreviousTokenSeparator = false;
-          pos++;
-          continue;
-        }
-        break;
-      }
-      if (text.charCodeAt(pos - 1) === 95 /* _ */) {
-        tokenFlags |= 16384 /* ContainsInvalidSeparator */;
-        error(Diagnostics.Numeric_separators_are_not_allowed_here, pos - 1, 1);
-      }
-      return result + text.substring(start2, pos);
-    }
-    function scanNumber() {
-      let start2 = pos;
-      let mainFragment;
-      if (text.charCodeAt(pos) === 48 /* _0 */) {
-        pos++;
-        if (text.charCodeAt(pos) === 95 /* _ */) {
-          tokenFlags |= 512 /* ContainsSeparator */ | 16384 /* ContainsInvalidSeparator */;
-          error(Diagnostics.Numeric_separators_are_not_allowed_here, pos, 1);
-          pos--;
-          mainFragment = scanNumberFragment();
-        } else if (!scanDigits()) {
-          tokenFlags |= 8192 /* ContainsLeadingZero */;
-          mainFragment = "" + +tokenValue;
-        } else if (!tokenValue) {
-          mainFragment = "0";
-        } else {
-          tokenValue = "" + parseInt(tokenValue, 8);
-          tokenFlags |= 32 /* Octal */;
-          const withMinus = token === 41 /* MinusToken */;
-          const literal = (withMinus ? "-" : "") + "0o" + (+tokenValue).toString(8);
-          if (withMinus)
-            start2--;
-          error(Diagnostics.Octal_literals_are_not_allowed_Use_the_syntax_0, start2, pos - start2, literal);
-          return { type: 9 /* NumericLiteral */, value: tokenValue };
-        }
-      } else {
-        mainFragment = scanNumberFragment();
-      }
-      let decimalFragment;
-      let scientificFragment;
-      if (text.charCodeAt(pos) === 46 /* dot */) {
-        pos++;
-        decimalFragment = scanNumberFragment();
-      }
-      let end2 = pos;
-      if (text.charCodeAt(pos) === 69 /* E */ || text.charCodeAt(pos) === 101 /* e */) {
-        pos++;
-        tokenFlags |= 16 /* Scientific */;
-        if (text.charCodeAt(pos) === 43 /* plus */ || text.charCodeAt(pos) === 45 /* minus */)
-          pos++;
-        const preNumericPart = pos;
-        const finalFragment = scanNumberFragment();
-        if (!finalFragment) {
-          error(Diagnostics.Digit_expected);
-        } else {
-          scientificFragment = text.substring(end2, preNumericPart) + finalFragment;
-          end2 = pos;
-        }
-      }
-      let result;
-      if (tokenFlags & 512 /* ContainsSeparator */) {
-        result = mainFragment;
-        if (decimalFragment) {
-          result += "." + decimalFragment;
-        }
-        if (scientificFragment) {
-          result += scientificFragment;
-        }
-      } else {
-        result = text.substring(start2, end2);
-      }
-      if (tokenFlags & 8192 /* ContainsLeadingZero */) {
-        error(Diagnostics.Decimals_with_leading_zeros_are_not_allowed, start2, end2 - start2);
-        return { type: 9 /* NumericLiteral */, value: "" + +result };
-      }
-      if (decimalFragment !== void 0 || tokenFlags & 16 /* Scientific */) {
-        checkForIdentifierStartAfterNumericLiteral(start2, decimalFragment === void 0 && !!(tokenFlags & 16 /* Scientific */));
-        return {
-          type: 9 /* NumericLiteral */,
-          value: "" + +result
-          // if value is not an integer, it can be safely coerced to a number
-        };
-      } else {
-        tokenValue = result;
-        const type = checkBigIntSuffix();
-        checkForIdentifierStartAfterNumericLiteral(start2);
-        return { type, value: tokenValue };
-      }
-    }
-    function checkForIdentifierStartAfterNumericLiteral(numericStart, isScientific) {
-      if (!isIdentifierStart(codePointAt(text, pos), languageVersion)) {
-        return;
-      }
-      const identifierStart = pos;
-      const { length: length3 } = scanIdentifierParts();
-      if (length3 === 1 && text[identifierStart] === "n") {
-        if (isScientific) {
-          error(Diagnostics.A_bigint_literal_cannot_use_exponential_notation, numericStart, identifierStart - numericStart + 1);
-        } else {
-          error(Diagnostics.A_bigint_literal_must_be_an_integer, numericStart, identifierStart - numericStart + 1);
-        }
-      } else {
-        error(Diagnostics.An_identifier_or_keyword_cannot_immediately_follow_a_numeric_literal, identifierStart, length3);
-        pos = identifierStart;
-      }
-    }
-    function scanDigits() {
-      const start2 = pos;
-      let isOctal = true;
-      while (isDigit(text.charCodeAt(pos))) {
-        if (!isOctalDigit(text.charCodeAt(pos))) {
-          isOctal = false;
-        }
-        pos++;
-      }
-      tokenValue = text.substring(start2, pos);
-      return isOctal;
-    }
-    function scanExactNumberOfHexDigits(count, canHaveSeparators) {
-      const valueString = scanHexDigits(
-        /*minCount*/
-        count,
-        /*scanAsManyAsPossible*/
-        false,
-        canHaveSeparators
-      );
-      return valueString ? parseInt(valueString, 16) : -1;
-    }
-    function scanMinimumNumberOfHexDigits(count, canHaveSeparators) {
-      return scanHexDigits(
-        /*minCount*/
-        count,
-        /*scanAsManyAsPossible*/
-        true,
-        canHaveSeparators
-      );
-    }
-    function scanHexDigits(minCount, scanAsManyAsPossible, canHaveSeparators) {
-      let valueChars = [];
-      let allowSeparator = false;
-      let isPreviousTokenSeparator = false;
-      while (valueChars.length < minCount || scanAsManyAsPossible) {
-        let ch = text.charCodeAt(pos);
-        if (canHaveSeparators && ch === 95 /* _ */) {
-          tokenFlags |= 512 /* ContainsSeparator */;
-          if (allowSeparator) {
-            allowSeparator = false;
-            isPreviousTokenSeparator = true;
-          } else if (isPreviousTokenSeparator) {
-            error(Diagnostics.Multiple_consecutive_numeric_separators_are_not_permitted, pos, 1);
-          } else {
-            error(Diagnostics.Numeric_separators_are_not_allowed_here, pos, 1);
-          }
-          pos++;
-          continue;
-        }
-        allowSeparator = canHaveSeparators;
-        if (ch >= 65 /* A */ && ch <= 70 /* F */) {
-          ch += 97 /* a */ - 65 /* A */;
-        } else if (!(ch >= 48 /* _0 */ && ch <= 57 /* _9 */ || ch >= 97 /* a */ && ch <= 102 /* f */)) {
-          break;
-        }
-        valueChars.push(ch);
-        pos++;
-        isPreviousTokenSeparator = false;
-      }
-      if (valueChars.length < minCount) {
-        valueChars = [];
-      }
-      if (text.charCodeAt(pos - 1) === 95 /* _ */) {
-        error(Diagnostics.Numeric_separators_are_not_allowed_here, pos - 1, 1);
-      }
-      return String.fromCharCode(...valueChars);
-    }
-    function scanString(jsxAttributeString = false) {
-      const quote2 = text.charCodeAt(pos);
-      pos++;
-      let result = "";
-      let start2 = pos;
-      while (true) {
-        if (pos >= end) {
-          result += text.substring(start2, pos);
-          tokenFlags |= 4 /* Unterminated */;
-          error(Diagnostics.Unterminated_string_literal);
-          break;
-        }
-        const ch = text.charCodeAt(pos);
-        if (ch === quote2) {
-          result += text.substring(start2, pos);
-          pos++;
-          break;
-        }
-        if (ch === 92 /* backslash */ && !jsxAttributeString) {
-          result += text.substring(start2, pos);
-          result += scanEscapeSequence(
-            /*shouldEmitInvalidEscapeError*/
-            true
-          );
-          start2 = pos;
-          continue;
-        }
-        if (isLineBreak(ch) && !jsxAttributeString) {
-          result += text.substring(start2, pos);
-          tokenFlags |= 4 /* Unterminated */;
-          error(Diagnostics.Unterminated_string_literal);
-          break;
-        }
-        pos++;
-      }
-      return result;
-    }
-    function scanTemplateAndSetTokenValue(shouldEmitInvalidEscapeError) {
-      const startedWithBacktick = text.charCodeAt(pos) === 96 /* backtick */;
-      pos++;
-      let start2 = pos;
-      let contents = "";
-      let resultingToken;
-      while (true) {
-        if (pos >= end) {
-          contents += text.substring(start2, pos);
-          tokenFlags |= 4 /* Unterminated */;
-          error(Diagnostics.Unterminated_template_literal);
-          resultingToken = startedWithBacktick ? 15 /* NoSubstitutionTemplateLiteral */ : 18 /* TemplateTail */;
-          break;
-        }
-        const currChar = text.charCodeAt(pos);
-        if (currChar === 96 /* backtick */) {
-          contents += text.substring(start2, pos);
-          pos++;
-          resultingToken = startedWithBacktick ? 15 /* NoSubstitutionTemplateLiteral */ : 18 /* TemplateTail */;
-          break;
-        }
-        if (currChar === 36 /* $ */ && pos + 1 < end && text.charCodeAt(pos + 1) === 123 /* openBrace */) {
-          contents += text.substring(start2, pos);
-          pos += 2;
-          resultingToken = startedWithBacktick ? 16 /* TemplateHead */ : 17 /* TemplateMiddle */;
-          break;
-        }
-        if (currChar === 92 /* backslash */) {
-          contents += text.substring(start2, pos);
-          contents += scanEscapeSequence(shouldEmitInvalidEscapeError);
-          start2 = pos;
-          continue;
-        }
-        if (currChar === 13 /* carriageReturn */) {
-          contents += text.substring(start2, pos);
-          pos++;
-          if (pos < end && text.charCodeAt(pos) === 10 /* lineFeed */) {
-            pos++;
-          }
-          contents += "\n";
-          start2 = pos;
-          continue;
-        }
-        pos++;
-      }
-      Debug.assert(resultingToken !== void 0);
-      tokenValue = contents;
-      return resultingToken;
-    }
-    function scanEscapeSequence(shouldEmitInvalidEscapeError) {
-      const start2 = pos;
-      pos++;
-      if (pos >= end) {
-        error(Diagnostics.Unexpected_end_of_text);
-        return "";
-      }
-      const ch = text.charCodeAt(pos);
-      pos++;
-      switch (ch) {
-        case 48 /* _0 */:
-          if (pos >= end || !isDigit(text.charCodeAt(pos))) {
-            return "\0";
-          }
-        case 49 /* _1 */:
-        case 50 /* _2 */:
-        case 51 /* _3 */:
-          if (pos < end && isOctalDigit(text.charCodeAt(pos))) {
-            pos++;
-          }
-        case 52 /* _4 */:
-        case 53 /* _5 */:
-        case 54 /* _6 */:
-        case 55 /* _7 */:
-          if (pos < end && isOctalDigit(text.charCodeAt(pos))) {
-            pos++;
-          }
-          tokenFlags |= 2048 /* ContainsInvalidEscape */;
-          if (shouldEmitInvalidEscapeError) {
-            const code = parseInt(text.substring(start2 + 1, pos), 8);
-            error(Diagnostics.Octal_escape_sequences_are_not_allowed_Use_the_syntax_0, start2, pos - start2, "\\x" + padLeft(code.toString(16), 2, "0"));
-            return String.fromCharCode(code);
-          }
-          return text.substring(start2, pos);
-        case 56 /* _8 */:
-        case 57 /* _9 */:
-          tokenFlags |= 2048 /* ContainsInvalidEscape */;
-          if (shouldEmitInvalidEscapeError) {
-            error(Diagnostics.Escape_sequence_0_is_not_allowed, start2, pos - start2, text.substring(start2, pos));
-            return String.fromCharCode(ch);
-          }
-          return text.substring(start2, pos);
-        case 98 /* b */:
-          return "\b";
-        case 116 /* t */:
-          return "	";
-        case 110 /* n */:
-          return "\n";
-        case 118 /* v */:
-          return "\v";
-        case 102 /* f */:
-          return "\f";
-        case 114 /* r */:
-          return "\r";
-        case 39 /* singleQuote */:
-          return "'";
-        case 34 /* doubleQuote */:
-          return '"';
-        case 117 /* u */:
-          if (pos < end && text.charCodeAt(pos) === 123 /* openBrace */) {
-            pos++;
-            const escapedValueString = scanMinimumNumberOfHexDigits(
-              1,
-              /*canHaveSeparators*/
-              false
-            );
-            const escapedValue = escapedValueString ? parseInt(escapedValueString, 16) : -1;
-            if (escapedValue < 0) {
-              tokenFlags |= 2048 /* ContainsInvalidEscape */;
-              if (shouldEmitInvalidEscapeError) {
-                error(Diagnostics.Hexadecimal_digit_expected);
-              }
-              return text.substring(start2, pos);
-            }
-            if (!isCodePoint(escapedValue)) {
-              tokenFlags |= 2048 /* ContainsInvalidEscape */;
-              if (shouldEmitInvalidEscapeError) {
-                error(Diagnostics.An_extended_Unicode_escape_value_must_be_between_0x0_and_0x10FFFF_inclusive);
-              }
-              return text.substring(start2, pos);
-            }
-            if (pos >= end) {
-              tokenFlags |= 2048 /* ContainsInvalidEscape */;
-              if (shouldEmitInvalidEscapeError) {
-                error(Diagnostics.Unexpected_end_of_text);
-              }
-              return text.substring(start2, pos);
-            }
-            if (text.charCodeAt(pos) !== 125 /* closeBrace */) {
-              tokenFlags |= 2048 /* ContainsInvalidEscape */;
-              if (shouldEmitInvalidEscapeError) {
-                error(Diagnostics.Unterminated_Unicode_escape_sequence);
-              }
-              return text.substring(start2, pos);
-            }
-            pos++;
-            tokenFlags |= 8 /* ExtendedUnicodeEscape */;
-            return utf16EncodeAsString(escapedValue);
-          }
-          for (; pos < start2 + 6; pos++) {
-            if (!(pos < end && isHexDigit(text.charCodeAt(pos)))) {
-              tokenFlags |= 2048 /* ContainsInvalidEscape */;
-              if (shouldEmitInvalidEscapeError) {
-                error(Diagnostics.Hexadecimal_digit_expected);
-              }
-              return text.substring(start2, pos);
-            }
-          }
-          tokenFlags |= 1024 /* UnicodeEscape */;
-          return String.fromCharCode(parseInt(text.substring(start2 + 2, pos), 16));
-        case 120 /* x */:
-          for (; pos < start2 + 4; pos++) {
-            if (!(pos < end && isHexDigit(text.charCodeAt(pos)))) {
-              tokenFlags |= 2048 /* ContainsInvalidEscape */;
-              if (shouldEmitInvalidEscapeError) {
-                error(Diagnostics.Hexadecimal_digit_expected);
-              }
-              return text.substring(start2, pos);
-            }
-          }
-          tokenFlags |= 4096 /* HexEscape */;
-          return String.fromCharCode(parseInt(text.substring(start2 + 2, pos), 16));
-        case 13 /* carriageReturn */:
-          if (pos < end && text.charCodeAt(pos) === 10 /* lineFeed */) {
-            pos++;
-          }
-        case 10 /* lineFeed */:
-        case 8232 /* lineSeparator */:
-        case 8233 /* paragraphSeparator */:
-          return "";
-        default:
-          return String.fromCharCode(ch);
-      }
-    }
-    function scanExtendedUnicodeEscape() {
-      const escapedValueString = scanMinimumNumberOfHexDigits(
-        1,
-        /*canHaveSeparators*/
-        false
-      );
-      const escapedValue = escapedValueString ? parseInt(escapedValueString, 16) : -1;
-      let isInvalidExtendedEscape = false;
-      if (escapedValue < 0) {
-        error(Diagnostics.Hexadecimal_digit_expected);
-        isInvalidExtendedEscape = true;
-      } else if (escapedValue > 1114111) {
-        error(Diagnostics.An_extended_Unicode_escape_value_must_be_between_0x0_and_0x10FFFF_inclusive);
-        isInvalidExtendedEscape = true;
-      }
-      if (pos >= end) {
-        error(Diagnostics.Unexpected_end_of_text);
-        isInvalidExtendedEscape = true;
-      } else if (text.charCodeAt(pos) === 125 /* closeBrace */) {
-        pos++;
-      } else {
-        error(Diagnostics.Unterminated_Unicode_escape_sequence);
-        isInvalidExtendedEscape = true;
-      }
-      if (isInvalidExtendedEscape) {
-        return "";
-      }
-      return utf16EncodeAsString(escapedValue);
-    }
-    function peekUnicodeEscape() {
-      if (pos + 5 < end && text.charCodeAt(pos + 1) === 117 /* u */) {
-        const start2 = pos;
-        pos += 2;
-        const value = scanExactNumberOfHexDigits(
-          4,
-          /*canHaveSeparators*/
-          false
-        );
-        pos = start2;
-        return value;
-      }
-      return -1;
-    }
-    function peekExtendedUnicodeEscape() {
-      if (codePointAt(text, pos + 1) === 117 /* u */ && codePointAt(text, pos + 2) === 123 /* openBrace */) {
-        const start2 = pos;
-        pos += 3;
-        const escapedValueString = scanMinimumNumberOfHexDigits(
-          1,
-          /*canHaveSeparators*/
-          false
-        );
-        const escapedValue = escapedValueString ? parseInt(escapedValueString, 16) : -1;
-        pos = start2;
-        return escapedValue;
-      }
-      return -1;
-    }
-    function scanIdentifierParts() {
-      let result = "";
-      let start2 = pos;
-      while (pos < end) {
-        let ch = codePointAt(text, pos);
-        if (isIdentifierPart(ch, languageVersion)) {
-          pos += charSize(ch);
-        } else if (ch === 92 /* backslash */) {
-          ch = peekExtendedUnicodeEscape();
-          if (ch >= 0 && isIdentifierPart(ch, languageVersion)) {
-            pos += 3;
-            tokenFlags |= 8 /* ExtendedUnicodeEscape */;
-            result += scanExtendedUnicodeEscape();
-            start2 = pos;
-            continue;
-          }
-          ch = peekUnicodeEscape();
-          if (!(ch >= 0 && isIdentifierPart(ch, languageVersion))) {
-            break;
-          }
-          tokenFlags |= 1024 /* UnicodeEscape */;
-          result += text.substring(start2, pos);
-          result += utf16EncodeAsString(ch);
-          pos += 6;
-          start2 = pos;
-        } else {
-          break;
-        }
-      }
-      result += text.substring(start2, pos);
-      return result;
-    }
-    function getIdentifierToken() {
-      const len = tokenValue.length;
-      if (len >= 2 && len <= 12) {
-        const ch = tokenValue.charCodeAt(0);
-        if (ch >= 97 /* a */ && ch <= 122 /* z */) {
-          const keyword = textToKeyword.get(tokenValue);
-          if (keyword !== void 0) {
-            return token = keyword;
-          }
-        }
-      }
-      return token = 80 /* Identifier */;
-    }
-    function scanBinaryOrOctalDigits(base) {
-      let value = "";
-      let separatorAllowed = false;
-      let isPreviousTokenSeparator = false;
-      while (true) {
-        const ch = text.charCodeAt(pos);
-        if (ch === 95 /* _ */) {
-          tokenFlags |= 512 /* ContainsSeparator */;
-          if (separatorAllowed) {
-            separatorAllowed = false;
-            isPreviousTokenSeparator = true;
-          } else if (isPreviousTokenSeparator) {
-            error(Diagnostics.Multiple_consecutive_numeric_separators_are_not_permitted, pos, 1);
-          } else {
-            error(Diagnostics.Numeric_separators_are_not_allowed_here, pos, 1);
-          }
-          pos++;
-          continue;
-        }
-        separatorAllowed = true;
-        if (!isDigit(ch) || ch - 48 /* _0 */ >= base) {
-          break;
-        }
-        value += text[pos];
-        pos++;
-        isPreviousTokenSeparator = false;
-      }
-      if (text.charCodeAt(pos - 1) === 95 /* _ */) {
-        error(Diagnostics.Numeric_separators_are_not_allowed_here, pos - 1, 1);
-      }
-      return value;
-    }
-    function checkBigIntSuffix() {
-      if (text.charCodeAt(pos) === 110 /* n */) {
-        tokenValue += "n";
-        if (tokenFlags & 384 /* BinaryOrOctalSpecifier */) {
-          tokenValue = parsePseudoBigInt(tokenValue) + "n";
-        }
-        pos++;
-        return 10 /* BigIntLiteral */;
-      } else {
-        const numericValue = tokenFlags & 128 /* BinarySpecifier */ ? parseInt(tokenValue.slice(2), 2) : tokenFlags & 256 /* OctalSpecifier */ ? parseInt(tokenValue.slice(2), 8) : +tokenValue;
-        tokenValue = "" + numericValue;
-        return 9 /* NumericLiteral */;
-      }
-    }
-    function scan() {
-      fullStartPos = pos;
-      tokenFlags = 0 /* None */;
-      let asteriskSeen = false;
-      while (true) {
-        tokenStart = pos;
-        if (pos >= end) {
-          return token = 1 /* EndOfFileToken */;
-        }
-        const ch = codePointAt(text, pos);
-        if (pos === 0) {
-          if (ch === 65533 /* replacementCharacter */) {
-            error(Diagnostics.File_appears_to_be_binary);
-            pos = end;
-            return token = 8 /* NonTextFileMarkerTrivia */;
-          }
-          if (ch === 35 /* hash */ && isShebangTrivia(text, pos)) {
-            pos = scanShebangTrivia(text, pos);
-            if (skipTrivia2) {
-              continue;
-            } else {
-              return token = 6 /* ShebangTrivia */;
-            }
-          }
-        }
-        switch (ch) {
-          case 10 /* lineFeed */:
-          case 13 /* carriageReturn */:
-            tokenFlags |= 1 /* PrecedingLineBreak */;
-            if (skipTrivia2) {
-              pos++;
-              continue;
-            } else {
-              if (ch === 13 /* carriageReturn */ && pos + 1 < end && text.charCodeAt(pos + 1) === 10 /* lineFeed */) {
-                pos += 2;
-              } else {
-                pos++;
-              }
-              return token = 4 /* NewLineTrivia */;
-            }
-          case 9 /* tab */:
-          case 11 /* verticalTab */:
-          case 12 /* formFeed */:
-          case 32 /* space */:
-          case 160 /* nonBreakingSpace */:
-          case 5760 /* ogham */:
-          case 8192 /* enQuad */:
-          case 8193 /* emQuad */:
-          case 8194 /* enSpace */:
-          case 8195 /* emSpace */:
-          case 8196 /* threePerEmSpace */:
-          case 8197 /* fourPerEmSpace */:
-          case 8198 /* sixPerEmSpace */:
-          case 8199 /* figureSpace */:
-          case 8200 /* punctuationSpace */:
-          case 8201 /* thinSpace */:
-          case 8202 /* hairSpace */:
-          case 8203 /* zeroWidthSpace */:
-          case 8239 /* narrowNoBreakSpace */:
-          case 8287 /* mathematicalSpace */:
-          case 12288 /* ideographicSpace */:
-          case 65279 /* byteOrderMark */:
-            if (skipTrivia2) {
-              pos++;
-              continue;
-            } else {
-              while (pos < end && isWhiteSpaceSingleLine(text.charCodeAt(pos))) {
-                pos++;
-              }
-              return token = 5 /* WhitespaceTrivia */;
-            }
-          case 33 /* exclamation */:
-            if (text.charCodeAt(pos + 1) === 61 /* equals */) {
-              if (text.charCodeAt(pos + 2) === 61 /* equals */) {
-                return pos += 3, token = 38 /* ExclamationEqualsEqualsToken */;
-              }
-              return pos += 2, token = 36 /* ExclamationEqualsToken */;
-            }
-            pos++;
-            return token = 54 /* ExclamationToken */;
-          case 34 /* doubleQuote */:
-          case 39 /* singleQuote */:
-            tokenValue = scanString();
-            return token = 11 /* StringLiteral */;
-          case 96 /* backtick */:
-            return token = scanTemplateAndSetTokenValue(
-              /*shouldEmitInvalidEscapeError*/
-              false
-            );
-          case 37 /* percent */:
-            if (text.charCodeAt(pos + 1) === 61 /* equals */) {
-              return pos += 2, token = 70 /* PercentEqualsToken */;
-            }
-            pos++;
-            return token = 45 /* PercentToken */;
-          case 38 /* ampersand */:
-            if (text.charCodeAt(pos + 1) === 38 /* ampersand */) {
-              if (text.charCodeAt(pos + 2) === 61 /* equals */) {
-                return pos += 3, token = 77 /* AmpersandAmpersandEqualsToken */;
-              }
-              return pos += 2, token = 56 /* AmpersandAmpersandToken */;
-            }
-            if (text.charCodeAt(pos + 1) === 61 /* equals */) {
-              return pos += 2, token = 74 /* AmpersandEqualsToken */;
-            }
-            pos++;
-            return token = 51 /* AmpersandToken */;
-          case 40 /* openParen */:
-            pos++;
-            return token = 21 /* OpenParenToken */;
-          case 41 /* closeParen */:
-            pos++;
-            return token = 22 /* CloseParenToken */;
-          case 42 /* asterisk */:
-            if (text.charCodeAt(pos + 1) === 61 /* equals */) {
-              return pos += 2, token = 67 /* AsteriskEqualsToken */;
-            }
-            if (text.charCodeAt(pos + 1) === 42 /* asterisk */) {
-              if (text.charCodeAt(pos + 2) === 61 /* equals */) {
-                return pos += 3, token = 68 /* AsteriskAsteriskEqualsToken */;
-              }
-              return pos += 2, token = 43 /* AsteriskAsteriskToken */;
-            }
-            pos++;
-            if (inJSDocType && !asteriskSeen && tokenFlags & 1 /* PrecedingLineBreak */) {
-              asteriskSeen = true;
-              continue;
-            }
-            return token = 42 /* AsteriskToken */;
-          case 43 /* plus */:
-            if (text.charCodeAt(pos + 1) === 43 /* plus */) {
-              return pos += 2, token = 46 /* PlusPlusToken */;
-            }
-            if (text.charCodeAt(pos + 1) === 61 /* equals */) {
-              return pos += 2, token = 65 /* PlusEqualsToken */;
-            }
-            pos++;
-            return token = 40 /* PlusToken */;
-          case 44 /* comma */:
-            pos++;
-            return token = 28 /* CommaToken */;
-          case 45 /* minus */:
-            if (text.charCodeAt(pos + 1) === 45 /* minus */) {
-              return pos += 2, token = 47 /* MinusMinusToken */;
-            }
-            if (text.charCodeAt(pos + 1) === 61 /* equals */) {
-              return pos += 2, token = 66 /* MinusEqualsToken */;
-            }
-            pos++;
-            return token = 41 /* MinusToken */;
-          case 46 /* dot */:
-            if (isDigit(text.charCodeAt(pos + 1))) {
-              tokenValue = scanNumber().value;
-              return token = 9 /* NumericLiteral */;
-            }
-            if (text.charCodeAt(pos + 1) === 46 /* dot */ && text.charCodeAt(pos + 2) === 46 /* dot */) {
-              return pos += 3, token = 26 /* DotDotDotToken */;
-            }
-            pos++;
-            return token = 25 /* DotToken */;
-          case 47 /* slash */:
-            if (text.charCodeAt(pos + 1) === 47 /* slash */) {
-              pos += 2;
-              while (pos < end) {
-                if (isLineBreak(text.charCodeAt(pos))) {
-                  break;
-                }
-                pos++;
-              }
-              commentDirectives = appendIfCommentDirective(
-                commentDirectives,
-                text.slice(tokenStart, pos),
-                commentDirectiveRegExSingleLine,
-                tokenStart
-              );
-              if (skipTrivia2) {
-                continue;
-              } else {
-                return token = 2 /* SingleLineCommentTrivia */;
-              }
-            }
-            if (text.charCodeAt(pos + 1) === 42 /* asterisk */) {
-              pos += 2;
-              if (text.charCodeAt(pos) === 42 /* asterisk */ && text.charCodeAt(pos + 1) !== 47 /* slash */) {
-                tokenFlags |= 2 /* PrecedingJSDocComment */;
-              }
-              let commentClosed = false;
-              let lastLineStart = tokenStart;
-              while (pos < end) {
-                const ch2 = text.charCodeAt(pos);
-                if (ch2 === 42 /* asterisk */ && text.charCodeAt(pos + 1) === 47 /* slash */) {
-                  pos += 2;
-                  commentClosed = true;
-                  break;
-                }
-                pos++;
-                if (isLineBreak(ch2)) {
-                  lastLineStart = pos;
-                  tokenFlags |= 1 /* PrecedingLineBreak */;
-                }
-              }
-              commentDirectives = appendIfCommentDirective(commentDirectives, text.slice(lastLineStart, pos), commentDirectiveRegExMultiLine, lastLineStart);
-              if (!commentClosed) {
-                error(Diagnostics.Asterisk_Slash_expected);
-              }
-              if (skipTrivia2) {
-                continue;
-              } else {
-                if (!commentClosed) {
-                  tokenFlags |= 4 /* Unterminated */;
-                }
-                return token = 3 /* MultiLineCommentTrivia */;
-              }
-            }
-            if (text.charCodeAt(pos + 1) === 61 /* equals */) {
-              return pos += 2, token = 69 /* SlashEqualsToken */;
-            }
-            pos++;
-            return token = 44 /* SlashToken */;
-          case 48 /* _0 */:
-            if (pos + 2 < end && (text.charCodeAt(pos + 1) === 88 /* X */ || text.charCodeAt(pos + 1) === 120 /* x */)) {
-              pos += 2;
-              tokenValue = scanMinimumNumberOfHexDigits(
-                1,
-                /*canHaveSeparators*/
-                true
-              );
-              if (!tokenValue) {
-                error(Diagnostics.Hexadecimal_digit_expected);
-                tokenValue = "0";
-              }
-              tokenValue = "0x" + tokenValue;
-              tokenFlags |= 64 /* HexSpecifier */;
-              return token = checkBigIntSuffix();
-            } else if (pos + 2 < end && (text.charCodeAt(pos + 1) === 66 /* B */ || text.charCodeAt(pos + 1) === 98 /* b */)) {
-              pos += 2;
-              tokenValue = scanBinaryOrOctalDigits(
-                /* base */
-                2
-              );
-              if (!tokenValue) {
-                error(Diagnostics.Binary_digit_expected);
-                tokenValue = "0";
-              }
-              tokenValue = "0b" + tokenValue;
-              tokenFlags |= 128 /* BinarySpecifier */;
-              return token = checkBigIntSuffix();
-            } else if (pos + 2 < end && (text.charCodeAt(pos + 1) === 79 /* O */ || text.charCodeAt(pos + 1) === 111 /* o */)) {
-              pos += 2;
-              tokenValue = scanBinaryOrOctalDigits(
-                /* base */
-                8
-              );
-              if (!tokenValue) {
-                error(Diagnostics.Octal_digit_expected);
-                tokenValue = "0";
-              }
-              tokenValue = "0o" + tokenValue;
-              tokenFlags |= 256 /* OctalSpecifier */;
-              return token = checkBigIntSuffix();
-            }
-          case 49 /* _1 */:
-          case 50 /* _2 */:
-          case 51 /* _3 */:
-          case 52 /* _4 */:
-          case 53 /* _5 */:
-          case 54 /* _6 */:
-          case 55 /* _7 */:
-          case 56 /* _8 */:
-          case 57 /* _9 */:
-            ({ type: token, value: tokenValue } = scanNumber());
-            return token;
-          case 58 /* colon */:
-            pos++;
-            return token = 59 /* ColonToken */;
-          case 59 /* semicolon */:
-            pos++;
-            return token = 27 /* SemicolonToken */;
-          case 60 /* lessThan */:
-            if (isConflictMarkerTrivia(text, pos)) {
-              pos = scanConflictMarkerTrivia(text, pos, error);
-              if (skipTrivia2) {
-                continue;
-              } else {
-                return token = 7 /* ConflictMarkerTrivia */;
-              }
-            }
-            if (text.charCodeAt(pos + 1) === 60 /* lessThan */) {
-              if (text.charCodeAt(pos + 2) === 61 /* equals */) {
-                return pos += 3, token = 71 /* LessThanLessThanEqualsToken */;
-              }
-              return pos += 2, token = 48 /* LessThanLessThanToken */;
-            }
-            if (text.charCodeAt(pos + 1) === 61 /* equals */) {
-              return pos += 2, token = 33 /* LessThanEqualsToken */;
-            }
-            if (languageVariant === 1 /* JSX */ && text.charCodeAt(pos + 1) === 47 /* slash */ && text.charCodeAt(pos + 2) !== 42 /* asterisk */) {
-              return pos += 2, token = 31 /* LessThanSlashToken */;
-            }
-            pos++;
-            return token = 30 /* LessThanToken */;
-          case 61 /* equals */:
-            if (isConflictMarkerTrivia(text, pos)) {
-              pos = scanConflictMarkerTrivia(text, pos, error);
-              if (skipTrivia2) {
-                continue;
-              } else {
-                return token = 7 /* ConflictMarkerTrivia */;
-              }
-            }
-            if (text.charCodeAt(pos + 1) === 61 /* equals */) {
-              if (text.charCodeAt(pos + 2) === 61 /* equals */) {
-                return pos += 3, token = 37 /* EqualsEqualsEqualsToken */;
-              }
-              return pos += 2, token = 35 /* EqualsEqualsToken */;
-            }
-            if (text.charCodeAt(pos + 1) === 62 /* greaterThan */) {
-              return pos += 2, token = 39 /* EqualsGreaterThanToken */;
-            }
-            pos++;
-            return token = 64 /* EqualsToken */;
-          case 62 /* greaterThan */:
-            if (isConflictMarkerTrivia(text, pos)) {
-              pos = scanConflictMarkerTrivia(text, pos, error);
-              if (skipTrivia2) {
-                continue;
-              } else {
-                return token = 7 /* ConflictMarkerTrivia */;
-              }
-            }
-            pos++;
-            return token = 32 /* GreaterThanToken */;
-          case 63 /* question */:
-            if (text.charCodeAt(pos + 1) === 46 /* dot */ && !isDigit(text.charCodeAt(pos + 2))) {
-              return pos += 2, token = 29 /* QuestionDotToken */;
-            }
-            if (text.charCodeAt(pos + 1) === 63 /* question */) {
-              if (text.charCodeAt(pos + 2) === 61 /* equals */) {
-                return pos += 3, token = 78 /* QuestionQuestionEqualsToken */;
-              }
-              return pos += 2, token = 61 /* QuestionQuestionToken */;
-            }
-            pos++;
-            return token = 58 /* QuestionToken */;
-          case 91 /* openBracket */:
-            pos++;
-            return token = 23 /* OpenBracketToken */;
-          case 93 /* closeBracket */:
-            pos++;
-            return token = 24 /* CloseBracketToken */;
-          case 94 /* caret */:
-            if (text.charCodeAt(pos + 1) === 61 /* equals */) {
-              return pos += 2, token = 79 /* CaretEqualsToken */;
-            }
-            pos++;
-            return token = 53 /* CaretToken */;
-          case 123 /* openBrace */:
-            pos++;
-            return token = 19 /* OpenBraceToken */;
-          case 124 /* bar */:
-            if (isConflictMarkerTrivia(text, pos)) {
-              pos = scanConflictMarkerTrivia(text, pos, error);
-              if (skipTrivia2) {
-                continue;
-              } else {
-                return token = 7 /* ConflictMarkerTrivia */;
-              }
-            }
-            if (text.charCodeAt(pos + 1) === 124 /* bar */) {
-              if (text.charCodeAt(pos + 2) === 61 /* equals */) {
-                return pos += 3, token = 76 /* BarBarEqualsToken */;
-              }
-              return pos += 2, token = 57 /* BarBarToken */;
-            }
-            if (text.charCodeAt(pos + 1) === 61 /* equals */) {
-              return pos += 2, token = 75 /* BarEqualsToken */;
-            }
-            pos++;
-            return token = 52 /* BarToken */;
-          case 125 /* closeBrace */:
-            pos++;
-            return token = 20 /* CloseBraceToken */;
-          case 126 /* tilde */:
-            pos++;
-            return token = 55 /* TildeToken */;
-          case 64 /* at */:
-            pos++;
-            return token = 60 /* AtToken */;
-          case 92 /* backslash */:
-            const extendedCookedChar = peekExtendedUnicodeEscape();
-            if (extendedCookedChar >= 0 && isIdentifierStart(extendedCookedChar, languageVersion)) {
-              pos += 3;
-              tokenFlags |= 8 /* ExtendedUnicodeEscape */;
-              tokenValue = scanExtendedUnicodeEscape() + scanIdentifierParts();
-              return token = getIdentifierToken();
-            }
-            const cookedChar = peekUnicodeEscape();
-            if (cookedChar >= 0 && isIdentifierStart(cookedChar, languageVersion)) {
-              pos += 6;
-              tokenFlags |= 1024 /* UnicodeEscape */;
-              tokenValue = String.fromCharCode(cookedChar) + scanIdentifierParts();
-              return token = getIdentifierToken();
-            }
-            error(Diagnostics.Invalid_character);
-            pos++;
-            return token = 0 /* Unknown */;
-          case 35 /* hash */:
-            if (pos !== 0 && text[pos + 1] === "!") {
-              error(Diagnostics.can_only_be_used_at_the_start_of_a_file);
-              pos++;
-              return token = 0 /* Unknown */;
-            }
-            const charAfterHash = codePointAt(text, pos + 1);
-            if (charAfterHash === 92 /* backslash */) {
-              pos++;
-              const extendedCookedChar2 = peekExtendedUnicodeEscape();
-              if (extendedCookedChar2 >= 0 && isIdentifierStart(extendedCookedChar2, languageVersion)) {
-                pos += 3;
-                tokenFlags |= 8 /* ExtendedUnicodeEscape */;
-                tokenValue = "#" + scanExtendedUnicodeEscape() + scanIdentifierParts();
-                return token = 81 /* PrivateIdentifier */;
-              }
-              const cookedChar2 = peekUnicodeEscape();
-              if (cookedChar2 >= 0 && isIdentifierStart(cookedChar2, languageVersion)) {
-                pos += 6;
-                tokenFlags |= 1024 /* UnicodeEscape */;
-                tokenValue = "#" + String.fromCharCode(cookedChar2) + scanIdentifierParts();
-                return token = 81 /* PrivateIdentifier */;
-              }
-              pos--;
-            }
-            if (isIdentifierStart(charAfterHash, languageVersion)) {
-              pos++;
-              scanIdentifier(charAfterHash, languageVersion);
-            } else {
-              tokenValue = "#";
-              error(Diagnostics.Invalid_character, pos++, charSize(ch));
-            }
-            return token = 81 /* PrivateIdentifier */;
-          default:
-            const identifierKind = scanIdentifier(ch, languageVersion);
-            if (identifierKind) {
-              return token = identifierKind;
-            } else if (isWhiteSpaceSingleLine(ch)) {
-              pos += charSize(ch);
-              continue;
-            } else if (isLineBreak(ch)) {
-              tokenFlags |= 1 /* PrecedingLineBreak */;
-              pos += charSize(ch);
-              continue;
-            }
-            const size = charSize(ch);
-            error(Diagnostics.Invalid_character, pos, size);
-            pos += size;
-            return token = 0 /* Unknown */;
-        }
-      }
-    }
-    function reScanInvalidIdentifier() {
-      Debug.assert(token === 0 /* Unknown */, "'reScanInvalidIdentifier' should only be called when the current token is 'SyntaxKind.Unknown'.");
-      pos = tokenStart = fullStartPos;
-      tokenFlags = 0;
-      const ch = codePointAt(text, pos);
-      const identifierKind = scanIdentifier(ch, 99 /* ESNext */);
-      if (identifierKind) {
-        return token = identifierKind;
-      }
-      pos += charSize(ch);
-      return token;
-    }
-    function scanIdentifier(startCharacter, languageVersion2) {
-      let ch = startCharacter;
-      if (isIdentifierStart(ch, languageVersion2)) {
-        pos += charSize(ch);
-        while (pos < end && isIdentifierPart(ch = codePointAt(text, pos), languageVersion2))
-          pos += charSize(ch);
-        tokenValue = text.substring(tokenStart, pos);
-        if (ch === 92 /* backslash */) {
-          tokenValue += scanIdentifierParts();
-        }
-        return getIdentifierToken();
-      }
-    }
-    function reScanGreaterToken() {
-      if (token === 32 /* GreaterThanToken */) {
-        if (text.charCodeAt(pos) === 62 /* greaterThan */) {
-          if (text.charCodeAt(pos + 1) === 62 /* greaterThan */) {
-            if (text.charCodeAt(pos + 2) === 61 /* equals */) {
-              return pos += 3, token = 73 /* GreaterThanGreaterThanGreaterThanEqualsToken */;
-            }
-            return pos += 2, token = 50 /* GreaterThanGreaterThanGreaterThanToken */;
-          }
-          if (text.charCodeAt(pos + 1) === 61 /* equals */) {
-            return pos += 2, token = 72 /* GreaterThanGreaterThanEqualsToken */;
-          }
-          pos++;
-          return token = 49 /* GreaterThanGreaterThanToken */;
-        }
-        if (text.charCodeAt(pos) === 61 /* equals */) {
-          pos++;
-          return token = 34 /* GreaterThanEqualsToken */;
-        }
-      }
-      return token;
-    }
-    function reScanAsteriskEqualsToken() {
-      Debug.assert(token === 67 /* AsteriskEqualsToken */, "'reScanAsteriskEqualsToken' should only be called on a '*='");
-      pos = tokenStart + 1;
-      return token = 64 /* EqualsToken */;
-    }
-    function reScanSlashToken() {
-      if (token === 44 /* SlashToken */ || token === 69 /* SlashEqualsToken */) {
-        let p = tokenStart + 1;
-        let inEscape = false;
-        let inCharacterClass = false;
-        while (true) {
-          if (p >= end) {
-            tokenFlags |= 4 /* Unterminated */;
-            error(Diagnostics.Unterminated_regular_expression_literal);
-            break;
-          }
-          const ch = text.charCodeAt(p);
-          if (isLineBreak(ch)) {
-            tokenFlags |= 4 /* Unterminated */;
-            error(Diagnostics.Unterminated_regular_expression_literal);
-            break;
-          }
-          if (inEscape) {
-            inEscape = false;
-          } else if (ch === 47 /* slash */ && !inCharacterClass) {
-            p++;
-            break;
-          } else if (ch === 91 /* openBracket */) {
-            inCharacterClass = true;
-          } else if (ch === 92 /* backslash */) {
-            inEscape = true;
-          } else if (ch === 93 /* closeBracket */) {
-            inCharacterClass = false;
-          }
-          p++;
-        }
-        while (p < end && isIdentifierPart(text.charCodeAt(p), languageVersion)) {
-          p++;
-        }
-        pos = p;
-        tokenValue = text.substring(tokenStart, pos);
-        token = 14 /* RegularExpressionLiteral */;
-      }
-      return token;
-    }
-    function appendIfCommentDirective(commentDirectives2, text2, commentDirectiveRegEx, lineStart) {
-      const type = getDirectiveFromComment(trimStringStart(text2), commentDirectiveRegEx);
-      if (type === void 0) {
-        return commentDirectives2;
-      }
-      return append(
-        commentDirectives2,
-        {
-          range: { pos: lineStart, end: pos },
-          type
-        }
-      );
-    }
-    function getDirectiveFromComment(text2, commentDirectiveRegEx) {
-      const match = commentDirectiveRegEx.exec(text2);
-      if (!match) {
-        return void 0;
-      }
-      switch (match[1]) {
-        case "ts-expect-error":
-          return 0 /* ExpectError */;
-        case "ts-ignore":
-          return 1 /* Ignore */;
-      }
-      return void 0;
-    }
-    function reScanTemplateToken(isTaggedTemplate) {
-      pos = tokenStart;
-      return token = scanTemplateAndSetTokenValue(!isTaggedTemplate);
-    }
-    function reScanTemplateHeadOrNoSubstitutionTemplate() {
-      pos = tokenStart;
-      return token = scanTemplateAndSetTokenValue(
-        /*shouldEmitInvalidEscapeError*/
-        true
-      );
-    }
-    function reScanJsxToken(allowMultilineJsxText = true) {
-      pos = tokenStart = fullStartPos;
-      return token = scanJsxToken(allowMultilineJsxText);
-    }
-    function reScanLessThanToken() {
-      if (token === 48 /* LessThanLessThanToken */) {
-        pos = tokenStart + 1;
-        return token = 30 /* LessThanToken */;
-      }
-      return token;
-    }
-    function reScanHashToken() {
-      if (token === 81 /* PrivateIdentifier */) {
-        pos = tokenStart + 1;
-        return token = 63 /* HashToken */;
-      }
-      return token;
-    }
-    function reScanQuestionToken() {
-      Debug.assert(token === 61 /* QuestionQuestionToken */, "'reScanQuestionToken' should only be called on a '??'");
-      pos = tokenStart + 1;
-      return token = 58 /* QuestionToken */;
-    }
-    function scanJsxToken(allowMultilineJsxText = true) {
-      fullStartPos = tokenStart = pos;
-      if (pos >= end) {
-        return token = 1 /* EndOfFileToken */;
-      }
-      let char = text.charCodeAt(pos);
-      if (char === 60 /* lessThan */) {
-        if (text.charCodeAt(pos + 1) === 47 /* slash */) {
-          pos += 2;
-          return token = 31 /* LessThanSlashToken */;
-        }
-        pos++;
-        return token = 30 /* LessThanToken */;
-      }
-      if (char === 123 /* openBrace */) {
-        pos++;
-        return token = 19 /* OpenBraceToken */;
-      }
-      let firstNonWhitespace = 0;
-      while (pos < end) {
-        char = text.charCodeAt(pos);
-        if (char === 123 /* openBrace */) {
-          break;
-        }
-        if (char === 60 /* lessThan */) {
-          if (isConflictMarkerTrivia(text, pos)) {
-            pos = scanConflictMarkerTrivia(text, pos, error);
-            return token = 7 /* ConflictMarkerTrivia */;
-          }
-          break;
-        }
-        if (char === 62 /* greaterThan */) {
-          error(Diagnostics.Unexpected_token_Did_you_mean_or_gt, pos, 1);
-        }
-        if (char === 125 /* closeBrace */) {
-          error(Diagnostics.Unexpected_token_Did_you_mean_or_rbrace, pos, 1);
-        }
-        if (isLineBreak(char) && firstNonWhitespace === 0) {
-          firstNonWhitespace = -1;
-        } else if (!allowMultilineJsxText && isLineBreak(char) && firstNonWhitespace > 0) {
-          break;
-        } else if (!isWhiteSpaceLike(char)) {
-          firstNonWhitespace = pos;
-        }
-        pos++;
-      }
-      tokenValue = text.substring(fullStartPos, pos);
-      return firstNonWhitespace === -1 ? 13 /* JsxTextAllWhiteSpaces */ : 12 /* JsxText */;
-    }
-    function scanJsxIdentifier() {
-      if (tokenIsIdentifierOrKeyword(token)) {
-        while (pos < end) {
-          const ch = text.charCodeAt(pos);
-          if (ch === 45 /* minus */) {
-            tokenValue += "-";
-            pos++;
-            continue;
-          }
-          const oldPos = pos;
-          tokenValue += scanIdentifierParts();
-          if (pos === oldPos) {
-            break;
-          }
-        }
-        return getIdentifierToken();
-      }
-      return token;
-    }
-    function scanJsxAttributeValue() {
-      fullStartPos = pos;
-      switch (text.charCodeAt(pos)) {
-        case 34 /* doubleQuote */:
-        case 39 /* singleQuote */:
-          tokenValue = scanString(
-            /*jsxAttributeString*/
-            true
-          );
-          return token = 11 /* StringLiteral */;
-        default:
-          return scan();
-      }
-    }
-    function reScanJsxAttributeValue() {
-      pos = tokenStart = fullStartPos;
-      return scanJsxAttributeValue();
-    }
-    function scanJSDocCommentTextToken(inBackticks) {
-      fullStartPos = tokenStart = pos;
-      tokenFlags = 0 /* None */;
-      if (pos >= end) {
-        return token = 1 /* EndOfFileToken */;
-      }
-      for (let ch = text.charCodeAt(pos); pos < end && (!isLineBreak(ch) && ch !== 96 /* backtick */); ch = codePointAt(text, ++pos)) {
-        if (!inBackticks) {
-          if (ch === 123 /* openBrace */) {
-            break;
-          } else if (ch === 64 /* at */ && pos - 1 >= 0 && isWhiteSpaceSingleLine(text.charCodeAt(pos - 1)) && !(pos + 1 < end && isWhiteSpaceLike(text.charCodeAt(pos + 1)))) {
-            break;
-          }
-        }
-      }
-      if (pos === tokenStart) {
-        return scanJsDocToken();
-      }
-      tokenValue = text.substring(tokenStart, pos);
-      return token = 82 /* JSDocCommentTextToken */;
-    }
-    function scanJsDocToken() {
-      fullStartPos = tokenStart = pos;
-      tokenFlags = 0 /* None */;
-      if (pos >= end) {
-        return token = 1 /* EndOfFileToken */;
-      }
-      const ch = codePointAt(text, pos);
-      pos += charSize(ch);
-      switch (ch) {
-        case 9 /* tab */:
-        case 11 /* verticalTab */:
-        case 12 /* formFeed */:
-        case 32 /* space */:
-          while (pos < end && isWhiteSpaceSingleLine(text.charCodeAt(pos))) {
-            pos++;
-          }
-          return token = 5 /* WhitespaceTrivia */;
-        case 64 /* at */:
-          return token = 60 /* AtToken */;
-        case 13 /* carriageReturn */:
-          if (text.charCodeAt(pos) === 10 /* lineFeed */) {
-            pos++;
-          }
-        case 10 /* lineFeed */:
-          tokenFlags |= 1 /* PrecedingLineBreak */;
-          return token = 4 /* NewLineTrivia */;
-        case 42 /* asterisk */:
-          return token = 42 /* AsteriskToken */;
-        case 123 /* openBrace */:
-          return token = 19 /* OpenBraceToken */;
-        case 125 /* closeBrace */:
-          return token = 20 /* CloseBraceToken */;
-        case 91 /* openBracket */:
-          return token = 23 /* OpenBracketToken */;
-        case 93 /* closeBracket */:
-          return token = 24 /* CloseBracketToken */;
-        case 60 /* lessThan */:
-          return token = 30 /* LessThanToken */;
-        case 62 /* greaterThan */:
-          return token = 32 /* GreaterThanToken */;
-        case 61 /* equals */:
-          return token = 64 /* EqualsToken */;
-        case 44 /* comma */:
-          return token = 28 /* CommaToken */;
-        case 46 /* dot */:
-          return token = 25 /* DotToken */;
-        case 96 /* backtick */:
-          return token = 62 /* BacktickToken */;
-        case 35 /* hash */:
-          return token = 63 /* HashToken */;
-        case 92 /* backslash */:
-          pos--;
-          const extendedCookedChar = peekExtendedUnicodeEscape();
-          if (extendedCookedChar >= 0 && isIdentifierStart(extendedCookedChar, languageVersion)) {
-            pos += 3;
-            tokenFlags |= 8 /* ExtendedUnicodeEscape */;
-            tokenValue = scanExtendedUnicodeEscape() + scanIdentifierParts();
-            return token = getIdentifierToken();
-          }
-          const cookedChar = peekUnicodeEscape();
-          if (cookedChar >= 0 && isIdentifierStart(cookedChar, languageVersion)) {
-            pos += 6;
-            tokenFlags |= 1024 /* UnicodeEscape */;
-            tokenValue = String.fromCharCode(cookedChar) + scanIdentifierParts();
-            return token = getIdentifierToken();
-          }
-          pos++;
-          return token = 0 /* Unknown */;
-      }
-      if (isIdentifierStart(ch, languageVersion)) {
-        let char = ch;
-        while (pos < end && isIdentifierPart(char = codePointAt(text, pos), languageVersion) || text.charCodeAt(pos) === 45 /* minus */)
-          pos += charSize(char);
-        tokenValue = text.substring(tokenStart, pos);
-        if (char === 92 /* backslash */) {
-          tokenValue += scanIdentifierParts();
-        }
-        return token = getIdentifierToken();
-      } else {
-        return token = 0 /* Unknown */;
-      }
-    }
-    function speculationHelper(callback, isLookahead) {
-      const savePos = pos;
-      const saveStartPos = fullStartPos;
-      const saveTokenPos = tokenStart;
-      const saveToken = token;
-      const saveTokenValue = tokenValue;
-      const saveTokenFlags = tokenFlags;
-      const result = callback();
-      if (!result || isLookahead) {
-        pos = savePos;
-        fullStartPos = saveStartPos;
-        tokenStart = saveTokenPos;
-        token = saveToken;
-        tokenValue = saveTokenValue;
-        tokenFlags = saveTokenFlags;
-      }
-      return result;
-    }
-    function scanRange(start2, length3, callback) {
-      const saveEnd = end;
-      const savePos = pos;
-      const saveStartPos = fullStartPos;
-      const saveTokenPos = tokenStart;
-      const saveToken = token;
-      const saveTokenValue = tokenValue;
-      const saveTokenFlags = tokenFlags;
-      const saveErrorExpectations = commentDirectives;
-      setText(text, start2, length3);
-      const result = callback();
-      end = saveEnd;
-      pos = savePos;
-      fullStartPos = saveStartPos;
-      tokenStart = saveTokenPos;
-      token = saveToken;
-      tokenValue = saveTokenValue;
-      tokenFlags = saveTokenFlags;
-      commentDirectives = saveErrorExpectations;
-      return result;
-    }
-    function lookAhead(callback) {
-      return speculationHelper(
-        callback,
-        /*isLookahead*/
-        true
-      );
-    }
-    function tryScan(callback) {
-      return speculationHelper(
-        callback,
-        /*isLookahead*/
-        false
-      );
-    }
-    function getText() {
-      return text;
-    }
-    function clearCommentDirectives() {
-      commentDirectives = void 0;
-    }
-    function setText(newText, start2, length3) {
-      text = newText || "";
-      end = length3 === void 0 ? text.length : start2 + length3;
-      resetTokenState(start2 || 0);
-    }
-    function setOnError(errorCallback) {
-      onError = errorCallback;
-    }
-    function setScriptTarget(scriptTarget) {
-      languageVersion = scriptTarget;
-    }
-    function setLanguageVariant(variant) {
-      languageVariant = variant;
-    }
-    function resetTokenState(position) {
-      Debug.assert(position >= 0);
-      pos = position;
-      fullStartPos = position;
-      tokenStart = position;
-      token = 0 /* Unknown */;
-      tokenValue = void 0;
-      tokenFlags = 0 /* None */;
-    }
-    function setInJSDocType(inType) {
-      inJSDocType += inType ? 1 : -1;
-    }
-  }
-  function charSize(ch) {
-    if (ch >= 65536) {
-      return 2;
-    }
-    return 1;
-  }
-  function utf16EncodeAsStringFallback(codePoint) {
-    Debug.assert(0 <= codePoint && codePoint <= 1114111);
-    if (codePoint <= 65535) {
-      return String.fromCharCode(codePoint);
-    }
-    const codeUnit1 = Math.floor((codePoint - 65536) / 1024) + 55296;
-    const codeUnit2 = (codePoint - 65536) % 1024 + 56320;
-    return String.fromCharCode(codeUnit1, codeUnit2);
-  }
-  function utf16EncodeAsString(codePoint) {
-    return utf16EncodeAsStringWorker(codePoint);
-  }
-  var textToKeywordObj, textToKeyword, textToToken, unicodeES3IdentifierStart, unicodeES3IdentifierPart, unicodeES5IdentifierStart, unicodeES5IdentifierPart, unicodeESNextIdentifierStart, unicodeESNextIdentifierPart, commentDirectiveRegExSingleLine, commentDirectiveRegExMultiLine, tokenStrings, mergeConflictMarkerLength, shebangTriviaRegex, codePointAt, utf16EncodeAsStringWorker;
-  var init_scanner = __esm({
-    "src/compiler/scanner.ts"() {
-      "use strict";
-      init_ts2();
-      textToKeywordObj = {
-        abstract: 128 /* AbstractKeyword */,
-        accessor: 129 /* AccessorKeyword */,
-        any: 133 /* AnyKeyword */,
-        as: 130 /* AsKeyword */,
-        asserts: 131 /* AssertsKeyword */,
-        assert: 132 /* AssertKeyword */,
-        bigint: 162 /* BigIntKeyword */,
-        boolean: 136 /* BooleanKeyword */,
-        break: 83 /* BreakKeyword */,
-        case: 84 /* CaseKeyword */,
-        catch: 85 /* CatchKeyword */,
-        class: 86 /* ClassKeyword */,
-        continue: 88 /* ContinueKeyword */,
-        const: 87 /* ConstKeyword */,
-        ["constructor"]: 137 /* ConstructorKeyword */,
-        debugger: 89 /* DebuggerKeyword */,
-        declare: 138 /* DeclareKeyword */,
-        default: 90 /* DefaultKeyword */,
-        delete: 91 /* DeleteKeyword */,
-        do: 92 /* DoKeyword */,
-        else: 93 /* ElseKeyword */,
-        enum: 94 /* EnumKeyword */,
-        export: 95 /* ExportKeyword */,
-        extends: 96 /* ExtendsKeyword */,
-        false: 97 /* FalseKeyword */,
-        finally: 98 /* FinallyKeyword */,
-        for: 99 /* ForKeyword */,
-        from: 160 /* FromKeyword */,
-        function: 100 /* FunctionKeyword */,
-        get: 139 /* GetKeyword */,
-        if: 101 /* IfKeyword */,
-        implements: 119 /* ImplementsKeyword */,
-        import: 102 /* ImportKeyword */,
-        in: 103 /* InKeyword */,
-        infer: 140 /* InferKeyword */,
-        instanceof: 104 /* InstanceOfKeyword */,
-        interface: 120 /* InterfaceKeyword */,
-        intrinsic: 141 /* IntrinsicKeyword */,
-        is: 142 /* IsKeyword */,
-        keyof: 143 /* KeyOfKeyword */,
-        let: 121 /* LetKeyword */,
-        module: 144 /* ModuleKeyword */,
-        namespace: 145 /* NamespaceKeyword */,
-        never: 146 /* NeverKeyword */,
-        new: 105 /* NewKeyword */,
-        null: 106 /* NullKeyword */,
-        number: 150 /* NumberKeyword */,
-        object: 151 /* ObjectKeyword */,
-        package: 122 /* PackageKeyword */,
-        private: 123 /* PrivateKeyword */,
-        protected: 124 /* ProtectedKeyword */,
-        public: 125 /* PublicKeyword */,
-        override: 163 /* OverrideKeyword */,
-        out: 147 /* OutKeyword */,
-        readonly: 148 /* ReadonlyKeyword */,
-        require: 149 /* RequireKeyword */,
-        global: 161 /* GlobalKeyword */,
-        return: 107 /* ReturnKeyword */,
-        satisfies: 152 /* SatisfiesKeyword */,
-        set: 153 /* SetKeyword */,
-        static: 126 /* StaticKeyword */,
-        string: 154 /* StringKeyword */,
-        super: 108 /* SuperKeyword */,
-        switch: 109 /* SwitchKeyword */,
-        symbol: 155 /* SymbolKeyword */,
-        this: 110 /* ThisKeyword */,
-        throw: 111 /* ThrowKeyword */,
-        true: 112 /* TrueKeyword */,
-        try: 113 /* TryKeyword */,
-        type: 156 /* TypeKeyword */,
-        typeof: 114 /* TypeOfKeyword */,
-        undefined: 157 /* UndefinedKeyword */,
-        unique: 158 /* UniqueKeyword */,
-        unknown: 159 /* UnknownKeyword */,
-        var: 115 /* VarKeyword */,
-        void: 116 /* VoidKeyword */,
-        while: 117 /* WhileKeyword */,
-        with: 118 /* WithKeyword */,
-        yield: 127 /* YieldKeyword */,
-        async: 134 /* AsyncKeyword */,
-        await: 135 /* AwaitKeyword */,
-        of: 164 /* OfKeyword */
-      };
-      textToKeyword = new Map(Object.entries(textToKeywordObj));
-      textToToken = new Map(Object.entries({
-        ...textToKeywordObj,
-        "{": 19 /* OpenBraceToken */,
-        "}": 20 /* CloseBraceToken */,
-        "(": 21 /* OpenParenToken */,
-        ")": 22 /* CloseParenToken */,
-        "[": 23 /* OpenBracketToken */,
-        "]": 24 /* CloseBracketToken */,
-        ".": 25 /* DotToken */,
-        "...": 26 /* DotDotDotToken */,
-        ";": 27 /* SemicolonToken */,
-        ",": 28 /* CommaToken */,
-        "<": 30 /* LessThanToken */,
-        ">": 32 /* GreaterThanToken */,
-        "<=": 33 /* LessThanEqualsToken */,
-        ">=": 34 /* GreaterThanEqualsToken */,
-        "==": 35 /* EqualsEqualsToken */,
-        "!=": 36 /* ExclamationEqualsToken */,
-        "===": 37 /* EqualsEqualsEqualsToken */,
-        "!==": 38 /* ExclamationEqualsEqualsToken */,
-        "=>": 39 /* EqualsGreaterThanToken */,
-        "+": 40 /* PlusToken */,
-        "-": 41 /* MinusToken */,
-        "**": 43 /* AsteriskAsteriskToken */,
-        "*": 42 /* AsteriskToken */,
-        "/": 44 /* SlashToken */,
-        "%": 45 /* PercentToken */,
-        "++": 46 /* PlusPlusToken */,
-        "--": 47 /* MinusMinusToken */,
-        "<<": 48 /* LessThanLessThanToken */,
-        ">": 49 /* GreaterThanGreaterThanToken */,
-        ">>>": 50 /* GreaterThanGreaterThanGreaterThanToken */,
-        "&": 51 /* AmpersandToken */,
-        "|": 52 /* BarToken */,
-        "^": 53 /* CaretToken */,
-        "!": 54 /* ExclamationToken */,
-        "~": 55 /* TildeToken */,
-        "&&": 56 /* AmpersandAmpersandToken */,
-        "||": 57 /* BarBarToken */,
-        "?": 58 /* QuestionToken */,
-        "??": 61 /* QuestionQuestionToken */,
-        "?.": 29 /* QuestionDotToken */,
-        ":": 59 /* ColonToken */,
-        "=": 64 /* EqualsToken */,
-        "+=": 65 /* PlusEqualsToken */,
-        "-=": 66 /* MinusEqualsToken */,
-        "*=": 67 /* AsteriskEqualsToken */,
-        "**=": 68 /* AsteriskAsteriskEqualsToken */,
-        "/=": 69 /* SlashEqualsToken */,
-        "%=": 70 /* PercentEqualsToken */,
-        "<<=": 71 /* LessThanLessThanEqualsToken */,
-        ">>=": 72 /* GreaterThanGreaterThanEqualsToken */,
-        ">>>=": 73 /* GreaterThanGreaterThanGreaterThanEqualsToken */,
-        "&=": 74 /* AmpersandEqualsToken */,
-        "|=": 75 /* BarEqualsToken */,
-        "^=": 79 /* CaretEqualsToken */,
-        "||=": 76 /* BarBarEqualsToken */,
-        "&&=": 77 /* AmpersandAmpersandEqualsToken */,
-        "??=": 78 /* QuestionQuestionEqualsToken */,
-        "@": 60 /* AtToken */,
-        "#": 63 /* HashToken */,
-        "`": 62 /* BacktickToken */
-      }));
-      unicodeES3IdentifierStart = [170, 170, 181, 181, 186, 186, 192, 214, 216, 246, 248, 543, 546, 563, 592, 685, 688, 696, 699, 705, 720, 721, 736, 740, 750, 750, 890, 890, 902, 902, 904, 906, 908, 908, 910, 929, 931, 974, 976, 983, 986, 1011, 1024, 1153, 1164, 1220, 1223, 1224, 1227, 1228, 1232, 1269, 1272, 1273, 1329, 1366, 1369, 1369, 1377, 1415, 1488, 1514, 1520, 1522, 1569, 1594, 1600, 1610, 1649, 1747, 1749, 1749, 1765, 1766, 1786, 1788, 1808, 1808, 1810, 1836, 1920, 1957, 2309, 2361, 2365, 2365, 2384, 2384, 2392, 2401, 2437, 2444, 2447, 2448, 2451, 2472, 2474, 2480, 2482, 2482, 2486, 2489, 2524, 2525, 2527, 2529, 2544, 2545, 2565, 2570, 2575, 2576, 2579, 2600, 2602, 2608, 2610, 2611, 2613, 2614, 2616, 2617, 2649, 2652, 2654, 2654, 2674, 2676, 2693, 2699, 2701, 2701, 2703, 2705, 2707, 2728, 2730, 2736, 2738, 2739, 2741, 2745, 2749, 2749, 2768, 2768, 2784, 2784, 2821, 2828, 2831, 2832, 2835, 2856, 2858, 2864, 2866, 2867, 2870, 2873, 2877, 2877, 2908, 2909, 2911, 2913, 2949, 2954, 2958, 2960, 2962, 2965, 2969, 2970, 2972, 2972, 2974, 2975, 2979, 2980, 2984, 2986, 2990, 2997, 2999, 3001, 3077, 3084, 3086, 3088, 3090, 3112, 3114, 3123, 3125, 3129, 3168, 3169, 3205, 3212, 3214, 3216, 3218, 3240, 3242, 3251, 3253, 3257, 3294, 3294, 3296, 3297, 3333, 3340, 3342, 3344, 3346, 3368, 3370, 3385, 3424, 3425, 3461, 3478, 3482, 3505, 3507, 3515, 3517, 3517, 3520, 3526, 3585, 3632, 3634, 3635, 3648, 3654, 3713, 3714, 3716, 3716, 3719, 3720, 3722, 3722, 3725, 3725, 3732, 3735, 3737, 3743, 3745, 3747, 3749, 3749, 3751, 3751, 3754, 3755, 3757, 3760, 3762, 3763, 3773, 3773, 3776, 3780, 3782, 3782, 3804, 3805, 3840, 3840, 3904, 3911, 3913, 3946, 3976, 3979, 4096, 4129, 4131, 4135, 4137, 4138, 4176, 4181, 4256, 4293, 4304, 4342, 4352, 4441, 4447, 4514, 4520, 4601, 4608, 4614, 4616, 4678, 4680, 4680, 4682, 4685, 4688, 4694, 4696, 4696, 4698, 4701, 4704, 4742, 4744, 4744, 4746, 4749, 4752, 4782, 4784, 4784, 4786, 4789, 4792, 4798, 4800, 4800, 4802, 4805, 4808, 4814, 4816, 4822, 4824, 4846, 4848, 4878, 4880, 4880, 4882, 4885, 4888, 4894, 4896, 4934, 4936, 4954, 5024, 5108, 5121, 5740, 5743, 5750, 5761, 5786, 5792, 5866, 6016, 6067, 6176, 6263, 6272, 6312, 7680, 7835, 7840, 7929, 7936, 7957, 7960, 7965, 7968, 8005, 8008, 8013, 8016, 8023, 8025, 8025, 8027, 8027, 8029, 8029, 8031, 8061, 8064, 8116, 8118, 8124, 8126, 8126, 8130, 8132, 8134, 8140, 8144, 8147, 8150, 8155, 8160, 8172, 8178, 8180, 8182, 8188, 8319, 8319, 8450, 8450, 8455, 8455, 8458, 8467, 8469, 8469, 8473, 8477, 8484, 8484, 8486, 8486, 8488, 8488, 8490, 8493, 8495, 8497, 8499, 8505, 8544, 8579, 12293, 12295, 12321, 12329, 12337, 12341, 12344, 12346, 12353, 12436, 12445, 12446, 12449, 12538, 12540, 12542, 12549, 12588, 12593, 12686, 12704, 12727, 13312, 19893, 19968, 40869, 40960, 42124, 44032, 55203, 63744, 64045, 64256, 64262, 64275, 64279, 64285, 64285, 64287, 64296, 64298, 64310, 64312, 64316, 64318, 64318, 64320, 64321, 64323, 64324, 64326, 64433, 64467, 64829, 64848, 64911, 64914, 64967, 65008, 65019, 65136, 65138, 65140, 65140, 65142, 65276, 65313, 65338, 65345, 65370, 65382, 65470, 65474, 65479, 65482, 65487, 65490, 65495, 65498, 65500];
-      unicodeES3IdentifierPart = [170, 170, 181, 181, 186, 186, 192, 214, 216, 246, 248, 543, 546, 563, 592, 685, 688, 696, 699, 705, 720, 721, 736, 740, 750, 750, 768, 846, 864, 866, 890, 890, 902, 902, 904, 906, 908, 908, 910, 929, 931, 974, 976, 983, 986, 1011, 1024, 1153, 1155, 1158, 1164, 1220, 1223, 1224, 1227, 1228, 1232, 1269, 1272, 1273, 1329, 1366, 1369, 1369, 1377, 1415, 1425, 1441, 1443, 1465, 1467, 1469, 1471, 1471, 1473, 1474, 1476, 1476, 1488, 1514, 1520, 1522, 1569, 1594, 1600, 1621, 1632, 1641, 1648, 1747, 1749, 1756, 1759, 1768, 1770, 1773, 1776, 1788, 1808, 1836, 1840, 1866, 1920, 1968, 2305, 2307, 2309, 2361, 2364, 2381, 2384, 2388, 2392, 2403, 2406, 2415, 2433, 2435, 2437, 2444, 2447, 2448, 2451, 2472, 2474, 2480, 2482, 2482, 2486, 2489, 2492, 2492, 2494, 2500, 2503, 2504, 2507, 2509, 2519, 2519, 2524, 2525, 2527, 2531, 2534, 2545, 2562, 2562, 2565, 2570, 2575, 2576, 2579, 2600, 2602, 2608, 2610, 2611, 2613, 2614, 2616, 2617, 2620, 2620, 2622, 2626, 2631, 2632, 2635, 2637, 2649, 2652, 2654, 2654, 2662, 2676, 2689, 2691, 2693, 2699, 2701, 2701, 2703, 2705, 2707, 2728, 2730, 2736, 2738, 2739, 2741, 2745, 2748, 2757, 2759, 2761, 2763, 2765, 2768, 2768, 2784, 2784, 2790, 2799, 2817, 2819, 2821, 2828, 2831, 2832, 2835, 2856, 2858, 2864, 2866, 2867, 2870, 2873, 2876, 2883, 2887, 2888, 2891, 2893, 2902, 2903, 2908, 2909, 2911, 2913, 2918, 2927, 2946, 2947, 2949, 2954, 2958, 2960, 2962, 2965, 2969, 2970, 2972, 2972, 2974, 2975, 2979, 2980, 2984, 2986, 2990, 2997, 2999, 3001, 3006, 3010, 3014, 3016, 3018, 3021, 3031, 3031, 3047, 3055, 3073, 3075, 3077, 3084, 3086, 3088, 3090, 3112, 3114, 3123, 3125, 3129, 3134, 3140, 3142, 3144, 3146, 3149, 3157, 3158, 3168, 3169, 3174, 3183, 3202, 3203, 3205, 3212, 3214, 3216, 3218, 3240, 3242, 3251, 3253, 3257, 3262, 3268, 3270, 3272, 3274, 3277, 3285, 3286, 3294, 3294, 3296, 3297, 3302, 3311, 3330, 3331, 3333, 3340, 3342, 3344, 3346, 3368, 3370, 3385, 3390, 3395, 3398, 3400, 3402, 3405, 3415, 3415, 3424, 3425, 3430, 3439, 3458, 3459, 3461, 3478, 3482, 3505, 3507, 3515, 3517, 3517, 3520, 3526, 3530, 3530, 3535, 3540, 3542, 3542, 3544, 3551, 3570, 3571, 3585, 3642, 3648, 3662, 3664, 3673, 3713, 3714, 3716, 3716, 3719, 3720, 3722, 3722, 3725, 3725, 3732, 3735, 3737, 3743, 3745, 3747, 3749, 3749, 3751, 3751, 3754, 3755, 3757, 3769, 3771, 3773, 3776, 3780, 3782, 3782, 3784, 3789, 3792, 3801, 3804, 3805, 3840, 3840, 3864, 3865, 3872, 3881, 3893, 3893, 3895, 3895, 3897, 3897, 3902, 3911, 3913, 3946, 3953, 3972, 3974, 3979, 3984, 3991, 3993, 4028, 4038, 4038, 4096, 4129, 4131, 4135, 4137, 4138, 4140, 4146, 4150, 4153, 4160, 4169, 4176, 4185, 4256, 4293, 4304, 4342, 4352, 4441, 4447, 4514, 4520, 4601, 4608, 4614, 4616, 4678, 4680, 4680, 4682, 4685, 4688, 4694, 4696, 4696, 4698, 4701, 4704, 4742, 4744, 4744, 4746, 4749, 4752, 4782, 4784, 4784, 4786, 4789, 4792, 4798, 4800, 4800, 4802, 4805, 4808, 4814, 4816, 4822, 4824, 4846, 4848, 4878, 4880, 4880, 4882, 4885, 4888, 4894, 4896, 4934, 4936, 4954, 4969, 4977, 5024, 5108, 5121, 5740, 5743, 5750, 5761, 5786, 5792, 5866, 6016, 6099, 6112, 6121, 6160, 6169, 6176, 6263, 6272, 6313, 7680, 7835, 7840, 7929, 7936, 7957, 7960, 7965, 7968, 8005, 8008, 8013, 8016, 8023, 8025, 8025, 8027, 8027, 8029, 8029, 8031, 8061, 8064, 8116, 8118, 8124, 8126, 8126, 8130, 8132, 8134, 8140, 8144, 8147, 8150, 8155, 8160, 8172, 8178, 8180, 8182, 8188, 8255, 8256, 8319, 8319, 8400, 8412, 8417, 8417, 8450, 8450, 8455, 8455, 8458, 8467, 8469, 8469, 8473, 8477, 8484, 8484, 8486, 8486, 8488, 8488, 8490, 8493, 8495, 8497, 8499, 8505, 8544, 8579, 12293, 12295, 12321, 12335, 12337, 12341, 12344, 12346, 12353, 12436, 12441, 12442, 12445, 12446, 12449, 12542, 12549, 12588, 12593, 12686, 12704, 12727, 13312, 19893, 19968, 40869, 40960, 42124, 44032, 55203, 63744, 64045, 64256, 64262, 64275, 64279, 64285, 64296, 64298, 64310, 64312, 64316, 64318, 64318, 64320, 64321, 64323, 64324, 64326, 64433, 64467, 64829, 64848, 64911, 64914, 64967, 65008, 65019, 65056, 65059, 65075, 65076, 65101, 65103, 65136, 65138, 65140, 65140, 65142, 65276, 65296, 65305, 65313, 65338, 65343, 65343, 65345, 65370, 65381, 65470, 65474, 65479, 65482, 65487, 65490, 65495, 65498, 65500];
-      unicodeES5IdentifierStart = [170, 170, 181, 181, 186, 186, 192, 214, 216, 246, 248, 705, 710, 721, 736, 740, 748, 748, 750, 750, 880, 884, 886, 887, 890, 893, 902, 902, 904, 906, 908, 908, 910, 929, 931, 1013, 1015, 1153, 1162, 1319, 1329, 1366, 1369, 1369, 1377, 1415, 1488, 1514, 1520, 1522, 1568, 1610, 1646, 1647, 1649, 1747, 1749, 1749, 1765, 1766, 1774, 1775, 1786, 1788, 1791, 1791, 1808, 1808, 1810, 1839, 1869, 1957, 1969, 1969, 1994, 2026, 2036, 2037, 2042, 2042, 2048, 2069, 2074, 2074, 2084, 2084, 2088, 2088, 2112, 2136, 2208, 2208, 2210, 2220, 2308, 2361, 2365, 2365, 2384, 2384, 2392, 2401, 2417, 2423, 2425, 2431, 2437, 2444, 2447, 2448, 2451, 2472, 2474, 2480, 2482, 2482, 2486, 2489, 2493, 2493, 2510, 2510, 2524, 2525, 2527, 2529, 2544, 2545, 2565, 2570, 2575, 2576, 2579, 2600, 2602, 2608, 2610, 2611, 2613, 2614, 2616, 2617, 2649, 2652, 2654, 2654, 2674, 2676, 2693, 2701, 2703, 2705, 2707, 2728, 2730, 2736, 2738, 2739, 2741, 2745, 2749, 2749, 2768, 2768, 2784, 2785, 2821, 2828, 2831, 2832, 2835, 2856, 2858, 2864, 2866, 2867, 2869, 2873, 2877, 2877, 2908, 2909, 2911, 2913, 2929, 2929, 2947, 2947, 2949, 2954, 2958, 2960, 2962, 2965, 2969, 2970, 2972, 2972, 2974, 2975, 2979, 2980, 2984, 2986, 2990, 3001, 3024, 3024, 3077, 3084, 3086, 3088, 3090, 3112, 3114, 3123, 3125, 3129, 3133, 3133, 3160, 3161, 3168, 3169, 3205, 3212, 3214, 3216, 3218, 3240, 3242, 3251, 3253, 3257, 3261, 3261, 3294, 3294, 3296, 3297, 3313, 3314, 3333, 3340, 3342, 3344, 3346, 3386, 3389, 3389, 3406, 3406, 3424, 3425, 3450, 3455, 3461, 3478, 3482, 3505, 3507, 3515, 3517, 3517, 3520, 3526, 3585, 3632, 3634, 3635, 3648, 3654, 3713, 3714, 3716, 3716, 3719, 3720, 3722, 3722, 3725, 3725, 3732, 3735, 3737, 3743, 3745, 3747, 3749, 3749, 3751, 3751, 3754, 3755, 3757, 3760, 3762, 3763, 3773, 3773, 3776, 3780, 3782, 3782, 3804, 3807, 3840, 3840, 3904, 3911, 3913, 3948, 3976, 3980, 4096, 4138, 4159, 4159, 4176, 4181, 4186, 4189, 4193, 4193, 4197, 4198, 4206, 4208, 4213, 4225, 4238, 4238, 4256, 4293, 4295, 4295, 4301, 4301, 4304, 4346, 4348, 4680, 4682, 4685, 4688, 4694, 4696, 4696, 4698, 4701, 4704, 4744, 4746, 4749, 4752, 4784, 4786, 4789, 4792, 4798, 4800, 4800, 4802, 4805, 4808, 4822, 4824, 4880, 4882, 4885, 4888, 4954, 4992, 5007, 5024, 5108, 5121, 5740, 5743, 5759, 5761, 5786, 5792, 5866, 5870, 5872, 5888, 5900, 5902, 5905, 5920, 5937, 5952, 5969, 5984, 5996, 5998, 6e3, 6016, 6067, 6103, 6103, 6108, 6108, 6176, 6263, 6272, 6312, 6314, 6314, 6320, 6389, 6400, 6428, 6480, 6509, 6512, 6516, 6528, 6571, 6593, 6599, 6656, 6678, 6688, 6740, 6823, 6823, 6917, 6963, 6981, 6987, 7043, 7072, 7086, 7087, 7098, 7141, 7168, 7203, 7245, 7247, 7258, 7293, 7401, 7404, 7406, 7409, 7413, 7414, 7424, 7615, 7680, 7957, 7960, 7965, 7968, 8005, 8008, 8013, 8016, 8023, 8025, 8025, 8027, 8027, 8029, 8029, 8031, 8061, 8064, 8116, 8118, 8124, 8126, 8126, 8130, 8132, 8134, 8140, 8144, 8147, 8150, 8155, 8160, 8172, 8178, 8180, 8182, 8188, 8305, 8305, 8319, 8319, 8336, 8348, 8450, 8450, 8455, 8455, 8458, 8467, 8469, 8469, 8473, 8477, 8484, 8484, 8486, 8486, 8488, 8488, 8490, 8493, 8495, 8505, 8508, 8511, 8517, 8521, 8526, 8526, 8544, 8584, 11264, 11310, 11312, 11358, 11360, 11492, 11499, 11502, 11506, 11507, 11520, 11557, 11559, 11559, 11565, 11565, 11568, 11623, 11631, 11631, 11648, 11670, 11680, 11686, 11688, 11694, 11696, 11702, 11704, 11710, 11712, 11718, 11720, 11726, 11728, 11734, 11736, 11742, 11823, 11823, 12293, 12295, 12321, 12329, 12337, 12341, 12344, 12348, 12353, 12438, 12445, 12447, 12449, 12538, 12540, 12543, 12549, 12589, 12593, 12686, 12704, 12730, 12784, 12799, 13312, 19893, 19968, 40908, 40960, 42124, 42192, 42237, 42240, 42508, 42512, 42527, 42538, 42539, 42560, 42606, 42623, 42647, 42656, 42735, 42775, 42783, 42786, 42888, 42891, 42894, 42896, 42899, 42912, 42922, 43e3, 43009, 43011, 43013, 43015, 43018, 43020, 43042, 43072, 43123, 43138, 43187, 43250, 43255, 43259, 43259, 43274, 43301, 43312, 43334, 43360, 43388, 43396, 43442, 43471, 43471, 43520, 43560, 43584, 43586, 43588, 43595, 43616, 43638, 43642, 43642, 43648, 43695, 43697, 43697, 43701, 43702, 43705, 43709, 43712, 43712, 43714, 43714, 43739, 43741, 43744, 43754, 43762, 43764, 43777, 43782, 43785, 43790, 43793, 43798, 43808, 43814, 43816, 43822, 43968, 44002, 44032, 55203, 55216, 55238, 55243, 55291, 63744, 64109, 64112, 64217, 64256, 64262, 64275, 64279, 64285, 64285, 64287, 64296, 64298, 64310, 64312, 64316, 64318, 64318, 64320, 64321, 64323, 64324, 64326, 64433, 64467, 64829, 64848, 64911, 64914, 64967, 65008, 65019, 65136, 65140, 65142, 65276, 65313, 65338, 65345, 65370, 65382, 65470, 65474, 65479, 65482, 65487, 65490, 65495, 65498, 65500];
-      unicodeES5IdentifierPart = [170, 170, 181, 181, 186, 186, 192, 214, 216, 246, 248, 705, 710, 721, 736, 740, 748, 748, 750, 750, 768, 884, 886, 887, 890, 893, 902, 902, 904, 906, 908, 908, 910, 929, 931, 1013, 1015, 1153, 1155, 1159, 1162, 1319, 1329, 1366, 1369, 1369, 1377, 1415, 1425, 1469, 1471, 1471, 1473, 1474, 1476, 1477, 1479, 1479, 1488, 1514, 1520, 1522, 1552, 1562, 1568, 1641, 1646, 1747, 1749, 1756, 1759, 1768, 1770, 1788, 1791, 1791, 1808, 1866, 1869, 1969, 1984, 2037, 2042, 2042, 2048, 2093, 2112, 2139, 2208, 2208, 2210, 2220, 2276, 2302, 2304, 2403, 2406, 2415, 2417, 2423, 2425, 2431, 2433, 2435, 2437, 2444, 2447, 2448, 2451, 2472, 2474, 2480, 2482, 2482, 2486, 2489, 2492, 2500, 2503, 2504, 2507, 2510, 2519, 2519, 2524, 2525, 2527, 2531, 2534, 2545, 2561, 2563, 2565, 2570, 2575, 2576, 2579, 2600, 2602, 2608, 2610, 2611, 2613, 2614, 2616, 2617, 2620, 2620, 2622, 2626, 2631, 2632, 2635, 2637, 2641, 2641, 2649, 2652, 2654, 2654, 2662, 2677, 2689, 2691, 2693, 2701, 2703, 2705, 2707, 2728, 2730, 2736, 2738, 2739, 2741, 2745, 2748, 2757, 2759, 2761, 2763, 2765, 2768, 2768, 2784, 2787, 2790, 2799, 2817, 2819, 2821, 2828, 2831, 2832, 2835, 2856, 2858, 2864, 2866, 2867, 2869, 2873, 2876, 2884, 2887, 2888, 2891, 2893, 2902, 2903, 2908, 2909, 2911, 2915, 2918, 2927, 2929, 2929, 2946, 2947, 2949, 2954, 2958, 2960, 2962, 2965, 2969, 2970, 2972, 2972, 2974, 2975, 2979, 2980, 2984, 2986, 2990, 3001, 3006, 3010, 3014, 3016, 3018, 3021, 3024, 3024, 3031, 3031, 3046, 3055, 3073, 3075, 3077, 3084, 3086, 3088, 3090, 3112, 3114, 3123, 3125, 3129, 3133, 3140, 3142, 3144, 3146, 3149, 3157, 3158, 3160, 3161, 3168, 3171, 3174, 3183, 3202, 3203, 3205, 3212, 3214, 3216, 3218, 3240, 3242, 3251, 3253, 3257, 3260, 3268, 3270, 3272, 3274, 3277, 3285, 3286, 3294, 3294, 3296, 3299, 3302, 3311, 3313, 3314, 3330, 3331, 3333, 3340, 3342, 3344, 3346, 3386, 3389, 3396, 3398, 3400, 3402, 3406, 3415, 3415, 3424, 3427, 3430, 3439, 3450, 3455, 3458, 3459, 3461, 3478, 3482, 3505, 3507, 3515, 3517, 3517, 3520, 3526, 3530, 3530, 3535, 3540, 3542, 3542, 3544, 3551, 3570, 3571, 3585, 3642, 3648, 3662, 3664, 3673, 3713, 3714, 3716, 3716, 3719, 3720, 3722, 3722, 3725, 3725, 3732, 3735, 3737, 3743, 3745, 3747, 3749, 3749, 3751, 3751, 3754, 3755, 3757, 3769, 3771, 3773, 3776, 3780, 3782, 3782, 3784, 3789, 3792, 3801, 3804, 3807, 3840, 3840, 3864, 3865, 3872, 3881, 3893, 3893, 3895, 3895, 3897, 3897, 3902, 3911, 3913, 3948, 3953, 3972, 3974, 3991, 3993, 4028, 4038, 4038, 4096, 4169, 4176, 4253, 4256, 4293, 4295, 4295, 4301, 4301, 4304, 4346, 4348, 4680, 4682, 4685, 4688, 4694, 4696, 4696, 4698, 4701, 4704, 4744, 4746, 4749, 4752, 4784, 4786, 4789, 4792, 4798, 4800, 4800, 4802, 4805, 4808, 4822, 4824, 4880, 4882, 4885, 4888, 4954, 4957, 4959, 4992, 5007, 5024, 5108, 5121, 5740, 5743, 5759, 5761, 5786, 5792, 5866, 5870, 5872, 5888, 5900, 5902, 5908, 5920, 5940, 5952, 5971, 5984, 5996, 5998, 6e3, 6002, 6003, 6016, 6099, 6103, 6103, 6108, 6109, 6112, 6121, 6155, 6157, 6160, 6169, 6176, 6263, 6272, 6314, 6320, 6389, 6400, 6428, 6432, 6443, 6448, 6459, 6470, 6509, 6512, 6516, 6528, 6571, 6576, 6601, 6608, 6617, 6656, 6683, 6688, 6750, 6752, 6780, 6783, 6793, 6800, 6809, 6823, 6823, 6912, 6987, 6992, 7001, 7019, 7027, 7040, 7155, 7168, 7223, 7232, 7241, 7245, 7293, 7376, 7378, 7380, 7414, 7424, 7654, 7676, 7957, 7960, 7965, 7968, 8005, 8008, 8013, 8016, 8023, 8025, 8025, 8027, 8027, 8029, 8029, 8031, 8061, 8064, 8116, 8118, 8124, 8126, 8126, 8130, 8132, 8134, 8140, 8144, 8147, 8150, 8155, 8160, 8172, 8178, 8180, 8182, 8188, 8204, 8205, 8255, 8256, 8276, 8276, 8305, 8305, 8319, 8319, 8336, 8348, 8400, 8412, 8417, 8417, 8421, 8432, 8450, 8450, 8455, 8455, 8458, 8467, 8469, 8469, 8473, 8477, 8484, 8484, 8486, 8486, 8488, 8488, 8490, 8493, 8495, 8505, 8508, 8511, 8517, 8521, 8526, 8526, 8544, 8584, 11264, 11310, 11312, 11358, 11360, 11492, 11499, 11507, 11520, 11557, 11559, 11559, 11565, 11565, 11568, 11623, 11631, 11631, 11647, 11670, 11680, 11686, 11688, 11694, 11696, 11702, 11704, 11710, 11712, 11718, 11720, 11726, 11728, 11734, 11736, 11742, 11744, 11775, 11823, 11823, 12293, 12295, 12321, 12335, 12337, 12341, 12344, 12348, 12353, 12438, 12441, 12442, 12445, 12447, 12449, 12538, 12540, 12543, 12549, 12589, 12593, 12686, 12704, 12730, 12784, 12799, 13312, 19893, 19968, 40908, 40960, 42124, 42192, 42237, 42240, 42508, 42512, 42539, 42560, 42607, 42612, 42621, 42623, 42647, 42655, 42737, 42775, 42783, 42786, 42888, 42891, 42894, 42896, 42899, 42912, 42922, 43e3, 43047, 43072, 43123, 43136, 43204, 43216, 43225, 43232, 43255, 43259, 43259, 43264, 43309, 43312, 43347, 43360, 43388, 43392, 43456, 43471, 43481, 43520, 43574, 43584, 43597, 43600, 43609, 43616, 43638, 43642, 43643, 43648, 43714, 43739, 43741, 43744, 43759, 43762, 43766, 43777, 43782, 43785, 43790, 43793, 43798, 43808, 43814, 43816, 43822, 43968, 44010, 44012, 44013, 44016, 44025, 44032, 55203, 55216, 55238, 55243, 55291, 63744, 64109, 64112, 64217, 64256, 64262, 64275, 64279, 64285, 64296, 64298, 64310, 64312, 64316, 64318, 64318, 64320, 64321, 64323, 64324, 64326, 64433, 64467, 64829, 64848, 64911, 64914, 64967, 65008, 65019, 65024, 65039, 65056, 65062, 65075, 65076, 65101, 65103, 65136, 65140, 65142, 65276, 65296, 65305, 65313, 65338, 65343, 65343, 65345, 65370, 65382, 65470, 65474, 65479, 65482, 65487, 65490, 65495, 65498, 65500];
-      unicodeESNextIdentifierStart = [65, 90, 97, 122, 170, 170, 181, 181, 186, 186, 192, 214, 216, 246, 248, 705, 710, 721, 736, 740, 748, 748, 750, 750, 880, 884, 886, 887, 890, 893, 895, 895, 902, 902, 904, 906, 908, 908, 910, 929, 931, 1013, 1015, 1153, 1162, 1327, 1329, 1366, 1369, 1369, 1376, 1416, 1488, 1514, 1519, 1522, 1568, 1610, 1646, 1647, 1649, 1747, 1749, 1749, 1765, 1766, 1774, 1775, 1786, 1788, 1791, 1791, 1808, 1808, 1810, 1839, 1869, 1957, 1969, 1969, 1994, 2026, 2036, 2037, 2042, 2042, 2048, 2069, 2074, 2074, 2084, 2084, 2088, 2088, 2112, 2136, 2144, 2154, 2208, 2228, 2230, 2237, 2308, 2361, 2365, 2365, 2384, 2384, 2392, 2401, 2417, 2432, 2437, 2444, 2447, 2448, 2451, 2472, 2474, 2480, 2482, 2482, 2486, 2489, 2493, 2493, 2510, 2510, 2524, 2525, 2527, 2529, 2544, 2545, 2556, 2556, 2565, 2570, 2575, 2576, 2579, 2600, 2602, 2608, 2610, 2611, 2613, 2614, 2616, 2617, 2649, 2652, 2654, 2654, 2674, 2676, 2693, 2701, 2703, 2705, 2707, 2728, 2730, 2736, 2738, 2739, 2741, 2745, 2749, 2749, 2768, 2768, 2784, 2785, 2809, 2809, 2821, 2828, 2831, 2832, 2835, 2856, 2858, 2864, 2866, 2867, 2869, 2873, 2877, 2877, 2908, 2909, 2911, 2913, 2929, 2929, 2947, 2947, 2949, 2954, 2958, 2960, 2962, 2965, 2969, 2970, 2972, 2972, 2974, 2975, 2979, 2980, 2984, 2986, 2990, 3001, 3024, 3024, 3077, 3084, 3086, 3088, 3090, 3112, 3114, 3129, 3133, 3133, 3160, 3162, 3168, 3169, 3200, 3200, 3205, 3212, 3214, 3216, 3218, 3240, 3242, 3251, 3253, 3257, 3261, 3261, 3294, 3294, 3296, 3297, 3313, 3314, 3333, 3340, 3342, 3344, 3346, 3386, 3389, 3389, 3406, 3406, 3412, 3414, 3423, 3425, 3450, 3455, 3461, 3478, 3482, 3505, 3507, 3515, 3517, 3517, 3520, 3526, 3585, 3632, 3634, 3635, 3648, 3654, 3713, 3714, 3716, 3716, 3718, 3722, 3724, 3747, 3749, 3749, 3751, 3760, 3762, 3763, 3773, 3773, 3776, 3780, 3782, 3782, 3804, 3807, 3840, 3840, 3904, 3911, 3913, 3948, 3976, 3980, 4096, 4138, 4159, 4159, 4176, 4181, 4186, 4189, 4193, 4193, 4197, 4198, 4206, 4208, 4213, 4225, 4238, 4238, 4256, 4293, 4295, 4295, 4301, 4301, 4304, 4346, 4348, 4680, 4682, 4685, 4688, 4694, 4696, 4696, 4698, 4701, 4704, 4744, 4746, 4749, 4752, 4784, 4786, 4789, 4792, 4798, 4800, 4800, 4802, 4805, 4808, 4822, 4824, 4880, 4882, 4885, 4888, 4954, 4992, 5007, 5024, 5109, 5112, 5117, 5121, 5740, 5743, 5759, 5761, 5786, 5792, 5866, 5870, 5880, 5888, 5900, 5902, 5905, 5920, 5937, 5952, 5969, 5984, 5996, 5998, 6e3, 6016, 6067, 6103, 6103, 6108, 6108, 6176, 6264, 6272, 6312, 6314, 6314, 6320, 6389, 6400, 6430, 6480, 6509, 6512, 6516, 6528, 6571, 6576, 6601, 6656, 6678, 6688, 6740, 6823, 6823, 6917, 6963, 6981, 6987, 7043, 7072, 7086, 7087, 7098, 7141, 7168, 7203, 7245, 7247, 7258, 7293, 7296, 7304, 7312, 7354, 7357, 7359, 7401, 7404, 7406, 7411, 7413, 7414, 7418, 7418, 7424, 7615, 7680, 7957, 7960, 7965, 7968, 8005, 8008, 8013, 8016, 8023, 8025, 8025, 8027, 8027, 8029, 8029, 8031, 8061, 8064, 8116, 8118, 8124, 8126, 8126, 8130, 8132, 8134, 8140, 8144, 8147, 8150, 8155, 8160, 8172, 8178, 8180, 8182, 8188, 8305, 8305, 8319, 8319, 8336, 8348, 8450, 8450, 8455, 8455, 8458, 8467, 8469, 8469, 8472, 8477, 8484, 8484, 8486, 8486, 8488, 8488, 8490, 8505, 8508, 8511, 8517, 8521, 8526, 8526, 8544, 8584, 11264, 11310, 11312, 11358, 11360, 11492, 11499, 11502, 11506, 11507, 11520, 11557, 11559, 11559, 11565, 11565, 11568, 11623, 11631, 11631, 11648, 11670, 11680, 11686, 11688, 11694, 11696, 11702, 11704, 11710, 11712, 11718, 11720, 11726, 11728, 11734, 11736, 11742, 12293, 12295, 12321, 12329, 12337, 12341, 12344, 12348, 12353, 12438, 12443, 12447, 12449, 12538, 12540, 12543, 12549, 12591, 12593, 12686, 12704, 12730, 12784, 12799, 13312, 19893, 19968, 40943, 40960, 42124, 42192, 42237, 42240, 42508, 42512, 42527, 42538, 42539, 42560, 42606, 42623, 42653, 42656, 42735, 42775, 42783, 42786, 42888, 42891, 42943, 42946, 42950, 42999, 43009, 43011, 43013, 43015, 43018, 43020, 43042, 43072, 43123, 43138, 43187, 43250, 43255, 43259, 43259, 43261, 43262, 43274, 43301, 43312, 43334, 43360, 43388, 43396, 43442, 43471, 43471, 43488, 43492, 43494, 43503, 43514, 43518, 43520, 43560, 43584, 43586, 43588, 43595, 43616, 43638, 43642, 43642, 43646, 43695, 43697, 43697, 43701, 43702, 43705, 43709, 43712, 43712, 43714, 43714, 43739, 43741, 43744, 43754, 43762, 43764, 43777, 43782, 43785, 43790, 43793, 43798, 43808, 43814, 43816, 43822, 43824, 43866, 43868, 43879, 43888, 44002, 44032, 55203, 55216, 55238, 55243, 55291, 63744, 64109, 64112, 64217, 64256, 64262, 64275, 64279, 64285, 64285, 64287, 64296, 64298, 64310, 64312, 64316, 64318, 64318, 64320, 64321, 64323, 64324, 64326, 64433, 64467, 64829, 64848, 64911, 64914, 64967, 65008, 65019, 65136, 65140, 65142, 65276, 65313, 65338, 65345, 65370, 65382, 65470, 65474, 65479, 65482, 65487, 65490, 65495, 65498, 65500, 65536, 65547, 65549, 65574, 65576, 65594, 65596, 65597, 65599, 65613, 65616, 65629, 65664, 65786, 65856, 65908, 66176, 66204, 66208, 66256, 66304, 66335, 66349, 66378, 66384, 66421, 66432, 66461, 66464, 66499, 66504, 66511, 66513, 66517, 66560, 66717, 66736, 66771, 66776, 66811, 66816, 66855, 66864, 66915, 67072, 67382, 67392, 67413, 67424, 67431, 67584, 67589, 67592, 67592, 67594, 67637, 67639, 67640, 67644, 67644, 67647, 67669, 67680, 67702, 67712, 67742, 67808, 67826, 67828, 67829, 67840, 67861, 67872, 67897, 67968, 68023, 68030, 68031, 68096, 68096, 68112, 68115, 68117, 68119, 68121, 68149, 68192, 68220, 68224, 68252, 68288, 68295, 68297, 68324, 68352, 68405, 68416, 68437, 68448, 68466, 68480, 68497, 68608, 68680, 68736, 68786, 68800, 68850, 68864, 68899, 69376, 69404, 69415, 69415, 69424, 69445, 69600, 69622, 69635, 69687, 69763, 69807, 69840, 69864, 69891, 69926, 69956, 69956, 69968, 70002, 70006, 70006, 70019, 70066, 70081, 70084, 70106, 70106, 70108, 70108, 70144, 70161, 70163, 70187, 70272, 70278, 70280, 70280, 70282, 70285, 70287, 70301, 70303, 70312, 70320, 70366, 70405, 70412, 70415, 70416, 70419, 70440, 70442, 70448, 70450, 70451, 70453, 70457, 70461, 70461, 70480, 70480, 70493, 70497, 70656, 70708, 70727, 70730, 70751, 70751, 70784, 70831, 70852, 70853, 70855, 70855, 71040, 71086, 71128, 71131, 71168, 71215, 71236, 71236, 71296, 71338, 71352, 71352, 71424, 71450, 71680, 71723, 71840, 71903, 71935, 71935, 72096, 72103, 72106, 72144, 72161, 72161, 72163, 72163, 72192, 72192, 72203, 72242, 72250, 72250, 72272, 72272, 72284, 72329, 72349, 72349, 72384, 72440, 72704, 72712, 72714, 72750, 72768, 72768, 72818, 72847, 72960, 72966, 72968, 72969, 72971, 73008, 73030, 73030, 73056, 73061, 73063, 73064, 73066, 73097, 73112, 73112, 73440, 73458, 73728, 74649, 74752, 74862, 74880, 75075, 77824, 78894, 82944, 83526, 92160, 92728, 92736, 92766, 92880, 92909, 92928, 92975, 92992, 92995, 93027, 93047, 93053, 93071, 93760, 93823, 93952, 94026, 94032, 94032, 94099, 94111, 94176, 94177, 94179, 94179, 94208, 100343, 100352, 101106, 110592, 110878, 110928, 110930, 110948, 110951, 110960, 111355, 113664, 113770, 113776, 113788, 113792, 113800, 113808, 113817, 119808, 119892, 119894, 119964, 119966, 119967, 119970, 119970, 119973, 119974, 119977, 119980, 119982, 119993, 119995, 119995, 119997, 120003, 120005, 120069, 120071, 120074, 120077, 120084, 120086, 120092, 120094, 120121, 120123, 120126, 120128, 120132, 120134, 120134, 120138, 120144, 120146, 120485, 120488, 120512, 120514, 120538, 120540, 120570, 120572, 120596, 120598, 120628, 120630, 120654, 120656, 120686, 120688, 120712, 120714, 120744, 120746, 120770, 120772, 120779, 123136, 123180, 123191, 123197, 123214, 123214, 123584, 123627, 124928, 125124, 125184, 125251, 125259, 125259, 126464, 126467, 126469, 126495, 126497, 126498, 126500, 126500, 126503, 126503, 126505, 126514, 126516, 126519, 126521, 126521, 126523, 126523, 126530, 126530, 126535, 126535, 126537, 126537, 126539, 126539, 126541, 126543, 126545, 126546, 126548, 126548, 126551, 126551, 126553, 126553, 126555, 126555, 126557, 126557, 126559, 126559, 126561, 126562, 126564, 126564, 126567, 126570, 126572, 126578, 126580, 126583, 126585, 126588, 126590, 126590, 126592, 126601, 126603, 126619, 126625, 126627, 126629, 126633, 126635, 126651, 131072, 173782, 173824, 177972, 177984, 178205, 178208, 183969, 183984, 191456, 194560, 195101];
-      unicodeESNextIdentifierPart = [48, 57, 65, 90, 95, 95, 97, 122, 170, 170, 181, 181, 183, 183, 186, 186, 192, 214, 216, 246, 248, 705, 710, 721, 736, 740, 748, 748, 750, 750, 768, 884, 886, 887, 890, 893, 895, 895, 902, 906, 908, 908, 910, 929, 931, 1013, 1015, 1153, 1155, 1159, 1162, 1327, 1329, 1366, 1369, 1369, 1376, 1416, 1425, 1469, 1471, 1471, 1473, 1474, 1476, 1477, 1479, 1479, 1488, 1514, 1519, 1522, 1552, 1562, 1568, 1641, 1646, 1747, 1749, 1756, 1759, 1768, 1770, 1788, 1791, 1791, 1808, 1866, 1869, 1969, 1984, 2037, 2042, 2042, 2045, 2045, 2048, 2093, 2112, 2139, 2144, 2154, 2208, 2228, 2230, 2237, 2259, 2273, 2275, 2403, 2406, 2415, 2417, 2435, 2437, 2444, 2447, 2448, 2451, 2472, 2474, 2480, 2482, 2482, 2486, 2489, 2492, 2500, 2503, 2504, 2507, 2510, 2519, 2519, 2524, 2525, 2527, 2531, 2534, 2545, 2556, 2556, 2558, 2558, 2561, 2563, 2565, 2570, 2575, 2576, 2579, 2600, 2602, 2608, 2610, 2611, 2613, 2614, 2616, 2617, 2620, 2620, 2622, 2626, 2631, 2632, 2635, 2637, 2641, 2641, 2649, 2652, 2654, 2654, 2662, 2677, 2689, 2691, 2693, 2701, 2703, 2705, 2707, 2728, 2730, 2736, 2738, 2739, 2741, 2745, 2748, 2757, 2759, 2761, 2763, 2765, 2768, 2768, 2784, 2787, 2790, 2799, 2809, 2815, 2817, 2819, 2821, 2828, 2831, 2832, 2835, 2856, 2858, 2864, 2866, 2867, 2869, 2873, 2876, 2884, 2887, 2888, 2891, 2893, 2902, 2903, 2908, 2909, 2911, 2915, 2918, 2927, 2929, 2929, 2946, 2947, 2949, 2954, 2958, 2960, 2962, 2965, 2969, 2970, 2972, 2972, 2974, 2975, 2979, 2980, 2984, 2986, 2990, 3001, 3006, 3010, 3014, 3016, 3018, 3021, 3024, 3024, 3031, 3031, 3046, 3055, 3072, 3084, 3086, 3088, 3090, 3112, 3114, 3129, 3133, 3140, 3142, 3144, 3146, 3149, 3157, 3158, 3160, 3162, 3168, 3171, 3174, 3183, 3200, 3203, 3205, 3212, 3214, 3216, 3218, 3240, 3242, 3251, 3253, 3257, 3260, 3268, 3270, 3272, 3274, 3277, 3285, 3286, 3294, 3294, 3296, 3299, 3302, 3311, 3313, 3314, 3328, 3331, 3333, 3340, 3342, 3344, 3346, 3396, 3398, 3400, 3402, 3406, 3412, 3415, 3423, 3427, 3430, 3439, 3450, 3455, 3458, 3459, 3461, 3478, 3482, 3505, 3507, 3515, 3517, 3517, 3520, 3526, 3530, 3530, 3535, 3540, 3542, 3542, 3544, 3551, 3558, 3567, 3570, 3571, 3585, 3642, 3648, 3662, 3664, 3673, 3713, 3714, 3716, 3716, 3718, 3722, 3724, 3747, 3749, 3749, 3751, 3773, 3776, 3780, 3782, 3782, 3784, 3789, 3792, 3801, 3804, 3807, 3840, 3840, 3864, 3865, 3872, 3881, 3893, 3893, 3895, 3895, 3897, 3897, 3902, 3911, 3913, 3948, 3953, 3972, 3974, 3991, 3993, 4028, 4038, 4038, 4096, 4169, 4176, 4253, 4256, 4293, 4295, 4295, 4301, 4301, 4304, 4346, 4348, 4680, 4682, 4685, 4688, 4694, 4696, 4696, 4698, 4701, 4704, 4744, 4746, 4749, 4752, 4784, 4786, 4789, 4792, 4798, 4800, 4800, 4802, 4805, 4808, 4822, 4824, 4880, 4882, 4885, 4888, 4954, 4957, 4959, 4969, 4977, 4992, 5007, 5024, 5109, 5112, 5117, 5121, 5740, 5743, 5759, 5761, 5786, 5792, 5866, 5870, 5880, 5888, 5900, 5902, 5908, 5920, 5940, 5952, 5971, 5984, 5996, 5998, 6e3, 6002, 6003, 6016, 6099, 6103, 6103, 6108, 6109, 6112, 6121, 6155, 6157, 6160, 6169, 6176, 6264, 6272, 6314, 6320, 6389, 6400, 6430, 6432, 6443, 6448, 6459, 6470, 6509, 6512, 6516, 6528, 6571, 6576, 6601, 6608, 6618, 6656, 6683, 6688, 6750, 6752, 6780, 6783, 6793, 6800, 6809, 6823, 6823, 6832, 6845, 6912, 6987, 6992, 7001, 7019, 7027, 7040, 7155, 7168, 7223, 7232, 7241, 7245, 7293, 7296, 7304, 7312, 7354, 7357, 7359, 7376, 7378, 7380, 7418, 7424, 7673, 7675, 7957, 7960, 7965, 7968, 8005, 8008, 8013, 8016, 8023, 8025, 8025, 8027, 8027, 8029, 8029, 8031, 8061, 8064, 8116, 8118, 8124, 8126, 8126, 8130, 8132, 8134, 8140, 8144, 8147, 8150, 8155, 8160, 8172, 8178, 8180, 8182, 8188, 8255, 8256, 8276, 8276, 8305, 8305, 8319, 8319, 8336, 8348, 8400, 8412, 8417, 8417, 8421, 8432, 8450, 8450, 8455, 8455, 8458, 8467, 8469, 8469, 8472, 8477, 8484, 8484, 8486, 8486, 8488, 8488, 8490, 8505, 8508, 8511, 8517, 8521, 8526, 8526, 8544, 8584, 11264, 11310, 11312, 11358, 11360, 11492, 11499, 11507, 11520, 11557, 11559, 11559, 11565, 11565, 11568, 11623, 11631, 11631, 11647, 11670, 11680, 11686, 11688, 11694, 11696, 11702, 11704, 11710, 11712, 11718, 11720, 11726, 11728, 11734, 11736, 11742, 11744, 11775, 12293, 12295, 12321, 12335, 12337, 12341, 12344, 12348, 12353, 12438, 12441, 12447, 12449, 12538, 12540, 12543, 12549, 12591, 12593, 12686, 12704, 12730, 12784, 12799, 13312, 19893, 19968, 40943, 40960, 42124, 42192, 42237, 42240, 42508, 42512, 42539, 42560, 42607, 42612, 42621, 42623, 42737, 42775, 42783, 42786, 42888, 42891, 42943, 42946, 42950, 42999, 43047, 43072, 43123, 43136, 43205, 43216, 43225, 43232, 43255, 43259, 43259, 43261, 43309, 43312, 43347, 43360, 43388, 43392, 43456, 43471, 43481, 43488, 43518, 43520, 43574, 43584, 43597, 43600, 43609, 43616, 43638, 43642, 43714, 43739, 43741, 43744, 43759, 43762, 43766, 43777, 43782, 43785, 43790, 43793, 43798, 43808, 43814, 43816, 43822, 43824, 43866, 43868, 43879, 43888, 44010, 44012, 44013, 44016, 44025, 44032, 55203, 55216, 55238, 55243, 55291, 63744, 64109, 64112, 64217, 64256, 64262, 64275, 64279, 64285, 64296, 64298, 64310, 64312, 64316, 64318, 64318, 64320, 64321, 64323, 64324, 64326, 64433, 64467, 64829, 64848, 64911, 64914, 64967, 65008, 65019, 65024, 65039, 65056, 65071, 65075, 65076, 65101, 65103, 65136, 65140, 65142, 65276, 65296, 65305, 65313, 65338, 65343, 65343, 65345, 65370, 65382, 65470, 65474, 65479, 65482, 65487, 65490, 65495, 65498, 65500, 65536, 65547, 65549, 65574, 65576, 65594, 65596, 65597, 65599, 65613, 65616, 65629, 65664, 65786, 65856, 65908, 66045, 66045, 66176, 66204, 66208, 66256, 66272, 66272, 66304, 66335, 66349, 66378, 66384, 66426, 66432, 66461, 66464, 66499, 66504, 66511, 66513, 66517, 66560, 66717, 66720, 66729, 66736, 66771, 66776, 66811, 66816, 66855, 66864, 66915, 67072, 67382, 67392, 67413, 67424, 67431, 67584, 67589, 67592, 67592, 67594, 67637, 67639, 67640, 67644, 67644, 67647, 67669, 67680, 67702, 67712, 67742, 67808, 67826, 67828, 67829, 67840, 67861, 67872, 67897, 67968, 68023, 68030, 68031, 68096, 68099, 68101, 68102, 68108, 68115, 68117, 68119, 68121, 68149, 68152, 68154, 68159, 68159, 68192, 68220, 68224, 68252, 68288, 68295, 68297, 68326, 68352, 68405, 68416, 68437, 68448, 68466, 68480, 68497, 68608, 68680, 68736, 68786, 68800, 68850, 68864, 68903, 68912, 68921, 69376, 69404, 69415, 69415, 69424, 69456, 69600, 69622, 69632, 69702, 69734, 69743, 69759, 69818, 69840, 69864, 69872, 69881, 69888, 69940, 69942, 69951, 69956, 69958, 69968, 70003, 70006, 70006, 70016, 70084, 70089, 70092, 70096, 70106, 70108, 70108, 70144, 70161, 70163, 70199, 70206, 70206, 70272, 70278, 70280, 70280, 70282, 70285, 70287, 70301, 70303, 70312, 70320, 70378, 70384, 70393, 70400, 70403, 70405, 70412, 70415, 70416, 70419, 70440, 70442, 70448, 70450, 70451, 70453, 70457, 70459, 70468, 70471, 70472, 70475, 70477, 70480, 70480, 70487, 70487, 70493, 70499, 70502, 70508, 70512, 70516, 70656, 70730, 70736, 70745, 70750, 70751, 70784, 70853, 70855, 70855, 70864, 70873, 71040, 71093, 71096, 71104, 71128, 71133, 71168, 71232, 71236, 71236, 71248, 71257, 71296, 71352, 71360, 71369, 71424, 71450, 71453, 71467, 71472, 71481, 71680, 71738, 71840, 71913, 71935, 71935, 72096, 72103, 72106, 72151, 72154, 72161, 72163, 72164, 72192, 72254, 72263, 72263, 72272, 72345, 72349, 72349, 72384, 72440, 72704, 72712, 72714, 72758, 72760, 72768, 72784, 72793, 72818, 72847, 72850, 72871, 72873, 72886, 72960, 72966, 72968, 72969, 72971, 73014, 73018, 73018, 73020, 73021, 73023, 73031, 73040, 73049, 73056, 73061, 73063, 73064, 73066, 73102, 73104, 73105, 73107, 73112, 73120, 73129, 73440, 73462, 73728, 74649, 74752, 74862, 74880, 75075, 77824, 78894, 82944, 83526, 92160, 92728, 92736, 92766, 92768, 92777, 92880, 92909, 92912, 92916, 92928, 92982, 92992, 92995, 93008, 93017, 93027, 93047, 93053, 93071, 93760, 93823, 93952, 94026, 94031, 94087, 94095, 94111, 94176, 94177, 94179, 94179, 94208, 100343, 100352, 101106, 110592, 110878, 110928, 110930, 110948, 110951, 110960, 111355, 113664, 113770, 113776, 113788, 113792, 113800, 113808, 113817, 113821, 113822, 119141, 119145, 119149, 119154, 119163, 119170, 119173, 119179, 119210, 119213, 119362, 119364, 119808, 119892, 119894, 119964, 119966, 119967, 119970, 119970, 119973, 119974, 119977, 119980, 119982, 119993, 119995, 119995, 119997, 120003, 120005, 120069, 120071, 120074, 120077, 120084, 120086, 120092, 120094, 120121, 120123, 120126, 120128, 120132, 120134, 120134, 120138, 120144, 120146, 120485, 120488, 120512, 120514, 120538, 120540, 120570, 120572, 120596, 120598, 120628, 120630, 120654, 120656, 120686, 120688, 120712, 120714, 120744, 120746, 120770, 120772, 120779, 120782, 120831, 121344, 121398, 121403, 121452, 121461, 121461, 121476, 121476, 121499, 121503, 121505, 121519, 122880, 122886, 122888, 122904, 122907, 122913, 122915, 122916, 122918, 122922, 123136, 123180, 123184, 123197, 123200, 123209, 123214, 123214, 123584, 123641, 124928, 125124, 125136, 125142, 125184, 125259, 125264, 125273, 126464, 126467, 126469, 126495, 126497, 126498, 126500, 126500, 126503, 126503, 126505, 126514, 126516, 126519, 126521, 126521, 126523, 126523, 126530, 126530, 126535, 126535, 126537, 126537, 126539, 126539, 126541, 126543, 126545, 126546, 126548, 126548, 126551, 126551, 126553, 126553, 126555, 126555, 126557, 126557, 126559, 126559, 126561, 126562, 126564, 126564, 126567, 126570, 126572, 126578, 126580, 126583, 126585, 126588, 126590, 126590, 126592, 126601, 126603, 126619, 126625, 126627, 126629, 126633, 126635, 126651, 131072, 173782, 173824, 177972, 177984, 178205, 178208, 183969, 183984, 191456, 194560, 195101, 917760, 917999];
-      commentDirectiveRegExSingleLine = /^\/\/\/?\s*@(ts-expect-error|ts-ignore)/;
-      commentDirectiveRegExMultiLine = /^(?:\/|\*)*\s*@(ts-expect-error|ts-ignore)/;
-      tokenStrings = makeReverseMap(textToToken);
-      mergeConflictMarkerLength = "<<<<<<<".length;
-      shebangTriviaRegex = /^#!.*/;
-      codePointAt = String.prototype.codePointAt ? (s, i) => s.codePointAt(i) : function codePointAt2(str, i) {
-        const size = str.length;
-        if (i < 0 || i >= size) {
-          return void 0;
-        }
-        const first2 = str.charCodeAt(i);
-        if (first2 >= 55296 && first2 <= 56319 && size > i + 1) {
-          const second = str.charCodeAt(i + 1);
-          if (second >= 56320 && second <= 57343) {
-            return (first2 - 55296) * 1024 + second - 56320 + 65536;
-          }
-        }
-        return first2;
-      };
-      utf16EncodeAsStringWorker = String.fromCodePoint ? (codePoint) => String.fromCodePoint(codePoint) : utf16EncodeAsStringFallback;
-    }
-  });
-
-  // src/compiler/utilitiesPublic.ts
-  function isExternalModuleNameRelative(moduleName) {
-    return pathIsRelative(moduleName) || isRootedDiskPath(moduleName);
-  }
-  function sortAndDeduplicateDiagnostics(diagnostics) {
-    return sortAndDeduplicate(diagnostics, compareDiagnostics);
-  }
-  function getDefaultLibFileName(options) {
-    switch (getEmitScriptTarget(options)) {
-      case 99 /* ESNext */:
-        return "lib.esnext.full.d.ts";
-      case 9 /* ES2022 */:
-        return "lib.es2022.full.d.ts";
-      case 8 /* ES2021 */:
-        return "lib.es2021.full.d.ts";
-      case 7 /* ES2020 */:
-        return "lib.es2020.full.d.ts";
-      case 6 /* ES2019 */:
-        return "lib.es2019.full.d.ts";
-      case 5 /* ES2018 */:
-        return "lib.es2018.full.d.ts";
-      case 4 /* ES2017 */:
-        return "lib.es2017.full.d.ts";
-      case 3 /* ES2016 */:
-        return "lib.es2016.full.d.ts";
-      case 2 /* ES2015 */:
-        return "lib.es6.d.ts";
-      default:
-        return "lib.d.ts";
-    }
-  }
-  function textSpanEnd(span) {
-    return span.start + span.length;
-  }
-  function textSpanIsEmpty(span) {
-    return span.length === 0;
-  }
-  function textSpanContainsPosition(span, position) {
-    return position >= span.start && position < textSpanEnd(span);
-  }
-  function textRangeContainsPositionInclusive(span, position) {
-    return position >= span.pos && position <= span.end;
-  }
-  function textSpanContainsTextSpan(span, other) {
-    return other.start >= span.start && textSpanEnd(other) <= textSpanEnd(span);
-  }
-  function textSpanOverlapsWith(span, other) {
-    return textSpanOverlap(span, other) !== void 0;
-  }
-  function textSpanOverlap(span1, span2) {
-    const overlap = textSpanIntersection(span1, span2);
-    return overlap && overlap.length === 0 ? void 0 : overlap;
-  }
-  function textSpanIntersectsWithTextSpan(span, other) {
-    return decodedTextSpanIntersectsWith(span.start, span.length, other.start, other.length);
-  }
-  function textSpanIntersectsWith(span, start, length2) {
-    return decodedTextSpanIntersectsWith(span.start, span.length, start, length2);
-  }
-  function decodedTextSpanIntersectsWith(start1, length1, start2, length2) {
-    const end1 = start1 + length1;
-    const end2 = start2 + length2;
-    return start2 <= end1 && end2 >= start1;
-  }
-  function textSpanIntersectsWithPosition(span, position) {
-    return position <= textSpanEnd(span) && position >= span.start;
-  }
-  function textSpanIntersection(span1, span2) {
-    const start = Math.max(span1.start, span2.start);
-    const end = Math.min(textSpanEnd(span1), textSpanEnd(span2));
-    return start <= end ? createTextSpanFromBounds(start, end) : void 0;
-  }
-  function createTextSpan(start, length2) {
-    if (start < 0) {
-      throw new Error("start < 0");
-    }
-    if (length2 < 0) {
-      throw new Error("length < 0");
-    }
-    return { start, length: length2 };
-  }
-  function createTextSpanFromBounds(start, end) {
-    return createTextSpan(start, end - start);
-  }
-  function textChangeRangeNewSpan(range) {
-    return createTextSpan(range.span.start, range.newLength);
-  }
-  function textChangeRangeIsUnchanged(range) {
-    return textSpanIsEmpty(range.span) && range.newLength === 0;
-  }
-  function createTextChangeRange(span, newLength) {
-    if (newLength < 0) {
-      throw new Error("newLength < 0");
-    }
-    return { span, newLength };
-  }
-  function collapseTextChangeRangesAcrossMultipleVersions(changes) {
-    if (changes.length === 0) {
-      return unchangedTextChangeRange;
-    }
-    if (changes.length === 1) {
-      return changes[0];
-    }
-    const change0 = changes[0];
-    let oldStartN = change0.span.start;
-    let oldEndN = textSpanEnd(change0.span);
-    let newEndN = oldStartN + change0.newLength;
-    for (let i = 1; i < changes.length; i++) {
-      const nextChange = changes[i];
-      const oldStart1 = oldStartN;
-      const oldEnd1 = oldEndN;
-      const newEnd1 = newEndN;
-      const oldStart2 = nextChange.span.start;
-      const oldEnd2 = textSpanEnd(nextChange.span);
-      const newEnd2 = oldStart2 + nextChange.newLength;
-      oldStartN = Math.min(oldStart1, oldStart2);
-      oldEndN = Math.max(oldEnd1, oldEnd1 + (oldEnd2 - newEnd1));
-      newEndN = Math.max(newEnd2, newEnd2 + (newEnd1 - oldEnd2));
-    }
-    return createTextChangeRange(
-      createTextSpanFromBounds(oldStartN, oldEndN),
-      /*newLength*/
-      newEndN - oldStartN
-    );
-  }
-  function getTypeParameterOwner(d) {
-    if (d && d.kind === 167 /* TypeParameter */) {
-      for (let current = d; current; current = current.parent) {
-        if (isFunctionLike(current) || isClassLike(current) || current.kind === 263 /* InterfaceDeclaration */) {
-          return current;
-        }
-      }
-    }
-  }
-  function isParameterPropertyDeclaration(node, parent2) {
-    return isParameter(node) && hasSyntacticModifier(node, 16476 /* ParameterPropertyModifier */) && parent2.kind === 175 /* Constructor */;
-  }
-  function isEmptyBindingPattern(node) {
-    if (isBindingPattern(node)) {
-      return every(node.elements, isEmptyBindingElement);
-    }
-    return false;
-  }
-  function isEmptyBindingElement(node) {
-    if (isOmittedExpression(node)) {
-      return true;
-    }
-    return isEmptyBindingPattern(node.name);
-  }
-  function walkUpBindingElementsAndPatterns(binding) {
-    let node = binding.parent;
-    while (isBindingElement(node.parent)) {
-      node = node.parent.parent;
-    }
-    return node.parent;
-  }
-  function getCombinedFlags(node, getFlags) {
-    if (isBindingElement(node)) {
-      node = walkUpBindingElementsAndPatterns(node);
-    }
-    let flags = getFlags(node);
-    if (node.kind === 259 /* VariableDeclaration */) {
-      node = node.parent;
-    }
-    if (node && node.kind === 260 /* VariableDeclarationList */) {
-      flags |= getFlags(node);
-      node = node.parent;
-    }
-    if (node && node.kind === 242 /* VariableStatement */) {
-      flags |= getFlags(node);
-    }
-    return flags;
-  }
-  function getCombinedModifierFlags(node) {
-    return getCombinedFlags(node, getEffectiveModifierFlags);
-  }
-  function getCombinedNodeFlagsAlwaysIncludeJSDoc(node) {
-    return getCombinedFlags(node, getEffectiveModifierFlagsAlwaysIncludeJSDoc);
-  }
-  function getCombinedNodeFlags(node) {
-    return getCombinedFlags(node, (n) => n.flags);
-  }
-  function validateLocaleAndSetLanguage(locale, sys2, errors) {
-    const lowerCaseLocale = locale.toLowerCase();
-    const matchResult = /^([a-z]+)([_\-]([a-z]+))?$/.exec(lowerCaseLocale);
-    if (!matchResult) {
-      if (errors) {
-        errors.push(createCompilerDiagnostic(Diagnostics.Locale_must_be_of_the_form_language_or_language_territory_For_example_0_or_1, "en", "ja-jp"));
-      }
-      return;
-    }
-    const language = matchResult[1];
-    const territory = matchResult[3];
-    if (contains(supportedLocaleDirectories, lowerCaseLocale) && !trySetLanguageAndTerritory(language, territory, errors)) {
-      trySetLanguageAndTerritory(
-        language,
-        /*territory*/
-        void 0,
-        errors
-      );
-    }
-    setUILocale(locale);
-    function trySetLanguageAndTerritory(language2, territory2, errors2) {
-      const compilerFilePath = normalizePath(sys2.getExecutingFilePath());
-      const containingDirectoryPath = getDirectoryPath(compilerFilePath);
-      let filePath = combinePaths(containingDirectoryPath, language2);
-      if (territory2) {
-        filePath = filePath + "-" + territory2;
-      }
-      filePath = sys2.resolvePath(combinePaths(filePath, "diagnosticMessages.generated.json"));
-      if (!sys2.fileExists(filePath)) {
-        return false;
-      }
-      let fileContents = "";
-      try {
-        fileContents = sys2.readFile(filePath);
-      } catch (e) {
-        if (errors2) {
-          errors2.push(createCompilerDiagnostic(Diagnostics.Unable_to_open_file_0, filePath));
-        }
-        return false;
-      }
-      try {
-        setLocalizedDiagnosticMessages(JSON.parse(fileContents));
-      } catch {
-        if (errors2) {
-          errors2.push(createCompilerDiagnostic(Diagnostics.Corrupted_locale_file_0, filePath));
-        }
-        return false;
-      }
-      return true;
-    }
-  }
-  function getOriginalNode(node, nodeTest) {
-    if (node) {
-      while (node.original !== void 0) {
-        node = node.original;
-      }
-    }
-    if (!node || !nodeTest) {
-      return node;
-    }
-    return nodeTest(node) ? node : void 0;
-  }
-  function findAncestor(node, callback) {
-    while (node) {
-      const result = callback(node);
-      if (result === "quit") {
-        return void 0;
-      } else if (result) {
-        return node;
-      }
-      node = node.parent;
-    }
-    return void 0;
-  }
-  function isParseTreeNode(node) {
-    return (node.flags & 8 /* Synthesized */) === 0;
-  }
-  function getParseTreeNode(node, nodeTest) {
-    if (node === void 0 || isParseTreeNode(node)) {
-      return node;
-    }
-    node = node.original;
-    while (node) {
-      if (isParseTreeNode(node)) {
-        return !nodeTest || nodeTest(node) ? node : void 0;
-      }
-      node = node.original;
-    }
-  }
-  function escapeLeadingUnderscores(identifier) {
-    return identifier.length >= 2 && identifier.charCodeAt(0) === 95 /* _ */ && identifier.charCodeAt(1) === 95 /* _ */ ? "_" + identifier : identifier;
-  }
-  function unescapeLeadingUnderscores(identifier) {
-    const id = identifier;
-    return id.length >= 3 && id.charCodeAt(0) === 95 /* _ */ && id.charCodeAt(1) === 95 /* _ */ && id.charCodeAt(2) === 95 /* _ */ ? id.substr(1) : id;
-  }
-  function idText(identifierOrPrivateName) {
-    return unescapeLeadingUnderscores(identifierOrPrivateName.escapedText);
-  }
-  function identifierToKeywordKind(node) {
-    const token = stringToToken(node.escapedText);
-    return token ? tryCast(token, isKeyword) : void 0;
-  }
-  function symbolName(symbol) {
-    if (symbol.valueDeclaration && isPrivateIdentifierClassElementDeclaration(symbol.valueDeclaration)) {
-      return idText(symbol.valueDeclaration.name);
-    }
-    return unescapeLeadingUnderscores(symbol.escapedName);
-  }
-  function nameForNamelessJSDocTypedef(declaration) {
-    const hostNode = declaration.parent.parent;
-    if (!hostNode) {
-      return void 0;
-    }
-    if (isDeclaration(hostNode)) {
-      return getDeclarationIdentifier(hostNode);
-    }
-    switch (hostNode.kind) {
-      case 242 /* VariableStatement */:
-        if (hostNode.declarationList && hostNode.declarationList.declarations[0]) {
-          return getDeclarationIdentifier(hostNode.declarationList.declarations[0]);
-        }
-        break;
-      case 243 /* ExpressionStatement */:
-        let expr = hostNode.expression;
-        if (expr.kind === 225 /* BinaryExpression */ && expr.operatorToken.kind === 64 /* EqualsToken */) {
-          expr = expr.left;
-        }
-        switch (expr.kind) {
-          case 210 /* PropertyAccessExpression */:
-            return expr.name;
-          case 211 /* ElementAccessExpression */:
-            const arg = expr.argumentExpression;
-            if (isIdentifier(arg)) {
-              return arg;
-            }
-        }
-        break;
-      case 216 /* ParenthesizedExpression */: {
-        return getDeclarationIdentifier(hostNode.expression);
-      }
-      case 255 /* LabeledStatement */: {
-        if (isDeclaration(hostNode.statement) || isExpression(hostNode.statement)) {
-          return getDeclarationIdentifier(hostNode.statement);
-        }
-        break;
-      }
-    }
-  }
-  function getDeclarationIdentifier(node) {
-    const name = getNameOfDeclaration(node);
-    return name && isIdentifier(name) ? name : void 0;
-  }
-  function nodeHasName(statement, name) {
-    if (isNamedDeclaration(statement) && isIdentifier(statement.name) && idText(statement.name) === idText(name)) {
-      return true;
-    }
-    if (isVariableStatement(statement) && some(statement.declarationList.declarations, (d) => nodeHasName(d, name))) {
-      return true;
-    }
-    return false;
-  }
-  function getNameOfJSDocTypedef(declaration) {
-    return declaration.name || nameForNamelessJSDocTypedef(declaration);
-  }
-  function isNamedDeclaration(node) {
-    return !!node.name;
-  }
-  function getNonAssignedNameOfDeclaration(declaration) {
-    switch (declaration.kind) {
-      case 80 /* Identifier */:
-        return declaration;
-      case 354 /* JSDocPropertyTag */:
-      case 347 /* JSDocParameterTag */: {
-        const { name } = declaration;
-        if (name.kind === 165 /* QualifiedName */) {
-          return name.right;
-        }
-        break;
-      }
-      case 212 /* CallExpression */:
-      case 225 /* BinaryExpression */: {
-        const expr2 = declaration;
-        switch (getAssignmentDeclarationKind(expr2)) {
-          case 1 /* ExportsProperty */:
-          case 4 /* ThisProperty */:
-          case 5 /* Property */:
-          case 3 /* PrototypeProperty */:
-            return getElementOrPropertyAccessArgumentExpressionOrName(expr2.left);
-          case 7 /* ObjectDefinePropertyValue */:
-          case 8 /* ObjectDefinePropertyExports */:
-          case 9 /* ObjectDefinePrototypeProperty */:
-            return expr2.arguments[1];
-          default:
-            return void 0;
-        }
-      }
-      case 352 /* JSDocTypedefTag */:
-        return getNameOfJSDocTypedef(declaration);
-      case 346 /* JSDocEnumTag */:
-        return nameForNamelessJSDocTypedef(declaration);
-      case 276 /* ExportAssignment */: {
-        const { expression } = declaration;
-        return isIdentifier(expression) ? expression : void 0;
-      }
-      case 211 /* ElementAccessExpression */:
-        const expr = declaration;
-        if (isBindableStaticElementAccessExpression(expr)) {
-          return expr.argumentExpression;
-        }
-    }
-    return declaration.name;
-  }
-  function getNameOfDeclaration(declaration) {
-    if (declaration === void 0)
-      return void 0;
-    return getNonAssignedNameOfDeclaration(declaration) || (isFunctionExpression(declaration) || isArrowFunction(declaration) || isClassExpression(declaration) ? getAssignedName(declaration) : void 0);
-  }
-  function getAssignedName(node) {
-    if (!node.parent) {
-      return void 0;
-    } else if (isPropertyAssignment(node.parent) || isBindingElement(node.parent)) {
-      return node.parent.name;
-    } else if (isBinaryExpression(node.parent) && node === node.parent.right) {
-      if (isIdentifier(node.parent.left)) {
-        return node.parent.left;
-      } else if (isAccessExpression(node.parent.left)) {
-        return getElementOrPropertyAccessArgumentExpressionOrName(node.parent.left);
-      }
-    } else if (isVariableDeclaration(node.parent) && isIdentifier(node.parent.name)) {
-      return node.parent.name;
-    }
-  }
-  function getDecorators(node) {
-    if (hasDecorators(node)) {
-      return filter(node.modifiers, isDecorator);
-    }
-  }
-  function getModifiers(node) {
-    if (hasSyntacticModifier(node, 126975 /* Modifier */)) {
-      return filter(node.modifiers, isModifier);
-    }
-  }
-  function getJSDocParameterTagsWorker(param, noCache) {
-    if (param.name) {
-      if (isIdentifier(param.name)) {
-        const name = param.name.escapedText;
-        return getJSDocTagsWorker(param.parent, noCache).filter((tag) => isJSDocParameterTag(tag) && isIdentifier(tag.name) && tag.name.escapedText === name);
-      } else {
-        const i = param.parent.parameters.indexOf(param);
-        Debug.assert(i > -1, "Parameters should always be in their parents' parameter list");
-        const paramTags = getJSDocTagsWorker(param.parent, noCache).filter(isJSDocParameterTag);
-        if (i < paramTags.length) {
-          return [paramTags[i]];
-        }
-      }
-    }
-    return emptyArray;
-  }
-  function getJSDocParameterTags(param) {
-    return getJSDocParameterTagsWorker(
-      param,
-      /*noCache*/
-      false
-    );
-  }
-  function getJSDocParameterTagsNoCache(param) {
-    return getJSDocParameterTagsWorker(
-      param,
-      /*noCache*/
-      true
-    );
-  }
-  function getJSDocTypeParameterTagsWorker(param, noCache) {
-    const name = param.name.escapedText;
-    return getJSDocTagsWorker(param.parent, noCache).filter((tag) => isJSDocTemplateTag(tag) && tag.typeParameters.some((tp) => tp.name.escapedText === name));
-  }
-  function getJSDocTypeParameterTags(param) {
-    return getJSDocTypeParameterTagsWorker(
-      param,
-      /*noCache*/
-      false
-    );
-  }
-  function getJSDocTypeParameterTagsNoCache(param) {
-    return getJSDocTypeParameterTagsWorker(
-      param,
-      /*noCache*/
-      true
-    );
-  }
-  function hasJSDocParameterTags(node) {
-    return !!getFirstJSDocTag(node, isJSDocParameterTag);
-  }
-  function getJSDocAugmentsTag(node) {
-    return getFirstJSDocTag(node, isJSDocAugmentsTag);
-  }
-  function getJSDocImplementsTags(node) {
-    return getAllJSDocTags(node, isJSDocImplementsTag);
-  }
-  function getJSDocClassTag(node) {
-    return getFirstJSDocTag(node, isJSDocClassTag);
-  }
-  function getJSDocPublicTag(node) {
-    return getFirstJSDocTag(node, isJSDocPublicTag);
-  }
-  function getJSDocPublicTagNoCache(node) {
-    return getFirstJSDocTag(
-      node,
-      isJSDocPublicTag,
-      /*noCache*/
-      true
-    );
-  }
-  function getJSDocPrivateTag(node) {
-    return getFirstJSDocTag(node, isJSDocPrivateTag);
-  }
-  function getJSDocPrivateTagNoCache(node) {
-    return getFirstJSDocTag(
-      node,
-      isJSDocPrivateTag,
-      /*noCache*/
-      true
-    );
-  }
-  function getJSDocProtectedTag(node) {
-    return getFirstJSDocTag(node, isJSDocProtectedTag);
-  }
-  function getJSDocProtectedTagNoCache(node) {
-    return getFirstJSDocTag(
-      node,
-      isJSDocProtectedTag,
-      /*noCache*/
-      true
-    );
-  }
-  function getJSDocReadonlyTag(node) {
-    return getFirstJSDocTag(node, isJSDocReadonlyTag);
-  }
-  function getJSDocReadonlyTagNoCache(node) {
-    return getFirstJSDocTag(
-      node,
-      isJSDocReadonlyTag,
-      /*noCache*/
-      true
-    );
-  }
-  function getJSDocOverrideTagNoCache(node) {
-    return getFirstJSDocTag(
-      node,
-      isJSDocOverrideTag,
-      /*noCache*/
-      true
-    );
-  }
-  function getJSDocDeprecatedTag(node) {
-    return getFirstJSDocTag(node, isJSDocDeprecatedTag);
-  }
-  function getJSDocDeprecatedTagNoCache(node) {
-    return getFirstJSDocTag(
-      node,
-      isJSDocDeprecatedTag,
-      /*noCache*/
-      true
-    );
-  }
-  function getJSDocEnumTag(node) {
-    return getFirstJSDocTag(node, isJSDocEnumTag);
-  }
-  function getJSDocThisTag(node) {
-    return getFirstJSDocTag(node, isJSDocThisTag);
-  }
-  function getJSDocReturnTag(node) {
-    return getFirstJSDocTag(node, isJSDocReturnTag);
-  }
-  function getJSDocTemplateTag(node) {
-    return getFirstJSDocTag(node, isJSDocTemplateTag);
-  }
-  function getJSDocSatisfiesTag(node) {
-    return getFirstJSDocTag(node, isJSDocSatisfiesTag);
-  }
-  function getJSDocTypeTag(node) {
-    const tag = getFirstJSDocTag(node, isJSDocTypeTag);
-    if (tag && tag.typeExpression && tag.typeExpression.type) {
-      return tag;
-    }
-    return void 0;
-  }
-  function getJSDocType(node) {
-    let tag = getFirstJSDocTag(node, isJSDocTypeTag);
-    if (!tag && isParameter(node)) {
-      tag = find(getJSDocParameterTags(node), (tag2) => !!tag2.typeExpression);
-    }
-    return tag && tag.typeExpression && tag.typeExpression.type;
-  }
-  function getJSDocReturnType(node) {
-    const returnTag = getJSDocReturnTag(node);
-    if (returnTag && returnTag.typeExpression) {
-      return returnTag.typeExpression.type;
-    }
-    const typeTag = getJSDocTypeTag(node);
-    if (typeTag && typeTag.typeExpression) {
-      const type = typeTag.typeExpression.type;
-      if (isTypeLiteralNode(type)) {
-        const sig = find(type.members, isCallSignatureDeclaration);
-        return sig && sig.type;
-      }
-      if (isFunctionTypeNode(type) || isJSDocFunctionType(type)) {
-        return type.type;
-      }
-    }
-  }
-  function getJSDocTagsWorker(node, noCache) {
-    var _a;
-    if (!canHaveJSDoc(node))
-      return emptyArray;
-    let tags = (_a = node.jsDoc) == null ? void 0 : _a.jsDocCache;
-    if (tags === void 0 || noCache) {
-      const comments = getJSDocCommentsAndTags(node, noCache);
-      Debug.assert(comments.length < 2 || comments[0] !== comments[1]);
-      tags = flatMap(comments, (j) => isJSDoc(j) ? j.tags : j);
-      if (!noCache) {
-        node.jsDoc ?? (node.jsDoc = []);
-        node.jsDoc.jsDocCache = tags;
-      }
-    }
-    return tags;
-  }
-  function getJSDocTags(node) {
-    return getJSDocTagsWorker(
-      node,
-      /*noCache*/
-      false
-    );
-  }
-  function getJSDocTagsNoCache(node) {
-    return getJSDocTagsWorker(
-      node,
-      /*noCache*/
-      true
-    );
-  }
-  function getFirstJSDocTag(node, predicate, noCache) {
-    return find(getJSDocTagsWorker(node, noCache), predicate);
-  }
-  function getAllJSDocTags(node, predicate) {
-    return getJSDocTags(node).filter(predicate);
-  }
-  function getAllJSDocTagsOfKind(node, kind) {
-    return getJSDocTags(node).filter((doc) => doc.kind === kind);
-  }
-  function getTextOfJSDocComment(comment) {
-    return typeof comment === "string" ? comment : comment == null ? void 0 : comment.map((c) => c.kind === 327 /* JSDocText */ ? c.text : formatJSDocLink(c)).join("");
-  }
-  function formatJSDocLink(link) {
-    const kind = link.kind === 330 /* JSDocLink */ ? "link" : link.kind === 331 /* JSDocLinkCode */ ? "linkcode" : "linkplain";
-    const name = link.name ? entityNameToString(link.name) : "";
-    const space = link.name && link.text.startsWith("://") ? "" : " ";
-    return `{@${kind} ${name}${space}${link.text}}`;
-  }
-  function getEffectiveTypeParameterDeclarations(node) {
-    if (isJSDocSignature(node)) {
-      if (isJSDocOverloadTag(node.parent)) {
-        const jsDoc = getJSDocRoot(node.parent);
-        if (jsDoc && length(jsDoc.tags)) {
-          return flatMap(jsDoc.tags, (tag) => isJSDocTemplateTag(tag) ? tag.typeParameters : void 0);
-        }
-      }
-      return emptyArray;
-    }
-    if (isJSDocTypeAlias(node)) {
-      Debug.assert(node.parent.kind === 326 /* JSDoc */);
-      return flatMap(node.parent.tags, (tag) => isJSDocTemplateTag(tag) ? tag.typeParameters : void 0);
-    }
-    if (node.typeParameters) {
-      return node.typeParameters;
-    }
-    if (canHaveIllegalTypeParameters(node) && node.typeParameters) {
-      return node.typeParameters;
-    }
-    if (isInJSFile(node)) {
-      const decls = getJSDocTypeParameterDeclarations(node);
-      if (decls.length) {
-        return decls;
-      }
-      const typeTag = getJSDocType(node);
-      if (typeTag && isFunctionTypeNode(typeTag) && typeTag.typeParameters) {
-        return typeTag.typeParameters;
-      }
-    }
-    return emptyArray;
-  }
-  function getEffectiveConstraintOfTypeParameter(node) {
-    return node.constraint ? node.constraint : isJSDocTemplateTag(node.parent) && node === node.parent.typeParameters[0] ? node.parent.constraint : void 0;
-  }
-  function isMemberName(node) {
-    return node.kind === 80 /* Identifier */ || node.kind === 81 /* PrivateIdentifier */;
-  }
-  function isGetOrSetAccessorDeclaration(node) {
-    return node.kind === 177 /* SetAccessor */ || node.kind === 176 /* GetAccessor */;
-  }
-  function isPropertyAccessChain(node) {
-    return isPropertyAccessExpression(node) && !!(node.flags & 32 /* OptionalChain */);
-  }
-  function isElementAccessChain(node) {
-    return isElementAccessExpression(node) && !!(node.flags & 32 /* OptionalChain */);
-  }
-  function isCallChain(node) {
-    return isCallExpression(node) && !!(node.flags & 32 /* OptionalChain */);
-  }
-  function isOptionalChain(node) {
-    const kind = node.kind;
-    return !!(node.flags & 32 /* OptionalChain */) && (kind === 210 /* PropertyAccessExpression */ || kind === 211 /* ElementAccessExpression */ || kind === 212 /* CallExpression */ || kind === 234 /* NonNullExpression */);
-  }
-  function isOptionalChainRoot(node) {
-    return isOptionalChain(node) && !isNonNullExpression(node) && !!node.questionDotToken;
-  }
-  function isExpressionOfOptionalChainRoot(node) {
-    return isOptionalChainRoot(node.parent) && node.parent.expression === node;
-  }
-  function isOutermostOptionalChain(node) {
-    return !isOptionalChain(node.parent) || isOptionalChainRoot(node.parent) || node !== node.parent.expression;
-  }
-  function isNullishCoalesce(node) {
-    return node.kind === 225 /* BinaryExpression */ && node.operatorToken.kind === 61 /* QuestionQuestionToken */;
-  }
-  function isConstTypeReference(node) {
-    return isTypeReferenceNode(node) && isIdentifier(node.typeName) && node.typeName.escapedText === "const" && !node.typeArguments;
-  }
-  function skipPartiallyEmittedExpressions(node) {
-    return skipOuterExpressions(node, 8 /* PartiallyEmittedExpressions */);
-  }
-  function isNonNullChain(node) {
-    return isNonNullExpression(node) && !!(node.flags & 32 /* OptionalChain */);
-  }
-  function isBreakOrContinueStatement(node) {
-    return node.kind === 251 /* BreakStatement */ || node.kind === 250 /* ContinueStatement */;
-  }
-  function isNamedExportBindings(node) {
-    return node.kind === 279 /* NamespaceExport */ || node.kind === 278 /* NamedExports */;
-  }
-  function isUnparsedTextLike(node) {
-    switch (node.kind) {
-      case 308 /* UnparsedText */:
-      case 309 /* UnparsedInternalText */:
-        return true;
-      default:
-        return false;
-    }
-  }
-  function isUnparsedNode(node) {
-    return isUnparsedTextLike(node) || node.kind === 306 /* UnparsedPrologue */ || node.kind === 310 /* UnparsedSyntheticReference */;
-  }
-  function isJSDocPropertyLikeTag(node) {
-    return node.kind === 354 /* JSDocPropertyTag */ || node.kind === 347 /* JSDocParameterTag */;
-  }
-  function isNode(node) {
-    return isNodeKind(node.kind);
-  }
-  function isNodeKind(kind) {
-    return kind >= 165 /* FirstNode */;
-  }
-  function isTokenKind(kind) {
-    return kind >= 0 /* FirstToken */ && kind <= 164 /* LastToken */;
-  }
-  function isToken(n) {
-    return isTokenKind(n.kind);
-  }
-  function isNodeArray(array) {
-    return hasProperty(array, "pos") && hasProperty(array, "end");
-  }
-  function isLiteralKind(kind) {
-    return 9 /* FirstLiteralToken */ <= kind && kind <= 15 /* LastLiteralToken */;
-  }
-  function isLiteralExpression(node) {
-    return isLiteralKind(node.kind);
-  }
-  function isLiteralExpressionOfObject(node) {
-    switch (node.kind) {
-      case 209 /* ObjectLiteralExpression */:
-      case 208 /* ArrayLiteralExpression */:
-      case 14 /* RegularExpressionLiteral */:
-      case 217 /* FunctionExpression */:
-      case 230 /* ClassExpression */:
-        return true;
-    }
-    return false;
-  }
-  function isTemplateLiteralKind(kind) {
-    return 15 /* FirstTemplateToken */ <= kind && kind <= 18 /* LastTemplateToken */;
-  }
-  function isTemplateLiteralToken(node) {
-    return isTemplateLiteralKind(node.kind);
-  }
-  function isTemplateMiddleOrTemplateTail(node) {
-    const kind = node.kind;
-    return kind === 17 /* TemplateMiddle */ || kind === 18 /* TemplateTail */;
-  }
-  function isImportOrExportSpecifier(node) {
-    return isImportSpecifier(node) || isExportSpecifier(node);
-  }
-  function isTypeOnlyImportDeclaration(node) {
-    switch (node.kind) {
-      case 275 /* ImportSpecifier */:
-        return node.isTypeOnly || node.parent.parent.isTypeOnly;
-      case 273 /* NamespaceImport */:
-        return node.parent.isTypeOnly;
-      case 272 /* ImportClause */:
-      case 270 /* ImportEqualsDeclaration */:
-        return node.isTypeOnly;
-    }
-    return false;
-  }
-  function isTypeOnlyExportDeclaration(node) {
-    switch (node.kind) {
-      case 280 /* ExportSpecifier */:
-        return node.isTypeOnly || node.parent.parent.isTypeOnly;
-      case 277 /* ExportDeclaration */:
-        return node.isTypeOnly && !!node.moduleSpecifier && !node.exportClause;
-      case 279 /* NamespaceExport */:
-        return node.parent.isTypeOnly;
-    }
-    return false;
-  }
-  function isTypeOnlyImportOrExportDeclaration(node) {
-    return isTypeOnlyImportDeclaration(node) || isTypeOnlyExportDeclaration(node);
-  }
-  function isAssertionKey(node) {
-    return isStringLiteral(node) || isIdentifier(node);
-  }
-  function isStringTextContainingNode(node) {
-    return node.kind === 11 /* StringLiteral */ || isTemplateLiteralKind(node.kind);
-  }
-  function isGeneratedIdentifier(node) {
-    var _a;
-    return isIdentifier(node) && ((_a = node.emitNode) == null ? void 0 : _a.autoGenerate) !== void 0;
-  }
-  function isGeneratedPrivateIdentifier(node) {
-    var _a;
-    return isPrivateIdentifier(node) && ((_a = node.emitNode) == null ? void 0 : _a.autoGenerate) !== void 0;
-  }
-  function isPrivateIdentifierClassElementDeclaration(node) {
-    return (isPropertyDeclaration(node) || isMethodOrAccessor(node)) && isPrivateIdentifier(node.name);
-  }
-  function isPrivateIdentifierPropertyAccessExpression(node) {
-    return isPropertyAccessExpression(node) && isPrivateIdentifier(node.name);
-  }
-  function isModifierKind(token) {
-    switch (token) {
-      case 128 /* AbstractKeyword */:
-      case 129 /* AccessorKeyword */:
-      case 134 /* AsyncKeyword */:
-      case 87 /* ConstKeyword */:
-      case 138 /* DeclareKeyword */:
-      case 90 /* DefaultKeyword */:
-      case 95 /* ExportKeyword */:
-      case 103 /* InKeyword */:
-      case 125 /* PublicKeyword */:
-      case 123 /* PrivateKeyword */:
-      case 124 /* ProtectedKeyword */:
-      case 148 /* ReadonlyKeyword */:
-      case 126 /* StaticKeyword */:
-      case 147 /* OutKeyword */:
-      case 163 /* OverrideKeyword */:
-        return true;
-    }
-    return false;
-  }
-  function isParameterPropertyModifier(kind) {
-    return !!(modifierToFlag(kind) & 16476 /* ParameterPropertyModifier */);
-  }
-  function isClassMemberModifier(idToken) {
-    return isParameterPropertyModifier(idToken) || idToken === 126 /* StaticKeyword */ || idToken === 163 /* OverrideKeyword */ || idToken === 129 /* AccessorKeyword */;
-  }
-  function isModifier(node) {
-    return isModifierKind(node.kind);
-  }
-  function isEntityName(node) {
-    const kind = node.kind;
-    return kind === 165 /* QualifiedName */ || kind === 80 /* Identifier */;
-  }
-  function isPropertyName(node) {
-    const kind = node.kind;
-    return kind === 80 /* Identifier */ || kind === 81 /* PrivateIdentifier */ || kind === 11 /* StringLiteral */ || kind === 9 /* NumericLiteral */ || kind === 166 /* ComputedPropertyName */;
-  }
-  function isBindingName(node) {
-    const kind = node.kind;
-    return kind === 80 /* Identifier */ || kind === 205 /* ObjectBindingPattern */ || kind === 206 /* ArrayBindingPattern */;
-  }
-  function isFunctionLike(node) {
-    return !!node && isFunctionLikeKind(node.kind);
-  }
-  function isFunctionLikeOrClassStaticBlockDeclaration(node) {
-    return !!node && (isFunctionLikeKind(node.kind) || isClassStaticBlockDeclaration(node));
-  }
-  function isFunctionLikeDeclaration(node) {
-    return node && isFunctionLikeDeclarationKind(node.kind);
-  }
-  function isBooleanLiteral(node) {
-    return node.kind === 112 /* TrueKeyword */ || node.kind === 97 /* FalseKeyword */;
-  }
-  function isFunctionLikeDeclarationKind(kind) {
-    switch (kind) {
-      case 261 /* FunctionDeclaration */:
-      case 173 /* MethodDeclaration */:
-      case 175 /* Constructor */:
-      case 176 /* GetAccessor */:
-      case 177 /* SetAccessor */:
-      case 217 /* FunctionExpression */:
-      case 218 /* ArrowFunction */:
-        return true;
-      default:
-        return false;
-    }
-  }
-  function isFunctionLikeKind(kind) {
-    switch (kind) {
-      case 172 /* MethodSignature */:
-      case 178 /* CallSignature */:
-      case 329 /* JSDocSignature */:
-      case 179 /* ConstructSignature */:
-      case 180 /* IndexSignature */:
-      case 183 /* FunctionType */:
-      case 323 /* JSDocFunctionType */:
-      case 184 /* ConstructorType */:
-        return true;
-      default:
-        return isFunctionLikeDeclarationKind(kind);
-    }
-  }
-  function isFunctionOrModuleBlock(node) {
-    return isSourceFile(node) || isModuleBlock(node) || isBlock(node) && isFunctionLike(node.parent);
-  }
-  function isClassElement(node) {
-    const kind = node.kind;
-    return kind === 175 /* Constructor */ || kind === 171 /* PropertyDeclaration */ || kind === 173 /* MethodDeclaration */ || kind === 176 /* GetAccessor */ || kind === 177 /* SetAccessor */ || kind === 180 /* IndexSignature */ || kind === 174 /* ClassStaticBlockDeclaration */ || kind === 239 /* SemicolonClassElement */;
-  }
-  function isClassLike(node) {
-    return node && (node.kind === 262 /* ClassDeclaration */ || node.kind === 230 /* ClassExpression */);
-  }
-  function isAccessor(node) {
-    return node && (node.kind === 176 /* GetAccessor */ || node.kind === 177 /* SetAccessor */);
-  }
-  function isAutoAccessorPropertyDeclaration(node) {
-    return isPropertyDeclaration(node) && hasAccessorModifier(node);
-  }
-  function isMethodOrAccessor(node) {
-    switch (node.kind) {
-      case 173 /* MethodDeclaration */:
-      case 176 /* GetAccessor */:
-      case 177 /* SetAccessor */:
-        return true;
-      default:
-        return false;
-    }
-  }
-  function isNamedClassElement(node) {
-    switch (node.kind) {
-      case 173 /* MethodDeclaration */:
-      case 176 /* GetAccessor */:
-      case 177 /* SetAccessor */:
-      case 171 /* PropertyDeclaration */:
-        return true;
-      default:
-        return false;
-    }
-  }
-  function isModifierLike(node) {
-    return isModifier(node) || isDecorator(node);
-  }
-  function isTypeElement(node) {
-    const kind = node.kind;
-    return kind === 179 /* ConstructSignature */ || kind === 178 /* CallSignature */ || kind === 170 /* PropertySignature */ || kind === 172 /* MethodSignature */ || kind === 180 /* IndexSignature */ || kind === 176 /* GetAccessor */ || kind === 177 /* SetAccessor */;
-  }
-  function isClassOrTypeElement(node) {
-    return isTypeElement(node) || isClassElement(node);
-  }
-  function isObjectLiteralElementLike(node) {
-    const kind = node.kind;
-    return kind === 302 /* PropertyAssignment */ || kind === 303 /* ShorthandPropertyAssignment */ || kind === 304 /* SpreadAssignment */ || kind === 173 /* MethodDeclaration */ || kind === 176 /* GetAccessor */ || kind === 177 /* SetAccessor */;
-  }
-  function isTypeNode(node) {
-    return isTypeNodeKind(node.kind);
-  }
-  function isFunctionOrConstructorTypeNode(node) {
-    switch (node.kind) {
-      case 183 /* FunctionType */:
-      case 184 /* ConstructorType */:
-        return true;
-    }
-    return false;
-  }
-  function isBindingPattern(node) {
-    if (node) {
-      const kind = node.kind;
-      return kind === 206 /* ArrayBindingPattern */ || kind === 205 /* ObjectBindingPattern */;
-    }
-    return false;
-  }
-  function isAssignmentPattern(node) {
-    const kind = node.kind;
-    return kind === 208 /* ArrayLiteralExpression */ || kind === 209 /* ObjectLiteralExpression */;
-  }
-  function isArrayBindingElement(node) {
-    const kind = node.kind;
-    return kind === 207 /* BindingElement */ || kind === 231 /* OmittedExpression */;
-  }
-  function isDeclarationBindingElement(bindingElement) {
-    switch (bindingElement.kind) {
-      case 259 /* VariableDeclaration */:
-      case 168 /* Parameter */:
-      case 207 /* BindingElement */:
-        return true;
-    }
-    return false;
-  }
-  function isBindingOrAssignmentElement(node) {
-    return isVariableDeclaration(node) || isParameter(node) || isObjectBindingOrAssignmentElement(node) || isArrayBindingOrAssignmentElement(node);
-  }
-  function isBindingOrAssignmentPattern(node) {
-    return isObjectBindingOrAssignmentPattern(node) || isArrayBindingOrAssignmentPattern(node);
-  }
-  function isObjectBindingOrAssignmentPattern(node) {
-    switch (node.kind) {
-      case 205 /* ObjectBindingPattern */:
-      case 209 /* ObjectLiteralExpression */:
-        return true;
-    }
-    return false;
-  }
-  function isObjectBindingOrAssignmentElement(node) {
-    switch (node.kind) {
-      case 207 /* BindingElement */:
-      case 302 /* PropertyAssignment */:
-      case 303 /* ShorthandPropertyAssignment */:
-      case 304 /* SpreadAssignment */:
-        return true;
-    }
-    return false;
-  }
-  function isArrayBindingOrAssignmentPattern(node) {
-    switch (node.kind) {
-      case 206 /* ArrayBindingPattern */:
-      case 208 /* ArrayLiteralExpression */:
-        return true;
-    }
-    return false;
-  }
-  function isArrayBindingOrAssignmentElement(node) {
-    switch (node.kind) {
-      case 207 /* BindingElement */:
-      case 231 /* OmittedExpression */:
-      case 229 /* SpreadElement */:
-      case 208 /* ArrayLiteralExpression */:
-      case 209 /* ObjectLiteralExpression */:
-      case 80 /* Identifier */:
-      case 210 /* PropertyAccessExpression */:
-      case 211 /* ElementAccessExpression */:
-        return true;
-    }
-    return isAssignmentExpression(
-      node,
-      /*excludeCompoundAssignment*/
-      true
-    );
-  }
-  function isPropertyAccessOrQualifiedNameOrImportTypeNode(node) {
-    const kind = node.kind;
-    return kind === 210 /* PropertyAccessExpression */ || kind === 165 /* QualifiedName */ || kind === 204 /* ImportType */;
-  }
-  function isPropertyAccessOrQualifiedName(node) {
-    const kind = node.kind;
-    return kind === 210 /* PropertyAccessExpression */ || kind === 165 /* QualifiedName */;
-  }
-  function isCallLikeExpression(node) {
-    switch (node.kind) {
-      case 285 /* JsxOpeningElement */:
-      case 284 /* JsxSelfClosingElement */:
-      case 212 /* CallExpression */:
-      case 213 /* NewExpression */:
-      case 214 /* TaggedTemplateExpression */:
-      case 169 /* Decorator */:
-        return true;
-      default:
-        return false;
-    }
-  }
-  function isCallOrNewExpression(node) {
-    return node.kind === 212 /* CallExpression */ || node.kind === 213 /* NewExpression */;
-  }
-  function isTemplateLiteral(node) {
-    const kind = node.kind;
-    return kind === 227 /* TemplateExpression */ || kind === 15 /* NoSubstitutionTemplateLiteral */;
-  }
-  function isLeftHandSideExpression(node) {
-    return isLeftHandSideExpressionKind(skipPartiallyEmittedExpressions(node).kind);
-  }
-  function isLeftHandSideExpressionKind(kind) {
-    switch (kind) {
-      case 210 /* PropertyAccessExpression */:
-      case 211 /* ElementAccessExpression */:
-      case 213 /* NewExpression */:
-      case 212 /* CallExpression */:
-      case 283 /* JsxElement */:
-      case 284 /* JsxSelfClosingElement */:
-      case 287 /* JsxFragment */:
-      case 214 /* TaggedTemplateExpression */:
-      case 208 /* ArrayLiteralExpression */:
-      case 216 /* ParenthesizedExpression */:
-      case 209 /* ObjectLiteralExpression */:
-      case 230 /* ClassExpression */:
-      case 217 /* FunctionExpression */:
-      case 80 /* Identifier */:
-      case 81 /* PrivateIdentifier */:
-      case 14 /* RegularExpressionLiteral */:
-      case 9 /* NumericLiteral */:
-      case 10 /* BigIntLiteral */:
-      case 11 /* StringLiteral */:
-      case 15 /* NoSubstitutionTemplateLiteral */:
-      case 227 /* TemplateExpression */:
-      case 97 /* FalseKeyword */:
-      case 106 /* NullKeyword */:
-      case 110 /* ThisKeyword */:
-      case 112 /* TrueKeyword */:
-      case 108 /* SuperKeyword */:
-      case 234 /* NonNullExpression */:
-      case 232 /* ExpressionWithTypeArguments */:
-      case 235 /* MetaProperty */:
-      case 102 /* ImportKeyword */:
-      case 281 /* MissingDeclaration */:
-        return true;
-      default:
-        return false;
-    }
-  }
-  function isUnaryExpression(node) {
-    return isUnaryExpressionKind(skipPartiallyEmittedExpressions(node).kind);
-  }
-  function isUnaryExpressionKind(kind) {
-    switch (kind) {
-      case 223 /* PrefixUnaryExpression */:
-      case 224 /* PostfixUnaryExpression */:
-      case 219 /* DeleteExpression */:
-      case 220 /* TypeOfExpression */:
-      case 221 /* VoidExpression */:
-      case 222 /* AwaitExpression */:
-      case 215 /* TypeAssertionExpression */:
-        return true;
-      default:
-        return isLeftHandSideExpressionKind(kind);
-    }
-  }
-  function isUnaryExpressionWithWrite(expr) {
-    switch (expr.kind) {
-      case 224 /* PostfixUnaryExpression */:
-        return true;
-      case 223 /* PrefixUnaryExpression */:
-        return expr.operator === 46 /* PlusPlusToken */ || expr.operator === 47 /* MinusMinusToken */;
-      default:
-        return false;
-    }
-  }
-  function isLiteralTypeLiteral(node) {
-    switch (node.kind) {
-      case 106 /* NullKeyword */:
-      case 112 /* TrueKeyword */:
-      case 97 /* FalseKeyword */:
-      case 223 /* PrefixUnaryExpression */:
-        return true;
-      default:
-        return isLiteralExpression(node);
-    }
-  }
-  function isExpression(node) {
-    return isExpressionKind(skipPartiallyEmittedExpressions(node).kind);
-  }
-  function isExpressionKind(kind) {
-    switch (kind) {
-      case 226 /* ConditionalExpression */:
-      case 228 /* YieldExpression */:
-      case 218 /* ArrowFunction */:
-      case 225 /* BinaryExpression */:
-      case 229 /* SpreadElement */:
-      case 233 /* AsExpression */:
-      case 231 /* OmittedExpression */:
-      case 360 /* CommaListExpression */:
-      case 359 /* PartiallyEmittedExpression */:
-      case 237 /* SatisfiesExpression */:
-        return true;
-      default:
-        return isUnaryExpressionKind(kind);
-    }
-  }
-  function isAssertionExpression(node) {
-    const kind = node.kind;
-    return kind === 215 /* TypeAssertionExpression */ || kind === 233 /* AsExpression */;
-  }
-  function isNotEmittedOrPartiallyEmittedNode(node) {
-    return isNotEmittedStatement(node) || isPartiallyEmittedExpression(node);
-  }
-  function isIterationStatement(node, lookInLabeledStatements) {
-    switch (node.kind) {
-      case 247 /* ForStatement */:
-      case 248 /* ForInStatement */:
-      case 249 /* ForOfStatement */:
-      case 245 /* DoStatement */:
-      case 246 /* WhileStatement */:
-        return true;
-      case 255 /* LabeledStatement */:
-        return lookInLabeledStatements && isIterationStatement(node.statement, lookInLabeledStatements);
-    }
-    return false;
-  }
-  function isScopeMarker(node) {
-    return isExportAssignment(node) || isExportDeclaration(node);
-  }
-  function hasScopeMarker(statements) {
-    return some(statements, isScopeMarker);
-  }
-  function needsScopeMarker(result) {
-    return !isAnyImportOrReExport(result) && !isExportAssignment(result) && !hasSyntacticModifier(result, 1 /* Export */) && !isAmbientModule(result);
-  }
-  function isExternalModuleIndicator(result) {
-    return isAnyImportOrReExport(result) || isExportAssignment(result) || hasSyntacticModifier(result, 1 /* Export */);
-  }
-  function isForInOrOfStatement(node) {
-    return node.kind === 248 /* ForInStatement */ || node.kind === 249 /* ForOfStatement */;
-  }
-  function isConciseBody(node) {
-    return isBlock(node) || isExpression(node);
-  }
-  function isFunctionBody(node) {
-    return isBlock(node);
-  }
-  function isForInitializer(node) {
-    return isVariableDeclarationList(node) || isExpression(node);
-  }
-  function isModuleBody(node) {
-    const kind = node.kind;
-    return kind === 267 /* ModuleBlock */ || kind === 266 /* ModuleDeclaration */ || kind === 80 /* Identifier */;
-  }
-  function isNamespaceBody(node) {
-    const kind = node.kind;
-    return kind === 267 /* ModuleBlock */ || kind === 266 /* ModuleDeclaration */;
-  }
-  function isJSDocNamespaceBody(node) {
-    const kind = node.kind;
-    return kind === 80 /* Identifier */ || kind === 266 /* ModuleDeclaration */;
-  }
-  function isNamedImportBindings(node) {
-    const kind = node.kind;
-    return kind === 274 /* NamedImports */ || kind === 273 /* NamespaceImport */;
-  }
-  function isModuleOrEnumDeclaration(node) {
-    return node.kind === 266 /* ModuleDeclaration */ || node.kind === 265 /* EnumDeclaration */;
-  }
-  function canHaveSymbol(node) {
-    switch (node.kind) {
-      case 218 /* ArrowFunction */:
-      case 225 /* BinaryExpression */:
-      case 207 /* BindingElement */:
-      case 212 /* CallExpression */:
-      case 178 /* CallSignature */:
-      case 262 /* ClassDeclaration */:
-      case 230 /* ClassExpression */:
-      case 174 /* ClassStaticBlockDeclaration */:
-      case 175 /* Constructor */:
-      case 184 /* ConstructorType */:
-      case 179 /* ConstructSignature */:
-      case 211 /* ElementAccessExpression */:
-      case 265 /* EnumDeclaration */:
-      case 305 /* EnumMember */:
-      case 276 /* ExportAssignment */:
-      case 277 /* ExportDeclaration */:
-      case 280 /* ExportSpecifier */:
-      case 261 /* FunctionDeclaration */:
-      case 217 /* FunctionExpression */:
-      case 183 /* FunctionType */:
-      case 176 /* GetAccessor */:
-      case 80 /* Identifier */:
-      case 272 /* ImportClause */:
-      case 270 /* ImportEqualsDeclaration */:
-      case 275 /* ImportSpecifier */:
-      case 180 /* IndexSignature */:
-      case 263 /* InterfaceDeclaration */:
-      case 344 /* JSDocCallbackTag */:
-      case 346 /* JSDocEnumTag */:
-      case 323 /* JSDocFunctionType */:
-      case 347 /* JSDocParameterTag */:
-      case 354 /* JSDocPropertyTag */:
-      case 329 /* JSDocSignature */:
-      case 352 /* JSDocTypedefTag */:
-      case 328 /* JSDocTypeLiteral */:
-      case 290 /* JsxAttribute */:
-      case 291 /* JsxAttributes */:
-      case 292 /* JsxSpreadAttribute */:
-      case 199 /* MappedType */:
-      case 173 /* MethodDeclaration */:
-      case 172 /* MethodSignature */:
-      case 266 /* ModuleDeclaration */:
-      case 201 /* NamedTupleMember */:
-      case 279 /* NamespaceExport */:
-      case 269 /* NamespaceExportDeclaration */:
-      case 273 /* NamespaceImport */:
-      case 213 /* NewExpression */:
-      case 15 /* NoSubstitutionTemplateLiteral */:
-      case 9 /* NumericLiteral */:
-      case 209 /* ObjectLiteralExpression */:
-      case 168 /* Parameter */:
-      case 210 /* PropertyAccessExpression */:
-      case 302 /* PropertyAssignment */:
-      case 171 /* PropertyDeclaration */:
-      case 170 /* PropertySignature */:
-      case 177 /* SetAccessor */:
-      case 303 /* ShorthandPropertyAssignment */:
-      case 311 /* SourceFile */:
-      case 304 /* SpreadAssignment */:
-      case 11 /* StringLiteral */:
-      case 264 /* TypeAliasDeclaration */:
-      case 186 /* TypeLiteral */:
-      case 167 /* TypeParameter */:
-      case 259 /* VariableDeclaration */:
-        return true;
-      default:
-        return false;
-    }
-  }
-  function canHaveLocals(node) {
-    switch (node.kind) {
-      case 218 /* ArrowFunction */:
-      case 240 /* Block */:
-      case 178 /* CallSignature */:
-      case 268 /* CaseBlock */:
-      case 298 /* CatchClause */:
-      case 174 /* ClassStaticBlockDeclaration */:
-      case 193 /* ConditionalType */:
-      case 175 /* Constructor */:
-      case 184 /* ConstructorType */:
-      case 179 /* ConstructSignature */:
-      case 247 /* ForStatement */:
-      case 248 /* ForInStatement */:
-      case 249 /* ForOfStatement */:
-      case 261 /* FunctionDeclaration */:
-      case 217 /* FunctionExpression */:
-      case 183 /* FunctionType */:
-      case 176 /* GetAccessor */:
-      case 180 /* IndexSignature */:
-      case 344 /* JSDocCallbackTag */:
-      case 346 /* JSDocEnumTag */:
-      case 323 /* JSDocFunctionType */:
-      case 329 /* JSDocSignature */:
-      case 352 /* JSDocTypedefTag */:
-      case 199 /* MappedType */:
-      case 173 /* MethodDeclaration */:
-      case 172 /* MethodSignature */:
-      case 266 /* ModuleDeclaration */:
-      case 177 /* SetAccessor */:
-      case 311 /* SourceFile */:
-      case 264 /* TypeAliasDeclaration */:
-        return true;
-      default:
-        return false;
-    }
-  }
-  function isDeclarationKind(kind) {
-    return kind === 218 /* ArrowFunction */ || kind === 207 /* BindingElement */ || kind === 262 /* ClassDeclaration */ || kind === 230 /* ClassExpression */ || kind === 174 /* ClassStaticBlockDeclaration */ || kind === 175 /* Constructor */ || kind === 265 /* EnumDeclaration */ || kind === 305 /* EnumMember */ || kind === 280 /* ExportSpecifier */ || kind === 261 /* FunctionDeclaration */ || kind === 217 /* FunctionExpression */ || kind === 176 /* GetAccessor */ || kind === 272 /* ImportClause */ || kind === 270 /* ImportEqualsDeclaration */ || kind === 275 /* ImportSpecifier */ || kind === 263 /* InterfaceDeclaration */ || kind === 290 /* JsxAttribute */ || kind === 173 /* MethodDeclaration */ || kind === 172 /* MethodSignature */ || kind === 266 /* ModuleDeclaration */ || kind === 269 /* NamespaceExportDeclaration */ || kind === 273 /* NamespaceImport */ || kind === 279 /* NamespaceExport */ || kind === 168 /* Parameter */ || kind === 302 /* PropertyAssignment */ || kind === 171 /* PropertyDeclaration */ || kind === 170 /* PropertySignature */ || kind === 177 /* SetAccessor */ || kind === 303 /* ShorthandPropertyAssignment */ || kind === 264 /* TypeAliasDeclaration */ || kind === 167 /* TypeParameter */ || kind === 259 /* VariableDeclaration */ || kind === 352 /* JSDocTypedefTag */ || kind === 344 /* JSDocCallbackTag */ || kind === 354 /* JSDocPropertyTag */;
-  }
-  function isDeclarationStatementKind(kind) {
-    return kind === 261 /* FunctionDeclaration */ || kind === 281 /* MissingDeclaration */ || kind === 262 /* ClassDeclaration */ || kind === 263 /* InterfaceDeclaration */ || kind === 264 /* TypeAliasDeclaration */ || kind === 265 /* EnumDeclaration */ || kind === 266 /* ModuleDeclaration */ || kind === 271 /* ImportDeclaration */ || kind === 270 /* ImportEqualsDeclaration */ || kind === 277 /* ExportDeclaration */ || kind === 276 /* ExportAssignment */ || kind === 269 /* NamespaceExportDeclaration */;
-  }
-  function isStatementKindButNotDeclarationKind(kind) {
-    return kind === 251 /* BreakStatement */ || kind === 250 /* ContinueStatement */ || kind === 258 /* DebuggerStatement */ || kind === 245 /* DoStatement */ || kind === 243 /* ExpressionStatement */ || kind === 241 /* EmptyStatement */ || kind === 248 /* ForInStatement */ || kind === 249 /* ForOfStatement */ || kind === 247 /* ForStatement */ || kind === 244 /* IfStatement */ || kind === 255 /* LabeledStatement */ || kind === 252 /* ReturnStatement */ || kind === 254 /* SwitchStatement */ || kind === 256 /* ThrowStatement */ || kind === 257 /* TryStatement */ || kind === 242 /* VariableStatement */ || kind === 246 /* WhileStatement */ || kind === 253 /* WithStatement */ || kind === 358 /* NotEmittedStatement */;
-  }
-  function isDeclaration(node) {
-    if (node.kind === 167 /* TypeParameter */) {
-      return node.parent && node.parent.kind !== 351 /* JSDocTemplateTag */ || isInJSFile(node);
-    }
-    return isDeclarationKind(node.kind);
-  }
-  function isDeclarationStatement(node) {
-    return isDeclarationStatementKind(node.kind);
-  }
-  function isStatementButNotDeclaration(node) {
-    return isStatementKindButNotDeclarationKind(node.kind);
-  }
-  function isStatement(node) {
-    const kind = node.kind;
-    return isStatementKindButNotDeclarationKind(kind) || isDeclarationStatementKind(kind) || isBlockStatement(node);
-  }
-  function isBlockStatement(node) {
-    if (node.kind !== 240 /* Block */)
-      return false;
-    if (node.parent !== void 0) {
-      if (node.parent.kind === 257 /* TryStatement */ || node.parent.kind === 298 /* CatchClause */) {
-        return false;
-      }
-    }
-    return !isFunctionBlock(node);
-  }
-  function isStatementOrBlock(node) {
-    const kind = node.kind;
-    return isStatementKindButNotDeclarationKind(kind) || isDeclarationStatementKind(kind) || kind === 240 /* Block */;
-  }
-  function isModuleReference(node) {
-    const kind = node.kind;
-    return kind === 282 /* ExternalModuleReference */ || kind === 165 /* QualifiedName */ || kind === 80 /* Identifier */;
-  }
-  function isJsxTagNameExpression(node) {
-    const kind = node.kind;
-    return kind === 110 /* ThisKeyword */ || kind === 80 /* Identifier */ || kind === 210 /* PropertyAccessExpression */ || kind === 294 /* JsxNamespacedName */;
-  }
-  function isJsxChild(node) {
-    const kind = node.kind;
-    return kind === 283 /* JsxElement */ || kind === 293 /* JsxExpression */ || kind === 284 /* JsxSelfClosingElement */ || kind === 12 /* JsxText */ || kind === 287 /* JsxFragment */;
-  }
-  function isJsxAttributeLike(node) {
-    const kind = node.kind;
-    return kind === 290 /* JsxAttribute */ || kind === 292 /* JsxSpreadAttribute */;
-  }
-  function isStringLiteralOrJsxExpression(node) {
-    const kind = node.kind;
-    return kind === 11 /* StringLiteral */ || kind === 293 /* JsxExpression */;
-  }
-  function isJsxOpeningLikeElement(node) {
-    const kind = node.kind;
-    return kind === 285 /* JsxOpeningElement */ || kind === 284 /* JsxSelfClosingElement */;
-  }
-  function isCaseOrDefaultClause(node) {
-    const kind = node.kind;
-    return kind === 295 /* CaseClause */ || kind === 296 /* DefaultClause */;
-  }
-  function isJSDocNode(node) {
-    return node.kind >= 315 /* FirstJSDocNode */ && node.kind <= 356 /* LastJSDocNode */;
-  }
-  function isJSDocCommentContainingNode(node) {
-    return node.kind === 326 /* JSDoc */ || node.kind === 325 /* JSDocNamepathType */ || node.kind === 327 /* JSDocText */ || isJSDocLinkLike(node) || isJSDocTag(node) || isJSDocTypeLiteral(node) || isJSDocSignature(node);
-  }
-  function isJSDocTag(node) {
-    return node.kind >= 333 /* FirstJSDocTagNode */ && node.kind <= 356 /* LastJSDocTagNode */;
-  }
-  function isSetAccessor(node) {
-    return node.kind === 177 /* SetAccessor */;
-  }
-  function isGetAccessor(node) {
-    return node.kind === 176 /* GetAccessor */;
-  }
-  function hasJSDocNodes(node) {
-    if (!canHaveJSDoc(node))
-      return false;
-    const { jsDoc } = node;
-    return !!jsDoc && jsDoc.length > 0;
-  }
-  function hasType(node) {
-    return !!node.type;
-  }
-  function hasInitializer(node) {
-    return !!node.initializer;
-  }
-  function hasOnlyExpressionInitializer(node) {
-    switch (node.kind) {
-      case 259 /* VariableDeclaration */:
-      case 168 /* Parameter */:
-      case 207 /* BindingElement */:
-      case 171 /* PropertyDeclaration */:
-      case 302 /* PropertyAssignment */:
-      case 305 /* EnumMember */:
-        return true;
-      default:
-        return false;
-    }
-  }
-  function isObjectLiteralElement(node) {
-    return node.kind === 290 /* JsxAttribute */ || node.kind === 292 /* JsxSpreadAttribute */ || isObjectLiteralElementLike(node);
-  }
-  function isTypeReferenceType(node) {
-    return node.kind === 182 /* TypeReference */ || node.kind === 232 /* ExpressionWithTypeArguments */;
-  }
-  function guessIndentation(lines) {
-    let indentation = MAX_SMI_X86;
-    for (const line of lines) {
-      if (!line.length) {
-        continue;
-      }
-      let i = 0;
-      for (; i < line.length && i < indentation; i++) {
-        if (!isWhiteSpaceLike(line.charCodeAt(i))) {
-          break;
-        }
-      }
-      if (i < indentation) {
-        indentation = i;
-      }
-      if (indentation === 0) {
-        return 0;
-      }
-    }
-    return indentation === MAX_SMI_X86 ? void 0 : indentation;
-  }
-  function isStringLiteralLike(node) {
-    return node.kind === 11 /* StringLiteral */ || node.kind === 15 /* NoSubstitutionTemplateLiteral */;
-  }
-  function isJSDocLinkLike(node) {
-    return node.kind === 330 /* JSDocLink */ || node.kind === 331 /* JSDocLinkCode */ || node.kind === 332 /* JSDocLinkPlain */;
-  }
-  function hasRestParameter(s) {
-    const last2 = lastOrUndefined(s.parameters);
-    return !!last2 && isRestParameter(last2);
-  }
-  function isRestParameter(node) {
-    const type = isJSDocParameterTag(node) ? node.typeExpression && node.typeExpression.type : node.type;
-    return node.dotDotDotToken !== void 0 || !!type && type.kind === 324 /* JSDocVariadicType */;
-  }
-  var unchangedTextChangeRange, supportedLocaleDirectories, MAX_SMI_X86;
-  var init_utilitiesPublic = __esm({
-    "src/compiler/utilitiesPublic.ts"() {
-      "use strict";
-      init_ts2();
-      unchangedTextChangeRange = createTextChangeRange(createTextSpan(0, 0), 0);
-      supportedLocaleDirectories = ["cs", "de", "es", "fr", "it", "ja", "ko", "pl", "pt-br", "ru", "tr", "zh-cn", "zh-tw"];
-      MAX_SMI_X86 = 1073741823;
-    }
-  });
-
-  // src/compiler/utilities.ts
-  function getDeclarationOfKind(symbol, kind) {
-    const declarations = symbol.declarations;
-    if (declarations) {
-      for (const declaration of declarations) {
-        if (declaration.kind === kind) {
-          return declaration;
-        }
-      }
-    }
-    return void 0;
-  }
-  function getDeclarationsOfKind(symbol, kind) {
-    return filter(symbol.declarations || emptyArray, (d) => d.kind === kind);
-  }
-  function createSymbolTable(symbols) {
-    const result = /* @__PURE__ */ new Map();
-    if (symbols) {
-      for (const symbol of symbols) {
-        result.set(symbol.escapedName, symbol);
-      }
-    }
-    return result;
-  }
-  function isTransientSymbol(symbol) {
-    return (symbol.flags & 33554432 /* Transient */) !== 0;
-  }
-  function createSingleLineStringWriter() {
-    var str = "";
-    const writeText = (text) => str += text;
-    return {
-      getText: () => str,
-      write: writeText,
-      rawWrite: writeText,
-      writeKeyword: writeText,
-      writeOperator: writeText,
-      writePunctuation: writeText,
-      writeSpace: writeText,
-      writeStringLiteral: writeText,
-      writeLiteral: writeText,
-      writeParameter: writeText,
-      writeProperty: writeText,
-      writeSymbol: (s, _) => writeText(s),
-      writeTrailingSemicolon: writeText,
-      writeComment: writeText,
-      getTextPos: () => str.length,
-      getLine: () => 0,
-      getColumn: () => 0,
-      getIndent: () => 0,
-      isAtStartOfLine: () => false,
-      hasTrailingComment: () => false,
-      hasTrailingWhitespace: () => !!str.length && isWhiteSpaceLike(str.charCodeAt(str.length - 1)),
-      // Completely ignore indentation for string writers.  And map newlines to
-      // a single space.
-      writeLine: () => str += " ",
-      increaseIndent: noop,
-      decreaseIndent: noop,
-      clear: () => str = ""
-    };
-  }
-  function changesAffectModuleResolution(oldOptions, newOptions) {
-    return oldOptions.configFilePath !== newOptions.configFilePath || optionsHaveModuleResolutionChanges(oldOptions, newOptions);
-  }
-  function optionsHaveModuleResolutionChanges(oldOptions, newOptions) {
-    return optionsHaveChanges(oldOptions, newOptions, moduleResolutionOptionDeclarations);
-  }
-  function changesAffectingProgramStructure(oldOptions, newOptions) {
-    return optionsHaveChanges(oldOptions, newOptions, optionsAffectingProgramStructure);
-  }
-  function optionsHaveChanges(oldOptions, newOptions, optionDeclarations2) {
-    return oldOptions !== newOptions && optionDeclarations2.some((o) => !isJsonEqual(getCompilerOptionValue(oldOptions, o), getCompilerOptionValue(newOptions, o)));
-  }
-  function forEachAncestor(node, callback) {
-    while (true) {
-      const res = callback(node);
-      if (res === "quit")
-        return void 0;
-      if (res !== void 0)
-        return res;
-      if (isSourceFile(node))
-        return void 0;
-      node = node.parent;
-    }
-  }
-  function forEachEntry(map2, callback) {
-    const iterator = map2.entries();
-    for (const [key, value] of iterator) {
-      const result = callback(value, key);
-      if (result) {
-        return result;
-      }
-    }
-    return void 0;
-  }
-  function forEachKey(map2, callback) {
-    const iterator = map2.keys();
-    for (const key of iterator) {
-      const result = callback(key);
-      if (result) {
-        return result;
-      }
-    }
-    return void 0;
-  }
-  function copyEntries(source, target) {
-    source.forEach((value, key) => {
-      target.set(key, value);
-    });
-  }
-  function usingSingleLineStringWriter(action) {
-    const oldString = stringWriter.getText();
-    try {
-      action(stringWriter);
-      return stringWriter.getText();
-    } finally {
-      stringWriter.clear();
-      stringWriter.writeKeyword(oldString);
-    }
-  }
-  function getFullWidth(node) {
-    return node.end - node.pos;
-  }
-  function getResolvedModule(sourceFile, moduleNameText, mode) {
-    var _a, _b;
-    return (_b = (_a = sourceFile == null ? void 0 : sourceFile.resolvedModules) == null ? void 0 : _a.get(moduleNameText, mode)) == null ? void 0 : _b.resolvedModule;
-  }
-  function setResolvedModule(sourceFile, moduleNameText, resolvedModule, mode) {
-    if (!sourceFile.resolvedModules) {
-      sourceFile.resolvedModules = createModeAwareCache();
-    }
-    sourceFile.resolvedModules.set(moduleNameText, mode, resolvedModule);
-  }
-  function setResolvedTypeReferenceDirective(sourceFile, typeReferenceDirectiveName, resolvedTypeReferenceDirective, mode) {
-    if (!sourceFile.resolvedTypeReferenceDirectiveNames) {
-      sourceFile.resolvedTypeReferenceDirectiveNames = createModeAwareCache();
-    }
-    sourceFile.resolvedTypeReferenceDirectiveNames.set(typeReferenceDirectiveName, mode, resolvedTypeReferenceDirective);
-  }
-  function getResolvedTypeReferenceDirective(sourceFile, typeReferenceDirectiveName, mode) {
-    var _a, _b;
-    return (_b = (_a = sourceFile == null ? void 0 : sourceFile.resolvedTypeReferenceDirectiveNames) == null ? void 0 : _a.get(typeReferenceDirectiveName, mode)) == null ? void 0 : _b.resolvedTypeReferenceDirective;
-  }
-  function projectReferenceIsEqualTo(oldRef, newRef) {
-    return oldRef.path === newRef.path && !oldRef.prepend === !newRef.prepend && !oldRef.circular === !newRef.circular;
-  }
-  function moduleResolutionIsEqualTo(oldResolution, newResolution) {
-    return oldResolution === newResolution || oldResolution.resolvedModule === newResolution.resolvedModule || !!oldResolution.resolvedModule && !!newResolution.resolvedModule && oldResolution.resolvedModule.isExternalLibraryImport === newResolution.resolvedModule.isExternalLibraryImport && oldResolution.resolvedModule.extension === newResolution.resolvedModule.extension && oldResolution.resolvedModule.resolvedFileName === newResolution.resolvedModule.resolvedFileName && oldResolution.resolvedModule.originalPath === newResolution.resolvedModule.originalPath && packageIdIsEqual(oldResolution.resolvedModule.packageId, newResolution.resolvedModule.packageId) && oldResolution.node10Result === newResolution.node10Result;
-  }
-  function createModuleNotFoundChain(sourceFile, host, moduleReference, mode, packageName) {
-    var _a, _b;
-    const node10Result = (_b = (_a = sourceFile.resolvedModules) == null ? void 0 : _a.get(moduleReference, mode)) == null ? void 0 : _b.node10Result;
-    const result = node10Result ? chainDiagnosticMessages(
-      /*details*/
-      void 0,
-      Diagnostics.There_are_types_at_0_but_this_result_could_not_be_resolved_when_respecting_package_json_exports_The_1_library_may_need_to_update_its_package_json_or_typings,
-      node10Result,
-      node10Result.indexOf(nodeModulesPathPart + "@types/") > -1 ? `@types/${mangleScopedPackageName(packageName)}` : packageName
-    ) : host.typesPackageExists(packageName) ? chainDiagnosticMessages(
-      /*details*/
-      void 0,
-      Diagnostics.If_the_0_package_actually_exposes_this_module_consider_sending_a_pull_request_to_amend_https_Colon_Slash_Slashgithub_com_SlashDefinitelyTyped_SlashDefinitelyTyped_Slashtree_Slashmaster_Slashtypes_Slash_1,
-      packageName,
-      mangleScopedPackageName(packageName)
-    ) : host.packageBundlesTypes(packageName) ? chainDiagnosticMessages(
-      /*details*/
-      void 0,
-      Diagnostics.If_the_0_package_actually_exposes_this_module_try_adding_a_new_declaration_d_ts_file_containing_declare_module_1,
-      packageName,
-      moduleReference
-    ) : chainDiagnosticMessages(
-      /*details*/
-      void 0,
-      Diagnostics.Try_npm_i_save_dev_types_Slash_1_if_it_exists_or_add_a_new_declaration_d_ts_file_containing_declare_module_0,
-      moduleReference,
-      mangleScopedPackageName(packageName)
-    );
-    if (result)
-      result.repopulateInfo = () => ({ moduleReference, mode, packageName: packageName === moduleReference ? void 0 : packageName });
-    return result;
-  }
-  function packageIdIsEqual(a, b) {
-    return a === b || !!a && !!b && a.name === b.name && a.subModuleName === b.subModuleName && a.version === b.version;
-  }
-  function packageIdToPackageName({ name, subModuleName }) {
-    return subModuleName ? `${name}/${subModuleName}` : name;
-  }
-  function packageIdToString(packageId) {
-    return `${packageIdToPackageName(packageId)}@${packageId.version}`;
-  }
-  function typeDirectiveIsEqualTo(oldResolution, newResolution) {
-    return oldResolution === newResolution || oldResolution.resolvedTypeReferenceDirective === newResolution.resolvedTypeReferenceDirective || !!oldResolution.resolvedTypeReferenceDirective && !!newResolution.resolvedTypeReferenceDirective && oldResolution.resolvedTypeReferenceDirective.resolvedFileName === newResolution.resolvedTypeReferenceDirective.resolvedFileName && !!oldResolution.resolvedTypeReferenceDirective.primary === !!newResolution.resolvedTypeReferenceDirective.primary && oldResolution.resolvedTypeReferenceDirective.originalPath === newResolution.resolvedTypeReferenceDirective.originalPath;
-  }
-  function hasChangesInResolutions(names, newSourceFile, newResolutions, oldResolutions, comparer, nameAndModeGetter) {
-    Debug.assert(names.length === newResolutions.length);
-    for (let i = 0; i < names.length; i++) {
-      const newResolution = newResolutions[i];
-      const entry = names[i];
-      const name = nameAndModeGetter.getName(entry);
-      const mode = nameAndModeGetter.getMode(entry, newSourceFile);
-      const oldResolution = oldResolutions && oldResolutions.get(name, mode);
-      const changed = oldResolution ? !newResolution || !comparer(oldResolution, newResolution) : newResolution;
-      if (changed) {
-        return true;
-      }
-    }
-    return false;
-  }
-  function containsParseError(node) {
-    aggregateChildData(node);
-    return (node.flags & 524288 /* ThisNodeOrAnySubNodesHasError */) !== 0;
-  }
-  function aggregateChildData(node) {
-    if (!(node.flags & 1048576 /* HasAggregatedChildData */)) {
-      const thisNodeOrAnySubNodesHasError = (node.flags & 131072 /* ThisNodeHasError */) !== 0 || forEachChild(node, containsParseError);
-      if (thisNodeOrAnySubNodesHasError) {
-        node.flags |= 524288 /* ThisNodeOrAnySubNodesHasError */;
-      }
-      node.flags |= 1048576 /* HasAggregatedChildData */;
-    }
-  }
-  function getSourceFileOfNode(node) {
-    while (node && node.kind !== 311 /* SourceFile */) {
-      node = node.parent;
-    }
-    return node;
-  }
-  function getSourceFileOfModule(module2) {
-    return getSourceFileOfNode(module2.valueDeclaration || getNonAugmentationDeclaration(module2));
-  }
-  function isPlainJsFile(file, checkJs) {
-    return !!file && (file.scriptKind === 1 /* JS */ || file.scriptKind === 2 /* JSX */) && !file.checkJsDirective && checkJs === void 0;
-  }
-  function isStatementWithLocals(node) {
-    switch (node.kind) {
-      case 240 /* Block */:
-      case 268 /* CaseBlock */:
-      case 247 /* ForStatement */:
-      case 248 /* ForInStatement */:
-      case 249 /* ForOfStatement */:
-        return true;
-    }
-    return false;
-  }
-  function getStartPositionOfLine(line, sourceFile) {
-    Debug.assert(line >= 0);
-    return getLineStarts(sourceFile)[line];
-  }
-  function nodePosToString(node) {
-    const file = getSourceFileOfNode(node);
-    const loc = getLineAndCharacterOfPosition(file, node.pos);
-    return `${file.fileName}(${loc.line + 1},${loc.character + 1})`;
-  }
-  function getEndLinePosition(line, sourceFile) {
-    Debug.assert(line >= 0);
-    const lineStarts = getLineStarts(sourceFile);
-    const lineIndex = line;
-    const sourceText = sourceFile.text;
-    if (lineIndex + 1 === lineStarts.length) {
-      return sourceText.length - 1;
-    } else {
-      const start = lineStarts[lineIndex];
-      let pos = lineStarts[lineIndex + 1] - 1;
-      Debug.assert(isLineBreak(sourceText.charCodeAt(pos)));
-      while (start <= pos && isLineBreak(sourceText.charCodeAt(pos))) {
-        pos--;
-      }
-      return pos;
-    }
-  }
-  function isFileLevelUniqueName(sourceFile, name, hasGlobalName) {
-    return !(hasGlobalName && hasGlobalName(name)) && !sourceFile.identifiers.has(name);
-  }
-  function nodeIsMissing(node) {
-    if (node === void 0) {
-      return true;
-    }
-    return node.pos === node.end && node.pos >= 0 && node.kind !== 1 /* EndOfFileToken */;
-  }
-  function nodeIsPresent(node) {
-    return !nodeIsMissing(node);
-  }
-  function isGrammarError(parent2, child) {
-    if (isTypeParameterDeclaration(parent2))
-      return child === parent2.expression;
-    if (isClassStaticBlockDeclaration(parent2))
-      return child === parent2.modifiers;
-    if (isPropertySignature(parent2))
-      return child === parent2.initializer;
-    if (isPropertyDeclaration(parent2))
-      return child === parent2.questionToken && isAutoAccessorPropertyDeclaration(parent2);
-    if (isPropertyAssignment(parent2))
-      return child === parent2.modifiers || child === parent2.questionToken || child === parent2.exclamationToken || isGrammarErrorElement(parent2.modifiers, child, isModifierLike);
-    if (isShorthandPropertyAssignment(parent2))
-      return child === parent2.equalsToken || child === parent2.modifiers || child === parent2.questionToken || child === parent2.exclamationToken || isGrammarErrorElement(parent2.modifiers, child, isModifierLike);
-    if (isMethodDeclaration(parent2))
-      return child === parent2.exclamationToken;
-    if (isConstructorDeclaration(parent2))
-      return child === parent2.typeParameters || child === parent2.type || isGrammarErrorElement(parent2.typeParameters, child, isTypeParameterDeclaration);
-    if (isGetAccessorDeclaration(parent2))
-      return child === parent2.typeParameters || isGrammarErrorElement(parent2.typeParameters, child, isTypeParameterDeclaration);
-    if (isSetAccessorDeclaration(parent2))
-      return child === parent2.typeParameters || child === parent2.type || isGrammarErrorElement(parent2.typeParameters, child, isTypeParameterDeclaration);
-    if (isNamespaceExportDeclaration(parent2))
-      return child === parent2.modifiers || isGrammarErrorElement(parent2.modifiers, child, isModifierLike);
-    return false;
-  }
-  function isGrammarErrorElement(nodeArray, child, isElement) {
-    if (!nodeArray || isArray(child) || !isElement(child))
-      return false;
-    return contains(nodeArray, child);
-  }
-  function insertStatementsAfterPrologue(to, from, isPrologueDirective2) {
-    if (from === void 0 || from.length === 0)
-      return to;
-    let statementIndex = 0;
-    for (; statementIndex < to.length; ++statementIndex) {
-      if (!isPrologueDirective2(to[statementIndex])) {
-        break;
-      }
-    }
-    to.splice(statementIndex, 0, ...from);
-    return to;
-  }
-  function insertStatementAfterPrologue(to, statement, isPrologueDirective2) {
-    if (statement === void 0)
-      return to;
-    let statementIndex = 0;
-    for (; statementIndex < to.length; ++statementIndex) {
-      if (!isPrologueDirective2(to[statementIndex])) {
-        break;
-      }
-    }
-    to.splice(statementIndex, 0, statement);
-    return to;
-  }
-  function isAnyPrologueDirective(node) {
-    return isPrologueDirective(node) || !!(getEmitFlags(node) & 2097152 /* CustomPrologue */);
-  }
-  function insertStatementsAfterStandardPrologue(to, from) {
-    return insertStatementsAfterPrologue(to, from, isPrologueDirective);
-  }
-  function insertStatementsAfterCustomPrologue(to, from) {
-    return insertStatementsAfterPrologue(to, from, isAnyPrologueDirective);
-  }
-  function insertStatementAfterStandardPrologue(to, statement) {
-    return insertStatementAfterPrologue(to, statement, isPrologueDirective);
-  }
-  function insertStatementAfterCustomPrologue(to, statement) {
-    return insertStatementAfterPrologue(to, statement, isAnyPrologueDirective);
-  }
-  function isRecognizedTripleSlashComment(text, commentPos, commentEnd) {
-    if (text.charCodeAt(commentPos + 1) === 47 /* slash */ && commentPos + 2 < commentEnd && text.charCodeAt(commentPos + 2) === 47 /* slash */) {
-      const textSubStr = text.substring(commentPos, commentEnd);
-      return fullTripleSlashReferencePathRegEx.test(textSubStr) || fullTripleSlashAMDReferencePathRegEx.test(textSubStr) || fullTripleSlashAMDModuleRegEx.test(textSubStr) || fullTripleSlashReferenceTypeReferenceDirectiveRegEx.test(textSubStr) || fullTripleSlashLibReferenceRegEx.test(textSubStr) || defaultLibReferenceRegEx.test(textSubStr) ? true : false;
-    }
-    return false;
-  }
-  function isPinnedComment(text, start) {
-    return text.charCodeAt(start + 1) === 42 /* asterisk */ && text.charCodeAt(start + 2) === 33 /* exclamation */;
-  }
-  function createCommentDirectivesMap(sourceFile, commentDirectives) {
-    const directivesByLine = new Map(
-      commentDirectives.map((commentDirective) => [
-        `${getLineAndCharacterOfPosition(sourceFile, commentDirective.range.end).line}`,
-        commentDirective
-      ])
-    );
-    const usedLines = /* @__PURE__ */ new Map();
-    return { getUnusedExpectations, markUsed };
-    function getUnusedExpectations() {
-      return arrayFrom(directivesByLine.entries()).filter(([line, directive]) => directive.type === 0 /* ExpectError */ && !usedLines.get(line)).map(([_, directive]) => directive);
-    }
-    function markUsed(line) {
-      if (!directivesByLine.has(`${line}`)) {
-        return false;
-      }
-      usedLines.set(`${line}`, true);
-      return true;
-    }
-  }
-  function getTokenPosOfNode(node, sourceFile, includeJsDoc) {
-    if (nodeIsMissing(node)) {
-      return node.pos;
-    }
-    if (isJSDocNode(node) || node.kind === 12 /* JsxText */) {
-      return skipTrivia(
-        (sourceFile || getSourceFileOfNode(node)).text,
-        node.pos,
-        /*stopAfterLineBreak*/
-        false,
-        /*stopAtComments*/
-        true
-      );
-    }
-    if (includeJsDoc && hasJSDocNodes(node)) {
-      return getTokenPosOfNode(node.jsDoc[0], sourceFile);
-    }
-    if (node.kind === 357 /* SyntaxList */ && node._children.length > 0) {
-      return getTokenPosOfNode(node._children[0], sourceFile, includeJsDoc);
-    }
-    return skipTrivia(
-      (sourceFile || getSourceFileOfNode(node)).text,
-      node.pos,
-      /*stopAfterLineBreak*/
-      false,
-      /*stopAtComments*/
-      false,
-      isInJSDoc(node)
-    );
-  }
-  function getNonDecoratorTokenPosOfNode(node, sourceFile) {
-    const lastDecorator = !nodeIsMissing(node) && canHaveModifiers(node) ? findLast(node.modifiers, isDecorator) : void 0;
-    if (!lastDecorator) {
-      return getTokenPosOfNode(node, sourceFile);
-    }
-    return skipTrivia((sourceFile || getSourceFileOfNode(node)).text, lastDecorator.end);
-  }
-  function getSourceTextOfNodeFromSourceFile(sourceFile, node, includeTrivia = false) {
-    return getTextOfNodeFromSourceText(sourceFile.text, node, includeTrivia);
-  }
-  function isJSDocTypeExpressionOrChild(node) {
-    return !!findAncestor(node, isJSDocTypeExpression);
-  }
-  function isExportNamespaceAsDefaultDeclaration(node) {
-    return !!(isExportDeclaration(node) && node.exportClause && isNamespaceExport(node.exportClause) && node.exportClause.name.escapedText === "default");
-  }
-  function getTextOfNodeFromSourceText(sourceText, node, includeTrivia = false) {
-    if (nodeIsMissing(node)) {
-      return "";
-    }
-    let text = sourceText.substring(includeTrivia ? node.pos : skipTrivia(sourceText, node.pos), node.end);
-    if (isJSDocTypeExpressionOrChild(node)) {
-      text = text.split(/\r\n|\n|\r/).map((line) => trimStringStart(line.replace(/^\s*\*/, ""))).join("\n");
-    }
-    return text;
-  }
-  function getTextOfNode(node, includeTrivia = false) {
-    return getSourceTextOfNodeFromSourceFile(getSourceFileOfNode(node), node, includeTrivia);
-  }
-  function getPos(range) {
-    return range.pos;
-  }
-  function indexOfNode(nodeArray, node) {
-    return binarySearch(nodeArray, node, getPos, compareValues);
-  }
-  function getEmitFlags(node) {
-    const emitNode = node.emitNode;
-    return emitNode && emitNode.flags || 0;
-  }
-  function getInternalEmitFlags(node) {
-    const emitNode = node.emitNode;
-    return emitNode && emitNode.internalFlags || 0;
-  }
-  function getScriptTargetFeatures() {
-    return new Map(Object.entries({
-      Array: new Map(Object.entries({
-        es2015: [
-          "find",
-          "findIndex",
-          "fill",
-          "copyWithin",
-          "entries",
-          "keys",
-          "values"
-        ],
-        es2016: [
-          "includes"
-        ],
-        es2019: [
-          "flat",
-          "flatMap"
-        ],
-        es2022: [
-          "at"
-        ],
-        es2023: [
-          "findLastIndex",
-          "findLast"
-        ]
-      })),
-      Iterator: new Map(Object.entries({
-        es2015: emptyArray
-      })),
-      AsyncIterator: new Map(Object.entries({
-        es2015: emptyArray
-      })),
-      Atomics: new Map(Object.entries({
-        es2017: emptyArray
-      })),
-      SharedArrayBuffer: new Map(Object.entries({
-        es2017: emptyArray
-      })),
-      AsyncIterable: new Map(Object.entries({
-        es2018: emptyArray
-      })),
-      AsyncIterableIterator: new Map(Object.entries({
-        es2018: emptyArray
-      })),
-      AsyncGenerator: new Map(Object.entries({
-        es2018: emptyArray
-      })),
-      AsyncGeneratorFunction: new Map(Object.entries({
-        es2018: emptyArray
-      })),
-      RegExp: new Map(Object.entries({
-        es2015: [
-          "flags",
-          "sticky",
-          "unicode"
-        ],
-        es2018: [
-          "dotAll"
-        ]
-      })),
-      Reflect: new Map(Object.entries({
-        es2015: [
-          "apply",
-          "construct",
-          "defineProperty",
-          "deleteProperty",
-          "get",
-          " getOwnPropertyDescriptor",
-          "getPrototypeOf",
-          "has",
-          "isExtensible",
-          "ownKeys",
-          "preventExtensions",
-          "set",
-          "setPrototypeOf"
-        ]
-      })),
-      ArrayConstructor: new Map(Object.entries({
-        es2015: [
-          "from",
-          "of"
-        ]
-      })),
-      ObjectConstructor: new Map(Object.entries({
-        es2015: [
-          "assign",
-          "getOwnPropertySymbols",
-          "keys",
-          "is",
-          "setPrototypeOf"
-        ],
-        es2017: [
-          "values",
-          "entries",
-          "getOwnPropertyDescriptors"
-        ],
-        es2019: [
-          "fromEntries"
-        ],
-        es2022: [
-          "hasOwn"
-        ]
-      })),
-      NumberConstructor: new Map(Object.entries({
-        es2015: [
-          "isFinite",
-          "isInteger",
-          "isNaN",
-          "isSafeInteger",
-          "parseFloat",
-          "parseInt"
-        ]
-      })),
-      Math: new Map(Object.entries({
-        es2015: [
-          "clz32",
-          "imul",
-          "sign",
-          "log10",
-          "log2",
-          "log1p",
-          "expm1",
-          "cosh",
-          "sinh",
-          "tanh",
-          "acosh",
-          "asinh",
-          "atanh",
-          "hypot",
-          "trunc",
-          "fround",
-          "cbrt"
-        ]
-      })),
-      Map: new Map(Object.entries({
-        es2015: [
-          "entries",
-          "keys",
-          "values"
-        ]
-      })),
-      Set: new Map(Object.entries({
-        es2015: [
-          "entries",
-          "keys",
-          "values"
-        ]
-      })),
-      PromiseConstructor: new Map(Object.entries({
-        es2015: [
-          "all",
-          "race",
-          "reject",
-          "resolve"
-        ],
-        es2020: [
-          "allSettled"
-        ],
-        es2021: [
-          "any"
-        ]
-      })),
-      Symbol: new Map(Object.entries({
-        es2015: [
-          "for",
-          "keyFor"
-        ],
-        es2019: [
-          "description"
-        ]
-      })),
-      WeakMap: new Map(Object.entries({
-        es2015: [
-          "entries",
-          "keys",
-          "values"
-        ]
-      })),
-      WeakSet: new Map(Object.entries({
-        es2015: [
-          "entries",
-          "keys",
-          "values"
-        ]
-      })),
-      String: new Map(Object.entries({
-        es2015: [
-          "codePointAt",
-          "includes",
-          "endsWith",
-          "normalize",
-          "repeat",
-          "startsWith",
-          "anchor",
-          "big",
-          "blink",
-          "bold",
-          "fixed",
-          "fontcolor",
-          "fontsize",
-          "italics",
-          "link",
-          "small",
-          "strike",
-          "sub",
-          "sup"
-        ],
-        es2017: [
-          "padStart",
-          "padEnd"
-        ],
-        es2019: [
-          "trimStart",
-          "trimEnd",
-          "trimLeft",
-          "trimRight"
-        ],
-        es2020: [
-          "matchAll"
-        ],
-        es2021: [
-          "replaceAll"
-        ],
-        es2022: [
-          "at"
-        ]
-      })),
-      StringConstructor: new Map(Object.entries({
-        es2015: [
-          "fromCodePoint",
-          "raw"
-        ]
-      })),
-      DateTimeFormat: new Map(Object.entries({
-        es2017: [
-          "formatToParts"
-        ]
-      })),
-      Promise: new Map(Object.entries({
-        es2015: emptyArray,
-        es2018: [
-          "finally"
-        ]
-      })),
-      RegExpMatchArray: new Map(Object.entries({
-        es2018: [
-          "groups"
-        ]
-      })),
-      RegExpExecArray: new Map(Object.entries({
-        es2018: [
-          "groups"
-        ]
-      })),
-      Intl: new Map(Object.entries({
-        es2018: [
-          "PluralRules"
-        ]
-      })),
-      NumberFormat: new Map(Object.entries({
-        es2018: [
-          "formatToParts"
-        ]
-      })),
-      SymbolConstructor: new Map(Object.entries({
-        es2020: [
-          "matchAll"
-        ]
-      })),
-      DataView: new Map(Object.entries({
-        es2020: [
-          "setBigInt64",
-          "setBigUint64",
-          "getBigInt64",
-          "getBigUint64"
-        ]
-      })),
-      BigInt: new Map(Object.entries({
-        es2020: emptyArray
-      })),
-      RelativeTimeFormat: new Map(Object.entries({
-        es2020: [
-          "format",
-          "formatToParts",
-          "resolvedOptions"
-        ]
-      })),
-      Int8Array: new Map(Object.entries({
-        es2022: [
-          "at"
-        ],
-        es2023: [
-          "findLastIndex",
-          "findLast"
-        ]
-      })),
-      Uint8Array: new Map(Object.entries({
-        es2022: [
-          "at"
-        ],
-        es2023: [
-          "findLastIndex",
-          "findLast"
-        ]
-      })),
-      Uint8ClampedArray: new Map(Object.entries({
-        es2022: [
-          "at"
-        ],
-        es2023: [
-          "findLastIndex",
-          "findLast"
-        ]
-      })),
-      Int16Array: new Map(Object.entries({
-        es2022: [
-          "at"
-        ],
-        es2023: [
-          "findLastIndex",
-          "findLast"
-        ]
-      })),
-      Uint16Array: new Map(Object.entries({
-        es2022: [
-          "at"
-        ],
-        es2023: [
-          "findLastIndex",
-          "findLast"
-        ]
-      })),
-      Int32Array: new Map(Object.entries({
-        es2022: [
-          "at"
-        ],
-        es2023: [
-          "findLastIndex",
-          "findLast"
-        ]
-      })),
-      Uint32Array: new Map(Object.entries({
-        es2022: [
-          "at"
-        ],
-        es2023: [
-          "findLastIndex",
-          "findLast"
-        ]
-      })),
-      Float32Array: new Map(Object.entries({
-        es2022: [
-          "at"
-        ],
-        es2023: [
-          "findLastIndex",
-          "findLast"
-        ]
-      })),
-      Float64Array: new Map(Object.entries({
-        es2022: [
-          "at"
-        ],
-        es2023: [
-          "findLastIndex",
-          "findLast"
-        ]
-      })),
-      BigInt64Array: new Map(Object.entries({
-        es2020: emptyArray,
-        es2022: [
-          "at"
-        ],
-        es2023: [
-          "findLastIndex",
-          "findLast"
-        ]
-      })),
-      BigUint64Array: new Map(Object.entries({
-        es2020: emptyArray,
-        es2022: [
-          "at"
-        ],
-        es2023: [
-          "findLastIndex",
-          "findLast"
-        ]
-      })),
-      Error: new Map(Object.entries({
-        es2022: [
-          "cause"
-        ]
-      }))
-    }));
-  }
-  function getLiteralText(node, sourceFile, flags) {
-    if (sourceFile && canUseOriginalText(node, flags)) {
-      return getSourceTextOfNodeFromSourceFile(sourceFile, node);
-    }
-    switch (node.kind) {
-      case 11 /* StringLiteral */: {
-        const escapeText = flags & 2 /* JsxAttributeEscape */ ? escapeJsxAttributeString : flags & 1 /* NeverAsciiEscape */ || getEmitFlags(node) & 16777216 /* NoAsciiEscaping */ ? escapeString : escapeNonAsciiString;
-        if (node.singleQuote) {
-          return "'" + escapeText(node.text, 39 /* singleQuote */) + "'";
-        } else {
-          return '"' + escapeText(node.text, 34 /* doubleQuote */) + '"';
-        }
-      }
-      case 15 /* NoSubstitutionTemplateLiteral */:
-      case 16 /* TemplateHead */:
-      case 17 /* TemplateMiddle */:
-      case 18 /* TemplateTail */: {
-        const escapeText = flags & 1 /* NeverAsciiEscape */ || getEmitFlags(node) & 16777216 /* NoAsciiEscaping */ ? escapeString : escapeNonAsciiString;
-        const rawText = node.rawText ?? escapeTemplateSubstitution(escapeText(node.text, 96 /* backtick */));
-        switch (node.kind) {
-          case 15 /* NoSubstitutionTemplateLiteral */:
-            return "`" + rawText + "`";
-          case 16 /* TemplateHead */:
-            return "`" + rawText + "${";
-          case 17 /* TemplateMiddle */:
-            return "}" + rawText + "${";
-          case 18 /* TemplateTail */:
-            return "}" + rawText + "`";
-        }
-        break;
-      }
-      case 9 /* NumericLiteral */:
-      case 10 /* BigIntLiteral */:
-        return node.text;
-      case 14 /* RegularExpressionLiteral */:
-        if (flags & 4 /* TerminateUnterminatedLiterals */ && node.isUnterminated) {
-          return node.text + (node.text.charCodeAt(node.text.length - 1) === 92 /* backslash */ ? " /" : "/");
-        }
-        return node.text;
-    }
-    return Debug.fail(`Literal kind '${node.kind}' not accounted for.`);
-  }
-  function canUseOriginalText(node, flags) {
-    if (nodeIsSynthesized(node) || !node.parent || flags & 4 /* TerminateUnterminatedLiterals */ && node.isUnterminated) {
-      return false;
-    }
-    if (isNumericLiteral(node)) {
-      if (node.numericLiteralFlags & 26656 /* IsInvalid */) {
-        return false;
-      }
-      if (node.numericLiteralFlags & 512 /* ContainsSeparator */) {
-        return !!(flags & 8 /* AllowNumericSeparator */);
-      }
-    }
-    return !isBigIntLiteral(node);
-  }
-  function getTextOfConstantValue(value) {
-    return isString(value) ? '"' + escapeNonAsciiString(value) + '"' : "" + value;
-  }
-  function makeIdentifierFromModuleName(moduleName) {
-    return getBaseFileName(moduleName).replace(/^(\d)/, "_$1").replace(/\W/g, "_");
-  }
-  function isBlockOrCatchScoped(declaration) {
-    return (getCombinedNodeFlags(declaration) & 3 /* BlockScoped */) !== 0 || isCatchClauseVariableDeclarationOrBindingElement(declaration);
-  }
-  function isCatchClauseVariableDeclarationOrBindingElement(declaration) {
-    const node = getRootDeclaration(declaration);
-    return node.kind === 259 /* VariableDeclaration */ && node.parent.kind === 298 /* CatchClause */;
-  }
-  function isAmbientModule(node) {
-    return isModuleDeclaration(node) && (node.name.kind === 11 /* StringLiteral */ || isGlobalScopeAugmentation(node));
-  }
-  function isModuleWithStringLiteralName(node) {
-    return isModuleDeclaration(node) && node.name.kind === 11 /* StringLiteral */;
-  }
-  function isNonGlobalAmbientModule(node) {
-    return isModuleDeclaration(node) && isStringLiteral(node.name);
-  }
-  function isEffectiveModuleDeclaration(node) {
-    return isModuleDeclaration(node) || isIdentifier(node);
-  }
-  function isShorthandAmbientModuleSymbol(moduleSymbol) {
-    return isShorthandAmbientModule(moduleSymbol.valueDeclaration);
-  }
-  function isShorthandAmbientModule(node) {
-    return !!node && node.kind === 266 /* ModuleDeclaration */ && !node.body;
-  }
-  function isBlockScopedContainerTopLevel(node) {
-    return node.kind === 311 /* SourceFile */ || node.kind === 266 /* ModuleDeclaration */ || isFunctionLikeOrClassStaticBlockDeclaration(node);
-  }
-  function isGlobalScopeAugmentation(module2) {
-    return !!(module2.flags & 1024 /* GlobalAugmentation */);
-  }
-  function isExternalModuleAugmentation(node) {
-    return isAmbientModule(node) && isModuleAugmentationExternal(node);
-  }
-  function isModuleAugmentationExternal(node) {
-    switch (node.parent.kind) {
-      case 311 /* SourceFile */:
-        return isExternalModule(node.parent);
-      case 267 /* ModuleBlock */:
-        return isAmbientModule(node.parent.parent) && isSourceFile(node.parent.parent.parent) && !isExternalModule(node.parent.parent.parent);
-    }
-    return false;
-  }
-  function getNonAugmentationDeclaration(symbol) {
-    var _a;
-    return (_a = symbol.declarations) == null ? void 0 : _a.find((d) => !isExternalModuleAugmentation(d) && !(isModuleDeclaration(d) && isGlobalScopeAugmentation(d)));
-  }
-  function isCommonJSContainingModuleKind(kind) {
-    return kind === 1 /* CommonJS */ || kind === 100 /* Node16 */ || kind === 199 /* NodeNext */;
-  }
-  function isEffectiveExternalModule(node, compilerOptions) {
-    return isExternalModule(node) || isCommonJSContainingModuleKind(getEmitModuleKind(compilerOptions)) && !!node.commonJsModuleIndicator;
-  }
-  function isEffectiveStrictModeSourceFile(node, compilerOptions) {
-    switch (node.scriptKind) {
-      case 1 /* JS */:
-      case 3 /* TS */:
-      case 2 /* JSX */:
-      case 4 /* TSX */:
-        break;
-      default:
-        return false;
-    }
-    if (node.isDeclarationFile) {
-      return false;
-    }
-    if (getStrictOptionValue(compilerOptions, "alwaysStrict")) {
-      return true;
-    }
-    if (startsWithUseStrict(node.statements)) {
-      return true;
-    }
-    if (isExternalModule(node) || getIsolatedModules(compilerOptions)) {
-      if (getEmitModuleKind(compilerOptions) >= 5 /* ES2015 */) {
-        return true;
-      }
-      return !compilerOptions.noImplicitUseStrict;
-    }
-    return false;
-  }
-  function isAmbientPropertyDeclaration(node) {
-    return !!(node.flags & 16777216 /* Ambient */) || hasSyntacticModifier(node, 2 /* Ambient */);
-  }
-  function isBlockScope(node, parentNode) {
-    switch (node.kind) {
-      case 311 /* SourceFile */:
-      case 268 /* CaseBlock */:
-      case 298 /* CatchClause */:
-      case 266 /* ModuleDeclaration */:
-      case 247 /* ForStatement */:
-      case 248 /* ForInStatement */:
-      case 249 /* ForOfStatement */:
-      case 175 /* Constructor */:
-      case 173 /* MethodDeclaration */:
-      case 176 /* GetAccessor */:
-      case 177 /* SetAccessor */:
-      case 261 /* FunctionDeclaration */:
-      case 217 /* FunctionExpression */:
-      case 218 /* ArrowFunction */:
-      case 171 /* PropertyDeclaration */:
-      case 174 /* ClassStaticBlockDeclaration */:
-        return true;
-      case 240 /* Block */:
-        return !isFunctionLikeOrClassStaticBlockDeclaration(parentNode);
-    }
-    return false;
-  }
-  function isDeclarationWithTypeParameters(node) {
-    Debug.type(node);
-    switch (node.kind) {
-      case 344 /* JSDocCallbackTag */:
-      case 352 /* JSDocTypedefTag */:
-      case 329 /* JSDocSignature */:
-        return true;
-      default:
-        assertType(node);
-        return isDeclarationWithTypeParameterChildren(node);
-    }
-  }
-  function isDeclarationWithTypeParameterChildren(node) {
-    Debug.type(node);
-    switch (node.kind) {
-      case 178 /* CallSignature */:
-      case 179 /* ConstructSignature */:
-      case 172 /* MethodSignature */:
-      case 180 /* IndexSignature */:
-      case 183 /* FunctionType */:
-      case 184 /* ConstructorType */:
-      case 323 /* JSDocFunctionType */:
-      case 262 /* ClassDeclaration */:
-      case 230 /* ClassExpression */:
-      case 263 /* InterfaceDeclaration */:
-      case 264 /* TypeAliasDeclaration */:
-      case 351 /* JSDocTemplateTag */:
-      case 261 /* FunctionDeclaration */:
-      case 173 /* MethodDeclaration */:
-      case 175 /* Constructor */:
-      case 176 /* GetAccessor */:
-      case 177 /* SetAccessor */:
-      case 217 /* FunctionExpression */:
-      case 218 /* ArrowFunction */:
-        return true;
-      default:
-        assertType(node);
-        return false;
-    }
-  }
-  function isAnyImportSyntax(node) {
-    switch (node.kind) {
-      case 271 /* ImportDeclaration */:
-      case 270 /* ImportEqualsDeclaration */:
-        return true;
-      default:
-        return false;
-    }
-  }
-  function isAnyImportOrBareOrAccessedRequire(node) {
-    return isAnyImportSyntax(node) || isVariableDeclarationInitializedToBareOrAccessedRequire(node);
-  }
-  function isLateVisibilityPaintedStatement(node) {
-    switch (node.kind) {
-      case 271 /* ImportDeclaration */:
-      case 270 /* ImportEqualsDeclaration */:
-      case 242 /* VariableStatement */:
-      case 262 /* ClassDeclaration */:
-      case 261 /* FunctionDeclaration */:
-      case 266 /* ModuleDeclaration */:
-      case 264 /* TypeAliasDeclaration */:
-      case 263 /* InterfaceDeclaration */:
-      case 265 /* EnumDeclaration */:
-        return true;
-      default:
-        return false;
-    }
-  }
-  function hasPossibleExternalModuleReference(node) {
-    return isAnyImportOrReExport(node) || isModuleDeclaration(node) || isImportTypeNode(node) || isImportCall(node);
-  }
-  function isAnyImportOrReExport(node) {
-    return isAnyImportSyntax(node) || isExportDeclaration(node);
-  }
-  function getEnclosingBlockScopeContainer(node) {
-    return findAncestor(node.parent, (current) => isBlockScope(current, current.parent));
-  }
-  function forEachEnclosingBlockScopeContainer(node, cb) {
-    let container = getEnclosingBlockScopeContainer(node);
-    while (container) {
-      cb(container);
-      container = getEnclosingBlockScopeContainer(container);
-    }
-  }
-  function declarationNameToString(name) {
-    return !name || getFullWidth(name) === 0 ? "(Missing)" : getTextOfNode(name);
-  }
-  function getNameFromIndexInfo(info) {
-    return info.declaration ? declarationNameToString(info.declaration.parameters[0].name) : void 0;
-  }
-  function isComputedNonLiteralName(name) {
-    return name.kind === 166 /* ComputedPropertyName */ && !isStringOrNumericLiteralLike(name.expression);
-  }
-  function tryGetTextOfPropertyName(name) {
-    var _a;
-    switch (name.kind) {
-      case 80 /* Identifier */:
-      case 81 /* PrivateIdentifier */:
-        return ((_a = name.emitNode) == null ? void 0 : _a.autoGenerate) ? void 0 : name.escapedText;
-      case 11 /* StringLiteral */:
-      case 9 /* NumericLiteral */:
-      case 15 /* NoSubstitutionTemplateLiteral */:
-        return escapeLeadingUnderscores(name.text);
-      case 166 /* ComputedPropertyName */:
-        if (isStringOrNumericLiteralLike(name.expression))
-          return escapeLeadingUnderscores(name.expression.text);
-        return void 0;
-      case 294 /* JsxNamespacedName */:
-        return getEscapedTextOfJsxNamespacedName(name);
-      default:
-        return Debug.assertNever(name);
-    }
-  }
-  function getTextOfPropertyName(name) {
-    return Debug.checkDefined(tryGetTextOfPropertyName(name));
-  }
-  function entityNameToString(name) {
-    switch (name.kind) {
-      case 110 /* ThisKeyword */:
-        return "this";
-      case 81 /* PrivateIdentifier */:
-      case 80 /* Identifier */:
-        return getFullWidth(name) === 0 ? idText(name) : getTextOfNode(name);
-      case 165 /* QualifiedName */:
-        return entityNameToString(name.left) + "." + entityNameToString(name.right);
-      case 210 /* PropertyAccessExpression */:
-        if (isIdentifier(name.name) || isPrivateIdentifier(name.name)) {
-          return entityNameToString(name.expression) + "." + entityNameToString(name.name);
-        } else {
-          return Debug.assertNever(name.name);
-        }
-      case 317 /* JSDocMemberName */:
-        return entityNameToString(name.left) + entityNameToString(name.right);
-      case 294 /* JsxNamespacedName */:
-        return entityNameToString(name.namespace) + ":" + entityNameToString(name.name);
-      default:
-        return Debug.assertNever(name);
-    }
-  }
-  function createDiagnosticForNode(node, message, ...args) {
-    const sourceFile = getSourceFileOfNode(node);
-    return createDiagnosticForNodeInSourceFile(sourceFile, node, message, ...args);
-  }
-  function createDiagnosticForNodeArray(sourceFile, nodes, message, ...args) {
-    const start = skipTrivia(sourceFile.text, nodes.pos);
-    return createFileDiagnostic(sourceFile, start, nodes.end - start, message, ...args);
-  }
-  function createDiagnosticForNodeInSourceFile(sourceFile, node, message, ...args) {
-    const span = getErrorSpanForNode(sourceFile, node);
-    return createFileDiagnostic(sourceFile, span.start, span.length, message, ...args);
-  }
-  function createDiagnosticForNodeFromMessageChain(sourceFile, node, messageChain, relatedInformation) {
-    const span = getErrorSpanForNode(sourceFile, node);
-    return createFileDiagnosticFromMessageChain(sourceFile, span.start, span.length, messageChain, relatedInformation);
-  }
-  function createDiagnosticForNodeArrayFromMessageChain(sourceFile, nodes, messageChain, relatedInformation) {
-    const start = skipTrivia(sourceFile.text, nodes.pos);
-    return createFileDiagnosticFromMessageChain(sourceFile, start, nodes.end - start, messageChain, relatedInformation);
-  }
-  function assertDiagnosticLocation(file, start, length2) {
-    Debug.assertGreaterThanOrEqual(start, 0);
-    Debug.assertGreaterThanOrEqual(length2, 0);
-    if (file) {
-      Debug.assertLessThanOrEqual(start, file.text.length);
-      Debug.assertLessThanOrEqual(start + length2, file.text.length);
-    }
-  }
-  function createFileDiagnosticFromMessageChain(file, start, length2, messageChain, relatedInformation) {
-    assertDiagnosticLocation(file, start, length2);
-    return {
-      file,
-      start,
-      length: length2,
-      code: messageChain.code,
-      category: messageChain.category,
-      messageText: messageChain.next ? messageChain : messageChain.messageText,
-      relatedInformation
-    };
-  }
-  function createDiagnosticForFileFromMessageChain(sourceFile, messageChain, relatedInformation) {
-    return {
-      file: sourceFile,
-      start: 0,
-      length: 0,
-      code: messageChain.code,
-      category: messageChain.category,
-      messageText: messageChain.next ? messageChain : messageChain.messageText,
-      relatedInformation
-    };
-  }
-  function createDiagnosticMessageChainFromDiagnostic(diagnostic) {
-    return typeof diagnostic.messageText === "string" ? {
-      code: diagnostic.code,
-      category: diagnostic.category,
-      messageText: diagnostic.messageText,
-      next: diagnostic.next
-    } : diagnostic.messageText;
-  }
-  function createDiagnosticForRange(sourceFile, range, message) {
-    return {
-      file: sourceFile,
-      start: range.pos,
-      length: range.end - range.pos,
-      code: message.code,
-      category: message.category,
-      messageText: message.message
-    };
-  }
-  function getSpanOfTokenAtPosition(sourceFile, pos) {
-    const scanner2 = createScanner(
-      sourceFile.languageVersion,
-      /*skipTrivia*/
-      true,
-      sourceFile.languageVariant,
-      sourceFile.text,
-      /*onError*/
-      void 0,
-      pos
-    );
-    scanner2.scan();
-    const start = scanner2.getTokenStart();
-    return createTextSpanFromBounds(start, scanner2.getTokenEnd());
-  }
-  function scanTokenAtPosition(sourceFile, pos) {
-    const scanner2 = createScanner(
-      sourceFile.languageVersion,
-      /*skipTrivia*/
-      true,
-      sourceFile.languageVariant,
-      sourceFile.text,
-      /*onError*/
-      void 0,
-      pos
-    );
-    scanner2.scan();
-    return scanner2.getToken();
-  }
-  function getErrorSpanForArrowFunction(sourceFile, node) {
-    const pos = skipTrivia(sourceFile.text, node.pos);
-    if (node.body && node.body.kind === 240 /* Block */) {
-      const { line: startLine } = getLineAndCharacterOfPosition(sourceFile, node.body.pos);
-      const { line: endLine } = getLineAndCharacterOfPosition(sourceFile, node.body.end);
-      if (startLine < endLine) {
-        return createTextSpan(pos, getEndLinePosition(startLine, sourceFile) - pos + 1);
-      }
-    }
-    return createTextSpanFromBounds(pos, node.end);
-  }
-  function getErrorSpanForNode(sourceFile, node) {
-    let errorNode = node;
-    switch (node.kind) {
-      case 311 /* SourceFile */: {
-        const pos2 = skipTrivia(
-          sourceFile.text,
-          0,
-          /*stopAfterLineBreak*/
-          false
-        );
-        if (pos2 === sourceFile.text.length) {
-          return createTextSpan(0, 0);
-        }
-        return getSpanOfTokenAtPosition(sourceFile, pos2);
-      }
-      case 259 /* VariableDeclaration */:
-      case 207 /* BindingElement */:
-      case 262 /* ClassDeclaration */:
-      case 230 /* ClassExpression */:
-      case 263 /* InterfaceDeclaration */:
-      case 266 /* ModuleDeclaration */:
-      case 265 /* EnumDeclaration */:
-      case 305 /* EnumMember */:
-      case 261 /* FunctionDeclaration */:
-      case 217 /* FunctionExpression */:
-      case 173 /* MethodDeclaration */:
-      case 176 /* GetAccessor */:
-      case 177 /* SetAccessor */:
-      case 264 /* TypeAliasDeclaration */:
-      case 171 /* PropertyDeclaration */:
-      case 170 /* PropertySignature */:
-      case 273 /* NamespaceImport */:
-        errorNode = node.name;
-        break;
-      case 218 /* ArrowFunction */:
-        return getErrorSpanForArrowFunction(sourceFile, node);
-      case 295 /* CaseClause */:
-      case 296 /* DefaultClause */: {
-        const start = skipTrivia(sourceFile.text, node.pos);
-        const end = node.statements.length > 0 ? node.statements[0].pos : node.end;
-        return createTextSpanFromBounds(start, end);
-      }
-      case 252 /* ReturnStatement */:
-      case 228 /* YieldExpression */: {
-        const pos2 = skipTrivia(sourceFile.text, node.pos);
-        return getSpanOfTokenAtPosition(sourceFile, pos2);
-      }
-      case 237 /* SatisfiesExpression */: {
-        const pos2 = skipTrivia(sourceFile.text, node.expression.end);
-        return getSpanOfTokenAtPosition(sourceFile, pos2);
-      }
-      case 356 /* JSDocSatisfiesTag */: {
-        const pos2 = skipTrivia(sourceFile.text, node.tagName.pos);
-        return getSpanOfTokenAtPosition(sourceFile, pos2);
-      }
-    }
-    if (errorNode === void 0) {
-      return getSpanOfTokenAtPosition(sourceFile, node.pos);
-    }
-    Debug.assert(!isJSDoc(errorNode));
-    const isMissing = nodeIsMissing(errorNode);
-    const pos = isMissing || isJsxText(node) ? errorNode.pos : skipTrivia(sourceFile.text, errorNode.pos);
-    if (isMissing) {
-      Debug.assert(pos === errorNode.pos, "This failure could trigger https://github.com/Microsoft/TypeScript/issues/20809");
-      Debug.assert(pos === errorNode.end, "This failure could trigger https://github.com/Microsoft/TypeScript/issues/20809");
-    } else {
-      Debug.assert(pos >= errorNode.pos, "This failure could trigger https://github.com/Microsoft/TypeScript/issues/20809");
-      Debug.assert(pos <= errorNode.end, "This failure could trigger https://github.com/Microsoft/TypeScript/issues/20809");
-    }
-    return createTextSpanFromBounds(pos, errorNode.end);
-  }
-  function isExternalOrCommonJsModule(file) {
-    return (file.externalModuleIndicator || file.commonJsModuleIndicator) !== void 0;
-  }
-  function isJsonSourceFile(file) {
-    return file.scriptKind === 6 /* JSON */;
-  }
-  function isEnumConst(node) {
-    return !!(getCombinedModifierFlags(node) & 2048 /* Const */);
-  }
-  function isDeclarationReadonly(declaration) {
-    return !!(getCombinedModifierFlags(declaration) & 64 /* Readonly */ && !isParameterPropertyDeclaration(declaration, declaration.parent));
-  }
-  function isVarConst(node) {
-    return !!(getCombinedNodeFlags(node) & 2 /* Const */);
-  }
-  function isLet(node) {
-    return !!(getCombinedNodeFlags(node) & 1 /* Let */);
-  }
-  function isSuperCall(n) {
-    return n.kind === 212 /* CallExpression */ && n.expression.kind === 108 /* SuperKeyword */;
-  }
-  function isImportCall(n) {
-    return n.kind === 212 /* CallExpression */ && n.expression.kind === 102 /* ImportKeyword */;
-  }
-  function isImportMeta(n) {
-    return isMetaProperty(n) && n.keywordToken === 102 /* ImportKeyword */ && n.name.escapedText === "meta";
-  }
-  function isLiteralImportTypeNode(n) {
-    return isImportTypeNode(n) && isLiteralTypeNode(n.argument) && isStringLiteral(n.argument.literal);
-  }
-  function isPrologueDirective(node) {
-    return node.kind === 243 /* ExpressionStatement */ && node.expression.kind === 11 /* StringLiteral */;
-  }
-  function isCustomPrologue(node) {
-    return !!(getEmitFlags(node) & 2097152 /* CustomPrologue */);
-  }
-  function isHoistedFunction(node) {
-    return isCustomPrologue(node) && isFunctionDeclaration(node);
-  }
-  function isHoistedVariable(node) {
-    return isIdentifier(node.name) && !node.initializer;
-  }
-  function isHoistedVariableStatement(node) {
-    return isCustomPrologue(node) && isVariableStatement(node) && every(node.declarationList.declarations, isHoistedVariable);
-  }
-  function getLeadingCommentRangesOfNode(node, sourceFileOfNode) {
-    return node.kind !== 12 /* JsxText */ ? getLeadingCommentRanges(sourceFileOfNode.text, node.pos) : void 0;
-  }
-  function getJSDocCommentRanges(node, text) {
-    const commentRanges = node.kind === 168 /* Parameter */ || node.kind === 167 /* TypeParameter */ || node.kind === 217 /* FunctionExpression */ || node.kind === 218 /* ArrowFunction */ || node.kind === 216 /* ParenthesizedExpression */ || node.kind === 259 /* VariableDeclaration */ || node.kind === 280 /* ExportSpecifier */ ? concatenate(getTrailingCommentRanges(text, node.pos), getLeadingCommentRanges(text, node.pos)) : getLeadingCommentRanges(text, node.pos);
-    return filter(commentRanges, (comment) => text.charCodeAt(comment.pos + 1) === 42 /* asterisk */ && text.charCodeAt(comment.pos + 2) === 42 /* asterisk */ && text.charCodeAt(comment.pos + 3) !== 47 /* slash */);
-  }
-  function isPartOfTypeNode(node) {
-    if (181 /* FirstTypeNode */ <= node.kind && node.kind <= 204 /* LastTypeNode */) {
-      return true;
-    }
-    switch (node.kind) {
-      case 133 /* AnyKeyword */:
-      case 159 /* UnknownKeyword */:
-      case 150 /* NumberKeyword */:
-      case 162 /* BigIntKeyword */:
-      case 154 /* StringKeyword */:
-      case 136 /* BooleanKeyword */:
-      case 155 /* SymbolKeyword */:
-      case 151 /* ObjectKeyword */:
-      case 157 /* UndefinedKeyword */:
-      case 106 /* NullKeyword */:
-      case 146 /* NeverKeyword */:
-        return true;
-      case 116 /* VoidKeyword */:
-        return node.parent.kind !== 221 /* VoidExpression */;
-      case 232 /* ExpressionWithTypeArguments */:
-        return isHeritageClause(node.parent) && !isExpressionWithTypeArgumentsInClassExtendsClause(node);
-      case 167 /* TypeParameter */:
-        return node.parent.kind === 199 /* MappedType */ || node.parent.kind === 194 /* InferType */;
-      case 80 /* Identifier */:
-        if (node.parent.kind === 165 /* QualifiedName */ && node.parent.right === node) {
-          node = node.parent;
-        } else if (node.parent.kind === 210 /* PropertyAccessExpression */ && node.parent.name === node) {
-          node = node.parent;
-        }
-        Debug.assert(
-          node.kind === 80 /* Identifier */ || node.kind === 165 /* QualifiedName */ || node.kind === 210 /* PropertyAccessExpression */,
-          "'node' was expected to be a qualified name, identifier or property access in 'isPartOfTypeNode'."
-        );
-      case 165 /* QualifiedName */:
-      case 210 /* PropertyAccessExpression */:
-      case 110 /* ThisKeyword */: {
-        const { parent: parent2 } = node;
-        if (parent2.kind === 185 /* TypeQuery */) {
-          return false;
-        }
-        if (parent2.kind === 204 /* ImportType */) {
-          return !parent2.isTypeOf;
-        }
-        if (181 /* FirstTypeNode */ <= parent2.kind && parent2.kind <= 204 /* LastTypeNode */) {
-          return true;
-        }
-        switch (parent2.kind) {
-          case 232 /* ExpressionWithTypeArguments */:
-            return isHeritageClause(parent2.parent) && !isExpressionWithTypeArgumentsInClassExtendsClause(parent2);
-          case 167 /* TypeParameter */:
-            return node === parent2.constraint;
-          case 351 /* JSDocTemplateTag */:
-            return node === parent2.constraint;
-          case 171 /* PropertyDeclaration */:
-          case 170 /* PropertySignature */:
-          case 168 /* Parameter */:
-          case 259 /* VariableDeclaration */:
-            return node === parent2.type;
-          case 261 /* FunctionDeclaration */:
-          case 217 /* FunctionExpression */:
-          case 218 /* ArrowFunction */:
-          case 175 /* Constructor */:
-          case 173 /* MethodDeclaration */:
-          case 172 /* MethodSignature */:
-          case 176 /* GetAccessor */:
-          case 177 /* SetAccessor */:
-            return node === parent2.type;
-          case 178 /* CallSignature */:
-          case 179 /* ConstructSignature */:
-          case 180 /* IndexSignature */:
-            return node === parent2.type;
-          case 215 /* TypeAssertionExpression */:
-            return node === parent2.type;
-          case 212 /* CallExpression */:
-          case 213 /* NewExpression */:
-          case 214 /* TaggedTemplateExpression */:
-            return contains(parent2.typeArguments, node);
-        }
-      }
-    }
-    return false;
-  }
-  function isChildOfNodeWithKind(node, kind) {
-    while (node) {
-      if (node.kind === kind) {
-        return true;
-      }
-      node = node.parent;
-    }
-    return false;
-  }
-  function forEachReturnStatement(body, visitor) {
-    return traverse(body);
-    function traverse(node) {
-      switch (node.kind) {
-        case 252 /* ReturnStatement */:
-          return visitor(node);
-        case 268 /* CaseBlock */:
-        case 240 /* Block */:
-        case 244 /* IfStatement */:
-        case 245 /* DoStatement */:
-        case 246 /* WhileStatement */:
-        case 247 /* ForStatement */:
-        case 248 /* ForInStatement */:
-        case 249 /* ForOfStatement */:
-        case 253 /* WithStatement */:
-        case 254 /* SwitchStatement */:
-        case 295 /* CaseClause */:
-        case 296 /* DefaultClause */:
-        case 255 /* LabeledStatement */:
-        case 257 /* TryStatement */:
-        case 298 /* CatchClause */:
-          return forEachChild(node, traverse);
-      }
-    }
-  }
-  function forEachYieldExpression(body, visitor) {
-    return traverse(body);
-    function traverse(node) {
-      switch (node.kind) {
-        case 228 /* YieldExpression */:
-          visitor(node);
-          const operand = node.expression;
-          if (operand) {
-            traverse(operand);
-          }
-          return;
-        case 265 /* EnumDeclaration */:
-        case 263 /* InterfaceDeclaration */:
-        case 266 /* ModuleDeclaration */:
-        case 264 /* TypeAliasDeclaration */:
-          return;
-        default:
-          if (isFunctionLike(node)) {
-            if (node.name && node.name.kind === 166 /* ComputedPropertyName */) {
-              traverse(node.name.expression);
-              return;
-            }
-          } else if (!isPartOfTypeNode(node)) {
-            forEachChild(node, traverse);
-          }
-      }
-    }
-  }
-  function getRestParameterElementType(node) {
-    if (node && node.kind === 187 /* ArrayType */) {
-      return node.elementType;
-    } else if (node && node.kind === 182 /* TypeReference */) {
-      return singleOrUndefined(node.typeArguments);
-    } else {
-      return void 0;
-    }
-  }
-  function getMembersOfDeclaration(node) {
-    switch (node.kind) {
-      case 263 /* InterfaceDeclaration */:
-      case 262 /* ClassDeclaration */:
-      case 230 /* ClassExpression */:
-      case 186 /* TypeLiteral */:
-        return node.members;
-      case 209 /* ObjectLiteralExpression */:
-        return node.properties;
-    }
-  }
-  function isVariableLike(node) {
-    if (node) {
-      switch (node.kind) {
-        case 207 /* BindingElement */:
-        case 305 /* EnumMember */:
-        case 168 /* Parameter */:
-        case 302 /* PropertyAssignment */:
-        case 171 /* PropertyDeclaration */:
-        case 170 /* PropertySignature */:
-        case 303 /* ShorthandPropertyAssignment */:
-        case 259 /* VariableDeclaration */:
-          return true;
-      }
-    }
-    return false;
-  }
-  function isVariableLikeOrAccessor(node) {
-    return isVariableLike(node) || isAccessor(node);
-  }
-  function isVariableDeclarationInVariableStatement(node) {
-    return node.parent.kind === 260 /* VariableDeclarationList */ && node.parent.parent.kind === 242 /* VariableStatement */;
-  }
-  function isCommonJsExportedExpression(node) {
-    if (!isInJSFile(node))
-      return false;
-    return isObjectLiteralExpression(node.parent) && isBinaryExpression(node.parent.parent) && getAssignmentDeclarationKind(node.parent.parent) === 2 /* ModuleExports */ || isCommonJsExportPropertyAssignment(node.parent);
-  }
-  function isCommonJsExportPropertyAssignment(node) {
-    if (!isInJSFile(node))
-      return false;
-    return isBinaryExpression(node) && getAssignmentDeclarationKind(node) === 1 /* ExportsProperty */;
-  }
-  function isValidESSymbolDeclaration(node) {
-    return (isVariableDeclaration(node) ? isVarConst(node) && isIdentifier(node.name) && isVariableDeclarationInVariableStatement(node) : isPropertyDeclaration(node) ? hasEffectiveReadonlyModifier(node) && hasStaticModifier(node) : isPropertySignature(node) && hasEffectiveReadonlyModifier(node)) || isCommonJsExportPropertyAssignment(node);
-  }
-  function introducesArgumentsExoticObject(node) {
-    switch (node.kind) {
-      case 173 /* MethodDeclaration */:
-      case 172 /* MethodSignature */:
-      case 175 /* Constructor */:
-      case 176 /* GetAccessor */:
-      case 177 /* SetAccessor */:
-      case 261 /* FunctionDeclaration */:
-      case 217 /* FunctionExpression */:
-        return true;
-    }
-    return false;
-  }
-  function unwrapInnermostStatementOfLabel(node, beforeUnwrapLabelCallback) {
-    while (true) {
-      if (beforeUnwrapLabelCallback) {
-        beforeUnwrapLabelCallback(node);
-      }
-      if (node.statement.kind !== 255 /* LabeledStatement */) {
-        return node.statement;
-      }
-      node = node.statement;
-    }
-  }
-  function isFunctionBlock(node) {
-    return node && node.kind === 240 /* Block */ && isFunctionLike(node.parent);
-  }
-  function isObjectLiteralMethod(node) {
-    return node && node.kind === 173 /* MethodDeclaration */ && node.parent.kind === 209 /* ObjectLiteralExpression */;
-  }
-  function isObjectLiteralOrClassExpressionMethodOrAccessor(node) {
-    return (node.kind === 173 /* MethodDeclaration */ || node.kind === 176 /* GetAccessor */ || node.kind === 177 /* SetAccessor */) && (node.parent.kind === 209 /* ObjectLiteralExpression */ || node.parent.kind === 230 /* ClassExpression */);
-  }
-  function isIdentifierTypePredicate(predicate) {
-    return predicate && predicate.kind === 1 /* Identifier */;
-  }
-  function isThisTypePredicate(predicate) {
-    return predicate && predicate.kind === 0 /* This */;
-  }
-  function forEachPropertyAssignment(objectLiteral, key, callback, key2) {
-    return forEach(objectLiteral == null ? void 0 : objectLiteral.properties, (property) => {
-      if (!isPropertyAssignment(property))
-        return void 0;
-      const propName = tryGetTextOfPropertyName(property.name);
-      return key === propName || key2 && key2 === propName ? callback(property) : void 0;
-    });
-  }
-  function getPropertyArrayElementValue(objectLiteral, propKey, elementValue) {
-    return forEachPropertyAssignment(
-      objectLiteral,
-      propKey,
-      (property) => isArrayLiteralExpression(property.initializer) ? find(property.initializer.elements, (element) => isStringLiteral(element) && element.text === elementValue) : void 0
-    );
-  }
-  function getTsConfigObjectLiteralExpression(tsConfigSourceFile) {
-    if (tsConfigSourceFile && tsConfigSourceFile.statements.length) {
-      const expression = tsConfigSourceFile.statements[0].expression;
-      return tryCast(expression, isObjectLiteralExpression);
-    }
-  }
-  function getTsConfigPropArrayElementValue(tsConfigSourceFile, propKey, elementValue) {
-    return forEachTsConfigPropArray(tsConfigSourceFile, propKey, (property) => isArrayLiteralExpression(property.initializer) ? find(property.initializer.elements, (element) => isStringLiteral(element) && element.text === elementValue) : void 0);
-  }
-  function forEachTsConfigPropArray(tsConfigSourceFile, propKey, callback) {
-    return forEachPropertyAssignment(getTsConfigObjectLiteralExpression(tsConfigSourceFile), propKey, callback);
-  }
-  function getContainingFunction(node) {
-    return findAncestor(node.parent, isFunctionLike);
-  }
-  function getContainingFunctionDeclaration(node) {
-    return findAncestor(node.parent, isFunctionLikeDeclaration);
-  }
-  function getContainingClass(node) {
-    return findAncestor(node.parent, isClassLike);
-  }
-  function getContainingClassStaticBlock(node) {
-    return findAncestor(node.parent, (n) => {
-      if (isClassLike(n) || isFunctionLike(n)) {
-        return "quit";
-      }
-      return isClassStaticBlockDeclaration(n);
-    });
-  }
-  function getContainingFunctionOrClassStaticBlock(node) {
-    return findAncestor(node.parent, isFunctionLikeOrClassStaticBlockDeclaration);
-  }
-  function getThisContainer(node, includeArrowFunctions, includeClassComputedPropertyName) {
-    Debug.assert(node.kind !== 311 /* SourceFile */);
-    while (true) {
-      node = node.parent;
-      if (!node) {
-        return Debug.fail();
-      }
-      switch (node.kind) {
-        case 166 /* ComputedPropertyName */:
-          if (includeClassComputedPropertyName && isClassLike(node.parent.parent)) {
-            return node;
-          }
-          node = node.parent.parent;
-          break;
-        case 169 /* Decorator */:
-          if (node.parent.kind === 168 /* Parameter */ && isClassElement(node.parent.parent)) {
-            node = node.parent.parent;
-          } else if (isClassElement(node.parent)) {
-            node = node.parent;
-          }
-          break;
-        case 218 /* ArrowFunction */:
-          if (!includeArrowFunctions) {
-            continue;
-          }
-        case 261 /* FunctionDeclaration */:
-        case 217 /* FunctionExpression */:
-        case 266 /* ModuleDeclaration */:
-        case 174 /* ClassStaticBlockDeclaration */:
-        case 171 /* PropertyDeclaration */:
-        case 170 /* PropertySignature */:
-        case 173 /* MethodDeclaration */:
-        case 172 /* MethodSignature */:
-        case 175 /* Constructor */:
-        case 176 /* GetAccessor */:
-        case 177 /* SetAccessor */:
-        case 178 /* CallSignature */:
-        case 179 /* ConstructSignature */:
-        case 180 /* IndexSignature */:
-        case 265 /* EnumDeclaration */:
-        case 311 /* SourceFile */:
-          return node;
-      }
-    }
-  }
-  function isThisContainerOrFunctionBlock(node) {
-    switch (node.kind) {
-      case 218 /* ArrowFunction */:
-      case 261 /* FunctionDeclaration */:
-      case 217 /* FunctionExpression */:
-      case 171 /* PropertyDeclaration */:
-        return true;
-      case 240 /* Block */:
-        switch (node.parent.kind) {
-          case 175 /* Constructor */:
-          case 173 /* MethodDeclaration */:
-          case 176 /* GetAccessor */:
-          case 177 /* SetAccessor */:
-            return true;
-          default:
-            return false;
-        }
-      default:
-        return false;
-    }
-  }
-  function isInTopLevelContext(node) {
-    if (isIdentifier(node) && (isClassDeclaration(node.parent) || isFunctionDeclaration(node.parent)) && node.parent.name === node) {
-      node = node.parent;
-    }
-    const container = getThisContainer(
-      node,
-      /*includeArrowFunctions*/
-      true,
-      /*includeClassComputedPropertyName*/
-      false
-    );
-    return isSourceFile(container);
-  }
-  function getNewTargetContainer(node) {
-    const container = getThisContainer(
-      node,
-      /*includeArrowFunctions*/
-      false,
-      /*includeClassComputedPropertyName*/
-      false
-    );
-    if (container) {
-      switch (container.kind) {
-        case 175 /* Constructor */:
-        case 261 /* FunctionDeclaration */:
-        case 217 /* FunctionExpression */:
-          return container;
-      }
-    }
-    return void 0;
-  }
-  function getSuperContainer(node, stopOnFunctions) {
-    while (true) {
-      node = node.parent;
-      if (!node) {
-        return void 0;
-      }
-      switch (node.kind) {
-        case 166 /* ComputedPropertyName */:
-          node = node.parent;
-          break;
-        case 261 /* FunctionDeclaration */:
-        case 217 /* FunctionExpression */:
-        case 218 /* ArrowFunction */:
-          if (!stopOnFunctions) {
-            continue;
-          }
-        case 171 /* PropertyDeclaration */:
-        case 170 /* PropertySignature */:
-        case 173 /* MethodDeclaration */:
-        case 172 /* MethodSignature */:
-        case 175 /* Constructor */:
-        case 176 /* GetAccessor */:
-        case 177 /* SetAccessor */:
-        case 174 /* ClassStaticBlockDeclaration */:
-          return node;
-        case 169 /* Decorator */:
-          if (node.parent.kind === 168 /* Parameter */ && isClassElement(node.parent.parent)) {
-            node = node.parent.parent;
-          } else if (isClassElement(node.parent)) {
-            node = node.parent;
-          }
-          break;
-      }
-    }
-  }
-  function getImmediatelyInvokedFunctionExpression(func) {
-    if (func.kind === 217 /* FunctionExpression */ || func.kind === 218 /* ArrowFunction */) {
-      let prev = func;
-      let parent2 = func.parent;
-      while (parent2.kind === 216 /* ParenthesizedExpression */) {
-        prev = parent2;
-        parent2 = parent2.parent;
-      }
-      if (parent2.kind === 212 /* CallExpression */ && parent2.expression === prev) {
-        return parent2;
-      }
-    }
-  }
-  function isSuperOrSuperProperty(node) {
-    return node.kind === 108 /* SuperKeyword */ || isSuperProperty(node);
-  }
-  function isSuperProperty(node) {
-    const kind = node.kind;
-    return (kind === 210 /* PropertyAccessExpression */ || kind === 211 /* ElementAccessExpression */) && node.expression.kind === 108 /* SuperKeyword */;
-  }
-  function isThisProperty(node) {
-    const kind = node.kind;
-    return (kind === 210 /* PropertyAccessExpression */ || kind === 211 /* ElementAccessExpression */) && node.expression.kind === 110 /* ThisKeyword */;
-  }
-  function isThisInitializedDeclaration(node) {
-    var _a;
-    return !!node && isVariableDeclaration(node) && ((_a = node.initializer) == null ? void 0 : _a.kind) === 110 /* ThisKeyword */;
-  }
-  function isThisInitializedObjectBindingExpression(node) {
-    return !!node && (isShorthandPropertyAssignment(node) || isPropertyAssignment(node)) && isBinaryExpression(node.parent.parent) && node.parent.parent.operatorToken.kind === 64 /* EqualsToken */ && node.parent.parent.right.kind === 110 /* ThisKeyword */;
-  }
-  function getEntityNameFromTypeNode(node) {
-    switch (node.kind) {
-      case 182 /* TypeReference */:
-        return node.typeName;
-      case 232 /* ExpressionWithTypeArguments */:
-        return isEntityNameExpression(node.expression) ? node.expression : void 0;
-      case 80 /* Identifier */:
-      case 165 /* QualifiedName */:
-        return node;
-    }
-    return void 0;
-  }
-  function getInvokedExpression(node) {
-    switch (node.kind) {
-      case 214 /* TaggedTemplateExpression */:
-        return node.tag;
-      case 285 /* JsxOpeningElement */:
-      case 284 /* JsxSelfClosingElement */:
-        return node.tagName;
-      default:
-        return node.expression;
-    }
-  }
-  function nodeCanBeDecorated(useLegacyDecorators, node, parent2, grandparent) {
-    if (useLegacyDecorators && isNamedDeclaration(node) && isPrivateIdentifier(node.name)) {
-      return false;
-    }
-    switch (node.kind) {
-      case 262 /* ClassDeclaration */:
-        return true;
-      case 230 /* ClassExpression */:
-        return !useLegacyDecorators;
-      case 171 /* PropertyDeclaration */:
-        return parent2 !== void 0 && (useLegacyDecorators ? isClassDeclaration(parent2) : isClassLike(parent2) && !hasAbstractModifier(node) && !hasAmbientModifier(node));
-      case 176 /* GetAccessor */:
-      case 177 /* SetAccessor */:
-      case 173 /* MethodDeclaration */:
-        return node.body !== void 0 && parent2 !== void 0 && (useLegacyDecorators ? isClassDeclaration(parent2) : isClassLike(parent2));
-      case 168 /* Parameter */:
-        if (!useLegacyDecorators)
-          return false;
-        return parent2 !== void 0 && parent2.body !== void 0 && (parent2.kind === 175 /* Constructor */ || parent2.kind === 173 /* MethodDeclaration */ || parent2.kind === 177 /* SetAccessor */) && getThisParameter(parent2) !== node && grandparent !== void 0 && grandparent.kind === 262 /* ClassDeclaration */;
-    }
-    return false;
-  }
-  function nodeIsDecorated(useLegacyDecorators, node, parent2, grandparent) {
-    return hasDecorators(node) && nodeCanBeDecorated(useLegacyDecorators, node, parent2, grandparent);
-  }
-  function nodeOrChildIsDecorated(useLegacyDecorators, node, parent2, grandparent) {
-    return nodeIsDecorated(useLegacyDecorators, node, parent2, grandparent) || childIsDecorated(useLegacyDecorators, node, parent2);
-  }
-  function childIsDecorated(useLegacyDecorators, node, parent2) {
-    switch (node.kind) {
-      case 262 /* ClassDeclaration */:
-        return some(node.members, (m) => nodeOrChildIsDecorated(useLegacyDecorators, m, node, parent2));
-      case 230 /* ClassExpression */:
-        return !useLegacyDecorators && some(node.members, (m) => nodeOrChildIsDecorated(useLegacyDecorators, m, node, parent2));
-      case 173 /* MethodDeclaration */:
-      case 177 /* SetAccessor */:
-      case 175 /* Constructor */:
-        return some(node.parameters, (p) => nodeIsDecorated(useLegacyDecorators, p, node, parent2));
-      default:
-        return false;
-    }
-  }
-  function classOrConstructorParameterIsDecorated(useLegacyDecorators, node) {
-    if (nodeIsDecorated(useLegacyDecorators, node))
-      return true;
-    const constructor = getFirstConstructorWithBody(node);
-    return !!constructor && childIsDecorated(useLegacyDecorators, constructor, node);
-  }
-  function classElementOrClassElementParameterIsDecorated(useLegacyDecorators, node, parent2) {
-    let parameters;
-    if (isAccessor(node)) {
-      const { firstAccessor, secondAccessor, setAccessor } = getAllAccessorDeclarations(parent2.members, node);
-      const firstAccessorWithDecorators = hasDecorators(firstAccessor) ? firstAccessor : secondAccessor && hasDecorators(secondAccessor) ? secondAccessor : void 0;
-      if (!firstAccessorWithDecorators || node !== firstAccessorWithDecorators) {
-        return false;
-      }
-      parameters = setAccessor == null ? void 0 : setAccessor.parameters;
-    } else if (isMethodDeclaration(node)) {
-      parameters = node.parameters;
-    }
-    if (nodeIsDecorated(useLegacyDecorators, node, parent2)) {
-      return true;
-    }
-    if (parameters) {
-      for (const parameter of parameters) {
-        if (parameterIsThisKeyword(parameter))
-          continue;
-        if (nodeIsDecorated(useLegacyDecorators, parameter, node, parent2))
-          return true;
-      }
-    }
-    return false;
-  }
-  function isEmptyStringLiteral(node) {
-    if (node.textSourceNode) {
-      switch (node.textSourceNode.kind) {
-        case 11 /* StringLiteral */:
-          return isEmptyStringLiteral(node.textSourceNode);
-        case 15 /* NoSubstitutionTemplateLiteral */:
-          return node.text === "";
-      }
-      return false;
-    }
-    return node.text === "";
-  }
-  function isJSXTagName(node) {
-    const { parent: parent2 } = node;
-    if (parent2.kind === 285 /* JsxOpeningElement */ || parent2.kind === 284 /* JsxSelfClosingElement */ || parent2.kind === 286 /* JsxClosingElement */) {
-      return parent2.tagName === node;
-    }
-    return false;
-  }
-  function isExpressionNode(node) {
-    switch (node.kind) {
-      case 108 /* SuperKeyword */:
-      case 106 /* NullKeyword */:
-      case 112 /* TrueKeyword */:
-      case 97 /* FalseKeyword */:
-      case 14 /* RegularExpressionLiteral */:
-      case 208 /* ArrayLiteralExpression */:
-      case 209 /* ObjectLiteralExpression */:
-      case 210 /* PropertyAccessExpression */:
-      case 211 /* ElementAccessExpression */:
-      case 212 /* CallExpression */:
-      case 213 /* NewExpression */:
-      case 214 /* TaggedTemplateExpression */:
-      case 233 /* AsExpression */:
-      case 215 /* TypeAssertionExpression */:
-      case 237 /* SatisfiesExpression */:
-      case 234 /* NonNullExpression */:
-      case 216 /* ParenthesizedExpression */:
-      case 217 /* FunctionExpression */:
-      case 230 /* ClassExpression */:
-      case 218 /* ArrowFunction */:
-      case 221 /* VoidExpression */:
-      case 219 /* DeleteExpression */:
-      case 220 /* TypeOfExpression */:
-      case 223 /* PrefixUnaryExpression */:
-      case 224 /* PostfixUnaryExpression */:
-      case 225 /* BinaryExpression */:
-      case 226 /* ConditionalExpression */:
-      case 229 /* SpreadElement */:
-      case 227 /* TemplateExpression */:
-      case 231 /* OmittedExpression */:
-      case 283 /* JsxElement */:
-      case 284 /* JsxSelfClosingElement */:
-      case 287 /* JsxFragment */:
-      case 228 /* YieldExpression */:
-      case 222 /* AwaitExpression */:
-      case 235 /* MetaProperty */:
-        return true;
-      case 232 /* ExpressionWithTypeArguments */:
-        return !isHeritageClause(node.parent) && !isJSDocAugmentsTag(node.parent);
-      case 165 /* QualifiedName */:
-        while (node.parent.kind === 165 /* QualifiedName */) {
-          node = node.parent;
-        }
-        return node.parent.kind === 185 /* TypeQuery */ || isJSDocLinkLike(node.parent) || isJSDocNameReference(node.parent) || isJSDocMemberName(node.parent) || isJSXTagName(node);
-      case 317 /* JSDocMemberName */:
-        while (isJSDocMemberName(node.parent)) {
-          node = node.parent;
-        }
-        return node.parent.kind === 185 /* TypeQuery */ || isJSDocLinkLike(node.parent) || isJSDocNameReference(node.parent) || isJSDocMemberName(node.parent) || isJSXTagName(node);
-      case 81 /* PrivateIdentifier */:
-        return isBinaryExpression(node.parent) && node.parent.left === node && node.parent.operatorToken.kind === 103 /* InKeyword */;
-      case 80 /* Identifier */:
-        if (node.parent.kind === 185 /* TypeQuery */ || isJSDocLinkLike(node.parent) || isJSDocNameReference(node.parent) || isJSDocMemberName(node.parent) || isJSXTagName(node)) {
-          return true;
-        }
-      case 9 /* NumericLiteral */:
-      case 10 /* BigIntLiteral */:
-      case 11 /* StringLiteral */:
-      case 15 /* NoSubstitutionTemplateLiteral */:
-      case 110 /* ThisKeyword */:
-        return isInExpressionContext(node);
-      default:
-        return false;
-    }
-  }
-  function isInExpressionContext(node) {
-    const { parent: parent2 } = node;
-    switch (parent2.kind) {
-      case 259 /* VariableDeclaration */:
-      case 168 /* Parameter */:
-      case 171 /* PropertyDeclaration */:
-      case 170 /* PropertySignature */:
-      case 305 /* EnumMember */:
-      case 302 /* PropertyAssignment */:
-      case 207 /* BindingElement */:
-        return parent2.initializer === node;
-      case 243 /* ExpressionStatement */:
-      case 244 /* IfStatement */:
-      case 245 /* DoStatement */:
-      case 246 /* WhileStatement */:
-      case 252 /* ReturnStatement */:
-      case 253 /* WithStatement */:
-      case 254 /* SwitchStatement */:
-      case 295 /* CaseClause */:
-      case 256 /* ThrowStatement */:
-        return parent2.expression === node;
-      case 247 /* ForStatement */:
-        const forStatement = parent2;
-        return forStatement.initializer === node && forStatement.initializer.kind !== 260 /* VariableDeclarationList */ || forStatement.condition === node || forStatement.incrementor === node;
-      case 248 /* ForInStatement */:
-      case 249 /* ForOfStatement */:
-        const forInStatement = parent2;
-        return forInStatement.initializer === node && forInStatement.initializer.kind !== 260 /* VariableDeclarationList */ || forInStatement.expression === node;
-      case 215 /* TypeAssertionExpression */:
-      case 233 /* AsExpression */:
-        return node === parent2.expression;
-      case 238 /* TemplateSpan */:
-        return node === parent2.expression;
-      case 166 /* ComputedPropertyName */:
-        return node === parent2.expression;
-      case 169 /* Decorator */:
-      case 293 /* JsxExpression */:
-      case 292 /* JsxSpreadAttribute */:
-      case 304 /* SpreadAssignment */:
-        return true;
-      case 232 /* ExpressionWithTypeArguments */:
-        return parent2.expression === node && !isPartOfTypeNode(parent2);
-      case 303 /* ShorthandPropertyAssignment */:
-        return parent2.objectAssignmentInitializer === node;
-      case 237 /* SatisfiesExpression */:
-        return node === parent2.expression;
-      default:
-        return isExpressionNode(parent2);
-    }
-  }
-  function isPartOfTypeQuery(node) {
-    while (node.kind === 165 /* QualifiedName */ || node.kind === 80 /* Identifier */) {
-      node = node.parent;
-    }
-    return node.kind === 185 /* TypeQuery */;
-  }
-  function isNamespaceReexportDeclaration(node) {
-    return isNamespaceExport(node) && !!node.parent.moduleSpecifier;
-  }
-  function isExternalModuleImportEqualsDeclaration(node) {
-    return node.kind === 270 /* ImportEqualsDeclaration */ && node.moduleReference.kind === 282 /* ExternalModuleReference */;
-  }
-  function getExternalModuleImportEqualsDeclarationExpression(node) {
-    Debug.assert(isExternalModuleImportEqualsDeclaration(node));
-    return node.moduleReference.expression;
-  }
-  function getExternalModuleRequireArgument(node) {
-    return isVariableDeclarationInitializedToBareOrAccessedRequire(node) && getLeftmostAccessExpression(node.initializer).arguments[0];
-  }
-  function isInternalModuleImportEqualsDeclaration(node) {
-    return node.kind === 270 /* ImportEqualsDeclaration */ && node.moduleReference.kind !== 282 /* ExternalModuleReference */;
-  }
-  function isSourceFileJS(file) {
-    return isInJSFile(file);
-  }
-  function isSourceFileNotJS(file) {
-    return !isInJSFile(file);
-  }
-  function isInJSFile(node) {
-    return !!node && !!(node.flags & 262144 /* JavaScriptFile */);
-  }
-  function isInJsonFile(node) {
-    return !!node && !!(node.flags & 67108864 /* JsonFile */);
-  }
-  function isSourceFileNotJson(file) {
-    return !isJsonSourceFile(file);
-  }
-  function isInJSDoc(node) {
-    return !!node && !!(node.flags & 8388608 /* JSDoc */);
-  }
-  function isJSDocIndexSignature(node) {
-    return isTypeReferenceNode(node) && isIdentifier(node.typeName) && node.typeName.escapedText === "Object" && node.typeArguments && node.typeArguments.length === 2 && (node.typeArguments[0].kind === 154 /* StringKeyword */ || node.typeArguments[0].kind === 150 /* NumberKeyword */);
-  }
-  function isRequireCall(callExpression, requireStringLiteralLikeArgument) {
-    if (callExpression.kind !== 212 /* CallExpression */) {
-      return false;
-    }
-    const { expression, arguments: args } = callExpression;
-    if (expression.kind !== 80 /* Identifier */ || expression.escapedText !== "require") {
-      return false;
-    }
-    if (args.length !== 1) {
-      return false;
-    }
-    const arg = args[0];
-    return !requireStringLiteralLikeArgument || isStringLiteralLike(arg);
-  }
-  function isVariableDeclarationInitializedToRequire(node) {
-    return isVariableDeclarationInitializedWithRequireHelper(
-      node,
-      /*allowAccessedRequire*/
-      false
-    );
-  }
-  function isVariableDeclarationInitializedToBareOrAccessedRequire(node) {
-    return isVariableDeclarationInitializedWithRequireHelper(
-      node,
-      /*allowAccessedRequire*/
-      true
-    );
-  }
-  function isBindingElementOfBareOrAccessedRequire(node) {
-    return isBindingElement(node) && isVariableDeclarationInitializedToBareOrAccessedRequire(node.parent.parent);
-  }
-  function isVariableDeclarationInitializedWithRequireHelper(node, allowAccessedRequire) {
-    return isVariableDeclaration(node) && !!node.initializer && isRequireCall(
-      allowAccessedRequire ? getLeftmostAccessExpression(node.initializer) : node.initializer,
-      /*requireStringLiteralLikeArgument*/
-      true
-    );
-  }
-  function isRequireVariableStatement(node) {
-    return isVariableStatement(node) && node.declarationList.declarations.length > 0 && every(node.declarationList.declarations, (decl) => isVariableDeclarationInitializedToRequire(decl));
-  }
-  function isSingleOrDoubleQuote(charCode) {
-    return charCode === 39 /* singleQuote */ || charCode === 34 /* doubleQuote */;
-  }
-  function isStringDoubleQuoted(str, sourceFile) {
-    return getSourceTextOfNodeFromSourceFile(sourceFile, str).charCodeAt(0) === 34 /* doubleQuote */;
-  }
-  function isAssignmentDeclaration(decl) {
-    return isBinaryExpression(decl) || isAccessExpression(decl) || isIdentifier(decl) || isCallExpression(decl);
-  }
-  function getEffectiveInitializer(node) {
-    if (isInJSFile(node) && node.initializer && isBinaryExpression(node.initializer) && (node.initializer.operatorToken.kind === 57 /* BarBarToken */ || node.initializer.operatorToken.kind === 61 /* QuestionQuestionToken */) && node.name && isEntityNameExpression(node.name) && isSameEntityName(node.name, node.initializer.left)) {
-      return node.initializer.right;
-    }
-    return node.initializer;
-  }
-  function getDeclaredExpandoInitializer(node) {
-    const init = getEffectiveInitializer(node);
-    return init && getExpandoInitializer(init, isPrototypeAccess(node.name));
-  }
-  function hasExpandoValueProperty(node, isPrototypeAssignment) {
-    return forEach(node.properties, (p) => isPropertyAssignment(p) && isIdentifier(p.name) && p.name.escapedText === "value" && p.initializer && getExpandoInitializer(p.initializer, isPrototypeAssignment));
-  }
-  function getAssignedExpandoInitializer(node) {
-    if (node && node.parent && isBinaryExpression(node.parent) && node.parent.operatorToken.kind === 64 /* EqualsToken */) {
-      const isPrototypeAssignment = isPrototypeAccess(node.parent.left);
-      return getExpandoInitializer(node.parent.right, isPrototypeAssignment) || getDefaultedExpandoInitializer(node.parent.left, node.parent.right, isPrototypeAssignment);
-    }
-    if (node && isCallExpression(node) && isBindableObjectDefinePropertyCall(node)) {
-      const result = hasExpandoValueProperty(node.arguments[2], node.arguments[1].text === "prototype");
-      if (result) {
-        return result;
-      }
-    }
-  }
-  function getExpandoInitializer(initializer, isPrototypeAssignment) {
-    if (isCallExpression(initializer)) {
-      const e = skipParentheses(initializer.expression);
-      return e.kind === 217 /* FunctionExpression */ || e.kind === 218 /* ArrowFunction */ ? initializer : void 0;
-    }
-    if (initializer.kind === 217 /* FunctionExpression */ || initializer.kind === 230 /* ClassExpression */ || initializer.kind === 218 /* ArrowFunction */) {
-      return initializer;
-    }
-    if (isObjectLiteralExpression(initializer) && (initializer.properties.length === 0 || isPrototypeAssignment)) {
-      return initializer;
-    }
-  }
-  function getDefaultedExpandoInitializer(name, initializer, isPrototypeAssignment) {
-    const e = isBinaryExpression(initializer) && (initializer.operatorToken.kind === 57 /* BarBarToken */ || initializer.operatorToken.kind === 61 /* QuestionQuestionToken */) && getExpandoInitializer(initializer.right, isPrototypeAssignment);
-    if (e && isSameEntityName(name, initializer.left)) {
-      return e;
-    }
-  }
-  function isDefaultedExpandoInitializer(node) {
-    const name = isVariableDeclaration(node.parent) ? node.parent.name : isBinaryExpression(node.parent) && node.parent.operatorToken.kind === 64 /* EqualsToken */ ? node.parent.left : void 0;
-    return name && getExpandoInitializer(node.right, isPrototypeAccess(name)) && isEntityNameExpression(name) && isSameEntityName(name, node.left);
-  }
-  function getNameOfExpando(node) {
-    if (isBinaryExpression(node.parent)) {
-      const parent2 = (node.parent.operatorToken.kind === 57 /* BarBarToken */ || node.parent.operatorToken.kind === 61 /* QuestionQuestionToken */) && isBinaryExpression(node.parent.parent) ? node.parent.parent : node.parent;
-      if (parent2.operatorToken.kind === 64 /* EqualsToken */ && isIdentifier(parent2.left)) {
-        return parent2.left;
-      }
-    } else if (isVariableDeclaration(node.parent)) {
-      return node.parent.name;
-    }
-  }
-  function isSameEntityName(name, initializer) {
-    if (isPropertyNameLiteral(name) && isPropertyNameLiteral(initializer)) {
-      return getTextOfIdentifierOrLiteral(name) === getTextOfIdentifierOrLiteral(initializer);
-    }
-    if (isMemberName(name) && isLiteralLikeAccess(initializer) && (initializer.expression.kind === 110 /* ThisKeyword */ || isIdentifier(initializer.expression) && (initializer.expression.escapedText === "window" || initializer.expression.escapedText === "self" || initializer.expression.escapedText === "global"))) {
-      return isSameEntityName(name, getNameOrArgument(initializer));
-    }
-    if (isLiteralLikeAccess(name) && isLiteralLikeAccess(initializer)) {
-      return getElementOrPropertyAccessName(name) === getElementOrPropertyAccessName(initializer) && isSameEntityName(name.expression, initializer.expression);
-    }
-    return false;
-  }
-  function getRightMostAssignedExpression(node) {
-    while (isAssignmentExpression(
-      node,
-      /*excludeCompoundAssignment*/
-      true
-    )) {
-      node = node.right;
-    }
-    return node;
-  }
-  function isExportsIdentifier(node) {
-    return isIdentifier(node) && node.escapedText === "exports";
-  }
-  function isModuleIdentifier(node) {
-    return isIdentifier(node) && node.escapedText === "module";
-  }
-  function isModuleExportsAccessExpression(node) {
-    return (isPropertyAccessExpression(node) || isLiteralLikeElementAccess(node)) && isModuleIdentifier(node.expression) && getElementOrPropertyAccessName(node) === "exports";
-  }
-  function getAssignmentDeclarationKind(expr) {
-    const special = getAssignmentDeclarationKindWorker(expr);
-    return special === 5 /* Property */ || isInJSFile(expr) ? special : 0 /* None */;
-  }
-  function isBindableObjectDefinePropertyCall(expr) {
-    return length(expr.arguments) === 3 && isPropertyAccessExpression(expr.expression) && isIdentifier(expr.expression.expression) && idText(expr.expression.expression) === "Object" && idText(expr.expression.name) === "defineProperty" && isStringOrNumericLiteralLike(expr.arguments[1]) && isBindableStaticNameExpression(
-      expr.arguments[0],
-      /*excludeThisKeyword*/
-      true
-    );
-  }
-  function isLiteralLikeAccess(node) {
-    return isPropertyAccessExpression(node) || isLiteralLikeElementAccess(node);
-  }
-  function isLiteralLikeElementAccess(node) {
-    return isElementAccessExpression(node) && isStringOrNumericLiteralLike(node.argumentExpression);
-  }
-  function isBindableStaticAccessExpression(node, excludeThisKeyword) {
-    return isPropertyAccessExpression(node) && (!excludeThisKeyword && node.expression.kind === 110 /* ThisKeyword */ || isIdentifier(node.name) && isBindableStaticNameExpression(
-      node.expression,
-      /*excludeThisKeyword*/
-      true
-    )) || isBindableStaticElementAccessExpression(node, excludeThisKeyword);
-  }
-  function isBindableStaticElementAccessExpression(node, excludeThisKeyword) {
-    return isLiteralLikeElementAccess(node) && (!excludeThisKeyword && node.expression.kind === 110 /* ThisKeyword */ || isEntityNameExpression(node.expression) || isBindableStaticAccessExpression(
-      node.expression,
-      /*excludeThisKeyword*/
-      true
-    ));
-  }
-  function isBindableStaticNameExpression(node, excludeThisKeyword) {
-    return isEntityNameExpression(node) || isBindableStaticAccessExpression(node, excludeThisKeyword);
-  }
-  function getNameOrArgument(expr) {
-    if (isPropertyAccessExpression(expr)) {
-      return expr.name;
-    }
-    return expr.argumentExpression;
-  }
-  function getAssignmentDeclarationKindWorker(expr) {
-    if (isCallExpression(expr)) {
-      if (!isBindableObjectDefinePropertyCall(expr)) {
-        return 0 /* None */;
-      }
-      const entityName = expr.arguments[0];
-      if (isExportsIdentifier(entityName) || isModuleExportsAccessExpression(entityName)) {
-        return 8 /* ObjectDefinePropertyExports */;
-      }
-      if (isBindableStaticAccessExpression(entityName) && getElementOrPropertyAccessName(entityName) === "prototype") {
-        return 9 /* ObjectDefinePrototypeProperty */;
-      }
-      return 7 /* ObjectDefinePropertyValue */;
-    }
-    if (expr.operatorToken.kind !== 64 /* EqualsToken */ || !isAccessExpression(expr.left) || isVoidZero(getRightMostAssignedExpression(expr))) {
-      return 0 /* None */;
-    }
-    if (isBindableStaticNameExpression(
-      expr.left.expression,
-      /*excludeThisKeyword*/
-      true
-    ) && getElementOrPropertyAccessName(expr.left) === "prototype" && isObjectLiteralExpression(getInitializerOfBinaryExpression(expr))) {
-      return 6 /* Prototype */;
-    }
-    return getAssignmentDeclarationPropertyAccessKind(expr.left);
-  }
-  function isVoidZero(node) {
-    return isVoidExpression(node) && isNumericLiteral(node.expression) && node.expression.text === "0";
-  }
-  function getElementOrPropertyAccessArgumentExpressionOrName(node) {
-    if (isPropertyAccessExpression(node)) {
-      return node.name;
-    }
-    const arg = skipParentheses(node.argumentExpression);
-    if (isNumericLiteral(arg) || isStringLiteralLike(arg)) {
-      return arg;
-    }
-    return node;
-  }
-  function getElementOrPropertyAccessName(node) {
-    const name = getElementOrPropertyAccessArgumentExpressionOrName(node);
-    if (name) {
-      if (isIdentifier(name)) {
-        return name.escapedText;
-      }
-      if (isStringLiteralLike(name) || isNumericLiteral(name)) {
-        return escapeLeadingUnderscores(name.text);
-      }
-    }
-    return void 0;
-  }
-  function getAssignmentDeclarationPropertyAccessKind(lhs) {
-    if (lhs.expression.kind === 110 /* ThisKeyword */) {
-      return 4 /* ThisProperty */;
-    } else if (isModuleExportsAccessExpression(lhs)) {
-      return 2 /* ModuleExports */;
-    } else if (isBindableStaticNameExpression(
-      lhs.expression,
-      /*excludeThisKeyword*/
-      true
-    )) {
-      if (isPrototypeAccess(lhs.expression)) {
-        return 3 /* PrototypeProperty */;
-      }
-      let nextToLast = lhs;
-      while (!isIdentifier(nextToLast.expression)) {
-        nextToLast = nextToLast.expression;
-      }
-      const id = nextToLast.expression;
-      if ((id.escapedText === "exports" || id.escapedText === "module" && getElementOrPropertyAccessName(nextToLast) === "exports") && // ExportsProperty does not support binding with computed names
-      isBindableStaticAccessExpression(lhs)) {
-        return 1 /* ExportsProperty */;
-      }
-      if (isBindableStaticNameExpression(
-        lhs,
-        /*excludeThisKeyword*/
-        true
-      ) || isElementAccessExpression(lhs) && isDynamicName(lhs)) {
-        return 5 /* Property */;
-      }
-    }
-    return 0 /* None */;
-  }
-  function getInitializerOfBinaryExpression(expr) {
-    while (isBinaryExpression(expr.right)) {
-      expr = expr.right;
-    }
-    return expr.right;
-  }
-  function isPrototypePropertyAssignment(node) {
-    return isBinaryExpression(node) && getAssignmentDeclarationKind(node) === 3 /* PrototypeProperty */;
-  }
-  function isSpecialPropertyDeclaration(expr) {
-    return isInJSFile(expr) && expr.parent && expr.parent.kind === 243 /* ExpressionStatement */ && (!isElementAccessExpression(expr) || isLiteralLikeElementAccess(expr)) && !!getJSDocTypeTag(expr.parent);
-  }
-  function setValueDeclaration(symbol, node) {
-    const { valueDeclaration } = symbol;
-    if (!valueDeclaration || !(node.flags & 16777216 /* Ambient */ && !isInJSFile(node) && !(valueDeclaration.flags & 16777216 /* Ambient */)) && (isAssignmentDeclaration(valueDeclaration) && !isAssignmentDeclaration(node)) || valueDeclaration.kind !== node.kind && isEffectiveModuleDeclaration(valueDeclaration)) {
-      symbol.valueDeclaration = node;
-    }
-  }
-  function isFunctionSymbol(symbol) {
-    if (!symbol || !symbol.valueDeclaration) {
-      return false;
-    }
-    const decl = symbol.valueDeclaration;
-    return decl.kind === 261 /* FunctionDeclaration */ || isVariableDeclaration(decl) && decl.initializer && isFunctionLike(decl.initializer);
-  }
-  function tryGetModuleSpecifierFromDeclaration(node) {
-    var _a, _b;
-    switch (node.kind) {
-      case 259 /* VariableDeclaration */:
-      case 207 /* BindingElement */:
-        return (_a = findAncestor(node.initializer, (node2) => isRequireCall(
-          node2,
-          /*requireStringLiteralLikeArgument*/
-          true
-        ))) == null ? void 0 : _a.arguments[0];
-      case 271 /* ImportDeclaration */:
-        return tryCast(node.moduleSpecifier, isStringLiteralLike);
-      case 270 /* ImportEqualsDeclaration */:
-        return tryCast((_b = tryCast(node.moduleReference, isExternalModuleReference)) == null ? void 0 : _b.expression, isStringLiteralLike);
-      case 272 /* ImportClause */:
-      case 279 /* NamespaceExport */:
-        return tryCast(node.parent.moduleSpecifier, isStringLiteralLike);
-      case 273 /* NamespaceImport */:
-      case 280 /* ExportSpecifier */:
-        return tryCast(node.parent.parent.moduleSpecifier, isStringLiteralLike);
-      case 275 /* ImportSpecifier */:
-        return tryCast(node.parent.parent.parent.moduleSpecifier, isStringLiteralLike);
-      default:
-        Debug.assertNever(node);
-    }
-  }
-  function importFromModuleSpecifier(node) {
-    return tryGetImportFromModuleSpecifier(node) || Debug.failBadSyntaxKind(node.parent);
-  }
-  function tryGetImportFromModuleSpecifier(node) {
-    switch (node.parent.kind) {
-      case 271 /* ImportDeclaration */:
-      case 277 /* ExportDeclaration */:
-        return node.parent;
-      case 282 /* ExternalModuleReference */:
-        return node.parent.parent;
-      case 212 /* CallExpression */:
-        return isImportCall(node.parent) || isRequireCall(
-          node.parent,
-          /*requireStringLiteralLikeArgument*/
-          false
-        ) ? node.parent : void 0;
-      case 200 /* LiteralType */:
-        Debug.assert(isStringLiteral(node));
-        return tryCast(node.parent.parent, isImportTypeNode);
-      default:
-        return void 0;
-    }
-  }
-  function getExternalModuleName(node) {
-    switch (node.kind) {
-      case 271 /* ImportDeclaration */:
-      case 277 /* ExportDeclaration */:
-        return node.moduleSpecifier;
-      case 270 /* ImportEqualsDeclaration */:
-        return node.moduleReference.kind === 282 /* ExternalModuleReference */ ? node.moduleReference.expression : void 0;
-      case 204 /* ImportType */:
-        return isLiteralImportTypeNode(node) ? node.argument.literal : void 0;
-      case 212 /* CallExpression */:
-        return node.arguments[0];
-      case 266 /* ModuleDeclaration */:
-        return node.name.kind === 11 /* StringLiteral */ ? node.name : void 0;
-      default:
-        return Debug.assertNever(node);
-    }
-  }
-  function getNamespaceDeclarationNode(node) {
-    switch (node.kind) {
-      case 271 /* ImportDeclaration */:
-        return node.importClause && tryCast(node.importClause.namedBindings, isNamespaceImport);
-      case 270 /* ImportEqualsDeclaration */:
-        return node;
-      case 277 /* ExportDeclaration */:
-        return node.exportClause && tryCast(node.exportClause, isNamespaceExport);
-      default:
-        return Debug.assertNever(node);
-    }
-  }
-  function isDefaultImport(node) {
-    return node.kind === 271 /* ImportDeclaration */ && !!node.importClause && !!node.importClause.name;
-  }
-  function forEachImportClauseDeclaration(node, action) {
-    if (node.name) {
-      const result = action(node);
-      if (result)
-        return result;
-    }
-    if (node.namedBindings) {
-      const result = isNamespaceImport(node.namedBindings) ? action(node.namedBindings) : forEach(node.namedBindings.elements, action);
-      if (result)
-        return result;
-    }
-  }
-  function hasQuestionToken(node) {
-    if (node) {
-      switch (node.kind) {
-        case 168 /* Parameter */:
-        case 173 /* MethodDeclaration */:
-        case 172 /* MethodSignature */:
-        case 303 /* ShorthandPropertyAssignment */:
-        case 302 /* PropertyAssignment */:
-        case 171 /* PropertyDeclaration */:
-        case 170 /* PropertySignature */:
-          return node.questionToken !== void 0;
-      }
-    }
-    return false;
-  }
-  function isJSDocConstructSignature(node) {
-    const param = isJSDocFunctionType(node) ? firstOrUndefined(node.parameters) : void 0;
-    const name = tryCast(param && param.name, isIdentifier);
-    return !!name && name.escapedText === "new";
-  }
-  function isJSDocTypeAlias(node) {
-    return node.kind === 352 /* JSDocTypedefTag */ || node.kind === 344 /* JSDocCallbackTag */ || node.kind === 346 /* JSDocEnumTag */;
-  }
-  function isTypeAlias(node) {
-    return isJSDocTypeAlias(node) || isTypeAliasDeclaration(node);
-  }
-  function getSourceOfAssignment(node) {
-    return isExpressionStatement(node) && isBinaryExpression(node.expression) && node.expression.operatorToken.kind === 64 /* EqualsToken */ ? getRightMostAssignedExpression(node.expression) : void 0;
-  }
-  function getSourceOfDefaultedAssignment(node) {
-    return isExpressionStatement(node) && isBinaryExpression(node.expression) && getAssignmentDeclarationKind(node.expression) !== 0 /* None */ && isBinaryExpression(node.expression.right) && (node.expression.right.operatorToken.kind === 57 /* BarBarToken */ || node.expression.right.operatorToken.kind === 61 /* QuestionQuestionToken */) ? node.expression.right.right : void 0;
-  }
-  function getSingleInitializerOfVariableStatementOrPropertyDeclaration(node) {
-    switch (node.kind) {
-      case 242 /* VariableStatement */:
-        const v = getSingleVariableOfVariableStatement(node);
-        return v && v.initializer;
-      case 171 /* PropertyDeclaration */:
-        return node.initializer;
-      case 302 /* PropertyAssignment */:
-        return node.initializer;
-    }
-  }
-  function getSingleVariableOfVariableStatement(node) {
-    return isVariableStatement(node) ? firstOrUndefined(node.declarationList.declarations) : void 0;
-  }
-  function getNestedModuleDeclaration(node) {
-    return isModuleDeclaration(node) && node.body && node.body.kind === 266 /* ModuleDeclaration */ ? node.body : void 0;
-  }
-  function canHaveFlowNode(node) {
-    if (node.kind >= 242 /* FirstStatement */ && node.kind <= 258 /* LastStatement */) {
-      return true;
-    }
-    switch (node.kind) {
-      case 80 /* Identifier */:
-      case 110 /* ThisKeyword */:
-      case 108 /* SuperKeyword */:
-      case 165 /* QualifiedName */:
-      case 235 /* MetaProperty */:
-      case 211 /* ElementAccessExpression */:
-      case 210 /* PropertyAccessExpression */:
-      case 207 /* BindingElement */:
-      case 217 /* FunctionExpression */:
-      case 218 /* ArrowFunction */:
-      case 173 /* MethodDeclaration */:
-      case 176 /* GetAccessor */:
-      case 177 /* SetAccessor */:
-        return true;
-      default:
-        return false;
-    }
-  }
-  function canHaveJSDoc(node) {
-    switch (node.kind) {
-      case 218 /* ArrowFunction */:
-      case 225 /* BinaryExpression */:
-      case 240 /* Block */:
-      case 251 /* BreakStatement */:
-      case 178 /* CallSignature */:
-      case 295 /* CaseClause */:
-      case 262 /* ClassDeclaration */:
-      case 230 /* ClassExpression */:
-      case 174 /* ClassStaticBlockDeclaration */:
-      case 175 /* Constructor */:
-      case 184 /* ConstructorType */:
-      case 179 /* ConstructSignature */:
-      case 250 /* ContinueStatement */:
-      case 258 /* DebuggerStatement */:
-      case 245 /* DoStatement */:
-      case 211 /* ElementAccessExpression */:
-      case 241 /* EmptyStatement */:
-      case 1 /* EndOfFileToken */:
-      case 265 /* EnumDeclaration */:
-      case 305 /* EnumMember */:
-      case 276 /* ExportAssignment */:
-      case 277 /* ExportDeclaration */:
-      case 280 /* ExportSpecifier */:
-      case 243 /* ExpressionStatement */:
-      case 248 /* ForInStatement */:
-      case 249 /* ForOfStatement */:
-      case 247 /* ForStatement */:
-      case 261 /* FunctionDeclaration */:
-      case 217 /* FunctionExpression */:
-      case 183 /* FunctionType */:
-      case 176 /* GetAccessor */:
-      case 80 /* Identifier */:
-      case 244 /* IfStatement */:
-      case 271 /* ImportDeclaration */:
-      case 270 /* ImportEqualsDeclaration */:
-      case 180 /* IndexSignature */:
-      case 263 /* InterfaceDeclaration */:
-      case 323 /* JSDocFunctionType */:
-      case 329 /* JSDocSignature */:
-      case 255 /* LabeledStatement */:
-      case 173 /* MethodDeclaration */:
-      case 172 /* MethodSignature */:
-      case 266 /* ModuleDeclaration */:
-      case 201 /* NamedTupleMember */:
-      case 269 /* NamespaceExportDeclaration */:
-      case 209 /* ObjectLiteralExpression */:
-      case 168 /* Parameter */:
-      case 216 /* ParenthesizedExpression */:
-      case 210 /* PropertyAccessExpression */:
-      case 302 /* PropertyAssignment */:
-      case 171 /* PropertyDeclaration */:
-      case 170 /* PropertySignature */:
-      case 252 /* ReturnStatement */:
-      case 239 /* SemicolonClassElement */:
-      case 177 /* SetAccessor */:
-      case 303 /* ShorthandPropertyAssignment */:
-      case 304 /* SpreadAssignment */:
-      case 254 /* SwitchStatement */:
-      case 256 /* ThrowStatement */:
-      case 257 /* TryStatement */:
-      case 264 /* TypeAliasDeclaration */:
-      case 167 /* TypeParameter */:
-      case 259 /* VariableDeclaration */:
-      case 242 /* VariableStatement */:
-      case 246 /* WhileStatement */:
-      case 253 /* WithStatement */:
-        return true;
-      default:
-        return false;
-    }
-  }
-  function getJSDocCommentsAndTags(hostNode, noCache) {
-    let result;
-    if (isVariableLike(hostNode) && hasInitializer(hostNode) && hasJSDocNodes(hostNode.initializer)) {
-      result = addRange(result, filterOwnedJSDocTags(hostNode, last(hostNode.initializer.jsDoc)));
-    }
-    let node = hostNode;
-    while (node && node.parent) {
-      if (hasJSDocNodes(node)) {
-        result = addRange(result, filterOwnedJSDocTags(hostNode, last(node.jsDoc)));
-      }
-      if (node.kind === 168 /* Parameter */) {
-        result = addRange(result, (noCache ? getJSDocParameterTagsNoCache : getJSDocParameterTags)(node));
-        break;
-      }
-      if (node.kind === 167 /* TypeParameter */) {
-        result = addRange(result, (noCache ? getJSDocTypeParameterTagsNoCache : getJSDocTypeParameterTags)(node));
-        break;
-      }
-      node = getNextJSDocCommentLocation(node);
-    }
-    return result || emptyArray;
-  }
-  function filterOwnedJSDocTags(hostNode, jsDoc) {
-    if (isJSDoc(jsDoc)) {
-      const ownedTags = filter(jsDoc.tags, (tag) => ownsJSDocTag(hostNode, tag));
-      return jsDoc.tags === ownedTags ? [jsDoc] : ownedTags;
-    }
-    return ownsJSDocTag(hostNode, jsDoc) ? [jsDoc] : void 0;
-  }
-  function ownsJSDocTag(hostNode, tag) {
-    return !(isJSDocTypeTag(tag) || isJSDocSatisfiesTag(tag)) || !tag.parent || !isJSDoc(tag.parent) || !isParenthesizedExpression(tag.parent.parent) || tag.parent.parent === hostNode;
-  }
-  function getNextJSDocCommentLocation(node) {
-    const parent2 = node.parent;
-    if (parent2.kind === 302 /* PropertyAssignment */ || parent2.kind === 276 /* ExportAssignment */ || parent2.kind === 171 /* PropertyDeclaration */ || parent2.kind === 243 /* ExpressionStatement */ && node.kind === 210 /* PropertyAccessExpression */ || parent2.kind === 252 /* ReturnStatement */ || getNestedModuleDeclaration(parent2) || isBinaryExpression(node) && node.operatorToken.kind === 64 /* EqualsToken */) {
-      return parent2;
-    } else if (parent2.parent && (getSingleVariableOfVariableStatement(parent2.parent) === node || isBinaryExpression(parent2) && parent2.operatorToken.kind === 64 /* EqualsToken */)) {
-      return parent2.parent;
-    } else if (parent2.parent && parent2.parent.parent && (getSingleVariableOfVariableStatement(parent2.parent.parent) || getSingleInitializerOfVariableStatementOrPropertyDeclaration(parent2.parent.parent) === node || getSourceOfDefaultedAssignment(parent2.parent.parent))) {
-      return parent2.parent.parent;
-    }
-  }
-  function getParameterSymbolFromJSDoc(node) {
-    if (node.symbol) {
-      return node.symbol;
-    }
-    if (!isIdentifier(node.name)) {
-      return void 0;
-    }
-    const name = node.name.escapedText;
-    const decl = getHostSignatureFromJSDoc(node);
-    if (!decl) {
-      return void 0;
-    }
-    const parameter = find(decl.parameters, (p) => p.name.kind === 80 /* Identifier */ && p.name.escapedText === name);
-    return parameter && parameter.symbol;
-  }
-  function getEffectiveContainerForJSDocTemplateTag(node) {
-    if (isJSDoc(node.parent) && node.parent.tags) {
-      const typeAlias = find(node.parent.tags, isJSDocTypeAlias);
-      if (typeAlias) {
-        return typeAlias;
-      }
-    }
-    return getHostSignatureFromJSDoc(node);
-  }
-  function getHostSignatureFromJSDoc(node) {
-    const host = getEffectiveJSDocHost(node);
-    if (host) {
-      return isPropertySignature(host) && host.type && isFunctionLike(host.type) ? host.type : isFunctionLike(host) ? host : void 0;
-    }
-    return void 0;
-  }
-  function getEffectiveJSDocHost(node) {
-    const host = getJSDocHost(node);
-    if (host) {
-      return getSourceOfDefaultedAssignment(host) || getSourceOfAssignment(host) || getSingleInitializerOfVariableStatementOrPropertyDeclaration(host) || getSingleVariableOfVariableStatement(host) || getNestedModuleDeclaration(host) || host;
-    }
-  }
-  function getJSDocHost(node) {
-    const jsDoc = getJSDocRoot(node);
-    if (!jsDoc) {
-      return void 0;
-    }
-    const host = jsDoc.parent;
-    if (host && host.jsDoc && jsDoc === lastOrUndefined(host.jsDoc)) {
-      return host;
-    }
-  }
-  function getJSDocRoot(node) {
-    return findAncestor(node.parent, isJSDoc);
-  }
-  function getTypeParameterFromJsDoc(node) {
-    const name = node.name.escapedText;
-    const { typeParameters } = node.parent.parent.parent;
-    return typeParameters && find(typeParameters, (p) => p.name.escapedText === name);
-  }
-  function hasTypeArguments(node) {
-    return !!node.typeArguments;
-  }
-  function getAssignmentTargetKind(node) {
-    let parent2 = node.parent;
-    while (true) {
-      switch (parent2.kind) {
-        case 225 /* BinaryExpression */:
-          const binaryOperator = parent2.operatorToken.kind;
-          return isAssignmentOperator(binaryOperator) && parent2.left === node ? binaryOperator === 64 /* EqualsToken */ || isLogicalOrCoalescingAssignmentOperator(binaryOperator) ? 1 /* Definite */ : 2 /* Compound */ : 0 /* None */;
-        case 223 /* PrefixUnaryExpression */:
-        case 224 /* PostfixUnaryExpression */:
-          const unaryOperator = parent2.operator;
-          return unaryOperator === 46 /* PlusPlusToken */ || unaryOperator === 47 /* MinusMinusToken */ ? 2 /* Compound */ : 0 /* None */;
-        case 248 /* ForInStatement */:
-        case 249 /* ForOfStatement */:
-          return parent2.initializer === node ? 1 /* Definite */ : 0 /* None */;
-        case 216 /* ParenthesizedExpression */:
-        case 208 /* ArrayLiteralExpression */:
-        case 229 /* SpreadElement */:
-        case 234 /* NonNullExpression */:
-          node = parent2;
-          break;
-        case 304 /* SpreadAssignment */:
-          node = parent2.parent;
-          break;
-        case 303 /* ShorthandPropertyAssignment */:
-          if (parent2.name !== node) {
-            return 0 /* None */;
-          }
-          node = parent2.parent;
-          break;
-        case 302 /* PropertyAssignment */:
-          if (parent2.name === node) {
-            return 0 /* None */;
-          }
-          node = parent2.parent;
-          break;
-        default:
-          return 0 /* None */;
-      }
-      parent2 = node.parent;
-    }
-  }
-  function isAssignmentTarget(node) {
-    return getAssignmentTargetKind(node) !== 0 /* None */;
-  }
-  function isNodeWithPossibleHoistedDeclaration(node) {
-    switch (node.kind) {
-      case 240 /* Block */:
-      case 242 /* VariableStatement */:
-      case 253 /* WithStatement */:
-      case 244 /* IfStatement */:
-      case 254 /* SwitchStatement */:
-      case 268 /* CaseBlock */:
-      case 295 /* CaseClause */:
-      case 296 /* DefaultClause */:
-      case 255 /* LabeledStatement */:
-      case 247 /* ForStatement */:
-      case 248 /* ForInStatement */:
-      case 249 /* ForOfStatement */:
-      case 245 /* DoStatement */:
-      case 246 /* WhileStatement */:
-      case 257 /* TryStatement */:
-      case 298 /* CatchClause */:
-        return true;
-    }
-    return false;
-  }
-  function isValueSignatureDeclaration(node) {
-    return isFunctionExpression(node) || isArrowFunction(node) || isMethodOrAccessor(node) || isFunctionDeclaration(node) || isConstructorDeclaration(node);
-  }
-  function walkUp(node, kind) {
-    while (node && node.kind === kind) {
-      node = node.parent;
-    }
-    return node;
-  }
-  function walkUpParenthesizedTypes(node) {
-    return walkUp(node, 195 /* ParenthesizedType */);
-  }
-  function walkUpParenthesizedExpressions(node) {
-    return walkUp(node, 216 /* ParenthesizedExpression */);
-  }
-  function walkUpParenthesizedTypesAndGetParentAndChild(node) {
-    let child;
-    while (node && node.kind === 195 /* ParenthesizedType */) {
-      child = node;
-      node = node.parent;
-    }
-    return [child, node];
-  }
-  function skipTypeParentheses(node) {
-    while (isParenthesizedTypeNode(node))
-      node = node.type;
-    return node;
-  }
-  function skipParentheses(node, excludeJSDocTypeAssertions) {
-    const flags = excludeJSDocTypeAssertions ? 1 /* Parentheses */ | 16 /* ExcludeJSDocTypeAssertion */ : 1 /* Parentheses */;
-    return skipOuterExpressions(node, flags);
-  }
-  function isDeleteTarget(node) {
-    if (node.kind !== 210 /* PropertyAccessExpression */ && node.kind !== 211 /* ElementAccessExpression */) {
-      return false;
-    }
-    node = walkUpParenthesizedExpressions(node.parent);
-    return node && node.kind === 219 /* DeleteExpression */;
-  }
-  function isNodeDescendantOf(node, ancestor) {
-    while (node) {
-      if (node === ancestor)
-        return true;
-      node = node.parent;
-    }
-    return false;
-  }
-  function isDeclarationName(name) {
-    return !isSourceFile(name) && !isBindingPattern(name) && isDeclaration(name.parent) && name.parent.name === name;
-  }
-  function getDeclarationFromName(name) {
-    const parent2 = name.parent;
-    switch (name.kind) {
-      case 11 /* StringLiteral */:
-      case 15 /* NoSubstitutionTemplateLiteral */:
-      case 9 /* NumericLiteral */:
-        if (isComputedPropertyName(parent2))
-          return parent2.parent;
-      case 80 /* Identifier */:
-        if (isDeclaration(parent2)) {
-          return parent2.name === name ? parent2 : void 0;
-        } else if (isQualifiedName(parent2)) {
-          const tag = parent2.parent;
-          return isJSDocParameterTag(tag) && tag.name === parent2 ? tag : void 0;
-        } else {
-          const binExp = parent2.parent;
-          return isBinaryExpression(binExp) && getAssignmentDeclarationKind(binExp) !== 0 /* None */ && (binExp.left.symbol || binExp.symbol) && getNameOfDeclaration(binExp) === name ? binExp : void 0;
-        }
-      case 81 /* PrivateIdentifier */:
-        return isDeclaration(parent2) && parent2.name === name ? parent2 : void 0;
-      default:
-        return void 0;
-    }
-  }
-  function isLiteralComputedPropertyDeclarationName(node) {
-    return isStringOrNumericLiteralLike(node) && node.parent.kind === 166 /* ComputedPropertyName */ && isDeclaration(node.parent.parent);
-  }
-  function isIdentifierName(node) {
-    const parent2 = node.parent;
-    switch (parent2.kind) {
-      case 171 /* PropertyDeclaration */:
-      case 170 /* PropertySignature */:
-      case 173 /* MethodDeclaration */:
-      case 172 /* MethodSignature */:
-      case 176 /* GetAccessor */:
-      case 177 /* SetAccessor */:
-      case 305 /* EnumMember */:
-      case 302 /* PropertyAssignment */:
-      case 210 /* PropertyAccessExpression */:
-        return parent2.name === node;
-      case 165 /* QualifiedName */:
-        return parent2.right === node;
-      case 207 /* BindingElement */:
-      case 275 /* ImportSpecifier */:
-        return parent2.propertyName === node;
-      case 280 /* ExportSpecifier */:
-      case 290 /* JsxAttribute */:
-      case 284 /* JsxSelfClosingElement */:
-      case 285 /* JsxOpeningElement */:
-      case 286 /* JsxClosingElement */:
-        return true;
-    }
-    return false;
-  }
-  function isAliasSymbolDeclaration(node) {
-    if (node.kind === 270 /* ImportEqualsDeclaration */ || node.kind === 269 /* NamespaceExportDeclaration */ || node.kind === 272 /* ImportClause */ && !!node.name || node.kind === 273 /* NamespaceImport */ || node.kind === 279 /* NamespaceExport */ || node.kind === 275 /* ImportSpecifier */ || node.kind === 280 /* ExportSpecifier */ || node.kind === 276 /* ExportAssignment */ && exportAssignmentIsAlias(node)) {
-      return true;
-    }
-    return isInJSFile(node) && (isBinaryExpression(node) && getAssignmentDeclarationKind(node) === 2 /* ModuleExports */ && exportAssignmentIsAlias(node) || isPropertyAccessExpression(node) && isBinaryExpression(node.parent) && node.parent.left === node && node.parent.operatorToken.kind === 64 /* EqualsToken */ && isAliasableExpression(node.parent.right));
-  }
-  function getAliasDeclarationFromName(node) {
-    switch (node.parent.kind) {
-      case 272 /* ImportClause */:
-      case 275 /* ImportSpecifier */:
-      case 273 /* NamespaceImport */:
-      case 280 /* ExportSpecifier */:
-      case 276 /* ExportAssignment */:
-      case 270 /* ImportEqualsDeclaration */:
-      case 279 /* NamespaceExport */:
-        return node.parent;
-      case 165 /* QualifiedName */:
-        do {
-          node = node.parent;
-        } while (node.parent.kind === 165 /* QualifiedName */);
-        return getAliasDeclarationFromName(node);
-    }
-  }
-  function isAliasableExpression(e) {
-    return isEntityNameExpression(e) || isClassExpression(e);
-  }
-  function exportAssignmentIsAlias(node) {
-    const e = getExportAssignmentExpression(node);
-    return isAliasableExpression(e);
-  }
-  function getExportAssignmentExpression(node) {
-    return isExportAssignment(node) ? node.expression : node.right;
-  }
-  function getPropertyAssignmentAliasLikeExpression(node) {
-    return node.kind === 303 /* ShorthandPropertyAssignment */ ? node.name : node.kind === 302 /* PropertyAssignment */ ? node.initializer : node.parent.right;
-  }
-  function getEffectiveBaseTypeNode(node) {
-    const baseType = getClassExtendsHeritageElement(node);
-    if (baseType && isInJSFile(node)) {
-      const tag = getJSDocAugmentsTag(node);
-      if (tag) {
-        return tag.class;
-      }
-    }
-    return baseType;
-  }
-  function getClassExtendsHeritageElement(node) {
-    const heritageClause = getHeritageClause(node.heritageClauses, 96 /* ExtendsKeyword */);
-    return heritageClause && heritageClause.types.length > 0 ? heritageClause.types[0] : void 0;
-  }
-  function getEffectiveImplementsTypeNodes(node) {
-    if (isInJSFile(node)) {
-      return getJSDocImplementsTags(node).map((n) => n.class);
-    } else {
-      const heritageClause = getHeritageClause(node.heritageClauses, 119 /* ImplementsKeyword */);
-      return heritageClause == null ? void 0 : heritageClause.types;
-    }
-  }
-  function getAllSuperTypeNodes(node) {
-    return isInterfaceDeclaration(node) ? getInterfaceBaseTypeNodes(node) || emptyArray : isClassLike(node) ? concatenate(singleElementArray(getEffectiveBaseTypeNode(node)), getEffectiveImplementsTypeNodes(node)) || emptyArray : emptyArray;
-  }
-  function getInterfaceBaseTypeNodes(node) {
-    const heritageClause = getHeritageClause(node.heritageClauses, 96 /* ExtendsKeyword */);
-    return heritageClause ? heritageClause.types : void 0;
-  }
-  function getHeritageClause(clauses, kind) {
-    if (clauses) {
-      for (const clause of clauses) {
-        if (clause.token === kind) {
-          return clause;
-        }
-      }
-    }
-    return void 0;
-  }
-  function getAncestor(node, kind) {
-    while (node) {
-      if (node.kind === kind) {
-        return node;
-      }
-      node = node.parent;
-    }
-    return void 0;
-  }
-  function isKeyword(token) {
-    return 83 /* FirstKeyword */ <= token && token <= 164 /* LastKeyword */;
-  }
-  function isPunctuation(token) {
-    return 19 /* FirstPunctuation */ <= token && token <= 79 /* LastPunctuation */;
-  }
-  function isKeywordOrPunctuation(token) {
-    return isKeyword(token) || isPunctuation(token);
-  }
-  function isContextualKeyword(token) {
-    return 128 /* FirstContextualKeyword */ <= token && token <= 164 /* LastContextualKeyword */;
-  }
-  function isNonContextualKeyword(token) {
-    return isKeyword(token) && !isContextualKeyword(token);
-  }
-  function isFutureReservedKeyword(token) {
-    return 119 /* FirstFutureReservedWord */ <= token && token <= 127 /* LastFutureReservedWord */;
-  }
-  function isStringANonContextualKeyword(name) {
-    const token = stringToToken(name);
-    return token !== void 0 && isNonContextualKeyword(token);
-  }
-  function isStringAKeyword(name) {
-    const token = stringToToken(name);
-    return token !== void 0 && isKeyword(token);
-  }
-  function isIdentifierANonContextualKeyword(node) {
-    const originalKeywordKind = identifierToKeywordKind(node);
-    return !!originalKeywordKind && !isContextualKeyword(originalKeywordKind);
-  }
-  function isTrivia(token) {
-    return 2 /* FirstTriviaToken */ <= token && token <= 7 /* LastTriviaToken */;
-  }
-  function getFunctionFlags(node) {
-    if (!node) {
-      return 4 /* Invalid */;
-    }
-    let flags = 0 /* Normal */;
-    switch (node.kind) {
-      case 261 /* FunctionDeclaration */:
-      case 217 /* FunctionExpression */:
-      case 173 /* MethodDeclaration */:
-        if (node.asteriskToken) {
-          flags |= 1 /* Generator */;
-        }
-      case 218 /* ArrowFunction */:
-        if (hasSyntacticModifier(node, 512 /* Async */)) {
-          flags |= 2 /* Async */;
-        }
-        break;
-    }
-    if (!node.body) {
-      flags |= 4 /* Invalid */;
-    }
-    return flags;
-  }
-  function isAsyncFunction(node) {
-    switch (node.kind) {
-      case 261 /* FunctionDeclaration */:
-      case 217 /* FunctionExpression */:
-      case 218 /* ArrowFunction */:
-      case 173 /* MethodDeclaration */:
-        return node.body !== void 0 && node.asteriskToken === void 0 && hasSyntacticModifier(node, 512 /* Async */);
-    }
-    return false;
-  }
-  function isStringOrNumericLiteralLike(node) {
-    return isStringLiteralLike(node) || isNumericLiteral(node);
-  }
-  function isSignedNumericLiteral(node) {
-    return isPrefixUnaryExpression(node) && (node.operator === 40 /* PlusToken */ || node.operator === 41 /* MinusToken */) && isNumericLiteral(node.operand);
-  }
-  function hasDynamicName(declaration) {
-    const name = getNameOfDeclaration(declaration);
-    return !!name && isDynamicName(name);
-  }
-  function isDynamicName(name) {
-    if (!(name.kind === 166 /* ComputedPropertyName */ || name.kind === 211 /* ElementAccessExpression */)) {
-      return false;
-    }
-    const expr = isElementAccessExpression(name) ? skipParentheses(name.argumentExpression) : name.expression;
-    return !isStringOrNumericLiteralLike(expr) && !isSignedNumericLiteral(expr);
-  }
-  function getPropertyNameForPropertyNameNode(name) {
-    switch (name.kind) {
-      case 80 /* Identifier */:
-      case 81 /* PrivateIdentifier */:
-        return name.escapedText;
-      case 11 /* StringLiteral */:
-      case 9 /* NumericLiteral */:
-        return escapeLeadingUnderscores(name.text);
-      case 166 /* ComputedPropertyName */:
-        const nameExpression = name.expression;
-        if (isStringOrNumericLiteralLike(nameExpression)) {
-          return escapeLeadingUnderscores(nameExpression.text);
-        } else if (isSignedNumericLiteral(nameExpression)) {
-          if (nameExpression.operator === 41 /* MinusToken */) {
-            return tokenToString(nameExpression.operator) + nameExpression.operand.text;
-          }
-          return nameExpression.operand.text;
-        }
-        return void 0;
-      case 294 /* JsxNamespacedName */:
-        return getEscapedTextOfJsxNamespacedName(name);
-      default:
-        return Debug.assertNever(name);
-    }
-  }
-  function isPropertyNameLiteral(node) {
-    switch (node.kind) {
-      case 80 /* Identifier */:
-      case 11 /* StringLiteral */:
-      case 15 /* NoSubstitutionTemplateLiteral */:
-      case 9 /* NumericLiteral */:
-        return true;
-      default:
-        return false;
-    }
-  }
-  function getTextOfIdentifierOrLiteral(node) {
-    return isMemberName(node) ? idText(node) : isJsxNamespacedName(node) ? getTextOfJsxNamespacedName(node) : node.text;
-  }
-  function getEscapedTextOfIdentifierOrLiteral(node) {
-    return isMemberName(node) ? node.escapedText : isJsxNamespacedName(node) ? getEscapedTextOfJsxNamespacedName(node) : escapeLeadingUnderscores(node.text);
-  }
-  function getPropertyNameForUniqueESSymbol(symbol) {
-    return `__@${getSymbolId(symbol)}@${symbol.escapedName}`;
-  }
-  function getSymbolNameForPrivateIdentifier(containingClassSymbol, description3) {
-    return `__#${getSymbolId(containingClassSymbol)}@${description3}`;
-  }
-  function isKnownSymbol(symbol) {
-    return startsWith(symbol.escapedName, "__@");
-  }
-  function isPrivateIdentifierSymbol(symbol) {
-    return startsWith(symbol.escapedName, "__#");
-  }
-  function isESSymbolIdentifier(node) {
-    return node.kind === 80 /* Identifier */ && node.escapedText === "Symbol";
-  }
-  function isProtoSetter(node) {
-    return isIdentifier(node) ? idText(node) === "__proto__" : isStringLiteral(node) && node.text === "__proto__";
-  }
-  function isAnonymousFunctionDefinition(node, cb) {
-    node = skipOuterExpressions(node);
-    switch (node.kind) {
-      case 230 /* ClassExpression */:
-      case 217 /* FunctionExpression */:
-        if (node.name) {
-          return false;
-        }
-        break;
-      case 218 /* ArrowFunction */:
-        break;
-      default:
-        return false;
-    }
-    return typeof cb === "function" ? cb(node) : true;
-  }
-  function isNamedEvaluationSource(node) {
-    switch (node.kind) {
-      case 302 /* PropertyAssignment */:
-        return !isProtoSetter(node.name);
-      case 303 /* ShorthandPropertyAssignment */:
-        return !!node.objectAssignmentInitializer;
-      case 259 /* VariableDeclaration */:
-        return isIdentifier(node.name) && !!node.initializer;
-      case 168 /* Parameter */:
-        return isIdentifier(node.name) && !!node.initializer && !node.dotDotDotToken;
-      case 207 /* BindingElement */:
-        return isIdentifier(node.name) && !!node.initializer && !node.dotDotDotToken;
-      case 171 /* PropertyDeclaration */:
-        return !!node.initializer;
-      case 225 /* BinaryExpression */:
-        switch (node.operatorToken.kind) {
-          case 64 /* EqualsToken */:
-          case 77 /* AmpersandAmpersandEqualsToken */:
-          case 76 /* BarBarEqualsToken */:
-          case 78 /* QuestionQuestionEqualsToken */:
-            return isIdentifier(node.left);
-        }
-        break;
-      case 276 /* ExportAssignment */:
-        return true;
-    }
-    return false;
-  }
-  function isNamedEvaluation(node, cb) {
-    if (!isNamedEvaluationSource(node))
-      return false;
-    switch (node.kind) {
-      case 302 /* PropertyAssignment */:
-        return isAnonymousFunctionDefinition(node.initializer, cb);
-      case 303 /* ShorthandPropertyAssignment */:
-        return isAnonymousFunctionDefinition(node.objectAssignmentInitializer, cb);
-      case 259 /* VariableDeclaration */:
-      case 168 /* Parameter */:
-      case 207 /* BindingElement */:
-      case 171 /* PropertyDeclaration */:
-        return isAnonymousFunctionDefinition(node.initializer, cb);
-      case 225 /* BinaryExpression */:
-        return isAnonymousFunctionDefinition(node.right, cb);
-      case 276 /* ExportAssignment */:
-        return isAnonymousFunctionDefinition(node.expression, cb);
-    }
-  }
-  function isPushOrUnshiftIdentifier(node) {
-    return node.escapedText === "push" || node.escapedText === "unshift";
-  }
-  function isParameterDeclaration(node) {
-    const root = getRootDeclaration(node);
-    return root.kind === 168 /* Parameter */;
-  }
-  function getRootDeclaration(node) {
-    while (node.kind === 207 /* BindingElement */) {
-      node = node.parent.parent;
-    }
-    return node;
-  }
-  function nodeStartsNewLexicalEnvironment(node) {
-    const kind = node.kind;
-    return kind === 175 /* Constructor */ || kind === 217 /* FunctionExpression */ || kind === 261 /* FunctionDeclaration */ || kind === 218 /* ArrowFunction */ || kind === 173 /* MethodDeclaration */ || kind === 176 /* GetAccessor */ || kind === 177 /* SetAccessor */ || kind === 266 /* ModuleDeclaration */ || kind === 311 /* SourceFile */;
-  }
-  function nodeIsSynthesized(range) {
-    return positionIsSynthesized(range.pos) || positionIsSynthesized(range.end);
-  }
-  function getOriginalSourceFile(sourceFile) {
-    return getParseTreeNode(sourceFile, isSourceFile) || sourceFile;
-  }
-  function getExpressionAssociativity(expression) {
-    const operator = getOperator(expression);
-    const hasArguments = expression.kind === 213 /* NewExpression */ && expression.arguments !== void 0;
-    return getOperatorAssociativity(expression.kind, operator, hasArguments);
-  }
-  function getOperatorAssociativity(kind, operator, hasArguments) {
-    switch (kind) {
-      case 213 /* NewExpression */:
-        return hasArguments ? 0 /* Left */ : 1 /* Right */;
-      case 223 /* PrefixUnaryExpression */:
-      case 220 /* TypeOfExpression */:
-      case 221 /* VoidExpression */:
-      case 219 /* DeleteExpression */:
-      case 222 /* AwaitExpression */:
-      case 226 /* ConditionalExpression */:
-      case 228 /* YieldExpression */:
-        return 1 /* Right */;
-      case 225 /* BinaryExpression */:
-        switch (operator) {
-          case 43 /* AsteriskAsteriskToken */:
-          case 64 /* EqualsToken */:
-          case 65 /* PlusEqualsToken */:
-          case 66 /* MinusEqualsToken */:
-          case 68 /* AsteriskAsteriskEqualsToken */:
-          case 67 /* AsteriskEqualsToken */:
-          case 69 /* SlashEqualsToken */:
-          case 70 /* PercentEqualsToken */:
-          case 71 /* LessThanLessThanEqualsToken */:
-          case 72 /* GreaterThanGreaterThanEqualsToken */:
-          case 73 /* GreaterThanGreaterThanGreaterThanEqualsToken */:
-          case 74 /* AmpersandEqualsToken */:
-          case 79 /* CaretEqualsToken */:
-          case 75 /* BarEqualsToken */:
-          case 76 /* BarBarEqualsToken */:
-          case 77 /* AmpersandAmpersandEqualsToken */:
-          case 78 /* QuestionQuestionEqualsToken */:
-            return 1 /* Right */;
-        }
-    }
-    return 0 /* Left */;
-  }
-  function getExpressionPrecedence(expression) {
-    const operator = getOperator(expression);
-    const hasArguments = expression.kind === 213 /* NewExpression */ && expression.arguments !== void 0;
-    return getOperatorPrecedence(expression.kind, operator, hasArguments);
-  }
-  function getOperator(expression) {
-    if (expression.kind === 225 /* BinaryExpression */) {
-      return expression.operatorToken.kind;
-    } else if (expression.kind === 223 /* PrefixUnaryExpression */ || expression.kind === 224 /* PostfixUnaryExpression */) {
-      return expression.operator;
-    } else {
-      return expression.kind;
-    }
-  }
-  function getOperatorPrecedence(nodeKind, operatorKind, hasArguments) {
-    switch (nodeKind) {
-      case 360 /* CommaListExpression */:
-        return 0 /* Comma */;
-      case 229 /* SpreadElement */:
-        return 1 /* Spread */;
-      case 228 /* YieldExpression */:
-        return 2 /* Yield */;
-      case 226 /* ConditionalExpression */:
-        return 4 /* Conditional */;
-      case 225 /* BinaryExpression */:
-        switch (operatorKind) {
-          case 28 /* CommaToken */:
-            return 0 /* Comma */;
-          case 64 /* EqualsToken */:
-          case 65 /* PlusEqualsToken */:
-          case 66 /* MinusEqualsToken */:
-          case 68 /* AsteriskAsteriskEqualsToken */:
-          case 67 /* AsteriskEqualsToken */:
-          case 69 /* SlashEqualsToken */:
-          case 70 /* PercentEqualsToken */:
-          case 71 /* LessThanLessThanEqualsToken */:
-          case 72 /* GreaterThanGreaterThanEqualsToken */:
-          case 73 /* GreaterThanGreaterThanGreaterThanEqualsToken */:
-          case 74 /* AmpersandEqualsToken */:
-          case 79 /* CaretEqualsToken */:
-          case 75 /* BarEqualsToken */:
-          case 76 /* BarBarEqualsToken */:
-          case 77 /* AmpersandAmpersandEqualsToken */:
-          case 78 /* QuestionQuestionEqualsToken */:
-            return 3 /* Assignment */;
-          default:
-            return getBinaryOperatorPrecedence(operatorKind);
-        }
-      case 215 /* TypeAssertionExpression */:
-      case 234 /* NonNullExpression */:
-      case 223 /* PrefixUnaryExpression */:
-      case 220 /* TypeOfExpression */:
-      case 221 /* VoidExpression */:
-      case 219 /* DeleteExpression */:
-      case 222 /* AwaitExpression */:
-        return 16 /* Unary */;
-      case 224 /* PostfixUnaryExpression */:
-        return 17 /* Update */;
-      case 212 /* CallExpression */:
-        return 18 /* LeftHandSide */;
-      case 213 /* NewExpression */:
-        return hasArguments ? 19 /* Member */ : 18 /* LeftHandSide */;
-      case 214 /* TaggedTemplateExpression */:
-      case 210 /* PropertyAccessExpression */:
-      case 211 /* ElementAccessExpression */:
-      case 235 /* MetaProperty */:
-        return 19 /* Member */;
-      case 233 /* AsExpression */:
-      case 237 /* SatisfiesExpression */:
-        return 11 /* Relational */;
-      case 110 /* ThisKeyword */:
-      case 108 /* SuperKeyword */:
-      case 80 /* Identifier */:
-      case 81 /* PrivateIdentifier */:
-      case 106 /* NullKeyword */:
-      case 112 /* TrueKeyword */:
-      case 97 /* FalseKeyword */:
-      case 9 /* NumericLiteral */:
-      case 10 /* BigIntLiteral */:
-      case 11 /* StringLiteral */:
-      case 208 /* ArrayLiteralExpression */:
-      case 209 /* ObjectLiteralExpression */:
-      case 217 /* FunctionExpression */:
-      case 218 /* ArrowFunction */:
-      case 230 /* ClassExpression */:
-      case 14 /* RegularExpressionLiteral */:
-      case 15 /* NoSubstitutionTemplateLiteral */:
-      case 227 /* TemplateExpression */:
-      case 216 /* ParenthesizedExpression */:
-      case 231 /* OmittedExpression */:
-      case 283 /* JsxElement */:
-      case 284 /* JsxSelfClosingElement */:
-      case 287 /* JsxFragment */:
-        return 20 /* Primary */;
-      default:
-        return -1 /* Invalid */;
-    }
-  }
-  function getBinaryOperatorPrecedence(kind) {
-    switch (kind) {
-      case 61 /* QuestionQuestionToken */:
-        return 4 /* Coalesce */;
-      case 57 /* BarBarToken */:
-        return 5 /* LogicalOR */;
-      case 56 /* AmpersandAmpersandToken */:
-        return 6 /* LogicalAND */;
-      case 52 /* BarToken */:
-        return 7 /* BitwiseOR */;
-      case 53 /* CaretToken */:
-        return 8 /* BitwiseXOR */;
-      case 51 /* AmpersandToken */:
-        return 9 /* BitwiseAND */;
-      case 35 /* EqualsEqualsToken */:
-      case 36 /* ExclamationEqualsToken */:
-      case 37 /* EqualsEqualsEqualsToken */:
-      case 38 /* ExclamationEqualsEqualsToken */:
-        return 10 /* Equality */;
-      case 30 /* LessThanToken */:
-      case 32 /* GreaterThanToken */:
-      case 33 /* LessThanEqualsToken */:
-      case 34 /* GreaterThanEqualsToken */:
-      case 104 /* InstanceOfKeyword */:
-      case 103 /* InKeyword */:
-      case 130 /* AsKeyword */:
-      case 152 /* SatisfiesKeyword */:
-        return 11 /* Relational */;
-      case 48 /* LessThanLessThanToken */:
-      case 49 /* GreaterThanGreaterThanToken */:
-      case 50 /* GreaterThanGreaterThanGreaterThanToken */:
-        return 12 /* Shift */;
-      case 40 /* PlusToken */:
-      case 41 /* MinusToken */:
-        return 13 /* Additive */;
-      case 42 /* AsteriskToken */:
-      case 44 /* SlashToken */:
-      case 45 /* PercentToken */:
-        return 14 /* Multiplicative */;
-      case 43 /* AsteriskAsteriskToken */:
-        return 15 /* Exponentiation */;
-    }
-    return -1;
-  }
-  function getSemanticJsxChildren(children) {
-    return filter(children, (i) => {
-      switch (i.kind) {
-        case 293 /* JsxExpression */:
-          return !!i.expression;
-        case 12 /* JsxText */:
-          return !i.containsOnlyTriviaWhiteSpaces;
-        default:
-          return true;
-      }
-    });
-  }
-  function createDiagnosticCollection() {
-    let nonFileDiagnostics = [];
-    const filesWithDiagnostics = [];
-    const fileDiagnostics = /* @__PURE__ */ new Map();
-    let hasReadNonFileDiagnostics = false;
-    return {
-      add,
-      lookup,
-      getGlobalDiagnostics,
-      getDiagnostics: getDiagnostics2
-    };
-    function lookup(diagnostic) {
-      let diagnostics;
-      if (diagnostic.file) {
-        diagnostics = fileDiagnostics.get(diagnostic.file.fileName);
-      } else {
-        diagnostics = nonFileDiagnostics;
-      }
-      if (!diagnostics) {
-        return void 0;
-      }
-      const result = binarySearch(diagnostics, diagnostic, identity, compareDiagnosticsSkipRelatedInformation);
-      if (result >= 0) {
-        return diagnostics[result];
-      }
-      return void 0;
-    }
-    function add(diagnostic) {
-      let diagnostics;
-      if (diagnostic.file) {
-        diagnostics = fileDiagnostics.get(diagnostic.file.fileName);
-        if (!diagnostics) {
-          diagnostics = [];
-          fileDiagnostics.set(diagnostic.file.fileName, diagnostics);
-          insertSorted(filesWithDiagnostics, diagnostic.file.fileName, compareStringsCaseSensitive);
-        }
-      } else {
-        if (hasReadNonFileDiagnostics) {
-          hasReadNonFileDiagnostics = false;
-          nonFileDiagnostics = nonFileDiagnostics.slice();
-        }
-        diagnostics = nonFileDiagnostics;
-      }
-      insertSorted(diagnostics, diagnostic, compareDiagnosticsSkipRelatedInformation);
-    }
-    function getGlobalDiagnostics() {
-      hasReadNonFileDiagnostics = true;
-      return nonFileDiagnostics;
-    }
-    function getDiagnostics2(fileName) {
-      if (fileName) {
-        return fileDiagnostics.get(fileName) || [];
-      }
-      const fileDiags = flatMapToMutable(filesWithDiagnostics, (f) => fileDiagnostics.get(f));
-      if (!nonFileDiagnostics.length) {
-        return fileDiags;
-      }
-      fileDiags.unshift(...nonFileDiagnostics);
-      return fileDiags;
-    }
-  }
-  function escapeTemplateSubstitution(str) {
-    return str.replace(templateSubstitutionRegExp, "\\${");
-  }
-  function hasInvalidEscape(template) {
-    return template && !!(isNoSubstitutionTemplateLiteral(template) ? template.templateFlags : template.head.templateFlags || some(template.templateSpans, (span) => !!span.literal.templateFlags));
-  }
-  function encodeUtf16EscapeSequence(charCode) {
-    const hexCharCode = charCode.toString(16).toUpperCase();
-    const paddedHexCode = ("0000" + hexCharCode).slice(-4);
-    return "\\u" + paddedHexCode;
-  }
-  function getReplacement(c, offset, input) {
-    if (c.charCodeAt(0) === 0 /* nullCharacter */) {
-      const lookAhead = input.charCodeAt(offset + c.length);
-      if (lookAhead >= 48 /* _0 */ && lookAhead <= 57 /* _9 */) {
-        return "\\x00";
-      }
-      return "\\0";
-    }
-    return escapedCharsMap.get(c) || encodeUtf16EscapeSequence(c.charCodeAt(0));
-  }
-  function escapeString(s, quoteChar) {
-    const escapedCharsRegExp = quoteChar === 96 /* backtick */ ? backtickQuoteEscapedCharsRegExp : quoteChar === 39 /* singleQuote */ ? singleQuoteEscapedCharsRegExp : doubleQuoteEscapedCharsRegExp;
-    return s.replace(escapedCharsRegExp, getReplacement);
-  }
-  function escapeNonAsciiString(s, quoteChar) {
-    s = escapeString(s, quoteChar);
-    return nonAsciiCharacters.test(s) ? s.replace(nonAsciiCharacters, (c) => encodeUtf16EscapeSequence(c.charCodeAt(0))) : s;
-  }
-  function encodeJsxCharacterEntity(charCode) {
-    const hexCharCode = charCode.toString(16).toUpperCase();
-    return "&#x" + hexCharCode + ";";
-  }
-  function getJsxAttributeStringReplacement(c) {
-    if (c.charCodeAt(0) === 0 /* nullCharacter */) {
-      return "�";
-    }
-    return jsxEscapedCharsMap.get(c) || encodeJsxCharacterEntity(c.charCodeAt(0));
-  }
-  function escapeJsxAttributeString(s, quoteChar) {
-    const escapedCharsRegExp = quoteChar === 39 /* singleQuote */ ? jsxSingleQuoteEscapedCharsRegExp : jsxDoubleQuoteEscapedCharsRegExp;
-    return s.replace(escapedCharsRegExp, getJsxAttributeStringReplacement);
-  }
-  function stripQuotes(name) {
-    const length2 = name.length;
-    if (length2 >= 2 && name.charCodeAt(0) === name.charCodeAt(length2 - 1) && isQuoteOrBacktick(name.charCodeAt(0))) {
-      return name.substring(1, length2 - 1);
-    }
-    return name;
-  }
-  function isQuoteOrBacktick(charCode) {
-    return charCode === 39 /* singleQuote */ || charCode === 34 /* doubleQuote */ || charCode === 96 /* backtick */;
-  }
-  function isIntrinsicJsxName(name) {
-    const ch = name.charCodeAt(0);
-    return ch >= 97 /* a */ && ch <= 122 /* z */ || stringContains(name, "-");
-  }
-  function getIndentString(level) {
-    const singleLevel = indentStrings[1];
-    for (let current = indentStrings.length; current <= level; current++) {
-      indentStrings.push(indentStrings[current - 1] + singleLevel);
-    }
-    return indentStrings[level];
-  }
-  function getIndentSize() {
-    return indentStrings[1].length;
-  }
-  function isNightly() {
-    return stringContains(version, "-dev") || stringContains(version, "-insiders");
-  }
-  function createTextWriter(newLine) {
-    var output;
-    var indent2;
-    var lineStart;
-    var lineCount;
-    var linePos;
-    var hasTrailingComment = false;
-    function updateLineCountAndPosFor(s) {
-      const lineStartsOfS = computeLineStarts(s);
-      if (lineStartsOfS.length > 1) {
-        lineCount = lineCount + lineStartsOfS.length - 1;
-        linePos = output.length - s.length + last(lineStartsOfS);
-        lineStart = linePos - output.length === 0;
-      } else {
-        lineStart = false;
-      }
-    }
-    function writeText(s) {
-      if (s && s.length) {
-        if (lineStart) {
-          s = getIndentString(indent2) + s;
-          lineStart = false;
-        }
-        output += s;
-        updateLineCountAndPosFor(s);
-      }
-    }
-    function write(s) {
-      if (s)
-        hasTrailingComment = false;
-      writeText(s);
-    }
-    function writeComment(s) {
-      if (s)
-        hasTrailingComment = true;
-      writeText(s);
-    }
-    function reset2() {
-      output = "";
-      indent2 = 0;
-      lineStart = true;
-      lineCount = 0;
-      linePos = 0;
-      hasTrailingComment = false;
-    }
-    function rawWrite(s) {
-      if (s !== void 0) {
-        output += s;
-        updateLineCountAndPosFor(s);
-        hasTrailingComment = false;
-      }
-    }
-    function writeLiteral(s) {
-      if (s && s.length) {
-        write(s);
-      }
-    }
-    function writeLine(force) {
-      if (!lineStart || force) {
-        output += newLine;
-        lineCount++;
-        linePos = output.length;
-        lineStart = true;
-        hasTrailingComment = false;
-      }
-    }
-    function getTextPosWithWriteLine() {
-      return lineStart ? output.length : output.length + newLine.length;
-    }
-    reset2();
-    return {
-      write,
-      rawWrite,
-      writeLiteral,
-      writeLine,
-      increaseIndent: () => {
-        indent2++;
-      },
-      decreaseIndent: () => {
-        indent2--;
-      },
-      getIndent: () => indent2,
-      getTextPos: () => output.length,
-      getLine: () => lineCount,
-      getColumn: () => lineStart ? indent2 * getIndentSize() : output.length - linePos,
-      getText: () => output,
-      isAtStartOfLine: () => lineStart,
-      hasTrailingComment: () => hasTrailingComment,
-      hasTrailingWhitespace: () => !!output.length && isWhiteSpaceLike(output.charCodeAt(output.length - 1)),
-      clear: reset2,
-      writeKeyword: write,
-      writeOperator: write,
-      writeParameter: write,
-      writeProperty: write,
-      writePunctuation: write,
-      writeSpace: write,
-      writeStringLiteral: write,
-      writeSymbol: (s, _) => write(s),
-      writeTrailingSemicolon: write,
-      writeComment,
-      getTextPosWithWriteLine
-    };
-  }
-  function getTrailingSemicolonDeferringWriter(writer) {
-    let pendingTrailingSemicolon = false;
-    function commitPendingTrailingSemicolon() {
-      if (pendingTrailingSemicolon) {
-        writer.writeTrailingSemicolon(";");
-        pendingTrailingSemicolon = false;
-      }
-    }
-    return {
-      ...writer,
-      writeTrailingSemicolon() {
-        pendingTrailingSemicolon = true;
-      },
-      writeLiteral(s) {
-        commitPendingTrailingSemicolon();
-        writer.writeLiteral(s);
-      },
-      writeStringLiteral(s) {
-        commitPendingTrailingSemicolon();
-        writer.writeStringLiteral(s);
-      },
-      writeSymbol(s, sym) {
-        commitPendingTrailingSemicolon();
-        writer.writeSymbol(s, sym);
-      },
-      writePunctuation(s) {
-        commitPendingTrailingSemicolon();
-        writer.writePunctuation(s);
-      },
-      writeKeyword(s) {
-        commitPendingTrailingSemicolon();
-        writer.writeKeyword(s);
-      },
-      writeOperator(s) {
-        commitPendingTrailingSemicolon();
-        writer.writeOperator(s);
-      },
-      writeParameter(s) {
-        commitPendingTrailingSemicolon();
-        writer.writeParameter(s);
-      },
-      writeSpace(s) {
-        commitPendingTrailingSemicolon();
-        writer.writeSpace(s);
-      },
-      writeProperty(s) {
-        commitPendingTrailingSemicolon();
-        writer.writeProperty(s);
-      },
-      writeComment(s) {
-        commitPendingTrailingSemicolon();
-        writer.writeComment(s);
-      },
-      writeLine() {
-        commitPendingTrailingSemicolon();
-        writer.writeLine();
-      },
-      increaseIndent() {
-        commitPendingTrailingSemicolon();
-        writer.increaseIndent();
-      },
-      decreaseIndent() {
-        commitPendingTrailingSemicolon();
-        writer.decreaseIndent();
-      }
-    };
-  }
-  function hostUsesCaseSensitiveFileNames(host) {
-    return host.useCaseSensitiveFileNames ? host.useCaseSensitiveFileNames() : false;
-  }
-  function hostGetCanonicalFileName(host) {
-    return createGetCanonicalFileName(hostUsesCaseSensitiveFileNames(host));
-  }
-  function getResolvedExternalModuleName(host, file, referenceFile) {
-    return file.moduleName || getExternalModuleNameFromPath(host, file.fileName, referenceFile && referenceFile.fileName);
-  }
-  function getCanonicalAbsolutePath(host, path) {
-    return host.getCanonicalFileName(getNormalizedAbsolutePath(path, host.getCurrentDirectory()));
-  }
-  function getExternalModuleNameFromDeclaration(host, resolver, declaration) {
-    const file = resolver.getExternalModuleFileFromDeclaration(declaration);
-    if (!file || file.isDeclarationFile) {
-      return void 0;
-    }
-    const specifier = getExternalModuleName(declaration);
-    if (specifier && isStringLiteralLike(specifier) && !pathIsRelative(specifier.text) && getCanonicalAbsolutePath(host, file.path).indexOf(getCanonicalAbsolutePath(host, ensureTrailingDirectorySeparator(host.getCommonSourceDirectory()))) === -1) {
-      return void 0;
-    }
-    return getResolvedExternalModuleName(host, file);
-  }
-  function getExternalModuleNameFromPath(host, fileName, referencePath) {
-    const getCanonicalFileName = (f) => host.getCanonicalFileName(f);
-    const dir = toPath(referencePath ? getDirectoryPath(referencePath) : host.getCommonSourceDirectory(), host.getCurrentDirectory(), getCanonicalFileName);
-    const filePath = getNormalizedAbsolutePath(fileName, host.getCurrentDirectory());
-    const relativePath = getRelativePathToDirectoryOrUrl(
-      dir,
-      filePath,
-      dir,
-      getCanonicalFileName,
-      /*isAbsolutePathAnUrl*/
-      false
-    );
-    const extensionless = removeFileExtension(relativePath);
-    return referencePath ? ensurePathIsNonModuleName(extensionless) : extensionless;
-  }
-  function getOwnEmitOutputFilePath(fileName, host, extension) {
-    const compilerOptions = host.getCompilerOptions();
-    let emitOutputFilePathWithoutExtension;
-    if (compilerOptions.outDir) {
-      emitOutputFilePathWithoutExtension = removeFileExtension(getSourceFilePathInNewDir(fileName, host, compilerOptions.outDir));
-    } else {
-      emitOutputFilePathWithoutExtension = removeFileExtension(fileName);
-    }
-    return emitOutputFilePathWithoutExtension + extension;
-  }
-  function getDeclarationEmitOutputFilePath(fileName, host) {
-    return getDeclarationEmitOutputFilePathWorker(fileName, host.getCompilerOptions(), host.getCurrentDirectory(), host.getCommonSourceDirectory(), (f) => host.getCanonicalFileName(f));
-  }
-  function getDeclarationEmitOutputFilePathWorker(fileName, options, currentDirectory, commonSourceDirectory, getCanonicalFileName) {
-    const outputDir = options.declarationDir || options.outDir;
-    const path = outputDir ? getSourceFilePathInNewDirWorker(fileName, outputDir, currentDirectory, commonSourceDirectory, getCanonicalFileName) : fileName;
-    const declarationExtension = getDeclarationEmitExtensionForPath(path);
-    return removeFileExtension(path) + declarationExtension;
-  }
-  function getDeclarationEmitExtensionForPath(path) {
-    return fileExtensionIsOneOf(path, [".mjs" /* Mjs */, ".mts" /* Mts */]) ? ".d.mts" /* Dmts */ : fileExtensionIsOneOf(path, [".cjs" /* Cjs */, ".cts" /* Cts */]) ? ".d.cts" /* Dcts */ : fileExtensionIsOneOf(path, [".json" /* Json */]) ? `.d.json.ts` : (
-      // Drive-by redefinition of json declaration file output name so if it's ever enabled, it behaves well
-      ".d.ts" /* Dts */
-    );
-  }
-  function getPossibleOriginalInputExtensionForExtension(path) {
-    return fileExtensionIsOneOf(path, [".d.mts" /* Dmts */, ".mjs" /* Mjs */, ".mts" /* Mts */]) ? [".mts" /* Mts */, ".mjs" /* Mjs */] : fileExtensionIsOneOf(path, [".d.cts" /* Dcts */, ".cjs" /* Cjs */, ".cts" /* Cts */]) ? [".cts" /* Cts */, ".cjs" /* Cjs */] : fileExtensionIsOneOf(path, [`.d.json.ts`]) ? [".json" /* Json */] : [".tsx" /* Tsx */, ".ts" /* Ts */, ".jsx" /* Jsx */, ".js" /* Js */];
-  }
-  function outFile(options) {
-    return options.outFile || options.out;
-  }
-  function getPathsBasePath(options, host) {
-    var _a;
-    if (!options.paths)
-      return void 0;
-    return options.baseUrl ?? Debug.checkDefined(options.pathsBasePath || ((_a = host.getCurrentDirectory) == null ? void 0 : _a.call(host)), "Encountered 'paths' without a 'baseUrl', config file, or host 'getCurrentDirectory'.");
-  }
-  function getSourceFilesToEmit(host, targetSourceFile, forceDtsEmit) {
-    const options = host.getCompilerOptions();
-    if (outFile(options)) {
-      const moduleKind = getEmitModuleKind(options);
-      const moduleEmitEnabled = options.emitDeclarationOnly || moduleKind === 2 /* AMD */ || moduleKind === 4 /* System */;
-      return filter(
-        host.getSourceFiles(),
-        (sourceFile) => (moduleEmitEnabled || !isExternalModule(sourceFile)) && sourceFileMayBeEmitted(sourceFile, host, forceDtsEmit)
-      );
-    } else {
-      const sourceFiles = targetSourceFile === void 0 ? host.getSourceFiles() : [targetSourceFile];
-      return filter(
-        sourceFiles,
-        (sourceFile) => sourceFileMayBeEmitted(sourceFile, host, forceDtsEmit)
-      );
-    }
-  }
-  function sourceFileMayBeEmitted(sourceFile, host, forceDtsEmit) {
-    const options = host.getCompilerOptions();
-    return !(options.noEmitForJsFiles && isSourceFileJS(sourceFile)) && !sourceFile.isDeclarationFile && !host.isSourceFileFromExternalLibrary(sourceFile) && (forceDtsEmit || !(isJsonSourceFile(sourceFile) && host.getResolvedProjectReferenceToRedirect(sourceFile.fileName)) && !host.isSourceOfProjectReferenceRedirect(sourceFile.fileName));
-  }
-  function getSourceFilePathInNewDir(fileName, host, newDirPath) {
-    return getSourceFilePathInNewDirWorker(fileName, newDirPath, host.getCurrentDirectory(), host.getCommonSourceDirectory(), (f) => host.getCanonicalFileName(f));
-  }
-  function getSourceFilePathInNewDirWorker(fileName, newDirPath, currentDirectory, commonSourceDirectory, getCanonicalFileName) {
-    let sourceFilePath = getNormalizedAbsolutePath(fileName, currentDirectory);
-    const isSourceFileInCommonSourceDirectory = getCanonicalFileName(sourceFilePath).indexOf(getCanonicalFileName(commonSourceDirectory)) === 0;
-    sourceFilePath = isSourceFileInCommonSourceDirectory ? sourceFilePath.substring(commonSourceDirectory.length) : sourceFilePath;
-    return combinePaths(newDirPath, sourceFilePath);
-  }
-  function writeFile(host, diagnostics, fileName, text, writeByteOrderMark, sourceFiles, data) {
-    host.writeFile(fileName, text, writeByteOrderMark, (hostErrorMessage) => {
-      diagnostics.add(createCompilerDiagnostic(Diagnostics.Could_not_write_file_0_Colon_1, fileName, hostErrorMessage));
-    }, sourceFiles, data);
-  }
-  function ensureDirectoriesExist(directoryPath, createDirectory, directoryExists) {
-    if (directoryPath.length > getRootLength(directoryPath) && !directoryExists(directoryPath)) {
-      const parentDirectory = getDirectoryPath(directoryPath);
-      ensureDirectoriesExist(parentDirectory, createDirectory, directoryExists);
-      createDirectory(directoryPath);
-    }
-  }
-  function writeFileEnsuringDirectories(path, data, writeByteOrderMark, writeFile2, createDirectory, directoryExists) {
-    try {
-      writeFile2(path, data, writeByteOrderMark);
-    } catch {
-      ensureDirectoriesExist(getDirectoryPath(normalizePath(path)), createDirectory, directoryExists);
-      writeFile2(path, data, writeByteOrderMark);
-    }
-  }
-  function getLineOfLocalPosition(sourceFile, pos) {
-    const lineStarts = getLineStarts(sourceFile);
-    return computeLineOfPosition(lineStarts, pos);
-  }
-  function getLineOfLocalPositionFromLineMap(lineMap, pos) {
-    return computeLineOfPosition(lineMap, pos);
-  }
-  function getFirstConstructorWithBody(node) {
-    return find(node.members, (member) => isConstructorDeclaration(member) && nodeIsPresent(member.body));
-  }
-  function getSetAccessorValueParameter(accessor) {
-    if (accessor && accessor.parameters.length > 0) {
-      const hasThis = accessor.parameters.length === 2 && parameterIsThisKeyword(accessor.parameters[0]);
-      return accessor.parameters[hasThis ? 1 : 0];
-    }
-  }
-  function getSetAccessorTypeAnnotationNode(accessor) {
-    const parameter = getSetAccessorValueParameter(accessor);
-    return parameter && parameter.type;
-  }
-  function getThisParameter(signature) {
-    if (signature.parameters.length && !isJSDocSignature(signature)) {
-      const thisParameter = signature.parameters[0];
-      if (parameterIsThisKeyword(thisParameter)) {
-        return thisParameter;
-      }
-    }
-  }
-  function parameterIsThisKeyword(parameter) {
-    return isThisIdentifier(parameter.name);
-  }
-  function isThisIdentifier(node) {
-    return !!node && node.kind === 80 /* Identifier */ && identifierIsThisKeyword(node);
-  }
-  function isThisInTypeQuery(node) {
-    if (!isThisIdentifier(node)) {
-      return false;
-    }
-    while (isQualifiedName(node.parent) && node.parent.left === node) {
-      node = node.parent;
-    }
-    return node.parent.kind === 185 /* TypeQuery */;
-  }
-  function identifierIsThisKeyword(id) {
-    return id.escapedText === "this";
-  }
-  function getAllAccessorDeclarations(declarations, accessor) {
-    let firstAccessor;
-    let secondAccessor;
-    let getAccessor;
-    let setAccessor;
-    if (hasDynamicName(accessor)) {
-      firstAccessor = accessor;
-      if (accessor.kind === 176 /* GetAccessor */) {
-        getAccessor = accessor;
-      } else if (accessor.kind === 177 /* SetAccessor */) {
-        setAccessor = accessor;
-      } else {
-        Debug.fail("Accessor has wrong kind");
-      }
-    } else {
-      forEach(declarations, (member) => {
-        if (isAccessor(member) && isStatic(member) === isStatic(accessor)) {
-          const memberName = getPropertyNameForPropertyNameNode(member.name);
-          const accessorName = getPropertyNameForPropertyNameNode(accessor.name);
-          if (memberName === accessorName) {
-            if (!firstAccessor) {
-              firstAccessor = member;
-            } else if (!secondAccessor) {
-              secondAccessor = member;
-            }
-            if (member.kind === 176 /* GetAccessor */ && !getAccessor) {
-              getAccessor = member;
-            }
-            if (member.kind === 177 /* SetAccessor */ && !setAccessor) {
-              setAccessor = member;
-            }
-          }
-        }
-      });
-    }
-    return {
-      firstAccessor,
-      secondAccessor,
-      getAccessor,
-      setAccessor
-    };
-  }
-  function getEffectiveTypeAnnotationNode(node) {
-    if (!isInJSFile(node) && isFunctionDeclaration(node))
-      return void 0;
-    const type = node.type;
-    if (type || !isInJSFile(node))
-      return type;
-    return isJSDocPropertyLikeTag(node) ? node.typeExpression && node.typeExpression.type : getJSDocType(node);
-  }
-  function getTypeAnnotationNode(node) {
-    return node.type;
-  }
-  function getEffectiveReturnTypeNode(node) {
-    return isJSDocSignature(node) ? node.type && node.type.typeExpression && node.type.typeExpression.type : node.type || (isInJSFile(node) ? getJSDocReturnType(node) : void 0);
-  }
-  function getJSDocTypeParameterDeclarations(node) {
-    return flatMap(getJSDocTags(node), (tag) => isNonTypeAliasTemplate(tag) ? tag.typeParameters : void 0);
-  }
-  function isNonTypeAliasTemplate(tag) {
-    return isJSDocTemplateTag(tag) && !(tag.parent.kind === 326 /* JSDoc */ && (tag.parent.tags.some(isJSDocTypeAlias) || tag.parent.tags.some(isJSDocOverloadTag)));
-  }
-  function getEffectiveSetAccessorTypeAnnotationNode(node) {
-    const parameter = getSetAccessorValueParameter(node);
-    return parameter && getEffectiveTypeAnnotationNode(parameter);
-  }
-  function emitNewLineBeforeLeadingComments(lineMap, writer, node, leadingComments) {
-    emitNewLineBeforeLeadingCommentsOfPosition(lineMap, writer, node.pos, leadingComments);
-  }
-  function emitNewLineBeforeLeadingCommentsOfPosition(lineMap, writer, pos, leadingComments) {
-    if (leadingComments && leadingComments.length && pos !== leadingComments[0].pos && getLineOfLocalPositionFromLineMap(lineMap, pos) !== getLineOfLocalPositionFromLineMap(lineMap, leadingComments[0].pos)) {
-      writer.writeLine();
-    }
-  }
-  function emitNewLineBeforeLeadingCommentOfPosition(lineMap, writer, pos, commentPos) {
-    if (pos !== commentPos && getLineOfLocalPositionFromLineMap(lineMap, pos) !== getLineOfLocalPositionFromLineMap(lineMap, commentPos)) {
-      writer.writeLine();
-    }
-  }
-  function emitComments(text, lineMap, writer, comments, leadingSeparator, trailingSeparator, newLine, writeComment) {
-    if (comments && comments.length > 0) {
-      if (leadingSeparator) {
-        writer.writeSpace(" ");
-      }
-      let emitInterveningSeparator = false;
-      for (const comment of comments) {
-        if (emitInterveningSeparator) {
-          writer.writeSpace(" ");
-          emitInterveningSeparator = false;
-        }
-        writeComment(text, lineMap, writer, comment.pos, comment.end, newLine);
-        if (comment.hasTrailingNewLine) {
-          writer.writeLine();
-        } else {
-          emitInterveningSeparator = true;
-        }
-      }
-      if (emitInterveningSeparator && trailingSeparator) {
-        writer.writeSpace(" ");
-      }
-    }
-  }
-  function emitDetachedComments(text, lineMap, writer, writeComment, node, newLine, removeComments) {
-    let leadingComments;
-    let currentDetachedCommentInfo;
-    if (removeComments) {
-      if (node.pos === 0) {
-        leadingComments = filter(getLeadingCommentRanges(text, node.pos), isPinnedCommentLocal);
-      }
-    } else {
-      leadingComments = getLeadingCommentRanges(text, node.pos);
-    }
-    if (leadingComments) {
-      const detachedComments = [];
-      let lastComment;
-      for (const comment of leadingComments) {
-        if (lastComment) {
-          const lastCommentLine = getLineOfLocalPositionFromLineMap(lineMap, lastComment.end);
-          const commentLine = getLineOfLocalPositionFromLineMap(lineMap, comment.pos);
-          if (commentLine >= lastCommentLine + 2) {
-            break;
-          }
-        }
-        detachedComments.push(comment);
-        lastComment = comment;
-      }
-      if (detachedComments.length) {
-        const lastCommentLine = getLineOfLocalPositionFromLineMap(lineMap, last(detachedComments).end);
-        const nodeLine = getLineOfLocalPositionFromLineMap(lineMap, skipTrivia(text, node.pos));
-        if (nodeLine >= lastCommentLine + 2) {
-          emitNewLineBeforeLeadingComments(lineMap, writer, node, leadingComments);
-          emitComments(
-            text,
-            lineMap,
-            writer,
-            detachedComments,
-            /*leadingSeparator*/
-            false,
-            /*trailingSeparator*/
-            true,
-            newLine,
-            writeComment
-          );
-          currentDetachedCommentInfo = { nodePos: node.pos, detachedCommentEndPos: last(detachedComments).end };
-        }
-      }
-    }
-    return currentDetachedCommentInfo;
-    function isPinnedCommentLocal(comment) {
-      return isPinnedComment(text, comment.pos);
-    }
-  }
-  function writeCommentRange(text, lineMap, writer, commentPos, commentEnd, newLine) {
-    if (text.charCodeAt(commentPos + 1) === 42 /* asterisk */) {
-      const firstCommentLineAndCharacter = computeLineAndCharacterOfPosition(lineMap, commentPos);
-      const lineCount = lineMap.length;
-      let firstCommentLineIndent;
-      for (let pos = commentPos, currentLine = firstCommentLineAndCharacter.line; pos < commentEnd; currentLine++) {
-        const nextLineStart = currentLine + 1 === lineCount ? text.length + 1 : lineMap[currentLine + 1];
-        if (pos !== commentPos) {
-          if (firstCommentLineIndent === void 0) {
-            firstCommentLineIndent = calculateIndent(text, lineMap[firstCommentLineAndCharacter.line], commentPos);
-          }
-          const currentWriterIndentSpacing = writer.getIndent() * getIndentSize();
-          const spacesToEmit = currentWriterIndentSpacing - firstCommentLineIndent + calculateIndent(text, pos, nextLineStart);
-          if (spacesToEmit > 0) {
-            let numberOfSingleSpacesToEmit = spacesToEmit % getIndentSize();
-            const indentSizeSpaceString = getIndentString((spacesToEmit - numberOfSingleSpacesToEmit) / getIndentSize());
-            writer.rawWrite(indentSizeSpaceString);
-            while (numberOfSingleSpacesToEmit) {
-              writer.rawWrite(" ");
-              numberOfSingleSpacesToEmit--;
-            }
-          } else {
-            writer.rawWrite("");
-          }
-        }
-        writeTrimmedCurrentLine(text, commentEnd, writer, newLine, pos, nextLineStart);
-        pos = nextLineStart;
-      }
-    } else {
-      writer.writeComment(text.substring(commentPos, commentEnd));
-    }
-  }
-  function writeTrimmedCurrentLine(text, commentEnd, writer, newLine, pos, nextLineStart) {
-    const end = Math.min(commentEnd, nextLineStart - 1);
-    const currentLineText = trimString(text.substring(pos, end));
-    if (currentLineText) {
-      writer.writeComment(currentLineText);
-      if (end !== commentEnd) {
-        writer.writeLine();
-      }
-    } else {
-      writer.rawWrite(newLine);
-    }
-  }
-  function calculateIndent(text, pos, end) {
-    let currentLineIndent = 0;
-    for (; pos < end && isWhiteSpaceSingleLine(text.charCodeAt(pos)); pos++) {
-      if (text.charCodeAt(pos) === 9 /* tab */) {
-        currentLineIndent += getIndentSize() - currentLineIndent % getIndentSize();
-      } else {
-        currentLineIndent++;
-      }
-    }
-    return currentLineIndent;
-  }
-  function hasEffectiveModifiers(node) {
-    return getEffectiveModifierFlags(node) !== 0 /* None */;
-  }
-  function hasSyntacticModifiers(node) {
-    return getSyntacticModifierFlags(node) !== 0 /* None */;
-  }
-  function hasEffectiveModifier(node, flags) {
-    return !!getSelectedEffectiveModifierFlags(node, flags);
-  }
-  function hasSyntacticModifier(node, flags) {
-    return !!getSelectedSyntacticModifierFlags(node, flags);
-  }
-  function isStatic(node) {
-    return isClassElement(node) && hasStaticModifier(node) || isClassStaticBlockDeclaration(node);
-  }
-  function hasStaticModifier(node) {
-    return hasSyntacticModifier(node, 32 /* Static */);
-  }
-  function hasOverrideModifier(node) {
-    return hasEffectiveModifier(node, 16384 /* Override */);
-  }
-  function hasAbstractModifier(node) {
-    return hasSyntacticModifier(node, 256 /* Abstract */);
-  }
-  function hasAmbientModifier(node) {
-    return hasSyntacticModifier(node, 2 /* Ambient */);
-  }
-  function hasAccessorModifier(node) {
-    return hasSyntacticModifier(node, 128 /* Accessor */);
-  }
-  function hasEffectiveReadonlyModifier(node) {
-    return hasEffectiveModifier(node, 64 /* Readonly */);
-  }
-  function hasDecorators(node) {
-    return hasSyntacticModifier(node, 131072 /* Decorator */);
-  }
-  function getSelectedEffectiveModifierFlags(node, flags) {
-    return getEffectiveModifierFlags(node) & flags;
-  }
-  function getSelectedSyntacticModifierFlags(node, flags) {
-    return getSyntacticModifierFlags(node) & flags;
-  }
-  function getModifierFlagsWorker(node, includeJSDoc, alwaysIncludeJSDoc) {
-    if (node.kind >= 0 /* FirstToken */ && node.kind <= 164 /* LastToken */) {
-      return 0 /* None */;
-    }
-    if (!(node.modifierFlagsCache & 536870912 /* HasComputedFlags */)) {
-      node.modifierFlagsCache = getSyntacticModifierFlagsNoCache(node) | 536870912 /* HasComputedFlags */;
-    }
-    if (includeJSDoc && !(node.modifierFlagsCache & 4096 /* HasComputedJSDocModifiers */) && (alwaysIncludeJSDoc || isInJSFile(node)) && node.parent) {
-      node.modifierFlagsCache |= getJSDocModifierFlagsNoCache(node) | 4096 /* HasComputedJSDocModifiers */;
-    }
-    return node.modifierFlagsCache & ~(536870912 /* HasComputedFlags */ | 4096 /* HasComputedJSDocModifiers */);
-  }
-  function getEffectiveModifierFlags(node) {
-    return getModifierFlagsWorker(
-      node,
-      /*includeJSDoc*/
-      true
-    );
-  }
-  function getEffectiveModifierFlagsAlwaysIncludeJSDoc(node) {
-    return getModifierFlagsWorker(
-      node,
-      /*includeJSDoc*/
-      true,
-      /*alwaysIncludeJSDoc*/
-      true
-    );
-  }
-  function getSyntacticModifierFlags(node) {
-    return getModifierFlagsWorker(
-      node,
-      /*includeJSDoc*/
-      false
-    );
-  }
-  function getJSDocModifierFlagsNoCache(node) {
-    let flags = 0 /* None */;
-    if (!!node.parent && !isParameter(node)) {
-      if (isInJSFile(node)) {
-        if (getJSDocPublicTagNoCache(node))
-          flags |= 4 /* Public */;
-        if (getJSDocPrivateTagNoCache(node))
-          flags |= 8 /* Private */;
-        if (getJSDocProtectedTagNoCache(node))
-          flags |= 16 /* Protected */;
-        if (getJSDocReadonlyTagNoCache(node))
-          flags |= 64 /* Readonly */;
-        if (getJSDocOverrideTagNoCache(node))
-          flags |= 16384 /* Override */;
-      }
-      if (getJSDocDeprecatedTagNoCache(node))
-        flags |= 8192 /* Deprecated */;
-    }
-    return flags;
-  }
-  function getEffectiveModifierFlagsNoCache(node) {
-    return getSyntacticModifierFlagsNoCache(node) | getJSDocModifierFlagsNoCache(node);
-  }
-  function getSyntacticModifierFlagsNoCache(node) {
-    let flags = canHaveModifiers(node) ? modifiersToFlags(node.modifiers) : 0 /* None */;
-    if (node.flags & 4 /* NestedNamespace */ || node.kind === 80 /* Identifier */ && node.flags & 2048 /* IdentifierIsInJSDocNamespace */) {
-      flags |= 1 /* Export */;
-    }
-    return flags;
-  }
-  function modifiersToFlags(modifiers) {
-    let flags = 0 /* None */;
-    if (modifiers) {
-      for (const modifier of modifiers) {
-        flags |= modifierToFlag(modifier.kind);
-      }
-    }
-    return flags;
-  }
-  function modifierToFlag(token) {
-    switch (token) {
-      case 126 /* StaticKeyword */:
-        return 32 /* Static */;
-      case 125 /* PublicKeyword */:
-        return 4 /* Public */;
-      case 124 /* ProtectedKeyword */:
-        return 16 /* Protected */;
-      case 123 /* PrivateKeyword */:
-        return 8 /* Private */;
-      case 128 /* AbstractKeyword */:
-        return 256 /* Abstract */;
-      case 129 /* AccessorKeyword */:
-        return 128 /* Accessor */;
-      case 95 /* ExportKeyword */:
-        return 1 /* Export */;
-      case 138 /* DeclareKeyword */:
-        return 2 /* Ambient */;
-      case 87 /* ConstKeyword */:
-        return 2048 /* Const */;
-      case 90 /* DefaultKeyword */:
-        return 1024 /* Default */;
-      case 134 /* AsyncKeyword */:
-        return 512 /* Async */;
-      case 148 /* ReadonlyKeyword */:
-        return 64 /* Readonly */;
-      case 163 /* OverrideKeyword */:
-        return 16384 /* Override */;
-      case 103 /* InKeyword */:
-        return 32768 /* In */;
-      case 147 /* OutKeyword */:
-        return 65536 /* Out */;
-      case 169 /* Decorator */:
-        return 131072 /* Decorator */;
-    }
-    return 0 /* None */;
-  }
-  function isBinaryLogicalOperator(token) {
-    return token === 57 /* BarBarToken */ || token === 56 /* AmpersandAmpersandToken */;
-  }
-  function isLogicalOperator(token) {
-    return isBinaryLogicalOperator(token) || token === 54 /* ExclamationToken */;
-  }
-  function isLogicalOrCoalescingAssignmentOperator(token) {
-    return token === 76 /* BarBarEqualsToken */ || token === 77 /* AmpersandAmpersandEqualsToken */ || token === 78 /* QuestionQuestionEqualsToken */;
-  }
-  function isLogicalOrCoalescingAssignmentExpression(expr) {
-    return isBinaryExpression(expr) && isLogicalOrCoalescingAssignmentOperator(expr.operatorToken.kind);
-  }
-  function isLogicalOrCoalescingBinaryOperator(token) {
-    return isBinaryLogicalOperator(token) || token === 61 /* QuestionQuestionToken */;
-  }
-  function isLogicalOrCoalescingBinaryExpression(expr) {
-    return isBinaryExpression(expr) && isLogicalOrCoalescingBinaryOperator(expr.operatorToken.kind);
-  }
-  function isAssignmentOperator(token) {
-    return token >= 64 /* FirstAssignment */ && token <= 79 /* LastAssignment */;
-  }
-  function tryGetClassExtendingExpressionWithTypeArguments(node) {
-    const cls = tryGetClassImplementingOrExtendingExpressionWithTypeArguments(node);
-    return cls && !cls.isImplements ? cls.class : void 0;
-  }
-  function tryGetClassImplementingOrExtendingExpressionWithTypeArguments(node) {
-    if (isExpressionWithTypeArguments(node)) {
-      if (isHeritageClause(node.parent) && isClassLike(node.parent.parent)) {
-        return { class: node.parent.parent, isImplements: node.parent.token === 119 /* ImplementsKeyword */ };
-      }
-      if (isJSDocAugmentsTag(node.parent)) {
-        const host = getEffectiveJSDocHost(node.parent);
-        if (host && isClassLike(host)) {
-          return { class: host, isImplements: false };
-        }
-      }
-    }
-    return void 0;
-  }
-  function isAssignmentExpression(node, excludeCompoundAssignment) {
-    return isBinaryExpression(node) && (excludeCompoundAssignment ? node.operatorToken.kind === 64 /* EqualsToken */ : isAssignmentOperator(node.operatorToken.kind)) && isLeftHandSideExpression(node.left);
-  }
-  function isLeftHandSideOfAssignment(node) {
-    return isAssignmentExpression(node.parent) && node.parent.left === node;
-  }
-  function isDestructuringAssignment(node) {
-    if (isAssignmentExpression(
-      node,
-      /*excludeCompoundAssignment*/
-      true
-    )) {
-      const kind = node.left.kind;
-      return kind === 209 /* ObjectLiteralExpression */ || kind === 208 /* ArrayLiteralExpression */;
-    }
-    return false;
-  }
-  function isExpressionWithTypeArgumentsInClassExtendsClause(node) {
-    return tryGetClassExtendingExpressionWithTypeArguments(node) !== void 0;
-  }
-  function isEntityNameExpression(node) {
-    return node.kind === 80 /* Identifier */ || isPropertyAccessEntityNameExpression(node);
-  }
-  function getFirstIdentifier(node) {
-    switch (node.kind) {
-      case 80 /* Identifier */:
-        return node;
-      case 165 /* QualifiedName */:
-        do {
-          node = node.left;
-        } while (node.kind !== 80 /* Identifier */);
-        return node;
-      case 210 /* PropertyAccessExpression */:
-        do {
-          node = node.expression;
-        } while (node.kind !== 80 /* Identifier */);
-        return node;
-    }
-  }
-  function isDottedName(node) {
-    return node.kind === 80 /* Identifier */ || node.kind === 110 /* ThisKeyword */ || node.kind === 108 /* SuperKeyword */ || node.kind === 235 /* MetaProperty */ || node.kind === 210 /* PropertyAccessExpression */ && isDottedName(node.expression) || node.kind === 216 /* ParenthesizedExpression */ && isDottedName(node.expression);
-  }
-  function isPropertyAccessEntityNameExpression(node) {
-    return isPropertyAccessExpression(node) && isIdentifier(node.name) && isEntityNameExpression(node.expression);
-  }
-  function tryGetPropertyAccessOrIdentifierToString(expr) {
-    if (isPropertyAccessExpression(expr)) {
-      const baseStr = tryGetPropertyAccessOrIdentifierToString(expr.expression);
-      if (baseStr !== void 0) {
-        return baseStr + "." + entityNameToString(expr.name);
-      }
-    } else if (isElementAccessExpression(expr)) {
-      const baseStr = tryGetPropertyAccessOrIdentifierToString(expr.expression);
-      if (baseStr !== void 0 && isPropertyName(expr.argumentExpression)) {
-        return baseStr + "." + getPropertyNameForPropertyNameNode(expr.argumentExpression);
-      }
-    } else if (isIdentifier(expr)) {
-      return unescapeLeadingUnderscores(expr.escapedText);
-    } else if (isJsxNamespacedName(expr)) {
-      return getTextOfJsxNamespacedName(expr);
-    }
-    return void 0;
-  }
-  function isPrototypeAccess(node) {
-    return isBindableStaticAccessExpression(node) && getElementOrPropertyAccessName(node) === "prototype";
-  }
-  function isRightSideOfQualifiedNameOrPropertyAccess(node) {
-    return node.parent.kind === 165 /* QualifiedName */ && node.parent.right === node || node.parent.kind === 210 /* PropertyAccessExpression */ && node.parent.name === node;
-  }
-  function isRightSideOfAccessExpression(node) {
-    return isPropertyAccessExpression(node.parent) && node.parent.name === node || isElementAccessExpression(node.parent) && node.parent.argumentExpression === node;
-  }
-  function isRightSideOfQualifiedNameOrPropertyAccessOrJSDocMemberName(node) {
-    return isQualifiedName(node.parent) && node.parent.right === node || isPropertyAccessExpression(node.parent) && node.parent.name === node || isJSDocMemberName(node.parent) && node.parent.right === node;
-  }
-  function isEmptyObjectLiteral(expression) {
-    return expression.kind === 209 /* ObjectLiteralExpression */ && expression.properties.length === 0;
-  }
-  function isEmptyArrayLiteral(expression) {
-    return expression.kind === 208 /* ArrayLiteralExpression */ && expression.elements.length === 0;
-  }
-  function getLocalSymbolForExportDefault(symbol) {
-    if (!isExportDefaultSymbol(symbol) || !symbol.declarations)
-      return void 0;
-    for (const decl of symbol.declarations) {
-      if (decl.localSymbol)
-        return decl.localSymbol;
-    }
-    return void 0;
-  }
-  function isExportDefaultSymbol(symbol) {
-    return symbol && length(symbol.declarations) > 0 && hasSyntacticModifier(symbol.declarations[0], 1024 /* Default */);
-  }
-  function tryExtractTSExtension(fileName) {
-    return find(supportedTSExtensionsForExtractExtension, (extension) => fileExtensionIs(fileName, extension));
-  }
-  function getExpandedCharCodes(input) {
-    const output = [];
-    const length2 = input.length;
-    for (let i = 0; i < length2; i++) {
-      const charCode = input.charCodeAt(i);
-      if (charCode < 128) {
-        output.push(charCode);
-      } else if (charCode < 2048) {
-        output.push(charCode >> 6 | 192);
-        output.push(charCode & 63 | 128);
-      } else if (charCode < 65536) {
-        output.push(charCode >> 12 | 224);
-        output.push(charCode >> 6 & 63 | 128);
-        output.push(charCode & 63 | 128);
-      } else if (charCode < 131072) {
-        output.push(charCode >> 18 | 240);
-        output.push(charCode >> 12 & 63 | 128);
-        output.push(charCode >> 6 & 63 | 128);
-        output.push(charCode & 63 | 128);
-      } else {
-        Debug.assert(false, "Unexpected code point");
-      }
-    }
-    return output;
-  }
-  function convertToBase64(input) {
-    let result = "";
-    const charCodes = getExpandedCharCodes(input);
-    let i = 0;
-    const length2 = charCodes.length;
-    let byte1, byte2, byte3, byte4;
-    while (i < length2) {
-      byte1 = charCodes[i] >> 2;
-      byte2 = (charCodes[i] & 3) << 4 | charCodes[i + 1] >> 4;
-      byte3 = (charCodes[i + 1] & 15) << 2 | charCodes[i + 2] >> 6;
-      byte4 = charCodes[i + 2] & 63;
-      if (i + 1 >= length2) {
-        byte3 = byte4 = 64;
-      } else if (i + 2 >= length2) {
-        byte4 = 64;
-      }
-      result += base64Digits.charAt(byte1) + base64Digits.charAt(byte2) + base64Digits.charAt(byte3) + base64Digits.charAt(byte4);
-      i += 3;
-    }
-    return result;
-  }
-  function getStringFromExpandedCharCodes(codes) {
-    let output = "";
-    let i = 0;
-    const length2 = codes.length;
-    while (i < length2) {
-      const charCode = codes[i];
-      if (charCode < 128) {
-        output += String.fromCharCode(charCode);
-        i++;
-      } else if ((charCode & 192) === 192) {
-        let value = charCode & 63;
-        i++;
-        let nextCode = codes[i];
-        while ((nextCode & 192) === 128) {
-          value = value << 6 | nextCode & 63;
-          i++;
-          nextCode = codes[i];
-        }
-        output += String.fromCharCode(value);
-      } else {
-        output += String.fromCharCode(charCode);
-        i++;
-      }
-    }
-    return output;
-  }
-  function base64encode(host, input) {
-    if (host && host.base64encode) {
-      return host.base64encode(input);
-    }
-    return convertToBase64(input);
-  }
-  function base64decode(host, input) {
-    if (host && host.base64decode) {
-      return host.base64decode(input);
-    }
-    const length2 = input.length;
-    const expandedCharCodes = [];
-    let i = 0;
-    while (i < length2) {
-      if (input.charCodeAt(i) === base64Digits.charCodeAt(64)) {
-        break;
-      }
-      const ch1 = base64Digits.indexOf(input[i]);
-      const ch2 = base64Digits.indexOf(input[i + 1]);
-      const ch3 = base64Digits.indexOf(input[i + 2]);
-      const ch4 = base64Digits.indexOf(input[i + 3]);
-      const code1 = (ch1 & 63) << 2 | ch2 >> 4 & 3;
-      const code2 = (ch2 & 15) << 4 | ch3 >> 2 & 15;
-      const code3 = (ch3 & 3) << 6 | ch4 & 63;
-      if (code2 === 0 && ch3 !== 0) {
-        expandedCharCodes.push(code1);
-      } else if (code3 === 0 && ch4 !== 0) {
-        expandedCharCodes.push(code1, code2);
-      } else {
-        expandedCharCodes.push(code1, code2, code3);
-      }
-      i += 4;
-    }
-    return getStringFromExpandedCharCodes(expandedCharCodes);
-  }
-  function readJsonOrUndefined(path, hostOrText) {
-    const jsonText = isString(hostOrText) ? hostOrText : hostOrText.readFile(path);
-    if (!jsonText)
-      return void 0;
-    const result = parseConfigFileTextToJson(path, jsonText);
-    return !result.error ? result.config : void 0;
-  }
-  function readJson(path, host) {
-    return readJsonOrUndefined(path, host) || {};
-  }
-  function directoryProbablyExists(directoryName, host) {
-    return !host.directoryExists || host.directoryExists(directoryName);
-  }
-  function getNewLineCharacter(options) {
-    switch (options.newLine) {
-      case 0 /* CarriageReturnLineFeed */:
-        return carriageReturnLineFeed;
-      case 1 /* LineFeed */:
-      case void 0:
-        return lineFeed;
-    }
-  }
-  function createRange(pos, end = pos) {
-    Debug.assert(end >= pos || end === -1);
-    return { pos, end };
-  }
-  function moveRangeEnd(range, end) {
-    return createRange(range.pos, end);
-  }
-  function moveRangePos(range, pos) {
-    return createRange(pos, range.end);
-  }
-  function moveRangePastDecorators(node) {
-    const lastDecorator = canHaveModifiers(node) ? findLast(node.modifiers, isDecorator) : void 0;
-    return lastDecorator && !positionIsSynthesized(lastDecorator.end) ? moveRangePos(node, lastDecorator.end) : node;
-  }
-  function moveRangePastModifiers(node) {
-    if (isPropertyDeclaration(node) || isMethodDeclaration(node)) {
-      return moveRangePos(node, node.name.pos);
-    }
-    const lastModifier = canHaveModifiers(node) ? lastOrUndefined(node.modifiers) : void 0;
-    return lastModifier && !positionIsSynthesized(lastModifier.end) ? moveRangePos(node, lastModifier.end) : moveRangePastDecorators(node);
-  }
-  function isCollapsedRange(range) {
-    return range.pos === range.end;
-  }
-  function createTokenRange(pos, token) {
-    return createRange(pos, pos + tokenToString(token).length);
-  }
-  function rangeIsOnSingleLine(range, sourceFile) {
-    return rangeStartIsOnSameLineAsRangeEnd(range, range, sourceFile);
-  }
-  function rangeStartPositionsAreOnSameLine(range1, range2, sourceFile) {
-    return positionsAreOnSameLine(
-      getStartPositionOfRange(
-        range1,
-        sourceFile,
-        /*includeComments*/
-        false
-      ),
-      getStartPositionOfRange(
-        range2,
-        sourceFile,
-        /*includeComments*/
-        false
-      ),
-      sourceFile
-    );
-  }
-  function rangeEndPositionsAreOnSameLine(range1, range2, sourceFile) {
-    return positionsAreOnSameLine(range1.end, range2.end, sourceFile);
-  }
-  function rangeStartIsOnSameLineAsRangeEnd(range1, range2, sourceFile) {
-    return positionsAreOnSameLine(getStartPositionOfRange(
-      range1,
-      sourceFile,
-      /*includeComments*/
-      false
-    ), range2.end, sourceFile);
-  }
-  function rangeEndIsOnSameLineAsRangeStart(range1, range2, sourceFile) {
-    return positionsAreOnSameLine(range1.end, getStartPositionOfRange(
-      range2,
-      sourceFile,
-      /*includeComments*/
-      false
-    ), sourceFile);
-  }
-  function getLinesBetweenRangeEndAndRangeStart(range1, range2, sourceFile, includeSecondRangeComments) {
-    const range2Start = getStartPositionOfRange(range2, sourceFile, includeSecondRangeComments);
-    return getLinesBetweenPositions(sourceFile, range1.end, range2Start);
-  }
-  function getLinesBetweenRangeEndPositions(range1, range2, sourceFile) {
-    return getLinesBetweenPositions(sourceFile, range1.end, range2.end);
-  }
-  function isNodeArrayMultiLine(list, sourceFile) {
-    return !positionsAreOnSameLine(list.pos, list.end, sourceFile);
-  }
-  function positionsAreOnSameLine(pos1, pos2, sourceFile) {
-    return getLinesBetweenPositions(sourceFile, pos1, pos2) === 0;
-  }
-  function getStartPositionOfRange(range, sourceFile, includeComments) {
-    return positionIsSynthesized(range.pos) ? -1 : skipTrivia(
-      sourceFile.text,
-      range.pos,
-      /*stopAfterLineBreak*/
-      false,
-      includeComments
-    );
-  }
-  function getLinesBetweenPositionAndPrecedingNonWhitespaceCharacter(pos, stopPos, sourceFile, includeComments) {
-    const startPos = skipTrivia(
-      sourceFile.text,
-      pos,
-      /*stopAfterLineBreak*/
-      false,
-      includeComments
-    );
-    const prevPos = getPreviousNonWhitespacePosition(startPos, stopPos, sourceFile);
-    return getLinesBetweenPositions(sourceFile, prevPos ?? stopPos, startPos);
-  }
-  function getLinesBetweenPositionAndNextNonWhitespaceCharacter(pos, stopPos, sourceFile, includeComments) {
-    const nextPos = skipTrivia(
-      sourceFile.text,
-      pos,
-      /*stopAfterLineBreak*/
-      false,
-      includeComments
-    );
-    return getLinesBetweenPositions(sourceFile, pos, Math.min(stopPos, nextPos));
-  }
-  function getPreviousNonWhitespacePosition(pos, stopPos = 0, sourceFile) {
-    while (pos-- > stopPos) {
-      if (!isWhiteSpaceLike(sourceFile.text.charCodeAt(pos))) {
-        return pos;
-      }
-    }
-  }
-  function isDeclarationNameOfEnumOrNamespace(node) {
-    const parseNode = getParseTreeNode(node);
-    if (parseNode) {
-      switch (parseNode.parent.kind) {
-        case 265 /* EnumDeclaration */:
-        case 266 /* ModuleDeclaration */:
-          return parseNode === parseNode.parent.name;
-      }
-    }
-    return false;
-  }
-  function getInitializedVariables(node) {
-    return filter(node.declarations, isInitializedVariable);
-  }
-  function isInitializedVariable(node) {
-    return isVariableDeclaration(node) && node.initializer !== void 0;
-  }
-  function isWatchSet(options) {
-    return options.watch && hasProperty(options, "watch");
-  }
-  function closeFileWatcher(watcher) {
-    watcher.close();
-  }
-  function getCheckFlags(symbol) {
-    return symbol.flags & 33554432 /* Transient */ ? symbol.links.checkFlags : 0;
-  }
-  function getDeclarationModifierFlagsFromSymbol(s, isWrite = false) {
-    if (s.valueDeclaration) {
-      const declaration = isWrite && s.declarations && find(s.declarations, isSetAccessorDeclaration) || s.flags & 32768 /* GetAccessor */ && find(s.declarations, isGetAccessorDeclaration) || s.valueDeclaration;
-      const flags = getCombinedModifierFlags(declaration);
-      return s.parent && s.parent.flags & 32 /* Class */ ? flags : flags & ~28 /* AccessibilityModifier */;
-    }
-    if (getCheckFlags(s) & 6 /* Synthetic */) {
-      const checkFlags = s.links.checkFlags;
-      const accessModifier = checkFlags & 1024 /* ContainsPrivate */ ? 8 /* Private */ : checkFlags & 256 /* ContainsPublic */ ? 4 /* Public */ : 16 /* Protected */;
-      const staticModifier = checkFlags & 2048 /* ContainsStatic */ ? 32 /* Static */ : 0;
-      return accessModifier | staticModifier;
-    }
-    if (s.flags & 4194304 /* Prototype */) {
-      return 4 /* Public */ | 32 /* Static */;
-    }
-    return 0;
-  }
-  function skipAlias(symbol, checker) {
-    return symbol.flags & 2097152 /* Alias */ ? checker.getAliasedSymbol(symbol) : symbol;
-  }
-  function getCombinedLocalAndExportSymbolFlags(symbol) {
-    return symbol.exportSymbol ? symbol.exportSymbol.flags | symbol.flags : symbol.flags;
-  }
-  function isWriteOnlyAccess(node) {
-    return accessKind(node) === 1 /* Write */;
-  }
-  function isWriteAccess(node) {
-    return accessKind(node) !== 0 /* Read */;
-  }
-  function accessKind(node) {
-    const { parent: parent2 } = node;
-    switch (parent2 == null ? void 0 : parent2.kind) {
-      case 216 /* ParenthesizedExpression */:
-        return accessKind(parent2);
-      case 224 /* PostfixUnaryExpression */:
-      case 223 /* PrefixUnaryExpression */:
-        const { operator } = parent2;
-        return operator === 46 /* PlusPlusToken */ || operator === 47 /* MinusMinusToken */ ? 2 /* ReadWrite */ : 0 /* Read */;
-      case 225 /* BinaryExpression */:
-        const { left, operatorToken } = parent2;
-        return left === node && isAssignmentOperator(operatorToken.kind) ? operatorToken.kind === 64 /* EqualsToken */ ? 1 /* Write */ : 2 /* ReadWrite */ : 0 /* Read */;
-      case 210 /* PropertyAccessExpression */:
-        return parent2.name !== node ? 0 /* Read */ : accessKind(parent2);
-      case 302 /* PropertyAssignment */: {
-        const parentAccess = accessKind(parent2.parent);
-        return node === parent2.name ? reverseAccessKind(parentAccess) : parentAccess;
-      }
-      case 303 /* ShorthandPropertyAssignment */:
-        return node === parent2.objectAssignmentInitializer ? 0 /* Read */ : accessKind(parent2.parent);
-      case 208 /* ArrayLiteralExpression */:
-        return accessKind(parent2);
-      default:
-        return 0 /* Read */;
-    }
-  }
-  function reverseAccessKind(a) {
-    switch (a) {
-      case 0 /* Read */:
-        return 1 /* Write */;
-      case 1 /* Write */:
-        return 0 /* Read */;
-      case 2 /* ReadWrite */:
-        return 2 /* ReadWrite */;
-      default:
-        return Debug.assertNever(a);
-    }
-  }
-  function compareDataObjects(dst, src) {
-    if (!dst || !src || Object.keys(dst).length !== Object.keys(src).length) {
-      return false;
-    }
-    for (const e in dst) {
-      if (typeof dst[e] === "object") {
-        if (!compareDataObjects(dst[e], src[e])) {
-          return false;
-        }
-      } else if (typeof dst[e] !== "function") {
-        if (dst[e] !== src[e]) {
-          return false;
-        }
-      }
-    }
-    return true;
-  }
-  function clearMap(map2, onDeleteValue) {
-    map2.forEach(onDeleteValue);
-    map2.clear();
-  }
-  function mutateMapSkippingNewValues(map2, newMap, options) {
-    const { onDeleteValue, onExistingValue } = options;
-    map2.forEach((existingValue, key) => {
-      const valueInNewMap = newMap.get(key);
-      if (valueInNewMap === void 0) {
-        map2.delete(key);
-        onDeleteValue(existingValue, key);
-      } else if (onExistingValue) {
-        onExistingValue(existingValue, valueInNewMap, key);
-      }
-    });
-  }
-  function mutateMap(map2, newMap, options) {
-    mutateMapSkippingNewValues(map2, newMap, options);
-    const { createNewValue } = options;
-    newMap.forEach((valueInNewMap, key) => {
-      if (!map2.has(key)) {
-        map2.set(key, createNewValue(key, valueInNewMap));
-      }
-    });
-  }
-  function isAbstractConstructorSymbol(symbol) {
-    if (symbol.flags & 32 /* Class */) {
-      const declaration = getClassLikeDeclarationOfSymbol(symbol);
-      return !!declaration && hasSyntacticModifier(declaration, 256 /* Abstract */);
-    }
-    return false;
-  }
-  function getClassLikeDeclarationOfSymbol(symbol) {
-    var _a;
-    return (_a = symbol.declarations) == null ? void 0 : _a.find(isClassLike);
-  }
-  function getObjectFlags(type) {
-    return type.flags & 138117121 /* ObjectFlagsType */ ? type.objectFlags : 0;
-  }
-  function forSomeAncestorDirectory(directory, callback) {
-    return !!forEachAncestorDirectory(directory, (d) => callback(d) ? true : void 0);
-  }
-  function isUMDExportSymbol(symbol) {
-    return !!symbol && !!symbol.declarations && !!symbol.declarations[0] && isNamespaceExportDeclaration(symbol.declarations[0]);
-  }
-  function showModuleSpecifier({ moduleSpecifier }) {
-    return isStringLiteral(moduleSpecifier) ? moduleSpecifier.text : getTextOfNode(moduleSpecifier);
-  }
-  function getLastChild(node) {
-    let lastChild;
-    forEachChild(
-      node,
-      (child) => {
-        if (nodeIsPresent(child))
-          lastChild = child;
-      },
-      (children) => {
-        for (let i = children.length - 1; i >= 0; i--) {
-          if (nodeIsPresent(children[i])) {
-            lastChild = children[i];
-            break;
-          }
-        }
-      }
-    );
-    return lastChild;
-  }
-  function addToSeen(seen, key, value = true) {
-    if (seen.has(key)) {
-      return false;
-    }
-    seen.set(key, value);
-    return true;
-  }
-  function isObjectTypeDeclaration(node) {
-    return isClassLike(node) || isInterfaceDeclaration(node) || isTypeLiteralNode(node);
-  }
-  function isTypeNodeKind(kind) {
-    return kind >= 181 /* FirstTypeNode */ && kind <= 204 /* LastTypeNode */ || kind === 133 /* AnyKeyword */ || kind === 159 /* UnknownKeyword */ || kind === 150 /* NumberKeyword */ || kind === 162 /* BigIntKeyword */ || kind === 151 /* ObjectKeyword */ || kind === 136 /* BooleanKeyword */ || kind === 154 /* StringKeyword */ || kind === 155 /* SymbolKeyword */ || kind === 116 /* VoidKeyword */ || kind === 157 /* UndefinedKeyword */ || kind === 146 /* NeverKeyword */ || kind === 141 /* IntrinsicKeyword */ || kind === 232 /* ExpressionWithTypeArguments */ || kind === 318 /* JSDocAllType */ || kind === 319 /* JSDocUnknownType */ || kind === 320 /* JSDocNullableType */ || kind === 321 /* JSDocNonNullableType */ || kind === 322 /* JSDocOptionalType */ || kind === 323 /* JSDocFunctionType */ || kind === 324 /* JSDocVariadicType */;
-  }
-  function isAccessExpression(node) {
-    return node.kind === 210 /* PropertyAccessExpression */ || node.kind === 211 /* ElementAccessExpression */;
-  }
-  function getNameOfAccessExpression(node) {
-    if (node.kind === 210 /* PropertyAccessExpression */) {
-      return node.name;
-    }
-    Debug.assert(node.kind === 211 /* ElementAccessExpression */);
-    return node.argumentExpression;
-  }
-  function isBundleFileTextLike(section) {
-    switch (section.kind) {
-      case "text" /* Text */:
-      case "internal" /* Internal */:
-        return true;
-      default:
-        return false;
-    }
-  }
-  function isNamedImportsOrExports(node) {
-    return node.kind === 274 /* NamedImports */ || node.kind === 278 /* NamedExports */;
-  }
-  function getLeftmostAccessExpression(expr) {
-    while (isAccessExpression(expr)) {
-      expr = expr.expression;
-    }
-    return expr;
-  }
-  function forEachNameInAccessChainWalkingLeft(name, action) {
-    if (isAccessExpression(name.parent) && isRightSideOfAccessExpression(name)) {
-      return walkAccessExpression(name.parent);
-    }
-    function walkAccessExpression(access) {
-      if (access.kind === 210 /* PropertyAccessExpression */) {
-        const res = action(access.name);
-        if (res !== void 0) {
-          return res;
-        }
-      } else if (access.kind === 211 /* ElementAccessExpression */) {
-        if (isIdentifier(access.argumentExpression) || isStringLiteralLike(access.argumentExpression)) {
-          const res = action(access.argumentExpression);
-          if (res !== void 0) {
-            return res;
-          }
-        } else {
-          return void 0;
-        }
-      }
-      if (isAccessExpression(access.expression)) {
-        return walkAccessExpression(access.expression);
-      }
-      if (isIdentifier(access.expression)) {
-        return action(access.expression);
-      }
-      return void 0;
-    }
-  }
-  function getLeftmostExpression(node, stopAtCallExpressions) {
-    while (true) {
-      switch (node.kind) {
-        case 224 /* PostfixUnaryExpression */:
-          node = node.operand;
-          continue;
-        case 225 /* BinaryExpression */:
-          node = node.left;
-          continue;
-        case 226 /* ConditionalExpression */:
-          node = node.condition;
-          continue;
-        case 214 /* TaggedTemplateExpression */:
-          node = node.tag;
-          continue;
-        case 212 /* CallExpression */:
-          if (stopAtCallExpressions) {
-            return node;
-          }
-        case 233 /* AsExpression */:
-        case 211 /* ElementAccessExpression */:
-        case 210 /* PropertyAccessExpression */:
-        case 234 /* NonNullExpression */:
-        case 359 /* PartiallyEmittedExpression */:
-        case 237 /* SatisfiesExpression */:
-          node = node.expression;
-          continue;
-      }
-      return node;
-    }
-  }
-  function Symbol4(flags, name) {
-    this.flags = flags;
-    this.escapedName = name;
-    this.declarations = void 0;
-    this.valueDeclaration = void 0;
-    this.id = 0;
-    this.mergeId = 0;
-    this.parent = void 0;
-    this.members = void 0;
-    this.exports = void 0;
-    this.exportSymbol = void 0;
-    this.constEnumOnlyModule = void 0;
-    this.isReferenced = void 0;
-    this.isAssigned = void 0;
-    this.links = void 0;
-  }
-  function Type3(checker, flags) {
-    this.flags = flags;
-    if (Debug.isDebugging || tracing) {
-      this.checker = checker;
-    }
-  }
-  function Signature2(checker, flags) {
-    this.flags = flags;
-    if (Debug.isDebugging) {
-      this.checker = checker;
-    }
-  }
-  function Node4(kind, pos, end) {
-    this.pos = pos;
-    this.end = end;
-    this.kind = kind;
-    this.id = 0;
-    this.flags = 0 /* None */;
-    this.modifierFlagsCache = 0 /* None */;
-    this.transformFlags = 0 /* None */;
-    this.parent = void 0;
-    this.original = void 0;
-    this.emitNode = void 0;
-  }
-  function Token(kind, pos, end) {
-    this.pos = pos;
-    this.end = end;
-    this.kind = kind;
-    this.id = 0;
-    this.flags = 0 /* None */;
-    this.transformFlags = 0 /* None */;
-    this.parent = void 0;
-    this.emitNode = void 0;
-  }
-  function Identifier2(kind, pos, end) {
-    this.pos = pos;
-    this.end = end;
-    this.kind = kind;
-    this.id = 0;
-    this.flags = 0 /* None */;
-    this.transformFlags = 0 /* None */;
-    this.parent = void 0;
-    this.original = void 0;
-    this.emitNode = void 0;
-  }
-  function SourceMapSource(fileName, text, skipTrivia2) {
-    this.fileName = fileName;
-    this.text = text;
-    this.skipTrivia = skipTrivia2 || ((pos) => pos);
-  }
-  function addObjectAllocatorPatcher(fn) {
-    objectAllocatorPatchers.push(fn);
-    fn(objectAllocator);
-  }
-  function setObjectAllocator(alloc) {
-    Object.assign(objectAllocator, alloc);
-    forEach(objectAllocatorPatchers, (fn) => fn(objectAllocator));
-  }
-  function formatStringFromArgs(text, args, baseIndex = 0) {
-    return text.replace(/{(\d+)}/g, (_match, index) => "" + Debug.checkDefined(args[+index + baseIndex]));
-  }
-  function setLocalizedDiagnosticMessages(messages) {
-    localizedDiagnosticMessages = messages;
-  }
-  function maybeSetLocalizedDiagnosticMessages(getMessages) {
-    if (!localizedDiagnosticMessages && getMessages) {
-      localizedDiagnosticMessages = getMessages();
-    }
-  }
-  function getLocaleSpecificMessage(message) {
-    return localizedDiagnosticMessages && localizedDiagnosticMessages[message.key] || message.message;
-  }
-  function createDetachedDiagnostic(fileName, start, length2, message) {
-    assertDiagnosticLocation(
-      /*file*/
-      void 0,
-      start,
-      length2
-    );
-    let text = getLocaleSpecificMessage(message);
-    if (arguments.length > 4) {
-      text = formatStringFromArgs(text, arguments, 4);
-    }
-    return {
-      file: void 0,
-      start,
-      length: length2,
-      messageText: text,
-      category: message.category,
-      code: message.code,
-      reportsUnnecessary: message.reportsUnnecessary,
-      fileName
-    };
-  }
-  function isDiagnosticWithDetachedLocation(diagnostic) {
-    return diagnostic.file === void 0 && diagnostic.start !== void 0 && diagnostic.length !== void 0 && typeof diagnostic.fileName === "string";
-  }
-  function attachFileToDiagnostic(diagnostic, file) {
-    const fileName = file.fileName || "";
-    const length2 = file.text.length;
-    Debug.assertEqual(diagnostic.fileName, fileName);
-    Debug.assertLessThanOrEqual(diagnostic.start, length2);
-    Debug.assertLessThanOrEqual(diagnostic.start + diagnostic.length, length2);
-    const diagnosticWithLocation = {
-      file,
-      start: diagnostic.start,
-      length: diagnostic.length,
-      messageText: diagnostic.messageText,
-      category: diagnostic.category,
-      code: diagnostic.code,
-      reportsUnnecessary: diagnostic.reportsUnnecessary
-    };
-    if (diagnostic.relatedInformation) {
-      diagnosticWithLocation.relatedInformation = [];
-      for (const related of diagnostic.relatedInformation) {
-        if (isDiagnosticWithDetachedLocation(related) && related.fileName === fileName) {
-          Debug.assertLessThanOrEqual(related.start, length2);
-          Debug.assertLessThanOrEqual(related.start + related.length, length2);
-          diagnosticWithLocation.relatedInformation.push(attachFileToDiagnostic(related, file));
-        } else {
-          diagnosticWithLocation.relatedInformation.push(related);
-        }
-      }
-    }
-    return diagnosticWithLocation;
-  }
-  function attachFileToDiagnostics(diagnostics, file) {
-    const diagnosticsWithLocation = [];
-    for (const diagnostic of diagnostics) {
-      diagnosticsWithLocation.push(attachFileToDiagnostic(diagnostic, file));
-    }
-    return diagnosticsWithLocation;
-  }
-  function createFileDiagnostic(file, start, length2, message) {
-    assertDiagnosticLocation(file, start, length2);
-    let text = getLocaleSpecificMessage(message);
-    if (arguments.length > 4) {
-      text = formatStringFromArgs(text, arguments, 4);
-    }
-    return {
-      file,
-      start,
-      length: length2,
-      messageText: text,
-      category: message.category,
-      code: message.code,
-      reportsUnnecessary: message.reportsUnnecessary,
-      reportsDeprecated: message.reportsDeprecated
-    };
-  }
-  function formatMessage(_dummy, message) {
-    let text = getLocaleSpecificMessage(message);
-    if (arguments.length > 2) {
-      text = formatStringFromArgs(text, arguments, 2);
-    }
-    return text;
-  }
-  function createCompilerDiagnostic(message) {
-    let text = getLocaleSpecificMessage(message);
-    if (arguments.length > 1) {
-      text = formatStringFromArgs(text, arguments, 1);
-    }
-    return {
-      file: void 0,
-      start: void 0,
-      length: void 0,
-      messageText: text,
-      category: message.category,
-      code: message.code,
-      reportsUnnecessary: message.reportsUnnecessary,
-      reportsDeprecated: message.reportsDeprecated
-    };
-  }
-  function createCompilerDiagnosticFromMessageChain(chain, relatedInformation) {
-    return {
-      file: void 0,
-      start: void 0,
-      length: void 0,
-      code: chain.code,
-      category: chain.category,
-      messageText: chain.next ? chain : chain.messageText,
-      relatedInformation
-    };
-  }
-  function chainDiagnosticMessages(details, message) {
-    let text = getLocaleSpecificMessage(message);
-    if (arguments.length > 2) {
-      text = formatStringFromArgs(text, arguments, 2);
-    }
-    return {
-      messageText: text,
-      category: message.category,
-      code: message.code,
-      next: details === void 0 || Array.isArray(details) ? details : [details]
-    };
-  }
-  function concatenateDiagnosticMessageChains(headChain, tailChain) {
-    let lastChain = headChain;
-    while (lastChain.next) {
-      lastChain = lastChain.next[0];
-    }
-    lastChain.next = [tailChain];
-  }
-  function getDiagnosticFilePath(diagnostic) {
-    return diagnostic.file ? diagnostic.file.path : void 0;
-  }
-  function compareDiagnostics(d1, d2) {
-    return compareDiagnosticsSkipRelatedInformation(d1, d2) || compareRelatedInformation(d1, d2) || 0 /* EqualTo */;
-  }
-  function compareDiagnosticsSkipRelatedInformation(d1, d2) {
-    return compareStringsCaseSensitive(getDiagnosticFilePath(d1), getDiagnosticFilePath(d2)) || compareValues(d1.start, d2.start) || compareValues(d1.length, d2.length) || compareValues(d1.code, d2.code) || compareMessageText(d1.messageText, d2.messageText) || 0 /* EqualTo */;
-  }
-  function compareRelatedInformation(d1, d2) {
-    if (!d1.relatedInformation && !d2.relatedInformation) {
-      return 0 /* EqualTo */;
-    }
-    if (d1.relatedInformation && d2.relatedInformation) {
-      return compareValues(d1.relatedInformation.length, d2.relatedInformation.length) || forEach(d1.relatedInformation, (d1i, index) => {
-        const d2i = d2.relatedInformation[index];
-        return compareDiagnostics(d1i, d2i);
-      }) || 0 /* EqualTo */;
-    }
-    return d1.relatedInformation ? -1 /* LessThan */ : 1 /* GreaterThan */;
-  }
-  function compareMessageText(t1, t2) {
-    if (typeof t1 === "string" && typeof t2 === "string") {
-      return compareStringsCaseSensitive(t1, t2);
-    } else if (typeof t1 === "string") {
-      return -1 /* LessThan */;
-    } else if (typeof t2 === "string") {
-      return 1 /* GreaterThan */;
-    }
-    let res = compareStringsCaseSensitive(t1.messageText, t2.messageText);
-    if (res) {
-      return res;
-    }
-    if (!t1.next && !t2.next) {
-      return 0 /* EqualTo */;
-    }
-    if (!t1.next) {
-      return -1 /* LessThan */;
-    }
-    if (!t2.next) {
-      return 1 /* GreaterThan */;
-    }
-    const len = Math.min(t1.next.length, t2.next.length);
-    for (let i = 0; i < len; i++) {
-      res = compareMessageText(t1.next[i], t2.next[i]);
-      if (res) {
-        return res;
-      }
-    }
-    if (t1.next.length < t2.next.length) {
-      return -1 /* LessThan */;
-    } else if (t1.next.length > t2.next.length) {
-      return 1 /* GreaterThan */;
-    }
-    return 0 /* EqualTo */;
-  }
-  function getLanguageVariant(scriptKind) {
-    return scriptKind === 4 /* TSX */ || scriptKind === 2 /* JSX */ || scriptKind === 1 /* JS */ || scriptKind === 6 /* JSON */ ? 1 /* JSX */ : 0 /* Standard */;
-  }
-  function walkTreeForJSXTags(node) {
-    if (!(node.transformFlags & 2 /* ContainsJsx */))
-      return void 0;
-    return isJsxOpeningLikeElement(node) || isJsxFragment(node) ? node : forEachChild(node, walkTreeForJSXTags);
-  }
-  function isFileModuleFromUsingJSXTag(file) {
-    return !file.isDeclarationFile ? walkTreeForJSXTags(file) : void 0;
-  }
-  function isFileForcedToBeModuleByFormat(file) {
-    return (file.impliedNodeFormat === 99 /* ESNext */ || fileExtensionIsOneOf(file.fileName, [".cjs" /* Cjs */, ".cts" /* Cts */, ".mjs" /* Mjs */, ".mts" /* Mts */])) && !file.isDeclarationFile ? true : void 0;
-  }
-  function getSetExternalModuleIndicator(options) {
-    switch (getEmitModuleDetectionKind(options)) {
-      case 3 /* Force */:
-        return (file) => {
-          file.externalModuleIndicator = isFileProbablyExternalModule(file) || !file.isDeclarationFile || void 0;
-        };
-      case 1 /* Legacy */:
-        return (file) => {
-          file.externalModuleIndicator = isFileProbablyExternalModule(file);
-        };
-      case 2 /* Auto */:
-        const checks = [isFileProbablyExternalModule];
-        if (options.jsx === 4 /* ReactJSX */ || options.jsx === 5 /* ReactJSXDev */) {
-          checks.push(isFileModuleFromUsingJSXTag);
-        }
-        checks.push(isFileForcedToBeModuleByFormat);
-        const combined = or(...checks);
-        const callback = (file) => void (file.externalModuleIndicator = combined(file));
-        return callback;
-    }
-  }
-  function getEmitScriptTarget(compilerOptions) {
-    return compilerOptions.target ?? (compilerOptions.module === 100 /* Node16 */ && 9 /* ES2022 */ || compilerOptions.module === 199 /* NodeNext */ && 99 /* ESNext */ || 1 /* ES5 */);
-  }
-  function getEmitModuleKind(compilerOptions) {
-    return typeof compilerOptions.module === "number" ? compilerOptions.module : getEmitScriptTarget(compilerOptions) >= 2 /* ES2015 */ ? 5 /* ES2015 */ : 1 /* CommonJS */;
-  }
-  function emitModuleKindIsNonNodeESM(moduleKind) {
-    return moduleKind >= 5 /* ES2015 */ && moduleKind <= 99 /* ESNext */;
-  }
-  function getEmitModuleResolutionKind(compilerOptions) {
-    let moduleResolution = compilerOptions.moduleResolution;
-    if (moduleResolution === void 0) {
-      switch (getEmitModuleKind(compilerOptions)) {
-        case 1 /* CommonJS */:
-          moduleResolution = 2 /* Node10 */;
-          break;
-        case 100 /* Node16 */:
-          moduleResolution = 3 /* Node16 */;
-          break;
-        case 199 /* NodeNext */:
-          moduleResolution = 99 /* NodeNext */;
-          break;
-        default:
-          moduleResolution = 1 /* Classic */;
-          break;
-      }
-    }
-    return moduleResolution;
-  }
-  function getEmitModuleDetectionKind(options) {
-    return options.moduleDetection || (getEmitModuleKind(options) === 100 /* Node16 */ || getEmitModuleKind(options) === 199 /* NodeNext */ ? 3 /* Force */ : 2 /* Auto */);
-  }
-  function hasJsonModuleEmitEnabled(options) {
-    switch (getEmitModuleKind(options)) {
-      case 1 /* CommonJS */:
-      case 2 /* AMD */:
-      case 5 /* ES2015 */:
-      case 6 /* ES2020 */:
-      case 7 /* ES2022 */:
-      case 99 /* ESNext */:
-      case 100 /* Node16 */:
-      case 199 /* NodeNext */:
-        return true;
-      default:
-        return false;
-    }
-  }
-  function getIsolatedModules(options) {
-    return !!(options.isolatedModules || options.verbatimModuleSyntax);
-  }
-  function importNameElisionDisabled(options) {
-    return options.verbatimModuleSyntax || options.isolatedModules && options.preserveValueImports;
-  }
-  function unreachableCodeIsError(options) {
-    return options.allowUnreachableCode === false;
-  }
-  function unusedLabelIsError(options) {
-    return options.allowUnusedLabels === false;
-  }
-  function getAreDeclarationMapsEnabled(options) {
-    return !!(getEmitDeclarations(options) && options.declarationMap);
-  }
-  function getESModuleInterop(compilerOptions) {
-    if (compilerOptions.esModuleInterop !== void 0) {
-      return compilerOptions.esModuleInterop;
-    }
-    switch (getEmitModuleKind(compilerOptions)) {
-      case 100 /* Node16 */:
-      case 199 /* NodeNext */:
-        return true;
-    }
-    return void 0;
-  }
-  function getAllowSyntheticDefaultImports(compilerOptions) {
-    if (compilerOptions.allowSyntheticDefaultImports !== void 0) {
-      return compilerOptions.allowSyntheticDefaultImports;
-    }
-    return getESModuleInterop(compilerOptions) || getEmitModuleKind(compilerOptions) === 4 /* System */ || getEmitModuleResolutionKind(compilerOptions) === 100 /* Bundler */;
-  }
-  function moduleResolutionSupportsPackageJsonExportsAndImports(moduleResolution) {
-    return moduleResolution >= 3 /* Node16 */ && moduleResolution <= 99 /* NodeNext */ || moduleResolution === 100 /* Bundler */;
-  }
-  function shouldResolveJsRequire(compilerOptions) {
-    return !!compilerOptions.noDtsResolution || getEmitModuleResolutionKind(compilerOptions) !== 100 /* Bundler */;
-  }
-  function getResolvePackageJsonExports(compilerOptions) {
-    const moduleResolution = getEmitModuleResolutionKind(compilerOptions);
-    if (!moduleResolutionSupportsPackageJsonExportsAndImports(moduleResolution)) {
-      return false;
-    }
-    if (compilerOptions.resolvePackageJsonExports !== void 0) {
-      return compilerOptions.resolvePackageJsonExports;
-    }
-    switch (moduleResolution) {
-      case 3 /* Node16 */:
-      case 99 /* NodeNext */:
-      case 100 /* Bundler */:
-        return true;
-    }
-    return false;
-  }
-  function getResolvePackageJsonImports(compilerOptions) {
-    const moduleResolution = getEmitModuleResolutionKind(compilerOptions);
-    if (!moduleResolutionSupportsPackageJsonExportsAndImports(moduleResolution)) {
-      return false;
-    }
-    if (compilerOptions.resolvePackageJsonExports !== void 0) {
-      return compilerOptions.resolvePackageJsonExports;
-    }
-    switch (moduleResolution) {
-      case 3 /* Node16 */:
-      case 99 /* NodeNext */:
-      case 100 /* Bundler */:
-        return true;
-    }
-    return false;
-  }
-  function getResolveJsonModule(compilerOptions) {
-    if (compilerOptions.resolveJsonModule !== void 0) {
-      return compilerOptions.resolveJsonModule;
-    }
-    return getEmitModuleResolutionKind(compilerOptions) === 100 /* Bundler */;
-  }
-  function getEmitDeclarations(compilerOptions) {
-    return !!(compilerOptions.declaration || compilerOptions.composite);
-  }
-  function shouldPreserveConstEnums(compilerOptions) {
-    return !!(compilerOptions.preserveConstEnums || getIsolatedModules(compilerOptions));
-  }
-  function isIncrementalCompilation(options) {
-    return !!(options.incremental || options.composite);
-  }
-  function getStrictOptionValue(compilerOptions, flag) {
-    return compilerOptions[flag] === void 0 ? !!compilerOptions.strict : !!compilerOptions[flag];
-  }
-  function getAllowJSCompilerOption(compilerOptions) {
-    return compilerOptions.allowJs === void 0 ? !!compilerOptions.checkJs : compilerOptions.allowJs;
-  }
-  function getUseDefineForClassFields(compilerOptions) {
-    return compilerOptions.useDefineForClassFields === void 0 ? getEmitScriptTarget(compilerOptions) >= 9 /* ES2022 */ : compilerOptions.useDefineForClassFields;
-  }
-  function compilerOptionsAffectSemanticDiagnostics(newOptions, oldOptions) {
-    return optionsHaveChanges(oldOptions, newOptions, semanticDiagnosticsOptionDeclarations);
-  }
-  function compilerOptionsAffectEmit(newOptions, oldOptions) {
-    return optionsHaveChanges(oldOptions, newOptions, affectsEmitOptionDeclarations);
-  }
-  function compilerOptionsAffectDeclarationPath(newOptions, oldOptions) {
-    return optionsHaveChanges(oldOptions, newOptions, affectsDeclarationPathOptionDeclarations);
-  }
-  function getCompilerOptionValue(options, option) {
-    return option.strictFlag ? getStrictOptionValue(options, option.name) : options[option.name];
-  }
-  function getJSXTransformEnabled(options) {
-    const jsx = options.jsx;
-    return jsx === 2 /* React */ || jsx === 4 /* ReactJSX */ || jsx === 5 /* ReactJSXDev */;
-  }
-  function getJSXImplicitImportBase(compilerOptions, file) {
-    const jsxImportSourcePragmas = file == null ? void 0 : file.pragmas.get("jsximportsource");
-    const jsxImportSourcePragma = isArray(jsxImportSourcePragmas) ? jsxImportSourcePragmas[jsxImportSourcePragmas.length - 1] : jsxImportSourcePragmas;
-    return compilerOptions.jsx === 4 /* ReactJSX */ || compilerOptions.jsx === 5 /* ReactJSXDev */ || compilerOptions.jsxImportSource || jsxImportSourcePragma ? (jsxImportSourcePragma == null ? void 0 : jsxImportSourcePragma.arguments.factory) || compilerOptions.jsxImportSource || "react" : void 0;
-  }
-  function getJSXRuntimeImport(base, options) {
-    return base ? `${base}/${options.jsx === 5 /* ReactJSXDev */ ? "jsx-dev-runtime" : "jsx-runtime"}` : void 0;
-  }
-  function hasZeroOrOneAsteriskCharacter(str) {
-    let seenAsterisk = false;
-    for (let i = 0; i < str.length; i++) {
-      if (str.charCodeAt(i) === 42 /* asterisk */) {
-        if (!seenAsterisk) {
-          seenAsterisk = true;
-        } else {
-          return false;
-        }
-      }
-    }
-    return true;
-  }
-  function createSymlinkCache(cwd, getCanonicalFileName) {
-    let symlinkedDirectories;
-    let symlinkedDirectoriesByRealpath;
-    let symlinkedFiles;
-    let hasProcessedResolutions = false;
-    return {
-      getSymlinkedFiles: () => symlinkedFiles,
-      getSymlinkedDirectories: () => symlinkedDirectories,
-      getSymlinkedDirectoriesByRealpath: () => symlinkedDirectoriesByRealpath,
-      setSymlinkedFile: (path, real) => (symlinkedFiles || (symlinkedFiles = /* @__PURE__ */ new Map())).set(path, real),
-      setSymlinkedDirectory: (symlink, real) => {
-        let symlinkPath = toPath(symlink, cwd, getCanonicalFileName);
-        if (!containsIgnoredPath(symlinkPath)) {
-          symlinkPath = ensureTrailingDirectorySeparator(symlinkPath);
-          if (real !== false && !(symlinkedDirectories == null ? void 0 : symlinkedDirectories.has(symlinkPath))) {
-            (symlinkedDirectoriesByRealpath || (symlinkedDirectoriesByRealpath = createMultiMap())).add(ensureTrailingDirectorySeparator(real.realPath), symlink);
-          }
-          (symlinkedDirectories || (symlinkedDirectories = /* @__PURE__ */ new Map())).set(symlinkPath, real);
-        }
-      },
-      setSymlinksFromResolutions(files, typeReferenceDirectives) {
-        var _a, _b;
-        Debug.assert(!hasProcessedResolutions);
-        hasProcessedResolutions = true;
-        for (const file of files) {
-          (_a = file.resolvedModules) == null ? void 0 : _a.forEach((resolution) => processResolution(this, resolution.resolvedModule));
-          (_b = file.resolvedTypeReferenceDirectiveNames) == null ? void 0 : _b.forEach((resolution) => processResolution(this, resolution.resolvedTypeReferenceDirective));
-        }
-        typeReferenceDirectives.forEach((resolution) => processResolution(this, resolution.resolvedTypeReferenceDirective));
-      },
-      hasProcessedResolutions: () => hasProcessedResolutions
-    };
-    function processResolution(cache, resolution) {
-      if (!resolution || !resolution.originalPath || !resolution.resolvedFileName)
-        return;
-      const { resolvedFileName, originalPath } = resolution;
-      cache.setSymlinkedFile(toPath(originalPath, cwd, getCanonicalFileName), resolvedFileName);
-      const [commonResolved, commonOriginal] = guessDirectorySymlink(resolvedFileName, originalPath, cwd, getCanonicalFileName) || emptyArray;
-      if (commonResolved && commonOriginal) {
-        cache.setSymlinkedDirectory(
-          commonOriginal,
-          { real: commonResolved, realPath: toPath(commonResolved, cwd, getCanonicalFileName) }
-        );
-      }
-    }
-  }
-  function guessDirectorySymlink(a, b, cwd, getCanonicalFileName) {
-    const aParts = getPathComponents(getNormalizedAbsolutePath(a, cwd));
-    const bParts = getPathComponents(getNormalizedAbsolutePath(b, cwd));
-    let isDirectory = false;
-    while (aParts.length >= 2 && bParts.length >= 2 && !isNodeModulesOrScopedPackageDirectory(aParts[aParts.length - 2], getCanonicalFileName) && !isNodeModulesOrScopedPackageDirectory(bParts[bParts.length - 2], getCanonicalFileName) && getCanonicalFileName(aParts[aParts.length - 1]) === getCanonicalFileName(bParts[bParts.length - 1])) {
-      aParts.pop();
-      bParts.pop();
-      isDirectory = true;
-    }
-    return isDirectory ? [getPathFromPathComponents(aParts), getPathFromPathComponents(bParts)] : void 0;
-  }
-  function isNodeModulesOrScopedPackageDirectory(s, getCanonicalFileName) {
-    return s !== void 0 && (getCanonicalFileName(s) === "node_modules" || startsWith(s, "@"));
-  }
-  function stripLeadingDirectorySeparator(s) {
-    return isAnyDirectorySeparator(s.charCodeAt(0)) ? s.slice(1) : void 0;
-  }
-  function tryRemoveDirectoryPrefix(path, dirPath, getCanonicalFileName) {
-    const withoutPrefix = tryRemovePrefix(path, dirPath, getCanonicalFileName);
-    return withoutPrefix === void 0 ? void 0 : stripLeadingDirectorySeparator(withoutPrefix);
-  }
-  function regExpEscape(text) {
-    return text.replace(reservedCharacterPattern, escapeRegExpCharacter);
-  }
-  function escapeRegExpCharacter(match) {
-    return "\\" + match;
-  }
-  function getRegularExpressionForWildcard(specs, basePath, usage) {
-    const patterns = getRegularExpressionsForWildcards(specs, basePath, usage);
-    if (!patterns || !patterns.length) {
-      return void 0;
-    }
-    const pattern = patterns.map((pattern2) => `(${pattern2})`).join("|");
-    const terminator = usage === "exclude" ? "($|/)" : "$";
-    return `^(${pattern})${terminator}`;
-  }
-  function getRegularExpressionsForWildcards(specs, basePath, usage) {
-    if (specs === void 0 || specs.length === 0) {
-      return void 0;
-    }
-    return flatMap(specs, (spec) => spec && getSubPatternFromSpec(spec, basePath, usage, wildcardMatchers[usage]));
-  }
-  function isImplicitGlob(lastPathComponent) {
-    return !/[.*?]/.test(lastPathComponent);
-  }
-  function getPatternFromSpec(spec, basePath, usage) {
-    const pattern = spec && getSubPatternFromSpec(spec, basePath, usage, wildcardMatchers[usage]);
-    return pattern && `^(${pattern})${usage === "exclude" ? "($|/)" : "$"}`;
-  }
-  function getSubPatternFromSpec(spec, basePath, usage, { singleAsteriskRegexFragment, doubleAsteriskRegexFragment, replaceWildcardCharacter: replaceWildcardCharacter2 }) {
-    let subpattern = "";
-    let hasWrittenComponent = false;
-    const components = getNormalizedPathComponents(spec, basePath);
-    const lastComponent = last(components);
-    if (usage !== "exclude" && lastComponent === "**") {
-      return void 0;
-    }
-    components[0] = removeTrailingDirectorySeparator(components[0]);
-    if (isImplicitGlob(lastComponent)) {
-      components.push("**", "*");
-    }
-    let optionalCount = 0;
-    for (let component of components) {
-      if (component === "**") {
-        subpattern += doubleAsteriskRegexFragment;
-      } else {
-        if (usage === "directories") {
-          subpattern += "(";
-          optionalCount++;
-        }
-        if (hasWrittenComponent) {
-          subpattern += directorySeparator;
-        }
-        if (usage !== "exclude") {
-          let componentPattern = "";
-          if (component.charCodeAt(0) === 42 /* asterisk */) {
-            componentPattern += "([^./]" + singleAsteriskRegexFragment + ")?";
-            component = component.substr(1);
-          } else if (component.charCodeAt(0) === 63 /* question */) {
-            componentPattern += "[^./]";
-            component = component.substr(1);
-          }
-          componentPattern += component.replace(reservedCharacterPattern, replaceWildcardCharacter2);
-          if (componentPattern !== component) {
-            subpattern += implicitExcludePathRegexPattern;
-          }
-          subpattern += componentPattern;
-        } else {
-          subpattern += component.replace(reservedCharacterPattern, replaceWildcardCharacter2);
-        }
-      }
-      hasWrittenComponent = true;
-    }
-    while (optionalCount > 0) {
-      subpattern += ")?";
-      optionalCount--;
-    }
-    return subpattern;
-  }
-  function replaceWildcardCharacter(match, singleAsteriskRegexFragment) {
-    return match === "*" ? singleAsteriskRegexFragment : match === "?" ? "[^/]" : "\\" + match;
-  }
-  function getFileMatcherPatterns(path, excludes, includes, useCaseSensitiveFileNames, currentDirectory) {
-    path = normalizePath(path);
-    currentDirectory = normalizePath(currentDirectory);
-    const absolutePath = combinePaths(currentDirectory, path);
-    return {
-      includeFilePatterns: map(getRegularExpressionsForWildcards(includes, absolutePath, "files"), (pattern) => `^${pattern}$`),
-      includeFilePattern: getRegularExpressionForWildcard(includes, absolutePath, "files"),
-      includeDirectoryPattern: getRegularExpressionForWildcard(includes, absolutePath, "directories"),
-      excludePattern: getRegularExpressionForWildcard(excludes, absolutePath, "exclude"),
-      basePaths: getBasePaths(path, includes, useCaseSensitiveFileNames)
-    };
-  }
-  function getRegexFromPattern(pattern, useCaseSensitiveFileNames) {
-    return new RegExp(pattern, useCaseSensitiveFileNames ? "" : "i");
-  }
-  function matchFiles(path, extensions, excludes, includes, useCaseSensitiveFileNames, currentDirectory, depth, getFileSystemEntries, realpath) {
-    path = normalizePath(path);
-    currentDirectory = normalizePath(currentDirectory);
-    const patterns = getFileMatcherPatterns(path, excludes, includes, useCaseSensitiveFileNames, currentDirectory);
-    const includeFileRegexes = patterns.includeFilePatterns && patterns.includeFilePatterns.map((pattern) => getRegexFromPattern(pattern, useCaseSensitiveFileNames));
-    const includeDirectoryRegex = patterns.includeDirectoryPattern && getRegexFromPattern(patterns.includeDirectoryPattern, useCaseSensitiveFileNames);
-    const excludeRegex = patterns.excludePattern && getRegexFromPattern(patterns.excludePattern, useCaseSensitiveFileNames);
-    const results = includeFileRegexes ? includeFileRegexes.map(() => []) : [[]];
-    const visited = /* @__PURE__ */ new Map();
-    const toCanonical = createGetCanonicalFileName(useCaseSensitiveFileNames);
-    for (const basePath of patterns.basePaths) {
-      visitDirectory(basePath, combinePaths(currentDirectory, basePath), depth);
-    }
-    return flatten(results);
-    function visitDirectory(path2, absolutePath, depth2) {
-      const canonicalPath = toCanonical(realpath(absolutePath));
-      if (visited.has(canonicalPath))
-        return;
-      visited.set(canonicalPath, true);
-      const { files, directories } = getFileSystemEntries(path2);
-      for (const current of sort(files, compareStringsCaseSensitive)) {
-        const name = combinePaths(path2, current);
-        const absoluteName = combinePaths(absolutePath, current);
-        if (extensions && !fileExtensionIsOneOf(name, extensions))
-          continue;
-        if (excludeRegex && excludeRegex.test(absoluteName))
-          continue;
-        if (!includeFileRegexes) {
-          results[0].push(name);
-        } else {
-          const includeIndex = findIndex(includeFileRegexes, (re) => re.test(absoluteName));
-          if (includeIndex !== -1) {
-            results[includeIndex].push(name);
-          }
-        }
-      }
-      if (depth2 !== void 0) {
-        depth2--;
-        if (depth2 === 0) {
-          return;
-        }
-      }
-      for (const current of sort(directories, compareStringsCaseSensitive)) {
-        const name = combinePaths(path2, current);
-        const absoluteName = combinePaths(absolutePath, current);
-        if ((!includeDirectoryRegex || includeDirectoryRegex.test(absoluteName)) && (!excludeRegex || !excludeRegex.test(absoluteName))) {
-          visitDirectory(name, absoluteName, depth2);
-        }
-      }
-    }
-  }
-  function getBasePaths(path, includes, useCaseSensitiveFileNames) {
-    const basePaths = [path];
-    if (includes) {
-      const includeBasePaths = [];
-      for (const include of includes) {
-        const absolute = isRootedDiskPath(include) ? include : normalizePath(combinePaths(path, include));
-        includeBasePaths.push(getIncludeBasePath(absolute));
-      }
-      includeBasePaths.sort(getStringComparer(!useCaseSensitiveFileNames));
-      for (const includeBasePath of includeBasePaths) {
-        if (every(basePaths, (basePath) => !containsPath(basePath, includeBasePath, path, !useCaseSensitiveFileNames))) {
-          basePaths.push(includeBasePath);
-        }
-      }
-    }
-    return basePaths;
-  }
-  function getIncludeBasePath(absolute) {
-    const wildcardOffset = indexOfAnyCharCode(absolute, wildcardCharCodes);
-    if (wildcardOffset < 0) {
-      return !hasExtension(absolute) ? absolute : removeTrailingDirectorySeparator(getDirectoryPath(absolute));
-    }
-    return absolute.substring(0, absolute.lastIndexOf(directorySeparator, wildcardOffset));
-  }
-  function ensureScriptKind(fileName, scriptKind) {
-    return scriptKind || getScriptKindFromFileName(fileName) || 3 /* TS */;
-  }
-  function getScriptKindFromFileName(fileName) {
-    const ext = fileName.substr(fileName.lastIndexOf("."));
-    switch (ext.toLowerCase()) {
-      case ".js" /* Js */:
-      case ".cjs" /* Cjs */:
-      case ".mjs" /* Mjs */:
-        return 1 /* JS */;
-      case ".jsx" /* Jsx */:
-        return 2 /* JSX */;
-      case ".ts" /* Ts */:
-      case ".cts" /* Cts */:
-      case ".mts" /* Mts */:
-        return 3 /* TS */;
-      case ".tsx" /* Tsx */:
-        return 4 /* TSX */;
-      case ".json" /* Json */:
-        return 6 /* JSON */;
-      default:
-        return 0 /* Unknown */;
-    }
-  }
-  function getSupportedExtensions(options, extraFileExtensions) {
-    const needJsExtensions = options && getAllowJSCompilerOption(options);
-    if (!extraFileExtensions || extraFileExtensions.length === 0) {
-      return needJsExtensions ? allSupportedExtensions : supportedTSExtensions;
-    }
-    const builtins = needJsExtensions ? allSupportedExtensions : supportedTSExtensions;
-    const flatBuiltins = flatten(builtins);
-    const extensions = [
-      ...builtins,
-      ...mapDefined(extraFileExtensions, (x) => x.scriptKind === 7 /* Deferred */ || needJsExtensions && isJSLike(x.scriptKind) && flatBuiltins.indexOf(x.extension) === -1 ? [x.extension] : void 0)
-    ];
-    return extensions;
-  }
-  function getSupportedExtensionsWithJsonIfResolveJsonModule(options, supportedExtensions) {
-    if (!options || !getResolveJsonModule(options))
-      return supportedExtensions;
-    if (supportedExtensions === allSupportedExtensions)
-      return allSupportedExtensionsWithJson;
-    if (supportedExtensions === supportedTSExtensions)
-      return supportedTSExtensionsWithJson;
-    return [...supportedExtensions, [".json" /* Json */]];
-  }
-  function isJSLike(scriptKind) {
-    return scriptKind === 1 /* JS */ || scriptKind === 2 /* JSX */;
-  }
-  function hasJSFileExtension(fileName) {
-    return some(supportedJSExtensionsFlat, (extension) => fileExtensionIs(fileName, extension));
-  }
-  function hasTSFileExtension(fileName) {
-    return some(supportedTSExtensionsFlat, (extension) => fileExtensionIs(fileName, extension));
-  }
-  function usesExtensionsOnImports({ imports }, hasExtension2 = or(hasJSFileExtension, hasTSFileExtension)) {
-    return firstDefined(imports, ({ text }) => pathIsRelative(text) && !fileExtensionIsOneOf(text, extensionsNotSupportingExtensionlessResolution) ? hasExtension2(text) : void 0) || false;
-  }
-  function getModuleSpecifierEndingPreference(preference, resolutionMode, compilerOptions, sourceFile) {
-    if (preference === "js" || resolutionMode === 99 /* ESNext */) {
-      if (!shouldAllowImportingTsExtension(compilerOptions)) {
-        return 2 /* JsExtension */;
-      }
-      return inferPreference() !== 2 /* JsExtension */ ? 3 /* TsExtension */ : 2 /* JsExtension */;
-    }
-    if (preference === "minimal") {
-      return 0 /* Minimal */;
-    }
-    if (preference === "index") {
-      return 1 /* Index */;
-    }
-    if (!shouldAllowImportingTsExtension(compilerOptions)) {
-      return usesExtensionsOnImports(sourceFile) ? 2 /* JsExtension */ : 0 /* Minimal */;
-    }
-    return inferPreference();
-    function inferPreference() {
-      let usesJsExtensions = false;
-      const specifiers = sourceFile.imports.length ? sourceFile.imports.map((i) => i.text) : isSourceFileJS(sourceFile) ? getRequiresAtTopOfFile(sourceFile).map((r) => r.arguments[0].text) : emptyArray;
-      for (const specifier of specifiers) {
-        if (pathIsRelative(specifier)) {
-          if (fileExtensionIsOneOf(specifier, extensionsNotSupportingExtensionlessResolution)) {
-            continue;
-          }
-          if (hasTSFileExtension(specifier)) {
-            return 3 /* TsExtension */;
-          }
-          if (hasJSFileExtension(specifier)) {
-            usesJsExtensions = true;
-          }
-        }
-      }
-      return usesJsExtensions ? 2 /* JsExtension */ : 0 /* Minimal */;
-    }
-  }
-  function getRequiresAtTopOfFile(sourceFile) {
-    let nonRequireStatementCount = 0;
-    let requires;
-    for (const statement of sourceFile.statements) {
-      if (nonRequireStatementCount > 3) {
-        break;
-      }
-      if (isRequireVariableStatement(statement)) {
-        requires = concatenate(requires, statement.declarationList.declarations.map((d) => d.initializer));
-      } else if (isExpressionStatement(statement) && isRequireCall(
-        statement.expression,
-        /*requireStringLiteralLikeArgument*/
-        true
-      )) {
-        requires = append(requires, statement.expression);
-      } else {
-        nonRequireStatementCount++;
-      }
-    }
-    return requires || emptyArray;
-  }
-  function isSupportedSourceFileName(fileName, compilerOptions, extraFileExtensions) {
-    if (!fileName)
-      return false;
-    const supportedExtensions = getSupportedExtensions(compilerOptions, extraFileExtensions);
-    for (const extension of flatten(getSupportedExtensionsWithJsonIfResolveJsonModule(compilerOptions, supportedExtensions))) {
-      if (fileExtensionIs(fileName, extension)) {
-        return true;
-      }
-    }
-    return false;
-  }
-  function numberOfDirectorySeparators(str) {
-    const match = str.match(/\//g);
-    return match ? match.length : 0;
-  }
-  function compareNumberOfDirectorySeparators(path1, path2) {
-    return compareValues(
-      numberOfDirectorySeparators(path1),
-      numberOfDirectorySeparators(path2)
-    );
-  }
-  function removeFileExtension(path) {
-    for (const ext of extensionsToRemove) {
-      const extensionless = tryRemoveExtension(path, ext);
-      if (extensionless !== void 0) {
-        return extensionless;
-      }
-    }
-    return path;
-  }
-  function tryRemoveExtension(path, extension) {
-    return fileExtensionIs(path, extension) ? removeExtension(path, extension) : void 0;
-  }
-  function removeExtension(path, extension) {
-    return path.substring(0, path.length - extension.length);
-  }
-  function changeExtension(path, newExtension) {
-    return changeAnyExtension(
-      path,
-      newExtension,
-      extensionsToRemove,
-      /*ignoreCase*/
-      false
-    );
-  }
-  function tryParsePattern(pattern) {
-    const indexOfStar = pattern.indexOf("*");
-    if (indexOfStar === -1) {
-      return pattern;
-    }
-    return pattern.indexOf("*", indexOfStar + 1) !== -1 ? void 0 : {
-      prefix: pattern.substr(0, indexOfStar),
-      suffix: pattern.substr(indexOfStar + 1)
-    };
-  }
-  function tryParsePatterns(paths) {
-    return mapDefined(getOwnKeys(paths), (path) => tryParsePattern(path));
-  }
-  function positionIsSynthesized(pos) {
-    return !(pos >= 0);
-  }
-  function extensionIsTS(ext) {
-    return ext === ".ts" /* Ts */ || ext === ".tsx" /* Tsx */ || ext === ".d.ts" /* Dts */ || ext === ".cts" /* Cts */ || ext === ".mts" /* Mts */ || ext === ".d.mts" /* Dmts */ || ext === ".d.cts" /* Dcts */ || startsWith(ext, ".d.") && endsWith(ext, ".ts");
-  }
-  function resolutionExtensionIsTSOrJson(ext) {
-    return extensionIsTS(ext) || ext === ".json" /* Json */;
-  }
-  function extensionFromPath(path) {
-    const ext = tryGetExtensionFromPath2(path);
-    return ext !== void 0 ? ext : Debug.fail(`File ${path} has unknown extension.`);
-  }
-  function isAnySupportedFileExtension(path) {
-    return tryGetExtensionFromPath2(path) !== void 0;
-  }
-  function tryGetExtensionFromPath2(path) {
-    return find(extensionsToRemove, (e) => fileExtensionIs(path, e));
-  }
-  function isCheckJsEnabledForFile(sourceFile, compilerOptions) {
-    return sourceFile.checkJsDirective ? sourceFile.checkJsDirective.enabled : compilerOptions.checkJs;
-  }
-  function matchPatternOrExact(patternOrStrings, candidate) {
-    const patterns = [];
-    for (const patternOrString of patternOrStrings) {
-      if (patternOrString === candidate) {
-        return candidate;
-      }
-      if (!isString(patternOrString)) {
-        patterns.push(patternOrString);
-      }
-    }
-    return findBestPatternMatch(patterns, (_) => _, candidate);
-  }
-  function sliceAfter(arr, value) {
-    const index = arr.indexOf(value);
-    Debug.assert(index !== -1);
-    return arr.slice(index);
-  }
-  function addRelatedInfo(diagnostic, ...relatedInformation) {
-    if (!relatedInformation.length) {
-      return diagnostic;
-    }
-    if (!diagnostic.relatedInformation) {
-      diagnostic.relatedInformation = [];
-    }
-    Debug.assert(diagnostic.relatedInformation !== emptyArray, "Diagnostic had empty array singleton for related info, but is still being constructed!");
-    diagnostic.relatedInformation.push(...relatedInformation);
-    return diagnostic;
-  }
-  function minAndMax(arr, getValue) {
-    Debug.assert(arr.length !== 0);
-    let min2 = getValue(arr[0]);
-    let max = min2;
-    for (let i = 1; i < arr.length; i++) {
-      const value = getValue(arr[i]);
-      if (value < min2) {
-        min2 = value;
-      } else if (value > max) {
-        max = value;
-      }
-    }
-    return { min: min2, max };
-  }
-  function rangeOfNode(node) {
-    return { pos: getTokenPosOfNode(node), end: node.end };
-  }
-  function rangeOfTypeParameters(sourceFile, typeParameters) {
-    const pos = typeParameters.pos - 1;
-    const end = Math.min(sourceFile.text.length, skipTrivia(sourceFile.text, typeParameters.end) + 1);
-    return { pos, end };
-  }
-  function skipTypeChecking(sourceFile, options, host) {
-    return options.skipLibCheck && sourceFile.isDeclarationFile || options.skipDefaultLibCheck && sourceFile.hasNoDefaultLib || host.isSourceOfProjectReferenceRedirect(sourceFile.fileName);
-  }
-  function isJsonEqual(a, b) {
-    return a === b || typeof a === "object" && a !== null && typeof b === "object" && b !== null && equalOwnProperties(a, b, isJsonEqual);
-  }
-  function parsePseudoBigInt(stringValue) {
-    let log2Base;
-    switch (stringValue.charCodeAt(1)) {
-      case 98 /* b */:
-      case 66 /* B */:
-        log2Base = 1;
-        break;
-      case 111 /* o */:
-      case 79 /* O */:
-        log2Base = 3;
-        break;
-      case 120 /* x */:
-      case 88 /* X */:
-        log2Base = 4;
-        break;
-      default:
-        const nIndex = stringValue.length - 1;
-        let nonZeroStart = 0;
-        while (stringValue.charCodeAt(nonZeroStart) === 48 /* _0 */) {
-          nonZeroStart++;
-        }
-        return stringValue.slice(nonZeroStart, nIndex) || "0";
-    }
-    const startIndex = 2, endIndex = stringValue.length - 1;
-    const bitsNeeded = (endIndex - startIndex) * log2Base;
-    const segments = new Uint16Array((bitsNeeded >>> 4) + (bitsNeeded & 15 ? 1 : 0));
-    for (let i = endIndex - 1, bitOffset = 0; i >= startIndex; i--, bitOffset += log2Base) {
-      const segment = bitOffset >>> 4;
-      const digitChar = stringValue.charCodeAt(i);
-      const digit = digitChar <= 57 /* _9 */ ? digitChar - 48 /* _0 */ : 10 + digitChar - (digitChar <= 70 /* F */ ? 65 /* A */ : 97 /* a */);
-      const shiftedDigit = digit << (bitOffset & 15);
-      segments[segment] |= shiftedDigit;
-      const residual = shiftedDigit >>> 16;
-      if (residual)
-        segments[segment + 1] |= residual;
-    }
-    let base10Value = "";
-    let firstNonzeroSegment = segments.length - 1;
-    let segmentsRemaining = true;
-    while (segmentsRemaining) {
-      let mod10 = 0;
-      segmentsRemaining = false;
-      for (let segment = firstNonzeroSegment; segment >= 0; segment--) {
-        const newSegment = mod10 << 16 | segments[segment];
-        const segmentValue = newSegment / 10 | 0;
-        segments[segment] = segmentValue;
-        mod10 = newSegment - segmentValue * 10;
-        if (segmentValue && !segmentsRemaining) {
-          firstNonzeroSegment = segment;
-          segmentsRemaining = true;
-        }
-      }
-      base10Value = mod10 + base10Value;
-    }
-    return base10Value;
-  }
-  function pseudoBigIntToString({ negative, base10Value }) {
-    return (negative && base10Value !== "0" ? "-" : "") + base10Value;
-  }
-  function parseBigInt(text) {
-    if (!isValidBigIntString(
-      text,
-      /*roundTripOnly*/
-      false
-    )) {
-      return void 0;
-    }
-    return parseValidBigInt(text);
-  }
-  function parseValidBigInt(text) {
-    const negative = text.startsWith("-");
-    const base10Value = parsePseudoBigInt(`${negative ? text.slice(1) : text}n`);
-    return { negative, base10Value };
-  }
-  function isValidBigIntString(s, roundTripOnly) {
-    if (s === "")
-      return false;
-    const scanner2 = createScanner(
-      99 /* ESNext */,
-      /*skipTrivia*/
-      false
-    );
-    let success = true;
-    scanner2.setOnError(() => success = false);
-    scanner2.setText(s + "n");
-    let result = scanner2.scan();
-    const negative = result === 41 /* MinusToken */;
-    if (negative) {
-      result = scanner2.scan();
-    }
-    const flags = scanner2.getTokenFlags();
-    return success && result === 10 /* BigIntLiteral */ && scanner2.getTokenEnd() === s.length + 1 && !(flags & 512 /* ContainsSeparator */) && (!roundTripOnly || s === pseudoBigIntToString({ negative, base10Value: parsePseudoBigInt(scanner2.getTokenValue()) }));
-  }
-  function isValidTypeOnlyAliasUseSite(useSite) {
-    return !!(useSite.flags & 16777216 /* Ambient */) || isPartOfTypeQuery(useSite) || isIdentifierInNonEmittingHeritageClause(useSite) || isPartOfPossiblyValidTypeOrAbstractComputedPropertyName(useSite) || !(isExpressionNode(useSite) || isShorthandPropertyNameUseSite(useSite));
-  }
-  function isShorthandPropertyNameUseSite(useSite) {
-    return isIdentifier(useSite) && isShorthandPropertyAssignment(useSite.parent) && useSite.parent.name === useSite;
-  }
-  function isPartOfPossiblyValidTypeOrAbstractComputedPropertyName(node) {
-    while (node.kind === 80 /* Identifier */ || node.kind === 210 /* PropertyAccessExpression */) {
-      node = node.parent;
-    }
-    if (node.kind !== 166 /* ComputedPropertyName */) {
-      return false;
-    }
-    if (hasSyntacticModifier(node.parent, 256 /* Abstract */)) {
-      return true;
-    }
-    const containerKind = node.parent.parent.kind;
-    return containerKind === 263 /* InterfaceDeclaration */ || containerKind === 186 /* TypeLiteral */;
-  }
-  function isIdentifierInNonEmittingHeritageClause(node) {
-    if (node.kind !== 80 /* Identifier */)
-      return false;
-    const heritageClause = findAncestor(node.parent, (parent2) => {
-      switch (parent2.kind) {
-        case 297 /* HeritageClause */:
-          return true;
-        case 210 /* PropertyAccessExpression */:
-        case 232 /* ExpressionWithTypeArguments */:
-          return false;
-        default:
-          return "quit";
-      }
-    });
-    return (heritageClause == null ? void 0 : heritageClause.token) === 119 /* ImplementsKeyword */ || (heritageClause == null ? void 0 : heritageClause.parent.kind) === 263 /* InterfaceDeclaration */;
-  }
-  function isIdentifierTypeReference(node) {
-    return isTypeReferenceNode(node) && isIdentifier(node.typeName);
-  }
-  function arrayIsHomogeneous(array, comparer = equateValues) {
-    if (array.length < 2)
-      return true;
-    const first2 = array[0];
-    for (let i = 1, length2 = array.length; i < length2; i++) {
-      const target = array[i];
-      if (!comparer(first2, target))
-        return false;
-    }
-    return true;
-  }
-  function setTextRangePos(range, pos) {
-    range.pos = pos;
-    return range;
-  }
-  function setTextRangeEnd(range, end) {
-    range.end = end;
-    return range;
-  }
-  function setTextRangePosEnd(range, pos, end) {
-    return setTextRangeEnd(setTextRangePos(range, pos), end);
-  }
-  function setTextRangePosWidth(range, pos, width) {
-    return setTextRangePosEnd(range, pos, pos + width);
-  }
-  function setNodeFlags(node, newFlags) {
-    if (node) {
-      node.flags = newFlags;
-    }
-    return node;
-  }
-  function setParent(child, parent2) {
-    if (child && parent2) {
-      child.parent = parent2;
-    }
-    return child;
-  }
-  function setEachParent(children, parent2) {
-    if (children) {
-      for (const child of children) {
-        setParent(child, parent2);
-      }
-    }
-    return children;
-  }
-  function setParentRecursive(rootNode, incremental) {
-    if (!rootNode)
-      return rootNode;
-    forEachChildRecursively(rootNode, isJSDocNode(rootNode) ? bindParentToChildIgnoringJSDoc : bindParentToChild);
-    return rootNode;
-    function bindParentToChildIgnoringJSDoc(child, parent2) {
-      if (incremental && child.parent === parent2) {
-        return "skip";
-      }
-      setParent(child, parent2);
-    }
-    function bindJSDoc(child) {
-      if (hasJSDocNodes(child)) {
-        for (const doc of child.jsDoc) {
-          bindParentToChildIgnoringJSDoc(doc, child);
-          forEachChildRecursively(doc, bindParentToChildIgnoringJSDoc);
-        }
-      }
-    }
-    function bindParentToChild(child, parent2) {
-      return bindParentToChildIgnoringJSDoc(child, parent2) || bindJSDoc(child);
-    }
-  }
-  function isPackedElement(node) {
-    return !isOmittedExpression(node);
-  }
-  function isPackedArrayLiteral(node) {
-    return isArrayLiteralExpression(node) && every(node.elements, isPackedElement);
-  }
-  function expressionResultIsUnused(node) {
-    Debug.assertIsDefined(node.parent);
-    while (true) {
-      const parent2 = node.parent;
-      if (isParenthesizedExpression(parent2)) {
-        node = parent2;
-        continue;
-      }
-      if (isExpressionStatement(parent2) || isVoidExpression(parent2) || isForStatement(parent2) && (parent2.initializer === node || parent2.incrementor === node)) {
-        return true;
-      }
-      if (isCommaListExpression(parent2)) {
-        if (node !== last(parent2.elements))
-          return true;
-        node = parent2;
-        continue;
-      }
-      if (isBinaryExpression(parent2) && parent2.operatorToken.kind === 28 /* CommaToken */) {
-        if (node === parent2.left)
-          return true;
-        node = parent2;
-        continue;
-      }
-      return false;
-    }
-  }
-  function containsIgnoredPath(path) {
-    return some(ignoredPaths, (p) => stringContains(path, p));
-  }
-  function getContainingNodeArray(node) {
-    if (!node.parent)
-      return void 0;
-    switch (node.kind) {
-      case 167 /* TypeParameter */:
-        const { parent: parent3 } = node;
-        return parent3.kind === 194 /* InferType */ ? void 0 : parent3.typeParameters;
-      case 168 /* Parameter */:
-        return node.parent.parameters;
-      case 203 /* TemplateLiteralTypeSpan */:
-        return node.parent.templateSpans;
-      case 238 /* TemplateSpan */:
-        return node.parent.templateSpans;
-      case 169 /* Decorator */: {
-        const { parent: parent4 } = node;
-        return canHaveDecorators(parent4) ? parent4.modifiers : void 0;
-      }
-      case 297 /* HeritageClause */:
-        return node.parent.heritageClauses;
-    }
-    const { parent: parent2 } = node;
-    if (isJSDocTag(node)) {
-      return isJSDocTypeLiteral(node.parent) ? void 0 : node.parent.tags;
-    }
-    switch (parent2.kind) {
-      case 186 /* TypeLiteral */:
-      case 263 /* InterfaceDeclaration */:
-        return isTypeElement(node) ? parent2.members : void 0;
-      case 191 /* UnionType */:
-      case 192 /* IntersectionType */:
-        return parent2.types;
-      case 188 /* TupleType */:
-      case 208 /* ArrayLiteralExpression */:
-      case 360 /* CommaListExpression */:
-      case 274 /* NamedImports */:
-      case 278 /* NamedExports */:
-        return parent2.elements;
-      case 209 /* ObjectLiteralExpression */:
-      case 291 /* JsxAttributes */:
-        return parent2.properties;
-      case 212 /* CallExpression */:
-      case 213 /* NewExpression */:
-        return isTypeNode(node) ? parent2.typeArguments : parent2.expression === node ? void 0 : parent2.arguments;
-      case 283 /* JsxElement */:
-      case 287 /* JsxFragment */:
-        return isJsxChild(node) ? parent2.children : void 0;
-      case 285 /* JsxOpeningElement */:
-      case 284 /* JsxSelfClosingElement */:
-        return isTypeNode(node) ? parent2.typeArguments : void 0;
-      case 240 /* Block */:
-      case 295 /* CaseClause */:
-      case 296 /* DefaultClause */:
-      case 267 /* ModuleBlock */:
-        return parent2.statements;
-      case 268 /* CaseBlock */:
-        return parent2.clauses;
-      case 262 /* ClassDeclaration */:
-      case 230 /* ClassExpression */:
-        return isClassElement(node) ? parent2.members : void 0;
-      case 265 /* EnumDeclaration */:
-        return isEnumMember(node) ? parent2.members : void 0;
-      case 311 /* SourceFile */:
-        return parent2.statements;
-    }
-  }
-  function hasContextSensitiveParameters(node) {
-    if (!node.typeParameters) {
-      if (some(node.parameters, (p) => !getEffectiveTypeAnnotationNode(p))) {
-        return true;
-      }
-      if (node.kind !== 218 /* ArrowFunction */) {
-        const parameter = firstOrUndefined(node.parameters);
-        if (!(parameter && parameterIsThisKeyword(parameter))) {
-          return true;
-        }
-      }
-    }
-    return false;
-  }
-  function isInfinityOrNaNString(name) {
-    return name === "Infinity" || name === "-Infinity" || name === "NaN";
-  }
-  function isCatchClauseVariableDeclaration(node) {
-    return node.kind === 259 /* VariableDeclaration */ && node.parent.kind === 298 /* CatchClause */;
-  }
-  function isParameterOrCatchClauseVariable(symbol) {
-    const declaration = symbol.valueDeclaration && getRootDeclaration(symbol.valueDeclaration);
-    return !!declaration && (isParameter(declaration) || isCatchClauseVariableDeclaration(declaration));
-  }
-  function isFunctionExpressionOrArrowFunction(node) {
-    return node.kind === 217 /* FunctionExpression */ || node.kind === 218 /* ArrowFunction */;
-  }
-  function escapeSnippetText(text) {
-    return text.replace(/\$/gm, () => "\\$");
-  }
-  function isNumericLiteralName(name) {
-    return (+name).toString() === name;
-  }
-  function createPropertyNameNodeForIdentifierOrLiteral(name, target, singleQuote, stringNamed) {
-    return isIdentifierText(name, target) ? factory.createIdentifier(name) : !stringNamed && isNumericLiteralName(name) && +name >= 0 ? factory.createNumericLiteral(+name) : factory.createStringLiteral(name, !!singleQuote);
-  }
-  function isThisTypeParameter(type) {
-    return !!(type.flags & 262144 /* TypeParameter */ && type.isThisType);
-  }
-  function getNodeModulePathParts(fullPath) {
-    let topLevelNodeModulesIndex = 0;
-    let topLevelPackageNameIndex = 0;
-    let packageRootIndex = 0;
-    let fileNameIndex = 0;
-    let States;
-    ((States2) => {
-      States2[States2["BeforeNodeModules"] = 0] = "BeforeNodeModules";
-      States2[States2["NodeModules"] = 1] = "NodeModules";
-      States2[States2["Scope"] = 2] = "Scope";
-      States2[States2["PackageContent"] = 3] = "PackageContent";
-    })(States || (States = {}));
-    let partStart = 0;
-    let partEnd = 0;
-    let state = 0 /* BeforeNodeModules */;
-    while (partEnd >= 0) {
-      partStart = partEnd;
-      partEnd = fullPath.indexOf("/", partStart + 1);
-      switch (state) {
-        case 0 /* BeforeNodeModules */:
-          if (fullPath.indexOf(nodeModulesPathPart, partStart) === partStart) {
-            topLevelNodeModulesIndex = partStart;
-            topLevelPackageNameIndex = partEnd;
-            state = 1 /* NodeModules */;
-          }
-          break;
-        case 1 /* NodeModules */:
-        case 2 /* Scope */:
-          if (state === 1 /* NodeModules */ && fullPath.charAt(partStart + 1) === "@") {
-            state = 2 /* Scope */;
-          } else {
-            packageRootIndex = partEnd;
-            state = 3 /* PackageContent */;
-          }
-          break;
-        case 3 /* PackageContent */:
-          if (fullPath.indexOf(nodeModulesPathPart, partStart) === partStart) {
-            state = 1 /* NodeModules */;
-          } else {
-            state = 3 /* PackageContent */;
-          }
-          break;
-      }
-    }
-    fileNameIndex = partStart;
-    return state > 1 /* NodeModules */ ? { topLevelNodeModulesIndex, topLevelPackageNameIndex, packageRootIndex, fileNameIndex } : void 0;
-  }
-  function getParameterTypeNode(parameter) {
-    var _a;
-    return parameter.kind === 347 /* JSDocParameterTag */ ? (_a = parameter.typeExpression) == null ? void 0 : _a.type : parameter.type;
-  }
-  function isTypeDeclaration(node) {
-    switch (node.kind) {
-      case 167 /* TypeParameter */:
-      case 262 /* ClassDeclaration */:
-      case 263 /* InterfaceDeclaration */:
-      case 264 /* TypeAliasDeclaration */:
-      case 265 /* EnumDeclaration */:
-      case 352 /* JSDocTypedefTag */:
-      case 344 /* JSDocCallbackTag */:
-      case 346 /* JSDocEnumTag */:
-        return true;
-      case 272 /* ImportClause */:
-        return node.isTypeOnly;
-      case 275 /* ImportSpecifier */:
-      case 280 /* ExportSpecifier */:
-        return node.parent.parent.isTypeOnly;
-      default:
-        return false;
-    }
-  }
-  function canHaveExportModifier(node) {
-    return isEnumDeclaration(node) || isVariableStatement(node) || isFunctionDeclaration(node) || isClassDeclaration(node) || isInterfaceDeclaration(node) || isTypeDeclaration(node) || isModuleDeclaration(node) && !isExternalModuleAugmentation(node) && !isGlobalScopeAugmentation(node);
-  }
-  function isOptionalJSDocPropertyLikeTag(node) {
-    if (!isJSDocPropertyLikeTag(node)) {
-      return false;
-    }
-    const { isBracketed, typeExpression } = node;
-    return isBracketed || !!typeExpression && typeExpression.type.kind === 322 /* JSDocOptionalType */;
-  }
-  function canUsePropertyAccess(name, languageVersion) {
-    if (name.length === 0) {
-      return false;
-    }
-    const firstChar = name.charCodeAt(0);
-    return firstChar === 35 /* hash */ ? name.length > 1 && isIdentifierStart(name.charCodeAt(1), languageVersion) : isIdentifierStart(firstChar, languageVersion);
-  }
-  function hasTabstop(node) {
-    var _a;
-    return ((_a = getSnippetElement(node)) == null ? void 0 : _a.kind) === 0 /* TabStop */;
-  }
-  function isJSDocOptionalParameter(node) {
-    return isInJSFile(node) && // node.type should only be a JSDocOptionalType when node is a parameter of a JSDocFunctionType
-    (node.type && node.type.kind === 322 /* JSDocOptionalType */ || getJSDocParameterTags(node).some(({ isBracketed, typeExpression }) => isBracketed || !!typeExpression && typeExpression.type.kind === 322 /* JSDocOptionalType */));
-  }
-  function isOptionalDeclaration(declaration) {
-    switch (declaration.kind) {
-      case 171 /* PropertyDeclaration */:
-      case 170 /* PropertySignature */:
-        return !!declaration.questionToken;
-      case 168 /* Parameter */:
-        return !!declaration.questionToken || isJSDocOptionalParameter(declaration);
-      case 354 /* JSDocPropertyTag */:
-      case 347 /* JSDocParameterTag */:
-        return isOptionalJSDocPropertyLikeTag(declaration);
-      default:
-        return false;
-    }
-  }
-  function isNonNullAccess(node) {
-    const kind = node.kind;
-    return (kind === 210 /* PropertyAccessExpression */ || kind === 211 /* ElementAccessExpression */) && isNonNullExpression(node.expression);
-  }
-  function isJSDocSatisfiesExpression(node) {
-    return isInJSFile(node) && isParenthesizedExpression(node) && hasJSDocNodes(node) && !!getJSDocSatisfiesTag(node);
-  }
-  function getJSDocSatisfiesExpressionType(node) {
-    return Debug.checkDefined(tryGetJSDocSatisfiesTypeNode(node));
-  }
-  function tryGetJSDocSatisfiesTypeNode(node) {
-    const tag = getJSDocSatisfiesTag(node);
-    return tag && tag.typeExpression && tag.typeExpression.type;
-  }
-  function getEscapedTextOfJsxAttributeName(node) {
-    return isIdentifier(node) ? node.escapedText : getEscapedTextOfJsxNamespacedName(node);
-  }
-  function getTextOfJsxAttributeName(node) {
-    return isIdentifier(node) ? idText(node) : getTextOfJsxNamespacedName(node);
-  }
-  function isJsxAttributeName(node) {
-    const kind = node.kind;
-    return kind === 80 /* Identifier */ || kind === 294 /* JsxNamespacedName */;
-  }
-  function getEscapedTextOfJsxNamespacedName(node) {
-    return `${node.namespace.escapedText}:${idText(node.name)}`;
-  }
-  function getTextOfJsxNamespacedName(node) {
-    return `${idText(node.namespace)}:${idText(node.name)}`;
-  }
-  function intrinsicTagNameToString(node) {
-    return isIdentifier(node) ? idText(node) : getTextOfJsxNamespacedName(node);
-  }
-  var resolvingEmptyArray, externalHelpersModuleNameText, defaultMaximumTruncationLength, noTruncationMaximumTruncationLength, stringWriter, GetLiteralTextFlags, fullTripleSlashReferencePathRegEx, fullTripleSlashReferenceTypeReferenceDirectiveRegEx, fullTripleSlashLibReferenceRegEx, fullTripleSlashAMDReferencePathRegEx, fullTripleSlashAMDModuleRegEx, defaultLibReferenceRegEx, AssignmentKind, FunctionFlags, Associativity, OperatorPrecedence, templateSubstitutionRegExp, doubleQuoteEscapedCharsRegExp, singleQuoteEscapedCharsRegExp, backtickQuoteEscapedCharsRegExp, escapedCharsMap, nonAsciiCharacters, jsxDoubleQuoteEscapedCharsRegExp, jsxSingleQuoteEscapedCharsRegExp, jsxEscapedCharsMap, indentStrings, base64Digits, carriageReturnLineFeed, lineFeed, objectAllocator, objectAllocatorPatchers, localizedDiagnosticMessages, reservedCharacterPattern, wildcardCharCodes, commonPackageFolders, implicitExcludePathRegexPattern, filesMatcher, directoriesMatcher, excludeMatcher, wildcardMatchers, supportedTSExtensions, supportedTSExtensionsFlat, supportedTSExtensionsWithJson, supportedTSExtensionsForExtractExtension, supportedJSExtensions, supportedJSExtensionsFlat, allSupportedExtensions, allSupportedExtensionsWithJson, supportedDeclarationExtensions, supportedTSImplementationExtensions, extensionsNotSupportingExtensionlessResolution, ModuleSpecifierEnding, extensionsToRemove, emptyFileSystemEntries;
-  var init_utilities = __esm({
-    "src/compiler/utilities.ts"() {
-      "use strict";
-      init_ts2();
-      resolvingEmptyArray = [];
-      externalHelpersModuleNameText = "tslib";
-      defaultMaximumTruncationLength = 160;
-      noTruncationMaximumTruncationLength = 1e6;
-      stringWriter = createSingleLineStringWriter();
-      GetLiteralTextFlags = /* @__PURE__ */ ((GetLiteralTextFlags2) => {
-        GetLiteralTextFlags2[GetLiteralTextFlags2["None"] = 0] = "None";
-        GetLiteralTextFlags2[GetLiteralTextFlags2["NeverAsciiEscape"] = 1] = "NeverAsciiEscape";
-        GetLiteralTextFlags2[GetLiteralTextFlags2["JsxAttributeEscape"] = 2] = "JsxAttributeEscape";
-        GetLiteralTextFlags2[GetLiteralTextFlags2["TerminateUnterminatedLiterals"] = 4] = "TerminateUnterminatedLiterals";
-        GetLiteralTextFlags2[GetLiteralTextFlags2["AllowNumericSeparator"] = 8] = "AllowNumericSeparator";
-        return GetLiteralTextFlags2;
-      })(GetLiteralTextFlags || {});
-      fullTripleSlashReferencePathRegEx = /^(\/\/\/\s*/;
-      fullTripleSlashReferenceTypeReferenceDirectiveRegEx = /^(\/\/\/\s*/;
-      fullTripleSlashLibReferenceRegEx = /^(\/\/\/\s*/;
-      fullTripleSlashAMDReferencePathRegEx = /^(\/\/\/\s*/;
-      fullTripleSlashAMDModuleRegEx = /^\/\/\/\s*/;
-      defaultLibReferenceRegEx = /^(\/\/\/\s*/;
-      AssignmentKind = /* @__PURE__ */ ((AssignmentKind2) => {
-        AssignmentKind2[AssignmentKind2["None"] = 0] = "None";
-        AssignmentKind2[AssignmentKind2["Definite"] = 1] = "Definite";
-        AssignmentKind2[AssignmentKind2["Compound"] = 2] = "Compound";
-        return AssignmentKind2;
-      })(AssignmentKind || {});
-      FunctionFlags = /* @__PURE__ */ ((FunctionFlags2) => {
-        FunctionFlags2[FunctionFlags2["Normal"] = 0] = "Normal";
-        FunctionFlags2[FunctionFlags2["Generator"] = 1] = "Generator";
-        FunctionFlags2[FunctionFlags2["Async"] = 2] = "Async";
-        FunctionFlags2[FunctionFlags2["Invalid"] = 4] = "Invalid";
-        FunctionFlags2[FunctionFlags2["AsyncGenerator"] = 3] = "AsyncGenerator";
-        return FunctionFlags2;
-      })(FunctionFlags || {});
-      Associativity = /* @__PURE__ */ ((Associativity2) => {
-        Associativity2[Associativity2["Left"] = 0] = "Left";
-        Associativity2[Associativity2["Right"] = 1] = "Right";
-        return Associativity2;
-      })(Associativity || {});
-      OperatorPrecedence = /* @__PURE__ */ ((OperatorPrecedence2) => {
-        OperatorPrecedence2[OperatorPrecedence2["Comma"] = 0] = "Comma";
-        OperatorPrecedence2[OperatorPrecedence2["Spread"] = 1] = "Spread";
-        OperatorPrecedence2[OperatorPrecedence2["Yield"] = 2] = "Yield";
-        OperatorPrecedence2[OperatorPrecedence2["Assignment"] = 3] = "Assignment";
-        OperatorPrecedence2[OperatorPrecedence2["Conditional"] = 4] = "Conditional";
-        OperatorPrecedence2[OperatorPrecedence2["Coalesce"] = 4 /* Conditional */] = "Coalesce";
-        OperatorPrecedence2[OperatorPrecedence2["LogicalOR"] = 5] = "LogicalOR";
-        OperatorPrecedence2[OperatorPrecedence2["LogicalAND"] = 6] = "LogicalAND";
-        OperatorPrecedence2[OperatorPrecedence2["BitwiseOR"] = 7] = "BitwiseOR";
-        OperatorPrecedence2[OperatorPrecedence2["BitwiseXOR"] = 8] = "BitwiseXOR";
-        OperatorPrecedence2[OperatorPrecedence2["BitwiseAND"] = 9] = "BitwiseAND";
-        OperatorPrecedence2[OperatorPrecedence2["Equality"] = 10] = "Equality";
-        OperatorPrecedence2[OperatorPrecedence2["Relational"] = 11] = "Relational";
-        OperatorPrecedence2[OperatorPrecedence2["Shift"] = 12] = "Shift";
-        OperatorPrecedence2[OperatorPrecedence2["Additive"] = 13] = "Additive";
-        OperatorPrecedence2[OperatorPrecedence2["Multiplicative"] = 14] = "Multiplicative";
-        OperatorPrecedence2[OperatorPrecedence2["Exponentiation"] = 15] = "Exponentiation";
-        OperatorPrecedence2[OperatorPrecedence2["Unary"] = 16] = "Unary";
-        OperatorPrecedence2[OperatorPrecedence2["Update"] = 17] = "Update";
-        OperatorPrecedence2[OperatorPrecedence2["LeftHandSide"] = 18] = "LeftHandSide";
-        OperatorPrecedence2[OperatorPrecedence2["Member"] = 19] = "Member";
-        OperatorPrecedence2[OperatorPrecedence2["Primary"] = 20] = "Primary";
-        OperatorPrecedence2[OperatorPrecedence2["Highest"] = 20 /* Primary */] = "Highest";
-        OperatorPrecedence2[OperatorPrecedence2["Lowest"] = 0 /* Comma */] = "Lowest";
-        OperatorPrecedence2[OperatorPrecedence2["Invalid"] = -1] = "Invalid";
-        return OperatorPrecedence2;
-      })(OperatorPrecedence || {});
-      templateSubstitutionRegExp = /\$\{/g;
-      doubleQuoteEscapedCharsRegExp = /[\\\"\u0000-\u001f\t\v\f\b\r\n\u2028\u2029\u0085]/g;
-      singleQuoteEscapedCharsRegExp = /[\\\'\u0000-\u001f\t\v\f\b\r\n\u2028\u2029\u0085]/g;
-      backtickQuoteEscapedCharsRegExp = /\r\n|[\\\`\u0000-\u001f\t\v\f\b\r\u2028\u2029\u0085]/g;
-      escapedCharsMap = new Map(Object.entries({
-        "	": "\\t",
-        "\v": "\\v",
-        "\f": "\\f",
-        "\b": "\\b",
-        "\r": "\\r",
-        "\n": "\\n",
-        "\\": "\\\\",
-        '"': '\\"',
-        "'": "\\'",
-        "`": "\\`",
-        "\u2028": "\\u2028",
-        // lineSeparator
-        "\u2029": "\\u2029",
-        // paragraphSeparator
-        "\x85": "\\u0085",
-        // nextLine
-        "\r\n": "\\r\\n"
-        // special case for CRLFs in backticks
-      }));
-      nonAsciiCharacters = /[^\u0000-\u007F]/g;
-      jsxDoubleQuoteEscapedCharsRegExp = /[\"\u0000-\u001f\u2028\u2029\u0085]/g;
-      jsxSingleQuoteEscapedCharsRegExp = /[\'\u0000-\u001f\u2028\u2029\u0085]/g;
-      jsxEscapedCharsMap = new Map(Object.entries({
-        '"': """,
-        "'": "'"
-      }));
-      indentStrings = ["", "    "];
-      base64Digits = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=";
-      carriageReturnLineFeed = "\r\n";
-      lineFeed = "\n";
-      objectAllocator = {
-        getNodeConstructor: () => Node4,
-        getTokenConstructor: () => Token,
-        getIdentifierConstructor: () => Identifier2,
-        getPrivateIdentifierConstructor: () => Node4,
-        getSourceFileConstructor: () => Node4,
-        getSymbolConstructor: () => Symbol4,
-        getTypeConstructor: () => Type3,
-        getSignatureConstructor: () => Signature2,
-        getSourceMapSourceConstructor: () => SourceMapSource
-      };
-      objectAllocatorPatchers = [];
-      reservedCharacterPattern = /[^\w\s\/]/g;
-      wildcardCharCodes = [42 /* asterisk */, 63 /* question */];
-      commonPackageFolders = ["node_modules", "bower_components", "jspm_packages"];
-      implicitExcludePathRegexPattern = `(?!(${commonPackageFolders.join("|")})(/|$))`;
-      filesMatcher = {
-        /**
-         * Matches any single directory segment unless it is the last segment and a .min.js file
-         * Breakdown:
-         *  [^./]                   # matches everything up to the first . character (excluding directory separators)
-         *  (\\.(?!min\\.js$))?     # matches . characters but not if they are part of the .min.js file extension
-         */
-        singleAsteriskRegexFragment: "([^./]|(\\.(?!min\\.js$))?)*",
-        /**
-         * Regex for the ** wildcard. Matches any number of subdirectories. When used for including
-         * files or directories, does not match subdirectories that start with a . character
-         */
-        doubleAsteriskRegexFragment: `(/${implicitExcludePathRegexPattern}[^/.][^/]*)*?`,
-        replaceWildcardCharacter: (match) => replaceWildcardCharacter(match, filesMatcher.singleAsteriskRegexFragment)
-      };
-      directoriesMatcher = {
-        singleAsteriskRegexFragment: "[^/]*",
-        /**
-         * Regex for the ** wildcard. Matches any number of subdirectories. When used for including
-         * files or directories, does not match subdirectories that start with a . character
-         */
-        doubleAsteriskRegexFragment: `(/${implicitExcludePathRegexPattern}[^/.][^/]*)*?`,
-        replaceWildcardCharacter: (match) => replaceWildcardCharacter(match, directoriesMatcher.singleAsteriskRegexFragment)
-      };
-      excludeMatcher = {
-        singleAsteriskRegexFragment: "[^/]*",
-        doubleAsteriskRegexFragment: "(/.+?)?",
-        replaceWildcardCharacter: (match) => replaceWildcardCharacter(match, excludeMatcher.singleAsteriskRegexFragment)
-      };
-      wildcardMatchers = {
-        files: filesMatcher,
-        directories: directoriesMatcher,
-        exclude: excludeMatcher
-      };
-      supportedTSExtensions = [[".ts" /* Ts */, ".tsx" /* Tsx */, ".d.ts" /* Dts */], [".cts" /* Cts */, ".d.cts" /* Dcts */], [".mts" /* Mts */, ".d.mts" /* Dmts */]];
-      supportedTSExtensionsFlat = flatten(supportedTSExtensions);
-      supportedTSExtensionsWithJson = [...supportedTSExtensions, [".json" /* Json */]];
-      supportedTSExtensionsForExtractExtension = [".d.ts" /* Dts */, ".d.cts" /* Dcts */, ".d.mts" /* Dmts */, ".cts" /* Cts */, ".mts" /* Mts */, ".ts" /* Ts */, ".tsx" /* Tsx */];
-      supportedJSExtensions = [[".js" /* Js */, ".jsx" /* Jsx */], [".mjs" /* Mjs */], [".cjs" /* Cjs */]];
-      supportedJSExtensionsFlat = flatten(supportedJSExtensions);
-      allSupportedExtensions = [[".ts" /* Ts */, ".tsx" /* Tsx */, ".d.ts" /* Dts */, ".js" /* Js */, ".jsx" /* Jsx */], [".cts" /* Cts */, ".d.cts" /* Dcts */, ".cjs" /* Cjs */], [".mts" /* Mts */, ".d.mts" /* Dmts */, ".mjs" /* Mjs */]];
-      allSupportedExtensionsWithJson = [...allSupportedExtensions, [".json" /* Json */]];
-      supportedDeclarationExtensions = [".d.ts" /* Dts */, ".d.cts" /* Dcts */, ".d.mts" /* Dmts */];
-      supportedTSImplementationExtensions = [".ts" /* Ts */, ".cts" /* Cts */, ".mts" /* Mts */, ".tsx" /* Tsx */];
-      extensionsNotSupportingExtensionlessResolution = [".mts" /* Mts */, ".d.mts" /* Dmts */, ".mjs" /* Mjs */, ".cts" /* Cts */, ".d.cts" /* Dcts */, ".cjs" /* Cjs */];
-      ModuleSpecifierEnding = /* @__PURE__ */ ((ModuleSpecifierEnding2) => {
-        ModuleSpecifierEnding2[ModuleSpecifierEnding2["Minimal"] = 0] = "Minimal";
-        ModuleSpecifierEnding2[ModuleSpecifierEnding2["Index"] = 1] = "Index";
-        ModuleSpecifierEnding2[ModuleSpecifierEnding2["JsExtension"] = 2] = "JsExtension";
-        ModuleSpecifierEnding2[ModuleSpecifierEnding2["TsExtension"] = 3] = "TsExtension";
-        return ModuleSpecifierEnding2;
-      })(ModuleSpecifierEnding || {});
-      extensionsToRemove = [".d.ts" /* Dts */, ".d.mts" /* Dmts */, ".d.cts" /* Dcts */, ".mjs" /* Mjs */, ".mts" /* Mts */, ".cjs" /* Cjs */, ".cts" /* Cts */, ".ts" /* Ts */, ".js" /* Js */, ".tsx" /* Tsx */, ".jsx" /* Jsx */, ".json" /* Json */];
-      emptyFileSystemEntries = {
-        files: emptyArray,
-        directories: emptyArray
-      };
-    }
-  });
-
-  // src/compiler/factory/baseNodeFactory.ts
-  function createBaseNodeFactory() {
-    let NodeConstructor2;
-    let TokenConstructor2;
-    let IdentifierConstructor2;
-    let PrivateIdentifierConstructor2;
-    let SourceFileConstructor2;
-    return {
-      createBaseSourceFileNode,
-      createBaseIdentifierNode,
-      createBasePrivateIdentifierNode,
-      createBaseTokenNode,
-      createBaseNode
-    };
-    function createBaseSourceFileNode(kind) {
-      return new (SourceFileConstructor2 || (SourceFileConstructor2 = objectAllocator.getSourceFileConstructor()))(
-        kind,
-        /*pos*/
-        -1,
-        /*end*/
-        -1
-      );
-    }
-    function createBaseIdentifierNode(kind) {
-      return new (IdentifierConstructor2 || (IdentifierConstructor2 = objectAllocator.getIdentifierConstructor()))(
-        kind,
-        /*pos*/
-        -1,
-        /*end*/
-        -1
-      );
-    }
-    function createBasePrivateIdentifierNode(kind) {
-      return new (PrivateIdentifierConstructor2 || (PrivateIdentifierConstructor2 = objectAllocator.getPrivateIdentifierConstructor()))(
-        kind,
-        /*pos*/
-        -1,
-        /*end*/
-        -1
-      );
-    }
-    function createBaseTokenNode(kind) {
-      return new (TokenConstructor2 || (TokenConstructor2 = objectAllocator.getTokenConstructor()))(
-        kind,
-        /*pos*/
-        -1,
-        /*end*/
-        -1
-      );
-    }
-    function createBaseNode(kind) {
-      return new (NodeConstructor2 || (NodeConstructor2 = objectAllocator.getNodeConstructor()))(
-        kind,
-        /*pos*/
-        -1,
-        /*end*/
-        -1
-      );
-    }
-  }
-  var init_baseNodeFactory = __esm({
-    "src/compiler/factory/baseNodeFactory.ts"() {
-      "use strict";
-      init_ts2();
-    }
-  });
-
-  // src/compiler/factory/parenthesizerRules.ts
-  function createParenthesizerRules(factory2) {
-    let binaryLeftOperandParenthesizerCache;
-    let binaryRightOperandParenthesizerCache;
-    return {
-      getParenthesizeLeftSideOfBinaryForOperator,
-      getParenthesizeRightSideOfBinaryForOperator,
-      parenthesizeLeftSideOfBinary,
-      parenthesizeRightSideOfBinary,
-      parenthesizeExpressionOfComputedPropertyName,
-      parenthesizeConditionOfConditionalExpression,
-      parenthesizeBranchOfConditionalExpression,
-      parenthesizeExpressionOfExportDefault,
-      parenthesizeExpressionOfNew,
-      parenthesizeLeftSideOfAccess,
-      parenthesizeOperandOfPostfixUnary,
-      parenthesizeOperandOfPrefixUnary,
-      parenthesizeExpressionsOfCommaDelimitedList,
-      parenthesizeExpressionForDisallowedComma,
-      parenthesizeExpressionOfExpressionStatement,
-      parenthesizeConciseBodyOfArrowFunction,
-      parenthesizeCheckTypeOfConditionalType,
-      parenthesizeExtendsTypeOfConditionalType,
-      parenthesizeConstituentTypesOfUnionType,
-      parenthesizeConstituentTypeOfUnionType,
-      parenthesizeConstituentTypesOfIntersectionType,
-      parenthesizeConstituentTypeOfIntersectionType,
-      parenthesizeOperandOfTypeOperator,
-      parenthesizeOperandOfReadonlyTypeOperator,
-      parenthesizeNonArrayTypeOfPostfixType,
-      parenthesizeElementTypesOfTupleType,
-      parenthesizeElementTypeOfTupleType,
-      parenthesizeTypeOfOptionalType,
-      parenthesizeTypeArguments,
-      parenthesizeLeadingTypeArgument
-    };
-    function getParenthesizeLeftSideOfBinaryForOperator(operatorKind) {
-      binaryLeftOperandParenthesizerCache || (binaryLeftOperandParenthesizerCache = /* @__PURE__ */ new Map());
-      let parenthesizerRule = binaryLeftOperandParenthesizerCache.get(operatorKind);
-      if (!parenthesizerRule) {
-        parenthesizerRule = (node) => parenthesizeLeftSideOfBinary(operatorKind, node);
-        binaryLeftOperandParenthesizerCache.set(operatorKind, parenthesizerRule);
-      }
-      return parenthesizerRule;
-    }
-    function getParenthesizeRightSideOfBinaryForOperator(operatorKind) {
-      binaryRightOperandParenthesizerCache || (binaryRightOperandParenthesizerCache = /* @__PURE__ */ new Map());
-      let parenthesizerRule = binaryRightOperandParenthesizerCache.get(operatorKind);
-      if (!parenthesizerRule) {
-        parenthesizerRule = (node) => parenthesizeRightSideOfBinary(
-          operatorKind,
-          /*leftSide*/
-          void 0,
-          node
-        );
-        binaryRightOperandParenthesizerCache.set(operatorKind, parenthesizerRule);
-      }
-      return parenthesizerRule;
-    }
-    function binaryOperandNeedsParentheses(binaryOperator, operand, isLeftSideOfBinary, leftOperand) {
-      const binaryOperatorPrecedence = getOperatorPrecedence(225 /* BinaryExpression */, binaryOperator);
-      const binaryOperatorAssociativity = getOperatorAssociativity(225 /* BinaryExpression */, binaryOperator);
-      const emittedOperand = skipPartiallyEmittedExpressions(operand);
-      if (!isLeftSideOfBinary && operand.kind === 218 /* ArrowFunction */ && binaryOperatorPrecedence > 3 /* Assignment */) {
-        return true;
-      }
-      const operandPrecedence = getExpressionPrecedence(emittedOperand);
-      switch (compareValues(operandPrecedence, binaryOperatorPrecedence)) {
-        case -1 /* LessThan */:
-          if (!isLeftSideOfBinary && binaryOperatorAssociativity === 1 /* Right */ && operand.kind === 228 /* YieldExpression */) {
-            return false;
-          }
-          return true;
-        case 1 /* GreaterThan */:
-          return false;
-        case 0 /* EqualTo */:
-          if (isLeftSideOfBinary) {
-            return binaryOperatorAssociativity === 1 /* Right */;
-          } else {
-            if (isBinaryExpression(emittedOperand) && emittedOperand.operatorToken.kind === binaryOperator) {
-              if (operatorHasAssociativeProperty(binaryOperator)) {
-                return false;
-              }
-              if (binaryOperator === 40 /* PlusToken */) {
-                const leftKind = leftOperand ? getLiteralKindOfBinaryPlusOperand(leftOperand) : 0 /* Unknown */;
-                if (isLiteralKind(leftKind) && leftKind === getLiteralKindOfBinaryPlusOperand(emittedOperand)) {
-                  return false;
-                }
-              }
-            }
-            const operandAssociativity = getExpressionAssociativity(emittedOperand);
-            return operandAssociativity === 0 /* Left */;
-          }
-      }
-    }
-    function operatorHasAssociativeProperty(binaryOperator) {
-      return binaryOperator === 42 /* AsteriskToken */ || binaryOperator === 52 /* BarToken */ || binaryOperator === 51 /* AmpersandToken */ || binaryOperator === 53 /* CaretToken */ || binaryOperator === 28 /* CommaToken */;
-    }
-    function getLiteralKindOfBinaryPlusOperand(node) {
-      node = skipPartiallyEmittedExpressions(node);
-      if (isLiteralKind(node.kind)) {
-        return node.kind;
-      }
-      if (node.kind === 225 /* BinaryExpression */ && node.operatorToken.kind === 40 /* PlusToken */) {
-        if (node.cachedLiteralKind !== void 0) {
-          return node.cachedLiteralKind;
-        }
-        const leftKind = getLiteralKindOfBinaryPlusOperand(node.left);
-        const literalKind = isLiteralKind(leftKind) && leftKind === getLiteralKindOfBinaryPlusOperand(node.right) ? leftKind : 0 /* Unknown */;
-        node.cachedLiteralKind = literalKind;
-        return literalKind;
-      }
-      return 0 /* Unknown */;
-    }
-    function parenthesizeBinaryOperand(binaryOperator, operand, isLeftSideOfBinary, leftOperand) {
-      const skipped = skipPartiallyEmittedExpressions(operand);
-      if (skipped.kind === 216 /* ParenthesizedExpression */) {
-        return operand;
-      }
-      return binaryOperandNeedsParentheses(binaryOperator, operand, isLeftSideOfBinary, leftOperand) ? factory2.createParenthesizedExpression(operand) : operand;
-    }
-    function parenthesizeLeftSideOfBinary(binaryOperator, leftSide) {
-      return parenthesizeBinaryOperand(
-        binaryOperator,
-        leftSide,
-        /*isLeftSideOfBinary*/
-        true
-      );
-    }
-    function parenthesizeRightSideOfBinary(binaryOperator, leftSide, rightSide) {
-      return parenthesizeBinaryOperand(
-        binaryOperator,
-        rightSide,
-        /*isLeftSideOfBinary*/
-        false,
-        leftSide
-      );
-    }
-    function parenthesizeExpressionOfComputedPropertyName(expression) {
-      return isCommaSequence(expression) ? factory2.createParenthesizedExpression(expression) : expression;
-    }
-    function parenthesizeConditionOfConditionalExpression(condition) {
-      const conditionalPrecedence = getOperatorPrecedence(226 /* ConditionalExpression */, 58 /* QuestionToken */);
-      const emittedCondition = skipPartiallyEmittedExpressions(condition);
-      const conditionPrecedence = getExpressionPrecedence(emittedCondition);
-      if (compareValues(conditionPrecedence, conditionalPrecedence) !== 1 /* GreaterThan */) {
-        return factory2.createParenthesizedExpression(condition);
-      }
-      return condition;
-    }
-    function parenthesizeBranchOfConditionalExpression(branch) {
-      const emittedExpression = skipPartiallyEmittedExpressions(branch);
-      return isCommaSequence(emittedExpression) ? factory2.createParenthesizedExpression(branch) : branch;
-    }
-    function parenthesizeExpressionOfExportDefault(expression) {
-      const check = skipPartiallyEmittedExpressions(expression);
-      let needsParens = isCommaSequence(check);
-      if (!needsParens) {
-        switch (getLeftmostExpression(
-          check,
-          /*stopAtCallExpressions*/
-          false
-        ).kind) {
-          case 230 /* ClassExpression */:
-          case 217 /* FunctionExpression */:
-            needsParens = true;
-        }
-      }
-      return needsParens ? factory2.createParenthesizedExpression(expression) : expression;
-    }
-    function parenthesizeExpressionOfNew(expression) {
-      const leftmostExpr = getLeftmostExpression(
-        expression,
-        /*stopAtCallExpressions*/
-        true
-      );
-      switch (leftmostExpr.kind) {
-        case 212 /* CallExpression */:
-          return factory2.createParenthesizedExpression(expression);
-        case 213 /* NewExpression */:
-          return !leftmostExpr.arguments ? factory2.createParenthesizedExpression(expression) : expression;
-      }
-      return parenthesizeLeftSideOfAccess(expression);
-    }
-    function parenthesizeLeftSideOfAccess(expression, optionalChain) {
-      const emittedExpression = skipPartiallyEmittedExpressions(expression);
-      if (isLeftHandSideExpression(emittedExpression) && (emittedExpression.kind !== 213 /* NewExpression */ || emittedExpression.arguments) && (optionalChain || !isOptionalChain(emittedExpression))) {
-        return expression;
-      }
-      return setTextRange(factory2.createParenthesizedExpression(expression), expression);
-    }
-    function parenthesizeOperandOfPostfixUnary(operand) {
-      return isLeftHandSideExpression(operand) ? operand : setTextRange(factory2.createParenthesizedExpression(operand), operand);
-    }
-    function parenthesizeOperandOfPrefixUnary(operand) {
-      return isUnaryExpression(operand) ? operand : setTextRange(factory2.createParenthesizedExpression(operand), operand);
-    }
-    function parenthesizeExpressionsOfCommaDelimitedList(elements) {
-      const result = sameMap(elements, parenthesizeExpressionForDisallowedComma);
-      return setTextRange(factory2.createNodeArray(result, elements.hasTrailingComma), elements);
-    }
-    function parenthesizeExpressionForDisallowedComma(expression) {
-      const emittedExpression = skipPartiallyEmittedExpressions(expression);
-      const expressionPrecedence = getExpressionPrecedence(emittedExpression);
-      const commaPrecedence = getOperatorPrecedence(225 /* BinaryExpression */, 28 /* CommaToken */);
-      return expressionPrecedence > commaPrecedence ? expression : setTextRange(factory2.createParenthesizedExpression(expression), expression);
-    }
-    function parenthesizeExpressionOfExpressionStatement(expression) {
-      const emittedExpression = skipPartiallyEmittedExpressions(expression);
-      if (isCallExpression(emittedExpression)) {
-        const callee = emittedExpression.expression;
-        const kind = skipPartiallyEmittedExpressions(callee).kind;
-        if (kind === 217 /* FunctionExpression */ || kind === 218 /* ArrowFunction */) {
-          const updated = factory2.updateCallExpression(
-            emittedExpression,
-            setTextRange(factory2.createParenthesizedExpression(callee), callee),
-            emittedExpression.typeArguments,
-            emittedExpression.arguments
-          );
-          return factory2.restoreOuterExpressions(expression, updated, 8 /* PartiallyEmittedExpressions */);
-        }
-      }
-      const leftmostExpressionKind = getLeftmostExpression(
-        emittedExpression,
-        /*stopAtCallExpressions*/
-        false
-      ).kind;
-      if (leftmostExpressionKind === 209 /* ObjectLiteralExpression */ || leftmostExpressionKind === 217 /* FunctionExpression */) {
-        return setTextRange(factory2.createParenthesizedExpression(expression), expression);
-      }
-      return expression;
-    }
-    function parenthesizeConciseBodyOfArrowFunction(body) {
-      if (!isBlock(body) && (isCommaSequence(body) || getLeftmostExpression(
-        body,
-        /*stopAtCallExpressions*/
-        false
-      ).kind === 209 /* ObjectLiteralExpression */)) {
-        return setTextRange(factory2.createParenthesizedExpression(body), body);
-      }
-      return body;
-    }
-    function parenthesizeCheckTypeOfConditionalType(checkType) {
-      switch (checkType.kind) {
-        case 183 /* FunctionType */:
-        case 184 /* ConstructorType */:
-        case 193 /* ConditionalType */:
-          return factory2.createParenthesizedType(checkType);
-      }
-      return checkType;
-    }
-    function parenthesizeExtendsTypeOfConditionalType(extendsType) {
-      switch (extendsType.kind) {
-        case 193 /* ConditionalType */:
-          return factory2.createParenthesizedType(extendsType);
-      }
-      return extendsType;
-    }
-    function parenthesizeConstituentTypeOfUnionType(type) {
-      switch (type.kind) {
-        case 191 /* UnionType */:
-        case 192 /* IntersectionType */:
-          return factory2.createParenthesizedType(type);
-      }
-      return parenthesizeCheckTypeOfConditionalType(type);
-    }
-    function parenthesizeConstituentTypesOfUnionType(members) {
-      return factory2.createNodeArray(sameMap(members, parenthesizeConstituentTypeOfUnionType));
-    }
-    function parenthesizeConstituentTypeOfIntersectionType(type) {
-      switch (type.kind) {
-        case 191 /* UnionType */:
-        case 192 /* IntersectionType */:
-          return factory2.createParenthesizedType(type);
-      }
-      return parenthesizeConstituentTypeOfUnionType(type);
-    }
-    function parenthesizeConstituentTypesOfIntersectionType(members) {
-      return factory2.createNodeArray(sameMap(members, parenthesizeConstituentTypeOfIntersectionType));
-    }
-    function parenthesizeOperandOfTypeOperator(type) {
-      switch (type.kind) {
-        case 192 /* IntersectionType */:
-          return factory2.createParenthesizedType(type);
-      }
-      return parenthesizeConstituentTypeOfIntersectionType(type);
-    }
-    function parenthesizeOperandOfReadonlyTypeOperator(type) {
-      switch (type.kind) {
-        case 197 /* TypeOperator */:
-          return factory2.createParenthesizedType(type);
-      }
-      return parenthesizeOperandOfTypeOperator(type);
-    }
-    function parenthesizeNonArrayTypeOfPostfixType(type) {
-      switch (type.kind) {
-        case 194 /* InferType */:
-        case 197 /* TypeOperator */:
-        case 185 /* TypeQuery */:
-          return factory2.createParenthesizedType(type);
-      }
-      return parenthesizeOperandOfTypeOperator(type);
-    }
-    function parenthesizeElementTypesOfTupleType(types) {
-      return factory2.createNodeArray(sameMap(types, parenthesizeElementTypeOfTupleType));
-    }
-    function parenthesizeElementTypeOfTupleType(type) {
-      if (hasJSDocPostfixQuestion(type))
-        return factory2.createParenthesizedType(type);
-      return type;
-    }
-    function hasJSDocPostfixQuestion(type) {
-      if (isJSDocNullableType(type))
-        return type.postfix;
-      if (isNamedTupleMember(type))
-        return hasJSDocPostfixQuestion(type.type);
-      if (isFunctionTypeNode(type) || isConstructorTypeNode(type) || isTypeOperatorNode(type))
-        return hasJSDocPostfixQuestion(type.type);
-      if (isConditionalTypeNode(type))
-        return hasJSDocPostfixQuestion(type.falseType);
-      if (isUnionTypeNode(type))
-        return hasJSDocPostfixQuestion(last(type.types));
-      if (isIntersectionTypeNode(type))
-        return hasJSDocPostfixQuestion(last(type.types));
-      if (isInferTypeNode(type))
-        return !!type.typeParameter.constraint && hasJSDocPostfixQuestion(type.typeParameter.constraint);
-      return false;
-    }
-    function parenthesizeTypeOfOptionalType(type) {
-      if (hasJSDocPostfixQuestion(type))
-        return factory2.createParenthesizedType(type);
-      return parenthesizeNonArrayTypeOfPostfixType(type);
-    }
-    function parenthesizeLeadingTypeArgument(node) {
-      return isFunctionOrConstructorTypeNode(node) && node.typeParameters ? factory2.createParenthesizedType(node) : node;
-    }
-    function parenthesizeOrdinalTypeArgument(node, i) {
-      return i === 0 ? parenthesizeLeadingTypeArgument(node) : node;
-    }
-    function parenthesizeTypeArguments(typeArguments) {
-      if (some(typeArguments)) {
-        return factory2.createNodeArray(sameMap(typeArguments, parenthesizeOrdinalTypeArgument));
-      }
-    }
-  }
-  var nullParenthesizerRules;
-  var init_parenthesizerRules = __esm({
-    "src/compiler/factory/parenthesizerRules.ts"() {
-      "use strict";
-      init_ts2();
-      nullParenthesizerRules = {
-        getParenthesizeLeftSideOfBinaryForOperator: (_) => identity,
-        getParenthesizeRightSideOfBinaryForOperator: (_) => identity,
-        parenthesizeLeftSideOfBinary: (_binaryOperator, leftSide) => leftSide,
-        parenthesizeRightSideOfBinary: (_binaryOperator, _leftSide, rightSide) => rightSide,
-        parenthesizeExpressionOfComputedPropertyName: identity,
-        parenthesizeConditionOfConditionalExpression: identity,
-        parenthesizeBranchOfConditionalExpression: identity,
-        parenthesizeExpressionOfExportDefault: identity,
-        parenthesizeExpressionOfNew: (expression) => cast(expression, isLeftHandSideExpression),
-        parenthesizeLeftSideOfAccess: (expression) => cast(expression, isLeftHandSideExpression),
-        parenthesizeOperandOfPostfixUnary: (operand) => cast(operand, isLeftHandSideExpression),
-        parenthesizeOperandOfPrefixUnary: (operand) => cast(operand, isUnaryExpression),
-        parenthesizeExpressionsOfCommaDelimitedList: (nodes) => cast(nodes, isNodeArray),
-        parenthesizeExpressionForDisallowedComma: identity,
-        parenthesizeExpressionOfExpressionStatement: identity,
-        parenthesizeConciseBodyOfArrowFunction: identity,
-        parenthesizeCheckTypeOfConditionalType: identity,
-        parenthesizeExtendsTypeOfConditionalType: identity,
-        parenthesizeConstituentTypesOfUnionType: (nodes) => cast(nodes, isNodeArray),
-        parenthesizeConstituentTypeOfUnionType: identity,
-        parenthesizeConstituentTypesOfIntersectionType: (nodes) => cast(nodes, isNodeArray),
-        parenthesizeConstituentTypeOfIntersectionType: identity,
-        parenthesizeOperandOfTypeOperator: identity,
-        parenthesizeOperandOfReadonlyTypeOperator: identity,
-        parenthesizeNonArrayTypeOfPostfixType: identity,
-        parenthesizeElementTypesOfTupleType: (nodes) => cast(nodes, isNodeArray),
-        parenthesizeElementTypeOfTupleType: identity,
-        parenthesizeTypeOfOptionalType: identity,
-        parenthesizeTypeArguments: (nodes) => nodes && cast(nodes, isNodeArray),
-        parenthesizeLeadingTypeArgument: identity
-      };
-    }
-  });
-
-  // src/compiler/factory/nodeConverters.ts
-  function createNodeConverters(factory2) {
-    return {
-      convertToFunctionBlock,
-      convertToFunctionExpression,
-      convertToArrayAssignmentElement,
-      convertToObjectAssignmentElement,
-      convertToAssignmentPattern,
-      convertToObjectAssignmentPattern,
-      convertToArrayAssignmentPattern,
-      convertToAssignmentElementTarget
-    };
-    function convertToFunctionBlock(node, multiLine) {
-      if (isBlock(node))
-        return node;
-      const returnStatement = factory2.createReturnStatement(node);
-      setTextRange(returnStatement, node);
-      const body = factory2.createBlock([returnStatement], multiLine);
-      setTextRange(body, node);
-      return body;
-    }
-    function convertToFunctionExpression(node) {
-      if (!node.body)
-        return Debug.fail(`Cannot convert a FunctionDeclaration without a body`);
-      const updated = factory2.createFunctionExpression(
-        getModifiers(node),
-        node.asteriskToken,
-        node.name,
-        node.typeParameters,
-        node.parameters,
-        node.type,
-        node.body
-      );
-      setOriginalNode(updated, node);
-      setTextRange(updated, node);
-      if (getStartsOnNewLine(node)) {
-        setStartsOnNewLine(
-          updated,
-          /*newLine*/
-          true
-        );
-      }
-      return updated;
-    }
-    function convertToArrayAssignmentElement(element) {
-      if (isBindingElement(element)) {
-        if (element.dotDotDotToken) {
-          Debug.assertNode(element.name, isIdentifier);
-          return setOriginalNode(setTextRange(factory2.createSpreadElement(element.name), element), element);
-        }
-        const expression = convertToAssignmentElementTarget(element.name);
-        return element.initializer ? setOriginalNode(
-          setTextRange(
-            factory2.createAssignment(expression, element.initializer),
-            element
-          ),
-          element
-        ) : expression;
-      }
-      return cast(element, isExpression);
-    }
-    function convertToObjectAssignmentElement(element) {
-      if (isBindingElement(element)) {
-        if (element.dotDotDotToken) {
-          Debug.assertNode(element.name, isIdentifier);
-          return setOriginalNode(setTextRange(factory2.createSpreadAssignment(element.name), element), element);
-        }
-        if (element.propertyName) {
-          const expression = convertToAssignmentElementTarget(element.name);
-          return setOriginalNode(setTextRange(factory2.createPropertyAssignment(element.propertyName, element.initializer ? factory2.createAssignment(expression, element.initializer) : expression), element), element);
-        }
-        Debug.assertNode(element.name, isIdentifier);
-        return setOriginalNode(setTextRange(factory2.createShorthandPropertyAssignment(element.name, element.initializer), element), element);
-      }
-      return cast(element, isObjectLiteralElementLike);
-    }
-    function convertToAssignmentPattern(node) {
-      switch (node.kind) {
-        case 206 /* ArrayBindingPattern */:
-        case 208 /* ArrayLiteralExpression */:
-          return convertToArrayAssignmentPattern(node);
-        case 205 /* ObjectBindingPattern */:
-        case 209 /* ObjectLiteralExpression */:
-          return convertToObjectAssignmentPattern(node);
-      }
-    }
-    function convertToObjectAssignmentPattern(node) {
-      if (isObjectBindingPattern(node)) {
-        return setOriginalNode(
-          setTextRange(
-            factory2.createObjectLiteralExpression(map(node.elements, convertToObjectAssignmentElement)),
-            node
-          ),
-          node
-        );
-      }
-      return cast(node, isObjectLiteralExpression);
-    }
-    function convertToArrayAssignmentPattern(node) {
-      if (isArrayBindingPattern(node)) {
-        return setOriginalNode(
-          setTextRange(
-            factory2.createArrayLiteralExpression(map(node.elements, convertToArrayAssignmentElement)),
-            node
-          ),
-          node
-        );
-      }
-      return cast(node, isArrayLiteralExpression);
-    }
-    function convertToAssignmentElementTarget(node) {
-      if (isBindingPattern(node)) {
-        return convertToAssignmentPattern(node);
-      }
-      return cast(node, isExpression);
-    }
-  }
-  var nullNodeConverters;
-  var init_nodeConverters = __esm({
-    "src/compiler/factory/nodeConverters.ts"() {
-      "use strict";
-      init_ts2();
-      nullNodeConverters = {
-        convertToFunctionBlock: notImplemented,
-        convertToFunctionExpression: notImplemented,
-        convertToArrayAssignmentElement: notImplemented,
-        convertToObjectAssignmentElement: notImplemented,
-        convertToAssignmentPattern: notImplemented,
-        convertToObjectAssignmentPattern: notImplemented,
-        convertToArrayAssignmentPattern: notImplemented,
-        convertToAssignmentElementTarget: notImplemented
-      };
-    }
-  });
-
-  // src/compiler/factory/nodeFactory.ts
-  function addNodeFactoryPatcher(fn) {
-    nodeFactoryPatchers.push(fn);
-  }
-  function createNodeFactory(flags, baseFactory2) {
-    const update = flags & 8 /* NoOriginalNode */ ? updateWithoutOriginal : updateWithOriginal;
-    const parenthesizerRules = memoize(() => flags & 1 /* NoParenthesizerRules */ ? nullParenthesizerRules : createParenthesizerRules(factory2));
-    const converters = memoize(() => flags & 2 /* NoNodeConverters */ ? nullNodeConverters : createNodeConverters(factory2));
-    const getBinaryCreateFunction = memoizeOne((operator) => (left, right) => createBinaryExpression(left, operator, right));
-    const getPrefixUnaryCreateFunction = memoizeOne((operator) => (operand) => createPrefixUnaryExpression(operator, operand));
-    const getPostfixUnaryCreateFunction = memoizeOne((operator) => (operand) => createPostfixUnaryExpression(operand, operator));
-    const getJSDocPrimaryTypeCreateFunction = memoizeOne((kind) => () => createJSDocPrimaryTypeWorker(kind));
-    const getJSDocUnaryTypeCreateFunction = memoizeOne((kind) => (type) => createJSDocUnaryTypeWorker(kind, type));
-    const getJSDocUnaryTypeUpdateFunction = memoizeOne((kind) => (node, type) => updateJSDocUnaryTypeWorker(kind, node, type));
-    const getJSDocPrePostfixUnaryTypeCreateFunction = memoizeOne((kind) => (type, postfix) => createJSDocPrePostfixUnaryTypeWorker(kind, type, postfix));
-    const getJSDocPrePostfixUnaryTypeUpdateFunction = memoizeOne((kind) => (node, type) => updateJSDocPrePostfixUnaryTypeWorker(kind, node, type));
-    const getJSDocSimpleTagCreateFunction = memoizeOne((kind) => (tagName, comment) => createJSDocSimpleTagWorker(kind, tagName, comment));
-    const getJSDocSimpleTagUpdateFunction = memoizeOne((kind) => (node, tagName, comment) => updateJSDocSimpleTagWorker(kind, node, tagName, comment));
-    const getJSDocTypeLikeTagCreateFunction = memoizeOne((kind) => (tagName, typeExpression, comment) => createJSDocTypeLikeTagWorker(kind, tagName, typeExpression, comment));
-    const getJSDocTypeLikeTagUpdateFunction = memoizeOne((kind) => (node, tagName, typeExpression, comment) => updateJSDocTypeLikeTagWorker(kind, node, tagName, typeExpression, comment));
-    const factory2 = {
-      get parenthesizer() {
-        return parenthesizerRules();
-      },
-      get converters() {
-        return converters();
-      },
-      baseFactory: baseFactory2,
-      flags,
-      createNodeArray,
-      createNumericLiteral,
-      createBigIntLiteral,
-      createStringLiteral,
-      createStringLiteralFromNode,
-      createRegularExpressionLiteral,
-      createLiteralLikeNode,
-      createIdentifier,
-      createTempVariable,
-      createLoopVariable,
-      createUniqueName,
-      getGeneratedNameForNode,
-      createPrivateIdentifier,
-      createUniquePrivateName,
-      getGeneratedPrivateNameForNode,
-      createToken,
-      createSuper,
-      createThis,
-      createNull,
-      createTrue,
-      createFalse,
-      createModifier,
-      createModifiersFromModifierFlags,
-      createQualifiedName,
-      updateQualifiedName,
-      createComputedPropertyName,
-      updateComputedPropertyName,
-      createTypeParameterDeclaration,
-      updateTypeParameterDeclaration,
-      createParameterDeclaration,
-      updateParameterDeclaration,
-      createDecorator,
-      updateDecorator,
-      createPropertySignature,
-      updatePropertySignature,
-      createPropertyDeclaration,
-      updatePropertyDeclaration: updatePropertyDeclaration2,
-      createMethodSignature,
-      updateMethodSignature,
-      createMethodDeclaration,
-      updateMethodDeclaration,
-      createConstructorDeclaration,
-      updateConstructorDeclaration,
-      createGetAccessorDeclaration,
-      updateGetAccessorDeclaration,
-      createSetAccessorDeclaration,
-      updateSetAccessorDeclaration,
-      createCallSignature,
-      updateCallSignature,
-      createConstructSignature,
-      updateConstructSignature,
-      createIndexSignature,
-      updateIndexSignature,
-      createClassStaticBlockDeclaration,
-      updateClassStaticBlockDeclaration,
-      createTemplateLiteralTypeSpan,
-      updateTemplateLiteralTypeSpan,
-      createKeywordTypeNode,
-      createTypePredicateNode,
-      updateTypePredicateNode,
-      createTypeReferenceNode,
-      updateTypeReferenceNode,
-      createFunctionTypeNode,
-      updateFunctionTypeNode,
-      createConstructorTypeNode,
-      updateConstructorTypeNode,
-      createTypeQueryNode,
-      updateTypeQueryNode,
-      createTypeLiteralNode,
-      updateTypeLiteralNode,
-      createArrayTypeNode,
-      updateArrayTypeNode,
-      createTupleTypeNode,
-      updateTupleTypeNode,
-      createNamedTupleMember,
-      updateNamedTupleMember,
-      createOptionalTypeNode,
-      updateOptionalTypeNode,
-      createRestTypeNode,
-      updateRestTypeNode,
-      createUnionTypeNode,
-      updateUnionTypeNode,
-      createIntersectionTypeNode,
-      updateIntersectionTypeNode,
-      createConditionalTypeNode,
-      updateConditionalTypeNode,
-      createInferTypeNode,
-      updateInferTypeNode,
-      createImportTypeNode,
-      updateImportTypeNode,
-      createParenthesizedType,
-      updateParenthesizedType,
-      createThisTypeNode,
-      createTypeOperatorNode,
-      updateTypeOperatorNode,
-      createIndexedAccessTypeNode,
-      updateIndexedAccessTypeNode,
-      createMappedTypeNode,
-      updateMappedTypeNode,
-      createLiteralTypeNode,
-      updateLiteralTypeNode,
-      createTemplateLiteralType,
-      updateTemplateLiteralType,
-      createObjectBindingPattern,
-      updateObjectBindingPattern,
-      createArrayBindingPattern,
-      updateArrayBindingPattern,
-      createBindingElement,
-      updateBindingElement,
-      createArrayLiteralExpression,
-      updateArrayLiteralExpression,
-      createObjectLiteralExpression,
-      updateObjectLiteralExpression,
-      createPropertyAccessExpression: flags & 4 /* NoIndentationOnFreshPropertyAccess */ ? (expression, name) => setEmitFlags(createPropertyAccessExpression(expression, name), 262144 /* NoIndentation */) : createPropertyAccessExpression,
-      updatePropertyAccessExpression,
-      createPropertyAccessChain: flags & 4 /* NoIndentationOnFreshPropertyAccess */ ? (expression, questionDotToken, name) => setEmitFlags(createPropertyAccessChain(expression, questionDotToken, name), 262144 /* NoIndentation */) : createPropertyAccessChain,
-      updatePropertyAccessChain,
-      createElementAccessExpression,
-      updateElementAccessExpression,
-      createElementAccessChain,
-      updateElementAccessChain,
-      createCallExpression,
-      updateCallExpression,
-      createCallChain,
-      updateCallChain,
-      createNewExpression,
-      updateNewExpression,
-      createTaggedTemplateExpression,
-      updateTaggedTemplateExpression,
-      createTypeAssertion,
-      updateTypeAssertion,
-      createParenthesizedExpression,
-      updateParenthesizedExpression,
-      createFunctionExpression,
-      updateFunctionExpression,
-      createArrowFunction,
-      updateArrowFunction,
-      createDeleteExpression,
-      updateDeleteExpression,
-      createTypeOfExpression,
-      updateTypeOfExpression,
-      createVoidExpression,
-      updateVoidExpression,
-      createAwaitExpression,
-      updateAwaitExpression,
-      createPrefixUnaryExpression,
-      updatePrefixUnaryExpression,
-      createPostfixUnaryExpression,
-      updatePostfixUnaryExpression,
-      createBinaryExpression,
-      updateBinaryExpression,
-      createConditionalExpression,
-      updateConditionalExpression,
-      createTemplateExpression,
-      updateTemplateExpression,
-      createTemplateHead,
-      createTemplateMiddle,
-      createTemplateTail,
-      createNoSubstitutionTemplateLiteral,
-      createTemplateLiteralLikeNode,
-      createYieldExpression,
-      updateYieldExpression,
-      createSpreadElement,
-      updateSpreadElement,
-      createClassExpression,
-      updateClassExpression,
-      createOmittedExpression,
-      createExpressionWithTypeArguments,
-      updateExpressionWithTypeArguments,
-      createAsExpression,
-      updateAsExpression,
-      createNonNullExpression,
-      updateNonNullExpression,
-      createSatisfiesExpression,
-      updateSatisfiesExpression,
-      createNonNullChain,
-      updateNonNullChain,
-      createMetaProperty,
-      updateMetaProperty,
-      createTemplateSpan,
-      updateTemplateSpan,
-      createSemicolonClassElement,
-      createBlock,
-      updateBlock,
-      createVariableStatement,
-      updateVariableStatement,
-      createEmptyStatement,
-      createExpressionStatement,
-      updateExpressionStatement,
-      createIfStatement,
-      updateIfStatement,
-      createDoStatement,
-      updateDoStatement,
-      createWhileStatement,
-      updateWhileStatement,
-      createForStatement,
-      updateForStatement,
-      createForInStatement,
-      updateForInStatement,
-      createForOfStatement,
-      updateForOfStatement,
-      createContinueStatement,
-      updateContinueStatement,
-      createBreakStatement,
-      updateBreakStatement,
-      createReturnStatement,
-      updateReturnStatement,
-      createWithStatement,
-      updateWithStatement,
-      createSwitchStatement,
-      updateSwitchStatement,
-      createLabeledStatement,
-      updateLabeledStatement,
-      createThrowStatement,
-      updateThrowStatement,
-      createTryStatement,
-      updateTryStatement,
-      createDebuggerStatement,
-      createVariableDeclaration,
-      updateVariableDeclaration,
-      createVariableDeclarationList,
-      updateVariableDeclarationList,
-      createFunctionDeclaration,
-      updateFunctionDeclaration,
-      createClassDeclaration,
-      updateClassDeclaration,
-      createInterfaceDeclaration,
-      updateInterfaceDeclaration,
-      createTypeAliasDeclaration,
-      updateTypeAliasDeclaration,
-      createEnumDeclaration,
-      updateEnumDeclaration,
-      createModuleDeclaration,
-      updateModuleDeclaration,
-      createModuleBlock,
-      updateModuleBlock,
-      createCaseBlock,
-      updateCaseBlock,
-      createNamespaceExportDeclaration,
-      updateNamespaceExportDeclaration,
-      createImportEqualsDeclaration,
-      updateImportEqualsDeclaration,
-      createImportDeclaration,
-      updateImportDeclaration,
-      createImportClause,
-      updateImportClause,
-      createAssertClause,
-      updateAssertClause,
-      createAssertEntry,
-      updateAssertEntry,
-      createImportTypeAssertionContainer,
-      updateImportTypeAssertionContainer,
-      createNamespaceImport,
-      updateNamespaceImport,
-      createNamespaceExport,
-      updateNamespaceExport,
-      createNamedImports,
-      updateNamedImports,
-      createImportSpecifier,
-      updateImportSpecifier,
-      createExportAssignment: createExportAssignment2,
-      updateExportAssignment,
-      createExportDeclaration,
-      updateExportDeclaration,
-      createNamedExports,
-      updateNamedExports,
-      createExportSpecifier,
-      updateExportSpecifier,
-      createMissingDeclaration,
-      createExternalModuleReference,
-      updateExternalModuleReference,
-      // lazily load factory members for JSDoc types with similar structure
-      get createJSDocAllType() {
-        return getJSDocPrimaryTypeCreateFunction(318 /* JSDocAllType */);
-      },
-      get createJSDocUnknownType() {
-        return getJSDocPrimaryTypeCreateFunction(319 /* JSDocUnknownType */);
-      },
-      get createJSDocNonNullableType() {
-        return getJSDocPrePostfixUnaryTypeCreateFunction(321 /* JSDocNonNullableType */);
-      },
-      get updateJSDocNonNullableType() {
-        return getJSDocPrePostfixUnaryTypeUpdateFunction(321 /* JSDocNonNullableType */);
-      },
-      get createJSDocNullableType() {
-        return getJSDocPrePostfixUnaryTypeCreateFunction(320 /* JSDocNullableType */);
-      },
-      get updateJSDocNullableType() {
-        return getJSDocPrePostfixUnaryTypeUpdateFunction(320 /* JSDocNullableType */);
-      },
-      get createJSDocOptionalType() {
-        return getJSDocUnaryTypeCreateFunction(322 /* JSDocOptionalType */);
-      },
-      get updateJSDocOptionalType() {
-        return getJSDocUnaryTypeUpdateFunction(322 /* JSDocOptionalType */);
-      },
-      get createJSDocVariadicType() {
-        return getJSDocUnaryTypeCreateFunction(324 /* JSDocVariadicType */);
-      },
-      get updateJSDocVariadicType() {
-        return getJSDocUnaryTypeUpdateFunction(324 /* JSDocVariadicType */);
-      },
-      get createJSDocNamepathType() {
-        return getJSDocUnaryTypeCreateFunction(325 /* JSDocNamepathType */);
-      },
-      get updateJSDocNamepathType() {
-        return getJSDocUnaryTypeUpdateFunction(325 /* JSDocNamepathType */);
-      },
-      createJSDocFunctionType,
-      updateJSDocFunctionType,
-      createJSDocTypeLiteral,
-      updateJSDocTypeLiteral,
-      createJSDocTypeExpression,
-      updateJSDocTypeExpression,
-      createJSDocSignature,
-      updateJSDocSignature,
-      createJSDocTemplateTag,
-      updateJSDocTemplateTag,
-      createJSDocTypedefTag,
-      updateJSDocTypedefTag,
-      createJSDocParameterTag,
-      updateJSDocParameterTag,
-      createJSDocPropertyTag,
-      updateJSDocPropertyTag,
-      createJSDocCallbackTag,
-      updateJSDocCallbackTag,
-      createJSDocOverloadTag,
-      updateJSDocOverloadTag,
-      createJSDocAugmentsTag,
-      updateJSDocAugmentsTag,
-      createJSDocImplementsTag,
-      updateJSDocImplementsTag,
-      createJSDocSeeTag,
-      updateJSDocSeeTag,
-      createJSDocNameReference,
-      updateJSDocNameReference,
-      createJSDocMemberName,
-      updateJSDocMemberName,
-      createJSDocLink,
-      updateJSDocLink,
-      createJSDocLinkCode,
-      updateJSDocLinkCode,
-      createJSDocLinkPlain,
-      updateJSDocLinkPlain,
-      // lazily load factory members for JSDoc tags with similar structure
-      get createJSDocTypeTag() {
-        return getJSDocTypeLikeTagCreateFunction(350 /* JSDocTypeTag */);
-      },
-      get updateJSDocTypeTag() {
-        return getJSDocTypeLikeTagUpdateFunction(350 /* JSDocTypeTag */);
-      },
-      get createJSDocReturnTag() {
-        return getJSDocTypeLikeTagCreateFunction(348 /* JSDocReturnTag */);
-      },
-      get updateJSDocReturnTag() {
-        return getJSDocTypeLikeTagUpdateFunction(348 /* JSDocReturnTag */);
-      },
-      get createJSDocThisTag() {
-        return getJSDocTypeLikeTagCreateFunction(349 /* JSDocThisTag */);
-      },
-      get updateJSDocThisTag() {
-        return getJSDocTypeLikeTagUpdateFunction(349 /* JSDocThisTag */);
-      },
-      get createJSDocAuthorTag() {
-        return getJSDocSimpleTagCreateFunction(336 /* JSDocAuthorTag */);
-      },
-      get updateJSDocAuthorTag() {
-        return getJSDocSimpleTagUpdateFunction(336 /* JSDocAuthorTag */);
-      },
-      get createJSDocClassTag() {
-        return getJSDocSimpleTagCreateFunction(338 /* JSDocClassTag */);
-      },
-      get updateJSDocClassTag() {
-        return getJSDocSimpleTagUpdateFunction(338 /* JSDocClassTag */);
-      },
-      get createJSDocPublicTag() {
-        return getJSDocSimpleTagCreateFunction(339 /* JSDocPublicTag */);
-      },
-      get updateJSDocPublicTag() {
-        return getJSDocSimpleTagUpdateFunction(339 /* JSDocPublicTag */);
-      },
-      get createJSDocPrivateTag() {
-        return getJSDocSimpleTagCreateFunction(340 /* JSDocPrivateTag */);
-      },
-      get updateJSDocPrivateTag() {
-        return getJSDocSimpleTagUpdateFunction(340 /* JSDocPrivateTag */);
-      },
-      get createJSDocProtectedTag() {
-        return getJSDocSimpleTagCreateFunction(341 /* JSDocProtectedTag */);
-      },
-      get updateJSDocProtectedTag() {
-        return getJSDocSimpleTagUpdateFunction(341 /* JSDocProtectedTag */);
-      },
-      get createJSDocReadonlyTag() {
-        return getJSDocSimpleTagCreateFunction(342 /* JSDocReadonlyTag */);
-      },
-      get updateJSDocReadonlyTag() {
-        return getJSDocSimpleTagUpdateFunction(342 /* JSDocReadonlyTag */);
-      },
-      get createJSDocOverrideTag() {
-        return getJSDocSimpleTagCreateFunction(343 /* JSDocOverrideTag */);
-      },
-      get updateJSDocOverrideTag() {
-        return getJSDocSimpleTagUpdateFunction(343 /* JSDocOverrideTag */);
-      },
-      get createJSDocDeprecatedTag() {
-        return getJSDocSimpleTagCreateFunction(337 /* JSDocDeprecatedTag */);
-      },
-      get updateJSDocDeprecatedTag() {
-        return getJSDocSimpleTagUpdateFunction(337 /* JSDocDeprecatedTag */);
-      },
-      get createJSDocThrowsTag() {
-        return getJSDocTypeLikeTagCreateFunction(355 /* JSDocThrowsTag */);
-      },
-      get updateJSDocThrowsTag() {
-        return getJSDocTypeLikeTagUpdateFunction(355 /* JSDocThrowsTag */);
-      },
-      get createJSDocSatisfiesTag() {
-        return getJSDocTypeLikeTagCreateFunction(356 /* JSDocSatisfiesTag */);
-      },
-      get updateJSDocSatisfiesTag() {
-        return getJSDocTypeLikeTagUpdateFunction(356 /* JSDocSatisfiesTag */);
-      },
-      createJSDocEnumTag,
-      updateJSDocEnumTag,
-      createJSDocUnknownTag,
-      updateJSDocUnknownTag,
-      createJSDocText,
-      updateJSDocText,
-      createJSDocComment,
-      updateJSDocComment,
-      createJsxElement,
-      updateJsxElement,
-      createJsxSelfClosingElement,
-      updateJsxSelfClosingElement,
-      createJsxOpeningElement,
-      updateJsxOpeningElement,
-      createJsxClosingElement,
-      updateJsxClosingElement,
-      createJsxFragment,
-      createJsxText,
-      updateJsxText,
-      createJsxOpeningFragment,
-      createJsxJsxClosingFragment,
-      updateJsxFragment,
-      createJsxAttribute,
-      updateJsxAttribute,
-      createJsxAttributes,
-      updateJsxAttributes,
-      createJsxSpreadAttribute,
-      updateJsxSpreadAttribute,
-      createJsxExpression,
-      updateJsxExpression,
-      createJsxNamespacedName,
-      updateJsxNamespacedName,
-      createCaseClause,
-      updateCaseClause,
-      createDefaultClause,
-      updateDefaultClause,
-      createHeritageClause,
-      updateHeritageClause,
-      createCatchClause,
-      updateCatchClause,
-      createPropertyAssignment,
-      updatePropertyAssignment,
-      createShorthandPropertyAssignment,
-      updateShorthandPropertyAssignment,
-      createSpreadAssignment,
-      updateSpreadAssignment,
-      createEnumMember,
-      updateEnumMember,
-      createSourceFile: createSourceFile2,
-      updateSourceFile: updateSourceFile2,
-      createRedirectedSourceFile,
-      createBundle,
-      updateBundle,
-      createUnparsedSource,
-      createUnparsedPrologue,
-      createUnparsedPrepend,
-      createUnparsedTextLike,
-      createUnparsedSyntheticReference,
-      createInputFiles: createInputFiles2,
-      createSyntheticExpression,
-      createSyntaxList: createSyntaxList3,
-      createNotEmittedStatement,
-      createPartiallyEmittedExpression,
-      updatePartiallyEmittedExpression,
-      createCommaListExpression,
-      updateCommaListExpression,
-      createSyntheticReferenceExpression,
-      updateSyntheticReferenceExpression,
-      cloneNode,
-      // Lazily load factory methods for common operator factories and utilities
-      get createComma() {
-        return getBinaryCreateFunction(28 /* CommaToken */);
-      },
-      get createAssignment() {
-        return getBinaryCreateFunction(64 /* EqualsToken */);
-      },
-      get createLogicalOr() {
-        return getBinaryCreateFunction(57 /* BarBarToken */);
-      },
-      get createLogicalAnd() {
-        return getBinaryCreateFunction(56 /* AmpersandAmpersandToken */);
-      },
-      get createBitwiseOr() {
-        return getBinaryCreateFunction(52 /* BarToken */);
-      },
-      get createBitwiseXor() {
-        return getBinaryCreateFunction(53 /* CaretToken */);
-      },
-      get createBitwiseAnd() {
-        return getBinaryCreateFunction(51 /* AmpersandToken */);
-      },
-      get createStrictEquality() {
-        return getBinaryCreateFunction(37 /* EqualsEqualsEqualsToken */);
-      },
-      get createStrictInequality() {
-        return getBinaryCreateFunction(38 /* ExclamationEqualsEqualsToken */);
-      },
-      get createEquality() {
-        return getBinaryCreateFunction(35 /* EqualsEqualsToken */);
-      },
-      get createInequality() {
-        return getBinaryCreateFunction(36 /* ExclamationEqualsToken */);
-      },
-      get createLessThan() {
-        return getBinaryCreateFunction(30 /* LessThanToken */);
-      },
-      get createLessThanEquals() {
-        return getBinaryCreateFunction(33 /* LessThanEqualsToken */);
-      },
-      get createGreaterThan() {
-        return getBinaryCreateFunction(32 /* GreaterThanToken */);
-      },
-      get createGreaterThanEquals() {
-        return getBinaryCreateFunction(34 /* GreaterThanEqualsToken */);
-      },
-      get createLeftShift() {
-        return getBinaryCreateFunction(48 /* LessThanLessThanToken */);
-      },
-      get createRightShift() {
-        return getBinaryCreateFunction(49 /* GreaterThanGreaterThanToken */);
-      },
-      get createUnsignedRightShift() {
-        return getBinaryCreateFunction(50 /* GreaterThanGreaterThanGreaterThanToken */);
-      },
-      get createAdd() {
-        return getBinaryCreateFunction(40 /* PlusToken */);
-      },
-      get createSubtract() {
-        return getBinaryCreateFunction(41 /* MinusToken */);
-      },
-      get createMultiply() {
-        return getBinaryCreateFunction(42 /* AsteriskToken */);
-      },
-      get createDivide() {
-        return getBinaryCreateFunction(44 /* SlashToken */);
-      },
-      get createModulo() {
-        return getBinaryCreateFunction(45 /* PercentToken */);
-      },
-      get createExponent() {
-        return getBinaryCreateFunction(43 /* AsteriskAsteriskToken */);
-      },
-      get createPrefixPlus() {
-        return getPrefixUnaryCreateFunction(40 /* PlusToken */);
-      },
-      get createPrefixMinus() {
-        return getPrefixUnaryCreateFunction(41 /* MinusToken */);
-      },
-      get createPrefixIncrement() {
-        return getPrefixUnaryCreateFunction(46 /* PlusPlusToken */);
-      },
-      get createPrefixDecrement() {
-        return getPrefixUnaryCreateFunction(47 /* MinusMinusToken */);
-      },
-      get createBitwiseNot() {
-        return getPrefixUnaryCreateFunction(55 /* TildeToken */);
-      },
-      get createLogicalNot() {
-        return getPrefixUnaryCreateFunction(54 /* ExclamationToken */);
-      },
-      get createPostfixIncrement() {
-        return getPostfixUnaryCreateFunction(46 /* PlusPlusToken */);
-      },
-      get createPostfixDecrement() {
-        return getPostfixUnaryCreateFunction(47 /* MinusMinusToken */);
-      },
-      // Compound nodes
-      createImmediatelyInvokedFunctionExpression,
-      createImmediatelyInvokedArrowFunction,
-      createVoidZero,
-      createExportDefault,
-      createExternalModuleExport,
-      createTypeCheck,
-      createMethodCall,
-      createGlobalMethodCall,
-      createFunctionBindCall,
-      createFunctionCallCall,
-      createFunctionApplyCall,
-      createArraySliceCall,
-      createArrayConcatCall,
-      createObjectDefinePropertyCall,
-      createObjectGetOwnPropertyDescriptorCall,
-      createReflectGetCall,
-      createReflectSetCall,
-      createPropertyDescriptor,
-      createCallBinding,
-      createAssignmentTargetWrapper,
-      // Utilities
-      inlineExpressions,
-      getInternalName,
-      getLocalName,
-      getExportName,
-      getDeclarationName,
-      getNamespaceMemberName,
-      getExternalModuleOrNamespaceExportName,
-      restoreOuterExpressions,
-      restoreEnclosingLabel,
-      createUseStrictPrologue,
-      copyPrologue,
-      copyStandardPrologue,
-      copyCustomPrologue,
-      ensureUseStrict,
-      liftToBlock,
-      mergeLexicalEnvironment,
-      updateModifiers
-    };
-    forEach(nodeFactoryPatchers, (fn) => fn(factory2));
-    return factory2;
-    function createNodeArray(elements, hasTrailingComma) {
-      if (elements === void 0 || elements === emptyArray) {
-        elements = [];
-      } else if (isNodeArray(elements)) {
-        if (hasTrailingComma === void 0 || elements.hasTrailingComma === hasTrailingComma) {
-          if (elements.transformFlags === void 0) {
-            aggregateChildrenFlags(elements);
-          }
-          Debug.attachNodeArrayDebugInfo(elements);
-          return elements;
-        }
-        const array2 = elements.slice();
-        array2.pos = elements.pos;
-        array2.end = elements.end;
-        array2.hasTrailingComma = hasTrailingComma;
-        array2.transformFlags = elements.transformFlags;
-        Debug.attachNodeArrayDebugInfo(array2);
-        return array2;
-      }
-      const length2 = elements.length;
-      const array = length2 >= 1 && length2 <= 4 ? elements.slice() : elements;
-      array.pos = -1;
-      array.end = -1;
-      array.hasTrailingComma = !!hasTrailingComma;
-      array.transformFlags = 0 /* None */;
-      aggregateChildrenFlags(array);
-      Debug.attachNodeArrayDebugInfo(array);
-      return array;
-    }
-    function createBaseNode(kind) {
-      return baseFactory2.createBaseNode(kind);
-    }
-    function createBaseDeclaration(kind) {
-      const node = createBaseNode(kind);
-      node.symbol = void 0;
-      node.localSymbol = void 0;
-      return node;
-    }
-    function finishUpdateBaseSignatureDeclaration(updated, original) {
-      if (updated !== original) {
-        updated.typeArguments = original.typeArguments;
-      }
-      return update(updated, original);
-    }
-    function createNumericLiteral(value, numericLiteralFlags = 0 /* None */) {
-      const node = createBaseDeclaration(9 /* NumericLiteral */);
-      node.text = typeof value === "number" ? value + "" : value;
-      node.numericLiteralFlags = numericLiteralFlags;
-      if (numericLiteralFlags & 384 /* BinaryOrOctalSpecifier */)
-        node.transformFlags |= 1024 /* ContainsES2015 */;
-      return node;
-    }
-    function createBigIntLiteral(value) {
-      const node = createBaseToken(10 /* BigIntLiteral */);
-      node.text = typeof value === "string" ? value : pseudoBigIntToString(value) + "n";
-      node.transformFlags |= 32 /* ContainsES2020 */;
-      return node;
-    }
-    function createBaseStringLiteral(text, isSingleQuote) {
-      const node = createBaseDeclaration(11 /* StringLiteral */);
-      node.text = text;
-      node.singleQuote = isSingleQuote;
-      return node;
-    }
-    function createStringLiteral(text, isSingleQuote, hasExtendedUnicodeEscape) {
-      const node = createBaseStringLiteral(text, isSingleQuote);
-      node.hasExtendedUnicodeEscape = hasExtendedUnicodeEscape;
-      if (hasExtendedUnicodeEscape)
-        node.transformFlags |= 1024 /* ContainsES2015 */;
-      return node;
-    }
-    function createStringLiteralFromNode(sourceNode) {
-      const node = createBaseStringLiteral(
-        getTextOfIdentifierOrLiteral(sourceNode),
-        /*isSingleQuote*/
-        void 0
-      );
-      node.textSourceNode = sourceNode;
-      return node;
-    }
-    function createRegularExpressionLiteral(text) {
-      const node = createBaseToken(14 /* RegularExpressionLiteral */);
-      node.text = text;
-      return node;
-    }
-    function createLiteralLikeNode(kind, text) {
-      switch (kind) {
-        case 9 /* NumericLiteral */:
-          return createNumericLiteral(
-            text,
-            /*numericLiteralFlags*/
-            0
-          );
-        case 10 /* BigIntLiteral */:
-          return createBigIntLiteral(text);
-        case 11 /* StringLiteral */:
-          return createStringLiteral(
-            text,
-            /*isSingleQuote*/
-            void 0
-          );
-        case 12 /* JsxText */:
-          return createJsxText(
-            text,
-            /*containsOnlyTriviaWhiteSpaces*/
-            false
-          );
-        case 13 /* JsxTextAllWhiteSpaces */:
-          return createJsxText(
-            text,
-            /*containsOnlyTriviaWhiteSpaces*/
-            true
-          );
-        case 14 /* RegularExpressionLiteral */:
-          return createRegularExpressionLiteral(text);
-        case 15 /* NoSubstitutionTemplateLiteral */:
-          return createTemplateLiteralLikeNode(
-            kind,
-            text,
-            /*rawText*/
-            void 0,
-            /*templateFlags*/
-            0
-          );
-      }
-    }
-    function createBaseIdentifier(escapedText) {
-      const node = baseFactory2.createBaseIdentifierNode(80 /* Identifier */);
-      node.escapedText = escapedText;
-      node.jsDoc = void 0;
-      node.flowNode = void 0;
-      node.symbol = void 0;
-      return node;
-    }
-    function createBaseGeneratedIdentifier(text, autoGenerateFlags, prefix, suffix) {
-      const node = createBaseIdentifier(escapeLeadingUnderscores(text));
-      setIdentifierAutoGenerate(node, {
-        flags: autoGenerateFlags,
-        id: nextAutoGenerateId,
-        prefix,
-        suffix
-      });
-      nextAutoGenerateId++;
-      return node;
-    }
-    function createIdentifier(text, originalKeywordKind, hasExtendedUnicodeEscape) {
-      if (originalKeywordKind === void 0 && text) {
-        originalKeywordKind = stringToToken(text);
-      }
-      if (originalKeywordKind === 80 /* Identifier */) {
-        originalKeywordKind = void 0;
-      }
-      const node = createBaseIdentifier(escapeLeadingUnderscores(text));
-      if (hasExtendedUnicodeEscape)
-        node.flags |= 128 /* IdentifierHasExtendedUnicodeEscape */;
-      if (node.escapedText === "await") {
-        node.transformFlags |= 67108864 /* ContainsPossibleTopLevelAwait */;
-      }
-      if (node.flags & 128 /* IdentifierHasExtendedUnicodeEscape */) {
-        node.transformFlags |= 1024 /* ContainsES2015 */;
-      }
-      return node;
-    }
-    function createTempVariable(recordTempVariable, reservedInNestedScopes, prefix, suffix) {
-      let flags2 = 1 /* Auto */;
-      if (reservedInNestedScopes)
-        flags2 |= 8 /* ReservedInNestedScopes */;
-      const name = createBaseGeneratedIdentifier("", flags2, prefix, suffix);
-      if (recordTempVariable) {
-        recordTempVariable(name);
-      }
-      return name;
-    }
-    function createLoopVariable(reservedInNestedScopes) {
-      let flags2 = 2 /* Loop */;
-      if (reservedInNestedScopes)
-        flags2 |= 8 /* ReservedInNestedScopes */;
-      return createBaseGeneratedIdentifier(
-        "",
-        flags2,
-        /*prefix*/
-        void 0,
-        /*suffix*/
-        void 0
-      );
-    }
-    function createUniqueName(text, flags2 = 0 /* None */, prefix, suffix) {
-      Debug.assert(!(flags2 & 7 /* KindMask */), "Argument out of range: flags");
-      Debug.assert((flags2 & (16 /* Optimistic */ | 32 /* FileLevel */)) !== 32 /* FileLevel */, "GeneratedIdentifierFlags.FileLevel cannot be set without also setting GeneratedIdentifierFlags.Optimistic");
-      return createBaseGeneratedIdentifier(text, 3 /* Unique */ | flags2, prefix, suffix);
-    }
-    function getGeneratedNameForNode(node, flags2 = 0, prefix, suffix) {
-      Debug.assert(!(flags2 & 7 /* KindMask */), "Argument out of range: flags");
-      const text = !node ? "" : isMemberName(node) ? formatGeneratedName(
-        /*privateName*/
-        false,
-        prefix,
-        node,
-        suffix,
-        idText
-      ) : `generated@${getNodeId(node)}`;
-      if (prefix || suffix)
-        flags2 |= 16 /* Optimistic */;
-      const name = createBaseGeneratedIdentifier(text, 4 /* Node */ | flags2, prefix, suffix);
-      name.original = node;
-      return name;
-    }
-    function createBasePrivateIdentifier(escapedText) {
-      const node = baseFactory2.createBasePrivateIdentifierNode(81 /* PrivateIdentifier */);
-      node.escapedText = escapedText;
-      node.transformFlags |= 16777216 /* ContainsClassFields */;
-      return node;
-    }
-    function createPrivateIdentifier(text) {
-      if (!startsWith(text, "#"))
-        Debug.fail("First character of private identifier must be #: " + text);
-      return createBasePrivateIdentifier(escapeLeadingUnderscores(text));
-    }
-    function createBaseGeneratedPrivateIdentifier(text, autoGenerateFlags, prefix, suffix) {
-      const node = createBasePrivateIdentifier(escapeLeadingUnderscores(text));
-      setIdentifierAutoGenerate(node, {
-        flags: autoGenerateFlags,
-        id: nextAutoGenerateId,
-        prefix,
-        suffix
-      });
-      nextAutoGenerateId++;
-      return node;
-    }
-    function createUniquePrivateName(text, prefix, suffix) {
-      if (text && !startsWith(text, "#"))
-        Debug.fail("First character of private identifier must be #: " + text);
-      const autoGenerateFlags = 8 /* ReservedInNestedScopes */ | (text ? 3 /* Unique */ : 1 /* Auto */);
-      return createBaseGeneratedPrivateIdentifier(text ?? "", autoGenerateFlags, prefix, suffix);
-    }
-    function getGeneratedPrivateNameForNode(node, prefix, suffix) {
-      const text = isMemberName(node) ? formatGeneratedName(
-        /*privateName*/
-        true,
-        prefix,
-        node,
-        suffix,
-        idText
-      ) : `#generated@${getNodeId(node)}`;
-      const flags2 = prefix || suffix ? 16 /* Optimistic */ : 0 /* None */;
-      const name = createBaseGeneratedPrivateIdentifier(text, 4 /* Node */ | flags2, prefix, suffix);
-      name.original = node;
-      return name;
-    }
-    function createBaseToken(kind) {
-      return baseFactory2.createBaseTokenNode(kind);
-    }
-    function createToken(token) {
-      Debug.assert(token >= 0 /* FirstToken */ && token <= 164 /* LastToken */, "Invalid token");
-      Debug.assert(token <= 15 /* FirstTemplateToken */ || token >= 18 /* LastTemplateToken */, "Invalid token. Use 'createTemplateLiteralLikeNode' to create template literals.");
-      Debug.assert(token <= 9 /* FirstLiteralToken */ || token >= 15 /* LastLiteralToken */, "Invalid token. Use 'createLiteralLikeNode' to create literals.");
-      Debug.assert(token !== 80 /* Identifier */, "Invalid token. Use 'createIdentifier' to create identifiers");
-      const node = createBaseToken(token);
-      let transformFlags = 0 /* None */;
-      switch (token) {
-        case 134 /* AsyncKeyword */:
-          transformFlags = 256 /* ContainsES2017 */ | 128 /* ContainsES2018 */;
-          break;
-        case 125 /* PublicKeyword */:
-        case 123 /* PrivateKeyword */:
-        case 124 /* ProtectedKeyword */:
-        case 148 /* ReadonlyKeyword */:
-        case 128 /* AbstractKeyword */:
-        case 138 /* DeclareKeyword */:
-        case 87 /* ConstKeyword */:
-        case 133 /* AnyKeyword */:
-        case 150 /* NumberKeyword */:
-        case 162 /* BigIntKeyword */:
-        case 146 /* NeverKeyword */:
-        case 151 /* ObjectKeyword */:
-        case 103 /* InKeyword */:
-        case 147 /* OutKeyword */:
-        case 163 /* OverrideKeyword */:
-        case 154 /* StringKeyword */:
-        case 136 /* BooleanKeyword */:
-        case 155 /* SymbolKeyword */:
-        case 116 /* VoidKeyword */:
-        case 159 /* UnknownKeyword */:
-        case 157 /* UndefinedKeyword */:
-          transformFlags = 1 /* ContainsTypeScript */;
-          break;
-        case 108 /* SuperKeyword */:
-          transformFlags = 1024 /* ContainsES2015 */ | 134217728 /* ContainsLexicalSuper */;
-          node.flowNode = void 0;
-          break;
-        case 126 /* StaticKeyword */:
-          transformFlags = 1024 /* ContainsES2015 */;
-          break;
-        case 129 /* AccessorKeyword */:
-          transformFlags = 16777216 /* ContainsClassFields */;
-          break;
-        case 110 /* ThisKeyword */:
-          transformFlags = 16384 /* ContainsLexicalThis */;
-          node.flowNode = void 0;
-          break;
-      }
-      if (transformFlags) {
-        node.transformFlags |= transformFlags;
-      }
-      return node;
-    }
-    function createSuper() {
-      return createToken(108 /* SuperKeyword */);
-    }
-    function createThis() {
-      return createToken(110 /* ThisKeyword */);
-    }
-    function createNull() {
-      return createToken(106 /* NullKeyword */);
-    }
-    function createTrue() {
-      return createToken(112 /* TrueKeyword */);
-    }
-    function createFalse() {
-      return createToken(97 /* FalseKeyword */);
-    }
-    function createModifier(kind) {
-      return createToken(kind);
-    }
-    function createModifiersFromModifierFlags(flags2) {
-      const result = [];
-      if (flags2 & 1 /* Export */)
-        result.push(createModifier(95 /* ExportKeyword */));
-      if (flags2 & 2 /* Ambient */)
-        result.push(createModifier(138 /* DeclareKeyword */));
-      if (flags2 & 1024 /* Default */)
-        result.push(createModifier(90 /* DefaultKeyword */));
-      if (flags2 & 2048 /* Const */)
-        result.push(createModifier(87 /* ConstKeyword */));
-      if (flags2 & 4 /* Public */)
-        result.push(createModifier(125 /* PublicKeyword */));
-      if (flags2 & 8 /* Private */)
-        result.push(createModifier(123 /* PrivateKeyword */));
-      if (flags2 & 16 /* Protected */)
-        result.push(createModifier(124 /* ProtectedKeyword */));
-      if (flags2 & 256 /* Abstract */)
-        result.push(createModifier(128 /* AbstractKeyword */));
-      if (flags2 & 32 /* Static */)
-        result.push(createModifier(126 /* StaticKeyword */));
-      if (flags2 & 16384 /* Override */)
-        result.push(createModifier(163 /* OverrideKeyword */));
-      if (flags2 & 64 /* Readonly */)
-        result.push(createModifier(148 /* ReadonlyKeyword */));
-      if (flags2 & 128 /* Accessor */)
-        result.push(createModifier(129 /* AccessorKeyword */));
-      if (flags2 & 512 /* Async */)
-        result.push(createModifier(134 /* AsyncKeyword */));
-      if (flags2 & 32768 /* In */)
-        result.push(createModifier(103 /* InKeyword */));
-      if (flags2 & 65536 /* Out */)
-        result.push(createModifier(147 /* OutKeyword */));
-      return result.length ? result : void 0;
-    }
-    function createQualifiedName(left, right) {
-      const node = createBaseNode(165 /* QualifiedName */);
-      node.left = left;
-      node.right = asName(right);
-      node.transformFlags |= propagateChildFlags(node.left) | propagateIdentifierNameFlags(node.right);
-      node.flowNode = void 0;
-      return node;
-    }
-    function updateQualifiedName(node, left, right) {
-      return node.left !== left || node.right !== right ? update(createQualifiedName(left, right), node) : node;
-    }
-    function createComputedPropertyName(expression) {
-      const node = createBaseNode(166 /* ComputedPropertyName */);
-      node.expression = parenthesizerRules().parenthesizeExpressionOfComputedPropertyName(expression);
-      node.transformFlags |= propagateChildFlags(node.expression) | 1024 /* ContainsES2015 */ | 131072 /* ContainsComputedPropertyName */;
-      return node;
-    }
-    function updateComputedPropertyName(node, expression) {
-      return node.expression !== expression ? update(createComputedPropertyName(expression), node) : node;
-    }
-    function createTypeParameterDeclaration(modifiers, name, constraint, defaultType) {
-      const node = createBaseDeclaration(167 /* TypeParameter */);
-      node.modifiers = asNodeArray(modifiers);
-      node.name = asName(name);
-      node.constraint = constraint;
-      node.default = defaultType;
-      node.transformFlags = 1 /* ContainsTypeScript */;
-      node.expression = void 0;
-      node.jsDoc = void 0;
-      return node;
-    }
-    function updateTypeParameterDeclaration(node, modifiers, name, constraint, defaultType) {
-      return node.modifiers !== modifiers || node.name !== name || node.constraint !== constraint || node.default !== defaultType ? update(createTypeParameterDeclaration(modifiers, name, constraint, defaultType), node) : node;
-    }
-    function createParameterDeclaration(modifiers, dotDotDotToken, name, questionToken, type, initializer) {
-      const node = createBaseDeclaration(168 /* Parameter */);
-      node.modifiers = asNodeArray(modifiers);
-      node.dotDotDotToken = dotDotDotToken;
-      node.name = asName(name);
-      node.questionToken = questionToken;
-      node.type = type;
-      node.initializer = asInitializer(initializer);
-      if (isThisIdentifier(node.name)) {
-        node.transformFlags = 1 /* ContainsTypeScript */;
-      } else {
-        node.transformFlags = propagateChildrenFlags(node.modifiers) | propagateChildFlags(node.dotDotDotToken) | propagateNameFlags(node.name) | propagateChildFlags(node.questionToken) | propagateChildFlags(node.initializer) | (node.questionToken ?? node.type ? 1 /* ContainsTypeScript */ : 0 /* None */) | (node.dotDotDotToken ?? node.initializer ? 1024 /* ContainsES2015 */ : 0 /* None */) | (modifiersToFlags(node.modifiers) & 16476 /* ParameterPropertyModifier */ ? 8192 /* ContainsTypeScriptClassSyntax */ : 0 /* None */);
-      }
-      node.jsDoc = void 0;
-      return node;
-    }
-    function updateParameterDeclaration(node, modifiers, dotDotDotToken, name, questionToken, type, initializer) {
-      return node.modifiers !== modifiers || node.dotDotDotToken !== dotDotDotToken || node.name !== name || node.questionToken !== questionToken || node.type !== type || node.initializer !== initializer ? update(createParameterDeclaration(modifiers, dotDotDotToken, name, questionToken, type, initializer), node) : node;
-    }
-    function createDecorator(expression) {
-      const node = createBaseNode(169 /* Decorator */);
-      node.expression = parenthesizerRules().parenthesizeLeftSideOfAccess(
-        expression,
-        /*optionalChain*/
-        false
-      );
-      node.transformFlags |= propagateChildFlags(node.expression) | 1 /* ContainsTypeScript */ | 8192 /* ContainsTypeScriptClassSyntax */ | 33554432 /* ContainsDecorators */;
-      return node;
-    }
-    function updateDecorator(node, expression) {
-      return node.expression !== expression ? update(createDecorator(expression), node) : node;
-    }
-    function createPropertySignature(modifiers, name, questionToken, type) {
-      const node = createBaseDeclaration(170 /* PropertySignature */);
-      node.modifiers = asNodeArray(modifiers);
-      node.name = asName(name);
-      node.type = type;
-      node.questionToken = questionToken;
-      node.transformFlags = 1 /* ContainsTypeScript */;
-      node.initializer = void 0;
-      node.jsDoc = void 0;
-      return node;
-    }
-    function updatePropertySignature(node, modifiers, name, questionToken, type) {
-      return node.modifiers !== modifiers || node.name !== name || node.questionToken !== questionToken || node.type !== type ? finishUpdatePropertySignature(createPropertySignature(modifiers, name, questionToken, type), node) : node;
-    }
-    function finishUpdatePropertySignature(updated, original) {
-      if (updated !== original) {
-        updated.initializer = original.initializer;
-      }
-      return update(updated, original);
-    }
-    function createPropertyDeclaration(modifiers, name, questionOrExclamationToken, type, initializer) {
-      const node = createBaseDeclaration(171 /* PropertyDeclaration */);
-      node.modifiers = asNodeArray(modifiers);
-      node.name = asName(name);
-      node.questionToken = questionOrExclamationToken && isQuestionToken(questionOrExclamationToken) ? questionOrExclamationToken : void 0;
-      node.exclamationToken = questionOrExclamationToken && isExclamationToken(questionOrExclamationToken) ? questionOrExclamationToken : void 0;
-      node.type = type;
-      node.initializer = asInitializer(initializer);
-      const isAmbient = node.flags & 16777216 /* Ambient */ || modifiersToFlags(node.modifiers) & 2 /* Ambient */;
-      node.transformFlags = propagateChildrenFlags(node.modifiers) | propagateNameFlags(node.name) | propagateChildFlags(node.initializer) | (isAmbient || node.questionToken || node.exclamationToken || node.type ? 1 /* ContainsTypeScript */ : 0 /* None */) | (isComputedPropertyName(node.name) || modifiersToFlags(node.modifiers) & 32 /* Static */ && node.initializer ? 8192 /* ContainsTypeScriptClassSyntax */ : 0 /* None */) | 16777216 /* ContainsClassFields */;
-      node.jsDoc = void 0;
-      return node;
-    }
-    function updatePropertyDeclaration2(node, modifiers, name, questionOrExclamationToken, type, initializer) {
-      return node.modifiers !== modifiers || node.name !== name || node.questionToken !== (questionOrExclamationToken !== void 0 && isQuestionToken(questionOrExclamationToken) ? questionOrExclamationToken : void 0) || node.exclamationToken !== (questionOrExclamationToken !== void 0 && isExclamationToken(questionOrExclamationToken) ? questionOrExclamationToken : void 0) || node.type !== type || node.initializer !== initializer ? update(createPropertyDeclaration(modifiers, name, questionOrExclamationToken, type, initializer), node) : node;
-    }
-    function createMethodSignature(modifiers, name, questionToken, typeParameters, parameters, type) {
-      const node = createBaseDeclaration(172 /* MethodSignature */);
-      node.modifiers = asNodeArray(modifiers);
-      node.name = asName(name);
-      node.questionToken = questionToken;
-      node.typeParameters = asNodeArray(typeParameters);
-      node.parameters = asNodeArray(parameters);
-      node.type = type;
-      node.transformFlags = 1 /* ContainsTypeScript */;
-      node.jsDoc = void 0;
-      node.locals = void 0;
-      node.nextContainer = void 0;
-      node.typeArguments = void 0;
-      return node;
-    }
-    function updateMethodSignature(node, modifiers, name, questionToken, typeParameters, parameters, type) {
-      return node.modifiers !== modifiers || node.name !== name || node.questionToken !== questionToken || node.typeParameters !== typeParameters || node.parameters !== parameters || node.type !== type ? finishUpdateBaseSignatureDeclaration(createMethodSignature(modifiers, name, questionToken, typeParameters, parameters, type), node) : node;
-    }
-    function createMethodDeclaration(modifiers, asteriskToken, name, questionToken, typeParameters, parameters, type, body) {
-      const node = createBaseDeclaration(173 /* MethodDeclaration */);
-      node.modifiers = asNodeArray(modifiers);
-      node.asteriskToken = asteriskToken;
-      node.name = asName(name);
-      node.questionToken = questionToken;
-      node.exclamationToken = void 0;
-      node.typeParameters = asNodeArray(typeParameters);
-      node.parameters = createNodeArray(parameters);
-      node.type = type;
-      node.body = body;
-      if (!node.body) {
-        node.transformFlags = 1 /* ContainsTypeScript */;
-      } else {
-        const isAsync = modifiersToFlags(node.modifiers) & 512 /* Async */;
-        const isGenerator = !!node.asteriskToken;
-        const isAsyncGenerator = isAsync && isGenerator;
-        node.transformFlags = propagateChildrenFlags(node.modifiers) | propagateChildFlags(node.asteriskToken) | propagateNameFlags(node.name) | propagateChildFlags(node.questionToken) | propagateChildrenFlags(node.typeParameters) | propagateChildrenFlags(node.parameters) | propagateChildFlags(node.type) | propagateChildFlags(node.body) & ~67108864 /* ContainsPossibleTopLevelAwait */ | (isAsyncGenerator ? 128 /* ContainsES2018 */ : isAsync ? 256 /* ContainsES2017 */ : isGenerator ? 2048 /* ContainsGenerator */ : 0 /* None */) | (node.questionToken || node.typeParameters || node.type ? 1 /* ContainsTypeScript */ : 0 /* None */) | 1024 /* ContainsES2015 */;
-      }
-      node.typeArguments = void 0;
-      node.jsDoc = void 0;
-      node.locals = void 0;
-      node.nextContainer = void 0;
-      node.flowNode = void 0;
-      node.endFlowNode = void 0;
-      node.returnFlowNode = void 0;
-      return node;
-    }
-    function updateMethodDeclaration(node, modifiers, asteriskToken, name, questionToken, typeParameters, parameters, type, body) {
-      return node.modifiers !== modifiers || node.asteriskToken !== asteriskToken || node.name !== name || node.questionToken !== questionToken || node.typeParameters !== typeParameters || node.parameters !== parameters || node.type !== type || node.body !== body ? finishUpdateMethodDeclaration(createMethodDeclaration(modifiers, asteriskToken, name, questionToken, typeParameters, parameters, type, body), node) : node;
-    }
-    function finishUpdateMethodDeclaration(updated, original) {
-      if (updated !== original) {
-        updated.exclamationToken = original.exclamationToken;
-      }
-      return update(updated, original);
-    }
-    function createClassStaticBlockDeclaration(body) {
-      const node = createBaseDeclaration(174 /* ClassStaticBlockDeclaration */);
-      node.body = body;
-      node.transformFlags = propagateChildFlags(body) | 16777216 /* ContainsClassFields */;
-      node.modifiers = void 0;
-      node.jsDoc = void 0;
-      node.locals = void 0;
-      node.nextContainer = void 0;
-      node.endFlowNode = void 0;
-      node.returnFlowNode = void 0;
-      return node;
-    }
-    function updateClassStaticBlockDeclaration(node, body) {
-      return node.body !== body ? finishUpdateClassStaticBlockDeclaration(createClassStaticBlockDeclaration(body), node) : node;
-    }
-    function finishUpdateClassStaticBlockDeclaration(updated, original) {
-      if (updated !== original) {
-        updated.modifiers = original.modifiers;
-      }
-      return update(updated, original);
-    }
-    function createConstructorDeclaration(modifiers, parameters, body) {
-      const node = createBaseDeclaration(175 /* Constructor */);
-      node.modifiers = asNodeArray(modifiers);
-      node.parameters = createNodeArray(parameters);
-      node.body = body;
-      node.transformFlags = propagateChildrenFlags(node.modifiers) | propagateChildrenFlags(node.parameters) | propagateChildFlags(node.body) & ~67108864 /* ContainsPossibleTopLevelAwait */ | 1024 /* ContainsES2015 */;
-      node.typeParameters = void 0;
-      node.type = void 0;
-      node.typeArguments = void 0;
-      node.jsDoc = void 0;
-      node.locals = void 0;
-      node.nextContainer = void 0;
-      node.endFlowNode = void 0;
-      node.returnFlowNode = void 0;
-      return node;
-    }
-    function updateConstructorDeclaration(node, modifiers, parameters, body) {
-      return node.modifiers !== modifiers || node.parameters !== parameters || node.body !== body ? finishUpdateConstructorDeclaration(createConstructorDeclaration(modifiers, parameters, body), node) : node;
-    }
-    function finishUpdateConstructorDeclaration(updated, original) {
-      if (updated !== original) {
-        updated.typeParameters = original.typeParameters;
-        updated.type = original.type;
-      }
-      return finishUpdateBaseSignatureDeclaration(updated, original);
-    }
-    function createGetAccessorDeclaration(modifiers, name, parameters, type, body) {
-      const node = createBaseDeclaration(176 /* GetAccessor */);
-      node.modifiers = asNodeArray(modifiers);
-      node.name = asName(name);
-      node.parameters = createNodeArray(parameters);
-      node.type = type;
-      node.body = body;
-      if (!node.body) {
-        node.transformFlags = 1 /* ContainsTypeScript */;
-      } else {
-        node.transformFlags = propagateChildrenFlags(node.modifiers) | propagateNameFlags(node.name) | propagateChildrenFlags(node.parameters) | propagateChildFlags(node.type) | propagateChildFlags(node.body) & ~67108864 /* ContainsPossibleTopLevelAwait */ | (node.type ? 1 /* ContainsTypeScript */ : 0 /* None */);
-      }
-      node.typeArguments = void 0;
-      node.typeParameters = void 0;
-      node.jsDoc = void 0;
-      node.locals = void 0;
-      node.nextContainer = void 0;
-      node.flowNode = void 0;
-      node.endFlowNode = void 0;
-      node.returnFlowNode = void 0;
-      return node;
-    }
-    function updateGetAccessorDeclaration(node, modifiers, name, parameters, type, body) {
-      return node.modifiers !== modifiers || node.name !== name || node.parameters !== parameters || node.type !== type || node.body !== body ? finishUpdateGetAccessorDeclaration(createGetAccessorDeclaration(modifiers, name, parameters, type, body), node) : node;
-    }
-    function finishUpdateGetAccessorDeclaration(updated, original) {
-      if (updated !== original) {
-        updated.typeParameters = original.typeParameters;
-      }
-      return finishUpdateBaseSignatureDeclaration(updated, original);
-    }
-    function createSetAccessorDeclaration(modifiers, name, parameters, body) {
-      const node = createBaseDeclaration(177 /* SetAccessor */);
-      node.modifiers = asNodeArray(modifiers);
-      node.name = asName(name);
-      node.parameters = createNodeArray(parameters);
-      node.body = body;
-      if (!node.body) {
-        node.transformFlags = 1 /* ContainsTypeScript */;
-      } else {
-        node.transformFlags = propagateChildrenFlags(node.modifiers) | propagateNameFlags(node.name) | propagateChildrenFlags(node.parameters) | propagateChildFlags(node.body) & ~67108864 /* ContainsPossibleTopLevelAwait */ | (node.type ? 1 /* ContainsTypeScript */ : 0 /* None */);
-      }
-      node.typeArguments = void 0;
-      node.typeParameters = void 0;
-      node.type = void 0;
-      node.jsDoc = void 0;
-      node.locals = void 0;
-      node.nextContainer = void 0;
-      node.flowNode = void 0;
-      node.endFlowNode = void 0;
-      node.returnFlowNode = void 0;
-      return node;
-    }
-    function updateSetAccessorDeclaration(node, modifiers, name, parameters, body) {
-      return node.modifiers !== modifiers || node.name !== name || node.parameters !== parameters || node.body !== body ? finishUpdateSetAccessorDeclaration(createSetAccessorDeclaration(modifiers, name, parameters, body), node) : node;
-    }
-    function finishUpdateSetAccessorDeclaration(updated, original) {
-      if (updated !== original) {
-        updated.typeParameters = original.typeParameters;
-        updated.type = original.type;
-      }
-      return finishUpdateBaseSignatureDeclaration(updated, original);
-    }
-    function createCallSignature(typeParameters, parameters, type) {
-      const node = createBaseDeclaration(178 /* CallSignature */);
-      node.typeParameters = asNodeArray(typeParameters);
-      node.parameters = asNodeArray(parameters);
-      node.type = type;
-      node.transformFlags = 1 /* ContainsTypeScript */;
-      node.jsDoc = void 0;
-      node.locals = void 0;
-      node.nextContainer = void 0;
-      node.typeArguments = void 0;
-      return node;
-    }
-    function updateCallSignature(node, typeParameters, parameters, type) {
-      return node.typeParameters !== typeParameters || node.parameters !== parameters || node.type !== type ? finishUpdateBaseSignatureDeclaration(createCallSignature(typeParameters, parameters, type), node) : node;
-    }
-    function createConstructSignature(typeParameters, parameters, type) {
-      const node = createBaseDeclaration(179 /* ConstructSignature */);
-      node.typeParameters = asNodeArray(typeParameters);
-      node.parameters = asNodeArray(parameters);
-      node.type = type;
-      node.transformFlags = 1 /* ContainsTypeScript */;
-      node.jsDoc = void 0;
-      node.locals = void 0;
-      node.nextContainer = void 0;
-      node.typeArguments = void 0;
-      return node;
-    }
-    function updateConstructSignature(node, typeParameters, parameters, type) {
-      return node.typeParameters !== typeParameters || node.parameters !== parameters || node.type !== type ? finishUpdateBaseSignatureDeclaration(createConstructSignature(typeParameters, parameters, type), node) : node;
-    }
-    function createIndexSignature(modifiers, parameters, type) {
-      const node = createBaseDeclaration(180 /* IndexSignature */);
-      node.modifiers = asNodeArray(modifiers);
-      node.parameters = asNodeArray(parameters);
-      node.type = type;
-      node.transformFlags = 1 /* ContainsTypeScript */;
-      node.jsDoc = void 0;
-      node.locals = void 0;
-      node.nextContainer = void 0;
-      node.typeArguments = void 0;
-      return node;
-    }
-    function updateIndexSignature(node, modifiers, parameters, type) {
-      return node.parameters !== parameters || node.type !== type || node.modifiers !== modifiers ? finishUpdateBaseSignatureDeclaration(createIndexSignature(modifiers, parameters, type), node) : node;
-    }
-    function createTemplateLiteralTypeSpan(type, literal) {
-      const node = createBaseNode(203 /* TemplateLiteralTypeSpan */);
-      node.type = type;
-      node.literal = literal;
-      node.transformFlags = 1 /* ContainsTypeScript */;
-      return node;
-    }
-    function updateTemplateLiteralTypeSpan(node, type, literal) {
-      return node.type !== type || node.literal !== literal ? update(createTemplateLiteralTypeSpan(type, literal), node) : node;
-    }
-    function createKeywordTypeNode(kind) {
-      return createToken(kind);
-    }
-    function createTypePredicateNode(assertsModifier, parameterName, type) {
-      const node = createBaseNode(181 /* TypePredicate */);
-      node.assertsModifier = assertsModifier;
-      node.parameterName = asName(parameterName);
-      node.type = type;
-      node.transformFlags = 1 /* ContainsTypeScript */;
-      return node;
-    }
-    function updateTypePredicateNode(node, assertsModifier, parameterName, type) {
-      return node.assertsModifier !== assertsModifier || node.parameterName !== parameterName || node.type !== type ? update(createTypePredicateNode(assertsModifier, parameterName, type), node) : node;
-    }
-    function createTypeReferenceNode(typeName, typeArguments) {
-      const node = createBaseNode(182 /* TypeReference */);
-      node.typeName = asName(typeName);
-      node.typeArguments = typeArguments && parenthesizerRules().parenthesizeTypeArguments(createNodeArray(typeArguments));
-      node.transformFlags = 1 /* ContainsTypeScript */;
-      return node;
-    }
-    function updateTypeReferenceNode(node, typeName, typeArguments) {
-      return node.typeName !== typeName || node.typeArguments !== typeArguments ? update(createTypeReferenceNode(typeName, typeArguments), node) : node;
-    }
-    function createFunctionTypeNode(typeParameters, parameters, type) {
-      const node = createBaseDeclaration(183 /* FunctionType */);
-      node.typeParameters = asNodeArray(typeParameters);
-      node.parameters = asNodeArray(parameters);
-      node.type = type;
-      node.transformFlags = 1 /* ContainsTypeScript */;
-      node.modifiers = void 0;
-      node.jsDoc = void 0;
-      node.locals = void 0;
-      node.nextContainer = void 0;
-      node.typeArguments = void 0;
-      return node;
-    }
-    function updateFunctionTypeNode(node, typeParameters, parameters, type) {
-      return node.typeParameters !== typeParameters || node.parameters !== parameters || node.type !== type ? finishUpdateFunctionTypeNode(createFunctionTypeNode(typeParameters, parameters, type), node) : node;
-    }
-    function finishUpdateFunctionTypeNode(updated, original) {
-      if (updated !== original) {
-        updated.modifiers = original.modifiers;
-      }
-      return finishUpdateBaseSignatureDeclaration(updated, original);
-    }
-    function createConstructorTypeNode(...args) {
-      return args.length === 4 ? createConstructorTypeNode1(...args) : args.length === 3 ? createConstructorTypeNode2(...args) : Debug.fail("Incorrect number of arguments specified.");
-    }
-    function createConstructorTypeNode1(modifiers, typeParameters, parameters, type) {
-      const node = createBaseDeclaration(184 /* ConstructorType */);
-      node.modifiers = asNodeArray(modifiers);
-      node.typeParameters = asNodeArray(typeParameters);
-      node.parameters = asNodeArray(parameters);
-      node.type = type;
-      node.transformFlags = 1 /* ContainsTypeScript */;
-      node.jsDoc = void 0;
-      node.locals = void 0;
-      node.nextContainer = void 0;
-      node.typeArguments = void 0;
-      return node;
-    }
-    function createConstructorTypeNode2(typeParameters, parameters, type) {
-      return createConstructorTypeNode1(
-        /*modifiers*/
-        void 0,
-        typeParameters,
-        parameters,
-        type
-      );
-    }
-    function updateConstructorTypeNode(...args) {
-      return args.length === 5 ? updateConstructorTypeNode1(...args) : args.length === 4 ? updateConstructorTypeNode2(...args) : Debug.fail("Incorrect number of arguments specified.");
-    }
-    function updateConstructorTypeNode1(node, modifiers, typeParameters, parameters, type) {
-      return node.modifiers !== modifiers || node.typeParameters !== typeParameters || node.parameters !== parameters || node.type !== type ? finishUpdateBaseSignatureDeclaration(createConstructorTypeNode(modifiers, typeParameters, parameters, type), node) : node;
-    }
-    function updateConstructorTypeNode2(node, typeParameters, parameters, type) {
-      return updateConstructorTypeNode1(node, node.modifiers, typeParameters, parameters, type);
-    }
-    function createTypeQueryNode(exprName, typeArguments) {
-      const node = createBaseNode(185 /* TypeQuery */);
-      node.exprName = exprName;
-      node.typeArguments = typeArguments && parenthesizerRules().parenthesizeTypeArguments(typeArguments);
-      node.transformFlags = 1 /* ContainsTypeScript */;
-      return node;
-    }
-    function updateTypeQueryNode(node, exprName, typeArguments) {
-      return node.exprName !== exprName || node.typeArguments !== typeArguments ? update(createTypeQueryNode(exprName, typeArguments), node) : node;
-    }
-    function createTypeLiteralNode(members) {
-      const node = createBaseDeclaration(186 /* TypeLiteral */);
-      node.members = createNodeArray(members);
-      node.transformFlags = 1 /* ContainsTypeScript */;
-      return node;
-    }
-    function updateTypeLiteralNode(node, members) {
-      return node.members !== members ? update(createTypeLiteralNode(members), node) : node;
-    }
-    function createArrayTypeNode(elementType) {
-      const node = createBaseNode(187 /* ArrayType */);
-      node.elementType = parenthesizerRules().parenthesizeNonArrayTypeOfPostfixType(elementType);
-      node.transformFlags = 1 /* ContainsTypeScript */;
-      return node;
-    }
-    function updateArrayTypeNode(node, elementType) {
-      return node.elementType !== elementType ? update(createArrayTypeNode(elementType), node) : node;
-    }
-    function createTupleTypeNode(elements) {
-      const node = createBaseNode(188 /* TupleType */);
-      node.elements = createNodeArray(parenthesizerRules().parenthesizeElementTypesOfTupleType(elements));
-      node.transformFlags = 1 /* ContainsTypeScript */;
-      return node;
-    }
-    function updateTupleTypeNode(node, elements) {
-      return node.elements !== elements ? update(createTupleTypeNode(elements), node) : node;
-    }
-    function createNamedTupleMember(dotDotDotToken, name, questionToken, type) {
-      const node = createBaseDeclaration(201 /* NamedTupleMember */);
-      node.dotDotDotToken = dotDotDotToken;
-      node.name = name;
-      node.questionToken = questionToken;
-      node.type = type;
-      node.transformFlags = 1 /* ContainsTypeScript */;
-      node.jsDoc = void 0;
-      return node;
-    }
-    function updateNamedTupleMember(node, dotDotDotToken, name, questionToken, type) {
-      return node.dotDotDotToken !== dotDotDotToken || node.name !== name || node.questionToken !== questionToken || node.type !== type ? update(createNamedTupleMember(dotDotDotToken, name, questionToken, type), node) : node;
-    }
-    function createOptionalTypeNode(type) {
-      const node = createBaseNode(189 /* OptionalType */);
-      node.type = parenthesizerRules().parenthesizeTypeOfOptionalType(type);
-      node.transformFlags = 1 /* ContainsTypeScript */;
-      return node;
-    }
-    function updateOptionalTypeNode(node, type) {
-      return node.type !== type ? update(createOptionalTypeNode(type), node) : node;
-    }
-    function createRestTypeNode(type) {
-      const node = createBaseNode(190 /* RestType */);
-      node.type = type;
-      node.transformFlags = 1 /* ContainsTypeScript */;
-      return node;
-    }
-    function updateRestTypeNode(node, type) {
-      return node.type !== type ? update(createRestTypeNode(type), node) : node;
-    }
-    function createUnionOrIntersectionTypeNode(kind, types, parenthesize) {
-      const node = createBaseNode(kind);
-      node.types = factory2.createNodeArray(parenthesize(types));
-      node.transformFlags = 1 /* ContainsTypeScript */;
-      return node;
-    }
-    function updateUnionOrIntersectionTypeNode(node, types, parenthesize) {
-      return node.types !== types ? update(createUnionOrIntersectionTypeNode(node.kind, types, parenthesize), node) : node;
-    }
-    function createUnionTypeNode(types) {
-      return createUnionOrIntersectionTypeNode(191 /* UnionType */, types, parenthesizerRules().parenthesizeConstituentTypesOfUnionType);
-    }
-    function updateUnionTypeNode(node, types) {
-      return updateUnionOrIntersectionTypeNode(node, types, parenthesizerRules().parenthesizeConstituentTypesOfUnionType);
-    }
-    function createIntersectionTypeNode(types) {
-      return createUnionOrIntersectionTypeNode(192 /* IntersectionType */, types, parenthesizerRules().parenthesizeConstituentTypesOfIntersectionType);
-    }
-    function updateIntersectionTypeNode(node, types) {
-      return updateUnionOrIntersectionTypeNode(node, types, parenthesizerRules().parenthesizeConstituentTypesOfIntersectionType);
-    }
-    function createConditionalTypeNode(checkType, extendsType, trueType, falseType) {
-      const node = createBaseNode(193 /* ConditionalType */);
-      node.checkType = parenthesizerRules().parenthesizeCheckTypeOfConditionalType(checkType);
-      node.extendsType = parenthesizerRules().parenthesizeExtendsTypeOfConditionalType(extendsType);
-      node.trueType = trueType;
-      node.falseType = falseType;
-      node.transformFlags = 1 /* ContainsTypeScript */;
-      node.locals = void 0;
-      node.nextContainer = void 0;
-      return node;
-    }
-    function updateConditionalTypeNode(node, checkType, extendsType, trueType, falseType) {
-      return node.checkType !== checkType || node.extendsType !== extendsType || node.trueType !== trueType || node.falseType !== falseType ? update(createConditionalTypeNode(checkType, extendsType, trueType, falseType), node) : node;
-    }
-    function createInferTypeNode(typeParameter) {
-      const node = createBaseNode(194 /* InferType */);
-      node.typeParameter = typeParameter;
-      node.transformFlags = 1 /* ContainsTypeScript */;
-      return node;
-    }
-    function updateInferTypeNode(node, typeParameter) {
-      return node.typeParameter !== typeParameter ? update(createInferTypeNode(typeParameter), node) : node;
-    }
-    function createTemplateLiteralType(head, templateSpans) {
-      const node = createBaseNode(202 /* TemplateLiteralType */);
-      node.head = head;
-      node.templateSpans = createNodeArray(templateSpans);
-      node.transformFlags = 1 /* ContainsTypeScript */;
-      return node;
-    }
-    function updateTemplateLiteralType(node, head, templateSpans) {
-      return node.head !== head || node.templateSpans !== templateSpans ? update(createTemplateLiteralType(head, templateSpans), node) : node;
-    }
-    function createImportTypeNode(argument, assertions, qualifier, typeArguments, isTypeOf = false) {
-      const node = createBaseNode(204 /* ImportType */);
-      node.argument = argument;
-      node.assertions = assertions;
-      node.qualifier = qualifier;
-      node.typeArguments = typeArguments && parenthesizerRules().parenthesizeTypeArguments(typeArguments);
-      node.isTypeOf = isTypeOf;
-      node.transformFlags = 1 /* ContainsTypeScript */;
-      return node;
-    }
-    function updateImportTypeNode(node, argument, assertions, qualifier, typeArguments, isTypeOf = node.isTypeOf) {
-      return node.argument !== argument || node.assertions !== assertions || node.qualifier !== qualifier || node.typeArguments !== typeArguments || node.isTypeOf !== isTypeOf ? update(createImportTypeNode(argument, assertions, qualifier, typeArguments, isTypeOf), node) : node;
-    }
-    function createParenthesizedType(type) {
-      const node = createBaseNode(195 /* ParenthesizedType */);
-      node.type = type;
-      node.transformFlags = 1 /* ContainsTypeScript */;
-      return node;
-    }
-    function updateParenthesizedType(node, type) {
-      return node.type !== type ? update(createParenthesizedType(type), node) : node;
-    }
-    function createThisTypeNode() {
-      const node = createBaseNode(196 /* ThisType */);
-      node.transformFlags = 1 /* ContainsTypeScript */;
-      return node;
-    }
-    function createTypeOperatorNode(operator, type) {
-      const node = createBaseNode(197 /* TypeOperator */);
-      node.operator = operator;
-      node.type = operator === 148 /* ReadonlyKeyword */ ? parenthesizerRules().parenthesizeOperandOfReadonlyTypeOperator(type) : parenthesizerRules().parenthesizeOperandOfTypeOperator(type);
-      node.transformFlags = 1 /* ContainsTypeScript */;
-      return node;
-    }
-    function updateTypeOperatorNode(node, type) {
-      return node.type !== type ? update(createTypeOperatorNode(node.operator, type), node) : node;
-    }
-    function createIndexedAccessTypeNode(objectType, indexType) {
-      const node = createBaseNode(198 /* IndexedAccessType */);
-      node.objectType = parenthesizerRules().parenthesizeNonArrayTypeOfPostfixType(objectType);
-      node.indexType = indexType;
-      node.transformFlags = 1 /* ContainsTypeScript */;
-      return node;
-    }
-    function updateIndexedAccessTypeNode(node, objectType, indexType) {
-      return node.objectType !== objectType || node.indexType !== indexType ? update(createIndexedAccessTypeNode(objectType, indexType), node) : node;
-    }
-    function createMappedTypeNode(readonlyToken, typeParameter, nameType, questionToken, type, members) {
-      const node = createBaseDeclaration(199 /* MappedType */);
-      node.readonlyToken = readonlyToken;
-      node.typeParameter = typeParameter;
-      node.nameType = nameType;
-      node.questionToken = questionToken;
-      node.type = type;
-      node.members = members && createNodeArray(members);
-      node.transformFlags = 1 /* ContainsTypeScript */;
-      node.locals = void 0;
-      node.nextContainer = void 0;
-      return node;
-    }
-    function updateMappedTypeNode(node, readonlyToken, typeParameter, nameType, questionToken, type, members) {
-      return node.readonlyToken !== readonlyToken || node.typeParameter !== typeParameter || node.nameType !== nameType || node.questionToken !== questionToken || node.type !== type || node.members !== members ? update(createMappedTypeNode(readonlyToken, typeParameter, nameType, questionToken, type, members), node) : node;
-    }
-    function createLiteralTypeNode(literal) {
-      const node = createBaseNode(200 /* LiteralType */);
-      node.literal = literal;
-      node.transformFlags = 1 /* ContainsTypeScript */;
-      return node;
-    }
-    function updateLiteralTypeNode(node, literal) {
-      return node.literal !== literal ? update(createLiteralTypeNode(literal), node) : node;
-    }
-    function createObjectBindingPattern(elements) {
-      const node = createBaseNode(205 /* ObjectBindingPattern */);
-      node.elements = createNodeArray(elements);
-      node.transformFlags |= propagateChildrenFlags(node.elements) | 1024 /* ContainsES2015 */ | 524288 /* ContainsBindingPattern */;
-      if (node.transformFlags & 32768 /* ContainsRestOrSpread */) {
-        node.transformFlags |= 128 /* ContainsES2018 */ | 65536 /* ContainsObjectRestOrSpread */;
-      }
-      return node;
-    }
-    function updateObjectBindingPattern(node, elements) {
-      return node.elements !== elements ? update(createObjectBindingPattern(elements), node) : node;
-    }
-    function createArrayBindingPattern(elements) {
-      const node = createBaseNode(206 /* ArrayBindingPattern */);
-      node.elements = createNodeArray(elements);
-      node.transformFlags |= propagateChildrenFlags(node.elements) | 1024 /* ContainsES2015 */ | 524288 /* ContainsBindingPattern */;
-      return node;
-    }
-    function updateArrayBindingPattern(node, elements) {
-      return node.elements !== elements ? update(createArrayBindingPattern(elements), node) : node;
-    }
-    function createBindingElement(dotDotDotToken, propertyName, name, initializer) {
-      const node = createBaseDeclaration(207 /* BindingElement */);
-      node.dotDotDotToken = dotDotDotToken;
-      node.propertyName = asName(propertyName);
-      node.name = asName(name);
-      node.initializer = asInitializer(initializer);
-      node.transformFlags |= propagateChildFlags(node.dotDotDotToken) | propagateNameFlags(node.propertyName) | propagateNameFlags(node.name) | propagateChildFlags(node.initializer) | (node.dotDotDotToken ? 32768 /* ContainsRestOrSpread */ : 0 /* None */) | 1024 /* ContainsES2015 */;
-      node.flowNode = void 0;
-      return node;
-    }
-    function updateBindingElement(node, dotDotDotToken, propertyName, name, initializer) {
-      return node.propertyName !== propertyName || node.dotDotDotToken !== dotDotDotToken || node.name !== name || node.initializer !== initializer ? update(createBindingElement(dotDotDotToken, propertyName, name, initializer), node) : node;
-    }
-    function createArrayLiteralExpression(elements, multiLine) {
-      const node = createBaseNode(208 /* ArrayLiteralExpression */);
-      const lastElement = elements && lastOrUndefined(elements);
-      const elementsArray = createNodeArray(elements, lastElement && isOmittedExpression(lastElement) ? true : void 0);
-      node.elements = parenthesizerRules().parenthesizeExpressionsOfCommaDelimitedList(elementsArray);
-      node.multiLine = multiLine;
-      node.transformFlags |= propagateChildrenFlags(node.elements);
-      return node;
-    }
-    function updateArrayLiteralExpression(node, elements) {
-      return node.elements !== elements ? update(createArrayLiteralExpression(elements, node.multiLine), node) : node;
-    }
-    function createObjectLiteralExpression(properties, multiLine) {
-      const node = createBaseDeclaration(209 /* ObjectLiteralExpression */);
-      node.properties = createNodeArray(properties);
-      node.multiLine = multiLine;
-      node.transformFlags |= propagateChildrenFlags(node.properties);
-      node.jsDoc = void 0;
-      return node;
-    }
-    function updateObjectLiteralExpression(node, properties) {
-      return node.properties !== properties ? update(createObjectLiteralExpression(properties, node.multiLine), node) : node;
-    }
-    function createBasePropertyAccessExpression(expression, questionDotToken, name) {
-      const node = createBaseDeclaration(210 /* PropertyAccessExpression */);
-      node.expression = expression;
-      node.questionDotToken = questionDotToken;
-      node.name = name;
-      node.transformFlags = propagateChildFlags(node.expression) | propagateChildFlags(node.questionDotToken) | (isIdentifier(node.name) ? propagateIdentifierNameFlags(node.name) : propagateChildFlags(node.name) | 536870912 /* ContainsPrivateIdentifierInExpression */);
-      node.jsDoc = void 0;
-      node.flowNode = void 0;
-      return node;
-    }
-    function createPropertyAccessExpression(expression, name) {
-      const node = createBasePropertyAccessExpression(
-        parenthesizerRules().parenthesizeLeftSideOfAccess(
-          expression,
-          /*optionalChain*/
-          false
-        ),
-        /*questionDotToken*/
-        void 0,
-        asName(name)
-      );
-      if (isSuperKeyword(expression)) {
-        node.transformFlags |= 256 /* ContainsES2017 */ | 128 /* ContainsES2018 */;
-      }
-      return node;
-    }
-    function updatePropertyAccessExpression(node, expression, name) {
-      if (isPropertyAccessChain(node)) {
-        return updatePropertyAccessChain(node, expression, node.questionDotToken, cast(name, isIdentifier));
-      }
-      return node.expression !== expression || node.name !== name ? update(createPropertyAccessExpression(expression, name), node) : node;
-    }
-    function createPropertyAccessChain(expression, questionDotToken, name) {
-      const node = createBasePropertyAccessExpression(
-        parenthesizerRules().parenthesizeLeftSideOfAccess(
-          expression,
-          /*optionalChain*/
-          true
-        ),
-        questionDotToken,
-        asName(name)
-      );
-      node.flags |= 32 /* OptionalChain */;
-      node.transformFlags |= 32 /* ContainsES2020 */;
-      return node;
-    }
-    function updatePropertyAccessChain(node, expression, questionDotToken, name) {
-      Debug.assert(!!(node.flags & 32 /* OptionalChain */), "Cannot update a PropertyAccessExpression using updatePropertyAccessChain. Use updatePropertyAccess instead.");
-      return node.expression !== expression || node.questionDotToken !== questionDotToken || node.name !== name ? update(createPropertyAccessChain(expression, questionDotToken, name), node) : node;
-    }
-    function createBaseElementAccessExpression(expression, questionDotToken, argumentExpression) {
-      const node = createBaseDeclaration(211 /* ElementAccessExpression */);
-      node.expression = expression;
-      node.questionDotToken = questionDotToken;
-      node.argumentExpression = argumentExpression;
-      node.transformFlags |= propagateChildFlags(node.expression) | propagateChildFlags(node.questionDotToken) | propagateChildFlags(node.argumentExpression);
-      node.jsDoc = void 0;
-      node.flowNode = void 0;
-      return node;
-    }
-    function createElementAccessExpression(expression, index) {
-      const node = createBaseElementAccessExpression(
-        parenthesizerRules().parenthesizeLeftSideOfAccess(
-          expression,
-          /*optionalChain*/
-          false
-        ),
-        /*questionDotToken*/
-        void 0,
-        asExpression(index)
-      );
-      if (isSuperKeyword(expression)) {
-        node.transformFlags |= 256 /* ContainsES2017 */ | 128 /* ContainsES2018 */;
-      }
-      return node;
-    }
-    function updateElementAccessExpression(node, expression, argumentExpression) {
-      if (isElementAccessChain(node)) {
-        return updateElementAccessChain(node, expression, node.questionDotToken, argumentExpression);
-      }
-      return node.expression !== expression || node.argumentExpression !== argumentExpression ? update(createElementAccessExpression(expression, argumentExpression), node) : node;
-    }
-    function createElementAccessChain(expression, questionDotToken, index) {
-      const node = createBaseElementAccessExpression(
-        parenthesizerRules().parenthesizeLeftSideOfAccess(
-          expression,
-          /*optionalChain*/
-          true
-        ),
-        questionDotToken,
-        asExpression(index)
-      );
-      node.flags |= 32 /* OptionalChain */;
-      node.transformFlags |= 32 /* ContainsES2020 */;
-      return node;
-    }
-    function updateElementAccessChain(node, expression, questionDotToken, argumentExpression) {
-      Debug.assert(!!(node.flags & 32 /* OptionalChain */), "Cannot update a ElementAccessExpression using updateElementAccessChain. Use updateElementAccess instead.");
-      return node.expression !== expression || node.questionDotToken !== questionDotToken || node.argumentExpression !== argumentExpression ? update(createElementAccessChain(expression, questionDotToken, argumentExpression), node) : node;
-    }
-    function createBaseCallExpression(expression, questionDotToken, typeArguments, argumentsArray) {
-      const node = createBaseDeclaration(212 /* CallExpression */);
-      node.expression = expression;
-      node.questionDotToken = questionDotToken;
-      node.typeArguments = typeArguments;
-      node.arguments = argumentsArray;
-      node.transformFlags |= propagateChildFlags(node.expression) | propagateChildFlags(node.questionDotToken) | propagateChildrenFlags(node.typeArguments) | propagateChildrenFlags(node.arguments);
-      if (node.typeArguments) {
-        node.transformFlags |= 1 /* ContainsTypeScript */;
-      }
-      if (isSuperProperty(node.expression)) {
-        node.transformFlags |= 16384 /* ContainsLexicalThis */;
-      }
-      return node;
-    }
-    function createCallExpression(expression, typeArguments, argumentsArray) {
-      const node = createBaseCallExpression(
-        parenthesizerRules().parenthesizeLeftSideOfAccess(
-          expression,
-          /*optionalChain*/
-          false
-        ),
-        /*questionDotToken*/
-        void 0,
-        asNodeArray(typeArguments),
-        parenthesizerRules().parenthesizeExpressionsOfCommaDelimitedList(createNodeArray(argumentsArray))
-      );
-      if (isImportKeyword(node.expression)) {
-        node.transformFlags |= 8388608 /* ContainsDynamicImport */;
-      }
-      return node;
-    }
-    function updateCallExpression(node, expression, typeArguments, argumentsArray) {
-      if (isCallChain(node)) {
-        return updateCallChain(node, expression, node.questionDotToken, typeArguments, argumentsArray);
-      }
-      return node.expression !== expression || node.typeArguments !== typeArguments || node.arguments !== argumentsArray ? update(createCallExpression(expression, typeArguments, argumentsArray), node) : node;
-    }
-    function createCallChain(expression, questionDotToken, typeArguments, argumentsArray) {
-      const node = createBaseCallExpression(
-        parenthesizerRules().parenthesizeLeftSideOfAccess(
-          expression,
-          /*optionalChain*/
-          true
-        ),
-        questionDotToken,
-        asNodeArray(typeArguments),
-        parenthesizerRules().parenthesizeExpressionsOfCommaDelimitedList(createNodeArray(argumentsArray))
-      );
-      node.flags |= 32 /* OptionalChain */;
-      node.transformFlags |= 32 /* ContainsES2020 */;
-      return node;
-    }
-    function updateCallChain(node, expression, questionDotToken, typeArguments, argumentsArray) {
-      Debug.assert(!!(node.flags & 32 /* OptionalChain */), "Cannot update a CallExpression using updateCallChain. Use updateCall instead.");
-      return node.expression !== expression || node.questionDotToken !== questionDotToken || node.typeArguments !== typeArguments || node.arguments !== argumentsArray ? update(createCallChain(expression, questionDotToken, typeArguments, argumentsArray), node) : node;
-    }
-    function createNewExpression(expression, typeArguments, argumentsArray) {
-      const node = createBaseDeclaration(213 /* NewExpression */);
-      node.expression = parenthesizerRules().parenthesizeExpressionOfNew(expression);
-      node.typeArguments = asNodeArray(typeArguments);
-      node.arguments = argumentsArray ? parenthesizerRules().parenthesizeExpressionsOfCommaDelimitedList(argumentsArray) : void 0;
-      node.transformFlags |= propagateChildFlags(node.expression) | propagateChildrenFlags(node.typeArguments) | propagateChildrenFlags(node.arguments) | 32 /* ContainsES2020 */;
-      if (node.typeArguments) {
-        node.transformFlags |= 1 /* ContainsTypeScript */;
-      }
-      return node;
-    }
-    function updateNewExpression(node, expression, typeArguments, argumentsArray) {
-      return node.expression !== expression || node.typeArguments !== typeArguments || node.arguments !== argumentsArray ? update(createNewExpression(expression, typeArguments, argumentsArray), node) : node;
-    }
-    function createTaggedTemplateExpression(tag, typeArguments, template) {
-      const node = createBaseNode(214 /* TaggedTemplateExpression */);
-      node.tag = parenthesizerRules().parenthesizeLeftSideOfAccess(
-        tag,
-        /*optionalChain*/
-        false
-      );
-      node.typeArguments = asNodeArray(typeArguments);
-      node.template = template;
-      node.transformFlags |= propagateChildFlags(node.tag) | propagateChildrenFlags(node.typeArguments) | propagateChildFlags(node.template) | 1024 /* ContainsES2015 */;
-      if (node.typeArguments) {
-        node.transformFlags |= 1 /* ContainsTypeScript */;
-      }
-      if (hasInvalidEscape(node.template)) {
-        node.transformFlags |= 128 /* ContainsES2018 */;
-      }
-      return node;
-    }
-    function updateTaggedTemplateExpression(node, tag, typeArguments, template) {
-      return node.tag !== tag || node.typeArguments !== typeArguments || node.template !== template ? update(createTaggedTemplateExpression(tag, typeArguments, template), node) : node;
-    }
-    function createTypeAssertion(type, expression) {
-      const node = createBaseNode(215 /* TypeAssertionExpression */);
-      node.expression = parenthesizerRules().parenthesizeOperandOfPrefixUnary(expression);
-      node.type = type;
-      node.transformFlags |= propagateChildFlags(node.expression) | propagateChildFlags(node.type) | 1 /* ContainsTypeScript */;
-      return node;
-    }
-    function updateTypeAssertion(node, type, expression) {
-      return node.type !== type || node.expression !== expression ? update(createTypeAssertion(type, expression), node) : node;
-    }
-    function createParenthesizedExpression(expression) {
-      const node = createBaseNode(216 /* ParenthesizedExpression */);
-      node.expression = expression;
-      node.transformFlags = propagateChildFlags(node.expression);
-      node.jsDoc = void 0;
-      return node;
-    }
-    function updateParenthesizedExpression(node, expression) {
-      return node.expression !== expression ? update(createParenthesizedExpression(expression), node) : node;
-    }
-    function createFunctionExpression(modifiers, asteriskToken, name, typeParameters, parameters, type, body) {
-      const node = createBaseDeclaration(217 /* FunctionExpression */);
-      node.modifiers = asNodeArray(modifiers);
-      node.asteriskToken = asteriskToken;
-      node.name = asName(name);
-      node.typeParameters = asNodeArray(typeParameters);
-      node.parameters = createNodeArray(parameters);
-      node.type = type;
-      node.body = body;
-      const isAsync = modifiersToFlags(node.modifiers) & 512 /* Async */;
-      const isGenerator = !!node.asteriskToken;
-      const isAsyncGenerator = isAsync && isGenerator;
-      node.transformFlags = propagateChildrenFlags(node.modifiers) | propagateChildFlags(node.asteriskToken) | propagateNameFlags(node.name) | propagateChildrenFlags(node.typeParameters) | propagateChildrenFlags(node.parameters) | propagateChildFlags(node.type) | propagateChildFlags(node.body) & ~67108864 /* ContainsPossibleTopLevelAwait */ | (isAsyncGenerator ? 128 /* ContainsES2018 */ : isAsync ? 256 /* ContainsES2017 */ : isGenerator ? 2048 /* ContainsGenerator */ : 0 /* None */) | (node.typeParameters || node.type ? 1 /* ContainsTypeScript */ : 0 /* None */) | 4194304 /* ContainsHoistedDeclarationOrCompletion */;
-      node.typeArguments = void 0;
-      node.jsDoc = void 0;
-      node.locals = void 0;
-      node.nextContainer = void 0;
-      node.flowNode = void 0;
-      node.endFlowNode = void 0;
-      node.returnFlowNode = void 0;
-      return node;
-    }
-    function updateFunctionExpression(node, modifiers, asteriskToken, name, typeParameters, parameters, type, body) {
-      return node.name !== name || node.modifiers !== modifiers || node.asteriskToken !== asteriskToken || node.typeParameters !== typeParameters || node.parameters !== parameters || node.type !== type || node.body !== body ? finishUpdateBaseSignatureDeclaration(createFunctionExpression(modifiers, asteriskToken, name, typeParameters, parameters, type, body), node) : node;
-    }
-    function createArrowFunction(modifiers, typeParameters, parameters, type, equalsGreaterThanToken, body) {
-      const node = createBaseDeclaration(218 /* ArrowFunction */);
-      node.modifiers = asNodeArray(modifiers);
-      node.typeParameters = asNodeArray(typeParameters);
-      node.parameters = createNodeArray(parameters);
-      node.type = type;
-      node.equalsGreaterThanToken = equalsGreaterThanToken ?? createToken(39 /* EqualsGreaterThanToken */);
-      node.body = parenthesizerRules().parenthesizeConciseBodyOfArrowFunction(body);
-      const isAsync = modifiersToFlags(node.modifiers) & 512 /* Async */;
-      node.transformFlags = propagateChildrenFlags(node.modifiers) | propagateChildrenFlags(node.typeParameters) | propagateChildrenFlags(node.parameters) | propagateChildFlags(node.type) | propagateChildFlags(node.equalsGreaterThanToken) | propagateChildFlags(node.body) & ~67108864 /* ContainsPossibleTopLevelAwait */ | (node.typeParameters || node.type ? 1 /* ContainsTypeScript */ : 0 /* None */) | (isAsync ? 256 /* ContainsES2017 */ | 16384 /* ContainsLexicalThis */ : 0 /* None */) | 1024 /* ContainsES2015 */;
-      node.typeArguments = void 0;
-      node.jsDoc = void 0;
-      node.locals = void 0;
-      node.nextContainer = void 0;
-      node.flowNode = void 0;
-      node.endFlowNode = void 0;
-      node.returnFlowNode = void 0;
-      return node;
-    }
-    function updateArrowFunction(node, modifiers, typeParameters, parameters, type, equalsGreaterThanToken, body) {
-      return node.modifiers !== modifiers || node.typeParameters !== typeParameters || node.parameters !== parameters || node.type !== type || node.equalsGreaterThanToken !== equalsGreaterThanToken || node.body !== body ? finishUpdateBaseSignatureDeclaration(createArrowFunction(modifiers, typeParameters, parameters, type, equalsGreaterThanToken, body), node) : node;
-    }
-    function createDeleteExpression(expression) {
-      const node = createBaseNode(219 /* DeleteExpression */);
-      node.expression = parenthesizerRules().parenthesizeOperandOfPrefixUnary(expression);
-      node.transformFlags |= propagateChildFlags(node.expression);
-      return node;
-    }
-    function updateDeleteExpression(node, expression) {
-      return node.expression !== expression ? update(createDeleteExpression(expression), node) : node;
-    }
-    function createTypeOfExpression(expression) {
-      const node = createBaseNode(220 /* TypeOfExpression */);
-      node.expression = parenthesizerRules().parenthesizeOperandOfPrefixUnary(expression);
-      node.transformFlags |= propagateChildFlags(node.expression);
-      return node;
-    }
-    function updateTypeOfExpression(node, expression) {
-      return node.expression !== expression ? update(createTypeOfExpression(expression), node) : node;
-    }
-    function createVoidExpression(expression) {
-      const node = createBaseNode(221 /* VoidExpression */);
-      node.expression = parenthesizerRules().parenthesizeOperandOfPrefixUnary(expression);
-      node.transformFlags |= propagateChildFlags(node.expression);
-      return node;
-    }
-    function updateVoidExpression(node, expression) {
-      return node.expression !== expression ? update(createVoidExpression(expression), node) : node;
-    }
-    function createAwaitExpression(expression) {
-      const node = createBaseNode(222 /* AwaitExpression */);
-      node.expression = parenthesizerRules().parenthesizeOperandOfPrefixUnary(expression);
-      node.transformFlags |= propagateChildFlags(node.expression) | 256 /* ContainsES2017 */ | 128 /* ContainsES2018 */ | 2097152 /* ContainsAwait */;
-      return node;
-    }
-    function updateAwaitExpression(node, expression) {
-      return node.expression !== expression ? update(createAwaitExpression(expression), node) : node;
-    }
-    function createPrefixUnaryExpression(operator, operand) {
-      const node = createBaseNode(223 /* PrefixUnaryExpression */);
-      node.operator = operator;
-      node.operand = parenthesizerRules().parenthesizeOperandOfPrefixUnary(operand);
-      node.transformFlags |= propagateChildFlags(node.operand);
-      if ((operator === 46 /* PlusPlusToken */ || operator === 47 /* MinusMinusToken */) && isIdentifier(node.operand) && !isGeneratedIdentifier(node.operand) && !isLocalName(node.operand)) {
-        node.transformFlags |= 268435456 /* ContainsUpdateExpressionForIdentifier */;
-      }
-      return node;
-    }
-    function updatePrefixUnaryExpression(node, operand) {
-      return node.operand !== operand ? update(createPrefixUnaryExpression(node.operator, operand), node) : node;
-    }
-    function createPostfixUnaryExpression(operand, operator) {
-      const node = createBaseNode(224 /* PostfixUnaryExpression */);
-      node.operator = operator;
-      node.operand = parenthesizerRules().parenthesizeOperandOfPostfixUnary(operand);
-      node.transformFlags |= propagateChildFlags(node.operand);
-      if (isIdentifier(node.operand) && !isGeneratedIdentifier(node.operand) && !isLocalName(node.operand)) {
-        node.transformFlags |= 268435456 /* ContainsUpdateExpressionForIdentifier */;
-      }
-      return node;
-    }
-    function updatePostfixUnaryExpression(node, operand) {
-      return node.operand !== operand ? update(createPostfixUnaryExpression(operand, node.operator), node) : node;
-    }
-    function createBinaryExpression(left, operator, right) {
-      const node = createBaseDeclaration(225 /* BinaryExpression */);
-      const operatorToken = asToken(operator);
-      const operatorKind = operatorToken.kind;
-      node.left = parenthesizerRules().parenthesizeLeftSideOfBinary(operatorKind, left);
-      node.operatorToken = operatorToken;
-      node.right = parenthesizerRules().parenthesizeRightSideOfBinary(operatorKind, node.left, right);
-      node.transformFlags |= propagateChildFlags(node.left) | propagateChildFlags(node.operatorToken) | propagateChildFlags(node.right);
-      if (operatorKind === 61 /* QuestionQuestionToken */) {
-        node.transformFlags |= 32 /* ContainsES2020 */;
-      } else if (operatorKind === 64 /* EqualsToken */) {
-        if (isObjectLiteralExpression(node.left)) {
-          node.transformFlags |= 1024 /* ContainsES2015 */ | 128 /* ContainsES2018 */ | 4096 /* ContainsDestructuringAssignment */ | propagateAssignmentPatternFlags(node.left);
-        } else if (isArrayLiteralExpression(node.left)) {
-          node.transformFlags |= 1024 /* ContainsES2015 */ | 4096 /* ContainsDestructuringAssignment */ | propagateAssignmentPatternFlags(node.left);
-        }
-      } else if (operatorKind === 43 /* AsteriskAsteriskToken */ || operatorKind === 68 /* AsteriskAsteriskEqualsToken */) {
-        node.transformFlags |= 512 /* ContainsES2016 */;
-      } else if (isLogicalOrCoalescingAssignmentOperator(operatorKind)) {
-        node.transformFlags |= 16 /* ContainsES2021 */;
-      }
-      if (operatorKind === 103 /* InKeyword */ && isPrivateIdentifier(node.left)) {
-        node.transformFlags |= 536870912 /* ContainsPrivateIdentifierInExpression */;
-      }
-      node.jsDoc = void 0;
-      return node;
-    }
-    function propagateAssignmentPatternFlags(node) {
-      return containsObjectRestOrSpread(node) ? 65536 /* ContainsObjectRestOrSpread */ : 0 /* None */;
-    }
-    function updateBinaryExpression(node, left, operator, right) {
-      return node.left !== left || node.operatorToken !== operator || node.right !== right ? update(createBinaryExpression(left, operator, right), node) : node;
-    }
-    function createConditionalExpression(condition, questionToken, whenTrue, colonToken, whenFalse) {
-      const node = createBaseNode(226 /* ConditionalExpression */);
-      node.condition = parenthesizerRules().parenthesizeConditionOfConditionalExpression(condition);
-      node.questionToken = questionToken ?? createToken(58 /* QuestionToken */);
-      node.whenTrue = parenthesizerRules().parenthesizeBranchOfConditionalExpression(whenTrue);
-      node.colonToken = colonToken ?? createToken(59 /* ColonToken */);
-      node.whenFalse = parenthesizerRules().parenthesizeBranchOfConditionalExpression(whenFalse);
-      node.transformFlags |= propagateChildFlags(node.condition) | propagateChildFlags(node.questionToken) | propagateChildFlags(node.whenTrue) | propagateChildFlags(node.colonToken) | propagateChildFlags(node.whenFalse);
-      return node;
-    }
-    function updateConditionalExpression(node, condition, questionToken, whenTrue, colonToken, whenFalse) {
-      return node.condition !== condition || node.questionToken !== questionToken || node.whenTrue !== whenTrue || node.colonToken !== colonToken || node.whenFalse !== whenFalse ? update(createConditionalExpression(condition, questionToken, whenTrue, colonToken, whenFalse), node) : node;
-    }
-    function createTemplateExpression(head, templateSpans) {
-      const node = createBaseNode(227 /* TemplateExpression */);
-      node.head = head;
-      node.templateSpans = createNodeArray(templateSpans);
-      node.transformFlags |= propagateChildFlags(node.head) | propagateChildrenFlags(node.templateSpans) | 1024 /* ContainsES2015 */;
-      return node;
-    }
-    function updateTemplateExpression(node, head, templateSpans) {
-      return node.head !== head || node.templateSpans !== templateSpans ? update(createTemplateExpression(head, templateSpans), node) : node;
-    }
-    function checkTemplateLiteralLikeNode(kind, text, rawText, templateFlags = 0 /* None */) {
-      Debug.assert(!(templateFlags & ~7176 /* TemplateLiteralLikeFlags */), "Unsupported template flags.");
-      let cooked = void 0;
-      if (rawText !== void 0 && rawText !== text) {
-        cooked = getCookedText(kind, rawText);
-        if (typeof cooked === "object") {
-          return Debug.fail("Invalid raw text");
-        }
-      }
-      if (text === void 0) {
-        if (cooked === void 0) {
-          return Debug.fail("Arguments 'text' and 'rawText' may not both be undefined.");
-        }
-        text = cooked;
-      } else if (cooked !== void 0) {
-        Debug.assert(text === cooked, "Expected argument 'text' to be the normalized (i.e. 'cooked') version of argument 'rawText'.");
-      }
-      return text;
-    }
-    function getTransformFlagsOfTemplateLiteralLike(templateFlags) {
-      let transformFlags = 1024 /* ContainsES2015 */;
-      if (templateFlags) {
-        transformFlags |= 128 /* ContainsES2018 */;
-      }
-      return transformFlags;
-    }
-    function createTemplateLiteralLikeToken(kind, text, rawText, templateFlags) {
-      const node = createBaseToken(kind);
-      node.text = text;
-      node.rawText = rawText;
-      node.templateFlags = templateFlags & 7176 /* TemplateLiteralLikeFlags */;
-      node.transformFlags = getTransformFlagsOfTemplateLiteralLike(node.templateFlags);
-      return node;
-    }
-    function createTemplateLiteralLikeDeclaration(kind, text, rawText, templateFlags) {
-      const node = createBaseDeclaration(kind);
-      node.text = text;
-      node.rawText = rawText;
-      node.templateFlags = templateFlags & 7176 /* TemplateLiteralLikeFlags */;
-      node.transformFlags = getTransformFlagsOfTemplateLiteralLike(node.templateFlags);
-      return node;
-    }
-    function createTemplateLiteralLikeNode(kind, text, rawText, templateFlags) {
-      if (kind === 15 /* NoSubstitutionTemplateLiteral */) {
-        return createTemplateLiteralLikeDeclaration(kind, text, rawText, templateFlags);
-      }
-      return createTemplateLiteralLikeToken(kind, text, rawText, templateFlags);
-    }
-    function createTemplateHead(text, rawText, templateFlags) {
-      text = checkTemplateLiteralLikeNode(16 /* TemplateHead */, text, rawText, templateFlags);
-      return createTemplateLiteralLikeNode(16 /* TemplateHead */, text, rawText, templateFlags);
-    }
-    function createTemplateMiddle(text, rawText, templateFlags) {
-      text = checkTemplateLiteralLikeNode(16 /* TemplateHead */, text, rawText, templateFlags);
-      return createTemplateLiteralLikeNode(17 /* TemplateMiddle */, text, rawText, templateFlags);
-    }
-    function createTemplateTail(text, rawText, templateFlags) {
-      text = checkTemplateLiteralLikeNode(16 /* TemplateHead */, text, rawText, templateFlags);
-      return createTemplateLiteralLikeNode(18 /* TemplateTail */, text, rawText, templateFlags);
-    }
-    function createNoSubstitutionTemplateLiteral(text, rawText, templateFlags) {
-      text = checkTemplateLiteralLikeNode(16 /* TemplateHead */, text, rawText, templateFlags);
-      return createTemplateLiteralLikeDeclaration(15 /* NoSubstitutionTemplateLiteral */, text, rawText, templateFlags);
-    }
-    function createYieldExpression(asteriskToken, expression) {
-      Debug.assert(!asteriskToken || !!expression, "A `YieldExpression` with an asteriskToken must have an expression.");
-      const node = createBaseNode(228 /* YieldExpression */);
-      node.expression = expression && parenthesizerRules().parenthesizeExpressionForDisallowedComma(expression);
-      node.asteriskToken = asteriskToken;
-      node.transformFlags |= propagateChildFlags(node.expression) | propagateChildFlags(node.asteriskToken) | 1024 /* ContainsES2015 */ | 128 /* ContainsES2018 */ | 1048576 /* ContainsYield */;
-      return node;
-    }
-    function updateYieldExpression(node, asteriskToken, expression) {
-      return node.expression !== expression || node.asteriskToken !== asteriskToken ? update(createYieldExpression(asteriskToken, expression), node) : node;
-    }
-    function createSpreadElement(expression) {
-      const node = createBaseNode(229 /* SpreadElement */);
-      node.expression = parenthesizerRules().parenthesizeExpressionForDisallowedComma(expression);
-      node.transformFlags |= propagateChildFlags(node.expression) | 1024 /* ContainsES2015 */ | 32768 /* ContainsRestOrSpread */;
-      return node;
-    }
-    function updateSpreadElement(node, expression) {
-      return node.expression !== expression ? update(createSpreadElement(expression), node) : node;
-    }
-    function createClassExpression(modifiers, name, typeParameters, heritageClauses, members) {
-      const node = createBaseDeclaration(230 /* ClassExpression */);
-      node.modifiers = asNodeArray(modifiers);
-      node.name = asName(name);
-      node.typeParameters = asNodeArray(typeParameters);
-      node.heritageClauses = asNodeArray(heritageClauses);
-      node.members = createNodeArray(members);
-      node.transformFlags |= propagateChildrenFlags(node.modifiers) | propagateNameFlags(node.name) | propagateChildrenFlags(node.typeParameters) | propagateChildrenFlags(node.heritageClauses) | propagateChildrenFlags(node.members) | (node.typeParameters ? 1 /* ContainsTypeScript */ : 0 /* None */) | 1024 /* ContainsES2015 */;
-      node.jsDoc = void 0;
-      return node;
-    }
-    function updateClassExpression(node, modifiers, name, typeParameters, heritageClauses, members) {
-      return node.modifiers !== modifiers || node.name !== name || node.typeParameters !== typeParameters || node.heritageClauses !== heritageClauses || node.members !== members ? update(createClassExpression(modifiers, name, typeParameters, heritageClauses, members), node) : node;
-    }
-    function createOmittedExpression() {
-      return createBaseNode(231 /* OmittedExpression */);
-    }
-    function createExpressionWithTypeArguments(expression, typeArguments) {
-      const node = createBaseNode(232 /* ExpressionWithTypeArguments */);
-      node.expression = parenthesizerRules().parenthesizeLeftSideOfAccess(
-        expression,
-        /*optionalChain*/
-        false
-      );
-      node.typeArguments = typeArguments && parenthesizerRules().parenthesizeTypeArguments(typeArguments);
-      node.transformFlags |= propagateChildFlags(node.expression) | propagateChildrenFlags(node.typeArguments) | 1024 /* ContainsES2015 */;
-      return node;
-    }
-    function updateExpressionWithTypeArguments(node, expression, typeArguments) {
-      return node.expression !== expression || node.typeArguments !== typeArguments ? update(createExpressionWithTypeArguments(expression, typeArguments), node) : node;
-    }
-    function createAsExpression(expression, type) {
-      const node = createBaseNode(233 /* AsExpression */);
-      node.expression = expression;
-      node.type = type;
-      node.transformFlags |= propagateChildFlags(node.expression) | propagateChildFlags(node.type) | 1 /* ContainsTypeScript */;
-      return node;
-    }
-    function updateAsExpression(node, expression, type) {
-      return node.expression !== expression || node.type !== type ? update(createAsExpression(expression, type), node) : node;
-    }
-    function createNonNullExpression(expression) {
-      const node = createBaseNode(234 /* NonNullExpression */);
-      node.expression = parenthesizerRules().parenthesizeLeftSideOfAccess(
-        expression,
-        /*optionalChain*/
-        false
-      );
-      node.transformFlags |= propagateChildFlags(node.expression) | 1 /* ContainsTypeScript */;
-      return node;
-    }
-    function updateNonNullExpression(node, expression) {
-      if (isNonNullChain(node)) {
-        return updateNonNullChain(node, expression);
-      }
-      return node.expression !== expression ? update(createNonNullExpression(expression), node) : node;
-    }
-    function createSatisfiesExpression(expression, type) {
-      const node = createBaseNode(237 /* SatisfiesExpression */);
-      node.expression = expression;
-      node.type = type;
-      node.transformFlags |= propagateChildFlags(node.expression) | propagateChildFlags(node.type) | 1 /* ContainsTypeScript */;
-      return node;
-    }
-    function updateSatisfiesExpression(node, expression, type) {
-      return node.expression !== expression || node.type !== type ? update(createSatisfiesExpression(expression, type), node) : node;
-    }
-    function createNonNullChain(expression) {
-      const node = createBaseNode(234 /* NonNullExpression */);
-      node.flags |= 32 /* OptionalChain */;
-      node.expression = parenthesizerRules().parenthesizeLeftSideOfAccess(
-        expression,
-        /*optionalChain*/
-        true
-      );
-      node.transformFlags |= propagateChildFlags(node.expression) | 1 /* ContainsTypeScript */;
-      return node;
-    }
-    function updateNonNullChain(node, expression) {
-      Debug.assert(!!(node.flags & 32 /* OptionalChain */), "Cannot update a NonNullExpression using updateNonNullChain. Use updateNonNullExpression instead.");
-      return node.expression !== expression ? update(createNonNullChain(expression), node) : node;
-    }
-    function createMetaProperty(keywordToken, name) {
-      const node = createBaseNode(235 /* MetaProperty */);
-      node.keywordToken = keywordToken;
-      node.name = name;
-      node.transformFlags |= propagateChildFlags(node.name);
-      switch (keywordToken) {
-        case 105 /* NewKeyword */:
-          node.transformFlags |= 1024 /* ContainsES2015 */;
-          break;
-        case 102 /* ImportKeyword */:
-          node.transformFlags |= 32 /* ContainsES2020 */;
-          break;
-        default:
-          return Debug.assertNever(keywordToken);
-      }
-      node.flowNode = void 0;
-      return node;
-    }
-    function updateMetaProperty(node, name) {
-      return node.name !== name ? update(createMetaProperty(node.keywordToken, name), node) : node;
-    }
-    function createTemplateSpan(expression, literal) {
-      const node = createBaseNode(238 /* TemplateSpan */);
-      node.expression = expression;
-      node.literal = literal;
-      node.transformFlags |= propagateChildFlags(node.expression) | propagateChildFlags(node.literal) | 1024 /* ContainsES2015 */;
-      return node;
-    }
-    function updateTemplateSpan(node, expression, literal) {
-      return node.expression !== expression || node.literal !== literal ? update(createTemplateSpan(expression, literal), node) : node;
-    }
-    function createSemicolonClassElement() {
-      const node = createBaseNode(239 /* SemicolonClassElement */);
-      node.transformFlags |= 1024 /* ContainsES2015 */;
-      return node;
-    }
-    function createBlock(statements, multiLine) {
-      const node = createBaseNode(240 /* Block */);
-      node.statements = createNodeArray(statements);
-      node.multiLine = multiLine;
-      node.transformFlags |= propagateChildrenFlags(node.statements);
-      node.jsDoc = void 0;
-      node.locals = void 0;
-      node.nextContainer = void 0;
-      return node;
-    }
-    function updateBlock(node, statements) {
-      return node.statements !== statements ? update(createBlock(statements, node.multiLine), node) : node;
-    }
-    function createVariableStatement(modifiers, declarationList) {
-      const node = createBaseNode(242 /* VariableStatement */);
-      node.modifiers = asNodeArray(modifiers);
-      node.declarationList = isArray(declarationList) ? createVariableDeclarationList(declarationList) : declarationList;
-      node.transformFlags |= propagateChildrenFlags(node.modifiers) | propagateChildFlags(node.declarationList);
-      if (modifiersToFlags(node.modifiers) & 2 /* Ambient */) {
-        node.transformFlags = 1 /* ContainsTypeScript */;
-      }
-      node.jsDoc = void 0;
-      node.flowNode = void 0;
-      return node;
-    }
-    function updateVariableStatement(node, modifiers, declarationList) {
-      return node.modifiers !== modifiers || node.declarationList !== declarationList ? update(createVariableStatement(modifiers, declarationList), node) : node;
-    }
-    function createEmptyStatement() {
-      const node = createBaseNode(241 /* EmptyStatement */);
-      node.jsDoc = void 0;
-      return node;
-    }
-    function createExpressionStatement(expression) {
-      const node = createBaseNode(243 /* ExpressionStatement */);
-      node.expression = parenthesizerRules().parenthesizeExpressionOfExpressionStatement(expression);
-      node.transformFlags |= propagateChildFlags(node.expression);
-      node.jsDoc = void 0;
-      node.flowNode = void 0;
-      return node;
-    }
-    function updateExpressionStatement(node, expression) {
-      return node.expression !== expression ? update(createExpressionStatement(expression), node) : node;
-    }
-    function createIfStatement(expression, thenStatement, elseStatement) {
-      const node = createBaseNode(244 /* IfStatement */);
-      node.expression = expression;
-      node.thenStatement = asEmbeddedStatement(thenStatement);
-      node.elseStatement = asEmbeddedStatement(elseStatement);
-      node.transformFlags |= propagateChildFlags(node.expression) | propagateChildFlags(node.thenStatement) | propagateChildFlags(node.elseStatement);
-      node.jsDoc = void 0;
-      node.flowNode = void 0;
-      return node;
-    }
-    function updateIfStatement(node, expression, thenStatement, elseStatement) {
-      return node.expression !== expression || node.thenStatement !== thenStatement || node.elseStatement !== elseStatement ? update(createIfStatement(expression, thenStatement, elseStatement), node) : node;
-    }
-    function createDoStatement(statement, expression) {
-      const node = createBaseNode(245 /* DoStatement */);
-      node.statement = asEmbeddedStatement(statement);
-      node.expression = expression;
-      node.transformFlags |= propagateChildFlags(node.statement) | propagateChildFlags(node.expression);
-      node.jsDoc = void 0;
-      node.flowNode = void 0;
-      return node;
-    }
-    function updateDoStatement(node, statement, expression) {
-      return node.statement !== statement || node.expression !== expression ? update(createDoStatement(statement, expression), node) : node;
-    }
-    function createWhileStatement(expression, statement) {
-      const node = createBaseNode(246 /* WhileStatement */);
-      node.expression = expression;
-      node.statement = asEmbeddedStatement(statement);
-      node.transformFlags |= propagateChildFlags(node.expression) | propagateChildFlags(node.statement);
-      node.jsDoc = void 0;
-      node.flowNode = void 0;
-      return node;
-    }
-    function updateWhileStatement(node, expression, statement) {
-      return node.expression !== expression || node.statement !== statement ? update(createWhileStatement(expression, statement), node) : node;
-    }
-    function createForStatement(initializer, condition, incrementor, statement) {
-      const node = createBaseNode(247 /* ForStatement */);
-      node.initializer = initializer;
-      node.condition = condition;
-      node.incrementor = incrementor;
-      node.statement = asEmbeddedStatement(statement);
-      node.transformFlags |= propagateChildFlags(node.initializer) | propagateChildFlags(node.condition) | propagateChildFlags(node.incrementor) | propagateChildFlags(node.statement);
-      node.jsDoc = void 0;
-      node.locals = void 0;
-      node.nextContainer = void 0;
-      node.flowNode = void 0;
-      return node;
-    }
-    function updateForStatement(node, initializer, condition, incrementor, statement) {
-      return node.initializer !== initializer || node.condition !== condition || node.incrementor !== incrementor || node.statement !== statement ? update(createForStatement(initializer, condition, incrementor, statement), node) : node;
-    }
-    function createForInStatement(initializer, expression, statement) {
-      const node = createBaseNode(248 /* ForInStatement */);
-      node.initializer = initializer;
-      node.expression = expression;
-      node.statement = asEmbeddedStatement(statement);
-      node.transformFlags |= propagateChildFlags(node.initializer) | propagateChildFlags(node.expression) | propagateChildFlags(node.statement);
-      node.jsDoc = void 0;
-      node.locals = void 0;
-      node.nextContainer = void 0;
-      node.flowNode = void 0;
-      return node;
-    }
-    function updateForInStatement(node, initializer, expression, statement) {
-      return node.initializer !== initializer || node.expression !== expression || node.statement !== statement ? update(createForInStatement(initializer, expression, statement), node) : node;
-    }
-    function createForOfStatement(awaitModifier, initializer, expression, statement) {
-      const node = createBaseNode(249 /* ForOfStatement */);
-      node.awaitModifier = awaitModifier;
-      node.initializer = initializer;
-      node.expression = parenthesizerRules().parenthesizeExpressionForDisallowedComma(expression);
-      node.statement = asEmbeddedStatement(statement);
-      node.transformFlags |= propagateChildFlags(node.awaitModifier) | propagateChildFlags(node.initializer) | propagateChildFlags(node.expression) | propagateChildFlags(node.statement) | 1024 /* ContainsES2015 */;
-      if (awaitModifier)
-        node.transformFlags |= 128 /* ContainsES2018 */;
-      node.jsDoc = void 0;
-      node.locals = void 0;
-      node.nextContainer = void 0;
-      node.flowNode = void 0;
-      return node;
-    }
-    function updateForOfStatement(node, awaitModifier, initializer, expression, statement) {
-      return node.awaitModifier !== awaitModifier || node.initializer !== initializer || node.expression !== expression || node.statement !== statement ? update(createForOfStatement(awaitModifier, initializer, expression, statement), node) : node;
-    }
-    function createContinueStatement(label) {
-      const node = createBaseNode(250 /* ContinueStatement */);
-      node.label = asName(label);
-      node.transformFlags |= propagateChildFlags(node.label) | 4194304 /* ContainsHoistedDeclarationOrCompletion */;
-      node.jsDoc = void 0;
-      node.flowNode = void 0;
-      return node;
-    }
-    function updateContinueStatement(node, label) {
-      return node.label !== label ? update(createContinueStatement(label), node) : node;
-    }
-    function createBreakStatement(label) {
-      const node = createBaseNode(251 /* BreakStatement */);
-      node.label = asName(label);
-      node.transformFlags |= propagateChildFlags(node.label) | 4194304 /* ContainsHoistedDeclarationOrCompletion */;
-      node.jsDoc = void 0;
-      node.flowNode = void 0;
-      return node;
-    }
-    function updateBreakStatement(node, label) {
-      return node.label !== label ? update(createBreakStatement(label), node) : node;
-    }
-    function createReturnStatement(expression) {
-      const node = createBaseNode(252 /* ReturnStatement */);
-      node.expression = expression;
-      node.transformFlags |= propagateChildFlags(node.expression) | 128 /* ContainsES2018 */ | 4194304 /* ContainsHoistedDeclarationOrCompletion */;
-      node.jsDoc = void 0;
-      node.flowNode = void 0;
-      return node;
-    }
-    function updateReturnStatement(node, expression) {
-      return node.expression !== expression ? update(createReturnStatement(expression), node) : node;
-    }
-    function createWithStatement(expression, statement) {
-      const node = createBaseNode(253 /* WithStatement */);
-      node.expression = expression;
-      node.statement = asEmbeddedStatement(statement);
-      node.transformFlags |= propagateChildFlags(node.expression) | propagateChildFlags(node.statement);
-      node.jsDoc = void 0;
-      node.flowNode = void 0;
-      return node;
-    }
-    function updateWithStatement(node, expression, statement) {
-      return node.expression !== expression || node.statement !== statement ? update(createWithStatement(expression, statement), node) : node;
-    }
-    function createSwitchStatement(expression, caseBlock) {
-      const node = createBaseNode(254 /* SwitchStatement */);
-      node.expression = parenthesizerRules().parenthesizeExpressionForDisallowedComma(expression);
-      node.caseBlock = caseBlock;
-      node.transformFlags |= propagateChildFlags(node.expression) | propagateChildFlags(node.caseBlock);
-      node.jsDoc = void 0;
-      node.flowNode = void 0;
-      node.possiblyExhaustive = false;
-      return node;
-    }
-    function updateSwitchStatement(node, expression, caseBlock) {
-      return node.expression !== expression || node.caseBlock !== caseBlock ? update(createSwitchStatement(expression, caseBlock), node) : node;
-    }
-    function createLabeledStatement(label, statement) {
-      const node = createBaseNode(255 /* LabeledStatement */);
-      node.label = asName(label);
-      node.statement = asEmbeddedStatement(statement);
-      node.transformFlags |= propagateChildFlags(node.label) | propagateChildFlags(node.statement);
-      node.jsDoc = void 0;
-      node.flowNode = void 0;
-      return node;
-    }
-    function updateLabeledStatement(node, label, statement) {
-      return node.label !== label || node.statement !== statement ? update(createLabeledStatement(label, statement), node) : node;
-    }
-    function createThrowStatement(expression) {
-      const node = createBaseNode(256 /* ThrowStatement */);
-      node.expression = expression;
-      node.transformFlags |= propagateChildFlags(node.expression);
-      node.jsDoc = void 0;
-      node.flowNode = void 0;
-      return node;
-    }
-    function updateThrowStatement(node, expression) {
-      return node.expression !== expression ? update(createThrowStatement(expression), node) : node;
-    }
-    function createTryStatement(tryBlock, catchClause, finallyBlock) {
-      const node = createBaseNode(257 /* TryStatement */);
-      node.tryBlock = tryBlock;
-      node.catchClause = catchClause;
-      node.finallyBlock = finallyBlock;
-      node.transformFlags |= propagateChildFlags(node.tryBlock) | propagateChildFlags(node.catchClause) | propagateChildFlags(node.finallyBlock);
-      node.jsDoc = void 0;
-      node.flowNode = void 0;
-      return node;
-    }
-    function updateTryStatement(node, tryBlock, catchClause, finallyBlock) {
-      return node.tryBlock !== tryBlock || node.catchClause !== catchClause || node.finallyBlock !== finallyBlock ? update(createTryStatement(tryBlock, catchClause, finallyBlock), node) : node;
-    }
-    function createDebuggerStatement() {
-      const node = createBaseNode(258 /* DebuggerStatement */);
-      node.jsDoc = void 0;
-      node.flowNode = void 0;
-      return node;
-    }
-    function createVariableDeclaration(name, exclamationToken, type, initializer) {
-      const node = createBaseDeclaration(259 /* VariableDeclaration */);
-      node.name = asName(name);
-      node.exclamationToken = exclamationToken;
-      node.type = type;
-      node.initializer = asInitializer(initializer);
-      node.transformFlags |= propagateNameFlags(node.name) | propagateChildFlags(node.initializer) | (node.exclamationToken ?? node.type ? 1 /* ContainsTypeScript */ : 0 /* None */);
-      node.jsDoc = void 0;
-      return node;
-    }
-    function updateVariableDeclaration(node, name, exclamationToken, type, initializer) {
-      return node.name !== name || node.type !== type || node.exclamationToken !== exclamationToken || node.initializer !== initializer ? update(createVariableDeclaration(name, exclamationToken, type, initializer), node) : node;
-    }
-    function createVariableDeclarationList(declarations, flags2 = 0 /* None */) {
-      const node = createBaseNode(260 /* VariableDeclarationList */);
-      node.flags |= flags2 & 3 /* BlockScoped */;
-      node.declarations = createNodeArray(declarations);
-      node.transformFlags |= propagateChildrenFlags(node.declarations) | 4194304 /* ContainsHoistedDeclarationOrCompletion */;
-      if (flags2 & 3 /* BlockScoped */) {
-        node.transformFlags |= 1024 /* ContainsES2015 */ | 262144 /* ContainsBlockScopedBinding */;
-      }
-      return node;
-    }
-    function updateVariableDeclarationList(node, declarations) {
-      return node.declarations !== declarations ? update(createVariableDeclarationList(declarations, node.flags), node) : node;
-    }
-    function createFunctionDeclaration(modifiers, asteriskToken, name, typeParameters, parameters, type, body) {
-      const node = createBaseDeclaration(261 /* FunctionDeclaration */);
-      node.modifiers = asNodeArray(modifiers);
-      node.asteriskToken = asteriskToken;
-      node.name = asName(name);
-      node.typeParameters = asNodeArray(typeParameters);
-      node.parameters = createNodeArray(parameters);
-      node.type = type;
-      node.body = body;
-      if (!node.body || modifiersToFlags(node.modifiers) & 2 /* Ambient */) {
-        node.transformFlags = 1 /* ContainsTypeScript */;
-      } else {
-        const isAsync = modifiersToFlags(node.modifiers) & 512 /* Async */;
-        const isGenerator = !!node.asteriskToken;
-        const isAsyncGenerator = isAsync && isGenerator;
-        node.transformFlags = propagateChildrenFlags(node.modifiers) | propagateChildFlags(node.asteriskToken) | propagateNameFlags(node.name) | propagateChildrenFlags(node.typeParameters) | propagateChildrenFlags(node.parameters) | propagateChildFlags(node.type) | propagateChildFlags(node.body) & ~67108864 /* ContainsPossibleTopLevelAwait */ | (isAsyncGenerator ? 128 /* ContainsES2018 */ : isAsync ? 256 /* ContainsES2017 */ : isGenerator ? 2048 /* ContainsGenerator */ : 0 /* None */) | (node.typeParameters || node.type ? 1 /* ContainsTypeScript */ : 0 /* None */) | 4194304 /* ContainsHoistedDeclarationOrCompletion */;
-      }
-      node.typeArguments = void 0;
-      node.jsDoc = void 0;
-      node.locals = void 0;
-      node.nextContainer = void 0;
-      node.endFlowNode = void 0;
-      node.returnFlowNode = void 0;
-      return node;
-    }
-    function updateFunctionDeclaration(node, modifiers, asteriskToken, name, typeParameters, parameters, type, body) {
-      return node.modifiers !== modifiers || node.asteriskToken !== asteriskToken || node.name !== name || node.typeParameters !== typeParameters || node.parameters !== parameters || node.type !== type || node.body !== body ? finishUpdateFunctionDeclaration(createFunctionDeclaration(modifiers, asteriskToken, name, typeParameters, parameters, type, body), node) : node;
-    }
-    function finishUpdateFunctionDeclaration(updated, original) {
-      if (updated !== original) {
-        if (updated.modifiers === original.modifiers) {
-          updated.modifiers = original.modifiers;
-        }
-      }
-      return finishUpdateBaseSignatureDeclaration(updated, original);
-    }
-    function createClassDeclaration(modifiers, name, typeParameters, heritageClauses, members) {
-      const node = createBaseDeclaration(262 /* ClassDeclaration */);
-      node.modifiers = asNodeArray(modifiers);
-      node.name = asName(name);
-      node.typeParameters = asNodeArray(typeParameters);
-      node.heritageClauses = asNodeArray(heritageClauses);
-      node.members = createNodeArray(members);
-      if (modifiersToFlags(node.modifiers) & 2 /* Ambient */) {
-        node.transformFlags = 1 /* ContainsTypeScript */;
-      } else {
-        node.transformFlags |= propagateChildrenFlags(node.modifiers) | propagateNameFlags(node.name) | propagateChildrenFlags(node.typeParameters) | propagateChildrenFlags(node.heritageClauses) | propagateChildrenFlags(node.members) | (node.typeParameters ? 1 /* ContainsTypeScript */ : 0 /* None */) | 1024 /* ContainsES2015 */;
-        if (node.transformFlags & 8192 /* ContainsTypeScriptClassSyntax */) {
-          node.transformFlags |= 1 /* ContainsTypeScript */;
-        }
-      }
-      node.jsDoc = void 0;
-      return node;
-    }
-    function updateClassDeclaration(node, modifiers, name, typeParameters, heritageClauses, members) {
-      return node.modifiers !== modifiers || node.name !== name || node.typeParameters !== typeParameters || node.heritageClauses !== heritageClauses || node.members !== members ? update(createClassDeclaration(modifiers, name, typeParameters, heritageClauses, members), node) : node;
-    }
-    function createInterfaceDeclaration(modifiers, name, typeParameters, heritageClauses, members) {
-      const node = createBaseDeclaration(263 /* InterfaceDeclaration */);
-      node.modifiers = asNodeArray(modifiers);
-      node.name = asName(name);
-      node.typeParameters = asNodeArray(typeParameters);
-      node.heritageClauses = asNodeArray(heritageClauses);
-      node.members = createNodeArray(members);
-      node.transformFlags = 1 /* ContainsTypeScript */;
-      node.jsDoc = void 0;
-      return node;
-    }
-    function updateInterfaceDeclaration(node, modifiers, name, typeParameters, heritageClauses, members) {
-      return node.modifiers !== modifiers || node.name !== name || node.typeParameters !== typeParameters || node.heritageClauses !== heritageClauses || node.members !== members ? update(createInterfaceDeclaration(modifiers, name, typeParameters, heritageClauses, members), node) : node;
-    }
-    function createTypeAliasDeclaration(modifiers, name, typeParameters, type) {
-      const node = createBaseDeclaration(264 /* TypeAliasDeclaration */);
-      node.modifiers = asNodeArray(modifiers);
-      node.name = asName(name);
-      node.typeParameters = asNodeArray(typeParameters);
-      node.type = type;
-      node.transformFlags = 1 /* ContainsTypeScript */;
-      node.jsDoc = void 0;
-      node.locals = void 0;
-      node.nextContainer = void 0;
-      return node;
-    }
-    function updateTypeAliasDeclaration(node, modifiers, name, typeParameters, type) {
-      return node.modifiers !== modifiers || node.name !== name || node.typeParameters !== typeParameters || node.type !== type ? update(createTypeAliasDeclaration(modifiers, name, typeParameters, type), node) : node;
-    }
-    function createEnumDeclaration(modifiers, name, members) {
-      const node = createBaseDeclaration(265 /* EnumDeclaration */);
-      node.modifiers = asNodeArray(modifiers);
-      node.name = asName(name);
-      node.members = createNodeArray(members);
-      node.transformFlags |= propagateChildrenFlags(node.modifiers) | propagateChildFlags(node.name) | propagateChildrenFlags(node.members) | 1 /* ContainsTypeScript */;
-      node.transformFlags &= ~67108864 /* ContainsPossibleTopLevelAwait */;
-      node.jsDoc = void 0;
-      return node;
-    }
-    function updateEnumDeclaration(node, modifiers, name, members) {
-      return node.modifiers !== modifiers || node.name !== name || node.members !== members ? update(createEnumDeclaration(modifiers, name, members), node) : node;
-    }
-    function createModuleDeclaration(modifiers, name, body, flags2 = 0 /* None */) {
-      const node = createBaseDeclaration(266 /* ModuleDeclaration */);
-      node.modifiers = asNodeArray(modifiers);
-      node.flags |= flags2 & (16 /* Namespace */ | 4 /* NestedNamespace */ | 1024 /* GlobalAugmentation */);
-      node.name = name;
-      node.body = body;
-      if (modifiersToFlags(node.modifiers) & 2 /* Ambient */) {
-        node.transformFlags = 1 /* ContainsTypeScript */;
-      } else {
-        node.transformFlags |= propagateChildrenFlags(node.modifiers) | propagateChildFlags(node.name) | propagateChildFlags(node.body) | 1 /* ContainsTypeScript */;
-      }
-      node.transformFlags &= ~67108864 /* ContainsPossibleTopLevelAwait */;
-      node.jsDoc = void 0;
-      node.locals = void 0;
-      node.nextContainer = void 0;
-      return node;
-    }
-    function updateModuleDeclaration(node, modifiers, name, body) {
-      return node.modifiers !== modifiers || node.name !== name || node.body !== body ? update(createModuleDeclaration(modifiers, name, body, node.flags), node) : node;
-    }
-    function createModuleBlock(statements) {
-      const node = createBaseNode(267 /* ModuleBlock */);
-      node.statements = createNodeArray(statements);
-      node.transformFlags |= propagateChildrenFlags(node.statements);
-      node.jsDoc = void 0;
-      return node;
-    }
-    function updateModuleBlock(node, statements) {
-      return node.statements !== statements ? update(createModuleBlock(statements), node) : node;
-    }
-    function createCaseBlock(clauses) {
-      const node = createBaseNode(268 /* CaseBlock */);
-      node.clauses = createNodeArray(clauses);
-      node.transformFlags |= propagateChildrenFlags(node.clauses);
-      node.locals = void 0;
-      node.nextContainer = void 0;
-      return node;
-    }
-    function updateCaseBlock(node, clauses) {
-      return node.clauses !== clauses ? update(createCaseBlock(clauses), node) : node;
-    }
-    function createNamespaceExportDeclaration(name) {
-      const node = createBaseDeclaration(269 /* NamespaceExportDeclaration */);
-      node.name = asName(name);
-      node.transformFlags |= propagateIdentifierNameFlags(node.name) | 1 /* ContainsTypeScript */;
-      node.modifiers = void 0;
-      node.jsDoc = void 0;
-      return node;
-    }
-    function updateNamespaceExportDeclaration(node, name) {
-      return node.name !== name ? finishUpdateNamespaceExportDeclaration(createNamespaceExportDeclaration(name), node) : node;
-    }
-    function finishUpdateNamespaceExportDeclaration(updated, original) {
-      if (updated !== original) {
-        updated.modifiers = original.modifiers;
-      }
-      return update(updated, original);
-    }
-    function createImportEqualsDeclaration(modifiers, isTypeOnly, name, moduleReference) {
-      const node = createBaseDeclaration(270 /* ImportEqualsDeclaration */);
-      node.modifiers = asNodeArray(modifiers);
-      node.name = asName(name);
-      node.isTypeOnly = isTypeOnly;
-      node.moduleReference = moduleReference;
-      node.transformFlags |= propagateChildrenFlags(node.modifiers) | propagateIdentifierNameFlags(node.name) | propagateChildFlags(node.moduleReference);
-      if (!isExternalModuleReference(node.moduleReference)) {
-        node.transformFlags |= 1 /* ContainsTypeScript */;
-      }
-      node.transformFlags &= ~67108864 /* ContainsPossibleTopLevelAwait */;
-      node.jsDoc = void 0;
-      return node;
-    }
-    function updateImportEqualsDeclaration(node, modifiers, isTypeOnly, name, moduleReference) {
-      return node.modifiers !== modifiers || node.isTypeOnly !== isTypeOnly || node.name !== name || node.moduleReference !== moduleReference ? update(createImportEqualsDeclaration(modifiers, isTypeOnly, name, moduleReference), node) : node;
-    }
-    function createImportDeclaration(modifiers, importClause, moduleSpecifier, assertClause) {
-      const node = createBaseNode(271 /* ImportDeclaration */);
-      node.modifiers = asNodeArray(modifiers);
-      node.importClause = importClause;
-      node.moduleSpecifier = moduleSpecifier;
-      node.assertClause = assertClause;
-      node.transformFlags |= propagateChildFlags(node.importClause) | propagateChildFlags(node.moduleSpecifier);
-      node.transformFlags &= ~67108864 /* ContainsPossibleTopLevelAwait */;
-      node.jsDoc = void 0;
-      return node;
-    }
-    function updateImportDeclaration(node, modifiers, importClause, moduleSpecifier, assertClause) {
-      return node.modifiers !== modifiers || node.importClause !== importClause || node.moduleSpecifier !== moduleSpecifier || node.assertClause !== assertClause ? update(createImportDeclaration(modifiers, importClause, moduleSpecifier, assertClause), node) : node;
-    }
-    function createImportClause(isTypeOnly, name, namedBindings) {
-      const node = createBaseDeclaration(272 /* ImportClause */);
-      node.isTypeOnly = isTypeOnly;
-      node.name = name;
-      node.namedBindings = namedBindings;
-      node.transformFlags |= propagateChildFlags(node.name) | propagateChildFlags(node.namedBindings);
-      if (isTypeOnly) {
-        node.transformFlags |= 1 /* ContainsTypeScript */;
-      }
-      node.transformFlags &= ~67108864 /* ContainsPossibleTopLevelAwait */;
-      return node;
-    }
-    function updateImportClause(node, isTypeOnly, name, namedBindings) {
-      return node.isTypeOnly !== isTypeOnly || node.name !== name || node.namedBindings !== namedBindings ? update(createImportClause(isTypeOnly, name, namedBindings), node) : node;
-    }
-    function createAssertClause(elements, multiLine) {
-      const node = createBaseNode(299 /* AssertClause */);
-      node.elements = createNodeArray(elements);
-      node.multiLine = multiLine;
-      node.transformFlags |= 4 /* ContainsESNext */;
-      return node;
-    }
-    function updateAssertClause(node, elements, multiLine) {
-      return node.elements !== elements || node.multiLine !== multiLine ? update(createAssertClause(elements, multiLine), node) : node;
-    }
-    function createAssertEntry(name, value) {
-      const node = createBaseNode(300 /* AssertEntry */);
-      node.name = name;
-      node.value = value;
-      node.transformFlags |= 4 /* ContainsESNext */;
-      return node;
-    }
-    function updateAssertEntry(node, name, value) {
-      return node.name !== name || node.value !== value ? update(createAssertEntry(name, value), node) : node;
-    }
-    function createImportTypeAssertionContainer(clause, multiLine) {
-      const node = createBaseNode(301 /* ImportTypeAssertionContainer */);
-      node.assertClause = clause;
-      node.multiLine = multiLine;
-      return node;
-    }
-    function updateImportTypeAssertionContainer(node, clause, multiLine) {
-      return node.assertClause !== clause || node.multiLine !== multiLine ? update(createImportTypeAssertionContainer(clause, multiLine), node) : node;
-    }
-    function createNamespaceImport(name) {
-      const node = createBaseDeclaration(273 /* NamespaceImport */);
-      node.name = name;
-      node.transformFlags |= propagateChildFlags(node.name);
-      node.transformFlags &= ~67108864 /* ContainsPossibleTopLevelAwait */;
-      return node;
-    }
-    function updateNamespaceImport(node, name) {
-      return node.name !== name ? update(createNamespaceImport(name), node) : node;
-    }
-    function createNamespaceExport(name) {
-      const node = createBaseDeclaration(279 /* NamespaceExport */);
-      node.name = name;
-      node.transformFlags |= propagateChildFlags(node.name) | 32 /* ContainsES2020 */;
-      node.transformFlags &= ~67108864 /* ContainsPossibleTopLevelAwait */;
-      return node;
-    }
-    function updateNamespaceExport(node, name) {
-      return node.name !== name ? update(createNamespaceExport(name), node) : node;
-    }
-    function createNamedImports(elements) {
-      const node = createBaseNode(274 /* NamedImports */);
-      node.elements = createNodeArray(elements);
-      node.transformFlags |= propagateChildrenFlags(node.elements);
-      node.transformFlags &= ~67108864 /* ContainsPossibleTopLevelAwait */;
-      return node;
-    }
-    function updateNamedImports(node, elements) {
-      return node.elements !== elements ? update(createNamedImports(elements), node) : node;
-    }
-    function createImportSpecifier(isTypeOnly, propertyName, name) {
-      const node = createBaseDeclaration(275 /* ImportSpecifier */);
-      node.isTypeOnly = isTypeOnly;
-      node.propertyName = propertyName;
-      node.name = name;
-      node.transformFlags |= propagateChildFlags(node.propertyName) | propagateChildFlags(node.name);
-      node.transformFlags &= ~67108864 /* ContainsPossibleTopLevelAwait */;
-      return node;
-    }
-    function updateImportSpecifier(node, isTypeOnly, propertyName, name) {
-      return node.isTypeOnly !== isTypeOnly || node.propertyName !== propertyName || node.name !== name ? update(createImportSpecifier(isTypeOnly, propertyName, name), node) : node;
-    }
-    function createExportAssignment2(modifiers, isExportEquals, expression) {
-      const node = createBaseDeclaration(276 /* ExportAssignment */);
-      node.modifiers = asNodeArray(modifiers);
-      node.isExportEquals = isExportEquals;
-      node.expression = isExportEquals ? parenthesizerRules().parenthesizeRightSideOfBinary(
-        64 /* EqualsToken */,
-        /*leftSide*/
-        void 0,
-        expression
-      ) : parenthesizerRules().parenthesizeExpressionOfExportDefault(expression);
-      node.transformFlags |= propagateChildrenFlags(node.modifiers) | propagateChildFlags(node.expression);
-      node.transformFlags &= ~67108864 /* ContainsPossibleTopLevelAwait */;
-      node.jsDoc = void 0;
-      return node;
-    }
-    function updateExportAssignment(node, modifiers, expression) {
-      return node.modifiers !== modifiers || node.expression !== expression ? update(createExportAssignment2(modifiers, node.isExportEquals, expression), node) : node;
-    }
-    function createExportDeclaration(modifiers, isTypeOnly, exportClause, moduleSpecifier, assertClause) {
-      const node = createBaseDeclaration(277 /* ExportDeclaration */);
-      node.modifiers = asNodeArray(modifiers);
-      node.isTypeOnly = isTypeOnly;
-      node.exportClause = exportClause;
-      node.moduleSpecifier = moduleSpecifier;
-      node.assertClause = assertClause;
-      node.transformFlags |= propagateChildrenFlags(node.modifiers) | propagateChildFlags(node.exportClause) | propagateChildFlags(node.moduleSpecifier);
-      node.transformFlags &= ~67108864 /* ContainsPossibleTopLevelAwait */;
-      node.jsDoc = void 0;
-      return node;
-    }
-    function updateExportDeclaration(node, modifiers, isTypeOnly, exportClause, moduleSpecifier, assertClause) {
-      return node.modifiers !== modifiers || node.isTypeOnly !== isTypeOnly || node.exportClause !== exportClause || node.moduleSpecifier !== moduleSpecifier || node.assertClause !== assertClause ? finishUpdateExportDeclaration(createExportDeclaration(modifiers, isTypeOnly, exportClause, moduleSpecifier, assertClause), node) : node;
-    }
-    function finishUpdateExportDeclaration(updated, original) {
-      if (updated !== original) {
-        if (updated.modifiers === original.modifiers) {
-          updated.modifiers = original.modifiers;
-        }
-      }
-      return update(updated, original);
-    }
-    function createNamedExports(elements) {
-      const node = createBaseNode(278 /* NamedExports */);
-      node.elements = createNodeArray(elements);
-      node.transformFlags |= propagateChildrenFlags(node.elements);
-      node.transformFlags &= ~67108864 /* ContainsPossibleTopLevelAwait */;
-      return node;
-    }
-    function updateNamedExports(node, elements) {
-      return node.elements !== elements ? update(createNamedExports(elements), node) : node;
-    }
-    function createExportSpecifier(isTypeOnly, propertyName, name) {
-      const node = createBaseNode(280 /* ExportSpecifier */);
-      node.isTypeOnly = isTypeOnly;
-      node.propertyName = asName(propertyName);
-      node.name = asName(name);
-      node.transformFlags |= propagateChildFlags(node.propertyName) | propagateChildFlags(node.name);
-      node.transformFlags &= ~67108864 /* ContainsPossibleTopLevelAwait */;
-      node.jsDoc = void 0;
-      return node;
-    }
-    function updateExportSpecifier(node, isTypeOnly, propertyName, name) {
-      return node.isTypeOnly !== isTypeOnly || node.propertyName !== propertyName || node.name !== name ? update(createExportSpecifier(isTypeOnly, propertyName, name), node) : node;
-    }
-    function createMissingDeclaration() {
-      const node = createBaseDeclaration(281 /* MissingDeclaration */);
-      node.jsDoc = void 0;
-      return node;
-    }
-    function createExternalModuleReference(expression) {
-      const node = createBaseNode(282 /* ExternalModuleReference */);
-      node.expression = expression;
-      node.transformFlags |= propagateChildFlags(node.expression);
-      node.transformFlags &= ~67108864 /* ContainsPossibleTopLevelAwait */;
-      return node;
-    }
-    function updateExternalModuleReference(node, expression) {
-      return node.expression !== expression ? update(createExternalModuleReference(expression), node) : node;
-    }
-    function createJSDocPrimaryTypeWorker(kind) {
-      return createBaseNode(kind);
-    }
-    function createJSDocPrePostfixUnaryTypeWorker(kind, type, postfix = false) {
-      const node = createJSDocUnaryTypeWorker(
-        kind,
-        postfix ? type && parenthesizerRules().parenthesizeNonArrayTypeOfPostfixType(type) : type
-      );
-      node.postfix = postfix;
-      return node;
-    }
-    function createJSDocUnaryTypeWorker(kind, type) {
-      const node = createBaseNode(kind);
-      node.type = type;
-      return node;
-    }
-    function updateJSDocPrePostfixUnaryTypeWorker(kind, node, type) {
-      return node.type !== type ? update(createJSDocPrePostfixUnaryTypeWorker(kind, type, node.postfix), node) : node;
-    }
-    function updateJSDocUnaryTypeWorker(kind, node, type) {
-      return node.type !== type ? update(createJSDocUnaryTypeWorker(kind, type), node) : node;
-    }
-    function createJSDocFunctionType(parameters, type) {
-      const node = createBaseDeclaration(323 /* JSDocFunctionType */);
-      node.parameters = asNodeArray(parameters);
-      node.type = type;
-      node.transformFlags = propagateChildrenFlags(node.parameters) | (node.type ? 1 /* ContainsTypeScript */ : 0 /* None */);
-      node.jsDoc = void 0;
-      node.locals = void 0;
-      node.nextContainer = void 0;
-      node.typeArguments = void 0;
-      return node;
-    }
-    function updateJSDocFunctionType(node, parameters, type) {
-      return node.parameters !== parameters || node.type !== type ? update(createJSDocFunctionType(parameters, type), node) : node;
-    }
-    function createJSDocTypeLiteral(propertyTags, isArrayType = false) {
-      const node = createBaseDeclaration(328 /* JSDocTypeLiteral */);
-      node.jsDocPropertyTags = asNodeArray(propertyTags);
-      node.isArrayType = isArrayType;
-      return node;
-    }
-    function updateJSDocTypeLiteral(node, propertyTags, isArrayType) {
-      return node.jsDocPropertyTags !== propertyTags || node.isArrayType !== isArrayType ? update(createJSDocTypeLiteral(propertyTags, isArrayType), node) : node;
-    }
-    function createJSDocTypeExpression(type) {
-      const node = createBaseNode(315 /* JSDocTypeExpression */);
-      node.type = type;
-      return node;
-    }
-    function updateJSDocTypeExpression(node, type) {
-      return node.type !== type ? update(createJSDocTypeExpression(type), node) : node;
-    }
-    function createJSDocSignature(typeParameters, parameters, type) {
-      const node = createBaseDeclaration(329 /* JSDocSignature */);
-      node.typeParameters = asNodeArray(typeParameters);
-      node.parameters = createNodeArray(parameters);
-      node.type = type;
-      node.jsDoc = void 0;
-      node.locals = void 0;
-      node.nextContainer = void 0;
-      return node;
-    }
-    function updateJSDocSignature(node, typeParameters, parameters, type) {
-      return node.typeParameters !== typeParameters || node.parameters !== parameters || node.type !== type ? update(createJSDocSignature(typeParameters, parameters, type), node) : node;
-    }
-    function getDefaultTagName(node) {
-      const defaultTagName = getDefaultTagNameForKind(node.kind);
-      return node.tagName.escapedText === escapeLeadingUnderscores(defaultTagName) ? node.tagName : createIdentifier(defaultTagName);
-    }
-    function createBaseJSDocTag(kind, tagName, comment) {
-      const node = createBaseNode(kind);
-      node.tagName = tagName;
-      node.comment = comment;
-      return node;
-    }
-    function createBaseJSDocTagDeclaration(kind, tagName, comment) {
-      const node = createBaseDeclaration(kind);
-      node.tagName = tagName;
-      node.comment = comment;
-      return node;
-    }
-    function createJSDocTemplateTag(tagName, constraint, typeParameters, comment) {
-      const node = createBaseJSDocTag(351 /* JSDocTemplateTag */, tagName ?? createIdentifier("template"), comment);
-      node.constraint = constraint;
-      node.typeParameters = createNodeArray(typeParameters);
-      return node;
-    }
-    function updateJSDocTemplateTag(node, tagName = getDefaultTagName(node), constraint, typeParameters, comment) {
-      return node.tagName !== tagName || node.constraint !== constraint || node.typeParameters !== typeParameters || node.comment !== comment ? update(createJSDocTemplateTag(tagName, constraint, typeParameters, comment), node) : node;
-    }
-    function createJSDocTypedefTag(tagName, typeExpression, fullName, comment) {
-      const node = createBaseJSDocTagDeclaration(352 /* JSDocTypedefTag */, tagName ?? createIdentifier("typedef"), comment);
-      node.typeExpression = typeExpression;
-      node.fullName = fullName;
-      node.name = getJSDocTypeAliasName(fullName);
-      node.locals = void 0;
-      node.nextContainer = void 0;
-      return node;
-    }
-    function updateJSDocTypedefTag(node, tagName = getDefaultTagName(node), typeExpression, fullName, comment) {
-      return node.tagName !== tagName || node.typeExpression !== typeExpression || node.fullName !== fullName || node.comment !== comment ? update(createJSDocTypedefTag(tagName, typeExpression, fullName, comment), node) : node;
-    }
-    function createJSDocParameterTag(tagName, name, isBracketed, typeExpression, isNameFirst, comment) {
-      const node = createBaseJSDocTagDeclaration(347 /* JSDocParameterTag */, tagName ?? createIdentifier("param"), comment);
-      node.typeExpression = typeExpression;
-      node.name = name;
-      node.isNameFirst = !!isNameFirst;
-      node.isBracketed = isBracketed;
-      return node;
-    }
-    function updateJSDocParameterTag(node, tagName = getDefaultTagName(node), name, isBracketed, typeExpression, isNameFirst, comment) {
-      return node.tagName !== tagName || node.name !== name || node.isBracketed !== isBracketed || node.typeExpression !== typeExpression || node.isNameFirst !== isNameFirst || node.comment !== comment ? update(createJSDocParameterTag(tagName, name, isBracketed, typeExpression, isNameFirst, comment), node) : node;
-    }
-    function createJSDocPropertyTag(tagName, name, isBracketed, typeExpression, isNameFirst, comment) {
-      const node = createBaseJSDocTagDeclaration(354 /* JSDocPropertyTag */, tagName ?? createIdentifier("prop"), comment);
-      node.typeExpression = typeExpression;
-      node.name = name;
-      node.isNameFirst = !!isNameFirst;
-      node.isBracketed = isBracketed;
-      return node;
-    }
-    function updateJSDocPropertyTag(node, tagName = getDefaultTagName(node), name, isBracketed, typeExpression, isNameFirst, comment) {
-      return node.tagName !== tagName || node.name !== name || node.isBracketed !== isBracketed || node.typeExpression !== typeExpression || node.isNameFirst !== isNameFirst || node.comment !== comment ? update(createJSDocPropertyTag(tagName, name, isBracketed, typeExpression, isNameFirst, comment), node) : node;
-    }
-    function createJSDocCallbackTag(tagName, typeExpression, fullName, comment) {
-      const node = createBaseJSDocTagDeclaration(344 /* JSDocCallbackTag */, tagName ?? createIdentifier("callback"), comment);
-      node.typeExpression = typeExpression;
-      node.fullName = fullName;
-      node.name = getJSDocTypeAliasName(fullName);
-      node.locals = void 0;
-      node.nextContainer = void 0;
-      return node;
-    }
-    function updateJSDocCallbackTag(node, tagName = getDefaultTagName(node), typeExpression, fullName, comment) {
-      return node.tagName !== tagName || node.typeExpression !== typeExpression || node.fullName !== fullName || node.comment !== comment ? update(createJSDocCallbackTag(tagName, typeExpression, fullName, comment), node) : node;
-    }
-    function createJSDocOverloadTag(tagName, typeExpression, comment) {
-      const node = createBaseJSDocTag(345 /* JSDocOverloadTag */, tagName ?? createIdentifier("overload"), comment);
-      node.typeExpression = typeExpression;
-      return node;
-    }
-    function updateJSDocOverloadTag(node, tagName = getDefaultTagName(node), typeExpression, comment) {
-      return node.tagName !== tagName || node.typeExpression !== typeExpression || node.comment !== comment ? update(createJSDocOverloadTag(tagName, typeExpression, comment), node) : node;
-    }
-    function createJSDocAugmentsTag(tagName, className, comment) {
-      const node = createBaseJSDocTag(334 /* JSDocAugmentsTag */, tagName ?? createIdentifier("augments"), comment);
-      node.class = className;
-      return node;
-    }
-    function updateJSDocAugmentsTag(node, tagName = getDefaultTagName(node), className, comment) {
-      return node.tagName !== tagName || node.class !== className || node.comment !== comment ? update(createJSDocAugmentsTag(tagName, className, comment), node) : node;
-    }
-    function createJSDocImplementsTag(tagName, className, comment) {
-      const node = createBaseJSDocTag(335 /* JSDocImplementsTag */, tagName ?? createIdentifier("implements"), comment);
-      node.class = className;
-      return node;
-    }
-    function createJSDocSeeTag(tagName, name, comment) {
-      const node = createBaseJSDocTag(353 /* JSDocSeeTag */, tagName ?? createIdentifier("see"), comment);
-      node.name = name;
-      return node;
-    }
-    function updateJSDocSeeTag(node, tagName, name, comment) {
-      return node.tagName !== tagName || node.name !== name || node.comment !== comment ? update(createJSDocSeeTag(tagName, name, comment), node) : node;
-    }
-    function createJSDocNameReference(name) {
-      const node = createBaseNode(316 /* JSDocNameReference */);
-      node.name = name;
-      return node;
-    }
-    function updateJSDocNameReference(node, name) {
-      return node.name !== name ? update(createJSDocNameReference(name), node) : node;
-    }
-    function createJSDocMemberName(left, right) {
-      const node = createBaseNode(317 /* JSDocMemberName */);
-      node.left = left;
-      node.right = right;
-      node.transformFlags |= propagateChildFlags(node.left) | propagateChildFlags(node.right);
-      return node;
-    }
-    function updateJSDocMemberName(node, left, right) {
-      return node.left !== left || node.right !== right ? update(createJSDocMemberName(left, right), node) : node;
-    }
-    function createJSDocLink(name, text) {
-      const node = createBaseNode(330 /* JSDocLink */);
-      node.name = name;
-      node.text = text;
-      return node;
-    }
-    function updateJSDocLink(node, name, text) {
-      return node.name !== name ? update(createJSDocLink(name, text), node) : node;
-    }
-    function createJSDocLinkCode(name, text) {
-      const node = createBaseNode(331 /* JSDocLinkCode */);
-      node.name = name;
-      node.text = text;
-      return node;
-    }
-    function updateJSDocLinkCode(node, name, text) {
-      return node.name !== name ? update(createJSDocLinkCode(name, text), node) : node;
-    }
-    function createJSDocLinkPlain(name, text) {
-      const node = createBaseNode(332 /* JSDocLinkPlain */);
-      node.name = name;
-      node.text = text;
-      return node;
-    }
-    function updateJSDocLinkPlain(node, name, text) {
-      return node.name !== name ? update(createJSDocLinkPlain(name, text), node) : node;
-    }
-    function updateJSDocImplementsTag(node, tagName = getDefaultTagName(node), className, comment) {
-      return node.tagName !== tagName || node.class !== className || node.comment !== comment ? update(createJSDocImplementsTag(tagName, className, comment), node) : node;
-    }
-    function createJSDocSimpleTagWorker(kind, tagName, comment) {
-      const node = createBaseJSDocTag(kind, tagName ?? createIdentifier(getDefaultTagNameForKind(kind)), comment);
-      return node;
-    }
-    function updateJSDocSimpleTagWorker(kind, node, tagName = getDefaultTagName(node), comment) {
-      return node.tagName !== tagName || node.comment !== comment ? update(createJSDocSimpleTagWorker(kind, tagName, comment), node) : node;
-    }
-    function createJSDocTypeLikeTagWorker(kind, tagName, typeExpression, comment) {
-      const node = createBaseJSDocTag(kind, tagName ?? createIdentifier(getDefaultTagNameForKind(kind)), comment);
-      node.typeExpression = typeExpression;
-      return node;
-    }
-    function updateJSDocTypeLikeTagWorker(kind, node, tagName = getDefaultTagName(node), typeExpression, comment) {
-      return node.tagName !== tagName || node.typeExpression !== typeExpression || node.comment !== comment ? update(createJSDocTypeLikeTagWorker(kind, tagName, typeExpression, comment), node) : node;
-    }
-    function createJSDocUnknownTag(tagName, comment) {
-      const node = createBaseJSDocTag(333 /* JSDocTag */, tagName, comment);
-      return node;
-    }
-    function updateJSDocUnknownTag(node, tagName, comment) {
-      return node.tagName !== tagName || node.comment !== comment ? update(createJSDocUnknownTag(tagName, comment), node) : node;
-    }
-    function createJSDocEnumTag(tagName, typeExpression, comment) {
-      const node = createBaseJSDocTagDeclaration(346 /* JSDocEnumTag */, tagName ?? createIdentifier(getDefaultTagNameForKind(346 /* JSDocEnumTag */)), comment);
-      node.typeExpression = typeExpression;
-      node.locals = void 0;
-      node.nextContainer = void 0;
-      return node;
-    }
-    function updateJSDocEnumTag(node, tagName = getDefaultTagName(node), typeExpression, comment) {
-      return node.tagName !== tagName || node.typeExpression !== typeExpression || node.comment !== comment ? update(createJSDocEnumTag(tagName, typeExpression, comment), node) : node;
-    }
-    function createJSDocText(text) {
-      const node = createBaseNode(327 /* JSDocText */);
-      node.text = text;
-      return node;
-    }
-    function updateJSDocText(node, text) {
-      return node.text !== text ? update(createJSDocText(text), node) : node;
-    }
-    function createJSDocComment(comment, tags) {
-      const node = createBaseNode(326 /* JSDoc */);
-      node.comment = comment;
-      node.tags = asNodeArray(tags);
-      return node;
-    }
-    function updateJSDocComment(node, comment, tags) {
-      return node.comment !== comment || node.tags !== tags ? update(createJSDocComment(comment, tags), node) : node;
-    }
-    function createJsxElement(openingElement, children, closingElement) {
-      const node = createBaseNode(283 /* JsxElement */);
-      node.openingElement = openingElement;
-      node.children = createNodeArray(children);
-      node.closingElement = closingElement;
-      node.transformFlags |= propagateChildFlags(node.openingElement) | propagateChildrenFlags(node.children) | propagateChildFlags(node.closingElement) | 2 /* ContainsJsx */;
-      return node;
-    }
-    function updateJsxElement(node, openingElement, children, closingElement) {
-      return node.openingElement !== openingElement || node.children !== children || node.closingElement !== closingElement ? update(createJsxElement(openingElement, children, closingElement), node) : node;
-    }
-    function createJsxSelfClosingElement(tagName, typeArguments, attributes) {
-      const node = createBaseNode(284 /* JsxSelfClosingElement */);
-      node.tagName = tagName;
-      node.typeArguments = asNodeArray(typeArguments);
-      node.attributes = attributes;
-      node.transformFlags |= propagateChildFlags(node.tagName) | propagateChildrenFlags(node.typeArguments) | propagateChildFlags(node.attributes) | 2 /* ContainsJsx */;
-      if (node.typeArguments) {
-        node.transformFlags |= 1 /* ContainsTypeScript */;
-      }
-      return node;
-    }
-    function updateJsxSelfClosingElement(node, tagName, typeArguments, attributes) {
-      return node.tagName !== tagName || node.typeArguments !== typeArguments || node.attributes !== attributes ? update(createJsxSelfClosingElement(tagName, typeArguments, attributes), node) : node;
-    }
-    function createJsxOpeningElement(tagName, typeArguments, attributes) {
-      const node = createBaseNode(285 /* JsxOpeningElement */);
-      node.tagName = tagName;
-      node.typeArguments = asNodeArray(typeArguments);
-      node.attributes = attributes;
-      node.transformFlags |= propagateChildFlags(node.tagName) | propagateChildrenFlags(node.typeArguments) | propagateChildFlags(node.attributes) | 2 /* ContainsJsx */;
-      if (typeArguments) {
-        node.transformFlags |= 1 /* ContainsTypeScript */;
-      }
-      return node;
-    }
-    function updateJsxOpeningElement(node, tagName, typeArguments, attributes) {
-      return node.tagName !== tagName || node.typeArguments !== typeArguments || node.attributes !== attributes ? update(createJsxOpeningElement(tagName, typeArguments, attributes), node) : node;
-    }
-    function createJsxClosingElement(tagName) {
-      const node = createBaseNode(286 /* JsxClosingElement */);
-      node.tagName = tagName;
-      node.transformFlags |= propagateChildFlags(node.tagName) | 2 /* ContainsJsx */;
-      return node;
-    }
-    function updateJsxClosingElement(node, tagName) {
-      return node.tagName !== tagName ? update(createJsxClosingElement(tagName), node) : node;
-    }
-    function createJsxFragment(openingFragment, children, closingFragment) {
-      const node = createBaseNode(287 /* JsxFragment */);
-      node.openingFragment = openingFragment;
-      node.children = createNodeArray(children);
-      node.closingFragment = closingFragment;
-      node.transformFlags |= propagateChildFlags(node.openingFragment) | propagateChildrenFlags(node.children) | propagateChildFlags(node.closingFragment) | 2 /* ContainsJsx */;
-      return node;
-    }
-    function updateJsxFragment(node, openingFragment, children, closingFragment) {
-      return node.openingFragment !== openingFragment || node.children !== children || node.closingFragment !== closingFragment ? update(createJsxFragment(openingFragment, children, closingFragment), node) : node;
-    }
-    function createJsxText(text, containsOnlyTriviaWhiteSpaces) {
-      const node = createBaseNode(12 /* JsxText */);
-      node.text = text;
-      node.containsOnlyTriviaWhiteSpaces = !!containsOnlyTriviaWhiteSpaces;
-      node.transformFlags |= 2 /* ContainsJsx */;
-      return node;
-    }
-    function updateJsxText(node, text, containsOnlyTriviaWhiteSpaces) {
-      return node.text !== text || node.containsOnlyTriviaWhiteSpaces !== containsOnlyTriviaWhiteSpaces ? update(createJsxText(text, containsOnlyTriviaWhiteSpaces), node) : node;
-    }
-    function createJsxOpeningFragment() {
-      const node = createBaseNode(288 /* JsxOpeningFragment */);
-      node.transformFlags |= 2 /* ContainsJsx */;
-      return node;
-    }
-    function createJsxJsxClosingFragment() {
-      const node = createBaseNode(289 /* JsxClosingFragment */);
-      node.transformFlags |= 2 /* ContainsJsx */;
-      return node;
-    }
-    function createJsxAttribute(name, initializer) {
-      const node = createBaseDeclaration(290 /* JsxAttribute */);
-      node.name = name;
-      node.initializer = initializer;
-      node.transformFlags |= propagateChildFlags(node.name) | propagateChildFlags(node.initializer) | 2 /* ContainsJsx */;
-      return node;
-    }
-    function updateJsxAttribute(node, name, initializer) {
-      return node.name !== name || node.initializer !== initializer ? update(createJsxAttribute(name, initializer), node) : node;
-    }
-    function createJsxAttributes(properties) {
-      const node = createBaseDeclaration(291 /* JsxAttributes */);
-      node.properties = createNodeArray(properties);
-      node.transformFlags |= propagateChildrenFlags(node.properties) | 2 /* ContainsJsx */;
-      return node;
-    }
-    function updateJsxAttributes(node, properties) {
-      return node.properties !== properties ? update(createJsxAttributes(properties), node) : node;
-    }
-    function createJsxSpreadAttribute(expression) {
-      const node = createBaseNode(292 /* JsxSpreadAttribute */);
-      node.expression = expression;
-      node.transformFlags |= propagateChildFlags(node.expression) | 2 /* ContainsJsx */;
-      return node;
-    }
-    function updateJsxSpreadAttribute(node, expression) {
-      return node.expression !== expression ? update(createJsxSpreadAttribute(expression), node) : node;
-    }
-    function createJsxExpression(dotDotDotToken, expression) {
-      const node = createBaseNode(293 /* JsxExpression */);
-      node.dotDotDotToken = dotDotDotToken;
-      node.expression = expression;
-      node.transformFlags |= propagateChildFlags(node.dotDotDotToken) | propagateChildFlags(node.expression) | 2 /* ContainsJsx */;
-      return node;
-    }
-    function updateJsxExpression(node, expression) {
-      return node.expression !== expression ? update(createJsxExpression(node.dotDotDotToken, expression), node) : node;
-    }
-    function createJsxNamespacedName(namespace, name) {
-      const node = createBaseNode(294 /* JsxNamespacedName */);
-      node.namespace = namespace;
-      node.name = name;
-      node.transformFlags |= propagateChildFlags(node.namespace) | propagateChildFlags(node.name) | 2 /* ContainsJsx */;
-      return node;
-    }
-    function updateJsxNamespacedName(node, namespace, name) {
-      return node.namespace !== namespace || node.name !== name ? update(createJsxNamespacedName(namespace, name), node) : node;
-    }
-    function createCaseClause(expression, statements) {
-      const node = createBaseNode(295 /* CaseClause */);
-      node.expression = parenthesizerRules().parenthesizeExpressionForDisallowedComma(expression);
-      node.statements = createNodeArray(statements);
-      node.transformFlags |= propagateChildFlags(node.expression) | propagateChildrenFlags(node.statements);
-      node.jsDoc = void 0;
-      return node;
-    }
-    function updateCaseClause(node, expression, statements) {
-      return node.expression !== expression || node.statements !== statements ? update(createCaseClause(expression, statements), node) : node;
-    }
-    function createDefaultClause(statements) {
-      const node = createBaseNode(296 /* DefaultClause */);
-      node.statements = createNodeArray(statements);
-      node.transformFlags = propagateChildrenFlags(node.statements);
-      return node;
-    }
-    function updateDefaultClause(node, statements) {
-      return node.statements !== statements ? update(createDefaultClause(statements), node) : node;
-    }
-    function createHeritageClause(token, types) {
-      const node = createBaseNode(297 /* HeritageClause */);
-      node.token = token;
-      node.types = createNodeArray(types);
-      node.transformFlags |= propagateChildrenFlags(node.types);
-      switch (token) {
-        case 96 /* ExtendsKeyword */:
-          node.transformFlags |= 1024 /* ContainsES2015 */;
-          break;
-        case 119 /* ImplementsKeyword */:
-          node.transformFlags |= 1 /* ContainsTypeScript */;
-          break;
-        default:
-          return Debug.assertNever(token);
-      }
-      return node;
-    }
-    function updateHeritageClause(node, types) {
-      return node.types !== types ? update(createHeritageClause(node.token, types), node) : node;
-    }
-    function createCatchClause(variableDeclaration, block) {
-      const node = createBaseNode(298 /* CatchClause */);
-      node.variableDeclaration = asVariableDeclaration(variableDeclaration);
-      node.block = block;
-      node.transformFlags |= propagateChildFlags(node.variableDeclaration) | propagateChildFlags(node.block) | (!variableDeclaration ? 64 /* ContainsES2019 */ : 0 /* None */);
-      node.locals = void 0;
-      node.nextContainer = void 0;
-      return node;
-    }
-    function updateCatchClause(node, variableDeclaration, block) {
-      return node.variableDeclaration !== variableDeclaration || node.block !== block ? update(createCatchClause(variableDeclaration, block), node) : node;
-    }
-    function createPropertyAssignment(name, initializer) {
-      const node = createBaseDeclaration(302 /* PropertyAssignment */);
-      node.name = asName(name);
-      node.initializer = parenthesizerRules().parenthesizeExpressionForDisallowedComma(initializer);
-      node.transformFlags |= propagateNameFlags(node.name) | propagateChildFlags(node.initializer);
-      node.modifiers = void 0;
-      node.questionToken = void 0;
-      node.exclamationToken = void 0;
-      node.jsDoc = void 0;
-      return node;
-    }
-    function updatePropertyAssignment(node, name, initializer) {
-      return node.name !== name || node.initializer !== initializer ? finishUpdatePropertyAssignment(createPropertyAssignment(name, initializer), node) : node;
-    }
-    function finishUpdatePropertyAssignment(updated, original) {
-      if (updated !== original) {
-        updated.modifiers = original.modifiers;
-        updated.questionToken = original.questionToken;
-        updated.exclamationToken = original.exclamationToken;
-      }
-      return update(updated, original);
-    }
-    function createShorthandPropertyAssignment(name, objectAssignmentInitializer) {
-      const node = createBaseDeclaration(303 /* ShorthandPropertyAssignment */);
-      node.name = asName(name);
-      node.objectAssignmentInitializer = objectAssignmentInitializer && parenthesizerRules().parenthesizeExpressionForDisallowedComma(objectAssignmentInitializer);
-      node.transformFlags |= propagateIdentifierNameFlags(node.name) | propagateChildFlags(node.objectAssignmentInitializer) | 1024 /* ContainsES2015 */;
-      node.equalsToken = void 0;
-      node.modifiers = void 0;
-      node.questionToken = void 0;
-      node.exclamationToken = void 0;
-      node.jsDoc = void 0;
-      return node;
-    }
-    function updateShorthandPropertyAssignment(node, name, objectAssignmentInitializer) {
-      return node.name !== name || node.objectAssignmentInitializer !== objectAssignmentInitializer ? finishUpdateShorthandPropertyAssignment(createShorthandPropertyAssignment(name, objectAssignmentInitializer), node) : node;
-    }
-    function finishUpdateShorthandPropertyAssignment(updated, original) {
-      if (updated !== original) {
-        updated.modifiers = original.modifiers;
-        updated.questionToken = original.questionToken;
-        updated.exclamationToken = original.exclamationToken;
-        updated.equalsToken = original.equalsToken;
-      }
-      return update(updated, original);
-    }
-    function createSpreadAssignment(expression) {
-      const node = createBaseDeclaration(304 /* SpreadAssignment */);
-      node.expression = parenthesizerRules().parenthesizeExpressionForDisallowedComma(expression);
-      node.transformFlags |= propagateChildFlags(node.expression) | 128 /* ContainsES2018 */ | 65536 /* ContainsObjectRestOrSpread */;
-      node.jsDoc = void 0;
-      return node;
-    }
-    function updateSpreadAssignment(node, expression) {
-      return node.expression !== expression ? update(createSpreadAssignment(expression), node) : node;
-    }
-    function createEnumMember(name, initializer) {
-      const node = createBaseDeclaration(305 /* EnumMember */);
-      node.name = asName(name);
-      node.initializer = initializer && parenthesizerRules().parenthesizeExpressionForDisallowedComma(initializer);
-      node.transformFlags |= propagateChildFlags(node.name) | propagateChildFlags(node.initializer) | 1 /* ContainsTypeScript */;
-      node.jsDoc = void 0;
-      return node;
-    }
-    function updateEnumMember(node, name, initializer) {
-      return node.name !== name || node.initializer !== initializer ? update(createEnumMember(name, initializer), node) : node;
-    }
-    function createSourceFile2(statements, endOfFileToken, flags2) {
-      const node = baseFactory2.createBaseSourceFileNode(311 /* SourceFile */);
-      node.statements = createNodeArray(statements);
-      node.endOfFileToken = endOfFileToken;
-      node.flags |= flags2;
-      node.text = "";
-      node.fileName = "";
-      node.path = "";
-      node.resolvedPath = "";
-      node.originalFileName = "";
-      node.languageVersion = 0;
-      node.languageVariant = 0;
-      node.scriptKind = 0;
-      node.isDeclarationFile = false;
-      node.hasNoDefaultLib = false;
-      node.transformFlags |= propagateChildrenFlags(node.statements) | propagateChildFlags(node.endOfFileToken);
-      node.locals = void 0;
-      node.nextContainer = void 0;
-      node.endFlowNode = void 0;
-      node.nodeCount = 0;
-      node.identifierCount = 0;
-      node.symbolCount = 0;
-      node.parseDiagnostics = void 0;
-      node.bindDiagnostics = void 0;
-      node.bindSuggestionDiagnostics = void 0;
-      node.lineMap = void 0;
-      node.externalModuleIndicator = void 0;
-      node.setExternalModuleIndicator = void 0;
-      node.pragmas = void 0;
-      node.checkJsDirective = void 0;
-      node.referencedFiles = void 0;
-      node.typeReferenceDirectives = void 0;
-      node.libReferenceDirectives = void 0;
-      node.amdDependencies = void 0;
-      node.commentDirectives = void 0;
-      node.identifiers = void 0;
-      node.packageJsonLocations = void 0;
-      node.packageJsonScope = void 0;
-      node.imports = void 0;
-      node.moduleAugmentations = void 0;
-      node.ambientModuleNames = void 0;
-      node.resolvedModules = void 0;
-      node.classifiableNames = void 0;
-      node.impliedNodeFormat = void 0;
-      return node;
-    }
-    function createRedirectedSourceFile(redirectInfo) {
-      const node = Object.create(redirectInfo.redirectTarget);
-      Object.defineProperties(node, {
-        id: {
-          get() {
-            return this.redirectInfo.redirectTarget.id;
-          },
-          set(value) {
-            this.redirectInfo.redirectTarget.id = value;
-          }
-        },
-        symbol: {
-          get() {
-            return this.redirectInfo.redirectTarget.symbol;
-          },
-          set(value) {
-            this.redirectInfo.redirectTarget.symbol = value;
-          }
-        }
-      });
-      node.redirectInfo = redirectInfo;
-      return node;
-    }
-    function cloneRedirectedSourceFile(source) {
-      const node = createRedirectedSourceFile(source.redirectInfo);
-      node.flags |= source.flags & ~8 /* Synthesized */;
-      node.fileName = source.fileName;
-      node.path = source.path;
-      node.resolvedPath = source.resolvedPath;
-      node.originalFileName = source.originalFileName;
-      node.packageJsonLocations = source.packageJsonLocations;
-      node.packageJsonScope = source.packageJsonScope;
-      node.emitNode = void 0;
-      return node;
-    }
-    function cloneSourceFileWorker(source) {
-      const node = baseFactory2.createBaseSourceFileNode(311 /* SourceFile */);
-      node.flags |= source.flags & ~8 /* Synthesized */;
-      for (const p in source) {
-        if (hasProperty(node, p) || !hasProperty(source, p)) {
-          continue;
-        }
-        if (p === "emitNode") {
-          node.emitNode = void 0;
-          continue;
-        }
-        node[p] = source[p];
-      }
-      return node;
-    }
-    function cloneSourceFile(source) {
-      const node = source.redirectInfo ? cloneRedirectedSourceFile(source) : cloneSourceFileWorker(source);
-      setOriginalNode(node, source);
-      return node;
-    }
-    function cloneSourceFileWithChanges(source, statements, isDeclarationFile, referencedFiles, typeReferences, hasNoDefaultLib, libReferences) {
-      const node = cloneSourceFile(source);
-      node.statements = createNodeArray(statements);
-      node.isDeclarationFile = isDeclarationFile;
-      node.referencedFiles = referencedFiles;
-      node.typeReferenceDirectives = typeReferences;
-      node.hasNoDefaultLib = hasNoDefaultLib;
-      node.libReferenceDirectives = libReferences;
-      node.transformFlags = propagateChildrenFlags(node.statements) | propagateChildFlags(node.endOfFileToken);
-      return node;
-    }
-    function updateSourceFile2(node, statements, isDeclarationFile = node.isDeclarationFile, referencedFiles = node.referencedFiles, typeReferenceDirectives = node.typeReferenceDirectives, hasNoDefaultLib = node.hasNoDefaultLib, libReferenceDirectives = node.libReferenceDirectives) {
-      return node.statements !== statements || node.isDeclarationFile !== isDeclarationFile || node.referencedFiles !== referencedFiles || node.typeReferenceDirectives !== typeReferenceDirectives || node.hasNoDefaultLib !== hasNoDefaultLib || node.libReferenceDirectives !== libReferenceDirectives ? update(cloneSourceFileWithChanges(node, statements, isDeclarationFile, referencedFiles, typeReferenceDirectives, hasNoDefaultLib, libReferenceDirectives), node) : node;
-    }
-    function createBundle(sourceFiles, prepends = emptyArray) {
-      const node = createBaseNode(312 /* Bundle */);
-      node.prepends = prepends;
-      node.sourceFiles = sourceFiles;
-      node.syntheticFileReferences = void 0;
-      node.syntheticTypeReferences = void 0;
-      node.syntheticLibReferences = void 0;
-      node.hasNoDefaultLib = void 0;
-      return node;
-    }
-    function updateBundle(node, sourceFiles, prepends = emptyArray) {
-      return node.sourceFiles !== sourceFiles || node.prepends !== prepends ? update(createBundle(sourceFiles, prepends), node) : node;
-    }
-    function createUnparsedSource(prologues, syntheticReferences, texts) {
-      const node = createBaseNode(313 /* UnparsedSource */);
-      node.prologues = prologues;
-      node.syntheticReferences = syntheticReferences;
-      node.texts = texts;
-      node.fileName = "";
-      node.text = "";
-      node.referencedFiles = emptyArray;
-      node.libReferenceDirectives = emptyArray;
-      node.getLineAndCharacterOfPosition = (pos) => getLineAndCharacterOfPosition(node, pos);
-      return node;
-    }
-    function createBaseUnparsedNode(kind, data) {
-      const node = createBaseNode(kind);
-      node.data = data;
-      return node;
-    }
-    function createUnparsedPrologue(data) {
-      return createBaseUnparsedNode(306 /* UnparsedPrologue */, data);
-    }
-    function createUnparsedPrepend(data, texts) {
-      const node = createBaseUnparsedNode(307 /* UnparsedPrepend */, data);
-      node.texts = texts;
-      return node;
-    }
-    function createUnparsedTextLike(data, internal) {
-      return createBaseUnparsedNode(internal ? 309 /* UnparsedInternalText */ : 308 /* UnparsedText */, data);
-    }
-    function createUnparsedSyntheticReference(section) {
-      const node = createBaseNode(310 /* UnparsedSyntheticReference */);
-      node.data = section.data;
-      node.section = section;
-      return node;
-    }
-    function createInputFiles2() {
-      const node = createBaseNode(314 /* InputFiles */);
-      node.javascriptText = "";
-      node.declarationText = "";
-      return node;
-    }
-    function createSyntheticExpression(type, isSpread = false, tupleNameSource) {
-      const node = createBaseNode(236 /* SyntheticExpression */);
-      node.type = type;
-      node.isSpread = isSpread;
-      node.tupleNameSource = tupleNameSource;
-      return node;
-    }
-    function createSyntaxList3(children) {
-      const node = createBaseNode(357 /* SyntaxList */);
-      node._children = children;
-      return node;
-    }
-    function createNotEmittedStatement(original) {
-      const node = createBaseNode(358 /* NotEmittedStatement */);
-      node.original = original;
-      setTextRange(node, original);
-      return node;
-    }
-    function createPartiallyEmittedExpression(expression, original) {
-      const node = createBaseNode(359 /* PartiallyEmittedExpression */);
-      node.expression = expression;
-      node.original = original;
-      node.transformFlags |= propagateChildFlags(node.expression) | 1 /* ContainsTypeScript */;
-      setTextRange(node, original);
-      return node;
-    }
-    function updatePartiallyEmittedExpression(node, expression) {
-      return node.expression !== expression ? update(createPartiallyEmittedExpression(expression, node.original), node) : node;
-    }
-    function flattenCommaElements(node) {
-      if (nodeIsSynthesized(node) && !isParseTreeNode(node) && !node.original && !node.emitNode && !node.id) {
-        if (isCommaListExpression(node)) {
-          return node.elements;
-        }
-        if (isBinaryExpression(node) && isCommaToken(node.operatorToken)) {
-          return [node.left, node.right];
-        }
-      }
-      return node;
-    }
-    function createCommaListExpression(elements) {
-      const node = createBaseNode(360 /* CommaListExpression */);
-      node.elements = createNodeArray(sameFlatMap(elements, flattenCommaElements));
-      node.transformFlags |= propagateChildrenFlags(node.elements);
-      return node;
-    }
-    function updateCommaListExpression(node, elements) {
-      return node.elements !== elements ? update(createCommaListExpression(elements), node) : node;
-    }
-    function createSyntheticReferenceExpression(expression, thisArg) {
-      const node = createBaseNode(361 /* SyntheticReferenceExpression */);
-      node.expression = expression;
-      node.thisArg = thisArg;
-      node.transformFlags |= propagateChildFlags(node.expression) | propagateChildFlags(node.thisArg);
-      return node;
-    }
-    function updateSyntheticReferenceExpression(node, expression, thisArg) {
-      return node.expression !== expression || node.thisArg !== thisArg ? update(createSyntheticReferenceExpression(expression, thisArg), node) : node;
-    }
-    function cloneGeneratedIdentifier(node) {
-      const clone2 = createBaseIdentifier(node.escapedText);
-      clone2.flags |= node.flags & ~8 /* Synthesized */;
-      clone2.transformFlags = node.transformFlags;
-      setOriginalNode(clone2, node);
-      setIdentifierAutoGenerate(clone2, { ...node.emitNode.autoGenerate });
-      return clone2;
-    }
-    function cloneIdentifier(node) {
-      const clone2 = createBaseIdentifier(node.escapedText);
-      clone2.flags |= node.flags & ~8 /* Synthesized */;
-      clone2.jsDoc = node.jsDoc;
-      clone2.flowNode = node.flowNode;
-      clone2.symbol = node.symbol;
-      clone2.transformFlags = node.transformFlags;
-      setOriginalNode(clone2, node);
-      const typeArguments = getIdentifierTypeArguments(node);
-      if (typeArguments)
-        setIdentifierTypeArguments(clone2, typeArguments);
-      return clone2;
-    }
-    function cloneGeneratedPrivateIdentifier(node) {
-      const clone2 = createBasePrivateIdentifier(node.escapedText);
-      clone2.flags |= node.flags & ~8 /* Synthesized */;
-      clone2.transformFlags = node.transformFlags;
-      setOriginalNode(clone2, node);
-      setIdentifierAutoGenerate(clone2, { ...node.emitNode.autoGenerate });
-      return clone2;
-    }
-    function clonePrivateIdentifier(node) {
-      const clone2 = createBasePrivateIdentifier(node.escapedText);
-      clone2.flags |= node.flags & ~8 /* Synthesized */;
-      clone2.transformFlags = node.transformFlags;
-      setOriginalNode(clone2, node);
-      return clone2;
-    }
-    function cloneNode(node) {
-      if (node === void 0) {
-        return node;
-      }
-      if (isSourceFile(node)) {
-        return cloneSourceFile(node);
-      }
-      if (isGeneratedIdentifier(node)) {
-        return cloneGeneratedIdentifier(node);
-      }
-      if (isIdentifier(node)) {
-        return cloneIdentifier(node);
-      }
-      if (isGeneratedPrivateIdentifier(node)) {
-        return cloneGeneratedPrivateIdentifier(node);
-      }
-      if (isPrivateIdentifier(node)) {
-        return clonePrivateIdentifier(node);
-      }
-      const clone2 = !isNodeKind(node.kind) ? baseFactory2.createBaseTokenNode(node.kind) : baseFactory2.createBaseNode(node.kind);
-      clone2.flags |= node.flags & ~8 /* Synthesized */;
-      clone2.transformFlags = node.transformFlags;
-      setOriginalNode(clone2, node);
-      for (const key in node) {
-        if (hasProperty(clone2, key) || !hasProperty(node, key)) {
-          continue;
-        }
-        clone2[key] = node[key];
-      }
-      return clone2;
-    }
-    function createImmediatelyInvokedFunctionExpression(statements, param, paramValue) {
-      return createCallExpression(
-        createFunctionExpression(
-          /*modifiers*/
-          void 0,
-          /*asteriskToken*/
-          void 0,
-          /*name*/
-          void 0,
-          /*typeParameters*/
-          void 0,
-          /*parameters*/
-          param ? [param] : [],
-          /*type*/
-          void 0,
-          createBlock(
-            statements,
-            /*multiLine*/
-            true
-          )
-        ),
-        /*typeArguments*/
-        void 0,
-        /*argumentsArray*/
-        paramValue ? [paramValue] : []
-      );
-    }
-    function createImmediatelyInvokedArrowFunction(statements, param, paramValue) {
-      return createCallExpression(
-        createArrowFunction(
-          /*modifiers*/
-          void 0,
-          /*typeParameters*/
-          void 0,
-          /*parameters*/
-          param ? [param] : [],
-          /*type*/
-          void 0,
-          /*equalsGreaterThanToken*/
-          void 0,
-          createBlock(
-            statements,
-            /*multiLine*/
-            true
-          )
-        ),
-        /*typeArguments*/
-        void 0,
-        /*argumentsArray*/
-        paramValue ? [paramValue] : []
-      );
-    }
-    function createVoidZero() {
-      return createVoidExpression(createNumericLiteral("0"));
-    }
-    function createExportDefault(expression) {
-      return createExportAssignment2(
-        /*modifiers*/
-        void 0,
-        /*isExportEquals*/
-        false,
-        expression
-      );
-    }
-    function createExternalModuleExport(exportName) {
-      return createExportDeclaration(
-        /*modifiers*/
-        void 0,
-        /*isTypeOnly*/
-        false,
-        createNamedExports([
-          createExportSpecifier(
-            /*isTypeOnly*/
-            false,
-            /*propertyName*/
-            void 0,
-            exportName
-          )
-        ])
-      );
-    }
-    function createTypeCheck(value, tag) {
-      return tag === "undefined" ? factory2.createStrictEquality(value, createVoidZero()) : factory2.createStrictEquality(createTypeOfExpression(value), createStringLiteral(tag));
-    }
-    function createMethodCall(object, methodName, argumentsList) {
-      if (isCallChain(object)) {
-        return createCallChain(
-          createPropertyAccessChain(
-            object,
-            /*questionDotToken*/
-            void 0,
-            methodName
-          ),
-          /*questionDotToken*/
-          void 0,
-          /*typeArguments*/
-          void 0,
-          argumentsList
-        );
-      }
-      return createCallExpression(
-        createPropertyAccessExpression(object, methodName),
-        /*typeArguments*/
-        void 0,
-        argumentsList
-      );
-    }
-    function createFunctionBindCall(target, thisArg, argumentsList) {
-      return createMethodCall(target, "bind", [thisArg, ...argumentsList]);
-    }
-    function createFunctionCallCall(target, thisArg, argumentsList) {
-      return createMethodCall(target, "call", [thisArg, ...argumentsList]);
-    }
-    function createFunctionApplyCall(target, thisArg, argumentsExpression) {
-      return createMethodCall(target, "apply", [thisArg, argumentsExpression]);
-    }
-    function createGlobalMethodCall(globalObjectName, methodName, argumentsList) {
-      return createMethodCall(createIdentifier(globalObjectName), methodName, argumentsList);
-    }
-    function createArraySliceCall(array, start) {
-      return createMethodCall(array, "slice", start === void 0 ? [] : [asExpression(start)]);
-    }
-    function createArrayConcatCall(array, argumentsList) {
-      return createMethodCall(array, "concat", argumentsList);
-    }
-    function createObjectDefinePropertyCall(target, propertyName, attributes) {
-      return createGlobalMethodCall("Object", "defineProperty", [target, asExpression(propertyName), attributes]);
-    }
-    function createObjectGetOwnPropertyDescriptorCall(target, propertyName) {
-      return createGlobalMethodCall("Object", "getOwnPropertyDescriptor", [target, asExpression(propertyName)]);
-    }
-    function createReflectGetCall(target, propertyKey, receiver) {
-      return createGlobalMethodCall("Reflect", "get", receiver ? [target, propertyKey, receiver] : [target, propertyKey]);
-    }
-    function createReflectSetCall(target, propertyKey, value, receiver) {
-      return createGlobalMethodCall("Reflect", "set", receiver ? [target, propertyKey, value, receiver] : [target, propertyKey, value]);
-    }
-    function tryAddPropertyAssignment(properties, propertyName, expression) {
-      if (expression) {
-        properties.push(createPropertyAssignment(propertyName, expression));
-        return true;
-      }
-      return false;
-    }
-    function createPropertyDescriptor(attributes, singleLine) {
-      const properties = [];
-      tryAddPropertyAssignment(properties, "enumerable", asExpression(attributes.enumerable));
-      tryAddPropertyAssignment(properties, "configurable", asExpression(attributes.configurable));
-      let isData = tryAddPropertyAssignment(properties, "writable", asExpression(attributes.writable));
-      isData = tryAddPropertyAssignment(properties, "value", attributes.value) || isData;
-      let isAccessor2 = tryAddPropertyAssignment(properties, "get", attributes.get);
-      isAccessor2 = tryAddPropertyAssignment(properties, "set", attributes.set) || isAccessor2;
-      Debug.assert(!(isData && isAccessor2), "A PropertyDescriptor may not be both an accessor descriptor and a data descriptor.");
-      return createObjectLiteralExpression(properties, !singleLine);
-    }
-    function updateOuterExpression(outerExpression, expression) {
-      switch (outerExpression.kind) {
-        case 216 /* ParenthesizedExpression */:
-          return updateParenthesizedExpression(outerExpression, expression);
-        case 215 /* TypeAssertionExpression */:
-          return updateTypeAssertion(outerExpression, outerExpression.type, expression);
-        case 233 /* AsExpression */:
-          return updateAsExpression(outerExpression, expression, outerExpression.type);
-        case 237 /* SatisfiesExpression */:
-          return updateSatisfiesExpression(outerExpression, expression, outerExpression.type);
-        case 234 /* NonNullExpression */:
-          return updateNonNullExpression(outerExpression, expression);
-        case 359 /* PartiallyEmittedExpression */:
-          return updatePartiallyEmittedExpression(outerExpression, expression);
-      }
-    }
-    function isIgnorableParen(node) {
-      return isParenthesizedExpression(node) && nodeIsSynthesized(node) && nodeIsSynthesized(getSourceMapRange(node)) && nodeIsSynthesized(getCommentRange(node)) && !some(getSyntheticLeadingComments(node)) && !some(getSyntheticTrailingComments(node));
-    }
-    function restoreOuterExpressions(outerExpression, innerExpression, kinds = 15 /* All */) {
-      if (outerExpression && isOuterExpression(outerExpression, kinds) && !isIgnorableParen(outerExpression)) {
-        return updateOuterExpression(
-          outerExpression,
-          restoreOuterExpressions(outerExpression.expression, innerExpression)
-        );
-      }
-      return innerExpression;
-    }
-    function restoreEnclosingLabel(node, outermostLabeledStatement, afterRestoreLabelCallback) {
-      if (!outermostLabeledStatement) {
-        return node;
-      }
-      const updated = updateLabeledStatement(
-        outermostLabeledStatement,
-        outermostLabeledStatement.label,
-        isLabeledStatement(outermostLabeledStatement.statement) ? restoreEnclosingLabel(node, outermostLabeledStatement.statement) : node
-      );
-      if (afterRestoreLabelCallback) {
-        afterRestoreLabelCallback(outermostLabeledStatement);
-      }
-      return updated;
-    }
-    function shouldBeCapturedInTempVariable(node, cacheIdentifiers) {
-      const target = skipParentheses(node);
-      switch (target.kind) {
-        case 80 /* Identifier */:
-          return cacheIdentifiers;
-        case 110 /* ThisKeyword */:
-        case 9 /* NumericLiteral */:
-        case 10 /* BigIntLiteral */:
-        case 11 /* StringLiteral */:
-          return false;
-        case 208 /* ArrayLiteralExpression */:
-          const elements = target.elements;
-          if (elements.length === 0) {
-            return false;
-          }
-          return true;
-        case 209 /* ObjectLiteralExpression */:
-          return target.properties.length > 0;
-        default:
-          return true;
-      }
-    }
-    function createCallBinding(expression, recordTempVariable, languageVersion, cacheIdentifiers = false) {
-      const callee = skipOuterExpressions(expression, 15 /* All */);
-      let thisArg;
-      let target;
-      if (isSuperProperty(callee)) {
-        thisArg = createThis();
-        target = callee;
-      } else if (isSuperKeyword(callee)) {
-        thisArg = createThis();
-        target = languageVersion !== void 0 && languageVersion < 2 /* ES2015 */ ? setTextRange(createIdentifier("_super"), callee) : callee;
-      } else if (getEmitFlags(callee) & 8192 /* HelperName */) {
-        thisArg = createVoidZero();
-        target = parenthesizerRules().parenthesizeLeftSideOfAccess(
-          callee,
-          /*optionalChain*/
-          false
-        );
-      } else if (isPropertyAccessExpression(callee)) {
-        if (shouldBeCapturedInTempVariable(callee.expression, cacheIdentifiers)) {
-          thisArg = createTempVariable(recordTempVariable);
-          target = createPropertyAccessExpression(
-            setTextRange(
-              factory2.createAssignment(
-                thisArg,
-                callee.expression
-              ),
-              callee.expression
-            ),
-            callee.name
-          );
-          setTextRange(target, callee);
-        } else {
-          thisArg = callee.expression;
-          target = callee;
-        }
-      } else if (isElementAccessExpression(callee)) {
-        if (shouldBeCapturedInTempVariable(callee.expression, cacheIdentifiers)) {
-          thisArg = createTempVariable(recordTempVariable);
-          target = createElementAccessExpression(
-            setTextRange(
-              factory2.createAssignment(
-                thisArg,
-                callee.expression
-              ),
-              callee.expression
-            ),
-            callee.argumentExpression
-          );
-          setTextRange(target, callee);
-        } else {
-          thisArg = callee.expression;
-          target = callee;
-        }
-      } else {
-        thisArg = createVoidZero();
-        target = parenthesizerRules().parenthesizeLeftSideOfAccess(
-          expression,
-          /*optionalChain*/
-          false
-        );
-      }
-      return { target, thisArg };
-    }
-    function createAssignmentTargetWrapper(paramName, expression) {
-      return createPropertyAccessExpression(
-        // Explicit parens required because of v8 regression (https://bugs.chromium.org/p/v8/issues/detail?id=9560)
-        createParenthesizedExpression(
-          createObjectLiteralExpression([
-            createSetAccessorDeclaration(
-              /*modifiers*/
-              void 0,
-              "value",
-              [createParameterDeclaration(
-                /*modifiers*/
-                void 0,
-                /*dotDotDotToken*/
-                void 0,
-                paramName,
-                /*questionToken*/
-                void 0,
-                /*type*/
-                void 0,
-                /*initializer*/
-                void 0
-              )],
-              createBlock([
-                createExpressionStatement(expression)
-              ])
-            )
-          ])
-        ),
-        "value"
-      );
-    }
-    function inlineExpressions(expressions) {
-      return expressions.length > 10 ? createCommaListExpression(expressions) : reduceLeft(expressions, factory2.createComma);
-    }
-    function getName(node, allowComments, allowSourceMaps, emitFlags = 0, ignoreAssignedName) {
-      const nodeName = ignoreAssignedName ? node && getNonAssignedNameOfDeclaration(node) : getNameOfDeclaration(node);
-      if (nodeName && isIdentifier(nodeName) && !isGeneratedIdentifier(nodeName)) {
-        const name = setParent(setTextRange(cloneNode(nodeName), nodeName), nodeName.parent);
-        emitFlags |= getEmitFlags(nodeName);
-        if (!allowSourceMaps)
-          emitFlags |= 96 /* NoSourceMap */;
-        if (!allowComments)
-          emitFlags |= 3072 /* NoComments */;
-        if (emitFlags)
-          setEmitFlags(name, emitFlags);
-        return name;
-      }
-      return getGeneratedNameForNode(node);
-    }
-    function getInternalName(node, allowComments, allowSourceMaps) {
-      return getName(node, allowComments, allowSourceMaps, 32768 /* LocalName */ | 65536 /* InternalName */);
-    }
-    function getLocalName(node, allowComments, allowSourceMaps, ignoreAssignedName) {
-      return getName(node, allowComments, allowSourceMaps, 32768 /* LocalName */, ignoreAssignedName);
-    }
-    function getExportName(node, allowComments, allowSourceMaps) {
-      return getName(node, allowComments, allowSourceMaps, 16384 /* ExportName */);
-    }
-    function getDeclarationName(node, allowComments, allowSourceMaps) {
-      return getName(node, allowComments, allowSourceMaps);
-    }
-    function getNamespaceMemberName(ns, name, allowComments, allowSourceMaps) {
-      const qualifiedName = createPropertyAccessExpression(ns, nodeIsSynthesized(name) ? name : cloneNode(name));
-      setTextRange(qualifiedName, name);
-      let emitFlags = 0;
-      if (!allowSourceMaps)
-        emitFlags |= 96 /* NoSourceMap */;
-      if (!allowComments)
-        emitFlags |= 3072 /* NoComments */;
-      if (emitFlags)
-        setEmitFlags(qualifiedName, emitFlags);
-      return qualifiedName;
-    }
-    function getExternalModuleOrNamespaceExportName(ns, node, allowComments, allowSourceMaps) {
-      if (ns && hasSyntacticModifier(node, 1 /* Export */)) {
-        return getNamespaceMemberName(ns, getName(node), allowComments, allowSourceMaps);
-      }
-      return getExportName(node, allowComments, allowSourceMaps);
-    }
-    function copyPrologue(source, target, ensureUseStrict2, visitor) {
-      const offset = copyStandardPrologue(source, target, 0, ensureUseStrict2);
-      return copyCustomPrologue(source, target, offset, visitor);
-    }
-    function isUseStrictPrologue2(node) {
-      return isStringLiteral(node.expression) && node.expression.text === "use strict";
-    }
-    function createUseStrictPrologue() {
-      return startOnNewLine(createExpressionStatement(createStringLiteral("use strict")));
-    }
-    function copyStandardPrologue(source, target, statementOffset = 0, ensureUseStrict2) {
-      Debug.assert(target.length === 0, "Prologue directives should be at the first statement in the target statements array");
-      let foundUseStrict = false;
-      const numStatements = source.length;
-      while (statementOffset < numStatements) {
-        const statement = source[statementOffset];
-        if (isPrologueDirective(statement)) {
-          if (isUseStrictPrologue2(statement)) {
-            foundUseStrict = true;
-          }
-          target.push(statement);
-        } else {
-          break;
-        }
-        statementOffset++;
-      }
-      if (ensureUseStrict2 && !foundUseStrict) {
-        target.push(createUseStrictPrologue());
-      }
-      return statementOffset;
-    }
-    function copyCustomPrologue(source, target, statementOffset, visitor, filter2 = returnTrue) {
-      const numStatements = source.length;
-      while (statementOffset !== void 0 && statementOffset < numStatements) {
-        const statement = source[statementOffset];
-        if (getEmitFlags(statement) & 2097152 /* CustomPrologue */ && filter2(statement)) {
-          append(target, visitor ? visitNode(statement, visitor, isStatement) : statement);
-        } else {
-          break;
-        }
-        statementOffset++;
-      }
-      return statementOffset;
-    }
-    function ensureUseStrict(statements) {
-      const foundUseStrict = findUseStrictPrologue(statements);
-      if (!foundUseStrict) {
-        return setTextRange(createNodeArray([createUseStrictPrologue(), ...statements]), statements);
-      }
-      return statements;
-    }
-    function liftToBlock(nodes) {
-      Debug.assert(every(nodes, isStatementOrBlock), "Cannot lift nodes to a Block.");
-      return singleOrUndefined(nodes) || createBlock(nodes);
-    }
-    function findSpanEnd(array, test, start) {
-      let i = start;
-      while (i < array.length && test(array[i])) {
-        i++;
-      }
-      return i;
-    }
-    function mergeLexicalEnvironment(statements, declarations) {
-      if (!some(declarations)) {
-        return statements;
-      }
-      const leftStandardPrologueEnd = findSpanEnd(statements, isPrologueDirective, 0);
-      const leftHoistedFunctionsEnd = findSpanEnd(statements, isHoistedFunction, leftStandardPrologueEnd);
-      const leftHoistedVariablesEnd = findSpanEnd(statements, isHoistedVariableStatement, leftHoistedFunctionsEnd);
-      const rightStandardPrologueEnd = findSpanEnd(declarations, isPrologueDirective, 0);
-      const rightHoistedFunctionsEnd = findSpanEnd(declarations, isHoistedFunction, rightStandardPrologueEnd);
-      const rightHoistedVariablesEnd = findSpanEnd(declarations, isHoistedVariableStatement, rightHoistedFunctionsEnd);
-      const rightCustomPrologueEnd = findSpanEnd(declarations, isCustomPrologue, rightHoistedVariablesEnd);
-      Debug.assert(rightCustomPrologueEnd === declarations.length, "Expected declarations to be valid standard or custom prologues");
-      const left = isNodeArray(statements) ? statements.slice() : statements;
-      if (rightCustomPrologueEnd > rightHoistedVariablesEnd) {
-        left.splice(leftHoistedVariablesEnd, 0, ...declarations.slice(rightHoistedVariablesEnd, rightCustomPrologueEnd));
-      }
-      if (rightHoistedVariablesEnd > rightHoistedFunctionsEnd) {
-        left.splice(leftHoistedFunctionsEnd, 0, ...declarations.slice(rightHoistedFunctionsEnd, rightHoistedVariablesEnd));
-      }
-      if (rightHoistedFunctionsEnd > rightStandardPrologueEnd) {
-        left.splice(leftStandardPrologueEnd, 0, ...declarations.slice(rightStandardPrologueEnd, rightHoistedFunctionsEnd));
-      }
-      if (rightStandardPrologueEnd > 0) {
-        if (leftStandardPrologueEnd === 0) {
-          left.splice(0, 0, ...declarations.slice(0, rightStandardPrologueEnd));
-        } else {
-          const leftPrologues = /* @__PURE__ */ new Map();
-          for (let i = 0; i < leftStandardPrologueEnd; i++) {
-            const leftPrologue = statements[i];
-            leftPrologues.set(leftPrologue.expression.text, true);
-          }
-          for (let i = rightStandardPrologueEnd - 1; i >= 0; i--) {
-            const rightPrologue = declarations[i];
-            if (!leftPrologues.has(rightPrologue.expression.text)) {
-              left.unshift(rightPrologue);
-            }
-          }
-        }
-      }
-      if (isNodeArray(statements)) {
-        return setTextRange(createNodeArray(left, statements.hasTrailingComma), statements);
-      }
-      return statements;
-    }
-    function updateModifiers(node, modifiers) {
-      let modifierArray;
-      if (typeof modifiers === "number") {
-        modifierArray = createModifiersFromModifierFlags(modifiers);
-      } else {
-        modifierArray = modifiers;
-      }
-      return isTypeParameterDeclaration(node) ? updateTypeParameterDeclaration(node, modifierArray, node.name, node.constraint, node.default) : isParameter(node) ? updateParameterDeclaration(node, modifierArray, node.dotDotDotToken, node.name, node.questionToken, node.type, node.initializer) : isConstructorTypeNode(node) ? updateConstructorTypeNode1(node, modifierArray, node.typeParameters, node.parameters, node.type) : isPropertySignature(node) ? updatePropertySignature(node, modifierArray, node.name, node.questionToken, node.type) : isPropertyDeclaration(node) ? updatePropertyDeclaration2(node, modifierArray, node.name, node.questionToken ?? node.exclamationToken, node.type, node.initializer) : isMethodSignature(node) ? updateMethodSignature(node, modifierArray, node.name, node.questionToken, node.typeParameters, node.parameters, node.type) : isMethodDeclaration(node) ? updateMethodDeclaration(node, modifierArray, node.asteriskToken, node.name, node.questionToken, node.typeParameters, node.parameters, node.type, node.body) : isConstructorDeclaration(node) ? updateConstructorDeclaration(node, modifierArray, node.parameters, node.body) : isGetAccessorDeclaration(node) ? updateGetAccessorDeclaration(node, modifierArray, node.name, node.parameters, node.type, node.body) : isSetAccessorDeclaration(node) ? updateSetAccessorDeclaration(node, modifierArray, node.name, node.parameters, node.body) : isIndexSignatureDeclaration(node) ? updateIndexSignature(node, modifierArray, node.parameters, node.type) : isFunctionExpression(node) ? updateFunctionExpression(node, modifierArray, node.asteriskToken, node.name, node.typeParameters, node.parameters, node.type, node.body) : isArrowFunction(node) ? updateArrowFunction(node, modifierArray, node.typeParameters, node.parameters, node.type, node.equalsGreaterThanToken, node.body) : isClassExpression(node) ? updateClassExpression(node, modifierArray, node.name, node.typeParameters, node.heritageClauses, node.members) : isVariableStatement(node) ? updateVariableStatement(node, modifierArray, node.declarationList) : isFunctionDeclaration(node) ? updateFunctionDeclaration(node, modifierArray, node.asteriskToken, node.name, node.typeParameters, node.parameters, node.type, node.body) : isClassDeclaration(node) ? updateClassDeclaration(node, modifierArray, node.name, node.typeParameters, node.heritageClauses, node.members) : isInterfaceDeclaration(node) ? updateInterfaceDeclaration(node, modifierArray, node.name, node.typeParameters, node.heritageClauses, node.members) : isTypeAliasDeclaration(node) ? updateTypeAliasDeclaration(node, modifierArray, node.name, node.typeParameters, node.type) : isEnumDeclaration(node) ? updateEnumDeclaration(node, modifierArray, node.name, node.members) : isModuleDeclaration(node) ? updateModuleDeclaration(node, modifierArray, node.name, node.body) : isImportEqualsDeclaration(node) ? updateImportEqualsDeclaration(node, modifierArray, node.isTypeOnly, node.name, node.moduleReference) : isImportDeclaration(node) ? updateImportDeclaration(node, modifierArray, node.importClause, node.moduleSpecifier, node.assertClause) : isExportAssignment(node) ? updateExportAssignment(node, modifierArray, node.expression) : isExportDeclaration(node) ? updateExportDeclaration(node, modifierArray, node.isTypeOnly, node.exportClause, node.moduleSpecifier, node.assertClause) : Debug.assertNever(node);
-    }
-    function asNodeArray(array) {
-      return array ? createNodeArray(array) : void 0;
-    }
-    function asName(name) {
-      return typeof name === "string" ? createIdentifier(name) : name;
-    }
-    function asExpression(value) {
-      return typeof value === "string" ? createStringLiteral(value) : typeof value === "number" ? createNumericLiteral(value) : typeof value === "boolean" ? value ? createTrue() : createFalse() : value;
-    }
-    function asInitializer(node) {
-      return node && parenthesizerRules().parenthesizeExpressionForDisallowedComma(node);
-    }
-    function asToken(value) {
-      return typeof value === "number" ? createToken(value) : value;
-    }
-    function asEmbeddedStatement(statement) {
-      return statement && isNotEmittedStatement(statement) ? setTextRange(setOriginalNode(createEmptyStatement(), statement), statement) : statement;
-    }
-    function asVariableDeclaration(variableDeclaration) {
-      if (typeof variableDeclaration === "string" || variableDeclaration && !isVariableDeclaration(variableDeclaration)) {
-        return createVariableDeclaration(
-          variableDeclaration,
-          /*exclamationToken*/
-          void 0,
-          /*type*/
-          void 0,
-          /*initializer*/
-          void 0
-        );
-      }
-      return variableDeclaration;
-    }
-  }
-  function updateWithoutOriginal(updated, original) {
-    if (updated !== original) {
-      setTextRange(updated, original);
-    }
-    return updated;
-  }
-  function updateWithOriginal(updated, original) {
-    if (updated !== original) {
-      setOriginalNode(updated, original);
-      setTextRange(updated, original);
-    }
-    return updated;
-  }
-  function getDefaultTagNameForKind(kind) {
-    switch (kind) {
-      case 350 /* JSDocTypeTag */:
-        return "type";
-      case 348 /* JSDocReturnTag */:
-        return "returns";
-      case 349 /* JSDocThisTag */:
-        return "this";
-      case 346 /* JSDocEnumTag */:
-        return "enum";
-      case 336 /* JSDocAuthorTag */:
-        return "author";
-      case 338 /* JSDocClassTag */:
-        return "class";
-      case 339 /* JSDocPublicTag */:
-        return "public";
-      case 340 /* JSDocPrivateTag */:
-        return "private";
-      case 341 /* JSDocProtectedTag */:
-        return "protected";
-      case 342 /* JSDocReadonlyTag */:
-        return "readonly";
-      case 343 /* JSDocOverrideTag */:
-        return "override";
-      case 351 /* JSDocTemplateTag */:
-        return "template";
-      case 352 /* JSDocTypedefTag */:
-        return "typedef";
-      case 347 /* JSDocParameterTag */:
-        return "param";
-      case 354 /* JSDocPropertyTag */:
-        return "prop";
-      case 344 /* JSDocCallbackTag */:
-        return "callback";
-      case 345 /* JSDocOverloadTag */:
-        return "overload";
-      case 334 /* JSDocAugmentsTag */:
-        return "augments";
-      case 335 /* JSDocImplementsTag */:
-        return "implements";
-      default:
-        return Debug.fail(`Unsupported kind: ${Debug.formatSyntaxKind(kind)}`);
-    }
-  }
-  function getCookedText(kind, rawText) {
-    if (!rawTextScanner) {
-      rawTextScanner = createScanner(
-        99 /* Latest */,
-        /*skipTrivia*/
-        false,
-        0 /* Standard */
-      );
-    }
-    switch (kind) {
-      case 15 /* NoSubstitutionTemplateLiteral */:
-        rawTextScanner.setText("`" + rawText + "`");
-        break;
-      case 16 /* TemplateHead */:
-        rawTextScanner.setText("`" + rawText + "${");
-        break;
-      case 17 /* TemplateMiddle */:
-        rawTextScanner.setText("}" + rawText + "${");
-        break;
-      case 18 /* TemplateTail */:
-        rawTextScanner.setText("}" + rawText + "`");
-        break;
-    }
-    let token = rawTextScanner.scan();
-    if (token === 20 /* CloseBraceToken */) {
-      token = rawTextScanner.reScanTemplateToken(
-        /*isTaggedTemplate*/
-        false
-      );
-    }
-    if (rawTextScanner.isUnterminated()) {
-      rawTextScanner.setText(void 0);
-      return invalidValueSentinel;
-    }
-    let tokenValue;
-    switch (token) {
-      case 15 /* NoSubstitutionTemplateLiteral */:
-      case 16 /* TemplateHead */:
-      case 17 /* TemplateMiddle */:
-      case 18 /* TemplateTail */:
-        tokenValue = rawTextScanner.getTokenValue();
-        break;
-    }
-    if (tokenValue === void 0 || rawTextScanner.scan() !== 1 /* EndOfFileToken */) {
-      rawTextScanner.setText(void 0);
-      return invalidValueSentinel;
-    }
-    rawTextScanner.setText(void 0);
-    return tokenValue;
-  }
-  function propagateNameFlags(node) {
-    return node && isIdentifier(node) ? propagateIdentifierNameFlags(node) : propagateChildFlags(node);
-  }
-  function propagateIdentifierNameFlags(node) {
-    return propagateChildFlags(node) & ~67108864 /* ContainsPossibleTopLevelAwait */;
-  }
-  function propagatePropertyNameFlagsOfChild(node, transformFlags) {
-    return transformFlags | node.transformFlags & 134234112 /* PropertyNamePropagatingFlags */;
-  }
-  function propagateChildFlags(child) {
-    if (!child)
-      return 0 /* None */;
-    const childFlags = child.transformFlags & ~getTransformFlagsSubtreeExclusions(child.kind);
-    return isNamedDeclaration(child) && isPropertyName(child.name) ? propagatePropertyNameFlagsOfChild(child.name, childFlags) : childFlags;
-  }
-  function propagateChildrenFlags(children) {
-    return children ? children.transformFlags : 0 /* None */;
-  }
-  function aggregateChildrenFlags(children) {
-    let subtreeFlags = 0 /* None */;
-    for (const child of children) {
-      subtreeFlags |= propagateChildFlags(child);
-    }
-    children.transformFlags = subtreeFlags;
-  }
-  function getTransformFlagsSubtreeExclusions(kind) {
-    if (kind >= 181 /* FirstTypeNode */ && kind <= 204 /* LastTypeNode */) {
-      return -2 /* TypeExcludes */;
-    }
-    switch (kind) {
-      case 212 /* CallExpression */:
-      case 213 /* NewExpression */:
-      case 208 /* ArrayLiteralExpression */:
-        return -2147450880 /* ArrayLiteralOrCallOrNewExcludes */;
-      case 266 /* ModuleDeclaration */:
-        return -1941676032 /* ModuleExcludes */;
-      case 168 /* Parameter */:
-        return -2147483648 /* ParameterExcludes */;
-      case 218 /* ArrowFunction */:
-        return -2072174592 /* ArrowFunctionExcludes */;
-      case 217 /* FunctionExpression */:
-      case 261 /* FunctionDeclaration */:
-        return -1937940480 /* FunctionExcludes */;
-      case 260 /* VariableDeclarationList */:
-        return -2146893824 /* VariableDeclarationListExcludes */;
-      case 262 /* ClassDeclaration */:
-      case 230 /* ClassExpression */:
-        return -2147344384 /* ClassExcludes */;
-      case 175 /* Constructor */:
-        return -1937948672 /* ConstructorExcludes */;
-      case 171 /* PropertyDeclaration */:
-        return -2013249536 /* PropertyExcludes */;
-      case 173 /* MethodDeclaration */:
-      case 176 /* GetAccessor */:
-      case 177 /* SetAccessor */:
-        return -2005057536 /* MethodOrAccessorExcludes */;
-      case 133 /* AnyKeyword */:
-      case 150 /* NumberKeyword */:
-      case 162 /* BigIntKeyword */:
-      case 146 /* NeverKeyword */:
-      case 154 /* StringKeyword */:
-      case 151 /* ObjectKeyword */:
-      case 136 /* BooleanKeyword */:
-      case 155 /* SymbolKeyword */:
-      case 116 /* VoidKeyword */:
-      case 167 /* TypeParameter */:
-      case 170 /* PropertySignature */:
-      case 172 /* MethodSignature */:
-      case 178 /* CallSignature */:
-      case 179 /* ConstructSignature */:
-      case 180 /* IndexSignature */:
-      case 263 /* InterfaceDeclaration */:
-      case 264 /* TypeAliasDeclaration */:
-        return -2 /* TypeExcludes */;
-      case 209 /* ObjectLiteralExpression */:
-        return -2147278848 /* ObjectLiteralExcludes */;
-      case 298 /* CatchClause */:
-        return -2147418112 /* CatchClauseExcludes */;
-      case 205 /* ObjectBindingPattern */:
-      case 206 /* ArrayBindingPattern */:
-        return -2147450880 /* BindingPatternExcludes */;
-      case 215 /* TypeAssertionExpression */:
-      case 237 /* SatisfiesExpression */:
-      case 233 /* AsExpression */:
-      case 359 /* PartiallyEmittedExpression */:
-      case 216 /* ParenthesizedExpression */:
-      case 108 /* SuperKeyword */:
-        return -2147483648 /* OuterExpressionExcludes */;
-      case 210 /* PropertyAccessExpression */:
-      case 211 /* ElementAccessExpression */:
-        return -2147483648 /* PropertyAccessExcludes */;
-      default:
-        return -2147483648 /* NodeExcludes */;
-    }
-  }
-  function makeSynthetic(node) {
-    node.flags |= 8 /* Synthesized */;
-    return node;
-  }
-  function createUnparsedSourceFile(textOrInputFiles, mapPathOrType, mapTextOrStripInternal) {
-    let stripInternal;
-    let bundleFileInfo;
-    let fileName;
-    let text;
-    let length2;
-    let sourceMapPath;
-    let sourceMapText;
-    let getText;
-    let getSourceMapText;
-    let oldFileOfCurrentEmit;
-    if (!isString(textOrInputFiles)) {
-      Debug.assert(mapPathOrType === "js" || mapPathOrType === "dts");
-      fileName = (mapPathOrType === "js" ? textOrInputFiles.javascriptPath : textOrInputFiles.declarationPath) || "";
-      sourceMapPath = mapPathOrType === "js" ? textOrInputFiles.javascriptMapPath : textOrInputFiles.declarationMapPath;
-      getText = () => mapPathOrType === "js" ? textOrInputFiles.javascriptText : textOrInputFiles.declarationText;
-      getSourceMapText = () => mapPathOrType === "js" ? textOrInputFiles.javascriptMapText : textOrInputFiles.declarationMapText;
-      length2 = () => getText().length;
-      if (textOrInputFiles.buildInfo && textOrInputFiles.buildInfo.bundle) {
-        Debug.assert(mapTextOrStripInternal === void 0 || typeof mapTextOrStripInternal === "boolean");
-        stripInternal = mapTextOrStripInternal;
-        bundleFileInfo = mapPathOrType === "js" ? textOrInputFiles.buildInfo.bundle.js : textOrInputFiles.buildInfo.bundle.dts;
-        oldFileOfCurrentEmit = textOrInputFiles.oldFileOfCurrentEmit;
-      }
-    } else {
-      fileName = "";
-      text = textOrInputFiles;
-      length2 = textOrInputFiles.length;
-      sourceMapPath = mapPathOrType;
-      sourceMapText = mapTextOrStripInternal;
-    }
-    const node = oldFileOfCurrentEmit ? parseOldFileOfCurrentEmit(Debug.checkDefined(bundleFileInfo)) : parseUnparsedSourceFile(bundleFileInfo, stripInternal, length2);
-    node.fileName = fileName;
-    node.sourceMapPath = sourceMapPath;
-    node.oldFileOfCurrentEmit = oldFileOfCurrentEmit;
-    if (getText && getSourceMapText) {
-      Object.defineProperty(node, "text", { get: getText });
-      Object.defineProperty(node, "sourceMapText", { get: getSourceMapText });
-    } else {
-      Debug.assert(!oldFileOfCurrentEmit);
-      node.text = text ?? "";
-      node.sourceMapText = sourceMapText;
-    }
-    return node;
-  }
-  function parseUnparsedSourceFile(bundleFileInfo, stripInternal, length2) {
-    let prologues;
-    let helpers;
-    let referencedFiles;
-    let typeReferenceDirectives;
-    let libReferenceDirectives;
-    let prependChildren;
-    let texts;
-    let hasNoDefaultLib;
-    for (const section of bundleFileInfo ? bundleFileInfo.sections : emptyArray) {
-      switch (section.kind) {
-        case "prologue" /* Prologue */:
-          prologues = append(prologues, setTextRange(factory.createUnparsedPrologue(section.data), section));
-          break;
-        case "emitHelpers" /* EmitHelpers */:
-          helpers = append(helpers, getAllUnscopedEmitHelpers().get(section.data));
-          break;
-        case "no-default-lib" /* NoDefaultLib */:
-          hasNoDefaultLib = true;
-          break;
-        case "reference" /* Reference */:
-          referencedFiles = append(referencedFiles, { pos: -1, end: -1, fileName: section.data });
-          break;
-        case "type" /* Type */:
-          typeReferenceDirectives = append(typeReferenceDirectives, { pos: -1, end: -1, fileName: section.data });
-          break;
-        case "type-import" /* TypeResolutionModeImport */:
-          typeReferenceDirectives = append(typeReferenceDirectives, { pos: -1, end: -1, fileName: section.data, resolutionMode: 99 /* ESNext */ });
-          break;
-        case "type-require" /* TypeResolutionModeRequire */:
-          typeReferenceDirectives = append(typeReferenceDirectives, { pos: -1, end: -1, fileName: section.data, resolutionMode: 1 /* CommonJS */ });
-          break;
-        case "lib" /* Lib */:
-          libReferenceDirectives = append(libReferenceDirectives, { pos: -1, end: -1, fileName: section.data });
-          break;
-        case "prepend" /* Prepend */:
-          let prependTexts;
-          for (const text of section.texts) {
-            if (!stripInternal || text.kind !== "internal" /* Internal */) {
-              prependTexts = append(prependTexts, setTextRange(factory.createUnparsedTextLike(text.data, text.kind === "internal" /* Internal */), text));
-            }
-          }
-          prependChildren = addRange(prependChildren, prependTexts);
-          texts = append(texts, factory.createUnparsedPrepend(section.data, prependTexts ?? emptyArray));
-          break;
-        case "internal" /* Internal */:
-          if (stripInternal) {
-            if (!texts)
-              texts = [];
-            break;
-          }
-        case "text" /* Text */:
-          texts = append(texts, setTextRange(factory.createUnparsedTextLike(section.data, section.kind === "internal" /* Internal */), section));
-          break;
-        default:
-          Debug.assertNever(section);
-      }
-    }
-    if (!texts) {
-      const textNode = factory.createUnparsedTextLike(
-        /*data*/
-        void 0,
-        /*internal*/
-        false
-      );
-      setTextRangePosWidth(textNode, 0, typeof length2 === "function" ? length2() : length2);
-      texts = [textNode];
-    }
-    const node = parseNodeFactory.createUnparsedSource(
-      prologues ?? emptyArray,
-      /*syntheticReferences*/
-      void 0,
-      texts
-    );
-    setEachParent(prologues, node);
-    setEachParent(texts, node);
-    setEachParent(prependChildren, node);
-    node.hasNoDefaultLib = hasNoDefaultLib;
-    node.helpers = helpers;
-    node.referencedFiles = referencedFiles || emptyArray;
-    node.typeReferenceDirectives = typeReferenceDirectives;
-    node.libReferenceDirectives = libReferenceDirectives || emptyArray;
-    return node;
-  }
-  function parseOldFileOfCurrentEmit(bundleFileInfo) {
-    let texts;
-    let syntheticReferences;
-    for (const section of bundleFileInfo.sections) {
-      switch (section.kind) {
-        case "internal" /* Internal */:
-        case "text" /* Text */:
-          texts = append(texts, setTextRange(factory.createUnparsedTextLike(section.data, section.kind === "internal" /* Internal */), section));
-          break;
-        case "no-default-lib" /* NoDefaultLib */:
-        case "reference" /* Reference */:
-        case "type" /* Type */:
-        case "type-import" /* TypeResolutionModeImport */:
-        case "type-require" /* TypeResolutionModeRequire */:
-        case "lib" /* Lib */:
-          syntheticReferences = append(syntheticReferences, setTextRange(factory.createUnparsedSyntheticReference(section), section));
-          break;
-        case "prologue" /* Prologue */:
-        case "emitHelpers" /* EmitHelpers */:
-        case "prepend" /* Prepend */:
-          break;
-        default:
-          Debug.assertNever(section);
-      }
-    }
-    const node = factory.createUnparsedSource(emptyArray, syntheticReferences, texts ?? emptyArray);
-    setEachParent(syntheticReferences, node);
-    setEachParent(texts, node);
-    node.helpers = map(bundleFileInfo.sources && bundleFileInfo.sources.helpers, (name) => getAllUnscopedEmitHelpers().get(name));
-    return node;
-  }
-  function createInputFiles(javascriptTextOrReadFileText, declarationTextOrJavascriptPath, javascriptMapPath, javascriptMapTextOrDeclarationPath, declarationMapPath, declarationMapTextOrBuildInfoPath) {
-    return !isString(javascriptTextOrReadFileText) ? createInputFilesWithFilePaths(
-      javascriptTextOrReadFileText,
-      declarationTextOrJavascriptPath,
-      javascriptMapPath,
-      javascriptMapTextOrDeclarationPath,
-      declarationMapPath,
-      declarationMapTextOrBuildInfoPath
-    ) : createInputFilesWithFileTexts(
-      /*javascriptPath*/
-      void 0,
-      javascriptTextOrReadFileText,
-      javascriptMapPath,
-      javascriptMapTextOrDeclarationPath,
-      /*declarationPath*/
-      void 0,
-      declarationTextOrJavascriptPath,
-      declarationMapPath,
-      declarationMapTextOrBuildInfoPath
-    );
-  }
-  function createInputFilesWithFilePaths(readFileText, javascriptPath, javascriptMapPath, declarationPath, declarationMapPath, buildInfoPath, host, options) {
-    const node = parseNodeFactory.createInputFiles();
-    node.javascriptPath = javascriptPath;
-    node.javascriptMapPath = javascriptMapPath;
-    node.declarationPath = declarationPath;
-    node.declarationMapPath = declarationMapPath;
-    node.buildInfoPath = buildInfoPath;
-    const cache = /* @__PURE__ */ new Map();
-    const textGetter = (path) => {
-      if (path === void 0)
-        return void 0;
-      let value = cache.get(path);
-      if (value === void 0) {
-        value = readFileText(path);
-        cache.set(path, value !== void 0 ? value : false);
-      }
-      return value !== false ? value : void 0;
-    };
-    const definedTextGetter = (path) => {
-      const result = textGetter(path);
-      return result !== void 0 ? result : `/* Input file ${path} was missing */\r
-`;
-    };
-    let buildInfo;
-    const getAndCacheBuildInfo = () => {
-      if (buildInfo === void 0 && buildInfoPath) {
-        if (host == null ? void 0 : host.getBuildInfo) {
-          buildInfo = host.getBuildInfo(buildInfoPath, options.configFilePath) ?? false;
-        } else {
-          const result = textGetter(buildInfoPath);
-          buildInfo = result !== void 0 ? getBuildInfo(buildInfoPath, result) ?? false : false;
-        }
-      }
-      return buildInfo || void 0;
-    };
-    Object.defineProperties(node, {
-      javascriptText: { get: () => definedTextGetter(javascriptPath) },
-      javascriptMapText: { get: () => textGetter(javascriptMapPath) },
-      // TODO:: if there is inline sourceMap in jsFile, use that
-      declarationText: { get: () => definedTextGetter(Debug.checkDefined(declarationPath)) },
-      declarationMapText: { get: () => textGetter(declarationMapPath) },
-      // TODO:: if there is inline sourceMap in dtsFile, use that
-      buildInfo: { get: getAndCacheBuildInfo }
-    });
-    return node;
-  }
-  function createInputFilesWithFileTexts(javascriptPath, javascriptText, javascriptMapPath, javascriptMapText, declarationPath, declarationText, declarationMapPath, declarationMapText, buildInfoPath, buildInfo, oldFileOfCurrentEmit) {
-    const node = parseNodeFactory.createInputFiles();
-    node.javascriptPath = javascriptPath;
-    node.javascriptText = javascriptText;
-    node.javascriptMapPath = javascriptMapPath;
-    node.javascriptMapText = javascriptMapText;
-    node.declarationPath = declarationPath;
-    node.declarationText = declarationText;
-    node.declarationMapPath = declarationMapPath;
-    node.declarationMapText = declarationMapText;
-    node.buildInfoPath = buildInfoPath;
-    node.buildInfo = buildInfo;
-    node.oldFileOfCurrentEmit = oldFileOfCurrentEmit;
-    return node;
-  }
-  function createSourceMapSource(fileName, text, skipTrivia2) {
-    return new (SourceMapSource2 || (SourceMapSource2 = objectAllocator.getSourceMapSourceConstructor()))(fileName, text, skipTrivia2);
-  }
-  function setOriginalNode(node, original) {
-    node.original = original;
-    if (original) {
-      const emitNode = original.emitNode;
-      if (emitNode)
-        node.emitNode = mergeEmitNode(emitNode, node.emitNode);
-    }
-    return node;
-  }
-  function mergeEmitNode(sourceEmitNode, destEmitNode) {
-    const {
-      flags,
-      internalFlags,
-      leadingComments,
-      trailingComments,
-      commentRange,
-      sourceMapRange,
-      tokenSourceMapRanges,
-      constantValue,
-      helpers,
-      startsOnNewLine,
-      snippetElement
-    } = sourceEmitNode;
-    if (!destEmitNode)
-      destEmitNode = {};
-    if (leadingComments)
-      destEmitNode.leadingComments = addRange(leadingComments.slice(), destEmitNode.leadingComments);
-    if (trailingComments)
-      destEmitNode.trailingComments = addRange(trailingComments.slice(), destEmitNode.trailingComments);
-    if (flags)
-      destEmitNode.flags = flags;
-    if (internalFlags)
-      destEmitNode.internalFlags = internalFlags & ~8 /* Immutable */;
-    if (commentRange)
-      destEmitNode.commentRange = commentRange;
-    if (sourceMapRange)
-      destEmitNode.sourceMapRange = sourceMapRange;
-    if (tokenSourceMapRanges)
-      destEmitNode.tokenSourceMapRanges = mergeTokenSourceMapRanges(tokenSourceMapRanges, destEmitNode.tokenSourceMapRanges);
-    if (constantValue !== void 0)
-      destEmitNode.constantValue = constantValue;
-    if (helpers) {
-      for (const helper of helpers) {
-        destEmitNode.helpers = appendIfUnique(destEmitNode.helpers, helper);
-      }
-    }
-    if (startsOnNewLine !== void 0)
-      destEmitNode.startsOnNewLine = startsOnNewLine;
-    if (snippetElement !== void 0)
-      destEmitNode.snippetElement = snippetElement;
-    return destEmitNode;
-  }
-  function mergeTokenSourceMapRanges(sourceRanges, destRanges) {
-    if (!destRanges)
-      destRanges = [];
-    for (const key in sourceRanges) {
-      destRanges[key] = sourceRanges[key];
-    }
-    return destRanges;
-  }
-  var nextAutoGenerateId, NodeFactoryFlags, nodeFactoryPatchers, rawTextScanner, invalidValueSentinel, baseFactory, syntheticFactory, factory, SourceMapSource2;
-  var init_nodeFactory = __esm({
-    "src/compiler/factory/nodeFactory.ts"() {
-      "use strict";
-      init_ts2();
-      nextAutoGenerateId = 0;
-      NodeFactoryFlags = /* @__PURE__ */ ((NodeFactoryFlags2) => {
-        NodeFactoryFlags2[NodeFactoryFlags2["None"] = 0] = "None";
-        NodeFactoryFlags2[NodeFactoryFlags2["NoParenthesizerRules"] = 1] = "NoParenthesizerRules";
-        NodeFactoryFlags2[NodeFactoryFlags2["NoNodeConverters"] = 2] = "NoNodeConverters";
-        NodeFactoryFlags2[NodeFactoryFlags2["NoIndentationOnFreshPropertyAccess"] = 4] = "NoIndentationOnFreshPropertyAccess";
-        NodeFactoryFlags2[NodeFactoryFlags2["NoOriginalNode"] = 8] = "NoOriginalNode";
-        return NodeFactoryFlags2;
-      })(NodeFactoryFlags || {});
-      nodeFactoryPatchers = [];
-      invalidValueSentinel = {};
-      baseFactory = createBaseNodeFactory();
-      syntheticFactory = {
-        createBaseSourceFileNode: (kind) => makeSynthetic(baseFactory.createBaseSourceFileNode(kind)),
-        createBaseIdentifierNode: (kind) => makeSynthetic(baseFactory.createBaseIdentifierNode(kind)),
-        createBasePrivateIdentifierNode: (kind) => makeSynthetic(baseFactory.createBasePrivateIdentifierNode(kind)),
-        createBaseTokenNode: (kind) => makeSynthetic(baseFactory.createBaseTokenNode(kind)),
-        createBaseNode: (kind) => makeSynthetic(baseFactory.createBaseNode(kind))
-      };
-      factory = createNodeFactory(4 /* NoIndentationOnFreshPropertyAccess */, syntheticFactory);
-    }
-  });
-
-  // src/compiler/factory/emitNode.ts
-  function getOrCreateEmitNode(node) {
-    if (!node.emitNode) {
-      if (isParseTreeNode(node)) {
-        if (node.kind === 311 /* SourceFile */) {
-          return node.emitNode = { annotatedNodes: [node] };
-        }
-        const sourceFile = getSourceFileOfNode(getParseTreeNode(getSourceFileOfNode(node))) ?? Debug.fail("Could not determine parsed source file.");
-        getOrCreateEmitNode(sourceFile).annotatedNodes.push(node);
-      }
-      node.emitNode = {};
-    } else {
-      Debug.assert(!(node.emitNode.internalFlags & 8 /* Immutable */), "Invalid attempt to mutate an immutable node.");
-    }
-    return node.emitNode;
-  }
-  function disposeEmitNodes(sourceFile) {
-    var _a, _b;
-    const annotatedNodes = (_b = (_a = getSourceFileOfNode(getParseTreeNode(sourceFile))) == null ? void 0 : _a.emitNode) == null ? void 0 : _b.annotatedNodes;
-    if (annotatedNodes) {
-      for (const node of annotatedNodes) {
-        node.emitNode = void 0;
-      }
-    }
-  }
-  function removeAllComments(node) {
-    const emitNode = getOrCreateEmitNode(node);
-    emitNode.flags |= 3072 /* NoComments */;
-    emitNode.leadingComments = void 0;
-    emitNode.trailingComments = void 0;
-    return node;
-  }
-  function setEmitFlags(node, emitFlags) {
-    getOrCreateEmitNode(node).flags = emitFlags;
-    return node;
-  }
-  function addEmitFlags(node, emitFlags) {
-    const emitNode = getOrCreateEmitNode(node);
-    emitNode.flags = emitNode.flags | emitFlags;
-    return node;
-  }
-  function setInternalEmitFlags(node, emitFlags) {
-    getOrCreateEmitNode(node).internalFlags = emitFlags;
-    return node;
-  }
-  function addInternalEmitFlags(node, emitFlags) {
-    const emitNode = getOrCreateEmitNode(node);
-    emitNode.internalFlags = emitNode.internalFlags | emitFlags;
-    return node;
-  }
-  function getSourceMapRange(node) {
-    var _a;
-    return ((_a = node.emitNode) == null ? void 0 : _a.sourceMapRange) ?? node;
-  }
-  function setSourceMapRange(node, range) {
-    getOrCreateEmitNode(node).sourceMapRange = range;
-    return node;
-  }
-  function getTokenSourceMapRange(node, token) {
-    var _a, _b;
-    return (_b = (_a = node.emitNode) == null ? void 0 : _a.tokenSourceMapRanges) == null ? void 0 : _b[token];
-  }
-  function setTokenSourceMapRange(node, token, range) {
-    const emitNode = getOrCreateEmitNode(node);
-    const tokenSourceMapRanges = emitNode.tokenSourceMapRanges ?? (emitNode.tokenSourceMapRanges = []);
-    tokenSourceMapRanges[token] = range;
-    return node;
-  }
-  function getStartsOnNewLine(node) {
-    var _a;
-    return (_a = node.emitNode) == null ? void 0 : _a.startsOnNewLine;
-  }
-  function setStartsOnNewLine(node, newLine) {
-    getOrCreateEmitNode(node).startsOnNewLine = newLine;
-    return node;
-  }
-  function getCommentRange(node) {
-    var _a;
-    return ((_a = node.emitNode) == null ? void 0 : _a.commentRange) ?? node;
-  }
-  function setCommentRange(node, range) {
-    getOrCreateEmitNode(node).commentRange = range;
-    return node;
-  }
-  function getSyntheticLeadingComments(node) {
-    var _a;
-    return (_a = node.emitNode) == null ? void 0 : _a.leadingComments;
-  }
-  function setSyntheticLeadingComments(node, comments) {
-    getOrCreateEmitNode(node).leadingComments = comments;
-    return node;
-  }
-  function addSyntheticLeadingComment(node, kind, text, hasTrailingNewLine) {
-    return setSyntheticLeadingComments(node, append(getSyntheticLeadingComments(node), { kind, pos: -1, end: -1, hasTrailingNewLine, text }));
-  }
-  function getSyntheticTrailingComments(node) {
-    var _a;
-    return (_a = node.emitNode) == null ? void 0 : _a.trailingComments;
-  }
-  function setSyntheticTrailingComments(node, comments) {
-    getOrCreateEmitNode(node).trailingComments = comments;
-    return node;
-  }
-  function addSyntheticTrailingComment(node, kind, text, hasTrailingNewLine) {
-    return setSyntheticTrailingComments(node, append(getSyntheticTrailingComments(node), { kind, pos: -1, end: -1, hasTrailingNewLine, text }));
-  }
-  function moveSyntheticComments(node, original) {
-    setSyntheticLeadingComments(node, getSyntheticLeadingComments(original));
-    setSyntheticTrailingComments(node, getSyntheticTrailingComments(original));
-    const emit = getOrCreateEmitNode(original);
-    emit.leadingComments = void 0;
-    emit.trailingComments = void 0;
-    return node;
-  }
-  function getConstantValue(node) {
-    var _a;
-    return (_a = node.emitNode) == null ? void 0 : _a.constantValue;
-  }
-  function setConstantValue(node, value) {
-    const emitNode = getOrCreateEmitNode(node);
-    emitNode.constantValue = value;
-    return node;
-  }
-  function addEmitHelper(node, helper) {
-    const emitNode = getOrCreateEmitNode(node);
-    emitNode.helpers = append(emitNode.helpers, helper);
-    return node;
-  }
-  function addEmitHelpers(node, helpers) {
-    if (some(helpers)) {
-      const emitNode = getOrCreateEmitNode(node);
-      for (const helper of helpers) {
-        emitNode.helpers = appendIfUnique(emitNode.helpers, helper);
-      }
-    }
-    return node;
-  }
-  function removeEmitHelper(node, helper) {
-    var _a;
-    const helpers = (_a = node.emitNode) == null ? void 0 : _a.helpers;
-    if (helpers) {
-      return orderedRemoveItem(helpers, helper);
-    }
-    return false;
-  }
-  function getEmitHelpers(node) {
-    var _a;
-    return (_a = node.emitNode) == null ? void 0 : _a.helpers;
-  }
-  function moveEmitHelpers(source, target, predicate) {
-    const sourceEmitNode = source.emitNode;
-    const sourceEmitHelpers = sourceEmitNode && sourceEmitNode.helpers;
-    if (!some(sourceEmitHelpers))
-      return;
-    const targetEmitNode = getOrCreateEmitNode(target);
-    let helpersRemoved = 0;
-    for (let i = 0; i < sourceEmitHelpers.length; i++) {
-      const helper = sourceEmitHelpers[i];
-      if (predicate(helper)) {
-        helpersRemoved++;
-        targetEmitNode.helpers = appendIfUnique(targetEmitNode.helpers, helper);
-      } else if (helpersRemoved > 0) {
-        sourceEmitHelpers[i - helpersRemoved] = helper;
-      }
-    }
-    if (helpersRemoved > 0) {
-      sourceEmitHelpers.length -= helpersRemoved;
-    }
-  }
-  function getSnippetElement(node) {
-    var _a;
-    return (_a = node.emitNode) == null ? void 0 : _a.snippetElement;
-  }
-  function setSnippetElement(node, snippet) {
-    const emitNode = getOrCreateEmitNode(node);
-    emitNode.snippetElement = snippet;
-    return node;
-  }
-  function ignoreSourceNewlines(node) {
-    getOrCreateEmitNode(node).internalFlags |= 4 /* IgnoreSourceNewlines */;
-    return node;
-  }
-  function setTypeNode(node, type) {
-    const emitNode = getOrCreateEmitNode(node);
-    emitNode.typeNode = type;
-    return node;
-  }
-  function getTypeNode(node) {
-    var _a;
-    return (_a = node.emitNode) == null ? void 0 : _a.typeNode;
-  }
-  function setIdentifierTypeArguments(node, typeArguments) {
-    getOrCreateEmitNode(node).identifierTypeArguments = typeArguments;
-    return node;
-  }
-  function getIdentifierTypeArguments(node) {
-    var _a;
-    return (_a = node.emitNode) == null ? void 0 : _a.identifierTypeArguments;
-  }
-  function setIdentifierAutoGenerate(node, autoGenerate) {
-    getOrCreateEmitNode(node).autoGenerate = autoGenerate;
-    return node;
-  }
-  function getIdentifierAutoGenerate(node) {
-    var _a;
-    return (_a = node.emitNode) == null ? void 0 : _a.autoGenerate;
-  }
-  function setIdentifierGeneratedImportReference(node, value) {
-    getOrCreateEmitNode(node).generatedImportReference = value;
-    return node;
-  }
-  function getIdentifierGeneratedImportReference(node) {
-    var _a;
-    return (_a = node.emitNode) == null ? void 0 : _a.generatedImportReference;
-  }
-  var init_emitNode = __esm({
-    "src/compiler/factory/emitNode.ts"() {
-      "use strict";
-      init_ts2();
-    }
-  });
-
-  // src/compiler/factory/emitHelpers.ts
-  function createEmitHelperFactory(context) {
-    const factory2 = context.factory;
-    const immutableTrue = memoize(() => setInternalEmitFlags(factory2.createTrue(), 8 /* Immutable */));
-    const immutableFalse = memoize(() => setInternalEmitFlags(factory2.createFalse(), 8 /* Immutable */));
-    return {
-      getUnscopedHelperName,
-      // TypeScript Helpers
-      createDecorateHelper,
-      createMetadataHelper,
-      createParamHelper,
-      // ES Decorators Helpers
-      createESDecorateHelper,
-      createRunInitializersHelper,
-      // ES2018 Helpers
-      createAssignHelper,
-      createAwaitHelper,
-      createAsyncGeneratorHelper,
-      createAsyncDelegatorHelper,
-      createAsyncValuesHelper,
-      // ES2018 Destructuring Helpers
-      createRestHelper,
-      // ES2017 Helpers
-      createAwaiterHelper,
-      // ES2015 Helpers
-      createExtendsHelper,
-      createTemplateObjectHelper,
-      createSpreadArrayHelper,
-      createPropKeyHelper,
-      createSetFunctionNameHelper,
-      // ES2015 Destructuring Helpers
-      createValuesHelper,
-      createReadHelper,
-      // ES2015 Generator Helpers
-      createGeneratorHelper,
-      // ES Module Helpers
-      createCreateBindingHelper,
-      createImportStarHelper,
-      createImportStarCallbackHelper,
-      createImportDefaultHelper,
-      createExportStarHelper,
-      // Class Fields Helpers
-      createClassPrivateFieldGetHelper,
-      createClassPrivateFieldSetHelper,
-      createClassPrivateFieldInHelper
-    };
-    function getUnscopedHelperName(name) {
-      return setEmitFlags(factory2.createIdentifier(name), 8192 /* HelperName */ | 4 /* AdviseOnEmitNode */);
-    }
-    function createDecorateHelper(decoratorExpressions, target, memberName, descriptor) {
-      context.requestEmitHelper(decorateHelper);
-      const argumentsArray = [];
-      argumentsArray.push(factory2.createArrayLiteralExpression(
-        decoratorExpressions,
-        /*multiLine*/
-        true
-      ));
-      argumentsArray.push(target);
-      if (memberName) {
-        argumentsArray.push(memberName);
-        if (descriptor) {
-          argumentsArray.push(descriptor);
-        }
-      }
-      return factory2.createCallExpression(
-        getUnscopedHelperName("__decorate"),
-        /*typeArguments*/
-        void 0,
-        argumentsArray
-      );
-    }
-    function createMetadataHelper(metadataKey, metadataValue) {
-      context.requestEmitHelper(metadataHelper);
-      return factory2.createCallExpression(
-        getUnscopedHelperName("__metadata"),
-        /*typeArguments*/
-        void 0,
-        [
-          factory2.createStringLiteral(metadataKey),
-          metadataValue
-        ]
-      );
-    }
-    function createParamHelper(expression, parameterOffset, location) {
-      context.requestEmitHelper(paramHelper);
-      return setTextRange(
-        factory2.createCallExpression(
-          getUnscopedHelperName("__param"),
-          /*typeArguments*/
-          void 0,
-          [
-            factory2.createNumericLiteral(parameterOffset + ""),
-            expression
-          ]
-        ),
-        location
-      );
-    }
-    function createESDecorateClassContextObject(contextIn) {
-      return factory2.createObjectLiteralExpression([
-        factory2.createPropertyAssignment(factory2.createIdentifier("kind"), factory2.createStringLiteral("class")),
-        factory2.createPropertyAssignment(factory2.createIdentifier("name"), contextIn.name)
-      ]);
-    }
-    function createESDecorateClassElementAccessGetMethod(elementName) {
-      const accessor = elementName.computed ? factory2.createElementAccessExpression(factory2.createIdentifier("obj"), elementName.name) : factory2.createPropertyAccessExpression(factory2.createIdentifier("obj"), elementName.name);
-      return factory2.createPropertyAssignment(
-        "get",
-        factory2.createArrowFunction(
-          /*modifiers*/
-          void 0,
-          /*typeParameters*/
-          void 0,
-          [factory2.createParameterDeclaration(
-            /*modifiers*/
-            void 0,
-            /*dotDotDotToken*/
-            void 0,
-            factory2.createIdentifier("obj")
-          )],
-          /*type*/
-          void 0,
-          /*equalsGreaterThanToken*/
-          void 0,
-          accessor
-        )
-      );
-    }
-    function createESDecorateClassElementAccessSetMethod(elementName) {
-      const accessor = elementName.computed ? factory2.createElementAccessExpression(factory2.createIdentifier("obj"), elementName.name) : factory2.createPropertyAccessExpression(factory2.createIdentifier("obj"), elementName.name);
-      return factory2.createPropertyAssignment(
-        "set",
-        factory2.createArrowFunction(
-          /*modifiers*/
-          void 0,
-          /*typeParameters*/
-          void 0,
-          [
-            factory2.createParameterDeclaration(
-              /*modifiers*/
-              void 0,
-              /*dotDotDotToken*/
-              void 0,
-              factory2.createIdentifier("obj")
-            ),
-            factory2.createParameterDeclaration(
-              /*modifiers*/
-              void 0,
-              /*dotDotDotToken*/
-              void 0,
-              factory2.createIdentifier("value")
-            )
-          ],
-          /*type*/
-          void 0,
-          /*equalsGreaterThanToken*/
-          void 0,
-          factory2.createBlock([
-            factory2.createExpressionStatement(
-              factory2.createAssignment(
-                accessor,
-                factory2.createIdentifier("value")
-              )
-            )
-          ])
-        )
-      );
-    }
-    function createESDecorateClassElementAccessHasMethod(elementName) {
-      const propertyName = elementName.computed ? elementName.name : isIdentifier(elementName.name) ? factory2.createStringLiteralFromNode(elementName.name) : elementName.name;
-      return factory2.createPropertyAssignment(
-        "has",
-        factory2.createArrowFunction(
-          /*modifiers*/
-          void 0,
-          /*typeParameters*/
-          void 0,
-          [factory2.createParameterDeclaration(
-            /*modifiers*/
-            void 0,
-            /*dotDotDotToken*/
-            void 0,
-            factory2.createIdentifier("obj")
-          )],
-          /*type*/
-          void 0,
-          /*equalsGreaterThanToken*/
-          void 0,
-          factory2.createBinaryExpression(
-            propertyName,
-            103 /* InKeyword */,
-            factory2.createIdentifier("obj")
-          )
-        )
-      );
-    }
-    function createESDecorateClassElementAccessObject(name, access) {
-      const properties = [];
-      properties.push(createESDecorateClassElementAccessHasMethod(name));
-      if (access.get)
-        properties.push(createESDecorateClassElementAccessGetMethod(name));
-      if (access.set)
-        properties.push(createESDecorateClassElementAccessSetMethod(name));
-      return factory2.createObjectLiteralExpression(properties);
-    }
-    function createESDecorateClassElementContextObject(contextIn) {
-      return factory2.createObjectLiteralExpression([
-        factory2.createPropertyAssignment(factory2.createIdentifier("kind"), factory2.createStringLiteral(contextIn.kind)),
-        factory2.createPropertyAssignment(factory2.createIdentifier("name"), contextIn.name.computed ? contextIn.name.name : factory2.createStringLiteralFromNode(contextIn.name.name)),
-        factory2.createPropertyAssignment(factory2.createIdentifier("static"), contextIn.static ? factory2.createTrue() : factory2.createFalse()),
-        factory2.createPropertyAssignment(factory2.createIdentifier("private"), contextIn.private ? factory2.createTrue() : factory2.createFalse()),
-        factory2.createPropertyAssignment(factory2.createIdentifier("access"), createESDecorateClassElementAccessObject(contextIn.name, contextIn.access))
-      ]);
-    }
-    function createESDecorateContextObject(contextIn) {
-      return contextIn.kind === "class" ? createESDecorateClassContextObject(contextIn) : createESDecorateClassElementContextObject(contextIn);
-    }
-    function createESDecorateHelper(ctor, descriptorIn, decorators, contextIn, initializers, extraInitializers) {
-      context.requestEmitHelper(esDecorateHelper);
-      return factory2.createCallExpression(
-        getUnscopedHelperName("__esDecorate"),
-        /*typeArguments*/
-        void 0,
-        [
-          ctor ?? factory2.createNull(),
-          descriptorIn ?? factory2.createNull(),
-          decorators,
-          createESDecorateContextObject(contextIn),
-          initializers,
-          extraInitializers
-        ]
-      );
-    }
-    function createRunInitializersHelper(thisArg, initializers, value) {
-      context.requestEmitHelper(runInitializersHelper);
-      return factory2.createCallExpression(
-        getUnscopedHelperName("__runInitializers"),
-        /*typeArguments*/
-        void 0,
-        value ? [thisArg, initializers, value] : [thisArg, initializers]
-      );
-    }
-    function createAssignHelper(attributesSegments) {
-      if (getEmitScriptTarget(context.getCompilerOptions()) >= 2 /* ES2015 */) {
-        return factory2.createCallExpression(
-          factory2.createPropertyAccessExpression(factory2.createIdentifier("Object"), "assign"),
-          /*typeArguments*/
-          void 0,
-          attributesSegments
-        );
-      }
-      context.requestEmitHelper(assignHelper);
-      return factory2.createCallExpression(
-        getUnscopedHelperName("__assign"),
-        /*typeArguments*/
-        void 0,
-        attributesSegments
-      );
-    }
-    function createAwaitHelper(expression) {
-      context.requestEmitHelper(awaitHelper);
-      return factory2.createCallExpression(
-        getUnscopedHelperName("__await"),
-        /*typeArguments*/
-        void 0,
-        [expression]
-      );
-    }
-    function createAsyncGeneratorHelper(generatorFunc, hasLexicalThis) {
-      context.requestEmitHelper(awaitHelper);
-      context.requestEmitHelper(asyncGeneratorHelper);
-      (generatorFunc.emitNode || (generatorFunc.emitNode = {})).flags |= 524288 /* AsyncFunctionBody */ | 1048576 /* ReuseTempVariableScope */;
-      return factory2.createCallExpression(
-        getUnscopedHelperName("__asyncGenerator"),
-        /*typeArguments*/
-        void 0,
-        [
-          hasLexicalThis ? factory2.createThis() : factory2.createVoidZero(),
-          factory2.createIdentifier("arguments"),
-          generatorFunc
-        ]
-      );
-    }
-    function createAsyncDelegatorHelper(expression) {
-      context.requestEmitHelper(awaitHelper);
-      context.requestEmitHelper(asyncDelegator);
-      return factory2.createCallExpression(
-        getUnscopedHelperName("__asyncDelegator"),
-        /*typeArguments*/
-        void 0,
-        [expression]
-      );
-    }
-    function createAsyncValuesHelper(expression) {
-      context.requestEmitHelper(asyncValues);
-      return factory2.createCallExpression(
-        getUnscopedHelperName("__asyncValues"),
-        /*typeArguments*/
-        void 0,
-        [expression]
-      );
-    }
-    function createRestHelper(value, elements, computedTempVariables, location) {
-      context.requestEmitHelper(restHelper);
-      const propertyNames = [];
-      let computedTempVariableOffset = 0;
-      for (let i = 0; i < elements.length - 1; i++) {
-        const propertyName = getPropertyNameOfBindingOrAssignmentElement(elements[i]);
-        if (propertyName) {
-          if (isComputedPropertyName(propertyName)) {
-            Debug.assertIsDefined(computedTempVariables, "Encountered computed property name but 'computedTempVariables' argument was not provided.");
-            const temp = computedTempVariables[computedTempVariableOffset];
-            computedTempVariableOffset++;
-            propertyNames.push(
-              factory2.createConditionalExpression(
-                factory2.createTypeCheck(temp, "symbol"),
-                /*questionToken*/
-                void 0,
-                temp,
-                /*colonToken*/
-                void 0,
-                factory2.createAdd(temp, factory2.createStringLiteral(""))
-              )
-            );
-          } else {
-            propertyNames.push(factory2.createStringLiteralFromNode(propertyName));
-          }
-        }
-      }
-      return factory2.createCallExpression(
-        getUnscopedHelperName("__rest"),
-        /*typeArguments*/
-        void 0,
-        [
-          value,
-          setTextRange(
-            factory2.createArrayLiteralExpression(propertyNames),
-            location
-          )
-        ]
-      );
-    }
-    function createAwaiterHelper(hasLexicalThis, hasLexicalArguments, promiseConstructor, body) {
-      context.requestEmitHelper(awaiterHelper);
-      const generatorFunc = factory2.createFunctionExpression(
-        /*modifiers*/
-        void 0,
-        factory2.createToken(42 /* AsteriskToken */),
-        /*name*/
-        void 0,
-        /*typeParameters*/
-        void 0,
-        /*parameters*/
-        [],
-        /*type*/
-        void 0,
-        body
-      );
-      (generatorFunc.emitNode || (generatorFunc.emitNode = {})).flags |= 524288 /* AsyncFunctionBody */ | 1048576 /* ReuseTempVariableScope */;
-      return factory2.createCallExpression(
-        getUnscopedHelperName("__awaiter"),
-        /*typeArguments*/
-        void 0,
-        [
-          hasLexicalThis ? factory2.createThis() : factory2.createVoidZero(),
-          hasLexicalArguments ? factory2.createIdentifier("arguments") : factory2.createVoidZero(),
-          promiseConstructor ? createExpressionFromEntityName(factory2, promiseConstructor) : factory2.createVoidZero(),
-          generatorFunc
-        ]
-      );
-    }
-    function createExtendsHelper(name) {
-      context.requestEmitHelper(extendsHelper);
-      return factory2.createCallExpression(
-        getUnscopedHelperName("__extends"),
-        /*typeArguments*/
-        void 0,
-        [name, factory2.createUniqueName("_super", 16 /* Optimistic */ | 32 /* FileLevel */)]
-      );
-    }
-    function createTemplateObjectHelper(cooked, raw) {
-      context.requestEmitHelper(templateObjectHelper);
-      return factory2.createCallExpression(
-        getUnscopedHelperName("__makeTemplateObject"),
-        /*typeArguments*/
-        void 0,
-        [cooked, raw]
-      );
-    }
-    function createSpreadArrayHelper(to, from, packFrom) {
-      context.requestEmitHelper(spreadArrayHelper);
-      return factory2.createCallExpression(
-        getUnscopedHelperName("__spreadArray"),
-        /*typeArguments*/
-        void 0,
-        [to, from, packFrom ? immutableTrue() : immutableFalse()]
-      );
-    }
-    function createPropKeyHelper(expr) {
-      context.requestEmitHelper(propKeyHelper);
-      return factory2.createCallExpression(
-        getUnscopedHelperName("__propKey"),
-        /*typeArguments*/
-        void 0,
-        [expr]
-      );
-    }
-    function createSetFunctionNameHelper(f, name, prefix) {
-      context.requestEmitHelper(setFunctionNameHelper);
-      return context.factory.createCallExpression(
-        getUnscopedHelperName("__setFunctionName"),
-        /*typeArguments*/
-        void 0,
-        prefix ? [f, name, context.factory.createStringLiteral(prefix)] : [f, name]
-      );
-    }
-    function createValuesHelper(expression) {
-      context.requestEmitHelper(valuesHelper);
-      return factory2.createCallExpression(
-        getUnscopedHelperName("__values"),
-        /*typeArguments*/
-        void 0,
-        [expression]
-      );
-    }
-    function createReadHelper(iteratorRecord, count) {
-      context.requestEmitHelper(readHelper);
-      return factory2.createCallExpression(
-        getUnscopedHelperName("__read"),
-        /*typeArguments*/
-        void 0,
-        count !== void 0 ? [iteratorRecord, factory2.createNumericLiteral(count + "")] : [iteratorRecord]
-      );
-    }
-    function createGeneratorHelper(body) {
-      context.requestEmitHelper(generatorHelper);
-      return factory2.createCallExpression(
-        getUnscopedHelperName("__generator"),
-        /*typeArguments*/
-        void 0,
-        [factory2.createThis(), body]
-      );
-    }
-    function createCreateBindingHelper(module2, inputName, outputName) {
-      context.requestEmitHelper(createBindingHelper);
-      return factory2.createCallExpression(
-        getUnscopedHelperName("__createBinding"),
-        /*typeArguments*/
-        void 0,
-        [factory2.createIdentifier("exports"), module2, inputName, ...outputName ? [outputName] : []]
-      );
-    }
-    function createImportStarHelper(expression) {
-      context.requestEmitHelper(importStarHelper);
-      return factory2.createCallExpression(
-        getUnscopedHelperName("__importStar"),
-        /*typeArguments*/
-        void 0,
-        [expression]
-      );
-    }
-    function createImportStarCallbackHelper() {
-      context.requestEmitHelper(importStarHelper);
-      return getUnscopedHelperName("__importStar");
-    }
-    function createImportDefaultHelper(expression) {
-      context.requestEmitHelper(importDefaultHelper);
-      return factory2.createCallExpression(
-        getUnscopedHelperName("__importDefault"),
-        /*typeArguments*/
-        void 0,
-        [expression]
-      );
-    }
-    function createExportStarHelper(moduleExpression, exportsExpression = factory2.createIdentifier("exports")) {
-      context.requestEmitHelper(exportStarHelper);
-      context.requestEmitHelper(createBindingHelper);
-      return factory2.createCallExpression(
-        getUnscopedHelperName("__exportStar"),
-        /*typeArguments*/
-        void 0,
-        [moduleExpression, exportsExpression]
-      );
-    }
-    function createClassPrivateFieldGetHelper(receiver, state, kind, f) {
-      context.requestEmitHelper(classPrivateFieldGetHelper);
-      let args;
-      if (!f) {
-        args = [receiver, state, factory2.createStringLiteral(kind)];
-      } else {
-        args = [receiver, state, factory2.createStringLiteral(kind), f];
-      }
-      return factory2.createCallExpression(
-        getUnscopedHelperName("__classPrivateFieldGet"),
-        /*typeArguments*/
-        void 0,
-        args
-      );
-    }
-    function createClassPrivateFieldSetHelper(receiver, state, value, kind, f) {
-      context.requestEmitHelper(classPrivateFieldSetHelper);
-      let args;
-      if (!f) {
-        args = [receiver, state, value, factory2.createStringLiteral(kind)];
-      } else {
-        args = [receiver, state, value, factory2.createStringLiteral(kind), f];
-      }
-      return factory2.createCallExpression(
-        getUnscopedHelperName("__classPrivateFieldSet"),
-        /*typeArguments*/
-        void 0,
-        args
-      );
-    }
-    function createClassPrivateFieldInHelper(state, receiver) {
-      context.requestEmitHelper(classPrivateFieldInHelper);
-      return factory2.createCallExpression(
-        getUnscopedHelperName("__classPrivateFieldIn"),
-        /*typeArguments*/
-        void 0,
-        [state, receiver]
-      );
-    }
-  }
-  function compareEmitHelpers(x, y) {
-    if (x === y)
-      return 0 /* EqualTo */;
-    if (x.priority === y.priority)
-      return 0 /* EqualTo */;
-    if (x.priority === void 0)
-      return 1 /* GreaterThan */;
-    if (y.priority === void 0)
-      return -1 /* LessThan */;
-    return compareValues(x.priority, y.priority);
-  }
-  function helperString(input, ...args) {
-    return (uniqueName) => {
-      let result = "";
-      for (let i = 0; i < args.length; i++) {
-        result += input[i];
-        result += uniqueName(args[i]);
-      }
-      result += input[input.length - 1];
-      return result;
-    };
-  }
-  function getAllUnscopedEmitHelpers() {
-    return allUnscopedEmitHelpers || (allUnscopedEmitHelpers = arrayToMap([
-      decorateHelper,
-      metadataHelper,
-      paramHelper,
-      esDecorateHelper,
-      runInitializersHelper,
-      assignHelper,
-      awaitHelper,
-      asyncGeneratorHelper,
-      asyncDelegator,
-      asyncValues,
-      restHelper,
-      awaiterHelper,
-      extendsHelper,
-      templateObjectHelper,
-      spreadArrayHelper,
-      valuesHelper,
-      readHelper,
-      propKeyHelper,
-      setFunctionNameHelper,
-      generatorHelper,
-      importStarHelper,
-      importDefaultHelper,
-      exportStarHelper,
-      classPrivateFieldGetHelper,
-      classPrivateFieldSetHelper,
-      classPrivateFieldInHelper,
-      createBindingHelper,
-      setModuleDefaultHelper
-    ], (helper) => helper.name));
-  }
-  function isCallToHelper(firstSegment, helperName) {
-    return isCallExpression(firstSegment) && isIdentifier(firstSegment.expression) && (getEmitFlags(firstSegment.expression) & 8192 /* HelperName */) !== 0 && firstSegment.expression.escapedText === helperName;
-  }
-  var PrivateIdentifierKind, decorateHelper, metadataHelper, paramHelper, esDecorateHelper, runInitializersHelper, assignHelper, awaitHelper, asyncGeneratorHelper, asyncDelegator, asyncValues, restHelper, awaiterHelper, extendsHelper, templateObjectHelper, readHelper, spreadArrayHelper, propKeyHelper, setFunctionNameHelper, valuesHelper, generatorHelper, createBindingHelper, setModuleDefaultHelper, importStarHelper, importDefaultHelper, exportStarHelper, classPrivateFieldGetHelper, classPrivateFieldSetHelper, classPrivateFieldInHelper, allUnscopedEmitHelpers, asyncSuperHelper, advancedAsyncSuperHelper;
-  var init_emitHelpers = __esm({
-    "src/compiler/factory/emitHelpers.ts"() {
-      "use strict";
-      init_ts2();
-      PrivateIdentifierKind = /* @__PURE__ */ ((PrivateIdentifierKind2) => {
-        PrivateIdentifierKind2["Field"] = "f";
-        PrivateIdentifierKind2["Method"] = "m";
-        PrivateIdentifierKind2["Accessor"] = "a";
-        return PrivateIdentifierKind2;
-      })(PrivateIdentifierKind || {});
-      decorateHelper = {
-        name: "typescript:decorate",
-        importName: "__decorate",
-        scoped: false,
-        priority: 2,
-        text: `
-            var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
-                var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
-                if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
-                else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
-                return c > 3 && r && Object.defineProperty(target, key, r), r;
-            };`
-      };
-      metadataHelper = {
-        name: "typescript:metadata",
-        importName: "__metadata",
-        scoped: false,
-        priority: 3,
-        text: `
-            var __metadata = (this && this.__metadata) || function (k, v) {
-                if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
-            };`
-      };
-      paramHelper = {
-        name: "typescript:param",
-        importName: "__param",
-        scoped: false,
-        priority: 4,
-        text: `
-            var __param = (this && this.__param) || function (paramIndex, decorator) {
-                return function (target, key) { decorator(target, key, paramIndex); }
-            };`
-      };
-      esDecorateHelper = {
-        name: "typescript:esDecorate",
-        importName: "__esDecorate",
-        scoped: false,
-        priority: 2,
-        text: `
-        var __esDecorate = (this && this.__esDecorate) || function (ctor, descriptorIn, decorators, contextIn, initializers, extraInitializers) {
-            function accept(f) { if (f !== void 0 && typeof f !== "function") throw new TypeError("Function expected"); return f; }
-            var kind = contextIn.kind, key = kind === "getter" ? "get" : kind === "setter" ? "set" : "value";
-            var target = !descriptorIn && ctor ? contextIn["static"] ? ctor : ctor.prototype : null;
-            var descriptor = descriptorIn || (target ? Object.getOwnPropertyDescriptor(target, contextIn.name) : {});
-            var _, done = false;
-            for (var i = decorators.length - 1; i >= 0; i--) {
-                var context = {};
-                for (var p in contextIn) context[p] = p === "access" ? {} : contextIn[p];
-                for (var p in contextIn.access) context.access[p] = contextIn.access[p];
-                context.addInitializer = function (f) { if (done) throw new TypeError("Cannot add initializers after decoration has completed"); extraInitializers.push(accept(f || null)); };
-                var result = (0, decorators[i])(kind === "accessor" ? { get: descriptor.get, set: descriptor.set } : descriptor[key], context);
-                if (kind === "accessor") {
-                    if (result === void 0) continue;
-                    if (result === null || typeof result !== "object") throw new TypeError("Object expected");
-                    if (_ = accept(result.get)) descriptor.get = _;
-                    if (_ = accept(result.set)) descriptor.set = _;
-                    if (_ = accept(result.init)) initializers.unshift(_);
-                }
-                else if (_ = accept(result)) {
-                    if (kind === "field") initializers.unshift(_);
-                    else descriptor[key] = _;
-                }
-            }
-            if (target) Object.defineProperty(target, contextIn.name, descriptor);
-            done = true;
-        };`
-      };
-      runInitializersHelper = {
-        name: "typescript:runInitializers",
-        importName: "__runInitializers",
-        scoped: false,
-        priority: 2,
-        text: `
-        var __runInitializers = (this && this.__runInitializers) || function (thisArg, initializers, value) {
-            var useValue = arguments.length > 2;
-            for (var i = 0; i < initializers.length; i++) {
-                value = useValue ? initializers[i].call(thisArg, value) : initializers[i].call(thisArg);
-            }
-            return useValue ? value : void 0;
-        };`
-      };
-      assignHelper = {
-        name: "typescript:assign",
-        importName: "__assign",
-        scoped: false,
-        priority: 1,
-        text: `
-            var __assign = (this && this.__assign) || function () {
-                __assign = Object.assign || function(t) {
-                    for (var s, i = 1, n = arguments.length; i < n; i++) {
-                        s = arguments[i];
-                        for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
-                            t[p] = s[p];
-                    }
-                    return t;
-                };
-                return __assign.apply(this, arguments);
-            };`
-      };
-      awaitHelper = {
-        name: "typescript:await",
-        importName: "__await",
-        scoped: false,
-        text: `
-            var __await = (this && this.__await) || function (v) { return this instanceof __await ? (this.v = v, this) : new __await(v); }`
-      };
-      asyncGeneratorHelper = {
-        name: "typescript:asyncGenerator",
-        importName: "__asyncGenerator",
-        scoped: false,
-        dependencies: [awaitHelper],
-        text: `
-            var __asyncGenerator = (this && this.__asyncGenerator) || function (thisArg, _arguments, generator) {
-                if (!Symbol.asyncIterator) throw new TypeError("Symbol.asyncIterator is not defined.");
-                var g = generator.apply(thisArg, _arguments || []), i, q = [];
-                return i = {}, verb("next"), verb("throw"), verb("return"), i[Symbol.asyncIterator] = function () { return this; }, i;
-                function verb(n) { if (g[n]) i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; }
-                function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } }
-                function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); }
-                function fulfill(value) { resume("next", value); }
-                function reject(value) { resume("throw", value); }
-                function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); }
-            };`
-      };
-      asyncDelegator = {
-        name: "typescript:asyncDelegator",
-        importName: "__asyncDelegator",
-        scoped: false,
-        dependencies: [awaitHelper],
-        text: `
-            var __asyncDelegator = (this && this.__asyncDelegator) || function (o) {
-                var i, p;
-                return i = {}, verb("next"), verb("throw", function (e) { throw e; }), verb("return"), i[Symbol.iterator] = function () { return this; }, i;
-                function verb(n, f) { i[n] = o[n] ? function (v) { return (p = !p) ? { value: __await(o[n](v)), done: false } : f ? f(v) : v; } : f; }
-            };`
-      };
-      asyncValues = {
-        name: "typescript:asyncValues",
-        importName: "__asyncValues",
-        scoped: false,
-        text: `
-            var __asyncValues = (this && this.__asyncValues) || function (o) {
-                if (!Symbol.asyncIterator) throw new TypeError("Symbol.asyncIterator is not defined.");
-                var m = o[Symbol.asyncIterator], i;
-                return m ? m.call(o) : (o = typeof __values === "function" ? __values(o) : o[Symbol.iterator](), i = {}, verb("next"), verb("throw"), verb("return"), i[Symbol.asyncIterator] = function () { return this; }, i);
-                function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; }
-                function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); }
-            };`
-      };
-      restHelper = {
-        name: "typescript:rest",
-        importName: "__rest",
-        scoped: false,
-        text: `
-            var __rest = (this && this.__rest) || function (s, e) {
-                var t = {};
-                for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
-                    t[p] = s[p];
-                if (s != null && typeof Object.getOwnPropertySymbols === "function")
-                    for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
-                        if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
-                            t[p[i]] = s[p[i]];
-                    }
-                return t;
-            };`
-      };
-      awaiterHelper = {
-        name: "typescript:awaiter",
-        importName: "__awaiter",
-        scoped: false,
-        priority: 5,
-        text: `
-            var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
-                function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
-                return new (P || (P = Promise))(function (resolve, reject) {
-                    function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
-                    function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
-                    function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
-                    step((generator = generator.apply(thisArg, _arguments || [])).next());
-                });
-            };`
-      };
-      extendsHelper = {
-        name: "typescript:extends",
-        importName: "__extends",
-        scoped: false,
-        priority: 0,
-        text: `
-            var __extends = (this && this.__extends) || (function () {
-                var extendStatics = function (d, b) {
-                    extendStatics = Object.setPrototypeOf ||
-                        ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
-                        function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };
-                    return extendStatics(d, b);
-                };
-
-                return function (d, b) {
-                    if (typeof b !== "function" && b !== null)
-                        throw new TypeError("Class extends value " + String(b) + " is not a constructor or null");
-                    extendStatics(d, b);
-                    function __() { this.constructor = d; }
-                    d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
-                };
-            })();`
-      };
-      templateObjectHelper = {
-        name: "typescript:makeTemplateObject",
-        importName: "__makeTemplateObject",
-        scoped: false,
-        priority: 0,
-        text: `
-            var __makeTemplateObject = (this && this.__makeTemplateObject) || function (cooked, raw) {
-                if (Object.defineProperty) { Object.defineProperty(cooked, "raw", { value: raw }); } else { cooked.raw = raw; }
-                return cooked;
-            };`
-      };
-      readHelper = {
-        name: "typescript:read",
-        importName: "__read",
-        scoped: false,
-        text: `
-            var __read = (this && this.__read) || function (o, n) {
-                var m = typeof Symbol === "function" && o[Symbol.iterator];
-                if (!m) return o;
-                var i = m.call(o), r, ar = [], e;
-                try {
-                    while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);
-                }
-                catch (error) { e = { error: error }; }
-                finally {
-                    try {
-                        if (r && !r.done && (m = i["return"])) m.call(i);
-                    }
-                    finally { if (e) throw e.error; }
-                }
-                return ar;
-            };`
-      };
-      spreadArrayHelper = {
-        name: "typescript:spreadArray",
-        importName: "__spreadArray",
-        scoped: false,
-        text: `
-            var __spreadArray = (this && this.__spreadArray) || function (to, from, pack) {
-                if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {
-                    if (ar || !(i in from)) {
-                        if (!ar) ar = Array.prototype.slice.call(from, 0, i);
-                        ar[i] = from[i];
-                    }
-                }
-                return to.concat(ar || Array.prototype.slice.call(from));
-            };`
-      };
-      propKeyHelper = {
-        name: "typescript:propKey",
-        importName: "__propKey",
-        scoped: false,
-        text: `
-        var __propKey = (this && this.__propKey) || function (x) {
-            return typeof x === "symbol" ? x : "".concat(x);
-        };`
-      };
-      setFunctionNameHelper = {
-        name: "typescript:setFunctionName",
-        importName: "__setFunctionName",
-        scoped: false,
-        text: `
-        var __setFunctionName = (this && this.__setFunctionName) || function (f, name, prefix) {
-            if (typeof name === "symbol") name = name.description ? "[".concat(name.description, "]") : "";
-            return Object.defineProperty(f, "name", { configurable: true, value: prefix ? "".concat(prefix, " ", name) : name });
-        };`
-      };
-      valuesHelper = {
-        name: "typescript:values",
-        importName: "__values",
-        scoped: false,
-        text: `
-            var __values = (this && this.__values) || function(o) {
-                var s = typeof Symbol === "function" && Symbol.iterator, m = s && o[s], i = 0;
-                if (m) return m.call(o);
-                if (o && typeof o.length === "number") return {
-                    next: function () {
-                        if (o && i >= o.length) o = void 0;
-                        return { value: o && o[i++], done: !o };
-                    }
-                };
-                throw new TypeError(s ? "Object is not iterable." : "Symbol.iterator is not defined.");
-            };`
-      };
-      generatorHelper = {
-        name: "typescript:generator",
-        importName: "__generator",
-        scoped: false,
-        priority: 6,
-        text: `
-            var __generator = (this && this.__generator) || function (thisArg, body) {
-                var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;
-                return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
-                function verb(n) { return function (v) { return step([n, v]); }; }
-                function step(op) {
-                    if (f) throw new TypeError("Generator is already executing.");
-                    while (g && (g = 0, op[0] && (_ = 0)), _) try {
-                        if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
-                        if (y = 0, t) op = [op[0] & 2, t.value];
-                        switch (op[0]) {
-                            case 0: case 1: t = op; break;
-                            case 4: _.label++; return { value: op[1], done: false };
-                            case 5: _.label++; y = op[1]; op = [0]; continue;
-                            case 7: op = _.ops.pop(); _.trys.pop(); continue;
-                            default:
-                                if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
-                                if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
-                                if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
-                                if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
-                                if (t[2]) _.ops.pop();
-                                _.trys.pop(); continue;
-                        }
-                        op = body.call(thisArg, _);
-                    } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
-                    if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
-                }
-            };`
-      };
-      createBindingHelper = {
-        name: "typescript:commonjscreatebinding",
-        importName: "__createBinding",
-        scoped: false,
-        priority: 1,
-        text: `
-            var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
-                if (k2 === undefined) k2 = k;
-                var desc = Object.getOwnPropertyDescriptor(m, k);
-                if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
-                  desc = { enumerable: true, get: function() { return m[k]; } };
-                }
-                Object.defineProperty(o, k2, desc);
-            }) : (function(o, m, k, k2) {
-                if (k2 === undefined) k2 = k;
-                o[k2] = m[k];
-            }));`
-      };
-      setModuleDefaultHelper = {
-        name: "typescript:commonjscreatevalue",
-        importName: "__setModuleDefault",
-        scoped: false,
-        priority: 1,
-        text: `
-            var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
-                Object.defineProperty(o, "default", { enumerable: true, value: v });
-            }) : function(o, v) {
-                o["default"] = v;
-            });`
-      };
-      importStarHelper = {
-        name: "typescript:commonjsimportstar",
-        importName: "__importStar",
-        scoped: false,
-        dependencies: [createBindingHelper, setModuleDefaultHelper],
-        priority: 2,
-        text: `
-            var __importStar = (this && this.__importStar) || function (mod) {
-                if (mod && mod.__esModule) return mod;
-                var result = {};
-                if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
-                __setModuleDefault(result, mod);
-                return result;
-            };`
-      };
-      importDefaultHelper = {
-        name: "typescript:commonjsimportdefault",
-        importName: "__importDefault",
-        scoped: false,
-        text: `
-            var __importDefault = (this && this.__importDefault) || function (mod) {
-                return (mod && mod.__esModule) ? mod : { "default": mod };
-            };`
-      };
-      exportStarHelper = {
-        name: "typescript:export-star",
-        importName: "__exportStar",
-        scoped: false,
-        dependencies: [createBindingHelper],
-        priority: 2,
-        text: `
-            var __exportStar = (this && this.__exportStar) || function(m, exports) {
-                for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
-            };`
-      };
-      classPrivateFieldGetHelper = {
-        name: "typescript:classPrivateFieldGet",
-        importName: "__classPrivateFieldGet",
-        scoped: false,
-        text: `
-            var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (receiver, state, kind, f) {
-                if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a getter");
-                if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot read private member from an object whose class did not declare it");
-                return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
-            };`
-      };
-      classPrivateFieldSetHelper = {
-        name: "typescript:classPrivateFieldSet",
-        importName: "__classPrivateFieldSet",
-        scoped: false,
-        text: `
-            var __classPrivateFieldSet = (this && this.__classPrivateFieldSet) || function (receiver, state, value, kind, f) {
-                if (kind === "m") throw new TypeError("Private method is not writable");
-                if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a setter");
-                if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot write private member to an object whose class did not declare it");
-                return (kind === "a" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;
-            };`
-      };
-      classPrivateFieldInHelper = {
-        name: "typescript:classPrivateFieldIn",
-        importName: "__classPrivateFieldIn",
-        scoped: false,
-        text: `
-            var __classPrivateFieldIn = (this && this.__classPrivateFieldIn) || function(state, receiver) {
-                if (receiver === null || (typeof receiver !== "object" && typeof receiver !== "function")) throw new TypeError("Cannot use 'in' operator on non-object");
-                return typeof state === "function" ? receiver === state : state.has(receiver);
-            };`
-      };
-      asyncSuperHelper = {
-        name: "typescript:async-super",
-        scoped: true,
-        text: helperString`
-            const ${"_superIndex"} = name => super[name];`
-      };
-      advancedAsyncSuperHelper = {
-        name: "typescript:advanced-async-super",
-        scoped: true,
-        text: helperString`
-            const ${"_superIndex"} = (function (geti, seti) {
-                const cache = Object.create(null);
-                return name => cache[name] || (cache[name] = { get value() { return geti(name); }, set value(v) { seti(name, v); } });
-            })(name => super[name], (name, value) => super[name] = value);`
-      };
-    }
-  });
-
-  // src/compiler/factory/nodeTests.ts
-  function isNumericLiteral(node) {
-    return node.kind === 9 /* NumericLiteral */;
-  }
-  function isBigIntLiteral(node) {
-    return node.kind === 10 /* BigIntLiteral */;
-  }
-  function isStringLiteral(node) {
-    return node.kind === 11 /* StringLiteral */;
-  }
-  function isJsxText(node) {
-    return node.kind === 12 /* JsxText */;
-  }
-  function isRegularExpressionLiteral(node) {
-    return node.kind === 14 /* RegularExpressionLiteral */;
-  }
-  function isNoSubstitutionTemplateLiteral(node) {
-    return node.kind === 15 /* NoSubstitutionTemplateLiteral */;
-  }
-  function isTemplateHead(node) {
-    return node.kind === 16 /* TemplateHead */;
-  }
-  function isTemplateMiddle(node) {
-    return node.kind === 17 /* TemplateMiddle */;
-  }
-  function isTemplateTail(node) {
-    return node.kind === 18 /* TemplateTail */;
-  }
-  function isDotDotDotToken(node) {
-    return node.kind === 26 /* DotDotDotToken */;
-  }
-  function isCommaToken(node) {
-    return node.kind === 28 /* CommaToken */;
-  }
-  function isPlusToken(node) {
-    return node.kind === 40 /* PlusToken */;
-  }
-  function isMinusToken(node) {
-    return node.kind === 41 /* MinusToken */;
-  }
-  function isAsteriskToken(node) {
-    return node.kind === 42 /* AsteriskToken */;
-  }
-  function isExclamationToken(node) {
-    return node.kind === 54 /* ExclamationToken */;
-  }
-  function isQuestionToken(node) {
-    return node.kind === 58 /* QuestionToken */;
-  }
-  function isColonToken(node) {
-    return node.kind === 59 /* ColonToken */;
-  }
-  function isQuestionDotToken(node) {
-    return node.kind === 29 /* QuestionDotToken */;
-  }
-  function isEqualsGreaterThanToken(node) {
-    return node.kind === 39 /* EqualsGreaterThanToken */;
-  }
-  function isIdentifier(node) {
-    return node.kind === 80 /* Identifier */;
-  }
-  function isPrivateIdentifier(node) {
-    return node.kind === 81 /* PrivateIdentifier */;
-  }
-  function isExportModifier(node) {
-    return node.kind === 95 /* ExportKeyword */;
-  }
-  function isDefaultModifier(node) {
-    return node.kind === 90 /* DefaultKeyword */;
-  }
-  function isAsyncModifier(node) {
-    return node.kind === 134 /* AsyncKeyword */;
-  }
-  function isAssertsKeyword(node) {
-    return node.kind === 131 /* AssertsKeyword */;
-  }
-  function isAwaitKeyword(node) {
-    return node.kind === 135 /* AwaitKeyword */;
-  }
-  function isReadonlyKeyword(node) {
-    return node.kind === 148 /* ReadonlyKeyword */;
-  }
-  function isStaticModifier(node) {
-    return node.kind === 126 /* StaticKeyword */;
-  }
-  function isAbstractModifier(node) {
-    return node.kind === 128 /* AbstractKeyword */;
-  }
-  function isOverrideModifier(node) {
-    return node.kind === 163 /* OverrideKeyword */;
-  }
-  function isAccessorModifier(node) {
-    return node.kind === 129 /* AccessorKeyword */;
-  }
-  function isSuperKeyword(node) {
-    return node.kind === 108 /* SuperKeyword */;
-  }
-  function isImportKeyword(node) {
-    return node.kind === 102 /* ImportKeyword */;
-  }
-  function isCaseKeyword(node) {
-    return node.kind === 84 /* CaseKeyword */;
-  }
-  function isQualifiedName(node) {
-    return node.kind === 165 /* QualifiedName */;
-  }
-  function isComputedPropertyName(node) {
-    return node.kind === 166 /* ComputedPropertyName */;
-  }
-  function isTypeParameterDeclaration(node) {
-    return node.kind === 167 /* TypeParameter */;
-  }
-  function isParameter(node) {
-    return node.kind === 168 /* Parameter */;
-  }
-  function isDecorator(node) {
-    return node.kind === 169 /* Decorator */;
-  }
-  function isPropertySignature(node) {
-    return node.kind === 170 /* PropertySignature */;
-  }
-  function isPropertyDeclaration(node) {
-    return node.kind === 171 /* PropertyDeclaration */;
-  }
-  function isMethodSignature(node) {
-    return node.kind === 172 /* MethodSignature */;
-  }
-  function isMethodDeclaration(node) {
-    return node.kind === 173 /* MethodDeclaration */;
-  }
-  function isClassStaticBlockDeclaration(node) {
-    return node.kind === 174 /* ClassStaticBlockDeclaration */;
-  }
-  function isConstructorDeclaration(node) {
-    return node.kind === 175 /* Constructor */;
-  }
-  function isGetAccessorDeclaration(node) {
-    return node.kind === 176 /* GetAccessor */;
-  }
-  function isSetAccessorDeclaration(node) {
-    return node.kind === 177 /* SetAccessor */;
-  }
-  function isCallSignatureDeclaration(node) {
-    return node.kind === 178 /* CallSignature */;
-  }
-  function isConstructSignatureDeclaration(node) {
-    return node.kind === 179 /* ConstructSignature */;
-  }
-  function isIndexSignatureDeclaration(node) {
-    return node.kind === 180 /* IndexSignature */;
-  }
-  function isTypePredicateNode(node) {
-    return node.kind === 181 /* TypePredicate */;
-  }
-  function isTypeReferenceNode(node) {
-    return node.kind === 182 /* TypeReference */;
-  }
-  function isFunctionTypeNode(node) {
-    return node.kind === 183 /* FunctionType */;
-  }
-  function isConstructorTypeNode(node) {
-    return node.kind === 184 /* ConstructorType */;
-  }
-  function isTypeQueryNode(node) {
-    return node.kind === 185 /* TypeQuery */;
-  }
-  function isTypeLiteralNode(node) {
-    return node.kind === 186 /* TypeLiteral */;
-  }
-  function isArrayTypeNode(node) {
-    return node.kind === 187 /* ArrayType */;
-  }
-  function isTupleTypeNode(node) {
-    return node.kind === 188 /* TupleType */;
-  }
-  function isNamedTupleMember(node) {
-    return node.kind === 201 /* NamedTupleMember */;
-  }
-  function isOptionalTypeNode(node) {
-    return node.kind === 189 /* OptionalType */;
-  }
-  function isRestTypeNode(node) {
-    return node.kind === 190 /* RestType */;
-  }
-  function isUnionTypeNode(node) {
-    return node.kind === 191 /* UnionType */;
-  }
-  function isIntersectionTypeNode(node) {
-    return node.kind === 192 /* IntersectionType */;
-  }
-  function isConditionalTypeNode(node) {
-    return node.kind === 193 /* ConditionalType */;
-  }
-  function isInferTypeNode(node) {
-    return node.kind === 194 /* InferType */;
-  }
-  function isParenthesizedTypeNode(node) {
-    return node.kind === 195 /* ParenthesizedType */;
-  }
-  function isThisTypeNode(node) {
-    return node.kind === 196 /* ThisType */;
-  }
-  function isTypeOperatorNode(node) {
-    return node.kind === 197 /* TypeOperator */;
-  }
-  function isIndexedAccessTypeNode(node) {
-    return node.kind === 198 /* IndexedAccessType */;
-  }
-  function isMappedTypeNode(node) {
-    return node.kind === 199 /* MappedType */;
-  }
-  function isLiteralTypeNode(node) {
-    return node.kind === 200 /* LiteralType */;
-  }
-  function isImportTypeNode(node) {
-    return node.kind === 204 /* ImportType */;
-  }
-  function isTemplateLiteralTypeSpan(node) {
-    return node.kind === 203 /* TemplateLiteralTypeSpan */;
-  }
-  function isTemplateLiteralTypeNode(node) {
-    return node.kind === 202 /* TemplateLiteralType */;
-  }
-  function isObjectBindingPattern(node) {
-    return node.kind === 205 /* ObjectBindingPattern */;
-  }
-  function isArrayBindingPattern(node) {
-    return node.kind === 206 /* ArrayBindingPattern */;
-  }
-  function isBindingElement(node) {
-    return node.kind === 207 /* BindingElement */;
-  }
-  function isArrayLiteralExpression(node) {
-    return node.kind === 208 /* ArrayLiteralExpression */;
-  }
-  function isObjectLiteralExpression(node) {
-    return node.kind === 209 /* ObjectLiteralExpression */;
-  }
-  function isPropertyAccessExpression(node) {
-    return node.kind === 210 /* PropertyAccessExpression */;
-  }
-  function isElementAccessExpression(node) {
-    return node.kind === 211 /* ElementAccessExpression */;
-  }
-  function isCallExpression(node) {
-    return node.kind === 212 /* CallExpression */;
-  }
-  function isNewExpression(node) {
-    return node.kind === 213 /* NewExpression */;
-  }
-  function isTaggedTemplateExpression(node) {
-    return node.kind === 214 /* TaggedTemplateExpression */;
-  }
-  function isTypeAssertionExpression(node) {
-    return node.kind === 215 /* TypeAssertionExpression */;
-  }
-  function isParenthesizedExpression(node) {
-    return node.kind === 216 /* ParenthesizedExpression */;
-  }
-  function isFunctionExpression(node) {
-    return node.kind === 217 /* FunctionExpression */;
-  }
-  function isArrowFunction(node) {
-    return node.kind === 218 /* ArrowFunction */;
-  }
-  function isDeleteExpression(node) {
-    return node.kind === 219 /* DeleteExpression */;
-  }
-  function isTypeOfExpression(node) {
-    return node.kind === 220 /* TypeOfExpression */;
-  }
-  function isVoidExpression(node) {
-    return node.kind === 221 /* VoidExpression */;
-  }
-  function isAwaitExpression(node) {
-    return node.kind === 222 /* AwaitExpression */;
-  }
-  function isPrefixUnaryExpression(node) {
-    return node.kind === 223 /* PrefixUnaryExpression */;
-  }
-  function isPostfixUnaryExpression(node) {
-    return node.kind === 224 /* PostfixUnaryExpression */;
-  }
-  function isBinaryExpression(node) {
-    return node.kind === 225 /* BinaryExpression */;
-  }
-  function isConditionalExpression(node) {
-    return node.kind === 226 /* ConditionalExpression */;
-  }
-  function isTemplateExpression(node) {
-    return node.kind === 227 /* TemplateExpression */;
-  }
-  function isYieldExpression(node) {
-    return node.kind === 228 /* YieldExpression */;
-  }
-  function isSpreadElement(node) {
-    return node.kind === 229 /* SpreadElement */;
-  }
-  function isClassExpression(node) {
-    return node.kind === 230 /* ClassExpression */;
-  }
-  function isOmittedExpression(node) {
-    return node.kind === 231 /* OmittedExpression */;
-  }
-  function isExpressionWithTypeArguments(node) {
-    return node.kind === 232 /* ExpressionWithTypeArguments */;
-  }
-  function isAsExpression(node) {
-    return node.kind === 233 /* AsExpression */;
-  }
-  function isSatisfiesExpression(node) {
-    return node.kind === 237 /* SatisfiesExpression */;
-  }
-  function isNonNullExpression(node) {
-    return node.kind === 234 /* NonNullExpression */;
-  }
-  function isMetaProperty(node) {
-    return node.kind === 235 /* MetaProperty */;
-  }
-  function isSyntheticExpression(node) {
-    return node.kind === 236 /* SyntheticExpression */;
-  }
-  function isPartiallyEmittedExpression(node) {
-    return node.kind === 359 /* PartiallyEmittedExpression */;
-  }
-  function isCommaListExpression(node) {
-    return node.kind === 360 /* CommaListExpression */;
-  }
-  function isTemplateSpan(node) {
-    return node.kind === 238 /* TemplateSpan */;
-  }
-  function isSemicolonClassElement(node) {
-    return node.kind === 239 /* SemicolonClassElement */;
-  }
-  function isBlock(node) {
-    return node.kind === 240 /* Block */;
-  }
-  function isVariableStatement(node) {
-    return node.kind === 242 /* VariableStatement */;
-  }
-  function isEmptyStatement(node) {
-    return node.kind === 241 /* EmptyStatement */;
-  }
-  function isExpressionStatement(node) {
-    return node.kind === 243 /* ExpressionStatement */;
-  }
-  function isIfStatement(node) {
-    return node.kind === 244 /* IfStatement */;
-  }
-  function isDoStatement(node) {
-    return node.kind === 245 /* DoStatement */;
-  }
-  function isWhileStatement(node) {
-    return node.kind === 246 /* WhileStatement */;
-  }
-  function isForStatement(node) {
-    return node.kind === 247 /* ForStatement */;
-  }
-  function isForInStatement(node) {
-    return node.kind === 248 /* ForInStatement */;
-  }
-  function isForOfStatement(node) {
-    return node.kind === 249 /* ForOfStatement */;
-  }
-  function isContinueStatement(node) {
-    return node.kind === 250 /* ContinueStatement */;
-  }
-  function isBreakStatement(node) {
-    return node.kind === 251 /* BreakStatement */;
-  }
-  function isReturnStatement(node) {
-    return node.kind === 252 /* ReturnStatement */;
-  }
-  function isWithStatement(node) {
-    return node.kind === 253 /* WithStatement */;
-  }
-  function isSwitchStatement(node) {
-    return node.kind === 254 /* SwitchStatement */;
-  }
-  function isLabeledStatement(node) {
-    return node.kind === 255 /* LabeledStatement */;
-  }
-  function isThrowStatement(node) {
-    return node.kind === 256 /* ThrowStatement */;
-  }
-  function isTryStatement(node) {
-    return node.kind === 257 /* TryStatement */;
-  }
-  function isDebuggerStatement(node) {
-    return node.kind === 258 /* DebuggerStatement */;
-  }
-  function isVariableDeclaration(node) {
-    return node.kind === 259 /* VariableDeclaration */;
-  }
-  function isVariableDeclarationList(node) {
-    return node.kind === 260 /* VariableDeclarationList */;
-  }
-  function isFunctionDeclaration(node) {
-    return node.kind === 261 /* FunctionDeclaration */;
-  }
-  function isClassDeclaration(node) {
-    return node.kind === 262 /* ClassDeclaration */;
-  }
-  function isInterfaceDeclaration(node) {
-    return node.kind === 263 /* InterfaceDeclaration */;
-  }
-  function isTypeAliasDeclaration(node) {
-    return node.kind === 264 /* TypeAliasDeclaration */;
-  }
-  function isEnumDeclaration(node) {
-    return node.kind === 265 /* EnumDeclaration */;
-  }
-  function isModuleDeclaration(node) {
-    return node.kind === 266 /* ModuleDeclaration */;
-  }
-  function isModuleBlock(node) {
-    return node.kind === 267 /* ModuleBlock */;
-  }
-  function isCaseBlock(node) {
-    return node.kind === 268 /* CaseBlock */;
-  }
-  function isNamespaceExportDeclaration(node) {
-    return node.kind === 269 /* NamespaceExportDeclaration */;
-  }
-  function isImportEqualsDeclaration(node) {
-    return node.kind === 270 /* ImportEqualsDeclaration */;
-  }
-  function isImportDeclaration(node) {
-    return node.kind === 271 /* ImportDeclaration */;
-  }
-  function isImportClause(node) {
-    return node.kind === 272 /* ImportClause */;
-  }
-  function isImportTypeAssertionContainer(node) {
-    return node.kind === 301 /* ImportTypeAssertionContainer */;
-  }
-  function isAssertClause(node) {
-    return node.kind === 299 /* AssertClause */;
-  }
-  function isAssertEntry(node) {
-    return node.kind === 300 /* AssertEntry */;
-  }
-  function isNamespaceImport(node) {
-    return node.kind === 273 /* NamespaceImport */;
-  }
-  function isNamespaceExport(node) {
-    return node.kind === 279 /* NamespaceExport */;
-  }
-  function isNamedImports(node) {
-    return node.kind === 274 /* NamedImports */;
-  }
-  function isImportSpecifier(node) {
-    return node.kind === 275 /* ImportSpecifier */;
-  }
-  function isExportAssignment(node) {
-    return node.kind === 276 /* ExportAssignment */;
-  }
-  function isExportDeclaration(node) {
-    return node.kind === 277 /* ExportDeclaration */;
-  }
-  function isNamedExports(node) {
-    return node.kind === 278 /* NamedExports */;
-  }
-  function isExportSpecifier(node) {
-    return node.kind === 280 /* ExportSpecifier */;
-  }
-  function isMissingDeclaration(node) {
-    return node.kind === 281 /* MissingDeclaration */;
-  }
-  function isNotEmittedStatement(node) {
-    return node.kind === 358 /* NotEmittedStatement */;
-  }
-  function isSyntheticReference(node) {
-    return node.kind === 361 /* SyntheticReferenceExpression */;
-  }
-  function isExternalModuleReference(node) {
-    return node.kind === 282 /* ExternalModuleReference */;
-  }
-  function isJsxElement(node) {
-    return node.kind === 283 /* JsxElement */;
-  }
-  function isJsxSelfClosingElement(node) {
-    return node.kind === 284 /* JsxSelfClosingElement */;
-  }
-  function isJsxOpeningElement(node) {
-    return node.kind === 285 /* JsxOpeningElement */;
-  }
-  function isJsxClosingElement(node) {
-    return node.kind === 286 /* JsxClosingElement */;
-  }
-  function isJsxFragment(node) {
-    return node.kind === 287 /* JsxFragment */;
-  }
-  function isJsxOpeningFragment(node) {
-    return node.kind === 288 /* JsxOpeningFragment */;
-  }
-  function isJsxClosingFragment(node) {
-    return node.kind === 289 /* JsxClosingFragment */;
-  }
-  function isJsxAttribute(node) {
-    return node.kind === 290 /* JsxAttribute */;
-  }
-  function isJsxAttributes(node) {
-    return node.kind === 291 /* JsxAttributes */;
-  }
-  function isJsxSpreadAttribute(node) {
-    return node.kind === 292 /* JsxSpreadAttribute */;
-  }
-  function isJsxExpression(node) {
-    return node.kind === 293 /* JsxExpression */;
-  }
-  function isJsxNamespacedName(node) {
-    return node.kind === 294 /* JsxNamespacedName */;
-  }
-  function isCaseClause(node) {
-    return node.kind === 295 /* CaseClause */;
-  }
-  function isDefaultClause(node) {
-    return node.kind === 296 /* DefaultClause */;
-  }
-  function isHeritageClause(node) {
-    return node.kind === 297 /* HeritageClause */;
-  }
-  function isCatchClause(node) {
-    return node.kind === 298 /* CatchClause */;
-  }
-  function isPropertyAssignment(node) {
-    return node.kind === 302 /* PropertyAssignment */;
-  }
-  function isShorthandPropertyAssignment(node) {
-    return node.kind === 303 /* ShorthandPropertyAssignment */;
-  }
-  function isSpreadAssignment(node) {
-    return node.kind === 304 /* SpreadAssignment */;
-  }
-  function isEnumMember(node) {
-    return node.kind === 305 /* EnumMember */;
-  }
-  function isUnparsedPrepend(node) {
-    return node.kind === 307 /* UnparsedPrepend */;
-  }
-  function isSourceFile(node) {
-    return node.kind === 311 /* SourceFile */;
-  }
-  function isBundle(node) {
-    return node.kind === 312 /* Bundle */;
-  }
-  function isUnparsedSource(node) {
-    return node.kind === 313 /* UnparsedSource */;
-  }
-  function isJSDocTypeExpression(node) {
-    return node.kind === 315 /* JSDocTypeExpression */;
-  }
-  function isJSDocNameReference(node) {
-    return node.kind === 316 /* JSDocNameReference */;
-  }
-  function isJSDocMemberName(node) {
-    return node.kind === 317 /* JSDocMemberName */;
-  }
-  function isJSDocLink(node) {
-    return node.kind === 330 /* JSDocLink */;
-  }
-  function isJSDocLinkCode(node) {
-    return node.kind === 331 /* JSDocLinkCode */;
-  }
-  function isJSDocLinkPlain(node) {
-    return node.kind === 332 /* JSDocLinkPlain */;
-  }
-  function isJSDocAllType(node) {
-    return node.kind === 318 /* JSDocAllType */;
-  }
-  function isJSDocUnknownType(node) {
-    return node.kind === 319 /* JSDocUnknownType */;
-  }
-  function isJSDocNullableType(node) {
-    return node.kind === 320 /* JSDocNullableType */;
-  }
-  function isJSDocNonNullableType(node) {
-    return node.kind === 321 /* JSDocNonNullableType */;
-  }
-  function isJSDocOptionalType(node) {
-    return node.kind === 322 /* JSDocOptionalType */;
-  }
-  function isJSDocFunctionType(node) {
-    return node.kind === 323 /* JSDocFunctionType */;
-  }
-  function isJSDocVariadicType(node) {
-    return node.kind === 324 /* JSDocVariadicType */;
-  }
-  function isJSDocNamepathType(node) {
-    return node.kind === 325 /* JSDocNamepathType */;
-  }
-  function isJSDoc(node) {
-    return node.kind === 326 /* JSDoc */;
-  }
-  function isJSDocTypeLiteral(node) {
-    return node.kind === 328 /* JSDocTypeLiteral */;
-  }
-  function isJSDocSignature(node) {
-    return node.kind === 329 /* JSDocSignature */;
-  }
-  function isJSDocAugmentsTag(node) {
-    return node.kind === 334 /* JSDocAugmentsTag */;
-  }
-  function isJSDocAuthorTag(node) {
-    return node.kind === 336 /* JSDocAuthorTag */;
-  }
-  function isJSDocClassTag(node) {
-    return node.kind === 338 /* JSDocClassTag */;
-  }
-  function isJSDocCallbackTag(node) {
-    return node.kind === 344 /* JSDocCallbackTag */;
-  }
-  function isJSDocPublicTag(node) {
-    return node.kind === 339 /* JSDocPublicTag */;
-  }
-  function isJSDocPrivateTag(node) {
-    return node.kind === 340 /* JSDocPrivateTag */;
-  }
-  function isJSDocProtectedTag(node) {
-    return node.kind === 341 /* JSDocProtectedTag */;
-  }
-  function isJSDocReadonlyTag(node) {
-    return node.kind === 342 /* JSDocReadonlyTag */;
-  }
-  function isJSDocOverrideTag(node) {
-    return node.kind === 343 /* JSDocOverrideTag */;
-  }
-  function isJSDocOverloadTag(node) {
-    return node.kind === 345 /* JSDocOverloadTag */;
-  }
-  function isJSDocDeprecatedTag(node) {
-    return node.kind === 337 /* JSDocDeprecatedTag */;
-  }
-  function isJSDocSeeTag(node) {
-    return node.kind === 353 /* JSDocSeeTag */;
-  }
-  function isJSDocEnumTag(node) {
-    return node.kind === 346 /* JSDocEnumTag */;
-  }
-  function isJSDocParameterTag(node) {
-    return node.kind === 347 /* JSDocParameterTag */;
-  }
-  function isJSDocReturnTag(node) {
-    return node.kind === 348 /* JSDocReturnTag */;
-  }
-  function isJSDocThisTag(node) {
-    return node.kind === 349 /* JSDocThisTag */;
-  }
-  function isJSDocTypeTag(node) {
-    return node.kind === 350 /* JSDocTypeTag */;
-  }
-  function isJSDocTemplateTag(node) {
-    return node.kind === 351 /* JSDocTemplateTag */;
-  }
-  function isJSDocTypedefTag(node) {
-    return node.kind === 352 /* JSDocTypedefTag */;
-  }
-  function isJSDocUnknownTag(node) {
-    return node.kind === 333 /* JSDocTag */;
-  }
-  function isJSDocPropertyTag(node) {
-    return node.kind === 354 /* JSDocPropertyTag */;
-  }
-  function isJSDocImplementsTag(node) {
-    return node.kind === 335 /* JSDocImplementsTag */;
-  }
-  function isJSDocSatisfiesTag(node) {
-    return node.kind === 356 /* JSDocSatisfiesTag */;
-  }
-  function isJSDocThrowsTag(node) {
-    return node.kind === 355 /* JSDocThrowsTag */;
-  }
-  function isSyntaxList(n) {
-    return n.kind === 357 /* SyntaxList */;
-  }
-  var init_nodeTests = __esm({
-    "src/compiler/factory/nodeTests.ts"() {
-      "use strict";
-      init_ts2();
-    }
-  });
-
-  // src/compiler/factory/utilities.ts
-  function createEmptyExports(factory2) {
-    return factory2.createExportDeclaration(
-      /*modifiers*/
-      void 0,
-      /*isTypeOnly*/
-      false,
-      factory2.createNamedExports([]),
-      /*moduleSpecifier*/
-      void 0
-    );
-  }
-  function createMemberAccessForPropertyName(factory2, target, memberName, location) {
-    if (isComputedPropertyName(memberName)) {
-      return setTextRange(factory2.createElementAccessExpression(target, memberName.expression), location);
-    } else {
-      const expression = setTextRange(
-        isMemberName(memberName) ? factory2.createPropertyAccessExpression(target, memberName) : factory2.createElementAccessExpression(target, memberName),
-        memberName
-      );
-      addEmitFlags(expression, 128 /* NoNestedSourceMaps */);
-      return expression;
-    }
-  }
-  function createReactNamespace(reactNamespace, parent2) {
-    const react = parseNodeFactory.createIdentifier(reactNamespace || "React");
-    setParent(react, getParseTreeNode(parent2));
-    return react;
-  }
-  function createJsxFactoryExpressionFromEntityName(factory2, jsxFactory, parent2) {
-    if (isQualifiedName(jsxFactory)) {
-      const left = createJsxFactoryExpressionFromEntityName(factory2, jsxFactory.left, parent2);
-      const right = factory2.createIdentifier(idText(jsxFactory.right));
-      right.escapedText = jsxFactory.right.escapedText;
-      return factory2.createPropertyAccessExpression(left, right);
-    } else {
-      return createReactNamespace(idText(jsxFactory), parent2);
-    }
-  }
-  function createJsxFactoryExpression(factory2, jsxFactoryEntity, reactNamespace, parent2) {
-    return jsxFactoryEntity ? createJsxFactoryExpressionFromEntityName(factory2, jsxFactoryEntity, parent2) : factory2.createPropertyAccessExpression(
-      createReactNamespace(reactNamespace, parent2),
-      "createElement"
-    );
-  }
-  function createJsxFragmentFactoryExpression(factory2, jsxFragmentFactoryEntity, reactNamespace, parent2) {
-    return jsxFragmentFactoryEntity ? createJsxFactoryExpressionFromEntityName(factory2, jsxFragmentFactoryEntity, parent2) : factory2.createPropertyAccessExpression(
-      createReactNamespace(reactNamespace, parent2),
-      "Fragment"
-    );
-  }
-  function createExpressionForJsxElement(factory2, callee, tagName, props, children, location) {
-    const argumentsList = [tagName];
-    if (props) {
-      argumentsList.push(props);
-    }
-    if (children && children.length > 0) {
-      if (!props) {
-        argumentsList.push(factory2.createNull());
-      }
-      if (children.length > 1) {
-        for (const child of children) {
-          startOnNewLine(child);
-          argumentsList.push(child);
-        }
-      } else {
-        argumentsList.push(children[0]);
-      }
-    }
-    return setTextRange(
-      factory2.createCallExpression(
-        callee,
-        /*typeArguments*/
-        void 0,
-        argumentsList
-      ),
-      location
-    );
-  }
-  function createExpressionForJsxFragment(factory2, jsxFactoryEntity, jsxFragmentFactoryEntity, reactNamespace, children, parentElement, location) {
-    const tagName = createJsxFragmentFactoryExpression(factory2, jsxFragmentFactoryEntity, reactNamespace, parentElement);
-    const argumentsList = [tagName, factory2.createNull()];
-    if (children && children.length > 0) {
-      if (children.length > 1) {
-        for (const child of children) {
-          startOnNewLine(child);
-          argumentsList.push(child);
-        }
-      } else {
-        argumentsList.push(children[0]);
-      }
-    }
-    return setTextRange(
-      factory2.createCallExpression(
-        createJsxFactoryExpression(factory2, jsxFactoryEntity, reactNamespace, parentElement),
-        /*typeArguments*/
-        void 0,
-        argumentsList
-      ),
-      location
-    );
-  }
-  function createForOfBindingStatement(factory2, node, boundValue) {
-    if (isVariableDeclarationList(node)) {
-      const firstDeclaration = first(node.declarations);
-      const updatedDeclaration = factory2.updateVariableDeclaration(
-        firstDeclaration,
-        firstDeclaration.name,
-        /*exclamationToken*/
-        void 0,
-        /*type*/
-        void 0,
-        boundValue
-      );
-      return setTextRange(
-        factory2.createVariableStatement(
-          /*modifiers*/
-          void 0,
-          factory2.updateVariableDeclarationList(node, [updatedDeclaration])
-        ),
-        /*location*/
-        node
-      );
-    } else {
-      const updatedExpression = setTextRange(
-        factory2.createAssignment(node, boundValue),
-        /*location*/
-        node
-      );
-      return setTextRange(
-        factory2.createExpressionStatement(updatedExpression),
-        /*location*/
-        node
-      );
-    }
-  }
-  function insertLeadingStatement(factory2, dest, source) {
-    if (isBlock(dest)) {
-      return factory2.updateBlock(dest, setTextRange(factory2.createNodeArray([source, ...dest.statements]), dest.statements));
-    } else {
-      return factory2.createBlock(
-        factory2.createNodeArray([dest, source]),
-        /*multiLine*/
-        true
-      );
-    }
-  }
-  function createExpressionFromEntityName(factory2, node) {
-    if (isQualifiedName(node)) {
-      const left = createExpressionFromEntityName(factory2, node.left);
-      const right = setParent(setTextRange(factory2.cloneNode(node.right), node.right), node.right.parent);
-      return setTextRange(factory2.createPropertyAccessExpression(left, right), node);
-    } else {
-      return setParent(setTextRange(factory2.cloneNode(node), node), node.parent);
-    }
-  }
-  function createExpressionForPropertyName(factory2, memberName) {
-    if (isIdentifier(memberName)) {
-      return factory2.createStringLiteralFromNode(memberName);
-    } else if (isComputedPropertyName(memberName)) {
-      return setParent(setTextRange(factory2.cloneNode(memberName.expression), memberName.expression), memberName.expression.parent);
-    } else {
-      return setParent(setTextRange(factory2.cloneNode(memberName), memberName), memberName.parent);
-    }
-  }
-  function createExpressionForAccessorDeclaration(factory2, properties, property, receiver, multiLine) {
-    const { firstAccessor, getAccessor, setAccessor } = getAllAccessorDeclarations(properties, property);
-    if (property === firstAccessor) {
-      return setTextRange(
-        factory2.createObjectDefinePropertyCall(
-          receiver,
-          createExpressionForPropertyName(factory2, property.name),
-          factory2.createPropertyDescriptor({
-            enumerable: factory2.createFalse(),
-            configurable: true,
-            get: getAccessor && setTextRange(
-              setOriginalNode(
-                factory2.createFunctionExpression(
-                  getModifiers(getAccessor),
-                  /*asteriskToken*/
-                  void 0,
-                  /*name*/
-                  void 0,
-                  /*typeParameters*/
-                  void 0,
-                  getAccessor.parameters,
-                  /*type*/
-                  void 0,
-                  getAccessor.body
-                  // TODO: GH#18217
-                ),
-                getAccessor
-              ),
-              getAccessor
-            ),
-            set: setAccessor && setTextRange(
-              setOriginalNode(
-                factory2.createFunctionExpression(
-                  getModifiers(setAccessor),
-                  /*asteriskToken*/
-                  void 0,
-                  /*name*/
-                  void 0,
-                  /*typeParameters*/
-                  void 0,
-                  setAccessor.parameters,
-                  /*type*/
-                  void 0,
-                  setAccessor.body
-                  // TODO: GH#18217
-                ),
-                setAccessor
-              ),
-              setAccessor
-            )
-          }, !multiLine)
-        ),
-        firstAccessor
-      );
-    }
-    return void 0;
-  }
-  function createExpressionForPropertyAssignment(factory2, property, receiver) {
-    return setOriginalNode(
-      setTextRange(
-        factory2.createAssignment(
-          createMemberAccessForPropertyName(
-            factory2,
-            receiver,
-            property.name,
-            /*location*/
-            property.name
-          ),
-          property.initializer
-        ),
-        property
-      ),
-      property
-    );
-  }
-  function createExpressionForShorthandPropertyAssignment(factory2, property, receiver) {
-    return setOriginalNode(
-      setTextRange(
-        factory2.createAssignment(
-          createMemberAccessForPropertyName(
-            factory2,
-            receiver,
-            property.name,
-            /*location*/
-            property.name
-          ),
-          factory2.cloneNode(property.name)
-        ),
-        /*location*/
-        property
-      ),
-      /*original*/
-      property
-    );
-  }
-  function createExpressionForMethodDeclaration(factory2, method, receiver) {
-    return setOriginalNode(
-      setTextRange(
-        factory2.createAssignment(
-          createMemberAccessForPropertyName(
-            factory2,
-            receiver,
-            method.name,
-            /*location*/
-            method.name
-          ),
-          setOriginalNode(
-            setTextRange(
-              factory2.createFunctionExpression(
-                getModifiers(method),
-                method.asteriskToken,
-                /*name*/
-                void 0,
-                /*typeParameters*/
-                void 0,
-                method.parameters,
-                /*type*/
-                void 0,
-                method.body
-                // TODO: GH#18217
-              ),
-              /*location*/
-              method
-            ),
-            /*original*/
-            method
-          )
-        ),
-        /*location*/
-        method
-      ),
-      /*original*/
-      method
-    );
-  }
-  function createExpressionForObjectLiteralElementLike(factory2, node, property, receiver) {
-    if (property.name && isPrivateIdentifier(property.name)) {
-      Debug.failBadSyntaxKind(property.name, "Private identifiers are not allowed in object literals.");
-    }
-    switch (property.kind) {
-      case 176 /* GetAccessor */:
-      case 177 /* SetAccessor */:
-        return createExpressionForAccessorDeclaration(factory2, node.properties, property, receiver, !!node.multiLine);
-      case 302 /* PropertyAssignment */:
-        return createExpressionForPropertyAssignment(factory2, property, receiver);
-      case 303 /* ShorthandPropertyAssignment */:
-        return createExpressionForShorthandPropertyAssignment(factory2, property, receiver);
-      case 173 /* MethodDeclaration */:
-        return createExpressionForMethodDeclaration(factory2, property, receiver);
-    }
-  }
-  function expandPreOrPostfixIncrementOrDecrementExpression(factory2, node, expression, recordTempVariable, resultVariable) {
-    const operator = node.operator;
-    Debug.assert(operator === 46 /* PlusPlusToken */ || operator === 47 /* MinusMinusToken */, "Expected 'node' to be a pre- or post-increment or pre- or post-decrement expression");
-    const temp = factory2.createTempVariable(recordTempVariable);
-    expression = factory2.createAssignment(temp, expression);
-    setTextRange(expression, node.operand);
-    let operation = isPrefixUnaryExpression(node) ? factory2.createPrefixUnaryExpression(operator, temp) : factory2.createPostfixUnaryExpression(temp, operator);
-    setTextRange(operation, node);
-    if (resultVariable) {
-      operation = factory2.createAssignment(resultVariable, operation);
-      setTextRange(operation, node);
-    }
-    expression = factory2.createComma(expression, operation);
-    setTextRange(expression, node);
-    if (isPostfixUnaryExpression(node)) {
-      expression = factory2.createComma(expression, temp);
-      setTextRange(expression, node);
-    }
-    return expression;
-  }
-  function isInternalName(node) {
-    return (getEmitFlags(node) & 65536 /* InternalName */) !== 0;
-  }
-  function isLocalName(node) {
-    return (getEmitFlags(node) & 32768 /* LocalName */) !== 0;
-  }
-  function isExportName(node) {
-    return (getEmitFlags(node) & 16384 /* ExportName */) !== 0;
-  }
-  function isUseStrictPrologue(node) {
-    return isStringLiteral(node.expression) && node.expression.text === "use strict";
-  }
-  function findUseStrictPrologue(statements) {
-    for (const statement of statements) {
-      if (isPrologueDirective(statement)) {
-        if (isUseStrictPrologue(statement)) {
-          return statement;
-        }
-      } else {
-        break;
-      }
-    }
-    return void 0;
-  }
-  function startsWithUseStrict(statements) {
-    const firstStatement = firstOrUndefined(statements);
-    return firstStatement !== void 0 && isPrologueDirective(firstStatement) && isUseStrictPrologue(firstStatement);
-  }
-  function isCommaExpression(node) {
-    return node.kind === 225 /* BinaryExpression */ && node.operatorToken.kind === 28 /* CommaToken */;
-  }
-  function isCommaSequence(node) {
-    return isCommaExpression(node) || isCommaListExpression(node);
-  }
-  function isJSDocTypeAssertion(node) {
-    return isParenthesizedExpression(node) && isInJSFile(node) && !!getJSDocTypeTag(node);
-  }
-  function getJSDocTypeAssertionType(node) {
-    const type = getJSDocType(node);
-    Debug.assertIsDefined(type);
-    return type;
-  }
-  function isOuterExpression(node, kinds = 15 /* All */) {
-    switch (node.kind) {
-      case 216 /* ParenthesizedExpression */:
-        if (kinds & 16 /* ExcludeJSDocTypeAssertion */ && isJSDocTypeAssertion(node)) {
-          return false;
-        }
-        return (kinds & 1 /* Parentheses */) !== 0;
-      case 215 /* TypeAssertionExpression */:
-      case 233 /* AsExpression */:
-      case 232 /* ExpressionWithTypeArguments */:
-      case 237 /* SatisfiesExpression */:
-        return (kinds & 2 /* TypeAssertions */) !== 0;
-      case 234 /* NonNullExpression */:
-        return (kinds & 4 /* NonNullAssertions */) !== 0;
-      case 359 /* PartiallyEmittedExpression */:
-        return (kinds & 8 /* PartiallyEmittedExpressions */) !== 0;
-    }
-    return false;
-  }
-  function skipOuterExpressions(node, kinds = 15 /* All */) {
-    while (isOuterExpression(node, kinds)) {
-      node = node.expression;
-    }
-    return node;
-  }
-  function walkUpOuterExpressions(node, kinds = 15 /* All */) {
-    let parent2 = node.parent;
-    while (isOuterExpression(parent2, kinds)) {
-      parent2 = parent2.parent;
-      Debug.assert(parent2);
-    }
-    return parent2;
-  }
-  function skipAssertions(node) {
-    return skipOuterExpressions(node, 6 /* Assertions */);
-  }
-  function startOnNewLine(node) {
-    return setStartsOnNewLine(
-      node,
-      /*newLine*/
-      true
-    );
-  }
-  function getExternalHelpersModuleName(node) {
-    const parseNode = getOriginalNode(node, isSourceFile);
-    const emitNode = parseNode && parseNode.emitNode;
-    return emitNode && emitNode.externalHelpersModuleName;
-  }
-  function hasRecordedExternalHelpers(sourceFile) {
-    const parseNode = getOriginalNode(sourceFile, isSourceFile);
-    const emitNode = parseNode && parseNode.emitNode;
-    return !!emitNode && (!!emitNode.externalHelpersModuleName || !!emitNode.externalHelpers);
-  }
-  function createExternalHelpersImportDeclarationIfNeeded(nodeFactory, helperFactory, sourceFile, compilerOptions, hasExportStarsToExportValues, hasImportStar, hasImportDefault) {
-    if (compilerOptions.importHelpers && isEffectiveExternalModule(sourceFile, compilerOptions)) {
-      let namedBindings;
-      const moduleKind = getEmitModuleKind(compilerOptions);
-      if (moduleKind >= 5 /* ES2015 */ && moduleKind <= 99 /* ESNext */ || sourceFile.impliedNodeFormat === 99 /* ESNext */) {
-        const helpers = getEmitHelpers(sourceFile);
-        if (helpers) {
-          const helperNames = [];
-          for (const helper of helpers) {
-            if (!helper.scoped) {
-              const importName = helper.importName;
-              if (importName) {
-                pushIfUnique(helperNames, importName);
-              }
-            }
-          }
-          if (some(helperNames)) {
-            helperNames.sort(compareStringsCaseSensitive);
-            namedBindings = nodeFactory.createNamedImports(
-              map(
-                helperNames,
-                (name) => isFileLevelUniqueName(sourceFile, name) ? nodeFactory.createImportSpecifier(
-                  /*isTypeOnly*/
-                  false,
-                  /*propertyName*/
-                  void 0,
-                  nodeFactory.createIdentifier(name)
-                ) : nodeFactory.createImportSpecifier(
-                  /*isTypeOnly*/
-                  false,
-                  nodeFactory.createIdentifier(name),
-                  helperFactory.getUnscopedHelperName(name)
-                )
-              )
-            );
-            const parseNode = getOriginalNode(sourceFile, isSourceFile);
-            const emitNode = getOrCreateEmitNode(parseNode);
-            emitNode.externalHelpers = true;
-          }
-        }
-      } else {
-        const externalHelpersModuleName = getOrCreateExternalHelpersModuleNameIfNeeded(nodeFactory, sourceFile, compilerOptions, hasExportStarsToExportValues, hasImportStar || hasImportDefault);
-        if (externalHelpersModuleName) {
-          namedBindings = nodeFactory.createNamespaceImport(externalHelpersModuleName);
-        }
-      }
-      if (namedBindings) {
-        const externalHelpersImportDeclaration = nodeFactory.createImportDeclaration(
-          /*modifiers*/
-          void 0,
-          nodeFactory.createImportClause(
-            /*isTypeOnly*/
-            false,
-            /*name*/
-            void 0,
-            namedBindings
-          ),
-          nodeFactory.createStringLiteral(externalHelpersModuleNameText),
-          /*assertClause*/
-          void 0
-        );
-        addInternalEmitFlags(externalHelpersImportDeclaration, 2 /* NeverApplyImportHelper */);
-        return externalHelpersImportDeclaration;
-      }
-    }
-  }
-  function getOrCreateExternalHelpersModuleNameIfNeeded(factory2, node, compilerOptions, hasExportStarsToExportValues, hasImportStarOrImportDefault) {
-    if (compilerOptions.importHelpers && isEffectiveExternalModule(node, compilerOptions)) {
-      const externalHelpersModuleName = getExternalHelpersModuleName(node);
-      if (externalHelpersModuleName) {
-        return externalHelpersModuleName;
-      }
-      const moduleKind = getEmitModuleKind(compilerOptions);
-      let create = (hasExportStarsToExportValues || getESModuleInterop(compilerOptions) && hasImportStarOrImportDefault) && moduleKind !== 4 /* System */ && (moduleKind < 5 /* ES2015 */ || node.impliedNodeFormat === 1 /* CommonJS */);
-      if (!create) {
-        const helpers = getEmitHelpers(node);
-        if (helpers) {
-          for (const helper of helpers) {
-            if (!helper.scoped) {
-              create = true;
-              break;
-            }
-          }
-        }
-      }
-      if (create) {
-        const parseNode = getOriginalNode(node, isSourceFile);
-        const emitNode = getOrCreateEmitNode(parseNode);
-        return emitNode.externalHelpersModuleName || (emitNode.externalHelpersModuleName = factory2.createUniqueName(externalHelpersModuleNameText));
-      }
-    }
-  }
-  function getLocalNameForExternalImport(factory2, node, sourceFile) {
-    const namespaceDeclaration = getNamespaceDeclarationNode(node);
-    if (namespaceDeclaration && !isDefaultImport(node) && !isExportNamespaceAsDefaultDeclaration(node)) {
-      const name = namespaceDeclaration.name;
-      return isGeneratedIdentifier(name) ? name : factory2.createIdentifier(getSourceTextOfNodeFromSourceFile(sourceFile, name) || idText(name));
-    }
-    if (node.kind === 271 /* ImportDeclaration */ && node.importClause) {
-      return factory2.getGeneratedNameForNode(node);
-    }
-    if (node.kind === 277 /* ExportDeclaration */ && node.moduleSpecifier) {
-      return factory2.getGeneratedNameForNode(node);
-    }
-    return void 0;
-  }
-  function getExternalModuleNameLiteral(factory2, importNode, sourceFile, host, resolver, compilerOptions) {
-    const moduleName = getExternalModuleName(importNode);
-    if (moduleName && isStringLiteral(moduleName)) {
-      return tryGetModuleNameFromDeclaration(importNode, host, factory2, resolver, compilerOptions) || tryRenameExternalModule(factory2, moduleName, sourceFile) || factory2.cloneNode(moduleName);
-    }
-    return void 0;
-  }
-  function tryRenameExternalModule(factory2, moduleName, sourceFile) {
-    const rename = sourceFile.renamedDependencies && sourceFile.renamedDependencies.get(moduleName.text);
-    return rename ? factory2.createStringLiteral(rename) : void 0;
-  }
-  function tryGetModuleNameFromFile(factory2, file, host, options) {
-    if (!file) {
-      return void 0;
-    }
-    if (file.moduleName) {
-      return factory2.createStringLiteral(file.moduleName);
-    }
-    if (!file.isDeclarationFile && outFile(options)) {
-      return factory2.createStringLiteral(getExternalModuleNameFromPath(host, file.fileName));
-    }
-    return void 0;
-  }
-  function tryGetModuleNameFromDeclaration(declaration, host, factory2, resolver, compilerOptions) {
-    return tryGetModuleNameFromFile(factory2, resolver.getExternalModuleFileFromDeclaration(declaration), host, compilerOptions);
-  }
-  function getInitializerOfBindingOrAssignmentElement(bindingElement) {
-    if (isDeclarationBindingElement(bindingElement)) {
-      return bindingElement.initializer;
-    }
-    if (isPropertyAssignment(bindingElement)) {
-      const initializer = bindingElement.initializer;
-      return isAssignmentExpression(
-        initializer,
-        /*excludeCompoundAssignment*/
-        true
-      ) ? initializer.right : void 0;
-    }
-    if (isShorthandPropertyAssignment(bindingElement)) {
-      return bindingElement.objectAssignmentInitializer;
-    }
-    if (isAssignmentExpression(
-      bindingElement,
-      /*excludeCompoundAssignment*/
-      true
-    )) {
-      return bindingElement.right;
-    }
-    if (isSpreadElement(bindingElement)) {
-      return getInitializerOfBindingOrAssignmentElement(bindingElement.expression);
-    }
-  }
-  function getTargetOfBindingOrAssignmentElement(bindingElement) {
-    if (isDeclarationBindingElement(bindingElement)) {
-      return bindingElement.name;
-    }
-    if (isObjectLiteralElementLike(bindingElement)) {
-      switch (bindingElement.kind) {
-        case 302 /* PropertyAssignment */:
-          return getTargetOfBindingOrAssignmentElement(bindingElement.initializer);
-        case 303 /* ShorthandPropertyAssignment */:
-          return bindingElement.name;
-        case 304 /* SpreadAssignment */:
-          return getTargetOfBindingOrAssignmentElement(bindingElement.expression);
-      }
-      return void 0;
-    }
-    if (isAssignmentExpression(
-      bindingElement,
-      /*excludeCompoundAssignment*/
-      true
-    )) {
-      return getTargetOfBindingOrAssignmentElement(bindingElement.left);
-    }
-    if (isSpreadElement(bindingElement)) {
-      return getTargetOfBindingOrAssignmentElement(bindingElement.expression);
-    }
-    return bindingElement;
-  }
-  function getRestIndicatorOfBindingOrAssignmentElement(bindingElement) {
-    switch (bindingElement.kind) {
-      case 168 /* Parameter */:
-      case 207 /* BindingElement */:
-        return bindingElement.dotDotDotToken;
-      case 229 /* SpreadElement */:
-      case 304 /* SpreadAssignment */:
-        return bindingElement;
-    }
-    return void 0;
-  }
-  function getPropertyNameOfBindingOrAssignmentElement(bindingElement) {
-    const propertyName = tryGetPropertyNameOfBindingOrAssignmentElement(bindingElement);
-    Debug.assert(!!propertyName || isSpreadAssignment(bindingElement), "Invalid property name for binding element.");
-    return propertyName;
-  }
-  function tryGetPropertyNameOfBindingOrAssignmentElement(bindingElement) {
-    switch (bindingElement.kind) {
-      case 207 /* BindingElement */:
-        if (bindingElement.propertyName) {
-          const propertyName = bindingElement.propertyName;
-          if (isPrivateIdentifier(propertyName)) {
-            return Debug.failBadSyntaxKind(propertyName);
-          }
-          return isComputedPropertyName(propertyName) && isStringOrNumericLiteral(propertyName.expression) ? propertyName.expression : propertyName;
-        }
-        break;
-      case 302 /* PropertyAssignment */:
-        if (bindingElement.name) {
-          const propertyName = bindingElement.name;
-          if (isPrivateIdentifier(propertyName)) {
-            return Debug.failBadSyntaxKind(propertyName);
-          }
-          return isComputedPropertyName(propertyName) && isStringOrNumericLiteral(propertyName.expression) ? propertyName.expression : propertyName;
-        }
-        break;
-      case 304 /* SpreadAssignment */:
-        if (bindingElement.name && isPrivateIdentifier(bindingElement.name)) {
-          return Debug.failBadSyntaxKind(bindingElement.name);
-        }
-        return bindingElement.name;
-    }
-    const target = getTargetOfBindingOrAssignmentElement(bindingElement);
-    if (target && isPropertyName(target)) {
-      return target;
-    }
-  }
-  function isStringOrNumericLiteral(node) {
-    const kind = node.kind;
-    return kind === 11 /* StringLiteral */ || kind === 9 /* NumericLiteral */;
-  }
-  function getElementsOfBindingOrAssignmentPattern(name) {
-    switch (name.kind) {
-      case 205 /* ObjectBindingPattern */:
-      case 206 /* ArrayBindingPattern */:
-      case 208 /* ArrayLiteralExpression */:
-        return name.elements;
-      case 209 /* ObjectLiteralExpression */:
-        return name.properties;
-    }
-  }
-  function getJSDocTypeAliasName(fullName) {
-    if (fullName) {
-      let rightNode = fullName;
-      while (true) {
-        if (isIdentifier(rightNode) || !rightNode.body) {
-          return isIdentifier(rightNode) ? rightNode : rightNode.name;
-        }
-        rightNode = rightNode.body;
-      }
-    }
-  }
-  function canHaveIllegalType(node) {
-    const kind = node.kind;
-    return kind === 175 /* Constructor */ || kind === 177 /* SetAccessor */;
-  }
-  function canHaveIllegalTypeParameters(node) {
-    const kind = node.kind;
-    return kind === 175 /* Constructor */ || kind === 176 /* GetAccessor */ || kind === 177 /* SetAccessor */;
-  }
-  function canHaveIllegalDecorators(node) {
-    const kind = node.kind;
-    return kind === 302 /* PropertyAssignment */ || kind === 303 /* ShorthandPropertyAssignment */ || kind === 261 /* FunctionDeclaration */ || kind === 175 /* Constructor */ || kind === 180 /* IndexSignature */ || kind === 174 /* ClassStaticBlockDeclaration */ || kind === 281 /* MissingDeclaration */ || kind === 242 /* VariableStatement */ || kind === 263 /* InterfaceDeclaration */ || kind === 264 /* TypeAliasDeclaration */ || kind === 265 /* EnumDeclaration */ || kind === 266 /* ModuleDeclaration */ || kind === 270 /* ImportEqualsDeclaration */ || kind === 271 /* ImportDeclaration */ || kind === 269 /* NamespaceExportDeclaration */ || kind === 277 /* ExportDeclaration */ || kind === 276 /* ExportAssignment */;
-  }
-  function canHaveIllegalModifiers(node) {
-    const kind = node.kind;
-    return kind === 174 /* ClassStaticBlockDeclaration */ || kind === 302 /* PropertyAssignment */ || kind === 303 /* ShorthandPropertyAssignment */ || kind === 281 /* MissingDeclaration */ || kind === 269 /* NamespaceExportDeclaration */;
-  }
-  function isQuestionOrExclamationToken(node) {
-    return isQuestionToken(node) || isExclamationToken(node);
-  }
-  function isIdentifierOrThisTypeNode(node) {
-    return isIdentifier(node) || isThisTypeNode(node);
-  }
-  function isReadonlyKeywordOrPlusOrMinusToken(node) {
-    return isReadonlyKeyword(node) || isPlusToken(node) || isMinusToken(node);
-  }
-  function isQuestionOrPlusOrMinusToken(node) {
-    return isQuestionToken(node) || isPlusToken(node) || isMinusToken(node);
-  }
-  function isModuleName(node) {
-    return isIdentifier(node) || isStringLiteral(node);
-  }
-  function isLiteralTypeLikeExpression(node) {
-    const kind = node.kind;
-    return kind === 106 /* NullKeyword */ || kind === 112 /* TrueKeyword */ || kind === 97 /* FalseKeyword */ || isLiteralExpression(node) || isPrefixUnaryExpression(node);
-  }
-  function isExponentiationOperator(kind) {
-    return kind === 43 /* AsteriskAsteriskToken */;
-  }
-  function isMultiplicativeOperator(kind) {
-    return kind === 42 /* AsteriskToken */ || kind === 44 /* SlashToken */ || kind === 45 /* PercentToken */;
-  }
-  function isMultiplicativeOperatorOrHigher(kind) {
-    return isExponentiationOperator(kind) || isMultiplicativeOperator(kind);
-  }
-  function isAdditiveOperator(kind) {
-    return kind === 40 /* PlusToken */ || kind === 41 /* MinusToken */;
-  }
-  function isAdditiveOperatorOrHigher(kind) {
-    return isAdditiveOperator(kind) || isMultiplicativeOperatorOrHigher(kind);
-  }
-  function isShiftOperator(kind) {
-    return kind === 48 /* LessThanLessThanToken */ || kind === 49 /* GreaterThanGreaterThanToken */ || kind === 50 /* GreaterThanGreaterThanGreaterThanToken */;
-  }
-  function isShiftOperatorOrHigher(kind) {
-    return isShiftOperator(kind) || isAdditiveOperatorOrHigher(kind);
-  }
-  function isRelationalOperator(kind) {
-    return kind === 30 /* LessThanToken */ || kind === 33 /* LessThanEqualsToken */ || kind === 32 /* GreaterThanToken */ || kind === 34 /* GreaterThanEqualsToken */ || kind === 104 /* InstanceOfKeyword */ || kind === 103 /* InKeyword */;
-  }
-  function isRelationalOperatorOrHigher(kind) {
-    return isRelationalOperator(kind) || isShiftOperatorOrHigher(kind);
-  }
-  function isEqualityOperator(kind) {
-    return kind === 35 /* EqualsEqualsToken */ || kind === 37 /* EqualsEqualsEqualsToken */ || kind === 36 /* ExclamationEqualsToken */ || kind === 38 /* ExclamationEqualsEqualsToken */;
-  }
-  function isEqualityOperatorOrHigher(kind) {
-    return isEqualityOperator(kind) || isRelationalOperatorOrHigher(kind);
-  }
-  function isBitwiseOperator(kind) {
-    return kind === 51 /* AmpersandToken */ || kind === 52 /* BarToken */ || kind === 53 /* CaretToken */;
-  }
-  function isBitwiseOperatorOrHigher(kind) {
-    return isBitwiseOperator(kind) || isEqualityOperatorOrHigher(kind);
-  }
-  function isLogicalOperator2(kind) {
-    return kind === 56 /* AmpersandAmpersandToken */ || kind === 57 /* BarBarToken */;
-  }
-  function isLogicalOperatorOrHigher(kind) {
-    return isLogicalOperator2(kind) || isBitwiseOperatorOrHigher(kind);
-  }
-  function isAssignmentOperatorOrHigher(kind) {
-    return kind === 61 /* QuestionQuestionToken */ || isLogicalOperatorOrHigher(kind) || isAssignmentOperator(kind);
-  }
-  function isBinaryOperator(kind) {
-    return isAssignmentOperatorOrHigher(kind) || kind === 28 /* CommaToken */;
-  }
-  function isBinaryOperatorToken(node) {
-    return isBinaryOperator(node.kind);
-  }
-  function createBinaryExpressionTrampoline(onEnter, onLeft, onOperator, onRight, onExit, foldState) {
-    const machine = new BinaryExpressionStateMachine(onEnter, onLeft, onOperator, onRight, onExit, foldState);
-    return trampoline;
-    function trampoline(node, outerState) {
-      const resultHolder = { value: void 0 };
-      const stateStack = [BinaryExpressionState.enter];
-      const nodeStack = [node];
-      const userStateStack = [void 0];
-      let stackIndex = 0;
-      while (stateStack[stackIndex] !== BinaryExpressionState.done) {
-        stackIndex = stateStack[stackIndex](machine, stackIndex, stateStack, nodeStack, userStateStack, resultHolder, outerState);
-      }
-      Debug.assertEqual(stackIndex, 0);
-      return resultHolder.value;
-    }
-  }
-  function isExportOrDefaultKeywordKind(kind) {
-    return kind === 95 /* ExportKeyword */ || kind === 90 /* DefaultKeyword */;
-  }
-  function isExportOrDefaultModifier(node) {
-    const kind = node.kind;
-    return isExportOrDefaultKeywordKind(kind);
-  }
-  function isNonExportDefaultModifier(node) {
-    const kind = node.kind;
-    return isModifierKind(kind) && !isExportOrDefaultKeywordKind(kind);
-  }
-  function elideNodes(factory2, nodes) {
-    if (nodes === void 0)
-      return void 0;
-    if (nodes.length === 0)
-      return nodes;
-    return setTextRange(factory2.createNodeArray([], nodes.hasTrailingComma), nodes);
-  }
-  function getNodeForGeneratedName(name) {
-    var _a;
-    const autoGenerate = name.emitNode.autoGenerate;
-    if (autoGenerate.flags & 4 /* Node */) {
-      const autoGenerateId = autoGenerate.id;
-      let node = name;
-      let original = node.original;
-      while (original) {
-        node = original;
-        const autoGenerate2 = (_a = node.emitNode) == null ? void 0 : _a.autoGenerate;
-        if (isMemberName(node) && (autoGenerate2 === void 0 || !!(autoGenerate2.flags & 4 /* Node */) && autoGenerate2.id !== autoGenerateId)) {
-          break;
-        }
-        original = node.original;
-      }
-      return node;
-    }
-    return name;
-  }
-  function formatGeneratedNamePart(part, generateName) {
-    return typeof part === "object" ? formatGeneratedName(
-      /*privateName*/
-      false,
-      part.prefix,
-      part.node,
-      part.suffix,
-      generateName
-    ) : typeof part === "string" ? part.length > 0 && part.charCodeAt(0) === 35 /* hash */ ? part.slice(1) : part : "";
-  }
-  function formatIdentifier(name, generateName) {
-    return typeof name === "string" ? name : formatIdentifierWorker(name, Debug.checkDefined(generateName));
-  }
-  function formatIdentifierWorker(node, generateName) {
-    return isGeneratedPrivateIdentifier(node) ? generateName(node).slice(1) : isGeneratedIdentifier(node) ? generateName(node) : isPrivateIdentifier(node) ? node.escapedText.slice(1) : idText(node);
-  }
-  function formatGeneratedName(privateName, prefix, baseName, suffix, generateName) {
-    prefix = formatGeneratedNamePart(prefix, generateName);
-    suffix = formatGeneratedNamePart(suffix, generateName);
-    baseName = formatIdentifier(baseName, generateName);
-    return `${privateName ? "#" : ""}${prefix}${baseName}${suffix}`;
-  }
-  function createAccessorPropertyBackingField(factory2, node, modifiers, initializer) {
-    return factory2.updatePropertyDeclaration(
-      node,
-      modifiers,
-      factory2.getGeneratedPrivateNameForNode(
-        node.name,
-        /*prefix*/
-        void 0,
-        "_accessor_storage"
-      ),
-      /*questionOrExclamationToken*/
-      void 0,
-      /*type*/
-      void 0,
-      initializer
-    );
-  }
-  function createAccessorPropertyGetRedirector(factory2, node, modifiers, name) {
-    return factory2.createGetAccessorDeclaration(
-      modifiers,
-      name,
-      [],
-      /*type*/
-      void 0,
-      factory2.createBlock([
-        factory2.createReturnStatement(
-          factory2.createPropertyAccessExpression(
-            factory2.createThis(),
-            factory2.getGeneratedPrivateNameForNode(
-              node.name,
-              /*prefix*/
-              void 0,
-              "_accessor_storage"
-            )
-          )
-        )
-      ])
-    );
-  }
-  function createAccessorPropertySetRedirector(factory2, node, modifiers, name) {
-    return factory2.createSetAccessorDeclaration(
-      modifiers,
-      name,
-      [factory2.createParameterDeclaration(
-        /*modifiers*/
-        void 0,
-        /*dotDotDotToken*/
-        void 0,
-        "value"
-      )],
-      factory2.createBlock([
-        factory2.createExpressionStatement(
-          factory2.createAssignment(
-            factory2.createPropertyAccessExpression(
-              factory2.createThis(),
-              factory2.getGeneratedPrivateNameForNode(
-                node.name,
-                /*prefix*/
-                void 0,
-                "_accessor_storage"
-              )
-            ),
-            factory2.createIdentifier("value")
-          )
-        )
-      ])
-    );
-  }
-  function findComputedPropertyNameCacheAssignment(name) {
-    let node = name.expression;
-    while (true) {
-      node = skipOuterExpressions(node);
-      if (isCommaListExpression(node)) {
-        node = last(node.elements);
-        continue;
-      }
-      if (isCommaExpression(node)) {
-        node = node.right;
-        continue;
-      }
-      if (isAssignmentExpression(
-        node,
-        /*excludeCompoundAssignment*/
-        true
-      ) && isGeneratedIdentifier(node.left)) {
-        return node;
-      }
-      break;
-    }
-  }
-  function isSyntheticParenthesizedExpression(node) {
-    return isParenthesizedExpression(node) && nodeIsSynthesized(node) && !node.emitNode;
-  }
-  function flattenCommaListWorker(node, expressions) {
-    if (isSyntheticParenthesizedExpression(node)) {
-      flattenCommaListWorker(node.expression, expressions);
-    } else if (isCommaExpression(node)) {
-      flattenCommaListWorker(node.left, expressions);
-      flattenCommaListWorker(node.right, expressions);
-    } else if (isCommaListExpression(node)) {
-      for (const child of node.elements) {
-        flattenCommaListWorker(child, expressions);
-      }
-    } else {
-      expressions.push(node);
-    }
-  }
-  function flattenCommaList(node) {
-    const expressions = [];
-    flattenCommaListWorker(node, expressions);
-    return expressions;
-  }
-  function containsObjectRestOrSpread(node) {
-    if (node.transformFlags & 65536 /* ContainsObjectRestOrSpread */)
-      return true;
-    if (node.transformFlags & 128 /* ContainsES2018 */) {
-      for (const element of getElementsOfBindingOrAssignmentPattern(node)) {
-        const target = getTargetOfBindingOrAssignmentElement(element);
-        if (target && isAssignmentPattern(target)) {
-          if (target.transformFlags & 65536 /* ContainsObjectRestOrSpread */) {
-            return true;
-          }
-          if (target.transformFlags & 128 /* ContainsES2018 */) {
-            if (containsObjectRestOrSpread(target))
-              return true;
-          }
-        }
-      }
-    }
-    return false;
-  }
-  var BinaryExpressionState, BinaryExpressionStateMachine;
-  var init_utilities2 = __esm({
-    "src/compiler/factory/utilities.ts"() {
-      "use strict";
-      init_ts2();
-      ((BinaryExpressionState2) => {
-        function enter(machine, stackIndex, stateStack, nodeStack, userStateStack, _resultHolder, outerState) {
-          const prevUserState = stackIndex > 0 ? userStateStack[stackIndex - 1] : void 0;
-          Debug.assertEqual(stateStack[stackIndex], enter);
-          userStateStack[stackIndex] = machine.onEnter(nodeStack[stackIndex], prevUserState, outerState);
-          stateStack[stackIndex] = nextState(machine, enter);
-          return stackIndex;
-        }
-        BinaryExpressionState2.enter = enter;
-        function left(machine, stackIndex, stateStack, nodeStack, userStateStack, _resultHolder, _outerState) {
-          Debug.assertEqual(stateStack[stackIndex], left);
-          Debug.assertIsDefined(machine.onLeft);
-          stateStack[stackIndex] = nextState(machine, left);
-          const nextNode = machine.onLeft(nodeStack[stackIndex].left, userStateStack[stackIndex], nodeStack[stackIndex]);
-          if (nextNode) {
-            checkCircularity(stackIndex, nodeStack, nextNode);
-            return pushStack(stackIndex, stateStack, nodeStack, userStateStack, nextNode);
-          }
-          return stackIndex;
-        }
-        BinaryExpressionState2.left = left;
-        function operator(machine, stackIndex, stateStack, nodeStack, userStateStack, _resultHolder, _outerState) {
-          Debug.assertEqual(stateStack[stackIndex], operator);
-          Debug.assertIsDefined(machine.onOperator);
-          stateStack[stackIndex] = nextState(machine, operator);
-          machine.onOperator(nodeStack[stackIndex].operatorToken, userStateStack[stackIndex], nodeStack[stackIndex]);
-          return stackIndex;
-        }
-        BinaryExpressionState2.operator = operator;
-        function right(machine, stackIndex, stateStack, nodeStack, userStateStack, _resultHolder, _outerState) {
-          Debug.assertEqual(stateStack[stackIndex], right);
-          Debug.assertIsDefined(machine.onRight);
-          stateStack[stackIndex] = nextState(machine, right);
-          const nextNode = machine.onRight(nodeStack[stackIndex].right, userStateStack[stackIndex], nodeStack[stackIndex]);
-          if (nextNode) {
-            checkCircularity(stackIndex, nodeStack, nextNode);
-            return pushStack(stackIndex, stateStack, nodeStack, userStateStack, nextNode);
-          }
-          return stackIndex;
-        }
-        BinaryExpressionState2.right = right;
-        function exit(machine, stackIndex, stateStack, nodeStack, userStateStack, resultHolder, _outerState) {
-          Debug.assertEqual(stateStack[stackIndex], exit);
-          stateStack[stackIndex] = nextState(machine, exit);
-          const result = machine.onExit(nodeStack[stackIndex], userStateStack[stackIndex]);
-          if (stackIndex > 0) {
-            stackIndex--;
-            if (machine.foldState) {
-              const side = stateStack[stackIndex] === exit ? "right" : "left";
-              userStateStack[stackIndex] = machine.foldState(userStateStack[stackIndex], result, side);
-            }
-          } else {
-            resultHolder.value = result;
-          }
-          return stackIndex;
-        }
-        BinaryExpressionState2.exit = exit;
-        function done(_machine, stackIndex, stateStack, _nodeStack, _userStateStack, _resultHolder, _outerState) {
-          Debug.assertEqual(stateStack[stackIndex], done);
-          return stackIndex;
-        }
-        BinaryExpressionState2.done = done;
-        function nextState(machine, currentState) {
-          switch (currentState) {
-            case enter:
-              if (machine.onLeft)
-                return left;
-            case left:
-              if (machine.onOperator)
-                return operator;
-            case operator:
-              if (machine.onRight)
-                return right;
-            case right:
-              return exit;
-            case exit:
-              return done;
-            case done:
-              return done;
-            default:
-              Debug.fail("Invalid state");
-          }
-        }
-        BinaryExpressionState2.nextState = nextState;
-        function pushStack(stackIndex, stateStack, nodeStack, userStateStack, node) {
-          stackIndex++;
-          stateStack[stackIndex] = enter;
-          nodeStack[stackIndex] = node;
-          userStateStack[stackIndex] = void 0;
-          return stackIndex;
-        }
-        function checkCircularity(stackIndex, nodeStack, node) {
-          if (Debug.shouldAssert(2 /* Aggressive */)) {
-            while (stackIndex >= 0) {
-              Debug.assert(nodeStack[stackIndex] !== node, "Circular traversal detected.");
-              stackIndex--;
-            }
-          }
-        }
-      })(BinaryExpressionState || (BinaryExpressionState = {}));
-      BinaryExpressionStateMachine = class {
-        constructor(onEnter, onLeft, onOperator, onRight, onExit, foldState) {
-          this.onEnter = onEnter;
-          this.onLeft = onLeft;
-          this.onOperator = onOperator;
-          this.onRight = onRight;
-          this.onExit = onExit;
-          this.foldState = foldState;
-        }
-      };
-    }
-  });
-
-  // src/compiler/factory/utilitiesPublic.ts
-  function setTextRange(range, location) {
-    return location ? setTextRangePosEnd(range, location.pos, location.end) : range;
-  }
-  function canHaveModifiers(node) {
-    const kind = node.kind;
-    return kind === 167 /* TypeParameter */ || kind === 168 /* Parameter */ || kind === 170 /* PropertySignature */ || kind === 171 /* PropertyDeclaration */ || kind === 172 /* MethodSignature */ || kind === 173 /* MethodDeclaration */ || kind === 175 /* Constructor */ || kind === 176 /* GetAccessor */ || kind === 177 /* SetAccessor */ || kind === 180 /* IndexSignature */ || kind === 184 /* ConstructorType */ || kind === 217 /* FunctionExpression */ || kind === 218 /* ArrowFunction */ || kind === 230 /* ClassExpression */ || kind === 242 /* VariableStatement */ || kind === 261 /* FunctionDeclaration */ || kind === 262 /* ClassDeclaration */ || kind === 263 /* InterfaceDeclaration */ || kind === 264 /* TypeAliasDeclaration */ || kind === 265 /* EnumDeclaration */ || kind === 266 /* ModuleDeclaration */ || kind === 270 /* ImportEqualsDeclaration */ || kind === 271 /* ImportDeclaration */ || kind === 276 /* ExportAssignment */ || kind === 277 /* ExportDeclaration */;
-  }
-  function canHaveDecorators(node) {
-    const kind = node.kind;
-    return kind === 168 /* Parameter */ || kind === 171 /* PropertyDeclaration */ || kind === 173 /* MethodDeclaration */ || kind === 176 /* GetAccessor */ || kind === 177 /* SetAccessor */ || kind === 230 /* ClassExpression */ || kind === 262 /* ClassDeclaration */;
-  }
-  var init_utilitiesPublic2 = __esm({
-    "src/compiler/factory/utilitiesPublic.ts"() {
-      "use strict";
-      init_ts2();
-    }
-  });
-
-  // src/compiler/parser.ts
-  function visitNode2(cbNode, node) {
-    return node && cbNode(node);
-  }
-  function visitNodes(cbNode, cbNodes, nodes) {
-    if (nodes) {
-      if (cbNodes) {
-        return cbNodes(nodes);
-      }
-      for (const node of nodes) {
-        const result = cbNode(node);
-        if (result) {
-          return result;
-        }
-      }
-    }
-  }
-  function isJSDocLikeText(text, start) {
-    return text.charCodeAt(start + 1) === 42 /* asterisk */ && text.charCodeAt(start + 2) === 42 /* asterisk */ && text.charCodeAt(start + 3) !== 47 /* slash */;
-  }
-  function isFileProbablyExternalModule(sourceFile) {
-    return forEach(sourceFile.statements, isAnExternalModuleIndicatorNode) || getImportMetaIfNecessary(sourceFile);
-  }
-  function isAnExternalModuleIndicatorNode(node) {
-    return canHaveModifiers(node) && hasModifierOfKind(node, 95 /* ExportKeyword */) || isImportEqualsDeclaration(node) && isExternalModuleReference(node.moduleReference) || isImportDeclaration(node) || isExportAssignment(node) || isExportDeclaration(node) ? node : void 0;
-  }
-  function getImportMetaIfNecessary(sourceFile) {
-    return sourceFile.flags & 4194304 /* PossiblyContainsImportMeta */ ? walkTreeForImportMeta(sourceFile) : void 0;
-  }
-  function walkTreeForImportMeta(node) {
-    return isImportMeta2(node) ? node : forEachChild(node, walkTreeForImportMeta);
-  }
-  function hasModifierOfKind(node, kind) {
-    return some(node.modifiers, (m) => m.kind === kind);
-  }
-  function isImportMeta2(node) {
-    return isMetaProperty(node) && node.keywordToken === 102 /* ImportKeyword */ && node.name.escapedText === "meta";
-  }
-  function forEachChildInCallOrConstructSignature(node, cbNode, cbNodes) {
-    return visitNodes(cbNode, cbNodes, node.typeParameters) || visitNodes(cbNode, cbNodes, node.parameters) || visitNode2(cbNode, node.type);
-  }
-  function forEachChildInUnionOrIntersectionType(node, cbNode, cbNodes) {
-    return visitNodes(cbNode, cbNodes, node.types);
-  }
-  function forEachChildInParenthesizedTypeOrTypeOperator(node, cbNode, _cbNodes) {
-    return visitNode2(cbNode, node.type);
-  }
-  function forEachChildInObjectOrArrayBindingPattern(node, cbNode, cbNodes) {
-    return visitNodes(cbNode, cbNodes, node.elements);
-  }
-  function forEachChildInCallOrNewExpression(node, cbNode, cbNodes) {
-    return visitNode2(cbNode, node.expression) || // TODO: should we separate these branches out?
-    visitNode2(cbNode, node.questionDotToken) || visitNodes(cbNode, cbNodes, node.typeArguments) || visitNodes(cbNode, cbNodes, node.arguments);
-  }
-  function forEachChildInBlock(node, cbNode, cbNodes) {
-    return visitNodes(cbNode, cbNodes, node.statements);
-  }
-  function forEachChildInContinueOrBreakStatement(node, cbNode, _cbNodes) {
-    return visitNode2(cbNode, node.label);
-  }
-  function forEachChildInClassDeclarationOrExpression(node, cbNode, cbNodes) {
-    return visitNodes(cbNode, cbNodes, node.modifiers) || visitNode2(cbNode, node.name) || visitNodes(cbNode, cbNodes, node.typeParameters) || visitNodes(cbNode, cbNodes, node.heritageClauses) || visitNodes(cbNode, cbNodes, node.members);
-  }
-  function forEachChildInNamedImportsOrExports(node, cbNode, cbNodes) {
-    return visitNodes(cbNode, cbNodes, node.elements);
-  }
-  function forEachChildInImportOrExportSpecifier(node, cbNode, _cbNodes) {
-    return visitNode2(cbNode, node.propertyName) || visitNode2(cbNode, node.name);
-  }
-  function forEachChildInJsxOpeningOrSelfClosingElement(node, cbNode, cbNodes) {
-    return visitNode2(cbNode, node.tagName) || visitNodes(cbNode, cbNodes, node.typeArguments) || visitNode2(cbNode, node.attributes);
-  }
-  function forEachChildInOptionalRestOrJSDocParameterModifier(node, cbNode, _cbNodes) {
-    return visitNode2(cbNode, node.type);
-  }
-  function forEachChildInJSDocParameterOrPropertyTag(node, cbNode, cbNodes) {
-    return visitNode2(cbNode, node.tagName) || (node.isNameFirst ? visitNode2(cbNode, node.name) || visitNode2(cbNode, node.typeExpression) : visitNode2(cbNode, node.typeExpression) || visitNode2(cbNode, node.name)) || (typeof node.comment === "string" ? void 0 : visitNodes(cbNode, cbNodes, node.comment));
-  }
-  function forEachChildInJSDocTypeLikeTag(node, cbNode, cbNodes) {
-    return visitNode2(cbNode, node.tagName) || visitNode2(cbNode, node.typeExpression) || (typeof node.comment === "string" ? void 0 : visitNodes(cbNode, cbNodes, node.comment));
-  }
-  function forEachChildInJSDocLinkCodeOrPlain(node, cbNode, _cbNodes) {
-    return visitNode2(cbNode, node.name);
-  }
-  function forEachChildInJSDocTag(node, cbNode, cbNodes) {
-    return visitNode2(cbNode, node.tagName) || (typeof node.comment === "string" ? void 0 : visitNodes(cbNode, cbNodes, node.comment));
-  }
-  function forEachChildInPartiallyEmittedExpression(node, cbNode, _cbNodes) {
-    return visitNode2(cbNode, node.expression);
-  }
-  function forEachChild(node, cbNode, cbNodes) {
-    if (node === void 0 || node.kind <= 164 /* LastToken */) {
-      return;
-    }
-    const fn = forEachChildTable[node.kind];
-    return fn === void 0 ? void 0 : fn(node, cbNode, cbNodes);
-  }
-  function forEachChildRecursively(rootNode, cbNode, cbNodes) {
-    const queue = gatherPossibleChildren(rootNode);
-    const parents = [];
-    while (parents.length < queue.length) {
-      parents.push(rootNode);
-    }
-    while (queue.length !== 0) {
-      const current = queue.pop();
-      const parent2 = parents.pop();
-      if (isArray(current)) {
-        if (cbNodes) {
-          const res = cbNodes(current, parent2);
-          if (res) {
-            if (res === "skip")
-              continue;
-            return res;
-          }
-        }
-        for (let i = current.length - 1; i >= 0; --i) {
-          queue.push(current[i]);
-          parents.push(parent2);
-        }
-      } else {
-        const res = cbNode(current, parent2);
-        if (res) {
-          if (res === "skip")
-            continue;
-          return res;
-        }
-        if (current.kind >= 165 /* FirstNode */) {
-          for (const child of gatherPossibleChildren(current)) {
-            queue.push(child);
-            parents.push(current);
-          }
-        }
-      }
-    }
-  }
-  function gatherPossibleChildren(node) {
-    const children = [];
-    forEachChild(node, addWorkItem, addWorkItem);
-    return children;
-    function addWorkItem(n) {
-      children.unshift(n);
-    }
-  }
-  function setExternalModuleIndicator(sourceFile) {
-    sourceFile.externalModuleIndicator = isFileProbablyExternalModule(sourceFile);
-  }
-  function createSourceFile(fileName, sourceText, languageVersionOrOptions, setParentNodes = false, scriptKind) {
-    var _a, _b, _c, _d;
-    (_a = tracing) == null ? void 0 : _a.push(
-      tracing.Phase.Parse,
-      "createSourceFile",
-      { path: fileName },
-      /*separateBeginAndEnd*/
-      true
-    );
-    mark("beforeParse");
-    let result;
-    (_b = perfLogger) == null ? void 0 : _b.logStartParseSourceFile(fileName);
-    const {
-      languageVersion,
-      setExternalModuleIndicator: overrideSetExternalModuleIndicator,
-      impliedNodeFormat: format
-    } = typeof languageVersionOrOptions === "object" ? languageVersionOrOptions : { languageVersion: languageVersionOrOptions };
-    if (languageVersion === 100 /* JSON */) {
-      result = Parser.parseSourceFile(
-        fileName,
-        sourceText,
-        languageVersion,
-        /*syntaxCursor*/
-        void 0,
-        setParentNodes,
-        6 /* JSON */,
-        noop
-      );
-    } else {
-      const setIndicator = format === void 0 ? overrideSetExternalModuleIndicator : (file) => {
-        file.impliedNodeFormat = format;
-        return (overrideSetExternalModuleIndicator || setExternalModuleIndicator)(file);
-      };
-      result = Parser.parseSourceFile(
-        fileName,
-        sourceText,
-        languageVersion,
-        /*syntaxCursor*/
-        void 0,
-        setParentNodes,
-        scriptKind,
-        setIndicator
-      );
-    }
-    (_c = perfLogger) == null ? void 0 : _c.logStopParseSourceFile();
-    mark("afterParse");
-    measure("Parse", "beforeParse", "afterParse");
-    (_d = tracing) == null ? void 0 : _d.pop();
-    return result;
-  }
-  function parseIsolatedEntityName(text, languageVersion) {
-    return Parser.parseIsolatedEntityName(text, languageVersion);
-  }
-  function parseJsonText(fileName, sourceText) {
-    return Parser.parseJsonText(fileName, sourceText);
-  }
-  function isExternalModule(file) {
-    return file.externalModuleIndicator !== void 0;
-  }
-  function updateSourceFile(sourceFile, newText, textChangeRange, aggressiveChecks = false) {
-    const newSourceFile = IncrementalParser.updateSourceFile(sourceFile, newText, textChangeRange, aggressiveChecks);
-    newSourceFile.flags |= sourceFile.flags & 6291456 /* PermanentlySetIncrementalFlags */;
-    return newSourceFile;
-  }
-  function parseIsolatedJSDocComment(content, start, length2) {
-    const result = Parser.JSDocParser.parseIsolatedJSDocComment(content, start, length2);
-    if (result && result.jsDoc) {
-      Parser.fixupParentReferences(result.jsDoc);
-    }
-    return result;
-  }
-  function parseJSDocTypeExpressionForTests(content, start, length2) {
-    return Parser.JSDocParser.parseJSDocTypeExpressionForTests(content, start, length2);
-  }
-  function isDeclarationFileName(fileName) {
-    return fileExtensionIsOneOf(fileName, supportedDeclarationExtensions) || fileExtensionIs(fileName, ".ts" /* Ts */) && stringContains(getBaseFileName(fileName), ".d.");
-  }
-  function parseResolutionMode(mode, pos, end, reportDiagnostic) {
-    if (!mode) {
-      return void 0;
-    }
-    if (mode === "import") {
-      return 99 /* ESNext */;
-    }
-    if (mode === "require") {
-      return 1 /* CommonJS */;
-    }
-    reportDiagnostic(pos, end - pos, Diagnostics.resolution_mode_should_be_either_require_or_import);
-    return void 0;
-  }
-  function processCommentPragmas(context, sourceText) {
-    const pragmas = [];
-    for (const range of getLeadingCommentRanges(sourceText, 0) || emptyArray) {
-      const comment = sourceText.substring(range.pos, range.end);
-      extractPragmas(pragmas, range, comment);
-    }
-    context.pragmas = /* @__PURE__ */ new Map();
-    for (const pragma of pragmas) {
-      if (context.pragmas.has(pragma.name)) {
-        const currentValue = context.pragmas.get(pragma.name);
-        if (currentValue instanceof Array) {
-          currentValue.push(pragma.args);
-        } else {
-          context.pragmas.set(pragma.name, [currentValue, pragma.args]);
-        }
-        continue;
-      }
-      context.pragmas.set(pragma.name, pragma.args);
-    }
-  }
-  function processPragmasIntoFields(context, reportDiagnostic) {
-    context.checkJsDirective = void 0;
-    context.referencedFiles = [];
-    context.typeReferenceDirectives = [];
-    context.libReferenceDirectives = [];
-    context.amdDependencies = [];
-    context.hasNoDefaultLib = false;
-    context.pragmas.forEach((entryOrList, key) => {
-      switch (key) {
-        case "reference": {
-          const referencedFiles = context.referencedFiles;
-          const typeReferenceDirectives = context.typeReferenceDirectives;
-          const libReferenceDirectives = context.libReferenceDirectives;
-          forEach(toArray(entryOrList), (arg) => {
-            const { types, lib, path, ["resolution-mode"]: res } = arg.arguments;
-            if (arg.arguments["no-default-lib"]) {
-              context.hasNoDefaultLib = true;
-            } else if (types) {
-              const parsed = parseResolutionMode(res, types.pos, types.end, reportDiagnostic);
-              typeReferenceDirectives.push({ pos: types.pos, end: types.end, fileName: types.value, ...parsed ? { resolutionMode: parsed } : {} });
-            } else if (lib) {
-              libReferenceDirectives.push({ pos: lib.pos, end: lib.end, fileName: lib.value });
-            } else if (path) {
-              referencedFiles.push({ pos: path.pos, end: path.end, fileName: path.value });
-            } else {
-              reportDiagnostic(arg.range.pos, arg.range.end - arg.range.pos, Diagnostics.Invalid_reference_directive_syntax);
-            }
-          });
-          break;
-        }
-        case "amd-dependency": {
-          context.amdDependencies = map(
-            toArray(entryOrList),
-            (x) => ({ name: x.arguments.name, path: x.arguments.path })
-          );
-          break;
-        }
-        case "amd-module": {
-          if (entryOrList instanceof Array) {
-            for (const entry of entryOrList) {
-              if (context.moduleName) {
-                reportDiagnostic(entry.range.pos, entry.range.end - entry.range.pos, Diagnostics.An_AMD_module_cannot_have_multiple_name_assignments);
-              }
-              context.moduleName = entry.arguments.name;
-            }
-          } else {
-            context.moduleName = entryOrList.arguments.name;
-          }
-          break;
-        }
-        case "ts-nocheck":
-        case "ts-check": {
-          forEach(toArray(entryOrList), (entry) => {
-            if (!context.checkJsDirective || entry.range.pos > context.checkJsDirective.pos) {
-              context.checkJsDirective = {
-                enabled: key === "ts-check",
-                end: entry.range.end,
-                pos: entry.range.pos
-              };
-            }
-          });
-          break;
-        }
-        case "jsx":
-        case "jsxfrag":
-        case "jsximportsource":
-        case "jsxruntime":
-          return;
-        default:
-          Debug.fail("Unhandled pragma kind");
-      }
-    });
-  }
-  function getNamedArgRegEx(name) {
-    if (namedArgRegExCache.has(name)) {
-      return namedArgRegExCache.get(name);
-    }
-    const result = new RegExp(`(\\s${name}\\s*=\\s*)(?:(?:'([^']*)')|(?:"([^"]*)"))`, "im");
-    namedArgRegExCache.set(name, result);
-    return result;
-  }
-  function extractPragmas(pragmas, range, text) {
-    const tripleSlash = range.kind === 2 /* SingleLineCommentTrivia */ && tripleSlashXMLCommentStartRegEx.exec(text);
-    if (tripleSlash) {
-      const name = tripleSlash[1].toLowerCase();
-      const pragma = commentPragmas[name];
-      if (!pragma || !(pragma.kind & 1 /* TripleSlashXML */)) {
-        return;
-      }
-      if (pragma.args) {
-        const argument = {};
-        for (const arg of pragma.args) {
-          const matcher = getNamedArgRegEx(arg.name);
-          const matchResult = matcher.exec(text);
-          if (!matchResult && !arg.optional) {
-            return;
-          } else if (matchResult) {
-            const value = matchResult[2] || matchResult[3];
-            if (arg.captureSpan) {
-              const startPos = range.pos + matchResult.index + matchResult[1].length + 1;
-              argument[arg.name] = {
-                value,
-                pos: startPos,
-                end: startPos + value.length
-              };
-            } else {
-              argument[arg.name] = value;
-            }
-          }
-        }
-        pragmas.push({ name, args: { arguments: argument, range } });
-      } else {
-        pragmas.push({ name, args: { arguments: {}, range } });
-      }
-      return;
-    }
-    const singleLine = range.kind === 2 /* SingleLineCommentTrivia */ && singleLinePragmaRegEx.exec(text);
-    if (singleLine) {
-      return addPragmaForMatch(pragmas, range, 2 /* SingleLine */, singleLine);
-    }
-    if (range.kind === 3 /* MultiLineCommentTrivia */) {
-      const multiLinePragmaRegEx = /@(\S+)(\s+.*)?$/gim;
-      let multiLineMatch;
-      while (multiLineMatch = multiLinePragmaRegEx.exec(text)) {
-        addPragmaForMatch(pragmas, range, 4 /* MultiLine */, multiLineMatch);
-      }
-    }
-  }
-  function addPragmaForMatch(pragmas, range, kind, match) {
-    if (!match)
-      return;
-    const name = match[1].toLowerCase();
-    const pragma = commentPragmas[name];
-    if (!pragma || !(pragma.kind & kind)) {
-      return;
-    }
-    const args = match[2];
-    const argument = getNamedPragmaArguments(pragma, args);
-    if (argument === "fail")
-      return;
-    pragmas.push({ name, args: { arguments: argument, range } });
-    return;
-  }
-  function getNamedPragmaArguments(pragma, text) {
-    if (!text)
-      return {};
-    if (!pragma.args)
-      return {};
-    const args = trimString(text).split(/\s+/);
-    const argMap = {};
-    for (let i = 0; i < pragma.args.length; i++) {
-      const argument = pragma.args[i];
-      if (!args[i] && !argument.optional) {
-        return "fail";
-      }
-      if (argument.captureSpan) {
-        return Debug.fail("Capture spans not yet implemented for non-xml pragmas");
-      }
-      argMap[argument.name] = args[i];
-    }
-    return argMap;
-  }
-  function tagNamesAreEquivalent(lhs, rhs) {
-    if (lhs.kind !== rhs.kind) {
-      return false;
-    }
-    if (lhs.kind === 80 /* Identifier */) {
-      return lhs.escapedText === rhs.escapedText;
-    }
-    if (lhs.kind === 110 /* ThisKeyword */) {
-      return true;
-    }
-    if (lhs.kind === 294 /* JsxNamespacedName */) {
-      return lhs.namespace.escapedText === rhs.namespace.escapedText && lhs.name.escapedText === rhs.name.escapedText;
-    }
-    return lhs.name.escapedText === rhs.name.escapedText && tagNamesAreEquivalent(lhs.expression, rhs.expression);
-  }
-  var NodeConstructor, TokenConstructor, IdentifierConstructor, PrivateIdentifierConstructor, SourceFileConstructor, parseBaseNodeFactory, parseNodeFactory, forEachChildTable, Parser, IncrementalParser, namedArgRegExCache, tripleSlashXMLCommentStartRegEx, singleLinePragmaRegEx;
-  var init_parser = __esm({
-    "src/compiler/parser.ts"() {
-      "use strict";
-      init_ts2();
-      init_ts_performance();
-      parseBaseNodeFactory = {
-        createBaseSourceFileNode: (kind) => new (SourceFileConstructor || (SourceFileConstructor = objectAllocator.getSourceFileConstructor()))(kind, -1, -1),
-        createBaseIdentifierNode: (kind) => new (IdentifierConstructor || (IdentifierConstructor = objectAllocator.getIdentifierConstructor()))(kind, -1, -1),
-        createBasePrivateIdentifierNode: (kind) => new (PrivateIdentifierConstructor || (PrivateIdentifierConstructor = objectAllocator.getPrivateIdentifierConstructor()))(kind, -1, -1),
-        createBaseTokenNode: (kind) => new (TokenConstructor || (TokenConstructor = objectAllocator.getTokenConstructor()))(kind, -1, -1),
-        createBaseNode: (kind) => new (NodeConstructor || (NodeConstructor = objectAllocator.getNodeConstructor()))(kind, -1, -1)
-      };
-      parseNodeFactory = createNodeFactory(1 /* NoParenthesizerRules */, parseBaseNodeFactory);
-      forEachChildTable = {
-        [165 /* QualifiedName */]: function forEachChildInQualifiedName(node, cbNode, _cbNodes) {
-          return visitNode2(cbNode, node.left) || visitNode2(cbNode, node.right);
-        },
-        [167 /* TypeParameter */]: function forEachChildInTypeParameter(node, cbNode, cbNodes) {
-          return visitNodes(cbNode, cbNodes, node.modifiers) || visitNode2(cbNode, node.name) || visitNode2(cbNode, node.constraint) || visitNode2(cbNode, node.default) || visitNode2(cbNode, node.expression);
-        },
-        [303 /* ShorthandPropertyAssignment */]: function forEachChildInShorthandPropertyAssignment(node, cbNode, cbNodes) {
-          return visitNodes(cbNode, cbNodes, node.modifiers) || visitNode2(cbNode, node.name) || visitNode2(cbNode, node.questionToken) || visitNode2(cbNode, node.exclamationToken) || visitNode2(cbNode, node.equalsToken) || visitNode2(cbNode, node.objectAssignmentInitializer);
-        },
-        [304 /* SpreadAssignment */]: function forEachChildInSpreadAssignment(node, cbNode, _cbNodes) {
-          return visitNode2(cbNode, node.expression);
-        },
-        [168 /* Parameter */]: function forEachChildInParameter(node, cbNode, cbNodes) {
-          return visitNodes(cbNode, cbNodes, node.modifiers) || visitNode2(cbNode, node.dotDotDotToken) || visitNode2(cbNode, node.name) || visitNode2(cbNode, node.questionToken) || visitNode2(cbNode, node.type) || visitNode2(cbNode, node.initializer);
-        },
-        [171 /* PropertyDeclaration */]: function forEachChildInPropertyDeclaration(node, cbNode, cbNodes) {
-          return visitNodes(cbNode, cbNodes, node.modifiers) || visitNode2(cbNode, node.name) || visitNode2(cbNode, node.questionToken) || visitNode2(cbNode, node.exclamationToken) || visitNode2(cbNode, node.type) || visitNode2(cbNode, node.initializer);
-        },
-        [170 /* PropertySignature */]: function forEachChildInPropertySignature(node, cbNode, cbNodes) {
-          return visitNodes(cbNode, cbNodes, node.modifiers) || visitNode2(cbNode, node.name) || visitNode2(cbNode, node.questionToken) || visitNode2(cbNode, node.type) || visitNode2(cbNode, node.initializer);
-        },
-        [302 /* PropertyAssignment */]: function forEachChildInPropertyAssignment(node, cbNode, cbNodes) {
-          return visitNodes(cbNode, cbNodes, node.modifiers) || visitNode2(cbNode, node.name) || visitNode2(cbNode, node.questionToken) || visitNode2(cbNode, node.exclamationToken) || visitNode2(cbNode, node.initializer);
-        },
-        [259 /* VariableDeclaration */]: function forEachChildInVariableDeclaration(node, cbNode, _cbNodes) {
-          return visitNode2(cbNode, node.name) || visitNode2(cbNode, node.exclamationToken) || visitNode2(cbNode, node.type) || visitNode2(cbNode, node.initializer);
-        },
-        [207 /* BindingElement */]: function forEachChildInBindingElement(node, cbNode, _cbNodes) {
-          return visitNode2(cbNode, node.dotDotDotToken) || visitNode2(cbNode, node.propertyName) || visitNode2(cbNode, node.name) || visitNode2(cbNode, node.initializer);
-        },
-        [180 /* IndexSignature */]: function forEachChildInIndexSignature(node, cbNode, cbNodes) {
-          return visitNodes(cbNode, cbNodes, node.modifiers) || visitNodes(cbNode, cbNodes, node.typeParameters) || visitNodes(cbNode, cbNodes, node.parameters) || visitNode2(cbNode, node.type);
-        },
-        [184 /* ConstructorType */]: function forEachChildInConstructorType(node, cbNode, cbNodes) {
-          return visitNodes(cbNode, cbNodes, node.modifiers) || visitNodes(cbNode, cbNodes, node.typeParameters) || visitNodes(cbNode, cbNodes, node.parameters) || visitNode2(cbNode, node.type);
-        },
-        [183 /* FunctionType */]: function forEachChildInFunctionType(node, cbNode, cbNodes) {
-          return visitNodes(cbNode, cbNodes, node.modifiers) || visitNodes(cbNode, cbNodes, node.typeParameters) || visitNodes(cbNode, cbNodes, node.parameters) || visitNode2(cbNode, node.type);
-        },
-        [178 /* CallSignature */]: forEachChildInCallOrConstructSignature,
-        [179 /* ConstructSignature */]: forEachChildInCallOrConstructSignature,
-        [173 /* MethodDeclaration */]: function forEachChildInMethodDeclaration(node, cbNode, cbNodes) {
-          return visitNodes(cbNode, cbNodes, node.modifiers) || visitNode2(cbNode, node.asteriskToken) || visitNode2(cbNode, node.name) || visitNode2(cbNode, node.questionToken) || visitNode2(cbNode, node.exclamationToken) || visitNodes(cbNode, cbNodes, node.typeParameters) || visitNodes(cbNode, cbNodes, node.parameters) || visitNode2(cbNode, node.type) || visitNode2(cbNode, node.body);
-        },
-        [172 /* MethodSignature */]: function forEachChildInMethodSignature(node, cbNode, cbNodes) {
-          return visitNodes(cbNode, cbNodes, node.modifiers) || visitNode2(cbNode, node.name) || visitNode2(cbNode, node.questionToken) || visitNodes(cbNode, cbNodes, node.typeParameters) || visitNodes(cbNode, cbNodes, node.parameters) || visitNode2(cbNode, node.type);
-        },
-        [175 /* Constructor */]: function forEachChildInConstructor(node, cbNode, cbNodes) {
-          return visitNodes(cbNode, cbNodes, node.modifiers) || visitNode2(cbNode, node.name) || visitNodes(cbNode, cbNodes, node.typeParameters) || visitNodes(cbNode, cbNodes, node.parameters) || visitNode2(cbNode, node.type) || visitNode2(cbNode, node.body);
-        },
-        [176 /* GetAccessor */]: function forEachChildInGetAccessor(node, cbNode, cbNodes) {
-          return visitNodes(cbNode, cbNodes, node.modifiers) || visitNode2(cbNode, node.name) || visitNodes(cbNode, cbNodes, node.typeParameters) || visitNodes(cbNode, cbNodes, node.parameters) || visitNode2(cbNode, node.type) || visitNode2(cbNode, node.body);
-        },
-        [177 /* SetAccessor */]: function forEachChildInSetAccessor(node, cbNode, cbNodes) {
-          return visitNodes(cbNode, cbNodes, node.modifiers) || visitNode2(cbNode, node.name) || visitNodes(cbNode, cbNodes, node.typeParameters) || visitNodes(cbNode, cbNodes, node.parameters) || visitNode2(cbNode, node.type) || visitNode2(cbNode, node.body);
-        },
-        [261 /* FunctionDeclaration */]: function forEachChildInFunctionDeclaration(node, cbNode, cbNodes) {
-          return visitNodes(cbNode, cbNodes, node.modifiers) || visitNode2(cbNode, node.asteriskToken) || visitNode2(cbNode, node.name) || visitNodes(cbNode, cbNodes, node.typeParameters) || visitNodes(cbNode, cbNodes, node.parameters) || visitNode2(cbNode, node.type) || visitNode2(cbNode, node.body);
-        },
-        [217 /* FunctionExpression */]: function forEachChildInFunctionExpression(node, cbNode, cbNodes) {
-          return visitNodes(cbNode, cbNodes, node.modifiers) || visitNode2(cbNode, node.asteriskToken) || visitNode2(cbNode, node.name) || visitNodes(cbNode, cbNodes, node.typeParameters) || visitNodes(cbNode, cbNodes, node.parameters) || visitNode2(cbNode, node.type) || visitNode2(cbNode, node.body);
-        },
-        [218 /* ArrowFunction */]: function forEachChildInArrowFunction(node, cbNode, cbNodes) {
-          return visitNodes(cbNode, cbNodes, node.modifiers) || visitNodes(cbNode, cbNodes, node.typeParameters) || visitNodes(cbNode, cbNodes, node.parameters) || visitNode2(cbNode, node.type) || visitNode2(cbNode, node.equalsGreaterThanToken) || visitNode2(cbNode, node.body);
-        },
-        [174 /* ClassStaticBlockDeclaration */]: function forEachChildInClassStaticBlockDeclaration(node, cbNode, cbNodes) {
-          return visitNodes(cbNode, cbNodes, node.modifiers) || visitNode2(cbNode, node.body);
-        },
-        [182 /* TypeReference */]: function forEachChildInTypeReference(node, cbNode, cbNodes) {
-          return visitNode2(cbNode, node.typeName) || visitNodes(cbNode, cbNodes, node.typeArguments);
-        },
-        [181 /* TypePredicate */]: function forEachChildInTypePredicate(node, cbNode, _cbNodes) {
-          return visitNode2(cbNode, node.assertsModifier) || visitNode2(cbNode, node.parameterName) || visitNode2(cbNode, node.type);
-        },
-        [185 /* TypeQuery */]: function forEachChildInTypeQuery(node, cbNode, cbNodes) {
-          return visitNode2(cbNode, node.exprName) || visitNodes(cbNode, cbNodes, node.typeArguments);
-        },
-        [186 /* TypeLiteral */]: function forEachChildInTypeLiteral(node, cbNode, cbNodes) {
-          return visitNodes(cbNode, cbNodes, node.members);
-        },
-        [187 /* ArrayType */]: function forEachChildInArrayType(node, cbNode, _cbNodes) {
-          return visitNode2(cbNode, node.elementType);
-        },
-        [188 /* TupleType */]: function forEachChildInTupleType(node, cbNode, cbNodes) {
-          return visitNodes(cbNode, cbNodes, node.elements);
-        },
-        [191 /* UnionType */]: forEachChildInUnionOrIntersectionType,
-        [192 /* IntersectionType */]: forEachChildInUnionOrIntersectionType,
-        [193 /* ConditionalType */]: function forEachChildInConditionalType(node, cbNode, _cbNodes) {
-          return visitNode2(cbNode, node.checkType) || visitNode2(cbNode, node.extendsType) || visitNode2(cbNode, node.trueType) || visitNode2(cbNode, node.falseType);
-        },
-        [194 /* InferType */]: function forEachChildInInferType(node, cbNode, _cbNodes) {
-          return visitNode2(cbNode, node.typeParameter);
-        },
-        [204 /* ImportType */]: function forEachChildInImportType(node, cbNode, cbNodes) {
-          return visitNode2(cbNode, node.argument) || visitNode2(cbNode, node.assertions) || visitNode2(cbNode, node.qualifier) || visitNodes(cbNode, cbNodes, node.typeArguments);
-        },
-        [301 /* ImportTypeAssertionContainer */]: function forEachChildInImportTypeAssertionContainer(node, cbNode, _cbNodes) {
-          return visitNode2(cbNode, node.assertClause);
-        },
-        [195 /* ParenthesizedType */]: forEachChildInParenthesizedTypeOrTypeOperator,
-        [197 /* TypeOperator */]: forEachChildInParenthesizedTypeOrTypeOperator,
-        [198 /* IndexedAccessType */]: function forEachChildInIndexedAccessType(node, cbNode, _cbNodes) {
-          return visitNode2(cbNode, node.objectType) || visitNode2(cbNode, node.indexType);
-        },
-        [199 /* MappedType */]: function forEachChildInMappedType(node, cbNode, cbNodes) {
-          return visitNode2(cbNode, node.readonlyToken) || visitNode2(cbNode, node.typeParameter) || visitNode2(cbNode, node.nameType) || visitNode2(cbNode, node.questionToken) || visitNode2(cbNode, node.type) || visitNodes(cbNode, cbNodes, node.members);
-        },
-        [200 /* LiteralType */]: function forEachChildInLiteralType(node, cbNode, _cbNodes) {
-          return visitNode2(cbNode, node.literal);
-        },
-        [201 /* NamedTupleMember */]: function forEachChildInNamedTupleMember(node, cbNode, _cbNodes) {
-          return visitNode2(cbNode, node.dotDotDotToken) || visitNode2(cbNode, node.name) || visitNode2(cbNode, node.questionToken) || visitNode2(cbNode, node.type);
-        },
-        [205 /* ObjectBindingPattern */]: forEachChildInObjectOrArrayBindingPattern,
-        [206 /* ArrayBindingPattern */]: forEachChildInObjectOrArrayBindingPattern,
-        [208 /* ArrayLiteralExpression */]: function forEachChildInArrayLiteralExpression(node, cbNode, cbNodes) {
-          return visitNodes(cbNode, cbNodes, node.elements);
-        },
-        [209 /* ObjectLiteralExpression */]: function forEachChildInObjectLiteralExpression(node, cbNode, cbNodes) {
-          return visitNodes(cbNode, cbNodes, node.properties);
-        },
-        [210 /* PropertyAccessExpression */]: function forEachChildInPropertyAccessExpression(node, cbNode, _cbNodes) {
-          return visitNode2(cbNode, node.expression) || visitNode2(cbNode, node.questionDotToken) || visitNode2(cbNode, node.name);
-        },
-        [211 /* ElementAccessExpression */]: function forEachChildInElementAccessExpression(node, cbNode, _cbNodes) {
-          return visitNode2(cbNode, node.expression) || visitNode2(cbNode, node.questionDotToken) || visitNode2(cbNode, node.argumentExpression);
-        },
-        [212 /* CallExpression */]: forEachChildInCallOrNewExpression,
-        [213 /* NewExpression */]: forEachChildInCallOrNewExpression,
-        [214 /* TaggedTemplateExpression */]: function forEachChildInTaggedTemplateExpression(node, cbNode, cbNodes) {
-          return visitNode2(cbNode, node.tag) || visitNode2(cbNode, node.questionDotToken) || visitNodes(cbNode, cbNodes, node.typeArguments) || visitNode2(cbNode, node.template);
-        },
-        [215 /* TypeAssertionExpression */]: function forEachChildInTypeAssertionExpression(node, cbNode, _cbNodes) {
-          return visitNode2(cbNode, node.type) || visitNode2(cbNode, node.expression);
-        },
-        [216 /* ParenthesizedExpression */]: function forEachChildInParenthesizedExpression(node, cbNode, _cbNodes) {
-          return visitNode2(cbNode, node.expression);
-        },
-        [219 /* DeleteExpression */]: function forEachChildInDeleteExpression(node, cbNode, _cbNodes) {
-          return visitNode2(cbNode, node.expression);
-        },
-        [220 /* TypeOfExpression */]: function forEachChildInTypeOfExpression(node, cbNode, _cbNodes) {
-          return visitNode2(cbNode, node.expression);
-        },
-        [221 /* VoidExpression */]: function forEachChildInVoidExpression(node, cbNode, _cbNodes) {
-          return visitNode2(cbNode, node.expression);
-        },
-        [223 /* PrefixUnaryExpression */]: function forEachChildInPrefixUnaryExpression(node, cbNode, _cbNodes) {
-          return visitNode2(cbNode, node.operand);
-        },
-        [228 /* YieldExpression */]: function forEachChildInYieldExpression(node, cbNode, _cbNodes) {
-          return visitNode2(cbNode, node.asteriskToken) || visitNode2(cbNode, node.expression);
-        },
-        [222 /* AwaitExpression */]: function forEachChildInAwaitExpression(node, cbNode, _cbNodes) {
-          return visitNode2(cbNode, node.expression);
-        },
-        [224 /* PostfixUnaryExpression */]: function forEachChildInPostfixUnaryExpression(node, cbNode, _cbNodes) {
-          return visitNode2(cbNode, node.operand);
-        },
-        [225 /* BinaryExpression */]: function forEachChildInBinaryExpression(node, cbNode, _cbNodes) {
-          return visitNode2(cbNode, node.left) || visitNode2(cbNode, node.operatorToken) || visitNode2(cbNode, node.right);
-        },
-        [233 /* AsExpression */]: function forEachChildInAsExpression(node, cbNode, _cbNodes) {
-          return visitNode2(cbNode, node.expression) || visitNode2(cbNode, node.type);
-        },
-        [234 /* NonNullExpression */]: function forEachChildInNonNullExpression(node, cbNode, _cbNodes) {
-          return visitNode2(cbNode, node.expression);
-        },
-        [237 /* SatisfiesExpression */]: function forEachChildInSatisfiesExpression(node, cbNode, _cbNodes) {
-          return visitNode2(cbNode, node.expression) || visitNode2(cbNode, node.type);
-        },
-        [235 /* MetaProperty */]: function forEachChildInMetaProperty(node, cbNode, _cbNodes) {
-          return visitNode2(cbNode, node.name);
-        },
-        [226 /* ConditionalExpression */]: function forEachChildInConditionalExpression(node, cbNode, _cbNodes) {
-          return visitNode2(cbNode, node.condition) || visitNode2(cbNode, node.questionToken) || visitNode2(cbNode, node.whenTrue) || visitNode2(cbNode, node.colonToken) || visitNode2(cbNode, node.whenFalse);
-        },
-        [229 /* SpreadElement */]: function forEachChildInSpreadElement(node, cbNode, _cbNodes) {
-          return visitNode2(cbNode, node.expression);
-        },
-        [240 /* Block */]: forEachChildInBlock,
-        [267 /* ModuleBlock */]: forEachChildInBlock,
-        [311 /* SourceFile */]: function forEachChildInSourceFile(node, cbNode, cbNodes) {
-          return visitNodes(cbNode, cbNodes, node.statements) || visitNode2(cbNode, node.endOfFileToken);
-        },
-        [242 /* VariableStatement */]: function forEachChildInVariableStatement(node, cbNode, cbNodes) {
-          return visitNodes(cbNode, cbNodes, node.modifiers) || visitNode2(cbNode, node.declarationList);
-        },
-        [260 /* VariableDeclarationList */]: function forEachChildInVariableDeclarationList(node, cbNode, cbNodes) {
-          return visitNodes(cbNode, cbNodes, node.declarations);
-        },
-        [243 /* ExpressionStatement */]: function forEachChildInExpressionStatement(node, cbNode, _cbNodes) {
-          return visitNode2(cbNode, node.expression);
-        },
-        [244 /* IfStatement */]: function forEachChildInIfStatement(node, cbNode, _cbNodes) {
-          return visitNode2(cbNode, node.expression) || visitNode2(cbNode, node.thenStatement) || visitNode2(cbNode, node.elseStatement);
-        },
-        [245 /* DoStatement */]: function forEachChildInDoStatement(node, cbNode, _cbNodes) {
-          return visitNode2(cbNode, node.statement) || visitNode2(cbNode, node.expression);
-        },
-        [246 /* WhileStatement */]: function forEachChildInWhileStatement(node, cbNode, _cbNodes) {
-          return visitNode2(cbNode, node.expression) || visitNode2(cbNode, node.statement);
-        },
-        [247 /* ForStatement */]: function forEachChildInForStatement(node, cbNode, _cbNodes) {
-          return visitNode2(cbNode, node.initializer) || visitNode2(cbNode, node.condition) || visitNode2(cbNode, node.incrementor) || visitNode2(cbNode, node.statement);
-        },
-        [248 /* ForInStatement */]: function forEachChildInForInStatement(node, cbNode, _cbNodes) {
-          return visitNode2(cbNode, node.initializer) || visitNode2(cbNode, node.expression) || visitNode2(cbNode, node.statement);
-        },
-        [249 /* ForOfStatement */]: function forEachChildInForOfStatement(node, cbNode, _cbNodes) {
-          return visitNode2(cbNode, node.awaitModifier) || visitNode2(cbNode, node.initializer) || visitNode2(cbNode, node.expression) || visitNode2(cbNode, node.statement);
-        },
-        [250 /* ContinueStatement */]: forEachChildInContinueOrBreakStatement,
-        [251 /* BreakStatement */]: forEachChildInContinueOrBreakStatement,
-        [252 /* ReturnStatement */]: function forEachChildInReturnStatement(node, cbNode, _cbNodes) {
-          return visitNode2(cbNode, node.expression);
-        },
-        [253 /* WithStatement */]: function forEachChildInWithStatement(node, cbNode, _cbNodes) {
-          return visitNode2(cbNode, node.expression) || visitNode2(cbNode, node.statement);
-        },
-        [254 /* SwitchStatement */]: function forEachChildInSwitchStatement(node, cbNode, _cbNodes) {
-          return visitNode2(cbNode, node.expression) || visitNode2(cbNode, node.caseBlock);
-        },
-        [268 /* CaseBlock */]: function forEachChildInCaseBlock(node, cbNode, cbNodes) {
-          return visitNodes(cbNode, cbNodes, node.clauses);
-        },
-        [295 /* CaseClause */]: function forEachChildInCaseClause(node, cbNode, cbNodes) {
-          return visitNode2(cbNode, node.expression) || visitNodes(cbNode, cbNodes, node.statements);
-        },
-        [296 /* DefaultClause */]: function forEachChildInDefaultClause(node, cbNode, cbNodes) {
-          return visitNodes(cbNode, cbNodes, node.statements);
-        },
-        [255 /* LabeledStatement */]: function forEachChildInLabeledStatement(node, cbNode, _cbNodes) {
-          return visitNode2(cbNode, node.label) || visitNode2(cbNode, node.statement);
-        },
-        [256 /* ThrowStatement */]: function forEachChildInThrowStatement(node, cbNode, _cbNodes) {
-          return visitNode2(cbNode, node.expression);
-        },
-        [257 /* TryStatement */]: function forEachChildInTryStatement(node, cbNode, _cbNodes) {
-          return visitNode2(cbNode, node.tryBlock) || visitNode2(cbNode, node.catchClause) || visitNode2(cbNode, node.finallyBlock);
-        },
-        [298 /* CatchClause */]: function forEachChildInCatchClause(node, cbNode, _cbNodes) {
-          return visitNode2(cbNode, node.variableDeclaration) || visitNode2(cbNode, node.block);
-        },
-        [169 /* Decorator */]: function forEachChildInDecorator(node, cbNode, _cbNodes) {
-          return visitNode2(cbNode, node.expression);
-        },
-        [262 /* ClassDeclaration */]: forEachChildInClassDeclarationOrExpression,
-        [230 /* ClassExpression */]: forEachChildInClassDeclarationOrExpression,
-        [263 /* InterfaceDeclaration */]: function forEachChildInInterfaceDeclaration(node, cbNode, cbNodes) {
-          return visitNodes(cbNode, cbNodes, node.modifiers) || visitNode2(cbNode, node.name) || visitNodes(cbNode, cbNodes, node.typeParameters) || visitNodes(cbNode, cbNodes, node.heritageClauses) || visitNodes(cbNode, cbNodes, node.members);
-        },
-        [264 /* TypeAliasDeclaration */]: function forEachChildInTypeAliasDeclaration(node, cbNode, cbNodes) {
-          return visitNodes(cbNode, cbNodes, node.modifiers) || visitNode2(cbNode, node.name) || visitNodes(cbNode, cbNodes, node.typeParameters) || visitNode2(cbNode, node.type);
-        },
-        [265 /* EnumDeclaration */]: function forEachChildInEnumDeclaration(node, cbNode, cbNodes) {
-          return visitNodes(cbNode, cbNodes, node.modifiers) || visitNode2(cbNode, node.name) || visitNodes(cbNode, cbNodes, node.members);
-        },
-        [305 /* EnumMember */]: function forEachChildInEnumMember(node, cbNode, _cbNodes) {
-          return visitNode2(cbNode, node.name) || visitNode2(cbNode, node.initializer);
-        },
-        [266 /* ModuleDeclaration */]: function forEachChildInModuleDeclaration(node, cbNode, cbNodes) {
-          return visitNodes(cbNode, cbNodes, node.modifiers) || visitNode2(cbNode, node.name) || visitNode2(cbNode, node.body);
-        },
-        [270 /* ImportEqualsDeclaration */]: function forEachChildInImportEqualsDeclaration(node, cbNode, cbNodes) {
-          return visitNodes(cbNode, cbNodes, node.modifiers) || visitNode2(cbNode, node.name) || visitNode2(cbNode, node.moduleReference);
-        },
-        [271 /* ImportDeclaration */]: function forEachChildInImportDeclaration(node, cbNode, cbNodes) {
-          return visitNodes(cbNode, cbNodes, node.modifiers) || visitNode2(cbNode, node.importClause) || visitNode2(cbNode, node.moduleSpecifier) || visitNode2(cbNode, node.assertClause);
-        },
-        [272 /* ImportClause */]: function forEachChildInImportClause(node, cbNode, _cbNodes) {
-          return visitNode2(cbNode, node.name) || visitNode2(cbNode, node.namedBindings);
-        },
-        [299 /* AssertClause */]: function forEachChildInAssertClause(node, cbNode, cbNodes) {
-          return visitNodes(cbNode, cbNodes, node.elements);
-        },
-        [300 /* AssertEntry */]: function forEachChildInAssertEntry(node, cbNode, _cbNodes) {
-          return visitNode2(cbNode, node.name) || visitNode2(cbNode, node.value);
-        },
-        [269 /* NamespaceExportDeclaration */]: function forEachChildInNamespaceExportDeclaration(node, cbNode, cbNodes) {
-          return visitNodes(cbNode, cbNodes, node.modifiers) || visitNode2(cbNode, node.name);
-        },
-        [273 /* NamespaceImport */]: function forEachChildInNamespaceImport(node, cbNode, _cbNodes) {
-          return visitNode2(cbNode, node.name);
-        },
-        [279 /* NamespaceExport */]: function forEachChildInNamespaceExport(node, cbNode, _cbNodes) {
-          return visitNode2(cbNode, node.name);
-        },
-        [274 /* NamedImports */]: forEachChildInNamedImportsOrExports,
-        [278 /* NamedExports */]: forEachChildInNamedImportsOrExports,
-        [277 /* ExportDeclaration */]: function forEachChildInExportDeclaration(node, cbNode, cbNodes) {
-          return visitNodes(cbNode, cbNodes, node.modifiers) || visitNode2(cbNode, node.exportClause) || visitNode2(cbNode, node.moduleSpecifier) || visitNode2(cbNode, node.assertClause);
-        },
-        [275 /* ImportSpecifier */]: forEachChildInImportOrExportSpecifier,
-        [280 /* ExportSpecifier */]: forEachChildInImportOrExportSpecifier,
-        [276 /* ExportAssignment */]: function forEachChildInExportAssignment(node, cbNode, cbNodes) {
-          return visitNodes(cbNode, cbNodes, node.modifiers) || visitNode2(cbNode, node.expression);
-        },
-        [227 /* TemplateExpression */]: function forEachChildInTemplateExpression(node, cbNode, cbNodes) {
-          return visitNode2(cbNode, node.head) || visitNodes(cbNode, cbNodes, node.templateSpans);
-        },
-        [238 /* TemplateSpan */]: function forEachChildInTemplateSpan(node, cbNode, _cbNodes) {
-          return visitNode2(cbNode, node.expression) || visitNode2(cbNode, node.literal);
-        },
-        [202 /* TemplateLiteralType */]: function forEachChildInTemplateLiteralType(node, cbNode, cbNodes) {
-          return visitNode2(cbNode, node.head) || visitNodes(cbNode, cbNodes, node.templateSpans);
-        },
-        [203 /* TemplateLiteralTypeSpan */]: function forEachChildInTemplateLiteralTypeSpan(node, cbNode, _cbNodes) {
-          return visitNode2(cbNode, node.type) || visitNode2(cbNode, node.literal);
-        },
-        [166 /* ComputedPropertyName */]: function forEachChildInComputedPropertyName(node, cbNode, _cbNodes) {
-          return visitNode2(cbNode, node.expression);
-        },
-        [297 /* HeritageClause */]: function forEachChildInHeritageClause(node, cbNode, cbNodes) {
-          return visitNodes(cbNode, cbNodes, node.types);
-        },
-        [232 /* ExpressionWithTypeArguments */]: function forEachChildInExpressionWithTypeArguments(node, cbNode, cbNodes) {
-          return visitNode2(cbNode, node.expression) || visitNodes(cbNode, cbNodes, node.typeArguments);
-        },
-        [282 /* ExternalModuleReference */]: function forEachChildInExternalModuleReference(node, cbNode, _cbNodes) {
-          return visitNode2(cbNode, node.expression);
-        },
-        [281 /* MissingDeclaration */]: function forEachChildInMissingDeclaration(node, cbNode, cbNodes) {
-          return visitNodes(cbNode, cbNodes, node.modifiers);
-        },
-        [360 /* CommaListExpression */]: function forEachChildInCommaListExpression(node, cbNode, cbNodes) {
-          return visitNodes(cbNode, cbNodes, node.elements);
-        },
-        [283 /* JsxElement */]: function forEachChildInJsxElement(node, cbNode, cbNodes) {
-          return visitNode2(cbNode, node.openingElement) || visitNodes(cbNode, cbNodes, node.children) || visitNode2(cbNode, node.closingElement);
-        },
-        [287 /* JsxFragment */]: function forEachChildInJsxFragment(node, cbNode, cbNodes) {
-          return visitNode2(cbNode, node.openingFragment) || visitNodes(cbNode, cbNodes, node.children) || visitNode2(cbNode, node.closingFragment);
-        },
-        [284 /* JsxSelfClosingElement */]: forEachChildInJsxOpeningOrSelfClosingElement,
-        [285 /* JsxOpeningElement */]: forEachChildInJsxOpeningOrSelfClosingElement,
-        [291 /* JsxAttributes */]: function forEachChildInJsxAttributes(node, cbNode, cbNodes) {
-          return visitNodes(cbNode, cbNodes, node.properties);
-        },
-        [290 /* JsxAttribute */]: function forEachChildInJsxAttribute(node, cbNode, _cbNodes) {
-          return visitNode2(cbNode, node.name) || visitNode2(cbNode, node.initializer);
-        },
-        [292 /* JsxSpreadAttribute */]: function forEachChildInJsxSpreadAttribute(node, cbNode, _cbNodes) {
-          return visitNode2(cbNode, node.expression);
-        },
-        [293 /* JsxExpression */]: function forEachChildInJsxExpression(node, cbNode, _cbNodes) {
-          return visitNode2(cbNode, node.dotDotDotToken) || visitNode2(cbNode, node.expression);
-        },
-        [286 /* JsxClosingElement */]: function forEachChildInJsxClosingElement(node, cbNode, _cbNodes) {
-          return visitNode2(cbNode, node.tagName);
-        },
-        [294 /* JsxNamespacedName */]: function forEachChildInJsxNamespacedName(node, cbNode, _cbNodes) {
-          return visitNode2(cbNode, node.namespace) || visitNode2(cbNode, node.name);
-        },
-        [189 /* OptionalType */]: forEachChildInOptionalRestOrJSDocParameterModifier,
-        [190 /* RestType */]: forEachChildInOptionalRestOrJSDocParameterModifier,
-        [315 /* JSDocTypeExpression */]: forEachChildInOptionalRestOrJSDocParameterModifier,
-        [321 /* JSDocNonNullableType */]: forEachChildInOptionalRestOrJSDocParameterModifier,
-        [320 /* JSDocNullableType */]: forEachChildInOptionalRestOrJSDocParameterModifier,
-        [322 /* JSDocOptionalType */]: forEachChildInOptionalRestOrJSDocParameterModifier,
-        [324 /* JSDocVariadicType */]: forEachChildInOptionalRestOrJSDocParameterModifier,
-        [323 /* JSDocFunctionType */]: function forEachChildInJSDocFunctionType(node, cbNode, cbNodes) {
-          return visitNodes(cbNode, cbNodes, node.parameters) || visitNode2(cbNode, node.type);
-        },
-        [326 /* JSDoc */]: function forEachChildInJSDoc(node, cbNode, cbNodes) {
-          return (typeof node.comment === "string" ? void 0 : visitNodes(cbNode, cbNodes, node.comment)) || visitNodes(cbNode, cbNodes, node.tags);
-        },
-        [353 /* JSDocSeeTag */]: function forEachChildInJSDocSeeTag(node, cbNode, cbNodes) {
-          return visitNode2(cbNode, node.tagName) || visitNode2(cbNode, node.name) || (typeof node.comment === "string" ? void 0 : visitNodes(cbNode, cbNodes, node.comment));
-        },
-        [316 /* JSDocNameReference */]: function forEachChildInJSDocNameReference(node, cbNode, _cbNodes) {
-          return visitNode2(cbNode, node.name);
-        },
-        [317 /* JSDocMemberName */]: function forEachChildInJSDocMemberName(node, cbNode, _cbNodes) {
-          return visitNode2(cbNode, node.left) || visitNode2(cbNode, node.right);
-        },
-        [347 /* JSDocParameterTag */]: forEachChildInJSDocParameterOrPropertyTag,
-        [354 /* JSDocPropertyTag */]: forEachChildInJSDocParameterOrPropertyTag,
-        [336 /* JSDocAuthorTag */]: function forEachChildInJSDocAuthorTag(node, cbNode, cbNodes) {
-          return visitNode2(cbNode, node.tagName) || (typeof node.comment === "string" ? void 0 : visitNodes(cbNode, cbNodes, node.comment));
-        },
-        [335 /* JSDocImplementsTag */]: function forEachChildInJSDocImplementsTag(node, cbNode, cbNodes) {
-          return visitNode2(cbNode, node.tagName) || visitNode2(cbNode, node.class) || (typeof node.comment === "string" ? void 0 : visitNodes(cbNode, cbNodes, node.comment));
-        },
-        [334 /* JSDocAugmentsTag */]: function forEachChildInJSDocAugmentsTag(node, cbNode, cbNodes) {
-          return visitNode2(cbNode, node.tagName) || visitNode2(cbNode, node.class) || (typeof node.comment === "string" ? void 0 : visitNodes(cbNode, cbNodes, node.comment));
-        },
-        [351 /* JSDocTemplateTag */]: function forEachChildInJSDocTemplateTag(node, cbNode, cbNodes) {
-          return visitNode2(cbNode, node.tagName) || visitNode2(cbNode, node.constraint) || visitNodes(cbNode, cbNodes, node.typeParameters) || (typeof node.comment === "string" ? void 0 : visitNodes(cbNode, cbNodes, node.comment));
-        },
-        [352 /* JSDocTypedefTag */]: function forEachChildInJSDocTypedefTag(node, cbNode, cbNodes) {
-          return visitNode2(cbNode, node.tagName) || (node.typeExpression && node.typeExpression.kind === 315 /* JSDocTypeExpression */ ? visitNode2(cbNode, node.typeExpression) || visitNode2(cbNode, node.fullName) || (typeof node.comment === "string" ? void 0 : visitNodes(cbNode, cbNodes, node.comment)) : visitNode2(cbNode, node.fullName) || visitNode2(cbNode, node.typeExpression) || (typeof node.comment === "string" ? void 0 : visitNodes(cbNode, cbNodes, node.comment)));
-        },
-        [344 /* JSDocCallbackTag */]: function forEachChildInJSDocCallbackTag(node, cbNode, cbNodes) {
-          return visitNode2(cbNode, node.tagName) || visitNode2(cbNode, node.fullName) || visitNode2(cbNode, node.typeExpression) || (typeof node.comment === "string" ? void 0 : visitNodes(cbNode, cbNodes, node.comment));
-        },
-        [348 /* JSDocReturnTag */]: forEachChildInJSDocTypeLikeTag,
-        [350 /* JSDocTypeTag */]: forEachChildInJSDocTypeLikeTag,
-        [349 /* JSDocThisTag */]: forEachChildInJSDocTypeLikeTag,
-        [346 /* JSDocEnumTag */]: forEachChildInJSDocTypeLikeTag,
-        [356 /* JSDocSatisfiesTag */]: forEachChildInJSDocTypeLikeTag,
-        [355 /* JSDocThrowsTag */]: forEachChildInJSDocTypeLikeTag,
-        [345 /* JSDocOverloadTag */]: forEachChildInJSDocTypeLikeTag,
-        [329 /* JSDocSignature */]: function forEachChildInJSDocSignature(node, cbNode, _cbNodes) {
-          return forEach(node.typeParameters, cbNode) || forEach(node.parameters, cbNode) || visitNode2(cbNode, node.type);
-        },
-        [330 /* JSDocLink */]: forEachChildInJSDocLinkCodeOrPlain,
-        [331 /* JSDocLinkCode */]: forEachChildInJSDocLinkCodeOrPlain,
-        [332 /* JSDocLinkPlain */]: forEachChildInJSDocLinkCodeOrPlain,
-        [328 /* JSDocTypeLiteral */]: function forEachChildInJSDocTypeLiteral(node, cbNode, _cbNodes) {
-          return forEach(node.jsDocPropertyTags, cbNode);
-        },
-        [333 /* JSDocTag */]: forEachChildInJSDocTag,
-        [338 /* JSDocClassTag */]: forEachChildInJSDocTag,
-        [339 /* JSDocPublicTag */]: forEachChildInJSDocTag,
-        [340 /* JSDocPrivateTag */]: forEachChildInJSDocTag,
-        [341 /* JSDocProtectedTag */]: forEachChildInJSDocTag,
-        [342 /* JSDocReadonlyTag */]: forEachChildInJSDocTag,
-        [337 /* JSDocDeprecatedTag */]: forEachChildInJSDocTag,
-        [343 /* JSDocOverrideTag */]: forEachChildInJSDocTag,
-        [359 /* PartiallyEmittedExpression */]: forEachChildInPartiallyEmittedExpression
-      };
-      ((Parser2) => {
-        var scanner2 = createScanner(
-          99 /* Latest */,
-          /*skipTrivia*/
-          true
-        );
-        var disallowInAndDecoratorContext = 4096 /* DisallowInContext */ | 16384 /* DecoratorContext */;
-        var NodeConstructor2;
-        var TokenConstructor2;
-        var IdentifierConstructor2;
-        var PrivateIdentifierConstructor2;
-        var SourceFileConstructor2;
-        function countNode(node) {
-          nodeCount++;
-          return node;
-        }
-        var baseNodeFactory = {
-          createBaseSourceFileNode: (kind) => countNode(new SourceFileConstructor2(
-            kind,
-            /*pos*/
-            0,
-            /*end*/
-            0
-          )),
-          createBaseIdentifierNode: (kind) => countNode(new IdentifierConstructor2(
-            kind,
-            /*pos*/
-            0,
-            /*end*/
-            0
-          )),
-          createBasePrivateIdentifierNode: (kind) => countNode(new PrivateIdentifierConstructor2(
-            kind,
-            /*pos*/
-            0,
-            /*end*/
-            0
-          )),
-          createBaseTokenNode: (kind) => countNode(new TokenConstructor2(
-            kind,
-            /*pos*/
-            0,
-            /*end*/
-            0
-          )),
-          createBaseNode: (kind) => countNode(new NodeConstructor2(
-            kind,
-            /*pos*/
-            0,
-            /*end*/
-            0
-          ))
-        };
-        var factory2 = createNodeFactory(1 /* NoParenthesizerRules */ | 2 /* NoNodeConverters */ | 8 /* NoOriginalNode */, baseNodeFactory);
-        var {
-          createNodeArray: factoryCreateNodeArray,
-          createNumericLiteral: factoryCreateNumericLiteral,
-          createStringLiteral: factoryCreateStringLiteral,
-          createLiteralLikeNode: factoryCreateLiteralLikeNode,
-          createIdentifier: factoryCreateIdentifier,
-          createPrivateIdentifier: factoryCreatePrivateIdentifier,
-          createToken: factoryCreateToken,
-          createArrayLiteralExpression: factoryCreateArrayLiteralExpression,
-          createObjectLiteralExpression: factoryCreateObjectLiteralExpression,
-          createPropertyAccessExpression: factoryCreatePropertyAccessExpression,
-          createPropertyAccessChain: factoryCreatePropertyAccessChain,
-          createElementAccessExpression: factoryCreateElementAccessExpression,
-          createElementAccessChain: factoryCreateElementAccessChain,
-          createCallExpression: factoryCreateCallExpression,
-          createCallChain: factoryCreateCallChain,
-          createNewExpression: factoryCreateNewExpression,
-          createParenthesizedExpression: factoryCreateParenthesizedExpression,
-          createBlock: factoryCreateBlock,
-          createVariableStatement: factoryCreateVariableStatement,
-          createExpressionStatement: factoryCreateExpressionStatement,
-          createIfStatement: factoryCreateIfStatement,
-          createWhileStatement: factoryCreateWhileStatement,
-          createForStatement: factoryCreateForStatement,
-          createForOfStatement: factoryCreateForOfStatement,
-          createVariableDeclaration: factoryCreateVariableDeclaration,
-          createVariableDeclarationList: factoryCreateVariableDeclarationList
-        } = factory2;
-        var fileName;
-        var sourceFlags;
-        var sourceText;
-        var languageVersion;
-        var scriptKind;
-        var languageVariant;
-        var parseDiagnostics;
-        var jsDocDiagnostics;
-        var syntaxCursor;
-        var currentToken;
-        var nodeCount;
-        var identifiers;
-        var identifierCount;
-        var parsingContext;
-        var notParenthesizedArrow;
-        var contextFlags;
-        var topLevel = true;
-        var parseErrorBeforeNextFinishedNode = false;
-        function parseSourceFile(fileName2, sourceText2, languageVersion2, syntaxCursor2, setParentNodes = false, scriptKind2, setExternalModuleIndicatorOverride) {
-          var _a;
-          scriptKind2 = ensureScriptKind(fileName2, scriptKind2);
-          if (scriptKind2 === 6 /* JSON */) {
-            const result2 = parseJsonText2(fileName2, sourceText2, languageVersion2, syntaxCursor2, setParentNodes);
-            convertToJson(
-              result2,
-              (_a = result2.statements[0]) == null ? void 0 : _a.expression,
-              result2.parseDiagnostics,
-              /*returnValue*/
-              false,
-              /*jsonConversionNotifier*/
-              void 0
-            );
-            result2.referencedFiles = emptyArray;
-            result2.typeReferenceDirectives = emptyArray;
-            result2.libReferenceDirectives = emptyArray;
-            result2.amdDependencies = emptyArray;
-            result2.hasNoDefaultLib = false;
-            result2.pragmas = emptyMap;
-            return result2;
-          }
-          initializeState(fileName2, sourceText2, languageVersion2, syntaxCursor2, scriptKind2);
-          const result = parseSourceFileWorker(languageVersion2, setParentNodes, scriptKind2, setExternalModuleIndicatorOverride || setExternalModuleIndicator);
-          clearState();
-          return result;
-        }
-        Parser2.parseSourceFile = parseSourceFile;
-        function parseIsolatedEntityName2(content, languageVersion2) {
-          initializeState(
-            "",
-            content,
-            languageVersion2,
-            /*syntaxCursor*/
-            void 0,
-            1 /* JS */
-          );
-          nextToken();
-          const entityName = parseEntityName(
-            /*allowReservedWords*/
-            true
-          );
-          const isInvalid = token() === 1 /* EndOfFileToken */ && !parseDiagnostics.length;
-          clearState();
-          return isInvalid ? entityName : void 0;
-        }
-        Parser2.parseIsolatedEntityName = parseIsolatedEntityName2;
-        function parseJsonText2(fileName2, sourceText2, languageVersion2 = 2 /* ES2015 */, syntaxCursor2, setParentNodes = false) {
-          initializeState(fileName2, sourceText2, languageVersion2, syntaxCursor2, 6 /* JSON */);
-          sourceFlags = contextFlags;
-          nextToken();
-          const pos = getNodePos();
-          let statements, endOfFileToken;
-          if (token() === 1 /* EndOfFileToken */) {
-            statements = createNodeArray([], pos, pos);
-            endOfFileToken = parseTokenNode();
-          } else {
-            let expressions;
-            while (token() !== 1 /* EndOfFileToken */) {
-              let expression2;
-              switch (token()) {
-                case 23 /* OpenBracketToken */:
-                  expression2 = parseArrayLiteralExpression();
-                  break;
-                case 112 /* TrueKeyword */:
-                case 97 /* FalseKeyword */:
-                case 106 /* NullKeyword */:
-                  expression2 = parseTokenNode();
-                  break;
-                case 41 /* MinusToken */:
-                  if (lookAhead(() => nextToken() === 9 /* NumericLiteral */ && nextToken() !== 59 /* ColonToken */)) {
-                    expression2 = parsePrefixUnaryExpression();
-                  } else {
-                    expression2 = parseObjectLiteralExpression();
-                  }
-                  break;
-                case 9 /* NumericLiteral */:
-                case 11 /* StringLiteral */:
-                  if (lookAhead(() => nextToken() !== 59 /* ColonToken */)) {
-                    expression2 = parseLiteralNode();
-                    break;
-                  }
-                default:
-                  expression2 = parseObjectLiteralExpression();
-                  break;
-              }
-              if (expressions && isArray(expressions)) {
-                expressions.push(expression2);
-              } else if (expressions) {
-                expressions = [expressions, expression2];
-              } else {
-                expressions = expression2;
-                if (token() !== 1 /* EndOfFileToken */) {
-                  parseErrorAtCurrentToken(Diagnostics.Unexpected_token);
-                }
-              }
-            }
-            const expression = isArray(expressions) ? finishNode(factoryCreateArrayLiteralExpression(expressions), pos) : Debug.checkDefined(expressions);
-            const statement = factoryCreateExpressionStatement(expression);
-            finishNode(statement, pos);
-            statements = createNodeArray([statement], pos);
-            endOfFileToken = parseExpectedToken(1 /* EndOfFileToken */, Diagnostics.Unexpected_token);
-          }
-          const sourceFile = createSourceFile2(
-            fileName2,
-            2 /* ES2015 */,
-            6 /* JSON */,
-            /*isDeclarationFile*/
-            false,
-            statements,
-            endOfFileToken,
-            sourceFlags,
-            noop
-          );
-          if (setParentNodes) {
-            fixupParentReferences(sourceFile);
-          }
-          sourceFile.nodeCount = nodeCount;
-          sourceFile.identifierCount = identifierCount;
-          sourceFile.identifiers = identifiers;
-          sourceFile.parseDiagnostics = attachFileToDiagnostics(parseDiagnostics, sourceFile);
-          if (jsDocDiagnostics) {
-            sourceFile.jsDocDiagnostics = attachFileToDiagnostics(jsDocDiagnostics, sourceFile);
-          }
-          const result = sourceFile;
-          clearState();
-          return result;
-        }
-        Parser2.parseJsonText = parseJsonText2;
-        function initializeState(_fileName, _sourceText, _languageVersion, _syntaxCursor, _scriptKind) {
-          NodeConstructor2 = objectAllocator.getNodeConstructor();
-          TokenConstructor2 = objectAllocator.getTokenConstructor();
-          IdentifierConstructor2 = objectAllocator.getIdentifierConstructor();
-          PrivateIdentifierConstructor2 = objectAllocator.getPrivateIdentifierConstructor();
-          SourceFileConstructor2 = objectAllocator.getSourceFileConstructor();
-          fileName = normalizePath(_fileName);
-          sourceText = _sourceText;
-          languageVersion = _languageVersion;
-          syntaxCursor = _syntaxCursor;
-          scriptKind = _scriptKind;
-          languageVariant = getLanguageVariant(_scriptKind);
-          parseDiagnostics = [];
-          parsingContext = 0;
-          identifiers = /* @__PURE__ */ new Map();
-          identifierCount = 0;
-          nodeCount = 0;
-          sourceFlags = 0;
-          topLevel = true;
-          switch (scriptKind) {
-            case 1 /* JS */:
-            case 2 /* JSX */:
-              contextFlags = 262144 /* JavaScriptFile */;
-              break;
-            case 6 /* JSON */:
-              contextFlags = 262144 /* JavaScriptFile */ | 67108864 /* JsonFile */;
-              break;
-            default:
-              contextFlags = 0 /* None */;
-              break;
-          }
-          parseErrorBeforeNextFinishedNode = false;
-          scanner2.setText(sourceText);
-          scanner2.setOnError(scanError);
-          scanner2.setScriptTarget(languageVersion);
-          scanner2.setLanguageVariant(languageVariant);
-        }
-        function clearState() {
-          scanner2.clearCommentDirectives();
-          scanner2.setText("");
-          scanner2.setOnError(void 0);
-          sourceText = void 0;
-          languageVersion = void 0;
-          syntaxCursor = void 0;
-          scriptKind = void 0;
-          languageVariant = void 0;
-          sourceFlags = 0;
-          parseDiagnostics = void 0;
-          jsDocDiagnostics = void 0;
-          parsingContext = 0;
-          identifiers = void 0;
-          notParenthesizedArrow = void 0;
-          topLevel = true;
-        }
-        function parseSourceFileWorker(languageVersion2, setParentNodes, scriptKind2, setExternalModuleIndicator2) {
-          const isDeclarationFile = isDeclarationFileName(fileName);
-          if (isDeclarationFile) {
-            contextFlags |= 16777216 /* Ambient */;
-          }
-          sourceFlags = contextFlags;
-          nextToken();
-          const statements = parseList(0 /* SourceElements */, parseStatement);
-          Debug.assert(token() === 1 /* EndOfFileToken */);
-          const endOfFileToken = addJSDocComment(parseTokenNode());
-          const sourceFile = createSourceFile2(fileName, languageVersion2, scriptKind2, isDeclarationFile, statements, endOfFileToken, sourceFlags, setExternalModuleIndicator2);
-          processCommentPragmas(sourceFile, sourceText);
-          processPragmasIntoFields(sourceFile, reportPragmaDiagnostic);
-          sourceFile.commentDirectives = scanner2.getCommentDirectives();
-          sourceFile.nodeCount = nodeCount;
-          sourceFile.identifierCount = identifierCount;
-          sourceFile.identifiers = identifiers;
-          sourceFile.parseDiagnostics = attachFileToDiagnostics(parseDiagnostics, sourceFile);
-          if (jsDocDiagnostics) {
-            sourceFile.jsDocDiagnostics = attachFileToDiagnostics(jsDocDiagnostics, sourceFile);
-          }
-          if (setParentNodes) {
-            fixupParentReferences(sourceFile);
-          }
-          return sourceFile;
-          function reportPragmaDiagnostic(pos, end, diagnostic) {
-            parseDiagnostics.push(createDetachedDiagnostic(fileName, pos, end, diagnostic));
-          }
-        }
-        function withJSDoc(node, hasJSDoc) {
-          return hasJSDoc ? addJSDocComment(node) : node;
-        }
-        let hasDeprecatedTag = false;
-        function addJSDocComment(node) {
-          Debug.assert(!node.jsDoc);
-          const jsDoc = mapDefined(getJSDocCommentRanges(node, sourceText), (comment) => JSDocParser.parseJSDocComment(node, comment.pos, comment.end - comment.pos));
-          if (jsDoc.length)
-            node.jsDoc = jsDoc;
-          if (hasDeprecatedTag) {
-            hasDeprecatedTag = false;
-            node.flags |= 268435456 /* Deprecated */;
-          }
-          return node;
-        }
-        function reparseTopLevelAwait(sourceFile) {
-          const savedSyntaxCursor = syntaxCursor;
-          const baseSyntaxCursor = IncrementalParser.createSyntaxCursor(sourceFile);
-          syntaxCursor = { currentNode: currentNode2 };
-          const statements = [];
-          const savedParseDiagnostics = parseDiagnostics;
-          parseDiagnostics = [];
-          let pos = 0;
-          let start = findNextStatementWithAwait(sourceFile.statements, 0);
-          while (start !== -1) {
-            const prevStatement = sourceFile.statements[pos];
-            const nextStatement = sourceFile.statements[start];
-            addRange(statements, sourceFile.statements, pos, start);
-            pos = findNextStatementWithoutAwait(sourceFile.statements, start);
-            const diagnosticStart = findIndex(savedParseDiagnostics, (diagnostic) => diagnostic.start >= prevStatement.pos);
-            const diagnosticEnd = diagnosticStart >= 0 ? findIndex(savedParseDiagnostics, (diagnostic) => diagnostic.start >= nextStatement.pos, diagnosticStart) : -1;
-            if (diagnosticStart >= 0) {
-              addRange(parseDiagnostics, savedParseDiagnostics, diagnosticStart, diagnosticEnd >= 0 ? diagnosticEnd : void 0);
-            }
-            speculationHelper(() => {
-              const savedContextFlags = contextFlags;
-              contextFlags |= 32768 /* AwaitContext */;
-              scanner2.resetTokenState(nextStatement.pos);
-              nextToken();
-              while (token() !== 1 /* EndOfFileToken */) {
-                const startPos = scanner2.getTokenFullStart();
-                const statement = parseListElement(0 /* SourceElements */, parseStatement);
-                statements.push(statement);
-                if (startPos === scanner2.getTokenFullStart()) {
-                  nextToken();
-                }
-                if (pos >= 0) {
-                  const nonAwaitStatement = sourceFile.statements[pos];
-                  if (statement.end === nonAwaitStatement.pos) {
-                    break;
-                  }
-                  if (statement.end > nonAwaitStatement.pos) {
-                    pos = findNextStatementWithoutAwait(sourceFile.statements, pos + 1);
-                  }
-                }
-              }
-              contextFlags = savedContextFlags;
-            }, 2 /* Reparse */);
-            start = pos >= 0 ? findNextStatementWithAwait(sourceFile.statements, pos) : -1;
-          }
-          if (pos >= 0) {
-            const prevStatement = sourceFile.statements[pos];
-            addRange(statements, sourceFile.statements, pos);
-            const diagnosticStart = findIndex(savedParseDiagnostics, (diagnostic) => diagnostic.start >= prevStatement.pos);
-            if (diagnosticStart >= 0) {
-              addRange(parseDiagnostics, savedParseDiagnostics, diagnosticStart);
-            }
-          }
-          syntaxCursor = savedSyntaxCursor;
-          return factory2.updateSourceFile(sourceFile, setTextRange(factoryCreateNodeArray(statements), sourceFile.statements));
-          function containsPossibleTopLevelAwait(node) {
-            return !(node.flags & 32768 /* AwaitContext */) && !!(node.transformFlags & 67108864 /* ContainsPossibleTopLevelAwait */);
-          }
-          function findNextStatementWithAwait(statements2, start2) {
-            for (let i = start2; i < statements2.length; i++) {
-              if (containsPossibleTopLevelAwait(statements2[i])) {
-                return i;
-              }
-            }
-            return -1;
-          }
-          function findNextStatementWithoutAwait(statements2, start2) {
-            for (let i = start2; i < statements2.length; i++) {
-              if (!containsPossibleTopLevelAwait(statements2[i])) {
-                return i;
-              }
-            }
-            return -1;
-          }
-          function currentNode2(position) {
-            const node = baseSyntaxCursor.currentNode(position);
-            if (topLevel && node && containsPossibleTopLevelAwait(node)) {
-              node.intersectsChange = true;
-            }
-            return node;
-          }
-        }
-        function fixupParentReferences(rootNode) {
-          setParentRecursive(
-            rootNode,
-            /*incremental*/
-            true
-          );
-        }
-        Parser2.fixupParentReferences = fixupParentReferences;
-        function createSourceFile2(fileName2, languageVersion2, scriptKind2, isDeclarationFile, statements, endOfFileToken, flags, setExternalModuleIndicator2) {
-          let sourceFile = factory2.createSourceFile(statements, endOfFileToken, flags);
-          setTextRangePosWidth(sourceFile, 0, sourceText.length);
-          setFields(sourceFile);
-          if (!isDeclarationFile && isExternalModule(sourceFile) && sourceFile.transformFlags & 67108864 /* ContainsPossibleTopLevelAwait */) {
-            sourceFile = reparseTopLevelAwait(sourceFile);
-            setFields(sourceFile);
-          }
-          return sourceFile;
-          function setFields(sourceFile2) {
-            sourceFile2.text = sourceText;
-            sourceFile2.bindDiagnostics = [];
-            sourceFile2.bindSuggestionDiagnostics = void 0;
-            sourceFile2.languageVersion = languageVersion2;
-            sourceFile2.fileName = fileName2;
-            sourceFile2.languageVariant = getLanguageVariant(scriptKind2);
-            sourceFile2.isDeclarationFile = isDeclarationFile;
-            sourceFile2.scriptKind = scriptKind2;
-            setExternalModuleIndicator2(sourceFile2);
-            sourceFile2.setExternalModuleIndicator = setExternalModuleIndicator2;
-          }
-        }
-        function setContextFlag(val, flag) {
-          if (val) {
-            contextFlags |= flag;
-          } else {
-            contextFlags &= ~flag;
-          }
-        }
-        function setDisallowInContext(val) {
-          setContextFlag(val, 4096 /* DisallowInContext */);
-        }
-        function setYieldContext(val) {
-          setContextFlag(val, 8192 /* YieldContext */);
-        }
-        function setDecoratorContext(val) {
-          setContextFlag(val, 16384 /* DecoratorContext */);
-        }
-        function setAwaitContext(val) {
-          setContextFlag(val, 32768 /* AwaitContext */);
-        }
-        function doOutsideOfContext(context, func) {
-          const contextFlagsToClear = context & contextFlags;
-          if (contextFlagsToClear) {
-            setContextFlag(
-              /*val*/
-              false,
-              contextFlagsToClear
-            );
-            const result = func();
-            setContextFlag(
-              /*val*/
-              true,
-              contextFlagsToClear
-            );
-            return result;
-          }
-          return func();
-        }
-        function doInsideOfContext(context, func) {
-          const contextFlagsToSet = context & ~contextFlags;
-          if (contextFlagsToSet) {
-            setContextFlag(
-              /*val*/
-              true,
-              contextFlagsToSet
-            );
-            const result = func();
-            setContextFlag(
-              /*val*/
-              false,
-              contextFlagsToSet
-            );
-            return result;
-          }
-          return func();
-        }
-        function allowInAnd(func) {
-          return doOutsideOfContext(4096 /* DisallowInContext */, func);
-        }
-        function disallowInAnd(func) {
-          return doInsideOfContext(4096 /* DisallowInContext */, func);
-        }
-        function allowConditionalTypesAnd(func) {
-          return doOutsideOfContext(65536 /* DisallowConditionalTypesContext */, func);
-        }
-        function disallowConditionalTypesAnd(func) {
-          return doInsideOfContext(65536 /* DisallowConditionalTypesContext */, func);
-        }
-        function doInYieldContext(func) {
-          return doInsideOfContext(8192 /* YieldContext */, func);
-        }
-        function doInDecoratorContext(func) {
-          return doInsideOfContext(16384 /* DecoratorContext */, func);
-        }
-        function doInAwaitContext(func) {
-          return doInsideOfContext(32768 /* AwaitContext */, func);
-        }
-        function doOutsideOfAwaitContext(func) {
-          return doOutsideOfContext(32768 /* AwaitContext */, func);
-        }
-        function doInYieldAndAwaitContext(func) {
-          return doInsideOfContext(8192 /* YieldContext */ | 32768 /* AwaitContext */, func);
-        }
-        function doOutsideOfYieldAndAwaitContext(func) {
-          return doOutsideOfContext(8192 /* YieldContext */ | 32768 /* AwaitContext */, func);
-        }
-        function inContext(flags) {
-          return (contextFlags & flags) !== 0;
-        }
-        function inYieldContext() {
-          return inContext(8192 /* YieldContext */);
-        }
-        function inDisallowInContext() {
-          return inContext(4096 /* DisallowInContext */);
-        }
-        function inDisallowConditionalTypesContext() {
-          return inContext(65536 /* DisallowConditionalTypesContext */);
-        }
-        function inDecoratorContext() {
-          return inContext(16384 /* DecoratorContext */);
-        }
-        function inAwaitContext() {
-          return inContext(32768 /* AwaitContext */);
-        }
-        function parseErrorAtCurrentToken(message, ...args) {
-          return parseErrorAt(scanner2.getTokenStart(), scanner2.getTokenEnd(), message, ...args);
-        }
-        function parseErrorAtPosition(start, length2, message, ...args) {
-          const lastError = lastOrUndefined(parseDiagnostics);
-          let result;
-          if (!lastError || start !== lastError.start) {
-            result = createDetachedDiagnostic(fileName, start, length2, message, ...args);
-            parseDiagnostics.push(result);
-          }
-          parseErrorBeforeNextFinishedNode = true;
-          return result;
-        }
-        function parseErrorAt(start, end, message, ...args) {
-          return parseErrorAtPosition(start, end - start, message, ...args);
-        }
-        function parseErrorAtRange(range, message, ...args) {
-          parseErrorAt(range.pos, range.end, message, ...args);
-        }
-        function scanError(message, length2, arg0) {
-          parseErrorAtPosition(scanner2.getTokenEnd(), length2, message, arg0);
-        }
-        function getNodePos() {
-          return scanner2.getTokenFullStart();
-        }
-        function hasPrecedingJSDocComment() {
-          return scanner2.hasPrecedingJSDocComment();
-        }
-        function token() {
-          return currentToken;
-        }
-        function nextTokenWithoutCheck() {
-          return currentToken = scanner2.scan();
-        }
-        function nextTokenAnd(func) {
-          nextToken();
-          return func();
-        }
-        function nextToken() {
-          if (isKeyword(currentToken) && (scanner2.hasUnicodeEscape() || scanner2.hasExtendedUnicodeEscape())) {
-            parseErrorAt(scanner2.getTokenStart(), scanner2.getTokenEnd(), Diagnostics.Keywords_cannot_contain_escape_characters);
-          }
-          return nextTokenWithoutCheck();
-        }
-        function nextTokenJSDoc() {
-          return currentToken = scanner2.scanJsDocToken();
-        }
-        function nextJSDocCommentTextToken(inBackticks) {
-          return currentToken = scanner2.scanJSDocCommentTextToken(inBackticks);
-        }
-        function reScanGreaterToken() {
-          return currentToken = scanner2.reScanGreaterToken();
-        }
-        function reScanSlashToken() {
-          return currentToken = scanner2.reScanSlashToken();
-        }
-        function reScanTemplateToken(isTaggedTemplate) {
-          return currentToken = scanner2.reScanTemplateToken(isTaggedTemplate);
-        }
-        function reScanLessThanToken() {
-          return currentToken = scanner2.reScanLessThanToken();
-        }
-        function reScanHashToken() {
-          return currentToken = scanner2.reScanHashToken();
-        }
-        function scanJsxIdentifier() {
-          return currentToken = scanner2.scanJsxIdentifier();
-        }
-        function scanJsxText() {
-          return currentToken = scanner2.scanJsxToken();
-        }
-        function scanJsxAttributeValue() {
-          return currentToken = scanner2.scanJsxAttributeValue();
-        }
-        function speculationHelper(callback, speculationKind) {
-          const saveToken = currentToken;
-          const saveParseDiagnosticsLength = parseDiagnostics.length;
-          const saveParseErrorBeforeNextFinishedNode = parseErrorBeforeNextFinishedNode;
-          const saveContextFlags = contextFlags;
-          const result = speculationKind !== 0 /* TryParse */ ? scanner2.lookAhead(callback) : scanner2.tryScan(callback);
-          Debug.assert(saveContextFlags === contextFlags);
-          if (!result || speculationKind !== 0 /* TryParse */) {
-            currentToken = saveToken;
-            if (speculationKind !== 2 /* Reparse */) {
-              parseDiagnostics.length = saveParseDiagnosticsLength;
-            }
-            parseErrorBeforeNextFinishedNode = saveParseErrorBeforeNextFinishedNode;
-          }
-          return result;
-        }
-        function lookAhead(callback) {
-          return speculationHelper(callback, 1 /* Lookahead */);
-        }
-        function tryParse(callback) {
-          return speculationHelper(callback, 0 /* TryParse */);
-        }
-        function isBindingIdentifier() {
-          if (token() === 80 /* Identifier */) {
-            return true;
-          }
-          return token() > 118 /* LastReservedWord */;
-        }
-        function isIdentifier2() {
-          if (token() === 80 /* Identifier */) {
-            return true;
-          }
-          if (token() === 127 /* YieldKeyword */ && inYieldContext()) {
-            return false;
-          }
-          if (token() === 135 /* AwaitKeyword */ && inAwaitContext()) {
-            return false;
-          }
-          return token() > 118 /* LastReservedWord */;
-        }
-        function parseExpected(kind, diagnosticMessage, shouldAdvance = true) {
-          if (token() === kind) {
-            if (shouldAdvance) {
-              nextToken();
-            }
-            return true;
-          }
-          if (diagnosticMessage) {
-            parseErrorAtCurrentToken(diagnosticMessage);
-          } else {
-            parseErrorAtCurrentToken(Diagnostics._0_expected, tokenToString(kind));
-          }
-          return false;
-        }
-        const viableKeywordSuggestions = Object.keys(textToKeywordObj).filter((keyword) => keyword.length > 2);
-        function parseErrorForMissingSemicolonAfter(node) {
-          if (isTaggedTemplateExpression(node)) {
-            parseErrorAt(skipTrivia(sourceText, node.template.pos), node.template.end, Diagnostics.Module_declaration_names_may_only_use_or_quoted_strings);
-            return;
-          }
-          const expressionText = isIdentifier(node) ? idText(node) : void 0;
-          if (!expressionText || !isIdentifierText(expressionText, languageVersion)) {
-            parseErrorAtCurrentToken(Diagnostics._0_expected, tokenToString(27 /* SemicolonToken */));
-            return;
-          }
-          const pos = skipTrivia(sourceText, node.pos);
-          switch (expressionText) {
-            case "const":
-            case "let":
-            case "var":
-              parseErrorAt(pos, node.end, Diagnostics.Variable_declaration_not_allowed_at_this_location);
-              return;
-            case "declare":
-              return;
-            case "interface":
-              parseErrorForInvalidName(Diagnostics.Interface_name_cannot_be_0, Diagnostics.Interface_must_be_given_a_name, 19 /* OpenBraceToken */);
-              return;
-            case "is":
-              parseErrorAt(pos, scanner2.getTokenStart(), Diagnostics.A_type_predicate_is_only_allowed_in_return_type_position_for_functions_and_methods);
-              return;
-            case "module":
-            case "namespace":
-              parseErrorForInvalidName(Diagnostics.Namespace_name_cannot_be_0, Diagnostics.Namespace_must_be_given_a_name, 19 /* OpenBraceToken */);
-              return;
-            case "type":
-              parseErrorForInvalidName(Diagnostics.Type_alias_name_cannot_be_0, Diagnostics.Type_alias_must_be_given_a_name, 64 /* EqualsToken */);
-              return;
-          }
-          const suggestion = getSpellingSuggestion(expressionText, viableKeywordSuggestions, (n) => n) ?? getSpaceSuggestion(expressionText);
-          if (suggestion) {
-            parseErrorAt(pos, node.end, Diagnostics.Unknown_keyword_or_identifier_Did_you_mean_0, suggestion);
-            return;
-          }
-          if (token() === 0 /* Unknown */) {
-            return;
-          }
-          parseErrorAt(pos, node.end, Diagnostics.Unexpected_keyword_or_identifier);
-        }
-        function parseErrorForInvalidName(nameDiagnostic, blankDiagnostic, tokenIfBlankName) {
-          if (token() === tokenIfBlankName) {
-            parseErrorAtCurrentToken(blankDiagnostic);
-          } else {
-            parseErrorAtCurrentToken(nameDiagnostic, scanner2.getTokenValue());
-          }
-        }
-        function getSpaceSuggestion(expressionText) {
-          for (const keyword of viableKeywordSuggestions) {
-            if (expressionText.length > keyword.length + 2 && startsWith(expressionText, keyword)) {
-              return `${keyword} ${expressionText.slice(keyword.length)}`;
-            }
-          }
-          return void 0;
-        }
-        function parseSemicolonAfterPropertyName(name, type, initializer) {
-          if (token() === 60 /* AtToken */ && !scanner2.hasPrecedingLineBreak()) {
-            parseErrorAtCurrentToken(Diagnostics.Decorators_must_precede_the_name_and_all_keywords_of_property_declarations);
-            return;
-          }
-          if (token() === 21 /* OpenParenToken */) {
-            parseErrorAtCurrentToken(Diagnostics.Cannot_start_a_function_call_in_a_type_annotation);
-            nextToken();
-            return;
-          }
-          if (type && !canParseSemicolon()) {
-            if (initializer) {
-              parseErrorAtCurrentToken(Diagnostics._0_expected, tokenToString(27 /* SemicolonToken */));
-            } else {
-              parseErrorAtCurrentToken(Diagnostics.Expected_for_property_initializer);
-            }
-            return;
-          }
-          if (tryParseSemicolon()) {
-            return;
-          }
-          if (initializer) {
-            parseErrorAtCurrentToken(Diagnostics._0_expected, tokenToString(27 /* SemicolonToken */));
-            return;
-          }
-          parseErrorForMissingSemicolonAfter(name);
-        }
-        function parseExpectedJSDoc(kind) {
-          if (token() === kind) {
-            nextTokenJSDoc();
-            return true;
-          }
-          Debug.assert(isKeywordOrPunctuation(kind));
-          parseErrorAtCurrentToken(Diagnostics._0_expected, tokenToString(kind));
-          return false;
-        }
-        function parseExpectedMatchingBrackets(openKind, closeKind, openParsed, openPosition) {
-          if (token() === closeKind) {
-            nextToken();
-            return;
-          }
-          const lastError = parseErrorAtCurrentToken(Diagnostics._0_expected, tokenToString(closeKind));
-          if (!openParsed) {
-            return;
-          }
-          if (lastError) {
-            addRelatedInfo(
-              lastError,
-              createDetachedDiagnostic(fileName, openPosition, 1, Diagnostics.The_parser_expected_to_find_a_1_to_match_the_0_token_here, tokenToString(openKind), tokenToString(closeKind))
-            );
-          }
-        }
-        function parseOptional(t) {
-          if (token() === t) {
-            nextToken();
-            return true;
-          }
-          return false;
-        }
-        function parseOptionalToken(t) {
-          if (token() === t) {
-            return parseTokenNode();
-          }
-          return void 0;
-        }
-        function parseOptionalTokenJSDoc(t) {
-          if (token() === t) {
-            return parseTokenNodeJSDoc();
-          }
-          return void 0;
-        }
-        function parseExpectedToken(t, diagnosticMessage, arg0) {
-          return parseOptionalToken(t) || createMissingNode(
-            t,
-            /*reportAtCurrentPosition*/
-            false,
-            diagnosticMessage || Diagnostics._0_expected,
-            arg0 || tokenToString(t)
-          );
-        }
-        function parseExpectedTokenJSDoc(t) {
-          const optional = parseOptionalTokenJSDoc(t);
-          if (optional)
-            return optional;
-          Debug.assert(isKeywordOrPunctuation(t));
-          return createMissingNode(
-            t,
-            /*reportAtCurrentPosition*/
-            false,
-            Diagnostics._0_expected,
-            tokenToString(t)
-          );
-        }
-        function parseTokenNode() {
-          const pos = getNodePos();
-          const kind = token();
-          nextToken();
-          return finishNode(factoryCreateToken(kind), pos);
-        }
-        function parseTokenNodeJSDoc() {
-          const pos = getNodePos();
-          const kind = token();
-          nextTokenJSDoc();
-          return finishNode(factoryCreateToken(kind), pos);
-        }
-        function canParseSemicolon() {
-          if (token() === 27 /* SemicolonToken */) {
-            return true;
-          }
-          return token() === 20 /* CloseBraceToken */ || token() === 1 /* EndOfFileToken */ || scanner2.hasPrecedingLineBreak();
-        }
-        function tryParseSemicolon() {
-          if (!canParseSemicolon()) {
-            return false;
-          }
-          if (token() === 27 /* SemicolonToken */) {
-            nextToken();
-          }
-          return true;
-        }
-        function parseSemicolon() {
-          return tryParseSemicolon() || parseExpected(27 /* SemicolonToken */);
-        }
-        function createNodeArray(elements, pos, end, hasTrailingComma) {
-          const array = factoryCreateNodeArray(elements, hasTrailingComma);
-          setTextRangePosEnd(array, pos, end ?? scanner2.getTokenFullStart());
-          return array;
-        }
-        function finishNode(node, pos, end) {
-          setTextRangePosEnd(node, pos, end ?? scanner2.getTokenFullStart());
-          if (contextFlags) {
-            node.flags |= contextFlags;
-          }
-          if (parseErrorBeforeNextFinishedNode) {
-            parseErrorBeforeNextFinishedNode = false;
-            node.flags |= 131072 /* ThisNodeHasError */;
-          }
-          return node;
-        }
-        function createMissingNode(kind, reportAtCurrentPosition, diagnosticMessage, ...args) {
-          if (reportAtCurrentPosition) {
-            parseErrorAtPosition(scanner2.getTokenFullStart(), 0, diagnosticMessage, ...args);
-          } else if (diagnosticMessage) {
-            parseErrorAtCurrentToken(diagnosticMessage, ...args);
-          }
-          const pos = getNodePos();
-          const result = kind === 80 /* Identifier */ ? factoryCreateIdentifier(
-            "",
-            /*originalKeywordKind*/
-            void 0
-          ) : isTemplateLiteralKind(kind) ? factory2.createTemplateLiteralLikeNode(
-            kind,
-            "",
-            "",
-            /*templateFlags*/
-            void 0
-          ) : kind === 9 /* NumericLiteral */ ? factoryCreateNumericLiteral(
-            "",
-            /*numericLiteralFlags*/
-            void 0
-          ) : kind === 11 /* StringLiteral */ ? factoryCreateStringLiteral(
-            "",
-            /*isSingleQuote*/
-            void 0
-          ) : kind === 281 /* MissingDeclaration */ ? factory2.createMissingDeclaration() : factoryCreateToken(kind);
-          return finishNode(result, pos);
-        }
-        function internIdentifier(text) {
-          let identifier = identifiers.get(text);
-          if (identifier === void 0) {
-            identifiers.set(text, identifier = text);
-          }
-          return identifier;
-        }
-        function createIdentifier(isIdentifier3, diagnosticMessage, privateIdentifierDiagnosticMessage) {
-          if (isIdentifier3) {
-            identifierCount++;
-            const pos = getNodePos();
-            const originalKeywordKind = token();
-            const text = internIdentifier(scanner2.getTokenValue());
-            const hasExtendedUnicodeEscape = scanner2.hasExtendedUnicodeEscape();
-            nextTokenWithoutCheck();
-            return finishNode(factoryCreateIdentifier(text, originalKeywordKind, hasExtendedUnicodeEscape), pos);
-          }
-          if (token() === 81 /* PrivateIdentifier */) {
-            parseErrorAtCurrentToken(privateIdentifierDiagnosticMessage || Diagnostics.Private_identifiers_are_not_allowed_outside_class_bodies);
-            return createIdentifier(
-              /*isIdentifier*/
-              true
-            );
-          }
-          if (token() === 0 /* Unknown */ && scanner2.tryScan(() => scanner2.reScanInvalidIdentifier() === 80 /* Identifier */)) {
-            return createIdentifier(
-              /*isIdentifier*/
-              true
-            );
-          }
-          identifierCount++;
-          const reportAtCurrentPosition = token() === 1 /* EndOfFileToken */;
-          const isReservedWord = scanner2.isReservedWord();
-          const msgArg = scanner2.getTokenText();
-          const defaultMessage = isReservedWord ? Diagnostics.Identifier_expected_0_is_a_reserved_word_that_cannot_be_used_here : Diagnostics.Identifier_expected;
-          return createMissingNode(80 /* Identifier */, reportAtCurrentPosition, diagnosticMessage || defaultMessage, msgArg);
-        }
-        function parseBindingIdentifier(privateIdentifierDiagnosticMessage) {
-          return createIdentifier(
-            isBindingIdentifier(),
-            /*diagnosticMessage*/
-            void 0,
-            privateIdentifierDiagnosticMessage
-          );
-        }
-        function parseIdentifier(diagnosticMessage, privateIdentifierDiagnosticMessage) {
-          return createIdentifier(isIdentifier2(), diagnosticMessage, privateIdentifierDiagnosticMessage);
-        }
-        function parseIdentifierName(diagnosticMessage) {
-          return createIdentifier(tokenIsIdentifierOrKeyword(token()), diagnosticMessage);
-        }
-        function isLiteralPropertyName() {
-          return tokenIsIdentifierOrKeyword(token()) || token() === 11 /* StringLiteral */ || token() === 9 /* NumericLiteral */;
-        }
-        function isAssertionKey2() {
-          return tokenIsIdentifierOrKeyword(token()) || token() === 11 /* StringLiteral */;
-        }
-        function parsePropertyNameWorker(allowComputedPropertyNames) {
-          if (token() === 11 /* StringLiteral */ || token() === 9 /* NumericLiteral */) {
-            const node = parseLiteralNode();
-            node.text = internIdentifier(node.text);
-            return node;
-          }
-          if (allowComputedPropertyNames && token() === 23 /* OpenBracketToken */) {
-            return parseComputedPropertyName();
-          }
-          if (token() === 81 /* PrivateIdentifier */) {
-            return parsePrivateIdentifier();
-          }
-          return parseIdentifierName();
-        }
-        function parsePropertyName() {
-          return parsePropertyNameWorker(
-            /*allowComputedPropertyNames*/
-            true
-          );
-        }
-        function parseComputedPropertyName() {
-          const pos = getNodePos();
-          parseExpected(23 /* OpenBracketToken */);
-          const expression = allowInAnd(parseExpression);
-          parseExpected(24 /* CloseBracketToken */);
-          return finishNode(factory2.createComputedPropertyName(expression), pos);
-        }
-        function parsePrivateIdentifier() {
-          const pos = getNodePos();
-          const node = factoryCreatePrivateIdentifier(internIdentifier(scanner2.getTokenValue()));
-          nextToken();
-          return finishNode(node, pos);
-        }
-        function parseContextualModifier(t) {
-          return token() === t && tryParse(nextTokenCanFollowModifier);
-        }
-        function nextTokenIsOnSameLineAndCanFollowModifier() {
-          nextToken();
-          if (scanner2.hasPrecedingLineBreak()) {
-            return false;
-          }
-          return canFollowModifier();
-        }
-        function nextTokenCanFollowModifier() {
-          switch (token()) {
-            case 87 /* ConstKeyword */:
-              return nextToken() === 94 /* EnumKeyword */;
-            case 95 /* ExportKeyword */:
-              nextToken();
-              if (token() === 90 /* DefaultKeyword */) {
-                return lookAhead(nextTokenCanFollowDefaultKeyword);
-              }
-              if (token() === 156 /* TypeKeyword */) {
-                return lookAhead(nextTokenCanFollowExportModifier);
-              }
-              return canFollowExportModifier();
-            case 90 /* DefaultKeyword */:
-              return nextTokenCanFollowDefaultKeyword();
-            case 126 /* StaticKeyword */:
-            case 139 /* GetKeyword */:
-            case 153 /* SetKeyword */:
-              nextToken();
-              return canFollowModifier();
-            default:
-              return nextTokenIsOnSameLineAndCanFollowModifier();
-          }
-        }
-        function canFollowExportModifier() {
-          return token() === 60 /* AtToken */ || token() !== 42 /* AsteriskToken */ && token() !== 130 /* AsKeyword */ && token() !== 19 /* OpenBraceToken */ && canFollowModifier();
-        }
-        function nextTokenCanFollowExportModifier() {
-          nextToken();
-          return canFollowExportModifier();
-        }
-        function parseAnyContextualModifier() {
-          return isModifierKind(token()) && tryParse(nextTokenCanFollowModifier);
-        }
-        function canFollowModifier() {
-          return token() === 23 /* OpenBracketToken */ || token() === 19 /* OpenBraceToken */ || token() === 42 /* AsteriskToken */ || token() === 26 /* DotDotDotToken */ || isLiteralPropertyName();
-        }
-        function nextTokenCanFollowDefaultKeyword() {
-          nextToken();
-          return token() === 86 /* ClassKeyword */ || token() === 100 /* FunctionKeyword */ || token() === 120 /* InterfaceKeyword */ || token() === 60 /* AtToken */ || token() === 128 /* AbstractKeyword */ && lookAhead(nextTokenIsClassKeywordOnSameLine) || token() === 134 /* AsyncKeyword */ && lookAhead(nextTokenIsFunctionKeywordOnSameLine);
-        }
-        function isListElement2(parsingContext2, inErrorRecovery) {
-          const node = currentNode(parsingContext2);
-          if (node) {
-            return true;
-          }
-          switch (parsingContext2) {
-            case 0 /* SourceElements */:
-            case 1 /* BlockStatements */:
-            case 3 /* SwitchClauseStatements */:
-              return !(token() === 27 /* SemicolonToken */ && inErrorRecovery) && isStartOfStatement();
-            case 2 /* SwitchClauses */:
-              return token() === 84 /* CaseKeyword */ || token() === 90 /* DefaultKeyword */;
-            case 4 /* TypeMembers */:
-              return lookAhead(isTypeMemberStart);
-            case 5 /* ClassMembers */:
-              return lookAhead(isClassMemberStart) || token() === 27 /* SemicolonToken */ && !inErrorRecovery;
-            case 6 /* EnumMembers */:
-              return token() === 23 /* OpenBracketToken */ || isLiteralPropertyName();
-            case 12 /* ObjectLiteralMembers */:
-              switch (token()) {
-                case 23 /* OpenBracketToken */:
-                case 42 /* AsteriskToken */:
-                case 26 /* DotDotDotToken */:
-                case 25 /* DotToken */:
-                  return true;
-                default:
-                  return isLiteralPropertyName();
-              }
-            case 18 /* RestProperties */:
-              return isLiteralPropertyName();
-            case 9 /* ObjectBindingElements */:
-              return token() === 23 /* OpenBracketToken */ || token() === 26 /* DotDotDotToken */ || isLiteralPropertyName();
-            case 24 /* AssertEntries */:
-              return isAssertionKey2();
-            case 7 /* HeritageClauseElement */:
-              if (token() === 19 /* OpenBraceToken */) {
-                return lookAhead(isValidHeritageClauseObjectLiteral);
-              }
-              if (!inErrorRecovery) {
-                return isStartOfLeftHandSideExpression() && !isHeritageClauseExtendsOrImplementsKeyword();
-              } else {
-                return isIdentifier2() && !isHeritageClauseExtendsOrImplementsKeyword();
-              }
-            case 8 /* VariableDeclarations */:
-              return isBindingIdentifierOrPrivateIdentifierOrPattern();
-            case 10 /* ArrayBindingElements */:
-              return token() === 28 /* CommaToken */ || token() === 26 /* DotDotDotToken */ || isBindingIdentifierOrPrivateIdentifierOrPattern();
-            case 19 /* TypeParameters */:
-              return token() === 103 /* InKeyword */ || token() === 87 /* ConstKeyword */ || isIdentifier2();
-            case 15 /* ArrayLiteralMembers */:
-              switch (token()) {
-                case 28 /* CommaToken */:
-                case 25 /* DotToken */:
-                  return true;
-              }
-            case 11 /* ArgumentExpressions */:
-              return token() === 26 /* DotDotDotToken */ || isStartOfExpression();
-            case 16 /* Parameters */:
-              return isStartOfParameter(
-                /*isJSDocParameter*/
-                false
-              );
-            case 17 /* JSDocParameters */:
-              return isStartOfParameter(
-                /*isJSDocParameter*/
-                true
-              );
-            case 20 /* TypeArguments */:
-            case 21 /* TupleElementTypes */:
-              return token() === 28 /* CommaToken */ || isStartOfType();
-            case 22 /* HeritageClauses */:
-              return isHeritageClause2();
-            case 23 /* ImportOrExportSpecifiers */:
-              return tokenIsIdentifierOrKeyword(token());
-            case 13 /* JsxAttributes */:
-              return tokenIsIdentifierOrKeyword(token()) || token() === 19 /* OpenBraceToken */;
-            case 14 /* JsxChildren */:
-              return true;
-            case 25 /* JSDocComment */:
-              return true;
-            case 26 /* Count */:
-              return Debug.fail("ParsingContext.Count used as a context");
-            default:
-              Debug.assertNever(parsingContext2, "Non-exhaustive case in 'isListElement'.");
-          }
-        }
-        function isValidHeritageClauseObjectLiteral() {
-          Debug.assert(token() === 19 /* OpenBraceToken */);
-          if (nextToken() === 20 /* CloseBraceToken */) {
-            const next = nextToken();
-            return next === 28 /* CommaToken */ || next === 19 /* OpenBraceToken */ || next === 96 /* ExtendsKeyword */ || next === 119 /* ImplementsKeyword */;
-          }
-          return true;
-        }
-        function nextTokenIsIdentifier() {
-          nextToken();
-          return isIdentifier2();
-        }
-        function nextTokenIsIdentifierOrKeyword() {
-          nextToken();
-          return tokenIsIdentifierOrKeyword(token());
-        }
-        function nextTokenIsIdentifierOrKeywordOrGreaterThan() {
-          nextToken();
-          return tokenIsIdentifierOrKeywordOrGreaterThan(token());
-        }
-        function isHeritageClauseExtendsOrImplementsKeyword() {
-          if (token() === 119 /* ImplementsKeyword */ || token() === 96 /* ExtendsKeyword */) {
-            return lookAhead(nextTokenIsStartOfExpression);
-          }
-          return false;
-        }
-        function nextTokenIsStartOfExpression() {
-          nextToken();
-          return isStartOfExpression();
-        }
-        function nextTokenIsStartOfType() {
-          nextToken();
-          return isStartOfType();
-        }
-        function isListTerminator(kind) {
-          if (token() === 1 /* EndOfFileToken */) {
-            return true;
-          }
-          switch (kind) {
-            case 1 /* BlockStatements */:
-            case 2 /* SwitchClauses */:
-            case 4 /* TypeMembers */:
-            case 5 /* ClassMembers */:
-            case 6 /* EnumMembers */:
-            case 12 /* ObjectLiteralMembers */:
-            case 9 /* ObjectBindingElements */:
-            case 23 /* ImportOrExportSpecifiers */:
-            case 24 /* AssertEntries */:
-              return token() === 20 /* CloseBraceToken */;
-            case 3 /* SwitchClauseStatements */:
-              return token() === 20 /* CloseBraceToken */ || token() === 84 /* CaseKeyword */ || token() === 90 /* DefaultKeyword */;
-            case 7 /* HeritageClauseElement */:
-              return token() === 19 /* OpenBraceToken */ || token() === 96 /* ExtendsKeyword */ || token() === 119 /* ImplementsKeyword */;
-            case 8 /* VariableDeclarations */:
-              return isVariableDeclaratorListTerminator();
-            case 19 /* TypeParameters */:
-              return token() === 32 /* GreaterThanToken */ || token() === 21 /* OpenParenToken */ || token() === 19 /* OpenBraceToken */ || token() === 96 /* ExtendsKeyword */ || token() === 119 /* ImplementsKeyword */;
-            case 11 /* ArgumentExpressions */:
-              return token() === 22 /* CloseParenToken */ || token() === 27 /* SemicolonToken */;
-            case 15 /* ArrayLiteralMembers */:
-            case 21 /* TupleElementTypes */:
-            case 10 /* ArrayBindingElements */:
-              return token() === 24 /* CloseBracketToken */;
-            case 17 /* JSDocParameters */:
-            case 16 /* Parameters */:
-            case 18 /* RestProperties */:
-              return token() === 22 /* CloseParenToken */ || token() === 24 /* CloseBracketToken */;
-            case 20 /* TypeArguments */:
-              return token() !== 28 /* CommaToken */;
-            case 22 /* HeritageClauses */:
-              return token() === 19 /* OpenBraceToken */ || token() === 20 /* CloseBraceToken */;
-            case 13 /* JsxAttributes */:
-              return token() === 32 /* GreaterThanToken */ || token() === 44 /* SlashToken */;
-            case 14 /* JsxChildren */:
-              return token() === 30 /* LessThanToken */ && lookAhead(nextTokenIsSlash);
-            default:
-              return false;
-          }
-        }
-        function isVariableDeclaratorListTerminator() {
-          if (canParseSemicolon()) {
-            return true;
-          }
-          if (isInOrOfKeyword(token())) {
-            return true;
-          }
-          if (token() === 39 /* EqualsGreaterThanToken */) {
-            return true;
-          }
-          return false;
-        }
-        function isInSomeParsingContext() {
-          Debug.assert(parsingContext, "Missing parsing context");
-          for (let kind = 0; kind < 26 /* Count */; kind++) {
-            if (parsingContext & 1 << kind) {
-              if (isListElement2(
-                kind,
-                /*inErrorRecovery*/
-                true
-              ) || isListTerminator(kind)) {
-                return true;
-              }
-            }
-          }
-          return false;
-        }
-        function parseList(kind, parseElement) {
-          const saveParsingContext = parsingContext;
-          parsingContext |= 1 << kind;
-          const list = [];
-          const listPos = getNodePos();
-          while (!isListTerminator(kind)) {
-            if (isListElement2(
-              kind,
-              /*inErrorRecovery*/
-              false
-            )) {
-              list.push(parseListElement(kind, parseElement));
-              continue;
-            }
-            if (abortParsingListOrMoveToNextToken(kind)) {
-              break;
-            }
-          }
-          parsingContext = saveParsingContext;
-          return createNodeArray(list, listPos);
-        }
-        function parseListElement(parsingContext2, parseElement) {
-          const node = currentNode(parsingContext2);
-          if (node) {
-            return consumeNode(node);
-          }
-          return parseElement();
-        }
-        function currentNode(parsingContext2, pos) {
-          var _a;
-          if (!syntaxCursor || !isReusableParsingContext(parsingContext2) || parseErrorBeforeNextFinishedNode) {
-            return void 0;
-          }
-          const node = syntaxCursor.currentNode(pos ?? scanner2.getTokenFullStart());
-          if (nodeIsMissing(node) || node.intersectsChange || containsParseError(node)) {
-            return void 0;
-          }
-          const nodeContextFlags = node.flags & 50720768 /* ContextFlags */;
-          if (nodeContextFlags !== contextFlags) {
-            return void 0;
-          }
-          if (!canReuseNode(node, parsingContext2)) {
-            return void 0;
-          }
-          if (canHaveJSDoc(node) && ((_a = node.jsDoc) == null ? void 0 : _a.jsDocCache)) {
-            node.jsDoc.jsDocCache = void 0;
-          }
-          return node;
-        }
-        function consumeNode(node) {
-          scanner2.resetTokenState(node.end);
-          nextToken();
-          return node;
-        }
-        function isReusableParsingContext(parsingContext2) {
-          switch (parsingContext2) {
-            case 5 /* ClassMembers */:
-            case 2 /* SwitchClauses */:
-            case 0 /* SourceElements */:
-            case 1 /* BlockStatements */:
-            case 3 /* SwitchClauseStatements */:
-            case 6 /* EnumMembers */:
-            case 4 /* TypeMembers */:
-            case 8 /* VariableDeclarations */:
-            case 17 /* JSDocParameters */:
-            case 16 /* Parameters */:
-              return true;
-          }
-          return false;
-        }
-        function canReuseNode(node, parsingContext2) {
-          switch (parsingContext2) {
-            case 5 /* ClassMembers */:
-              return isReusableClassMember(node);
-            case 2 /* SwitchClauses */:
-              return isReusableSwitchClause(node);
-            case 0 /* SourceElements */:
-            case 1 /* BlockStatements */:
-            case 3 /* SwitchClauseStatements */:
-              return isReusableStatement(node);
-            case 6 /* EnumMembers */:
-              return isReusableEnumMember(node);
-            case 4 /* TypeMembers */:
-              return isReusableTypeMember(node);
-            case 8 /* VariableDeclarations */:
-              return isReusableVariableDeclaration(node);
-            case 17 /* JSDocParameters */:
-            case 16 /* Parameters */:
-              return isReusableParameter(node);
-          }
-          return false;
-        }
-        function isReusableClassMember(node) {
-          if (node) {
-            switch (node.kind) {
-              case 175 /* Constructor */:
-              case 180 /* IndexSignature */:
-              case 176 /* GetAccessor */:
-              case 177 /* SetAccessor */:
-              case 171 /* PropertyDeclaration */:
-              case 239 /* SemicolonClassElement */:
-                return true;
-              case 173 /* MethodDeclaration */:
-                const methodDeclaration = node;
-                const nameIsConstructor = methodDeclaration.name.kind === 80 /* Identifier */ && methodDeclaration.name.escapedText === "constructor";
-                return !nameIsConstructor;
-            }
-          }
-          return false;
-        }
-        function isReusableSwitchClause(node) {
-          if (node) {
-            switch (node.kind) {
-              case 295 /* CaseClause */:
-              case 296 /* DefaultClause */:
-                return true;
-            }
-          }
-          return false;
-        }
-        function isReusableStatement(node) {
-          if (node) {
-            switch (node.kind) {
-              case 261 /* FunctionDeclaration */:
-              case 242 /* VariableStatement */:
-              case 240 /* Block */:
-              case 244 /* IfStatement */:
-              case 243 /* ExpressionStatement */:
-              case 256 /* ThrowStatement */:
-              case 252 /* ReturnStatement */:
-              case 254 /* SwitchStatement */:
-              case 251 /* BreakStatement */:
-              case 250 /* ContinueStatement */:
-              case 248 /* ForInStatement */:
-              case 249 /* ForOfStatement */:
-              case 247 /* ForStatement */:
-              case 246 /* WhileStatement */:
-              case 253 /* WithStatement */:
-              case 241 /* EmptyStatement */:
-              case 257 /* TryStatement */:
-              case 255 /* LabeledStatement */:
-              case 245 /* DoStatement */:
-              case 258 /* DebuggerStatement */:
-              case 271 /* ImportDeclaration */:
-              case 270 /* ImportEqualsDeclaration */:
-              case 277 /* ExportDeclaration */:
-              case 276 /* ExportAssignment */:
-              case 266 /* ModuleDeclaration */:
-              case 262 /* ClassDeclaration */:
-              case 263 /* InterfaceDeclaration */:
-              case 265 /* EnumDeclaration */:
-              case 264 /* TypeAliasDeclaration */:
-                return true;
-            }
-          }
-          return false;
-        }
-        function isReusableEnumMember(node) {
-          return node.kind === 305 /* EnumMember */;
-        }
-        function isReusableTypeMember(node) {
-          if (node) {
-            switch (node.kind) {
-              case 179 /* ConstructSignature */:
-              case 172 /* MethodSignature */:
-              case 180 /* IndexSignature */:
-              case 170 /* PropertySignature */:
-              case 178 /* CallSignature */:
-                return true;
-            }
-          }
-          return false;
-        }
-        function isReusableVariableDeclaration(node) {
-          if (node.kind !== 259 /* VariableDeclaration */) {
-            return false;
-          }
-          const variableDeclarator = node;
-          return variableDeclarator.initializer === void 0;
-        }
-        function isReusableParameter(node) {
-          if (node.kind !== 168 /* Parameter */) {
-            return false;
-          }
-          const parameter = node;
-          return parameter.initializer === void 0;
-        }
-        function abortParsingListOrMoveToNextToken(kind) {
-          parsingContextErrors(kind);
-          if (isInSomeParsingContext()) {
-            return true;
-          }
-          nextToken();
-          return false;
-        }
-        function parsingContextErrors(context) {
-          switch (context) {
-            case 0 /* SourceElements */:
-              return token() === 90 /* DefaultKeyword */ ? parseErrorAtCurrentToken(Diagnostics._0_expected, tokenToString(95 /* ExportKeyword */)) : parseErrorAtCurrentToken(Diagnostics.Declaration_or_statement_expected);
-            case 1 /* BlockStatements */:
-              return parseErrorAtCurrentToken(Diagnostics.Declaration_or_statement_expected);
-            case 2 /* SwitchClauses */:
-              return parseErrorAtCurrentToken(Diagnostics.case_or_default_expected);
-            case 3 /* SwitchClauseStatements */:
-              return parseErrorAtCurrentToken(Diagnostics.Statement_expected);
-            case 18 /* RestProperties */:
-            case 4 /* TypeMembers */:
-              return parseErrorAtCurrentToken(Diagnostics.Property_or_signature_expected);
-            case 5 /* ClassMembers */:
-              return parseErrorAtCurrentToken(Diagnostics.Unexpected_token_A_constructor_method_accessor_or_property_was_expected);
-            case 6 /* EnumMembers */:
-              return parseErrorAtCurrentToken(Diagnostics.Enum_member_expected);
-            case 7 /* HeritageClauseElement */:
-              return parseErrorAtCurrentToken(Diagnostics.Expression_expected);
-            case 8 /* VariableDeclarations */:
-              return isKeyword(token()) ? parseErrorAtCurrentToken(Diagnostics._0_is_not_allowed_as_a_variable_declaration_name, tokenToString(token())) : parseErrorAtCurrentToken(Diagnostics.Variable_declaration_expected);
-            case 9 /* ObjectBindingElements */:
-              return parseErrorAtCurrentToken(Diagnostics.Property_destructuring_pattern_expected);
-            case 10 /* ArrayBindingElements */:
-              return parseErrorAtCurrentToken(Diagnostics.Array_element_destructuring_pattern_expected);
-            case 11 /* ArgumentExpressions */:
-              return parseErrorAtCurrentToken(Diagnostics.Argument_expression_expected);
-            case 12 /* ObjectLiteralMembers */:
-              return parseErrorAtCurrentToken(Diagnostics.Property_assignment_expected);
-            case 15 /* ArrayLiteralMembers */:
-              return parseErrorAtCurrentToken(Diagnostics.Expression_or_comma_expected);
-            case 17 /* JSDocParameters */:
-              return parseErrorAtCurrentToken(Diagnostics.Parameter_declaration_expected);
-            case 16 /* Parameters */:
-              return isKeyword(token()) ? parseErrorAtCurrentToken(Diagnostics._0_is_not_allowed_as_a_parameter_name, tokenToString(token())) : parseErrorAtCurrentToken(Diagnostics.Parameter_declaration_expected);
-            case 19 /* TypeParameters */:
-              return parseErrorAtCurrentToken(Diagnostics.Type_parameter_declaration_expected);
-            case 20 /* TypeArguments */:
-              return parseErrorAtCurrentToken(Diagnostics.Type_argument_expected);
-            case 21 /* TupleElementTypes */:
-              return parseErrorAtCurrentToken(Diagnostics.Type_expected);
-            case 22 /* HeritageClauses */:
-              return parseErrorAtCurrentToken(Diagnostics.Unexpected_token_expected);
-            case 23 /* ImportOrExportSpecifiers */:
-              return parseErrorAtCurrentToken(Diagnostics.Identifier_expected);
-            case 13 /* JsxAttributes */:
-              return parseErrorAtCurrentToken(Diagnostics.Identifier_expected);
-            case 14 /* JsxChildren */:
-              return parseErrorAtCurrentToken(Diagnostics.Identifier_expected);
-            case 24 /* AssertEntries */:
-              return parseErrorAtCurrentToken(Diagnostics.Identifier_or_string_literal_expected);
-            case 25 /* JSDocComment */:
-              return parseErrorAtCurrentToken(Diagnostics.Identifier_expected);
-            case 26 /* Count */:
-              return Debug.fail("ParsingContext.Count used as a context");
-            default:
-              Debug.assertNever(context);
-          }
-        }
-        function parseDelimitedList(kind, parseElement, considerSemicolonAsDelimiter) {
-          const saveParsingContext = parsingContext;
-          parsingContext |= 1 << kind;
-          const list = [];
-          const listPos = getNodePos();
-          let commaStart = -1;
-          while (true) {
-            if (isListElement2(
-              kind,
-              /*inErrorRecovery*/
-              false
-            )) {
-              const startPos = scanner2.getTokenFullStart();
-              const result = parseListElement(kind, parseElement);
-              if (!result) {
-                parsingContext = saveParsingContext;
-                return void 0;
-              }
-              list.push(result);
-              commaStart = scanner2.getTokenStart();
-              if (parseOptional(28 /* CommaToken */)) {
-                continue;
-              }
-              commaStart = -1;
-              if (isListTerminator(kind)) {
-                break;
-              }
-              parseExpected(28 /* CommaToken */, getExpectedCommaDiagnostic(kind));
-              if (considerSemicolonAsDelimiter && token() === 27 /* SemicolonToken */ && !scanner2.hasPrecedingLineBreak()) {
-                nextToken();
-              }
-              if (startPos === scanner2.getTokenFullStart()) {
-                nextToken();
-              }
-              continue;
-            }
-            if (isListTerminator(kind)) {
-              break;
-            }
-            if (abortParsingListOrMoveToNextToken(kind)) {
-              break;
-            }
-          }
-          parsingContext = saveParsingContext;
-          return createNodeArray(
-            list,
-            listPos,
-            /*end*/
-            void 0,
-            commaStart >= 0
-          );
-        }
-        function getExpectedCommaDiagnostic(kind) {
-          return kind === 6 /* EnumMembers */ ? Diagnostics.An_enum_member_name_must_be_followed_by_a_or : void 0;
-        }
-        function createMissingList() {
-          const list = createNodeArray([], getNodePos());
-          list.isMissingList = true;
-          return list;
-        }
-        function isMissingList(arr) {
-          return !!arr.isMissingList;
-        }
-        function parseBracketedList(kind, parseElement, open, close) {
-          if (parseExpected(open)) {
-            const result = parseDelimitedList(kind, parseElement);
-            parseExpected(close);
-            return result;
-          }
-          return createMissingList();
-        }
-        function parseEntityName(allowReservedWords, diagnosticMessage) {
-          const pos = getNodePos();
-          let entity = allowReservedWords ? parseIdentifierName(diagnosticMessage) : parseIdentifier(diagnosticMessage);
-          while (parseOptional(25 /* DotToken */)) {
-            if (token() === 30 /* LessThanToken */) {
-              break;
-            }
-            entity = finishNode(
-              factory2.createQualifiedName(
-                entity,
-                parseRightSideOfDot(
-                  allowReservedWords,
-                  /*allowPrivateIdentifiers*/
-                  false
-                )
-              ),
-              pos
-            );
-          }
-          return entity;
-        }
-        function createQualifiedName(entity, name) {
-          return finishNode(factory2.createQualifiedName(entity, name), entity.pos);
-        }
-        function parseRightSideOfDot(allowIdentifierNames, allowPrivateIdentifiers) {
-          if (scanner2.hasPrecedingLineBreak() && tokenIsIdentifierOrKeyword(token())) {
-            const matchesPattern = lookAhead(nextTokenIsIdentifierOrKeywordOnSameLine);
-            if (matchesPattern) {
-              return createMissingNode(
-                80 /* Identifier */,
-                /*reportAtCurrentPosition*/
-                true,
-                Diagnostics.Identifier_expected
-              );
-            }
-          }
-          if (token() === 81 /* PrivateIdentifier */) {
-            const node = parsePrivateIdentifier();
-            return allowPrivateIdentifiers ? node : createMissingNode(
-              80 /* Identifier */,
-              /*reportAtCurrentPosition*/
-              true,
-              Diagnostics.Identifier_expected
-            );
-          }
-          return allowIdentifierNames ? parseIdentifierName() : parseIdentifier();
-        }
-        function parseTemplateSpans(isTaggedTemplate) {
-          const pos = getNodePos();
-          const list = [];
-          let node;
-          do {
-            node = parseTemplateSpan(isTaggedTemplate);
-            list.push(node);
-          } while (node.literal.kind === 17 /* TemplateMiddle */);
-          return createNodeArray(list, pos);
-        }
-        function parseTemplateExpression(isTaggedTemplate) {
-          const pos = getNodePos();
-          return finishNode(
-            factory2.createTemplateExpression(
-              parseTemplateHead(isTaggedTemplate),
-              parseTemplateSpans(isTaggedTemplate)
-            ),
-            pos
-          );
-        }
-        function parseTemplateType() {
-          const pos = getNodePos();
-          return finishNode(
-            factory2.createTemplateLiteralType(
-              parseTemplateHead(
-                /*isTaggedTemplate*/
-                false
-              ),
-              parseTemplateTypeSpans()
-            ),
-            pos
-          );
-        }
-        function parseTemplateTypeSpans() {
-          const pos = getNodePos();
-          const list = [];
-          let node;
-          do {
-            node = parseTemplateTypeSpan();
-            list.push(node);
-          } while (node.literal.kind === 17 /* TemplateMiddle */);
-          return createNodeArray(list, pos);
-        }
-        function parseTemplateTypeSpan() {
-          const pos = getNodePos();
-          return finishNode(
-            factory2.createTemplateLiteralTypeSpan(
-              parseType(),
-              parseLiteralOfTemplateSpan(
-                /*isTaggedTemplate*/
-                false
-              )
-            ),
-            pos
-          );
-        }
-        function parseLiteralOfTemplateSpan(isTaggedTemplate) {
-          if (token() === 20 /* CloseBraceToken */) {
-            reScanTemplateToken(isTaggedTemplate);
-            return parseTemplateMiddleOrTemplateTail();
-          } else {
-            return parseExpectedToken(18 /* TemplateTail */, Diagnostics._0_expected, tokenToString(20 /* CloseBraceToken */));
-          }
-        }
-        function parseTemplateSpan(isTaggedTemplate) {
-          const pos = getNodePos();
-          return finishNode(
-            factory2.createTemplateSpan(
-              allowInAnd(parseExpression),
-              parseLiteralOfTemplateSpan(isTaggedTemplate)
-            ),
-            pos
-          );
-        }
-        function parseLiteralNode() {
-          return parseLiteralLikeNode(token());
-        }
-        function parseTemplateHead(isTaggedTemplate) {
-          if (!isTaggedTemplate && scanner2.getTokenFlags() & 26656 /* IsInvalid */) {
-            reScanTemplateToken(
-              /*isTaggedTemplate*/
-              false
-            );
-          }
-          const fragment = parseLiteralLikeNode(token());
-          Debug.assert(fragment.kind === 16 /* TemplateHead */, "Template head has wrong token kind");
-          return fragment;
-        }
-        function parseTemplateMiddleOrTemplateTail() {
-          const fragment = parseLiteralLikeNode(token());
-          Debug.assert(fragment.kind === 17 /* TemplateMiddle */ || fragment.kind === 18 /* TemplateTail */, "Template fragment has wrong token kind");
-          return fragment;
-        }
-        function getTemplateLiteralRawText(kind) {
-          const isLast = kind === 15 /* NoSubstitutionTemplateLiteral */ || kind === 18 /* TemplateTail */;
-          const tokenText = scanner2.getTokenText();
-          return tokenText.substring(1, tokenText.length - (scanner2.isUnterminated() ? 0 : isLast ? 1 : 2));
-        }
-        function parseLiteralLikeNode(kind) {
-          const pos = getNodePos();
-          const node = isTemplateLiteralKind(kind) ? factory2.createTemplateLiteralLikeNode(kind, scanner2.getTokenValue(), getTemplateLiteralRawText(kind), scanner2.getTokenFlags() & 7176 /* TemplateLiteralLikeFlags */) : (
-            // Note that theoretically the following condition would hold true literals like 009,
-            // which is not octal. But because of how the scanner separates the tokens, we would
-            // never get a token like this. Instead, we would get 00 and 9 as two separate tokens.
-            // We also do not need to check for negatives because any prefix operator would be part of a
-            // parent unary expression.
-            kind === 9 /* NumericLiteral */ ? factoryCreateNumericLiteral(scanner2.getTokenValue(), scanner2.getNumericLiteralFlags()) : kind === 11 /* StringLiteral */ ? factoryCreateStringLiteral(
-              scanner2.getTokenValue(),
-              /*isSingleQuote*/
-              void 0,
-              scanner2.hasExtendedUnicodeEscape()
-            ) : isLiteralKind(kind) ? factoryCreateLiteralLikeNode(kind, scanner2.getTokenValue()) : Debug.fail()
-          );
-          if (scanner2.hasExtendedUnicodeEscape()) {
-            node.hasExtendedUnicodeEscape = true;
-          }
-          if (scanner2.isUnterminated()) {
-            node.isUnterminated = true;
-          }
-          nextToken();
-          return finishNode(node, pos);
-        }
-        function parseEntityNameOfTypeReference() {
-          return parseEntityName(
-            /*allowReservedWords*/
-            true,
-            Diagnostics.Type_expected
-          );
-        }
-        function parseTypeArgumentsOfTypeReference() {
-          if (!scanner2.hasPrecedingLineBreak() && reScanLessThanToken() === 30 /* LessThanToken */) {
-            return parseBracketedList(20 /* TypeArguments */, parseType, 30 /* LessThanToken */, 32 /* GreaterThanToken */);
-          }
-        }
-        function parseTypeReference() {
-          const pos = getNodePos();
-          return finishNode(
-            factory2.createTypeReferenceNode(
-              parseEntityNameOfTypeReference(),
-              parseTypeArgumentsOfTypeReference()
-            ),
-            pos
-          );
-        }
-        function typeHasArrowFunctionBlockingParseError(node) {
-          switch (node.kind) {
-            case 182 /* TypeReference */:
-              return nodeIsMissing(node.typeName);
-            case 183 /* FunctionType */:
-            case 184 /* ConstructorType */: {
-              const { parameters, type } = node;
-              return isMissingList(parameters) || typeHasArrowFunctionBlockingParseError(type);
-            }
-            case 195 /* ParenthesizedType */:
-              return typeHasArrowFunctionBlockingParseError(node.type);
-            default:
-              return false;
-          }
-        }
-        function parseThisTypePredicate(lhs) {
-          nextToken();
-          return finishNode(factory2.createTypePredicateNode(
-            /*assertsModifier*/
-            void 0,
-            lhs,
-            parseType()
-          ), lhs.pos);
-        }
-        function parseThisTypeNode() {
-          const pos = getNodePos();
-          nextToken();
-          return finishNode(factory2.createThisTypeNode(), pos);
-        }
-        function parseJSDocAllType() {
-          const pos = getNodePos();
-          nextToken();
-          return finishNode(factory2.createJSDocAllType(), pos);
-        }
-        function parseJSDocNonNullableType() {
-          const pos = getNodePos();
-          nextToken();
-          return finishNode(factory2.createJSDocNonNullableType(
-            parseNonArrayType(),
-            /*postfix*/
-            false
-          ), pos);
-        }
-        function parseJSDocUnknownOrNullableType() {
-          const pos = getNodePos();
-          nextToken();
-          if (token() === 28 /* CommaToken */ || token() === 20 /* CloseBraceToken */ || token() === 22 /* CloseParenToken */ || token() === 32 /* GreaterThanToken */ || token() === 64 /* EqualsToken */ || token() === 52 /* BarToken */) {
-            return finishNode(factory2.createJSDocUnknownType(), pos);
-          } else {
-            return finishNode(factory2.createJSDocNullableType(
-              parseType(),
-              /*postfix*/
-              false
-            ), pos);
-          }
-        }
-        function parseJSDocFunctionType() {
-          const pos = getNodePos();
-          const hasJSDoc = hasPrecedingJSDocComment();
-          if (lookAhead(nextTokenIsOpenParen)) {
-            nextToken();
-            const parameters = parseParameters(4 /* Type */ | 32 /* JSDoc */);
-            const type = parseReturnType(
-              59 /* ColonToken */,
-              /*isType*/
-              false
-            );
-            return withJSDoc(finishNode(factory2.createJSDocFunctionType(parameters, type), pos), hasJSDoc);
-          }
-          return finishNode(factory2.createTypeReferenceNode(
-            parseIdentifierName(),
-            /*typeArguments*/
-            void 0
-          ), pos);
-        }
-        function parseJSDocParameter() {
-          const pos = getNodePos();
-          let name;
-          if (token() === 110 /* ThisKeyword */ || token() === 105 /* NewKeyword */) {
-            name = parseIdentifierName();
-            parseExpected(59 /* ColonToken */);
-          }
-          return finishNode(
-            factory2.createParameterDeclaration(
-              /*modifiers*/
-              void 0,
-              /*dotDotDotToken*/
-              void 0,
-              // TODO(rbuckton): JSDoc parameters don't have names (except `this`/`new`), should we manufacture an empty identifier?
-              name,
-              /*questionToken*/
-              void 0,
-              parseJSDocType(),
-              /*initializer*/
-              void 0
-            ),
-            pos
-          );
-        }
-        function parseJSDocType() {
-          scanner2.setInJSDocType(true);
-          const pos = getNodePos();
-          if (parseOptional(144 /* ModuleKeyword */)) {
-            const moduleTag = factory2.createJSDocNamepathType(
-              /*type*/
-              void 0
-            );
-            terminate:
-              while (true) {
-                switch (token()) {
-                  case 20 /* CloseBraceToken */:
-                  case 1 /* EndOfFileToken */:
-                  case 28 /* CommaToken */:
-                  case 5 /* WhitespaceTrivia */:
-                    break terminate;
-                  default:
-                    nextTokenJSDoc();
-                }
-              }
-            scanner2.setInJSDocType(false);
-            return finishNode(moduleTag, pos);
-          }
-          const hasDotDotDot = parseOptional(26 /* DotDotDotToken */);
-          let type = parseTypeOrTypePredicate();
-          scanner2.setInJSDocType(false);
-          if (hasDotDotDot) {
-            type = finishNode(factory2.createJSDocVariadicType(type), pos);
-          }
-          if (token() === 64 /* EqualsToken */) {
-            nextToken();
-            return finishNode(factory2.createJSDocOptionalType(type), pos);
-          }
-          return type;
-        }
-        function parseTypeQuery() {
-          const pos = getNodePos();
-          parseExpected(114 /* TypeOfKeyword */);
-          const entityName = parseEntityName(
-            /*allowReservedWords*/
-            true
-          );
-          const typeArguments = !scanner2.hasPrecedingLineBreak() ? tryParseTypeArguments() : void 0;
-          return finishNode(factory2.createTypeQueryNode(entityName, typeArguments), pos);
-        }
-        function parseTypeParameter() {
-          const pos = getNodePos();
-          const modifiers = parseModifiers(
-            /*allowDecorators*/
-            false,
-            /*permitConstAsModifier*/
-            true
-          );
-          const name = parseIdentifier();
-          let constraint;
-          let expression;
-          if (parseOptional(96 /* ExtendsKeyword */)) {
-            if (isStartOfType() || !isStartOfExpression()) {
-              constraint = parseType();
-            } else {
-              expression = parseUnaryExpressionOrHigher();
-            }
-          }
-          const defaultType = parseOptional(64 /* EqualsToken */) ? parseType() : void 0;
-          const node = factory2.createTypeParameterDeclaration(modifiers, name, constraint, defaultType);
-          node.expression = expression;
-          return finishNode(node, pos);
-        }
-        function parseTypeParameters() {
-          if (token() === 30 /* LessThanToken */) {
-            return parseBracketedList(19 /* TypeParameters */, parseTypeParameter, 30 /* LessThanToken */, 32 /* GreaterThanToken */);
-          }
-        }
-        function isStartOfParameter(isJSDocParameter) {
-          return token() === 26 /* DotDotDotToken */ || isBindingIdentifierOrPrivateIdentifierOrPattern() || isModifierKind(token()) || token() === 60 /* AtToken */ || isStartOfType(
-            /*inStartOfParameter*/
-            !isJSDocParameter
-          );
-        }
-        function parseNameOfParameter(modifiers) {
-          const name = parseIdentifierOrPattern(Diagnostics.Private_identifiers_cannot_be_used_as_parameters);
-          if (getFullWidth(name) === 0 && !some(modifiers) && isModifierKind(token())) {
-            nextToken();
-          }
-          return name;
-        }
-        function isParameterNameStart() {
-          return isBindingIdentifier() || token() === 23 /* OpenBracketToken */ || token() === 19 /* OpenBraceToken */;
-        }
-        function parseParameter(inOuterAwaitContext) {
-          return parseParameterWorker(inOuterAwaitContext);
-        }
-        function parseParameterForSpeculation(inOuterAwaitContext) {
-          return parseParameterWorker(
-            inOuterAwaitContext,
-            /*allowAmbiguity*/
-            false
-          );
-        }
-        function parseParameterWorker(inOuterAwaitContext, allowAmbiguity = true) {
-          const pos = getNodePos();
-          const hasJSDoc = hasPrecedingJSDocComment();
-          const modifiers = inOuterAwaitContext ? doInAwaitContext(() => parseModifiers(
-            /*allowDecorators*/
-            true
-          )) : doOutsideOfAwaitContext(() => parseModifiers(
-            /*allowDecorators*/
-            true
-          ));
-          if (token() === 110 /* ThisKeyword */) {
-            const node2 = factory2.createParameterDeclaration(
-              modifiers,
-              /*dotDotDotToken*/
-              void 0,
-              createIdentifier(
-                /*isIdentifier*/
-                true
-              ),
-              /*questionToken*/
-              void 0,
-              parseTypeAnnotation(),
-              /*initializer*/
-              void 0
-            );
-            const modifier = firstOrUndefined(modifiers);
-            if (modifier) {
-              parseErrorAtRange(modifier, Diagnostics.Neither_decorators_nor_modifiers_may_be_applied_to_this_parameters);
-            }
-            return withJSDoc(finishNode(node2, pos), hasJSDoc);
-          }
-          const savedTopLevel = topLevel;
-          topLevel = false;
-          const dotDotDotToken = parseOptionalToken(26 /* DotDotDotToken */);
-          if (!allowAmbiguity && !isParameterNameStart()) {
-            return void 0;
-          }
-          const node = withJSDoc(
-            finishNode(
-              factory2.createParameterDeclaration(
-                modifiers,
-                dotDotDotToken,
-                parseNameOfParameter(modifiers),
-                parseOptionalToken(58 /* QuestionToken */),
-                parseTypeAnnotation(),
-                parseInitializer()
-              ),
-              pos
-            ),
-            hasJSDoc
-          );
-          topLevel = savedTopLevel;
-          return node;
-        }
-        function parseReturnType(returnToken, isType) {
-          if (shouldParseReturnType(returnToken, isType)) {
-            return allowConditionalTypesAnd(parseTypeOrTypePredicate);
-          }
-        }
-        function shouldParseReturnType(returnToken, isType) {
-          if (returnToken === 39 /* EqualsGreaterThanToken */) {
-            parseExpected(returnToken);
-            return true;
-          } else if (parseOptional(59 /* ColonToken */)) {
-            return true;
-          } else if (isType && token() === 39 /* EqualsGreaterThanToken */) {
-            parseErrorAtCurrentToken(Diagnostics._0_expected, tokenToString(59 /* ColonToken */));
-            nextToken();
-            return true;
-          }
-          return false;
-        }
-        function parseParametersWorker(flags, allowAmbiguity) {
-          const savedYieldContext = inYieldContext();
-          const savedAwaitContext = inAwaitContext();
-          setYieldContext(!!(flags & 1 /* Yield */));
-          setAwaitContext(!!(flags & 2 /* Await */));
-          const parameters = flags & 32 /* JSDoc */ ? parseDelimitedList(17 /* JSDocParameters */, parseJSDocParameter) : parseDelimitedList(16 /* Parameters */, () => allowAmbiguity ? parseParameter(savedAwaitContext) : parseParameterForSpeculation(savedAwaitContext));
-          setYieldContext(savedYieldContext);
-          setAwaitContext(savedAwaitContext);
-          return parameters;
-        }
-        function parseParameters(flags) {
-          if (!parseExpected(21 /* OpenParenToken */)) {
-            return createMissingList();
-          }
-          const parameters = parseParametersWorker(
-            flags,
-            /*allowAmbiguity*/
-            true
-          );
-          parseExpected(22 /* CloseParenToken */);
-          return parameters;
-        }
-        function parseTypeMemberSemicolon() {
-          if (parseOptional(28 /* CommaToken */)) {
-            return;
-          }
-          parseSemicolon();
-        }
-        function parseSignatureMember(kind) {
-          const pos = getNodePos();
-          const hasJSDoc = hasPrecedingJSDocComment();
-          if (kind === 179 /* ConstructSignature */) {
-            parseExpected(105 /* NewKeyword */);
-          }
-          const typeParameters = parseTypeParameters();
-          const parameters = parseParameters(4 /* Type */);
-          const type = parseReturnType(
-            59 /* ColonToken */,
-            /*isType*/
-            true
-          );
-          parseTypeMemberSemicolon();
-          const node = kind === 178 /* CallSignature */ ? factory2.createCallSignature(typeParameters, parameters, type) : factory2.createConstructSignature(typeParameters, parameters, type);
-          return withJSDoc(finishNode(node, pos), hasJSDoc);
-        }
-        function isIndexSignature() {
-          return token() === 23 /* OpenBracketToken */ && lookAhead(isUnambiguouslyIndexSignature);
-        }
-        function isUnambiguouslyIndexSignature() {
-          nextToken();
-          if (token() === 26 /* DotDotDotToken */ || token() === 24 /* CloseBracketToken */) {
-            return true;
-          }
-          if (isModifierKind(token())) {
-            nextToken();
-            if (isIdentifier2()) {
-              return true;
-            }
-          } else if (!isIdentifier2()) {
-            return false;
-          } else {
-            nextToken();
-          }
-          if (token() === 59 /* ColonToken */ || token() === 28 /* CommaToken */) {
-            return true;
-          }
-          if (token() !== 58 /* QuestionToken */) {
-            return false;
-          }
-          nextToken();
-          return token() === 59 /* ColonToken */ || token() === 28 /* CommaToken */ || token() === 24 /* CloseBracketToken */;
-        }
-        function parseIndexSignatureDeclaration(pos, hasJSDoc, modifiers) {
-          const parameters = parseBracketedList(16 /* Parameters */, () => parseParameter(
-            /*inOuterAwaitContext*/
-            false
-          ), 23 /* OpenBracketToken */, 24 /* CloseBracketToken */);
-          const type = parseTypeAnnotation();
-          parseTypeMemberSemicolon();
-          const node = factory2.createIndexSignature(modifiers, parameters, type);
-          return withJSDoc(finishNode(node, pos), hasJSDoc);
-        }
-        function parsePropertyOrMethodSignature(pos, hasJSDoc, modifiers) {
-          const name = parsePropertyName();
-          const questionToken = parseOptionalToken(58 /* QuestionToken */);
-          let node;
-          if (token() === 21 /* OpenParenToken */ || token() === 30 /* LessThanToken */) {
-            const typeParameters = parseTypeParameters();
-            const parameters = parseParameters(4 /* Type */);
-            const type = parseReturnType(
-              59 /* ColonToken */,
-              /*isType*/
-              true
-            );
-            node = factory2.createMethodSignature(modifiers, name, questionToken, typeParameters, parameters, type);
-          } else {
-            const type = parseTypeAnnotation();
-            node = factory2.createPropertySignature(modifiers, name, questionToken, type);
-            if (token() === 64 /* EqualsToken */)
-              node.initializer = parseInitializer();
-          }
-          parseTypeMemberSemicolon();
-          return withJSDoc(finishNode(node, pos), hasJSDoc);
-        }
-        function isTypeMemberStart() {
-          if (token() === 21 /* OpenParenToken */ || token() === 30 /* LessThanToken */ || token() === 139 /* GetKeyword */ || token() === 153 /* SetKeyword */) {
-            return true;
-          }
-          let idToken = false;
-          while (isModifierKind(token())) {
-            idToken = true;
-            nextToken();
-          }
-          if (token() === 23 /* OpenBracketToken */) {
-            return true;
-          }
-          if (isLiteralPropertyName()) {
-            idToken = true;
-            nextToken();
-          }
-          if (idToken) {
-            return token() === 21 /* OpenParenToken */ || token() === 30 /* LessThanToken */ || token() === 58 /* QuestionToken */ || token() === 59 /* ColonToken */ || token() === 28 /* CommaToken */ || canParseSemicolon();
-          }
-          return false;
-        }
-        function parseTypeMember() {
-          if (token() === 21 /* OpenParenToken */ || token() === 30 /* LessThanToken */) {
-            return parseSignatureMember(178 /* CallSignature */);
-          }
-          if (token() === 105 /* NewKeyword */ && lookAhead(nextTokenIsOpenParenOrLessThan)) {
-            return parseSignatureMember(179 /* ConstructSignature */);
-          }
-          const pos = getNodePos();
-          const hasJSDoc = hasPrecedingJSDocComment();
-          const modifiers = parseModifiers(
-            /*allowDecorators*/
-            false
-          );
-          if (parseContextualModifier(139 /* GetKeyword */)) {
-            return parseAccessorDeclaration(pos, hasJSDoc, modifiers, 176 /* GetAccessor */, 4 /* Type */);
-          }
-          if (parseContextualModifier(153 /* SetKeyword */)) {
-            return parseAccessorDeclaration(pos, hasJSDoc, modifiers, 177 /* SetAccessor */, 4 /* Type */);
-          }
-          if (isIndexSignature()) {
-            return parseIndexSignatureDeclaration(pos, hasJSDoc, modifiers);
-          }
-          return parsePropertyOrMethodSignature(pos, hasJSDoc, modifiers);
-        }
-        function nextTokenIsOpenParenOrLessThan() {
-          nextToken();
-          return token() === 21 /* OpenParenToken */ || token() === 30 /* LessThanToken */;
-        }
-        function nextTokenIsDot() {
-          return nextToken() === 25 /* DotToken */;
-        }
-        function nextTokenIsOpenParenOrLessThanOrDot() {
-          switch (nextToken()) {
-            case 21 /* OpenParenToken */:
-            case 30 /* LessThanToken */:
-            case 25 /* DotToken */:
-              return true;
-          }
-          return false;
-        }
-        function parseTypeLiteral() {
-          const pos = getNodePos();
-          return finishNode(factory2.createTypeLiteralNode(parseObjectTypeMembers()), pos);
-        }
-        function parseObjectTypeMembers() {
-          let members;
-          if (parseExpected(19 /* OpenBraceToken */)) {
-            members = parseList(4 /* TypeMembers */, parseTypeMember);
-            parseExpected(20 /* CloseBraceToken */);
-          } else {
-            members = createMissingList();
-          }
-          return members;
-        }
-        function isStartOfMappedType() {
-          nextToken();
-          if (token() === 40 /* PlusToken */ || token() === 41 /* MinusToken */) {
-            return nextToken() === 148 /* ReadonlyKeyword */;
-          }
-          if (token() === 148 /* ReadonlyKeyword */) {
-            nextToken();
-          }
-          return token() === 23 /* OpenBracketToken */ && nextTokenIsIdentifier() && nextToken() === 103 /* InKeyword */;
-        }
-        function parseMappedTypeParameter() {
-          const pos = getNodePos();
-          const name = parseIdentifierName();
-          parseExpected(103 /* InKeyword */);
-          const type = parseType();
-          return finishNode(factory2.createTypeParameterDeclaration(
-            /*modifiers*/
-            void 0,
-            name,
-            type,
-            /*defaultType*/
-            void 0
-          ), pos);
-        }
-        function parseMappedType() {
-          const pos = getNodePos();
-          parseExpected(19 /* OpenBraceToken */);
-          let readonlyToken;
-          if (token() === 148 /* ReadonlyKeyword */ || token() === 40 /* PlusToken */ || token() === 41 /* MinusToken */) {
-            readonlyToken = parseTokenNode();
-            if (readonlyToken.kind !== 148 /* ReadonlyKeyword */) {
-              parseExpected(148 /* ReadonlyKeyword */);
-            }
-          }
-          parseExpected(23 /* OpenBracketToken */);
-          const typeParameter = parseMappedTypeParameter();
-          const nameType = parseOptional(130 /* AsKeyword */) ? parseType() : void 0;
-          parseExpected(24 /* CloseBracketToken */);
-          let questionToken;
-          if (token() === 58 /* QuestionToken */ || token() === 40 /* PlusToken */ || token() === 41 /* MinusToken */) {
-            questionToken = parseTokenNode();
-            if (questionToken.kind !== 58 /* QuestionToken */) {
-              parseExpected(58 /* QuestionToken */);
-            }
-          }
-          const type = parseTypeAnnotation();
-          parseSemicolon();
-          const members = parseList(4 /* TypeMembers */, parseTypeMember);
-          parseExpected(20 /* CloseBraceToken */);
-          return finishNode(factory2.createMappedTypeNode(readonlyToken, typeParameter, nameType, questionToken, type, members), pos);
-        }
-        function parseTupleElementType() {
-          const pos = getNodePos();
-          if (parseOptional(26 /* DotDotDotToken */)) {
-            return finishNode(factory2.createRestTypeNode(parseType()), pos);
-          }
-          const type = parseType();
-          if (isJSDocNullableType(type) && type.pos === type.type.pos) {
-            const node = factory2.createOptionalTypeNode(type.type);
-            setTextRange(node, type);
-            node.flags = type.flags;
-            return node;
-          }
-          return type;
-        }
-        function isNextTokenColonOrQuestionColon() {
-          return nextToken() === 59 /* ColonToken */ || token() === 58 /* QuestionToken */ && nextToken() === 59 /* ColonToken */;
-        }
-        function isTupleElementName() {
-          if (token() === 26 /* DotDotDotToken */) {
-            return tokenIsIdentifierOrKeyword(nextToken()) && isNextTokenColonOrQuestionColon();
-          }
-          return tokenIsIdentifierOrKeyword(token()) && isNextTokenColonOrQuestionColon();
-        }
-        function parseTupleElementNameOrTupleElementType() {
-          if (lookAhead(isTupleElementName)) {
-            const pos = getNodePos();
-            const hasJSDoc = hasPrecedingJSDocComment();
-            const dotDotDotToken = parseOptionalToken(26 /* DotDotDotToken */);
-            const name = parseIdentifierName();
-            const questionToken = parseOptionalToken(58 /* QuestionToken */);
-            parseExpected(59 /* ColonToken */);
-            const type = parseTupleElementType();
-            const node = factory2.createNamedTupleMember(dotDotDotToken, name, questionToken, type);
-            return withJSDoc(finishNode(node, pos), hasJSDoc);
-          }
-          return parseTupleElementType();
-        }
-        function parseTupleType() {
-          const pos = getNodePos();
-          return finishNode(
-            factory2.createTupleTypeNode(
-              parseBracketedList(21 /* TupleElementTypes */, parseTupleElementNameOrTupleElementType, 23 /* OpenBracketToken */, 24 /* CloseBracketToken */)
-            ),
-            pos
-          );
-        }
-        function parseParenthesizedType() {
-          const pos = getNodePos();
-          parseExpected(21 /* OpenParenToken */);
-          const type = parseType();
-          parseExpected(22 /* CloseParenToken */);
-          return finishNode(factory2.createParenthesizedType(type), pos);
-        }
-        function parseModifiersForConstructorType() {
-          let modifiers;
-          if (token() === 128 /* AbstractKeyword */) {
-            const pos = getNodePos();
-            nextToken();
-            const modifier = finishNode(factoryCreateToken(128 /* AbstractKeyword */), pos);
-            modifiers = createNodeArray([modifier], pos);
-          }
-          return modifiers;
-        }
-        function parseFunctionOrConstructorType() {
-          const pos = getNodePos();
-          const hasJSDoc = hasPrecedingJSDocComment();
-          const modifiers = parseModifiersForConstructorType();
-          const isConstructorType = parseOptional(105 /* NewKeyword */);
-          Debug.assert(!modifiers || isConstructorType, "Per isStartOfFunctionOrConstructorType, a function type cannot have modifiers.");
-          const typeParameters = parseTypeParameters();
-          const parameters = parseParameters(4 /* Type */);
-          const type = parseReturnType(
-            39 /* EqualsGreaterThanToken */,
-            /*isType*/
-            false
-          );
-          const node = isConstructorType ? factory2.createConstructorTypeNode(modifiers, typeParameters, parameters, type) : factory2.createFunctionTypeNode(typeParameters, parameters, type);
-          return withJSDoc(finishNode(node, pos), hasJSDoc);
-        }
-        function parseKeywordAndNoDot() {
-          const node = parseTokenNode();
-          return token() === 25 /* DotToken */ ? void 0 : node;
-        }
-        function parseLiteralTypeNode(negative) {
-          const pos = getNodePos();
-          if (negative) {
-            nextToken();
-          }
-          let expression = token() === 112 /* TrueKeyword */ || token() === 97 /* FalseKeyword */ || token() === 106 /* NullKeyword */ ? parseTokenNode() : parseLiteralLikeNode(token());
-          if (negative) {
-            expression = finishNode(factory2.createPrefixUnaryExpression(41 /* MinusToken */, expression), pos);
-          }
-          return finishNode(factory2.createLiteralTypeNode(expression), pos);
-        }
-        function isStartOfTypeOfImportType() {
-          nextToken();
-          return token() === 102 /* ImportKeyword */;
-        }
-        function parseImportTypeAssertions() {
-          const pos = getNodePos();
-          const openBracePosition = scanner2.getTokenStart();
-          parseExpected(19 /* OpenBraceToken */);
-          const multiLine = scanner2.hasPrecedingLineBreak();
-          parseExpected(132 /* AssertKeyword */);
-          parseExpected(59 /* ColonToken */);
-          const clause = parseAssertClause(
-            /*skipAssertKeyword*/
-            true
-          );
-          if (!parseExpected(20 /* CloseBraceToken */)) {
-            const lastError = lastOrUndefined(parseDiagnostics);
-            if (lastError && lastError.code === Diagnostics._0_expected.code) {
-              addRelatedInfo(
-                lastError,
-                createDetachedDiagnostic(fileName, openBracePosition, 1, Diagnostics.The_parser_expected_to_find_a_1_to_match_the_0_token_here, "{", "}")
-              );
-            }
-          }
-          return finishNode(factory2.createImportTypeAssertionContainer(clause, multiLine), pos);
-        }
-        function parseImportType() {
-          sourceFlags |= 2097152 /* PossiblyContainsDynamicImport */;
-          const pos = getNodePos();
-          const isTypeOf = parseOptional(114 /* TypeOfKeyword */);
-          parseExpected(102 /* ImportKeyword */);
-          parseExpected(21 /* OpenParenToken */);
-          const type = parseType();
-          let assertions;
-          if (parseOptional(28 /* CommaToken */)) {
-            assertions = parseImportTypeAssertions();
-          }
-          parseExpected(22 /* CloseParenToken */);
-          const qualifier = parseOptional(25 /* DotToken */) ? parseEntityNameOfTypeReference() : void 0;
-          const typeArguments = parseTypeArgumentsOfTypeReference();
-          return finishNode(factory2.createImportTypeNode(type, assertions, qualifier, typeArguments, isTypeOf), pos);
-        }
-        function nextTokenIsNumericOrBigIntLiteral() {
-          nextToken();
-          return token() === 9 /* NumericLiteral */ || token() === 10 /* BigIntLiteral */;
-        }
-        function parseNonArrayType() {
-          switch (token()) {
-            case 133 /* AnyKeyword */:
-            case 159 /* UnknownKeyword */:
-            case 154 /* StringKeyword */:
-            case 150 /* NumberKeyword */:
-            case 162 /* BigIntKeyword */:
-            case 155 /* SymbolKeyword */:
-            case 136 /* BooleanKeyword */:
-            case 157 /* UndefinedKeyword */:
-            case 146 /* NeverKeyword */:
-            case 151 /* ObjectKeyword */:
-              return tryParse(parseKeywordAndNoDot) || parseTypeReference();
-            case 67 /* AsteriskEqualsToken */:
-              scanner2.reScanAsteriskEqualsToken();
-            case 42 /* AsteriskToken */:
-              return parseJSDocAllType();
-            case 61 /* QuestionQuestionToken */:
-              scanner2.reScanQuestionToken();
-            case 58 /* QuestionToken */:
-              return parseJSDocUnknownOrNullableType();
-            case 100 /* FunctionKeyword */:
-              return parseJSDocFunctionType();
-            case 54 /* ExclamationToken */:
-              return parseJSDocNonNullableType();
-            case 15 /* NoSubstitutionTemplateLiteral */:
-            case 11 /* StringLiteral */:
-            case 9 /* NumericLiteral */:
-            case 10 /* BigIntLiteral */:
-            case 112 /* TrueKeyword */:
-            case 97 /* FalseKeyword */:
-            case 106 /* NullKeyword */:
-              return parseLiteralTypeNode();
-            case 41 /* MinusToken */:
-              return lookAhead(nextTokenIsNumericOrBigIntLiteral) ? parseLiteralTypeNode(
-                /*negative*/
-                true
-              ) : parseTypeReference();
-            case 116 /* VoidKeyword */:
-              return parseTokenNode();
-            case 110 /* ThisKeyword */: {
-              const thisKeyword = parseThisTypeNode();
-              if (token() === 142 /* IsKeyword */ && !scanner2.hasPrecedingLineBreak()) {
-                return parseThisTypePredicate(thisKeyword);
-              } else {
-                return thisKeyword;
-              }
-            }
-            case 114 /* TypeOfKeyword */:
-              return lookAhead(isStartOfTypeOfImportType) ? parseImportType() : parseTypeQuery();
-            case 19 /* OpenBraceToken */:
-              return lookAhead(isStartOfMappedType) ? parseMappedType() : parseTypeLiteral();
-            case 23 /* OpenBracketToken */:
-              return parseTupleType();
-            case 21 /* OpenParenToken */:
-              return parseParenthesizedType();
-            case 102 /* ImportKeyword */:
-              return parseImportType();
-            case 131 /* AssertsKeyword */:
-              return lookAhead(nextTokenIsIdentifierOrKeywordOnSameLine) ? parseAssertsTypePredicate() : parseTypeReference();
-            case 16 /* TemplateHead */:
-              return parseTemplateType();
-            default:
-              return parseTypeReference();
-          }
-        }
-        function isStartOfType(inStartOfParameter) {
-          switch (token()) {
-            case 133 /* AnyKeyword */:
-            case 159 /* UnknownKeyword */:
-            case 154 /* StringKeyword */:
-            case 150 /* NumberKeyword */:
-            case 162 /* BigIntKeyword */:
-            case 136 /* BooleanKeyword */:
-            case 148 /* ReadonlyKeyword */:
-            case 155 /* SymbolKeyword */:
-            case 158 /* UniqueKeyword */:
-            case 116 /* VoidKeyword */:
-            case 157 /* UndefinedKeyword */:
-            case 106 /* NullKeyword */:
-            case 110 /* ThisKeyword */:
-            case 114 /* TypeOfKeyword */:
-            case 146 /* NeverKeyword */:
-            case 19 /* OpenBraceToken */:
-            case 23 /* OpenBracketToken */:
-            case 30 /* LessThanToken */:
-            case 52 /* BarToken */:
-            case 51 /* AmpersandToken */:
-            case 105 /* NewKeyword */:
-            case 11 /* StringLiteral */:
-            case 9 /* NumericLiteral */:
-            case 10 /* BigIntLiteral */:
-            case 112 /* TrueKeyword */:
-            case 97 /* FalseKeyword */:
-            case 151 /* ObjectKeyword */:
-            case 42 /* AsteriskToken */:
-            case 58 /* QuestionToken */:
-            case 54 /* ExclamationToken */:
-            case 26 /* DotDotDotToken */:
-            case 140 /* InferKeyword */:
-            case 102 /* ImportKeyword */:
-            case 131 /* AssertsKeyword */:
-            case 15 /* NoSubstitutionTemplateLiteral */:
-            case 16 /* TemplateHead */:
-              return true;
-            case 100 /* FunctionKeyword */:
-              return !inStartOfParameter;
-            case 41 /* MinusToken */:
-              return !inStartOfParameter && lookAhead(nextTokenIsNumericOrBigIntLiteral);
-            case 21 /* OpenParenToken */:
-              return !inStartOfParameter && lookAhead(isStartOfParenthesizedOrFunctionType);
-            default:
-              return isIdentifier2();
-          }
-        }
-        function isStartOfParenthesizedOrFunctionType() {
-          nextToken();
-          return token() === 22 /* CloseParenToken */ || isStartOfParameter(
-            /*isJSDocParameter*/
-            false
-          ) || isStartOfType();
-        }
-        function parsePostfixTypeOrHigher() {
-          const pos = getNodePos();
-          let type = parseNonArrayType();
-          while (!scanner2.hasPrecedingLineBreak()) {
-            switch (token()) {
-              case 54 /* ExclamationToken */:
-                nextToken();
-                type = finishNode(factory2.createJSDocNonNullableType(
-                  type,
-                  /*postfix*/
-                  true
-                ), pos);
-                break;
-              case 58 /* QuestionToken */:
-                if (lookAhead(nextTokenIsStartOfType)) {
-                  return type;
-                }
-                nextToken();
-                type = finishNode(factory2.createJSDocNullableType(
-                  type,
-                  /*postfix*/
-                  true
-                ), pos);
-                break;
-              case 23 /* OpenBracketToken */:
-                parseExpected(23 /* OpenBracketToken */);
-                if (isStartOfType()) {
-                  const indexType = parseType();
-                  parseExpected(24 /* CloseBracketToken */);
-                  type = finishNode(factory2.createIndexedAccessTypeNode(type, indexType), pos);
-                } else {
-                  parseExpected(24 /* CloseBracketToken */);
-                  type = finishNode(factory2.createArrayTypeNode(type), pos);
-                }
-                break;
-              default:
-                return type;
-            }
-          }
-          return type;
-        }
-        function parseTypeOperator(operator) {
-          const pos = getNodePos();
-          parseExpected(operator);
-          return finishNode(factory2.createTypeOperatorNode(operator, parseTypeOperatorOrHigher()), pos);
-        }
-        function tryParseConstraintOfInferType() {
-          if (parseOptional(96 /* ExtendsKeyword */)) {
-            const constraint = disallowConditionalTypesAnd(parseType);
-            if (inDisallowConditionalTypesContext() || token() !== 58 /* QuestionToken */) {
-              return constraint;
-            }
-          }
-        }
-        function parseTypeParameterOfInferType() {
-          const pos = getNodePos();
-          const name = parseIdentifier();
-          const constraint = tryParse(tryParseConstraintOfInferType);
-          const node = factory2.createTypeParameterDeclaration(
-            /*modifiers*/
-            void 0,
-            name,
-            constraint
-          );
-          return finishNode(node, pos);
-        }
-        function parseInferType() {
-          const pos = getNodePos();
-          parseExpected(140 /* InferKeyword */);
-          return finishNode(factory2.createInferTypeNode(parseTypeParameterOfInferType()), pos);
-        }
-        function parseTypeOperatorOrHigher() {
-          const operator = token();
-          switch (operator) {
-            case 143 /* KeyOfKeyword */:
-            case 158 /* UniqueKeyword */:
-            case 148 /* ReadonlyKeyword */:
-              return parseTypeOperator(operator);
-            case 140 /* InferKeyword */:
-              return parseInferType();
-          }
-          return allowConditionalTypesAnd(parsePostfixTypeOrHigher);
-        }
-        function parseFunctionOrConstructorTypeToError(isInUnionType) {
-          if (isStartOfFunctionTypeOrConstructorType()) {
-            const type = parseFunctionOrConstructorType();
-            let diagnostic;
-            if (isFunctionTypeNode(type)) {
-              diagnostic = isInUnionType ? Diagnostics.Function_type_notation_must_be_parenthesized_when_used_in_a_union_type : Diagnostics.Function_type_notation_must_be_parenthesized_when_used_in_an_intersection_type;
-            } else {
-              diagnostic = isInUnionType ? Diagnostics.Constructor_type_notation_must_be_parenthesized_when_used_in_a_union_type : Diagnostics.Constructor_type_notation_must_be_parenthesized_when_used_in_an_intersection_type;
-            }
-            parseErrorAtRange(type, diagnostic);
-            return type;
-          }
-          return void 0;
-        }
-        function parseUnionOrIntersectionType(operator, parseConstituentType, createTypeNode) {
-          const pos = getNodePos();
-          const isUnionType = operator === 52 /* BarToken */;
-          const hasLeadingOperator = parseOptional(operator);
-          let type = hasLeadingOperator && parseFunctionOrConstructorTypeToError(isUnionType) || parseConstituentType();
-          if (token() === operator || hasLeadingOperator) {
-            const types = [type];
-            while (parseOptional(operator)) {
-              types.push(parseFunctionOrConstructorTypeToError(isUnionType) || parseConstituentType());
-            }
-            type = finishNode(createTypeNode(createNodeArray(types, pos)), pos);
-          }
-          return type;
-        }
-        function parseIntersectionTypeOrHigher() {
-          return parseUnionOrIntersectionType(51 /* AmpersandToken */, parseTypeOperatorOrHigher, factory2.createIntersectionTypeNode);
-        }
-        function parseUnionTypeOrHigher() {
-          return parseUnionOrIntersectionType(52 /* BarToken */, parseIntersectionTypeOrHigher, factory2.createUnionTypeNode);
-        }
-        function nextTokenIsNewKeyword() {
-          nextToken();
-          return token() === 105 /* NewKeyword */;
-        }
-        function isStartOfFunctionTypeOrConstructorType() {
-          if (token() === 30 /* LessThanToken */) {
-            return true;
-          }
-          if (token() === 21 /* OpenParenToken */ && lookAhead(isUnambiguouslyStartOfFunctionType)) {
-            return true;
-          }
-          return token() === 105 /* NewKeyword */ || token() === 128 /* AbstractKeyword */ && lookAhead(nextTokenIsNewKeyword);
-        }
-        function skipParameterStart() {
-          if (isModifierKind(token())) {
-            parseModifiers(
-              /*allowDecorators*/
-              false
-            );
-          }
-          if (isIdentifier2() || token() === 110 /* ThisKeyword */) {
-            nextToken();
-            return true;
-          }
-          if (token() === 23 /* OpenBracketToken */ || token() === 19 /* OpenBraceToken */) {
-            const previousErrorCount = parseDiagnostics.length;
-            parseIdentifierOrPattern();
-            return previousErrorCount === parseDiagnostics.length;
-          }
-          return false;
-        }
-        function isUnambiguouslyStartOfFunctionType() {
-          nextToken();
-          if (token() === 22 /* CloseParenToken */ || token() === 26 /* DotDotDotToken */) {
-            return true;
-          }
-          if (skipParameterStart()) {
-            if (token() === 59 /* ColonToken */ || token() === 28 /* CommaToken */ || token() === 58 /* QuestionToken */ || token() === 64 /* EqualsToken */) {
-              return true;
-            }
-            if (token() === 22 /* CloseParenToken */) {
-              nextToken();
-              if (token() === 39 /* EqualsGreaterThanToken */) {
-                return true;
-              }
-            }
-          }
-          return false;
-        }
-        function parseTypeOrTypePredicate() {
-          const pos = getNodePos();
-          const typePredicateVariable = isIdentifier2() && tryParse(parseTypePredicatePrefix);
-          const type = parseType();
-          if (typePredicateVariable) {
-            return finishNode(factory2.createTypePredicateNode(
-              /*assertsModifier*/
-              void 0,
-              typePredicateVariable,
-              type
-            ), pos);
-          } else {
-            return type;
-          }
-        }
-        function parseTypePredicatePrefix() {
-          const id = parseIdentifier();
-          if (token() === 142 /* IsKeyword */ && !scanner2.hasPrecedingLineBreak()) {
-            nextToken();
-            return id;
-          }
-        }
-        function parseAssertsTypePredicate() {
-          const pos = getNodePos();
-          const assertsModifier = parseExpectedToken(131 /* AssertsKeyword */);
-          const parameterName = token() === 110 /* ThisKeyword */ ? parseThisTypeNode() : parseIdentifier();
-          const type = parseOptional(142 /* IsKeyword */) ? parseType() : void 0;
-          return finishNode(factory2.createTypePredicateNode(assertsModifier, parameterName, type), pos);
-        }
-        function parseType() {
-          if (contextFlags & 40960 /* TypeExcludesFlags */) {
-            return doOutsideOfContext(40960 /* TypeExcludesFlags */, parseType);
-          }
-          if (isStartOfFunctionTypeOrConstructorType()) {
-            return parseFunctionOrConstructorType();
-          }
-          const pos = getNodePos();
-          const type = parseUnionTypeOrHigher();
-          if (!inDisallowConditionalTypesContext() && !scanner2.hasPrecedingLineBreak() && parseOptional(96 /* ExtendsKeyword */)) {
-            const extendsType = disallowConditionalTypesAnd(parseType);
-            parseExpected(58 /* QuestionToken */);
-            const trueType = allowConditionalTypesAnd(parseType);
-            parseExpected(59 /* ColonToken */);
-            const falseType = allowConditionalTypesAnd(parseType);
-            return finishNode(factory2.createConditionalTypeNode(type, extendsType, trueType, falseType), pos);
-          }
-          return type;
-        }
-        function parseTypeAnnotation() {
-          return parseOptional(59 /* ColonToken */) ? parseType() : void 0;
-        }
-        function isStartOfLeftHandSideExpression() {
-          switch (token()) {
-            case 110 /* ThisKeyword */:
-            case 108 /* SuperKeyword */:
-            case 106 /* NullKeyword */:
-            case 112 /* TrueKeyword */:
-            case 97 /* FalseKeyword */:
-            case 9 /* NumericLiteral */:
-            case 10 /* BigIntLiteral */:
-            case 11 /* StringLiteral */:
-            case 15 /* NoSubstitutionTemplateLiteral */:
-            case 16 /* TemplateHead */:
-            case 21 /* OpenParenToken */:
-            case 23 /* OpenBracketToken */:
-            case 19 /* OpenBraceToken */:
-            case 100 /* FunctionKeyword */:
-            case 86 /* ClassKeyword */:
-            case 105 /* NewKeyword */:
-            case 44 /* SlashToken */:
-            case 69 /* SlashEqualsToken */:
-            case 80 /* Identifier */:
-              return true;
-            case 102 /* ImportKeyword */:
-              return lookAhead(nextTokenIsOpenParenOrLessThanOrDot);
-            default:
-              return isIdentifier2();
-          }
-        }
-        function isStartOfExpression() {
-          if (isStartOfLeftHandSideExpression()) {
-            return true;
-          }
-          switch (token()) {
-            case 40 /* PlusToken */:
-            case 41 /* MinusToken */:
-            case 55 /* TildeToken */:
-            case 54 /* ExclamationToken */:
-            case 91 /* DeleteKeyword */:
-            case 114 /* TypeOfKeyword */:
-            case 116 /* VoidKeyword */:
-            case 46 /* PlusPlusToken */:
-            case 47 /* MinusMinusToken */:
-            case 30 /* LessThanToken */:
-            case 135 /* AwaitKeyword */:
-            case 127 /* YieldKeyword */:
-            case 81 /* PrivateIdentifier */:
-            case 60 /* AtToken */:
-              return true;
-            default:
-              if (isBinaryOperator2()) {
-                return true;
-              }
-              return isIdentifier2();
-          }
-        }
-        function isStartOfExpressionStatement() {
-          return token() !== 19 /* OpenBraceToken */ && token() !== 100 /* FunctionKeyword */ && token() !== 86 /* ClassKeyword */ && token() !== 60 /* AtToken */ && isStartOfExpression();
-        }
-        function parseExpression() {
-          const saveDecoratorContext = inDecoratorContext();
-          if (saveDecoratorContext) {
-            setDecoratorContext(
-              /*val*/
-              false
-            );
-          }
-          const pos = getNodePos();
-          let expr = parseAssignmentExpressionOrHigher(
-            /*allowReturnTypeInArrowFunction*/
-            true
-          );
-          let operatorToken;
-          while (operatorToken = parseOptionalToken(28 /* CommaToken */)) {
-            expr = makeBinaryExpression(expr, operatorToken, parseAssignmentExpressionOrHigher(
-              /*allowReturnTypeInArrowFunction*/
-              true
-            ), pos);
-          }
-          if (saveDecoratorContext) {
-            setDecoratorContext(
-              /*val*/
-              true
-            );
-          }
-          return expr;
-        }
-        function parseInitializer() {
-          return parseOptional(64 /* EqualsToken */) ? parseAssignmentExpressionOrHigher(
-            /*allowReturnTypeInArrowFunction*/
-            true
-          ) : void 0;
-        }
-        function parseAssignmentExpressionOrHigher(allowReturnTypeInArrowFunction) {
-          if (isYieldExpression2()) {
-            return parseYieldExpression();
-          }
-          const arrowExpression = tryParseParenthesizedArrowFunctionExpression(allowReturnTypeInArrowFunction) || tryParseAsyncSimpleArrowFunctionExpression(allowReturnTypeInArrowFunction);
-          if (arrowExpression) {
-            return arrowExpression;
-          }
-          const pos = getNodePos();
-          const expr = parseBinaryExpressionOrHigher(0 /* Lowest */);
-          if (expr.kind === 80 /* Identifier */ && token() === 39 /* EqualsGreaterThanToken */) {
-            return parseSimpleArrowFunctionExpression(
-              pos,
-              expr,
-              allowReturnTypeInArrowFunction,
-              /*asyncModifier*/
-              void 0
-            );
-          }
-          if (isLeftHandSideExpression(expr) && isAssignmentOperator(reScanGreaterToken())) {
-            return makeBinaryExpression(expr, parseTokenNode(), parseAssignmentExpressionOrHigher(allowReturnTypeInArrowFunction), pos);
-          }
-          return parseConditionalExpressionRest(expr, pos, allowReturnTypeInArrowFunction);
-        }
-        function isYieldExpression2() {
-          if (token() === 127 /* YieldKeyword */) {
-            if (inYieldContext()) {
-              return true;
-            }
-            return lookAhead(nextTokenIsIdentifierOrKeywordOrLiteralOnSameLine);
-          }
-          return false;
-        }
-        function nextTokenIsIdentifierOnSameLine() {
-          nextToken();
-          return !scanner2.hasPrecedingLineBreak() && isIdentifier2();
-        }
-        function parseYieldExpression() {
-          const pos = getNodePos();
-          nextToken();
-          if (!scanner2.hasPrecedingLineBreak() && (token() === 42 /* AsteriskToken */ || isStartOfExpression())) {
-            return finishNode(
-              factory2.createYieldExpression(
-                parseOptionalToken(42 /* AsteriskToken */),
-                parseAssignmentExpressionOrHigher(
-                  /*allowReturnTypeInArrowFunction*/
-                  true
-                )
-              ),
-              pos
-            );
-          } else {
-            return finishNode(factory2.createYieldExpression(
-              /*asteriskToken*/
-              void 0,
-              /*expression*/
-              void 0
-            ), pos);
-          }
-        }
-        function parseSimpleArrowFunctionExpression(pos, identifier, allowReturnTypeInArrowFunction, asyncModifier) {
-          Debug.assert(token() === 39 /* EqualsGreaterThanToken */, "parseSimpleArrowFunctionExpression should only have been called if we had a =>");
-          const parameter = factory2.createParameterDeclaration(
-            /*modifiers*/
-            void 0,
-            /*dotDotDotToken*/
-            void 0,
-            identifier,
-            /*questionToken*/
-            void 0,
-            /*type*/
-            void 0,
-            /*initializer*/
-            void 0
-          );
-          finishNode(parameter, identifier.pos);
-          const parameters = createNodeArray([parameter], parameter.pos, parameter.end);
-          const equalsGreaterThanToken = parseExpectedToken(39 /* EqualsGreaterThanToken */);
-          const body = parseArrowFunctionExpressionBody(
-            /*isAsync*/
-            !!asyncModifier,
-            allowReturnTypeInArrowFunction
-          );
-          const node = factory2.createArrowFunction(
-            asyncModifier,
-            /*typeParameters*/
-            void 0,
-            parameters,
-            /*type*/
-            void 0,
-            equalsGreaterThanToken,
-            body
-          );
-          return addJSDocComment(finishNode(node, pos));
-        }
-        function tryParseParenthesizedArrowFunctionExpression(allowReturnTypeInArrowFunction) {
-          const triState = isParenthesizedArrowFunctionExpression();
-          if (triState === 0 /* False */) {
-            return void 0;
-          }
-          return triState === 1 /* True */ ? parseParenthesizedArrowFunctionExpression(
-            /*allowAmbiguity*/
-            true,
-            /*allowReturnTypeInArrowFunction*/
-            true
-          ) : tryParse(() => parsePossibleParenthesizedArrowFunctionExpression(allowReturnTypeInArrowFunction));
-        }
-        function isParenthesizedArrowFunctionExpression() {
-          if (token() === 21 /* OpenParenToken */ || token() === 30 /* LessThanToken */ || token() === 134 /* AsyncKeyword */) {
-            return lookAhead(isParenthesizedArrowFunctionExpressionWorker);
-          }
-          if (token() === 39 /* EqualsGreaterThanToken */) {
-            return 1 /* True */;
-          }
-          return 0 /* False */;
-        }
-        function isParenthesizedArrowFunctionExpressionWorker() {
-          if (token() === 134 /* AsyncKeyword */) {
-            nextToken();
-            if (scanner2.hasPrecedingLineBreak()) {
-              return 0 /* False */;
-            }
-            if (token() !== 21 /* OpenParenToken */ && token() !== 30 /* LessThanToken */) {
-              return 0 /* False */;
-            }
-          }
-          const first2 = token();
-          const second = nextToken();
-          if (first2 === 21 /* OpenParenToken */) {
-            if (second === 22 /* CloseParenToken */) {
-              const third = nextToken();
-              switch (third) {
-                case 39 /* EqualsGreaterThanToken */:
-                case 59 /* ColonToken */:
-                case 19 /* OpenBraceToken */:
-                  return 1 /* True */;
-                default:
-                  return 0 /* False */;
-              }
-            }
-            if (second === 23 /* OpenBracketToken */ || second === 19 /* OpenBraceToken */) {
-              return 2 /* Unknown */;
-            }
-            if (second === 26 /* DotDotDotToken */) {
-              return 1 /* True */;
-            }
-            if (isModifierKind(second) && second !== 134 /* AsyncKeyword */ && lookAhead(nextTokenIsIdentifier)) {
-              if (nextToken() === 130 /* AsKeyword */) {
-                return 0 /* False */;
-              }
-              return 1 /* True */;
-            }
-            if (!isIdentifier2() && second !== 110 /* ThisKeyword */) {
-              return 0 /* False */;
-            }
-            switch (nextToken()) {
-              case 59 /* ColonToken */:
-                return 1 /* True */;
-              case 58 /* QuestionToken */:
-                nextToken();
-                if (token() === 59 /* ColonToken */ || token() === 28 /* CommaToken */ || token() === 64 /* EqualsToken */ || token() === 22 /* CloseParenToken */) {
-                  return 1 /* True */;
-                }
-                return 0 /* False */;
-              case 28 /* CommaToken */:
-              case 64 /* EqualsToken */:
-              case 22 /* CloseParenToken */:
-                return 2 /* Unknown */;
-            }
-            return 0 /* False */;
-          } else {
-            Debug.assert(first2 === 30 /* LessThanToken */);
-            if (!isIdentifier2() && token() !== 87 /* ConstKeyword */) {
-              return 0 /* False */;
-            }
-            if (languageVariant === 1 /* JSX */) {
-              const isArrowFunctionInJsx = lookAhead(() => {
-                parseOptional(87 /* ConstKeyword */);
-                const third = nextToken();
-                if (third === 96 /* ExtendsKeyword */) {
-                  const fourth = nextToken();
-                  switch (fourth) {
-                    case 64 /* EqualsToken */:
-                    case 32 /* GreaterThanToken */:
-                    case 44 /* SlashToken */:
-                      return false;
-                    default:
-                      return true;
-                  }
-                } else if (third === 28 /* CommaToken */ || third === 64 /* EqualsToken */) {
-                  return true;
-                }
-                return false;
-              });
-              if (isArrowFunctionInJsx) {
-                return 1 /* True */;
-              }
-              return 0 /* False */;
-            }
-            return 2 /* Unknown */;
-          }
-        }
-        function parsePossibleParenthesizedArrowFunctionExpression(allowReturnTypeInArrowFunction) {
-          const tokenPos = scanner2.getTokenStart();
-          if (notParenthesizedArrow == null ? void 0 : notParenthesizedArrow.has(tokenPos)) {
-            return void 0;
-          }
-          const result = parseParenthesizedArrowFunctionExpression(
-            /*allowAmbiguity*/
-            false,
-            allowReturnTypeInArrowFunction
-          );
-          if (!result) {
-            (notParenthesizedArrow || (notParenthesizedArrow = /* @__PURE__ */ new Set())).add(tokenPos);
-          }
-          return result;
-        }
-        function tryParseAsyncSimpleArrowFunctionExpression(allowReturnTypeInArrowFunction) {
-          if (token() === 134 /* AsyncKeyword */) {
-            if (lookAhead(isUnParenthesizedAsyncArrowFunctionWorker) === 1 /* True */) {
-              const pos = getNodePos();
-              const asyncModifier = parseModifiersForArrowFunction();
-              const expr = parseBinaryExpressionOrHigher(0 /* Lowest */);
-              return parseSimpleArrowFunctionExpression(pos, expr, allowReturnTypeInArrowFunction, asyncModifier);
-            }
-          }
-          return void 0;
-        }
-        function isUnParenthesizedAsyncArrowFunctionWorker() {
-          if (token() === 134 /* AsyncKeyword */) {
-            nextToken();
-            if (scanner2.hasPrecedingLineBreak() || token() === 39 /* EqualsGreaterThanToken */) {
-              return 0 /* False */;
-            }
-            const expr = parseBinaryExpressionOrHigher(0 /* Lowest */);
-            if (!scanner2.hasPrecedingLineBreak() && expr.kind === 80 /* Identifier */ && token() === 39 /* EqualsGreaterThanToken */) {
-              return 1 /* True */;
-            }
-          }
-          return 0 /* False */;
-        }
-        function parseParenthesizedArrowFunctionExpression(allowAmbiguity, allowReturnTypeInArrowFunction) {
-          const pos = getNodePos();
-          const hasJSDoc = hasPrecedingJSDocComment();
-          const modifiers = parseModifiersForArrowFunction();
-          const isAsync = some(modifiers, isAsyncModifier) ? 2 /* Await */ : 0 /* None */;
-          const typeParameters = parseTypeParameters();
-          let parameters;
-          if (!parseExpected(21 /* OpenParenToken */)) {
-            if (!allowAmbiguity) {
-              return void 0;
-            }
-            parameters = createMissingList();
-          } else {
-            if (!allowAmbiguity) {
-              const maybeParameters = parseParametersWorker(isAsync, allowAmbiguity);
-              if (!maybeParameters) {
-                return void 0;
-              }
-              parameters = maybeParameters;
-            } else {
-              parameters = parseParametersWorker(isAsync, allowAmbiguity);
-            }
-            if (!parseExpected(22 /* CloseParenToken */) && !allowAmbiguity) {
-              return void 0;
-            }
-          }
-          const hasReturnColon = token() === 59 /* ColonToken */;
-          const type = parseReturnType(
-            59 /* ColonToken */,
-            /*isType*/
-            false
-          );
-          if (type && !allowAmbiguity && typeHasArrowFunctionBlockingParseError(type)) {
-            return void 0;
-          }
-          let unwrappedType = type;
-          while ((unwrappedType == null ? void 0 : unwrappedType.kind) === 195 /* ParenthesizedType */) {
-            unwrappedType = unwrappedType.type;
-          }
-          const hasJSDocFunctionType = unwrappedType && isJSDocFunctionType(unwrappedType);
-          if (!allowAmbiguity && token() !== 39 /* EqualsGreaterThanToken */ && (hasJSDocFunctionType || token() !== 19 /* OpenBraceToken */)) {
-            return void 0;
-          }
-          const lastToken = token();
-          const equalsGreaterThanToken = parseExpectedToken(39 /* EqualsGreaterThanToken */);
-          const body = lastToken === 39 /* EqualsGreaterThanToken */ || lastToken === 19 /* OpenBraceToken */ ? parseArrowFunctionExpressionBody(some(modifiers, isAsyncModifier), allowReturnTypeInArrowFunction) : parseIdentifier();
-          if (!allowReturnTypeInArrowFunction && hasReturnColon) {
-            if (token() !== 59 /* ColonToken */) {
-              return void 0;
-            }
-          }
-          const node = factory2.createArrowFunction(modifiers, typeParameters, parameters, type, equalsGreaterThanToken, body);
-          return withJSDoc(finishNode(node, pos), hasJSDoc);
-        }
-        function parseArrowFunctionExpressionBody(isAsync, allowReturnTypeInArrowFunction) {
-          if (token() === 19 /* OpenBraceToken */) {
-            return parseFunctionBlock(isAsync ? 2 /* Await */ : 0 /* None */);
-          }
-          if (token() !== 27 /* SemicolonToken */ && token() !== 100 /* FunctionKeyword */ && token() !== 86 /* ClassKeyword */ && isStartOfStatement() && !isStartOfExpressionStatement()) {
-            return parseFunctionBlock(16 /* IgnoreMissingOpenBrace */ | (isAsync ? 2 /* Await */ : 0 /* None */));
-          }
-          const savedTopLevel = topLevel;
-          topLevel = false;
-          const node = isAsync ? doInAwaitContext(() => parseAssignmentExpressionOrHigher(allowReturnTypeInArrowFunction)) : doOutsideOfAwaitContext(() => parseAssignmentExpressionOrHigher(allowReturnTypeInArrowFunction));
-          topLevel = savedTopLevel;
-          return node;
-        }
-        function parseConditionalExpressionRest(leftOperand, pos, allowReturnTypeInArrowFunction) {
-          const questionToken = parseOptionalToken(58 /* QuestionToken */);
-          if (!questionToken) {
-            return leftOperand;
-          }
-          let colonToken;
-          return finishNode(
-            factory2.createConditionalExpression(
-              leftOperand,
-              questionToken,
-              doOutsideOfContext(disallowInAndDecoratorContext, () => parseAssignmentExpressionOrHigher(
-                /*allowReturnTypeInArrowFunction*/
-                false
-              )),
-              colonToken = parseExpectedToken(59 /* ColonToken */),
-              nodeIsPresent(colonToken) ? parseAssignmentExpressionOrHigher(allowReturnTypeInArrowFunction) : createMissingNode(
-                80 /* Identifier */,
-                /*reportAtCurrentPosition*/
-                false,
-                Diagnostics._0_expected,
-                tokenToString(59 /* ColonToken */)
-              )
-            ),
-            pos
-          );
-        }
-        function parseBinaryExpressionOrHigher(precedence) {
-          const pos = getNodePos();
-          const leftOperand = parseUnaryExpressionOrHigher();
-          return parseBinaryExpressionRest(precedence, leftOperand, pos);
-        }
-        function isInOrOfKeyword(t) {
-          return t === 103 /* InKeyword */ || t === 164 /* OfKeyword */;
-        }
-        function parseBinaryExpressionRest(precedence, leftOperand, pos) {
-          while (true) {
-            reScanGreaterToken();
-            const newPrecedence = getBinaryOperatorPrecedence(token());
-            const consumeCurrentOperator = token() === 43 /* AsteriskAsteriskToken */ ? newPrecedence >= precedence : newPrecedence > precedence;
-            if (!consumeCurrentOperator) {
-              break;
-            }
-            if (token() === 103 /* InKeyword */ && inDisallowInContext()) {
-              break;
-            }
-            if (token() === 130 /* AsKeyword */ || token() === 152 /* SatisfiesKeyword */) {
-              if (scanner2.hasPrecedingLineBreak()) {
-                break;
-              } else {
-                const keywordKind = token();
-                nextToken();
-                leftOperand = keywordKind === 152 /* SatisfiesKeyword */ ? makeSatisfiesExpression(leftOperand, parseType()) : makeAsExpression(leftOperand, parseType());
-              }
-            } else {
-              leftOperand = makeBinaryExpression(leftOperand, parseTokenNode(), parseBinaryExpressionOrHigher(newPrecedence), pos);
-            }
-          }
-          return leftOperand;
-        }
-        function isBinaryOperator2() {
-          if (inDisallowInContext() && token() === 103 /* InKeyword */) {
-            return false;
-          }
-          return getBinaryOperatorPrecedence(token()) > 0;
-        }
-        function makeSatisfiesExpression(left, right) {
-          return finishNode(factory2.createSatisfiesExpression(left, right), left.pos);
-        }
-        function makeBinaryExpression(left, operatorToken, right, pos) {
-          return finishNode(factory2.createBinaryExpression(left, operatorToken, right), pos);
-        }
-        function makeAsExpression(left, right) {
-          return finishNode(factory2.createAsExpression(left, right), left.pos);
-        }
-        function parsePrefixUnaryExpression() {
-          const pos = getNodePos();
-          return finishNode(factory2.createPrefixUnaryExpression(token(), nextTokenAnd(parseSimpleUnaryExpression)), pos);
-        }
-        function parseDeleteExpression() {
-          const pos = getNodePos();
-          return finishNode(factory2.createDeleteExpression(nextTokenAnd(parseSimpleUnaryExpression)), pos);
-        }
-        function parseTypeOfExpression() {
-          const pos = getNodePos();
-          return finishNode(factory2.createTypeOfExpression(nextTokenAnd(parseSimpleUnaryExpression)), pos);
-        }
-        function parseVoidExpression() {
-          const pos = getNodePos();
-          return finishNode(factory2.createVoidExpression(nextTokenAnd(parseSimpleUnaryExpression)), pos);
-        }
-        function isAwaitExpression2() {
-          if (token() === 135 /* AwaitKeyword */) {
-            if (inAwaitContext()) {
-              return true;
-            }
-            return lookAhead(nextTokenIsIdentifierOrKeywordOrLiteralOnSameLine);
-          }
-          return false;
-        }
-        function parseAwaitExpression() {
-          const pos = getNodePos();
-          return finishNode(factory2.createAwaitExpression(nextTokenAnd(parseSimpleUnaryExpression)), pos);
-        }
-        function parseUnaryExpressionOrHigher() {
-          if (isUpdateExpression()) {
-            const pos = getNodePos();
-            const updateExpression = parseUpdateExpression();
-            return token() === 43 /* AsteriskAsteriskToken */ ? parseBinaryExpressionRest(getBinaryOperatorPrecedence(token()), updateExpression, pos) : updateExpression;
-          }
-          const unaryOperator = token();
-          const simpleUnaryExpression = parseSimpleUnaryExpression();
-          if (token() === 43 /* AsteriskAsteriskToken */) {
-            const pos = skipTrivia(sourceText, simpleUnaryExpression.pos);
-            const { end } = simpleUnaryExpression;
-            if (simpleUnaryExpression.kind === 215 /* TypeAssertionExpression */) {
-              parseErrorAt(pos, end, Diagnostics.A_type_assertion_expression_is_not_allowed_in_the_left_hand_side_of_an_exponentiation_expression_Consider_enclosing_the_expression_in_parentheses);
-            } else {
-              Debug.assert(isKeywordOrPunctuation(unaryOperator));
-              parseErrorAt(pos, end, Diagnostics.An_unary_expression_with_the_0_operator_is_not_allowed_in_the_left_hand_side_of_an_exponentiation_expression_Consider_enclosing_the_expression_in_parentheses, tokenToString(unaryOperator));
-            }
-          }
-          return simpleUnaryExpression;
-        }
-        function parseSimpleUnaryExpression() {
-          switch (token()) {
-            case 40 /* PlusToken */:
-            case 41 /* MinusToken */:
-            case 55 /* TildeToken */:
-            case 54 /* ExclamationToken */:
-              return parsePrefixUnaryExpression();
-            case 91 /* DeleteKeyword */:
-              return parseDeleteExpression();
-            case 114 /* TypeOfKeyword */:
-              return parseTypeOfExpression();
-            case 116 /* VoidKeyword */:
-              return parseVoidExpression();
-            case 30 /* LessThanToken */:
-              if (languageVariant === 1 /* JSX */) {
-                return parseJsxElementOrSelfClosingElementOrFragment(
-                  /*inExpressionContext*/
-                  true,
-                  /*topInvalidNodePosition*/
-                  void 0,
-                  /*openingTag*/
-                  void 0,
-                  /*mustBeUnary*/
-                  true
-                );
-              }
-              return parseTypeAssertion();
-            case 135 /* AwaitKeyword */:
-              if (isAwaitExpression2()) {
-                return parseAwaitExpression();
-              }
-            default:
-              return parseUpdateExpression();
-          }
-        }
-        function isUpdateExpression() {
-          switch (token()) {
-            case 40 /* PlusToken */:
-            case 41 /* MinusToken */:
-            case 55 /* TildeToken */:
-            case 54 /* ExclamationToken */:
-            case 91 /* DeleteKeyword */:
-            case 114 /* TypeOfKeyword */:
-            case 116 /* VoidKeyword */:
-            case 135 /* AwaitKeyword */:
-              return false;
-            case 30 /* LessThanToken */:
-              if (languageVariant !== 1 /* JSX */) {
-                return false;
-              }
-            default:
-              return true;
-          }
-        }
-        function parseUpdateExpression() {
-          if (token() === 46 /* PlusPlusToken */ || token() === 47 /* MinusMinusToken */) {
-            const pos = getNodePos();
-            return finishNode(factory2.createPrefixUnaryExpression(token(), nextTokenAnd(parseLeftHandSideExpressionOrHigher)), pos);
-          } else if (languageVariant === 1 /* JSX */ && token() === 30 /* LessThanToken */ && lookAhead(nextTokenIsIdentifierOrKeywordOrGreaterThan)) {
-            return parseJsxElementOrSelfClosingElementOrFragment(
-              /*inExpressionContext*/
-              true
-            );
-          }
-          const expression = parseLeftHandSideExpressionOrHigher();
-          Debug.assert(isLeftHandSideExpression(expression));
-          if ((token() === 46 /* PlusPlusToken */ || token() === 47 /* MinusMinusToken */) && !scanner2.hasPrecedingLineBreak()) {
-            const operator = token();
-            nextToken();
-            return finishNode(factory2.createPostfixUnaryExpression(expression, operator), expression.pos);
-          }
-          return expression;
-        }
-        function parseLeftHandSideExpressionOrHigher() {
-          const pos = getNodePos();
-          let expression;
-          if (token() === 102 /* ImportKeyword */) {
-            if (lookAhead(nextTokenIsOpenParenOrLessThan)) {
-              sourceFlags |= 2097152 /* PossiblyContainsDynamicImport */;
-              expression = parseTokenNode();
-            } else if (lookAhead(nextTokenIsDot)) {
-              nextToken();
-              nextToken();
-              expression = finishNode(factory2.createMetaProperty(102 /* ImportKeyword */, parseIdentifierName()), pos);
-              sourceFlags |= 4194304 /* PossiblyContainsImportMeta */;
-            } else {
-              expression = parseMemberExpressionOrHigher();
-            }
-          } else {
-            expression = token() === 108 /* SuperKeyword */ ? parseSuperExpression() : parseMemberExpressionOrHigher();
-          }
-          return parseCallExpressionRest(pos, expression);
-        }
-        function parseMemberExpressionOrHigher() {
-          const pos = getNodePos();
-          const expression = parsePrimaryExpression();
-          return parseMemberExpressionRest(
-            pos,
-            expression,
-            /*allowOptionalChain*/
-            true
-          );
-        }
-        function parseSuperExpression() {
-          const pos = getNodePos();
-          let expression = parseTokenNode();
-          if (token() === 30 /* LessThanToken */) {
-            const startPos = getNodePos();
-            const typeArguments = tryParse(parseTypeArgumentsInExpression);
-            if (typeArguments !== void 0) {
-              parseErrorAt(startPos, getNodePos(), Diagnostics.super_may_not_use_type_arguments);
-              if (!isTemplateStartOfTaggedTemplate()) {
-                expression = factory2.createExpressionWithTypeArguments(expression, typeArguments);
-              }
-            }
-          }
-          if (token() === 21 /* OpenParenToken */ || token() === 25 /* DotToken */ || token() === 23 /* OpenBracketToken */) {
-            return expression;
-          }
-          parseExpectedToken(25 /* DotToken */, Diagnostics.super_must_be_followed_by_an_argument_list_or_member_access);
-          return finishNode(factoryCreatePropertyAccessExpression(expression, parseRightSideOfDot(
-            /*allowIdentifierNames*/
-            true,
-            /*allowPrivateIdentifiers*/
-            true
-          )), pos);
-        }
-        function parseJsxElementOrSelfClosingElementOrFragment(inExpressionContext, topInvalidNodePosition, openingTag, mustBeUnary = false) {
-          const pos = getNodePos();
-          const opening = parseJsxOpeningOrSelfClosingElementOrOpeningFragment(inExpressionContext);
-          let result;
-          if (opening.kind === 285 /* JsxOpeningElement */) {
-            let children = parseJsxChildren(opening);
-            let closingElement;
-            const lastChild = children[children.length - 1];
-            if ((lastChild == null ? void 0 : lastChild.kind) === 283 /* JsxElement */ && !tagNamesAreEquivalent(lastChild.openingElement.tagName, lastChild.closingElement.tagName) && tagNamesAreEquivalent(opening.tagName, lastChild.closingElement.tagName)) {
-              const end = lastChild.children.end;
-              const newLast = finishNode(
-                factory2.createJsxElement(
-                  lastChild.openingElement,
-                  lastChild.children,
-                  finishNode(factory2.createJsxClosingElement(finishNode(factoryCreateIdentifier(""), end, end)), end, end)
-                ),
-                lastChild.openingElement.pos,
-                end
-              );
-              children = createNodeArray([...children.slice(0, children.length - 1), newLast], children.pos, end);
-              closingElement = lastChild.closingElement;
-            } else {
-              closingElement = parseJsxClosingElement(opening, inExpressionContext);
-              if (!tagNamesAreEquivalent(opening.tagName, closingElement.tagName)) {
-                if (openingTag && isJsxOpeningElement(openingTag) && tagNamesAreEquivalent(closingElement.tagName, openingTag.tagName)) {
-                  parseErrorAtRange(opening.tagName, Diagnostics.JSX_element_0_has_no_corresponding_closing_tag, getTextOfNodeFromSourceText(sourceText, opening.tagName));
-                } else {
-                  parseErrorAtRange(closingElement.tagName, Diagnostics.Expected_corresponding_JSX_closing_tag_for_0, getTextOfNodeFromSourceText(sourceText, opening.tagName));
-                }
-              }
-            }
-            result = finishNode(factory2.createJsxElement(opening, children, closingElement), pos);
-          } else if (opening.kind === 288 /* JsxOpeningFragment */) {
-            result = finishNode(factory2.createJsxFragment(opening, parseJsxChildren(opening), parseJsxClosingFragment(inExpressionContext)), pos);
-          } else {
-            Debug.assert(opening.kind === 284 /* JsxSelfClosingElement */);
-            result = opening;
-          }
-          if (!mustBeUnary && inExpressionContext && token() === 30 /* LessThanToken */) {
-            const topBadPos = typeof topInvalidNodePosition === "undefined" ? result.pos : topInvalidNodePosition;
-            const invalidElement = tryParse(() => parseJsxElementOrSelfClosingElementOrFragment(
-              /*inExpressionContext*/
-              true,
-              topBadPos
-            ));
-            if (invalidElement) {
-              const operatorToken = createMissingNode(
-                28 /* CommaToken */,
-                /*reportAtCurrentPosition*/
-                false
-              );
-              setTextRangePosWidth(operatorToken, invalidElement.pos, 0);
-              parseErrorAt(skipTrivia(sourceText, topBadPos), invalidElement.end, Diagnostics.JSX_expressions_must_have_one_parent_element);
-              return finishNode(factory2.createBinaryExpression(result, operatorToken, invalidElement), pos);
-            }
-          }
-          return result;
-        }
-        function parseJsxText() {
-          const pos = getNodePos();
-          const node = factory2.createJsxText(scanner2.getTokenValue(), currentToken === 13 /* JsxTextAllWhiteSpaces */);
-          currentToken = scanner2.scanJsxToken();
-          return finishNode(node, pos);
-        }
-        function parseJsxChild(openingTag, token2) {
-          switch (token2) {
-            case 1 /* EndOfFileToken */:
-              if (isJsxOpeningFragment(openingTag)) {
-                parseErrorAtRange(openingTag, Diagnostics.JSX_fragment_has_no_corresponding_closing_tag);
-              } else {
-                const tag = openingTag.tagName;
-                const start = Math.min(skipTrivia(sourceText, tag.pos), tag.end);
-                parseErrorAt(start, tag.end, Diagnostics.JSX_element_0_has_no_corresponding_closing_tag, getTextOfNodeFromSourceText(sourceText, openingTag.tagName));
-              }
-              return void 0;
-            case 31 /* LessThanSlashToken */:
-            case 7 /* ConflictMarkerTrivia */:
-              return void 0;
-            case 12 /* JsxText */:
-            case 13 /* JsxTextAllWhiteSpaces */:
-              return parseJsxText();
-            case 19 /* OpenBraceToken */:
-              return parseJsxExpression(
-                /*inExpressionContext*/
-                false
-              );
-            case 30 /* LessThanToken */:
-              return parseJsxElementOrSelfClosingElementOrFragment(
-                /*inExpressionContext*/
-                false,
-                /*topInvalidNodePosition*/
-                void 0,
-                openingTag
-              );
-            default:
-              return Debug.assertNever(token2);
-          }
-        }
-        function parseJsxChildren(openingTag) {
-          const list = [];
-          const listPos = getNodePos();
-          const saveParsingContext = parsingContext;
-          parsingContext |= 1 << 14 /* JsxChildren */;
-          while (true) {
-            const child = parseJsxChild(openingTag, currentToken = scanner2.reScanJsxToken());
-            if (!child)
-              break;
-            list.push(child);
-            if (isJsxOpeningElement(openingTag) && (child == null ? void 0 : child.kind) === 283 /* JsxElement */ && !tagNamesAreEquivalent(child.openingElement.tagName, child.closingElement.tagName) && tagNamesAreEquivalent(openingTag.tagName, child.closingElement.tagName)) {
-              break;
-            }
-          }
-          parsingContext = saveParsingContext;
-          return createNodeArray(list, listPos);
-        }
-        function parseJsxAttributes() {
-          const pos = getNodePos();
-          return finishNode(factory2.createJsxAttributes(parseList(13 /* JsxAttributes */, parseJsxAttribute)), pos);
-        }
-        function parseJsxOpeningOrSelfClosingElementOrOpeningFragment(inExpressionContext) {
-          const pos = getNodePos();
-          parseExpected(30 /* LessThanToken */);
-          if (token() === 32 /* GreaterThanToken */) {
-            scanJsxText();
-            return finishNode(factory2.createJsxOpeningFragment(), pos);
-          }
-          const tagName = parseJsxElementName();
-          const typeArguments = (contextFlags & 262144 /* JavaScriptFile */) === 0 ? tryParseTypeArguments() : void 0;
-          const attributes = parseJsxAttributes();
-          let node;
-          if (token() === 32 /* GreaterThanToken */) {
-            scanJsxText();
-            node = factory2.createJsxOpeningElement(tagName, typeArguments, attributes);
-          } else {
-            parseExpected(44 /* SlashToken */);
-            if (parseExpected(
-              32 /* GreaterThanToken */,
-              /*diagnosticMessage*/
-              void 0,
-              /*shouldAdvance*/
-              false
-            )) {
-              if (inExpressionContext) {
-                nextToken();
-              } else {
-                scanJsxText();
-              }
-            }
-            node = factory2.createJsxSelfClosingElement(tagName, typeArguments, attributes);
-          }
-          return finishNode(node, pos);
-        }
-        function parseJsxElementName() {
-          const pos = getNodePos();
-          const initialExpression = parseJsxTagName();
-          if (isJsxNamespacedName(initialExpression)) {
-            return initialExpression;
-          }
-          let expression = initialExpression;
-          while (parseOptional(25 /* DotToken */)) {
-            expression = finishNode(factoryCreatePropertyAccessExpression(expression, parseRightSideOfDot(
-              /*allowIdentifierNames*/
-              true,
-              /*allowPrivateIdentifiers*/
-              false
-            )), pos);
-          }
-          return expression;
-        }
-        function parseJsxTagName() {
-          const pos = getNodePos();
-          scanJsxIdentifier();
-          const isThis2 = token() === 110 /* ThisKeyword */;
-          const tagName = parseIdentifierName();
-          if (parseOptional(59 /* ColonToken */)) {
-            scanJsxIdentifier();
-            return finishNode(factory2.createJsxNamespacedName(tagName, parseIdentifierName()), pos);
-          }
-          return isThis2 ? finishNode(factory2.createToken(110 /* ThisKeyword */), pos) : tagName;
-        }
-        function parseJsxExpression(inExpressionContext) {
-          const pos = getNodePos();
-          if (!parseExpected(19 /* OpenBraceToken */)) {
-            return void 0;
-          }
-          let dotDotDotToken;
-          let expression;
-          if (token() !== 20 /* CloseBraceToken */) {
-            dotDotDotToken = parseOptionalToken(26 /* DotDotDotToken */);
-            expression = parseExpression();
-          }
-          if (inExpressionContext) {
-            parseExpected(20 /* CloseBraceToken */);
-          } else {
-            if (parseExpected(
-              20 /* CloseBraceToken */,
-              /*diagnosticMessage*/
-              void 0,
-              /*shouldAdvance*/
-              false
-            )) {
-              scanJsxText();
-            }
-          }
-          return finishNode(factory2.createJsxExpression(dotDotDotToken, expression), pos);
-        }
-        function parseJsxAttribute() {
-          if (token() === 19 /* OpenBraceToken */) {
-            return parseJsxSpreadAttribute();
-          }
-          const pos = getNodePos();
-          return finishNode(factory2.createJsxAttribute(parseJsxAttributeName(), parseJsxAttributeValue()), pos);
-        }
-        function parseJsxAttributeValue() {
-          if (token() === 64 /* EqualsToken */) {
-            if (scanJsxAttributeValue() === 11 /* StringLiteral */) {
-              return parseLiteralNode();
-            }
-            if (token() === 19 /* OpenBraceToken */) {
-              return parseJsxExpression(
-                /*inExpressionContext*/
-                true
-              );
-            }
-            if (token() === 30 /* LessThanToken */) {
-              return parseJsxElementOrSelfClosingElementOrFragment(
-                /*inExpressionContext*/
-                true
-              );
-            }
-            parseErrorAtCurrentToken(Diagnostics.or_JSX_element_expected);
-          }
-          return void 0;
-        }
-        function parseJsxAttributeName() {
-          const pos = getNodePos();
-          scanJsxIdentifier();
-          const attrName = parseIdentifierName();
-          if (parseOptional(59 /* ColonToken */)) {
-            scanJsxIdentifier();
-            return finishNode(factory2.createJsxNamespacedName(attrName, parseIdentifierName()), pos);
-          }
-          return attrName;
-        }
-        function parseJsxSpreadAttribute() {
-          const pos = getNodePos();
-          parseExpected(19 /* OpenBraceToken */);
-          parseExpected(26 /* DotDotDotToken */);
-          const expression = parseExpression();
-          parseExpected(20 /* CloseBraceToken */);
-          return finishNode(factory2.createJsxSpreadAttribute(expression), pos);
-        }
-        function parseJsxClosingElement(open, inExpressionContext) {
-          const pos = getNodePos();
-          parseExpected(31 /* LessThanSlashToken */);
-          const tagName = parseJsxElementName();
-          if (parseExpected(
-            32 /* GreaterThanToken */,
-            /*diagnosticMessage*/
-            void 0,
-            /*shouldAdvance*/
-            false
-          )) {
-            if (inExpressionContext || !tagNamesAreEquivalent(open.tagName, tagName)) {
-              nextToken();
-            } else {
-              scanJsxText();
-            }
-          }
-          return finishNode(factory2.createJsxClosingElement(tagName), pos);
-        }
-        function parseJsxClosingFragment(inExpressionContext) {
-          const pos = getNodePos();
-          parseExpected(31 /* LessThanSlashToken */);
-          if (parseExpected(
-            32 /* GreaterThanToken */,
-            Diagnostics.Expected_corresponding_closing_tag_for_JSX_fragment,
-            /*shouldAdvance*/
-            false
-          )) {
-            if (inExpressionContext) {
-              nextToken();
-            } else {
-              scanJsxText();
-            }
-          }
-          return finishNode(factory2.createJsxJsxClosingFragment(), pos);
-        }
-        function parseTypeAssertion() {
-          Debug.assert(languageVariant !== 1 /* JSX */, "Type assertions should never be parsed in JSX; they should be parsed as comparisons or JSX elements/fragments.");
-          const pos = getNodePos();
-          parseExpected(30 /* LessThanToken */);
-          const type = parseType();
-          parseExpected(32 /* GreaterThanToken */);
-          const expression = parseSimpleUnaryExpression();
-          return finishNode(factory2.createTypeAssertion(type, expression), pos);
-        }
-        function nextTokenIsIdentifierOrKeywordOrOpenBracketOrTemplate() {
-          nextToken();
-          return tokenIsIdentifierOrKeyword(token()) || token() === 23 /* OpenBracketToken */ || isTemplateStartOfTaggedTemplate();
-        }
-        function isStartOfOptionalPropertyOrElementAccessChain() {
-          return token() === 29 /* QuestionDotToken */ && lookAhead(nextTokenIsIdentifierOrKeywordOrOpenBracketOrTemplate);
-        }
-        function tryReparseOptionalChain(node) {
-          if (node.flags & 32 /* OptionalChain */) {
-            return true;
-          }
-          if (isNonNullExpression(node)) {
-            let expr = node.expression;
-            while (isNonNullExpression(expr) && !(expr.flags & 32 /* OptionalChain */)) {
-              expr = expr.expression;
-            }
-            if (expr.flags & 32 /* OptionalChain */) {
-              while (isNonNullExpression(node)) {
-                node.flags |= 32 /* OptionalChain */;
-                node = node.expression;
-              }
-              return true;
-            }
-          }
-          return false;
-        }
-        function parsePropertyAccessExpressionRest(pos, expression, questionDotToken) {
-          const name = parseRightSideOfDot(
-            /*allowIdentifierNames*/
-            true,
-            /*allowPrivateIdentifiers*/
-            true
-          );
-          const isOptionalChain2 = questionDotToken || tryReparseOptionalChain(expression);
-          const propertyAccess = isOptionalChain2 ? factoryCreatePropertyAccessChain(expression, questionDotToken, name) : factoryCreatePropertyAccessExpression(expression, name);
-          if (isOptionalChain2 && isPrivateIdentifier(propertyAccess.name)) {
-            parseErrorAtRange(propertyAccess.name, Diagnostics.An_optional_chain_cannot_contain_private_identifiers);
-          }
-          if (isExpressionWithTypeArguments(expression) && expression.typeArguments) {
-            const pos2 = expression.typeArguments.pos - 1;
-            const end = skipTrivia(sourceText, expression.typeArguments.end) + 1;
-            parseErrorAt(pos2, end, Diagnostics.An_instantiation_expression_cannot_be_followed_by_a_property_access);
-          }
-          return finishNode(propertyAccess, pos);
-        }
-        function parseElementAccessExpressionRest(pos, expression, questionDotToken) {
-          let argumentExpression;
-          if (token() === 24 /* CloseBracketToken */) {
-            argumentExpression = createMissingNode(
-              80 /* Identifier */,
-              /*reportAtCurrentPosition*/
-              true,
-              Diagnostics.An_element_access_expression_should_take_an_argument
-            );
-          } else {
-            const argument = allowInAnd(parseExpression);
-            if (isStringOrNumericLiteralLike(argument)) {
-              argument.text = internIdentifier(argument.text);
-            }
-            argumentExpression = argument;
-          }
-          parseExpected(24 /* CloseBracketToken */);
-          const indexedAccess = questionDotToken || tryReparseOptionalChain(expression) ? factoryCreateElementAccessChain(expression, questionDotToken, argumentExpression) : factoryCreateElementAccessExpression(expression, argumentExpression);
-          return finishNode(indexedAccess, pos);
-        }
-        function parseMemberExpressionRest(pos, expression, allowOptionalChain) {
-          while (true) {
-            let questionDotToken;
-            let isPropertyAccess = false;
-            if (allowOptionalChain && isStartOfOptionalPropertyOrElementAccessChain()) {
-              questionDotToken = parseExpectedToken(29 /* QuestionDotToken */);
-              isPropertyAccess = tokenIsIdentifierOrKeyword(token());
-            } else {
-              isPropertyAccess = parseOptional(25 /* DotToken */);
-            }
-            if (isPropertyAccess) {
-              expression = parsePropertyAccessExpressionRest(pos, expression, questionDotToken);
-              continue;
-            }
-            if ((questionDotToken || !inDecoratorContext()) && parseOptional(23 /* OpenBracketToken */)) {
-              expression = parseElementAccessExpressionRest(pos, expression, questionDotToken);
-              continue;
-            }
-            if (isTemplateStartOfTaggedTemplate()) {
-              expression = !questionDotToken && expression.kind === 232 /* ExpressionWithTypeArguments */ ? parseTaggedTemplateRest(pos, expression.expression, questionDotToken, expression.typeArguments) : parseTaggedTemplateRest(
-                pos,
-                expression,
-                questionDotToken,
-                /*typeArguments*/
-                void 0
-              );
-              continue;
-            }
-            if (!questionDotToken) {
-              if (token() === 54 /* ExclamationToken */ && !scanner2.hasPrecedingLineBreak()) {
-                nextToken();
-                expression = finishNode(factory2.createNonNullExpression(expression), pos);
-                continue;
-              }
-              const typeArguments = tryParse(parseTypeArgumentsInExpression);
-              if (typeArguments) {
-                expression = finishNode(factory2.createExpressionWithTypeArguments(expression, typeArguments), pos);
-                continue;
-              }
-            }
-            return expression;
-          }
-        }
-        function isTemplateStartOfTaggedTemplate() {
-          return token() === 15 /* NoSubstitutionTemplateLiteral */ || token() === 16 /* TemplateHead */;
-        }
-        function parseTaggedTemplateRest(pos, tag, questionDotToken, typeArguments) {
-          const tagExpression = factory2.createTaggedTemplateExpression(
-            tag,
-            typeArguments,
-            token() === 15 /* NoSubstitutionTemplateLiteral */ ? (reScanTemplateToken(
-              /*isTaggedTemplate*/
-              true
-            ), parseLiteralNode()) : parseTemplateExpression(
-              /*isTaggedTemplate*/
-              true
-            )
-          );
-          if (questionDotToken || tag.flags & 32 /* OptionalChain */) {
-            tagExpression.flags |= 32 /* OptionalChain */;
-          }
-          tagExpression.questionDotToken = questionDotToken;
-          return finishNode(tagExpression, pos);
-        }
-        function parseCallExpressionRest(pos, expression) {
-          while (true) {
-            expression = parseMemberExpressionRest(
-              pos,
-              expression,
-              /*allowOptionalChain*/
-              true
-            );
-            let typeArguments;
-            const questionDotToken = parseOptionalToken(29 /* QuestionDotToken */);
-            if (questionDotToken) {
-              typeArguments = tryParse(parseTypeArgumentsInExpression);
-              if (isTemplateStartOfTaggedTemplate()) {
-                expression = parseTaggedTemplateRest(pos, expression, questionDotToken, typeArguments);
-                continue;
-              }
-            }
-            if (typeArguments || token() === 21 /* OpenParenToken */) {
-              if (!questionDotToken && expression.kind === 232 /* ExpressionWithTypeArguments */) {
-                typeArguments = expression.typeArguments;
-                expression = expression.expression;
-              }
-              const argumentList = parseArgumentList();
-              const callExpr = questionDotToken || tryReparseOptionalChain(expression) ? factoryCreateCallChain(expression, questionDotToken, typeArguments, argumentList) : factoryCreateCallExpression(expression, typeArguments, argumentList);
-              expression = finishNode(callExpr, pos);
-              continue;
-            }
-            if (questionDotToken) {
-              const name = createMissingNode(
-                80 /* Identifier */,
-                /*reportAtCurrentPosition*/
-                false,
-                Diagnostics.Identifier_expected
-              );
-              expression = finishNode(factoryCreatePropertyAccessChain(expression, questionDotToken, name), pos);
-            }
-            break;
-          }
-          return expression;
-        }
-        function parseArgumentList() {
-          parseExpected(21 /* OpenParenToken */);
-          const result = parseDelimitedList(11 /* ArgumentExpressions */, parseArgumentExpression);
-          parseExpected(22 /* CloseParenToken */);
-          return result;
-        }
-        function parseTypeArgumentsInExpression() {
-          if ((contextFlags & 262144 /* JavaScriptFile */) !== 0) {
-            return void 0;
-          }
-          if (reScanLessThanToken() !== 30 /* LessThanToken */) {
-            return void 0;
-          }
-          nextToken();
-          const typeArguments = parseDelimitedList(20 /* TypeArguments */, parseType);
-          if (reScanGreaterToken() !== 32 /* GreaterThanToken */) {
-            return void 0;
-          }
-          nextToken();
-          return typeArguments && canFollowTypeArgumentsInExpression() ? typeArguments : void 0;
-        }
-        function canFollowTypeArgumentsInExpression() {
-          switch (token()) {
-            case 21 /* OpenParenToken */:
-            case 15 /* NoSubstitutionTemplateLiteral */:
-            case 16 /* TemplateHead */:
-              return true;
-            case 30 /* LessThanToken */:
-            case 32 /* GreaterThanToken */:
-            case 40 /* PlusToken */:
-            case 41 /* MinusToken */:
-              return false;
-          }
-          return scanner2.hasPrecedingLineBreak() || isBinaryOperator2() || !isStartOfExpression();
-        }
-        function parsePrimaryExpression() {
-          switch (token()) {
-            case 15 /* NoSubstitutionTemplateLiteral */:
-              if (scanner2.getTokenFlags() & 26656 /* IsInvalid */) {
-                reScanTemplateToken(
-                  /*isTaggedTemplate*/
-                  false
-                );
-              }
-            case 9 /* NumericLiteral */:
-            case 10 /* BigIntLiteral */:
-            case 11 /* StringLiteral */:
-              return parseLiteralNode();
-            case 110 /* ThisKeyword */:
-            case 108 /* SuperKeyword */:
-            case 106 /* NullKeyword */:
-            case 112 /* TrueKeyword */:
-            case 97 /* FalseKeyword */:
-              return parseTokenNode();
-            case 21 /* OpenParenToken */:
-              return parseParenthesizedExpression();
-            case 23 /* OpenBracketToken */:
-              return parseArrayLiteralExpression();
-            case 19 /* OpenBraceToken */:
-              return parseObjectLiteralExpression();
-            case 134 /* AsyncKeyword */:
-              if (!lookAhead(nextTokenIsFunctionKeywordOnSameLine)) {
-                break;
-              }
-              return parseFunctionExpression();
-            case 60 /* AtToken */:
-              return parseDecoratedExpression();
-            case 86 /* ClassKeyword */:
-              return parseClassExpression();
-            case 100 /* FunctionKeyword */:
-              return parseFunctionExpression();
-            case 105 /* NewKeyword */:
-              return parseNewExpressionOrNewDotTarget();
-            case 44 /* SlashToken */:
-            case 69 /* SlashEqualsToken */:
-              if (reScanSlashToken() === 14 /* RegularExpressionLiteral */) {
-                return parseLiteralNode();
-              }
-              break;
-            case 16 /* TemplateHead */:
-              return parseTemplateExpression(
-                /*isTaggedTemplate*/
-                false
-              );
-            case 81 /* PrivateIdentifier */:
-              return parsePrivateIdentifier();
-          }
-          return parseIdentifier(Diagnostics.Expression_expected);
-        }
-        function parseParenthesizedExpression() {
-          const pos = getNodePos();
-          const hasJSDoc = hasPrecedingJSDocComment();
-          parseExpected(21 /* OpenParenToken */);
-          const expression = allowInAnd(parseExpression);
-          parseExpected(22 /* CloseParenToken */);
-          return withJSDoc(finishNode(factoryCreateParenthesizedExpression(expression), pos), hasJSDoc);
-        }
-        function parseSpreadElement() {
-          const pos = getNodePos();
-          parseExpected(26 /* DotDotDotToken */);
-          const expression = parseAssignmentExpressionOrHigher(
-            /*allowReturnTypeInArrowFunction*/
-            true
-          );
-          return finishNode(factory2.createSpreadElement(expression), pos);
-        }
-        function parseArgumentOrArrayLiteralElement() {
-          return token() === 26 /* DotDotDotToken */ ? parseSpreadElement() : token() === 28 /* CommaToken */ ? finishNode(factory2.createOmittedExpression(), getNodePos()) : parseAssignmentExpressionOrHigher(
-            /*allowReturnTypeInArrowFunction*/
-            true
-          );
-        }
-        function parseArgumentExpression() {
-          return doOutsideOfContext(disallowInAndDecoratorContext, parseArgumentOrArrayLiteralElement);
-        }
-        function parseArrayLiteralExpression() {
-          const pos = getNodePos();
-          const openBracketPosition = scanner2.getTokenStart();
-          const openBracketParsed = parseExpected(23 /* OpenBracketToken */);
-          const multiLine = scanner2.hasPrecedingLineBreak();
-          const elements = parseDelimitedList(15 /* ArrayLiteralMembers */, parseArgumentOrArrayLiteralElement);
-          parseExpectedMatchingBrackets(23 /* OpenBracketToken */, 24 /* CloseBracketToken */, openBracketParsed, openBracketPosition);
-          return finishNode(factoryCreateArrayLiteralExpression(elements, multiLine), pos);
-        }
-        function parseObjectLiteralElement() {
-          const pos = getNodePos();
-          const hasJSDoc = hasPrecedingJSDocComment();
-          if (parseOptionalToken(26 /* DotDotDotToken */)) {
-            const expression = parseAssignmentExpressionOrHigher(
-              /*allowReturnTypeInArrowFunction*/
-              true
-            );
-            return withJSDoc(finishNode(factory2.createSpreadAssignment(expression), pos), hasJSDoc);
-          }
-          const modifiers = parseModifiers(
-            /*allowDecorators*/
-            true
-          );
-          if (parseContextualModifier(139 /* GetKeyword */)) {
-            return parseAccessorDeclaration(pos, hasJSDoc, modifiers, 176 /* GetAccessor */, 0 /* None */);
-          }
-          if (parseContextualModifier(153 /* SetKeyword */)) {
-            return parseAccessorDeclaration(pos, hasJSDoc, modifiers, 177 /* SetAccessor */, 0 /* None */);
-          }
-          const asteriskToken = parseOptionalToken(42 /* AsteriskToken */);
-          const tokenIsIdentifier = isIdentifier2();
-          const name = parsePropertyName();
-          const questionToken = parseOptionalToken(58 /* QuestionToken */);
-          const exclamationToken = parseOptionalToken(54 /* ExclamationToken */);
-          if (asteriskToken || token() === 21 /* OpenParenToken */ || token() === 30 /* LessThanToken */) {
-            return parseMethodDeclaration(pos, hasJSDoc, modifiers, asteriskToken, name, questionToken, exclamationToken);
-          }
-          let node;
-          const isShorthandPropertyAssignment2 = tokenIsIdentifier && token() !== 59 /* ColonToken */;
-          if (isShorthandPropertyAssignment2) {
-            const equalsToken = parseOptionalToken(64 /* EqualsToken */);
-            const objectAssignmentInitializer = equalsToken ? allowInAnd(() => parseAssignmentExpressionOrHigher(
-              /*allowReturnTypeInArrowFunction*/
-              true
-            )) : void 0;
-            node = factory2.createShorthandPropertyAssignment(name, objectAssignmentInitializer);
-            node.equalsToken = equalsToken;
-          } else {
-            parseExpected(59 /* ColonToken */);
-            const initializer = allowInAnd(() => parseAssignmentExpressionOrHigher(
-              /*allowReturnTypeInArrowFunction*/
-              true
-            ));
-            node = factory2.createPropertyAssignment(name, initializer);
-          }
-          node.modifiers = modifiers;
-          node.questionToken = questionToken;
-          node.exclamationToken = exclamationToken;
-          return withJSDoc(finishNode(node, pos), hasJSDoc);
-        }
-        function parseObjectLiteralExpression() {
-          const pos = getNodePos();
-          const openBracePosition = scanner2.getTokenStart();
-          const openBraceParsed = parseExpected(19 /* OpenBraceToken */);
-          const multiLine = scanner2.hasPrecedingLineBreak();
-          const properties = parseDelimitedList(
-            12 /* ObjectLiteralMembers */,
-            parseObjectLiteralElement,
-            /*considerSemicolonAsDelimiter*/
-            true
-          );
-          parseExpectedMatchingBrackets(19 /* OpenBraceToken */, 20 /* CloseBraceToken */, openBraceParsed, openBracePosition);
-          return finishNode(factoryCreateObjectLiteralExpression(properties, multiLine), pos);
-        }
-        function parseFunctionExpression() {
-          const savedDecoratorContext = inDecoratorContext();
-          setDecoratorContext(
-            /*val*/
-            false
-          );
-          const pos = getNodePos();
-          const hasJSDoc = hasPrecedingJSDocComment();
-          const modifiers = parseModifiers(
-            /*allowDecorators*/
-            false
-          );
-          parseExpected(100 /* FunctionKeyword */);
-          const asteriskToken = parseOptionalToken(42 /* AsteriskToken */);
-          const isGenerator = asteriskToken ? 1 /* Yield */ : 0 /* None */;
-          const isAsync = some(modifiers, isAsyncModifier) ? 2 /* Await */ : 0 /* None */;
-          const name = isGenerator && isAsync ? doInYieldAndAwaitContext(parseOptionalBindingIdentifier) : isGenerator ? doInYieldContext(parseOptionalBindingIdentifier) : isAsync ? doInAwaitContext(parseOptionalBindingIdentifier) : parseOptionalBindingIdentifier();
-          const typeParameters = parseTypeParameters();
-          const parameters = parseParameters(isGenerator | isAsync);
-          const type = parseReturnType(
-            59 /* ColonToken */,
-            /*isType*/
-            false
-          );
-          const body = parseFunctionBlock(isGenerator | isAsync);
-          setDecoratorContext(savedDecoratorContext);
-          const node = factory2.createFunctionExpression(modifiers, asteriskToken, name, typeParameters, parameters, type, body);
-          return withJSDoc(finishNode(node, pos), hasJSDoc);
-        }
-        function parseOptionalBindingIdentifier() {
-          return isBindingIdentifier() ? parseBindingIdentifier() : void 0;
-        }
-        function parseNewExpressionOrNewDotTarget() {
-          const pos = getNodePos();
-          parseExpected(105 /* NewKeyword */);
-          if (parseOptional(25 /* DotToken */)) {
-            const name = parseIdentifierName();
-            return finishNode(factory2.createMetaProperty(105 /* NewKeyword */, name), pos);
-          }
-          const expressionPos = getNodePos();
-          let expression = parseMemberExpressionRest(
-            expressionPos,
-            parsePrimaryExpression(),
-            /*allowOptionalChain*/
-            false
-          );
-          let typeArguments;
-          if (expression.kind === 232 /* ExpressionWithTypeArguments */) {
-            typeArguments = expression.typeArguments;
-            expression = expression.expression;
-          }
-          if (token() === 29 /* QuestionDotToken */) {
-            parseErrorAtCurrentToken(Diagnostics.Invalid_optional_chain_from_new_expression_Did_you_mean_to_call_0, getTextOfNodeFromSourceText(sourceText, expression));
-          }
-          const argumentList = token() === 21 /* OpenParenToken */ ? parseArgumentList() : void 0;
-          return finishNode(factoryCreateNewExpression(expression, typeArguments, argumentList), pos);
-        }
-        function parseBlock(ignoreMissingOpenBrace, diagnosticMessage) {
-          const pos = getNodePos();
-          const hasJSDoc = hasPrecedingJSDocComment();
-          const openBracePosition = scanner2.getTokenStart();
-          const openBraceParsed = parseExpected(19 /* OpenBraceToken */, diagnosticMessage);
-          if (openBraceParsed || ignoreMissingOpenBrace) {
-            const multiLine = scanner2.hasPrecedingLineBreak();
-            const statements = parseList(1 /* BlockStatements */, parseStatement);
-            parseExpectedMatchingBrackets(19 /* OpenBraceToken */, 20 /* CloseBraceToken */, openBraceParsed, openBracePosition);
-            const result = withJSDoc(finishNode(factoryCreateBlock(statements, multiLine), pos), hasJSDoc);
-            if (token() === 64 /* EqualsToken */) {
-              parseErrorAtCurrentToken(Diagnostics.Declaration_or_statement_expected_This_follows_a_block_of_statements_so_if_you_intended_to_write_a_destructuring_assignment_you_might_need_to_wrap_the_whole_assignment_in_parentheses);
-              nextToken();
-            }
-            return result;
-          } else {
-            const statements = createMissingList();
-            return withJSDoc(finishNode(factoryCreateBlock(
-              statements,
-              /*multiLine*/
-              void 0
-            ), pos), hasJSDoc);
-          }
-        }
-        function parseFunctionBlock(flags, diagnosticMessage) {
-          const savedYieldContext = inYieldContext();
-          setYieldContext(!!(flags & 1 /* Yield */));
-          const savedAwaitContext = inAwaitContext();
-          setAwaitContext(!!(flags & 2 /* Await */));
-          const savedTopLevel = topLevel;
-          topLevel = false;
-          const saveDecoratorContext = inDecoratorContext();
-          if (saveDecoratorContext) {
-            setDecoratorContext(
-              /*val*/
-              false
-            );
-          }
-          const block = parseBlock(!!(flags & 16 /* IgnoreMissingOpenBrace */), diagnosticMessage);
-          if (saveDecoratorContext) {
-            setDecoratorContext(
-              /*val*/
-              true
-            );
-          }
-          topLevel = savedTopLevel;
-          setYieldContext(savedYieldContext);
-          setAwaitContext(savedAwaitContext);
-          return block;
-        }
-        function parseEmptyStatement() {
-          const pos = getNodePos();
-          const hasJSDoc = hasPrecedingJSDocComment();
-          parseExpected(27 /* SemicolonToken */);
-          return withJSDoc(finishNode(factory2.createEmptyStatement(), pos), hasJSDoc);
-        }
-        function parseIfStatement() {
-          const pos = getNodePos();
-          const hasJSDoc = hasPrecedingJSDocComment();
-          parseExpected(101 /* IfKeyword */);
-          const openParenPosition = scanner2.getTokenStart();
-          const openParenParsed = parseExpected(21 /* OpenParenToken */);
-          const expression = allowInAnd(parseExpression);
-          parseExpectedMatchingBrackets(21 /* OpenParenToken */, 22 /* CloseParenToken */, openParenParsed, openParenPosition);
-          const thenStatement = parseStatement();
-          const elseStatement = parseOptional(93 /* ElseKeyword */) ? parseStatement() : void 0;
-          return withJSDoc(finishNode(factoryCreateIfStatement(expression, thenStatement, elseStatement), pos), hasJSDoc);
-        }
-        function parseDoStatement() {
-          const pos = getNodePos();
-          const hasJSDoc = hasPrecedingJSDocComment();
-          parseExpected(92 /* DoKeyword */);
-          const statement = parseStatement();
-          parseExpected(117 /* WhileKeyword */);
-          const openParenPosition = scanner2.getTokenStart();
-          const openParenParsed = parseExpected(21 /* OpenParenToken */);
-          const expression = allowInAnd(parseExpression);
-          parseExpectedMatchingBrackets(21 /* OpenParenToken */, 22 /* CloseParenToken */, openParenParsed, openParenPosition);
-          parseOptional(27 /* SemicolonToken */);
-          return withJSDoc(finishNode(factory2.createDoStatement(statement, expression), pos), hasJSDoc);
-        }
-        function parseWhileStatement() {
-          const pos = getNodePos();
-          const hasJSDoc = hasPrecedingJSDocComment();
-          parseExpected(117 /* WhileKeyword */);
-          const openParenPosition = scanner2.getTokenStart();
-          const openParenParsed = parseExpected(21 /* OpenParenToken */);
-          const expression = allowInAnd(parseExpression);
-          parseExpectedMatchingBrackets(21 /* OpenParenToken */, 22 /* CloseParenToken */, openParenParsed, openParenPosition);
-          const statement = parseStatement();
-          return withJSDoc(finishNode(factoryCreateWhileStatement(expression, statement), pos), hasJSDoc);
-        }
-        function parseForOrForInOrForOfStatement() {
-          const pos = getNodePos();
-          const hasJSDoc = hasPrecedingJSDocComment();
-          parseExpected(99 /* ForKeyword */);
-          const awaitToken = parseOptionalToken(135 /* AwaitKeyword */);
-          parseExpected(21 /* OpenParenToken */);
-          let initializer;
-          if (token() !== 27 /* SemicolonToken */) {
-            if (token() === 115 /* VarKeyword */ || token() === 121 /* LetKeyword */ || token() === 87 /* ConstKeyword */) {
-              initializer = parseVariableDeclarationList(
-                /*inForStatementInitializer*/
-                true
-              );
-            } else {
-              initializer = disallowInAnd(parseExpression);
-            }
-          }
-          let node;
-          if (awaitToken ? parseExpected(164 /* OfKeyword */) : parseOptional(164 /* OfKeyword */)) {
-            const expression = allowInAnd(() => parseAssignmentExpressionOrHigher(
-              /*allowReturnTypeInArrowFunction*/
-              true
-            ));
-            parseExpected(22 /* CloseParenToken */);
-            node = factoryCreateForOfStatement(awaitToken, initializer, expression, parseStatement());
-          } else if (parseOptional(103 /* InKeyword */)) {
-            const expression = allowInAnd(parseExpression);
-            parseExpected(22 /* CloseParenToken */);
-            node = factory2.createForInStatement(initializer, expression, parseStatement());
-          } else {
-            parseExpected(27 /* SemicolonToken */);
-            const condition = token() !== 27 /* SemicolonToken */ && token() !== 22 /* CloseParenToken */ ? allowInAnd(parseExpression) : void 0;
-            parseExpected(27 /* SemicolonToken */);
-            const incrementor = token() !== 22 /* CloseParenToken */ ? allowInAnd(parseExpression) : void 0;
-            parseExpected(22 /* CloseParenToken */);
-            node = factoryCreateForStatement(initializer, condition, incrementor, parseStatement());
-          }
-          return withJSDoc(finishNode(node, pos), hasJSDoc);
-        }
-        function parseBreakOrContinueStatement(kind) {
-          const pos = getNodePos();
-          const hasJSDoc = hasPrecedingJSDocComment();
-          parseExpected(kind === 251 /* BreakStatement */ ? 83 /* BreakKeyword */ : 88 /* ContinueKeyword */);
-          const label = canParseSemicolon() ? void 0 : parseIdentifier();
-          parseSemicolon();
-          const node = kind === 251 /* BreakStatement */ ? factory2.createBreakStatement(label) : factory2.createContinueStatement(label);
-          return withJSDoc(finishNode(node, pos), hasJSDoc);
-        }
-        function parseReturnStatement() {
-          const pos = getNodePos();
-          const hasJSDoc = hasPrecedingJSDocComment();
-          parseExpected(107 /* ReturnKeyword */);
-          const expression = canParseSemicolon() ? void 0 : allowInAnd(parseExpression);
-          parseSemicolon();
-          return withJSDoc(finishNode(factory2.createReturnStatement(expression), pos), hasJSDoc);
-        }
-        function parseWithStatement() {
-          const pos = getNodePos();
-          const hasJSDoc = hasPrecedingJSDocComment();
-          parseExpected(118 /* WithKeyword */);
-          const openParenPosition = scanner2.getTokenStart();
-          const openParenParsed = parseExpected(21 /* OpenParenToken */);
-          const expression = allowInAnd(parseExpression);
-          parseExpectedMatchingBrackets(21 /* OpenParenToken */, 22 /* CloseParenToken */, openParenParsed, openParenPosition);
-          const statement = doInsideOfContext(33554432 /* InWithStatement */, parseStatement);
-          return withJSDoc(finishNode(factory2.createWithStatement(expression, statement), pos), hasJSDoc);
-        }
-        function parseCaseClause() {
-          const pos = getNodePos();
-          const hasJSDoc = hasPrecedingJSDocComment();
-          parseExpected(84 /* CaseKeyword */);
-          const expression = allowInAnd(parseExpression);
-          parseExpected(59 /* ColonToken */);
-          const statements = parseList(3 /* SwitchClauseStatements */, parseStatement);
-          return withJSDoc(finishNode(factory2.createCaseClause(expression, statements), pos), hasJSDoc);
-        }
-        function parseDefaultClause() {
-          const pos = getNodePos();
-          parseExpected(90 /* DefaultKeyword */);
-          parseExpected(59 /* ColonToken */);
-          const statements = parseList(3 /* SwitchClauseStatements */, parseStatement);
-          return finishNode(factory2.createDefaultClause(statements), pos);
-        }
-        function parseCaseOrDefaultClause() {
-          return token() === 84 /* CaseKeyword */ ? parseCaseClause() : parseDefaultClause();
-        }
-        function parseCaseBlock() {
-          const pos = getNodePos();
-          parseExpected(19 /* OpenBraceToken */);
-          const clauses = parseList(2 /* SwitchClauses */, parseCaseOrDefaultClause);
-          parseExpected(20 /* CloseBraceToken */);
-          return finishNode(factory2.createCaseBlock(clauses), pos);
-        }
-        function parseSwitchStatement() {
-          const pos = getNodePos();
-          const hasJSDoc = hasPrecedingJSDocComment();
-          parseExpected(109 /* SwitchKeyword */);
-          parseExpected(21 /* OpenParenToken */);
-          const expression = allowInAnd(parseExpression);
-          parseExpected(22 /* CloseParenToken */);
-          const caseBlock = parseCaseBlock();
-          return withJSDoc(finishNode(factory2.createSwitchStatement(expression, caseBlock), pos), hasJSDoc);
-        }
-        function parseThrowStatement() {
-          const pos = getNodePos();
-          const hasJSDoc = hasPrecedingJSDocComment();
-          parseExpected(111 /* ThrowKeyword */);
-          let expression = scanner2.hasPrecedingLineBreak() ? void 0 : allowInAnd(parseExpression);
-          if (expression === void 0) {
-            identifierCount++;
-            expression = finishNode(factoryCreateIdentifier(""), getNodePos());
-          }
-          if (!tryParseSemicolon()) {
-            parseErrorForMissingSemicolonAfter(expression);
-          }
-          return withJSDoc(finishNode(factory2.createThrowStatement(expression), pos), hasJSDoc);
-        }
-        function parseTryStatement() {
-          const pos = getNodePos();
-          const hasJSDoc = hasPrecedingJSDocComment();
-          parseExpected(113 /* TryKeyword */);
-          const tryBlock = parseBlock(
-            /*ignoreMissingOpenBrace*/
-            false
-          );
-          const catchClause = token() === 85 /* CatchKeyword */ ? parseCatchClause() : void 0;
-          let finallyBlock;
-          if (!catchClause || token() === 98 /* FinallyKeyword */) {
-            parseExpected(98 /* FinallyKeyword */, Diagnostics.catch_or_finally_expected);
-            finallyBlock = parseBlock(
-              /*ignoreMissingOpenBrace*/
-              false
-            );
-          }
-          return withJSDoc(finishNode(factory2.createTryStatement(tryBlock, catchClause, finallyBlock), pos), hasJSDoc);
-        }
-        function parseCatchClause() {
-          const pos = getNodePos();
-          parseExpected(85 /* CatchKeyword */);
-          let variableDeclaration;
-          if (parseOptional(21 /* OpenParenToken */)) {
-            variableDeclaration = parseVariableDeclaration();
-            parseExpected(22 /* CloseParenToken */);
-          } else {
-            variableDeclaration = void 0;
-          }
-          const block = parseBlock(
-            /*ignoreMissingOpenBrace*/
-            false
-          );
-          return finishNode(factory2.createCatchClause(variableDeclaration, block), pos);
-        }
-        function parseDebuggerStatement() {
-          const pos = getNodePos();
-          const hasJSDoc = hasPrecedingJSDocComment();
-          parseExpected(89 /* DebuggerKeyword */);
-          parseSemicolon();
-          return withJSDoc(finishNode(factory2.createDebuggerStatement(), pos), hasJSDoc);
-        }
-        function parseExpressionOrLabeledStatement() {
-          const pos = getNodePos();
-          let hasJSDoc = hasPrecedingJSDocComment();
-          let node;
-          const hasParen = token() === 21 /* OpenParenToken */;
-          const expression = allowInAnd(parseExpression);
-          if (isIdentifier(expression) && parseOptional(59 /* ColonToken */)) {
-            node = factory2.createLabeledStatement(expression, parseStatement());
-          } else {
-            if (!tryParseSemicolon()) {
-              parseErrorForMissingSemicolonAfter(expression);
-            }
-            node = factoryCreateExpressionStatement(expression);
-            if (hasParen) {
-              hasJSDoc = false;
-            }
-          }
-          return withJSDoc(finishNode(node, pos), hasJSDoc);
-        }
-        function nextTokenIsIdentifierOrKeywordOnSameLine() {
-          nextToken();
-          return tokenIsIdentifierOrKeyword(token()) && !scanner2.hasPrecedingLineBreak();
-        }
-        function nextTokenIsClassKeywordOnSameLine() {
-          nextToken();
-          return token() === 86 /* ClassKeyword */ && !scanner2.hasPrecedingLineBreak();
-        }
-        function nextTokenIsFunctionKeywordOnSameLine() {
-          nextToken();
-          return token() === 100 /* FunctionKeyword */ && !scanner2.hasPrecedingLineBreak();
-        }
-        function nextTokenIsIdentifierOrKeywordOrLiteralOnSameLine() {
-          nextToken();
-          return (tokenIsIdentifierOrKeyword(token()) || token() === 9 /* NumericLiteral */ || token() === 10 /* BigIntLiteral */ || token() === 11 /* StringLiteral */) && !scanner2.hasPrecedingLineBreak();
-        }
-        function isDeclaration2() {
-          while (true) {
-            switch (token()) {
-              case 115 /* VarKeyword */:
-              case 121 /* LetKeyword */:
-              case 87 /* ConstKeyword */:
-              case 100 /* FunctionKeyword */:
-              case 86 /* ClassKeyword */:
-              case 94 /* EnumKeyword */:
-                return true;
-              case 120 /* InterfaceKeyword */:
-              case 156 /* TypeKeyword */:
-                return nextTokenIsIdentifierOnSameLine();
-              case 144 /* ModuleKeyword */:
-              case 145 /* NamespaceKeyword */:
-                return nextTokenIsIdentifierOrStringLiteralOnSameLine();
-              case 128 /* AbstractKeyword */:
-              case 129 /* AccessorKeyword */:
-              case 134 /* AsyncKeyword */:
-              case 138 /* DeclareKeyword */:
-              case 123 /* PrivateKeyword */:
-              case 124 /* ProtectedKeyword */:
-              case 125 /* PublicKeyword */:
-              case 148 /* ReadonlyKeyword */:
-                nextToken();
-                if (scanner2.hasPrecedingLineBreak()) {
-                  return false;
-                }
-                continue;
-              case 161 /* GlobalKeyword */:
-                nextToken();
-                return token() === 19 /* OpenBraceToken */ || token() === 80 /* Identifier */ || token() === 95 /* ExportKeyword */;
-              case 102 /* ImportKeyword */:
-                nextToken();
-                return token() === 11 /* StringLiteral */ || token() === 42 /* AsteriskToken */ || token() === 19 /* OpenBraceToken */ || tokenIsIdentifierOrKeyword(token());
-              case 95 /* ExportKeyword */:
-                let currentToken2 = nextToken();
-                if (currentToken2 === 156 /* TypeKeyword */) {
-                  currentToken2 = lookAhead(nextToken);
-                }
-                if (currentToken2 === 64 /* EqualsToken */ || currentToken2 === 42 /* AsteriskToken */ || currentToken2 === 19 /* OpenBraceToken */ || currentToken2 === 90 /* DefaultKeyword */ || currentToken2 === 130 /* AsKeyword */ || currentToken2 === 60 /* AtToken */) {
-                  return true;
-                }
-                continue;
-              case 126 /* StaticKeyword */:
-                nextToken();
-                continue;
-              default:
-                return false;
-            }
-          }
-        }
-        function isStartOfDeclaration() {
-          return lookAhead(isDeclaration2);
-        }
-        function isStartOfStatement() {
-          switch (token()) {
-            case 60 /* AtToken */:
-            case 27 /* SemicolonToken */:
-            case 19 /* OpenBraceToken */:
-            case 115 /* VarKeyword */:
-            case 121 /* LetKeyword */:
-            case 100 /* FunctionKeyword */:
-            case 86 /* ClassKeyword */:
-            case 94 /* EnumKeyword */:
-            case 101 /* IfKeyword */:
-            case 92 /* DoKeyword */:
-            case 117 /* WhileKeyword */:
-            case 99 /* ForKeyword */:
-            case 88 /* ContinueKeyword */:
-            case 83 /* BreakKeyword */:
-            case 107 /* ReturnKeyword */:
-            case 118 /* WithKeyword */:
-            case 109 /* SwitchKeyword */:
-            case 111 /* ThrowKeyword */:
-            case 113 /* TryKeyword */:
-            case 89 /* DebuggerKeyword */:
-            case 85 /* CatchKeyword */:
-            case 98 /* FinallyKeyword */:
-              return true;
-            case 102 /* ImportKeyword */:
-              return isStartOfDeclaration() || lookAhead(nextTokenIsOpenParenOrLessThanOrDot);
-            case 87 /* ConstKeyword */:
-            case 95 /* ExportKeyword */:
-              return isStartOfDeclaration();
-            case 134 /* AsyncKeyword */:
-            case 138 /* DeclareKeyword */:
-            case 120 /* InterfaceKeyword */:
-            case 144 /* ModuleKeyword */:
-            case 145 /* NamespaceKeyword */:
-            case 156 /* TypeKeyword */:
-            case 161 /* GlobalKeyword */:
-              return true;
-            case 129 /* AccessorKeyword */:
-            case 125 /* PublicKeyword */:
-            case 123 /* PrivateKeyword */:
-            case 124 /* ProtectedKeyword */:
-            case 126 /* StaticKeyword */:
-            case 148 /* ReadonlyKeyword */:
-              return isStartOfDeclaration() || !lookAhead(nextTokenIsIdentifierOrKeywordOnSameLine);
-            default:
-              return isStartOfExpression();
-          }
-        }
-        function nextTokenIsBindingIdentifierOrStartOfDestructuring() {
-          nextToken();
-          return isBindingIdentifier() || token() === 19 /* OpenBraceToken */ || token() === 23 /* OpenBracketToken */;
-        }
-        function isLetDeclaration() {
-          return lookAhead(nextTokenIsBindingIdentifierOrStartOfDestructuring);
-        }
-        function parseStatement() {
-          switch (token()) {
-            case 27 /* SemicolonToken */:
-              return parseEmptyStatement();
-            case 19 /* OpenBraceToken */:
-              return parseBlock(
-                /*ignoreMissingOpenBrace*/
-                false
-              );
-            case 115 /* VarKeyword */:
-              return parseVariableStatement(
-                getNodePos(),
-                hasPrecedingJSDocComment(),
-                /*modifiers*/
-                void 0
-              );
-            case 121 /* LetKeyword */:
-              if (isLetDeclaration()) {
-                return parseVariableStatement(
-                  getNodePos(),
-                  hasPrecedingJSDocComment(),
-                  /*modifiers*/
-                  void 0
-                );
-              }
-              break;
-            case 100 /* FunctionKeyword */:
-              return parseFunctionDeclaration(
-                getNodePos(),
-                hasPrecedingJSDocComment(),
-                /*modifiers*/
-                void 0
-              );
-            case 86 /* ClassKeyword */:
-              return parseClassDeclaration(
-                getNodePos(),
-                hasPrecedingJSDocComment(),
-                /*modifiers*/
-                void 0
-              );
-            case 101 /* IfKeyword */:
-              return parseIfStatement();
-            case 92 /* DoKeyword */:
-              return parseDoStatement();
-            case 117 /* WhileKeyword */:
-              return parseWhileStatement();
-            case 99 /* ForKeyword */:
-              return parseForOrForInOrForOfStatement();
-            case 88 /* ContinueKeyword */:
-              return parseBreakOrContinueStatement(250 /* ContinueStatement */);
-            case 83 /* BreakKeyword */:
-              return parseBreakOrContinueStatement(251 /* BreakStatement */);
-            case 107 /* ReturnKeyword */:
-              return parseReturnStatement();
-            case 118 /* WithKeyword */:
-              return parseWithStatement();
-            case 109 /* SwitchKeyword */:
-              return parseSwitchStatement();
-            case 111 /* ThrowKeyword */:
-              return parseThrowStatement();
-            case 113 /* TryKeyword */:
-            case 85 /* CatchKeyword */:
-            case 98 /* FinallyKeyword */:
-              return parseTryStatement();
-            case 89 /* DebuggerKeyword */:
-              return parseDebuggerStatement();
-            case 60 /* AtToken */:
-              return parseDeclaration();
-            case 134 /* AsyncKeyword */:
-            case 120 /* InterfaceKeyword */:
-            case 156 /* TypeKeyword */:
-            case 144 /* ModuleKeyword */:
-            case 145 /* NamespaceKeyword */:
-            case 138 /* DeclareKeyword */:
-            case 87 /* ConstKeyword */:
-            case 94 /* EnumKeyword */:
-            case 95 /* ExportKeyword */:
-            case 102 /* ImportKeyword */:
-            case 123 /* PrivateKeyword */:
-            case 124 /* ProtectedKeyword */:
-            case 125 /* PublicKeyword */:
-            case 128 /* AbstractKeyword */:
-            case 129 /* AccessorKeyword */:
-            case 126 /* StaticKeyword */:
-            case 148 /* ReadonlyKeyword */:
-            case 161 /* GlobalKeyword */:
-              if (isStartOfDeclaration()) {
-                return parseDeclaration();
-              }
-              break;
-          }
-          return parseExpressionOrLabeledStatement();
-        }
-        function isDeclareModifier(modifier) {
-          return modifier.kind === 138 /* DeclareKeyword */;
-        }
-        function parseDeclaration() {
-          const pos = getNodePos();
-          const hasJSDoc = hasPrecedingJSDocComment();
-          const modifiers = parseModifiers(
-            /*allowDecorators*/
-            true
-          );
-          const isAmbient = some(modifiers, isDeclareModifier);
-          if (isAmbient) {
-            const node = tryReuseAmbientDeclaration(pos);
-            if (node) {
-              return node;
-            }
-            for (const m of modifiers) {
-              m.flags |= 16777216 /* Ambient */;
-            }
-            return doInsideOfContext(16777216 /* Ambient */, () => parseDeclarationWorker(pos, hasJSDoc, modifiers));
-          } else {
-            return parseDeclarationWorker(pos, hasJSDoc, modifiers);
-          }
-        }
-        function tryReuseAmbientDeclaration(pos) {
-          return doInsideOfContext(16777216 /* Ambient */, () => {
-            const node = currentNode(parsingContext, pos);
-            if (node) {
-              return consumeNode(node);
-            }
-          });
-        }
-        function parseDeclarationWorker(pos, hasJSDoc, modifiersIn) {
-          switch (token()) {
-            case 115 /* VarKeyword */:
-            case 121 /* LetKeyword */:
-            case 87 /* ConstKeyword */:
-              return parseVariableStatement(pos, hasJSDoc, modifiersIn);
-            case 100 /* FunctionKeyword */:
-              return parseFunctionDeclaration(pos, hasJSDoc, modifiersIn);
-            case 86 /* ClassKeyword */:
-              return parseClassDeclaration(pos, hasJSDoc, modifiersIn);
-            case 120 /* InterfaceKeyword */:
-              return parseInterfaceDeclaration(pos, hasJSDoc, modifiersIn);
-            case 156 /* TypeKeyword */:
-              return parseTypeAliasDeclaration(pos, hasJSDoc, modifiersIn);
-            case 94 /* EnumKeyword */:
-              return parseEnumDeclaration(pos, hasJSDoc, modifiersIn);
-            case 161 /* GlobalKeyword */:
-            case 144 /* ModuleKeyword */:
-            case 145 /* NamespaceKeyword */:
-              return parseModuleDeclaration(pos, hasJSDoc, modifiersIn);
-            case 102 /* ImportKeyword */:
-              return parseImportDeclarationOrImportEqualsDeclaration(pos, hasJSDoc, modifiersIn);
-            case 95 /* ExportKeyword */:
-              nextToken();
-              switch (token()) {
-                case 90 /* DefaultKeyword */:
-                case 64 /* EqualsToken */:
-                  return parseExportAssignment(pos, hasJSDoc, modifiersIn);
-                case 130 /* AsKeyword */:
-                  return parseNamespaceExportDeclaration(pos, hasJSDoc, modifiersIn);
-                default:
-                  return parseExportDeclaration(pos, hasJSDoc, modifiersIn);
-              }
-            default:
-              if (modifiersIn) {
-                const missing = createMissingNode(
-                  281 /* MissingDeclaration */,
-                  /*reportAtCurrentPosition*/
-                  true,
-                  Diagnostics.Declaration_expected
-                );
-                setTextRangePos(missing, pos);
-                missing.modifiers = modifiersIn;
-                return missing;
-              }
-              return void 0;
-          }
-        }
-        function nextTokenIsIdentifierOrStringLiteralOnSameLine() {
-          nextToken();
-          return !scanner2.hasPrecedingLineBreak() && (isIdentifier2() || token() === 11 /* StringLiteral */);
-        }
-        function parseFunctionBlockOrSemicolon(flags, diagnosticMessage) {
-          if (token() !== 19 /* OpenBraceToken */) {
-            if (flags & 4 /* Type */) {
-              parseTypeMemberSemicolon();
-              return;
-            }
-            if (canParseSemicolon()) {
-              parseSemicolon();
-              return;
-            }
-          }
-          return parseFunctionBlock(flags, diagnosticMessage);
-        }
-        function parseArrayBindingElement() {
-          const pos = getNodePos();
-          if (token() === 28 /* CommaToken */) {
-            return finishNode(factory2.createOmittedExpression(), pos);
-          }
-          const dotDotDotToken = parseOptionalToken(26 /* DotDotDotToken */);
-          const name = parseIdentifierOrPattern();
-          const initializer = parseInitializer();
-          return finishNode(factory2.createBindingElement(
-            dotDotDotToken,
-            /*propertyName*/
-            void 0,
-            name,
-            initializer
-          ), pos);
-        }
-        function parseObjectBindingElement() {
-          const pos = getNodePos();
-          const dotDotDotToken = parseOptionalToken(26 /* DotDotDotToken */);
-          const tokenIsIdentifier = isBindingIdentifier();
-          let propertyName = parsePropertyName();
-          let name;
-          if (tokenIsIdentifier && token() !== 59 /* ColonToken */) {
-            name = propertyName;
-            propertyName = void 0;
-          } else {
-            parseExpected(59 /* ColonToken */);
-            name = parseIdentifierOrPattern();
-          }
-          const initializer = parseInitializer();
-          return finishNode(factory2.createBindingElement(dotDotDotToken, propertyName, name, initializer), pos);
-        }
-        function parseObjectBindingPattern() {
-          const pos = getNodePos();
-          parseExpected(19 /* OpenBraceToken */);
-          const elements = parseDelimitedList(9 /* ObjectBindingElements */, parseObjectBindingElement);
-          parseExpected(20 /* CloseBraceToken */);
-          return finishNode(factory2.createObjectBindingPattern(elements), pos);
-        }
-        function parseArrayBindingPattern() {
-          const pos = getNodePos();
-          parseExpected(23 /* OpenBracketToken */);
-          const elements = parseDelimitedList(10 /* ArrayBindingElements */, parseArrayBindingElement);
-          parseExpected(24 /* CloseBracketToken */);
-          return finishNode(factory2.createArrayBindingPattern(elements), pos);
-        }
-        function isBindingIdentifierOrPrivateIdentifierOrPattern() {
-          return token() === 19 /* OpenBraceToken */ || token() === 23 /* OpenBracketToken */ || token() === 81 /* PrivateIdentifier */ || isBindingIdentifier();
-        }
-        function parseIdentifierOrPattern(privateIdentifierDiagnosticMessage) {
-          if (token() === 23 /* OpenBracketToken */) {
-            return parseArrayBindingPattern();
-          }
-          if (token() === 19 /* OpenBraceToken */) {
-            return parseObjectBindingPattern();
-          }
-          return parseBindingIdentifier(privateIdentifierDiagnosticMessage);
-        }
-        function parseVariableDeclarationAllowExclamation() {
-          return parseVariableDeclaration(
-            /*allowExclamation*/
-            true
-          );
-        }
-        function parseVariableDeclaration(allowExclamation) {
-          const pos = getNodePos();
-          const hasJSDoc = hasPrecedingJSDocComment();
-          const name = parseIdentifierOrPattern(Diagnostics.Private_identifiers_are_not_allowed_in_variable_declarations);
-          let exclamationToken;
-          if (allowExclamation && name.kind === 80 /* Identifier */ && token() === 54 /* ExclamationToken */ && !scanner2.hasPrecedingLineBreak()) {
-            exclamationToken = parseTokenNode();
-          }
-          const type = parseTypeAnnotation();
-          const initializer = isInOrOfKeyword(token()) ? void 0 : parseInitializer();
-          const node = factoryCreateVariableDeclaration(name, exclamationToken, type, initializer);
-          return withJSDoc(finishNode(node, pos), hasJSDoc);
-        }
-        function parseVariableDeclarationList(inForStatementInitializer) {
-          const pos = getNodePos();
-          let flags = 0;
-          switch (token()) {
-            case 115 /* VarKeyword */:
-              break;
-            case 121 /* LetKeyword */:
-              flags |= 1 /* Let */;
-              break;
-            case 87 /* ConstKeyword */:
-              flags |= 2 /* Const */;
-              break;
-            default:
-              Debug.fail();
-          }
-          nextToken();
-          let declarations;
-          if (token() === 164 /* OfKeyword */ && lookAhead(canFollowContextualOfKeyword)) {
-            declarations = createMissingList();
-          } else {
-            const savedDisallowIn = inDisallowInContext();
-            setDisallowInContext(inForStatementInitializer);
-            declarations = parseDelimitedList(
-              8 /* VariableDeclarations */,
-              inForStatementInitializer ? parseVariableDeclaration : parseVariableDeclarationAllowExclamation
-            );
-            setDisallowInContext(savedDisallowIn);
-          }
-          return finishNode(factoryCreateVariableDeclarationList(declarations, flags), pos);
-        }
-        function canFollowContextualOfKeyword() {
-          return nextTokenIsIdentifier() && nextToken() === 22 /* CloseParenToken */;
-        }
-        function parseVariableStatement(pos, hasJSDoc, modifiers) {
-          const declarationList = parseVariableDeclarationList(
-            /*inForStatementInitializer*/
-            false
-          );
-          parseSemicolon();
-          const node = factoryCreateVariableStatement(modifiers, declarationList);
-          return withJSDoc(finishNode(node, pos), hasJSDoc);
-        }
-        function parseFunctionDeclaration(pos, hasJSDoc, modifiers) {
-          const savedAwaitContext = inAwaitContext();
-          const modifierFlags = modifiersToFlags(modifiers);
-          parseExpected(100 /* FunctionKeyword */);
-          const asteriskToken = parseOptionalToken(42 /* AsteriskToken */);
-          const name = modifierFlags & 1024 /* Default */ ? parseOptionalBindingIdentifier() : parseBindingIdentifier();
-          const isGenerator = asteriskToken ? 1 /* Yield */ : 0 /* None */;
-          const isAsync = modifierFlags & 512 /* Async */ ? 2 /* Await */ : 0 /* None */;
-          const typeParameters = parseTypeParameters();
-          if (modifierFlags & 1 /* Export */)
-            setAwaitContext(
-              /*value*/
-              true
-            );
-          const parameters = parseParameters(isGenerator | isAsync);
-          const type = parseReturnType(
-            59 /* ColonToken */,
-            /*isType*/
-            false
-          );
-          const body = parseFunctionBlockOrSemicolon(isGenerator | isAsync, Diagnostics.or_expected);
-          setAwaitContext(savedAwaitContext);
-          const node = factory2.createFunctionDeclaration(modifiers, asteriskToken, name, typeParameters, parameters, type, body);
-          return withJSDoc(finishNode(node, pos), hasJSDoc);
-        }
-        function parseConstructorName() {
-          if (token() === 137 /* ConstructorKeyword */) {
-            return parseExpected(137 /* ConstructorKeyword */);
-          }
-          if (token() === 11 /* StringLiteral */ && lookAhead(nextToken) === 21 /* OpenParenToken */) {
-            return tryParse(() => {
-              const literalNode = parseLiteralNode();
-              return literalNode.text === "constructor" ? literalNode : void 0;
-            });
-          }
-        }
-        function tryParseConstructorDeclaration(pos, hasJSDoc, modifiers) {
-          return tryParse(() => {
-            if (parseConstructorName()) {
-              const typeParameters = parseTypeParameters();
-              const parameters = parseParameters(0 /* None */);
-              const type = parseReturnType(
-                59 /* ColonToken */,
-                /*isType*/
-                false
-              );
-              const body = parseFunctionBlockOrSemicolon(0 /* None */, Diagnostics.or_expected);
-              const node = factory2.createConstructorDeclaration(modifiers, parameters, body);
-              node.typeParameters = typeParameters;
-              node.type = type;
-              return withJSDoc(finishNode(node, pos), hasJSDoc);
-            }
-          });
-        }
-        function parseMethodDeclaration(pos, hasJSDoc, modifiers, asteriskToken, name, questionToken, exclamationToken, diagnosticMessage) {
-          const isGenerator = asteriskToken ? 1 /* Yield */ : 0 /* None */;
-          const isAsync = some(modifiers, isAsyncModifier) ? 2 /* Await */ : 0 /* None */;
-          const typeParameters = parseTypeParameters();
-          const parameters = parseParameters(isGenerator | isAsync);
-          const type = parseReturnType(
-            59 /* ColonToken */,
-            /*isType*/
-            false
-          );
-          const body = parseFunctionBlockOrSemicolon(isGenerator | isAsync, diagnosticMessage);
-          const node = factory2.createMethodDeclaration(
-            modifiers,
-            asteriskToken,
-            name,
-            questionToken,
-            typeParameters,
-            parameters,
-            type,
-            body
-          );
-          node.exclamationToken = exclamationToken;
-          return withJSDoc(finishNode(node, pos), hasJSDoc);
-        }
-        function parsePropertyDeclaration(pos, hasJSDoc, modifiers, name, questionToken) {
-          const exclamationToken = !questionToken && !scanner2.hasPrecedingLineBreak() ? parseOptionalToken(54 /* ExclamationToken */) : void 0;
-          const type = parseTypeAnnotation();
-          const initializer = doOutsideOfContext(8192 /* YieldContext */ | 32768 /* AwaitContext */ | 4096 /* DisallowInContext */, parseInitializer);
-          parseSemicolonAfterPropertyName(name, type, initializer);
-          const node = factory2.createPropertyDeclaration(
-            modifiers,
-            name,
-            questionToken || exclamationToken,
-            type,
-            initializer
-          );
-          return withJSDoc(finishNode(node, pos), hasJSDoc);
-        }
-        function parsePropertyOrMethodDeclaration(pos, hasJSDoc, modifiers) {
-          const asteriskToken = parseOptionalToken(42 /* AsteriskToken */);
-          const name = parsePropertyName();
-          const questionToken = parseOptionalToken(58 /* QuestionToken */);
-          if (asteriskToken || token() === 21 /* OpenParenToken */ || token() === 30 /* LessThanToken */) {
-            return parseMethodDeclaration(
-              pos,
-              hasJSDoc,
-              modifiers,
-              asteriskToken,
-              name,
-              questionToken,
-              /*exclamationToken*/
-              void 0,
-              Diagnostics.or_expected
-            );
-          }
-          return parsePropertyDeclaration(pos, hasJSDoc, modifiers, name, questionToken);
-        }
-        function parseAccessorDeclaration(pos, hasJSDoc, modifiers, kind, flags) {
-          const name = parsePropertyName();
-          const typeParameters = parseTypeParameters();
-          const parameters = parseParameters(0 /* None */);
-          const type = parseReturnType(
-            59 /* ColonToken */,
-            /*isType*/
-            false
-          );
-          const body = parseFunctionBlockOrSemicolon(flags);
-          const node = kind === 176 /* GetAccessor */ ? factory2.createGetAccessorDeclaration(modifiers, name, parameters, type, body) : factory2.createSetAccessorDeclaration(modifiers, name, parameters, body);
-          node.typeParameters = typeParameters;
-          if (isSetAccessorDeclaration(node))
-            node.type = type;
-          return withJSDoc(finishNode(node, pos), hasJSDoc);
-        }
-        function isClassMemberStart() {
-          let idToken;
-          if (token() === 60 /* AtToken */) {
-            return true;
-          }
-          while (isModifierKind(token())) {
-            idToken = token();
-            if (isClassMemberModifier(idToken)) {
-              return true;
-            }
-            nextToken();
-          }
-          if (token() === 42 /* AsteriskToken */) {
-            return true;
-          }
-          if (isLiteralPropertyName()) {
-            idToken = token();
-            nextToken();
-          }
-          if (token() === 23 /* OpenBracketToken */) {
-            return true;
-          }
-          if (idToken !== void 0) {
-            if (!isKeyword(idToken) || idToken === 153 /* SetKeyword */ || idToken === 139 /* GetKeyword */) {
-              return true;
-            }
-            switch (token()) {
-              case 21 /* OpenParenToken */:
-              case 30 /* LessThanToken */:
-              case 54 /* ExclamationToken */:
-              case 59 /* ColonToken */:
-              case 64 /* EqualsToken */:
-              case 58 /* QuestionToken */:
-                return true;
-              default:
-                return canParseSemicolon();
-            }
-          }
-          return false;
-        }
-        function parseClassStaticBlockDeclaration(pos, hasJSDoc, modifiers) {
-          parseExpectedToken(126 /* StaticKeyword */);
-          const body = parseClassStaticBlockBody();
-          const node = withJSDoc(finishNode(factory2.createClassStaticBlockDeclaration(body), pos), hasJSDoc);
-          node.modifiers = modifiers;
-          return node;
-        }
-        function parseClassStaticBlockBody() {
-          const savedYieldContext = inYieldContext();
-          const savedAwaitContext = inAwaitContext();
-          setYieldContext(false);
-          setAwaitContext(true);
-          const body = parseBlock(
-            /*ignoreMissingOpenBrace*/
-            false
-          );
-          setYieldContext(savedYieldContext);
-          setAwaitContext(savedAwaitContext);
-          return body;
-        }
-        function parseDecoratorExpression() {
-          if (inAwaitContext() && token() === 135 /* AwaitKeyword */) {
-            const pos = getNodePos();
-            const awaitExpression = parseIdentifier(Diagnostics.Expression_expected);
-            nextToken();
-            const memberExpression = parseMemberExpressionRest(
-              pos,
-              awaitExpression,
-              /*allowOptionalChain*/
-              true
-            );
-            return parseCallExpressionRest(pos, memberExpression);
-          }
-          return parseLeftHandSideExpressionOrHigher();
-        }
-        function tryParseDecorator() {
-          const pos = getNodePos();
-          if (!parseOptional(60 /* AtToken */)) {
-            return void 0;
-          }
-          const expression = doInDecoratorContext(parseDecoratorExpression);
-          return finishNode(factory2.createDecorator(expression), pos);
-        }
-        function tryParseModifier(hasSeenStaticModifier, permitConstAsModifier, stopOnStartOfClassStaticBlock) {
-          const pos = getNodePos();
-          const kind = token();
-          if (token() === 87 /* ConstKeyword */ && permitConstAsModifier) {
-            if (!tryParse(nextTokenIsOnSameLineAndCanFollowModifier)) {
-              return void 0;
-            }
-          } else if (stopOnStartOfClassStaticBlock && token() === 126 /* StaticKeyword */ && lookAhead(nextTokenIsOpenBrace)) {
-            return void 0;
-          } else if (hasSeenStaticModifier && token() === 126 /* StaticKeyword */) {
-            return void 0;
-          } else {
-            if (!parseAnyContextualModifier()) {
-              return void 0;
-            }
-          }
-          return finishNode(factoryCreateToken(kind), pos);
-        }
-        function parseModifiers(allowDecorators, permitConstAsModifier, stopOnStartOfClassStaticBlock) {
-          const pos = getNodePos();
-          let list;
-          let decorator, modifier, hasSeenStaticModifier = false, hasLeadingModifier = false, hasTrailingDecorator = false;
-          if (allowDecorators && token() === 60 /* AtToken */) {
-            while (decorator = tryParseDecorator()) {
-              list = append(list, decorator);
-            }
-          }
-          while (modifier = tryParseModifier(hasSeenStaticModifier, permitConstAsModifier, stopOnStartOfClassStaticBlock)) {
-            if (modifier.kind === 126 /* StaticKeyword */)
-              hasSeenStaticModifier = true;
-            list = append(list, modifier);
-            hasLeadingModifier = true;
-          }
-          if (hasLeadingModifier && allowDecorators && token() === 60 /* AtToken */) {
-            while (decorator = tryParseDecorator()) {
-              list = append(list, decorator);
-              hasTrailingDecorator = true;
-            }
-          }
-          if (hasTrailingDecorator) {
-            while (modifier = tryParseModifier(hasSeenStaticModifier, permitConstAsModifier, stopOnStartOfClassStaticBlock)) {
-              if (modifier.kind === 126 /* StaticKeyword */)
-                hasSeenStaticModifier = true;
-              list = append(list, modifier);
-            }
-          }
-          return list && createNodeArray(list, pos);
-        }
-        function parseModifiersForArrowFunction() {
-          let modifiers;
-          if (token() === 134 /* AsyncKeyword */) {
-            const pos = getNodePos();
-            nextToken();
-            const modifier = finishNode(factoryCreateToken(134 /* AsyncKeyword */), pos);
-            modifiers = createNodeArray([modifier], pos);
-          }
-          return modifiers;
-        }
-        function parseClassElement() {
-          const pos = getNodePos();
-          const hasJSDoc = hasPrecedingJSDocComment();
-          if (token() === 27 /* SemicolonToken */) {
-            nextToken();
-            return withJSDoc(finishNode(factory2.createSemicolonClassElement(), pos), hasJSDoc);
-          }
-          const modifiers = parseModifiers(
-            /*allowDecorators*/
-            true,
-            /*permitConstAsModifier*/
-            true,
-            /*stopOnStartOfClassStaticBlock*/
-            true
-          );
-          if (token() === 126 /* StaticKeyword */ && lookAhead(nextTokenIsOpenBrace)) {
-            return parseClassStaticBlockDeclaration(pos, hasJSDoc, modifiers);
-          }
-          if (parseContextualModifier(139 /* GetKeyword */)) {
-            return parseAccessorDeclaration(pos, hasJSDoc, modifiers, 176 /* GetAccessor */, 0 /* None */);
-          }
-          if (parseContextualModifier(153 /* SetKeyword */)) {
-            return parseAccessorDeclaration(pos, hasJSDoc, modifiers, 177 /* SetAccessor */, 0 /* None */);
-          }
-          if (token() === 137 /* ConstructorKeyword */ || token() === 11 /* StringLiteral */) {
-            const constructorDeclaration = tryParseConstructorDeclaration(pos, hasJSDoc, modifiers);
-            if (constructorDeclaration) {
-              return constructorDeclaration;
-            }
-          }
-          if (isIndexSignature()) {
-            return parseIndexSignatureDeclaration(pos, hasJSDoc, modifiers);
-          }
-          if (tokenIsIdentifierOrKeyword(token()) || token() === 11 /* StringLiteral */ || token() === 9 /* NumericLiteral */ || token() === 42 /* AsteriskToken */ || token() === 23 /* OpenBracketToken */) {
-            const isAmbient = some(modifiers, isDeclareModifier);
-            if (isAmbient) {
-              for (const m of modifiers) {
-                m.flags |= 16777216 /* Ambient */;
-              }
-              return doInsideOfContext(16777216 /* Ambient */, () => parsePropertyOrMethodDeclaration(pos, hasJSDoc, modifiers));
-            } else {
-              return parsePropertyOrMethodDeclaration(pos, hasJSDoc, modifiers);
-            }
-          }
-          if (modifiers) {
-            const name = createMissingNode(
-              80 /* Identifier */,
-              /*reportAtCurrentPosition*/
-              true,
-              Diagnostics.Declaration_expected
-            );
-            return parsePropertyDeclaration(
-              pos,
-              hasJSDoc,
-              modifiers,
-              name,
-              /*questionToken*/
-              void 0
-            );
-          }
-          return Debug.fail("Should not have attempted to parse class member declaration.");
-        }
-        function parseDecoratedExpression() {
-          const pos = getNodePos();
-          const hasJSDoc = hasPrecedingJSDocComment();
-          const modifiers = parseModifiers(
-            /*allowDecorators*/
-            true
-          );
-          if (token() === 86 /* ClassKeyword */) {
-            return parseClassDeclarationOrExpression(pos, hasJSDoc, modifiers, 230 /* ClassExpression */);
-          }
-          const missing = createMissingNode(
-            281 /* MissingDeclaration */,
-            /*reportAtCurrentPosition*/
-            true,
-            Diagnostics.Expression_expected
-          );
-          setTextRangePos(missing, pos);
-          missing.modifiers = modifiers;
-          return missing;
-        }
-        function parseClassExpression() {
-          return parseClassDeclarationOrExpression(
-            getNodePos(),
-            hasPrecedingJSDocComment(),
-            /*modifiers*/
-            void 0,
-            230 /* ClassExpression */
-          );
-        }
-        function parseClassDeclaration(pos, hasJSDoc, modifiers) {
-          return parseClassDeclarationOrExpression(pos, hasJSDoc, modifiers, 262 /* ClassDeclaration */);
-        }
-        function parseClassDeclarationOrExpression(pos, hasJSDoc, modifiers, kind) {
-          const savedAwaitContext = inAwaitContext();
-          parseExpected(86 /* ClassKeyword */);
-          const name = parseNameOfClassDeclarationOrExpression();
-          const typeParameters = parseTypeParameters();
-          if (some(modifiers, isExportModifier))
-            setAwaitContext(
-              /*value*/
-              true
-            );
-          const heritageClauses = parseHeritageClauses();
-          let members;
-          if (parseExpected(19 /* OpenBraceToken */)) {
-            members = parseClassMembers();
-            parseExpected(20 /* CloseBraceToken */);
-          } else {
-            members = createMissingList();
-          }
-          setAwaitContext(savedAwaitContext);
-          const node = kind === 262 /* ClassDeclaration */ ? factory2.createClassDeclaration(modifiers, name, typeParameters, heritageClauses, members) : factory2.createClassExpression(modifiers, name, typeParameters, heritageClauses, members);
-          return withJSDoc(finishNode(node, pos), hasJSDoc);
-        }
-        function parseNameOfClassDeclarationOrExpression() {
-          return isBindingIdentifier() && !isImplementsClause() ? createIdentifier(isBindingIdentifier()) : void 0;
-        }
-        function isImplementsClause() {
-          return token() === 119 /* ImplementsKeyword */ && lookAhead(nextTokenIsIdentifierOrKeyword);
-        }
-        function parseHeritageClauses() {
-          if (isHeritageClause2()) {
-            return parseList(22 /* HeritageClauses */, parseHeritageClause);
-          }
-          return void 0;
-        }
-        function parseHeritageClause() {
-          const pos = getNodePos();
-          const tok = token();
-          Debug.assert(tok === 96 /* ExtendsKeyword */ || tok === 119 /* ImplementsKeyword */);
-          nextToken();
-          const types = parseDelimitedList(7 /* HeritageClauseElement */, parseExpressionWithTypeArguments);
-          return finishNode(factory2.createHeritageClause(tok, types), pos);
-        }
-        function parseExpressionWithTypeArguments() {
-          const pos = getNodePos();
-          const expression = parseLeftHandSideExpressionOrHigher();
-          if (expression.kind === 232 /* ExpressionWithTypeArguments */) {
-            return expression;
-          }
-          const typeArguments = tryParseTypeArguments();
-          return finishNode(factory2.createExpressionWithTypeArguments(expression, typeArguments), pos);
-        }
-        function tryParseTypeArguments() {
-          return token() === 30 /* LessThanToken */ ? parseBracketedList(20 /* TypeArguments */, parseType, 30 /* LessThanToken */, 32 /* GreaterThanToken */) : void 0;
-        }
-        function isHeritageClause2() {
-          return token() === 96 /* ExtendsKeyword */ || token() === 119 /* ImplementsKeyword */;
-        }
-        function parseClassMembers() {
-          return parseList(5 /* ClassMembers */, parseClassElement);
-        }
-        function parseInterfaceDeclaration(pos, hasJSDoc, modifiers) {
-          parseExpected(120 /* InterfaceKeyword */);
-          const name = parseIdentifier();
-          const typeParameters = parseTypeParameters();
-          const heritageClauses = parseHeritageClauses();
-          const members = parseObjectTypeMembers();
-          const node = factory2.createInterfaceDeclaration(modifiers, name, typeParameters, heritageClauses, members);
-          return withJSDoc(finishNode(node, pos), hasJSDoc);
-        }
-        function parseTypeAliasDeclaration(pos, hasJSDoc, modifiers) {
-          parseExpected(156 /* TypeKeyword */);
-          const name = parseIdentifier();
-          const typeParameters = parseTypeParameters();
-          parseExpected(64 /* EqualsToken */);
-          const type = token() === 141 /* IntrinsicKeyword */ && tryParse(parseKeywordAndNoDot) || parseType();
-          parseSemicolon();
-          const node = factory2.createTypeAliasDeclaration(modifiers, name, typeParameters, type);
-          return withJSDoc(finishNode(node, pos), hasJSDoc);
-        }
-        function parseEnumMember() {
-          const pos = getNodePos();
-          const hasJSDoc = hasPrecedingJSDocComment();
-          const name = parsePropertyName();
-          const initializer = allowInAnd(parseInitializer);
-          return withJSDoc(finishNode(factory2.createEnumMember(name, initializer), pos), hasJSDoc);
-        }
-        function parseEnumDeclaration(pos, hasJSDoc, modifiers) {
-          parseExpected(94 /* EnumKeyword */);
-          const name = parseIdentifier();
-          let members;
-          if (parseExpected(19 /* OpenBraceToken */)) {
-            members = doOutsideOfYieldAndAwaitContext(() => parseDelimitedList(6 /* EnumMembers */, parseEnumMember));
-            parseExpected(20 /* CloseBraceToken */);
-          } else {
-            members = createMissingList();
-          }
-          const node = factory2.createEnumDeclaration(modifiers, name, members);
-          return withJSDoc(finishNode(node, pos), hasJSDoc);
-        }
-        function parseModuleBlock() {
-          const pos = getNodePos();
-          let statements;
-          if (parseExpected(19 /* OpenBraceToken */)) {
-            statements = parseList(1 /* BlockStatements */, parseStatement);
-            parseExpected(20 /* CloseBraceToken */);
-          } else {
-            statements = createMissingList();
-          }
-          return finishNode(factory2.createModuleBlock(statements), pos);
-        }
-        function parseModuleOrNamespaceDeclaration(pos, hasJSDoc, modifiers, flags) {
-          const namespaceFlag = flags & 16 /* Namespace */;
-          const name = parseIdentifier();
-          const body = parseOptional(25 /* DotToken */) ? parseModuleOrNamespaceDeclaration(
-            getNodePos(),
-            /*hasJSDoc*/
-            false,
-            /*modifiers*/
-            void 0,
-            4 /* NestedNamespace */ | namespaceFlag
-          ) : parseModuleBlock();
-          const node = factory2.createModuleDeclaration(modifiers, name, body, flags);
-          return withJSDoc(finishNode(node, pos), hasJSDoc);
-        }
-        function parseAmbientExternalModuleDeclaration(pos, hasJSDoc, modifiersIn) {
-          let flags = 0;
-          let name;
-          if (token() === 161 /* GlobalKeyword */) {
-            name = parseIdentifier();
-            flags |= 1024 /* GlobalAugmentation */;
-          } else {
-            name = parseLiteralNode();
-            name.text = internIdentifier(name.text);
-          }
-          let body;
-          if (token() === 19 /* OpenBraceToken */) {
-            body = parseModuleBlock();
-          } else {
-            parseSemicolon();
-          }
-          const node = factory2.createModuleDeclaration(modifiersIn, name, body, flags);
-          return withJSDoc(finishNode(node, pos), hasJSDoc);
-        }
-        function parseModuleDeclaration(pos, hasJSDoc, modifiersIn) {
-          let flags = 0;
-          if (token() === 161 /* GlobalKeyword */) {
-            return parseAmbientExternalModuleDeclaration(pos, hasJSDoc, modifiersIn);
-          } else if (parseOptional(145 /* NamespaceKeyword */)) {
-            flags |= 16 /* Namespace */;
-          } else {
-            parseExpected(144 /* ModuleKeyword */);
-            if (token() === 11 /* StringLiteral */) {
-              return parseAmbientExternalModuleDeclaration(pos, hasJSDoc, modifiersIn);
-            }
-          }
-          return parseModuleOrNamespaceDeclaration(pos, hasJSDoc, modifiersIn, flags);
-        }
-        function isExternalModuleReference2() {
-          return token() === 149 /* RequireKeyword */ && lookAhead(nextTokenIsOpenParen);
-        }
-        function nextTokenIsOpenParen() {
-          return nextToken() === 21 /* OpenParenToken */;
-        }
-        function nextTokenIsOpenBrace() {
-          return nextToken() === 19 /* OpenBraceToken */;
-        }
-        function nextTokenIsSlash() {
-          return nextToken() === 44 /* SlashToken */;
-        }
-        function parseNamespaceExportDeclaration(pos, hasJSDoc, modifiers) {
-          parseExpected(130 /* AsKeyword */);
-          parseExpected(145 /* NamespaceKeyword */);
-          const name = parseIdentifier();
-          parseSemicolon();
-          const node = factory2.createNamespaceExportDeclaration(name);
-          node.modifiers = modifiers;
-          return withJSDoc(finishNode(node, pos), hasJSDoc);
-        }
-        function parseImportDeclarationOrImportEqualsDeclaration(pos, hasJSDoc, modifiers) {
-          parseExpected(102 /* ImportKeyword */);
-          const afterImportPos = scanner2.getTokenFullStart();
-          let identifier;
-          if (isIdentifier2()) {
-            identifier = parseIdentifier();
-          }
-          let isTypeOnly = false;
-          if (token() !== 160 /* FromKeyword */ && (identifier == null ? void 0 : identifier.escapedText) === "type" && (isIdentifier2() || tokenAfterImportDefinitelyProducesImportDeclaration())) {
-            isTypeOnly = true;
-            identifier = isIdentifier2() ? parseIdentifier() : void 0;
-          }
-          if (identifier && !tokenAfterImportedIdentifierDefinitelyProducesImportDeclaration()) {
-            return parseImportEqualsDeclaration(pos, hasJSDoc, modifiers, identifier, isTypeOnly);
-          }
-          let importClause;
-          if (identifier || // import id
-          token() === 42 /* AsteriskToken */ || // import *
-          token() === 19 /* OpenBraceToken */) {
-            importClause = parseImportClause(identifier, afterImportPos, isTypeOnly);
-            parseExpected(160 /* FromKeyword */);
-          }
-          const moduleSpecifier = parseModuleSpecifier();
-          let assertClause;
-          if (token() === 132 /* AssertKeyword */ && !scanner2.hasPrecedingLineBreak()) {
-            assertClause = parseAssertClause();
-          }
-          parseSemicolon();
-          const node = factory2.createImportDeclaration(modifiers, importClause, moduleSpecifier, assertClause);
-          return withJSDoc(finishNode(node, pos), hasJSDoc);
-        }
-        function parseAssertEntry() {
-          const pos = getNodePos();
-          const name = tokenIsIdentifierOrKeyword(token()) ? parseIdentifierName() : parseLiteralLikeNode(11 /* StringLiteral */);
-          parseExpected(59 /* ColonToken */);
-          const value = parseAssignmentExpressionOrHigher(
-            /*allowReturnTypeInArrowFunction*/
-            true
-          );
-          return finishNode(factory2.createAssertEntry(name, value), pos);
-        }
-        function parseAssertClause(skipAssertKeyword) {
-          const pos = getNodePos();
-          if (!skipAssertKeyword) {
-            parseExpected(132 /* AssertKeyword */);
-          }
-          const openBracePosition = scanner2.getTokenStart();
-          if (parseExpected(19 /* OpenBraceToken */)) {
-            const multiLine = scanner2.hasPrecedingLineBreak();
-            const elements = parseDelimitedList(
-              24 /* AssertEntries */,
-              parseAssertEntry,
-              /*considerSemicolonAsDelimiter*/
-              true
-            );
-            if (!parseExpected(20 /* CloseBraceToken */)) {
-              const lastError = lastOrUndefined(parseDiagnostics);
-              if (lastError && lastError.code === Diagnostics._0_expected.code) {
-                addRelatedInfo(
-                  lastError,
-                  createDetachedDiagnostic(fileName, openBracePosition, 1, Diagnostics.The_parser_expected_to_find_a_1_to_match_the_0_token_here, "{", "}")
-                );
-              }
-            }
-            return finishNode(factory2.createAssertClause(elements, multiLine), pos);
-          } else {
-            const elements = createNodeArray(
-              [],
-              getNodePos(),
-              /*end*/
-              void 0,
-              /*hasTrailingComma*/
-              false
-            );
-            return finishNode(factory2.createAssertClause(
-              elements,
-              /*multiLine*/
-              false
-            ), pos);
-          }
-        }
-        function tokenAfterImportDefinitelyProducesImportDeclaration() {
-          return token() === 42 /* AsteriskToken */ || token() === 19 /* OpenBraceToken */;
-        }
-        function tokenAfterImportedIdentifierDefinitelyProducesImportDeclaration() {
-          return token() === 28 /* CommaToken */ || token() === 160 /* FromKeyword */;
-        }
-        function parseImportEqualsDeclaration(pos, hasJSDoc, modifiers, identifier, isTypeOnly) {
-          parseExpected(64 /* EqualsToken */);
-          const moduleReference = parseModuleReference();
-          parseSemicolon();
-          const node = factory2.createImportEqualsDeclaration(modifiers, isTypeOnly, identifier, moduleReference);
-          const finished = withJSDoc(finishNode(node, pos), hasJSDoc);
-          return finished;
-        }
-        function parseImportClause(identifier, pos, isTypeOnly) {
-          let namedBindings;
-          if (!identifier || parseOptional(28 /* CommaToken */)) {
-            namedBindings = token() === 42 /* AsteriskToken */ ? parseNamespaceImport() : parseNamedImportsOrExports(274 /* NamedImports */);
-          }
-          return finishNode(factory2.createImportClause(isTypeOnly, identifier, namedBindings), pos);
-        }
-        function parseModuleReference() {
-          return isExternalModuleReference2() ? parseExternalModuleReference() : parseEntityName(
-            /*allowReservedWords*/
-            false
-          );
-        }
-        function parseExternalModuleReference() {
-          const pos = getNodePos();
-          parseExpected(149 /* RequireKeyword */);
-          parseExpected(21 /* OpenParenToken */);
-          const expression = parseModuleSpecifier();
-          parseExpected(22 /* CloseParenToken */);
-          return finishNode(factory2.createExternalModuleReference(expression), pos);
-        }
-        function parseModuleSpecifier() {
-          if (token() === 11 /* StringLiteral */) {
-            const result = parseLiteralNode();
-            result.text = internIdentifier(result.text);
-            return result;
-          } else {
-            return parseExpression();
-          }
-        }
-        function parseNamespaceImport() {
-          const pos = getNodePos();
-          parseExpected(42 /* AsteriskToken */);
-          parseExpected(130 /* AsKeyword */);
-          const name = parseIdentifier();
-          return finishNode(factory2.createNamespaceImport(name), pos);
-        }
-        function parseNamedImportsOrExports(kind) {
-          const pos = getNodePos();
-          const node = kind === 274 /* NamedImports */ ? factory2.createNamedImports(parseBracketedList(23 /* ImportOrExportSpecifiers */, parseImportSpecifier, 19 /* OpenBraceToken */, 20 /* CloseBraceToken */)) : factory2.createNamedExports(parseBracketedList(23 /* ImportOrExportSpecifiers */, parseExportSpecifier, 19 /* OpenBraceToken */, 20 /* CloseBraceToken */));
-          return finishNode(node, pos);
-        }
-        function parseExportSpecifier() {
-          const hasJSDoc = hasPrecedingJSDocComment();
-          return withJSDoc(parseImportOrExportSpecifier(280 /* ExportSpecifier */), hasJSDoc);
-        }
-        function parseImportSpecifier() {
-          return parseImportOrExportSpecifier(275 /* ImportSpecifier */);
-        }
-        function parseImportOrExportSpecifier(kind) {
-          const pos = getNodePos();
-          let checkIdentifierIsKeyword = isKeyword(token()) && !isIdentifier2();
-          let checkIdentifierStart = scanner2.getTokenStart();
-          let checkIdentifierEnd = scanner2.getTokenEnd();
-          let isTypeOnly = false;
-          let propertyName;
-          let canParseAsKeyword = true;
-          let name = parseIdentifierName();
-          if (name.escapedText === "type") {
-            if (token() === 130 /* AsKeyword */) {
-              const firstAs = parseIdentifierName();
-              if (token() === 130 /* AsKeyword */) {
-                const secondAs = parseIdentifierName();
-                if (tokenIsIdentifierOrKeyword(token())) {
-                  isTypeOnly = true;
-                  propertyName = firstAs;
-                  name = parseNameWithKeywordCheck();
-                  canParseAsKeyword = false;
-                } else {
-                  propertyName = name;
-                  name = secondAs;
-                  canParseAsKeyword = false;
-                }
-              } else if (tokenIsIdentifierOrKeyword(token())) {
-                propertyName = name;
-                canParseAsKeyword = false;
-                name = parseNameWithKeywordCheck();
-              } else {
-                isTypeOnly = true;
-                name = firstAs;
-              }
-            } else if (tokenIsIdentifierOrKeyword(token())) {
-              isTypeOnly = true;
-              name = parseNameWithKeywordCheck();
-            }
-          }
-          if (canParseAsKeyword && token() === 130 /* AsKeyword */) {
-            propertyName = name;
-            parseExpected(130 /* AsKeyword */);
-            name = parseNameWithKeywordCheck();
-          }
-          if (kind === 275 /* ImportSpecifier */ && checkIdentifierIsKeyword) {
-            parseErrorAt(checkIdentifierStart, checkIdentifierEnd, Diagnostics.Identifier_expected);
-          }
-          const node = kind === 275 /* ImportSpecifier */ ? factory2.createImportSpecifier(isTypeOnly, propertyName, name) : factory2.createExportSpecifier(isTypeOnly, propertyName, name);
-          return finishNode(node, pos);
-          function parseNameWithKeywordCheck() {
-            checkIdentifierIsKeyword = isKeyword(token()) && !isIdentifier2();
-            checkIdentifierStart = scanner2.getTokenStart();
-            checkIdentifierEnd = scanner2.getTokenEnd();
-            return parseIdentifierName();
-          }
-        }
-        function parseNamespaceExport(pos) {
-          return finishNode(factory2.createNamespaceExport(parseIdentifierName()), pos);
-        }
-        function parseExportDeclaration(pos, hasJSDoc, modifiers) {
-          const savedAwaitContext = inAwaitContext();
-          setAwaitContext(
-            /*value*/
-            true
-          );
-          let exportClause;
-          let moduleSpecifier;
-          let assertClause;
-          const isTypeOnly = parseOptional(156 /* TypeKeyword */);
-          const namespaceExportPos = getNodePos();
-          if (parseOptional(42 /* AsteriskToken */)) {
-            if (parseOptional(130 /* AsKeyword */)) {
-              exportClause = parseNamespaceExport(namespaceExportPos);
-            }
-            parseExpected(160 /* FromKeyword */);
-            moduleSpecifier = parseModuleSpecifier();
-          } else {
-            exportClause = parseNamedImportsOrExports(278 /* NamedExports */);
-            if (token() === 160 /* FromKeyword */ || token() === 11 /* StringLiteral */ && !scanner2.hasPrecedingLineBreak()) {
-              parseExpected(160 /* FromKeyword */);
-              moduleSpecifier = parseModuleSpecifier();
-            }
-          }
-          if (moduleSpecifier && token() === 132 /* AssertKeyword */ && !scanner2.hasPrecedingLineBreak()) {
-            assertClause = parseAssertClause();
-          }
-          parseSemicolon();
-          setAwaitContext(savedAwaitContext);
-          const node = factory2.createExportDeclaration(modifiers, isTypeOnly, exportClause, moduleSpecifier, assertClause);
-          return withJSDoc(finishNode(node, pos), hasJSDoc);
-        }
-        function parseExportAssignment(pos, hasJSDoc, modifiers) {
-          const savedAwaitContext = inAwaitContext();
-          setAwaitContext(
-            /*value*/
-            true
-          );
-          let isExportEquals;
-          if (parseOptional(64 /* EqualsToken */)) {
-            isExportEquals = true;
-          } else {
-            parseExpected(90 /* DefaultKeyword */);
-          }
-          const expression = parseAssignmentExpressionOrHigher(
-            /*allowReturnTypeInArrowFunction*/
-            true
-          );
-          parseSemicolon();
-          setAwaitContext(savedAwaitContext);
-          const node = factory2.createExportAssignment(modifiers, isExportEquals, expression);
-          return withJSDoc(finishNode(node, pos), hasJSDoc);
-        }
-        let ParsingContext;
-        ((ParsingContext2) => {
-          ParsingContext2[ParsingContext2["SourceElements"] = 0] = "SourceElements";
-          ParsingContext2[ParsingContext2["BlockStatements"] = 1] = "BlockStatements";
-          ParsingContext2[ParsingContext2["SwitchClauses"] = 2] = "SwitchClauses";
-          ParsingContext2[ParsingContext2["SwitchClauseStatements"] = 3] = "SwitchClauseStatements";
-          ParsingContext2[ParsingContext2["TypeMembers"] = 4] = "TypeMembers";
-          ParsingContext2[ParsingContext2["ClassMembers"] = 5] = "ClassMembers";
-          ParsingContext2[ParsingContext2["EnumMembers"] = 6] = "EnumMembers";
-          ParsingContext2[ParsingContext2["HeritageClauseElement"] = 7] = "HeritageClauseElement";
-          ParsingContext2[ParsingContext2["VariableDeclarations"] = 8] = "VariableDeclarations";
-          ParsingContext2[ParsingContext2["ObjectBindingElements"] = 9] = "ObjectBindingElements";
-          ParsingContext2[ParsingContext2["ArrayBindingElements"] = 10] = "ArrayBindingElements";
-          ParsingContext2[ParsingContext2["ArgumentExpressions"] = 11] = "ArgumentExpressions";
-          ParsingContext2[ParsingContext2["ObjectLiteralMembers"] = 12] = "ObjectLiteralMembers";
-          ParsingContext2[ParsingContext2["JsxAttributes"] = 13] = "JsxAttributes";
-          ParsingContext2[ParsingContext2["JsxChildren"] = 14] = "JsxChildren";
-          ParsingContext2[ParsingContext2["ArrayLiteralMembers"] = 15] = "ArrayLiteralMembers";
-          ParsingContext2[ParsingContext2["Parameters"] = 16] = "Parameters";
-          ParsingContext2[ParsingContext2["JSDocParameters"] = 17] = "JSDocParameters";
-          ParsingContext2[ParsingContext2["RestProperties"] = 18] = "RestProperties";
-          ParsingContext2[ParsingContext2["TypeParameters"] = 19] = "TypeParameters";
-          ParsingContext2[ParsingContext2["TypeArguments"] = 20] = "TypeArguments";
-          ParsingContext2[ParsingContext2["TupleElementTypes"] = 21] = "TupleElementTypes";
-          ParsingContext2[ParsingContext2["HeritageClauses"] = 22] = "HeritageClauses";
-          ParsingContext2[ParsingContext2["ImportOrExportSpecifiers"] = 23] = "ImportOrExportSpecifiers";
-          ParsingContext2[ParsingContext2["AssertEntries"] = 24] = "AssertEntries";
-          ParsingContext2[ParsingContext2["JSDocComment"] = 25] = "JSDocComment";
-          ParsingContext2[ParsingContext2["Count"] = 26] = "Count";
-        })(ParsingContext || (ParsingContext = {}));
-        let Tristate;
-        ((Tristate2) => {
-          Tristate2[Tristate2["False"] = 0] = "False";
-          Tristate2[Tristate2["True"] = 1] = "True";
-          Tristate2[Tristate2["Unknown"] = 2] = "Unknown";
-        })(Tristate || (Tristate = {}));
-        let JSDocParser;
-        ((JSDocParser2) => {
-          function parseJSDocTypeExpressionForTests2(content, start, length2) {
-            initializeState(
-              "file.js",
-              content,
-              99 /* Latest */,
-              /*syntaxCursor*/
-              void 0,
-              1 /* JS */
-            );
-            scanner2.setText(content, start, length2);
-            currentToken = scanner2.scan();
-            const jsDocTypeExpression = parseJSDocTypeExpression();
-            const sourceFile = createSourceFile2(
-              "file.js",
-              99 /* Latest */,
-              1 /* JS */,
-              /*isDeclarationFile*/
-              false,
-              [],
-              factoryCreateToken(1 /* EndOfFileToken */),
-              0 /* None */,
-              noop
-            );
-            const diagnostics = attachFileToDiagnostics(parseDiagnostics, sourceFile);
-            if (jsDocDiagnostics) {
-              sourceFile.jsDocDiagnostics = attachFileToDiagnostics(jsDocDiagnostics, sourceFile);
-            }
-            clearState();
-            return jsDocTypeExpression ? { jsDocTypeExpression, diagnostics } : void 0;
-          }
-          JSDocParser2.parseJSDocTypeExpressionForTests = parseJSDocTypeExpressionForTests2;
-          function parseJSDocTypeExpression(mayOmitBraces) {
-            const pos = getNodePos();
-            const hasBrace = (mayOmitBraces ? parseOptional : parseExpected)(19 /* OpenBraceToken */);
-            const type = doInsideOfContext(8388608 /* JSDoc */, parseJSDocType);
-            if (!mayOmitBraces || hasBrace) {
-              parseExpectedJSDoc(20 /* CloseBraceToken */);
-            }
-            const result = factory2.createJSDocTypeExpression(type);
-            fixupParentReferences(result);
-            return finishNode(result, pos);
-          }
-          JSDocParser2.parseJSDocTypeExpression = parseJSDocTypeExpression;
-          function parseJSDocNameReference() {
-            const pos = getNodePos();
-            const hasBrace = parseOptional(19 /* OpenBraceToken */);
-            const p2 = getNodePos();
-            let entityName = parseEntityName(
-              /*allowReservedWords*/
-              false
-            );
-            while (token() === 81 /* PrivateIdentifier */) {
-              reScanHashToken();
-              nextTokenJSDoc();
-              entityName = finishNode(factory2.createJSDocMemberName(entityName, parseIdentifier()), p2);
-            }
-            if (hasBrace) {
-              parseExpectedJSDoc(20 /* CloseBraceToken */);
-            }
-            const result = factory2.createJSDocNameReference(entityName);
-            fixupParentReferences(result);
-            return finishNode(result, pos);
-          }
-          JSDocParser2.parseJSDocNameReference = parseJSDocNameReference;
-          function parseIsolatedJSDocComment2(content, start, length2) {
-            initializeState(
-              "",
-              content,
-              99 /* Latest */,
-              /*syntaxCursor*/
-              void 0,
-              1 /* JS */
-            );
-            const jsDoc = doInsideOfContext(8388608 /* JSDoc */, () => parseJSDocCommentWorker(start, length2));
-            const sourceFile = { languageVariant: 0 /* Standard */, text: content };
-            const diagnostics = attachFileToDiagnostics(parseDiagnostics, sourceFile);
-            clearState();
-            return jsDoc ? { jsDoc, diagnostics } : void 0;
-          }
-          JSDocParser2.parseIsolatedJSDocComment = parseIsolatedJSDocComment2;
-          function parseJSDocComment(parent2, start, length2) {
-            const saveToken = currentToken;
-            const saveParseDiagnosticsLength = parseDiagnostics.length;
-            const saveParseErrorBeforeNextFinishedNode = parseErrorBeforeNextFinishedNode;
-            const comment = doInsideOfContext(8388608 /* JSDoc */, () => parseJSDocCommentWorker(start, length2));
-            setParent(comment, parent2);
-            if (contextFlags & 262144 /* JavaScriptFile */) {
-              if (!jsDocDiagnostics) {
-                jsDocDiagnostics = [];
-              }
-              jsDocDiagnostics.push(...parseDiagnostics);
-            }
-            currentToken = saveToken;
-            parseDiagnostics.length = saveParseDiagnosticsLength;
-            parseErrorBeforeNextFinishedNode = saveParseErrorBeforeNextFinishedNode;
-            return comment;
-          }
-          JSDocParser2.parseJSDocComment = parseJSDocComment;
-          let JSDocState;
-          ((JSDocState2) => {
-            JSDocState2[JSDocState2["BeginningOfLine"] = 0] = "BeginningOfLine";
-            JSDocState2[JSDocState2["SawAsterisk"] = 1] = "SawAsterisk";
-            JSDocState2[JSDocState2["SavingComments"] = 2] = "SavingComments";
-            JSDocState2[JSDocState2["SavingBackticks"] = 3] = "SavingBackticks";
-          })(JSDocState || (JSDocState = {}));
-          let PropertyLikeParse;
-          ((PropertyLikeParse2) => {
-            PropertyLikeParse2[PropertyLikeParse2["Property"] = 1] = "Property";
-            PropertyLikeParse2[PropertyLikeParse2["Parameter"] = 2] = "Parameter";
-            PropertyLikeParse2[PropertyLikeParse2["CallbackParameter"] = 4] = "CallbackParameter";
-          })(PropertyLikeParse || (PropertyLikeParse = {}));
-          function parseJSDocCommentWorker(start = 0, length2) {
-            const saveParsingContext = parsingContext;
-            parsingContext |= 1 << 25 /* JSDocComment */;
-            const content = sourceText;
-            const end = length2 === void 0 ? content.length : start + length2;
-            length2 = end - start;
-            Debug.assert(start >= 0);
-            Debug.assert(start <= end);
-            Debug.assert(end <= content.length);
-            if (!isJSDocLikeText(content, start)) {
-              return void 0;
-            }
-            let tags;
-            let tagsPos;
-            let tagsEnd;
-            let linkEnd;
-            let commentsPos;
-            let comments = [];
-            const parts = [];
-            const result = scanner2.scanRange(start + 3, length2 - 5, doJSDocScan);
-            parsingContext = saveParsingContext;
-            return result;
-            function doJSDocScan() {
-              let state = 1 /* SawAsterisk */;
-              let margin;
-              let indent2 = start - (content.lastIndexOf("\n", start) + 1) + 4;
-              function pushComment(text) {
-                if (!margin) {
-                  margin = indent2;
-                }
-                comments.push(text);
-                indent2 += text.length;
-              }
-              nextTokenJSDoc();
-              while (parseOptionalJsdoc(5 /* WhitespaceTrivia */))
-                ;
-              if (parseOptionalJsdoc(4 /* NewLineTrivia */)) {
-                state = 0 /* BeginningOfLine */;
-                indent2 = 0;
-              }
-              loop:
-                while (true) {
-                  switch (token()) {
-                    case 60 /* AtToken */:
-                      removeTrailingWhitespace(comments);
-                      if (!commentsPos)
-                        commentsPos = getNodePos();
-                      addTag(parseTag(indent2));
-                      state = 0 /* BeginningOfLine */;
-                      margin = void 0;
-                      break;
-                    case 4 /* NewLineTrivia */:
-                      comments.push(scanner2.getTokenText());
-                      state = 0 /* BeginningOfLine */;
-                      indent2 = 0;
-                      break;
-                    case 42 /* AsteriskToken */:
-                      const asterisk = scanner2.getTokenText();
-                      if (state === 1 /* SawAsterisk */) {
-                        state = 2 /* SavingComments */;
-                        pushComment(asterisk);
-                      } else {
-                        Debug.assert(state === 0 /* BeginningOfLine */);
-                        state = 1 /* SawAsterisk */;
-                        indent2 += asterisk.length;
-                      }
-                      break;
-                    case 5 /* WhitespaceTrivia */:
-                      Debug.assert(state !== 2 /* SavingComments */, "whitespace shouldn't come from the scanner while saving top-level comment text");
-                      const whitespace = scanner2.getTokenText();
-                      if (margin !== void 0 && indent2 + whitespace.length > margin) {
-                        comments.push(whitespace.slice(margin - indent2));
-                      }
-                      indent2 += whitespace.length;
-                      break;
-                    case 1 /* EndOfFileToken */:
-                      break loop;
-                    case 82 /* JSDocCommentTextToken */:
-                      state = 2 /* SavingComments */;
-                      pushComment(scanner2.getTokenValue());
-                      break;
-                    case 19 /* OpenBraceToken */:
-                      state = 2 /* SavingComments */;
-                      const commentEnd = scanner2.getTokenFullStart();
-                      const linkStart = scanner2.getTokenEnd() - 1;
-                      const link = parseJSDocLink(linkStart);
-                      if (link) {
-                        if (!linkEnd) {
-                          removeLeadingNewlines(comments);
-                        }
-                        parts.push(finishNode(factory2.createJSDocText(comments.join("")), linkEnd ?? start, commentEnd));
-                        parts.push(link);
-                        comments = [];
-                        linkEnd = scanner2.getTokenEnd();
-                        break;
-                      }
-                    default:
-                      state = 2 /* SavingComments */;
-                      pushComment(scanner2.getTokenText());
-                      break;
-                  }
-                  if (state === 2 /* SavingComments */) {
-                    nextJSDocCommentTextToken(
-                      /*inBackticks*/
-                      false
-                    );
-                  } else {
-                    nextTokenJSDoc();
-                  }
-                }
-              const trimmedComments = trimStringEnd(comments.join(""));
-              if (parts.length && trimmedComments.length) {
-                parts.push(finishNode(factory2.createJSDocText(trimmedComments), linkEnd ?? start, commentsPos));
-              }
-              if (parts.length && tags)
-                Debug.assertIsDefined(commentsPos, "having parsed tags implies that the end of the comment span should be set");
-              const tagsArray = tags && createNodeArray(tags, tagsPos, tagsEnd);
-              return finishNode(factory2.createJSDocComment(parts.length ? createNodeArray(parts, start, commentsPos) : trimmedComments.length ? trimmedComments : void 0, tagsArray), start, end);
-            }
-            function removeLeadingNewlines(comments2) {
-              while (comments2.length && (comments2[0] === "\n" || comments2[0] === "\r")) {
-                comments2.shift();
-              }
-            }
-            function removeTrailingWhitespace(comments2) {
-              while (comments2.length) {
-                const trimmed = trimStringEnd(comments2[comments2.length - 1]);
-                if (trimmed === "") {
-                  comments2.pop();
-                } else if (trimmed.length < comments2[comments2.length - 1].length) {
-                  comments2[comments2.length - 1] = trimmed;
-                  break;
-                } else {
-                  break;
-                }
-              }
-            }
-            function isNextNonwhitespaceTokenEndOfFile() {
-              while (true) {
-                nextTokenJSDoc();
-                if (token() === 1 /* EndOfFileToken */) {
-                  return true;
-                }
-                if (!(token() === 5 /* WhitespaceTrivia */ || token() === 4 /* NewLineTrivia */)) {
-                  return false;
-                }
-              }
-            }
-            function skipWhitespace() {
-              if (token() === 5 /* WhitespaceTrivia */ || token() === 4 /* NewLineTrivia */) {
-                if (lookAhead(isNextNonwhitespaceTokenEndOfFile)) {
-                  return;
-                }
-              }
-              while (token() === 5 /* WhitespaceTrivia */ || token() === 4 /* NewLineTrivia */) {
-                nextTokenJSDoc();
-              }
-            }
-            function skipWhitespaceOrAsterisk() {
-              if (token() === 5 /* WhitespaceTrivia */ || token() === 4 /* NewLineTrivia */) {
-                if (lookAhead(isNextNonwhitespaceTokenEndOfFile)) {
-                  return "";
-                }
-              }
-              let precedingLineBreak = scanner2.hasPrecedingLineBreak();
-              let seenLineBreak = false;
-              let indentText = "";
-              while (precedingLineBreak && token() === 42 /* AsteriskToken */ || token() === 5 /* WhitespaceTrivia */ || token() === 4 /* NewLineTrivia */) {
-                indentText += scanner2.getTokenText();
-                if (token() === 4 /* NewLineTrivia */) {
-                  precedingLineBreak = true;
-                  seenLineBreak = true;
-                  indentText = "";
-                } else if (token() === 42 /* AsteriskToken */) {
-                  precedingLineBreak = false;
-                }
-                nextTokenJSDoc();
-              }
-              return seenLineBreak ? indentText : "";
-            }
-            function parseTag(margin) {
-              Debug.assert(token() === 60 /* AtToken */);
-              const start2 = scanner2.getTokenStart();
-              nextTokenJSDoc();
-              const tagName = parseJSDocIdentifierName(
-                /*message*/
-                void 0
-              );
-              const indentText = skipWhitespaceOrAsterisk();
-              let tag;
-              switch (tagName.escapedText) {
-                case "author":
-                  tag = parseAuthorTag(start2, tagName, margin, indentText);
-                  break;
-                case "implements":
-                  tag = parseImplementsTag(start2, tagName, margin, indentText);
-                  break;
-                case "augments":
-                case "extends":
-                  tag = parseAugmentsTag(start2, tagName, margin, indentText);
-                  break;
-                case "class":
-                case "constructor":
-                  tag = parseSimpleTag(start2, factory2.createJSDocClassTag, tagName, margin, indentText);
-                  break;
-                case "public":
-                  tag = parseSimpleTag(start2, factory2.createJSDocPublicTag, tagName, margin, indentText);
-                  break;
-                case "private":
-                  tag = parseSimpleTag(start2, factory2.createJSDocPrivateTag, tagName, margin, indentText);
-                  break;
-                case "protected":
-                  tag = parseSimpleTag(start2, factory2.createJSDocProtectedTag, tagName, margin, indentText);
-                  break;
-                case "readonly":
-                  tag = parseSimpleTag(start2, factory2.createJSDocReadonlyTag, tagName, margin, indentText);
-                  break;
-                case "override":
-                  tag = parseSimpleTag(start2, factory2.createJSDocOverrideTag, tagName, margin, indentText);
-                  break;
-                case "deprecated":
-                  hasDeprecatedTag = true;
-                  tag = parseSimpleTag(start2, factory2.createJSDocDeprecatedTag, tagName, margin, indentText);
-                  break;
-                case "this":
-                  tag = parseThisTag(start2, tagName, margin, indentText);
-                  break;
-                case "enum":
-                  tag = parseEnumTag(start2, tagName, margin, indentText);
-                  break;
-                case "arg":
-                case "argument":
-                case "param":
-                  return parseParameterOrPropertyTag(start2, tagName, 2 /* Parameter */, margin);
-                case "return":
-                case "returns":
-                  tag = parseReturnTag(start2, tagName, margin, indentText);
-                  break;
-                case "template":
-                  tag = parseTemplateTag(start2, tagName, margin, indentText);
-                  break;
-                case "type":
-                  tag = parseTypeTag(start2, tagName, margin, indentText);
-                  break;
-                case "typedef":
-                  tag = parseTypedefTag(start2, tagName, margin, indentText);
-                  break;
-                case "callback":
-                  tag = parseCallbackTag(start2, tagName, margin, indentText);
-                  break;
-                case "overload":
-                  tag = parseOverloadTag(start2, tagName, margin, indentText);
-                  break;
-                case "satisfies":
-                  tag = parseSatisfiesTag(start2, tagName, margin, indentText);
-                  break;
-                case "see":
-                  tag = parseSeeTag(start2, tagName, margin, indentText);
-                  break;
-                case "exception":
-                case "throws":
-                  tag = parseThrowsTag(start2, tagName, margin, indentText);
-                  break;
-                default:
-                  tag = parseUnknownTag(start2, tagName, margin, indentText);
-                  break;
-              }
-              return tag;
-            }
-            function parseTrailingTagComments(pos, end2, margin, indentText) {
-              if (!indentText) {
-                margin += end2 - pos;
-              }
-              return parseTagComments(margin, indentText.slice(margin));
-            }
-            function parseTagComments(indent2, initialMargin) {
-              const commentsPos2 = getNodePos();
-              let comments2 = [];
-              const parts2 = [];
-              let linkEnd2;
-              let state = 0 /* BeginningOfLine */;
-              let margin;
-              function pushComment(text) {
-                if (!margin) {
-                  margin = indent2;
-                }
-                comments2.push(text);
-                indent2 += text.length;
-              }
-              if (initialMargin !== void 0) {
-                if (initialMargin !== "") {
-                  pushComment(initialMargin);
-                }
-                state = 1 /* SawAsterisk */;
-              }
-              let tok = token();
-              loop:
-                while (true) {
-                  switch (tok) {
-                    case 4 /* NewLineTrivia */:
-                      state = 0 /* BeginningOfLine */;
-                      comments2.push(scanner2.getTokenText());
-                      indent2 = 0;
-                      break;
-                    case 60 /* AtToken */:
-                      scanner2.resetTokenState(scanner2.getTokenEnd() - 1);
-                      break loop;
-                    case 1 /* EndOfFileToken */:
-                      break loop;
-                    case 5 /* WhitespaceTrivia */:
-                      Debug.assert(state !== 2 /* SavingComments */ && state !== 3 /* SavingBackticks */, "whitespace shouldn't come from the scanner while saving comment text");
-                      const whitespace = scanner2.getTokenText();
-                      if (margin !== void 0 && indent2 + whitespace.length > margin) {
-                        comments2.push(whitespace.slice(margin - indent2));
-                        state = 2 /* SavingComments */;
-                      }
-                      indent2 += whitespace.length;
-                      break;
-                    case 19 /* OpenBraceToken */:
-                      state = 2 /* SavingComments */;
-                      const commentEnd = scanner2.getTokenFullStart();
-                      const linkStart = scanner2.getTokenEnd() - 1;
-                      const link = parseJSDocLink(linkStart);
-                      if (link) {
-                        parts2.push(finishNode(factory2.createJSDocText(comments2.join("")), linkEnd2 ?? commentsPos2, commentEnd));
-                        parts2.push(link);
-                        comments2 = [];
-                        linkEnd2 = scanner2.getTokenEnd();
-                      } else {
-                        pushComment(scanner2.getTokenText());
-                      }
-                      break;
-                    case 62 /* BacktickToken */:
-                      if (state === 3 /* SavingBackticks */) {
-                        state = 2 /* SavingComments */;
-                      } else {
-                        state = 3 /* SavingBackticks */;
-                      }
-                      pushComment(scanner2.getTokenText());
-                      break;
-                    case 82 /* JSDocCommentTextToken */:
-                      if (state !== 3 /* SavingBackticks */) {
-                        state = 2 /* SavingComments */;
-                      }
-                      pushComment(scanner2.getTokenValue());
-                      break;
-                    case 42 /* AsteriskToken */:
-                      if (state === 0 /* BeginningOfLine */) {
-                        state = 1 /* SawAsterisk */;
-                        indent2 += 1;
-                        break;
-                      }
-                    default:
-                      if (state !== 3 /* SavingBackticks */) {
-                        state = 2 /* SavingComments */;
-                      }
-                      pushComment(scanner2.getTokenText());
-                      break;
-                  }
-                  if (state === 2 /* SavingComments */ || state === 3 /* SavingBackticks */) {
-                    tok = nextJSDocCommentTextToken(state === 3 /* SavingBackticks */);
-                  } else {
-                    tok = nextTokenJSDoc();
-                  }
-                }
-              removeLeadingNewlines(comments2);
-              const trimmedComments = trimStringEnd(comments2.join(""));
-              if (parts2.length) {
-                if (trimmedComments.length) {
-                  parts2.push(finishNode(factory2.createJSDocText(trimmedComments), linkEnd2 ?? commentsPos2));
-                }
-                return createNodeArray(parts2, commentsPos2, scanner2.getTokenEnd());
-              } else if (trimmedComments.length) {
-                return trimmedComments;
-              }
-            }
-            function parseJSDocLink(start2) {
-              const linkType = tryParse(parseJSDocLinkPrefix);
-              if (!linkType) {
-                return void 0;
-              }
-              nextTokenJSDoc();
-              skipWhitespace();
-              const p2 = getNodePos();
-              let name = tokenIsIdentifierOrKeyword(token()) ? parseEntityName(
-                /*allowReservedWords*/
-                true
-              ) : void 0;
-              if (name) {
-                while (token() === 81 /* PrivateIdentifier */) {
-                  reScanHashToken();
-                  nextTokenJSDoc();
-                  name = finishNode(factory2.createJSDocMemberName(name, parseIdentifier()), p2);
-                }
-              }
-              const text = [];
-              while (token() !== 20 /* CloseBraceToken */ && token() !== 4 /* NewLineTrivia */ && token() !== 1 /* EndOfFileToken */) {
-                text.push(scanner2.getTokenText());
-                nextTokenJSDoc();
-              }
-              const create = linkType === "link" ? factory2.createJSDocLink : linkType === "linkcode" ? factory2.createJSDocLinkCode : factory2.createJSDocLinkPlain;
-              return finishNode(create(name, text.join("")), start2, scanner2.getTokenEnd());
-            }
-            function parseJSDocLinkPrefix() {
-              skipWhitespaceOrAsterisk();
-              if (token() === 19 /* OpenBraceToken */ && nextTokenJSDoc() === 60 /* AtToken */ && tokenIsIdentifierOrKeyword(nextTokenJSDoc())) {
-                const kind = scanner2.getTokenValue();
-                if (isJSDocLinkTag(kind))
-                  return kind;
-              }
-            }
-            function isJSDocLinkTag(kind) {
-              return kind === "link" || kind === "linkcode" || kind === "linkplain";
-            }
-            function parseUnknownTag(start2, tagName, indent2, indentText) {
-              return finishNode(factory2.createJSDocUnknownTag(tagName, parseTrailingTagComments(start2, getNodePos(), indent2, indentText)), start2);
-            }
-            function addTag(tag) {
-              if (!tag) {
-                return;
-              }
-              if (!tags) {
-                tags = [tag];
-                tagsPos = tag.pos;
-              } else {
-                tags.push(tag);
-              }
-              tagsEnd = tag.end;
-            }
-            function tryParseTypeExpression() {
-              skipWhitespaceOrAsterisk();
-              return token() === 19 /* OpenBraceToken */ ? parseJSDocTypeExpression() : void 0;
-            }
-            function parseBracketNameInPropertyAndParamTag() {
-              const isBracketed = parseOptionalJsdoc(23 /* OpenBracketToken */);
-              if (isBracketed) {
-                skipWhitespace();
-              }
-              const isBackquoted = parseOptionalJsdoc(62 /* BacktickToken */);
-              const name = parseJSDocEntityName();
-              if (isBackquoted) {
-                parseExpectedTokenJSDoc(62 /* BacktickToken */);
-              }
-              if (isBracketed) {
-                skipWhitespace();
-                if (parseOptionalToken(64 /* EqualsToken */)) {
-                  parseExpression();
-                }
-                parseExpected(24 /* CloseBracketToken */);
-              }
-              return { name, isBracketed };
-            }
-            function isObjectOrObjectArrayTypeReference(node) {
-              switch (node.kind) {
-                case 151 /* ObjectKeyword */:
-                  return true;
-                case 187 /* ArrayType */:
-                  return isObjectOrObjectArrayTypeReference(node.elementType);
-                default:
-                  return isTypeReferenceNode(node) && isIdentifier(node.typeName) && node.typeName.escapedText === "Object" && !node.typeArguments;
-              }
-            }
-            function parseParameterOrPropertyTag(start2, tagName, target, indent2) {
-              let typeExpression = tryParseTypeExpression();
-              let isNameFirst = !typeExpression;
-              skipWhitespaceOrAsterisk();
-              const { name, isBracketed } = parseBracketNameInPropertyAndParamTag();
-              const indentText = skipWhitespaceOrAsterisk();
-              if (isNameFirst && !lookAhead(parseJSDocLinkPrefix)) {
-                typeExpression = tryParseTypeExpression();
-              }
-              const comment = parseTrailingTagComments(start2, getNodePos(), indent2, indentText);
-              const nestedTypeLiteral = target !== 4 /* CallbackParameter */ && parseNestedTypeLiteral(typeExpression, name, target, indent2);
-              if (nestedTypeLiteral) {
-                typeExpression = nestedTypeLiteral;
-                isNameFirst = true;
-              }
-              const result2 = target === 1 /* Property */ ? factory2.createJSDocPropertyTag(tagName, name, isBracketed, typeExpression, isNameFirst, comment) : factory2.createJSDocParameterTag(tagName, name, isBracketed, typeExpression, isNameFirst, comment);
-              return finishNode(result2, start2);
-            }
-            function parseNestedTypeLiteral(typeExpression, name, target, indent2) {
-              if (typeExpression && isObjectOrObjectArrayTypeReference(typeExpression.type)) {
-                const pos = getNodePos();
-                let child;
-                let children;
-                while (child = tryParse(() => parseChildParameterOrPropertyTag(target, indent2, name))) {
-                  if (child.kind === 347 /* JSDocParameterTag */ || child.kind === 354 /* JSDocPropertyTag */) {
-                    children = append(children, child);
-                  } else if (child.kind === 351 /* JSDocTemplateTag */) {
-                    parseErrorAtRange(child.tagName, Diagnostics.A_JSDoc_template_tag_may_not_follow_a_typedef_callback_or_overload_tag);
-                  }
-                }
-                if (children) {
-                  const literal = finishNode(factory2.createJSDocTypeLiteral(children, typeExpression.type.kind === 187 /* ArrayType */), pos);
-                  return finishNode(factory2.createJSDocTypeExpression(literal), pos);
-                }
-              }
-            }
-            function parseReturnTag(start2, tagName, indent2, indentText) {
-              if (some(tags, isJSDocReturnTag)) {
-                parseErrorAt(tagName.pos, scanner2.getTokenStart(), Diagnostics._0_tag_already_specified, unescapeLeadingUnderscores(tagName.escapedText));
-              }
-              const typeExpression = tryParseTypeExpression();
-              return finishNode(factory2.createJSDocReturnTag(tagName, typeExpression, parseTrailingTagComments(start2, getNodePos(), indent2, indentText)), start2);
-            }
-            function parseTypeTag(start2, tagName, indent2, indentText) {
-              if (some(tags, isJSDocTypeTag)) {
-                parseErrorAt(tagName.pos, scanner2.getTokenStart(), Diagnostics._0_tag_already_specified, unescapeLeadingUnderscores(tagName.escapedText));
-              }
-              const typeExpression = parseJSDocTypeExpression(
-                /*mayOmitBraces*/
-                true
-              );
-              const comments2 = indent2 !== void 0 && indentText !== void 0 ? parseTrailingTagComments(start2, getNodePos(), indent2, indentText) : void 0;
-              return finishNode(factory2.createJSDocTypeTag(tagName, typeExpression, comments2), start2);
-            }
-            function parseSeeTag(start2, tagName, indent2, indentText) {
-              const isMarkdownOrJSDocLink = token() === 23 /* OpenBracketToken */ || lookAhead(() => nextTokenJSDoc() === 60 /* AtToken */ && tokenIsIdentifierOrKeyword(nextTokenJSDoc()) && isJSDocLinkTag(scanner2.getTokenValue()));
-              const nameExpression = isMarkdownOrJSDocLink ? void 0 : parseJSDocNameReference();
-              const comments2 = indent2 !== void 0 && indentText !== void 0 ? parseTrailingTagComments(start2, getNodePos(), indent2, indentText) : void 0;
-              return finishNode(factory2.createJSDocSeeTag(tagName, nameExpression, comments2), start2);
-            }
-            function parseThrowsTag(start2, tagName, indent2, indentText) {
-              const typeExpression = tryParseTypeExpression();
-              const comment = parseTrailingTagComments(start2, getNodePos(), indent2, indentText);
-              return finishNode(factory2.createJSDocThrowsTag(tagName, typeExpression, comment), start2);
-            }
-            function parseAuthorTag(start2, tagName, indent2, indentText) {
-              const commentStart = getNodePos();
-              const textOnly = parseAuthorNameAndEmail();
-              let commentEnd = scanner2.getTokenFullStart();
-              const comments2 = parseTrailingTagComments(start2, commentEnd, indent2, indentText);
-              if (!comments2) {
-                commentEnd = scanner2.getTokenFullStart();
-              }
-              const allParts = typeof comments2 !== "string" ? createNodeArray(concatenate([finishNode(textOnly, commentStart, commentEnd)], comments2), commentStart) : textOnly.text + comments2;
-              return finishNode(factory2.createJSDocAuthorTag(tagName, allParts), start2);
-            }
-            function parseAuthorNameAndEmail() {
-              const comments2 = [];
-              let inEmail = false;
-              let token2 = scanner2.getToken();
-              while (token2 !== 1 /* EndOfFileToken */ && token2 !== 4 /* NewLineTrivia */) {
-                if (token2 === 30 /* LessThanToken */) {
-                  inEmail = true;
-                } else if (token2 === 60 /* AtToken */ && !inEmail) {
-                  break;
-                } else if (token2 === 32 /* GreaterThanToken */ && inEmail) {
-                  comments2.push(scanner2.getTokenText());
-                  scanner2.resetTokenState(scanner2.getTokenEnd());
-                  break;
-                }
-                comments2.push(scanner2.getTokenText());
-                token2 = nextTokenJSDoc();
-              }
-              return factory2.createJSDocText(comments2.join(""));
-            }
-            function parseImplementsTag(start2, tagName, margin, indentText) {
-              const className = parseExpressionWithTypeArgumentsForAugments();
-              return finishNode(factory2.createJSDocImplementsTag(tagName, className, parseTrailingTagComments(start2, getNodePos(), margin, indentText)), start2);
-            }
-            function parseAugmentsTag(start2, tagName, margin, indentText) {
-              const className = parseExpressionWithTypeArgumentsForAugments();
-              return finishNode(factory2.createJSDocAugmentsTag(tagName, className, parseTrailingTagComments(start2, getNodePos(), margin, indentText)), start2);
-            }
-            function parseSatisfiesTag(start2, tagName, margin, indentText) {
-              const typeExpression = parseJSDocTypeExpression(
-                /*mayOmitBraces*/
-                false
-              );
-              const comments2 = margin !== void 0 && indentText !== void 0 ? parseTrailingTagComments(start2, getNodePos(), margin, indentText) : void 0;
-              return finishNode(factory2.createJSDocSatisfiesTag(tagName, typeExpression, comments2), start2);
-            }
-            function parseExpressionWithTypeArgumentsForAugments() {
-              const usedBrace = parseOptional(19 /* OpenBraceToken */);
-              const pos = getNodePos();
-              const expression = parsePropertyAccessEntityNameExpression();
-              scanner2.setInJSDocType(true);
-              const typeArguments = tryParseTypeArguments();
-              scanner2.setInJSDocType(false);
-              const node = factory2.createExpressionWithTypeArguments(expression, typeArguments);
-              const res = finishNode(node, pos);
-              if (usedBrace) {
-                parseExpected(20 /* CloseBraceToken */);
-              }
-              return res;
-            }
-            function parsePropertyAccessEntityNameExpression() {
-              const pos = getNodePos();
-              let node = parseJSDocIdentifierName();
-              while (parseOptional(25 /* DotToken */)) {
-                const name = parseJSDocIdentifierName();
-                node = finishNode(factoryCreatePropertyAccessExpression(node, name), pos);
-              }
-              return node;
-            }
-            function parseSimpleTag(start2, createTag, tagName, margin, indentText) {
-              return finishNode(createTag(tagName, parseTrailingTagComments(start2, getNodePos(), margin, indentText)), start2);
-            }
-            function parseThisTag(start2, tagName, margin, indentText) {
-              const typeExpression = parseJSDocTypeExpression(
-                /*mayOmitBraces*/
-                true
-              );
-              skipWhitespace();
-              return finishNode(factory2.createJSDocThisTag(tagName, typeExpression, parseTrailingTagComments(start2, getNodePos(), margin, indentText)), start2);
-            }
-            function parseEnumTag(start2, tagName, margin, indentText) {
-              const typeExpression = parseJSDocTypeExpression(
-                /*mayOmitBraces*/
-                true
-              );
-              skipWhitespace();
-              return finishNode(factory2.createJSDocEnumTag(tagName, typeExpression, parseTrailingTagComments(start2, getNodePos(), margin, indentText)), start2);
-            }
-            function parseTypedefTag(start2, tagName, indent2, indentText) {
-              let typeExpression = tryParseTypeExpression();
-              skipWhitespaceOrAsterisk();
-              const fullName = parseJSDocTypeNameWithNamespace();
-              skipWhitespace();
-              let comment = parseTagComments(indent2);
-              let end2;
-              if (!typeExpression || isObjectOrObjectArrayTypeReference(typeExpression.type)) {
-                let child;
-                let childTypeTag;
-                let jsDocPropertyTags;
-                let hasChildren = false;
-                while (child = tryParse(() => parseChildPropertyTag(indent2))) {
-                  if (child.kind === 351 /* JSDocTemplateTag */) {
-                    break;
-                  }
-                  hasChildren = true;
-                  if (child.kind === 350 /* JSDocTypeTag */) {
-                    if (childTypeTag) {
-                      const lastError = parseErrorAtCurrentToken(Diagnostics.A_JSDoc_typedef_comment_may_not_contain_multiple_type_tags);
-                      if (lastError) {
-                        addRelatedInfo(lastError, createDetachedDiagnostic(fileName, 0, 0, Diagnostics.The_tag_was_first_specified_here));
-                      }
-                      break;
-                    } else {
-                      childTypeTag = child;
-                    }
-                  } else {
-                    jsDocPropertyTags = append(jsDocPropertyTags, child);
-                  }
-                }
-                if (hasChildren) {
-                  const isArrayType = typeExpression && typeExpression.type.kind === 187 /* ArrayType */;
-                  const jsdocTypeLiteral = factory2.createJSDocTypeLiteral(jsDocPropertyTags, isArrayType);
-                  typeExpression = childTypeTag && childTypeTag.typeExpression && !isObjectOrObjectArrayTypeReference(childTypeTag.typeExpression.type) ? childTypeTag.typeExpression : finishNode(jsdocTypeLiteral, start2);
-                  end2 = typeExpression.end;
-                }
-              }
-              end2 = end2 || comment !== void 0 ? getNodePos() : (fullName ?? typeExpression ?? tagName).end;
-              if (!comment) {
-                comment = parseTrailingTagComments(start2, end2, indent2, indentText);
-              }
-              const typedefTag = factory2.createJSDocTypedefTag(tagName, typeExpression, fullName, comment);
-              return finishNode(typedefTag, start2, end2);
-            }
-            function parseJSDocTypeNameWithNamespace(nested) {
-              const start2 = scanner2.getTokenStart();
-              if (!tokenIsIdentifierOrKeyword(token())) {
-                return void 0;
-              }
-              const typeNameOrNamespaceName = parseJSDocIdentifierName();
-              if (parseOptional(25 /* DotToken */)) {
-                const body = parseJSDocTypeNameWithNamespace(
-                  /*nested*/
-                  true
-                );
-                const jsDocNamespaceNode = factory2.createModuleDeclaration(
-                  /*modifiers*/
-                  void 0,
-                  typeNameOrNamespaceName,
-                  body,
-                  nested ? 4 /* NestedNamespace */ : void 0
-                );
-                return finishNode(jsDocNamespaceNode, start2);
-              }
-              if (nested) {
-                typeNameOrNamespaceName.flags |= 2048 /* IdentifierIsInJSDocNamespace */;
-              }
-              return typeNameOrNamespaceName;
-            }
-            function parseCallbackTagParameters(indent2) {
-              const pos = getNodePos();
-              let child;
-              let parameters;
-              while (child = tryParse(() => parseChildParameterOrPropertyTag(4 /* CallbackParameter */, indent2))) {
-                if (child.kind === 351 /* JSDocTemplateTag */) {
-                  parseErrorAtRange(child.tagName, Diagnostics.A_JSDoc_template_tag_may_not_follow_a_typedef_callback_or_overload_tag);
-                  break;
-                }
-                parameters = append(parameters, child);
-              }
-              return createNodeArray(parameters || [], pos);
-            }
-            function parseJSDocSignature(start2, indent2) {
-              const parameters = parseCallbackTagParameters(indent2);
-              const returnTag = tryParse(() => {
-                if (parseOptionalJsdoc(60 /* AtToken */)) {
-                  const tag = parseTag(indent2);
-                  if (tag && tag.kind === 348 /* JSDocReturnTag */) {
-                    return tag;
-                  }
-                }
-              });
-              return finishNode(factory2.createJSDocSignature(
-                /*typeParameters*/
-                void 0,
-                parameters,
-                returnTag
-              ), start2);
-            }
-            function parseCallbackTag(start2, tagName, indent2, indentText) {
-              const fullName = parseJSDocTypeNameWithNamespace();
-              skipWhitespace();
-              let comment = parseTagComments(indent2);
-              const typeExpression = parseJSDocSignature(start2, indent2);
-              if (!comment) {
-                comment = parseTrailingTagComments(start2, getNodePos(), indent2, indentText);
-              }
-              const end2 = comment !== void 0 ? getNodePos() : typeExpression.end;
-              return finishNode(factory2.createJSDocCallbackTag(tagName, typeExpression, fullName, comment), start2, end2);
-            }
-            function parseOverloadTag(start2, tagName, indent2, indentText) {
-              skipWhitespace();
-              let comment = parseTagComments(indent2);
-              const typeExpression = parseJSDocSignature(start2, indent2);
-              if (!comment) {
-                comment = parseTrailingTagComments(start2, getNodePos(), indent2, indentText);
-              }
-              const end2 = comment !== void 0 ? getNodePos() : typeExpression.end;
-              return finishNode(factory2.createJSDocOverloadTag(tagName, typeExpression, comment), start2, end2);
-            }
-            function escapedTextsEqual(a, b) {
-              while (!isIdentifier(a) || !isIdentifier(b)) {
-                if (!isIdentifier(a) && !isIdentifier(b) && a.right.escapedText === b.right.escapedText) {
-                  a = a.left;
-                  b = b.left;
-                } else {
-                  return false;
-                }
-              }
-              return a.escapedText === b.escapedText;
-            }
-            function parseChildPropertyTag(indent2) {
-              return parseChildParameterOrPropertyTag(1 /* Property */, indent2);
-            }
-            function parseChildParameterOrPropertyTag(target, indent2, name) {
-              let canParseTag = true;
-              let seenAsterisk = false;
-              while (true) {
-                switch (nextTokenJSDoc()) {
-                  case 60 /* AtToken */:
-                    if (canParseTag) {
-                      const child = tryParseChildTag(target, indent2);
-                      if (child && (child.kind === 347 /* JSDocParameterTag */ || child.kind === 354 /* JSDocPropertyTag */) && target !== 4 /* CallbackParameter */ && name && (isIdentifier(child.name) || !escapedTextsEqual(name, child.name.left))) {
-                        return false;
-                      }
-                      return child;
-                    }
-                    seenAsterisk = false;
-                    break;
-                  case 4 /* NewLineTrivia */:
-                    canParseTag = true;
-                    seenAsterisk = false;
-                    break;
-                  case 42 /* AsteriskToken */:
-                    if (seenAsterisk) {
-                      canParseTag = false;
-                    }
-                    seenAsterisk = true;
-                    break;
-                  case 80 /* Identifier */:
-                    canParseTag = false;
-                    break;
-                  case 1 /* EndOfFileToken */:
-                    return false;
-                }
-              }
-            }
-            function tryParseChildTag(target, indent2) {
-              Debug.assert(token() === 60 /* AtToken */);
-              const start2 = scanner2.getTokenFullStart();
-              nextTokenJSDoc();
-              const tagName = parseJSDocIdentifierName();
-              const indentText = skipWhitespaceOrAsterisk();
-              let t;
-              switch (tagName.escapedText) {
-                case "type":
-                  return target === 1 /* Property */ && parseTypeTag(start2, tagName);
-                case "prop":
-                case "property":
-                  t = 1 /* Property */;
-                  break;
-                case "arg":
-                case "argument":
-                case "param":
-                  t = 2 /* Parameter */ | 4 /* CallbackParameter */;
-                  break;
-                case "template":
-                  return parseTemplateTag(start2, tagName, indent2, indentText);
-                default:
-                  return false;
-              }
-              if (!(target & t)) {
-                return false;
-              }
-              return parseParameterOrPropertyTag(start2, tagName, target, indent2);
-            }
-            function parseTemplateTagTypeParameter() {
-              const typeParameterPos = getNodePos();
-              const isBracketed = parseOptionalJsdoc(23 /* OpenBracketToken */);
-              if (isBracketed) {
-                skipWhitespace();
-              }
-              const name = parseJSDocIdentifierName(Diagnostics.Unexpected_token_A_type_parameter_name_was_expected_without_curly_braces);
-              let defaultType;
-              if (isBracketed) {
-                skipWhitespace();
-                parseExpected(64 /* EqualsToken */);
-                defaultType = doInsideOfContext(8388608 /* JSDoc */, parseJSDocType);
-                parseExpected(24 /* CloseBracketToken */);
-              }
-              if (nodeIsMissing(name)) {
-                return void 0;
-              }
-              return finishNode(factory2.createTypeParameterDeclaration(
-                /*modifiers*/
-                void 0,
-                name,
-                /*constraint*/
-                void 0,
-                defaultType
-              ), typeParameterPos);
-            }
-            function parseTemplateTagTypeParameters() {
-              const pos = getNodePos();
-              const typeParameters = [];
-              do {
-                skipWhitespace();
-                const node = parseTemplateTagTypeParameter();
-                if (node !== void 0) {
-                  typeParameters.push(node);
-                }
-                skipWhitespaceOrAsterisk();
-              } while (parseOptionalJsdoc(28 /* CommaToken */));
-              return createNodeArray(typeParameters, pos);
-            }
-            function parseTemplateTag(start2, tagName, indent2, indentText) {
-              const constraint = token() === 19 /* OpenBraceToken */ ? parseJSDocTypeExpression() : void 0;
-              const typeParameters = parseTemplateTagTypeParameters();
-              return finishNode(factory2.createJSDocTemplateTag(tagName, constraint, typeParameters, parseTrailingTagComments(start2, getNodePos(), indent2, indentText)), start2);
-            }
-            function parseOptionalJsdoc(t) {
-              if (token() === t) {
-                nextTokenJSDoc();
-                return true;
-              }
-              return false;
-            }
-            function parseJSDocEntityName() {
-              let entity = parseJSDocIdentifierName();
-              if (parseOptional(23 /* OpenBracketToken */)) {
-                parseExpected(24 /* CloseBracketToken */);
-              }
-              while (parseOptional(25 /* DotToken */)) {
-                const name = parseJSDocIdentifierName();
-                if (parseOptional(23 /* OpenBracketToken */)) {
-                  parseExpected(24 /* CloseBracketToken */);
-                }
-                entity = createQualifiedName(entity, name);
-              }
-              return entity;
-            }
-            function parseJSDocIdentifierName(message) {
-              if (!tokenIsIdentifierOrKeyword(token())) {
-                return createMissingNode(
-                  80 /* Identifier */,
-                  /*reportAtCurrentPosition*/
-                  !message,
-                  message || Diagnostics.Identifier_expected
-                );
-              }
-              identifierCount++;
-              const start2 = scanner2.getTokenStart();
-              const end2 = scanner2.getTokenEnd();
-              const originalKeywordKind = token();
-              const text = internIdentifier(scanner2.getTokenValue());
-              const result2 = finishNode(factoryCreateIdentifier(text, originalKeywordKind), start2, end2);
-              nextTokenJSDoc();
-              return result2;
-            }
-          }
-        })(JSDocParser = Parser2.JSDocParser || (Parser2.JSDocParser = {}));
-      })(Parser || (Parser = {}));
-      ((IncrementalParser2) => {
-        function updateSourceFile2(sourceFile, newText, textChangeRange, aggressiveChecks) {
-          aggressiveChecks = aggressiveChecks || Debug.shouldAssert(2 /* Aggressive */);
-          checkChangeRange(sourceFile, newText, textChangeRange, aggressiveChecks);
-          if (textChangeRangeIsUnchanged(textChangeRange)) {
-            return sourceFile;
-          }
-          if (sourceFile.statements.length === 0) {
-            return Parser.parseSourceFile(
-              sourceFile.fileName,
-              newText,
-              sourceFile.languageVersion,
-              /*syntaxCursor*/
-              void 0,
-              /*setParentNodes*/
-              true,
-              sourceFile.scriptKind,
-              sourceFile.setExternalModuleIndicator
-            );
-          }
-          const incrementalSourceFile = sourceFile;
-          Debug.assert(!incrementalSourceFile.hasBeenIncrementallyParsed);
-          incrementalSourceFile.hasBeenIncrementallyParsed = true;
-          Parser.fixupParentReferences(incrementalSourceFile);
-          const oldText = sourceFile.text;
-          const syntaxCursor = createSyntaxCursor(sourceFile);
-          const changeRange = extendToAffectedRange(sourceFile, textChangeRange);
-          checkChangeRange(sourceFile, newText, changeRange, aggressiveChecks);
-          Debug.assert(changeRange.span.start <= textChangeRange.span.start);
-          Debug.assert(textSpanEnd(changeRange.span) === textSpanEnd(textChangeRange.span));
-          Debug.assert(textSpanEnd(textChangeRangeNewSpan(changeRange)) === textSpanEnd(textChangeRangeNewSpan(textChangeRange)));
-          const delta = textChangeRangeNewSpan(changeRange).length - changeRange.span.length;
-          updateTokenPositionsAndMarkElements(
-            incrementalSourceFile,
-            changeRange.span.start,
-            textSpanEnd(changeRange.span),
-            textSpanEnd(textChangeRangeNewSpan(changeRange)),
-            delta,
-            oldText,
-            newText,
-            aggressiveChecks
-          );
-          const result = Parser.parseSourceFile(
-            sourceFile.fileName,
-            newText,
-            sourceFile.languageVersion,
-            syntaxCursor,
-            /*setParentNodes*/
-            true,
-            sourceFile.scriptKind,
-            sourceFile.setExternalModuleIndicator
-          );
-          result.commentDirectives = getNewCommentDirectives(
-            sourceFile.commentDirectives,
-            result.commentDirectives,
-            changeRange.span.start,
-            textSpanEnd(changeRange.span),
-            delta,
-            oldText,
-            newText,
-            aggressiveChecks
-          );
-          result.impliedNodeFormat = sourceFile.impliedNodeFormat;
-          return result;
-        }
-        IncrementalParser2.updateSourceFile = updateSourceFile2;
-        function getNewCommentDirectives(oldDirectives, newDirectives, changeStart, changeRangeOldEnd, delta, oldText, newText, aggressiveChecks) {
-          if (!oldDirectives)
-            return newDirectives;
-          let commentDirectives;
-          let addedNewlyScannedDirectives = false;
-          for (const directive of oldDirectives) {
-            const { range, type } = directive;
-            if (range.end < changeStart) {
-              commentDirectives = append(commentDirectives, directive);
-            } else if (range.pos > changeRangeOldEnd) {
-              addNewlyScannedDirectives();
-              const updatedDirective = {
-                range: { pos: range.pos + delta, end: range.end + delta },
-                type
-              };
-              commentDirectives = append(commentDirectives, updatedDirective);
-              if (aggressiveChecks) {
-                Debug.assert(oldText.substring(range.pos, range.end) === newText.substring(updatedDirective.range.pos, updatedDirective.range.end));
-              }
-            }
-          }
-          addNewlyScannedDirectives();
-          return commentDirectives;
-          function addNewlyScannedDirectives() {
-            if (addedNewlyScannedDirectives)
-              return;
-            addedNewlyScannedDirectives = true;
-            if (!commentDirectives) {
-              commentDirectives = newDirectives;
-            } else if (newDirectives) {
-              commentDirectives.push(...newDirectives);
-            }
-          }
-        }
-        function moveElementEntirelyPastChangeRange(element, isArray2, delta, oldText, newText, aggressiveChecks) {
-          if (isArray2) {
-            visitArray2(element);
-          } else {
-            visitNode3(element);
-          }
-          return;
-          function visitNode3(node) {
-            let text = "";
-            if (aggressiveChecks && shouldCheckNode(node)) {
-              text = oldText.substring(node.pos, node.end);
-            }
-            if (node._children) {
-              node._children = void 0;
-            }
-            setTextRangePosEnd(node, node.pos + delta, node.end + delta);
-            if (aggressiveChecks && shouldCheckNode(node)) {
-              Debug.assert(text === newText.substring(node.pos, node.end));
-            }
-            forEachChild(node, visitNode3, visitArray2);
-            if (hasJSDocNodes(node)) {
-              for (const jsDocComment of node.jsDoc) {
-                visitNode3(jsDocComment);
-              }
-            }
-            checkNodePositions(node, aggressiveChecks);
-          }
-          function visitArray2(array) {
-            array._children = void 0;
-            setTextRangePosEnd(array, array.pos + delta, array.end + delta);
-            for (const node of array) {
-              visitNode3(node);
-            }
-          }
-        }
-        function shouldCheckNode(node) {
-          switch (node.kind) {
-            case 11 /* StringLiteral */:
-            case 9 /* NumericLiteral */:
-            case 80 /* Identifier */:
-              return true;
-          }
-          return false;
-        }
-        function adjustIntersectingElement(element, changeStart, changeRangeOldEnd, changeRangeNewEnd, delta) {
-          Debug.assert(element.end >= changeStart, "Adjusting an element that was entirely before the change range");
-          Debug.assert(element.pos <= changeRangeOldEnd, "Adjusting an element that was entirely after the change range");
-          Debug.assert(element.pos <= element.end);
-          const pos = Math.min(element.pos, changeRangeNewEnd);
-          const end = element.end >= changeRangeOldEnd ? (
-            // Element ends after the change range.  Always adjust the end pos.
-            element.end + delta
-          ) : (
-            // Element ends in the change range.  The element will keep its position if
-            // possible. Or Move backward to the new-end if it's in the 'Y' range.
-            Math.min(element.end, changeRangeNewEnd)
-          );
-          Debug.assert(pos <= end);
-          if (element.parent) {
-            Debug.assertGreaterThanOrEqual(pos, element.parent.pos);
-            Debug.assertLessThanOrEqual(end, element.parent.end);
-          }
-          setTextRangePosEnd(element, pos, end);
-        }
-        function checkNodePositions(node, aggressiveChecks) {
-          if (aggressiveChecks) {
-            let pos = node.pos;
-            const visitNode3 = (child) => {
-              Debug.assert(child.pos >= pos);
-              pos = child.end;
-            };
-            if (hasJSDocNodes(node)) {
-              for (const jsDocComment of node.jsDoc) {
-                visitNode3(jsDocComment);
-              }
-            }
-            forEachChild(node, visitNode3);
-            Debug.assert(pos <= node.end);
-          }
-        }
-        function updateTokenPositionsAndMarkElements(sourceFile, changeStart, changeRangeOldEnd, changeRangeNewEnd, delta, oldText, newText, aggressiveChecks) {
-          visitNode3(sourceFile);
-          return;
-          function visitNode3(child) {
-            Debug.assert(child.pos <= child.end);
-            if (child.pos > changeRangeOldEnd) {
-              moveElementEntirelyPastChangeRange(
-                child,
-                /*isArray*/
-                false,
-                delta,
-                oldText,
-                newText,
-                aggressiveChecks
-              );
-              return;
-            }
-            const fullEnd = child.end;
-            if (fullEnd >= changeStart) {
-              child.intersectsChange = true;
-              child._children = void 0;
-              adjustIntersectingElement(child, changeStart, changeRangeOldEnd, changeRangeNewEnd, delta);
-              forEachChild(child, visitNode3, visitArray2);
-              if (hasJSDocNodes(child)) {
-                for (const jsDocComment of child.jsDoc) {
-                  visitNode3(jsDocComment);
-                }
-              }
-              checkNodePositions(child, aggressiveChecks);
-              return;
-            }
-            Debug.assert(fullEnd < changeStart);
-          }
-          function visitArray2(array) {
-            Debug.assert(array.pos <= array.end);
-            if (array.pos > changeRangeOldEnd) {
-              moveElementEntirelyPastChangeRange(
-                array,
-                /*isArray*/
-                true,
-                delta,
-                oldText,
-                newText,
-                aggressiveChecks
-              );
-              return;
-            }
-            const fullEnd = array.end;
-            if (fullEnd >= changeStart) {
-              array.intersectsChange = true;
-              array._children = void 0;
-              adjustIntersectingElement(array, changeStart, changeRangeOldEnd, changeRangeNewEnd, delta);
-              for (const node of array) {
-                visitNode3(node);
-              }
-              return;
-            }
-            Debug.assert(fullEnd < changeStart);
-          }
-        }
-        function extendToAffectedRange(sourceFile, changeRange) {
-          const maxLookahead = 1;
-          let start = changeRange.span.start;
-          for (let i = 0; start > 0 && i <= maxLookahead; i++) {
-            const nearestNode = findNearestNodeStartingBeforeOrAtPosition(sourceFile, start);
-            Debug.assert(nearestNode.pos <= start);
-            const position = nearestNode.pos;
-            start = Math.max(0, position - 1);
-          }
-          const finalSpan = createTextSpanFromBounds(start, textSpanEnd(changeRange.span));
-          const finalLength = changeRange.newLength + (changeRange.span.start - start);
-          return createTextChangeRange(finalSpan, finalLength);
-        }
-        function findNearestNodeStartingBeforeOrAtPosition(sourceFile, position) {
-          let bestResult = sourceFile;
-          let lastNodeEntirelyBeforePosition;
-          forEachChild(sourceFile, visit);
-          if (lastNodeEntirelyBeforePosition) {
-            const lastChildOfLastEntireNodeBeforePosition = getLastDescendant(lastNodeEntirelyBeforePosition);
-            if (lastChildOfLastEntireNodeBeforePosition.pos > bestResult.pos) {
-              bestResult = lastChildOfLastEntireNodeBeforePosition;
-            }
-          }
-          return bestResult;
-          function getLastDescendant(node) {
-            while (true) {
-              const lastChild = getLastChild(node);
-              if (lastChild) {
-                node = lastChild;
-              } else {
-                return node;
-              }
-            }
-          }
-          function visit(child) {
-            if (nodeIsMissing(child)) {
-              return;
-            }
-            if (child.pos <= position) {
-              if (child.pos >= bestResult.pos) {
-                bestResult = child;
-              }
-              if (position < child.end) {
-                forEachChild(child, visit);
-                return true;
-              } else {
-                Debug.assert(child.end <= position);
-                lastNodeEntirelyBeforePosition = child;
-              }
-            } else {
-              Debug.assert(child.pos > position);
-              return true;
-            }
-          }
-        }
-        function checkChangeRange(sourceFile, newText, textChangeRange, aggressiveChecks) {
-          const oldText = sourceFile.text;
-          if (textChangeRange) {
-            Debug.assert(oldText.length - textChangeRange.span.length + textChangeRange.newLength === newText.length);
-            if (aggressiveChecks || Debug.shouldAssert(3 /* VeryAggressive */)) {
-              const oldTextPrefix = oldText.substr(0, textChangeRange.span.start);
-              const newTextPrefix = newText.substr(0, textChangeRange.span.start);
-              Debug.assert(oldTextPrefix === newTextPrefix);
-              const oldTextSuffix = oldText.substring(textSpanEnd(textChangeRange.span), oldText.length);
-              const newTextSuffix = newText.substring(textSpanEnd(textChangeRangeNewSpan(textChangeRange)), newText.length);
-              Debug.assert(oldTextSuffix === newTextSuffix);
-            }
-          }
-        }
-        function createSyntaxCursor(sourceFile) {
-          let currentArray = sourceFile.statements;
-          let currentArrayIndex = 0;
-          Debug.assert(currentArrayIndex < currentArray.length);
-          let current = currentArray[currentArrayIndex];
-          let lastQueriedPosition = -1 /* Value */;
-          return {
-            currentNode(position) {
-              if (position !== lastQueriedPosition) {
-                if (current && current.end === position && currentArrayIndex < currentArray.length - 1) {
-                  currentArrayIndex++;
-                  current = currentArray[currentArrayIndex];
-                }
-                if (!current || current.pos !== position) {
-                  findHighestListElementThatStartsAtPosition(position);
-                }
-              }
-              lastQueriedPosition = position;
-              Debug.assert(!current || current.pos === position);
-              return current;
-            }
-          };
-          function findHighestListElementThatStartsAtPosition(position) {
-            currentArray = void 0;
-            currentArrayIndex = -1 /* Value */;
-            current = void 0;
-            forEachChild(sourceFile, visitNode3, visitArray2);
-            return;
-            function visitNode3(node) {
-              if (position >= node.pos && position < node.end) {
-                forEachChild(node, visitNode3, visitArray2);
-                return true;
-              }
-              return false;
-            }
-            function visitArray2(array) {
-              if (position >= array.pos && position < array.end) {
-                for (let i = 0; i < array.length; i++) {
-                  const child = array[i];
-                  if (child) {
-                    if (child.pos === position) {
-                      currentArray = array;
-                      currentArrayIndex = i;
-                      current = child;
-                      return true;
-                    } else {
-                      if (child.pos < position && position < child.end) {
-                        forEachChild(child, visitNode3, visitArray2);
-                        return true;
-                      }
-                    }
-                  }
-                }
-              }
-              return false;
-            }
-          }
-        }
-        IncrementalParser2.createSyntaxCursor = createSyntaxCursor;
-        let InvalidPosition;
-        ((InvalidPosition2) => {
-          InvalidPosition2[InvalidPosition2["Value"] = -1] = "Value";
-        })(InvalidPosition || (InvalidPosition = {}));
-      })(IncrementalParser || (IncrementalParser = {}));
-      namedArgRegExCache = /* @__PURE__ */ new Map();
-      tripleSlashXMLCommentStartRegEx = /^\/\/\/\s*<(\S+)\s.*?\/>/im;
-      singleLinePragmaRegEx = /^\/\/\/?\s*@(\S+)\s*(.*)\s*$/im;
-    }
-  });
-
-  // src/compiler/commandLineParser.ts
-  function createOptionNameMap(optionDeclarations2) {
-    const optionsNameMap = /* @__PURE__ */ new Map();
-    const shortOptionNames = /* @__PURE__ */ new Map();
-    forEach(optionDeclarations2, (option) => {
-      optionsNameMap.set(option.name.toLowerCase(), option);
-      if (option.shortName) {
-        shortOptionNames.set(option.shortName, option.name);
-      }
-    });
-    return { optionsNameMap, shortOptionNames };
-  }
-  function getOptionsNameMap() {
-    return optionsNameMapCache || (optionsNameMapCache = createOptionNameMap(optionDeclarations));
-  }
-  function createCompilerDiagnosticForInvalidCustomType(opt) {
-    return createDiagnosticForInvalidCustomType(opt, createCompilerDiagnostic);
-  }
-  function createDiagnosticForInvalidCustomType(opt, createDiagnostic) {
-    const namesOfType = arrayFrom(opt.type.keys());
-    const stringNames = (opt.deprecatedKeys ? namesOfType.filter((k) => !opt.deprecatedKeys.has(k)) : namesOfType).map((key) => `'${key}'`).join(", ");
-    return createDiagnostic(Diagnostics.Argument_for_0_option_must_be_Colon_1, `--${opt.name}`, stringNames);
-  }
-  function parseCustomTypeOption(opt, value, errors) {
-    return convertJsonOptionOfCustomType(opt, trimString(value || ""), errors);
-  }
-  function parseListTypeOption(opt, value = "", errors) {
-    value = trimString(value);
-    if (startsWith(value, "-")) {
-      return void 0;
-    }
-    if (opt.type === "listOrElement" && !stringContains(value, ",")) {
-      return validateJsonOptionValue(opt, value, errors);
-    }
-    if (value === "") {
-      return [];
-    }
-    const values = value.split(",");
-    switch (opt.element.type) {
-      case "number":
-        return mapDefined(values, (v) => validateJsonOptionValue(opt.element, parseInt(v), errors));
-      case "string":
-        return mapDefined(values, (v) => validateJsonOptionValue(opt.element, v || "", errors));
-      case "boolean":
-      case "object":
-        return Debug.fail(`List of ${opt.element.type} is not yet supported.`);
-      default:
-        return mapDefined(values, (v) => parseCustomTypeOption(opt.element, v, errors));
-    }
-  }
-  function getOptionName(option) {
-    return option.name;
-  }
-  function createUnknownOptionError(unknownOption, diagnostics, unknownOptionErrorText, node, sourceFile) {
-    var _a;
-    if ((_a = diagnostics.alternateMode) == null ? void 0 : _a.getOptionsNameMap().optionsNameMap.has(unknownOption.toLowerCase())) {
-      return createDiagnosticForNodeInSourceFileOrCompilerDiagnostic(sourceFile, node, diagnostics.alternateMode.diagnostic, unknownOption);
-    }
-    const possibleOption = getSpellingSuggestion(unknownOption, diagnostics.optionDeclarations, getOptionName);
-    return possibleOption ? createDiagnosticForNodeInSourceFileOrCompilerDiagnostic(sourceFile, node, diagnostics.unknownDidYouMeanDiagnostic, unknownOptionErrorText || unknownOption, possibleOption.name) : createDiagnosticForNodeInSourceFileOrCompilerDiagnostic(sourceFile, node, diagnostics.unknownOptionDiagnostic, unknownOptionErrorText || unknownOption);
-  }
-  function parseCommandLineWorker(diagnostics, commandLine, readFile) {
-    const options = {};
-    let watchOptions;
-    const fileNames = [];
-    const errors = [];
-    parseStrings(commandLine);
-    return {
-      options,
-      watchOptions,
-      fileNames,
-      errors
-    };
-    function parseStrings(args) {
-      let i = 0;
-      while (i < args.length) {
-        const s = args[i];
-        i++;
-        if (s.charCodeAt(0) === 64 /* at */) {
-          parseResponseFile(s.slice(1));
-        } else if (s.charCodeAt(0) === 45 /* minus */) {
-          const inputOptionName = s.slice(s.charCodeAt(1) === 45 /* minus */ ? 2 : 1);
-          const opt = getOptionDeclarationFromName(
-            diagnostics.getOptionsNameMap,
-            inputOptionName,
-            /*allowShort*/
-            true
-          );
-          if (opt) {
-            i = parseOptionValue(args, i, diagnostics, opt, options, errors);
-          } else {
-            const watchOpt = getOptionDeclarationFromName(
-              watchOptionsDidYouMeanDiagnostics.getOptionsNameMap,
-              inputOptionName,
-              /*allowShort*/
-              true
-            );
-            if (watchOpt) {
-              i = parseOptionValue(args, i, watchOptionsDidYouMeanDiagnostics, watchOpt, watchOptions || (watchOptions = {}), errors);
-            } else {
-              errors.push(createUnknownOptionError(inputOptionName, diagnostics, s));
-            }
-          }
-        } else {
-          fileNames.push(s);
-        }
-      }
-    }
-    function parseResponseFile(fileName) {
-      const text = tryReadFile(fileName, readFile || ((fileName2) => sys.readFile(fileName2)));
-      if (!isString(text)) {
-        errors.push(text);
-        return;
-      }
-      const args = [];
-      let pos = 0;
-      while (true) {
-        while (pos < text.length && text.charCodeAt(pos) <= 32 /* space */)
-          pos++;
-        if (pos >= text.length)
-          break;
-        const start = pos;
-        if (text.charCodeAt(start) === 34 /* doubleQuote */) {
-          pos++;
-          while (pos < text.length && text.charCodeAt(pos) !== 34 /* doubleQuote */)
-            pos++;
-          if (pos < text.length) {
-            args.push(text.substring(start + 1, pos));
-            pos++;
-          } else {
-            errors.push(createCompilerDiagnostic(Diagnostics.Unterminated_quoted_string_in_response_file_0, fileName));
-          }
-        } else {
-          while (text.charCodeAt(pos) > 32 /* space */)
-            pos++;
-          args.push(text.substring(start, pos));
-        }
-      }
-      parseStrings(args);
-    }
-  }
-  function parseOptionValue(args, i, diagnostics, opt, options, errors) {
-    if (opt.isTSConfigOnly) {
-      const optValue = args[i];
-      if (optValue === "null") {
-        options[opt.name] = void 0;
-        i++;
-      } else if (opt.type === "boolean") {
-        if (optValue === "false") {
-          options[opt.name] = validateJsonOptionValue(
-            opt,
-            /*value*/
-            false,
-            errors
-          );
-          i++;
-        } else {
-          if (optValue === "true")
-            i++;
-          errors.push(createCompilerDiagnostic(Diagnostics.Option_0_can_only_be_specified_in_tsconfig_json_file_or_set_to_false_or_null_on_command_line, opt.name));
-        }
-      } else {
-        errors.push(createCompilerDiagnostic(Diagnostics.Option_0_can_only_be_specified_in_tsconfig_json_file_or_set_to_null_on_command_line, opt.name));
-        if (optValue && !startsWith(optValue, "-"))
-          i++;
-      }
-    } else {
-      if (!args[i] && opt.type !== "boolean") {
-        errors.push(createCompilerDiagnostic(diagnostics.optionTypeMismatchDiagnostic, opt.name, getCompilerOptionValueTypeString(opt)));
-      }
-      if (args[i] !== "null") {
-        switch (opt.type) {
-          case "number":
-            options[opt.name] = validateJsonOptionValue(opt, parseInt(args[i]), errors);
-            i++;
-            break;
-          case "boolean":
-            const optValue = args[i];
-            options[opt.name] = validateJsonOptionValue(opt, optValue !== "false", errors);
-            if (optValue === "false" || optValue === "true") {
-              i++;
-            }
-            break;
-          case "string":
-            options[opt.name] = validateJsonOptionValue(opt, args[i] || "", errors);
-            i++;
-            break;
-          case "list":
-            const result = parseListTypeOption(opt, args[i], errors);
-            options[opt.name] = result || [];
-            if (result) {
-              i++;
-            }
-            break;
-          case "listOrElement":
-            Debug.fail("listOrElement not supported here");
-            break;
-          default:
-            options[opt.name] = parseCustomTypeOption(opt, args[i], errors);
-            i++;
-            break;
-        }
-      } else {
-        options[opt.name] = void 0;
-        i++;
-      }
-    }
-    return i;
-  }
-  function parseCommandLine(commandLine, readFile) {
-    return parseCommandLineWorker(compilerOptionsDidYouMeanDiagnostics, commandLine, readFile);
-  }
-  function getOptionFromName(optionName, allowShort) {
-    return getOptionDeclarationFromName(getOptionsNameMap, optionName, allowShort);
-  }
-  function getOptionDeclarationFromName(getOptionNameMap, optionName, allowShort = false) {
-    optionName = optionName.toLowerCase();
-    const { optionsNameMap, shortOptionNames } = getOptionNameMap();
-    if (allowShort) {
-      const short = shortOptionNames.get(optionName);
-      if (short !== void 0) {
-        optionName = short;
-      }
-    }
-    return optionsNameMap.get(optionName);
-  }
-  function getBuildOptionsNameMap() {
-    return buildOptionsNameMapCache || (buildOptionsNameMapCache = createOptionNameMap(buildOpts));
-  }
-  function parseBuildCommand(args) {
-    const { options, watchOptions, fileNames: projects, errors } = parseCommandLineWorker(
-      buildOptionsDidYouMeanDiagnostics,
-      args
-    );
-    const buildOptions = options;
-    if (projects.length === 0) {
-      projects.push(".");
-    }
-    if (buildOptions.clean && buildOptions.force) {
-      errors.push(createCompilerDiagnostic(Diagnostics.Options_0_and_1_cannot_be_combined, "clean", "force"));
-    }
-    if (buildOptions.clean && buildOptions.verbose) {
-      errors.push(createCompilerDiagnostic(Diagnostics.Options_0_and_1_cannot_be_combined, "clean", "verbose"));
-    }
-    if (buildOptions.clean && buildOptions.watch) {
-      errors.push(createCompilerDiagnostic(Diagnostics.Options_0_and_1_cannot_be_combined, "clean", "watch"));
-    }
-    if (buildOptions.watch && buildOptions.dry) {
-      errors.push(createCompilerDiagnostic(Diagnostics.Options_0_and_1_cannot_be_combined, "watch", "dry"));
-    }
-    return { buildOptions, watchOptions, projects, errors };
-  }
-  function getDiagnosticText(_message, ..._args) {
-    const diagnostic = createCompilerDiagnostic.apply(void 0, arguments);
-    return diagnostic.messageText;
-  }
-  function getParsedCommandLineOfConfigFile(configFileName, optionsToExtend, host, extendedConfigCache, watchOptionsToExtend, extraFileExtensions) {
-    const configFileText = tryReadFile(configFileName, (fileName) => host.readFile(fileName));
-    if (!isString(configFileText)) {
-      host.onUnRecoverableConfigFileDiagnostic(configFileText);
-      return void 0;
-    }
-    const result = parseJsonText(configFileName, configFileText);
-    const cwd = host.getCurrentDirectory();
-    result.path = toPath(configFileName, cwd, createGetCanonicalFileName(host.useCaseSensitiveFileNames));
-    result.resolvedPath = result.path;
-    result.originalFileName = result.fileName;
-    return parseJsonSourceFileConfigFileContent(
-      result,
-      host,
-      getNormalizedAbsolutePath(getDirectoryPath(configFileName), cwd),
-      optionsToExtend,
-      getNormalizedAbsolutePath(configFileName, cwd),
-      /*resolutionStack*/
-      void 0,
-      extraFileExtensions,
-      extendedConfigCache,
-      watchOptionsToExtend
-    );
-  }
-  function readConfigFile(fileName, readFile) {
-    const textOrDiagnostic = tryReadFile(fileName, readFile);
-    return isString(textOrDiagnostic) ? parseConfigFileTextToJson(fileName, textOrDiagnostic) : { config: {}, error: textOrDiagnostic };
-  }
-  function parseConfigFileTextToJson(fileName, jsonText) {
-    const jsonSourceFile = parseJsonText(fileName, jsonText);
-    return {
-      config: convertConfigFileToObject(
-        jsonSourceFile,
-        jsonSourceFile.parseDiagnostics,
-        /*jsonConversionNotifier*/
-        void 0
-      ),
-      error: jsonSourceFile.parseDiagnostics.length ? jsonSourceFile.parseDiagnostics[0] : void 0
-    };
-  }
-  function readJsonConfigFile(fileName, readFile) {
-    const textOrDiagnostic = tryReadFile(fileName, readFile);
-    return isString(textOrDiagnostic) ? parseJsonText(fileName, textOrDiagnostic) : { fileName, parseDiagnostics: [textOrDiagnostic] };
-  }
-  function tryReadFile(fileName, readFile) {
-    let text;
-    try {
-      text = readFile(fileName);
-    } catch (e) {
-      return createCompilerDiagnostic(Diagnostics.Cannot_read_file_0_Colon_1, fileName, e.message);
-    }
-    return text === void 0 ? createCompilerDiagnostic(Diagnostics.Cannot_read_file_0, fileName) : text;
-  }
-  function commandLineOptionsToMap(options) {
-    return arrayToMap(options, getOptionName);
-  }
-  function getWatchOptionsNameMap() {
-    return watchOptionsNameMapCache || (watchOptionsNameMapCache = createOptionNameMap(optionsForWatch));
-  }
-  function getCommandLineCompilerOptionsMap() {
-    return commandLineCompilerOptionsMapCache || (commandLineCompilerOptionsMapCache = commandLineOptionsToMap(optionDeclarations));
-  }
-  function getCommandLineWatchOptionsMap() {
-    return commandLineWatchOptionsMapCache || (commandLineWatchOptionsMapCache = commandLineOptionsToMap(optionsForWatch));
-  }
-  function getCommandLineTypeAcquisitionMap() {
-    return commandLineTypeAcquisitionMapCache || (commandLineTypeAcquisitionMapCache = commandLineOptionsToMap(typeAcquisitionDeclarations));
-  }
-  function getTsconfigRootOptionsMap() {
-    if (_tsconfigRootOptions === void 0) {
-      _tsconfigRootOptions = {
-        name: void 0,
-        // should never be needed since this is root
-        type: "object",
-        elementOptions: commandLineOptionsToMap([
-          compilerOptionsDeclaration,
-          watchOptionsDeclaration,
-          typeAcquisitionDeclaration,
-          extendsOptionDeclaration,
-          {
-            name: "references",
-            type: "list",
-            element: {
-              name: "references",
-              type: "object"
-            },
-            category: Diagnostics.Projects
-          },
-          {
-            name: "files",
-            type: "list",
-            element: {
-              name: "files",
-              type: "string"
-            },
-            category: Diagnostics.File_Management
-          },
-          {
-            name: "include",
-            type: "list",
-            element: {
-              name: "include",
-              type: "string"
-            },
-            category: Diagnostics.File_Management,
-            defaultValueDescription: Diagnostics.if_files_is_specified_otherwise_Asterisk_Asterisk_Slash_Asterisk
-          },
-          {
-            name: "exclude",
-            type: "list",
-            element: {
-              name: "exclude",
-              type: "string"
-            },
-            category: Diagnostics.File_Management,
-            defaultValueDescription: Diagnostics.node_modules_bower_components_jspm_packages_plus_the_value_of_outDir_if_one_is_specified
-          },
-          compileOnSaveCommandLineOption
-        ])
-      };
-    }
-    return _tsconfigRootOptions;
-  }
-  function convertConfigFileToObject(sourceFile, errors, jsonConversionNotifier) {
-    var _a;
-    const rootExpression = (_a = sourceFile.statements[0]) == null ? void 0 : _a.expression;
-    if (rootExpression && rootExpression.kind !== 209 /* ObjectLiteralExpression */) {
-      errors.push(createDiagnosticForNodeInSourceFile(
-        sourceFile,
-        rootExpression,
-        Diagnostics.The_root_value_of_a_0_file_must_be_an_object,
-        getBaseFileName(sourceFile.fileName) === "jsconfig.json" ? "jsconfig.json" : "tsconfig.json"
-      ));
-      if (isArrayLiteralExpression(rootExpression)) {
-        const firstObject = find(rootExpression.elements, isObjectLiteralExpression);
-        if (firstObject) {
-          return convertToJson(
-            sourceFile,
-            firstObject,
-            errors,
-            /*returnValue*/
-            true,
-            jsonConversionNotifier
-          );
-        }
-      }
-      return {};
-    }
-    return convertToJson(
-      sourceFile,
-      rootExpression,
-      errors,
-      /*returnValue*/
-      true,
-      jsonConversionNotifier
-    );
-  }
-  function convertToObject(sourceFile, errors) {
-    var _a;
-    return convertToJson(
-      sourceFile,
-      (_a = sourceFile.statements[0]) == null ? void 0 : _a.expression,
-      errors,
-      /*returnValue*/
-      true,
-      /*jsonConversionNotifier*/
-      void 0
-    );
-  }
-  function convertToJson(sourceFile, rootExpression, errors, returnValue, jsonConversionNotifier) {
-    if (!rootExpression) {
-      return returnValue ? {} : void 0;
-    }
-    return convertPropertyValueToJson(rootExpression, jsonConversionNotifier == null ? void 0 : jsonConversionNotifier.rootOptions);
-    function convertObjectLiteralExpressionToJson(node, objectOption) {
-      var _a;
-      const result = returnValue ? {} : void 0;
-      for (const element of node.properties) {
-        if (element.kind !== 302 /* PropertyAssignment */) {
-          errors.push(createDiagnosticForNodeInSourceFile(sourceFile, element, Diagnostics.Property_assignment_expected));
-          continue;
-        }
-        if (element.questionToken) {
-          errors.push(createDiagnosticForNodeInSourceFile(sourceFile, element.questionToken, Diagnostics.The_0_modifier_can_only_be_used_in_TypeScript_files, "?"));
-        }
-        if (!isDoubleQuotedString(element.name)) {
-          errors.push(createDiagnosticForNodeInSourceFile(sourceFile, element.name, Diagnostics.String_literal_with_double_quotes_expected));
-        }
-        const textOfKey = isComputedNonLiteralName(element.name) ? void 0 : getTextOfPropertyName(element.name);
-        const keyText = textOfKey && unescapeLeadingUnderscores(textOfKey);
-        const option = keyText ? (_a = objectOption == null ? void 0 : objectOption.elementOptions) == null ? void 0 : _a.get(keyText) : void 0;
-        const value = convertPropertyValueToJson(element.initializer, option);
-        if (typeof keyText !== "undefined") {
-          if (returnValue) {
-            result[keyText] = value;
-          }
-          jsonConversionNotifier == null ? void 0 : jsonConversionNotifier.onPropertySet(keyText, value, element, objectOption, option);
-        }
-      }
-      return result;
-    }
-    function convertArrayLiteralExpressionToJson(elements, elementOption) {
-      if (!returnValue) {
-        elements.forEach((element) => convertPropertyValueToJson(element, elementOption));
-        return void 0;
-      }
-      return filter(elements.map((element) => convertPropertyValueToJson(element, elementOption)), (v) => v !== void 0);
-    }
-    function convertPropertyValueToJson(valueExpression, option) {
-      switch (valueExpression.kind) {
-        case 112 /* TrueKeyword */:
-          return true;
-        case 97 /* FalseKeyword */:
-          return false;
-        case 106 /* NullKeyword */:
-          return null;
-        case 11 /* StringLiteral */:
-          if (!isDoubleQuotedString(valueExpression)) {
-            errors.push(createDiagnosticForNodeInSourceFile(sourceFile, valueExpression, Diagnostics.String_literal_with_double_quotes_expected));
-          }
-          return valueExpression.text;
-        case 9 /* NumericLiteral */:
-          return Number(valueExpression.text);
-        case 223 /* PrefixUnaryExpression */:
-          if (valueExpression.operator !== 41 /* MinusToken */ || valueExpression.operand.kind !== 9 /* NumericLiteral */) {
-            break;
-          }
-          return -Number(valueExpression.operand.text);
-        case 209 /* ObjectLiteralExpression */:
-          const objectLiteralExpression = valueExpression;
-          return convertObjectLiteralExpressionToJson(objectLiteralExpression, option);
-        case 208 /* ArrayLiteralExpression */:
-          return convertArrayLiteralExpressionToJson(
-            valueExpression.elements,
-            option && option.element
-          );
-      }
-      if (option) {
-        errors.push(createDiagnosticForNodeInSourceFile(sourceFile, valueExpression, Diagnostics.Compiler_option_0_requires_a_value_of_type_1, option.name, getCompilerOptionValueTypeString(option)));
-      } else {
-        errors.push(createDiagnosticForNodeInSourceFile(sourceFile, valueExpression, Diagnostics.Property_value_can_only_be_string_literal_numeric_literal_true_false_null_object_literal_or_array_literal));
-      }
-      return void 0;
-    }
-    function isDoubleQuotedString(node) {
-      return isStringLiteral(node) && isStringDoubleQuoted(node, sourceFile);
-    }
-  }
-  function getCompilerOptionValueTypeString(option) {
-    return option.type === "listOrElement" ? `${getCompilerOptionValueTypeString(option.element)} or Array` : option.type === "list" ? "Array" : isString(option.type) ? option.type : "string";
-  }
-  function isCompilerOptionsValue(option, value) {
-    if (option) {
-      if (isNullOrUndefined(value))
-        return !option.disallowNullOrUndefined;
-      if (option.type === "list") {
-        return isArray(value);
-      }
-      if (option.type === "listOrElement") {
-        return isArray(value) || isCompilerOptionsValue(option.element, value);
-      }
-      const expectedType = isString(option.type) ? option.type : "string";
-      return typeof value === expectedType;
-    }
-    return false;
-  }
-  function convertToTSConfig(configParseResult, configFileName, host) {
-    var _a, _b, _c;
-    const getCanonicalFileName = createGetCanonicalFileName(host.useCaseSensitiveFileNames);
-    const files = map(
-      filter(
-        configParseResult.fileNames,
-        !((_b = (_a = configParseResult.options.configFile) == null ? void 0 : _a.configFileSpecs) == null ? void 0 : _b.validatedIncludeSpecs) ? returnTrue : matchesSpecs(
-          configFileName,
-          configParseResult.options.configFile.configFileSpecs.validatedIncludeSpecs,
-          configParseResult.options.configFile.configFileSpecs.validatedExcludeSpecs,
-          host
-        )
-      ),
-      (f) => getRelativePathFromFile(getNormalizedAbsolutePath(configFileName, host.getCurrentDirectory()), getNormalizedAbsolutePath(f, host.getCurrentDirectory()), getCanonicalFileName)
-    );
-    const optionMap = serializeCompilerOptions(configParseResult.options, { configFilePath: getNormalizedAbsolutePath(configFileName, host.getCurrentDirectory()), useCaseSensitiveFileNames: host.useCaseSensitiveFileNames });
-    const watchOptionMap = configParseResult.watchOptions && serializeWatchOptions(configParseResult.watchOptions);
-    const config = {
-      compilerOptions: {
-        ...optionMapToObject(optionMap),
-        showConfig: void 0,
-        configFile: void 0,
-        configFilePath: void 0,
-        help: void 0,
-        init: void 0,
-        listFiles: void 0,
-        listEmittedFiles: void 0,
-        project: void 0,
-        build: void 0,
-        version: void 0
-      },
-      watchOptions: watchOptionMap && optionMapToObject(watchOptionMap),
-      references: map(configParseResult.projectReferences, (r) => ({ ...r, path: r.originalPath ? r.originalPath : "", originalPath: void 0 })),
-      files: length(files) ? files : void 0,
-      ...((_c = configParseResult.options.configFile) == null ? void 0 : _c.configFileSpecs) ? {
-        include: filterSameAsDefaultInclude(configParseResult.options.configFile.configFileSpecs.validatedIncludeSpecs),
-        exclude: configParseResult.options.configFile.configFileSpecs.validatedExcludeSpecs
-      } : {},
-      compileOnSave: !!configParseResult.compileOnSave ? true : void 0
-    };
-    return config;
-  }
-  function optionMapToObject(optionMap) {
-    return {
-      ...arrayFrom(optionMap.entries()).reduce((prev, cur) => ({ ...prev, [cur[0]]: cur[1] }), {})
-    };
-  }
-  function filterSameAsDefaultInclude(specs) {
-    if (!length(specs))
-      return void 0;
-    if (length(specs) !== 1)
-      return specs;
-    if (specs[0] === defaultIncludeSpec)
-      return void 0;
-    return specs;
-  }
-  function matchesSpecs(path, includeSpecs, excludeSpecs, host) {
-    if (!includeSpecs)
-      return returnTrue;
-    const patterns = getFileMatcherPatterns(path, excludeSpecs, includeSpecs, host.useCaseSensitiveFileNames, host.getCurrentDirectory());
-    const excludeRe = patterns.excludePattern && getRegexFromPattern(patterns.excludePattern, host.useCaseSensitiveFileNames);
-    const includeRe = patterns.includeFilePattern && getRegexFromPattern(patterns.includeFilePattern, host.useCaseSensitiveFileNames);
-    if (includeRe) {
-      if (excludeRe) {
-        return (path2) => !(includeRe.test(path2) && !excludeRe.test(path2));
-      }
-      return (path2) => !includeRe.test(path2);
-    }
-    if (excludeRe) {
-      return (path2) => excludeRe.test(path2);
-    }
-    return returnTrue;
-  }
-  function getCustomTypeMapOfCommandLineOption(optionDefinition) {
-    switch (optionDefinition.type) {
-      case "string":
-      case "number":
-      case "boolean":
-      case "object":
-        return void 0;
-      case "list":
-      case "listOrElement":
-        return getCustomTypeMapOfCommandLineOption(optionDefinition.element);
-      default:
-        return optionDefinition.type;
-    }
-  }
-  function getNameOfCompilerOptionValue(value, customTypeMap) {
-    return forEachEntry(customTypeMap, (mapValue, key) => {
-      if (mapValue === value) {
-        return key;
-      }
-    });
-  }
-  function serializeCompilerOptions(options, pathOptions) {
-    return serializeOptionBaseObject(options, getOptionsNameMap(), pathOptions);
-  }
-  function serializeWatchOptions(options) {
-    return serializeOptionBaseObject(options, getWatchOptionsNameMap());
-  }
-  function serializeOptionBaseObject(options, { optionsNameMap }, pathOptions) {
-    const result = /* @__PURE__ */ new Map();
-    const getCanonicalFileName = pathOptions && createGetCanonicalFileName(pathOptions.useCaseSensitiveFileNames);
-    for (const name in options) {
-      if (hasProperty(options, name)) {
-        if (optionsNameMap.has(name) && (optionsNameMap.get(name).category === Diagnostics.Command_line_Options || optionsNameMap.get(name).category === Diagnostics.Output_Formatting)) {
-          continue;
-        }
-        const value = options[name];
-        const optionDefinition = optionsNameMap.get(name.toLowerCase());
-        if (optionDefinition) {
-          Debug.assert(optionDefinition.type !== "listOrElement");
-          const customTypeMap = getCustomTypeMapOfCommandLineOption(optionDefinition);
-          if (!customTypeMap) {
-            if (pathOptions && optionDefinition.isFilePath) {
-              result.set(name, getRelativePathFromFile(pathOptions.configFilePath, getNormalizedAbsolutePath(value, getDirectoryPath(pathOptions.configFilePath)), getCanonicalFileName));
-            } else {
-              result.set(name, value);
-            }
-          } else {
-            if (optionDefinition.type === "list") {
-              result.set(name, value.map((element) => getNameOfCompilerOptionValue(element, customTypeMap)));
-            } else {
-              result.set(name, getNameOfCompilerOptionValue(value, customTypeMap));
-            }
-          }
-        }
-      }
-    }
-    return result;
-  }
-  function getCompilerOptionsDiffValue(options, newLine) {
-    const compilerOptionsMap = getSerializedCompilerOption(options);
-    return getOverwrittenDefaultOptions();
-    function makePadding(paddingLength) {
-      return Array(paddingLength + 1).join(" ");
-    }
-    function getOverwrittenDefaultOptions() {
-      const result = [];
-      const tab = makePadding(2);
-      commandOptionsWithoutBuild.forEach((cmd) => {
-        if (!compilerOptionsMap.has(cmd.name)) {
-          return;
-        }
-        const newValue = compilerOptionsMap.get(cmd.name);
-        const defaultValue = getDefaultValueForOption(cmd);
-        if (newValue !== defaultValue) {
-          result.push(`${tab}${cmd.name}: ${newValue}`);
-        } else if (hasProperty(defaultInitCompilerOptions, cmd.name)) {
-          result.push(`${tab}${cmd.name}: ${defaultValue}`);
-        }
-      });
-      return result.join(newLine) + newLine;
-    }
-  }
-  function getSerializedCompilerOption(options) {
-    const compilerOptions = extend(options, defaultInitCompilerOptions);
-    return serializeCompilerOptions(compilerOptions);
-  }
-  function generateTSConfig(options, fileNames, newLine) {
-    const compilerOptionsMap = getSerializedCompilerOption(options);
-    return writeConfigurations();
-    function makePadding(paddingLength) {
-      return Array(paddingLength + 1).join(" ");
-    }
-    function isAllowedOptionForOutput({ category, name, isCommandLineOnly }) {
-      const categoriesToSkip = [Diagnostics.Command_line_Options, Diagnostics.Editor_Support, Diagnostics.Compiler_Diagnostics, Diagnostics.Backwards_Compatibility, Diagnostics.Watch_and_Build_Modes, Diagnostics.Output_Formatting];
-      return !isCommandLineOnly && category !== void 0 && (!categoriesToSkip.includes(category) || compilerOptionsMap.has(name));
-    }
-    function writeConfigurations() {
-      const categorizedOptions = /* @__PURE__ */ new Map();
-      categorizedOptions.set(Diagnostics.Projects, []);
-      categorizedOptions.set(Diagnostics.Language_and_Environment, []);
-      categorizedOptions.set(Diagnostics.Modules, []);
-      categorizedOptions.set(Diagnostics.JavaScript_Support, []);
-      categorizedOptions.set(Diagnostics.Emit, []);
-      categorizedOptions.set(Diagnostics.Interop_Constraints, []);
-      categorizedOptions.set(Diagnostics.Type_Checking, []);
-      categorizedOptions.set(Diagnostics.Completeness, []);
-      for (const option of optionDeclarations) {
-        if (isAllowedOptionForOutput(option)) {
-          let listForCategory = categorizedOptions.get(option.category);
-          if (!listForCategory)
-            categorizedOptions.set(option.category, listForCategory = []);
-          listForCategory.push(option);
-        }
-      }
-      let marginLength = 0;
-      let seenKnownKeys = 0;
-      const entries = [];
-      categorizedOptions.forEach((options2, category) => {
-        if (entries.length !== 0) {
-          entries.push({ value: "" });
-        }
-        entries.push({ value: `/* ${getLocaleSpecificMessage(category)} */` });
-        for (const option of options2) {
-          let optionName;
-          if (compilerOptionsMap.has(option.name)) {
-            optionName = `"${option.name}": ${JSON.stringify(compilerOptionsMap.get(option.name))}${(seenKnownKeys += 1) === compilerOptionsMap.size ? "" : ","}`;
-          } else {
-            optionName = `// "${option.name}": ${JSON.stringify(getDefaultValueForOption(option))},`;
-          }
-          entries.push({
-            value: optionName,
-            description: `/* ${option.description && getLocaleSpecificMessage(option.description) || option.name} */`
-          });
-          marginLength = Math.max(optionName.length, marginLength);
-        }
-      });
-      const tab = makePadding(2);
-      const result = [];
-      result.push(`{`);
-      result.push(`${tab}"compilerOptions": {`);
-      result.push(`${tab}${tab}/* ${getLocaleSpecificMessage(Diagnostics.Visit_https_Colon_Slash_Slashaka_ms_Slashtsconfig_to_read_more_about_this_file)} */`);
-      result.push("");
-      for (const entry of entries) {
-        const { value, description: description3 = "" } = entry;
-        result.push(value && `${tab}${tab}${value}${description3 && makePadding(marginLength - value.length + 2) + description3}`);
-      }
-      if (fileNames.length) {
-        result.push(`${tab}},`);
-        result.push(`${tab}"files": [`);
-        for (let i = 0; i < fileNames.length; i++) {
-          result.push(`${tab}${tab}${JSON.stringify(fileNames[i])}${i === fileNames.length - 1 ? "" : ","}`);
-        }
-        result.push(`${tab}]`);
-      } else {
-        result.push(`${tab}}`);
-      }
-      result.push(`}`);
-      return result.join(newLine) + newLine;
-    }
-  }
-  function convertToOptionsWithAbsolutePaths(options, toAbsolutePath) {
-    const result = {};
-    const optionsNameMap = getOptionsNameMap().optionsNameMap;
-    for (const name in options) {
-      if (hasProperty(options, name)) {
-        result[name] = convertToOptionValueWithAbsolutePaths(
-          optionsNameMap.get(name.toLowerCase()),
-          options[name],
-          toAbsolutePath
-        );
-      }
-    }
-    if (result.configFilePath) {
-      result.configFilePath = toAbsolutePath(result.configFilePath);
-    }
-    return result;
-  }
-  function convertToOptionValueWithAbsolutePaths(option, value, toAbsolutePath) {
-    if (option && !isNullOrUndefined(value)) {
-      if (option.type === "list") {
-        const values = value;
-        if (option.element.isFilePath && values.length) {
-          return values.map(toAbsolutePath);
-        }
-      } else if (option.isFilePath) {
-        return toAbsolutePath(value);
-      }
-      Debug.assert(option.type !== "listOrElement");
-    }
-    return value;
-  }
-  function parseJsonConfigFileContent(json, host, basePath, existingOptions, configFileName, resolutionStack, extraFileExtensions, extendedConfigCache, existingWatchOptions) {
-    return parseJsonConfigFileContentWorker(
-      json,
-      /*sourceFile*/
-      void 0,
-      host,
-      basePath,
-      existingOptions,
-      existingWatchOptions,
-      configFileName,
-      resolutionStack,
-      extraFileExtensions,
-      extendedConfigCache
-    );
-  }
-  function parseJsonSourceFileConfigFileContent(sourceFile, host, basePath, existingOptions, configFileName, resolutionStack, extraFileExtensions, extendedConfigCache, existingWatchOptions) {
-    var _a, _b;
-    (_a = tracing) == null ? void 0 : _a.push(tracing.Phase.Parse, "parseJsonSourceFileConfigFileContent", { path: sourceFile.fileName });
-    const result = parseJsonConfigFileContentWorker(
-      /*json*/
-      void 0,
-      sourceFile,
-      host,
-      basePath,
-      existingOptions,
-      existingWatchOptions,
-      configFileName,
-      resolutionStack,
-      extraFileExtensions,
-      extendedConfigCache
-    );
-    (_b = tracing) == null ? void 0 : _b.pop();
-    return result;
-  }
-  function setConfigFileInOptions(options, configFile) {
-    if (configFile) {
-      Object.defineProperty(options, "configFile", { enumerable: false, writable: false, value: configFile });
-    }
-  }
-  function isNullOrUndefined(x) {
-    return x === void 0 || x === null;
-  }
-  function directoryOfCombinedPath(fileName, basePath) {
-    return getDirectoryPath(getNormalizedAbsolutePath(fileName, basePath));
-  }
-  function parseJsonConfigFileContentWorker(json, sourceFile, host, basePath, existingOptions = {}, existingWatchOptions, configFileName, resolutionStack = [], extraFileExtensions = [], extendedConfigCache) {
-    Debug.assert(json === void 0 && sourceFile !== void 0 || json !== void 0 && sourceFile === void 0);
-    const errors = [];
-    const parsedConfig = parseConfig(json, sourceFile, host, basePath, configFileName, resolutionStack, errors, extendedConfigCache);
-    const { raw } = parsedConfig;
-    const options = extend(existingOptions, parsedConfig.options || {});
-    const watchOptions = existingWatchOptions && parsedConfig.watchOptions ? extend(existingWatchOptions, parsedConfig.watchOptions) : parsedConfig.watchOptions || existingWatchOptions;
-    options.configFilePath = configFileName && normalizeSlashes(configFileName);
-    const configFileSpecs = getConfigFileSpecs();
-    if (sourceFile)
-      sourceFile.configFileSpecs = configFileSpecs;
-    setConfigFileInOptions(options, sourceFile);
-    const basePathForFileNames = normalizePath(configFileName ? directoryOfCombinedPath(configFileName, basePath) : basePath);
-    return {
-      options,
-      watchOptions,
-      fileNames: getFileNames(basePathForFileNames),
-      projectReferences: getProjectReferences(basePathForFileNames),
-      typeAcquisition: parsedConfig.typeAcquisition || getDefaultTypeAcquisition(),
-      raw,
-      errors,
-      // Wildcard directories (provided as part of a wildcard path) are stored in a
-      // file map that marks whether it was a regular wildcard match (with a `*` or `?` token),
-      // or a recursive directory. This information is used by filesystem watchers to monitor for
-      // new entries in these paths.
-      wildcardDirectories: getWildcardDirectories(configFileSpecs, basePathForFileNames, host.useCaseSensitiveFileNames),
-      compileOnSave: !!raw.compileOnSave
-    };
-    function getConfigFileSpecs() {
-      const referencesOfRaw = getPropFromRaw("references", (element) => typeof element === "object", "object");
-      const filesSpecs = toPropValue(getSpecsFromRaw("files"));
-      if (filesSpecs) {
-        const hasZeroOrNoReferences = referencesOfRaw === "no-prop" || isArray(referencesOfRaw) && referencesOfRaw.length === 0;
-        const hasExtends = hasProperty(raw, "extends");
-        if (filesSpecs.length === 0 && hasZeroOrNoReferences && !hasExtends) {
-          if (sourceFile) {
-            const fileName = configFileName || "tsconfig.json";
-            const diagnosticMessage = Diagnostics.The_files_list_in_config_file_0_is_empty;
-            const nodeValue = forEachTsConfigPropArray(sourceFile, "files", (property) => property.initializer);
-            const error = createDiagnosticForNodeInSourceFileOrCompilerDiagnostic(sourceFile, nodeValue, diagnosticMessage, fileName);
-            errors.push(error);
-          } else {
-            createCompilerDiagnosticOnlyIfJson(Diagnostics.The_files_list_in_config_file_0_is_empty, configFileName || "tsconfig.json");
-          }
-        }
-      }
-      let includeSpecs = toPropValue(getSpecsFromRaw("include"));
-      const excludeOfRaw = getSpecsFromRaw("exclude");
-      let isDefaultIncludeSpec = false;
-      let excludeSpecs = toPropValue(excludeOfRaw);
-      if (excludeOfRaw === "no-prop" && raw.compilerOptions) {
-        const outDir = raw.compilerOptions.outDir;
-        const declarationDir = raw.compilerOptions.declarationDir;
-        if (outDir || declarationDir) {
-          excludeSpecs = [outDir, declarationDir].filter((d) => !!d);
-        }
-      }
-      if (filesSpecs === void 0 && includeSpecs === void 0) {
-        includeSpecs = [defaultIncludeSpec];
-        isDefaultIncludeSpec = true;
-      }
-      let validatedIncludeSpecs, validatedExcludeSpecs;
-      if (includeSpecs) {
-        validatedIncludeSpecs = validateSpecs(
-          includeSpecs,
-          errors,
-          /*disallowTrailingRecursion*/
-          true,
-          sourceFile,
-          "include"
-        );
-      }
-      if (excludeSpecs) {
-        validatedExcludeSpecs = validateSpecs(
-          excludeSpecs,
-          errors,
-          /*disallowTrailingRecursion*/
-          false,
-          sourceFile,
-          "exclude"
-        );
-      }
-      return {
-        filesSpecs,
-        includeSpecs,
-        excludeSpecs,
-        validatedFilesSpec: filter(filesSpecs, isString),
-        validatedIncludeSpecs,
-        validatedExcludeSpecs,
-        pathPatterns: void 0,
-        // Initialized on first use
-        isDefaultIncludeSpec
-      };
-    }
-    function getFileNames(basePath2) {
-      const fileNames = getFileNamesFromConfigSpecs(configFileSpecs, basePath2, options, host, extraFileExtensions);
-      if (shouldReportNoInputFiles(fileNames, canJsonReportNoInputFiles(raw), resolutionStack)) {
-        errors.push(getErrorForNoInputFiles(configFileSpecs, configFileName));
-      }
-      return fileNames;
-    }
-    function getProjectReferences(basePath2) {
-      let projectReferences;
-      const referencesOfRaw = getPropFromRaw("references", (element) => typeof element === "object", "object");
-      if (isArray(referencesOfRaw)) {
-        for (const ref of referencesOfRaw) {
-          if (typeof ref.path !== "string") {
-            createCompilerDiagnosticOnlyIfJson(Diagnostics.Compiler_option_0_requires_a_value_of_type_1, "reference.path", "string");
-          } else {
-            (projectReferences || (projectReferences = [])).push({
-              path: getNormalizedAbsolutePath(ref.path, basePath2),
-              originalPath: ref.path,
-              prepend: ref.prepend,
-              circular: ref.circular
-            });
-          }
-        }
-      }
-      return projectReferences;
-    }
-    function toPropValue(specResult) {
-      return isArray(specResult) ? specResult : void 0;
-    }
-    function getSpecsFromRaw(prop) {
-      return getPropFromRaw(prop, isString, "string");
-    }
-    function getPropFromRaw(prop, validateElement, elementTypeName) {
-      if (hasProperty(raw, prop) && !isNullOrUndefined(raw[prop])) {
-        if (isArray(raw[prop])) {
-          const result = raw[prop];
-          if (!sourceFile && !every(result, validateElement)) {
-            errors.push(createCompilerDiagnostic(Diagnostics.Compiler_option_0_requires_a_value_of_type_1, prop, elementTypeName));
-          }
-          return result;
-        } else {
-          createCompilerDiagnosticOnlyIfJson(Diagnostics.Compiler_option_0_requires_a_value_of_type_1, prop, "Array");
-          return "not-array";
-        }
-      }
-      return "no-prop";
-    }
-    function createCompilerDiagnosticOnlyIfJson(message, ...args) {
-      if (!sourceFile) {
-        errors.push(createCompilerDiagnostic(message, ...args));
-      }
-    }
-  }
-  function isErrorNoInputFiles(error) {
-    return error.code === Diagnostics.No_inputs_were_found_in_config_file_0_Specified_include_paths_were_1_and_exclude_paths_were_2.code;
-  }
-  function getErrorForNoInputFiles({ includeSpecs, excludeSpecs }, configFileName) {
-    return createCompilerDiagnostic(
-      Diagnostics.No_inputs_were_found_in_config_file_0_Specified_include_paths_were_1_and_exclude_paths_were_2,
-      configFileName || "tsconfig.json",
-      JSON.stringify(includeSpecs || []),
-      JSON.stringify(excludeSpecs || [])
-    );
-  }
-  function shouldReportNoInputFiles(fileNames, canJsonReportNoInutFiles, resolutionStack) {
-    return fileNames.length === 0 && canJsonReportNoInutFiles && (!resolutionStack || resolutionStack.length === 0);
-  }
-  function canJsonReportNoInputFiles(raw) {
-    return !hasProperty(raw, "files") && !hasProperty(raw, "references");
-  }
-  function updateErrorForNoInputFiles(fileNames, configFileName, configFileSpecs, configParseDiagnostics, canJsonReportNoInutFiles) {
-    const existingErrors = configParseDiagnostics.length;
-    if (shouldReportNoInputFiles(fileNames, canJsonReportNoInutFiles)) {
-      configParseDiagnostics.push(getErrorForNoInputFiles(configFileSpecs, configFileName));
-    } else {
-      filterMutate(configParseDiagnostics, (error) => !isErrorNoInputFiles(error));
-    }
-    return existingErrors !== configParseDiagnostics.length;
-  }
-  function isSuccessfulParsedTsconfig(value) {
-    return !!value.options;
-  }
-  function parseConfig(json, sourceFile, host, basePath, configFileName, resolutionStack, errors, extendedConfigCache) {
-    var _a;
-    basePath = normalizeSlashes(basePath);
-    const resolvedPath = getNormalizedAbsolutePath(configFileName || "", basePath);
-    if (resolutionStack.indexOf(resolvedPath) >= 0) {
-      errors.push(createCompilerDiagnostic(Diagnostics.Circularity_detected_while_resolving_configuration_Colon_0, [...resolutionStack, resolvedPath].join(" -> ")));
-      return { raw: json || convertToObject(sourceFile, errors) };
-    }
-    const ownConfig = json ? parseOwnConfigOfJson(json, host, basePath, configFileName, errors) : parseOwnConfigOfJsonSourceFile(sourceFile, host, basePath, configFileName, errors);
-    if ((_a = ownConfig.options) == null ? void 0 : _a.paths) {
-      ownConfig.options.pathsBasePath = basePath;
-    }
-    if (ownConfig.extendedConfigPath) {
-      resolutionStack = resolutionStack.concat([resolvedPath]);
-      const result = { options: {} };
-      if (isString(ownConfig.extendedConfigPath)) {
-        applyExtendedConfig(result, ownConfig.extendedConfigPath);
-      } else {
-        ownConfig.extendedConfigPath.forEach((extendedConfigPath) => applyExtendedConfig(result, extendedConfigPath));
-      }
-      if (!ownConfig.raw.include && result.include)
-        ownConfig.raw.include = result.include;
-      if (!ownConfig.raw.exclude && result.exclude)
-        ownConfig.raw.exclude = result.exclude;
-      if (!ownConfig.raw.files && result.files)
-        ownConfig.raw.files = result.files;
-      if (ownConfig.raw.compileOnSave === void 0 && result.compileOnSave)
-        ownConfig.raw.compileOnSave = result.compileOnSave;
-      if (sourceFile && result.extendedSourceFiles)
-        sourceFile.extendedSourceFiles = arrayFrom(result.extendedSourceFiles.keys());
-      ownConfig.options = assign(result.options, ownConfig.options);
-      ownConfig.watchOptions = ownConfig.watchOptions && result.watchOptions ? assign(result.watchOptions, ownConfig.watchOptions) : ownConfig.watchOptions || result.watchOptions;
-    }
-    return ownConfig;
-    function applyExtendedConfig(result, extendedConfigPath) {
-      const extendedConfig = getExtendedConfig(sourceFile, extendedConfigPath, host, resolutionStack, errors, extendedConfigCache, result);
-      if (extendedConfig && isSuccessfulParsedTsconfig(extendedConfig)) {
-        const extendsRaw = extendedConfig.raw;
-        let relativeDifference;
-        const setPropertyInResultIfNotUndefined = (propertyName) => {
-          if (extendsRaw[propertyName]) {
-            result[propertyName] = map(extendsRaw[propertyName], (path) => isRootedDiskPath(path) ? path : combinePaths(
-              relativeDifference || (relativeDifference = convertToRelativePath(getDirectoryPath(extendedConfigPath), basePath, createGetCanonicalFileName(host.useCaseSensitiveFileNames))),
-              path
-            ));
-          }
-        };
-        setPropertyInResultIfNotUndefined("include");
-        setPropertyInResultIfNotUndefined("exclude");
-        setPropertyInResultIfNotUndefined("files");
-        if (extendsRaw.compileOnSave !== void 0) {
-          result.compileOnSave = extendsRaw.compileOnSave;
-        }
-        assign(result.options, extendedConfig.options);
-        result.watchOptions = result.watchOptions && extendedConfig.watchOptions ? assign({}, result.watchOptions, extendedConfig.watchOptions) : result.watchOptions || extendedConfig.watchOptions;
-      }
-    }
-  }
-  function parseOwnConfigOfJson(json, host, basePath, configFileName, errors) {
-    if (hasProperty(json, "excludes")) {
-      errors.push(createCompilerDiagnostic(Diagnostics.Unknown_option_excludes_Did_you_mean_exclude));
-    }
-    const options = convertCompilerOptionsFromJsonWorker(json.compilerOptions, basePath, errors, configFileName);
-    const typeAcquisition = convertTypeAcquisitionFromJsonWorker(json.typeAcquisition, basePath, errors, configFileName);
-    const watchOptions = convertWatchOptionsFromJsonWorker(json.watchOptions, basePath, errors);
-    json.compileOnSave = convertCompileOnSaveOptionFromJson(json, basePath, errors);
-    const extendedConfigPath = json.extends || json.extends === "" ? getExtendsConfigPathOrArray(json.extends, host, basePath, configFileName, errors) : void 0;
-    return { raw: json, options, watchOptions, typeAcquisition, extendedConfigPath };
-  }
-  function getExtendsConfigPathOrArray(value, host, basePath, configFileName, errors, propertyAssignment, valueExpression, sourceFile) {
-    let extendedConfigPath;
-    const newBase = configFileName ? directoryOfCombinedPath(configFileName, basePath) : basePath;
-    if (isString(value)) {
-      extendedConfigPath = getExtendsConfigPath(
-        value,
-        host,
-        newBase,
-        errors,
-        valueExpression,
-        sourceFile
-      );
-    } else if (isArray(value)) {
-      extendedConfigPath = [];
-      for (let index = 0; index < value.length; index++) {
-        const fileName = value[index];
-        if (isString(fileName)) {
-          extendedConfigPath = append(extendedConfigPath, getExtendsConfigPath(
-            fileName,
-            host,
-            newBase,
-            errors,
-            valueExpression == null ? void 0 : valueExpression.elements[index],
-            sourceFile
-          ));
-        } else {
-          convertJsonOption(extendsOptionDeclaration.element, value, basePath, errors, propertyAssignment, valueExpression == null ? void 0 : valueExpression.elements[index], sourceFile);
-        }
-      }
-    } else {
-      convertJsonOption(extendsOptionDeclaration, value, basePath, errors, propertyAssignment, valueExpression, sourceFile);
-    }
-    return extendedConfigPath;
-  }
-  function parseOwnConfigOfJsonSourceFile(sourceFile, host, basePath, configFileName, errors) {
-    const options = getDefaultCompilerOptions(configFileName);
-    let typeAcquisition;
-    let watchOptions;
-    let extendedConfigPath;
-    let rootCompilerOptions;
-    const rootOptions = getTsconfigRootOptionsMap();
-    const json = convertConfigFileToObject(
-      sourceFile,
-      errors,
-      { rootOptions, onPropertySet }
-    );
-    if (!typeAcquisition) {
-      typeAcquisition = getDefaultTypeAcquisition(configFileName);
-    }
-    if (rootCompilerOptions && json && json.compilerOptions === void 0) {
-      errors.push(createDiagnosticForNodeInSourceFile(sourceFile, rootCompilerOptions[0], Diagnostics._0_should_be_set_inside_the_compilerOptions_object_of_the_config_json_file, getTextOfPropertyName(rootCompilerOptions[0])));
-    }
-    return { raw: json, options, watchOptions, typeAcquisition, extendedConfigPath };
-    function onPropertySet(keyText, value, propertyAssignment, parentOption, option) {
-      if (option && option !== extendsOptionDeclaration)
-        value = convertJsonOption(option, value, basePath, errors, propertyAssignment, propertyAssignment.initializer, sourceFile);
-      if (parentOption == null ? void 0 : parentOption.name) {
-        if (option) {
-          let currentOption;
-          if (parentOption === compilerOptionsDeclaration)
-            currentOption = options;
-          else if (parentOption === watchOptionsDeclaration)
-            currentOption = watchOptions ?? (watchOptions = {});
-          else if (parentOption === typeAcquisitionDeclaration)
-            currentOption = typeAcquisition ?? (typeAcquisition = getDefaultTypeAcquisition(configFileName));
-          else
-            Debug.fail("Unknown option");
-          currentOption[option.name] = value;
-        } else if (keyText && (parentOption == null ? void 0 : parentOption.extraKeyDiagnostics)) {
-          if (parentOption.elementOptions) {
-            errors.push(createUnknownOptionError(
-              keyText,
-              parentOption.extraKeyDiagnostics,
-              /*unknownOptionErrorText*/
-              void 0,
-              propertyAssignment.name,
-              sourceFile
-            ));
-          } else {
-            errors.push(createDiagnosticForNodeInSourceFile(sourceFile, propertyAssignment.name, parentOption.extraKeyDiagnostics.unknownOptionDiagnostic, keyText));
-          }
-        }
-      } else if (parentOption === rootOptions) {
-        if (option === extendsOptionDeclaration) {
-          extendedConfigPath = getExtendsConfigPathOrArray(value, host, basePath, configFileName, errors, propertyAssignment, propertyAssignment.initializer, sourceFile);
-        } else if (!option) {
-          if (keyText === "excludes") {
-            errors.push(createDiagnosticForNodeInSourceFile(sourceFile, propertyAssignment.name, Diagnostics.Unknown_option_excludes_Did_you_mean_exclude));
-          }
-          if (find(commandOptionsWithoutBuild, (opt) => opt.name === keyText)) {
-            rootCompilerOptions = append(rootCompilerOptions, propertyAssignment.name);
-          }
-        }
-      }
-    }
-  }
-  function getExtendsConfigPath(extendedConfig, host, basePath, errors, valueExpression, sourceFile) {
-    extendedConfig = normalizeSlashes(extendedConfig);
-    if (isRootedDiskPath(extendedConfig) || startsWith(extendedConfig, "./") || startsWith(extendedConfig, "../")) {
-      let extendedConfigPath = getNormalizedAbsolutePath(extendedConfig, basePath);
-      if (!host.fileExists(extendedConfigPath) && !endsWith(extendedConfigPath, ".json" /* Json */)) {
-        extendedConfigPath = `${extendedConfigPath}.json`;
-        if (!host.fileExists(extendedConfigPath)) {
-          errors.push(createDiagnosticForNodeInSourceFileOrCompilerDiagnostic(sourceFile, valueExpression, Diagnostics.File_0_not_found, extendedConfig));
-          return void 0;
-        }
-      }
-      return extendedConfigPath;
-    }
-    const resolved = nodeNextJsonConfigResolver(extendedConfig, combinePaths(basePath, "tsconfig.json"), host);
-    if (resolved.resolvedModule) {
-      return resolved.resolvedModule.resolvedFileName;
-    }
-    if (extendedConfig === "") {
-      errors.push(createDiagnosticForNodeInSourceFileOrCompilerDiagnostic(sourceFile, valueExpression, Diagnostics.Compiler_option_0_cannot_be_given_an_empty_string, "extends"));
-    } else {
-      errors.push(createDiagnosticForNodeInSourceFileOrCompilerDiagnostic(sourceFile, valueExpression, Diagnostics.File_0_not_found, extendedConfig));
-    }
-    return void 0;
-  }
-  function getExtendedConfig(sourceFile, extendedConfigPath, host, resolutionStack, errors, extendedConfigCache, result) {
-    const path = host.useCaseSensitiveFileNames ? extendedConfigPath : toFileNameLowerCase(extendedConfigPath);
-    let value;
-    let extendedResult;
-    let extendedConfig;
-    if (extendedConfigCache && (value = extendedConfigCache.get(path))) {
-      ({ extendedResult, extendedConfig } = value);
-    } else {
-      extendedResult = readJsonConfigFile(extendedConfigPath, (path2) => host.readFile(path2));
-      if (!extendedResult.parseDiagnostics.length) {
-        extendedConfig = parseConfig(
-          /*json*/
-          void 0,
-          extendedResult,
-          host,
-          getDirectoryPath(extendedConfigPath),
-          getBaseFileName(extendedConfigPath),
-          resolutionStack,
-          errors,
-          extendedConfigCache
-        );
-      }
-      if (extendedConfigCache) {
-        extendedConfigCache.set(path, { extendedResult, extendedConfig });
-      }
-    }
-    if (sourceFile) {
-      (result.extendedSourceFiles ?? (result.extendedSourceFiles = /* @__PURE__ */ new Set())).add(extendedResult.fileName);
-      if (extendedResult.extendedSourceFiles) {
-        for (const extenedSourceFile of extendedResult.extendedSourceFiles) {
-          result.extendedSourceFiles.add(extenedSourceFile);
-        }
-      }
-    }
-    if (extendedResult.parseDiagnostics.length) {
-      errors.push(...extendedResult.parseDiagnostics);
-      return void 0;
-    }
-    return extendedConfig;
-  }
-  function convertCompileOnSaveOptionFromJson(jsonOption, basePath, errors) {
-    if (!hasProperty(jsonOption, compileOnSaveCommandLineOption.name)) {
-      return false;
-    }
-    const result = convertJsonOption(compileOnSaveCommandLineOption, jsonOption.compileOnSave, basePath, errors);
-    return typeof result === "boolean" && result;
-  }
-  function convertCompilerOptionsFromJson(jsonOptions, basePath, configFileName) {
-    const errors = [];
-    const options = convertCompilerOptionsFromJsonWorker(jsonOptions, basePath, errors, configFileName);
-    return { options, errors };
-  }
-  function convertTypeAcquisitionFromJson(jsonOptions, basePath, configFileName) {
-    const errors = [];
-    const options = convertTypeAcquisitionFromJsonWorker(jsonOptions, basePath, errors, configFileName);
-    return { options, errors };
-  }
-  function getDefaultCompilerOptions(configFileName) {
-    const options = configFileName && getBaseFileName(configFileName) === "jsconfig.json" ? { allowJs: true, maxNodeModuleJsDepth: 2, allowSyntheticDefaultImports: true, skipLibCheck: true, noEmit: true } : {};
-    return options;
-  }
-  function convertCompilerOptionsFromJsonWorker(jsonOptions, basePath, errors, configFileName) {
-    const options = getDefaultCompilerOptions(configFileName);
-    convertOptionsFromJson(getCommandLineCompilerOptionsMap(), jsonOptions, basePath, options, compilerOptionsDidYouMeanDiagnostics, errors);
-    if (configFileName) {
-      options.configFilePath = normalizeSlashes(configFileName);
-    }
-    return options;
-  }
-  function getDefaultTypeAcquisition(configFileName) {
-    return { enable: !!configFileName && getBaseFileName(configFileName) === "jsconfig.json", include: [], exclude: [] };
-  }
-  function convertTypeAcquisitionFromJsonWorker(jsonOptions, basePath, errors, configFileName) {
-    const options = getDefaultTypeAcquisition(configFileName);
-    convertOptionsFromJson(getCommandLineTypeAcquisitionMap(), jsonOptions, basePath, options, typeAcquisitionDidYouMeanDiagnostics, errors);
-    return options;
-  }
-  function convertWatchOptionsFromJsonWorker(jsonOptions, basePath, errors) {
-    return convertOptionsFromJson(
-      getCommandLineWatchOptionsMap(),
-      jsonOptions,
-      basePath,
-      /*defaultOptions*/
-      void 0,
-      watchOptionsDidYouMeanDiagnostics,
-      errors
-    );
-  }
-  function convertOptionsFromJson(optionsNameMap, jsonOptions, basePath, defaultOptions, diagnostics, errors) {
-    if (!jsonOptions) {
-      return;
-    }
-    for (const id in jsonOptions) {
-      const opt = optionsNameMap.get(id);
-      if (opt) {
-        (defaultOptions || (defaultOptions = {}))[opt.name] = convertJsonOption(opt, jsonOptions[id], basePath, errors);
-      } else {
-        errors.push(createUnknownOptionError(id, diagnostics));
-      }
-    }
-    return defaultOptions;
-  }
-  function createDiagnosticForNodeInSourceFileOrCompilerDiagnostic(sourceFile, node, message, ...args) {
-    return sourceFile && node ? createDiagnosticForNodeInSourceFile(sourceFile, node, message, ...args) : createCompilerDiagnostic(message, ...args);
-  }
-  function convertJsonOption(opt, value, basePath, errors, propertyAssignment, valueExpression, sourceFile) {
-    if (opt.isCommandLineOnly) {
-      errors.push(createDiagnosticForNodeInSourceFileOrCompilerDiagnostic(sourceFile, propertyAssignment == null ? void 0 : propertyAssignment.name, Diagnostics.Option_0_can_only_be_specified_on_command_line, opt.name));
-      return void 0;
-    }
-    if (isCompilerOptionsValue(opt, value)) {
-      const optType = opt.type;
-      if (optType === "list" && isArray(value)) {
-        return convertJsonOptionOfListType(opt, value, basePath, errors, propertyAssignment, valueExpression, sourceFile);
-      } else if (optType === "listOrElement") {
-        return isArray(value) ? convertJsonOptionOfListType(opt, value, basePath, errors, propertyAssignment, valueExpression, sourceFile) : convertJsonOption(opt.element, value, basePath, errors, propertyAssignment, valueExpression, sourceFile);
-      } else if (!isString(opt.type)) {
-        return convertJsonOptionOfCustomType(opt, value, errors, valueExpression, sourceFile);
-      }
-      const validatedValue = validateJsonOptionValue(opt, value, errors, valueExpression, sourceFile);
-      return isNullOrUndefined(validatedValue) ? validatedValue : normalizeNonListOptionValue(opt, basePath, validatedValue);
-    } else {
-      errors.push(createDiagnosticForNodeInSourceFileOrCompilerDiagnostic(sourceFile, valueExpression, Diagnostics.Compiler_option_0_requires_a_value_of_type_1, opt.name, getCompilerOptionValueTypeString(opt)));
-    }
-  }
-  function normalizeNonListOptionValue(option, basePath, value) {
-    if (option.isFilePath) {
-      value = getNormalizedAbsolutePath(value, basePath);
-      if (value === "") {
-        value = ".";
-      }
-    }
-    return value;
-  }
-  function validateJsonOptionValue(opt, value, errors, valueExpression, sourceFile) {
-    var _a;
-    if (isNullOrUndefined(value))
-      return void 0;
-    const d = (_a = opt.extraValidation) == null ? void 0 : _a.call(opt, value);
-    if (!d)
-      return value;
-    errors.push(createDiagnosticForNodeInSourceFileOrCompilerDiagnostic(sourceFile, valueExpression, ...d));
-    return void 0;
-  }
-  function convertJsonOptionOfCustomType(opt, value, errors, valueExpression, sourceFile) {
-    if (isNullOrUndefined(value))
-      return void 0;
-    const key = value.toLowerCase();
-    const val = opt.type.get(key);
-    if (val !== void 0) {
-      return validateJsonOptionValue(opt, val, errors, valueExpression, sourceFile);
-    } else {
-      errors.push(createDiagnosticForInvalidCustomType(opt, (message, ...args) => createDiagnosticForNodeInSourceFileOrCompilerDiagnostic(sourceFile, valueExpression, message, ...args)));
-    }
-  }
-  function convertJsonOptionOfListType(option, values, basePath, errors, propertyAssignment, valueExpression, sourceFile) {
-    return filter(map(values, (v, index) => convertJsonOption(option.element, v, basePath, errors, propertyAssignment, valueExpression == null ? void 0 : valueExpression.elements[index], sourceFile)), (v) => option.listPreserveFalsyValues ? true : !!v);
-  }
-  function getFileNamesFromConfigSpecs(configFileSpecs, basePath, options, host, extraFileExtensions = emptyArray) {
-    basePath = normalizePath(basePath);
-    const keyMapper = createGetCanonicalFileName(host.useCaseSensitiveFileNames);
-    const literalFileMap = /* @__PURE__ */ new Map();
-    const wildcardFileMap = /* @__PURE__ */ new Map();
-    const wildCardJsonFileMap = /* @__PURE__ */ new Map();
-    const { validatedFilesSpec, validatedIncludeSpecs, validatedExcludeSpecs } = configFileSpecs;
-    const supportedExtensions = getSupportedExtensions(options, extraFileExtensions);
-    const supportedExtensionsWithJsonIfResolveJsonModule = getSupportedExtensionsWithJsonIfResolveJsonModule(options, supportedExtensions);
-    if (validatedFilesSpec) {
-      for (const fileName of validatedFilesSpec) {
-        const file = getNormalizedAbsolutePath(fileName, basePath);
-        literalFileMap.set(keyMapper(file), file);
-      }
-    }
-    let jsonOnlyIncludeRegexes;
-    if (validatedIncludeSpecs && validatedIncludeSpecs.length > 0) {
-      for (const file of host.readDirectory(
-        basePath,
-        flatten(supportedExtensionsWithJsonIfResolveJsonModule),
-        validatedExcludeSpecs,
-        validatedIncludeSpecs,
-        /*depth*/
-        void 0
-      )) {
-        if (fileExtensionIs(file, ".json" /* Json */)) {
-          if (!jsonOnlyIncludeRegexes) {
-            const includes = validatedIncludeSpecs.filter((s) => endsWith(s, ".json" /* Json */));
-            const includeFilePatterns = map(getRegularExpressionsForWildcards(includes, basePath, "files"), (pattern) => `^${pattern}$`);
-            jsonOnlyIncludeRegexes = includeFilePatterns ? includeFilePatterns.map((pattern) => getRegexFromPattern(pattern, host.useCaseSensitiveFileNames)) : emptyArray;
-          }
-          const includeIndex = findIndex(jsonOnlyIncludeRegexes, (re) => re.test(file));
-          if (includeIndex !== -1) {
-            const key2 = keyMapper(file);
-            if (!literalFileMap.has(key2) && !wildCardJsonFileMap.has(key2)) {
-              wildCardJsonFileMap.set(key2, file);
-            }
-          }
-          continue;
-        }
-        if (hasFileWithHigherPriorityExtension(file, literalFileMap, wildcardFileMap, supportedExtensions, keyMapper)) {
-          continue;
-        }
-        removeWildcardFilesWithLowerPriorityExtension(file, wildcardFileMap, supportedExtensions, keyMapper);
-        const key = keyMapper(file);
-        if (!literalFileMap.has(key) && !wildcardFileMap.has(key)) {
-          wildcardFileMap.set(key, file);
-        }
-      }
-    }
-    const literalFiles = arrayFrom(literalFileMap.values());
-    const wildcardFiles = arrayFrom(wildcardFileMap.values());
-    return literalFiles.concat(wildcardFiles, arrayFrom(wildCardJsonFileMap.values()));
-  }
-  function isExcludedFile(pathToCheck, spec, basePath, useCaseSensitiveFileNames, currentDirectory) {
-    const { validatedFilesSpec, validatedIncludeSpecs, validatedExcludeSpecs } = spec;
-    if (!length(validatedIncludeSpecs) || !length(validatedExcludeSpecs))
-      return false;
-    basePath = normalizePath(basePath);
-    const keyMapper = createGetCanonicalFileName(useCaseSensitiveFileNames);
-    if (validatedFilesSpec) {
-      for (const fileName of validatedFilesSpec) {
-        if (keyMapper(getNormalizedAbsolutePath(fileName, basePath)) === pathToCheck)
-          return false;
-      }
-    }
-    return matchesExcludeWorker(pathToCheck, validatedExcludeSpecs, useCaseSensitiveFileNames, currentDirectory, basePath);
-  }
-  function invalidDotDotAfterRecursiveWildcard(s) {
-    const wildcardIndex = startsWith(s, "**/") ? 0 : s.indexOf("/**/");
-    if (wildcardIndex === -1) {
-      return false;
-    }
-    const lastDotIndex = endsWith(s, "/..") ? s.length : s.lastIndexOf("/../");
-    return lastDotIndex > wildcardIndex;
-  }
-  function matchesExclude(pathToCheck, excludeSpecs, useCaseSensitiveFileNames, currentDirectory) {
-    return matchesExcludeWorker(
-      pathToCheck,
-      filter(excludeSpecs, (spec) => !invalidDotDotAfterRecursiveWildcard(spec)),
-      useCaseSensitiveFileNames,
-      currentDirectory
-    );
-  }
-  function matchesExcludeWorker(pathToCheck, excludeSpecs, useCaseSensitiveFileNames, currentDirectory, basePath) {
-    const excludePattern = getRegularExpressionForWildcard(excludeSpecs, combinePaths(normalizePath(currentDirectory), basePath), "exclude");
-    const excludeRegex = excludePattern && getRegexFromPattern(excludePattern, useCaseSensitiveFileNames);
-    if (!excludeRegex)
-      return false;
-    if (excludeRegex.test(pathToCheck))
-      return true;
-    return !hasExtension(pathToCheck) && excludeRegex.test(ensureTrailingDirectorySeparator(pathToCheck));
-  }
-  function validateSpecs(specs, errors, disallowTrailingRecursion, jsonSourceFile, specKey) {
-    return specs.filter((spec) => {
-      if (!isString(spec))
-        return false;
-      const diag2 = specToDiagnostic(spec, disallowTrailingRecursion);
-      if (diag2 !== void 0) {
-        errors.push(createDiagnostic(...diag2));
-      }
-      return diag2 === void 0;
-    });
-    function createDiagnostic(message, spec) {
-      const element = getTsConfigPropArrayElementValue(jsonSourceFile, specKey, spec);
-      return createDiagnosticForNodeInSourceFileOrCompilerDiagnostic(jsonSourceFile, element, message, spec);
-    }
-  }
-  function specToDiagnostic(spec, disallowTrailingRecursion) {
-    Debug.assert(typeof spec === "string");
-    if (disallowTrailingRecursion && invalidTrailingRecursionPattern.test(spec)) {
-      return [Diagnostics.File_specification_cannot_end_in_a_recursive_directory_wildcard_Asterisk_Asterisk_Colon_0, spec];
-    } else if (invalidDotDotAfterRecursiveWildcard(spec)) {
-      return [Diagnostics.File_specification_cannot_contain_a_parent_directory_that_appears_after_a_recursive_directory_wildcard_Asterisk_Asterisk_Colon_0, spec];
-    }
-  }
-  function getWildcardDirectories({ validatedIncludeSpecs: include, validatedExcludeSpecs: exclude }, path, useCaseSensitiveFileNames) {
-    const rawExcludeRegex = getRegularExpressionForWildcard(exclude, path, "exclude");
-    const excludeRegex = rawExcludeRegex && new RegExp(rawExcludeRegex, useCaseSensitiveFileNames ? "" : "i");
-    const wildcardDirectories = {};
-    if (include !== void 0) {
-      const recursiveKeys = [];
-      for (const file of include) {
-        const spec = normalizePath(combinePaths(path, file));
-        if (excludeRegex && excludeRegex.test(spec)) {
-          continue;
-        }
-        const match = getWildcardDirectoryFromSpec(spec, useCaseSensitiveFileNames);
-        if (match) {
-          const { key, flags } = match;
-          const existingFlags = wildcardDirectories[key];
-          if (existingFlags === void 0 || existingFlags < flags) {
-            wildcardDirectories[key] = flags;
-            if (flags === 1 /* Recursive */) {
-              recursiveKeys.push(key);
-            }
-          }
-        }
-      }
-      for (const key in wildcardDirectories) {
-        if (hasProperty(wildcardDirectories, key)) {
-          for (const recursiveKey of recursiveKeys) {
-            if (key !== recursiveKey && containsPath(recursiveKey, key, path, !useCaseSensitiveFileNames)) {
-              delete wildcardDirectories[key];
-            }
-          }
-        }
-      }
-    }
-    return wildcardDirectories;
-  }
-  function getWildcardDirectoryFromSpec(spec, useCaseSensitiveFileNames) {
-    const match = wildcardDirectoryPattern.exec(spec);
-    if (match) {
-      const questionWildcardIndex = spec.indexOf("?");
-      const starWildcardIndex = spec.indexOf("*");
-      const lastDirectorySeperatorIndex = spec.lastIndexOf(directorySeparator);
-      return {
-        key: useCaseSensitiveFileNames ? match[0] : toFileNameLowerCase(match[0]),
-        flags: questionWildcardIndex !== -1 && questionWildcardIndex < lastDirectorySeperatorIndex || starWildcardIndex !== -1 && starWildcardIndex < lastDirectorySeperatorIndex ? 1 /* Recursive */ : 0 /* None */
-      };
-    }
-    if (isImplicitGlob(spec.substring(spec.lastIndexOf(directorySeparator) + 1))) {
-      return {
-        key: removeTrailingDirectorySeparator(useCaseSensitiveFileNames ? spec : toFileNameLowerCase(spec)),
-        flags: 1 /* Recursive */
-      };
-    }
-    return void 0;
-  }
-  function hasFileWithHigherPriorityExtension(file, literalFiles, wildcardFiles, extensions, keyMapper) {
-    const extensionGroup = forEach(extensions, (group2) => fileExtensionIsOneOf(file, group2) ? group2 : void 0);
-    if (!extensionGroup) {
-      return false;
-    }
-    for (const ext of extensionGroup) {
-      if (fileExtensionIs(file, ext)) {
-        return false;
-      }
-      const higherPriorityPath = keyMapper(changeExtension(file, ext));
-      if (literalFiles.has(higherPriorityPath) || wildcardFiles.has(higherPriorityPath)) {
-        if (ext === ".d.ts" /* Dts */ && (fileExtensionIs(file, ".js" /* Js */) || fileExtensionIs(file, ".jsx" /* Jsx */))) {
-          continue;
-        }
-        return true;
-      }
-    }
-    return false;
-  }
-  function removeWildcardFilesWithLowerPriorityExtension(file, wildcardFiles, extensions, keyMapper) {
-    const extensionGroup = forEach(extensions, (group2) => fileExtensionIsOneOf(file, group2) ? group2 : void 0);
-    if (!extensionGroup) {
-      return;
-    }
-    for (let i = extensionGroup.length - 1; i >= 0; i--) {
-      const ext = extensionGroup[i];
-      if (fileExtensionIs(file, ext)) {
-        return;
-      }
-      const lowerPriorityPath = keyMapper(changeExtension(file, ext));
-      wildcardFiles.delete(lowerPriorityPath);
-    }
-  }
-  function convertCompilerOptionsForTelemetry(opts) {
-    const out = {};
-    for (const key in opts) {
-      if (hasProperty(opts, key)) {
-        const type = getOptionFromName(key);
-        if (type !== void 0) {
-          out[key] = getOptionValueWithEmptyStrings(opts[key], type);
-        }
-      }
-    }
-    return out;
-  }
-  function getOptionValueWithEmptyStrings(value, option) {
-    if (value === void 0)
-      return value;
-    switch (option.type) {
-      case "object":
-        return "";
-      case "string":
-        return "";
-      case "number":
-        return typeof value === "number" ? value : "";
-      case "boolean":
-        return typeof value === "boolean" ? value : "";
-      case "listOrElement":
-        if (!isArray(value))
-          return getOptionValueWithEmptyStrings(value, option.element);
-      case "list":
-        const elementType = option.element;
-        return isArray(value) ? mapDefined(value, (v) => getOptionValueWithEmptyStrings(v, elementType)) : "";
-      default:
-        return forEachEntry(option.type, (optionEnumValue, optionStringValue) => {
-          if (optionEnumValue === value) {
-            return optionStringValue;
-          }
-        });
-    }
-  }
-  function getDefaultValueForOption(option) {
-    switch (option.type) {
-      case "number":
-        return 1;
-      case "boolean":
-        return true;
-      case "string":
-        const defaultValue = option.defaultValueDescription;
-        return option.isFilePath ? `./${defaultValue && typeof defaultValue === "string" ? defaultValue : ""}` : "";
-      case "list":
-        return [];
-      case "listOrElement":
-        return getDefaultValueForOption(option.element);
-      case "object":
-        return {};
-      default:
-        const value = firstOrUndefinedIterator(option.type.keys());
-        if (value !== void 0)
-          return value;
-        return Debug.fail("Expected 'option.type' to have entries.");
-    }
-  }
-  var compileOnSaveCommandLineOption, jsxOptionMap, inverseJsxOptionMap, libEntries, libs, libMap, optionsForWatch, commonOptionsWithBuild, targetOptionDeclaration, moduleOptionDeclaration, commandOptionsWithoutBuild, optionDeclarations, semanticDiagnosticsOptionDeclarations, affectsEmitOptionDeclarations, affectsDeclarationPathOptionDeclarations, moduleResolutionOptionDeclarations, sourceFileAffectingCompilerOptions, optionsAffectingProgramStructure, transpileOptionValueCompilerOptions, optionsForBuild, buildOpts, typeAcquisitionDeclarations, optionsNameMapCache, compilerOptionsAlternateMode, defaultInitCompilerOptions, compilerOptionsDidYouMeanDiagnostics, buildOptionsNameMapCache, buildOptionsAlternateMode, buildOptionsDidYouMeanDiagnostics, typeAcquisitionDidYouMeanDiagnostics, watchOptionsNameMapCache, watchOptionsDidYouMeanDiagnostics, commandLineCompilerOptionsMapCache, commandLineWatchOptionsMapCache, commandLineTypeAcquisitionMapCache, extendsOptionDeclaration, compilerOptionsDeclaration, watchOptionsDeclaration, typeAcquisitionDeclaration, _tsconfigRootOptions, defaultIncludeSpec, invalidTrailingRecursionPattern, wildcardDirectoryPattern;
-  var init_commandLineParser = __esm({
-    "src/compiler/commandLineParser.ts"() {
-      "use strict";
-      init_ts2();
-      compileOnSaveCommandLineOption = {
-        name: "compileOnSave",
-        type: "boolean",
-        defaultValueDescription: false
-      };
-      jsxOptionMap = new Map(Object.entries({
-        "preserve": 1 /* Preserve */,
-        "react-native": 3 /* ReactNative */,
-        "react": 2 /* React */,
-        "react-jsx": 4 /* ReactJSX */,
-        "react-jsxdev": 5 /* ReactJSXDev */
-      }));
-      inverseJsxOptionMap = new Map(mapIterator(jsxOptionMap.entries(), ([key, value]) => ["" + value, key]));
-      libEntries = [
-        // JavaScript only
-        ["es5", "lib.es5.d.ts"],
-        ["es6", "lib.es2015.d.ts"],
-        ["es2015", "lib.es2015.d.ts"],
-        ["es7", "lib.es2016.d.ts"],
-        ["es2016", "lib.es2016.d.ts"],
-        ["es2017", "lib.es2017.d.ts"],
-        ["es2018", "lib.es2018.d.ts"],
-        ["es2019", "lib.es2019.d.ts"],
-        ["es2020", "lib.es2020.d.ts"],
-        ["es2021", "lib.es2021.d.ts"],
-        ["es2022", "lib.es2022.d.ts"],
-        ["es2023", "lib.es2023.d.ts"],
-        ["esnext", "lib.esnext.d.ts"],
-        // Host only
-        ["dom", "lib.dom.d.ts"],
-        ["dom.iterable", "lib.dom.iterable.d.ts"],
-        ["webworker", "lib.webworker.d.ts"],
-        ["webworker.importscripts", "lib.webworker.importscripts.d.ts"],
-        ["webworker.iterable", "lib.webworker.iterable.d.ts"],
-        ["scripthost", "lib.scripthost.d.ts"],
-        // ES2015 Or ESNext By-feature options
-        ["es2015.core", "lib.es2015.core.d.ts"],
-        ["es2015.collection", "lib.es2015.collection.d.ts"],
-        ["es2015.generator", "lib.es2015.generator.d.ts"],
-        ["es2015.iterable", "lib.es2015.iterable.d.ts"],
-        ["es2015.promise", "lib.es2015.promise.d.ts"],
-        ["es2015.proxy", "lib.es2015.proxy.d.ts"],
-        ["es2015.reflect", "lib.es2015.reflect.d.ts"],
-        ["es2015.symbol", "lib.es2015.symbol.d.ts"],
-        ["es2015.symbol.wellknown", "lib.es2015.symbol.wellknown.d.ts"],
-        ["es2016.array.include", "lib.es2016.array.include.d.ts"],
-        ["es2017.object", "lib.es2017.object.d.ts"],
-        ["es2017.sharedmemory", "lib.es2017.sharedmemory.d.ts"],
-        ["es2017.string", "lib.es2017.string.d.ts"],
-        ["es2017.intl", "lib.es2017.intl.d.ts"],
-        ["es2017.typedarrays", "lib.es2017.typedarrays.d.ts"],
-        ["es2018.asyncgenerator", "lib.es2018.asyncgenerator.d.ts"],
-        ["es2018.asynciterable", "lib.es2018.asynciterable.d.ts"],
-        ["es2018.intl", "lib.es2018.intl.d.ts"],
-        ["es2018.promise", "lib.es2018.promise.d.ts"],
-        ["es2018.regexp", "lib.es2018.regexp.d.ts"],
-        ["es2019.array", "lib.es2019.array.d.ts"],
-        ["es2019.object", "lib.es2019.object.d.ts"],
-        ["es2019.string", "lib.es2019.string.d.ts"],
-        ["es2019.symbol", "lib.es2019.symbol.d.ts"],
-        ["es2019.intl", "lib.es2019.intl.d.ts"],
-        ["es2020.bigint", "lib.es2020.bigint.d.ts"],
-        ["es2020.date", "lib.es2020.date.d.ts"],
-        ["es2020.promise", "lib.es2020.promise.d.ts"],
-        ["es2020.sharedmemory", "lib.es2020.sharedmemory.d.ts"],
-        ["es2020.string", "lib.es2020.string.d.ts"],
-        ["es2020.symbol.wellknown", "lib.es2020.symbol.wellknown.d.ts"],
-        ["es2020.intl", "lib.es2020.intl.d.ts"],
-        ["es2020.number", "lib.es2020.number.d.ts"],
-        ["es2021.promise", "lib.es2021.promise.d.ts"],
-        ["es2021.string", "lib.es2021.string.d.ts"],
-        ["es2021.weakref", "lib.es2021.weakref.d.ts"],
-        ["es2021.intl", "lib.es2021.intl.d.ts"],
-        ["es2022.array", "lib.es2022.array.d.ts"],
-        ["es2022.error", "lib.es2022.error.d.ts"],
-        ["es2022.intl", "lib.es2022.intl.d.ts"],
-        ["es2022.object", "lib.es2022.object.d.ts"],
-        ["es2022.sharedmemory", "lib.es2022.sharedmemory.d.ts"],
-        ["es2022.string", "lib.es2022.string.d.ts"],
-        ["es2022.regexp", "lib.es2022.regexp.d.ts"],
-        ["es2023.array", "lib.es2023.array.d.ts"],
-        ["esnext.array", "lib.es2023.array.d.ts"],
-        ["esnext.symbol", "lib.es2019.symbol.d.ts"],
-        ["esnext.asynciterable", "lib.es2018.asynciterable.d.ts"],
-        ["esnext.intl", "lib.esnext.intl.d.ts"],
-        ["esnext.bigint", "lib.es2020.bigint.d.ts"],
-        ["esnext.string", "lib.es2022.string.d.ts"],
-        ["esnext.promise", "lib.es2021.promise.d.ts"],
-        ["esnext.weakref", "lib.es2021.weakref.d.ts"],
-        ["decorators", "lib.decorators.d.ts"],
-        ["decorators.legacy", "lib.decorators.legacy.d.ts"]
-      ];
-      libs = libEntries.map((entry) => entry[0]);
-      libMap = new Map(libEntries);
-      optionsForWatch = [
-        {
-          name: "watchFile",
-          type: new Map(Object.entries({
-            fixedpollinginterval: 0 /* FixedPollingInterval */,
-            prioritypollinginterval: 1 /* PriorityPollingInterval */,
-            dynamicprioritypolling: 2 /* DynamicPriorityPolling */,
-            fixedchunksizepolling: 3 /* FixedChunkSizePolling */,
-            usefsevents: 4 /* UseFsEvents */,
-            usefseventsonparentdirectory: 5 /* UseFsEventsOnParentDirectory */
-          })),
-          category: Diagnostics.Watch_and_Build_Modes,
-          description: Diagnostics.Specify_how_the_TypeScript_watch_mode_works,
-          defaultValueDescription: 4 /* UseFsEvents */
-        },
-        {
-          name: "watchDirectory",
-          type: new Map(Object.entries({
-            usefsevents: 0 /* UseFsEvents */,
-            fixedpollinginterval: 1 /* FixedPollingInterval */,
-            dynamicprioritypolling: 2 /* DynamicPriorityPolling */,
-            fixedchunksizepolling: 3 /* FixedChunkSizePolling */
-          })),
-          category: Diagnostics.Watch_and_Build_Modes,
-          description: Diagnostics.Specify_how_directories_are_watched_on_systems_that_lack_recursive_file_watching_functionality,
-          defaultValueDescription: 0 /* UseFsEvents */
-        },
-        {
-          name: "fallbackPolling",
-          type: new Map(Object.entries({
-            fixedinterval: 0 /* FixedInterval */,
-            priorityinterval: 1 /* PriorityInterval */,
-            dynamicpriority: 2 /* DynamicPriority */,
-            fixedchunksize: 3 /* FixedChunkSize */
-          })),
-          category: Diagnostics.Watch_and_Build_Modes,
-          description: Diagnostics.Specify_what_approach_the_watcher_should_use_if_the_system_runs_out_of_native_file_watchers,
-          defaultValueDescription: 1 /* PriorityInterval */
-        },
-        {
-          name: "synchronousWatchDirectory",
-          type: "boolean",
-          category: Diagnostics.Watch_and_Build_Modes,
-          description: Diagnostics.Synchronously_call_callbacks_and_update_the_state_of_directory_watchers_on_platforms_that_don_t_support_recursive_watching_natively,
-          defaultValueDescription: false
-        },
-        {
-          name: "excludeDirectories",
-          type: "list",
-          element: {
-            name: "excludeDirectory",
-            type: "string",
-            isFilePath: true,
-            extraValidation: specToDiagnostic
-          },
-          category: Diagnostics.Watch_and_Build_Modes,
-          description: Diagnostics.Remove_a_list_of_directories_from_the_watch_process
-        },
-        {
-          name: "excludeFiles",
-          type: "list",
-          element: {
-            name: "excludeFile",
-            type: "string",
-            isFilePath: true,
-            extraValidation: specToDiagnostic
-          },
-          category: Diagnostics.Watch_and_Build_Modes,
-          description: Diagnostics.Remove_a_list_of_files_from_the_watch_mode_s_processing
-        }
-      ];
-      commonOptionsWithBuild = [
-        {
-          name: "help",
-          shortName: "h",
-          type: "boolean",
-          showInSimplifiedHelpView: true,
-          isCommandLineOnly: true,
-          category: Diagnostics.Command_line_Options,
-          description: Diagnostics.Print_this_message,
-          defaultValueDescription: false
-        },
-        {
-          name: "help",
-          shortName: "?",
-          type: "boolean",
-          isCommandLineOnly: true,
-          category: Diagnostics.Command_line_Options,
-          defaultValueDescription: false
-        },
-        {
-          name: "watch",
-          shortName: "w",
-          type: "boolean",
-          showInSimplifiedHelpView: true,
-          isCommandLineOnly: true,
-          category: Diagnostics.Command_line_Options,
-          description: Diagnostics.Watch_input_files,
-          defaultValueDescription: false
-        },
-        {
-          name: "preserveWatchOutput",
-          type: "boolean",
-          showInSimplifiedHelpView: false,
-          category: Diagnostics.Output_Formatting,
-          description: Diagnostics.Disable_wiping_the_console_in_watch_mode,
-          defaultValueDescription: false
-        },
-        {
-          name: "listFiles",
-          type: "boolean",
-          category: Diagnostics.Compiler_Diagnostics,
-          description: Diagnostics.Print_all_of_the_files_read_during_the_compilation,
-          defaultValueDescription: false
-        },
-        {
-          name: "explainFiles",
-          type: "boolean",
-          category: Diagnostics.Compiler_Diagnostics,
-          description: Diagnostics.Print_files_read_during_the_compilation_including_why_it_was_included,
-          defaultValueDescription: false
-        },
-        {
-          name: "listEmittedFiles",
-          type: "boolean",
-          category: Diagnostics.Compiler_Diagnostics,
-          description: Diagnostics.Print_the_names_of_emitted_files_after_a_compilation,
-          defaultValueDescription: false
-        },
-        {
-          name: "pretty",
-          type: "boolean",
-          showInSimplifiedHelpView: true,
-          category: Diagnostics.Output_Formatting,
-          description: Diagnostics.Enable_color_and_formatting_in_TypeScript_s_output_to_make_compiler_errors_easier_to_read,
-          defaultValueDescription: true
-        },
-        {
-          name: "traceResolution",
-          type: "boolean",
-          category: Diagnostics.Compiler_Diagnostics,
-          description: Diagnostics.Log_paths_used_during_the_moduleResolution_process,
-          defaultValueDescription: false
-        },
-        {
-          name: "diagnostics",
-          type: "boolean",
-          category: Diagnostics.Compiler_Diagnostics,
-          description: Diagnostics.Output_compiler_performance_information_after_building,
-          defaultValueDescription: false
-        },
-        {
-          name: "extendedDiagnostics",
-          type: "boolean",
-          category: Diagnostics.Compiler_Diagnostics,
-          description: Diagnostics.Output_more_detailed_compiler_performance_information_after_building,
-          defaultValueDescription: false
-        },
-        {
-          name: "generateCpuProfile",
-          type: "string",
-          isFilePath: true,
-          paramType: Diagnostics.FILE_OR_DIRECTORY,
-          category: Diagnostics.Compiler_Diagnostics,
-          description: Diagnostics.Emit_a_v8_CPU_profile_of_the_compiler_run_for_debugging,
-          defaultValueDescription: "profile.cpuprofile"
-        },
-        {
-          name: "generateTrace",
-          type: "string",
-          isFilePath: true,
-          isCommandLineOnly: true,
-          paramType: Diagnostics.DIRECTORY,
-          category: Diagnostics.Compiler_Diagnostics,
-          description: Diagnostics.Generates_an_event_trace_and_a_list_of_types
-        },
-        {
-          name: "incremental",
-          shortName: "i",
-          type: "boolean",
-          category: Diagnostics.Projects,
-          description: Diagnostics.Save_tsbuildinfo_files_to_allow_for_incremental_compilation_of_projects,
-          transpileOptionValue: void 0,
-          defaultValueDescription: Diagnostics.false_unless_composite_is_set
-        },
-        {
-          name: "declaration",
-          shortName: "d",
-          type: "boolean",
-          // Not setting affectsEmit because we calculate this flag might not affect full emit
-          affectsBuildInfo: true,
-          showInSimplifiedHelpView: true,
-          category: Diagnostics.Emit,
-          transpileOptionValue: void 0,
-          description: Diagnostics.Generate_d_ts_files_from_TypeScript_and_JavaScript_files_in_your_project,
-          defaultValueDescription: Diagnostics.false_unless_composite_is_set
-        },
-        {
-          name: "declarationMap",
-          type: "boolean",
-          // Not setting affectsEmit because we calculate this flag might not affect full emit
-          affectsBuildInfo: true,
-          showInSimplifiedHelpView: true,
-          category: Diagnostics.Emit,
-          transpileOptionValue: void 0,
-          defaultValueDescription: false,
-          description: Diagnostics.Create_sourcemaps_for_d_ts_files
-        },
-        {
-          name: "emitDeclarationOnly",
-          type: "boolean",
-          // Not setting affectsEmit because we calculate this flag might not affect full emit
-          affectsBuildInfo: true,
-          showInSimplifiedHelpView: true,
-          category: Diagnostics.Emit,
-          description: Diagnostics.Only_output_d_ts_files_and_not_JavaScript_files,
-          transpileOptionValue: void 0,
-          defaultValueDescription: false
-        },
-        {
-          name: "sourceMap",
-          type: "boolean",
-          // Not setting affectsEmit because we calculate this flag might not affect full emit
-          affectsBuildInfo: true,
-          showInSimplifiedHelpView: true,
-          category: Diagnostics.Emit,
-          defaultValueDescription: false,
-          description: Diagnostics.Create_source_map_files_for_emitted_JavaScript_files
-        },
-        {
-          name: "inlineSourceMap",
-          type: "boolean",
-          // Not setting affectsEmit because we calculate this flag might not affect full emit
-          affectsBuildInfo: true,
-          category: Diagnostics.Emit,
-          description: Diagnostics.Include_sourcemap_files_inside_the_emitted_JavaScript,
-          defaultValueDescription: false
-        },
-        {
-          name: "assumeChangesOnlyAffectDirectDependencies",
-          type: "boolean",
-          affectsSemanticDiagnostics: true,
-          affectsEmit: true,
-          affectsBuildInfo: true,
-          category: Diagnostics.Watch_and_Build_Modes,
-          description: Diagnostics.Have_recompiles_in_projects_that_use_incremental_and_watch_mode_assume_that_changes_within_a_file_will_only_affect_files_directly_depending_on_it,
-          defaultValueDescription: false
-        },
-        {
-          name: "locale",
-          type: "string",
-          category: Diagnostics.Command_line_Options,
-          isCommandLineOnly: true,
-          description: Diagnostics.Set_the_language_of_the_messaging_from_TypeScript_This_does_not_affect_emit,
-          defaultValueDescription: Diagnostics.Platform_specific
-        }
-      ];
-      targetOptionDeclaration = {
-        name: "target",
-        shortName: "t",
-        type: new Map(Object.entries({
-          es3: 0 /* ES3 */,
-          es5: 1 /* ES5 */,
-          es6: 2 /* ES2015 */,
-          es2015: 2 /* ES2015 */,
-          es2016: 3 /* ES2016 */,
-          es2017: 4 /* ES2017 */,
-          es2018: 5 /* ES2018 */,
-          es2019: 6 /* ES2019 */,
-          es2020: 7 /* ES2020 */,
-          es2021: 8 /* ES2021 */,
-          es2022: 9 /* ES2022 */,
-          esnext: 99 /* ESNext */
-        })),
-        affectsSourceFile: true,
-        affectsModuleResolution: true,
-        affectsEmit: true,
-        affectsBuildInfo: true,
-        paramType: Diagnostics.VERSION,
-        showInSimplifiedHelpView: true,
-        category: Diagnostics.Language_and_Environment,
-        description: Diagnostics.Set_the_JavaScript_language_version_for_emitted_JavaScript_and_include_compatible_library_declarations,
-        defaultValueDescription: 1 /* ES5 */
-      };
-      moduleOptionDeclaration = {
-        name: "module",
-        shortName: "m",
-        type: new Map(Object.entries({
-          none: 0 /* None */,
-          commonjs: 1 /* CommonJS */,
-          amd: 2 /* AMD */,
-          system: 4 /* System */,
-          umd: 3 /* UMD */,
-          es6: 5 /* ES2015 */,
-          es2015: 5 /* ES2015 */,
-          es2020: 6 /* ES2020 */,
-          es2022: 7 /* ES2022 */,
-          esnext: 99 /* ESNext */,
-          node16: 100 /* Node16 */,
-          nodenext: 199 /* NodeNext */
-        })),
-        affectsModuleResolution: true,
-        affectsEmit: true,
-        affectsBuildInfo: true,
-        paramType: Diagnostics.KIND,
-        showInSimplifiedHelpView: true,
-        category: Diagnostics.Modules,
-        description: Diagnostics.Specify_what_module_code_is_generated,
-        defaultValueDescription: void 0
-      };
-      commandOptionsWithoutBuild = [
-        // CommandLine only options
-        {
-          name: "all",
-          type: "boolean",
-          showInSimplifiedHelpView: true,
-          category: Diagnostics.Command_line_Options,
-          description: Diagnostics.Show_all_compiler_options,
-          defaultValueDescription: false
-        },
-        {
-          name: "version",
-          shortName: "v",
-          type: "boolean",
-          showInSimplifiedHelpView: true,
-          category: Diagnostics.Command_line_Options,
-          description: Diagnostics.Print_the_compiler_s_version,
-          defaultValueDescription: false
-        },
-        {
-          name: "init",
-          type: "boolean",
-          showInSimplifiedHelpView: true,
-          category: Diagnostics.Command_line_Options,
-          description: Diagnostics.Initializes_a_TypeScript_project_and_creates_a_tsconfig_json_file,
-          defaultValueDescription: false
-        },
-        {
-          name: "project",
-          shortName: "p",
-          type: "string",
-          isFilePath: true,
-          showInSimplifiedHelpView: true,
-          category: Diagnostics.Command_line_Options,
-          paramType: Diagnostics.FILE_OR_DIRECTORY,
-          description: Diagnostics.Compile_the_project_given_the_path_to_its_configuration_file_or_to_a_folder_with_a_tsconfig_json
-        },
-        {
-          name: "build",
-          type: "boolean",
-          shortName: "b",
-          showInSimplifiedHelpView: true,
-          category: Diagnostics.Command_line_Options,
-          description: Diagnostics.Build_one_or_more_projects_and_their_dependencies_if_out_of_date,
-          defaultValueDescription: false
-        },
-        {
-          name: "showConfig",
-          type: "boolean",
-          showInSimplifiedHelpView: true,
-          category: Diagnostics.Command_line_Options,
-          isCommandLineOnly: true,
-          description: Diagnostics.Print_the_final_configuration_instead_of_building,
-          defaultValueDescription: false
-        },
-        {
-          name: "listFilesOnly",
-          type: "boolean",
-          category: Diagnostics.Command_line_Options,
-          isCommandLineOnly: true,
-          description: Diagnostics.Print_names_of_files_that_are_part_of_the_compilation_and_then_stop_processing,
-          defaultValueDescription: false
-        },
-        // Basic
-        targetOptionDeclaration,
-        moduleOptionDeclaration,
-        {
-          name: "lib",
-          type: "list",
-          element: {
-            name: "lib",
-            type: libMap,
-            defaultValueDescription: void 0
-          },
-          affectsProgramStructure: true,
-          showInSimplifiedHelpView: true,
-          category: Diagnostics.Language_and_Environment,
-          description: Diagnostics.Specify_a_set_of_bundled_library_declaration_files_that_describe_the_target_runtime_environment,
-          transpileOptionValue: void 0
-        },
-        {
-          name: "allowJs",
-          type: "boolean",
-          affectsModuleResolution: true,
-          showInSimplifiedHelpView: true,
-          category: Diagnostics.JavaScript_Support,
-          description: Diagnostics.Allow_JavaScript_files_to_be_a_part_of_your_program_Use_the_checkJS_option_to_get_errors_from_these_files,
-          defaultValueDescription: false
-        },
-        {
-          name: "checkJs",
-          type: "boolean",
-          showInSimplifiedHelpView: true,
-          category: Diagnostics.JavaScript_Support,
-          description: Diagnostics.Enable_error_reporting_in_type_checked_JavaScript_files,
-          defaultValueDescription: false
-        },
-        {
-          name: "jsx",
-          type: jsxOptionMap,
-          affectsSourceFile: true,
-          affectsEmit: true,
-          affectsBuildInfo: true,
-          affectsModuleResolution: true,
-          paramType: Diagnostics.KIND,
-          showInSimplifiedHelpView: true,
-          category: Diagnostics.Language_and_Environment,
-          description: Diagnostics.Specify_what_JSX_code_is_generated,
-          defaultValueDescription: void 0
-        },
-        {
-          name: "outFile",
-          type: "string",
-          affectsEmit: true,
-          affectsBuildInfo: true,
-          affectsDeclarationPath: true,
-          isFilePath: true,
-          paramType: Diagnostics.FILE,
-          showInSimplifiedHelpView: true,
-          category: Diagnostics.Emit,
-          description: Diagnostics.Specify_a_file_that_bundles_all_outputs_into_one_JavaScript_file_If_declaration_is_true_also_designates_a_file_that_bundles_all_d_ts_output,
-          transpileOptionValue: void 0
-        },
-        {
-          name: "outDir",
-          type: "string",
-          affectsEmit: true,
-          affectsBuildInfo: true,
-          affectsDeclarationPath: true,
-          isFilePath: true,
-          paramType: Diagnostics.DIRECTORY,
-          showInSimplifiedHelpView: true,
-          category: Diagnostics.Emit,
-          description: Diagnostics.Specify_an_output_folder_for_all_emitted_files
-        },
-        {
-          name: "rootDir",
-          type: "string",
-          affectsEmit: true,
-          affectsBuildInfo: true,
-          affectsDeclarationPath: true,
-          isFilePath: true,
-          paramType: Diagnostics.LOCATION,
-          category: Diagnostics.Modules,
-          description: Diagnostics.Specify_the_root_folder_within_your_source_files,
-          defaultValueDescription: Diagnostics.Computed_from_the_list_of_input_files
-        },
-        {
-          name: "composite",
-          type: "boolean",
-          // Not setting affectsEmit because we calculate this flag might not affect full emit
-          affectsBuildInfo: true,
-          isTSConfigOnly: true,
-          category: Diagnostics.Projects,
-          transpileOptionValue: void 0,
-          defaultValueDescription: false,
-          description: Diagnostics.Enable_constraints_that_allow_a_TypeScript_project_to_be_used_with_project_references
-        },
-        {
-          name: "tsBuildInfoFile",
-          type: "string",
-          affectsEmit: true,
-          affectsBuildInfo: true,
-          isFilePath: true,
-          paramType: Diagnostics.FILE,
-          category: Diagnostics.Projects,
-          transpileOptionValue: void 0,
-          defaultValueDescription: ".tsbuildinfo",
-          description: Diagnostics.Specify_the_path_to_tsbuildinfo_incremental_compilation_file
-        },
-        {
-          name: "removeComments",
-          type: "boolean",
-          affectsEmit: true,
-          affectsBuildInfo: true,
-          showInSimplifiedHelpView: true,
-          category: Diagnostics.Emit,
-          defaultValueDescription: false,
-          description: Diagnostics.Disable_emitting_comments
-        },
-        {
-          name: "noEmit",
-          type: "boolean",
-          showInSimplifiedHelpView: true,
-          category: Diagnostics.Emit,
-          description: Diagnostics.Disable_emitting_files_from_a_compilation,
-          transpileOptionValue: void 0,
-          defaultValueDescription: false
-        },
-        {
-          name: "importHelpers",
-          type: "boolean",
-          affectsEmit: true,
-          affectsBuildInfo: true,
-          category: Diagnostics.Emit,
-          description: Diagnostics.Allow_importing_helper_functions_from_tslib_once_per_project_instead_of_including_them_per_file,
-          defaultValueDescription: false
-        },
-        {
-          name: "importsNotUsedAsValues",
-          type: new Map(Object.entries({
-            remove: 0 /* Remove */,
-            preserve: 1 /* Preserve */,
-            error: 2 /* Error */
-          })),
-          affectsEmit: true,
-          affectsSemanticDiagnostics: true,
-          affectsBuildInfo: true,
-          category: Diagnostics.Emit,
-          description: Diagnostics.Specify_emit_Slashchecking_behavior_for_imports_that_are_only_used_for_types,
-          defaultValueDescription: 0 /* Remove */
-        },
-        {
-          name: "downlevelIteration",
-          type: "boolean",
-          affectsEmit: true,
-          affectsBuildInfo: true,
-          category: Diagnostics.Emit,
-          description: Diagnostics.Emit_more_compliant_but_verbose_and_less_performant_JavaScript_for_iteration,
-          defaultValueDescription: false
-        },
-        {
-          name: "isolatedModules",
-          type: "boolean",
-          category: Diagnostics.Interop_Constraints,
-          description: Diagnostics.Ensure_that_each_file_can_be_safely_transpiled_without_relying_on_other_imports,
-          transpileOptionValue: true,
-          defaultValueDescription: false
-        },
-        {
-          name: "verbatimModuleSyntax",
-          type: "boolean",
-          category: Diagnostics.Interop_Constraints,
-          description: Diagnostics.Do_not_transform_or_elide_any_imports_or_exports_not_marked_as_type_only_ensuring_they_are_written_in_the_output_file_s_format_based_on_the_module_setting,
-          defaultValueDescription: false
-        },
-        // Strict Type Checks
-        {
-          name: "strict",
-          type: "boolean",
-          // Though this affects semantic diagnostics, affectsSemanticDiagnostics is not set here
-          // The value of each strictFlag depends on own strictFlag value or this and never accessed directly.
-          // But we need to store `strict` in builf info, even though it won't be examined directly, so that the
-          // flags it controls (e.g. `strictNullChecks`) will be retrieved correctly
-          affectsBuildInfo: true,
-          showInSimplifiedHelpView: true,
-          category: Diagnostics.Type_Checking,
-          description: Diagnostics.Enable_all_strict_type_checking_options,
-          defaultValueDescription: false
-        },
-        {
-          name: "noImplicitAny",
-          type: "boolean",
-          affectsSemanticDiagnostics: true,
-          affectsBuildInfo: true,
-          strictFlag: true,
-          category: Diagnostics.Type_Checking,
-          description: Diagnostics.Enable_error_reporting_for_expressions_and_declarations_with_an_implied_any_type,
-          defaultValueDescription: Diagnostics.false_unless_strict_is_set
-        },
-        {
-          name: "strictNullChecks",
-          type: "boolean",
-          affectsSemanticDiagnostics: true,
-          affectsBuildInfo: true,
-          strictFlag: true,
-          category: Diagnostics.Type_Checking,
-          description: Diagnostics.When_type_checking_take_into_account_null_and_undefined,
-          defaultValueDescription: Diagnostics.false_unless_strict_is_set
-        },
-        {
-          name: "strictFunctionTypes",
-          type: "boolean",
-          affectsSemanticDiagnostics: true,
-          affectsBuildInfo: true,
-          strictFlag: true,
-          category: Diagnostics.Type_Checking,
-          description: Diagnostics.When_assigning_functions_check_to_ensure_parameters_and_the_return_values_are_subtype_compatible,
-          defaultValueDescription: Diagnostics.false_unless_strict_is_set
-        },
-        {
-          name: "strictBindCallApply",
-          type: "boolean",
-          affectsSemanticDiagnostics: true,
-          affectsBuildInfo: true,
-          strictFlag: true,
-          category: Diagnostics.Type_Checking,
-          description: Diagnostics.Check_that_the_arguments_for_bind_call_and_apply_methods_match_the_original_function,
-          defaultValueDescription: Diagnostics.false_unless_strict_is_set
-        },
-        {
-          name: "strictPropertyInitialization",
-          type: "boolean",
-          affectsSemanticDiagnostics: true,
-          affectsBuildInfo: true,
-          strictFlag: true,
-          category: Diagnostics.Type_Checking,
-          description: Diagnostics.Check_for_class_properties_that_are_declared_but_not_set_in_the_constructor,
-          defaultValueDescription: Diagnostics.false_unless_strict_is_set
-        },
-        {
-          name: "noImplicitThis",
-          type: "boolean",
-          affectsSemanticDiagnostics: true,
-          affectsBuildInfo: true,
-          strictFlag: true,
-          category: Diagnostics.Type_Checking,
-          description: Diagnostics.Enable_error_reporting_when_this_is_given_the_type_any,
-          defaultValueDescription: Diagnostics.false_unless_strict_is_set
-        },
-        {
-          name: "useUnknownInCatchVariables",
-          type: "boolean",
-          affectsSemanticDiagnostics: true,
-          affectsBuildInfo: true,
-          strictFlag: true,
-          category: Diagnostics.Type_Checking,
-          description: Diagnostics.Default_catch_clause_variables_as_unknown_instead_of_any,
-          defaultValueDescription: false
-        },
-        {
-          name: "alwaysStrict",
-          type: "boolean",
-          affectsSourceFile: true,
-          affectsEmit: true,
-          affectsBuildInfo: true,
-          strictFlag: true,
-          category: Diagnostics.Type_Checking,
-          description: Diagnostics.Ensure_use_strict_is_always_emitted,
-          defaultValueDescription: Diagnostics.false_unless_strict_is_set
-        },
-        // Additional Checks
-        {
-          name: "noUnusedLocals",
-          type: "boolean",
-          affectsSemanticDiagnostics: true,
-          affectsBuildInfo: true,
-          category: Diagnostics.Type_Checking,
-          description: Diagnostics.Enable_error_reporting_when_local_variables_aren_t_read,
-          defaultValueDescription: false
-        },
-        {
-          name: "noUnusedParameters",
-          type: "boolean",
-          affectsSemanticDiagnostics: true,
-          affectsBuildInfo: true,
-          category: Diagnostics.Type_Checking,
-          description: Diagnostics.Raise_an_error_when_a_function_parameter_isn_t_read,
-          defaultValueDescription: false
-        },
-        {
-          name: "exactOptionalPropertyTypes",
-          type: "boolean",
-          affectsSemanticDiagnostics: true,
-          affectsBuildInfo: true,
-          category: Diagnostics.Type_Checking,
-          description: Diagnostics.Interpret_optional_property_types_as_written_rather_than_adding_undefined,
-          defaultValueDescription: false
-        },
-        {
-          name: "noImplicitReturns",
-          type: "boolean",
-          affectsSemanticDiagnostics: true,
-          affectsBuildInfo: true,
-          category: Diagnostics.Type_Checking,
-          description: Diagnostics.Enable_error_reporting_for_codepaths_that_do_not_explicitly_return_in_a_function,
-          defaultValueDescription: false
-        },
-        {
-          name: "noFallthroughCasesInSwitch",
-          type: "boolean",
-          affectsBindDiagnostics: true,
-          affectsSemanticDiagnostics: true,
-          affectsBuildInfo: true,
-          category: Diagnostics.Type_Checking,
-          description: Diagnostics.Enable_error_reporting_for_fallthrough_cases_in_switch_statements,
-          defaultValueDescription: false
-        },
-        {
-          name: "noUncheckedIndexedAccess",
-          type: "boolean",
-          affectsSemanticDiagnostics: true,
-          affectsBuildInfo: true,
-          category: Diagnostics.Type_Checking,
-          description: Diagnostics.Add_undefined_to_a_type_when_accessed_using_an_index,
-          defaultValueDescription: false
-        },
-        {
-          name: "noImplicitOverride",
-          type: "boolean",
-          affectsSemanticDiagnostics: true,
-          affectsBuildInfo: true,
-          category: Diagnostics.Type_Checking,
-          description: Diagnostics.Ensure_overriding_members_in_derived_classes_are_marked_with_an_override_modifier,
-          defaultValueDescription: false
-        },
-        {
-          name: "noPropertyAccessFromIndexSignature",
-          type: "boolean",
-          affectsSemanticDiagnostics: true,
-          affectsBuildInfo: true,
-          showInSimplifiedHelpView: false,
-          category: Diagnostics.Type_Checking,
-          description: Diagnostics.Enforces_using_indexed_accessors_for_keys_declared_using_an_indexed_type,
-          defaultValueDescription: false
-        },
-        // Module Resolution
-        {
-          name: "moduleResolution",
-          type: new Map(Object.entries({
-            // N.B. The first entry specifies the value shown in `tsc --init`
-            node10: 2 /* Node10 */,
-            node: 2 /* Node10 */,
-            classic: 1 /* Classic */,
-            node16: 3 /* Node16 */,
-            nodenext: 99 /* NodeNext */,
-            bundler: 100 /* Bundler */
-          })),
-          deprecatedKeys: /* @__PURE__ */ new Set(["node"]),
-          affectsModuleResolution: true,
-          paramType: Diagnostics.STRATEGY,
-          category: Diagnostics.Modules,
-          description: Diagnostics.Specify_how_TypeScript_looks_up_a_file_from_a_given_module_specifier,
-          defaultValueDescription: Diagnostics.module_AMD_or_UMD_or_System_or_ES6_then_Classic_Otherwise_Node
-        },
-        {
-          name: "baseUrl",
-          type: "string",
-          affectsModuleResolution: true,
-          isFilePath: true,
-          category: Diagnostics.Modules,
-          description: Diagnostics.Specify_the_base_directory_to_resolve_non_relative_module_names
-        },
-        {
-          // this option can only be specified in tsconfig.json
-          // use type = object to copy the value as-is
-          name: "paths",
-          type: "object",
-          affectsModuleResolution: true,
-          isTSConfigOnly: true,
-          category: Diagnostics.Modules,
-          description: Diagnostics.Specify_a_set_of_entries_that_re_map_imports_to_additional_lookup_locations,
-          transpileOptionValue: void 0
-        },
-        {
-          // this option can only be specified in tsconfig.json
-          // use type = object to copy the value as-is
-          name: "rootDirs",
-          type: "list",
-          isTSConfigOnly: true,
-          element: {
-            name: "rootDirs",
-            type: "string",
-            isFilePath: true
-          },
-          affectsModuleResolution: true,
-          category: Diagnostics.Modules,
-          description: Diagnostics.Allow_multiple_folders_to_be_treated_as_one_when_resolving_modules,
-          transpileOptionValue: void 0,
-          defaultValueDescription: Diagnostics.Computed_from_the_list_of_input_files
-        },
-        {
-          name: "typeRoots",
-          type: "list",
-          element: {
-            name: "typeRoots",
-            type: "string",
-            isFilePath: true
-          },
-          affectsModuleResolution: true,
-          category: Diagnostics.Modules,
-          description: Diagnostics.Specify_multiple_folders_that_act_like_Slashnode_modules_Slash_types
-        },
-        {
-          name: "types",
-          type: "list",
-          element: {
-            name: "types",
-            type: "string"
-          },
-          affectsProgramStructure: true,
-          showInSimplifiedHelpView: true,
-          category: Diagnostics.Modules,
-          description: Diagnostics.Specify_type_package_names_to_be_included_without_being_referenced_in_a_source_file,
-          transpileOptionValue: void 0
-        },
-        {
-          name: "allowSyntheticDefaultImports",
-          type: "boolean",
-          affectsSemanticDiagnostics: true,
-          affectsBuildInfo: true,
-          category: Diagnostics.Interop_Constraints,
-          description: Diagnostics.Allow_import_x_from_y_when_a_module_doesn_t_have_a_default_export,
-          defaultValueDescription: Diagnostics.module_system_or_esModuleInterop
-        },
-        {
-          name: "esModuleInterop",
-          type: "boolean",
-          affectsSemanticDiagnostics: true,
-          affectsEmit: true,
-          affectsBuildInfo: true,
-          showInSimplifiedHelpView: true,
-          category: Diagnostics.Interop_Constraints,
-          description: Diagnostics.Emit_additional_JavaScript_to_ease_support_for_importing_CommonJS_modules_This_enables_allowSyntheticDefaultImports_for_type_compatibility,
-          defaultValueDescription: false
-        },
-        {
-          name: "preserveSymlinks",
-          type: "boolean",
-          category: Diagnostics.Interop_Constraints,
-          description: Diagnostics.Disable_resolving_symlinks_to_their_realpath_This_correlates_to_the_same_flag_in_node,
-          defaultValueDescription: false
-        },
-        {
-          name: "allowUmdGlobalAccess",
-          type: "boolean",
-          affectsSemanticDiagnostics: true,
-          affectsBuildInfo: true,
-          category: Diagnostics.Modules,
-          description: Diagnostics.Allow_accessing_UMD_globals_from_modules,
-          defaultValueDescription: false
-        },
-        {
-          name: "moduleSuffixes",
-          type: "list",
-          element: {
-            name: "suffix",
-            type: "string"
-          },
-          listPreserveFalsyValues: true,
-          affectsModuleResolution: true,
-          category: Diagnostics.Modules,
-          description: Diagnostics.List_of_file_name_suffixes_to_search_when_resolving_a_module
-        },
-        {
-          name: "allowImportingTsExtensions",
-          type: "boolean",
-          affectsSemanticDiagnostics: true,
-          affectsBuildInfo: true,
-          category: Diagnostics.Modules,
-          description: Diagnostics.Allow_imports_to_include_TypeScript_file_extensions_Requires_moduleResolution_bundler_and_either_noEmit_or_emitDeclarationOnly_to_be_set,
-          defaultValueDescription: false,
-          transpileOptionValue: void 0
-        },
-        {
-          name: "resolvePackageJsonExports",
-          type: "boolean",
-          affectsModuleResolution: true,
-          category: Diagnostics.Modules,
-          description: Diagnostics.Use_the_package_json_exports_field_when_resolving_package_imports,
-          defaultValueDescription: Diagnostics.true_when_moduleResolution_is_node16_nodenext_or_bundler_otherwise_false
-        },
-        {
-          name: "resolvePackageJsonImports",
-          type: "boolean",
-          affectsModuleResolution: true,
-          category: Diagnostics.Modules,
-          description: Diagnostics.Use_the_package_json_imports_field_when_resolving_imports,
-          defaultValueDescription: Diagnostics.true_when_moduleResolution_is_node16_nodenext_or_bundler_otherwise_false
-        },
-        {
-          name: "customConditions",
-          type: "list",
-          element: {
-            name: "condition",
-            type: "string"
-          },
-          affectsModuleResolution: true,
-          category: Diagnostics.Modules,
-          description: Diagnostics.Conditions_to_set_in_addition_to_the_resolver_specific_defaults_when_resolving_imports
-        },
-        // Source Maps
-        {
-          name: "sourceRoot",
-          type: "string",
-          affectsEmit: true,
-          affectsBuildInfo: true,
-          paramType: Diagnostics.LOCATION,
-          category: Diagnostics.Emit,
-          description: Diagnostics.Specify_the_root_path_for_debuggers_to_find_the_reference_source_code
-        },
-        {
-          name: "mapRoot",
-          type: "string",
-          affectsEmit: true,
-          affectsBuildInfo: true,
-          paramType: Diagnostics.LOCATION,
-          category: Diagnostics.Emit,
-          description: Diagnostics.Specify_the_location_where_debugger_should_locate_map_files_instead_of_generated_locations
-        },
-        {
-          name: "inlineSources",
-          type: "boolean",
-          affectsEmit: true,
-          affectsBuildInfo: true,
-          category: Diagnostics.Emit,
-          description: Diagnostics.Include_source_code_in_the_sourcemaps_inside_the_emitted_JavaScript,
-          defaultValueDescription: false
-        },
-        // Experimental
-        {
-          name: "experimentalDecorators",
-          type: "boolean",
-          affectsEmit: true,
-          affectsSemanticDiagnostics: true,
-          affectsBuildInfo: true,
-          category: Diagnostics.Language_and_Environment,
-          description: Diagnostics.Enable_experimental_support_for_legacy_experimental_decorators,
-          defaultValueDescription: false
-        },
-        {
-          name: "emitDecoratorMetadata",
-          type: "boolean",
-          affectsSemanticDiagnostics: true,
-          affectsEmit: true,
-          affectsBuildInfo: true,
-          category: Diagnostics.Language_and_Environment,
-          description: Diagnostics.Emit_design_type_metadata_for_decorated_declarations_in_source_files,
-          defaultValueDescription: false
-        },
-        // Advanced
-        {
-          name: "jsxFactory",
-          type: "string",
-          category: Diagnostics.Language_and_Environment,
-          description: Diagnostics.Specify_the_JSX_factory_function_used_when_targeting_React_JSX_emit_e_g_React_createElement_or_h,
-          defaultValueDescription: "`React.createElement`"
-        },
-        {
-          name: "jsxFragmentFactory",
-          type: "string",
-          category: Diagnostics.Language_and_Environment,
-          description: Diagnostics.Specify_the_JSX_Fragment_reference_used_for_fragments_when_targeting_React_JSX_emit_e_g_React_Fragment_or_Fragment,
-          defaultValueDescription: "React.Fragment"
-        },
-        {
-          name: "jsxImportSource",
-          type: "string",
-          affectsSemanticDiagnostics: true,
-          affectsEmit: true,
-          affectsBuildInfo: true,
-          affectsModuleResolution: true,
-          category: Diagnostics.Language_and_Environment,
-          description: Diagnostics.Specify_module_specifier_used_to_import_the_JSX_factory_functions_when_using_jsx_Colon_react_jsx_Asterisk,
-          defaultValueDescription: "react"
-        },
-        {
-          name: "resolveJsonModule",
-          type: "boolean",
-          affectsModuleResolution: true,
-          category: Diagnostics.Modules,
-          description: Diagnostics.Enable_importing_json_files,
-          defaultValueDescription: false
-        },
-        {
-          name: "allowArbitraryExtensions",
-          type: "boolean",
-          affectsProgramStructure: true,
-          category: Diagnostics.Modules,
-          description: Diagnostics.Enable_importing_files_with_any_extension_provided_a_declaration_file_is_present,
-          defaultValueDescription: false
-        },
-        {
-          name: "out",
-          type: "string",
-          affectsEmit: true,
-          affectsBuildInfo: true,
-          affectsDeclarationPath: true,
-          isFilePath: false,
-          // This is intentionally broken to support compatability with existing tsconfig files
-          // for correct behaviour, please use outFile
-          category: Diagnostics.Backwards_Compatibility,
-          paramType: Diagnostics.FILE,
-          transpileOptionValue: void 0,
-          description: Diagnostics.Deprecated_setting_Use_outFile_instead
-        },
-        {
-          name: "reactNamespace",
-          type: "string",
-          affectsEmit: true,
-          affectsBuildInfo: true,
-          category: Diagnostics.Language_and_Environment,
-          description: Diagnostics.Specify_the_object_invoked_for_createElement_This_only_applies_when_targeting_react_JSX_emit,
-          defaultValueDescription: "`React`"
-        },
-        {
-          name: "skipDefaultLibCheck",
-          type: "boolean",
-          // We need to store these to determine whether `lib` files need to be rechecked
-          affectsBuildInfo: true,
-          category: Diagnostics.Completeness,
-          description: Diagnostics.Skip_type_checking_d_ts_files_that_are_included_with_TypeScript,
-          defaultValueDescription: false
-        },
-        {
-          name: "charset",
-          type: "string",
-          category: Diagnostics.Backwards_Compatibility,
-          description: Diagnostics.No_longer_supported_In_early_versions_manually_set_the_text_encoding_for_reading_files,
-          defaultValueDescription: "utf8"
-        },
-        {
-          name: "emitBOM",
-          type: "boolean",
-          affectsEmit: true,
-          affectsBuildInfo: true,
-          category: Diagnostics.Emit,
-          description: Diagnostics.Emit_a_UTF_8_Byte_Order_Mark_BOM_in_the_beginning_of_output_files,
-          defaultValueDescription: false
-        },
-        {
-          name: "newLine",
-          type: new Map(Object.entries({
-            crlf: 0 /* CarriageReturnLineFeed */,
-            lf: 1 /* LineFeed */
-          })),
-          affectsEmit: true,
-          affectsBuildInfo: true,
-          paramType: Diagnostics.NEWLINE,
-          category: Diagnostics.Emit,
-          description: Diagnostics.Set_the_newline_character_for_emitting_files,
-          defaultValueDescription: "lf"
-        },
-        {
-          name: "noErrorTruncation",
-          type: "boolean",
-          affectsSemanticDiagnostics: true,
-          affectsBuildInfo: true,
-          category: Diagnostics.Output_Formatting,
-          description: Diagnostics.Disable_truncating_types_in_error_messages,
-          defaultValueDescription: false
-        },
-        {
-          name: "noLib",
-          type: "boolean",
-          category: Diagnostics.Language_and_Environment,
-          affectsProgramStructure: true,
-          description: Diagnostics.Disable_including_any_library_files_including_the_default_lib_d_ts,
-          // We are not returning a sourceFile for lib file when asked by the program,
-          // so pass --noLib to avoid reporting a file not found error.
-          transpileOptionValue: true,
-          defaultValueDescription: false
-        },
-        {
-          name: "noResolve",
-          type: "boolean",
-          affectsModuleResolution: true,
-          category: Diagnostics.Modules,
-          description: Diagnostics.Disallow_import_s_require_s_or_reference_s_from_expanding_the_number_of_files_TypeScript_should_add_to_a_project,
-          // We are not doing a full typecheck, we are not resolving the whole context,
-          // so pass --noResolve to avoid reporting missing file errors.
-          transpileOptionValue: true,
-          defaultValueDescription: false
-        },
-        {
-          name: "stripInternal",
-          type: "boolean",
-          affectsEmit: true,
-          affectsBuildInfo: true,
-          category: Diagnostics.Emit,
-          description: Diagnostics.Disable_emitting_declarations_that_have_internal_in_their_JSDoc_comments,
-          defaultValueDescription: false
-        },
-        {
-          name: "disableSizeLimit",
-          type: "boolean",
-          affectsProgramStructure: true,
-          category: Diagnostics.Editor_Support,
-          description: Diagnostics.Remove_the_20mb_cap_on_total_source_code_size_for_JavaScript_files_in_the_TypeScript_language_server,
-          defaultValueDescription: false
-        },
-        {
-          name: "disableSourceOfProjectReferenceRedirect",
-          type: "boolean",
-          isTSConfigOnly: true,
-          category: Diagnostics.Projects,
-          description: Diagnostics.Disable_preferring_source_files_instead_of_declaration_files_when_referencing_composite_projects,
-          defaultValueDescription: false
-        },
-        {
-          name: "disableSolutionSearching",
-          type: "boolean",
-          isTSConfigOnly: true,
-          category: Diagnostics.Projects,
-          description: Diagnostics.Opt_a_project_out_of_multi_project_reference_checking_when_editing,
-          defaultValueDescription: false
-        },
-        {
-          name: "disableReferencedProjectLoad",
-          type: "boolean",
-          isTSConfigOnly: true,
-          category: Diagnostics.Projects,
-          description: Diagnostics.Reduce_the_number_of_projects_loaded_automatically_by_TypeScript,
-          defaultValueDescription: false
-        },
-        {
-          name: "noImplicitUseStrict",
-          type: "boolean",
-          affectsSemanticDiagnostics: true,
-          affectsBuildInfo: true,
-          category: Diagnostics.Backwards_Compatibility,
-          description: Diagnostics.Disable_adding_use_strict_directives_in_emitted_JavaScript_files,
-          defaultValueDescription: false
-        },
-        {
-          name: "noEmitHelpers",
-          type: "boolean",
-          affectsEmit: true,
-          affectsBuildInfo: true,
-          category: Diagnostics.Emit,
-          description: Diagnostics.Disable_generating_custom_helper_functions_like_extends_in_compiled_output,
-          defaultValueDescription: false
-        },
-        {
-          name: "noEmitOnError",
-          type: "boolean",
-          affectsEmit: true,
-          affectsBuildInfo: true,
-          category: Diagnostics.Emit,
-          transpileOptionValue: void 0,
-          description: Diagnostics.Disable_emitting_files_if_any_type_checking_errors_are_reported,
-          defaultValueDescription: false
-        },
-        {
-          name: "preserveConstEnums",
-          type: "boolean",
-          affectsEmit: true,
-          affectsBuildInfo: true,
-          category: Diagnostics.Emit,
-          description: Diagnostics.Disable_erasing_const_enum_declarations_in_generated_code,
-          defaultValueDescription: false
-        },
-        {
-          name: "declarationDir",
-          type: "string",
-          affectsEmit: true,
-          affectsBuildInfo: true,
-          affectsDeclarationPath: true,
-          isFilePath: true,
-          paramType: Diagnostics.DIRECTORY,
-          category: Diagnostics.Emit,
-          transpileOptionValue: void 0,
-          description: Diagnostics.Specify_the_output_directory_for_generated_declaration_files
-        },
-        {
-          name: "skipLibCheck",
-          type: "boolean",
-          // We need to store these to determine whether `lib` files need to be rechecked
-          affectsBuildInfo: true,
-          category: Diagnostics.Completeness,
-          description: Diagnostics.Skip_type_checking_all_d_ts_files,
-          defaultValueDescription: false
-        },
-        {
-          name: "allowUnusedLabels",
-          type: "boolean",
-          affectsBindDiagnostics: true,
-          affectsSemanticDiagnostics: true,
-          affectsBuildInfo: true,
-          category: Diagnostics.Type_Checking,
-          description: Diagnostics.Disable_error_reporting_for_unused_labels,
-          defaultValueDescription: void 0
-        },
-        {
-          name: "allowUnreachableCode",
-          type: "boolean",
-          affectsBindDiagnostics: true,
-          affectsSemanticDiagnostics: true,
-          affectsBuildInfo: true,
-          category: Diagnostics.Type_Checking,
-          description: Diagnostics.Disable_error_reporting_for_unreachable_code,
-          defaultValueDescription: void 0
-        },
-        {
-          name: "suppressExcessPropertyErrors",
-          type: "boolean",
-          affectsSemanticDiagnostics: true,
-          affectsBuildInfo: true,
-          category: Diagnostics.Backwards_Compatibility,
-          description: Diagnostics.Disable_reporting_of_excess_property_errors_during_the_creation_of_object_literals,
-          defaultValueDescription: false
-        },
-        {
-          name: "suppressImplicitAnyIndexErrors",
-          type: "boolean",
-          affectsSemanticDiagnostics: true,
-          affectsBuildInfo: true,
-          category: Diagnostics.Backwards_Compatibility,
-          description: Diagnostics.Suppress_noImplicitAny_errors_when_indexing_objects_that_lack_index_signatures,
-          defaultValueDescription: false
-        },
-        {
-          name: "forceConsistentCasingInFileNames",
-          type: "boolean",
-          affectsModuleResolution: true,
-          category: Diagnostics.Interop_Constraints,
-          description: Diagnostics.Ensure_that_casing_is_correct_in_imports,
-          defaultValueDescription: true
-        },
-        {
-          name: "maxNodeModuleJsDepth",
-          type: "number",
-          affectsModuleResolution: true,
-          category: Diagnostics.JavaScript_Support,
-          description: Diagnostics.Specify_the_maximum_folder_depth_used_for_checking_JavaScript_files_from_node_modules_Only_applicable_with_allowJs,
-          defaultValueDescription: 0
-        },
-        {
-          name: "noStrictGenericChecks",
-          type: "boolean",
-          affectsSemanticDiagnostics: true,
-          affectsBuildInfo: true,
-          category: Diagnostics.Backwards_Compatibility,
-          description: Diagnostics.Disable_strict_checking_of_generic_signatures_in_function_types,
-          defaultValueDescription: false
-        },
-        {
-          name: "useDefineForClassFields",
-          type: "boolean",
-          affectsSemanticDiagnostics: true,
-          affectsEmit: true,
-          affectsBuildInfo: true,
-          category: Diagnostics.Language_and_Environment,
-          description: Diagnostics.Emit_ECMAScript_standard_compliant_class_fields,
-          defaultValueDescription: Diagnostics.true_for_ES2022_and_above_including_ESNext
-        },
-        {
-          name: "preserveValueImports",
-          type: "boolean",
-          affectsEmit: true,
-          affectsBuildInfo: true,
-          category: Diagnostics.Emit,
-          description: Diagnostics.Preserve_unused_imported_values_in_the_JavaScript_output_that_would_otherwise_be_removed,
-          defaultValueDescription: false
-        },
-        {
-          name: "keyofStringsOnly",
-          type: "boolean",
-          category: Diagnostics.Backwards_Compatibility,
-          description: Diagnostics.Make_keyof_only_return_strings_instead_of_string_numbers_or_symbols_Legacy_option,
-          defaultValueDescription: false
-        },
-        {
-          // A list of plugins to load in the language service
-          name: "plugins",
-          type: "list",
-          isTSConfigOnly: true,
-          element: {
-            name: "plugin",
-            type: "object"
-          },
-          description: Diagnostics.Specify_a_list_of_language_service_plugins_to_include,
-          category: Diagnostics.Editor_Support
-        },
-        {
-          name: "moduleDetection",
-          type: new Map(Object.entries({
-            auto: 2 /* Auto */,
-            legacy: 1 /* Legacy */,
-            force: 3 /* Force */
-          })),
-          affectsModuleResolution: true,
-          description: Diagnostics.Control_what_method_is_used_to_detect_module_format_JS_files,
-          category: Diagnostics.Language_and_Environment,
-          defaultValueDescription: Diagnostics.auto_Colon_Treat_files_with_imports_exports_import_meta_jsx_with_jsx_Colon_react_jsx_or_esm_format_with_module_Colon_node16_as_modules
-        },
-        {
-          name: "ignoreDeprecations",
-          type: "string",
-          defaultValueDescription: void 0
-        }
-      ];
-      optionDeclarations = [
-        ...commonOptionsWithBuild,
-        ...commandOptionsWithoutBuild
-      ];
-      semanticDiagnosticsOptionDeclarations = optionDeclarations.filter((option) => !!option.affectsSemanticDiagnostics);
-      affectsEmitOptionDeclarations = optionDeclarations.filter((option) => !!option.affectsEmit);
-      affectsDeclarationPathOptionDeclarations = optionDeclarations.filter((option) => !!option.affectsDeclarationPath);
-      moduleResolutionOptionDeclarations = optionDeclarations.filter((option) => !!option.affectsModuleResolution);
-      sourceFileAffectingCompilerOptions = optionDeclarations.filter((option) => !!option.affectsSourceFile || !!option.affectsModuleResolution || !!option.affectsBindDiagnostics);
-      optionsAffectingProgramStructure = optionDeclarations.filter((option) => !!option.affectsProgramStructure);
-      transpileOptionValueCompilerOptions = optionDeclarations.filter((option) => hasProperty(option, "transpileOptionValue"));
-      optionsForBuild = [
-        {
-          name: "verbose",
-          shortName: "v",
-          category: Diagnostics.Command_line_Options,
-          description: Diagnostics.Enable_verbose_logging,
-          type: "boolean",
-          defaultValueDescription: false
-        },
-        {
-          name: "dry",
-          shortName: "d",
-          category: Diagnostics.Command_line_Options,
-          description: Diagnostics.Show_what_would_be_built_or_deleted_if_specified_with_clean,
-          type: "boolean",
-          defaultValueDescription: false
-        },
-        {
-          name: "force",
-          shortName: "f",
-          category: Diagnostics.Command_line_Options,
-          description: Diagnostics.Build_all_projects_including_those_that_appear_to_be_up_to_date,
-          type: "boolean",
-          defaultValueDescription: false
-        },
-        {
-          name: "clean",
-          category: Diagnostics.Command_line_Options,
-          description: Diagnostics.Delete_the_outputs_of_all_projects,
-          type: "boolean",
-          defaultValueDescription: false
-        }
-      ];
-      buildOpts = [
-        ...commonOptionsWithBuild,
-        ...optionsForBuild
-      ];
-      typeAcquisitionDeclarations = [
-        {
-          name: "enable",
-          type: "boolean",
-          defaultValueDescription: false
-        },
-        {
-          name: "include",
-          type: "list",
-          element: {
-            name: "include",
-            type: "string"
-          }
-        },
-        {
-          name: "exclude",
-          type: "list",
-          element: {
-            name: "exclude",
-            type: "string"
-          }
-        },
-        {
-          name: "disableFilenameBasedTypeAcquisition",
-          type: "boolean",
-          defaultValueDescription: false
-        }
-      ];
-      compilerOptionsAlternateMode = {
-        diagnostic: Diagnostics.Compiler_option_0_may_only_be_used_with_build,
-        getOptionsNameMap: getBuildOptionsNameMap
-      };
-      defaultInitCompilerOptions = {
-        module: 1 /* CommonJS */,
-        target: 3 /* ES2016 */,
-        strict: true,
-        esModuleInterop: true,
-        forceConsistentCasingInFileNames: true,
-        skipLibCheck: true
-      };
-      compilerOptionsDidYouMeanDiagnostics = {
-        alternateMode: compilerOptionsAlternateMode,
-        getOptionsNameMap,
-        optionDeclarations,
-        unknownOptionDiagnostic: Diagnostics.Unknown_compiler_option_0,
-        unknownDidYouMeanDiagnostic: Diagnostics.Unknown_compiler_option_0_Did_you_mean_1,
-        optionTypeMismatchDiagnostic: Diagnostics.Compiler_option_0_expects_an_argument
-      };
-      buildOptionsAlternateMode = {
-        diagnostic: Diagnostics.Compiler_option_0_may_not_be_used_with_build,
-        getOptionsNameMap
-      };
-      buildOptionsDidYouMeanDiagnostics = {
-        alternateMode: buildOptionsAlternateMode,
-        getOptionsNameMap: getBuildOptionsNameMap,
-        optionDeclarations: buildOpts,
-        unknownOptionDiagnostic: Diagnostics.Unknown_build_option_0,
-        unknownDidYouMeanDiagnostic: Diagnostics.Unknown_build_option_0_Did_you_mean_1,
-        optionTypeMismatchDiagnostic: Diagnostics.Build_option_0_requires_a_value_of_type_1
-      };
-      typeAcquisitionDidYouMeanDiagnostics = {
-        optionDeclarations: typeAcquisitionDeclarations,
-        unknownOptionDiagnostic: Diagnostics.Unknown_type_acquisition_option_0,
-        unknownDidYouMeanDiagnostic: Diagnostics.Unknown_type_acquisition_option_0_Did_you_mean_1
-      };
-      watchOptionsDidYouMeanDiagnostics = {
-        getOptionsNameMap: getWatchOptionsNameMap,
-        optionDeclarations: optionsForWatch,
-        unknownOptionDiagnostic: Diagnostics.Unknown_watch_option_0,
-        unknownDidYouMeanDiagnostic: Diagnostics.Unknown_watch_option_0_Did_you_mean_1,
-        optionTypeMismatchDiagnostic: Diagnostics.Watch_option_0_requires_a_value_of_type_1
-      };
-      extendsOptionDeclaration = {
-        name: "extends",
-        type: "listOrElement",
-        element: {
-          name: "extends",
-          type: "string"
-        },
-        category: Diagnostics.File_Management,
-        disallowNullOrUndefined: true
-      };
-      compilerOptionsDeclaration = {
-        name: "compilerOptions",
-        type: "object",
-        elementOptions: getCommandLineCompilerOptionsMap(),
-        extraKeyDiagnostics: compilerOptionsDidYouMeanDiagnostics
-      };
-      watchOptionsDeclaration = {
-        name: "watchOptions",
-        type: "object",
-        elementOptions: getCommandLineWatchOptionsMap(),
-        extraKeyDiagnostics: watchOptionsDidYouMeanDiagnostics
-      };
-      typeAcquisitionDeclaration = {
-        name: "typeAcquisition",
-        type: "object",
-        elementOptions: getCommandLineTypeAcquisitionMap(),
-        extraKeyDiagnostics: typeAcquisitionDidYouMeanDiagnostics
-      };
-      defaultIncludeSpec = "**/*";
-      invalidTrailingRecursionPattern = /(^|\/)\*\*\/?$/;
-      wildcardDirectoryPattern = /^[^*?]*(?=\/[^/]*[*?])/;
-    }
-  });
-
-  // src/compiler/moduleNameResolver.ts
-  function trace(host) {
-    host.trace(formatMessage.apply(void 0, arguments));
-  }
-  function isTraceEnabled(compilerOptions, host) {
-    return !!compilerOptions.traceResolution && host.trace !== void 0;
-  }
-  function withPackageId(packageInfo, r) {
-    let packageId;
-    if (r && packageInfo) {
-      const packageJsonContent = packageInfo.contents.packageJsonContent;
-      if (typeof packageJsonContent.name === "string" && typeof packageJsonContent.version === "string") {
-        packageId = {
-          name: packageJsonContent.name,
-          subModuleName: r.path.slice(packageInfo.packageDirectory.length + directorySeparator.length),
-          version: packageJsonContent.version
-        };
-      }
-    }
-    return r && { path: r.path, extension: r.ext, packageId, resolvedUsingTsExtension: r.resolvedUsingTsExtension };
-  }
-  function noPackageId(r) {
-    return withPackageId(
-      /*packageInfo*/
-      void 0,
-      r
-    );
-  }
-  function removeIgnoredPackageId(r) {
-    if (r) {
-      Debug.assert(r.packageId === void 0);
-      return { path: r.path, ext: r.extension, resolvedUsingTsExtension: r.resolvedUsingTsExtension };
-    }
-  }
-  function formatExtensions(extensions) {
-    const result = [];
-    if (extensions & 1 /* TypeScript */)
-      result.push("TypeScript");
-    if (extensions & 2 /* JavaScript */)
-      result.push("JavaScript");
-    if (extensions & 4 /* Declaration */)
-      result.push("Declaration");
-    if (extensions & 8 /* Json */)
-      result.push("JSON");
-    return result.join(", ");
-  }
-  function resolvedTypeScriptOnly(resolved) {
-    if (!resolved) {
-      return void 0;
-    }
-    Debug.assert(extensionIsTS(resolved.extension));
-    return { fileName: resolved.path, packageId: resolved.packageId };
-  }
-  function createResolvedModuleWithFailedLookupLocationsHandlingSymlink(moduleName, resolved, isExternalLibraryImport, failedLookupLocations, affectingLocations, diagnostics, state, legacyResult) {
-    if (!state.resultFromCache && !state.compilerOptions.preserveSymlinks && resolved && isExternalLibraryImport && !resolved.originalPath && !isExternalModuleNameRelative(moduleName)) {
-      const { resolvedFileName, originalPath } = getOriginalAndResolvedFileName(resolved.path, state.host, state.traceEnabled);
-      if (originalPath)
-        resolved = { ...resolved, path: resolvedFileName, originalPath };
-    }
-    return createResolvedModuleWithFailedLookupLocations(
-      resolved,
-      isExternalLibraryImport,
-      failedLookupLocations,
-      affectingLocations,
-      diagnostics,
-      state.resultFromCache,
-      legacyResult
-    );
-  }
-  function createResolvedModuleWithFailedLookupLocations(resolved, isExternalLibraryImport, failedLookupLocations, affectingLocations, diagnostics, resultFromCache, legacyResult) {
-    if (resultFromCache) {
-      resultFromCache.failedLookupLocations = updateResolutionField(resultFromCache.failedLookupLocations, failedLookupLocations);
-      resultFromCache.affectingLocations = updateResolutionField(resultFromCache.affectingLocations, affectingLocations);
-      resultFromCache.resolutionDiagnostics = updateResolutionField(resultFromCache.resolutionDiagnostics, diagnostics);
-      return resultFromCache;
-    }
-    return {
-      resolvedModule: resolved && {
-        resolvedFileName: resolved.path,
-        originalPath: resolved.originalPath === true ? void 0 : resolved.originalPath,
-        extension: resolved.extension,
-        isExternalLibraryImport,
-        packageId: resolved.packageId,
-        resolvedUsingTsExtension: !!resolved.resolvedUsingTsExtension
-      },
-      failedLookupLocations: initializeResolutionField(failedLookupLocations),
-      affectingLocations: initializeResolutionField(affectingLocations),
-      resolutionDiagnostics: initializeResolutionField(diagnostics),
-      node10Result: legacyResult
-    };
-  }
-  function initializeResolutionField(value) {
-    return value.length ? value : void 0;
-  }
-  function updateResolutionField(to, value) {
-    if (!(value == null ? void 0 : value.length))
-      return to;
-    if (!(to == null ? void 0 : to.length))
-      return value;
-    to.push(...value);
-    return to;
-  }
-  function readPackageJsonField(jsonContent, fieldName, typeOfTag, state) {
-    if (!hasProperty(jsonContent, fieldName)) {
-      if (state.traceEnabled) {
-        trace(state.host, Diagnostics.package_json_does_not_have_a_0_field, fieldName);
-      }
-      return;
-    }
-    const value = jsonContent[fieldName];
-    if (typeof value !== typeOfTag || value === null) {
-      if (state.traceEnabled) {
-        trace(state.host, Diagnostics.Expected_type_of_0_field_in_package_json_to_be_1_got_2, fieldName, typeOfTag, value === null ? "null" : typeof value);
-      }
-      return;
-    }
-    return value;
-  }
-  function readPackageJsonPathField(jsonContent, fieldName, baseDirectory, state) {
-    const fileName = readPackageJsonField(jsonContent, fieldName, "string", state);
-    if (fileName === void 0) {
-      return;
-    }
-    if (!fileName) {
-      if (state.traceEnabled) {
-        trace(state.host, Diagnostics.package_json_had_a_falsy_0_field, fieldName);
-      }
-      return;
-    }
-    const path = normalizePath(combinePaths(baseDirectory, fileName));
-    if (state.traceEnabled) {
-      trace(state.host, Diagnostics.package_json_has_0_field_1_that_references_2, fieldName, fileName, path);
-    }
-    return path;
-  }
-  function readPackageJsonTypesFields(jsonContent, baseDirectory, state) {
-    return readPackageJsonPathField(jsonContent, "typings", baseDirectory, state) || readPackageJsonPathField(jsonContent, "types", baseDirectory, state);
-  }
-  function readPackageJsonTSConfigField(jsonContent, baseDirectory, state) {
-    return readPackageJsonPathField(jsonContent, "tsconfig", baseDirectory, state);
-  }
-  function readPackageJsonMainField(jsonContent, baseDirectory, state) {
-    return readPackageJsonPathField(jsonContent, "main", baseDirectory, state);
-  }
-  function readPackageJsonTypesVersionsField(jsonContent, state) {
-    const typesVersions = readPackageJsonField(jsonContent, "typesVersions", "object", state);
-    if (typesVersions === void 0)
-      return;
-    if (state.traceEnabled) {
-      trace(state.host, Diagnostics.package_json_has_a_typesVersions_field_with_version_specific_path_mappings);
-    }
-    return typesVersions;
-  }
-  function readPackageJsonTypesVersionPaths(jsonContent, state) {
-    const typesVersions = readPackageJsonTypesVersionsField(jsonContent, state);
-    if (typesVersions === void 0)
-      return;
-    if (state.traceEnabled) {
-      for (const key in typesVersions) {
-        if (hasProperty(typesVersions, key) && !VersionRange.tryParse(key)) {
-          trace(state.host, Diagnostics.package_json_has_a_typesVersions_entry_0_that_is_not_a_valid_semver_range, key);
-        }
-      }
-    }
-    const result = getPackageJsonTypesVersionsPaths(typesVersions);
-    if (!result) {
-      if (state.traceEnabled) {
-        trace(state.host, Diagnostics.package_json_does_not_have_a_typesVersions_entry_that_matches_version_0, versionMajorMinor);
-      }
-      return;
-    }
-    const { version: bestVersionKey, paths: bestVersionPaths } = result;
-    if (typeof bestVersionPaths !== "object") {
-      if (state.traceEnabled) {
-        trace(state.host, Diagnostics.Expected_type_of_0_field_in_package_json_to_be_1_got_2, `typesVersions['${bestVersionKey}']`, "object", typeof bestVersionPaths);
-      }
-      return;
-    }
-    return result;
-  }
-  function getPackageJsonTypesVersionsPaths(typesVersions) {
-    if (!typeScriptVersion)
-      typeScriptVersion = new Version(version);
-    for (const key in typesVersions) {
-      if (!hasProperty(typesVersions, key))
-        continue;
-      const keyRange = VersionRange.tryParse(key);
-      if (keyRange === void 0) {
-        continue;
-      }
-      if (keyRange.test(typeScriptVersion)) {
-        return { version: key, paths: typesVersions[key] };
-      }
-    }
-  }
-  function getEffectiveTypeRoots(options, host) {
-    if (options.typeRoots) {
-      return options.typeRoots;
-    }
-    let currentDirectory;
-    if (options.configFilePath) {
-      currentDirectory = getDirectoryPath(options.configFilePath);
-    } else if (host.getCurrentDirectory) {
-      currentDirectory = host.getCurrentDirectory();
-    }
-    if (currentDirectory !== void 0) {
-      return getDefaultTypeRoots(currentDirectory);
-    }
-  }
-  function getDefaultTypeRoots(currentDirectory) {
-    let typeRoots;
-    forEachAncestorDirectory(normalizePath(currentDirectory), (directory) => {
-      const atTypes = combinePaths(directory, nodeModulesAtTypes);
-      (typeRoots ?? (typeRoots = [])).push(atTypes);
-    });
-    return typeRoots;
-  }
-  function arePathsEqual(path1, path2, host) {
-    const useCaseSensitiveFileNames = typeof host.useCaseSensitiveFileNames === "function" ? host.useCaseSensitiveFileNames() : host.useCaseSensitiveFileNames;
-    return comparePaths(path1, path2, !useCaseSensitiveFileNames) === 0 /* EqualTo */;
-  }
-  function getOriginalAndResolvedFileName(fileName, host, traceEnabled) {
-    const resolvedFileName = realPath(fileName, host, traceEnabled);
-    const pathsAreEqual = arePathsEqual(fileName, resolvedFileName, host);
-    return {
-      // If the fileName and realpath are differing only in casing prefer fileName so that we can issue correct errors for casing under forceConsistentCasingInFileNames
-      resolvedFileName: pathsAreEqual ? fileName : resolvedFileName,
-      originalPath: pathsAreEqual ? void 0 : fileName
-    };
-  }
-  function getCandidateFromTypeRoot(typeRoot, typeReferenceDirectiveName, moduleResolutionState) {
-    const nameForLookup = endsWith(typeRoot, "/node_modules/@types") || endsWith(typeRoot, "/node_modules/@types/") ? mangleScopedPackageNameWithTrace(typeReferenceDirectiveName, moduleResolutionState) : typeReferenceDirectiveName;
-    return combinePaths(typeRoot, nameForLookup);
-  }
-  function resolveTypeReferenceDirective(typeReferenceDirectiveName, containingFile, options, host, redirectedReference, cache, resolutionMode) {
-    Debug.assert(typeof typeReferenceDirectiveName === "string", "Non-string value passed to `ts.resolveTypeReferenceDirective`, likely by a wrapping package working with an outdated `resolveTypeReferenceDirectives` signature. This is probably not a problem in TS itself.");
-    const traceEnabled = isTraceEnabled(options, host);
-    if (redirectedReference) {
-      options = redirectedReference.commandLine.options;
-    }
-    const containingDirectory = containingFile ? getDirectoryPath(containingFile) : void 0;
-    let result = containingDirectory ? cache == null ? void 0 : cache.getFromDirectoryCache(typeReferenceDirectiveName, resolutionMode, containingDirectory, redirectedReference) : void 0;
-    if (!result && containingDirectory && !isExternalModuleNameRelative(typeReferenceDirectiveName)) {
-      result = cache == null ? void 0 : cache.getFromNonRelativeNameCache(typeReferenceDirectiveName, resolutionMode, containingDirectory, redirectedReference);
-    }
-    if (result) {
-      if (traceEnabled) {
-        trace(host, Diagnostics.Resolving_type_reference_directive_0_containing_file_1, typeReferenceDirectiveName, containingFile);
-        if (redirectedReference)
-          trace(host, Diagnostics.Using_compiler_options_of_project_reference_redirect_0, redirectedReference.sourceFile.fileName);
-        trace(host, Diagnostics.Resolution_for_type_reference_directive_0_was_found_in_cache_from_location_1, typeReferenceDirectiveName, containingDirectory);
-        traceResult(result);
-      }
-      return result;
-    }
-    const typeRoots = getEffectiveTypeRoots(options, host);
-    if (traceEnabled) {
-      if (containingFile === void 0) {
-        if (typeRoots === void 0) {
-          trace(host, Diagnostics.Resolving_type_reference_directive_0_containing_file_not_set_root_directory_not_set, typeReferenceDirectiveName);
-        } else {
-          trace(host, Diagnostics.Resolving_type_reference_directive_0_containing_file_not_set_root_directory_1, typeReferenceDirectiveName, typeRoots);
-        }
-      } else {
-        if (typeRoots === void 0) {
-          trace(host, Diagnostics.Resolving_type_reference_directive_0_containing_file_1_root_directory_not_set, typeReferenceDirectiveName, containingFile);
-        } else {
-          trace(host, Diagnostics.Resolving_type_reference_directive_0_containing_file_1_root_directory_2, typeReferenceDirectiveName, containingFile, typeRoots);
-        }
-      }
-      if (redirectedReference) {
-        trace(host, Diagnostics.Using_compiler_options_of_project_reference_redirect_0, redirectedReference.sourceFile.fileName);
-      }
-    }
-    const failedLookupLocations = [];
-    const affectingLocations = [];
-    let features = getNodeResolutionFeatures(options);
-    if (resolutionMode === 99 /* ESNext */ && (getEmitModuleResolutionKind(options) === 3 /* Node16 */ || getEmitModuleResolutionKind(options) === 99 /* NodeNext */)) {
-      features |= 32 /* EsmMode */;
-    }
-    const conditions = features & 8 /* Exports */ ? getConditions(options, !!(features & 32 /* EsmMode */)) : [];
-    const diagnostics = [];
-    const moduleResolutionState = {
-      compilerOptions: options,
-      host,
-      traceEnabled,
-      failedLookupLocations,
-      affectingLocations,
-      packageJsonInfoCache: cache,
-      features,
-      conditions,
-      requestContainingDirectory: containingDirectory,
-      reportDiagnostic: (diag2) => void diagnostics.push(diag2),
-      isConfigLookup: false,
-      candidateIsFromPackageJsonField: false
-    };
-    let resolved = primaryLookup();
-    let primary = true;
-    if (!resolved) {
-      resolved = secondaryLookup();
-      primary = false;
-    }
-    let resolvedTypeReferenceDirective;
-    if (resolved) {
-      const { fileName, packageId } = resolved;
-      let resolvedFileName = fileName, originalPath;
-      if (!options.preserveSymlinks)
-        ({ resolvedFileName, originalPath } = getOriginalAndResolvedFileName(fileName, host, traceEnabled));
-      resolvedTypeReferenceDirective = {
-        primary,
-        resolvedFileName,
-        originalPath,
-        packageId,
-        isExternalLibraryImport: pathContainsNodeModules(fileName)
-      };
-    }
-    result = {
-      resolvedTypeReferenceDirective,
-      failedLookupLocations: initializeResolutionField(failedLookupLocations),
-      affectingLocations: initializeResolutionField(affectingLocations),
-      resolutionDiagnostics: initializeResolutionField(diagnostics)
-    };
-    if (containingDirectory) {
-      cache == null ? void 0 : cache.getOrCreateCacheForDirectory(containingDirectory, redirectedReference).set(
-        typeReferenceDirectiveName,
-        /*mode*/
-        resolutionMode,
-        result
-      );
-      if (!isExternalModuleNameRelative(typeReferenceDirectiveName)) {
-        cache == null ? void 0 : cache.getOrCreateCacheForNonRelativeName(typeReferenceDirectiveName, resolutionMode, redirectedReference).set(containingDirectory, result);
-      }
-    }
-    if (traceEnabled)
-      traceResult(result);
-    return result;
-    function traceResult(result2) {
-      var _a;
-      if (!((_a = result2.resolvedTypeReferenceDirective) == null ? void 0 : _a.resolvedFileName)) {
-        trace(host, Diagnostics.Type_reference_directive_0_was_not_resolved, typeReferenceDirectiveName);
-      } else if (result2.resolvedTypeReferenceDirective.packageId) {
-        trace(host, Diagnostics.Type_reference_directive_0_was_successfully_resolved_to_1_with_Package_ID_2_primary_Colon_3, typeReferenceDirectiveName, result2.resolvedTypeReferenceDirective.resolvedFileName, packageIdToString(result2.resolvedTypeReferenceDirective.packageId), result2.resolvedTypeReferenceDirective.primary);
-      } else {
-        trace(host, Diagnostics.Type_reference_directive_0_was_successfully_resolved_to_1_primary_Colon_2, typeReferenceDirectiveName, result2.resolvedTypeReferenceDirective.resolvedFileName, result2.resolvedTypeReferenceDirective.primary);
-      }
-    }
-    function primaryLookup() {
-      if (typeRoots && typeRoots.length) {
-        if (traceEnabled) {
-          trace(host, Diagnostics.Resolving_with_primary_search_path_0, typeRoots.join(", "));
-        }
-        return firstDefined(typeRoots, (typeRoot) => {
-          const candidate = getCandidateFromTypeRoot(typeRoot, typeReferenceDirectiveName, moduleResolutionState);
-          const directoryExists = directoryProbablyExists(typeRoot, host);
-          if (!directoryExists && traceEnabled) {
-            trace(host, Diagnostics.Directory_0_does_not_exist_skipping_all_lookups_in_it, typeRoot);
-          }
-          if (options.typeRoots) {
-            const resolvedFromFile = loadModuleFromFile(4 /* Declaration */, candidate, !directoryExists, moduleResolutionState);
-            if (resolvedFromFile) {
-              const packageDirectory = parseNodeModuleFromPath(resolvedFromFile.path);
-              const packageInfo = packageDirectory ? getPackageJsonInfo(
-                packageDirectory,
-                /*onlyRecordFailures*/
-                false,
-                moduleResolutionState
-              ) : void 0;
-              return resolvedTypeScriptOnly(withPackageId(packageInfo, resolvedFromFile));
-            }
-          }
-          return resolvedTypeScriptOnly(
-            loadNodeModuleFromDirectory(
-              4 /* Declaration */,
-              candidate,
-              !directoryExists,
-              moduleResolutionState
-            )
-          );
-        });
-      } else {
-        if (traceEnabled) {
-          trace(host, Diagnostics.Root_directory_cannot_be_determined_skipping_primary_search_paths);
-        }
-      }
-    }
-    function secondaryLookup() {
-      const initialLocationForSecondaryLookup = containingFile && getDirectoryPath(containingFile);
-      if (initialLocationForSecondaryLookup !== void 0) {
-        let result2;
-        if (!options.typeRoots || !endsWith(containingFile, inferredTypesContainingFile)) {
-          if (traceEnabled) {
-            trace(host, Diagnostics.Looking_up_in_node_modules_folder_initial_location_0, initialLocationForSecondaryLookup);
-          }
-          if (!isExternalModuleNameRelative(typeReferenceDirectiveName)) {
-            const searchResult = loadModuleFromNearestNodeModulesDirectory(
-              4 /* Declaration */,
-              typeReferenceDirectiveName,
-              initialLocationForSecondaryLookup,
-              moduleResolutionState,
-              /*cache*/
-              void 0,
-              /*redirectedReference*/
-              void 0
-            );
-            result2 = searchResult && searchResult.value;
-          } else {
-            const { path: candidate } = normalizePathForCJSResolution(initialLocationForSecondaryLookup, typeReferenceDirectiveName);
-            result2 = nodeLoadModuleByRelativeName(
-              4 /* Declaration */,
-              candidate,
-              /*onlyRecordFailures*/
-              false,
-              moduleResolutionState,
-              /*considerPackageJson*/
-              true
-            );
-          }
-        } else if (traceEnabled) {
-          trace(host, Diagnostics.Resolving_type_reference_directive_for_program_that_specifies_custom_typeRoots_skipping_lookup_in_node_modules_folder);
-        }
-        return resolvedTypeScriptOnly(result2);
-      } else {
-        if (traceEnabled) {
-          trace(host, Diagnostics.Containing_file_is_not_specified_and_root_directory_cannot_be_determined_skipping_lookup_in_node_modules_folder);
-        }
-      }
-    }
-  }
-  function getNodeResolutionFeatures(options) {
-    let features = 0 /* None */;
-    switch (getEmitModuleResolutionKind(options)) {
-      case 3 /* Node16 */:
-        features = 30 /* Node16Default */;
-        break;
-      case 99 /* NodeNext */:
-        features = 30 /* NodeNextDefault */;
-        break;
-      case 100 /* Bundler */:
-        features = 30 /* BundlerDefault */;
-        break;
-    }
-    if (options.resolvePackageJsonExports) {
-      features |= 8 /* Exports */;
-    } else if (options.resolvePackageJsonExports === false) {
-      features &= ~8 /* Exports */;
-    }
-    if (options.resolvePackageJsonImports) {
-      features |= 2 /* Imports */;
-    } else if (options.resolvePackageJsonImports === false) {
-      features &= ~2 /* Imports */;
-    }
-    return features;
-  }
-  function getConditions(options, esmMode) {
-    const conditions = esmMode || getEmitModuleResolutionKind(options) === 100 /* Bundler */ ? ["import"] : ["require"];
-    if (!options.noDtsResolution) {
-      conditions.push("types");
-    }
-    if (getEmitModuleResolutionKind(options) !== 100 /* Bundler */) {
-      conditions.push("node");
-    }
-    return concatenate(conditions, options.customConditions);
-  }
-  function resolvePackageNameToPackageJson(packageName, containingDirectory, options, host, cache) {
-    const moduleResolutionState = getTemporaryModuleResolutionState(cache == null ? void 0 : cache.getPackageJsonInfoCache(), host, options);
-    return forEachAncestorDirectory(containingDirectory, (ancestorDirectory) => {
-      if (getBaseFileName(ancestorDirectory) !== "node_modules") {
-        const nodeModulesFolder = combinePaths(ancestorDirectory, "node_modules");
-        const candidate = combinePaths(nodeModulesFolder, packageName);
-        return getPackageJsonInfo(
-          candidate,
-          /*onlyRecordFailures*/
-          false,
-          moduleResolutionState
-        );
-      }
-    });
-  }
-  function getAutomaticTypeDirectiveNames(options, host) {
-    if (options.types) {
-      return options.types;
-    }
-    const result = [];
-    if (host.directoryExists && host.getDirectories) {
-      const typeRoots = getEffectiveTypeRoots(options, host);
-      if (typeRoots) {
-        for (const root of typeRoots) {
-          if (host.directoryExists(root)) {
-            for (const typeDirectivePath of host.getDirectories(root)) {
-              const normalized = normalizePath(typeDirectivePath);
-              const packageJsonPath = combinePaths(root, normalized, "package.json");
-              const isNotNeededPackage = host.fileExists(packageJsonPath) && readJson(packageJsonPath, host).typings === null;
-              if (!isNotNeededPackage) {
-                const baseFileName = getBaseFileName(normalized);
-                if (baseFileName.charCodeAt(0) !== 46 /* dot */) {
-                  result.push(baseFileName);
-                }
-              }
-            }
-          }
-        }
-      }
-    }
-    return result;
-  }
-  function compilerOptionValueToString(value) {
-    var _a;
-    if (value === null || typeof value !== "object") {
-      return "" + value;
-    }
-    if (isArray(value)) {
-      return `[${(_a = value.map((e) => compilerOptionValueToString(e))) == null ? void 0 : _a.join(",")}]`;
-    }
-    let str = "{";
-    for (const key in value) {
-      if (hasProperty(value, key)) {
-        str += `${key}: ${compilerOptionValueToString(value[key])}`;
-      }
-    }
-    return str + "}";
-  }
-  function getKeyForCompilerOptions(options, affectingOptionDeclarations) {
-    return affectingOptionDeclarations.map((option) => compilerOptionValueToString(getCompilerOptionValue(options, option))).join("|") + (options.pathsBasePath ? `|${options.pathsBasePath}` : void 0);
-  }
-  function createCacheWithRedirects(ownOptions) {
-    const redirectsMap = /* @__PURE__ */ new Map();
-    const optionsToRedirectsKey = /* @__PURE__ */ new Map();
-    const redirectsKeyToMap = /* @__PURE__ */ new Map();
-    let ownMap = /* @__PURE__ */ new Map();
-    if (ownOptions)
-      redirectsMap.set(ownOptions, ownMap);
-    return {
-      getMapOfCacheRedirects,
-      getOrCreateMapOfCacheRedirects,
-      update,
-      clear: clear2
-    };
-    function getMapOfCacheRedirects(redirectedReference) {
-      return redirectedReference ? getOrCreateMap(
-        redirectedReference.commandLine.options,
-        /*create*/
-        false
-      ) : ownMap;
-    }
-    function getOrCreateMapOfCacheRedirects(redirectedReference) {
-      return redirectedReference ? getOrCreateMap(
-        redirectedReference.commandLine.options,
-        /*create*/
-        true
-      ) : ownMap;
-    }
-    function update(newOptions) {
-      if (ownOptions !== newOptions) {
-        if (ownOptions)
-          ownMap = getOrCreateMap(
-            newOptions,
-            /*create*/
-            true
-          );
-        else
-          redirectsMap.set(newOptions, ownMap);
-        ownOptions = newOptions;
-      }
-    }
-    function getOrCreateMap(redirectOptions, create) {
-      let result = redirectsMap.get(redirectOptions);
-      if (result)
-        return result;
-      const key = getRedirectsCacheKey(redirectOptions);
-      result = redirectsKeyToMap.get(key);
-      if (!result) {
-        if (ownOptions) {
-          const ownKey = getRedirectsCacheKey(ownOptions);
-          if (ownKey === key)
-            result = ownMap;
-          else if (!redirectsKeyToMap.has(ownKey))
-            redirectsKeyToMap.set(ownKey, ownMap);
-        }
-        if (create)
-          result ?? (result = /* @__PURE__ */ new Map());
-        if (result)
-          redirectsKeyToMap.set(key, result);
-      }
-      if (result)
-        redirectsMap.set(redirectOptions, result);
-      return result;
-    }
-    function clear2() {
-      const ownKey = ownOptions && optionsToRedirectsKey.get(ownOptions);
-      ownMap.clear();
-      redirectsMap.clear();
-      optionsToRedirectsKey.clear();
-      redirectsKeyToMap.clear();
-      if (ownOptions) {
-        if (ownKey)
-          optionsToRedirectsKey.set(ownOptions, ownKey);
-        redirectsMap.set(ownOptions, ownMap);
-      }
-    }
-    function getRedirectsCacheKey(options) {
-      let result = optionsToRedirectsKey.get(options);
-      if (!result) {
-        optionsToRedirectsKey.set(options, result = getKeyForCompilerOptions(options, moduleResolutionOptionDeclarations));
-      }
-      return result;
-    }
-  }
-  function createPackageJsonInfoCache(currentDirectory, getCanonicalFileName) {
-    let cache;
-    return { getPackageJsonInfo: getPackageJsonInfo2, setPackageJsonInfo, clear: clear2, entries, getInternalMap };
-    function getPackageJsonInfo2(packageJsonPath) {
-      return cache == null ? void 0 : cache.get(toPath(packageJsonPath, currentDirectory, getCanonicalFileName));
-    }
-    function setPackageJsonInfo(packageJsonPath, info) {
-      (cache || (cache = /* @__PURE__ */ new Map())).set(toPath(packageJsonPath, currentDirectory, getCanonicalFileName), info);
-    }
-    function clear2() {
-      cache = void 0;
-    }
-    function entries() {
-      const iter = cache == null ? void 0 : cache.entries();
-      return iter ? arrayFrom(iter) : [];
-    }
-    function getInternalMap() {
-      return cache;
-    }
-  }
-  function getOrCreateCache(cacheWithRedirects, redirectedReference, key, create) {
-    const cache = cacheWithRedirects.getOrCreateMapOfCacheRedirects(redirectedReference);
-    let result = cache.get(key);
-    if (!result) {
-      result = create();
-      cache.set(key, result);
-    }
-    return result;
-  }
-  function createPerDirectoryResolutionCache(currentDirectory, getCanonicalFileName, options) {
-    const directoryToModuleNameMap = createCacheWithRedirects(options);
-    return {
-      getFromDirectoryCache,
-      getOrCreateCacheForDirectory,
-      clear: clear2,
-      update
-    };
-    function clear2() {
-      directoryToModuleNameMap.clear();
-    }
-    function update(options2) {
-      directoryToModuleNameMap.update(options2);
-    }
-    function getOrCreateCacheForDirectory(directoryName, redirectedReference) {
-      const path = toPath(directoryName, currentDirectory, getCanonicalFileName);
-      return getOrCreateCache(directoryToModuleNameMap, redirectedReference, path, () => createModeAwareCache());
-    }
-    function getFromDirectoryCache(name, mode, directoryName, redirectedReference) {
-      var _a, _b;
-      const path = toPath(directoryName, currentDirectory, getCanonicalFileName);
-      return (_b = (_a = directoryToModuleNameMap.getMapOfCacheRedirects(redirectedReference)) == null ? void 0 : _a.get(path)) == null ? void 0 : _b.get(name, mode);
-    }
-  }
-  function createModeAwareCacheKey(specifier, mode) {
-    return mode === void 0 ? specifier : `${mode}|${specifier}`;
-  }
-  function createModeAwareCache() {
-    const underlying = /* @__PURE__ */ new Map();
-    const memoizedReverseKeys = /* @__PURE__ */ new Map();
-    const cache = {
-      get(specifier, mode) {
-        return underlying.get(getUnderlyingCacheKey(specifier, mode));
-      },
-      set(specifier, mode, value) {
-        underlying.set(getUnderlyingCacheKey(specifier, mode), value);
-        return cache;
-      },
-      delete(specifier, mode) {
-        underlying.delete(getUnderlyingCacheKey(specifier, mode));
-        return cache;
-      },
-      has(specifier, mode) {
-        return underlying.has(getUnderlyingCacheKey(specifier, mode));
-      },
-      forEach(cb) {
-        return underlying.forEach((elem, key) => {
-          const [specifier, mode] = memoizedReverseKeys.get(key);
-          return cb(elem, specifier, mode);
-        });
-      },
-      size() {
-        return underlying.size;
-      }
-    };
-    return cache;
-    function getUnderlyingCacheKey(specifier, mode) {
-      const result = createModeAwareCacheKey(specifier, mode);
-      memoizedReverseKeys.set(result, [specifier, mode]);
-      return result;
-    }
-  }
-  function zipToModeAwareCache(file, keys, values, nameAndModeGetter) {
-    Debug.assert(keys.length === values.length);
-    const map2 = createModeAwareCache();
-    for (let i = 0; i < keys.length; ++i) {
-      const entry = keys[i];
-      map2.set(nameAndModeGetter.getName(entry), nameAndModeGetter.getMode(entry, file), values[i]);
-    }
-    return map2;
-  }
-  function getOriginalOrResolvedModuleFileName(result) {
-    return result.resolvedModule && (result.resolvedModule.originalPath || result.resolvedModule.resolvedFileName);
-  }
-  function getOriginalOrResolvedTypeReferenceFileName(result) {
-    return result.resolvedTypeReferenceDirective && (result.resolvedTypeReferenceDirective.originalPath || result.resolvedTypeReferenceDirective.resolvedFileName);
-  }
-  function createNonRelativeNameResolutionCache(currentDirectory, getCanonicalFileName, options, getResolvedFileName) {
-    const moduleNameToDirectoryMap = createCacheWithRedirects(options);
-    return {
-      getFromNonRelativeNameCache,
-      getOrCreateCacheForNonRelativeName,
-      clear: clear2,
-      update
-    };
-    function clear2() {
-      moduleNameToDirectoryMap.clear();
-    }
-    function update(options2) {
-      moduleNameToDirectoryMap.update(options2);
-    }
-    function getFromNonRelativeNameCache(nonRelativeModuleName, mode, directoryName, redirectedReference) {
-      var _a, _b;
-      Debug.assert(!isExternalModuleNameRelative(nonRelativeModuleName));
-      return (_b = (_a = moduleNameToDirectoryMap.getMapOfCacheRedirects(redirectedReference)) == null ? void 0 : _a.get(createModeAwareCacheKey(nonRelativeModuleName, mode))) == null ? void 0 : _b.get(directoryName);
-    }
-    function getOrCreateCacheForNonRelativeName(nonRelativeModuleName, mode, redirectedReference) {
-      Debug.assert(!isExternalModuleNameRelative(nonRelativeModuleName));
-      return getOrCreateCache(moduleNameToDirectoryMap, redirectedReference, createModeAwareCacheKey(nonRelativeModuleName, mode), createPerModuleNameCache);
-    }
-    function createPerModuleNameCache() {
-      const directoryPathMap = /* @__PURE__ */ new Map();
-      return { get, set };
-      function get(directory) {
-        return directoryPathMap.get(toPath(directory, currentDirectory, getCanonicalFileName));
-      }
-      function set(directory, result) {
-        const path = toPath(directory, currentDirectory, getCanonicalFileName);
-        if (directoryPathMap.has(path)) {
-          return;
-        }
-        directoryPathMap.set(path, result);
-        const resolvedFileName = getResolvedFileName(result);
-        const commonPrefix = resolvedFileName && getCommonPrefix(path, resolvedFileName);
-        let current = path;
-        while (current !== commonPrefix) {
-          const parent2 = getDirectoryPath(current);
-          if (parent2 === current || directoryPathMap.has(parent2)) {
-            break;
-          }
-          directoryPathMap.set(parent2, result);
-          current = parent2;
-        }
-      }
-      function getCommonPrefix(directory, resolution) {
-        const resolutionDirectory = toPath(getDirectoryPath(resolution), currentDirectory, getCanonicalFileName);
-        let i = 0;
-        const limit = Math.min(directory.length, resolutionDirectory.length);
-        while (i < limit && directory.charCodeAt(i) === resolutionDirectory.charCodeAt(i)) {
-          i++;
-        }
-        if (i === directory.length && (resolutionDirectory.length === i || resolutionDirectory[i] === directorySeparator)) {
-          return directory;
-        }
-        const rootLength = getRootLength(directory);
-        if (i < rootLength) {
-          return void 0;
-        }
-        const sep = directory.lastIndexOf(directorySeparator, i - 1);
-        if (sep === -1) {
-          return void 0;
-        }
-        return directory.substr(0, Math.max(sep, rootLength));
-      }
-    }
-  }
-  function createModuleOrTypeReferenceResolutionCache(currentDirectory, getCanonicalFileName, options, packageJsonInfoCache, getResolvedFileName) {
-    const perDirectoryResolutionCache = createPerDirectoryResolutionCache(currentDirectory, getCanonicalFileName, options);
-    const nonRelativeNameResolutionCache = createNonRelativeNameResolutionCache(
-      currentDirectory,
-      getCanonicalFileName,
-      options,
-      getResolvedFileName
-    );
-    packageJsonInfoCache ?? (packageJsonInfoCache = createPackageJsonInfoCache(currentDirectory, getCanonicalFileName));
-    return {
-      ...packageJsonInfoCache,
-      ...perDirectoryResolutionCache,
-      ...nonRelativeNameResolutionCache,
-      clear: clear2,
-      update,
-      getPackageJsonInfoCache: () => packageJsonInfoCache,
-      clearAllExceptPackageJsonInfoCache
-    };
-    function clear2() {
-      clearAllExceptPackageJsonInfoCache();
-      packageJsonInfoCache.clear();
-    }
-    function clearAllExceptPackageJsonInfoCache() {
-      perDirectoryResolutionCache.clear();
-      nonRelativeNameResolutionCache.clear();
-    }
-    function update(options2) {
-      perDirectoryResolutionCache.update(options2);
-      nonRelativeNameResolutionCache.update(options2);
-    }
-  }
-  function createModuleResolutionCache(currentDirectory, getCanonicalFileName, options, packageJsonInfoCache) {
-    const result = createModuleOrTypeReferenceResolutionCache(
-      currentDirectory,
-      getCanonicalFileName,
-      options,
-      packageJsonInfoCache,
-      getOriginalOrResolvedModuleFileName
-    );
-    result.getOrCreateCacheForModuleName = (nonRelativeName, mode, redirectedReference) => result.getOrCreateCacheForNonRelativeName(nonRelativeName, mode, redirectedReference);
-    return result;
-  }
-  function createTypeReferenceDirectiveResolutionCache(currentDirectory, getCanonicalFileName, options, packageJsonInfoCache) {
-    return createModuleOrTypeReferenceResolutionCache(
-      currentDirectory,
-      getCanonicalFileName,
-      options,
-      packageJsonInfoCache,
-      getOriginalOrResolvedTypeReferenceFileName
-    );
-  }
-  function getOptionsForLibraryResolution(options) {
-    return { moduleResolution: 2 /* Node10 */, traceResolution: options.traceResolution };
-  }
-  function resolveLibrary(libraryName, resolveFrom, compilerOptions, host, cache) {
-    return resolveModuleName(libraryName, resolveFrom, getOptionsForLibraryResolution(compilerOptions), host, cache);
-  }
-  function resolveModuleNameFromCache(moduleName, containingFile, cache, mode) {
-    const containingDirectory = getDirectoryPath(containingFile);
-    return cache.getFromDirectoryCache(
-      moduleName,
-      mode,
-      containingDirectory,
-      /*redirectedReference*/
-      void 0
-    );
-  }
-  function resolveModuleName(moduleName, containingFile, compilerOptions, host, cache, redirectedReference, resolutionMode) {
-    var _a, _b, _c;
-    const traceEnabled = isTraceEnabled(compilerOptions, host);
-    if (redirectedReference) {
-      compilerOptions = redirectedReference.commandLine.options;
-    }
-    if (traceEnabled) {
-      trace(host, Diagnostics.Resolving_module_0_from_1, moduleName, containingFile);
-      if (redirectedReference) {
-        trace(host, Diagnostics.Using_compiler_options_of_project_reference_redirect_0, redirectedReference.sourceFile.fileName);
-      }
-    }
-    const containingDirectory = getDirectoryPath(containingFile);
-    let result = cache == null ? void 0 : cache.getFromDirectoryCache(moduleName, resolutionMode, containingDirectory, redirectedReference);
-    if (result) {
-      if (traceEnabled) {
-        trace(host, Diagnostics.Resolution_for_module_0_was_found_in_cache_from_location_1, moduleName, containingDirectory);
-      }
-    } else {
-      let moduleResolution = compilerOptions.moduleResolution;
-      if (moduleResolution === void 0) {
-        switch (getEmitModuleKind(compilerOptions)) {
-          case 1 /* CommonJS */:
-            moduleResolution = 2 /* Node10 */;
-            break;
-          case 100 /* Node16 */:
-            moduleResolution = 3 /* Node16 */;
-            break;
-          case 199 /* NodeNext */:
-            moduleResolution = 99 /* NodeNext */;
-            break;
-          default:
-            moduleResolution = 1 /* Classic */;
-            break;
-        }
-        if (traceEnabled) {
-          trace(host, Diagnostics.Module_resolution_kind_is_not_specified_using_0, ModuleResolutionKind[moduleResolution]);
-        }
-      } else {
-        if (traceEnabled) {
-          trace(host, Diagnostics.Explicitly_specified_module_resolution_kind_Colon_0, ModuleResolutionKind[moduleResolution]);
-        }
-      }
-      (_a = perfLogger) == null ? void 0 : _a.logStartResolveModule(moduleName);
-      switch (moduleResolution) {
-        case 3 /* Node16 */:
-          result = node16ModuleNameResolver(moduleName, containingFile, compilerOptions, host, cache, redirectedReference, resolutionMode);
-          break;
-        case 99 /* NodeNext */:
-          result = nodeNextModuleNameResolver(moduleName, containingFile, compilerOptions, host, cache, redirectedReference, resolutionMode);
-          break;
-        case 2 /* Node10 */:
-          result = nodeModuleNameResolver(moduleName, containingFile, compilerOptions, host, cache, redirectedReference);
-          break;
-        case 1 /* Classic */:
-          result = classicNameResolver(moduleName, containingFile, compilerOptions, host, cache, redirectedReference);
-          break;
-        case 100 /* Bundler */:
-          result = bundlerModuleNameResolver(moduleName, containingFile, compilerOptions, host, cache, redirectedReference);
-          break;
-        default:
-          return Debug.fail(`Unexpected moduleResolution: ${moduleResolution}`);
-      }
-      if (result && result.resolvedModule)
-        (_b = perfLogger) == null ? void 0 : _b.logInfoEvent(`Module "${moduleName}" resolved to "${result.resolvedModule.resolvedFileName}"`);
-      (_c = perfLogger) == null ? void 0 : _c.logStopResolveModule(result && result.resolvedModule ? "" + result.resolvedModule.resolvedFileName : "null");
-      cache == null ? void 0 : cache.getOrCreateCacheForDirectory(containingDirectory, redirectedReference).set(moduleName, resolutionMode, result);
-      if (!isExternalModuleNameRelative(moduleName)) {
-        cache == null ? void 0 : cache.getOrCreateCacheForNonRelativeName(moduleName, resolutionMode, redirectedReference).set(containingDirectory, result);
-      }
-    }
-    if (traceEnabled) {
-      if (result.resolvedModule) {
-        if (result.resolvedModule.packageId) {
-          trace(host, Diagnostics.Module_name_0_was_successfully_resolved_to_1_with_Package_ID_2, moduleName, result.resolvedModule.resolvedFileName, packageIdToString(result.resolvedModule.packageId));
-        } else {
-          trace(host, Diagnostics.Module_name_0_was_successfully_resolved_to_1, moduleName, result.resolvedModule.resolvedFileName);
-        }
-      } else {
-        trace(host, Diagnostics.Module_name_0_was_not_resolved, moduleName);
-      }
-    }
-    return result;
-  }
-  function tryLoadModuleUsingOptionalResolutionSettings(extensions, moduleName, containingDirectory, loader, state) {
-    const resolved = tryLoadModuleUsingPathsIfEligible(extensions, moduleName, loader, state);
-    if (resolved)
-      return resolved.value;
-    if (!isExternalModuleNameRelative(moduleName)) {
-      return tryLoadModuleUsingBaseUrl(extensions, moduleName, loader, state);
-    } else {
-      return tryLoadModuleUsingRootDirs(extensions, moduleName, containingDirectory, loader, state);
-    }
-  }
-  function tryLoadModuleUsingPathsIfEligible(extensions, moduleName, loader, state) {
-    var _a;
-    const { baseUrl, paths, configFile } = state.compilerOptions;
-    if (paths && !pathIsRelative(moduleName)) {
-      if (state.traceEnabled) {
-        if (baseUrl) {
-          trace(state.host, Diagnostics.baseUrl_option_is_set_to_0_using_this_value_to_resolve_non_relative_module_name_1, baseUrl, moduleName);
-        }
-        trace(state.host, Diagnostics.paths_option_is_specified_looking_for_a_pattern_to_match_module_name_0, moduleName);
-      }
-      const baseDirectory = getPathsBasePath(state.compilerOptions, state.host);
-      const pathPatterns = (configFile == null ? void 0 : configFile.configFileSpecs) ? (_a = configFile.configFileSpecs).pathPatterns || (_a.pathPatterns = tryParsePatterns(paths)) : void 0;
-      return tryLoadModuleUsingPaths(
-        extensions,
-        moduleName,
-        baseDirectory,
-        paths,
-        pathPatterns,
-        loader,
-        /*onlyRecordFailures*/
-        false,
-        state
-      );
-    }
-  }
-  function tryLoadModuleUsingRootDirs(extensions, moduleName, containingDirectory, loader, state) {
-    if (!state.compilerOptions.rootDirs) {
-      return void 0;
-    }
-    if (state.traceEnabled) {
-      trace(state.host, Diagnostics.rootDirs_option_is_set_using_it_to_resolve_relative_module_name_0, moduleName);
-    }
-    const candidate = normalizePath(combinePaths(containingDirectory, moduleName));
-    let matchedRootDir;
-    let matchedNormalizedPrefix;
-    for (const rootDir of state.compilerOptions.rootDirs) {
-      let normalizedRoot = normalizePath(rootDir);
-      if (!endsWith(normalizedRoot, directorySeparator)) {
-        normalizedRoot += directorySeparator;
-      }
-      const isLongestMatchingPrefix = startsWith(candidate, normalizedRoot) && (matchedNormalizedPrefix === void 0 || matchedNormalizedPrefix.length < normalizedRoot.length);
-      if (state.traceEnabled) {
-        trace(state.host, Diagnostics.Checking_if_0_is_the_longest_matching_prefix_for_1_2, normalizedRoot, candidate, isLongestMatchingPrefix);
-      }
-      if (isLongestMatchingPrefix) {
-        matchedNormalizedPrefix = normalizedRoot;
-        matchedRootDir = rootDir;
-      }
-    }
-    if (matchedNormalizedPrefix) {
-      if (state.traceEnabled) {
-        trace(state.host, Diagnostics.Longest_matching_prefix_for_0_is_1, candidate, matchedNormalizedPrefix);
-      }
-      const suffix = candidate.substr(matchedNormalizedPrefix.length);
-      if (state.traceEnabled) {
-        trace(state.host, Diagnostics.Loading_0_from_the_root_dir_1_candidate_location_2, suffix, matchedNormalizedPrefix, candidate);
-      }
-      const resolvedFileName = loader(extensions, candidate, !directoryProbablyExists(containingDirectory, state.host), state);
-      if (resolvedFileName) {
-        return resolvedFileName;
-      }
-      if (state.traceEnabled) {
-        trace(state.host, Diagnostics.Trying_other_entries_in_rootDirs);
-      }
-      for (const rootDir of state.compilerOptions.rootDirs) {
-        if (rootDir === matchedRootDir) {
-          continue;
-        }
-        const candidate2 = combinePaths(normalizePath(rootDir), suffix);
-        if (state.traceEnabled) {
-          trace(state.host, Diagnostics.Loading_0_from_the_root_dir_1_candidate_location_2, suffix, rootDir, candidate2);
-        }
-        const baseDirectory = getDirectoryPath(candidate2);
-        const resolvedFileName2 = loader(extensions, candidate2, !directoryProbablyExists(baseDirectory, state.host), state);
-        if (resolvedFileName2) {
-          return resolvedFileName2;
-        }
-      }
-      if (state.traceEnabled) {
-        trace(state.host, Diagnostics.Module_resolution_using_rootDirs_has_failed);
-      }
-    }
-    return void 0;
-  }
-  function tryLoadModuleUsingBaseUrl(extensions, moduleName, loader, state) {
-    const { baseUrl } = state.compilerOptions;
-    if (!baseUrl) {
-      return void 0;
-    }
-    if (state.traceEnabled) {
-      trace(state.host, Diagnostics.baseUrl_option_is_set_to_0_using_this_value_to_resolve_non_relative_module_name_1, baseUrl, moduleName);
-    }
-    const candidate = normalizePath(combinePaths(baseUrl, moduleName));
-    if (state.traceEnabled) {
-      trace(state.host, Diagnostics.Resolving_module_name_0_relative_to_base_url_1_2, moduleName, baseUrl, candidate);
-    }
-    return loader(extensions, candidate, !directoryProbablyExists(getDirectoryPath(candidate), state.host), state);
-  }
-  function resolveJSModule(moduleName, initialDir, host) {
-    const { resolvedModule, failedLookupLocations } = tryResolveJSModuleWorker(moduleName, initialDir, host);
-    if (!resolvedModule) {
-      throw new Error(`Could not resolve JS module '${moduleName}' starting at '${initialDir}'. Looked in: ${failedLookupLocations == null ? void 0 : failedLookupLocations.join(", ")}`);
-    }
-    return resolvedModule.resolvedFileName;
-  }
-  function node16ModuleNameResolver(moduleName, containingFile, compilerOptions, host, cache, redirectedReference, resolutionMode) {
-    return nodeNextModuleNameResolverWorker(
-      30 /* Node16Default */,
-      moduleName,
-      containingFile,
-      compilerOptions,
-      host,
-      cache,
-      redirectedReference,
-      resolutionMode
-    );
-  }
-  function nodeNextModuleNameResolver(moduleName, containingFile, compilerOptions, host, cache, redirectedReference, resolutionMode) {
-    return nodeNextModuleNameResolverWorker(
-      30 /* NodeNextDefault */,
-      moduleName,
-      containingFile,
-      compilerOptions,
-      host,
-      cache,
-      redirectedReference,
-      resolutionMode
-    );
-  }
-  function nodeNextModuleNameResolverWorker(features, moduleName, containingFile, compilerOptions, host, cache, redirectedReference, resolutionMode) {
-    const containingDirectory = getDirectoryPath(containingFile);
-    const esmMode = resolutionMode === 99 /* ESNext */ ? 32 /* EsmMode */ : 0;
-    let extensions = compilerOptions.noDtsResolution ? 3 /* ImplementationFiles */ : 1 /* TypeScript */ | 2 /* JavaScript */ | 4 /* Declaration */;
-    if (getResolveJsonModule(compilerOptions)) {
-      extensions |= 8 /* Json */;
-    }
-    return nodeModuleNameResolverWorker(
-      features | esmMode,
-      moduleName,
-      containingDirectory,
-      compilerOptions,
-      host,
-      cache,
-      extensions,
-      /*isConfigLookup*/
-      false,
-      redirectedReference
-    );
-  }
-  function tryResolveJSModuleWorker(moduleName, initialDir, host) {
-    return nodeModuleNameResolverWorker(
-      0 /* None */,
-      moduleName,
-      initialDir,
-      { moduleResolution: 2 /* Node10 */, allowJs: true },
-      host,
-      /*cache*/
-      void 0,
-      2 /* JavaScript */,
-      /*isConfigLookup*/
-      false,
-      /*redirectedReference*/
-      void 0
-    );
-  }
-  function bundlerModuleNameResolver(moduleName, containingFile, compilerOptions, host, cache, redirectedReference) {
-    const containingDirectory = getDirectoryPath(containingFile);
-    let extensions = compilerOptions.noDtsResolution ? 3 /* ImplementationFiles */ : 1 /* TypeScript */ | 2 /* JavaScript */ | 4 /* Declaration */;
-    if (getResolveJsonModule(compilerOptions)) {
-      extensions |= 8 /* Json */;
-    }
-    return nodeModuleNameResolverWorker(
-      getNodeResolutionFeatures(compilerOptions),
-      moduleName,
-      containingDirectory,
-      compilerOptions,
-      host,
-      cache,
-      extensions,
-      /*isConfigLookup*/
-      false,
-      redirectedReference
-    );
-  }
-  function nodeModuleNameResolver(moduleName, containingFile, compilerOptions, host, cache, redirectedReference, isConfigLookup) {
-    let extensions;
-    if (isConfigLookup) {
-      extensions = 8 /* Json */;
-    } else if (compilerOptions.noDtsResolution) {
-      extensions = 3 /* ImplementationFiles */;
-      if (getResolveJsonModule(compilerOptions))
-        extensions |= 8 /* Json */;
-    } else {
-      extensions = getResolveJsonModule(compilerOptions) ? 1 /* TypeScript */ | 2 /* JavaScript */ | 4 /* Declaration */ | 8 /* Json */ : 1 /* TypeScript */ | 2 /* JavaScript */ | 4 /* Declaration */;
-    }
-    return nodeModuleNameResolverWorker(0 /* None */, moduleName, getDirectoryPath(containingFile), compilerOptions, host, cache, extensions, !!isConfigLookup, redirectedReference);
-  }
-  function nodeNextJsonConfigResolver(moduleName, containingFile, host) {
-    return nodeModuleNameResolverWorker(
-      30 /* NodeNextDefault */,
-      moduleName,
-      getDirectoryPath(containingFile),
-      { moduleResolution: 99 /* NodeNext */ },
-      host,
-      /*cache*/
-      void 0,
-      8 /* Json */,
-      /*isConfigLookup*/
-      true,
-      /*redirectedReference*/
-      void 0
-    );
-  }
-  function nodeModuleNameResolverWorker(features, moduleName, containingDirectory, compilerOptions, host, cache, extensions, isConfigLookup, redirectedReference) {
-    var _a, _b, _c, _d;
-    const traceEnabled = isTraceEnabled(compilerOptions, host);
-    const failedLookupLocations = [];
-    const affectingLocations = [];
-    const conditions = getConditions(compilerOptions, !!(features & 32 /* EsmMode */));
-    const diagnostics = [];
-    const state = {
-      compilerOptions,
-      host,
-      traceEnabled,
-      failedLookupLocations,
-      affectingLocations,
-      packageJsonInfoCache: cache,
-      features,
-      conditions,
-      requestContainingDirectory: containingDirectory,
-      reportDiagnostic: (diag2) => void diagnostics.push(diag2),
-      isConfigLookup,
-      candidateIsFromPackageJsonField: false
-    };
-    if (traceEnabled && moduleResolutionSupportsPackageJsonExportsAndImports(getEmitModuleResolutionKind(compilerOptions))) {
-      trace(host, Diagnostics.Resolving_in_0_mode_with_conditions_1, features & 32 /* EsmMode */ ? "ESM" : "CJS", conditions.map((c) => `'${c}'`).join(", "));
-    }
-    let result;
-    if (getEmitModuleResolutionKind(compilerOptions) === 2 /* Node10 */) {
-      const priorityExtensions = extensions & (1 /* TypeScript */ | 4 /* Declaration */);
-      const secondaryExtensions = extensions & ~(1 /* TypeScript */ | 4 /* Declaration */);
-      result = priorityExtensions && tryResolve(priorityExtensions, state) || secondaryExtensions && tryResolve(secondaryExtensions, state) || void 0;
-    } else {
-      result = tryResolve(extensions, state);
-    }
-    let legacyResult;
-    if (((_a = result == null ? void 0 : result.value) == null ? void 0 : _a.isExternalLibraryImport) && !isConfigLookup && extensions & (1 /* TypeScript */ | 4 /* Declaration */) && features & 8 /* Exports */ && !isExternalModuleNameRelative(moduleName) && !extensionIsOk(1 /* TypeScript */ | 4 /* Declaration */, result.value.resolved.extension) && conditions.indexOf("import") > -1) {
-      traceIfEnabled(state, Diagnostics.Resolution_of_non_relative_name_failed_trying_with_modern_Node_resolution_features_disabled_to_see_if_npm_library_needs_configuration_update);
-      const diagnosticState = {
-        ...state,
-        features: state.features & ~8 /* Exports */,
-        reportDiagnostic: noop
-      };
-      const diagnosticResult = tryResolve(extensions & (1 /* TypeScript */ | 4 /* Declaration */), diagnosticState);
-      if ((_b = diagnosticResult == null ? void 0 : diagnosticResult.value) == null ? void 0 : _b.isExternalLibraryImport) {
-        legacyResult = diagnosticResult.value.resolved.path;
-      }
-    }
-    return createResolvedModuleWithFailedLookupLocationsHandlingSymlink(
-      moduleName,
-      (_c = result == null ? void 0 : result.value) == null ? void 0 : _c.resolved,
-      (_d = result == null ? void 0 : result.value) == null ? void 0 : _d.isExternalLibraryImport,
-      failedLookupLocations,
-      affectingLocations,
-      diagnostics,
-      state,
-      legacyResult
-    );
-    function tryResolve(extensions2, state2) {
-      const loader = (extensions3, candidate, onlyRecordFailures, state3) => nodeLoadModuleByRelativeName(
-        extensions3,
-        candidate,
-        onlyRecordFailures,
-        state3,
-        /*considerPackageJson*/
-        true
-      );
-      const resolved = tryLoadModuleUsingOptionalResolutionSettings(extensions2, moduleName, containingDirectory, loader, state2);
-      if (resolved) {
-        return toSearchResult({ resolved, isExternalLibraryImport: pathContainsNodeModules(resolved.path) });
-      }
-      if (!isExternalModuleNameRelative(moduleName)) {
-        let resolved2;
-        if (features & 2 /* Imports */ && startsWith(moduleName, "#")) {
-          resolved2 = loadModuleFromImports(extensions2, moduleName, containingDirectory, state2, cache, redirectedReference);
-        }
-        if (!resolved2 && features & 4 /* SelfName */) {
-          resolved2 = loadModuleFromSelfNameReference(extensions2, moduleName, containingDirectory, state2, cache, redirectedReference);
-        }
-        if (!resolved2) {
-          if (moduleName.indexOf(":") > -1) {
-            if (traceEnabled) {
-              trace(host, Diagnostics.Skipping_module_0_that_looks_like_an_absolute_URI_target_file_types_Colon_1, moduleName, formatExtensions(extensions2));
-            }
-            return void 0;
-          }
-          if (traceEnabled) {
-            trace(host, Diagnostics.Loading_module_0_from_node_modules_folder_target_file_types_Colon_1, moduleName, formatExtensions(extensions2));
-          }
-          resolved2 = loadModuleFromNearestNodeModulesDirectory(extensions2, moduleName, containingDirectory, state2, cache, redirectedReference);
-        }
-        if (extensions2 & 4 /* Declaration */) {
-          resolved2 ?? (resolved2 = resolveFromTypeRoot(moduleName, state2));
-        }
-        return resolved2 && { value: resolved2.value && { resolved: resolved2.value, isExternalLibraryImport: true } };
-      } else {
-        const { path: candidate, parts } = normalizePathForCJSResolution(containingDirectory, moduleName);
-        const resolved2 = nodeLoadModuleByRelativeName(
-          extensions2,
-          candidate,
-          /*onlyRecordFailures*/
-          false,
-          state2,
-          /*considerPackageJson*/
-          true
-        );
-        return resolved2 && toSearchResult({ resolved: resolved2, isExternalLibraryImport: contains(parts, "node_modules") });
-      }
-    }
-  }
-  function normalizePathForCJSResolution(containingDirectory, moduleName) {
-    const combined = combinePaths(containingDirectory, moduleName);
-    const parts = getPathComponents(combined);
-    const lastPart = lastOrUndefined(parts);
-    const path = lastPart === "." || lastPart === ".." ? ensureTrailingDirectorySeparator(normalizePath(combined)) : normalizePath(combined);
-    return { path, parts };
-  }
-  function realPath(path, host, traceEnabled) {
-    if (!host.realpath) {
-      return path;
-    }
-    const real = normalizePath(host.realpath(path));
-    if (traceEnabled) {
-      trace(host, Diagnostics.Resolving_real_path_for_0_result_1, path, real);
-    }
-    Debug.assert(host.fileExists(real), `${path} linked to nonexistent file ${real}`);
-    return real;
-  }
-  function nodeLoadModuleByRelativeName(extensions, candidate, onlyRecordFailures, state, considerPackageJson) {
-    if (state.traceEnabled) {
-      trace(state.host, Diagnostics.Loading_module_as_file_Slash_folder_candidate_module_location_0_target_file_types_Colon_1, candidate, formatExtensions(extensions));
-    }
-    if (!hasTrailingDirectorySeparator(candidate)) {
-      if (!onlyRecordFailures) {
-        const parentOfCandidate = getDirectoryPath(candidate);
-        if (!directoryProbablyExists(parentOfCandidate, state.host)) {
-          if (state.traceEnabled) {
-            trace(state.host, Diagnostics.Directory_0_does_not_exist_skipping_all_lookups_in_it, parentOfCandidate);
-          }
-          onlyRecordFailures = true;
-        }
-      }
-      const resolvedFromFile = loadModuleFromFile(extensions, candidate, onlyRecordFailures, state);
-      if (resolvedFromFile) {
-        const packageDirectory = considerPackageJson ? parseNodeModuleFromPath(resolvedFromFile.path) : void 0;
-        const packageInfo = packageDirectory ? getPackageJsonInfo(
-          packageDirectory,
-          /*onlyRecordFailures*/
-          false,
-          state
-        ) : void 0;
-        return withPackageId(packageInfo, resolvedFromFile);
-      }
-    }
-    if (!onlyRecordFailures) {
-      const candidateExists = directoryProbablyExists(candidate, state.host);
-      if (!candidateExists) {
-        if (state.traceEnabled) {
-          trace(state.host, Diagnostics.Directory_0_does_not_exist_skipping_all_lookups_in_it, candidate);
-        }
-        onlyRecordFailures = true;
-      }
-    }
-    if (!(state.features & 32 /* EsmMode */)) {
-      return loadNodeModuleFromDirectory(extensions, candidate, onlyRecordFailures, state, considerPackageJson);
-    }
-    return void 0;
-  }
-  function pathContainsNodeModules(path) {
-    return stringContains(path, nodeModulesPathPart);
-  }
-  function parseNodeModuleFromPath(resolved, isFolder) {
-    const path = normalizePath(resolved);
-    const idx = path.lastIndexOf(nodeModulesPathPart);
-    if (idx === -1) {
-      return void 0;
-    }
-    const indexAfterNodeModules = idx + nodeModulesPathPart.length;
-    let indexAfterPackageName = moveToNextDirectorySeparatorIfAvailable(path, indexAfterNodeModules, isFolder);
-    if (path.charCodeAt(indexAfterNodeModules) === 64 /* at */) {
-      indexAfterPackageName = moveToNextDirectorySeparatorIfAvailable(path, indexAfterPackageName, isFolder);
-    }
-    return path.slice(0, indexAfterPackageName);
-  }
-  function moveToNextDirectorySeparatorIfAvailable(path, prevSeparatorIndex, isFolder) {
-    const nextSeparatorIndex = path.indexOf(directorySeparator, prevSeparatorIndex + 1);
-    return nextSeparatorIndex === -1 ? isFolder ? path.length : prevSeparatorIndex : nextSeparatorIndex;
-  }
-  function loadModuleFromFileNoPackageId(extensions, candidate, onlyRecordFailures, state) {
-    return noPackageId(loadModuleFromFile(extensions, candidate, onlyRecordFailures, state));
-  }
-  function loadModuleFromFile(extensions, candidate, onlyRecordFailures, state) {
-    const resolvedByReplacingExtension = loadModuleFromFileNoImplicitExtensions(extensions, candidate, onlyRecordFailures, state);
-    if (resolvedByReplacingExtension) {
-      return resolvedByReplacingExtension;
-    }
-    if (!(state.features & 32 /* EsmMode */)) {
-      const resolvedByAddingExtension = tryAddingExtensions(candidate, extensions, "", onlyRecordFailures, state);
-      if (resolvedByAddingExtension) {
-        return resolvedByAddingExtension;
-      }
-    }
-  }
-  function loadModuleFromFileNoImplicitExtensions(extensions, candidate, onlyRecordFailures, state) {
-    const filename = getBaseFileName(candidate);
-    if (filename.indexOf(".") === -1) {
-      return void 0;
-    }
-    let extensionless = removeFileExtension(candidate);
-    if (extensionless === candidate) {
-      extensionless = candidate.substring(0, candidate.lastIndexOf("."));
-    }
-    const extension = candidate.substring(extensionless.length);
-    if (state.traceEnabled) {
-      trace(state.host, Diagnostics.File_name_0_has_a_1_extension_stripping_it, candidate, extension);
-    }
-    return tryAddingExtensions(extensionless, extensions, extension, onlyRecordFailures, state);
-  }
-  function loadFileNameFromPackageJsonField(extensions, candidate, onlyRecordFailures, state) {
-    if (extensions & 1 /* TypeScript */ && fileExtensionIsOneOf(candidate, supportedTSImplementationExtensions) || extensions & 4 /* Declaration */ && fileExtensionIsOneOf(candidate, supportedDeclarationExtensions)) {
-      const result = tryFile(candidate, onlyRecordFailures, state);
-      return result !== void 0 ? { path: candidate, ext: tryExtractTSExtension(candidate), resolvedUsingTsExtension: void 0 } : void 0;
-    }
-    if (state.isConfigLookup && extensions === 8 /* Json */ && fileExtensionIs(candidate, ".json" /* Json */)) {
-      const result = tryFile(candidate, onlyRecordFailures, state);
-      return result !== void 0 ? { path: candidate, ext: ".json" /* Json */, resolvedUsingTsExtension: void 0 } : void 0;
-    }
-    return loadModuleFromFileNoImplicitExtensions(extensions, candidate, onlyRecordFailures, state);
-  }
-  function tryAddingExtensions(candidate, extensions, originalExtension, onlyRecordFailures, state) {
-    if (!onlyRecordFailures) {
-      const directory = getDirectoryPath(candidate);
-      if (directory) {
-        onlyRecordFailures = !directoryProbablyExists(directory, state.host);
-      }
-    }
-    switch (originalExtension) {
-      case ".mjs" /* Mjs */:
-      case ".mts" /* Mts */:
-      case ".d.mts" /* Dmts */:
-        return extensions & 1 /* TypeScript */ && tryExtension(".mts" /* Mts */, originalExtension === ".mts" /* Mts */ || originalExtension === ".d.mts" /* Dmts */) || extensions & 4 /* Declaration */ && tryExtension(".d.mts" /* Dmts */, originalExtension === ".mts" /* Mts */ || originalExtension === ".d.mts" /* Dmts */) || extensions & 2 /* JavaScript */ && tryExtension(".mjs" /* Mjs */) || void 0;
-      case ".cjs" /* Cjs */:
-      case ".cts" /* Cts */:
-      case ".d.cts" /* Dcts */:
-        return extensions & 1 /* TypeScript */ && tryExtension(".cts" /* Cts */, originalExtension === ".cts" /* Cts */ || originalExtension === ".d.cts" /* Dcts */) || extensions & 4 /* Declaration */ && tryExtension(".d.cts" /* Dcts */, originalExtension === ".cts" /* Cts */ || originalExtension === ".d.cts" /* Dcts */) || extensions & 2 /* JavaScript */ && tryExtension(".cjs" /* Cjs */) || void 0;
-      case ".json" /* Json */:
-        return extensions & 4 /* Declaration */ && tryExtension(".d.json.ts") || extensions & 8 /* Json */ && tryExtension(".json" /* Json */) || void 0;
-      case ".tsx" /* Tsx */:
-      case ".jsx" /* Jsx */:
-        return extensions & 1 /* TypeScript */ && (tryExtension(".tsx" /* Tsx */, originalExtension === ".tsx" /* Tsx */) || tryExtension(".ts" /* Ts */, originalExtension === ".tsx" /* Tsx */)) || extensions & 4 /* Declaration */ && tryExtension(".d.ts" /* Dts */, originalExtension === ".tsx" /* Tsx */) || extensions & 2 /* JavaScript */ && (tryExtension(".jsx" /* Jsx */) || tryExtension(".js" /* Js */)) || void 0;
-      case ".ts" /* Ts */:
-      case ".d.ts" /* Dts */:
-      case ".js" /* Js */:
-      case "":
-        return extensions & 1 /* TypeScript */ && (tryExtension(".ts" /* Ts */, originalExtension === ".ts" /* Ts */ || originalExtension === ".d.ts" /* Dts */) || tryExtension(".tsx" /* Tsx */, originalExtension === ".ts" /* Ts */ || originalExtension === ".d.ts" /* Dts */)) || extensions & 4 /* Declaration */ && tryExtension(".d.ts" /* Dts */, originalExtension === ".ts" /* Ts */ || originalExtension === ".d.ts" /* Dts */) || extensions & 2 /* JavaScript */ && (tryExtension(".js" /* Js */) || tryExtension(".jsx" /* Jsx */)) || state.isConfigLookup && tryExtension(".json" /* Json */) || void 0;
-      default:
-        return extensions & 4 /* Declaration */ && !isDeclarationFileName(candidate + originalExtension) && tryExtension(`.d${originalExtension}.ts`) || void 0;
-    }
-    function tryExtension(ext, resolvedUsingTsExtension) {
-      const path = tryFile(candidate + ext, onlyRecordFailures, state);
-      return path === void 0 ? void 0 : { path, ext, resolvedUsingTsExtension: !state.candidateIsFromPackageJsonField && resolvedUsingTsExtension };
-    }
-  }
-  function tryFile(fileName, onlyRecordFailures, state) {
-    var _a;
-    if (!((_a = state.compilerOptions.moduleSuffixes) == null ? void 0 : _a.length)) {
-      return tryFileLookup(fileName, onlyRecordFailures, state);
-    }
-    const ext = tryGetExtensionFromPath2(fileName) ?? "";
-    const fileNameNoExtension = ext ? removeExtension(fileName, ext) : fileName;
-    return forEach(state.compilerOptions.moduleSuffixes, (suffix) => tryFileLookup(fileNameNoExtension + suffix + ext, onlyRecordFailures, state));
-  }
-  function tryFileLookup(fileName, onlyRecordFailures, state) {
-    var _a;
-    if (!onlyRecordFailures) {
-      if (state.host.fileExists(fileName)) {
-        if (state.traceEnabled) {
-          trace(state.host, Diagnostics.File_0_exists_use_it_as_a_name_resolution_result, fileName);
-        }
-        return fileName;
-      } else {
-        if (state.traceEnabled) {
-          trace(state.host, Diagnostics.File_0_does_not_exist, fileName);
-        }
-      }
-    }
-    (_a = state.failedLookupLocations) == null ? void 0 : _a.push(fileName);
-    return void 0;
-  }
-  function loadNodeModuleFromDirectory(extensions, candidate, onlyRecordFailures, state, considerPackageJson = true) {
-    const packageInfo = considerPackageJson ? getPackageJsonInfo(candidate, onlyRecordFailures, state) : void 0;
-    const packageJsonContent = packageInfo && packageInfo.contents.packageJsonContent;
-    const versionPaths = packageInfo && getVersionPathsOfPackageJsonInfo(packageInfo, state);
-    return withPackageId(packageInfo, loadNodeModuleFromDirectoryWorker(extensions, candidate, onlyRecordFailures, state, packageJsonContent, versionPaths));
-  }
-  function getEntrypointsFromPackageJsonInfo(packageJsonInfo, options, host, cache, resolveJs) {
-    if (!resolveJs && packageJsonInfo.contents.resolvedEntrypoints !== void 0) {
-      return packageJsonInfo.contents.resolvedEntrypoints;
-    }
-    let entrypoints;
-    const extensions = 1 /* TypeScript */ | 4 /* Declaration */ | (resolveJs ? 2 /* JavaScript */ : 0);
-    const features = getNodeResolutionFeatures(options);
-    const loadPackageJsonMainState = getTemporaryModuleResolutionState(cache == null ? void 0 : cache.getPackageJsonInfoCache(), host, options);
-    loadPackageJsonMainState.conditions = getConditions(options);
-    loadPackageJsonMainState.requestContainingDirectory = packageJsonInfo.packageDirectory;
-    const mainResolution = loadNodeModuleFromDirectoryWorker(
-      extensions,
-      packageJsonInfo.packageDirectory,
-      /*onlyRecordFailures*/
-      false,
-      loadPackageJsonMainState,
-      packageJsonInfo.contents.packageJsonContent,
-      getVersionPathsOfPackageJsonInfo(packageJsonInfo, loadPackageJsonMainState)
-    );
-    entrypoints = append(entrypoints, mainResolution == null ? void 0 : mainResolution.path);
-    if (features & 8 /* Exports */ && packageJsonInfo.contents.packageJsonContent.exports) {
-      const conditionSets = deduplicate(
-        [getConditions(
-          options,
-          /*esmMode*/
-          true
-        ), getConditions(
-          options,
-          /*esmMode*/
-          false
-        )],
-        arrayIsEqualTo
-      );
-      for (const conditions of conditionSets) {
-        const loadPackageJsonExportsState = { ...loadPackageJsonMainState, failedLookupLocations: [], conditions };
-        const exportResolutions = loadEntrypointsFromExportMap(
-          packageJsonInfo,
-          packageJsonInfo.contents.packageJsonContent.exports,
-          loadPackageJsonExportsState,
-          extensions
-        );
-        if (exportResolutions) {
-          for (const resolution of exportResolutions) {
-            entrypoints = appendIfUnique(entrypoints, resolution.path);
-          }
-        }
-      }
-    }
-    return packageJsonInfo.contents.resolvedEntrypoints = entrypoints || false;
-  }
-  function loadEntrypointsFromExportMap(scope, exports, state, extensions) {
-    let entrypoints;
-    if (isArray(exports)) {
-      for (const target of exports) {
-        loadEntrypointsFromTargetExports(target);
-      }
-    } else if (typeof exports === "object" && exports !== null && allKeysStartWithDot(exports)) {
-      for (const key in exports) {
-        loadEntrypointsFromTargetExports(exports[key]);
-      }
-    } else {
-      loadEntrypointsFromTargetExports(exports);
-    }
-    return entrypoints;
-    function loadEntrypointsFromTargetExports(target) {
-      var _a, _b;
-      if (typeof target === "string" && startsWith(target, "./") && target.indexOf("*") === -1) {
-        const partsAfterFirst = getPathComponents(target).slice(2);
-        if (partsAfterFirst.indexOf("..") >= 0 || partsAfterFirst.indexOf(".") >= 0 || partsAfterFirst.indexOf("node_modules") >= 0) {
-          return false;
-        }
-        const resolvedTarget = combinePaths(scope.packageDirectory, target);
-        const finalPath = getNormalizedAbsolutePath(resolvedTarget, (_b = (_a = state.host).getCurrentDirectory) == null ? void 0 : _b.call(_a));
-        const result = loadFileNameFromPackageJsonField(
-          extensions,
-          finalPath,
-          /*onlyRecordFailures*/
-          false,
-          state
-        );
-        if (result) {
-          entrypoints = appendIfUnique(entrypoints, result, (a, b) => a.path === b.path);
-          return true;
-        }
-      } else if (Array.isArray(target)) {
-        for (const t of target) {
-          const success = loadEntrypointsFromTargetExports(t);
-          if (success) {
-            return true;
-          }
-        }
-      } else if (typeof target === "object" && target !== null) {
-        return forEach(getOwnKeys(target), (key) => {
-          if (key === "default" || contains(state.conditions, key) || isApplicableVersionedTypesKey(state.conditions, key)) {
-            loadEntrypointsFromTargetExports(target[key]);
-            return true;
-          }
-        });
-      }
-    }
-  }
-  function getTemporaryModuleResolutionState(packageJsonInfoCache, host, options) {
-    return {
-      host,
-      compilerOptions: options,
-      traceEnabled: isTraceEnabled(options, host),
-      failedLookupLocations: void 0,
-      affectingLocations: void 0,
-      packageJsonInfoCache,
-      features: 0 /* None */,
-      conditions: emptyArray,
-      requestContainingDirectory: void 0,
-      reportDiagnostic: noop,
-      isConfigLookup: false,
-      candidateIsFromPackageJsonField: false
-    };
-  }
-  function getPackageScopeForPath(fileName, state) {
-    const parts = getPathComponents(fileName);
-    parts.pop();
-    while (parts.length > 0) {
-      const pkg = getPackageJsonInfo(
-        getPathFromPathComponents(parts),
-        /*onlyRecordFailures*/
-        false,
-        state
-      );
-      if (pkg) {
-        return pkg;
-      }
-      parts.pop();
-    }
-    return void 0;
-  }
-  function getVersionPathsOfPackageJsonInfo(packageJsonInfo, state) {
-    if (packageJsonInfo.contents.versionPaths === void 0) {
-      packageJsonInfo.contents.versionPaths = readPackageJsonTypesVersionPaths(packageJsonInfo.contents.packageJsonContent, state) || false;
-    }
-    return packageJsonInfo.contents.versionPaths || void 0;
-  }
-  function getPackageJsonInfo(packageDirectory, onlyRecordFailures, state) {
-    var _a, _b, _c, _d, _e, _f, _g, _h;
-    const { host, traceEnabled } = state;
-    const packageJsonPath = combinePaths(packageDirectory, "package.json");
-    if (onlyRecordFailures) {
-      (_a = state.failedLookupLocations) == null ? void 0 : _a.push(packageJsonPath);
-      return void 0;
-    }
-    const existing = (_b = state.packageJsonInfoCache) == null ? void 0 : _b.getPackageJsonInfo(packageJsonPath);
-    if (existing !== void 0) {
-      if (typeof existing !== "boolean") {
-        if (traceEnabled)
-          trace(host, Diagnostics.File_0_exists_according_to_earlier_cached_lookups, packageJsonPath);
-        (_c = state.affectingLocations) == null ? void 0 : _c.push(packageJsonPath);
-        return existing.packageDirectory === packageDirectory ? existing : { packageDirectory, contents: existing.contents };
-      } else {
-        if (existing && traceEnabled)
-          trace(host, Diagnostics.File_0_does_not_exist_according_to_earlier_cached_lookups, packageJsonPath);
-        (_d = state.failedLookupLocations) == null ? void 0 : _d.push(packageJsonPath);
-        return void 0;
-      }
-    }
-    const directoryExists = directoryProbablyExists(packageDirectory, host);
-    if (directoryExists && host.fileExists(packageJsonPath)) {
-      const packageJsonContent = readJson(packageJsonPath, host);
-      if (traceEnabled) {
-        trace(host, Diagnostics.Found_package_json_at_0, packageJsonPath);
-      }
-      const result = { packageDirectory, contents: { packageJsonContent, versionPaths: void 0, resolvedEntrypoints: void 0 } };
-      (_e = state.packageJsonInfoCache) == null ? void 0 : _e.setPackageJsonInfo(packageJsonPath, result);
-      (_f = state.affectingLocations) == null ? void 0 : _f.push(packageJsonPath);
-      return result;
-    } else {
-      if (directoryExists && traceEnabled) {
-        trace(host, Diagnostics.File_0_does_not_exist, packageJsonPath);
-      }
-      (_g = state.packageJsonInfoCache) == null ? void 0 : _g.setPackageJsonInfo(packageJsonPath, directoryExists);
-      (_h = state.failedLookupLocations) == null ? void 0 : _h.push(packageJsonPath);
-    }
-  }
-  function loadNodeModuleFromDirectoryWorker(extensions, candidate, onlyRecordFailures, state, jsonContent, versionPaths) {
-    let packageFile;
-    if (jsonContent) {
-      if (state.isConfigLookup) {
-        packageFile = readPackageJsonTSConfigField(jsonContent, candidate, state);
-      } else {
-        packageFile = extensions & 4 /* Declaration */ && readPackageJsonTypesFields(jsonContent, candidate, state) || extensions & (3 /* ImplementationFiles */ | 4 /* Declaration */) && readPackageJsonMainField(jsonContent, candidate, state) || void 0;
-      }
-    }
-    const loader = (extensions2, candidate2, onlyRecordFailures2, state2) => {
-      const fromFile = tryFile(candidate2, onlyRecordFailures2, state2);
-      if (fromFile) {
-        const resolved = resolvedIfExtensionMatches(extensions2, fromFile);
-        if (resolved) {
-          return noPackageId(resolved);
-        }
-        if (state2.traceEnabled) {
-          trace(state2.host, Diagnostics.File_0_has_an_unsupported_extension_so_skipping_it, fromFile);
-        }
-      }
-      const expandedExtensions = extensions2 === 4 /* Declaration */ ? 1 /* TypeScript */ | 4 /* Declaration */ : extensions2;
-      const features = state2.features;
-      const candidateIsFromPackageJsonField = state2.candidateIsFromPackageJsonField;
-      state2.candidateIsFromPackageJsonField = true;
-      if ((jsonContent == null ? void 0 : jsonContent.type) !== "module") {
-        state2.features &= ~32 /* EsmMode */;
-      }
-      const result = nodeLoadModuleByRelativeName(
-        expandedExtensions,
-        candidate2,
-        onlyRecordFailures2,
-        state2,
-        /*considerPackageJson*/
-        false
-      );
-      state2.features = features;
-      state2.candidateIsFromPackageJsonField = candidateIsFromPackageJsonField;
-      return result;
-    };
-    const onlyRecordFailuresForPackageFile = packageFile ? !directoryProbablyExists(getDirectoryPath(packageFile), state.host) : void 0;
-    const onlyRecordFailuresForIndex = onlyRecordFailures || !directoryProbablyExists(candidate, state.host);
-    const indexPath = combinePaths(candidate, state.isConfigLookup ? "tsconfig" : "index");
-    if (versionPaths && (!packageFile || containsPath(candidate, packageFile))) {
-      const moduleName = getRelativePathFromDirectory(
-        candidate,
-        packageFile || indexPath,
-        /*ignoreCase*/
-        false
-      );
-      if (state.traceEnabled) {
-        trace(state.host, Diagnostics.package_json_has_a_typesVersions_entry_0_that_matches_compiler_version_1_looking_for_a_pattern_to_match_module_name_2, versionPaths.version, version, moduleName);
-      }
-      const result = tryLoadModuleUsingPaths(
-        extensions,
-        moduleName,
-        candidate,
-        versionPaths.paths,
-        /*pathPatterns*/
-        void 0,
-        loader,
-        onlyRecordFailuresForPackageFile || onlyRecordFailuresForIndex,
-        state
-      );
-      if (result) {
-        return removeIgnoredPackageId(result.value);
-      }
-    }
-    const packageFileResult = packageFile && removeIgnoredPackageId(loader(extensions, packageFile, onlyRecordFailuresForPackageFile, state));
-    if (packageFileResult)
-      return packageFileResult;
-    if (!(state.features & 32 /* EsmMode */)) {
-      return loadModuleFromFile(extensions, indexPath, onlyRecordFailuresForIndex, state);
-    }
-  }
-  function resolvedIfExtensionMatches(extensions, path, resolvedUsingTsExtension) {
-    const ext = tryGetExtensionFromPath2(path);
-    return ext !== void 0 && extensionIsOk(extensions, ext) ? { path, ext, resolvedUsingTsExtension } : void 0;
-  }
-  function extensionIsOk(extensions, extension) {
-    return extensions & 2 /* JavaScript */ && (extension === ".js" /* Js */ || extension === ".jsx" /* Jsx */ || extension === ".mjs" /* Mjs */ || extension === ".cjs" /* Cjs */) || extensions & 1 /* TypeScript */ && (extension === ".ts" /* Ts */ || extension === ".tsx" /* Tsx */ || extension === ".mts" /* Mts */ || extension === ".cts" /* Cts */) || extensions & 4 /* Declaration */ && (extension === ".d.ts" /* Dts */ || extension === ".d.mts" /* Dmts */ || extension === ".d.cts" /* Dcts */) || extensions & 8 /* Json */ && extension === ".json" /* Json */ || false;
-  }
-  function parsePackageName(moduleName) {
-    let idx = moduleName.indexOf(directorySeparator);
-    if (moduleName[0] === "@") {
-      idx = moduleName.indexOf(directorySeparator, idx + 1);
-    }
-    return idx === -1 ? { packageName: moduleName, rest: "" } : { packageName: moduleName.slice(0, idx), rest: moduleName.slice(idx + 1) };
-  }
-  function allKeysStartWithDot(obj) {
-    return every(getOwnKeys(obj), (k) => startsWith(k, "."));
-  }
-  function noKeyStartsWithDot(obj) {
-    return !some(getOwnKeys(obj), (k) => startsWith(k, "."));
-  }
-  function loadModuleFromSelfNameReference(extensions, moduleName, directory, state, cache, redirectedReference) {
-    var _a, _b;
-    const directoryPath = getNormalizedAbsolutePath(combinePaths(directory, "dummy"), (_b = (_a = state.host).getCurrentDirectory) == null ? void 0 : _b.call(_a));
-    const scope = getPackageScopeForPath(directoryPath, state);
-    if (!scope || !scope.contents.packageJsonContent.exports) {
-      return void 0;
-    }
-    if (typeof scope.contents.packageJsonContent.name !== "string") {
-      return void 0;
-    }
-    const parts = getPathComponents(moduleName);
-    const nameParts = getPathComponents(scope.contents.packageJsonContent.name);
-    if (!every(nameParts, (p, i) => parts[i] === p)) {
-      return void 0;
-    }
-    const trailingParts = parts.slice(nameParts.length);
-    const subpath = !length(trailingParts) ? "." : `.${directorySeparator}${trailingParts.join(directorySeparator)}`;
-    const priorityExtensions = extensions & (1 /* TypeScript */ | 4 /* Declaration */);
-    const secondaryExtensions = extensions & ~(1 /* TypeScript */ | 4 /* Declaration */);
-    return loadModuleFromExports(scope, priorityExtensions, subpath, state, cache, redirectedReference) || loadModuleFromExports(scope, secondaryExtensions, subpath, state, cache, redirectedReference);
-  }
-  function loadModuleFromExports(scope, extensions, subpath, state, cache, redirectedReference) {
-    if (!scope.contents.packageJsonContent.exports) {
-      return void 0;
-    }
-    if (subpath === ".") {
-      let mainExport;
-      if (typeof scope.contents.packageJsonContent.exports === "string" || Array.isArray(scope.contents.packageJsonContent.exports) || typeof scope.contents.packageJsonContent.exports === "object" && noKeyStartsWithDot(scope.contents.packageJsonContent.exports)) {
-        mainExport = scope.contents.packageJsonContent.exports;
-      } else if (hasProperty(scope.contents.packageJsonContent.exports, ".")) {
-        mainExport = scope.contents.packageJsonContent.exports["."];
-      }
-      if (mainExport) {
-        const loadModuleFromTargetImportOrExport = getLoadModuleFromTargetImportOrExport(
-          extensions,
-          state,
-          cache,
-          redirectedReference,
-          subpath,
-          scope,
-          /*isImports*/
-          false
-        );
-        return loadModuleFromTargetImportOrExport(
-          mainExport,
-          "",
-          /*pattern*/
-          false,
-          "."
-        );
-      }
-    } else if (allKeysStartWithDot(scope.contents.packageJsonContent.exports)) {
-      if (typeof scope.contents.packageJsonContent.exports !== "object") {
-        if (state.traceEnabled) {
-          trace(state.host, Diagnostics.Export_specifier_0_does_not_exist_in_package_json_scope_at_path_1, subpath, scope.packageDirectory);
-        }
-        return toSearchResult(
-          /*value*/
-          void 0
-        );
-      }
-      const result = loadModuleFromImportsOrExports(
-        extensions,
-        state,
-        cache,
-        redirectedReference,
-        subpath,
-        scope.contents.packageJsonContent.exports,
-        scope,
-        /*isImports*/
-        false
-      );
-      if (result) {
-        return result;
-      }
-    }
-    if (state.traceEnabled) {
-      trace(state.host, Diagnostics.Export_specifier_0_does_not_exist_in_package_json_scope_at_path_1, subpath, scope.packageDirectory);
-    }
-    return toSearchResult(
-      /*value*/
-      void 0
-    );
-  }
-  function loadModuleFromImports(extensions, moduleName, directory, state, cache, redirectedReference) {
-    var _a, _b;
-    if (moduleName === "#" || startsWith(moduleName, "#/")) {
-      if (state.traceEnabled) {
-        trace(state.host, Diagnostics.Invalid_import_specifier_0_has_no_possible_resolutions, moduleName);
-      }
-      return toSearchResult(
-        /*value*/
-        void 0
-      );
-    }
-    const directoryPath = getNormalizedAbsolutePath(combinePaths(directory, "dummy"), (_b = (_a = state.host).getCurrentDirectory) == null ? void 0 : _b.call(_a));
-    const scope = getPackageScopeForPath(directoryPath, state);
-    if (!scope) {
-      if (state.traceEnabled) {
-        trace(state.host, Diagnostics.Directory_0_has_no_containing_package_json_scope_Imports_will_not_resolve, directoryPath);
-      }
-      return toSearchResult(
-        /*value*/
-        void 0
-      );
-    }
-    if (!scope.contents.packageJsonContent.imports) {
-      if (state.traceEnabled) {
-        trace(state.host, Diagnostics.package_json_scope_0_has_no_imports_defined, scope.packageDirectory);
-      }
-      return toSearchResult(
-        /*value*/
-        void 0
-      );
-    }
-    const result = loadModuleFromImportsOrExports(
-      extensions,
-      state,
-      cache,
-      redirectedReference,
-      moduleName,
-      scope.contents.packageJsonContent.imports,
-      scope,
-      /*isImports*/
-      true
-    );
-    if (result) {
-      return result;
-    }
-    if (state.traceEnabled) {
-      trace(state.host, Diagnostics.Import_specifier_0_does_not_exist_in_package_json_scope_at_path_1, moduleName, scope.packageDirectory);
-    }
-    return toSearchResult(
-      /*value*/
-      void 0
-    );
-  }
-  function comparePatternKeys(a, b) {
-    const aPatternIndex = a.indexOf("*");
-    const bPatternIndex = b.indexOf("*");
-    const baseLenA = aPatternIndex === -1 ? a.length : aPatternIndex + 1;
-    const baseLenB = bPatternIndex === -1 ? b.length : bPatternIndex + 1;
-    if (baseLenA > baseLenB)
-      return -1;
-    if (baseLenB > baseLenA)
-      return 1;
-    if (aPatternIndex === -1)
-      return 1;
-    if (bPatternIndex === -1)
-      return -1;
-    if (a.length > b.length)
-      return -1;
-    if (b.length > a.length)
-      return 1;
-    return 0;
-  }
-  function loadModuleFromImportsOrExports(extensions, state, cache, redirectedReference, moduleName, lookupTable, scope, isImports) {
-    const loadModuleFromTargetImportOrExport = getLoadModuleFromTargetImportOrExport(extensions, state, cache, redirectedReference, moduleName, scope, isImports);
-    if (!endsWith(moduleName, directorySeparator) && moduleName.indexOf("*") === -1 && hasProperty(lookupTable, moduleName)) {
-      const target = lookupTable[moduleName];
-      return loadModuleFromTargetImportOrExport(
-        target,
-        /*subpath*/
-        "",
-        /*pattern*/
-        false,
-        moduleName
-      );
-    }
-    const expandingKeys = sort(filter(getOwnKeys(lookupTable), (k) => k.indexOf("*") !== -1 || endsWith(k, "/")), comparePatternKeys);
-    for (const potentialTarget of expandingKeys) {
-      if (state.features & 16 /* ExportsPatternTrailers */ && matchesPatternWithTrailer(potentialTarget, moduleName)) {
-        const target = lookupTable[potentialTarget];
-        const starPos = potentialTarget.indexOf("*");
-        const subpath = moduleName.substring(potentialTarget.substring(0, starPos).length, moduleName.length - (potentialTarget.length - 1 - starPos));
-        return loadModuleFromTargetImportOrExport(
-          target,
-          subpath,
-          /*pattern*/
-          true,
-          potentialTarget
-        );
-      } else if (endsWith(potentialTarget, "*") && startsWith(moduleName, potentialTarget.substring(0, potentialTarget.length - 1))) {
-        const target = lookupTable[potentialTarget];
-        const subpath = moduleName.substring(potentialTarget.length - 1);
-        return loadModuleFromTargetImportOrExport(
-          target,
-          subpath,
-          /*pattern*/
-          true,
-          potentialTarget
-        );
-      } else if (startsWith(moduleName, potentialTarget)) {
-        const target = lookupTable[potentialTarget];
-        const subpath = moduleName.substring(potentialTarget.length);
-        return loadModuleFromTargetImportOrExport(
-          target,
-          subpath,
-          /*pattern*/
-          false,
-          potentialTarget
-        );
-      }
-    }
-    function matchesPatternWithTrailer(target, name) {
-      if (endsWith(target, "*"))
-        return false;
-      const starPos = target.indexOf("*");
-      if (starPos === -1)
-        return false;
-      return startsWith(name, target.substring(0, starPos)) && endsWith(name, target.substring(starPos + 1));
-    }
-  }
-  function getLoadModuleFromTargetImportOrExport(extensions, state, cache, redirectedReference, moduleName, scope, isImports) {
-    return loadModuleFromTargetImportOrExport;
-    function loadModuleFromTargetImportOrExport(target, subpath, pattern, key) {
-      if (typeof target === "string") {
-        if (!pattern && subpath.length > 0 && !endsWith(target, "/")) {
-          if (state.traceEnabled) {
-            trace(state.host, Diagnostics.package_json_scope_0_has_invalid_type_for_target_of_specifier_1, scope.packageDirectory, moduleName);
-          }
-          return toSearchResult(
-            /*value*/
-            void 0
-          );
-        }
-        if (!startsWith(target, "./")) {
-          if (isImports && !startsWith(target, "../") && !startsWith(target, "/") && !isRootedDiskPath(target)) {
-            const combinedLookup = pattern ? target.replace(/\*/g, subpath) : target + subpath;
-            traceIfEnabled(state, Diagnostics.Using_0_subpath_1_with_target_2, "imports", key, combinedLookup);
-            traceIfEnabled(state, Diagnostics.Resolving_module_0_from_1, combinedLookup, scope.packageDirectory + "/");
-            const result = nodeModuleNameResolverWorker(
-              state.features,
-              combinedLookup,
-              scope.packageDirectory + "/",
-              state.compilerOptions,
-              state.host,
-              cache,
-              extensions,
-              /*isConfigLookup*/
-              false,
-              redirectedReference
-            );
-            return toSearchResult(result.resolvedModule ? {
-              path: result.resolvedModule.resolvedFileName,
-              extension: result.resolvedModule.extension,
-              packageId: result.resolvedModule.packageId,
-              originalPath: result.resolvedModule.originalPath,
-              resolvedUsingTsExtension: result.resolvedModule.resolvedUsingTsExtension
-            } : void 0);
-          }
-          if (state.traceEnabled) {
-            trace(state.host, Diagnostics.package_json_scope_0_has_invalid_type_for_target_of_specifier_1, scope.packageDirectory, moduleName);
-          }
-          return toSearchResult(
-            /*value*/
-            void 0
-          );
-        }
-        const parts = pathIsRelative(target) ? getPathComponents(target).slice(1) : getPathComponents(target);
-        const partsAfterFirst = parts.slice(1);
-        if (partsAfterFirst.indexOf("..") >= 0 || partsAfterFirst.indexOf(".") >= 0 || partsAfterFirst.indexOf("node_modules") >= 0) {
-          if (state.traceEnabled) {
-            trace(state.host, Diagnostics.package_json_scope_0_has_invalid_type_for_target_of_specifier_1, scope.packageDirectory, moduleName);
-          }
-          return toSearchResult(
-            /*value*/
-            void 0
-          );
-        }
-        const resolvedTarget = combinePaths(scope.packageDirectory, target);
-        const subpathParts = getPathComponents(subpath);
-        if (subpathParts.indexOf("..") >= 0 || subpathParts.indexOf(".") >= 0 || subpathParts.indexOf("node_modules") >= 0) {
-          if (state.traceEnabled) {
-            trace(state.host, Diagnostics.package_json_scope_0_has_invalid_type_for_target_of_specifier_1, scope.packageDirectory, moduleName);
-          }
-          return toSearchResult(
-            /*value*/
-            void 0
-          );
-        }
-        if (state.traceEnabled) {
-          trace(
-            state.host,
-            Diagnostics.Using_0_subpath_1_with_target_2,
-            isImports ? "imports" : "exports",
-            key,
-            pattern ? target.replace(/\*/g, subpath) : target + subpath
-          );
-        }
-        const finalPath = toAbsolutePath(pattern ? resolvedTarget.replace(/\*/g, subpath) : resolvedTarget + subpath);
-        const inputLink = tryLoadInputFileForPath(finalPath, subpath, combinePaths(scope.packageDirectory, "package.json"), isImports);
-        if (inputLink)
-          return inputLink;
-        return toSearchResult(withPackageId(scope, loadFileNameFromPackageJsonField(
-          extensions,
-          finalPath,
-          /*onlyRecordFailures*/
-          false,
-          state
-        )));
-      } else if (typeof target === "object" && target !== null) {
-        if (!Array.isArray(target)) {
-          traceIfEnabled(state, Diagnostics.Entering_conditional_exports);
-          for (const condition of getOwnKeys(target)) {
-            if (condition === "default" || state.conditions.indexOf(condition) >= 0 || isApplicableVersionedTypesKey(state.conditions, condition)) {
-              traceIfEnabled(state, Diagnostics.Matched_0_condition_1, isImports ? "imports" : "exports", condition);
-              const subTarget = target[condition];
-              const result = loadModuleFromTargetImportOrExport(subTarget, subpath, pattern, key);
-              if (result) {
-                traceIfEnabled(state, Diagnostics.Resolved_under_condition_0, condition);
-                traceIfEnabled(state, Diagnostics.Exiting_conditional_exports);
-                return result;
-              } else {
-                traceIfEnabled(state, Diagnostics.Failed_to_resolve_under_condition_0, condition);
-              }
-            } else {
-              traceIfEnabled(state, Diagnostics.Saw_non_matching_condition_0, condition);
-            }
-          }
-          traceIfEnabled(state, Diagnostics.Exiting_conditional_exports);
-          return void 0;
-        } else {
-          if (!length(target)) {
-            if (state.traceEnabled) {
-              trace(state.host, Diagnostics.package_json_scope_0_has_invalid_type_for_target_of_specifier_1, scope.packageDirectory, moduleName);
-            }
-            return toSearchResult(
-              /*value*/
-              void 0
-            );
-          }
-          for (const elem of target) {
-            const result = loadModuleFromTargetImportOrExport(elem, subpath, pattern, key);
-            if (result) {
-              return result;
-            }
-          }
-        }
-      } else if (target === null) {
-        if (state.traceEnabled) {
-          trace(state.host, Diagnostics.package_json_scope_0_explicitly_maps_specifier_1_to_null, scope.packageDirectory, moduleName);
-        }
-        return toSearchResult(
-          /*value*/
-          void 0
-        );
-      }
-      if (state.traceEnabled) {
-        trace(state.host, Diagnostics.package_json_scope_0_has_invalid_type_for_target_of_specifier_1, scope.packageDirectory, moduleName);
-      }
-      return toSearchResult(
-        /*value*/
-        void 0
-      );
-      function toAbsolutePath(path) {
-        var _a, _b;
-        if (path === void 0)
-          return path;
-        return getNormalizedAbsolutePath(path, (_b = (_a = state.host).getCurrentDirectory) == null ? void 0 : _b.call(_a));
-      }
-      function combineDirectoryPath(root, dir) {
-        return ensureTrailingDirectorySeparator(combinePaths(root, dir));
-      }
-      function useCaseSensitiveFileNames() {
-        return !state.host.useCaseSensitiveFileNames ? true : typeof state.host.useCaseSensitiveFileNames === "boolean" ? state.host.useCaseSensitiveFileNames : state.host.useCaseSensitiveFileNames();
-      }
-      function tryLoadInputFileForPath(finalPath, entry, packagePath, isImports2) {
-        var _a, _b, _c, _d;
-        if (!state.isConfigLookup && (state.compilerOptions.declarationDir || state.compilerOptions.outDir) && finalPath.indexOf("/node_modules/") === -1 && (state.compilerOptions.configFile ? containsPath(scope.packageDirectory, toAbsolutePath(state.compilerOptions.configFile.fileName), !useCaseSensitiveFileNames()) : true)) {
-          const getCanonicalFileName = hostGetCanonicalFileName({ useCaseSensitiveFileNames });
-          const commonSourceDirGuesses = [];
-          if (state.compilerOptions.rootDir || state.compilerOptions.composite && state.compilerOptions.configFilePath) {
-            const commonDir = toAbsolutePath(getCommonSourceDirectory(state.compilerOptions, () => [], ((_b = (_a = state.host).getCurrentDirectory) == null ? void 0 : _b.call(_a)) || "", getCanonicalFileName));
-            commonSourceDirGuesses.push(commonDir);
-          } else if (state.requestContainingDirectory) {
-            const requestingFile = toAbsolutePath(combinePaths(state.requestContainingDirectory, "index.ts"));
-            const commonDir = toAbsolutePath(getCommonSourceDirectory(state.compilerOptions, () => [requestingFile, toAbsolutePath(packagePath)], ((_d = (_c = state.host).getCurrentDirectory) == null ? void 0 : _d.call(_c)) || "", getCanonicalFileName));
-            commonSourceDirGuesses.push(commonDir);
-            let fragment = ensureTrailingDirectorySeparator(commonDir);
-            while (fragment && fragment.length > 1) {
-              const parts = getPathComponents(fragment);
-              parts.pop();
-              const commonDir2 = getPathFromPathComponents(parts);
-              commonSourceDirGuesses.unshift(commonDir2);
-              fragment = ensureTrailingDirectorySeparator(commonDir2);
-            }
-          }
-          if (commonSourceDirGuesses.length > 1) {
-            state.reportDiagnostic(createCompilerDiagnostic(
-              isImports2 ? Diagnostics.The_project_root_is_ambiguous_but_is_required_to_resolve_import_map_entry_0_in_file_1_Supply_the_rootDir_compiler_option_to_disambiguate : Diagnostics.The_project_root_is_ambiguous_but_is_required_to_resolve_export_map_entry_0_in_file_1_Supply_the_rootDir_compiler_option_to_disambiguate,
-              entry === "" ? "." : entry,
-              // replace empty string with `.` - the reverse of the operation done when entries are built - so main entrypoint errors don't look weird
-              packagePath
-            ));
-          }
-          for (const commonSourceDirGuess of commonSourceDirGuesses) {
-            const candidateDirectories = getOutputDirectoriesForBaseDirectory(commonSourceDirGuess);
-            for (const candidateDir of candidateDirectories) {
-              if (containsPath(candidateDir, finalPath, !useCaseSensitiveFileNames())) {
-                const pathFragment = finalPath.slice(candidateDir.length + 1);
-                const possibleInputBase = combinePaths(commonSourceDirGuess, pathFragment);
-                const jsAndDtsExtensions = [".mjs" /* Mjs */, ".cjs" /* Cjs */, ".js" /* Js */, ".json" /* Json */, ".d.mts" /* Dmts */, ".d.cts" /* Dcts */, ".d.ts" /* Dts */];
-                for (const ext of jsAndDtsExtensions) {
-                  if (fileExtensionIs(possibleInputBase, ext)) {
-                    const inputExts = getPossibleOriginalInputExtensionForExtension(possibleInputBase);
-                    for (const possibleExt of inputExts) {
-                      if (!extensionIsOk(extensions, possibleExt))
-                        continue;
-                      const possibleInputWithInputExtension = changeAnyExtension(possibleInputBase, possibleExt, ext, !useCaseSensitiveFileNames());
-                      if (state.host.fileExists(possibleInputWithInputExtension)) {
-                        return toSearchResult(withPackageId(scope, loadFileNameFromPackageJsonField(
-                          extensions,
-                          possibleInputWithInputExtension,
-                          /*onlyRecordFailures*/
-                          false,
-                          state
-                        )));
-                      }
-                    }
-                  }
-                }
-              }
-            }
-          }
-        }
-        return void 0;
-        function getOutputDirectoriesForBaseDirectory(commonSourceDirGuess) {
-          var _a2, _b2;
-          const currentDir = state.compilerOptions.configFile ? ((_b2 = (_a2 = state.host).getCurrentDirectory) == null ? void 0 : _b2.call(_a2)) || "" : commonSourceDirGuess;
-          const candidateDirectories = [];
-          if (state.compilerOptions.declarationDir) {
-            candidateDirectories.push(toAbsolutePath(combineDirectoryPath(currentDir, state.compilerOptions.declarationDir)));
-          }
-          if (state.compilerOptions.outDir && state.compilerOptions.outDir !== state.compilerOptions.declarationDir) {
-            candidateDirectories.push(toAbsolutePath(combineDirectoryPath(currentDir, state.compilerOptions.outDir)));
-          }
-          return candidateDirectories;
-        }
-      }
-    }
-  }
-  function isApplicableVersionedTypesKey(conditions, key) {
-    if (conditions.indexOf("types") === -1)
-      return false;
-    if (!startsWith(key, "types@"))
-      return false;
-    const range = VersionRange.tryParse(key.substring("types@".length));
-    if (!range)
-      return false;
-    return range.test(version);
-  }
-  function loadModuleFromNearestNodeModulesDirectory(extensions, moduleName, directory, state, cache, redirectedReference) {
-    return loadModuleFromNearestNodeModulesDirectoryWorker(
-      extensions,
-      moduleName,
-      directory,
-      state,
-      /*typesScopeOnly*/
-      false,
-      cache,
-      redirectedReference
-    );
-  }
-  function loadModuleFromNearestNodeModulesDirectoryTypesScope(moduleName, directory, state) {
-    return loadModuleFromNearestNodeModulesDirectoryWorker(
-      4 /* Declaration */,
-      moduleName,
-      directory,
-      state,
-      /*typesScopeOnly*/
-      true,
-      /*cache*/
-      void 0,
-      /*redirectedReference*/
-      void 0
-    );
-  }
-  function loadModuleFromNearestNodeModulesDirectoryWorker(extensions, moduleName, directory, state, typesScopeOnly, cache, redirectedReference) {
-    const mode = state.features === 0 ? void 0 : state.features & 32 /* EsmMode */ ? 99 /* ESNext */ : 1 /* CommonJS */;
-    const priorityExtensions = extensions & (1 /* TypeScript */ | 4 /* Declaration */);
-    const secondaryExtensions = extensions & ~(1 /* TypeScript */ | 4 /* Declaration */);
-    if (priorityExtensions) {
-      const result = lookup(priorityExtensions);
-      if (result)
-        return result;
-    }
-    if (secondaryExtensions && !typesScopeOnly) {
-      return lookup(secondaryExtensions);
-    }
-    function lookup(extensions2) {
-      return forEachAncestorDirectory(normalizeSlashes(directory), (ancestorDirectory) => {
-        if (getBaseFileName(ancestorDirectory) !== "node_modules") {
-          const resolutionFromCache = tryFindNonRelativeModuleNameInCache(cache, moduleName, mode, ancestorDirectory, redirectedReference, state);
-          if (resolutionFromCache) {
-            return resolutionFromCache;
-          }
-          return toSearchResult(loadModuleFromImmediateNodeModulesDirectory(extensions2, moduleName, ancestorDirectory, state, typesScopeOnly, cache, redirectedReference));
-        }
-      });
-    }
-  }
-  function loadModuleFromImmediateNodeModulesDirectory(extensions, moduleName, directory, state, typesScopeOnly, cache, redirectedReference) {
-    const nodeModulesFolder = combinePaths(directory, "node_modules");
-    const nodeModulesFolderExists = directoryProbablyExists(nodeModulesFolder, state.host);
-    if (!nodeModulesFolderExists && state.traceEnabled) {
-      trace(state.host, Diagnostics.Directory_0_does_not_exist_skipping_all_lookups_in_it, nodeModulesFolder);
-    }
-    if (!typesScopeOnly) {
-      const packageResult = loadModuleFromSpecificNodeModulesDirectory(extensions, moduleName, nodeModulesFolder, nodeModulesFolderExists, state, cache, redirectedReference);
-      if (packageResult) {
-        return packageResult;
-      }
-    }
-    if (extensions & 4 /* Declaration */) {
-      const nodeModulesAtTypes2 = combinePaths(nodeModulesFolder, "@types");
-      let nodeModulesAtTypesExists = nodeModulesFolderExists;
-      if (nodeModulesFolderExists && !directoryProbablyExists(nodeModulesAtTypes2, state.host)) {
-        if (state.traceEnabled) {
-          trace(state.host, Diagnostics.Directory_0_does_not_exist_skipping_all_lookups_in_it, nodeModulesAtTypes2);
-        }
-        nodeModulesAtTypesExists = false;
-      }
-      return loadModuleFromSpecificNodeModulesDirectory(4 /* Declaration */, mangleScopedPackageNameWithTrace(moduleName, state), nodeModulesAtTypes2, nodeModulesAtTypesExists, state, cache, redirectedReference);
-    }
-  }
-  function loadModuleFromSpecificNodeModulesDirectory(extensions, moduleName, nodeModulesDirectory, nodeModulesDirectoryExists, state, cache, redirectedReference) {
-    var _a, _b;
-    const candidate = normalizePath(combinePaths(nodeModulesDirectory, moduleName));
-    const { packageName, rest } = parsePackageName(moduleName);
-    const packageDirectory = combinePaths(nodeModulesDirectory, packageName);
-    let rootPackageInfo;
-    let packageInfo = getPackageJsonInfo(candidate, !nodeModulesDirectoryExists, state);
-    if (rest !== "" && packageInfo && (!(state.features & 8 /* Exports */) || !hasProperty(((_a = rootPackageInfo = getPackageJsonInfo(packageDirectory, !nodeModulesDirectoryExists, state)) == null ? void 0 : _a.contents.packageJsonContent) ?? emptyArray, "exports"))) {
-      const fromFile = loadModuleFromFile(extensions, candidate, !nodeModulesDirectoryExists, state);
-      if (fromFile) {
-        return noPackageId(fromFile);
-      }
-      const fromDirectory = loadNodeModuleFromDirectoryWorker(
-        extensions,
-        candidate,
-        !nodeModulesDirectoryExists,
-        state,
-        packageInfo.contents.packageJsonContent,
-        getVersionPathsOfPackageJsonInfo(packageInfo, state)
-      );
-      return withPackageId(packageInfo, fromDirectory);
-    }
-    const loader = (extensions2, candidate2, onlyRecordFailures, state2) => {
-      let pathAndExtension = (rest || !(state2.features & 32 /* EsmMode */)) && loadModuleFromFile(extensions2, candidate2, onlyRecordFailures, state2) || loadNodeModuleFromDirectoryWorker(
-        extensions2,
-        candidate2,
-        onlyRecordFailures,
-        state2,
-        packageInfo && packageInfo.contents.packageJsonContent,
-        packageInfo && getVersionPathsOfPackageJsonInfo(packageInfo, state2)
-      );
-      if (!pathAndExtension && packageInfo && (packageInfo.contents.packageJsonContent.exports === void 0 || packageInfo.contents.packageJsonContent.exports === null) && state2.features & 32 /* EsmMode */) {
-        pathAndExtension = loadModuleFromFile(extensions2, combinePaths(candidate2, "index.js"), onlyRecordFailures, state2);
-      }
-      return withPackageId(packageInfo, pathAndExtension);
-    };
-    if (rest !== "") {
-      packageInfo = rootPackageInfo ?? getPackageJsonInfo(packageDirectory, !nodeModulesDirectoryExists, state);
-    }
-    if (packageInfo && packageInfo.contents.packageJsonContent.exports && state.features & 8 /* Exports */) {
-      return (_b = loadModuleFromExports(packageInfo, extensions, combinePaths(".", rest), state, cache, redirectedReference)) == null ? void 0 : _b.value;
-    }
-    const versionPaths = rest !== "" && packageInfo ? getVersionPathsOfPackageJsonInfo(packageInfo, state) : void 0;
-    if (versionPaths) {
-      if (state.traceEnabled) {
-        trace(state.host, Diagnostics.package_json_has_a_typesVersions_entry_0_that_matches_compiler_version_1_looking_for_a_pattern_to_match_module_name_2, versionPaths.version, version, rest);
-      }
-      const packageDirectoryExists = nodeModulesDirectoryExists && directoryProbablyExists(packageDirectory, state.host);
-      const fromPaths = tryLoadModuleUsingPaths(
-        extensions,
-        rest,
-        packageDirectory,
-        versionPaths.paths,
-        /*pathPatterns*/
-        void 0,
-        loader,
-        !packageDirectoryExists,
-        state
-      );
-      if (fromPaths) {
-        return fromPaths.value;
-      }
-    }
-    return loader(extensions, candidate, !nodeModulesDirectoryExists, state);
-  }
-  function tryLoadModuleUsingPaths(extensions, moduleName, baseDirectory, paths, pathPatterns, loader, onlyRecordFailures, state) {
-    pathPatterns || (pathPatterns = tryParsePatterns(paths));
-    const matchedPattern = matchPatternOrExact(pathPatterns, moduleName);
-    if (matchedPattern) {
-      const matchedStar = isString(matchedPattern) ? void 0 : matchedText(matchedPattern, moduleName);
-      const matchedPatternText = isString(matchedPattern) ? matchedPattern : patternText(matchedPattern);
-      if (state.traceEnabled) {
-        trace(state.host, Diagnostics.Module_name_0_matched_pattern_1, moduleName, matchedPatternText);
-      }
-      const resolved = forEach(paths[matchedPatternText], (subst) => {
-        const path = matchedStar ? subst.replace("*", matchedStar) : subst;
-        const candidate = normalizePath(combinePaths(baseDirectory, path));
-        if (state.traceEnabled) {
-          trace(state.host, Diagnostics.Trying_substitution_0_candidate_module_location_Colon_1, subst, path);
-        }
-        const extension = tryGetExtensionFromPath2(subst);
-        if (extension !== void 0) {
-          const path2 = tryFile(candidate, onlyRecordFailures, state);
-          if (path2 !== void 0) {
-            return noPackageId({ path: path2, ext: extension, resolvedUsingTsExtension: void 0 });
-          }
-        }
-        return loader(extensions, candidate, onlyRecordFailures || !directoryProbablyExists(getDirectoryPath(candidate), state.host), state);
-      });
-      return { value: resolved };
-    }
-  }
-  function mangleScopedPackageNameWithTrace(packageName, state) {
-    const mangled = mangleScopedPackageName(packageName);
-    if (state.traceEnabled && mangled !== packageName) {
-      trace(state.host, Diagnostics.Scoped_package_detected_looking_in_0, mangled);
-    }
-    return mangled;
-  }
-  function getTypesPackageName(packageName) {
-    return `@types/${mangleScopedPackageName(packageName)}`;
-  }
-  function mangleScopedPackageName(packageName) {
-    if (startsWith(packageName, "@")) {
-      const replaceSlash = packageName.replace(directorySeparator, mangledScopedPackageSeparator);
-      if (replaceSlash !== packageName) {
-        return replaceSlash.slice(1);
-      }
-    }
-    return packageName;
-  }
-  function getPackageNameFromTypesPackageName(mangledName) {
-    const withoutAtTypePrefix = removePrefix(mangledName, "@types/");
-    if (withoutAtTypePrefix !== mangledName) {
-      return unmangleScopedPackageName(withoutAtTypePrefix);
-    }
-    return mangledName;
-  }
-  function unmangleScopedPackageName(typesPackageName) {
-    return stringContains(typesPackageName, mangledScopedPackageSeparator) ? "@" + typesPackageName.replace(mangledScopedPackageSeparator, directorySeparator) : typesPackageName;
-  }
-  function tryFindNonRelativeModuleNameInCache(cache, moduleName, mode, containingDirectory, redirectedReference, state) {
-    const result = cache && cache.getFromNonRelativeNameCache(moduleName, mode, containingDirectory, redirectedReference);
-    if (result) {
-      if (state.traceEnabled) {
-        trace(state.host, Diagnostics.Resolution_for_module_0_was_found_in_cache_from_location_1, moduleName, containingDirectory);
-      }
-      state.resultFromCache = result;
-      return {
-        value: result.resolvedModule && {
-          path: result.resolvedModule.resolvedFileName,
-          originalPath: result.resolvedModule.originalPath || true,
-          extension: result.resolvedModule.extension,
-          packageId: result.resolvedModule.packageId,
-          resolvedUsingTsExtension: result.resolvedModule.resolvedUsingTsExtension
-        }
-      };
-    }
-  }
-  function classicNameResolver(moduleName, containingFile, compilerOptions, host, cache, redirectedReference) {
-    const traceEnabled = isTraceEnabled(compilerOptions, host);
-    const failedLookupLocations = [];
-    const affectingLocations = [];
-    const containingDirectory = getDirectoryPath(containingFile);
-    const diagnostics = [];
-    const state = {
-      compilerOptions,
-      host,
-      traceEnabled,
-      failedLookupLocations,
-      affectingLocations,
-      packageJsonInfoCache: cache,
-      features: 0 /* None */,
-      conditions: [],
-      requestContainingDirectory: containingDirectory,
-      reportDiagnostic: (diag2) => void diagnostics.push(diag2),
-      isConfigLookup: false,
-      candidateIsFromPackageJsonField: false
-    };
-    const resolved = tryResolve(1 /* TypeScript */ | 4 /* Declaration */) || tryResolve(2 /* JavaScript */ | (compilerOptions.resolveJsonModule ? 8 /* Json */ : 0));
-    return createResolvedModuleWithFailedLookupLocationsHandlingSymlink(
-      moduleName,
-      resolved && resolved.value,
-      (resolved == null ? void 0 : resolved.value) && pathContainsNodeModules(resolved.value.path),
-      failedLookupLocations,
-      affectingLocations,
-      diagnostics,
-      state
-    );
-    function tryResolve(extensions) {
-      const resolvedUsingSettings = tryLoadModuleUsingOptionalResolutionSettings(extensions, moduleName, containingDirectory, loadModuleFromFileNoPackageId, state);
-      if (resolvedUsingSettings) {
-        return { value: resolvedUsingSettings };
-      }
-      if (!isExternalModuleNameRelative(moduleName)) {
-        const resolved2 = forEachAncestorDirectory(containingDirectory, (directory) => {
-          const resolutionFromCache = tryFindNonRelativeModuleNameInCache(
-            cache,
-            moduleName,
-            /*mode*/
-            void 0,
-            directory,
-            redirectedReference,
-            state
-          );
-          if (resolutionFromCache) {
-            return resolutionFromCache;
-          }
-          const searchName = normalizePath(combinePaths(directory, moduleName));
-          return toSearchResult(loadModuleFromFileNoPackageId(
-            extensions,
-            searchName,
-            /*onlyRecordFailures*/
-            false,
-            state
-          ));
-        });
-        if (resolved2)
-          return resolved2;
-        if (extensions & (1 /* TypeScript */ | 4 /* Declaration */)) {
-          let resolved3 = loadModuleFromNearestNodeModulesDirectoryTypesScope(moduleName, containingDirectory, state);
-          if (extensions & 4 /* Declaration */)
-            resolved3 ?? (resolved3 = resolveFromTypeRoot(moduleName, state));
-          return resolved3;
-        }
-      } else {
-        const candidate = normalizePath(combinePaths(containingDirectory, moduleName));
-        return toSearchResult(loadModuleFromFileNoPackageId(
-          extensions,
-          candidate,
-          /*onlyRecordFailures*/
-          false,
-          state
-        ));
-      }
-    }
-  }
-  function resolveFromTypeRoot(moduleName, state) {
-    if (!state.compilerOptions.typeRoots)
-      return;
-    for (const typeRoot of state.compilerOptions.typeRoots) {
-      const candidate = getCandidateFromTypeRoot(typeRoot, moduleName, state);
-      const directoryExists = directoryProbablyExists(typeRoot, state.host);
-      if (!directoryExists && state.traceEnabled) {
-        trace(state.host, Diagnostics.Directory_0_does_not_exist_skipping_all_lookups_in_it, typeRoot);
-      }
-      const resolvedFromFile = loadModuleFromFile(4 /* Declaration */, candidate, !directoryExists, state);
-      if (resolvedFromFile) {
-        const packageDirectory = parseNodeModuleFromPath(resolvedFromFile.path);
-        const packageInfo = packageDirectory ? getPackageJsonInfo(
-          packageDirectory,
-          /*onlyRecordFailures*/
-          false,
-          state
-        ) : void 0;
-        return toSearchResult(withPackageId(packageInfo, resolvedFromFile));
-      }
-      const resolved = loadNodeModuleFromDirectory(4 /* Declaration */, candidate, !directoryExists, state);
-      if (resolved)
-        return toSearchResult(resolved);
-    }
-  }
-  function shouldAllowImportingTsExtension(compilerOptions, fromFileName) {
-    return !!compilerOptions.allowImportingTsExtensions || fromFileName && isDeclarationFileName(fromFileName);
-  }
-  function loadModuleFromGlobalCache(moduleName, projectName, compilerOptions, host, globalCache, packageJsonInfoCache) {
-    const traceEnabled = isTraceEnabled(compilerOptions, host);
-    if (traceEnabled) {
-      trace(host, Diagnostics.Auto_discovery_for_typings_is_enabled_in_project_0_Running_extra_resolution_pass_for_module_1_using_cache_location_2, projectName, moduleName, globalCache);
-    }
-    const failedLookupLocations = [];
-    const affectingLocations = [];
-    const diagnostics = [];
-    const state = {
-      compilerOptions,
-      host,
-      traceEnabled,
-      failedLookupLocations,
-      affectingLocations,
-      packageJsonInfoCache,
-      features: 0 /* None */,
-      conditions: [],
-      requestContainingDirectory: void 0,
-      reportDiagnostic: (diag2) => void diagnostics.push(diag2),
-      isConfigLookup: false,
-      candidateIsFromPackageJsonField: false
-    };
-    const resolved = loadModuleFromImmediateNodeModulesDirectory(
-      4 /* Declaration */,
-      moduleName,
-      globalCache,
-      state,
-      /*typesScopeOnly*/
-      false,
-      /*cache*/
-      void 0,
-      /*redirectedReference*/
-      void 0
-    );
-    return createResolvedModuleWithFailedLookupLocations(
-      resolved,
-      /*isExternalLibraryImport*/
-      true,
-      failedLookupLocations,
-      affectingLocations,
-      diagnostics,
-      state.resultFromCache
-    );
-  }
-  function toSearchResult(value) {
-    return value !== void 0 ? { value } : void 0;
-  }
-  function traceIfEnabled(state, diagnostic, ...args) {
-    if (state.traceEnabled) {
-      trace(state.host, diagnostic, ...args);
-    }
-  }
-  var typeScriptVersion, nodeModulesAtTypes, NodeResolutionFeatures, nodeModulesPathPart, mangledScopedPackageSeparator;
-  var init_moduleNameResolver = __esm({
-    "src/compiler/moduleNameResolver.ts"() {
-      "use strict";
-      init_ts2();
-      nodeModulesAtTypes = combinePaths("node_modules", "@types");
-      NodeResolutionFeatures = /* @__PURE__ */ ((NodeResolutionFeatures2) => {
-        NodeResolutionFeatures2[NodeResolutionFeatures2["None"] = 0] = "None";
-        NodeResolutionFeatures2[NodeResolutionFeatures2["Imports"] = 2] = "Imports";
-        NodeResolutionFeatures2[NodeResolutionFeatures2["SelfName"] = 4] = "SelfName";
-        NodeResolutionFeatures2[NodeResolutionFeatures2["Exports"] = 8] = "Exports";
-        NodeResolutionFeatures2[NodeResolutionFeatures2["ExportsPatternTrailers"] = 16] = "ExportsPatternTrailers";
-        NodeResolutionFeatures2[NodeResolutionFeatures2["AllFeatures"] = 30] = "AllFeatures";
-        NodeResolutionFeatures2[NodeResolutionFeatures2["Node16Default"] = 30] = "Node16Default";
-        NodeResolutionFeatures2[NodeResolutionFeatures2["NodeNextDefault"] = 30 /* AllFeatures */] = "NodeNextDefault";
-        NodeResolutionFeatures2[NodeResolutionFeatures2["BundlerDefault"] = 30] = "BundlerDefault";
-        NodeResolutionFeatures2[NodeResolutionFeatures2["EsmMode"] = 32] = "EsmMode";
-        return NodeResolutionFeatures2;
-      })(NodeResolutionFeatures || {});
-      nodeModulesPathPart = "/node_modules/";
-      mangledScopedPackageSeparator = "__";
-    }
-  });
-
-  // src/compiler/binder.ts
-  function getModuleInstanceState(node, visited) {
-    if (node.body && !node.body.parent) {
-      setParent(node.body, node);
-      setParentRecursive(
-        node.body,
-        /*incremental*/
-        false
-      );
-    }
-    return node.body ? getModuleInstanceStateCached(node.body, visited) : 1 /* Instantiated */;
-  }
-  function getModuleInstanceStateCached(node, visited = /* @__PURE__ */ new Map()) {
-    const nodeId = getNodeId(node);
-    if (visited.has(nodeId)) {
-      return visited.get(nodeId) || 0 /* NonInstantiated */;
-    }
-    visited.set(nodeId, void 0);
-    const result = getModuleInstanceStateWorker(node, visited);
-    visited.set(nodeId, result);
-    return result;
-  }
-  function getModuleInstanceStateWorker(node, visited) {
-    switch (node.kind) {
-      case 263 /* InterfaceDeclaration */:
-      case 264 /* TypeAliasDeclaration */:
-        return 0 /* NonInstantiated */;
-      case 265 /* EnumDeclaration */:
-        if (isEnumConst(node)) {
-          return 2 /* ConstEnumOnly */;
-        }
-        break;
-      case 271 /* ImportDeclaration */:
-      case 270 /* ImportEqualsDeclaration */:
-        if (!hasSyntacticModifier(node, 1 /* Export */)) {
-          return 0 /* NonInstantiated */;
-        }
-        break;
-      case 277 /* ExportDeclaration */:
-        const exportDeclaration = node;
-        if (!exportDeclaration.moduleSpecifier && exportDeclaration.exportClause && exportDeclaration.exportClause.kind === 278 /* NamedExports */) {
-          let state = 0 /* NonInstantiated */;
-          for (const specifier of exportDeclaration.exportClause.elements) {
-            const specifierState = getModuleInstanceStateForAliasTarget(specifier, visited);
-            if (specifierState > state) {
-              state = specifierState;
-            }
-            if (state === 1 /* Instantiated */) {
-              return state;
-            }
-          }
-          return state;
-        }
-        break;
-      case 267 /* ModuleBlock */: {
-        let state = 0 /* NonInstantiated */;
-        forEachChild(node, (n) => {
-          const childState = getModuleInstanceStateCached(n, visited);
-          switch (childState) {
-            case 0 /* NonInstantiated */:
-              return;
-            case 2 /* ConstEnumOnly */:
-              state = 2 /* ConstEnumOnly */;
-              return;
-            case 1 /* Instantiated */:
-              state = 1 /* Instantiated */;
-              return true;
-            default:
-              Debug.assertNever(childState);
-          }
-        });
-        return state;
-      }
-      case 266 /* ModuleDeclaration */:
-        return getModuleInstanceState(node, visited);
-      case 80 /* Identifier */:
-        if (node.flags & 2048 /* IdentifierIsInJSDocNamespace */) {
-          return 0 /* NonInstantiated */;
-        }
-    }
-    return 1 /* Instantiated */;
-  }
-  function getModuleInstanceStateForAliasTarget(specifier, visited) {
-    const name = specifier.propertyName || specifier.name;
-    let p = specifier.parent;
-    while (p) {
-      if (isBlock(p) || isModuleBlock(p) || isSourceFile(p)) {
-        const statements = p.statements;
-        let found;
-        for (const statement of statements) {
-          if (nodeHasName(statement, name)) {
-            if (!statement.parent) {
-              setParent(statement, p);
-              setParentRecursive(
-                statement,
-                /*incremental*/
-                false
-              );
-            }
-            const state = getModuleInstanceStateCached(statement, visited);
-            if (found === void 0 || state > found) {
-              found = state;
-            }
-            if (found === 1 /* Instantiated */) {
-              return found;
-            }
-          }
-        }
-        if (found !== void 0) {
-          return found;
-        }
-      }
-      p = p.parent;
-    }
-    return 1 /* Instantiated */;
-  }
-  function initFlowNode(node) {
-    Debug.attachFlowNodeDebugInfo(node);
-    return node;
-  }
-  function bindSourceFile(file, options) {
-    var _a, _b;
-    mark("beforeBind");
-    (_a = perfLogger) == null ? void 0 : _a.logStartBindFile("" + file.fileName);
-    binder(file, options);
-    (_b = perfLogger) == null ? void 0 : _b.logStopBindFile();
-    mark("afterBind");
-    measure("Bind", "beforeBind", "afterBind");
-  }
-  function createBinder() {
-    var file;
-    var options;
-    var languageVersion;
-    var parent2;
-    var container;
-    var thisParentContainer;
-    var blockScopeContainer;
-    var lastContainer;
-    var delayedTypeAliases;
-    var seenThisKeyword;
-    var currentFlow;
-    var currentBreakTarget;
-    var currentContinueTarget;
-    var currentReturnTarget;
-    var currentTrueTarget;
-    var currentFalseTarget;
-    var currentExceptionTarget;
-    var preSwitchCaseFlow;
-    var activeLabelList;
-    var hasExplicitReturn;
-    var emitFlags;
-    var inStrictMode;
-    var inAssignmentPattern = false;
-    var symbolCount = 0;
-    var Symbol47;
-    var classifiableNames;
-    var unreachableFlow = { flags: 1 /* Unreachable */ };
-    var reportedUnreachableFlow = { flags: 1 /* Unreachable */ };
-    var bindBinaryExpressionFlow = createBindBinaryExpressionFlow();
-    return bindSourceFile2;
-    function createDiagnosticForNode2(node, message, ...args) {
-      return createDiagnosticForNodeInSourceFile(getSourceFileOfNode(node) || file, node, message, ...args);
-    }
-    function bindSourceFile2(f, opts) {
-      var _a, _b;
-      file = f;
-      options = opts;
-      languageVersion = getEmitScriptTarget(options);
-      inStrictMode = bindInStrictMode(file, opts);
-      classifiableNames = /* @__PURE__ */ new Set();
-      symbolCount = 0;
-      Symbol47 = objectAllocator.getSymbolConstructor();
-      Debug.attachFlowNodeDebugInfo(unreachableFlow);
-      Debug.attachFlowNodeDebugInfo(reportedUnreachableFlow);
-      if (!file.locals) {
-        (_a = tracing) == null ? void 0 : _a.push(
-          tracing.Phase.Bind,
-          "bindSourceFile",
-          { path: file.path },
-          /*separateBeginAndEnd*/
-          true
-        );
-        bind(file);
-        (_b = tracing) == null ? void 0 : _b.pop();
-        file.symbolCount = symbolCount;
-        file.classifiableNames = classifiableNames;
-        delayedBindJSDocTypedefTag();
-      }
-      file = void 0;
-      options = void 0;
-      languageVersion = void 0;
-      parent2 = void 0;
-      container = void 0;
-      thisParentContainer = void 0;
-      blockScopeContainer = void 0;
-      lastContainer = void 0;
-      delayedTypeAliases = void 0;
-      seenThisKeyword = false;
-      currentFlow = void 0;
-      currentBreakTarget = void 0;
-      currentContinueTarget = void 0;
-      currentReturnTarget = void 0;
-      currentTrueTarget = void 0;
-      currentFalseTarget = void 0;
-      currentExceptionTarget = void 0;
-      activeLabelList = void 0;
-      hasExplicitReturn = false;
-      inAssignmentPattern = false;
-      emitFlags = 0 /* None */;
-    }
-    function bindInStrictMode(file2, opts) {
-      if (getStrictOptionValue(opts, "alwaysStrict") && !file2.isDeclarationFile) {
-        return true;
-      } else {
-        return !!file2.externalModuleIndicator;
-      }
-    }
-    function createSymbol(flags, name) {
-      symbolCount++;
-      return new Symbol47(flags, name);
-    }
-    function addDeclarationToSymbol(symbol, node, symbolFlags) {
-      symbol.flags |= symbolFlags;
-      node.symbol = symbol;
-      symbol.declarations = appendIfUnique(symbol.declarations, node);
-      if (symbolFlags & (32 /* Class */ | 384 /* Enum */ | 1536 /* Module */ | 3 /* Variable */) && !symbol.exports) {
-        symbol.exports = createSymbolTable();
-      }
-      if (symbolFlags & (32 /* Class */ | 64 /* Interface */ | 2048 /* TypeLiteral */ | 4096 /* ObjectLiteral */) && !symbol.members) {
-        symbol.members = createSymbolTable();
-      }
-      if (symbol.constEnumOnlyModule && symbol.flags & (16 /* Function */ | 32 /* Class */ | 256 /* RegularEnum */)) {
-        symbol.constEnumOnlyModule = false;
-      }
-      if (symbolFlags & 111551 /* Value */) {
-        setValueDeclaration(symbol, node);
-      }
-    }
-    function getDeclarationName(node) {
-      if (node.kind === 276 /* ExportAssignment */) {
-        return node.isExportEquals ? "export=" /* ExportEquals */ : "default" /* Default */;
-      }
-      const name = getNameOfDeclaration(node);
-      if (name) {
-        if (isAmbientModule(node)) {
-          const moduleName = getTextOfIdentifierOrLiteral(name);
-          return isGlobalScopeAugmentation(node) ? "__global" : `"${moduleName}"`;
-        }
-        if (name.kind === 166 /* ComputedPropertyName */) {
-          const nameExpression = name.expression;
-          if (isStringOrNumericLiteralLike(nameExpression)) {
-            return escapeLeadingUnderscores(nameExpression.text);
-          }
-          if (isSignedNumericLiteral(nameExpression)) {
-            return tokenToString(nameExpression.operator) + nameExpression.operand.text;
-          } else {
-            Debug.fail("Only computed properties with literal names have declaration names");
-          }
-        }
-        if (isPrivateIdentifier(name)) {
-          const containingClass = getContainingClass(node);
-          if (!containingClass) {
-            return void 0;
-          }
-          const containingClassSymbol = containingClass.symbol;
-          return getSymbolNameForPrivateIdentifier(containingClassSymbol, name.escapedText);
-        }
-        if (isJsxNamespacedName(name)) {
-          return getEscapedTextOfJsxNamespacedName(name);
-        }
-        return isPropertyNameLiteral(name) ? getEscapedTextOfIdentifierOrLiteral(name) : void 0;
-      }
-      switch (node.kind) {
-        case 175 /* Constructor */:
-          return "__constructor" /* Constructor */;
-        case 183 /* FunctionType */:
-        case 178 /* CallSignature */:
-        case 329 /* JSDocSignature */:
-          return "__call" /* Call */;
-        case 184 /* ConstructorType */:
-        case 179 /* ConstructSignature */:
-          return "__new" /* New */;
-        case 180 /* IndexSignature */:
-          return "__index" /* Index */;
-        case 277 /* ExportDeclaration */:
-          return "__export" /* ExportStar */;
-        case 311 /* SourceFile */:
-          return "export=" /* ExportEquals */;
-        case 225 /* BinaryExpression */:
-          if (getAssignmentDeclarationKind(node) === 2 /* ModuleExports */) {
-            return "export=" /* ExportEquals */;
-          }
-          Debug.fail("Unknown binary declaration kind");
-          break;
-        case 323 /* JSDocFunctionType */:
-          return isJSDocConstructSignature(node) ? "__new" /* New */ : "__call" /* Call */;
-        case 168 /* Parameter */:
-          Debug.assert(node.parent.kind === 323 /* JSDocFunctionType */, "Impossible parameter parent kind", () => `parent is: ${Debug.formatSyntaxKind(node.parent.kind)}, expected JSDocFunctionType`);
-          const functionType = node.parent;
-          const index = functionType.parameters.indexOf(node);
-          return "arg" + index;
-      }
-    }
-    function getDisplayName(node) {
-      return isNamedDeclaration(node) ? declarationNameToString(node.name) : unescapeLeadingUnderscores(Debug.checkDefined(getDeclarationName(node)));
-    }
-    function declareSymbol(symbolTable, parent3, node, includes, excludes, isReplaceableByMethod, isComputedName) {
-      Debug.assert(isComputedName || !hasDynamicName(node));
-      const isDefaultExport = hasSyntacticModifier(node, 1024 /* Default */) || isExportSpecifier(node) && node.name.escapedText === "default";
-      const name = isComputedName ? "__computed" /* Computed */ : isDefaultExport && parent3 ? "default" /* Default */ : getDeclarationName(node);
-      let symbol;
-      if (name === void 0) {
-        symbol = createSymbol(0 /* None */, "__missing" /* Missing */);
-      } else {
-        symbol = symbolTable.get(name);
-        if (includes & 2885600 /* Classifiable */) {
-          classifiableNames.add(name);
-        }
-        if (!symbol) {
-          symbolTable.set(name, symbol = createSymbol(0 /* None */, name));
-          if (isReplaceableByMethod)
-            symbol.isReplaceableByMethod = true;
-        } else if (isReplaceableByMethod && !symbol.isReplaceableByMethod) {
-          return symbol;
-        } else if (symbol.flags & excludes) {
-          if (symbol.isReplaceableByMethod) {
-            symbolTable.set(name, symbol = createSymbol(0 /* None */, name));
-          } else if (!(includes & 3 /* Variable */ && symbol.flags & 67108864 /* Assignment */)) {
-            if (isNamedDeclaration(node)) {
-              setParent(node.name, node);
-            }
-            let message = symbol.flags & 2 /* BlockScopedVariable */ ? Diagnostics.Cannot_redeclare_block_scoped_variable_0 : Diagnostics.Duplicate_identifier_0;
-            let messageNeedsName = true;
-            if (symbol.flags & 384 /* Enum */ || includes & 384 /* Enum */) {
-              message = Diagnostics.Enum_declarations_can_only_merge_with_namespace_or_other_enum_declarations;
-              messageNeedsName = false;
-            }
-            let multipleDefaultExports = false;
-            if (length(symbol.declarations)) {
-              if (isDefaultExport) {
-                message = Diagnostics.A_module_cannot_have_multiple_default_exports;
-                messageNeedsName = false;
-                multipleDefaultExports = true;
-              } else {
-                if (symbol.declarations && symbol.declarations.length && (node.kind === 276 /* ExportAssignment */ && !node.isExportEquals)) {
-                  message = Diagnostics.A_module_cannot_have_multiple_default_exports;
-                  messageNeedsName = false;
-                  multipleDefaultExports = true;
-                }
-              }
-            }
-            const relatedInformation = [];
-            if (isTypeAliasDeclaration(node) && nodeIsMissing(node.type) && hasSyntacticModifier(node, 1 /* Export */) && symbol.flags & (2097152 /* Alias */ | 788968 /* Type */ | 1920 /* Namespace */)) {
-              relatedInformation.push(createDiagnosticForNode2(node, Diagnostics.Did_you_mean_0, `export type { ${unescapeLeadingUnderscores(node.name.escapedText)} }`));
-            }
-            const declarationName = getNameOfDeclaration(node) || node;
-            forEach(symbol.declarations, (declaration, index) => {
-              const decl = getNameOfDeclaration(declaration) || declaration;
-              const diag3 = messageNeedsName ? createDiagnosticForNode2(decl, message, getDisplayName(declaration)) : createDiagnosticForNode2(decl, message);
-              file.bindDiagnostics.push(
-                multipleDefaultExports ? addRelatedInfo(diag3, createDiagnosticForNode2(declarationName, index === 0 ? Diagnostics.Another_export_default_is_here : Diagnostics.and_here)) : diag3
-              );
-              if (multipleDefaultExports) {
-                relatedInformation.push(createDiagnosticForNode2(decl, Diagnostics.The_first_export_default_is_here));
-              }
-            });
-            const diag2 = messageNeedsName ? createDiagnosticForNode2(declarationName, message, getDisplayName(node)) : createDiagnosticForNode2(declarationName, message);
-            file.bindDiagnostics.push(addRelatedInfo(diag2, ...relatedInformation));
-            symbol = createSymbol(0 /* None */, name);
-          }
-        }
-      }
-      addDeclarationToSymbol(symbol, node, includes);
-      if (symbol.parent) {
-        Debug.assert(symbol.parent === parent3, "Existing symbol parent should match new one");
-      } else {
-        symbol.parent = parent3;
-      }
-      return symbol;
-    }
-    function declareModuleMember(node, symbolFlags, symbolExcludes) {
-      const hasExportModifier = !!(getCombinedModifierFlags(node) & 1 /* Export */) || jsdocTreatAsExported(node);
-      if (symbolFlags & 2097152 /* Alias */) {
-        if (node.kind === 280 /* ExportSpecifier */ || node.kind === 270 /* ImportEqualsDeclaration */ && hasExportModifier) {
-          return declareSymbol(container.symbol.exports, container.symbol, node, symbolFlags, symbolExcludes);
-        } else {
-          Debug.assertNode(container, canHaveLocals);
-          return declareSymbol(
-            container.locals,
-            /*parent*/
-            void 0,
-            node,
-            symbolFlags,
-            symbolExcludes
-          );
-        }
-      } else {
-        if (isJSDocTypeAlias(node))
-          Debug.assert(isInJSFile(node));
-        if (!isAmbientModule(node) && (hasExportModifier || container.flags & 64 /* ExportContext */)) {
-          if (!canHaveLocals(container) || !container.locals || hasSyntacticModifier(node, 1024 /* Default */) && !getDeclarationName(node)) {
-            return declareSymbol(container.symbol.exports, container.symbol, node, symbolFlags, symbolExcludes);
-          }
-          const exportKind = symbolFlags & 111551 /* Value */ ? 1048576 /* ExportValue */ : 0;
-          const local = declareSymbol(
-            container.locals,
-            /*parent*/
-            void 0,
-            node,
-            exportKind,
-            symbolExcludes
-          );
-          local.exportSymbol = declareSymbol(container.symbol.exports, container.symbol, node, symbolFlags, symbolExcludes);
-          node.localSymbol = local;
-          return local;
-        } else {
-          Debug.assertNode(container, canHaveLocals);
-          return declareSymbol(
-            container.locals,
-            /*parent*/
-            void 0,
-            node,
-            symbolFlags,
-            symbolExcludes
-          );
-        }
-      }
-    }
-    function jsdocTreatAsExported(node) {
-      if (node.parent && isModuleDeclaration(node)) {
-        node = node.parent;
-      }
-      if (!isJSDocTypeAlias(node))
-        return false;
-      if (!isJSDocEnumTag(node) && !!node.fullName)
-        return true;
-      const declName = getNameOfDeclaration(node);
-      if (!declName)
-        return false;
-      if (isPropertyAccessEntityNameExpression(declName.parent) && isTopLevelNamespaceAssignment(declName.parent))
-        return true;
-      if (isDeclaration(declName.parent) && getCombinedModifierFlags(declName.parent) & 1 /* Export */)
-        return true;
-      return false;
-    }
-    function bindContainer(node, containerFlags) {
-      const saveContainer = container;
-      const saveThisParentContainer = thisParentContainer;
-      const savedBlockScopeContainer = blockScopeContainer;
-      if (containerFlags & 1 /* IsContainer */) {
-        if (node.kind !== 218 /* ArrowFunction */) {
-          thisParentContainer = container;
-        }
-        container = blockScopeContainer = node;
-        if (containerFlags & 32 /* HasLocals */) {
-          container.locals = createSymbolTable();
-          addToContainerChain(container);
-        }
-      } else if (containerFlags & 2 /* IsBlockScopedContainer */) {
-        blockScopeContainer = node;
-        if (containerFlags & 32 /* HasLocals */) {
-          blockScopeContainer.locals = void 0;
-        }
-      }
-      if (containerFlags & 4 /* IsControlFlowContainer */) {
-        const saveCurrentFlow = currentFlow;
-        const saveBreakTarget = currentBreakTarget;
-        const saveContinueTarget = currentContinueTarget;
-        const saveReturnTarget = currentReturnTarget;
-        const saveExceptionTarget = currentExceptionTarget;
-        const saveActiveLabelList = activeLabelList;
-        const saveHasExplicitReturn = hasExplicitReturn;
-        const isImmediatelyInvoked = containerFlags & 16 /* IsFunctionExpression */ && !hasSyntacticModifier(node, 512 /* Async */) && !node.asteriskToken && !!getImmediatelyInvokedFunctionExpression(node) || node.kind === 174 /* ClassStaticBlockDeclaration */;
-        if (!isImmediatelyInvoked) {
-          currentFlow = initFlowNode({ flags: 2 /* Start */ });
-          if (containerFlags & (16 /* IsFunctionExpression */ | 128 /* IsObjectLiteralOrClassExpressionMethodOrAccessor */)) {
-            currentFlow.node = node;
-          }
-        }
-        currentReturnTarget = isImmediatelyInvoked || node.kind === 175 /* Constructor */ || isInJSFile(node) && (node.kind === 261 /* FunctionDeclaration */ || node.kind === 217 /* FunctionExpression */) ? createBranchLabel() : void 0;
-        currentExceptionTarget = void 0;
-        currentBreakTarget = void 0;
-        currentContinueTarget = void 0;
-        activeLabelList = void 0;
-        hasExplicitReturn = false;
-        bindChildren(node);
-        node.flags &= ~2816 /* ReachabilityAndEmitFlags */;
-        if (!(currentFlow.flags & 1 /* Unreachable */) && containerFlags & 8 /* IsFunctionLike */ && nodeIsPresent(node.body)) {
-          node.flags |= 256 /* HasImplicitReturn */;
-          if (hasExplicitReturn)
-            node.flags |= 512 /* HasExplicitReturn */;
-          node.endFlowNode = currentFlow;
-        }
-        if (node.kind === 311 /* SourceFile */) {
-          node.flags |= emitFlags;
-          node.endFlowNode = currentFlow;
-        }
-        if (currentReturnTarget) {
-          addAntecedent(currentReturnTarget, currentFlow);
-          currentFlow = finishFlowLabel(currentReturnTarget);
-          if (node.kind === 175 /* Constructor */ || node.kind === 174 /* ClassStaticBlockDeclaration */ || isInJSFile(node) && (node.kind === 261 /* FunctionDeclaration */ || node.kind === 217 /* FunctionExpression */)) {
-            node.returnFlowNode = currentFlow;
-          }
-        }
-        if (!isImmediatelyInvoked) {
-          currentFlow = saveCurrentFlow;
-        }
-        currentBreakTarget = saveBreakTarget;
-        currentContinueTarget = saveContinueTarget;
-        currentReturnTarget = saveReturnTarget;
-        currentExceptionTarget = saveExceptionTarget;
-        activeLabelList = saveActiveLabelList;
-        hasExplicitReturn = saveHasExplicitReturn;
-      } else if (containerFlags & 64 /* IsInterface */) {
-        seenThisKeyword = false;
-        bindChildren(node);
-        Debug.assertNotNode(node, isIdentifier);
-        node.flags = seenThisKeyword ? node.flags | 128 /* ContainsThis */ : node.flags & ~128 /* ContainsThis */;
-      } else {
-        bindChildren(node);
-      }
-      container = saveContainer;
-      thisParentContainer = saveThisParentContainer;
-      blockScopeContainer = savedBlockScopeContainer;
-    }
-    function bindEachFunctionsFirst(nodes) {
-      bindEach(nodes, (n) => n.kind === 261 /* FunctionDeclaration */ ? bind(n) : void 0);
-      bindEach(nodes, (n) => n.kind !== 261 /* FunctionDeclaration */ ? bind(n) : void 0);
-    }
-    function bindEach(nodes, bindFunction = bind) {
-      if (nodes === void 0) {
-        return;
-      }
-      forEach(nodes, bindFunction);
-    }
-    function bindEachChild(node) {
-      forEachChild(node, bind, bindEach);
-    }
-    function bindChildren(node) {
-      const saveInAssignmentPattern = inAssignmentPattern;
-      inAssignmentPattern = false;
-      if (checkUnreachable(node)) {
-        bindEachChild(node);
-        bindJSDoc(node);
-        inAssignmentPattern = saveInAssignmentPattern;
-        return;
-      }
-      if (node.kind >= 242 /* FirstStatement */ && node.kind <= 258 /* LastStatement */ && !options.allowUnreachableCode) {
-        node.flowNode = currentFlow;
-      }
-      switch (node.kind) {
-        case 246 /* WhileStatement */:
-          bindWhileStatement(node);
-          break;
-        case 245 /* DoStatement */:
-          bindDoStatement(node);
-          break;
-        case 247 /* ForStatement */:
-          bindForStatement(node);
-          break;
-        case 248 /* ForInStatement */:
-        case 249 /* ForOfStatement */:
-          bindForInOrForOfStatement(node);
-          break;
-        case 244 /* IfStatement */:
-          bindIfStatement(node);
-          break;
-        case 252 /* ReturnStatement */:
-        case 256 /* ThrowStatement */:
-          bindReturnOrThrow(node);
-          break;
-        case 251 /* BreakStatement */:
-        case 250 /* ContinueStatement */:
-          bindBreakOrContinueStatement(node);
-          break;
-        case 257 /* TryStatement */:
-          bindTryStatement(node);
-          break;
-        case 254 /* SwitchStatement */:
-          bindSwitchStatement(node);
-          break;
-        case 268 /* CaseBlock */:
-          bindCaseBlock(node);
-          break;
-        case 295 /* CaseClause */:
-          bindCaseClause(node);
-          break;
-        case 243 /* ExpressionStatement */:
-          bindExpressionStatement(node);
-          break;
-        case 255 /* LabeledStatement */:
-          bindLabeledStatement(node);
-          break;
-        case 223 /* PrefixUnaryExpression */:
-          bindPrefixUnaryExpressionFlow(node);
-          break;
-        case 224 /* PostfixUnaryExpression */:
-          bindPostfixUnaryExpressionFlow(node);
-          break;
-        case 225 /* BinaryExpression */:
-          if (isDestructuringAssignment(node)) {
-            inAssignmentPattern = saveInAssignmentPattern;
-            bindDestructuringAssignmentFlow(node);
-            return;
-          }
-          bindBinaryExpressionFlow(node);
-          break;
-        case 219 /* DeleteExpression */:
-          bindDeleteExpressionFlow(node);
-          break;
-        case 226 /* ConditionalExpression */:
-          bindConditionalExpressionFlow(node);
-          break;
-        case 259 /* VariableDeclaration */:
-          bindVariableDeclarationFlow(node);
-          break;
-        case 210 /* PropertyAccessExpression */:
-        case 211 /* ElementAccessExpression */:
-          bindAccessExpressionFlow(node);
-          break;
-        case 212 /* CallExpression */:
-          bindCallExpressionFlow(node);
-          break;
-        case 234 /* NonNullExpression */:
-          bindNonNullExpressionFlow(node);
-          break;
-        case 352 /* JSDocTypedefTag */:
-        case 344 /* JSDocCallbackTag */:
-        case 346 /* JSDocEnumTag */:
-          bindJSDocTypeAlias(node);
-          break;
-        case 311 /* SourceFile */: {
-          bindEachFunctionsFirst(node.statements);
-          bind(node.endOfFileToken);
-          break;
-        }
-        case 240 /* Block */:
-        case 267 /* ModuleBlock */:
-          bindEachFunctionsFirst(node.statements);
-          break;
-        case 207 /* BindingElement */:
-          bindBindingElementFlow(node);
-          break;
-        case 168 /* Parameter */:
-          bindParameterFlow(node);
-          break;
-        case 209 /* ObjectLiteralExpression */:
-        case 208 /* ArrayLiteralExpression */:
-        case 302 /* PropertyAssignment */:
-        case 229 /* SpreadElement */:
-          inAssignmentPattern = saveInAssignmentPattern;
-        default:
-          bindEachChild(node);
-          break;
-      }
-      bindJSDoc(node);
-      inAssignmentPattern = saveInAssignmentPattern;
-    }
-    function isNarrowingExpression(expr) {
-      switch (expr.kind) {
-        case 80 /* Identifier */:
-        case 81 /* PrivateIdentifier */:
-        case 110 /* ThisKeyword */:
-        case 210 /* PropertyAccessExpression */:
-        case 211 /* ElementAccessExpression */:
-          return containsNarrowableReference(expr);
-        case 212 /* CallExpression */:
-          return hasNarrowableArgument(expr);
-        case 216 /* ParenthesizedExpression */:
-        case 234 /* NonNullExpression */:
-          return isNarrowingExpression(expr.expression);
-        case 225 /* BinaryExpression */:
-          return isNarrowingBinaryExpression(expr);
-        case 223 /* PrefixUnaryExpression */:
-          return expr.operator === 54 /* ExclamationToken */ && isNarrowingExpression(expr.operand);
-        case 220 /* TypeOfExpression */:
-          return isNarrowingExpression(expr.expression);
-      }
-      return false;
-    }
-    function isNarrowableReference(expr) {
-      return isDottedName(expr) || (isPropertyAccessExpression(expr) || isNonNullExpression(expr) || isParenthesizedExpression(expr)) && isNarrowableReference(expr.expression) || isBinaryExpression(expr) && expr.operatorToken.kind === 28 /* CommaToken */ && isNarrowableReference(expr.right) || isElementAccessExpression(expr) && (isStringOrNumericLiteralLike(expr.argumentExpression) || isEntityNameExpression(expr.argumentExpression)) && isNarrowableReference(expr.expression) || isAssignmentExpression(expr) && isNarrowableReference(expr.left);
-    }
-    function containsNarrowableReference(expr) {
-      return isNarrowableReference(expr) || isOptionalChain(expr) && containsNarrowableReference(expr.expression);
-    }
-    function hasNarrowableArgument(expr) {
-      if (expr.arguments) {
-        for (const argument of expr.arguments) {
-          if (containsNarrowableReference(argument)) {
-            return true;
-          }
-        }
-      }
-      if (expr.expression.kind === 210 /* PropertyAccessExpression */ && containsNarrowableReference(expr.expression.expression)) {
-        return true;
-      }
-      return false;
-    }
-    function isNarrowingTypeofOperands(expr1, expr2) {
-      return isTypeOfExpression(expr1) && isNarrowableOperand(expr1.expression) && isStringLiteralLike(expr2);
-    }
-    function isNarrowingBinaryExpression(expr) {
-      switch (expr.operatorToken.kind) {
-        case 64 /* EqualsToken */:
-        case 76 /* BarBarEqualsToken */:
-        case 77 /* AmpersandAmpersandEqualsToken */:
-        case 78 /* QuestionQuestionEqualsToken */:
-          return containsNarrowableReference(expr.left);
-        case 35 /* EqualsEqualsToken */:
-        case 36 /* ExclamationEqualsToken */:
-        case 37 /* EqualsEqualsEqualsToken */:
-        case 38 /* ExclamationEqualsEqualsToken */:
-          return isNarrowableOperand(expr.left) || isNarrowableOperand(expr.right) || isNarrowingTypeofOperands(expr.right, expr.left) || isNarrowingTypeofOperands(expr.left, expr.right);
-        case 104 /* InstanceOfKeyword */:
-          return isNarrowableOperand(expr.left);
-        case 103 /* InKeyword */:
-          return isNarrowingExpression(expr.right);
-        case 28 /* CommaToken */:
-          return isNarrowingExpression(expr.right);
-      }
-      return false;
-    }
-    function isNarrowableOperand(expr) {
-      switch (expr.kind) {
-        case 216 /* ParenthesizedExpression */:
-          return isNarrowableOperand(expr.expression);
-        case 225 /* BinaryExpression */:
-          switch (expr.operatorToken.kind) {
-            case 64 /* EqualsToken */:
-              return isNarrowableOperand(expr.left);
-            case 28 /* CommaToken */:
-              return isNarrowableOperand(expr.right);
-          }
-      }
-      return containsNarrowableReference(expr);
-    }
-    function createBranchLabel() {
-      return initFlowNode({ flags: 4 /* BranchLabel */, antecedents: void 0 });
-    }
-    function createLoopLabel() {
-      return initFlowNode({ flags: 8 /* LoopLabel */, antecedents: void 0 });
-    }
-    function createReduceLabel(target, antecedents, antecedent) {
-      return initFlowNode({ flags: 1024 /* ReduceLabel */, target, antecedents, antecedent });
-    }
-    function setFlowNodeReferenced(flow) {
-      flow.flags |= flow.flags & 2048 /* Referenced */ ? 4096 /* Shared */ : 2048 /* Referenced */;
-    }
-    function addAntecedent(label, antecedent) {
-      if (!(antecedent.flags & 1 /* Unreachable */) && !contains(label.antecedents, antecedent)) {
-        (label.antecedents || (label.antecedents = [])).push(antecedent);
-        setFlowNodeReferenced(antecedent);
-      }
-    }
-    function createFlowCondition(flags, antecedent, expression) {
-      if (antecedent.flags & 1 /* Unreachable */) {
-        return antecedent;
-      }
-      if (!expression) {
-        return flags & 32 /* TrueCondition */ ? antecedent : unreachableFlow;
-      }
-      if ((expression.kind === 112 /* TrueKeyword */ && flags & 64 /* FalseCondition */ || expression.kind === 97 /* FalseKeyword */ && flags & 32 /* TrueCondition */) && !isExpressionOfOptionalChainRoot(expression) && !isNullishCoalesce(expression.parent)) {
-        return unreachableFlow;
-      }
-      if (!isNarrowingExpression(expression)) {
-        return antecedent;
-      }
-      setFlowNodeReferenced(antecedent);
-      return initFlowNode({ flags, antecedent, node: expression });
-    }
-    function createFlowSwitchClause(antecedent, switchStatement, clauseStart, clauseEnd) {
-      setFlowNodeReferenced(antecedent);
-      return initFlowNode({ flags: 128 /* SwitchClause */, antecedent, switchStatement, clauseStart, clauseEnd });
-    }
-    function createFlowMutation(flags, antecedent, node) {
-      setFlowNodeReferenced(antecedent);
-      const result = initFlowNode({ flags, antecedent, node });
-      if (currentExceptionTarget) {
-        addAntecedent(currentExceptionTarget, result);
-      }
-      return result;
-    }
-    function createFlowCall(antecedent, node) {
-      setFlowNodeReferenced(antecedent);
-      return initFlowNode({ flags: 512 /* Call */, antecedent, node });
-    }
-    function finishFlowLabel(flow) {
-      const antecedents = flow.antecedents;
-      if (!antecedents) {
-        return unreachableFlow;
-      }
-      if (antecedents.length === 1) {
-        return antecedents[0];
-      }
-      return flow;
-    }
-    function isStatementCondition(node) {
-      const parent3 = node.parent;
-      switch (parent3.kind) {
-        case 244 /* IfStatement */:
-        case 246 /* WhileStatement */:
-        case 245 /* DoStatement */:
-          return parent3.expression === node;
-        case 247 /* ForStatement */:
-        case 226 /* ConditionalExpression */:
-          return parent3.condition === node;
-      }
-      return false;
-    }
-    function isLogicalExpression(node) {
-      while (true) {
-        if (node.kind === 216 /* ParenthesizedExpression */) {
-          node = node.expression;
-        } else if (node.kind === 223 /* PrefixUnaryExpression */ && node.operator === 54 /* ExclamationToken */) {
-          node = node.operand;
-        } else {
-          return isLogicalOrCoalescingBinaryExpression(node);
-        }
-      }
-    }
-    function isLogicalAssignmentExpression(node) {
-      return isLogicalOrCoalescingAssignmentExpression(skipParentheses(node));
-    }
-    function isTopLevelLogicalExpression(node) {
-      while (isParenthesizedExpression(node.parent) || isPrefixUnaryExpression(node.parent) && node.parent.operator === 54 /* ExclamationToken */) {
-        node = node.parent;
-      }
-      return !isStatementCondition(node) && !isLogicalExpression(node.parent) && !(isOptionalChain(node.parent) && node.parent.expression === node);
-    }
-    function doWithConditionalBranches(action, value, trueTarget, falseTarget) {
-      const savedTrueTarget = currentTrueTarget;
-      const savedFalseTarget = currentFalseTarget;
-      currentTrueTarget = trueTarget;
-      currentFalseTarget = falseTarget;
-      action(value);
-      currentTrueTarget = savedTrueTarget;
-      currentFalseTarget = savedFalseTarget;
-    }
-    function bindCondition(node, trueTarget, falseTarget) {
-      doWithConditionalBranches(bind, node, trueTarget, falseTarget);
-      if (!node || !isLogicalAssignmentExpression(node) && !isLogicalExpression(node) && !(isOptionalChain(node) && isOutermostOptionalChain(node))) {
-        addAntecedent(trueTarget, createFlowCondition(32 /* TrueCondition */, currentFlow, node));
-        addAntecedent(falseTarget, createFlowCondition(64 /* FalseCondition */, currentFlow, node));
-      }
-    }
-    function bindIterativeStatement(node, breakTarget, continueTarget) {
-      const saveBreakTarget = currentBreakTarget;
-      const saveContinueTarget = currentContinueTarget;
-      currentBreakTarget = breakTarget;
-      currentContinueTarget = continueTarget;
-      bind(node);
-      currentBreakTarget = saveBreakTarget;
-      currentContinueTarget = saveContinueTarget;
-    }
-    function setContinueTarget(node, target) {
-      let label = activeLabelList;
-      while (label && node.parent.kind === 255 /* LabeledStatement */) {
-        label.continueTarget = target;
-        label = label.next;
-        node = node.parent;
-      }
-      return target;
-    }
-    function bindWhileStatement(node) {
-      const preWhileLabel = setContinueTarget(node, createLoopLabel());
-      const preBodyLabel = createBranchLabel();
-      const postWhileLabel = createBranchLabel();
-      addAntecedent(preWhileLabel, currentFlow);
-      currentFlow = preWhileLabel;
-      bindCondition(node.expression, preBodyLabel, postWhileLabel);
-      currentFlow = finishFlowLabel(preBodyLabel);
-      bindIterativeStatement(node.statement, postWhileLabel, preWhileLabel);
-      addAntecedent(preWhileLabel, currentFlow);
-      currentFlow = finishFlowLabel(postWhileLabel);
-    }
-    function bindDoStatement(node) {
-      const preDoLabel = createLoopLabel();
-      const preConditionLabel = setContinueTarget(node, createBranchLabel());
-      const postDoLabel = createBranchLabel();
-      addAntecedent(preDoLabel, currentFlow);
-      currentFlow = preDoLabel;
-      bindIterativeStatement(node.statement, postDoLabel, preConditionLabel);
-      addAntecedent(preConditionLabel, currentFlow);
-      currentFlow = finishFlowLabel(preConditionLabel);
-      bindCondition(node.expression, preDoLabel, postDoLabel);
-      currentFlow = finishFlowLabel(postDoLabel);
-    }
-    function bindForStatement(node) {
-      const preLoopLabel = setContinueTarget(node, createLoopLabel());
-      const preBodyLabel = createBranchLabel();
-      const postLoopLabel = createBranchLabel();
-      bind(node.initializer);
-      addAntecedent(preLoopLabel, currentFlow);
-      currentFlow = preLoopLabel;
-      bindCondition(node.condition, preBodyLabel, postLoopLabel);
-      currentFlow = finishFlowLabel(preBodyLabel);
-      bindIterativeStatement(node.statement, postLoopLabel, preLoopLabel);
-      bind(node.incrementor);
-      addAntecedent(preLoopLabel, currentFlow);
-      currentFlow = finishFlowLabel(postLoopLabel);
-    }
-    function bindForInOrForOfStatement(node) {
-      const preLoopLabel = setContinueTarget(node, createLoopLabel());
-      const postLoopLabel = createBranchLabel();
-      bind(node.expression);
-      addAntecedent(preLoopLabel, currentFlow);
-      currentFlow = preLoopLabel;
-      if (node.kind === 249 /* ForOfStatement */) {
-        bind(node.awaitModifier);
-      }
-      addAntecedent(postLoopLabel, currentFlow);
-      bind(node.initializer);
-      if (node.initializer.kind !== 260 /* VariableDeclarationList */) {
-        bindAssignmentTargetFlow(node.initializer);
-      }
-      bindIterativeStatement(node.statement, postLoopLabel, preLoopLabel);
-      addAntecedent(preLoopLabel, currentFlow);
-      currentFlow = finishFlowLabel(postLoopLabel);
-    }
-    function bindIfStatement(node) {
-      const thenLabel = createBranchLabel();
-      const elseLabel = createBranchLabel();
-      const postIfLabel = createBranchLabel();
-      bindCondition(node.expression, thenLabel, elseLabel);
-      currentFlow = finishFlowLabel(thenLabel);
-      bind(node.thenStatement);
-      addAntecedent(postIfLabel, currentFlow);
-      currentFlow = finishFlowLabel(elseLabel);
-      bind(node.elseStatement);
-      addAntecedent(postIfLabel, currentFlow);
-      currentFlow = finishFlowLabel(postIfLabel);
-    }
-    function bindReturnOrThrow(node) {
-      bind(node.expression);
-      if (node.kind === 252 /* ReturnStatement */) {
-        hasExplicitReturn = true;
-        if (currentReturnTarget) {
-          addAntecedent(currentReturnTarget, currentFlow);
-        }
-      }
-      currentFlow = unreachableFlow;
-    }
-    function findActiveLabel(name) {
-      for (let label = activeLabelList; label; label = label.next) {
-        if (label.name === name) {
-          return label;
-        }
-      }
-      return void 0;
-    }
-    function bindBreakOrContinueFlow(node, breakTarget, continueTarget) {
-      const flowLabel = node.kind === 251 /* BreakStatement */ ? breakTarget : continueTarget;
-      if (flowLabel) {
-        addAntecedent(flowLabel, currentFlow);
-        currentFlow = unreachableFlow;
-      }
-    }
-    function bindBreakOrContinueStatement(node) {
-      bind(node.label);
-      if (node.label) {
-        const activeLabel = findActiveLabel(node.label.escapedText);
-        if (activeLabel) {
-          activeLabel.referenced = true;
-          bindBreakOrContinueFlow(node, activeLabel.breakTarget, activeLabel.continueTarget);
-        }
-      } else {
-        bindBreakOrContinueFlow(node, currentBreakTarget, currentContinueTarget);
-      }
-    }
-    function bindTryStatement(node) {
-      const saveReturnTarget = currentReturnTarget;
-      const saveExceptionTarget = currentExceptionTarget;
-      const normalExitLabel = createBranchLabel();
-      const returnLabel = createBranchLabel();
-      let exceptionLabel = createBranchLabel();
-      if (node.finallyBlock) {
-        currentReturnTarget = returnLabel;
-      }
-      addAntecedent(exceptionLabel, currentFlow);
-      currentExceptionTarget = exceptionLabel;
-      bind(node.tryBlock);
-      addAntecedent(normalExitLabel, currentFlow);
-      if (node.catchClause) {
-        currentFlow = finishFlowLabel(exceptionLabel);
-        exceptionLabel = createBranchLabel();
-        addAntecedent(exceptionLabel, currentFlow);
-        currentExceptionTarget = exceptionLabel;
-        bind(node.catchClause);
-        addAntecedent(normalExitLabel, currentFlow);
-      }
-      currentReturnTarget = saveReturnTarget;
-      currentExceptionTarget = saveExceptionTarget;
-      if (node.finallyBlock) {
-        const finallyLabel = createBranchLabel();
-        finallyLabel.antecedents = concatenate(concatenate(normalExitLabel.antecedents, exceptionLabel.antecedents), returnLabel.antecedents);
-        currentFlow = finallyLabel;
-        bind(node.finallyBlock);
-        if (currentFlow.flags & 1 /* Unreachable */) {
-          currentFlow = unreachableFlow;
-        } else {
-          if (currentReturnTarget && returnLabel.antecedents) {
-            addAntecedent(currentReturnTarget, createReduceLabel(finallyLabel, returnLabel.antecedents, currentFlow));
-          }
-          if (currentExceptionTarget && exceptionLabel.antecedents) {
-            addAntecedent(currentExceptionTarget, createReduceLabel(finallyLabel, exceptionLabel.antecedents, currentFlow));
-          }
-          currentFlow = normalExitLabel.antecedents ? createReduceLabel(finallyLabel, normalExitLabel.antecedents, currentFlow) : unreachableFlow;
-        }
-      } else {
-        currentFlow = finishFlowLabel(normalExitLabel);
-      }
-    }
-    function bindSwitchStatement(node) {
-      const postSwitchLabel = createBranchLabel();
-      bind(node.expression);
-      const saveBreakTarget = currentBreakTarget;
-      const savePreSwitchCaseFlow = preSwitchCaseFlow;
-      currentBreakTarget = postSwitchLabel;
-      preSwitchCaseFlow = currentFlow;
-      bind(node.caseBlock);
-      addAntecedent(postSwitchLabel, currentFlow);
-      const hasDefault = forEach(node.caseBlock.clauses, (c) => c.kind === 296 /* DefaultClause */);
-      node.possiblyExhaustive = !hasDefault && !postSwitchLabel.antecedents;
-      if (!hasDefault) {
-        addAntecedent(postSwitchLabel, createFlowSwitchClause(preSwitchCaseFlow, node, 0, 0));
-      }
-      currentBreakTarget = saveBreakTarget;
-      preSwitchCaseFlow = savePreSwitchCaseFlow;
-      currentFlow = finishFlowLabel(postSwitchLabel);
-    }
-    function bindCaseBlock(node) {
-      const clauses = node.clauses;
-      const isNarrowingSwitch = isNarrowingExpression(node.parent.expression);
-      let fallthroughFlow = unreachableFlow;
-      for (let i = 0; i < clauses.length; i++) {
-        const clauseStart = i;
-        while (!clauses[i].statements.length && i + 1 < clauses.length) {
-          bind(clauses[i]);
-          i++;
-        }
-        const preCaseLabel = createBranchLabel();
-        addAntecedent(preCaseLabel, isNarrowingSwitch ? createFlowSwitchClause(preSwitchCaseFlow, node.parent, clauseStart, i + 1) : preSwitchCaseFlow);
-        addAntecedent(preCaseLabel, fallthroughFlow);
-        currentFlow = finishFlowLabel(preCaseLabel);
-        const clause = clauses[i];
-        bind(clause);
-        fallthroughFlow = currentFlow;
-        if (!(currentFlow.flags & 1 /* Unreachable */) && i !== clauses.length - 1 && options.noFallthroughCasesInSwitch) {
-          clause.fallthroughFlowNode = currentFlow;
-        }
-      }
-    }
-    function bindCaseClause(node) {
-      const saveCurrentFlow = currentFlow;
-      currentFlow = preSwitchCaseFlow;
-      bind(node.expression);
-      currentFlow = saveCurrentFlow;
-      bindEach(node.statements);
-    }
-    function bindExpressionStatement(node) {
-      bind(node.expression);
-      maybeBindExpressionFlowIfCall(node.expression);
-    }
-    function maybeBindExpressionFlowIfCall(node) {
-      if (node.kind === 212 /* CallExpression */) {
-        const call = node;
-        if (call.expression.kind !== 108 /* SuperKeyword */ && isDottedName(call.expression)) {
-          currentFlow = createFlowCall(currentFlow, call);
-        }
-      }
-    }
-    function bindLabeledStatement(node) {
-      const postStatementLabel = createBranchLabel();
-      activeLabelList = {
-        next: activeLabelList,
-        name: node.label.escapedText,
-        breakTarget: postStatementLabel,
-        continueTarget: void 0,
-        referenced: false
-      };
-      bind(node.label);
-      bind(node.statement);
-      if (!activeLabelList.referenced && !options.allowUnusedLabels) {
-        errorOrSuggestionOnNode(unusedLabelIsError(options), node.label, Diagnostics.Unused_label);
-      }
-      activeLabelList = activeLabelList.next;
-      addAntecedent(postStatementLabel, currentFlow);
-      currentFlow = finishFlowLabel(postStatementLabel);
-    }
-    function bindDestructuringTargetFlow(node) {
-      if (node.kind === 225 /* BinaryExpression */ && node.operatorToken.kind === 64 /* EqualsToken */) {
-        bindAssignmentTargetFlow(node.left);
-      } else {
-        bindAssignmentTargetFlow(node);
-      }
-    }
-    function bindAssignmentTargetFlow(node) {
-      if (isNarrowableReference(node)) {
-        currentFlow = createFlowMutation(16 /* Assignment */, currentFlow, node);
-      } else if (node.kind === 208 /* ArrayLiteralExpression */) {
-        for (const e of node.elements) {
-          if (e.kind === 229 /* SpreadElement */) {
-            bindAssignmentTargetFlow(e.expression);
-          } else {
-            bindDestructuringTargetFlow(e);
-          }
-        }
-      } else if (node.kind === 209 /* ObjectLiteralExpression */) {
-        for (const p of node.properties) {
-          if (p.kind === 302 /* PropertyAssignment */) {
-            bindDestructuringTargetFlow(p.initializer);
-          } else if (p.kind === 303 /* ShorthandPropertyAssignment */) {
-            bindAssignmentTargetFlow(p.name);
-          } else if (p.kind === 304 /* SpreadAssignment */) {
-            bindAssignmentTargetFlow(p.expression);
-          }
-        }
-      }
-    }
-    function bindLogicalLikeExpression(node, trueTarget, falseTarget) {
-      const preRightLabel = createBranchLabel();
-      if (node.operatorToken.kind === 56 /* AmpersandAmpersandToken */ || node.operatorToken.kind === 77 /* AmpersandAmpersandEqualsToken */) {
-        bindCondition(node.left, preRightLabel, falseTarget);
-      } else {
-        bindCondition(node.left, trueTarget, preRightLabel);
-      }
-      currentFlow = finishFlowLabel(preRightLabel);
-      bind(node.operatorToken);
-      if (isLogicalOrCoalescingAssignmentOperator(node.operatorToken.kind)) {
-        doWithConditionalBranches(bind, node.right, trueTarget, falseTarget);
-        bindAssignmentTargetFlow(node.left);
-        addAntecedent(trueTarget, createFlowCondition(32 /* TrueCondition */, currentFlow, node));
-        addAntecedent(falseTarget, createFlowCondition(64 /* FalseCondition */, currentFlow, node));
-      } else {
-        bindCondition(node.right, trueTarget, falseTarget);
-      }
-    }
-    function bindPrefixUnaryExpressionFlow(node) {
-      if (node.operator === 54 /* ExclamationToken */) {
-        const saveTrueTarget = currentTrueTarget;
-        currentTrueTarget = currentFalseTarget;
-        currentFalseTarget = saveTrueTarget;
-        bindEachChild(node);
-        currentFalseTarget = currentTrueTarget;
-        currentTrueTarget = saveTrueTarget;
-      } else {
-        bindEachChild(node);
-        if (node.operator === 46 /* PlusPlusToken */ || node.operator === 47 /* MinusMinusToken */) {
-          bindAssignmentTargetFlow(node.operand);
-        }
-      }
-    }
-    function bindPostfixUnaryExpressionFlow(node) {
-      bindEachChild(node);
-      if (node.operator === 46 /* PlusPlusToken */ || node.operator === 47 /* MinusMinusToken */) {
-        bindAssignmentTargetFlow(node.operand);
-      }
-    }
-    function bindDestructuringAssignmentFlow(node) {
-      if (inAssignmentPattern) {
-        inAssignmentPattern = false;
-        bind(node.operatorToken);
-        bind(node.right);
-        inAssignmentPattern = true;
-        bind(node.left);
-      } else {
-        inAssignmentPattern = true;
-        bind(node.left);
-        inAssignmentPattern = false;
-        bind(node.operatorToken);
-        bind(node.right);
-      }
-      bindAssignmentTargetFlow(node.left);
-    }
-    function createBindBinaryExpressionFlow() {
-      return createBinaryExpressionTrampoline(
-        onEnter,
-        onLeft,
-        onOperator,
-        onRight,
-        onExit,
-        /*foldState*/
-        void 0
-      );
-      function onEnter(node, state) {
-        if (state) {
-          state.stackIndex++;
-          setParent(node, parent2);
-          const saveInStrictMode = inStrictMode;
-          bindWorker(node);
-          const saveParent = parent2;
-          parent2 = node;
-          state.skip = false;
-          state.inStrictModeStack[state.stackIndex] = saveInStrictMode;
-          state.parentStack[state.stackIndex] = saveParent;
-        } else {
-          state = {
-            stackIndex: 0,
-            skip: false,
-            inStrictModeStack: [void 0],
-            parentStack: [void 0]
-          };
-        }
-        const operator = node.operatorToken.kind;
-        if (isLogicalOrCoalescingBinaryOperator(operator) || isLogicalOrCoalescingAssignmentOperator(operator)) {
-          if (isTopLevelLogicalExpression(node)) {
-            const postExpressionLabel = createBranchLabel();
-            bindLogicalLikeExpression(node, postExpressionLabel, postExpressionLabel);
-            currentFlow = finishFlowLabel(postExpressionLabel);
-          } else {
-            bindLogicalLikeExpression(node, currentTrueTarget, currentFalseTarget);
-          }
-          state.skip = true;
-        }
-        return state;
-      }
-      function onLeft(left, state, node) {
-        if (!state.skip) {
-          const maybeBound = maybeBind2(left);
-          if (node.operatorToken.kind === 28 /* CommaToken */) {
-            maybeBindExpressionFlowIfCall(left);
-          }
-          return maybeBound;
-        }
-      }
-      function onOperator(operatorToken, state, _node) {
-        if (!state.skip) {
-          bind(operatorToken);
-        }
-      }
-      function onRight(right, state, node) {
-        if (!state.skip) {
-          const maybeBound = maybeBind2(right);
-          if (node.operatorToken.kind === 28 /* CommaToken */) {
-            maybeBindExpressionFlowIfCall(right);
-          }
-          return maybeBound;
-        }
-      }
-      function onExit(node, state) {
-        if (!state.skip) {
-          const operator = node.operatorToken.kind;
-          if (isAssignmentOperator(operator) && !isAssignmentTarget(node)) {
-            bindAssignmentTargetFlow(node.left);
-            if (operator === 64 /* EqualsToken */ && node.left.kind === 211 /* ElementAccessExpression */) {
-              const elementAccess = node.left;
-              if (isNarrowableOperand(elementAccess.expression)) {
-                currentFlow = createFlowMutation(256 /* ArrayMutation */, currentFlow, node);
-              }
-            }
-          }
-        }
-        const savedInStrictMode = state.inStrictModeStack[state.stackIndex];
-        const savedParent = state.parentStack[state.stackIndex];
-        if (savedInStrictMode !== void 0) {
-          inStrictMode = savedInStrictMode;
-        }
-        if (savedParent !== void 0) {
-          parent2 = savedParent;
-        }
-        state.skip = false;
-        state.stackIndex--;
-      }
-      function maybeBind2(node) {
-        if (node && isBinaryExpression(node) && !isDestructuringAssignment(node)) {
-          return node;
-        }
-        bind(node);
-      }
-    }
-    function bindDeleteExpressionFlow(node) {
-      bindEachChild(node);
-      if (node.expression.kind === 210 /* PropertyAccessExpression */) {
-        bindAssignmentTargetFlow(node.expression);
-      }
-    }
-    function bindConditionalExpressionFlow(node) {
-      const trueLabel = createBranchLabel();
-      const falseLabel = createBranchLabel();
-      const postExpressionLabel = createBranchLabel();
-      bindCondition(node.condition, trueLabel, falseLabel);
-      currentFlow = finishFlowLabel(trueLabel);
-      bind(node.questionToken);
-      bind(node.whenTrue);
-      addAntecedent(postExpressionLabel, currentFlow);
-      currentFlow = finishFlowLabel(falseLabel);
-      bind(node.colonToken);
-      bind(node.whenFalse);
-      addAntecedent(postExpressionLabel, currentFlow);
-      currentFlow = finishFlowLabel(postExpressionLabel);
-    }
-    function bindInitializedVariableFlow(node) {
-      const name = !isOmittedExpression(node) ? node.name : void 0;
-      if (isBindingPattern(name)) {
-        for (const child of name.elements) {
-          bindInitializedVariableFlow(child);
-        }
-      } else {
-        currentFlow = createFlowMutation(16 /* Assignment */, currentFlow, node);
-      }
-    }
-    function bindVariableDeclarationFlow(node) {
-      bindEachChild(node);
-      if (node.initializer || isForInOrOfStatement(node.parent.parent)) {
-        bindInitializedVariableFlow(node);
-      }
-    }
-    function bindBindingElementFlow(node) {
-      bind(node.dotDotDotToken);
-      bind(node.propertyName);
-      bindInitializer(node.initializer);
-      bind(node.name);
-    }
-    function bindParameterFlow(node) {
-      bindEach(node.modifiers);
-      bind(node.dotDotDotToken);
-      bind(node.questionToken);
-      bind(node.type);
-      bindInitializer(node.initializer);
-      bind(node.name);
-    }
-    function bindInitializer(node) {
-      if (!node) {
-        return;
-      }
-      const entryFlow = currentFlow;
-      bind(node);
-      if (entryFlow === unreachableFlow || entryFlow === currentFlow) {
-        return;
-      }
-      const exitFlow = createBranchLabel();
-      addAntecedent(exitFlow, entryFlow);
-      addAntecedent(exitFlow, currentFlow);
-      currentFlow = finishFlowLabel(exitFlow);
-    }
-    function bindJSDocTypeAlias(node) {
-      bind(node.tagName);
-      if (node.kind !== 346 /* JSDocEnumTag */ && node.fullName) {
-        setParent(node.fullName, node);
-        setParentRecursive(
-          node.fullName,
-          /*incremental*/
-          false
-        );
-      }
-      if (typeof node.comment !== "string") {
-        bindEach(node.comment);
-      }
-    }
-    function bindJSDocClassTag(node) {
-      bindEachChild(node);
-      const host = getHostSignatureFromJSDoc(node);
-      if (host && host.kind !== 173 /* MethodDeclaration */) {
-        addDeclarationToSymbol(host.symbol, host, 32 /* Class */);
-      }
-    }
-    function bindOptionalExpression(node, trueTarget, falseTarget) {
-      doWithConditionalBranches(bind, node, trueTarget, falseTarget);
-      if (!isOptionalChain(node) || isOutermostOptionalChain(node)) {
-        addAntecedent(trueTarget, createFlowCondition(32 /* TrueCondition */, currentFlow, node));
-        addAntecedent(falseTarget, createFlowCondition(64 /* FalseCondition */, currentFlow, node));
-      }
-    }
-    function bindOptionalChainRest(node) {
-      switch (node.kind) {
-        case 210 /* PropertyAccessExpression */:
-          bind(node.questionDotToken);
-          bind(node.name);
-          break;
-        case 211 /* ElementAccessExpression */:
-          bind(node.questionDotToken);
-          bind(node.argumentExpression);
-          break;
-        case 212 /* CallExpression */:
-          bind(node.questionDotToken);
-          bindEach(node.typeArguments);
-          bindEach(node.arguments);
-          break;
-      }
-    }
-    function bindOptionalChain(node, trueTarget, falseTarget) {
-      const preChainLabel = isOptionalChainRoot(node) ? createBranchLabel() : void 0;
-      bindOptionalExpression(node.expression, preChainLabel || trueTarget, falseTarget);
-      if (preChainLabel) {
-        currentFlow = finishFlowLabel(preChainLabel);
-      }
-      doWithConditionalBranches(bindOptionalChainRest, node, trueTarget, falseTarget);
-      if (isOutermostOptionalChain(node)) {
-        addAntecedent(trueTarget, createFlowCondition(32 /* TrueCondition */, currentFlow, node));
-        addAntecedent(falseTarget, createFlowCondition(64 /* FalseCondition */, currentFlow, node));
-      }
-    }
-    function bindOptionalChainFlow(node) {
-      if (isTopLevelLogicalExpression(node)) {
-        const postExpressionLabel = createBranchLabel();
-        bindOptionalChain(node, postExpressionLabel, postExpressionLabel);
-        currentFlow = finishFlowLabel(postExpressionLabel);
-      } else {
-        bindOptionalChain(node, currentTrueTarget, currentFalseTarget);
-      }
-    }
-    function bindNonNullExpressionFlow(node) {
-      if (isOptionalChain(node)) {
-        bindOptionalChainFlow(node);
-      } else {
-        bindEachChild(node);
-      }
-    }
-    function bindAccessExpressionFlow(node) {
-      if (isOptionalChain(node)) {
-        bindOptionalChainFlow(node);
-      } else {
-        bindEachChild(node);
-      }
-    }
-    function bindCallExpressionFlow(node) {
-      if (isOptionalChain(node)) {
-        bindOptionalChainFlow(node);
-      } else {
-        const expr = skipParentheses(node.expression);
-        if (expr.kind === 217 /* FunctionExpression */ || expr.kind === 218 /* ArrowFunction */) {
-          bindEach(node.typeArguments);
-          bindEach(node.arguments);
-          bind(node.expression);
-        } else {
-          bindEachChild(node);
-          if (node.expression.kind === 108 /* SuperKeyword */) {
-            currentFlow = createFlowCall(currentFlow, node);
-          }
-        }
-      }
-      if (node.expression.kind === 210 /* PropertyAccessExpression */) {
-        const propertyAccess = node.expression;
-        if (isIdentifier(propertyAccess.name) && isNarrowableOperand(propertyAccess.expression) && isPushOrUnshiftIdentifier(propertyAccess.name)) {
-          currentFlow = createFlowMutation(256 /* ArrayMutation */, currentFlow, node);
-        }
-      }
-    }
-    function addToContainerChain(next) {
-      if (lastContainer) {
-        lastContainer.nextContainer = next;
-      }
-      lastContainer = next;
-    }
-    function declareSymbolAndAddToSymbolTable(node, symbolFlags, symbolExcludes) {
-      switch (container.kind) {
-        case 266 /* ModuleDeclaration */:
-          return declareModuleMember(node, symbolFlags, symbolExcludes);
-        case 311 /* SourceFile */:
-          return declareSourceFileMember(node, symbolFlags, symbolExcludes);
-        case 230 /* ClassExpression */:
-        case 262 /* ClassDeclaration */:
-          return declareClassMember(node, symbolFlags, symbolExcludes);
-        case 265 /* EnumDeclaration */:
-          return declareSymbol(container.symbol.exports, container.symbol, node, symbolFlags, symbolExcludes);
-        case 186 /* TypeLiteral */:
-        case 328 /* JSDocTypeLiteral */:
-        case 209 /* ObjectLiteralExpression */:
-        case 263 /* InterfaceDeclaration */:
-        case 291 /* JsxAttributes */:
-          return declareSymbol(container.symbol.members, container.symbol, node, symbolFlags, symbolExcludes);
-        case 183 /* FunctionType */:
-        case 184 /* ConstructorType */:
-        case 178 /* CallSignature */:
-        case 179 /* ConstructSignature */:
-        case 329 /* JSDocSignature */:
-        case 180 /* IndexSignature */:
-        case 173 /* MethodDeclaration */:
-        case 172 /* MethodSignature */:
-        case 175 /* Constructor */:
-        case 176 /* GetAccessor */:
-        case 177 /* SetAccessor */:
-        case 261 /* FunctionDeclaration */:
-        case 217 /* FunctionExpression */:
-        case 218 /* ArrowFunction */:
-        case 323 /* JSDocFunctionType */:
-        case 174 /* ClassStaticBlockDeclaration */:
-        case 264 /* TypeAliasDeclaration */:
-        case 199 /* MappedType */:
-          if (container.locals)
-            Debug.assertNode(container, canHaveLocals);
-          return declareSymbol(
-            container.locals,
-            /*parent*/
-            void 0,
-            node,
-            symbolFlags,
-            symbolExcludes
-          );
-      }
-    }
-    function declareClassMember(node, symbolFlags, symbolExcludes) {
-      return isStatic(node) ? declareSymbol(container.symbol.exports, container.symbol, node, symbolFlags, symbolExcludes) : declareSymbol(container.symbol.members, container.symbol, node, symbolFlags, symbolExcludes);
-    }
-    function declareSourceFileMember(node, symbolFlags, symbolExcludes) {
-      return isExternalModule(file) ? declareModuleMember(node, symbolFlags, symbolExcludes) : declareSymbol(
-        file.locals,
-        /*parent*/
-        void 0,
-        node,
-        symbolFlags,
-        symbolExcludes
-      );
-    }
-    function hasExportDeclarations(node) {
-      const body = isSourceFile(node) ? node : tryCast(node.body, isModuleBlock);
-      return !!body && body.statements.some((s) => isExportDeclaration(s) || isExportAssignment(s));
-    }
-    function setExportContextFlag(node) {
-      if (node.flags & 16777216 /* Ambient */ && !hasExportDeclarations(node)) {
-        node.flags |= 64 /* ExportContext */;
-      } else {
-        node.flags &= ~64 /* ExportContext */;
-      }
-    }
-    function bindModuleDeclaration(node) {
-      setExportContextFlag(node);
-      if (isAmbientModule(node)) {
-        if (hasSyntacticModifier(node, 1 /* Export */)) {
-          errorOnFirstToken(node, Diagnostics.export_modifier_cannot_be_applied_to_ambient_modules_and_module_augmentations_since_they_are_always_visible);
-        }
-        if (isModuleAugmentationExternal(node)) {
-          declareModuleSymbol(node);
-        } else {
-          let pattern;
-          if (node.name.kind === 11 /* StringLiteral */) {
-            const { text } = node.name;
-            pattern = tryParsePattern(text);
-            if (pattern === void 0) {
-              errorOnFirstToken(node.name, Diagnostics.Pattern_0_can_have_at_most_one_Asterisk_character, text);
-            }
-          }
-          const symbol = declareSymbolAndAddToSymbolTable(node, 512 /* ValueModule */, 110735 /* ValueModuleExcludes */);
-          file.patternAmbientModules = append(file.patternAmbientModules, pattern && !isString(pattern) ? { pattern, symbol } : void 0);
-        }
-      } else {
-        const state = declareModuleSymbol(node);
-        if (state !== 0 /* NonInstantiated */) {
-          const { symbol } = node;
-          symbol.constEnumOnlyModule = !(symbol.flags & (16 /* Function */ | 32 /* Class */ | 256 /* RegularEnum */)) && state === 2 /* ConstEnumOnly */ && symbol.constEnumOnlyModule !== false;
-        }
-      }
-    }
-    function declareModuleSymbol(node) {
-      const state = getModuleInstanceState(node);
-      const instantiated = state !== 0 /* NonInstantiated */;
-      declareSymbolAndAddToSymbolTable(
-        node,
-        instantiated ? 512 /* ValueModule */ : 1024 /* NamespaceModule */,
-        instantiated ? 110735 /* ValueModuleExcludes */ : 0 /* NamespaceModuleExcludes */
-      );
-      return state;
-    }
-    function bindFunctionOrConstructorType(node) {
-      const symbol = createSymbol(131072 /* Signature */, getDeclarationName(node));
-      addDeclarationToSymbol(symbol, node, 131072 /* Signature */);
-      const typeLiteralSymbol = createSymbol(2048 /* TypeLiteral */, "__type" /* Type */);
-      addDeclarationToSymbol(typeLiteralSymbol, node, 2048 /* TypeLiteral */);
-      typeLiteralSymbol.members = createSymbolTable();
-      typeLiteralSymbol.members.set(symbol.escapedName, symbol);
-    }
-    function bindObjectLiteralExpression(node) {
-      return bindAnonymousDeclaration(node, 4096 /* ObjectLiteral */, "__object" /* Object */);
-    }
-    function bindJsxAttributes(node) {
-      return bindAnonymousDeclaration(node, 4096 /* ObjectLiteral */, "__jsxAttributes" /* JSXAttributes */);
-    }
-    function bindJsxAttribute(node, symbolFlags, symbolExcludes) {
-      return declareSymbolAndAddToSymbolTable(node, symbolFlags, symbolExcludes);
-    }
-    function bindAnonymousDeclaration(node, symbolFlags, name) {
-      const symbol = createSymbol(symbolFlags, name);
-      if (symbolFlags & (8 /* EnumMember */ | 106500 /* ClassMember */)) {
-        symbol.parent = container.symbol;
-      }
-      addDeclarationToSymbol(symbol, node, symbolFlags);
-      return symbol;
-    }
-    function bindBlockScopedDeclaration(node, symbolFlags, symbolExcludes) {
-      switch (blockScopeContainer.kind) {
-        case 266 /* ModuleDeclaration */:
-          declareModuleMember(node, symbolFlags, symbolExcludes);
-          break;
-        case 311 /* SourceFile */:
-          if (isExternalOrCommonJsModule(container)) {
-            declareModuleMember(node, symbolFlags, symbolExcludes);
-            break;
-          }
-        default:
-          Debug.assertNode(blockScopeContainer, canHaveLocals);
-          if (!blockScopeContainer.locals) {
-            blockScopeContainer.locals = createSymbolTable();
-            addToContainerChain(blockScopeContainer);
-          }
-          declareSymbol(
-            blockScopeContainer.locals,
-            /*parent*/
-            void 0,
-            node,
-            symbolFlags,
-            symbolExcludes
-          );
-      }
-    }
-    function delayedBindJSDocTypedefTag() {
-      if (!delayedTypeAliases) {
-        return;
-      }
-      const saveContainer = container;
-      const saveLastContainer = lastContainer;
-      const saveBlockScopeContainer = blockScopeContainer;
-      const saveParent = parent2;
-      const saveCurrentFlow = currentFlow;
-      for (const typeAlias of delayedTypeAliases) {
-        const host = typeAlias.parent.parent;
-        container = findAncestor(host.parent, (n) => !!(getContainerFlags(n) & 1 /* IsContainer */)) || file;
-        blockScopeContainer = getEnclosingBlockScopeContainer(host) || file;
-        currentFlow = initFlowNode({ flags: 2 /* Start */ });
-        parent2 = typeAlias;
-        bind(typeAlias.typeExpression);
-        const declName = getNameOfDeclaration(typeAlias);
-        if ((isJSDocEnumTag(typeAlias) || !typeAlias.fullName) && declName && isPropertyAccessEntityNameExpression(declName.parent)) {
-          const isTopLevel = isTopLevelNamespaceAssignment(declName.parent);
-          if (isTopLevel) {
-            bindPotentiallyMissingNamespaces(
-              file.symbol,
-              declName.parent,
-              isTopLevel,
-              !!findAncestor(declName, (d) => isPropertyAccessExpression(d) && d.name.escapedText === "prototype"),
-              /*containerIsClass*/
-              false
-            );
-            const oldContainer = container;
-            switch (getAssignmentDeclarationPropertyAccessKind(declName.parent)) {
-              case 1 /* ExportsProperty */:
-              case 2 /* ModuleExports */:
-                if (!isExternalOrCommonJsModule(file)) {
-                  container = void 0;
-                } else {
-                  container = file;
-                }
-                break;
-              case 4 /* ThisProperty */:
-                container = declName.parent.expression;
-                break;
-              case 3 /* PrototypeProperty */:
-                container = declName.parent.expression.name;
-                break;
-              case 5 /* Property */:
-                container = isExportsOrModuleExportsOrAlias(file, declName.parent.expression) ? file : isPropertyAccessExpression(declName.parent.expression) ? declName.parent.expression.name : declName.parent.expression;
-                break;
-              case 0 /* None */:
-                return Debug.fail("Shouldn't have detected typedef or enum on non-assignment declaration");
-            }
-            if (container) {
-              declareModuleMember(typeAlias, 524288 /* TypeAlias */, 788968 /* TypeAliasExcludes */);
-            }
-            container = oldContainer;
-          }
-        } else if (isJSDocEnumTag(typeAlias) || !typeAlias.fullName || typeAlias.fullName.kind === 80 /* Identifier */) {
-          parent2 = typeAlias.parent;
-          bindBlockScopedDeclaration(typeAlias, 524288 /* TypeAlias */, 788968 /* TypeAliasExcludes */);
-        } else {
-          bind(typeAlias.fullName);
-        }
-      }
-      container = saveContainer;
-      lastContainer = saveLastContainer;
-      blockScopeContainer = saveBlockScopeContainer;
-      parent2 = saveParent;
-      currentFlow = saveCurrentFlow;
-    }
-    function checkContextualIdentifier(node) {
-      if (!file.parseDiagnostics.length && !(node.flags & 16777216 /* Ambient */) && !(node.flags & 8388608 /* JSDoc */) && !isIdentifierName(node)) {
-        const originalKeywordKind = identifierToKeywordKind(node);
-        if (originalKeywordKind === void 0) {
-          return;
-        }
-        if (inStrictMode && originalKeywordKind >= 119 /* FirstFutureReservedWord */ && originalKeywordKind <= 127 /* LastFutureReservedWord */) {
-          file.bindDiagnostics.push(createDiagnosticForNode2(
-            node,
-            getStrictModeIdentifierMessage(node),
-            declarationNameToString(node)
-          ));
-        } else if (originalKeywordKind === 135 /* AwaitKeyword */) {
-          if (isExternalModule(file) && isInTopLevelContext(node)) {
-            file.bindDiagnostics.push(createDiagnosticForNode2(
-              node,
-              Diagnostics.Identifier_expected_0_is_a_reserved_word_at_the_top_level_of_a_module,
-              declarationNameToString(node)
-            ));
-          } else if (node.flags & 32768 /* AwaitContext */) {
-            file.bindDiagnostics.push(createDiagnosticForNode2(
-              node,
-              Diagnostics.Identifier_expected_0_is_a_reserved_word_that_cannot_be_used_here,
-              declarationNameToString(node)
-            ));
-          }
-        } else if (originalKeywordKind === 127 /* YieldKeyword */ && node.flags & 8192 /* YieldContext */) {
-          file.bindDiagnostics.push(createDiagnosticForNode2(
-            node,
-            Diagnostics.Identifier_expected_0_is_a_reserved_word_that_cannot_be_used_here,
-            declarationNameToString(node)
-          ));
-        }
-      }
-    }
-    function getStrictModeIdentifierMessage(node) {
-      if (getContainingClass(node)) {
-        return Diagnostics.Identifier_expected_0_is_a_reserved_word_in_strict_mode_Class_definitions_are_automatically_in_strict_mode;
-      }
-      if (file.externalModuleIndicator) {
-        return Diagnostics.Identifier_expected_0_is_a_reserved_word_in_strict_mode_Modules_are_automatically_in_strict_mode;
-      }
-      return Diagnostics.Identifier_expected_0_is_a_reserved_word_in_strict_mode;
-    }
-    function checkPrivateIdentifier(node) {
-      if (node.escapedText === "#constructor") {
-        if (!file.parseDiagnostics.length) {
-          file.bindDiagnostics.push(createDiagnosticForNode2(
-            node,
-            Diagnostics.constructor_is_a_reserved_word,
-            declarationNameToString(node)
-          ));
-        }
-      }
-    }
-    function checkStrictModeBinaryExpression(node) {
-      if (inStrictMode && isLeftHandSideExpression(node.left) && isAssignmentOperator(node.operatorToken.kind)) {
-        checkStrictModeEvalOrArguments(node, node.left);
-      }
-    }
-    function checkStrictModeCatchClause(node) {
-      if (inStrictMode && node.variableDeclaration) {
-        checkStrictModeEvalOrArguments(node, node.variableDeclaration.name);
-      }
-    }
-    function checkStrictModeDeleteExpression(node) {
-      if (inStrictMode && node.expression.kind === 80 /* Identifier */) {
-        const span = getErrorSpanForNode(file, node.expression);
-        file.bindDiagnostics.push(createFileDiagnostic(file, span.start, span.length, Diagnostics.delete_cannot_be_called_on_an_identifier_in_strict_mode));
-      }
-    }
-    function isEvalOrArgumentsIdentifier(node) {
-      return isIdentifier(node) && (node.escapedText === "eval" || node.escapedText === "arguments");
-    }
-    function checkStrictModeEvalOrArguments(contextNode, name) {
-      if (name && name.kind === 80 /* Identifier */) {
-        const identifier = name;
-        if (isEvalOrArgumentsIdentifier(identifier)) {
-          const span = getErrorSpanForNode(file, name);
-          file.bindDiagnostics.push(createFileDiagnostic(
-            file,
-            span.start,
-            span.length,
-            getStrictModeEvalOrArgumentsMessage(contextNode),
-            idText(identifier)
-          ));
-        }
-      }
-    }
-    function getStrictModeEvalOrArgumentsMessage(node) {
-      if (getContainingClass(node)) {
-        return Diagnostics.Code_contained_in_a_class_is_evaluated_in_JavaScript_s_strict_mode_which_does_not_allow_this_use_of_0_For_more_information_see_https_Colon_Slash_Slashdeveloper_mozilla_org_Slashen_US_Slashdocs_SlashWeb_SlashJavaScript_SlashReference_SlashStrict_mode;
-      }
-      if (file.externalModuleIndicator) {
-        return Diagnostics.Invalid_use_of_0_Modules_are_automatically_in_strict_mode;
-      }
-      return Diagnostics.Invalid_use_of_0_in_strict_mode;
-    }
-    function checkStrictModeFunctionName(node) {
-      if (inStrictMode) {
-        checkStrictModeEvalOrArguments(node, node.name);
-      }
-    }
-    function getStrictModeBlockScopeFunctionDeclarationMessage(node) {
-      if (getContainingClass(node)) {
-        return Diagnostics.Function_declarations_are_not_allowed_inside_blocks_in_strict_mode_when_targeting_ES3_or_ES5_Class_definitions_are_automatically_in_strict_mode;
-      }
-      if (file.externalModuleIndicator) {
-        return Diagnostics.Function_declarations_are_not_allowed_inside_blocks_in_strict_mode_when_targeting_ES3_or_ES5_Modules_are_automatically_in_strict_mode;
-      }
-      return Diagnostics.Function_declarations_are_not_allowed_inside_blocks_in_strict_mode_when_targeting_ES3_or_ES5;
-    }
-    function checkStrictModeFunctionDeclaration(node) {
-      if (languageVersion < 2 /* ES2015 */) {
-        if (blockScopeContainer.kind !== 311 /* SourceFile */ && blockScopeContainer.kind !== 266 /* ModuleDeclaration */ && !isFunctionLikeOrClassStaticBlockDeclaration(blockScopeContainer)) {
-          const errorSpan = getErrorSpanForNode(file, node);
-          file.bindDiagnostics.push(createFileDiagnostic(
-            file,
-            errorSpan.start,
-            errorSpan.length,
-            getStrictModeBlockScopeFunctionDeclarationMessage(node)
-          ));
-        }
-      }
-    }
-    function checkStrictModePostfixUnaryExpression(node) {
-      if (inStrictMode) {
-        checkStrictModeEvalOrArguments(node, node.operand);
-      }
-    }
-    function checkStrictModePrefixUnaryExpression(node) {
-      if (inStrictMode) {
-        if (node.operator === 46 /* PlusPlusToken */ || node.operator === 47 /* MinusMinusToken */) {
-          checkStrictModeEvalOrArguments(node, node.operand);
-        }
-      }
-    }
-    function checkStrictModeWithStatement(node) {
-      if (inStrictMode) {
-        errorOnFirstToken(node, Diagnostics.with_statements_are_not_allowed_in_strict_mode);
-      }
-    }
-    function checkStrictModeLabeledStatement(node) {
-      if (inStrictMode && getEmitScriptTarget(options) >= 2 /* ES2015 */) {
-        if (isDeclarationStatement(node.statement) || isVariableStatement(node.statement)) {
-          errorOnFirstToken(node.label, Diagnostics.A_label_is_not_allowed_here);
-        }
-      }
-    }
-    function errorOnFirstToken(node, message, ...args) {
-      const span = getSpanOfTokenAtPosition(file, node.pos);
-      file.bindDiagnostics.push(createFileDiagnostic(file, span.start, span.length, message, ...args));
-    }
-    function errorOrSuggestionOnNode(isError, node, message) {
-      errorOrSuggestionOnRange(isError, node, node, message);
-    }
-    function errorOrSuggestionOnRange(isError, startNode2, endNode2, message) {
-      addErrorOrSuggestionDiagnostic(isError, { pos: getTokenPosOfNode(startNode2, file), end: endNode2.end }, message);
-    }
-    function addErrorOrSuggestionDiagnostic(isError, range, message) {
-      const diag2 = createFileDiagnostic(file, range.pos, range.end - range.pos, message);
-      if (isError) {
-        file.bindDiagnostics.push(diag2);
-      } else {
-        file.bindSuggestionDiagnostics = append(file.bindSuggestionDiagnostics, { ...diag2, category: 2 /* Suggestion */ });
-      }
-    }
-    function bind(node) {
-      if (!node) {
-        return;
-      }
-      setParent(node, parent2);
-      if (tracing)
-        node.tracingPath = file.path;
-      const saveInStrictMode = inStrictMode;
-      bindWorker(node);
-      if (node.kind > 164 /* LastToken */) {
-        const saveParent = parent2;
-        parent2 = node;
-        const containerFlags = getContainerFlags(node);
-        if (containerFlags === 0 /* None */) {
-          bindChildren(node);
-        } else {
-          bindContainer(node, containerFlags);
-        }
-        parent2 = saveParent;
-      } else {
-        const saveParent = parent2;
-        if (node.kind === 1 /* EndOfFileToken */)
-          parent2 = node;
-        bindJSDoc(node);
-        parent2 = saveParent;
-      }
-      inStrictMode = saveInStrictMode;
-    }
-    function bindJSDoc(node) {
-      if (hasJSDocNodes(node)) {
-        if (isInJSFile(node)) {
-          for (const j of node.jsDoc) {
-            bind(j);
-          }
-        } else {
-          for (const j of node.jsDoc) {
-            setParent(j, node);
-            setParentRecursive(
-              j,
-              /*incremental*/
-              false
-            );
-          }
-        }
-      }
-    }
-    function updateStrictModeStatementList(statements) {
-      if (!inStrictMode) {
-        for (const statement of statements) {
-          if (!isPrologueDirective(statement)) {
-            return;
-          }
-          if (isUseStrictPrologueDirective(statement)) {
-            inStrictMode = true;
-            return;
-          }
-        }
-      }
-    }
-    function isUseStrictPrologueDirective(node) {
-      const nodeText2 = getSourceTextOfNodeFromSourceFile(file, node.expression);
-      return nodeText2 === '"use strict"' || nodeText2 === "'use strict'";
-    }
-    function bindWorker(node) {
-      switch (node.kind) {
-        case 80 /* Identifier */:
-          if (node.flags & 2048 /* IdentifierIsInJSDocNamespace */) {
-            let parentNode = node.parent;
-            while (parentNode && !isJSDocTypeAlias(parentNode)) {
-              parentNode = parentNode.parent;
-            }
-            bindBlockScopedDeclaration(parentNode, 524288 /* TypeAlias */, 788968 /* TypeAliasExcludes */);
-            break;
-          }
-        case 110 /* ThisKeyword */:
-          if (currentFlow && (isExpression(node) || parent2.kind === 303 /* ShorthandPropertyAssignment */)) {
-            node.flowNode = currentFlow;
-          }
-          return checkContextualIdentifier(node);
-        case 165 /* QualifiedName */:
-          if (currentFlow && isPartOfTypeQuery(node)) {
-            node.flowNode = currentFlow;
-          }
-          break;
-        case 235 /* MetaProperty */:
-        case 108 /* SuperKeyword */:
-          node.flowNode = currentFlow;
-          break;
-        case 81 /* PrivateIdentifier */:
-          return checkPrivateIdentifier(node);
-        case 210 /* PropertyAccessExpression */:
-        case 211 /* ElementAccessExpression */:
-          const expr = node;
-          if (currentFlow && isNarrowableReference(expr)) {
-            expr.flowNode = currentFlow;
-          }
-          if (isSpecialPropertyDeclaration(expr)) {
-            bindSpecialPropertyDeclaration(expr);
-          }
-          if (isInJSFile(expr) && file.commonJsModuleIndicator && isModuleExportsAccessExpression(expr) && !lookupSymbolForName(blockScopeContainer, "module")) {
-            declareSymbol(
-              file.locals,
-              /*parent*/
-              void 0,
-              expr.expression,
-              1 /* FunctionScopedVariable */ | 134217728 /* ModuleExports */,
-              111550 /* FunctionScopedVariableExcludes */
-            );
-          }
-          break;
-        case 225 /* BinaryExpression */:
-          const specialKind = getAssignmentDeclarationKind(node);
-          switch (specialKind) {
-            case 1 /* ExportsProperty */:
-              bindExportsPropertyAssignment(node);
-              break;
-            case 2 /* ModuleExports */:
-              bindModuleExportsAssignment(node);
-              break;
-            case 3 /* PrototypeProperty */:
-              bindPrototypePropertyAssignment(node.left, node);
-              break;
-            case 6 /* Prototype */:
-              bindPrototypeAssignment(node);
-              break;
-            case 4 /* ThisProperty */:
-              bindThisPropertyAssignment(node);
-              break;
-            case 5 /* Property */:
-              const expression = node.left.expression;
-              if (isInJSFile(node) && isIdentifier(expression)) {
-                const symbol = lookupSymbolForName(blockScopeContainer, expression.escapedText);
-                if (isThisInitializedDeclaration(symbol == null ? void 0 : symbol.valueDeclaration)) {
-                  bindThisPropertyAssignment(node);
-                  break;
-                }
-              }
-              bindSpecialPropertyAssignment(node);
-              break;
-            case 0 /* None */:
-              break;
-            default:
-              Debug.fail("Unknown binary expression special property assignment kind");
-          }
-          return checkStrictModeBinaryExpression(node);
-        case 298 /* CatchClause */:
-          return checkStrictModeCatchClause(node);
-        case 219 /* DeleteExpression */:
-          return checkStrictModeDeleteExpression(node);
-        case 224 /* PostfixUnaryExpression */:
-          return checkStrictModePostfixUnaryExpression(node);
-        case 223 /* PrefixUnaryExpression */:
-          return checkStrictModePrefixUnaryExpression(node);
-        case 253 /* WithStatement */:
-          return checkStrictModeWithStatement(node);
-        case 255 /* LabeledStatement */:
-          return checkStrictModeLabeledStatement(node);
-        case 196 /* ThisType */:
-          seenThisKeyword = true;
-          return;
-        case 181 /* TypePredicate */:
-          break;
-        case 167 /* TypeParameter */:
-          return bindTypeParameter(node);
-        case 168 /* Parameter */:
-          return bindParameter(node);
-        case 259 /* VariableDeclaration */:
-          return bindVariableDeclarationOrBindingElement(node);
-        case 207 /* BindingElement */:
-          node.flowNode = currentFlow;
-          return bindVariableDeclarationOrBindingElement(node);
-        case 171 /* PropertyDeclaration */:
-        case 170 /* PropertySignature */:
-          return bindPropertyWorker(node);
-        case 302 /* PropertyAssignment */:
-        case 303 /* ShorthandPropertyAssignment */:
-          return bindPropertyOrMethodOrAccessor(node, 4 /* Property */, 0 /* PropertyExcludes */);
-        case 305 /* EnumMember */:
-          return bindPropertyOrMethodOrAccessor(node, 8 /* EnumMember */, 900095 /* EnumMemberExcludes */);
-        case 178 /* CallSignature */:
-        case 179 /* ConstructSignature */:
-        case 180 /* IndexSignature */:
-          return declareSymbolAndAddToSymbolTable(node, 131072 /* Signature */, 0 /* None */);
-        case 173 /* MethodDeclaration */:
-        case 172 /* MethodSignature */:
-          return bindPropertyOrMethodOrAccessor(
-            node,
-            8192 /* Method */ | (node.questionToken ? 16777216 /* Optional */ : 0 /* None */),
-            isObjectLiteralMethod(node) ? 0 /* PropertyExcludes */ : 103359 /* MethodExcludes */
-          );
-        case 261 /* FunctionDeclaration */:
-          return bindFunctionDeclaration(node);
-        case 175 /* Constructor */:
-          return declareSymbolAndAddToSymbolTable(
-            node,
-            16384 /* Constructor */,
-            /*symbolExcludes:*/
-            0 /* None */
-          );
-        case 176 /* GetAccessor */:
-          return bindPropertyOrMethodOrAccessor(node, 32768 /* GetAccessor */, 46015 /* GetAccessorExcludes */);
-        case 177 /* SetAccessor */:
-          return bindPropertyOrMethodOrAccessor(node, 65536 /* SetAccessor */, 78783 /* SetAccessorExcludes */);
-        case 183 /* FunctionType */:
-        case 323 /* JSDocFunctionType */:
-        case 329 /* JSDocSignature */:
-        case 184 /* ConstructorType */:
-          return bindFunctionOrConstructorType(node);
-        case 186 /* TypeLiteral */:
-        case 328 /* JSDocTypeLiteral */:
-        case 199 /* MappedType */:
-          return bindAnonymousTypeWorker(node);
-        case 338 /* JSDocClassTag */:
-          return bindJSDocClassTag(node);
-        case 209 /* ObjectLiteralExpression */:
-          return bindObjectLiteralExpression(node);
-        case 217 /* FunctionExpression */:
-        case 218 /* ArrowFunction */:
-          return bindFunctionExpression(node);
-        case 212 /* CallExpression */:
-          const assignmentKind = getAssignmentDeclarationKind(node);
-          switch (assignmentKind) {
-            case 7 /* ObjectDefinePropertyValue */:
-              return bindObjectDefinePropertyAssignment(node);
-            case 8 /* ObjectDefinePropertyExports */:
-              return bindObjectDefinePropertyExport(node);
-            case 9 /* ObjectDefinePrototypeProperty */:
-              return bindObjectDefinePrototypeProperty(node);
-            case 0 /* None */:
-              break;
-            default:
-              return Debug.fail("Unknown call expression assignment declaration kind");
-          }
-          if (isInJSFile(node)) {
-            bindCallExpression(node);
-          }
-          break;
-        case 230 /* ClassExpression */:
-        case 262 /* ClassDeclaration */:
-          inStrictMode = true;
-          return bindClassLikeDeclaration(node);
-        case 263 /* InterfaceDeclaration */:
-          return bindBlockScopedDeclaration(node, 64 /* Interface */, 788872 /* InterfaceExcludes */);
-        case 264 /* TypeAliasDeclaration */:
-          return bindBlockScopedDeclaration(node, 524288 /* TypeAlias */, 788968 /* TypeAliasExcludes */);
-        case 265 /* EnumDeclaration */:
-          return bindEnumDeclaration(node);
-        case 266 /* ModuleDeclaration */:
-          return bindModuleDeclaration(node);
-        case 291 /* JsxAttributes */:
-          return bindJsxAttributes(node);
-        case 290 /* JsxAttribute */:
-          return bindJsxAttribute(node, 4 /* Property */, 0 /* PropertyExcludes */);
-        case 270 /* ImportEqualsDeclaration */:
-        case 273 /* NamespaceImport */:
-        case 275 /* ImportSpecifier */:
-        case 280 /* ExportSpecifier */:
-          return declareSymbolAndAddToSymbolTable(node, 2097152 /* Alias */, 2097152 /* AliasExcludes */);
-        case 269 /* NamespaceExportDeclaration */:
-          return bindNamespaceExportDeclaration(node);
-        case 272 /* ImportClause */:
-          return bindImportClause(node);
-        case 277 /* ExportDeclaration */:
-          return bindExportDeclaration(node);
-        case 276 /* ExportAssignment */:
-          return bindExportAssignment(node);
-        case 311 /* SourceFile */:
-          updateStrictModeStatementList(node.statements);
-          return bindSourceFileIfExternalModule();
-        case 240 /* Block */:
-          if (!isFunctionLikeOrClassStaticBlockDeclaration(node.parent)) {
-            return;
-          }
-        case 267 /* ModuleBlock */:
-          return updateStrictModeStatementList(node.statements);
-        case 347 /* JSDocParameterTag */:
-          if (node.parent.kind === 329 /* JSDocSignature */) {
-            return bindParameter(node);
-          }
-          if (node.parent.kind !== 328 /* JSDocTypeLiteral */) {
-            break;
-          }
-        case 354 /* JSDocPropertyTag */:
-          const propTag = node;
-          const flags = propTag.isBracketed || propTag.typeExpression && propTag.typeExpression.type.kind === 322 /* JSDocOptionalType */ ? 4 /* Property */ | 16777216 /* Optional */ : 4 /* Property */;
-          return declareSymbolAndAddToSymbolTable(propTag, flags, 0 /* PropertyExcludes */);
-        case 352 /* JSDocTypedefTag */:
-        case 344 /* JSDocCallbackTag */:
-        case 346 /* JSDocEnumTag */:
-          return (delayedTypeAliases || (delayedTypeAliases = [])).push(node);
-        case 345 /* JSDocOverloadTag */:
-          return bind(node.typeExpression);
-      }
-    }
-    function bindPropertyWorker(node) {
-      const isAutoAccessor = isAutoAccessorPropertyDeclaration(node);
-      const includes = isAutoAccessor ? 98304 /* Accessor */ : 4 /* Property */;
-      const excludes = isAutoAccessor ? 13247 /* AccessorExcludes */ : 0 /* PropertyExcludes */;
-      return bindPropertyOrMethodOrAccessor(node, includes | (node.questionToken ? 16777216 /* Optional */ : 0 /* None */), excludes);
-    }
-    function bindAnonymousTypeWorker(node) {
-      return bindAnonymousDeclaration(node, 2048 /* TypeLiteral */, "__type" /* Type */);
-    }
-    function bindSourceFileIfExternalModule() {
-      setExportContextFlag(file);
-      if (isExternalModule(file)) {
-        bindSourceFileAsExternalModule();
-      } else if (isJsonSourceFile(file)) {
-        bindSourceFileAsExternalModule();
-        const originalSymbol = file.symbol;
-        declareSymbol(file.symbol.exports, file.symbol, file, 4 /* Property */, 67108863 /* All */);
-        file.symbol = originalSymbol;
-      }
-    }
-    function bindSourceFileAsExternalModule() {
-      bindAnonymousDeclaration(file, 512 /* ValueModule */, `"${removeFileExtension(file.fileName)}"`);
-    }
-    function bindExportAssignment(node) {
-      if (!container.symbol || !container.symbol.exports) {
-        bindAnonymousDeclaration(node, 111551 /* Value */, getDeclarationName(node));
-      } else {
-        const flags = exportAssignmentIsAlias(node) ? 2097152 /* Alias */ : 4 /* Property */;
-        const symbol = declareSymbol(container.symbol.exports, container.symbol, node, flags, 67108863 /* All */);
-        if (node.isExportEquals) {
-          setValueDeclaration(symbol, node);
-        }
-      }
-    }
-    function bindNamespaceExportDeclaration(node) {
-      if (some(node.modifiers)) {
-        file.bindDiagnostics.push(createDiagnosticForNode2(node, Diagnostics.Modifiers_cannot_appear_here));
-      }
-      const diag2 = !isSourceFile(node.parent) ? Diagnostics.Global_module_exports_may_only_appear_at_top_level : !isExternalModule(node.parent) ? Diagnostics.Global_module_exports_may_only_appear_in_module_files : !node.parent.isDeclarationFile ? Diagnostics.Global_module_exports_may_only_appear_in_declaration_files : void 0;
-      if (diag2) {
-        file.bindDiagnostics.push(createDiagnosticForNode2(node, diag2));
-      } else {
-        file.symbol.globalExports = file.symbol.globalExports || createSymbolTable();
-        declareSymbol(file.symbol.globalExports, file.symbol, node, 2097152 /* Alias */, 2097152 /* AliasExcludes */);
-      }
-    }
-    function bindExportDeclaration(node) {
-      if (!container.symbol || !container.symbol.exports) {
-        bindAnonymousDeclaration(node, 8388608 /* ExportStar */, getDeclarationName(node));
-      } else if (!node.exportClause) {
-        declareSymbol(container.symbol.exports, container.symbol, node, 8388608 /* ExportStar */, 0 /* None */);
-      } else if (isNamespaceExport(node.exportClause)) {
-        setParent(node.exportClause, node);
-        declareSymbol(container.symbol.exports, container.symbol, node.exportClause, 2097152 /* Alias */, 2097152 /* AliasExcludes */);
-      }
-    }
-    function bindImportClause(node) {
-      if (node.name) {
-        declareSymbolAndAddToSymbolTable(node, 2097152 /* Alias */, 2097152 /* AliasExcludes */);
-      }
-    }
-    function setCommonJsModuleIndicator(node) {
-      if (file.externalModuleIndicator && file.externalModuleIndicator !== true) {
-        return false;
-      }
-      if (!file.commonJsModuleIndicator) {
-        file.commonJsModuleIndicator = node;
-        if (!file.externalModuleIndicator) {
-          bindSourceFileAsExternalModule();
-        }
-      }
-      return true;
-    }
-    function bindObjectDefinePropertyExport(node) {
-      if (!setCommonJsModuleIndicator(node)) {
-        return;
-      }
-      const symbol = forEachIdentifierInEntityName(
-        node.arguments[0],
-        /*parent*/
-        void 0,
-        (id, symbol2) => {
-          if (symbol2) {
-            addDeclarationToSymbol(symbol2, id, 1536 /* Module */ | 67108864 /* Assignment */);
-          }
-          return symbol2;
-        }
-      );
-      if (symbol) {
-        const flags = 4 /* Property */ | 1048576 /* ExportValue */;
-        declareSymbol(symbol.exports, symbol, node, flags, 0 /* None */);
-      }
-    }
-    function bindExportsPropertyAssignment(node) {
-      if (!setCommonJsModuleIndicator(node)) {
-        return;
-      }
-      const symbol = forEachIdentifierInEntityName(
-        node.left.expression,
-        /*parent*/
-        void 0,
-        (id, symbol2) => {
-          if (symbol2) {
-            addDeclarationToSymbol(symbol2, id, 1536 /* Module */ | 67108864 /* Assignment */);
-          }
-          return symbol2;
-        }
-      );
-      if (symbol) {
-        const isAlias = isAliasableExpression(node.right) && (isExportsIdentifier(node.left.expression) || isModuleExportsAccessExpression(node.left.expression));
-        const flags = isAlias ? 2097152 /* Alias */ : 4 /* Property */ | 1048576 /* ExportValue */;
-        setParent(node.left, node);
-        declareSymbol(symbol.exports, symbol, node.left, flags, 0 /* None */);
-      }
-    }
-    function bindModuleExportsAssignment(node) {
-      if (!setCommonJsModuleIndicator(node)) {
-        return;
-      }
-      const assignedExpression = getRightMostAssignedExpression(node.right);
-      if (isEmptyObjectLiteral(assignedExpression) || container === file && isExportsOrModuleExportsOrAlias(file, assignedExpression)) {
-        return;
-      }
-      if (isObjectLiteralExpression(assignedExpression) && every(assignedExpression.properties, isShorthandPropertyAssignment)) {
-        forEach(assignedExpression.properties, bindExportAssignedObjectMemberAlias);
-        return;
-      }
-      const flags = exportAssignmentIsAlias(node) ? 2097152 /* Alias */ : 4 /* Property */ | 1048576 /* ExportValue */ | 512 /* ValueModule */;
-      const symbol = declareSymbol(file.symbol.exports, file.symbol, node, flags | 67108864 /* Assignment */, 0 /* None */);
-      setValueDeclaration(symbol, node);
-    }
-    function bindExportAssignedObjectMemberAlias(node) {
-      declareSymbol(file.symbol.exports, file.symbol, node, 2097152 /* Alias */ | 67108864 /* Assignment */, 0 /* None */);
-    }
-    function bindThisPropertyAssignment(node) {
-      Debug.assert(isInJSFile(node));
-      const hasPrivateIdentifier = isBinaryExpression(node) && isPropertyAccessExpression(node.left) && isPrivateIdentifier(node.left.name) || isPropertyAccessExpression(node) && isPrivateIdentifier(node.name);
-      if (hasPrivateIdentifier) {
-        return;
-      }
-      const thisContainer = getThisContainer(
-        node,
-        /*includeArrowFunctions*/
-        false,
-        /*includeClassComputedPropertyName*/
-        false
-      );
-      switch (thisContainer.kind) {
-        case 261 /* FunctionDeclaration */:
-        case 217 /* FunctionExpression */:
-          let constructorSymbol = thisContainer.symbol;
-          if (isBinaryExpression(thisContainer.parent) && thisContainer.parent.operatorToken.kind === 64 /* EqualsToken */) {
-            const l = thisContainer.parent.left;
-            if (isBindableStaticAccessExpression(l) && isPrototypeAccess(l.expression)) {
-              constructorSymbol = lookupSymbolForPropertyAccess(l.expression.expression, thisParentContainer);
-            }
-          }
-          if (constructorSymbol && constructorSymbol.valueDeclaration) {
-            constructorSymbol.members = constructorSymbol.members || createSymbolTable();
-            if (hasDynamicName(node)) {
-              bindDynamicallyNamedThisPropertyAssignment(node, constructorSymbol, constructorSymbol.members);
-            } else {
-              declareSymbol(constructorSymbol.members, constructorSymbol, node, 4 /* Property */ | 67108864 /* Assignment */, 0 /* PropertyExcludes */ & ~4 /* Property */);
-            }
-            addDeclarationToSymbol(constructorSymbol, constructorSymbol.valueDeclaration, 32 /* Class */);
-          }
-          break;
-        case 175 /* Constructor */:
-        case 171 /* PropertyDeclaration */:
-        case 173 /* MethodDeclaration */:
-        case 176 /* GetAccessor */:
-        case 177 /* SetAccessor */:
-        case 174 /* ClassStaticBlockDeclaration */:
-          const containingClass = thisContainer.parent;
-          const symbolTable = isStatic(thisContainer) ? containingClass.symbol.exports : containingClass.symbol.members;
-          if (hasDynamicName(node)) {
-            bindDynamicallyNamedThisPropertyAssignment(node, containingClass.symbol, symbolTable);
-          } else {
-            declareSymbol(
-              symbolTable,
-              containingClass.symbol,
-              node,
-              4 /* Property */ | 67108864 /* Assignment */,
-              0 /* None */,
-              /*isReplaceableByMethod*/
-              true
-            );
-          }
-          break;
-        case 311 /* SourceFile */:
-          if (hasDynamicName(node)) {
-            break;
-          } else if (thisContainer.commonJsModuleIndicator) {
-            declareSymbol(thisContainer.symbol.exports, thisContainer.symbol, node, 4 /* Property */ | 1048576 /* ExportValue */, 0 /* None */);
-          } else {
-            declareSymbolAndAddToSymbolTable(node, 1 /* FunctionScopedVariable */, 111550 /* FunctionScopedVariableExcludes */);
-          }
-          break;
-        case 266 /* ModuleDeclaration */:
-          break;
-        default:
-          Debug.failBadSyntaxKind(thisContainer);
-      }
-    }
-    function bindDynamicallyNamedThisPropertyAssignment(node, symbol, symbolTable) {
-      declareSymbol(
-        symbolTable,
-        symbol,
-        node,
-        4 /* Property */,
-        0 /* None */,
-        /*isReplaceableByMethod*/
-        true,
-        /*isComputedName*/
-        true
-      );
-      addLateBoundAssignmentDeclarationToSymbol(node, symbol);
-    }
-    function addLateBoundAssignmentDeclarationToSymbol(node, symbol) {
-      if (symbol) {
-        (symbol.assignmentDeclarationMembers || (symbol.assignmentDeclarationMembers = /* @__PURE__ */ new Map())).set(getNodeId(node), node);
-      }
-    }
-    function bindSpecialPropertyDeclaration(node) {
-      if (node.expression.kind === 110 /* ThisKeyword */) {
-        bindThisPropertyAssignment(node);
-      } else if (isBindableStaticAccessExpression(node) && node.parent.parent.kind === 311 /* SourceFile */) {
-        if (isPrototypeAccess(node.expression)) {
-          bindPrototypePropertyAssignment(node, node.parent);
-        } else {
-          bindStaticPropertyAssignment(node);
-        }
-      }
-    }
-    function bindPrototypeAssignment(node) {
-      setParent(node.left, node);
-      setParent(node.right, node);
-      bindPropertyAssignment(
-        node.left.expression,
-        node.left,
-        /*isPrototypeProperty*/
-        false,
-        /*containerIsClass*/
-        true
-      );
-    }
-    function bindObjectDefinePrototypeProperty(node) {
-      const namespaceSymbol = lookupSymbolForPropertyAccess(node.arguments[0].expression);
-      if (namespaceSymbol && namespaceSymbol.valueDeclaration) {
-        addDeclarationToSymbol(namespaceSymbol, namespaceSymbol.valueDeclaration, 32 /* Class */);
-      }
-      bindPotentiallyNewExpandoMemberToNamespace(
-        node,
-        namespaceSymbol,
-        /*isPrototypeProperty*/
-        true
-      );
-    }
-    function bindPrototypePropertyAssignment(lhs, parent3) {
-      const classPrototype = lhs.expression;
-      const constructorFunction = classPrototype.expression;
-      setParent(constructorFunction, classPrototype);
-      setParent(classPrototype, lhs);
-      setParent(lhs, parent3);
-      bindPropertyAssignment(
-        constructorFunction,
-        lhs,
-        /*isPrototypeProperty*/
-        true,
-        /*containerIsClass*/
-        true
-      );
-    }
-    function bindObjectDefinePropertyAssignment(node) {
-      let namespaceSymbol = lookupSymbolForPropertyAccess(node.arguments[0]);
-      const isToplevel = node.parent.parent.kind === 311 /* SourceFile */;
-      namespaceSymbol = bindPotentiallyMissingNamespaces(
-        namespaceSymbol,
-        node.arguments[0],
-        isToplevel,
-        /*isPrototypeProperty*/
-        false,
-        /*containerIsClass*/
-        false
-      );
-      bindPotentiallyNewExpandoMemberToNamespace(
-        node,
-        namespaceSymbol,
-        /*isPrototypeProperty*/
-        false
-      );
-    }
-    function bindSpecialPropertyAssignment(node) {
-      var _a;
-      const parentSymbol = lookupSymbolForPropertyAccess(node.left.expression, container) || lookupSymbolForPropertyAccess(node.left.expression, blockScopeContainer);
-      if (!isInJSFile(node) && !isFunctionSymbol(parentSymbol)) {
-        return;
-      }
-      const rootExpr = getLeftmostAccessExpression(node.left);
-      if (isIdentifier(rootExpr) && ((_a = lookupSymbolForName(container, rootExpr.escapedText)) == null ? void 0 : _a.flags) & 2097152 /* Alias */) {
-        return;
-      }
-      setParent(node.left, node);
-      setParent(node.right, node);
-      if (isIdentifier(node.left.expression) && container === file && isExportsOrModuleExportsOrAlias(file, node.left.expression)) {
-        bindExportsPropertyAssignment(node);
-      } else if (hasDynamicName(node)) {
-        bindAnonymousDeclaration(node, 4 /* Property */ | 67108864 /* Assignment */, "__computed" /* Computed */);
-        const sym = bindPotentiallyMissingNamespaces(
-          parentSymbol,
-          node.left.expression,
-          isTopLevelNamespaceAssignment(node.left),
-          /*isPrototypeProperty*/
-          false,
-          /*containerIsClass*/
-          false
-        );
-        addLateBoundAssignmentDeclarationToSymbol(node, sym);
-      } else {
-        bindStaticPropertyAssignment(cast(node.left, isBindableStaticNameExpression));
-      }
-    }
-    function bindStaticPropertyAssignment(node) {
-      Debug.assert(!isIdentifier(node));
-      setParent(node.expression, node);
-      bindPropertyAssignment(
-        node.expression,
-        node,
-        /*isPrototypeProperty*/
-        false,
-        /*containerIsClass*/
-        false
-      );
-    }
-    function bindPotentiallyMissingNamespaces(namespaceSymbol, entityName, isToplevel, isPrototypeProperty, containerIsClass) {
-      if ((namespaceSymbol == null ? void 0 : namespaceSymbol.flags) & 2097152 /* Alias */) {
-        return namespaceSymbol;
-      }
-      if (isToplevel && !isPrototypeProperty) {
-        const flags = 1536 /* Module */ | 67108864 /* Assignment */;
-        const excludeFlags = 110735 /* ValueModuleExcludes */ & ~67108864 /* Assignment */;
-        namespaceSymbol = forEachIdentifierInEntityName(entityName, namespaceSymbol, (id, symbol, parent3) => {
-          if (symbol) {
-            addDeclarationToSymbol(symbol, id, flags);
-            return symbol;
-          } else {
-            const table = parent3 ? parent3.exports : file.jsGlobalAugmentations || (file.jsGlobalAugmentations = createSymbolTable());
-            return declareSymbol(table, parent3, id, flags, excludeFlags);
-          }
-        });
-      }
-      if (containerIsClass && namespaceSymbol && namespaceSymbol.valueDeclaration) {
-        addDeclarationToSymbol(namespaceSymbol, namespaceSymbol.valueDeclaration, 32 /* Class */);
-      }
-      return namespaceSymbol;
-    }
-    function bindPotentiallyNewExpandoMemberToNamespace(declaration, namespaceSymbol, isPrototypeProperty) {
-      if (!namespaceSymbol || !isExpandoSymbol(namespaceSymbol)) {
-        return;
-      }
-      const symbolTable = isPrototypeProperty ? namespaceSymbol.members || (namespaceSymbol.members = createSymbolTable()) : namespaceSymbol.exports || (namespaceSymbol.exports = createSymbolTable());
-      let includes = 0 /* None */;
-      let excludes = 0 /* None */;
-      if (isFunctionLikeDeclaration(getAssignedExpandoInitializer(declaration))) {
-        includes = 8192 /* Method */;
-        excludes = 103359 /* MethodExcludes */;
-      } else if (isCallExpression(declaration) && isBindableObjectDefinePropertyCall(declaration)) {
-        if (some(declaration.arguments[2].properties, (p) => {
-          const id = getNameOfDeclaration(p);
-          return !!id && isIdentifier(id) && idText(id) === "set";
-        })) {
-          includes |= 65536 /* SetAccessor */ | 4 /* Property */;
-          excludes |= 78783 /* SetAccessorExcludes */;
-        }
-        if (some(declaration.arguments[2].properties, (p) => {
-          const id = getNameOfDeclaration(p);
-          return !!id && isIdentifier(id) && idText(id) === "get";
-        })) {
-          includes |= 32768 /* GetAccessor */ | 4 /* Property */;
-          excludes |= 46015 /* GetAccessorExcludes */;
-        }
-      }
-      if (includes === 0 /* None */) {
-        includes = 4 /* Property */;
-        excludes = 0 /* PropertyExcludes */;
-      }
-      declareSymbol(symbolTable, namespaceSymbol, declaration, includes | 67108864 /* Assignment */, excludes & ~67108864 /* Assignment */);
-    }
-    function isTopLevelNamespaceAssignment(propertyAccess) {
-      return isBinaryExpression(propertyAccess.parent) ? getParentOfBinaryExpression(propertyAccess.parent).parent.kind === 311 /* SourceFile */ : propertyAccess.parent.parent.kind === 311 /* SourceFile */;
-    }
-    function bindPropertyAssignment(name, propertyAccess, isPrototypeProperty, containerIsClass) {
-      let namespaceSymbol = lookupSymbolForPropertyAccess(name, container) || lookupSymbolForPropertyAccess(name, blockScopeContainer);
-      const isToplevel = isTopLevelNamespaceAssignment(propertyAccess);
-      namespaceSymbol = bindPotentiallyMissingNamespaces(namespaceSymbol, propertyAccess.expression, isToplevel, isPrototypeProperty, containerIsClass);
-      bindPotentiallyNewExpandoMemberToNamespace(propertyAccess, namespaceSymbol, isPrototypeProperty);
-    }
-    function isExpandoSymbol(symbol) {
-      if (symbol.flags & (16 /* Function */ | 32 /* Class */ | 1024 /* NamespaceModule */)) {
-        return true;
-      }
-      const node = symbol.valueDeclaration;
-      if (node && isCallExpression(node)) {
-        return !!getAssignedExpandoInitializer(node);
-      }
-      let init = !node ? void 0 : isVariableDeclaration(node) ? node.initializer : isBinaryExpression(node) ? node.right : isPropertyAccessExpression(node) && isBinaryExpression(node.parent) ? node.parent.right : void 0;
-      init = init && getRightMostAssignedExpression(init);
-      if (init) {
-        const isPrototypeAssignment = isPrototypeAccess(isVariableDeclaration(node) ? node.name : isBinaryExpression(node) ? node.left : node);
-        return !!getExpandoInitializer(isBinaryExpression(init) && (init.operatorToken.kind === 57 /* BarBarToken */ || init.operatorToken.kind === 61 /* QuestionQuestionToken */) ? init.right : init, isPrototypeAssignment);
-      }
-      return false;
-    }
-    function getParentOfBinaryExpression(expr) {
-      while (isBinaryExpression(expr.parent)) {
-        expr = expr.parent;
-      }
-      return expr.parent;
-    }
-    function lookupSymbolForPropertyAccess(node, lookupContainer = container) {
-      if (isIdentifier(node)) {
-        return lookupSymbolForName(lookupContainer, node.escapedText);
-      } else {
-        const symbol = lookupSymbolForPropertyAccess(node.expression);
-        return symbol && symbol.exports && symbol.exports.get(getElementOrPropertyAccessName(node));
-      }
-    }
-    function forEachIdentifierInEntityName(e, parent3, action) {
-      if (isExportsOrModuleExportsOrAlias(file, e)) {
-        return file.symbol;
-      } else if (isIdentifier(e)) {
-        return action(e, lookupSymbolForPropertyAccess(e), parent3);
-      } else {
-        const s = forEachIdentifierInEntityName(e.expression, parent3, action);
-        const name = getNameOrArgument(e);
-        if (isPrivateIdentifier(name)) {
-          Debug.fail("unexpected PrivateIdentifier");
-        }
-        return action(name, s && s.exports && s.exports.get(getElementOrPropertyAccessName(e)), s);
-      }
-    }
-    function bindCallExpression(node) {
-      if (!file.commonJsModuleIndicator && isRequireCall(
-        node,
-        /*requireStringLiteralLikeArgument*/
-        false
-      )) {
-        setCommonJsModuleIndicator(node);
-      }
-    }
-    function bindClassLikeDeclaration(node) {
-      if (node.kind === 262 /* ClassDeclaration */) {
-        bindBlockScopedDeclaration(node, 32 /* Class */, 899503 /* ClassExcludes */);
-      } else {
-        const bindingName = node.name ? node.name.escapedText : "__class" /* Class */;
-        bindAnonymousDeclaration(node, 32 /* Class */, bindingName);
-        if (node.name) {
-          classifiableNames.add(node.name.escapedText);
-        }
-      }
-      const { symbol } = node;
-      const prototypeSymbol = createSymbol(4 /* Property */ | 4194304 /* Prototype */, "prototype");
-      const symbolExport = symbol.exports.get(prototypeSymbol.escapedName);
-      if (symbolExport) {
-        if (node.name) {
-          setParent(node.name, node);
-        }
-        file.bindDiagnostics.push(createDiagnosticForNode2(symbolExport.declarations[0], Diagnostics.Duplicate_identifier_0, symbolName(prototypeSymbol)));
-      }
-      symbol.exports.set(prototypeSymbol.escapedName, prototypeSymbol);
-      prototypeSymbol.parent = symbol;
-    }
-    function bindEnumDeclaration(node) {
-      return isEnumConst(node) ? bindBlockScopedDeclaration(node, 128 /* ConstEnum */, 899967 /* ConstEnumExcludes */) : bindBlockScopedDeclaration(node, 256 /* RegularEnum */, 899327 /* RegularEnumExcludes */);
-    }
-    function bindVariableDeclarationOrBindingElement(node) {
-      if (inStrictMode) {
-        checkStrictModeEvalOrArguments(node, node.name);
-      }
-      if (!isBindingPattern(node.name)) {
-        const possibleVariableDecl = node.kind === 259 /* VariableDeclaration */ ? node : node.parent.parent;
-        if (isInJSFile(node) && shouldResolveJsRequire(options) && isVariableDeclarationInitializedToBareOrAccessedRequire(possibleVariableDecl) && !getJSDocTypeTag(node) && !(getCombinedModifierFlags(node) & 1 /* Export */)) {
-          declareSymbolAndAddToSymbolTable(node, 2097152 /* Alias */, 2097152 /* AliasExcludes */);
-        } else if (isBlockOrCatchScoped(node)) {
-          bindBlockScopedDeclaration(node, 2 /* BlockScopedVariable */, 111551 /* BlockScopedVariableExcludes */);
-        } else if (isParameterDeclaration(node)) {
-          declareSymbolAndAddToSymbolTable(node, 1 /* FunctionScopedVariable */, 111551 /* ParameterExcludes */);
-        } else {
-          declareSymbolAndAddToSymbolTable(node, 1 /* FunctionScopedVariable */, 111550 /* FunctionScopedVariableExcludes */);
-        }
-      }
-    }
-    function bindParameter(node) {
-      if (node.kind === 347 /* JSDocParameterTag */ && container.kind !== 329 /* JSDocSignature */) {
-        return;
-      }
-      if (inStrictMode && !(node.flags & 16777216 /* Ambient */)) {
-        checkStrictModeEvalOrArguments(node, node.name);
-      }
-      if (isBindingPattern(node.name)) {
-        bindAnonymousDeclaration(node, 1 /* FunctionScopedVariable */, "__" + node.parent.parameters.indexOf(node));
-      } else {
-        declareSymbolAndAddToSymbolTable(node, 1 /* FunctionScopedVariable */, 111551 /* ParameterExcludes */);
-      }
-      if (isParameterPropertyDeclaration(node, node.parent)) {
-        const classDeclaration = node.parent.parent;
-        declareSymbol(classDeclaration.symbol.members, classDeclaration.symbol, node, 4 /* Property */ | (node.questionToken ? 16777216 /* Optional */ : 0 /* None */), 0 /* PropertyExcludes */);
-      }
-    }
-    function bindFunctionDeclaration(node) {
-      if (!file.isDeclarationFile && !(node.flags & 16777216 /* Ambient */)) {
-        if (isAsyncFunction(node)) {
-          emitFlags |= 2048 /* HasAsyncFunctions */;
-        }
-      }
-      checkStrictModeFunctionName(node);
-      if (inStrictMode) {
-        checkStrictModeFunctionDeclaration(node);
-        bindBlockScopedDeclaration(node, 16 /* Function */, 110991 /* FunctionExcludes */);
-      } else {
-        declareSymbolAndAddToSymbolTable(node, 16 /* Function */, 110991 /* FunctionExcludes */);
-      }
-    }
-    function bindFunctionExpression(node) {
-      if (!file.isDeclarationFile && !(node.flags & 16777216 /* Ambient */)) {
-        if (isAsyncFunction(node)) {
-          emitFlags |= 2048 /* HasAsyncFunctions */;
-        }
-      }
-      if (currentFlow) {
-        node.flowNode = currentFlow;
-      }
-      checkStrictModeFunctionName(node);
-      const bindingName = node.name ? node.name.escapedText : "__function" /* Function */;
-      return bindAnonymousDeclaration(node, 16 /* Function */, bindingName);
-    }
-    function bindPropertyOrMethodOrAccessor(node, symbolFlags, symbolExcludes) {
-      if (!file.isDeclarationFile && !(node.flags & 16777216 /* Ambient */) && isAsyncFunction(node)) {
-        emitFlags |= 2048 /* HasAsyncFunctions */;
-      }
-      if (currentFlow && isObjectLiteralOrClassExpressionMethodOrAccessor(node)) {
-        node.flowNode = currentFlow;
-      }
-      return hasDynamicName(node) ? bindAnonymousDeclaration(node, symbolFlags, "__computed" /* Computed */) : declareSymbolAndAddToSymbolTable(node, symbolFlags, symbolExcludes);
-    }
-    function getInferTypeContainer(node) {
-      const extendsType = findAncestor(node, (n) => n.parent && isConditionalTypeNode(n.parent) && n.parent.extendsType === n);
-      return extendsType && extendsType.parent;
-    }
-    function bindTypeParameter(node) {
-      if (isJSDocTemplateTag(node.parent)) {
-        const container2 = getEffectiveContainerForJSDocTemplateTag(node.parent);
-        if (container2) {
-          Debug.assertNode(container2, canHaveLocals);
-          container2.locals ?? (container2.locals = createSymbolTable());
-          declareSymbol(
-            container2.locals,
-            /*parent*/
-            void 0,
-            node,
-            262144 /* TypeParameter */,
-            526824 /* TypeParameterExcludes */
-          );
-        } else {
-          declareSymbolAndAddToSymbolTable(node, 262144 /* TypeParameter */, 526824 /* TypeParameterExcludes */);
-        }
-      } else if (node.parent.kind === 194 /* InferType */) {
-        const container2 = getInferTypeContainer(node.parent);
-        if (container2) {
-          Debug.assertNode(container2, canHaveLocals);
-          container2.locals ?? (container2.locals = createSymbolTable());
-          declareSymbol(
-            container2.locals,
-            /*parent*/
-            void 0,
-            node,
-            262144 /* TypeParameter */,
-            526824 /* TypeParameterExcludes */
-          );
-        } else {
-          bindAnonymousDeclaration(node, 262144 /* TypeParameter */, getDeclarationName(node));
-        }
-      } else {
-        declareSymbolAndAddToSymbolTable(node, 262144 /* TypeParameter */, 526824 /* TypeParameterExcludes */);
-      }
-    }
-    function shouldReportErrorOnModuleDeclaration(node) {
-      const instanceState = getModuleInstanceState(node);
-      return instanceState === 1 /* Instantiated */ || instanceState === 2 /* ConstEnumOnly */ && shouldPreserveConstEnums(options);
-    }
-    function checkUnreachable(node) {
-      if (!(currentFlow.flags & 1 /* Unreachable */)) {
-        return false;
-      }
-      if (currentFlow === unreachableFlow) {
-        const reportError = (
-          // report error on all statements except empty ones
-          isStatementButNotDeclaration(node) && node.kind !== 241 /* EmptyStatement */ || // report error on class declarations
-          node.kind === 262 /* ClassDeclaration */ || // report error on instantiated modules or const-enums only modules if preserveConstEnums is set
-          node.kind === 266 /* ModuleDeclaration */ && shouldReportErrorOnModuleDeclaration(node)
-        );
-        if (reportError) {
-          currentFlow = reportedUnreachableFlow;
-          if (!options.allowUnreachableCode) {
-            const isError = unreachableCodeIsError(options) && !(node.flags & 16777216 /* Ambient */) && (!isVariableStatement(node) || !!(getCombinedNodeFlags(node.declarationList) & 3 /* BlockScoped */) || node.declarationList.declarations.some((d) => !!d.initializer));
-            eachUnreachableRange(node, (start, end) => errorOrSuggestionOnRange(isError, start, end, Diagnostics.Unreachable_code_detected));
-          }
-        }
-      }
-      return true;
-    }
-  }
-  function eachUnreachableRange(node, cb) {
-    if (isStatement(node) && isExecutableStatement(node) && isBlock(node.parent)) {
-      const { statements } = node.parent;
-      const slice = sliceAfter(statements, node);
-      getRangesWhere(slice, isExecutableStatement, (start, afterEnd) => cb(slice[start], slice[afterEnd - 1]));
-    } else {
-      cb(node, node);
-    }
-  }
-  function isExecutableStatement(s) {
-    return !isFunctionDeclaration(s) && !isPurelyTypeDeclaration(s) && !isEnumDeclaration(s) && // `var x;` may declare a variable used above
-    !(isVariableStatement(s) && !(getCombinedNodeFlags(s) & (1 /* Let */ | 2 /* Const */)) && s.declarationList.declarations.some((d) => !d.initializer));
-  }
-  function isPurelyTypeDeclaration(s) {
-    switch (s.kind) {
-      case 263 /* InterfaceDeclaration */:
-      case 264 /* TypeAliasDeclaration */:
-        return true;
-      case 266 /* ModuleDeclaration */:
-        return getModuleInstanceState(s) !== 1 /* Instantiated */;
-      case 265 /* EnumDeclaration */:
-        return hasSyntacticModifier(s, 2048 /* Const */);
-      default:
-        return false;
-    }
-  }
-  function isExportsOrModuleExportsOrAlias(sourceFile, node) {
-    let i = 0;
-    const q = createQueue();
-    q.enqueue(node);
-    while (!q.isEmpty() && i < 100) {
-      i++;
-      node = q.dequeue();
-      if (isExportsIdentifier(node) || isModuleExportsAccessExpression(node)) {
-        return true;
-      } else if (isIdentifier(node)) {
-        const symbol = lookupSymbolForName(sourceFile, node.escapedText);
-        if (!!symbol && !!symbol.valueDeclaration && isVariableDeclaration(symbol.valueDeclaration) && !!symbol.valueDeclaration.initializer) {
-          const init = symbol.valueDeclaration.initializer;
-          q.enqueue(init);
-          if (isAssignmentExpression(
-            init,
-            /*excludeCompoundAssignment*/
-            true
-          )) {
-            q.enqueue(init.left);
-            q.enqueue(init.right);
-          }
-        }
-      }
-    }
-    return false;
-  }
-  function getContainerFlags(node) {
-    switch (node.kind) {
-      case 230 /* ClassExpression */:
-      case 262 /* ClassDeclaration */:
-      case 265 /* EnumDeclaration */:
-      case 209 /* ObjectLiteralExpression */:
-      case 186 /* TypeLiteral */:
-      case 328 /* JSDocTypeLiteral */:
-      case 291 /* JsxAttributes */:
-        return 1 /* IsContainer */;
-      case 263 /* InterfaceDeclaration */:
-        return 1 /* IsContainer */ | 64 /* IsInterface */;
-      case 266 /* ModuleDeclaration */:
-      case 264 /* TypeAliasDeclaration */:
-      case 199 /* MappedType */:
-      case 180 /* IndexSignature */:
-        return 1 /* IsContainer */ | 32 /* HasLocals */;
-      case 311 /* SourceFile */:
-        return 1 /* IsContainer */ | 4 /* IsControlFlowContainer */ | 32 /* HasLocals */;
-      case 176 /* GetAccessor */:
-      case 177 /* SetAccessor */:
-      case 173 /* MethodDeclaration */:
-        if (isObjectLiteralOrClassExpressionMethodOrAccessor(node)) {
-          return 1 /* IsContainer */ | 4 /* IsControlFlowContainer */ | 32 /* HasLocals */ | 8 /* IsFunctionLike */ | 128 /* IsObjectLiteralOrClassExpressionMethodOrAccessor */;
-        }
-      case 175 /* Constructor */:
-      case 261 /* FunctionDeclaration */:
-      case 172 /* MethodSignature */:
-      case 178 /* CallSignature */:
-      case 329 /* JSDocSignature */:
-      case 323 /* JSDocFunctionType */:
-      case 183 /* FunctionType */:
-      case 179 /* ConstructSignature */:
-      case 184 /* ConstructorType */:
-      case 174 /* ClassStaticBlockDeclaration */:
-        return 1 /* IsContainer */ | 4 /* IsControlFlowContainer */ | 32 /* HasLocals */ | 8 /* IsFunctionLike */;
-      case 217 /* FunctionExpression */:
-      case 218 /* ArrowFunction */:
-        return 1 /* IsContainer */ | 4 /* IsControlFlowContainer */ | 32 /* HasLocals */ | 8 /* IsFunctionLike */ | 16 /* IsFunctionExpression */;
-      case 267 /* ModuleBlock */:
-        return 4 /* IsControlFlowContainer */;
-      case 171 /* PropertyDeclaration */:
-        return node.initializer ? 4 /* IsControlFlowContainer */ : 0;
-      case 298 /* CatchClause */:
-      case 247 /* ForStatement */:
-      case 248 /* ForInStatement */:
-      case 249 /* ForOfStatement */:
-      case 268 /* CaseBlock */:
-        return 2 /* IsBlockScopedContainer */ | 32 /* HasLocals */;
-      case 240 /* Block */:
-        return isFunctionLike(node.parent) || isClassStaticBlockDeclaration(node.parent) ? 0 /* None */ : 2 /* IsBlockScopedContainer */ | 32 /* HasLocals */;
-    }
-    return 0 /* None */;
-  }
-  function lookupSymbolForName(container, name) {
-    var _a, _b, _c, _d;
-    const local = (_b = (_a = tryCast(container, canHaveLocals)) == null ? void 0 : _a.locals) == null ? void 0 : _b.get(name);
-    if (local) {
-      return local.exportSymbol ?? local;
-    }
-    if (isSourceFile(container) && container.jsGlobalAugmentations && container.jsGlobalAugmentations.has(name)) {
-      return container.jsGlobalAugmentations.get(name);
-    }
-    if (canHaveSymbol(container)) {
-      return (_d = (_c = container.symbol) == null ? void 0 : _c.exports) == null ? void 0 : _d.get(name);
-    }
-  }
-  var ModuleInstanceState, binder;
-  var init_binder = __esm({
-    "src/compiler/binder.ts"() {
-      "use strict";
-      init_ts2();
-      init_ts_performance();
-      ModuleInstanceState = /* @__PURE__ */ ((ModuleInstanceState2) => {
-        ModuleInstanceState2[ModuleInstanceState2["NonInstantiated"] = 0] = "NonInstantiated";
-        ModuleInstanceState2[ModuleInstanceState2["Instantiated"] = 1] = "Instantiated";
-        ModuleInstanceState2[ModuleInstanceState2["ConstEnumOnly"] = 2] = "ConstEnumOnly";
-        return ModuleInstanceState2;
-      })(ModuleInstanceState || {});
-      binder = /* @__PURE__ */ createBinder();
-    }
-  });
-
-  // src/compiler/symbolWalker.ts
-  function createGetSymbolWalker(getRestTypeOfSignature, getTypePredicateOfSignature, getReturnTypeOfSignature, getBaseTypes, resolveStructuredTypeMembers, getTypeOfSymbol, getResolvedSymbol, getConstraintOfTypeParameter, getFirstIdentifier2, getTypeArguments) {
-    return getSymbolWalker;
-    function getSymbolWalker(accept = () => true) {
-      const visitedTypes = [];
-      const visitedSymbols = [];
-      return {
-        walkType: (type) => {
-          try {
-            visitType(type);
-            return { visitedTypes: getOwnValues(visitedTypes), visitedSymbols: getOwnValues(visitedSymbols) };
-          } finally {
-            clear(visitedTypes);
-            clear(visitedSymbols);
-          }
-        },
-        walkSymbol: (symbol) => {
-          try {
-            visitSymbol(symbol);
-            return { visitedTypes: getOwnValues(visitedTypes), visitedSymbols: getOwnValues(visitedSymbols) };
-          } finally {
-            clear(visitedTypes);
-            clear(visitedSymbols);
-          }
-        }
-      };
-      function visitType(type) {
-        if (!type) {
-          return;
-        }
-        if (visitedTypes[type.id]) {
-          return;
-        }
-        visitedTypes[type.id] = type;
-        const shouldBail = visitSymbol(type.symbol);
-        if (shouldBail)
-          return;
-        if (type.flags & 524288 /* Object */) {
-          const objectType = type;
-          const objectFlags = objectType.objectFlags;
-          if (objectFlags & 4 /* Reference */) {
-            visitTypeReference(type);
-          }
-          if (objectFlags & 32 /* Mapped */) {
-            visitMappedType(type);
-          }
-          if (objectFlags & (1 /* Class */ | 2 /* Interface */)) {
-            visitInterfaceType(type);
-          }
-          if (objectFlags & (8 /* Tuple */ | 16 /* Anonymous */)) {
-            visitObjectType(objectType);
-          }
-        }
-        if (type.flags & 262144 /* TypeParameter */) {
-          visitTypeParameter(type);
-        }
-        if (type.flags & 3145728 /* UnionOrIntersection */) {
-          visitUnionOrIntersectionType(type);
-        }
-        if (type.flags & 4194304 /* Index */) {
-          visitIndexType(type);
-        }
-        if (type.flags & 8388608 /* IndexedAccess */) {
-          visitIndexedAccessType(type);
-        }
-      }
-      function visitTypeReference(type) {
-        visitType(type.target);
-        forEach(getTypeArguments(type), visitType);
-      }
-      function visitTypeParameter(type) {
-        visitType(getConstraintOfTypeParameter(type));
-      }
-      function visitUnionOrIntersectionType(type) {
-        forEach(type.types, visitType);
-      }
-      function visitIndexType(type) {
-        visitType(type.type);
-      }
-      function visitIndexedAccessType(type) {
-        visitType(type.objectType);
-        visitType(type.indexType);
-        visitType(type.constraint);
-      }
-      function visitMappedType(type) {
-        visitType(type.typeParameter);
-        visitType(type.constraintType);
-        visitType(type.templateType);
-        visitType(type.modifiersType);
-      }
-      function visitSignature(signature) {
-        const typePredicate = getTypePredicateOfSignature(signature);
-        if (typePredicate) {
-          visitType(typePredicate.type);
-        }
-        forEach(signature.typeParameters, visitType);
-        for (const parameter of signature.parameters) {
-          visitSymbol(parameter);
-        }
-        visitType(getRestTypeOfSignature(signature));
-        visitType(getReturnTypeOfSignature(signature));
-      }
-      function visitInterfaceType(interfaceT) {
-        visitObjectType(interfaceT);
-        forEach(interfaceT.typeParameters, visitType);
-        forEach(getBaseTypes(interfaceT), visitType);
-        visitType(interfaceT.thisType);
-      }
-      function visitObjectType(type) {
-        const resolved = resolveStructuredTypeMembers(type);
-        for (const info of resolved.indexInfos) {
-          visitType(info.keyType);
-          visitType(info.type);
-        }
-        for (const signature of resolved.callSignatures) {
-          visitSignature(signature);
-        }
-        for (const signature of resolved.constructSignatures) {
-          visitSignature(signature);
-        }
-        for (const p of resolved.properties) {
-          visitSymbol(p);
-        }
-      }
-      function visitSymbol(symbol) {
-        if (!symbol) {
-          return false;
-        }
-        const symbolId = getSymbolId(symbol);
-        if (visitedSymbols[symbolId]) {
-          return false;
-        }
-        visitedSymbols[symbolId] = symbol;
-        if (!accept(symbol)) {
-          return true;
-        }
-        const t = getTypeOfSymbol(symbol);
-        visitType(t);
-        if (symbol.exports) {
-          symbol.exports.forEach(visitSymbol);
-        }
-        forEach(symbol.declarations, (d) => {
-          if (d.type && d.type.kind === 185 /* TypeQuery */) {
-            const query = d.type;
-            const entity = getResolvedSymbol(getFirstIdentifier2(query.exprName));
-            visitSymbol(entity);
-          }
-        });
-        return false;
-      }
-    }
-  }
-  var init_symbolWalker = __esm({
-    "src/compiler/symbolWalker.ts"() {
-      "use strict";
-      init_ts2();
-    }
-  });
-
-  // src/compiler/moduleSpecifiers.ts
-  function getPreferences({ importModuleSpecifierPreference, importModuleSpecifierEnding }, compilerOptions, importingSourceFile, oldImportSpecifier) {
-    const preferredEnding = getPreferredEnding();
-    return {
-      relativePreference: oldImportSpecifier !== void 0 ? isExternalModuleNameRelative(oldImportSpecifier) ? 0 /* Relative */ : 1 /* NonRelative */ : importModuleSpecifierPreference === "relative" ? 0 /* Relative */ : importModuleSpecifierPreference === "non-relative" ? 1 /* NonRelative */ : importModuleSpecifierPreference === "project-relative" ? 3 /* ExternalNonRelative */ : 2 /* Shortest */,
-      getAllowedEndingsInPreferredOrder: (syntaxImpliedNodeFormat) => {
-        if ((syntaxImpliedNodeFormat ?? importingSourceFile.impliedNodeFormat) === 99 /* ESNext */) {
-          if (shouldAllowImportingTsExtension(compilerOptions, importingSourceFile.fileName)) {
-            return [3 /* TsExtension */, 2 /* JsExtension */];
-          }
-          return [2 /* JsExtension */];
-        }
-        if (getEmitModuleResolutionKind(compilerOptions) === 1 /* Classic */) {
-          return preferredEnding === 2 /* JsExtension */ ? [2 /* JsExtension */, 1 /* Index */] : [1 /* Index */, 2 /* JsExtension */];
-        }
-        const allowImportingTsExtension = shouldAllowImportingTsExtension(compilerOptions, importingSourceFile.fileName);
-        switch (preferredEnding) {
-          case 2 /* JsExtension */:
-            return allowImportingTsExtension ? [2 /* JsExtension */, 3 /* TsExtension */, 0 /* Minimal */, 1 /* Index */] : [2 /* JsExtension */, 0 /* Minimal */, 1 /* Index */];
-          case 3 /* TsExtension */:
-            return [3 /* TsExtension */, 0 /* Minimal */, 2 /* JsExtension */, 1 /* Index */];
-          case 1 /* Index */:
-            return allowImportingTsExtension ? [1 /* Index */, 0 /* Minimal */, 3 /* TsExtension */, 2 /* JsExtension */] : [1 /* Index */, 0 /* Minimal */, 2 /* JsExtension */];
-          case 0 /* Minimal */:
-            return allowImportingTsExtension ? [0 /* Minimal */, 1 /* Index */, 3 /* TsExtension */, 2 /* JsExtension */] : [0 /* Minimal */, 1 /* Index */, 2 /* JsExtension */];
-          default:
-            Debug.assertNever(preferredEnding);
-        }
-      }
-    };
-    function getPreferredEnding() {
-      if (oldImportSpecifier !== void 0) {
-        if (hasJSFileExtension(oldImportSpecifier))
-          return 2 /* JsExtension */;
-        if (endsWith(oldImportSpecifier, "/index"))
-          return 1 /* Index */;
-      }
-      return getModuleSpecifierEndingPreference(
-        importModuleSpecifierEnding,
-        importingSourceFile.impliedNodeFormat,
-        compilerOptions,
-        importingSourceFile
-      );
-    }
-  }
-  function updateModuleSpecifier(compilerOptions, importingSourceFile, importingSourceFileName, toFileName2, host, oldImportSpecifier, options = {}) {
-    const res = getModuleSpecifierWorker(compilerOptions, importingSourceFile, importingSourceFileName, toFileName2, host, getPreferences({}, compilerOptions, importingSourceFile, oldImportSpecifier), {}, options);
-    if (res === oldImportSpecifier)
-      return void 0;
-    return res;
-  }
-  function getModuleSpecifier(compilerOptions, importingSourceFile, importingSourceFileName, toFileName2, host, options = {}) {
-    return getModuleSpecifierWorker(compilerOptions, importingSourceFile, importingSourceFileName, toFileName2, host, getPreferences({}, compilerOptions, importingSourceFile), {}, options);
-  }
-  function getNodeModulesPackageName(compilerOptions, importingSourceFile, nodeModulesFileName, host, preferences, options = {}) {
-    const info = getInfo(importingSourceFile.path, host);
-    const modulePaths = getAllModulePaths(importingSourceFile.path, nodeModulesFileName, host, preferences, options);
-    return firstDefined(
-      modulePaths,
-      (modulePath) => tryGetModuleNameAsNodeModule(
-        modulePath,
-        info,
-        importingSourceFile,
-        host,
-        compilerOptions,
-        preferences,
-        /*packageNameOnly*/
-        true,
-        options.overrideImportMode
-      )
-    );
-  }
-  function getModuleSpecifierWorker(compilerOptions, importingSourceFile, importingSourceFileName, toFileName2, host, preferences, userPreferences, options = {}) {
-    const info = getInfo(importingSourceFileName, host);
-    const modulePaths = getAllModulePaths(importingSourceFileName, toFileName2, host, userPreferences, options);
-    return firstDefined(modulePaths, (modulePath) => tryGetModuleNameAsNodeModule(
-      modulePath,
-      info,
-      importingSourceFile,
-      host,
-      compilerOptions,
-      userPreferences,
-      /*packageNameOnly*/
-      void 0,
-      options.overrideImportMode
-    )) || getLocalModuleSpecifier(toFileName2, info, compilerOptions, host, options.overrideImportMode || importingSourceFile.impliedNodeFormat, preferences);
-  }
-  function tryGetModuleSpecifiersFromCache(moduleSymbol, importingSourceFile, host, userPreferences, options = {}) {
-    return tryGetModuleSpecifiersFromCacheWorker(
-      moduleSymbol,
-      importingSourceFile,
-      host,
-      userPreferences,
-      options
-    )[0];
-  }
-  function tryGetModuleSpecifiersFromCacheWorker(moduleSymbol, importingSourceFile, host, userPreferences, options = {}) {
-    var _a;
-    const moduleSourceFile = getSourceFileOfModule(moduleSymbol);
-    if (!moduleSourceFile) {
-      return emptyArray;
-    }
-    const cache = (_a = host.getModuleSpecifierCache) == null ? void 0 : _a.call(host);
-    const cached = cache == null ? void 0 : cache.get(importingSourceFile.path, moduleSourceFile.path, userPreferences, options);
-    return [cached == null ? void 0 : cached.moduleSpecifiers, moduleSourceFile, cached == null ? void 0 : cached.modulePaths, cache];
-  }
-  function getModuleSpecifiers(moduleSymbol, checker, compilerOptions, importingSourceFile, host, userPreferences, options = {}) {
-    return getModuleSpecifiersWithCacheInfo(
-      moduleSymbol,
-      checker,
-      compilerOptions,
-      importingSourceFile,
-      host,
-      userPreferences,
-      options
-    ).moduleSpecifiers;
-  }
-  function getModuleSpecifiersWithCacheInfo(moduleSymbol, checker, compilerOptions, importingSourceFile, host, userPreferences, options = {}) {
-    let computedWithoutCache = false;
-    const ambient = tryGetModuleNameFromAmbientModule(moduleSymbol, checker);
-    if (ambient)
-      return { moduleSpecifiers: [ambient], computedWithoutCache };
-    let [specifiers, moduleSourceFile, modulePaths, cache] = tryGetModuleSpecifiersFromCacheWorker(
-      moduleSymbol,
-      importingSourceFile,
-      host,
-      userPreferences,
-      options
-    );
-    if (specifiers)
-      return { moduleSpecifiers: specifiers, computedWithoutCache };
-    if (!moduleSourceFile)
-      return { moduleSpecifiers: emptyArray, computedWithoutCache };
-    computedWithoutCache = true;
-    modulePaths || (modulePaths = getAllModulePathsWorker(importingSourceFile.path, moduleSourceFile.originalFileName, host));
-    const result = computeModuleSpecifiers(modulePaths, compilerOptions, importingSourceFile, host, userPreferences, options);
-    cache == null ? void 0 : cache.set(importingSourceFile.path, moduleSourceFile.path, userPreferences, options, modulePaths, result);
-    return { moduleSpecifiers: result, computedWithoutCache };
-  }
-  function computeModuleSpecifiers(modulePaths, compilerOptions, importingSourceFile, host, userPreferences, options = {}) {
-    const info = getInfo(importingSourceFile.path, host);
-    const preferences = getPreferences(userPreferences, compilerOptions, importingSourceFile);
-    const existingSpecifier = forEach(modulePaths, (modulePath) => forEach(
-      host.getFileIncludeReasons().get(toPath(modulePath.path, host.getCurrentDirectory(), info.getCanonicalFileName)),
-      (reason) => {
-        if (reason.kind !== 3 /* Import */ || reason.file !== importingSourceFile.path)
-          return void 0;
-        if (importingSourceFile.impliedNodeFormat && importingSourceFile.impliedNodeFormat !== getModeForResolutionAtIndex(importingSourceFile, reason.index))
-          return void 0;
-        const specifier = getModuleNameStringLiteralAt(importingSourceFile, reason.index).text;
-        return preferences.relativePreference !== 1 /* NonRelative */ || !pathIsRelative(specifier) ? specifier : void 0;
-      }
-    ));
-    if (existingSpecifier) {
-      const moduleSpecifiers = [existingSpecifier];
-      return moduleSpecifiers;
-    }
-    const importedFileIsInNodeModules = some(modulePaths, (p) => p.isInNodeModules);
-    let nodeModulesSpecifiers;
-    let pathsSpecifiers;
-    let redirectPathsSpecifiers;
-    let relativeSpecifiers;
-    for (const modulePath of modulePaths) {
-      const specifier = modulePath.isInNodeModules ? tryGetModuleNameAsNodeModule(
-        modulePath,
-        info,
-        importingSourceFile,
-        host,
-        compilerOptions,
-        userPreferences,
-        /*packageNameOnly*/
-        void 0,
-        options.overrideImportMode
-      ) : void 0;
-      nodeModulesSpecifiers = append(nodeModulesSpecifiers, specifier);
-      if (specifier && modulePath.isRedirect) {
-        return nodeModulesSpecifiers;
-      }
-      if (!specifier) {
-        const local = getLocalModuleSpecifier(
-          modulePath.path,
-          info,
-          compilerOptions,
-          host,
-          options.overrideImportMode || importingSourceFile.impliedNodeFormat,
-          preferences,
-          /*pathsOnly*/
-          modulePath.isRedirect
-        );
-        if (!local) {
-          continue;
-        }
-        if (modulePath.isRedirect) {
-          redirectPathsSpecifiers = append(redirectPathsSpecifiers, local);
-        } else if (pathIsBareSpecifier(local)) {
-          pathsSpecifiers = append(pathsSpecifiers, local);
-        } else if (!importedFileIsInNodeModules || modulePath.isInNodeModules) {
-          relativeSpecifiers = append(relativeSpecifiers, local);
-        }
-      }
-    }
-    return (pathsSpecifiers == null ? void 0 : pathsSpecifiers.length) ? pathsSpecifiers : (redirectPathsSpecifiers == null ? void 0 : redirectPathsSpecifiers.length) ? redirectPathsSpecifiers : (nodeModulesSpecifiers == null ? void 0 : nodeModulesSpecifiers.length) ? nodeModulesSpecifiers : Debug.checkDefined(relativeSpecifiers);
-  }
-  function getInfo(importingSourceFileName, host) {
-    const getCanonicalFileName = createGetCanonicalFileName(host.useCaseSensitiveFileNames ? host.useCaseSensitiveFileNames() : true);
-    const sourceDirectory = getDirectoryPath(importingSourceFileName);
-    return { getCanonicalFileName, importingSourceFileName, sourceDirectory };
-  }
-  function getLocalModuleSpecifier(moduleFileName, info, compilerOptions, host, importMode, { getAllowedEndingsInPreferredOrder: getAllowedEndingsInPrefererredOrder, relativePreference }, pathsOnly) {
-    const { baseUrl, paths, rootDirs } = compilerOptions;
-    if (pathsOnly && !paths) {
-      return void 0;
-    }
-    const { sourceDirectory, getCanonicalFileName } = info;
-    const allowedEndings = getAllowedEndingsInPrefererredOrder(importMode);
-    const relativePath = rootDirs && tryGetModuleNameFromRootDirs(rootDirs, moduleFileName, sourceDirectory, getCanonicalFileName, allowedEndings, compilerOptions) || processEnding(ensurePathIsNonModuleName(getRelativePathFromDirectory(sourceDirectory, moduleFileName, getCanonicalFileName)), allowedEndings, compilerOptions);
-    if (!baseUrl && !paths || relativePreference === 0 /* Relative */) {
-      return pathsOnly ? void 0 : relativePath;
-    }
-    const baseDirectory = getNormalizedAbsolutePath(getPathsBasePath(compilerOptions, host) || baseUrl, host.getCurrentDirectory());
-    const relativeToBaseUrl = getRelativePathIfInSameVolume(moduleFileName, baseDirectory, getCanonicalFileName);
-    if (!relativeToBaseUrl) {
-      return pathsOnly ? void 0 : relativePath;
-    }
-    const fromPaths = paths && tryGetModuleNameFromPaths(relativeToBaseUrl, paths, allowedEndings, host, compilerOptions);
-    if (pathsOnly) {
-      return fromPaths;
-    }
-    const maybeNonRelative = fromPaths === void 0 && baseUrl !== void 0 ? processEnding(relativeToBaseUrl, allowedEndings, compilerOptions) : fromPaths;
-    if (!maybeNonRelative) {
-      return relativePath;
-    }
-    if (relativePreference === 1 /* NonRelative */ && !pathIsRelative(maybeNonRelative)) {
-      return maybeNonRelative;
-    }
-    if (relativePreference === 3 /* ExternalNonRelative */ && !pathIsRelative(maybeNonRelative)) {
-      const projectDirectory = compilerOptions.configFilePath ? toPath(getDirectoryPath(compilerOptions.configFilePath), host.getCurrentDirectory(), info.getCanonicalFileName) : info.getCanonicalFileName(host.getCurrentDirectory());
-      const modulePath = toPath(moduleFileName, projectDirectory, getCanonicalFileName);
-      const sourceIsInternal = startsWith(sourceDirectory, projectDirectory);
-      const targetIsInternal = startsWith(modulePath, projectDirectory);
-      if (sourceIsInternal && !targetIsInternal || !sourceIsInternal && targetIsInternal) {
-        return maybeNonRelative;
-      }
-      const nearestTargetPackageJson = getNearestAncestorDirectoryWithPackageJson(host, getDirectoryPath(modulePath));
-      const nearestSourcePackageJson = getNearestAncestorDirectoryWithPackageJson(host, sourceDirectory);
-      if (nearestSourcePackageJson !== nearestTargetPackageJson) {
-        return maybeNonRelative;
-      }
-      return relativePath;
-    }
-    return isPathRelativeToParent(maybeNonRelative) || countPathComponents(relativePath) < countPathComponents(maybeNonRelative) ? relativePath : maybeNonRelative;
-  }
-  function countPathComponents(path) {
-    let count = 0;
-    for (let i = startsWith(path, "./") ? 2 : 0; i < path.length; i++) {
-      if (path.charCodeAt(i) === 47 /* slash */)
-        count++;
-    }
-    return count;
-  }
-  function comparePathsByRedirectAndNumberOfDirectorySeparators(a, b) {
-    return compareBooleans(b.isRedirect, a.isRedirect) || compareNumberOfDirectorySeparators(a.path, b.path);
-  }
-  function getNearestAncestorDirectoryWithPackageJson(host, fileName) {
-    if (host.getNearestAncestorDirectoryWithPackageJson) {
-      return host.getNearestAncestorDirectoryWithPackageJson(fileName);
-    }
-    return !!forEachAncestorDirectory(fileName, (directory) => {
-      return host.fileExists(combinePaths(directory, "package.json")) ? true : void 0;
-    });
-  }
-  function forEachFileNameOfModule(importingFileName, importedFileName, host, preferSymlinks, cb) {
-    var _a;
-    const getCanonicalFileName = hostGetCanonicalFileName(host);
-    const cwd = host.getCurrentDirectory();
-    const referenceRedirect = host.isSourceOfProjectReferenceRedirect(importedFileName) ? host.getProjectReferenceRedirect(importedFileName) : void 0;
-    const importedPath = toPath(importedFileName, cwd, getCanonicalFileName);
-    const redirects = host.redirectTargetsMap.get(importedPath) || emptyArray;
-    const importedFileNames = [...referenceRedirect ? [referenceRedirect] : emptyArray, importedFileName, ...redirects];
-    const targets = importedFileNames.map((f) => getNormalizedAbsolutePath(f, cwd));
-    let shouldFilterIgnoredPaths = !every(targets, containsIgnoredPath);
-    if (!preferSymlinks) {
-      const result2 = forEach(targets, (p) => !(shouldFilterIgnoredPaths && containsIgnoredPath(p)) && cb(p, referenceRedirect === p));
-      if (result2)
-        return result2;
-    }
-    const symlinkedDirectories = (_a = host.getSymlinkCache) == null ? void 0 : _a.call(host).getSymlinkedDirectoriesByRealpath();
-    const fullImportedFileName = getNormalizedAbsolutePath(importedFileName, cwd);
-    const result = symlinkedDirectories && forEachAncestorDirectory(getDirectoryPath(fullImportedFileName), (realPathDirectory) => {
-      const symlinkDirectories = symlinkedDirectories.get(ensureTrailingDirectorySeparator(toPath(realPathDirectory, cwd, getCanonicalFileName)));
-      if (!symlinkDirectories)
-        return void 0;
-      if (startsWithDirectory(importingFileName, realPathDirectory, getCanonicalFileName)) {
-        return false;
-      }
-      return forEach(targets, (target) => {
-        if (!startsWithDirectory(target, realPathDirectory, getCanonicalFileName)) {
-          return;
-        }
-        const relative = getRelativePathFromDirectory(realPathDirectory, target, getCanonicalFileName);
-        for (const symlinkDirectory of symlinkDirectories) {
-          const option = resolvePath(symlinkDirectory, relative);
-          const result2 = cb(option, target === referenceRedirect);
-          shouldFilterIgnoredPaths = true;
-          if (result2)
-            return result2;
-        }
-      });
-    });
-    return result || (preferSymlinks ? forEach(targets, (p) => shouldFilterIgnoredPaths && containsIgnoredPath(p) ? void 0 : cb(p, p === referenceRedirect)) : void 0);
-  }
-  function getAllModulePaths(importingFilePath, importedFileName, host, preferences, options = {}) {
-    var _a;
-    const importedFilePath = toPath(importedFileName, host.getCurrentDirectory(), hostGetCanonicalFileName(host));
-    const cache = (_a = host.getModuleSpecifierCache) == null ? void 0 : _a.call(host);
-    if (cache) {
-      const cached = cache.get(importingFilePath, importedFilePath, preferences, options);
-      if (cached == null ? void 0 : cached.modulePaths)
-        return cached.modulePaths;
-    }
-    const modulePaths = getAllModulePathsWorker(importingFilePath, importedFileName, host);
-    if (cache) {
-      cache.setModulePaths(importingFilePath, importedFilePath, preferences, options, modulePaths);
-    }
-    return modulePaths;
-  }
-  function getAllModulePathsWorker(importingFileName, importedFileName, host) {
-    const getCanonicalFileName = hostGetCanonicalFileName(host);
-    const allFileNames = /* @__PURE__ */ new Map();
-    let importedFileFromNodeModules = false;
-    forEachFileNameOfModule(
-      importingFileName,
-      importedFileName,
-      host,
-      /*preferSymlinks*/
-      true,
-      (path, isRedirect) => {
-        const isInNodeModules = pathContainsNodeModules(path);
-        allFileNames.set(path, { path: getCanonicalFileName(path), isRedirect, isInNodeModules });
-        importedFileFromNodeModules = importedFileFromNodeModules || isInNodeModules;
-      }
-    );
-    const sortedPaths = [];
-    for (let directory = getDirectoryPath(importingFileName); allFileNames.size !== 0; ) {
-      const directoryStart = ensureTrailingDirectorySeparator(directory);
-      let pathsInDirectory;
-      allFileNames.forEach(({ path, isRedirect, isInNodeModules }, fileName) => {
-        if (startsWith(path, directoryStart)) {
-          (pathsInDirectory || (pathsInDirectory = [])).push({ path: fileName, isRedirect, isInNodeModules });
-          allFileNames.delete(fileName);
-        }
-      });
-      if (pathsInDirectory) {
-        if (pathsInDirectory.length > 1) {
-          pathsInDirectory.sort(comparePathsByRedirectAndNumberOfDirectorySeparators);
-        }
-        sortedPaths.push(...pathsInDirectory);
-      }
-      const newDirectory = getDirectoryPath(directory);
-      if (newDirectory === directory)
-        break;
-      directory = newDirectory;
-    }
-    if (allFileNames.size) {
-      const remainingPaths = arrayFrom(allFileNames.values());
-      if (remainingPaths.length > 1)
-        remainingPaths.sort(comparePathsByRedirectAndNumberOfDirectorySeparators);
-      sortedPaths.push(...remainingPaths);
-    }
-    return sortedPaths;
-  }
-  function tryGetModuleNameFromAmbientModule(moduleSymbol, checker) {
-    var _a;
-    const decl = (_a = moduleSymbol.declarations) == null ? void 0 : _a.find(
-      (d) => isNonGlobalAmbientModule(d) && (!isExternalModuleAugmentation(d) || !isExternalModuleNameRelative(getTextOfIdentifierOrLiteral(d.name)))
-    );
-    if (decl) {
-      return decl.name.text;
-    }
-    const ambientModuleDeclareCandidates = mapDefined(
-      moduleSymbol.declarations,
-      (d) => {
-        var _a2, _b, _c, _d;
-        if (!isModuleDeclaration(d))
-          return;
-        const topNamespace = getTopNamespace(d);
-        if (!(((_a2 = topNamespace == null ? void 0 : topNamespace.parent) == null ? void 0 : _a2.parent) && isModuleBlock(topNamespace.parent) && isAmbientModule(topNamespace.parent.parent) && isSourceFile(topNamespace.parent.parent.parent)))
-          return;
-        const exportAssignment = (_d = (_c = (_b = topNamespace.parent.parent.symbol.exports) == null ? void 0 : _b.get("export=")) == null ? void 0 : _c.valueDeclaration) == null ? void 0 : _d.expression;
-        if (!exportAssignment)
-          return;
-        const exportSymbol = checker.getSymbolAtLocation(exportAssignment);
-        if (!exportSymbol)
-          return;
-        const originalExportSymbol = (exportSymbol == null ? void 0 : exportSymbol.flags) & 2097152 /* Alias */ ? checker.getAliasedSymbol(exportSymbol) : exportSymbol;
-        if (originalExportSymbol === d.symbol)
-          return topNamespace.parent.parent;
-        function getTopNamespace(namespaceDeclaration) {
-          while (namespaceDeclaration.flags & 4 /* NestedNamespace */) {
-            namespaceDeclaration = namespaceDeclaration.parent;
-          }
-          return namespaceDeclaration;
-        }
-      }
-    );
-    const ambientModuleDeclare = ambientModuleDeclareCandidates[0];
-    if (ambientModuleDeclare) {
-      return ambientModuleDeclare.name.text;
-    }
-  }
-  function tryGetModuleNameFromPaths(relativeToBaseUrl, paths, allowedEndings, host, compilerOptions) {
-    for (const key in paths) {
-      for (const patternText2 of paths[key]) {
-        const pattern = normalizePath(patternText2);
-        const indexOfStar = pattern.indexOf("*");
-        const candidates = allowedEndings.map((ending) => ({
-          ending,
-          value: processEnding(relativeToBaseUrl, [ending], compilerOptions)
-        }));
-        if (tryGetExtensionFromPath2(pattern)) {
-          candidates.push({ ending: void 0, value: relativeToBaseUrl });
-        }
-        if (indexOfStar !== -1) {
-          const prefix = pattern.substring(0, indexOfStar);
-          const suffix = pattern.substring(indexOfStar + 1);
-          for (const { ending, value } of candidates) {
-            if (value.length >= prefix.length + suffix.length && startsWith(value, prefix) && endsWith(value, suffix) && validateEnding({ ending, value })) {
-              const matchedStar = value.substring(prefix.length, value.length - suffix.length);
-              return pathIsRelative(matchedStar) ? void 0 : key.replace("*", matchedStar);
-            }
-          }
-        } else if (some(candidates, (c) => c.ending !== 0 /* Minimal */ && pattern === c.value) || some(candidates, (c) => c.ending === 0 /* Minimal */ && pattern === c.value && validateEnding(c))) {
-          return key;
-        }
-      }
-    }
-    function validateEnding({ ending, value }) {
-      return ending !== 0 /* Minimal */ || value === processEnding(relativeToBaseUrl, [ending], compilerOptions, host);
-    }
-  }
-  function tryGetModuleNameFromExports(options, targetFilePath, packageDirectory, packageName, exports, conditions, mode = 0 /* Exact */) {
-    if (typeof exports === "string") {
-      const pathOrPattern = getNormalizedAbsolutePath(
-        combinePaths(packageDirectory, exports),
-        /*currentDirectory*/
-        void 0
-      );
-      const extensionSwappedTarget = hasTSFileExtension(targetFilePath) ? removeFileExtension(targetFilePath) + tryGetJSExtensionForFile(targetFilePath, options) : void 0;
-      switch (mode) {
-        case 0 /* Exact */:
-          if (comparePaths(targetFilePath, pathOrPattern) === 0 /* EqualTo */ || extensionSwappedTarget && comparePaths(extensionSwappedTarget, pathOrPattern) === 0 /* EqualTo */) {
-            return { moduleFileToTry: packageName };
-          }
-          break;
-        case 1 /* Directory */:
-          if (containsPath(pathOrPattern, targetFilePath)) {
-            const fragment = getRelativePathFromDirectory(
-              pathOrPattern,
-              targetFilePath,
-              /*ignoreCase*/
-              false
-            );
-            return { moduleFileToTry: getNormalizedAbsolutePath(
-              combinePaths(combinePaths(packageName, exports), fragment),
-              /*currentDirectory*/
-              void 0
-            ) };
-          }
-          break;
-        case 2 /* Pattern */:
-          const starPos = pathOrPattern.indexOf("*");
-          const leadingSlice = pathOrPattern.slice(0, starPos);
-          const trailingSlice = pathOrPattern.slice(starPos + 1);
-          if (startsWith(targetFilePath, leadingSlice) && endsWith(targetFilePath, trailingSlice)) {
-            const starReplacement = targetFilePath.slice(leadingSlice.length, targetFilePath.length - trailingSlice.length);
-            return { moduleFileToTry: packageName.replace("*", starReplacement) };
-          }
-          if (extensionSwappedTarget && startsWith(extensionSwappedTarget, leadingSlice) && endsWith(extensionSwappedTarget, trailingSlice)) {
-            const starReplacement = extensionSwappedTarget.slice(leadingSlice.length, extensionSwappedTarget.length - trailingSlice.length);
-            return { moduleFileToTry: packageName.replace("*", starReplacement) };
-          }
-          break;
-      }
-    } else if (Array.isArray(exports)) {
-      return forEach(exports, (e) => tryGetModuleNameFromExports(options, targetFilePath, packageDirectory, packageName, e, conditions));
-    } else if (typeof exports === "object" && exports !== null) {
-      if (allKeysStartWithDot(exports)) {
-        return forEach(getOwnKeys(exports), (k) => {
-          const subPackageName = getNormalizedAbsolutePath(
-            combinePaths(packageName, k),
-            /*currentDirectory*/
-            void 0
-          );
-          const mode2 = endsWith(k, "/") ? 1 /* Directory */ : stringContains(k, "*") ? 2 /* Pattern */ : 0 /* Exact */;
-          return tryGetModuleNameFromExports(options, targetFilePath, packageDirectory, subPackageName, exports[k], conditions, mode2);
-        });
-      } else {
-        for (const key of getOwnKeys(exports)) {
-          if (key === "default" || conditions.indexOf(key) >= 0 || isApplicableVersionedTypesKey(conditions, key)) {
-            const subTarget = exports[key];
-            const result = tryGetModuleNameFromExports(options, targetFilePath, packageDirectory, packageName, subTarget, conditions);
-            if (result) {
-              return result;
-            }
-          }
-        }
-      }
-    }
-    return void 0;
-  }
-  function tryGetModuleNameFromRootDirs(rootDirs, moduleFileName, sourceDirectory, getCanonicalFileName, allowedEndings, compilerOptions) {
-    const normalizedTargetPaths = getPathsRelativeToRootDirs(moduleFileName, rootDirs, getCanonicalFileName);
-    if (normalizedTargetPaths === void 0) {
-      return void 0;
-    }
-    const normalizedSourcePaths = getPathsRelativeToRootDirs(sourceDirectory, rootDirs, getCanonicalFileName);
-    const relativePaths = flatMap(normalizedSourcePaths, (sourcePath) => {
-      return map(normalizedTargetPaths, (targetPath) => ensurePathIsNonModuleName(getRelativePathFromDirectory(sourcePath, targetPath, getCanonicalFileName)));
-    });
-    const shortest = min(relativePaths, compareNumberOfDirectorySeparators);
-    if (!shortest) {
-      return void 0;
-    }
-    return processEnding(shortest, allowedEndings, compilerOptions);
-  }
-  function tryGetModuleNameAsNodeModule({ path, isRedirect }, { getCanonicalFileName, sourceDirectory }, importingSourceFile, host, options, userPreferences, packageNameOnly, overrideMode) {
-    if (!host.fileExists || !host.readFile) {
-      return void 0;
-    }
-    const parts = getNodeModulePathParts(path);
-    if (!parts) {
-      return void 0;
-    }
-    const preferences = getPreferences(userPreferences, options, importingSourceFile);
-    const allowedEndings = preferences.getAllowedEndingsInPreferredOrder();
-    let moduleSpecifier = path;
-    let isPackageRootPath = false;
-    if (!packageNameOnly) {
-      let packageRootIndex = parts.packageRootIndex;
-      let moduleFileName;
-      while (true) {
-        const { moduleFileToTry, packageRootPath, blockedByExports, verbatimFromExports } = tryDirectoryWithPackageJson(packageRootIndex);
-        if (getEmitModuleResolutionKind(options) !== 1 /* Classic */) {
-          if (blockedByExports) {
-            return void 0;
-          }
-          if (verbatimFromExports) {
-            return moduleFileToTry;
-          }
-        }
-        if (packageRootPath) {
-          moduleSpecifier = packageRootPath;
-          isPackageRootPath = true;
-          break;
-        }
-        if (!moduleFileName)
-          moduleFileName = moduleFileToTry;
-        packageRootIndex = path.indexOf(directorySeparator, packageRootIndex + 1);
-        if (packageRootIndex === -1) {
-          moduleSpecifier = processEnding(moduleFileName, allowedEndings, options, host);
-          break;
-        }
-      }
-    }
-    if (isRedirect && !isPackageRootPath) {
-      return void 0;
-    }
-    const globalTypingsCacheLocation = host.getGlobalTypingsCacheLocation && host.getGlobalTypingsCacheLocation();
-    const pathToTopLevelNodeModules = getCanonicalFileName(moduleSpecifier.substring(0, parts.topLevelNodeModulesIndex));
-    if (!(startsWith(sourceDirectory, pathToTopLevelNodeModules) || globalTypingsCacheLocation && startsWith(getCanonicalFileName(globalTypingsCacheLocation), pathToTopLevelNodeModules))) {
-      return void 0;
-    }
-    const nodeModulesDirectoryName = moduleSpecifier.substring(parts.topLevelPackageNameIndex + 1);
-    const packageName = getPackageNameFromTypesPackageName(nodeModulesDirectoryName);
-    return getEmitModuleResolutionKind(options) === 1 /* Classic */ && packageName === nodeModulesDirectoryName ? void 0 : packageName;
-    function tryDirectoryWithPackageJson(packageRootIndex) {
-      var _a, _b;
-      const packageRootPath = path.substring(0, packageRootIndex);
-      const packageJsonPath = combinePaths(packageRootPath, "package.json");
-      let moduleFileToTry = path;
-      let maybeBlockedByTypesVersions = false;
-      const cachedPackageJson = (_b = (_a = host.getPackageJsonInfoCache) == null ? void 0 : _a.call(host)) == null ? void 0 : _b.getPackageJsonInfo(packageJsonPath);
-      if (typeof cachedPackageJson === "object" || cachedPackageJson === void 0 && host.fileExists(packageJsonPath)) {
-        const packageJsonContent = (cachedPackageJson == null ? void 0 : cachedPackageJson.contents.packageJsonContent) || JSON.parse(host.readFile(packageJsonPath));
-        const importMode = overrideMode || importingSourceFile.impliedNodeFormat;
-        if (getResolvePackageJsonExports(options)) {
-          const nodeModulesDirectoryName2 = packageRootPath.substring(parts.topLevelPackageNameIndex + 1);
-          const packageName2 = getPackageNameFromTypesPackageName(nodeModulesDirectoryName2);
-          const conditions = getConditions(options, importMode === 99 /* ESNext */);
-          const fromExports = packageJsonContent.exports ? tryGetModuleNameFromExports(options, path, packageRootPath, packageName2, packageJsonContent.exports, conditions) : void 0;
-          if (fromExports) {
-            const withJsExtension = !hasTSFileExtension(fromExports.moduleFileToTry) ? fromExports : { moduleFileToTry: removeFileExtension(fromExports.moduleFileToTry) + tryGetJSExtensionForFile(fromExports.moduleFileToTry, options) };
-            return { ...withJsExtension, verbatimFromExports: true };
-          }
-          if (packageJsonContent.exports) {
-            return { moduleFileToTry: path, blockedByExports: true };
-          }
-        }
-        const versionPaths = packageJsonContent.typesVersions ? getPackageJsonTypesVersionsPaths(packageJsonContent.typesVersions) : void 0;
-        if (versionPaths) {
-          const subModuleName = path.slice(packageRootPath.length + 1);
-          const fromPaths = tryGetModuleNameFromPaths(
-            subModuleName,
-            versionPaths.paths,
-            allowedEndings,
-            host,
-            options
-          );
-          if (fromPaths === void 0) {
-            maybeBlockedByTypesVersions = true;
-          } else {
-            moduleFileToTry = combinePaths(packageRootPath, fromPaths);
-          }
-        }
-        const mainFileRelative = packageJsonContent.typings || packageJsonContent.types || packageJsonContent.main || "index.js";
-        if (isString(mainFileRelative) && !(maybeBlockedByTypesVersions && matchPatternOrExact(tryParsePatterns(versionPaths.paths), mainFileRelative))) {
-          const mainExportFile = toPath(mainFileRelative, packageRootPath, getCanonicalFileName);
-          const canonicalModuleFileToTry = getCanonicalFileName(moduleFileToTry);
-          if (removeFileExtension(mainExportFile) === removeFileExtension(canonicalModuleFileToTry)) {
-            return { packageRootPath, moduleFileToTry };
-          } else if (packageJsonContent.type !== "module" && !fileExtensionIsOneOf(canonicalModuleFileToTry, extensionsNotSupportingExtensionlessResolution) && startsWith(canonicalModuleFileToTry, mainExportFile) && getDirectoryPath(canonicalModuleFileToTry) === removeTrailingDirectorySeparator(mainExportFile) && removeFileExtension(getBaseFileName(canonicalModuleFileToTry)) === "index") {
-            return { packageRootPath, moduleFileToTry };
-          }
-        }
-      } else {
-        const fileName = getCanonicalFileName(moduleFileToTry.substring(parts.packageRootIndex + 1));
-        if (fileName === "index.d.ts" || fileName === "index.js" || fileName === "index.ts" || fileName === "index.tsx") {
-          return { moduleFileToTry, packageRootPath };
-        }
-      }
-      return { moduleFileToTry };
-    }
-  }
-  function tryGetAnyFileFromPath(host, path) {
-    if (!host.fileExists)
-      return;
-    const extensions = flatten(getSupportedExtensions({ allowJs: true }, [{ extension: "node", isMixedContent: false }, { extension: "json", isMixedContent: false, scriptKind: 6 /* JSON */ }]));
-    for (const e of extensions) {
-      const fullPath = path + e;
-      if (host.fileExists(fullPath)) {
-        return fullPath;
-      }
-    }
-  }
-  function getPathsRelativeToRootDirs(path, rootDirs, getCanonicalFileName) {
-    return mapDefined(rootDirs, (rootDir) => {
-      const relativePath = getRelativePathIfInSameVolume(path, rootDir, getCanonicalFileName);
-      return relativePath !== void 0 && isPathRelativeToParent(relativePath) ? void 0 : relativePath;
-    });
-  }
-  function processEnding(fileName, allowedEndings, options, host) {
-    if (fileExtensionIsOneOf(fileName, [".json" /* Json */, ".mjs" /* Mjs */, ".cjs" /* Cjs */])) {
-      return fileName;
-    }
-    const noExtension = removeFileExtension(fileName);
-    if (fileName === noExtension) {
-      return fileName;
-    }
-    const jsPriority = allowedEndings.indexOf(2 /* JsExtension */);
-    const tsPriority = allowedEndings.indexOf(3 /* TsExtension */);
-    if (fileExtensionIsOneOf(fileName, [".mts" /* Mts */, ".cts" /* Cts */]) && tsPriority !== -1 && tsPriority < jsPriority) {
-      return fileName;
-    } else if (fileExtensionIsOneOf(fileName, [".d.mts" /* Dmts */, ".mts" /* Mts */, ".d.cts" /* Dcts */, ".cts" /* Cts */])) {
-      return noExtension + getJSExtensionForFile(fileName, options);
-    } else if (!fileExtensionIsOneOf(fileName, [".d.ts" /* Dts */]) && fileExtensionIsOneOf(fileName, [".ts" /* Ts */]) && stringContains(fileName, ".d.")) {
-      return tryGetRealFileNameForNonJsDeclarationFileName(fileName);
-    }
-    switch (allowedEndings[0]) {
-      case 0 /* Minimal */:
-        const withoutIndex = removeSuffix(noExtension, "/index");
-        if (host && withoutIndex !== noExtension && tryGetAnyFileFromPath(host, withoutIndex)) {
-          return noExtension;
-        }
-        return withoutIndex;
-      case 1 /* Index */:
-        return noExtension;
-      case 2 /* JsExtension */:
-        return noExtension + getJSExtensionForFile(fileName, options);
-      case 3 /* TsExtension */:
-        if (isDeclarationFileName(fileName)) {
-          const extensionlessPriority = allowedEndings.findIndex((e) => e === 0 /* Minimal */ || e === 1 /* Index */);
-          return extensionlessPriority !== -1 && extensionlessPriority < jsPriority ? noExtension : noExtension + getJSExtensionForFile(fileName, options);
-        }
-        return fileName;
-      default:
-        return Debug.assertNever(allowedEndings[0]);
-    }
-  }
-  function tryGetRealFileNameForNonJsDeclarationFileName(fileName) {
-    const baseName = getBaseFileName(fileName);
-    if (!endsWith(fileName, ".ts" /* Ts */) || !stringContains(baseName, ".d.") || fileExtensionIsOneOf(baseName, [".d.ts" /* Dts */]))
-      return void 0;
-    const noExtension = removeExtension(fileName, ".ts" /* Ts */);
-    const ext = noExtension.substring(noExtension.lastIndexOf("."));
-    return noExtension.substring(0, noExtension.indexOf(".d.")) + ext;
-  }
-  function getJSExtensionForFile(fileName, options) {
-    return tryGetJSExtensionForFile(fileName, options) ?? Debug.fail(`Extension ${extensionFromPath(fileName)} is unsupported:: FileName:: ${fileName}`);
-  }
-  function tryGetJSExtensionForFile(fileName, options) {
-    const ext = tryGetExtensionFromPath2(fileName);
-    switch (ext) {
-      case ".ts" /* Ts */:
-      case ".d.ts" /* Dts */:
-        return ".js" /* Js */;
-      case ".tsx" /* Tsx */:
-        return options.jsx === 1 /* Preserve */ ? ".jsx" /* Jsx */ : ".js" /* Js */;
-      case ".js" /* Js */:
-      case ".jsx" /* Jsx */:
-      case ".json" /* Json */:
-        return ext;
-      case ".d.mts" /* Dmts */:
-      case ".mts" /* Mts */:
-      case ".mjs" /* Mjs */:
-        return ".mjs" /* Mjs */;
-      case ".d.cts" /* Dcts */:
-      case ".cts" /* Cts */:
-      case ".cjs" /* Cjs */:
-        return ".cjs" /* Cjs */;
-      default:
-        return void 0;
-    }
-  }
-  function getRelativePathIfInSameVolume(path, directoryPath, getCanonicalFileName) {
-    const relativePath = getRelativePathToDirectoryOrUrl(
-      directoryPath,
-      path,
-      directoryPath,
-      getCanonicalFileName,
-      /*isAbsolutePathAnUrl*/
-      false
-    );
-    return isRootedDiskPath(relativePath) ? void 0 : relativePath;
-  }
-  function isPathRelativeToParent(path) {
-    return startsWith(path, "..");
-  }
-  var init_moduleSpecifiers = __esm({
-    "src/compiler/moduleSpecifiers.ts"() {
-      "use strict";
-      init_ts2();
-    }
-  });
-
-  // src/compiler/_namespaces/ts.moduleSpecifiers.ts
-  var ts_moduleSpecifiers_exports = {};
-  __export(ts_moduleSpecifiers_exports, {
-    countPathComponents: () => countPathComponents,
-    forEachFileNameOfModule: () => forEachFileNameOfModule,
-    getModuleSpecifier: () => getModuleSpecifier,
-    getModuleSpecifiers: () => getModuleSpecifiers,
-    getModuleSpecifiersWithCacheInfo: () => getModuleSpecifiersWithCacheInfo,
-    getNodeModulesPackageName: () => getNodeModulesPackageName,
-    tryGetJSExtensionForFile: () => tryGetJSExtensionForFile,
-    tryGetModuleSpecifiersFromCache: () => tryGetModuleSpecifiersFromCache,
-    tryGetRealFileNameForNonJsDeclarationFileName: () => tryGetRealFileNameForNonJsDeclarationFileName,
-    updateModuleSpecifier: () => updateModuleSpecifier
-  });
-  var init_ts_moduleSpecifiers = __esm({
-    "src/compiler/_namespaces/ts.moduleSpecifiers.ts"() {
-      "use strict";
-      init_moduleSpecifiers();
-    }
-  });
-
-  // src/compiler/checker.ts
-  function NodeLinks() {
-    this.flags = 0 /* None */;
-  }
-  function getNodeId(node) {
-    if (!node.id) {
-      node.id = nextNodeId;
-      nextNodeId++;
-    }
-    return node.id;
-  }
-  function getSymbolId(symbol) {
-    if (!symbol.id) {
-      symbol.id = nextSymbolId;
-      nextSymbolId++;
-    }
-    return symbol.id;
-  }
-  function isInstantiatedModule(node, preserveConstEnums) {
-    const moduleState = getModuleInstanceState(node);
-    return moduleState === 1 /* Instantiated */ || preserveConstEnums && moduleState === 2 /* ConstEnumOnly */;
-  }
-  function createTypeChecker(host) {
-    var deferredDiagnosticsCallbacks = [];
-    var addLazyDiagnostic = (arg) => {
-      deferredDiagnosticsCallbacks.push(arg);
-    };
-    var cancellationToken;
-    var requestedExternalEmitHelperNames = /* @__PURE__ */ new Set();
-    var requestedExternalEmitHelpers;
-    var externalHelpersModule;
-    var Symbol47 = objectAllocator.getSymbolConstructor();
-    var Type27 = objectAllocator.getTypeConstructor();
-    var Signature15 = objectAllocator.getSignatureConstructor();
-    var typeCount = 0;
-    var symbolCount = 0;
-    var totalInstantiationCount = 0;
-    var instantiationCount = 0;
-    var instantiationDepth = 0;
-    var inlineLevel = 0;
-    var currentNode;
-    var varianceTypeParameter;
-    var isInferencePartiallyBlocked = false;
-    var emptySymbols = createSymbolTable();
-    var arrayVariances = [1 /* Covariant */];
-    var compilerOptions = host.getCompilerOptions();
-    var languageVersion = getEmitScriptTarget(compilerOptions);
-    var moduleKind = getEmitModuleKind(compilerOptions);
-    var legacyDecorators = !!compilerOptions.experimentalDecorators;
-    var useDefineForClassFields = getUseDefineForClassFields(compilerOptions);
-    var allowSyntheticDefaultImports = getAllowSyntheticDefaultImports(compilerOptions);
-    var strictNullChecks = getStrictOptionValue(compilerOptions, "strictNullChecks");
-    var strictFunctionTypes = getStrictOptionValue(compilerOptions, "strictFunctionTypes");
-    var strictBindCallApply = getStrictOptionValue(compilerOptions, "strictBindCallApply");
-    var strictPropertyInitialization = getStrictOptionValue(compilerOptions, "strictPropertyInitialization");
-    var noImplicitAny = getStrictOptionValue(compilerOptions, "noImplicitAny");
-    var noImplicitThis = getStrictOptionValue(compilerOptions, "noImplicitThis");
-    var useUnknownInCatchVariables = getStrictOptionValue(compilerOptions, "useUnknownInCatchVariables");
-    var keyofStringsOnly = !!compilerOptions.keyofStringsOnly;
-    var defaultIndexFlags = keyofStringsOnly ? 1 /* StringsOnly */ : 0 /* None */;
-    var freshObjectLiteralFlag = compilerOptions.suppressExcessPropertyErrors ? 0 : 8192 /* FreshLiteral */;
-    var exactOptionalPropertyTypes = compilerOptions.exactOptionalPropertyTypes;
-    var checkBinaryExpression = createCheckBinaryExpression();
-    var emitResolver = createResolver();
-    var nodeBuilder = createNodeBuilder();
-    var globals = createSymbolTable();
-    var undefinedSymbol = createSymbol(4 /* Property */, "undefined");
-    undefinedSymbol.declarations = [];
-    var globalThisSymbol = createSymbol(1536 /* Module */, "globalThis", 8 /* Readonly */);
-    globalThisSymbol.exports = globals;
-    globalThisSymbol.declarations = [];
-    globals.set(globalThisSymbol.escapedName, globalThisSymbol);
-    var argumentsSymbol = createSymbol(4 /* Property */, "arguments");
-    var requireSymbol = createSymbol(4 /* Property */, "require");
-    var isolatedModulesLikeFlagName = compilerOptions.verbatimModuleSyntax ? "verbatimModuleSyntax" : "isolatedModules";
-    var canCollectSymbolAliasAccessabilityData = !compilerOptions.verbatimModuleSyntax || !!compilerOptions.importsNotUsedAsValues;
-    var apparentArgumentCount;
-    const checker = {
-      getNodeCount: () => reduceLeft(host.getSourceFiles(), (n, s) => n + s.nodeCount, 0),
-      getIdentifierCount: () => reduceLeft(host.getSourceFiles(), (n, s) => n + s.identifierCount, 0),
-      getSymbolCount: () => reduceLeft(host.getSourceFiles(), (n, s) => n + s.symbolCount, symbolCount),
-      getTypeCount: () => typeCount,
-      getInstantiationCount: () => totalInstantiationCount,
-      getRelationCacheSizes: () => ({
-        assignable: assignableRelation.size,
-        identity: identityRelation.size,
-        subtype: subtypeRelation.size,
-        strictSubtype: strictSubtypeRelation.size
-      }),
-      isUndefinedSymbol: (symbol) => symbol === undefinedSymbol,
-      isArgumentsSymbol: (symbol) => symbol === argumentsSymbol,
-      isUnknownSymbol: (symbol) => symbol === unknownSymbol,
-      getMergedSymbol,
-      getDiagnostics: getDiagnostics2,
-      getGlobalDiagnostics,
-      getRecursionIdentity,
-      getUnmatchedProperties,
-      getTypeOfSymbolAtLocation: (symbol, locationIn) => {
-        const location = getParseTreeNode(locationIn);
-        return location ? getTypeOfSymbolAtLocation(symbol, location) : errorType;
-      },
-      getTypeOfSymbol,
-      getSymbolsOfParameterPropertyDeclaration: (parameterIn, parameterName) => {
-        const parameter = getParseTreeNode(parameterIn, isParameter);
-        if (parameter === void 0)
-          return Debug.fail("Cannot get symbols of a synthetic parameter that cannot be resolved to a parse-tree node.");
-        Debug.assert(isParameterPropertyDeclaration(parameter, parameter.parent));
-        return getSymbolsOfParameterPropertyDeclaration(parameter, escapeLeadingUnderscores(parameterName));
-      },
-      getDeclaredTypeOfSymbol,
-      getPropertiesOfType,
-      getPropertyOfType: (type, name) => getPropertyOfType(type, escapeLeadingUnderscores(name)),
-      getPrivateIdentifierPropertyOfType: (leftType, name, location) => {
-        const node = getParseTreeNode(location);
-        if (!node) {
-          return void 0;
-        }
-        const propName = escapeLeadingUnderscores(name);
-        const lexicallyScopedIdentifier = lookupSymbolForPrivateIdentifierDeclaration(propName, node);
-        return lexicallyScopedIdentifier ? getPrivateIdentifierPropertyOfType(leftType, lexicallyScopedIdentifier) : void 0;
-      },
-      getTypeOfPropertyOfType: (type, name) => getTypeOfPropertyOfType(type, escapeLeadingUnderscores(name)),
-      getIndexInfoOfType: (type, kind) => getIndexInfoOfType(type, kind === 0 /* String */ ? stringType : numberType),
-      getIndexInfosOfType,
-      getIndexInfosOfIndexSymbol,
-      getSignaturesOfType,
-      getIndexTypeOfType: (type, kind) => getIndexTypeOfType(type, kind === 0 /* String */ ? stringType : numberType),
-      getIndexType: (type) => getIndexType(type),
-      getBaseTypes,
-      getBaseTypeOfLiteralType,
-      getWidenedType,
-      getTypeFromTypeNode: (nodeIn) => {
-        const node = getParseTreeNode(nodeIn, isTypeNode);
-        return node ? getTypeFromTypeNode(node) : errorType;
-      },
-      getParameterType: getTypeAtPosition,
-      getParameterIdentifierNameAtPosition,
-      getPromisedTypeOfPromise,
-      getAwaitedType: (type) => getAwaitedType(type),
-      getReturnTypeOfSignature,
-      isNullableType,
-      getNullableType,
-      getNonNullableType,
-      getNonOptionalType: removeOptionalTypeMarker,
-      getTypeArguments,
-      typeToTypeNode: nodeBuilder.typeToTypeNode,
-      indexInfoToIndexSignatureDeclaration: nodeBuilder.indexInfoToIndexSignatureDeclaration,
-      signatureToSignatureDeclaration: nodeBuilder.signatureToSignatureDeclaration,
-      symbolToEntityName: nodeBuilder.symbolToEntityName,
-      symbolToExpression: nodeBuilder.symbolToExpression,
-      symbolToNode: nodeBuilder.symbolToNode,
-      symbolToTypeParameterDeclarations: nodeBuilder.symbolToTypeParameterDeclarations,
-      symbolToParameterDeclaration: nodeBuilder.symbolToParameterDeclaration,
-      typeParameterToDeclaration: nodeBuilder.typeParameterToDeclaration,
-      getSymbolsInScope: (locationIn, meaning) => {
-        const location = getParseTreeNode(locationIn);
-        return location ? getSymbolsInScope(location, meaning) : [];
-      },
-      getSymbolAtLocation: (nodeIn) => {
-        const node = getParseTreeNode(nodeIn);
-        return node ? getSymbolAtLocation(
-          node,
-          /*ignoreErrors*/
-          true
-        ) : void 0;
-      },
-      getIndexInfosAtLocation: (nodeIn) => {
-        const node = getParseTreeNode(nodeIn);
-        return node ? getIndexInfosAtLocation(node) : void 0;
-      },
-      getShorthandAssignmentValueSymbol: (nodeIn) => {
-        const node = getParseTreeNode(nodeIn);
-        return node ? getShorthandAssignmentValueSymbol(node) : void 0;
-      },
-      getExportSpecifierLocalTargetSymbol: (nodeIn) => {
-        const node = getParseTreeNode(nodeIn, isExportSpecifier);
-        return node ? getExportSpecifierLocalTargetSymbol(node) : void 0;
-      },
-      getExportSymbolOfSymbol(symbol) {
-        return getMergedSymbol(symbol.exportSymbol || symbol);
-      },
-      getTypeAtLocation: (nodeIn) => {
-        const node = getParseTreeNode(nodeIn);
-        return node ? getTypeOfNode(node) : errorType;
-      },
-      getTypeOfAssignmentPattern: (nodeIn) => {
-        const node = getParseTreeNode(nodeIn, isAssignmentPattern);
-        return node && getTypeOfAssignmentPattern(node) || errorType;
-      },
-      getPropertySymbolOfDestructuringAssignment: (locationIn) => {
-        const location = getParseTreeNode(locationIn, isIdentifier);
-        return location ? getPropertySymbolOfDestructuringAssignment(location) : void 0;
-      },
-      signatureToString: (signature, enclosingDeclaration, flags, kind) => {
-        return signatureToString(signature, getParseTreeNode(enclosingDeclaration), flags, kind);
-      },
-      typeToString: (type, enclosingDeclaration, flags) => {
-        return typeToString(type, getParseTreeNode(enclosingDeclaration), flags);
-      },
-      symbolToString: (symbol, enclosingDeclaration, meaning, flags) => {
-        return symbolToString(symbol, getParseTreeNode(enclosingDeclaration), meaning, flags);
-      },
-      typePredicateToString: (predicate, enclosingDeclaration, flags) => {
-        return typePredicateToString(predicate, getParseTreeNode(enclosingDeclaration), flags);
-      },
-      writeSignature: (signature, enclosingDeclaration, flags, kind, writer) => {
-        return signatureToString(signature, getParseTreeNode(enclosingDeclaration), flags, kind, writer);
-      },
-      writeType: (type, enclosingDeclaration, flags, writer) => {
-        return typeToString(type, getParseTreeNode(enclosingDeclaration), flags, writer);
-      },
-      writeSymbol: (symbol, enclosingDeclaration, meaning, flags, writer) => {
-        return symbolToString(symbol, getParseTreeNode(enclosingDeclaration), meaning, flags, writer);
-      },
-      writeTypePredicate: (predicate, enclosingDeclaration, flags, writer) => {
-        return typePredicateToString(predicate, getParseTreeNode(enclosingDeclaration), flags, writer);
-      },
-      getAugmentedPropertiesOfType,
-      getRootSymbols,
-      getSymbolOfExpando,
-      getContextualType: (nodeIn, contextFlags) => {
-        const node = getParseTreeNode(nodeIn, isExpression);
-        if (!node) {
-          return void 0;
-        }
-        if (contextFlags & 4 /* Completions */) {
-          return runWithInferenceBlockedFromSourceNode(node, () => getContextualType2(node, contextFlags));
-        }
-        return getContextualType2(node, contextFlags);
-      },
-      getContextualTypeForObjectLiteralElement: (nodeIn) => {
-        const node = getParseTreeNode(nodeIn, isObjectLiteralElementLike);
-        return node ? getContextualTypeForObjectLiteralElement(
-          node,
-          /*contextFlags*/
-          void 0
-        ) : void 0;
-      },
-      getContextualTypeForArgumentAtIndex: (nodeIn, argIndex) => {
-        const node = getParseTreeNode(nodeIn, isCallLikeExpression);
-        return node && getContextualTypeForArgumentAtIndex(node, argIndex);
-      },
-      getContextualTypeForJsxAttribute: (nodeIn) => {
-        const node = getParseTreeNode(nodeIn, isJsxAttributeLike);
-        return node && getContextualTypeForJsxAttribute(
-          node,
-          /*contextFlags*/
-          void 0
-        );
-      },
-      isContextSensitive,
-      getTypeOfPropertyOfContextualType,
-      getFullyQualifiedName,
-      getResolvedSignature: (node, candidatesOutArray, argumentCount) => getResolvedSignatureWorker(node, candidatesOutArray, argumentCount, 0 /* Normal */),
-      getResolvedSignatureForStringLiteralCompletions: (call, editingArgument, candidatesOutArray) => runWithInferenceBlockedFromSourceNode(editingArgument, () => getResolvedSignatureWorker(
-        call,
-        candidatesOutArray,
-        /*argumentCount*/
-        void 0,
-        32 /* IsForStringLiteralArgumentCompletions */
-      )),
-      getResolvedSignatureForSignatureHelp: (node, candidatesOutArray, argumentCount) => runWithoutResolvedSignatureCaching(node, () => getResolvedSignatureWorker(node, candidatesOutArray, argumentCount, 16 /* IsForSignatureHelp */)),
-      getExpandedParameters,
-      hasEffectiveRestParameter,
-      containsArgumentsReference,
-      getConstantValue: (nodeIn) => {
-        const node = getParseTreeNode(nodeIn, canHaveConstantValue);
-        return node ? getConstantValue2(node) : void 0;
-      },
-      isValidPropertyAccess: (nodeIn, propertyName) => {
-        const node = getParseTreeNode(nodeIn, isPropertyAccessOrQualifiedNameOrImportTypeNode);
-        return !!node && isValidPropertyAccess(node, escapeLeadingUnderscores(propertyName));
-      },
-      isValidPropertyAccessForCompletions: (nodeIn, type, property) => {
-        const node = getParseTreeNode(nodeIn, isPropertyAccessExpression);
-        return !!node && isValidPropertyAccessForCompletions(node, type, property);
-      },
-      getSignatureFromDeclaration: (declarationIn) => {
-        const declaration = getParseTreeNode(declarationIn, isFunctionLike);
-        return declaration ? getSignatureFromDeclaration(declaration) : void 0;
-      },
-      isImplementationOfOverload: (nodeIn) => {
-        const node = getParseTreeNode(nodeIn, isFunctionLike);
-        return node ? isImplementationOfOverload(node) : void 0;
-      },
-      getImmediateAliasedSymbol,
-      getAliasedSymbol: resolveAlias,
-      getEmitResolver,
-      getExportsOfModule: getExportsOfModuleAsArray,
-      getExportsAndPropertiesOfModule,
-      forEachExportAndPropertyOfModule,
-      getSymbolWalker: createGetSymbolWalker(
-        getRestTypeOfSignature,
-        getTypePredicateOfSignature,
-        getReturnTypeOfSignature,
-        getBaseTypes,
-        resolveStructuredTypeMembers,
-        getTypeOfSymbol,
-        getResolvedSymbol,
-        getConstraintOfTypeParameter,
-        getFirstIdentifier,
-        getTypeArguments
-      ),
-      getAmbientModules,
-      getJsxIntrinsicTagNamesAt,
-      isOptionalParameter: (nodeIn) => {
-        const node = getParseTreeNode(nodeIn, isParameter);
-        return node ? isOptionalParameter(node) : false;
-      },
-      tryGetMemberInModuleExports: (name, symbol) => tryGetMemberInModuleExports(escapeLeadingUnderscores(name), symbol),
-      tryGetMemberInModuleExportsAndProperties: (name, symbol) => tryGetMemberInModuleExportsAndProperties(escapeLeadingUnderscores(name), symbol),
-      tryFindAmbientModule: (moduleName) => tryFindAmbientModule(
-        moduleName,
-        /*withAugmentations*/
-        true
-      ),
-      tryFindAmbientModuleWithoutAugmentations: (moduleName) => {
-        return tryFindAmbientModule(
-          moduleName,
-          /*withAugmentations*/
-          false
-        );
-      },
-      getApparentType,
-      getUnionType,
-      isTypeAssignableTo,
-      createAnonymousType,
-      createSignature,
-      createSymbol,
-      createIndexInfo,
-      getAnyType: () => anyType,
-      getStringType: () => stringType,
-      getStringLiteralType,
-      getNumberType: () => numberType,
-      getNumberLiteralType,
-      getBigIntType: () => bigintType,
-      createPromiseType,
-      createArrayType,
-      getElementTypeOfArrayType,
-      getBooleanType: () => booleanType,
-      getFalseType: (fresh) => fresh ? falseType : regularFalseType,
-      getTrueType: (fresh) => fresh ? trueType : regularTrueType,
-      getVoidType: () => voidType,
-      getUndefinedType: () => undefinedType,
-      getNullType: () => nullType,
-      getESSymbolType: () => esSymbolType,
-      getNeverType: () => neverType,
-      getOptionalType: () => optionalType,
-      getPromiseType: () => getGlobalPromiseType(
-        /*reportErrors*/
-        false
-      ),
-      getPromiseLikeType: () => getGlobalPromiseLikeType(
-        /*reportErrors*/
-        false
-      ),
-      getAsyncIterableType: () => {
-        const type = getGlobalAsyncIterableType(
-          /*reportErrors*/
-          false
-        );
-        if (type === emptyGenericType)
-          return void 0;
-        return type;
-      },
-      isSymbolAccessible,
-      isArrayType,
-      isTupleType,
-      isArrayLikeType,
-      isEmptyAnonymousObjectType,
-      isTypeInvalidDueToUnionDiscriminant,
-      getExactOptionalProperties,
-      getAllPossiblePropertiesOfTypes,
-      getSuggestedSymbolForNonexistentProperty,
-      getSuggestionForNonexistentProperty,
-      getSuggestedSymbolForNonexistentJSXAttribute,
-      getSuggestedSymbolForNonexistentSymbol: (location, name, meaning) => getSuggestedSymbolForNonexistentSymbol(location, escapeLeadingUnderscores(name), meaning),
-      getSuggestionForNonexistentSymbol: (location, name, meaning) => getSuggestionForNonexistentSymbol(location, escapeLeadingUnderscores(name), meaning),
-      getSuggestedSymbolForNonexistentModule,
-      getSuggestionForNonexistentExport,
-      getSuggestedSymbolForNonexistentClassMember,
-      getBaseConstraintOfType,
-      getDefaultFromTypeParameter: (type) => type && type.flags & 262144 /* TypeParameter */ ? getDefaultFromTypeParameter(type) : void 0,
-      resolveName(name, location, meaning, excludeGlobals) {
-        return resolveName(
-          location,
-          escapeLeadingUnderscores(name),
-          meaning,
-          /*nameNotFoundMessage*/
-          void 0,
-          /*nameArg*/
-          void 0,
-          /*isUse*/
-          false,
-          excludeGlobals
-        );
-      },
-      getJsxNamespace: (n) => unescapeLeadingUnderscores(getJsxNamespace(n)),
-      getJsxFragmentFactory: (n) => {
-        const jsxFragmentFactory = getJsxFragmentFactoryEntity(n);
-        return jsxFragmentFactory && unescapeLeadingUnderscores(getFirstIdentifier(jsxFragmentFactory).escapedText);
-      },
-      getAccessibleSymbolChain,
-      getTypePredicateOfSignature,
-      resolveExternalModuleName: (moduleSpecifierIn) => {
-        const moduleSpecifier = getParseTreeNode(moduleSpecifierIn, isExpression);
-        return moduleSpecifier && resolveExternalModuleName(
-          moduleSpecifier,
-          moduleSpecifier,
-          /*ignoreErrors*/
-          true
-        );
-      },
-      resolveExternalModuleSymbol,
-      tryGetThisTypeAt: (nodeIn, includeGlobalThis, container) => {
-        const node = getParseTreeNode(nodeIn);
-        return node && tryGetThisTypeAt(node, includeGlobalThis, container);
-      },
-      getTypeArgumentConstraint: (nodeIn) => {
-        const node = getParseTreeNode(nodeIn, isTypeNode);
-        return node && getTypeArgumentConstraint(node);
-      },
-      getSuggestionDiagnostics: (fileIn, ct) => {
-        const file = getParseTreeNode(fileIn, isSourceFile) || Debug.fail("Could not determine parsed source file.");
-        if (skipTypeChecking(file, compilerOptions, host)) {
-          return emptyArray;
-        }
-        let diagnostics2;
-        try {
-          cancellationToken = ct;
-          checkSourceFileWithEagerDiagnostics(file);
-          Debug.assert(!!(getNodeLinks(file).flags & 1 /* TypeChecked */));
-          diagnostics2 = addRange(diagnostics2, suggestionDiagnostics.getDiagnostics(file.fileName));
-          checkUnusedIdentifiers(getPotentiallyUnusedIdentifiers(file), (containingNode, kind, diag2) => {
-            if (!containsParseError(containingNode) && !unusedIsError(kind, !!(containingNode.flags & 16777216 /* Ambient */))) {
-              (diagnostics2 || (diagnostics2 = [])).push({ ...diag2, category: 2 /* Suggestion */ });
-            }
-          });
-          return diagnostics2 || emptyArray;
-        } finally {
-          cancellationToken = void 0;
-        }
-      },
-      runWithCancellationToken: (token, callback) => {
-        try {
-          cancellationToken = token;
-          return callback(checker);
-        } finally {
-          cancellationToken = void 0;
-        }
-      },
-      getLocalTypeParametersOfClassOrInterfaceOrTypeAlias,
-      isDeclarationVisible,
-      isPropertyAccessible,
-      getTypeOnlyAliasDeclaration,
-      getMemberOverrideModifierStatus,
-      isTypeParameterPossiblyReferenced,
-      typeHasCallOrConstructSignatures
-    };
-    function runWithoutResolvedSignatureCaching(node, fn) {
-      const containingCall = findAncestor(node, isCallLikeExpression);
-      const containingCallResolvedSignature = containingCall && getNodeLinks(containingCall).resolvedSignature;
-      if (containingCall) {
-        getNodeLinks(containingCall).resolvedSignature = void 0;
-      }
-      const result = fn();
-      if (containingCall) {
-        getNodeLinks(containingCall).resolvedSignature = containingCallResolvedSignature;
-      }
-      return result;
-    }
-    function runWithInferenceBlockedFromSourceNode(node, fn) {
-      const containingCall = findAncestor(node, isCallLikeExpression);
-      if (containingCall) {
-        let toMarkSkip = node;
-        do {
-          getNodeLinks(toMarkSkip).skipDirectInference = true;
-          toMarkSkip = toMarkSkip.parent;
-        } while (toMarkSkip && toMarkSkip !== containingCall);
-      }
-      isInferencePartiallyBlocked = true;
-      const result = runWithoutResolvedSignatureCaching(node, fn);
-      isInferencePartiallyBlocked = false;
-      if (containingCall) {
-        let toMarkSkip = node;
-        do {
-          getNodeLinks(toMarkSkip).skipDirectInference = void 0;
-          toMarkSkip = toMarkSkip.parent;
-        } while (toMarkSkip && toMarkSkip !== containingCall);
-      }
-      return result;
-    }
-    function getResolvedSignatureWorker(nodeIn, candidatesOutArray, argumentCount, checkMode) {
-      const node = getParseTreeNode(nodeIn, isCallLikeExpression);
-      apparentArgumentCount = argumentCount;
-      const res = !node ? void 0 : getResolvedSignature(node, candidatesOutArray, checkMode);
-      apparentArgumentCount = void 0;
-      return res;
-    }
-    var tupleTypes = /* @__PURE__ */ new Map();
-    var unionTypes = /* @__PURE__ */ new Map();
-    var unionOfUnionTypes = /* @__PURE__ */ new Map();
-    var intersectionTypes = /* @__PURE__ */ new Map();
-    var stringLiteralTypes = /* @__PURE__ */ new Map();
-    var numberLiteralTypes = /* @__PURE__ */ new Map();
-    var bigIntLiteralTypes = /* @__PURE__ */ new Map();
-    var enumLiteralTypes = /* @__PURE__ */ new Map();
-    var indexedAccessTypes = /* @__PURE__ */ new Map();
-    var templateLiteralTypes = /* @__PURE__ */ new Map();
-    var stringMappingTypes = /* @__PURE__ */ new Map();
-    var substitutionTypes = /* @__PURE__ */ new Map();
-    var subtypeReductionCache = /* @__PURE__ */ new Map();
-    var decoratorContextOverrideTypeCache = /* @__PURE__ */ new Map();
-    var cachedTypes = /* @__PURE__ */ new Map();
-    var evolvingArrayTypes = [];
-    var undefinedProperties = /* @__PURE__ */ new Map();
-    var markerTypes = /* @__PURE__ */ new Set();
-    var unknownSymbol = createSymbol(4 /* Property */, "unknown");
-    var resolvingSymbol = createSymbol(0, "__resolving__" /* Resolving */);
-    var unresolvedSymbols = /* @__PURE__ */ new Map();
-    var errorTypes = /* @__PURE__ */ new Map();
-    var anyType = createIntrinsicType(1 /* Any */, "any");
-    var autoType = createIntrinsicType(1 /* Any */, "any", 262144 /* NonInferrableType */);
-    var wildcardType = createIntrinsicType(1 /* Any */, "any");
-    var errorType = createIntrinsicType(1 /* Any */, "error");
-    var unresolvedType = createIntrinsicType(1 /* Any */, "unresolved");
-    var nonInferrableAnyType = createIntrinsicType(1 /* Any */, "any", 65536 /* ContainsWideningType */);
-    var intrinsicMarkerType = createIntrinsicType(1 /* Any */, "intrinsic");
-    var unknownType = createIntrinsicType(2 /* Unknown */, "unknown");
-    var nonNullUnknownType = createIntrinsicType(2 /* Unknown */, "unknown");
-    var undefinedType = createIntrinsicType(32768 /* Undefined */, "undefined");
-    var undefinedWideningType = strictNullChecks ? undefinedType : createIntrinsicType(32768 /* Undefined */, "undefined", 65536 /* ContainsWideningType */);
-    var missingType = createIntrinsicType(32768 /* Undefined */, "undefined");
-    var undefinedOrMissingType = exactOptionalPropertyTypes ? missingType : undefinedType;
-    var optionalType = createIntrinsicType(32768 /* Undefined */, "undefined");
-    var nullType = createIntrinsicType(65536 /* Null */, "null");
-    var nullWideningType = strictNullChecks ? nullType : createIntrinsicType(65536 /* Null */, "null", 65536 /* ContainsWideningType */);
-    var stringType = createIntrinsicType(4 /* String */, "string");
-    var numberType = createIntrinsicType(8 /* Number */, "number");
-    var bigintType = createIntrinsicType(64 /* BigInt */, "bigint");
-    var falseType = createIntrinsicType(512 /* BooleanLiteral */, "false");
-    var regularFalseType = createIntrinsicType(512 /* BooleanLiteral */, "false");
-    var trueType = createIntrinsicType(512 /* BooleanLiteral */, "true");
-    var regularTrueType = createIntrinsicType(512 /* BooleanLiteral */, "true");
-    trueType.regularType = regularTrueType;
-    trueType.freshType = trueType;
-    regularTrueType.regularType = regularTrueType;
-    regularTrueType.freshType = trueType;
-    falseType.regularType = regularFalseType;
-    falseType.freshType = falseType;
-    regularFalseType.regularType = regularFalseType;
-    regularFalseType.freshType = falseType;
-    var booleanType = getUnionType([regularFalseType, regularTrueType]);
-    var esSymbolType = createIntrinsicType(4096 /* ESSymbol */, "symbol");
-    var voidType = createIntrinsicType(16384 /* Void */, "void");
-    var neverType = createIntrinsicType(131072 /* Never */, "never");
-    var silentNeverType = createIntrinsicType(131072 /* Never */, "never", 262144 /* NonInferrableType */);
-    var implicitNeverType = createIntrinsicType(131072 /* Never */, "never");
-    var unreachableNeverType = createIntrinsicType(131072 /* Never */, "never");
-    var nonPrimitiveType = createIntrinsicType(67108864 /* NonPrimitive */, "object");
-    var stringOrNumberType = getUnionType([stringType, numberType]);
-    var stringNumberSymbolType = getUnionType([stringType, numberType, esSymbolType]);
-    var keyofConstraintType = keyofStringsOnly ? stringType : stringNumberSymbolType;
-    var numberOrBigIntType = getUnionType([numberType, bigintType]);
-    var templateConstraintType = getUnionType([stringType, numberType, booleanType, bigintType, nullType, undefinedType]);
-    var numericStringType = getTemplateLiteralType(["", ""], [numberType]);
-    var restrictiveMapper = makeFunctionTypeMapper((t) => t.flags & 262144 /* TypeParameter */ ? getRestrictiveTypeParameter(t) : t, () => "(restrictive mapper)");
-    var permissiveMapper = makeFunctionTypeMapper((t) => t.flags & 262144 /* TypeParameter */ ? wildcardType : t, () => "(permissive mapper)");
-    var uniqueLiteralType = createIntrinsicType(131072 /* Never */, "never");
-    var uniqueLiteralMapper = makeFunctionTypeMapper((t) => t.flags & 262144 /* TypeParameter */ ? uniqueLiteralType : t, () => "(unique literal mapper)");
-    var outofbandVarianceMarkerHandler;
-    var reportUnreliableMapper = makeFunctionTypeMapper((t) => {
-      if (outofbandVarianceMarkerHandler && (t === markerSuperType || t === markerSubType || t === markerOtherType)) {
-        outofbandVarianceMarkerHandler(
-          /*onlyUnreliable*/
-          true
-        );
-      }
-      return t;
-    }, () => "(unmeasurable reporter)");
-    var reportUnmeasurableMapper = makeFunctionTypeMapper((t) => {
-      if (outofbandVarianceMarkerHandler && (t === markerSuperType || t === markerSubType || t === markerOtherType)) {
-        outofbandVarianceMarkerHandler(
-          /*onlyUnreliable*/
-          false
-        );
-      }
-      return t;
-    }, () => "(unreliable reporter)");
-    var emptyObjectType = createAnonymousType(
-      /*symbol*/
-      void 0,
-      emptySymbols,
-      emptyArray,
-      emptyArray,
-      emptyArray
-    );
-    var emptyJsxObjectType = createAnonymousType(
-      /*symbol*/
-      void 0,
-      emptySymbols,
-      emptyArray,
-      emptyArray,
-      emptyArray
-    );
-    emptyJsxObjectType.objectFlags |= 2048 /* JsxAttributes */;
-    var emptyTypeLiteralSymbol = createSymbol(2048 /* TypeLiteral */, "__type" /* Type */);
-    emptyTypeLiteralSymbol.members = createSymbolTable();
-    var emptyTypeLiteralType = createAnonymousType(emptyTypeLiteralSymbol, emptySymbols, emptyArray, emptyArray, emptyArray);
-    var unknownEmptyObjectType = createAnonymousType(
-      /*symbol*/
-      void 0,
-      emptySymbols,
-      emptyArray,
-      emptyArray,
-      emptyArray
-    );
-    var unknownUnionType = strictNullChecks ? getUnionType([undefinedType, nullType, unknownEmptyObjectType]) : unknownType;
-    var emptyGenericType = createAnonymousType(
-      /*symbol*/
-      void 0,
-      emptySymbols,
-      emptyArray,
-      emptyArray,
-      emptyArray
-    );
-    emptyGenericType.instantiations = /* @__PURE__ */ new Map();
-    var anyFunctionType = createAnonymousType(
-      /*symbol*/
-      void 0,
-      emptySymbols,
-      emptyArray,
-      emptyArray,
-      emptyArray
-    );
-    anyFunctionType.objectFlags |= 262144 /* NonInferrableType */;
-    var noConstraintType = createAnonymousType(
-      /*symbol*/
-      void 0,
-      emptySymbols,
-      emptyArray,
-      emptyArray,
-      emptyArray
-    );
-    var circularConstraintType = createAnonymousType(
-      /*symbol*/
-      void 0,
-      emptySymbols,
-      emptyArray,
-      emptyArray,
-      emptyArray
-    );
-    var resolvingDefaultType = createAnonymousType(
-      /*symbol*/
-      void 0,
-      emptySymbols,
-      emptyArray,
-      emptyArray,
-      emptyArray
-    );
-    var markerSuperType = createTypeParameter();
-    var markerSubType = createTypeParameter();
-    markerSubType.constraint = markerSuperType;
-    var markerOtherType = createTypeParameter();
-    var markerSuperTypeForCheck = createTypeParameter();
-    var markerSubTypeForCheck = createTypeParameter();
-    markerSubTypeForCheck.constraint = markerSuperTypeForCheck;
-    var noTypePredicate = createTypePredicate(1 /* Identifier */, "<>", 0, anyType);
-    var anySignature = createSignature(
-      /*declaration*/
-      void 0,
-      /*typeParameters*/
-      void 0,
-      /*thisParameter*/
-      void 0,
-      emptyArray,
-      anyType,
-      /*resolvedTypePredicate*/
-      void 0,
-      0,
-      0 /* None */
-    );
-    var unknownSignature = createSignature(
-      /*declaration*/
-      void 0,
-      /*typeParameters*/
-      void 0,
-      /*thisParameter*/
-      void 0,
-      emptyArray,
-      errorType,
-      /*resolvedTypePredicate*/
-      void 0,
-      0,
-      0 /* None */
-    );
-    var resolvingSignature = createSignature(
-      /*declaration*/
-      void 0,
-      /*typeParameters*/
-      void 0,
-      /*thisParameter*/
-      void 0,
-      emptyArray,
-      anyType,
-      /*resolvedTypePredicate*/
-      void 0,
-      0,
-      0 /* None */
-    );
-    var silentNeverSignature = createSignature(
-      /*declaration*/
-      void 0,
-      /*typeParameters*/
-      void 0,
-      /*thisParameter*/
-      void 0,
-      emptyArray,
-      silentNeverType,
-      /*resolvedTypePredicate*/
-      void 0,
-      0,
-      0 /* None */
-    );
-    var enumNumberIndexInfo = createIndexInfo(
-      numberType,
-      stringType,
-      /*isReadonly*/
-      true
-    );
-    var iterationTypesCache = /* @__PURE__ */ new Map();
-    var noIterationTypes = {
-      get yieldType() {
-        return Debug.fail("Not supported");
-      },
-      get returnType() {
-        return Debug.fail("Not supported");
-      },
-      get nextType() {
-        return Debug.fail("Not supported");
-      }
-    };
-    var anyIterationTypes = createIterationTypes(anyType, anyType, anyType);
-    var anyIterationTypesExceptNext = createIterationTypes(anyType, anyType, unknownType);
-    var defaultIterationTypes = createIterationTypes(neverType, anyType, undefinedType);
-    var asyncIterationTypesResolver = {
-      iterableCacheKey: "iterationTypesOfAsyncIterable",
-      iteratorCacheKey: "iterationTypesOfAsyncIterator",
-      iteratorSymbolName: "asyncIterator",
-      getGlobalIteratorType: getGlobalAsyncIteratorType,
-      getGlobalIterableType: getGlobalAsyncIterableType,
-      getGlobalIterableIteratorType: getGlobalAsyncIterableIteratorType,
-      getGlobalGeneratorType: getGlobalAsyncGeneratorType,
-      resolveIterationType: (type, errorNode) => getAwaitedType(type, errorNode, Diagnostics.Type_of_await_operand_must_either_be_a_valid_promise_or_must_not_contain_a_callable_then_member),
-      mustHaveANextMethodDiagnostic: Diagnostics.An_async_iterator_must_have_a_next_method,
-      mustBeAMethodDiagnostic: Diagnostics.The_0_property_of_an_async_iterator_must_be_a_method,
-      mustHaveAValueDiagnostic: Diagnostics.The_type_returned_by_the_0_method_of_an_async_iterator_must_be_a_promise_for_a_type_with_a_value_property
-    };
-    var syncIterationTypesResolver = {
-      iterableCacheKey: "iterationTypesOfIterable",
-      iteratorCacheKey: "iterationTypesOfIterator",
-      iteratorSymbolName: "iterator",
-      getGlobalIteratorType,
-      getGlobalIterableType,
-      getGlobalIterableIteratorType,
-      getGlobalGeneratorType,
-      resolveIterationType: (type, _errorNode) => type,
-      mustHaveANextMethodDiagnostic: Diagnostics.An_iterator_must_have_a_next_method,
-      mustBeAMethodDiagnostic: Diagnostics.The_0_property_of_an_iterator_must_be_a_method,
-      mustHaveAValueDiagnostic: Diagnostics.The_type_returned_by_the_0_method_of_an_iterator_must_have_a_value_property
-    };
-    var amalgamatedDuplicates;
-    var reverseMappedCache = /* @__PURE__ */ new Map();
-    var inInferTypeForHomomorphicMappedType = false;
-    var ambientModulesCache;
-    var patternAmbientModules;
-    var patternAmbientModuleAugmentations;
-    var globalObjectType;
-    var globalFunctionType;
-    var globalCallableFunctionType;
-    var globalNewableFunctionType;
-    var globalArrayType;
-    var globalReadonlyArrayType;
-    var globalStringType;
-    var globalNumberType;
-    var globalBooleanType;
-    var globalRegExpType;
-    var globalThisType;
-    var anyArrayType;
-    var autoArrayType;
-    var anyReadonlyArrayType;
-    var deferredGlobalNonNullableTypeAlias;
-    var deferredGlobalESSymbolConstructorSymbol;
-    var deferredGlobalESSymbolConstructorTypeSymbol;
-    var deferredGlobalESSymbolType;
-    var deferredGlobalTypedPropertyDescriptorType;
-    var deferredGlobalPromiseType;
-    var deferredGlobalPromiseLikeType;
-    var deferredGlobalPromiseConstructorSymbol;
-    var deferredGlobalPromiseConstructorLikeType;
-    var deferredGlobalIterableType;
-    var deferredGlobalIteratorType;
-    var deferredGlobalIterableIteratorType;
-    var deferredGlobalGeneratorType;
-    var deferredGlobalIteratorYieldResultType;
-    var deferredGlobalIteratorReturnResultType;
-    var deferredGlobalAsyncIterableType;
-    var deferredGlobalAsyncIteratorType;
-    var deferredGlobalAsyncIterableIteratorType;
-    var deferredGlobalAsyncGeneratorType;
-    var deferredGlobalTemplateStringsArrayType;
-    var deferredGlobalImportMetaType;
-    var deferredGlobalImportMetaExpressionType;
-    var deferredGlobalImportCallOptionsType;
-    var deferredGlobalExtractSymbol;
-    var deferredGlobalOmitSymbol;
-    var deferredGlobalAwaitedSymbol;
-    var deferredGlobalBigIntType;
-    var deferredGlobalNaNSymbol;
-    var deferredGlobalRecordSymbol;
-    var deferredGlobalClassDecoratorContextType;
-    var deferredGlobalClassMethodDecoratorContextType;
-    var deferredGlobalClassGetterDecoratorContextType;
-    var deferredGlobalClassSetterDecoratorContextType;
-    var deferredGlobalClassAccessorDecoratorContextType;
-    var deferredGlobalClassAccessorDecoratorTargetType;
-    var deferredGlobalClassAccessorDecoratorResultType;
-    var deferredGlobalClassFieldDecoratorContextType;
-    var allPotentiallyUnusedIdentifiers = /* @__PURE__ */ new Map();
-    var flowLoopStart = 0;
-    var flowLoopCount = 0;
-    var sharedFlowCount = 0;
-    var flowAnalysisDisabled = false;
-    var flowInvocationCount = 0;
-    var lastFlowNode;
-    var lastFlowNodeReachable;
-    var flowTypeCache;
-    var contextualTypeNodes = [];
-    var contextualTypes = [];
-    var contextualIsCache = [];
-    var contextualTypeCount = 0;
-    var inferenceContextNodes = [];
-    var inferenceContexts = [];
-    var inferenceContextCount = 0;
-    var emptyStringType = getStringLiteralType("");
-    var zeroType = getNumberLiteralType(0);
-    var zeroBigIntType = getBigIntLiteralType({ negative: false, base10Value: "0" });
-    var resolutionTargets = [];
-    var resolutionResults = [];
-    var resolutionPropertyNames = [];
-    var resolutionStart = 0;
-    var inVarianceComputation = false;
-    var suggestionCount = 0;
-    var maximumSuggestionCount = 10;
-    var mergedSymbols = [];
-    var symbolLinks = [];
-    var nodeLinks = [];
-    var flowLoopCaches = [];
-    var flowLoopNodes = [];
-    var flowLoopKeys = [];
-    var flowLoopTypes = [];
-    var sharedFlowNodes = [];
-    var sharedFlowTypes = [];
-    var flowNodeReachable = [];
-    var flowNodePostSuper = [];
-    var potentialThisCollisions = [];
-    var potentialNewTargetCollisions = [];
-    var potentialWeakMapSetCollisions = [];
-    var potentialReflectCollisions = [];
-    var potentialUnusedRenamedBindingElementsInTypes = [];
-    var awaitedTypeStack = [];
-    var diagnostics = createDiagnosticCollection();
-    var suggestionDiagnostics = createDiagnosticCollection();
-    var typeofType = createTypeofType();
-    var _jsxNamespace;
-    var _jsxFactoryEntity;
-    var subtypeRelation = /* @__PURE__ */ new Map();
-    var strictSubtypeRelation = /* @__PURE__ */ new Map();
-    var assignableRelation = /* @__PURE__ */ new Map();
-    var comparableRelation = /* @__PURE__ */ new Map();
-    var identityRelation = /* @__PURE__ */ new Map();
-    var enumRelation = /* @__PURE__ */ new Map();
-    var builtinGlobals = createSymbolTable();
-    builtinGlobals.set(undefinedSymbol.escapedName, undefinedSymbol);
-    var suggestedExtensions = [
-      [".mts", ".mjs"],
-      [".ts", ".js"],
-      [".cts", ".cjs"],
-      [".mjs", ".mjs"],
-      [".js", ".js"],
-      [".cjs", ".cjs"],
-      [".tsx", compilerOptions.jsx === 1 /* Preserve */ ? ".jsx" : ".js"],
-      [".jsx", ".jsx"],
-      [".json", ".json"]
-    ];
-    initializeTypeChecker();
-    return checker;
-    function getCachedType(key) {
-      return key ? cachedTypes.get(key) : void 0;
-    }
-    function setCachedType(key, type) {
-      if (key)
-        cachedTypes.set(key, type);
-      return type;
-    }
-    function getJsxNamespace(location) {
-      if (location) {
-        const file = getSourceFileOfNode(location);
-        if (file) {
-          if (isJsxOpeningFragment(location)) {
-            if (file.localJsxFragmentNamespace) {
-              return file.localJsxFragmentNamespace;
-            }
-            const jsxFragmentPragma = file.pragmas.get("jsxfrag");
-            if (jsxFragmentPragma) {
-              const chosenPragma = isArray(jsxFragmentPragma) ? jsxFragmentPragma[0] : jsxFragmentPragma;
-              file.localJsxFragmentFactory = parseIsolatedEntityName(chosenPragma.arguments.factory, languageVersion);
-              visitNode(file.localJsxFragmentFactory, markAsSynthetic, isEntityName);
-              if (file.localJsxFragmentFactory) {
-                return file.localJsxFragmentNamespace = getFirstIdentifier(file.localJsxFragmentFactory).escapedText;
-              }
-            }
-            const entity = getJsxFragmentFactoryEntity(location);
-            if (entity) {
-              file.localJsxFragmentFactory = entity;
-              return file.localJsxFragmentNamespace = getFirstIdentifier(entity).escapedText;
-            }
-          } else {
-            const localJsxNamespace = getLocalJsxNamespace(file);
-            if (localJsxNamespace) {
-              return file.localJsxNamespace = localJsxNamespace;
-            }
-          }
-        }
-      }
-      if (!_jsxNamespace) {
-        _jsxNamespace = "React";
-        if (compilerOptions.jsxFactory) {
-          _jsxFactoryEntity = parseIsolatedEntityName(compilerOptions.jsxFactory, languageVersion);
-          visitNode(_jsxFactoryEntity, markAsSynthetic);
-          if (_jsxFactoryEntity) {
-            _jsxNamespace = getFirstIdentifier(_jsxFactoryEntity).escapedText;
-          }
-        } else if (compilerOptions.reactNamespace) {
-          _jsxNamespace = escapeLeadingUnderscores(compilerOptions.reactNamespace);
-        }
-      }
-      if (!_jsxFactoryEntity) {
-        _jsxFactoryEntity = factory.createQualifiedName(factory.createIdentifier(unescapeLeadingUnderscores(_jsxNamespace)), "createElement");
-      }
-      return _jsxNamespace;
-    }
-    function getLocalJsxNamespace(file) {
-      if (file.localJsxNamespace) {
-        return file.localJsxNamespace;
-      }
-      const jsxPragma = file.pragmas.get("jsx");
-      if (jsxPragma) {
-        const chosenPragma = isArray(jsxPragma) ? jsxPragma[0] : jsxPragma;
-        file.localJsxFactory = parseIsolatedEntityName(chosenPragma.arguments.factory, languageVersion);
-        visitNode(file.localJsxFactory, markAsSynthetic, isEntityName);
-        if (file.localJsxFactory) {
-          return file.localJsxNamespace = getFirstIdentifier(file.localJsxFactory).escapedText;
-        }
-      }
-    }
-    function markAsSynthetic(node) {
-      setTextRangePosEnd(node, -1, -1);
-      return visitEachChild(node, markAsSynthetic, nullTransformationContext);
-    }
-    function getEmitResolver(sourceFile, cancellationToken2) {
-      getDiagnostics2(sourceFile, cancellationToken2);
-      return emitResolver;
-    }
-    function lookupOrIssueError(location, message, ...args) {
-      const diagnostic = location ? createDiagnosticForNode(location, message, ...args) : createCompilerDiagnostic(message, ...args);
-      const existing = diagnostics.lookup(diagnostic);
-      if (existing) {
-        return existing;
-      } else {
-        diagnostics.add(diagnostic);
-        return diagnostic;
-      }
-    }
-    function errorSkippedOn(key, location, message, ...args) {
-      const diagnostic = error(location, message, ...args);
-      diagnostic.skippedOn = key;
-      return diagnostic;
-    }
-    function createError(location, message, ...args) {
-      return location ? createDiagnosticForNode(location, message, ...args) : createCompilerDiagnostic(message, ...args);
-    }
-    function error(location, message, ...args) {
-      const diagnostic = createError(location, message, ...args);
-      diagnostics.add(diagnostic);
-      return diagnostic;
-    }
-    function addErrorOrSuggestion(isError, diagnostic) {
-      if (isError) {
-        diagnostics.add(diagnostic);
-      } else {
-        suggestionDiagnostics.add({ ...diagnostic, category: 2 /* Suggestion */ });
-      }
-    }
-    function errorOrSuggestion(isError, location, message, ...args) {
-      if (location.pos < 0 || location.end < 0) {
-        if (!isError) {
-          return;
-        }
-        const file = getSourceFileOfNode(location);
-        addErrorOrSuggestion(isError, "message" in message ? createFileDiagnostic(file, 0, 0, message, ...args) : createDiagnosticForFileFromMessageChain(file, message));
-        return;
-      }
-      addErrorOrSuggestion(isError, "message" in message ? createDiagnosticForNode(location, message, ...args) : createDiagnosticForNodeFromMessageChain(getSourceFileOfNode(location), location, message));
-    }
-    function errorAndMaybeSuggestAwait(location, maybeMissingAwait, message, ...args) {
-      const diagnostic = error(location, message, ...args);
-      if (maybeMissingAwait) {
-        const related = createDiagnosticForNode(location, Diagnostics.Did_you_forget_to_use_await);
-        addRelatedInfo(diagnostic, related);
-      }
-      return diagnostic;
-    }
-    function addDeprecatedSuggestionWorker(declarations, diagnostic) {
-      const deprecatedTag = Array.isArray(declarations) ? forEach(declarations, getJSDocDeprecatedTag) : getJSDocDeprecatedTag(declarations);
-      if (deprecatedTag) {
-        addRelatedInfo(
-          diagnostic,
-          createDiagnosticForNode(deprecatedTag, Diagnostics.The_declaration_was_marked_as_deprecated_here)
-        );
-      }
-      suggestionDiagnostics.add(diagnostic);
-      return diagnostic;
-    }
-    function isDeprecatedSymbol(symbol) {
-      const parentSymbol = getParentOfSymbol(symbol);
-      if (parentSymbol && length(symbol.declarations) > 1) {
-        return parentSymbol.flags & 64 /* Interface */ ? some(symbol.declarations, isDeprecatedDeclaration2) : every(symbol.declarations, isDeprecatedDeclaration2);
-      }
-      return !!symbol.valueDeclaration && isDeprecatedDeclaration2(symbol.valueDeclaration) || length(symbol.declarations) && every(symbol.declarations, isDeprecatedDeclaration2);
-    }
-    function isDeprecatedDeclaration2(declaration) {
-      return !!(getCombinedNodeFlags(declaration) & 268435456 /* Deprecated */);
-    }
-    function addDeprecatedSuggestion(location, declarations, deprecatedEntity) {
-      const diagnostic = createDiagnosticForNode(location, Diagnostics._0_is_deprecated, deprecatedEntity);
-      return addDeprecatedSuggestionWorker(declarations, diagnostic);
-    }
-    function addDeprecatedSuggestionWithSignature(location, declaration, deprecatedEntity, signatureString) {
-      const diagnostic = deprecatedEntity ? createDiagnosticForNode(location, Diagnostics.The_signature_0_of_1_is_deprecated, signatureString, deprecatedEntity) : createDiagnosticForNode(location, Diagnostics._0_is_deprecated, signatureString);
-      return addDeprecatedSuggestionWorker(declaration, diagnostic);
-    }
-    function createSymbol(flags, name, checkFlags) {
-      symbolCount++;
-      const symbol = new Symbol47(flags | 33554432 /* Transient */, name);
-      symbol.links = new SymbolLinks();
-      symbol.links.checkFlags = checkFlags || 0 /* None */;
-      return symbol;
-    }
-    function createParameter(name, type) {
-      const symbol = createSymbol(1 /* FunctionScopedVariable */, name);
-      symbol.links.type = type;
-      return symbol;
-    }
-    function createProperty(name, type) {
-      const symbol = createSymbol(4 /* Property */, name);
-      symbol.links.type = type;
-      return symbol;
-    }
-    function getExcludedSymbolFlags(flags) {
-      let result = 0;
-      if (flags & 2 /* BlockScopedVariable */)
-        result |= 111551 /* BlockScopedVariableExcludes */;
-      if (flags & 1 /* FunctionScopedVariable */)
-        result |= 111550 /* FunctionScopedVariableExcludes */;
-      if (flags & 4 /* Property */)
-        result |= 0 /* PropertyExcludes */;
-      if (flags & 8 /* EnumMember */)
-        result |= 900095 /* EnumMemberExcludes */;
-      if (flags & 16 /* Function */)
-        result |= 110991 /* FunctionExcludes */;
-      if (flags & 32 /* Class */)
-        result |= 899503 /* ClassExcludes */;
-      if (flags & 64 /* Interface */)
-        result |= 788872 /* InterfaceExcludes */;
-      if (flags & 256 /* RegularEnum */)
-        result |= 899327 /* RegularEnumExcludes */;
-      if (flags & 128 /* ConstEnum */)
-        result |= 899967 /* ConstEnumExcludes */;
-      if (flags & 512 /* ValueModule */)
-        result |= 110735 /* ValueModuleExcludes */;
-      if (flags & 8192 /* Method */)
-        result |= 103359 /* MethodExcludes */;
-      if (flags & 32768 /* GetAccessor */)
-        result |= 46015 /* GetAccessorExcludes */;
-      if (flags & 65536 /* SetAccessor */)
-        result |= 78783 /* SetAccessorExcludes */;
-      if (flags & 262144 /* TypeParameter */)
-        result |= 526824 /* TypeParameterExcludes */;
-      if (flags & 524288 /* TypeAlias */)
-        result |= 788968 /* TypeAliasExcludes */;
-      if (flags & 2097152 /* Alias */)
-        result |= 2097152 /* AliasExcludes */;
-      return result;
-    }
-    function recordMergedSymbol(target, source) {
-      if (!source.mergeId) {
-        source.mergeId = nextMergeId;
-        nextMergeId++;
-      }
-      mergedSymbols[source.mergeId] = target;
-    }
-    function cloneSymbol(symbol) {
-      const result = createSymbol(symbol.flags, symbol.escapedName);
-      result.declarations = symbol.declarations ? symbol.declarations.slice() : [];
-      result.parent = symbol.parent;
-      if (symbol.valueDeclaration)
-        result.valueDeclaration = symbol.valueDeclaration;
-      if (symbol.constEnumOnlyModule)
-        result.constEnumOnlyModule = true;
-      if (symbol.members)
-        result.members = new Map(symbol.members);
-      if (symbol.exports)
-        result.exports = new Map(symbol.exports);
-      recordMergedSymbol(result, symbol);
-      return result;
-    }
-    function mergeSymbol(target, source, unidirectional = false) {
-      if (!(target.flags & getExcludedSymbolFlags(source.flags)) || (source.flags | target.flags) & 67108864 /* Assignment */) {
-        if (source === target) {
-          return target;
-        }
-        if (!(target.flags & 33554432 /* Transient */)) {
-          const resolvedTarget = resolveSymbol(target);
-          if (resolvedTarget === unknownSymbol) {
-            return source;
-          }
-          target = cloneSymbol(resolvedTarget);
-        }
-        if (source.flags & 512 /* ValueModule */ && target.flags & 512 /* ValueModule */ && target.constEnumOnlyModule && !source.constEnumOnlyModule) {
-          target.constEnumOnlyModule = false;
-        }
-        target.flags |= source.flags;
-        if (source.valueDeclaration) {
-          setValueDeclaration(target, source.valueDeclaration);
-        }
-        addRange(target.declarations, source.declarations);
-        if (source.members) {
-          if (!target.members)
-            target.members = createSymbolTable();
-          mergeSymbolTable(target.members, source.members, unidirectional);
-        }
-        if (source.exports) {
-          if (!target.exports)
-            target.exports = createSymbolTable();
-          mergeSymbolTable(target.exports, source.exports, unidirectional);
-        }
-        if (!unidirectional) {
-          recordMergedSymbol(target, source);
-        }
-      } else if (target.flags & 1024 /* NamespaceModule */) {
-        if (target !== globalThisSymbol) {
-          error(
-            source.declarations && getNameOfDeclaration(source.declarations[0]),
-            Diagnostics.Cannot_augment_module_0_with_value_exports_because_it_resolves_to_a_non_module_entity,
-            symbolToString(target)
-          );
-        }
-      } else {
-        const isEitherEnum = !!(target.flags & 384 /* Enum */ || source.flags & 384 /* Enum */);
-        const isEitherBlockScoped = !!(target.flags & 2 /* BlockScopedVariable */ || source.flags & 2 /* BlockScopedVariable */);
-        const message = isEitherEnum ? Diagnostics.Enum_declarations_can_only_merge_with_namespace_or_other_enum_declarations : isEitherBlockScoped ? Diagnostics.Cannot_redeclare_block_scoped_variable_0 : Diagnostics.Duplicate_identifier_0;
-        const sourceSymbolFile = source.declarations && getSourceFileOfNode(source.declarations[0]);
-        const targetSymbolFile = target.declarations && getSourceFileOfNode(target.declarations[0]);
-        const isSourcePlainJs = isPlainJsFile(sourceSymbolFile, compilerOptions.checkJs);
-        const isTargetPlainJs = isPlainJsFile(targetSymbolFile, compilerOptions.checkJs);
-        const symbolName2 = symbolToString(source);
-        if (sourceSymbolFile && targetSymbolFile && amalgamatedDuplicates && !isEitherEnum && sourceSymbolFile !== targetSymbolFile) {
-          const firstFile = comparePaths(sourceSymbolFile.path, targetSymbolFile.path) === -1 /* LessThan */ ? sourceSymbolFile : targetSymbolFile;
-          const secondFile = firstFile === sourceSymbolFile ? targetSymbolFile : sourceSymbolFile;
-          const filesDuplicates = getOrUpdate(amalgamatedDuplicates, `${firstFile.path}|${secondFile.path}`, () => ({ firstFile, secondFile, conflictingSymbols: /* @__PURE__ */ new Map() }));
-          const conflictingSymbolInfo = getOrUpdate(filesDuplicates.conflictingSymbols, symbolName2, () => ({ isBlockScoped: isEitherBlockScoped, firstFileLocations: [], secondFileLocations: [] }));
-          if (!isSourcePlainJs)
-            addDuplicateLocations(conflictingSymbolInfo.firstFileLocations, source);
-          if (!isTargetPlainJs)
-            addDuplicateLocations(conflictingSymbolInfo.secondFileLocations, target);
-        } else {
-          if (!isSourcePlainJs)
-            addDuplicateDeclarationErrorsForSymbols(source, message, symbolName2, target);
-          if (!isTargetPlainJs)
-            addDuplicateDeclarationErrorsForSymbols(target, message, symbolName2, source);
-        }
-      }
-      return target;
-      function addDuplicateLocations(locs, symbol) {
-        if (symbol.declarations) {
-          for (const decl of symbol.declarations) {
-            pushIfUnique(locs, decl);
-          }
-        }
-      }
-    }
-    function addDuplicateDeclarationErrorsForSymbols(target, message, symbolName2, source) {
-      forEach(target.declarations, (node) => {
-        addDuplicateDeclarationError(node, message, symbolName2, source.declarations);
-      });
-    }
-    function addDuplicateDeclarationError(node, message, symbolName2, relatedNodes) {
-      const errorNode = (getExpandoInitializer(
-        node,
-        /*isPrototypeAssignment*/
-        false
-      ) ? getNameOfExpando(node) : getNameOfDeclaration(node)) || node;
-      const err = lookupOrIssueError(errorNode, message, symbolName2);
-      for (const relatedNode of relatedNodes || emptyArray) {
-        const adjustedNode = (getExpandoInitializer(
-          relatedNode,
-          /*isPrototypeAssignment*/
-          false
-        ) ? getNameOfExpando(relatedNode) : getNameOfDeclaration(relatedNode)) || relatedNode;
-        if (adjustedNode === errorNode)
-          continue;
-        err.relatedInformation = err.relatedInformation || [];
-        const leadingMessage = createDiagnosticForNode(adjustedNode, Diagnostics._0_was_also_declared_here, symbolName2);
-        const followOnMessage = createDiagnosticForNode(adjustedNode, Diagnostics.and_here);
-        if (length(err.relatedInformation) >= 5 || some(err.relatedInformation, (r) => compareDiagnostics(r, followOnMessage) === 0 /* EqualTo */ || compareDiagnostics(r, leadingMessage) === 0 /* EqualTo */))
-          continue;
-        addRelatedInfo(err, !length(err.relatedInformation) ? leadingMessage : followOnMessage);
-      }
-    }
-    function combineSymbolTables(first2, second) {
-      if (!(first2 == null ? void 0 : first2.size))
-        return second;
-      if (!(second == null ? void 0 : second.size))
-        return first2;
-      const combined = createSymbolTable();
-      mergeSymbolTable(combined, first2);
-      mergeSymbolTable(combined, second);
-      return combined;
-    }
-    function mergeSymbolTable(target, source, unidirectional = false) {
-      source.forEach((sourceSymbol, id) => {
-        const targetSymbol = target.get(id);
-        target.set(id, targetSymbol ? mergeSymbol(targetSymbol, sourceSymbol, unidirectional) : getMergedSymbol(sourceSymbol));
-      });
-    }
-    function mergeModuleAugmentation(moduleName) {
-      var _a, _b, _c;
-      const moduleAugmentation = moduleName.parent;
-      if (((_a = moduleAugmentation.symbol.declarations) == null ? void 0 : _a[0]) !== moduleAugmentation) {
-        Debug.assert(moduleAugmentation.symbol.declarations.length > 1);
-        return;
-      }
-      if (isGlobalScopeAugmentation(moduleAugmentation)) {
-        mergeSymbolTable(globals, moduleAugmentation.symbol.exports);
-      } else {
-        const moduleNotFoundError = !(moduleName.parent.parent.flags & 16777216 /* Ambient */) ? Diagnostics.Invalid_module_name_in_augmentation_module_0_cannot_be_found : void 0;
-        let mainModule = resolveExternalModuleNameWorker(
-          moduleName,
-          moduleName,
-          moduleNotFoundError,
-          /*isForAugmentation*/
-          true
-        );
-        if (!mainModule) {
-          return;
-        }
-        mainModule = resolveExternalModuleSymbol(mainModule);
-        if (mainModule.flags & 1920 /* Namespace */) {
-          if (some(patternAmbientModules, (module2) => mainModule === module2.symbol)) {
-            const merged = mergeSymbol(
-              moduleAugmentation.symbol,
-              mainModule,
-              /*unidirectional*/
-              true
-            );
-            if (!patternAmbientModuleAugmentations) {
-              patternAmbientModuleAugmentations = /* @__PURE__ */ new Map();
-            }
-            patternAmbientModuleAugmentations.set(moduleName.text, merged);
-          } else {
-            if (((_b = mainModule.exports) == null ? void 0 : _b.get("__export" /* ExportStar */)) && ((_c = moduleAugmentation.symbol.exports) == null ? void 0 : _c.size)) {
-              const resolvedExports = getResolvedMembersOrExportsOfSymbol(mainModule, "resolvedExports" /* resolvedExports */);
-              for (const [key, value] of arrayFrom(moduleAugmentation.symbol.exports.entries())) {
-                if (resolvedExports.has(key) && !mainModule.exports.has(key)) {
-                  mergeSymbol(resolvedExports.get(key), value);
-                }
-              }
-            }
-            mergeSymbol(mainModule, moduleAugmentation.symbol);
-          }
-        } else {
-          error(moduleName, Diagnostics.Cannot_augment_module_0_because_it_resolves_to_a_non_module_entity, moduleName.text);
-        }
-      }
-    }
-    function addToSymbolTable(target, source, message) {
-      source.forEach((sourceSymbol, id) => {
-        const targetSymbol = target.get(id);
-        if (targetSymbol) {
-          forEach(targetSymbol.declarations, addDeclarationDiagnostic(unescapeLeadingUnderscores(id), message));
-        } else {
-          target.set(id, sourceSymbol);
-        }
-      });
-      function addDeclarationDiagnostic(id, message2) {
-        return (declaration) => diagnostics.add(createDiagnosticForNode(declaration, message2, id));
-      }
-    }
-    function getSymbolLinks(symbol) {
-      if (symbol.flags & 33554432 /* Transient */)
-        return symbol.links;
-      const id = getSymbolId(symbol);
-      return symbolLinks[id] ?? (symbolLinks[id] = new SymbolLinks());
-    }
-    function getNodeLinks(node) {
-      const nodeId = getNodeId(node);
-      return nodeLinks[nodeId] || (nodeLinks[nodeId] = new NodeLinks());
-    }
-    function isGlobalSourceFile(node) {
-      return node.kind === 311 /* SourceFile */ && !isExternalOrCommonJsModule(node);
-    }
-    function getSymbol2(symbols, name, meaning) {
-      if (meaning) {
-        const symbol = getMergedSymbol(symbols.get(name));
-        if (symbol) {
-          Debug.assert((getCheckFlags(symbol) & 1 /* Instantiated */) === 0, "Should never get an instantiated symbol here.");
-          if (symbol.flags & meaning) {
-            return symbol;
-          }
-          if (symbol.flags & 2097152 /* Alias */) {
-            const targetFlags = getAllSymbolFlags(symbol);
-            if (targetFlags & meaning) {
-              return symbol;
-            }
-          }
-        }
-      }
-    }
-    function getSymbolsOfParameterPropertyDeclaration(parameter, parameterName) {
-      const constructorDeclaration = parameter.parent;
-      const classDeclaration = parameter.parent.parent;
-      const parameterSymbol = getSymbol2(constructorDeclaration.locals, parameterName, 111551 /* Value */);
-      const propertySymbol = getSymbol2(getMembersOfSymbol(classDeclaration.symbol), parameterName, 111551 /* Value */);
-      if (parameterSymbol && propertySymbol) {
-        return [parameterSymbol, propertySymbol];
-      }
-      return Debug.fail("There should exist two symbols, one as property declaration and one as parameter declaration");
-    }
-    function isBlockScopedNameDeclaredBeforeUse(declaration, usage) {
-      const declarationFile = getSourceFileOfNode(declaration);
-      const useFile = getSourceFileOfNode(usage);
-      const declContainer = getEnclosingBlockScopeContainer(declaration);
-      if (declarationFile !== useFile) {
-        if (moduleKind && (declarationFile.externalModuleIndicator || useFile.externalModuleIndicator) || !outFile(compilerOptions) || isInTypeQuery(usage) || declaration.flags & 16777216 /* Ambient */) {
-          return true;
-        }
-        if (isUsedInFunctionOrInstanceProperty(usage, declaration)) {
-          return true;
-        }
-        const sourceFiles = host.getSourceFiles();
-        return sourceFiles.indexOf(declarationFile) <= sourceFiles.indexOf(useFile);
-      }
-      if (declaration.pos <= usage.pos && !(isPropertyDeclaration(declaration) && isThisProperty(usage.parent) && !declaration.initializer && !declaration.exclamationToken)) {
-        if (declaration.kind === 207 /* BindingElement */) {
-          const errorBindingElement = getAncestor(usage, 207 /* BindingElement */);
-          if (errorBindingElement) {
-            return findAncestor(errorBindingElement, isBindingElement) !== findAncestor(declaration, isBindingElement) || declaration.pos < errorBindingElement.pos;
-          }
-          return isBlockScopedNameDeclaredBeforeUse(getAncestor(declaration, 259 /* VariableDeclaration */), usage);
-        } else if (declaration.kind === 259 /* VariableDeclaration */) {
-          return !isImmediatelyUsedInInitializerOfBlockScopedVariable(declaration, usage);
-        } else if (isClassDeclaration(declaration)) {
-          return !findAncestor(usage, (n) => isComputedPropertyName(n) && n.parent.parent === declaration);
-        } else if (isPropertyDeclaration(declaration)) {
-          return !isPropertyImmediatelyReferencedWithinDeclaration(
-            declaration,
-            usage,
-            /*stopAtAnyPropertyDeclaration*/
-            false
-          );
-        } else if (isParameterPropertyDeclaration(declaration, declaration.parent)) {
-          return !(getEmitScriptTarget(compilerOptions) === 99 /* ESNext */ && useDefineForClassFields && getContainingClass(declaration) === getContainingClass(usage) && isUsedInFunctionOrInstanceProperty(usage, declaration));
-        }
-        return true;
-      }
-      if (usage.parent.kind === 280 /* ExportSpecifier */ || usage.parent.kind === 276 /* ExportAssignment */ && usage.parent.isExportEquals) {
-        return true;
-      }
-      if (usage.kind === 276 /* ExportAssignment */ && usage.isExportEquals) {
-        return true;
-      }
-      if (!!(usage.flags & 8388608 /* JSDoc */) || isInTypeQuery(usage) || isInAmbientOrTypeNode(usage)) {
-        return true;
-      }
-      if (isUsedInFunctionOrInstanceProperty(usage, declaration)) {
-        if (getEmitScriptTarget(compilerOptions) >= 9 /* ES2022 */ && useDefineForClassFields && getContainingClass(declaration) && (isPropertyDeclaration(declaration) || isParameterPropertyDeclaration(declaration, declaration.parent))) {
-          return !isPropertyImmediatelyReferencedWithinDeclaration(
-            declaration,
-            usage,
-            /*stopAtAnyPropertyDeclaration*/
-            true
-          );
-        } else {
-          return true;
-        }
-      }
-      return false;
-      function isImmediatelyUsedInInitializerOfBlockScopedVariable(declaration2, usage2) {
-        switch (declaration2.parent.parent.kind) {
-          case 242 /* VariableStatement */:
-          case 247 /* ForStatement */:
-          case 249 /* ForOfStatement */:
-            if (isSameScopeDescendentOf(usage2, declaration2, declContainer)) {
-              return true;
-            }
-            break;
-        }
-        const grandparent = declaration2.parent.parent;
-        return isForInOrOfStatement(grandparent) && isSameScopeDescendentOf(usage2, grandparent.expression, declContainer);
-      }
-      function isUsedInFunctionOrInstanceProperty(usage2, declaration2) {
-        return !!findAncestor(usage2, (current) => {
-          if (current === declContainer) {
-            return "quit";
-          }
-          if (isFunctionLike(current)) {
-            return true;
-          }
-          if (isClassStaticBlockDeclaration(current)) {
-            return declaration2.pos < usage2.pos;
-          }
-          const propertyDeclaration = tryCast(current.parent, isPropertyDeclaration);
-          if (propertyDeclaration) {
-            const initializerOfProperty = propertyDeclaration.initializer === current;
-            if (initializerOfProperty) {
-              if (isStatic(current.parent)) {
-                if (declaration2.kind === 173 /* MethodDeclaration */) {
-                  return true;
-                }
-                if (isPropertyDeclaration(declaration2) && getContainingClass(usage2) === getContainingClass(declaration2)) {
-                  const propName = declaration2.name;
-                  if (isIdentifier(propName) || isPrivateIdentifier(propName)) {
-                    const type = getTypeOfSymbol(getSymbolOfDeclaration(declaration2));
-                    const staticBlocks = filter(declaration2.parent.members, isClassStaticBlockDeclaration);
-                    if (isPropertyInitializedInStaticBlocks(propName, type, staticBlocks, declaration2.parent.pos, current.pos)) {
-                      return true;
-                    }
-                  }
-                }
-              } else {
-                const isDeclarationInstanceProperty = declaration2.kind === 171 /* PropertyDeclaration */ && !isStatic(declaration2);
-                if (!isDeclarationInstanceProperty || getContainingClass(usage2) !== getContainingClass(declaration2)) {
-                  return true;
-                }
-              }
-            }
-          }
-          return false;
-        });
-      }
-      function isPropertyImmediatelyReferencedWithinDeclaration(declaration2, usage2, stopAtAnyPropertyDeclaration) {
-        if (usage2.end > declaration2.end) {
-          return false;
-        }
-        const ancestorChangingReferenceScope = findAncestor(usage2, (node) => {
-          if (node === declaration2) {
-            return "quit";
-          }
-          switch (node.kind) {
-            case 218 /* ArrowFunction */:
-              return true;
-            case 171 /* PropertyDeclaration */:
-              return stopAtAnyPropertyDeclaration && (isPropertyDeclaration(declaration2) && node.parent === declaration2.parent || isParameterPropertyDeclaration(declaration2, declaration2.parent) && node.parent === declaration2.parent.parent) ? "quit" : true;
-            case 240 /* Block */:
-              switch (node.parent.kind) {
-                case 176 /* GetAccessor */:
-                case 173 /* MethodDeclaration */:
-                case 177 /* SetAccessor */:
-                  return true;
-                default:
-                  return false;
-              }
-            default:
-              return false;
-          }
-        });
-        return ancestorChangingReferenceScope === void 0;
-      }
-    }
-    function useOuterVariableScopeInParameter(result, location, lastLocation) {
-      const target = getEmitScriptTarget(compilerOptions);
-      const functionLocation = location;
-      if (isParameter(lastLocation) && functionLocation.body && result.valueDeclaration && result.valueDeclaration.pos >= functionLocation.body.pos && result.valueDeclaration.end <= functionLocation.body.end) {
-        if (target >= 2 /* ES2015 */) {
-          const links = getNodeLinks(functionLocation);
-          if (links.declarationRequiresScopeChange === void 0) {
-            links.declarationRequiresScopeChange = forEach(functionLocation.parameters, requiresScopeChange) || false;
-          }
-          return !links.declarationRequiresScopeChange;
-        }
-      }
-      return false;
-      function requiresScopeChange(node) {
-        return requiresScopeChangeWorker(node.name) || !!node.initializer && requiresScopeChangeWorker(node.initializer);
-      }
-      function requiresScopeChangeWorker(node) {
-        switch (node.kind) {
-          case 218 /* ArrowFunction */:
-          case 217 /* FunctionExpression */:
-          case 261 /* FunctionDeclaration */:
-          case 175 /* Constructor */:
-            return false;
-          case 173 /* MethodDeclaration */:
-          case 176 /* GetAccessor */:
-          case 177 /* SetAccessor */:
-          case 302 /* PropertyAssignment */:
-            return requiresScopeChangeWorker(node.name);
-          case 171 /* PropertyDeclaration */:
-            if (hasStaticModifier(node)) {
-              return target < 99 /* ESNext */ || !useDefineForClassFields;
-            }
-            return requiresScopeChangeWorker(node.name);
-          default:
-            if (isNullishCoalesce(node) || isOptionalChain(node)) {
-              return target < 7 /* ES2020 */;
-            }
-            if (isBindingElement(node) && node.dotDotDotToken && isObjectBindingPattern(node.parent)) {
-              return target < 4 /* ES2017 */;
-            }
-            if (isTypeNode(node))
-              return false;
-            return forEachChild(node, requiresScopeChangeWorker) || false;
-        }
-      }
-    }
-    function isConstAssertion(location) {
-      return isAssertionExpression(location) && isConstTypeReference(location.type) || isJSDocTypeTag(location) && isConstTypeReference(location.typeExpression);
-    }
-    function resolveName(location, name, meaning, nameNotFoundMessage, nameArg, isUse, excludeGlobals = false, getSpellingSuggestions = true) {
-      return resolveNameHelper(location, name, meaning, nameNotFoundMessage, nameArg, isUse, excludeGlobals, getSpellingSuggestions, getSymbol2);
-    }
-    function resolveNameHelper(location, name, meaning, nameNotFoundMessage, nameArg, isUse, excludeGlobals, getSpellingSuggestions, lookup) {
-      var _a, _b, _c;
-      const originalLocation = location;
-      let result;
-      let lastLocation;
-      let lastSelfReferenceLocation;
-      let propertyWithInvalidInitializer;
-      let associatedDeclarationForContainingInitializerOrBindingName;
-      let withinDeferredContext = false;
-      const errorLocation = location;
-      let grandparent;
-      let isInExternalModule = false;
-      loop:
-        while (location) {
-          if (name === "const" && isConstAssertion(location)) {
-            return void 0;
-          }
-          if (isModuleDeclaration(location) && lastLocation && location.name === lastLocation) {
-            lastLocation = location;
-            location = location.parent;
-          }
-          if (canHaveLocals(location) && location.locals && !isGlobalSourceFile(location)) {
-            if (result = lookup(location.locals, name, meaning)) {
-              let useResult = true;
-              if (isFunctionLike(location) && lastLocation && lastLocation !== location.body) {
-                if (meaning & result.flags & 788968 /* Type */ && lastLocation.kind !== 326 /* JSDoc */) {
-                  useResult = result.flags & 262144 /* TypeParameter */ ? lastLocation === location.type || lastLocation.kind === 168 /* Parameter */ || lastLocation.kind === 347 /* JSDocParameterTag */ || lastLocation.kind === 348 /* JSDocReturnTag */ || lastLocation.kind === 167 /* TypeParameter */ : false;
-                }
-                if (meaning & result.flags & 3 /* Variable */) {
-                  if (useOuterVariableScopeInParameter(result, location, lastLocation)) {
-                    useResult = false;
-                  } else if (result.flags & 1 /* FunctionScopedVariable */) {
-                    useResult = lastLocation.kind === 168 /* Parameter */ || lastLocation === location.type && !!findAncestor(result.valueDeclaration, isParameter);
-                  }
-                }
-              } else if (location.kind === 193 /* ConditionalType */) {
-                useResult = lastLocation === location.trueType;
-              }
-              if (useResult) {
-                break loop;
-              } else {
-                result = void 0;
-              }
-            }
-          }
-          withinDeferredContext = withinDeferredContext || getIsDeferredContext(location, lastLocation);
-          switch (location.kind) {
-            case 311 /* SourceFile */:
-              if (!isExternalOrCommonJsModule(location))
-                break;
-              isInExternalModule = true;
-            case 266 /* ModuleDeclaration */:
-              const moduleExports = ((_a = getSymbolOfDeclaration(location)) == null ? void 0 : _a.exports) || emptySymbols;
-              if (location.kind === 311 /* SourceFile */ || isModuleDeclaration(location) && location.flags & 16777216 /* Ambient */ && !isGlobalScopeAugmentation(location)) {
-                if (result = moduleExports.get("default" /* Default */)) {
-                  const localSymbol = getLocalSymbolForExportDefault(result);
-                  if (localSymbol && result.flags & meaning && localSymbol.escapedName === name) {
-                    break loop;
-                  }
-                  result = void 0;
-                }
-                const moduleExport = moduleExports.get(name);
-                if (moduleExport && moduleExport.flags === 2097152 /* Alias */ && (getDeclarationOfKind(moduleExport, 280 /* ExportSpecifier */) || getDeclarationOfKind(moduleExport, 279 /* NamespaceExport */))) {
-                  break;
-                }
-              }
-              if (name !== "default" /* Default */ && (result = lookup(moduleExports, name, meaning & 2623475 /* ModuleMember */))) {
-                if (isSourceFile(location) && location.commonJsModuleIndicator && !((_b = result.declarations) == null ? void 0 : _b.some(isJSDocTypeAlias))) {
-                  result = void 0;
-                } else {
-                  break loop;
-                }
-              }
-              break;
-            case 265 /* EnumDeclaration */:
-              if (result = lookup(((_c = getSymbolOfDeclaration(location)) == null ? void 0 : _c.exports) || emptySymbols, name, meaning & 8 /* EnumMember */)) {
-                if (nameNotFoundMessage && getIsolatedModules(compilerOptions) && !(location.flags & 16777216 /* Ambient */) && getSourceFileOfNode(location) !== getSourceFileOfNode(result.valueDeclaration)) {
-                  error(
-                    errorLocation,
-                    Diagnostics.Cannot_access_0_from_another_file_without_qualification_when_1_is_enabled_Use_2_instead,
-                    unescapeLeadingUnderscores(name),
-                    isolatedModulesLikeFlagName,
-                    `${unescapeLeadingUnderscores(getSymbolOfNode(location).escapedName)}.${unescapeLeadingUnderscores(name)}`
-                  );
-                }
-                break loop;
-              }
-              break;
-            case 171 /* PropertyDeclaration */:
-              if (!isStatic(location)) {
-                const ctor = findConstructorDeclaration(location.parent);
-                if (ctor && ctor.locals) {
-                  if (lookup(ctor.locals, name, meaning & 111551 /* Value */)) {
-                    Debug.assertNode(location, isPropertyDeclaration);
-                    propertyWithInvalidInitializer = location;
-                  }
-                }
-              }
-              break;
-            case 262 /* ClassDeclaration */:
-            case 230 /* ClassExpression */:
-            case 263 /* InterfaceDeclaration */:
-              if (result = lookup(getSymbolOfDeclaration(location).members || emptySymbols, name, meaning & 788968 /* Type */)) {
-                if (!isTypeParameterSymbolDeclaredInContainer(result, location)) {
-                  result = void 0;
-                  break;
-                }
-                if (lastLocation && isStatic(lastLocation)) {
-                  if (nameNotFoundMessage) {
-                    error(errorLocation, Diagnostics.Static_members_cannot_reference_class_type_parameters);
-                  }
-                  return void 0;
-                }
-                break loop;
-              }
-              if (isClassExpression(location) && meaning & 32 /* Class */) {
-                const className = location.name;
-                if (className && name === className.escapedText) {
-                  result = location.symbol;
-                  break loop;
-                }
-              }
-              break;
-            case 232 /* ExpressionWithTypeArguments */:
-              if (lastLocation === location.expression && location.parent.token === 96 /* ExtendsKeyword */) {
-                const container = location.parent.parent;
-                if (isClassLike(container) && (result = lookup(getSymbolOfDeclaration(container).members, name, meaning & 788968 /* Type */))) {
-                  if (nameNotFoundMessage) {
-                    error(errorLocation, Diagnostics.Base_class_expressions_cannot_reference_class_type_parameters);
-                  }
-                  return void 0;
-                }
-              }
-              break;
-            case 166 /* ComputedPropertyName */:
-              grandparent = location.parent.parent;
-              if (isClassLike(grandparent) || grandparent.kind === 263 /* InterfaceDeclaration */) {
-                if (result = lookup(getSymbolOfDeclaration(grandparent).members, name, meaning & 788968 /* Type */)) {
-                  if (nameNotFoundMessage) {
-                    error(errorLocation, Diagnostics.A_computed_property_name_cannot_reference_a_type_parameter_from_its_containing_type);
-                  }
-                  return void 0;
-                }
-              }
-              break;
-            case 218 /* ArrowFunction */:
-              if (getEmitScriptTarget(compilerOptions) >= 2 /* ES2015 */) {
-                break;
-              }
-            case 173 /* MethodDeclaration */:
-            case 175 /* Constructor */:
-            case 176 /* GetAccessor */:
-            case 177 /* SetAccessor */:
-            case 261 /* FunctionDeclaration */:
-              if (meaning & 3 /* Variable */ && name === "arguments") {
-                result = argumentsSymbol;
-                break loop;
-              }
-              break;
-            case 217 /* FunctionExpression */:
-              if (meaning & 3 /* Variable */ && name === "arguments") {
-                result = argumentsSymbol;
-                break loop;
-              }
-              if (meaning & 16 /* Function */) {
-                const functionName = location.name;
-                if (functionName && name === functionName.escapedText) {
-                  result = location.symbol;
-                  break loop;
-                }
-              }
-              break;
-            case 169 /* Decorator */:
-              if (location.parent && location.parent.kind === 168 /* Parameter */) {
-                location = location.parent;
-              }
-              if (location.parent && (isClassElement(location.parent) || location.parent.kind === 262 /* ClassDeclaration */)) {
-                location = location.parent;
-              }
-              break;
-            case 352 /* JSDocTypedefTag */:
-            case 344 /* JSDocCallbackTag */:
-            case 346 /* JSDocEnumTag */:
-              const root = getJSDocRoot(location);
-              if (root) {
-                location = root.parent;
-              }
-              break;
-            case 168 /* Parameter */:
-              if (lastLocation && (lastLocation === location.initializer || lastLocation === location.name && isBindingPattern(lastLocation))) {
-                if (!associatedDeclarationForContainingInitializerOrBindingName) {
-                  associatedDeclarationForContainingInitializerOrBindingName = location;
-                }
-              }
-              break;
-            case 207 /* BindingElement */:
-              if (lastLocation && (lastLocation === location.initializer || lastLocation === location.name && isBindingPattern(lastLocation))) {
-                if (isParameterDeclaration(location) && !associatedDeclarationForContainingInitializerOrBindingName) {
-                  associatedDeclarationForContainingInitializerOrBindingName = location;
-                }
-              }
-              break;
-            case 194 /* InferType */:
-              if (meaning & 262144 /* TypeParameter */) {
-                const parameterName = location.typeParameter.name;
-                if (parameterName && name === parameterName.escapedText) {
-                  result = location.typeParameter.symbol;
-                  break loop;
-                }
-              }
-              break;
-            case 280 /* ExportSpecifier */:
-              if (lastLocation && lastLocation === location.propertyName && location.parent.parent.moduleSpecifier) {
-                location = location.parent.parent.parent;
-              }
-              break;
-          }
-          if (isSelfReferenceLocation(location)) {
-            lastSelfReferenceLocation = location;
-          }
-          lastLocation = location;
-          location = isJSDocTemplateTag(location) ? getEffectiveContainerForJSDocTemplateTag(location) || location.parent : isJSDocParameterTag(location) || isJSDocReturnTag(location) ? getHostSignatureFromJSDoc(location) || location.parent : location.parent;
-        }
-      if (isUse && result && (!lastSelfReferenceLocation || result !== lastSelfReferenceLocation.symbol)) {
-        result.isReferenced |= meaning;
-      }
-      if (!result) {
-        if (lastLocation) {
-          Debug.assertNode(lastLocation, isSourceFile);
-          if (lastLocation.commonJsModuleIndicator && name === "exports" && meaning & lastLocation.symbol.flags) {
-            return lastLocation.symbol;
-          }
-        }
-        if (!excludeGlobals) {
-          result = lookup(globals, name, meaning);
-        }
-      }
-      if (!result) {
-        if (originalLocation && isInJSFile(originalLocation) && originalLocation.parent) {
-          if (isRequireCall(
-            originalLocation.parent,
-            /*requireStringLiteralLikeArgument*/
-            false
-          )) {
-            return requireSymbol;
-          }
-        }
-      }
-      function checkAndReportErrorForInvalidInitializer() {
-        if (propertyWithInvalidInitializer && !(useDefineForClassFields && getEmitScriptTarget(compilerOptions) >= 9 /* ES2022 */)) {
-          error(
-            errorLocation,
-            errorLocation && propertyWithInvalidInitializer.type && textRangeContainsPositionInclusive(propertyWithInvalidInitializer.type, errorLocation.pos) ? Diagnostics.Type_of_instance_member_variable_0_cannot_reference_identifier_1_declared_in_the_constructor : Diagnostics.Initializer_of_instance_member_variable_0_cannot_reference_identifier_1_declared_in_the_constructor,
-            declarationNameToString(propertyWithInvalidInitializer.name),
-            diagnosticName(nameArg)
-          );
-          return true;
-        }
-        return false;
-      }
-      if (!result) {
-        if (nameNotFoundMessage) {
-          addLazyDiagnostic(() => {
-            if (!errorLocation || errorLocation.parent.kind !== 330 /* JSDocLink */ && !checkAndReportErrorForMissingPrefix(errorLocation, name, nameArg) && // TODO: GH#18217
-            !checkAndReportErrorForInvalidInitializer() && !checkAndReportErrorForExtendingInterface(errorLocation) && !checkAndReportErrorForUsingTypeAsNamespace(errorLocation, name, meaning) && !checkAndReportErrorForExportingPrimitiveType(errorLocation, name) && !checkAndReportErrorForUsingNamespaceAsTypeOrValue(errorLocation, name, meaning) && !checkAndReportErrorForUsingTypeAsValue(errorLocation, name, meaning) && !checkAndReportErrorForUsingValueAsType(errorLocation, name, meaning)) {
-              let suggestion;
-              let suggestedLib;
-              if (nameArg) {
-                suggestedLib = getSuggestedLibForNonExistentName(nameArg);
-                if (suggestedLib) {
-                  error(errorLocation, nameNotFoundMessage, diagnosticName(nameArg), suggestedLib);
-                }
-              }
-              if (!suggestedLib && getSpellingSuggestions && suggestionCount < maximumSuggestionCount) {
-                suggestion = getSuggestedSymbolForNonexistentSymbol(originalLocation, name, meaning);
-                const isGlobalScopeAugmentationDeclaration = (suggestion == null ? void 0 : suggestion.valueDeclaration) && isAmbientModule(suggestion.valueDeclaration) && isGlobalScopeAugmentation(suggestion.valueDeclaration);
-                if (isGlobalScopeAugmentationDeclaration) {
-                  suggestion = void 0;
-                }
-                if (suggestion) {
-                  const suggestionName = symbolToString(suggestion);
-                  const isUncheckedJS = isUncheckedJSSuggestion(
-                    originalLocation,
-                    suggestion,
-                    /*excludeClasses*/
-                    false
-                  );
-                  const message = meaning === 1920 /* Namespace */ || nameArg && typeof nameArg !== "string" && nodeIsSynthesized(nameArg) ? Diagnostics.Cannot_find_namespace_0_Did_you_mean_1 : isUncheckedJS ? Diagnostics.Could_not_find_name_0_Did_you_mean_1 : Diagnostics.Cannot_find_name_0_Did_you_mean_1;
-                  const diagnostic = createError(errorLocation, message, diagnosticName(nameArg), suggestionName);
-                  addErrorOrSuggestion(!isUncheckedJS, diagnostic);
-                  if (suggestion.valueDeclaration) {
-                    addRelatedInfo(
-                      diagnostic,
-                      createDiagnosticForNode(suggestion.valueDeclaration, Diagnostics._0_is_declared_here, suggestionName)
-                    );
-                  }
-                }
-              }
-              if (!suggestion && !suggestedLib && nameArg) {
-                error(errorLocation, nameNotFoundMessage, diagnosticName(nameArg));
-              }
-              suggestionCount++;
-            }
-          });
-        }
-        return void 0;
-      } else if (nameNotFoundMessage && checkAndReportErrorForInvalidInitializer()) {
-        return void 0;
-      }
-      if (nameNotFoundMessage) {
-        addLazyDiagnostic(() => {
-          if (errorLocation && (meaning & 2 /* BlockScopedVariable */ || (meaning & 32 /* Class */ || meaning & 384 /* Enum */) && (meaning & 111551 /* Value */) === 111551 /* Value */)) {
-            const exportOrLocalSymbol = getExportSymbolOfValueSymbolIfExported(result);
-            if (exportOrLocalSymbol.flags & 2 /* BlockScopedVariable */ || exportOrLocalSymbol.flags & 32 /* Class */ || exportOrLocalSymbol.flags & 384 /* Enum */) {
-              checkResolvedBlockScopedVariable(exportOrLocalSymbol, errorLocation);
-            }
-          }
-          if (result && isInExternalModule && (meaning & 111551 /* Value */) === 111551 /* Value */ && !(originalLocation.flags & 8388608 /* JSDoc */)) {
-            const merged = getMergedSymbol(result);
-            if (length(merged.declarations) && every(merged.declarations, (d) => isNamespaceExportDeclaration(d) || isSourceFile(d) && !!d.symbol.globalExports)) {
-              errorOrSuggestion(!compilerOptions.allowUmdGlobalAccess, errorLocation, Diagnostics._0_refers_to_a_UMD_global_but_the_current_file_is_a_module_Consider_adding_an_import_instead, unescapeLeadingUnderscores(name));
-            }
-          }
-          if (result && associatedDeclarationForContainingInitializerOrBindingName && !withinDeferredContext && (meaning & 111551 /* Value */) === 111551 /* Value */) {
-            const candidate = getMergedSymbol(getLateBoundSymbol(result));
-            const root = getRootDeclaration(associatedDeclarationForContainingInitializerOrBindingName);
-            if (candidate === getSymbolOfDeclaration(associatedDeclarationForContainingInitializerOrBindingName)) {
-              error(errorLocation, Diagnostics.Parameter_0_cannot_reference_itself, declarationNameToString(associatedDeclarationForContainingInitializerOrBindingName.name));
-            } else if (candidate.valueDeclaration && candidate.valueDeclaration.pos > associatedDeclarationForContainingInitializerOrBindingName.pos && root.parent.locals && lookup(root.parent.locals, candidate.escapedName, meaning) === candidate) {
-              error(errorLocation, Diagnostics.Parameter_0_cannot_reference_identifier_1_declared_after_it, declarationNameToString(associatedDeclarationForContainingInitializerOrBindingName.name), declarationNameToString(errorLocation));
-            }
-          }
-          if (result && errorLocation && meaning & 111551 /* Value */ && result.flags & 2097152 /* Alias */ && !(result.flags & 111551 /* Value */) && !isValidTypeOnlyAliasUseSite(errorLocation)) {
-            const typeOnlyDeclaration = getTypeOnlyAliasDeclaration(result, 111551 /* Value */);
-            if (typeOnlyDeclaration) {
-              const message = typeOnlyDeclaration.kind === 280 /* ExportSpecifier */ || typeOnlyDeclaration.kind === 277 /* ExportDeclaration */ || typeOnlyDeclaration.kind === 279 /* NamespaceExport */ ? Diagnostics._0_cannot_be_used_as_a_value_because_it_was_exported_using_export_type : Diagnostics._0_cannot_be_used_as_a_value_because_it_was_imported_using_import_type;
-              const unescapedName = unescapeLeadingUnderscores(name);
-              addTypeOnlyDeclarationRelatedInfo(
-                error(errorLocation, message, unescapedName),
-                typeOnlyDeclaration,
-                unescapedName
-              );
-            }
-          }
-        });
-      }
-      return result;
-    }
-    function addTypeOnlyDeclarationRelatedInfo(diagnostic, typeOnlyDeclaration, unescapedName) {
-      if (!typeOnlyDeclaration)
-        return diagnostic;
-      return addRelatedInfo(
-        diagnostic,
-        createDiagnosticForNode(
-          typeOnlyDeclaration,
-          typeOnlyDeclaration.kind === 280 /* ExportSpecifier */ || typeOnlyDeclaration.kind === 277 /* ExportDeclaration */ || typeOnlyDeclaration.kind === 279 /* NamespaceExport */ ? Diagnostics._0_was_exported_here : Diagnostics._0_was_imported_here,
-          unescapedName
-        )
-      );
-    }
-    function getIsDeferredContext(location, lastLocation) {
-      if (location.kind !== 218 /* ArrowFunction */ && location.kind !== 217 /* FunctionExpression */) {
-        return isTypeQueryNode(location) || (isFunctionLikeDeclaration(location) || location.kind === 171 /* PropertyDeclaration */ && !isStatic(location)) && (!lastLocation || lastLocation !== location.name);
-      }
-      if (lastLocation && lastLocation === location.name) {
-        return false;
-      }
-      if (location.asteriskToken || hasSyntacticModifier(location, 512 /* Async */)) {
-        return true;
-      }
-      return !getImmediatelyInvokedFunctionExpression(location);
-    }
-    function isSelfReferenceLocation(node) {
-      switch (node.kind) {
-        case 261 /* FunctionDeclaration */:
-        case 262 /* ClassDeclaration */:
-        case 263 /* InterfaceDeclaration */:
-        case 265 /* EnumDeclaration */:
-        case 264 /* TypeAliasDeclaration */:
-        case 266 /* ModuleDeclaration */:
-          return true;
-        default:
-          return false;
-      }
-    }
-    function diagnosticName(nameArg) {
-      return isString(nameArg) ? unescapeLeadingUnderscores(nameArg) : declarationNameToString(nameArg);
-    }
-    function isTypeParameterSymbolDeclaredInContainer(symbol, container) {
-      if (symbol.declarations) {
-        for (const decl of symbol.declarations) {
-          if (decl.kind === 167 /* TypeParameter */) {
-            const parent2 = isJSDocTemplateTag(decl.parent) ? getJSDocHost(decl.parent) : decl.parent;
-            if (parent2 === container) {
-              return !(isJSDocTemplateTag(decl.parent) && find(decl.parent.parent.tags, isJSDocTypeAlias));
-            }
-          }
-        }
-      }
-      return false;
-    }
-    function checkAndReportErrorForMissingPrefix(errorLocation, name, nameArg) {
-      if (!isIdentifier(errorLocation) || errorLocation.escapedText !== name || isTypeReferenceIdentifier(errorLocation) || isInTypeQuery(errorLocation)) {
-        return false;
-      }
-      const container = getThisContainer(
-        errorLocation,
-        /*includeArrowFunctions*/
-        false,
-        /*includeClassComputedPropertyName*/
-        false
-      );
-      let location = container;
-      while (location) {
-        if (isClassLike(location.parent)) {
-          const classSymbol = getSymbolOfDeclaration(location.parent);
-          if (!classSymbol) {
-            break;
-          }
-          const constructorType = getTypeOfSymbol(classSymbol);
-          if (getPropertyOfType(constructorType, name)) {
-            error(errorLocation, Diagnostics.Cannot_find_name_0_Did_you_mean_the_static_member_1_0, diagnosticName(nameArg), symbolToString(classSymbol));
-            return true;
-          }
-          if (location === container && !isStatic(location)) {
-            const instanceType = getDeclaredTypeOfSymbol(classSymbol).thisType;
-            if (getPropertyOfType(instanceType, name)) {
-              error(errorLocation, Diagnostics.Cannot_find_name_0_Did_you_mean_the_instance_member_this_0, diagnosticName(nameArg));
-              return true;
-            }
-          }
-        }
-        location = location.parent;
-      }
-      return false;
-    }
-    function checkAndReportErrorForExtendingInterface(errorLocation) {
-      const expression = getEntityNameForExtendingInterface(errorLocation);
-      if (expression && resolveEntityName(
-        expression,
-        64 /* Interface */,
-        /*ignoreErrors*/
-        true
-      )) {
-        error(errorLocation, Diagnostics.Cannot_extend_an_interface_0_Did_you_mean_implements, getTextOfNode(expression));
-        return true;
-      }
-      return false;
-    }
-    function getEntityNameForExtendingInterface(node) {
-      switch (node.kind) {
-        case 80 /* Identifier */:
-        case 210 /* PropertyAccessExpression */:
-          return node.parent ? getEntityNameForExtendingInterface(node.parent) : void 0;
-        case 232 /* ExpressionWithTypeArguments */:
-          if (isEntityNameExpression(node.expression)) {
-            return node.expression;
-          }
-        default:
-          return void 0;
-      }
-    }
-    function checkAndReportErrorForUsingTypeAsNamespace(errorLocation, name, meaning) {
-      const namespaceMeaning = 1920 /* Namespace */ | (isInJSFile(errorLocation) ? 111551 /* Value */ : 0);
-      if (meaning === namespaceMeaning) {
-        const symbol = resolveSymbol(resolveName(
-          errorLocation,
-          name,
-          788968 /* Type */ & ~namespaceMeaning,
-          /*nameNotFoundMessage*/
-          void 0,
-          /*nameArg*/
-          void 0,
-          /*isUse*/
-          false
-        ));
-        const parent2 = errorLocation.parent;
-        if (symbol) {
-          if (isQualifiedName(parent2)) {
-            Debug.assert(parent2.left === errorLocation, "Should only be resolving left side of qualified name as a namespace");
-            const propName = parent2.right.escapedText;
-            const propType = getPropertyOfType(getDeclaredTypeOfSymbol(symbol), propName);
-            if (propType) {
-              error(
-                parent2,
-                Diagnostics.Cannot_access_0_1_because_0_is_a_type_but_not_a_namespace_Did_you_mean_to_retrieve_the_type_of_the_property_1_in_0_with_0_1,
-                unescapeLeadingUnderscores(name),
-                unescapeLeadingUnderscores(propName)
-              );
-              return true;
-            }
-          }
-          error(errorLocation, Diagnostics._0_only_refers_to_a_type_but_is_being_used_as_a_namespace_here, unescapeLeadingUnderscores(name));
-          return true;
-        }
-      }
-      return false;
-    }
-    function checkAndReportErrorForUsingValueAsType(errorLocation, name, meaning) {
-      if (meaning & (788968 /* Type */ & ~1920 /* Namespace */)) {
-        const symbol = resolveSymbol(resolveName(
-          errorLocation,
-          name,
-          ~788968 /* Type */ & 111551 /* Value */,
-          /*nameNotFoundMessage*/
-          void 0,
-          /*nameArg*/
-          void 0,
-          /*isUse*/
-          false
-        ));
-        if (symbol && !(symbol.flags & 1920 /* Namespace */)) {
-          error(errorLocation, Diagnostics._0_refers_to_a_value_but_is_being_used_as_a_type_here_Did_you_mean_typeof_0, unescapeLeadingUnderscores(name));
-          return true;
-        }
-      }
-      return false;
-    }
-    function isPrimitiveTypeName(name) {
-      return name === "any" || name === "string" || name === "number" || name === "boolean" || name === "never" || name === "unknown";
-    }
-    function checkAndReportErrorForExportingPrimitiveType(errorLocation, name) {
-      if (isPrimitiveTypeName(name) && errorLocation.parent.kind === 280 /* ExportSpecifier */) {
-        error(errorLocation, Diagnostics.Cannot_export_0_Only_local_declarations_can_be_exported_from_a_module, name);
-        return true;
-      }
-      return false;
-    }
-    function checkAndReportErrorForUsingTypeAsValue(errorLocation, name, meaning) {
-      if (meaning & 111551 /* Value */) {
-        if (isPrimitiveTypeName(name)) {
-          if (isExtendedByInterface(errorLocation)) {
-            error(errorLocation, Diagnostics.An_interface_cannot_extend_a_primitive_type_like_0_an_interface_can_only_extend_named_types_and_classes, unescapeLeadingUnderscores(name));
-          } else {
-            error(errorLocation, Diagnostics._0_only_refers_to_a_type_but_is_being_used_as_a_value_here, unescapeLeadingUnderscores(name));
-          }
-          return true;
-        }
-        const symbol = resolveSymbol(resolveName(
-          errorLocation,
-          name,
-          788968 /* Type */ & ~111551 /* Value */,
-          /*nameNotFoundMessage*/
-          void 0,
-          /*nameArg*/
-          void 0,
-          /*isUse*/
-          false
-        ));
-        const allFlags = symbol && getAllSymbolFlags(symbol);
-        if (symbol && allFlags !== void 0 && !(allFlags & 111551 /* Value */)) {
-          const rawName = unescapeLeadingUnderscores(name);
-          if (isES2015OrLaterConstructorName(name)) {
-            error(errorLocation, Diagnostics._0_only_refers_to_a_type_but_is_being_used_as_a_value_here_Do_you_need_to_change_your_target_library_Try_changing_the_lib_compiler_option_to_es2015_or_later, rawName);
-          } else if (maybeMappedType(errorLocation, symbol)) {
-            error(errorLocation, Diagnostics._0_only_refers_to_a_type_but_is_being_used_as_a_value_here_Did_you_mean_to_use_1_in_0, rawName, rawName === "K" ? "P" : "K");
-          } else {
-            error(errorLocation, Diagnostics._0_only_refers_to_a_type_but_is_being_used_as_a_value_here, rawName);
-          }
-          return true;
-        }
-      }
-      return false;
-    }
-    function isExtendedByInterface(node) {
-      const grandparent = node.parent.parent;
-      const parentOfGrandparent = grandparent.parent;
-      if (grandparent && parentOfGrandparent) {
-        const isExtending = isHeritageClause(grandparent) && grandparent.token === 96 /* ExtendsKeyword */;
-        const isInterface = isInterfaceDeclaration(parentOfGrandparent);
-        return isExtending && isInterface;
-      }
-      return false;
-    }
-    function maybeMappedType(node, symbol) {
-      const container = findAncestor(node.parent, (n) => isComputedPropertyName(n) || isPropertySignature(n) ? false : isTypeLiteralNode(n) || "quit");
-      if (container && container.members.length === 1) {
-        const type = getDeclaredTypeOfSymbol(symbol);
-        return !!(type.flags & 1048576 /* Union */) && allTypesAssignableToKind(
-          type,
-          384 /* StringOrNumberLiteral */,
-          /*strict*/
-          true
-        );
-      }
-      return false;
-    }
-    function isES2015OrLaterConstructorName(n) {
-      switch (n) {
-        case "Promise":
-        case "Symbol":
-        case "Map":
-        case "WeakMap":
-        case "Set":
-        case "WeakSet":
-          return true;
-      }
-      return false;
-    }
-    function checkAndReportErrorForUsingNamespaceAsTypeOrValue(errorLocation, name, meaning) {
-      if (meaning & (111551 /* Value */ & ~788968 /* Type */)) {
-        const symbol = resolveSymbol(resolveName(
-          errorLocation,
-          name,
-          1024 /* NamespaceModule */,
-          /*nameNotFoundMessage*/
-          void 0,
-          /*nameArg*/
-          void 0,
-          /*isUse*/
-          false
-        ));
-        if (symbol) {
-          error(
-            errorLocation,
-            Diagnostics.Cannot_use_namespace_0_as_a_value,
-            unescapeLeadingUnderscores(name)
-          );
-          return true;
-        }
-      } else if (meaning & (788968 /* Type */ & ~111551 /* Value */)) {
-        const symbol = resolveSymbol(resolveName(
-          errorLocation,
-          name,
-          1536 /* Module */,
-          /*nameNotFoundMessage*/
-          void 0,
-          /*nameArg*/
-          void 0,
-          /*isUse*/
-          false
-        ));
-        if (symbol) {
-          error(errorLocation, Diagnostics.Cannot_use_namespace_0_as_a_type, unescapeLeadingUnderscores(name));
-          return true;
-        }
-      }
-      return false;
-    }
-    function checkResolvedBlockScopedVariable(result, errorLocation) {
-      var _a;
-      Debug.assert(!!(result.flags & 2 /* BlockScopedVariable */ || result.flags & 32 /* Class */ || result.flags & 384 /* Enum */));
-      if (result.flags & (16 /* Function */ | 1 /* FunctionScopedVariable */ | 67108864 /* Assignment */) && result.flags & 32 /* Class */) {
-        return;
-      }
-      const declaration = (_a = result.declarations) == null ? void 0 : _a.find(
-        (d) => isBlockOrCatchScoped(d) || isClassLike(d) || d.kind === 265 /* EnumDeclaration */
-      );
-      if (declaration === void 0)
-        return Debug.fail("checkResolvedBlockScopedVariable could not find block-scoped declaration");
-      if (!(declaration.flags & 16777216 /* Ambient */) && !isBlockScopedNameDeclaredBeforeUse(declaration, errorLocation)) {
-        let diagnosticMessage;
-        const declarationName = declarationNameToString(getNameOfDeclaration(declaration));
-        if (result.flags & 2 /* BlockScopedVariable */) {
-          diagnosticMessage = error(errorLocation, Diagnostics.Block_scoped_variable_0_used_before_its_declaration, declarationName);
-        } else if (result.flags & 32 /* Class */) {
-          diagnosticMessage = error(errorLocation, Diagnostics.Class_0_used_before_its_declaration, declarationName);
-        } else if (result.flags & 256 /* RegularEnum */) {
-          diagnosticMessage = error(errorLocation, Diagnostics.Enum_0_used_before_its_declaration, declarationName);
-        }
-        if (diagnosticMessage) {
-          addRelatedInfo(
-            diagnosticMessage,
-            createDiagnosticForNode(declaration, Diagnostics._0_is_declared_here, declarationName)
-          );
-        }
-      }
-    }
-    function isSameScopeDescendentOf(initial, parent2, stopAt) {
-      return !!parent2 && !!findAncestor(initial, (n) => n === parent2 || (n === stopAt || isFunctionLike(n) && (!getImmediatelyInvokedFunctionExpression(n) || isAsyncFunction(n)) ? "quit" : false));
-    }
-    function getAnyImportSyntax(node) {
-      switch (node.kind) {
-        case 270 /* ImportEqualsDeclaration */:
-          return node;
-        case 272 /* ImportClause */:
-          return node.parent;
-        case 273 /* NamespaceImport */:
-          return node.parent.parent;
-        case 275 /* ImportSpecifier */:
-          return node.parent.parent.parent;
-        default:
-          return void 0;
-      }
-    }
-    function getDeclarationOfAliasSymbol(symbol) {
-      return symbol.declarations && findLast(symbol.declarations, isAliasSymbolDeclaration2);
-    }
-    function isAliasSymbolDeclaration2(node) {
-      return node.kind === 270 /* ImportEqualsDeclaration */ || node.kind === 269 /* NamespaceExportDeclaration */ || node.kind === 272 /* ImportClause */ && !!node.name || node.kind === 273 /* NamespaceImport */ || node.kind === 279 /* NamespaceExport */ || node.kind === 275 /* ImportSpecifier */ || node.kind === 280 /* ExportSpecifier */ || node.kind === 276 /* ExportAssignment */ && exportAssignmentIsAlias(node) || isBinaryExpression(node) && getAssignmentDeclarationKind(node) === 2 /* ModuleExports */ && exportAssignmentIsAlias(node) || isAccessExpression(node) && isBinaryExpression(node.parent) && node.parent.left === node && node.parent.operatorToken.kind === 64 /* EqualsToken */ && isAliasableOrJsExpression(node.parent.right) || node.kind === 303 /* ShorthandPropertyAssignment */ || node.kind === 302 /* PropertyAssignment */ && isAliasableOrJsExpression(node.initializer) || node.kind === 259 /* VariableDeclaration */ && isVariableDeclarationInitializedToBareOrAccessedRequire(node) || node.kind === 207 /* BindingElement */ && isVariableDeclarationInitializedToBareOrAccessedRequire(node.parent.parent);
-    }
-    function isAliasableOrJsExpression(e) {
-      return isAliasableExpression(e) || isFunctionExpression(e) && isJSConstructor(e);
-    }
-    function getTargetOfImportEqualsDeclaration(node, dontResolveAlias) {
-      const commonJSPropertyAccess = getCommonJSPropertyAccess(node);
-      if (commonJSPropertyAccess) {
-        const name = getLeftmostAccessExpression(commonJSPropertyAccess.expression).arguments[0];
-        return isIdentifier(commonJSPropertyAccess.name) ? resolveSymbol(getPropertyOfType(resolveExternalModuleTypeByLiteral(name), commonJSPropertyAccess.name.escapedText)) : void 0;
-      }
-      if (isVariableDeclaration(node) || node.moduleReference.kind === 282 /* ExternalModuleReference */) {
-        const immediate = resolveExternalModuleName(
-          node,
-          getExternalModuleRequireArgument(node) || getExternalModuleImportEqualsDeclarationExpression(node)
-        );
-        const resolved2 = resolveExternalModuleSymbol(immediate);
-        markSymbolOfAliasDeclarationIfTypeOnly(
-          node,
-          immediate,
-          resolved2,
-          /*overwriteEmpty*/
-          false
-        );
-        return resolved2;
-      }
-      const resolved = getSymbolOfPartOfRightHandSideOfImportEquals(node.moduleReference, dontResolveAlias);
-      checkAndReportErrorForResolvingImportAliasToTypeOnlySymbol(node, resolved);
-      return resolved;
-    }
-    function checkAndReportErrorForResolvingImportAliasToTypeOnlySymbol(node, resolved) {
-      if (markSymbolOfAliasDeclarationIfTypeOnly(
-        node,
-        /*immediateTarget*/
-        void 0,
-        resolved,
-        /*overwriteEmpty*/
-        false
-      ) && !node.isTypeOnly) {
-        const typeOnlyDeclaration = getTypeOnlyAliasDeclaration(getSymbolOfDeclaration(node));
-        const isExport = typeOnlyDeclaration.kind === 280 /* ExportSpecifier */ || typeOnlyDeclaration.kind === 277 /* ExportDeclaration */;
-        const message = isExport ? Diagnostics.An_import_alias_cannot_reference_a_declaration_that_was_exported_using_export_type : Diagnostics.An_import_alias_cannot_reference_a_declaration_that_was_imported_using_import_type;
-        const relatedMessage = isExport ? Diagnostics._0_was_exported_here : Diagnostics._0_was_imported_here;
-        const name = typeOnlyDeclaration.kind === 277 /* ExportDeclaration */ ? "*" : unescapeLeadingUnderscores(typeOnlyDeclaration.name.escapedText);
-        addRelatedInfo(error(node.moduleReference, message), createDiagnosticForNode(typeOnlyDeclaration, relatedMessage, name));
-      }
-    }
-    function resolveExportByName(moduleSymbol, name, sourceNode, dontResolveAlias) {
-      const exportValue = moduleSymbol.exports.get("export=" /* ExportEquals */);
-      const exportSymbol = exportValue ? getPropertyOfType(
-        getTypeOfSymbol(exportValue),
-        name,
-        /*skipObjectFunctionPropertyAugment*/
-        true
-      ) : moduleSymbol.exports.get(name);
-      const resolved = resolveSymbol(exportSymbol, dontResolveAlias);
-      markSymbolOfAliasDeclarationIfTypeOnly(
-        sourceNode,
-        exportSymbol,
-        resolved,
-        /*overwriteEmpty*/
-        false
-      );
-      return resolved;
-    }
-    function isSyntacticDefault(node) {
-      return isExportAssignment(node) && !node.isExportEquals || hasSyntacticModifier(node, 1024 /* Default */) || isExportSpecifier(node);
-    }
-    function getUsageModeForExpression(usage) {
-      return isStringLiteralLike(usage) ? getModeForUsageLocation(getSourceFileOfNode(usage), usage) : void 0;
-    }
-    function isESMFormatImportImportingCommonjsFormatFile(usageMode, targetMode) {
-      return usageMode === 99 /* ESNext */ && targetMode === 1 /* CommonJS */;
-    }
-    function isOnlyImportedAsDefault(usage) {
-      const usageMode = getUsageModeForExpression(usage);
-      return usageMode === 99 /* ESNext */ && endsWith(usage.text, ".json" /* Json */);
-    }
-    function canHaveSyntheticDefault(file, moduleSymbol, dontResolveAlias, usage) {
-      const usageMode = file && getUsageModeForExpression(usage);
-      if (file && usageMode !== void 0) {
-        const result = isESMFormatImportImportingCommonjsFormatFile(usageMode, file.impliedNodeFormat);
-        if (usageMode === 99 /* ESNext */ || result) {
-          return result;
-        }
-      }
-      if (!allowSyntheticDefaultImports) {
-        return false;
-      }
-      if (!file || file.isDeclarationFile) {
-        const defaultExportSymbol = resolveExportByName(
-          moduleSymbol,
-          "default" /* Default */,
-          /*sourceNode*/
-          void 0,
-          /*dontResolveAlias*/
-          true
-        );
-        if (defaultExportSymbol && some(defaultExportSymbol.declarations, isSyntacticDefault)) {
-          return false;
-        }
-        if (resolveExportByName(
-          moduleSymbol,
-          escapeLeadingUnderscores("__esModule"),
-          /*sourceNode*/
-          void 0,
-          dontResolveAlias
-        )) {
-          return false;
-        }
-        return true;
-      }
-      if (!isSourceFileJS(file)) {
-        return hasExportAssignmentSymbol(moduleSymbol);
-      }
-      return typeof file.externalModuleIndicator !== "object" && !resolveExportByName(
-        moduleSymbol,
-        escapeLeadingUnderscores("__esModule"),
-        /*sourceNode*/
-        void 0,
-        dontResolveAlias
-      );
-    }
-    function getTargetOfImportClause(node, dontResolveAlias) {
-      const moduleSymbol = resolveExternalModuleName(node, node.parent.moduleSpecifier);
-      if (moduleSymbol) {
-        return getTargetofModuleDefault(moduleSymbol, node, dontResolveAlias);
-      }
-    }
-    function getTargetofModuleDefault(moduleSymbol, node, dontResolveAlias) {
-      var _a;
-      let exportDefaultSymbol;
-      if (isShorthandAmbientModuleSymbol(moduleSymbol)) {
-        exportDefaultSymbol = moduleSymbol;
-      } else {
-        exportDefaultSymbol = resolveExportByName(moduleSymbol, "default" /* Default */, node, dontResolveAlias);
-      }
-      const file = (_a = moduleSymbol.declarations) == null ? void 0 : _a.find(isSourceFile);
-      const specifier = getModuleSpecifierForImportOrExport(node);
-      if (!specifier) {
-        return exportDefaultSymbol;
-      }
-      const hasDefaultOnly = isOnlyImportedAsDefault(specifier);
-      const hasSyntheticDefault = canHaveSyntheticDefault(file, moduleSymbol, dontResolveAlias, specifier);
-      if (!exportDefaultSymbol && !hasSyntheticDefault && !hasDefaultOnly) {
-        if (hasExportAssignmentSymbol(moduleSymbol) && !allowSyntheticDefaultImports) {
-          const compilerOptionName = moduleKind >= 5 /* ES2015 */ ? "allowSyntheticDefaultImports" : "esModuleInterop";
-          const exportEqualsSymbol = moduleSymbol.exports.get("export=" /* ExportEquals */);
-          const exportAssignment = exportEqualsSymbol.valueDeclaration;
-          const err = error(node.name, Diagnostics.Module_0_can_only_be_default_imported_using_the_1_flag, symbolToString(moduleSymbol), compilerOptionName);
-          if (exportAssignment) {
-            addRelatedInfo(err, createDiagnosticForNode(
-              exportAssignment,
-              Diagnostics.This_module_is_declared_with_export_and_can_only_be_used_with_a_default_import_when_using_the_0_flag,
-              compilerOptionName
-            ));
-          }
-        } else if (isImportClause(node)) {
-          reportNonDefaultExport(moduleSymbol, node);
-        } else {
-          errorNoModuleMemberSymbol(moduleSymbol, moduleSymbol, node, isImportOrExportSpecifier(node) && node.propertyName || node.name);
-        }
-      } else if (hasSyntheticDefault || hasDefaultOnly) {
-        const resolved = resolveExternalModuleSymbol(moduleSymbol, dontResolveAlias) || resolveSymbol(moduleSymbol, dontResolveAlias);
-        markSymbolOfAliasDeclarationIfTypeOnly(
-          node,
-          moduleSymbol,
-          resolved,
-          /*overwriteEmpty*/
-          false
-        );
-        return resolved;
-      }
-      markSymbolOfAliasDeclarationIfTypeOnly(
-        node,
-        exportDefaultSymbol,
-        /*finalTarget*/
-        void 0,
-        /*overwriteEmpty*/
-        false
-      );
-      return exportDefaultSymbol;
-    }
-    function getModuleSpecifierForImportOrExport(node) {
-      switch (node.kind) {
-        case 272 /* ImportClause */:
-          return node.parent.moduleSpecifier;
-        case 270 /* ImportEqualsDeclaration */:
-          return isExternalModuleReference(node.moduleReference) ? node.moduleReference.expression : void 0;
-        case 273 /* NamespaceImport */:
-          return node.parent.parent.moduleSpecifier;
-        case 275 /* ImportSpecifier */:
-          return node.parent.parent.parent.moduleSpecifier;
-        case 280 /* ExportSpecifier */:
-          return node.parent.parent.moduleSpecifier;
-        default:
-          return Debug.assertNever(node);
-      }
-    }
-    function reportNonDefaultExport(moduleSymbol, node) {
-      var _a, _b, _c;
-      if ((_a = moduleSymbol.exports) == null ? void 0 : _a.has(node.symbol.escapedName)) {
-        error(
-          node.name,
-          Diagnostics.Module_0_has_no_default_export_Did_you_mean_to_use_import_1_from_0_instead,
-          symbolToString(moduleSymbol),
-          symbolToString(node.symbol)
-        );
-      } else {
-        const diagnostic = error(node.name, Diagnostics.Module_0_has_no_default_export, symbolToString(moduleSymbol));
-        const exportStar = (_b = moduleSymbol.exports) == null ? void 0 : _b.get("__export" /* ExportStar */);
-        if (exportStar) {
-          const defaultExport = (_c = exportStar.declarations) == null ? void 0 : _c.find((decl) => {
-            var _a2, _b2;
-            return !!(isExportDeclaration(decl) && decl.moduleSpecifier && ((_b2 = (_a2 = resolveExternalModuleName(decl, decl.moduleSpecifier)) == null ? void 0 : _a2.exports) == null ? void 0 : _b2.has("default" /* Default */)));
-          });
-          if (defaultExport) {
-            addRelatedInfo(diagnostic, createDiagnosticForNode(defaultExport, Diagnostics.export_Asterisk_does_not_re_export_a_default));
-          }
-        }
-      }
-    }
-    function getTargetOfNamespaceImport(node, dontResolveAlias) {
-      const moduleSpecifier = node.parent.parent.moduleSpecifier;
-      const immediate = resolveExternalModuleName(node, moduleSpecifier);
-      const resolved = resolveESModuleSymbol(
-        immediate,
-        moduleSpecifier,
-        dontResolveAlias,
-        /*suppressInteropError*/
-        false
-      );
-      markSymbolOfAliasDeclarationIfTypeOnly(
-        node,
-        immediate,
-        resolved,
-        /*overwriteEmpty*/
-        false
-      );
-      return resolved;
-    }
-    function getTargetOfNamespaceExport(node, dontResolveAlias) {
-      const moduleSpecifier = node.parent.moduleSpecifier;
-      const immediate = moduleSpecifier && resolveExternalModuleName(node, moduleSpecifier);
-      const resolved = moduleSpecifier && resolveESModuleSymbol(
-        immediate,
-        moduleSpecifier,
-        dontResolveAlias,
-        /*suppressInteropError*/
-        false
-      );
-      markSymbolOfAliasDeclarationIfTypeOnly(
-        node,
-        immediate,
-        resolved,
-        /*overwriteEmpty*/
-        false
-      );
-      return resolved;
-    }
-    function combineValueAndTypeSymbols(valueSymbol, typeSymbol) {
-      if (valueSymbol === unknownSymbol && typeSymbol === unknownSymbol) {
-        return unknownSymbol;
-      }
-      if (valueSymbol.flags & (788968 /* Type */ | 1920 /* Namespace */)) {
-        return valueSymbol;
-      }
-      const result = createSymbol(valueSymbol.flags | typeSymbol.flags, valueSymbol.escapedName);
-      Debug.assert(valueSymbol.declarations || typeSymbol.declarations);
-      result.declarations = deduplicate(concatenate(valueSymbol.declarations, typeSymbol.declarations), equateValues);
-      result.parent = valueSymbol.parent || typeSymbol.parent;
-      if (valueSymbol.valueDeclaration)
-        result.valueDeclaration = valueSymbol.valueDeclaration;
-      if (typeSymbol.members)
-        result.members = new Map(typeSymbol.members);
-      if (valueSymbol.exports)
-        result.exports = new Map(valueSymbol.exports);
-      return result;
-    }
-    function getExportOfModule(symbol, name, specifier, dontResolveAlias) {
-      var _a;
-      if (symbol.flags & 1536 /* Module */) {
-        const exportSymbol = getExportsOfSymbol(symbol).get(name.escapedText);
-        const resolved = resolveSymbol(exportSymbol, dontResolveAlias);
-        const exportStarDeclaration = (_a = getSymbolLinks(symbol).typeOnlyExportStarMap) == null ? void 0 : _a.get(name.escapedText);
-        markSymbolOfAliasDeclarationIfTypeOnly(
-          specifier,
-          exportSymbol,
-          resolved,
-          /*overwriteEmpty*/
-          false,
-          exportStarDeclaration,
-          name.escapedText
-        );
-        return resolved;
-      }
-    }
-    function getPropertyOfVariable(symbol, name) {
-      if (symbol.flags & 3 /* Variable */) {
-        const typeAnnotation = symbol.valueDeclaration.type;
-        if (typeAnnotation) {
-          return resolveSymbol(getPropertyOfType(getTypeFromTypeNode(typeAnnotation), name));
-        }
-      }
-    }
-    function getExternalModuleMember(node, specifier, dontResolveAlias = false) {
-      var _a;
-      const moduleSpecifier = getExternalModuleRequireArgument(node) || node.moduleSpecifier;
-      const moduleSymbol = resolveExternalModuleName(node, moduleSpecifier);
-      const name = !isPropertyAccessExpression(specifier) && specifier.propertyName || specifier.name;
-      if (!isIdentifier(name)) {
-        return void 0;
-      }
-      const suppressInteropError = name.escapedText === "default" /* Default */ && allowSyntheticDefaultImports;
-      const targetSymbol = resolveESModuleSymbol(
-        moduleSymbol,
-        moduleSpecifier,
-        /*dontResolveAlias*/
-        false,
-        suppressInteropError
-      );
-      if (targetSymbol) {
-        if (name.escapedText) {
-          if (isShorthandAmbientModuleSymbol(moduleSymbol)) {
-            return moduleSymbol;
-          }
-          let symbolFromVariable;
-          if (moduleSymbol && moduleSymbol.exports && moduleSymbol.exports.get("export=" /* ExportEquals */)) {
-            symbolFromVariable = getPropertyOfType(
-              getTypeOfSymbol(targetSymbol),
-              name.escapedText,
-              /*skipObjectFunctionPropertyAugment*/
-              true
-            );
-          } else {
-            symbolFromVariable = getPropertyOfVariable(targetSymbol, name.escapedText);
-          }
-          symbolFromVariable = resolveSymbol(symbolFromVariable, dontResolveAlias);
-          let symbolFromModule = getExportOfModule(targetSymbol, name, specifier, dontResolveAlias);
-          if (symbolFromModule === void 0 && name.escapedText === "default" /* Default */) {
-            const file = (_a = moduleSymbol.declarations) == null ? void 0 : _a.find(isSourceFile);
-            if (isOnlyImportedAsDefault(moduleSpecifier) || canHaveSyntheticDefault(file, moduleSymbol, dontResolveAlias, moduleSpecifier)) {
-              symbolFromModule = resolveExternalModuleSymbol(moduleSymbol, dontResolveAlias) || resolveSymbol(moduleSymbol, dontResolveAlias);
-            }
-          }
-          const symbol = symbolFromModule && symbolFromVariable && symbolFromModule !== symbolFromVariable ? combineValueAndTypeSymbols(symbolFromVariable, symbolFromModule) : symbolFromModule || symbolFromVariable;
-          if (!symbol) {
-            errorNoModuleMemberSymbol(moduleSymbol, targetSymbol, node, name);
-          }
-          return symbol;
-        }
-      }
-    }
-    function errorNoModuleMemberSymbol(moduleSymbol, targetSymbol, node, name) {
-      var _a;
-      const moduleName = getFullyQualifiedName(moduleSymbol, node);
-      const declarationName = declarationNameToString(name);
-      const suggestion = getSuggestedSymbolForNonexistentModule(name, targetSymbol);
-      if (suggestion !== void 0) {
-        const suggestionName = symbolToString(suggestion);
-        const diagnostic = error(name, Diagnostics._0_has_no_exported_member_named_1_Did_you_mean_2, moduleName, declarationName, suggestionName);
-        if (suggestion.valueDeclaration) {
-          addRelatedInfo(
-            diagnostic,
-            createDiagnosticForNode(suggestion.valueDeclaration, Diagnostics._0_is_declared_here, suggestionName)
-          );
-        }
-      } else {
-        if ((_a = moduleSymbol.exports) == null ? void 0 : _a.has("default" /* Default */)) {
-          error(
-            name,
-            Diagnostics.Module_0_has_no_exported_member_1_Did_you_mean_to_use_import_1_from_0_instead,
-            moduleName,
-            declarationName
-          );
-        } else {
-          reportNonExportedMember(node, name, declarationName, moduleSymbol, moduleName);
-        }
-      }
-    }
-    function reportNonExportedMember(node, name, declarationName, moduleSymbol, moduleName) {
-      var _a, _b;
-      const localSymbol = (_b = (_a = tryCast(moduleSymbol.valueDeclaration, canHaveLocals)) == null ? void 0 : _a.locals) == null ? void 0 : _b.get(name.escapedText);
-      const exports = moduleSymbol.exports;
-      if (localSymbol) {
-        const exportedEqualsSymbol = exports == null ? void 0 : exports.get("export=" /* ExportEquals */);
-        if (exportedEqualsSymbol) {
-          getSymbolIfSameReference(exportedEqualsSymbol, localSymbol) ? reportInvalidImportEqualsExportMember(node, name, declarationName, moduleName) : error(name, Diagnostics.Module_0_has_no_exported_member_1, moduleName, declarationName);
-        } else {
-          const exportedSymbol = exports ? find(symbolsToArray(exports), (symbol) => !!getSymbolIfSameReference(symbol, localSymbol)) : void 0;
-          const diagnostic = exportedSymbol ? error(name, Diagnostics.Module_0_declares_1_locally_but_it_is_exported_as_2, moduleName, declarationName, symbolToString(exportedSymbol)) : error(name, Diagnostics.Module_0_declares_1_locally_but_it_is_not_exported, moduleName, declarationName);
-          if (localSymbol.declarations) {
-            addRelatedInfo(
-              diagnostic,
-              ...map(localSymbol.declarations, (decl, index) => createDiagnosticForNode(decl, index === 0 ? Diagnostics._0_is_declared_here : Diagnostics.and_here, declarationName))
-            );
-          }
-        }
-      } else {
-        error(name, Diagnostics.Module_0_has_no_exported_member_1, moduleName, declarationName);
-      }
-    }
-    function reportInvalidImportEqualsExportMember(node, name, declarationName, moduleName) {
-      if (moduleKind >= 5 /* ES2015 */) {
-        const message = getESModuleInterop(compilerOptions) ? Diagnostics._0_can_only_be_imported_by_using_a_default_import : Diagnostics._0_can_only_be_imported_by_turning_on_the_esModuleInterop_flag_and_using_a_default_import;
-        error(name, message, declarationName);
-      } else {
-        if (isInJSFile(node)) {
-          const message = getESModuleInterop(compilerOptions) ? Diagnostics._0_can_only_be_imported_by_using_a_require_call_or_by_using_a_default_import : Diagnostics._0_can_only_be_imported_by_using_a_require_call_or_by_turning_on_the_esModuleInterop_flag_and_using_a_default_import;
-          error(name, message, declarationName);
-        } else {
-          const message = getESModuleInterop(compilerOptions) ? Diagnostics._0_can_only_be_imported_by_using_import_1_require_2_or_a_default_import : Diagnostics._0_can_only_be_imported_by_using_import_1_require_2_or_by_turning_on_the_esModuleInterop_flag_and_using_a_default_import;
-          error(name, message, declarationName, declarationName, moduleName);
-        }
-      }
-    }
-    function getTargetOfImportSpecifier(node, dontResolveAlias) {
-      if (isImportSpecifier(node) && idText(node.propertyName || node.name) === "default" /* Default */) {
-        const specifier = getModuleSpecifierForImportOrExport(node);
-        const moduleSymbol = specifier && resolveExternalModuleName(node, specifier);
-        if (moduleSymbol) {
-          return getTargetofModuleDefault(moduleSymbol, node, dontResolveAlias);
-        }
-      }
-      const root = isBindingElement(node) ? getRootDeclaration(node) : node.parent.parent.parent;
-      const commonJSPropertyAccess = getCommonJSPropertyAccess(root);
-      const resolved = getExternalModuleMember(root, commonJSPropertyAccess || node, dontResolveAlias);
-      const name = node.propertyName || node.name;
-      if (commonJSPropertyAccess && resolved && isIdentifier(name)) {
-        return resolveSymbol(getPropertyOfType(getTypeOfSymbol(resolved), name.escapedText), dontResolveAlias);
-      }
-      markSymbolOfAliasDeclarationIfTypeOnly(
-        node,
-        /*immediateTarget*/
-        void 0,
-        resolved,
-        /*overwriteEmpty*/
-        false
-      );
-      return resolved;
-    }
-    function getCommonJSPropertyAccess(node) {
-      if (isVariableDeclaration(node) && node.initializer && isPropertyAccessExpression(node.initializer)) {
-        return node.initializer;
-      }
-    }
-    function getTargetOfNamespaceExportDeclaration(node, dontResolveAlias) {
-      if (canHaveSymbol(node.parent)) {
-        const resolved = resolveExternalModuleSymbol(node.parent.symbol, dontResolveAlias);
-        markSymbolOfAliasDeclarationIfTypeOnly(
-          node,
-          /*immediateTarget*/
-          void 0,
-          resolved,
-          /*overwriteEmpty*/
-          false
-        );
-        return resolved;
-      }
-    }
-    function getTargetOfExportSpecifier(node, meaning, dontResolveAlias) {
-      if (idText(node.propertyName || node.name) === "default" /* Default */) {
-        const specifier = getModuleSpecifierForImportOrExport(node);
-        const moduleSymbol = specifier && resolveExternalModuleName(node, specifier);
-        if (moduleSymbol) {
-          return getTargetofModuleDefault(moduleSymbol, node, !!dontResolveAlias);
-        }
-      }
-      const resolved = node.parent.parent.moduleSpecifier ? getExternalModuleMember(node.parent.parent, node, dontResolveAlias) : resolveEntityName(
-        node.propertyName || node.name,
-        meaning,
-        /*ignoreErrors*/
-        false,
-        dontResolveAlias
-      );
-      markSymbolOfAliasDeclarationIfTypeOnly(
-        node,
-        /*immediateTarget*/
-        void 0,
-        resolved,
-        /*overwriteEmpty*/
-        false
-      );
-      return resolved;
-    }
-    function getTargetOfExportAssignment(node, dontResolveAlias) {
-      const expression = isExportAssignment(node) ? node.expression : node.right;
-      const resolved = getTargetOfAliasLikeExpression(expression, dontResolveAlias);
-      markSymbolOfAliasDeclarationIfTypeOnly(
-        node,
-        /*immediateTarget*/
-        void 0,
-        resolved,
-        /*overwriteEmpty*/
-        false
-      );
-      return resolved;
-    }
-    function getTargetOfAliasLikeExpression(expression, dontResolveAlias) {
-      if (isClassExpression(expression)) {
-        return checkExpressionCached(expression).symbol;
-      }
-      if (!isEntityName(expression) && !isEntityNameExpression(expression)) {
-        return void 0;
-      }
-      const aliasLike = resolveEntityName(
-        expression,
-        111551 /* Value */ | 788968 /* Type */ | 1920 /* Namespace */,
-        /*ignoreErrors*/
-        true,
-        dontResolveAlias
-      );
-      if (aliasLike) {
-        return aliasLike;
-      }
-      checkExpressionCached(expression);
-      return getNodeLinks(expression).resolvedSymbol;
-    }
-    function getTargetOfAccessExpression(node, dontRecursivelyResolve) {
-      if (!(isBinaryExpression(node.parent) && node.parent.left === node && node.parent.operatorToken.kind === 64 /* EqualsToken */)) {
-        return void 0;
-      }
-      return getTargetOfAliasLikeExpression(node.parent.right, dontRecursivelyResolve);
-    }
-    function getTargetOfAliasDeclaration(node, dontRecursivelyResolve = false) {
-      switch (node.kind) {
-        case 270 /* ImportEqualsDeclaration */:
-        case 259 /* VariableDeclaration */:
-          return getTargetOfImportEqualsDeclaration(node, dontRecursivelyResolve);
-        case 272 /* ImportClause */:
-          return getTargetOfImportClause(node, dontRecursivelyResolve);
-        case 273 /* NamespaceImport */:
-          return getTargetOfNamespaceImport(node, dontRecursivelyResolve);
-        case 279 /* NamespaceExport */:
-          return getTargetOfNamespaceExport(node, dontRecursivelyResolve);
-        case 275 /* ImportSpecifier */:
-        case 207 /* BindingElement */:
-          return getTargetOfImportSpecifier(node, dontRecursivelyResolve);
-        case 280 /* ExportSpecifier */:
-          return getTargetOfExportSpecifier(node, 111551 /* Value */ | 788968 /* Type */ | 1920 /* Namespace */, dontRecursivelyResolve);
-        case 276 /* ExportAssignment */:
-        case 225 /* BinaryExpression */:
-          return getTargetOfExportAssignment(node, dontRecursivelyResolve);
-        case 269 /* NamespaceExportDeclaration */:
-          return getTargetOfNamespaceExportDeclaration(node, dontRecursivelyResolve);
-        case 303 /* ShorthandPropertyAssignment */:
-          return resolveEntityName(
-            node.name,
-            111551 /* Value */ | 788968 /* Type */ | 1920 /* Namespace */,
-            /*ignoreErrors*/
-            true,
-            dontRecursivelyResolve
-          );
-        case 302 /* PropertyAssignment */:
-          return getTargetOfAliasLikeExpression(node.initializer, dontRecursivelyResolve);
-        case 211 /* ElementAccessExpression */:
-        case 210 /* PropertyAccessExpression */:
-          return getTargetOfAccessExpression(node, dontRecursivelyResolve);
-        default:
-          return Debug.fail();
-      }
-    }
-    function isNonLocalAlias(symbol, excludes = 111551 /* Value */ | 788968 /* Type */ | 1920 /* Namespace */) {
-      if (!symbol)
-        return false;
-      return (symbol.flags & (2097152 /* Alias */ | excludes)) === 2097152 /* Alias */ || !!(symbol.flags & 2097152 /* Alias */ && symbol.flags & 67108864 /* Assignment */);
-    }
-    function resolveSymbol(symbol, dontResolveAlias) {
-      return !dontResolveAlias && isNonLocalAlias(symbol) ? resolveAlias(symbol) : symbol;
-    }
-    function resolveAlias(symbol) {
-      Debug.assert((symbol.flags & 2097152 /* Alias */) !== 0, "Should only get Alias here.");
-      const links = getSymbolLinks(symbol);
-      if (!links.aliasTarget) {
-        links.aliasTarget = resolvingSymbol;
-        const node = getDeclarationOfAliasSymbol(symbol);
-        if (!node)
-          return Debug.fail();
-        const target = getTargetOfAliasDeclaration(node);
-        if (links.aliasTarget === resolvingSymbol) {
-          links.aliasTarget = target || unknownSymbol;
-        } else {
-          error(node, Diagnostics.Circular_definition_of_import_alias_0, symbolToString(symbol));
-        }
-      } else if (links.aliasTarget === resolvingSymbol) {
-        links.aliasTarget = unknownSymbol;
-      }
-      return links.aliasTarget;
-    }
-    function tryResolveAlias(symbol) {
-      const links = getSymbolLinks(symbol);
-      if (links.aliasTarget !== resolvingSymbol) {
-        return resolveAlias(symbol);
-      }
-      return void 0;
-    }
-    function getAllSymbolFlags(symbol) {
-      let flags = symbol.flags;
-      let seenSymbols;
-      while (symbol.flags & 2097152 /* Alias */) {
-        const target = resolveAlias(symbol);
-        if (target === unknownSymbol) {
-          return 67108863 /* All */;
-        }
-        if (target === symbol || (seenSymbols == null ? void 0 : seenSymbols.has(target))) {
-          break;
-        }
-        if (target.flags & 2097152 /* Alias */) {
-          if (seenSymbols) {
-            seenSymbols.add(target);
-          } else {
-            seenSymbols = /* @__PURE__ */ new Set([symbol, target]);
-          }
-        }
-        flags |= target.flags;
-        symbol = target;
-      }
-      return flags;
-    }
-    function markSymbolOfAliasDeclarationIfTypeOnly(aliasDeclaration, immediateTarget, finalTarget, overwriteEmpty, exportStarDeclaration, exportStarName) {
-      if (!aliasDeclaration || isPropertyAccessExpression(aliasDeclaration))
-        return false;
-      const sourceSymbol = getSymbolOfDeclaration(aliasDeclaration);
-      if (isTypeOnlyImportOrExportDeclaration(aliasDeclaration)) {
-        const links2 = getSymbolLinks(sourceSymbol);
-        links2.typeOnlyDeclaration = aliasDeclaration;
-        return true;
-      }
-      if (exportStarDeclaration) {
-        const links2 = getSymbolLinks(sourceSymbol);
-        links2.typeOnlyDeclaration = exportStarDeclaration;
-        if (sourceSymbol.escapedName !== exportStarName) {
-          links2.typeOnlyExportStarName = exportStarName;
-        }
-        return true;
-      }
-      const links = getSymbolLinks(sourceSymbol);
-      return markSymbolOfAliasDeclarationIfTypeOnlyWorker(links, immediateTarget, overwriteEmpty) || markSymbolOfAliasDeclarationIfTypeOnlyWorker(links, finalTarget, overwriteEmpty);
-    }
-    function markSymbolOfAliasDeclarationIfTypeOnlyWorker(aliasDeclarationLinks, target, overwriteEmpty) {
-      var _a;
-      if (target && (aliasDeclarationLinks.typeOnlyDeclaration === void 0 || overwriteEmpty && aliasDeclarationLinks.typeOnlyDeclaration === false)) {
-        const exportSymbol = ((_a = target.exports) == null ? void 0 : _a.get("export=" /* ExportEquals */)) ?? target;
-        const typeOnly = exportSymbol.declarations && find(exportSymbol.declarations, isTypeOnlyImportOrExportDeclaration);
-        aliasDeclarationLinks.typeOnlyDeclaration = typeOnly ?? getSymbolLinks(exportSymbol).typeOnlyDeclaration ?? false;
-      }
-      return !!aliasDeclarationLinks.typeOnlyDeclaration;
-    }
-    function getTypeOnlyAliasDeclaration(symbol, include) {
-      if (!(symbol.flags & 2097152 /* Alias */)) {
-        return void 0;
-      }
-      const links = getSymbolLinks(symbol);
-      if (include === void 0) {
-        return links.typeOnlyDeclaration || void 0;
-      }
-      if (links.typeOnlyDeclaration) {
-        const resolved = links.typeOnlyDeclaration.kind === 277 /* ExportDeclaration */ ? resolveSymbol(getExportsOfModule(links.typeOnlyDeclaration.symbol.parent).get(links.typeOnlyExportStarName || symbol.escapedName)) : resolveAlias(links.typeOnlyDeclaration.symbol);
-        return getAllSymbolFlags(resolved) & include ? links.typeOnlyDeclaration : void 0;
-      }
-      return void 0;
-    }
-    function markExportAsReferenced(node) {
-      if (!canCollectSymbolAliasAccessabilityData) {
-        return;
-      }
-      const symbol = getSymbolOfDeclaration(node);
-      const target = resolveAlias(symbol);
-      if (target) {
-        const markAlias = target === unknownSymbol || getAllSymbolFlags(target) & 111551 /* Value */ && !isConstEnumOrConstEnumOnlyModule(target) && !getTypeOnlyAliasDeclaration(symbol, 111551 /* Value */);
-        if (markAlias) {
-          markAliasSymbolAsReferenced(symbol);
-        }
-      }
-    }
-    function markAliasSymbolAsReferenced(symbol) {
-      Debug.assert(canCollectSymbolAliasAccessabilityData);
-      const links = getSymbolLinks(symbol);
-      if (!links.referenced) {
-        links.referenced = true;
-        const node = getDeclarationOfAliasSymbol(symbol);
-        if (!node)
-          return Debug.fail();
-        if (isInternalModuleImportEqualsDeclaration(node)) {
-          if (getAllSymbolFlags(resolveSymbol(symbol)) & 111551 /* Value */) {
-            checkExpressionCached(node.moduleReference);
-          }
-        }
-      }
-    }
-    function markConstEnumAliasAsReferenced(symbol) {
-      const links = getSymbolLinks(symbol);
-      if (!links.constEnumReferenced) {
-        links.constEnumReferenced = true;
-      }
-    }
-    function getSymbolOfPartOfRightHandSideOfImportEquals(entityName, dontResolveAlias) {
-      if (entityName.kind === 80 /* Identifier */ && isRightSideOfQualifiedNameOrPropertyAccess(entityName)) {
-        entityName = entityName.parent;
-      }
-      if (entityName.kind === 80 /* Identifier */ || entityName.parent.kind === 165 /* QualifiedName */) {
-        return resolveEntityName(
-          entityName,
-          1920 /* Namespace */,
-          /*ignoreErrors*/
-          false,
-          dontResolveAlias
-        );
-      } else {
-        Debug.assert(entityName.parent.kind === 270 /* ImportEqualsDeclaration */);
-        return resolveEntityName(
-          entityName,
-          111551 /* Value */ | 788968 /* Type */ | 1920 /* Namespace */,
-          /*ignoreErrors*/
-          false,
-          dontResolveAlias
-        );
-      }
-    }
-    function getFullyQualifiedName(symbol, containingLocation) {
-      return symbol.parent ? getFullyQualifiedName(symbol.parent, containingLocation) + "." + symbolToString(symbol) : symbolToString(
-        symbol,
-        containingLocation,
-        /*meaning*/
-        void 0,
-        32 /* DoNotIncludeSymbolChain */ | 4 /* AllowAnyNodeKind */
-      );
-    }
-    function getContainingQualifiedNameNode(node) {
-      while (isQualifiedName(node.parent)) {
-        node = node.parent;
-      }
-      return node;
-    }
-    function tryGetQualifiedNameAsValue(node) {
-      let left = getFirstIdentifier(node);
-      let symbol = resolveName(
-        left,
-        left.escapedText,
-        111551 /* Value */,
-        /*nameNotFoundMessage*/
-        void 0,
-        left,
-        /*isUse*/
-        true
-      );
-      if (!symbol) {
-        return void 0;
-      }
-      while (isQualifiedName(left.parent)) {
-        const type = getTypeOfSymbol(symbol);
-        symbol = getPropertyOfType(type, left.parent.right.escapedText);
-        if (!symbol) {
-          return void 0;
-        }
-        left = left.parent;
-      }
-      return symbol;
-    }
-    function resolveEntityName(name, meaning, ignoreErrors, dontResolveAlias, location) {
-      if (nodeIsMissing(name)) {
-        return void 0;
-      }
-      const namespaceMeaning = 1920 /* Namespace */ | (isInJSFile(name) ? meaning & 111551 /* Value */ : 0);
-      let symbol;
-      if (name.kind === 80 /* Identifier */) {
-        const message = meaning === namespaceMeaning || nodeIsSynthesized(name) ? Diagnostics.Cannot_find_namespace_0 : getCannotFindNameDiagnosticForName(getFirstIdentifier(name));
-        const symbolFromJSPrototype = isInJSFile(name) && !nodeIsSynthesized(name) ? resolveEntityNameFromAssignmentDeclaration(name, meaning) : void 0;
-        symbol = getMergedSymbol(resolveName(
-          location || name,
-          name.escapedText,
-          meaning,
-          ignoreErrors || symbolFromJSPrototype ? void 0 : message,
-          name,
-          /*isUse*/
-          true,
-          /*excludeGlobals*/
-          false
-        ));
-        if (!symbol) {
-          return getMergedSymbol(symbolFromJSPrototype);
-        }
-      } else if (name.kind === 165 /* QualifiedName */ || name.kind === 210 /* PropertyAccessExpression */) {
-        const left = name.kind === 165 /* QualifiedName */ ? name.left : name.expression;
-        const right = name.kind === 165 /* QualifiedName */ ? name.right : name.name;
-        let namespace = resolveEntityName(
-          left,
-          namespaceMeaning,
-          ignoreErrors,
-          /*dontResolveAlias*/
-          false,
-          location
-        );
-        if (!namespace || nodeIsMissing(right)) {
-          return void 0;
-        } else if (namespace === unknownSymbol) {
-          return namespace;
-        }
-        if (namespace.valueDeclaration && isInJSFile(namespace.valueDeclaration) && getEmitModuleResolutionKind(compilerOptions) !== 100 /* Bundler */ && isVariableDeclaration(namespace.valueDeclaration) && namespace.valueDeclaration.initializer && isCommonJsRequire(namespace.valueDeclaration.initializer)) {
-          const moduleName = namespace.valueDeclaration.initializer.arguments[0];
-          const moduleSym = resolveExternalModuleName(moduleName, moduleName);
-          if (moduleSym) {
-            const resolvedModuleSymbol = resolveExternalModuleSymbol(moduleSym);
-            if (resolvedModuleSymbol) {
-              namespace = resolvedModuleSymbol;
-            }
-          }
-        }
-        symbol = getMergedSymbol(getSymbol2(getExportsOfSymbol(namespace), right.escapedText, meaning));
-        if (!symbol && namespace.flags & 2097152 /* Alias */) {
-          symbol = getMergedSymbol(getSymbol2(getExportsOfSymbol(resolveAlias(namespace)), right.escapedText, meaning));
-        }
-        if (!symbol) {
-          if (!ignoreErrors) {
-            const namespaceName = getFullyQualifiedName(namespace);
-            const declarationName = declarationNameToString(right);
-            const suggestionForNonexistentModule = getSuggestedSymbolForNonexistentModule(right, namespace);
-            if (suggestionForNonexistentModule) {
-              error(right, Diagnostics._0_has_no_exported_member_named_1_Did_you_mean_2, namespaceName, declarationName, symbolToString(suggestionForNonexistentModule));
-              return void 0;
-            }
-            const containingQualifiedName = isQualifiedName(name) && getContainingQualifiedNameNode(name);
-            const canSuggestTypeof = globalObjectType && meaning & 788968 /* Type */ && containingQualifiedName && !isTypeOfExpression(containingQualifiedName.parent) && tryGetQualifiedNameAsValue(containingQualifiedName);
-            if (canSuggestTypeof) {
-              error(
-                containingQualifiedName,
-                Diagnostics._0_refers_to_a_value_but_is_being_used_as_a_type_here_Did_you_mean_typeof_0,
-                entityNameToString(containingQualifiedName)
-              );
-              return void 0;
-            }
-            if (meaning & 1920 /* Namespace */ && isQualifiedName(name.parent)) {
-              const exportedTypeSymbol = getMergedSymbol(getSymbol2(getExportsOfSymbol(namespace), right.escapedText, 788968 /* Type */));
-              if (exportedTypeSymbol) {
-                error(
-                  name.parent.right,
-                  Diagnostics.Cannot_access_0_1_because_0_is_a_type_but_not_a_namespace_Did_you_mean_to_retrieve_the_type_of_the_property_1_in_0_with_0_1,
-                  symbolToString(exportedTypeSymbol),
-                  unescapeLeadingUnderscores(name.parent.right.escapedText)
-                );
-                return void 0;
-              }
-            }
-            error(right, Diagnostics.Namespace_0_has_no_exported_member_1, namespaceName, declarationName);
-          }
-          return void 0;
-        }
-      } else {
-        Debug.assertNever(name, "Unknown entity name kind.");
-      }
-      Debug.assert((getCheckFlags(symbol) & 1 /* Instantiated */) === 0, "Should never get an instantiated symbol here.");
-      if (!nodeIsSynthesized(name) && isEntityName(name) && (symbol.flags & 2097152 /* Alias */ || name.parent.kind === 276 /* ExportAssignment */)) {
-        markSymbolOfAliasDeclarationIfTypeOnly(
-          getAliasDeclarationFromName(name),
-          symbol,
-          /*finalTarget*/
-          void 0,
-          /*overwriteEmpty*/
-          true
-        );
-      }
-      return symbol.flags & meaning || dontResolveAlias ? symbol : resolveAlias(symbol);
-    }
-    function resolveEntityNameFromAssignmentDeclaration(name, meaning) {
-      if (isJSDocTypeReference(name.parent)) {
-        const secondaryLocation = getAssignmentDeclarationLocation(name.parent);
-        if (secondaryLocation) {
-          return resolveName(
-            secondaryLocation,
-            name.escapedText,
-            meaning,
-            /*nameNotFoundMessage*/
-            void 0,
-            name,
-            /*isUse*/
-            true
-          );
-        }
-      }
-    }
-    function getAssignmentDeclarationLocation(node) {
-      const typeAlias = findAncestor(node, (node2) => !(isJSDocNode(node2) || node2.flags & 8388608 /* JSDoc */) ? "quit" : isJSDocTypeAlias(node2));
-      if (typeAlias) {
-        return;
-      }
-      const host2 = getJSDocHost(node);
-      if (host2 && isExpressionStatement(host2) && isPrototypePropertyAssignment(host2.expression)) {
-        const symbol = getSymbolOfDeclaration(host2.expression.left);
-        if (symbol) {
-          return getDeclarationOfJSPrototypeContainer(symbol);
-        }
-      }
-      if (host2 && isFunctionExpression(host2) && isPrototypePropertyAssignment(host2.parent) && isExpressionStatement(host2.parent.parent)) {
-        const symbol = getSymbolOfDeclaration(host2.parent.left);
-        if (symbol) {
-          return getDeclarationOfJSPrototypeContainer(symbol);
-        }
-      }
-      if (host2 && (isObjectLiteralMethod(host2) || isPropertyAssignment(host2)) && isBinaryExpression(host2.parent.parent) && getAssignmentDeclarationKind(host2.parent.parent) === 6 /* Prototype */) {
-        const symbol = getSymbolOfDeclaration(host2.parent.parent.left);
-        if (symbol) {
-          return getDeclarationOfJSPrototypeContainer(symbol);
-        }
-      }
-      const sig = getEffectiveJSDocHost(node);
-      if (sig && isFunctionLike(sig)) {
-        const symbol = getSymbolOfDeclaration(sig);
-        return symbol && symbol.valueDeclaration;
-      }
-    }
-    function getDeclarationOfJSPrototypeContainer(symbol) {
-      const decl = symbol.parent.valueDeclaration;
-      if (!decl) {
-        return void 0;
-      }
-      const initializer = isAssignmentDeclaration(decl) ? getAssignedExpandoInitializer(decl) : hasOnlyExpressionInitializer(decl) ? getDeclaredExpandoInitializer(decl) : void 0;
-      return initializer || decl;
-    }
-    function getExpandoSymbol(symbol) {
-      const decl = symbol.valueDeclaration;
-      if (!decl || !isInJSFile(decl) || symbol.flags & 524288 /* TypeAlias */ || getExpandoInitializer(
-        decl,
-        /*isPrototypeAssignment*/
-        false
-      )) {
-        return void 0;
-      }
-      const init = isVariableDeclaration(decl) ? getDeclaredExpandoInitializer(decl) : getAssignedExpandoInitializer(decl);
-      if (init) {
-        const initSymbol = getSymbolOfNode(init);
-        if (initSymbol) {
-          return mergeJSSymbols(initSymbol, symbol);
-        }
-      }
-    }
-    function resolveExternalModuleName(location, moduleReferenceExpression, ignoreErrors) {
-      const isClassic = getEmitModuleResolutionKind(compilerOptions) === 1 /* Classic */;
-      const errorMessage = isClassic ? Diagnostics.Cannot_find_module_0_Did_you_mean_to_set_the_moduleResolution_option_to_nodenext_or_to_add_aliases_to_the_paths_option : Diagnostics.Cannot_find_module_0_or_its_corresponding_type_declarations;
-      return resolveExternalModuleNameWorker(location, moduleReferenceExpression, ignoreErrors ? void 0 : errorMessage);
-    }
-    function resolveExternalModuleNameWorker(location, moduleReferenceExpression, moduleNotFoundError, isForAugmentation = false) {
-      return isStringLiteralLike(moduleReferenceExpression) ? resolveExternalModule(location, moduleReferenceExpression.text, moduleNotFoundError, moduleReferenceExpression, isForAugmentation) : void 0;
-    }
-    function resolveExternalModule(location, moduleReference, moduleNotFoundError, errorNode, isForAugmentation = false) {
-      var _a, _b, _c, _d, _e, _f, _g, _h, _i;
-      if (startsWith(moduleReference, "@types/")) {
-        const diag2 = Diagnostics.Cannot_import_type_declaration_files_Consider_importing_0_instead_of_1;
-        const withoutAtTypePrefix = removePrefix(moduleReference, "@types/");
-        error(errorNode, diag2, withoutAtTypePrefix, moduleReference);
-      }
-      const ambientModule = tryFindAmbientModule(
-        moduleReference,
-        /*withAugmentations*/
-        true
-      );
-      if (ambientModule) {
-        return ambientModule;
-      }
-      const currentSourceFile = getSourceFileOfNode(location);
-      const contextSpecifier = isStringLiteralLike(location) ? location : ((_a = findAncestor(location, isImportCall)) == null ? void 0 : _a.arguments[0]) || ((_b = findAncestor(location, isImportDeclaration)) == null ? void 0 : _b.moduleSpecifier) || ((_c = findAncestor(location, isExternalModuleImportEqualsDeclaration)) == null ? void 0 : _c.moduleReference.expression) || ((_d = findAncestor(location, isExportDeclaration)) == null ? void 0 : _d.moduleSpecifier) || ((_e = isModuleDeclaration(location) ? location : location.parent && isModuleDeclaration(location.parent) && location.parent.name === location ? location.parent : void 0) == null ? void 0 : _e.name) || ((_f = isLiteralImportTypeNode(location) ? location : void 0) == null ? void 0 : _f.argument.literal);
-      const mode = contextSpecifier && isStringLiteralLike(contextSpecifier) ? getModeForUsageLocation(currentSourceFile, contextSpecifier) : currentSourceFile.impliedNodeFormat;
-      const moduleResolutionKind = getEmitModuleResolutionKind(compilerOptions);
-      const resolvedModule = getResolvedModule(currentSourceFile, moduleReference, mode);
-      const resolutionDiagnostic = resolvedModule && getResolutionDiagnostic(compilerOptions, resolvedModule, currentSourceFile);
-      const sourceFile = resolvedModule && (!resolutionDiagnostic || resolutionDiagnostic === Diagnostics.Module_0_was_resolved_to_1_but_jsx_is_not_set) && host.getSourceFile(resolvedModule.resolvedFileName);
-      if (sourceFile) {
-        if (resolutionDiagnostic) {
-          error(errorNode, resolutionDiagnostic, moduleReference, resolvedModule.resolvedFileName);
-        }
-        if (resolvedModule.resolvedUsingTsExtension && isDeclarationFileName(moduleReference)) {
-          const importOrExport = ((_g = findAncestor(location, isImportDeclaration)) == null ? void 0 : _g.importClause) || findAncestor(location, or(isImportEqualsDeclaration, isExportDeclaration));
-          if (importOrExport && !importOrExport.isTypeOnly || findAncestor(location, isImportCall)) {
-            error(
-              errorNode,
-              Diagnostics.A_declaration_file_cannot_be_imported_without_import_type_Did_you_mean_to_import_an_implementation_file_0_instead,
-              getSuggestedImportSource(Debug.checkDefined(tryExtractTSExtension(moduleReference)))
-            );
-          }
-        } else if (resolvedModule.resolvedUsingTsExtension && !shouldAllowImportingTsExtension(compilerOptions, currentSourceFile.fileName)) {
-          const tsExtension = Debug.checkDefined(tryExtractTSExtension(moduleReference));
-          error(errorNode, Diagnostics.An_import_path_can_only_end_with_a_0_extension_when_allowImportingTsExtensions_is_enabled, tsExtension);
-        }
-        if (sourceFile.symbol) {
-          if (resolvedModule.isExternalLibraryImport && !resolutionExtensionIsTSOrJson(resolvedModule.extension)) {
-            errorOnImplicitAnyModule(
-              /*isError*/
-              false,
-              errorNode,
-              currentSourceFile,
-              mode,
-              resolvedModule,
-              moduleReference
-            );
-          }
-          if (moduleResolutionKind === 3 /* Node16 */ || moduleResolutionKind === 99 /* NodeNext */) {
-            const isSyncImport = currentSourceFile.impliedNodeFormat === 1 /* CommonJS */ && !findAncestor(location, isImportCall) || !!findAncestor(location, isImportEqualsDeclaration);
-            const overrideClauseHost = findAncestor(location, (l) => isImportTypeNode(l) || isExportDeclaration(l) || isImportDeclaration(l));
-            const overrideClause = overrideClauseHost && isImportTypeNode(overrideClauseHost) ? (_h = overrideClauseHost.assertions) == null ? void 0 : _h.assertClause : overrideClauseHost == null ? void 0 : overrideClauseHost.assertClause;
-            if (isSyncImport && sourceFile.impliedNodeFormat === 99 /* ESNext */ && !getResolutionModeOverrideForClause(overrideClause)) {
-              if (findAncestor(location, isImportEqualsDeclaration)) {
-                error(errorNode, Diagnostics.Module_0_cannot_be_imported_using_this_construct_The_specifier_only_resolves_to_an_ES_module_which_cannot_be_imported_with_require_Use_an_ECMAScript_import_instead, moduleReference);
-              } else {
-                let diagnosticDetails;
-                const ext = tryGetExtensionFromPath2(currentSourceFile.fileName);
-                if (ext === ".ts" /* Ts */ || ext === ".js" /* Js */ || ext === ".tsx" /* Tsx */ || ext === ".jsx" /* Jsx */) {
-                  const scope = currentSourceFile.packageJsonScope;
-                  const targetExt = ext === ".ts" /* Ts */ ? ".mts" /* Mts */ : ext === ".js" /* Js */ ? ".mjs" /* Mjs */ : void 0;
-                  if (scope && !scope.contents.packageJsonContent.type) {
-                    if (targetExt) {
-                      diagnosticDetails = chainDiagnosticMessages(
-                        /*details*/
-                        void 0,
-                        Diagnostics.To_convert_this_file_to_an_ECMAScript_module_change_its_file_extension_to_0_or_add_the_field_type_Colon_module_to_1,
-                        targetExt,
-                        combinePaths(scope.packageDirectory, "package.json")
-                      );
-                    } else {
-                      diagnosticDetails = chainDiagnosticMessages(
-                        /*details*/
-                        void 0,
-                        Diagnostics.To_convert_this_file_to_an_ECMAScript_module_add_the_field_type_Colon_module_to_0,
-                        combinePaths(scope.packageDirectory, "package.json")
-                      );
-                    }
-                  } else {
-                    if (targetExt) {
-                      diagnosticDetails = chainDiagnosticMessages(
-                        /*details*/
-                        void 0,
-                        Diagnostics.To_convert_this_file_to_an_ECMAScript_module_change_its_file_extension_to_0_or_create_a_local_package_json_file_with_type_Colon_module,
-                        targetExt
-                      );
-                    } else {
-                      diagnosticDetails = chainDiagnosticMessages(
-                        /*details*/
-                        void 0,
-                        Diagnostics.To_convert_this_file_to_an_ECMAScript_module_create_a_local_package_json_file_with_type_Colon_module
-                      );
-                    }
-                  }
-                }
-                diagnostics.add(createDiagnosticForNodeFromMessageChain(getSourceFileOfNode(errorNode), errorNode, chainDiagnosticMessages(
-                  diagnosticDetails,
-                  Diagnostics.The_current_file_is_a_CommonJS_module_whose_imports_will_produce_require_calls_however_the_referenced_file_is_an_ECMAScript_module_and_cannot_be_imported_with_require_Consider_writing_a_dynamic_import_0_call_instead,
-                  moduleReference
-                )));
-              }
-            }
-          }
-          return getMergedSymbol(sourceFile.symbol);
-        }
-        if (moduleNotFoundError) {
-          error(errorNode, Diagnostics.File_0_is_not_a_module, sourceFile.fileName);
-        }
-        return void 0;
-      }
-      if (patternAmbientModules) {
-        const pattern = findBestPatternMatch(patternAmbientModules, (_) => _.pattern, moduleReference);
-        if (pattern) {
-          const augmentation = patternAmbientModuleAugmentations && patternAmbientModuleAugmentations.get(moduleReference);
-          if (augmentation) {
-            return getMergedSymbol(augmentation);
-          }
-          return getMergedSymbol(pattern.symbol);
-        }
-      }
-      if (resolvedModule && !resolutionExtensionIsTSOrJson(resolvedModule.extension) && resolutionDiagnostic === void 0 || resolutionDiagnostic === Diagnostics.Could_not_find_a_declaration_file_for_module_0_1_implicitly_has_an_any_type) {
-        if (isForAugmentation) {
-          const diag2 = Diagnostics.Invalid_module_name_in_augmentation_Module_0_resolves_to_an_untyped_module_at_1_which_cannot_be_augmented;
-          error(errorNode, diag2, moduleReference, resolvedModule.resolvedFileName);
-        } else {
-          errorOnImplicitAnyModule(
-            /*isError*/
-            noImplicitAny && !!moduleNotFoundError,
-            errorNode,
-            currentSourceFile,
-            mode,
-            resolvedModule,
-            moduleReference
-          );
-        }
-        return void 0;
-      }
-      if (moduleNotFoundError) {
-        if (resolvedModule) {
-          const redirect = host.getProjectReferenceRedirect(resolvedModule.resolvedFileName);
-          if (redirect) {
-            error(errorNode, Diagnostics.Output_file_0_has_not_been_built_from_source_file_1, redirect, resolvedModule.resolvedFileName);
-            return void 0;
-          }
-        }
-        if (resolutionDiagnostic) {
-          error(errorNode, resolutionDiagnostic, moduleReference, resolvedModule.resolvedFileName);
-        } else {
-          const isExtensionlessRelativePathImport = pathIsRelative(moduleReference) && !hasExtension(moduleReference);
-          const resolutionIsNode16OrNext = moduleResolutionKind === 3 /* Node16 */ || moduleResolutionKind === 99 /* NodeNext */;
-          if (!getResolveJsonModule(compilerOptions) && fileExtensionIs(moduleReference, ".json" /* Json */) && moduleResolutionKind !== 1 /* Classic */ && hasJsonModuleEmitEnabled(compilerOptions)) {
-            error(errorNode, Diagnostics.Cannot_find_module_0_Consider_using_resolveJsonModule_to_import_module_with_json_extension, moduleReference);
-          } else if (mode === 99 /* ESNext */ && resolutionIsNode16OrNext && isExtensionlessRelativePathImport) {
-            const absoluteRef = getNormalizedAbsolutePath(moduleReference, getDirectoryPath(currentSourceFile.path));
-            const suggestedExt = (_i = suggestedExtensions.find(([actualExt, _importExt]) => host.fileExists(absoluteRef + actualExt))) == null ? void 0 : _i[1];
-            if (suggestedExt) {
-              error(
-                errorNode,
-                Diagnostics.Relative_import_paths_need_explicit_file_extensions_in_EcmaScript_imports_when_moduleResolution_is_node16_or_nodenext_Did_you_mean_0,
-                moduleReference + suggestedExt
-              );
-            } else {
-              error(errorNode, Diagnostics.Relative_import_paths_need_explicit_file_extensions_in_EcmaScript_imports_when_moduleResolution_is_node16_or_nodenext_Consider_adding_an_extension_to_the_import_path);
-            }
-          } else {
-            error(errorNode, moduleNotFoundError, moduleReference);
-          }
-        }
-      }
-      return void 0;
-      function getSuggestedImportSource(tsExtension) {
-        const importSourceWithoutExtension = removeExtension(moduleReference, tsExtension);
-        if (emitModuleKindIsNonNodeESM(moduleKind) || mode === 99 /* ESNext */) {
-          const preferTs = isDeclarationFileName(moduleReference) && shouldAllowImportingTsExtension(compilerOptions);
-          const ext = tsExtension === ".mts" /* Mts */ || tsExtension === ".d.mts" /* Dmts */ ? preferTs ? ".mts" : ".mjs" : tsExtension === ".cts" /* Cts */ || tsExtension === ".d.mts" /* Dmts */ ? preferTs ? ".cts" : ".cjs" : preferTs ? ".ts" : ".js";
-          return importSourceWithoutExtension + ext;
-        }
-        return importSourceWithoutExtension;
-      }
-    }
-    function errorOnImplicitAnyModule(isError, errorNode, sourceFile, mode, { packageId, resolvedFileName }, moduleReference) {
-      let errorInfo;
-      if (!isExternalModuleNameRelative(moduleReference) && packageId) {
-        errorInfo = createModuleNotFoundChain(sourceFile, host, moduleReference, mode, packageId.name);
-      }
-      errorOrSuggestion(isError, errorNode, chainDiagnosticMessages(
-        errorInfo,
-        Diagnostics.Could_not_find_a_declaration_file_for_module_0_1_implicitly_has_an_any_type,
-        moduleReference,
-        resolvedFileName
-      ));
-    }
-    function resolveExternalModuleSymbol(moduleSymbol, dontResolveAlias) {
-      if (moduleSymbol == null ? void 0 : moduleSymbol.exports) {
-        const exportEquals = resolveSymbol(moduleSymbol.exports.get("export=" /* ExportEquals */), dontResolveAlias);
-        const exported = getCommonJsExportEquals(getMergedSymbol(exportEquals), getMergedSymbol(moduleSymbol));
-        return getMergedSymbol(exported) || moduleSymbol;
-      }
-      return void 0;
-    }
-    function getCommonJsExportEquals(exported, moduleSymbol) {
-      if (!exported || exported === unknownSymbol || exported === moduleSymbol || moduleSymbol.exports.size === 1 || exported.flags & 2097152 /* Alias */) {
-        return exported;
-      }
-      const links = getSymbolLinks(exported);
-      if (links.cjsExportMerged) {
-        return links.cjsExportMerged;
-      }
-      const merged = exported.flags & 33554432 /* Transient */ ? exported : cloneSymbol(exported);
-      merged.flags = merged.flags | 512 /* ValueModule */;
-      if (merged.exports === void 0) {
-        merged.exports = createSymbolTable();
-      }
-      moduleSymbol.exports.forEach((s, name) => {
-        if (name === "export=" /* ExportEquals */)
-          return;
-        merged.exports.set(name, merged.exports.has(name) ? mergeSymbol(merged.exports.get(name), s) : s);
-      });
-      if (merged === exported) {
-        getSymbolLinks(merged).resolvedExports = void 0;
-        getSymbolLinks(merged).resolvedMembers = void 0;
-      }
-      getSymbolLinks(merged).cjsExportMerged = merged;
-      return links.cjsExportMerged = merged;
-    }
-    function resolveESModuleSymbol(moduleSymbol, referencingLocation, dontResolveAlias, suppressInteropError) {
-      var _a;
-      const symbol = resolveExternalModuleSymbol(moduleSymbol, dontResolveAlias);
-      if (!dontResolveAlias && symbol) {
-        if (!suppressInteropError && !(symbol.flags & (1536 /* Module */ | 3 /* Variable */)) && !getDeclarationOfKind(symbol, 311 /* SourceFile */)) {
-          const compilerOptionName = moduleKind >= 5 /* ES2015 */ ? "allowSyntheticDefaultImports" : "esModuleInterop";
-          error(referencingLocation, Diagnostics.This_module_can_only_be_referenced_with_ECMAScript_imports_Slashexports_by_turning_on_the_0_flag_and_referencing_its_default_export, compilerOptionName);
-          return symbol;
-        }
-        const referenceParent = referencingLocation.parent;
-        if (isImportDeclaration(referenceParent) && getNamespaceDeclarationNode(referenceParent) || isImportCall(referenceParent)) {
-          const reference = isImportCall(referenceParent) ? referenceParent.arguments[0] : referenceParent.moduleSpecifier;
-          const type = getTypeOfSymbol(symbol);
-          const defaultOnlyType = getTypeWithSyntheticDefaultOnly(type, symbol, moduleSymbol, reference);
-          if (defaultOnlyType) {
-            return cloneTypeAsModuleType(symbol, defaultOnlyType, referenceParent);
-          }
-          const targetFile = (_a = moduleSymbol == null ? void 0 : moduleSymbol.declarations) == null ? void 0 : _a.find(isSourceFile);
-          const isEsmCjsRef = targetFile && isESMFormatImportImportingCommonjsFormatFile(getUsageModeForExpression(reference), targetFile.impliedNodeFormat);
-          if (getESModuleInterop(compilerOptions) || isEsmCjsRef) {
-            let sigs = getSignaturesOfStructuredType(type, 0 /* Call */);
-            if (!sigs || !sigs.length) {
-              sigs = getSignaturesOfStructuredType(type, 1 /* Construct */);
-            }
-            if (sigs && sigs.length || getPropertyOfType(
-              type,
-              "default" /* Default */,
-              /*skipObjectFunctionPropertyAugment*/
-              true
-            ) || isEsmCjsRef) {
-              const moduleType = type.flags & 3670016 /* StructuredType */ ? getTypeWithSyntheticDefaultImportType(type, symbol, moduleSymbol, reference) : createDefaultPropertyWrapperForModule(symbol, symbol.parent);
-              return cloneTypeAsModuleType(symbol, moduleType, referenceParent);
-            }
-          }
-        }
-      }
-      return symbol;
-    }
-    function cloneTypeAsModuleType(symbol, moduleType, referenceParent) {
-      const result = createSymbol(symbol.flags, symbol.escapedName);
-      result.declarations = symbol.declarations ? symbol.declarations.slice() : [];
-      result.parent = symbol.parent;
-      result.links.target = symbol;
-      result.links.originatingImport = referenceParent;
-      if (symbol.valueDeclaration)
-        result.valueDeclaration = symbol.valueDeclaration;
-      if (symbol.constEnumOnlyModule)
-        result.constEnumOnlyModule = true;
-      if (symbol.members)
-        result.members = new Map(symbol.members);
-      if (symbol.exports)
-        result.exports = new Map(symbol.exports);
-      const resolvedModuleType = resolveStructuredTypeMembers(moduleType);
-      result.links.type = createAnonymousType(result, resolvedModuleType.members, emptyArray, emptyArray, resolvedModuleType.indexInfos);
-      return result;
-    }
-    function hasExportAssignmentSymbol(moduleSymbol) {
-      return moduleSymbol.exports.get("export=" /* ExportEquals */) !== void 0;
-    }
-    function getExportsOfModuleAsArray(moduleSymbol) {
-      return symbolsToArray(getExportsOfModule(moduleSymbol));
-    }
-    function getExportsAndPropertiesOfModule(moduleSymbol) {
-      const exports = getExportsOfModuleAsArray(moduleSymbol);
-      const exportEquals = resolveExternalModuleSymbol(moduleSymbol);
-      if (exportEquals !== moduleSymbol) {
-        const type = getTypeOfSymbol(exportEquals);
-        if (shouldTreatPropertiesOfExternalModuleAsExports(type)) {
-          addRange(exports, getPropertiesOfType(type));
-        }
-      }
-      return exports;
-    }
-    function forEachExportAndPropertyOfModule(moduleSymbol, cb) {
-      const exports = getExportsOfModule(moduleSymbol);
-      exports.forEach((symbol, key) => {
-        if (!isReservedMemberName(key)) {
-          cb(symbol, key);
-        }
-      });
-      const exportEquals = resolveExternalModuleSymbol(moduleSymbol);
-      if (exportEquals !== moduleSymbol) {
-        const type = getTypeOfSymbol(exportEquals);
-        if (shouldTreatPropertiesOfExternalModuleAsExports(type)) {
-          forEachPropertyOfType(type, (symbol, escapedName) => {
-            cb(symbol, escapedName);
-          });
-        }
-      }
-    }
-    function tryGetMemberInModuleExports(memberName, moduleSymbol) {
-      const symbolTable = getExportsOfModule(moduleSymbol);
-      if (symbolTable) {
-        return symbolTable.get(memberName);
-      }
-    }
-    function tryGetMemberInModuleExportsAndProperties(memberName, moduleSymbol) {
-      const symbol = tryGetMemberInModuleExports(memberName, moduleSymbol);
-      if (symbol) {
-        return symbol;
-      }
-      const exportEquals = resolveExternalModuleSymbol(moduleSymbol);
-      if (exportEquals === moduleSymbol) {
-        return void 0;
-      }
-      const type = getTypeOfSymbol(exportEquals);
-      return shouldTreatPropertiesOfExternalModuleAsExports(type) ? getPropertyOfType(type, memberName) : void 0;
-    }
-    function shouldTreatPropertiesOfExternalModuleAsExports(resolvedExternalModuleType) {
-      return !(resolvedExternalModuleType.flags & 402784252 /* Primitive */ || getObjectFlags(resolvedExternalModuleType) & 1 /* Class */ || // `isArrayOrTupleLikeType` is too expensive to use in this auto-imports hot path
-      isArrayType(resolvedExternalModuleType) || isTupleType(resolvedExternalModuleType));
-    }
-    function getExportsOfSymbol(symbol) {
-      return symbol.flags & 6256 /* LateBindingContainer */ ? getResolvedMembersOrExportsOfSymbol(symbol, "resolvedExports" /* resolvedExports */) : symbol.flags & 1536 /* Module */ ? getExportsOfModule(symbol) : symbol.exports || emptySymbols;
-    }
-    function getExportsOfModule(moduleSymbol) {
-      const links = getSymbolLinks(moduleSymbol);
-      if (!links.resolvedExports) {
-        const { exports, typeOnlyExportStarMap } = getExportsOfModuleWorker(moduleSymbol);
-        links.resolvedExports = exports;
-        links.typeOnlyExportStarMap = typeOnlyExportStarMap;
-      }
-      return links.resolvedExports;
-    }
-    function extendExportSymbols(target, source, lookupTable, exportNode) {
-      if (!source)
-        return;
-      source.forEach((sourceSymbol, id) => {
-        if (id === "default" /* Default */)
-          return;
-        const targetSymbol = target.get(id);
-        if (!targetSymbol) {
-          target.set(id, sourceSymbol);
-          if (lookupTable && exportNode) {
-            lookupTable.set(id, {
-              specifierText: getTextOfNode(exportNode.moduleSpecifier)
-            });
-          }
-        } else if (lookupTable && exportNode && targetSymbol && resolveSymbol(targetSymbol) !== resolveSymbol(sourceSymbol)) {
-          const collisionTracker = lookupTable.get(id);
-          if (!collisionTracker.exportsWithDuplicate) {
-            collisionTracker.exportsWithDuplicate = [exportNode];
-          } else {
-            collisionTracker.exportsWithDuplicate.push(exportNode);
-          }
-        }
-      });
-    }
-    function getExportsOfModuleWorker(moduleSymbol) {
-      const visitedSymbols = [];
-      let typeOnlyExportStarMap;
-      const nonTypeOnlyNames = /* @__PURE__ */ new Set();
-      moduleSymbol = resolveExternalModuleSymbol(moduleSymbol);
-      const exports = visit(moduleSymbol) || emptySymbols;
-      if (typeOnlyExportStarMap) {
-        nonTypeOnlyNames.forEach((name) => typeOnlyExportStarMap.delete(name));
-      }
-      return {
-        exports,
-        typeOnlyExportStarMap
-      };
-      function visit(symbol, exportStar, isTypeOnly) {
-        if (!isTypeOnly && (symbol == null ? void 0 : symbol.exports)) {
-          symbol.exports.forEach((_, name) => nonTypeOnlyNames.add(name));
-        }
-        if (!(symbol && symbol.exports && pushIfUnique(visitedSymbols, symbol))) {
-          return;
-        }
-        const symbols = new Map(symbol.exports);
-        const exportStars = symbol.exports.get("__export" /* ExportStar */);
-        if (exportStars) {
-          const nestedSymbols = createSymbolTable();
-          const lookupTable = /* @__PURE__ */ new Map();
-          if (exportStars.declarations) {
-            for (const node of exportStars.declarations) {
-              const resolvedModule = resolveExternalModuleName(node, node.moduleSpecifier);
-              const exportedSymbols = visit(resolvedModule, node, isTypeOnly || node.isTypeOnly);
-              extendExportSymbols(
-                nestedSymbols,
-                exportedSymbols,
-                lookupTable,
-                node
-              );
-            }
-          }
-          lookupTable.forEach(({ exportsWithDuplicate }, id) => {
-            if (id === "export=" || !(exportsWithDuplicate && exportsWithDuplicate.length) || symbols.has(id)) {
-              return;
-            }
-            for (const node of exportsWithDuplicate) {
-              diagnostics.add(createDiagnosticForNode(
-                node,
-                Diagnostics.Module_0_has_already_exported_a_member_named_1_Consider_explicitly_re_exporting_to_resolve_the_ambiguity,
-                lookupTable.get(id).specifierText,
-                unescapeLeadingUnderscores(id)
-              ));
-            }
-          });
-          extendExportSymbols(symbols, nestedSymbols);
-        }
-        if (exportStar == null ? void 0 : exportStar.isTypeOnly) {
-          typeOnlyExportStarMap ?? (typeOnlyExportStarMap = /* @__PURE__ */ new Map());
-          symbols.forEach((_, escapedName) => typeOnlyExportStarMap.set(
-            escapedName,
-            exportStar
-          ));
-        }
-        return symbols;
-      }
-    }
-    function getMergedSymbol(symbol) {
-      let merged;
-      return symbol && symbol.mergeId && (merged = mergedSymbols[symbol.mergeId]) ? merged : symbol;
-    }
-    function getSymbolOfDeclaration(node) {
-      return getMergedSymbol(node.symbol && getLateBoundSymbol(node.symbol));
-    }
-    function getSymbolOfNode(node) {
-      return canHaveSymbol(node) ? getSymbolOfDeclaration(node) : void 0;
-    }
-    function getParentOfSymbol(symbol) {
-      return getMergedSymbol(symbol.parent && getLateBoundSymbol(symbol.parent));
-    }
-    function getAlternativeContainingModules(symbol, enclosingDeclaration) {
-      const containingFile = getSourceFileOfNode(enclosingDeclaration);
-      const id = getNodeId(containingFile);
-      const links = getSymbolLinks(symbol);
-      let results;
-      if (links.extendedContainersByFile && (results = links.extendedContainersByFile.get(id))) {
-        return results;
-      }
-      if (containingFile && containingFile.imports) {
-        for (const importRef of containingFile.imports) {
-          if (nodeIsSynthesized(importRef))
-            continue;
-          const resolvedModule = resolveExternalModuleName(
-            enclosingDeclaration,
-            importRef,
-            /*ignoreErrors*/
-            true
-          );
-          if (!resolvedModule)
-            continue;
-          const ref = getAliasForSymbolInContainer(resolvedModule, symbol);
-          if (!ref)
-            continue;
-          results = append(results, resolvedModule);
-        }
-        if (length(results)) {
-          (links.extendedContainersByFile || (links.extendedContainersByFile = /* @__PURE__ */ new Map())).set(id, results);
-          return results;
-        }
-      }
-      if (links.extendedContainers) {
-        return links.extendedContainers;
-      }
-      const otherFiles = host.getSourceFiles();
-      for (const file of otherFiles) {
-        if (!isExternalModule(file))
-          continue;
-        const sym = getSymbolOfDeclaration(file);
-        const ref = getAliasForSymbolInContainer(sym, symbol);
-        if (!ref)
-          continue;
-        results = append(results, sym);
-      }
-      return links.extendedContainers = results || emptyArray;
-    }
-    function getContainersOfSymbol(symbol, enclosingDeclaration, meaning) {
-      const container = getParentOfSymbol(symbol);
-      if (container && !(symbol.flags & 262144 /* TypeParameter */)) {
-        const additionalContainers = mapDefined(container.declarations, fileSymbolIfFileSymbolExportEqualsContainer);
-        const reexportContainers = enclosingDeclaration && getAlternativeContainingModules(symbol, enclosingDeclaration);
-        const objectLiteralContainer = getVariableDeclarationOfObjectLiteral(container, meaning);
-        if (enclosingDeclaration && container.flags & getQualifiedLeftMeaning(meaning) && getAccessibleSymbolChain(
-          container,
-          enclosingDeclaration,
-          1920 /* Namespace */,
-          /*useOnlyExternalAliasing*/
-          false
-        )) {
-          return append(concatenate(concatenate([container], additionalContainers), reexportContainers), objectLiteralContainer);
-        }
-        const firstVariableMatch = !(container.flags & getQualifiedLeftMeaning(meaning)) && container.flags & 788968 /* Type */ && getDeclaredTypeOfSymbol(container).flags & 524288 /* Object */ && meaning === 111551 /* Value */ ? forEachSymbolTableInScope(enclosingDeclaration, (t) => {
-          return forEachEntry(t, (s) => {
-            if (s.flags & getQualifiedLeftMeaning(meaning) && getTypeOfSymbol(s) === getDeclaredTypeOfSymbol(container)) {
-              return s;
-            }
-          });
-        }) : void 0;
-        let res = firstVariableMatch ? [firstVariableMatch, ...additionalContainers, container] : [...additionalContainers, container];
-        res = append(res, objectLiteralContainer);
-        res = addRange(res, reexportContainers);
-        return res;
-      }
-      const candidates = mapDefined(symbol.declarations, (d) => {
-        if (!isAmbientModule(d) && d.parent) {
-          if (hasNonGlobalAugmentationExternalModuleSymbol(d.parent)) {
-            return getSymbolOfDeclaration(d.parent);
-          }
-          if (isModuleBlock(d.parent) && d.parent.parent && resolveExternalModuleSymbol(getSymbolOfDeclaration(d.parent.parent)) === symbol) {
-            return getSymbolOfDeclaration(d.parent.parent);
-          }
-        }
-        if (isClassExpression(d) && isBinaryExpression(d.parent) && d.parent.operatorToken.kind === 64 /* EqualsToken */ && isAccessExpression(d.parent.left) && isEntityNameExpression(d.parent.left.expression)) {
-          if (isModuleExportsAccessExpression(d.parent.left) || isExportsIdentifier(d.parent.left.expression)) {
-            return getSymbolOfDeclaration(getSourceFileOfNode(d));
-          }
-          checkExpressionCached(d.parent.left.expression);
-          return getNodeLinks(d.parent.left.expression).resolvedSymbol;
-        }
-      });
-      if (!length(candidates)) {
-        return void 0;
-      }
-      return mapDefined(candidates, (candidate) => getAliasForSymbolInContainer(candidate, symbol) ? candidate : void 0);
-      function fileSymbolIfFileSymbolExportEqualsContainer(d) {
-        return container && getFileSymbolIfFileSymbolExportEqualsContainer(d, container);
-      }
-    }
-    function getVariableDeclarationOfObjectLiteral(symbol, meaning) {
-      const firstDecl = !!length(symbol.declarations) && first(symbol.declarations);
-      if (meaning & 111551 /* Value */ && firstDecl && firstDecl.parent && isVariableDeclaration(firstDecl.parent)) {
-        if (isObjectLiteralExpression(firstDecl) && firstDecl === firstDecl.parent.initializer || isTypeLiteralNode(firstDecl) && firstDecl === firstDecl.parent.type) {
-          return getSymbolOfDeclaration(firstDecl.parent);
-        }
-      }
-    }
-    function getFileSymbolIfFileSymbolExportEqualsContainer(d, container) {
-      const fileSymbol = getExternalModuleContainer(d);
-      const exported = fileSymbol && fileSymbol.exports && fileSymbol.exports.get("export=" /* ExportEquals */);
-      return exported && getSymbolIfSameReference(exported, container) ? fileSymbol : void 0;
-    }
-    function getAliasForSymbolInContainer(container, symbol) {
-      if (container === getParentOfSymbol(symbol)) {
-        return symbol;
-      }
-      const exportEquals = container.exports && container.exports.get("export=" /* ExportEquals */);
-      if (exportEquals && getSymbolIfSameReference(exportEquals, symbol)) {
-        return container;
-      }
-      const exports = getExportsOfSymbol(container);
-      const quick = exports.get(symbol.escapedName);
-      if (quick && getSymbolIfSameReference(quick, symbol)) {
-        return quick;
-      }
-      return forEachEntry(exports, (exported) => {
-        if (getSymbolIfSameReference(exported, symbol)) {
-          return exported;
-        }
-      });
-    }
-    function getSymbolIfSameReference(s1, s2) {
-      if (getMergedSymbol(resolveSymbol(getMergedSymbol(s1))) === getMergedSymbol(resolveSymbol(getMergedSymbol(s2)))) {
-        return s1;
-      }
-    }
-    function getExportSymbolOfValueSymbolIfExported(symbol) {
-      return getMergedSymbol(symbol && (symbol.flags & 1048576 /* ExportValue */) !== 0 && symbol.exportSymbol || symbol);
-    }
-    function symbolIsValue(symbol, includeTypeOnlyMembers) {
-      return !!(symbol.flags & 111551 /* Value */ || symbol.flags & 2097152 /* Alias */ && getAllSymbolFlags(symbol) & 111551 /* Value */ && (includeTypeOnlyMembers || !getTypeOnlyAliasDeclaration(symbol)));
-    }
-    function findConstructorDeclaration(node) {
-      const members = node.members;
-      for (const member of members) {
-        if (member.kind === 175 /* Constructor */ && nodeIsPresent(member.body)) {
-          return member;
-        }
-      }
-    }
-    function createType(flags) {
-      var _a;
-      const result = new Type27(checker, flags);
-      typeCount++;
-      result.id = typeCount;
-      (_a = tracing) == null ? void 0 : _a.recordType(result);
-      return result;
-    }
-    function createTypeWithSymbol(flags, symbol) {
-      const result = createType(flags);
-      result.symbol = symbol;
-      return result;
-    }
-    function createOriginType(flags) {
-      return new Type27(checker, flags);
-    }
-    function createIntrinsicType(kind, intrinsicName, objectFlags = 0 /* None */) {
-      const type = createType(kind);
-      type.intrinsicName = intrinsicName;
-      type.objectFlags = objectFlags;
-      return type;
-    }
-    function createObjectType(objectFlags, symbol) {
-      const type = createTypeWithSymbol(524288 /* Object */, symbol);
-      type.objectFlags = objectFlags;
-      type.members = void 0;
-      type.properties = void 0;
-      type.callSignatures = void 0;
-      type.constructSignatures = void 0;
-      type.indexInfos = void 0;
-      return type;
-    }
-    function createTypeofType() {
-      return getUnionType(arrayFrom(typeofNEFacts.keys(), getStringLiteralType));
-    }
-    function createTypeParameter(symbol) {
-      return createTypeWithSymbol(262144 /* TypeParameter */, symbol);
-    }
-    function isReservedMemberName(name) {
-      return name.charCodeAt(0) === 95 /* _ */ && name.charCodeAt(1) === 95 /* _ */ && name.charCodeAt(2) !== 95 /* _ */ && name.charCodeAt(2) !== 64 /* at */ && name.charCodeAt(2) !== 35 /* hash */;
-    }
-    function getNamedMembers(members) {
-      let result;
-      members.forEach((symbol, id) => {
-        if (isNamedMember(symbol, id)) {
-          (result || (result = [])).push(symbol);
-        }
-      });
-      return result || emptyArray;
-    }
-    function isNamedMember(member, escapedName) {
-      return !isReservedMemberName(escapedName) && symbolIsValue(member);
-    }
-    function getNamedOrIndexSignatureMembers(members) {
-      const result = getNamedMembers(members);
-      const index = getIndexSymbolFromSymbolTable(members);
-      return index ? concatenate(result, [index]) : result;
-    }
-    function setStructuredTypeMembers(type, members, callSignatures, constructSignatures, indexInfos) {
-      const resolved = type;
-      resolved.members = members;
-      resolved.properties = emptyArray;
-      resolved.callSignatures = callSignatures;
-      resolved.constructSignatures = constructSignatures;
-      resolved.indexInfos = indexInfos;
-      if (members !== emptySymbols)
-        resolved.properties = getNamedMembers(members);
-      return resolved;
-    }
-    function createAnonymousType(symbol, members, callSignatures, constructSignatures, indexInfos) {
-      return setStructuredTypeMembers(
-        createObjectType(16 /* Anonymous */, symbol),
-        members,
-        callSignatures,
-        constructSignatures,
-        indexInfos
-      );
-    }
-    function getResolvedTypeWithoutAbstractConstructSignatures(type) {
-      if (type.constructSignatures.length === 0)
-        return type;
-      if (type.objectTypeWithoutAbstractConstructSignatures)
-        return type.objectTypeWithoutAbstractConstructSignatures;
-      const constructSignatures = filter(type.constructSignatures, (signature) => !(signature.flags & 4 /* Abstract */));
-      if (type.constructSignatures === constructSignatures)
-        return type;
-      const typeCopy = createAnonymousType(
-        type.symbol,
-        type.members,
-        type.callSignatures,
-        some(constructSignatures) ? constructSignatures : emptyArray,
-        type.indexInfos
-      );
-      type.objectTypeWithoutAbstractConstructSignatures = typeCopy;
-      typeCopy.objectTypeWithoutAbstractConstructSignatures = typeCopy;
-      return typeCopy;
-    }
-    function forEachSymbolTableInScope(enclosingDeclaration, callback) {
-      let result;
-      for (let location = enclosingDeclaration; location; location = location.parent) {
-        if (canHaveLocals(location) && location.locals && !isGlobalSourceFile(location)) {
-          if (result = callback(
-            location.locals,
-            /*ignoreQualification*/
-            void 0,
-            /*isLocalNameLookup*/
-            true,
-            location
-          )) {
-            return result;
-          }
-        }
-        switch (location.kind) {
-          case 311 /* SourceFile */:
-            if (!isExternalOrCommonJsModule(location)) {
-              break;
-            }
-          case 266 /* ModuleDeclaration */:
-            const sym = getSymbolOfDeclaration(location);
-            if (result = callback(
-              (sym == null ? void 0 : sym.exports) || emptySymbols,
-              /*ignoreQualification*/
-              void 0,
-              /*isLocalNameLookup*/
-              true,
-              location
-            )) {
-              return result;
-            }
-            break;
-          case 262 /* ClassDeclaration */:
-          case 230 /* ClassExpression */:
-          case 263 /* InterfaceDeclaration */:
-            let table;
-            (getSymbolOfDeclaration(location).members || emptySymbols).forEach((memberSymbol, key) => {
-              if (memberSymbol.flags & (788968 /* Type */ & ~67108864 /* Assignment */)) {
-                (table || (table = createSymbolTable())).set(key, memberSymbol);
-              }
-            });
-            if (table && (result = callback(
-              table,
-              /*ignoreQualification*/
-              void 0,
-              /*isLocalNameLookup*/
-              false,
-              location
-            ))) {
-              return result;
-            }
-            break;
-        }
-      }
-      return callback(
-        globals,
-        /*ignoreQualification*/
-        void 0,
-        /*isLocalNameLookup*/
-        true
-      );
-    }
-    function getQualifiedLeftMeaning(rightMeaning) {
-      return rightMeaning === 111551 /* Value */ ? 111551 /* Value */ : 1920 /* Namespace */;
-    }
-    function getAccessibleSymbolChain(symbol, enclosingDeclaration, meaning, useOnlyExternalAliasing, visitedSymbolTablesMap = /* @__PURE__ */ new Map()) {
-      if (!(symbol && !isPropertyOrMethodDeclarationSymbol(symbol))) {
-        return void 0;
-      }
-      const links = getSymbolLinks(symbol);
-      const cache = links.accessibleChainCache || (links.accessibleChainCache = /* @__PURE__ */ new Map());
-      const firstRelevantLocation = forEachSymbolTableInScope(enclosingDeclaration, (_, __, ___, node) => node);
-      const key = `${useOnlyExternalAliasing ? 0 : 1}|${firstRelevantLocation && getNodeId(firstRelevantLocation)}|${meaning}`;
-      if (cache.has(key)) {
-        return cache.get(key);
-      }
-      const id = getSymbolId(symbol);
-      let visitedSymbolTables = visitedSymbolTablesMap.get(id);
-      if (!visitedSymbolTables) {
-        visitedSymbolTablesMap.set(id, visitedSymbolTables = []);
-      }
-      const result = forEachSymbolTableInScope(enclosingDeclaration, getAccessibleSymbolChainFromSymbolTable);
-      cache.set(key, result);
-      return result;
-      function getAccessibleSymbolChainFromSymbolTable(symbols, ignoreQualification, isLocalNameLookup) {
-        if (!pushIfUnique(visitedSymbolTables, symbols)) {
-          return void 0;
-        }
-        const result2 = trySymbolTable(symbols, ignoreQualification, isLocalNameLookup);
-        visitedSymbolTables.pop();
-        return result2;
-      }
-      function canQualifySymbol(symbolFromSymbolTable, meaning2) {
-        return !needsQualification(symbolFromSymbolTable, enclosingDeclaration, meaning2) || // If symbol needs qualification, make sure that parent is accessible, if it is then this symbol is accessible too
-        !!getAccessibleSymbolChain(symbolFromSymbolTable.parent, enclosingDeclaration, getQualifiedLeftMeaning(meaning2), useOnlyExternalAliasing, visitedSymbolTablesMap);
-      }
-      function isAccessible(symbolFromSymbolTable, resolvedAliasSymbol, ignoreQualification) {
-        return (symbol === (resolvedAliasSymbol || symbolFromSymbolTable) || getMergedSymbol(symbol) === getMergedSymbol(resolvedAliasSymbol || symbolFromSymbolTable)) && // if the symbolFromSymbolTable is not external module (it could be if it was determined as ambient external module and would be in globals table)
-        // and if symbolFromSymbolTable or alias resolution matches the symbol,
-        // check the symbol can be qualified, it is only then this symbol is accessible
-        !some(symbolFromSymbolTable.declarations, hasNonGlobalAugmentationExternalModuleSymbol) && (ignoreQualification || canQualifySymbol(getMergedSymbol(symbolFromSymbolTable), meaning));
-      }
-      function trySymbolTable(symbols, ignoreQualification, isLocalNameLookup) {
-        if (isAccessible(
-          symbols.get(symbol.escapedName),
-          /*resolvedAliasSymbol*/
-          void 0,
-          ignoreQualification
-        )) {
-          return [symbol];
-        }
-        const result2 = forEachEntry(symbols, (symbolFromSymbolTable) => {
-          if (symbolFromSymbolTable.flags & 2097152 /* Alias */ && symbolFromSymbolTable.escapedName !== "export=" /* ExportEquals */ && symbolFromSymbolTable.escapedName !== "default" /* Default */ && !(isUMDExportSymbol(symbolFromSymbolTable) && enclosingDeclaration && isExternalModule(getSourceFileOfNode(enclosingDeclaration))) && (!useOnlyExternalAliasing || some(symbolFromSymbolTable.declarations, isExternalModuleImportEqualsDeclaration)) && (isLocalNameLookup ? !some(symbolFromSymbolTable.declarations, isNamespaceReexportDeclaration) : true) && (ignoreQualification || !getDeclarationOfKind(symbolFromSymbolTable, 280 /* ExportSpecifier */))) {
-            const resolvedImportedSymbol = resolveAlias(symbolFromSymbolTable);
-            const candidate = getCandidateListForSymbol(symbolFromSymbolTable, resolvedImportedSymbol, ignoreQualification);
-            if (candidate) {
-              return candidate;
-            }
-          }
-          if (symbolFromSymbolTable.escapedName === symbol.escapedName && symbolFromSymbolTable.exportSymbol) {
-            if (isAccessible(
-              getMergedSymbol(symbolFromSymbolTable.exportSymbol),
-              /*resolvedAliasSymbol*/
-              void 0,
-              ignoreQualification
-            )) {
-              return [symbol];
-            }
-          }
-        });
-        return result2 || (symbols === globals ? getCandidateListForSymbol(globalThisSymbol, globalThisSymbol, ignoreQualification) : void 0);
-      }
-      function getCandidateListForSymbol(symbolFromSymbolTable, resolvedImportedSymbol, ignoreQualification) {
-        if (isAccessible(symbolFromSymbolTable, resolvedImportedSymbol, ignoreQualification)) {
-          return [symbolFromSymbolTable];
-        }
-        const candidateTable = getExportsOfSymbol(resolvedImportedSymbol);
-        const accessibleSymbolsFromExports = candidateTable && getAccessibleSymbolChainFromSymbolTable(
-          candidateTable,
-          /*ignoreQualification*/
-          true
-        );
-        if (accessibleSymbolsFromExports && canQualifySymbol(symbolFromSymbolTable, getQualifiedLeftMeaning(meaning))) {
-          return [symbolFromSymbolTable].concat(accessibleSymbolsFromExports);
-        }
-      }
-    }
-    function needsQualification(symbol, enclosingDeclaration, meaning) {
-      let qualify = false;
-      forEachSymbolTableInScope(enclosingDeclaration, (symbolTable) => {
-        let symbolFromSymbolTable = getMergedSymbol(symbolTable.get(symbol.escapedName));
-        if (!symbolFromSymbolTable) {
-          return false;
-        }
-        if (symbolFromSymbolTable === symbol) {
-          return true;
-        }
-        const shouldResolveAlias = symbolFromSymbolTable.flags & 2097152 /* Alias */ && !getDeclarationOfKind(symbolFromSymbolTable, 280 /* ExportSpecifier */);
-        symbolFromSymbolTable = shouldResolveAlias ? resolveAlias(symbolFromSymbolTable) : symbolFromSymbolTable;
-        const flags = shouldResolveAlias ? getAllSymbolFlags(symbolFromSymbolTable) : symbolFromSymbolTable.flags;
-        if (flags & meaning) {
-          qualify = true;
-          return true;
-        }
-        return false;
-      });
-      return qualify;
-    }
-    function isPropertyOrMethodDeclarationSymbol(symbol) {
-      if (symbol.declarations && symbol.declarations.length) {
-        for (const declaration of symbol.declarations) {
-          switch (declaration.kind) {
-            case 171 /* PropertyDeclaration */:
-            case 173 /* MethodDeclaration */:
-            case 176 /* GetAccessor */:
-            case 177 /* SetAccessor */:
-              continue;
-            default:
-              return false;
-          }
-        }
-        return true;
-      }
-      return false;
-    }
-    function isTypeSymbolAccessible(typeSymbol, enclosingDeclaration) {
-      const access = isSymbolAccessibleWorker(
-        typeSymbol,
-        enclosingDeclaration,
-        788968 /* Type */,
-        /*shouldComputeAliasesToMakeVisible*/
-        false,
-        /*allowModules*/
-        true
-      );
-      return access.accessibility === 0 /* Accessible */;
-    }
-    function isValueSymbolAccessible(typeSymbol, enclosingDeclaration) {
-      const access = isSymbolAccessibleWorker(
-        typeSymbol,
-        enclosingDeclaration,
-        111551 /* Value */,
-        /*shouldComputeAliasesToMakeVisible*/
-        false,
-        /*allowModules*/
-        true
-      );
-      return access.accessibility === 0 /* Accessible */;
-    }
-    function isSymbolAccessibleByFlags(typeSymbol, enclosingDeclaration, flags) {
-      const access = isSymbolAccessibleWorker(
-        typeSymbol,
-        enclosingDeclaration,
-        flags,
-        /*shouldComputeAliasesToMakeVisible*/
-        false,
-        /*allowModules*/
-        false
-      );
-      return access.accessibility === 0 /* Accessible */;
-    }
-    function isAnySymbolAccessible(symbols, enclosingDeclaration, initialSymbol, meaning, shouldComputeAliasesToMakeVisible, allowModules) {
-      if (!length(symbols))
-        return;
-      let hadAccessibleChain;
-      let earlyModuleBail = false;
-      for (const symbol of symbols) {
-        const accessibleSymbolChain = getAccessibleSymbolChain(
-          symbol,
-          enclosingDeclaration,
-          meaning,
-          /*useOnlyExternalAliasing*/
-          false
-        );
-        if (accessibleSymbolChain) {
-          hadAccessibleChain = symbol;
-          const hasAccessibleDeclarations = hasVisibleDeclarations(accessibleSymbolChain[0], shouldComputeAliasesToMakeVisible);
-          if (hasAccessibleDeclarations) {
-            return hasAccessibleDeclarations;
-          }
-        }
-        if (allowModules) {
-          if (some(symbol.declarations, hasNonGlobalAugmentationExternalModuleSymbol)) {
-            if (shouldComputeAliasesToMakeVisible) {
-              earlyModuleBail = true;
-              continue;
-            }
-            return {
-              accessibility: 0 /* Accessible */
-            };
-          }
-        }
-        const containers = getContainersOfSymbol(symbol, enclosingDeclaration, meaning);
-        const parentResult = isAnySymbolAccessible(containers, enclosingDeclaration, initialSymbol, initialSymbol === symbol ? getQualifiedLeftMeaning(meaning) : meaning, shouldComputeAliasesToMakeVisible, allowModules);
-        if (parentResult) {
-          return parentResult;
-        }
-      }
-      if (earlyModuleBail) {
-        return {
-          accessibility: 0 /* Accessible */
-        };
-      }
-      if (hadAccessibleChain) {
-        return {
-          accessibility: 1 /* NotAccessible */,
-          errorSymbolName: symbolToString(initialSymbol, enclosingDeclaration, meaning),
-          errorModuleName: hadAccessibleChain !== initialSymbol ? symbolToString(hadAccessibleChain, enclosingDeclaration, 1920 /* Namespace */) : void 0
-        };
-      }
-    }
-    function isSymbolAccessible(symbol, enclosingDeclaration, meaning, shouldComputeAliasesToMakeVisible) {
-      return isSymbolAccessibleWorker(
-        symbol,
-        enclosingDeclaration,
-        meaning,
-        shouldComputeAliasesToMakeVisible,
-        /*allowModules*/
-        true
-      );
-    }
-    function isSymbolAccessibleWorker(symbol, enclosingDeclaration, meaning, shouldComputeAliasesToMakeVisible, allowModules) {
-      if (symbol && enclosingDeclaration) {
-        const result = isAnySymbolAccessible([symbol], enclosingDeclaration, symbol, meaning, shouldComputeAliasesToMakeVisible, allowModules);
-        if (result) {
-          return result;
-        }
-        const symbolExternalModule = forEach(symbol.declarations, getExternalModuleContainer);
-        if (symbolExternalModule) {
-          const enclosingExternalModule = getExternalModuleContainer(enclosingDeclaration);
-          if (symbolExternalModule !== enclosingExternalModule) {
-            return {
-              accessibility: 2 /* CannotBeNamed */,
-              errorSymbolName: symbolToString(symbol, enclosingDeclaration, meaning),
-              errorModuleName: symbolToString(symbolExternalModule),
-              errorNode: isInJSFile(enclosingDeclaration) ? enclosingDeclaration : void 0
-            };
-          }
-        }
-        return {
-          accessibility: 1 /* NotAccessible */,
-          errorSymbolName: symbolToString(symbol, enclosingDeclaration, meaning)
-        };
-      }
-      return { accessibility: 0 /* Accessible */ };
-    }
-    function getExternalModuleContainer(declaration) {
-      const node = findAncestor(declaration, hasExternalModuleSymbol);
-      return node && getSymbolOfDeclaration(node);
-    }
-    function hasExternalModuleSymbol(declaration) {
-      return isAmbientModule(declaration) || declaration.kind === 311 /* SourceFile */ && isExternalOrCommonJsModule(declaration);
-    }
-    function hasNonGlobalAugmentationExternalModuleSymbol(declaration) {
-      return isModuleWithStringLiteralName(declaration) || declaration.kind === 311 /* SourceFile */ && isExternalOrCommonJsModule(declaration);
-    }
-    function hasVisibleDeclarations(symbol, shouldComputeAliasToMakeVisible) {
-      let aliasesToMakeVisible;
-      if (!every(filter(symbol.declarations, (d) => d.kind !== 80 /* Identifier */), getIsDeclarationVisible)) {
-        return void 0;
-      }
-      return { accessibility: 0 /* Accessible */, aliasesToMakeVisible };
-      function getIsDeclarationVisible(declaration) {
-        var _a, _b;
-        if (!isDeclarationVisible(declaration)) {
-          const anyImportSyntax = getAnyImportSyntax(declaration);
-          if (anyImportSyntax && !hasSyntacticModifier(anyImportSyntax, 1 /* Export */) && // import clause without export
-          isDeclarationVisible(anyImportSyntax.parent)) {
-            return addVisibleAlias(declaration, anyImportSyntax);
-          } else if (isVariableDeclaration(declaration) && isVariableStatement(declaration.parent.parent) && !hasSyntacticModifier(declaration.parent.parent, 1 /* Export */) && // unexported variable statement
-          isDeclarationVisible(declaration.parent.parent.parent)) {
-            return addVisibleAlias(declaration, declaration.parent.parent);
-          } else if (isLateVisibilityPaintedStatement(declaration) && !hasSyntacticModifier(declaration, 1 /* Export */) && isDeclarationVisible(declaration.parent)) {
-            return addVisibleAlias(declaration, declaration);
-          } else if (isBindingElement(declaration)) {
-            if (symbol.flags & 2097152 /* Alias */ && isInJSFile(declaration) && ((_a = declaration.parent) == null ? void 0 : _a.parent) && isVariableDeclaration(declaration.parent.parent) && ((_b = declaration.parent.parent.parent) == null ? void 0 : _b.parent) && isVariableStatement(declaration.parent.parent.parent.parent) && !hasSyntacticModifier(declaration.parent.parent.parent.parent, 1 /* Export */) && declaration.parent.parent.parent.parent.parent && isDeclarationVisible(declaration.parent.parent.parent.parent.parent)) {
-              return addVisibleAlias(declaration, declaration.parent.parent.parent.parent);
-            } else if (symbol.flags & 2 /* BlockScopedVariable */) {
-              const variableStatement = findAncestor(declaration, isVariableStatement);
-              if (hasSyntacticModifier(variableStatement, 1 /* Export */)) {
-                return true;
-              }
-              if (!isDeclarationVisible(variableStatement.parent)) {
-                return false;
-              }
-              return addVisibleAlias(declaration, variableStatement);
-            }
-          }
-          return false;
-        }
-        return true;
-      }
-      function addVisibleAlias(declaration, aliasingStatement) {
-        if (shouldComputeAliasToMakeVisible) {
-          getNodeLinks(declaration).isVisible = true;
-          aliasesToMakeVisible = appendIfUnique(aliasesToMakeVisible, aliasingStatement);
-        }
-        return true;
-      }
-    }
-    function isEntityNameVisible(entityName, enclosingDeclaration) {
-      let meaning;
-      if (entityName.parent.kind === 185 /* TypeQuery */ || entityName.parent.kind === 232 /* ExpressionWithTypeArguments */ && !isPartOfTypeNode(entityName.parent) || entityName.parent.kind === 166 /* ComputedPropertyName */) {
-        meaning = 111551 /* Value */ | 1048576 /* ExportValue */;
-      } else if (entityName.kind === 165 /* QualifiedName */ || entityName.kind === 210 /* PropertyAccessExpression */ || entityName.parent.kind === 270 /* ImportEqualsDeclaration */) {
-        meaning = 1920 /* Namespace */;
-      } else {
-        meaning = 788968 /* Type */;
-      }
-      const firstIdentifier = getFirstIdentifier(entityName);
-      const symbol = resolveName(
-        enclosingDeclaration,
-        firstIdentifier.escapedText,
-        meaning,
-        /*nameNotFoundMessage*/
-        void 0,
-        /*nameArg*/
-        void 0,
-        /*isUse*/
-        false
-      );
-      if (symbol && symbol.flags & 262144 /* TypeParameter */ && meaning & 788968 /* Type */) {
-        return { accessibility: 0 /* Accessible */ };
-      }
-      if (!symbol && isThisIdentifier(firstIdentifier) && isSymbolAccessible(
-        getSymbolOfDeclaration(getThisContainer(
-          firstIdentifier,
-          /*includeArrowFunctions*/
-          false,
-          /*includeClassComputedPropertyName*/
-          false
-        )),
-        firstIdentifier,
-        meaning,
-        /*shouldComputeAliasesToMakeVisible*/
-        false
-      ).accessibility === 0 /* Accessible */) {
-        return { accessibility: 0 /* Accessible */ };
-      }
-      return symbol && hasVisibleDeclarations(
-        symbol,
-        /*shouldComputeAliasToMakeVisible*/
-        true
-      ) || {
-        accessibility: 1 /* NotAccessible */,
-        errorSymbolName: getTextOfNode(firstIdentifier),
-        errorNode: firstIdentifier
-      };
-    }
-    function symbolToString(symbol, enclosingDeclaration, meaning, flags = 4 /* AllowAnyNodeKind */, writer) {
-      let nodeFlags = 70221824 /* IgnoreErrors */;
-      if (flags & 2 /* UseOnlyExternalAliasing */) {
-        nodeFlags |= 128 /* UseOnlyExternalAliasing */;
-      }
-      if (flags & 1 /* WriteTypeParametersOrArguments */) {
-        nodeFlags |= 512 /* WriteTypeParametersInQualifiedName */;
-      }
-      if (flags & 8 /* UseAliasDefinedOutsideCurrentScope */) {
-        nodeFlags |= 16384 /* UseAliasDefinedOutsideCurrentScope */;
-      }
-      if (flags & 32 /* DoNotIncludeSymbolChain */) {
-        nodeFlags |= 134217728 /* DoNotIncludeSymbolChain */;
-      }
-      if (flags & 16 /* WriteComputedProps */) {
-        nodeFlags |= 1073741824 /* WriteComputedProps */;
-      }
-      const builder = flags & 4 /* AllowAnyNodeKind */ ? nodeBuilder.symbolToNode : nodeBuilder.symbolToEntityName;
-      return writer ? symbolToStringWorker(writer).getText() : usingSingleLineStringWriter(symbolToStringWorker);
-      function symbolToStringWorker(writer2) {
-        const entity = builder(symbol, meaning, enclosingDeclaration, nodeFlags);
-        const printer = (enclosingDeclaration == null ? void 0 : enclosingDeclaration.kind) === 311 /* SourceFile */ ? createPrinterWithRemoveCommentsNeverAsciiEscape() : createPrinterWithRemoveComments();
-        const sourceFile = enclosingDeclaration && getSourceFileOfNode(enclosingDeclaration);
-        printer.writeNode(
-          4 /* Unspecified */,
-          entity,
-          /*sourceFile*/
-          sourceFile,
-          writer2
-        );
-        return writer2;
-      }
-    }
-    function signatureToString(signature, enclosingDeclaration, flags = 0 /* None */, kind, writer) {
-      return writer ? signatureToStringWorker(writer).getText() : usingSingleLineStringWriter(signatureToStringWorker);
-      function signatureToStringWorker(writer2) {
-        let sigOutput;
-        if (flags & 262144 /* WriteArrowStyleSignature */) {
-          sigOutput = kind === 1 /* Construct */ ? 184 /* ConstructorType */ : 183 /* FunctionType */;
-        } else {
-          sigOutput = kind === 1 /* Construct */ ? 179 /* ConstructSignature */ : 178 /* CallSignature */;
-        }
-        const sig = nodeBuilder.signatureToSignatureDeclaration(signature, sigOutput, enclosingDeclaration, toNodeBuilderFlags(flags) | 70221824 /* IgnoreErrors */ | 512 /* WriteTypeParametersInQualifiedName */);
-        const printer = createPrinterWithRemoveCommentsOmitTrailingSemicolon();
-        const sourceFile = enclosingDeclaration && getSourceFileOfNode(enclosingDeclaration);
-        printer.writeNode(
-          4 /* Unspecified */,
-          sig,
-          /*sourceFile*/
-          sourceFile,
-          getTrailingSemicolonDeferringWriter(writer2)
-        );
-        return writer2;
-      }
-    }
-    function typeToString(type, enclosingDeclaration, flags = 1048576 /* AllowUniqueESSymbolType */ | 16384 /* UseAliasDefinedOutsideCurrentScope */, writer = createTextWriter("")) {
-      const noTruncation = compilerOptions.noErrorTruncation || flags & 1 /* NoTruncation */;
-      const typeNode = nodeBuilder.typeToTypeNode(type, enclosingDeclaration, toNodeBuilderFlags(flags) | 70221824 /* IgnoreErrors */ | (noTruncation ? 1 /* NoTruncation */ : 0));
-      if (typeNode === void 0)
-        return Debug.fail("should always get typenode");
-      const printer = type !== unresolvedType ? createPrinterWithRemoveComments() : createPrinterWithDefaults();
-      const sourceFile = enclosingDeclaration && getSourceFileOfNode(enclosingDeclaration);
-      printer.writeNode(
-        4 /* Unspecified */,
-        typeNode,
-        /*sourceFile*/
-        sourceFile,
-        writer
-      );
-      const result = writer.getText();
-      const maxLength2 = noTruncation ? noTruncationMaximumTruncationLength * 2 : defaultMaximumTruncationLength * 2;
-      if (maxLength2 && result && result.length >= maxLength2) {
-        return result.substr(0, maxLength2 - "...".length) + "...";
-      }
-      return result;
-    }
-    function getTypeNamesForErrorDisplay(left, right) {
-      let leftStr = symbolValueDeclarationIsContextSensitive(left.symbol) ? typeToString(left, left.symbol.valueDeclaration) : typeToString(left);
-      let rightStr = symbolValueDeclarationIsContextSensitive(right.symbol) ? typeToString(right, right.symbol.valueDeclaration) : typeToString(right);
-      if (leftStr === rightStr) {
-        leftStr = getTypeNameForErrorDisplay(left);
-        rightStr = getTypeNameForErrorDisplay(right);
-      }
-      return [leftStr, rightStr];
-    }
-    function getTypeNameForErrorDisplay(type) {
-      return typeToString(
-        type,
-        /*enclosingDeclaration*/
-        void 0,
-        64 /* UseFullyQualifiedType */
-      );
-    }
-    function symbolValueDeclarationIsContextSensitive(symbol) {
-      return symbol && !!symbol.valueDeclaration && isExpression(symbol.valueDeclaration) && !isContextSensitive(symbol.valueDeclaration);
-    }
-    function toNodeBuilderFlags(flags = 0 /* None */) {
-      return flags & 848330091 /* NodeBuilderFlagsMask */;
-    }
-    function isClassInstanceSide(type) {
-      return !!type.symbol && !!(type.symbol.flags & 32 /* Class */) && (type === getDeclaredTypeOfClassOrInterface(type.symbol) || !!(type.flags & 524288 /* Object */) && !!(getObjectFlags(type) & 16777216 /* IsClassInstanceClone */));
-    }
-    function createNodeBuilder() {
-      return {
-        typeToTypeNode: (type, enclosingDeclaration, flags, tracker) => withContext(enclosingDeclaration, flags, tracker, (context) => typeToTypeNodeHelper(type, context)),
-        indexInfoToIndexSignatureDeclaration: (indexInfo, enclosingDeclaration, flags, tracker) => withContext(enclosingDeclaration, flags, tracker, (context) => indexInfoToIndexSignatureDeclarationHelper(
-          indexInfo,
-          context,
-          /*typeNode*/
-          void 0
-        )),
-        signatureToSignatureDeclaration: (signature, kind, enclosingDeclaration, flags, tracker) => withContext(enclosingDeclaration, flags, tracker, (context) => signatureToSignatureDeclarationHelper(signature, kind, context)),
-        symbolToEntityName: (symbol, meaning, enclosingDeclaration, flags, tracker) => withContext(enclosingDeclaration, flags, tracker, (context) => symbolToName(
-          symbol,
-          context,
-          meaning,
-          /*expectsIdentifier*/
-          false
-        )),
-        symbolToExpression: (symbol, meaning, enclosingDeclaration, flags, tracker) => withContext(enclosingDeclaration, flags, tracker, (context) => symbolToExpression(symbol, context, meaning)),
-        symbolToTypeParameterDeclarations: (symbol, enclosingDeclaration, flags, tracker) => withContext(enclosingDeclaration, flags, tracker, (context) => typeParametersToTypeParameterDeclarations(symbol, context)),
-        symbolToParameterDeclaration: (symbol, enclosingDeclaration, flags, tracker) => withContext(enclosingDeclaration, flags, tracker, (context) => symbolToParameterDeclaration(symbol, context)),
-        typeParameterToDeclaration: (parameter, enclosingDeclaration, flags, tracker) => withContext(enclosingDeclaration, flags, tracker, (context) => typeParameterToDeclaration(parameter, context)),
-        symbolTableToDeclarationStatements: (symbolTable, enclosingDeclaration, flags, tracker, bundled) => withContext(enclosingDeclaration, flags, tracker, (context) => symbolTableToDeclarationStatements(symbolTable, context, bundled)),
-        symbolToNode: (symbol, meaning, enclosingDeclaration, flags, tracker) => withContext(enclosingDeclaration, flags, tracker, (context) => symbolToNode(symbol, context, meaning))
-      };
-      function symbolToNode(symbol, context, meaning) {
-        if (context.flags & 1073741824 /* WriteComputedProps */) {
-          if (symbol.valueDeclaration) {
-            const name = getNameOfDeclaration(symbol.valueDeclaration);
-            if (name && isComputedPropertyName(name))
-              return name;
-          }
-          const nameType = getSymbolLinks(symbol).nameType;
-          if (nameType && nameType.flags & (1024 /* EnumLiteral */ | 8192 /* UniqueESSymbol */)) {
-            context.enclosingDeclaration = nameType.symbol.valueDeclaration;
-            return factory.createComputedPropertyName(symbolToExpression(nameType.symbol, context, meaning));
-          }
-        }
-        return symbolToExpression(symbol, context, meaning);
-      }
-      function withContext(enclosingDeclaration, flags, tracker, cb) {
-        Debug.assert(enclosingDeclaration === void 0 || (enclosingDeclaration.flags & 8 /* Synthesized */) === 0);
-        const moduleResolverHost = (tracker == null ? void 0 : tracker.trackSymbol) ? tracker.moduleResolverHost : flags & 134217728 /* DoNotIncludeSymbolChain */ ? createBasicNodeBuilderModuleSpecifierResolutionHost(host) : void 0;
-        const context = {
-          enclosingDeclaration,
-          flags: flags || 0 /* None */,
-          tracker: void 0,
-          encounteredError: false,
-          reportedDiagnostic: false,
-          visitedTypes: void 0,
-          symbolDepth: void 0,
-          inferTypeParameters: void 0,
-          approximateLength: 0
-        };
-        context.tracker = new SymbolTrackerImpl(context, tracker, moduleResolverHost);
-        const resultingNode = cb(context);
-        if (context.truncating && context.flags & 1 /* NoTruncation */) {
-          context.tracker.reportTruncationError();
-        }
-        return context.encounteredError ? void 0 : resultingNode;
-      }
-      function checkTruncationLength(context) {
-        if (context.truncating)
-          return context.truncating;
-        return context.truncating = context.approximateLength > (context.flags & 1 /* NoTruncation */ ? noTruncationMaximumTruncationLength : defaultMaximumTruncationLength);
-      }
-      function typeToTypeNodeHelper(type, context) {
-        const savedFlags = context.flags;
-        const typeNode = typeToTypeNodeWorker(type, context);
-        context.flags = savedFlags;
-        return typeNode;
-      }
-      function typeToTypeNodeWorker(type, context) {
-        var _a, _b;
-        if (cancellationToken && cancellationToken.throwIfCancellationRequested) {
-          cancellationToken.throwIfCancellationRequested();
-        }
-        const inTypeAlias = context.flags & 8388608 /* InTypeAlias */;
-        context.flags &= ~8388608 /* InTypeAlias */;
-        if (!type) {
-          if (!(context.flags & 262144 /* AllowEmptyUnionOrIntersection */)) {
-            context.encounteredError = true;
-            return void 0;
-          }
-          context.approximateLength += 3;
-          return factory.createKeywordTypeNode(133 /* AnyKeyword */);
-        }
-        if (!(context.flags & 536870912 /* NoTypeReduction */)) {
-          type = getReducedType(type);
-        }
-        if (type.flags & 1 /* Any */) {
-          if (type.aliasSymbol) {
-            return factory.createTypeReferenceNode(symbolToEntityNameNode(type.aliasSymbol), mapToTypeNodes(type.aliasTypeArguments, context));
-          }
-          if (type === unresolvedType) {
-            return addSyntheticLeadingComment(factory.createKeywordTypeNode(133 /* AnyKeyword */), 3 /* MultiLineCommentTrivia */, "unresolved");
-          }
-          context.approximateLength += 3;
-          return factory.createKeywordTypeNode(type === intrinsicMarkerType ? 141 /* IntrinsicKeyword */ : 133 /* AnyKeyword */);
-        }
-        if (type.flags & 2 /* Unknown */) {
-          return factory.createKeywordTypeNode(159 /* UnknownKeyword */);
-        }
-        if (type.flags & 4 /* String */) {
-          context.approximateLength += 6;
-          return factory.createKeywordTypeNode(154 /* StringKeyword */);
-        }
-        if (type.flags & 8 /* Number */) {
-          context.approximateLength += 6;
-          return factory.createKeywordTypeNode(150 /* NumberKeyword */);
-        }
-        if (type.flags & 64 /* BigInt */) {
-          context.approximateLength += 6;
-          return factory.createKeywordTypeNode(162 /* BigIntKeyword */);
-        }
-        if (type.flags & 16 /* Boolean */ && !type.aliasSymbol) {
-          context.approximateLength += 7;
-          return factory.createKeywordTypeNode(136 /* BooleanKeyword */);
-        }
-        if (type.flags & 1056 /* EnumLike */) {
-          if (type.symbol.flags & 8 /* EnumMember */) {
-            const parentSymbol = getParentOfSymbol(type.symbol);
-            const parentName = symbolToTypeNode(parentSymbol, context, 788968 /* Type */);
-            if (getDeclaredTypeOfSymbol(parentSymbol) === type) {
-              return parentName;
-            }
-            const memberName = symbolName(type.symbol);
-            if (isIdentifierText(memberName, 0 /* ES3 */)) {
-              return appendReferenceToType(
-                parentName,
-                factory.createTypeReferenceNode(
-                  memberName,
-                  /*typeArguments*/
-                  void 0
-                )
-              );
-            }
-            if (isImportTypeNode(parentName)) {
-              parentName.isTypeOf = true;
-              return factory.createIndexedAccessTypeNode(parentName, factory.createLiteralTypeNode(factory.createStringLiteral(memberName)));
-            } else if (isTypeReferenceNode(parentName)) {
-              return factory.createIndexedAccessTypeNode(factory.createTypeQueryNode(parentName.typeName), factory.createLiteralTypeNode(factory.createStringLiteral(memberName)));
-            } else {
-              return Debug.fail("Unhandled type node kind returned from `symbolToTypeNode`.");
-            }
-          }
-          return symbolToTypeNode(type.symbol, context, 788968 /* Type */);
-        }
-        if (type.flags & 128 /* StringLiteral */) {
-          context.approximateLength += type.value.length + 2;
-          return factory.createLiteralTypeNode(setEmitFlags(factory.createStringLiteral(type.value, !!(context.flags & 268435456 /* UseSingleQuotesForStringLiteralType */)), 16777216 /* NoAsciiEscaping */));
-        }
-        if (type.flags & 256 /* NumberLiteral */) {
-          const value = type.value;
-          context.approximateLength += ("" + value).length;
-          return factory.createLiteralTypeNode(value < 0 ? factory.createPrefixUnaryExpression(41 /* MinusToken */, factory.createNumericLiteral(-value)) : factory.createNumericLiteral(value));
-        }
-        if (type.flags & 2048 /* BigIntLiteral */) {
-          context.approximateLength += pseudoBigIntToString(type.value).length + 1;
-          return factory.createLiteralTypeNode(factory.createBigIntLiteral(type.value));
-        }
-        if (type.flags & 512 /* BooleanLiteral */) {
-          context.approximateLength += type.intrinsicName.length;
-          return factory.createLiteralTypeNode(type.intrinsicName === "true" ? factory.createTrue() : factory.createFalse());
-        }
-        if (type.flags & 8192 /* UniqueESSymbol */) {
-          if (!(context.flags & 1048576 /* AllowUniqueESSymbolType */)) {
-            if (isValueSymbolAccessible(type.symbol, context.enclosingDeclaration)) {
-              context.approximateLength += 6;
-              return symbolToTypeNode(type.symbol, context, 111551 /* Value */);
-            }
-            if (context.tracker.reportInaccessibleUniqueSymbolError) {
-              context.tracker.reportInaccessibleUniqueSymbolError();
-            }
-          }
-          context.approximateLength += 13;
-          return factory.createTypeOperatorNode(158 /* UniqueKeyword */, factory.createKeywordTypeNode(155 /* SymbolKeyword */));
-        }
-        if (type.flags & 16384 /* Void */) {
-          context.approximateLength += 4;
-          return factory.createKeywordTypeNode(116 /* VoidKeyword */);
-        }
-        if (type.flags & 32768 /* Undefined */) {
-          context.approximateLength += 9;
-          return factory.createKeywordTypeNode(157 /* UndefinedKeyword */);
-        }
-        if (type.flags & 65536 /* Null */) {
-          context.approximateLength += 4;
-          return factory.createLiteralTypeNode(factory.createNull());
-        }
-        if (type.flags & 131072 /* Never */) {
-          context.approximateLength += 5;
-          return factory.createKeywordTypeNode(146 /* NeverKeyword */);
-        }
-        if (type.flags & 4096 /* ESSymbol */) {
-          context.approximateLength += 6;
-          return factory.createKeywordTypeNode(155 /* SymbolKeyword */);
-        }
-        if (type.flags & 67108864 /* NonPrimitive */) {
-          context.approximateLength += 6;
-          return factory.createKeywordTypeNode(151 /* ObjectKeyword */);
-        }
-        if (isThisTypeParameter(type)) {
-          if (context.flags & 4194304 /* InObjectTypeLiteral */) {
-            if (!context.encounteredError && !(context.flags & 32768 /* AllowThisInObjectLiteral */)) {
-              context.encounteredError = true;
-            }
-            (_b = (_a = context.tracker).reportInaccessibleThisError) == null ? void 0 : _b.call(_a);
-          }
-          context.approximateLength += 4;
-          return factory.createThisTypeNode();
-        }
-        if (!inTypeAlias && type.aliasSymbol && (context.flags & 16384 /* UseAliasDefinedOutsideCurrentScope */ || isTypeSymbolAccessible(type.aliasSymbol, context.enclosingDeclaration))) {
-          const typeArgumentNodes = mapToTypeNodes(type.aliasTypeArguments, context);
-          if (isReservedMemberName(type.aliasSymbol.escapedName) && !(type.aliasSymbol.flags & 32 /* Class */))
-            return factory.createTypeReferenceNode(factory.createIdentifier(""), typeArgumentNodes);
-          if (length(typeArgumentNodes) === 1 && type.aliasSymbol === globalArrayType.symbol) {
-            return factory.createArrayTypeNode(typeArgumentNodes[0]);
-          }
-          return symbolToTypeNode(type.aliasSymbol, context, 788968 /* Type */, typeArgumentNodes);
-        }
-        const objectFlags = getObjectFlags(type);
-        if (objectFlags & 4 /* Reference */) {
-          Debug.assert(!!(type.flags & 524288 /* Object */));
-          return type.node ? visitAndTransformType(type, typeReferenceToTypeNode) : typeReferenceToTypeNode(type);
-        }
-        if (type.flags & 262144 /* TypeParameter */ || objectFlags & 3 /* ClassOrInterface */) {
-          if (type.flags & 262144 /* TypeParameter */ && contains(context.inferTypeParameters, type)) {
-            context.approximateLength += symbolName(type.symbol).length + 6;
-            let constraintNode;
-            const constraint = getConstraintOfTypeParameter(type);
-            if (constraint) {
-              const inferredConstraint = getInferredTypeParameterConstraint(
-                type,
-                /*omitTypeReferences*/
-                true
-              );
-              if (!(inferredConstraint && isTypeIdenticalTo(constraint, inferredConstraint))) {
-                context.approximateLength += 9;
-                constraintNode = constraint && typeToTypeNodeHelper(constraint, context);
-              }
-            }
-            return factory.createInferTypeNode(typeParameterToDeclarationWithConstraint(type, context, constraintNode));
-          }
-          if (context.flags & 4 /* GenerateNamesForShadowedTypeParams */ && type.flags & 262144 /* TypeParameter */ && !isTypeSymbolAccessible(type.symbol, context.enclosingDeclaration)) {
-            const name2 = typeParameterToName(type, context);
-            context.approximateLength += idText(name2).length;
-            return factory.createTypeReferenceNode(
-              factory.createIdentifier(idText(name2)),
-              /*typeArguments*/
-              void 0
-            );
-          }
-          if (type.symbol) {
-            return symbolToTypeNode(type.symbol, context, 788968 /* Type */);
-          }
-          const name = (type === markerSuperTypeForCheck || type === markerSubTypeForCheck) && varianceTypeParameter && varianceTypeParameter.symbol ? (type === markerSubTypeForCheck ? "sub-" : "super-") + symbolName(varianceTypeParameter.symbol) : "?";
-          return factory.createTypeReferenceNode(
-            factory.createIdentifier(name),
-            /*typeArguments*/
-            void 0
-          );
-        }
-        if (type.flags & 1048576 /* Union */ && type.origin) {
-          type = type.origin;
-        }
-        if (type.flags & (1048576 /* Union */ | 2097152 /* Intersection */)) {
-          const types = type.flags & 1048576 /* Union */ ? formatUnionTypes(type.types) : type.types;
-          if (length(types) === 1) {
-            return typeToTypeNodeHelper(types[0], context);
-          }
-          const typeNodes = mapToTypeNodes(
-            types,
-            context,
-            /*isBareList*/
-            true
-          );
-          if (typeNodes && typeNodes.length > 0) {
-            return type.flags & 1048576 /* Union */ ? factory.createUnionTypeNode(typeNodes) : factory.createIntersectionTypeNode(typeNodes);
-          } else {
-            if (!context.encounteredError && !(context.flags & 262144 /* AllowEmptyUnionOrIntersection */)) {
-              context.encounteredError = true;
-            }
-            return void 0;
-          }
-        }
-        if (objectFlags & (16 /* Anonymous */ | 32 /* Mapped */)) {
-          Debug.assert(!!(type.flags & 524288 /* Object */));
-          return createAnonymousTypeNode(type);
-        }
-        if (type.flags & 4194304 /* Index */) {
-          const indexedType = type.type;
-          context.approximateLength += 6;
-          const indexTypeNode = typeToTypeNodeHelper(indexedType, context);
-          return factory.createTypeOperatorNode(143 /* KeyOfKeyword */, indexTypeNode);
-        }
-        if (type.flags & 134217728 /* TemplateLiteral */) {
-          const texts = type.texts;
-          const types = type.types;
-          const templateHead = factory.createTemplateHead(texts[0]);
-          const templateSpans = factory.createNodeArray(
-            map(types, (t, i) => factory.createTemplateLiteralTypeSpan(
-              typeToTypeNodeHelper(t, context),
-              (i < types.length - 1 ? factory.createTemplateMiddle : factory.createTemplateTail)(texts[i + 1])
-            ))
-          );
-          context.approximateLength += 2;
-          return factory.createTemplateLiteralType(templateHead, templateSpans);
-        }
-        if (type.flags & 268435456 /* StringMapping */) {
-          const typeNode = typeToTypeNodeHelper(type.type, context);
-          return symbolToTypeNode(type.symbol, context, 788968 /* Type */, [typeNode]);
-        }
-        if (type.flags & 8388608 /* IndexedAccess */) {
-          const objectTypeNode = typeToTypeNodeHelper(type.objectType, context);
-          const indexTypeNode = typeToTypeNodeHelper(type.indexType, context);
-          context.approximateLength += 2;
-          return factory.createIndexedAccessTypeNode(objectTypeNode, indexTypeNode);
-        }
-        if (type.flags & 16777216 /* Conditional */) {
-          return visitAndTransformType(type, (type2) => conditionalTypeToTypeNode(type2));
-        }
-        if (type.flags & 33554432 /* Substitution */) {
-          return typeToTypeNodeHelper(type.baseType, context);
-        }
-        return Debug.fail("Should be unreachable.");
-        function conditionalTypeToTypeNode(type2) {
-          const checkTypeNode = typeToTypeNodeHelper(type2.checkType, context);
-          context.approximateLength += 15;
-          if (context.flags & 4 /* GenerateNamesForShadowedTypeParams */ && type2.root.isDistributive && !(type2.checkType.flags & 262144 /* TypeParameter */)) {
-            const newParam = createTypeParameter(createSymbol(262144 /* TypeParameter */, "T"));
-            const name = typeParameterToName(newParam, context);
-            const newTypeVariable = factory.createTypeReferenceNode(name);
-            context.approximateLength += 37;
-            const newMapper = prependTypeMapping(type2.root.checkType, newParam, type2.mapper);
-            const saveInferTypeParameters2 = context.inferTypeParameters;
-            context.inferTypeParameters = type2.root.inferTypeParameters;
-            const extendsTypeNode2 = typeToTypeNodeHelper(instantiateType(type2.root.extendsType, newMapper), context);
-            context.inferTypeParameters = saveInferTypeParameters2;
-            const trueTypeNode2 = typeToTypeNodeOrCircularityElision(instantiateType(getTypeFromTypeNode(type2.root.node.trueType), newMapper));
-            const falseTypeNode2 = typeToTypeNodeOrCircularityElision(instantiateType(getTypeFromTypeNode(type2.root.node.falseType), newMapper));
-            return factory.createConditionalTypeNode(
-              checkTypeNode,
-              factory.createInferTypeNode(factory.createTypeParameterDeclaration(
-                /*modifiers*/
-                void 0,
-                factory.cloneNode(newTypeVariable.typeName)
-              )),
-              factory.createConditionalTypeNode(
-                factory.createTypeReferenceNode(factory.cloneNode(name)),
-                typeToTypeNodeHelper(type2.checkType, context),
-                factory.createConditionalTypeNode(newTypeVariable, extendsTypeNode2, trueTypeNode2, falseTypeNode2),
-                factory.createKeywordTypeNode(146 /* NeverKeyword */)
-              ),
-              factory.createKeywordTypeNode(146 /* NeverKeyword */)
-            );
-          }
-          const saveInferTypeParameters = context.inferTypeParameters;
-          context.inferTypeParameters = type2.root.inferTypeParameters;
-          const extendsTypeNode = typeToTypeNodeHelper(type2.extendsType, context);
-          context.inferTypeParameters = saveInferTypeParameters;
-          const trueTypeNode = typeToTypeNodeOrCircularityElision(getTrueTypeFromConditionalType(type2));
-          const falseTypeNode = typeToTypeNodeOrCircularityElision(getFalseTypeFromConditionalType(type2));
-          return factory.createConditionalTypeNode(checkTypeNode, extendsTypeNode, trueTypeNode, falseTypeNode);
-        }
-        function typeToTypeNodeOrCircularityElision(type2) {
-          var _a2, _b2, _c;
-          if (type2.flags & 1048576 /* Union */) {
-            if ((_a2 = context.visitedTypes) == null ? void 0 : _a2.has(getTypeId(type2))) {
-              if (!(context.flags & 131072 /* AllowAnonymousIdentifier */)) {
-                context.encounteredError = true;
-                (_c = (_b2 = context.tracker) == null ? void 0 : _b2.reportCyclicStructureError) == null ? void 0 : _c.call(_b2);
-              }
-              return createElidedInformationPlaceholder(context);
-            }
-            return visitAndTransformType(type2, (type3) => typeToTypeNodeHelper(type3, context));
-          }
-          return typeToTypeNodeHelper(type2, context);
-        }
-        function isMappedTypeHomomorphic(type2) {
-          return !!getHomomorphicTypeVariable(type2);
-        }
-        function isHomomorphicMappedTypeWithNonHomomorphicInstantiation(type2) {
-          return !!type2.target && isMappedTypeHomomorphic(type2.target) && !isMappedTypeHomomorphic(type2);
-        }
-        function createMappedTypeNodeFromType(type2) {
-          Debug.assert(!!(type2.flags & 524288 /* Object */));
-          const readonlyToken = type2.declaration.readonlyToken ? factory.createToken(type2.declaration.readonlyToken.kind) : void 0;
-          const questionToken = type2.declaration.questionToken ? factory.createToken(type2.declaration.questionToken.kind) : void 0;
-          let appropriateConstraintTypeNode;
-          let newTypeVariable;
-          if (isMappedTypeWithKeyofConstraintDeclaration(type2)) {
-            if (isHomomorphicMappedTypeWithNonHomomorphicInstantiation(type2) && context.flags & 4 /* GenerateNamesForShadowedTypeParams */) {
-              const newParam = createTypeParameter(createSymbol(262144 /* TypeParameter */, "T"));
-              const name = typeParameterToName(newParam, context);
-              newTypeVariable = factory.createTypeReferenceNode(name);
-            }
-            appropriateConstraintTypeNode = factory.createTypeOperatorNode(143 /* KeyOfKeyword */, newTypeVariable || typeToTypeNodeHelper(getModifiersTypeFromMappedType(type2), context));
-          } else {
-            appropriateConstraintTypeNode = typeToTypeNodeHelper(getConstraintTypeFromMappedType(type2), context);
-          }
-          const typeParameterNode = typeParameterToDeclarationWithConstraint(getTypeParameterFromMappedType(type2), context, appropriateConstraintTypeNode);
-          const nameTypeNode = type2.declaration.nameType ? typeToTypeNodeHelper(getNameTypeFromMappedType(type2), context) : void 0;
-          const templateTypeNode = typeToTypeNodeHelper(removeMissingType(getTemplateTypeFromMappedType(type2), !!(getMappedTypeModifiers(type2) & 4 /* IncludeOptional */)), context);
-          const mappedTypeNode = factory.createMappedTypeNode(
-            readonlyToken,
-            typeParameterNode,
-            nameTypeNode,
-            questionToken,
-            templateTypeNode,
-            /*members*/
-            void 0
-          );
-          context.approximateLength += 10;
-          const result = setEmitFlags(mappedTypeNode, 1 /* SingleLine */);
-          if (isHomomorphicMappedTypeWithNonHomomorphicInstantiation(type2) && context.flags & 4 /* GenerateNamesForShadowedTypeParams */) {
-            const originalConstraint = instantiateType(getConstraintOfTypeParameter(getTypeFromTypeNode(type2.declaration.typeParameter.constraint.type)) || unknownType, type2.mapper);
-            return factory.createConditionalTypeNode(
-              typeToTypeNodeHelper(getModifiersTypeFromMappedType(type2), context),
-              factory.createInferTypeNode(factory.createTypeParameterDeclaration(
-                /*modifiers*/
-                void 0,
-                factory.cloneNode(newTypeVariable.typeName),
-                originalConstraint.flags & 2 /* Unknown */ ? void 0 : typeToTypeNodeHelper(originalConstraint, context)
-              )),
-              result,
-              factory.createKeywordTypeNode(146 /* NeverKeyword */)
-            );
-          }
-          return result;
-        }
-        function createAnonymousTypeNode(type2) {
-          var _a2, _b2;
-          const typeId = type2.id;
-          const symbol = type2.symbol;
-          if (symbol) {
-            const isInstanceType = isClassInstanceSide(type2) ? 788968 /* Type */ : 111551 /* Value */;
-            if (isJSConstructor(symbol.valueDeclaration)) {
-              return symbolToTypeNode(symbol, context, isInstanceType);
-            } else if (symbol.flags & 32 /* Class */ && !getBaseTypeVariableOfClass(symbol) && !(symbol.valueDeclaration && isClassLike(symbol.valueDeclaration) && context.flags & 2048 /* WriteClassExpressionAsTypeLiteral */ && (!isClassDeclaration(symbol.valueDeclaration) || isSymbolAccessible(
-              symbol,
-              context.enclosingDeclaration,
-              isInstanceType,
-              /*shouldComputeAliasesToMakeVisible*/
-              false
-            ).accessibility !== 0 /* Accessible */)) || symbol.flags & (384 /* Enum */ | 512 /* ValueModule */) || shouldWriteTypeOfFunctionSymbol()) {
-              return symbolToTypeNode(symbol, context, isInstanceType);
-            } else if ((_a2 = context.visitedTypes) == null ? void 0 : _a2.has(typeId)) {
-              const typeAlias = getTypeAliasForTypeLiteral(type2);
-              if (typeAlias) {
-                return symbolToTypeNode(typeAlias, context, 788968 /* Type */);
-              } else {
-                return createElidedInformationPlaceholder(context);
-              }
-            } else {
-              return visitAndTransformType(type2, createTypeNodeFromObjectType);
-            }
-          } else {
-            const isInstantiationExpressionType = !!(getObjectFlags(type2) & 8388608 /* InstantiationExpressionType */);
-            if (isInstantiationExpressionType) {
-              const instantiationExpressionType = type2;
-              if (isTypeQueryNode(instantiationExpressionType.node)) {
-                const typeNode = serializeExistingTypeNode(context, instantiationExpressionType.node);
-                if (typeNode) {
-                  return typeNode;
-                }
-              }
-              if ((_b2 = context.visitedTypes) == null ? void 0 : _b2.has(typeId)) {
-                return createElidedInformationPlaceholder(context);
-              }
-              return visitAndTransformType(type2, createTypeNodeFromObjectType);
-            }
-            return createTypeNodeFromObjectType(type2);
-          }
-          function shouldWriteTypeOfFunctionSymbol() {
-            var _a3;
-            const isStaticMethodSymbol = !!(symbol.flags & 8192 /* Method */) && // typeof static method
-            some(symbol.declarations, (declaration) => isStatic(declaration));
-            const isNonLocalFunctionSymbol = !!(symbol.flags & 16 /* Function */) && (symbol.parent || // is exported function symbol
-            forEach(symbol.declarations, (declaration) => declaration.parent.kind === 311 /* SourceFile */ || declaration.parent.kind === 267 /* ModuleBlock */));
-            if (isStaticMethodSymbol || isNonLocalFunctionSymbol) {
-              return (!!(context.flags & 4096 /* UseTypeOfFunction */) || ((_a3 = context.visitedTypes) == null ? void 0 : _a3.has(typeId))) && // it is type of the symbol uses itself recursively
-              (!(context.flags & 8 /* UseStructuralFallback */) || isValueSymbolAccessible(symbol, context.enclosingDeclaration));
-            }
-          }
-        }
-        function visitAndTransformType(type2, transform2) {
-          var _a2, _b2;
-          const typeId = type2.id;
-          const isConstructorObject = getObjectFlags(type2) & 16 /* Anonymous */ && type2.symbol && type2.symbol.flags & 32 /* Class */;
-          const id = getObjectFlags(type2) & 4 /* Reference */ && type2.node ? "N" + getNodeId(type2.node) : type2.flags & 16777216 /* Conditional */ ? "N" + getNodeId(type2.root.node) : type2.symbol ? (isConstructorObject ? "+" : "") + getSymbolId(type2.symbol) : void 0;
-          if (!context.visitedTypes) {
-            context.visitedTypes = /* @__PURE__ */ new Set();
-          }
-          if (id && !context.symbolDepth) {
-            context.symbolDepth = /* @__PURE__ */ new Map();
-          }
-          const links = context.enclosingDeclaration && getNodeLinks(context.enclosingDeclaration);
-          const key = `${getTypeId(type2)}|${context.flags}`;
-          if (links) {
-            links.serializedTypes || (links.serializedTypes = /* @__PURE__ */ new Map());
-          }
-          const cachedResult = (_a2 = links == null ? void 0 : links.serializedTypes) == null ? void 0 : _a2.get(key);
-          if (cachedResult) {
-            if (cachedResult.truncating) {
-              context.truncating = true;
-            }
-            context.approximateLength += cachedResult.addedLength;
-            return deepCloneOrReuseNode(cachedResult.node);
-          }
-          let depth;
-          if (id) {
-            depth = context.symbolDepth.get(id) || 0;
-            if (depth > 10) {
-              return createElidedInformationPlaceholder(context);
-            }
-            context.symbolDepth.set(id, depth + 1);
-          }
-          context.visitedTypes.add(typeId);
-          const startLength = context.approximateLength;
-          const result = transform2(type2);
-          const addedLength = context.approximateLength - startLength;
-          if (!context.reportedDiagnostic && !context.encounteredError) {
-            (_b2 = links == null ? void 0 : links.serializedTypes) == null ? void 0 : _b2.set(key, { node: result, truncating: context.truncating, addedLength });
-          }
-          context.visitedTypes.delete(typeId);
-          if (id) {
-            context.symbolDepth.set(id, depth);
-          }
-          return result;
-          function deepCloneOrReuseNode(node) {
-            if (!nodeIsSynthesized(node) && getParseTreeNode(node) === node) {
-              return node;
-            }
-            return setTextRange(factory.cloneNode(visitEachChild(node, deepCloneOrReuseNode, nullTransformationContext, deepCloneOrReuseNodes)), node);
-          }
-          function deepCloneOrReuseNodes(nodes, visitor, test, start, count) {
-            if (nodes && nodes.length === 0) {
-              return setTextRange(factory.createNodeArray(
-                /*elements*/
-                void 0,
-                nodes.hasTrailingComma
-              ), nodes);
-            }
-            return visitNodes2(nodes, visitor, test, start, count);
-          }
-        }
-        function createTypeNodeFromObjectType(type2) {
-          if (isGenericMappedType(type2) || type2.containsError) {
-            return createMappedTypeNodeFromType(type2);
-          }
-          const resolved = resolveStructuredTypeMembers(type2);
-          if (!resolved.properties.length && !resolved.indexInfos.length) {
-            if (!resolved.callSignatures.length && !resolved.constructSignatures.length) {
-              context.approximateLength += 2;
-              return setEmitFlags(factory.createTypeLiteralNode(
-                /*members*/
-                void 0
-              ), 1 /* SingleLine */);
-            }
-            if (resolved.callSignatures.length === 1 && !resolved.constructSignatures.length) {
-              const signature = resolved.callSignatures[0];
-              const signatureNode = signatureToSignatureDeclarationHelper(signature, 183 /* FunctionType */, context);
-              return signatureNode;
-            }
-            if (resolved.constructSignatures.length === 1 && !resolved.callSignatures.length) {
-              const signature = resolved.constructSignatures[0];
-              const signatureNode = signatureToSignatureDeclarationHelper(signature, 184 /* ConstructorType */, context);
-              return signatureNode;
-            }
-          }
-          const abstractSignatures = filter(resolved.constructSignatures, (signature) => !!(signature.flags & 4 /* Abstract */));
-          if (some(abstractSignatures)) {
-            const types = map(abstractSignatures, getOrCreateTypeFromSignature);
-            const typeElementCount = resolved.callSignatures.length + (resolved.constructSignatures.length - abstractSignatures.length) + resolved.indexInfos.length + // exclude `prototype` when writing a class expression as a type literal, as per
-            // the logic in `createTypeNodesFromResolvedType`.
-            (context.flags & 2048 /* WriteClassExpressionAsTypeLiteral */ ? countWhere(resolved.properties, (p) => !(p.flags & 4194304 /* Prototype */)) : length(resolved.properties));
-            if (typeElementCount) {
-              types.push(getResolvedTypeWithoutAbstractConstructSignatures(resolved));
-            }
-            return typeToTypeNodeHelper(getIntersectionType(types), context);
-          }
-          const savedFlags = context.flags;
-          context.flags |= 4194304 /* InObjectTypeLiteral */;
-          const members = createTypeNodesFromResolvedType(resolved);
-          context.flags = savedFlags;
-          const typeLiteralNode = factory.createTypeLiteralNode(members);
-          context.approximateLength += 2;
-          setEmitFlags(typeLiteralNode, context.flags & 1024 /* MultilineObjectLiterals */ ? 0 : 1 /* SingleLine */);
-          return typeLiteralNode;
-        }
-        function typeReferenceToTypeNode(type2) {
-          let typeArguments = getTypeArguments(type2);
-          if (type2.target === globalArrayType || type2.target === globalReadonlyArrayType) {
-            if (context.flags & 2 /* WriteArrayAsGenericType */) {
-              const typeArgumentNode = typeToTypeNodeHelper(typeArguments[0], context);
-              return factory.createTypeReferenceNode(type2.target === globalArrayType ? "Array" : "ReadonlyArray", [typeArgumentNode]);
-            }
-            const elementType = typeToTypeNodeHelper(typeArguments[0], context);
-            const arrayType = factory.createArrayTypeNode(elementType);
-            return type2.target === globalArrayType ? arrayType : factory.createTypeOperatorNode(148 /* ReadonlyKeyword */, arrayType);
-          } else if (type2.target.objectFlags & 8 /* Tuple */) {
-            typeArguments = sameMap(typeArguments, (t, i) => removeMissingType(t, !!(type2.target.elementFlags[i] & 2 /* Optional */)));
-            if (typeArguments.length > 0) {
-              const arity = getTypeReferenceArity(type2);
-              const tupleConstituentNodes = mapToTypeNodes(typeArguments.slice(0, arity), context);
-              if (tupleConstituentNodes) {
-                if (type2.target.labeledElementDeclarations) {
-                  for (let i = 0; i < tupleConstituentNodes.length; i++) {
-                    const flags = type2.target.elementFlags[i];
-                    tupleConstituentNodes[i] = factory.createNamedTupleMember(
-                      flags & 12 /* Variable */ ? factory.createToken(26 /* DotDotDotToken */) : void 0,
-                      factory.createIdentifier(unescapeLeadingUnderscores(getTupleElementLabel(type2.target.labeledElementDeclarations[i]))),
-                      flags & 2 /* Optional */ ? factory.createToken(58 /* QuestionToken */) : void 0,
-                      flags & 4 /* Rest */ ? factory.createArrayTypeNode(tupleConstituentNodes[i]) : tupleConstituentNodes[i]
-                    );
-                  }
-                } else {
-                  for (let i = 0; i < Math.min(arity, tupleConstituentNodes.length); i++) {
-                    const flags = type2.target.elementFlags[i];
-                    tupleConstituentNodes[i] = flags & 12 /* Variable */ ? factory.createRestTypeNode(flags & 4 /* Rest */ ? factory.createArrayTypeNode(tupleConstituentNodes[i]) : tupleConstituentNodes[i]) : flags & 2 /* Optional */ ? factory.createOptionalTypeNode(tupleConstituentNodes[i]) : tupleConstituentNodes[i];
-                  }
-                }
-                const tupleTypeNode = setEmitFlags(factory.createTupleTypeNode(tupleConstituentNodes), 1 /* SingleLine */);
-                return type2.target.readonly ? factory.createTypeOperatorNode(148 /* ReadonlyKeyword */, tupleTypeNode) : tupleTypeNode;
-              }
-            }
-            if (context.encounteredError || context.flags & 524288 /* AllowEmptyTuple */) {
-              const tupleTypeNode = setEmitFlags(factory.createTupleTypeNode([]), 1 /* SingleLine */);
-              return type2.target.readonly ? factory.createTypeOperatorNode(148 /* ReadonlyKeyword */, tupleTypeNode) : tupleTypeNode;
-            }
-            context.encounteredError = true;
-            return void 0;
-          } else if (context.flags & 2048 /* WriteClassExpressionAsTypeLiteral */ && type2.symbol.valueDeclaration && isClassLike(type2.symbol.valueDeclaration) && !isValueSymbolAccessible(type2.symbol, context.enclosingDeclaration)) {
-            return createAnonymousTypeNode(type2);
-          } else {
-            const outerTypeParameters = type2.target.outerTypeParameters;
-            let i = 0;
-            let resultType;
-            if (outerTypeParameters) {
-              const length2 = outerTypeParameters.length;
-              while (i < length2) {
-                const start = i;
-                const parent2 = getParentSymbolOfTypeParameter(outerTypeParameters[i]);
-                do {
-                  i++;
-                } while (i < length2 && getParentSymbolOfTypeParameter(outerTypeParameters[i]) === parent2);
-                if (!rangeEquals(outerTypeParameters, typeArguments, start, i)) {
-                  const typeArgumentSlice = mapToTypeNodes(typeArguments.slice(start, i), context);
-                  const flags2 = context.flags;
-                  context.flags |= 16 /* ForbidIndexedAccessSymbolReferences */;
-                  const ref = symbolToTypeNode(parent2, context, 788968 /* Type */, typeArgumentSlice);
-                  context.flags = flags2;
-                  resultType = !resultType ? ref : appendReferenceToType(resultType, ref);
-                }
-              }
-            }
-            let typeArgumentNodes;
-            if (typeArguments.length > 0) {
-              const typeParameterCount = (type2.target.typeParameters || emptyArray).length;
-              typeArgumentNodes = mapToTypeNodes(typeArguments.slice(i, typeParameterCount), context);
-            }
-            const flags = context.flags;
-            context.flags |= 16 /* ForbidIndexedAccessSymbolReferences */;
-            const finalRef = symbolToTypeNode(type2.symbol, context, 788968 /* Type */, typeArgumentNodes);
-            context.flags = flags;
-            return !resultType ? finalRef : appendReferenceToType(resultType, finalRef);
-          }
-        }
-        function appendReferenceToType(root, ref) {
-          if (isImportTypeNode(root)) {
-            let typeArguments = root.typeArguments;
-            let qualifier = root.qualifier;
-            if (qualifier) {
-              if (isIdentifier(qualifier)) {
-                if (typeArguments !== getIdentifierTypeArguments(qualifier)) {
-                  qualifier = setIdentifierTypeArguments(factory.cloneNode(qualifier), typeArguments);
-                }
-              } else {
-                if (typeArguments !== getIdentifierTypeArguments(qualifier.right)) {
-                  qualifier = factory.updateQualifiedName(
-                    qualifier,
-                    qualifier.left,
-                    setIdentifierTypeArguments(factory.cloneNode(qualifier.right), typeArguments)
-                  );
-                }
-              }
-            }
-            typeArguments = ref.typeArguments;
-            const ids = getAccessStack(ref);
-            for (const id of ids) {
-              qualifier = qualifier ? factory.createQualifiedName(qualifier, id) : id;
-            }
-            return factory.updateImportTypeNode(
-              root,
-              root.argument,
-              root.assertions,
-              qualifier,
-              typeArguments,
-              root.isTypeOf
-            );
-          } else {
-            let typeArguments = root.typeArguments;
-            let typeName = root.typeName;
-            if (isIdentifier(typeName)) {
-              if (typeArguments !== getIdentifierTypeArguments(typeName)) {
-                typeName = setIdentifierTypeArguments(factory.cloneNode(typeName), typeArguments);
-              }
-            } else {
-              if (typeArguments !== getIdentifierTypeArguments(typeName.right)) {
-                typeName = factory.updateQualifiedName(
-                  typeName,
-                  typeName.left,
-                  setIdentifierTypeArguments(factory.cloneNode(typeName.right), typeArguments)
-                );
-              }
-            }
-            typeArguments = ref.typeArguments;
-            const ids = getAccessStack(ref);
-            for (const id of ids) {
-              typeName = factory.createQualifiedName(typeName, id);
-            }
-            return factory.updateTypeReferenceNode(
-              root,
-              typeName,
-              typeArguments
-            );
-          }
-        }
-        function getAccessStack(ref) {
-          let state = ref.typeName;
-          const ids = [];
-          while (!isIdentifier(state)) {
-            ids.unshift(state.right);
-            state = state.left;
-          }
-          ids.unshift(state);
-          return ids;
-        }
-        function createTypeNodesFromResolvedType(resolvedType) {
-          if (checkTruncationLength(context)) {
-            return [factory.createPropertySignature(
-              /*modifiers*/
-              void 0,
-              "...",
-              /*questionToken*/
-              void 0,
-              /*type*/
-              void 0
-            )];
-          }
-          const typeElements = [];
-          for (const signature of resolvedType.callSignatures) {
-            typeElements.push(signatureToSignatureDeclarationHelper(signature, 178 /* CallSignature */, context));
-          }
-          for (const signature of resolvedType.constructSignatures) {
-            if (signature.flags & 4 /* Abstract */)
-              continue;
-            typeElements.push(signatureToSignatureDeclarationHelper(signature, 179 /* ConstructSignature */, context));
-          }
-          for (const info of resolvedType.indexInfos) {
-            typeElements.push(indexInfoToIndexSignatureDeclarationHelper(info, context, resolvedType.objectFlags & 1024 /* ReverseMapped */ ? createElidedInformationPlaceholder(context) : void 0));
-          }
-          const properties = resolvedType.properties;
-          if (!properties) {
-            return typeElements;
-          }
-          let i = 0;
-          for (const propertySymbol of properties) {
-            i++;
-            if (context.flags & 2048 /* WriteClassExpressionAsTypeLiteral */) {
-              if (propertySymbol.flags & 4194304 /* Prototype */) {
-                continue;
-              }
-              if (getDeclarationModifierFlagsFromSymbol(propertySymbol) & (8 /* Private */ | 16 /* Protected */) && context.tracker.reportPrivateInBaseOfClassExpression) {
-                context.tracker.reportPrivateInBaseOfClassExpression(unescapeLeadingUnderscores(propertySymbol.escapedName));
-              }
-            }
-            if (checkTruncationLength(context) && i + 2 < properties.length - 1) {
-              typeElements.push(factory.createPropertySignature(
-                /*modifiers*/
-                void 0,
-                `... ${properties.length - i} more ...`,
-                /*questionToken*/
-                void 0,
-                /*type*/
-                void 0
-              ));
-              addPropertyToElementList(properties[properties.length - 1], context, typeElements);
-              break;
-            }
-            addPropertyToElementList(propertySymbol, context, typeElements);
-          }
-          return typeElements.length ? typeElements : void 0;
-        }
-      }
-      function createElidedInformationPlaceholder(context) {
-        context.approximateLength += 3;
-        if (!(context.flags & 1 /* NoTruncation */)) {
-          return factory.createTypeReferenceNode(
-            factory.createIdentifier("..."),
-            /*typeArguments*/
-            void 0
-          );
-        }
-        return factory.createKeywordTypeNode(133 /* AnyKeyword */);
-      }
-      function shouldUsePlaceholderForProperty(propertySymbol, context) {
-        var _a;
-        return !!(getCheckFlags(propertySymbol) & 8192 /* ReverseMapped */) && (contains(context.reverseMappedStack, propertySymbol) || ((_a = context.reverseMappedStack) == null ? void 0 : _a[0]) && !(getObjectFlags(last(context.reverseMappedStack).links.propertyType) & 16 /* Anonymous */));
-      }
-      function addPropertyToElementList(propertySymbol, context, typeElements) {
-        var _a;
-        const propertyIsReverseMapped = !!(getCheckFlags(propertySymbol) & 8192 /* ReverseMapped */);
-        const propertyType = shouldUsePlaceholderForProperty(propertySymbol, context) ? anyType : getNonMissingTypeOfSymbol(propertySymbol);
-        const saveEnclosingDeclaration = context.enclosingDeclaration;
-        context.enclosingDeclaration = void 0;
-        if (context.tracker.canTrackSymbol && isLateBoundName(propertySymbol.escapedName)) {
-          if (propertySymbol.declarations) {
-            const decl = first(propertySymbol.declarations);
-            if (hasLateBindableName(decl)) {
-              if (isBinaryExpression(decl)) {
-                const name = getNameOfDeclaration(decl);
-                if (name && isElementAccessExpression(name) && isPropertyAccessEntityNameExpression(name.argumentExpression)) {
-                  trackComputedName(name.argumentExpression, saveEnclosingDeclaration, context);
-                }
-              } else {
-                trackComputedName(decl.name.expression, saveEnclosingDeclaration, context);
-              }
-            }
-          } else {
-            context.tracker.reportNonSerializableProperty(symbolToString(propertySymbol));
-          }
-        }
-        context.enclosingDeclaration = propertySymbol.valueDeclaration || ((_a = propertySymbol.declarations) == null ? void 0 : _a[0]) || saveEnclosingDeclaration;
-        const propertyName = getPropertyNameNodeForSymbol(propertySymbol, context);
-        context.enclosingDeclaration = saveEnclosingDeclaration;
-        context.approximateLength += symbolName(propertySymbol).length + 1;
-        const optionalToken = propertySymbol.flags & 16777216 /* Optional */ ? factory.createToken(58 /* QuestionToken */) : void 0;
-        if (propertySymbol.flags & (16 /* Function */ | 8192 /* Method */) && !getPropertiesOfObjectType(propertyType).length && !isReadonlySymbol(propertySymbol)) {
-          const signatures = getSignaturesOfType(filterType(propertyType, (t) => !(t.flags & 32768 /* Undefined */)), 0 /* Call */);
-          for (const signature of signatures) {
-            const methodDeclaration = signatureToSignatureDeclarationHelper(signature, 172 /* MethodSignature */, context, { name: propertyName, questionToken: optionalToken });
-            typeElements.push(preserveCommentsOn(methodDeclaration));
-          }
-        } else {
-          let propertyTypeNode;
-          if (shouldUsePlaceholderForProperty(propertySymbol, context)) {
-            propertyTypeNode = createElidedInformationPlaceholder(context);
-          } else {
-            if (propertyIsReverseMapped) {
-              context.reverseMappedStack || (context.reverseMappedStack = []);
-              context.reverseMappedStack.push(propertySymbol);
-            }
-            propertyTypeNode = propertyType ? serializeTypeForDeclaration(context, propertyType, propertySymbol, saveEnclosingDeclaration) : factory.createKeywordTypeNode(133 /* AnyKeyword */);
-            if (propertyIsReverseMapped) {
-              context.reverseMappedStack.pop();
-            }
-          }
-          const modifiers = isReadonlySymbol(propertySymbol) ? [factory.createToken(148 /* ReadonlyKeyword */)] : void 0;
-          if (modifiers) {
-            context.approximateLength += 9;
-          }
-          const propertySignature = factory.createPropertySignature(
-            modifiers,
-            propertyName,
-            optionalToken,
-            propertyTypeNode
-          );
-          typeElements.push(preserveCommentsOn(propertySignature));
-        }
-        function preserveCommentsOn(node) {
-          var _a2;
-          if (some(propertySymbol.declarations, (d) => d.kind === 354 /* JSDocPropertyTag */)) {
-            const d = (_a2 = propertySymbol.declarations) == null ? void 0 : _a2.find((d2) => d2.kind === 354 /* JSDocPropertyTag */);
-            const commentText = getTextOfJSDocComment(d.comment);
-            if (commentText) {
-              setSyntheticLeadingComments(node, [{ kind: 3 /* MultiLineCommentTrivia */, text: "*\n * " + commentText.replace(/\n/g, "\n * ") + "\n ", pos: -1, end: -1, hasTrailingNewLine: true }]);
-            }
-          } else if (propertySymbol.valueDeclaration) {
-            setCommentRange(node, propertySymbol.valueDeclaration);
-          }
-          return node;
-        }
-      }
-      function mapToTypeNodes(types, context, isBareList) {
-        if (some(types)) {
-          if (checkTruncationLength(context)) {
-            if (!isBareList) {
-              return [factory.createTypeReferenceNode(
-                "...",
-                /*typeArguments*/
-                void 0
-              )];
-            } else if (types.length > 2) {
-              return [
-                typeToTypeNodeHelper(types[0], context),
-                factory.createTypeReferenceNode(
-                  `... ${types.length - 2} more ...`,
-                  /*typeArguments*/
-                  void 0
-                ),
-                typeToTypeNodeHelper(types[types.length - 1], context)
-              ];
-            }
-          }
-          const mayHaveNameCollisions = !(context.flags & 64 /* UseFullyQualifiedType */);
-          const seenNames = mayHaveNameCollisions ? createMultiMap() : void 0;
-          const result = [];
-          let i = 0;
-          for (const type of types) {
-            i++;
-            if (checkTruncationLength(context) && i + 2 < types.length - 1) {
-              result.push(factory.createTypeReferenceNode(
-                `... ${types.length - i} more ...`,
-                /*typeArguments*/
-                void 0
-              ));
-              const typeNode2 = typeToTypeNodeHelper(types[types.length - 1], context);
-              if (typeNode2) {
-                result.push(typeNode2);
-              }
-              break;
-            }
-            context.approximateLength += 2;
-            const typeNode = typeToTypeNodeHelper(type, context);
-            if (typeNode) {
-              result.push(typeNode);
-              if (seenNames && isIdentifierTypeReference(typeNode)) {
-                seenNames.add(typeNode.typeName.escapedText, [type, result.length - 1]);
-              }
-            }
-          }
-          if (seenNames) {
-            const saveContextFlags = context.flags;
-            context.flags |= 64 /* UseFullyQualifiedType */;
-            seenNames.forEach((types2) => {
-              if (!arrayIsHomogeneous(types2, ([a], [b]) => typesAreSameReference(a, b))) {
-                for (const [type, resultIndex] of types2) {
-                  result[resultIndex] = typeToTypeNodeHelper(type, context);
-                }
-              }
-            });
-            context.flags = saveContextFlags;
-          }
-          return result;
-        }
-      }
-      function typesAreSameReference(a, b) {
-        return a === b || !!a.symbol && a.symbol === b.symbol || !!a.aliasSymbol && a.aliasSymbol === b.aliasSymbol;
-      }
-      function indexInfoToIndexSignatureDeclarationHelper(indexInfo, context, typeNode) {
-        const name = getNameFromIndexInfo(indexInfo) || "x";
-        const indexerTypeNode = typeToTypeNodeHelper(indexInfo.keyType, context);
-        const indexingParameter = factory.createParameterDeclaration(
-          /*modifiers*/
-          void 0,
-          /*dotDotDotToken*/
-          void 0,
-          name,
-          /*questionToken*/
-          void 0,
-          indexerTypeNode,
-          /*initializer*/
-          void 0
-        );
-        if (!typeNode) {
-          typeNode = typeToTypeNodeHelper(indexInfo.type || anyType, context);
-        }
-        if (!indexInfo.type && !(context.flags & 2097152 /* AllowEmptyIndexInfoType */)) {
-          context.encounteredError = true;
-        }
-        context.approximateLength += name.length + 4;
-        return factory.createIndexSignature(
-          indexInfo.isReadonly ? [factory.createToken(148 /* ReadonlyKeyword */)] : void 0,
-          [indexingParameter],
-          typeNode
-        );
-      }
-      function signatureToSignatureDeclarationHelper(signature, kind, context, options) {
-        const suppressAny = context.flags & 256 /* SuppressAnyReturnType */;
-        if (suppressAny)
-          context.flags &= ~256 /* SuppressAnyReturnType */;
-        context.approximateLength += 3;
-        let typeParameters;
-        let typeArguments;
-        if (context.flags & 32 /* WriteTypeArgumentsOfSignature */ && signature.target && signature.mapper && signature.target.typeParameters) {
-          typeArguments = signature.target.typeParameters.map((parameter) => typeToTypeNodeHelper(instantiateType(parameter, signature.mapper), context));
-        } else {
-          typeParameters = signature.typeParameters && signature.typeParameters.map((parameter) => typeParameterToDeclaration(parameter, context));
-        }
-        const expandedParams = getExpandedParameters(
-          signature,
-          /*skipUnionExpanding*/
-          true
-        )[0];
-        let cleanup;
-        if (context.enclosingDeclaration && signature.declaration && signature.declaration !== context.enclosingDeclaration && !isInJSFile(signature.declaration) && some(expandedParams)) {
-          const existingFakeScope = getNodeLinks(context.enclosingDeclaration).fakeScopeForSignatureDeclaration ? context.enclosingDeclaration : void 0;
-          Debug.assertOptionalNode(existingFakeScope, isBlock);
-          const locals = (existingFakeScope == null ? void 0 : existingFakeScope.locals) ?? createSymbolTable();
-          let newLocals;
-          for (const param of expandedParams) {
-            if (!locals.has(param.escapedName)) {
-              newLocals = append(newLocals, param.escapedName);
-              locals.set(param.escapedName, param);
-            }
-          }
-          if (newLocals) {
-            let removeNewLocals2 = function() {
-              forEach(newLocals, (s) => locals.delete(s));
-            };
-            var removeNewLocals = removeNewLocals2;
-            if (existingFakeScope) {
-              cleanup = removeNewLocals2;
-            } else {
-              const fakeScope = parseNodeFactory.createBlock(emptyArray);
-              getNodeLinks(fakeScope).fakeScopeForSignatureDeclaration = true;
-              fakeScope.locals = locals;
-              const saveEnclosingDeclaration = context.enclosingDeclaration;
-              setParent(fakeScope, saveEnclosingDeclaration);
-              context.enclosingDeclaration = fakeScope;
-              cleanup = () => {
-                context.enclosingDeclaration = saveEnclosingDeclaration;
-                removeNewLocals2();
-              };
-            }
-          }
-        }
-        const parameters = (some(expandedParams, (p) => p !== expandedParams[expandedParams.length - 1] && !!(getCheckFlags(p) & 32768 /* RestParameter */)) ? signature.parameters : expandedParams).map((parameter) => symbolToParameterDeclaration(parameter, context, kind === 175 /* Constructor */, options == null ? void 0 : options.privateSymbolVisitor, options == null ? void 0 : options.bundledImports));
-        const thisParameter = context.flags & 33554432 /* OmitThisParameter */ ? void 0 : tryGetThisParameterDeclaration(signature, context);
-        if (thisParameter) {
-          parameters.unshift(thisParameter);
-        }
-        let returnTypeNode;
-        const typePredicate = getTypePredicateOfSignature(signature);
-        if (typePredicate) {
-          const assertsModifier = typePredicate.kind === 2 /* AssertsThis */ || typePredicate.kind === 3 /* AssertsIdentifier */ ? factory.createToken(131 /* AssertsKeyword */) : void 0;
-          const parameterName = typePredicate.kind === 1 /* Identifier */ || typePredicate.kind === 3 /* AssertsIdentifier */ ? setEmitFlags(factory.createIdentifier(typePredicate.parameterName), 16777216 /* NoAsciiEscaping */) : factory.createThisTypeNode();
-          const typeNode = typePredicate.type && typeToTypeNodeHelper(typePredicate.type, context);
-          returnTypeNode = factory.createTypePredicateNode(assertsModifier, parameterName, typeNode);
-        } else {
-          const returnType = getReturnTypeOfSignature(signature);
-          if (returnType && !(suppressAny && isTypeAny(returnType))) {
-            returnTypeNode = serializeReturnTypeForSignature(context, returnType, signature, options == null ? void 0 : options.privateSymbolVisitor, options == null ? void 0 : options.bundledImports);
-          } else if (!suppressAny) {
-            returnTypeNode = factory.createKeywordTypeNode(133 /* AnyKeyword */);
-          }
-        }
-        let modifiers = options == null ? void 0 : options.modifiers;
-        if (kind === 184 /* ConstructorType */ && signature.flags & 4 /* Abstract */) {
-          const flags = modifiersToFlags(modifiers);
-          modifiers = factory.createModifiersFromModifierFlags(flags | 256 /* Abstract */);
-        }
-        const node = kind === 178 /* CallSignature */ ? factory.createCallSignature(typeParameters, parameters, returnTypeNode) : kind === 179 /* ConstructSignature */ ? factory.createConstructSignature(typeParameters, parameters, returnTypeNode) : kind === 172 /* MethodSignature */ ? factory.createMethodSignature(modifiers, (options == null ? void 0 : options.name) ?? factory.createIdentifier(""), options == null ? void 0 : options.questionToken, typeParameters, parameters, returnTypeNode) : kind === 173 /* MethodDeclaration */ ? factory.createMethodDeclaration(
-          modifiers,
-          /*asteriskToken*/
-          void 0,
-          (options == null ? void 0 : options.name) ?? factory.createIdentifier(""),
-          /*questionToken*/
-          void 0,
-          typeParameters,
-          parameters,
-          returnTypeNode,
-          /*body*/
-          void 0
-        ) : kind === 175 /* Constructor */ ? factory.createConstructorDeclaration(
-          modifiers,
-          parameters,
-          /*body*/
-          void 0
-        ) : kind === 176 /* GetAccessor */ ? factory.createGetAccessorDeclaration(
-          modifiers,
-          (options == null ? void 0 : options.name) ?? factory.createIdentifier(""),
-          parameters,
-          returnTypeNode,
-          /*body*/
-          void 0
-        ) : kind === 177 /* SetAccessor */ ? factory.createSetAccessorDeclaration(
-          modifiers,
-          (options == null ? void 0 : options.name) ?? factory.createIdentifier(""),
-          parameters,
-          /*body*/
-          void 0
-        ) : kind === 180 /* IndexSignature */ ? factory.createIndexSignature(modifiers, parameters, returnTypeNode) : kind === 323 /* JSDocFunctionType */ ? factory.createJSDocFunctionType(parameters, returnTypeNode) : kind === 183 /* FunctionType */ ? factory.createFunctionTypeNode(typeParameters, parameters, returnTypeNode ?? factory.createTypeReferenceNode(factory.createIdentifier(""))) : kind === 184 /* ConstructorType */ ? factory.createConstructorTypeNode(modifiers, typeParameters, parameters, returnTypeNode ?? factory.createTypeReferenceNode(factory.createIdentifier(""))) : kind === 261 /* FunctionDeclaration */ ? factory.createFunctionDeclaration(
-          modifiers,
-          /*asteriskToken*/
-          void 0,
-          (options == null ? void 0 : options.name) ? cast(options.name, isIdentifier) : factory.createIdentifier(""),
-          typeParameters,
-          parameters,
-          returnTypeNode,
-          /*body*/
-          void 0
-        ) : kind === 217 /* FunctionExpression */ ? factory.createFunctionExpression(
-          modifiers,
-          /*asteriskToken*/
-          void 0,
-          (options == null ? void 0 : options.name) ? cast(options.name, isIdentifier) : factory.createIdentifier(""),
-          typeParameters,
-          parameters,
-          returnTypeNode,
-          factory.createBlock([])
-        ) : kind === 218 /* ArrowFunction */ ? factory.createArrowFunction(
-          modifiers,
-          typeParameters,
-          parameters,
-          returnTypeNode,
-          /*equalsGreaterThanToken*/
-          void 0,
-          factory.createBlock([])
-        ) : Debug.assertNever(kind);
-        if (typeArguments) {
-          node.typeArguments = factory.createNodeArray(typeArguments);
-        }
-        cleanup == null ? void 0 : cleanup();
-        return node;
-      }
-      function tryGetThisParameterDeclaration(signature, context) {
-        if (signature.thisParameter) {
-          return symbolToParameterDeclaration(signature.thisParameter, context);
-        }
-        if (signature.declaration && isInJSFile(signature.declaration)) {
-          const thisTag = getJSDocThisTag(signature.declaration);
-          if (thisTag && thisTag.typeExpression) {
-            return factory.createParameterDeclaration(
-              /*modifiers*/
-              void 0,
-              /*dotDotDotToken*/
-              void 0,
-              "this",
-              /*questionToken*/
-              void 0,
-              typeToTypeNodeHelper(getTypeFromTypeNode(thisTag.typeExpression), context)
-            );
-          }
-        }
-      }
-      function typeParameterToDeclarationWithConstraint(type, context, constraintNode) {
-        const savedContextFlags = context.flags;
-        context.flags &= ~512 /* WriteTypeParametersInQualifiedName */;
-        const modifiers = factory.createModifiersFromModifierFlags(getTypeParameterModifiers(type));
-        const name = typeParameterToName(type, context);
-        const defaultParameter = getDefaultFromTypeParameter(type);
-        const defaultParameterNode = defaultParameter && typeToTypeNodeHelper(defaultParameter, context);
-        context.flags = savedContextFlags;
-        return factory.createTypeParameterDeclaration(modifiers, name, constraintNode, defaultParameterNode);
-      }
-      function typeParameterToDeclaration(type, context, constraint = getConstraintOfTypeParameter(type)) {
-        const constraintNode = constraint && typeToTypeNodeHelper(constraint, context);
-        return typeParameterToDeclarationWithConstraint(type, context, constraintNode);
-      }
-      function symbolToParameterDeclaration(parameterSymbol, context, preserveModifierFlags, privateSymbolVisitor, bundledImports) {
-        let parameterDeclaration = getDeclarationOfKind(parameterSymbol, 168 /* Parameter */);
-        if (!parameterDeclaration && !isTransientSymbol(parameterSymbol)) {
-          parameterDeclaration = getDeclarationOfKind(parameterSymbol, 347 /* JSDocParameterTag */);
-        }
-        let parameterType = getTypeOfSymbol(parameterSymbol);
-        if (parameterDeclaration && isRequiredInitializedParameter(parameterDeclaration)) {
-          parameterType = getOptionalType(parameterType);
-        }
-        const parameterTypeNode = serializeTypeForDeclaration(context, parameterType, parameterSymbol, context.enclosingDeclaration, privateSymbolVisitor, bundledImports);
-        const modifiers = !(context.flags & 8192 /* OmitParameterModifiers */) && preserveModifierFlags && parameterDeclaration && canHaveModifiers(parameterDeclaration) ? map(getModifiers(parameterDeclaration), factory.cloneNode) : void 0;
-        const isRest = parameterDeclaration && isRestParameter(parameterDeclaration) || getCheckFlags(parameterSymbol) & 32768 /* RestParameter */;
-        const dotDotDotToken = isRest ? factory.createToken(26 /* DotDotDotToken */) : void 0;
-        const name = parameterDeclaration ? parameterDeclaration.name ? parameterDeclaration.name.kind === 80 /* Identifier */ ? setEmitFlags(factory.cloneNode(parameterDeclaration.name), 16777216 /* NoAsciiEscaping */) : parameterDeclaration.name.kind === 165 /* QualifiedName */ ? setEmitFlags(factory.cloneNode(parameterDeclaration.name.right), 16777216 /* NoAsciiEscaping */) : cloneBindingName(parameterDeclaration.name) : symbolName(parameterSymbol) : symbolName(parameterSymbol);
-        const isOptional = parameterDeclaration && isOptionalParameter(parameterDeclaration) || getCheckFlags(parameterSymbol) & 16384 /* OptionalParameter */;
-        const questionToken = isOptional ? factory.createToken(58 /* QuestionToken */) : void 0;
-        const parameterNode = factory.createParameterDeclaration(
-          modifiers,
-          dotDotDotToken,
-          name,
-          questionToken,
-          parameterTypeNode,
-          /*initializer*/
-          void 0
-        );
-        context.approximateLength += symbolName(parameterSymbol).length + 3;
-        return parameterNode;
-        function cloneBindingName(node) {
-          return elideInitializerAndSetEmitFlags(node);
-          function elideInitializerAndSetEmitFlags(node2) {
-            if (context.tracker.canTrackSymbol && isComputedPropertyName(node2) && isLateBindableName(node2)) {
-              trackComputedName(node2.expression, context.enclosingDeclaration, context);
-            }
-            let visited = visitEachChild(
-              node2,
-              elideInitializerAndSetEmitFlags,
-              nullTransformationContext,
-              /*nodesVisitor*/
-              void 0,
-              elideInitializerAndSetEmitFlags
-            );
-            if (isBindingElement(visited)) {
-              visited = factory.updateBindingElement(
-                visited,
-                visited.dotDotDotToken,
-                visited.propertyName,
-                visited.name,
-                /*initializer*/
-                void 0
-              );
-            }
-            if (!nodeIsSynthesized(visited)) {
-              visited = factory.cloneNode(visited);
-            }
-            return setEmitFlags(visited, 1 /* SingleLine */ | 16777216 /* NoAsciiEscaping */);
-          }
-        }
-      }
-      function trackComputedName(accessExpression, enclosingDeclaration, context) {
-        if (!context.tracker.canTrackSymbol)
-          return;
-        const firstIdentifier = getFirstIdentifier(accessExpression);
-        const name = resolveName(
-          firstIdentifier,
-          firstIdentifier.escapedText,
-          111551 /* Value */ | 1048576 /* ExportValue */,
-          /*nameNotFoundMessage*/
-          void 0,
-          /*nameArg*/
-          void 0,
-          /*isUse*/
-          true
-        );
-        if (name) {
-          context.tracker.trackSymbol(name, enclosingDeclaration, 111551 /* Value */);
-        }
-      }
-      function lookupSymbolChain(symbol, context, meaning, yieldModuleSymbol) {
-        context.tracker.trackSymbol(symbol, context.enclosingDeclaration, meaning);
-        return lookupSymbolChainWorker(symbol, context, meaning, yieldModuleSymbol);
-      }
-      function lookupSymbolChainWorker(symbol, context, meaning, yieldModuleSymbol) {
-        let chain;
-        const isTypeParameter = symbol.flags & 262144 /* TypeParameter */;
-        if (!isTypeParameter && (context.enclosingDeclaration || context.flags & 64 /* UseFullyQualifiedType */) && !(context.flags & 134217728 /* DoNotIncludeSymbolChain */)) {
-          chain = Debug.checkDefined(getSymbolChain(
-            symbol,
-            meaning,
-            /*endOfChain*/
-            true
-          ));
-          Debug.assert(chain && chain.length > 0);
-        } else {
-          chain = [symbol];
-        }
-        return chain;
-        function getSymbolChain(symbol2, meaning2, endOfChain) {
-          let accessibleSymbolChain = getAccessibleSymbolChain(symbol2, context.enclosingDeclaration, meaning2, !!(context.flags & 128 /* UseOnlyExternalAliasing */));
-          let parentSpecifiers;
-          if (!accessibleSymbolChain || needsQualification(accessibleSymbolChain[0], context.enclosingDeclaration, accessibleSymbolChain.length === 1 ? meaning2 : getQualifiedLeftMeaning(meaning2))) {
-            const parents = getContainersOfSymbol(accessibleSymbolChain ? accessibleSymbolChain[0] : symbol2, context.enclosingDeclaration, meaning2);
-            if (length(parents)) {
-              parentSpecifiers = parents.map((symbol3) => some(symbol3.declarations, hasNonGlobalAugmentationExternalModuleSymbol) ? getSpecifierForModuleSymbol(symbol3, context) : void 0);
-              const indices = parents.map((_, i) => i);
-              indices.sort(sortByBestName);
-              const sortedParents = indices.map((i) => parents[i]);
-              for (const parent2 of sortedParents) {
-                const parentChain = getSymbolChain(
-                  parent2,
-                  getQualifiedLeftMeaning(meaning2),
-                  /*endOfChain*/
-                  false
-                );
-                if (parentChain) {
-                  if (parent2.exports && parent2.exports.get("export=" /* ExportEquals */) && getSymbolIfSameReference(parent2.exports.get("export=" /* ExportEquals */), symbol2)) {
-                    accessibleSymbolChain = parentChain;
-                    break;
-                  }
-                  accessibleSymbolChain = parentChain.concat(accessibleSymbolChain || [getAliasForSymbolInContainer(parent2, symbol2) || symbol2]);
-                  break;
-                }
-              }
-            }
-          }
-          if (accessibleSymbolChain) {
-            return accessibleSymbolChain;
-          }
-          if (
-            // If this is the last part of outputting the symbol, always output. The cases apply only to parent symbols.
-            endOfChain || // If a parent symbol is an anonymous type, don't write it.
-            !(symbol2.flags & (2048 /* TypeLiteral */ | 4096 /* ObjectLiteral */))
-          ) {
-            if (!endOfChain && !yieldModuleSymbol && !!forEach(symbol2.declarations, hasNonGlobalAugmentationExternalModuleSymbol)) {
-              return;
-            }
-            return [symbol2];
-          }
-          function sortByBestName(a, b) {
-            const specifierA = parentSpecifiers[a];
-            const specifierB = parentSpecifiers[b];
-            if (specifierA && specifierB) {
-              const isBRelative = pathIsRelative(specifierB);
-              if (pathIsRelative(specifierA) === isBRelative) {
-                return countPathComponents(specifierA) - countPathComponents(specifierB);
-              }
-              if (isBRelative) {
-                return -1;
-              }
-              return 1;
-            }
-            return 0;
-          }
-        }
-      }
-      function typeParametersToTypeParameterDeclarations(symbol, context) {
-        let typeParameterNodes;
-        const targetSymbol = getTargetSymbol(symbol);
-        if (targetSymbol.flags & (32 /* Class */ | 64 /* Interface */ | 524288 /* TypeAlias */)) {
-          typeParameterNodes = factory.createNodeArray(map(getLocalTypeParametersOfClassOrInterfaceOrTypeAlias(symbol), (tp) => typeParameterToDeclaration(tp, context)));
-        }
-        return typeParameterNodes;
-      }
-      function lookupTypeParameterNodes(chain, index, context) {
-        var _a;
-        Debug.assert(chain && 0 <= index && index < chain.length);
-        const symbol = chain[index];
-        const symbolId = getSymbolId(symbol);
-        if ((_a = context.typeParameterSymbolList) == null ? void 0 : _a.has(symbolId)) {
-          return void 0;
-        }
-        (context.typeParameterSymbolList || (context.typeParameterSymbolList = /* @__PURE__ */ new Set())).add(symbolId);
-        let typeParameterNodes;
-        if (context.flags & 512 /* WriteTypeParametersInQualifiedName */ && index < chain.length - 1) {
-          const parentSymbol = symbol;
-          const nextSymbol = chain[index + 1];
-          if (getCheckFlags(nextSymbol) & 1 /* Instantiated */) {
-            const params = getTypeParametersOfClassOrInterface(
-              parentSymbol.flags & 2097152 /* Alias */ ? resolveAlias(parentSymbol) : parentSymbol
-            );
-            typeParameterNodes = mapToTypeNodes(map(params, (t) => getMappedType(t, nextSymbol.links.mapper)), context);
-          } else {
-            typeParameterNodes = typeParametersToTypeParameterDeclarations(symbol, context);
-          }
-        }
-        return typeParameterNodes;
-      }
-      function getTopmostIndexedAccessType(top) {
-        if (isIndexedAccessTypeNode(top.objectType)) {
-          return getTopmostIndexedAccessType(top.objectType);
-        }
-        return top;
-      }
-      function getSpecifierForModuleSymbol(symbol, context, overrideImportMode) {
-        let file = getDeclarationOfKind(symbol, 311 /* SourceFile */);
-        if (!file) {
-          const equivalentFileSymbol = firstDefined(symbol.declarations, (d) => getFileSymbolIfFileSymbolExportEqualsContainer(d, symbol));
-          if (equivalentFileSymbol) {
-            file = getDeclarationOfKind(equivalentFileSymbol, 311 /* SourceFile */);
-          }
-        }
-        if (file && file.moduleName !== void 0) {
-          return file.moduleName;
-        }
-        if (!file) {
-          if (context.tracker.trackReferencedAmbientModule) {
-            const ambientDecls = filter(symbol.declarations, isAmbientModule);
-            if (length(ambientDecls)) {
-              for (const decl of ambientDecls) {
-                context.tracker.trackReferencedAmbientModule(decl, symbol);
-              }
-            }
-          }
-          if (ambientModuleSymbolRegex.test(symbol.escapedName)) {
-            return symbol.escapedName.substring(1, symbol.escapedName.length - 1);
-          }
-        }
-        if (!context.enclosingDeclaration || !context.tracker.moduleResolverHost) {
-          if (ambientModuleSymbolRegex.test(symbol.escapedName)) {
-            return symbol.escapedName.substring(1, symbol.escapedName.length - 1);
-          }
-          return getSourceFileOfNode(getNonAugmentationDeclaration(symbol)).fileName;
-        }
-        const contextFile = getSourceFileOfNode(getOriginalNode(context.enclosingDeclaration));
-        const resolutionMode = overrideImportMode || (contextFile == null ? void 0 : contextFile.impliedNodeFormat);
-        const cacheKey = createModeAwareCacheKey(contextFile.path, resolutionMode);
-        const links = getSymbolLinks(symbol);
-        let specifier = links.specifierCache && links.specifierCache.get(cacheKey);
-        if (!specifier) {
-          const isBundle2 = !!outFile(compilerOptions);
-          const { moduleResolverHost } = context.tracker;
-          const specifierCompilerOptions = isBundle2 ? { ...compilerOptions, baseUrl: moduleResolverHost.getCommonSourceDirectory() } : compilerOptions;
-          specifier = first(getModuleSpecifiers(
-            symbol,
-            checker,
-            specifierCompilerOptions,
-            contextFile,
-            moduleResolverHost,
-            {
-              importModuleSpecifierPreference: isBundle2 ? "non-relative" : "project-relative",
-              importModuleSpecifierEnding: isBundle2 ? "minimal" : resolutionMode === 99 /* ESNext */ ? "js" : void 0
-            },
-            { overrideImportMode }
-          ));
-          links.specifierCache ?? (links.specifierCache = /* @__PURE__ */ new Map());
-          links.specifierCache.set(cacheKey, specifier);
-        }
-        return specifier;
-      }
-      function symbolToEntityNameNode(symbol) {
-        const identifier = factory.createIdentifier(unescapeLeadingUnderscores(symbol.escapedName));
-        return symbol.parent ? factory.createQualifiedName(symbolToEntityNameNode(symbol.parent), identifier) : identifier;
-      }
-      function symbolToTypeNode(symbol, context, meaning, overrideTypeArguments) {
-        var _a, _b, _c, _d;
-        const chain = lookupSymbolChain(symbol, context, meaning, !(context.flags & 16384 /* UseAliasDefinedOutsideCurrentScope */));
-        const isTypeOf = meaning === 111551 /* Value */;
-        if (some(chain[0].declarations, hasNonGlobalAugmentationExternalModuleSymbol)) {
-          const nonRootParts = chain.length > 1 ? createAccessFromSymbolChain(chain, chain.length - 1, 1) : void 0;
-          const typeParameterNodes = overrideTypeArguments || lookupTypeParameterNodes(chain, 0, context);
-          const contextFile = getSourceFileOfNode(getOriginalNode(context.enclosingDeclaration));
-          const targetFile = getSourceFileOfModule(chain[0]);
-          let specifier;
-          let assertion;
-          if (getEmitModuleResolutionKind(compilerOptions) === 3 /* Node16 */ || getEmitModuleResolutionKind(compilerOptions) === 99 /* NodeNext */) {
-            if ((targetFile == null ? void 0 : targetFile.impliedNodeFormat) === 99 /* ESNext */ && targetFile.impliedNodeFormat !== (contextFile == null ? void 0 : contextFile.impliedNodeFormat)) {
-              specifier = getSpecifierForModuleSymbol(chain[0], context, 99 /* ESNext */);
-              assertion = factory.createImportTypeAssertionContainer(factory.createAssertClause(factory.createNodeArray([
-                factory.createAssertEntry(
-                  factory.createStringLiteral("resolution-mode"),
-                  factory.createStringLiteral("import")
-                )
-              ])));
-              (_b = (_a = context.tracker).reportImportTypeNodeResolutionModeOverride) == null ? void 0 : _b.call(_a);
-            }
-          }
-          if (!specifier) {
-            specifier = getSpecifierForModuleSymbol(chain[0], context);
-          }
-          if (!(context.flags & 67108864 /* AllowNodeModulesRelativePaths */) && getEmitModuleResolutionKind(compilerOptions) !== 1 /* Classic */ && specifier.indexOf("/node_modules/") >= 0) {
-            const oldSpecifier = specifier;
-            if (getEmitModuleResolutionKind(compilerOptions) === 3 /* Node16 */ || getEmitModuleResolutionKind(compilerOptions) === 99 /* NodeNext */) {
-              const swappedMode = (contextFile == null ? void 0 : contextFile.impliedNodeFormat) === 99 /* ESNext */ ? 1 /* CommonJS */ : 99 /* ESNext */;
-              specifier = getSpecifierForModuleSymbol(chain[0], context, swappedMode);
-              if (specifier.indexOf("/node_modules/") >= 0) {
-                specifier = oldSpecifier;
-              } else {
-                assertion = factory.createImportTypeAssertionContainer(factory.createAssertClause(factory.createNodeArray([
-                  factory.createAssertEntry(
-                    factory.createStringLiteral("resolution-mode"),
-                    factory.createStringLiteral(swappedMode === 99 /* ESNext */ ? "import" : "require")
-                  )
-                ])));
-                (_d = (_c = context.tracker).reportImportTypeNodeResolutionModeOverride) == null ? void 0 : _d.call(_c);
-              }
-            }
-            if (!assertion) {
-              context.encounteredError = true;
-              if (context.tracker.reportLikelyUnsafeImportRequiredError) {
-                context.tracker.reportLikelyUnsafeImportRequiredError(oldSpecifier);
-              }
-            }
-          }
-          const lit = factory.createLiteralTypeNode(factory.createStringLiteral(specifier));
-          if (context.tracker.trackExternalModuleSymbolOfImportTypeNode)
-            context.tracker.trackExternalModuleSymbolOfImportTypeNode(chain[0]);
-          context.approximateLength += specifier.length + 10;
-          if (!nonRootParts || isEntityName(nonRootParts)) {
-            if (nonRootParts) {
-              const lastId = isIdentifier(nonRootParts) ? nonRootParts : nonRootParts.right;
-              setIdentifierTypeArguments(
-                lastId,
-                /*typeArguments*/
-                void 0
-              );
-            }
-            return factory.createImportTypeNode(lit, assertion, nonRootParts, typeParameterNodes, isTypeOf);
-          } else {
-            const splitNode = getTopmostIndexedAccessType(nonRootParts);
-            const qualifier = splitNode.objectType.typeName;
-            return factory.createIndexedAccessTypeNode(factory.createImportTypeNode(lit, assertion, qualifier, typeParameterNodes, isTypeOf), splitNode.indexType);
-          }
-        }
-        const entityName = createAccessFromSymbolChain(chain, chain.length - 1, 0);
-        if (isIndexedAccessTypeNode(entityName)) {
-          return entityName;
-        }
-        if (isTypeOf) {
-          return factory.createTypeQueryNode(entityName);
-        } else {
-          const lastId = isIdentifier(entityName) ? entityName : entityName.right;
-          const lastTypeArgs = getIdentifierTypeArguments(lastId);
-          setIdentifierTypeArguments(
-            lastId,
-            /*typeArguments*/
-            void 0
-          );
-          return factory.createTypeReferenceNode(entityName, lastTypeArgs);
-        }
-        function createAccessFromSymbolChain(chain2, index, stopper) {
-          const typeParameterNodes = index === chain2.length - 1 ? overrideTypeArguments : lookupTypeParameterNodes(chain2, index, context);
-          const symbol2 = chain2[index];
-          const parent2 = chain2[index - 1];
-          let symbolName2;
-          if (index === 0) {
-            context.flags |= 16777216 /* InInitialEntityName */;
-            symbolName2 = getNameOfSymbolAsWritten(symbol2, context);
-            context.approximateLength += (symbolName2 ? symbolName2.length : 0) + 1;
-            context.flags ^= 16777216 /* InInitialEntityName */;
-          } else {
-            if (parent2 && getExportsOfSymbol(parent2)) {
-              const exports = getExportsOfSymbol(parent2);
-              forEachEntry(exports, (ex, name) => {
-                if (getSymbolIfSameReference(ex, symbol2) && !isLateBoundName(name) && name !== "export=" /* ExportEquals */) {
-                  symbolName2 = unescapeLeadingUnderscores(name);
-                  return true;
-                }
-              });
-            }
-          }
-          if (symbolName2 === void 0) {
-            const name = firstDefined(symbol2.declarations, getNameOfDeclaration);
-            if (name && isComputedPropertyName(name) && isEntityName(name.expression)) {
-              const LHS = createAccessFromSymbolChain(chain2, index - 1, stopper);
-              if (isEntityName(LHS)) {
-                return factory.createIndexedAccessTypeNode(factory.createParenthesizedType(factory.createTypeQueryNode(LHS)), factory.createTypeQueryNode(name.expression));
-              }
-              return LHS;
-            }
-            symbolName2 = getNameOfSymbolAsWritten(symbol2, context);
-          }
-          context.approximateLength += symbolName2.length + 1;
-          if (!(context.flags & 16 /* ForbidIndexedAccessSymbolReferences */) && parent2 && getMembersOfSymbol(parent2) && getMembersOfSymbol(parent2).get(symbol2.escapedName) && getSymbolIfSameReference(getMembersOfSymbol(parent2).get(symbol2.escapedName), symbol2)) {
-            const LHS = createAccessFromSymbolChain(chain2, index - 1, stopper);
-            if (isIndexedAccessTypeNode(LHS)) {
-              return factory.createIndexedAccessTypeNode(LHS, factory.createLiteralTypeNode(factory.createStringLiteral(symbolName2)));
-            } else {
-              return factory.createIndexedAccessTypeNode(factory.createTypeReferenceNode(LHS, typeParameterNodes), factory.createLiteralTypeNode(factory.createStringLiteral(symbolName2)));
-            }
-          }
-          const identifier = setEmitFlags(factory.createIdentifier(symbolName2), 16777216 /* NoAsciiEscaping */);
-          if (typeParameterNodes)
-            setIdentifierTypeArguments(identifier, factory.createNodeArray(typeParameterNodes));
-          identifier.symbol = symbol2;
-          if (index > stopper) {
-            const LHS = createAccessFromSymbolChain(chain2, index - 1, stopper);
-            if (!isEntityName(LHS)) {
-              return Debug.fail("Impossible construct - an export of an indexed access cannot be reachable");
-            }
-            return factory.createQualifiedName(LHS, identifier);
-          }
-          return identifier;
-        }
-      }
-      function typeParameterShadowsNameInScope(escapedName, context, type) {
-        const result = resolveName(
-          context.enclosingDeclaration,
-          escapedName,
-          788968 /* Type */,
-          /*nameNotFoundMessage*/
-          void 0,
-          escapedName,
-          /*isUse*/
-          false
-        );
-        if (result) {
-          if (result.flags & 262144 /* TypeParameter */ && result === type.symbol) {
-            return false;
-          }
-          return true;
-        }
-        return false;
-      }
-      function typeParameterToName(type, context) {
-        var _a, _b;
-        if (context.flags & 4 /* GenerateNamesForShadowedTypeParams */ && context.typeParameterNames) {
-          const cached = context.typeParameterNames.get(getTypeId(type));
-          if (cached) {
-            return cached;
-          }
-        }
-        let result = symbolToName(
-          type.symbol,
-          context,
-          788968 /* Type */,
-          /*expectsIdentifier*/
-          true
-        );
-        if (!(result.kind & 80 /* Identifier */)) {
-          return factory.createIdentifier("(Missing type parameter)");
-        }
-        if (context.flags & 4 /* GenerateNamesForShadowedTypeParams */) {
-          const rawtext = result.escapedText;
-          let i = ((_a = context.typeParameterNamesByTextNextNameCount) == null ? void 0 : _a.get(rawtext)) || 0;
-          let text = rawtext;
-          while (((_b = context.typeParameterNamesByText) == null ? void 0 : _b.has(text)) || typeParameterShadowsNameInScope(text, context, type)) {
-            i++;
-            text = `${rawtext}_${i}`;
-          }
-          if (text !== rawtext) {
-            const typeArguments = getIdentifierTypeArguments(result);
-            result = factory.createIdentifier(text);
-            setIdentifierTypeArguments(result, typeArguments);
-          }
-          (context.typeParameterNamesByTextNextNameCount || (context.typeParameterNamesByTextNextNameCount = /* @__PURE__ */ new Map())).set(rawtext, i);
-          (context.typeParameterNames || (context.typeParameterNames = /* @__PURE__ */ new Map())).set(getTypeId(type), result);
-          (context.typeParameterNamesByText || (context.typeParameterNamesByText = /* @__PURE__ */ new Set())).add(rawtext);
-        }
-        return result;
-      }
-      function symbolToName(symbol, context, meaning, expectsIdentifier) {
-        const chain = lookupSymbolChain(symbol, context, meaning);
-        if (expectsIdentifier && chain.length !== 1 && !context.encounteredError && !(context.flags & 65536 /* AllowQualifiedNameInPlaceOfIdentifier */)) {
-          context.encounteredError = true;
-        }
-        return createEntityNameFromSymbolChain(chain, chain.length - 1);
-        function createEntityNameFromSymbolChain(chain2, index) {
-          const typeParameterNodes = lookupTypeParameterNodes(chain2, index, context);
-          const symbol2 = chain2[index];
-          if (index === 0) {
-            context.flags |= 16777216 /* InInitialEntityName */;
-          }
-          const symbolName2 = getNameOfSymbolAsWritten(symbol2, context);
-          if (index === 0) {
-            context.flags ^= 16777216 /* InInitialEntityName */;
-          }
-          const identifier = setEmitFlags(factory.createIdentifier(symbolName2), 16777216 /* NoAsciiEscaping */);
-          if (typeParameterNodes)
-            setIdentifierTypeArguments(identifier, factory.createNodeArray(typeParameterNodes));
-          identifier.symbol = symbol2;
-          return index > 0 ? factory.createQualifiedName(createEntityNameFromSymbolChain(chain2, index - 1), identifier) : identifier;
-        }
-      }
-      function symbolToExpression(symbol, context, meaning) {
-        const chain = lookupSymbolChain(symbol, context, meaning);
-        return createExpressionFromSymbolChain(chain, chain.length - 1);
-        function createExpressionFromSymbolChain(chain2, index) {
-          const typeParameterNodes = lookupTypeParameterNodes(chain2, index, context);
-          const symbol2 = chain2[index];
-          if (index === 0) {
-            context.flags |= 16777216 /* InInitialEntityName */;
-          }
-          let symbolName2 = getNameOfSymbolAsWritten(symbol2, context);
-          if (index === 0) {
-            context.flags ^= 16777216 /* InInitialEntityName */;
-          }
-          let firstChar = symbolName2.charCodeAt(0);
-          if (isSingleOrDoubleQuote(firstChar) && some(symbol2.declarations, hasNonGlobalAugmentationExternalModuleSymbol)) {
-            return factory.createStringLiteral(getSpecifierForModuleSymbol(symbol2, context));
-          }
-          if (index === 0 || canUsePropertyAccess(symbolName2, languageVersion)) {
-            const identifier = setEmitFlags(factory.createIdentifier(symbolName2), 16777216 /* NoAsciiEscaping */);
-            if (typeParameterNodes)
-              setIdentifierTypeArguments(identifier, factory.createNodeArray(typeParameterNodes));
-            identifier.symbol = symbol2;
-            return index > 0 ? factory.createPropertyAccessExpression(createExpressionFromSymbolChain(chain2, index - 1), identifier) : identifier;
-          } else {
-            if (firstChar === 91 /* openBracket */) {
-              symbolName2 = symbolName2.substring(1, symbolName2.length - 1);
-              firstChar = symbolName2.charCodeAt(0);
-            }
-            let expression;
-            if (isSingleOrDoubleQuote(firstChar) && !(symbol2.flags & 8 /* EnumMember */)) {
-              expression = factory.createStringLiteral(stripQuotes(symbolName2).replace(/\\./g, (s) => s.substring(1)), firstChar === 39 /* singleQuote */);
-            } else if ("" + +symbolName2 === symbolName2) {
-              expression = factory.createNumericLiteral(+symbolName2);
-            }
-            if (!expression) {
-              const identifier = setEmitFlags(factory.createIdentifier(symbolName2), 16777216 /* NoAsciiEscaping */);
-              if (typeParameterNodes)
-                setIdentifierTypeArguments(identifier, factory.createNodeArray(typeParameterNodes));
-              identifier.symbol = symbol2;
-              expression = identifier;
-            }
-            return factory.createElementAccessExpression(createExpressionFromSymbolChain(chain2, index - 1), expression);
-          }
-        }
-      }
-      function isStringNamed(d) {
-        const name = getNameOfDeclaration(d);
-        return !!name && isStringLiteral(name);
-      }
-      function isSingleQuotedStringNamed(d) {
-        const name = getNameOfDeclaration(d);
-        return !!(name && isStringLiteral(name) && (name.singleQuote || !nodeIsSynthesized(name) && startsWith(getTextOfNode(
-          name,
-          /*includeTrivia*/
-          false
-        ), "'")));
-      }
-      function getPropertyNameNodeForSymbol(symbol, context) {
-        const stringNamed = !!length(symbol.declarations) && every(symbol.declarations, isStringNamed);
-        const singleQuote = !!length(symbol.declarations) && every(symbol.declarations, isSingleQuotedStringNamed);
-        const fromNameType = getPropertyNameNodeForSymbolFromNameType(symbol, context, singleQuote, stringNamed);
-        if (fromNameType) {
-          return fromNameType;
-        }
-        const rawName = unescapeLeadingUnderscores(symbol.escapedName);
-        return createPropertyNameNodeForIdentifierOrLiteral(rawName, getEmitScriptTarget(compilerOptions), singleQuote, stringNamed);
-      }
-      function getPropertyNameNodeForSymbolFromNameType(symbol, context, singleQuote, stringNamed) {
-        const nameType = getSymbolLinks(symbol).nameType;
-        if (nameType) {
-          if (nameType.flags & 384 /* StringOrNumberLiteral */) {
-            const name = "" + nameType.value;
-            if (!isIdentifierText(name, getEmitScriptTarget(compilerOptions)) && (stringNamed || !isNumericLiteralName(name))) {
-              return factory.createStringLiteral(name, !!singleQuote);
-            }
-            if (isNumericLiteralName(name) && startsWith(name, "-")) {
-              return factory.createComputedPropertyName(factory.createNumericLiteral(+name));
-            }
-            return createPropertyNameNodeForIdentifierOrLiteral(name, getEmitScriptTarget(compilerOptions));
-          }
-          if (nameType.flags & 8192 /* UniqueESSymbol */) {
-            return factory.createComputedPropertyName(symbolToExpression(nameType.symbol, context, 111551 /* Value */));
-          }
-        }
-      }
-      function cloneNodeBuilderContext(context) {
-        const initial = { ...context };
-        if (initial.typeParameterNames) {
-          initial.typeParameterNames = new Map(initial.typeParameterNames);
-        }
-        if (initial.typeParameterNamesByText) {
-          initial.typeParameterNamesByText = new Set(initial.typeParameterNamesByText);
-        }
-        if (initial.typeParameterSymbolList) {
-          initial.typeParameterSymbolList = new Set(initial.typeParameterSymbolList);
-        }
-        initial.tracker = new SymbolTrackerImpl(initial, initial.tracker.inner, initial.tracker.moduleResolverHost);
-        return initial;
-      }
-      function getDeclarationWithTypeAnnotation(symbol, enclosingDeclaration) {
-        return symbol.declarations && find(symbol.declarations, (s) => !!getEffectiveTypeAnnotationNode(s) && (!enclosingDeclaration || !!findAncestor(s, (n) => n === enclosingDeclaration)));
-      }
-      function existingTypeNodeIsNotReferenceOrIsReferenceWithCompatibleTypeArgumentCount(existing, type) {
-        return !(getObjectFlags(type) & 4 /* Reference */) || !isTypeReferenceNode(existing) || length(existing.typeArguments) >= getMinTypeArgumentCount(type.target.typeParameters);
-      }
-      function getEnclosingDeclarationIgnoringFakeScope(enclosingDeclaration) {
-        return getNodeLinks(enclosingDeclaration).fakeScopeForSignatureDeclaration ? enclosingDeclaration.parent : enclosingDeclaration;
-      }
-      function serializeTypeForDeclaration(context, type, symbol, enclosingDeclaration, includePrivateSymbol, bundled) {
-        if (!isErrorType(type) && enclosingDeclaration) {
-          const declWithExistingAnnotation = getDeclarationWithTypeAnnotation(symbol, getEnclosingDeclarationIgnoringFakeScope(enclosingDeclaration));
-          if (declWithExistingAnnotation && !isFunctionLikeDeclaration(declWithExistingAnnotation) && !isGetAccessorDeclaration(declWithExistingAnnotation)) {
-            const existing = getEffectiveTypeAnnotationNode(declWithExistingAnnotation);
-            if (typeNodeIsEquivalentToType(existing, declWithExistingAnnotation, type) && existingTypeNodeIsNotReferenceOrIsReferenceWithCompatibleTypeArgumentCount(existing, type)) {
-              const result2 = serializeExistingTypeNode(context, existing, includePrivateSymbol, bundled);
-              if (result2) {
-                return result2;
-              }
-            }
-          }
-        }
-        const oldFlags = context.flags;
-        if (type.flags & 8192 /* UniqueESSymbol */ && type.symbol === symbol && (!context.enclosingDeclaration || some(symbol.declarations, (d) => getSourceFileOfNode(d) === getSourceFileOfNode(context.enclosingDeclaration)))) {
-          context.flags |= 1048576 /* AllowUniqueESSymbolType */;
-        }
-        const result = typeToTypeNodeHelper(type, context);
-        context.flags = oldFlags;
-        return result;
-      }
-      function typeNodeIsEquivalentToType(typeNode, annotatedDeclaration, type) {
-        const typeFromTypeNode = getTypeFromTypeNode(typeNode);
-        if (typeFromTypeNode === type) {
-          return true;
-        }
-        if (isParameter(annotatedDeclaration) && annotatedDeclaration.questionToken) {
-          return getTypeWithFacts(type, 524288 /* NEUndefined */) === typeFromTypeNode;
-        }
-        return false;
-      }
-      function serializeReturnTypeForSignature(context, type, signature, includePrivateSymbol, bundled) {
-        if (!isErrorType(type) && context.enclosingDeclaration) {
-          const annotation = signature.declaration && getEffectiveReturnTypeNode(signature.declaration);
-          const enclosingDeclarationIgnoringFakeScope = getEnclosingDeclarationIgnoringFakeScope(context.enclosingDeclaration);
-          if (!!findAncestor(annotation, (n) => n === enclosingDeclarationIgnoringFakeScope) && annotation) {
-            const annotated = getTypeFromTypeNode(annotation);
-            const thisInstantiated = annotated.flags & 262144 /* TypeParameter */ && annotated.isThisType ? instantiateType(annotated, signature.mapper) : annotated;
-            if (thisInstantiated === type && existingTypeNodeIsNotReferenceOrIsReferenceWithCompatibleTypeArgumentCount(annotation, type)) {
-              const result = serializeExistingTypeNode(context, annotation, includePrivateSymbol, bundled);
-              if (result) {
-                return result;
-              }
-            }
-          }
-        }
-        return typeToTypeNodeHelper(type, context);
-      }
-      function trackExistingEntityName(node, context, includePrivateSymbol) {
-        let introducesError = false;
-        const leftmost = getFirstIdentifier(node);
-        if (isInJSFile(node) && (isExportsIdentifier(leftmost) || isModuleExportsAccessExpression(leftmost.parent) || isQualifiedName(leftmost.parent) && isModuleIdentifier(leftmost.parent.left) && isExportsIdentifier(leftmost.parent.right))) {
-          introducesError = true;
-          return { introducesError, node };
-        }
-        const sym = resolveEntityName(
-          leftmost,
-          67108863 /* All */,
-          /*ignoreErrors*/
-          true,
-          /*dontResolveAlias*/
-          true
-        );
-        if (sym) {
-          if (isSymbolAccessible(
-            sym,
-            context.enclosingDeclaration,
-            67108863 /* All */,
-            /*shouldComputeAliasesToMakeVisible*/
-            false
-          ).accessibility !== 0 /* Accessible */) {
-            introducesError = true;
-          } else {
-            context.tracker.trackSymbol(sym, context.enclosingDeclaration, 67108863 /* All */);
-            includePrivateSymbol == null ? void 0 : includePrivateSymbol(sym);
-          }
-          if (isIdentifier(node)) {
-            const type = getDeclaredTypeOfSymbol(sym);
-            const name = sym.flags & 262144 /* TypeParameter */ && !isTypeSymbolAccessible(type.symbol, context.enclosingDeclaration) ? typeParameterToName(type, context) : factory.cloneNode(node);
-            name.symbol = sym;
-            return { introducesError, node: setEmitFlags(setOriginalNode(name, node), 16777216 /* NoAsciiEscaping */) };
-          }
-        }
-        return { introducesError, node };
-      }
-      function serializeExistingTypeNode(context, existing, includePrivateSymbol, bundled) {
-        if (cancellationToken && cancellationToken.throwIfCancellationRequested) {
-          cancellationToken.throwIfCancellationRequested();
-        }
-        let hadError = false;
-        const file = getSourceFileOfNode(existing);
-        const transformed = visitNode(existing, visitExistingNodeTreeSymbols, isTypeNode);
-        if (hadError) {
-          return void 0;
-        }
-        return transformed === existing ? setTextRange(factory.cloneNode(existing), existing) : transformed;
-        function visitExistingNodeTreeSymbols(node) {
-          if (isJSDocAllType(node) || node.kind === 325 /* JSDocNamepathType */) {
-            return factory.createKeywordTypeNode(133 /* AnyKeyword */);
-          }
-          if (isJSDocUnknownType(node)) {
-            return factory.createKeywordTypeNode(159 /* UnknownKeyword */);
-          }
-          if (isJSDocNullableType(node)) {
-            return factory.createUnionTypeNode([visitNode(node.type, visitExistingNodeTreeSymbols, isTypeNode), factory.createLiteralTypeNode(factory.createNull())]);
-          }
-          if (isJSDocOptionalType(node)) {
-            return factory.createUnionTypeNode([visitNode(node.type, visitExistingNodeTreeSymbols, isTypeNode), factory.createKeywordTypeNode(157 /* UndefinedKeyword */)]);
-          }
-          if (isJSDocNonNullableType(node)) {
-            return visitNode(node.type, visitExistingNodeTreeSymbols);
-          }
-          if (isJSDocVariadicType(node)) {
-            return factory.createArrayTypeNode(visitNode(node.type, visitExistingNodeTreeSymbols, isTypeNode));
-          }
-          if (isJSDocTypeLiteral(node)) {
-            return factory.createTypeLiteralNode(map(node.jsDocPropertyTags, (t) => {
-              const name = isIdentifier(t.name) ? t.name : t.name.right;
-              const typeViaParent = getTypeOfPropertyOfType(getTypeFromTypeNode(node), name.escapedText);
-              const overrideTypeNode = typeViaParent && t.typeExpression && getTypeFromTypeNode(t.typeExpression.type) !== typeViaParent ? typeToTypeNodeHelper(typeViaParent, context) : void 0;
-              return factory.createPropertySignature(
-                /*modifiers*/
-                void 0,
-                name,
-                t.isBracketed || t.typeExpression && isJSDocOptionalType(t.typeExpression.type) ? factory.createToken(58 /* QuestionToken */) : void 0,
-                overrideTypeNode || t.typeExpression && visitNode(t.typeExpression.type, visitExistingNodeTreeSymbols, isTypeNode) || factory.createKeywordTypeNode(133 /* AnyKeyword */)
-              );
-            }));
-          }
-          if (isTypeReferenceNode(node) && isIdentifier(node.typeName) && node.typeName.escapedText === "") {
-            return setOriginalNode(factory.createKeywordTypeNode(133 /* AnyKeyword */), node);
-          }
-          if ((isExpressionWithTypeArguments(node) || isTypeReferenceNode(node)) && isJSDocIndexSignature(node)) {
-            return factory.createTypeLiteralNode([factory.createIndexSignature(
-              /*modifiers*/
-              void 0,
-              [factory.createParameterDeclaration(
-                /*modifiers*/
-                void 0,
-                /*dotDotDotToken*/
-                void 0,
-                "x",
-                /*questionToken*/
-                void 0,
-                visitNode(node.typeArguments[0], visitExistingNodeTreeSymbols, isTypeNode)
-              )],
-              visitNode(node.typeArguments[1], visitExistingNodeTreeSymbols, isTypeNode)
-            )]);
-          }
-          if (isJSDocFunctionType(node)) {
-            if (isJSDocConstructSignature(node)) {
-              let newTypeNode;
-              return factory.createConstructorTypeNode(
-                /*modifiers*/
-                void 0,
-                visitNodes2(node.typeParameters, visitExistingNodeTreeSymbols, isTypeParameterDeclaration),
-                mapDefined(node.parameters, (p, i) => p.name && isIdentifier(p.name) && p.name.escapedText === "new" ? (newTypeNode = p.type, void 0) : factory.createParameterDeclaration(
-                  /*modifiers*/
-                  void 0,
-                  getEffectiveDotDotDotForParameter(p),
-                  getNameForJSDocFunctionParameter(p, i),
-                  p.questionToken,
-                  visitNode(p.type, visitExistingNodeTreeSymbols, isTypeNode),
-                  /*initializer*/
-                  void 0
-                )),
-                visitNode(newTypeNode || node.type, visitExistingNodeTreeSymbols, isTypeNode) || factory.createKeywordTypeNode(133 /* AnyKeyword */)
-              );
-            } else {
-              return factory.createFunctionTypeNode(
-                visitNodes2(node.typeParameters, visitExistingNodeTreeSymbols, isTypeParameterDeclaration),
-                map(node.parameters, (p, i) => factory.createParameterDeclaration(
-                  /*modifiers*/
-                  void 0,
-                  getEffectiveDotDotDotForParameter(p),
-                  getNameForJSDocFunctionParameter(p, i),
-                  p.questionToken,
-                  visitNode(p.type, visitExistingNodeTreeSymbols, isTypeNode),
-                  /*initializer*/
-                  void 0
-                )),
-                visitNode(node.type, visitExistingNodeTreeSymbols, isTypeNode) || factory.createKeywordTypeNode(133 /* AnyKeyword */)
-              );
-            }
-          }
-          if (isTypeReferenceNode(node) && isInJSDoc(node) && (!existingTypeNodeIsNotReferenceOrIsReferenceWithCompatibleTypeArgumentCount(node, getTypeFromTypeNode(node)) || getIntendedTypeFromJSDocTypeReference(node) || unknownSymbol === resolveTypeReferenceName(
-            node,
-            788968 /* Type */,
-            /*ignoreErrors*/
-            true
-          ))) {
-            return setOriginalNode(typeToTypeNodeHelper(getTypeFromTypeNode(node), context), node);
-          }
-          if (isLiteralImportTypeNode(node)) {
-            const nodeSymbol = getNodeLinks(node).resolvedSymbol;
-            if (isInJSDoc(node) && nodeSymbol && // The import type resolved using jsdoc fallback logic
-            (!node.isTypeOf && !(nodeSymbol.flags & 788968 /* Type */) || // The import type had type arguments autofilled by js fallback logic
-            !(length(node.typeArguments) >= getMinTypeArgumentCount(getLocalTypeParametersOfClassOrInterfaceOrTypeAlias(nodeSymbol))))) {
-              return setOriginalNode(typeToTypeNodeHelper(getTypeFromTypeNode(node), context), node);
-            }
-            return factory.updateImportTypeNode(
-              node,
-              factory.updateLiteralTypeNode(node.argument, rewriteModuleSpecifier(node, node.argument.literal)),
-              node.assertions,
-              node.qualifier,
-              visitNodes2(node.typeArguments, visitExistingNodeTreeSymbols, isTypeNode),
-              node.isTypeOf
-            );
-          }
-          if (isEntityName(node) || isEntityNameExpression(node)) {
-            const { introducesError, node: result } = trackExistingEntityName(node, context, includePrivateSymbol);
-            hadError = hadError || introducesError;
-            if (result !== node) {
-              return result;
-            }
-          }
-          if (file && isTupleTypeNode(node) && getLineAndCharacterOfPosition(file, node.pos).line === getLineAndCharacterOfPosition(file, node.end).line) {
-            setEmitFlags(node, 1 /* SingleLine */);
-          }
-          return visitEachChild(node, visitExistingNodeTreeSymbols, nullTransformationContext);
-          function getEffectiveDotDotDotForParameter(p) {
-            return p.dotDotDotToken || (p.type && isJSDocVariadicType(p.type) ? factory.createToken(26 /* DotDotDotToken */) : void 0);
-          }
-          function getNameForJSDocFunctionParameter(p, index) {
-            return p.name && isIdentifier(p.name) && p.name.escapedText === "this" ? "this" : getEffectiveDotDotDotForParameter(p) ? `args` : `arg${index}`;
-          }
-          function rewriteModuleSpecifier(parent2, lit) {
-            if (bundled) {
-              if (context.tracker && context.tracker.moduleResolverHost) {
-                const targetFile = getExternalModuleFileFromDeclaration(parent2);
-                if (targetFile) {
-                  const getCanonicalFileName = createGetCanonicalFileName(!!host.useCaseSensitiveFileNames);
-                  const resolverHost = {
-                    getCanonicalFileName,
-                    getCurrentDirectory: () => context.tracker.moduleResolverHost.getCurrentDirectory(),
-                    getCommonSourceDirectory: () => context.tracker.moduleResolverHost.getCommonSourceDirectory()
-                  };
-                  const newName = getResolvedExternalModuleName(resolverHost, targetFile);
-                  return factory.createStringLiteral(newName);
-                }
-              }
-            } else {
-              if (context.tracker && context.tracker.trackExternalModuleSymbolOfImportTypeNode) {
-                const moduleSym = resolveExternalModuleNameWorker(
-                  lit,
-                  lit,
-                  /*moduleNotFoundError*/
-                  void 0
-                );
-                if (moduleSym) {
-                  context.tracker.trackExternalModuleSymbolOfImportTypeNode(moduleSym);
-                }
-              }
-            }
-            return lit;
-          }
-        }
-      }
-      function symbolTableToDeclarationStatements(symbolTable, context, bundled) {
-        const serializePropertySymbolForClass = makeSerializePropertySymbol(
-          factory.createPropertyDeclaration,
-          173 /* MethodDeclaration */,
-          /*useAccessors*/
-          true
-        );
-        const serializePropertySymbolForInterfaceWorker = makeSerializePropertySymbol(
-          (mods, name, question, type) => factory.createPropertySignature(mods, name, question, type),
-          172 /* MethodSignature */,
-          /*useAccessors*/
-          false
-        );
-        const enclosingDeclaration = context.enclosingDeclaration;
-        let results = [];
-        const visitedSymbols = /* @__PURE__ */ new Set();
-        const deferredPrivatesStack = [];
-        const oldcontext = context;
-        context = {
-          ...oldcontext,
-          usedSymbolNames: new Set(oldcontext.usedSymbolNames),
-          remappedSymbolNames: /* @__PURE__ */ new Map(),
-          tracker: void 0
-        };
-        const tracker = {
-          ...oldcontext.tracker.inner,
-          trackSymbol: (sym, decl, meaning) => {
-            var _a;
-            const accessibleResult = isSymbolAccessible(
-              sym,
-              decl,
-              meaning,
-              /*shouldComputeAliasesToMakeVisible*/
-              false
-            );
-            if (accessibleResult.accessibility === 0 /* Accessible */) {
-              const chain = lookupSymbolChainWorker(sym, context, meaning);
-              if (!(sym.flags & 4 /* Property */)) {
-                includePrivateSymbol(chain[0]);
-              }
-            } else if ((_a = oldcontext.tracker.inner) == null ? void 0 : _a.trackSymbol) {
-              return oldcontext.tracker.inner.trackSymbol(sym, decl, meaning);
-            }
-            return false;
-          }
-        };
-        context.tracker = new SymbolTrackerImpl(context, tracker, oldcontext.tracker.moduleResolverHost);
-        forEachEntry(symbolTable, (symbol, name) => {
-          const baseName = unescapeLeadingUnderscores(name);
-          void getInternalSymbolName(symbol, baseName);
-        });
-        let addingDeclare = !bundled;
-        const exportEquals = symbolTable.get("export=" /* ExportEquals */);
-        if (exportEquals && symbolTable.size > 1 && exportEquals.flags & 2097152 /* Alias */) {
-          symbolTable = createSymbolTable();
-          symbolTable.set("export=" /* ExportEquals */, exportEquals);
-        }
-        visitSymbolTable(symbolTable);
-        return mergeRedundantStatements(results);
-        function isIdentifierAndNotUndefined(node) {
-          return !!node && node.kind === 80 /* Identifier */;
-        }
-        function getNamesOfDeclaration(statement) {
-          if (isVariableStatement(statement)) {
-            return filter(map(statement.declarationList.declarations, getNameOfDeclaration), isIdentifierAndNotUndefined);
-          }
-          return filter([getNameOfDeclaration(statement)], isIdentifierAndNotUndefined);
-        }
-        function flattenExportAssignedNamespace(statements) {
-          const exportAssignment = find(statements, isExportAssignment);
-          const nsIndex = findIndex(statements, isModuleDeclaration);
-          let ns = nsIndex !== -1 ? statements[nsIndex] : void 0;
-          if (ns && exportAssignment && exportAssignment.isExportEquals && isIdentifier(exportAssignment.expression) && isIdentifier(ns.name) && idText(ns.name) === idText(exportAssignment.expression) && ns.body && isModuleBlock(ns.body)) {
-            const excessExports = filter(statements, (s) => !!(getEffectiveModifierFlags(s) & 1 /* Export */));
-            const name = ns.name;
-            let body = ns.body;
-            if (length(excessExports)) {
-              ns = factory.updateModuleDeclaration(
-                ns,
-                ns.modifiers,
-                ns.name,
-                body = factory.updateModuleBlock(
-                  body,
-                  factory.createNodeArray([...ns.body.statements, factory.createExportDeclaration(
-                    /*modifiers*/
-                    void 0,
-                    /*isTypeOnly*/
-                    false,
-                    factory.createNamedExports(map(flatMap(excessExports, (e) => getNamesOfDeclaration(e)), (id) => factory.createExportSpecifier(
-                      /*isTypeOnly*/
-                      false,
-                      /*propertyName*/
-                      void 0,
-                      id
-                    ))),
-                    /*moduleSpecifier*/
-                    void 0
-                  )])
-                )
-              );
-              statements = [...statements.slice(0, nsIndex), ns, ...statements.slice(nsIndex + 1)];
-            }
-            if (!find(statements, (s) => s !== ns && nodeHasName(s, name))) {
-              results = [];
-              const mixinExportFlag = !some(body.statements, (s) => hasSyntacticModifier(s, 1 /* Export */) || isExportAssignment(s) || isExportDeclaration(s));
-              forEach(body.statements, (s) => {
-                addResult(s, mixinExportFlag ? 1 /* Export */ : 0 /* None */);
-              });
-              statements = [...filter(statements, (s) => s !== ns && s !== exportAssignment), ...results];
-            }
-          }
-          return statements;
-        }
-        function mergeExportDeclarations(statements) {
-          const exports = filter(statements, (d) => isExportDeclaration(d) && !d.moduleSpecifier && !!d.exportClause && isNamedExports(d.exportClause));
-          if (length(exports) > 1) {
-            const nonExports = filter(statements, (d) => !isExportDeclaration(d) || !!d.moduleSpecifier || !d.exportClause);
-            statements = [...nonExports, factory.createExportDeclaration(
-              /*modifiers*/
-              void 0,
-              /*isTypeOnly*/
-              false,
-              factory.createNamedExports(flatMap(exports, (e) => cast(e.exportClause, isNamedExports).elements)),
-              /*moduleSpecifier*/
-              void 0
-            )];
-          }
-          const reexports = filter(statements, (d) => isExportDeclaration(d) && !!d.moduleSpecifier && !!d.exportClause && isNamedExports(d.exportClause));
-          if (length(reexports) > 1) {
-            const groups = group(reexports, (decl) => isStringLiteral(decl.moduleSpecifier) ? ">" + decl.moduleSpecifier.text : ">");
-            if (groups.length !== reexports.length) {
-              for (const group2 of groups) {
-                if (group2.length > 1) {
-                  statements = [
-                    ...filter(statements, (s) => group2.indexOf(s) === -1),
-                    factory.createExportDeclaration(
-                      /*modifiers*/
-                      void 0,
-                      /*isTypeOnly*/
-                      false,
-                      factory.createNamedExports(flatMap(group2, (e) => cast(e.exportClause, isNamedExports).elements)),
-                      group2[0].moduleSpecifier
-                    )
-                  ];
-                }
-              }
-            }
-          }
-          return statements;
-        }
-        function inlineExportModifiers(statements) {
-          const index = findIndex(statements, (d) => isExportDeclaration(d) && !d.moduleSpecifier && !d.assertClause && !!d.exportClause && isNamedExports(d.exportClause));
-          if (index >= 0) {
-            const exportDecl = statements[index];
-            const replacements = mapDefined(exportDecl.exportClause.elements, (e) => {
-              if (!e.propertyName) {
-                const indices = indicesOf(statements);
-                const associatedIndices = filter(indices, (i) => nodeHasName(statements[i], e.name));
-                if (length(associatedIndices) && every(associatedIndices, (i) => canHaveExportModifier(statements[i]))) {
-                  for (const index2 of associatedIndices) {
-                    statements[index2] = addExportModifier(statements[index2]);
-                  }
-                  return void 0;
-                }
-              }
-              return e;
-            });
-            if (!length(replacements)) {
-              orderedRemoveItemAt(statements, index);
-            } else {
-              statements[index] = factory.updateExportDeclaration(
-                exportDecl,
-                exportDecl.modifiers,
-                exportDecl.isTypeOnly,
-                factory.updateNamedExports(
-                  exportDecl.exportClause,
-                  replacements
-                ),
-                exportDecl.moduleSpecifier,
-                exportDecl.assertClause
-              );
-            }
-          }
-          return statements;
-        }
-        function mergeRedundantStatements(statements) {
-          statements = flattenExportAssignedNamespace(statements);
-          statements = mergeExportDeclarations(statements);
-          statements = inlineExportModifiers(statements);
-          if (enclosingDeclaration && (isSourceFile(enclosingDeclaration) && isExternalOrCommonJsModule(enclosingDeclaration) || isModuleDeclaration(enclosingDeclaration)) && (!some(statements, isExternalModuleIndicator) || !hasScopeMarker(statements) && some(statements, needsScopeMarker))) {
-            statements.push(createEmptyExports(factory));
-          }
-          return statements;
-        }
-        function addExportModifier(node) {
-          const flags = (getEffectiveModifierFlags(node) | 1 /* Export */) & ~2 /* Ambient */;
-          return factory.updateModifiers(node, flags);
-        }
-        function removeExportModifier(node) {
-          const flags = getEffectiveModifierFlags(node) & ~1 /* Export */;
-          return factory.updateModifiers(node, flags);
-        }
-        function visitSymbolTable(symbolTable2, suppressNewPrivateContext, propertyAsAlias) {
-          if (!suppressNewPrivateContext) {
-            deferredPrivatesStack.push(/* @__PURE__ */ new Map());
-          }
-          symbolTable2.forEach((symbol) => {
-            serializeSymbol(
-              symbol,
-              /*isPrivate*/
-              false,
-              !!propertyAsAlias
-            );
-          });
-          if (!suppressNewPrivateContext) {
-            deferredPrivatesStack[deferredPrivatesStack.length - 1].forEach((symbol) => {
-              serializeSymbol(
-                symbol,
-                /*isPrivate*/
-                true,
-                !!propertyAsAlias
-              );
-            });
-            deferredPrivatesStack.pop();
-          }
-        }
-        function serializeSymbol(symbol, isPrivate, propertyAsAlias) {
-          const visitedSym = getMergedSymbol(symbol);
-          if (visitedSymbols.has(getSymbolId(visitedSym))) {
-            return;
-          }
-          visitedSymbols.add(getSymbolId(visitedSym));
-          const skipMembershipCheck = !isPrivate;
-          if (skipMembershipCheck || !!length(symbol.declarations) && some(symbol.declarations, (d) => !!findAncestor(d, (n) => n === enclosingDeclaration))) {
-            const oldContext = context;
-            context = cloneNodeBuilderContext(context);
-            serializeSymbolWorker(symbol, isPrivate, propertyAsAlias);
-            if (context.reportedDiagnostic) {
-              oldcontext.reportedDiagnostic = context.reportedDiagnostic;
-            }
-            context = oldContext;
-          }
-        }
-        function serializeSymbolWorker(symbol, isPrivate, propertyAsAlias) {
-          var _a, _b, _c, _d;
-          const symbolName2 = unescapeLeadingUnderscores(symbol.escapedName);
-          const isDefault = symbol.escapedName === "default" /* Default */;
-          if (isPrivate && !(context.flags & 131072 /* AllowAnonymousIdentifier */) && isStringANonContextualKeyword(symbolName2) && !isDefault) {
-            context.encounteredError = true;
-            return;
-          }
-          let needsPostExportDefault = isDefault && !!(symbol.flags & -113 /* ExportDoesNotSupportDefaultModifier */ || symbol.flags & 16 /* Function */ && length(getPropertiesOfType(getTypeOfSymbol(symbol)))) && !(symbol.flags & 2097152 /* Alias */);
-          let needsExportDeclaration = !needsPostExportDefault && !isPrivate && isStringANonContextualKeyword(symbolName2) && !isDefault;
-          if (needsPostExportDefault || needsExportDeclaration) {
-            isPrivate = true;
-          }
-          const modifierFlags = (!isPrivate ? 1 /* Export */ : 0) | (isDefault && !needsPostExportDefault ? 1024 /* Default */ : 0);
-          const isConstMergedWithNS = symbol.flags & 1536 /* Module */ && symbol.flags & (2 /* BlockScopedVariable */ | 1 /* FunctionScopedVariable */ | 4 /* Property */) && symbol.escapedName !== "export=" /* ExportEquals */;
-          const isConstMergedWithNSPrintableAsSignatureMerge = isConstMergedWithNS && isTypeRepresentableAsFunctionNamespaceMerge(getTypeOfSymbol(symbol), symbol);
-          if (symbol.flags & (16 /* Function */ | 8192 /* Method */) || isConstMergedWithNSPrintableAsSignatureMerge) {
-            serializeAsFunctionNamespaceMerge(getTypeOfSymbol(symbol), symbol, getInternalSymbolName(symbol, symbolName2), modifierFlags);
-          }
-          if (symbol.flags & 524288 /* TypeAlias */) {
-            serializeTypeAlias(symbol, symbolName2, modifierFlags);
-          }
-          if (symbol.flags & (2 /* BlockScopedVariable */ | 1 /* FunctionScopedVariable */ | 4 /* Property */ | 98304 /* Accessor */) && symbol.escapedName !== "export=" /* ExportEquals */ && !(symbol.flags & 4194304 /* Prototype */) && !(symbol.flags & 32 /* Class */) && !(symbol.flags & 8192 /* Method */) && !isConstMergedWithNSPrintableAsSignatureMerge) {
-            if (propertyAsAlias) {
-              const createdExport = serializeMaybeAliasAssignment(symbol);
-              if (createdExport) {
-                needsExportDeclaration = false;
-                needsPostExportDefault = false;
-              }
-            } else {
-              const type = getTypeOfSymbol(symbol);
-              const localName = getInternalSymbolName(symbol, symbolName2);
-              if (!(symbol.flags & 16 /* Function */) && isTypeRepresentableAsFunctionNamespaceMerge(type, symbol)) {
-                serializeAsFunctionNamespaceMerge(type, symbol, localName, modifierFlags);
-              } else {
-                const flags = !(symbol.flags & 2 /* BlockScopedVariable */) ? ((_a = symbol.parent) == null ? void 0 : _a.valueDeclaration) && isSourceFile((_b = symbol.parent) == null ? void 0 : _b.valueDeclaration) ? 2 /* Const */ : void 0 : isConstVariable(symbol) ? 2 /* Const */ : 1 /* Let */;
-                const name = needsPostExportDefault || !(symbol.flags & 4 /* Property */) ? localName : getUnusedName(localName, symbol);
-                let textRange = symbol.declarations && find(symbol.declarations, (d) => isVariableDeclaration(d));
-                if (textRange && isVariableDeclarationList(textRange.parent) && textRange.parent.declarations.length === 1) {
-                  textRange = textRange.parent.parent;
-                }
-                const propertyAccessRequire = (_c = symbol.declarations) == null ? void 0 : _c.find(isPropertyAccessExpression);
-                if (propertyAccessRequire && isBinaryExpression(propertyAccessRequire.parent) && isIdentifier(propertyAccessRequire.parent.right) && ((_d = type.symbol) == null ? void 0 : _d.valueDeclaration) && isSourceFile(type.symbol.valueDeclaration)) {
-                  const alias = localName === propertyAccessRequire.parent.right.escapedText ? void 0 : propertyAccessRequire.parent.right;
-                  addResult(
-                    factory.createExportDeclaration(
-                      /*modifiers*/
-                      void 0,
-                      /*isTypeOnly*/
-                      false,
-                      factory.createNamedExports([factory.createExportSpecifier(
-                        /*isTypeOnly*/
-                        false,
-                        alias,
-                        localName
-                      )])
-                    ),
-                    0 /* None */
-                  );
-                  context.tracker.trackSymbol(type.symbol, context.enclosingDeclaration, 111551 /* Value */);
-                } else {
-                  const statement = setTextRange(factory.createVariableStatement(
-                    /*modifiers*/
-                    void 0,
-                    factory.createVariableDeclarationList([
-                      factory.createVariableDeclaration(
-                        name,
-                        /*exclamationToken*/
-                        void 0,
-                        serializeTypeForDeclaration(context, type, symbol, enclosingDeclaration, includePrivateSymbol, bundled)
-                      )
-                    ], flags)
-                  ), textRange);
-                  addResult(statement, name !== localName ? modifierFlags & ~1 /* Export */ : modifierFlags);
-                  if (name !== localName && !isPrivate) {
-                    addResult(
-                      factory.createExportDeclaration(
-                        /*modifiers*/
-                        void 0,
-                        /*isTypeOnly*/
-                        false,
-                        factory.createNamedExports([factory.createExportSpecifier(
-                          /*isTypeOnly*/
-                          false,
-                          name,
-                          localName
-                        )])
-                      ),
-                      0 /* None */
-                    );
-                    needsExportDeclaration = false;
-                    needsPostExportDefault = false;
-                  }
-                }
-              }
-            }
-          }
-          if (symbol.flags & 384 /* Enum */) {
-            serializeEnum(symbol, symbolName2, modifierFlags);
-          }
-          if (symbol.flags & 32 /* Class */) {
-            if (symbol.flags & 4 /* Property */ && symbol.valueDeclaration && isBinaryExpression(symbol.valueDeclaration.parent) && isClassExpression(symbol.valueDeclaration.parent.right)) {
-              serializeAsAlias(symbol, getInternalSymbolName(symbol, symbolName2), modifierFlags);
-            } else {
-              serializeAsClass(symbol, getInternalSymbolName(symbol, symbolName2), modifierFlags);
-            }
-          }
-          if (symbol.flags & (512 /* ValueModule */ | 1024 /* NamespaceModule */) && (!isConstMergedWithNS || isTypeOnlyNamespace(symbol)) || isConstMergedWithNSPrintableAsSignatureMerge) {
-            serializeModule(symbol, symbolName2, modifierFlags);
-          }
-          if (symbol.flags & 64 /* Interface */ && !(symbol.flags & 32 /* Class */)) {
-            serializeInterface(symbol, symbolName2, modifierFlags);
-          }
-          if (symbol.flags & 2097152 /* Alias */) {
-            serializeAsAlias(symbol, getInternalSymbolName(symbol, symbolName2), modifierFlags);
-          }
-          if (symbol.flags & 4 /* Property */ && symbol.escapedName === "export=" /* ExportEquals */) {
-            serializeMaybeAliasAssignment(symbol);
-          }
-          if (symbol.flags & 8388608 /* ExportStar */) {
-            if (symbol.declarations) {
-              for (const node of symbol.declarations) {
-                const resolvedModule = resolveExternalModuleName(node, node.moduleSpecifier);
-                if (!resolvedModule)
-                  continue;
-                addResult(factory.createExportDeclaration(
-                  /*modifiers*/
-                  void 0,
-                  /*isTypeOnly*/
-                  node.isTypeOnly,
-                  /*exportClause*/
-                  void 0,
-                  factory.createStringLiteral(getSpecifierForModuleSymbol(resolvedModule, context))
-                ), 0 /* None */);
-              }
-            }
-          }
-          if (needsPostExportDefault) {
-            addResult(factory.createExportAssignment(
-              /*modifiers*/
-              void 0,
-              /*isExportEquals*/
-              false,
-              factory.createIdentifier(getInternalSymbolName(symbol, symbolName2))
-            ), 0 /* None */);
-          } else if (needsExportDeclaration) {
-            addResult(factory.createExportDeclaration(
-              /*modifiers*/
-              void 0,
-              /*isTypeOnly*/
-              false,
-              factory.createNamedExports([factory.createExportSpecifier(
-                /*isTypeOnly*/
-                false,
-                getInternalSymbolName(symbol, symbolName2),
-                symbolName2
-              )])
-            ), 0 /* None */);
-          }
-        }
-        function includePrivateSymbol(symbol) {
-          if (some(symbol.declarations, isParameterDeclaration))
-            return;
-          Debug.assertIsDefined(deferredPrivatesStack[deferredPrivatesStack.length - 1]);
-          getUnusedName(unescapeLeadingUnderscores(symbol.escapedName), symbol);
-          const isExternalImportAlias = !!(symbol.flags & 2097152 /* Alias */) && !some(
-            symbol.declarations,
-            (d) => !!findAncestor(d, isExportDeclaration) || isNamespaceExport(d) || isImportEqualsDeclaration(d) && !isExternalModuleReference(d.moduleReference)
-          );
-          deferredPrivatesStack[isExternalImportAlias ? 0 : deferredPrivatesStack.length - 1].set(getSymbolId(symbol), symbol);
-        }
-        function isExportingScope(enclosingDeclaration2) {
-          return isSourceFile(enclosingDeclaration2) && (isExternalOrCommonJsModule(enclosingDeclaration2) || isJsonSourceFile(enclosingDeclaration2)) || isAmbientModule(enclosingDeclaration2) && !isGlobalScopeAugmentation(enclosingDeclaration2);
-        }
-        function addResult(node, additionalModifierFlags) {
-          if (canHaveModifiers(node)) {
-            let newModifierFlags = 0 /* None */;
-            const enclosingDeclaration2 = context.enclosingDeclaration && (isJSDocTypeAlias(context.enclosingDeclaration) ? getSourceFileOfNode(context.enclosingDeclaration) : context.enclosingDeclaration);
-            if (additionalModifierFlags & 1 /* Export */ && enclosingDeclaration2 && (isExportingScope(enclosingDeclaration2) || isModuleDeclaration(enclosingDeclaration2)) && canHaveExportModifier(node)) {
-              newModifierFlags |= 1 /* Export */;
-            }
-            if (addingDeclare && !(newModifierFlags & 1 /* Export */) && (!enclosingDeclaration2 || !(enclosingDeclaration2.flags & 16777216 /* Ambient */)) && (isEnumDeclaration(node) || isVariableStatement(node) || isFunctionDeclaration(node) || isClassDeclaration(node) || isModuleDeclaration(node))) {
-              newModifierFlags |= 2 /* Ambient */;
-            }
-            if (additionalModifierFlags & 1024 /* Default */ && (isClassDeclaration(node) || isInterfaceDeclaration(node) || isFunctionDeclaration(node))) {
-              newModifierFlags |= 1024 /* Default */;
-            }
-            if (newModifierFlags) {
-              node = factory.updateModifiers(node, newModifierFlags | getEffectiveModifierFlags(node));
-            }
-          }
-          results.push(node);
-        }
-        function serializeTypeAlias(symbol, symbolName2, modifierFlags) {
-          var _a;
-          const aliasType = getDeclaredTypeOfTypeAlias(symbol);
-          const typeParams = getSymbolLinks(symbol).typeParameters;
-          const typeParamDecls = map(typeParams, (p) => typeParameterToDeclaration(p, context));
-          const jsdocAliasDecl = (_a = symbol.declarations) == null ? void 0 : _a.find(isJSDocTypeAlias);
-          const commentText = getTextOfJSDocComment(jsdocAliasDecl ? jsdocAliasDecl.comment || jsdocAliasDecl.parent.comment : void 0);
-          const oldFlags = context.flags;
-          context.flags |= 8388608 /* InTypeAlias */;
-          const oldEnclosingDecl = context.enclosingDeclaration;
-          context.enclosingDeclaration = jsdocAliasDecl;
-          const typeNode = jsdocAliasDecl && jsdocAliasDecl.typeExpression && isJSDocTypeExpression(jsdocAliasDecl.typeExpression) && serializeExistingTypeNode(context, jsdocAliasDecl.typeExpression.type, includePrivateSymbol, bundled) || typeToTypeNodeHelper(aliasType, context);
-          addResult(setSyntheticLeadingComments(
-            factory.createTypeAliasDeclaration(
-              /*modifiers*/
-              void 0,
-              getInternalSymbolName(symbol, symbolName2),
-              typeParamDecls,
-              typeNode
-            ),
-            !commentText ? [] : [{ kind: 3 /* MultiLineCommentTrivia */, text: "*\n * " + commentText.replace(/\n/g, "\n * ") + "\n ", pos: -1, end: -1, hasTrailingNewLine: true }]
-          ), modifierFlags);
-          context.flags = oldFlags;
-          context.enclosingDeclaration = oldEnclosingDecl;
-        }
-        function serializeInterface(symbol, symbolName2, modifierFlags) {
-          const interfaceType = getDeclaredTypeOfClassOrInterface(symbol);
-          const localParams = getLocalTypeParametersOfClassOrInterfaceOrTypeAlias(symbol);
-          const typeParamDecls = map(localParams, (p) => typeParameterToDeclaration(p, context));
-          const baseTypes = getBaseTypes(interfaceType);
-          const baseType = length(baseTypes) ? getIntersectionType(baseTypes) : void 0;
-          const members = flatMap(getPropertiesOfType(interfaceType), (p) => serializePropertySymbolForInterface(p, baseType));
-          const callSignatures = serializeSignatures(0 /* Call */, interfaceType, baseType, 178 /* CallSignature */);
-          const constructSignatures = serializeSignatures(1 /* Construct */, interfaceType, baseType, 179 /* ConstructSignature */);
-          const indexSignatures = serializeIndexSignatures(interfaceType, baseType);
-          const heritageClauses = !length(baseTypes) ? void 0 : [factory.createHeritageClause(96 /* ExtendsKeyword */, mapDefined(baseTypes, (b) => trySerializeAsTypeReference(b, 111551 /* Value */)))];
-          addResult(factory.createInterfaceDeclaration(
-            /*modifiers*/
-            void 0,
-            getInternalSymbolName(symbol, symbolName2),
-            typeParamDecls,
-            heritageClauses,
-            [...indexSignatures, ...constructSignatures, ...callSignatures, ...members]
-          ), modifierFlags);
-        }
-        function getNamespaceMembersForSerialization(symbol) {
-          const exports = getExportsOfSymbol(symbol);
-          return !exports ? [] : filter(arrayFrom(exports.values()), (m) => isNamespaceMember(m) && isIdentifierText(m.escapedName, 99 /* ESNext */));
-        }
-        function isTypeOnlyNamespace(symbol) {
-          return every(getNamespaceMembersForSerialization(symbol), (m) => !(getAllSymbolFlags(resolveSymbol(m)) & 111551 /* Value */));
-        }
-        function serializeModule(symbol, symbolName2, modifierFlags) {
-          const members = getNamespaceMembersForSerialization(symbol);
-          const locationMap = arrayToMultiMap(members, (m) => m.parent && m.parent === symbol ? "real" : "merged");
-          const realMembers = locationMap.get("real") || emptyArray;
-          const mergedMembers = locationMap.get("merged") || emptyArray;
-          if (length(realMembers)) {
-            const localName = getInternalSymbolName(symbol, symbolName2);
-            serializeAsNamespaceDeclaration(realMembers, localName, modifierFlags, !!(symbol.flags & (16 /* Function */ | 67108864 /* Assignment */)));
-          }
-          if (length(mergedMembers)) {
-            const containingFile = getSourceFileOfNode(context.enclosingDeclaration);
-            const localName = getInternalSymbolName(symbol, symbolName2);
-            const nsBody = factory.createModuleBlock([factory.createExportDeclaration(
-              /*modifiers*/
-              void 0,
-              /*isTypeOnly*/
-              false,
-              factory.createNamedExports(mapDefined(filter(mergedMembers, (n) => n.escapedName !== "export=" /* ExportEquals */), (s) => {
-                var _a, _b;
-                const name = unescapeLeadingUnderscores(s.escapedName);
-                const localName2 = getInternalSymbolName(s, name);
-                const aliasDecl = s.declarations && getDeclarationOfAliasSymbol(s);
-                if (containingFile && (aliasDecl ? containingFile !== getSourceFileOfNode(aliasDecl) : !some(s.declarations, (d) => getSourceFileOfNode(d) === containingFile))) {
-                  (_b = (_a = context.tracker) == null ? void 0 : _a.reportNonlocalAugmentation) == null ? void 0 : _b.call(_a, containingFile, symbol, s);
-                  return void 0;
-                }
-                const target = aliasDecl && getTargetOfAliasDeclaration(
-                  aliasDecl,
-                  /*dontRecursivelyResolve*/
-                  true
-                );
-                includePrivateSymbol(target || s);
-                const targetName = target ? getInternalSymbolName(target, unescapeLeadingUnderscores(target.escapedName)) : localName2;
-                return factory.createExportSpecifier(
-                  /*isTypeOnly*/
-                  false,
-                  name === targetName ? void 0 : targetName,
-                  name
-                );
-              }))
-            )]);
-            addResult(factory.createModuleDeclaration(
-              /*modifiers*/
-              void 0,
-              factory.createIdentifier(localName),
-              nsBody,
-              16 /* Namespace */
-            ), 0 /* None */);
-          }
-        }
-        function serializeEnum(symbol, symbolName2, modifierFlags) {
-          addResult(factory.createEnumDeclaration(
-            factory.createModifiersFromModifierFlags(isConstEnumSymbol(symbol) ? 2048 /* Const */ : 0),
-            getInternalSymbolName(symbol, symbolName2),
-            map(filter(getPropertiesOfType(getTypeOfSymbol(symbol)), (p) => !!(p.flags & 8 /* EnumMember */)), (p) => {
-              const initializedValue = p.declarations && p.declarations[0] && isEnumMember(p.declarations[0]) ? getConstantValue2(p.declarations[0]) : void 0;
-              return factory.createEnumMember(unescapeLeadingUnderscores(p.escapedName), initializedValue === void 0 ? void 0 : typeof initializedValue === "string" ? factory.createStringLiteral(initializedValue) : factory.createNumericLiteral(initializedValue));
-            })
-          ), modifierFlags);
-        }
-        function serializeAsFunctionNamespaceMerge(type, symbol, localName, modifierFlags) {
-          const signatures = getSignaturesOfType(type, 0 /* Call */);
-          for (const sig of signatures) {
-            const decl = signatureToSignatureDeclarationHelper(sig, 261 /* FunctionDeclaration */, context, { name: factory.createIdentifier(localName), privateSymbolVisitor: includePrivateSymbol, bundledImports: bundled });
-            addResult(setTextRange(decl, getSignatureTextRangeLocation(sig)), modifierFlags);
-          }
-          if (!(symbol.flags & (512 /* ValueModule */ | 1024 /* NamespaceModule */) && !!symbol.exports && !!symbol.exports.size)) {
-            const props = filter(getPropertiesOfType(type), isNamespaceMember);
-            serializeAsNamespaceDeclaration(
-              props,
-              localName,
-              modifierFlags,
-              /*suppressNewPrivateContext*/
-              true
-            );
-          }
-        }
-        function getSignatureTextRangeLocation(signature) {
-          if (signature.declaration && signature.declaration.parent) {
-            if (isBinaryExpression(signature.declaration.parent) && getAssignmentDeclarationKind(signature.declaration.parent) === 5 /* Property */) {
-              return signature.declaration.parent;
-            }
-            if (isVariableDeclaration(signature.declaration.parent) && signature.declaration.parent.parent) {
-              return signature.declaration.parent.parent;
-            }
-          }
-          return signature.declaration;
-        }
-        function serializeAsNamespaceDeclaration(props, localName, modifierFlags, suppressNewPrivateContext) {
-          if (length(props)) {
-            const localVsRemoteMap = arrayToMultiMap(
-              props,
-              (p) => !length(p.declarations) || some(
-                p.declarations,
-                (d) => getSourceFileOfNode(d) === getSourceFileOfNode(context.enclosingDeclaration)
-              ) ? "local" : "remote"
-            );
-            const localProps = localVsRemoteMap.get("local") || emptyArray;
-            let fakespace = parseNodeFactory.createModuleDeclaration(
-              /*modifiers*/
-              void 0,
-              factory.createIdentifier(localName),
-              factory.createModuleBlock([]),
-              16 /* Namespace */
-            );
-            setParent(fakespace, enclosingDeclaration);
-            fakespace.locals = createSymbolTable(props);
-            fakespace.symbol = props[0].parent;
-            const oldResults = results;
-            results = [];
-            const oldAddingDeclare = addingDeclare;
-            addingDeclare = false;
-            const subcontext = { ...context, enclosingDeclaration: fakespace };
-            const oldContext = context;
-            context = subcontext;
-            visitSymbolTable(
-              createSymbolTable(localProps),
-              suppressNewPrivateContext,
-              /*propertyAsAlias*/
-              true
-            );
-            context = oldContext;
-            addingDeclare = oldAddingDeclare;
-            const declarations = results;
-            results = oldResults;
-            const defaultReplaced = map(declarations, (d) => isExportAssignment(d) && !d.isExportEquals && isIdentifier(d.expression) ? factory.createExportDeclaration(
-              /*modifiers*/
-              void 0,
-              /*isTypeOnly*/
-              false,
-              factory.createNamedExports([factory.createExportSpecifier(
-                /*isTypeOnly*/
-                false,
-                d.expression,
-                factory.createIdentifier("default" /* Default */)
-              )])
-            ) : d);
-            const exportModifierStripped = every(defaultReplaced, (d) => hasSyntacticModifier(d, 1 /* Export */)) ? map(defaultReplaced, removeExportModifier) : defaultReplaced;
-            fakespace = factory.updateModuleDeclaration(
-              fakespace,
-              fakespace.modifiers,
-              fakespace.name,
-              factory.createModuleBlock(exportModifierStripped)
-            );
-            addResult(fakespace, modifierFlags);
-          }
-        }
-        function isNamespaceMember(p) {
-          return !!(p.flags & (788968 /* Type */ | 1920 /* Namespace */ | 2097152 /* Alias */)) || !(p.flags & 4194304 /* Prototype */ || p.escapedName === "prototype" || p.valueDeclaration && isStatic(p.valueDeclaration) && isClassLike(p.valueDeclaration.parent));
-        }
-        function sanitizeJSDocImplements(clauses) {
-          const result = mapDefined(clauses, (e) => {
-            const oldEnclosing = context.enclosingDeclaration;
-            context.enclosingDeclaration = e;
-            let expr = e.expression;
-            if (isEntityNameExpression(expr)) {
-              if (isIdentifier(expr) && idText(expr) === "") {
-                return cleanup(
-                  /*result*/
-                  void 0
-                );
-              }
-              let introducesError;
-              ({ introducesError, node: expr } = trackExistingEntityName(expr, context, includePrivateSymbol));
-              if (introducesError) {
-                return cleanup(
-                  /*result*/
-                  void 0
-                );
-              }
-            }
-            return cleanup(factory.createExpressionWithTypeArguments(
-              expr,
-              map(
-                e.typeArguments,
-                (a) => serializeExistingTypeNode(context, a, includePrivateSymbol, bundled) || typeToTypeNodeHelper(getTypeFromTypeNode(a), context)
-              )
-            ));
-            function cleanup(result2) {
-              context.enclosingDeclaration = oldEnclosing;
-              return result2;
-            }
-          });
-          if (result.length === clauses.length) {
-            return result;
-          }
-          return void 0;
-        }
-        function serializeAsClass(symbol, localName, modifierFlags) {
-          var _a, _b;
-          const originalDecl = (_a = symbol.declarations) == null ? void 0 : _a.find(isClassLike);
-          const oldEnclosing = context.enclosingDeclaration;
-          context.enclosingDeclaration = originalDecl || oldEnclosing;
-          const localParams = getLocalTypeParametersOfClassOrInterfaceOrTypeAlias(symbol);
-          const typeParamDecls = map(localParams, (p) => typeParameterToDeclaration(p, context));
-          const classType = getTypeWithThisArgument(getDeclaredTypeOfClassOrInterface(symbol));
-          const baseTypes = getBaseTypes(classType);
-          const originalImplements = originalDecl && getEffectiveImplementsTypeNodes(originalDecl);
-          const implementsExpressions = originalImplements && sanitizeJSDocImplements(originalImplements) || mapDefined(getImplementsTypes(classType), serializeImplementedType);
-          const staticType = getTypeOfSymbol(symbol);
-          const isClass = !!((_b = staticType.symbol) == null ? void 0 : _b.valueDeclaration) && isClassLike(staticType.symbol.valueDeclaration);
-          const staticBaseType = isClass ? getBaseConstructorTypeOfClass(staticType) : anyType;
-          const heritageClauses = [
-            ...!length(baseTypes) ? [] : [factory.createHeritageClause(96 /* ExtendsKeyword */, map(baseTypes, (b) => serializeBaseType(b, staticBaseType, localName)))],
-            ...!length(implementsExpressions) ? [] : [factory.createHeritageClause(119 /* ImplementsKeyword */, implementsExpressions)]
-          ];
-          const symbolProps = getNonInheritedProperties(classType, baseTypes, getPropertiesOfType(classType));
-          const publicSymbolProps = filter(symbolProps, (s) => {
-            const valueDecl = s.valueDeclaration;
-            return !!valueDecl && !(isNamedDeclaration(valueDecl) && isPrivateIdentifier(valueDecl.name));
-          });
-          const hasPrivateIdentifier = some(symbolProps, (s) => {
-            const valueDecl = s.valueDeclaration;
-            return !!valueDecl && isNamedDeclaration(valueDecl) && isPrivateIdentifier(valueDecl.name);
-          });
-          const privateProperties = hasPrivateIdentifier ? [factory.createPropertyDeclaration(
-            /*modifiers*/
-            void 0,
-            factory.createPrivateIdentifier("#private"),
-            /*questionOrExclamationToken*/
-            void 0,
-            /*type*/
-            void 0,
-            /*initializer*/
-            void 0
-          )] : emptyArray;
-          const publicProperties = flatMap(publicSymbolProps, (p) => serializePropertySymbolForClass(
-            p,
-            /*isStatic*/
-            false,
-            baseTypes[0]
-          ));
-          const staticMembers = flatMap(
-            filter(getPropertiesOfType(staticType), (p) => !(p.flags & 4194304 /* Prototype */) && p.escapedName !== "prototype" && !isNamespaceMember(p)),
-            (p) => serializePropertySymbolForClass(
-              p,
-              /*isStatic*/
-              true,
-              staticBaseType
-            )
-          );
-          const isNonConstructableClassLikeInJsFile = !isClass && !!symbol.valueDeclaration && isInJSFile(symbol.valueDeclaration) && !some(getSignaturesOfType(staticType, 1 /* Construct */));
-          const constructors = isNonConstructableClassLikeInJsFile ? [factory.createConstructorDeclaration(
-            factory.createModifiersFromModifierFlags(8 /* Private */),
-            [],
-            /*body*/
-            void 0
-          )] : serializeSignatures(1 /* Construct */, staticType, staticBaseType, 175 /* Constructor */);
-          const indexSignatures = serializeIndexSignatures(classType, baseTypes[0]);
-          context.enclosingDeclaration = oldEnclosing;
-          addResult(setTextRange(factory.createClassDeclaration(
-            /*modifiers*/
-            void 0,
-            localName,
-            typeParamDecls,
-            heritageClauses,
-            [...indexSignatures, ...staticMembers, ...constructors, ...publicProperties, ...privateProperties]
-          ), symbol.declarations && filter(symbol.declarations, (d) => isClassDeclaration(d) || isClassExpression(d))[0]), modifierFlags);
-        }
-        function getSomeTargetNameFromDeclarations(declarations) {
-          return firstDefined(declarations, (d) => {
-            if (isImportSpecifier(d) || isExportSpecifier(d)) {
-              return idText(d.propertyName || d.name);
-            }
-            if (isBinaryExpression(d) || isExportAssignment(d)) {
-              const expression = isExportAssignment(d) ? d.expression : d.right;
-              if (isPropertyAccessExpression(expression)) {
-                return idText(expression.name);
-              }
-            }
-            if (isAliasSymbolDeclaration2(d)) {
-              const name = getNameOfDeclaration(d);
-              if (name && isIdentifier(name)) {
-                return idText(name);
-              }
-            }
-            return void 0;
-          });
-        }
-        function serializeAsAlias(symbol, localName, modifierFlags) {
-          var _a, _b, _c, _d, _e;
-          const node = getDeclarationOfAliasSymbol(symbol);
-          if (!node)
-            return Debug.fail();
-          const target = getMergedSymbol(getTargetOfAliasDeclaration(
-            node,
-            /*dontRecursivelyResolve*/
-            true
-          ));
-          if (!target) {
-            return;
-          }
-          let verbatimTargetName = isShorthandAmbientModuleSymbol(target) && getSomeTargetNameFromDeclarations(symbol.declarations) || unescapeLeadingUnderscores(target.escapedName);
-          if (verbatimTargetName === "export=" /* ExportEquals */ && allowSyntheticDefaultImports) {
-            verbatimTargetName = "default" /* Default */;
-          }
-          const targetName = getInternalSymbolName(target, verbatimTargetName);
-          includePrivateSymbol(target);
-          switch (node.kind) {
-            case 207 /* BindingElement */:
-              if (((_b = (_a = node.parent) == null ? void 0 : _a.parent) == null ? void 0 : _b.kind) === 259 /* VariableDeclaration */) {
-                const specifier2 = getSpecifierForModuleSymbol(target.parent || target, context);
-                const { propertyName } = node;
-                addResult(factory.createImportDeclaration(
-                  /*modifiers*/
-                  void 0,
-                  factory.createImportClause(
-                    /*isTypeOnly*/
-                    false,
-                    /*name*/
-                    void 0,
-                    factory.createNamedImports([factory.createImportSpecifier(
-                      /*isTypeOnly*/
-                      false,
-                      propertyName && isIdentifier(propertyName) ? factory.createIdentifier(idText(propertyName)) : void 0,
-                      factory.createIdentifier(localName)
-                    )])
-                  ),
-                  factory.createStringLiteral(specifier2),
-                  /*assertClause*/
-                  void 0
-                ), 0 /* None */);
-                break;
-              }
-              Debug.failBadSyntaxKind(((_c = node.parent) == null ? void 0 : _c.parent) || node, "Unhandled binding element grandparent kind in declaration serialization");
-              break;
-            case 303 /* ShorthandPropertyAssignment */:
-              if (((_e = (_d = node.parent) == null ? void 0 : _d.parent) == null ? void 0 : _e.kind) === 225 /* BinaryExpression */) {
-                serializeExportSpecifier(
-                  unescapeLeadingUnderscores(symbol.escapedName),
-                  targetName
-                );
-              }
-              break;
-            case 259 /* VariableDeclaration */:
-              if (isPropertyAccessExpression(node.initializer)) {
-                const initializer = node.initializer;
-                const uniqueName = factory.createUniqueName(localName);
-                const specifier2 = getSpecifierForModuleSymbol(target.parent || target, context);
-                addResult(factory.createImportEqualsDeclaration(
-                  /*modifiers*/
-                  void 0,
-                  /*isTypeOnly*/
-                  false,
-                  uniqueName,
-                  factory.createExternalModuleReference(factory.createStringLiteral(specifier2))
-                ), 0 /* None */);
-                addResult(factory.createImportEqualsDeclaration(
-                  /*modifiers*/
-                  void 0,
-                  /*isTypeOnly*/
-                  false,
-                  factory.createIdentifier(localName),
-                  factory.createQualifiedName(uniqueName, initializer.name)
-                ), modifierFlags);
-                break;
-              }
-            case 270 /* ImportEqualsDeclaration */:
-              if (target.escapedName === "export=" /* ExportEquals */ && some(target.declarations, (d) => isSourceFile(d) && isJsonSourceFile(d))) {
-                serializeMaybeAliasAssignment(symbol);
-                break;
-              }
-              const isLocalImport = !(target.flags & 512 /* ValueModule */) && !isVariableDeclaration(node);
-              addResult(factory.createImportEqualsDeclaration(
-                /*modifiers*/
-                void 0,
-                /*isTypeOnly*/
-                false,
-                factory.createIdentifier(localName),
-                isLocalImport ? symbolToName(
-                  target,
-                  context,
-                  67108863 /* All */,
-                  /*expectsIdentifier*/
-                  false
-                ) : factory.createExternalModuleReference(factory.createStringLiteral(getSpecifierForModuleSymbol(target, context)))
-              ), isLocalImport ? modifierFlags : 0 /* None */);
-              break;
-            case 269 /* NamespaceExportDeclaration */:
-              addResult(factory.createNamespaceExportDeclaration(idText(node.name)), 0 /* None */);
-              break;
-            case 272 /* ImportClause */: {
-              const generatedSpecifier = getSpecifierForModuleSymbol(target.parent || target, context);
-              const specifier2 = bundled ? factory.createStringLiteral(generatedSpecifier) : node.parent.moduleSpecifier;
-              addResult(factory.createImportDeclaration(
-                /*modifiers*/
-                void 0,
-                factory.createImportClause(
-                  /*isTypeOnly*/
-                  false,
-                  factory.createIdentifier(localName),
-                  /*namedBindings*/
-                  void 0
-                ),
-                specifier2,
-                node.parent.assertClause
-              ), 0 /* None */);
-              break;
-            }
-            case 273 /* NamespaceImport */: {
-              const generatedSpecifier = getSpecifierForModuleSymbol(target.parent || target, context);
-              const specifier2 = bundled ? factory.createStringLiteral(generatedSpecifier) : node.parent.parent.moduleSpecifier;
-              addResult(factory.createImportDeclaration(
-                /*modifiers*/
-                void 0,
-                factory.createImportClause(
-                  /*isTypeOnly*/
-                  false,
-                  /*name*/
-                  void 0,
-                  factory.createNamespaceImport(factory.createIdentifier(localName))
-                ),
-                specifier2,
-                node.parent.parent.assertClause
-              ), 0 /* None */);
-              break;
-            }
-            case 279 /* NamespaceExport */:
-              addResult(factory.createExportDeclaration(
-                /*modifiers*/
-                void 0,
-                /*isTypeOnly*/
-                false,
-                factory.createNamespaceExport(factory.createIdentifier(localName)),
-                factory.createStringLiteral(getSpecifierForModuleSymbol(target, context))
-              ), 0 /* None */);
-              break;
-            case 275 /* ImportSpecifier */: {
-              const generatedSpecifier = getSpecifierForModuleSymbol(target.parent || target, context);
-              const specifier2 = bundled ? factory.createStringLiteral(generatedSpecifier) : node.parent.parent.parent.moduleSpecifier;
-              addResult(factory.createImportDeclaration(
-                /*modifiers*/
-                void 0,
-                factory.createImportClause(
-                  /*isTypeOnly*/
-                  false,
-                  /*name*/
-                  void 0,
-                  factory.createNamedImports([
-                    factory.createImportSpecifier(
-                      /*isTypeOnly*/
-                      false,
-                      localName !== verbatimTargetName ? factory.createIdentifier(verbatimTargetName) : void 0,
-                      factory.createIdentifier(localName)
-                    )
-                  ])
-                ),
-                specifier2,
-                node.parent.parent.parent.assertClause
-              ), 0 /* None */);
-              break;
-            }
-            case 280 /* ExportSpecifier */:
-              const specifier = node.parent.parent.moduleSpecifier;
-              serializeExportSpecifier(
-                unescapeLeadingUnderscores(symbol.escapedName),
-                specifier ? verbatimTargetName : targetName,
-                specifier && isStringLiteralLike(specifier) ? factory.createStringLiteral(specifier.text) : void 0
-              );
-              break;
-            case 276 /* ExportAssignment */:
-              serializeMaybeAliasAssignment(symbol);
-              break;
-            case 225 /* BinaryExpression */:
-            case 210 /* PropertyAccessExpression */:
-            case 211 /* ElementAccessExpression */:
-              if (symbol.escapedName === "default" /* Default */ || symbol.escapedName === "export=" /* ExportEquals */) {
-                serializeMaybeAliasAssignment(symbol);
-              } else {
-                serializeExportSpecifier(localName, targetName);
-              }
-              break;
-            default:
-              return Debug.failBadSyntaxKind(node, "Unhandled alias declaration kind in symbol serializer!");
-          }
-        }
-        function serializeExportSpecifier(localName, targetName, specifier) {
-          addResult(factory.createExportDeclaration(
-            /*modifiers*/
-            void 0,
-            /*isTypeOnly*/
-            false,
-            factory.createNamedExports([factory.createExportSpecifier(
-              /*isTypeOnly*/
-              false,
-              localName !== targetName ? targetName : void 0,
-              localName
-            )]),
-            specifier
-          ), 0 /* None */);
-        }
-        function serializeMaybeAliasAssignment(symbol) {
-          var _a;
-          if (symbol.flags & 4194304 /* Prototype */) {
-            return false;
-          }
-          const name = unescapeLeadingUnderscores(symbol.escapedName);
-          const isExportEquals = name === "export=" /* ExportEquals */;
-          const isDefault = name === "default" /* Default */;
-          const isExportAssignmentCompatibleSymbolName = isExportEquals || isDefault;
-          const aliasDecl = symbol.declarations && getDeclarationOfAliasSymbol(symbol);
-          const target = aliasDecl && getTargetOfAliasDeclaration(
-            aliasDecl,
-            /*dontRecursivelyResolve*/
-            true
-          );
-          if (target && length(target.declarations) && some(target.declarations, (d) => getSourceFileOfNode(d) === getSourceFileOfNode(enclosingDeclaration))) {
-            const expr = aliasDecl && (isExportAssignment(aliasDecl) || isBinaryExpression(aliasDecl) ? getExportAssignmentExpression(aliasDecl) : getPropertyAssignmentAliasLikeExpression(aliasDecl));
-            const first2 = expr && isEntityNameExpression(expr) ? getFirstNonModuleExportsIdentifier(expr) : void 0;
-            const referenced = first2 && resolveEntityName(
-              first2,
-              67108863 /* All */,
-              /*ignoreErrors*/
-              true,
-              /*dontResolveAlias*/
-              true,
-              enclosingDeclaration
-            );
-            if (referenced || target) {
-              includePrivateSymbol(referenced || target);
-            }
-            const prevDisableTrackSymbol = context.tracker.disableTrackSymbol;
-            context.tracker.disableTrackSymbol = true;
-            if (isExportAssignmentCompatibleSymbolName) {
-              results.push(factory.createExportAssignment(
-                /*modifiers*/
-                void 0,
-                isExportEquals,
-                symbolToExpression(target, context, 67108863 /* All */)
-              ));
-            } else {
-              if (first2 === expr && first2) {
-                serializeExportSpecifier(name, idText(first2));
-              } else if (expr && isClassExpression(expr)) {
-                serializeExportSpecifier(name, getInternalSymbolName(target, symbolName(target)));
-              } else {
-                const varName = getUnusedName(name, symbol);
-                addResult(factory.createImportEqualsDeclaration(
-                  /*modifiers*/
-                  void 0,
-                  /*isTypeOnly*/
-                  false,
-                  factory.createIdentifier(varName),
-                  symbolToName(
-                    target,
-                    context,
-                    67108863 /* All */,
-                    /*expectsIdentifier*/
-                    false
-                  )
-                ), 0 /* None */);
-                serializeExportSpecifier(name, varName);
-              }
-            }
-            context.tracker.disableTrackSymbol = prevDisableTrackSymbol;
-            return true;
-          } else {
-            const varName = getUnusedName(name, symbol);
-            const typeToSerialize = getWidenedType(getTypeOfSymbol(getMergedSymbol(symbol)));
-            if (isTypeRepresentableAsFunctionNamespaceMerge(typeToSerialize, symbol)) {
-              serializeAsFunctionNamespaceMerge(typeToSerialize, symbol, varName, isExportAssignmentCompatibleSymbolName ? 0 /* None */ : 1 /* Export */);
-            } else {
-              const statement = factory.createVariableStatement(
-                /*modifiers*/
-                void 0,
-                factory.createVariableDeclarationList([
-                  factory.createVariableDeclaration(
-                    varName,
-                    /*exclamationToken*/
-                    void 0,
-                    serializeTypeForDeclaration(context, typeToSerialize, symbol, enclosingDeclaration, includePrivateSymbol, bundled)
-                  )
-                ], ((_a = context.enclosingDeclaration) == null ? void 0 : _a.kind) === 266 /* ModuleDeclaration */ ? 1 /* Let */ : 2 /* Const */)
-              );
-              addResult(
-                statement,
-                target && target.flags & 4 /* Property */ && target.escapedName === "export=" /* ExportEquals */ ? 2 /* Ambient */ : name === varName ? 1 /* Export */ : 0 /* None */
-              );
-            }
-            if (isExportAssignmentCompatibleSymbolName) {
-              results.push(factory.createExportAssignment(
-                /*modifiers*/
-                void 0,
-                isExportEquals,
-                factory.createIdentifier(varName)
-              ));
-              return true;
-            } else if (name !== varName) {
-              serializeExportSpecifier(name, varName);
-              return true;
-            }
-            return false;
-          }
-        }
-        function isTypeRepresentableAsFunctionNamespaceMerge(typeToSerialize, hostSymbol) {
-          const ctxSrc = getSourceFileOfNode(context.enclosingDeclaration);
-          return getObjectFlags(typeToSerialize) & (16 /* Anonymous */ | 32 /* Mapped */) && !length(getIndexInfosOfType(typeToSerialize)) && !isClassInstanceSide(typeToSerialize) && // While a class instance is potentially representable as a NS, prefer printing a reference to the instance type and serializing the class
-          !!(length(filter(getPropertiesOfType(typeToSerialize), isNamespaceMember)) || length(getSignaturesOfType(typeToSerialize, 0 /* Call */))) && !length(getSignaturesOfType(typeToSerialize, 1 /* Construct */)) && // TODO: could probably serialize as function + ns + class, now that that's OK
-          !getDeclarationWithTypeAnnotation(hostSymbol, enclosingDeclaration) && !(typeToSerialize.symbol && some(typeToSerialize.symbol.declarations, (d) => getSourceFileOfNode(d) !== ctxSrc)) && !some(getPropertiesOfType(typeToSerialize), (p) => isLateBoundName(p.escapedName)) && !some(getPropertiesOfType(typeToSerialize), (p) => some(p.declarations, (d) => getSourceFileOfNode(d) !== ctxSrc)) && every(getPropertiesOfType(typeToSerialize), (p) => isIdentifierText(symbolName(p), languageVersion));
-        }
-        function makeSerializePropertySymbol(createProperty2, methodKind, useAccessors) {
-          return function serializePropertySymbol(p, isStatic2, baseType) {
-            var _a, _b, _c, _d, _e;
-            const modifierFlags = getDeclarationModifierFlagsFromSymbol(p);
-            const isPrivate = !!(modifierFlags & 8 /* Private */);
-            if (isStatic2 && p.flags & (788968 /* Type */ | 1920 /* Namespace */ | 2097152 /* Alias */)) {
-              return [];
-            }
-            if (p.flags & 4194304 /* Prototype */ || p.escapedName === "constructor" || baseType && getPropertyOfType(baseType, p.escapedName) && isReadonlySymbol(getPropertyOfType(baseType, p.escapedName)) === isReadonlySymbol(p) && (p.flags & 16777216 /* Optional */) === (getPropertyOfType(baseType, p.escapedName).flags & 16777216 /* Optional */) && isTypeIdenticalTo(getTypeOfSymbol(p), getTypeOfPropertyOfType(baseType, p.escapedName))) {
-              return [];
-            }
-            const flag = modifierFlags & ~512 /* Async */ | (isStatic2 ? 32 /* Static */ : 0);
-            const name = getPropertyNameNodeForSymbol(p, context);
-            const firstPropertyLikeDecl = (_a = p.declarations) == null ? void 0 : _a.find(or(isPropertyDeclaration, isAccessor, isVariableDeclaration, isPropertySignature, isBinaryExpression, isPropertyAccessExpression));
-            if (p.flags & 98304 /* Accessor */ && useAccessors) {
-              const result = [];
-              if (p.flags & 65536 /* SetAccessor */) {
-                result.push(setTextRange(factory.createSetAccessorDeclaration(
-                  factory.createModifiersFromModifierFlags(flag),
-                  name,
-                  [factory.createParameterDeclaration(
-                    /*modifiers*/
-                    void 0,
-                    /*dotDotDotToken*/
-                    void 0,
-                    "arg",
-                    /*questionToken*/
-                    void 0,
-                    isPrivate ? void 0 : serializeTypeForDeclaration(context, getTypeOfSymbol(p), p, enclosingDeclaration, includePrivateSymbol, bundled)
-                  )],
-                  /*body*/
-                  void 0
-                ), ((_b = p.declarations) == null ? void 0 : _b.find(isSetAccessor)) || firstPropertyLikeDecl));
-              }
-              if (p.flags & 32768 /* GetAccessor */) {
-                const isPrivate2 = modifierFlags & 8 /* Private */;
-                result.push(setTextRange(factory.createGetAccessorDeclaration(
-                  factory.createModifiersFromModifierFlags(flag),
-                  name,
-                  [],
-                  isPrivate2 ? void 0 : serializeTypeForDeclaration(context, getTypeOfSymbol(p), p, enclosingDeclaration, includePrivateSymbol, bundled),
-                  /*body*/
-                  void 0
-                ), ((_c = p.declarations) == null ? void 0 : _c.find(isGetAccessor)) || firstPropertyLikeDecl));
-              }
-              return result;
-            } else if (p.flags & (4 /* Property */ | 3 /* Variable */ | 98304 /* Accessor */)) {
-              return setTextRange(createProperty2(
-                factory.createModifiersFromModifierFlags((isReadonlySymbol(p) ? 64 /* Readonly */ : 0) | flag),
-                name,
-                p.flags & 16777216 /* Optional */ ? factory.createToken(58 /* QuestionToken */) : void 0,
-                isPrivate ? void 0 : serializeTypeForDeclaration(context, getWriteTypeOfSymbol(p), p, enclosingDeclaration, includePrivateSymbol, bundled),
-                // TODO: https://github.com/microsoft/TypeScript/pull/32372#discussion_r328386357
-                // interface members can't have initializers, however class members _can_
-                /*initializer*/
-                void 0
-              ), ((_d = p.declarations) == null ? void 0 : _d.find(or(isPropertyDeclaration, isVariableDeclaration))) || firstPropertyLikeDecl);
-            }
-            if (p.flags & (8192 /* Method */ | 16 /* Function */)) {
-              const type = getTypeOfSymbol(p);
-              const signatures = getSignaturesOfType(type, 0 /* Call */);
-              if (flag & 8 /* Private */) {
-                return setTextRange(createProperty2(
-                  factory.createModifiersFromModifierFlags((isReadonlySymbol(p) ? 64 /* Readonly */ : 0) | flag),
-                  name,
-                  p.flags & 16777216 /* Optional */ ? factory.createToken(58 /* QuestionToken */) : void 0,
-                  /*type*/
-                  void 0,
-                  /*initializer*/
-                  void 0
-                ), ((_e = p.declarations) == null ? void 0 : _e.find(isFunctionLikeDeclaration)) || signatures[0] && signatures[0].declaration || p.declarations && p.declarations[0]);
-              }
-              const results2 = [];
-              for (const sig of signatures) {
-                const decl = signatureToSignatureDeclarationHelper(
-                  sig,
-                  methodKind,
-                  context,
-                  {
-                    name,
-                    questionToken: p.flags & 16777216 /* Optional */ ? factory.createToken(58 /* QuestionToken */) : void 0,
-                    modifiers: flag ? factory.createModifiersFromModifierFlags(flag) : void 0
-                  }
-                );
-                const location = sig.declaration && isPrototypePropertyAssignment(sig.declaration.parent) ? sig.declaration.parent : sig.declaration;
-                results2.push(setTextRange(decl, location));
-              }
-              return results2;
-            }
-            return Debug.fail(`Unhandled class member kind! ${p.__debugFlags || p.flags}`);
-          };
-        }
-        function serializePropertySymbolForInterface(p, baseType) {
-          return serializePropertySymbolForInterfaceWorker(
-            p,
-            /*isStatic*/
-            false,
-            baseType
-          );
-        }
-        function serializeSignatures(kind, input, baseType, outputKind) {
-          const signatures = getSignaturesOfType(input, kind);
-          if (kind === 1 /* Construct */) {
-            if (!baseType && every(signatures, (s) => length(s.parameters) === 0)) {
-              return [];
-            }
-            if (baseType) {
-              const baseSigs = getSignaturesOfType(baseType, 1 /* Construct */);
-              if (!length(baseSigs) && every(signatures, (s) => length(s.parameters) === 0)) {
-                return [];
-              }
-              if (baseSigs.length === signatures.length) {
-                let failed = false;
-                for (let i = 0; i < baseSigs.length; i++) {
-                  if (!compareSignaturesIdentical(
-                    signatures[i],
-                    baseSigs[i],
-                    /*partialMatch*/
-                    false,
-                    /*ignoreThisTypes*/
-                    false,
-                    /*ignoreReturnTypes*/
-                    true,
-                    compareTypesIdentical
-                  )) {
-                    failed = true;
-                    break;
-                  }
-                }
-                if (!failed) {
-                  return [];
-                }
-              }
-            }
-            let privateProtected = 0;
-            for (const s of signatures) {
-              if (s.declaration) {
-                privateProtected |= getSelectedEffectiveModifierFlags(s.declaration, 8 /* Private */ | 16 /* Protected */);
-              }
-            }
-            if (privateProtected) {
-              return [setTextRange(factory.createConstructorDeclaration(
-                factory.createModifiersFromModifierFlags(privateProtected),
-                /*parameters*/
-                [],
-                /*body*/
-                void 0
-              ), signatures[0].declaration)];
-            }
-          }
-          const results2 = [];
-          for (const sig of signatures) {
-            const decl = signatureToSignatureDeclarationHelper(sig, outputKind, context);
-            results2.push(setTextRange(decl, sig.declaration));
-          }
-          return results2;
-        }
-        function serializeIndexSignatures(input, baseType) {
-          const results2 = [];
-          for (const info of getIndexInfosOfType(input)) {
-            if (baseType) {
-              const baseInfo = getIndexInfoOfType(baseType, info.keyType);
-              if (baseInfo) {
-                if (isTypeIdenticalTo(info.type, baseInfo.type)) {
-                  continue;
-                }
-              }
-            }
-            results2.push(indexInfoToIndexSignatureDeclarationHelper(
-              info,
-              context,
-              /*typeNode*/
-              void 0
-            ));
-          }
-          return results2;
-        }
-        function serializeBaseType(t, staticType, rootName) {
-          const ref = trySerializeAsTypeReference(t, 111551 /* Value */);
-          if (ref) {
-            return ref;
-          }
-          const tempName = getUnusedName(`${rootName}_base`);
-          const statement = factory.createVariableStatement(
-            /*modifiers*/
-            void 0,
-            factory.createVariableDeclarationList([
-              factory.createVariableDeclaration(
-                tempName,
-                /*exclamationToken*/
-                void 0,
-                typeToTypeNodeHelper(staticType, context)
-              )
-            ], 2 /* Const */)
-          );
-          addResult(statement, 0 /* None */);
-          return factory.createExpressionWithTypeArguments(
-            factory.createIdentifier(tempName),
-            /*typeArguments*/
-            void 0
-          );
-        }
-        function trySerializeAsTypeReference(t, flags) {
-          let typeArgs;
-          let reference;
-          if (t.target && isSymbolAccessibleByFlags(t.target.symbol, enclosingDeclaration, flags)) {
-            typeArgs = map(getTypeArguments(t), (t2) => typeToTypeNodeHelper(t2, context));
-            reference = symbolToExpression(t.target.symbol, context, 788968 /* Type */);
-          } else if (t.symbol && isSymbolAccessibleByFlags(t.symbol, enclosingDeclaration, flags)) {
-            reference = symbolToExpression(t.symbol, context, 788968 /* Type */);
-          }
-          if (reference) {
-            return factory.createExpressionWithTypeArguments(reference, typeArgs);
-          }
-        }
-        function serializeImplementedType(t) {
-          const ref = trySerializeAsTypeReference(t, 788968 /* Type */);
-          if (ref) {
-            return ref;
-          }
-          if (t.symbol) {
-            return factory.createExpressionWithTypeArguments(
-              symbolToExpression(t.symbol, context, 788968 /* Type */),
-              /*typeArguments*/
-              void 0
-            );
-          }
-        }
-        function getUnusedName(input, symbol) {
-          var _a, _b;
-          const id = symbol ? getSymbolId(symbol) : void 0;
-          if (id) {
-            if (context.remappedSymbolNames.has(id)) {
-              return context.remappedSymbolNames.get(id);
-            }
-          }
-          if (symbol) {
-            input = getNameCandidateWorker(symbol, input);
-          }
-          let i = 0;
-          const original = input;
-          while ((_a = context.usedSymbolNames) == null ? void 0 : _a.has(input)) {
-            i++;
-            input = `${original}_${i}`;
-          }
-          (_b = context.usedSymbolNames) == null ? void 0 : _b.add(input);
-          if (id) {
-            context.remappedSymbolNames.set(id, input);
-          }
-          return input;
-        }
-        function getNameCandidateWorker(symbol, localName) {
-          if (localName === "default" /* Default */ || localName === "__class" /* Class */ || localName === "__function" /* Function */) {
-            const flags = context.flags;
-            context.flags |= 16777216 /* InInitialEntityName */;
-            const nameCandidate = getNameOfSymbolAsWritten(symbol, context);
-            context.flags = flags;
-            localName = nameCandidate.length > 0 && isSingleOrDoubleQuote(nameCandidate.charCodeAt(0)) ? stripQuotes(nameCandidate) : nameCandidate;
-          }
-          if (localName === "default" /* Default */) {
-            localName = "_default";
-          } else if (localName === "export=" /* ExportEquals */) {
-            localName = "_exports";
-          }
-          localName = isIdentifierText(localName, languageVersion) && !isStringANonContextualKeyword(localName) ? localName : "_" + localName.replace(/[^a-zA-Z0-9]/g, "_");
-          return localName;
-        }
-        function getInternalSymbolName(symbol, localName) {
-          const id = getSymbolId(symbol);
-          if (context.remappedSymbolNames.has(id)) {
-            return context.remappedSymbolNames.get(id);
-          }
-          localName = getNameCandidateWorker(symbol, localName);
-          context.remappedSymbolNames.set(id, localName);
-          return localName;
-        }
-      }
-    }
-    function typePredicateToString(typePredicate, enclosingDeclaration, flags = 16384 /* UseAliasDefinedOutsideCurrentScope */, writer) {
-      return writer ? typePredicateToStringWorker(writer).getText() : usingSingleLineStringWriter(typePredicateToStringWorker);
-      function typePredicateToStringWorker(writer2) {
-        const predicate = factory.createTypePredicateNode(
-          typePredicate.kind === 2 /* AssertsThis */ || typePredicate.kind === 3 /* AssertsIdentifier */ ? factory.createToken(131 /* AssertsKeyword */) : void 0,
-          typePredicate.kind === 1 /* Identifier */ || typePredicate.kind === 3 /* AssertsIdentifier */ ? factory.createIdentifier(typePredicate.parameterName) : factory.createThisTypeNode(),
-          typePredicate.type && nodeBuilder.typeToTypeNode(typePredicate.type, enclosingDeclaration, toNodeBuilderFlags(flags) | 70221824 /* IgnoreErrors */ | 512 /* WriteTypeParametersInQualifiedName */)
-          // TODO: GH#18217
-        );
-        const printer = createPrinterWithRemoveComments();
-        const sourceFile = enclosingDeclaration && getSourceFileOfNode(enclosingDeclaration);
-        printer.writeNode(
-          4 /* Unspecified */,
-          predicate,
-          /*sourceFile*/
-          sourceFile,
-          writer2
-        );
-        return writer2;
-      }
-    }
-    function formatUnionTypes(types) {
-      const result = [];
-      let flags = 0;
-      for (let i = 0; i < types.length; i++) {
-        const t = types[i];
-        flags |= t.flags;
-        if (!(t.flags & 98304 /* Nullable */)) {
-          if (t.flags & (512 /* BooleanLiteral */ | 1056 /* EnumLike */)) {
-            const baseType = t.flags & 512 /* BooleanLiteral */ ? booleanType : getBaseTypeOfEnumLikeType(t);
-            if (baseType.flags & 1048576 /* Union */) {
-              const count = baseType.types.length;
-              if (i + count <= types.length && getRegularTypeOfLiteralType(types[i + count - 1]) === getRegularTypeOfLiteralType(baseType.types[count - 1])) {
-                result.push(baseType);
-                i += count - 1;
-                continue;
-              }
-            }
-          }
-          result.push(t);
-        }
-      }
-      if (flags & 65536 /* Null */)
-        result.push(nullType);
-      if (flags & 32768 /* Undefined */)
-        result.push(undefinedType);
-      return result || types;
-    }
-    function visibilityToString(flags) {
-      if (flags === 8 /* Private */) {
-        return "private";
-      }
-      if (flags === 16 /* Protected */) {
-        return "protected";
-      }
-      return "public";
-    }
-    function getTypeAliasForTypeLiteral(type) {
-      if (type.symbol && type.symbol.flags & 2048 /* TypeLiteral */ && type.symbol.declarations) {
-        const node = walkUpParenthesizedTypes(type.symbol.declarations[0].parent);
-        if (isTypeAliasDeclaration(node)) {
-          return getSymbolOfDeclaration(node);
-        }
-      }
-      return void 0;
-    }
-    function isTopLevelInExternalModuleAugmentation(node) {
-      return node && node.parent && node.parent.kind === 267 /* ModuleBlock */ && isExternalModuleAugmentation(node.parent.parent);
-    }
-    function isDefaultBindingContext(location) {
-      return location.kind === 311 /* SourceFile */ || isAmbientModule(location);
-    }
-    function getNameOfSymbolFromNameType(symbol, context) {
-      const nameType = getSymbolLinks(symbol).nameType;
-      if (nameType) {
-        if (nameType.flags & 384 /* StringOrNumberLiteral */) {
-          const name = "" + nameType.value;
-          if (!isIdentifierText(name, getEmitScriptTarget(compilerOptions)) && !isNumericLiteralName(name)) {
-            return `"${escapeString(name, 34 /* doubleQuote */)}"`;
-          }
-          if (isNumericLiteralName(name) && startsWith(name, "-")) {
-            return `[${name}]`;
-          }
-          return name;
-        }
-        if (nameType.flags & 8192 /* UniqueESSymbol */) {
-          return `[${getNameOfSymbolAsWritten(nameType.symbol, context)}]`;
-        }
-      }
-    }
-    function getNameOfSymbolAsWritten(symbol, context) {
-      if (context && symbol.escapedName === "default" /* Default */ && !(context.flags & 16384 /* UseAliasDefinedOutsideCurrentScope */) && // If it's not the first part of an entity name, it must print as `default`
-      (!(context.flags & 16777216 /* InInitialEntityName */) || // if the symbol is synthesized, it will only be referenced externally it must print as `default`
-      !symbol.declarations || // if not in the same binding context (source file, module declaration), it must print as `default`
-      context.enclosingDeclaration && findAncestor(symbol.declarations[0], isDefaultBindingContext) !== findAncestor(context.enclosingDeclaration, isDefaultBindingContext))) {
-        return "default";
-      }
-      if (symbol.declarations && symbol.declarations.length) {
-        let declaration = firstDefined(symbol.declarations, (d) => getNameOfDeclaration(d) ? d : void 0);
-        const name2 = declaration && getNameOfDeclaration(declaration);
-        if (declaration && name2) {
-          if (isCallExpression(declaration) && isBindableObjectDefinePropertyCall(declaration)) {
-            return symbolName(symbol);
-          }
-          if (isComputedPropertyName(name2) && !(getCheckFlags(symbol) & 4096 /* Late */)) {
-            const nameType = getSymbolLinks(symbol).nameType;
-            if (nameType && nameType.flags & 384 /* StringOrNumberLiteral */) {
-              const result = getNameOfSymbolFromNameType(symbol, context);
-              if (result !== void 0) {
-                return result;
-              }
-            }
-          }
-          return declarationNameToString(name2);
-        }
-        if (!declaration) {
-          declaration = symbol.declarations[0];
-        }
-        if (declaration.parent && declaration.parent.kind === 259 /* VariableDeclaration */) {
-          return declarationNameToString(declaration.parent.name);
-        }
-        switch (declaration.kind) {
-          case 230 /* ClassExpression */:
-          case 217 /* FunctionExpression */:
-          case 218 /* ArrowFunction */:
-            if (context && !context.encounteredError && !(context.flags & 131072 /* AllowAnonymousIdentifier */)) {
-              context.encounteredError = true;
-            }
-            return declaration.kind === 230 /* ClassExpression */ ? "(Anonymous class)" : "(Anonymous function)";
-        }
-      }
-      const name = getNameOfSymbolFromNameType(symbol, context);
-      return name !== void 0 ? name : symbolName(symbol);
-    }
-    function isDeclarationVisible(node) {
-      if (node) {
-        const links = getNodeLinks(node);
-        if (links.isVisible === void 0) {
-          links.isVisible = !!determineIfDeclarationIsVisible();
-        }
-        return links.isVisible;
-      }
-      return false;
-      function determineIfDeclarationIsVisible() {
-        switch (node.kind) {
-          case 344 /* JSDocCallbackTag */:
-          case 352 /* JSDocTypedefTag */:
-          case 346 /* JSDocEnumTag */:
-            return !!(node.parent && node.parent.parent && node.parent.parent.parent && isSourceFile(node.parent.parent.parent));
-          case 207 /* BindingElement */:
-            return isDeclarationVisible(node.parent.parent);
-          case 259 /* VariableDeclaration */:
-            if (isBindingPattern(node.name) && !node.name.elements.length) {
-              return false;
-            }
-          case 266 /* ModuleDeclaration */:
-          case 262 /* ClassDeclaration */:
-          case 263 /* InterfaceDeclaration */:
-          case 264 /* TypeAliasDeclaration */:
-          case 261 /* FunctionDeclaration */:
-          case 265 /* EnumDeclaration */:
-          case 270 /* ImportEqualsDeclaration */:
-            if (isExternalModuleAugmentation(node)) {
-              return true;
-            }
-            const parent2 = getDeclarationContainer(node);
-            if (!(getCombinedModifierFlags(node) & 1 /* Export */) && !(node.kind !== 270 /* ImportEqualsDeclaration */ && parent2.kind !== 311 /* SourceFile */ && parent2.flags & 16777216 /* Ambient */)) {
-              return isGlobalSourceFile(parent2);
-            }
-            return isDeclarationVisible(parent2);
-          case 171 /* PropertyDeclaration */:
-          case 170 /* PropertySignature */:
-          case 176 /* GetAccessor */:
-          case 177 /* SetAccessor */:
-          case 173 /* MethodDeclaration */:
-          case 172 /* MethodSignature */:
-            if (hasEffectiveModifier(node, 8 /* Private */ | 16 /* Protected */)) {
-              return false;
-            }
-          case 175 /* Constructor */:
-          case 179 /* ConstructSignature */:
-          case 178 /* CallSignature */:
-          case 180 /* IndexSignature */:
-          case 168 /* Parameter */:
-          case 267 /* ModuleBlock */:
-          case 183 /* FunctionType */:
-          case 184 /* ConstructorType */:
-          case 186 /* TypeLiteral */:
-          case 182 /* TypeReference */:
-          case 187 /* ArrayType */:
-          case 188 /* TupleType */:
-          case 191 /* UnionType */:
-          case 192 /* IntersectionType */:
-          case 195 /* ParenthesizedType */:
-          case 201 /* NamedTupleMember */:
-            return isDeclarationVisible(node.parent);
-          case 272 /* ImportClause */:
-          case 273 /* NamespaceImport */:
-          case 275 /* ImportSpecifier */:
-            return false;
-          case 167 /* TypeParameter */:
-          case 311 /* SourceFile */:
-          case 269 /* NamespaceExportDeclaration */:
-            return true;
-          case 276 /* ExportAssignment */:
-            return false;
-          default:
-            return false;
-        }
-      }
-    }
-    function collectLinkedAliases(node, setVisibility) {
-      let exportSymbol;
-      if (node.parent && node.parent.kind === 276 /* ExportAssignment */) {
-        exportSymbol = resolveName(
-          node,
-          node.escapedText,
-          111551 /* Value */ | 788968 /* Type */ | 1920 /* Namespace */ | 2097152 /* Alias */,
-          /*nameNotFoundMessage*/
-          void 0,
-          node,
-          /*isUse*/
-          false
-        );
-      } else if (node.parent.kind === 280 /* ExportSpecifier */) {
-        exportSymbol = getTargetOfExportSpecifier(node.parent, 111551 /* Value */ | 788968 /* Type */ | 1920 /* Namespace */ | 2097152 /* Alias */);
-      }
-      let result;
-      let visited;
-      if (exportSymbol) {
-        visited = /* @__PURE__ */ new Set();
-        visited.add(getSymbolId(exportSymbol));
-        buildVisibleNodeList(exportSymbol.declarations);
-      }
-      return result;
-      function buildVisibleNodeList(declarations) {
-        forEach(declarations, (declaration) => {
-          const resultNode = getAnyImportSyntax(declaration) || declaration;
-          if (setVisibility) {
-            getNodeLinks(declaration).isVisible = true;
-          } else {
-            result = result || [];
-            pushIfUnique(result, resultNode);
-          }
-          if (isInternalModuleImportEqualsDeclaration(declaration)) {
-            const internalModuleReference = declaration.moduleReference;
-            const firstIdentifier = getFirstIdentifier(internalModuleReference);
-            const importSymbol = resolveName(
-              declaration,
-              firstIdentifier.escapedText,
-              111551 /* Value */ | 788968 /* Type */ | 1920 /* Namespace */,
-              /*nameNotFoundMessage*/
-              void 0,
-              /*nameArg*/
-              void 0,
-              /*isUse*/
-              false
-            );
-            if (importSymbol && visited) {
-              if (tryAddToSet(visited, getSymbolId(importSymbol))) {
-                buildVisibleNodeList(importSymbol.declarations);
-              }
-            }
-          }
-        });
-      }
-    }
-    function pushTypeResolution(target, propertyName) {
-      const resolutionCycleStartIndex = findResolutionCycleStartIndex(target, propertyName);
-      if (resolutionCycleStartIndex >= 0) {
-        const { length: length2 } = resolutionTargets;
-        for (let i = resolutionCycleStartIndex; i < length2; i++) {
-          resolutionResults[i] = false;
-        }
-        return false;
-      }
-      resolutionTargets.push(target);
-      resolutionResults.push(
-        /*items*/
-        true
-      );
-      resolutionPropertyNames.push(propertyName);
-      return true;
-    }
-    function findResolutionCycleStartIndex(target, propertyName) {
-      for (let i = resolutionTargets.length - 1; i >= resolutionStart; i--) {
-        if (resolutionTargetHasProperty(resolutionTargets[i], resolutionPropertyNames[i])) {
-          return -1;
-        }
-        if (resolutionTargets[i] === target && resolutionPropertyNames[i] === propertyName) {
-          return i;
-        }
-      }
-      return -1;
-    }
-    function resolutionTargetHasProperty(target, propertyName) {
-      switch (propertyName) {
-        case 0 /* Type */:
-          return !!getSymbolLinks(target).type;
-        case 5 /* EnumTagType */:
-          return !!getNodeLinks(target).resolvedEnumType;
-        case 2 /* DeclaredType */:
-          return !!getSymbolLinks(target).declaredType;
-        case 1 /* ResolvedBaseConstructorType */:
-          return !!target.resolvedBaseConstructorType;
-        case 3 /* ResolvedReturnType */:
-          return !!target.resolvedReturnType;
-        case 4 /* ImmediateBaseConstraint */:
-          return !!target.immediateBaseConstraint;
-        case 6 /* ResolvedTypeArguments */:
-          return !!target.resolvedTypeArguments;
-        case 7 /* ResolvedBaseTypes */:
-          return !!target.baseTypesResolved;
-        case 8 /* WriteType */:
-          return !!getSymbolLinks(target).writeType;
-        case 9 /* ParameterInitializerContainsUndefined */:
-          return getNodeLinks(target).parameterInitializerContainsUndefined !== void 0;
-      }
-      return Debug.assertNever(propertyName);
-    }
-    function popTypeResolution() {
-      resolutionTargets.pop();
-      resolutionPropertyNames.pop();
-      return resolutionResults.pop();
-    }
-    function getDeclarationContainer(node) {
-      return findAncestor(getRootDeclaration(node), (node2) => {
-        switch (node2.kind) {
-          case 259 /* VariableDeclaration */:
-          case 260 /* VariableDeclarationList */:
-          case 275 /* ImportSpecifier */:
-          case 274 /* NamedImports */:
-          case 273 /* NamespaceImport */:
-          case 272 /* ImportClause */:
-            return false;
-          default:
-            return true;
-        }
-      }).parent;
-    }
-    function getTypeOfPrototypeProperty(prototype) {
-      const classType = getDeclaredTypeOfSymbol(getParentOfSymbol(prototype));
-      return classType.typeParameters ? createTypeReference(classType, map(classType.typeParameters, (_) => anyType)) : classType;
-    }
-    function getTypeOfPropertyOfType(type, name) {
-      const prop = getPropertyOfType(type, name);
-      return prop ? getTypeOfSymbol(prop) : void 0;
-    }
-    function getTypeOfPropertyOrIndexSignature(type, name) {
-      var _a;
-      return getTypeOfPropertyOfType(type, name) || ((_a = getApplicableIndexInfoForName(type, name)) == null ? void 0 : _a.type) || unknownType;
-    }
-    function isTypeAny(type) {
-      return type && (type.flags & 1 /* Any */) !== 0;
-    }
-    function isErrorType(type) {
-      return type === errorType || !!(type.flags & 1 /* Any */ && type.aliasSymbol);
-    }
-    function getTypeForBindingElementParent(node, checkMode) {
-      if (checkMode !== 0 /* Normal */) {
-        return getTypeForVariableLikeDeclaration(
-          node,
-          /*includeOptionality*/
-          false,
-          checkMode
-        );
-      }
-      const symbol = getSymbolOfDeclaration(node);
-      return symbol && getSymbolLinks(symbol).type || getTypeForVariableLikeDeclaration(
-        node,
-        /*includeOptionality*/
-        false,
-        checkMode
-      );
-    }
-    function getRestType(source, properties, symbol) {
-      source = filterType(source, (t) => !(t.flags & 98304 /* Nullable */));
-      if (source.flags & 131072 /* Never */) {
-        return emptyObjectType;
-      }
-      if (source.flags & 1048576 /* Union */) {
-        return mapType(source, (t) => getRestType(t, properties, symbol));
-      }
-      let omitKeyType = getUnionType(map(properties, getLiteralTypeFromPropertyName));
-      const spreadableProperties = [];
-      const unspreadableToRestKeys = [];
-      for (const prop of getPropertiesOfType(source)) {
-        const literalTypeFromProperty = getLiteralTypeFromProperty(prop, 8576 /* StringOrNumberLiteralOrUnique */);
-        if (!isTypeAssignableTo(literalTypeFromProperty, omitKeyType) && !(getDeclarationModifierFlagsFromSymbol(prop) & (8 /* Private */ | 16 /* Protected */)) && isSpreadableProperty(prop)) {
-          spreadableProperties.push(prop);
-        } else {
-          unspreadableToRestKeys.push(literalTypeFromProperty);
-        }
-      }
-      if (isGenericObjectType(source) || isGenericIndexType(omitKeyType)) {
-        if (unspreadableToRestKeys.length) {
-          omitKeyType = getUnionType([omitKeyType, ...unspreadableToRestKeys]);
-        }
-        if (omitKeyType.flags & 131072 /* Never */) {
-          return source;
-        }
-        const omitTypeAlias = getGlobalOmitSymbol();
-        if (!omitTypeAlias) {
-          return errorType;
-        }
-        return getTypeAliasInstantiation(omitTypeAlias, [source, omitKeyType]);
-      }
-      const members = createSymbolTable();
-      for (const prop of spreadableProperties) {
-        members.set(prop.escapedName, getSpreadSymbol(
-          prop,
-          /*readonly*/
-          false
-        ));
-      }
-      const result = createAnonymousType(symbol, members, emptyArray, emptyArray, getIndexInfosOfType(source));
-      result.objectFlags |= 4194304 /* ObjectRestType */;
-      return result;
-    }
-    function isGenericTypeWithUndefinedConstraint(type) {
-      return !!(type.flags & 465829888 /* Instantiable */) && maybeTypeOfKind(getBaseConstraintOfType(type) || unknownType, 32768 /* Undefined */);
-    }
-    function getNonUndefinedType(type) {
-      const typeOrConstraint = someType(type, isGenericTypeWithUndefinedConstraint) ? mapType(type, (t) => t.flags & 465829888 /* Instantiable */ ? getBaseConstraintOrType(t) : t) : type;
-      return getTypeWithFacts(typeOrConstraint, 524288 /* NEUndefined */);
-    }
-    function getFlowTypeOfDestructuring(node, declaredType) {
-      const reference = getSyntheticElementAccess(node);
-      return reference ? getFlowTypeOfReference(reference, declaredType) : declaredType;
-    }
-    function getSyntheticElementAccess(node) {
-      const parentAccess = getParentElementAccess(node);
-      if (parentAccess && canHaveFlowNode(parentAccess) && parentAccess.flowNode) {
-        const propName = getDestructuringPropertyName(node);
-        if (propName) {
-          const literal = setTextRange(parseNodeFactory.createStringLiteral(propName), node);
-          const lhsExpr = isLeftHandSideExpression(parentAccess) ? parentAccess : parseNodeFactory.createParenthesizedExpression(parentAccess);
-          const result = setTextRange(parseNodeFactory.createElementAccessExpression(lhsExpr, literal), node);
-          setParent(literal, result);
-          setParent(result, node);
-          if (lhsExpr !== parentAccess) {
-            setParent(lhsExpr, result);
-          }
-          result.flowNode = parentAccess.flowNode;
-          return result;
-        }
-      }
-    }
-    function getParentElementAccess(node) {
-      const ancestor = node.parent.parent;
-      switch (ancestor.kind) {
-        case 207 /* BindingElement */:
-        case 302 /* PropertyAssignment */:
-          return getSyntheticElementAccess(ancestor);
-        case 208 /* ArrayLiteralExpression */:
-          return getSyntheticElementAccess(node.parent);
-        case 259 /* VariableDeclaration */:
-          return ancestor.initializer;
-        case 225 /* BinaryExpression */:
-          return ancestor.right;
-      }
-    }
-    function getDestructuringPropertyName(node) {
-      const parent2 = node.parent;
-      if (node.kind === 207 /* BindingElement */ && parent2.kind === 205 /* ObjectBindingPattern */) {
-        return getLiteralPropertyNameText(node.propertyName || node.name);
-      }
-      if (node.kind === 302 /* PropertyAssignment */ || node.kind === 303 /* ShorthandPropertyAssignment */) {
-        return getLiteralPropertyNameText(node.name);
-      }
-      return "" + parent2.elements.indexOf(node);
-    }
-    function getLiteralPropertyNameText(name) {
-      const type = getLiteralTypeFromPropertyName(name);
-      return type.flags & (128 /* StringLiteral */ | 256 /* NumberLiteral */) ? "" + type.value : void 0;
-    }
-    function getTypeForBindingElement(declaration) {
-      const checkMode = declaration.dotDotDotToken ? 64 /* RestBindingElement */ : 0 /* Normal */;
-      const parentType = getTypeForBindingElementParent(declaration.parent.parent, checkMode);
-      return parentType && getBindingElementTypeFromParentType(declaration, parentType);
-    }
-    function getBindingElementTypeFromParentType(declaration, parentType) {
-      if (isTypeAny(parentType)) {
-        return parentType;
-      }
-      const pattern = declaration.parent;
-      if (strictNullChecks && declaration.flags & 16777216 /* Ambient */ && isParameterDeclaration(declaration)) {
-        parentType = getNonNullableType(parentType);
-      } else if (strictNullChecks && pattern.parent.initializer && !(getTypeFacts(getTypeOfInitializer(pattern.parent.initializer)) & 65536 /* EQUndefined */)) {
-        parentType = getTypeWithFacts(parentType, 524288 /* NEUndefined */);
-      }
-      let type;
-      if (pattern.kind === 205 /* ObjectBindingPattern */) {
-        if (declaration.dotDotDotToken) {
-          parentType = getReducedType(parentType);
-          if (parentType.flags & 2 /* Unknown */ || !isValidSpreadType(parentType)) {
-            error(declaration, Diagnostics.Rest_types_may_only_be_created_from_object_types);
-            return errorType;
-          }
-          const literalMembers = [];
-          for (const element of pattern.elements) {
-            if (!element.dotDotDotToken) {
-              literalMembers.push(element.propertyName || element.name);
-            }
-          }
-          type = getRestType(parentType, literalMembers, declaration.symbol);
-        } else {
-          const name = declaration.propertyName || declaration.name;
-          const indexType = getLiteralTypeFromPropertyName(name);
-          const declaredType = getIndexedAccessType(parentType, indexType, 32 /* ExpressionPosition */, name);
-          type = getFlowTypeOfDestructuring(declaration, declaredType);
-        }
-      } else {
-        const elementType = checkIteratedTypeOrElementType(65 /* Destructuring */ | (declaration.dotDotDotToken ? 0 : 128 /* PossiblyOutOfBounds */), parentType, undefinedType, pattern);
-        const index = pattern.elements.indexOf(declaration);
-        if (declaration.dotDotDotToken) {
-          const baseConstraint = mapType(parentType, (t) => t.flags & 58982400 /* InstantiableNonPrimitive */ ? getBaseConstraintOrType(t) : t);
-          type = everyType(baseConstraint, isTupleType) ? mapType(baseConstraint, (t) => sliceTupleType(t, index)) : createArrayType(elementType);
-        } else if (isArrayLikeType(parentType)) {
-          const indexType = getNumberLiteralType(index);
-          const accessFlags = 32 /* ExpressionPosition */ | (hasDefaultValue(declaration) ? 16 /* NoTupleBoundsCheck */ : 0);
-          const declaredType = getIndexedAccessTypeOrUndefined(parentType, indexType, accessFlags, declaration.name) || errorType;
-          type = getFlowTypeOfDestructuring(declaration, declaredType);
-        } else {
-          type = elementType;
-        }
-      }
-      if (!declaration.initializer) {
-        return type;
-      }
-      if (getEffectiveTypeAnnotationNode(walkUpBindingElementsAndPatterns(declaration))) {
-        return strictNullChecks && !(getTypeFacts(checkDeclarationInitializer(declaration, 0 /* Normal */)) & 16777216 /* IsUndefined */) ? getNonUndefinedType(type) : type;
-      }
-      return widenTypeInferredFromInitializer(declaration, getUnionType([getNonUndefinedType(type), checkDeclarationInitializer(declaration, 0 /* Normal */)], 2 /* Subtype */));
-    }
-    function getTypeForDeclarationFromJSDocComment(declaration) {
-      const jsdocType = getJSDocType(declaration);
-      if (jsdocType) {
-        return getTypeFromTypeNode(jsdocType);
-      }
-      return void 0;
-    }
-    function isNullOrUndefined3(node) {
-      const expr = skipParentheses(
-        node,
-        /*excludeJSDocTypeAssertions*/
-        true
-      );
-      return expr.kind === 106 /* NullKeyword */ || expr.kind === 80 /* Identifier */ && getResolvedSymbol(expr) === undefinedSymbol;
-    }
-    function isEmptyArrayLiteral2(node) {
-      const expr = skipParentheses(
-        node,
-        /*excludeJSDocTypeAssertions*/
-        true
-      );
-      return expr.kind === 208 /* ArrayLiteralExpression */ && expr.elements.length === 0;
-    }
-    function addOptionality(type, isProperty = false, isOptional = true) {
-      return strictNullChecks && isOptional ? getOptionalType(type, isProperty) : type;
-    }
-    function getTypeForVariableLikeDeclaration(declaration, includeOptionality, checkMode) {
-      if (isVariableDeclaration(declaration) && declaration.parent.parent.kind === 248 /* ForInStatement */) {
-        const indexType = getIndexType(getNonNullableTypeIfNeeded(checkExpression(
-          declaration.parent.parent.expression,
-          /*checkMode*/
-          checkMode
-        )));
-        return indexType.flags & (262144 /* TypeParameter */ | 4194304 /* Index */) ? getExtractStringType(indexType) : stringType;
-      }
-      if (isVariableDeclaration(declaration) && declaration.parent.parent.kind === 249 /* ForOfStatement */) {
-        const forOfStatement = declaration.parent.parent;
-        return checkRightHandSideOfForOf(forOfStatement) || anyType;
-      }
-      if (isBindingPattern(declaration.parent)) {
-        return getTypeForBindingElement(declaration);
-      }
-      const isProperty = isPropertyDeclaration(declaration) && !hasAccessorModifier(declaration) || isPropertySignature(declaration) || isJSDocPropertyTag(declaration);
-      const isOptional = includeOptionality && isOptionalDeclaration(declaration);
-      const declaredType = tryGetTypeFromEffectiveTypeNode(declaration);
-      if (isCatchClauseVariableDeclarationOrBindingElement(declaration)) {
-        if (declaredType) {
-          return isTypeAny(declaredType) || declaredType === unknownType ? declaredType : errorType;
-        }
-        return useUnknownInCatchVariables ? unknownType : anyType;
-      }
-      if (declaredType) {
-        return addOptionality(declaredType, isProperty, isOptional);
-      }
-      if ((noImplicitAny || isInJSFile(declaration)) && isVariableDeclaration(declaration) && !isBindingPattern(declaration.name) && !(getCombinedModifierFlags(declaration) & 1 /* Export */) && !(declaration.flags & 16777216 /* Ambient */)) {
-        if (!(getCombinedNodeFlags(declaration) & 2 /* Const */) && (!declaration.initializer || isNullOrUndefined3(declaration.initializer))) {
-          return autoType;
-        }
-        if (declaration.initializer && isEmptyArrayLiteral2(declaration.initializer)) {
-          return autoArrayType;
-        }
-      }
-      if (isParameter(declaration)) {
-        const func = declaration.parent;
-        if (func.kind === 177 /* SetAccessor */ && hasBindableName(func)) {
-          const getter = getDeclarationOfKind(getSymbolOfDeclaration(declaration.parent), 176 /* GetAccessor */);
-          if (getter) {
-            const getterSignature = getSignatureFromDeclaration(getter);
-            const thisParameter = getAccessorThisParameter(func);
-            if (thisParameter && declaration === thisParameter) {
-              Debug.assert(!thisParameter.type);
-              return getTypeOfSymbol(getterSignature.thisParameter);
-            }
-            return getReturnTypeOfSignature(getterSignature);
-          }
-        }
-        const parameterTypeOfTypeTag = getParameterTypeOfTypeTag(func, declaration);
-        if (parameterTypeOfTypeTag)
-          return parameterTypeOfTypeTag;
-        const type = declaration.symbol.escapedName === "this" /* This */ ? getContextualThisParameterType(func) : getContextuallyTypedParameterType(declaration);
-        if (type) {
-          return addOptionality(
-            type,
-            /*isProperty*/
-            false,
-            isOptional
-          );
-        }
-      }
-      if (hasOnlyExpressionInitializer(declaration) && !!declaration.initializer) {
-        if (isInJSFile(declaration) && !isParameter(declaration)) {
-          const containerObjectType = getJSContainerObjectType(declaration, getSymbolOfDeclaration(declaration), getDeclaredExpandoInitializer(declaration));
-          if (containerObjectType) {
-            return containerObjectType;
-          }
-        }
-        const type = widenTypeInferredFromInitializer(declaration, checkDeclarationInitializer(declaration, checkMode));
-        return addOptionality(type, isProperty, isOptional);
-      }
-      if (isPropertyDeclaration(declaration) && (noImplicitAny || isInJSFile(declaration))) {
-        if (!hasStaticModifier(declaration)) {
-          const constructor = findConstructorDeclaration(declaration.parent);
-          const type = constructor ? getFlowTypeInConstructor(declaration.symbol, constructor) : getEffectiveModifierFlags(declaration) & 2 /* Ambient */ ? getTypeOfPropertyInBaseClass(declaration.symbol) : void 0;
-          return type && addOptionality(
-            type,
-            /*isProperty*/
-            true,
-            isOptional
-          );
-        } else {
-          const staticBlocks = filter(declaration.parent.members, isClassStaticBlockDeclaration);
-          const type = staticBlocks.length ? getFlowTypeInStaticBlocks(declaration.symbol, staticBlocks) : getEffectiveModifierFlags(declaration) & 2 /* Ambient */ ? getTypeOfPropertyInBaseClass(declaration.symbol) : void 0;
-          return type && addOptionality(
-            type,
-            /*isProperty*/
-            true,
-            isOptional
-          );
-        }
-      }
-      if (isJsxAttribute(declaration)) {
-        return trueType;
-      }
-      if (isBindingPattern(declaration.name)) {
-        return getTypeFromBindingPattern(
-          declaration.name,
-          /*includePatternInType*/
-          false,
-          /*reportErrors*/
-          true
-        );
-      }
-      return void 0;
-    }
-    function isConstructorDeclaredProperty(symbol) {
-      if (symbol.valueDeclaration && isBinaryExpression(symbol.valueDeclaration)) {
-        const links = getSymbolLinks(symbol);
-        if (links.isConstructorDeclaredProperty === void 0) {
-          links.isConstructorDeclaredProperty = false;
-          links.isConstructorDeclaredProperty = !!getDeclaringConstructor(symbol) && every(symbol.declarations, (declaration) => isBinaryExpression(declaration) && isPossiblyAliasedThisProperty(declaration) && (declaration.left.kind !== 211 /* ElementAccessExpression */ || isStringOrNumericLiteralLike(declaration.left.argumentExpression)) && !getAnnotatedTypeForAssignmentDeclaration(
-            /*declaredType*/
-            void 0,
-            declaration,
-            symbol,
-            declaration
-          ));
-        }
-        return links.isConstructorDeclaredProperty;
-      }
-      return false;
-    }
-    function isAutoTypedProperty(symbol) {
-      const declaration = symbol.valueDeclaration;
-      return declaration && isPropertyDeclaration(declaration) && !getEffectiveTypeAnnotationNode(declaration) && !declaration.initializer && (noImplicitAny || isInJSFile(declaration));
-    }
-    function getDeclaringConstructor(symbol) {
-      if (!symbol.declarations) {
-        return;
-      }
-      for (const declaration of symbol.declarations) {
-        const container = getThisContainer(
-          declaration,
-          /*includeArrowFunctions*/
-          false,
-          /*includeClassComputedPropertyName*/
-          false
-        );
-        if (container && (container.kind === 175 /* Constructor */ || isJSConstructor(container))) {
-          return container;
-        }
-      }
-    }
-    function getFlowTypeFromCommonJSExport(symbol) {
-      const file = getSourceFileOfNode(symbol.declarations[0]);
-      const accessName = unescapeLeadingUnderscores(symbol.escapedName);
-      const areAllModuleExports = symbol.declarations.every((d) => isInJSFile(d) && isAccessExpression(d) && isModuleExportsAccessExpression(d.expression));
-      const reference = areAllModuleExports ? factory.createPropertyAccessExpression(factory.createPropertyAccessExpression(factory.createIdentifier("module"), factory.createIdentifier("exports")), accessName) : factory.createPropertyAccessExpression(factory.createIdentifier("exports"), accessName);
-      if (areAllModuleExports) {
-        setParent(reference.expression.expression, reference.expression);
-      }
-      setParent(reference.expression, reference);
-      setParent(reference, file);
-      reference.flowNode = file.endFlowNode;
-      return getFlowTypeOfReference(reference, autoType, undefinedType);
-    }
-    function getFlowTypeInStaticBlocks(symbol, staticBlocks) {
-      const accessName = startsWith(symbol.escapedName, "__#") ? factory.createPrivateIdentifier(symbol.escapedName.split("@")[1]) : unescapeLeadingUnderscores(symbol.escapedName);
-      for (const staticBlock of staticBlocks) {
-        const reference = factory.createPropertyAccessExpression(factory.createThis(), accessName);
-        setParent(reference.expression, reference);
-        setParent(reference, staticBlock);
-        reference.flowNode = staticBlock.returnFlowNode;
-        const flowType = getFlowTypeOfProperty(reference, symbol);
-        if (noImplicitAny && (flowType === autoType || flowType === autoArrayType)) {
-          error(symbol.valueDeclaration, Diagnostics.Member_0_implicitly_has_an_1_type, symbolToString(symbol), typeToString(flowType));
-        }
-        if (everyType(flowType, isNullableType)) {
-          continue;
-        }
-        return convertAutoToAny(flowType);
-      }
-    }
-    function getFlowTypeInConstructor(symbol, constructor) {
-      const accessName = startsWith(symbol.escapedName, "__#") ? factory.createPrivateIdentifier(symbol.escapedName.split("@")[1]) : unescapeLeadingUnderscores(symbol.escapedName);
-      const reference = factory.createPropertyAccessExpression(factory.createThis(), accessName);
-      setParent(reference.expression, reference);
-      setParent(reference, constructor);
-      reference.flowNode = constructor.returnFlowNode;
-      const flowType = getFlowTypeOfProperty(reference, symbol);
-      if (noImplicitAny && (flowType === autoType || flowType === autoArrayType)) {
-        error(symbol.valueDeclaration, Diagnostics.Member_0_implicitly_has_an_1_type, symbolToString(symbol), typeToString(flowType));
-      }
-      return everyType(flowType, isNullableType) ? void 0 : convertAutoToAny(flowType);
-    }
-    function getFlowTypeOfProperty(reference, prop) {
-      const initialType = (prop == null ? void 0 : prop.valueDeclaration) && (!isAutoTypedProperty(prop) || getEffectiveModifierFlags(prop.valueDeclaration) & 2 /* Ambient */) && getTypeOfPropertyInBaseClass(prop) || undefinedType;
-      return getFlowTypeOfReference(reference, autoType, initialType);
-    }
-    function getWidenedTypeForAssignmentDeclaration(symbol, resolvedSymbol) {
-      const container = getAssignedExpandoInitializer(symbol.valueDeclaration);
-      if (container) {
-        const tag = isInJSFile(container) ? getJSDocTypeTag(container) : void 0;
-        if (tag && tag.typeExpression) {
-          return getTypeFromTypeNode(tag.typeExpression);
-        }
-        const containerObjectType = symbol.valueDeclaration && getJSContainerObjectType(symbol.valueDeclaration, symbol, container);
-        return containerObjectType || getWidenedLiteralType(checkExpressionCached(container));
-      }
-      let type;
-      let definedInConstructor = false;
-      let definedInMethod = false;
-      if (isConstructorDeclaredProperty(symbol)) {
-        type = getFlowTypeInConstructor(symbol, getDeclaringConstructor(symbol));
-      }
-      if (!type) {
-        let types;
-        if (symbol.declarations) {
-          let jsdocType;
-          for (const declaration of symbol.declarations) {
-            const expression = isBinaryExpression(declaration) || isCallExpression(declaration) ? declaration : isAccessExpression(declaration) ? isBinaryExpression(declaration.parent) ? declaration.parent : declaration : void 0;
-            if (!expression) {
-              continue;
-            }
-            const kind = isAccessExpression(expression) ? getAssignmentDeclarationPropertyAccessKind(expression) : getAssignmentDeclarationKind(expression);
-            if (kind === 4 /* ThisProperty */ || isBinaryExpression(expression) && isPossiblyAliasedThisProperty(expression, kind)) {
-              if (isDeclarationInConstructor(expression)) {
-                definedInConstructor = true;
-              } else {
-                definedInMethod = true;
-              }
-            }
-            if (!isCallExpression(expression)) {
-              jsdocType = getAnnotatedTypeForAssignmentDeclaration(jsdocType, expression, symbol, declaration);
-            }
-            if (!jsdocType) {
-              (types || (types = [])).push(isBinaryExpression(expression) || isCallExpression(expression) ? getInitializerTypeFromAssignmentDeclaration(symbol, resolvedSymbol, expression, kind) : neverType);
-            }
-          }
-          type = jsdocType;
-        }
-        if (!type) {
-          if (!length(types)) {
-            return errorType;
-          }
-          let constructorTypes = definedInConstructor && symbol.declarations ? getConstructorDefinedThisAssignmentTypes(types, symbol.declarations) : void 0;
-          if (definedInMethod) {
-            const propType = getTypeOfPropertyInBaseClass(symbol);
-            if (propType) {
-              (constructorTypes || (constructorTypes = [])).push(propType);
-              definedInConstructor = true;
-            }
-          }
-          const sourceTypes = some(constructorTypes, (t) => !!(t.flags & ~98304 /* Nullable */)) ? constructorTypes : types;
-          type = getUnionType(sourceTypes);
-        }
-      }
-      const widened = getWidenedType(addOptionality(
-        type,
-        /*isProperty*/
-        false,
-        definedInMethod && !definedInConstructor
-      ));
-      if (symbol.valueDeclaration && filterType(widened, (t) => !!(t.flags & ~98304 /* Nullable */)) === neverType) {
-        reportImplicitAny(symbol.valueDeclaration, anyType);
-        return anyType;
-      }
-      return widened;
-    }
-    function getJSContainerObjectType(decl, symbol, init) {
-      var _a, _b;
-      if (!isInJSFile(decl) || !init || !isObjectLiteralExpression(init) || init.properties.length) {
-        return void 0;
-      }
-      const exports = createSymbolTable();
-      while (isBinaryExpression(decl) || isPropertyAccessExpression(decl)) {
-        const s2 = getSymbolOfNode(decl);
-        if ((_a = s2 == null ? void 0 : s2.exports) == null ? void 0 : _a.size) {
-          mergeSymbolTable(exports, s2.exports);
-        }
-        decl = isBinaryExpression(decl) ? decl.parent : decl.parent.parent;
-      }
-      const s = getSymbolOfNode(decl);
-      if ((_b = s == null ? void 0 : s.exports) == null ? void 0 : _b.size) {
-        mergeSymbolTable(exports, s.exports);
-      }
-      const type = createAnonymousType(symbol, exports, emptyArray, emptyArray, emptyArray);
-      type.objectFlags |= 4096 /* JSLiteral */;
-      return type;
-    }
-    function getAnnotatedTypeForAssignmentDeclaration(declaredType, expression, symbol, declaration) {
-      var _a;
-      const typeNode = getEffectiveTypeAnnotationNode(expression.parent);
-      if (typeNode) {
-        const type = getWidenedType(getTypeFromTypeNode(typeNode));
-        if (!declaredType) {
-          return type;
-        } else if (!isErrorType(declaredType) && !isErrorType(type) && !isTypeIdenticalTo(declaredType, type)) {
-          errorNextVariableOrPropertyDeclarationMustHaveSameType(
-            /*firstDeclaration*/
-            void 0,
-            declaredType,
-            declaration,
-            type
-          );
-        }
-      }
-      if ((_a = symbol.parent) == null ? void 0 : _a.valueDeclaration) {
-        const typeNode2 = getEffectiveTypeAnnotationNode(symbol.parent.valueDeclaration);
-        if (typeNode2) {
-          const annotationSymbol = getPropertyOfType(getTypeFromTypeNode(typeNode2), symbol.escapedName);
-          if (annotationSymbol) {
-            return getNonMissingTypeOfSymbol(annotationSymbol);
-          }
-        }
-      }
-      return declaredType;
-    }
-    function getInitializerTypeFromAssignmentDeclaration(symbol, resolvedSymbol, expression, kind) {
-      if (isCallExpression(expression)) {
-        if (resolvedSymbol) {
-          return getTypeOfSymbol(resolvedSymbol);
-        }
-        const objectLitType = checkExpressionCached(expression.arguments[2]);
-        const valueType = getTypeOfPropertyOfType(objectLitType, "value");
-        if (valueType) {
-          return valueType;
-        }
-        const getFunc = getTypeOfPropertyOfType(objectLitType, "get");
-        if (getFunc) {
-          const getSig = getSingleCallSignature(getFunc);
-          if (getSig) {
-            return getReturnTypeOfSignature(getSig);
-          }
-        }
-        const setFunc = getTypeOfPropertyOfType(objectLitType, "set");
-        if (setFunc) {
-          const setSig = getSingleCallSignature(setFunc);
-          if (setSig) {
-            return getTypeOfFirstParameterOfSignature(setSig);
-          }
-        }
-        return anyType;
-      }
-      if (containsSameNamedThisProperty(expression.left, expression.right)) {
-        return anyType;
-      }
-      const isDirectExport = kind === 1 /* ExportsProperty */ && (isPropertyAccessExpression(expression.left) || isElementAccessExpression(expression.left)) && (isModuleExportsAccessExpression(expression.left.expression) || isIdentifier(expression.left.expression) && isExportsIdentifier(expression.left.expression));
-      const type = resolvedSymbol ? getTypeOfSymbol(resolvedSymbol) : isDirectExport ? getRegularTypeOfLiteralType(checkExpressionCached(expression.right)) : getWidenedLiteralType(checkExpressionCached(expression.right));
-      if (type.flags & 524288 /* Object */ && kind === 2 /* ModuleExports */ && symbol.escapedName === "export=" /* ExportEquals */) {
-        const exportedType = resolveStructuredTypeMembers(type);
-        const members = createSymbolTable();
-        copyEntries(exportedType.members, members);
-        const initialSize = members.size;
-        if (resolvedSymbol && !resolvedSymbol.exports) {
-          resolvedSymbol.exports = createSymbolTable();
-        }
-        (resolvedSymbol || symbol).exports.forEach((s, name) => {
-          var _a;
-          const exportedMember = members.get(name);
-          if (exportedMember && exportedMember !== s && !(s.flags & 2097152 /* Alias */)) {
-            if (s.flags & 111551 /* Value */ && exportedMember.flags & 111551 /* Value */) {
-              if (s.valueDeclaration && exportedMember.valueDeclaration && getSourceFileOfNode(s.valueDeclaration) !== getSourceFileOfNode(exportedMember.valueDeclaration)) {
-                const unescapedName = unescapeLeadingUnderscores(s.escapedName);
-                const exportedMemberName = ((_a = tryCast(exportedMember.valueDeclaration, isNamedDeclaration)) == null ? void 0 : _a.name) || exportedMember.valueDeclaration;
-                addRelatedInfo(
-                  error(s.valueDeclaration, Diagnostics.Duplicate_identifier_0, unescapedName),
-                  createDiagnosticForNode(exportedMemberName, Diagnostics._0_was_also_declared_here, unescapedName)
-                );
-                addRelatedInfo(
-                  error(exportedMemberName, Diagnostics.Duplicate_identifier_0, unescapedName),
-                  createDiagnosticForNode(s.valueDeclaration, Diagnostics._0_was_also_declared_here, unescapedName)
-                );
-              }
-              const union = createSymbol(s.flags | exportedMember.flags, name);
-              union.links.type = getUnionType([getTypeOfSymbol(s), getTypeOfSymbol(exportedMember)]);
-              union.valueDeclaration = exportedMember.valueDeclaration;
-              union.declarations = concatenate(exportedMember.declarations, s.declarations);
-              members.set(name, union);
-            } else {
-              members.set(name, mergeSymbol(s, exportedMember));
-            }
-          } else {
-            members.set(name, s);
-          }
-        });
-        const result = createAnonymousType(
-          initialSize !== members.size ? void 0 : exportedType.symbol,
-          // Only set the type's symbol if it looks to be the same as the original type
-          members,
-          exportedType.callSignatures,
-          exportedType.constructSignatures,
-          exportedType.indexInfos
-        );
-        if (initialSize === members.size) {
-          if (type.aliasSymbol) {
-            result.aliasSymbol = type.aliasSymbol;
-            result.aliasTypeArguments = type.aliasTypeArguments;
-          }
-          if (getObjectFlags(type) & 4 /* Reference */) {
-            result.aliasSymbol = type.symbol;
-            const args = getTypeArguments(type);
-            result.aliasTypeArguments = length(args) ? args : void 0;
-          }
-        }
-        result.objectFlags |= getObjectFlags(type) & 4096 /* JSLiteral */;
-        if (result.symbol && result.symbol.flags & 32 /* Class */ && type === getDeclaredTypeOfClassOrInterface(result.symbol)) {
-          result.objectFlags |= 16777216 /* IsClassInstanceClone */;
-        }
-        return result;
-      }
-      if (isEmptyArrayLiteralType(type)) {
-        reportImplicitAny(expression, anyArrayType);
-        return anyArrayType;
-      }
-      return type;
-    }
-    function containsSameNamedThisProperty(thisProperty, expression) {
-      return isPropertyAccessExpression(thisProperty) && thisProperty.expression.kind === 110 /* ThisKeyword */ && forEachChildRecursively(expression, (n) => isMatchingReference(thisProperty, n));
-    }
-    function isDeclarationInConstructor(expression) {
-      const thisContainer = getThisContainer(
-        expression,
-        /*includeArrowFunctions*/
-        false,
-        /*includeClassComputedPropertyName*/
-        false
-      );
-      return thisContainer.kind === 175 /* Constructor */ || thisContainer.kind === 261 /* FunctionDeclaration */ || thisContainer.kind === 217 /* FunctionExpression */ && !isPrototypePropertyAssignment(thisContainer.parent);
-    }
-    function getConstructorDefinedThisAssignmentTypes(types, declarations) {
-      Debug.assert(types.length === declarations.length);
-      return types.filter((_, i) => {
-        const declaration = declarations[i];
-        const expression = isBinaryExpression(declaration) ? declaration : isBinaryExpression(declaration.parent) ? declaration.parent : void 0;
-        return expression && isDeclarationInConstructor(expression);
-      });
-    }
-    function getTypeFromBindingElement(element, includePatternInType, reportErrors2) {
-      if (element.initializer) {
-        const contextualType = isBindingPattern(element.name) ? getTypeFromBindingPattern(
-          element.name,
-          /*includePatternInType*/
-          true,
-          /*reportErrors*/
-          false
-        ) : unknownType;
-        return addOptionality(widenTypeInferredFromInitializer(element, checkDeclarationInitializer(element, 0 /* Normal */, contextualType)));
-      }
-      if (isBindingPattern(element.name)) {
-        return getTypeFromBindingPattern(element.name, includePatternInType, reportErrors2);
-      }
-      if (reportErrors2 && !declarationBelongsToPrivateAmbientMember(element)) {
-        reportImplicitAny(element, anyType);
-      }
-      return includePatternInType ? nonInferrableAnyType : anyType;
-    }
-    function getTypeFromObjectBindingPattern(pattern, includePatternInType, reportErrors2) {
-      const members = createSymbolTable();
-      let stringIndexInfo;
-      let objectFlags = 128 /* ObjectLiteral */ | 131072 /* ContainsObjectOrArrayLiteral */;
-      forEach(pattern.elements, (e) => {
-        const name = e.propertyName || e.name;
-        if (e.dotDotDotToken) {
-          stringIndexInfo = createIndexInfo(
-            stringType,
-            anyType,
-            /*isReadonly*/
-            false
-          );
-          return;
-        }
-        const exprType = getLiteralTypeFromPropertyName(name);
-        if (!isTypeUsableAsPropertyName(exprType)) {
-          objectFlags |= 512 /* ObjectLiteralPatternWithComputedProperties */;
-          return;
-        }
-        const text = getPropertyNameFromType(exprType);
-        const flags = 4 /* Property */ | (e.initializer ? 16777216 /* Optional */ : 0);
-        const symbol = createSymbol(flags, text);
-        symbol.links.type = getTypeFromBindingElement(e, includePatternInType, reportErrors2);
-        symbol.links.bindingElement = e;
-        members.set(symbol.escapedName, symbol);
-      });
-      const result = createAnonymousType(
-        /*symbol*/
-        void 0,
-        members,
-        emptyArray,
-        emptyArray,
-        stringIndexInfo ? [stringIndexInfo] : emptyArray
-      );
-      result.objectFlags |= objectFlags;
-      if (includePatternInType) {
-        result.pattern = pattern;
-        result.objectFlags |= 131072 /* ContainsObjectOrArrayLiteral */;
-      }
-      return result;
-    }
-    function getTypeFromArrayBindingPattern(pattern, includePatternInType, reportErrors2) {
-      const elements = pattern.elements;
-      const lastElement = lastOrUndefined(elements);
-      const restElement = lastElement && lastElement.kind === 207 /* BindingElement */ && lastElement.dotDotDotToken ? lastElement : void 0;
-      if (elements.length === 0 || elements.length === 1 && restElement) {
-        return languageVersion >= 2 /* ES2015 */ ? createIterableType(anyType) : anyArrayType;
-      }
-      const elementTypes = map(elements, (e) => isOmittedExpression(e) ? anyType : getTypeFromBindingElement(e, includePatternInType, reportErrors2));
-      const minLength = findLastIndex(elements, (e) => !(e === restElement || isOmittedExpression(e) || hasDefaultValue(e)), elements.length - 1) + 1;
-      const elementFlags = map(elements, (e, i) => e === restElement ? 4 /* Rest */ : i >= minLength ? 2 /* Optional */ : 1 /* Required */);
-      let result = createTupleType(elementTypes, elementFlags);
-      if (includePatternInType) {
-        result = cloneTypeReference(result);
-        result.pattern = pattern;
-        result.objectFlags |= 131072 /* ContainsObjectOrArrayLiteral */;
-      }
-      return result;
-    }
-    function getTypeFromBindingPattern(pattern, includePatternInType = false, reportErrors2 = false) {
-      return pattern.kind === 205 /* ObjectBindingPattern */ ? getTypeFromObjectBindingPattern(pattern, includePatternInType, reportErrors2) : getTypeFromArrayBindingPattern(pattern, includePatternInType, reportErrors2);
-    }
-    function getWidenedTypeForVariableLikeDeclaration(declaration, reportErrors2) {
-      return widenTypeForVariableLikeDeclaration(getTypeForVariableLikeDeclaration(
-        declaration,
-        /*includeOptionality*/
-        true,
-        0 /* Normal */
-      ), declaration, reportErrors2);
-    }
-    function isGlobalSymbolConstructor(node) {
-      const symbol = getSymbolOfNode(node);
-      const globalSymbol = getGlobalESSymbolConstructorTypeSymbol(
-        /*reportErrors*/
-        false
-      );
-      return globalSymbol && symbol && symbol === globalSymbol;
-    }
-    function widenTypeForVariableLikeDeclaration(type, declaration, reportErrors2) {
-      if (type) {
-        if (type.flags & 4096 /* ESSymbol */ && isGlobalSymbolConstructor(declaration.parent)) {
-          type = getESSymbolLikeTypeForNode(declaration);
-        }
-        if (reportErrors2) {
-          reportErrorsFromWidening(declaration, type);
-        }
-        if (type.flags & 8192 /* UniqueESSymbol */ && (isBindingElement(declaration) || !declaration.type) && type.symbol !== getSymbolOfDeclaration(declaration)) {
-          type = esSymbolType;
-        }
-        return getWidenedType(type);
-      }
-      type = isParameter(declaration) && declaration.dotDotDotToken ? anyArrayType : anyType;
-      if (reportErrors2) {
-        if (!declarationBelongsToPrivateAmbientMember(declaration)) {
-          reportImplicitAny(declaration, type);
-        }
-      }
-      return type;
-    }
-    function declarationBelongsToPrivateAmbientMember(declaration) {
-      const root = getRootDeclaration(declaration);
-      const memberDeclaration = root.kind === 168 /* Parameter */ ? root.parent : root;
-      return isPrivateWithinAmbient(memberDeclaration);
-    }
-    function tryGetTypeFromEffectiveTypeNode(node) {
-      const typeNode = getEffectiveTypeAnnotationNode(node);
-      if (typeNode) {
-        return getTypeFromTypeNode(typeNode);
-      }
-    }
-    function isParameterOfContextSensitiveSignature(symbol) {
-      let decl = symbol.valueDeclaration;
-      if (!decl) {
-        return false;
-      }
-      if (isBindingElement(decl)) {
-        decl = walkUpBindingElementsAndPatterns(decl);
-      }
-      if (isParameter(decl)) {
-        return isContextSensitiveFunctionOrObjectLiteralMethod(decl.parent);
-      }
-      return false;
-    }
-    function getTypeOfVariableOrParameterOrProperty(symbol) {
-      const links = getSymbolLinks(symbol);
-      if (!links.type) {
-        const type = getTypeOfVariableOrParameterOrPropertyWorker(symbol);
-        if (!links.type && !isParameterOfContextSensitiveSignature(symbol)) {
-          links.type = type;
-        }
-        return type;
-      }
-      return links.type;
-    }
-    function getTypeOfVariableOrParameterOrPropertyWorker(symbol) {
-      if (symbol.flags & 4194304 /* Prototype */) {
-        return getTypeOfPrototypeProperty(symbol);
-      }
-      if (symbol === requireSymbol) {
-        return anyType;
-      }
-      if (symbol.flags & 134217728 /* ModuleExports */ && symbol.valueDeclaration) {
-        const fileSymbol = getSymbolOfDeclaration(getSourceFileOfNode(symbol.valueDeclaration));
-        const result = createSymbol(fileSymbol.flags, "exports");
-        result.declarations = fileSymbol.declarations ? fileSymbol.declarations.slice() : [];
-        result.parent = symbol;
-        result.links.target = fileSymbol;
-        if (fileSymbol.valueDeclaration)
-          result.valueDeclaration = fileSymbol.valueDeclaration;
-        if (fileSymbol.members)
-          result.members = new Map(fileSymbol.members);
-        if (fileSymbol.exports)
-          result.exports = new Map(fileSymbol.exports);
-        const members = createSymbolTable();
-        members.set("exports", result);
-        return createAnonymousType(symbol, members, emptyArray, emptyArray, emptyArray);
-      }
-      Debug.assertIsDefined(symbol.valueDeclaration);
-      const declaration = symbol.valueDeclaration;
-      if (isSourceFile(declaration) && isJsonSourceFile(declaration)) {
-        if (!declaration.statements.length) {
-          return emptyObjectType;
-        }
-        return getWidenedType(getWidenedLiteralType(checkExpression(declaration.statements[0].expression)));
-      }
-      if (isAccessor(declaration)) {
-        return getTypeOfAccessors(symbol);
-      }
-      if (!pushTypeResolution(symbol, 0 /* Type */)) {
-        if (symbol.flags & 512 /* ValueModule */ && !(symbol.flags & 67108864 /* Assignment */)) {
-          return getTypeOfFuncClassEnumModule(symbol);
-        }
-        return reportCircularityError(symbol);
-      }
-      let type;
-      if (declaration.kind === 276 /* ExportAssignment */) {
-        type = widenTypeForVariableLikeDeclaration(tryGetTypeFromEffectiveTypeNode(declaration) || checkExpressionCached(declaration.expression), declaration);
-      } else if (isBinaryExpression(declaration) || isInJSFile(declaration) && (isCallExpression(declaration) || (isPropertyAccessExpression(declaration) || isBindableStaticElementAccessExpression(declaration)) && isBinaryExpression(declaration.parent))) {
-        type = getWidenedTypeForAssignmentDeclaration(symbol);
-      } else if (isPropertyAccessExpression(declaration) || isElementAccessExpression(declaration) || isIdentifier(declaration) || isStringLiteralLike(declaration) || isNumericLiteral(declaration) || isClassDeclaration(declaration) || isFunctionDeclaration(declaration) || isMethodDeclaration(declaration) && !isObjectLiteralMethod(declaration) || isMethodSignature(declaration) || isSourceFile(declaration)) {
-        if (symbol.flags & (16 /* Function */ | 8192 /* Method */ | 32 /* Class */ | 384 /* Enum */ | 512 /* ValueModule */)) {
-          return getTypeOfFuncClassEnumModule(symbol);
-        }
-        type = isBinaryExpression(declaration.parent) ? getWidenedTypeForAssignmentDeclaration(symbol) : tryGetTypeFromEffectiveTypeNode(declaration) || anyType;
-      } else if (isPropertyAssignment(declaration)) {
-        type = tryGetTypeFromEffectiveTypeNode(declaration) || checkPropertyAssignment(declaration);
-      } else if (isJsxAttribute(declaration)) {
-        type = tryGetTypeFromEffectiveTypeNode(declaration) || checkJsxAttribute(declaration);
-      } else if (isShorthandPropertyAssignment(declaration)) {
-        type = tryGetTypeFromEffectiveTypeNode(declaration) || checkExpressionForMutableLocation(declaration.name, 0 /* Normal */);
-      } else if (isObjectLiteralMethod(declaration)) {
-        type = tryGetTypeFromEffectiveTypeNode(declaration) || checkObjectLiteralMethod(declaration, 0 /* Normal */);
-      } else if (isParameter(declaration) || isPropertyDeclaration(declaration) || isPropertySignature(declaration) || isVariableDeclaration(declaration) || isBindingElement(declaration) || isJSDocPropertyLikeTag(declaration)) {
-        type = getWidenedTypeForVariableLikeDeclaration(
-          declaration,
-          /*reportErrors*/
-          true
-        );
-      } else if (isEnumDeclaration(declaration)) {
-        type = getTypeOfFuncClassEnumModule(symbol);
-      } else if (isEnumMember(declaration)) {
-        type = getTypeOfEnumMember(symbol);
-      } else {
-        return Debug.fail("Unhandled declaration kind! " + Debug.formatSyntaxKind(declaration.kind) + " for " + Debug.formatSymbol(symbol));
-      }
-      if (!popTypeResolution()) {
-        if (symbol.flags & 512 /* ValueModule */ && !(symbol.flags & 67108864 /* Assignment */)) {
-          return getTypeOfFuncClassEnumModule(symbol);
-        }
-        return reportCircularityError(symbol);
-      }
-      return type;
-    }
-    function getAnnotatedAccessorTypeNode(accessor) {
-      if (accessor) {
-        switch (accessor.kind) {
-          case 176 /* GetAccessor */:
-            const getterTypeAnnotation = getEffectiveReturnTypeNode(accessor);
-            return getterTypeAnnotation;
-          case 177 /* SetAccessor */:
-            const setterTypeAnnotation = getEffectiveSetAccessorTypeAnnotationNode(accessor);
-            return setterTypeAnnotation;
-          case 171 /* PropertyDeclaration */:
-            Debug.assert(hasAccessorModifier(accessor));
-            const accessorTypeAnnotation = getEffectiveTypeAnnotationNode(accessor);
-            return accessorTypeAnnotation;
-        }
-      }
-      return void 0;
-    }
-    function getAnnotatedAccessorType(accessor) {
-      const node = getAnnotatedAccessorTypeNode(accessor);
-      return node && getTypeFromTypeNode(node);
-    }
-    function getAnnotatedAccessorThisParameter(accessor) {
-      const parameter = getAccessorThisParameter(accessor);
-      return parameter && parameter.symbol;
-    }
-    function getThisTypeOfDeclaration(declaration) {
-      return getThisTypeOfSignature(getSignatureFromDeclaration(declaration));
-    }
-    function getTypeOfAccessors(symbol) {
-      const links = getSymbolLinks(symbol);
-      if (!links.type) {
-        if (!pushTypeResolution(symbol, 0 /* Type */)) {
-          return errorType;
-        }
-        const getter = getDeclarationOfKind(symbol, 176 /* GetAccessor */);
-        const setter = getDeclarationOfKind(symbol, 177 /* SetAccessor */);
-        const accessor = tryCast(getDeclarationOfKind(symbol, 171 /* PropertyDeclaration */), isAutoAccessorPropertyDeclaration);
-        let type = getter && isInJSFile(getter) && getTypeForDeclarationFromJSDocComment(getter) || getAnnotatedAccessorType(getter) || getAnnotatedAccessorType(setter) || getAnnotatedAccessorType(accessor) || getter && getter.body && getReturnTypeFromBody(getter) || accessor && accessor.initializer && getWidenedTypeForVariableLikeDeclaration(
-          accessor,
-          /*reportErrors*/
-          true
-        );
-        if (!type) {
-          if (setter && !isPrivateWithinAmbient(setter)) {
-            errorOrSuggestion(noImplicitAny, setter, Diagnostics.Property_0_implicitly_has_type_any_because_its_set_accessor_lacks_a_parameter_type_annotation, symbolToString(symbol));
-          } else if (getter && !isPrivateWithinAmbient(getter)) {
-            errorOrSuggestion(noImplicitAny, getter, Diagnostics.Property_0_implicitly_has_type_any_because_its_get_accessor_lacks_a_return_type_annotation, symbolToString(symbol));
-          } else if (accessor && !isPrivateWithinAmbient(accessor)) {
-            errorOrSuggestion(noImplicitAny, accessor, Diagnostics.Member_0_implicitly_has_an_1_type, symbolToString(symbol), "any");
-          }
-          type = anyType;
-        }
-        if (!popTypeResolution()) {
-          if (getAnnotatedAccessorTypeNode(getter)) {
-            error(getter, Diagnostics._0_is_referenced_directly_or_indirectly_in_its_own_type_annotation, symbolToString(symbol));
-          } else if (getAnnotatedAccessorTypeNode(setter)) {
-            error(setter, Diagnostics._0_is_referenced_directly_or_indirectly_in_its_own_type_annotation, symbolToString(symbol));
-          } else if (getAnnotatedAccessorTypeNode(accessor)) {
-            error(setter, Diagnostics._0_is_referenced_directly_or_indirectly_in_its_own_type_annotation, symbolToString(symbol));
-          } else if (getter && noImplicitAny) {
-            error(getter, Diagnostics._0_implicitly_has_return_type_any_because_it_does_not_have_a_return_type_annotation_and_is_referenced_directly_or_indirectly_in_one_of_its_return_expressions, symbolToString(symbol));
-          }
-          type = anyType;
-        }
-        links.type = type;
-      }
-      return links.type;
-    }
-    function getWriteTypeOfAccessors(symbol) {
-      const links = getSymbolLinks(symbol);
-      if (!links.writeType) {
-        if (!pushTypeResolution(symbol, 8 /* WriteType */)) {
-          return errorType;
-        }
-        const setter = getDeclarationOfKind(symbol, 177 /* SetAccessor */) ?? tryCast(getDeclarationOfKind(symbol, 171 /* PropertyDeclaration */), isAutoAccessorPropertyDeclaration);
-        let writeType = getAnnotatedAccessorType(setter);
-        if (!popTypeResolution()) {
-          if (getAnnotatedAccessorTypeNode(setter)) {
-            error(setter, Diagnostics._0_is_referenced_directly_or_indirectly_in_its_own_type_annotation, symbolToString(symbol));
-          }
-          writeType = anyType;
-        }
-        links.writeType = writeType || getTypeOfAccessors(symbol);
-      }
-      return links.writeType;
-    }
-    function getBaseTypeVariableOfClass(symbol) {
-      const baseConstructorType = getBaseConstructorTypeOfClass(getDeclaredTypeOfClassOrInterface(symbol));
-      return baseConstructorType.flags & 8650752 /* TypeVariable */ ? baseConstructorType : baseConstructorType.flags & 2097152 /* Intersection */ ? find(baseConstructorType.types, (t) => !!(t.flags & 8650752 /* TypeVariable */)) : void 0;
-    }
-    function getTypeOfFuncClassEnumModule(symbol) {
-      let links = getSymbolLinks(symbol);
-      const originalLinks = links;
-      if (!links.type) {
-        const expando = symbol.valueDeclaration && getSymbolOfExpando(
-          symbol.valueDeclaration,
-          /*allowDeclaration*/
-          false
-        );
-        if (expando) {
-          const merged = mergeJSSymbols(symbol, expando);
-          if (merged) {
-            symbol = merged;
-            links = merged.links;
-          }
-        }
-        originalLinks.type = links.type = getTypeOfFuncClassEnumModuleWorker(symbol);
-      }
-      return links.type;
-    }
-    function getTypeOfFuncClassEnumModuleWorker(symbol) {
-      const declaration = symbol.valueDeclaration;
-      if (symbol.flags & 1536 /* Module */ && isShorthandAmbientModuleSymbol(symbol)) {
-        return anyType;
-      } else if (declaration && (declaration.kind === 225 /* BinaryExpression */ || isAccessExpression(declaration) && declaration.parent.kind === 225 /* BinaryExpression */)) {
-        return getWidenedTypeForAssignmentDeclaration(symbol);
-      } else if (symbol.flags & 512 /* ValueModule */ && declaration && isSourceFile(declaration) && declaration.commonJsModuleIndicator) {
-        const resolvedModule = resolveExternalModuleSymbol(symbol);
-        if (resolvedModule !== symbol) {
-          if (!pushTypeResolution(symbol, 0 /* Type */)) {
-            return errorType;
-          }
-          const exportEquals = getMergedSymbol(symbol.exports.get("export=" /* ExportEquals */));
-          const type2 = getWidenedTypeForAssignmentDeclaration(exportEquals, exportEquals === resolvedModule ? void 0 : resolvedModule);
-          if (!popTypeResolution()) {
-            return reportCircularityError(symbol);
-          }
-          return type2;
-        }
-      }
-      const type = createObjectType(16 /* Anonymous */, symbol);
-      if (symbol.flags & 32 /* Class */) {
-        const baseTypeVariable = getBaseTypeVariableOfClass(symbol);
-        return baseTypeVariable ? getIntersectionType([type, baseTypeVariable]) : type;
-      } else {
-        return strictNullChecks && symbol.flags & 16777216 /* Optional */ ? getOptionalType(
-          type,
-          /*isProperty*/
-          true
-        ) : type;
-      }
-    }
-    function getTypeOfEnumMember(symbol) {
-      const links = getSymbolLinks(symbol);
-      return links.type || (links.type = getDeclaredTypeOfEnumMember(symbol));
-    }
-    function getTypeOfAlias(symbol) {
-      const links = getSymbolLinks(symbol);
-      if (!links.type) {
-        const targetSymbol = resolveAlias(symbol);
-        const exportSymbol = symbol.declarations && getTargetOfAliasDeclaration(
-          getDeclarationOfAliasSymbol(symbol),
-          /*dontRecursivelyResolve*/
-          true
-        );
-        const declaredType = firstDefined(exportSymbol == null ? void 0 : exportSymbol.declarations, (d) => isExportAssignment(d) ? tryGetTypeFromEffectiveTypeNode(d) : void 0);
-        links.type = (exportSymbol == null ? void 0 : exportSymbol.declarations) && isDuplicatedCommonJSExport(exportSymbol.declarations) && symbol.declarations.length ? getFlowTypeFromCommonJSExport(exportSymbol) : isDuplicatedCommonJSExport(symbol.declarations) ? autoType : declaredType ? declaredType : getAllSymbolFlags(targetSymbol) & 111551 /* Value */ ? getTypeOfSymbol(targetSymbol) : errorType;
-      }
-      return links.type;
-    }
-    function getTypeOfInstantiatedSymbol(symbol) {
-      const links = getSymbolLinks(symbol);
-      return links.type || (links.type = instantiateType(getTypeOfSymbol(links.target), links.mapper));
-    }
-    function getWriteTypeOfInstantiatedSymbol(symbol) {
-      const links = getSymbolLinks(symbol);
-      return links.writeType || (links.writeType = instantiateType(getWriteTypeOfSymbol(links.target), links.mapper));
-    }
-    function reportCircularityError(symbol) {
-      const declaration = symbol.valueDeclaration;
-      if (getEffectiveTypeAnnotationNode(declaration)) {
-        error(
-          symbol.valueDeclaration,
-          Diagnostics._0_is_referenced_directly_or_indirectly_in_its_own_type_annotation,
-          symbolToString(symbol)
-        );
-        return errorType;
-      }
-      if (noImplicitAny && (declaration.kind !== 168 /* Parameter */ || declaration.initializer)) {
-        error(
-          symbol.valueDeclaration,
-          Diagnostics._0_implicitly_has_type_any_because_it_does_not_have_a_type_annotation_and_is_referenced_directly_or_indirectly_in_its_own_initializer,
-          symbolToString(symbol)
-        );
-      }
-      return anyType;
-    }
-    function getTypeOfSymbolWithDeferredType(symbol) {
-      const links = getSymbolLinks(symbol);
-      if (!links.type) {
-        Debug.assertIsDefined(links.deferralParent);
-        Debug.assertIsDefined(links.deferralConstituents);
-        links.type = links.deferralParent.flags & 1048576 /* Union */ ? getUnionType(links.deferralConstituents) : getIntersectionType(links.deferralConstituents);
-      }
-      return links.type;
-    }
-    function getWriteTypeOfSymbolWithDeferredType(symbol) {
-      const links = getSymbolLinks(symbol);
-      if (!links.writeType && links.deferralWriteConstituents) {
-        Debug.assertIsDefined(links.deferralParent);
-        Debug.assertIsDefined(links.deferralConstituents);
-        links.writeType = links.deferralParent.flags & 1048576 /* Union */ ? getUnionType(links.deferralWriteConstituents) : getIntersectionType(links.deferralWriteConstituents);
-      }
-      return links.writeType;
-    }
-    function getWriteTypeOfSymbol(symbol) {
-      const checkFlags = getCheckFlags(symbol);
-      if (symbol.flags & 4 /* Property */) {
-        return checkFlags & 2 /* SyntheticProperty */ ? checkFlags & 65536 /* DeferredType */ ? getWriteTypeOfSymbolWithDeferredType(symbol) || getTypeOfSymbolWithDeferredType(symbol) : (
-          // NOTE: cast to TransientSymbol should be safe because only TransientSymbols can have CheckFlags.SyntheticProperty
-          symbol.links.writeType || symbol.links.type
-        ) : getTypeOfSymbol(symbol);
-      }
-      if (symbol.flags & 98304 /* Accessor */) {
-        return checkFlags & 1 /* Instantiated */ ? getWriteTypeOfInstantiatedSymbol(symbol) : getWriteTypeOfAccessors(symbol);
-      }
-      return getTypeOfSymbol(symbol);
-    }
-    function getTypeOfSymbol(symbol) {
-      const checkFlags = getCheckFlags(symbol);
-      if (checkFlags & 65536 /* DeferredType */) {
-        return getTypeOfSymbolWithDeferredType(symbol);
-      }
-      if (checkFlags & 1 /* Instantiated */) {
-        return getTypeOfInstantiatedSymbol(symbol);
-      }
-      if (checkFlags & 262144 /* Mapped */) {
-        return getTypeOfMappedSymbol(symbol);
-      }
-      if (checkFlags & 8192 /* ReverseMapped */) {
-        return getTypeOfReverseMappedSymbol(symbol);
-      }
-      if (symbol.flags & (3 /* Variable */ | 4 /* Property */)) {
-        return getTypeOfVariableOrParameterOrProperty(symbol);
-      }
-      if (symbol.flags & (16 /* Function */ | 8192 /* Method */ | 32 /* Class */ | 384 /* Enum */ | 512 /* ValueModule */)) {
-        return getTypeOfFuncClassEnumModule(symbol);
-      }
-      if (symbol.flags & 8 /* EnumMember */) {
-        return getTypeOfEnumMember(symbol);
-      }
-      if (symbol.flags & 98304 /* Accessor */) {
-        return getTypeOfAccessors(symbol);
-      }
-      if (symbol.flags & 2097152 /* Alias */) {
-        return getTypeOfAlias(symbol);
-      }
-      return errorType;
-    }
-    function getNonMissingTypeOfSymbol(symbol) {
-      return removeMissingType(getTypeOfSymbol(symbol), !!(symbol.flags & 16777216 /* Optional */));
-    }
-    function isReferenceToType2(type, target) {
-      return type !== void 0 && target !== void 0 && (getObjectFlags(type) & 4 /* Reference */) !== 0 && type.target === target;
-    }
-    function getTargetType(type) {
-      return getObjectFlags(type) & 4 /* Reference */ ? type.target : type;
-    }
-    function hasBaseType(type, checkBase) {
-      return check(type);
-      function check(type2) {
-        if (getObjectFlags(type2) & (3 /* ClassOrInterface */ | 4 /* Reference */)) {
-          const target = getTargetType(type2);
-          return target === checkBase || some(getBaseTypes(target), check);
-        } else if (type2.flags & 2097152 /* Intersection */) {
-          return some(type2.types, check);
-        }
-        return false;
-      }
-    }
-    function appendTypeParameters(typeParameters, declarations) {
-      for (const declaration of declarations) {
-        typeParameters = appendIfUnique(typeParameters, getDeclaredTypeOfTypeParameter(getSymbolOfDeclaration(declaration)));
-      }
-      return typeParameters;
-    }
-    function getOuterTypeParameters(node, includeThisTypes) {
-      while (true) {
-        node = node.parent;
-        if (node && isBinaryExpression(node)) {
-          const assignmentKind = getAssignmentDeclarationKind(node);
-          if (assignmentKind === 6 /* Prototype */ || assignmentKind === 3 /* PrototypeProperty */) {
-            const symbol = getSymbolOfDeclaration(node.left);
-            if (symbol && symbol.parent && !findAncestor(symbol.parent.valueDeclaration, (d) => node === d)) {
-              node = symbol.parent.valueDeclaration;
-            }
-          }
-        }
-        if (!node) {
-          return void 0;
-        }
-        switch (node.kind) {
-          case 262 /* ClassDeclaration */:
-          case 230 /* ClassExpression */:
-          case 263 /* InterfaceDeclaration */:
-          case 178 /* CallSignature */:
-          case 179 /* ConstructSignature */:
-          case 172 /* MethodSignature */:
-          case 183 /* FunctionType */:
-          case 184 /* ConstructorType */:
-          case 323 /* JSDocFunctionType */:
-          case 261 /* FunctionDeclaration */:
-          case 173 /* MethodDeclaration */:
-          case 217 /* FunctionExpression */:
-          case 218 /* ArrowFunction */:
-          case 264 /* TypeAliasDeclaration */:
-          case 351 /* JSDocTemplateTag */:
-          case 352 /* JSDocTypedefTag */:
-          case 346 /* JSDocEnumTag */:
-          case 344 /* JSDocCallbackTag */:
-          case 199 /* MappedType */:
-          case 193 /* ConditionalType */: {
-            const outerTypeParameters = getOuterTypeParameters(node, includeThisTypes);
-            if (node.kind === 199 /* MappedType */) {
-              return append(outerTypeParameters, getDeclaredTypeOfTypeParameter(getSymbolOfDeclaration(node.typeParameter)));
-            } else if (node.kind === 193 /* ConditionalType */) {
-              return concatenate(outerTypeParameters, getInferTypeParameters(node));
-            }
-            const outerAndOwnTypeParameters = appendTypeParameters(outerTypeParameters, getEffectiveTypeParameterDeclarations(node));
-            const thisType = includeThisTypes && (node.kind === 262 /* ClassDeclaration */ || node.kind === 230 /* ClassExpression */ || node.kind === 263 /* InterfaceDeclaration */ || isJSConstructor(node)) && getDeclaredTypeOfClassOrInterface(getSymbolOfDeclaration(node)).thisType;
-            return thisType ? append(outerAndOwnTypeParameters, thisType) : outerAndOwnTypeParameters;
-          }
-          case 347 /* JSDocParameterTag */:
-            const paramSymbol = getParameterSymbolFromJSDoc(node);
-            if (paramSymbol) {
-              node = paramSymbol.valueDeclaration;
-            }
-            break;
-          case 326 /* JSDoc */: {
-            const outerTypeParameters = getOuterTypeParameters(node, includeThisTypes);
-            return node.tags ? appendTypeParameters(outerTypeParameters, flatMap(node.tags, (t) => isJSDocTemplateTag(t) ? t.typeParameters : void 0)) : outerTypeParameters;
-          }
-        }
-      }
-    }
-    function getOuterTypeParametersOfClassOrInterface(symbol) {
-      var _a;
-      const declaration = symbol.flags & 32 /* Class */ || symbol.flags & 16 /* Function */ ? symbol.valueDeclaration : (_a = symbol.declarations) == null ? void 0 : _a.find((decl) => {
-        if (decl.kind === 263 /* InterfaceDeclaration */) {
-          return true;
-        }
-        if (decl.kind !== 259 /* VariableDeclaration */) {
-          return false;
-        }
-        const initializer = decl.initializer;
-        return !!initializer && (initializer.kind === 217 /* FunctionExpression */ || initializer.kind === 218 /* ArrowFunction */);
-      });
-      Debug.assert(!!declaration, "Class was missing valueDeclaration -OR- non-class had no interface declarations");
-      return getOuterTypeParameters(declaration);
-    }
-    function getLocalTypeParametersOfClassOrInterfaceOrTypeAlias(symbol) {
-      if (!symbol.declarations) {
-        return;
-      }
-      let result;
-      for (const node of symbol.declarations) {
-        if (node.kind === 263 /* InterfaceDeclaration */ || node.kind === 262 /* ClassDeclaration */ || node.kind === 230 /* ClassExpression */ || isJSConstructor(node) || isTypeAlias(node)) {
-          const declaration = node;
-          result = appendTypeParameters(result, getEffectiveTypeParameterDeclarations(declaration));
-        }
-      }
-      return result;
-    }
-    function getTypeParametersOfClassOrInterface(symbol) {
-      return concatenate(getOuterTypeParametersOfClassOrInterface(symbol), getLocalTypeParametersOfClassOrInterfaceOrTypeAlias(symbol));
-    }
-    function isMixinConstructorType(type) {
-      const signatures = getSignaturesOfType(type, 1 /* Construct */);
-      if (signatures.length === 1) {
-        const s = signatures[0];
-        if (!s.typeParameters && s.parameters.length === 1 && signatureHasRestParameter(s)) {
-          const paramType = getTypeOfParameter(s.parameters[0]);
-          return isTypeAny(paramType) || getElementTypeOfArrayType(paramType) === anyType;
-        }
-      }
-      return false;
-    }
-    function isConstructorType(type) {
-      if (getSignaturesOfType(type, 1 /* Construct */).length > 0) {
-        return true;
-      }
-      if (type.flags & 8650752 /* TypeVariable */) {
-        const constraint = getBaseConstraintOfType(type);
-        return !!constraint && isMixinConstructorType(constraint);
-      }
-      return false;
-    }
-    function getBaseTypeNodeOfClass(type) {
-      const decl = getClassLikeDeclarationOfSymbol(type.symbol);
-      return decl && getEffectiveBaseTypeNode(decl);
-    }
-    function getConstructorsForTypeArguments(type, typeArgumentNodes, location) {
-      const typeArgCount = length(typeArgumentNodes);
-      const isJavascript = isInJSFile(location);
-      return filter(
-        getSignaturesOfType(type, 1 /* Construct */),
-        (sig) => (isJavascript || typeArgCount >= getMinTypeArgumentCount(sig.typeParameters)) && typeArgCount <= length(sig.typeParameters)
-      );
-    }
-    function getInstantiatedConstructorsForTypeArguments(type, typeArgumentNodes, location) {
-      const signatures = getConstructorsForTypeArguments(type, typeArgumentNodes, location);
-      const typeArguments = map(typeArgumentNodes, getTypeFromTypeNode);
-      return sameMap(signatures, (sig) => some(sig.typeParameters) ? getSignatureInstantiation(sig, typeArguments, isInJSFile(location)) : sig);
-    }
-    function getBaseConstructorTypeOfClass(type) {
-      if (!type.resolvedBaseConstructorType) {
-        const decl = getClassLikeDeclarationOfSymbol(type.symbol);
-        const extended = decl && getEffectiveBaseTypeNode(decl);
-        const baseTypeNode = getBaseTypeNodeOfClass(type);
-        if (!baseTypeNode) {
-          return type.resolvedBaseConstructorType = undefinedType;
-        }
-        if (!pushTypeResolution(type, 1 /* ResolvedBaseConstructorType */)) {
-          return errorType;
-        }
-        const baseConstructorType = checkExpression(baseTypeNode.expression);
-        if (extended && baseTypeNode !== extended) {
-          Debug.assert(!extended.typeArguments);
-          checkExpression(extended.expression);
-        }
-        if (baseConstructorType.flags & (524288 /* Object */ | 2097152 /* Intersection */)) {
-          resolveStructuredTypeMembers(baseConstructorType);
-        }
-        if (!popTypeResolution()) {
-          error(type.symbol.valueDeclaration, Diagnostics._0_is_referenced_directly_or_indirectly_in_its_own_base_expression, symbolToString(type.symbol));
-          return type.resolvedBaseConstructorType = errorType;
-        }
-        if (!(baseConstructorType.flags & 1 /* Any */) && baseConstructorType !== nullWideningType && !isConstructorType(baseConstructorType)) {
-          const err = error(baseTypeNode.expression, Diagnostics.Type_0_is_not_a_constructor_function_type, typeToString(baseConstructorType));
-          if (baseConstructorType.flags & 262144 /* TypeParameter */) {
-            const constraint = getConstraintFromTypeParameter(baseConstructorType);
-            let ctorReturn = unknownType;
-            if (constraint) {
-              const ctorSig = getSignaturesOfType(constraint, 1 /* Construct */);
-              if (ctorSig[0]) {
-                ctorReturn = getReturnTypeOfSignature(ctorSig[0]);
-              }
-            }
-            if (baseConstructorType.symbol.declarations) {
-              addRelatedInfo(err, createDiagnosticForNode(baseConstructorType.symbol.declarations[0], Diagnostics.Did_you_mean_for_0_to_be_constrained_to_type_new_args_Colon_any_1, symbolToString(baseConstructorType.symbol), typeToString(ctorReturn)));
-            }
-          }
-          return type.resolvedBaseConstructorType = errorType;
-        }
-        type.resolvedBaseConstructorType = baseConstructorType;
-      }
-      return type.resolvedBaseConstructorType;
-    }
-    function getImplementsTypes(type) {
-      let resolvedImplementsTypes = emptyArray;
-      if (type.symbol.declarations) {
-        for (const declaration of type.symbol.declarations) {
-          const implementsTypeNodes = getEffectiveImplementsTypeNodes(declaration);
-          if (!implementsTypeNodes)
-            continue;
-          for (const node of implementsTypeNodes) {
-            const implementsType = getTypeFromTypeNode(node);
-            if (!isErrorType(implementsType)) {
-              if (resolvedImplementsTypes === emptyArray) {
-                resolvedImplementsTypes = [implementsType];
-              } else {
-                resolvedImplementsTypes.push(implementsType);
-              }
-            }
-          }
-        }
-      }
-      return resolvedImplementsTypes;
-    }
-    function reportCircularBaseType(node, type) {
-      error(node, Diagnostics.Type_0_recursively_references_itself_as_a_base_type, typeToString(
-        type,
-        /*enclosingDeclaration*/
-        void 0,
-        2 /* WriteArrayAsGenericType */
-      ));
-    }
-    function getBaseTypes(type) {
-      if (!type.baseTypesResolved) {
-        if (pushTypeResolution(type, 7 /* ResolvedBaseTypes */)) {
-          if (type.objectFlags & 8 /* Tuple */) {
-            type.resolvedBaseTypes = [getTupleBaseType(type)];
-          } else if (type.symbol.flags & (32 /* Class */ | 64 /* Interface */)) {
-            if (type.symbol.flags & 32 /* Class */) {
-              resolveBaseTypesOfClass(type);
-            }
-            if (type.symbol.flags & 64 /* Interface */) {
-              resolveBaseTypesOfInterface(type);
-            }
-          } else {
-            Debug.fail("type must be class or interface");
-          }
-          if (!popTypeResolution() && type.symbol.declarations) {
-            for (const declaration of type.symbol.declarations) {
-              if (declaration.kind === 262 /* ClassDeclaration */ || declaration.kind === 263 /* InterfaceDeclaration */) {
-                reportCircularBaseType(declaration, type);
-              }
-            }
-          }
-        }
-        type.baseTypesResolved = true;
-      }
-      return type.resolvedBaseTypes;
-    }
-    function getTupleBaseType(type) {
-      const elementTypes = sameMap(type.typeParameters, (t, i) => type.elementFlags[i] & 8 /* Variadic */ ? getIndexedAccessType(t, numberType) : t);
-      return createArrayType(getUnionType(elementTypes || emptyArray), type.readonly);
-    }
-    function resolveBaseTypesOfClass(type) {
-      type.resolvedBaseTypes = resolvingEmptyArray;
-      const baseConstructorType = getApparentType(getBaseConstructorTypeOfClass(type));
-      if (!(baseConstructorType.flags & (524288 /* Object */ | 2097152 /* Intersection */ | 1 /* Any */))) {
-        return type.resolvedBaseTypes = emptyArray;
-      }
-      const baseTypeNode = getBaseTypeNodeOfClass(type);
-      let baseType;
-      const originalBaseType = baseConstructorType.symbol ? getDeclaredTypeOfSymbol(baseConstructorType.symbol) : void 0;
-      if (baseConstructorType.symbol && baseConstructorType.symbol.flags & 32 /* Class */ && areAllOuterTypeParametersApplied(originalBaseType)) {
-        baseType = getTypeFromClassOrInterfaceReference(baseTypeNode, baseConstructorType.symbol);
-      } else if (baseConstructorType.flags & 1 /* Any */) {
-        baseType = baseConstructorType;
-      } else {
-        const constructors = getInstantiatedConstructorsForTypeArguments(baseConstructorType, baseTypeNode.typeArguments, baseTypeNode);
-        if (!constructors.length) {
-          error(baseTypeNode.expression, Diagnostics.No_base_constructor_has_the_specified_number_of_type_arguments);
-          return type.resolvedBaseTypes = emptyArray;
-        }
-        baseType = getReturnTypeOfSignature(constructors[0]);
-      }
-      if (isErrorType(baseType)) {
-        return type.resolvedBaseTypes = emptyArray;
-      }
-      const reducedBaseType = getReducedType(baseType);
-      if (!isValidBaseType(reducedBaseType)) {
-        const elaboration = elaborateNeverIntersection(
-          /*errorInfo*/
-          void 0,
-          baseType
-        );
-        const diagnostic = chainDiagnosticMessages(elaboration, Diagnostics.Base_constructor_return_type_0_is_not_an_object_type_or_intersection_of_object_types_with_statically_known_members, typeToString(reducedBaseType));
-        diagnostics.add(createDiagnosticForNodeFromMessageChain(getSourceFileOfNode(baseTypeNode.expression), baseTypeNode.expression, diagnostic));
-        return type.resolvedBaseTypes = emptyArray;
-      }
-      if (type === reducedBaseType || hasBaseType(reducedBaseType, type)) {
-        error(
-          type.symbol.valueDeclaration,
-          Diagnostics.Type_0_recursively_references_itself_as_a_base_type,
-          typeToString(
-            type,
-            /*enclosingDeclaration*/
-            void 0,
-            2 /* WriteArrayAsGenericType */
-          )
-        );
-        return type.resolvedBaseTypes = emptyArray;
-      }
-      if (type.resolvedBaseTypes === resolvingEmptyArray) {
-        type.members = void 0;
-      }
-      return type.resolvedBaseTypes = [reducedBaseType];
-    }
-    function areAllOuterTypeParametersApplied(type) {
-      const outerTypeParameters = type.outerTypeParameters;
-      if (outerTypeParameters) {
-        const last2 = outerTypeParameters.length - 1;
-        const typeArguments = getTypeArguments(type);
-        return outerTypeParameters[last2].symbol !== typeArguments[last2].symbol;
-      }
-      return true;
-    }
-    function isValidBaseType(type) {
-      if (type.flags & 262144 /* TypeParameter */) {
-        const constraint = getBaseConstraintOfType(type);
-        if (constraint) {
-          return isValidBaseType(constraint);
-        }
-      }
-      return !!(type.flags & (524288 /* Object */ | 67108864 /* NonPrimitive */ | 1 /* Any */) && !isGenericMappedType(type) || type.flags & 2097152 /* Intersection */ && every(type.types, isValidBaseType));
-    }
-    function resolveBaseTypesOfInterface(type) {
-      type.resolvedBaseTypes = type.resolvedBaseTypes || emptyArray;
-      if (type.symbol.declarations) {
-        for (const declaration of type.symbol.declarations) {
-          if (declaration.kind === 263 /* InterfaceDeclaration */ && getInterfaceBaseTypeNodes(declaration)) {
-            for (const node of getInterfaceBaseTypeNodes(declaration)) {
-              const baseType = getReducedType(getTypeFromTypeNode(node));
-              if (!isErrorType(baseType)) {
-                if (isValidBaseType(baseType)) {
-                  if (type !== baseType && !hasBaseType(baseType, type)) {
-                    if (type.resolvedBaseTypes === emptyArray) {
-                      type.resolvedBaseTypes = [baseType];
-                    } else {
-                      type.resolvedBaseTypes.push(baseType);
-                    }
-                  } else {
-                    reportCircularBaseType(declaration, type);
-                  }
-                } else {
-                  error(node, Diagnostics.An_interface_can_only_extend_an_object_type_or_intersection_of_object_types_with_statically_known_members);
-                }
-              }
-            }
-          }
-        }
-      }
-    }
-    function isThislessInterface(symbol) {
-      if (!symbol.declarations) {
-        return true;
-      }
-      for (const declaration of symbol.declarations) {
-        if (declaration.kind === 263 /* InterfaceDeclaration */) {
-          if (declaration.flags & 128 /* ContainsThis */) {
-            return false;
-          }
-          const baseTypeNodes = getInterfaceBaseTypeNodes(declaration);
-          if (baseTypeNodes) {
-            for (const node of baseTypeNodes) {
-              if (isEntityNameExpression(node.expression)) {
-                const baseSymbol = resolveEntityName(
-                  node.expression,
-                  788968 /* Type */,
-                  /*ignoreErrors*/
-                  true
-                );
-                if (!baseSymbol || !(baseSymbol.flags & 64 /* Interface */) || getDeclaredTypeOfClassOrInterface(baseSymbol).thisType) {
-                  return false;
-                }
-              }
-            }
-          }
-        }
-      }
-      return true;
-    }
-    function getDeclaredTypeOfClassOrInterface(symbol) {
-      let links = getSymbolLinks(symbol);
-      const originalLinks = links;
-      if (!links.declaredType) {
-        const kind = symbol.flags & 32 /* Class */ ? 1 /* Class */ : 2 /* Interface */;
-        const merged = mergeJSSymbols(symbol, symbol.valueDeclaration && getAssignedClassSymbol(symbol.valueDeclaration));
-        if (merged) {
-          symbol = merged;
-          links = merged.links;
-        }
-        const type = originalLinks.declaredType = links.declaredType = createObjectType(kind, symbol);
-        const outerTypeParameters = getOuterTypeParametersOfClassOrInterface(symbol);
-        const localTypeParameters = getLocalTypeParametersOfClassOrInterfaceOrTypeAlias(symbol);
-        if (outerTypeParameters || localTypeParameters || kind === 1 /* Class */ || !isThislessInterface(symbol)) {
-          type.objectFlags |= 4 /* Reference */;
-          type.typeParameters = concatenate(outerTypeParameters, localTypeParameters);
-          type.outerTypeParameters = outerTypeParameters;
-          type.localTypeParameters = localTypeParameters;
-          type.instantiations = /* @__PURE__ */ new Map();
-          type.instantiations.set(getTypeListId(type.typeParameters), type);
-          type.target = type;
-          type.resolvedTypeArguments = type.typeParameters;
-          type.thisType = createTypeParameter(symbol);
-          type.thisType.isThisType = true;
-          type.thisType.constraint = type;
-        }
-      }
-      return links.declaredType;
-    }
-    function getDeclaredTypeOfTypeAlias(symbol) {
-      var _a;
-      const links = getSymbolLinks(symbol);
-      if (!links.declaredType) {
-        if (!pushTypeResolution(symbol, 2 /* DeclaredType */)) {
-          return errorType;
-        }
-        const declaration = Debug.checkDefined((_a = symbol.declarations) == null ? void 0 : _a.find(isTypeAlias), "Type alias symbol with no valid declaration found");
-        const typeNode = isJSDocTypeAlias(declaration) ? declaration.typeExpression : declaration.type;
-        let type = typeNode ? getTypeFromTypeNode(typeNode) : errorType;
-        if (popTypeResolution()) {
-          const typeParameters = getLocalTypeParametersOfClassOrInterfaceOrTypeAlias(symbol);
-          if (typeParameters) {
-            links.typeParameters = typeParameters;
-            links.instantiations = /* @__PURE__ */ new Map();
-            links.instantiations.set(getTypeListId(typeParameters), type);
-          }
-        } else {
-          type = errorType;
-          if (declaration.kind === 346 /* JSDocEnumTag */) {
-            error(declaration.typeExpression.type, Diagnostics.Type_alias_0_circularly_references_itself, symbolToString(symbol));
-          } else {
-            error(isNamedDeclaration(declaration) ? declaration.name || declaration : declaration, Diagnostics.Type_alias_0_circularly_references_itself, symbolToString(symbol));
-          }
-        }
-        links.declaredType = type;
-      }
-      return links.declaredType;
-    }
-    function getBaseTypeOfEnumLikeType(type) {
-      return type.flags & 1056 /* EnumLike */ && type.symbol.flags & 8 /* EnumMember */ ? getDeclaredTypeOfSymbol(getParentOfSymbol(type.symbol)) : type;
-    }
-    function getDeclaredTypeOfEnum(symbol) {
-      const links = getSymbolLinks(symbol);
-      if (!links.declaredType) {
-        const memberTypeList = [];
-        if (symbol.declarations) {
-          for (const declaration of symbol.declarations) {
-            if (declaration.kind === 265 /* EnumDeclaration */) {
-              for (const member of declaration.members) {
-                if (hasBindableName(member)) {
-                  const memberSymbol = getSymbolOfDeclaration(member);
-                  const value = getEnumMemberValue(member);
-                  const memberType = getFreshTypeOfLiteralType(value !== void 0 ? getEnumLiteralType(value, getSymbolId(symbol), memberSymbol) : createComputedEnumType(memberSymbol));
-                  getSymbolLinks(memberSymbol).declaredType = memberType;
-                  memberTypeList.push(getRegularTypeOfLiteralType(memberType));
-                }
-              }
-            }
-          }
-        }
-        const enumType = memberTypeList.length ? getUnionType(
-          memberTypeList,
-          1 /* Literal */,
-          symbol,
-          /*aliasTypeArguments*/
-          void 0
-        ) : createComputedEnumType(symbol);
-        if (enumType.flags & 1048576 /* Union */) {
-          enumType.flags |= 1024 /* EnumLiteral */;
-          enumType.symbol = symbol;
-        }
-        links.declaredType = enumType;
-      }
-      return links.declaredType;
-    }
-    function createComputedEnumType(symbol) {
-      const regularType = createTypeWithSymbol(32 /* Enum */, symbol);
-      const freshType = createTypeWithSymbol(32 /* Enum */, symbol);
-      regularType.regularType = regularType;
-      regularType.freshType = freshType;
-      freshType.regularType = regularType;
-      freshType.freshType = freshType;
-      return regularType;
-    }
-    function getDeclaredTypeOfEnumMember(symbol) {
-      const links = getSymbolLinks(symbol);
-      if (!links.declaredType) {
-        const enumType = getDeclaredTypeOfEnum(getParentOfSymbol(symbol));
-        if (!links.declaredType) {
-          links.declaredType = enumType;
-        }
-      }
-      return links.declaredType;
-    }
-    function getDeclaredTypeOfTypeParameter(symbol) {
-      const links = getSymbolLinks(symbol);
-      return links.declaredType || (links.declaredType = createTypeParameter(symbol));
-    }
-    function getDeclaredTypeOfAlias(symbol) {
-      const links = getSymbolLinks(symbol);
-      return links.declaredType || (links.declaredType = getDeclaredTypeOfSymbol(resolveAlias(symbol)));
-    }
-    function getDeclaredTypeOfSymbol(symbol) {
-      return tryGetDeclaredTypeOfSymbol(symbol) || errorType;
-    }
-    function tryGetDeclaredTypeOfSymbol(symbol) {
-      if (symbol.flags & (32 /* Class */ | 64 /* Interface */)) {
-        return getDeclaredTypeOfClassOrInterface(symbol);
-      }
-      if (symbol.flags & 524288 /* TypeAlias */) {
-        return getDeclaredTypeOfTypeAlias(symbol);
-      }
-      if (symbol.flags & 262144 /* TypeParameter */) {
-        return getDeclaredTypeOfTypeParameter(symbol);
-      }
-      if (symbol.flags & 384 /* Enum */) {
-        return getDeclaredTypeOfEnum(symbol);
-      }
-      if (symbol.flags & 8 /* EnumMember */) {
-        return getDeclaredTypeOfEnumMember(symbol);
-      }
-      if (symbol.flags & 2097152 /* Alias */) {
-        return getDeclaredTypeOfAlias(symbol);
-      }
-      return void 0;
-    }
-    function isThislessType(node) {
-      switch (node.kind) {
-        case 133 /* AnyKeyword */:
-        case 159 /* UnknownKeyword */:
-        case 154 /* StringKeyword */:
-        case 150 /* NumberKeyword */:
-        case 162 /* BigIntKeyword */:
-        case 136 /* BooleanKeyword */:
-        case 155 /* SymbolKeyword */:
-        case 151 /* ObjectKeyword */:
-        case 116 /* VoidKeyword */:
-        case 157 /* UndefinedKeyword */:
-        case 146 /* NeverKeyword */:
-        case 200 /* LiteralType */:
-          return true;
-        case 187 /* ArrayType */:
-          return isThislessType(node.elementType);
-        case 182 /* TypeReference */:
-          return !node.typeArguments || node.typeArguments.every(isThislessType);
-      }
-      return false;
-    }
-    function isThislessTypeParameter(node) {
-      const constraint = getEffectiveConstraintOfTypeParameter(node);
-      return !constraint || isThislessType(constraint);
-    }
-    function isThislessVariableLikeDeclaration(node) {
-      const typeNode = getEffectiveTypeAnnotationNode(node);
-      return typeNode ? isThislessType(typeNode) : !hasInitializer(node);
-    }
-    function isThislessFunctionLikeDeclaration(node) {
-      const returnType = getEffectiveReturnTypeNode(node);
-      const typeParameters = getEffectiveTypeParameterDeclarations(node);
-      return (node.kind === 175 /* Constructor */ || !!returnType && isThislessType(returnType)) && node.parameters.every(isThislessVariableLikeDeclaration) && typeParameters.every(isThislessTypeParameter);
-    }
-    function isThisless(symbol) {
-      if (symbol.declarations && symbol.declarations.length === 1) {
-        const declaration = symbol.declarations[0];
-        if (declaration) {
-          switch (declaration.kind) {
-            case 171 /* PropertyDeclaration */:
-            case 170 /* PropertySignature */:
-              return isThislessVariableLikeDeclaration(declaration);
-            case 173 /* MethodDeclaration */:
-            case 172 /* MethodSignature */:
-            case 175 /* Constructor */:
-            case 176 /* GetAccessor */:
-            case 177 /* SetAccessor */:
-              return isThislessFunctionLikeDeclaration(declaration);
-          }
-        }
-      }
-      return false;
-    }
-    function createInstantiatedSymbolTable(symbols, mapper, mappingThisOnly) {
-      const result = createSymbolTable();
-      for (const symbol of symbols) {
-        result.set(symbol.escapedName, mappingThisOnly && isThisless(symbol) ? symbol : instantiateSymbol(symbol, mapper));
-      }
-      return result;
-    }
-    function addInheritedMembers(symbols, baseSymbols) {
-      for (const base of baseSymbols) {
-        if (isStaticPrivateIdentifierProperty(base)) {
-          continue;
-        }
-        const derived = symbols.get(base.escapedName);
-        if (!derived || derived.valueDeclaration && isBinaryExpression(derived.valueDeclaration) && !isConstructorDeclaredProperty(derived) && !getContainingClassStaticBlock(derived.valueDeclaration)) {
-          symbols.set(base.escapedName, base);
-          symbols.set(base.escapedName, base);
-        }
-      }
-    }
-    function isStaticPrivateIdentifierProperty(s) {
-      return !!s.valueDeclaration && isPrivateIdentifierClassElementDeclaration(s.valueDeclaration) && isStatic(s.valueDeclaration);
-    }
-    function resolveDeclaredMembers(type) {
-      if (!type.declaredProperties) {
-        const symbol = type.symbol;
-        const members = getMembersOfSymbol(symbol);
-        type.declaredProperties = getNamedMembers(members);
-        type.declaredCallSignatures = emptyArray;
-        type.declaredConstructSignatures = emptyArray;
-        type.declaredIndexInfos = emptyArray;
-        type.declaredCallSignatures = getSignaturesOfSymbol(members.get("__call" /* Call */));
-        type.declaredConstructSignatures = getSignaturesOfSymbol(members.get("__new" /* New */));
-        type.declaredIndexInfos = getIndexInfosOfSymbol(symbol);
-      }
-      return type;
-    }
-    function isTypeUsableAsPropertyName(type) {
-      return !!(type.flags & 8576 /* StringOrNumberLiteralOrUnique */);
-    }
-    function isLateBindableName(node) {
-      if (!isComputedPropertyName(node) && !isElementAccessExpression(node)) {
-        return false;
-      }
-      const expr = isComputedPropertyName(node) ? node.expression : node.argumentExpression;
-      return isEntityNameExpression(expr) && isTypeUsableAsPropertyName(isComputedPropertyName(node) ? checkComputedPropertyName(node) : checkExpressionCached(expr));
-    }
-    function isLateBoundName(name) {
-      return name.charCodeAt(0) === 95 /* _ */ && name.charCodeAt(1) === 95 /* _ */ && name.charCodeAt(2) === 64 /* at */;
-    }
-    function hasLateBindableName(node) {
-      const name = getNameOfDeclaration(node);
-      return !!name && isLateBindableName(name);
-    }
-    function hasBindableName(node) {
-      return !hasDynamicName(node) || hasLateBindableName(node);
-    }
-    function isNonBindableDynamicName(node) {
-      return isDynamicName(node) && !isLateBindableName(node);
-    }
-    function getPropertyNameFromType(type) {
-      if (type.flags & 8192 /* UniqueESSymbol */) {
-        return type.escapedName;
-      }
-      if (type.flags & (128 /* StringLiteral */ | 256 /* NumberLiteral */)) {
-        return escapeLeadingUnderscores("" + type.value);
-      }
-      return Debug.fail();
-    }
-    function addDeclarationToLateBoundSymbol(symbol, member, symbolFlags) {
-      Debug.assert(!!(getCheckFlags(symbol) & 4096 /* Late */), "Expected a late-bound symbol.");
-      symbol.flags |= symbolFlags;
-      getSymbolLinks(member.symbol).lateSymbol = symbol;
-      if (!symbol.declarations) {
-        symbol.declarations = [member];
-      } else if (!member.symbol.isReplaceableByMethod) {
-        symbol.declarations.push(member);
-      }
-      if (symbolFlags & 111551 /* Value */) {
-        if (!symbol.valueDeclaration || symbol.valueDeclaration.kind !== member.kind) {
-          symbol.valueDeclaration = member;
-        }
-      }
-    }
-    function lateBindMember(parent2, earlySymbols, lateSymbols, decl) {
-      Debug.assert(!!decl.symbol, "The member is expected to have a symbol.");
-      const links = getNodeLinks(decl);
-      if (!links.resolvedSymbol) {
-        links.resolvedSymbol = decl.symbol;
-        const declName = isBinaryExpression(decl) ? decl.left : decl.name;
-        const type = isElementAccessExpression(declName) ? checkExpressionCached(declName.argumentExpression) : checkComputedPropertyName(declName);
-        if (isTypeUsableAsPropertyName(type)) {
-          const memberName = getPropertyNameFromType(type);
-          const symbolFlags = decl.symbol.flags;
-          let lateSymbol = lateSymbols.get(memberName);
-          if (!lateSymbol)
-            lateSymbols.set(memberName, lateSymbol = createSymbol(0 /* None */, memberName, 4096 /* Late */));
-          const earlySymbol = earlySymbols && earlySymbols.get(memberName);
-          if (lateSymbol.flags & getExcludedSymbolFlags(symbolFlags) || earlySymbol) {
-            const declarations = earlySymbol ? concatenate(earlySymbol.declarations, lateSymbol.declarations) : lateSymbol.declarations;
-            const name = !(type.flags & 8192 /* UniqueESSymbol */) && unescapeLeadingUnderscores(memberName) || declarationNameToString(declName);
-            forEach(declarations, (declaration) => error(getNameOfDeclaration(declaration) || declaration, Diagnostics.Property_0_was_also_declared_here, name));
-            error(declName || decl, Diagnostics.Duplicate_property_0, name);
-            lateSymbol = createSymbol(0 /* None */, memberName, 4096 /* Late */);
-          }
-          lateSymbol.links.nameType = type;
-          addDeclarationToLateBoundSymbol(lateSymbol, decl, symbolFlags);
-          if (lateSymbol.parent) {
-            Debug.assert(lateSymbol.parent === parent2, "Existing symbol parent should match new one");
-          } else {
-            lateSymbol.parent = parent2;
-          }
-          return links.resolvedSymbol = lateSymbol;
-        }
-      }
-      return links.resolvedSymbol;
-    }
-    function getResolvedMembersOrExportsOfSymbol(symbol, resolutionKind) {
-      const links = getSymbolLinks(symbol);
-      if (!links[resolutionKind]) {
-        const isStatic2 = resolutionKind === "resolvedExports" /* resolvedExports */;
-        const earlySymbols = !isStatic2 ? symbol.members : symbol.flags & 1536 /* Module */ ? getExportsOfModuleWorker(symbol).exports : symbol.exports;
-        links[resolutionKind] = earlySymbols || emptySymbols;
-        const lateSymbols = createSymbolTable();
-        for (const decl of symbol.declarations || emptyArray) {
-          const members = getMembersOfDeclaration(decl);
-          if (members) {
-            for (const member of members) {
-              if (isStatic2 === hasStaticModifier(member)) {
-                if (hasLateBindableName(member)) {
-                  lateBindMember(symbol, earlySymbols, lateSymbols, member);
-                }
-              }
-            }
-          }
-        }
-        const assignments = symbol.assignmentDeclarationMembers;
-        if (assignments) {
-          const decls = arrayFrom(assignments.values());
-          for (const member of decls) {
-            const assignmentKind = getAssignmentDeclarationKind(member);
-            const isInstanceMember = assignmentKind === 3 /* PrototypeProperty */ || isBinaryExpression(member) && isPossiblyAliasedThisProperty(member, assignmentKind) || assignmentKind === 9 /* ObjectDefinePrototypeProperty */ || assignmentKind === 6 /* Prototype */;
-            if (isStatic2 === !isInstanceMember) {
-              if (hasLateBindableName(member)) {
-                lateBindMember(symbol, earlySymbols, lateSymbols, member);
-              }
-            }
-          }
-        }
-        links[resolutionKind] = combineSymbolTables(earlySymbols, lateSymbols) || emptySymbols;
-      }
-      return links[resolutionKind];
-    }
-    function getMembersOfSymbol(symbol) {
-      return symbol.flags & 6256 /* LateBindingContainer */ ? getResolvedMembersOrExportsOfSymbol(symbol, "resolvedMembers" /* resolvedMembers */) : symbol.members || emptySymbols;
-    }
-    function getLateBoundSymbol(symbol) {
-      if (symbol.flags & 106500 /* ClassMember */ && symbol.escapedName === "__computed" /* Computed */) {
-        const links = getSymbolLinks(symbol);
-        if (!links.lateSymbol && some(symbol.declarations, hasLateBindableName)) {
-          const parent2 = getMergedSymbol(symbol.parent);
-          if (some(symbol.declarations, hasStaticModifier)) {
-            getExportsOfSymbol(parent2);
-          } else {
-            getMembersOfSymbol(parent2);
-          }
-        }
-        return links.lateSymbol || (links.lateSymbol = symbol);
-      }
-      return symbol;
-    }
-    function getTypeWithThisArgument(type, thisArgument, needApparentType) {
-      if (getObjectFlags(type) & 4 /* Reference */) {
-        const target = type.target;
-        const typeArguments = getTypeArguments(type);
-        return length(target.typeParameters) === length(typeArguments) ? createTypeReference(target, concatenate(typeArguments, [thisArgument || target.thisType])) : type;
-      } else if (type.flags & 2097152 /* Intersection */) {
-        const types = sameMap(type.types, (t) => getTypeWithThisArgument(t, thisArgument, needApparentType));
-        return types !== type.types ? getIntersectionType(types) : type;
-      }
-      return needApparentType ? getApparentType(type) : type;
-    }
-    function resolveObjectTypeMembers(type, source, typeParameters, typeArguments) {
-      let mapper;
-      let members;
-      let callSignatures;
-      let constructSignatures;
-      let indexInfos;
-      if (rangeEquals(typeParameters, typeArguments, 0, typeParameters.length)) {
-        members = source.symbol ? getMembersOfSymbol(source.symbol) : createSymbolTable(source.declaredProperties);
-        callSignatures = source.declaredCallSignatures;
-        constructSignatures = source.declaredConstructSignatures;
-        indexInfos = source.declaredIndexInfos;
-      } else {
-        mapper = createTypeMapper(typeParameters, typeArguments);
-        members = createInstantiatedSymbolTable(
-          source.declaredProperties,
-          mapper,
-          /*mappingThisOnly*/
-          typeParameters.length === 1
-        );
-        callSignatures = instantiateSignatures(source.declaredCallSignatures, mapper);
-        constructSignatures = instantiateSignatures(source.declaredConstructSignatures, mapper);
-        indexInfos = instantiateIndexInfos(source.declaredIndexInfos, mapper);
-      }
-      const baseTypes = getBaseTypes(source);
-      if (baseTypes.length) {
-        if (source.symbol && members === getMembersOfSymbol(source.symbol)) {
-          members = createSymbolTable(source.declaredProperties);
-        }
-        setStructuredTypeMembers(type, members, callSignatures, constructSignatures, indexInfos);
-        const thisArgument = lastOrUndefined(typeArguments);
-        for (const baseType of baseTypes) {
-          const instantiatedBaseType = thisArgument ? getTypeWithThisArgument(instantiateType(baseType, mapper), thisArgument) : baseType;
-          addInheritedMembers(members, getPropertiesOfType(instantiatedBaseType));
-          callSignatures = concatenate(callSignatures, getSignaturesOfType(instantiatedBaseType, 0 /* Call */));
-          constructSignatures = concatenate(constructSignatures, getSignaturesOfType(instantiatedBaseType, 1 /* Construct */));
-          const inheritedIndexInfos = instantiatedBaseType !== anyType ? getIndexInfosOfType(instantiatedBaseType) : [createIndexInfo(
-            stringType,
-            anyType,
-            /*isReadonly*/
-            false
-          )];
-          indexInfos = concatenate(indexInfos, filter(inheritedIndexInfos, (info) => !findIndexInfo(indexInfos, info.keyType)));
-        }
-      }
-      setStructuredTypeMembers(type, members, callSignatures, constructSignatures, indexInfos);
-    }
-    function resolveClassOrInterfaceMembers(type) {
-      resolveObjectTypeMembers(type, resolveDeclaredMembers(type), emptyArray, emptyArray);
-    }
-    function resolveTypeReferenceMembers(type) {
-      const source = resolveDeclaredMembers(type.target);
-      const typeParameters = concatenate(source.typeParameters, [source.thisType]);
-      const typeArguments = getTypeArguments(type);
-      const paddedTypeArguments = typeArguments.length === typeParameters.length ? typeArguments : concatenate(typeArguments, [type]);
-      resolveObjectTypeMembers(type, source, typeParameters, paddedTypeArguments);
-    }
-    function createSignature(declaration, typeParameters, thisParameter, parameters, resolvedReturnType, resolvedTypePredicate, minArgumentCount, flags) {
-      const sig = new Signature15(checker, flags);
-      sig.declaration = declaration;
-      sig.typeParameters = typeParameters;
-      sig.parameters = parameters;
-      sig.thisParameter = thisParameter;
-      sig.resolvedReturnType = resolvedReturnType;
-      sig.resolvedTypePredicate = resolvedTypePredicate;
-      sig.minArgumentCount = minArgumentCount;
-      sig.resolvedMinArgumentCount = void 0;
-      sig.target = void 0;
-      sig.mapper = void 0;
-      sig.compositeSignatures = void 0;
-      sig.compositeKind = void 0;
-      return sig;
-    }
-    function cloneSignature(sig) {
-      const result = createSignature(
-        sig.declaration,
-        sig.typeParameters,
-        sig.thisParameter,
-        sig.parameters,
-        /*resolvedReturnType*/
-        void 0,
-        /*resolvedTypePredicate*/
-        void 0,
-        sig.minArgumentCount,
-        sig.flags & 39 /* PropagatingFlags */
-      );
-      result.target = sig.target;
-      result.mapper = sig.mapper;
-      result.compositeSignatures = sig.compositeSignatures;
-      result.compositeKind = sig.compositeKind;
-      return result;
-    }
-    function createUnionSignature(signature, unionSignatures) {
-      const result = cloneSignature(signature);
-      result.compositeSignatures = unionSignatures;
-      result.compositeKind = 1048576 /* Union */;
-      result.target = void 0;
-      result.mapper = void 0;
-      return result;
-    }
-    function getOptionalCallSignature(signature, callChainFlags) {
-      if ((signature.flags & 24 /* CallChainFlags */) === callChainFlags) {
-        return signature;
-      }
-      if (!signature.optionalCallSignatureCache) {
-        signature.optionalCallSignatureCache = {};
-      }
-      const key = callChainFlags === 8 /* IsInnerCallChain */ ? "inner" : "outer";
-      return signature.optionalCallSignatureCache[key] || (signature.optionalCallSignatureCache[key] = createOptionalCallSignature(signature, callChainFlags));
-    }
-    function createOptionalCallSignature(signature, callChainFlags) {
-      Debug.assert(
-        callChainFlags === 8 /* IsInnerCallChain */ || callChainFlags === 16 /* IsOuterCallChain */,
-        "An optional call signature can either be for an inner call chain or an outer call chain, but not both."
-      );
-      const result = cloneSignature(signature);
-      result.flags |= callChainFlags;
-      return result;
-    }
-    function getExpandedParameters(sig, skipUnionExpanding) {
-      if (signatureHasRestParameter(sig)) {
-        const restIndex = sig.parameters.length - 1;
-        const restType = getTypeOfSymbol(sig.parameters[restIndex]);
-        if (isTupleType(restType)) {
-          return [expandSignatureParametersWithTupleMembers(restType, restIndex)];
-        } else if (!skipUnionExpanding && restType.flags & 1048576 /* Union */ && every(restType.types, isTupleType)) {
-          return map(restType.types, (t) => expandSignatureParametersWithTupleMembers(t, restIndex));
-        }
-      }
-      return [sig.parameters];
-      function expandSignatureParametersWithTupleMembers(restType, restIndex) {
-        const elementTypes = getElementTypes(restType);
-        const associatedNames = getUniqAssociatedNamesFromTupleType(restType);
-        const restParams = map(elementTypes, (t, i) => {
-          const name = associatedNames && associatedNames[i] ? associatedNames[i] : getParameterNameAtPosition(sig, restIndex + i, restType);
-          const flags = restType.target.elementFlags[i];
-          const checkFlags = flags & 12 /* Variable */ ? 32768 /* RestParameter */ : flags & 2 /* Optional */ ? 16384 /* OptionalParameter */ : 0;
-          const symbol = createSymbol(1 /* FunctionScopedVariable */, name, checkFlags);
-          symbol.links.type = flags & 4 /* Rest */ ? createArrayType(t) : t;
-          return symbol;
-        });
-        return concatenate(sig.parameters.slice(0, restIndex), restParams);
-      }
-      function getUniqAssociatedNamesFromTupleType(type) {
-        const associatedNamesMap = /* @__PURE__ */ new Map();
-        return map(type.target.labeledElementDeclarations, (labeledElement) => {
-          const name = getTupleElementLabel(labeledElement);
-          const prevCounter = associatedNamesMap.get(name);
-          if (prevCounter === void 0) {
-            associatedNamesMap.set(name, 1);
-            return name;
-          } else {
-            associatedNamesMap.set(name, prevCounter + 1);
-            return `${name}_${prevCounter}`;
-          }
-        });
-      }
-    }
-    function getDefaultConstructSignatures(classType) {
-      const baseConstructorType = getBaseConstructorTypeOfClass(classType);
-      const baseSignatures = getSignaturesOfType(baseConstructorType, 1 /* Construct */);
-      const declaration = getClassLikeDeclarationOfSymbol(classType.symbol);
-      const isAbstract = !!declaration && hasSyntacticModifier(declaration, 256 /* Abstract */);
-      if (baseSignatures.length === 0) {
-        return [createSignature(
-          /*declaration*/
-          void 0,
-          classType.localTypeParameters,
-          /*thisParameter*/
-          void 0,
-          emptyArray,
-          classType,
-          /*resolvedTypePredicate*/
-          void 0,
-          0,
-          isAbstract ? 4 /* Abstract */ : 0 /* None */
-        )];
-      }
-      const baseTypeNode = getBaseTypeNodeOfClass(classType);
-      const isJavaScript = isInJSFile(baseTypeNode);
-      const typeArguments = typeArgumentsFromTypeReferenceNode(baseTypeNode);
-      const typeArgCount = length(typeArguments);
-      const result = [];
-      for (const baseSig of baseSignatures) {
-        const minTypeArgumentCount = getMinTypeArgumentCount(baseSig.typeParameters);
-        const typeParamCount = length(baseSig.typeParameters);
-        if (isJavaScript || typeArgCount >= minTypeArgumentCount && typeArgCount <= typeParamCount) {
-          const sig = typeParamCount ? createSignatureInstantiation(baseSig, fillMissingTypeArguments(typeArguments, baseSig.typeParameters, minTypeArgumentCount, isJavaScript)) : cloneSignature(baseSig);
-          sig.typeParameters = classType.localTypeParameters;
-          sig.resolvedReturnType = classType;
-          sig.flags = isAbstract ? sig.flags | 4 /* Abstract */ : sig.flags & ~4 /* Abstract */;
-          result.push(sig);
-        }
-      }
-      return result;
-    }
-    function findMatchingSignature(signatureList, signature, partialMatch, ignoreThisTypes, ignoreReturnTypes) {
-      for (const s of signatureList) {
-        if (compareSignaturesIdentical(s, signature, partialMatch, ignoreThisTypes, ignoreReturnTypes, partialMatch ? compareTypesSubtypeOf : compareTypesIdentical)) {
-          return s;
-        }
-      }
-    }
-    function findMatchingSignatures(signatureLists, signature, listIndex) {
-      if (signature.typeParameters) {
-        if (listIndex > 0) {
-          return void 0;
-        }
-        for (let i = 1; i < signatureLists.length; i++) {
-          if (!findMatchingSignature(
-            signatureLists[i],
-            signature,
-            /*partialMatch*/
-            false,
-            /*ignoreThisTypes*/
-            false,
-            /*ignoreReturnTypes*/
-            false
-          )) {
-            return void 0;
-          }
-        }
-        return [signature];
-      }
-      let result;
-      for (let i = 0; i < signatureLists.length; i++) {
-        const match = i === listIndex ? signature : findMatchingSignature(
-          signatureLists[i],
-          signature,
-          /*partialMatch*/
-          true,
-          /*ignoreThisTypes*/
-          false,
-          /*ignoreReturnTypes*/
-          true
-        );
-        if (!match) {
-          return void 0;
-        }
-        result = appendIfUnique(result, match);
-      }
-      return result;
-    }
-    function getUnionSignatures(signatureLists) {
-      let result;
-      let indexWithLengthOverOne;
-      for (let i = 0; i < signatureLists.length; i++) {
-        if (signatureLists[i].length === 0)
-          return emptyArray;
-        if (signatureLists[i].length > 1) {
-          indexWithLengthOverOne = indexWithLengthOverOne === void 0 ? i : -1;
-        }
-        for (const signature of signatureLists[i]) {
-          if (!result || !findMatchingSignature(
-            result,
-            signature,
-            /*partialMatch*/
-            false,
-            /*ignoreThisTypes*/
-            false,
-            /*ignoreReturnTypes*/
-            true
-          )) {
-            const unionSignatures = findMatchingSignatures(signatureLists, signature, i);
-            if (unionSignatures) {
-              let s = signature;
-              if (unionSignatures.length > 1) {
-                let thisParameter = signature.thisParameter;
-                const firstThisParameterOfUnionSignatures = forEach(unionSignatures, (sig) => sig.thisParameter);
-                if (firstThisParameterOfUnionSignatures) {
-                  const thisType = getIntersectionType(mapDefined(unionSignatures, (sig) => sig.thisParameter && getTypeOfSymbol(sig.thisParameter)));
-                  thisParameter = createSymbolWithType(firstThisParameterOfUnionSignatures, thisType);
-                }
-                s = createUnionSignature(signature, unionSignatures);
-                s.thisParameter = thisParameter;
-              }
-              (result || (result = [])).push(s);
-            }
-          }
-        }
-      }
-      if (!length(result) && indexWithLengthOverOne !== -1) {
-        const masterList = signatureLists[indexWithLengthOverOne !== void 0 ? indexWithLengthOverOne : 0];
-        let results = masterList.slice();
-        for (const signatures of signatureLists) {
-          if (signatures !== masterList) {
-            const signature = signatures[0];
-            Debug.assert(!!signature, "getUnionSignatures bails early on empty signature lists and should not have empty lists on second pass");
-            results = !!signature.typeParameters && some(results, (s) => !!s.typeParameters && !compareTypeParametersIdentical(signature.typeParameters, s.typeParameters)) ? void 0 : map(results, (sig) => combineSignaturesOfUnionMembers(sig, signature));
-            if (!results) {
-              break;
-            }
-          }
-        }
-        result = results;
-      }
-      return result || emptyArray;
-    }
-    function compareTypeParametersIdentical(sourceParams, targetParams) {
-      if (length(sourceParams) !== length(targetParams)) {
-        return false;
-      }
-      if (!sourceParams || !targetParams) {
-        return true;
-      }
-      const mapper = createTypeMapper(targetParams, sourceParams);
-      for (let i = 0; i < sourceParams.length; i++) {
-        const source = sourceParams[i];
-        const target = targetParams[i];
-        if (source === target)
-          continue;
-        if (!isTypeIdenticalTo(getConstraintFromTypeParameter(source) || unknownType, instantiateType(getConstraintFromTypeParameter(target) || unknownType, mapper)))
-          return false;
-      }
-      return true;
-    }
-    function combineUnionThisParam(left, right, mapper) {
-      if (!left || !right) {
-        return left || right;
-      }
-      const thisType = getIntersectionType([getTypeOfSymbol(left), instantiateType(getTypeOfSymbol(right), mapper)]);
-      return createSymbolWithType(left, thisType);
-    }
-    function combineUnionParameters(left, right, mapper) {
-      const leftCount = getParameterCount(left);
-      const rightCount = getParameterCount(right);
-      const longest = leftCount >= rightCount ? left : right;
-      const shorter = longest === left ? right : left;
-      const longestCount = longest === left ? leftCount : rightCount;
-      const eitherHasEffectiveRest = hasEffectiveRestParameter(left) || hasEffectiveRestParameter(right);
-      const needsExtraRestElement = eitherHasEffectiveRest && !hasEffectiveRestParameter(longest);
-      const params = new Array(longestCount + (needsExtraRestElement ? 1 : 0));
-      for (let i = 0; i < longestCount; i++) {
-        let longestParamType = tryGetTypeAtPosition(longest, i);
-        if (longest === right) {
-          longestParamType = instantiateType(longestParamType, mapper);
-        }
-        let shorterParamType = tryGetTypeAtPosition(shorter, i) || unknownType;
-        if (shorter === right) {
-          shorterParamType = instantiateType(shorterParamType, mapper);
-        }
-        const unionParamType = getIntersectionType([longestParamType, shorterParamType]);
-        const isRestParam = eitherHasEffectiveRest && !needsExtraRestElement && i === longestCount - 1;
-        const isOptional = i >= getMinArgumentCount(longest) && i >= getMinArgumentCount(shorter);
-        const leftName = i >= leftCount ? void 0 : getParameterNameAtPosition(left, i);
-        const rightName = i >= rightCount ? void 0 : getParameterNameAtPosition(right, i);
-        const paramName = leftName === rightName ? leftName : !leftName ? rightName : !rightName ? leftName : void 0;
-        const paramSymbol = createSymbol(
-          1 /* FunctionScopedVariable */ | (isOptional && !isRestParam ? 16777216 /* Optional */ : 0),
-          paramName || `arg${i}`
-        );
-        paramSymbol.links.type = isRestParam ? createArrayType(unionParamType) : unionParamType;
-        params[i] = paramSymbol;
-      }
-      if (needsExtraRestElement) {
-        const restParamSymbol = createSymbol(1 /* FunctionScopedVariable */, "args");
-        restParamSymbol.links.type = createArrayType(getTypeAtPosition(shorter, longestCount));
-        if (shorter === right) {
-          restParamSymbol.links.type = instantiateType(restParamSymbol.links.type, mapper);
-        }
-        params[longestCount] = restParamSymbol;
-      }
-      return params;
-    }
-    function combineSignaturesOfUnionMembers(left, right) {
-      const typeParams = left.typeParameters || right.typeParameters;
-      let paramMapper;
-      if (left.typeParameters && right.typeParameters) {
-        paramMapper = createTypeMapper(right.typeParameters, left.typeParameters);
-      }
-      const declaration = left.declaration;
-      const params = combineUnionParameters(left, right, paramMapper);
-      const thisParam = combineUnionThisParam(left.thisParameter, right.thisParameter, paramMapper);
-      const minArgCount = Math.max(left.minArgumentCount, right.minArgumentCount);
-      const result = createSignature(
-        declaration,
-        typeParams,
-        thisParam,
-        params,
-        /*resolvedReturnType*/
-        void 0,
-        /*resolvedTypePredicate*/
-        void 0,
-        minArgCount,
-        (left.flags | right.flags) & 39 /* PropagatingFlags */
-      );
-      result.compositeKind = 1048576 /* Union */;
-      result.compositeSignatures = concatenate(left.compositeKind !== 2097152 /* Intersection */ && left.compositeSignatures || [left], [right]);
-      if (paramMapper) {
-        result.mapper = left.compositeKind !== 2097152 /* Intersection */ && left.mapper && left.compositeSignatures ? combineTypeMappers(left.mapper, paramMapper) : paramMapper;
-      }
-      return result;
-    }
-    function getUnionIndexInfos(types) {
-      const sourceInfos = getIndexInfosOfType(types[0]);
-      if (sourceInfos) {
-        const result = [];
-        for (const info of sourceInfos) {
-          const indexType = info.keyType;
-          if (every(types, (t) => !!getIndexInfoOfType(t, indexType))) {
-            result.push(createIndexInfo(
-              indexType,
-              getUnionType(map(types, (t) => getIndexTypeOfType(t, indexType))),
-              some(types, (t) => getIndexInfoOfType(t, indexType).isReadonly)
-            ));
-          }
-        }
-        return result;
-      }
-      return emptyArray;
-    }
-    function resolveUnionTypeMembers(type) {
-      const callSignatures = getUnionSignatures(map(type.types, (t) => t === globalFunctionType ? [unknownSignature] : getSignaturesOfType(t, 0 /* Call */)));
-      const constructSignatures = getUnionSignatures(map(type.types, (t) => getSignaturesOfType(t, 1 /* Construct */)));
-      const indexInfos = getUnionIndexInfos(type.types);
-      setStructuredTypeMembers(type, emptySymbols, callSignatures, constructSignatures, indexInfos);
-    }
-    function intersectTypes(type1, type2) {
-      return !type1 ? type2 : !type2 ? type1 : getIntersectionType([type1, type2]);
-    }
-    function findMixins(types) {
-      const constructorTypeCount = countWhere(types, (t) => getSignaturesOfType(t, 1 /* Construct */).length > 0);
-      const mixinFlags = map(types, isMixinConstructorType);
-      if (constructorTypeCount > 0 && constructorTypeCount === countWhere(mixinFlags, (b) => b)) {
-        const firstMixinIndex = mixinFlags.indexOf(
-          /*searchElement*/
-          true
-        );
-        mixinFlags[firstMixinIndex] = false;
-      }
-      return mixinFlags;
-    }
-    function includeMixinType(type, types, mixinFlags, index) {
-      const mixedTypes = [];
-      for (let i = 0; i < types.length; i++) {
-        if (i === index) {
-          mixedTypes.push(type);
-        } else if (mixinFlags[i]) {
-          mixedTypes.push(getReturnTypeOfSignature(getSignaturesOfType(types[i], 1 /* Construct */)[0]));
-        }
-      }
-      return getIntersectionType(mixedTypes);
-    }
-    function resolveIntersectionTypeMembers(type) {
-      let callSignatures;
-      let constructSignatures;
-      let indexInfos;
-      const types = type.types;
-      const mixinFlags = findMixins(types);
-      const mixinCount = countWhere(mixinFlags, (b) => b);
-      for (let i = 0; i < types.length; i++) {
-        const t = type.types[i];
-        if (!mixinFlags[i]) {
-          let signatures = getSignaturesOfType(t, 1 /* Construct */);
-          if (signatures.length && mixinCount > 0) {
-            signatures = map(signatures, (s) => {
-              const clone2 = cloneSignature(s);
-              clone2.resolvedReturnType = includeMixinType(getReturnTypeOfSignature(s), types, mixinFlags, i);
-              return clone2;
-            });
-          }
-          constructSignatures = appendSignatures(constructSignatures, signatures);
-        }
-        callSignatures = appendSignatures(callSignatures, getSignaturesOfType(t, 0 /* Call */));
-        indexInfos = reduceLeft(getIndexInfosOfType(t), (infos, newInfo) => appendIndexInfo(
-          infos,
-          newInfo,
-          /*union*/
-          false
-        ), indexInfos);
-      }
-      setStructuredTypeMembers(type, emptySymbols, callSignatures || emptyArray, constructSignatures || emptyArray, indexInfos || emptyArray);
-    }
-    function appendSignatures(signatures, newSignatures) {
-      for (const sig of newSignatures) {
-        if (!signatures || every(signatures, (s) => !compareSignaturesIdentical(
-          s,
-          sig,
-          /*partialMatch*/
-          false,
-          /*ignoreThisTypes*/
-          false,
-          /*ignoreReturnTypes*/
-          false,
-          compareTypesIdentical
-        ))) {
-          signatures = append(signatures, sig);
-        }
-      }
-      return signatures;
-    }
-    function appendIndexInfo(indexInfos, newInfo, union) {
-      if (indexInfos) {
-        for (let i = 0; i < indexInfos.length; i++) {
-          const info = indexInfos[i];
-          if (info.keyType === newInfo.keyType) {
-            indexInfos[i] = createIndexInfo(
-              info.keyType,
-              union ? getUnionType([info.type, newInfo.type]) : getIntersectionType([info.type, newInfo.type]),
-              union ? info.isReadonly || newInfo.isReadonly : info.isReadonly && newInfo.isReadonly
-            );
-            return indexInfos;
-          }
-        }
-      }
-      return append(indexInfos, newInfo);
-    }
-    function resolveAnonymousTypeMembers(type) {
-      if (type.target) {
-        setStructuredTypeMembers(type, emptySymbols, emptyArray, emptyArray, emptyArray);
-        const members2 = createInstantiatedSymbolTable(
-          getPropertiesOfObjectType(type.target),
-          type.mapper,
-          /*mappingThisOnly*/
-          false
-        );
-        const callSignatures = instantiateSignatures(getSignaturesOfType(type.target, 0 /* Call */), type.mapper);
-        const constructSignatures = instantiateSignatures(getSignaturesOfType(type.target, 1 /* Construct */), type.mapper);
-        const indexInfos2 = instantiateIndexInfos(getIndexInfosOfType(type.target), type.mapper);
-        setStructuredTypeMembers(type, members2, callSignatures, constructSignatures, indexInfos2);
-        return;
-      }
-      const symbol = getMergedSymbol(type.symbol);
-      if (symbol.flags & 2048 /* TypeLiteral */) {
-        setStructuredTypeMembers(type, emptySymbols, emptyArray, emptyArray, emptyArray);
-        const members2 = getMembersOfSymbol(symbol);
-        const callSignatures = getSignaturesOfSymbol(members2.get("__call" /* Call */));
-        const constructSignatures = getSignaturesOfSymbol(members2.get("__new" /* New */));
-        const indexInfos2 = getIndexInfosOfSymbol(symbol);
-        setStructuredTypeMembers(type, members2, callSignatures, constructSignatures, indexInfos2);
-        return;
-      }
-      let members = emptySymbols;
-      let indexInfos;
-      if (symbol.exports) {
-        members = getExportsOfSymbol(symbol);
-        if (symbol === globalThisSymbol) {
-          const varsOnly = /* @__PURE__ */ new Map();
-          members.forEach((p) => {
-            var _a;
-            if (!(p.flags & 418 /* BlockScoped */) && !(p.flags & 512 /* ValueModule */ && ((_a = p.declarations) == null ? void 0 : _a.length) && every(p.declarations, isAmbientModule))) {
-              varsOnly.set(p.escapedName, p);
-            }
-          });
-          members = varsOnly;
-        }
-      }
-      let baseConstructorIndexInfo;
-      setStructuredTypeMembers(type, members, emptyArray, emptyArray, emptyArray);
-      if (symbol.flags & 32 /* Class */) {
-        const classType = getDeclaredTypeOfClassOrInterface(symbol);
-        const baseConstructorType = getBaseConstructorTypeOfClass(classType);
-        if (baseConstructorType.flags & (524288 /* Object */ | 2097152 /* Intersection */ | 8650752 /* TypeVariable */)) {
-          members = createSymbolTable(getNamedOrIndexSignatureMembers(members));
-          addInheritedMembers(members, getPropertiesOfType(baseConstructorType));
-        } else if (baseConstructorType === anyType) {
-          baseConstructorIndexInfo = createIndexInfo(
-            stringType,
-            anyType,
-            /*isReadonly*/
-            false
-          );
-        }
-      }
-      const indexSymbol = getIndexSymbolFromSymbolTable(members);
-      if (indexSymbol) {
-        indexInfos = getIndexInfosOfIndexSymbol(indexSymbol);
-      } else {
-        if (baseConstructorIndexInfo) {
-          indexInfos = append(indexInfos, baseConstructorIndexInfo);
-        }
-        if (symbol.flags & 384 /* Enum */ && (getDeclaredTypeOfSymbol(symbol).flags & 32 /* Enum */ || some(type.properties, (prop) => !!(getTypeOfSymbol(prop).flags & 296 /* NumberLike */)))) {
-          indexInfos = append(indexInfos, enumNumberIndexInfo);
-        }
-      }
-      setStructuredTypeMembers(type, members, emptyArray, emptyArray, indexInfos || emptyArray);
-      if (symbol.flags & (16 /* Function */ | 8192 /* Method */)) {
-        type.callSignatures = getSignaturesOfSymbol(symbol);
-      }
-      if (symbol.flags & 32 /* Class */) {
-        const classType = getDeclaredTypeOfClassOrInterface(symbol);
-        let constructSignatures = symbol.members ? getSignaturesOfSymbol(symbol.members.get("__constructor" /* Constructor */)) : emptyArray;
-        if (symbol.flags & 16 /* Function */) {
-          constructSignatures = addRange(constructSignatures.slice(), mapDefined(
-            type.callSignatures,
-            (sig) => isJSConstructor(sig.declaration) ? createSignature(
-              sig.declaration,
-              sig.typeParameters,
-              sig.thisParameter,
-              sig.parameters,
-              classType,
-              /*resolvedTypePredicate*/
-              void 0,
-              sig.minArgumentCount,
-              sig.flags & 39 /* PropagatingFlags */
-            ) : void 0
-          ));
-        }
-        if (!constructSignatures.length) {
-          constructSignatures = getDefaultConstructSignatures(classType);
-        }
-        type.constructSignatures = constructSignatures;
-      }
-    }
-    function replaceIndexedAccess(instantiable, type, replacement) {
-      return instantiateType(instantiable, createTypeMapper([type.indexType, type.objectType], [getNumberLiteralType(0), createTupleType([replacement])]));
-    }
-    function resolveReverseMappedTypeMembers(type) {
-      const indexInfo = getIndexInfoOfType(type.source, stringType);
-      const modifiers = getMappedTypeModifiers(type.mappedType);
-      const readonlyMask = modifiers & 1 /* IncludeReadonly */ ? false : true;
-      const optionalMask = modifiers & 4 /* IncludeOptional */ ? 0 : 16777216 /* Optional */;
-      const indexInfos = indexInfo ? [createIndexInfo(stringType, inferReverseMappedType(indexInfo.type, type.mappedType, type.constraintType), readonlyMask && indexInfo.isReadonly)] : emptyArray;
-      const members = createSymbolTable();
-      for (const prop of getPropertiesOfType(type.source)) {
-        const checkFlags = 8192 /* ReverseMapped */ | (readonlyMask && isReadonlySymbol(prop) ? 8 /* Readonly */ : 0);
-        const inferredProp = createSymbol(4 /* Property */ | prop.flags & optionalMask, prop.escapedName, checkFlags);
-        inferredProp.declarations = prop.declarations;
-        inferredProp.links.nameType = getSymbolLinks(prop).nameType;
-        inferredProp.links.propertyType = getTypeOfSymbol(prop);
-        if (type.constraintType.type.flags & 8388608 /* IndexedAccess */ && type.constraintType.type.objectType.flags & 262144 /* TypeParameter */ && type.constraintType.type.indexType.flags & 262144 /* TypeParameter */) {
-          const newTypeParam = type.constraintType.type.objectType;
-          const newMappedType = replaceIndexedAccess(type.mappedType, type.constraintType.type, newTypeParam);
-          inferredProp.links.mappedType = newMappedType;
-          inferredProp.links.constraintType = getIndexType(newTypeParam);
-        } else {
-          inferredProp.links.mappedType = type.mappedType;
-          inferredProp.links.constraintType = type.constraintType;
-        }
-        members.set(prop.escapedName, inferredProp);
-      }
-      setStructuredTypeMembers(type, members, emptyArray, emptyArray, indexInfos);
-    }
-    function getLowerBoundOfKeyType(type) {
-      if (type.flags & 4194304 /* Index */) {
-        const t = getApparentType(type.type);
-        return isGenericTupleType(t) ? getKnownKeysOfTupleType(t) : getIndexType(t);
-      }
-      if (type.flags & 16777216 /* Conditional */) {
-        if (type.root.isDistributive) {
-          const checkType = type.checkType;
-          const constraint = getLowerBoundOfKeyType(checkType);
-          if (constraint !== checkType) {
-            return getConditionalTypeInstantiation(type, prependTypeMapping(type.root.checkType, constraint, type.mapper));
-          }
-        }
-        return type;
-      }
-      if (type.flags & 1048576 /* Union */) {
-        return mapType(
-          type,
-          getLowerBoundOfKeyType,
-          /*noReductions*/
-          true
-        );
-      }
-      if (type.flags & 2097152 /* Intersection */) {
-        const types = type.types;
-        if (types.length === 2 && !!(types[0].flags & (4 /* String */ | 8 /* Number */ | 64 /* BigInt */)) && types[1] === emptyTypeLiteralType) {
-          return type;
-        }
-        return getIntersectionType(sameMap(type.types, getLowerBoundOfKeyType));
-      }
-      return type;
-    }
-    function getIsLateCheckFlag(s) {
-      return getCheckFlags(s) & 4096 /* Late */;
-    }
-    function forEachMappedTypePropertyKeyTypeAndIndexSignatureKeyType(type, include, stringsOnly, cb) {
-      for (const prop of getPropertiesOfType(type)) {
-        cb(getLiteralTypeFromProperty(prop, include));
-      }
-      if (type.flags & 1 /* Any */) {
-        cb(stringType);
-      } else {
-        for (const info of getIndexInfosOfType(type)) {
-          if (!stringsOnly || info.keyType.flags & (4 /* String */ | 134217728 /* TemplateLiteral */)) {
-            cb(info.keyType);
-          }
-        }
-      }
-    }
-    function resolveMappedTypeMembers(type) {
-      const members = createSymbolTable();
-      let indexInfos;
-      setStructuredTypeMembers(type, emptySymbols, emptyArray, emptyArray, emptyArray);
-      const typeParameter = getTypeParameterFromMappedType(type);
-      const constraintType = getConstraintTypeFromMappedType(type);
-      const mappedType = type.target || type;
-      const nameType = getNameTypeFromMappedType(mappedType);
-      const shouldLinkPropDeclarations = !nameType || isFilteringMappedType(mappedType);
-      const templateType = getTemplateTypeFromMappedType(mappedType);
-      const modifiersType = getApparentType(getModifiersTypeFromMappedType(type));
-      const templateModifiers = getMappedTypeModifiers(type);
-      const include = keyofStringsOnly ? 128 /* StringLiteral */ : 8576 /* StringOrNumberLiteralOrUnique */;
-      if (isMappedTypeWithKeyofConstraintDeclaration(type)) {
-        forEachMappedTypePropertyKeyTypeAndIndexSignatureKeyType(modifiersType, include, keyofStringsOnly, addMemberForKeyType);
-      } else {
-        forEachType(getLowerBoundOfKeyType(constraintType), addMemberForKeyType);
-      }
-      setStructuredTypeMembers(type, members, emptyArray, emptyArray, indexInfos || emptyArray);
-      function addMemberForKeyType(keyType) {
-        const propNameType = nameType ? instantiateType(nameType, appendTypeMapping(type.mapper, typeParameter, keyType)) : keyType;
-        forEachType(propNameType, (t) => addMemberForKeyTypeWorker(keyType, t));
-      }
-      function addMemberForKeyTypeWorker(keyType, propNameType) {
-        if (isTypeUsableAsPropertyName(propNameType)) {
-          const propName = getPropertyNameFromType(propNameType);
-          const existingProp = members.get(propName);
-          if (existingProp) {
-            existingProp.links.nameType = getUnionType([existingProp.links.nameType, propNameType]);
-            existingProp.links.keyType = getUnionType([existingProp.links.keyType, keyType]);
-          } else {
-            const modifiersProp = isTypeUsableAsPropertyName(keyType) ? getPropertyOfType(modifiersType, getPropertyNameFromType(keyType)) : void 0;
-            const isOptional = !!(templateModifiers & 4 /* IncludeOptional */ || !(templateModifiers & 8 /* ExcludeOptional */) && modifiersProp && modifiersProp.flags & 16777216 /* Optional */);
-            const isReadonly = !!(templateModifiers & 1 /* IncludeReadonly */ || !(templateModifiers & 2 /* ExcludeReadonly */) && modifiersProp && isReadonlySymbol(modifiersProp));
-            const stripOptional = strictNullChecks && !isOptional && modifiersProp && modifiersProp.flags & 16777216 /* Optional */;
-            const lateFlag = modifiersProp ? getIsLateCheckFlag(modifiersProp) : 0;
-            const prop = createSymbol(
-              4 /* Property */ | (isOptional ? 16777216 /* Optional */ : 0),
-              propName,
-              lateFlag | 262144 /* Mapped */ | (isReadonly ? 8 /* Readonly */ : 0) | (stripOptional ? 524288 /* StripOptional */ : 0)
-            );
-            prop.links.mappedType = type;
-            prop.links.nameType = propNameType;
-            prop.links.keyType = keyType;
-            if (modifiersProp) {
-              prop.links.syntheticOrigin = modifiersProp;
-              prop.declarations = shouldLinkPropDeclarations ? modifiersProp.declarations : void 0;
-            }
-            members.set(propName, prop);
-          }
-        } else if (isValidIndexKeyType(propNameType) || propNameType.flags & (1 /* Any */ | 32 /* Enum */)) {
-          const indexKeyType = propNameType.flags & (1 /* Any */ | 4 /* String */) ? stringType : propNameType.flags & (8 /* Number */ | 32 /* Enum */) ? numberType : propNameType;
-          const propType = instantiateType(templateType, appendTypeMapping(type.mapper, typeParameter, keyType));
-          const indexInfo = createIndexInfo(indexKeyType, propType, !!(templateModifiers & 1 /* IncludeReadonly */));
-          indexInfos = appendIndexInfo(
-            indexInfos,
-            indexInfo,
-            /*union*/
-            true
-          );
-        }
-      }
-    }
-    function getTypeOfMappedSymbol(symbol) {
-      if (!symbol.links.type) {
-        const mappedType = symbol.links.mappedType;
-        if (!pushTypeResolution(symbol, 0 /* Type */)) {
-          mappedType.containsError = true;
-          return errorType;
-        }
-        const templateType = getTemplateTypeFromMappedType(mappedType.target || mappedType);
-        const mapper = appendTypeMapping(mappedType.mapper, getTypeParameterFromMappedType(mappedType), symbol.links.keyType);
-        const propType = instantiateType(templateType, mapper);
-        let type = strictNullChecks && symbol.flags & 16777216 /* Optional */ && !maybeTypeOfKind(propType, 32768 /* Undefined */ | 16384 /* Void */) ? getOptionalType(
-          propType,
-          /*isProperty*/
-          true
-        ) : symbol.links.checkFlags & 524288 /* StripOptional */ ? removeMissingOrUndefinedType(propType) : propType;
-        if (!popTypeResolution()) {
-          error(currentNode, Diagnostics.Type_of_property_0_circularly_references_itself_in_mapped_type_1, symbolToString(symbol), typeToString(mappedType));
-          type = errorType;
-        }
-        symbol.links.type = type;
-      }
-      return symbol.links.type;
-    }
-    function getTypeParameterFromMappedType(type) {
-      return type.typeParameter || (type.typeParameter = getDeclaredTypeOfTypeParameter(getSymbolOfDeclaration(type.declaration.typeParameter)));
-    }
-    function getConstraintTypeFromMappedType(type) {
-      return type.constraintType || (type.constraintType = getConstraintOfTypeParameter(getTypeParameterFromMappedType(type)) || errorType);
-    }
-    function getNameTypeFromMappedType(type) {
-      return type.declaration.nameType ? type.nameType || (type.nameType = instantiateType(getTypeFromTypeNode(type.declaration.nameType), type.mapper)) : void 0;
-    }
-    function getTemplateTypeFromMappedType(type) {
-      return type.templateType || (type.templateType = type.declaration.type ? instantiateType(addOptionality(
-        getTypeFromTypeNode(type.declaration.type),
-        /*isProperty*/
-        true,
-        !!(getMappedTypeModifiers(type) & 4 /* IncludeOptional */)
-      ), type.mapper) : errorType);
-    }
-    function getConstraintDeclarationForMappedType(type) {
-      return getEffectiveConstraintOfTypeParameter(type.declaration.typeParameter);
-    }
-    function isMappedTypeWithKeyofConstraintDeclaration(type) {
-      const constraintDeclaration = getConstraintDeclarationForMappedType(type);
-      return constraintDeclaration.kind === 197 /* TypeOperator */ && constraintDeclaration.operator === 143 /* KeyOfKeyword */;
-    }
-    function getModifiersTypeFromMappedType(type) {
-      if (!type.modifiersType) {
-        if (isMappedTypeWithKeyofConstraintDeclaration(type)) {
-          type.modifiersType = instantiateType(getTypeFromTypeNode(getConstraintDeclarationForMappedType(type).type), type.mapper);
-        } else {
-          const declaredType = getTypeFromMappedTypeNode(type.declaration);
-          const constraint = getConstraintTypeFromMappedType(declaredType);
-          const extendedConstraint = constraint && constraint.flags & 262144 /* TypeParameter */ ? getConstraintOfTypeParameter(constraint) : constraint;
-          type.modifiersType = extendedConstraint && extendedConstraint.flags & 4194304 /* Index */ ? instantiateType(extendedConstraint.type, type.mapper) : unknownType;
-        }
-      }
-      return type.modifiersType;
-    }
-    function getMappedTypeModifiers(type) {
-      const declaration = type.declaration;
-      return (declaration.readonlyToken ? declaration.readonlyToken.kind === 41 /* MinusToken */ ? 2 /* ExcludeReadonly */ : 1 /* IncludeReadonly */ : 0) | (declaration.questionToken ? declaration.questionToken.kind === 41 /* MinusToken */ ? 8 /* ExcludeOptional */ : 4 /* IncludeOptional */ : 0);
-    }
-    function getMappedTypeOptionality(type) {
-      const modifiers = getMappedTypeModifiers(type);
-      return modifiers & 8 /* ExcludeOptional */ ? -1 : modifiers & 4 /* IncludeOptional */ ? 1 : 0;
-    }
-    function getCombinedMappedTypeOptionality(type) {
-      const optionality = getMappedTypeOptionality(type);
-      const modifiersType = getModifiersTypeFromMappedType(type);
-      return optionality || (isGenericMappedType(modifiersType) ? getMappedTypeOptionality(modifiersType) : 0);
-    }
-    function isPartialMappedType(type) {
-      return !!(getObjectFlags(type) & 32 /* Mapped */ && getMappedTypeModifiers(type) & 4 /* IncludeOptional */);
-    }
-    function isGenericMappedType(type) {
-      if (getObjectFlags(type) & 32 /* Mapped */) {
-        const constraint = getConstraintTypeFromMappedType(type);
-        if (isGenericIndexType(constraint)) {
-          return true;
-        }
-        const nameType = getNameTypeFromMappedType(type);
-        if (nameType && isGenericIndexType(instantiateType(nameType, makeUnaryTypeMapper(getTypeParameterFromMappedType(type), constraint)))) {
-          return true;
-        }
-      }
-      return false;
-    }
-    function isFilteringMappedType(type) {
-      const nameType = getNameTypeFromMappedType(type);
-      return !!nameType && isTypeAssignableTo(nameType, getTypeParameterFromMappedType(type));
-    }
-    function resolveStructuredTypeMembers(type) {
-      if (!type.members) {
-        if (type.flags & 524288 /* Object */) {
-          if (type.objectFlags & 4 /* Reference */) {
-            resolveTypeReferenceMembers(type);
-          } else if (type.objectFlags & 3 /* ClassOrInterface */) {
-            resolveClassOrInterfaceMembers(type);
-          } else if (type.objectFlags & 1024 /* ReverseMapped */) {
-            resolveReverseMappedTypeMembers(type);
-          } else if (type.objectFlags & 16 /* Anonymous */) {
-            resolveAnonymousTypeMembers(type);
-          } else if (type.objectFlags & 32 /* Mapped */) {
-            resolveMappedTypeMembers(type);
-          } else {
-            Debug.fail("Unhandled object type " + Debug.formatObjectFlags(type.objectFlags));
-          }
-        } else if (type.flags & 1048576 /* Union */) {
-          resolveUnionTypeMembers(type);
-        } else if (type.flags & 2097152 /* Intersection */) {
-          resolveIntersectionTypeMembers(type);
-        } else {
-          Debug.fail("Unhandled type " + Debug.formatTypeFlags(type.flags));
-        }
-      }
-      return type;
-    }
-    function getPropertiesOfObjectType(type) {
-      if (type.flags & 524288 /* Object */) {
-        return resolveStructuredTypeMembers(type).properties;
-      }
-      return emptyArray;
-    }
-    function getPropertyOfObjectType(type, name) {
-      if (type.flags & 524288 /* Object */) {
-        const resolved = resolveStructuredTypeMembers(type);
-        const symbol = resolved.members.get(name);
-        if (symbol && symbolIsValue(symbol)) {
-          return symbol;
-        }
-      }
-    }
-    function getPropertiesOfUnionOrIntersectionType(type) {
-      if (!type.resolvedProperties) {
-        const members = createSymbolTable();
-        for (const current of type.types) {
-          for (const prop of getPropertiesOfType(current)) {
-            if (!members.has(prop.escapedName)) {
-              const combinedProp = getPropertyOfUnionOrIntersectionType(type, prop.escapedName);
-              if (combinedProp) {
-                members.set(prop.escapedName, combinedProp);
-              }
-            }
-          }
-          if (type.flags & 1048576 /* Union */ && getIndexInfosOfType(current).length === 0) {
-            break;
-          }
-        }
-        type.resolvedProperties = getNamedMembers(members);
-      }
-      return type.resolvedProperties;
-    }
-    function getPropertiesOfType(type) {
-      type = getReducedApparentType(type);
-      return type.flags & 3145728 /* UnionOrIntersection */ ? getPropertiesOfUnionOrIntersectionType(type) : getPropertiesOfObjectType(type);
-    }
-    function forEachPropertyOfType(type, action) {
-      type = getReducedApparentType(type);
-      if (type.flags & 3670016 /* StructuredType */) {
-        resolveStructuredTypeMembers(type).members.forEach((symbol, escapedName) => {
-          if (isNamedMember(symbol, escapedName)) {
-            action(symbol, escapedName);
-          }
-        });
-      }
-    }
-    function isTypeInvalidDueToUnionDiscriminant(contextualType, obj) {
-      const list = obj.properties;
-      return list.some((property) => {
-        const nameType = property.name && (isJsxNamespacedName(property.name) ? getStringLiteralType(getTextOfJsxAttributeName(property.name)) : getLiteralTypeFromPropertyName(property.name));
-        const name = nameType && isTypeUsableAsPropertyName(nameType) ? getPropertyNameFromType(nameType) : void 0;
-        const expected = name === void 0 ? void 0 : getTypeOfPropertyOfType(contextualType, name);
-        return !!expected && isLiteralType(expected) && !isTypeAssignableTo(getTypeOfNode(property), expected);
-      });
-    }
-    function getAllPossiblePropertiesOfTypes(types) {
-      const unionType = getUnionType(types);
-      if (!(unionType.flags & 1048576 /* Union */)) {
-        return getAugmentedPropertiesOfType(unionType);
-      }
-      const props = createSymbolTable();
-      for (const memberType of types) {
-        for (const { escapedName } of getAugmentedPropertiesOfType(memberType)) {
-          if (!props.has(escapedName)) {
-            const prop = createUnionOrIntersectionProperty(unionType, escapedName);
-            if (prop)
-              props.set(escapedName, prop);
-          }
-        }
-      }
-      return arrayFrom(props.values());
-    }
-    function getConstraintOfType(type) {
-      return type.flags & 262144 /* TypeParameter */ ? getConstraintOfTypeParameter(type) : type.flags & 8388608 /* IndexedAccess */ ? getConstraintOfIndexedAccess(type) : type.flags & 16777216 /* Conditional */ ? getConstraintOfConditionalType(type) : getBaseConstraintOfType(type);
-    }
-    function getConstraintOfTypeParameter(typeParameter) {
-      return hasNonCircularBaseConstraint(typeParameter) ? getConstraintFromTypeParameter(typeParameter) : void 0;
-    }
-    function isConstTypeVariable(type) {
-      var _a;
-      return !!(type && (type.flags & 262144 /* TypeParameter */ && some((_a = type.symbol) == null ? void 0 : _a.declarations, (d) => hasSyntacticModifier(d, 2048 /* Const */)) || type.flags & 1048576 /* Union */ && some(type.types, isConstTypeVariable) || type.flags & 8388608 /* IndexedAccess */ && isConstTypeVariable(type.objectType) || type.flags & 16777216 /* Conditional */ && isConstTypeVariable(getConstraintOfConditionalType(type)) || type.flags & 33554432 /* Substitution */ && isConstTypeVariable(type.baseType) || isGenericTupleType(type) && findIndex(getElementTypes(type), (t, i) => !!(type.target.elementFlags[i] & 8 /* Variadic */) && isConstTypeVariable(t)) >= 0));
-    }
-    function getConstraintOfIndexedAccess(type) {
-      return hasNonCircularBaseConstraint(type) ? getConstraintFromIndexedAccess(type) : void 0;
-    }
-    function getSimplifiedTypeOrConstraint(type) {
-      const simplified = getSimplifiedType(
-        type,
-        /*writing*/
-        false
-      );
-      return simplified !== type ? simplified : getConstraintOfType(type);
-    }
-    function getConstraintFromIndexedAccess(type) {
-      if (isMappedTypeGenericIndexedAccess(type) || isGenericMappedType(type.objectType)) {
-        return substituteIndexedMappedType(type.objectType, type.indexType);
-      }
-      const indexConstraint = getSimplifiedTypeOrConstraint(type.indexType);
-      if (indexConstraint && indexConstraint !== type.indexType) {
-        const indexedAccess = getIndexedAccessTypeOrUndefined(type.objectType, indexConstraint, type.accessFlags);
-        if (indexedAccess) {
-          return indexedAccess;
-        }
-      }
-      const objectConstraint = getSimplifiedTypeOrConstraint(type.objectType);
-      if (objectConstraint && objectConstraint !== type.objectType) {
-        return getIndexedAccessTypeOrUndefined(objectConstraint, type.indexType, type.accessFlags);
-      }
-      return void 0;
-    }
-    function getDefaultConstraintOfConditionalType(type) {
-      if (!type.resolvedDefaultConstraint) {
-        const trueConstraint = getInferredTrueTypeFromConditionalType(type);
-        const falseConstraint = getFalseTypeFromConditionalType(type);
-        type.resolvedDefaultConstraint = isTypeAny(trueConstraint) ? falseConstraint : isTypeAny(falseConstraint) ? trueConstraint : getUnionType([trueConstraint, falseConstraint]);
-      }
-      return type.resolvedDefaultConstraint;
-    }
-    function getConstraintOfDistributiveConditionalType(type) {
-      if (type.resolvedConstraintOfDistributive !== void 0) {
-        return type.resolvedConstraintOfDistributive || void 0;
-      }
-      if (type.root.isDistributive && type.restrictiveInstantiation !== type) {
-        const simplified = getSimplifiedType(
-          type.checkType,
-          /*writing*/
-          false
-        );
-        const constraint = simplified === type.checkType ? getConstraintOfType(simplified) : simplified;
-        if (constraint && constraint !== type.checkType) {
-          const instantiated = getConditionalTypeInstantiation(type, prependTypeMapping(type.root.checkType, constraint, type.mapper));
-          if (!(instantiated.flags & 131072 /* Never */)) {
-            type.resolvedConstraintOfDistributive = instantiated;
-            return instantiated;
-          }
-        }
-      }
-      type.resolvedConstraintOfDistributive = false;
-      return void 0;
-    }
-    function getConstraintFromConditionalType(type) {
-      return getConstraintOfDistributiveConditionalType(type) || getDefaultConstraintOfConditionalType(type);
-    }
-    function getConstraintOfConditionalType(type) {
-      return hasNonCircularBaseConstraint(type) ? getConstraintFromConditionalType(type) : void 0;
-    }
-    function getEffectiveConstraintOfIntersection(types, targetIsUnion) {
-      let constraints;
-      let hasDisjointDomainType = false;
-      for (const t of types) {
-        if (t.flags & 465829888 /* Instantiable */) {
-          let constraint = getConstraintOfType(t);
-          while (constraint && constraint.flags & (262144 /* TypeParameter */ | 4194304 /* Index */ | 16777216 /* Conditional */)) {
-            constraint = getConstraintOfType(constraint);
-          }
-          if (constraint) {
-            constraints = append(constraints, constraint);
-            if (targetIsUnion) {
-              constraints = append(constraints, t);
-            }
-          }
-        } else if (t.flags & 469892092 /* DisjointDomains */ || isEmptyAnonymousObjectType(t)) {
-          hasDisjointDomainType = true;
-        }
-      }
-      if (constraints && (targetIsUnion || hasDisjointDomainType)) {
-        if (hasDisjointDomainType) {
-          for (const t of types) {
-            if (t.flags & 469892092 /* DisjointDomains */ || isEmptyAnonymousObjectType(t)) {
-              constraints = append(constraints, t);
-            }
-          }
-        }
-        return getNormalizedType(
-          getIntersectionType(constraints),
-          /*writing*/
-          false
-        );
-      }
-      return void 0;
-    }
-    function getBaseConstraintOfType(type) {
-      if (type.flags & (58982400 /* InstantiableNonPrimitive */ | 3145728 /* UnionOrIntersection */ | 134217728 /* TemplateLiteral */ | 268435456 /* StringMapping */) || isGenericTupleType(type)) {
-        const constraint = getResolvedBaseConstraint(type);
-        return constraint !== noConstraintType && constraint !== circularConstraintType ? constraint : void 0;
-      }
-      return type.flags & 4194304 /* Index */ ? keyofConstraintType : void 0;
-    }
-    function getBaseConstraintOrType(type) {
-      return getBaseConstraintOfType(type) || type;
-    }
-    function hasNonCircularBaseConstraint(type) {
-      return getResolvedBaseConstraint(type) !== circularConstraintType;
-    }
-    function getResolvedBaseConstraint(type) {
-      if (type.resolvedBaseConstraint) {
-        return type.resolvedBaseConstraint;
-      }
-      const stack = [];
-      return type.resolvedBaseConstraint = getImmediateBaseConstraint(type);
-      function getImmediateBaseConstraint(t) {
-        if (!t.immediateBaseConstraint) {
-          if (!pushTypeResolution(t, 4 /* ImmediateBaseConstraint */)) {
-            return circularConstraintType;
-          }
-          let result;
-          const identity2 = getRecursionIdentity(t);
-          if (stack.length < 10 || stack.length < 50 && !contains(stack, identity2)) {
-            stack.push(identity2);
-            result = computeBaseConstraint(getSimplifiedType(
-              t,
-              /*writing*/
-              false
-            ));
-            stack.pop();
-          }
-          if (!popTypeResolution()) {
-            if (t.flags & 262144 /* TypeParameter */) {
-              const errorNode = getConstraintDeclaration(t);
-              if (errorNode) {
-                const diagnostic = error(errorNode, Diagnostics.Type_parameter_0_has_a_circular_constraint, typeToString(t));
-                if (currentNode && !isNodeDescendantOf(errorNode, currentNode) && !isNodeDescendantOf(currentNode, errorNode)) {
-                  addRelatedInfo(diagnostic, createDiagnosticForNode(currentNode, Diagnostics.Circularity_originates_in_type_at_this_location));
-                }
-              }
-            }
-            result = circularConstraintType;
-          }
-          t.immediateBaseConstraint = result || noConstraintType;
-        }
-        return t.immediateBaseConstraint;
-      }
-      function getBaseConstraint(t) {
-        const c = getImmediateBaseConstraint(t);
-        return c !== noConstraintType && c !== circularConstraintType ? c : void 0;
-      }
-      function computeBaseConstraint(t) {
-        if (t.flags & 262144 /* TypeParameter */) {
-          const constraint = getConstraintFromTypeParameter(t);
-          return t.isThisType || !constraint ? constraint : getBaseConstraint(constraint);
-        }
-        if (t.flags & 3145728 /* UnionOrIntersection */) {
-          const types = t.types;
-          const baseTypes = [];
-          let different = false;
-          for (const type2 of types) {
-            const baseType = getBaseConstraint(type2);
-            if (baseType) {
-              if (baseType !== type2) {
-                different = true;
-              }
-              baseTypes.push(baseType);
-            } else {
-              different = true;
-            }
-          }
-          if (!different) {
-            return t;
-          }
-          return t.flags & 1048576 /* Union */ && baseTypes.length === types.length ? getUnionType(baseTypes) : t.flags & 2097152 /* Intersection */ && baseTypes.length ? getIntersectionType(baseTypes) : void 0;
-        }
-        if (t.flags & 4194304 /* Index */) {
-          return keyofConstraintType;
-        }
-        if (t.flags & 134217728 /* TemplateLiteral */) {
-          const types = t.types;
-          const constraints = mapDefined(types, getBaseConstraint);
-          return constraints.length === types.length ? getTemplateLiteralType(t.texts, constraints) : stringType;
-        }
-        if (t.flags & 268435456 /* StringMapping */) {
-          const constraint = getBaseConstraint(t.type);
-          return constraint && constraint !== t.type ? getStringMappingType(t.symbol, constraint) : stringType;
-        }
-        if (t.flags & 8388608 /* IndexedAccess */) {
-          if (isMappedTypeGenericIndexedAccess(t)) {
-            return getBaseConstraint(substituteIndexedMappedType(t.objectType, t.indexType));
-          }
-          const baseObjectType = getBaseConstraint(t.objectType);
-          const baseIndexType = getBaseConstraint(t.indexType);
-          const baseIndexedAccess = baseObjectType && baseIndexType && getIndexedAccessTypeOrUndefined(baseObjectType, baseIndexType, t.accessFlags);
-          return baseIndexedAccess && getBaseConstraint(baseIndexedAccess);
-        }
-        if (t.flags & 16777216 /* Conditional */) {
-          const constraint = getConstraintFromConditionalType(t);
-          return constraint && getBaseConstraint(constraint);
-        }
-        if (t.flags & 33554432 /* Substitution */) {
-          return getBaseConstraint(getSubstitutionIntersection(t));
-        }
-        if (isGenericTupleType(t)) {
-          const newElements = map(getElementTypes(t), (v, i) => {
-            const constraint = v.flags & 262144 /* TypeParameter */ && t.target.elementFlags[i] & 8 /* Variadic */ && getBaseConstraint(v) || v;
-            return constraint !== v && everyType(constraint, (c) => isArrayOrTupleType(c) && !isGenericTupleType(c)) ? constraint : v;
-          });
-          return createTupleType(newElements, t.target.elementFlags, t.target.readonly, t.target.labeledElementDeclarations);
-        }
-        return t;
-      }
-    }
-    function getApparentTypeOfIntersectionType(type, thisArgument) {
-      return type.resolvedApparentType || (type.resolvedApparentType = getTypeWithThisArgument(
-        type,
-        thisArgument,
-        /*needApparentType*/
-        true
-      ));
-    }
-    function getResolvedTypeParameterDefault(typeParameter) {
-      if (!typeParameter.default) {
-        if (typeParameter.target) {
-          const targetDefault = getResolvedTypeParameterDefault(typeParameter.target);
-          typeParameter.default = targetDefault ? instantiateType(targetDefault, typeParameter.mapper) : noConstraintType;
-        } else {
-          typeParameter.default = resolvingDefaultType;
-          const defaultDeclaration = typeParameter.symbol && forEach(typeParameter.symbol.declarations, (decl) => isTypeParameterDeclaration(decl) && decl.default);
-          const defaultType = defaultDeclaration ? getTypeFromTypeNode(defaultDeclaration) : noConstraintType;
-          if (typeParameter.default === resolvingDefaultType) {
-            typeParameter.default = defaultType;
-          }
-        }
-      } else if (typeParameter.default === resolvingDefaultType) {
-        typeParameter.default = circularConstraintType;
-      }
-      return typeParameter.default;
-    }
-    function getDefaultFromTypeParameter(typeParameter) {
-      const defaultType = getResolvedTypeParameterDefault(typeParameter);
-      return defaultType !== noConstraintType && defaultType !== circularConstraintType ? defaultType : void 0;
-    }
-    function hasNonCircularTypeParameterDefault(typeParameter) {
-      return getResolvedTypeParameterDefault(typeParameter) !== circularConstraintType;
-    }
-    function hasTypeParameterDefault(typeParameter) {
-      return !!(typeParameter.symbol && forEach(typeParameter.symbol.declarations, (decl) => isTypeParameterDeclaration(decl) && decl.default));
-    }
-    function getApparentTypeOfMappedType(type) {
-      return type.resolvedApparentType || (type.resolvedApparentType = getResolvedApparentTypeOfMappedType(type));
-    }
-    function getResolvedApparentTypeOfMappedType(type) {
-      const typeVariable = getHomomorphicTypeVariable(type);
-      if (typeVariable && !type.declaration.nameType) {
-        const constraint = getConstraintOfTypeParameter(typeVariable);
-        if (constraint && everyType(constraint, isArrayOrTupleType)) {
-          return instantiateType(type, prependTypeMapping(typeVariable, constraint, type.mapper));
-        }
-      }
-      return type;
-    }
-    function isMappedTypeGenericIndexedAccess(type) {
-      let objectType;
-      return !!(type.flags & 8388608 /* IndexedAccess */ && getObjectFlags(objectType = type.objectType) & 32 /* Mapped */ && !isGenericMappedType(objectType) && isGenericIndexType(type.indexType) && !(getMappedTypeModifiers(objectType) & 8 /* ExcludeOptional */) && !objectType.declaration.nameType);
-    }
-    function getApparentType(type) {
-      const t = type.flags & 465829888 /* Instantiable */ ? getBaseConstraintOfType(type) || unknownType : type;
-      const objectFlags = getObjectFlags(t);
-      return objectFlags & 32 /* Mapped */ ? getApparentTypeOfMappedType(t) : objectFlags & 4 /* Reference */ && t !== type ? getTypeWithThisArgument(t, type) : t.flags & 2097152 /* Intersection */ ? getApparentTypeOfIntersectionType(t, type) : t.flags & 402653316 /* StringLike */ ? globalStringType : t.flags & 296 /* NumberLike */ ? globalNumberType : t.flags & 2112 /* BigIntLike */ ? getGlobalBigIntType() : t.flags & 528 /* BooleanLike */ ? globalBooleanType : t.flags & 12288 /* ESSymbolLike */ ? getGlobalESSymbolType() : t.flags & 67108864 /* NonPrimitive */ ? emptyObjectType : t.flags & 4194304 /* Index */ ? keyofConstraintType : t.flags & 2 /* Unknown */ && !strictNullChecks ? emptyObjectType : t;
-    }
-    function getReducedApparentType(type) {
-      return getReducedType(getApparentType(getReducedType(type)));
-    }
-    function createUnionOrIntersectionProperty(containingType, name, skipObjectFunctionPropertyAugment) {
-      var _a, _b, _c;
-      let singleProp;
-      let propSet;
-      let indexTypes;
-      const isUnion = containingType.flags & 1048576 /* Union */;
-      let optionalFlag;
-      let syntheticFlag = 4 /* SyntheticMethod */;
-      let checkFlags = isUnion ? 0 : 8 /* Readonly */;
-      let mergedInstantiations = false;
-      for (const current of containingType.types) {
-        const type = getApparentType(current);
-        if (!(isErrorType(type) || type.flags & 131072 /* Never */)) {
-          const prop = getPropertyOfType(type, name, skipObjectFunctionPropertyAugment);
-          const modifiers = prop ? getDeclarationModifierFlagsFromSymbol(prop) : 0;
-          if (prop) {
-            if (prop.flags & 106500 /* ClassMember */) {
-              optionalFlag ?? (optionalFlag = isUnion ? 0 /* None */ : 16777216 /* Optional */);
-              if (isUnion) {
-                optionalFlag |= prop.flags & 16777216 /* Optional */;
-              } else {
-                optionalFlag &= prop.flags;
-              }
-            }
-            if (!singleProp) {
-              singleProp = prop;
-            } else if (prop !== singleProp) {
-              const isInstantiation = (getTargetSymbol(prop) || prop) === (getTargetSymbol(singleProp) || singleProp);
-              if (isInstantiation && compareProperties2(singleProp, prop, (a, b) => a === b ? -1 /* True */ : 0 /* False */) === -1 /* True */) {
-                mergedInstantiations = !!singleProp.parent && !!length(getLocalTypeParametersOfClassOrInterfaceOrTypeAlias(singleProp.parent));
-              } else {
-                if (!propSet) {
-                  propSet = /* @__PURE__ */ new Map();
-                  propSet.set(getSymbolId(singleProp), singleProp);
-                }
-                const id = getSymbolId(prop);
-                if (!propSet.has(id)) {
-                  propSet.set(id, prop);
-                }
-              }
-            }
-            if (isUnion && isReadonlySymbol(prop)) {
-              checkFlags |= 8 /* Readonly */;
-            } else if (!isUnion && !isReadonlySymbol(prop)) {
-              checkFlags &= ~8 /* Readonly */;
-            }
-            checkFlags |= (!(modifiers & 24 /* NonPublicAccessibilityModifier */) ? 256 /* ContainsPublic */ : 0) | (modifiers & 16 /* Protected */ ? 512 /* ContainsProtected */ : 0) | (modifiers & 8 /* Private */ ? 1024 /* ContainsPrivate */ : 0) | (modifiers & 32 /* Static */ ? 2048 /* ContainsStatic */ : 0);
-            if (!isPrototypeProperty(prop)) {
-              syntheticFlag = 2 /* SyntheticProperty */;
-            }
-          } else if (isUnion) {
-            const indexInfo = !isLateBoundName(name) && getApplicableIndexInfoForName(type, name);
-            if (indexInfo) {
-              checkFlags |= 32 /* WritePartial */ | (indexInfo.isReadonly ? 8 /* Readonly */ : 0);
-              indexTypes = append(indexTypes, isTupleType(type) ? getRestTypeOfTupleType(type) || undefinedType : indexInfo.type);
-            } else if (isObjectLiteralType2(type) && !(getObjectFlags(type) & 2097152 /* ContainsSpread */)) {
-              checkFlags |= 32 /* WritePartial */;
-              indexTypes = append(indexTypes, undefinedType);
-            } else {
-              checkFlags |= 16 /* ReadPartial */;
-            }
-          }
-        }
-      }
-      if (!singleProp || isUnion && (propSet || checkFlags & 48 /* Partial */) && checkFlags & (1024 /* ContainsPrivate */ | 512 /* ContainsProtected */) && !(propSet && getCommonDeclarationsOfSymbols(propSet.values()))) {
-        return void 0;
-      }
-      if (!propSet && !(checkFlags & 16 /* ReadPartial */) && !indexTypes) {
-        if (mergedInstantiations) {
-          const links = (_a = tryCast(singleProp, isTransientSymbol)) == null ? void 0 : _a.links;
-          const clone2 = createSymbolWithType(singleProp, links == null ? void 0 : links.type);
-          clone2.parent = (_c = (_b = singleProp.valueDeclaration) == null ? void 0 : _b.symbol) == null ? void 0 : _c.parent;
-          clone2.links.containingType = containingType;
-          clone2.links.mapper = links == null ? void 0 : links.mapper;
-          return clone2;
-        } else {
-          return singleProp;
-        }
-      }
-      const props = propSet ? arrayFrom(propSet.values()) : [singleProp];
-      let declarations;
-      let firstType;
-      let nameType;
-      const propTypes = [];
-      let writeTypes;
-      let firstValueDeclaration;
-      let hasNonUniformValueDeclaration = false;
-      for (const prop of props) {
-        if (!firstValueDeclaration) {
-          firstValueDeclaration = prop.valueDeclaration;
-        } else if (prop.valueDeclaration && prop.valueDeclaration !== firstValueDeclaration) {
-          hasNonUniformValueDeclaration = true;
-        }
-        declarations = addRange(declarations, prop.declarations);
-        const type = getTypeOfSymbol(prop);
-        if (!firstType) {
-          firstType = type;
-          nameType = getSymbolLinks(prop).nameType;
-        }
-        const writeType = getWriteTypeOfSymbol(prop);
-        if (writeTypes || writeType !== type) {
-          writeTypes = append(!writeTypes ? propTypes.slice() : writeTypes, writeType);
-        } else if (type !== firstType) {
-          checkFlags |= 64 /* HasNonUniformType */;
-        }
-        if (isLiteralType(type) || isPatternLiteralType(type)) {
-          checkFlags |= 128 /* HasLiteralType */;
-        }
-        if (type.flags & 131072 /* Never */ && type !== uniqueLiteralType) {
-          checkFlags |= 131072 /* HasNeverType */;
-        }
-        propTypes.push(type);
-      }
-      addRange(propTypes, indexTypes);
-      const result = createSymbol(4 /* Property */ | (optionalFlag ?? 0), name, syntheticFlag | checkFlags);
-      result.links.containingType = containingType;
-      if (!hasNonUniformValueDeclaration && firstValueDeclaration) {
-        result.valueDeclaration = firstValueDeclaration;
-        if (firstValueDeclaration.symbol.parent) {
-          result.parent = firstValueDeclaration.symbol.parent;
-        }
-      }
-      result.declarations = declarations;
-      result.links.nameType = nameType;
-      if (propTypes.length > 2) {
-        result.links.checkFlags |= 65536 /* DeferredType */;
-        result.links.deferralParent = containingType;
-        result.links.deferralConstituents = propTypes;
-        result.links.deferralWriteConstituents = writeTypes;
-      } else {
-        result.links.type = isUnion ? getUnionType(propTypes) : getIntersectionType(propTypes);
-        if (writeTypes) {
-          result.links.writeType = isUnion ? getUnionType(writeTypes) : getIntersectionType(writeTypes);
-        }
-      }
-      return result;
-    }
-    function getUnionOrIntersectionProperty(type, name, skipObjectFunctionPropertyAugment) {
-      var _a, _b;
-      let property = ((_a = type.propertyCacheWithoutObjectFunctionPropertyAugment) == null ? void 0 : _a.get(name)) || !skipObjectFunctionPropertyAugment ? (_b = type.propertyCache) == null ? void 0 : _b.get(name) : void 0;
-      if (!property) {
-        property = createUnionOrIntersectionProperty(type, name, skipObjectFunctionPropertyAugment);
-        if (property) {
-          const properties = skipObjectFunctionPropertyAugment ? type.propertyCacheWithoutObjectFunctionPropertyAugment || (type.propertyCacheWithoutObjectFunctionPropertyAugment = createSymbolTable()) : type.propertyCache || (type.propertyCache = createSymbolTable());
-          properties.set(name, property);
-        }
-      }
-      return property;
-    }
-    function getCommonDeclarationsOfSymbols(symbols) {
-      let commonDeclarations;
-      for (const symbol of symbols) {
-        if (!symbol.declarations) {
-          return void 0;
-        }
-        if (!commonDeclarations) {
-          commonDeclarations = new Set(symbol.declarations);
-          continue;
-        }
-        commonDeclarations.forEach((declaration) => {
-          if (!contains(symbol.declarations, declaration)) {
-            commonDeclarations.delete(declaration);
-          }
-        });
-        if (commonDeclarations.size === 0) {
-          return void 0;
-        }
-      }
-      return commonDeclarations;
-    }
-    function getPropertyOfUnionOrIntersectionType(type, name, skipObjectFunctionPropertyAugment) {
-      const property = getUnionOrIntersectionProperty(type, name, skipObjectFunctionPropertyAugment);
-      return property && !(getCheckFlags(property) & 16 /* ReadPartial */) ? property : void 0;
-    }
-    function getReducedType(type) {
-      if (type.flags & 1048576 /* Union */ && type.objectFlags & 16777216 /* ContainsIntersections */) {
-        return type.resolvedReducedType || (type.resolvedReducedType = getReducedUnionType(type));
-      } else if (type.flags & 2097152 /* Intersection */) {
-        if (!(type.objectFlags & 16777216 /* IsNeverIntersectionComputed */)) {
-          type.objectFlags |= 16777216 /* IsNeverIntersectionComputed */ | (some(getPropertiesOfUnionOrIntersectionType(type), isNeverReducedProperty) ? 33554432 /* IsNeverIntersection */ : 0);
-        }
-        return type.objectFlags & 33554432 /* IsNeverIntersection */ ? neverType : type;
-      }
-      return type;
-    }
-    function getReducedUnionType(unionType) {
-      const reducedTypes = sameMap(unionType.types, getReducedType);
-      if (reducedTypes === unionType.types) {
-        return unionType;
-      }
-      const reduced = getUnionType(reducedTypes);
-      if (reduced.flags & 1048576 /* Union */) {
-        reduced.resolvedReducedType = reduced;
-      }
-      return reduced;
-    }
-    function isNeverReducedProperty(prop) {
-      return isDiscriminantWithNeverType(prop) || isConflictingPrivateProperty(prop);
-    }
-    function isDiscriminantWithNeverType(prop) {
-      return !(prop.flags & 16777216 /* Optional */) && (getCheckFlags(prop) & (192 /* Discriminant */ | 131072 /* HasNeverType */)) === 192 /* Discriminant */ && !!(getTypeOfSymbol(prop).flags & 131072 /* Never */);
-    }
-    function isConflictingPrivateProperty(prop) {
-      return !prop.valueDeclaration && !!(getCheckFlags(prop) & 1024 /* ContainsPrivate */);
-    }
-    function isGenericReducibleType(type) {
-      return !!(type.flags & 1048576 /* Union */ && type.objectFlags & 16777216 /* ContainsIntersections */ && some(type.types, isGenericReducibleType) || type.flags & 2097152 /* Intersection */ && isReducibleIntersection(type));
-    }
-    function isReducibleIntersection(type) {
-      const uniqueFilled = type.uniqueLiteralFilledInstantiation || (type.uniqueLiteralFilledInstantiation = instantiateType(type, uniqueLiteralMapper));
-      return getReducedType(uniqueFilled) !== uniqueFilled;
-    }
-    function elaborateNeverIntersection(errorInfo, type) {
-      if (type.flags & 2097152 /* Intersection */ && getObjectFlags(type) & 33554432 /* IsNeverIntersection */) {
-        const neverProp = find(getPropertiesOfUnionOrIntersectionType(type), isDiscriminantWithNeverType);
-        if (neverProp) {
-          return chainDiagnosticMessages(
-            errorInfo,
-            Diagnostics.The_intersection_0_was_reduced_to_never_because_property_1_has_conflicting_types_in_some_constituents,
-            typeToString(
-              type,
-              /*enclosingDeclaration*/
-              void 0,
-              536870912 /* NoTypeReduction */
-            ),
-            symbolToString(neverProp)
-          );
-        }
-        const privateProp = find(getPropertiesOfUnionOrIntersectionType(type), isConflictingPrivateProperty);
-        if (privateProp) {
-          return chainDiagnosticMessages(
-            errorInfo,
-            Diagnostics.The_intersection_0_was_reduced_to_never_because_property_1_exists_in_multiple_constituents_and_is_private_in_some,
-            typeToString(
-              type,
-              /*enclosingDeclaration*/
-              void 0,
-              536870912 /* NoTypeReduction */
-            ),
-            symbolToString(privateProp)
-          );
-        }
-      }
-      return errorInfo;
-    }
-    function getPropertyOfType(type, name, skipObjectFunctionPropertyAugment, includeTypeOnlyMembers) {
-      type = getReducedApparentType(type);
-      if (type.flags & 524288 /* Object */) {
-        const resolved = resolveStructuredTypeMembers(type);
-        const symbol = resolved.members.get(name);
-        if (symbol && symbolIsValue(symbol, includeTypeOnlyMembers)) {
-          return symbol;
-        }
-        if (skipObjectFunctionPropertyAugment)
-          return void 0;
-        const functionType = resolved === anyFunctionType ? globalFunctionType : resolved.callSignatures.length ? globalCallableFunctionType : resolved.constructSignatures.length ? globalNewableFunctionType : void 0;
-        if (functionType) {
-          const symbol2 = getPropertyOfObjectType(functionType, name);
-          if (symbol2) {
-            return symbol2;
-          }
-        }
-        return getPropertyOfObjectType(globalObjectType, name);
-      }
-      if (type.flags & 3145728 /* UnionOrIntersection */) {
-        return getPropertyOfUnionOrIntersectionType(type, name, skipObjectFunctionPropertyAugment);
-      }
-      return void 0;
-    }
-    function getSignaturesOfStructuredType(type, kind) {
-      if (type.flags & 3670016 /* StructuredType */) {
-        const resolved = resolveStructuredTypeMembers(type);
-        return kind === 0 /* Call */ ? resolved.callSignatures : resolved.constructSignatures;
-      }
-      return emptyArray;
-    }
-    function getSignaturesOfType(type, kind) {
-      return getSignaturesOfStructuredType(getReducedApparentType(type), kind);
-    }
-    function findIndexInfo(indexInfos, keyType) {
-      return find(indexInfos, (info) => info.keyType === keyType);
-    }
-    function findApplicableIndexInfo(indexInfos, keyType) {
-      let stringIndexInfo;
-      let applicableInfo;
-      let applicableInfos;
-      for (const info of indexInfos) {
-        if (info.keyType === stringType) {
-          stringIndexInfo = info;
-        } else if (isApplicableIndexType(keyType, info.keyType)) {
-          if (!applicableInfo) {
-            applicableInfo = info;
-          } else {
-            (applicableInfos || (applicableInfos = [applicableInfo])).push(info);
-          }
-        }
-      }
-      return applicableInfos ? createIndexInfo(
-        unknownType,
-        getIntersectionType(map(applicableInfos, (info) => info.type)),
-        reduceLeft(
-          applicableInfos,
-          (isReadonly, info) => isReadonly && info.isReadonly,
-          /*initial*/
-          true
-        )
-      ) : applicableInfo ? applicableInfo : stringIndexInfo && isApplicableIndexType(keyType, stringType) ? stringIndexInfo : void 0;
-    }
-    function isApplicableIndexType(source, target) {
-      return isTypeAssignableTo(source, target) || target === stringType && isTypeAssignableTo(source, numberType) || target === numberType && (source === numericStringType || !!(source.flags & 128 /* StringLiteral */) && isNumericLiteralName(source.value));
-    }
-    function getIndexInfosOfStructuredType(type) {
-      if (type.flags & 3670016 /* StructuredType */) {
-        const resolved = resolveStructuredTypeMembers(type);
-        return resolved.indexInfos;
-      }
-      return emptyArray;
-    }
-    function getIndexInfosOfType(type) {
-      return getIndexInfosOfStructuredType(getReducedApparentType(type));
-    }
-    function getIndexInfoOfType(type, keyType) {
-      return findIndexInfo(getIndexInfosOfType(type), keyType);
-    }
-    function getIndexTypeOfType(type, keyType) {
-      var _a;
-      return (_a = getIndexInfoOfType(type, keyType)) == null ? void 0 : _a.type;
-    }
-    function getApplicableIndexInfos(type, keyType) {
-      return getIndexInfosOfType(type).filter((info) => isApplicableIndexType(keyType, info.keyType));
-    }
-    function getApplicableIndexInfo(type, keyType) {
-      return findApplicableIndexInfo(getIndexInfosOfType(type), keyType);
-    }
-    function getApplicableIndexInfoForName(type, name) {
-      return getApplicableIndexInfo(type, isLateBoundName(name) ? esSymbolType : getStringLiteralType(unescapeLeadingUnderscores(name)));
-    }
-    function getTypeParametersFromDeclaration(declaration) {
-      var _a;
-      let result;
-      for (const node of getEffectiveTypeParameterDeclarations(declaration)) {
-        result = appendIfUnique(result, getDeclaredTypeOfTypeParameter(node.symbol));
-      }
-      return (result == null ? void 0 : result.length) ? result : isFunctionDeclaration(declaration) ? (_a = getSignatureOfTypeTag(declaration)) == null ? void 0 : _a.typeParameters : void 0;
-    }
-    function symbolsToArray(symbols) {
-      const result = [];
-      symbols.forEach((symbol, id) => {
-        if (!isReservedMemberName(id)) {
-          result.push(symbol);
-        }
-      });
-      return result;
-    }
-    function tryFindAmbientModule(moduleName, withAugmentations) {
-      if (isExternalModuleNameRelative(moduleName)) {
-        return void 0;
-      }
-      const symbol = getSymbol2(globals, '"' + moduleName + '"', 512 /* ValueModule */);
-      return symbol && withAugmentations ? getMergedSymbol(symbol) : symbol;
-    }
-    function isOptionalParameter(node) {
-      if (hasQuestionToken(node) || isOptionalJSDocPropertyLikeTag(node) || isJSDocOptionalParameter(node)) {
-        return true;
-      }
-      if (node.initializer) {
-        const signature = getSignatureFromDeclaration(node.parent);
-        const parameterIndex = node.parent.parameters.indexOf(node);
-        Debug.assert(parameterIndex >= 0);
-        return parameterIndex >= getMinArgumentCount(signature, 1 /* StrongArityForUntypedJS */ | 2 /* VoidIsNonOptional */);
-      }
-      const iife = getImmediatelyInvokedFunctionExpression(node.parent);
-      if (iife) {
-        return !node.type && !node.dotDotDotToken && node.parent.parameters.indexOf(node) >= iife.arguments.length;
-      }
-      return false;
-    }
-    function isOptionalPropertyDeclaration(node) {
-      return isPropertyDeclaration(node) && !hasAccessorModifier(node) && node.questionToken;
-    }
-    function createTypePredicate(kind, parameterName, parameterIndex, type) {
-      return { kind, parameterName, parameterIndex, type };
-    }
-    function getMinTypeArgumentCount(typeParameters) {
-      let minTypeArgumentCount = 0;
-      if (typeParameters) {
-        for (let i = 0; i < typeParameters.length; i++) {
-          if (!hasTypeParameterDefault(typeParameters[i])) {
-            minTypeArgumentCount = i + 1;
-          }
-        }
-      }
-      return minTypeArgumentCount;
-    }
-    function fillMissingTypeArguments(typeArguments, typeParameters, minTypeArgumentCount, isJavaScriptImplicitAny) {
-      const numTypeParameters = length(typeParameters);
-      if (!numTypeParameters) {
-        return [];
-      }
-      const numTypeArguments = length(typeArguments);
-      if (isJavaScriptImplicitAny || numTypeArguments >= minTypeArgumentCount && numTypeArguments <= numTypeParameters) {
-        const result = typeArguments ? typeArguments.slice() : [];
-        for (let i = numTypeArguments; i < numTypeParameters; i++) {
-          result[i] = errorType;
-        }
-        const baseDefaultType = getDefaultTypeArgumentType(isJavaScriptImplicitAny);
-        for (let i = numTypeArguments; i < numTypeParameters; i++) {
-          let defaultType = getDefaultFromTypeParameter(typeParameters[i]);
-          if (isJavaScriptImplicitAny && defaultType && (isTypeIdenticalTo(defaultType, unknownType) || isTypeIdenticalTo(defaultType, emptyObjectType))) {
-            defaultType = anyType;
-          }
-          result[i] = defaultType ? instantiateType(defaultType, createTypeMapper(typeParameters, result)) : baseDefaultType;
-        }
-        result.length = typeParameters.length;
-        return result;
-      }
-      return typeArguments && typeArguments.slice();
-    }
-    function getSignatureFromDeclaration(declaration) {
-      const links = getNodeLinks(declaration);
-      if (!links.resolvedSignature) {
-        const parameters = [];
-        let flags = 0 /* None */;
-        let minArgumentCount = 0;
-        let thisParameter;
-        let hasThisParameter2 = false;
-        const iife = getImmediatelyInvokedFunctionExpression(declaration);
-        const isJSConstructSignature = isJSDocConstructSignature(declaration);
-        const isUntypedSignatureInJSFile = !iife && isInJSFile(declaration) && isValueSignatureDeclaration(declaration) && !hasJSDocParameterTags(declaration) && !getJSDocType(declaration);
-        if (isUntypedSignatureInJSFile) {
-          flags |= 32 /* IsUntypedSignatureInJSFile */;
-        }
-        for (let i = isJSConstructSignature ? 1 : 0; i < declaration.parameters.length; i++) {
-          const param = declaration.parameters[i];
-          let paramSymbol = param.symbol;
-          const type = isJSDocParameterTag(param) ? param.typeExpression && param.typeExpression.type : param.type;
-          if (paramSymbol && !!(paramSymbol.flags & 4 /* Property */) && !isBindingPattern(param.name)) {
-            const resolvedSymbol = resolveName(
-              param,
-              paramSymbol.escapedName,
-              111551 /* Value */,
-              /*nameNotFoundMessage*/
-              void 0,
-              /*nameArg*/
-              void 0,
-              /*isUse*/
-              false
-            );
-            paramSymbol = resolvedSymbol;
-          }
-          if (i === 0 && paramSymbol.escapedName === "this" /* This */) {
-            hasThisParameter2 = true;
-            thisParameter = param.symbol;
-          } else {
-            parameters.push(paramSymbol);
-          }
-          if (type && type.kind === 200 /* LiteralType */) {
-            flags |= 2 /* HasLiteralTypes */;
-          }
-          const isOptionalParameter2 = isOptionalJSDocPropertyLikeTag(param) || param.initializer || param.questionToken || isRestParameter(param) || iife && parameters.length > iife.arguments.length && !type || isJSDocOptionalParameter(param);
-          if (!isOptionalParameter2) {
-            minArgumentCount = parameters.length;
-          }
-        }
-        if ((declaration.kind === 176 /* GetAccessor */ || declaration.kind === 177 /* SetAccessor */) && hasBindableName(declaration) && (!hasThisParameter2 || !thisParameter)) {
-          const otherKind = declaration.kind === 176 /* GetAccessor */ ? 177 /* SetAccessor */ : 176 /* GetAccessor */;
-          const other = getDeclarationOfKind(getSymbolOfDeclaration(declaration), otherKind);
-          if (other) {
-            thisParameter = getAnnotatedAccessorThisParameter(other);
-          }
-        }
-        if (isInJSFile(declaration)) {
-          const thisTag = getJSDocThisTag(declaration);
-          if (thisTag && thisTag.typeExpression) {
-            thisParameter = createSymbolWithType(createSymbol(1 /* FunctionScopedVariable */, "this" /* This */), getTypeFromTypeNode(thisTag.typeExpression));
-          }
-        }
-        const hostDeclaration = isJSDocSignature(declaration) ? getEffectiveJSDocHost(declaration) : declaration;
-        const classType = hostDeclaration && isConstructorDeclaration(hostDeclaration) ? getDeclaredTypeOfClassOrInterface(getMergedSymbol(hostDeclaration.parent.symbol)) : void 0;
-        const typeParameters = classType ? classType.localTypeParameters : getTypeParametersFromDeclaration(declaration);
-        if (hasRestParameter(declaration) || isInJSFile(declaration) && maybeAddJsSyntheticRestParameter(declaration, parameters)) {
-          flags |= 1 /* HasRestParameter */;
-        }
-        if (isConstructorTypeNode(declaration) && hasSyntacticModifier(declaration, 256 /* Abstract */) || isConstructorDeclaration(declaration) && hasSyntacticModifier(declaration.parent, 256 /* Abstract */)) {
-          flags |= 4 /* Abstract */;
-        }
-        links.resolvedSignature = createSignature(
-          declaration,
-          typeParameters,
-          thisParameter,
-          parameters,
-          /*resolvedReturnType*/
-          void 0,
-          /*resolvedTypePredicate*/
-          void 0,
-          minArgumentCount,
-          flags
-        );
-      }
-      return links.resolvedSignature;
-    }
-    function maybeAddJsSyntheticRestParameter(declaration, parameters) {
-      if (isJSDocSignature(declaration) || !containsArgumentsReference(declaration)) {
-        return false;
-      }
-      const lastParam = lastOrUndefined(declaration.parameters);
-      const lastParamTags = lastParam ? getJSDocParameterTags(lastParam) : getJSDocTags(declaration).filter(isJSDocParameterTag);
-      const lastParamVariadicType = firstDefined(lastParamTags, (p) => p.typeExpression && isJSDocVariadicType(p.typeExpression.type) ? p.typeExpression.type : void 0);
-      const syntheticArgsSymbol = createSymbol(3 /* Variable */, "args", 32768 /* RestParameter */);
-      if (lastParamVariadicType) {
-        syntheticArgsSymbol.links.type = createArrayType(getTypeFromTypeNode(lastParamVariadicType.type));
-      } else {
-        syntheticArgsSymbol.links.checkFlags |= 65536 /* DeferredType */;
-        syntheticArgsSymbol.links.deferralParent = neverType;
-        syntheticArgsSymbol.links.deferralConstituents = [anyArrayType];
-        syntheticArgsSymbol.links.deferralWriteConstituents = [anyArrayType];
-      }
-      if (lastParamVariadicType) {
-        parameters.pop();
-      }
-      parameters.push(syntheticArgsSymbol);
-      return true;
-    }
-    function getSignatureOfTypeTag(node) {
-      if (!(isInJSFile(node) && isFunctionLikeDeclaration(node)))
-        return void 0;
-      const typeTag = getJSDocTypeTag(node);
-      return (typeTag == null ? void 0 : typeTag.typeExpression) && getSingleCallSignature(getTypeFromTypeNode(typeTag.typeExpression));
-    }
-    function getParameterTypeOfTypeTag(func, parameter) {
-      const signature = getSignatureOfTypeTag(func);
-      if (!signature)
-        return void 0;
-      const pos = func.parameters.indexOf(parameter);
-      return parameter.dotDotDotToken ? getRestTypeAtPosition(signature, pos) : getTypeAtPosition(signature, pos);
-    }
-    function getReturnTypeOfTypeTag(node) {
-      const signature = getSignatureOfTypeTag(node);
-      return signature && getReturnTypeOfSignature(signature);
-    }
-    function containsArgumentsReference(declaration) {
-      const links = getNodeLinks(declaration);
-      if (links.containsArgumentsReference === void 0) {
-        if (links.flags & 512 /* CaptureArguments */) {
-          links.containsArgumentsReference = true;
-        } else {
-          links.containsArgumentsReference = traverse(declaration.body);
-        }
-      }
-      return links.containsArgumentsReference;
-      function traverse(node) {
-        if (!node)
-          return false;
-        switch (node.kind) {
-          case 80 /* Identifier */:
-            return node.escapedText === argumentsSymbol.escapedName && getReferencedValueSymbol(node) === argumentsSymbol;
-          case 171 /* PropertyDeclaration */:
-          case 173 /* MethodDeclaration */:
-          case 176 /* GetAccessor */:
-          case 177 /* SetAccessor */:
-            return node.name.kind === 166 /* ComputedPropertyName */ && traverse(node.name);
-          case 210 /* PropertyAccessExpression */:
-          case 211 /* ElementAccessExpression */:
-            return traverse(node.expression);
-          case 302 /* PropertyAssignment */:
-            return traverse(node.initializer);
-          default:
-            return !nodeStartsNewLexicalEnvironment(node) && !isPartOfTypeNode(node) && !!forEachChild(node, traverse);
-        }
-      }
-    }
-    function getSignaturesOfSymbol(symbol) {
-      if (!symbol || !symbol.declarations)
-        return emptyArray;
-      const result = [];
-      for (let i = 0; i < symbol.declarations.length; i++) {
-        const decl = symbol.declarations[i];
-        if (!isFunctionLike(decl))
-          continue;
-        if (i > 0 && decl.body) {
-          const previous = symbol.declarations[i - 1];
-          if (decl.parent === previous.parent && decl.kind === previous.kind && decl.pos === previous.end) {
-            continue;
-          }
-        }
-        if (isInJSFile(decl) && decl.jsDoc) {
-          let hasJSDocOverloads = false;
-          for (const node of decl.jsDoc) {
-            if (node.tags) {
-              for (const tag of node.tags) {
-                if (isJSDocOverloadTag(tag)) {
-                  const jsDocSignature = tag.typeExpression;
-                  if (jsDocSignature.type === void 0 && !isConstructorDeclaration(decl)) {
-                    reportImplicitAny(jsDocSignature, anyType);
-                  }
-                  result.push(getSignatureFromDeclaration(jsDocSignature));
-                  hasJSDocOverloads = true;
-                }
-              }
-            }
-          }
-          if (hasJSDocOverloads) {
-            continue;
-          }
-        }
-        result.push(
-          !isFunctionExpressionOrArrowFunction(decl) && !isObjectLiteralMethod(decl) && getSignatureOfTypeTag(decl) || getSignatureFromDeclaration(decl)
-        );
-      }
-      return result;
-    }
-    function resolveExternalModuleTypeByLiteral(name) {
-      const moduleSym = resolveExternalModuleName(name, name);
-      if (moduleSym) {
-        const resolvedModuleSymbol = resolveExternalModuleSymbol(moduleSym);
-        if (resolvedModuleSymbol) {
-          return getTypeOfSymbol(resolvedModuleSymbol);
-        }
-      }
-      return anyType;
-    }
-    function getThisTypeOfSignature(signature) {
-      if (signature.thisParameter) {
-        return getTypeOfSymbol(signature.thisParameter);
-      }
-    }
-    function getTypePredicateOfSignature(signature) {
-      if (!signature.resolvedTypePredicate) {
-        if (signature.target) {
-          const targetTypePredicate = getTypePredicateOfSignature(signature.target);
-          signature.resolvedTypePredicate = targetTypePredicate ? instantiateTypePredicate(targetTypePredicate, signature.mapper) : noTypePredicate;
-        } else if (signature.compositeSignatures) {
-          signature.resolvedTypePredicate = getUnionOrIntersectionTypePredicate(signature.compositeSignatures, signature.compositeKind) || noTypePredicate;
-        } else {
-          const type = signature.declaration && getEffectiveReturnTypeNode(signature.declaration);
-          let jsdocPredicate;
-          if (!type) {
-            const jsdocSignature = getSignatureOfTypeTag(signature.declaration);
-            if (jsdocSignature && signature !== jsdocSignature) {
-              jsdocPredicate = getTypePredicateOfSignature(jsdocSignature);
-            }
-          }
-          signature.resolvedTypePredicate = type && isTypePredicateNode(type) ? createTypePredicateFromTypePredicateNode(type, signature) : jsdocPredicate || noTypePredicate;
-        }
-        Debug.assert(!!signature.resolvedTypePredicate);
-      }
-      return signature.resolvedTypePredicate === noTypePredicate ? void 0 : signature.resolvedTypePredicate;
-    }
-    function createTypePredicateFromTypePredicateNode(node, signature) {
-      const parameterName = node.parameterName;
-      const type = node.type && getTypeFromTypeNode(node.type);
-      return parameterName.kind === 196 /* ThisType */ ? createTypePredicate(
-        node.assertsModifier ? 2 /* AssertsThis */ : 0 /* This */,
-        /*parameterName*/
-        void 0,
-        /*parameterIndex*/
-        void 0,
-        type
-      ) : createTypePredicate(
-        node.assertsModifier ? 3 /* AssertsIdentifier */ : 1 /* Identifier */,
-        parameterName.escapedText,
-        findIndex(signature.parameters, (p) => p.escapedName === parameterName.escapedText),
-        type
-      );
-    }
-    function getUnionOrIntersectionType(types, kind, unionReduction) {
-      return kind !== 2097152 /* Intersection */ ? getUnionType(types, unionReduction) : getIntersectionType(types);
-    }
-    function getReturnTypeOfSignature(signature) {
-      if (!signature.resolvedReturnType) {
-        if (!pushTypeResolution(signature, 3 /* ResolvedReturnType */)) {
-          return errorType;
-        }
-        let type = signature.target ? instantiateType(getReturnTypeOfSignature(signature.target), signature.mapper) : signature.compositeSignatures ? instantiateType(getUnionOrIntersectionType(map(signature.compositeSignatures, getReturnTypeOfSignature), signature.compositeKind, 2 /* Subtype */), signature.mapper) : getReturnTypeFromAnnotation(signature.declaration) || (nodeIsMissing(signature.declaration.body) ? anyType : getReturnTypeFromBody(signature.declaration));
-        if (signature.flags & 8 /* IsInnerCallChain */) {
-          type = addOptionalTypeMarker(type);
-        } else if (signature.flags & 16 /* IsOuterCallChain */) {
-          type = getOptionalType(type);
-        }
-        if (!popTypeResolution()) {
-          if (signature.declaration) {
-            const typeNode = getEffectiveReturnTypeNode(signature.declaration);
-            if (typeNode) {
-              error(typeNode, Diagnostics.Return_type_annotation_circularly_references_itself);
-            } else if (noImplicitAny) {
-              const declaration = signature.declaration;
-              const name = getNameOfDeclaration(declaration);
-              if (name) {
-                error(name, Diagnostics._0_implicitly_has_return_type_any_because_it_does_not_have_a_return_type_annotation_and_is_referenced_directly_or_indirectly_in_one_of_its_return_expressions, declarationNameToString(name));
-              } else {
-                error(declaration, Diagnostics.Function_implicitly_has_return_type_any_because_it_does_not_have_a_return_type_annotation_and_is_referenced_directly_or_indirectly_in_one_of_its_return_expressions);
-              }
-            }
-          }
-          type = anyType;
-        }
-        signature.resolvedReturnType = type;
-      }
-      return signature.resolvedReturnType;
-    }
-    function getReturnTypeFromAnnotation(declaration) {
-      if (declaration.kind === 175 /* Constructor */) {
-        return getDeclaredTypeOfClassOrInterface(getMergedSymbol(declaration.parent.symbol));
-      }
-      const typeNode = getEffectiveReturnTypeNode(declaration);
-      if (isJSDocSignature(declaration)) {
-        const root = getJSDocRoot(declaration);
-        if (root && isConstructorDeclaration(root.parent) && !typeNode) {
-          return getDeclaredTypeOfClassOrInterface(getMergedSymbol(root.parent.parent.symbol));
-        }
-      }
-      if (isJSDocConstructSignature(declaration)) {
-        return getTypeFromTypeNode(declaration.parameters[0].type);
-      }
-      if (typeNode) {
-        return getTypeFromTypeNode(typeNode);
-      }
-      if (declaration.kind === 176 /* GetAccessor */ && hasBindableName(declaration)) {
-        const jsDocType = isInJSFile(declaration) && getTypeForDeclarationFromJSDocComment(declaration);
-        if (jsDocType) {
-          return jsDocType;
-        }
-        const setter = getDeclarationOfKind(getSymbolOfDeclaration(declaration), 177 /* SetAccessor */);
-        const setterType = getAnnotatedAccessorType(setter);
-        if (setterType) {
-          return setterType;
-        }
-      }
-      return getReturnTypeOfTypeTag(declaration);
-    }
-    function isResolvingReturnTypeOfSignature(signature) {
-      return !signature.resolvedReturnType && findResolutionCycleStartIndex(signature, 3 /* ResolvedReturnType */) >= 0;
-    }
-    function getRestTypeOfSignature(signature) {
-      return tryGetRestTypeOfSignature(signature) || anyType;
-    }
-    function tryGetRestTypeOfSignature(signature) {
-      if (signatureHasRestParameter(signature)) {
-        const sigRestType = getTypeOfSymbol(signature.parameters[signature.parameters.length - 1]);
-        const restType = isTupleType(sigRestType) ? getRestTypeOfTupleType(sigRestType) : sigRestType;
-        return restType && getIndexTypeOfType(restType, numberType);
-      }
-      return void 0;
-    }
-    function getSignatureInstantiation(signature, typeArguments, isJavascript, inferredTypeParameters) {
-      const instantiatedSignature = getSignatureInstantiationWithoutFillingInTypeArguments(signature, fillMissingTypeArguments(typeArguments, signature.typeParameters, getMinTypeArgumentCount(signature.typeParameters), isJavascript));
-      if (inferredTypeParameters) {
-        const returnSignature = getSingleCallOrConstructSignature(getReturnTypeOfSignature(instantiatedSignature));
-        if (returnSignature) {
-          const newReturnSignature = cloneSignature(returnSignature);
-          newReturnSignature.typeParameters = inferredTypeParameters;
-          const newInstantiatedSignature = cloneSignature(instantiatedSignature);
-          newInstantiatedSignature.resolvedReturnType = getOrCreateTypeFromSignature(newReturnSignature);
-          return newInstantiatedSignature;
-        }
-      }
-      return instantiatedSignature;
-    }
-    function getSignatureInstantiationWithoutFillingInTypeArguments(signature, typeArguments) {
-      const instantiations = signature.instantiations || (signature.instantiations = /* @__PURE__ */ new Map());
-      const id = getTypeListId(typeArguments);
-      let instantiation = instantiations.get(id);
-      if (!instantiation) {
-        instantiations.set(id, instantiation = createSignatureInstantiation(signature, typeArguments));
-      }
-      return instantiation;
-    }
-    function createSignatureInstantiation(signature, typeArguments) {
-      return instantiateSignature(
-        signature,
-        createSignatureTypeMapper(signature, typeArguments),
-        /*eraseTypeParameters*/
-        true
-      );
-    }
-    function createSignatureTypeMapper(signature, typeArguments) {
-      return createTypeMapper(signature.typeParameters, typeArguments);
-    }
-    function getErasedSignature(signature) {
-      return signature.typeParameters ? signature.erasedSignatureCache || (signature.erasedSignatureCache = createErasedSignature(signature)) : signature;
-    }
-    function createErasedSignature(signature) {
-      return instantiateSignature(
-        signature,
-        createTypeEraser(signature.typeParameters),
-        /*eraseTypeParameters*/
-        true
-      );
-    }
-    function getCanonicalSignature(signature) {
-      return signature.typeParameters ? signature.canonicalSignatureCache || (signature.canonicalSignatureCache = createCanonicalSignature(signature)) : signature;
-    }
-    function createCanonicalSignature(signature) {
-      return getSignatureInstantiation(
-        signature,
-        map(signature.typeParameters, (tp) => tp.target && !getConstraintOfTypeParameter(tp.target) ? tp.target : tp),
-        isInJSFile(signature.declaration)
-      );
-    }
-    function getBaseSignature(signature) {
-      const typeParameters = signature.typeParameters;
-      if (typeParameters) {
-        if (signature.baseSignatureCache) {
-          return signature.baseSignatureCache;
-        }
-        const typeEraser = createTypeEraser(typeParameters);
-        const baseConstraintMapper = createTypeMapper(typeParameters, map(typeParameters, (tp) => getConstraintOfTypeParameter(tp) || unknownType));
-        let baseConstraints = map(typeParameters, (tp) => instantiateType(tp, baseConstraintMapper) || unknownType);
-        for (let i = 0; i < typeParameters.length - 1; i++) {
-          baseConstraints = instantiateTypes(baseConstraints, baseConstraintMapper);
-        }
-        baseConstraints = instantiateTypes(baseConstraints, typeEraser);
-        return signature.baseSignatureCache = instantiateSignature(
-          signature,
-          createTypeMapper(typeParameters, baseConstraints),
-          /*eraseTypeParameters*/
-          true
-        );
-      }
-      return signature;
-    }
-    function getOrCreateTypeFromSignature(signature) {
-      var _a;
-      if (!signature.isolatedSignatureType) {
-        const kind = (_a = signature.declaration) == null ? void 0 : _a.kind;
-        const isConstructor = kind === void 0 || kind === 175 /* Constructor */ || kind === 179 /* ConstructSignature */ || kind === 184 /* ConstructorType */;
-        const type = createObjectType(16 /* Anonymous */);
-        type.members = emptySymbols;
-        type.properties = emptyArray;
-        type.callSignatures = !isConstructor ? [signature] : emptyArray;
-        type.constructSignatures = isConstructor ? [signature] : emptyArray;
-        type.indexInfos = emptyArray;
-        signature.isolatedSignatureType = type;
-      }
-      return signature.isolatedSignatureType;
-    }
-    function getIndexSymbol(symbol) {
-      return symbol.members ? getIndexSymbolFromSymbolTable(symbol.members) : void 0;
-    }
-    function getIndexSymbolFromSymbolTable(symbolTable) {
-      return symbolTable.get("__index" /* Index */);
-    }
-    function createIndexInfo(keyType, type, isReadonly, declaration) {
-      return { keyType, type, isReadonly, declaration };
-    }
-    function getIndexInfosOfSymbol(symbol) {
-      const indexSymbol = getIndexSymbol(symbol);
-      return indexSymbol ? getIndexInfosOfIndexSymbol(indexSymbol) : emptyArray;
-    }
-    function getIndexInfosOfIndexSymbol(indexSymbol) {
-      if (indexSymbol.declarations) {
-        const indexInfos = [];
-        for (const declaration of indexSymbol.declarations) {
-          if (declaration.parameters.length === 1) {
-            const parameter = declaration.parameters[0];
-            if (parameter.type) {
-              forEachType(getTypeFromTypeNode(parameter.type), (keyType) => {
-                if (isValidIndexKeyType(keyType) && !findIndexInfo(indexInfos, keyType)) {
-                  indexInfos.push(createIndexInfo(
-                    keyType,
-                    declaration.type ? getTypeFromTypeNode(declaration.type) : anyType,
-                    hasEffectiveModifier(declaration, 64 /* Readonly */),
-                    declaration
-                  ));
-                }
-              });
-            }
-          }
-        }
-        return indexInfos;
-      }
-      return emptyArray;
-    }
-    function isValidIndexKeyType(type) {
-      return !!(type.flags & (4 /* String */ | 8 /* Number */ | 4096 /* ESSymbol */)) || isPatternLiteralType(type) || !!(type.flags & 2097152 /* Intersection */) && !isGenericType(type) && some(type.types, isValidIndexKeyType);
-    }
-    function getConstraintDeclaration(type) {
-      return mapDefined(filter(type.symbol && type.symbol.declarations, isTypeParameterDeclaration), getEffectiveConstraintOfTypeParameter)[0];
-    }
-    function getInferredTypeParameterConstraint(typeParameter, omitTypeReferences) {
-      var _a;
-      let inferences;
-      if ((_a = typeParameter.symbol) == null ? void 0 : _a.declarations) {
-        for (const declaration of typeParameter.symbol.declarations) {
-          if (declaration.parent.kind === 194 /* InferType */) {
-            const [childTypeParameter = declaration.parent, grandParent] = walkUpParenthesizedTypesAndGetParentAndChild(declaration.parent.parent);
-            if (grandParent.kind === 182 /* TypeReference */ && !omitTypeReferences) {
-              const typeReference = grandParent;
-              const typeParameters = getTypeParametersForTypeReferenceOrImport(typeReference);
-              if (typeParameters) {
-                const index = typeReference.typeArguments.indexOf(childTypeParameter);
-                if (index < typeParameters.length) {
-                  const declaredConstraint = getConstraintOfTypeParameter(typeParameters[index]);
-                  if (declaredConstraint) {
-                    const mapper = makeDeferredTypeMapper(typeParameters, typeParameters.map((_, index2) => () => {
-                      return getEffectiveTypeArgumentAtIndex(typeReference, typeParameters, index2);
-                    }));
-                    const constraint = instantiateType(declaredConstraint, mapper);
-                    if (constraint !== typeParameter) {
-                      inferences = append(inferences, constraint);
-                    }
-                  }
-                }
-              }
-            } else if (grandParent.kind === 168 /* Parameter */ && grandParent.dotDotDotToken || grandParent.kind === 190 /* RestType */ || grandParent.kind === 201 /* NamedTupleMember */ && grandParent.dotDotDotToken) {
-              inferences = append(inferences, createArrayType(unknownType));
-            } else if (grandParent.kind === 203 /* TemplateLiteralTypeSpan */) {
-              inferences = append(inferences, stringType);
-            } else if (grandParent.kind === 167 /* TypeParameter */ && grandParent.parent.kind === 199 /* MappedType */) {
-              inferences = append(inferences, keyofConstraintType);
-            } else if (grandParent.kind === 199 /* MappedType */ && grandParent.type && skipParentheses(grandParent.type) === declaration.parent && grandParent.parent.kind === 193 /* ConditionalType */ && grandParent.parent.extendsType === grandParent && grandParent.parent.checkType.kind === 199 /* MappedType */ && grandParent.parent.checkType.type) {
-              const checkMappedType2 = grandParent.parent.checkType;
-              const nodeType = getTypeFromTypeNode(checkMappedType2.type);
-              inferences = append(inferences, instantiateType(
-                nodeType,
-                makeUnaryTypeMapper(getDeclaredTypeOfTypeParameter(getSymbolOfDeclaration(checkMappedType2.typeParameter)), checkMappedType2.typeParameter.constraint ? getTypeFromTypeNode(checkMappedType2.typeParameter.constraint) : keyofConstraintType)
-              ));
-            }
-          }
-        }
-      }
-      return inferences && getIntersectionType(inferences);
-    }
-    function getConstraintFromTypeParameter(typeParameter) {
-      if (!typeParameter.constraint) {
-        if (typeParameter.target) {
-          const targetConstraint = getConstraintOfTypeParameter(typeParameter.target);
-          typeParameter.constraint = targetConstraint ? instantiateType(targetConstraint, typeParameter.mapper) : noConstraintType;
-        } else {
-          const constraintDeclaration = getConstraintDeclaration(typeParameter);
-          if (!constraintDeclaration) {
-            typeParameter.constraint = getInferredTypeParameterConstraint(typeParameter) || noConstraintType;
-          } else {
-            let type = getTypeFromTypeNode(constraintDeclaration);
-            if (type.flags & 1 /* Any */ && !isErrorType(type)) {
-              type = constraintDeclaration.parent.parent.kind === 199 /* MappedType */ ? keyofConstraintType : unknownType;
-            }
-            typeParameter.constraint = type;
-          }
-        }
-      }
-      return typeParameter.constraint === noConstraintType ? void 0 : typeParameter.constraint;
-    }
-    function getParentSymbolOfTypeParameter(typeParameter) {
-      const tp = getDeclarationOfKind(typeParameter.symbol, 167 /* TypeParameter */);
-      const host2 = isJSDocTemplateTag(tp.parent) ? getEffectiveContainerForJSDocTemplateTag(tp.parent) : tp.parent;
-      return host2 && getSymbolOfNode(host2);
-    }
-    function getTypeListId(types) {
-      let result = "";
-      if (types) {
-        const length2 = types.length;
-        let i = 0;
-        while (i < length2) {
-          const startId = types[i].id;
-          let count = 1;
-          while (i + count < length2 && types[i + count].id === startId + count) {
-            count++;
-          }
-          if (result.length) {
-            result += ",";
-          }
-          result += startId;
-          if (count > 1) {
-            result += ":" + count;
-          }
-          i += count;
-        }
-      }
-      return result;
-    }
-    function getAliasId(aliasSymbol, aliasTypeArguments) {
-      return aliasSymbol ? `@${getSymbolId(aliasSymbol)}` + (aliasTypeArguments ? `:${getTypeListId(aliasTypeArguments)}` : "") : "";
-    }
-    function getPropagatingFlagsOfTypes(types, excludeKinds) {
-      let result = 0;
-      for (const type of types) {
-        if (excludeKinds === void 0 || !(type.flags & excludeKinds)) {
-          result |= getObjectFlags(type);
-        }
-      }
-      return result & 458752 /* PropagatingFlags */;
-    }
-    function tryCreateTypeReference(target, typeArguments) {
-      if (some(typeArguments) && target === emptyGenericType) {
-        return unknownType;
-      }
-      return createTypeReference(target, typeArguments);
-    }
-    function createTypeReference(target, typeArguments) {
-      const id = getTypeListId(typeArguments);
-      let type = target.instantiations.get(id);
-      if (!type) {
-        type = createObjectType(4 /* Reference */, target.symbol);
-        target.instantiations.set(id, type);
-        type.objectFlags |= typeArguments ? getPropagatingFlagsOfTypes(typeArguments) : 0;
-        type.target = target;
-        type.resolvedTypeArguments = typeArguments;
-      }
-      return type;
-    }
-    function cloneTypeReference(source) {
-      const type = createTypeWithSymbol(source.flags, source.symbol);
-      type.objectFlags = source.objectFlags;
-      type.target = source.target;
-      type.resolvedTypeArguments = source.resolvedTypeArguments;
-      return type;
-    }
-    function createDeferredTypeReference(target, node, mapper, aliasSymbol, aliasTypeArguments) {
-      if (!aliasSymbol) {
-        aliasSymbol = getAliasSymbolForTypeNode(node);
-        const localAliasTypeArguments = getTypeArgumentsForAliasSymbol(aliasSymbol);
-        aliasTypeArguments = mapper ? instantiateTypes(localAliasTypeArguments, mapper) : localAliasTypeArguments;
-      }
-      const type = createObjectType(4 /* Reference */, target.symbol);
-      type.target = target;
-      type.node = node;
-      type.mapper = mapper;
-      type.aliasSymbol = aliasSymbol;
-      type.aliasTypeArguments = aliasTypeArguments;
-      return type;
-    }
-    function getTypeArguments(type) {
-      var _a, _b;
-      if (!type.resolvedTypeArguments) {
-        if (!pushTypeResolution(type, 6 /* ResolvedTypeArguments */)) {
-          return ((_a = type.target.localTypeParameters) == null ? void 0 : _a.map(() => errorType)) || emptyArray;
-        }
-        const node = type.node;
-        const typeArguments = !node ? emptyArray : node.kind === 182 /* TypeReference */ ? concatenate(type.target.outerTypeParameters, getEffectiveTypeArguments2(node, type.target.localTypeParameters)) : node.kind === 187 /* ArrayType */ ? [getTypeFromTypeNode(node.elementType)] : map(node.elements, getTypeFromTypeNode);
-        if (popTypeResolution()) {
-          type.resolvedTypeArguments = type.mapper ? instantiateTypes(typeArguments, type.mapper) : typeArguments;
-        } else {
-          type.resolvedTypeArguments = ((_b = type.target.localTypeParameters) == null ? void 0 : _b.map(() => errorType)) || emptyArray;
-          error(
-            type.node || currentNode,
-            type.target.symbol ? Diagnostics.Type_arguments_for_0_circularly_reference_themselves : Diagnostics.Tuple_type_arguments_circularly_reference_themselves,
-            type.target.symbol && symbolToString(type.target.symbol)
-          );
-        }
-      }
-      return type.resolvedTypeArguments;
-    }
-    function getTypeReferenceArity(type) {
-      return length(type.target.typeParameters);
-    }
-    function getTypeFromClassOrInterfaceReference(node, symbol) {
-      const type = getDeclaredTypeOfSymbol(getMergedSymbol(symbol));
-      const typeParameters = type.localTypeParameters;
-      if (typeParameters) {
-        const numTypeArguments = length(node.typeArguments);
-        const minTypeArgumentCount = getMinTypeArgumentCount(typeParameters);
-        const isJs = isInJSFile(node);
-        const isJsImplicitAny = !noImplicitAny && isJs;
-        if (!isJsImplicitAny && (numTypeArguments < minTypeArgumentCount || numTypeArguments > typeParameters.length)) {
-          const missingAugmentsTag = isJs && isExpressionWithTypeArguments(node) && !isJSDocAugmentsTag(node.parent);
-          const diag2 = minTypeArgumentCount === typeParameters.length ? missingAugmentsTag ? Diagnostics.Expected_0_type_arguments_provide_these_with_an_extends_tag : Diagnostics.Generic_type_0_requires_1_type_argument_s : missingAugmentsTag ? Diagnostics.Expected_0_1_type_arguments_provide_these_with_an_extends_tag : Diagnostics.Generic_type_0_requires_between_1_and_2_type_arguments;
-          const typeStr = typeToString(
-            type,
-            /*enclosingDeclaration*/
-            void 0,
-            2 /* WriteArrayAsGenericType */
-          );
-          error(node, diag2, typeStr, minTypeArgumentCount, typeParameters.length);
-          if (!isJs) {
-            return errorType;
-          }
-        }
-        if (node.kind === 182 /* TypeReference */ && isDeferredTypeReferenceNode(node, length(node.typeArguments) !== typeParameters.length)) {
-          return createDeferredTypeReference(
-            type,
-            node,
-            /*mapper*/
-            void 0
-          );
-        }
-        const typeArguments = concatenate(type.outerTypeParameters, fillMissingTypeArguments(typeArgumentsFromTypeReferenceNode(node), typeParameters, minTypeArgumentCount, isJs));
-        return createTypeReference(type, typeArguments);
-      }
-      return checkNoTypeArguments(node, symbol) ? type : errorType;
-    }
-    function getTypeAliasInstantiation(symbol, typeArguments, aliasSymbol, aliasTypeArguments) {
-      const type = getDeclaredTypeOfSymbol(symbol);
-      if (type === intrinsicMarkerType && intrinsicTypeKinds.has(symbol.escapedName) && typeArguments && typeArguments.length === 1) {
-        return getStringMappingType(symbol, typeArguments[0]);
-      }
-      const links = getSymbolLinks(symbol);
-      const typeParameters = links.typeParameters;
-      const id = getTypeListId(typeArguments) + getAliasId(aliasSymbol, aliasTypeArguments);
-      let instantiation = links.instantiations.get(id);
-      if (!instantiation) {
-        links.instantiations.set(id, instantiation = instantiateTypeWithAlias(
-          type,
-          createTypeMapper(typeParameters, fillMissingTypeArguments(typeArguments, typeParameters, getMinTypeArgumentCount(typeParameters), isInJSFile(symbol.valueDeclaration))),
-          aliasSymbol,
-          aliasTypeArguments
-        ));
-      }
-      return instantiation;
-    }
-    function getTypeFromTypeAliasReference(node, symbol) {
-      if (getCheckFlags(symbol) & 1048576 /* Unresolved */) {
-        const typeArguments = typeArgumentsFromTypeReferenceNode(node);
-        const id = getAliasId(symbol, typeArguments);
-        let errorType2 = errorTypes.get(id);
-        if (!errorType2) {
-          errorType2 = createIntrinsicType(1 /* Any */, "error");
-          errorType2.aliasSymbol = symbol;
-          errorType2.aliasTypeArguments = typeArguments;
-          errorTypes.set(id, errorType2);
-        }
-        return errorType2;
-      }
-      const type = getDeclaredTypeOfSymbol(symbol);
-      const typeParameters = getSymbolLinks(symbol).typeParameters;
-      if (typeParameters) {
-        const numTypeArguments = length(node.typeArguments);
-        const minTypeArgumentCount = getMinTypeArgumentCount(typeParameters);
-        if (numTypeArguments < minTypeArgumentCount || numTypeArguments > typeParameters.length) {
-          error(
-            node,
-            minTypeArgumentCount === typeParameters.length ? Diagnostics.Generic_type_0_requires_1_type_argument_s : Diagnostics.Generic_type_0_requires_between_1_and_2_type_arguments,
-            symbolToString(symbol),
-            minTypeArgumentCount,
-            typeParameters.length
-          );
-          return errorType;
-        }
-        const aliasSymbol = getAliasSymbolForTypeNode(node);
-        let newAliasSymbol = aliasSymbol && (isLocalTypeAlias(symbol) || !isLocalTypeAlias(aliasSymbol)) ? aliasSymbol : void 0;
-        let aliasTypeArguments;
-        if (newAliasSymbol) {
-          aliasTypeArguments = getTypeArgumentsForAliasSymbol(newAliasSymbol);
-        } else if (isTypeReferenceType(node)) {
-          const aliasSymbol2 = resolveTypeReferenceName(
-            node,
-            2097152 /* Alias */,
-            /*ignoreErrors*/
-            true
-          );
-          if (aliasSymbol2 && aliasSymbol2 !== unknownSymbol) {
-            const resolved = resolveAlias(aliasSymbol2);
-            if (resolved && resolved.flags & 524288 /* TypeAlias */) {
-              newAliasSymbol = resolved;
-              aliasTypeArguments = typeArgumentsFromTypeReferenceNode(node) || (typeParameters ? [] : void 0);
-            }
-          }
-        }
-        return getTypeAliasInstantiation(symbol, typeArgumentsFromTypeReferenceNode(node), newAliasSymbol, aliasTypeArguments);
-      }
-      return checkNoTypeArguments(node, symbol) ? type : errorType;
-    }
-    function isLocalTypeAlias(symbol) {
-      var _a;
-      const declaration = (_a = symbol.declarations) == null ? void 0 : _a.find(isTypeAlias);
-      return !!(declaration && getContainingFunction(declaration));
-    }
-    function getTypeReferenceName(node) {
-      switch (node.kind) {
-        case 182 /* TypeReference */:
-          return node.typeName;
-        case 232 /* ExpressionWithTypeArguments */:
-          const expr = node.expression;
-          if (isEntityNameExpression(expr)) {
-            return expr;
-          }
-      }
-      return void 0;
-    }
-    function getSymbolPath(symbol) {
-      return symbol.parent ? `${getSymbolPath(symbol.parent)}.${symbol.escapedName}` : symbol.escapedName;
-    }
-    function getUnresolvedSymbolForEntityName(name) {
-      const identifier = name.kind === 165 /* QualifiedName */ ? name.right : name.kind === 210 /* PropertyAccessExpression */ ? name.name : name;
-      const text = identifier.escapedText;
-      if (text) {
-        const parentSymbol = name.kind === 165 /* QualifiedName */ ? getUnresolvedSymbolForEntityName(name.left) : name.kind === 210 /* PropertyAccessExpression */ ? getUnresolvedSymbolForEntityName(name.expression) : void 0;
-        const path = parentSymbol ? `${getSymbolPath(parentSymbol)}.${text}` : text;
-        let result = unresolvedSymbols.get(path);
-        if (!result) {
-          unresolvedSymbols.set(path, result = createSymbol(524288 /* TypeAlias */, text, 1048576 /* Unresolved */));
-          result.parent = parentSymbol;
-          result.links.declaredType = unresolvedType;
-        }
-        return result;
-      }
-      return unknownSymbol;
-    }
-    function resolveTypeReferenceName(typeReference, meaning, ignoreErrors) {
-      const name = getTypeReferenceName(typeReference);
-      if (!name) {
-        return unknownSymbol;
-      }
-      const symbol = resolveEntityName(name, meaning, ignoreErrors);
-      return symbol && symbol !== unknownSymbol ? symbol : ignoreErrors ? unknownSymbol : getUnresolvedSymbolForEntityName(name);
-    }
-    function getTypeReferenceType(node, symbol) {
-      if (symbol === unknownSymbol) {
-        return errorType;
-      }
-      symbol = getExpandoSymbol(symbol) || symbol;
-      if (symbol.flags & (32 /* Class */ | 64 /* Interface */)) {
-        return getTypeFromClassOrInterfaceReference(node, symbol);
-      }
-      if (symbol.flags & 524288 /* TypeAlias */) {
-        return getTypeFromTypeAliasReference(node, symbol);
-      }
-      const res = tryGetDeclaredTypeOfSymbol(symbol);
-      if (res) {
-        return checkNoTypeArguments(node, symbol) ? getRegularTypeOfLiteralType(res) : errorType;
-      }
-      if (symbol.flags & 111551 /* Value */ && isJSDocTypeReference(node)) {
-        const jsdocType = getTypeFromJSDocValueReference(node, symbol);
-        if (jsdocType) {
-          return jsdocType;
-        } else {
-          resolveTypeReferenceName(node, 788968 /* Type */);
-          return getTypeOfSymbol(symbol);
-        }
-      }
-      return errorType;
-    }
-    function getTypeFromJSDocValueReference(node, symbol) {
-      const links = getNodeLinks(node);
-      if (!links.resolvedJSDocType) {
-        const valueType = getTypeOfSymbol(symbol);
-        let typeType = valueType;
-        if (symbol.valueDeclaration) {
-          const isImportTypeWithQualifier = node.kind === 204 /* ImportType */ && node.qualifier;
-          if (valueType.symbol && valueType.symbol !== symbol && isImportTypeWithQualifier) {
-            typeType = getTypeReferenceType(node, valueType.symbol);
-          }
-        }
-        links.resolvedJSDocType = typeType;
-      }
-      return links.resolvedJSDocType;
-    }
-    function getSubstitutionType(baseType, constraint) {
-      if (constraint.flags & 3 /* AnyOrUnknown */ || constraint === baseType || baseType.flags & 1 /* Any */) {
-        return baseType;
-      }
-      const id = `${getTypeId(baseType)}>${getTypeId(constraint)}`;
-      const cached = substitutionTypes.get(id);
-      if (cached) {
-        return cached;
-      }
-      const result = createType(33554432 /* Substitution */);
-      result.baseType = baseType;
-      result.constraint = constraint;
-      substitutionTypes.set(id, result);
-      return result;
-    }
-    function getSubstitutionIntersection(substitutionType) {
-      return getIntersectionType([substitutionType.constraint, substitutionType.baseType]);
-    }
-    function isUnaryTupleTypeNode(node) {
-      return node.kind === 188 /* TupleType */ && node.elements.length === 1;
-    }
-    function getImpliedConstraint(type, checkNode, extendsNode) {
-      return isUnaryTupleTypeNode(checkNode) && isUnaryTupleTypeNode(extendsNode) ? getImpliedConstraint(type, checkNode.elements[0], extendsNode.elements[0]) : getActualTypeVariable(getTypeFromTypeNode(checkNode)) === getActualTypeVariable(type) ? getTypeFromTypeNode(extendsNode) : void 0;
-    }
-    function getConditionalFlowTypeOfType(type, node) {
-      let constraints;
-      let covariant = true;
-      while (node && !isStatement(node) && node.kind !== 326 /* JSDoc */) {
-        const parent2 = node.parent;
-        if (parent2.kind === 168 /* Parameter */) {
-          covariant = !covariant;
-        }
-        if ((covariant || type.flags & 8650752 /* TypeVariable */) && parent2.kind === 193 /* ConditionalType */ && node === parent2.trueType) {
-          const constraint = getImpliedConstraint(type, parent2.checkType, parent2.extendsType);
-          if (constraint) {
-            constraints = append(constraints, constraint);
-          }
-        } else if (type.flags & 262144 /* TypeParameter */ && parent2.kind === 199 /* MappedType */ && node === parent2.type) {
-          const mappedType = getTypeFromTypeNode(parent2);
-          if (getTypeParameterFromMappedType(mappedType) === getActualTypeVariable(type)) {
-            const typeParameter = getHomomorphicTypeVariable(mappedType);
-            if (typeParameter) {
-              const constraint = getConstraintOfTypeParameter(typeParameter);
-              if (constraint && everyType(constraint, isArrayOrTupleType)) {
-                constraints = append(constraints, getUnionType([numberType, numericStringType]));
-              }
-            }
-          }
-        }
-        node = parent2;
-      }
-      return constraints ? getSubstitutionType(type, getIntersectionType(constraints)) : type;
-    }
-    function isJSDocTypeReference(node) {
-      return !!(node.flags & 8388608 /* JSDoc */) && (node.kind === 182 /* TypeReference */ || node.kind === 204 /* ImportType */);
-    }
-    function checkNoTypeArguments(node, symbol) {
-      if (node.typeArguments) {
-        error(node, Diagnostics.Type_0_is_not_generic, symbol ? symbolToString(symbol) : node.typeName ? declarationNameToString(node.typeName) : anon);
-        return false;
-      }
-      return true;
-    }
-    function getIntendedTypeFromJSDocTypeReference(node) {
-      if (isIdentifier(node.typeName)) {
-        const typeArgs = node.typeArguments;
-        switch (node.typeName.escapedText) {
-          case "String":
-            checkNoTypeArguments(node);
-            return stringType;
-          case "Number":
-            checkNoTypeArguments(node);
-            return numberType;
-          case "Boolean":
-            checkNoTypeArguments(node);
-            return booleanType;
-          case "Void":
-            checkNoTypeArguments(node);
-            return voidType;
-          case "Undefined":
-            checkNoTypeArguments(node);
-            return undefinedType;
-          case "Null":
-            checkNoTypeArguments(node);
-            return nullType;
-          case "Function":
-          case "function":
-            checkNoTypeArguments(node);
-            return globalFunctionType;
-          case "array":
-            return (!typeArgs || !typeArgs.length) && !noImplicitAny ? anyArrayType : void 0;
-          case "promise":
-            return (!typeArgs || !typeArgs.length) && !noImplicitAny ? createPromiseType(anyType) : void 0;
-          case "Object":
-            if (typeArgs && typeArgs.length === 2) {
-              if (isJSDocIndexSignature(node)) {
-                const indexed = getTypeFromTypeNode(typeArgs[0]);
-                const target = getTypeFromTypeNode(typeArgs[1]);
-                const indexInfo = indexed === stringType || indexed === numberType ? [createIndexInfo(
-                  indexed,
-                  target,
-                  /*isReadonly*/
-                  false
-                )] : emptyArray;
-                return createAnonymousType(
-                  /*symbol*/
-                  void 0,
-                  emptySymbols,
-                  emptyArray,
-                  emptyArray,
-                  indexInfo
-                );
-              }
-              return anyType;
-            }
-            checkNoTypeArguments(node);
-            return !noImplicitAny ? anyType : void 0;
-        }
-      }
-    }
-    function getTypeFromJSDocNullableTypeNode(node) {
-      const type = getTypeFromTypeNode(node.type);
-      return strictNullChecks ? getNullableType(type, 65536 /* Null */) : type;
-    }
-    function getTypeFromTypeReference(node) {
-      const links = getNodeLinks(node);
-      if (!links.resolvedType) {
-        if (isConstTypeReference(node) && isAssertionExpression(node.parent)) {
-          links.resolvedSymbol = unknownSymbol;
-          return links.resolvedType = checkExpressionCached(node.parent.expression);
-        }
-        let symbol;
-        let type;
-        const meaning = 788968 /* Type */;
-        if (isJSDocTypeReference(node)) {
-          type = getIntendedTypeFromJSDocTypeReference(node);
-          if (!type) {
-            symbol = resolveTypeReferenceName(
-              node,
-              meaning,
-              /*ignoreErrors*/
-              true
-            );
-            if (symbol === unknownSymbol) {
-              symbol = resolveTypeReferenceName(node, meaning | 111551 /* Value */);
-            } else {
-              resolveTypeReferenceName(node, meaning);
-            }
-            type = getTypeReferenceType(node, symbol);
-          }
-        }
-        if (!type) {
-          symbol = resolveTypeReferenceName(node, meaning);
-          type = getTypeReferenceType(node, symbol);
-        }
-        links.resolvedSymbol = symbol;
-        links.resolvedType = type;
-      }
-      return links.resolvedType;
-    }
-    function typeArgumentsFromTypeReferenceNode(node) {
-      return map(node.typeArguments, getTypeFromTypeNode);
-    }
-    function getTypeFromTypeQueryNode(node) {
-      const links = getNodeLinks(node);
-      if (!links.resolvedType) {
-        const type = checkExpressionWithTypeArguments(node);
-        links.resolvedType = getRegularTypeOfLiteralType(getWidenedType(type));
-      }
-      return links.resolvedType;
-    }
-    function getTypeOfGlobalSymbol(symbol, arity) {
-      function getTypeDeclaration(symbol2) {
-        const declarations = symbol2.declarations;
-        if (declarations) {
-          for (const declaration of declarations) {
-            switch (declaration.kind) {
-              case 262 /* ClassDeclaration */:
-              case 263 /* InterfaceDeclaration */:
-              case 265 /* EnumDeclaration */:
-                return declaration;
-            }
-          }
-        }
-      }
-      if (!symbol) {
-        return arity ? emptyGenericType : emptyObjectType;
-      }
-      const type = getDeclaredTypeOfSymbol(symbol);
-      if (!(type.flags & 524288 /* Object */)) {
-        error(getTypeDeclaration(symbol), Diagnostics.Global_type_0_must_be_a_class_or_interface_type, symbolName(symbol));
-        return arity ? emptyGenericType : emptyObjectType;
-      }
-      if (length(type.typeParameters) !== arity) {
-        error(getTypeDeclaration(symbol), Diagnostics.Global_type_0_must_have_1_type_parameter_s, symbolName(symbol), arity);
-        return arity ? emptyGenericType : emptyObjectType;
-      }
-      return type;
-    }
-    function getGlobalValueSymbol(name, reportErrors2) {
-      return getGlobalSymbol(name, 111551 /* Value */, reportErrors2 ? Diagnostics.Cannot_find_global_value_0 : void 0);
-    }
-    function getGlobalTypeSymbol(name, reportErrors2) {
-      return getGlobalSymbol(name, 788968 /* Type */, reportErrors2 ? Diagnostics.Cannot_find_global_type_0 : void 0);
-    }
-    function getGlobalTypeAliasSymbol(name, arity, reportErrors2) {
-      const symbol = getGlobalSymbol(name, 788968 /* Type */, reportErrors2 ? Diagnostics.Cannot_find_global_type_0 : void 0);
-      if (symbol) {
-        getDeclaredTypeOfSymbol(symbol);
-        if (length(getSymbolLinks(symbol).typeParameters) !== arity) {
-          const decl = symbol.declarations && find(symbol.declarations, isTypeAliasDeclaration);
-          error(decl, Diagnostics.Global_type_0_must_have_1_type_parameter_s, symbolName(symbol), arity);
-          return void 0;
-        }
-      }
-      return symbol;
-    }
-    function getGlobalSymbol(name, meaning, diagnostic) {
-      return resolveName(
-        /*location*/
-        void 0,
-        name,
-        meaning,
-        diagnostic,
-        name,
-        /*isUse*/
-        false,
-        /*excludeGlobals*/
-        false,
-        /*getSpellingSuggestions*/
-        false
-      );
-    }
-    function getGlobalType(name, arity, reportErrors2) {
-      const symbol = getGlobalTypeSymbol(name, reportErrors2);
-      return symbol || reportErrors2 ? getTypeOfGlobalSymbol(symbol, arity) : void 0;
-    }
-    function getGlobalTypedPropertyDescriptorType() {
-      return deferredGlobalTypedPropertyDescriptorType || (deferredGlobalTypedPropertyDescriptorType = getGlobalType(
-        "TypedPropertyDescriptor",
-        /*arity*/
-        1,
-        /*reportErrors*/
-        true
-      ) || emptyGenericType);
-    }
-    function getGlobalTemplateStringsArrayType() {
-      return deferredGlobalTemplateStringsArrayType || (deferredGlobalTemplateStringsArrayType = getGlobalType(
-        "TemplateStringsArray",
-        /*arity*/
-        0,
-        /*reportErrors*/
-        true
-      ) || emptyObjectType);
-    }
-    function getGlobalImportMetaType() {
-      return deferredGlobalImportMetaType || (deferredGlobalImportMetaType = getGlobalType(
-        "ImportMeta",
-        /*arity*/
-        0,
-        /*reportErrors*/
-        true
-      ) || emptyObjectType);
-    }
-    function getGlobalImportMetaExpressionType() {
-      if (!deferredGlobalImportMetaExpressionType) {
-        const symbol = createSymbol(0 /* None */, "ImportMetaExpression");
-        const importMetaType = getGlobalImportMetaType();
-        const metaPropertySymbol = createSymbol(4 /* Property */, "meta", 8 /* Readonly */);
-        metaPropertySymbol.parent = symbol;
-        metaPropertySymbol.links.type = importMetaType;
-        const members = createSymbolTable([metaPropertySymbol]);
-        symbol.members = members;
-        deferredGlobalImportMetaExpressionType = createAnonymousType(symbol, members, emptyArray, emptyArray, emptyArray);
-      }
-      return deferredGlobalImportMetaExpressionType;
-    }
-    function getGlobalImportCallOptionsType(reportErrors2) {
-      return deferredGlobalImportCallOptionsType || (deferredGlobalImportCallOptionsType = getGlobalType(
-        "ImportCallOptions",
-        /*arity*/
-        0,
-        reportErrors2
-      )) || emptyObjectType;
-    }
-    function getGlobalESSymbolConstructorSymbol(reportErrors2) {
-      return deferredGlobalESSymbolConstructorSymbol || (deferredGlobalESSymbolConstructorSymbol = getGlobalValueSymbol("Symbol", reportErrors2));
-    }
-    function getGlobalESSymbolConstructorTypeSymbol(reportErrors2) {
-      return deferredGlobalESSymbolConstructorTypeSymbol || (deferredGlobalESSymbolConstructorTypeSymbol = getGlobalTypeSymbol("SymbolConstructor", reportErrors2));
-    }
-    function getGlobalESSymbolType() {
-      return deferredGlobalESSymbolType || (deferredGlobalESSymbolType = getGlobalType(
-        "Symbol",
-        /*arity*/
-        0,
-        /*reportErrors*/
-        false
-      )) || emptyObjectType;
-    }
-    function getGlobalPromiseType(reportErrors2) {
-      return deferredGlobalPromiseType || (deferredGlobalPromiseType = getGlobalType(
-        "Promise",
-        /*arity*/
-        1,
-        reportErrors2
-      )) || emptyGenericType;
-    }
-    function getGlobalPromiseLikeType(reportErrors2) {
-      return deferredGlobalPromiseLikeType || (deferredGlobalPromiseLikeType = getGlobalType(
-        "PromiseLike",
-        /*arity*/
-        1,
-        reportErrors2
-      )) || emptyGenericType;
-    }
-    function getGlobalPromiseConstructorSymbol(reportErrors2) {
-      return deferredGlobalPromiseConstructorSymbol || (deferredGlobalPromiseConstructorSymbol = getGlobalValueSymbol("Promise", reportErrors2));
-    }
-    function getGlobalPromiseConstructorLikeType(reportErrors2) {
-      return deferredGlobalPromiseConstructorLikeType || (deferredGlobalPromiseConstructorLikeType = getGlobalType(
-        "PromiseConstructorLike",
-        /*arity*/
-        0,
-        reportErrors2
-      )) || emptyObjectType;
-    }
-    function getGlobalAsyncIterableType(reportErrors2) {
-      return deferredGlobalAsyncIterableType || (deferredGlobalAsyncIterableType = getGlobalType(
-        "AsyncIterable",
-        /*arity*/
-        1,
-        reportErrors2
-      )) || emptyGenericType;
-    }
-    function getGlobalAsyncIteratorType(reportErrors2) {
-      return deferredGlobalAsyncIteratorType || (deferredGlobalAsyncIteratorType = getGlobalType(
-        "AsyncIterator",
-        /*arity*/
-        3,
-        reportErrors2
-      )) || emptyGenericType;
-    }
-    function getGlobalAsyncIterableIteratorType(reportErrors2) {
-      return deferredGlobalAsyncIterableIteratorType || (deferredGlobalAsyncIterableIteratorType = getGlobalType(
-        "AsyncIterableIterator",
-        /*arity*/
-        1,
-        reportErrors2
-      )) || emptyGenericType;
-    }
-    function getGlobalAsyncGeneratorType(reportErrors2) {
-      return deferredGlobalAsyncGeneratorType || (deferredGlobalAsyncGeneratorType = getGlobalType(
-        "AsyncGenerator",
-        /*arity*/
-        3,
-        reportErrors2
-      )) || emptyGenericType;
-    }
-    function getGlobalIterableType(reportErrors2) {
-      return deferredGlobalIterableType || (deferredGlobalIterableType = getGlobalType(
-        "Iterable",
-        /*arity*/
-        1,
-        reportErrors2
-      )) || emptyGenericType;
-    }
-    function getGlobalIteratorType(reportErrors2) {
-      return deferredGlobalIteratorType || (deferredGlobalIteratorType = getGlobalType(
-        "Iterator",
-        /*arity*/
-        3,
-        reportErrors2
-      )) || emptyGenericType;
-    }
-    function getGlobalIterableIteratorType(reportErrors2) {
-      return deferredGlobalIterableIteratorType || (deferredGlobalIterableIteratorType = getGlobalType(
-        "IterableIterator",
-        /*arity*/
-        1,
-        reportErrors2
-      )) || emptyGenericType;
-    }
-    function getGlobalGeneratorType(reportErrors2) {
-      return deferredGlobalGeneratorType || (deferredGlobalGeneratorType = getGlobalType(
-        "Generator",
-        /*arity*/
-        3,
-        reportErrors2
-      )) || emptyGenericType;
-    }
-    function getGlobalIteratorYieldResultType(reportErrors2) {
-      return deferredGlobalIteratorYieldResultType || (deferredGlobalIteratorYieldResultType = getGlobalType(
-        "IteratorYieldResult",
-        /*arity*/
-        1,
-        reportErrors2
-      )) || emptyGenericType;
-    }
-    function getGlobalIteratorReturnResultType(reportErrors2) {
-      return deferredGlobalIteratorReturnResultType || (deferredGlobalIteratorReturnResultType = getGlobalType(
-        "IteratorReturnResult",
-        /*arity*/
-        1,
-        reportErrors2
-      )) || emptyGenericType;
-    }
-    function getGlobalTypeOrUndefined(name, arity = 0) {
-      const symbol = getGlobalSymbol(
-        name,
-        788968 /* Type */,
-        /*diagnostic*/
-        void 0
-      );
-      return symbol && getTypeOfGlobalSymbol(symbol, arity);
-    }
-    function getGlobalExtractSymbol() {
-      deferredGlobalExtractSymbol || (deferredGlobalExtractSymbol = getGlobalTypeAliasSymbol(
-        "Extract",
-        /*arity*/
-        2,
-        /*reportErrors*/
-        true
-      ) || unknownSymbol);
-      return deferredGlobalExtractSymbol === unknownSymbol ? void 0 : deferredGlobalExtractSymbol;
-    }
-    function getGlobalOmitSymbol() {
-      deferredGlobalOmitSymbol || (deferredGlobalOmitSymbol = getGlobalTypeAliasSymbol(
-        "Omit",
-        /*arity*/
-        2,
-        /*reportErrors*/
-        true
-      ) || unknownSymbol);
-      return deferredGlobalOmitSymbol === unknownSymbol ? void 0 : deferredGlobalOmitSymbol;
-    }
-    function getGlobalAwaitedSymbol(reportErrors2) {
-      deferredGlobalAwaitedSymbol || (deferredGlobalAwaitedSymbol = getGlobalTypeAliasSymbol(
-        "Awaited",
-        /*arity*/
-        1,
-        reportErrors2
-      ) || (reportErrors2 ? unknownSymbol : void 0));
-      return deferredGlobalAwaitedSymbol === unknownSymbol ? void 0 : deferredGlobalAwaitedSymbol;
-    }
-    function getGlobalBigIntType() {
-      return deferredGlobalBigIntType || (deferredGlobalBigIntType = getGlobalType(
-        "BigInt",
-        /*arity*/
-        0,
-        /*reportErrors*/
-        false
-      )) || emptyObjectType;
-    }
-    function getGlobalClassDecoratorContextType(reportErrors2) {
-      return deferredGlobalClassDecoratorContextType ?? (deferredGlobalClassDecoratorContextType = getGlobalType(
-        "ClassDecoratorContext",
-        /*arity*/
-        1,
-        reportErrors2
-      )) ?? emptyGenericType;
-    }
-    function getGlobalClassMethodDecoratorContextType(reportErrors2) {
-      return deferredGlobalClassMethodDecoratorContextType ?? (deferredGlobalClassMethodDecoratorContextType = getGlobalType(
-        "ClassMethodDecoratorContext",
-        /*arity*/
-        2,
-        reportErrors2
-      )) ?? emptyGenericType;
-    }
-    function getGlobalClassGetterDecoratorContextType(reportErrors2) {
-      return deferredGlobalClassGetterDecoratorContextType ?? (deferredGlobalClassGetterDecoratorContextType = getGlobalType(
-        "ClassGetterDecoratorContext",
-        /*arity*/
-        2,
-        reportErrors2
-      )) ?? emptyGenericType;
-    }
-    function getGlobalClassSetterDecoratorContextType(reportErrors2) {
-      return deferredGlobalClassSetterDecoratorContextType ?? (deferredGlobalClassSetterDecoratorContextType = getGlobalType(
-        "ClassSetterDecoratorContext",
-        /*arity*/
-        2,
-        reportErrors2
-      )) ?? emptyGenericType;
-    }
-    function getGlobalClassAccessorDecoratorContextType(reportErrors2) {
-      return deferredGlobalClassAccessorDecoratorContextType ?? (deferredGlobalClassAccessorDecoratorContextType = getGlobalType(
-        "ClassAccessorDecoratorContext",
-        /*arity*/
-        2,
-        reportErrors2
-      )) ?? emptyGenericType;
-    }
-    function getGlobalClassAccessorDecoratorTargetType(reportErrors2) {
-      return deferredGlobalClassAccessorDecoratorTargetType ?? (deferredGlobalClassAccessorDecoratorTargetType = getGlobalType(
-        "ClassAccessorDecoratorTarget",
-        /*arity*/
-        2,
-        reportErrors2
-      )) ?? emptyGenericType;
-    }
-    function getGlobalClassAccessorDecoratorResultType(reportErrors2) {
-      return deferredGlobalClassAccessorDecoratorResultType ?? (deferredGlobalClassAccessorDecoratorResultType = getGlobalType(
-        "ClassAccessorDecoratorResult",
-        /*arity*/
-        2,
-        reportErrors2
-      )) ?? emptyGenericType;
-    }
-    function getGlobalClassFieldDecoratorContextType(reportErrors2) {
-      return deferredGlobalClassFieldDecoratorContextType ?? (deferredGlobalClassFieldDecoratorContextType = getGlobalType(
-        "ClassFieldDecoratorContext",
-        /*arity*/
-        2,
-        reportErrors2
-      )) ?? emptyGenericType;
-    }
-    function getGlobalNaNSymbol() {
-      return deferredGlobalNaNSymbol || (deferredGlobalNaNSymbol = getGlobalValueSymbol(
-        "NaN",
-        /*reportErrors*/
-        false
-      ));
-    }
-    function getGlobalRecordSymbol() {
-      deferredGlobalRecordSymbol || (deferredGlobalRecordSymbol = getGlobalTypeAliasSymbol(
-        "Record",
-        /*arity*/
-        2,
-        /*reportErrors*/
-        true
-      ) || unknownSymbol);
-      return deferredGlobalRecordSymbol === unknownSymbol ? void 0 : deferredGlobalRecordSymbol;
-    }
-    function createTypeFromGenericGlobalType(genericGlobalType, typeArguments) {
-      return genericGlobalType !== emptyGenericType ? createTypeReference(genericGlobalType, typeArguments) : emptyObjectType;
-    }
-    function createTypedPropertyDescriptorType(propertyType) {
-      return createTypeFromGenericGlobalType(getGlobalTypedPropertyDescriptorType(), [propertyType]);
-    }
-    function createIterableType(iteratedType) {
-      return createTypeFromGenericGlobalType(getGlobalIterableType(
-        /*reportErrors*/
-        true
-      ), [iteratedType]);
-    }
-    function createArrayType(elementType, readonly) {
-      return createTypeFromGenericGlobalType(readonly ? globalReadonlyArrayType : globalArrayType, [elementType]);
-    }
-    function getTupleElementFlags(node) {
-      switch (node.kind) {
-        case 189 /* OptionalType */:
-          return 2 /* Optional */;
-        case 190 /* RestType */:
-          return getRestTypeElementFlags(node);
-        case 201 /* NamedTupleMember */:
-          return node.questionToken ? 2 /* Optional */ : node.dotDotDotToken ? getRestTypeElementFlags(node) : 1 /* Required */;
-        default:
-          return 1 /* Required */;
-      }
-    }
-    function getRestTypeElementFlags(node) {
-      return getArrayElementTypeNode(node.type) ? 4 /* Rest */ : 8 /* Variadic */;
-    }
-    function getArrayOrTupleTargetType(node) {
-      const readonly = isReadonlyTypeOperator(node.parent);
-      const elementType = getArrayElementTypeNode(node);
-      if (elementType) {
-        return readonly ? globalReadonlyArrayType : globalArrayType;
-      }
-      const elementFlags = map(node.elements, getTupleElementFlags);
-      const missingName = some(node.elements, (e) => e.kind !== 201 /* NamedTupleMember */);
-      return getTupleTargetType(
-        elementFlags,
-        readonly,
-        /*associatedNames*/
-        missingName ? void 0 : node.elements
-      );
-    }
-    function isDeferredTypeReferenceNode(node, hasDefaultTypeArguments) {
-      return !!getAliasSymbolForTypeNode(node) || isResolvedByTypeAlias(node) && (node.kind === 187 /* ArrayType */ ? mayResolveTypeAlias(node.elementType) : node.kind === 188 /* TupleType */ ? some(node.elements, mayResolveTypeAlias) : hasDefaultTypeArguments || some(node.typeArguments, mayResolveTypeAlias));
-    }
-    function isResolvedByTypeAlias(node) {
-      const parent2 = node.parent;
-      switch (parent2.kind) {
-        case 195 /* ParenthesizedType */:
-        case 201 /* NamedTupleMember */:
-        case 182 /* TypeReference */:
-        case 191 /* UnionType */:
-        case 192 /* IntersectionType */:
-        case 198 /* IndexedAccessType */:
-        case 193 /* ConditionalType */:
-        case 197 /* TypeOperator */:
-        case 187 /* ArrayType */:
-        case 188 /* TupleType */:
-          return isResolvedByTypeAlias(parent2);
-        case 264 /* TypeAliasDeclaration */:
-          return true;
-      }
-      return false;
-    }
-    function mayResolveTypeAlias(node) {
-      switch (node.kind) {
-        case 182 /* TypeReference */:
-          return isJSDocTypeReference(node) || !!(resolveTypeReferenceName(node, 788968 /* Type */).flags & 524288 /* TypeAlias */);
-        case 185 /* TypeQuery */:
-          return true;
-        case 197 /* TypeOperator */:
-          return node.operator !== 158 /* UniqueKeyword */ && mayResolveTypeAlias(node.type);
-        case 195 /* ParenthesizedType */:
-        case 189 /* OptionalType */:
-        case 201 /* NamedTupleMember */:
-        case 322 /* JSDocOptionalType */:
-        case 320 /* JSDocNullableType */:
-        case 321 /* JSDocNonNullableType */:
-        case 315 /* JSDocTypeExpression */:
-          return mayResolveTypeAlias(node.type);
-        case 190 /* RestType */:
-          return node.type.kind !== 187 /* ArrayType */ || mayResolveTypeAlias(node.type.elementType);
-        case 191 /* UnionType */:
-        case 192 /* IntersectionType */:
-          return some(node.types, mayResolveTypeAlias);
-        case 198 /* IndexedAccessType */:
-          return mayResolveTypeAlias(node.objectType) || mayResolveTypeAlias(node.indexType);
-        case 193 /* ConditionalType */:
-          return mayResolveTypeAlias(node.checkType) || mayResolveTypeAlias(node.extendsType) || mayResolveTypeAlias(node.trueType) || mayResolveTypeAlias(node.falseType);
-      }
-      return false;
-    }
-    function getTypeFromArrayOrTupleTypeNode(node) {
-      const links = getNodeLinks(node);
-      if (!links.resolvedType) {
-        const target = getArrayOrTupleTargetType(node);
-        if (target === emptyGenericType) {
-          links.resolvedType = emptyObjectType;
-        } else if (!(node.kind === 188 /* TupleType */ && some(node.elements, (e) => !!(getTupleElementFlags(e) & 8 /* Variadic */))) && isDeferredTypeReferenceNode(node)) {
-          links.resolvedType = node.kind === 188 /* TupleType */ && node.elements.length === 0 ? target : createDeferredTypeReference(
-            target,
-            node,
-            /*mapper*/
-            void 0
-          );
-        } else {
-          const elementTypes = node.kind === 187 /* ArrayType */ ? [getTypeFromTypeNode(node.elementType)] : map(node.elements, getTypeFromTypeNode);
-          links.resolvedType = createNormalizedTypeReference(target, elementTypes);
-        }
-      }
-      return links.resolvedType;
-    }
-    function isReadonlyTypeOperator(node) {
-      return isTypeOperatorNode(node) && node.operator === 148 /* ReadonlyKeyword */;
-    }
-    function createTupleType(elementTypes, elementFlags, readonly = false, namedMemberDeclarations) {
-      const tupleTarget = getTupleTargetType(elementFlags || map(elementTypes, (_) => 1 /* Required */), readonly, namedMemberDeclarations);
-      return tupleTarget === emptyGenericType ? emptyObjectType : elementTypes.length ? createNormalizedTypeReference(tupleTarget, elementTypes) : tupleTarget;
-    }
-    function getTupleTargetType(elementFlags, readonly, namedMemberDeclarations) {
-      if (elementFlags.length === 1 && elementFlags[0] & 4 /* Rest */) {
-        return readonly ? globalReadonlyArrayType : globalArrayType;
-      }
-      const key = map(elementFlags, (f) => f & 1 /* Required */ ? "#" : f & 2 /* Optional */ ? "?" : f & 4 /* Rest */ ? "." : "*").join() + (readonly ? "R" : "") + (namedMemberDeclarations && namedMemberDeclarations.length ? "," + map(namedMemberDeclarations, getNodeId).join(",") : "");
-      let type = tupleTypes.get(key);
-      if (!type) {
-        tupleTypes.set(key, type = createTupleTargetType(elementFlags, readonly, namedMemberDeclarations));
-      }
-      return type;
-    }
-    function createTupleTargetType(elementFlags, readonly, namedMemberDeclarations) {
-      const arity = elementFlags.length;
-      const minLength = countWhere(elementFlags, (f) => !!(f & (1 /* Required */ | 8 /* Variadic */)));
-      let typeParameters;
-      const properties = [];
-      let combinedFlags = 0;
-      if (arity) {
-        typeParameters = new Array(arity);
-        for (let i = 0; i < arity; i++) {
-          const typeParameter = typeParameters[i] = createTypeParameter();
-          const flags = elementFlags[i];
-          combinedFlags |= flags;
-          if (!(combinedFlags & 12 /* Variable */)) {
-            const property = createSymbol(
-              4 /* Property */ | (flags & 2 /* Optional */ ? 16777216 /* Optional */ : 0),
-              "" + i,
-              readonly ? 8 /* Readonly */ : 0
-            );
-            property.links.tupleLabelDeclaration = namedMemberDeclarations == null ? void 0 : namedMemberDeclarations[i];
-            property.links.type = typeParameter;
-            properties.push(property);
-          }
-        }
-      }
-      const fixedLength = properties.length;
-      const lengthSymbol = createSymbol(4 /* Property */, "length", readonly ? 8 /* Readonly */ : 0);
-      if (combinedFlags & 12 /* Variable */) {
-        lengthSymbol.links.type = numberType;
-      } else {
-        const literalTypes = [];
-        for (let i = minLength; i <= arity; i++)
-          literalTypes.push(getNumberLiteralType(i));
-        lengthSymbol.links.type = getUnionType(literalTypes);
-      }
-      properties.push(lengthSymbol);
-      const type = createObjectType(8 /* Tuple */ | 4 /* Reference */);
-      type.typeParameters = typeParameters;
-      type.outerTypeParameters = void 0;
-      type.localTypeParameters = typeParameters;
-      type.instantiations = /* @__PURE__ */ new Map();
-      type.instantiations.set(getTypeListId(type.typeParameters), type);
-      type.target = type;
-      type.resolvedTypeArguments = type.typeParameters;
-      type.thisType = createTypeParameter();
-      type.thisType.isThisType = true;
-      type.thisType.constraint = type;
-      type.declaredProperties = properties;
-      type.declaredCallSignatures = emptyArray;
-      type.declaredConstructSignatures = emptyArray;
-      type.declaredIndexInfos = emptyArray;
-      type.elementFlags = elementFlags;
-      type.minLength = minLength;
-      type.fixedLength = fixedLength;
-      type.hasRestElement = !!(combinedFlags & 12 /* Variable */);
-      type.combinedFlags = combinedFlags;
-      type.readonly = readonly;
-      type.labeledElementDeclarations = namedMemberDeclarations;
-      return type;
-    }
-    function createNormalizedTypeReference(target, typeArguments) {
-      return target.objectFlags & 8 /* Tuple */ ? createNormalizedTupleType(target, typeArguments) : createTypeReference(target, typeArguments);
-    }
-    function createNormalizedTupleType(target, elementTypes) {
-      var _a, _b, _c;
-      if (!(target.combinedFlags & 14 /* NonRequired */)) {
-        return createTypeReference(target, elementTypes);
-      }
-      if (target.combinedFlags & 8 /* Variadic */) {
-        const unionIndex = findIndex(elementTypes, (t, i) => !!(target.elementFlags[i] & 8 /* Variadic */ && t.flags & (131072 /* Never */ | 1048576 /* Union */)));
-        if (unionIndex >= 0) {
-          return checkCrossProductUnion(map(elementTypes, (t, i) => target.elementFlags[i] & 8 /* Variadic */ ? t : unknownType)) ? mapType(elementTypes[unionIndex], (t) => createNormalizedTupleType(target, replaceElement(elementTypes, unionIndex, t))) : errorType;
-        }
-      }
-      const expandedTypes = [];
-      const expandedFlags = [];
-      let expandedDeclarations = [];
-      let lastRequiredIndex = -1;
-      let firstRestIndex = -1;
-      let lastOptionalOrRestIndex = -1;
-      for (let i = 0; i < elementTypes.length; i++) {
-        const type = elementTypes[i];
-        const flags = target.elementFlags[i];
-        if (flags & 8 /* Variadic */) {
-          if (type.flags & 58982400 /* InstantiableNonPrimitive */ || isGenericMappedType(type)) {
-            addElement(type, 8 /* Variadic */, (_a = target.labeledElementDeclarations) == null ? void 0 : _a[i]);
-          } else if (isTupleType(type)) {
-            const elements = getElementTypes(type);
-            if (elements.length + expandedTypes.length >= 1e4) {
-              error(currentNode, isPartOfTypeNode(currentNode) ? Diagnostics.Type_produces_a_tuple_type_that_is_too_large_to_represent : Diagnostics.Expression_produces_a_tuple_type_that_is_too_large_to_represent);
-              return errorType;
-            }
-            forEach(elements, (t, n) => {
-              var _a2;
-              return addElement(t, type.target.elementFlags[n], (_a2 = type.target.labeledElementDeclarations) == null ? void 0 : _a2[n]);
-            });
-          } else {
-            addElement(isArrayLikeType(type) && getIndexTypeOfType(type, numberType) || errorType, 4 /* Rest */, (_b = target.labeledElementDeclarations) == null ? void 0 : _b[i]);
-          }
-        } else {
-          addElement(type, flags, (_c = target.labeledElementDeclarations) == null ? void 0 : _c[i]);
-        }
-      }
-      for (let i = 0; i < lastRequiredIndex; i++) {
-        if (expandedFlags[i] & 2 /* Optional */)
-          expandedFlags[i] = 1 /* Required */;
-      }
-      if (firstRestIndex >= 0 && firstRestIndex < lastOptionalOrRestIndex) {
-        expandedTypes[firstRestIndex] = getUnionType(sameMap(
-          expandedTypes.slice(firstRestIndex, lastOptionalOrRestIndex + 1),
-          (t, i) => expandedFlags[firstRestIndex + i] & 8 /* Variadic */ ? getIndexedAccessType(t, numberType) : t
-        ));
-        expandedTypes.splice(firstRestIndex + 1, lastOptionalOrRestIndex - firstRestIndex);
-        expandedFlags.splice(firstRestIndex + 1, lastOptionalOrRestIndex - firstRestIndex);
-        expandedDeclarations == null ? void 0 : expandedDeclarations.splice(firstRestIndex + 1, lastOptionalOrRestIndex - firstRestIndex);
-      }
-      const tupleTarget = getTupleTargetType(expandedFlags, target.readonly, expandedDeclarations);
-      return tupleTarget === emptyGenericType ? emptyObjectType : expandedFlags.length ? createTypeReference(tupleTarget, expandedTypes) : tupleTarget;
-      function addElement(type, flags, declaration) {
-        if (flags & 1 /* Required */) {
-          lastRequiredIndex = expandedFlags.length;
-        }
-        if (flags & 4 /* Rest */ && firstRestIndex < 0) {
-          firstRestIndex = expandedFlags.length;
-        }
-        if (flags & (2 /* Optional */ | 4 /* Rest */)) {
-          lastOptionalOrRestIndex = expandedFlags.length;
-        }
-        expandedTypes.push(flags & 2 /* Optional */ ? addOptionality(
-          type,
-          /*isProperty*/
-          true
-        ) : type);
-        expandedFlags.push(flags);
-        if (expandedDeclarations && declaration) {
-          expandedDeclarations.push(declaration);
-        } else {
-          expandedDeclarations = void 0;
-        }
-      }
-    }
-    function sliceTupleType(type, index, endSkipCount = 0) {
-      const target = type.target;
-      const endIndex = getTypeReferenceArity(type) - endSkipCount;
-      return index > target.fixedLength ? getRestArrayTypeOfTupleType(type) || createTupleType(emptyArray) : createTupleType(
-        getTypeArguments(type).slice(index, endIndex),
-        target.elementFlags.slice(index, endIndex),
-        /*readonly*/
-        false,
-        target.labeledElementDeclarations && target.labeledElementDeclarations.slice(index, endIndex)
-      );
-    }
-    function getKnownKeysOfTupleType(type) {
-      return getUnionType(append(
-        arrayOf(type.target.fixedLength, (i) => getStringLiteralType("" + i)),
-        getIndexType(type.target.readonly ? globalReadonlyArrayType : globalArrayType)
-      ));
-    }
-    function getStartElementCount(type, flags) {
-      const index = findIndex(type.elementFlags, (f) => !(f & flags));
-      return index >= 0 ? index : type.elementFlags.length;
-    }
-    function getEndElementCount(type, flags) {
-      return type.elementFlags.length - findLastIndex(type.elementFlags, (f) => !(f & flags)) - 1;
-    }
-    function getElementTypes(type) {
-      const typeArguments = getTypeArguments(type);
-      const arity = getTypeReferenceArity(type);
-      return typeArguments.length === arity ? typeArguments : typeArguments.slice(0, arity);
-    }
-    function getTypeFromOptionalTypeNode(node) {
-      return addOptionality(
-        getTypeFromTypeNode(node.type),
-        /*isProperty*/
-        true
-      );
-    }
-    function getTypeId(type) {
-      return type.id;
-    }
-    function containsType(types, type) {
-      return binarySearch(types, type, getTypeId, compareValues) >= 0;
-    }
-    function insertType(types, type) {
-      const index = binarySearch(types, type, getTypeId, compareValues);
-      if (index < 0) {
-        types.splice(~index, 0, type);
-        return true;
-      }
-      return false;
-    }
-    function addTypeToUnion(typeSet, includes, type) {
-      const flags = type.flags;
-      if (!(flags & 131072 /* Never */)) {
-        includes |= flags & 473694207 /* IncludesMask */;
-        if (flags & 465829888 /* Instantiable */)
-          includes |= 33554432 /* IncludesInstantiable */;
-        if (type === wildcardType)
-          includes |= 8388608 /* IncludesWildcard */;
-        if (!strictNullChecks && flags & 98304 /* Nullable */) {
-          if (!(getObjectFlags(type) & 65536 /* ContainsWideningType */))
-            includes |= 4194304 /* IncludesNonWideningType */;
-        } else {
-          const len = typeSet.length;
-          const index = len && type.id > typeSet[len - 1].id ? ~len : binarySearch(typeSet, type, getTypeId, compareValues);
-          if (index < 0) {
-            typeSet.splice(~index, 0, type);
-          }
-        }
-      }
-      return includes;
-    }
-    function addTypesToUnion(typeSet, includes, types) {
-      let lastType;
-      for (const type of types) {
-        if (type !== lastType) {
-          includes = type.flags & 1048576 /* Union */ ? addTypesToUnion(typeSet, includes | (isNamedUnionType(type) ? 1048576 /* Union */ : 0), type.types) : addTypeToUnion(typeSet, includes, type);
-          lastType = type;
-        }
-      }
-      return includes;
-    }
-    function removeSubtypes(types, hasObjectTypes) {
-      var _a;
-      if (types.length < 2) {
-        return types;
-      }
-      const id = getTypeListId(types);
-      const match = subtypeReductionCache.get(id);
-      if (match) {
-        return match;
-      }
-      const hasEmptyObject = hasObjectTypes && some(types, (t) => !!(t.flags & 524288 /* Object */) && !isGenericMappedType(t) && isEmptyResolvedType(resolveStructuredTypeMembers(t)));
-      const len = types.length;
-      let i = len;
-      let count = 0;
-      while (i > 0) {
-        i--;
-        const source = types[i];
-        if (hasEmptyObject || source.flags & 469499904 /* StructuredOrInstantiable */) {
-          if (source.flags & 262144 /* TypeParameter */ && getBaseConstraintOrType(source).flags & 1048576 /* Union */) {
-            if (isTypeRelatedTo(source, getUnionType(map(types, (t) => t === source ? neverType : t)), strictSubtypeRelation)) {
-              orderedRemoveItemAt(types, i);
-            }
-            continue;
-          }
-          const keyProperty = source.flags & (524288 /* Object */ | 2097152 /* Intersection */ | 58982400 /* InstantiableNonPrimitive */) ? find(getPropertiesOfType(source), (p) => isUnitType(getTypeOfSymbol(p))) : void 0;
-          const keyPropertyType = keyProperty && getRegularTypeOfLiteralType(getTypeOfSymbol(keyProperty));
-          for (const target of types) {
-            if (source !== target) {
-              if (count === 1e5) {
-                const estimatedCount = count / (len - i) * len;
-                if (estimatedCount > 1e6) {
-                  (_a = tracing) == null ? void 0 : _a.instant(tracing.Phase.CheckTypes, "removeSubtypes_DepthLimit", { typeIds: types.map((t) => t.id) });
-                  error(currentNode, Diagnostics.Expression_produces_a_union_type_that_is_too_complex_to_represent);
-                  return void 0;
-                }
-              }
-              count++;
-              if (keyProperty && target.flags & (524288 /* Object */ | 2097152 /* Intersection */ | 58982400 /* InstantiableNonPrimitive */)) {
-                const t = getTypeOfPropertyOfType(target, keyProperty.escapedName);
-                if (t && isUnitType(t) && getRegularTypeOfLiteralType(t) !== keyPropertyType) {
-                  continue;
-                }
-              }
-              if (isTypeRelatedTo(source, target, strictSubtypeRelation) && (!(getObjectFlags(getTargetType(source)) & 1 /* Class */) || !(getObjectFlags(getTargetType(target)) & 1 /* Class */) || isTypeDerivedFrom(source, target))) {
-                orderedRemoveItemAt(types, i);
-                break;
-              }
-            }
-          }
-        }
-      }
-      subtypeReductionCache.set(id, types);
-      return types;
-    }
-    function removeRedundantLiteralTypes(types, includes, reduceVoidUndefined) {
-      let i = types.length;
-      while (i > 0) {
-        i--;
-        const t = types[i];
-        const flags = t.flags;
-        const remove = flags & (128 /* StringLiteral */ | 134217728 /* TemplateLiteral */ | 268435456 /* StringMapping */) && includes & 4 /* String */ || flags & 256 /* NumberLiteral */ && includes & 8 /* Number */ || flags & 2048 /* BigIntLiteral */ && includes & 64 /* BigInt */ || flags & 8192 /* UniqueESSymbol */ && includes & 4096 /* ESSymbol */ || reduceVoidUndefined && flags & 32768 /* Undefined */ && includes & 16384 /* Void */ || isFreshLiteralType(t) && containsType(types, t.regularType);
-        if (remove) {
-          orderedRemoveItemAt(types, i);
-        }
-      }
-    }
-    function removeStringLiteralsMatchedByTemplateLiterals(types) {
-      const templates = filter(types, (t) => !!(t.flags & 134217728 /* TemplateLiteral */) && isPatternLiteralType(t));
-      if (templates.length) {
-        let i = types.length;
-        while (i > 0) {
-          i--;
-          const t = types[i];
-          if (t.flags & 128 /* StringLiteral */ && some(templates, (template) => isTypeMatchedByTemplateLiteralType(t, template))) {
-            orderedRemoveItemAt(types, i);
-          }
-        }
-      }
-    }
-    function isNamedUnionType(type) {
-      return !!(type.flags & 1048576 /* Union */ && (type.aliasSymbol || type.origin));
-    }
-    function addNamedUnions(namedUnions, types) {
-      for (const t of types) {
-        if (t.flags & 1048576 /* Union */) {
-          const origin = t.origin;
-          if (t.aliasSymbol || origin && !(origin.flags & 1048576 /* Union */)) {
-            pushIfUnique(namedUnions, t);
-          } else if (origin && origin.flags & 1048576 /* Union */) {
-            addNamedUnions(namedUnions, origin.types);
-          }
-        }
-      }
-    }
-    function createOriginUnionOrIntersectionType(flags, types) {
-      const result = createOriginType(flags);
-      result.types = types;
-      return result;
-    }
-    function getUnionType(types, unionReduction = 1 /* Literal */, aliasSymbol, aliasTypeArguments, origin) {
-      if (types.length === 0) {
-        return neverType;
-      }
-      if (types.length === 1) {
-        return types[0];
-      }
-      if (types.length === 2 && !origin && (types[0].flags & 1048576 /* Union */ || types[1].flags & 1048576 /* Union */)) {
-        const infix = unionReduction === 0 /* None */ ? "N" : unionReduction === 2 /* Subtype */ ? "S" : "L";
-        const index = types[0].id < types[1].id ? 0 : 1;
-        const id = types[index].id + infix + types[1 - index].id + getAliasId(aliasSymbol, aliasTypeArguments);
-        let type = unionOfUnionTypes.get(id);
-        if (!type) {
-          type = getUnionTypeWorker(
-            types,
-            unionReduction,
-            aliasSymbol,
-            aliasTypeArguments,
-            /*origin*/
-            void 0
-          );
-          unionOfUnionTypes.set(id, type);
-        }
-        return type;
-      }
-      return getUnionTypeWorker(types, unionReduction, aliasSymbol, aliasTypeArguments, origin);
-    }
-    function getUnionTypeWorker(types, unionReduction, aliasSymbol, aliasTypeArguments, origin) {
-      let typeSet = [];
-      const includes = addTypesToUnion(typeSet, 0, types);
-      if (unionReduction !== 0 /* None */) {
-        if (includes & 3 /* AnyOrUnknown */) {
-          return includes & 1 /* Any */ ? includes & 8388608 /* IncludesWildcard */ ? wildcardType : anyType : includes & 65536 /* Null */ || containsType(typeSet, unknownType) ? unknownType : nonNullUnknownType;
-        }
-        if (includes & 32768 /* Undefined */) {
-          if (typeSet.length >= 2 && typeSet[0] === undefinedType && typeSet[1] === missingType) {
-            orderedRemoveItemAt(typeSet, 1);
-          }
-        }
-        if (includes & (32 /* Enum */ | 2944 /* Literal */ | 8192 /* UniqueESSymbol */ | 134217728 /* TemplateLiteral */ | 268435456 /* StringMapping */) || includes & 16384 /* Void */ && includes & 32768 /* Undefined */) {
-          removeRedundantLiteralTypes(typeSet, includes, !!(unionReduction & 2 /* Subtype */));
-        }
-        if (includes & 128 /* StringLiteral */ && includes & 134217728 /* TemplateLiteral */) {
-          removeStringLiteralsMatchedByTemplateLiterals(typeSet);
-        }
-        if (unionReduction === 2 /* Subtype */) {
-          typeSet = removeSubtypes(typeSet, !!(includes & 524288 /* Object */));
-          if (!typeSet) {
-            return errorType;
-          }
-        }
-        if (typeSet.length === 0) {
-          return includes & 65536 /* Null */ ? includes & 4194304 /* IncludesNonWideningType */ ? nullType : nullWideningType : includes & 32768 /* Undefined */ ? includes & 4194304 /* IncludesNonWideningType */ ? undefinedType : undefinedWideningType : neverType;
-        }
-      }
-      if (!origin && includes & 1048576 /* Union */) {
-        const namedUnions = [];
-        addNamedUnions(namedUnions, types);
-        const reducedTypes = [];
-        for (const t of typeSet) {
-          if (!some(namedUnions, (union) => containsType(union.types, t))) {
-            reducedTypes.push(t);
-          }
-        }
-        if (!aliasSymbol && namedUnions.length === 1 && reducedTypes.length === 0) {
-          return namedUnions[0];
-        }
-        const namedTypesCount = reduceLeft(namedUnions, (sum, union) => sum + union.types.length, 0);
-        if (namedTypesCount + reducedTypes.length === typeSet.length) {
-          for (const t of namedUnions) {
-            insertType(reducedTypes, t);
-          }
-          origin = createOriginUnionOrIntersectionType(1048576 /* Union */, reducedTypes);
-        }
-      }
-      const objectFlags = (includes & 36323331 /* NotPrimitiveUnion */ ? 0 : 32768 /* PrimitiveUnion */) | (includes & 2097152 /* Intersection */ ? 16777216 /* ContainsIntersections */ : 0);
-      return getUnionTypeFromSortedList(typeSet, objectFlags, aliasSymbol, aliasTypeArguments, origin);
-    }
-    function getUnionOrIntersectionTypePredicate(signatures, kind) {
-      let last2;
-      const types = [];
-      for (const sig of signatures) {
-        const pred = getTypePredicateOfSignature(sig);
-        if (pred) {
-          if (pred.kind !== 0 /* This */ && pred.kind !== 1 /* Identifier */ || last2 && !typePredicateKindsMatch(last2, pred)) {
-            return void 0;
-          }
-          last2 = pred;
-          types.push(pred.type);
-        } else {
-          const returnType = kind !== 2097152 /* Intersection */ ? getReturnTypeOfSignature(sig) : void 0;
-          if (returnType !== falseType && returnType !== regularFalseType) {
-            return void 0;
-          }
-        }
-      }
-      if (!last2) {
-        return void 0;
-      }
-      const compositeType = getUnionOrIntersectionType(types, kind);
-      return createTypePredicate(last2.kind, last2.parameterName, last2.parameterIndex, compositeType);
-    }
-    function typePredicateKindsMatch(a, b) {
-      return a.kind === b.kind && a.parameterIndex === b.parameterIndex;
-    }
-    function getUnionTypeFromSortedList(types, precomputedObjectFlags, aliasSymbol, aliasTypeArguments, origin) {
-      if (types.length === 0) {
-        return neverType;
-      }
-      if (types.length === 1) {
-        return types[0];
-      }
-      const typeKey = !origin ? getTypeListId(types) : origin.flags & 1048576 /* Union */ ? `|${getTypeListId(origin.types)}` : origin.flags & 2097152 /* Intersection */ ? `&${getTypeListId(origin.types)}` : `#${origin.type.id}|${getTypeListId(types)}`;
-      const id = typeKey + getAliasId(aliasSymbol, aliasTypeArguments);
-      let type = unionTypes.get(id);
-      if (!type) {
-        type = createType(1048576 /* Union */);
-        type.objectFlags = precomputedObjectFlags | getPropagatingFlagsOfTypes(
-          types,
-          /*excludeKinds*/
-          98304 /* Nullable */
-        );
-        type.types = types;
-        type.origin = origin;
-        type.aliasSymbol = aliasSymbol;
-        type.aliasTypeArguments = aliasTypeArguments;
-        if (types.length === 2 && types[0].flags & 512 /* BooleanLiteral */ && types[1].flags & 512 /* BooleanLiteral */) {
-          type.flags |= 16 /* Boolean */;
-          type.intrinsicName = "boolean";
-        }
-        unionTypes.set(id, type);
-      }
-      return type;
-    }
-    function getTypeFromUnionTypeNode(node) {
-      const links = getNodeLinks(node);
-      if (!links.resolvedType) {
-        const aliasSymbol = getAliasSymbolForTypeNode(node);
-        links.resolvedType = getUnionType(
-          map(node.types, getTypeFromTypeNode),
-          1 /* Literal */,
-          aliasSymbol,
-          getTypeArgumentsForAliasSymbol(aliasSymbol)
-        );
-      }
-      return links.resolvedType;
-    }
-    function addTypeToIntersection(typeSet, includes, type) {
-      const flags = type.flags;
-      if (flags & 2097152 /* Intersection */) {
-        return addTypesToIntersection(typeSet, includes, type.types);
-      }
-      if (isEmptyAnonymousObjectType(type)) {
-        if (!(includes & 16777216 /* IncludesEmptyObject */)) {
-          includes |= 16777216 /* IncludesEmptyObject */;
-          typeSet.set(type.id.toString(), type);
-        }
-      } else {
-        if (flags & 3 /* AnyOrUnknown */) {
-          if (type === wildcardType)
-            includes |= 8388608 /* IncludesWildcard */;
-        } else if (strictNullChecks || !(flags & 98304 /* Nullable */)) {
-          if (type === missingType) {
-            includes |= 262144 /* IncludesMissingType */;
-            type = undefinedType;
-          }
-          if (!typeSet.has(type.id.toString())) {
-            if (type.flags & 109472 /* Unit */ && includes & 109472 /* Unit */) {
-              includes |= 67108864 /* NonPrimitive */;
-            }
-            typeSet.set(type.id.toString(), type);
-          }
-        }
-        includes |= flags & 473694207 /* IncludesMask */;
-      }
-      return includes;
-    }
-    function addTypesToIntersection(typeSet, includes, types) {
-      for (const type of types) {
-        includes = addTypeToIntersection(typeSet, includes, getRegularTypeOfLiteralType(type));
-      }
-      return includes;
-    }
-    function removeRedundantSupertypes(types, includes) {
-      let i = types.length;
-      while (i > 0) {
-        i--;
-        const t = types[i];
-        const remove = t.flags & 4 /* String */ && includes & (128 /* StringLiteral */ | 134217728 /* TemplateLiteral */ | 268435456 /* StringMapping */) || t.flags & 8 /* Number */ && includes & 256 /* NumberLiteral */ || t.flags & 64 /* BigInt */ && includes & 2048 /* BigIntLiteral */ || t.flags & 4096 /* ESSymbol */ && includes & 8192 /* UniqueESSymbol */ || t.flags & 16384 /* Void */ && includes & 32768 /* Undefined */ || isEmptyAnonymousObjectType(t) && includes & 470302716 /* DefinitelyNonNullable */;
-        if (remove) {
-          orderedRemoveItemAt(types, i);
-        }
-      }
-    }
-    function eachUnionContains(unionTypes2, type) {
-      for (const u of unionTypes2) {
-        if (!containsType(u.types, type)) {
-          const primitive = type.flags & 128 /* StringLiteral */ ? stringType : type.flags & (32 /* Enum */ | 256 /* NumberLiteral */) ? numberType : type.flags & 2048 /* BigIntLiteral */ ? bigintType : type.flags & 8192 /* UniqueESSymbol */ ? esSymbolType : void 0;
-          if (!primitive || !containsType(u.types, primitive)) {
-            return false;
-          }
-        }
-      }
-      return true;
-    }
-    function extractRedundantTemplateLiterals(types) {
-      let i = types.length;
-      const literals = filter(types, (t) => !!(t.flags & 128 /* StringLiteral */));
-      while (i > 0) {
-        i--;
-        const t = types[i];
-        if (!(t.flags & 134217728 /* TemplateLiteral */))
-          continue;
-        for (const t2 of literals) {
-          if (isTypeSubtypeOf(t2, t)) {
-            orderedRemoveItemAt(types, i);
-            break;
-          } else if (isPatternLiteralType(t)) {
-            return true;
-          }
-        }
-      }
-      return false;
-    }
-    function removeFromEach(types, flag) {
-      for (let i = 0; i < types.length; i++) {
-        types[i] = filterType(types[i], (t) => !(t.flags & flag));
-      }
-    }
-    function intersectUnionsOfPrimitiveTypes(types) {
-      let unionTypes2;
-      const index = findIndex(types, (t) => !!(getObjectFlags(t) & 32768 /* PrimitiveUnion */));
-      if (index < 0) {
-        return false;
-      }
-      let i = index + 1;
-      while (i < types.length) {
-        const t = types[i];
-        if (getObjectFlags(t) & 32768 /* PrimitiveUnion */) {
-          (unionTypes2 || (unionTypes2 = [types[index]])).push(t);
-          orderedRemoveItemAt(types, i);
-        } else {
-          i++;
-        }
-      }
-      if (!unionTypes2) {
-        return false;
-      }
-      const checked = [];
-      const result = [];
-      for (const u of unionTypes2) {
-        for (const t of u.types) {
-          if (insertType(checked, t)) {
-            if (eachUnionContains(unionTypes2, t)) {
-              insertType(result, t);
-            }
-          }
-        }
-      }
-      types[index] = getUnionTypeFromSortedList(result, 32768 /* PrimitiveUnion */);
-      return true;
-    }
-    function createIntersectionType(types, aliasSymbol, aliasTypeArguments) {
-      const result = createType(2097152 /* Intersection */);
-      result.objectFlags = getPropagatingFlagsOfTypes(
-        types,
-        /*excludeKinds*/
-        98304 /* Nullable */
-      );
-      result.types = types;
-      result.aliasSymbol = aliasSymbol;
-      result.aliasTypeArguments = aliasTypeArguments;
-      return result;
-    }
-    function getIntersectionType(types, aliasSymbol, aliasTypeArguments, noSupertypeReduction) {
-      const typeMembershipMap = /* @__PURE__ */ new Map();
-      const includes = addTypesToIntersection(typeMembershipMap, 0, types);
-      const typeSet = arrayFrom(typeMembershipMap.values());
-      if (includes & 131072 /* Never */) {
-        return contains(typeSet, silentNeverType) ? silentNeverType : neverType;
-      }
-      if (strictNullChecks && includes & 98304 /* Nullable */ && includes & (524288 /* Object */ | 67108864 /* NonPrimitive */ | 16777216 /* IncludesEmptyObject */) || includes & 67108864 /* NonPrimitive */ && includes & (469892092 /* DisjointDomains */ & ~67108864 /* NonPrimitive */) || includes & 402653316 /* StringLike */ && includes & (469892092 /* DisjointDomains */ & ~402653316 /* StringLike */) || includes & 296 /* NumberLike */ && includes & (469892092 /* DisjointDomains */ & ~296 /* NumberLike */) || includes & 2112 /* BigIntLike */ && includes & (469892092 /* DisjointDomains */ & ~2112 /* BigIntLike */) || includes & 12288 /* ESSymbolLike */ && includes & (469892092 /* DisjointDomains */ & ~12288 /* ESSymbolLike */) || includes & 49152 /* VoidLike */ && includes & (469892092 /* DisjointDomains */ & ~49152 /* VoidLike */)) {
-        return neverType;
-      }
-      if (includes & 134217728 /* TemplateLiteral */ && includes & 128 /* StringLiteral */ && extractRedundantTemplateLiterals(typeSet)) {
-        return neverType;
-      }
-      if (includes & 1 /* Any */) {
-        return includes & 8388608 /* IncludesWildcard */ ? wildcardType : anyType;
-      }
-      if (!strictNullChecks && includes & 98304 /* Nullable */) {
-        return includes & 16777216 /* IncludesEmptyObject */ ? neverType : includes & 32768 /* Undefined */ ? undefinedType : nullType;
-      }
-      if (includes & 4 /* String */ && includes & (128 /* StringLiteral */ | 134217728 /* TemplateLiteral */ | 268435456 /* StringMapping */) || includes & 8 /* Number */ && includes & 256 /* NumberLiteral */ || includes & 64 /* BigInt */ && includes & 2048 /* BigIntLiteral */ || includes & 4096 /* ESSymbol */ && includes & 8192 /* UniqueESSymbol */ || includes & 16384 /* Void */ && includes & 32768 /* Undefined */ || includes & 16777216 /* IncludesEmptyObject */ && includes & 470302716 /* DefinitelyNonNullable */) {
-        if (!noSupertypeReduction)
-          removeRedundantSupertypes(typeSet, includes);
-      }
-      if (includes & 262144 /* IncludesMissingType */) {
-        typeSet[typeSet.indexOf(undefinedType)] = missingType;
-      }
-      if (typeSet.length === 0) {
-        return unknownType;
-      }
-      if (typeSet.length === 1) {
-        return typeSet[0];
-      }
-      const id = getTypeListId(typeSet) + getAliasId(aliasSymbol, aliasTypeArguments);
-      let result = intersectionTypes.get(id);
-      if (!result) {
-        if (includes & 1048576 /* Union */) {
-          if (intersectUnionsOfPrimitiveTypes(typeSet)) {
-            result = getIntersectionType(typeSet, aliasSymbol, aliasTypeArguments);
-          } else if (every(typeSet, (t) => !!(t.flags & 1048576 /* Union */ && t.types[0].flags & 32768 /* Undefined */))) {
-            const containedUndefinedType = some(typeSet, containsMissingType) ? missingType : undefinedType;
-            removeFromEach(typeSet, 32768 /* Undefined */);
-            result = getUnionType([getIntersectionType(typeSet), containedUndefinedType], 1 /* Literal */, aliasSymbol, aliasTypeArguments);
-          } else if (every(typeSet, (t) => !!(t.flags & 1048576 /* Union */ && (t.types[0].flags & 65536 /* Null */ || t.types[1].flags & 65536 /* Null */)))) {
-            removeFromEach(typeSet, 65536 /* Null */);
-            result = getUnionType([getIntersectionType(typeSet), nullType], 1 /* Literal */, aliasSymbol, aliasTypeArguments);
-          } else {
-            if (!checkCrossProductUnion(typeSet)) {
-              return errorType;
-            }
-            const constituents = getCrossProductIntersections(typeSet);
-            const origin = some(constituents, (t) => !!(t.flags & 2097152 /* Intersection */)) && getConstituentCountOfTypes(constituents) > getConstituentCountOfTypes(typeSet) ? createOriginUnionOrIntersectionType(2097152 /* Intersection */, typeSet) : void 0;
-            result = getUnionType(constituents, 1 /* Literal */, aliasSymbol, aliasTypeArguments, origin);
-          }
-        } else {
-          result = createIntersectionType(typeSet, aliasSymbol, aliasTypeArguments);
-        }
-        intersectionTypes.set(id, result);
-      }
-      return result;
-    }
-    function getCrossProductUnionSize(types) {
-      return reduceLeft(types, (n, t) => t.flags & 1048576 /* Union */ ? n * t.types.length : t.flags & 131072 /* Never */ ? 0 : n, 1);
-    }
-    function checkCrossProductUnion(types) {
-      var _a;
-      const size = getCrossProductUnionSize(types);
-      if (size >= 1e5) {
-        (_a = tracing) == null ? void 0 : _a.instant(tracing.Phase.CheckTypes, "checkCrossProductUnion_DepthLimit", { typeIds: types.map((t) => t.id), size });
-        error(currentNode, Diagnostics.Expression_produces_a_union_type_that_is_too_complex_to_represent);
-        return false;
-      }
-      return true;
-    }
-    function getCrossProductIntersections(types) {
-      const count = getCrossProductUnionSize(types);
-      const intersections = [];
-      for (let i = 0; i < count; i++) {
-        const constituents = types.slice();
-        let n = i;
-        for (let j = types.length - 1; j >= 0; j--) {
-          if (types[j].flags & 1048576 /* Union */) {
-            const sourceTypes = types[j].types;
-            const length2 = sourceTypes.length;
-            constituents[j] = sourceTypes[n % length2];
-            n = Math.floor(n / length2);
-          }
-        }
-        const t = getIntersectionType(constituents);
-        if (!(t.flags & 131072 /* Never */))
-          intersections.push(t);
-      }
-      return intersections;
-    }
-    function getConstituentCount(type) {
-      return !(type.flags & 3145728 /* UnionOrIntersection */) || type.aliasSymbol ? 1 : type.flags & 1048576 /* Union */ && type.origin ? getConstituentCount(type.origin) : getConstituentCountOfTypes(type.types);
-    }
-    function getConstituentCountOfTypes(types) {
-      return reduceLeft(types, (n, t) => n + getConstituentCount(t), 0);
-    }
-    function areIntersectedTypesAvoidingPrimitiveReduction(t1, t2) {
-      return !!(t1.flags & (4 /* String */ | 8 /* Number */ | 64 /* BigInt */)) && t2 === emptyTypeLiteralType;
-    }
-    function getTypeFromIntersectionTypeNode(node) {
-      const links = getNodeLinks(node);
-      if (!links.resolvedType) {
-        const aliasSymbol = getAliasSymbolForTypeNode(node);
-        const types = map(node.types, getTypeFromTypeNode);
-        const noSupertypeReduction = types.length === 2 && (areIntersectedTypesAvoidingPrimitiveReduction(types[0], types[1]) || areIntersectedTypesAvoidingPrimitiveReduction(types[1], types[0]));
-        links.resolvedType = getIntersectionType(types, aliasSymbol, getTypeArgumentsForAliasSymbol(aliasSymbol), noSupertypeReduction);
-      }
-      return links.resolvedType;
-    }
-    function createIndexType(type, indexFlags) {
-      const result = createType(4194304 /* Index */);
-      result.type = type;
-      result.indexFlags = indexFlags;
-      return result;
-    }
-    function createOriginIndexType(type) {
-      const result = createOriginType(4194304 /* Index */);
-      result.type = type;
-      return result;
-    }
-    function getIndexTypeForGenericType(type, indexFlags) {
-      return indexFlags & 1 /* StringsOnly */ ? type.resolvedStringIndexType || (type.resolvedStringIndexType = createIndexType(type, 1 /* StringsOnly */)) : type.resolvedIndexType || (type.resolvedIndexType = createIndexType(type, 0 /* None */));
-    }
-    function getIndexTypeForMappedType(type, indexFlags) {
-      const typeParameter = getTypeParameterFromMappedType(type);
-      const constraintType = getConstraintTypeFromMappedType(type);
-      const nameType = getNameTypeFromMappedType(type.target || type);
-      if (!nameType && !(indexFlags & 2 /* NoIndexSignatures */)) {
-        return constraintType;
-      }
-      const keyTypes = [];
-      if (isMappedTypeWithKeyofConstraintDeclaration(type)) {
-        if (!isGenericIndexType(constraintType)) {
-          const modifiersType = getApparentType(getModifiersTypeFromMappedType(type));
-          forEachMappedTypePropertyKeyTypeAndIndexSignatureKeyType(modifiersType, 8576 /* StringOrNumberLiteralOrUnique */, !!(indexFlags & 1 /* StringsOnly */), addMemberForKeyType);
-        } else {
-          return getIndexTypeForGenericType(type, indexFlags);
-        }
-      } else {
-        forEachType(getLowerBoundOfKeyType(constraintType), addMemberForKeyType);
-      }
-      if (isGenericIndexType(constraintType)) {
-        forEachType(constraintType, addMemberForKeyType);
-      }
-      const result = indexFlags & 2 /* NoIndexSignatures */ ? filterType(getUnionType(keyTypes), (t) => !(t.flags & (1 /* Any */ | 4 /* String */))) : getUnionType(keyTypes);
-      if (result.flags & 1048576 /* Union */ && constraintType.flags & 1048576 /* Union */ && getTypeListId(result.types) === getTypeListId(constraintType.types)) {
-        return constraintType;
-      }
-      return result;
-      function addMemberForKeyType(keyType) {
-        const propNameType = nameType ? instantiateType(nameType, appendTypeMapping(type.mapper, typeParameter, keyType)) : keyType;
-        keyTypes.push(propNameType === stringType ? stringOrNumberType : propNameType);
-      }
-    }
-    function hasDistributiveNameType(mappedType) {
-      const typeVariable = getTypeParameterFromMappedType(mappedType);
-      return isDistributive(getNameTypeFromMappedType(mappedType) || typeVariable);
-      function isDistributive(type) {
-        return type.flags & (3 /* AnyOrUnknown */ | 402784252 /* Primitive */ | 131072 /* Never */ | 262144 /* TypeParameter */ | 524288 /* Object */ | 67108864 /* NonPrimitive */) ? true : type.flags & 16777216 /* Conditional */ ? type.root.isDistributive && type.checkType === typeVariable : type.flags & (3145728 /* UnionOrIntersection */ | 134217728 /* TemplateLiteral */) ? every(type.types, isDistributive) : type.flags & 8388608 /* IndexedAccess */ ? isDistributive(type.objectType) && isDistributive(type.indexType) : type.flags & 33554432 /* Substitution */ ? isDistributive(type.baseType) && isDistributive(type.constraint) : type.flags & 268435456 /* StringMapping */ ? isDistributive(type.type) : false;
-      }
-    }
-    function getLiteralTypeFromPropertyName(name) {
-      if (isPrivateIdentifier(name)) {
-        return neverType;
-      }
-      if (isNumericLiteral(name)) {
-        return getRegularTypeOfLiteralType(checkExpression(name));
-      }
-      if (isComputedPropertyName(name)) {
-        return getRegularTypeOfLiteralType(checkComputedPropertyName(name));
-      }
-      const propertyName = getPropertyNameForPropertyNameNode(name);
-      if (propertyName !== void 0) {
-        return getStringLiteralType(unescapeLeadingUnderscores(propertyName));
-      }
-      if (isExpression(name)) {
-        return getRegularTypeOfLiteralType(checkExpression(name));
-      }
-      return neverType;
-    }
-    function getLiteralTypeFromProperty(prop, include, includeNonPublic) {
-      if (includeNonPublic || !(getDeclarationModifierFlagsFromSymbol(prop) & 24 /* NonPublicAccessibilityModifier */)) {
-        let type = getSymbolLinks(getLateBoundSymbol(prop)).nameType;
-        if (!type) {
-          const name = getNameOfDeclaration(prop.valueDeclaration);
-          type = prop.escapedName === "default" /* Default */ ? getStringLiteralType("default") : name && getLiteralTypeFromPropertyName(name) || (!isKnownSymbol(prop) ? getStringLiteralType(symbolName(prop)) : void 0);
-        }
-        if (type && type.flags & include) {
-          return type;
-        }
-      }
-      return neverType;
-    }
-    function isKeyTypeIncluded(keyType, include) {
-      return !!(keyType.flags & include || keyType.flags & 2097152 /* Intersection */ && some(keyType.types, (t) => isKeyTypeIncluded(t, include)));
-    }
-    function getLiteralTypeFromProperties(type, include, includeOrigin) {
-      const origin = includeOrigin && (getObjectFlags(type) & (3 /* ClassOrInterface */ | 4 /* Reference */) || type.aliasSymbol) ? createOriginIndexType(type) : void 0;
-      const propertyTypes = map(getPropertiesOfType(type), (prop) => getLiteralTypeFromProperty(prop, include));
-      const indexKeyTypes = map(getIndexInfosOfType(type), (info) => info !== enumNumberIndexInfo && isKeyTypeIncluded(info.keyType, include) ? info.keyType === stringType && include & 8 /* Number */ ? stringOrNumberType : info.keyType : neverType);
-      return getUnionType(
-        concatenate(propertyTypes, indexKeyTypes),
-        1 /* Literal */,
-        /*aliasSymbol*/
-        void 0,
-        /*aliasTypeArguments*/
-        void 0,
-        origin
-      );
-    }
-    function shouldDeferIndexType(type, indexFlags = 0 /* None */) {
-      return !!(type.flags & 58982400 /* InstantiableNonPrimitive */ || isGenericTupleType(type) || isGenericMappedType(type) && !hasDistributiveNameType(type) || type.flags & 1048576 /* Union */ && !(indexFlags & 4 /* NoReducibleCheck */) && isGenericReducibleType(type) || type.flags & 2097152 /* Intersection */ && maybeTypeOfKind(type, 465829888 /* Instantiable */) && some(type.types, isEmptyAnonymousObjectType));
-    }
-    function getIndexType(type, indexFlags = defaultIndexFlags) {
-      type = getReducedType(type);
-      return shouldDeferIndexType(type, indexFlags) ? getIndexTypeForGenericType(type, indexFlags) : type.flags & 1048576 /* Union */ ? getIntersectionType(map(type.types, (t) => getIndexType(t, indexFlags))) : type.flags & 2097152 /* Intersection */ ? getUnionType(map(type.types, (t) => getIndexType(t, indexFlags))) : getObjectFlags(type) & 32 /* Mapped */ ? getIndexTypeForMappedType(type, indexFlags) : type === wildcardType ? wildcardType : type.flags & 2 /* Unknown */ ? neverType : type.flags & (1 /* Any */ | 131072 /* Never */) ? keyofConstraintType : getLiteralTypeFromProperties(
-        type,
-        (indexFlags & 2 /* NoIndexSignatures */ ? 128 /* StringLiteral */ : 402653316 /* StringLike */) | (indexFlags & 1 /* StringsOnly */ ? 0 : 296 /* NumberLike */ | 12288 /* ESSymbolLike */),
-        indexFlags === defaultIndexFlags
-      );
-    }
-    function getExtractStringType(type) {
-      if (keyofStringsOnly) {
-        return type;
-      }
-      const extractTypeAlias = getGlobalExtractSymbol();
-      return extractTypeAlias ? getTypeAliasInstantiation(extractTypeAlias, [type, stringType]) : stringType;
-    }
-    function getIndexTypeOrString(type) {
-      const indexType = getExtractStringType(getIndexType(type));
-      return indexType.flags & 131072 /* Never */ ? stringType : indexType;
-    }
-    function getTypeFromTypeOperatorNode(node) {
-      const links = getNodeLinks(node);
-      if (!links.resolvedType) {
-        switch (node.operator) {
-          case 143 /* KeyOfKeyword */:
-            links.resolvedType = getIndexType(getTypeFromTypeNode(node.type));
-            break;
-          case 158 /* UniqueKeyword */:
-            links.resolvedType = node.type.kind === 155 /* SymbolKeyword */ ? getESSymbolLikeTypeForNode(walkUpParenthesizedTypes(node.parent)) : errorType;
-            break;
-          case 148 /* ReadonlyKeyword */:
-            links.resolvedType = getTypeFromTypeNode(node.type);
-            break;
-          default:
-            Debug.assertNever(node.operator);
-        }
-      }
-      return links.resolvedType;
-    }
-    function getTypeFromTemplateTypeNode(node) {
-      const links = getNodeLinks(node);
-      if (!links.resolvedType) {
-        links.resolvedType = getTemplateLiteralType(
-          [node.head.text, ...map(node.templateSpans, (span) => span.literal.text)],
-          map(node.templateSpans, (span) => getTypeFromTypeNode(span.type))
-        );
-      }
-      return links.resolvedType;
-    }
-    function getTemplateLiteralType(texts, types) {
-      const unionIndex = findIndex(types, (t) => !!(t.flags & (131072 /* Never */ | 1048576 /* Union */)));
-      if (unionIndex >= 0) {
-        return checkCrossProductUnion(types) ? mapType(types[unionIndex], (t) => getTemplateLiteralType(texts, replaceElement(types, unionIndex, t))) : errorType;
-      }
-      if (contains(types, wildcardType)) {
-        return wildcardType;
-      }
-      const newTypes = [];
-      const newTexts = [];
-      let text = texts[0];
-      if (!addSpans(texts, types)) {
-        return stringType;
-      }
-      if (newTypes.length === 0) {
-        return getStringLiteralType(text);
-      }
-      newTexts.push(text);
-      if (every(newTexts, (t) => t === "")) {
-        if (every(newTypes, (t) => !!(t.flags & 4 /* String */))) {
-          return stringType;
-        }
-        if (newTypes.length === 1 && isPatternLiteralType(newTypes[0])) {
-          return newTypes[0];
-        }
-      }
-      const id = `${getTypeListId(newTypes)}|${map(newTexts, (t) => t.length).join(",")}|${newTexts.join("")}`;
-      let type = templateLiteralTypes.get(id);
-      if (!type) {
-        templateLiteralTypes.set(id, type = createTemplateLiteralType(newTexts, newTypes));
-      }
-      return type;
-      function addSpans(texts2, types2) {
-        for (let i = 0; i < types2.length; i++) {
-          const t = types2[i];
-          if (t.flags & (2944 /* Literal */ | 65536 /* Null */ | 32768 /* Undefined */)) {
-            text += getTemplateStringForType(t) || "";
-            text += texts2[i + 1];
-          } else if (t.flags & 134217728 /* TemplateLiteral */) {
-            text += t.texts[0];
-            if (!addSpans(t.texts, t.types))
-              return false;
-            text += texts2[i + 1];
-          } else if (isGenericIndexType(t) || isPatternLiteralPlaceholderType(t)) {
-            newTypes.push(t);
-            newTexts.push(text);
-            text = texts2[i + 1];
-          } else {
-            return false;
-          }
-        }
-        return true;
-      }
-    }
-    function getTemplateStringForType(type) {
-      return type.flags & 128 /* StringLiteral */ ? type.value : type.flags & 256 /* NumberLiteral */ ? "" + type.value : type.flags & 2048 /* BigIntLiteral */ ? pseudoBigIntToString(type.value) : type.flags & (512 /* BooleanLiteral */ | 98304 /* Nullable */) ? type.intrinsicName : void 0;
-    }
-    function createTemplateLiteralType(texts, types) {
-      const type = createType(134217728 /* TemplateLiteral */);
-      type.objectFlags = getPropagatingFlagsOfTypes(
-        types,
-        /*excludeKinds*/
-        98304 /* Nullable */
-      );
-      type.texts = texts;
-      type.types = types;
-      return type;
-    }
-    function getStringMappingType(symbol, type) {
-      return type.flags & (1048576 /* Union */ | 131072 /* Never */) ? mapType(type, (t) => getStringMappingType(symbol, t)) : type.flags & 128 /* StringLiteral */ ? getStringLiteralType(applyStringMapping(symbol, type.value)) : type.flags & 134217728 /* TemplateLiteral */ ? getTemplateLiteralType(...applyTemplateStringMapping(symbol, type.texts, type.types)) : (
-        // Mapping> === Mapping
-        type.flags & 268435456 /* StringMapping */ && symbol === type.symbol ? type : type.flags & (1 /* Any */ | 4 /* String */ | 268435456 /* StringMapping */) || isGenericIndexType(type) ? getStringMappingTypeForGenericType(symbol, type) : (
-          // This handles Mapping<`${number}`> and Mapping<`${bigint}`>
-          isPatternLiteralPlaceholderType(type) ? getStringMappingTypeForGenericType(symbol, getTemplateLiteralType(["", ""], [type])) : type
-        )
-      );
-    }
-    function applyStringMapping(symbol, str) {
-      switch (intrinsicTypeKinds.get(symbol.escapedName)) {
-        case 0 /* Uppercase */:
-          return str.toUpperCase();
-        case 1 /* Lowercase */:
-          return str.toLowerCase();
-        case 2 /* Capitalize */:
-          return str.charAt(0).toUpperCase() + str.slice(1);
-        case 3 /* Uncapitalize */:
-          return str.charAt(0).toLowerCase() + str.slice(1);
-      }
-      return str;
-    }
-    function applyTemplateStringMapping(symbol, texts, types) {
-      switch (intrinsicTypeKinds.get(symbol.escapedName)) {
-        case 0 /* Uppercase */:
-          return [texts.map((t) => t.toUpperCase()), types.map((t) => getStringMappingType(symbol, t))];
-        case 1 /* Lowercase */:
-          return [texts.map((t) => t.toLowerCase()), types.map((t) => getStringMappingType(symbol, t))];
-        case 2 /* Capitalize */:
-          return [texts[0] === "" ? texts : [texts[0].charAt(0).toUpperCase() + texts[0].slice(1), ...texts.slice(1)], texts[0] === "" ? [getStringMappingType(symbol, types[0]), ...types.slice(1)] : types];
-        case 3 /* Uncapitalize */:
-          return [texts[0] === "" ? texts : [texts[0].charAt(0).toLowerCase() + texts[0].slice(1), ...texts.slice(1)], texts[0] === "" ? [getStringMappingType(symbol, types[0]), ...types.slice(1)] : types];
-      }
-      return [texts, types];
-    }
-    function getStringMappingTypeForGenericType(symbol, type) {
-      const id = `${getSymbolId(symbol)},${getTypeId(type)}`;
-      let result = stringMappingTypes.get(id);
-      if (!result) {
-        stringMappingTypes.set(id, result = createStringMappingType(symbol, type));
-      }
-      return result;
-    }
-    function createStringMappingType(symbol, type) {
-      const result = createTypeWithSymbol(268435456 /* StringMapping */, symbol);
-      result.type = type;
-      return result;
-    }
-    function createIndexedAccessType(objectType, indexType, accessFlags, aliasSymbol, aliasTypeArguments) {
-      const type = createType(8388608 /* IndexedAccess */);
-      type.objectType = objectType;
-      type.indexType = indexType;
-      type.accessFlags = accessFlags;
-      type.aliasSymbol = aliasSymbol;
-      type.aliasTypeArguments = aliasTypeArguments;
-      return type;
-    }
-    function isJSLiteralType(type) {
-      if (noImplicitAny) {
-        return false;
-      }
-      if (getObjectFlags(type) & 4096 /* JSLiteral */) {
-        return true;
-      }
-      if (type.flags & 1048576 /* Union */) {
-        return every(type.types, isJSLiteralType);
-      }
-      if (type.flags & 2097152 /* Intersection */) {
-        return some(type.types, isJSLiteralType);
-      }
-      if (type.flags & 465829888 /* Instantiable */) {
-        const constraint = getResolvedBaseConstraint(type);
-        return constraint !== type && isJSLiteralType(constraint);
-      }
-      return false;
-    }
-    function getPropertyNameFromIndex(indexType, accessNode) {
-      return isTypeUsableAsPropertyName(indexType) ? getPropertyNameFromType(indexType) : accessNode && isPropertyName(accessNode) ? (
-        // late bound names are handled in the first branch, so here we only need to handle normal names
-        getPropertyNameForPropertyNameNode(accessNode)
-      ) : void 0;
-    }
-    function isUncalledFunctionReference(node, symbol) {
-      if (symbol.flags & (16 /* Function */ | 8192 /* Method */)) {
-        const parent2 = findAncestor(node.parent, (n) => !isAccessExpression(n)) || node.parent;
-        if (isCallLikeExpression(parent2)) {
-          return isCallOrNewExpression(parent2) && isIdentifier(node) && hasMatchingArgument(parent2, node);
-        }
-        return every(symbol.declarations, (d) => !isFunctionLike(d) || !!(getCombinedNodeFlags(d) & 268435456 /* Deprecated */));
-      }
-      return true;
-    }
-    function getPropertyTypeForIndexType(originalObjectType, objectType, indexType, fullIndexType, accessNode, accessFlags) {
-      const accessExpression = accessNode && accessNode.kind === 211 /* ElementAccessExpression */ ? accessNode : void 0;
-      const propName = accessNode && isPrivateIdentifier(accessNode) ? void 0 : getPropertyNameFromIndex(indexType, accessNode);
-      if (propName !== void 0) {
-        if (accessFlags & 256 /* Contextual */) {
-          return getTypeOfPropertyOfContextualType(objectType, propName) || anyType;
-        }
-        const prop = getPropertyOfType(objectType, propName);
-        if (prop) {
-          if (accessFlags & 64 /* ReportDeprecated */ && accessNode && prop.declarations && isDeprecatedSymbol(prop) && isUncalledFunctionReference(accessNode, prop)) {
-            const deprecatedNode = (accessExpression == null ? void 0 : accessExpression.argumentExpression) ?? (isIndexedAccessTypeNode(accessNode) ? accessNode.indexType : accessNode);
-            addDeprecatedSuggestion(deprecatedNode, prop.declarations, propName);
-          }
-          if (accessExpression) {
-            markPropertyAsReferenced(prop, accessExpression, isSelfTypeAccess(accessExpression.expression, objectType.symbol));
-            if (isAssignmentToReadonlyEntity(accessExpression, prop, getAssignmentTargetKind(accessExpression))) {
-              error(accessExpression.argumentExpression, Diagnostics.Cannot_assign_to_0_because_it_is_a_read_only_property, symbolToString(prop));
-              return void 0;
-            }
-            if (accessFlags & 8 /* CacheSymbol */) {
-              getNodeLinks(accessNode).resolvedSymbol = prop;
-            }
-            if (isThisPropertyAccessInConstructor(accessExpression, prop)) {
-              return autoType;
-            }
-          }
-          const propType = getTypeOfSymbol(prop);
-          return accessExpression && getAssignmentTargetKind(accessExpression) !== 1 /* Definite */ ? getFlowTypeOfReference(accessExpression, propType) : accessNode && isIndexedAccessTypeNode(accessNode) && containsMissingType(propType) ? getUnionType([propType, undefinedType]) : propType;
-        }
-        if (everyType(objectType, isTupleType) && isNumericLiteralName(propName)) {
-          const index = +propName;
-          if (accessNode && everyType(objectType, (t) => !t.target.hasRestElement) && !(accessFlags & 16 /* NoTupleBoundsCheck */)) {
-            const indexNode = getIndexNodeForAccessExpression(accessNode);
-            if (isTupleType(objectType)) {
-              if (index < 0) {
-                error(indexNode, Diagnostics.A_tuple_type_cannot_be_indexed_with_a_negative_value);
-                return undefinedType;
-              }
-              error(
-                indexNode,
-                Diagnostics.Tuple_type_0_of_length_1_has_no_element_at_index_2,
-                typeToString(objectType),
-                getTypeReferenceArity(objectType),
-                unescapeLeadingUnderscores(propName)
-              );
-            } else {
-              error(indexNode, Diagnostics.Property_0_does_not_exist_on_type_1, unescapeLeadingUnderscores(propName), typeToString(objectType));
-            }
-          }
-          if (index >= 0) {
-            errorIfWritingToReadonlyIndex(getIndexInfoOfType(objectType, numberType));
-            return mapType(objectType, (t) => {
-              const restType = getRestTypeOfTupleType(t) || undefinedType;
-              return accessFlags & 1 /* IncludeUndefined */ ? getUnionType([restType, missingType]) : restType;
-            });
-          }
-        }
-      }
-      if (!(indexType.flags & 98304 /* Nullable */) && isTypeAssignableToKind(indexType, 402653316 /* StringLike */ | 296 /* NumberLike */ | 12288 /* ESSymbolLike */)) {
-        if (objectType.flags & (1 /* Any */ | 131072 /* Never */)) {
-          return objectType;
-        }
-        const indexInfo = getApplicableIndexInfo(objectType, indexType) || getIndexInfoOfType(objectType, stringType);
-        if (indexInfo) {
-          if (accessFlags & 2 /* NoIndexSignatures */ && indexInfo.keyType !== numberType) {
-            if (accessExpression) {
-              error(accessExpression, Diagnostics.Type_0_cannot_be_used_to_index_type_1, typeToString(indexType), typeToString(originalObjectType));
-            }
-            return void 0;
-          }
-          if (accessNode && indexInfo.keyType === stringType && !isTypeAssignableToKind(indexType, 4 /* String */ | 8 /* Number */)) {
-            const indexNode = getIndexNodeForAccessExpression(accessNode);
-            error(indexNode, Diagnostics.Type_0_cannot_be_used_as_an_index_type, typeToString(indexType));
-            return accessFlags & 1 /* IncludeUndefined */ ? getUnionType([indexInfo.type, missingType]) : indexInfo.type;
-          }
-          errorIfWritingToReadonlyIndex(indexInfo);
-          if (accessFlags & 1 /* IncludeUndefined */ && !(objectType.symbol && objectType.symbol.flags & (256 /* RegularEnum */ | 128 /* ConstEnum */) && (indexType.symbol && indexType.flags & 1024 /* EnumLiteral */ && getParentOfSymbol(indexType.symbol) === objectType.symbol))) {
-            return getUnionType([indexInfo.type, missingType]);
-          }
-          return indexInfo.type;
-        }
-        if (indexType.flags & 131072 /* Never */) {
-          return neverType;
-        }
-        if (isJSLiteralType(objectType)) {
-          return anyType;
-        }
-        if (accessExpression && !isConstEnumObjectType(objectType)) {
-          if (isObjectLiteralType2(objectType)) {
-            if (noImplicitAny && indexType.flags & (128 /* StringLiteral */ | 256 /* NumberLiteral */)) {
-              diagnostics.add(createDiagnosticForNode(accessExpression, Diagnostics.Property_0_does_not_exist_on_type_1, indexType.value, typeToString(objectType)));
-              return undefinedType;
-            } else if (indexType.flags & (8 /* Number */ | 4 /* String */)) {
-              const types = map(objectType.properties, (property) => {
-                return getTypeOfSymbol(property);
-              });
-              return getUnionType(append(types, undefinedType));
-            }
-          }
-          if (objectType.symbol === globalThisSymbol && propName !== void 0 && globalThisSymbol.exports.has(propName) && globalThisSymbol.exports.get(propName).flags & 418 /* BlockScoped */) {
-            error(accessExpression, Diagnostics.Property_0_does_not_exist_on_type_1, unescapeLeadingUnderscores(propName), typeToString(objectType));
-          } else if (noImplicitAny && !compilerOptions.suppressImplicitAnyIndexErrors && !(accessFlags & 128 /* SuppressNoImplicitAnyError */)) {
-            if (propName !== void 0 && typeHasStaticProperty(propName, objectType)) {
-              const typeName = typeToString(objectType);
-              error(accessExpression, Diagnostics.Property_0_does_not_exist_on_type_1_Did_you_mean_to_access_the_static_member_2_instead, propName, typeName, typeName + "[" + getTextOfNode(accessExpression.argumentExpression) + "]");
-            } else if (getIndexTypeOfType(objectType, numberType)) {
-              error(accessExpression.argumentExpression, Diagnostics.Element_implicitly_has_an_any_type_because_index_expression_is_not_of_type_number);
-            } else {
-              let suggestion;
-              if (propName !== void 0 && (suggestion = getSuggestionForNonexistentProperty(propName, objectType))) {
-                if (suggestion !== void 0) {
-                  error(accessExpression.argumentExpression, Diagnostics.Property_0_does_not_exist_on_type_1_Did_you_mean_2, propName, typeToString(objectType), suggestion);
-                }
-              } else {
-                const suggestion2 = getSuggestionForNonexistentIndexSignature(objectType, accessExpression, indexType);
-                if (suggestion2 !== void 0) {
-                  error(accessExpression, Diagnostics.Element_implicitly_has_an_any_type_because_type_0_has_no_index_signature_Did_you_mean_to_call_1, typeToString(objectType), suggestion2);
-                } else {
-                  let errorInfo;
-                  if (indexType.flags & 1024 /* EnumLiteral */) {
-                    errorInfo = chainDiagnosticMessages(
-                      /*details*/
-                      void 0,
-                      Diagnostics.Property_0_does_not_exist_on_type_1,
-                      "[" + typeToString(indexType) + "]",
-                      typeToString(objectType)
-                    );
-                  } else if (indexType.flags & 8192 /* UniqueESSymbol */) {
-                    const symbolName2 = getFullyQualifiedName(indexType.symbol, accessExpression);
-                    errorInfo = chainDiagnosticMessages(
-                      /*details*/
-                      void 0,
-                      Diagnostics.Property_0_does_not_exist_on_type_1,
-                      "[" + symbolName2 + "]",
-                      typeToString(objectType)
-                    );
-                  } else if (indexType.flags & 128 /* StringLiteral */) {
-                    errorInfo = chainDiagnosticMessages(
-                      /*details*/
-                      void 0,
-                      Diagnostics.Property_0_does_not_exist_on_type_1,
-                      indexType.value,
-                      typeToString(objectType)
-                    );
-                  } else if (indexType.flags & 256 /* NumberLiteral */) {
-                    errorInfo = chainDiagnosticMessages(
-                      /*details*/
-                      void 0,
-                      Diagnostics.Property_0_does_not_exist_on_type_1,
-                      indexType.value,
-                      typeToString(objectType)
-                    );
-                  } else if (indexType.flags & (8 /* Number */ | 4 /* String */)) {
-                    errorInfo = chainDiagnosticMessages(
-                      /*details*/
-                      void 0,
-                      Diagnostics.No_index_signature_with_a_parameter_of_type_0_was_found_on_type_1,
-                      typeToString(indexType),
-                      typeToString(objectType)
-                    );
-                  }
-                  errorInfo = chainDiagnosticMessages(
-                    errorInfo,
-                    Diagnostics.Element_implicitly_has_an_any_type_because_expression_of_type_0_can_t_be_used_to_index_type_1,
-                    typeToString(fullIndexType),
-                    typeToString(objectType)
-                  );
-                  diagnostics.add(createDiagnosticForNodeFromMessageChain(getSourceFileOfNode(accessExpression), accessExpression, errorInfo));
-                }
-              }
-            }
-          }
-          return void 0;
-        }
-      }
-      if (isJSLiteralType(objectType)) {
-        return anyType;
-      }
-      if (accessNode) {
-        const indexNode = getIndexNodeForAccessExpression(accessNode);
-        if (indexType.flags & (128 /* StringLiteral */ | 256 /* NumberLiteral */)) {
-          error(indexNode, Diagnostics.Property_0_does_not_exist_on_type_1, "" + indexType.value, typeToString(objectType));
-        } else if (indexType.flags & (4 /* String */ | 8 /* Number */)) {
-          error(indexNode, Diagnostics.Type_0_has_no_matching_index_signature_for_type_1, typeToString(objectType), typeToString(indexType));
-        } else {
-          error(indexNode, Diagnostics.Type_0_cannot_be_used_as_an_index_type, typeToString(indexType));
-        }
-      }
-      if (isTypeAny(indexType)) {
-        return indexType;
-      }
-      return void 0;
-      function errorIfWritingToReadonlyIndex(indexInfo) {
-        if (indexInfo && indexInfo.isReadonly && accessExpression && (isAssignmentTarget(accessExpression) || isDeleteTarget(accessExpression))) {
-          error(accessExpression, Diagnostics.Index_signature_in_type_0_only_permits_reading, typeToString(objectType));
-        }
-      }
-    }
-    function getIndexNodeForAccessExpression(accessNode) {
-      return accessNode.kind === 211 /* ElementAccessExpression */ ? accessNode.argumentExpression : accessNode.kind === 198 /* IndexedAccessType */ ? accessNode.indexType : accessNode.kind === 166 /* ComputedPropertyName */ ? accessNode.expression : accessNode;
-    }
-    function isPatternLiteralPlaceholderType(type) {
-      if (type.flags & 2097152 /* Intersection */) {
-        return some(type.types, (t) => !!(t.flags & (2944 /* Literal */ | 65536 /* Null */ | 32768 /* Undefined */)) || isPatternLiteralPlaceholderType(t));
-      }
-      return !!(type.flags & (1 /* Any */ | 4 /* String */ | 8 /* Number */ | 64 /* BigInt */)) || isPatternLiteralType(type);
-    }
-    function isPatternLiteralType(type) {
-      return !!(type.flags & 134217728 /* TemplateLiteral */) && every(type.types, isPatternLiteralPlaceholderType) || !!(type.flags & 268435456 /* StringMapping */) && isPatternLiteralPlaceholderType(type.type);
-    }
-    function isGenericType(type) {
-      return !!getGenericObjectFlags(type);
-    }
-    function isGenericObjectType(type) {
-      return !!(getGenericObjectFlags(type) & 4194304 /* IsGenericObjectType */);
-    }
-    function isGenericIndexType(type) {
-      return !!(getGenericObjectFlags(type) & 8388608 /* IsGenericIndexType */);
-    }
-    function getGenericObjectFlags(type) {
-      if (type.flags & (3145728 /* UnionOrIntersection */ | 134217728 /* TemplateLiteral */)) {
-        if (!(type.objectFlags & 2097152 /* IsGenericTypeComputed */)) {
-          type.objectFlags |= 2097152 /* IsGenericTypeComputed */ | reduceLeft(type.types, (flags, t) => flags | getGenericObjectFlags(t), 0);
-        }
-        return type.objectFlags & 12582912 /* IsGenericType */;
-      }
-      if (type.flags & 33554432 /* Substitution */) {
-        if (!(type.objectFlags & 2097152 /* IsGenericTypeComputed */)) {
-          type.objectFlags |= 2097152 /* IsGenericTypeComputed */ | getGenericObjectFlags(type.baseType) | getGenericObjectFlags(type.constraint);
-        }
-        return type.objectFlags & 12582912 /* IsGenericType */;
-      }
-      return (type.flags & 58982400 /* InstantiableNonPrimitive */ || isGenericMappedType(type) || isGenericTupleType(type) ? 4194304 /* IsGenericObjectType */ : 0) | (type.flags & (58982400 /* InstantiableNonPrimitive */ | 4194304 /* Index */ | 268435456 /* StringMapping */) && !isPatternLiteralType(type) ? 8388608 /* IsGenericIndexType */ : 0);
-    }
-    function getSimplifiedType(type, writing) {
-      return type.flags & 8388608 /* IndexedAccess */ ? getSimplifiedIndexedAccessType(type, writing) : type.flags & 16777216 /* Conditional */ ? getSimplifiedConditionalType(type, writing) : type;
-    }
-    function distributeIndexOverObjectType(objectType, indexType, writing) {
-      if (objectType.flags & 1048576 /* Union */ || objectType.flags & 2097152 /* Intersection */ && !shouldDeferIndexType(objectType)) {
-        const types = map(objectType.types, (t) => getSimplifiedType(getIndexedAccessType(t, indexType), writing));
-        return objectType.flags & 2097152 /* Intersection */ || writing ? getIntersectionType(types) : getUnionType(types);
-      }
-    }
-    function distributeObjectOverIndexType(objectType, indexType, writing) {
-      if (indexType.flags & 1048576 /* Union */) {
-        const types = map(indexType.types, (t) => getSimplifiedType(getIndexedAccessType(objectType, t), writing));
-        return writing ? getIntersectionType(types) : getUnionType(types);
-      }
-    }
-    function getSimplifiedIndexedAccessType(type, writing) {
-      const cache = writing ? "simplifiedForWriting" : "simplifiedForReading";
-      if (type[cache]) {
-        return type[cache] === circularConstraintType ? type : type[cache];
-      }
-      type[cache] = circularConstraintType;
-      const objectType = getSimplifiedType(type.objectType, writing);
-      const indexType = getSimplifiedType(type.indexType, writing);
-      const distributedOverIndex = distributeObjectOverIndexType(objectType, indexType, writing);
-      if (distributedOverIndex) {
-        return type[cache] = distributedOverIndex;
-      }
-      if (!(indexType.flags & 465829888 /* Instantiable */)) {
-        const distributedOverObject = distributeIndexOverObjectType(objectType, indexType, writing);
-        if (distributedOverObject) {
-          return type[cache] = distributedOverObject;
-        }
-      }
-      if (isGenericTupleType(objectType) && indexType.flags & 296 /* NumberLike */) {
-        const elementType = getElementTypeOfSliceOfTupleType(
-          objectType,
-          indexType.flags & 8 /* Number */ ? 0 : objectType.target.fixedLength,
-          /*endSkipCount*/
-          0,
-          writing
-        );
-        if (elementType) {
-          return type[cache] = elementType;
-        }
-      }
-      if (isGenericMappedType(objectType)) {
-        if (!getNameTypeFromMappedType(objectType) || isFilteringMappedType(objectType)) {
-          return type[cache] = mapType(substituteIndexedMappedType(objectType, type.indexType), (t) => getSimplifiedType(t, writing));
-        }
-      }
-      return type[cache] = type;
-    }
-    function getSimplifiedConditionalType(type, writing) {
-      const checkType = type.checkType;
-      const extendsType = type.extendsType;
-      const trueType2 = getTrueTypeFromConditionalType(type);
-      const falseType2 = getFalseTypeFromConditionalType(type);
-      if (falseType2.flags & 131072 /* Never */ && getActualTypeVariable(trueType2) === getActualTypeVariable(checkType)) {
-        if (checkType.flags & 1 /* Any */ || isTypeAssignableTo(getRestrictiveInstantiation(checkType), getRestrictiveInstantiation(extendsType))) {
-          return getSimplifiedType(trueType2, writing);
-        } else if (isIntersectionEmpty(checkType, extendsType)) {
-          return neverType;
-        }
-      } else if (trueType2.flags & 131072 /* Never */ && getActualTypeVariable(falseType2) === getActualTypeVariable(checkType)) {
-        if (!(checkType.flags & 1 /* Any */) && isTypeAssignableTo(getRestrictiveInstantiation(checkType), getRestrictiveInstantiation(extendsType))) {
-          return neverType;
-        } else if (checkType.flags & 1 /* Any */ || isIntersectionEmpty(checkType, extendsType)) {
-          return getSimplifiedType(falseType2, writing);
-        }
-      }
-      return type;
-    }
-    function isIntersectionEmpty(type1, type2) {
-      return !!(getUnionType([intersectTypes(type1, type2), neverType]).flags & 131072 /* Never */);
-    }
-    function substituteIndexedMappedType(objectType, index) {
-      const mapper = createTypeMapper([getTypeParameterFromMappedType(objectType)], [index]);
-      const templateMapper = combineTypeMappers(objectType.mapper, mapper);
-      return instantiateType(getTemplateTypeFromMappedType(objectType.target || objectType), templateMapper);
-    }
-    function getIndexedAccessType(objectType, indexType, accessFlags = 0 /* None */, accessNode, aliasSymbol, aliasTypeArguments) {
-      return getIndexedAccessTypeOrUndefined(objectType, indexType, accessFlags, accessNode, aliasSymbol, aliasTypeArguments) || (accessNode ? errorType : unknownType);
-    }
-    function indexTypeLessThan(indexType, limit) {
-      return everyType(indexType, (t) => {
-        if (t.flags & 384 /* StringOrNumberLiteral */) {
-          const propName = getPropertyNameFromType(t);
-          if (isNumericLiteralName(propName)) {
-            const index = +propName;
-            return index >= 0 && index < limit;
-          }
-        }
-        return false;
-      });
-    }
-    function getIndexedAccessTypeOrUndefined(objectType, indexType, accessFlags = 0 /* None */, accessNode, aliasSymbol, aliasTypeArguments) {
-      if (objectType === wildcardType || indexType === wildcardType) {
-        return wildcardType;
-      }
-      objectType = getReducedType(objectType);
-      if (isStringIndexSignatureOnlyType(objectType) && !(indexType.flags & 98304 /* Nullable */) && isTypeAssignableToKind(indexType, 4 /* String */ | 8 /* Number */)) {
-        indexType = stringType;
-      }
-      if (compilerOptions.noUncheckedIndexedAccess && accessFlags & 32 /* ExpressionPosition */)
-        accessFlags |= 1 /* IncludeUndefined */;
-      if (isGenericIndexType(indexType) || (accessNode && accessNode.kind !== 198 /* IndexedAccessType */ ? isGenericTupleType(objectType) && !indexTypeLessThan(indexType, objectType.target.fixedLength) : isGenericObjectType(objectType) && !(isTupleType(objectType) && indexTypeLessThan(indexType, objectType.target.fixedLength)) || isGenericReducibleType(objectType))) {
-        if (objectType.flags & 3 /* AnyOrUnknown */) {
-          return objectType;
-        }
-        const persistentAccessFlags = accessFlags & 1 /* Persistent */;
-        const id = objectType.id + "," + indexType.id + "," + persistentAccessFlags + getAliasId(aliasSymbol, aliasTypeArguments);
-        let type = indexedAccessTypes.get(id);
-        if (!type) {
-          indexedAccessTypes.set(id, type = createIndexedAccessType(objectType, indexType, persistentAccessFlags, aliasSymbol, aliasTypeArguments));
-        }
-        return type;
-      }
-      const apparentObjectType = getReducedApparentType(objectType);
-      if (indexType.flags & 1048576 /* Union */ && !(indexType.flags & 16 /* Boolean */)) {
-        const propTypes = [];
-        let wasMissingProp = false;
-        for (const t of indexType.types) {
-          const propType = getPropertyTypeForIndexType(objectType, apparentObjectType, t, indexType, accessNode, accessFlags | (wasMissingProp ? 128 /* SuppressNoImplicitAnyError */ : 0));
-          if (propType) {
-            propTypes.push(propType);
-          } else if (!accessNode) {
-            return void 0;
-          } else {
-            wasMissingProp = true;
-          }
-        }
-        if (wasMissingProp) {
-          return void 0;
-        }
-        return accessFlags & 4 /* Writing */ ? getIntersectionType(propTypes, aliasSymbol, aliasTypeArguments) : getUnionType(propTypes, 1 /* Literal */, aliasSymbol, aliasTypeArguments);
-      }
-      return getPropertyTypeForIndexType(objectType, apparentObjectType, indexType, indexType, accessNode, accessFlags | 8 /* CacheSymbol */ | 64 /* ReportDeprecated */);
-    }
-    function getTypeFromIndexedAccessTypeNode(node) {
-      const links = getNodeLinks(node);
-      if (!links.resolvedType) {
-        const objectType = getTypeFromTypeNode(node.objectType);
-        const indexType = getTypeFromTypeNode(node.indexType);
-        const potentialAlias = getAliasSymbolForTypeNode(node);
-        links.resolvedType = getIndexedAccessType(objectType, indexType, 0 /* None */, node, potentialAlias, getTypeArgumentsForAliasSymbol(potentialAlias));
-      }
-      return links.resolvedType;
-    }
-    function getTypeFromMappedTypeNode(node) {
-      const links = getNodeLinks(node);
-      if (!links.resolvedType) {
-        const type = createObjectType(32 /* Mapped */, node.symbol);
-        type.declaration = node;
-        type.aliasSymbol = getAliasSymbolForTypeNode(node);
-        type.aliasTypeArguments = getTypeArgumentsForAliasSymbol(type.aliasSymbol);
-        links.resolvedType = type;
-        getConstraintTypeFromMappedType(type);
-      }
-      return links.resolvedType;
-    }
-    function getActualTypeVariable(type) {
-      if (type.flags & 33554432 /* Substitution */) {
-        return getActualTypeVariable(type.baseType);
-      }
-      if (type.flags & 8388608 /* IndexedAccess */ && (type.objectType.flags & 33554432 /* Substitution */ || type.indexType.flags & 33554432 /* Substitution */)) {
-        return getIndexedAccessType(getActualTypeVariable(type.objectType), getActualTypeVariable(type.indexType));
-      }
-      return type;
-    }
-    function maybeCloneTypeParameter(p) {
-      const constraint = getConstraintOfTypeParameter(p);
-      return constraint && (isGenericObjectType(constraint) || isGenericIndexType(constraint)) ? cloneTypeParameter(p) : p;
-    }
-    function isSimpleTupleType(node) {
-      return isTupleTypeNode(node) && length(node.elements) > 0 && !some(node.elements, (e) => isOptionalTypeNode(e) || isRestTypeNode(e) || isNamedTupleMember(e) && !!(e.questionToken || e.dotDotDotToken));
-    }
-    function isDeferredType(type, checkTuples) {
-      return isGenericType(type) || checkTuples && isTupleType(type) && some(getElementTypes(type), isGenericType);
-    }
-    function getConditionalType(root, mapper, aliasSymbol, aliasTypeArguments) {
-      let result;
-      let extraTypes;
-      let tailCount = 0;
-      while (true) {
-        if (tailCount === 1e3) {
-          error(currentNode, Diagnostics.Type_instantiation_is_excessively_deep_and_possibly_infinite);
-          return errorType;
-        }
-        const checkType = instantiateType(getActualTypeVariable(root.checkType), mapper);
-        const extendsType = instantiateType(root.extendsType, mapper);
-        if (checkType === errorType || extendsType === errorType) {
-          return errorType;
-        }
-        if (checkType === wildcardType || extendsType === wildcardType) {
-          return wildcardType;
-        }
-        const checkTuples = isSimpleTupleType(root.node.checkType) && isSimpleTupleType(root.node.extendsType) && length(root.node.checkType.elements) === length(root.node.extendsType.elements);
-        const checkTypeDeferred = isDeferredType(checkType, checkTuples);
-        let combinedMapper;
-        if (root.inferTypeParameters) {
-          const freshParams = sameMap(root.inferTypeParameters, maybeCloneTypeParameter);
-          const freshMapper = freshParams !== root.inferTypeParameters ? createTypeMapper(root.inferTypeParameters, freshParams) : void 0;
-          const context = createInferenceContext(
-            freshParams,
-            /*signature*/
-            void 0,
-            0 /* None */
-          );
-          if (freshMapper) {
-            const freshCombinedMapper = combineTypeMappers(mapper, freshMapper);
-            for (const p of freshParams) {
-              if (root.inferTypeParameters.indexOf(p) === -1) {
-                p.mapper = freshCombinedMapper;
-              }
-            }
-          }
-          if (!checkTypeDeferred) {
-            inferTypes(context.inferences, checkType, instantiateType(extendsType, freshMapper), 512 /* NoConstraints */ | 1024 /* AlwaysStrict */);
-          }
-          const innerMapper = combineTypeMappers(freshMapper, context.mapper);
-          combinedMapper = mapper ? combineTypeMappers(innerMapper, mapper) : innerMapper;
-        }
-        const inferredExtendsType = combinedMapper ? instantiateType(root.extendsType, combinedMapper) : extendsType;
-        if (!checkTypeDeferred && !isDeferredType(inferredExtendsType, checkTuples)) {
-          if (!(inferredExtendsType.flags & 3 /* AnyOrUnknown */) && (checkType.flags & 1 /* Any */ || !isTypeAssignableTo(getPermissiveInstantiation(checkType), getPermissiveInstantiation(inferredExtendsType)))) {
-            if (checkType.flags & 1 /* Any */) {
-              (extraTypes || (extraTypes = [])).push(instantiateType(getTypeFromTypeNode(root.node.trueType), combinedMapper || mapper));
-            }
-            const falseType2 = getTypeFromTypeNode(root.node.falseType);
-            if (falseType2.flags & 16777216 /* Conditional */) {
-              const newRoot = falseType2.root;
-              if (newRoot.node.parent === root.node && (!newRoot.isDistributive || newRoot.checkType === root.checkType)) {
-                root = newRoot;
-                continue;
-              }
-              if (canTailRecurse(falseType2, mapper)) {
-                continue;
-              }
-            }
-            result = instantiateType(falseType2, mapper);
-            break;
-          }
-          if (inferredExtendsType.flags & 3 /* AnyOrUnknown */ || isTypeAssignableTo(getRestrictiveInstantiation(checkType), getRestrictiveInstantiation(inferredExtendsType))) {
-            const trueType2 = getTypeFromTypeNode(root.node.trueType);
-            const trueMapper = combinedMapper || mapper;
-            if (canTailRecurse(trueType2, trueMapper)) {
-              continue;
-            }
-            result = instantiateType(trueType2, trueMapper);
-            break;
-          }
-        }
-        result = createType(16777216 /* Conditional */);
-        result.root = root;
-        result.checkType = instantiateType(root.checkType, mapper);
-        result.extendsType = instantiateType(root.extendsType, mapper);
-        result.mapper = mapper;
-        result.combinedMapper = combinedMapper;
-        result.aliasSymbol = aliasSymbol || root.aliasSymbol;
-        result.aliasTypeArguments = aliasSymbol ? aliasTypeArguments : instantiateTypes(root.aliasTypeArguments, mapper);
-        break;
-      }
-      return extraTypes ? getUnionType(append(extraTypes, result)) : result;
-      function canTailRecurse(newType, newMapper) {
-        if (newType.flags & 16777216 /* Conditional */ && newMapper) {
-          const newRoot = newType.root;
-          if (newRoot.outerTypeParameters) {
-            const typeParamMapper = combineTypeMappers(newType.mapper, newMapper);
-            const typeArguments = map(newRoot.outerTypeParameters, (t) => getMappedType(t, typeParamMapper));
-            const newRootMapper = createTypeMapper(newRoot.outerTypeParameters, typeArguments);
-            const newCheckType = newRoot.isDistributive ? getMappedType(newRoot.checkType, newRootMapper) : void 0;
-            if (!newCheckType || newCheckType === newRoot.checkType || !(newCheckType.flags & (1048576 /* Union */ | 131072 /* Never */))) {
-              root = newRoot;
-              mapper = newRootMapper;
-              aliasSymbol = void 0;
-              aliasTypeArguments = void 0;
-              if (newRoot.aliasSymbol) {
-                tailCount++;
-              }
-              return true;
-            }
-          }
-        }
-        return false;
-      }
-    }
-    function getTrueTypeFromConditionalType(type) {
-      return type.resolvedTrueType || (type.resolvedTrueType = instantiateType(getTypeFromTypeNode(type.root.node.trueType), type.mapper));
-    }
-    function getFalseTypeFromConditionalType(type) {
-      return type.resolvedFalseType || (type.resolvedFalseType = instantiateType(getTypeFromTypeNode(type.root.node.falseType), type.mapper));
-    }
-    function getInferredTrueTypeFromConditionalType(type) {
-      return type.resolvedInferredTrueType || (type.resolvedInferredTrueType = type.combinedMapper ? instantiateType(getTypeFromTypeNode(type.root.node.trueType), type.combinedMapper) : getTrueTypeFromConditionalType(type));
-    }
-    function getInferTypeParameters(node) {
-      let result;
-      if (node.locals) {
-        node.locals.forEach((symbol) => {
-          if (symbol.flags & 262144 /* TypeParameter */) {
-            result = append(result, getDeclaredTypeOfSymbol(symbol));
-          }
-        });
-      }
-      return result;
-    }
-    function isDistributionDependent(root) {
-      return root.isDistributive && (isTypeParameterPossiblyReferenced(root.checkType, root.node.trueType) || isTypeParameterPossiblyReferenced(root.checkType, root.node.falseType));
-    }
-    function getTypeFromConditionalTypeNode(node) {
-      const links = getNodeLinks(node);
-      if (!links.resolvedType) {
-        const checkType = getTypeFromTypeNode(node.checkType);
-        const aliasSymbol = getAliasSymbolForTypeNode(node);
-        const aliasTypeArguments = getTypeArgumentsForAliasSymbol(aliasSymbol);
-        const allOuterTypeParameters = getOuterTypeParameters(
-          node,
-          /*includeThisTypes*/
-          true
-        );
-        const outerTypeParameters = aliasTypeArguments ? allOuterTypeParameters : filter(allOuterTypeParameters, (tp) => isTypeParameterPossiblyReferenced(tp, node));
-        const root = {
-          node,
-          checkType,
-          extendsType: getTypeFromTypeNode(node.extendsType),
-          isDistributive: !!(checkType.flags & 262144 /* TypeParameter */),
-          inferTypeParameters: getInferTypeParameters(node),
-          outerTypeParameters,
-          instantiations: void 0,
-          aliasSymbol,
-          aliasTypeArguments
-        };
-        links.resolvedType = getConditionalType(
-          root,
-          /*mapper*/
-          void 0
-        );
-        if (outerTypeParameters) {
-          root.instantiations = /* @__PURE__ */ new Map();
-          root.instantiations.set(getTypeListId(outerTypeParameters), links.resolvedType);
-        }
-      }
-      return links.resolvedType;
-    }
-    function getTypeFromInferTypeNode(node) {
-      const links = getNodeLinks(node);
-      if (!links.resolvedType) {
-        links.resolvedType = getDeclaredTypeOfTypeParameter(getSymbolOfDeclaration(node.typeParameter));
-      }
-      return links.resolvedType;
-    }
-    function getIdentifierChain(node) {
-      if (isIdentifier(node)) {
-        return [node];
-      } else {
-        return append(getIdentifierChain(node.left), node.right);
-      }
-    }
-    function getTypeFromImportTypeNode(node) {
-      var _a;
-      const links = getNodeLinks(node);
-      if (!links.resolvedType) {
-        if (!isLiteralImportTypeNode(node)) {
-          error(node.argument, Diagnostics.String_literal_expected);
-          links.resolvedSymbol = unknownSymbol;
-          return links.resolvedType = errorType;
-        }
-        const targetMeaning = node.isTypeOf ? 111551 /* Value */ : node.flags & 8388608 /* JSDoc */ ? 111551 /* Value */ | 788968 /* Type */ : 788968 /* Type */;
-        const innerModuleSymbol = resolveExternalModuleName(node, node.argument.literal);
-        if (!innerModuleSymbol) {
-          links.resolvedSymbol = unknownSymbol;
-          return links.resolvedType = errorType;
-        }
-        const isExportEquals = !!((_a = innerModuleSymbol.exports) == null ? void 0 : _a.get("export=" /* ExportEquals */));
-        const moduleSymbol = resolveExternalModuleSymbol(
-          innerModuleSymbol,
-          /*dontResolveAlias*/
-          false
-        );
-        if (!nodeIsMissing(node.qualifier)) {
-          const nameStack = getIdentifierChain(node.qualifier);
-          let currentNamespace = moduleSymbol;
-          let current;
-          while (current = nameStack.shift()) {
-            const meaning = nameStack.length ? 1920 /* Namespace */ : targetMeaning;
-            const mergedResolvedSymbol = getMergedSymbol(resolveSymbol(currentNamespace));
-            const symbolFromVariable = node.isTypeOf || isInJSFile(node) && isExportEquals ? getPropertyOfType(
-              getTypeOfSymbol(mergedResolvedSymbol),
-              current.escapedText,
-              /*skipObjectFunctionPropertyAugment*/
-              false,
-              /*includeTypeOnlyMembers*/
-              true
-            ) : void 0;
-            const symbolFromModule = node.isTypeOf ? void 0 : getSymbol2(getExportsOfSymbol(mergedResolvedSymbol), current.escapedText, meaning);
-            const next = symbolFromModule ?? symbolFromVariable;
-            if (!next) {
-              error(current, Diagnostics.Namespace_0_has_no_exported_member_1, getFullyQualifiedName(currentNamespace), declarationNameToString(current));
-              return links.resolvedType = errorType;
-            }
-            getNodeLinks(current).resolvedSymbol = next;
-            getNodeLinks(current.parent).resolvedSymbol = next;
-            currentNamespace = next;
-          }
-          links.resolvedType = resolveImportSymbolType(node, links, currentNamespace, targetMeaning);
-        } else {
-          if (moduleSymbol.flags & targetMeaning) {
-            links.resolvedType = resolveImportSymbolType(node, links, moduleSymbol, targetMeaning);
-          } else {
-            const errorMessage = targetMeaning === 111551 /* Value */ ? Diagnostics.Module_0_does_not_refer_to_a_value_but_is_used_as_a_value_here : Diagnostics.Module_0_does_not_refer_to_a_type_but_is_used_as_a_type_here_Did_you_mean_typeof_import_0;
-            error(node, errorMessage, node.argument.literal.text);
-            links.resolvedSymbol = unknownSymbol;
-            links.resolvedType = errorType;
-          }
-        }
-      }
-      return links.resolvedType;
-    }
-    function resolveImportSymbolType(node, links, symbol, meaning) {
-      const resolvedSymbol = resolveSymbol(symbol);
-      links.resolvedSymbol = resolvedSymbol;
-      if (meaning === 111551 /* Value */) {
-        return getInstantiationExpressionType(getTypeOfSymbol(symbol), node);
-      } else {
-        return getTypeReferenceType(node, resolvedSymbol);
-      }
-    }
-    function getTypeFromTypeLiteralOrFunctionOrConstructorTypeNode(node) {
-      const links = getNodeLinks(node);
-      if (!links.resolvedType) {
-        const aliasSymbol = getAliasSymbolForTypeNode(node);
-        if (getMembersOfSymbol(node.symbol).size === 0 && !aliasSymbol) {
-          links.resolvedType = emptyTypeLiteralType;
-        } else {
-          let type = createObjectType(16 /* Anonymous */, node.symbol);
-          type.aliasSymbol = aliasSymbol;
-          type.aliasTypeArguments = getTypeArgumentsForAliasSymbol(aliasSymbol);
-          if (isJSDocTypeLiteral(node) && node.isArrayType) {
-            type = createArrayType(type);
-          }
-          links.resolvedType = type;
-        }
-      }
-      return links.resolvedType;
-    }
-    function getAliasSymbolForTypeNode(node) {
-      let host2 = node.parent;
-      while (isParenthesizedTypeNode(host2) || isJSDocTypeExpression(host2) || isTypeOperatorNode(host2) && host2.operator === 148 /* ReadonlyKeyword */) {
-        host2 = host2.parent;
-      }
-      return isTypeAlias(host2) ? getSymbolOfDeclaration(host2) : void 0;
-    }
-    function getTypeArgumentsForAliasSymbol(symbol) {
-      return symbol ? getLocalTypeParametersOfClassOrInterfaceOrTypeAlias(symbol) : void 0;
-    }
-    function isNonGenericObjectType(type) {
-      return !!(type.flags & 524288 /* Object */) && !isGenericMappedType(type);
-    }
-    function isEmptyObjectTypeOrSpreadsIntoEmptyObject(type) {
-      return isEmptyObjectType(type) || !!(type.flags & (65536 /* Null */ | 32768 /* Undefined */ | 528 /* BooleanLike */ | 296 /* NumberLike */ | 2112 /* BigIntLike */ | 402653316 /* StringLike */ | 1056 /* EnumLike */ | 67108864 /* NonPrimitive */ | 4194304 /* Index */));
-    }
-    function tryMergeUnionOfObjectTypeAndEmptyObject(type, readonly) {
-      if (!(type.flags & 1048576 /* Union */)) {
-        return type;
-      }
-      if (every(type.types, isEmptyObjectTypeOrSpreadsIntoEmptyObject)) {
-        return find(type.types, isEmptyObjectType) || emptyObjectType;
-      }
-      const firstType = find(type.types, (t) => !isEmptyObjectTypeOrSpreadsIntoEmptyObject(t));
-      if (!firstType) {
-        return type;
-      }
-      const secondType = find(type.types, (t) => t !== firstType && !isEmptyObjectTypeOrSpreadsIntoEmptyObject(t));
-      if (secondType) {
-        return type;
-      }
-      return getAnonymousPartialType(firstType);
-      function getAnonymousPartialType(type2) {
-        const members = createSymbolTable();
-        for (const prop of getPropertiesOfType(type2)) {
-          if (getDeclarationModifierFlagsFromSymbol(prop) & (8 /* Private */ | 16 /* Protected */)) {
-          } else if (isSpreadableProperty(prop)) {
-            const isSetonlyAccessor = prop.flags & 65536 /* SetAccessor */ && !(prop.flags & 32768 /* GetAccessor */);
-            const flags = 4 /* Property */ | 16777216 /* Optional */;
-            const result = createSymbol(flags, prop.escapedName, getIsLateCheckFlag(prop) | (readonly ? 8 /* Readonly */ : 0));
-            result.links.type = isSetonlyAccessor ? undefinedType : addOptionality(
-              getTypeOfSymbol(prop),
-              /*isProperty*/
-              true
-            );
-            result.declarations = prop.declarations;
-            result.links.nameType = getSymbolLinks(prop).nameType;
-            result.links.syntheticOrigin = prop;
-            members.set(prop.escapedName, result);
-          }
-        }
-        const spread = createAnonymousType(type2.symbol, members, emptyArray, emptyArray, getIndexInfosOfType(type2));
-        spread.objectFlags |= 128 /* ObjectLiteral */ | 131072 /* ContainsObjectOrArrayLiteral */;
-        return spread;
-      }
-    }
-    function getSpreadType(left, right, symbol, objectFlags, readonly) {
-      if (left.flags & 1 /* Any */ || right.flags & 1 /* Any */) {
-        return anyType;
-      }
-      if (left.flags & 2 /* Unknown */ || right.flags & 2 /* Unknown */) {
-        return unknownType;
-      }
-      if (left.flags & 131072 /* Never */) {
-        return right;
-      }
-      if (right.flags & 131072 /* Never */) {
-        return left;
-      }
-      left = tryMergeUnionOfObjectTypeAndEmptyObject(left, readonly);
-      if (left.flags & 1048576 /* Union */) {
-        return checkCrossProductUnion([left, right]) ? mapType(left, (t) => getSpreadType(t, right, symbol, objectFlags, readonly)) : errorType;
-      }
-      right = tryMergeUnionOfObjectTypeAndEmptyObject(right, readonly);
-      if (right.flags & 1048576 /* Union */) {
-        return checkCrossProductUnion([left, right]) ? mapType(right, (t) => getSpreadType(left, t, symbol, objectFlags, readonly)) : errorType;
-      }
-      if (right.flags & (528 /* BooleanLike */ | 296 /* NumberLike */ | 2112 /* BigIntLike */ | 402653316 /* StringLike */ | 1056 /* EnumLike */ | 67108864 /* NonPrimitive */ | 4194304 /* Index */)) {
-        return left;
-      }
-      if (isGenericObjectType(left) || isGenericObjectType(right)) {
-        if (isEmptyObjectType(left)) {
-          return right;
-        }
-        if (left.flags & 2097152 /* Intersection */) {
-          const types = left.types;
-          const lastLeft = types[types.length - 1];
-          if (isNonGenericObjectType(lastLeft) && isNonGenericObjectType(right)) {
-            return getIntersectionType(concatenate(types.slice(0, types.length - 1), [getSpreadType(lastLeft, right, symbol, objectFlags, readonly)]));
-          }
-        }
-        return getIntersectionType([left, right]);
-      }
-      const members = createSymbolTable();
-      const skippedPrivateMembers = /* @__PURE__ */ new Set();
-      const indexInfos = left === emptyObjectType ? getIndexInfosOfType(right) : getUnionIndexInfos([left, right]);
-      for (const rightProp of getPropertiesOfType(right)) {
-        if (getDeclarationModifierFlagsFromSymbol(rightProp) & (8 /* Private */ | 16 /* Protected */)) {
-          skippedPrivateMembers.add(rightProp.escapedName);
-        } else if (isSpreadableProperty(rightProp)) {
-          members.set(rightProp.escapedName, getSpreadSymbol(rightProp, readonly));
-        }
-      }
-      for (const leftProp of getPropertiesOfType(left)) {
-        if (skippedPrivateMembers.has(leftProp.escapedName) || !isSpreadableProperty(leftProp)) {
-          continue;
-        }
-        if (members.has(leftProp.escapedName)) {
-          const rightProp = members.get(leftProp.escapedName);
-          const rightType = getTypeOfSymbol(rightProp);
-          if (rightProp.flags & 16777216 /* Optional */) {
-            const declarations = concatenate(leftProp.declarations, rightProp.declarations);
-            const flags = 4 /* Property */ | leftProp.flags & 16777216 /* Optional */;
-            const result = createSymbol(flags, leftProp.escapedName);
-            const leftType = getTypeOfSymbol(leftProp);
-            const leftTypeWithoutUndefined = removeMissingOrUndefinedType(leftType);
-            const rightTypeWithoutUndefined = removeMissingOrUndefinedType(rightType);
-            result.links.type = leftTypeWithoutUndefined === rightTypeWithoutUndefined ? leftType : getUnionType([leftType, rightTypeWithoutUndefined], 2 /* Subtype */);
-            result.links.leftSpread = leftProp;
-            result.links.rightSpread = rightProp;
-            result.declarations = declarations;
-            result.links.nameType = getSymbolLinks(leftProp).nameType;
-            members.set(leftProp.escapedName, result);
-          }
-        } else {
-          members.set(leftProp.escapedName, getSpreadSymbol(leftProp, readonly));
-        }
-      }
-      const spread = createAnonymousType(symbol, members, emptyArray, emptyArray, sameMap(indexInfos, (info) => getIndexInfoWithReadonly(info, readonly)));
-      spread.objectFlags |= 128 /* ObjectLiteral */ | 131072 /* ContainsObjectOrArrayLiteral */ | 2097152 /* ContainsSpread */ | objectFlags;
-      return spread;
-    }
-    function isSpreadableProperty(prop) {
-      var _a;
-      return !some(prop.declarations, isPrivateIdentifierClassElementDeclaration) && (!(prop.flags & (8192 /* Method */ | 32768 /* GetAccessor */ | 65536 /* SetAccessor */)) || !((_a = prop.declarations) == null ? void 0 : _a.some((decl) => isClassLike(decl.parent))));
-    }
-    function getSpreadSymbol(prop, readonly) {
-      const isSetonlyAccessor = prop.flags & 65536 /* SetAccessor */ && !(prop.flags & 32768 /* GetAccessor */);
-      if (!isSetonlyAccessor && readonly === isReadonlySymbol(prop)) {
-        return prop;
-      }
-      const flags = 4 /* Property */ | prop.flags & 16777216 /* Optional */;
-      const result = createSymbol(flags, prop.escapedName, getIsLateCheckFlag(prop) | (readonly ? 8 /* Readonly */ : 0));
-      result.links.type = isSetonlyAccessor ? undefinedType : getTypeOfSymbol(prop);
-      result.declarations = prop.declarations;
-      result.links.nameType = getSymbolLinks(prop).nameType;
-      result.links.syntheticOrigin = prop;
-      return result;
-    }
-    function getIndexInfoWithReadonly(info, readonly) {
-      return info.isReadonly !== readonly ? createIndexInfo(info.keyType, info.type, readonly, info.declaration) : info;
-    }
-    function createLiteralType(flags, value, symbol, regularType) {
-      const type = createTypeWithSymbol(flags, symbol);
-      type.value = value;
-      type.regularType = regularType || type;
-      return type;
-    }
-    function getFreshTypeOfLiteralType(type) {
-      if (type.flags & 2976 /* Freshable */) {
-        if (!type.freshType) {
-          const freshType = createLiteralType(type.flags, type.value, type.symbol, type);
-          freshType.freshType = freshType;
-          type.freshType = freshType;
-        }
-        return type.freshType;
-      }
-      return type;
-    }
-    function getRegularTypeOfLiteralType(type) {
-      return type.flags & 2976 /* Freshable */ ? type.regularType : type.flags & 1048576 /* Union */ ? type.regularType || (type.regularType = mapType(type, getRegularTypeOfLiteralType)) : type;
-    }
-    function isFreshLiteralType(type) {
-      return !!(type.flags & 2976 /* Freshable */) && type.freshType === type;
-    }
-    function getStringLiteralType(value) {
-      let type;
-      return stringLiteralTypes.get(value) || (stringLiteralTypes.set(value, type = createLiteralType(128 /* StringLiteral */, value)), type);
-    }
-    function getNumberLiteralType(value) {
-      let type;
-      return numberLiteralTypes.get(value) || (numberLiteralTypes.set(value, type = createLiteralType(256 /* NumberLiteral */, value)), type);
-    }
-    function getBigIntLiteralType(value) {
-      let type;
-      const key = pseudoBigIntToString(value);
-      return bigIntLiteralTypes.get(key) || (bigIntLiteralTypes.set(key, type = createLiteralType(2048 /* BigIntLiteral */, value)), type);
-    }
-    function getEnumLiteralType(value, enumId, symbol) {
-      let type;
-      const key = `${enumId}${typeof value === "string" ? "@" : "#"}${value}`;
-      const flags = 1024 /* EnumLiteral */ | (typeof value === "string" ? 128 /* StringLiteral */ : 256 /* NumberLiteral */);
-      return enumLiteralTypes.get(key) || (enumLiteralTypes.set(key, type = createLiteralType(flags, value, symbol)), type);
-    }
-    function getTypeFromLiteralTypeNode(node) {
-      if (node.literal.kind === 106 /* NullKeyword */) {
-        return nullType;
-      }
-      const links = getNodeLinks(node);
-      if (!links.resolvedType) {
-        links.resolvedType = getRegularTypeOfLiteralType(checkExpression(node.literal));
-      }
-      return links.resolvedType;
-    }
-    function createUniqueESSymbolType(symbol) {
-      const type = createTypeWithSymbol(8192 /* UniqueESSymbol */, symbol);
-      type.escapedName = `__@${type.symbol.escapedName}@${getSymbolId(type.symbol)}`;
-      return type;
-    }
-    function getESSymbolLikeTypeForNode(node) {
-      if (isValidESSymbolDeclaration(node)) {
-        const symbol = isCommonJsExportPropertyAssignment(node) ? getSymbolOfNode(node.left) : getSymbolOfNode(node);
-        if (symbol) {
-          const links = getSymbolLinks(symbol);
-          return links.uniqueESSymbolType || (links.uniqueESSymbolType = createUniqueESSymbolType(symbol));
-        }
-      }
-      return esSymbolType;
-    }
-    function getThisType(node) {
-      const container = getThisContainer(
-        node,
-        /*includeArrowFunctions*/
-        false,
-        /*includeClassComputedPropertyName*/
-        false
-      );
-      const parent2 = container && container.parent;
-      if (parent2 && (isClassLike(parent2) || parent2.kind === 263 /* InterfaceDeclaration */)) {
-        if (!isStatic(container) && (!isConstructorDeclaration(container) || isNodeDescendantOf(node, container.body))) {
-          return getDeclaredTypeOfClassOrInterface(getSymbolOfDeclaration(parent2)).thisType;
-        }
-      }
-      if (parent2 && isObjectLiteralExpression(parent2) && isBinaryExpression(parent2.parent) && getAssignmentDeclarationKind(parent2.parent) === 6 /* Prototype */) {
-        return getDeclaredTypeOfClassOrInterface(getSymbolOfNode(parent2.parent.left).parent).thisType;
-      }
-      const host2 = node.flags & 8388608 /* JSDoc */ ? getHostSignatureFromJSDoc(node) : void 0;
-      if (host2 && isFunctionExpression(host2) && isBinaryExpression(host2.parent) && getAssignmentDeclarationKind(host2.parent) === 3 /* PrototypeProperty */) {
-        return getDeclaredTypeOfClassOrInterface(getSymbolOfNode(host2.parent.left).parent).thisType;
-      }
-      if (isJSConstructor(container) && isNodeDescendantOf(node, container.body)) {
-        return getDeclaredTypeOfClassOrInterface(getSymbolOfDeclaration(container)).thisType;
-      }
-      error(node, Diagnostics.A_this_type_is_available_only_in_a_non_static_member_of_a_class_or_interface);
-      return errorType;
-    }
-    function getTypeFromThisTypeNode(node) {
-      const links = getNodeLinks(node);
-      if (!links.resolvedType) {
-        links.resolvedType = getThisType(node);
-      }
-      return links.resolvedType;
-    }
-    function getTypeFromRestTypeNode(node) {
-      return getTypeFromTypeNode(getArrayElementTypeNode(node.type) || node.type);
-    }
-    function getArrayElementTypeNode(node) {
-      switch (node.kind) {
-        case 195 /* ParenthesizedType */:
-          return getArrayElementTypeNode(node.type);
-        case 188 /* TupleType */:
-          if (node.elements.length === 1) {
-            node = node.elements[0];
-            if (node.kind === 190 /* RestType */ || node.kind === 201 /* NamedTupleMember */ && node.dotDotDotToken) {
-              return getArrayElementTypeNode(node.type);
-            }
-          }
-          break;
-        case 187 /* ArrayType */:
-          return node.elementType;
-      }
-      return void 0;
-    }
-    function getTypeFromNamedTupleTypeNode(node) {
-      const links = getNodeLinks(node);
-      return links.resolvedType || (links.resolvedType = node.dotDotDotToken ? getTypeFromRestTypeNode(node) : addOptionality(
-        getTypeFromTypeNode(node.type),
-        /*isProperty*/
-        true,
-        !!node.questionToken
-      ));
-    }
-    function getTypeFromTypeNode(node) {
-      return getConditionalFlowTypeOfType(getTypeFromTypeNodeWorker(node), node);
-    }
-    function getTypeFromTypeNodeWorker(node) {
-      switch (node.kind) {
-        case 133 /* AnyKeyword */:
-        case 318 /* JSDocAllType */:
-        case 319 /* JSDocUnknownType */:
-          return anyType;
-        case 159 /* UnknownKeyword */:
-          return unknownType;
-        case 154 /* StringKeyword */:
-          return stringType;
-        case 150 /* NumberKeyword */:
-          return numberType;
-        case 162 /* BigIntKeyword */:
-          return bigintType;
-        case 136 /* BooleanKeyword */:
-          return booleanType;
-        case 155 /* SymbolKeyword */:
-          return esSymbolType;
-        case 116 /* VoidKeyword */:
-          return voidType;
-        case 157 /* UndefinedKeyword */:
-          return undefinedType;
-        case 106 /* NullKeyword */:
-          return nullType;
-        case 146 /* NeverKeyword */:
-          return neverType;
-        case 151 /* ObjectKeyword */:
-          return node.flags & 262144 /* JavaScriptFile */ && !noImplicitAny ? anyType : nonPrimitiveType;
-        case 141 /* IntrinsicKeyword */:
-          return intrinsicMarkerType;
-        case 196 /* ThisType */:
-        case 110 /* ThisKeyword */:
-          return getTypeFromThisTypeNode(node);
-        case 200 /* LiteralType */:
-          return getTypeFromLiteralTypeNode(node);
-        case 182 /* TypeReference */:
-          return getTypeFromTypeReference(node);
-        case 181 /* TypePredicate */:
-          return node.assertsModifier ? voidType : booleanType;
-        case 232 /* ExpressionWithTypeArguments */:
-          return getTypeFromTypeReference(node);
-        case 185 /* TypeQuery */:
-          return getTypeFromTypeQueryNode(node);
-        case 187 /* ArrayType */:
-        case 188 /* TupleType */:
-          return getTypeFromArrayOrTupleTypeNode(node);
-        case 189 /* OptionalType */:
-          return getTypeFromOptionalTypeNode(node);
-        case 191 /* UnionType */:
-          return getTypeFromUnionTypeNode(node);
-        case 192 /* IntersectionType */:
-          return getTypeFromIntersectionTypeNode(node);
-        case 320 /* JSDocNullableType */:
-          return getTypeFromJSDocNullableTypeNode(node);
-        case 322 /* JSDocOptionalType */:
-          return addOptionality(getTypeFromTypeNode(node.type));
-        case 201 /* NamedTupleMember */:
-          return getTypeFromNamedTupleTypeNode(node);
-        case 195 /* ParenthesizedType */:
-        case 321 /* JSDocNonNullableType */:
-        case 315 /* JSDocTypeExpression */:
-          return getTypeFromTypeNode(node.type);
-        case 190 /* RestType */:
-          return getTypeFromRestTypeNode(node);
-        case 324 /* JSDocVariadicType */:
-          return getTypeFromJSDocVariadicType(node);
-        case 183 /* FunctionType */:
-        case 184 /* ConstructorType */:
-        case 186 /* TypeLiteral */:
-        case 328 /* JSDocTypeLiteral */:
-        case 323 /* JSDocFunctionType */:
-        case 329 /* JSDocSignature */:
-          return getTypeFromTypeLiteralOrFunctionOrConstructorTypeNode(node);
-        case 197 /* TypeOperator */:
-          return getTypeFromTypeOperatorNode(node);
-        case 198 /* IndexedAccessType */:
-          return getTypeFromIndexedAccessTypeNode(node);
-        case 199 /* MappedType */:
-          return getTypeFromMappedTypeNode(node);
-        case 193 /* ConditionalType */:
-          return getTypeFromConditionalTypeNode(node);
-        case 194 /* InferType */:
-          return getTypeFromInferTypeNode(node);
-        case 202 /* TemplateLiteralType */:
-          return getTypeFromTemplateTypeNode(node);
-        case 204 /* ImportType */:
-          return getTypeFromImportTypeNode(node);
-        case 80 /* Identifier */:
-        case 165 /* QualifiedName */:
-        case 210 /* PropertyAccessExpression */:
-          const symbol = getSymbolAtLocation(node);
-          return symbol ? getDeclaredTypeOfSymbol(symbol) : errorType;
-        default:
-          return errorType;
-      }
-    }
-    function instantiateList(items, mapper, instantiator) {
-      if (items && items.length) {
-        for (let i = 0; i < items.length; i++) {
-          const item = items[i];
-          const mapped = instantiator(item, mapper);
-          if (item !== mapped) {
-            const result = i === 0 ? [] : items.slice(0, i);
-            result.push(mapped);
-            for (i++; i < items.length; i++) {
-              result.push(instantiator(items[i], mapper));
-            }
-            return result;
-          }
-        }
-      }
-      return items;
-    }
-    function instantiateTypes(types, mapper) {
-      return instantiateList(types, mapper, instantiateType);
-    }
-    function instantiateSignatures(signatures, mapper) {
-      return instantiateList(signatures, mapper, instantiateSignature);
-    }
-    function instantiateIndexInfos(indexInfos, mapper) {
-      return instantiateList(indexInfos, mapper, instantiateIndexInfo);
-    }
-    function createTypeMapper(sources, targets) {
-      return sources.length === 1 ? makeUnaryTypeMapper(sources[0], targets ? targets[0] : anyType) : makeArrayTypeMapper(sources, targets);
-    }
-    function getMappedType(type, mapper) {
-      switch (mapper.kind) {
-        case 0 /* Simple */:
-          return type === mapper.source ? mapper.target : type;
-        case 1 /* Array */: {
-          const sources = mapper.sources;
-          const targets = mapper.targets;
-          for (let i = 0; i < sources.length; i++) {
-            if (type === sources[i]) {
-              return targets ? targets[i] : anyType;
-            }
-          }
-          return type;
-        }
-        case 2 /* Deferred */: {
-          const sources = mapper.sources;
-          const targets = mapper.targets;
-          for (let i = 0; i < sources.length; i++) {
-            if (type === sources[i]) {
-              return targets[i]();
-            }
-          }
-          return type;
-        }
-        case 3 /* Function */:
-          return mapper.func(type);
-        case 4 /* Composite */:
-        case 5 /* Merged */:
-          const t1 = getMappedType(type, mapper.mapper1);
-          return t1 !== type && mapper.kind === 4 /* Composite */ ? instantiateType(t1, mapper.mapper2) : getMappedType(t1, mapper.mapper2);
-      }
-    }
-    function makeUnaryTypeMapper(source, target) {
-      return Debug.attachDebugPrototypeIfDebug({ kind: 0 /* Simple */, source, target });
-    }
-    function makeArrayTypeMapper(sources, targets) {
-      return Debug.attachDebugPrototypeIfDebug({ kind: 1 /* Array */, sources, targets });
-    }
-    function makeFunctionTypeMapper(func, debugInfo) {
-      return Debug.attachDebugPrototypeIfDebug({ kind: 3 /* Function */, func, debugInfo: Debug.isDebugging ? debugInfo : void 0 });
-    }
-    function makeDeferredTypeMapper(sources, targets) {
-      return Debug.attachDebugPrototypeIfDebug({ kind: 2 /* Deferred */, sources, targets });
-    }
-    function makeCompositeTypeMapper(kind, mapper1, mapper2) {
-      return Debug.attachDebugPrototypeIfDebug({ kind, mapper1, mapper2 });
-    }
-    function createTypeEraser(sources) {
-      return createTypeMapper(
-        sources,
-        /*targets*/
-        void 0
-      );
-    }
-    function createBackreferenceMapper(context, index) {
-      const forwardInferences = context.inferences.slice(index);
-      return createTypeMapper(map(forwardInferences, (i) => i.typeParameter), map(forwardInferences, () => unknownType));
-    }
-    function combineTypeMappers(mapper1, mapper2) {
-      return mapper1 ? makeCompositeTypeMapper(4 /* Composite */, mapper1, mapper2) : mapper2;
-    }
-    function mergeTypeMappers(mapper1, mapper2) {
-      return mapper1 ? makeCompositeTypeMapper(5 /* Merged */, mapper1, mapper2) : mapper2;
-    }
-    function prependTypeMapping(source, target, mapper) {
-      return !mapper ? makeUnaryTypeMapper(source, target) : makeCompositeTypeMapper(5 /* Merged */, makeUnaryTypeMapper(source, target), mapper);
-    }
-    function appendTypeMapping(mapper, source, target) {
-      return !mapper ? makeUnaryTypeMapper(source, target) : makeCompositeTypeMapper(5 /* Merged */, mapper, makeUnaryTypeMapper(source, target));
-    }
-    function getRestrictiveTypeParameter(tp) {
-      return !tp.constraint && !getConstraintDeclaration(tp) || tp.constraint === noConstraintType ? tp : tp.restrictiveInstantiation || (tp.restrictiveInstantiation = createTypeParameter(tp.symbol), tp.restrictiveInstantiation.constraint = noConstraintType, tp.restrictiveInstantiation);
-    }
-    function cloneTypeParameter(typeParameter) {
-      const result = createTypeParameter(typeParameter.symbol);
-      result.target = typeParameter;
-      return result;
-    }
-    function instantiateTypePredicate(predicate, mapper) {
-      return createTypePredicate(predicate.kind, predicate.parameterName, predicate.parameterIndex, instantiateType(predicate.type, mapper));
-    }
-    function instantiateSignature(signature, mapper, eraseTypeParameters) {
-      let freshTypeParameters;
-      if (signature.typeParameters && !eraseTypeParameters) {
-        freshTypeParameters = map(signature.typeParameters, cloneTypeParameter);
-        mapper = combineTypeMappers(createTypeMapper(signature.typeParameters, freshTypeParameters), mapper);
-        for (const tp of freshTypeParameters) {
-          tp.mapper = mapper;
-        }
-      }
-      const result = createSignature(
-        signature.declaration,
-        freshTypeParameters,
-        signature.thisParameter && instantiateSymbol(signature.thisParameter, mapper),
-        instantiateList(signature.parameters, mapper, instantiateSymbol),
-        /*resolvedReturnType*/
-        void 0,
-        /*resolvedTypePredicate*/
-        void 0,
-        signature.minArgumentCount,
-        signature.flags & 39 /* PropagatingFlags */
-      );
-      result.target = signature;
-      result.mapper = mapper;
-      return result;
-    }
-    function instantiateSymbol(symbol, mapper) {
-      const links = getSymbolLinks(symbol);
-      if (links.type && !couldContainTypeVariables(links.type)) {
-        return symbol;
-      }
-      if (getCheckFlags(symbol) & 1 /* Instantiated */) {
-        symbol = links.target;
-        mapper = combineTypeMappers(links.mapper, mapper);
-      }
-      const result = createSymbol(symbol.flags, symbol.escapedName, 1 /* Instantiated */ | getCheckFlags(symbol) & (8 /* Readonly */ | 4096 /* Late */ | 16384 /* OptionalParameter */ | 32768 /* RestParameter */));
-      result.declarations = symbol.declarations;
-      result.parent = symbol.parent;
-      result.links.target = symbol;
-      result.links.mapper = mapper;
-      if (symbol.valueDeclaration) {
-        result.valueDeclaration = symbol.valueDeclaration;
-      }
-      if (links.nameType) {
-        result.links.nameType = links.nameType;
-      }
-      return result;
-    }
-    function getObjectTypeInstantiation(type, mapper, aliasSymbol, aliasTypeArguments) {
-      const declaration = type.objectFlags & 4 /* Reference */ ? type.node : type.objectFlags & 8388608 /* InstantiationExpressionType */ ? type.node : type.symbol.declarations[0];
-      const links = getNodeLinks(declaration);
-      const target = type.objectFlags & 4 /* Reference */ ? links.resolvedType : type.objectFlags & 64 /* Instantiated */ ? type.target : type;
-      let typeParameters = links.outerTypeParameters;
-      if (!typeParameters) {
-        let outerTypeParameters = getOuterTypeParameters(
-          declaration,
-          /*includeThisTypes*/
-          true
-        );
-        if (isJSConstructor(declaration)) {
-          const templateTagParameters = getTypeParametersFromDeclaration(declaration);
-          outerTypeParameters = addRange(outerTypeParameters, templateTagParameters);
-        }
-        typeParameters = outerTypeParameters || emptyArray;
-        const allDeclarations = type.objectFlags & (4 /* Reference */ | 8388608 /* InstantiationExpressionType */) ? [declaration] : type.symbol.declarations;
-        typeParameters = (target.objectFlags & (4 /* Reference */ | 8388608 /* InstantiationExpressionType */) || target.symbol.flags & 8192 /* Method */ || target.symbol.flags & 2048 /* TypeLiteral */) && !target.aliasTypeArguments ? filter(typeParameters, (tp) => some(allDeclarations, (d) => isTypeParameterPossiblyReferenced(tp, d))) : typeParameters;
-        links.outerTypeParameters = typeParameters;
-      }
-      if (typeParameters.length) {
-        const combinedMapper = combineTypeMappers(type.mapper, mapper);
-        const typeArguments = map(typeParameters, (t) => getMappedType(t, combinedMapper));
-        const newAliasSymbol = aliasSymbol || type.aliasSymbol;
-        const newAliasTypeArguments = aliasSymbol ? aliasTypeArguments : instantiateTypes(type.aliasTypeArguments, mapper);
-        const id = getTypeListId(typeArguments) + getAliasId(newAliasSymbol, newAliasTypeArguments);
-        if (!target.instantiations) {
-          target.instantiations = /* @__PURE__ */ new Map();
-          target.instantiations.set(getTypeListId(typeParameters) + getAliasId(target.aliasSymbol, target.aliasTypeArguments), target);
-        }
-        let result = target.instantiations.get(id);
-        if (!result) {
-          const newMapper = createTypeMapper(typeParameters, typeArguments);
-          result = target.objectFlags & 4 /* Reference */ ? createDeferredTypeReference(type.target, type.node, newMapper, newAliasSymbol, newAliasTypeArguments) : target.objectFlags & 32 /* Mapped */ ? instantiateMappedType(target, newMapper, newAliasSymbol, newAliasTypeArguments) : instantiateAnonymousType(target, newMapper, newAliasSymbol, newAliasTypeArguments);
-          if (result.flags & 138117121 /* ObjectFlagsType */ && !(result.objectFlags & 524288 /* CouldContainTypeVariablesComputed */)) {
-            const resultCouldContainTypeVariables = some(typeArguments, couldContainTypeVariables);
-            if (!(result.objectFlags & 524288 /* CouldContainTypeVariablesComputed */)) {
-              result.objectFlags |= 524288 /* CouldContainTypeVariablesComputed */ | (resultCouldContainTypeVariables ? 1048576 /* CouldContainTypeVariables */ : 0);
-            }
-          }
-          target.instantiations.set(id, result);
-        }
-        return result;
-      }
-      return type;
-    }
-    function maybeTypeParameterReference(node) {
-      return !(node.parent.kind === 182 /* TypeReference */ && node.parent.typeArguments && node === node.parent.typeName || node.parent.kind === 204 /* ImportType */ && node.parent.typeArguments && node === node.parent.qualifier);
-    }
-    function isTypeParameterPossiblyReferenced(tp, node) {
-      if (tp.symbol && tp.symbol.declarations && tp.symbol.declarations.length === 1) {
-        const container = tp.symbol.declarations[0].parent;
-        for (let n = node; n !== container; n = n.parent) {
-          if (!n || n.kind === 240 /* Block */ || n.kind === 193 /* ConditionalType */ && forEachChild(n.extendsType, containsReference)) {
-            return true;
-          }
-        }
-        return containsReference(node);
-      }
-      return true;
-      function containsReference(node2) {
-        switch (node2.kind) {
-          case 196 /* ThisType */:
-            return !!tp.isThisType;
-          case 80 /* Identifier */:
-            return !tp.isThisType && isPartOfTypeNode(node2) && maybeTypeParameterReference(node2) && getTypeFromTypeNodeWorker(node2) === tp;
-          case 185 /* TypeQuery */:
-            const entityName = node2.exprName;
-            const firstIdentifier = getFirstIdentifier(entityName);
-            if (!isThisIdentifier(firstIdentifier)) {
-              const firstIdentifierSymbol = getResolvedSymbol(firstIdentifier);
-              const tpDeclaration = tp.symbol.declarations[0];
-              const tpScope = tpDeclaration.kind === 167 /* TypeParameter */ ? tpDeclaration.parent : (
-                // Type parameter is a regular type parameter, e.g. foo
-                tp.isThisType ? tpDeclaration : (
-                  // Type parameter is the this type, and its declaration is the class declaration.
-                  void 0
-                )
-              );
-              if (firstIdentifierSymbol.declarations && tpScope) {
-                return some(firstIdentifierSymbol.declarations, (idDecl) => isNodeDescendantOf(idDecl, tpScope)) || some(node2.typeArguments, containsReference);
-              }
-            }
-            return true;
-          case 173 /* MethodDeclaration */:
-          case 172 /* MethodSignature */:
-            return !node2.type && !!node2.body || some(node2.typeParameters, containsReference) || some(node2.parameters, containsReference) || !!node2.type && containsReference(node2.type);
-        }
-        return !!forEachChild(node2, containsReference);
-      }
-    }
-    function getHomomorphicTypeVariable(type) {
-      const constraintType = getConstraintTypeFromMappedType(type);
-      if (constraintType.flags & 4194304 /* Index */) {
-        const typeVariable = getActualTypeVariable(constraintType.type);
-        if (typeVariable.flags & 262144 /* TypeParameter */) {
-          return typeVariable;
-        }
-      }
-      return void 0;
-    }
-    function instantiateMappedType(type, mapper, aliasSymbol, aliasTypeArguments) {
-      const typeVariable = getHomomorphicTypeVariable(type);
-      if (typeVariable) {
-        const mappedTypeVariable = instantiateType(typeVariable, mapper);
-        if (typeVariable !== mappedTypeVariable) {
-          return mapTypeWithAlias(getReducedType(mappedTypeVariable), (t) => {
-            if (t.flags & (3 /* AnyOrUnknown */ | 58982400 /* InstantiableNonPrimitive */ | 524288 /* Object */ | 2097152 /* Intersection */) && t !== wildcardType && !isErrorType(t)) {
-              if (!type.declaration.nameType) {
-                let constraint;
-                if (isArrayType(t) || t.flags & 1 /* Any */ && findResolutionCycleStartIndex(typeVariable, 4 /* ImmediateBaseConstraint */) < 0 && (constraint = getConstraintOfTypeParameter(typeVariable)) && everyType(constraint, isArrayOrTupleType)) {
-                  return instantiateMappedArrayType(t, type, prependTypeMapping(typeVariable, t, mapper));
-                }
-                if (isGenericTupleType(t)) {
-                  return instantiateMappedGenericTupleType(t, type, typeVariable, mapper);
-                }
-                if (isTupleType(t)) {
-                  return instantiateMappedTupleType(t, type, prependTypeMapping(typeVariable, t, mapper));
-                }
-              }
-              return instantiateAnonymousType(type, prependTypeMapping(typeVariable, t, mapper));
-            }
-            return t;
-          }, aliasSymbol, aliasTypeArguments);
-        }
-      }
-      return instantiateType(getConstraintTypeFromMappedType(type), mapper) === wildcardType ? wildcardType : instantiateAnonymousType(type, mapper, aliasSymbol, aliasTypeArguments);
-    }
-    function getModifiedReadonlyState(state, modifiers) {
-      return modifiers & 1 /* IncludeReadonly */ ? true : modifiers & 2 /* ExcludeReadonly */ ? false : state;
-    }
-    function instantiateMappedGenericTupleType(tupleType, mappedType, typeVariable, mapper) {
-      const elementFlags = tupleType.target.elementFlags;
-      const elementTypes = map(getElementTypes(tupleType), (t, i) => {
-        const singleton = elementFlags[i] & 8 /* Variadic */ ? t : elementFlags[i] & 4 /* Rest */ ? createArrayType(t) : createTupleType([t], [elementFlags[i]]);
-        return instantiateMappedType(mappedType, prependTypeMapping(typeVariable, singleton, mapper));
-      });
-      const newReadonly = getModifiedReadonlyState(tupleType.target.readonly, getMappedTypeModifiers(mappedType));
-      return createTupleType(elementTypes, map(elementTypes, (_) => 8 /* Variadic */), newReadonly);
-    }
-    function instantiateMappedArrayType(arrayType, mappedType, mapper) {
-      const elementType = instantiateMappedTypeTemplate(
-        mappedType,
-        numberType,
-        /*isOptional*/
-        true,
-        mapper
-      );
-      return isErrorType(elementType) ? errorType : createArrayType(elementType, getModifiedReadonlyState(isReadonlyArrayType(arrayType), getMappedTypeModifiers(mappedType)));
-    }
-    function instantiateMappedTupleType(tupleType, mappedType, mapper) {
-      const elementFlags = tupleType.target.elementFlags;
-      const elementTypes = map(getElementTypes(tupleType), (_, i) => instantiateMappedTypeTemplate(mappedType, getStringLiteralType("" + i), !!(elementFlags[i] & 2 /* Optional */), mapper));
-      const modifiers = getMappedTypeModifiers(mappedType);
-      const newTupleModifiers = modifiers & 4 /* IncludeOptional */ ? map(elementFlags, (f) => f & 1 /* Required */ ? 2 /* Optional */ : f) : modifiers & 8 /* ExcludeOptional */ ? map(elementFlags, (f) => f & 2 /* Optional */ ? 1 /* Required */ : f) : elementFlags;
-      const newReadonly = getModifiedReadonlyState(tupleType.target.readonly, modifiers);
-      return contains(elementTypes, errorType) ? errorType : createTupleType(elementTypes, newTupleModifiers, newReadonly, tupleType.target.labeledElementDeclarations);
-    }
-    function instantiateMappedTypeTemplate(type, key, isOptional, mapper) {
-      const templateMapper = appendTypeMapping(mapper, getTypeParameterFromMappedType(type), key);
-      const propType = instantiateType(getTemplateTypeFromMappedType(type.target || type), templateMapper);
-      const modifiers = getMappedTypeModifiers(type);
-      return strictNullChecks && modifiers & 4 /* IncludeOptional */ && !maybeTypeOfKind(propType, 32768 /* Undefined */ | 16384 /* Void */) ? getOptionalType(
-        propType,
-        /*isProperty*/
-        true
-      ) : strictNullChecks && modifiers & 8 /* ExcludeOptional */ && isOptional ? getTypeWithFacts(propType, 524288 /* NEUndefined */) : propType;
-    }
-    function instantiateAnonymousType(type, mapper, aliasSymbol, aliasTypeArguments) {
-      const result = createObjectType(type.objectFlags & ~(524288 /* CouldContainTypeVariablesComputed */ | 1048576 /* CouldContainTypeVariables */) | 64 /* Instantiated */, type.symbol);
-      if (type.objectFlags & 32 /* Mapped */) {
-        result.declaration = type.declaration;
-        const origTypeParameter = getTypeParameterFromMappedType(type);
-        const freshTypeParameter = cloneTypeParameter(origTypeParameter);
-        result.typeParameter = freshTypeParameter;
-        mapper = combineTypeMappers(makeUnaryTypeMapper(origTypeParameter, freshTypeParameter), mapper);
-        freshTypeParameter.mapper = mapper;
-      }
-      if (type.objectFlags & 8388608 /* InstantiationExpressionType */) {
-        result.node = type.node;
-      }
-      result.target = type;
-      result.mapper = mapper;
-      result.aliasSymbol = aliasSymbol || type.aliasSymbol;
-      result.aliasTypeArguments = aliasSymbol ? aliasTypeArguments : instantiateTypes(type.aliasTypeArguments, mapper);
-      result.objectFlags |= result.aliasTypeArguments ? getPropagatingFlagsOfTypes(result.aliasTypeArguments) : 0;
-      return result;
-    }
-    function getConditionalTypeInstantiation(type, mapper, aliasSymbol, aliasTypeArguments) {
-      const root = type.root;
-      if (root.outerTypeParameters) {
-        const typeArguments = map(root.outerTypeParameters, (t) => getMappedType(t, mapper));
-        const id = getTypeListId(typeArguments) + getAliasId(aliasSymbol, aliasTypeArguments);
-        let result = root.instantiations.get(id);
-        if (!result) {
-          const newMapper = createTypeMapper(root.outerTypeParameters, typeArguments);
-          const checkType = root.checkType;
-          const distributionType = root.isDistributive ? getMappedType(checkType, newMapper) : void 0;
-          result = distributionType && checkType !== distributionType && distributionType.flags & (1048576 /* Union */ | 131072 /* Never */) ? mapTypeWithAlias(getReducedType(distributionType), (t) => getConditionalType(root, prependTypeMapping(checkType, t, newMapper)), aliasSymbol, aliasTypeArguments) : getConditionalType(root, newMapper, aliasSymbol, aliasTypeArguments);
-          root.instantiations.set(id, result);
-        }
-        return result;
-      }
-      return type;
-    }
-    function instantiateType(type, mapper) {
-      return type && mapper ? instantiateTypeWithAlias(
-        type,
-        mapper,
-        /*aliasSymbol*/
-        void 0,
-        /*aliasTypeArguments*/
-        void 0
-      ) : type;
-    }
-    function instantiateTypeWithAlias(type, mapper, aliasSymbol, aliasTypeArguments) {
-      var _a;
-      if (!couldContainTypeVariables(type)) {
-        return type;
-      }
-      if (instantiationDepth === 100 || instantiationCount >= 5e6) {
-        (_a = tracing) == null ? void 0 : _a.instant(tracing.Phase.CheckTypes, "instantiateType_DepthLimit", { typeId: type.id, instantiationDepth, instantiationCount });
-        error(currentNode, Diagnostics.Type_instantiation_is_excessively_deep_and_possibly_infinite);
-        return errorType;
-      }
-      totalInstantiationCount++;
-      instantiationCount++;
-      instantiationDepth++;
-      const result = instantiateTypeWorker(type, mapper, aliasSymbol, aliasTypeArguments);
-      instantiationDepth--;
-      return result;
-    }
-    function instantiateTypeWorker(type, mapper, aliasSymbol, aliasTypeArguments) {
-      const flags = type.flags;
-      if (flags & 262144 /* TypeParameter */) {
-        return getMappedType(type, mapper);
-      }
-      if (flags & 524288 /* Object */) {
-        const objectFlags = type.objectFlags;
-        if (objectFlags & (4 /* Reference */ | 16 /* Anonymous */ | 32 /* Mapped */)) {
-          if (objectFlags & 4 /* Reference */ && !type.node) {
-            const resolvedTypeArguments = type.resolvedTypeArguments;
-            const newTypeArguments = instantiateTypes(resolvedTypeArguments, mapper);
-            return newTypeArguments !== resolvedTypeArguments ? createNormalizedTypeReference(type.target, newTypeArguments) : type;
-          }
-          if (objectFlags & 1024 /* ReverseMapped */) {
-            return instantiateReverseMappedType(type, mapper);
-          }
-          return getObjectTypeInstantiation(type, mapper, aliasSymbol, aliasTypeArguments);
-        }
-        return type;
-      }
-      if (flags & 3145728 /* UnionOrIntersection */) {
-        const origin = type.flags & 1048576 /* Union */ ? type.origin : void 0;
-        const types = origin && origin.flags & 3145728 /* UnionOrIntersection */ ? origin.types : type.types;
-        const newTypes = instantiateTypes(types, mapper);
-        if (newTypes === types && aliasSymbol === type.aliasSymbol) {
-          return type;
-        }
-        const newAliasSymbol = aliasSymbol || type.aliasSymbol;
-        const newAliasTypeArguments = aliasSymbol ? aliasTypeArguments : instantiateTypes(type.aliasTypeArguments, mapper);
-        return flags & 2097152 /* Intersection */ || origin && origin.flags & 2097152 /* Intersection */ ? getIntersectionType(newTypes, newAliasSymbol, newAliasTypeArguments) : getUnionType(newTypes, 1 /* Literal */, newAliasSymbol, newAliasTypeArguments);
-      }
-      if (flags & 4194304 /* Index */) {
-        return getIndexType(instantiateType(type.type, mapper));
-      }
-      if (flags & 134217728 /* TemplateLiteral */) {
-        return getTemplateLiteralType(type.texts, instantiateTypes(type.types, mapper));
-      }
-      if (flags & 268435456 /* StringMapping */) {
-        return getStringMappingType(type.symbol, instantiateType(type.type, mapper));
-      }
-      if (flags & 8388608 /* IndexedAccess */) {
-        const newAliasSymbol = aliasSymbol || type.aliasSymbol;
-        const newAliasTypeArguments = aliasSymbol ? aliasTypeArguments : instantiateTypes(type.aliasTypeArguments, mapper);
-        return getIndexedAccessType(
-          instantiateType(type.objectType, mapper),
-          instantiateType(type.indexType, mapper),
-          type.accessFlags,
-          /*accessNode*/
-          void 0,
-          newAliasSymbol,
-          newAliasTypeArguments
-        );
-      }
-      if (flags & 16777216 /* Conditional */) {
-        return getConditionalTypeInstantiation(type, combineTypeMappers(type.mapper, mapper), aliasSymbol, aliasTypeArguments);
-      }
-      if (flags & 33554432 /* Substitution */) {
-        const newBaseType = instantiateType(type.baseType, mapper);
-        const newConstraint = instantiateType(type.constraint, mapper);
-        if (newBaseType.flags & 8650752 /* TypeVariable */ && isGenericType(newConstraint)) {
-          return getSubstitutionType(newBaseType, newConstraint);
-        }
-        if (newConstraint.flags & 3 /* AnyOrUnknown */ || isTypeAssignableTo(getRestrictiveInstantiation(newBaseType), getRestrictiveInstantiation(newConstraint))) {
-          return newBaseType;
-        }
-        return newBaseType.flags & 8650752 /* TypeVariable */ ? getSubstitutionType(newBaseType, newConstraint) : getIntersectionType([newConstraint, newBaseType]);
-      }
-      return type;
-    }
-    function instantiateReverseMappedType(type, mapper) {
-      const innerMappedType = instantiateType(type.mappedType, mapper);
-      if (!(getObjectFlags(innerMappedType) & 32 /* Mapped */)) {
-        return type;
-      }
-      const innerIndexType = instantiateType(type.constraintType, mapper);
-      if (!(innerIndexType.flags & 4194304 /* Index */)) {
-        return type;
-      }
-      const instantiated = inferTypeForHomomorphicMappedType(
-        instantiateType(type.source, mapper),
-        innerMappedType,
-        innerIndexType
-      );
-      if (instantiated) {
-        return instantiated;
-      }
-      return type;
-    }
-    function getPermissiveInstantiation(type) {
-      return type.flags & (402784252 /* Primitive */ | 3 /* AnyOrUnknown */ | 131072 /* Never */) ? type : type.permissiveInstantiation || (type.permissiveInstantiation = instantiateType(type, permissiveMapper));
-    }
-    function getRestrictiveInstantiation(type) {
-      if (type.flags & (402784252 /* Primitive */ | 3 /* AnyOrUnknown */ | 131072 /* Never */)) {
-        return type;
-      }
-      if (type.restrictiveInstantiation) {
-        return type.restrictiveInstantiation;
-      }
-      type.restrictiveInstantiation = instantiateType(type, restrictiveMapper);
-      type.restrictiveInstantiation.restrictiveInstantiation = type.restrictiveInstantiation;
-      return type.restrictiveInstantiation;
-    }
-    function instantiateIndexInfo(info, mapper) {
-      return createIndexInfo(info.keyType, instantiateType(info.type, mapper), info.isReadonly, info.declaration);
-    }
-    function isContextSensitive(node) {
-      Debug.assert(node.kind !== 173 /* MethodDeclaration */ || isObjectLiteralMethod(node));
-      switch (node.kind) {
-        case 217 /* FunctionExpression */:
-        case 218 /* ArrowFunction */:
-        case 173 /* MethodDeclaration */:
-        case 261 /* FunctionDeclaration */:
-          return isContextSensitiveFunctionLikeDeclaration(node);
-        case 209 /* ObjectLiteralExpression */:
-          return some(node.properties, isContextSensitive);
-        case 208 /* ArrayLiteralExpression */:
-          return some(node.elements, isContextSensitive);
-        case 226 /* ConditionalExpression */:
-          return isContextSensitive(node.whenTrue) || isContextSensitive(node.whenFalse);
-        case 225 /* BinaryExpression */:
-          return (node.operatorToken.kind === 57 /* BarBarToken */ || node.operatorToken.kind === 61 /* QuestionQuestionToken */) && (isContextSensitive(node.left) || isContextSensitive(node.right));
-        case 302 /* PropertyAssignment */:
-          return isContextSensitive(node.initializer);
-        case 216 /* ParenthesizedExpression */:
-          return isContextSensitive(node.expression);
-        case 291 /* JsxAttributes */:
-          return some(node.properties, isContextSensitive) || isJsxOpeningElement(node.parent) && some(node.parent.parent.children, isContextSensitive);
-        case 290 /* JsxAttribute */: {
-          const { initializer } = node;
-          return !!initializer && isContextSensitive(initializer);
-        }
-        case 293 /* JsxExpression */: {
-          const { expression } = node;
-          return !!expression && isContextSensitive(expression);
-        }
-      }
-      return false;
-    }
-    function isContextSensitiveFunctionLikeDeclaration(node) {
-      return hasContextSensitiveParameters(node) || hasContextSensitiveReturnExpression(node);
-    }
-    function hasContextSensitiveReturnExpression(node) {
-      if (node.typeParameters || getEffectiveReturnTypeNode(node) || !node.body) {
-        return false;
-      }
-      if (node.body.kind !== 240 /* Block */) {
-        return isContextSensitive(node.body);
-      }
-      return !!forEachReturnStatement(node.body, (statement) => !!statement.expression && isContextSensitive(statement.expression));
-    }
-    function isContextSensitiveFunctionOrObjectLiteralMethod(func) {
-      return (isFunctionExpressionOrArrowFunction(func) || isObjectLiteralMethod(func)) && isContextSensitiveFunctionLikeDeclaration(func);
-    }
-    function getTypeWithoutSignatures(type) {
-      if (type.flags & 524288 /* Object */) {
-        const resolved = resolveStructuredTypeMembers(type);
-        if (resolved.constructSignatures.length || resolved.callSignatures.length) {
-          const result = createObjectType(16 /* Anonymous */, type.symbol);
-          result.members = resolved.members;
-          result.properties = resolved.properties;
-          result.callSignatures = emptyArray;
-          result.constructSignatures = emptyArray;
-          result.indexInfos = emptyArray;
-          return result;
-        }
-      } else if (type.flags & 2097152 /* Intersection */) {
-        return getIntersectionType(map(type.types, getTypeWithoutSignatures));
-      }
-      return type;
-    }
-    function isTypeIdenticalTo(source, target) {
-      return isTypeRelatedTo(source, target, identityRelation);
-    }
-    function compareTypesIdentical(source, target) {
-      return isTypeRelatedTo(source, target, identityRelation) ? -1 /* True */ : 0 /* False */;
-    }
-    function compareTypesAssignable(source, target) {
-      return isTypeRelatedTo(source, target, assignableRelation) ? -1 /* True */ : 0 /* False */;
-    }
-    function compareTypesSubtypeOf(source, target) {
-      return isTypeRelatedTo(source, target, subtypeRelation) ? -1 /* True */ : 0 /* False */;
-    }
-    function isTypeSubtypeOf(source, target) {
-      return isTypeRelatedTo(source, target, subtypeRelation);
-    }
-    function isTypeStrictSubtypeOf(source, target) {
-      return isTypeRelatedTo(source, target, strictSubtypeRelation);
-    }
-    function isTypeAssignableTo(source, target) {
-      return isTypeRelatedTo(source, target, assignableRelation);
-    }
-    function isTypeDerivedFrom(source, target) {
-      return source.flags & 1048576 /* Union */ ? every(source.types, (t) => isTypeDerivedFrom(t, target)) : target.flags & 1048576 /* Union */ ? some(target.types, (t) => isTypeDerivedFrom(source, t)) : source.flags & 2097152 /* Intersection */ ? some(source.types, (t) => isTypeDerivedFrom(t, target)) : source.flags & 58982400 /* InstantiableNonPrimitive */ ? isTypeDerivedFrom(getBaseConstraintOfType(source) || unknownType, target) : isEmptyAnonymousObjectType(target) ? !!(source.flags & (524288 /* Object */ | 67108864 /* NonPrimitive */)) : target === globalObjectType ? !!(source.flags & (524288 /* Object */ | 67108864 /* NonPrimitive */)) && !isEmptyAnonymousObjectType(source) : target === globalFunctionType ? !!(source.flags & 524288 /* Object */) && isFunctionObjectType(source) : hasBaseType(source, getTargetType(target)) || isArrayType(target) && !isReadonlyArrayType(target) && isTypeDerivedFrom(source, globalReadonlyArrayType);
-    }
-    function isTypeComparableTo(source, target) {
-      return isTypeRelatedTo(source, target, comparableRelation);
-    }
-    function areTypesComparable(type1, type2) {
-      return isTypeComparableTo(type1, type2) || isTypeComparableTo(type2, type1);
-    }
-    function checkTypeAssignableTo(source, target, errorNode, headMessage, containingMessageChain, errorOutputObject) {
-      return checkTypeRelatedTo(source, target, assignableRelation, errorNode, headMessage, containingMessageChain, errorOutputObject);
-    }
-    function checkTypeAssignableToAndOptionallyElaborate(source, target, errorNode, expr, headMessage, containingMessageChain) {
-      return checkTypeRelatedToAndOptionallyElaborate(
-        source,
-        target,
-        assignableRelation,
-        errorNode,
-        expr,
-        headMessage,
-        containingMessageChain,
-        /*errorOutputContainer*/
-        void 0
-      );
-    }
-    function checkTypeRelatedToAndOptionallyElaborate(source, target, relation, errorNode, expr, headMessage, containingMessageChain, errorOutputContainer) {
-      if (isTypeRelatedTo(source, target, relation))
-        return true;
-      if (!errorNode || !elaborateError(expr, source, target, relation, headMessage, containingMessageChain, errorOutputContainer)) {
-        return checkTypeRelatedTo(source, target, relation, errorNode, headMessage, containingMessageChain, errorOutputContainer);
-      }
-      return false;
-    }
-    function isOrHasGenericConditional(type) {
-      return !!(type.flags & 16777216 /* Conditional */ || type.flags & 2097152 /* Intersection */ && some(type.types, isOrHasGenericConditional));
-    }
-    function elaborateError(node, source, target, relation, headMessage, containingMessageChain, errorOutputContainer) {
-      if (!node || isOrHasGenericConditional(target))
-        return false;
-      if (!checkTypeRelatedTo(
-        source,
-        target,
-        relation,
-        /*errorNode*/
-        void 0
-      ) && elaborateDidYouMeanToCallOrConstruct(node, source, target, relation, headMessage, containingMessageChain, errorOutputContainer)) {
-        return true;
-      }
-      switch (node.kind) {
-        case 293 /* JsxExpression */:
-        case 216 /* ParenthesizedExpression */:
-          return elaborateError(node.expression, source, target, relation, headMessage, containingMessageChain, errorOutputContainer);
-        case 225 /* BinaryExpression */:
-          switch (node.operatorToken.kind) {
-            case 64 /* EqualsToken */:
-            case 28 /* CommaToken */:
-              return elaborateError(node.right, source, target, relation, headMessage, containingMessageChain, errorOutputContainer);
-          }
-          break;
-        case 209 /* ObjectLiteralExpression */:
-          return elaborateObjectLiteral(node, source, target, relation, containingMessageChain, errorOutputContainer);
-        case 208 /* ArrayLiteralExpression */:
-          return elaborateArrayLiteral(node, source, target, relation, containingMessageChain, errorOutputContainer);
-        case 291 /* JsxAttributes */:
-          return elaborateJsxComponents(node, source, target, relation, containingMessageChain, errorOutputContainer);
-        case 218 /* ArrowFunction */:
-          return elaborateArrowFunction(node, source, target, relation, containingMessageChain, errorOutputContainer);
-      }
-      return false;
-    }
-    function elaborateDidYouMeanToCallOrConstruct(node, source, target, relation, headMessage, containingMessageChain, errorOutputContainer) {
-      const callSignatures = getSignaturesOfType(source, 0 /* Call */);
-      const constructSignatures = getSignaturesOfType(source, 1 /* Construct */);
-      for (const signatures of [constructSignatures, callSignatures]) {
-        if (some(signatures, (s) => {
-          const returnType = getReturnTypeOfSignature(s);
-          return !(returnType.flags & (1 /* Any */ | 131072 /* Never */)) && checkTypeRelatedTo(
-            returnType,
-            target,
-            relation,
-            /*errorNode*/
-            void 0
-          );
-        })) {
-          const resultObj = errorOutputContainer || {};
-          checkTypeAssignableTo(source, target, node, headMessage, containingMessageChain, resultObj);
-          const diagnostic = resultObj.errors[resultObj.errors.length - 1];
-          addRelatedInfo(diagnostic, createDiagnosticForNode(
-            node,
-            signatures === constructSignatures ? Diagnostics.Did_you_mean_to_use_new_with_this_expression : Diagnostics.Did_you_mean_to_call_this_expression
-          ));
-          return true;
-        }
-      }
-      return false;
-    }
-    function elaborateArrowFunction(node, source, target, relation, containingMessageChain, errorOutputContainer) {
-      if (isBlock(node.body)) {
-        return false;
-      }
-      if (some(node.parameters, hasType)) {
-        return false;
-      }
-      const sourceSig = getSingleCallSignature(source);
-      if (!sourceSig) {
-        return false;
-      }
-      const targetSignatures = getSignaturesOfType(target, 0 /* Call */);
-      if (!length(targetSignatures)) {
-        return false;
-      }
-      const returnExpression = node.body;
-      const sourceReturn = getReturnTypeOfSignature(sourceSig);
-      const targetReturn = getUnionType(map(targetSignatures, getReturnTypeOfSignature));
-      if (!checkTypeRelatedTo(
-        sourceReturn,
-        targetReturn,
-        relation,
-        /*errorNode*/
-        void 0
-      )) {
-        const elaborated = returnExpression && elaborateError(
-          returnExpression,
-          sourceReturn,
-          targetReturn,
-          relation,
-          /*headMessage*/
-          void 0,
-          containingMessageChain,
-          errorOutputContainer
-        );
-        if (elaborated) {
-          return elaborated;
-        }
-        const resultObj = errorOutputContainer || {};
-        checkTypeRelatedTo(
-          sourceReturn,
-          targetReturn,
-          relation,
-          returnExpression,
-          /*headMessage*/
-          void 0,
-          containingMessageChain,
-          resultObj
-        );
-        if (resultObj.errors) {
-          if (target.symbol && length(target.symbol.declarations)) {
-            addRelatedInfo(resultObj.errors[resultObj.errors.length - 1], createDiagnosticForNode(
-              target.symbol.declarations[0],
-              Diagnostics.The_expected_type_comes_from_the_return_type_of_this_signature
-            ));
-          }
-          if ((getFunctionFlags(node) & 2 /* Async */) === 0 && !getTypeOfPropertyOfType(sourceReturn, "then") && checkTypeRelatedTo(
-            createPromiseType(sourceReturn),
-            targetReturn,
-            relation,
-            /*errorNode*/
-            void 0
-          )) {
-            addRelatedInfo(resultObj.errors[resultObj.errors.length - 1], createDiagnosticForNode(
-              node,
-              Diagnostics.Did_you_mean_to_mark_this_function_as_async
-            ));
-          }
-          return true;
-        }
-      }
-      return false;
-    }
-    function getBestMatchIndexedAccessTypeOrUndefined(source, target, nameType) {
-      const idx = getIndexedAccessTypeOrUndefined(target, nameType);
-      if (idx) {
-        return idx;
-      }
-      if (target.flags & 1048576 /* Union */) {
-        const best = getBestMatchingType(source, target);
-        if (best) {
-          return getIndexedAccessTypeOrUndefined(best, nameType);
-        }
-      }
-    }
-    function checkExpressionForMutableLocationWithContextualType(next, sourcePropType) {
-      pushContextualType(
-        next,
-        sourcePropType,
-        /*isCache*/
-        false
-      );
-      const result = checkExpressionForMutableLocation(next, 1 /* Contextual */);
-      popContextualType();
-      return result;
-    }
-    function elaborateElementwise(iterator, source, target, relation, containingMessageChain, errorOutputContainer) {
-      let reportedError = false;
-      for (const value of iterator) {
-        const { errorNode: prop, innerExpression: next, nameType, errorMessage } = value;
-        let targetPropType = getBestMatchIndexedAccessTypeOrUndefined(source, target, nameType);
-        if (!targetPropType || targetPropType.flags & 8388608 /* IndexedAccess */)
-          continue;
-        let sourcePropType = getIndexedAccessTypeOrUndefined(source, nameType);
-        if (!sourcePropType)
-          continue;
-        const propName = getPropertyNameFromIndex(
-          nameType,
-          /*accessNode*/
-          void 0
-        );
-        if (!checkTypeRelatedTo(
-          sourcePropType,
-          targetPropType,
-          relation,
-          /*errorNode*/
-          void 0
-        )) {
-          const elaborated = next && elaborateError(
-            next,
-            sourcePropType,
-            targetPropType,
-            relation,
-            /*headMessage*/
-            void 0,
-            containingMessageChain,
-            errorOutputContainer
-          );
-          reportedError = true;
-          if (!elaborated) {
-            const resultObj = errorOutputContainer || {};
-            const specificSource = next ? checkExpressionForMutableLocationWithContextualType(next, sourcePropType) : sourcePropType;
-            if (exactOptionalPropertyTypes && isExactOptionalPropertyMismatch(specificSource, targetPropType)) {
-              const diag2 = createDiagnosticForNode(prop, Diagnostics.Type_0_is_not_assignable_to_type_1_with_exactOptionalPropertyTypes_Colon_true_Consider_adding_undefined_to_the_type_of_the_target, typeToString(specificSource), typeToString(targetPropType));
-              diagnostics.add(diag2);
-              resultObj.errors = [diag2];
-            } else {
-              const targetIsOptional = !!(propName && (getPropertyOfType(target, propName) || unknownSymbol).flags & 16777216 /* Optional */);
-              const sourceIsOptional = !!(propName && (getPropertyOfType(source, propName) || unknownSymbol).flags & 16777216 /* Optional */);
-              targetPropType = removeMissingType(targetPropType, targetIsOptional);
-              sourcePropType = removeMissingType(sourcePropType, targetIsOptional && sourceIsOptional);
-              const result = checkTypeRelatedTo(specificSource, targetPropType, relation, prop, errorMessage, containingMessageChain, resultObj);
-              if (result && specificSource !== sourcePropType) {
-                checkTypeRelatedTo(sourcePropType, targetPropType, relation, prop, errorMessage, containingMessageChain, resultObj);
-              }
-            }
-            if (resultObj.errors) {
-              const reportedDiag = resultObj.errors[resultObj.errors.length - 1];
-              const propertyName = isTypeUsableAsPropertyName(nameType) ? getPropertyNameFromType(nameType) : void 0;
-              const targetProp = propertyName !== void 0 ? getPropertyOfType(target, propertyName) : void 0;
-              let issuedElaboration = false;
-              if (!targetProp) {
-                const indexInfo = getApplicableIndexInfo(target, nameType);
-                if (indexInfo && indexInfo.declaration && !getSourceFileOfNode(indexInfo.declaration).hasNoDefaultLib) {
-                  issuedElaboration = true;
-                  addRelatedInfo(reportedDiag, createDiagnosticForNode(indexInfo.declaration, Diagnostics.The_expected_type_comes_from_this_index_signature));
-                }
-              }
-              if (!issuedElaboration && (targetProp && length(targetProp.declarations) || target.symbol && length(target.symbol.declarations))) {
-                const targetNode = targetProp && length(targetProp.declarations) ? targetProp.declarations[0] : target.symbol.declarations[0];
-                if (!getSourceFileOfNode(targetNode).hasNoDefaultLib) {
-                  addRelatedInfo(reportedDiag, createDiagnosticForNode(
-                    targetNode,
-                    Diagnostics.The_expected_type_comes_from_property_0_which_is_declared_here_on_type_1,
-                    propertyName && !(nameType.flags & 8192 /* UniqueESSymbol */) ? unescapeLeadingUnderscores(propertyName) : typeToString(nameType),
-                    typeToString(target)
-                  ));
-                }
-              }
-            }
-          }
-        }
-      }
-      return reportedError;
-    }
-    function elaborateIterableOrArrayLikeTargetElementwise(iterator, source, target, relation, containingMessageChain, errorOutputContainer) {
-      const tupleOrArrayLikeTargetParts = filterType(target, isArrayOrTupleLikeType);
-      const nonTupleOrArrayLikeTargetParts = filterType(target, (t) => !isArrayOrTupleLikeType(t));
-      const iterationType = nonTupleOrArrayLikeTargetParts !== neverType ? getIterationTypeOfIterable(
-        13 /* ForOf */,
-        0 /* Yield */,
-        nonTupleOrArrayLikeTargetParts,
-        /*errorNode*/
-        void 0
-      ) : void 0;
-      let reportedError = false;
-      for (let status = iterator.next(); !status.done; status = iterator.next()) {
-        const { errorNode: prop, innerExpression: next, nameType, errorMessage } = status.value;
-        let targetPropType = iterationType;
-        const targetIndexedPropType = tupleOrArrayLikeTargetParts !== neverType ? getBestMatchIndexedAccessTypeOrUndefined(source, tupleOrArrayLikeTargetParts, nameType) : void 0;
-        if (targetIndexedPropType && !(targetIndexedPropType.flags & 8388608 /* IndexedAccess */)) {
-          targetPropType = iterationType ? getUnionType([iterationType, targetIndexedPropType]) : targetIndexedPropType;
-        }
-        if (!targetPropType)
-          continue;
-        let sourcePropType = getIndexedAccessTypeOrUndefined(source, nameType);
-        if (!sourcePropType)
-          continue;
-        const propName = getPropertyNameFromIndex(
-          nameType,
-          /*accessNode*/
-          void 0
-        );
-        if (!checkTypeRelatedTo(
-          sourcePropType,
-          targetPropType,
-          relation,
-          /*errorNode*/
-          void 0
-        )) {
-          const elaborated = next && elaborateError(
-            next,
-            sourcePropType,
-            targetPropType,
-            relation,
-            /*headMessage*/
-            void 0,
-            containingMessageChain,
-            errorOutputContainer
-          );
-          reportedError = true;
-          if (!elaborated) {
-            const resultObj = errorOutputContainer || {};
-            const specificSource = next ? checkExpressionForMutableLocationWithContextualType(next, sourcePropType) : sourcePropType;
-            if (exactOptionalPropertyTypes && isExactOptionalPropertyMismatch(specificSource, targetPropType)) {
-              const diag2 = createDiagnosticForNode(prop, Diagnostics.Type_0_is_not_assignable_to_type_1_with_exactOptionalPropertyTypes_Colon_true_Consider_adding_undefined_to_the_type_of_the_target, typeToString(specificSource), typeToString(targetPropType));
-              diagnostics.add(diag2);
-              resultObj.errors = [diag2];
-            } else {
-              const targetIsOptional = !!(propName && (getPropertyOfType(tupleOrArrayLikeTargetParts, propName) || unknownSymbol).flags & 16777216 /* Optional */);
-              const sourceIsOptional = !!(propName && (getPropertyOfType(source, propName) || unknownSymbol).flags & 16777216 /* Optional */);
-              targetPropType = removeMissingType(targetPropType, targetIsOptional);
-              sourcePropType = removeMissingType(sourcePropType, targetIsOptional && sourceIsOptional);
-              const result = checkTypeRelatedTo(specificSource, targetPropType, relation, prop, errorMessage, containingMessageChain, resultObj);
-              if (result && specificSource !== sourcePropType) {
-                checkTypeRelatedTo(sourcePropType, targetPropType, relation, prop, errorMessage, containingMessageChain, resultObj);
-              }
-            }
-          }
-        }
-      }
-      return reportedError;
-    }
-    function* generateJsxAttributes(node) {
-      if (!length(node.properties))
-        return;
-      for (const prop of node.properties) {
-        if (isJsxSpreadAttribute(prop) || isHyphenatedJsxName(getTextOfJsxAttributeName(prop.name)))
-          continue;
-        yield { errorNode: prop.name, innerExpression: prop.initializer, nameType: getStringLiteralType(getTextOfJsxAttributeName(prop.name)) };
-      }
-    }
-    function* generateJsxChildren(node, getInvalidTextDiagnostic) {
-      if (!length(node.children))
-        return;
-      let memberOffset = 0;
-      for (let i = 0; i < node.children.length; i++) {
-        const child = node.children[i];
-        const nameType = getNumberLiteralType(i - memberOffset);
-        const elem = getElaborationElementForJsxChild(child, nameType, getInvalidTextDiagnostic);
-        if (elem) {
-          yield elem;
-        } else {
-          memberOffset++;
-        }
-      }
-    }
-    function getElaborationElementForJsxChild(child, nameType, getInvalidTextDiagnostic) {
-      switch (child.kind) {
-        case 293 /* JsxExpression */:
-          return { errorNode: child, innerExpression: child.expression, nameType };
-        case 12 /* JsxText */:
-          if (child.containsOnlyTriviaWhiteSpaces) {
-            break;
-          }
-          return { errorNode: child, innerExpression: void 0, nameType, errorMessage: getInvalidTextDiagnostic() };
-        case 283 /* JsxElement */:
-        case 284 /* JsxSelfClosingElement */:
-        case 287 /* JsxFragment */:
-          return { errorNode: child, innerExpression: child, nameType };
-        default:
-          return Debug.assertNever(child, "Found invalid jsx child");
-      }
-    }
-    function elaborateJsxComponents(node, source, target, relation, containingMessageChain, errorOutputContainer) {
-      let result = elaborateElementwise(generateJsxAttributes(node), source, target, relation, containingMessageChain, errorOutputContainer);
-      let invalidTextDiagnostic;
-      if (isJsxOpeningElement(node.parent) && isJsxElement(node.parent.parent)) {
-        const containingElement = node.parent.parent;
-        const childPropName = getJsxElementChildrenPropertyName(getJsxNamespaceAt(node));
-        const childrenPropName = childPropName === void 0 ? "children" : unescapeLeadingUnderscores(childPropName);
-        const childrenNameType = getStringLiteralType(childrenPropName);
-        const childrenTargetType = getIndexedAccessType(target, childrenNameType);
-        const validChildren = getSemanticJsxChildren(containingElement.children);
-        if (!length(validChildren)) {
-          return result;
-        }
-        const moreThanOneRealChildren = length(validChildren) > 1;
-        let arrayLikeTargetParts;
-        let nonArrayLikeTargetParts;
-        const iterableType = getGlobalIterableType(
-          /*reportErrors*/
-          false
-        );
-        if (iterableType !== emptyGenericType) {
-          const anyIterable = createIterableType(anyType);
-          arrayLikeTargetParts = filterType(childrenTargetType, (t) => isTypeAssignableTo(t, anyIterable));
-          nonArrayLikeTargetParts = filterType(childrenTargetType, (t) => !isTypeAssignableTo(t, anyIterable));
-        } else {
-          arrayLikeTargetParts = filterType(childrenTargetType, isArrayOrTupleLikeType);
-          nonArrayLikeTargetParts = filterType(childrenTargetType, (t) => !isArrayOrTupleLikeType(t));
-        }
-        if (moreThanOneRealChildren) {
-          if (arrayLikeTargetParts !== neverType) {
-            const realSource = createTupleType(checkJsxChildren(containingElement, 0 /* Normal */));
-            const children = generateJsxChildren(containingElement, getInvalidTextualChildDiagnostic);
-            result = elaborateIterableOrArrayLikeTargetElementwise(children, realSource, arrayLikeTargetParts, relation, containingMessageChain, errorOutputContainer) || result;
-          } else if (!isTypeRelatedTo(getIndexedAccessType(source, childrenNameType), childrenTargetType, relation)) {
-            result = true;
-            const diag2 = error(
-              containingElement.openingElement.tagName,
-              Diagnostics.This_JSX_tag_s_0_prop_expects_a_single_child_of_type_1_but_multiple_children_were_provided,
-              childrenPropName,
-              typeToString(childrenTargetType)
-            );
-            if (errorOutputContainer && errorOutputContainer.skipLogging) {
-              (errorOutputContainer.errors || (errorOutputContainer.errors = [])).push(diag2);
-            }
-          }
-        } else {
-          if (nonArrayLikeTargetParts !== neverType) {
-            const child = validChildren[0];
-            const elem = getElaborationElementForJsxChild(child, childrenNameType, getInvalidTextualChildDiagnostic);
-            if (elem) {
-              result = elaborateElementwise(
-                function* () {
-                  yield elem;
-                }(),
-                source,
-                target,
-                relation,
-                containingMessageChain,
-                errorOutputContainer
-              ) || result;
-            }
-          } else if (!isTypeRelatedTo(getIndexedAccessType(source, childrenNameType), childrenTargetType, relation)) {
-            result = true;
-            const diag2 = error(
-              containingElement.openingElement.tagName,
-              Diagnostics.This_JSX_tag_s_0_prop_expects_type_1_which_requires_multiple_children_but_only_a_single_child_was_provided,
-              childrenPropName,
-              typeToString(childrenTargetType)
-            );
-            if (errorOutputContainer && errorOutputContainer.skipLogging) {
-              (errorOutputContainer.errors || (errorOutputContainer.errors = [])).push(diag2);
-            }
-          }
-        }
-      }
-      return result;
-      function getInvalidTextualChildDiagnostic() {
-        if (!invalidTextDiagnostic) {
-          const tagNameText = getTextOfNode(node.parent.tagName);
-          const childPropName = getJsxElementChildrenPropertyName(getJsxNamespaceAt(node));
-          const childrenPropName = childPropName === void 0 ? "children" : unescapeLeadingUnderscores(childPropName);
-          const childrenTargetType = getIndexedAccessType(target, getStringLiteralType(childrenPropName));
-          const diagnostic = Diagnostics._0_components_don_t_accept_text_as_child_elements_Text_in_JSX_has_the_type_string_but_the_expected_type_of_1_is_2;
-          invalidTextDiagnostic = { ...diagnostic, key: "!!ALREADY FORMATTED!!", message: formatMessage(
-            /*dummy*/
-            void 0,
-            diagnostic,
-            tagNameText,
-            childrenPropName,
-            typeToString(childrenTargetType)
-          ) };
-        }
-        return invalidTextDiagnostic;
-      }
-    }
-    function* generateLimitedTupleElements(node, target) {
-      const len = length(node.elements);
-      if (!len)
-        return;
-      for (let i = 0; i < len; i++) {
-        if (isTupleLikeType(target) && !getPropertyOfType(target, "" + i))
-          continue;
-        const elem = node.elements[i];
-        if (isOmittedExpression(elem))
-          continue;
-        const nameType = getNumberLiteralType(i);
-        yield { errorNode: elem, innerExpression: elem, nameType };
-      }
-    }
-    function elaborateArrayLiteral(node, source, target, relation, containingMessageChain, errorOutputContainer) {
-      if (target.flags & (402784252 /* Primitive */ | 131072 /* Never */))
-        return false;
-      if (isTupleLikeType(source)) {
-        return elaborateElementwise(generateLimitedTupleElements(node, target), source, target, relation, containingMessageChain, errorOutputContainer);
-      }
-      pushContextualType(
-        node,
-        target,
-        /*isCache*/
-        false
-      );
-      const tupleizedType = checkArrayLiteral(
-        node,
-        1 /* Contextual */,
-        /*forceTuple*/
-        true
-      );
-      popContextualType();
-      if (isTupleLikeType(tupleizedType)) {
-        return elaborateElementwise(generateLimitedTupleElements(node, target), tupleizedType, target, relation, containingMessageChain, errorOutputContainer);
-      }
-      return false;
-    }
-    function* generateObjectLiteralElements(node) {
-      if (!length(node.properties))
-        return;
-      for (const prop of node.properties) {
-        if (isSpreadAssignment(prop))
-          continue;
-        const type = getLiteralTypeFromProperty(getSymbolOfDeclaration(prop), 8576 /* StringOrNumberLiteralOrUnique */);
-        if (!type || type.flags & 131072 /* Never */) {
-          continue;
-        }
-        switch (prop.kind) {
-          case 177 /* SetAccessor */:
-          case 176 /* GetAccessor */:
-          case 173 /* MethodDeclaration */:
-          case 303 /* ShorthandPropertyAssignment */:
-            yield { errorNode: prop.name, innerExpression: void 0, nameType: type };
-            break;
-          case 302 /* PropertyAssignment */:
-            yield { errorNode: prop.name, innerExpression: prop.initializer, nameType: type, errorMessage: isComputedNonLiteralName(prop.name) ? Diagnostics.Type_of_computed_property_s_value_is_0_which_is_not_assignable_to_type_1 : void 0 };
-            break;
-          default:
-            Debug.assertNever(prop);
-        }
-      }
-    }
-    function elaborateObjectLiteral(node, source, target, relation, containingMessageChain, errorOutputContainer) {
-      if (target.flags & (402784252 /* Primitive */ | 131072 /* Never */))
-        return false;
-      return elaborateElementwise(generateObjectLiteralElements(node), source, target, relation, containingMessageChain, errorOutputContainer);
-    }
-    function checkTypeComparableTo(source, target, errorNode, headMessage, containingMessageChain) {
-      return checkTypeRelatedTo(source, target, comparableRelation, errorNode, headMessage, containingMessageChain);
-    }
-    function isSignatureAssignableTo(source, target, ignoreReturnTypes) {
-      return compareSignaturesRelated(
-        source,
-        target,
-        ignoreReturnTypes ? 4 /* IgnoreReturnTypes */ : 0 /* None */,
-        /*reportErrors*/
-        false,
-        /*errorReporter*/
-        void 0,
-        /*incompatibleErrorReporter*/
-        void 0,
-        compareTypesAssignable,
-        /*reportUnreliableMarkers*/
-        void 0
-      ) !== 0 /* False */;
-    }
-    function isTopSignature(s) {
-      if (!s.typeParameters && (!s.thisParameter || isTypeAny(getTypeOfParameter(s.thisParameter))) && s.parameters.length === 1 && signatureHasRestParameter(s)) {
-        const paramType = getTypeOfParameter(s.parameters[0]);
-        const restType = isArrayType(paramType) ? getTypeArguments(paramType)[0] : paramType;
-        return !!(restType.flags & (1 /* Any */ | 131072 /* Never */) && getReturnTypeOfSignature(s).flags & 3 /* AnyOrUnknown */);
-      }
-      return false;
-    }
-    function compareSignaturesRelated(source, target, checkMode, reportErrors2, errorReporter, incompatibleErrorReporter, compareTypes, reportUnreliableMarkers) {
-      if (source === target) {
-        return -1 /* True */;
-      }
-      if (!(checkMode & 16 /* StrictTopSignature */ && isTopSignature(source)) && isTopSignature(target)) {
-        return -1 /* True */;
-      }
-      if (checkMode & 16 /* StrictTopSignature */ && isTopSignature(source) && !isTopSignature(target)) {
-        return 0 /* False */;
-      }
-      const targetCount = getParameterCount(target);
-      const sourceHasMoreParameters = !hasEffectiveRestParameter(target) && (checkMode & 8 /* StrictArity */ ? hasEffectiveRestParameter(source) || getParameterCount(source) > targetCount : getMinArgumentCount(source) > targetCount);
-      if (sourceHasMoreParameters) {
-        if (reportErrors2 && !(checkMode & 8 /* StrictArity */)) {
-          errorReporter(Diagnostics.Target_signature_provides_too_few_arguments_Expected_0_or_more_but_got_1, getMinArgumentCount(source), targetCount);
-        }
-        return 0 /* False */;
-      }
-      if (source.typeParameters && source.typeParameters !== target.typeParameters) {
-        target = getCanonicalSignature(target);
-        source = instantiateSignatureInContextOf(
-          source,
-          target,
-          /*inferenceContext*/
-          void 0,
-          compareTypes
-        );
-      }
-      const sourceCount = getParameterCount(source);
-      const sourceRestType = getNonArrayRestType(source);
-      const targetRestType = getNonArrayRestType(target);
-      if (sourceRestType || targetRestType) {
-        void instantiateType(sourceRestType || targetRestType, reportUnreliableMarkers);
-      }
-      const kind = target.declaration ? target.declaration.kind : 0 /* Unknown */;
-      const strictVariance = !(checkMode & 3 /* Callback */) && strictFunctionTypes && kind !== 173 /* MethodDeclaration */ && kind !== 172 /* MethodSignature */ && kind !== 175 /* Constructor */;
-      let result = -1 /* True */;
-      const sourceThisType = getThisTypeOfSignature(source);
-      if (sourceThisType && sourceThisType !== voidType) {
-        const targetThisType = getThisTypeOfSignature(target);
-        if (targetThisType) {
-          const related = !strictVariance && compareTypes(
-            sourceThisType,
-            targetThisType,
-            /*reportErrors*/
-            false
-          ) || compareTypes(targetThisType, sourceThisType, reportErrors2);
-          if (!related) {
-            if (reportErrors2) {
-              errorReporter(Diagnostics.The_this_types_of_each_signature_are_incompatible);
-            }
-            return 0 /* False */;
-          }
-          result &= related;
-        }
-      }
-      const paramCount = sourceRestType || targetRestType ? Math.min(sourceCount, targetCount) : Math.max(sourceCount, targetCount);
-      const restIndex = sourceRestType || targetRestType ? paramCount - 1 : -1;
-      for (let i = 0; i < paramCount; i++) {
-        const sourceType = i === restIndex ? getRestTypeAtPosition(source, i) : tryGetTypeAtPosition(source, i);
-        const targetType = i === restIndex ? getRestTypeAtPosition(target, i) : tryGetTypeAtPosition(target, i);
-        if (sourceType && targetType) {
-          const sourceSig = checkMode & 3 /* Callback */ ? void 0 : getSingleCallSignature(getNonNullableType(sourceType));
-          const targetSig = checkMode & 3 /* Callback */ ? void 0 : getSingleCallSignature(getNonNullableType(targetType));
-          const callbacks = sourceSig && targetSig && !getTypePredicateOfSignature(sourceSig) && !getTypePredicateOfSignature(targetSig) && (getTypeFacts(sourceType) & 50331648 /* IsUndefinedOrNull */) === (getTypeFacts(targetType) & 50331648 /* IsUndefinedOrNull */);
-          let related = callbacks ? compareSignaturesRelated(targetSig, sourceSig, checkMode & 8 /* StrictArity */ | (strictVariance ? 2 /* StrictCallback */ : 1 /* BivariantCallback */), reportErrors2, errorReporter, incompatibleErrorReporter, compareTypes, reportUnreliableMarkers) : !(checkMode & 3 /* Callback */) && !strictVariance && compareTypes(
-            sourceType,
-            targetType,
-            /*reportErrors*/
-            false
-          ) || compareTypes(targetType, sourceType, reportErrors2);
-          if (related && checkMode & 8 /* StrictArity */ && i >= getMinArgumentCount(source) && i < getMinArgumentCount(target) && compareTypes(
-            sourceType,
-            targetType,
-            /*reportErrors*/
-            false
-          )) {
-            related = 0 /* False */;
-          }
-          if (!related) {
-            if (reportErrors2) {
-              errorReporter(
-                Diagnostics.Types_of_parameters_0_and_1_are_incompatible,
-                unescapeLeadingUnderscores(getParameterNameAtPosition(source, i)),
-                unescapeLeadingUnderscores(getParameterNameAtPosition(target, i))
-              );
-            }
-            return 0 /* False */;
-          }
-          result &= related;
-        }
-      }
-      if (!(checkMode & 4 /* IgnoreReturnTypes */)) {
-        const targetReturnType = isResolvingReturnTypeOfSignature(target) ? anyType : target.declaration && isJSConstructor(target.declaration) ? getDeclaredTypeOfClassOrInterface(getMergedSymbol(target.declaration.symbol)) : getReturnTypeOfSignature(target);
-        if (targetReturnType === voidType || targetReturnType === anyType) {
-          return result;
-        }
-        const sourceReturnType = isResolvingReturnTypeOfSignature(source) ? anyType : source.declaration && isJSConstructor(source.declaration) ? getDeclaredTypeOfClassOrInterface(getMergedSymbol(source.declaration.symbol)) : getReturnTypeOfSignature(source);
-        const targetTypePredicate = getTypePredicateOfSignature(target);
-        if (targetTypePredicate) {
-          const sourceTypePredicate = getTypePredicateOfSignature(source);
-          if (sourceTypePredicate) {
-            result &= compareTypePredicateRelatedTo(sourceTypePredicate, targetTypePredicate, reportErrors2, errorReporter, compareTypes);
-          } else if (isIdentifierTypePredicate(targetTypePredicate)) {
-            if (reportErrors2) {
-              errorReporter(Diagnostics.Signature_0_must_be_a_type_predicate, signatureToString(source));
-            }
-            return 0 /* False */;
-          }
-        } else {
-          result &= checkMode & 1 /* BivariantCallback */ && compareTypes(
-            targetReturnType,
-            sourceReturnType,
-            /*reportErrors*/
-            false
-          ) || compareTypes(sourceReturnType, targetReturnType, reportErrors2);
-          if (!result && reportErrors2 && incompatibleErrorReporter) {
-            incompatibleErrorReporter(sourceReturnType, targetReturnType);
-          }
-        }
-      }
-      return result;
-    }
-    function compareTypePredicateRelatedTo(source, target, reportErrors2, errorReporter, compareTypes) {
-      if (source.kind !== target.kind) {
-        if (reportErrors2) {
-          errorReporter(Diagnostics.A_this_based_type_guard_is_not_compatible_with_a_parameter_based_type_guard);
-          errorReporter(Diagnostics.Type_predicate_0_is_not_assignable_to_1, typePredicateToString(source), typePredicateToString(target));
-        }
-        return 0 /* False */;
-      }
-      if (source.kind === 1 /* Identifier */ || source.kind === 3 /* AssertsIdentifier */) {
-        if (source.parameterIndex !== target.parameterIndex) {
-          if (reportErrors2) {
-            errorReporter(Diagnostics.Parameter_0_is_not_in_the_same_position_as_parameter_1, source.parameterName, target.parameterName);
-            errorReporter(Diagnostics.Type_predicate_0_is_not_assignable_to_1, typePredicateToString(source), typePredicateToString(target));
-          }
-          return 0 /* False */;
-        }
-      }
-      const related = source.type === target.type ? -1 /* True */ : source.type && target.type ? compareTypes(source.type, target.type, reportErrors2) : 0 /* False */;
-      if (related === 0 /* False */ && reportErrors2) {
-        errorReporter(Diagnostics.Type_predicate_0_is_not_assignable_to_1, typePredicateToString(source), typePredicateToString(target));
-      }
-      return related;
-    }
-    function isImplementationCompatibleWithOverload(implementation, overload) {
-      const erasedSource = getErasedSignature(implementation);
-      const erasedTarget = getErasedSignature(overload);
-      const sourceReturnType = getReturnTypeOfSignature(erasedSource);
-      const targetReturnType = getReturnTypeOfSignature(erasedTarget);
-      if (targetReturnType === voidType || isTypeRelatedTo(targetReturnType, sourceReturnType, assignableRelation) || isTypeRelatedTo(sourceReturnType, targetReturnType, assignableRelation)) {
-        return isSignatureAssignableTo(
-          erasedSource,
-          erasedTarget,
-          /*ignoreReturnTypes*/
-          true
-        );
-      }
-      return false;
-    }
-    function isEmptyResolvedType(t) {
-      return t !== anyFunctionType && t.properties.length === 0 && t.callSignatures.length === 0 && t.constructSignatures.length === 0 && t.indexInfos.length === 0;
-    }
-    function isEmptyObjectType(type) {
-      return type.flags & 524288 /* Object */ ? !isGenericMappedType(type) && isEmptyResolvedType(resolveStructuredTypeMembers(type)) : type.flags & 67108864 /* NonPrimitive */ ? true : type.flags & 1048576 /* Union */ ? some(type.types, isEmptyObjectType) : type.flags & 2097152 /* Intersection */ ? every(type.types, isEmptyObjectType) : false;
-    }
-    function isEmptyAnonymousObjectType(type) {
-      return !!(getObjectFlags(type) & 16 /* Anonymous */ && (type.members && isEmptyResolvedType(type) || type.symbol && type.symbol.flags & 2048 /* TypeLiteral */ && getMembersOfSymbol(type.symbol).size === 0));
-    }
-    function isUnknownLikeUnionType(type) {
-      if (strictNullChecks && type.flags & 1048576 /* Union */) {
-        if (!(type.objectFlags & 33554432 /* IsUnknownLikeUnionComputed */)) {
-          const types = type.types;
-          type.objectFlags |= 33554432 /* IsUnknownLikeUnionComputed */ | (types.length >= 3 && types[0].flags & 32768 /* Undefined */ && types[1].flags & 65536 /* Null */ && some(types, isEmptyAnonymousObjectType) ? 67108864 /* IsUnknownLikeUnion */ : 0);
-        }
-        return !!(type.objectFlags & 67108864 /* IsUnknownLikeUnion */);
-      }
-      return false;
-    }
-    function containsUndefinedType(type) {
-      return !!((type.flags & 1048576 /* Union */ ? type.types[0] : type).flags & 32768 /* Undefined */);
-    }
-    function isStringIndexSignatureOnlyType(type) {
-      return type.flags & 524288 /* Object */ && !isGenericMappedType(type) && getPropertiesOfType(type).length === 0 && getIndexInfosOfType(type).length === 1 && !!getIndexInfoOfType(type, stringType) || type.flags & 3145728 /* UnionOrIntersection */ && every(type.types, isStringIndexSignatureOnlyType) || false;
-    }
-    function isEnumTypeRelatedTo(source, target, errorReporter) {
-      const sourceSymbol = source.flags & 8 /* EnumMember */ ? getParentOfSymbol(source) : source;
-      const targetSymbol = target.flags & 8 /* EnumMember */ ? getParentOfSymbol(target) : target;
-      if (sourceSymbol === targetSymbol) {
-        return true;
-      }
-      if (sourceSymbol.escapedName !== targetSymbol.escapedName || !(sourceSymbol.flags & 256 /* RegularEnum */) || !(targetSymbol.flags & 256 /* RegularEnum */)) {
-        return false;
-      }
-      const id = getSymbolId(sourceSymbol) + "," + getSymbolId(targetSymbol);
-      const entry = enumRelation.get(id);
-      if (entry !== void 0 && !(!(entry & 4 /* Reported */) && entry & 2 /* Failed */ && errorReporter)) {
-        return !!(entry & 1 /* Succeeded */);
-      }
-      const targetEnumType = getTypeOfSymbol(targetSymbol);
-      for (const property of getPropertiesOfType(getTypeOfSymbol(sourceSymbol))) {
-        if (property.flags & 8 /* EnumMember */) {
-          const targetProperty = getPropertyOfType(targetEnumType, property.escapedName);
-          if (!targetProperty || !(targetProperty.flags & 8 /* EnumMember */)) {
-            if (errorReporter) {
-              errorReporter(
-                Diagnostics.Property_0_is_missing_in_type_1,
-                symbolName(property),
-                typeToString(
-                  getDeclaredTypeOfSymbol(targetSymbol),
-                  /*enclosingDeclaration*/
-                  void 0,
-                  64 /* UseFullyQualifiedType */
-                )
-              );
-              enumRelation.set(id, 2 /* Failed */ | 4 /* Reported */);
-            } else {
-              enumRelation.set(id, 2 /* Failed */);
-            }
-            return false;
-          }
-        }
-      }
-      enumRelation.set(id, 1 /* Succeeded */);
-      return true;
-    }
-    function isSimpleTypeRelatedTo(source, target, relation, errorReporter) {
-      const s = source.flags;
-      const t = target.flags;
-      if (t & 1 /* Any */ || s & 131072 /* Never */ || source === wildcardType)
-        return true;
-      if (t & 2 /* Unknown */ && !(relation === strictSubtypeRelation && s & 1 /* Any */))
-        return true;
-      if (t & 131072 /* Never */)
-        return false;
-      if (s & 402653316 /* StringLike */ && t & 4 /* String */)
-        return true;
-      if (s & 128 /* StringLiteral */ && s & 1024 /* EnumLiteral */ && t & 128 /* StringLiteral */ && !(t & 1024 /* EnumLiteral */) && source.value === target.value)
-        return true;
-      if (s & 296 /* NumberLike */ && t & 8 /* Number */)
-        return true;
-      if (s & 256 /* NumberLiteral */ && s & 1024 /* EnumLiteral */ && t & 256 /* NumberLiteral */ && !(t & 1024 /* EnumLiteral */) && source.value === target.value)
-        return true;
-      if (s & 2112 /* BigIntLike */ && t & 64 /* BigInt */)
-        return true;
-      if (s & 528 /* BooleanLike */ && t & 16 /* Boolean */)
-        return true;
-      if (s & 12288 /* ESSymbolLike */ && t & 4096 /* ESSymbol */)
-        return true;
-      if (s & 32 /* Enum */ && t & 32 /* Enum */ && source.symbol.escapedName === target.symbol.escapedName && isEnumTypeRelatedTo(source.symbol, target.symbol, errorReporter))
-        return true;
-      if (s & 1024 /* EnumLiteral */ && t & 1024 /* EnumLiteral */) {
-        if (s & 1048576 /* Union */ && t & 1048576 /* Union */ && isEnumTypeRelatedTo(source.symbol, target.symbol, errorReporter))
-          return true;
-        if (s & 2944 /* Literal */ && t & 2944 /* Literal */ && source.value === target.value && isEnumTypeRelatedTo(source.symbol, target.symbol, errorReporter))
-          return true;
-      }
-      if (s & 32768 /* Undefined */ && (!strictNullChecks && !(t & 3145728 /* UnionOrIntersection */) || t & (32768 /* Undefined */ | 16384 /* Void */)))
-        return true;
-      if (s & 65536 /* Null */ && (!strictNullChecks && !(t & 3145728 /* UnionOrIntersection */) || t & 65536 /* Null */))
-        return true;
-      if (s & 524288 /* Object */ && t & 67108864 /* NonPrimitive */ && !(relation === strictSubtypeRelation && isEmptyAnonymousObjectType(source) && !(getObjectFlags(source) & 8192 /* FreshLiteral */)))
-        return true;
-      if (relation === assignableRelation || relation === comparableRelation) {
-        if (s & 1 /* Any */)
-          return true;
-        if (s & 8 /* Number */ && (t & 32 /* Enum */ || t & 256 /* NumberLiteral */ && t & 1024 /* EnumLiteral */))
-          return true;
-        if (s & 256 /* NumberLiteral */ && !(s & 1024 /* EnumLiteral */) && (t & 32 /* Enum */ || t & 256 /* NumberLiteral */ && t & 1024 /* EnumLiteral */ && source.value === target.value))
-          return true;
-        if (isUnknownLikeUnionType(target))
-          return true;
-      }
-      return false;
-    }
-    function isTypeRelatedTo(source, target, relation) {
-      if (isFreshLiteralType(source)) {
-        source = source.regularType;
-      }
-      if (isFreshLiteralType(target)) {
-        target = target.regularType;
-      }
-      if (source === target) {
-        return true;
-      }
-      if (relation !== identityRelation) {
-        if (relation === comparableRelation && !(target.flags & 131072 /* Never */) && isSimpleTypeRelatedTo(target, source, relation) || isSimpleTypeRelatedTo(source, target, relation)) {
-          return true;
-        }
-      } else if (!((source.flags | target.flags) & (3145728 /* UnionOrIntersection */ | 8388608 /* IndexedAccess */ | 16777216 /* Conditional */ | 33554432 /* Substitution */))) {
-        if (source.flags !== target.flags)
-          return false;
-        if (source.flags & 67358815 /* Singleton */)
-          return true;
-      }
-      if (source.flags & 524288 /* Object */ && target.flags & 524288 /* Object */) {
-        const related = relation.get(getRelationKey(
-          source,
-          target,
-          0 /* None */,
-          relation,
-          /*ignoreConstraints*/
-          false
-        ));
-        if (related !== void 0) {
-          return !!(related & 1 /* Succeeded */);
-        }
-      }
-      if (source.flags & 469499904 /* StructuredOrInstantiable */ || target.flags & 469499904 /* StructuredOrInstantiable */) {
-        return checkTypeRelatedTo(
-          source,
-          target,
-          relation,
-          /*errorNode*/
-          void 0
-        );
-      }
-      return false;
-    }
-    function isIgnoredJsxProperty(source, sourceProp) {
-      return getObjectFlags(source) & 2048 /* JsxAttributes */ && isHyphenatedJsxName(sourceProp.escapedName);
-    }
-    function getNormalizedType(type, writing) {
-      while (true) {
-        const t = isFreshLiteralType(type) ? type.regularType : isGenericTupleType(type) ? getNormalizedTupleType(type, writing) : getObjectFlags(type) & 4 /* Reference */ ? type.node ? createTypeReference(type.target, getTypeArguments(type)) : getSingleBaseForNonAugmentingSubtype(type) || type : type.flags & 3145728 /* UnionOrIntersection */ ? getNormalizedUnionOrIntersectionType(type, writing) : type.flags & 33554432 /* Substitution */ ? writing ? type.baseType : getSubstitutionIntersection(type) : type.flags & 25165824 /* Simplifiable */ ? getSimplifiedType(type, writing) : type;
-        if (t === type)
-          return t;
-        type = t;
-      }
-    }
-    function getNormalizedUnionOrIntersectionType(type, writing) {
-      const reduced = getReducedType(type);
-      if (reduced !== type) {
-        return reduced;
-      }
-      if (type.flags & 2097152 /* Intersection */ && some(type.types, isEmptyAnonymousObjectType)) {
-        const normalizedTypes = sameMap(type.types, (t) => getNormalizedType(t, writing));
-        if (normalizedTypes !== type.types) {
-          return getIntersectionType(normalizedTypes);
-        }
-      }
-      return type;
-    }
-    function getNormalizedTupleType(type, writing) {
-      const elements = getElementTypes(type);
-      const normalizedElements = sameMap(elements, (t) => t.flags & 25165824 /* Simplifiable */ ? getSimplifiedType(t, writing) : t);
-      return elements !== normalizedElements ? createNormalizedTupleType(type.target, normalizedElements) : type;
-    }
-    function checkTypeRelatedTo(source, target, relation, errorNode, headMessage, containingMessageChain, errorOutputContainer) {
-      var _a;
-      let errorInfo;
-      let relatedInfo;
-      let maybeKeys;
-      let sourceStack;
-      let targetStack;
-      let maybeCount = 0;
-      let sourceDepth = 0;
-      let targetDepth = 0;
-      let expandingFlags = 0 /* None */;
-      let overflow = false;
-      let overrideNextErrorInfo = 0;
-      let lastSkippedInfo;
-      let incompatibleStack;
-      Debug.assert(relation !== identityRelation || !errorNode, "no error reporting in identity checking");
-      const result = isRelatedTo(
-        source,
-        target,
-        3 /* Both */,
-        /*reportErrors*/
-        !!errorNode,
-        headMessage
-      );
-      if (incompatibleStack) {
-        reportIncompatibleStack();
-      }
-      if (overflow) {
-        (_a = tracing) == null ? void 0 : _a.instant(tracing.Phase.CheckTypes, "checkTypeRelatedTo_DepthLimit", { sourceId: source.id, targetId: target.id, depth: sourceDepth, targetDepth });
-        const diag2 = error(errorNode || currentNode, Diagnostics.Excessive_stack_depth_comparing_types_0_and_1, typeToString(source), typeToString(target));
-        if (errorOutputContainer) {
-          (errorOutputContainer.errors || (errorOutputContainer.errors = [])).push(diag2);
-        }
-      } else if (errorInfo) {
-        if (containingMessageChain) {
-          const chain = containingMessageChain();
-          if (chain) {
-            concatenateDiagnosticMessageChains(chain, errorInfo);
-            errorInfo = chain;
-          }
-        }
-        let relatedInformation;
-        if (headMessage && errorNode && !result && source.symbol) {
-          const links = getSymbolLinks(source.symbol);
-          if (links.originatingImport && !isImportCall(links.originatingImport)) {
-            const helpfulRetry = checkTypeRelatedTo(
-              getTypeOfSymbol(links.target),
-              target,
-              relation,
-              /*errorNode*/
-              void 0
-            );
-            if (helpfulRetry) {
-              const diag3 = createDiagnosticForNode(links.originatingImport, Diagnostics.Type_originates_at_this_import_A_namespace_style_import_cannot_be_called_or_constructed_and_will_cause_a_failure_at_runtime_Consider_using_a_default_import_or_import_require_here_instead);
-              relatedInformation = append(relatedInformation, diag3);
-            }
-          }
-        }
-        const diag2 = createDiagnosticForNodeFromMessageChain(getSourceFileOfNode(errorNode), errorNode, errorInfo, relatedInformation);
-        if (relatedInfo) {
-          addRelatedInfo(diag2, ...relatedInfo);
-        }
-        if (errorOutputContainer) {
-          (errorOutputContainer.errors || (errorOutputContainer.errors = [])).push(diag2);
-        }
-        if (!errorOutputContainer || !errorOutputContainer.skipLogging) {
-          diagnostics.add(diag2);
-        }
-      }
-      if (errorNode && errorOutputContainer && errorOutputContainer.skipLogging && result === 0 /* False */) {
-        Debug.assert(!!errorOutputContainer.errors, "missed opportunity to interact with error.");
-      }
-      return result !== 0 /* False */;
-      function resetErrorInfo(saved) {
-        errorInfo = saved.errorInfo;
-        lastSkippedInfo = saved.lastSkippedInfo;
-        incompatibleStack = saved.incompatibleStack;
-        overrideNextErrorInfo = saved.overrideNextErrorInfo;
-        relatedInfo = saved.relatedInfo;
-      }
-      function captureErrorCalculationState() {
-        return {
-          errorInfo,
-          lastSkippedInfo,
-          incompatibleStack: incompatibleStack == null ? void 0 : incompatibleStack.slice(),
-          overrideNextErrorInfo,
-          relatedInfo: relatedInfo == null ? void 0 : relatedInfo.slice()
-        };
-      }
-      function reportIncompatibleError(message, ...args) {
-        overrideNextErrorInfo++;
-        lastSkippedInfo = void 0;
-        (incompatibleStack || (incompatibleStack = [])).push([message, ...args]);
-      }
-      function reportIncompatibleStack() {
-        const stack = incompatibleStack || [];
-        incompatibleStack = void 0;
-        const info = lastSkippedInfo;
-        lastSkippedInfo = void 0;
-        if (stack.length === 1) {
-          reportError(...stack[0]);
-          if (info) {
-            reportRelationError(
-              /*message*/
-              void 0,
-              ...info
-            );
-          }
-          return;
-        }
-        let path = "";
-        const secondaryRootErrors = [];
-        while (stack.length) {
-          const [msg, ...args] = stack.pop();
-          switch (msg.code) {
-            case Diagnostics.Types_of_property_0_are_incompatible.code: {
-              if (path.indexOf("new ") === 0) {
-                path = `(${path})`;
-              }
-              const str = "" + args[0];
-              if (path.length === 0) {
-                path = `${str}`;
-              } else if (isIdentifierText(str, getEmitScriptTarget(compilerOptions))) {
-                path = `${path}.${str}`;
-              } else if (str[0] === "[" && str[str.length - 1] === "]") {
-                path = `${path}${str}`;
-              } else {
-                path = `${path}[${str}]`;
-              }
-              break;
-            }
-            case Diagnostics.Call_signature_return_types_0_and_1_are_incompatible.code:
-            case Diagnostics.Construct_signature_return_types_0_and_1_are_incompatible.code:
-            case Diagnostics.Call_signatures_with_no_arguments_have_incompatible_return_types_0_and_1.code:
-            case Diagnostics.Construct_signatures_with_no_arguments_have_incompatible_return_types_0_and_1.code: {
-              if (path.length === 0) {
-                let mappedMsg = msg;
-                if (msg.code === Diagnostics.Call_signatures_with_no_arguments_have_incompatible_return_types_0_and_1.code) {
-                  mappedMsg = Diagnostics.Call_signature_return_types_0_and_1_are_incompatible;
-                } else if (msg.code === Diagnostics.Construct_signatures_with_no_arguments_have_incompatible_return_types_0_and_1.code) {
-                  mappedMsg = Diagnostics.Construct_signature_return_types_0_and_1_are_incompatible;
-                }
-                secondaryRootErrors.unshift([mappedMsg, args[0], args[1]]);
-              } else {
-                const prefix = msg.code === Diagnostics.Construct_signature_return_types_0_and_1_are_incompatible.code || msg.code === Diagnostics.Construct_signatures_with_no_arguments_have_incompatible_return_types_0_and_1.code ? "new " : "";
-                const params = msg.code === Diagnostics.Call_signatures_with_no_arguments_have_incompatible_return_types_0_and_1.code || msg.code === Diagnostics.Construct_signatures_with_no_arguments_have_incompatible_return_types_0_and_1.code ? "" : "...";
-                path = `${prefix}${path}(${params})`;
-              }
-              break;
-            }
-            case Diagnostics.Type_at_position_0_in_source_is_not_compatible_with_type_at_position_1_in_target.code: {
-              secondaryRootErrors.unshift([Diagnostics.Type_at_position_0_in_source_is_not_compatible_with_type_at_position_1_in_target, args[0], args[1]]);
-              break;
-            }
-            case Diagnostics.Type_at_positions_0_through_1_in_source_is_not_compatible_with_type_at_position_2_in_target.code: {
-              secondaryRootErrors.unshift([Diagnostics.Type_at_positions_0_through_1_in_source_is_not_compatible_with_type_at_position_2_in_target, args[0], args[1], args[2]]);
-              break;
-            }
-            default:
-              return Debug.fail(`Unhandled Diagnostic: ${msg.code}`);
-          }
-        }
-        if (path) {
-          reportError(
-            path[path.length - 1] === ")" ? Diagnostics.The_types_returned_by_0_are_incompatible_between_these_types : Diagnostics.The_types_of_0_are_incompatible_between_these_types,
-            path
-          );
-        } else {
-          secondaryRootErrors.shift();
-        }
-        for (const [msg, ...args] of secondaryRootErrors) {
-          const originalValue = msg.elidedInCompatabilityPyramid;
-          msg.elidedInCompatabilityPyramid = false;
-          reportError(msg, ...args);
-          msg.elidedInCompatabilityPyramid = originalValue;
-        }
-        if (info) {
-          reportRelationError(
-            /*message*/
-            void 0,
-            ...info
-          );
-        }
-      }
-      function reportError(message, ...args) {
-        Debug.assert(!!errorNode);
-        if (incompatibleStack)
-          reportIncompatibleStack();
-        if (message.elidedInCompatabilityPyramid)
-          return;
-        errorInfo = chainDiagnosticMessages(errorInfo, message, ...args);
-      }
-      function associateRelatedInfo(info) {
-        Debug.assert(!!errorInfo);
-        if (!relatedInfo) {
-          relatedInfo = [info];
-        } else {
-          relatedInfo.push(info);
-        }
-      }
-      function reportRelationError(message, source2, target2) {
-        if (incompatibleStack)
-          reportIncompatibleStack();
-        const [sourceType, targetType] = getTypeNamesForErrorDisplay(source2, target2);
-        let generalizedSource = source2;
-        let generalizedSourceType = sourceType;
-        if (isLiteralType(source2) && !typeCouldHaveTopLevelSingletonTypes(target2)) {
-          generalizedSource = getBaseTypeOfLiteralType(source2);
-          Debug.assert(!isTypeAssignableTo(generalizedSource, target2), "generalized source shouldn't be assignable");
-          generalizedSourceType = getTypeNameForErrorDisplay(generalizedSource);
-        }
-        const targetFlags = target2.flags & 8388608 /* IndexedAccess */ && !(source2.flags & 8388608 /* IndexedAccess */) ? target2.objectType.flags : target2.flags;
-        if (targetFlags & 262144 /* TypeParameter */ && target2 !== markerSuperTypeForCheck && target2 !== markerSubTypeForCheck) {
-          const constraint = getBaseConstraintOfType(target2);
-          let needsOriginalSource;
-          if (constraint && (isTypeAssignableTo(generalizedSource, constraint) || (needsOriginalSource = isTypeAssignableTo(source2, constraint)))) {
-            reportError(
-              Diagnostics._0_is_assignable_to_the_constraint_of_type_1_but_1_could_be_instantiated_with_a_different_subtype_of_constraint_2,
-              needsOriginalSource ? sourceType : generalizedSourceType,
-              targetType,
-              typeToString(constraint)
-            );
-          } else {
-            errorInfo = void 0;
-            reportError(
-              Diagnostics._0_could_be_instantiated_with_an_arbitrary_type_which_could_be_unrelated_to_1,
-              targetType,
-              generalizedSourceType
-            );
-          }
-        }
-        if (!message) {
-          if (relation === comparableRelation) {
-            message = Diagnostics.Type_0_is_not_comparable_to_type_1;
-          } else if (sourceType === targetType) {
-            message = Diagnostics.Type_0_is_not_assignable_to_type_1_Two_different_types_with_this_name_exist_but_they_are_unrelated;
-          } else if (exactOptionalPropertyTypes && getExactOptionalUnassignableProperties(source2, target2).length) {
-            message = Diagnostics.Type_0_is_not_assignable_to_type_1_with_exactOptionalPropertyTypes_Colon_true_Consider_adding_undefined_to_the_types_of_the_target_s_properties;
-          } else {
-            if (source2.flags & 128 /* StringLiteral */ && target2.flags & 1048576 /* Union */) {
-              const suggestedType = getSuggestedTypeForNonexistentStringLiteralType(source2, target2);
-              if (suggestedType) {
-                reportError(Diagnostics.Type_0_is_not_assignable_to_type_1_Did_you_mean_2, generalizedSourceType, targetType, typeToString(suggestedType));
-                return;
-              }
-            }
-            message = Diagnostics.Type_0_is_not_assignable_to_type_1;
-          }
-        } else if (message === Diagnostics.Argument_of_type_0_is_not_assignable_to_parameter_of_type_1 && exactOptionalPropertyTypes && getExactOptionalUnassignableProperties(source2, target2).length) {
-          message = Diagnostics.Argument_of_type_0_is_not_assignable_to_parameter_of_type_1_with_exactOptionalPropertyTypes_Colon_true_Consider_adding_undefined_to_the_types_of_the_target_s_properties;
-        }
-        reportError(message, generalizedSourceType, targetType);
-      }
-      function tryElaborateErrorsForPrimitivesAndObjects(source2, target2) {
-        const sourceType = symbolValueDeclarationIsContextSensitive(source2.symbol) ? typeToString(source2, source2.symbol.valueDeclaration) : typeToString(source2);
-        const targetType = symbolValueDeclarationIsContextSensitive(target2.symbol) ? typeToString(target2, target2.symbol.valueDeclaration) : typeToString(target2);
-        if (globalStringType === source2 && stringType === target2 || globalNumberType === source2 && numberType === target2 || globalBooleanType === source2 && booleanType === target2 || getGlobalESSymbolType() === source2 && esSymbolType === target2) {
-          reportError(Diagnostics._0_is_a_primitive_but_1_is_a_wrapper_object_Prefer_using_0_when_possible, targetType, sourceType);
-        }
-      }
-      function tryElaborateArrayLikeErrors(source2, target2, reportErrors2) {
-        if (isTupleType(source2)) {
-          if (source2.target.readonly && isMutableArrayOrTuple(target2)) {
-            if (reportErrors2) {
-              reportError(Diagnostics.The_type_0_is_readonly_and_cannot_be_assigned_to_the_mutable_type_1, typeToString(source2), typeToString(target2));
-            }
-            return false;
-          }
-          return isArrayOrTupleType(target2);
-        }
-        if (isReadonlyArrayType(source2) && isMutableArrayOrTuple(target2)) {
-          if (reportErrors2) {
-            reportError(Diagnostics.The_type_0_is_readonly_and_cannot_be_assigned_to_the_mutable_type_1, typeToString(source2), typeToString(target2));
-          }
-          return false;
-        }
-        if (isTupleType(target2)) {
-          return isArrayType(source2);
-        }
-        return true;
-      }
-      function isRelatedToWorker(source2, target2, reportErrors2) {
-        return isRelatedTo(source2, target2, 3 /* Both */, reportErrors2);
-      }
-      function isRelatedTo(originalSource, originalTarget, recursionFlags = 3 /* Both */, reportErrors2 = false, headMessage2, intersectionState = 0 /* None */) {
-        if (originalSource === originalTarget)
-          return -1 /* True */;
-        if (originalSource.flags & 524288 /* Object */ && originalTarget.flags & 402784252 /* Primitive */) {
-          if (relation === comparableRelation && !(originalTarget.flags & 131072 /* Never */) && isSimpleTypeRelatedTo(originalTarget, originalSource, relation) || isSimpleTypeRelatedTo(originalSource, originalTarget, relation, reportErrors2 ? reportError : void 0)) {
-            return -1 /* True */;
-          }
-          if (reportErrors2) {
-            reportErrorResults(originalSource, originalTarget, originalSource, originalTarget, headMessage2);
-          }
-          return 0 /* False */;
-        }
-        const source2 = getNormalizedType(
-          originalSource,
-          /*writing*/
-          false
-        );
-        let target2 = getNormalizedType(
-          originalTarget,
-          /*writing*/
-          true
-        );
-        if (source2 === target2)
-          return -1 /* True */;
-        if (relation === identityRelation) {
-          if (source2.flags !== target2.flags)
-            return 0 /* False */;
-          if (source2.flags & 67358815 /* Singleton */)
-            return -1 /* True */;
-          traceUnionsOrIntersectionsTooLarge(source2, target2);
-          return recursiveTypeRelatedTo(
-            source2,
-            target2,
-            /*reportErrors*/
-            false,
-            0 /* None */,
-            recursionFlags
-          );
-        }
-        if (source2.flags & 262144 /* TypeParameter */ && getConstraintOfType(source2) === target2) {
-          return -1 /* True */;
-        }
-        if (source2.flags & 470302716 /* DefinitelyNonNullable */ && target2.flags & 1048576 /* Union */) {
-          const types = target2.types;
-          const candidate = types.length === 2 && types[0].flags & 98304 /* Nullable */ ? types[1] : types.length === 3 && types[0].flags & 98304 /* Nullable */ && types[1].flags & 98304 /* Nullable */ ? types[2] : void 0;
-          if (candidate && !(candidate.flags & 98304 /* Nullable */)) {
-            target2 = getNormalizedType(
-              candidate,
-              /*writing*/
-              true
-            );
-            if (source2 === target2)
-              return -1 /* True */;
-          }
-        }
-        if (relation === comparableRelation && !(target2.flags & 131072 /* Never */) && isSimpleTypeRelatedTo(target2, source2, relation) || isSimpleTypeRelatedTo(source2, target2, relation, reportErrors2 ? reportError : void 0))
-          return -1 /* True */;
-        if (source2.flags & 469499904 /* StructuredOrInstantiable */ || target2.flags & 469499904 /* StructuredOrInstantiable */) {
-          const isPerformingExcessPropertyChecks = !(intersectionState & 2 /* Target */) && (isObjectLiteralType2(source2) && getObjectFlags(source2) & 8192 /* FreshLiteral */);
-          if (isPerformingExcessPropertyChecks) {
-            if (hasExcessProperties(source2, target2, reportErrors2)) {
-              if (reportErrors2) {
-                reportRelationError(headMessage2, source2, originalTarget.aliasSymbol ? originalTarget : target2);
-              }
-              return 0 /* False */;
-            }
-          }
-          const isPerformingCommonPropertyChecks = (relation !== comparableRelation || isUnitType(source2)) && !(intersectionState & 2 /* Target */) && source2.flags & (402784252 /* Primitive */ | 524288 /* Object */ | 2097152 /* Intersection */) && source2 !== globalObjectType && target2.flags & (524288 /* Object */ | 2097152 /* Intersection */) && isWeakType(target2) && (getPropertiesOfType(source2).length > 0 || typeHasCallOrConstructSignatures(source2));
-          const isComparingJsxAttributes = !!(getObjectFlags(source2) & 2048 /* JsxAttributes */);
-          if (isPerformingCommonPropertyChecks && !hasCommonProperties(source2, target2, isComparingJsxAttributes)) {
-            if (reportErrors2) {
-              const sourceString = typeToString(originalSource.aliasSymbol ? originalSource : source2);
-              const targetString = typeToString(originalTarget.aliasSymbol ? originalTarget : target2);
-              const calls = getSignaturesOfType(source2, 0 /* Call */);
-              const constructs = getSignaturesOfType(source2, 1 /* Construct */);
-              if (calls.length > 0 && isRelatedTo(
-                getReturnTypeOfSignature(calls[0]),
-                target2,
-                1 /* Source */,
-                /*reportErrors*/
-                false
-              ) || constructs.length > 0 && isRelatedTo(
-                getReturnTypeOfSignature(constructs[0]),
-                target2,
-                1 /* Source */,
-                /*reportErrors*/
-                false
-              )) {
-                reportError(Diagnostics.Value_of_type_0_has_no_properties_in_common_with_type_1_Did_you_mean_to_call_it, sourceString, targetString);
-              } else {
-                reportError(Diagnostics.Type_0_has_no_properties_in_common_with_type_1, sourceString, targetString);
-              }
-            }
-            return 0 /* False */;
-          }
-          traceUnionsOrIntersectionsTooLarge(source2, target2);
-          const skipCaching = source2.flags & 1048576 /* Union */ && source2.types.length < 4 && !(target2.flags & 1048576 /* Union */) || target2.flags & 1048576 /* Union */ && target2.types.length < 4 && !(source2.flags & 469499904 /* StructuredOrInstantiable */);
-          const result2 = skipCaching ? unionOrIntersectionRelatedTo(source2, target2, reportErrors2, intersectionState) : recursiveTypeRelatedTo(source2, target2, reportErrors2, intersectionState, recursionFlags);
-          if (result2) {
-            return result2;
-          }
-        }
-        if (reportErrors2) {
-          reportErrorResults(originalSource, originalTarget, source2, target2, headMessage2);
-        }
-        return 0 /* False */;
-      }
-      function reportErrorResults(originalSource, originalTarget, source2, target2, headMessage2) {
-        var _a2, _b;
-        const sourceHasBase = !!getSingleBaseForNonAugmentingSubtype(originalSource);
-        const targetHasBase = !!getSingleBaseForNonAugmentingSubtype(originalTarget);
-        source2 = originalSource.aliasSymbol || sourceHasBase ? originalSource : source2;
-        target2 = originalTarget.aliasSymbol || targetHasBase ? originalTarget : target2;
-        let maybeSuppress = overrideNextErrorInfo > 0;
-        if (maybeSuppress) {
-          overrideNextErrorInfo--;
-        }
-        if (source2.flags & 524288 /* Object */ && target2.flags & 524288 /* Object */) {
-          const currentError = errorInfo;
-          tryElaborateArrayLikeErrors(
-            source2,
-            target2,
-            /*reportErrors*/
-            true
-          );
-          if (errorInfo !== currentError) {
-            maybeSuppress = !!errorInfo;
-          }
-        }
-        if (source2.flags & 524288 /* Object */ && target2.flags & 402784252 /* Primitive */) {
-          tryElaborateErrorsForPrimitivesAndObjects(source2, target2);
-        } else if (source2.symbol && source2.flags & 524288 /* Object */ && globalObjectType === source2) {
-          reportError(Diagnostics.The_Object_type_is_assignable_to_very_few_other_types_Did_you_mean_to_use_the_any_type_instead);
-        } else if (getObjectFlags(source2) & 2048 /* JsxAttributes */ && target2.flags & 2097152 /* Intersection */) {
-          const targetTypes = target2.types;
-          const intrinsicAttributes = getJsxType(JsxNames.IntrinsicAttributes, errorNode);
-          const intrinsicClassAttributes = getJsxType(JsxNames.IntrinsicClassAttributes, errorNode);
-          if (!isErrorType(intrinsicAttributes) && !isErrorType(intrinsicClassAttributes) && (contains(targetTypes, intrinsicAttributes) || contains(targetTypes, intrinsicClassAttributes))) {
-            return;
-          }
-        } else {
-          errorInfo = elaborateNeverIntersection(errorInfo, originalTarget);
-        }
-        if (!headMessage2 && maybeSuppress) {
-          lastSkippedInfo = [source2, target2];
-          return;
-        }
-        reportRelationError(headMessage2, source2, target2);
-        if (source2.flags & 262144 /* TypeParameter */ && ((_b = (_a2 = source2.symbol) == null ? void 0 : _a2.declarations) == null ? void 0 : _b[0]) && !getConstraintOfType(source2)) {
-          const syntheticParam = cloneTypeParameter(source2);
-          syntheticParam.constraint = instantiateType(target2, makeUnaryTypeMapper(source2, syntheticParam));
-          if (hasNonCircularBaseConstraint(syntheticParam)) {
-            const targetConstraintString = typeToString(target2, source2.symbol.declarations[0]);
-            associateRelatedInfo(createDiagnosticForNode(source2.symbol.declarations[0], Diagnostics.This_type_parameter_might_need_an_extends_0_constraint, targetConstraintString));
-          }
-        }
-      }
-      function traceUnionsOrIntersectionsTooLarge(source2, target2) {
-        if (!tracing) {
-          return;
-        }
-        if (source2.flags & 3145728 /* UnionOrIntersection */ && target2.flags & 3145728 /* UnionOrIntersection */) {
-          const sourceUnionOrIntersection = source2;
-          const targetUnionOrIntersection = target2;
-          if (sourceUnionOrIntersection.objectFlags & targetUnionOrIntersection.objectFlags & 32768 /* PrimitiveUnion */) {
-            return;
-          }
-          const sourceSize = sourceUnionOrIntersection.types.length;
-          const targetSize = targetUnionOrIntersection.types.length;
-          if (sourceSize * targetSize > 1e6) {
-            tracing.instant(tracing.Phase.CheckTypes, "traceUnionsOrIntersectionsTooLarge_DepthLimit", {
-              sourceId: source2.id,
-              sourceSize,
-              targetId: target2.id,
-              targetSize,
-              pos: errorNode == null ? void 0 : errorNode.pos,
-              end: errorNode == null ? void 0 : errorNode.end
-            });
-          }
-        }
-      }
-      function getTypeOfPropertyInTypes(types, name) {
-        const appendPropType = (propTypes, type) => {
-          var _a2;
-          type = getApparentType(type);
-          const prop = type.flags & 3145728 /* UnionOrIntersection */ ? getPropertyOfUnionOrIntersectionType(type, name) : getPropertyOfObjectType(type, name);
-          const propType = prop && getTypeOfSymbol(prop) || ((_a2 = getApplicableIndexInfoForName(type, name)) == null ? void 0 : _a2.type) || undefinedType;
-          return append(propTypes, propType);
-        };
-        return getUnionType(reduceLeft(
-          types,
-          appendPropType,
-          /*initial*/
-          void 0
-        ) || emptyArray);
-      }
-      function hasExcessProperties(source2, target2, reportErrors2) {
-        var _a2;
-        if (!isExcessPropertyCheckTarget(target2) || !noImplicitAny && getObjectFlags(target2) & 4096 /* JSLiteral */) {
-          return false;
-        }
-        const isComparingJsxAttributes = !!(getObjectFlags(source2) & 2048 /* JsxAttributes */);
-        if ((relation === assignableRelation || relation === comparableRelation) && (isTypeSubsetOf(globalObjectType, target2) || !isComparingJsxAttributes && isEmptyObjectType(target2))) {
-          return false;
-        }
-        let reducedTarget = target2;
-        let checkTypes;
-        if (target2.flags & 1048576 /* Union */) {
-          reducedTarget = findMatchingDiscriminantType(source2, target2, isRelatedTo) || filterPrimitivesIfContainsNonPrimitive(target2);
-          checkTypes = reducedTarget.flags & 1048576 /* Union */ ? reducedTarget.types : [reducedTarget];
-        }
-        for (const prop of getPropertiesOfType(source2)) {
-          if (shouldCheckAsExcessProperty(prop, source2.symbol) && !isIgnoredJsxProperty(source2, prop)) {
-            if (!isKnownProperty(reducedTarget, prop.escapedName, isComparingJsxAttributes)) {
-              if (reportErrors2) {
-                const errorTarget = filterType(reducedTarget, isExcessPropertyCheckTarget);
-                if (!errorNode)
-                  return Debug.fail();
-                if (isJsxAttributes(errorNode) || isJsxOpeningLikeElement(errorNode) || isJsxOpeningLikeElement(errorNode.parent)) {
-                  if (prop.valueDeclaration && isJsxAttribute(prop.valueDeclaration) && getSourceFileOfNode(errorNode) === getSourceFileOfNode(prop.valueDeclaration.name)) {
-                    errorNode = prop.valueDeclaration.name;
-                  }
-                  const propName = symbolToString(prop);
-                  const suggestionSymbol = getSuggestedSymbolForNonexistentJSXAttribute(propName, errorTarget);
-                  const suggestion = suggestionSymbol ? symbolToString(suggestionSymbol) : void 0;
-                  if (suggestion) {
-                    reportError(Diagnostics.Property_0_does_not_exist_on_type_1_Did_you_mean_2, propName, typeToString(errorTarget), suggestion);
-                  } else {
-                    reportError(Diagnostics.Property_0_does_not_exist_on_type_1, propName, typeToString(errorTarget));
-                  }
-                } else {
-                  const objectLiteralDeclaration = ((_a2 = source2.symbol) == null ? void 0 : _a2.declarations) && firstOrUndefined(source2.symbol.declarations);
-                  let suggestion;
-                  if (prop.valueDeclaration && findAncestor(prop.valueDeclaration, (d) => d === objectLiteralDeclaration) && getSourceFileOfNode(objectLiteralDeclaration) === getSourceFileOfNode(errorNode)) {
-                    const propDeclaration = prop.valueDeclaration;
-                    Debug.assertNode(propDeclaration, isObjectLiteralElementLike);
-                    const name = propDeclaration.name;
-                    errorNode = name;
-                    if (isIdentifier(name)) {
-                      suggestion = getSuggestionForNonexistentProperty(name, errorTarget);
-                    }
-                  }
-                  if (suggestion !== void 0) {
-                    reportError(
-                      Diagnostics.Object_literal_may_only_specify_known_properties_but_0_does_not_exist_in_type_1_Did_you_mean_to_write_2,
-                      symbolToString(prop),
-                      typeToString(errorTarget),
-                      suggestion
-                    );
-                  } else {
-                    reportError(
-                      Diagnostics.Object_literal_may_only_specify_known_properties_and_0_does_not_exist_in_type_1,
-                      symbolToString(prop),
-                      typeToString(errorTarget)
-                    );
-                  }
-                }
-              }
-              return true;
-            }
-            if (checkTypes && !isRelatedTo(getTypeOfSymbol(prop), getTypeOfPropertyInTypes(checkTypes, prop.escapedName), 3 /* Both */, reportErrors2)) {
-              if (reportErrors2) {
-                reportIncompatibleError(Diagnostics.Types_of_property_0_are_incompatible, symbolToString(prop));
-              }
-              return true;
-            }
-          }
-        }
-        return false;
-      }
-      function shouldCheckAsExcessProperty(prop, container) {
-        return prop.valueDeclaration && container.valueDeclaration && prop.valueDeclaration.parent === container.valueDeclaration;
-      }
-      function unionOrIntersectionRelatedTo(source2, target2, reportErrors2, intersectionState) {
-        if (source2.flags & 1048576 /* Union */) {
-          return relation === comparableRelation ? someTypeRelatedToType(source2, target2, reportErrors2 && !(source2.flags & 402784252 /* Primitive */), intersectionState) : eachTypeRelatedToType(source2, target2, reportErrors2 && !(source2.flags & 402784252 /* Primitive */), intersectionState);
-        }
-        if (target2.flags & 1048576 /* Union */) {
-          return typeRelatedToSomeType(getRegularTypeOfObjectLiteral(source2), target2, reportErrors2 && !(source2.flags & 402784252 /* Primitive */) && !(target2.flags & 402784252 /* Primitive */));
-        }
-        if (target2.flags & 2097152 /* Intersection */) {
-          return typeRelatedToEachType(source2, target2, reportErrors2, 2 /* Target */);
-        }
-        if (relation === comparableRelation && target2.flags & 402784252 /* Primitive */) {
-          const constraints = sameMap(source2.types, (t) => t.flags & 465829888 /* Instantiable */ ? getBaseConstraintOfType(t) || unknownType : t);
-          if (constraints !== source2.types) {
-            source2 = getIntersectionType(constraints);
-            if (source2.flags & 131072 /* Never */) {
-              return 0 /* False */;
-            }
-            if (!(source2.flags & 2097152 /* Intersection */)) {
-              return isRelatedTo(
-                source2,
-                target2,
-                1 /* Source */,
-                /*reportErrors*/
-                false
-              ) || isRelatedTo(
-                target2,
-                source2,
-                1 /* Source */,
-                /*reportErrors*/
-                false
-              );
-            }
-          }
-        }
-        return someTypeRelatedToType(
-          source2,
-          target2,
-          /*reportErrors*/
-          false,
-          1 /* Source */
-        );
-      }
-      function eachTypeRelatedToSomeType(source2, target2) {
-        let result2 = -1 /* True */;
-        const sourceTypes = source2.types;
-        for (const sourceType of sourceTypes) {
-          const related = typeRelatedToSomeType(
-            sourceType,
-            target2,
-            /*reportErrors*/
-            false
-          );
-          if (!related) {
-            return 0 /* False */;
-          }
-          result2 &= related;
-        }
-        return result2;
-      }
-      function typeRelatedToSomeType(source2, target2, reportErrors2) {
-        const targetTypes = target2.types;
-        if (target2.flags & 1048576 /* Union */) {
-          if (containsType(targetTypes, source2)) {
-            return -1 /* True */;
-          }
-          if (relation !== comparableRelation && getObjectFlags(target2) & 32768 /* PrimitiveUnion */ && !(source2.flags & 1024 /* EnumLiteral */) && (source2.flags & (128 /* StringLiteral */ | 512 /* BooleanLiteral */ | 2048 /* BigIntLiteral */) || (relation === subtypeRelation || relation === strictSubtypeRelation) && source2.flags & 256 /* NumberLiteral */)) {
-            const alternateForm = source2 === source2.regularType ? source2.freshType : source2.regularType;
-            const primitive = source2.flags & 128 /* StringLiteral */ ? stringType : source2.flags & 256 /* NumberLiteral */ ? numberType : source2.flags & 2048 /* BigIntLiteral */ ? bigintType : void 0;
-            return primitive && containsType(targetTypes, primitive) || alternateForm && containsType(targetTypes, alternateForm) ? -1 /* True */ : 0 /* False */;
-          }
-          const match = getMatchingUnionConstituentForType(target2, source2);
-          if (match) {
-            const related = isRelatedTo(
-              source2,
-              match,
-              2 /* Target */,
-              /*reportErrors*/
-              false
-            );
-            if (related) {
-              return related;
-            }
-          }
-        }
-        for (const type of targetTypes) {
-          const related = isRelatedTo(
-            source2,
-            type,
-            2 /* Target */,
-            /*reportErrors*/
-            false
-          );
-          if (related) {
-            return related;
-          }
-        }
-        if (reportErrors2) {
-          const bestMatchingType = getBestMatchingType(source2, target2, isRelatedTo);
-          if (bestMatchingType) {
-            isRelatedTo(
-              source2,
-              bestMatchingType,
-              2 /* Target */,
-              /*reportErrors*/
-              true
-            );
-          }
-        }
-        return 0 /* False */;
-      }
-      function typeRelatedToEachType(source2, target2, reportErrors2, intersectionState) {
-        let result2 = -1 /* True */;
-        const targetTypes = target2.types;
-        for (const targetType of targetTypes) {
-          const related = isRelatedTo(
-            source2,
-            targetType,
-            2 /* Target */,
-            reportErrors2,
-            /*headMessage*/
-            void 0,
-            intersectionState
-          );
-          if (!related) {
-            return 0 /* False */;
-          }
-          result2 &= related;
-        }
-        return result2;
-      }
-      function someTypeRelatedToType(source2, target2, reportErrors2, intersectionState) {
-        const sourceTypes = source2.types;
-        if (source2.flags & 1048576 /* Union */ && containsType(sourceTypes, target2)) {
-          return -1 /* True */;
-        }
-        const len = sourceTypes.length;
-        for (let i = 0; i < len; i++) {
-          const related = isRelatedTo(
-            sourceTypes[i],
-            target2,
-            1 /* Source */,
-            reportErrors2 && i === len - 1,
-            /*headMessage*/
-            void 0,
-            intersectionState
-          );
-          if (related) {
-            return related;
-          }
-        }
-        return 0 /* False */;
-      }
-      function getUndefinedStrippedTargetIfNeeded(source2, target2) {
-        if (source2.flags & 1048576 /* Union */ && target2.flags & 1048576 /* Union */ && !(source2.types[0].flags & 32768 /* Undefined */) && target2.types[0].flags & 32768 /* Undefined */) {
-          return extractTypesOfKind(target2, ~32768 /* Undefined */);
-        }
-        return target2;
-      }
-      function eachTypeRelatedToType(source2, target2, reportErrors2, intersectionState) {
-        let result2 = -1 /* True */;
-        const sourceTypes = source2.types;
-        const undefinedStrippedTarget = getUndefinedStrippedTargetIfNeeded(source2, target2);
-        for (let i = 0; i < sourceTypes.length; i++) {
-          const sourceType = sourceTypes[i];
-          if (undefinedStrippedTarget.flags & 1048576 /* Union */ && sourceTypes.length >= undefinedStrippedTarget.types.length && sourceTypes.length % undefinedStrippedTarget.types.length === 0) {
-            const related2 = isRelatedTo(
-              sourceType,
-              undefinedStrippedTarget.types[i % undefinedStrippedTarget.types.length],
-              3 /* Both */,
-              /*reportErrors*/
-              false,
-              /*headMessage*/
-              void 0,
-              intersectionState
-            );
-            if (related2) {
-              result2 &= related2;
-              continue;
-            }
-          }
-          const related = isRelatedTo(
-            sourceType,
-            target2,
-            1 /* Source */,
-            reportErrors2,
-            /*headMessage*/
-            void 0,
-            intersectionState
-          );
-          if (!related) {
-            return 0 /* False */;
-          }
-          result2 &= related;
-        }
-        return result2;
-      }
-      function typeArgumentsRelatedTo(sources = emptyArray, targets = emptyArray, variances = emptyArray, reportErrors2, intersectionState) {
-        if (sources.length !== targets.length && relation === identityRelation) {
-          return 0 /* False */;
-        }
-        const length2 = sources.length <= targets.length ? sources.length : targets.length;
-        let result2 = -1 /* True */;
-        for (let i = 0; i < length2; i++) {
-          const varianceFlags = i < variances.length ? variances[i] : 1 /* Covariant */;
-          const variance = varianceFlags & 7 /* VarianceMask */;
-          if (variance !== 4 /* Independent */) {
-            const s = sources[i];
-            const t = targets[i];
-            let related = -1 /* True */;
-            if (varianceFlags & 8 /* Unmeasurable */) {
-              related = relation === identityRelation ? isRelatedTo(
-                s,
-                t,
-                3 /* Both */,
-                /*reportErrors*/
-                false
-              ) : compareTypesIdentical(s, t);
-            } else if (variance === 1 /* Covariant */) {
-              related = isRelatedTo(
-                s,
-                t,
-                3 /* Both */,
-                reportErrors2,
-                /*headMessage*/
-                void 0,
-                intersectionState
-              );
-            } else if (variance === 2 /* Contravariant */) {
-              related = isRelatedTo(
-                t,
-                s,
-                3 /* Both */,
-                reportErrors2,
-                /*headMessage*/
-                void 0,
-                intersectionState
-              );
-            } else if (variance === 3 /* Bivariant */) {
-              related = isRelatedTo(
-                t,
-                s,
-                3 /* Both */,
-                /*reportErrors*/
-                false
-              );
-              if (!related) {
-                related = isRelatedTo(
-                  s,
-                  t,
-                  3 /* Both */,
-                  reportErrors2,
-                  /*headMessage*/
-                  void 0,
-                  intersectionState
-                );
-              }
-            } else {
-              related = isRelatedTo(
-                s,
-                t,
-                3 /* Both */,
-                reportErrors2,
-                /*headMessage*/
-                void 0,
-                intersectionState
-              );
-              if (related) {
-                related &= isRelatedTo(
-                  t,
-                  s,
-                  3 /* Both */,
-                  reportErrors2,
-                  /*headMessage*/
-                  void 0,
-                  intersectionState
-                );
-              }
-            }
-            if (!related) {
-              return 0 /* False */;
-            }
-            result2 &= related;
-          }
-        }
-        return result2;
-      }
-      function recursiveTypeRelatedTo(source2, target2, reportErrors2, intersectionState, recursionFlags) {
-        var _a2, _b, _c;
-        if (overflow) {
-          return 0 /* False */;
-        }
-        const id = getRelationKey(
-          source2,
-          target2,
-          intersectionState,
-          relation,
-          /*ignoreConstraints*/
-          false
-        );
-        const entry = relation.get(id);
-        if (entry !== void 0) {
-          if (reportErrors2 && entry & 2 /* Failed */ && !(entry & 4 /* Reported */)) {
-          } else {
-            if (outofbandVarianceMarkerHandler) {
-              const saved = entry & 24 /* ReportsMask */;
-              if (saved & 8 /* ReportsUnmeasurable */) {
-                instantiateType(source2, reportUnmeasurableMapper);
-              }
-              if (saved & 16 /* ReportsUnreliable */) {
-                instantiateType(source2, reportUnreliableMapper);
-              }
-            }
-            return entry & 1 /* Succeeded */ ? -1 /* True */ : 0 /* False */;
-          }
-        }
-        if (!maybeKeys) {
-          maybeKeys = [];
-          sourceStack = [];
-          targetStack = [];
-        } else {
-          const broadestEquivalentId = id.startsWith("*") ? getRelationKey(
-            source2,
-            target2,
-            intersectionState,
-            relation,
-            /*ignoreConstraints*/
-            true
-          ) : void 0;
-          for (let i = 0; i < maybeCount; i++) {
-            if (id === maybeKeys[i] || broadestEquivalentId && broadestEquivalentId === maybeKeys[i]) {
-              return 3 /* Maybe */;
-            }
-          }
-          if (sourceDepth === 100 || targetDepth === 100) {
-            overflow = true;
-            return 0 /* False */;
-          }
-        }
-        const maybeStart = maybeCount;
-        maybeKeys[maybeCount] = id;
-        maybeCount++;
-        const saveExpandingFlags = expandingFlags;
-        if (recursionFlags & 1 /* Source */) {
-          sourceStack[sourceDepth] = source2;
-          sourceDepth++;
-          if (!(expandingFlags & 1 /* Source */) && isDeeplyNestedType(source2, sourceStack, sourceDepth))
-            expandingFlags |= 1 /* Source */;
-        }
-        if (recursionFlags & 2 /* Target */) {
-          targetStack[targetDepth] = target2;
-          targetDepth++;
-          if (!(expandingFlags & 2 /* Target */) && isDeeplyNestedType(target2, targetStack, targetDepth))
-            expandingFlags |= 2 /* Target */;
-        }
-        let originalHandler;
-        let propagatingVarianceFlags = 0;
-        if (outofbandVarianceMarkerHandler) {
-          originalHandler = outofbandVarianceMarkerHandler;
-          outofbandVarianceMarkerHandler = (onlyUnreliable) => {
-            propagatingVarianceFlags |= onlyUnreliable ? 16 /* ReportsUnreliable */ : 8 /* ReportsUnmeasurable */;
-            return originalHandler(onlyUnreliable);
-          };
-        }
-        let result2;
-        if (expandingFlags === 3 /* Both */) {
-          (_a2 = tracing) == null ? void 0 : _a2.instant(tracing.Phase.CheckTypes, "recursiveTypeRelatedTo_DepthLimit", {
-            sourceId: source2.id,
-            sourceIdStack: sourceStack.map((t) => t.id),
-            targetId: target2.id,
-            targetIdStack: targetStack.map((t) => t.id),
-            depth: sourceDepth,
-            targetDepth
-          });
-          result2 = 3 /* Maybe */;
-        } else {
-          (_b = tracing) == null ? void 0 : _b.push(tracing.Phase.CheckTypes, "structuredTypeRelatedTo", { sourceId: source2.id, targetId: target2.id });
-          result2 = structuredTypeRelatedTo(source2, target2, reportErrors2, intersectionState);
-          (_c = tracing) == null ? void 0 : _c.pop();
-        }
-        if (outofbandVarianceMarkerHandler) {
-          outofbandVarianceMarkerHandler = originalHandler;
-        }
-        if (recursionFlags & 1 /* Source */) {
-          sourceDepth--;
-        }
-        if (recursionFlags & 2 /* Target */) {
-          targetDepth--;
-        }
-        expandingFlags = saveExpandingFlags;
-        if (result2) {
-          if (result2 === -1 /* True */ || sourceDepth === 0 && targetDepth === 0) {
-            if (result2 === -1 /* True */ || result2 === 3 /* Maybe */) {
-              for (let i = maybeStart; i < maybeCount; i++) {
-                relation.set(maybeKeys[i], 1 /* Succeeded */ | propagatingVarianceFlags);
-              }
-            }
-            maybeCount = maybeStart;
-          }
-        } else {
-          relation.set(id, (reportErrors2 ? 4 /* Reported */ : 0) | 2 /* Failed */ | propagatingVarianceFlags);
-          maybeCount = maybeStart;
-        }
-        return result2;
-      }
-      function structuredTypeRelatedTo(source2, target2, reportErrors2, intersectionState) {
-        const saveErrorInfo = captureErrorCalculationState();
-        let result2 = structuredTypeRelatedToWorker(source2, target2, reportErrors2, intersectionState, saveErrorInfo);
-        if (relation !== identityRelation) {
-          if (!result2 && (source2.flags & 2097152 /* Intersection */ || source2.flags & 262144 /* TypeParameter */ && target2.flags & 1048576 /* Union */)) {
-            const constraint = getEffectiveConstraintOfIntersection(source2.flags & 2097152 /* Intersection */ ? source2.types : [source2], !!(target2.flags & 1048576 /* Union */));
-            if (constraint && everyType(constraint, (c) => c !== source2)) {
-              result2 = isRelatedTo(
-                constraint,
-                target2,
-                1 /* Source */,
-                /*reportErrors*/
-                false,
-                /*headMessage*/
-                void 0,
-                intersectionState
-              );
-            }
-          }
-          if (result2 && !(intersectionState & 2 /* Target */) && target2.flags & 2097152 /* Intersection */ && !isGenericObjectType(target2) && source2.flags & (524288 /* Object */ | 2097152 /* Intersection */)) {
-            result2 &= propertiesRelatedTo(
-              source2,
-              target2,
-              reportErrors2,
-              /*excludedProperties*/
-              void 0,
-              /*optionalsOnly*/
-              false,
-              0 /* None */
-            );
-            if (result2 && isObjectLiteralType2(source2) && getObjectFlags(source2) & 8192 /* FreshLiteral */) {
-              result2 &= indexSignaturesRelatedTo(
-                source2,
-                target2,
-                /*sourceIsPrimitive*/
-                false,
-                reportErrors2,
-                0 /* None */
-              );
-            }
-          } else if (result2 && isNonGenericObjectType(target2) && !isArrayOrTupleType(target2) && source2.flags & 2097152 /* Intersection */ && getApparentType(source2).flags & 3670016 /* StructuredType */ && !some(source2.types, (t) => t === target2 || !!(getObjectFlags(t) & 262144 /* NonInferrableType */))) {
-            result2 &= propertiesRelatedTo(
-              source2,
-              target2,
-              reportErrors2,
-              /*excludedProperties*/
-              void 0,
-              /*optionalsOnly*/
-              true,
-              intersectionState
-            );
-          }
-        }
-        if (result2) {
-          resetErrorInfo(saveErrorInfo);
-        }
-        return result2;
-      }
-      function structuredTypeRelatedToWorker(source2, target2, reportErrors2, intersectionState, saveErrorInfo) {
-        let result2;
-        let originalErrorInfo;
-        let varianceCheckFailed = false;
-        let sourceFlags = source2.flags;
-        const targetFlags = target2.flags;
-        if (relation === identityRelation) {
-          if (sourceFlags & 3145728 /* UnionOrIntersection */) {
-            let result3 = eachTypeRelatedToSomeType(source2, target2);
-            if (result3) {
-              result3 &= eachTypeRelatedToSomeType(target2, source2);
-            }
-            return result3;
-          }
-          if (sourceFlags & 4194304 /* Index */) {
-            return isRelatedTo(
-              source2.type,
-              target2.type,
-              3 /* Both */,
-              /*reportErrors*/
-              false
-            );
-          }
-          if (sourceFlags & 8388608 /* IndexedAccess */) {
-            if (result2 = isRelatedTo(
-              source2.objectType,
-              target2.objectType,
-              3 /* Both */,
-              /*reportErrors*/
-              false
-            )) {
-              if (result2 &= isRelatedTo(
-                source2.indexType,
-                target2.indexType,
-                3 /* Both */,
-                /*reportErrors*/
-                false
-              )) {
-                return result2;
-              }
-            }
-          }
-          if (sourceFlags & 16777216 /* Conditional */) {
-            if (source2.root.isDistributive === target2.root.isDistributive) {
-              if (result2 = isRelatedTo(
-                source2.checkType,
-                target2.checkType,
-                3 /* Both */,
-                /*reportErrors*/
-                false
-              )) {
-                if (result2 &= isRelatedTo(
-                  source2.extendsType,
-                  target2.extendsType,
-                  3 /* Both */,
-                  /*reportErrors*/
-                  false
-                )) {
-                  if (result2 &= isRelatedTo(
-                    getTrueTypeFromConditionalType(source2),
-                    getTrueTypeFromConditionalType(target2),
-                    3 /* Both */,
-                    /*reportErrors*/
-                    false
-                  )) {
-                    if (result2 &= isRelatedTo(
-                      getFalseTypeFromConditionalType(source2),
-                      getFalseTypeFromConditionalType(target2),
-                      3 /* Both */,
-                      /*reportErrors*/
-                      false
-                    )) {
-                      return result2;
-                    }
-                  }
-                }
-              }
-            }
-          }
-          if (sourceFlags & 33554432 /* Substitution */) {
-            if (result2 = isRelatedTo(
-              source2.baseType,
-              target2.baseType,
-              3 /* Both */,
-              /*reportErrors*/
-              false
-            )) {
-              if (result2 &= isRelatedTo(
-                source2.constraint,
-                target2.constraint,
-                3 /* Both */,
-                /*reportErrors*/
-                false
-              )) {
-                return result2;
-              }
-            }
-          }
-          if (!(sourceFlags & 524288 /* Object */)) {
-            return 0 /* False */;
-          }
-        } else if (sourceFlags & 3145728 /* UnionOrIntersection */ || targetFlags & 3145728 /* UnionOrIntersection */) {
-          if (result2 = unionOrIntersectionRelatedTo(source2, target2, reportErrors2, intersectionState)) {
-            return result2;
-          }
-          if (!(sourceFlags & 465829888 /* Instantiable */ || sourceFlags & 524288 /* Object */ && targetFlags & 1048576 /* Union */ || sourceFlags & 2097152 /* Intersection */ && targetFlags & (524288 /* Object */ | 1048576 /* Union */ | 465829888 /* Instantiable */))) {
-            return 0 /* False */;
-          }
-        }
-        if (sourceFlags & (524288 /* Object */ | 16777216 /* Conditional */) && source2.aliasSymbol && source2.aliasTypeArguments && source2.aliasSymbol === target2.aliasSymbol && !(isMarkerType(source2) || isMarkerType(target2))) {
-          const variances = getAliasVariances(source2.aliasSymbol);
-          if (variances === emptyArray) {
-            return 1 /* Unknown */;
-          }
-          const params = getSymbolLinks(source2.aliasSymbol).typeParameters;
-          const minParams = getMinTypeArgumentCount(params);
-          const sourceTypes = fillMissingTypeArguments(source2.aliasTypeArguments, params, minParams, isInJSFile(source2.aliasSymbol.valueDeclaration));
-          const targetTypes = fillMissingTypeArguments(target2.aliasTypeArguments, params, minParams, isInJSFile(source2.aliasSymbol.valueDeclaration));
-          const varianceResult = relateVariances(sourceTypes, targetTypes, variances, intersectionState);
-          if (varianceResult !== void 0) {
-            return varianceResult;
-          }
-        }
-        if (isSingleElementGenericTupleType(source2) && !source2.target.readonly && (result2 = isRelatedTo(getTypeArguments(source2)[0], target2, 1 /* Source */)) || isSingleElementGenericTupleType(target2) && (target2.target.readonly || isMutableArrayOrTuple(getBaseConstraintOfType(source2) || source2)) && (result2 = isRelatedTo(source2, getTypeArguments(target2)[0], 2 /* Target */))) {
-          return result2;
-        }
-        if (targetFlags & 262144 /* TypeParameter */) {
-          if (getObjectFlags(source2) & 32 /* Mapped */ && !source2.declaration.nameType && isRelatedTo(getIndexType(target2), getConstraintTypeFromMappedType(source2), 3 /* Both */)) {
-            if (!(getMappedTypeModifiers(source2) & 4 /* IncludeOptional */)) {
-              const templateType = getTemplateTypeFromMappedType(source2);
-              const indexedAccessType = getIndexedAccessType(target2, getTypeParameterFromMappedType(source2));
-              if (result2 = isRelatedTo(templateType, indexedAccessType, 3 /* Both */, reportErrors2)) {
-                return result2;
-              }
-            }
-          }
-          if (relation === comparableRelation && sourceFlags & 262144 /* TypeParameter */) {
-            let constraint = getConstraintOfTypeParameter(source2);
-            if (constraint && hasNonCircularBaseConstraint(source2)) {
-              while (constraint && someType(constraint, (c) => !!(c.flags & 262144 /* TypeParameter */))) {
-                if (result2 = isRelatedTo(
-                  constraint,
-                  target2,
-                  1 /* Source */,
-                  /*reportErrors*/
-                  false
-                )) {
-                  return result2;
-                }
-                constraint = getConstraintOfTypeParameter(constraint);
-              }
-            }
-            return 0 /* False */;
-          }
-        } else if (targetFlags & 4194304 /* Index */) {
-          const targetType = target2.type;
-          if (sourceFlags & 4194304 /* Index */) {
-            if (result2 = isRelatedTo(
-              targetType,
-              source2.type,
-              3 /* Both */,
-              /*reportErrors*/
-              false
-            )) {
-              return result2;
-            }
-          }
-          if (isTupleType(targetType)) {
-            if (result2 = isRelatedTo(source2, getKnownKeysOfTupleType(targetType), 2 /* Target */, reportErrors2)) {
-              return result2;
-            }
-          } else {
-            const constraint = getSimplifiedTypeOrConstraint(targetType);
-            if (constraint) {
-              if (isRelatedTo(source2, getIndexType(constraint, target2.indexFlags | 4 /* NoReducibleCheck */), 2 /* Target */, reportErrors2) === -1 /* True */) {
-                return -1 /* True */;
-              }
-            } else if (isGenericMappedType(targetType)) {
-              const nameType = getNameTypeFromMappedType(targetType);
-              const constraintType = getConstraintTypeFromMappedType(targetType);
-              let targetKeys;
-              if (nameType && isMappedTypeWithKeyofConstraintDeclaration(targetType)) {
-                const modifiersType = getApparentType(getModifiersTypeFromMappedType(targetType));
-                const mappedKeys = [];
-                forEachMappedTypePropertyKeyTypeAndIndexSignatureKeyType(
-                  modifiersType,
-                  8576 /* StringOrNumberLiteralOrUnique */,
-                  /*stringsOnly*/
-                  false,
-                  (t) => void mappedKeys.push(instantiateType(nameType, appendTypeMapping(targetType.mapper, getTypeParameterFromMappedType(targetType), t)))
-                );
-                targetKeys = getUnionType([...mappedKeys, nameType]);
-              } else {
-                targetKeys = nameType || constraintType;
-              }
-              if (isRelatedTo(source2, targetKeys, 2 /* Target */, reportErrors2) === -1 /* True */) {
-                return -1 /* True */;
-              }
-            }
-          }
-        } else if (targetFlags & 8388608 /* IndexedAccess */) {
-          if (sourceFlags & 8388608 /* IndexedAccess */) {
-            if (result2 = isRelatedTo(source2.objectType, target2.objectType, 3 /* Both */, reportErrors2)) {
-              result2 &= isRelatedTo(source2.indexType, target2.indexType, 3 /* Both */, reportErrors2);
-            }
-            if (result2) {
-              return result2;
-            }
-            if (reportErrors2) {
-              originalErrorInfo = errorInfo;
-            }
-          }
-          if (relation === assignableRelation || relation === comparableRelation) {
-            const objectType = target2.objectType;
-            const indexType = target2.indexType;
-            const baseObjectType = getBaseConstraintOfType(objectType) || objectType;
-            const baseIndexType = getBaseConstraintOfType(indexType) || indexType;
-            if (!isGenericObjectType(baseObjectType) && !isGenericIndexType(baseIndexType)) {
-              const accessFlags = 4 /* Writing */ | (baseObjectType !== objectType ? 2 /* NoIndexSignatures */ : 0);
-              const constraint = getIndexedAccessTypeOrUndefined(baseObjectType, baseIndexType, accessFlags);
-              if (constraint) {
-                if (reportErrors2 && originalErrorInfo) {
-                  resetErrorInfo(saveErrorInfo);
-                }
-                if (result2 = isRelatedTo(
-                  source2,
-                  constraint,
-                  2 /* Target */,
-                  reportErrors2,
-                  /*headMessage*/
-                  void 0,
-                  intersectionState
-                )) {
-                  return result2;
-                }
-                if (reportErrors2 && originalErrorInfo && errorInfo) {
-                  errorInfo = countMessageChainBreadth([originalErrorInfo]) <= countMessageChainBreadth([errorInfo]) ? originalErrorInfo : errorInfo;
-                }
-              }
-            }
-          }
-          if (reportErrors2) {
-            originalErrorInfo = void 0;
-          }
-        } else if (isGenericMappedType(target2) && relation !== identityRelation) {
-          const keysRemapped = !!target2.declaration.nameType;
-          const templateType = getTemplateTypeFromMappedType(target2);
-          const modifiers = getMappedTypeModifiers(target2);
-          if (!(modifiers & 8 /* ExcludeOptional */)) {
-            if (!keysRemapped && templateType.flags & 8388608 /* IndexedAccess */ && templateType.objectType === source2 && templateType.indexType === getTypeParameterFromMappedType(target2)) {
-              return -1 /* True */;
-            }
-            if (!isGenericMappedType(source2)) {
-              const targetKeys = keysRemapped ? getNameTypeFromMappedType(target2) : getConstraintTypeFromMappedType(target2);
-              const sourceKeys = getIndexType(source2, 2 /* NoIndexSignatures */);
-              const includeOptional = modifiers & 4 /* IncludeOptional */;
-              const filteredByApplicability = includeOptional ? intersectTypes(targetKeys, sourceKeys) : void 0;
-              if (includeOptional ? !(filteredByApplicability.flags & 131072 /* Never */) : isRelatedTo(targetKeys, sourceKeys, 3 /* Both */)) {
-                const templateType2 = getTemplateTypeFromMappedType(target2);
-                const typeParameter = getTypeParameterFromMappedType(target2);
-                const nonNullComponent = extractTypesOfKind(templateType2, ~98304 /* Nullable */);
-                if (!keysRemapped && nonNullComponent.flags & 8388608 /* IndexedAccess */ && nonNullComponent.indexType === typeParameter) {
-                  if (result2 = isRelatedTo(source2, nonNullComponent.objectType, 2 /* Target */, reportErrors2)) {
-                    return result2;
-                  }
-                } else {
-                  const indexingType = keysRemapped ? filteredByApplicability || targetKeys : filteredByApplicability ? getIntersectionType([filteredByApplicability, typeParameter]) : typeParameter;
-                  const indexedAccessType = getIndexedAccessType(source2, indexingType);
-                  if (result2 = isRelatedTo(indexedAccessType, templateType2, 3 /* Both */, reportErrors2)) {
-                    return result2;
-                  }
-                }
-              }
-              originalErrorInfo = errorInfo;
-              resetErrorInfo(saveErrorInfo);
-            }
-          }
-        } else if (targetFlags & 16777216 /* Conditional */) {
-          if (isDeeplyNestedType(target2, targetStack, targetDepth, 10)) {
-            return 3 /* Maybe */;
-          }
-          const c = target2;
-          if (!c.root.inferTypeParameters && !isDistributionDependent(c.root) && !(source2.flags & 16777216 /* Conditional */ && source2.root === c.root)) {
-            const skipTrue = !isTypeAssignableTo(getPermissiveInstantiation(c.checkType), getPermissiveInstantiation(c.extendsType));
-            const skipFalse = !skipTrue && isTypeAssignableTo(getRestrictiveInstantiation(c.checkType), getRestrictiveInstantiation(c.extendsType));
-            if (result2 = skipTrue ? -1 /* True */ : isRelatedTo(
-              source2,
-              getTrueTypeFromConditionalType(c),
-              2 /* Target */,
-              /*reportErrors*/
-              false,
-              /*headMessage*/
-              void 0,
-              intersectionState
-            )) {
-              result2 &= skipFalse ? -1 /* True */ : isRelatedTo(
-                source2,
-                getFalseTypeFromConditionalType(c),
-                2 /* Target */,
-                /*reportErrors*/
-                false,
-                /*headMessage*/
-                void 0,
-                intersectionState
-              );
-              if (result2) {
-                return result2;
-              }
-            }
-          }
-        } else if (targetFlags & 134217728 /* TemplateLiteral */) {
-          if (sourceFlags & 134217728 /* TemplateLiteral */) {
-            if (relation === comparableRelation) {
-              return templateLiteralTypesDefinitelyUnrelated(source2, target2) ? 0 /* False */ : -1 /* True */;
-            }
-            instantiateType(source2, reportUnreliableMapper);
-          }
-          if (isTypeMatchedByTemplateLiteralType(source2, target2)) {
-            return -1 /* True */;
-          }
-        } else if (target2.flags & 268435456 /* StringMapping */) {
-          if (!(source2.flags & 268435456 /* StringMapping */)) {
-            if (isMemberOfStringMapping(source2, target2)) {
-              return -1 /* True */;
-            }
-          }
-        }
-        if (sourceFlags & 8650752 /* TypeVariable */) {
-          if (!(sourceFlags & 8388608 /* IndexedAccess */ && targetFlags & 8388608 /* IndexedAccess */)) {
-            const constraint = getConstraintOfType(source2) || unknownType;
-            if (result2 = isRelatedTo(
-              constraint,
-              target2,
-              1 /* Source */,
-              /*reportErrors*/
-              false,
-              /*headMessage*/
-              void 0,
-              intersectionState
-            )) {
-              return result2;
-            } else if (result2 = isRelatedTo(
-              getTypeWithThisArgument(constraint, source2),
-              target2,
-              1 /* Source */,
-              reportErrors2 && constraint !== unknownType && !(targetFlags & sourceFlags & 262144 /* TypeParameter */),
-              /*headMessage*/
-              void 0,
-              intersectionState
-            )) {
-              return result2;
-            }
-            if (sourceFlags & 8388608 /* IndexedAccess */) {
-              const indexType = source2.indexType;
-              if (indexType.flags & 4194304 /* Index */) {
-                const unresolvedIndexConstraint = getBaseConstraintOfType(indexType.type);
-                const indexConstraint = unresolvedIndexConstraint && unresolvedIndexConstraint !== noConstraintType ? getIndexType(unresolvedIndexConstraint) : keyofConstraintType;
-                const constraint2 = getIndexedAccessType(source2.objectType, indexConstraint);
-                if (result2 = isRelatedTo(
-                  constraint2,
-                  target2,
-                  1 /* Source */,
-                  /*reportErrors*/
-                  false,
-                  /*headMessage*/
-                  void 0,
-                  intersectionState
-                )) {
-                  return result2;
-                }
-              }
-            }
-            if (isMappedTypeGenericIndexedAccess(source2)) {
-              const indexConstraint = getConstraintOfType(source2.indexType);
-              if (indexConstraint) {
-                if (result2 = isRelatedTo(getIndexedAccessType(source2.objectType, indexConstraint), target2, 1 /* Source */, reportErrors2)) {
-                  return result2;
-                }
-              }
-            }
-          }
-        } else if (sourceFlags & 4194304 /* Index */) {
-          if (result2 = isRelatedTo(keyofConstraintType, target2, 1 /* Source */, reportErrors2)) {
-            return result2;
-          }
-        } else if (sourceFlags & 134217728 /* TemplateLiteral */ && !(targetFlags & 524288 /* Object */)) {
-          if (!(targetFlags & 134217728 /* TemplateLiteral */)) {
-            const constraint = getBaseConstraintOfType(source2);
-            if (constraint && constraint !== source2 && (result2 = isRelatedTo(constraint, target2, 1 /* Source */, reportErrors2))) {
-              return result2;
-            }
-          }
-        } else if (sourceFlags & 268435456 /* StringMapping */) {
-          if (targetFlags & 268435456 /* StringMapping */) {
-            if (source2.symbol !== target2.symbol) {
-              return 0 /* False */;
-            }
-            if (result2 = isRelatedTo(source2.type, target2.type, 3 /* Both */, reportErrors2)) {
-              return result2;
-            }
-          } else {
-            const constraint = getBaseConstraintOfType(source2);
-            if (constraint && (result2 = isRelatedTo(constraint, target2, 1 /* Source */, reportErrors2))) {
-              return result2;
-            }
-          }
-        } else if (sourceFlags & 16777216 /* Conditional */) {
-          if (isDeeplyNestedType(source2, sourceStack, sourceDepth, 10)) {
-            return 3 /* Maybe */;
-          }
-          if (targetFlags & 16777216 /* Conditional */) {
-            const sourceParams = source2.root.inferTypeParameters;
-            let sourceExtends = source2.extendsType;
-            let mapper;
-            if (sourceParams) {
-              const ctx = createInferenceContext(
-                sourceParams,
-                /*signature*/
-                void 0,
-                0 /* None */,
-                isRelatedToWorker
-              );
-              inferTypes(ctx.inferences, target2.extendsType, sourceExtends, 512 /* NoConstraints */ | 1024 /* AlwaysStrict */);
-              sourceExtends = instantiateType(sourceExtends, ctx.mapper);
-              mapper = ctx.mapper;
-            }
-            if (isTypeIdenticalTo(sourceExtends, target2.extendsType) && (isRelatedTo(source2.checkType, target2.checkType, 3 /* Both */) || isRelatedTo(target2.checkType, source2.checkType, 3 /* Both */))) {
-              if (result2 = isRelatedTo(instantiateType(getTrueTypeFromConditionalType(source2), mapper), getTrueTypeFromConditionalType(target2), 3 /* Both */, reportErrors2)) {
-                result2 &= isRelatedTo(getFalseTypeFromConditionalType(source2), getFalseTypeFromConditionalType(target2), 3 /* Both */, reportErrors2);
-              }
-              if (result2) {
-                return result2;
-              }
-            }
-          } else {
-            const distributiveConstraint = hasNonCircularBaseConstraint(source2) ? getConstraintOfDistributiveConditionalType(source2) : void 0;
-            if (distributiveConstraint) {
-              if (result2 = isRelatedTo(distributiveConstraint, target2, 1 /* Source */, reportErrors2)) {
-                return result2;
-              }
-            }
-          }
-          const defaultConstraint = getDefaultConstraintOfConditionalType(source2);
-          if (defaultConstraint) {
-            if (result2 = isRelatedTo(defaultConstraint, target2, 1 /* Source */, reportErrors2)) {
-              return result2;
-            }
-          }
-        } else {
-          if (relation !== subtypeRelation && relation !== strictSubtypeRelation && isPartialMappedType(target2) && isEmptyObjectType(source2)) {
-            return -1 /* True */;
-          }
-          if (isGenericMappedType(target2)) {
-            if (isGenericMappedType(source2)) {
-              if (result2 = mappedTypeRelatedTo(source2, target2, reportErrors2)) {
-                return result2;
-              }
-            }
-            return 0 /* False */;
-          }
-          const sourceIsPrimitive = !!(sourceFlags & 402784252 /* Primitive */);
-          if (relation !== identityRelation) {
-            source2 = getApparentType(source2);
-            sourceFlags = source2.flags;
-          } else if (isGenericMappedType(source2)) {
-            return 0 /* False */;
-          }
-          if (getObjectFlags(source2) & 4 /* Reference */ && getObjectFlags(target2) & 4 /* Reference */ && source2.target === target2.target && !isTupleType(source2) && !(isMarkerType(source2) || isMarkerType(target2))) {
-            if (isEmptyArrayLiteralType(source2)) {
-              return -1 /* True */;
-            }
-            const variances = getVariances(source2.target);
-            if (variances === emptyArray) {
-              return 1 /* Unknown */;
-            }
-            const varianceResult = relateVariances(getTypeArguments(source2), getTypeArguments(target2), variances, intersectionState);
-            if (varianceResult !== void 0) {
-              return varianceResult;
-            }
-          } else if (isReadonlyArrayType(target2) ? everyType(source2, isArrayOrTupleType) : isArrayType(target2) && everyType(source2, (t) => isTupleType(t) && !t.target.readonly)) {
-            if (relation !== identityRelation) {
-              return isRelatedTo(getIndexTypeOfType(source2, numberType) || anyType, getIndexTypeOfType(target2, numberType) || anyType, 3 /* Both */, reportErrors2);
-            } else {
-              return 0 /* False */;
-            }
-          } else if (isGenericTupleType(source2) && isTupleType(target2) && !isGenericTupleType(target2)) {
-            const constraint = getBaseConstraintOrType(source2);
-            if (constraint !== source2) {
-              return isRelatedTo(constraint, target2, 1 /* Source */, reportErrors2);
-            }
-          } else if ((relation === subtypeRelation || relation === strictSubtypeRelation) && isEmptyObjectType(target2) && getObjectFlags(target2) & 8192 /* FreshLiteral */ && !isEmptyObjectType(source2)) {
-            return 0 /* False */;
-          }
-          if (sourceFlags & (524288 /* Object */ | 2097152 /* Intersection */) && targetFlags & 524288 /* Object */) {
-            const reportStructuralErrors = reportErrors2 && errorInfo === saveErrorInfo.errorInfo && !sourceIsPrimitive;
-            result2 = propertiesRelatedTo(
-              source2,
-              target2,
-              reportStructuralErrors,
-              /*excludedProperties*/
-              void 0,
-              /*optionalsOnly*/
-              false,
-              intersectionState
-            );
-            if (result2) {
-              result2 &= signaturesRelatedTo(source2, target2, 0 /* Call */, reportStructuralErrors, intersectionState);
-              if (result2) {
-                result2 &= signaturesRelatedTo(source2, target2, 1 /* Construct */, reportStructuralErrors, intersectionState);
-                if (result2) {
-                  result2 &= indexSignaturesRelatedTo(source2, target2, sourceIsPrimitive, reportStructuralErrors, intersectionState);
-                }
-              }
-            }
-            if (varianceCheckFailed && result2) {
-              errorInfo = originalErrorInfo || errorInfo || saveErrorInfo.errorInfo;
-            } else if (result2) {
-              return result2;
-            }
-          }
-          if (sourceFlags & (524288 /* Object */ | 2097152 /* Intersection */) && targetFlags & 1048576 /* Union */) {
-            const objectOnlyTarget = extractTypesOfKind(target2, 524288 /* Object */ | 2097152 /* Intersection */ | 33554432 /* Substitution */);
-            if (objectOnlyTarget.flags & 1048576 /* Union */) {
-              const result3 = typeRelatedToDiscriminatedType(source2, objectOnlyTarget);
-              if (result3) {
-                return result3;
-              }
-            }
-          }
-        }
-        return 0 /* False */;
-        function countMessageChainBreadth(info) {
-          if (!info)
-            return 0;
-          return reduceLeft(info, (value, chain) => value + 1 + countMessageChainBreadth(chain.next), 0);
-        }
-        function relateVariances(sourceTypeArguments, targetTypeArguments, variances, intersectionState2) {
-          if (result2 = typeArgumentsRelatedTo(sourceTypeArguments, targetTypeArguments, variances, reportErrors2, intersectionState2)) {
-            return result2;
-          }
-          if (some(variances, (v) => !!(v & 24 /* AllowsStructuralFallback */))) {
-            originalErrorInfo = void 0;
-            resetErrorInfo(saveErrorInfo);
-            return void 0;
-          }
-          const allowStructuralFallback = targetTypeArguments && hasCovariantVoidArgument(targetTypeArguments, variances);
-          varianceCheckFailed = !allowStructuralFallback;
-          if (variances !== emptyArray && !allowStructuralFallback) {
-            if (varianceCheckFailed && !(reportErrors2 && some(variances, (v) => (v & 7 /* VarianceMask */) === 0 /* Invariant */))) {
-              return 0 /* False */;
-            }
-            originalErrorInfo = errorInfo;
-            resetErrorInfo(saveErrorInfo);
-          }
-        }
-      }
-      function mappedTypeRelatedTo(source2, target2, reportErrors2) {
-        const modifiersRelated = relation === comparableRelation || (relation === identityRelation ? getMappedTypeModifiers(source2) === getMappedTypeModifiers(target2) : getCombinedMappedTypeOptionality(source2) <= getCombinedMappedTypeOptionality(target2));
-        if (modifiersRelated) {
-          let result2;
-          const targetConstraint = getConstraintTypeFromMappedType(target2);
-          const sourceConstraint = instantiateType(getConstraintTypeFromMappedType(source2), getCombinedMappedTypeOptionality(source2) < 0 ? reportUnmeasurableMapper : reportUnreliableMapper);
-          if (result2 = isRelatedTo(targetConstraint, sourceConstraint, 3 /* Both */, reportErrors2)) {
-            const mapper = createTypeMapper([getTypeParameterFromMappedType(source2)], [getTypeParameterFromMappedType(target2)]);
-            if (instantiateType(getNameTypeFromMappedType(source2), mapper) === instantiateType(getNameTypeFromMappedType(target2), mapper)) {
-              return result2 & isRelatedTo(instantiateType(getTemplateTypeFromMappedType(source2), mapper), getTemplateTypeFromMappedType(target2), 3 /* Both */, reportErrors2);
-            }
-          }
-        }
-        return 0 /* False */;
-      }
-      function typeRelatedToDiscriminatedType(source2, target2) {
-        var _a2;
-        const sourceProperties = getPropertiesOfType(source2);
-        const sourcePropertiesFiltered = findDiscriminantProperties(sourceProperties, target2);
-        if (!sourcePropertiesFiltered)
-          return 0 /* False */;
-        let numCombinations = 1;
-        for (const sourceProperty of sourcePropertiesFiltered) {
-          numCombinations *= countTypes(getNonMissingTypeOfSymbol(sourceProperty));
-          if (numCombinations > 25) {
-            (_a2 = tracing) == null ? void 0 : _a2.instant(tracing.Phase.CheckTypes, "typeRelatedToDiscriminatedType_DepthLimit", { sourceId: source2.id, targetId: target2.id, numCombinations });
-            return 0 /* False */;
-          }
-        }
-        const sourceDiscriminantTypes = new Array(sourcePropertiesFiltered.length);
-        const excludedProperties = /* @__PURE__ */ new Set();
-        for (let i = 0; i < sourcePropertiesFiltered.length; i++) {
-          const sourceProperty = sourcePropertiesFiltered[i];
-          const sourcePropertyType = getNonMissingTypeOfSymbol(sourceProperty);
-          sourceDiscriminantTypes[i] = sourcePropertyType.flags & 1048576 /* Union */ ? sourcePropertyType.types : [sourcePropertyType];
-          excludedProperties.add(sourceProperty.escapedName);
-        }
-        const discriminantCombinations = cartesianProduct(sourceDiscriminantTypes);
-        const matchingTypes = [];
-        for (const combination of discriminantCombinations) {
-          let hasMatch = false;
-          outer:
-            for (const type of target2.types) {
-              for (let i = 0; i < sourcePropertiesFiltered.length; i++) {
-                const sourceProperty = sourcePropertiesFiltered[i];
-                const targetProperty = getPropertyOfType(type, sourceProperty.escapedName);
-                if (!targetProperty)
-                  continue outer;
-                if (sourceProperty === targetProperty)
-                  continue;
-                const related = propertyRelatedTo(
-                  source2,
-                  target2,
-                  sourceProperty,
-                  targetProperty,
-                  (_) => combination[i],
-                  /*reportErrors*/
-                  false,
-                  0 /* None */,
-                  /*skipOptional*/
-                  strictNullChecks || relation === comparableRelation
-                );
-                if (!related) {
-                  continue outer;
-                }
-              }
-              pushIfUnique(matchingTypes, type, equateValues);
-              hasMatch = true;
-            }
-          if (!hasMatch) {
-            return 0 /* False */;
-          }
-        }
-        let result2 = -1 /* True */;
-        for (const type of matchingTypes) {
-          result2 &= propertiesRelatedTo(
-            source2,
-            type,
-            /*reportErrors*/
-            false,
-            excludedProperties,
-            /*optionalsOnly*/
-            false,
-            0 /* None */
-          );
-          if (result2) {
-            result2 &= signaturesRelatedTo(
-              source2,
-              type,
-              0 /* Call */,
-              /*reportErrors*/
-              false,
-              0 /* None */
-            );
-            if (result2) {
-              result2 &= signaturesRelatedTo(
-                source2,
-                type,
-                1 /* Construct */,
-                /*reportErrors*/
-                false,
-                0 /* None */
-              );
-              if (result2 && !(isTupleType(source2) && isTupleType(type))) {
-                result2 &= indexSignaturesRelatedTo(
-                  source2,
-                  type,
-                  /*sourceIsPrimitive*/
-                  false,
-                  /*reportErrors*/
-                  false,
-                  0 /* None */
-                );
-              }
-            }
-          }
-          if (!result2) {
-            return result2;
-          }
-        }
-        return result2;
-      }
-      function excludeProperties(properties, excludedProperties) {
-        if (!excludedProperties || properties.length === 0)
-          return properties;
-        let result2;
-        for (let i = 0; i < properties.length; i++) {
-          if (!excludedProperties.has(properties[i].escapedName)) {
-            if (result2) {
-              result2.push(properties[i]);
-            }
-          } else if (!result2) {
-            result2 = properties.slice(0, i);
-          }
-        }
-        return result2 || properties;
-      }
-      function isPropertySymbolTypeRelated(sourceProp, targetProp, getTypeOfSourceProperty, reportErrors2, intersectionState) {
-        const targetIsOptional = strictNullChecks && !!(getCheckFlags(targetProp) & 48 /* Partial */);
-        const effectiveTarget = addOptionality(
-          getNonMissingTypeOfSymbol(targetProp),
-          /*isProperty*/
-          false,
-          targetIsOptional
-        );
-        const effectiveSource = getTypeOfSourceProperty(sourceProp);
-        return isRelatedTo(
-          effectiveSource,
-          effectiveTarget,
-          3 /* Both */,
-          reportErrors2,
-          /*headMessage*/
-          void 0,
-          intersectionState
-        );
-      }
-      function propertyRelatedTo(source2, target2, sourceProp, targetProp, getTypeOfSourceProperty, reportErrors2, intersectionState, skipOptional) {
-        const sourcePropFlags = getDeclarationModifierFlagsFromSymbol(sourceProp);
-        const targetPropFlags = getDeclarationModifierFlagsFromSymbol(targetProp);
-        if (sourcePropFlags & 8 /* Private */ || targetPropFlags & 8 /* Private */) {
-          if (sourceProp.valueDeclaration !== targetProp.valueDeclaration) {
-            if (reportErrors2) {
-              if (sourcePropFlags & 8 /* Private */ && targetPropFlags & 8 /* Private */) {
-                reportError(Diagnostics.Types_have_separate_declarations_of_a_private_property_0, symbolToString(targetProp));
-              } else {
-                reportError(
-                  Diagnostics.Property_0_is_private_in_type_1_but_not_in_type_2,
-                  symbolToString(targetProp),
-                  typeToString(sourcePropFlags & 8 /* Private */ ? source2 : target2),
-                  typeToString(sourcePropFlags & 8 /* Private */ ? target2 : source2)
-                );
-              }
-            }
-            return 0 /* False */;
-          }
-        } else if (targetPropFlags & 16 /* Protected */) {
-          if (!isValidOverrideOf(sourceProp, targetProp)) {
-            if (reportErrors2) {
-              reportError(
-                Diagnostics.Property_0_is_protected_but_type_1_is_not_a_class_derived_from_2,
-                symbolToString(targetProp),
-                typeToString(getDeclaringClass(sourceProp) || source2),
-                typeToString(getDeclaringClass(targetProp) || target2)
-              );
-            }
-            return 0 /* False */;
-          }
-        } else if (sourcePropFlags & 16 /* Protected */) {
-          if (reportErrors2) {
-            reportError(
-              Diagnostics.Property_0_is_protected_in_type_1_but_public_in_type_2,
-              symbolToString(targetProp),
-              typeToString(source2),
-              typeToString(target2)
-            );
-          }
-          return 0 /* False */;
-        }
-        if (relation === strictSubtypeRelation && isReadonlySymbol(sourceProp) && !isReadonlySymbol(targetProp)) {
-          return 0 /* False */;
-        }
-        const related = isPropertySymbolTypeRelated(sourceProp, targetProp, getTypeOfSourceProperty, reportErrors2, intersectionState);
-        if (!related) {
-          if (reportErrors2) {
-            reportIncompatibleError(Diagnostics.Types_of_property_0_are_incompatible, symbolToString(targetProp));
-          }
-          return 0 /* False */;
-        }
-        if (!skipOptional && sourceProp.flags & 16777216 /* Optional */ && targetProp.flags & 106500 /* ClassMember */ && !(targetProp.flags & 16777216 /* Optional */)) {
-          if (reportErrors2) {
-            reportError(
-              Diagnostics.Property_0_is_optional_in_type_1_but_required_in_type_2,
-              symbolToString(targetProp),
-              typeToString(source2),
-              typeToString(target2)
-            );
-          }
-          return 0 /* False */;
-        }
-        return related;
-      }
-      function reportUnmatchedProperty(source2, target2, unmatchedProperty, requireOptionalProperties) {
-        let shouldSkipElaboration = false;
-        if (unmatchedProperty.valueDeclaration && isNamedDeclaration(unmatchedProperty.valueDeclaration) && isPrivateIdentifier(unmatchedProperty.valueDeclaration.name) && source2.symbol && source2.symbol.flags & 32 /* Class */) {
-          const privateIdentifierDescription = unmatchedProperty.valueDeclaration.name.escapedText;
-          const symbolTableKey = getSymbolNameForPrivateIdentifier(source2.symbol, privateIdentifierDescription);
-          if (symbolTableKey && getPropertyOfType(source2, symbolTableKey)) {
-            const sourceName = factory.getDeclarationName(source2.symbol.valueDeclaration);
-            const targetName = factory.getDeclarationName(target2.symbol.valueDeclaration);
-            reportError(
-              Diagnostics.Property_0_in_type_1_refers_to_a_different_member_that_cannot_be_accessed_from_within_type_2,
-              diagnosticName(privateIdentifierDescription),
-              diagnosticName(sourceName.escapedText === "" ? anon : sourceName),
-              diagnosticName(targetName.escapedText === "" ? anon : targetName)
-            );
-            return;
-          }
-        }
-        const props = arrayFrom(getUnmatchedProperties(
-          source2,
-          target2,
-          requireOptionalProperties,
-          /*matchDiscriminantProperties*/
-          false
-        ));
-        if (!headMessage || headMessage.code !== Diagnostics.Class_0_incorrectly_implements_interface_1.code && headMessage.code !== Diagnostics.Class_0_incorrectly_implements_class_1_Did_you_mean_to_extend_1_and_inherit_its_members_as_a_subclass.code) {
-          shouldSkipElaboration = true;
-        }
-        if (props.length === 1) {
-          const propName = symbolToString(
-            unmatchedProperty,
-            /*enclosingDeclaration*/
-            void 0,
-            0 /* None */,
-            4 /* AllowAnyNodeKind */ | 16 /* WriteComputedProps */
-          );
-          reportError(Diagnostics.Property_0_is_missing_in_type_1_but_required_in_type_2, propName, ...getTypeNamesForErrorDisplay(source2, target2));
-          if (length(unmatchedProperty.declarations)) {
-            associateRelatedInfo(createDiagnosticForNode(unmatchedProperty.declarations[0], Diagnostics._0_is_declared_here, propName));
-          }
-          if (shouldSkipElaboration && errorInfo) {
-            overrideNextErrorInfo++;
-          }
-        } else if (tryElaborateArrayLikeErrors(
-          source2,
-          target2,
-          /*reportErrors*/
-          false
-        )) {
-          if (props.length > 5) {
-            reportError(Diagnostics.Type_0_is_missing_the_following_properties_from_type_1_Colon_2_and_3_more, typeToString(source2), typeToString(target2), map(props.slice(0, 4), (p) => symbolToString(p)).join(", "), props.length - 4);
-          } else {
-            reportError(Diagnostics.Type_0_is_missing_the_following_properties_from_type_1_Colon_2, typeToString(source2), typeToString(target2), map(props, (p) => symbolToString(p)).join(", "));
-          }
-          if (shouldSkipElaboration && errorInfo) {
-            overrideNextErrorInfo++;
-          }
-        }
-      }
-      function propertiesRelatedTo(source2, target2, reportErrors2, excludedProperties, optionalsOnly, intersectionState) {
-        if (relation === identityRelation) {
-          return propertiesIdenticalTo(source2, target2, excludedProperties);
-        }
-        let result2 = -1 /* True */;
-        if (isTupleType(target2)) {
-          if (isArrayOrTupleType(source2)) {
-            if (!target2.target.readonly && (isReadonlyArrayType(source2) || isTupleType(source2) && source2.target.readonly)) {
-              return 0 /* False */;
-            }
-            const sourceArity = getTypeReferenceArity(source2);
-            const targetArity = getTypeReferenceArity(target2);
-            const sourceRestFlag = isTupleType(source2) ? source2.target.combinedFlags & 4 /* Rest */ : 4 /* Rest */;
-            const targetRestFlag = target2.target.combinedFlags & 4 /* Rest */;
-            const sourceMinLength = isTupleType(source2) ? source2.target.minLength : 0;
-            const targetMinLength = target2.target.minLength;
-            if (!sourceRestFlag && sourceArity < targetMinLength) {
-              if (reportErrors2) {
-                reportError(Diagnostics.Source_has_0_element_s_but_target_requires_1, sourceArity, targetMinLength);
-              }
-              return 0 /* False */;
-            }
-            if (!targetRestFlag && targetArity < sourceMinLength) {
-              if (reportErrors2) {
-                reportError(Diagnostics.Source_has_0_element_s_but_target_allows_only_1, sourceMinLength, targetArity);
-              }
-              return 0 /* False */;
-            }
-            if (!targetRestFlag && (sourceRestFlag || targetArity < sourceArity)) {
-              if (reportErrors2) {
-                if (sourceMinLength < targetMinLength) {
-                  reportError(Diagnostics.Target_requires_0_element_s_but_source_may_have_fewer, targetMinLength);
-                } else {
-                  reportError(Diagnostics.Target_allows_only_0_element_s_but_source_may_have_more, targetArity);
-                }
-              }
-              return 0 /* False */;
-            }
-            const sourceTypeArguments = getTypeArguments(source2);
-            const targetTypeArguments = getTypeArguments(target2);
-            const targetStartCount = getStartElementCount(target2.target, 11 /* NonRest */);
-            const targetEndCount = getEndElementCount(target2.target, 11 /* NonRest */);
-            const targetHasRestElement = target2.target.hasRestElement;
-            let canExcludeDiscriminants = !!excludedProperties;
-            for (let sourcePosition = 0; sourcePosition < sourceArity; sourcePosition++) {
-              const sourceFlags = isTupleType(source2) ? source2.target.elementFlags[sourcePosition] : 4 /* Rest */;
-              const sourcePositionFromEnd = sourceArity - 1 - sourcePosition;
-              const targetPosition = targetHasRestElement && sourcePosition >= targetStartCount ? targetArity - 1 - Math.min(sourcePositionFromEnd, targetEndCount) : sourcePosition;
-              const targetFlags = target2.target.elementFlags[targetPosition];
-              if (targetFlags & 8 /* Variadic */ && !(sourceFlags & 8 /* Variadic */)) {
-                if (reportErrors2) {
-                  reportError(Diagnostics.Source_provides_no_match_for_variadic_element_at_position_0_in_target, targetPosition);
-                }
-                return 0 /* False */;
-              }
-              if (sourceFlags & 8 /* Variadic */ && !(targetFlags & 12 /* Variable */)) {
-                if (reportErrors2) {
-                  reportError(Diagnostics.Variadic_element_at_position_0_in_source_does_not_match_element_at_position_1_in_target, sourcePosition, targetPosition);
-                }
-                return 0 /* False */;
-              }
-              if (targetFlags & 1 /* Required */ && !(sourceFlags & 1 /* Required */)) {
-                if (reportErrors2) {
-                  reportError(Diagnostics.Source_provides_no_match_for_required_element_at_position_0_in_target, targetPosition);
-                }
-                return 0 /* False */;
-              }
-              if (canExcludeDiscriminants) {
-                if (sourceFlags & 12 /* Variable */ || targetFlags & 12 /* Variable */) {
-                  canExcludeDiscriminants = false;
-                }
-                if (canExcludeDiscriminants && (excludedProperties == null ? void 0 : excludedProperties.has("" + sourcePosition))) {
-                  continue;
-                }
-              }
-              const sourceType = removeMissingType(sourceTypeArguments[sourcePosition], !!(sourceFlags & targetFlags & 2 /* Optional */));
-              const targetType = targetTypeArguments[targetPosition];
-              const targetCheckType = sourceFlags & 8 /* Variadic */ && targetFlags & 4 /* Rest */ ? createArrayType(targetType) : removeMissingType(targetType, !!(targetFlags & 2 /* Optional */));
-              const related = isRelatedTo(
-                sourceType,
-                targetCheckType,
-                3 /* Both */,
-                reportErrors2,
-                /*headMessage*/
-                void 0,
-                intersectionState
-              );
-              if (!related) {
-                if (reportErrors2 && (targetArity > 1 || sourceArity > 1)) {
-                  if (targetHasRestElement && sourcePosition >= targetStartCount && sourcePositionFromEnd >= targetEndCount && targetStartCount !== sourceArity - targetEndCount - 1) {
-                    reportIncompatibleError(Diagnostics.Type_at_positions_0_through_1_in_source_is_not_compatible_with_type_at_position_2_in_target, targetStartCount, sourceArity - targetEndCount - 1, targetPosition);
-                  } else {
-                    reportIncompatibleError(Diagnostics.Type_at_position_0_in_source_is_not_compatible_with_type_at_position_1_in_target, sourcePosition, targetPosition);
-                  }
-                }
-                return 0 /* False */;
-              }
-              result2 &= related;
-            }
-            return result2;
-          }
-          if (target2.target.combinedFlags & 12 /* Variable */) {
-            return 0 /* False */;
-          }
-        }
-        const requireOptionalProperties = (relation === subtypeRelation || relation === strictSubtypeRelation) && !isObjectLiteralType2(source2) && !isEmptyArrayLiteralType(source2) && !isTupleType(source2);
-        const unmatchedProperty = getUnmatchedProperty(
-          source2,
-          target2,
-          requireOptionalProperties,
-          /*matchDiscriminantProperties*/
-          false
-        );
-        if (unmatchedProperty) {
-          if (reportErrors2 && shouldReportUnmatchedPropertyError(source2, target2)) {
-            reportUnmatchedProperty(source2, target2, unmatchedProperty, requireOptionalProperties);
-          }
-          return 0 /* False */;
-        }
-        if (isObjectLiteralType2(target2)) {
-          for (const sourceProp of excludeProperties(getPropertiesOfType(source2), excludedProperties)) {
-            if (!getPropertyOfObjectType(target2, sourceProp.escapedName)) {
-              const sourceType = getTypeOfSymbol(sourceProp);
-              if (!(sourceType.flags & 32768 /* Undefined */)) {
-                if (reportErrors2) {
-                  reportError(Diagnostics.Property_0_does_not_exist_on_type_1, symbolToString(sourceProp), typeToString(target2));
-                }
-                return 0 /* False */;
-              }
-            }
-          }
-        }
-        const properties = getPropertiesOfType(target2);
-        const numericNamesOnly = isTupleType(source2) && isTupleType(target2);
-        for (const targetProp of excludeProperties(properties, excludedProperties)) {
-          const name = targetProp.escapedName;
-          if (!(targetProp.flags & 4194304 /* Prototype */) && (!numericNamesOnly || isNumericLiteralName(name) || name === "length") && (!optionalsOnly || targetProp.flags & 16777216 /* Optional */)) {
-            const sourceProp = getPropertyOfType(source2, name);
-            if (sourceProp && sourceProp !== targetProp) {
-              const related = propertyRelatedTo(source2, target2, sourceProp, targetProp, getNonMissingTypeOfSymbol, reportErrors2, intersectionState, relation === comparableRelation);
-              if (!related) {
-                return 0 /* False */;
-              }
-              result2 &= related;
-            }
-          }
-        }
-        return result2;
-      }
-      function propertiesIdenticalTo(source2, target2, excludedProperties) {
-        if (!(source2.flags & 524288 /* Object */ && target2.flags & 524288 /* Object */)) {
-          return 0 /* False */;
-        }
-        const sourceProperties = excludeProperties(getPropertiesOfObjectType(source2), excludedProperties);
-        const targetProperties = excludeProperties(getPropertiesOfObjectType(target2), excludedProperties);
-        if (sourceProperties.length !== targetProperties.length) {
-          return 0 /* False */;
-        }
-        let result2 = -1 /* True */;
-        for (const sourceProp of sourceProperties) {
-          const targetProp = getPropertyOfObjectType(target2, sourceProp.escapedName);
-          if (!targetProp) {
-            return 0 /* False */;
-          }
-          const related = compareProperties2(sourceProp, targetProp, isRelatedTo);
-          if (!related) {
-            return 0 /* False */;
-          }
-          result2 &= related;
-        }
-        return result2;
-      }
-      function signaturesRelatedTo(source2, target2, kind, reportErrors2, intersectionState) {
-        var _a2, _b;
-        if (relation === identityRelation) {
-          return signaturesIdenticalTo(source2, target2, kind);
-        }
-        if (target2 === anyFunctionType || source2 === anyFunctionType) {
-          return -1 /* True */;
-        }
-        const sourceIsJSConstructor = source2.symbol && isJSConstructor(source2.symbol.valueDeclaration);
-        const targetIsJSConstructor = target2.symbol && isJSConstructor(target2.symbol.valueDeclaration);
-        const sourceSignatures = getSignaturesOfType(source2, sourceIsJSConstructor && kind === 1 /* Construct */ ? 0 /* Call */ : kind);
-        const targetSignatures = getSignaturesOfType(target2, targetIsJSConstructor && kind === 1 /* Construct */ ? 0 /* Call */ : kind);
-        if (kind === 1 /* Construct */ && sourceSignatures.length && targetSignatures.length) {
-          const sourceIsAbstract = !!(sourceSignatures[0].flags & 4 /* Abstract */);
-          const targetIsAbstract = !!(targetSignatures[0].flags & 4 /* Abstract */);
-          if (sourceIsAbstract && !targetIsAbstract) {
-            if (reportErrors2) {
-              reportError(Diagnostics.Cannot_assign_an_abstract_constructor_type_to_a_non_abstract_constructor_type);
-            }
-            return 0 /* False */;
-          }
-          if (!constructorVisibilitiesAreCompatible(sourceSignatures[0], targetSignatures[0], reportErrors2)) {
-            return 0 /* False */;
-          }
-        }
-        let result2 = -1 /* True */;
-        const incompatibleReporter = kind === 1 /* Construct */ ? reportIncompatibleConstructSignatureReturn : reportIncompatibleCallSignatureReturn;
-        const sourceObjectFlags = getObjectFlags(source2);
-        const targetObjectFlags = getObjectFlags(target2);
-        if (sourceObjectFlags & 64 /* Instantiated */ && targetObjectFlags & 64 /* Instantiated */ && source2.symbol === target2.symbol || sourceObjectFlags & 4 /* Reference */ && targetObjectFlags & 4 /* Reference */ && source2.target === target2.target) {
-          for (let i = 0; i < targetSignatures.length; i++) {
-            const related = signatureRelatedTo(
-              sourceSignatures[i],
-              targetSignatures[i],
-              /*erase*/
-              true,
-              reportErrors2,
-              intersectionState,
-              incompatibleReporter(sourceSignatures[i], targetSignatures[i])
-            );
-            if (!related) {
-              return 0 /* False */;
-            }
-            result2 &= related;
-          }
-        } else if (sourceSignatures.length === 1 && targetSignatures.length === 1) {
-          const eraseGenerics = relation === comparableRelation || !!compilerOptions.noStrictGenericChecks;
-          const sourceSignature = first(sourceSignatures);
-          const targetSignature = first(targetSignatures);
-          result2 = signatureRelatedTo(sourceSignature, targetSignature, eraseGenerics, reportErrors2, intersectionState, incompatibleReporter(sourceSignature, targetSignature));
-          if (!result2 && reportErrors2 && kind === 1 /* Construct */ && sourceObjectFlags & targetObjectFlags && (((_a2 = targetSignature.declaration) == null ? void 0 : _a2.kind) === 175 /* Constructor */ || ((_b = sourceSignature.declaration) == null ? void 0 : _b.kind) === 175 /* Constructor */)) {
-            const constructSignatureToString = (signature) => signatureToString(
-              signature,
-              /*enclosingDeclaration*/
-              void 0,
-              262144 /* WriteArrowStyleSignature */,
-              kind
-            );
-            reportError(Diagnostics.Type_0_is_not_assignable_to_type_1, constructSignatureToString(sourceSignature), constructSignatureToString(targetSignature));
-            reportError(Diagnostics.Types_of_construct_signatures_are_incompatible);
-            return result2;
-          }
-        } else {
-          outer:
-            for (const t of targetSignatures) {
-              const saveErrorInfo = captureErrorCalculationState();
-              let shouldElaborateErrors = reportErrors2;
-              for (const s of sourceSignatures) {
-                const related = signatureRelatedTo(
-                  s,
-                  t,
-                  /*erase*/
-                  true,
-                  shouldElaborateErrors,
-                  intersectionState,
-                  incompatibleReporter(s, t)
-                );
-                if (related) {
-                  result2 &= related;
-                  resetErrorInfo(saveErrorInfo);
-                  continue outer;
-                }
-                shouldElaborateErrors = false;
-              }
-              if (shouldElaborateErrors) {
-                reportError(
-                  Diagnostics.Type_0_provides_no_match_for_the_signature_1,
-                  typeToString(source2),
-                  signatureToString(
-                    t,
-                    /*enclosingDeclaration*/
-                    void 0,
-                    /*flags*/
-                    void 0,
-                    kind
-                  )
-                );
-              }
-              return 0 /* False */;
-            }
-        }
-        return result2;
-      }
-      function shouldReportUnmatchedPropertyError(source2, target2) {
-        const typeCallSignatures = getSignaturesOfStructuredType(source2, 0 /* Call */);
-        const typeConstructSignatures = getSignaturesOfStructuredType(source2, 1 /* Construct */);
-        const typeProperties = getPropertiesOfObjectType(source2);
-        if ((typeCallSignatures.length || typeConstructSignatures.length) && !typeProperties.length) {
-          if (getSignaturesOfType(target2, 0 /* Call */).length && typeCallSignatures.length || getSignaturesOfType(target2, 1 /* Construct */).length && typeConstructSignatures.length) {
-            return true;
-          }
-          return false;
-        }
-        return true;
-      }
-      function reportIncompatibleCallSignatureReturn(siga, sigb) {
-        if (siga.parameters.length === 0 && sigb.parameters.length === 0) {
-          return (source2, target2) => reportIncompatibleError(Diagnostics.Call_signatures_with_no_arguments_have_incompatible_return_types_0_and_1, typeToString(source2), typeToString(target2));
-        }
-        return (source2, target2) => reportIncompatibleError(Diagnostics.Call_signature_return_types_0_and_1_are_incompatible, typeToString(source2), typeToString(target2));
-      }
-      function reportIncompatibleConstructSignatureReturn(siga, sigb) {
-        if (siga.parameters.length === 0 && sigb.parameters.length === 0) {
-          return (source2, target2) => reportIncompatibleError(Diagnostics.Construct_signatures_with_no_arguments_have_incompatible_return_types_0_and_1, typeToString(source2), typeToString(target2));
-        }
-        return (source2, target2) => reportIncompatibleError(Diagnostics.Construct_signature_return_types_0_and_1_are_incompatible, typeToString(source2), typeToString(target2));
-      }
-      function signatureRelatedTo(source2, target2, erase, reportErrors2, intersectionState, incompatibleReporter) {
-        const checkMode = relation === subtypeRelation ? 16 /* StrictTopSignature */ : relation === strictSubtypeRelation ? 16 /* StrictTopSignature */ | 8 /* StrictArity */ : 0 /* None */;
-        return compareSignaturesRelated(
-          erase ? getErasedSignature(source2) : source2,
-          erase ? getErasedSignature(target2) : target2,
-          checkMode,
-          reportErrors2,
-          reportError,
-          incompatibleReporter,
-          isRelatedToWorker2,
-          reportUnreliableMapper
-        );
-        function isRelatedToWorker2(source3, target3, reportErrors3) {
-          return isRelatedTo(
-            source3,
-            target3,
-            3 /* Both */,
-            reportErrors3,
-            /*headMessage*/
-            void 0,
-            intersectionState
-          );
-        }
-      }
-      function signaturesIdenticalTo(source2, target2, kind) {
-        const sourceSignatures = getSignaturesOfType(source2, kind);
-        const targetSignatures = getSignaturesOfType(target2, kind);
-        if (sourceSignatures.length !== targetSignatures.length) {
-          return 0 /* False */;
-        }
-        let result2 = -1 /* True */;
-        for (let i = 0; i < sourceSignatures.length; i++) {
-          const related = compareSignaturesIdentical(
-            sourceSignatures[i],
-            targetSignatures[i],
-            /*partialMatch*/
-            false,
-            /*ignoreThisTypes*/
-            false,
-            /*ignoreReturnTypes*/
-            false,
-            isRelatedTo
-          );
-          if (!related) {
-            return 0 /* False */;
-          }
-          result2 &= related;
-        }
-        return result2;
-      }
-      function membersRelatedToIndexInfo(source2, targetInfo, reportErrors2, intersectionState) {
-        let result2 = -1 /* True */;
-        const keyType = targetInfo.keyType;
-        const props = source2.flags & 2097152 /* Intersection */ ? getPropertiesOfUnionOrIntersectionType(source2) : getPropertiesOfObjectType(source2);
-        for (const prop of props) {
-          if (isIgnoredJsxProperty(source2, prop)) {
-            continue;
-          }
-          if (isApplicableIndexType(getLiteralTypeFromProperty(prop, 8576 /* StringOrNumberLiteralOrUnique */), keyType)) {
-            const propType = getNonMissingTypeOfSymbol(prop);
-            const type = exactOptionalPropertyTypes || propType.flags & 32768 /* Undefined */ || keyType === numberType || !(prop.flags & 16777216 /* Optional */) ? propType : getTypeWithFacts(propType, 524288 /* NEUndefined */);
-            const related = isRelatedTo(
-              type,
-              targetInfo.type,
-              3 /* Both */,
-              reportErrors2,
-              /*headMessage*/
-              void 0,
-              intersectionState
-            );
-            if (!related) {
-              if (reportErrors2) {
-                reportError(Diagnostics.Property_0_is_incompatible_with_index_signature, symbolToString(prop));
-              }
-              return 0 /* False */;
-            }
-            result2 &= related;
-          }
-        }
-        for (const info of getIndexInfosOfType(source2)) {
-          if (isApplicableIndexType(info.keyType, keyType)) {
-            const related = indexInfoRelatedTo(info, targetInfo, reportErrors2, intersectionState);
-            if (!related) {
-              return 0 /* False */;
-            }
-            result2 &= related;
-          }
-        }
-        return result2;
-      }
-      function indexInfoRelatedTo(sourceInfo, targetInfo, reportErrors2, intersectionState) {
-        const related = isRelatedTo(
-          sourceInfo.type,
-          targetInfo.type,
-          3 /* Both */,
-          reportErrors2,
-          /*headMessage*/
-          void 0,
-          intersectionState
-        );
-        if (!related && reportErrors2) {
-          if (sourceInfo.keyType === targetInfo.keyType) {
-            reportError(Diagnostics._0_index_signatures_are_incompatible, typeToString(sourceInfo.keyType));
-          } else {
-            reportError(Diagnostics._0_and_1_index_signatures_are_incompatible, typeToString(sourceInfo.keyType), typeToString(targetInfo.keyType));
-          }
-        }
-        return related;
-      }
-      function indexSignaturesRelatedTo(source2, target2, sourceIsPrimitive, reportErrors2, intersectionState) {
-        if (relation === identityRelation) {
-          return indexSignaturesIdenticalTo(source2, target2);
-        }
-        const indexInfos = getIndexInfosOfType(target2);
-        const targetHasStringIndex = some(indexInfos, (info) => info.keyType === stringType);
-        let result2 = -1 /* True */;
-        for (const targetInfo of indexInfos) {
-          const related = relation !== strictSubtypeRelation && !sourceIsPrimitive && targetHasStringIndex && targetInfo.type.flags & 1 /* Any */ ? -1 /* True */ : isGenericMappedType(source2) && targetHasStringIndex ? isRelatedTo(getTemplateTypeFromMappedType(source2), targetInfo.type, 3 /* Both */, reportErrors2) : typeRelatedToIndexInfo(source2, targetInfo, reportErrors2, intersectionState);
-          if (!related) {
-            return 0 /* False */;
-          }
-          result2 &= related;
-        }
-        return result2;
-      }
-      function typeRelatedToIndexInfo(source2, targetInfo, reportErrors2, intersectionState) {
-        const sourceInfo = getApplicableIndexInfo(source2, targetInfo.keyType);
-        if (sourceInfo) {
-          return indexInfoRelatedTo(sourceInfo, targetInfo, reportErrors2, intersectionState);
-        }
-        if (!(intersectionState & 1 /* Source */) && (relation !== strictSubtypeRelation || getObjectFlags(source2) & 8192 /* FreshLiteral */) && isObjectTypeWithInferableIndex(source2)) {
-          return membersRelatedToIndexInfo(source2, targetInfo, reportErrors2, intersectionState);
-        }
-        if (reportErrors2) {
-          reportError(Diagnostics.Index_signature_for_type_0_is_missing_in_type_1, typeToString(targetInfo.keyType), typeToString(source2));
-        }
-        return 0 /* False */;
-      }
-      function indexSignaturesIdenticalTo(source2, target2) {
-        const sourceInfos = getIndexInfosOfType(source2);
-        const targetInfos = getIndexInfosOfType(target2);
-        if (sourceInfos.length !== targetInfos.length) {
-          return 0 /* False */;
-        }
-        for (const targetInfo of targetInfos) {
-          const sourceInfo = getIndexInfoOfType(source2, targetInfo.keyType);
-          if (!(sourceInfo && isRelatedTo(sourceInfo.type, targetInfo.type, 3 /* Both */) && sourceInfo.isReadonly === targetInfo.isReadonly)) {
-            return 0 /* False */;
-          }
-        }
-        return -1 /* True */;
-      }
-      function constructorVisibilitiesAreCompatible(sourceSignature, targetSignature, reportErrors2) {
-        if (!sourceSignature.declaration || !targetSignature.declaration) {
-          return true;
-        }
-        const sourceAccessibility = getSelectedEffectiveModifierFlags(sourceSignature.declaration, 24 /* NonPublicAccessibilityModifier */);
-        const targetAccessibility = getSelectedEffectiveModifierFlags(targetSignature.declaration, 24 /* NonPublicAccessibilityModifier */);
-        if (targetAccessibility === 8 /* Private */) {
-          return true;
-        }
-        if (targetAccessibility === 16 /* Protected */ && sourceAccessibility !== 8 /* Private */) {
-          return true;
-        }
-        if (targetAccessibility !== 16 /* Protected */ && !sourceAccessibility) {
-          return true;
-        }
-        if (reportErrors2) {
-          reportError(Diagnostics.Cannot_assign_a_0_constructor_type_to_a_1_constructor_type, visibilityToString(sourceAccessibility), visibilityToString(targetAccessibility));
-        }
-        return false;
-      }
-    }
-    function typeCouldHaveTopLevelSingletonTypes(type) {
-      if (type.flags & 16 /* Boolean */) {
-        return false;
-      }
-      if (type.flags & 3145728 /* UnionOrIntersection */) {
-        return !!forEach(type.types, typeCouldHaveTopLevelSingletonTypes);
-      }
-      if (type.flags & 465829888 /* Instantiable */) {
-        const constraint = getConstraintOfType(type);
-        if (constraint && constraint !== type) {
-          return typeCouldHaveTopLevelSingletonTypes(constraint);
-        }
-      }
-      return isUnitType(type) || !!(type.flags & 134217728 /* TemplateLiteral */) || !!(type.flags & 268435456 /* StringMapping */);
-    }
-    function getExactOptionalUnassignableProperties(source, target) {
-      if (isTupleType(source) && isTupleType(target))
-        return emptyArray;
-      return getPropertiesOfType(target).filter((targetProp) => isExactOptionalPropertyMismatch(getTypeOfPropertyOfType(source, targetProp.escapedName), getTypeOfSymbol(targetProp)));
-    }
-    function isExactOptionalPropertyMismatch(source, target) {
-      return !!source && !!target && maybeTypeOfKind(source, 32768 /* Undefined */) && !!containsMissingType(target);
-    }
-    function getExactOptionalProperties(type) {
-      return getPropertiesOfType(type).filter((targetProp) => containsMissingType(getTypeOfSymbol(targetProp)));
-    }
-    function getBestMatchingType(source, target, isRelatedTo = compareTypesAssignable) {
-      return findMatchingDiscriminantType(source, target, isRelatedTo) || findMatchingTypeReferenceOrTypeAliasReference(source, target) || findBestTypeForObjectLiteral(source, target) || findBestTypeForInvokable(source, target) || findMostOverlappyType(source, target);
-    }
-    function discriminateTypeByDiscriminableItems(target, discriminators, related) {
-      const types = target.types;
-      const include = types.map((t) => t.flags & 402784252 /* Primitive */ ? 0 /* False */ : -1 /* True */);
-      for (const [getDiscriminatingType, propertyName] of discriminators) {
-        let matched = false;
-        for (let i = 0; i < types.length; i++) {
-          if (include[i]) {
-            const targetType = getTypeOfPropertyOfType(types[i], propertyName);
-            if (targetType && related(getDiscriminatingType(), targetType)) {
-              matched = true;
-            } else {
-              include[i] = 3 /* Maybe */;
-            }
-          }
-        }
-        for (let i = 0; i < types.length; i++) {
-          if (include[i] === 3 /* Maybe */) {
-            include[i] = matched ? 0 /* False */ : -1 /* True */;
-          }
-        }
-      }
-      const filtered = contains(include, 0 /* False */) ? getUnionType(types.filter((_, i) => include[i])) : target;
-      return filtered.flags & 131072 /* Never */ ? target : filtered;
-    }
-    function isWeakType(type) {
-      if (type.flags & 524288 /* Object */) {
-        const resolved = resolveStructuredTypeMembers(type);
-        return resolved.callSignatures.length === 0 && resolved.constructSignatures.length === 0 && resolved.indexInfos.length === 0 && resolved.properties.length > 0 && every(resolved.properties, (p) => !!(p.flags & 16777216 /* Optional */));
-      }
-      if (type.flags & 2097152 /* Intersection */) {
-        return every(type.types, isWeakType);
-      }
-      return false;
-    }
-    function hasCommonProperties(source, target, isComparingJsxAttributes) {
-      for (const prop of getPropertiesOfType(source)) {
-        if (isKnownProperty(target, prop.escapedName, isComparingJsxAttributes)) {
-          return true;
-        }
-      }
-      return false;
-    }
-    function getVariances(type) {
-      return type === globalArrayType || type === globalReadonlyArrayType || type.objectFlags & 8 /* Tuple */ ? arrayVariances : getVariancesWorker(type.symbol, type.typeParameters);
-    }
-    function getAliasVariances(symbol) {
-      return getVariancesWorker(symbol, getSymbolLinks(symbol).typeParameters);
-    }
-    function getVariancesWorker(symbol, typeParameters = emptyArray) {
-      var _a, _b;
-      const links = getSymbolLinks(symbol);
-      if (!links.variances) {
-        (_a = tracing) == null ? void 0 : _a.push(tracing.Phase.CheckTypes, "getVariancesWorker", { arity: typeParameters.length, id: getTypeId(getDeclaredTypeOfSymbol(symbol)) });
-        const oldVarianceComputation = inVarianceComputation;
-        if (!inVarianceComputation) {
-          inVarianceComputation = true;
-          resolutionStart = resolutionTargets.length;
-        }
-        links.variances = emptyArray;
-        const variances = [];
-        for (const tp of typeParameters) {
-          const modifiers = getTypeParameterModifiers(tp);
-          let variance = modifiers & 65536 /* Out */ ? modifiers & 32768 /* In */ ? 0 /* Invariant */ : 1 /* Covariant */ : modifiers & 32768 /* In */ ? 2 /* Contravariant */ : void 0;
-          if (variance === void 0) {
-            let unmeasurable = false;
-            let unreliable = false;
-            const oldHandler = outofbandVarianceMarkerHandler;
-            outofbandVarianceMarkerHandler = (onlyUnreliable) => onlyUnreliable ? unreliable = true : unmeasurable = true;
-            const typeWithSuper = createMarkerType(symbol, tp, markerSuperType);
-            const typeWithSub = createMarkerType(symbol, tp, markerSubType);
-            variance = (isTypeAssignableTo(typeWithSub, typeWithSuper) ? 1 /* Covariant */ : 0) | (isTypeAssignableTo(typeWithSuper, typeWithSub) ? 2 /* Contravariant */ : 0);
-            if (variance === 3 /* Bivariant */ && isTypeAssignableTo(createMarkerType(symbol, tp, markerOtherType), typeWithSuper)) {
-              variance = 4 /* Independent */;
-            }
-            outofbandVarianceMarkerHandler = oldHandler;
-            if (unmeasurable || unreliable) {
-              if (unmeasurable) {
-                variance |= 8 /* Unmeasurable */;
-              }
-              if (unreliable) {
-                variance |= 16 /* Unreliable */;
-              }
-            }
-          }
-          variances.push(variance);
-        }
-        if (!oldVarianceComputation) {
-          inVarianceComputation = false;
-          resolutionStart = 0;
-        }
-        links.variances = variances;
-        (_b = tracing) == null ? void 0 : _b.pop({ variances: variances.map(Debug.formatVariance) });
-      }
-      return links.variances;
-    }
-    function createMarkerType(symbol, source, target) {
-      const mapper = makeUnaryTypeMapper(source, target);
-      const type = getDeclaredTypeOfSymbol(symbol);
-      if (isErrorType(type)) {
-        return type;
-      }
-      const result = symbol.flags & 524288 /* TypeAlias */ ? getTypeAliasInstantiation(symbol, instantiateTypes(getSymbolLinks(symbol).typeParameters, mapper)) : createTypeReference(type, instantiateTypes(type.typeParameters, mapper));
-      markerTypes.add(getTypeId(result));
-      return result;
-    }
-    function isMarkerType(type) {
-      return markerTypes.has(getTypeId(type));
-    }
-    function getTypeParameterModifiers(tp) {
-      var _a;
-      return reduceLeft((_a = tp.symbol) == null ? void 0 : _a.declarations, (modifiers, d) => modifiers | getEffectiveModifierFlags(d), 0 /* None */) & (32768 /* In */ | 65536 /* Out */ | 2048 /* Const */);
-    }
-    function hasCovariantVoidArgument(typeArguments, variances) {
-      for (let i = 0; i < variances.length; i++) {
-        if ((variances[i] & 7 /* VarianceMask */) === 1 /* Covariant */ && typeArguments[i].flags & 16384 /* Void */) {
-          return true;
-        }
-      }
-      return false;
-    }
-    function isUnconstrainedTypeParameter(type) {
-      return type.flags & 262144 /* TypeParameter */ && !getConstraintOfTypeParameter(type);
-    }
-    function isNonDeferredTypeReference(type) {
-      return !!(getObjectFlags(type) & 4 /* Reference */) && !type.node;
-    }
-    function isTypeReferenceWithGenericArguments(type) {
-      return isNonDeferredTypeReference(type) && some(getTypeArguments(type), (t) => !!(t.flags & 262144 /* TypeParameter */) || isTypeReferenceWithGenericArguments(t));
-    }
-    function getGenericTypeReferenceRelationKey(source, target, postFix, ignoreConstraints) {
-      const typeParameters = [];
-      let constraintMarker = "";
-      const sourceId = getTypeReferenceId(source, 0);
-      const targetId = getTypeReferenceId(target, 0);
-      return `${constraintMarker}${sourceId},${targetId}${postFix}`;
-      function getTypeReferenceId(type, depth = 0) {
-        let result = "" + type.target.id;
-        for (const t of getTypeArguments(type)) {
-          if (t.flags & 262144 /* TypeParameter */) {
-            if (ignoreConstraints || isUnconstrainedTypeParameter(t)) {
-              let index = typeParameters.indexOf(t);
-              if (index < 0) {
-                index = typeParameters.length;
-                typeParameters.push(t);
-              }
-              result += "=" + index;
-              continue;
-            }
-            constraintMarker = "*";
-          } else if (depth < 4 && isTypeReferenceWithGenericArguments(t)) {
-            result += "<" + getTypeReferenceId(t, depth + 1) + ">";
-            continue;
-          }
-          result += "-" + t.id;
-        }
-        return result;
-      }
-    }
-    function getRelationKey(source, target, intersectionState, relation, ignoreConstraints) {
-      if (relation === identityRelation && source.id > target.id) {
-        const temp = source;
-        source = target;
-        target = temp;
-      }
-      const postFix = intersectionState ? ":" + intersectionState : "";
-      return isTypeReferenceWithGenericArguments(source) && isTypeReferenceWithGenericArguments(target) ? getGenericTypeReferenceRelationKey(source, target, postFix, ignoreConstraints) : `${source.id},${target.id}${postFix}`;
-    }
-    function forEachProperty2(prop, callback) {
-      if (getCheckFlags(prop) & 6 /* Synthetic */) {
-        for (const t of prop.links.containingType.types) {
-          const p = getPropertyOfType(t, prop.escapedName);
-          const result = p && forEachProperty2(p, callback);
-          if (result) {
-            return result;
-          }
-        }
-        return void 0;
-      }
-      return callback(prop);
-    }
-    function getDeclaringClass(prop) {
-      return prop.parent && prop.parent.flags & 32 /* Class */ ? getDeclaredTypeOfSymbol(getParentOfSymbol(prop)) : void 0;
-    }
-    function getTypeOfPropertyInBaseClass(property) {
-      const classType = getDeclaringClass(property);
-      const baseClassType = classType && getBaseTypes(classType)[0];
-      return baseClassType && getTypeOfPropertyOfType(baseClassType, property.escapedName);
-    }
-    function isPropertyInClassDerivedFrom(prop, baseClass) {
-      return forEachProperty2(prop, (sp) => {
-        const sourceClass = getDeclaringClass(sp);
-        return sourceClass ? hasBaseType(sourceClass, baseClass) : false;
-      });
-    }
-    function isValidOverrideOf(sourceProp, targetProp) {
-      return !forEachProperty2(targetProp, (tp) => getDeclarationModifierFlagsFromSymbol(tp) & 16 /* Protected */ ? !isPropertyInClassDerivedFrom(sourceProp, getDeclaringClass(tp)) : false);
-    }
-    function isClassDerivedFromDeclaringClasses(checkClass, prop, writing) {
-      return forEachProperty2(prop, (p) => getDeclarationModifierFlagsFromSymbol(p, writing) & 16 /* Protected */ ? !hasBaseType(checkClass, getDeclaringClass(p)) : false) ? void 0 : checkClass;
-    }
-    function isDeeplyNestedType(type, stack, depth, maxDepth = 3) {
-      if (depth >= maxDepth) {
-        if (type.flags & 2097152 /* Intersection */) {
-          return some(type.types, (t) => isDeeplyNestedType(t, stack, depth, maxDepth));
-        }
-        const identity2 = getRecursionIdentity(type);
-        let count = 0;
-        let lastTypeId = 0;
-        for (let i = 0; i < depth; i++) {
-          const t = stack[i];
-          if (t.flags & 2097152 /* Intersection */ ? some(t.types, (u) => getRecursionIdentity(u) === identity2) : getRecursionIdentity(t) === identity2) {
-            if (t.id >= lastTypeId) {
-              count++;
-              if (count >= maxDepth) {
-                return true;
-              }
-            }
-            lastTypeId = t.id;
-          }
-        }
-      }
-      return false;
-    }
-    function getRecursionIdentity(type) {
-      if (type.flags & 524288 /* Object */ && !isObjectOrArrayLiteralType(type)) {
-        if (getObjectFlags(type) && 4 /* Reference */ && type.node) {
-          return type.node;
-        }
-        if (type.symbol && !(getObjectFlags(type) & 16 /* Anonymous */ && type.symbol.flags & 32 /* Class */)) {
-          return type.symbol;
-        }
-        if (isTupleType(type)) {
-          return type.target;
-        }
-      }
-      if (type.flags & 262144 /* TypeParameter */) {
-        return type.symbol;
-      }
-      if (type.flags & 8388608 /* IndexedAccess */) {
-        do {
-          type = type.objectType;
-        } while (type.flags & 8388608 /* IndexedAccess */);
-        return type;
-      }
-      if (type.flags & 16777216 /* Conditional */) {
-        return type.root;
-      }
-      return type;
-    }
-    function isPropertyIdenticalTo(sourceProp, targetProp) {
-      return compareProperties2(sourceProp, targetProp, compareTypesIdentical) !== 0 /* False */;
-    }
-    function compareProperties2(sourceProp, targetProp, compareTypes) {
-      if (sourceProp === targetProp) {
-        return -1 /* True */;
-      }
-      const sourcePropAccessibility = getDeclarationModifierFlagsFromSymbol(sourceProp) & 24 /* NonPublicAccessibilityModifier */;
-      const targetPropAccessibility = getDeclarationModifierFlagsFromSymbol(targetProp) & 24 /* NonPublicAccessibilityModifier */;
-      if (sourcePropAccessibility !== targetPropAccessibility) {
-        return 0 /* False */;
-      }
-      if (sourcePropAccessibility) {
-        if (getTargetSymbol(sourceProp) !== getTargetSymbol(targetProp)) {
-          return 0 /* False */;
-        }
-      } else {
-        if ((sourceProp.flags & 16777216 /* Optional */) !== (targetProp.flags & 16777216 /* Optional */)) {
-          return 0 /* False */;
-        }
-      }
-      if (isReadonlySymbol(sourceProp) !== isReadonlySymbol(targetProp)) {
-        return 0 /* False */;
-      }
-      return compareTypes(getTypeOfSymbol(sourceProp), getTypeOfSymbol(targetProp));
-    }
-    function isMatchingSignature(source, target, partialMatch) {
-      const sourceParameterCount = getParameterCount(source);
-      const targetParameterCount = getParameterCount(target);
-      const sourceMinArgumentCount = getMinArgumentCount(source);
-      const targetMinArgumentCount = getMinArgumentCount(target);
-      const sourceHasRestParameter = hasEffectiveRestParameter(source);
-      const targetHasRestParameter = hasEffectiveRestParameter(target);
-      if (sourceParameterCount === targetParameterCount && sourceMinArgumentCount === targetMinArgumentCount && sourceHasRestParameter === targetHasRestParameter) {
-        return true;
-      }
-      if (partialMatch && sourceMinArgumentCount <= targetMinArgumentCount) {
-        return true;
-      }
-      return false;
-    }
-    function compareSignaturesIdentical(source, target, partialMatch, ignoreThisTypes, ignoreReturnTypes, compareTypes) {
-      if (source === target) {
-        return -1 /* True */;
-      }
-      if (!isMatchingSignature(source, target, partialMatch)) {
-        return 0 /* False */;
-      }
-      if (length(source.typeParameters) !== length(target.typeParameters)) {
-        return 0 /* False */;
-      }
-      if (target.typeParameters) {
-        const mapper = createTypeMapper(source.typeParameters, target.typeParameters);
-        for (let i = 0; i < target.typeParameters.length; i++) {
-          const s = source.typeParameters[i];
-          const t = target.typeParameters[i];
-          if (!(s === t || compareTypes(instantiateType(getConstraintFromTypeParameter(s), mapper) || unknownType, getConstraintFromTypeParameter(t) || unknownType) && compareTypes(instantiateType(getDefaultFromTypeParameter(s), mapper) || unknownType, getDefaultFromTypeParameter(t) || unknownType))) {
-            return 0 /* False */;
-          }
-        }
-        source = instantiateSignature(
-          source,
-          mapper,
-          /*eraseTypeParameters*/
-          true
-        );
-      }
-      let result = -1 /* True */;
-      if (!ignoreThisTypes) {
-        const sourceThisType = getThisTypeOfSignature(source);
-        if (sourceThisType) {
-          const targetThisType = getThisTypeOfSignature(target);
-          if (targetThisType) {
-            const related = compareTypes(sourceThisType, targetThisType);
-            if (!related) {
-              return 0 /* False */;
-            }
-            result &= related;
-          }
-        }
-      }
-      const targetLen = getParameterCount(target);
-      for (let i = 0; i < targetLen; i++) {
-        const s = getTypeAtPosition(source, i);
-        const t = getTypeAtPosition(target, i);
-        const related = compareTypes(t, s);
-        if (!related) {
-          return 0 /* False */;
-        }
-        result &= related;
-      }
-      if (!ignoreReturnTypes) {
-        const sourceTypePredicate = getTypePredicateOfSignature(source);
-        const targetTypePredicate = getTypePredicateOfSignature(target);
-        result &= sourceTypePredicate || targetTypePredicate ? compareTypePredicatesIdentical(sourceTypePredicate, targetTypePredicate, compareTypes) : compareTypes(getReturnTypeOfSignature(source), getReturnTypeOfSignature(target));
-      }
-      return result;
-    }
-    function compareTypePredicatesIdentical(source, target, compareTypes) {
-      return !(source && target && typePredicateKindsMatch(source, target)) ? 0 /* False */ : source.type === target.type ? -1 /* True */ : source.type && target.type ? compareTypes(source.type, target.type) : 0 /* False */;
-    }
-    function literalTypesWithSameBaseType(types) {
-      let commonBaseType;
-      for (const t of types) {
-        if (!(t.flags & 131072 /* Never */)) {
-          const baseType = getBaseTypeOfLiteralType(t);
-          commonBaseType ?? (commonBaseType = baseType);
-          if (baseType === t || baseType !== commonBaseType) {
-            return false;
-          }
-        }
-      }
-      return true;
-    }
-    function getCombinedTypeFlags(types) {
-      return reduceLeft(types, (flags, t) => flags | (t.flags & 1048576 /* Union */ ? getCombinedTypeFlags(t.types) : t.flags), 0);
-    }
-    function getCommonSupertype(types) {
-      if (types.length === 1) {
-        return types[0];
-      }
-      const primaryTypes = strictNullChecks ? sameMap(types, (t) => filterType(t, (u) => !(u.flags & 98304 /* Nullable */))) : types;
-      const superTypeOrUnion = literalTypesWithSameBaseType(primaryTypes) ? getUnionType(primaryTypes) : reduceLeft(primaryTypes, (s, t) => isTypeSubtypeOf(s, t) ? t : s);
-      return primaryTypes === types ? superTypeOrUnion : getNullableType(superTypeOrUnion, getCombinedTypeFlags(types) & 98304 /* Nullable */);
-    }
-    function getCommonSubtype(types) {
-      return reduceLeft(types, (s, t) => isTypeSubtypeOf(t, s) ? t : s);
-    }
-    function isArrayType(type) {
-      return !!(getObjectFlags(type) & 4 /* Reference */) && (type.target === globalArrayType || type.target === globalReadonlyArrayType);
-    }
-    function isReadonlyArrayType(type) {
-      return !!(getObjectFlags(type) & 4 /* Reference */) && type.target === globalReadonlyArrayType;
-    }
-    function isArrayOrTupleType(type) {
-      return isArrayType(type) || isTupleType(type);
-    }
-    function isMutableArrayOrTuple(type) {
-      return isArrayType(type) && !isReadonlyArrayType(type) || isTupleType(type) && !type.target.readonly;
-    }
-    function getElementTypeOfArrayType(type) {
-      return isArrayType(type) ? getTypeArguments(type)[0] : void 0;
-    }
-    function isArrayLikeType(type) {
-      return isArrayType(type) || !(type.flags & 98304 /* Nullable */) && isTypeAssignableTo(type, anyReadonlyArrayType);
-    }
-    function getSingleBaseForNonAugmentingSubtype(type) {
-      if (!(getObjectFlags(type) & 4 /* Reference */) || !(getObjectFlags(type.target) & 3 /* ClassOrInterface */)) {
-        return void 0;
-      }
-      if (getObjectFlags(type) & 33554432 /* IdenticalBaseTypeCalculated */) {
-        return getObjectFlags(type) & 67108864 /* IdenticalBaseTypeExists */ ? type.cachedEquivalentBaseType : void 0;
-      }
-      type.objectFlags |= 33554432 /* IdenticalBaseTypeCalculated */;
-      const target = type.target;
-      if (getObjectFlags(target) & 1 /* Class */) {
-        const baseTypeNode = getBaseTypeNodeOfClass(target);
-        if (baseTypeNode && baseTypeNode.expression.kind !== 80 /* Identifier */ && baseTypeNode.expression.kind !== 210 /* PropertyAccessExpression */) {
-          return void 0;
-        }
-      }
-      const bases = getBaseTypes(target);
-      if (bases.length !== 1) {
-        return void 0;
-      }
-      if (getMembersOfSymbol(type.symbol).size) {
-        return void 0;
-      }
-      let instantiatedBase = !length(target.typeParameters) ? bases[0] : instantiateType(bases[0], createTypeMapper(target.typeParameters, getTypeArguments(type).slice(0, target.typeParameters.length)));
-      if (length(getTypeArguments(type)) > length(target.typeParameters)) {
-        instantiatedBase = getTypeWithThisArgument(instantiatedBase, last(getTypeArguments(type)));
-      }
-      type.objectFlags |= 67108864 /* IdenticalBaseTypeExists */;
-      return type.cachedEquivalentBaseType = instantiatedBase;
-    }
-    function isEmptyLiteralType(type) {
-      return strictNullChecks ? type === implicitNeverType : type === undefinedWideningType;
-    }
-    function isEmptyArrayLiteralType(type) {
-      const elementType = getElementTypeOfArrayType(type);
-      return !!elementType && isEmptyLiteralType(elementType);
-    }
-    function isTupleLikeType(type) {
-      return isTupleType(type) || !!getPropertyOfType(type, "0");
-    }
-    function isArrayOrTupleLikeType(type) {
-      return isArrayLikeType(type) || isTupleLikeType(type);
-    }
-    function getTupleElementType(type, index) {
-      const propType = getTypeOfPropertyOfType(type, "" + index);
-      if (propType) {
-        return propType;
-      }
-      if (everyType(type, isTupleType)) {
-        return mapType(type, (t) => {
-          const tupleType = t;
-          const restType = getRestTypeOfTupleType(tupleType);
-          if (!restType) {
-            return undefinedType;
-          }
-          if (compilerOptions.noUncheckedIndexedAccess && index >= tupleType.target.fixedLength + getEndElementCount(tupleType.target, 3 /* Fixed */)) {
-            return getUnionType([restType, undefinedType]);
-          }
-          return restType;
-        });
-      }
-      return void 0;
-    }
-    function isNeitherUnitTypeNorNever(type) {
-      return !(type.flags & (109472 /* Unit */ | 131072 /* Never */));
-    }
-    function isUnitType(type) {
-      return !!(type.flags & 109472 /* Unit */);
-    }
-    function isUnitLikeType(type) {
-      const t = getBaseConstraintOrType(type);
-      return t.flags & 2097152 /* Intersection */ ? some(t.types, isUnitType) : isUnitType(t);
-    }
-    function extractUnitType(type) {
-      return type.flags & 2097152 /* Intersection */ ? find(type.types, isUnitType) || type : type;
-    }
-    function isLiteralType(type) {
-      return type.flags & 16 /* Boolean */ ? true : type.flags & 1048576 /* Union */ ? type.flags & 1024 /* EnumLiteral */ ? true : every(type.types, isUnitType) : isUnitType(type);
-    }
-    function getBaseTypeOfLiteralType(type) {
-      return type.flags & 1056 /* EnumLike */ ? getBaseTypeOfEnumLikeType(type) : type.flags & (128 /* StringLiteral */ | 134217728 /* TemplateLiteral */ | 268435456 /* StringMapping */) ? stringType : type.flags & 256 /* NumberLiteral */ ? numberType : type.flags & 2048 /* BigIntLiteral */ ? bigintType : type.flags & 512 /* BooleanLiteral */ ? booleanType : type.flags & 1048576 /* Union */ ? getBaseTypeOfLiteralTypeUnion(type) : type;
-    }
-    function getBaseTypeOfLiteralTypeUnion(type) {
-      const key = `B${getTypeId(type)}`;
-      return getCachedType(key) ?? setCachedType(key, mapType(type, getBaseTypeOfLiteralType));
-    }
-    function getBaseTypeOfLiteralTypeForComparison(type) {
-      return type.flags & (128 /* StringLiteral */ | 134217728 /* TemplateLiteral */ | 268435456 /* StringMapping */) ? stringType : type.flags & (256 /* NumberLiteral */ | 32 /* Enum */) ? numberType : type.flags & 2048 /* BigIntLiteral */ ? bigintType : type.flags & 512 /* BooleanLiteral */ ? booleanType : type.flags & 1048576 /* Union */ ? mapType(type, getBaseTypeOfLiteralTypeForComparison) : type;
-    }
-    function getWidenedLiteralType(type) {
-      return type.flags & 1056 /* EnumLike */ && isFreshLiteralType(type) ? getBaseTypeOfEnumLikeType(type) : type.flags & 128 /* StringLiteral */ && isFreshLiteralType(type) ? stringType : type.flags & 256 /* NumberLiteral */ && isFreshLiteralType(type) ? numberType : type.flags & 2048 /* BigIntLiteral */ && isFreshLiteralType(type) ? bigintType : type.flags & 512 /* BooleanLiteral */ && isFreshLiteralType(type) ? booleanType : type.flags & 1048576 /* Union */ ? mapType(type, getWidenedLiteralType) : type;
-    }
-    function getWidenedUniqueESSymbolType(type) {
-      return type.flags & 8192 /* UniqueESSymbol */ ? esSymbolType : type.flags & 1048576 /* Union */ ? mapType(type, getWidenedUniqueESSymbolType) : type;
-    }
-    function getWidenedLiteralLikeTypeForContextualType(type, contextualType) {
-      if (!isLiteralOfContextualType(type, contextualType)) {
-        type = getWidenedUniqueESSymbolType(getWidenedLiteralType(type));
-      }
-      return getRegularTypeOfLiteralType(type);
-    }
-    function getWidenedLiteralLikeTypeForContextualReturnTypeIfNeeded(type, contextualSignatureReturnType, isAsync) {
-      if (type && isUnitType(type)) {
-        const contextualType = !contextualSignatureReturnType ? void 0 : isAsync ? getPromisedTypeOfPromise(contextualSignatureReturnType) : contextualSignatureReturnType;
-        type = getWidenedLiteralLikeTypeForContextualType(type, contextualType);
-      }
-      return type;
-    }
-    function getWidenedLiteralLikeTypeForContextualIterationTypeIfNeeded(type, contextualSignatureReturnType, kind, isAsyncGenerator) {
-      if (type && isUnitType(type)) {
-        const contextualType = !contextualSignatureReturnType ? void 0 : getIterationTypeOfGeneratorFunctionReturnType(kind, contextualSignatureReturnType, isAsyncGenerator);
-        type = getWidenedLiteralLikeTypeForContextualType(type, contextualType);
-      }
-      return type;
-    }
-    function isTupleType(type) {
-      return !!(getObjectFlags(type) & 4 /* Reference */ && type.target.objectFlags & 8 /* Tuple */);
-    }
-    function isGenericTupleType(type) {
-      return isTupleType(type) && !!(type.target.combinedFlags & 8 /* Variadic */);
-    }
-    function isSingleElementGenericTupleType(type) {
-      return isGenericTupleType(type) && type.target.elementFlags.length === 1;
-    }
-    function getRestTypeOfTupleType(type) {
-      return getElementTypeOfSliceOfTupleType(type, type.target.fixedLength);
-    }
-    function getRestArrayTypeOfTupleType(type) {
-      const restType = getRestTypeOfTupleType(type);
-      return restType && createArrayType(restType);
-    }
-    function getElementTypeOfSliceOfTupleType(type, index, endSkipCount = 0, writing = false, noReductions = false) {
-      const length2 = getTypeReferenceArity(type) - endSkipCount;
-      if (index < length2) {
-        const typeArguments = getTypeArguments(type);
-        const elementTypes = [];
-        for (let i = index; i < length2; i++) {
-          const t = typeArguments[i];
-          elementTypes.push(type.target.elementFlags[i] & 8 /* Variadic */ ? getIndexedAccessType(t, numberType) : t);
-        }
-        return writing ? getIntersectionType(elementTypes) : getUnionType(elementTypes, noReductions ? 0 /* None */ : 1 /* Literal */);
-      }
-      return void 0;
-    }
-    function isTupleTypeStructureMatching(t1, t2) {
-      return getTypeReferenceArity(t1) === getTypeReferenceArity(t2) && every(t1.target.elementFlags, (f, i) => (f & 12 /* Variable */) === (t2.target.elementFlags[i] & 12 /* Variable */));
-    }
-    function isZeroBigInt({ value }) {
-      return value.base10Value === "0";
-    }
-    function removeDefinitelyFalsyTypes(type) {
-      return filterType(type, (t) => !!(getTypeFacts(t) & 4194304 /* Truthy */));
-    }
-    function extractDefinitelyFalsyTypes(type) {
-      return mapType(type, getDefinitelyFalsyPartOfType);
-    }
-    function getDefinitelyFalsyPartOfType(type) {
-      return type.flags & 4 /* String */ ? emptyStringType : type.flags & 8 /* Number */ ? zeroType : type.flags & 64 /* BigInt */ ? zeroBigIntType : type === regularFalseType || type === falseType || type.flags & (16384 /* Void */ | 32768 /* Undefined */ | 65536 /* Null */ | 3 /* AnyOrUnknown */) || type.flags & 128 /* StringLiteral */ && type.value === "" || type.flags & 256 /* NumberLiteral */ && type.value === 0 || type.flags & 2048 /* BigIntLiteral */ && isZeroBigInt(type) ? type : neverType;
-    }
-    function getNullableType(type, flags) {
-      const missing = flags & ~type.flags & (32768 /* Undefined */ | 65536 /* Null */);
-      return missing === 0 ? type : missing === 32768 /* Undefined */ ? getUnionType([type, undefinedType]) : missing === 65536 /* Null */ ? getUnionType([type, nullType]) : getUnionType([type, undefinedType, nullType]);
-    }
-    function getOptionalType(type, isProperty = false) {
-      Debug.assert(strictNullChecks);
-      const missingOrUndefined = isProperty ? undefinedOrMissingType : undefinedType;
-      return type === missingOrUndefined || type.flags & 1048576 /* Union */ && type.types[0] === missingOrUndefined ? type : getUnionType([type, missingOrUndefined]);
-    }
-    function getGlobalNonNullableTypeInstantiation(type) {
-      if (!deferredGlobalNonNullableTypeAlias) {
-        deferredGlobalNonNullableTypeAlias = getGlobalSymbol(
-          "NonNullable",
-          524288 /* TypeAlias */,
-          /*diagnostic*/
-          void 0
-        ) || unknownSymbol;
-      }
-      return deferredGlobalNonNullableTypeAlias !== unknownSymbol ? getTypeAliasInstantiation(deferredGlobalNonNullableTypeAlias, [type]) : getIntersectionType([type, emptyObjectType]);
-    }
-    function getNonNullableType(type) {
-      return strictNullChecks ? getAdjustedTypeWithFacts(type, 2097152 /* NEUndefinedOrNull */) : type;
-    }
-    function addOptionalTypeMarker(type) {
-      return strictNullChecks ? getUnionType([type, optionalType]) : type;
-    }
-    function removeOptionalTypeMarker(type) {
-      return strictNullChecks ? removeType(type, optionalType) : type;
-    }
-    function propagateOptionalTypeMarker(type, node, wasOptional) {
-      return wasOptional ? isOutermostOptionalChain(node) ? getOptionalType(type) : addOptionalTypeMarker(type) : type;
-    }
-    function getOptionalExpressionType(exprType, expression) {
-      return isExpressionOfOptionalChainRoot(expression) ? getNonNullableType(exprType) : isOptionalChain(expression) ? removeOptionalTypeMarker(exprType) : exprType;
-    }
-    function removeMissingType(type, isOptional) {
-      return exactOptionalPropertyTypes && isOptional ? removeType(type, missingType) : type;
-    }
-    function containsMissingType(type) {
-      return type === missingType || !!(type.flags & 1048576 /* Union */) && type.types[0] === missingType;
-    }
-    function removeMissingOrUndefinedType(type) {
-      return exactOptionalPropertyTypes ? removeType(type, missingType) : getTypeWithFacts(type, 524288 /* NEUndefined */);
-    }
-    function isCoercibleUnderDoubleEquals(source, target) {
-      return (source.flags & (8 /* Number */ | 4 /* String */ | 512 /* BooleanLiteral */)) !== 0 && (target.flags & (8 /* Number */ | 4 /* String */ | 16 /* Boolean */)) !== 0;
-    }
-    function isObjectTypeWithInferableIndex(type) {
-      const objectFlags = getObjectFlags(type);
-      return type.flags & 2097152 /* Intersection */ ? every(type.types, isObjectTypeWithInferableIndex) : !!(type.symbol && (type.symbol.flags & (4096 /* ObjectLiteral */ | 2048 /* TypeLiteral */ | 384 /* Enum */ | 512 /* ValueModule */)) !== 0 && !(type.symbol.flags & 32 /* Class */) && !typeHasCallOrConstructSignatures(type)) || !!(objectFlags & 4194304 /* ObjectRestType */) || !!(objectFlags & 1024 /* ReverseMapped */ && isObjectTypeWithInferableIndex(type.source));
-    }
-    function createSymbolWithType(source, type) {
-      const symbol = createSymbol(source.flags, source.escapedName, getCheckFlags(source) & 8 /* Readonly */);
-      symbol.declarations = source.declarations;
-      symbol.parent = source.parent;
-      symbol.links.type = type;
-      symbol.links.target = source;
-      if (source.valueDeclaration) {
-        symbol.valueDeclaration = source.valueDeclaration;
-      }
-      const nameType = getSymbolLinks(source).nameType;
-      if (nameType) {
-        symbol.links.nameType = nameType;
-      }
-      return symbol;
-    }
-    function transformTypeOfMembers(type, f) {
-      const members = createSymbolTable();
-      for (const property of getPropertiesOfObjectType(type)) {
-        const original = getTypeOfSymbol(property);
-        const updated = f(original);
-        members.set(property.escapedName, updated === original ? property : createSymbolWithType(property, updated));
-      }
-      return members;
-    }
-    function getRegularTypeOfObjectLiteral(type) {
-      if (!(isObjectLiteralType2(type) && getObjectFlags(type) & 8192 /* FreshLiteral */)) {
-        return type;
-      }
-      const regularType = type.regularType;
-      if (regularType) {
-        return regularType;
-      }
-      const resolved = type;
-      const members = transformTypeOfMembers(type, getRegularTypeOfObjectLiteral);
-      const regularNew = createAnonymousType(resolved.symbol, members, resolved.callSignatures, resolved.constructSignatures, resolved.indexInfos);
-      regularNew.flags = resolved.flags;
-      regularNew.objectFlags |= resolved.objectFlags & ~8192 /* FreshLiteral */;
-      type.regularType = regularNew;
-      return regularNew;
-    }
-    function createWideningContext(parent2, propertyName, siblings) {
-      return { parent: parent2, propertyName, siblings, resolvedProperties: void 0 };
-    }
-    function getSiblingsOfContext(context) {
-      if (!context.siblings) {
-        const siblings = [];
-        for (const type of getSiblingsOfContext(context.parent)) {
-          if (isObjectLiteralType2(type)) {
-            const prop = getPropertyOfObjectType(type, context.propertyName);
-            if (prop) {
-              forEachType(getTypeOfSymbol(prop), (t) => {
-                siblings.push(t);
-              });
-            }
-          }
-        }
-        context.siblings = siblings;
-      }
-      return context.siblings;
-    }
-    function getPropertiesOfContext(context) {
-      if (!context.resolvedProperties) {
-        const names = /* @__PURE__ */ new Map();
-        for (const t of getSiblingsOfContext(context)) {
-          if (isObjectLiteralType2(t) && !(getObjectFlags(t) & 2097152 /* ContainsSpread */)) {
-            for (const prop of getPropertiesOfType(t)) {
-              names.set(prop.escapedName, prop);
-            }
-          }
-        }
-        context.resolvedProperties = arrayFrom(names.values());
-      }
-      return context.resolvedProperties;
-    }
-    function getWidenedProperty(prop, context) {
-      if (!(prop.flags & 4 /* Property */)) {
-        return prop;
-      }
-      const original = getTypeOfSymbol(prop);
-      const propContext = context && createWideningContext(
-        context,
-        prop.escapedName,
-        /*siblings*/
-        void 0
-      );
-      const widened = getWidenedTypeWithContext(original, propContext);
-      return widened === original ? prop : createSymbolWithType(prop, widened);
-    }
-    function getUndefinedProperty(prop) {
-      const cached = undefinedProperties.get(prop.escapedName);
-      if (cached) {
-        return cached;
-      }
-      const result = createSymbolWithType(prop, undefinedOrMissingType);
-      result.flags |= 16777216 /* Optional */;
-      undefinedProperties.set(prop.escapedName, result);
-      return result;
-    }
-    function getWidenedTypeOfObjectLiteral(type, context) {
-      const members = createSymbolTable();
-      for (const prop of getPropertiesOfObjectType(type)) {
-        members.set(prop.escapedName, getWidenedProperty(prop, context));
-      }
-      if (context) {
-        for (const prop of getPropertiesOfContext(context)) {
-          if (!members.has(prop.escapedName)) {
-            members.set(prop.escapedName, getUndefinedProperty(prop));
-          }
-        }
-      }
-      const result = createAnonymousType(
-        type.symbol,
-        members,
-        emptyArray,
-        emptyArray,
-        sameMap(getIndexInfosOfType(type), (info) => createIndexInfo(info.keyType, getWidenedType(info.type), info.isReadonly))
-      );
-      result.objectFlags |= getObjectFlags(type) & (4096 /* JSLiteral */ | 262144 /* NonInferrableType */);
-      return result;
-    }
-    function getWidenedType(type) {
-      return getWidenedTypeWithContext(
-        type,
-        /*context*/
-        void 0
-      );
-    }
-    function getWidenedTypeWithContext(type, context) {
-      if (getObjectFlags(type) & 196608 /* RequiresWidening */) {
-        if (context === void 0 && type.widened) {
-          return type.widened;
-        }
-        let result;
-        if (type.flags & (1 /* Any */ | 98304 /* Nullable */)) {
-          result = anyType;
-        } else if (isObjectLiteralType2(type)) {
-          result = getWidenedTypeOfObjectLiteral(type, context);
-        } else if (type.flags & 1048576 /* Union */) {
-          const unionContext = context || createWideningContext(
-            /*parent*/
-            void 0,
-            /*propertyName*/
-            void 0,
-            type.types
-          );
-          const widenedTypes = sameMap(type.types, (t) => t.flags & 98304 /* Nullable */ ? t : getWidenedTypeWithContext(t, unionContext));
-          result = getUnionType(widenedTypes, some(widenedTypes, isEmptyObjectType) ? 2 /* Subtype */ : 1 /* Literal */);
-        } else if (type.flags & 2097152 /* Intersection */) {
-          result = getIntersectionType(sameMap(type.types, getWidenedType));
-        } else if (isArrayOrTupleType(type)) {
-          result = createTypeReference(type.target, sameMap(getTypeArguments(type), getWidenedType));
-        }
-        if (result && context === void 0) {
-          type.widened = result;
-        }
-        return result || type;
-      }
-      return type;
-    }
-    function reportWideningErrorsInType(type) {
-      let errorReported = false;
-      if (getObjectFlags(type) & 65536 /* ContainsWideningType */) {
-        if (type.flags & 1048576 /* Union */) {
-          if (some(type.types, isEmptyObjectType)) {
-            errorReported = true;
-          } else {
-            for (const t of type.types) {
-              if (reportWideningErrorsInType(t)) {
-                errorReported = true;
-              }
-            }
-          }
-        }
-        if (isArrayOrTupleType(type)) {
-          for (const t of getTypeArguments(type)) {
-            if (reportWideningErrorsInType(t)) {
-              errorReported = true;
-            }
-          }
-        }
-        if (isObjectLiteralType2(type)) {
-          for (const p of getPropertiesOfObjectType(type)) {
-            const t = getTypeOfSymbol(p);
-            if (getObjectFlags(t) & 65536 /* ContainsWideningType */) {
-              if (!reportWideningErrorsInType(t)) {
-                error(p.valueDeclaration, Diagnostics.Object_literal_s_property_0_implicitly_has_an_1_type, symbolToString(p), typeToString(getWidenedType(t)));
-              }
-              errorReported = true;
-            }
-          }
-        }
-      }
-      return errorReported;
-    }
-    function reportImplicitAny(declaration, type, wideningKind) {
-      const typeAsString = typeToString(getWidenedType(type));
-      if (isInJSFile(declaration) && !isCheckJsEnabledForFile(getSourceFileOfNode(declaration), compilerOptions)) {
-        return;
-      }
-      let diagnostic;
-      switch (declaration.kind) {
-        case 225 /* BinaryExpression */:
-        case 171 /* PropertyDeclaration */:
-        case 170 /* PropertySignature */:
-          diagnostic = noImplicitAny ? Diagnostics.Member_0_implicitly_has_an_1_type : Diagnostics.Member_0_implicitly_has_an_1_type_but_a_better_type_may_be_inferred_from_usage;
-          break;
-        case 168 /* Parameter */:
-          const param = declaration;
-          if (isIdentifier(param.name)) {
-            const originalKeywordKind = identifierToKeywordKind(param.name);
-            if ((isCallSignatureDeclaration(param.parent) || isMethodSignature(param.parent) || isFunctionTypeNode(param.parent)) && param.parent.parameters.indexOf(param) > -1 && (resolveName(
-              param,
-              param.name.escapedText,
-              788968 /* Type */,
-              /*nameNotFoundMessage*/
-              void 0,
-              param.name.escapedText,
-              /*isUse*/
-              true
-            ) || originalKeywordKind && isTypeNodeKind(originalKeywordKind))) {
-              const newName = "arg" + param.parent.parameters.indexOf(param);
-              const typeName = declarationNameToString(param.name) + (param.dotDotDotToken ? "[]" : "");
-              errorOrSuggestion(noImplicitAny, declaration, Diagnostics.Parameter_has_a_name_but_no_type_Did_you_mean_0_Colon_1, newName, typeName);
-              return;
-            }
-          }
-          diagnostic = declaration.dotDotDotToken ? noImplicitAny ? Diagnostics.Rest_parameter_0_implicitly_has_an_any_type : Diagnostics.Rest_parameter_0_implicitly_has_an_any_type_but_a_better_type_may_be_inferred_from_usage : noImplicitAny ? Diagnostics.Parameter_0_implicitly_has_an_1_type : Diagnostics.Parameter_0_implicitly_has_an_1_type_but_a_better_type_may_be_inferred_from_usage;
-          break;
-        case 207 /* BindingElement */:
-          diagnostic = Diagnostics.Binding_element_0_implicitly_has_an_1_type;
-          if (!noImplicitAny) {
-            return;
-          }
-          break;
-        case 323 /* JSDocFunctionType */:
-          error(declaration, Diagnostics.Function_type_which_lacks_return_type_annotation_implicitly_has_an_0_return_type, typeAsString);
-          return;
-        case 329 /* JSDocSignature */:
-          if (noImplicitAny && isJSDocOverloadTag(declaration.parent)) {
-            error(declaration.parent.tagName, Diagnostics.This_overload_implicitly_returns_the_type_0_because_it_lacks_a_return_type_annotation, typeAsString);
-          }
-          return;
-        case 261 /* FunctionDeclaration */:
-        case 173 /* MethodDeclaration */:
-        case 172 /* MethodSignature */:
-        case 176 /* GetAccessor */:
-        case 177 /* SetAccessor */:
-        case 217 /* FunctionExpression */:
-        case 218 /* ArrowFunction */:
-          if (noImplicitAny && !declaration.name) {
-            if (wideningKind === 3 /* GeneratorYield */) {
-              error(declaration, Diagnostics.Generator_implicitly_has_yield_type_0_because_it_does_not_yield_any_values_Consider_supplying_a_return_type_annotation, typeAsString);
-            } else {
-              error(declaration, Diagnostics.Function_expression_which_lacks_return_type_annotation_implicitly_has_an_0_return_type, typeAsString);
-            }
-            return;
-          }
-          diagnostic = !noImplicitAny ? Diagnostics._0_implicitly_has_an_1_return_type_but_a_better_type_may_be_inferred_from_usage : wideningKind === 3 /* GeneratorYield */ ? Diagnostics._0_which_lacks_return_type_annotation_implicitly_has_an_1_yield_type : Diagnostics._0_which_lacks_return_type_annotation_implicitly_has_an_1_return_type;
-          break;
-        case 199 /* MappedType */:
-          if (noImplicitAny) {
-            error(declaration, Diagnostics.Mapped_object_type_implicitly_has_an_any_template_type);
-          }
-          return;
-        default:
-          diagnostic = noImplicitAny ? Diagnostics.Variable_0_implicitly_has_an_1_type : Diagnostics.Variable_0_implicitly_has_an_1_type_but_a_better_type_may_be_inferred_from_usage;
-      }
-      errorOrSuggestion(noImplicitAny, declaration, diagnostic, declarationNameToString(getNameOfDeclaration(declaration)), typeAsString);
-    }
-    function reportErrorsFromWidening(declaration, type, wideningKind) {
-      addLazyDiagnostic(() => {
-        if (noImplicitAny && getObjectFlags(type) & 65536 /* ContainsWideningType */ && (!wideningKind || !getContextualSignatureForFunctionLikeDeclaration(declaration))) {
-          if (!reportWideningErrorsInType(type)) {
-            reportImplicitAny(declaration, type, wideningKind);
-          }
-        }
-      });
-    }
-    function applyToParameterTypes(source, target, callback) {
-      const sourceCount = getParameterCount(source);
-      const targetCount = getParameterCount(target);
-      const sourceRestType = getEffectiveRestType(source);
-      const targetRestType = getEffectiveRestType(target);
-      const targetNonRestCount = targetRestType ? targetCount - 1 : targetCount;
-      const paramCount = sourceRestType ? targetNonRestCount : Math.min(sourceCount, targetNonRestCount);
-      const sourceThisType = getThisTypeOfSignature(source);
-      if (sourceThisType) {
-        const targetThisType = getThisTypeOfSignature(target);
-        if (targetThisType) {
-          callback(sourceThisType, targetThisType);
-        }
-      }
-      for (let i = 0; i < paramCount; i++) {
-        callback(getTypeAtPosition(source, i), getTypeAtPosition(target, i));
-      }
-      if (targetRestType) {
-        callback(getRestTypeAtPosition(source, paramCount), targetRestType);
-      }
-    }
-    function applyToReturnTypes(source, target, callback) {
-      const sourceTypePredicate = getTypePredicateOfSignature(source);
-      const targetTypePredicate = getTypePredicateOfSignature(target);
-      if (sourceTypePredicate && targetTypePredicate && typePredicateKindsMatch(sourceTypePredicate, targetTypePredicate) && sourceTypePredicate.type && targetTypePredicate.type) {
-        callback(sourceTypePredicate.type, targetTypePredicate.type);
-      } else {
-        callback(getReturnTypeOfSignature(source), getReturnTypeOfSignature(target));
-      }
-    }
-    function createInferenceContext(typeParameters, signature, flags, compareTypes) {
-      return createInferenceContextWorker(typeParameters.map(createInferenceInfo), signature, flags, compareTypes || compareTypesAssignable);
-    }
-    function cloneInferenceContext(context, extraFlags = 0) {
-      return context && createInferenceContextWorker(map(context.inferences, cloneInferenceInfo), context.signature, context.flags | extraFlags, context.compareTypes);
-    }
-    function createInferenceContextWorker(inferences, signature, flags, compareTypes) {
-      const context = {
-        inferences,
-        signature,
-        flags,
-        compareTypes,
-        mapper: reportUnmeasurableMapper,
-        // initialize to a noop mapper so the context object is available, but the underlying object shape is right upon construction
-        nonFixingMapper: reportUnmeasurableMapper
-      };
-      context.mapper = makeFixingMapperForContext(context);
-      context.nonFixingMapper = makeNonFixingMapperForContext(context);
-      return context;
-    }
-    function makeFixingMapperForContext(context) {
-      return makeDeferredTypeMapper(map(context.inferences, (i) => i.typeParameter), map(context.inferences, (inference, i) => () => {
-        if (!inference.isFixed) {
-          inferFromIntraExpressionSites(context);
-          clearCachedInferences(context.inferences);
-          inference.isFixed = true;
-        }
-        return getInferredType(context, i);
-      }));
-    }
-    function makeNonFixingMapperForContext(context) {
-      return makeDeferredTypeMapper(map(context.inferences, (i) => i.typeParameter), map(context.inferences, (_, i) => () => {
-        return getInferredType(context, i);
-      }));
-    }
-    function clearCachedInferences(inferences) {
-      for (const inference of inferences) {
-        if (!inference.isFixed) {
-          inference.inferredType = void 0;
-        }
-      }
-    }
-    function addIntraExpressionInferenceSite(context, node, type) {
-      (context.intraExpressionInferenceSites ?? (context.intraExpressionInferenceSites = [])).push({ node, type });
-    }
-    function inferFromIntraExpressionSites(context) {
-      if (context.intraExpressionInferenceSites) {
-        for (const { node, type } of context.intraExpressionInferenceSites) {
-          const contextualType = node.kind === 173 /* MethodDeclaration */ ? getContextualTypeForObjectLiteralMethod(node, 2 /* NoConstraints */) : getContextualType2(node, 2 /* NoConstraints */);
-          if (contextualType) {
-            inferTypes(context.inferences, type, contextualType);
-          }
-        }
-        context.intraExpressionInferenceSites = void 0;
-      }
-    }
-    function createInferenceInfo(typeParameter) {
-      return {
-        typeParameter,
-        candidates: void 0,
-        contraCandidates: void 0,
-        inferredType: void 0,
-        priority: void 0,
-        topLevel: true,
-        isFixed: false,
-        impliedArity: void 0
-      };
-    }
-    function cloneInferenceInfo(inference) {
-      return {
-        typeParameter: inference.typeParameter,
-        candidates: inference.candidates && inference.candidates.slice(),
-        contraCandidates: inference.contraCandidates && inference.contraCandidates.slice(),
-        inferredType: inference.inferredType,
-        priority: inference.priority,
-        topLevel: inference.topLevel,
-        isFixed: inference.isFixed,
-        impliedArity: inference.impliedArity
-      };
-    }
-    function cloneInferredPartOfContext(context) {
-      const inferences = filter(context.inferences, hasInferenceCandidates);
-      return inferences.length ? createInferenceContextWorker(map(inferences, cloneInferenceInfo), context.signature, context.flags, context.compareTypes) : void 0;
-    }
-    function getMapperFromContext(context) {
-      return context && context.mapper;
-    }
-    function couldContainTypeVariables(type) {
-      const objectFlags = getObjectFlags(type);
-      if (objectFlags & 524288 /* CouldContainTypeVariablesComputed */) {
-        return !!(objectFlags & 1048576 /* CouldContainTypeVariables */);
-      }
-      const result = !!(type.flags & 465829888 /* Instantiable */ || type.flags & 524288 /* Object */ && !isNonGenericTopLevelType(type) && (objectFlags & 4 /* Reference */ && (type.node || some(getTypeArguments(type), couldContainTypeVariables)) || objectFlags & 16 /* Anonymous */ && type.symbol && type.symbol.flags & (16 /* Function */ | 8192 /* Method */ | 32 /* Class */ | 2048 /* TypeLiteral */ | 4096 /* ObjectLiteral */) && type.symbol.declarations || objectFlags & (32 /* Mapped */ | 1024 /* ReverseMapped */ | 4194304 /* ObjectRestType */ | 8388608 /* InstantiationExpressionType */)) || type.flags & (3145728 /* UnionOrIntersection */ | 134217728 /* TemplateLiteral */) && !(type.flags & 1024 /* EnumLiteral */) && !isNonGenericTopLevelType(type) && some(type.types, couldContainTypeVariables));
-      if (type.flags & 138117121 /* ObjectFlagsType */) {
-        type.objectFlags |= 524288 /* CouldContainTypeVariablesComputed */ | (result ? 1048576 /* CouldContainTypeVariables */ : 0);
-      }
-      return result;
-    }
-    function isNonGenericTopLevelType(type) {
-      if (type.aliasSymbol && !type.aliasTypeArguments) {
-        const declaration = getDeclarationOfKind(type.aliasSymbol, 264 /* TypeAliasDeclaration */);
-        return !!(declaration && findAncestor(declaration.parent, (n) => n.kind === 311 /* SourceFile */ ? true : n.kind === 266 /* ModuleDeclaration */ ? false : "quit"));
-      }
-      return false;
-    }
-    function isTypeParameterAtTopLevel(type, tp, depth = 0) {
-      return !!(type === tp || type.flags & 3145728 /* UnionOrIntersection */ && some(type.types, (t) => isTypeParameterAtTopLevel(t, tp, depth)) || depth < 3 && type.flags & 16777216 /* Conditional */ && (isTypeParameterAtTopLevel(getTrueTypeFromConditionalType(type), tp, depth + 1) || isTypeParameterAtTopLevel(getFalseTypeFromConditionalType(type), tp, depth + 1)));
-    }
-    function isTypeParameterAtTopLevelInReturnType(signature, typeParameter) {
-      const typePredicate = getTypePredicateOfSignature(signature);
-      return typePredicate ? !!typePredicate.type && isTypeParameterAtTopLevel(typePredicate.type, typeParameter) : isTypeParameterAtTopLevel(getReturnTypeOfSignature(signature), typeParameter);
-    }
-    function createEmptyObjectTypeFromStringLiteral(type) {
-      const members = createSymbolTable();
-      forEachType(type, (t) => {
-        if (!(t.flags & 128 /* StringLiteral */)) {
-          return;
-        }
-        const name = escapeLeadingUnderscores(t.value);
-        const literalProp = createSymbol(4 /* Property */, name);
-        literalProp.links.type = anyType;
-        if (t.symbol) {
-          literalProp.declarations = t.symbol.declarations;
-          literalProp.valueDeclaration = t.symbol.valueDeclaration;
-        }
-        members.set(name, literalProp);
-      });
-      const indexInfos = type.flags & 4 /* String */ ? [createIndexInfo(
-        stringType,
-        emptyObjectType,
-        /*isReadonly*/
-        false
-      )] : emptyArray;
-      return createAnonymousType(
-        /*symbol*/
-        void 0,
-        members,
-        emptyArray,
-        emptyArray,
-        indexInfos
-      );
-    }
-    function inferTypeForHomomorphicMappedType(source, target, constraint) {
-      if (inInferTypeForHomomorphicMappedType) {
-        return void 0;
-      }
-      const key = source.id + "," + target.id + "," + constraint.id;
-      if (reverseMappedCache.has(key)) {
-        return reverseMappedCache.get(key);
-      }
-      inInferTypeForHomomorphicMappedType = true;
-      const type = createReverseMappedType(source, target, constraint);
-      inInferTypeForHomomorphicMappedType = false;
-      reverseMappedCache.set(key, type);
-      return type;
-    }
-    function isPartiallyInferableType(type) {
-      return !(getObjectFlags(type) & 262144 /* NonInferrableType */) || isObjectLiteralType2(type) && some(getPropertiesOfType(type), (prop) => isPartiallyInferableType(getTypeOfSymbol(prop))) || isTupleType(type) && some(getElementTypes(type), isPartiallyInferableType);
-    }
-    function createReverseMappedType(source, target, constraint) {
-      if (!(getIndexInfoOfType(source, stringType) || getPropertiesOfType(source).length !== 0 && isPartiallyInferableType(source))) {
-        return void 0;
-      }
-      if (isArrayType(source)) {
-        return createArrayType(inferReverseMappedType(getTypeArguments(source)[0], target, constraint), isReadonlyArrayType(source));
-      }
-      if (isTupleType(source)) {
-        const elementTypes = map(getElementTypes(source), (t) => inferReverseMappedType(t, target, constraint));
-        const elementFlags = getMappedTypeModifiers(target) & 4 /* IncludeOptional */ ? sameMap(source.target.elementFlags, (f) => f & 2 /* Optional */ ? 1 /* Required */ : f) : source.target.elementFlags;
-        return createTupleType(elementTypes, elementFlags, source.target.readonly, source.target.labeledElementDeclarations);
-      }
-      const reversed = createObjectType(
-        1024 /* ReverseMapped */ | 16 /* Anonymous */,
-        /*symbol*/
-        void 0
-      );
-      reversed.source = source;
-      reversed.mappedType = target;
-      reversed.constraintType = constraint;
-      return reversed;
-    }
-    function getTypeOfReverseMappedSymbol(symbol) {
-      const links = getSymbolLinks(symbol);
-      if (!links.type) {
-        links.type = inferReverseMappedType(symbol.links.propertyType, symbol.links.mappedType, symbol.links.constraintType);
-      }
-      return links.type;
-    }
-    function inferReverseMappedType(sourceType, target, constraint) {
-      const typeParameter = getIndexedAccessType(constraint.type, getTypeParameterFromMappedType(target));
-      const templateType = getTemplateTypeFromMappedType(target);
-      const inference = createInferenceInfo(typeParameter);
-      inferTypes([inference], sourceType, templateType);
-      return getTypeFromInference(inference) || unknownType;
-    }
-    function* getUnmatchedProperties(source, target, requireOptionalProperties, matchDiscriminantProperties) {
-      const properties = getPropertiesOfType(target);
-      for (const targetProp of properties) {
-        if (isStaticPrivateIdentifierProperty(targetProp)) {
-          continue;
-        }
-        if (requireOptionalProperties || !(targetProp.flags & 16777216 /* Optional */ || getCheckFlags(targetProp) & 48 /* Partial */)) {
-          const sourceProp = getPropertyOfType(source, targetProp.escapedName);
-          if (!sourceProp) {
-            yield targetProp;
-          } else if (matchDiscriminantProperties) {
-            const targetType = getTypeOfSymbol(targetProp);
-            if (targetType.flags & 109472 /* Unit */) {
-              const sourceType = getTypeOfSymbol(sourceProp);
-              if (!(sourceType.flags & 1 /* Any */ || getRegularTypeOfLiteralType(sourceType) === getRegularTypeOfLiteralType(targetType))) {
-                yield targetProp;
-              }
-            }
-          }
-        }
-      }
-    }
-    function getUnmatchedProperty(source, target, requireOptionalProperties, matchDiscriminantProperties) {
-      return firstOrUndefinedIterator(getUnmatchedProperties(source, target, requireOptionalProperties, matchDiscriminantProperties));
-    }
-    function tupleTypesDefinitelyUnrelated(source, target) {
-      return !(target.target.combinedFlags & 8 /* Variadic */) && target.target.minLength > source.target.minLength || !target.target.hasRestElement && (source.target.hasRestElement || target.target.fixedLength < source.target.fixedLength);
-    }
-    function typesDefinitelyUnrelated(source, target) {
-      return isTupleType(source) && isTupleType(target) ? tupleTypesDefinitelyUnrelated(source, target) : !!getUnmatchedProperty(
-        source,
-        target,
-        /*requireOptionalProperties*/
-        false,
-        /*matchDiscriminantProperties*/
-        true
-      ) && !!getUnmatchedProperty(
-        target,
-        source,
-        /*requireOptionalProperties*/
-        false,
-        /*matchDiscriminantProperties*/
-        false
-      );
-    }
-    function getTypeFromInference(inference) {
-      return inference.candidates ? getUnionType(inference.candidates, 2 /* Subtype */) : inference.contraCandidates ? getIntersectionType(inference.contraCandidates) : void 0;
-    }
-    function hasSkipDirectInferenceFlag(node) {
-      return !!getNodeLinks(node).skipDirectInference;
-    }
-    function isFromInferenceBlockedSource(type) {
-      return !!(type.symbol && some(type.symbol.declarations, hasSkipDirectInferenceFlag));
-    }
-    function templateLiteralTypesDefinitelyUnrelated(source, target) {
-      const sourceStart = source.texts[0];
-      const targetStart = target.texts[0];
-      const sourceEnd = source.texts[source.texts.length - 1];
-      const targetEnd = target.texts[target.texts.length - 1];
-      const startLen = Math.min(sourceStart.length, targetStart.length);
-      const endLen = Math.min(sourceEnd.length, targetEnd.length);
-      return sourceStart.slice(0, startLen) !== targetStart.slice(0, startLen) || sourceEnd.slice(sourceEnd.length - endLen) !== targetEnd.slice(targetEnd.length - endLen);
-    }
-    function isValidNumberString(s, roundTripOnly) {
-      if (s === "")
-        return false;
-      const n = +s;
-      return isFinite(n) && (!roundTripOnly || "" + n === s);
-    }
-    function parseBigIntLiteralType(text) {
-      return getBigIntLiteralType(parseValidBigInt(text));
-    }
-    function isMemberOfStringMapping(source, target) {
-      if (target.flags & 1 /* Any */) {
-        return true;
-      }
-      if (target.flags & (4 /* String */ | 134217728 /* TemplateLiteral */)) {
-        return isTypeAssignableTo(source, target);
-      }
-      if (target.flags & 268435456 /* StringMapping */) {
-        const mappingStack = [];
-        while (target.flags & 268435456 /* StringMapping */) {
-          mappingStack.unshift(target.symbol);
-          target = target.type;
-        }
-        const mappedSource = reduceLeft(mappingStack, (memo, value) => getStringMappingType(value, memo), source);
-        return mappedSource === source && isMemberOfStringMapping(source, target);
-      }
-      return false;
-    }
-    function isValidTypeForTemplateLiteralPlaceholder(source, target) {
-      if (source === target || target.flags & (1 /* Any */ | 4 /* String */)) {
-        return true;
-      }
-      if (source.flags & 128 /* StringLiteral */) {
-        const value = source.value;
-        return !!(target.flags & 8 /* Number */ && isValidNumberString(
-          value,
-          /*roundTripOnly*/
-          false
-        ) || target.flags & 64 /* BigInt */ && isValidBigIntString(
-          value,
-          /*roundTripOnly*/
-          false
-        ) || target.flags & (512 /* BooleanLiteral */ | 98304 /* Nullable */) && value === target.intrinsicName || target.flags & 268435456 /* StringMapping */ && isMemberOfStringMapping(getStringLiteralType(value), target));
-      }
-      if (source.flags & 134217728 /* TemplateLiteral */) {
-        const texts = source.texts;
-        return texts.length === 2 && texts[0] === "" && texts[1] === "" && isTypeAssignableTo(source.types[0], target);
-      }
-      return isTypeAssignableTo(source, target);
-    }
-    function inferTypesFromTemplateLiteralType(source, target) {
-      return source.flags & 128 /* StringLiteral */ ? inferFromLiteralPartsToTemplateLiteral([source.value], emptyArray, target) : source.flags & 134217728 /* TemplateLiteral */ ? arraysEqual(source.texts, target.texts) ? map(source.types, getStringLikeTypeForType) : inferFromLiteralPartsToTemplateLiteral(source.texts, source.types, target) : void 0;
-    }
-    function isTypeMatchedByTemplateLiteralType(source, target) {
-      const inferences = inferTypesFromTemplateLiteralType(source, target);
-      return !!inferences && every(inferences, (r, i) => isValidTypeForTemplateLiteralPlaceholder(r, target.types[i]));
-    }
-    function getStringLikeTypeForType(type) {
-      return type.flags & (1 /* Any */ | 402653316 /* StringLike */) ? type : getTemplateLiteralType(["", ""], [type]);
-    }
-    function inferFromLiteralPartsToTemplateLiteral(sourceTexts, sourceTypes, target) {
-      const lastSourceIndex = sourceTexts.length - 1;
-      const sourceStartText = sourceTexts[0];
-      const sourceEndText = sourceTexts[lastSourceIndex];
-      const targetTexts = target.texts;
-      const lastTargetIndex = targetTexts.length - 1;
-      const targetStartText = targetTexts[0];
-      const targetEndText = targetTexts[lastTargetIndex];
-      if (lastSourceIndex === 0 && sourceStartText.length < targetStartText.length + targetEndText.length || !sourceStartText.startsWith(targetStartText) || !sourceEndText.endsWith(targetEndText))
-        return void 0;
-      const remainingEndText = sourceEndText.slice(0, sourceEndText.length - targetEndText.length);
-      const matches = [];
-      let seg = 0;
-      let pos = targetStartText.length;
-      for (let i = 1; i < lastTargetIndex; i++) {
-        const delim = targetTexts[i];
-        if (delim.length > 0) {
-          let s = seg;
-          let p = pos;
-          while (true) {
-            p = getSourceText(s).indexOf(delim, p);
-            if (p >= 0)
-              break;
-            s++;
-            if (s === sourceTexts.length)
-              return void 0;
-            p = 0;
-          }
-          addMatch(s, p);
-          pos += delim.length;
-        } else if (pos < getSourceText(seg).length) {
-          addMatch(seg, pos + 1);
-        } else if (seg < lastSourceIndex) {
-          addMatch(seg + 1, 0);
-        } else {
-          return void 0;
-        }
-      }
-      addMatch(lastSourceIndex, getSourceText(lastSourceIndex).length);
-      return matches;
-      function getSourceText(index) {
-        return index < lastSourceIndex ? sourceTexts[index] : remainingEndText;
-      }
-      function addMatch(s, p) {
-        const matchType = s === seg ? getStringLiteralType(getSourceText(s).slice(pos, p)) : getTemplateLiteralType(
-          [sourceTexts[seg].slice(pos), ...sourceTexts.slice(seg + 1, s), getSourceText(s).slice(0, p)],
-          sourceTypes.slice(seg, s)
-        );
-        matches.push(matchType);
-        seg = s;
-        pos = p;
-      }
-    }
-    function inferTypes(inferences, originalSource, originalTarget, priority = 0 /* None */, contravariant = false) {
-      let bivariant = false;
-      let propagationType;
-      let inferencePriority = 2048 /* MaxValue */;
-      let allowComplexConstraintInference = true;
-      let visited;
-      let sourceStack;
-      let targetStack;
-      let expandingFlags = 0 /* None */;
-      inferFromTypes(originalSource, originalTarget);
-      function inferFromTypes(source, target) {
-        if (!couldContainTypeVariables(target)) {
-          return;
-        }
-        if (source === wildcardType) {
-          const savePropagationType = propagationType;
-          propagationType = source;
-          inferFromTypes(target, target);
-          propagationType = savePropagationType;
-          return;
-        }
-        if (source.aliasSymbol && source.aliasSymbol === target.aliasSymbol) {
-          if (source.aliasTypeArguments) {
-            const params = getSymbolLinks(source.aliasSymbol).typeParameters;
-            const minParams = getMinTypeArgumentCount(params);
-            const sourceTypes = fillMissingTypeArguments(source.aliasTypeArguments, params, minParams, isInJSFile(source.aliasSymbol.valueDeclaration));
-            const targetTypes = fillMissingTypeArguments(target.aliasTypeArguments, params, minParams, isInJSFile(source.aliasSymbol.valueDeclaration));
-            inferFromTypeArguments(sourceTypes, targetTypes, getAliasVariances(source.aliasSymbol));
-          }
-          return;
-        }
-        if (source === target && source.flags & 3145728 /* UnionOrIntersection */) {
-          for (const t of source.types) {
-            inferFromTypes(t, t);
-          }
-          return;
-        }
-        if (target.flags & 1048576 /* Union */) {
-          const [tempSources, tempTargets] = inferFromMatchingTypes(source.flags & 1048576 /* Union */ ? source.types : [source], target.types, isTypeOrBaseIdenticalTo);
-          const [sources, targets] = inferFromMatchingTypes(tempSources, tempTargets, isTypeCloselyMatchedBy);
-          if (targets.length === 0) {
-            return;
-          }
-          target = getUnionType(targets);
-          if (sources.length === 0) {
-            inferWithPriority(source, target, 1 /* NakedTypeVariable */);
-            return;
-          }
-          source = getUnionType(sources);
-        } else if (target.flags & 2097152 /* Intersection */ && !every(target.types, isNonGenericObjectType)) {
-          if (!(source.flags & 1048576 /* Union */)) {
-            const [sources, targets] = inferFromMatchingTypes(source.flags & 2097152 /* Intersection */ ? source.types : [source], target.types, isTypeIdenticalTo);
-            if (sources.length === 0 || targets.length === 0) {
-              return;
-            }
-            source = getIntersectionType(sources);
-            target = getIntersectionType(targets);
-          }
-        } else if (target.flags & (8388608 /* IndexedAccess */ | 33554432 /* Substitution */)) {
-          target = getActualTypeVariable(target);
-        }
-        if (target.flags & 8650752 /* TypeVariable */) {
-          if (isFromInferenceBlockedSource(source)) {
-            return;
-          }
-          const inference = getInferenceInfoForType(target);
-          if (inference) {
-            if (getObjectFlags(source) & 262144 /* NonInferrableType */ || source === nonInferrableAnyType) {
-              return;
-            }
-            if (!inference.isFixed) {
-              if (inference.priority === void 0 || priority < inference.priority) {
-                inference.candidates = void 0;
-                inference.contraCandidates = void 0;
-                inference.topLevel = true;
-                inference.priority = priority;
-              }
-              if (priority === inference.priority) {
-                const candidate = propagationType || source;
-                if (contravariant && !bivariant) {
-                  if (!contains(inference.contraCandidates, candidate)) {
-                    inference.contraCandidates = append(inference.contraCandidates, candidate);
-                    clearCachedInferences(inferences);
-                  }
-                } else if (!contains(inference.candidates, candidate)) {
-                  inference.candidates = append(inference.candidates, candidate);
-                  clearCachedInferences(inferences);
-                }
-              }
-              if (!(priority & 128 /* ReturnType */) && target.flags & 262144 /* TypeParameter */ && inference.topLevel && !isTypeParameterAtTopLevel(originalTarget, target)) {
-                inference.topLevel = false;
-                clearCachedInferences(inferences);
-              }
-            }
-            inferencePriority = Math.min(inferencePriority, priority);
-            return;
-          }
-          const simplified = getSimplifiedType(
-            target,
-            /*writing*/
-            false
-          );
-          if (simplified !== target) {
-            inferFromTypes(source, simplified);
-          } else if (target.flags & 8388608 /* IndexedAccess */) {
-            const indexType = getSimplifiedType(
-              target.indexType,
-              /*writing*/
-              false
-            );
-            if (indexType.flags & 465829888 /* Instantiable */) {
-              const simplified2 = distributeIndexOverObjectType(
-                getSimplifiedType(
-                  target.objectType,
-                  /*writing*/
-                  false
-                ),
-                indexType,
-                /*writing*/
-                false
-              );
-              if (simplified2 && simplified2 !== target) {
-                inferFromTypes(source, simplified2);
-              }
-            }
-          }
-        }
-        if (getObjectFlags(source) & 4 /* Reference */ && getObjectFlags(target) & 4 /* Reference */ && (source.target === target.target || isArrayType(source) && isArrayType(target)) && !(source.node && target.node)) {
-          inferFromTypeArguments(getTypeArguments(source), getTypeArguments(target), getVariances(source.target));
-        } else if (source.flags & 4194304 /* Index */ && target.flags & 4194304 /* Index */) {
-          inferFromContravariantTypes(source.type, target.type);
-        } else if ((isLiteralType(source) || source.flags & 4 /* String */) && target.flags & 4194304 /* Index */) {
-          const empty = createEmptyObjectTypeFromStringLiteral(source);
-          inferFromContravariantTypesWithPriority(empty, target.type, 256 /* LiteralKeyof */);
-        } else if (source.flags & 8388608 /* IndexedAccess */ && target.flags & 8388608 /* IndexedAccess */) {
-          inferFromTypes(source.objectType, target.objectType);
-          inferFromTypes(source.indexType, target.indexType);
-        } else if (source.flags & 268435456 /* StringMapping */ && target.flags & 268435456 /* StringMapping */) {
-          if (source.symbol === target.symbol) {
-            inferFromTypes(source.type, target.type);
-          }
-        } else if (source.flags & 33554432 /* Substitution */) {
-          inferFromTypes(source.baseType, target);
-          inferWithPriority(getSubstitutionIntersection(source), target, 4 /* SubstituteSource */);
-        } else if (target.flags & 16777216 /* Conditional */) {
-          invokeOnce(source, target, inferToConditionalType);
-        } else if (target.flags & 3145728 /* UnionOrIntersection */) {
-          inferToMultipleTypes(source, target.types, target.flags);
-        } else if (source.flags & 1048576 /* Union */) {
-          const sourceTypes = source.types;
-          for (const sourceType of sourceTypes) {
-            inferFromTypes(sourceType, target);
-          }
-        } else if (target.flags & 134217728 /* TemplateLiteral */) {
-          inferToTemplateLiteralType(source, target);
-        } else {
-          source = getReducedType(source);
-          if (!(priority & 512 /* NoConstraints */ && source.flags & (2097152 /* Intersection */ | 465829888 /* Instantiable */))) {
-            const apparentSource = getApparentType(source);
-            if (apparentSource !== source && allowComplexConstraintInference && !(apparentSource.flags & (524288 /* Object */ | 2097152 /* Intersection */))) {
-              allowComplexConstraintInference = false;
-              return inferFromTypes(apparentSource, target);
-            }
-            source = apparentSource;
-          }
-          if (source.flags & (524288 /* Object */ | 2097152 /* Intersection */)) {
-            invokeOnce(source, target, inferFromObjectTypes);
-          }
-        }
-      }
-      function inferWithPriority(source, target, newPriority) {
-        const savePriority = priority;
-        priority |= newPriority;
-        inferFromTypes(source, target);
-        priority = savePriority;
-      }
-      function inferFromContravariantTypesWithPriority(source, target, newPriority) {
-        const savePriority = priority;
-        priority |= newPriority;
-        inferFromContravariantTypes(source, target);
-        priority = savePriority;
-      }
-      function inferToMultipleTypesWithPriority(source, targets, targetFlags, newPriority) {
-        const savePriority = priority;
-        priority |= newPriority;
-        inferToMultipleTypes(source, targets, targetFlags);
-        priority = savePriority;
-      }
-      function invokeOnce(source, target, action) {
-        const key = source.id + "," + target.id;
-        const status = visited && visited.get(key);
-        if (status !== void 0) {
-          inferencePriority = Math.min(inferencePriority, status);
-          return;
-        }
-        (visited || (visited = /* @__PURE__ */ new Map())).set(key, -1 /* Circularity */);
-        const saveInferencePriority = inferencePriority;
-        inferencePriority = 2048 /* MaxValue */;
-        const saveExpandingFlags = expandingFlags;
-        (sourceStack ?? (sourceStack = [])).push(source);
-        (targetStack ?? (targetStack = [])).push(target);
-        if (isDeeplyNestedType(source, sourceStack, sourceStack.length, 2))
-          expandingFlags |= 1 /* Source */;
-        if (isDeeplyNestedType(target, targetStack, targetStack.length, 2))
-          expandingFlags |= 2 /* Target */;
-        if (expandingFlags !== 3 /* Both */) {
-          action(source, target);
-        } else {
-          inferencePriority = -1 /* Circularity */;
-        }
-        targetStack.pop();
-        sourceStack.pop();
-        expandingFlags = saveExpandingFlags;
-        visited.set(key, inferencePriority);
-        inferencePriority = Math.min(inferencePriority, saveInferencePriority);
-      }
-      function inferFromMatchingTypes(sources, targets, matches) {
-        let matchedSources;
-        let matchedTargets;
-        for (const t of targets) {
-          for (const s of sources) {
-            if (matches(s, t)) {
-              inferFromTypes(s, t);
-              matchedSources = appendIfUnique(matchedSources, s);
-              matchedTargets = appendIfUnique(matchedTargets, t);
-            }
-          }
-        }
-        return [
-          matchedSources ? filter(sources, (t) => !contains(matchedSources, t)) : sources,
-          matchedTargets ? filter(targets, (t) => !contains(matchedTargets, t)) : targets
-        ];
-      }
-      function inferFromTypeArguments(sourceTypes, targetTypes, variances) {
-        const count = sourceTypes.length < targetTypes.length ? sourceTypes.length : targetTypes.length;
-        for (let i = 0; i < count; i++) {
-          if (i < variances.length && (variances[i] & 7 /* VarianceMask */) === 2 /* Contravariant */) {
-            inferFromContravariantTypes(sourceTypes[i], targetTypes[i]);
-          } else {
-            inferFromTypes(sourceTypes[i], targetTypes[i]);
-          }
-        }
-      }
-      function inferFromContravariantTypes(source, target) {
-        contravariant = !contravariant;
-        inferFromTypes(source, target);
-        contravariant = !contravariant;
-      }
-      function inferFromContravariantTypesIfStrictFunctionTypes(source, target) {
-        if (strictFunctionTypes || priority & 1024 /* AlwaysStrict */) {
-          inferFromContravariantTypes(source, target);
-        } else {
-          inferFromTypes(source, target);
-        }
-      }
-      function getInferenceInfoForType(type) {
-        if (type.flags & 8650752 /* TypeVariable */) {
-          for (const inference of inferences) {
-            if (type === inference.typeParameter) {
-              return inference;
-            }
-          }
-        }
-        return void 0;
-      }
-      function getSingleTypeVariableFromIntersectionTypes(types) {
-        let typeVariable;
-        for (const type of types) {
-          const t = type.flags & 2097152 /* Intersection */ && find(type.types, (t2) => !!getInferenceInfoForType(t2));
-          if (!t || typeVariable && t !== typeVariable) {
-            return void 0;
-          }
-          typeVariable = t;
-        }
-        return typeVariable;
-      }
-      function inferToMultipleTypes(source, targets, targetFlags) {
-        let typeVariableCount = 0;
-        if (targetFlags & 1048576 /* Union */) {
-          let nakedTypeVariable;
-          const sources = source.flags & 1048576 /* Union */ ? source.types : [source];
-          const matched = new Array(sources.length);
-          let inferenceCircularity = false;
-          for (const t of targets) {
-            if (getInferenceInfoForType(t)) {
-              nakedTypeVariable = t;
-              typeVariableCount++;
-            } else {
-              for (let i = 0; i < sources.length; i++) {
-                const saveInferencePriority = inferencePriority;
-                inferencePriority = 2048 /* MaxValue */;
-                inferFromTypes(sources[i], t);
-                if (inferencePriority === priority)
-                  matched[i] = true;
-                inferenceCircularity = inferenceCircularity || inferencePriority === -1 /* Circularity */;
-                inferencePriority = Math.min(inferencePriority, saveInferencePriority);
-              }
-            }
-          }
-          if (typeVariableCount === 0) {
-            const intersectionTypeVariable = getSingleTypeVariableFromIntersectionTypes(targets);
-            if (intersectionTypeVariable) {
-              inferWithPriority(source, intersectionTypeVariable, 1 /* NakedTypeVariable */);
-            }
-            return;
-          }
-          if (typeVariableCount === 1 && !inferenceCircularity) {
-            const unmatched = flatMap(sources, (s, i) => matched[i] ? void 0 : s);
-            if (unmatched.length) {
-              inferFromTypes(getUnionType(unmatched), nakedTypeVariable);
-              return;
-            }
-          }
-        } else {
-          for (const t of targets) {
-            if (getInferenceInfoForType(t)) {
-              typeVariableCount++;
-            } else {
-              inferFromTypes(source, t);
-            }
-          }
-        }
-        if (targetFlags & 2097152 /* Intersection */ ? typeVariableCount === 1 : typeVariableCount > 0) {
-          for (const t of targets) {
-            if (getInferenceInfoForType(t)) {
-              inferWithPriority(source, t, 1 /* NakedTypeVariable */);
-            }
-          }
-        }
-      }
-      function inferToMappedType(source, target, constraintType) {
-        if (constraintType.flags & 1048576 /* Union */) {
-          let result = false;
-          for (const type of constraintType.types) {
-            result = inferToMappedType(source, target, type) || result;
-          }
-          return result;
-        }
-        if (constraintType.flags & 4194304 /* Index */) {
-          const inference = getInferenceInfoForType(constraintType.type);
-          if (inference && !inference.isFixed && !isFromInferenceBlockedSource(source)) {
-            const inferredType = inferTypeForHomomorphicMappedType(source, target, constraintType);
-            if (inferredType) {
-              inferWithPriority(
-                inferredType,
-                inference.typeParameter,
-                getObjectFlags(source) & 262144 /* NonInferrableType */ ? 16 /* PartialHomomorphicMappedType */ : 8 /* HomomorphicMappedType */
-              );
-            }
-          }
-          return true;
-        }
-        if (constraintType.flags & 262144 /* TypeParameter */) {
-          inferWithPriority(getIndexType(
-            source,
-            /*indexFlags*/
-            !!source.pattern ? 2 /* NoIndexSignatures */ : 0 /* None */
-          ), constraintType, 32 /* MappedTypeConstraint */);
-          const extendedConstraint = getConstraintOfType(constraintType);
-          if (extendedConstraint && inferToMappedType(source, target, extendedConstraint)) {
-            return true;
-          }
-          const propTypes = map(getPropertiesOfType(source), getTypeOfSymbol);
-          const indexTypes = map(getIndexInfosOfType(source), (info) => info !== enumNumberIndexInfo ? info.type : neverType);
-          inferFromTypes(getUnionType(concatenate(propTypes, indexTypes)), getTemplateTypeFromMappedType(target));
-          return true;
-        }
-        return false;
-      }
-      function inferToConditionalType(source, target) {
-        if (source.flags & 16777216 /* Conditional */) {
-          inferFromTypes(source.checkType, target.checkType);
-          inferFromTypes(source.extendsType, target.extendsType);
-          inferFromTypes(getTrueTypeFromConditionalType(source), getTrueTypeFromConditionalType(target));
-          inferFromTypes(getFalseTypeFromConditionalType(source), getFalseTypeFromConditionalType(target));
-        } else {
-          const targetTypes = [getTrueTypeFromConditionalType(target), getFalseTypeFromConditionalType(target)];
-          inferToMultipleTypesWithPriority(source, targetTypes, target.flags, contravariant ? 64 /* ContravariantConditional */ : 0);
-        }
-      }
-      function inferToTemplateLiteralType(source, target) {
-        const matches = inferTypesFromTemplateLiteralType(source, target);
-        const types = target.types;
-        if (matches || every(target.texts, (s) => s.length === 0)) {
-          for (let i = 0; i < types.length; i++) {
-            const source2 = matches ? matches[i] : neverType;
-            const target2 = types[i];
-            if (source2.flags & 128 /* StringLiteral */ && target2.flags & 8650752 /* TypeVariable */) {
-              const inferenceContext = getInferenceInfoForType(target2);
-              const constraint = inferenceContext ? getBaseConstraintOfType(inferenceContext.typeParameter) : void 0;
-              if (constraint && !isTypeAny(constraint)) {
-                const constraintTypes = constraint.flags & 1048576 /* Union */ ? constraint.types : [constraint];
-                let allTypeFlags = reduceLeft(constraintTypes, (flags, t) => flags | t.flags, 0);
-                if (!(allTypeFlags & 4 /* String */)) {
-                  const str = source2.value;
-                  if (allTypeFlags & 296 /* NumberLike */ && !isValidNumberString(
-                    str,
-                    /*roundTripOnly*/
-                    true
-                  )) {
-                    allTypeFlags &= ~296 /* NumberLike */;
-                  }
-                  if (allTypeFlags & 2112 /* BigIntLike */ && !isValidBigIntString(
-                    str,
-                    /*roundTripOnly*/
-                    true
-                  )) {
-                    allTypeFlags &= ~2112 /* BigIntLike */;
-                  }
-                  const matchingType = reduceLeft(
-                    constraintTypes,
-                    (left, right) => !(right.flags & allTypeFlags) ? left : left.flags & 4 /* String */ ? left : right.flags & 4 /* String */ ? source2 : left.flags & 134217728 /* TemplateLiteral */ ? left : right.flags & 134217728 /* TemplateLiteral */ && isTypeMatchedByTemplateLiteralType(source2, right) ? source2 : left.flags & 268435456 /* StringMapping */ ? left : right.flags & 268435456 /* StringMapping */ && str === applyStringMapping(right.symbol, str) ? source2 : left.flags & 128 /* StringLiteral */ ? left : right.flags & 128 /* StringLiteral */ && right.value === str ? right : left.flags & 8 /* Number */ ? left : right.flags & 8 /* Number */ ? getNumberLiteralType(+str) : left.flags & 32 /* Enum */ ? left : right.flags & 32 /* Enum */ ? getNumberLiteralType(+str) : left.flags & 256 /* NumberLiteral */ ? left : right.flags & 256 /* NumberLiteral */ && right.value === +str ? right : left.flags & 64 /* BigInt */ ? left : right.flags & 64 /* BigInt */ ? parseBigIntLiteralType(str) : left.flags & 2048 /* BigIntLiteral */ ? left : right.flags & 2048 /* BigIntLiteral */ && pseudoBigIntToString(right.value) === str ? right : left.flags & 16 /* Boolean */ ? left : right.flags & 16 /* Boolean */ ? str === "true" ? trueType : str === "false" ? falseType : booleanType : left.flags & 512 /* BooleanLiteral */ ? left : right.flags & 512 /* BooleanLiteral */ && right.intrinsicName === str ? right : left.flags & 32768 /* Undefined */ ? left : right.flags & 32768 /* Undefined */ && right.intrinsicName === str ? right : left.flags & 65536 /* Null */ ? left : right.flags & 65536 /* Null */ && right.intrinsicName === str ? right : left,
-                    neverType
-                  );
-                  if (!(matchingType.flags & 131072 /* Never */)) {
-                    inferFromTypes(matchingType, target2);
-                    continue;
-                  }
-                }
-              }
-            }
-            inferFromTypes(source2, target2);
-          }
-        }
-      }
-      function inferFromObjectTypes(source, target) {
-        var _a, _b;
-        if (getObjectFlags(source) & 4 /* Reference */ && getObjectFlags(target) & 4 /* Reference */ && (source.target === target.target || isArrayType(source) && isArrayType(target))) {
-          inferFromTypeArguments(getTypeArguments(source), getTypeArguments(target), getVariances(source.target));
-          return;
-        }
-        if (isGenericMappedType(source) && isGenericMappedType(target)) {
-          inferFromTypes(getConstraintTypeFromMappedType(source), getConstraintTypeFromMappedType(target));
-          inferFromTypes(getTemplateTypeFromMappedType(source), getTemplateTypeFromMappedType(target));
-          const sourceNameType = getNameTypeFromMappedType(source);
-          const targetNameType = getNameTypeFromMappedType(target);
-          if (sourceNameType && targetNameType)
-            inferFromTypes(sourceNameType, targetNameType);
-        }
-        if (getObjectFlags(target) & 32 /* Mapped */ && !target.declaration.nameType) {
-          const constraintType = getConstraintTypeFromMappedType(target);
-          if (inferToMappedType(source, target, constraintType)) {
-            return;
-          }
-        }
-        if (!typesDefinitelyUnrelated(source, target)) {
-          if (isArrayOrTupleType(source)) {
-            if (isTupleType(target)) {
-              const sourceArity = getTypeReferenceArity(source);
-              const targetArity = getTypeReferenceArity(target);
-              const elementTypes = getTypeArguments(target);
-              const elementFlags = target.target.elementFlags;
-              if (isTupleType(source) && isTupleTypeStructureMatching(source, target)) {
-                for (let i = 0; i < targetArity; i++) {
-                  inferFromTypes(getTypeArguments(source)[i], elementTypes[i]);
-                }
-                return;
-              }
-              const startLength = isTupleType(source) ? Math.min(source.target.fixedLength, target.target.fixedLength) : 0;
-              const endLength = Math.min(
-                isTupleType(source) ? getEndElementCount(source.target, 3 /* Fixed */) : 0,
-                target.target.hasRestElement ? getEndElementCount(target.target, 3 /* Fixed */) : 0
-              );
-              for (let i = 0; i < startLength; i++) {
-                inferFromTypes(getTypeArguments(source)[i], elementTypes[i]);
-              }
-              if (!isTupleType(source) || sourceArity - startLength - endLength === 1 && source.target.elementFlags[startLength] & 4 /* Rest */) {
-                const restType = getTypeArguments(source)[startLength];
-                for (let i = startLength; i < targetArity - endLength; i++) {
-                  inferFromTypes(elementFlags[i] & 8 /* Variadic */ ? createArrayType(restType) : restType, elementTypes[i]);
-                }
-              } else {
-                const middleLength = targetArity - startLength - endLength;
-                if (middleLength === 2) {
-                  if (elementFlags[startLength] & elementFlags[startLength + 1] & 8 /* Variadic */) {
-                    const targetInfo = getInferenceInfoForType(elementTypes[startLength]);
-                    if (targetInfo && targetInfo.impliedArity !== void 0) {
-                      inferFromTypes(sliceTupleType(source, startLength, endLength + sourceArity - targetInfo.impliedArity), elementTypes[startLength]);
-                      inferFromTypes(sliceTupleType(source, startLength + targetInfo.impliedArity, endLength), elementTypes[startLength + 1]);
-                    }
-                  } else if (elementFlags[startLength] & 8 /* Variadic */ && elementFlags[startLength + 1] & 4 /* Rest */) {
-                    const param = (_a = getInferenceInfoForType(elementTypes[startLength])) == null ? void 0 : _a.typeParameter;
-                    const constraint = param && getBaseConstraintOfType(param);
-                    if (constraint && isTupleType(constraint) && !constraint.target.hasRestElement) {
-                      const impliedArity = constraint.target.fixedLength;
-                      inferFromTypes(sliceTupleType(source, startLength, sourceArity - (startLength + impliedArity)), elementTypes[startLength]);
-                      inferFromTypes(getElementTypeOfSliceOfTupleType(source, startLength + impliedArity, endLength), elementTypes[startLength + 1]);
-                    }
-                  } else if (elementFlags[startLength] & 4 /* Rest */ && elementFlags[startLength + 1] & 8 /* Variadic */) {
-                    const param = (_b = getInferenceInfoForType(elementTypes[startLength + 1])) == null ? void 0 : _b.typeParameter;
-                    const constraint = param && getBaseConstraintOfType(param);
-                    if (constraint && isTupleType(constraint) && !constraint.target.hasRestElement) {
-                      const impliedArity = constraint.target.fixedLength;
-                      const endIndex = sourceArity - getEndElementCount(target.target, 3 /* Fixed */);
-                      const startIndex = endIndex - impliedArity;
-                      const trailingSlice = createTupleType(
-                        getTypeArguments(source).slice(startIndex, endIndex),
-                        source.target.elementFlags.slice(startIndex, endIndex),
-                        /*readonly*/
-                        false,
-                        source.target.labeledElementDeclarations && source.target.labeledElementDeclarations.slice(startIndex, endIndex)
-                      );
-                      inferFromTypes(getElementTypeOfSliceOfTupleType(source, startLength, endLength + impliedArity), elementTypes[startLength]);
-                      inferFromTypes(trailingSlice, elementTypes[startLength + 1]);
-                    }
-                  }
-                } else if (middleLength === 1 && elementFlags[startLength] & 8 /* Variadic */) {
-                  const endsInOptional = target.target.elementFlags[targetArity - 1] & 2 /* Optional */;
-                  const sourceSlice = sliceTupleType(source, startLength, endLength);
-                  inferWithPriority(sourceSlice, elementTypes[startLength], endsInOptional ? 2 /* SpeculativeTuple */ : 0);
-                } else if (middleLength === 1 && elementFlags[startLength] & 4 /* Rest */) {
-                  const restType = getElementTypeOfSliceOfTupleType(source, startLength, endLength);
-                  if (restType) {
-                    inferFromTypes(restType, elementTypes[startLength]);
-                  }
-                }
-              }
-              for (let i = 0; i < endLength; i++) {
-                inferFromTypes(getTypeArguments(source)[sourceArity - i - 1], elementTypes[targetArity - i - 1]);
-              }
-              return;
-            }
-            if (isArrayType(target)) {
-              inferFromIndexTypes(source, target);
-              return;
-            }
-          }
-          inferFromProperties(source, target);
-          inferFromSignatures(source, target, 0 /* Call */);
-          inferFromSignatures(source, target, 1 /* Construct */);
-          inferFromIndexTypes(source, target);
-        }
-      }
-      function inferFromProperties(source, target) {
-        const properties = getPropertiesOfObjectType(target);
-        for (const targetProp of properties) {
-          const sourceProp = getPropertyOfType(source, targetProp.escapedName);
-          if (sourceProp && !some(sourceProp.declarations, hasSkipDirectInferenceFlag)) {
-            inferFromTypes(getTypeOfSymbol(sourceProp), getTypeOfSymbol(targetProp));
-          }
-        }
-      }
-      function inferFromSignatures(source, target, kind) {
-        const sourceSignatures = getSignaturesOfType(source, kind);
-        const targetSignatures = getSignaturesOfType(target, kind);
-        const sourceLen = sourceSignatures.length;
-        const targetLen = targetSignatures.length;
-        const len = sourceLen < targetLen ? sourceLen : targetLen;
-        for (let i = 0; i < len; i++) {
-          inferFromSignature(getBaseSignature(sourceSignatures[sourceLen - len + i]), getErasedSignature(targetSignatures[targetLen - len + i]));
-        }
-      }
-      function inferFromSignature(source, target) {
-        if (!(source.flags & 64 /* IsNonInferrable */)) {
-          const saveBivariant = bivariant;
-          const kind = target.declaration ? target.declaration.kind : 0 /* Unknown */;
-          bivariant = bivariant || kind === 173 /* MethodDeclaration */ || kind === 172 /* MethodSignature */ || kind === 175 /* Constructor */;
-          applyToParameterTypes(source, target, inferFromContravariantTypesIfStrictFunctionTypes);
-          bivariant = saveBivariant;
-        }
-        applyToReturnTypes(source, target, inferFromTypes);
-      }
-      function inferFromIndexTypes(source, target) {
-        const priority2 = getObjectFlags(source) & getObjectFlags(target) & 32 /* Mapped */ ? 8 /* HomomorphicMappedType */ : 0;
-        const indexInfos = getIndexInfosOfType(target);
-        if (isObjectTypeWithInferableIndex(source)) {
-          for (const targetInfo of indexInfos) {
-            const propTypes = [];
-            for (const prop of getPropertiesOfType(source)) {
-              if (isApplicableIndexType(getLiteralTypeFromProperty(prop, 8576 /* StringOrNumberLiteralOrUnique */), targetInfo.keyType)) {
-                const propType = getTypeOfSymbol(prop);
-                propTypes.push(prop.flags & 16777216 /* Optional */ ? removeMissingOrUndefinedType(propType) : propType);
-              }
-            }
-            for (const info of getIndexInfosOfType(source)) {
-              if (isApplicableIndexType(info.keyType, targetInfo.keyType)) {
-                propTypes.push(info.type);
-              }
-            }
-            if (propTypes.length) {
-              inferWithPriority(getUnionType(propTypes), targetInfo.type, priority2);
-            }
-          }
-        }
-        for (const targetInfo of indexInfos) {
-          const sourceInfo = getApplicableIndexInfo(source, targetInfo.keyType);
-          if (sourceInfo) {
-            inferWithPriority(sourceInfo.type, targetInfo.type, priority2);
-          }
-        }
-      }
-    }
-    function isTypeOrBaseIdenticalTo(s, t) {
-      return t === missingType ? s === t : isTypeIdenticalTo(s, t) || !!(t.flags & 4 /* String */ && s.flags & 128 /* StringLiteral */ || t.flags & 8 /* Number */ && s.flags & 256 /* NumberLiteral */);
-    }
-    function isTypeCloselyMatchedBy(s, t) {
-      return !!(s.flags & 524288 /* Object */ && t.flags & 524288 /* Object */ && s.symbol && s.symbol === t.symbol || s.aliasSymbol && s.aliasTypeArguments && s.aliasSymbol === t.aliasSymbol);
-    }
-    function hasPrimitiveConstraint(type) {
-      const constraint = getConstraintOfTypeParameter(type);
-      return !!constraint && maybeTypeOfKind(constraint.flags & 16777216 /* Conditional */ ? getDefaultConstraintOfConditionalType(constraint) : constraint, 402784252 /* Primitive */ | 4194304 /* Index */ | 134217728 /* TemplateLiteral */ | 268435456 /* StringMapping */);
-    }
-    function isObjectLiteralType2(type) {
-      return !!(getObjectFlags(type) & 128 /* ObjectLiteral */);
-    }
-    function isObjectOrArrayLiteralType(type) {
-      return !!(getObjectFlags(type) & (128 /* ObjectLiteral */ | 16384 /* ArrayLiteral */));
-    }
-    function unionObjectAndArrayLiteralCandidates(candidates) {
-      if (candidates.length > 1) {
-        const objectLiterals = filter(candidates, isObjectOrArrayLiteralType);
-        if (objectLiterals.length) {
-          const literalsType = getUnionType(objectLiterals, 2 /* Subtype */);
-          return concatenate(filter(candidates, (t) => !isObjectOrArrayLiteralType(t)), [literalsType]);
-        }
-      }
-      return candidates;
-    }
-    function getContravariantInference(inference) {
-      return inference.priority & 416 /* PriorityImpliesCombination */ ? getIntersectionType(inference.contraCandidates) : getCommonSubtype(inference.contraCandidates);
-    }
-    function getCovariantInference(inference, signature) {
-      const candidates = unionObjectAndArrayLiteralCandidates(inference.candidates);
-      const primitiveConstraint = hasPrimitiveConstraint(inference.typeParameter) || isConstTypeVariable(inference.typeParameter);
-      const widenLiteralTypes = !primitiveConstraint && inference.topLevel && (inference.isFixed || !isTypeParameterAtTopLevelInReturnType(signature, inference.typeParameter));
-      const baseCandidates = primitiveConstraint ? sameMap(candidates, getRegularTypeOfLiteralType) : widenLiteralTypes ? sameMap(candidates, getWidenedLiteralType) : candidates;
-      const unwidenedType = inference.priority & 416 /* PriorityImpliesCombination */ ? getUnionType(baseCandidates, 2 /* Subtype */) : getCommonSupertype(baseCandidates);
-      return getWidenedType(unwidenedType);
-    }
-    function getInferredType(context, index) {
-      const inference = context.inferences[index];
-      if (!inference.inferredType) {
-        let inferredType;
-        let fallbackType;
-        if (context.signature) {
-          const inferredCovariantType = inference.candidates ? getCovariantInference(inference, context.signature) : void 0;
-          const inferredContravariantType = inference.contraCandidates ? getContravariantInference(inference) : void 0;
-          if (inferredCovariantType || inferredContravariantType) {
-            const preferCovariantType = inferredCovariantType && (!inferredContravariantType || !(inferredCovariantType.flags & 131072 /* Never */) && some(inference.contraCandidates, (t) => isTypeSubtypeOf(inferredCovariantType, t)) && every(context.inferences, (other) => other !== inference && getConstraintOfTypeParameter(other.typeParameter) !== inference.typeParameter || every(other.candidates, (t) => isTypeSubtypeOf(t, inferredCovariantType))));
-            inferredType = preferCovariantType ? inferredCovariantType : inferredContravariantType;
-            fallbackType = preferCovariantType ? inferredContravariantType : inferredCovariantType;
-          } else if (context.flags & 1 /* NoDefault */) {
-            inferredType = silentNeverType;
-          } else {
-            const defaultType = getDefaultFromTypeParameter(inference.typeParameter);
-            if (defaultType) {
-              inferredType = instantiateType(defaultType, mergeTypeMappers(createBackreferenceMapper(context, index), context.nonFixingMapper));
-            }
-          }
-        } else {
-          inferredType = getTypeFromInference(inference);
-        }
-        inference.inferredType = inferredType || getDefaultTypeArgumentType(!!(context.flags & 2 /* AnyDefault */));
-        const constraint = getConstraintOfTypeParameter(inference.typeParameter);
-        if (constraint) {
-          const instantiatedConstraint = instantiateType(constraint, context.nonFixingMapper);
-          if (!inferredType || !context.compareTypes(inferredType, getTypeWithThisArgument(instantiatedConstraint, inferredType))) {
-            inference.inferredType = fallbackType && context.compareTypes(fallbackType, getTypeWithThisArgument(instantiatedConstraint, fallbackType)) ? fallbackType : instantiatedConstraint;
-          }
-        }
-      }
-      return inference.inferredType;
-    }
-    function getDefaultTypeArgumentType(isInJavaScriptFile) {
-      return isInJavaScriptFile ? anyType : unknownType;
-    }
-    function getInferredTypes(context) {
-      const result = [];
-      for (let i = 0; i < context.inferences.length; i++) {
-        result.push(getInferredType(context, i));
-      }
-      return result;
-    }
-    function getCannotFindNameDiagnosticForName(node) {
-      switch (node.escapedText) {
-        case "document":
-        case "console":
-          return Diagnostics.Cannot_find_name_0_Do_you_need_to_change_your_target_library_Try_changing_the_lib_compiler_option_to_include_dom;
-        case "$":
-          return compilerOptions.types ? Diagnostics.Cannot_find_name_0_Do_you_need_to_install_type_definitions_for_jQuery_Try_npm_i_save_dev_types_Slashjquery_and_then_add_jquery_to_the_types_field_in_your_tsconfig : Diagnostics.Cannot_find_name_0_Do_you_need_to_install_type_definitions_for_jQuery_Try_npm_i_save_dev_types_Slashjquery;
-        case "describe":
-        case "suite":
-        case "it":
-        case "test":
-          return compilerOptions.types ? Diagnostics.Cannot_find_name_0_Do_you_need_to_install_type_definitions_for_a_test_runner_Try_npm_i_save_dev_types_Slashjest_or_npm_i_save_dev_types_Slashmocha_and_then_add_jest_or_mocha_to_the_types_field_in_your_tsconfig : Diagnostics.Cannot_find_name_0_Do_you_need_to_install_type_definitions_for_a_test_runner_Try_npm_i_save_dev_types_Slashjest_or_npm_i_save_dev_types_Slashmocha;
-        case "process":
-        case "require":
-        case "Buffer":
-        case "module":
-          return compilerOptions.types ? Diagnostics.Cannot_find_name_0_Do_you_need_to_install_type_definitions_for_node_Try_npm_i_save_dev_types_Slashnode_and_then_add_node_to_the_types_field_in_your_tsconfig : Diagnostics.Cannot_find_name_0_Do_you_need_to_install_type_definitions_for_node_Try_npm_i_save_dev_types_Slashnode;
-        case "Map":
-        case "Set":
-        case "Promise":
-        case "Symbol":
-        case "WeakMap":
-        case "WeakSet":
-        case "Iterator":
-        case "AsyncIterator":
-        case "SharedArrayBuffer":
-        case "Atomics":
-        case "AsyncIterable":
-        case "AsyncIterableIterator":
-        case "AsyncGenerator":
-        case "AsyncGeneratorFunction":
-        case "BigInt":
-        case "Reflect":
-        case "BigInt64Array":
-        case "BigUint64Array":
-          return Diagnostics.Cannot_find_name_0_Do_you_need_to_change_your_target_library_Try_changing_the_lib_compiler_option_to_1_or_later;
-        case "await":
-          if (isCallExpression(node.parent)) {
-            return Diagnostics.Cannot_find_name_0_Did_you_mean_to_write_this_in_an_async_function;
-          }
-        default:
-          if (node.parent.kind === 303 /* ShorthandPropertyAssignment */) {
-            return Diagnostics.No_value_exists_in_scope_for_the_shorthand_property_0_Either_declare_one_or_provide_an_initializer;
-          } else {
-            return Diagnostics.Cannot_find_name_0;
-          }
-      }
-    }
-    function getResolvedSymbol(node) {
-      const links = getNodeLinks(node);
-      if (!links.resolvedSymbol) {
-        links.resolvedSymbol = !nodeIsMissing(node) && resolveName(
-          node,
-          node.escapedText,
-          111551 /* Value */ | 1048576 /* ExportValue */,
-          getCannotFindNameDiagnosticForName(node),
-          node,
-          !isWriteOnlyAccess(node),
-          /*excludeGlobals*/
-          false
-        ) || unknownSymbol;
-      }
-      return links.resolvedSymbol;
-    }
-    function isInTypeQuery(node) {
-      return !!findAncestor(
-        node,
-        (n) => n.kind === 185 /* TypeQuery */ ? true : n.kind === 80 /* Identifier */ || n.kind === 165 /* QualifiedName */ ? false : "quit"
-      );
-    }
-    function isInAmbientOrTypeNode(node) {
-      return !!(node.flags & 16777216 /* Ambient */ || findAncestor(node, (n) => isInterfaceDeclaration(n) || isTypeAliasDeclaration(n) || isTypeLiteralNode(n)));
-    }
-    function getFlowCacheKey(node, declaredType, initialType, flowContainer) {
-      switch (node.kind) {
-        case 80 /* Identifier */:
-          if (!isThisInTypeQuery(node)) {
-            const symbol = getResolvedSymbol(node);
-            return symbol !== unknownSymbol ? `${flowContainer ? getNodeId(flowContainer) : "-1"}|${getTypeId(declaredType)}|${getTypeId(initialType)}|${getSymbolId(symbol)}` : void 0;
-          }
-        case 110 /* ThisKeyword */:
-          return `0|${flowContainer ? getNodeId(flowContainer) : "-1"}|${getTypeId(declaredType)}|${getTypeId(initialType)}`;
-        case 234 /* NonNullExpression */:
-        case 216 /* ParenthesizedExpression */:
-          return getFlowCacheKey(node.expression, declaredType, initialType, flowContainer);
-        case 165 /* QualifiedName */:
-          const left = getFlowCacheKey(node.left, declaredType, initialType, flowContainer);
-          return left && left + "." + node.right.escapedText;
-        case 210 /* PropertyAccessExpression */:
-        case 211 /* ElementAccessExpression */:
-          const propName = getAccessedPropertyName(node);
-          if (propName !== void 0) {
-            const key = getFlowCacheKey(node.expression, declaredType, initialType, flowContainer);
-            return key && key + "." + propName;
-          }
-          break;
-        case 205 /* ObjectBindingPattern */:
-        case 206 /* ArrayBindingPattern */:
-        case 261 /* FunctionDeclaration */:
-        case 217 /* FunctionExpression */:
-        case 218 /* ArrowFunction */:
-        case 173 /* MethodDeclaration */:
-          return `${getNodeId(node)}#${getTypeId(declaredType)}`;
-      }
-      return void 0;
-    }
-    function isMatchingReference(source, target) {
-      switch (target.kind) {
-        case 216 /* ParenthesizedExpression */:
-        case 234 /* NonNullExpression */:
-          return isMatchingReference(source, target.expression);
-        case 225 /* BinaryExpression */:
-          return isAssignmentExpression(target) && isMatchingReference(source, target.left) || isBinaryExpression(target) && target.operatorToken.kind === 28 /* CommaToken */ && isMatchingReference(source, target.right);
-      }
-      switch (source.kind) {
-        case 235 /* MetaProperty */:
-          return target.kind === 235 /* MetaProperty */ && source.keywordToken === target.keywordToken && source.name.escapedText === target.name.escapedText;
-        case 80 /* Identifier */:
-        case 81 /* PrivateIdentifier */:
-          return isThisInTypeQuery(source) ? target.kind === 110 /* ThisKeyword */ : target.kind === 80 /* Identifier */ && getResolvedSymbol(source) === getResolvedSymbol(target) || (isVariableDeclaration(target) || isBindingElement(target)) && getExportSymbolOfValueSymbolIfExported(getResolvedSymbol(source)) === getSymbolOfDeclaration(target);
-        case 110 /* ThisKeyword */:
-          return target.kind === 110 /* ThisKeyword */;
-        case 108 /* SuperKeyword */:
-          return target.kind === 108 /* SuperKeyword */;
-        case 234 /* NonNullExpression */:
-        case 216 /* ParenthesizedExpression */:
-          return isMatchingReference(source.expression, target);
-        case 210 /* PropertyAccessExpression */:
-        case 211 /* ElementAccessExpression */:
-          const sourcePropertyName = getAccessedPropertyName(source);
-          const targetPropertyName = isAccessExpression(target) ? getAccessedPropertyName(target) : void 0;
-          return sourcePropertyName !== void 0 && targetPropertyName !== void 0 && targetPropertyName === sourcePropertyName && isMatchingReference(source.expression, target.expression);
-        case 165 /* QualifiedName */:
-          return isAccessExpression(target) && source.right.escapedText === getAccessedPropertyName(target) && isMatchingReference(source.left, target.expression);
-        case 225 /* BinaryExpression */:
-          return isBinaryExpression(source) && source.operatorToken.kind === 28 /* CommaToken */ && isMatchingReference(source.right, target);
-      }
-      return false;
-    }
-    function getAccessedPropertyName(access) {
-      if (isPropertyAccessExpression(access)) {
-        return access.name.escapedText;
-      }
-      if (isElementAccessExpression(access)) {
-        return tryGetElementAccessExpressionName(access);
-      }
-      if (isBindingElement(access)) {
-        const name = getDestructuringPropertyName(access);
-        return name ? escapeLeadingUnderscores(name) : void 0;
-      }
-      if (isParameter(access)) {
-        return "" + access.parent.parameters.indexOf(access);
-      }
-      return void 0;
-    }
-    function tryGetNameFromType(type) {
-      return type.flags & 8192 /* UniqueESSymbol */ ? type.escapedName : type.flags & 384 /* StringOrNumberLiteral */ ? escapeLeadingUnderscores("" + type.value) : void 0;
-    }
-    function tryGetElementAccessExpressionName(node) {
-      return isStringOrNumericLiteralLike(node.argumentExpression) ? escapeLeadingUnderscores(node.argumentExpression.text) : isEntityNameExpression(node.argumentExpression) ? tryGetNameFromEntityNameExpression(node.argumentExpression) : void 0;
-    }
-    function tryGetNameFromEntityNameExpression(node) {
-      const symbol = resolveEntityName(
-        node,
-        111551 /* Value */,
-        /*ignoreErrors*/
-        true
-      );
-      if (!symbol || !(isConstVariable(symbol) || symbol.flags & 8 /* EnumMember */))
-        return void 0;
-      const declaration = symbol.valueDeclaration;
-      if (declaration === void 0)
-        return void 0;
-      const type = tryGetTypeFromEffectiveTypeNode(declaration);
-      if (type) {
-        const name = tryGetNameFromType(type);
-        if (name !== void 0) {
-          return name;
-        }
-      }
-      if (hasOnlyExpressionInitializer(declaration) && isBlockScopedNameDeclaredBeforeUse(declaration, node)) {
-        const initializer = getEffectiveInitializer(declaration);
-        if (initializer) {
-          return tryGetNameFromType(getTypeOfExpression(initializer));
-        }
-        if (isEnumMember(declaration)) {
-          return getTextOfPropertyName(declaration.name);
-        }
-      }
-      return void 0;
-    }
-    function containsMatchingReference(source, target) {
-      while (isAccessExpression(source)) {
-        source = source.expression;
-        if (isMatchingReference(source, target)) {
-          return true;
-        }
-      }
-      return false;
-    }
-    function optionalChainContainsReference(source, target) {
-      while (isOptionalChain(source)) {
-        source = source.expression;
-        if (isMatchingReference(source, target)) {
-          return true;
-        }
-      }
-      return false;
-    }
-    function isDiscriminantProperty(type, name) {
-      if (type && type.flags & 1048576 /* Union */) {
-        const prop = getUnionOrIntersectionProperty(type, name);
-        if (prop && getCheckFlags(prop) & 2 /* SyntheticProperty */) {
-          if (prop.links.isDiscriminantProperty === void 0) {
-            prop.links.isDiscriminantProperty = (prop.links.checkFlags & 192 /* Discriminant */) === 192 /* Discriminant */ && !isGenericType(getTypeOfSymbol(prop));
-          }
-          return !!prop.links.isDiscriminantProperty;
-        }
-      }
-      return false;
-    }
-    function findDiscriminantProperties(sourceProperties, target) {
-      let result;
-      for (const sourceProperty of sourceProperties) {
-        if (isDiscriminantProperty(target, sourceProperty.escapedName)) {
-          if (result) {
-            result.push(sourceProperty);
-            continue;
-          }
-          result = [sourceProperty];
-        }
-      }
-      return result;
-    }
-    function mapTypesByKeyProperty(types, name) {
-      const map2 = /* @__PURE__ */ new Map();
-      let count = 0;
-      for (const type of types) {
-        if (type.flags & (524288 /* Object */ | 2097152 /* Intersection */ | 58982400 /* InstantiableNonPrimitive */)) {
-          const discriminant = getTypeOfPropertyOfType(type, name);
-          if (discriminant) {
-            if (!isLiteralType(discriminant)) {
-              return void 0;
-            }
-            let duplicate = false;
-            forEachType(discriminant, (t) => {
-              const id = getTypeId(getRegularTypeOfLiteralType(t));
-              const existing = map2.get(id);
-              if (!existing) {
-                map2.set(id, type);
-              } else if (existing !== unknownType) {
-                map2.set(id, unknownType);
-                duplicate = true;
-              }
-            });
-            if (!duplicate)
-              count++;
-          }
-        }
-      }
-      return count >= 10 && count * 2 >= types.length ? map2 : void 0;
-    }
-    function getKeyPropertyName(unionType) {
-      const types = unionType.types;
-      if (types.length < 10 || getObjectFlags(unionType) & 32768 /* PrimitiveUnion */ || countWhere(types, (t) => !!(t.flags & (524288 /* Object */ | 58982400 /* InstantiableNonPrimitive */))) < 10) {
-        return void 0;
-      }
-      if (unionType.keyPropertyName === void 0) {
-        const keyPropertyName = forEach(types, (t) => t.flags & (524288 /* Object */ | 58982400 /* InstantiableNonPrimitive */) ? forEach(getPropertiesOfType(t), (p) => isUnitType(getTypeOfSymbol(p)) ? p.escapedName : void 0) : void 0);
-        const mapByKeyProperty = keyPropertyName && mapTypesByKeyProperty(types, keyPropertyName);
-        unionType.keyPropertyName = mapByKeyProperty ? keyPropertyName : "";
-        unionType.constituentMap = mapByKeyProperty;
-      }
-      return unionType.keyPropertyName.length ? unionType.keyPropertyName : void 0;
-    }
-    function getConstituentTypeForKeyType(unionType, keyType) {
-      var _a;
-      const result = (_a = unionType.constituentMap) == null ? void 0 : _a.get(getTypeId(getRegularTypeOfLiteralType(keyType)));
-      return result !== unknownType ? result : void 0;
-    }
-    function getMatchingUnionConstituentForType(unionType, type) {
-      const keyPropertyName = getKeyPropertyName(unionType);
-      const propType = keyPropertyName && getTypeOfPropertyOfType(type, keyPropertyName);
-      return propType && getConstituentTypeForKeyType(unionType, propType);
-    }
-    function getMatchingUnionConstituentForObjectLiteral(unionType, node) {
-      const keyPropertyName = getKeyPropertyName(unionType);
-      const propNode = keyPropertyName && find(node.properties, (p) => p.symbol && p.kind === 302 /* PropertyAssignment */ && p.symbol.escapedName === keyPropertyName && isPossiblyDiscriminantValue(p.initializer));
-      const propType = propNode && getContextFreeTypeOfExpression(propNode.initializer);
-      return propType && getConstituentTypeForKeyType(unionType, propType);
-    }
-    function isOrContainsMatchingReference(source, target) {
-      return isMatchingReference(source, target) || containsMatchingReference(source, target);
-    }
-    function hasMatchingArgument(expression, reference) {
-      if (expression.arguments) {
-        for (const argument of expression.arguments) {
-          if (isOrContainsMatchingReference(reference, argument)) {
-            return true;
-          }
-        }
-      }
-      if (expression.expression.kind === 210 /* PropertyAccessExpression */ && isOrContainsMatchingReference(reference, expression.expression.expression)) {
-        return true;
-      }
-      return false;
-    }
-    function getFlowNodeId(flow) {
-      if (!flow.id || flow.id < 0) {
-        flow.id = nextFlowId;
-        nextFlowId++;
-      }
-      return flow.id;
-    }
-    function typeMaybeAssignableTo(source, target) {
-      if (!(source.flags & 1048576 /* Union */)) {
-        return isTypeAssignableTo(source, target);
-      }
-      for (const t of source.types) {
-        if (isTypeAssignableTo(t, target)) {
-          return true;
-        }
-      }
-      return false;
-    }
-    function getAssignmentReducedType(declaredType, assignedType) {
-      if (declaredType === assignedType) {
-        return declaredType;
-      }
-      if (assignedType.flags & 131072 /* Never */) {
-        return assignedType;
-      }
-      const key = `A${getTypeId(declaredType)},${getTypeId(assignedType)}`;
-      return getCachedType(key) ?? setCachedType(key, getAssignmentReducedTypeWorker(declaredType, assignedType));
-    }
-    function getAssignmentReducedTypeWorker(declaredType, assignedType) {
-      const filteredType = filterType(declaredType, (t) => typeMaybeAssignableTo(assignedType, t));
-      const reducedType = assignedType.flags & 512 /* BooleanLiteral */ && isFreshLiteralType(assignedType) ? mapType(filteredType, getFreshTypeOfLiteralType) : filteredType;
-      return isTypeAssignableTo(assignedType, reducedType) ? reducedType : declaredType;
-    }
-    function isFunctionObjectType(type) {
-      const resolved = resolveStructuredTypeMembers(type);
-      return !!(resolved.callSignatures.length || resolved.constructSignatures.length || resolved.members.get("bind") && isTypeSubtypeOf(type, globalFunctionType));
-    }
-    function getTypeFacts(type) {
-      if (type.flags & (2097152 /* Intersection */ | 465829888 /* Instantiable */)) {
-        type = getBaseConstraintOfType(type) || unknownType;
-      }
-      const flags = type.flags;
-      if (flags & (4 /* String */ | 268435456 /* StringMapping */)) {
-        return strictNullChecks ? 16317953 /* StringStrictFacts */ : 16776705 /* StringFacts */;
-      }
-      if (flags & (128 /* StringLiteral */ | 134217728 /* TemplateLiteral */)) {
-        const isEmpty = flags & 128 /* StringLiteral */ && type.value === "";
-        return strictNullChecks ? isEmpty ? 12123649 /* EmptyStringStrictFacts */ : 7929345 /* NonEmptyStringStrictFacts */ : isEmpty ? 12582401 /* EmptyStringFacts */ : 16776705 /* NonEmptyStringFacts */;
-      }
-      if (flags & (8 /* Number */ | 32 /* Enum */)) {
-        return strictNullChecks ? 16317698 /* NumberStrictFacts */ : 16776450 /* NumberFacts */;
-      }
-      if (flags & 256 /* NumberLiteral */) {
-        const isZero = type.value === 0;
-        return strictNullChecks ? isZero ? 12123394 /* ZeroNumberStrictFacts */ : 7929090 /* NonZeroNumberStrictFacts */ : isZero ? 12582146 /* ZeroNumberFacts */ : 16776450 /* NonZeroNumberFacts */;
-      }
-      if (flags & 64 /* BigInt */) {
-        return strictNullChecks ? 16317188 /* BigIntStrictFacts */ : 16775940 /* BigIntFacts */;
-      }
-      if (flags & 2048 /* BigIntLiteral */) {
-        const isZero = isZeroBigInt(type);
-        return strictNullChecks ? isZero ? 12122884 /* ZeroBigIntStrictFacts */ : 7928580 /* NonZeroBigIntStrictFacts */ : isZero ? 12581636 /* ZeroBigIntFacts */ : 16775940 /* NonZeroBigIntFacts */;
-      }
-      if (flags & 16 /* Boolean */) {
-        return strictNullChecks ? 16316168 /* BooleanStrictFacts */ : 16774920 /* BooleanFacts */;
-      }
-      if (flags & 528 /* BooleanLike */) {
-        return strictNullChecks ? type === falseType || type === regularFalseType ? 12121864 /* FalseStrictFacts */ : 7927560 /* TrueStrictFacts */ : type === falseType || type === regularFalseType ? 12580616 /* FalseFacts */ : 16774920 /* TrueFacts */;
-      }
-      if (flags & 524288 /* Object */) {
-        return getObjectFlags(type) & 16 /* Anonymous */ && isEmptyObjectType(type) ? strictNullChecks ? 83427327 /* EmptyObjectStrictFacts */ : 83886079 /* EmptyObjectFacts */ : isFunctionObjectType(type) ? strictNullChecks ? 7880640 /* FunctionStrictFacts */ : 16728e3 /* FunctionFacts */ : strictNullChecks ? 7888800 /* ObjectStrictFacts */ : 16736160 /* ObjectFacts */;
-      }
-      if (flags & 16384 /* Void */) {
-        return 9830144 /* VoidFacts */;
-      }
-      if (flags & 32768 /* Undefined */) {
-        return 26607360 /* UndefinedFacts */;
-      }
-      if (flags & 65536 /* Null */) {
-        return 42917664 /* NullFacts */;
-      }
-      if (flags & 12288 /* ESSymbolLike */) {
-        return strictNullChecks ? 7925520 /* SymbolStrictFacts */ : 16772880 /* SymbolFacts */;
-      }
-      if (flags & 67108864 /* NonPrimitive */) {
-        return strictNullChecks ? 7888800 /* ObjectStrictFacts */ : 16736160 /* ObjectFacts */;
-      }
-      if (flags & 131072 /* Never */) {
-        return 0 /* None */;
-      }
-      if (flags & 1048576 /* Union */) {
-        return reduceLeft(type.types, (facts, t) => facts | getTypeFacts(t), 0 /* None */);
-      }
-      if (flags & 2097152 /* Intersection */) {
-        return getIntersectionTypeFacts(type);
-      }
-      return 83886079 /* UnknownFacts */;
-    }
-    function getIntersectionTypeFacts(type) {
-      const ignoreObjects = maybeTypeOfKind(type, 402784252 /* Primitive */);
-      let oredFacts = 0 /* None */;
-      let andedFacts = 134217727 /* All */;
-      for (const t of type.types) {
-        if (!(ignoreObjects && t.flags & 524288 /* Object */)) {
-          const f = getTypeFacts(t);
-          oredFacts |= f;
-          andedFacts &= f;
-        }
-      }
-      return oredFacts & 8256 /* OrFactsMask */ | andedFacts & 134209471 /* AndFactsMask */;
-    }
-    function getTypeWithFacts(type, include) {
-      return filterType(type, (t) => (getTypeFacts(t) & include) !== 0);
-    }
-    function getAdjustedTypeWithFacts(type, facts) {
-      const reduced = recombineUnknownType(getTypeWithFacts(strictNullChecks && type.flags & 2 /* Unknown */ ? unknownUnionType : type, facts));
-      if (strictNullChecks) {
-        switch (facts) {
-          case 524288 /* NEUndefined */:
-            return mapType(reduced, (t) => getTypeFacts(t) & 65536 /* EQUndefined */ ? getIntersectionType([t, getTypeFacts(t) & 131072 /* EQNull */ && !maybeTypeOfKind(reduced, 65536 /* Null */) ? getUnionType([emptyObjectType, nullType]) : emptyObjectType]) : t);
-          case 1048576 /* NENull */:
-            return mapType(reduced, (t) => getTypeFacts(t) & 131072 /* EQNull */ ? getIntersectionType([t, getTypeFacts(t) & 65536 /* EQUndefined */ && !maybeTypeOfKind(reduced, 32768 /* Undefined */) ? getUnionType([emptyObjectType, undefinedType]) : emptyObjectType]) : t);
-          case 2097152 /* NEUndefinedOrNull */:
-          case 4194304 /* Truthy */:
-            return mapType(reduced, (t) => getTypeFacts(t) & 262144 /* EQUndefinedOrNull */ ? getGlobalNonNullableTypeInstantiation(t) : t);
-        }
-      }
-      return reduced;
-    }
-    function recombineUnknownType(type) {
-      return type === unknownUnionType ? unknownType : type;
-    }
-    function getTypeWithDefault(type, defaultExpression) {
-      return defaultExpression ? getUnionType([getNonUndefinedType(type), getTypeOfExpression(defaultExpression)]) : type;
-    }
-    function getTypeOfDestructuredProperty(type, name) {
-      var _a;
-      const nameType = getLiteralTypeFromPropertyName(name);
-      if (!isTypeUsableAsPropertyName(nameType))
-        return errorType;
-      const text = getPropertyNameFromType(nameType);
-      return getTypeOfPropertyOfType(type, text) || includeUndefinedInIndexSignature((_a = getApplicableIndexInfoForName(type, text)) == null ? void 0 : _a.type) || errorType;
-    }
-    function getTypeOfDestructuredArrayElement(type, index) {
-      return everyType(type, isTupleLikeType) && getTupleElementType(type, index) || includeUndefinedInIndexSignature(checkIteratedTypeOrElementType(
-        65 /* Destructuring */,
-        type,
-        undefinedType,
-        /*errorNode*/
-        void 0
-      )) || errorType;
-    }
-    function includeUndefinedInIndexSignature(type) {
-      if (!type)
-        return type;
-      return compilerOptions.noUncheckedIndexedAccess ? getUnionType([type, missingType]) : type;
-    }
-    function getTypeOfDestructuredSpreadExpression(type) {
-      return createArrayType(checkIteratedTypeOrElementType(
-        65 /* Destructuring */,
-        type,
-        undefinedType,
-        /*errorNode*/
-        void 0
-      ) || errorType);
-    }
-    function getAssignedTypeOfBinaryExpression(node) {
-      const isDestructuringDefaultAssignment = node.parent.kind === 208 /* ArrayLiteralExpression */ && isDestructuringAssignmentTarget(node.parent) || node.parent.kind === 302 /* PropertyAssignment */ && isDestructuringAssignmentTarget(node.parent.parent);
-      return isDestructuringDefaultAssignment ? getTypeWithDefault(getAssignedType(node), node.right) : getTypeOfExpression(node.right);
-    }
-    function isDestructuringAssignmentTarget(parent2) {
-      return parent2.parent.kind === 225 /* BinaryExpression */ && parent2.parent.left === parent2 || parent2.parent.kind === 249 /* ForOfStatement */ && parent2.parent.initializer === parent2;
-    }
-    function getAssignedTypeOfArrayLiteralElement(node, element) {
-      return getTypeOfDestructuredArrayElement(getAssignedType(node), node.elements.indexOf(element));
-    }
-    function getAssignedTypeOfSpreadExpression(node) {
-      return getTypeOfDestructuredSpreadExpression(getAssignedType(node.parent));
-    }
-    function getAssignedTypeOfPropertyAssignment(node) {
-      return getTypeOfDestructuredProperty(getAssignedType(node.parent), node.name);
-    }
-    function getAssignedTypeOfShorthandPropertyAssignment(node) {
-      return getTypeWithDefault(getAssignedTypeOfPropertyAssignment(node), node.objectAssignmentInitializer);
-    }
-    function getAssignedType(node) {
-      const { parent: parent2 } = node;
-      switch (parent2.kind) {
-        case 248 /* ForInStatement */:
-          return stringType;
-        case 249 /* ForOfStatement */:
-          return checkRightHandSideOfForOf(parent2) || errorType;
-        case 225 /* BinaryExpression */:
-          return getAssignedTypeOfBinaryExpression(parent2);
-        case 219 /* DeleteExpression */:
-          return undefinedType;
-        case 208 /* ArrayLiteralExpression */:
-          return getAssignedTypeOfArrayLiteralElement(parent2, node);
-        case 229 /* SpreadElement */:
-          return getAssignedTypeOfSpreadExpression(parent2);
-        case 302 /* PropertyAssignment */:
-          return getAssignedTypeOfPropertyAssignment(parent2);
-        case 303 /* ShorthandPropertyAssignment */:
-          return getAssignedTypeOfShorthandPropertyAssignment(parent2);
-      }
-      return errorType;
-    }
-    function getInitialTypeOfBindingElement(node) {
-      const pattern = node.parent;
-      const parentType = getInitialType(pattern.parent);
-      const type = pattern.kind === 205 /* ObjectBindingPattern */ ? getTypeOfDestructuredProperty(parentType, node.propertyName || node.name) : !node.dotDotDotToken ? getTypeOfDestructuredArrayElement(parentType, pattern.elements.indexOf(node)) : getTypeOfDestructuredSpreadExpression(parentType);
-      return getTypeWithDefault(type, node.initializer);
-    }
-    function getTypeOfInitializer(node) {
-      const links = getNodeLinks(node);
-      return links.resolvedType || getTypeOfExpression(node);
-    }
-    function getInitialTypeOfVariableDeclaration(node) {
-      if (node.initializer) {
-        return getTypeOfInitializer(node.initializer);
-      }
-      if (node.parent.parent.kind === 248 /* ForInStatement */) {
-        return stringType;
-      }
-      if (node.parent.parent.kind === 249 /* ForOfStatement */) {
-        return checkRightHandSideOfForOf(node.parent.parent) || errorType;
-      }
-      return errorType;
-    }
-    function getInitialType(node) {
-      return node.kind === 259 /* VariableDeclaration */ ? getInitialTypeOfVariableDeclaration(node) : getInitialTypeOfBindingElement(node);
-    }
-    function isEmptyArrayAssignment(node) {
-      return node.kind === 259 /* VariableDeclaration */ && node.initializer && isEmptyArrayLiteral2(node.initializer) || node.kind !== 207 /* BindingElement */ && node.parent.kind === 225 /* BinaryExpression */ && isEmptyArrayLiteral2(node.parent.right);
-    }
-    function getReferenceCandidate(node) {
-      switch (node.kind) {
-        case 216 /* ParenthesizedExpression */:
-          return getReferenceCandidate(node.expression);
-        case 225 /* BinaryExpression */:
-          switch (node.operatorToken.kind) {
-            case 64 /* EqualsToken */:
-            case 76 /* BarBarEqualsToken */:
-            case 77 /* AmpersandAmpersandEqualsToken */:
-            case 78 /* QuestionQuestionEqualsToken */:
-              return getReferenceCandidate(node.left);
-            case 28 /* CommaToken */:
-              return getReferenceCandidate(node.right);
-          }
-      }
-      return node;
-    }
-    function getReferenceRoot(node) {
-      const { parent: parent2 } = node;
-      return parent2.kind === 216 /* ParenthesizedExpression */ || parent2.kind === 225 /* BinaryExpression */ && parent2.operatorToken.kind === 64 /* EqualsToken */ && parent2.left === node || parent2.kind === 225 /* BinaryExpression */ && parent2.operatorToken.kind === 28 /* CommaToken */ && parent2.right === node ? getReferenceRoot(parent2) : node;
-    }
-    function getTypeOfSwitchClause(clause) {
-      if (clause.kind === 295 /* CaseClause */) {
-        return getRegularTypeOfLiteralType(getTypeOfExpression(clause.expression));
-      }
-      return neverType;
-    }
-    function getSwitchClauseTypes(switchStatement) {
-      const links = getNodeLinks(switchStatement);
-      if (!links.switchTypes) {
-        links.switchTypes = [];
-        for (const clause of switchStatement.caseBlock.clauses) {
-          links.switchTypes.push(getTypeOfSwitchClause(clause));
-        }
-      }
-      return links.switchTypes;
-    }
-    function getSwitchClauseTypeOfWitnesses(switchStatement) {
-      if (some(switchStatement.caseBlock.clauses, (clause) => clause.kind === 295 /* CaseClause */ && !isStringLiteralLike(clause.expression))) {
-        return void 0;
-      }
-      const witnesses = [];
-      for (const clause of switchStatement.caseBlock.clauses) {
-        const text = clause.kind === 295 /* CaseClause */ ? clause.expression.text : void 0;
-        witnesses.push(text && !contains(witnesses, text) ? text : void 0);
-      }
-      return witnesses;
-    }
-    function eachTypeContainedIn(source, types) {
-      return source.flags & 1048576 /* Union */ ? !forEach(source.types, (t) => !contains(types, t)) : contains(types, source);
-    }
-    function isTypeSubsetOf(source, target) {
-      return !!(source === target || source.flags & 131072 /* Never */ || target.flags & 1048576 /* Union */ && isTypeSubsetOfUnion(source, target));
-    }
-    function isTypeSubsetOfUnion(source, target) {
-      if (source.flags & 1048576 /* Union */) {
-        for (const t of source.types) {
-          if (!containsType(target.types, t)) {
-            return false;
-          }
-        }
-        return true;
-      }
-      if (source.flags & 1056 /* EnumLike */ && getBaseTypeOfEnumLikeType(source) === target) {
-        return true;
-      }
-      return containsType(target.types, source);
-    }
-    function forEachType(type, f) {
-      return type.flags & 1048576 /* Union */ ? forEach(type.types, f) : f(type);
-    }
-    function someType(type, f) {
-      return type.flags & 1048576 /* Union */ ? some(type.types, f) : f(type);
-    }
-    function everyType(type, f) {
-      return type.flags & 1048576 /* Union */ ? every(type.types, f) : f(type);
-    }
-    function everyContainedType(type, f) {
-      return type.flags & 3145728 /* UnionOrIntersection */ ? every(type.types, f) : f(type);
-    }
-    function filterType(type, f) {
-      if (type.flags & 1048576 /* Union */) {
-        const types = type.types;
-        const filtered = filter(types, f);
-        if (filtered === types) {
-          return type;
-        }
-        const origin = type.origin;
-        let newOrigin;
-        if (origin && origin.flags & 1048576 /* Union */) {
-          const originTypes = origin.types;
-          const originFiltered = filter(originTypes, (t) => !!(t.flags & 1048576 /* Union */) || f(t));
-          if (originTypes.length - originFiltered.length === types.length - filtered.length) {
-            if (originFiltered.length === 1) {
-              return originFiltered[0];
-            }
-            newOrigin = createOriginUnionOrIntersectionType(1048576 /* Union */, originFiltered);
-          }
-        }
-        return getUnionTypeFromSortedList(
-          filtered,
-          type.objectFlags & (32768 /* PrimitiveUnion */ | 16777216 /* ContainsIntersections */),
-          /*aliasSymbol*/
-          void 0,
-          /*aliasTypeArguments*/
-          void 0,
-          newOrigin
-        );
-      }
-      return type.flags & 131072 /* Never */ || f(type) ? type : neverType;
-    }
-    function removeType(type, targetType) {
-      return filterType(type, (t) => t !== targetType);
-    }
-    function countTypes(type) {
-      return type.flags & 1048576 /* Union */ ? type.types.length : 1;
-    }
-    function mapType(type, mapper, noReductions) {
-      if (type.flags & 131072 /* Never */) {
-        return type;
-      }
-      if (!(type.flags & 1048576 /* Union */)) {
-        return mapper(type);
-      }
-      const origin = type.origin;
-      const types = origin && origin.flags & 1048576 /* Union */ ? origin.types : type.types;
-      let mappedTypes;
-      let changed = false;
-      for (const t of types) {
-        const mapped = t.flags & 1048576 /* Union */ ? mapType(t, mapper, noReductions) : mapper(t);
-        changed || (changed = t !== mapped);
-        if (mapped) {
-          if (!mappedTypes) {
-            mappedTypes = [mapped];
-          } else {
-            mappedTypes.push(mapped);
-          }
-        }
-      }
-      return changed ? mappedTypes && getUnionType(mappedTypes, noReductions ? 0 /* None */ : 1 /* Literal */) : type;
-    }
-    function mapTypeWithAlias(type, mapper, aliasSymbol, aliasTypeArguments) {
-      return type.flags & 1048576 /* Union */ && aliasSymbol ? getUnionType(map(type.types, mapper), 1 /* Literal */, aliasSymbol, aliasTypeArguments) : mapType(type, mapper);
-    }
-    function extractTypesOfKind(type, kind) {
-      return filterType(type, (t) => (t.flags & kind) !== 0);
-    }
-    function replacePrimitivesWithLiterals(typeWithPrimitives, typeWithLiterals) {
-      if (maybeTypeOfKind(typeWithPrimitives, 4 /* String */ | 134217728 /* TemplateLiteral */ | 8 /* Number */ | 64 /* BigInt */) && maybeTypeOfKind(typeWithLiterals, 128 /* StringLiteral */ | 134217728 /* TemplateLiteral */ | 268435456 /* StringMapping */ | 256 /* NumberLiteral */ | 2048 /* BigIntLiteral */)) {
-        return mapType(typeWithPrimitives, (t) => t.flags & 4 /* String */ ? extractTypesOfKind(typeWithLiterals, 4 /* String */ | 128 /* StringLiteral */ | 134217728 /* TemplateLiteral */ | 268435456 /* StringMapping */) : isPatternLiteralType(t) && !maybeTypeOfKind(typeWithLiterals, 4 /* String */ | 134217728 /* TemplateLiteral */ | 268435456 /* StringMapping */) ? extractTypesOfKind(typeWithLiterals, 128 /* StringLiteral */) : t.flags & 8 /* Number */ ? extractTypesOfKind(typeWithLiterals, 8 /* Number */ | 256 /* NumberLiteral */) : t.flags & 64 /* BigInt */ ? extractTypesOfKind(typeWithLiterals, 64 /* BigInt */ | 2048 /* BigIntLiteral */) : t);
-      }
-      return typeWithPrimitives;
-    }
-    function isIncomplete(flowType) {
-      return flowType.flags === 0;
-    }
-    function getTypeFromFlowType(flowType) {
-      return flowType.flags === 0 ? flowType.type : flowType;
-    }
-    function createFlowType(type, incomplete) {
-      return incomplete ? { flags: 0, type: type.flags & 131072 /* Never */ ? silentNeverType : type } : type;
-    }
-    function createEvolvingArrayType(elementType) {
-      const result = createObjectType(256 /* EvolvingArray */);
-      result.elementType = elementType;
-      return result;
-    }
-    function getEvolvingArrayType(elementType) {
-      return evolvingArrayTypes[elementType.id] || (evolvingArrayTypes[elementType.id] = createEvolvingArrayType(elementType));
-    }
-    function addEvolvingArrayElementType(evolvingArrayType, node) {
-      const elementType = getRegularTypeOfObjectLiteral(getBaseTypeOfLiteralType(getContextFreeTypeOfExpression(node)));
-      return isTypeSubsetOf(elementType, evolvingArrayType.elementType) ? evolvingArrayType : getEvolvingArrayType(getUnionType([evolvingArrayType.elementType, elementType]));
-    }
-    function createFinalArrayType(elementType) {
-      return elementType.flags & 131072 /* Never */ ? autoArrayType : createArrayType(elementType.flags & 1048576 /* Union */ ? getUnionType(elementType.types, 2 /* Subtype */) : elementType);
-    }
-    function getFinalArrayType(evolvingArrayType) {
-      return evolvingArrayType.finalArrayType || (evolvingArrayType.finalArrayType = createFinalArrayType(evolvingArrayType.elementType));
-    }
-    function finalizeEvolvingArrayType(type) {
-      return getObjectFlags(type) & 256 /* EvolvingArray */ ? getFinalArrayType(type) : type;
-    }
-    function getElementTypeOfEvolvingArrayType(type) {
-      return getObjectFlags(type) & 256 /* EvolvingArray */ ? type.elementType : neverType;
-    }
-    function isEvolvingArrayTypeList(types) {
-      let hasEvolvingArrayType = false;
-      for (const t of types) {
-        if (!(t.flags & 131072 /* Never */)) {
-          if (!(getObjectFlags(t) & 256 /* EvolvingArray */)) {
-            return false;
-          }
-          hasEvolvingArrayType = true;
-        }
-      }
-      return hasEvolvingArrayType;
-    }
-    function isEvolvingArrayOperationTarget(node) {
-      const root = getReferenceRoot(node);
-      const parent2 = root.parent;
-      const isLengthPushOrUnshift = isPropertyAccessExpression(parent2) && (parent2.name.escapedText === "length" || parent2.parent.kind === 212 /* CallExpression */ && isIdentifier(parent2.name) && isPushOrUnshiftIdentifier(parent2.name));
-      const isElementAssignment = parent2.kind === 211 /* ElementAccessExpression */ && parent2.expression === root && parent2.parent.kind === 225 /* BinaryExpression */ && parent2.parent.operatorToken.kind === 64 /* EqualsToken */ && parent2.parent.left === parent2 && !isAssignmentTarget(parent2.parent) && isTypeAssignableToKind(getTypeOfExpression(parent2.argumentExpression), 296 /* NumberLike */);
-      return isLengthPushOrUnshift || isElementAssignment;
-    }
-    function isDeclarationWithExplicitTypeAnnotation(node) {
-      return (isVariableDeclaration(node) || isPropertyDeclaration(node) || isPropertySignature(node) || isParameter(node)) && !!(getEffectiveTypeAnnotationNode(node) || isInJSFile(node) && hasInitializer(node) && node.initializer && isFunctionExpressionOrArrowFunction(node.initializer) && getEffectiveReturnTypeNode(node.initializer));
-    }
-    function getExplicitTypeOfSymbol(symbol, diagnostic) {
-      symbol = resolveSymbol(symbol);
-      if (symbol.flags & (16 /* Function */ | 8192 /* Method */ | 32 /* Class */ | 512 /* ValueModule */)) {
-        return getTypeOfSymbol(symbol);
-      }
-      if (symbol.flags & (3 /* Variable */ | 4 /* Property */)) {
-        if (getCheckFlags(symbol) & 262144 /* Mapped */) {
-          const origin = symbol.links.syntheticOrigin;
-          if (origin && getExplicitTypeOfSymbol(origin)) {
-            return getTypeOfSymbol(symbol);
-          }
-        }
-        const declaration = symbol.valueDeclaration;
-        if (declaration) {
-          if (isDeclarationWithExplicitTypeAnnotation(declaration)) {
-            return getTypeOfSymbol(symbol);
-          }
-          if (isVariableDeclaration(declaration) && declaration.parent.parent.kind === 249 /* ForOfStatement */) {
-            const statement = declaration.parent.parent;
-            const expressionType = getTypeOfDottedName(
-              statement.expression,
-              /*diagnostic*/
-              void 0
-            );
-            if (expressionType) {
-              const use = statement.awaitModifier ? 15 /* ForAwaitOf */ : 13 /* ForOf */;
-              return checkIteratedTypeOrElementType(
-                use,
-                expressionType,
-                undefinedType,
-                /*errorNode*/
-                void 0
-              );
-            }
-          }
-          if (diagnostic) {
-            addRelatedInfo(diagnostic, createDiagnosticForNode(declaration, Diagnostics._0_needs_an_explicit_type_annotation, symbolToString(symbol)));
-          }
-        }
-      }
-    }
-    function getTypeOfDottedName(node, diagnostic) {
-      if (!(node.flags & 33554432 /* InWithStatement */)) {
-        switch (node.kind) {
-          case 80 /* Identifier */:
-            const symbol = getExportSymbolOfValueSymbolIfExported(getResolvedSymbol(node));
-            return getExplicitTypeOfSymbol(symbol, diagnostic);
-          case 110 /* ThisKeyword */:
-            return getExplicitThisType(node);
-          case 108 /* SuperKeyword */:
-            return checkSuperExpression(node);
-          case 210 /* PropertyAccessExpression */: {
-            const type = getTypeOfDottedName(node.expression, diagnostic);
-            if (type) {
-              const name = node.name;
-              let prop;
-              if (isPrivateIdentifier(name)) {
-                if (!type.symbol) {
-                  return void 0;
-                }
-                prop = getPropertyOfType(type, getSymbolNameForPrivateIdentifier(type.symbol, name.escapedText));
-              } else {
-                prop = getPropertyOfType(type, name.escapedText);
-              }
-              return prop && getExplicitTypeOfSymbol(prop, diagnostic);
-            }
-            return void 0;
-          }
-          case 216 /* ParenthesizedExpression */:
-            return getTypeOfDottedName(node.expression, diagnostic);
-        }
-      }
-    }
-    function getEffectsSignature(node) {
-      const links = getNodeLinks(node);
-      let signature = links.effectsSignature;
-      if (signature === void 0) {
-        let funcType;
-        if (node.parent.kind === 243 /* ExpressionStatement */) {
-          funcType = getTypeOfDottedName(
-            node.expression,
-            /*diagnostic*/
-            void 0
-          );
-        } else if (node.expression.kind !== 108 /* SuperKeyword */) {
-          if (isOptionalChain(node)) {
-            funcType = checkNonNullType(
-              getOptionalExpressionType(checkExpression(node.expression), node.expression),
-              node.expression
-            );
-          } else {
-            funcType = checkNonNullExpression(node.expression);
-          }
-        }
-        const signatures = getSignaturesOfType(funcType && getApparentType(funcType) || unknownType, 0 /* Call */);
-        const candidate = signatures.length === 1 && !signatures[0].typeParameters ? signatures[0] : some(signatures, hasTypePredicateOrNeverReturnType) ? getResolvedSignature(node) : void 0;
-        signature = links.effectsSignature = candidate && hasTypePredicateOrNeverReturnType(candidate) ? candidate : unknownSignature;
-      }
-      return signature === unknownSignature ? void 0 : signature;
-    }
-    function hasTypePredicateOrNeverReturnType(signature) {
-      return !!(getTypePredicateOfSignature(signature) || signature.declaration && (getReturnTypeFromAnnotation(signature.declaration) || unknownType).flags & 131072 /* Never */);
-    }
-    function getTypePredicateArgument(predicate, callExpression) {
-      if (predicate.kind === 1 /* Identifier */ || predicate.kind === 3 /* AssertsIdentifier */) {
-        return callExpression.arguments[predicate.parameterIndex];
-      }
-      const invokedExpression = skipParentheses(callExpression.expression);
-      return isAccessExpression(invokedExpression) ? skipParentheses(invokedExpression.expression) : void 0;
-    }
-    function reportFlowControlError(node) {
-      const block = findAncestor(node, isFunctionOrModuleBlock);
-      const sourceFile = getSourceFileOfNode(node);
-      const span = getSpanOfTokenAtPosition(sourceFile, block.statements.pos);
-      diagnostics.add(createFileDiagnostic(sourceFile, span.start, span.length, Diagnostics.The_containing_function_or_module_body_is_too_large_for_control_flow_analysis));
-    }
-    function isReachableFlowNode(flow) {
-      const result = isReachableFlowNodeWorker(
-        flow,
-        /*noCacheCheck*/
-        false
-      );
-      lastFlowNode = flow;
-      lastFlowNodeReachable = result;
-      return result;
-    }
-    function isFalseExpression(expr) {
-      const node = skipParentheses(
-        expr,
-        /*excludeJSDocTypeAssertions*/
-        true
-      );
-      return node.kind === 97 /* FalseKeyword */ || node.kind === 225 /* BinaryExpression */ && (node.operatorToken.kind === 56 /* AmpersandAmpersandToken */ && (isFalseExpression(node.left) || isFalseExpression(node.right)) || node.operatorToken.kind === 57 /* BarBarToken */ && isFalseExpression(node.left) && isFalseExpression(node.right));
-    }
-    function isReachableFlowNodeWorker(flow, noCacheCheck) {
-      while (true) {
-        if (flow === lastFlowNode) {
-          return lastFlowNodeReachable;
-        }
-        const flags = flow.flags;
-        if (flags & 4096 /* Shared */) {
-          if (!noCacheCheck) {
-            const id = getFlowNodeId(flow);
-            const reachable = flowNodeReachable[id];
-            return reachable !== void 0 ? reachable : flowNodeReachable[id] = isReachableFlowNodeWorker(
-              flow,
-              /*noCacheCheck*/
-              true
-            );
-          }
-          noCacheCheck = false;
-        }
-        if (flags & (16 /* Assignment */ | 96 /* Condition */ | 256 /* ArrayMutation */)) {
-          flow = flow.antecedent;
-        } else if (flags & 512 /* Call */) {
-          const signature = getEffectsSignature(flow.node);
-          if (signature) {
-            const predicate = getTypePredicateOfSignature(signature);
-            if (predicate && predicate.kind === 3 /* AssertsIdentifier */ && !predicate.type) {
-              const predicateArgument = flow.node.arguments[predicate.parameterIndex];
-              if (predicateArgument && isFalseExpression(predicateArgument)) {
-                return false;
-              }
-            }
-            if (getReturnTypeOfSignature(signature).flags & 131072 /* Never */) {
-              return false;
-            }
-          }
-          flow = flow.antecedent;
-        } else if (flags & 4 /* BranchLabel */) {
-          return some(flow.antecedents, (f) => isReachableFlowNodeWorker(
-            f,
-            /*noCacheCheck*/
-            false
-          ));
-        } else if (flags & 8 /* LoopLabel */) {
-          const antecedents = flow.antecedents;
-          if (antecedents === void 0 || antecedents.length === 0) {
-            return false;
-          }
-          flow = antecedents[0];
-        } else if (flags & 128 /* SwitchClause */) {
-          if (flow.clauseStart === flow.clauseEnd && isExhaustiveSwitchStatement(flow.switchStatement)) {
-            return false;
-          }
-          flow = flow.antecedent;
-        } else if (flags & 1024 /* ReduceLabel */) {
-          lastFlowNode = void 0;
-          const target = flow.target;
-          const saveAntecedents = target.antecedents;
-          target.antecedents = flow.antecedents;
-          const result = isReachableFlowNodeWorker(
-            flow.antecedent,
-            /*noCacheCheck*/
-            false
-          );
-          target.antecedents = saveAntecedents;
-          return result;
-        } else {
-          return !(flags & 1 /* Unreachable */);
-        }
-      }
-    }
-    function isPostSuperFlowNode(flow, noCacheCheck) {
-      while (true) {
-        const flags = flow.flags;
-        if (flags & 4096 /* Shared */) {
-          if (!noCacheCheck) {
-            const id = getFlowNodeId(flow);
-            const postSuper = flowNodePostSuper[id];
-            return postSuper !== void 0 ? postSuper : flowNodePostSuper[id] = isPostSuperFlowNode(
-              flow,
-              /*noCacheCheck*/
-              true
-            );
-          }
-          noCacheCheck = false;
-        }
-        if (flags & (16 /* Assignment */ | 96 /* Condition */ | 256 /* ArrayMutation */ | 128 /* SwitchClause */)) {
-          flow = flow.antecedent;
-        } else if (flags & 512 /* Call */) {
-          if (flow.node.expression.kind === 108 /* SuperKeyword */) {
-            return true;
-          }
-          flow = flow.antecedent;
-        } else if (flags & 4 /* BranchLabel */) {
-          return every(flow.antecedents, (f) => isPostSuperFlowNode(
-            f,
-            /*noCacheCheck*/
-            false
-          ));
-        } else if (flags & 8 /* LoopLabel */) {
-          flow = flow.antecedents[0];
-        } else if (flags & 1024 /* ReduceLabel */) {
-          const target = flow.target;
-          const saveAntecedents = target.antecedents;
-          target.antecedents = flow.antecedents;
-          const result = isPostSuperFlowNode(
-            flow.antecedent,
-            /*noCacheCheck*/
-            false
-          );
-          target.antecedents = saveAntecedents;
-          return result;
-        } else {
-          return !!(flags & 1 /* Unreachable */);
-        }
-      }
-    }
-    function isConstantReference(node) {
-      switch (node.kind) {
-        case 80 /* Identifier */:
-          if (!isThisInTypeQuery(node)) {
-            const symbol = getResolvedSymbol(node);
-            return isConstVariable(symbol) || isParameterOrCatchClauseVariable(symbol) && !isSymbolAssigned(symbol);
-          }
-          break;
-        case 210 /* PropertyAccessExpression */:
-        case 211 /* ElementAccessExpression */:
-          return isConstantReference(node.expression) && isReadonlySymbol(getNodeLinks(node).resolvedSymbol || unknownSymbol);
-      }
-      return false;
-    }
-    function getFlowTypeOfReference(reference, declaredType, initialType = declaredType, flowContainer, flowNode = ((_a) => (_a = tryCast(reference, canHaveFlowNode)) == null ? void 0 : _a.flowNode)()) {
-      let key;
-      let isKeySet = false;
-      let flowDepth = 0;
-      if (flowAnalysisDisabled) {
-        return errorType;
-      }
-      if (!flowNode) {
-        return declaredType;
-      }
-      flowInvocationCount++;
-      const sharedFlowStart = sharedFlowCount;
-      const evolvedType = getTypeFromFlowType(getTypeAtFlowNode(flowNode));
-      sharedFlowCount = sharedFlowStart;
-      const resultType = getObjectFlags(evolvedType) & 256 /* EvolvingArray */ && isEvolvingArrayOperationTarget(reference) ? autoArrayType : finalizeEvolvingArrayType(evolvedType);
-      if (resultType === unreachableNeverType || reference.parent && reference.parent.kind === 234 /* NonNullExpression */ && !(resultType.flags & 131072 /* Never */) && getTypeWithFacts(resultType, 2097152 /* NEUndefinedOrNull */).flags & 131072 /* Never */) {
-        return declaredType;
-      }
-      return resultType === nonNullUnknownType ? unknownType : resultType;
-      function getOrSetCacheKey() {
-        if (isKeySet) {
-          return key;
-        }
-        isKeySet = true;
-        return key = getFlowCacheKey(reference, declaredType, initialType, flowContainer);
-      }
-      function getTypeAtFlowNode(flow) {
-        var _a2;
-        if (flowDepth === 2e3) {
-          (_a2 = tracing) == null ? void 0 : _a2.instant(tracing.Phase.CheckTypes, "getTypeAtFlowNode_DepthLimit", { flowId: flow.id });
-          flowAnalysisDisabled = true;
-          reportFlowControlError(reference);
-          return errorType;
-        }
-        flowDepth++;
-        let sharedFlow;
-        while (true) {
-          const flags = flow.flags;
-          if (flags & 4096 /* Shared */) {
-            for (let i = sharedFlowStart; i < sharedFlowCount; i++) {
-              if (sharedFlowNodes[i] === flow) {
-                flowDepth--;
-                return sharedFlowTypes[i];
-              }
-            }
-            sharedFlow = flow;
-          }
-          let type;
-          if (flags & 16 /* Assignment */) {
-            type = getTypeAtFlowAssignment(flow);
-            if (!type) {
-              flow = flow.antecedent;
-              continue;
-            }
-          } else if (flags & 512 /* Call */) {
-            type = getTypeAtFlowCall(flow);
-            if (!type) {
-              flow = flow.antecedent;
-              continue;
-            }
-          } else if (flags & 96 /* Condition */) {
-            type = getTypeAtFlowCondition(flow);
-          } else if (flags & 128 /* SwitchClause */) {
-            type = getTypeAtSwitchClause(flow);
-          } else if (flags & 12 /* Label */) {
-            if (flow.antecedents.length === 1) {
-              flow = flow.antecedents[0];
-              continue;
-            }
-            type = flags & 4 /* BranchLabel */ ? getTypeAtFlowBranchLabel(flow) : getTypeAtFlowLoopLabel(flow);
-          } else if (flags & 256 /* ArrayMutation */) {
-            type = getTypeAtFlowArrayMutation(flow);
-            if (!type) {
-              flow = flow.antecedent;
-              continue;
-            }
-          } else if (flags & 1024 /* ReduceLabel */) {
-            const target = flow.target;
-            const saveAntecedents = target.antecedents;
-            target.antecedents = flow.antecedents;
-            type = getTypeAtFlowNode(flow.antecedent);
-            target.antecedents = saveAntecedents;
-          } else if (flags & 2 /* Start */) {
-            const container = flow.node;
-            if (container && container !== flowContainer && reference.kind !== 210 /* PropertyAccessExpression */ && reference.kind !== 211 /* ElementAccessExpression */ && reference.kind !== 110 /* ThisKeyword */) {
-              flow = container.flowNode;
-              continue;
-            }
-            type = initialType;
-          } else {
-            type = convertAutoToAny(declaredType);
-          }
-          if (sharedFlow) {
-            sharedFlowNodes[sharedFlowCount] = sharedFlow;
-            sharedFlowTypes[sharedFlowCount] = type;
-            sharedFlowCount++;
-          }
-          flowDepth--;
-          return type;
-        }
-      }
-      function getInitialOrAssignedType(flow) {
-        const node = flow.node;
-        return getNarrowableTypeForReference(node.kind === 259 /* VariableDeclaration */ || node.kind === 207 /* BindingElement */ ? getInitialType(node) : getAssignedType(node), reference);
-      }
-      function getTypeAtFlowAssignment(flow) {
-        const node = flow.node;
-        if (isMatchingReference(reference, node)) {
-          if (!isReachableFlowNode(flow)) {
-            return unreachableNeverType;
-          }
-          if (getAssignmentTargetKind(node) === 2 /* Compound */) {
-            const flowType = getTypeAtFlowNode(flow.antecedent);
-            return createFlowType(getBaseTypeOfLiteralType(getTypeFromFlowType(flowType)), isIncomplete(flowType));
-          }
-          if (declaredType === autoType || declaredType === autoArrayType) {
-            if (isEmptyArrayAssignment(node)) {
-              return getEvolvingArrayType(neverType);
-            }
-            const assignedType = getWidenedLiteralType(getInitialOrAssignedType(flow));
-            return isTypeAssignableTo(assignedType, declaredType) ? assignedType : anyArrayType;
-          }
-          if (declaredType.flags & 1048576 /* Union */) {
-            return getAssignmentReducedType(declaredType, getInitialOrAssignedType(flow));
-          }
-          return declaredType;
-        }
-        if (containsMatchingReference(reference, node)) {
-          if (!isReachableFlowNode(flow)) {
-            return unreachableNeverType;
-          }
-          if (isVariableDeclaration(node) && (isInJSFile(node) || isVarConst(node))) {
-            const init = getDeclaredExpandoInitializer(node);
-            if (init && (init.kind === 217 /* FunctionExpression */ || init.kind === 218 /* ArrowFunction */)) {
-              return getTypeAtFlowNode(flow.antecedent);
-            }
-          }
-          return declaredType;
-        }
-        if (isVariableDeclaration(node) && node.parent.parent.kind === 248 /* ForInStatement */ && (isMatchingReference(reference, node.parent.parent.expression) || optionalChainContainsReference(node.parent.parent.expression, reference))) {
-          return getNonNullableTypeIfNeeded(finalizeEvolvingArrayType(getTypeFromFlowType(getTypeAtFlowNode(flow.antecedent))));
-        }
-        return void 0;
-      }
-      function narrowTypeByAssertion(type, expr) {
-        const node = skipParentheses(
-          expr,
-          /*excludeJSDocTypeAssertions*/
-          true
-        );
-        if (node.kind === 97 /* FalseKeyword */) {
-          return unreachableNeverType;
-        }
-        if (node.kind === 225 /* BinaryExpression */) {
-          if (node.operatorToken.kind === 56 /* AmpersandAmpersandToken */) {
-            return narrowTypeByAssertion(narrowTypeByAssertion(type, node.left), node.right);
-          }
-          if (node.operatorToken.kind === 57 /* BarBarToken */) {
-            return getUnionType([narrowTypeByAssertion(type, node.left), narrowTypeByAssertion(type, node.right)]);
-          }
-        }
-        return narrowType(
-          type,
-          node,
-          /*assumeTrue*/
-          true
-        );
-      }
-      function getTypeAtFlowCall(flow) {
-        const signature = getEffectsSignature(flow.node);
-        if (signature) {
-          const predicate = getTypePredicateOfSignature(signature);
-          if (predicate && (predicate.kind === 2 /* AssertsThis */ || predicate.kind === 3 /* AssertsIdentifier */)) {
-            const flowType = getTypeAtFlowNode(flow.antecedent);
-            const type = finalizeEvolvingArrayType(getTypeFromFlowType(flowType));
-            const narrowedType = predicate.type ? narrowTypeByTypePredicate(
-              type,
-              predicate,
-              flow.node,
-              /*assumeTrue*/
-              true
-            ) : predicate.kind === 3 /* AssertsIdentifier */ && predicate.parameterIndex >= 0 && predicate.parameterIndex < flow.node.arguments.length ? narrowTypeByAssertion(type, flow.node.arguments[predicate.parameterIndex]) : type;
-            return narrowedType === type ? flowType : createFlowType(narrowedType, isIncomplete(flowType));
-          }
-          if (getReturnTypeOfSignature(signature).flags & 131072 /* Never */) {
-            return unreachableNeverType;
-          }
-        }
-        return void 0;
-      }
-      function getTypeAtFlowArrayMutation(flow) {
-        if (declaredType === autoType || declaredType === autoArrayType) {
-          const node = flow.node;
-          const expr = node.kind === 212 /* CallExpression */ ? node.expression.expression : node.left.expression;
-          if (isMatchingReference(reference, getReferenceCandidate(expr))) {
-            const flowType = getTypeAtFlowNode(flow.antecedent);
-            const type = getTypeFromFlowType(flowType);
-            if (getObjectFlags(type) & 256 /* EvolvingArray */) {
-              let evolvedType2 = type;
-              if (node.kind === 212 /* CallExpression */) {
-                for (const arg of node.arguments) {
-                  evolvedType2 = addEvolvingArrayElementType(evolvedType2, arg);
-                }
-              } else {
-                const indexType = getContextFreeTypeOfExpression(node.left.argumentExpression);
-                if (isTypeAssignableToKind(indexType, 296 /* NumberLike */)) {
-                  evolvedType2 = addEvolvingArrayElementType(evolvedType2, node.right);
-                }
-              }
-              return evolvedType2 === type ? flowType : createFlowType(evolvedType2, isIncomplete(flowType));
-            }
-            return flowType;
-          }
-        }
-        return void 0;
-      }
-      function getTypeAtFlowCondition(flow) {
-        const flowType = getTypeAtFlowNode(flow.antecedent);
-        const type = getTypeFromFlowType(flowType);
-        if (type.flags & 131072 /* Never */) {
-          return flowType;
-        }
-        const assumeTrue = (flow.flags & 32 /* TrueCondition */) !== 0;
-        const nonEvolvingType = finalizeEvolvingArrayType(type);
-        const narrowedType = narrowType(nonEvolvingType, flow.node, assumeTrue);
-        if (narrowedType === nonEvolvingType) {
-          return flowType;
-        }
-        return createFlowType(narrowedType, isIncomplete(flowType));
-      }
-      function getTypeAtSwitchClause(flow) {
-        const expr = flow.switchStatement.expression;
-        const flowType = getTypeAtFlowNode(flow.antecedent);
-        let type = getTypeFromFlowType(flowType);
-        if (isMatchingReference(reference, expr)) {
-          type = narrowTypeBySwitchOnDiscriminant(type, flow.switchStatement, flow.clauseStart, flow.clauseEnd);
-        } else if (expr.kind === 220 /* TypeOfExpression */ && isMatchingReference(reference, expr.expression)) {
-          type = narrowTypeBySwitchOnTypeOf(type, flow.switchStatement, flow.clauseStart, flow.clauseEnd);
-        } else {
-          if (strictNullChecks) {
-            if (optionalChainContainsReference(expr, reference)) {
-              type = narrowTypeBySwitchOptionalChainContainment(
-                type,
-                flow.switchStatement,
-                flow.clauseStart,
-                flow.clauseEnd,
-                (t) => !(t.flags & (32768 /* Undefined */ | 131072 /* Never */))
-              );
-            } else if (expr.kind === 220 /* TypeOfExpression */ && optionalChainContainsReference(expr.expression, reference)) {
-              type = narrowTypeBySwitchOptionalChainContainment(
-                type,
-                flow.switchStatement,
-                flow.clauseStart,
-                flow.clauseEnd,
-                (t) => !(t.flags & 131072 /* Never */ || t.flags & 128 /* StringLiteral */ && t.value === "undefined")
-              );
-            }
-          }
-          const access = getDiscriminantPropertyAccess(expr, type);
-          if (access) {
-            type = narrowTypeBySwitchOnDiscriminantProperty(type, access, flow.switchStatement, flow.clauseStart, flow.clauseEnd);
-          }
-        }
-        return createFlowType(type, isIncomplete(flowType));
-      }
-      function getTypeAtFlowBranchLabel(flow) {
-        const antecedentTypes = [];
-        let subtypeReduction = false;
-        let seenIncomplete = false;
-        let bypassFlow;
-        for (const antecedent of flow.antecedents) {
-          if (!bypassFlow && antecedent.flags & 128 /* SwitchClause */ && antecedent.clauseStart === antecedent.clauseEnd) {
-            bypassFlow = antecedent;
-            continue;
-          }
-          const flowType = getTypeAtFlowNode(antecedent);
-          const type = getTypeFromFlowType(flowType);
-          if (type === declaredType && declaredType === initialType) {
-            return type;
-          }
-          pushIfUnique(antecedentTypes, type);
-          if (!isTypeSubsetOf(type, initialType)) {
-            subtypeReduction = true;
-          }
-          if (isIncomplete(flowType)) {
-            seenIncomplete = true;
-          }
-        }
-        if (bypassFlow) {
-          const flowType = getTypeAtFlowNode(bypassFlow);
-          const type = getTypeFromFlowType(flowType);
-          if (!(type.flags & 131072 /* Never */) && !contains(antecedentTypes, type) && !isExhaustiveSwitchStatement(bypassFlow.switchStatement)) {
-            if (type === declaredType && declaredType === initialType) {
-              return type;
-            }
-            antecedentTypes.push(type);
-            if (!isTypeSubsetOf(type, initialType)) {
-              subtypeReduction = true;
-            }
-            if (isIncomplete(flowType)) {
-              seenIncomplete = true;
-            }
-          }
-        }
-        return createFlowType(getUnionOrEvolvingArrayType(antecedentTypes, subtypeReduction ? 2 /* Subtype */ : 1 /* Literal */), seenIncomplete);
-      }
-      function getTypeAtFlowLoopLabel(flow) {
-        const id = getFlowNodeId(flow);
-        const cache = flowLoopCaches[id] || (flowLoopCaches[id] = /* @__PURE__ */ new Map());
-        const key2 = getOrSetCacheKey();
-        if (!key2) {
-          return declaredType;
-        }
-        const cached = cache.get(key2);
-        if (cached) {
-          return cached;
-        }
-        for (let i = flowLoopStart; i < flowLoopCount; i++) {
-          if (flowLoopNodes[i] === flow && flowLoopKeys[i] === key2 && flowLoopTypes[i].length) {
-            return createFlowType(
-              getUnionOrEvolvingArrayType(flowLoopTypes[i], 1 /* Literal */),
-              /*incomplete*/
-              true
-            );
-          }
-        }
-        const antecedentTypes = [];
-        let subtypeReduction = false;
-        let firstAntecedentType;
-        for (const antecedent of flow.antecedents) {
-          let flowType;
-          if (!firstAntecedentType) {
-            flowType = firstAntecedentType = getTypeAtFlowNode(antecedent);
-          } else {
-            flowLoopNodes[flowLoopCount] = flow;
-            flowLoopKeys[flowLoopCount] = key2;
-            flowLoopTypes[flowLoopCount] = antecedentTypes;
-            flowLoopCount++;
-            const saveFlowTypeCache = flowTypeCache;
-            flowTypeCache = void 0;
-            flowType = getTypeAtFlowNode(antecedent);
-            flowTypeCache = saveFlowTypeCache;
-            flowLoopCount--;
-            const cached2 = cache.get(key2);
-            if (cached2) {
-              return cached2;
-            }
-          }
-          const type = getTypeFromFlowType(flowType);
-          pushIfUnique(antecedentTypes, type);
-          if (!isTypeSubsetOf(type, initialType)) {
-            subtypeReduction = true;
-          }
-          if (type === declaredType) {
-            break;
-          }
-        }
-        const result = getUnionOrEvolvingArrayType(antecedentTypes, subtypeReduction ? 2 /* Subtype */ : 1 /* Literal */);
-        if (isIncomplete(firstAntecedentType)) {
-          return createFlowType(
-            result,
-            /*incomplete*/
-            true
-          );
-        }
-        cache.set(key2, result);
-        return result;
-      }
-      function getUnionOrEvolvingArrayType(types, subtypeReduction) {
-        if (isEvolvingArrayTypeList(types)) {
-          return getEvolvingArrayType(getUnionType(map(types, getElementTypeOfEvolvingArrayType)));
-        }
-        const result = recombineUnknownType(getUnionType(sameMap(types, finalizeEvolvingArrayType), subtypeReduction));
-        if (result !== declaredType && result.flags & declaredType.flags & 1048576 /* Union */ && arraysEqual(result.types, declaredType.types)) {
-          return declaredType;
-        }
-        return result;
-      }
-      function getCandidateDiscriminantPropertyAccess(expr) {
-        if (isBindingPattern(reference) || isFunctionExpressionOrArrowFunction(reference) || isObjectLiteralMethod(reference)) {
-          if (isIdentifier(expr)) {
-            const symbol = getResolvedSymbol(expr);
-            const declaration = symbol.valueDeclaration;
-            if (declaration && (isBindingElement(declaration) || isParameter(declaration)) && reference === declaration.parent && !declaration.initializer && !declaration.dotDotDotToken) {
-              return declaration;
-            }
-          }
-        } else if (isAccessExpression(expr)) {
-          if (isMatchingReference(reference, expr.expression)) {
-            return expr;
-          }
-        } else if (isIdentifier(expr)) {
-          const symbol = getResolvedSymbol(expr);
-          if (isConstVariable(symbol)) {
-            const declaration = symbol.valueDeclaration;
-            if (isVariableDeclaration(declaration) && !declaration.type && declaration.initializer && isAccessExpression(declaration.initializer) && isMatchingReference(reference, declaration.initializer.expression)) {
-              return declaration.initializer;
-            }
-            if (isBindingElement(declaration) && !declaration.initializer) {
-              const parent2 = declaration.parent.parent;
-              if (isVariableDeclaration(parent2) && !parent2.type && parent2.initializer && (isIdentifier(parent2.initializer) || isAccessExpression(parent2.initializer)) && isMatchingReference(reference, parent2.initializer)) {
-                return declaration;
-              }
-            }
-          }
-        }
-        return void 0;
-      }
-      function getDiscriminantPropertyAccess(expr, computedType) {
-        const type = declaredType.flags & 1048576 /* Union */ ? declaredType : computedType;
-        if (type.flags & 1048576 /* Union */) {
-          const access = getCandidateDiscriminantPropertyAccess(expr);
-          if (access) {
-            const name = getAccessedPropertyName(access);
-            if (name && isDiscriminantProperty(type, name)) {
-              return access;
-            }
-          }
-        }
-        return void 0;
-      }
-      function narrowTypeByDiscriminant(type, access, narrowType2) {
-        const propName = getAccessedPropertyName(access);
-        if (propName === void 0) {
-          return type;
-        }
-        const optionalChain = isOptionalChain(access);
-        const removeNullable = strictNullChecks && (optionalChain || isNonNullAccess(access)) && maybeTypeOfKind(type, 98304 /* Nullable */);
-        let propType = getTypeOfPropertyOfType(removeNullable ? getTypeWithFacts(type, 2097152 /* NEUndefinedOrNull */) : type, propName);
-        if (!propType) {
-          return type;
-        }
-        propType = removeNullable && optionalChain ? getOptionalType(propType) : propType;
-        const narrowedPropType = narrowType2(propType);
-        return filterType(type, (t) => {
-          const discriminantType = getTypeOfPropertyOrIndexSignature(t, propName);
-          return !(discriminantType.flags & 131072 /* Never */) && !(narrowedPropType.flags & 131072 /* Never */) && areTypesComparable(narrowedPropType, discriminantType);
-        });
-      }
-      function narrowTypeByDiscriminantProperty(type, access, operator, value, assumeTrue) {
-        if ((operator === 37 /* EqualsEqualsEqualsToken */ || operator === 38 /* ExclamationEqualsEqualsToken */) && type.flags & 1048576 /* Union */) {
-          const keyPropertyName = getKeyPropertyName(type);
-          if (keyPropertyName && keyPropertyName === getAccessedPropertyName(access)) {
-            const candidate = getConstituentTypeForKeyType(type, getTypeOfExpression(value));
-            if (candidate) {
-              return operator === (assumeTrue ? 37 /* EqualsEqualsEqualsToken */ : 38 /* ExclamationEqualsEqualsToken */) ? candidate : isUnitType(getTypeOfPropertyOfType(candidate, keyPropertyName) || unknownType) ? removeType(type, candidate) : type;
-            }
-          }
-        }
-        return narrowTypeByDiscriminant(type, access, (t) => narrowTypeByEquality(t, operator, value, assumeTrue));
-      }
-      function narrowTypeBySwitchOnDiscriminantProperty(type, access, switchStatement, clauseStart, clauseEnd) {
-        if (clauseStart < clauseEnd && type.flags & 1048576 /* Union */ && getKeyPropertyName(type) === getAccessedPropertyName(access)) {
-          const clauseTypes = getSwitchClauseTypes(switchStatement).slice(clauseStart, clauseEnd);
-          const candidate = getUnionType(map(clauseTypes, (t) => getConstituentTypeForKeyType(type, t) || unknownType));
-          if (candidate !== unknownType) {
-            return candidate;
-          }
-        }
-        return narrowTypeByDiscriminant(type, access, (t) => narrowTypeBySwitchOnDiscriminant(t, switchStatement, clauseStart, clauseEnd));
-      }
-      function narrowTypeByTruthiness(type, expr, assumeTrue) {
-        if (isMatchingReference(reference, expr)) {
-          return getAdjustedTypeWithFacts(type, assumeTrue ? 4194304 /* Truthy */ : 8388608 /* Falsy */);
-        }
-        if (strictNullChecks && assumeTrue && optionalChainContainsReference(expr, reference)) {
-          type = getAdjustedTypeWithFacts(type, 2097152 /* NEUndefinedOrNull */);
-        }
-        const access = getDiscriminantPropertyAccess(expr, type);
-        if (access) {
-          return narrowTypeByDiscriminant(type, access, (t) => getTypeWithFacts(t, assumeTrue ? 4194304 /* Truthy */ : 8388608 /* Falsy */));
-        }
-        return type;
-      }
-      function isTypePresencePossible(type, propName, assumeTrue) {
-        const prop = getPropertyOfType(type, propName);
-        return prop ? !!(prop.flags & 16777216 /* Optional */ || getCheckFlags(prop) & 48 /* Partial */) || assumeTrue : !!getApplicableIndexInfoForName(type, propName) || !assumeTrue;
-      }
-      function narrowTypeByInKeyword(type, nameType, assumeTrue) {
-        const name = getPropertyNameFromType(nameType);
-        const isKnownProperty2 = someType(type, (t) => isTypePresencePossible(
-          t,
-          name,
-          /*assumeTrue*/
-          true
-        ));
-        if (isKnownProperty2) {
-          return filterType(type, (t) => isTypePresencePossible(t, name, assumeTrue));
-        }
-        if (assumeTrue) {
-          const recordSymbol = getGlobalRecordSymbol();
-          if (recordSymbol) {
-            return getIntersectionType([type, getTypeAliasInstantiation(recordSymbol, [nameType, unknownType])]);
-          }
-        }
-        return type;
-      }
-      function narrowTypeByBinaryExpression(type, expr, assumeTrue) {
-        switch (expr.operatorToken.kind) {
-          case 64 /* EqualsToken */:
-          case 76 /* BarBarEqualsToken */:
-          case 77 /* AmpersandAmpersandEqualsToken */:
-          case 78 /* QuestionQuestionEqualsToken */:
-            return narrowTypeByTruthiness(narrowType(type, expr.right, assumeTrue), expr.left, assumeTrue);
-          case 35 /* EqualsEqualsToken */:
-          case 36 /* ExclamationEqualsToken */:
-          case 37 /* EqualsEqualsEqualsToken */:
-          case 38 /* ExclamationEqualsEqualsToken */:
-            const operator = expr.operatorToken.kind;
-            const left = getReferenceCandidate(expr.left);
-            const right = getReferenceCandidate(expr.right);
-            if (left.kind === 220 /* TypeOfExpression */ && isStringLiteralLike(right)) {
-              return narrowTypeByTypeof(type, left, operator, right, assumeTrue);
-            }
-            if (right.kind === 220 /* TypeOfExpression */ && isStringLiteralLike(left)) {
-              return narrowTypeByTypeof(type, right, operator, left, assumeTrue);
-            }
-            if (isMatchingReference(reference, left)) {
-              return narrowTypeByEquality(type, operator, right, assumeTrue);
-            }
-            if (isMatchingReference(reference, right)) {
-              return narrowTypeByEquality(type, operator, left, assumeTrue);
-            }
-            if (strictNullChecks) {
-              if (optionalChainContainsReference(left, reference)) {
-                type = narrowTypeByOptionalChainContainment(type, operator, right, assumeTrue);
-              } else if (optionalChainContainsReference(right, reference)) {
-                type = narrowTypeByOptionalChainContainment(type, operator, left, assumeTrue);
-              }
-            }
-            const leftAccess = getDiscriminantPropertyAccess(left, type);
-            if (leftAccess) {
-              return narrowTypeByDiscriminantProperty(type, leftAccess, operator, right, assumeTrue);
-            }
-            const rightAccess = getDiscriminantPropertyAccess(right, type);
-            if (rightAccess) {
-              return narrowTypeByDiscriminantProperty(type, rightAccess, operator, left, assumeTrue);
-            }
-            if (isMatchingConstructorReference(left)) {
-              return narrowTypeByConstructor(type, operator, right, assumeTrue);
-            }
-            if (isMatchingConstructorReference(right)) {
-              return narrowTypeByConstructor(type, operator, left, assumeTrue);
-            }
-            break;
-          case 104 /* InstanceOfKeyword */:
-            return narrowTypeByInstanceof(type, expr, assumeTrue);
-          case 103 /* InKeyword */:
-            if (isPrivateIdentifier(expr.left)) {
-              return narrowTypeByPrivateIdentifierInInExpression(type, expr, assumeTrue);
-            }
-            const target = getReferenceCandidate(expr.right);
-            const leftType = getTypeOfExpression(expr.left);
-            if (leftType.flags & 8576 /* StringOrNumberLiteralOrUnique */) {
-              if (containsMissingType(type) && isAccessExpression(reference) && isMatchingReference(reference.expression, target) && getAccessedPropertyName(reference) === getPropertyNameFromType(leftType)) {
-                return getTypeWithFacts(type, assumeTrue ? 524288 /* NEUndefined */ : 65536 /* EQUndefined */);
-              }
-              if (isMatchingReference(reference, target)) {
-                return narrowTypeByInKeyword(type, leftType, assumeTrue);
-              }
-            }
-            break;
-          case 28 /* CommaToken */:
-            return narrowType(type, expr.right, assumeTrue);
-          case 56 /* AmpersandAmpersandToken */:
-            return assumeTrue ? narrowType(
-              narrowType(
-                type,
-                expr.left,
-                /*assumeTrue*/
-                true
-              ),
-              expr.right,
-              /*assumeTrue*/
-              true
-            ) : getUnionType([narrowType(
-              type,
-              expr.left,
-              /*assumeTrue*/
-              false
-            ), narrowType(
-              type,
-              expr.right,
-              /*assumeTrue*/
-              false
-            )]);
-          case 57 /* BarBarToken */:
-            return assumeTrue ? getUnionType([narrowType(
-              type,
-              expr.left,
-              /*assumeTrue*/
-              true
-            ), narrowType(
-              type,
-              expr.right,
-              /*assumeTrue*/
-              true
-            )]) : narrowType(
-              narrowType(
-                type,
-                expr.left,
-                /*assumeTrue*/
-                false
-              ),
-              expr.right,
-              /*assumeTrue*/
-              false
-            );
-        }
-        return type;
-      }
-      function narrowTypeByPrivateIdentifierInInExpression(type, expr, assumeTrue) {
-        const target = getReferenceCandidate(expr.right);
-        if (!isMatchingReference(reference, target)) {
-          return type;
-        }
-        Debug.assertNode(expr.left, isPrivateIdentifier);
-        const symbol = getSymbolForPrivateIdentifierExpression(expr.left);
-        if (symbol === void 0) {
-          return type;
-        }
-        const classSymbol = symbol.parent;
-        const targetType = hasStaticModifier(Debug.checkDefined(symbol.valueDeclaration, "should always have a declaration")) ? getTypeOfSymbol(classSymbol) : getDeclaredTypeOfSymbol(classSymbol);
-        return getNarrowedType(
-          type,
-          targetType,
-          assumeTrue,
-          /*checkDerived*/
-          true
-        );
-      }
-      function narrowTypeByOptionalChainContainment(type, operator, value, assumeTrue) {
-        const equalsOperator = operator === 35 /* EqualsEqualsToken */ || operator === 37 /* EqualsEqualsEqualsToken */;
-        const nullableFlags = operator === 35 /* EqualsEqualsToken */ || operator === 36 /* ExclamationEqualsToken */ ? 98304 /* Nullable */ : 32768 /* Undefined */;
-        const valueType = getTypeOfExpression(value);
-        const removeNullable = equalsOperator !== assumeTrue && everyType(valueType, (t) => !!(t.flags & nullableFlags)) || equalsOperator === assumeTrue && everyType(valueType, (t) => !(t.flags & (3 /* AnyOrUnknown */ | nullableFlags)));
-        return removeNullable ? getAdjustedTypeWithFacts(type, 2097152 /* NEUndefinedOrNull */) : type;
-      }
-      function narrowTypeByEquality(type, operator, value, assumeTrue) {
-        if (type.flags & 1 /* Any */) {
-          return type;
-        }
-        if (operator === 36 /* ExclamationEqualsToken */ || operator === 38 /* ExclamationEqualsEqualsToken */) {
-          assumeTrue = !assumeTrue;
-        }
-        const valueType = getTypeOfExpression(value);
-        const doubleEquals = operator === 35 /* EqualsEqualsToken */ || operator === 36 /* ExclamationEqualsToken */;
-        if (valueType.flags & 98304 /* Nullable */) {
-          if (!strictNullChecks) {
-            return type;
-          }
-          const facts = doubleEquals ? assumeTrue ? 262144 /* EQUndefinedOrNull */ : 2097152 /* NEUndefinedOrNull */ : valueType.flags & 65536 /* Null */ ? assumeTrue ? 131072 /* EQNull */ : 1048576 /* NENull */ : assumeTrue ? 65536 /* EQUndefined */ : 524288 /* NEUndefined */;
-          return getAdjustedTypeWithFacts(type, facts);
-        }
-        if (assumeTrue) {
-          if (!doubleEquals && (type.flags & 2 /* Unknown */ || someType(type, isEmptyAnonymousObjectType))) {
-            if (valueType.flags & (402784252 /* Primitive */ | 67108864 /* NonPrimitive */) || isEmptyAnonymousObjectType(valueType)) {
-              return valueType;
-            }
-            if (valueType.flags & 524288 /* Object */) {
-              return nonPrimitiveType;
-            }
-          }
-          const filteredType = filterType(type, (t) => areTypesComparable(t, valueType) || doubleEquals && isCoercibleUnderDoubleEquals(t, valueType));
-          return replacePrimitivesWithLiterals(filteredType, valueType);
-        }
-        if (isUnitType(valueType)) {
-          return filterType(type, (t) => !(isUnitLikeType(t) && areTypesComparable(t, valueType)));
-        }
-        return type;
-      }
-      function narrowTypeByTypeof(type, typeOfExpr, operator, literal, assumeTrue) {
-        if (operator === 36 /* ExclamationEqualsToken */ || operator === 38 /* ExclamationEqualsEqualsToken */) {
-          assumeTrue = !assumeTrue;
-        }
-        const target = getReferenceCandidate(typeOfExpr.expression);
-        if (!isMatchingReference(reference, target)) {
-          if (strictNullChecks && optionalChainContainsReference(target, reference) && assumeTrue === (literal.text !== "undefined")) {
-            type = getAdjustedTypeWithFacts(type, 2097152 /* NEUndefinedOrNull */);
-          }
-          const propertyAccess = getDiscriminantPropertyAccess(target, type);
-          if (propertyAccess) {
-            return narrowTypeByDiscriminant(type, propertyAccess, (t) => narrowTypeByLiteralExpression(t, literal, assumeTrue));
-          }
-          return type;
-        }
-        return narrowTypeByLiteralExpression(type, literal, assumeTrue);
-      }
-      function narrowTypeByLiteralExpression(type, literal, assumeTrue) {
-        return assumeTrue ? narrowTypeByTypeName(type, literal.text) : getAdjustedTypeWithFacts(type, typeofNEFacts.get(literal.text) || 32768 /* TypeofNEHostObject */);
-      }
-      function narrowTypeBySwitchOptionalChainContainment(type, switchStatement, clauseStart, clauseEnd, clauseCheck) {
-        const everyClauseChecks = clauseStart !== clauseEnd && every(getSwitchClauseTypes(switchStatement).slice(clauseStart, clauseEnd), clauseCheck);
-        return everyClauseChecks ? getTypeWithFacts(type, 2097152 /* NEUndefinedOrNull */) : type;
-      }
-      function narrowTypeBySwitchOnDiscriminant(type, switchStatement, clauseStart, clauseEnd) {
-        const switchTypes = getSwitchClauseTypes(switchStatement);
-        if (!switchTypes.length) {
-          return type;
-        }
-        const clauseTypes = switchTypes.slice(clauseStart, clauseEnd);
-        const hasDefaultClause = clauseStart === clauseEnd || contains(clauseTypes, neverType);
-        if (type.flags & 2 /* Unknown */ && !hasDefaultClause) {
-          let groundClauseTypes;
-          for (let i = 0; i < clauseTypes.length; i += 1) {
-            const t = clauseTypes[i];
-            if (t.flags & (402784252 /* Primitive */ | 67108864 /* NonPrimitive */)) {
-              if (groundClauseTypes !== void 0) {
-                groundClauseTypes.push(t);
-              }
-            } else if (t.flags & 524288 /* Object */) {
-              if (groundClauseTypes === void 0) {
-                groundClauseTypes = clauseTypes.slice(0, i);
-              }
-              groundClauseTypes.push(nonPrimitiveType);
-            } else {
-              return type;
-            }
-          }
-          return getUnionType(groundClauseTypes === void 0 ? clauseTypes : groundClauseTypes);
-        }
-        const discriminantType = getUnionType(clauseTypes);
-        const caseType = discriminantType.flags & 131072 /* Never */ ? neverType : replacePrimitivesWithLiterals(filterType(type, (t) => areTypesComparable(discriminantType, t)), discriminantType);
-        if (!hasDefaultClause) {
-          return caseType;
-        }
-        const defaultType = filterType(type, (t) => !(isUnitLikeType(t) && contains(switchTypes, getRegularTypeOfLiteralType(extractUnitType(t)))));
-        return caseType.flags & 131072 /* Never */ ? defaultType : getUnionType([caseType, defaultType]);
-      }
-      function narrowTypeByTypeName(type, typeName) {
-        switch (typeName) {
-          case "string":
-            return narrowTypeByTypeFacts(type, stringType, 1 /* TypeofEQString */);
-          case "number":
-            return narrowTypeByTypeFacts(type, numberType, 2 /* TypeofEQNumber */);
-          case "bigint":
-            return narrowTypeByTypeFacts(type, bigintType, 4 /* TypeofEQBigInt */);
-          case "boolean":
-            return narrowTypeByTypeFacts(type, booleanType, 8 /* TypeofEQBoolean */);
-          case "symbol":
-            return narrowTypeByTypeFacts(type, esSymbolType, 16 /* TypeofEQSymbol */);
-          case "object":
-            return type.flags & 1 /* Any */ ? type : getUnionType([narrowTypeByTypeFacts(type, nonPrimitiveType, 32 /* TypeofEQObject */), narrowTypeByTypeFacts(type, nullType, 131072 /* EQNull */)]);
-          case "function":
-            return type.flags & 1 /* Any */ ? type : narrowTypeByTypeFacts(type, globalFunctionType, 64 /* TypeofEQFunction */);
-          case "undefined":
-            return narrowTypeByTypeFacts(type, undefinedType, 65536 /* EQUndefined */);
-        }
-        return narrowTypeByTypeFacts(type, nonPrimitiveType, 128 /* TypeofEQHostObject */);
-      }
-      function narrowTypeByTypeFacts(type, impliedType, facts) {
-        return mapType(type, (t) => (
-          // We first check if a constituent is a subtype of the implied type. If so, we either keep or eliminate
-          // the constituent based on its type facts. We use the strict subtype relation because it treats `object`
-          // as a subtype of `{}`, and we need the type facts check because function types are subtypes of `object`,
-          // but are classified as "function" according to `typeof`.
-          isTypeRelatedTo(t, impliedType, strictSubtypeRelation) ? getTypeFacts(t) & facts ? t : neverType : (
-            // We next check if the consituent is a supertype of the implied type. If so, we substitute the implied
-            // type. This handles top types like `unknown` and `{}`, and supertypes like `{ toString(): string }`.
-            isTypeSubtypeOf(impliedType, t) ? impliedType : (
-              // Neither the constituent nor the implied type is a subtype of the other, however their domains may still
-              // overlap. For example, an unconstrained type parameter and type `string`. If the type facts indicate
-              // possible overlap, we form an intersection. Otherwise, we eliminate the constituent.
-              getTypeFacts(t) & facts ? getIntersectionType([t, impliedType]) : neverType
-            )
-          )
-        ));
-      }
-      function narrowTypeBySwitchOnTypeOf(type, switchStatement, clauseStart, clauseEnd) {
-        const witnesses = getSwitchClauseTypeOfWitnesses(switchStatement);
-        if (!witnesses) {
-          return type;
-        }
-        const defaultIndex = findIndex(switchStatement.caseBlock.clauses, (clause) => clause.kind === 296 /* DefaultClause */);
-        const hasDefaultClause = clauseStart === clauseEnd || defaultIndex >= clauseStart && defaultIndex < clauseEnd;
-        if (hasDefaultClause) {
-          const notEqualFacts = getNotEqualFactsFromTypeofSwitch(clauseStart, clauseEnd, witnesses);
-          return filterType(type, (t) => (getTypeFacts(t) & notEqualFacts) === notEqualFacts);
-        }
-        const clauseWitnesses = witnesses.slice(clauseStart, clauseEnd);
-        return getUnionType(map(clauseWitnesses, (text) => text ? narrowTypeByTypeName(type, text) : neverType));
-      }
-      function isMatchingConstructorReference(expr) {
-        return (isPropertyAccessExpression(expr) && idText(expr.name) === "constructor" || isElementAccessExpression(expr) && isStringLiteralLike(expr.argumentExpression) && expr.argumentExpression.text === "constructor") && isMatchingReference(reference, expr.expression);
-      }
-      function narrowTypeByConstructor(type, operator, identifier, assumeTrue) {
-        if (assumeTrue ? operator !== 35 /* EqualsEqualsToken */ && operator !== 37 /* EqualsEqualsEqualsToken */ : operator !== 36 /* ExclamationEqualsToken */ && operator !== 38 /* ExclamationEqualsEqualsToken */) {
-          return type;
-        }
-        const identifierType = getTypeOfExpression(identifier);
-        if (!isFunctionType(identifierType) && !isConstructorType(identifierType)) {
-          return type;
-        }
-        const prototypeProperty = getPropertyOfType(identifierType, "prototype");
-        if (!prototypeProperty) {
-          return type;
-        }
-        const prototypeType = getTypeOfSymbol(prototypeProperty);
-        const candidate = !isTypeAny(prototypeType) ? prototypeType : void 0;
-        if (!candidate || candidate === globalObjectType || candidate === globalFunctionType) {
-          return type;
-        }
-        if (isTypeAny(type)) {
-          return candidate;
-        }
-        return filterType(type, (t) => isConstructedBy(t, candidate));
-        function isConstructedBy(source, target) {
-          if (source.flags & 524288 /* Object */ && getObjectFlags(source) & 1 /* Class */ || target.flags & 524288 /* Object */ && getObjectFlags(target) & 1 /* Class */) {
-            return source.symbol === target.symbol;
-          }
-          return isTypeSubtypeOf(source, target);
-        }
-      }
-      function narrowTypeByInstanceof(type, expr, assumeTrue) {
-        const left = getReferenceCandidate(expr.left);
-        if (!isMatchingReference(reference, left)) {
-          if (assumeTrue && strictNullChecks && optionalChainContainsReference(left, reference)) {
-            return getAdjustedTypeWithFacts(type, 2097152 /* NEUndefinedOrNull */);
-          }
-          return type;
-        }
-        const rightType = getTypeOfExpression(expr.right);
-        if (!isTypeDerivedFrom(rightType, globalFunctionType)) {
-          return type;
-        }
-        const instanceType = mapType(rightType, getInstanceType);
-        if (isTypeAny(type) && (instanceType === globalObjectType || instanceType === globalFunctionType) || !assumeTrue && !(instanceType.flags & 524288 /* Object */ && !isEmptyAnonymousObjectType(instanceType))) {
-          return type;
-        }
-        return getNarrowedType(
-          type,
-          instanceType,
-          assumeTrue,
-          /*checkDerived*/
-          true
-        );
-      }
-      function getInstanceType(constructorType) {
-        const prototypePropertyType = getTypeOfPropertyOfType(constructorType, "prototype");
-        if (prototypePropertyType && !isTypeAny(prototypePropertyType)) {
-          return prototypePropertyType;
-        }
-        const constructSignatures = getSignaturesOfType(constructorType, 1 /* Construct */);
-        if (constructSignatures.length) {
-          return getUnionType(map(constructSignatures, (signature) => getReturnTypeOfSignature(getErasedSignature(signature))));
-        }
-        return emptyObjectType;
-      }
-      function getNarrowedType(type, candidate, assumeTrue, checkDerived) {
-        const key2 = type.flags & 1048576 /* Union */ ? `N${getTypeId(type)},${getTypeId(candidate)},${(assumeTrue ? 1 : 0) | (checkDerived ? 2 : 0)}` : void 0;
-        return getCachedType(key2) ?? setCachedType(key2, getNarrowedTypeWorker(type, candidate, assumeTrue, checkDerived));
-      }
-      function getNarrowedTypeWorker(type, candidate, assumeTrue, checkDerived) {
-        if (!assumeTrue) {
-          if (checkDerived) {
-            return filterType(type, (t) => !isTypeDerivedFrom(t, candidate));
-          }
-          const trueType2 = getNarrowedType(
-            type,
-            candidate,
-            /*assumeTrue*/
-            true,
-            /*checkDerived*/
-            false
-          );
-          return filterType(type, (t) => !isTypeSubsetOf(t, trueType2));
-        }
-        if (type.flags & 3 /* AnyOrUnknown */) {
-          return candidate;
-        }
-        const isRelated = checkDerived ? isTypeDerivedFrom : isTypeSubtypeOf;
-        const keyPropertyName = type.flags & 1048576 /* Union */ ? getKeyPropertyName(type) : void 0;
-        const narrowedType = mapType(candidate, (c) => {
-          const discriminant = keyPropertyName && getTypeOfPropertyOfType(c, keyPropertyName);
-          const matching = discriminant && getConstituentTypeForKeyType(type, discriminant);
-          const directlyRelated = mapType(matching || type, checkDerived ? (t) => isTypeDerivedFrom(t, c) ? t : isTypeDerivedFrom(c, t) ? c : neverType : (t) => isTypeStrictSubtypeOf(t, c) ? t : isTypeStrictSubtypeOf(c, t) ? c : isTypeSubtypeOf(t, c) ? t : isTypeSubtypeOf(c, t) ? c : neverType);
-          return directlyRelated.flags & 131072 /* Never */ ? mapType(type, (t) => maybeTypeOfKind(t, 465829888 /* Instantiable */) && isRelated(c, getBaseConstraintOfType(t) || unknownType) ? getIntersectionType([t, c]) : neverType) : directlyRelated;
-        });
-        return !(narrowedType.flags & 131072 /* Never */) ? narrowedType : isTypeSubtypeOf(candidate, type) ? candidate : isTypeAssignableTo(type, candidate) ? type : isTypeAssignableTo(candidate, type) ? candidate : getIntersectionType([type, candidate]);
-      }
-      function narrowTypeByCallExpression(type, callExpression, assumeTrue) {
-        if (hasMatchingArgument(callExpression, reference)) {
-          const signature = assumeTrue || !isCallChain(callExpression) ? getEffectsSignature(callExpression) : void 0;
-          const predicate = signature && getTypePredicateOfSignature(signature);
-          if (predicate && (predicate.kind === 0 /* This */ || predicate.kind === 1 /* Identifier */)) {
-            return narrowTypeByTypePredicate(type, predicate, callExpression, assumeTrue);
-          }
-        }
-        if (containsMissingType(type) && isAccessExpression(reference) && isPropertyAccessExpression(callExpression.expression)) {
-          const callAccess = callExpression.expression;
-          if (isMatchingReference(reference.expression, getReferenceCandidate(callAccess.expression)) && isIdentifier(callAccess.name) && callAccess.name.escapedText === "hasOwnProperty" && callExpression.arguments.length === 1) {
-            const argument = callExpression.arguments[0];
-            if (isStringLiteralLike(argument) && getAccessedPropertyName(reference) === escapeLeadingUnderscores(argument.text)) {
-              return getTypeWithFacts(type, assumeTrue ? 524288 /* NEUndefined */ : 65536 /* EQUndefined */);
-            }
-          }
-        }
-        return type;
-      }
-      function narrowTypeByTypePredicate(type, predicate, callExpression, assumeTrue) {
-        if (predicate.type && !(isTypeAny(type) && (predicate.type === globalObjectType || predicate.type === globalFunctionType))) {
-          const predicateArgument = getTypePredicateArgument(predicate, callExpression);
-          if (predicateArgument) {
-            if (isMatchingReference(reference, predicateArgument)) {
-              return getNarrowedType(
-                type,
-                predicate.type,
-                assumeTrue,
-                /*checkDerived*/
-                false
-              );
-            }
-            if (strictNullChecks && assumeTrue && optionalChainContainsReference(predicateArgument, reference) && !(getTypeFacts(predicate.type) & 65536 /* EQUndefined */)) {
-              type = getAdjustedTypeWithFacts(type, 2097152 /* NEUndefinedOrNull */);
-            }
-            const access = getDiscriminantPropertyAccess(predicateArgument, type);
-            if (access) {
-              return narrowTypeByDiscriminant(type, access, (t) => getNarrowedType(
-                t,
-                predicate.type,
-                assumeTrue,
-                /*checkDerived*/
-                false
-              ));
-            }
-          }
-        }
-        return type;
-      }
-      function narrowType(type, expr, assumeTrue) {
-        if (isExpressionOfOptionalChainRoot(expr) || isBinaryExpression(expr.parent) && (expr.parent.operatorToken.kind === 61 /* QuestionQuestionToken */ || expr.parent.operatorToken.kind === 78 /* QuestionQuestionEqualsToken */) && expr.parent.left === expr) {
-          return narrowTypeByOptionality(type, expr, assumeTrue);
-        }
-        switch (expr.kind) {
-          case 80 /* Identifier */:
-            if (!isMatchingReference(reference, expr) && inlineLevel < 5) {
-              const symbol = getResolvedSymbol(expr);
-              if (isConstVariable(symbol)) {
-                const declaration = symbol.valueDeclaration;
-                if (declaration && isVariableDeclaration(declaration) && !declaration.type && declaration.initializer && isConstantReference(reference)) {
-                  inlineLevel++;
-                  const result = narrowType(type, declaration.initializer, assumeTrue);
-                  inlineLevel--;
-                  return result;
-                }
-              }
-            }
-          case 110 /* ThisKeyword */:
-          case 108 /* SuperKeyword */:
-          case 210 /* PropertyAccessExpression */:
-          case 211 /* ElementAccessExpression */:
-            return narrowTypeByTruthiness(type, expr, assumeTrue);
-          case 212 /* CallExpression */:
-            return narrowTypeByCallExpression(type, expr, assumeTrue);
-          case 216 /* ParenthesizedExpression */:
-          case 234 /* NonNullExpression */:
-            return narrowType(type, expr.expression, assumeTrue);
-          case 225 /* BinaryExpression */:
-            return narrowTypeByBinaryExpression(type, expr, assumeTrue);
-          case 223 /* PrefixUnaryExpression */:
-            if (expr.operator === 54 /* ExclamationToken */) {
-              return narrowType(type, expr.operand, !assumeTrue);
-            }
-            break;
-        }
-        return type;
-      }
-      function narrowTypeByOptionality(type, expr, assumePresent) {
-        if (isMatchingReference(reference, expr)) {
-          return getAdjustedTypeWithFacts(type, assumePresent ? 2097152 /* NEUndefinedOrNull */ : 262144 /* EQUndefinedOrNull */);
-        }
-        const access = getDiscriminantPropertyAccess(expr, type);
-        if (access) {
-          return narrowTypeByDiscriminant(type, access, (t) => getTypeWithFacts(t, assumePresent ? 2097152 /* NEUndefinedOrNull */ : 262144 /* EQUndefinedOrNull */));
-        }
-        return type;
-      }
-    }
-    function getTypeOfSymbolAtLocation(symbol, location) {
-      symbol = getExportSymbolOfValueSymbolIfExported(symbol);
-      if (location.kind === 80 /* Identifier */ || location.kind === 81 /* PrivateIdentifier */) {
-        if (isRightSideOfQualifiedNameOrPropertyAccess(location)) {
-          location = location.parent;
-        }
-        if (isExpressionNode(location) && (!isAssignmentTarget(location) || isWriteAccess(location))) {
-          const type = getTypeOfExpression(location);
-          if (getExportSymbolOfValueSymbolIfExported(getNodeLinks(location).resolvedSymbol) === symbol) {
-            return type;
-          }
-        }
-      }
-      if (isDeclarationName(location) && isSetAccessor(location.parent) && getAnnotatedAccessorTypeNode(location.parent)) {
-        return getWriteTypeOfAccessors(location.parent.symbol);
-      }
-      return getNonMissingTypeOfSymbol(symbol);
-    }
-    function getControlFlowContainer(node) {
-      return findAncestor(node.parent, (node2) => isFunctionLike(node2) && !getImmediatelyInvokedFunctionExpression(node2) || node2.kind === 267 /* ModuleBlock */ || node2.kind === 311 /* SourceFile */ || node2.kind === 171 /* PropertyDeclaration */);
-    }
-    function isSymbolAssigned(symbol) {
-      if (!symbol.valueDeclaration) {
-        return false;
-      }
-      const parent2 = getRootDeclaration(symbol.valueDeclaration).parent;
-      const links = getNodeLinks(parent2);
-      if (!(links.flags & 524288 /* AssignmentsMarked */)) {
-        links.flags |= 524288 /* AssignmentsMarked */;
-        if (!hasParentWithAssignmentsMarked(parent2)) {
-          markNodeAssignments(parent2);
-        }
-      }
-      return symbol.isAssigned || false;
-    }
-    function hasParentWithAssignmentsMarked(node) {
-      return !!findAncestor(node.parent, (node2) => (isFunctionLike(node2) || isCatchClause(node2)) && !!(getNodeLinks(node2).flags & 524288 /* AssignmentsMarked */));
-    }
-    function markNodeAssignments(node) {
-      if (node.kind === 80 /* Identifier */) {
-        if (isAssignmentTarget(node)) {
-          const symbol = getResolvedSymbol(node);
-          if (isParameterOrCatchClauseVariable(symbol)) {
-            symbol.isAssigned = true;
-          }
-        }
-      } else {
-        forEachChild(node, markNodeAssignments);
-      }
-    }
-    function isConstVariable(symbol) {
-      return symbol.flags & 3 /* Variable */ && (getDeclarationNodeFlagsFromSymbol(symbol) & 2 /* Const */) !== 0;
-    }
-    function parameterInitializerContainsUndefined(declaration) {
-      const links = getNodeLinks(declaration);
-      if (links.parameterInitializerContainsUndefined === void 0) {
-        if (!pushTypeResolution(declaration, 9 /* ParameterInitializerContainsUndefined */)) {
-          reportCircularityError(declaration.symbol);
-          return true;
-        }
-        const containsUndefined = !!(getTypeFacts(checkDeclarationInitializer(declaration, 0 /* Normal */)) & 16777216 /* IsUndefined */);
-        if (!popTypeResolution()) {
-          reportCircularityError(declaration.symbol);
-          return true;
-        }
-        links.parameterInitializerContainsUndefined = containsUndefined;
-      }
-      return links.parameterInitializerContainsUndefined;
-    }
-    function removeOptionalityFromDeclaredType(declaredType, declaration) {
-      const removeUndefined = strictNullChecks && declaration.kind === 168 /* Parameter */ && declaration.initializer && getTypeFacts(declaredType) & 16777216 /* IsUndefined */ && !parameterInitializerContainsUndefined(declaration);
-      return removeUndefined ? getTypeWithFacts(declaredType, 524288 /* NEUndefined */) : declaredType;
-    }
-    function isConstraintPosition(type, node) {
-      const parent2 = node.parent;
-      return parent2.kind === 210 /* PropertyAccessExpression */ || parent2.kind === 165 /* QualifiedName */ || parent2.kind === 212 /* CallExpression */ && parent2.expression === node || parent2.kind === 211 /* ElementAccessExpression */ && parent2.expression === node && !(someType(type, isGenericTypeWithoutNullableConstraint) && isGenericIndexType(getTypeOfExpression(parent2.argumentExpression)));
-    }
-    function isGenericTypeWithUnionConstraint(type) {
-      return type.flags & 2097152 /* Intersection */ ? some(type.types, isGenericTypeWithUnionConstraint) : !!(type.flags & 465829888 /* Instantiable */ && getBaseConstraintOrType(type).flags & (98304 /* Nullable */ | 1048576 /* Union */));
-    }
-    function isGenericTypeWithoutNullableConstraint(type) {
-      return type.flags & 2097152 /* Intersection */ ? some(type.types, isGenericTypeWithoutNullableConstraint) : !!(type.flags & 465829888 /* Instantiable */ && !maybeTypeOfKind(getBaseConstraintOrType(type), 98304 /* Nullable */));
-    }
-    function hasContextualTypeWithNoGenericTypes(node, checkMode) {
-      const contextualType = (isIdentifier(node) || isPropertyAccessExpression(node) || isElementAccessExpression(node)) && !((isJsxOpeningElement(node.parent) || isJsxSelfClosingElement(node.parent)) && node.parent.tagName === node) && (checkMode && checkMode & 64 /* RestBindingElement */ ? getContextualType2(node, 8 /* SkipBindingPatterns */) : getContextualType2(
-        node,
-        /*contextFlags*/
-        void 0
-      ));
-      return contextualType && !isGenericType(contextualType);
-    }
-    function getNarrowableTypeForReference(type, reference, checkMode) {
-      const substituteConstraints = !(checkMode && checkMode & 2 /* Inferential */) && someType(type, isGenericTypeWithUnionConstraint) && (isConstraintPosition(type, reference) || hasContextualTypeWithNoGenericTypes(reference, checkMode));
-      return substituteConstraints ? mapType(type, getBaseConstraintOrType) : type;
-    }
-    function isExportOrExportExpression(location) {
-      return !!findAncestor(location, (n) => {
-        const parent2 = n.parent;
-        if (parent2 === void 0) {
-          return "quit";
-        }
-        if (isExportAssignment(parent2)) {
-          return parent2.expression === n && isEntityNameExpression(n);
-        }
-        if (isExportSpecifier(parent2)) {
-          return parent2.name === n || parent2.propertyName === n;
-        }
-        return false;
-      });
-    }
-    function markAliasReferenced(symbol, location) {
-      if (!canCollectSymbolAliasAccessabilityData) {
-        return;
-      }
-      if (isNonLocalAlias(
-        symbol,
-        /*excludes*/
-        111551 /* Value */
-      ) && !isInTypeQuery(location) && !getTypeOnlyAliasDeclaration(symbol, 111551 /* Value */)) {
-        const target = resolveAlias(symbol);
-        if (getAllSymbolFlags(target) & (111551 /* Value */ | 1048576 /* ExportValue */)) {
-          if (getIsolatedModules(compilerOptions) || shouldPreserveConstEnums(compilerOptions) && isExportOrExportExpression(location) || !isConstEnumOrConstEnumOnlyModule(getExportSymbolOfValueSymbolIfExported(target))) {
-            markAliasSymbolAsReferenced(symbol);
-          } else {
-            markConstEnumAliasAsReferenced(symbol);
-          }
-        }
-      }
-    }
-    function getNarrowedTypeOfSymbol(symbol, location) {
-      var _a;
-      const type = getTypeOfSymbol(symbol);
-      const declaration = symbol.valueDeclaration;
-      if (declaration) {
-        if (isBindingElement(declaration) && !declaration.initializer && !declaration.dotDotDotToken && declaration.parent.elements.length >= 2) {
-          const parent2 = declaration.parent.parent;
-          if (parent2.kind === 259 /* VariableDeclaration */ && getCombinedNodeFlags(declaration) & 2 /* Const */ || parent2.kind === 168 /* Parameter */) {
-            const links = getNodeLinks(parent2);
-            if (!(links.flags & 16777216 /* InCheckIdentifier */)) {
-              links.flags |= 16777216 /* InCheckIdentifier */;
-              const parentType = getTypeForBindingElementParent(parent2, 0 /* Normal */);
-              const parentTypeConstraint = parentType && mapType(parentType, getBaseConstraintOrType);
-              links.flags &= ~16777216 /* InCheckIdentifier */;
-              if (parentTypeConstraint && parentTypeConstraint.flags & 1048576 /* Union */ && !(parent2.kind === 168 /* Parameter */ && isSymbolAssigned(symbol))) {
-                const pattern = declaration.parent;
-                const narrowedType = getFlowTypeOfReference(
-                  pattern,
-                  parentTypeConstraint,
-                  parentTypeConstraint,
-                  /*flowContainer*/
-                  void 0,
-                  location.flowNode
-                );
-                if (narrowedType.flags & 131072 /* Never */) {
-                  return neverType;
-                }
-                return getBindingElementTypeFromParentType(declaration, narrowedType);
-              }
-            }
-          }
-        }
-        if (isParameter(declaration) && !declaration.type && !declaration.initializer && !declaration.dotDotDotToken) {
-          const func = declaration.parent;
-          if (func.parameters.length >= 2 && isContextSensitiveFunctionOrObjectLiteralMethod(func)) {
-            const contextualSignature = getContextualSignature(func);
-            if (contextualSignature && contextualSignature.parameters.length === 1 && signatureHasRestParameter(contextualSignature)) {
-              const restType = getReducedApparentType(instantiateType(getTypeOfSymbol(contextualSignature.parameters[0]), (_a = getInferenceContext(func)) == null ? void 0 : _a.nonFixingMapper));
-              if (restType.flags & 1048576 /* Union */ && everyType(restType, isTupleType) && !isSymbolAssigned(symbol)) {
-                const narrowedType = getFlowTypeOfReference(
-                  func,
-                  restType,
-                  restType,
-                  /*flowContainer*/
-                  void 0,
-                  location.flowNode
-                );
-                const index = func.parameters.indexOf(declaration) - (getThisParameter(func) ? 1 : 0);
-                return getIndexedAccessType(narrowedType, getNumberLiteralType(index));
-              }
-            }
-          }
-        }
-      }
-      return type;
-    }
-    function checkIdentifier(node, checkMode) {
-      if (isThisInTypeQuery(node)) {
-        return checkThisExpression(node);
-      }
-      const symbol = getResolvedSymbol(node);
-      if (symbol === unknownSymbol) {
-        return errorType;
-      }
-      if (symbol === argumentsSymbol) {
-        if (isInPropertyInitializerOrClassStaticBlock(node)) {
-          error(node, Diagnostics.arguments_cannot_be_referenced_in_property_initializers);
-          return errorType;
-        }
-        const container = getContainingFunction(node);
-        if (languageVersion < 2 /* ES2015 */) {
-          if (container.kind === 218 /* ArrowFunction */) {
-            error(node, Diagnostics.The_arguments_object_cannot_be_referenced_in_an_arrow_function_in_ES3_and_ES5_Consider_using_a_standard_function_expression);
-          } else if (hasSyntacticModifier(container, 512 /* Async */)) {
-            error(node, Diagnostics.The_arguments_object_cannot_be_referenced_in_an_async_function_or_method_in_ES3_and_ES5_Consider_using_a_standard_function_or_method);
-          }
-        }
-        getNodeLinks(container).flags |= 512 /* CaptureArguments */;
-        return getTypeOfSymbol(symbol);
-      }
-      if (shouldMarkIdentifierAliasReferenced(node)) {
-        markAliasReferenced(symbol, node);
-      }
-      const localOrExportSymbol = getExportSymbolOfValueSymbolIfExported(symbol);
-      const targetSymbol = resolveAliasWithDeprecationCheck(localOrExportSymbol, node);
-      if (isDeprecatedSymbol(targetSymbol) && isUncalledFunctionReference(node, targetSymbol) && targetSymbol.declarations) {
-        addDeprecatedSuggestion(node, targetSymbol.declarations, node.escapedText);
-      }
-      let declaration = localOrExportSymbol.valueDeclaration;
-      if (declaration && localOrExportSymbol.flags & 32 /* Class */) {
-        if (declaration.kind === 262 /* ClassDeclaration */ && nodeIsDecorated(legacyDecorators, declaration)) {
-          let container = getContainingClass(node);
-          while (container !== void 0) {
-            if (container === declaration && container.name !== node) {
-              getNodeLinks(declaration).flags |= 1048576 /* ClassWithConstructorReference */;
-              getNodeLinks(node).flags |= 2097152 /* ConstructorReferenceInClass */;
-              break;
-            }
-            container = getContainingClass(container);
-          }
-        } else if (declaration.kind === 230 /* ClassExpression */) {
-          let container = getThisContainer(
-            node,
-            /*includeArrowFunctions*/
-            false,
-            /*includeClassComputedPropertyName*/
-            false
-          );
-          while (container.kind !== 311 /* SourceFile */) {
-            if (container.parent === declaration) {
-              if (isPropertyDeclaration(container) && isStatic(container) || isClassStaticBlockDeclaration(container)) {
-                getNodeLinks(declaration).flags |= 1048576 /* ClassWithConstructorReference */;
-                getNodeLinks(node).flags |= 2097152 /* ConstructorReferenceInClass */;
-              }
-              break;
-            }
-            container = getThisContainer(
-              container,
-              /*includeArrowFunctions*/
-              false,
-              /*includeClassComputedPropertyName*/
-              false
-            );
-          }
-        }
-      }
-      checkNestedBlockScopedBinding(node, symbol);
-      let type = getNarrowedTypeOfSymbol(localOrExportSymbol, node);
-      const assignmentKind = getAssignmentTargetKind(node);
-      if (assignmentKind) {
-        if (!(localOrExportSymbol.flags & 3 /* Variable */) && !(isInJSFile(node) && localOrExportSymbol.flags & 512 /* ValueModule */)) {
-          const assignmentError = localOrExportSymbol.flags & 384 /* Enum */ ? Diagnostics.Cannot_assign_to_0_because_it_is_an_enum : localOrExportSymbol.flags & 32 /* Class */ ? Diagnostics.Cannot_assign_to_0_because_it_is_a_class : localOrExportSymbol.flags & 1536 /* Module */ ? Diagnostics.Cannot_assign_to_0_because_it_is_a_namespace : localOrExportSymbol.flags & 16 /* Function */ ? Diagnostics.Cannot_assign_to_0_because_it_is_a_function : localOrExportSymbol.flags & 2097152 /* Alias */ ? Diagnostics.Cannot_assign_to_0_because_it_is_an_import : Diagnostics.Cannot_assign_to_0_because_it_is_not_a_variable;
-          error(node, assignmentError, symbolToString(symbol));
-          return errorType;
-        }
-        if (isReadonlySymbol(localOrExportSymbol)) {
-          if (localOrExportSymbol.flags & 3 /* Variable */) {
-            error(node, Diagnostics.Cannot_assign_to_0_because_it_is_a_constant, symbolToString(symbol));
-          } else {
-            error(node, Diagnostics.Cannot_assign_to_0_because_it_is_a_read_only_property, symbolToString(symbol));
-          }
-          return errorType;
-        }
-      }
-      const isAlias = localOrExportSymbol.flags & 2097152 /* Alias */;
-      if (localOrExportSymbol.flags & 3 /* Variable */) {
-        if (assignmentKind === 1 /* Definite */) {
-          return type;
-        }
-      } else if (isAlias) {
-        declaration = getDeclarationOfAliasSymbol(symbol);
-      } else {
-        return type;
-      }
-      if (!declaration) {
-        return type;
-      }
-      type = getNarrowableTypeForReference(type, node, checkMode);
-      const isParameter2 = getRootDeclaration(declaration).kind === 168 /* Parameter */;
-      const declarationContainer = getControlFlowContainer(declaration);
-      let flowContainer = getControlFlowContainer(node);
-      const isOuterVariable = flowContainer !== declarationContainer;
-      const isSpreadDestructuringAssignmentTarget = node.parent && node.parent.parent && isSpreadAssignment(node.parent) && isDestructuringAssignmentTarget(node.parent.parent);
-      const isModuleExports = symbol.flags & 134217728 /* ModuleExports */;
-      const typeIsAutomatic = type === autoType || type === autoArrayType;
-      const isAutomaticTypeInNonNull = typeIsAutomatic && node.parent.kind === 234 /* NonNullExpression */;
-      while (flowContainer !== declarationContainer && (flowContainer.kind === 217 /* FunctionExpression */ || flowContainer.kind === 218 /* ArrowFunction */ || isObjectLiteralOrClassExpressionMethodOrAccessor(flowContainer)) && (isConstVariable(localOrExportSymbol) && type !== autoArrayType || isParameter2 && !isSymbolAssigned(localOrExportSymbol))) {
-        flowContainer = getControlFlowContainer(flowContainer);
-      }
-      const assumeInitialized = isParameter2 || isAlias || isOuterVariable || isSpreadDestructuringAssignmentTarget || isModuleExports || isSameScopedBindingElement(node, declaration) || type !== autoType && type !== autoArrayType && (!strictNullChecks || (type.flags & (3 /* AnyOrUnknown */ | 16384 /* Void */)) !== 0 || isInTypeQuery(node) || isInAmbientOrTypeNode(node) || node.parent.kind === 280 /* ExportSpecifier */) || node.parent.kind === 234 /* NonNullExpression */ || declaration.kind === 259 /* VariableDeclaration */ && declaration.exclamationToken || declaration.flags & 16777216 /* Ambient */;
-      const initialType = isAutomaticTypeInNonNull ? undefinedType : assumeInitialized ? isParameter2 ? removeOptionalityFromDeclaredType(type, declaration) : type : typeIsAutomatic ? undefinedType : getOptionalType(type);
-      const flowType = isAutomaticTypeInNonNull ? getNonNullableType(getFlowTypeOfReference(node, type, initialType, flowContainer)) : getFlowTypeOfReference(node, type, initialType, flowContainer);
-      if (!isEvolvingArrayOperationTarget(node) && (type === autoType || type === autoArrayType)) {
-        if (flowType === autoType || flowType === autoArrayType) {
-          if (noImplicitAny) {
-            error(getNameOfDeclaration(declaration), Diagnostics.Variable_0_implicitly_has_type_1_in_some_locations_where_its_type_cannot_be_determined, symbolToString(symbol), typeToString(flowType));
-            error(node, Diagnostics.Variable_0_implicitly_has_an_1_type, symbolToString(symbol), typeToString(flowType));
-          }
-          return convertAutoToAny(flowType);
-        }
-      } else if (!assumeInitialized && !containsUndefinedType(type) && containsUndefinedType(flowType)) {
-        error(node, Diagnostics.Variable_0_is_used_before_being_assigned, symbolToString(symbol));
-        return type;
-      }
-      return assignmentKind ? getBaseTypeOfLiteralType(flowType) : flowType;
-    }
-    function isSameScopedBindingElement(node, declaration) {
-      if (isBindingElement(declaration)) {
-        const bindingElement = findAncestor(node, isBindingElement);
-        return bindingElement && getRootDeclaration(bindingElement) === getRootDeclaration(declaration);
-      }
-    }
-    function shouldMarkIdentifierAliasReferenced(node) {
-      var _a;
-      const parent2 = node.parent;
-      if (parent2) {
-        if (isPropertyAccessExpression(parent2) && parent2.expression === node) {
-          return false;
-        }
-        if (isExportSpecifier(parent2) && parent2.isTypeOnly) {
-          return false;
-        }
-        const greatGrandparent = (_a = parent2.parent) == null ? void 0 : _a.parent;
-        if (greatGrandparent && isExportDeclaration(greatGrandparent) && greatGrandparent.isTypeOnly) {
-          return false;
-        }
-      }
-      return true;
-    }
-    function isInsideFunctionOrInstancePropertyInitializer(node, threshold) {
-      return !!findAncestor(node, (n) => n === threshold ? "quit" : isFunctionLike(n) || n.parent && isPropertyDeclaration(n.parent) && !hasStaticModifier(n.parent) && n.parent.initializer === n);
-    }
-    function getPartOfForStatementContainingNode(node, container) {
-      return findAncestor(node, (n) => n === container ? "quit" : n === container.initializer || n === container.condition || n === container.incrementor || n === container.statement);
-    }
-    function getEnclosingIterationStatement(node) {
-      return findAncestor(node, (n) => !n || nodeStartsNewLexicalEnvironment(n) ? "quit" : isIterationStatement(
-        n,
-        /*lookInLabeledStatements*/
-        false
-      ));
-    }
-    function checkNestedBlockScopedBinding(node, symbol) {
-      if (languageVersion >= 2 /* ES2015 */ || (symbol.flags & (2 /* BlockScopedVariable */ | 32 /* Class */)) === 0 || !symbol.valueDeclaration || isSourceFile(symbol.valueDeclaration) || symbol.valueDeclaration.parent.kind === 298 /* CatchClause */) {
-        return;
-      }
-      const container = getEnclosingBlockScopeContainer(symbol.valueDeclaration);
-      const isCaptured = isInsideFunctionOrInstancePropertyInitializer(node, container);
-      const enclosingIterationStatement = getEnclosingIterationStatement(container);
-      if (enclosingIterationStatement) {
-        if (isCaptured) {
-          let capturesBlockScopeBindingInLoopBody = true;
-          if (isForStatement(container)) {
-            const varDeclList = getAncestor(symbol.valueDeclaration, 260 /* VariableDeclarationList */);
-            if (varDeclList && varDeclList.parent === container) {
-              const part = getPartOfForStatementContainingNode(node.parent, container);
-              if (part) {
-                const links = getNodeLinks(part);
-                links.flags |= 8192 /* ContainsCapturedBlockScopeBinding */;
-                const capturedBindings = links.capturedBlockScopeBindings || (links.capturedBlockScopeBindings = []);
-                pushIfUnique(capturedBindings, symbol);
-                if (part === container.initializer) {
-                  capturesBlockScopeBindingInLoopBody = false;
-                }
-              }
-            }
-          }
-          if (capturesBlockScopeBindingInLoopBody) {
-            getNodeLinks(enclosingIterationStatement).flags |= 4096 /* LoopWithCapturedBlockScopedBinding */;
-          }
-        }
-        if (isForStatement(container)) {
-          const varDeclList = getAncestor(symbol.valueDeclaration, 260 /* VariableDeclarationList */);
-          if (varDeclList && varDeclList.parent === container && isAssignedInBodyOfForStatement(node, container)) {
-            getNodeLinks(symbol.valueDeclaration).flags |= 262144 /* NeedsLoopOutParameter */;
-          }
-        }
-        getNodeLinks(symbol.valueDeclaration).flags |= 32768 /* BlockScopedBindingInLoop */;
-      }
-      if (isCaptured) {
-        getNodeLinks(symbol.valueDeclaration).flags |= 16384 /* CapturedBlockScopedBinding */;
-      }
-    }
-    function isBindingCapturedByNode(node, decl) {
-      const links = getNodeLinks(node);
-      return !!links && contains(links.capturedBlockScopeBindings, getSymbolOfDeclaration(decl));
-    }
-    function isAssignedInBodyOfForStatement(node, container) {
-      let current = node;
-      while (current.parent.kind === 216 /* ParenthesizedExpression */) {
-        current = current.parent;
-      }
-      let isAssigned = false;
-      if (isAssignmentTarget(current)) {
-        isAssigned = true;
-      } else if (current.parent.kind === 223 /* PrefixUnaryExpression */ || current.parent.kind === 224 /* PostfixUnaryExpression */) {
-        const expr = current.parent;
-        isAssigned = expr.operator === 46 /* PlusPlusToken */ || expr.operator === 47 /* MinusMinusToken */;
-      }
-      if (!isAssigned) {
-        return false;
-      }
-      return !!findAncestor(current, (n) => n === container ? "quit" : n === container.statement);
-    }
-    function captureLexicalThis(node, container) {
-      getNodeLinks(node).flags |= 2 /* LexicalThis */;
-      if (container.kind === 171 /* PropertyDeclaration */ || container.kind === 175 /* Constructor */) {
-        const classNode = container.parent;
-        getNodeLinks(classNode).flags |= 4 /* CaptureThis */;
-      } else {
-        getNodeLinks(container).flags |= 4 /* CaptureThis */;
-      }
-    }
-    function findFirstSuperCall(node) {
-      return isSuperCall(node) ? node : isFunctionLike(node) ? void 0 : forEachChild(node, findFirstSuperCall);
-    }
-    function classDeclarationExtendsNull(classDecl) {
-      const classSymbol = getSymbolOfDeclaration(classDecl);
-      const classInstanceType = getDeclaredTypeOfSymbol(classSymbol);
-      const baseConstructorType = getBaseConstructorTypeOfClass(classInstanceType);
-      return baseConstructorType === nullWideningType;
-    }
-    function checkThisBeforeSuper(node, container, diagnosticMessage) {
-      const containingClassDecl = container.parent;
-      const baseTypeNode = getClassExtendsHeritageElement(containingClassDecl);
-      if (baseTypeNode && !classDeclarationExtendsNull(containingClassDecl)) {
-        if (canHaveFlowNode(node) && node.flowNode && !isPostSuperFlowNode(
-          node.flowNode,
-          /*noCacheCheck*/
-          false
-        )) {
-          error(node, diagnosticMessage);
-        }
-      }
-    }
-    function checkThisInStaticClassFieldInitializerInDecoratedClass(thisExpression, container) {
-      if (isPropertyDeclaration(container) && hasStaticModifier(container) && legacyDecorators && container.initializer && textRangeContainsPositionInclusive(container.initializer, thisExpression.pos) && hasDecorators(container.parent)) {
-        error(thisExpression, Diagnostics.Cannot_use_this_in_a_static_property_initializer_of_a_decorated_class);
-      }
-    }
-    function checkThisExpression(node) {
-      const isNodeInTypeQuery = isInTypeQuery(node);
-      let container = getThisContainer(
-        node,
-        /*includeArrowFunctions*/
-        true,
-        /*includeClassComputedPropertyName*/
-        true
-      );
-      let capturedByArrowFunction = false;
-      let thisInComputedPropertyName = false;
-      if (container.kind === 175 /* Constructor */) {
-        checkThisBeforeSuper(node, container, Diagnostics.super_must_be_called_before_accessing_this_in_the_constructor_of_a_derived_class);
-      }
-      while (true) {
-        if (container.kind === 218 /* ArrowFunction */) {
-          container = getThisContainer(
-            container,
-            /*includeArrowFunctions*/
-            false,
-            !thisInComputedPropertyName
-          );
-          capturedByArrowFunction = true;
-        }
-        if (container.kind === 166 /* ComputedPropertyName */) {
-          container = getThisContainer(
-            container,
-            !capturedByArrowFunction,
-            /*includeClassComputedPropertyName*/
-            false
-          );
-          thisInComputedPropertyName = true;
-          continue;
-        }
-        break;
-      }
-      checkThisInStaticClassFieldInitializerInDecoratedClass(node, container);
-      if (thisInComputedPropertyName) {
-        error(node, Diagnostics.this_cannot_be_referenced_in_a_computed_property_name);
-      } else {
-        switch (container.kind) {
-          case 266 /* ModuleDeclaration */:
-            error(node, Diagnostics.this_cannot_be_referenced_in_a_module_or_namespace_body);
-            break;
-          case 265 /* EnumDeclaration */:
-            error(node, Diagnostics.this_cannot_be_referenced_in_current_location);
-            break;
-          case 175 /* Constructor */:
-            if (isInConstructorArgumentInitializer(node, container)) {
-              error(node, Diagnostics.this_cannot_be_referenced_in_constructor_arguments);
-            }
-            break;
-        }
-      }
-      if (!isNodeInTypeQuery && capturedByArrowFunction && languageVersion < 2 /* ES2015 */) {
-        captureLexicalThis(node, container);
-      }
-      const type = tryGetThisTypeAt(
-        node,
-        /*includeGlobalThis*/
-        true,
-        container
-      );
-      if (noImplicitThis) {
-        const globalThisType2 = getTypeOfSymbol(globalThisSymbol);
-        if (type === globalThisType2 && capturedByArrowFunction) {
-          error(node, Diagnostics.The_containing_arrow_function_captures_the_global_value_of_this);
-        } else if (!type) {
-          const diag2 = error(node, Diagnostics.this_implicitly_has_type_any_because_it_does_not_have_a_type_annotation);
-          if (!isSourceFile(container)) {
-            const outsideThis = tryGetThisTypeAt(container);
-            if (outsideThis && outsideThis !== globalThisType2) {
-              addRelatedInfo(diag2, createDiagnosticForNode(container, Diagnostics.An_outer_value_of_this_is_shadowed_by_this_container));
-            }
-          }
-        }
-      }
-      return type || anyType;
-    }
-    function tryGetThisTypeAt(node, includeGlobalThis = true, container = getThisContainer(
-      node,
-      /*includeArrowFunctions*/
-      false,
-      /*includeClassComputedPropertyName*/
-      false
-    )) {
-      const isInJS = isInJSFile(node);
-      if (isFunctionLike(container) && (!isInParameterInitializerBeforeContainingFunction(node) || getThisParameter(container))) {
-        let thisType = getThisTypeOfDeclaration(container) || isInJS && getTypeForThisExpressionFromJSDoc(container);
-        if (!thisType) {
-          const className = getClassNameFromPrototypeMethod(container);
-          if (isInJS && className) {
-            const classSymbol = checkExpression(className).symbol;
-            if (classSymbol && classSymbol.members && classSymbol.flags & 16 /* Function */) {
-              thisType = getDeclaredTypeOfSymbol(classSymbol).thisType;
-            }
-          } else if (isJSConstructor(container)) {
-            thisType = getDeclaredTypeOfSymbol(getMergedSymbol(container.symbol)).thisType;
-          }
-          thisType || (thisType = getContextualThisParameterType(container));
-        }
-        if (thisType) {
-          return getFlowTypeOfReference(node, thisType);
-        }
-      }
-      if (isClassLike(container.parent)) {
-        const symbol = getSymbolOfDeclaration(container.parent);
-        const type = isStatic(container) ? getTypeOfSymbol(symbol) : getDeclaredTypeOfSymbol(symbol).thisType;
-        return getFlowTypeOfReference(node, type);
-      }
-      if (isSourceFile(container)) {
-        if (container.commonJsModuleIndicator) {
-          const fileSymbol = getSymbolOfDeclaration(container);
-          return fileSymbol && getTypeOfSymbol(fileSymbol);
-        } else if (container.externalModuleIndicator) {
-          return undefinedType;
-        } else if (includeGlobalThis) {
-          return getTypeOfSymbol(globalThisSymbol);
-        }
-      }
-    }
-    function getExplicitThisType(node) {
-      const container = getThisContainer(
-        node,
-        /*includeArrowFunctions*/
-        false,
-        /*includeClassComputedPropertyName*/
-        false
-      );
-      if (isFunctionLike(container)) {
-        const signature = getSignatureFromDeclaration(container);
-        if (signature.thisParameter) {
-          return getExplicitTypeOfSymbol(signature.thisParameter);
-        }
-      }
-      if (isClassLike(container.parent)) {
-        const symbol = getSymbolOfDeclaration(container.parent);
-        return isStatic(container) ? getTypeOfSymbol(symbol) : getDeclaredTypeOfSymbol(symbol).thisType;
-      }
-    }
-    function getClassNameFromPrototypeMethod(container) {
-      if (container.kind === 217 /* FunctionExpression */ && isBinaryExpression(container.parent) && getAssignmentDeclarationKind(container.parent) === 3 /* PrototypeProperty */) {
-        return container.parent.left.expression.expression;
-      } else if (container.kind === 173 /* MethodDeclaration */ && container.parent.kind === 209 /* ObjectLiteralExpression */ && isBinaryExpression(container.parent.parent) && getAssignmentDeclarationKind(container.parent.parent) === 6 /* Prototype */) {
-        return container.parent.parent.left.expression;
-      } else if (container.kind === 217 /* FunctionExpression */ && container.parent.kind === 302 /* PropertyAssignment */ && container.parent.parent.kind === 209 /* ObjectLiteralExpression */ && isBinaryExpression(container.parent.parent.parent) && getAssignmentDeclarationKind(container.parent.parent.parent) === 6 /* Prototype */) {
-        return container.parent.parent.parent.left.expression;
-      } else if (container.kind === 217 /* FunctionExpression */ && isPropertyAssignment(container.parent) && isIdentifier(container.parent.name) && (container.parent.name.escapedText === "value" || container.parent.name.escapedText === "get" || container.parent.name.escapedText === "set") && isObjectLiteralExpression(container.parent.parent) && isCallExpression(container.parent.parent.parent) && container.parent.parent.parent.arguments[2] === container.parent.parent && getAssignmentDeclarationKind(container.parent.parent.parent) === 9 /* ObjectDefinePrototypeProperty */) {
-        return container.parent.parent.parent.arguments[0].expression;
-      } else if (isMethodDeclaration(container) && isIdentifier(container.name) && (container.name.escapedText === "value" || container.name.escapedText === "get" || container.name.escapedText === "set") && isObjectLiteralExpression(container.parent) && isCallExpression(container.parent.parent) && container.parent.parent.arguments[2] === container.parent && getAssignmentDeclarationKind(container.parent.parent) === 9 /* ObjectDefinePrototypeProperty */) {
-        return container.parent.parent.arguments[0].expression;
-      }
-    }
-    function getTypeForThisExpressionFromJSDoc(node) {
-      const jsdocType = getJSDocType(node);
-      if (jsdocType && jsdocType.kind === 323 /* JSDocFunctionType */) {
-        const jsDocFunctionType = jsdocType;
-        if (jsDocFunctionType.parameters.length > 0 && jsDocFunctionType.parameters[0].name && jsDocFunctionType.parameters[0].name.escapedText === "this" /* This */) {
-          return getTypeFromTypeNode(jsDocFunctionType.parameters[0].type);
-        }
-      }
-      const thisTag = getJSDocThisTag(node);
-      if (thisTag && thisTag.typeExpression) {
-        return getTypeFromTypeNode(thisTag.typeExpression);
-      }
-    }
-    function isInConstructorArgumentInitializer(node, constructorDecl) {
-      return !!findAncestor(node, (n) => isFunctionLikeDeclaration(n) ? "quit" : n.kind === 168 /* Parameter */ && n.parent === constructorDecl);
-    }
-    function checkSuperExpression(node) {
-      const isCallExpression2 = node.parent.kind === 212 /* CallExpression */ && node.parent.expression === node;
-      const immediateContainer = getSuperContainer(
-        node,
-        /*stopOnFunctions*/
-        true
-      );
-      let container = immediateContainer;
-      let needToCaptureLexicalThis = false;
-      let inAsyncFunction = false;
-      if (!isCallExpression2) {
-        while (container && container.kind === 218 /* ArrowFunction */) {
-          if (hasSyntacticModifier(container, 512 /* Async */))
-            inAsyncFunction = true;
-          container = getSuperContainer(
-            container,
-            /*stopOnFunctions*/
-            true
-          );
-          needToCaptureLexicalThis = languageVersion < 2 /* ES2015 */;
-        }
-        if (container && hasSyntacticModifier(container, 512 /* Async */))
-          inAsyncFunction = true;
-      }
-      let nodeCheckFlag = 0;
-      if (!container || !isLegalUsageOfSuperExpression(container)) {
-        const current = findAncestor(node, (n) => n === container ? "quit" : n.kind === 166 /* ComputedPropertyName */);
-        if (current && current.kind === 166 /* ComputedPropertyName */) {
-          error(node, Diagnostics.super_cannot_be_referenced_in_a_computed_property_name);
-        } else if (isCallExpression2) {
-          error(node, Diagnostics.Super_calls_are_not_permitted_outside_constructors_or_in_nested_functions_inside_constructors);
-        } else if (!container || !container.parent || !(isClassLike(container.parent) || container.parent.kind === 209 /* ObjectLiteralExpression */)) {
-          error(node, Diagnostics.super_can_only_be_referenced_in_members_of_derived_classes_or_object_literal_expressions);
-        } else {
-          error(node, Diagnostics.super_property_access_is_permitted_only_in_a_constructor_member_function_or_member_accessor_of_a_derived_class);
-        }
-        return errorType;
-      }
-      if (!isCallExpression2 && immediateContainer.kind === 175 /* Constructor */) {
-        checkThisBeforeSuper(node, container, Diagnostics.super_must_be_called_before_accessing_a_property_of_super_in_the_constructor_of_a_derived_class);
-      }
-      if (isStatic(container) || isCallExpression2) {
-        nodeCheckFlag = 32 /* SuperStatic */;
-        if (!isCallExpression2 && languageVersion >= 2 /* ES2015 */ && languageVersion <= 8 /* ES2021 */ && (isPropertyDeclaration(container) || isClassStaticBlockDeclaration(container))) {
-          forEachEnclosingBlockScopeContainer(node.parent, (current) => {
-            if (!isSourceFile(current) || isExternalOrCommonJsModule(current)) {
-              getNodeLinks(current).flags |= 8388608 /* ContainsSuperPropertyInStaticInitializer */;
-            }
-          });
-        }
-      } else {
-        nodeCheckFlag = 16 /* SuperInstance */;
-      }
-      getNodeLinks(node).flags |= nodeCheckFlag;
-      if (container.kind === 173 /* MethodDeclaration */ && inAsyncFunction) {
-        if (isSuperProperty(node.parent) && isAssignmentTarget(node.parent)) {
-          getNodeLinks(container).flags |= 256 /* MethodWithSuperPropertyAssignmentInAsync */;
-        } else {
-          getNodeLinks(container).flags |= 128 /* MethodWithSuperPropertyAccessInAsync */;
-        }
-      }
-      if (needToCaptureLexicalThis) {
-        captureLexicalThis(node.parent, container);
-      }
-      if (container.parent.kind === 209 /* ObjectLiteralExpression */) {
-        if (languageVersion < 2 /* ES2015 */) {
-          error(node, Diagnostics.super_is_only_allowed_in_members_of_object_literal_expressions_when_option_target_is_ES2015_or_higher);
-          return errorType;
-        } else {
-          return anyType;
-        }
-      }
-      const classLikeDeclaration = container.parent;
-      if (!getClassExtendsHeritageElement(classLikeDeclaration)) {
-        error(node, Diagnostics.super_can_only_be_referenced_in_a_derived_class);
-        return errorType;
-      }
-      const classType = getDeclaredTypeOfSymbol(getSymbolOfDeclaration(classLikeDeclaration));
-      const baseClassType = classType && getBaseTypes(classType)[0];
-      if (!baseClassType) {
-        return errorType;
-      }
-      if (container.kind === 175 /* Constructor */ && isInConstructorArgumentInitializer(node, container)) {
-        error(node, Diagnostics.super_cannot_be_referenced_in_constructor_arguments);
-        return errorType;
-      }
-      return nodeCheckFlag === 32 /* SuperStatic */ ? getBaseConstructorTypeOfClass(classType) : getTypeWithThisArgument(baseClassType, classType.thisType);
-      function isLegalUsageOfSuperExpression(container2) {
-        if (isCallExpression2) {
-          return container2.kind === 175 /* Constructor */;
-        } else {
-          if (isClassLike(container2.parent) || container2.parent.kind === 209 /* ObjectLiteralExpression */) {
-            if (isStatic(container2)) {
-              return container2.kind === 173 /* MethodDeclaration */ || container2.kind === 172 /* MethodSignature */ || container2.kind === 176 /* GetAccessor */ || container2.kind === 177 /* SetAccessor */ || container2.kind === 171 /* PropertyDeclaration */ || container2.kind === 174 /* ClassStaticBlockDeclaration */;
-            } else {
-              return container2.kind === 173 /* MethodDeclaration */ || container2.kind === 172 /* MethodSignature */ || container2.kind === 176 /* GetAccessor */ || container2.kind === 177 /* SetAccessor */ || container2.kind === 171 /* PropertyDeclaration */ || container2.kind === 170 /* PropertySignature */ || container2.kind === 175 /* Constructor */;
-            }
-          }
-        }
-        return false;
-      }
-    }
-    function getContainingObjectLiteral(func) {
-      return (func.kind === 173 /* MethodDeclaration */ || func.kind === 176 /* GetAccessor */ || func.kind === 177 /* SetAccessor */) && func.parent.kind === 209 /* ObjectLiteralExpression */ ? func.parent : func.kind === 217 /* FunctionExpression */ && func.parent.kind === 302 /* PropertyAssignment */ ? func.parent.parent : void 0;
-    }
-    function getThisTypeArgument(type) {
-      return getObjectFlags(type) & 4 /* Reference */ && type.target === globalThisType ? getTypeArguments(type)[0] : void 0;
-    }
-    function getThisTypeFromContextualType(type) {
-      return mapType(type, (t) => {
-        return t.flags & 2097152 /* Intersection */ ? forEach(t.types, getThisTypeArgument) : getThisTypeArgument(t);
-      });
-    }
-    function getContextualThisParameterType(func) {
-      if (func.kind === 218 /* ArrowFunction */) {
-        return void 0;
-      }
-      if (isContextSensitiveFunctionOrObjectLiteralMethod(func)) {
-        const contextualSignature = getContextualSignature(func);
-        if (contextualSignature) {
-          const thisParameter = contextualSignature.thisParameter;
-          if (thisParameter) {
-            return getTypeOfSymbol(thisParameter);
-          }
-        }
-      }
-      const inJs = isInJSFile(func);
-      if (noImplicitThis || inJs) {
-        const containingLiteral = getContainingObjectLiteral(func);
-        if (containingLiteral) {
-          const contextualType = getApparentTypeOfContextualType(
-            containingLiteral,
-            /*contextFlags*/
-            void 0
-          );
-          let literal = containingLiteral;
-          let type = contextualType;
-          while (type) {
-            const thisType = getThisTypeFromContextualType(type);
-            if (thisType) {
-              return instantiateType(thisType, getMapperFromContext(getInferenceContext(containingLiteral)));
-            }
-            if (literal.parent.kind !== 302 /* PropertyAssignment */) {
-              break;
-            }
-            literal = literal.parent.parent;
-            type = getApparentTypeOfContextualType(
-              literal,
-              /*contextFlags*/
-              void 0
-            );
-          }
-          return getWidenedType(contextualType ? getNonNullableType(contextualType) : checkExpressionCached(containingLiteral));
-        }
-        const parent2 = walkUpParenthesizedExpressions(func.parent);
-        if (parent2.kind === 225 /* BinaryExpression */ && parent2.operatorToken.kind === 64 /* EqualsToken */) {
-          const target = parent2.left;
-          if (isAccessExpression(target)) {
-            const { expression } = target;
-            if (inJs && isIdentifier(expression)) {
-              const sourceFile = getSourceFileOfNode(parent2);
-              if (sourceFile.commonJsModuleIndicator && getResolvedSymbol(expression) === sourceFile.symbol) {
-                return void 0;
-              }
-            }
-            return getWidenedType(checkExpressionCached(expression));
-          }
-        }
-      }
-      return void 0;
-    }
-    function getContextuallyTypedParameterType(parameter) {
-      const func = parameter.parent;
-      if (!isContextSensitiveFunctionOrObjectLiteralMethod(func)) {
-        return void 0;
-      }
-      const iife = getImmediatelyInvokedFunctionExpression(func);
-      if (iife && iife.arguments) {
-        const args = getEffectiveCallArguments(iife);
-        const indexOfParameter = func.parameters.indexOf(parameter);
-        if (parameter.dotDotDotToken) {
-          return getSpreadArgumentType(
-            args,
-            indexOfParameter,
-            args.length,
-            anyType,
-            /*context*/
-            void 0,
-            0 /* Normal */
-          );
-        }
-        const links = getNodeLinks(iife);
-        const cached = links.resolvedSignature;
-        links.resolvedSignature = anySignature;
-        const type = indexOfParameter < args.length ? getWidenedLiteralType(checkExpression(args[indexOfParameter])) : parameter.initializer ? void 0 : undefinedWideningType;
-        links.resolvedSignature = cached;
-        return type;
-      }
-      const contextualSignature = getContextualSignature(func);
-      if (contextualSignature) {
-        const index = func.parameters.indexOf(parameter) - (getThisParameter(func) ? 1 : 0);
-        return parameter.dotDotDotToken && lastOrUndefined(func.parameters) === parameter ? getRestTypeAtPosition(contextualSignature, index) : tryGetTypeAtPosition(contextualSignature, index);
-      }
-    }
-    function getContextualTypeForVariableLikeDeclaration(declaration, contextFlags) {
-      const typeNode = getEffectiveTypeAnnotationNode(declaration) || (isInJSFile(declaration) ? tryGetJSDocSatisfiesTypeNode(declaration) : void 0);
-      if (typeNode) {
-        return getTypeFromTypeNode(typeNode);
-      }
-      switch (declaration.kind) {
-        case 168 /* Parameter */:
-          return getContextuallyTypedParameterType(declaration);
-        case 207 /* BindingElement */:
-          return getContextualTypeForBindingElement(declaration, contextFlags);
-        case 171 /* PropertyDeclaration */:
-          if (isStatic(declaration)) {
-            return getContextualTypeForStaticPropertyDeclaration(declaration, contextFlags);
-          }
-      }
-    }
-    function getContextualTypeForBindingElement(declaration, contextFlags) {
-      const parent2 = declaration.parent.parent;
-      const name = declaration.propertyName || declaration.name;
-      const parentType = getContextualTypeForVariableLikeDeclaration(parent2, contextFlags) || parent2.kind !== 207 /* BindingElement */ && parent2.initializer && checkDeclarationInitializer(parent2, declaration.dotDotDotToken ? 64 /* RestBindingElement */ : 0 /* Normal */);
-      if (!parentType || isBindingPattern(name) || isComputedNonLiteralName(name))
-        return void 0;
-      if (parent2.name.kind === 206 /* ArrayBindingPattern */) {
-        const index = indexOfNode(declaration.parent.elements, declaration);
-        if (index < 0)
-          return void 0;
-        return getContextualTypeForElementExpression(parentType, index);
-      }
-      const nameType = getLiteralTypeFromPropertyName(name);
-      if (isTypeUsableAsPropertyName(nameType)) {
-        const text = getPropertyNameFromType(nameType);
-        return getTypeOfPropertyOfType(parentType, text);
-      }
-    }
-    function getContextualTypeForStaticPropertyDeclaration(declaration, contextFlags) {
-      const parentType = isExpression(declaration.parent) && getContextualType2(declaration.parent, contextFlags);
-      if (!parentType)
-        return void 0;
-      return getTypeOfPropertyOfContextualType(parentType, getSymbolOfDeclaration(declaration).escapedName);
-    }
-    function getContextualTypeForInitializerExpression(node, contextFlags) {
-      const declaration = node.parent;
-      if (hasInitializer(declaration) && node === declaration.initializer) {
-        const result = getContextualTypeForVariableLikeDeclaration(declaration, contextFlags);
-        if (result) {
-          return result;
-        }
-        if (!(contextFlags & 8 /* SkipBindingPatterns */) && isBindingPattern(declaration.name) && declaration.name.elements.length > 0) {
-          return getTypeFromBindingPattern(
-            declaration.name,
-            /*includePatternInType*/
-            true,
-            /*reportErrors*/
-            false
-          );
-        }
-      }
-      return void 0;
-    }
-    function getContextualTypeForReturnExpression(node, contextFlags) {
-      const func = getContainingFunction(node);
-      if (func) {
-        let contextualReturnType = getContextualReturnType(func, contextFlags);
-        if (contextualReturnType) {
-          const functionFlags = getFunctionFlags(func);
-          if (functionFlags & 1 /* Generator */) {
-            const isAsyncGenerator = (functionFlags & 2 /* Async */) !== 0;
-            if (contextualReturnType.flags & 1048576 /* Union */) {
-              contextualReturnType = filterType(contextualReturnType, (type) => !!getIterationTypeOfGeneratorFunctionReturnType(1 /* Return */, type, isAsyncGenerator));
-            }
-            const iterationReturnType = getIterationTypeOfGeneratorFunctionReturnType(1 /* Return */, contextualReturnType, (functionFlags & 2 /* Async */) !== 0);
-            if (!iterationReturnType) {
-              return void 0;
-            }
-            contextualReturnType = iterationReturnType;
-          }
-          if (functionFlags & 2 /* Async */) {
-            const contextualAwaitedType = mapType(contextualReturnType, getAwaitedTypeNoAlias);
-            return contextualAwaitedType && getUnionType([contextualAwaitedType, createPromiseLikeType(contextualAwaitedType)]);
-          }
-          return contextualReturnType;
-        }
-      }
-      return void 0;
-    }
-    function getContextualTypeForAwaitOperand(node, contextFlags) {
-      const contextualType = getContextualType2(node, contextFlags);
-      if (contextualType) {
-        const contextualAwaitedType = getAwaitedTypeNoAlias(contextualType);
-        return contextualAwaitedType && getUnionType([contextualAwaitedType, createPromiseLikeType(contextualAwaitedType)]);
-      }
-      return void 0;
-    }
-    function getContextualTypeForYieldOperand(node, contextFlags) {
-      const func = getContainingFunction(node);
-      if (func) {
-        const functionFlags = getFunctionFlags(func);
-        let contextualReturnType = getContextualReturnType(func, contextFlags);
-        if (contextualReturnType) {
-          const isAsyncGenerator = (functionFlags & 2 /* Async */) !== 0;
-          if (!node.asteriskToken && contextualReturnType.flags & 1048576 /* Union */) {
-            contextualReturnType = filterType(contextualReturnType, (type) => !!getIterationTypeOfGeneratorFunctionReturnType(1 /* Return */, type, isAsyncGenerator));
-          }
-          return node.asteriskToken ? contextualReturnType : getIterationTypeOfGeneratorFunctionReturnType(0 /* Yield */, contextualReturnType, isAsyncGenerator);
-        }
-      }
-      return void 0;
-    }
-    function isInParameterInitializerBeforeContainingFunction(node) {
-      let inBindingInitializer = false;
-      while (node.parent && !isFunctionLike(node.parent)) {
-        if (isParameter(node.parent) && (inBindingInitializer || node.parent.initializer === node)) {
-          return true;
-        }
-        if (isBindingElement(node.parent) && node.parent.initializer === node) {
-          inBindingInitializer = true;
-        }
-        node = node.parent;
-      }
-      return false;
-    }
-    function getContextualIterationType(kind, functionDecl) {
-      const isAsync = !!(getFunctionFlags(functionDecl) & 2 /* Async */);
-      const contextualReturnType = getContextualReturnType(
-        functionDecl,
-        /*contextFlags*/
-        void 0
-      );
-      if (contextualReturnType) {
-        return getIterationTypeOfGeneratorFunctionReturnType(kind, contextualReturnType, isAsync) || void 0;
-      }
-      return void 0;
-    }
-    function getContextualReturnType(functionDecl, contextFlags) {
-      const returnType = getReturnTypeFromAnnotation(functionDecl);
-      if (returnType) {
-        return returnType;
-      }
-      const signature = getContextualSignatureForFunctionLikeDeclaration(functionDecl);
-      if (signature && !isResolvingReturnTypeOfSignature(signature)) {
-        return getReturnTypeOfSignature(signature);
-      }
-      const iife = getImmediatelyInvokedFunctionExpression(functionDecl);
-      if (iife) {
-        return getContextualType2(iife, contextFlags);
-      }
-      return void 0;
-    }
-    function getContextualTypeForArgument(callTarget, arg) {
-      const args = getEffectiveCallArguments(callTarget);
-      const argIndex = args.indexOf(arg);
-      return argIndex === -1 ? void 0 : getContextualTypeForArgumentAtIndex(callTarget, argIndex);
-    }
-    function getContextualTypeForArgumentAtIndex(callTarget, argIndex) {
-      if (isImportCall(callTarget)) {
-        return argIndex === 0 ? stringType : argIndex === 1 ? getGlobalImportCallOptionsType(
-          /*reportErrors*/
-          false
-        ) : anyType;
-      }
-      const signature = getNodeLinks(callTarget).resolvedSignature === resolvingSignature ? resolvingSignature : getResolvedSignature(callTarget);
-      if (isJsxOpeningLikeElement(callTarget) && argIndex === 0) {
-        return getEffectiveFirstArgumentForJsxSignature(signature, callTarget);
-      }
-      const restIndex = signature.parameters.length - 1;
-      return signatureHasRestParameter(signature) && argIndex >= restIndex ? getIndexedAccessType(getTypeOfSymbol(signature.parameters[restIndex]), getNumberLiteralType(argIndex - restIndex), 256 /* Contextual */) : getTypeAtPosition(signature, argIndex);
-    }
-    function getContextualTypeForDecorator(decorator) {
-      const signature = getDecoratorCallSignature(decorator);
-      return signature ? getOrCreateTypeFromSignature(signature) : void 0;
-    }
-    function getContextualTypeForSubstitutionExpression(template, substitutionExpression) {
-      if (template.parent.kind === 214 /* TaggedTemplateExpression */) {
-        return getContextualTypeForArgument(template.parent, substitutionExpression);
-      }
-      return void 0;
-    }
-    function getContextualTypeForBinaryOperand(node, contextFlags) {
-      const binaryExpression = node.parent;
-      const { left, operatorToken, right } = binaryExpression;
-      switch (operatorToken.kind) {
-        case 64 /* EqualsToken */:
-        case 77 /* AmpersandAmpersandEqualsToken */:
-        case 76 /* BarBarEqualsToken */:
-        case 78 /* QuestionQuestionEqualsToken */:
-          return node === right ? getContextualTypeForAssignmentDeclaration(binaryExpression) : void 0;
-        case 57 /* BarBarToken */:
-        case 61 /* QuestionQuestionToken */:
-          const type = getContextualType2(binaryExpression, contextFlags);
-          return node === right && (type && type.pattern || !type && !isDefaultedExpandoInitializer(binaryExpression)) ? getTypeOfExpression(left) : type;
-        case 56 /* AmpersandAmpersandToken */:
-        case 28 /* CommaToken */:
-          return node === right ? getContextualType2(binaryExpression, contextFlags) : void 0;
-        default:
-          return void 0;
-      }
-    }
-    function getSymbolForExpression(e) {
-      if (canHaveSymbol(e) && e.symbol) {
-        return e.symbol;
-      }
-      if (isIdentifier(e)) {
-        return getResolvedSymbol(e);
-      }
-      if (isPropertyAccessExpression(e)) {
-        const lhsType = getTypeOfExpression(e.expression);
-        return isPrivateIdentifier(e.name) ? tryGetPrivateIdentifierPropertyOfType(lhsType, e.name) : getPropertyOfType(lhsType, e.name.escapedText);
-      }
-      if (isElementAccessExpression(e)) {
-        const propType = checkExpressionCached(e.argumentExpression);
-        if (!isTypeUsableAsPropertyName(propType)) {
-          return void 0;
-        }
-        const lhsType = getTypeOfExpression(e.expression);
-        return getPropertyOfType(lhsType, getPropertyNameFromType(propType));
-      }
-      return void 0;
-      function tryGetPrivateIdentifierPropertyOfType(type, id) {
-        const lexicallyScopedSymbol = lookupSymbolForPrivateIdentifierDeclaration(id.escapedText, id);
-        return lexicallyScopedSymbol && getPrivateIdentifierPropertyOfType(type, lexicallyScopedSymbol);
-      }
-    }
-    function getContextualTypeForAssignmentDeclaration(binaryExpression) {
-      var _a, _b;
-      const kind = getAssignmentDeclarationKind(binaryExpression);
-      switch (kind) {
-        case 0 /* None */:
-        case 4 /* ThisProperty */:
-          const lhsSymbol = getSymbolForExpression(binaryExpression.left);
-          const decl = lhsSymbol && lhsSymbol.valueDeclaration;
-          if (decl && (isPropertyDeclaration(decl) || isPropertySignature(decl))) {
-            const overallAnnotation = getEffectiveTypeAnnotationNode(decl);
-            return overallAnnotation && instantiateType(getTypeFromTypeNode(overallAnnotation), getSymbolLinks(lhsSymbol).mapper) || (isPropertyDeclaration(decl) ? decl.initializer && getTypeOfExpression(binaryExpression.left) : void 0);
-          }
-          if (kind === 0 /* None */) {
-            return getTypeOfExpression(binaryExpression.left);
-          }
-          return getContextualTypeForThisPropertyAssignment(binaryExpression);
-        case 5 /* Property */:
-          if (isPossiblyAliasedThisProperty(binaryExpression, kind)) {
-            return getContextualTypeForThisPropertyAssignment(binaryExpression);
-          } else if (!canHaveSymbol(binaryExpression.left) || !binaryExpression.left.symbol) {
-            return getTypeOfExpression(binaryExpression.left);
-          } else {
-            const decl2 = binaryExpression.left.symbol.valueDeclaration;
-            if (!decl2) {
-              return void 0;
-            }
-            const lhs = cast(binaryExpression.left, isAccessExpression);
-            const overallAnnotation = getEffectiveTypeAnnotationNode(decl2);
-            if (overallAnnotation) {
-              return getTypeFromTypeNode(overallAnnotation);
-            } else if (isIdentifier(lhs.expression)) {
-              const id = lhs.expression;
-              const parentSymbol = resolveName(
-                id,
-                id.escapedText,
-                111551 /* Value */,
-                /*nameNotFoundMessage*/
-                void 0,
-                id.escapedText,
-                /*isUse*/
-                true
-              );
-              if (parentSymbol) {
-                const annotated2 = parentSymbol.valueDeclaration && getEffectiveTypeAnnotationNode(parentSymbol.valueDeclaration);
-                if (annotated2) {
-                  const nameStr = getElementOrPropertyAccessName(lhs);
-                  if (nameStr !== void 0) {
-                    return getTypeOfPropertyOfContextualType(getTypeFromTypeNode(annotated2), nameStr);
-                  }
-                }
-                return void 0;
-              }
-            }
-            return isInJSFile(decl2) || decl2 === binaryExpression.left ? void 0 : getTypeOfExpression(binaryExpression.left);
-          }
-        case 1 /* ExportsProperty */:
-        case 6 /* Prototype */:
-        case 3 /* PrototypeProperty */:
-        case 2 /* ModuleExports */:
-          let valueDeclaration;
-          if (kind !== 2 /* ModuleExports */) {
-            valueDeclaration = canHaveSymbol(binaryExpression.left) ? (_a = binaryExpression.left.symbol) == null ? void 0 : _a.valueDeclaration : void 0;
-          }
-          valueDeclaration || (valueDeclaration = (_b = binaryExpression.symbol) == null ? void 0 : _b.valueDeclaration);
-          const annotated = valueDeclaration && getEffectiveTypeAnnotationNode(valueDeclaration);
-          return annotated ? getTypeFromTypeNode(annotated) : void 0;
-        case 7 /* ObjectDefinePropertyValue */:
-        case 8 /* ObjectDefinePropertyExports */:
-        case 9 /* ObjectDefinePrototypeProperty */:
-          return Debug.fail("Does not apply");
-        default:
-          return Debug.assertNever(kind);
-      }
-    }
-    function isPossiblyAliasedThisProperty(declaration, kind = getAssignmentDeclarationKind(declaration)) {
-      if (kind === 4 /* ThisProperty */) {
-        return true;
-      }
-      if (!isInJSFile(declaration) || kind !== 5 /* Property */ || !isIdentifier(declaration.left.expression)) {
-        return false;
-      }
-      const name = declaration.left.expression.escapedText;
-      const symbol = resolveName(
-        declaration.left,
-        name,
-        111551 /* Value */,
-        /*nameNotFoundMessage*/
-        void 0,
-        /*nameArg*/
-        void 0,
-        /*isUse*/
-        true,
-        /*excludeGlobals*/
-        true
-      );
-      return isThisInitializedDeclaration(symbol == null ? void 0 : symbol.valueDeclaration);
-    }
-    function getContextualTypeForThisPropertyAssignment(binaryExpression) {
-      if (!binaryExpression.symbol)
-        return getTypeOfExpression(binaryExpression.left);
-      if (binaryExpression.symbol.valueDeclaration) {
-        const annotated = getEffectiveTypeAnnotationNode(binaryExpression.symbol.valueDeclaration);
-        if (annotated) {
-          const type = getTypeFromTypeNode(annotated);
-          if (type) {
-            return type;
-          }
-        }
-      }
-      const thisAccess = cast(binaryExpression.left, isAccessExpression);
-      if (!isObjectLiteralMethod(getThisContainer(
-        thisAccess.expression,
-        /*includeArrowFunctions*/
-        false,
-        /*includeClassComputedPropertyName*/
-        false
-      ))) {
-        return void 0;
-      }
-      const thisType = checkThisExpression(thisAccess.expression);
-      const nameStr = getElementOrPropertyAccessName(thisAccess);
-      return nameStr !== void 0 && getTypeOfPropertyOfContextualType(thisType, nameStr) || void 0;
-    }
-    function isCircularMappedProperty(symbol) {
-      return !!(getCheckFlags(symbol) & 262144 /* Mapped */ && !symbol.links.type && findResolutionCycleStartIndex(symbol, 0 /* Type */) >= 0);
-    }
-    function getTypeOfPropertyOfContextualType(type, name, nameType) {
-      return mapType(
-        type,
-        (t) => {
-          var _a;
-          if (isGenericMappedType(t) && !t.declaration.nameType) {
-            const constraint = getConstraintTypeFromMappedType(t);
-            const constraintOfConstraint = getBaseConstraintOfType(constraint) || constraint;
-            const propertyNameType = nameType || getStringLiteralType(unescapeLeadingUnderscores(name));
-            if (isTypeAssignableTo(propertyNameType, constraintOfConstraint)) {
-              return substituteIndexedMappedType(t, propertyNameType);
-            }
-          } else if (t.flags & 3670016 /* StructuredType */) {
-            const prop = getPropertyOfType(t, name);
-            if (prop) {
-              return isCircularMappedProperty(prop) ? void 0 : getTypeOfSymbol(prop);
-            }
-            if (isTupleType(t) && isNumericLiteralName(name) && +name >= 0) {
-              const restType = getElementTypeOfSliceOfTupleType(
-                t,
-                t.target.fixedLength,
-                /*endSkipCount*/
-                0,
-                /*writing*/
-                false,
-                /*noReductions*/
-                true
-              );
-              if (restType) {
-                return restType;
-              }
-            }
-            return (_a = findApplicableIndexInfo(getIndexInfosOfStructuredType(t), nameType || getStringLiteralType(unescapeLeadingUnderscores(name)))) == null ? void 0 : _a.type;
-          }
-          return void 0;
-        },
-        /*noReductions*/
-        true
-      );
-    }
-    function getContextualTypeForObjectLiteralMethod(node, contextFlags) {
-      Debug.assert(isObjectLiteralMethod(node));
-      if (node.flags & 33554432 /* InWithStatement */) {
-        return void 0;
-      }
-      return getContextualTypeForObjectLiteralElement(node, contextFlags);
-    }
-    function getContextualTypeForObjectLiteralElement(element, contextFlags) {
-      const objectLiteral = element.parent;
-      const propertyAssignmentType = isPropertyAssignment(element) && getContextualTypeForVariableLikeDeclaration(element, contextFlags);
-      if (propertyAssignmentType) {
-        return propertyAssignmentType;
-      }
-      const type = getApparentTypeOfContextualType(objectLiteral, contextFlags);
-      if (type) {
-        if (hasBindableName(element)) {
-          const symbol = getSymbolOfDeclaration(element);
-          return getTypeOfPropertyOfContextualType(type, symbol.escapedName, getSymbolLinks(symbol).nameType);
-        }
-        if (hasDynamicName(element)) {
-          const name = getNameOfDeclaration(element);
-          if (name && isComputedPropertyName(name)) {
-            const exprType = checkExpression(name.expression);
-            const propType = isTypeUsableAsPropertyName(exprType) && getTypeOfPropertyOfContextualType(type, getPropertyNameFromType(exprType));
-            if (propType) {
-              return propType;
-            }
-          }
-        }
-        if (element.name) {
-          const nameType = getLiteralTypeFromPropertyName(element.name);
-          return mapType(
-            type,
-            (t) => {
-              var _a;
-              return (_a = findApplicableIndexInfo(getIndexInfosOfStructuredType(t), nameType)) == null ? void 0 : _a.type;
-            },
-            /*noReductions*/
-            true
-          );
-        }
-      }
-      return void 0;
-    }
-    function getSpreadIndices(elements) {
-      let first2, last2;
-      for (let i = 0; i < elements.length; i++) {
-        if (isSpreadElement(elements[i])) {
-          first2 ?? (first2 = i);
-          last2 = i;
-        }
-      }
-      return { first: first2, last: last2 };
-    }
-    function getContextualTypeForElementExpression(type, index, length2, firstSpreadIndex, lastSpreadIndex) {
-      return type && mapType(
-        type,
-        (t) => {
-          if (isTupleType(t)) {
-            if ((firstSpreadIndex === void 0 || index < firstSpreadIndex) && index < t.target.fixedLength) {
-              return getTypeArguments(t)[index];
-            }
-            const offset = length2 !== void 0 && (lastSpreadIndex === void 0 || index > lastSpreadIndex) ? length2 - index : 0;
-            const fixedEndLength = offset > 0 && t.target.hasRestElement ? getEndElementCount(t.target, 3 /* Fixed */) : 0;
-            if (offset > 0 && offset <= fixedEndLength) {
-              return getTypeArguments(t)[getTypeReferenceArity(t) - offset];
-            }
-            return getElementTypeOfSliceOfTupleType(
-              t,
-              firstSpreadIndex === void 0 ? t.target.fixedLength : Math.min(t.target.fixedLength, firstSpreadIndex),
-              length2 === void 0 || lastSpreadIndex === void 0 ? fixedEndLength : Math.min(fixedEndLength, length2 - lastSpreadIndex),
-              /*writing*/
-              false,
-              /*noReductions*/
-              true
-            );
-          }
-          return (!firstSpreadIndex || index < firstSpreadIndex) && getTypeOfPropertyOfContextualType(t, "" + index) || getIteratedTypeOrElementType(
-            1 /* Element */,
-            t,
-            undefinedType,
-            /*errorNode*/
-            void 0,
-            /*checkAssignability*/
-            false
-          );
-        },
-        /*noReductions*/
-        true
-      );
-    }
-    function getContextualTypeForConditionalOperand(node, contextFlags) {
-      const conditional = node.parent;
-      return node === conditional.whenTrue || node === conditional.whenFalse ? getContextualType2(conditional, contextFlags) : void 0;
-    }
-    function getContextualTypeForChildJsxExpression(node, child, contextFlags) {
-      const attributesType = getApparentTypeOfContextualType(node.openingElement.attributes, contextFlags);
-      const jsxChildrenPropertyName = getJsxElementChildrenPropertyName(getJsxNamespaceAt(node));
-      if (!(attributesType && !isTypeAny(attributesType) && jsxChildrenPropertyName && jsxChildrenPropertyName !== "")) {
-        return void 0;
-      }
-      const realChildren = getSemanticJsxChildren(node.children);
-      const childIndex = realChildren.indexOf(child);
-      const childFieldType = getTypeOfPropertyOfContextualType(attributesType, jsxChildrenPropertyName);
-      return childFieldType && (realChildren.length === 1 ? childFieldType : mapType(
-        childFieldType,
-        (t) => {
-          if (isArrayLikeType(t)) {
-            return getIndexedAccessType(t, getNumberLiteralType(childIndex));
-          } else {
-            return t;
-          }
-        },
-        /*noReductions*/
-        true
-      ));
-    }
-    function getContextualTypeForJsxExpression(node, contextFlags) {
-      const exprParent = node.parent;
-      return isJsxAttributeLike(exprParent) ? getContextualType2(node, contextFlags) : isJsxElement(exprParent) ? getContextualTypeForChildJsxExpression(exprParent, node, contextFlags) : void 0;
-    }
-    function getContextualTypeForJsxAttribute(attribute, contextFlags) {
-      if (isJsxAttribute(attribute)) {
-        const attributesType = getApparentTypeOfContextualType(attribute.parent, contextFlags);
-        if (!attributesType || isTypeAny(attributesType)) {
-          return void 0;
-        }
-        return getTypeOfPropertyOfContextualType(attributesType, getEscapedTextOfJsxAttributeName(attribute.name));
-      } else {
-        return getContextualType2(attribute.parent, contextFlags);
-      }
-    }
-    function isPossiblyDiscriminantValue(node) {
-      switch (node.kind) {
-        case 11 /* StringLiteral */:
-        case 9 /* NumericLiteral */:
-        case 10 /* BigIntLiteral */:
-        case 15 /* NoSubstitutionTemplateLiteral */:
-        case 112 /* TrueKeyword */:
-        case 97 /* FalseKeyword */:
-        case 106 /* NullKeyword */:
-        case 80 /* Identifier */:
-        case 157 /* UndefinedKeyword */:
-          return true;
-        case 210 /* PropertyAccessExpression */:
-        case 216 /* ParenthesizedExpression */:
-          return isPossiblyDiscriminantValue(node.expression);
-        case 293 /* JsxExpression */:
-          return !node.expression || isPossiblyDiscriminantValue(node.expression);
-      }
-      return false;
-    }
-    function discriminateContextualTypeByObjectMembers(node, contextualType) {
-      return getMatchingUnionConstituentForObjectLiteral(contextualType, node) || discriminateTypeByDiscriminableItems(
-        contextualType,
-        concatenate(
-          map(
-            filter(node.properties, (p) => !!p.symbol && p.kind === 302 /* PropertyAssignment */ && isPossiblyDiscriminantValue(p.initializer) && isDiscriminantProperty(contextualType, p.symbol.escapedName)),
-            (prop) => [() => getContextFreeTypeOfExpression(prop.initializer), prop.symbol.escapedName]
-          ),
-          map(
-            filter(getPropertiesOfType(contextualType), (s) => {
-              var _a;
-              return !!(s.flags & 16777216 /* Optional */) && !!((_a = node == null ? void 0 : node.symbol) == null ? void 0 : _a.members) && !node.symbol.members.has(s.escapedName) && isDiscriminantProperty(contextualType, s.escapedName);
-            }),
-            (s) => [() => undefinedType, s.escapedName]
-          )
-        ),
-        isTypeAssignableTo
-      );
-    }
-    function discriminateContextualTypeByJSXAttributes(node, contextualType) {
-      const jsxChildrenPropertyName = getJsxElementChildrenPropertyName(getJsxNamespaceAt(node));
-      return discriminateTypeByDiscriminableItems(
-        contextualType,
-        concatenate(
-          map(
-            filter(node.properties, (p) => !!p.symbol && p.kind === 290 /* JsxAttribute */ && isDiscriminantProperty(contextualType, p.symbol.escapedName) && (!p.initializer || isPossiblyDiscriminantValue(p.initializer))),
-            (prop) => [!prop.initializer ? () => trueType : () => getContextFreeTypeOfExpression(prop.initializer), prop.symbol.escapedName]
-          ),
-          map(
-            filter(getPropertiesOfType(contextualType), (s) => {
-              var _a;
-              if (!(s.flags & 16777216 /* Optional */) || !((_a = node == null ? void 0 : node.symbol) == null ? void 0 : _a.members)) {
-                return false;
-              }
-              const element = node.parent.parent;
-              if (s.escapedName === jsxChildrenPropertyName && isJsxElement(element) && getSemanticJsxChildren(element.children).length) {
-                return false;
-              }
-              return !node.symbol.members.has(s.escapedName) && isDiscriminantProperty(contextualType, s.escapedName);
-            }),
-            (s) => [() => undefinedType, s.escapedName]
-          )
-        ),
-        isTypeAssignableTo
-      );
-    }
-    function getApparentTypeOfContextualType(node, contextFlags) {
-      const contextualType = isObjectLiteralMethod(node) ? getContextualTypeForObjectLiteralMethod(node, contextFlags) : getContextualType2(node, contextFlags);
-      const instantiatedType = instantiateContextualType(contextualType, node, contextFlags);
-      if (instantiatedType && !(contextFlags && contextFlags & 2 /* NoConstraints */ && instantiatedType.flags & 8650752 /* TypeVariable */)) {
-        const apparentType = mapType(
-          instantiatedType,
-          // When obtaining apparent type of *contextual* type we don't want to get apparent type of mapped types.
-          // That would evaluate mapped types with array or tuple type constraints too eagerly
-          // and thus it would prevent `getTypeOfPropertyOfContextualType` from obtaining per-position contextual type for elements of array literal expressions.
-          // Apparent type of other mapped types is already the mapped type itself so we can just avoid calling `getApparentType` here for all mapped types.
-          (t) => getObjectFlags(t) & 32 /* Mapped */ ? t : getApparentType(t),
-          /*noReductions*/
-          true
-        );
-        return apparentType.flags & 1048576 /* Union */ && isObjectLiteralExpression(node) ? discriminateContextualTypeByObjectMembers(node, apparentType) : apparentType.flags & 1048576 /* Union */ && isJsxAttributes(node) ? discriminateContextualTypeByJSXAttributes(node, apparentType) : apparentType;
-      }
-    }
-    function instantiateContextualType(contextualType, node, contextFlags) {
-      if (contextualType && maybeTypeOfKind(contextualType, 465829888 /* Instantiable */)) {
-        const inferenceContext = getInferenceContext(node);
-        if (inferenceContext && contextFlags & 1 /* Signature */ && some(inferenceContext.inferences, hasInferenceCandidatesOrDefault)) {
-          return instantiateInstantiableTypes(contextualType, inferenceContext.nonFixingMapper);
-        }
-        if (inferenceContext == null ? void 0 : inferenceContext.returnMapper) {
-          const type = instantiateInstantiableTypes(contextualType, inferenceContext.returnMapper);
-          return type.flags & 1048576 /* Union */ && containsType(type.types, regularFalseType) && containsType(type.types, regularTrueType) ? filterType(type, (t) => t !== regularFalseType && t !== regularTrueType) : type;
-        }
-      }
-      return contextualType;
-    }
-    function instantiateInstantiableTypes(type, mapper) {
-      if (type.flags & 465829888 /* Instantiable */) {
-        return instantiateType(type, mapper);
-      }
-      if (type.flags & 1048576 /* Union */) {
-        return getUnionType(map(type.types, (t) => instantiateInstantiableTypes(t, mapper)), 0 /* None */);
-      }
-      if (type.flags & 2097152 /* Intersection */) {
-        return getIntersectionType(map(type.types, (t) => instantiateInstantiableTypes(t, mapper)));
-      }
-      return type;
-    }
-    function getContextualType2(node, contextFlags) {
-      var _a;
-      if (node.flags & 33554432 /* InWithStatement */) {
-        return void 0;
-      }
-      const index = findContextualNode(
-        node,
-        /*includeCaches*/
-        !contextFlags
-      );
-      if (index >= 0) {
-        return contextualTypes[index];
-      }
-      const { parent: parent2 } = node;
-      switch (parent2.kind) {
-        case 259 /* VariableDeclaration */:
-        case 168 /* Parameter */:
-        case 171 /* PropertyDeclaration */:
-        case 170 /* PropertySignature */:
-        case 207 /* BindingElement */:
-          return getContextualTypeForInitializerExpression(node, contextFlags);
-        case 218 /* ArrowFunction */:
-        case 252 /* ReturnStatement */:
-          return getContextualTypeForReturnExpression(node, contextFlags);
-        case 228 /* YieldExpression */:
-          return getContextualTypeForYieldOperand(parent2, contextFlags);
-        case 222 /* AwaitExpression */:
-          return getContextualTypeForAwaitOperand(parent2, contextFlags);
-        case 212 /* CallExpression */:
-        case 213 /* NewExpression */:
-          return getContextualTypeForArgument(parent2, node);
-        case 169 /* Decorator */:
-          return getContextualTypeForDecorator(parent2);
-        case 215 /* TypeAssertionExpression */:
-        case 233 /* AsExpression */:
-          return isConstTypeReference(parent2.type) ? getContextualType2(parent2, contextFlags) : getTypeFromTypeNode(parent2.type);
-        case 225 /* BinaryExpression */:
-          return getContextualTypeForBinaryOperand(node, contextFlags);
-        case 302 /* PropertyAssignment */:
-        case 303 /* ShorthandPropertyAssignment */:
-          return getContextualTypeForObjectLiteralElement(parent2, contextFlags);
-        case 304 /* SpreadAssignment */:
-          return getContextualType2(parent2.parent, contextFlags);
-        case 208 /* ArrayLiteralExpression */: {
-          const arrayLiteral = parent2;
-          const type = getApparentTypeOfContextualType(arrayLiteral, contextFlags);
-          const elementIndex = indexOfNode(arrayLiteral.elements, node);
-          const spreadIndices = (_a = getNodeLinks(arrayLiteral)).spreadIndices ?? (_a.spreadIndices = getSpreadIndices(arrayLiteral.elements));
-          return getContextualTypeForElementExpression(type, elementIndex, arrayLiteral.elements.length, spreadIndices.first, spreadIndices.last);
-        }
-        case 226 /* ConditionalExpression */:
-          return getContextualTypeForConditionalOperand(node, contextFlags);
-        case 238 /* TemplateSpan */:
-          Debug.assert(parent2.parent.kind === 227 /* TemplateExpression */);
-          return getContextualTypeForSubstitutionExpression(parent2.parent, node);
-        case 216 /* ParenthesizedExpression */: {
-          if (isInJSFile(parent2)) {
-            if (isJSDocSatisfiesExpression(parent2)) {
-              return getTypeFromTypeNode(getJSDocSatisfiesExpressionType(parent2));
-            }
-            const typeTag = getJSDocTypeTag(parent2);
-            if (typeTag && !isConstTypeReference(typeTag.typeExpression.type)) {
-              return getTypeFromTypeNode(typeTag.typeExpression.type);
-            }
-          }
-          return getContextualType2(parent2, contextFlags);
-        }
-        case 234 /* NonNullExpression */:
-          return getContextualType2(parent2, contextFlags);
-        case 237 /* SatisfiesExpression */:
-          return getTypeFromTypeNode(parent2.type);
-        case 276 /* ExportAssignment */:
-          return tryGetTypeFromEffectiveTypeNode(parent2);
-        case 293 /* JsxExpression */:
-          return getContextualTypeForJsxExpression(parent2, contextFlags);
-        case 290 /* JsxAttribute */:
-        case 292 /* JsxSpreadAttribute */:
-          return getContextualTypeForJsxAttribute(parent2, contextFlags);
-        case 285 /* JsxOpeningElement */:
-        case 284 /* JsxSelfClosingElement */:
-          return getContextualJsxElementAttributesType(parent2, contextFlags);
-      }
-      return void 0;
-    }
-    function pushCachedContextualType(node) {
-      pushContextualType(
-        node,
-        getContextualType2(
-          node,
-          /*contextFlags*/
-          void 0
-        ),
-        /*isCache*/
-        true
-      );
-    }
-    function pushContextualType(node, type, isCache) {
-      contextualTypeNodes[contextualTypeCount] = node;
-      contextualTypes[contextualTypeCount] = type;
-      contextualIsCache[contextualTypeCount] = isCache;
-      contextualTypeCount++;
-    }
-    function popContextualType() {
-      contextualTypeCount--;
-    }
-    function findContextualNode(node, includeCaches) {
-      for (let i = contextualTypeCount - 1; i >= 0; i--) {
-        if (node === contextualTypeNodes[i] && (includeCaches || !contextualIsCache[i])) {
-          return i;
-        }
-      }
-      return -1;
-    }
-    function pushInferenceContext(node, inferenceContext) {
-      inferenceContextNodes[inferenceContextCount] = node;
-      inferenceContexts[inferenceContextCount] = inferenceContext;
-      inferenceContextCount++;
-    }
-    function popInferenceContext() {
-      inferenceContextCount--;
-    }
-    function getInferenceContext(node) {
-      for (let i = inferenceContextCount - 1; i >= 0; i--) {
-        if (isNodeDescendantOf(node, inferenceContextNodes[i])) {
-          return inferenceContexts[i];
-        }
-      }
-    }
-    function getContextualJsxElementAttributesType(node, contextFlags) {
-      if (isJsxOpeningElement(node) && contextFlags !== 4 /* Completions */) {
-        const index = findContextualNode(
-          node.parent,
-          /*includeCaches*/
-          !contextFlags
-        );
-        if (index >= 0) {
-          return contextualTypes[index];
-        }
-      }
-      return getContextualTypeForArgumentAtIndex(node, 0);
-    }
-    function getEffectiveFirstArgumentForJsxSignature(signature, node) {
-      return getJsxReferenceKind(node) !== 0 /* Component */ ? getJsxPropsTypeFromCallSignature(signature, node) : getJsxPropsTypeFromClassType(signature, node);
-    }
-    function getJsxPropsTypeFromCallSignature(sig, context) {
-      let propsType = getTypeOfFirstParameterOfSignatureWithFallback(sig, unknownType);
-      propsType = getJsxManagedAttributesFromLocatedAttributes(context, getJsxNamespaceAt(context), propsType);
-      const intrinsicAttribs = getJsxType(JsxNames.IntrinsicAttributes, context);
-      if (!isErrorType(intrinsicAttribs)) {
-        propsType = intersectTypes(intrinsicAttribs, propsType);
-      }
-      return propsType;
-    }
-    function getJsxPropsTypeForSignatureFromMember(sig, forcedLookupLocation) {
-      if (sig.compositeSignatures) {
-        const results = [];
-        for (const signature of sig.compositeSignatures) {
-          const instance = getReturnTypeOfSignature(signature);
-          if (isTypeAny(instance)) {
-            return instance;
-          }
-          const propType = getTypeOfPropertyOfType(instance, forcedLookupLocation);
-          if (!propType) {
-            return;
-          }
-          results.push(propType);
-        }
-        return getIntersectionType(results);
-      }
-      const instanceType = getReturnTypeOfSignature(sig);
-      return isTypeAny(instanceType) ? instanceType : getTypeOfPropertyOfType(instanceType, forcedLookupLocation);
-    }
-    function getStaticTypeOfReferencedJsxConstructor(context) {
-      if (isJsxIntrinsicTagName(context.tagName)) {
-        const result = getIntrinsicAttributesTypeFromJsxOpeningLikeElement(context);
-        const fakeSignature = createSignatureForJSXIntrinsic(context, result);
-        return getOrCreateTypeFromSignature(fakeSignature);
-      }
-      const tagType = checkExpressionCached(context.tagName);
-      if (tagType.flags & 128 /* StringLiteral */) {
-        const result = getIntrinsicAttributesTypeFromStringLiteralType(tagType, context);
-        if (!result) {
-          return errorType;
-        }
-        const fakeSignature = createSignatureForJSXIntrinsic(context, result);
-        return getOrCreateTypeFromSignature(fakeSignature);
-      }
-      return tagType;
-    }
-    function getJsxManagedAttributesFromLocatedAttributes(context, ns, attributesType) {
-      const managedSym = getJsxLibraryManagedAttributes(ns);
-      if (managedSym) {
-        const ctorType = getStaticTypeOfReferencedJsxConstructor(context);
-        const result = instantiateAliasOrInterfaceWithDefaults(managedSym, isInJSFile(context), ctorType, attributesType);
-        if (result) {
-          return result;
-        }
-      }
-      return attributesType;
-    }
-    function getJsxPropsTypeFromClassType(sig, context) {
-      const ns = getJsxNamespaceAt(context);
-      const forcedLookupLocation = getJsxElementPropertiesName(ns);
-      let attributesType = forcedLookupLocation === void 0 ? getTypeOfFirstParameterOfSignatureWithFallback(sig, unknownType) : forcedLookupLocation === "" ? getReturnTypeOfSignature(sig) : getJsxPropsTypeForSignatureFromMember(sig, forcedLookupLocation);
-      if (!attributesType) {
-        if (!!forcedLookupLocation && !!length(context.attributes.properties)) {
-          error(context, Diagnostics.JSX_element_class_does_not_support_attributes_because_it_does_not_have_a_0_property, unescapeLeadingUnderscores(forcedLookupLocation));
-        }
-        return unknownType;
-      }
-      attributesType = getJsxManagedAttributesFromLocatedAttributes(context, ns, attributesType);
-      if (isTypeAny(attributesType)) {
-        return attributesType;
-      } else {
-        let apparentAttributesType = attributesType;
-        const intrinsicClassAttribs = getJsxType(JsxNames.IntrinsicClassAttributes, context);
-        if (!isErrorType(intrinsicClassAttribs)) {
-          const typeParams = getLocalTypeParametersOfClassOrInterfaceOrTypeAlias(intrinsicClassAttribs.symbol);
-          const hostClassType = getReturnTypeOfSignature(sig);
-          let libraryManagedAttributeType;
-          if (typeParams) {
-            const inferredArgs = fillMissingTypeArguments([hostClassType], typeParams, getMinTypeArgumentCount(typeParams), isInJSFile(context));
-            libraryManagedAttributeType = instantiateType(intrinsicClassAttribs, createTypeMapper(typeParams, inferredArgs));
-          } else
-            libraryManagedAttributeType = intrinsicClassAttribs;
-          apparentAttributesType = intersectTypes(libraryManagedAttributeType, apparentAttributesType);
-        }
-        const intrinsicAttribs = getJsxType(JsxNames.IntrinsicAttributes, context);
-        if (!isErrorType(intrinsicAttribs)) {
-          apparentAttributesType = intersectTypes(intrinsicAttribs, apparentAttributesType);
-        }
-        return apparentAttributesType;
-      }
-    }
-    function getIntersectedSignatures(signatures) {
-      return getStrictOptionValue(compilerOptions, "noImplicitAny") ? reduceLeft(
-        signatures,
-        (left, right) => left === right || !left ? left : compareTypeParametersIdentical(left.typeParameters, right.typeParameters) ? combineSignaturesOfIntersectionMembers(left, right) : void 0
-      ) : void 0;
-    }
-    function combineIntersectionThisParam(left, right, mapper) {
-      if (!left || !right) {
-        return left || right;
-      }
-      const thisType = getUnionType([getTypeOfSymbol(left), instantiateType(getTypeOfSymbol(right), mapper)]);
-      return createSymbolWithType(left, thisType);
-    }
-    function combineIntersectionParameters(left, right, mapper) {
-      const leftCount = getParameterCount(left);
-      const rightCount = getParameterCount(right);
-      const longest = leftCount >= rightCount ? left : right;
-      const shorter = longest === left ? right : left;
-      const longestCount = longest === left ? leftCount : rightCount;
-      const eitherHasEffectiveRest = hasEffectiveRestParameter(left) || hasEffectiveRestParameter(right);
-      const needsExtraRestElement = eitherHasEffectiveRest && !hasEffectiveRestParameter(longest);
-      const params = new Array(longestCount + (needsExtraRestElement ? 1 : 0));
-      for (let i = 0; i < longestCount; i++) {
-        let longestParamType = tryGetTypeAtPosition(longest, i);
-        if (longest === right) {
-          longestParamType = instantiateType(longestParamType, mapper);
-        }
-        let shorterParamType = tryGetTypeAtPosition(shorter, i) || unknownType;
-        if (shorter === right) {
-          shorterParamType = instantiateType(shorterParamType, mapper);
-        }
-        const unionParamType = getUnionType([longestParamType, shorterParamType]);
-        const isRestParam = eitherHasEffectiveRest && !needsExtraRestElement && i === longestCount - 1;
-        const isOptional = i >= getMinArgumentCount(longest) && i >= getMinArgumentCount(shorter);
-        const leftName = i >= leftCount ? void 0 : getParameterNameAtPosition(left, i);
-        const rightName = i >= rightCount ? void 0 : getParameterNameAtPosition(right, i);
-        const paramName = leftName === rightName ? leftName : !leftName ? rightName : !rightName ? leftName : void 0;
-        const paramSymbol = createSymbol(
-          1 /* FunctionScopedVariable */ | (isOptional && !isRestParam ? 16777216 /* Optional */ : 0),
-          paramName || `arg${i}`
-        );
-        paramSymbol.links.type = isRestParam ? createArrayType(unionParamType) : unionParamType;
-        params[i] = paramSymbol;
-      }
-      if (needsExtraRestElement) {
-        const restParamSymbol = createSymbol(1 /* FunctionScopedVariable */, "args");
-        restParamSymbol.links.type = createArrayType(getTypeAtPosition(shorter, longestCount));
-        if (shorter === right) {
-          restParamSymbol.links.type = instantiateType(restParamSymbol.links.type, mapper);
-        }
-        params[longestCount] = restParamSymbol;
-      }
-      return params;
-    }
-    function combineSignaturesOfIntersectionMembers(left, right) {
-      const typeParams = left.typeParameters || right.typeParameters;
-      let paramMapper;
-      if (left.typeParameters && right.typeParameters) {
-        paramMapper = createTypeMapper(right.typeParameters, left.typeParameters);
-      }
-      const declaration = left.declaration;
-      const params = combineIntersectionParameters(left, right, paramMapper);
-      const thisParam = combineIntersectionThisParam(left.thisParameter, right.thisParameter, paramMapper);
-      const minArgCount = Math.max(left.minArgumentCount, right.minArgumentCount);
-      const result = createSignature(
-        declaration,
-        typeParams,
-        thisParam,
-        params,
-        /*resolvedReturnType*/
-        void 0,
-        /*resolvedTypePredicate*/
-        void 0,
-        minArgCount,
-        (left.flags | right.flags) & 39 /* PropagatingFlags */
-      );
-      result.compositeKind = 2097152 /* Intersection */;
-      result.compositeSignatures = concatenate(left.compositeKind === 2097152 /* Intersection */ && left.compositeSignatures || [left], [right]);
-      if (paramMapper) {
-        result.mapper = left.compositeKind === 2097152 /* Intersection */ && left.mapper && left.compositeSignatures ? combineTypeMappers(left.mapper, paramMapper) : paramMapper;
-      }
-      return result;
-    }
-    function getContextualCallSignature(type, node) {
-      const signatures = getSignaturesOfType(type, 0 /* Call */);
-      const applicableByArity = filter(signatures, (s) => !isAritySmaller(s, node));
-      return applicableByArity.length === 1 ? applicableByArity[0] : getIntersectedSignatures(applicableByArity);
-    }
-    function isAritySmaller(signature, target) {
-      let targetParameterCount = 0;
-      for (; targetParameterCount < target.parameters.length; targetParameterCount++) {
-        const param = target.parameters[targetParameterCount];
-        if (param.initializer || param.questionToken || param.dotDotDotToken || isJSDocOptionalParameter(param)) {
-          break;
-        }
-      }
-      if (target.parameters.length && parameterIsThisKeyword(target.parameters[0])) {
-        targetParameterCount--;
-      }
-      return !hasEffectiveRestParameter(signature) && getParameterCount(signature) < targetParameterCount;
-    }
-    function getContextualSignatureForFunctionLikeDeclaration(node) {
-      return isFunctionExpressionOrArrowFunction(node) || isObjectLiteralMethod(node) ? getContextualSignature(node) : void 0;
-    }
-    function getContextualSignature(node) {
-      Debug.assert(node.kind !== 173 /* MethodDeclaration */ || isObjectLiteralMethod(node));
-      const typeTagSignature = getSignatureOfTypeTag(node);
-      if (typeTagSignature) {
-        return typeTagSignature;
-      }
-      const type = getApparentTypeOfContextualType(node, 1 /* Signature */);
-      if (!type) {
-        return void 0;
-      }
-      if (!(type.flags & 1048576 /* Union */)) {
-        return getContextualCallSignature(type, node);
-      }
-      let signatureList;
-      const types = type.types;
-      for (const current of types) {
-        const signature = getContextualCallSignature(current, node);
-        if (signature) {
-          if (!signatureList) {
-            signatureList = [signature];
-          } else if (!compareSignaturesIdentical(
-            signatureList[0],
-            signature,
-            /*partialMatch*/
-            false,
-            /*ignoreThisTypes*/
-            true,
-            /*ignoreReturnTypes*/
-            true,
-            compareTypesIdentical
-          )) {
-            return void 0;
-          } else {
-            signatureList.push(signature);
-          }
-        }
-      }
-      if (signatureList) {
-        return signatureList.length === 1 ? signatureList[0] : createUnionSignature(signatureList[0], signatureList);
-      }
-    }
-    function checkSpreadExpression(node, checkMode) {
-      if (languageVersion < 2 /* ES2015 */) {
-        checkExternalEmitHelpers(node, compilerOptions.downlevelIteration ? 1536 /* SpreadIncludes */ : 1024 /* SpreadArray */);
-      }
-      const arrayOrIterableType = checkExpression(node.expression, checkMode);
-      return checkIteratedTypeOrElementType(33 /* Spread */, arrayOrIterableType, undefinedType, node.expression);
-    }
-    function checkSyntheticExpression(node) {
-      return node.isSpread ? getIndexedAccessType(node.type, numberType) : node.type;
-    }
-    function hasDefaultValue(node) {
-      return node.kind === 207 /* BindingElement */ && !!node.initializer || node.kind === 225 /* BinaryExpression */ && node.operatorToken.kind === 64 /* EqualsToken */;
-    }
-    function checkArrayLiteral(node, checkMode, forceTuple) {
-      const elements = node.elements;
-      const elementCount = elements.length;
-      const elementTypes = [];
-      const elementFlags = [];
-      pushCachedContextualType(node);
-      const inDestructuringPattern = isAssignmentTarget(node);
-      const isSpreadIntoCallOrNew = isSpreadElement(node.parent) && isCallOrNewExpression(node.parent.parent);
-      const inConstContext = isSpreadIntoCallOrNew || isConstContext(node);
-      const contextualType = getApparentTypeOfContextualType(
-        node,
-        /*contextFlags*/
-        void 0
-      );
-      const inTupleContext = isSpreadIntoCallOrNew || !!contextualType && someType(contextualType, isTupleLikeType);
-      let hasOmittedExpression = false;
-      for (let i = 0; i < elementCount; i++) {
-        const e = elements[i];
-        if (e.kind === 229 /* SpreadElement */) {
-          if (languageVersion < 2 /* ES2015 */) {
-            checkExternalEmitHelpers(e, compilerOptions.downlevelIteration ? 1536 /* SpreadIncludes */ : 1024 /* SpreadArray */);
-          }
-          const spreadType = checkExpression(e.expression, checkMode, forceTuple);
-          if (isArrayLikeType(spreadType)) {
-            elementTypes.push(spreadType);
-            elementFlags.push(8 /* Variadic */);
-          } else if (inDestructuringPattern) {
-            const restElementType = getIndexTypeOfType(spreadType, numberType) || getIteratedTypeOrElementType(
-              65 /* Destructuring */,
-              spreadType,
-              undefinedType,
-              /*errorNode*/
-              void 0,
-              /*checkAssignability*/
-              false
-            ) || unknownType;
-            elementTypes.push(restElementType);
-            elementFlags.push(4 /* Rest */);
-          } else {
-            elementTypes.push(checkIteratedTypeOrElementType(33 /* Spread */, spreadType, undefinedType, e.expression));
-            elementFlags.push(4 /* Rest */);
-          }
-        } else if (exactOptionalPropertyTypes && e.kind === 231 /* OmittedExpression */) {
-          hasOmittedExpression = true;
-          elementTypes.push(undefinedOrMissingType);
-          elementFlags.push(2 /* Optional */);
-        } else {
-          const type = checkExpressionForMutableLocation(e, checkMode, forceTuple);
-          elementTypes.push(addOptionality(
-            type,
-            /*isProperty*/
-            true,
-            hasOmittedExpression
-          ));
-          elementFlags.push(hasOmittedExpression ? 2 /* Optional */ : 1 /* Required */);
-          if (inTupleContext && checkMode && checkMode & 2 /* Inferential */ && !(checkMode & 4 /* SkipContextSensitive */) && isContextSensitive(e)) {
-            const inferenceContext = getInferenceContext(node);
-            Debug.assert(inferenceContext);
-            addIntraExpressionInferenceSite(inferenceContext, e, type);
-          }
-        }
-      }
-      popContextualType();
-      if (inDestructuringPattern) {
-        return createTupleType(elementTypes, elementFlags);
-      }
-      if (forceTuple || inConstContext || inTupleContext) {
-        return createArrayLiteralType(createTupleType(
-          elementTypes,
-          elementFlags,
-          /*readonly*/
-          inConstContext
-        ));
-      }
-      return createArrayLiteralType(createArrayType(elementTypes.length ? getUnionType(sameMap(elementTypes, (t, i) => elementFlags[i] & 8 /* Variadic */ ? getIndexedAccessTypeOrUndefined(t, numberType) || anyType : t), 2 /* Subtype */) : strictNullChecks ? implicitNeverType : undefinedWideningType, inConstContext));
-    }
-    function createArrayLiteralType(type) {
-      if (!(getObjectFlags(type) & 4 /* Reference */)) {
-        return type;
-      }
-      let literalType = type.literalType;
-      if (!literalType) {
-        literalType = type.literalType = cloneTypeReference(type);
-        literalType.objectFlags |= 16384 /* ArrayLiteral */ | 131072 /* ContainsObjectOrArrayLiteral */;
-      }
-      return literalType;
-    }
-    function isNumericName(name) {
-      switch (name.kind) {
-        case 166 /* ComputedPropertyName */:
-          return isNumericComputedName(name);
-        case 80 /* Identifier */:
-          return isNumericLiteralName(name.escapedText);
-        case 9 /* NumericLiteral */:
-        case 11 /* StringLiteral */:
-          return isNumericLiteralName(name.text);
-        default:
-          return false;
-      }
-    }
-    function isNumericComputedName(name) {
-      return isTypeAssignableToKind(checkComputedPropertyName(name), 296 /* NumberLike */);
-    }
-    function checkComputedPropertyName(node) {
-      const links = getNodeLinks(node.expression);
-      if (!links.resolvedType) {
-        if ((isTypeLiteralNode(node.parent.parent) || isClassLike(node.parent.parent) || isInterfaceDeclaration(node.parent.parent)) && isBinaryExpression(node.expression) && node.expression.operatorToken.kind === 103 /* InKeyword */ && node.parent.kind !== 176 /* GetAccessor */ && node.parent.kind !== 177 /* SetAccessor */) {
-          return links.resolvedType = errorType;
-        }
-        links.resolvedType = checkExpression(node.expression);
-        if (isPropertyDeclaration(node.parent) && !hasStaticModifier(node.parent) && isClassExpression(node.parent.parent)) {
-          const container = getEnclosingBlockScopeContainer(node.parent.parent);
-          const enclosingIterationStatement = getEnclosingIterationStatement(container);
-          if (enclosingIterationStatement) {
-            getNodeLinks(enclosingIterationStatement).flags |= 4096 /* LoopWithCapturedBlockScopedBinding */;
-            getNodeLinks(node).flags |= 32768 /* BlockScopedBindingInLoop */;
-            getNodeLinks(node.parent.parent).flags |= 32768 /* BlockScopedBindingInLoop */;
-          }
-        }
-        if (links.resolvedType.flags & 98304 /* Nullable */ || !isTypeAssignableToKind(links.resolvedType, 402653316 /* StringLike */ | 296 /* NumberLike */ | 12288 /* ESSymbolLike */) && !isTypeAssignableTo(links.resolvedType, stringNumberSymbolType)) {
-          error(node, Diagnostics.A_computed_property_name_must_be_of_type_string_number_symbol_or_any);
-        }
-      }
-      return links.resolvedType;
-    }
-    function isSymbolWithNumericName(symbol) {
-      var _a;
-      const firstDecl = (_a = symbol.declarations) == null ? void 0 : _a[0];
-      return isNumericLiteralName(symbol.escapedName) || firstDecl && isNamedDeclaration(firstDecl) && isNumericName(firstDecl.name);
-    }
-    function isSymbolWithSymbolName(symbol) {
-      var _a;
-      const firstDecl = (_a = symbol.declarations) == null ? void 0 : _a[0];
-      return isKnownSymbol(symbol) || firstDecl && isNamedDeclaration(firstDecl) && isComputedPropertyName(firstDecl.name) && isTypeAssignableToKind(checkComputedPropertyName(firstDecl.name), 4096 /* ESSymbol */);
-    }
-    function getObjectLiteralIndexInfo(node, offset, properties, keyType) {
-      const propTypes = [];
-      for (let i = offset; i < properties.length; i++) {
-        const prop = properties[i];
-        if (keyType === stringType && !isSymbolWithSymbolName(prop) || keyType === numberType && isSymbolWithNumericName(prop) || keyType === esSymbolType && isSymbolWithSymbolName(prop)) {
-          propTypes.push(getTypeOfSymbol(properties[i]));
-        }
-      }
-      const unionType = propTypes.length ? getUnionType(propTypes, 2 /* Subtype */) : undefinedType;
-      return createIndexInfo(keyType, unionType, isConstContext(node));
-    }
-    function getImmediateAliasedSymbol(symbol) {
-      Debug.assert((symbol.flags & 2097152 /* Alias */) !== 0, "Should only get Alias here.");
-      const links = getSymbolLinks(symbol);
-      if (!links.immediateTarget) {
-        const node = getDeclarationOfAliasSymbol(symbol);
-        if (!node)
-          return Debug.fail();
-        links.immediateTarget = getTargetOfAliasDeclaration(
-          node,
-          /*dontRecursivelyResolve*/
-          true
-        );
-      }
-      return links.immediateTarget;
-    }
-    function checkObjectLiteral(node, checkMode = 0 /* Normal */) {
-      var _a;
-      const inDestructuringPattern = isAssignmentTarget(node);
-      checkGrammarObjectLiteralExpression(node, inDestructuringPattern);
-      const allPropertiesTable = strictNullChecks ? createSymbolTable() : void 0;
-      let propertiesTable = createSymbolTable();
-      let propertiesArray = [];
-      let spread = emptyObjectType;
-      pushCachedContextualType(node);
-      const contextualType = getApparentTypeOfContextualType(
-        node,
-        /*contextFlags*/
-        void 0
-      );
-      const contextualTypeHasPattern = contextualType && contextualType.pattern && (contextualType.pattern.kind === 205 /* ObjectBindingPattern */ || contextualType.pattern.kind === 209 /* ObjectLiteralExpression */);
-      const inConstContext = isConstContext(node);
-      const checkFlags = inConstContext ? 8 /* Readonly */ : 0;
-      const isInJavascript = isInJSFile(node) && !isInJsonFile(node);
-      const enumTag = isInJavascript ? getJSDocEnumTag(node) : void 0;
-      const isJSObjectLiteral = !contextualType && isInJavascript && !enumTag;
-      let objectFlags = freshObjectLiteralFlag;
-      let patternWithComputedProperties = false;
-      let hasComputedStringProperty = false;
-      let hasComputedNumberProperty = false;
-      let hasComputedSymbolProperty = false;
-      for (const elem of node.properties) {
-        if (elem.name && isComputedPropertyName(elem.name)) {
-          checkComputedPropertyName(elem.name);
-        }
-      }
-      let offset = 0;
-      for (const memberDecl of node.properties) {
-        let member = getSymbolOfDeclaration(memberDecl);
-        const computedNameType = memberDecl.name && memberDecl.name.kind === 166 /* ComputedPropertyName */ ? checkComputedPropertyName(memberDecl.name) : void 0;
-        if (memberDecl.kind === 302 /* PropertyAssignment */ || memberDecl.kind === 303 /* ShorthandPropertyAssignment */ || isObjectLiteralMethod(memberDecl)) {
-          let type = memberDecl.kind === 302 /* PropertyAssignment */ ? checkPropertyAssignment(memberDecl, checkMode) : (
-            // avoid resolving the left side of the ShorthandPropertyAssignment outside of the destructuring
-            // for error recovery purposes. For example, if a user wrote `{ a = 100 }` instead of `{ a: 100 }`.
-            // we don't want to say "could not find 'a'".
-            memberDecl.kind === 303 /* ShorthandPropertyAssignment */ ? checkExpressionForMutableLocation(!inDestructuringPattern && memberDecl.objectAssignmentInitializer ? memberDecl.objectAssignmentInitializer : memberDecl.name, checkMode) : checkObjectLiteralMethod(memberDecl, checkMode)
-          );
-          if (isInJavascript) {
-            const jsDocType = getTypeForDeclarationFromJSDocComment(memberDecl);
-            if (jsDocType) {
-              checkTypeAssignableTo(type, jsDocType, memberDecl);
-              type = jsDocType;
-            } else if (enumTag && enumTag.typeExpression) {
-              checkTypeAssignableTo(type, getTypeFromTypeNode(enumTag.typeExpression), memberDecl);
-            }
-          }
-          objectFlags |= getObjectFlags(type) & 458752 /* PropagatingFlags */;
-          const nameType = computedNameType && isTypeUsableAsPropertyName(computedNameType) ? computedNameType : void 0;
-          const prop = nameType ? createSymbol(4 /* Property */ | member.flags, getPropertyNameFromType(nameType), checkFlags | 4096 /* Late */) : createSymbol(4 /* Property */ | member.flags, member.escapedName, checkFlags);
-          if (nameType) {
-            prop.links.nameType = nameType;
-          }
-          if (inDestructuringPattern) {
-            const isOptional = memberDecl.kind === 302 /* PropertyAssignment */ && hasDefaultValue(memberDecl.initializer) || memberDecl.kind === 303 /* ShorthandPropertyAssignment */ && memberDecl.objectAssignmentInitializer;
-            if (isOptional) {
-              prop.flags |= 16777216 /* Optional */;
-            }
-          } else if (contextualTypeHasPattern && !(getObjectFlags(contextualType) & 512 /* ObjectLiteralPatternWithComputedProperties */)) {
-            const impliedProp = getPropertyOfType(contextualType, member.escapedName);
-            if (impliedProp) {
-              prop.flags |= impliedProp.flags & 16777216 /* Optional */;
-            } else if (!compilerOptions.suppressExcessPropertyErrors && !getIndexInfoOfType(contextualType, stringType)) {
-              error(
-                memberDecl.name,
-                Diagnostics.Object_literal_may_only_specify_known_properties_and_0_does_not_exist_in_type_1,
-                symbolToString(member),
-                typeToString(contextualType)
-              );
-            }
-          }
-          prop.declarations = member.declarations;
-          prop.parent = member.parent;
-          if (member.valueDeclaration) {
-            prop.valueDeclaration = member.valueDeclaration;
-          }
-          prop.links.type = type;
-          prop.links.target = member;
-          member = prop;
-          allPropertiesTable == null ? void 0 : allPropertiesTable.set(prop.escapedName, prop);
-          if (contextualType && checkMode & 2 /* Inferential */ && !(checkMode & 4 /* SkipContextSensitive */) && (memberDecl.kind === 302 /* PropertyAssignment */ || memberDecl.kind === 173 /* MethodDeclaration */) && isContextSensitive(memberDecl)) {
-            const inferenceContext = getInferenceContext(node);
-            Debug.assert(inferenceContext);
-            const inferenceNode = memberDecl.kind === 302 /* PropertyAssignment */ ? memberDecl.initializer : memberDecl;
-            addIntraExpressionInferenceSite(inferenceContext, inferenceNode, type);
-          }
-        } else if (memberDecl.kind === 304 /* SpreadAssignment */) {
-          if (languageVersion < 2 /* ES2015 */) {
-            checkExternalEmitHelpers(memberDecl, 2 /* Assign */);
-          }
-          if (propertiesArray.length > 0) {
-            spread = getSpreadType(spread, createObjectLiteralType(), node.symbol, objectFlags, inConstContext);
-            propertiesArray = [];
-            propertiesTable = createSymbolTable();
-            hasComputedStringProperty = false;
-            hasComputedNumberProperty = false;
-            hasComputedSymbolProperty = false;
-          }
-          const type = getReducedType(checkExpression(memberDecl.expression, checkMode & 2 /* Inferential */));
-          if (isValidSpreadType(type)) {
-            const mergedType = tryMergeUnionOfObjectTypeAndEmptyObject(type, inConstContext);
-            if (allPropertiesTable) {
-              checkSpreadPropOverrides(mergedType, allPropertiesTable, memberDecl);
-            }
-            offset = propertiesArray.length;
-            if (isErrorType(spread)) {
-              continue;
-            }
-            spread = getSpreadType(spread, mergedType, node.symbol, objectFlags, inConstContext);
-          } else {
-            error(memberDecl, Diagnostics.Spread_types_may_only_be_created_from_object_types);
-            spread = errorType;
-          }
-          continue;
-        } else {
-          Debug.assert(memberDecl.kind === 176 /* GetAccessor */ || memberDecl.kind === 177 /* SetAccessor */);
-          checkNodeDeferred(memberDecl);
-        }
-        if (computedNameType && !(computedNameType.flags & 8576 /* StringOrNumberLiteralOrUnique */)) {
-          if (isTypeAssignableTo(computedNameType, stringNumberSymbolType)) {
-            if (isTypeAssignableTo(computedNameType, numberType)) {
-              hasComputedNumberProperty = true;
-            } else if (isTypeAssignableTo(computedNameType, esSymbolType)) {
-              hasComputedSymbolProperty = true;
-            } else {
-              hasComputedStringProperty = true;
-            }
-            if (inDestructuringPattern) {
-              patternWithComputedProperties = true;
-            }
-          }
-        } else {
-          propertiesTable.set(member.escapedName, member);
-        }
-        propertiesArray.push(member);
-      }
-      popContextualType();
-      if (contextualTypeHasPattern) {
-        const rootPatternParent = findAncestor(
-          contextualType.pattern.parent,
-          (n) => n.kind === 259 /* VariableDeclaration */ || n.kind === 225 /* BinaryExpression */ || n.kind === 168 /* Parameter */
-        );
-        const spreadOrOutsideRootObject = findAncestor(
-          node,
-          (n) => n === rootPatternParent || n.kind === 304 /* SpreadAssignment */
-        );
-        if (spreadOrOutsideRootObject.kind !== 304 /* SpreadAssignment */) {
-          for (const prop of getPropertiesOfType(contextualType)) {
-            if (!propertiesTable.get(prop.escapedName) && !getPropertyOfType(spread, prop.escapedName)) {
-              if (!(prop.flags & 16777216 /* Optional */)) {
-                error(
-                  prop.valueDeclaration || ((_a = tryCast(prop, isTransientSymbol)) == null ? void 0 : _a.links.bindingElement),
-                  Diagnostics.Initializer_provides_no_value_for_this_binding_element_and_the_binding_element_has_no_default_value
-                );
-              }
-              propertiesTable.set(prop.escapedName, prop);
-              propertiesArray.push(prop);
-            }
-          }
-        }
-      }
-      if (isErrorType(spread)) {
-        return errorType;
-      }
-      if (spread !== emptyObjectType) {
-        if (propertiesArray.length > 0) {
-          spread = getSpreadType(spread, createObjectLiteralType(), node.symbol, objectFlags, inConstContext);
-          propertiesArray = [];
-          propertiesTable = createSymbolTable();
-          hasComputedStringProperty = false;
-          hasComputedNumberProperty = false;
-        }
-        return mapType(spread, (t) => t === emptyObjectType ? createObjectLiteralType() : t);
-      }
-      return createObjectLiteralType();
-      function createObjectLiteralType() {
-        const indexInfos = [];
-        if (hasComputedStringProperty)
-          indexInfos.push(getObjectLiteralIndexInfo(node, offset, propertiesArray, stringType));
-        if (hasComputedNumberProperty)
-          indexInfos.push(getObjectLiteralIndexInfo(node, offset, propertiesArray, numberType));
-        if (hasComputedSymbolProperty)
-          indexInfos.push(getObjectLiteralIndexInfo(node, offset, propertiesArray, esSymbolType));
-        const result = createAnonymousType(node.symbol, propertiesTable, emptyArray, emptyArray, indexInfos);
-        result.objectFlags |= objectFlags | 128 /* ObjectLiteral */ | 131072 /* ContainsObjectOrArrayLiteral */;
-        if (isJSObjectLiteral) {
-          result.objectFlags |= 4096 /* JSLiteral */;
-        }
-        if (patternWithComputedProperties) {
-          result.objectFlags |= 512 /* ObjectLiteralPatternWithComputedProperties */;
-        }
-        if (inDestructuringPattern) {
-          result.pattern = node;
-        }
-        return result;
-      }
-    }
-    function isValidSpreadType(type) {
-      const t = removeDefinitelyFalsyTypes(mapType(type, getBaseConstraintOrType));
-      return !!(t.flags & (1 /* Any */ | 67108864 /* NonPrimitive */ | 524288 /* Object */ | 58982400 /* InstantiableNonPrimitive */) || t.flags & 3145728 /* UnionOrIntersection */ && every(t.types, isValidSpreadType));
-    }
-    function checkJsxSelfClosingElementDeferred(node) {
-      checkJsxOpeningLikeElementOrOpeningFragment(node);
-    }
-    function checkJsxSelfClosingElement(node, _checkMode) {
-      checkNodeDeferred(node);
-      return getJsxElementTypeAt(node) || anyType;
-    }
-    function checkJsxElementDeferred(node) {
-      checkJsxOpeningLikeElementOrOpeningFragment(node.openingElement);
-      if (isJsxIntrinsicTagName(node.closingElement.tagName)) {
-        getIntrinsicTagSymbol(node.closingElement);
-      } else {
-        checkExpression(node.closingElement.tagName);
-      }
-      checkJsxChildren(node);
-    }
-    function checkJsxElement(node, _checkMode) {
-      checkNodeDeferred(node);
-      return getJsxElementTypeAt(node) || anyType;
-    }
-    function checkJsxFragment(node) {
-      checkJsxOpeningLikeElementOrOpeningFragment(node.openingFragment);
-      const nodeSourceFile = getSourceFileOfNode(node);
-      if (getJSXTransformEnabled(compilerOptions) && (compilerOptions.jsxFactory || nodeSourceFile.pragmas.has("jsx")) && !compilerOptions.jsxFragmentFactory && !nodeSourceFile.pragmas.has("jsxfrag")) {
-        error(node, compilerOptions.jsxFactory ? Diagnostics.The_jsxFragmentFactory_compiler_option_must_be_provided_to_use_JSX_fragments_with_the_jsxFactory_compiler_option : Diagnostics.An_jsxFrag_pragma_is_required_when_using_an_jsx_pragma_with_JSX_fragments);
-      }
-      checkJsxChildren(node);
-      return getJsxElementTypeAt(node) || anyType;
-    }
-    function isHyphenatedJsxName(name) {
-      return stringContains(name, "-");
-    }
-    function isJsxIntrinsicTagName(tagName) {
-      return isIdentifier(tagName) && isIntrinsicJsxName(tagName.escapedText) || isJsxNamespacedName(tagName);
-    }
-    function checkJsxAttribute(node, checkMode) {
-      return node.initializer ? checkExpressionForMutableLocation(node.initializer, checkMode) : trueType;
-    }
-    function createJsxAttributesTypeFromAttributesProperty(openingLikeElement, checkMode = 0 /* Normal */) {
-      const attributes = openingLikeElement.attributes;
-      const contextualType = getContextualType2(attributes, 0 /* None */);
-      const allAttributesTable = strictNullChecks ? createSymbolTable() : void 0;
-      let attributesTable = createSymbolTable();
-      let spread = emptyJsxObjectType;
-      let hasSpreadAnyType = false;
-      let typeToIntersect;
-      let explicitlySpecifyChildrenAttribute = false;
-      let objectFlags = 2048 /* JsxAttributes */;
-      const jsxChildrenPropertyName = getJsxElementChildrenPropertyName(getJsxNamespaceAt(openingLikeElement));
-      for (const attributeDecl of attributes.properties) {
-        const member = attributeDecl.symbol;
-        if (isJsxAttribute(attributeDecl)) {
-          const exprType = checkJsxAttribute(attributeDecl, checkMode);
-          objectFlags |= getObjectFlags(exprType) & 458752 /* PropagatingFlags */;
-          const attributeSymbol = createSymbol(4 /* Property */ | member.flags, member.escapedName);
-          attributeSymbol.declarations = member.declarations;
-          attributeSymbol.parent = member.parent;
-          if (member.valueDeclaration) {
-            attributeSymbol.valueDeclaration = member.valueDeclaration;
-          }
-          attributeSymbol.links.type = exprType;
-          attributeSymbol.links.target = member;
-          attributesTable.set(attributeSymbol.escapedName, attributeSymbol);
-          allAttributesTable == null ? void 0 : allAttributesTable.set(attributeSymbol.escapedName, attributeSymbol);
-          if (getEscapedTextOfJsxAttributeName(attributeDecl.name) === jsxChildrenPropertyName) {
-            explicitlySpecifyChildrenAttribute = true;
-          }
-          if (contextualType) {
-            const prop = getPropertyOfType(contextualType, member.escapedName);
-            if (prop && prop.declarations && isDeprecatedSymbol(prop) && isIdentifier(attributeDecl.name)) {
-              addDeprecatedSuggestion(attributeDecl.name, prop.declarations, attributeDecl.name.escapedText);
-            }
-          }
-          if (contextualType && checkMode & 2 /* Inferential */ && !(checkMode & 4 /* SkipContextSensitive */) && isContextSensitive(attributeDecl)) {
-            const inferenceContext = getInferenceContext(attributes);
-            Debug.assert(inferenceContext);
-            const inferenceNode = attributeDecl.initializer.expression;
-            addIntraExpressionInferenceSite(inferenceContext, inferenceNode, exprType);
-          }
-        } else {
-          Debug.assert(attributeDecl.kind === 292 /* JsxSpreadAttribute */);
-          if (attributesTable.size > 0) {
-            spread = getSpreadType(
-              spread,
-              createJsxAttributesType(),
-              attributes.symbol,
-              objectFlags,
-              /*readonly*/
-              false
-            );
-            attributesTable = createSymbolTable();
-          }
-          const exprType = getReducedType(checkExpression(attributeDecl.expression, checkMode & 2 /* Inferential */));
-          if (isTypeAny(exprType)) {
-            hasSpreadAnyType = true;
-          }
-          if (isValidSpreadType(exprType)) {
-            spread = getSpreadType(
-              spread,
-              exprType,
-              attributes.symbol,
-              objectFlags,
-              /*readonly*/
-              false
-            );
-            if (allAttributesTable) {
-              checkSpreadPropOverrides(exprType, allAttributesTable, attributeDecl);
-            }
-          } else {
-            error(attributeDecl.expression, Diagnostics.Spread_types_may_only_be_created_from_object_types);
-            typeToIntersect = typeToIntersect ? getIntersectionType([typeToIntersect, exprType]) : exprType;
-          }
-        }
-      }
-      if (!hasSpreadAnyType) {
-        if (attributesTable.size > 0) {
-          spread = getSpreadType(
-            spread,
-            createJsxAttributesType(),
-            attributes.symbol,
-            objectFlags,
-            /*readonly*/
-            false
-          );
-        }
-      }
-      const parent2 = openingLikeElement.parent.kind === 283 /* JsxElement */ ? openingLikeElement.parent : void 0;
-      if (parent2 && parent2.openingElement === openingLikeElement && parent2.children.length > 0) {
-        const childrenTypes = checkJsxChildren(parent2, checkMode);
-        if (!hasSpreadAnyType && jsxChildrenPropertyName && jsxChildrenPropertyName !== "") {
-          if (explicitlySpecifyChildrenAttribute) {
-            error(attributes, Diagnostics._0_are_specified_twice_The_attribute_named_0_will_be_overwritten, unescapeLeadingUnderscores(jsxChildrenPropertyName));
-          }
-          const contextualType2 = getApparentTypeOfContextualType(
-            openingLikeElement.attributes,
-            /*contextFlags*/
-            void 0
-          );
-          const childrenContextualType = contextualType2 && getTypeOfPropertyOfContextualType(contextualType2, jsxChildrenPropertyName);
-          const childrenPropSymbol = createSymbol(4 /* Property */, jsxChildrenPropertyName);
-          childrenPropSymbol.links.type = childrenTypes.length === 1 ? childrenTypes[0] : childrenContextualType && someType(childrenContextualType, isTupleLikeType) ? createTupleType(childrenTypes) : createArrayType(getUnionType(childrenTypes));
-          childrenPropSymbol.valueDeclaration = factory.createPropertySignature(
-            /*modifiers*/
-            void 0,
-            unescapeLeadingUnderscores(jsxChildrenPropertyName),
-            /*questionToken*/
-            void 0,
-            /*type*/
-            void 0
-          );
-          setParent(childrenPropSymbol.valueDeclaration, attributes);
-          childrenPropSymbol.valueDeclaration.symbol = childrenPropSymbol;
-          const childPropMap = createSymbolTable();
-          childPropMap.set(jsxChildrenPropertyName, childrenPropSymbol);
-          spread = getSpreadType(
-            spread,
-            createAnonymousType(attributes.symbol, childPropMap, emptyArray, emptyArray, emptyArray),
-            attributes.symbol,
-            objectFlags,
-            /*readonly*/
-            false
-          );
-        }
-      }
-      if (hasSpreadAnyType) {
-        return anyType;
-      }
-      if (typeToIntersect && spread !== emptyJsxObjectType) {
-        return getIntersectionType([typeToIntersect, spread]);
-      }
-      return typeToIntersect || (spread === emptyJsxObjectType ? createJsxAttributesType() : spread);
-      function createJsxAttributesType() {
-        objectFlags |= freshObjectLiteralFlag;
-        const result = createAnonymousType(attributes.symbol, attributesTable, emptyArray, emptyArray, emptyArray);
-        result.objectFlags |= objectFlags | 128 /* ObjectLiteral */ | 131072 /* ContainsObjectOrArrayLiteral */;
-        return result;
-      }
-    }
-    function checkJsxChildren(node, checkMode) {
-      const childrenTypes = [];
-      for (const child of node.children) {
-        if (child.kind === 12 /* JsxText */) {
-          if (!child.containsOnlyTriviaWhiteSpaces) {
-            childrenTypes.push(stringType);
-          }
-        } else if (child.kind === 293 /* JsxExpression */ && !child.expression) {
-          continue;
-        } else {
-          childrenTypes.push(checkExpressionForMutableLocation(child, checkMode));
-        }
-      }
-      return childrenTypes;
-    }
-    function checkSpreadPropOverrides(type, props, spread) {
-      for (const right of getPropertiesOfType(type)) {
-        if (!(right.flags & 16777216 /* Optional */)) {
-          const left = props.get(right.escapedName);
-          if (left) {
-            const diagnostic = error(left.valueDeclaration, Diagnostics._0_is_specified_more_than_once_so_this_usage_will_be_overwritten, unescapeLeadingUnderscores(left.escapedName));
-            addRelatedInfo(diagnostic, createDiagnosticForNode(spread, Diagnostics.This_spread_always_overwrites_this_property));
-          }
-        }
-      }
-    }
-    function checkJsxAttributes(node, checkMode) {
-      return createJsxAttributesTypeFromAttributesProperty(node.parent, checkMode);
-    }
-    function getJsxType(name, location) {
-      const namespace = getJsxNamespaceAt(location);
-      const exports = namespace && getExportsOfSymbol(namespace);
-      const typeSymbol = exports && getSymbol2(exports, name, 788968 /* Type */);
-      return typeSymbol ? getDeclaredTypeOfSymbol(typeSymbol) : errorType;
-    }
-    function getIntrinsicTagSymbol(node) {
-      const links = getNodeLinks(node);
-      if (!links.resolvedSymbol) {
-        const intrinsicElementsType = getJsxType(JsxNames.IntrinsicElements, node);
-        if (!isErrorType(intrinsicElementsType)) {
-          if (!isIdentifier(node.tagName) && !isJsxNamespacedName(node.tagName))
-            return Debug.fail();
-          const intrinsicProp = getPropertyOfType(intrinsicElementsType, isJsxNamespacedName(node.tagName) ? getEscapedTextOfJsxNamespacedName(node.tagName) : node.tagName.escapedText);
-          if (intrinsicProp) {
-            links.jsxFlags |= 1 /* IntrinsicNamedElement */;
-            return links.resolvedSymbol = intrinsicProp;
-          }
-          const indexSignatureType = getIndexTypeOfType(intrinsicElementsType, stringType);
-          if (indexSignatureType) {
-            links.jsxFlags |= 2 /* IntrinsicIndexedElement */;
-            return links.resolvedSymbol = intrinsicElementsType.symbol;
-          }
-          error(node, Diagnostics.Property_0_does_not_exist_on_type_1, intrinsicTagNameToString(node.tagName), "JSX." + JsxNames.IntrinsicElements);
-          return links.resolvedSymbol = unknownSymbol;
-        } else {
-          if (noImplicitAny) {
-            error(node, Diagnostics.JSX_element_implicitly_has_type_any_because_no_interface_JSX_0_exists, unescapeLeadingUnderscores(JsxNames.IntrinsicElements));
-          }
-          return links.resolvedSymbol = unknownSymbol;
-        }
-      }
-      return links.resolvedSymbol;
-    }
-    function getJsxNamespaceContainerForImplicitImport(location) {
-      const file = location && getSourceFileOfNode(location);
-      const links = file && getNodeLinks(file);
-      if (links && links.jsxImplicitImportContainer === false) {
-        return void 0;
-      }
-      if (links && links.jsxImplicitImportContainer) {
-        return links.jsxImplicitImportContainer;
-      }
-      const runtimeImportSpecifier = getJSXRuntimeImport(getJSXImplicitImportBase(compilerOptions, file), compilerOptions);
-      if (!runtimeImportSpecifier) {
-        return void 0;
-      }
-      const isClassic = getEmitModuleResolutionKind(compilerOptions) === 1 /* Classic */;
-      const errorMessage = isClassic ? Diagnostics.Cannot_find_module_0_Did_you_mean_to_set_the_moduleResolution_option_to_nodenext_or_to_add_aliases_to_the_paths_option : Diagnostics.Cannot_find_module_0_or_its_corresponding_type_declarations;
-      const mod = resolveExternalModule(location, runtimeImportSpecifier, errorMessage, location);
-      const result = mod && mod !== unknownSymbol ? getMergedSymbol(resolveSymbol(mod)) : void 0;
-      if (links) {
-        links.jsxImplicitImportContainer = result || false;
-      }
-      return result;
-    }
-    function getJsxNamespaceAt(location) {
-      const links = location && getNodeLinks(location);
-      if (links && links.jsxNamespace) {
-        return links.jsxNamespace;
-      }
-      if (!links || links.jsxNamespace !== false) {
-        let resolvedNamespace = getJsxNamespaceContainerForImplicitImport(location);
-        if (!resolvedNamespace || resolvedNamespace === unknownSymbol) {
-          const namespaceName = getJsxNamespace(location);
-          resolvedNamespace = resolveName(
-            location,
-            namespaceName,
-            1920 /* Namespace */,
-            /*nameNotFoundMessage*/
-            void 0,
-            namespaceName,
-            /*isUse*/
-            false
-          );
-        }
-        if (resolvedNamespace) {
-          const candidate = resolveSymbol(getSymbol2(getExportsOfSymbol(resolveSymbol(resolvedNamespace)), JsxNames.JSX, 1920 /* Namespace */));
-          if (candidate && candidate !== unknownSymbol) {
-            if (links) {
-              links.jsxNamespace = candidate;
-            }
-            return candidate;
-          }
-        }
-        if (links) {
-          links.jsxNamespace = false;
-        }
-      }
-      const s = resolveSymbol(getGlobalSymbol(
-        JsxNames.JSX,
-        1920 /* Namespace */,
-        /*diagnostic*/
-        void 0
-      ));
-      if (s === unknownSymbol) {
-        return void 0;
-      }
-      return s;
-    }
-    function getNameFromJsxElementAttributesContainer(nameOfAttribPropContainer, jsxNamespace) {
-      const jsxElementAttribPropInterfaceSym = jsxNamespace && getSymbol2(jsxNamespace.exports, nameOfAttribPropContainer, 788968 /* Type */);
-      const jsxElementAttribPropInterfaceType = jsxElementAttribPropInterfaceSym && getDeclaredTypeOfSymbol(jsxElementAttribPropInterfaceSym);
-      const propertiesOfJsxElementAttribPropInterface = jsxElementAttribPropInterfaceType && getPropertiesOfType(jsxElementAttribPropInterfaceType);
-      if (propertiesOfJsxElementAttribPropInterface) {
-        if (propertiesOfJsxElementAttribPropInterface.length === 0) {
-          return "";
-        } else if (propertiesOfJsxElementAttribPropInterface.length === 1) {
-          return propertiesOfJsxElementAttribPropInterface[0].escapedName;
-        } else if (propertiesOfJsxElementAttribPropInterface.length > 1 && jsxElementAttribPropInterfaceSym.declarations) {
-          error(jsxElementAttribPropInterfaceSym.declarations[0], Diagnostics.The_global_type_JSX_0_may_not_have_more_than_one_property, unescapeLeadingUnderscores(nameOfAttribPropContainer));
-        }
-      }
-      return void 0;
-    }
-    function getJsxLibraryManagedAttributes(jsxNamespace) {
-      return jsxNamespace && getSymbol2(jsxNamespace.exports, JsxNames.LibraryManagedAttributes, 788968 /* Type */);
-    }
-    function getJsxElementTypeSymbol(jsxNamespace) {
-      return jsxNamespace && getSymbol2(jsxNamespace.exports, JsxNames.ElementType, 788968 /* Type */);
-    }
-    function getJsxElementPropertiesName(jsxNamespace) {
-      return getNameFromJsxElementAttributesContainer(JsxNames.ElementAttributesPropertyNameContainer, jsxNamespace);
-    }
-    function getJsxElementChildrenPropertyName(jsxNamespace) {
-      return getNameFromJsxElementAttributesContainer(JsxNames.ElementChildrenAttributeNameContainer, jsxNamespace);
-    }
-    function getUninstantiatedJsxSignaturesOfType(elementType, caller) {
-      if (elementType.flags & 4 /* String */) {
-        return [anySignature];
-      } else if (elementType.flags & 128 /* StringLiteral */) {
-        const intrinsicType = getIntrinsicAttributesTypeFromStringLiteralType(elementType, caller);
-        if (!intrinsicType) {
-          error(caller, Diagnostics.Property_0_does_not_exist_on_type_1, elementType.value, "JSX." + JsxNames.IntrinsicElements);
-          return emptyArray;
-        } else {
-          const fakeSignature = createSignatureForJSXIntrinsic(caller, intrinsicType);
-          return [fakeSignature];
-        }
-      }
-      const apparentElemType = getApparentType(elementType);
-      let signatures = getSignaturesOfType(apparentElemType, 1 /* Construct */);
-      if (signatures.length === 0) {
-        signatures = getSignaturesOfType(apparentElemType, 0 /* Call */);
-      }
-      if (signatures.length === 0 && apparentElemType.flags & 1048576 /* Union */) {
-        signatures = getUnionSignatures(map(apparentElemType.types, (t) => getUninstantiatedJsxSignaturesOfType(t, caller)));
-      }
-      return signatures;
-    }
-    function getIntrinsicAttributesTypeFromStringLiteralType(type, location) {
-      const intrinsicElementsType = getJsxType(JsxNames.IntrinsicElements, location);
-      if (!isErrorType(intrinsicElementsType)) {
-        const stringLiteralTypeName = type.value;
-        const intrinsicProp = getPropertyOfType(intrinsicElementsType, escapeLeadingUnderscores(stringLiteralTypeName));
-        if (intrinsicProp) {
-          return getTypeOfSymbol(intrinsicProp);
-        }
-        const indexSignatureType = getIndexTypeOfType(intrinsicElementsType, stringType);
-        if (indexSignatureType) {
-          return indexSignatureType;
-        }
-        return void 0;
-      }
-      return anyType;
-    }
-    function checkJsxReturnAssignableToAppropriateBound(refKind, elemInstanceType, openingLikeElement) {
-      if (refKind === 1 /* Function */) {
-        const sfcReturnConstraint = getJsxStatelessElementTypeAt(openingLikeElement);
-        if (sfcReturnConstraint) {
-          checkTypeRelatedTo(elemInstanceType, sfcReturnConstraint, assignableRelation, openingLikeElement.tagName, Diagnostics.Its_return_type_0_is_not_a_valid_JSX_element, generateInitialErrorChain);
-        }
-      } else if (refKind === 0 /* Component */) {
-        const classConstraint = getJsxElementClassTypeAt(openingLikeElement);
-        if (classConstraint) {
-          checkTypeRelatedTo(elemInstanceType, classConstraint, assignableRelation, openingLikeElement.tagName, Diagnostics.Its_instance_type_0_is_not_a_valid_JSX_element, generateInitialErrorChain);
-        }
-      } else {
-        const sfcReturnConstraint = getJsxStatelessElementTypeAt(openingLikeElement);
-        const classConstraint = getJsxElementClassTypeAt(openingLikeElement);
-        if (!sfcReturnConstraint || !classConstraint) {
-          return;
-        }
-        const combined = getUnionType([sfcReturnConstraint, classConstraint]);
-        checkTypeRelatedTo(elemInstanceType, combined, assignableRelation, openingLikeElement.tagName, Diagnostics.Its_element_type_0_is_not_a_valid_JSX_element, generateInitialErrorChain);
-      }
-      function generateInitialErrorChain() {
-        const componentName = getTextOfNode(openingLikeElement.tagName);
-        return chainDiagnosticMessages(
-          /*details*/
-          void 0,
-          Diagnostics._0_cannot_be_used_as_a_JSX_component,
-          componentName
-        );
-      }
-    }
-    function getIntrinsicAttributesTypeFromJsxOpeningLikeElement(node) {
-      Debug.assert(isJsxIntrinsicTagName(node.tagName));
-      const links = getNodeLinks(node);
-      if (!links.resolvedJsxElementAttributesType) {
-        const symbol = getIntrinsicTagSymbol(node);
-        if (links.jsxFlags & 1 /* IntrinsicNamedElement */) {
-          return links.resolvedJsxElementAttributesType = getTypeOfSymbol(symbol) || errorType;
-        } else if (links.jsxFlags & 2 /* IntrinsicIndexedElement */) {
-          return links.resolvedJsxElementAttributesType = getIndexTypeOfType(getJsxType(JsxNames.IntrinsicElements, node), stringType) || errorType;
-        } else {
-          return links.resolvedJsxElementAttributesType = errorType;
-        }
-      }
-      return links.resolvedJsxElementAttributesType;
-    }
-    function getJsxElementClassTypeAt(location) {
-      const type = getJsxType(JsxNames.ElementClass, location);
-      if (isErrorType(type))
-        return void 0;
-      return type;
-    }
-    function getJsxElementTypeAt(location) {
-      return getJsxType(JsxNames.Element, location);
-    }
-    function getJsxStatelessElementTypeAt(location) {
-      const jsxElementType = getJsxElementTypeAt(location);
-      if (jsxElementType) {
-        return getUnionType([jsxElementType, nullType]);
-      }
-    }
-    function getJsxElementTypeTypeAt(location) {
-      const ns = getJsxNamespaceAt(location);
-      if (!ns)
-        return void 0;
-      const sym = getJsxElementTypeSymbol(ns);
-      if (!sym)
-        return void 0;
-      const type = instantiateAliasOrInterfaceWithDefaults(sym, isInJSFile(location));
-      if (!type || isErrorType(type))
-        return void 0;
-      return type;
-    }
-    function instantiateAliasOrInterfaceWithDefaults(managedSym, inJs, ...typeArguments) {
-      const declaredManagedType = getDeclaredTypeOfSymbol(managedSym);
-      if (managedSym.flags & 524288 /* TypeAlias */) {
-        const params = getSymbolLinks(managedSym).typeParameters;
-        if (length(params) >= typeArguments.length) {
-          const args = fillMissingTypeArguments(typeArguments, params, typeArguments.length, inJs);
-          return length(args) === 0 ? declaredManagedType : getTypeAliasInstantiation(managedSym, args);
-        }
-      }
-      if (length(declaredManagedType.typeParameters) >= typeArguments.length) {
-        const args = fillMissingTypeArguments(typeArguments, declaredManagedType.typeParameters, typeArguments.length, inJs);
-        return createTypeReference(declaredManagedType, args);
-      }
-      return void 0;
-    }
-    function getJsxIntrinsicTagNamesAt(location) {
-      const intrinsics = getJsxType(JsxNames.IntrinsicElements, location);
-      return intrinsics ? getPropertiesOfType(intrinsics) : emptyArray;
-    }
-    function checkJsxPreconditions(errorNode) {
-      if ((compilerOptions.jsx || 0 /* None */) === 0 /* None */) {
-        error(errorNode, Diagnostics.Cannot_use_JSX_unless_the_jsx_flag_is_provided);
-      }
-      if (getJsxElementTypeAt(errorNode) === void 0) {
-        if (noImplicitAny) {
-          error(errorNode, Diagnostics.JSX_element_implicitly_has_type_any_because_the_global_type_JSX_Element_does_not_exist);
-        }
-      }
-    }
-    function checkJsxOpeningLikeElementOrOpeningFragment(node) {
-      const isNodeOpeningLikeElement = isJsxOpeningLikeElement(node);
-      if (isNodeOpeningLikeElement) {
-        checkGrammarJsxElement(node);
-      }
-      checkJsxPreconditions(node);
-      if (!getJsxNamespaceContainerForImplicitImport(node)) {
-        const jsxFactoryRefErr = diagnostics && compilerOptions.jsx === 2 /* React */ ? Diagnostics.Cannot_find_name_0 : void 0;
-        const jsxFactoryNamespace = getJsxNamespace(node);
-        const jsxFactoryLocation = isNodeOpeningLikeElement ? node.tagName : node;
-        let jsxFactorySym;
-        if (!(isJsxOpeningFragment(node) && jsxFactoryNamespace === "null")) {
-          jsxFactorySym = resolveName(
-            jsxFactoryLocation,
-            jsxFactoryNamespace,
-            111551 /* Value */,
-            jsxFactoryRefErr,
-            jsxFactoryNamespace,
-            /*isUse*/
-            true
-          );
-        }
-        if (jsxFactorySym) {
-          jsxFactorySym.isReferenced = 67108863 /* All */;
-          if (canCollectSymbolAliasAccessabilityData && jsxFactorySym.flags & 2097152 /* Alias */ && !getTypeOnlyAliasDeclaration(jsxFactorySym)) {
-            markAliasSymbolAsReferenced(jsxFactorySym);
-          }
-        }
-        if (isJsxOpeningFragment(node)) {
-          const file = getSourceFileOfNode(node);
-          const localJsxNamespace = getLocalJsxNamespace(file);
-          if (localJsxNamespace) {
-            resolveName(
-              jsxFactoryLocation,
-              localJsxNamespace,
-              111551 /* Value */,
-              jsxFactoryRefErr,
-              localJsxNamespace,
-              /*isUse*/
-              true
-            );
-          }
-        }
-      }
-      if (isNodeOpeningLikeElement) {
-        const jsxOpeningLikeNode = node;
-        const sig = getResolvedSignature(jsxOpeningLikeNode);
-        checkDeprecatedSignature(sig, node);
-        const elementTypeConstraint = getJsxElementTypeTypeAt(jsxOpeningLikeNode);
-        if (elementTypeConstraint !== void 0) {
-          const tagName = jsxOpeningLikeNode.tagName;
-          const tagType = isJsxIntrinsicTagName(tagName) ? getStringLiteralType(intrinsicTagNameToString(tagName)) : checkExpression(tagName);
-          checkTypeRelatedTo(tagType, elementTypeConstraint, assignableRelation, tagName, Diagnostics.Its_type_0_is_not_a_valid_JSX_element_type, () => {
-            const componentName = getTextOfNode(tagName);
-            return chainDiagnosticMessages(
-              /*details*/
-              void 0,
-              Diagnostics._0_cannot_be_used_as_a_JSX_component,
-              componentName
-            );
-          });
-        } else {
-          checkJsxReturnAssignableToAppropriateBound(getJsxReferenceKind(jsxOpeningLikeNode), getReturnTypeOfSignature(sig), jsxOpeningLikeNode);
-        }
-      }
-    }
-    function isKnownProperty(targetType, name, isComparingJsxAttributes) {
-      if (targetType.flags & 524288 /* Object */) {
-        if (getPropertyOfObjectType(targetType, name) || getApplicableIndexInfoForName(targetType, name) || isLateBoundName(name) && getIndexInfoOfType(targetType, stringType) || isComparingJsxAttributes && isHyphenatedJsxName(name)) {
-          return true;
-        }
-      } else if (targetType.flags & 3145728 /* UnionOrIntersection */ && isExcessPropertyCheckTarget(targetType)) {
-        for (const t of targetType.types) {
-          if (isKnownProperty(t, name, isComparingJsxAttributes)) {
-            return true;
-          }
-        }
-      }
-      return false;
-    }
-    function isExcessPropertyCheckTarget(type) {
-      return !!(type.flags & 524288 /* Object */ && !(getObjectFlags(type) & 512 /* ObjectLiteralPatternWithComputedProperties */) || type.flags & 67108864 /* NonPrimitive */ || type.flags & 1048576 /* Union */ && some(type.types, isExcessPropertyCheckTarget) || type.flags & 2097152 /* Intersection */ && every(type.types, isExcessPropertyCheckTarget));
-    }
-    function checkJsxExpression(node, checkMode) {
-      checkGrammarJsxExpression(node);
-      if (node.expression) {
-        const type = checkExpression(node.expression, checkMode);
-        if (node.dotDotDotToken && type !== anyType && !isArrayType(type)) {
-          error(node, Diagnostics.JSX_spread_child_must_be_an_array_type);
-        }
-        return type;
-      } else {
-        return errorType;
-      }
-    }
-    function getDeclarationNodeFlagsFromSymbol(s) {
-      return s.valueDeclaration ? getCombinedNodeFlags(s.valueDeclaration) : 0;
-    }
-    function isPrototypeProperty(symbol) {
-      if (symbol.flags & 8192 /* Method */ || getCheckFlags(symbol) & 4 /* SyntheticMethod */) {
-        return true;
-      }
-      if (isInJSFile(symbol.valueDeclaration)) {
-        const parent2 = symbol.valueDeclaration.parent;
-        return parent2 && isBinaryExpression(parent2) && getAssignmentDeclarationKind(parent2) === 3 /* PrototypeProperty */;
-      }
-    }
-    function checkPropertyAccessibility(node, isSuper, writing, type, prop, reportError = true) {
-      const errorNode = !reportError ? void 0 : node.kind === 165 /* QualifiedName */ ? node.right : node.kind === 204 /* ImportType */ ? node : node.kind === 207 /* BindingElement */ && node.propertyName ? node.propertyName : node.name;
-      return checkPropertyAccessibilityAtLocation(node, isSuper, writing, type, prop, errorNode);
-    }
-    function checkPropertyAccessibilityAtLocation(location, isSuper, writing, containingType, prop, errorNode) {
-      const flags = getDeclarationModifierFlagsFromSymbol(prop, writing);
-      if (isSuper) {
-        if (languageVersion < 2 /* ES2015 */) {
-          if (symbolHasNonMethodDeclaration(prop)) {
-            if (errorNode) {
-              error(errorNode, Diagnostics.Only_public_and_protected_methods_of_the_base_class_are_accessible_via_the_super_keyword);
-            }
-            return false;
-          }
-        }
-        if (flags & 256 /* Abstract */) {
-          if (errorNode) {
-            error(
-              errorNode,
-              Diagnostics.Abstract_method_0_in_class_1_cannot_be_accessed_via_super_expression,
-              symbolToString(prop),
-              typeToString(getDeclaringClass(prop))
-            );
-          }
-          return false;
-        }
-      }
-      if (flags & 256 /* Abstract */ && symbolHasNonMethodDeclaration(prop) && (isThisProperty(location) || isThisInitializedObjectBindingExpression(location) || isObjectBindingPattern(location.parent) && isThisInitializedDeclaration(location.parent.parent))) {
-        const declaringClassDeclaration = getClassLikeDeclarationOfSymbol(getParentOfSymbol(prop));
-        if (declaringClassDeclaration && isNodeUsedDuringClassInitialization(location)) {
-          if (errorNode) {
-            error(
-              errorNode,
-              Diagnostics.Abstract_property_0_in_class_1_cannot_be_accessed_in_the_constructor,
-              symbolToString(prop),
-              getTextOfIdentifierOrLiteral(declaringClassDeclaration.name)
-            );
-          }
-          return false;
-        }
-      }
-      if (!(flags & 24 /* NonPublicAccessibilityModifier */)) {
-        return true;
-      }
-      if (flags & 8 /* Private */) {
-        const declaringClassDeclaration = getClassLikeDeclarationOfSymbol(getParentOfSymbol(prop));
-        if (!isNodeWithinClass(location, declaringClassDeclaration)) {
-          if (errorNode) {
-            error(
-              errorNode,
-              Diagnostics.Property_0_is_private_and_only_accessible_within_class_1,
-              symbolToString(prop),
-              typeToString(getDeclaringClass(prop))
-            );
-          }
-          return false;
-        }
-        return true;
-      }
-      if (isSuper) {
-        return true;
-      }
-      let enclosingClass = forEachEnclosingClass(location, (enclosingDeclaration) => {
-        const enclosingClass2 = getDeclaredTypeOfSymbol(getSymbolOfDeclaration(enclosingDeclaration));
-        return isClassDerivedFromDeclaringClasses(enclosingClass2, prop, writing);
-      });
-      if (!enclosingClass) {
-        enclosingClass = getEnclosingClassFromThisParameter(location);
-        enclosingClass = enclosingClass && isClassDerivedFromDeclaringClasses(enclosingClass, prop, writing);
-        if (flags & 32 /* Static */ || !enclosingClass) {
-          if (errorNode) {
-            error(
-              errorNode,
-              Diagnostics.Property_0_is_protected_and_only_accessible_within_class_1_and_its_subclasses,
-              symbolToString(prop),
-              typeToString(getDeclaringClass(prop) || containingType)
-            );
-          }
-          return false;
-        }
-      }
-      if (flags & 32 /* Static */) {
-        return true;
-      }
-      if (containingType.flags & 262144 /* TypeParameter */) {
-        containingType = containingType.isThisType ? getConstraintOfTypeParameter(containingType) : getBaseConstraintOfType(containingType);
-      }
-      if (!containingType || !hasBaseType(containingType, enclosingClass)) {
-        if (errorNode) {
-          error(
-            errorNode,
-            Diagnostics.Property_0_is_protected_and_only_accessible_through_an_instance_of_class_1_This_is_an_instance_of_class_2,
-            symbolToString(prop),
-            typeToString(enclosingClass),
-            typeToString(containingType)
-          );
-        }
-        return false;
-      }
-      return true;
-    }
-    function getEnclosingClassFromThisParameter(node) {
-      const thisParameter = getThisParameterFromNodeContext(node);
-      let thisType = (thisParameter == null ? void 0 : thisParameter.type) && getTypeFromTypeNode(thisParameter.type);
-      if (thisType && thisType.flags & 262144 /* TypeParameter */) {
-        thisType = getConstraintOfTypeParameter(thisType);
-      }
-      if (thisType && getObjectFlags(thisType) & (3 /* ClassOrInterface */ | 4 /* Reference */)) {
-        return getTargetType(thisType);
-      }
-      return void 0;
-    }
-    function getThisParameterFromNodeContext(node) {
-      const thisContainer = getThisContainer(
-        node,
-        /*includeArrowFunctions*/
-        false,
-        /*includeClassComputedPropertyName*/
-        false
-      );
-      return thisContainer && isFunctionLike(thisContainer) ? getThisParameter(thisContainer) : void 0;
-    }
-    function symbolHasNonMethodDeclaration(symbol) {
-      return !!forEachProperty2(symbol, (prop) => !(prop.flags & 8192 /* Method */));
-    }
-    function checkNonNullExpression(node) {
-      return checkNonNullType(checkExpression(node), node);
-    }
-    function isNullableType(type) {
-      return !!(getTypeFacts(type) & 50331648 /* IsUndefinedOrNull */);
-    }
-    function getNonNullableTypeIfNeeded(type) {
-      return isNullableType(type) ? getNonNullableType(type) : type;
-    }
-    function reportObjectPossiblyNullOrUndefinedError(node, facts) {
-      const nodeText2 = isEntityNameExpression(node) ? entityNameToString(node) : void 0;
-      if (node.kind === 106 /* NullKeyword */) {
-        error(node, Diagnostics.The_value_0_cannot_be_used_here, "null");
-        return;
-      }
-      if (nodeText2 !== void 0 && nodeText2.length < 100) {
-        if (isIdentifier(node) && nodeText2 === "undefined") {
-          error(node, Diagnostics.The_value_0_cannot_be_used_here, "undefined");
-          return;
-        }
-        error(
-          node,
-          facts & 16777216 /* IsUndefined */ ? facts & 33554432 /* IsNull */ ? Diagnostics._0_is_possibly_null_or_undefined : Diagnostics._0_is_possibly_undefined : Diagnostics._0_is_possibly_null,
-          nodeText2
-        );
-      } else {
-        error(
-          node,
-          facts & 16777216 /* IsUndefined */ ? facts & 33554432 /* IsNull */ ? Diagnostics.Object_is_possibly_null_or_undefined : Diagnostics.Object_is_possibly_undefined : Diagnostics.Object_is_possibly_null
-        );
-      }
-    }
-    function reportCannotInvokePossiblyNullOrUndefinedError(node, facts) {
-      error(
-        node,
-        facts & 16777216 /* IsUndefined */ ? facts & 33554432 /* IsNull */ ? Diagnostics.Cannot_invoke_an_object_which_is_possibly_null_or_undefined : Diagnostics.Cannot_invoke_an_object_which_is_possibly_undefined : Diagnostics.Cannot_invoke_an_object_which_is_possibly_null
-      );
-    }
-    function checkNonNullTypeWithReporter(type, node, reportError) {
-      if (strictNullChecks && type.flags & 2 /* Unknown */) {
-        if (isEntityNameExpression(node)) {
-          const nodeText2 = entityNameToString(node);
-          if (nodeText2.length < 100) {
-            error(node, Diagnostics._0_is_of_type_unknown, nodeText2);
-            return errorType;
-          }
-        }
-        error(node, Diagnostics.Object_is_of_type_unknown);
-        return errorType;
-      }
-      const facts = getTypeFacts(type);
-      if (facts & 50331648 /* IsUndefinedOrNull */) {
-        reportError(node, facts);
-        const t = getNonNullableType(type);
-        return t.flags & (98304 /* Nullable */ | 131072 /* Never */) ? errorType : t;
-      }
-      return type;
-    }
-    function checkNonNullType(type, node) {
-      return checkNonNullTypeWithReporter(type, node, reportObjectPossiblyNullOrUndefinedError);
-    }
-    function checkNonNullNonVoidType(type, node) {
-      const nonNullType = checkNonNullType(type, node);
-      if (nonNullType.flags & 16384 /* Void */) {
-        if (isEntityNameExpression(node)) {
-          const nodeText2 = entityNameToString(node);
-          if (isIdentifier(node) && nodeText2 === "undefined") {
-            error(node, Diagnostics.The_value_0_cannot_be_used_here, nodeText2);
-            return nonNullType;
-          }
-          if (nodeText2.length < 100) {
-            error(node, Diagnostics._0_is_possibly_undefined, nodeText2);
-            return nonNullType;
-          }
-        }
-        error(node, Diagnostics.Object_is_possibly_undefined);
-      }
-      return nonNullType;
-    }
-    function checkPropertyAccessExpression(node, checkMode, writeOnly) {
-      return node.flags & 32 /* OptionalChain */ ? checkPropertyAccessChain(node, checkMode) : checkPropertyAccessExpressionOrQualifiedName(node, node.expression, checkNonNullExpression(node.expression), node.name, checkMode, writeOnly);
-    }
-    function checkPropertyAccessChain(node, checkMode) {
-      const leftType = checkExpression(node.expression);
-      const nonOptionalType = getOptionalExpressionType(leftType, node.expression);
-      return propagateOptionalTypeMarker(checkPropertyAccessExpressionOrQualifiedName(node, node.expression, checkNonNullType(nonOptionalType, node.expression), node.name, checkMode), node, nonOptionalType !== leftType);
-    }
-    function checkQualifiedName(node, checkMode) {
-      const leftType = isPartOfTypeQuery(node) && isThisIdentifier(node.left) ? checkNonNullType(checkThisExpression(node.left), node.left) : checkNonNullExpression(node.left);
-      return checkPropertyAccessExpressionOrQualifiedName(node, node.left, leftType, node.right, checkMode);
-    }
-    function isMethodAccessForCall(node) {
-      while (node.parent.kind === 216 /* ParenthesizedExpression */) {
-        node = node.parent;
-      }
-      return isCallOrNewExpression(node.parent) && node.parent.expression === node;
-    }
-    function lookupSymbolForPrivateIdentifierDeclaration(propName, location) {
-      for (let containingClass = getContainingClass(location); !!containingClass; containingClass = getContainingClass(containingClass)) {
-        const { symbol } = containingClass;
-        const name = getSymbolNameForPrivateIdentifier(symbol, propName);
-        const prop = symbol.members && symbol.members.get(name) || symbol.exports && symbol.exports.get(name);
-        if (prop) {
-          return prop;
-        }
-      }
-    }
-    function checkGrammarPrivateIdentifierExpression(privId) {
-      if (!getContainingClass(privId)) {
-        return grammarErrorOnNode(privId, Diagnostics.Private_identifiers_are_not_allowed_outside_class_bodies);
-      }
-      if (!isForInStatement(privId.parent)) {
-        if (!isExpressionNode(privId)) {
-          return grammarErrorOnNode(privId, Diagnostics.Private_identifiers_are_only_allowed_in_class_bodies_and_may_only_be_used_as_part_of_a_class_member_declaration_property_access_or_on_the_left_hand_side_of_an_in_expression);
-        }
-        const isInOperation = isBinaryExpression(privId.parent) && privId.parent.operatorToken.kind === 103 /* InKeyword */;
-        if (!getSymbolForPrivateIdentifierExpression(privId) && !isInOperation) {
-          return grammarErrorOnNode(privId, Diagnostics.Cannot_find_name_0, idText(privId));
-        }
-      }
-      return false;
-    }
-    function checkPrivateIdentifierExpression(privId) {
-      checkGrammarPrivateIdentifierExpression(privId);
-      const symbol = getSymbolForPrivateIdentifierExpression(privId);
-      if (symbol) {
-        markPropertyAsReferenced(
-          symbol,
-          /*nodeForCheckWriteOnly*/
-          void 0,
-          /*isSelfTypeAccess*/
-          false
-        );
-      }
-      return anyType;
-    }
-    function getSymbolForPrivateIdentifierExpression(privId) {
-      if (!isExpressionNode(privId)) {
-        return void 0;
-      }
-      const links = getNodeLinks(privId);
-      if (links.resolvedSymbol === void 0) {
-        links.resolvedSymbol = lookupSymbolForPrivateIdentifierDeclaration(privId.escapedText, privId);
-      }
-      return links.resolvedSymbol;
-    }
-    function getPrivateIdentifierPropertyOfType(leftType, lexicallyScopedIdentifier) {
-      return getPropertyOfType(leftType, lexicallyScopedIdentifier.escapedName);
-    }
-    function checkPrivateIdentifierPropertyAccess(leftType, right, lexicallyScopedIdentifier) {
-      let propertyOnType;
-      const properties = getPropertiesOfType(leftType);
-      if (properties) {
-        forEach(properties, (symbol) => {
-          const decl = symbol.valueDeclaration;
-          if (decl && isNamedDeclaration(decl) && isPrivateIdentifier(decl.name) && decl.name.escapedText === right.escapedText) {
-            propertyOnType = symbol;
-            return true;
-          }
-        });
-      }
-      const diagName = diagnosticName(right);
-      if (propertyOnType) {
-        const typeValueDecl = Debug.checkDefined(propertyOnType.valueDeclaration);
-        const typeClass = Debug.checkDefined(getContainingClass(typeValueDecl));
-        if (lexicallyScopedIdentifier == null ? void 0 : lexicallyScopedIdentifier.valueDeclaration) {
-          const lexicalValueDecl = lexicallyScopedIdentifier.valueDeclaration;
-          const lexicalClass = getContainingClass(lexicalValueDecl);
-          Debug.assert(!!lexicalClass);
-          if (findAncestor(lexicalClass, (n) => typeClass === n)) {
-            const diagnostic = error(
-              right,
-              Diagnostics.The_property_0_cannot_be_accessed_on_type_1_within_this_class_because_it_is_shadowed_by_another_private_identifier_with_the_same_spelling,
-              diagName,
-              typeToString(leftType)
-            );
-            addRelatedInfo(
-              diagnostic,
-              createDiagnosticForNode(
-                lexicalValueDecl,
-                Diagnostics.The_shadowing_declaration_of_0_is_defined_here,
-                diagName
-              ),
-              createDiagnosticForNode(
-                typeValueDecl,
-                Diagnostics.The_declaration_of_0_that_you_probably_intended_to_use_is_defined_here,
-                diagName
-              )
-            );
-            return true;
-          }
-        }
-        error(
-          right,
-          Diagnostics.Property_0_is_not_accessible_outside_class_1_because_it_has_a_private_identifier,
-          diagName,
-          diagnosticName(typeClass.name || anon)
-        );
-        return true;
-      }
-      return false;
-    }
-    function isThisPropertyAccessInConstructor(node, prop) {
-      return (isConstructorDeclaredProperty(prop) || isThisProperty(node) && isAutoTypedProperty(prop)) && getThisContainer(
-        node,
-        /*includeArrowFunctions*/
-        true,
-        /*includeClassComputedPropertyName*/
-        false
-      ) === getDeclaringConstructor(prop);
-    }
-    function checkPropertyAccessExpressionOrQualifiedName(node, left, leftType, right, checkMode, writeOnly) {
-      const parentSymbol = getNodeLinks(left).resolvedSymbol;
-      const assignmentKind = getAssignmentTargetKind(node);
-      const apparentType = getApparentType(assignmentKind !== 0 /* None */ || isMethodAccessForCall(node) ? getWidenedType(leftType) : leftType);
-      const isAnyLike = isTypeAny(apparentType) || apparentType === silentNeverType;
-      let prop;
-      if (isPrivateIdentifier(right)) {
-        if (languageVersion < 99 /* ESNext */) {
-          if (assignmentKind !== 0 /* None */) {
-            checkExternalEmitHelpers(node, 1048576 /* ClassPrivateFieldSet */);
-          }
-          if (assignmentKind !== 1 /* Definite */) {
-            checkExternalEmitHelpers(node, 524288 /* ClassPrivateFieldGet */);
-          }
-        }
-        const lexicallyScopedSymbol = lookupSymbolForPrivateIdentifierDeclaration(right.escapedText, right);
-        if (assignmentKind && lexicallyScopedSymbol && lexicallyScopedSymbol.valueDeclaration && isMethodDeclaration(lexicallyScopedSymbol.valueDeclaration)) {
-          grammarErrorOnNode(right, Diagnostics.Cannot_assign_to_private_method_0_Private_methods_are_not_writable, idText(right));
-        }
-        if (isAnyLike) {
-          if (lexicallyScopedSymbol) {
-            return isErrorType(apparentType) ? errorType : apparentType;
-          }
-          if (!getContainingClass(right)) {
-            grammarErrorOnNode(right, Diagnostics.Private_identifiers_are_not_allowed_outside_class_bodies);
-            return anyType;
-          }
-        }
-        prop = lexicallyScopedSymbol ? getPrivateIdentifierPropertyOfType(leftType, lexicallyScopedSymbol) : void 0;
-        if (!prop && checkPrivateIdentifierPropertyAccess(leftType, right, lexicallyScopedSymbol)) {
-          return errorType;
-        } else {
-          const isSetonlyAccessor = prop && prop.flags & 65536 /* SetAccessor */ && !(prop.flags & 32768 /* GetAccessor */);
-          if (isSetonlyAccessor && assignmentKind !== 1 /* Definite */) {
-            error(node, Diagnostics.Private_accessor_was_defined_without_a_getter);
-          }
-        }
-      } else {
-        if (isAnyLike) {
-          if (isIdentifier(left) && parentSymbol) {
-            markAliasReferenced(parentSymbol, node);
-          }
-          return isErrorType(apparentType) ? errorType : apparentType;
-        }
-        prop = getPropertyOfType(
-          apparentType,
-          right.escapedText,
-          /*skipObjectFunctionPropertyAugment*/
-          false,
-          /*includeTypeOnlyMembers*/
-          node.kind === 165 /* QualifiedName */
-        );
-      }
-      if (isIdentifier(left) && parentSymbol && (getIsolatedModules(compilerOptions) || !(prop && (isConstEnumOrConstEnumOnlyModule(prop) || prop.flags & 8 /* EnumMember */ && node.parent.kind === 305 /* EnumMember */)) || shouldPreserveConstEnums(compilerOptions) && isExportOrExportExpression(node))) {
-        markAliasReferenced(parentSymbol, node);
-      }
-      let propType;
-      if (!prop) {
-        const indexInfo = !isPrivateIdentifier(right) && (assignmentKind === 0 /* None */ || !isGenericObjectType(leftType) || isThisTypeParameter(leftType)) ? getApplicableIndexInfoForName(apparentType, right.escapedText) : void 0;
-        if (!(indexInfo && indexInfo.type)) {
-          const isUncheckedJS = isUncheckedJSSuggestion(
-            node,
-            leftType.symbol,
-            /*excludeClasses*/
-            true
-          );
-          if (!isUncheckedJS && isJSLiteralType(leftType)) {
-            return anyType;
-          }
-          if (leftType.symbol === globalThisSymbol) {
-            if (globalThisSymbol.exports.has(right.escapedText) && globalThisSymbol.exports.get(right.escapedText).flags & 418 /* BlockScoped */) {
-              error(right, Diagnostics.Property_0_does_not_exist_on_type_1, unescapeLeadingUnderscores(right.escapedText), typeToString(leftType));
-            } else if (noImplicitAny) {
-              error(right, Diagnostics.Element_implicitly_has_an_any_type_because_type_0_has_no_index_signature, typeToString(leftType));
-            }
-            return anyType;
-          }
-          if (right.escapedText && !checkAndReportErrorForExtendingInterface(node)) {
-            reportNonexistentProperty(right, isThisTypeParameter(leftType) ? apparentType : leftType, isUncheckedJS);
-          }
-          return errorType;
-        }
-        if (indexInfo.isReadonly && (isAssignmentTarget(node) || isDeleteTarget(node))) {
-          error(node, Diagnostics.Index_signature_in_type_0_only_permits_reading, typeToString(apparentType));
-        }
-        propType = compilerOptions.noUncheckedIndexedAccess && !isAssignmentTarget(node) ? getUnionType([indexInfo.type, missingType]) : indexInfo.type;
-        if (compilerOptions.noPropertyAccessFromIndexSignature && isPropertyAccessExpression(node)) {
-          error(right, Diagnostics.Property_0_comes_from_an_index_signature_so_it_must_be_accessed_with_0, unescapeLeadingUnderscores(right.escapedText));
-        }
-        if (indexInfo.declaration && getCombinedNodeFlags(indexInfo.declaration) & 268435456 /* Deprecated */) {
-          addDeprecatedSuggestion(right, [indexInfo.declaration], right.escapedText);
-        }
-      } else {
-        const targetPropSymbol = resolveAliasWithDeprecationCheck(prop, right);
-        if (isDeprecatedSymbol(targetPropSymbol) && isUncalledFunctionReference(node, targetPropSymbol) && targetPropSymbol.declarations) {
-          addDeprecatedSuggestion(right, targetPropSymbol.declarations, right.escapedText);
-        }
-        checkPropertyNotUsedBeforeDeclaration(prop, node, right);
-        markPropertyAsReferenced(prop, node, isSelfTypeAccess(left, parentSymbol));
-        getNodeLinks(node).resolvedSymbol = prop;
-        checkPropertyAccessibility(node, left.kind === 108 /* SuperKeyword */, isWriteAccess(node), apparentType, prop);
-        if (isAssignmentToReadonlyEntity(node, prop, assignmentKind)) {
-          error(right, Diagnostics.Cannot_assign_to_0_because_it_is_a_read_only_property, idText(right));
-          return errorType;
-        }
-        propType = isThisPropertyAccessInConstructor(node, prop) ? autoType : writeOnly || isWriteOnlyAccess(node) ? getWriteTypeOfSymbol(prop) : getTypeOfSymbol(prop);
-      }
-      return getFlowTypeOfAccessExpression(node, prop, propType, right, checkMode);
-    }
-    function isUncheckedJSSuggestion(node, suggestion, excludeClasses) {
-      const file = getSourceFileOfNode(node);
-      if (file) {
-        if (compilerOptions.checkJs === void 0 && file.checkJsDirective === void 0 && (file.scriptKind === 1 /* JS */ || file.scriptKind === 2 /* JSX */)) {
-          const declarationFile = forEach(suggestion == null ? void 0 : suggestion.declarations, getSourceFileOfNode);
-          return !(file !== declarationFile && !!declarationFile && isGlobalSourceFile(declarationFile)) && !(excludeClasses && suggestion && suggestion.flags & 32 /* Class */) && !(!!node && excludeClasses && isPropertyAccessExpression(node) && node.expression.kind === 110 /* ThisKeyword */);
-        }
-      }
-      return false;
-    }
-    function getFlowTypeOfAccessExpression(node, prop, propType, errorNode, checkMode) {
-      const assignmentKind = getAssignmentTargetKind(node);
-      if (assignmentKind === 1 /* Definite */) {
-        return removeMissingType(propType, !!(prop && prop.flags & 16777216 /* Optional */));
-      }
-      if (prop && !(prop.flags & (3 /* Variable */ | 4 /* Property */ | 98304 /* Accessor */)) && !(prop.flags & 8192 /* Method */ && propType.flags & 1048576 /* Union */) && !isDuplicatedCommonJSExport(prop.declarations)) {
-        return propType;
-      }
-      if (propType === autoType) {
-        return getFlowTypeOfProperty(node, prop);
-      }
-      propType = getNarrowableTypeForReference(propType, node, checkMode);
-      let assumeUninitialized = false;
-      if (strictNullChecks && strictPropertyInitialization && isAccessExpression(node) && node.expression.kind === 110 /* ThisKeyword */) {
-        const declaration = prop && prop.valueDeclaration;
-        if (declaration && isPropertyWithoutInitializer(declaration)) {
-          if (!isStatic(declaration)) {
-            const flowContainer = getControlFlowContainer(node);
-            if (flowContainer.kind === 175 /* Constructor */ && flowContainer.parent === declaration.parent && !(declaration.flags & 16777216 /* Ambient */)) {
-              assumeUninitialized = true;
-            }
-          }
-        }
-      } else if (strictNullChecks && prop && prop.valueDeclaration && isPropertyAccessExpression(prop.valueDeclaration) && getAssignmentDeclarationPropertyAccessKind(prop.valueDeclaration) && getControlFlowContainer(node) === getControlFlowContainer(prop.valueDeclaration)) {
-        assumeUninitialized = true;
-      }
-      const flowType = getFlowTypeOfReference(node, propType, assumeUninitialized ? getOptionalType(propType) : propType);
-      if (assumeUninitialized && !containsUndefinedType(propType) && containsUndefinedType(flowType)) {
-        error(errorNode, Diagnostics.Property_0_is_used_before_being_assigned, symbolToString(prop));
-        return propType;
-      }
-      return assignmentKind ? getBaseTypeOfLiteralType(flowType) : flowType;
-    }
-    function checkPropertyNotUsedBeforeDeclaration(prop, node, right) {
-      const { valueDeclaration } = prop;
-      if (!valueDeclaration || getSourceFileOfNode(node).isDeclarationFile) {
-        return;
-      }
-      let diagnosticMessage;
-      const declarationName = idText(right);
-      if (isInPropertyInitializerOrClassStaticBlock(node) && !isOptionalPropertyDeclaration(valueDeclaration) && !(isAccessExpression(node) && isAccessExpression(node.expression)) && !isBlockScopedNameDeclaredBeforeUse(valueDeclaration, right) && !(isMethodDeclaration(valueDeclaration) && getCombinedModifierFlags(valueDeclaration) & 32 /* Static */) && (compilerOptions.useDefineForClassFields || !isPropertyDeclaredInAncestorClass(prop))) {
-        diagnosticMessage = error(right, Diagnostics.Property_0_is_used_before_its_initialization, declarationName);
-      } else if (valueDeclaration.kind === 262 /* ClassDeclaration */ && node.parent.kind !== 182 /* TypeReference */ && !(valueDeclaration.flags & 16777216 /* Ambient */) && !isBlockScopedNameDeclaredBeforeUse(valueDeclaration, right)) {
-        diagnosticMessage = error(right, Diagnostics.Class_0_used_before_its_declaration, declarationName);
-      }
-      if (diagnosticMessage) {
-        addRelatedInfo(
-          diagnosticMessage,
-          createDiagnosticForNode(valueDeclaration, Diagnostics._0_is_declared_here, declarationName)
-        );
-      }
-    }
-    function isInPropertyInitializerOrClassStaticBlock(node) {
-      return !!findAncestor(node, (node2) => {
-        switch (node2.kind) {
-          case 171 /* PropertyDeclaration */:
-            return true;
-          case 302 /* PropertyAssignment */:
-          case 173 /* MethodDeclaration */:
-          case 176 /* GetAccessor */:
-          case 177 /* SetAccessor */:
-          case 304 /* SpreadAssignment */:
-          case 166 /* ComputedPropertyName */:
-          case 238 /* TemplateSpan */:
-          case 293 /* JsxExpression */:
-          case 290 /* JsxAttribute */:
-          case 291 /* JsxAttributes */:
-          case 292 /* JsxSpreadAttribute */:
-          case 285 /* JsxOpeningElement */:
-          case 232 /* ExpressionWithTypeArguments */:
-          case 297 /* HeritageClause */:
-            return false;
-          case 218 /* ArrowFunction */:
-          case 243 /* ExpressionStatement */:
-            return isBlock(node2.parent) && isClassStaticBlockDeclaration(node2.parent.parent) ? true : "quit";
-          default:
-            return isExpressionNode(node2) ? false : "quit";
-        }
-      });
-    }
-    function isPropertyDeclaredInAncestorClass(prop) {
-      if (!(prop.parent.flags & 32 /* Class */)) {
-        return false;
-      }
-      let classType = getTypeOfSymbol(prop.parent);
-      while (true) {
-        classType = classType.symbol && getSuperClass(classType);
-        if (!classType) {
-          return false;
-        }
-        const superProperty = getPropertyOfType(classType, prop.escapedName);
-        if (superProperty && superProperty.valueDeclaration) {
-          return true;
-        }
-      }
-    }
-    function getSuperClass(classType) {
-      const x = getBaseTypes(classType);
-      if (x.length === 0) {
-        return void 0;
-      }
-      return getIntersectionType(x);
-    }
-    function reportNonexistentProperty(propNode, containingType, isUncheckedJS) {
-      let errorInfo;
-      let relatedInfo;
-      if (!isPrivateIdentifier(propNode) && containingType.flags & 1048576 /* Union */ && !(containingType.flags & 402784252 /* Primitive */)) {
-        for (const subtype of containingType.types) {
-          if (!getPropertyOfType(subtype, propNode.escapedText) && !getApplicableIndexInfoForName(subtype, propNode.escapedText)) {
-            errorInfo = chainDiagnosticMessages(errorInfo, Diagnostics.Property_0_does_not_exist_on_type_1, declarationNameToString(propNode), typeToString(subtype));
-            break;
-          }
-        }
-      }
-      if (typeHasStaticProperty(propNode.escapedText, containingType)) {
-        const propName = declarationNameToString(propNode);
-        const typeName = typeToString(containingType);
-        errorInfo = chainDiagnosticMessages(errorInfo, Diagnostics.Property_0_does_not_exist_on_type_1_Did_you_mean_to_access_the_static_member_2_instead, propName, typeName, typeName + "." + propName);
-      } else {
-        const promisedType = getPromisedTypeOfPromise(containingType);
-        if (promisedType && getPropertyOfType(promisedType, propNode.escapedText)) {
-          errorInfo = chainDiagnosticMessages(errorInfo, Diagnostics.Property_0_does_not_exist_on_type_1, declarationNameToString(propNode), typeToString(containingType));
-          relatedInfo = createDiagnosticForNode(propNode, Diagnostics.Did_you_forget_to_use_await);
-        } else {
-          const missingProperty = declarationNameToString(propNode);
-          const container = typeToString(containingType);
-          const libSuggestion = getSuggestedLibForNonExistentProperty(missingProperty, containingType);
-          if (libSuggestion !== void 0) {
-            errorInfo = chainDiagnosticMessages(errorInfo, Diagnostics.Property_0_does_not_exist_on_type_1_Do_you_need_to_change_your_target_library_Try_changing_the_lib_compiler_option_to_2_or_later, missingProperty, container, libSuggestion);
-          } else {
-            const suggestion = getSuggestedSymbolForNonexistentProperty(propNode, containingType);
-            if (suggestion !== void 0) {
-              const suggestedName = symbolName(suggestion);
-              const message = isUncheckedJS ? Diagnostics.Property_0_may_not_exist_on_type_1_Did_you_mean_2 : Diagnostics.Property_0_does_not_exist_on_type_1_Did_you_mean_2;
-              errorInfo = chainDiagnosticMessages(errorInfo, message, missingProperty, container, suggestedName);
-              relatedInfo = suggestion.valueDeclaration && createDiagnosticForNode(suggestion.valueDeclaration, Diagnostics._0_is_declared_here, suggestedName);
-            } else {
-              const diagnostic = containerSeemsToBeEmptyDomElement(containingType) ? Diagnostics.Property_0_does_not_exist_on_type_1_Try_changing_the_lib_compiler_option_to_include_dom : Diagnostics.Property_0_does_not_exist_on_type_1;
-              errorInfo = chainDiagnosticMessages(elaborateNeverIntersection(errorInfo, containingType), diagnostic, missingProperty, container);
-            }
-          }
-        }
-      }
-      const resultDiagnostic = createDiagnosticForNodeFromMessageChain(getSourceFileOfNode(propNode), propNode, errorInfo);
-      if (relatedInfo) {
-        addRelatedInfo(resultDiagnostic, relatedInfo);
-      }
-      addErrorOrSuggestion(!isUncheckedJS || errorInfo.code !== Diagnostics.Property_0_may_not_exist_on_type_1_Did_you_mean_2.code, resultDiagnostic);
-    }
-    function containerSeemsToBeEmptyDomElement(containingType) {
-      return compilerOptions.lib && !compilerOptions.lib.includes("dom") && everyContainedType(containingType, (type) => type.symbol && /^(EventTarget|Node|((HTML[a-zA-Z]*)?Element))$/.test(unescapeLeadingUnderscores(type.symbol.escapedName))) && isEmptyObjectType(containingType);
-    }
-    function typeHasStaticProperty(propName, containingType) {
-      const prop = containingType.symbol && getPropertyOfType(getTypeOfSymbol(containingType.symbol), propName);
-      return prop !== void 0 && !!prop.valueDeclaration && isStatic(prop.valueDeclaration);
-    }
-    function getSuggestedLibForNonExistentName(name) {
-      const missingName = diagnosticName(name);
-      const allFeatures = getScriptTargetFeatures();
-      const typeFeatures = allFeatures.get(missingName);
-      return typeFeatures && firstIterator(typeFeatures.keys());
-    }
-    function getSuggestedLibForNonExistentProperty(missingProperty, containingType) {
-      const container = getApparentType(containingType).symbol;
-      if (!container) {
-        return void 0;
-      }
-      const containingTypeName = symbolName(container);
-      const allFeatures = getScriptTargetFeatures();
-      const typeFeatures = allFeatures.get(containingTypeName);
-      if (typeFeatures) {
-        for (const [libTarget, featuresOfType] of typeFeatures) {
-          if (contains(featuresOfType, missingProperty)) {
-            return libTarget;
-          }
-        }
-      }
-    }
-    function getSuggestedSymbolForNonexistentClassMember(name, baseType) {
-      return getSpellingSuggestionForName(name, getPropertiesOfType(baseType), 106500 /* ClassMember */);
-    }
-    function getSuggestedSymbolForNonexistentProperty(name, containingType) {
-      let props = getPropertiesOfType(containingType);
-      if (typeof name !== "string") {
-        const parent2 = name.parent;
-        if (isPropertyAccessExpression(parent2)) {
-          props = filter(props, (prop) => isValidPropertyAccessForCompletions(parent2, containingType, prop));
-        }
-        name = idText(name);
-      }
-      return getSpellingSuggestionForName(name, props, 111551 /* Value */);
-    }
-    function getSuggestedSymbolForNonexistentJSXAttribute(name, containingType) {
-      const strName = isString(name) ? name : idText(name);
-      const properties = getPropertiesOfType(containingType);
-      const jsxSpecific = strName === "for" ? find(properties, (x) => symbolName(x) === "htmlFor") : strName === "class" ? find(properties, (x) => symbolName(x) === "className") : void 0;
-      return jsxSpecific ?? getSpellingSuggestionForName(strName, properties, 111551 /* Value */);
-    }
-    function getSuggestionForNonexistentProperty(name, containingType) {
-      const suggestion = getSuggestedSymbolForNonexistentProperty(name, containingType);
-      return suggestion && symbolName(suggestion);
-    }
-    function getSuggestedSymbolForNonexistentSymbol(location, outerName, meaning) {
-      Debug.assert(outerName !== void 0, "outername should always be defined");
-      const result = resolveNameHelper(
-        location,
-        outerName,
-        meaning,
-        /*nameNotFoundMessage*/
-        void 0,
-        outerName,
-        /*isUse*/
-        false,
-        /*excludeGlobals*/
-        false,
-        /*getSpellingSuggestions*/
-        true,
-        (symbols, name, meaning2) => {
-          Debug.assertEqual(outerName, name, "name should equal outerName");
-          const symbol = getSymbol2(symbols, name, meaning2);
-          if (symbol)
-            return symbol;
-          let candidates;
-          if (symbols === globals) {
-            const primitives = mapDefined(
-              ["string", "number", "boolean", "object", "bigint", "symbol"],
-              (s) => symbols.has(s.charAt(0).toUpperCase() + s.slice(1)) ? createSymbol(524288 /* TypeAlias */, s) : void 0
-            );
-            candidates = primitives.concat(arrayFrom(symbols.values()));
-          } else {
-            candidates = arrayFrom(symbols.values());
-          }
-          return getSpellingSuggestionForName(unescapeLeadingUnderscores(name), candidates, meaning2);
-        }
-      );
-      return result;
-    }
-    function getSuggestionForNonexistentSymbol(location, outerName, meaning) {
-      const symbolResult = getSuggestedSymbolForNonexistentSymbol(location, outerName, meaning);
-      return symbolResult && symbolName(symbolResult);
-    }
-    function getSuggestedSymbolForNonexistentModule(name, targetModule) {
-      return targetModule.exports && getSpellingSuggestionForName(idText(name), getExportsOfModuleAsArray(targetModule), 2623475 /* ModuleMember */);
-    }
-    function getSuggestionForNonexistentExport(name, targetModule) {
-      const suggestion = getSuggestedSymbolForNonexistentModule(name, targetModule);
-      return suggestion && symbolName(suggestion);
-    }
-    function getSuggestionForNonexistentIndexSignature(objectType, expr, keyedType) {
-      function hasProp(name) {
-        const prop = getPropertyOfObjectType(objectType, name);
-        if (prop) {
-          const s = getSingleCallSignature(getTypeOfSymbol(prop));
-          return !!s && getMinArgumentCount(s) >= 1 && isTypeAssignableTo(keyedType, getTypeAtPosition(s, 0));
-        }
-        return false;
-      }
-      const suggestedMethod = isAssignmentTarget(expr) ? "set" : "get";
-      if (!hasProp(suggestedMethod)) {
-        return void 0;
-      }
-      let suggestion = tryGetPropertyAccessOrIdentifierToString(expr.expression);
-      if (suggestion === void 0) {
-        suggestion = suggestedMethod;
-      } else {
-        suggestion += "." + suggestedMethod;
-      }
-      return suggestion;
-    }
-    function getSuggestedTypeForNonexistentStringLiteralType(source, target) {
-      const candidates = target.types.filter((type) => !!(type.flags & 128 /* StringLiteral */));
-      return getSpellingSuggestion(source.value, candidates, (type) => type.value);
-    }
-    function getSpellingSuggestionForName(name, symbols, meaning) {
-      return getSpellingSuggestion(name, symbols, getCandidateName);
-      function getCandidateName(candidate) {
-        const candidateName = symbolName(candidate);
-        if (startsWith(candidateName, '"')) {
-          return void 0;
-        }
-        if (candidate.flags & meaning) {
-          return candidateName;
-        }
-        if (candidate.flags & 2097152 /* Alias */) {
-          const alias = tryResolveAlias(candidate);
-          if (alias && alias.flags & meaning) {
-            return candidateName;
-          }
-        }
-        return void 0;
-      }
-    }
-    function markPropertyAsReferenced(prop, nodeForCheckWriteOnly, isSelfTypeAccess2) {
-      const valueDeclaration = prop && prop.flags & 106500 /* ClassMember */ && prop.valueDeclaration;
-      if (!valueDeclaration) {
-        return;
-      }
-      const hasPrivateModifier = hasEffectiveModifier(valueDeclaration, 8 /* Private */);
-      const hasPrivateIdentifier = prop.valueDeclaration && isNamedDeclaration(prop.valueDeclaration) && isPrivateIdentifier(prop.valueDeclaration.name);
-      if (!hasPrivateModifier && !hasPrivateIdentifier) {
-        return;
-      }
-      if (nodeForCheckWriteOnly && isWriteOnlyAccess(nodeForCheckWriteOnly) && !(prop.flags & 65536 /* SetAccessor */)) {
-        return;
-      }
-      if (isSelfTypeAccess2) {
-        const containingMethod = findAncestor(nodeForCheckWriteOnly, isFunctionLikeDeclaration);
-        if (containingMethod && containingMethod.symbol === prop) {
-          return;
-        }
-      }
-      (getCheckFlags(prop) & 1 /* Instantiated */ ? getSymbolLinks(prop).target : prop).isReferenced = 67108863 /* All */;
-    }
-    function isSelfTypeAccess(name, parent2) {
-      return name.kind === 110 /* ThisKeyword */ || !!parent2 && isEntityNameExpression(name) && parent2 === getResolvedSymbol(getFirstIdentifier(name));
-    }
-    function isValidPropertyAccess(node, propertyName) {
-      switch (node.kind) {
-        case 210 /* PropertyAccessExpression */:
-          return isValidPropertyAccessWithType(node, node.expression.kind === 108 /* SuperKeyword */, propertyName, getWidenedType(checkExpression(node.expression)));
-        case 165 /* QualifiedName */:
-          return isValidPropertyAccessWithType(
-            node,
-            /*isSuper*/
-            false,
-            propertyName,
-            getWidenedType(checkExpression(node.left))
-          );
-        case 204 /* ImportType */:
-          return isValidPropertyAccessWithType(
-            node,
-            /*isSuper*/
-            false,
-            propertyName,
-            getTypeFromTypeNode(node)
-          );
-      }
-    }
-    function isValidPropertyAccessForCompletions(node, type, property) {
-      return isPropertyAccessible(
-        node,
-        node.kind === 210 /* PropertyAccessExpression */ && node.expression.kind === 108 /* SuperKeyword */,
-        /*isWrite*/
-        false,
-        type,
-        property
-      );
-    }
-    function isValidPropertyAccessWithType(node, isSuper, propertyName, type) {
-      if (isTypeAny(type)) {
-        return true;
-      }
-      const prop = getPropertyOfType(type, propertyName);
-      return !!prop && isPropertyAccessible(
-        node,
-        isSuper,
-        /*isWrite*/
-        false,
-        type,
-        prop
-      );
-    }
-    function isPropertyAccessible(node, isSuper, isWrite, containingType, property) {
-      if (isTypeAny(containingType)) {
-        return true;
-      }
-      if (property.valueDeclaration && isPrivateIdentifierClassElementDeclaration(property.valueDeclaration)) {
-        const declClass = getContainingClass(property.valueDeclaration);
-        return !isOptionalChain(node) && !!findAncestor(node, (parent2) => parent2 === declClass);
-      }
-      return checkPropertyAccessibilityAtLocation(node, isSuper, isWrite, containingType, property);
-    }
-    function getForInVariableSymbol(node) {
-      const initializer = node.initializer;
-      if (initializer.kind === 260 /* VariableDeclarationList */) {
-        const variable = initializer.declarations[0];
-        if (variable && !isBindingPattern(variable.name)) {
-          return getSymbolOfDeclaration(variable);
-        }
-      } else if (initializer.kind === 80 /* Identifier */) {
-        return getResolvedSymbol(initializer);
-      }
-      return void 0;
-    }
-    function hasNumericPropertyNames(type) {
-      return getIndexInfosOfType(type).length === 1 && !!getIndexInfoOfType(type, numberType);
-    }
-    function isForInVariableForNumericPropertyNames(expr) {
-      const e = skipParentheses(expr);
-      if (e.kind === 80 /* Identifier */) {
-        const symbol = getResolvedSymbol(e);
-        if (symbol.flags & 3 /* Variable */) {
-          let child = expr;
-          let node = expr.parent;
-          while (node) {
-            if (node.kind === 248 /* ForInStatement */ && child === node.statement && getForInVariableSymbol(node) === symbol && hasNumericPropertyNames(getTypeOfExpression(node.expression))) {
-              return true;
-            }
-            child = node;
-            node = node.parent;
-          }
-        }
-      }
-      return false;
-    }
-    function checkIndexedAccess(node, checkMode) {
-      return node.flags & 32 /* OptionalChain */ ? checkElementAccessChain(node, checkMode) : checkElementAccessExpression(node, checkNonNullExpression(node.expression), checkMode);
-    }
-    function checkElementAccessChain(node, checkMode) {
-      const exprType = checkExpression(node.expression);
-      const nonOptionalType = getOptionalExpressionType(exprType, node.expression);
-      return propagateOptionalTypeMarker(checkElementAccessExpression(node, checkNonNullType(nonOptionalType, node.expression), checkMode), node, nonOptionalType !== exprType);
-    }
-    function checkElementAccessExpression(node, exprType, checkMode) {
-      const objectType = getAssignmentTargetKind(node) !== 0 /* None */ || isMethodAccessForCall(node) ? getWidenedType(exprType) : exprType;
-      const indexExpression = node.argumentExpression;
-      const indexType = checkExpression(indexExpression);
-      if (isErrorType(objectType) || objectType === silentNeverType) {
-        return objectType;
-      }
-      if (isConstEnumObjectType(objectType) && !isStringLiteralLike(indexExpression)) {
-        error(indexExpression, Diagnostics.A_const_enum_member_can_only_be_accessed_using_a_string_literal);
-        return errorType;
-      }
-      const effectiveIndexType = isForInVariableForNumericPropertyNames(indexExpression) ? numberType : indexType;
-      const accessFlags = isAssignmentTarget(node) ? 4 /* Writing */ | (isGenericObjectType(objectType) && !isThisTypeParameter(objectType) ? 2 /* NoIndexSignatures */ : 0) : 32 /* ExpressionPosition */;
-      const indexedAccessType = getIndexedAccessTypeOrUndefined(objectType, effectiveIndexType, accessFlags, node) || errorType;
-      return checkIndexedAccessIndexType(getFlowTypeOfAccessExpression(node, getNodeLinks(node).resolvedSymbol, indexedAccessType, indexExpression, checkMode), node);
-    }
-    function callLikeExpressionMayHaveTypeArguments(node) {
-      return isCallOrNewExpression(node) || isTaggedTemplateExpression(node) || isJsxOpeningLikeElement(node);
-    }
-    function resolveUntypedCall(node) {
-      if (callLikeExpressionMayHaveTypeArguments(node)) {
-        forEach(node.typeArguments, checkSourceElement);
-      }
-      if (node.kind === 214 /* TaggedTemplateExpression */) {
-        checkExpression(node.template);
-      } else if (isJsxOpeningLikeElement(node)) {
-        checkExpression(node.attributes);
-      } else if (node.kind !== 169 /* Decorator */) {
-        forEach(node.arguments, (argument) => {
-          checkExpression(argument);
-        });
-      }
-      return anySignature;
-    }
-    function resolveErrorCall(node) {
-      resolveUntypedCall(node);
-      return unknownSignature;
-    }
-    function reorderCandidates(signatures, result, callChainFlags) {
-      let lastParent;
-      let lastSymbol;
-      let cutoffIndex = 0;
-      let index;
-      let specializedIndex = -1;
-      let spliceIndex;
-      Debug.assert(!result.length);
-      for (const signature of signatures) {
-        const symbol = signature.declaration && getSymbolOfDeclaration(signature.declaration);
-        const parent2 = signature.declaration && signature.declaration.parent;
-        if (!lastSymbol || symbol === lastSymbol) {
-          if (lastParent && parent2 === lastParent) {
-            index = index + 1;
-          } else {
-            lastParent = parent2;
-            index = cutoffIndex;
-          }
-        } else {
-          index = cutoffIndex = result.length;
-          lastParent = parent2;
-        }
-        lastSymbol = symbol;
-        if (signatureHasLiteralTypes(signature)) {
-          specializedIndex++;
-          spliceIndex = specializedIndex;
-          cutoffIndex++;
-        } else {
-          spliceIndex = index;
-        }
-        result.splice(spliceIndex, 0, callChainFlags ? getOptionalCallSignature(signature, callChainFlags) : signature);
-      }
-    }
-    function isSpreadArgument(arg) {
-      return !!arg && (arg.kind === 229 /* SpreadElement */ || arg.kind === 236 /* SyntheticExpression */ && arg.isSpread);
-    }
-    function getSpreadArgumentIndex(args) {
-      return findIndex(args, isSpreadArgument);
-    }
-    function acceptsVoid(t) {
-      return !!(t.flags & 16384 /* Void */);
-    }
-    function acceptsVoidUndefinedUnknownOrAny(t) {
-      return !!(t.flags & (16384 /* Void */ | 32768 /* Undefined */ | 2 /* Unknown */ | 1 /* Any */));
-    }
-    function hasCorrectArity(node, args, signature, signatureHelpTrailingComma = false) {
-      let argCount;
-      let callIsIncomplete = false;
-      let effectiveParameterCount = getParameterCount(signature);
-      let effectiveMinimumArguments = getMinArgumentCount(signature);
-      if (node.kind === 214 /* TaggedTemplateExpression */) {
-        argCount = args.length;
-        if (node.template.kind === 227 /* TemplateExpression */) {
-          const lastSpan = last(node.template.templateSpans);
-          callIsIncomplete = nodeIsMissing(lastSpan.literal) || !!lastSpan.literal.isUnterminated;
-        } else {
-          const templateLiteral = node.template;
-          Debug.assert(templateLiteral.kind === 15 /* NoSubstitutionTemplateLiteral */);
-          callIsIncomplete = !!templateLiteral.isUnterminated;
-        }
-      } else if (node.kind === 169 /* Decorator */) {
-        argCount = getDecoratorArgumentCount(node, signature);
-      } else if (isJsxOpeningLikeElement(node)) {
-        callIsIncomplete = node.attributes.end === node.end;
-        if (callIsIncomplete) {
-          return true;
-        }
-        argCount = effectiveMinimumArguments === 0 ? args.length : 1;
-        effectiveParameterCount = args.length === 0 ? effectiveParameterCount : 1;
-        effectiveMinimumArguments = Math.min(effectiveMinimumArguments, 1);
-      } else if (!node.arguments) {
-        Debug.assert(node.kind === 213 /* NewExpression */);
-        return getMinArgumentCount(signature) === 0;
-      } else {
-        argCount = signatureHelpTrailingComma ? args.length + 1 : args.length;
-        callIsIncomplete = node.arguments.end === node.end;
-        const spreadArgIndex = getSpreadArgumentIndex(args);
-        if (spreadArgIndex >= 0) {
-          return spreadArgIndex >= getMinArgumentCount(signature) && (hasEffectiveRestParameter(signature) || spreadArgIndex < getParameterCount(signature));
-        }
-      }
-      if (!hasEffectiveRestParameter(signature) && argCount > effectiveParameterCount) {
-        return false;
-      }
-      if (callIsIncomplete || argCount >= effectiveMinimumArguments) {
-        return true;
-      }
-      for (let i = argCount; i < effectiveMinimumArguments; i++) {
-        const type = getTypeAtPosition(signature, i);
-        if (filterType(type, isInJSFile(node) && !strictNullChecks ? acceptsVoidUndefinedUnknownOrAny : acceptsVoid).flags & 131072 /* Never */) {
-          return false;
-        }
-      }
-      return true;
-    }
-    function hasCorrectTypeArgumentArity(signature, typeArguments) {
-      const numTypeParameters = length(signature.typeParameters);
-      const minTypeArgumentCount = getMinTypeArgumentCount(signature.typeParameters);
-      return !some(typeArguments) || typeArguments.length >= minTypeArgumentCount && typeArguments.length <= numTypeParameters;
-    }
-    function getSingleCallSignature(type) {
-      return getSingleSignature(
-        type,
-        0 /* Call */,
-        /*allowMembers*/
-        false
-      );
-    }
-    function getSingleCallOrConstructSignature(type) {
-      return getSingleSignature(
-        type,
-        0 /* Call */,
-        /*allowMembers*/
-        false
-      ) || getSingleSignature(
-        type,
-        1 /* Construct */,
-        /*allowMembers*/
-        false
-      );
-    }
-    function getSingleSignature(type, kind, allowMembers) {
-      if (type.flags & 524288 /* Object */) {
-        const resolved = resolveStructuredTypeMembers(type);
-        if (allowMembers || resolved.properties.length === 0 && resolved.indexInfos.length === 0) {
-          if (kind === 0 /* Call */ && resolved.callSignatures.length === 1 && resolved.constructSignatures.length === 0) {
-            return resolved.callSignatures[0];
-          }
-          if (kind === 1 /* Construct */ && resolved.constructSignatures.length === 1 && resolved.callSignatures.length === 0) {
-            return resolved.constructSignatures[0];
-          }
-        }
-      }
-      return void 0;
-    }
-    function instantiateSignatureInContextOf(signature, contextualSignature, inferenceContext, compareTypes) {
-      const context = createInferenceContext(signature.typeParameters, signature, 0 /* None */, compareTypes);
-      const restType = getEffectiveRestType(contextualSignature);
-      const mapper = inferenceContext && (restType && restType.flags & 262144 /* TypeParameter */ ? inferenceContext.nonFixingMapper : inferenceContext.mapper);
-      const sourceSignature = mapper ? instantiateSignature(contextualSignature, mapper) : contextualSignature;
-      applyToParameterTypes(sourceSignature, signature, (source, target) => {
-        inferTypes(context.inferences, source, target);
-      });
-      if (!inferenceContext) {
-        applyToReturnTypes(contextualSignature, signature, (source, target) => {
-          inferTypes(context.inferences, source, target, 128 /* ReturnType */);
-        });
-      }
-      return getSignatureInstantiation(signature, getInferredTypes(context), isInJSFile(contextualSignature.declaration));
-    }
-    function inferJsxTypeArguments(node, signature, checkMode, context) {
-      const paramType = getEffectiveFirstArgumentForJsxSignature(signature, node);
-      const checkAttrType = checkExpressionWithContextualType(node.attributes, paramType, context, checkMode);
-      inferTypes(context.inferences, checkAttrType, paramType);
-      return getInferredTypes(context);
-    }
-    function getThisArgumentType(thisArgumentNode) {
-      if (!thisArgumentNode) {
-        return voidType;
-      }
-      const thisArgumentType = checkExpression(thisArgumentNode);
-      return isOptionalChainRoot(thisArgumentNode.parent) ? getNonNullableType(thisArgumentType) : isOptionalChain(thisArgumentNode.parent) ? removeOptionalTypeMarker(thisArgumentType) : thisArgumentType;
-    }
-    function inferTypeArguments(node, signature, args, checkMode, context) {
-      if (isJsxOpeningLikeElement(node)) {
-        return inferJsxTypeArguments(node, signature, checkMode, context);
-      }
-      if (node.kind !== 169 /* Decorator */) {
-        const skipBindingPatterns = every(signature.typeParameters, (p) => !!getDefaultFromTypeParameter(p));
-        const contextualType = getContextualType2(node, skipBindingPatterns ? 8 /* SkipBindingPatterns */ : 0 /* None */);
-        if (contextualType) {
-          const inferenceTargetType = getReturnTypeOfSignature(signature);
-          if (couldContainTypeVariables(inferenceTargetType)) {
-            const outerContext = getInferenceContext(node);
-            const isFromBindingPattern = !skipBindingPatterns && getContextualType2(node, 8 /* SkipBindingPatterns */) !== contextualType;
-            if (!isFromBindingPattern) {
-              const outerMapper = getMapperFromContext(cloneInferenceContext(outerContext, 1 /* NoDefault */));
-              const instantiatedType = instantiateType(contextualType, outerMapper);
-              const contextualSignature = getSingleCallSignature(instantiatedType);
-              const inferenceSourceType = contextualSignature && contextualSignature.typeParameters ? getOrCreateTypeFromSignature(getSignatureInstantiationWithoutFillingInTypeArguments(contextualSignature, contextualSignature.typeParameters)) : instantiatedType;
-              inferTypes(context.inferences, inferenceSourceType, inferenceTargetType, 128 /* ReturnType */);
-            }
-            const returnContext = createInferenceContext(signature.typeParameters, signature, context.flags);
-            const returnSourceType = instantiateType(contextualType, outerContext && outerContext.returnMapper);
-            inferTypes(returnContext.inferences, returnSourceType, inferenceTargetType);
-            context.returnMapper = some(returnContext.inferences, hasInferenceCandidates) ? getMapperFromContext(cloneInferredPartOfContext(returnContext)) : void 0;
-          }
-        }
-      }
-      const restType = getNonArrayRestType(signature);
-      const argCount = restType ? Math.min(getParameterCount(signature) - 1, args.length) : args.length;
-      if (restType && restType.flags & 262144 /* TypeParameter */) {
-        const info = find(context.inferences, (info2) => info2.typeParameter === restType);
-        if (info) {
-          info.impliedArity = findIndex(args, isSpreadArgument, argCount) < 0 ? args.length - argCount : void 0;
-        }
-      }
-      const thisType = getThisTypeOfSignature(signature);
-      if (thisType && couldContainTypeVariables(thisType)) {
-        const thisArgumentNode = getThisArgumentOfCall(node);
-        inferTypes(context.inferences, getThisArgumentType(thisArgumentNode), thisType);
-      }
-      for (let i = 0; i < argCount; i++) {
-        const arg = args[i];
-        if (arg.kind !== 231 /* OmittedExpression */ && !(checkMode & 32 /* IsForStringLiteralArgumentCompletions */ && hasSkipDirectInferenceFlag(arg))) {
-          const paramType = getTypeAtPosition(signature, i);
-          if (couldContainTypeVariables(paramType)) {
-            const argType = checkExpressionWithContextualType(arg, paramType, context, checkMode);
-            inferTypes(context.inferences, argType, paramType);
-          }
-        }
-      }
-      if (restType && couldContainTypeVariables(restType)) {
-        const spreadType = getSpreadArgumentType(args, argCount, args.length, restType, context, checkMode);
-        inferTypes(context.inferences, spreadType, restType);
-      }
-      return getInferredTypes(context);
-    }
-    function getMutableArrayOrTupleType(type) {
-      return type.flags & 1048576 /* Union */ ? mapType(type, getMutableArrayOrTupleType) : type.flags & 1 /* Any */ || isMutableArrayOrTuple(getBaseConstraintOfType(type) || type) ? type : isTupleType(type) ? createTupleType(
-        getElementTypes(type),
-        type.target.elementFlags,
-        /*readonly*/
-        false,
-        type.target.labeledElementDeclarations
-      ) : createTupleType([type], [8 /* Variadic */]);
-    }
-    function getSpreadArgumentType(args, index, argCount, restType, context, checkMode) {
-      const inConstContext = isConstTypeVariable(restType);
-      if (index >= argCount - 1) {
-        const arg = args[argCount - 1];
-        if (isSpreadArgument(arg)) {
-          const spreadType = arg.kind === 236 /* SyntheticExpression */ ? arg.type : checkExpressionWithContextualType(arg.expression, restType, context, checkMode);
-          if (isArrayLikeType(spreadType)) {
-            return getMutableArrayOrTupleType(spreadType);
-          }
-          return createArrayType(checkIteratedTypeOrElementType(33 /* Spread */, spreadType, undefinedType, arg.kind === 229 /* SpreadElement */ ? arg.expression : arg), inConstContext);
-        }
-      }
-      const types = [];
-      const flags = [];
-      const names = [];
-      for (let i = index; i < argCount; i++) {
-        const arg = args[i];
-        if (isSpreadArgument(arg)) {
-          const spreadType = arg.kind === 236 /* SyntheticExpression */ ? arg.type : checkExpression(arg.expression);
-          if (isArrayLikeType(spreadType)) {
-            types.push(spreadType);
-            flags.push(8 /* Variadic */);
-          } else {
-            types.push(checkIteratedTypeOrElementType(33 /* Spread */, spreadType, undefinedType, arg.kind === 229 /* SpreadElement */ ? arg.expression : arg));
-            flags.push(4 /* Rest */);
-          }
-        } else {
-          const contextualType = isTupleType(restType) ? getContextualTypeForElementExpression(restType, i - index, argCount - index) || unknownType : getIndexedAccessType(restType, getNumberLiteralType(i - index), 256 /* Contextual */);
-          const argType = checkExpressionWithContextualType(arg, contextualType, context, checkMode);
-          const hasPrimitiveContextualType = inConstContext || maybeTypeOfKind(contextualType, 402784252 /* Primitive */ | 4194304 /* Index */ | 134217728 /* TemplateLiteral */ | 268435456 /* StringMapping */);
-          types.push(hasPrimitiveContextualType ? getRegularTypeOfLiteralType(argType) : getWidenedLiteralType(argType));
-          flags.push(1 /* Required */);
-        }
-        if (arg.kind === 236 /* SyntheticExpression */ && arg.tupleNameSource) {
-          names.push(arg.tupleNameSource);
-        }
-      }
-      return createTupleType(types, flags, inConstContext, length(names) === length(types) ? names : void 0);
-    }
-    function checkTypeArguments(signature, typeArgumentNodes, reportErrors2, headMessage) {
-      const isJavascript = isInJSFile(signature.declaration);
-      const typeParameters = signature.typeParameters;
-      const typeArgumentTypes = fillMissingTypeArguments(map(typeArgumentNodes, getTypeFromTypeNode), typeParameters, getMinTypeArgumentCount(typeParameters), isJavascript);
-      let mapper;
-      for (let i = 0; i < typeArgumentNodes.length; i++) {
-        Debug.assert(typeParameters[i] !== void 0, "Should not call checkTypeArguments with too many type arguments");
-        const constraint = getConstraintOfTypeParameter(typeParameters[i]);
-        if (constraint) {
-          const errorInfo = reportErrors2 && headMessage ? () => chainDiagnosticMessages(
-            /*details*/
-            void 0,
-            Diagnostics.Type_0_does_not_satisfy_the_constraint_1
-          ) : void 0;
-          const typeArgumentHeadMessage = headMessage || Diagnostics.Type_0_does_not_satisfy_the_constraint_1;
-          if (!mapper) {
-            mapper = createTypeMapper(typeParameters, typeArgumentTypes);
-          }
-          const typeArgument = typeArgumentTypes[i];
-          if (!checkTypeAssignableTo(
-            typeArgument,
-            getTypeWithThisArgument(instantiateType(constraint, mapper), typeArgument),
-            reportErrors2 ? typeArgumentNodes[i] : void 0,
-            typeArgumentHeadMessage,
-            errorInfo
-          )) {
-            return void 0;
-          }
-        }
-      }
-      return typeArgumentTypes;
-    }
-    function getJsxReferenceKind(node) {
-      if (isJsxIntrinsicTagName(node.tagName)) {
-        return 2 /* Mixed */;
-      }
-      const tagType = getApparentType(checkExpression(node.tagName));
-      if (length(getSignaturesOfType(tagType, 1 /* Construct */))) {
-        return 0 /* Component */;
-      }
-      if (length(getSignaturesOfType(tagType, 0 /* Call */))) {
-        return 1 /* Function */;
-      }
-      return 2 /* Mixed */;
-    }
-    function checkApplicableSignatureForJsxOpeningLikeElement(node, signature, relation, checkMode, reportErrors2, containingMessageChain, errorOutputContainer) {
-      const paramType = getEffectiveFirstArgumentForJsxSignature(signature, node);
-      const attributesType = checkExpressionWithContextualType(
-        node.attributes,
-        paramType,
-        /*inferenceContext*/
-        void 0,
-        checkMode
-      );
-      return checkTagNameDoesNotExpectTooManyArguments() && checkTypeRelatedToAndOptionallyElaborate(
-        attributesType,
-        paramType,
-        relation,
-        reportErrors2 ? node.tagName : void 0,
-        node.attributes,
-        /*headMessage*/
-        void 0,
-        containingMessageChain,
-        errorOutputContainer
-      );
-      function checkTagNameDoesNotExpectTooManyArguments() {
-        var _a;
-        if (getJsxNamespaceContainerForImplicitImport(node)) {
-          return true;
-        }
-        const tagType = (isJsxOpeningElement(node) || isJsxSelfClosingElement(node)) && !(isJsxIntrinsicTagName(node.tagName) || isJsxNamespacedName(node.tagName)) ? checkExpression(node.tagName) : void 0;
-        if (!tagType) {
-          return true;
-        }
-        const tagCallSignatures = getSignaturesOfType(tagType, 0 /* Call */);
-        if (!length(tagCallSignatures)) {
-          return true;
-        }
-        const factory2 = getJsxFactoryEntity(node);
-        if (!factory2) {
-          return true;
-        }
-        const factorySymbol = resolveEntityName(
-          factory2,
-          111551 /* Value */,
-          /*ignoreErrors*/
-          true,
-          /*dontResolveAlias*/
-          false,
-          node
-        );
-        if (!factorySymbol) {
-          return true;
-        }
-        const factoryType = getTypeOfSymbol(factorySymbol);
-        const callSignatures = getSignaturesOfType(factoryType, 0 /* Call */);
-        if (!length(callSignatures)) {
-          return true;
-        }
-        let hasFirstParamSignatures = false;
-        let maxParamCount = 0;
-        for (const sig of callSignatures) {
-          const firstparam = getTypeAtPosition(sig, 0);
-          const signaturesOfParam = getSignaturesOfType(firstparam, 0 /* Call */);
-          if (!length(signaturesOfParam))
-            continue;
-          for (const paramSig of signaturesOfParam) {
-            hasFirstParamSignatures = true;
-            if (hasEffectiveRestParameter(paramSig)) {
-              return true;
-            }
-            const paramCount = getParameterCount(paramSig);
-            if (paramCount > maxParamCount) {
-              maxParamCount = paramCount;
-            }
-          }
-        }
-        if (!hasFirstParamSignatures) {
-          return true;
-        }
-        let absoluteMinArgCount = Infinity;
-        for (const tagSig of tagCallSignatures) {
-          const tagRequiredArgCount = getMinArgumentCount(tagSig);
-          if (tagRequiredArgCount < absoluteMinArgCount) {
-            absoluteMinArgCount = tagRequiredArgCount;
-          }
-        }
-        if (absoluteMinArgCount <= maxParamCount) {
-          return true;
-        }
-        if (reportErrors2) {
-          const diag2 = createDiagnosticForNode(node.tagName, Diagnostics.Tag_0_expects_at_least_1_arguments_but_the_JSX_factory_2_provides_at_most_3, entityNameToString(node.tagName), absoluteMinArgCount, entityNameToString(factory2), maxParamCount);
-          const tagNameDeclaration = (_a = getSymbolAtLocation(node.tagName)) == null ? void 0 : _a.valueDeclaration;
-          if (tagNameDeclaration) {
-            addRelatedInfo(diag2, createDiagnosticForNode(tagNameDeclaration, Diagnostics._0_is_declared_here, entityNameToString(node.tagName)));
-          }
-          if (errorOutputContainer && errorOutputContainer.skipLogging) {
-            (errorOutputContainer.errors || (errorOutputContainer.errors = [])).push(diag2);
-          }
-          if (!errorOutputContainer.skipLogging) {
-            diagnostics.add(diag2);
-          }
-        }
-        return false;
-      }
-    }
-    function getSignatureApplicabilityError(node, args, signature, relation, checkMode, reportErrors2, containingMessageChain) {
-      const errorOutputContainer = { errors: void 0, skipLogging: true };
-      if (isJsxOpeningLikeElement(node)) {
-        if (!checkApplicableSignatureForJsxOpeningLikeElement(node, signature, relation, checkMode, reportErrors2, containingMessageChain, errorOutputContainer)) {
-          Debug.assert(!reportErrors2 || !!errorOutputContainer.errors, "jsx should have errors when reporting errors");
-          return errorOutputContainer.errors || emptyArray;
-        }
-        return void 0;
-      }
-      const thisType = getThisTypeOfSignature(signature);
-      if (thisType && thisType !== voidType && !(isNewExpression(node) || isCallExpression(node) && isSuperProperty(node.expression))) {
-        const thisArgumentNode = getThisArgumentOfCall(node);
-        const thisArgumentType = getThisArgumentType(thisArgumentNode);
-        const errorNode = reportErrors2 ? thisArgumentNode || node : void 0;
-        const headMessage2 = Diagnostics.The_this_context_of_type_0_is_not_assignable_to_method_s_this_of_type_1;
-        if (!checkTypeRelatedTo(thisArgumentType, thisType, relation, errorNode, headMessage2, containingMessageChain, errorOutputContainer)) {
-          Debug.assert(!reportErrors2 || !!errorOutputContainer.errors, "this parameter should have errors when reporting errors");
-          return errorOutputContainer.errors || emptyArray;
-        }
-      }
-      const headMessage = Diagnostics.Argument_of_type_0_is_not_assignable_to_parameter_of_type_1;
-      const restType = getNonArrayRestType(signature);
-      const argCount = restType ? Math.min(getParameterCount(signature) - 1, args.length) : args.length;
-      for (let i = 0; i < argCount; i++) {
-        const arg = args[i];
-        if (arg.kind !== 231 /* OmittedExpression */) {
-          const paramType = getTypeAtPosition(signature, i);
-          const argType = checkExpressionWithContextualType(
-            arg,
-            paramType,
-            /*inferenceContext*/
-            void 0,
-            checkMode
-          );
-          const checkArgType = checkMode & 4 /* SkipContextSensitive */ ? getRegularTypeOfObjectLiteral(argType) : argType;
-          if (!checkTypeRelatedToAndOptionallyElaborate(checkArgType, paramType, relation, reportErrors2 ? arg : void 0, arg, headMessage, containingMessageChain, errorOutputContainer)) {
-            Debug.assert(!reportErrors2 || !!errorOutputContainer.errors, "parameter should have errors when reporting errors");
-            maybeAddMissingAwaitInfo(arg, checkArgType, paramType);
-            return errorOutputContainer.errors || emptyArray;
-          }
-        }
-      }
-      if (restType) {
-        const spreadType = getSpreadArgumentType(
-          args,
-          argCount,
-          args.length,
-          restType,
-          /*context*/
-          void 0,
-          checkMode
-        );
-        const restArgCount = args.length - argCount;
-        const errorNode = !reportErrors2 ? void 0 : restArgCount === 0 ? node : restArgCount === 1 ? args[argCount] : setTextRangePosEnd(createSyntheticExpression(node, spreadType), args[argCount].pos, args[args.length - 1].end);
-        if (!checkTypeRelatedTo(
-          spreadType,
-          restType,
-          relation,
-          errorNode,
-          headMessage,
-          /*containingMessageChain*/
-          void 0,
-          errorOutputContainer
-        )) {
-          Debug.assert(!reportErrors2 || !!errorOutputContainer.errors, "rest parameter should have errors when reporting errors");
-          maybeAddMissingAwaitInfo(errorNode, spreadType, restType);
-          return errorOutputContainer.errors || emptyArray;
-        }
-      }
-      return void 0;
-      function maybeAddMissingAwaitInfo(errorNode, source, target) {
-        if (errorNode && reportErrors2 && errorOutputContainer.errors && errorOutputContainer.errors.length) {
-          if (getAwaitedTypeOfPromise(target)) {
-            return;
-          }
-          const awaitedTypeOfSource = getAwaitedTypeOfPromise(source);
-          if (awaitedTypeOfSource && isTypeRelatedTo(awaitedTypeOfSource, target, relation)) {
-            addRelatedInfo(errorOutputContainer.errors[0], createDiagnosticForNode(errorNode, Diagnostics.Did_you_forget_to_use_await));
-          }
-        }
-      }
-    }
-    function getThisArgumentOfCall(node) {
-      const expression = node.kind === 212 /* CallExpression */ ? node.expression : node.kind === 214 /* TaggedTemplateExpression */ ? node.tag : void 0;
-      if (expression) {
-        const callee = skipOuterExpressions(expression);
-        if (isAccessExpression(callee)) {
-          return callee.expression;
-        }
-      }
-    }
-    function createSyntheticExpression(parent2, type, isSpread, tupleNameSource) {
-      const result = parseNodeFactory.createSyntheticExpression(type, isSpread, tupleNameSource);
-      setTextRange(result, parent2);
-      setParent(result, parent2);
-      return result;
-    }
-    function getEffectiveCallArguments(node) {
-      if (node.kind === 214 /* TaggedTemplateExpression */) {
-        const template = node.template;
-        const args2 = [createSyntheticExpression(template, getGlobalTemplateStringsArrayType())];
-        if (template.kind === 227 /* TemplateExpression */) {
-          forEach(template.templateSpans, (span) => {
-            args2.push(span.expression);
-          });
-        }
-        return args2;
-      }
-      if (node.kind === 169 /* Decorator */) {
-        return getEffectiveDecoratorArguments(node);
-      }
-      if (isJsxOpeningLikeElement(node)) {
-        return node.attributes.properties.length > 0 || isJsxOpeningElement(node) && node.parent.children.length > 0 ? [node.attributes] : emptyArray;
-      }
-      const args = node.arguments || emptyArray;
-      const spreadIndex = getSpreadArgumentIndex(args);
-      if (spreadIndex >= 0) {
-        const effectiveArgs = args.slice(0, spreadIndex);
-        for (let i = spreadIndex; i < args.length; i++) {
-          const arg = args[i];
-          const spreadType = arg.kind === 229 /* SpreadElement */ && (flowLoopCount ? checkExpression(arg.expression) : checkExpressionCached(arg.expression));
-          if (spreadType && isTupleType(spreadType)) {
-            forEach(getElementTypes(spreadType), (t, i2) => {
-              var _a;
-              const flags = spreadType.target.elementFlags[i2];
-              const syntheticArg = createSyntheticExpression(
-                arg,
-                flags & 4 /* Rest */ ? createArrayType(t) : t,
-                !!(flags & 12 /* Variable */),
-                (_a = spreadType.target.labeledElementDeclarations) == null ? void 0 : _a[i2]
-              );
-              effectiveArgs.push(syntheticArg);
-            });
-          } else {
-            effectiveArgs.push(arg);
-          }
-        }
-        return effectiveArgs;
-      }
-      return args;
-    }
-    function getEffectiveDecoratorArguments(node) {
-      const expr = node.expression;
-      const signature = getDecoratorCallSignature(node);
-      if (signature) {
-        const args = [];
-        for (const param of signature.parameters) {
-          const type = getTypeOfSymbol(param);
-          args.push(createSyntheticExpression(expr, type));
-        }
-        return args;
-      }
-      return Debug.fail();
-    }
-    function getDecoratorArgumentCount(node, signature) {
-      return compilerOptions.experimentalDecorators ? getLegacyDecoratorArgumentCount(node, signature) : 2;
-    }
-    function getLegacyDecoratorArgumentCount(node, signature) {
-      switch (node.parent.kind) {
-        case 262 /* ClassDeclaration */:
-        case 230 /* ClassExpression */:
-          return 1;
-        case 171 /* PropertyDeclaration */:
-          return hasAccessorModifier(node.parent) ? 3 : 2;
-        case 173 /* MethodDeclaration */:
-        case 176 /* GetAccessor */:
-        case 177 /* SetAccessor */:
-          return languageVersion === 0 /* ES3 */ || signature.parameters.length <= 2 ? 2 : 3;
-        case 168 /* Parameter */:
-          return 3;
-        default:
-          return Debug.fail();
-      }
-    }
-    function getDiagnosticSpanForCallNode(node, doNotIncludeArguments) {
-      let start;
-      let length2;
-      const sourceFile = getSourceFileOfNode(node);
-      if (isPropertyAccessExpression(node.expression)) {
-        const nameSpan = getErrorSpanForNode(sourceFile, node.expression.name);
-        start = nameSpan.start;
-        length2 = doNotIncludeArguments ? nameSpan.length : node.end - start;
-      } else {
-        const expressionSpan = getErrorSpanForNode(sourceFile, node.expression);
-        start = expressionSpan.start;
-        length2 = doNotIncludeArguments ? expressionSpan.length : node.end - start;
-      }
-      return { start, length: length2, sourceFile };
-    }
-    function getDiagnosticForCallNode(node, message, ...args) {
-      if (isCallExpression(node)) {
-        const { sourceFile, start, length: length2 } = getDiagnosticSpanForCallNode(node);
-        if ("message" in message) {
-          return createFileDiagnostic(sourceFile, start, length2, message, ...args);
-        }
-        return createDiagnosticForFileFromMessageChain(sourceFile, message);
-      } else {
-        if ("message" in message) {
-          return createDiagnosticForNode(node, message, ...args);
-        }
-        return createDiagnosticForNodeFromMessageChain(getSourceFileOfNode(node), node, message);
-      }
-    }
-    function isPromiseResolveArityError(node) {
-      if (!isCallExpression(node) || !isIdentifier(node.expression))
-        return false;
-      const symbol = resolveName(
-        node.expression,
-        node.expression.escapedText,
-        111551 /* Value */,
-        /*nameNotFoundMessage*/
-        void 0,
-        /*nameArg*/
-        void 0,
-        /*isUse*/
-        false
-      );
-      const decl = symbol == null ? void 0 : symbol.valueDeclaration;
-      if (!decl || !isParameter(decl) || !isFunctionExpressionOrArrowFunction(decl.parent) || !isNewExpression(decl.parent.parent) || !isIdentifier(decl.parent.parent.expression)) {
-        return false;
-      }
-      const globalPromiseSymbol = getGlobalPromiseConstructorSymbol(
-        /*reportErrors*/
-        false
-      );
-      if (!globalPromiseSymbol)
-        return false;
-      const constructorSymbol = getSymbolAtLocation(
-        decl.parent.parent.expression,
-        /*ignoreErrors*/
-        true
-      );
-      return constructorSymbol === globalPromiseSymbol;
-    }
-    function getArgumentArityError(node, signatures, args, headMessage) {
-      var _a;
-      const spreadIndex = getSpreadArgumentIndex(args);
-      if (spreadIndex > -1) {
-        return createDiagnosticForNode(args[spreadIndex], Diagnostics.A_spread_argument_must_either_have_a_tuple_type_or_be_passed_to_a_rest_parameter);
-      }
-      let min2 = Number.POSITIVE_INFINITY;
-      let max = Number.NEGATIVE_INFINITY;
-      let maxBelow = Number.NEGATIVE_INFINITY;
-      let minAbove = Number.POSITIVE_INFINITY;
-      let closestSignature;
-      for (const sig of signatures) {
-        const minParameter = getMinArgumentCount(sig);
-        const maxParameter = getParameterCount(sig);
-        if (minParameter < min2) {
-          min2 = minParameter;
-          closestSignature = sig;
-        }
-        max = Math.max(max, maxParameter);
-        if (minParameter < args.length && minParameter > maxBelow)
-          maxBelow = minParameter;
-        if (args.length < maxParameter && maxParameter < minAbove)
-          minAbove = maxParameter;
-      }
-      const hasRestParameter2 = some(signatures, hasEffectiveRestParameter);
-      const parameterRange = hasRestParameter2 ? min2 : min2 < max ? min2 + "-" + max : min2;
-      const isVoidPromiseError = !hasRestParameter2 && parameterRange === 1 && args.length === 0 && isPromiseResolveArityError(node);
-      if (isVoidPromiseError && isInJSFile(node)) {
-        return getDiagnosticForCallNode(node, Diagnostics.Expected_1_argument_but_got_0_new_Promise_needs_a_JSDoc_hint_to_produce_a_resolve_that_can_be_called_without_arguments);
-      }
-      const error2 = isDecorator(node) ? hasRestParameter2 ? Diagnostics.The_runtime_will_invoke_the_decorator_with_1_arguments_but_the_decorator_expects_at_least_0 : Diagnostics.The_runtime_will_invoke_the_decorator_with_1_arguments_but_the_decorator_expects_0 : hasRestParameter2 ? Diagnostics.Expected_at_least_0_arguments_but_got_1 : isVoidPromiseError ? Diagnostics.Expected_0_arguments_but_got_1_Did_you_forget_to_include_void_in_your_type_argument_to_Promise : Diagnostics.Expected_0_arguments_but_got_1;
-      if (min2 < args.length && args.length < max) {
-        if (headMessage) {
-          let chain = chainDiagnosticMessages(
-            /*details*/
-            void 0,
-            Diagnostics.No_overload_expects_0_arguments_but_overloads_do_exist_that_expect_either_1_or_2_arguments,
-            args.length,
-            maxBelow,
-            minAbove
-          );
-          chain = chainDiagnosticMessages(chain, headMessage);
-          return getDiagnosticForCallNode(node, chain);
-        }
-        return getDiagnosticForCallNode(node, Diagnostics.No_overload_expects_0_arguments_but_overloads_do_exist_that_expect_either_1_or_2_arguments, args.length, maxBelow, minAbove);
-      } else if (args.length < min2) {
-        let diagnostic;
-        if (headMessage) {
-          let chain = chainDiagnosticMessages(
-            /*details*/
-            void 0,
-            error2,
-            parameterRange,
-            args.length
-          );
-          chain = chainDiagnosticMessages(chain, headMessage);
-          diagnostic = getDiagnosticForCallNode(node, chain);
-        } else {
-          diagnostic = getDiagnosticForCallNode(node, error2, parameterRange, args.length);
-        }
-        const parameter = (_a = closestSignature == null ? void 0 : closestSignature.declaration) == null ? void 0 : _a.parameters[closestSignature.thisParameter ? args.length + 1 : args.length];
-        if (parameter) {
-          const messageAndArgs = isBindingPattern(parameter.name) ? [Diagnostics.An_argument_matching_this_binding_pattern_was_not_provided] : isRestParameter(parameter) ? [Diagnostics.Arguments_for_the_rest_parameter_0_were_not_provided, idText(getFirstIdentifier(parameter.name))] : [Diagnostics.An_argument_for_0_was_not_provided, !parameter.name ? args.length : idText(getFirstIdentifier(parameter.name))];
-          const parameterError = createDiagnosticForNode(parameter, ...messageAndArgs);
-          return addRelatedInfo(diagnostic, parameterError);
-        }
-        return diagnostic;
-      } else {
-        const errorSpan = factory.createNodeArray(args.slice(max));
-        const pos = first(errorSpan).pos;
-        let end = last(errorSpan).end;
-        if (end === pos) {
-          end++;
-        }
-        setTextRangePosEnd(errorSpan, pos, end);
-        if (headMessage) {
-          let chain = chainDiagnosticMessages(
-            /*details*/
-            void 0,
-            error2,
-            parameterRange,
-            args.length
-          );
-          chain = chainDiagnosticMessages(chain, headMessage);
-          return createDiagnosticForNodeArrayFromMessageChain(getSourceFileOfNode(node), errorSpan, chain);
-        }
-        return createDiagnosticForNodeArray(getSourceFileOfNode(node), errorSpan, error2, parameterRange, args.length);
-      }
-    }
-    function getTypeArgumentArityError(node, signatures, typeArguments, headMessage) {
-      const argCount = typeArguments.length;
-      if (signatures.length === 1) {
-        const sig = signatures[0];
-        const min2 = getMinTypeArgumentCount(sig.typeParameters);
-        const max = length(sig.typeParameters);
-        if (headMessage) {
-          let chain = chainDiagnosticMessages(
-            /*details*/
-            void 0,
-            Diagnostics.Expected_0_type_arguments_but_got_1,
-            min2 < max ? min2 + "-" + max : min2,
-            argCount
-          );
-          chain = chainDiagnosticMessages(chain, headMessage);
-          return createDiagnosticForNodeArrayFromMessageChain(getSourceFileOfNode(node), typeArguments, chain);
-        }
-        return createDiagnosticForNodeArray(getSourceFileOfNode(node), typeArguments, Diagnostics.Expected_0_type_arguments_but_got_1, min2 < max ? min2 + "-" + max : min2, argCount);
-      }
-      let belowArgCount = -Infinity;
-      let aboveArgCount = Infinity;
-      for (const sig of signatures) {
-        const min2 = getMinTypeArgumentCount(sig.typeParameters);
-        const max = length(sig.typeParameters);
-        if (min2 > argCount) {
-          aboveArgCount = Math.min(aboveArgCount, min2);
-        } else if (max < argCount) {
-          belowArgCount = Math.max(belowArgCount, max);
-        }
-      }
-      if (belowArgCount !== -Infinity && aboveArgCount !== Infinity) {
-        if (headMessage) {
-          let chain = chainDiagnosticMessages(
-            /*details*/
-            void 0,
-            Diagnostics.No_overload_expects_0_type_arguments_but_overloads_do_exist_that_expect_either_1_or_2_type_arguments,
-            argCount,
-            belowArgCount,
-            aboveArgCount
-          );
-          chain = chainDiagnosticMessages(chain, headMessage);
-          return createDiagnosticForNodeArrayFromMessageChain(getSourceFileOfNode(node), typeArguments, chain);
-        }
-        return createDiagnosticForNodeArray(getSourceFileOfNode(node), typeArguments, Diagnostics.No_overload_expects_0_type_arguments_but_overloads_do_exist_that_expect_either_1_or_2_type_arguments, argCount, belowArgCount, aboveArgCount);
-      }
-      if (headMessage) {
-        let chain = chainDiagnosticMessages(
-          /*details*/
-          void 0,
-          Diagnostics.Expected_0_type_arguments_but_got_1,
-          belowArgCount === -Infinity ? aboveArgCount : belowArgCount,
-          argCount
-        );
-        chain = chainDiagnosticMessages(chain, headMessage);
-        return createDiagnosticForNodeArrayFromMessageChain(getSourceFileOfNode(node), typeArguments, chain);
-      }
-      return createDiagnosticForNodeArray(getSourceFileOfNode(node), typeArguments, Diagnostics.Expected_0_type_arguments_but_got_1, belowArgCount === -Infinity ? aboveArgCount : belowArgCount, argCount);
-    }
-    function resolveCall(node, signatures, candidatesOutArray, checkMode, callChainFlags, headMessage) {
-      const isTaggedTemplate = node.kind === 214 /* TaggedTemplateExpression */;
-      const isDecorator2 = node.kind === 169 /* Decorator */;
-      const isJsxOpeningOrSelfClosingElement = isJsxOpeningLikeElement(node);
-      const reportErrors2 = !isInferencePartiallyBlocked && !candidatesOutArray;
-      let typeArguments;
-      if (!isDecorator2 && !isSuperCall(node)) {
-        typeArguments = node.typeArguments;
-        if (isTaggedTemplate || isJsxOpeningOrSelfClosingElement || node.expression.kind !== 108 /* SuperKeyword */) {
-          forEach(typeArguments, checkSourceElement);
-        }
-      }
-      const candidates = candidatesOutArray || [];
-      reorderCandidates(signatures, candidates, callChainFlags);
-      if (!candidates.length) {
-        if (reportErrors2) {
-          diagnostics.add(getDiagnosticForCallNode(node, Diagnostics.Call_target_does_not_contain_any_signatures));
-        }
-        return resolveErrorCall(node);
-      }
-      const args = getEffectiveCallArguments(node);
-      const isSingleNonGenericCandidate = candidates.length === 1 && !candidates[0].typeParameters;
-      let argCheckMode = !isDecorator2 && !isSingleNonGenericCandidate && some(args, isContextSensitive) ? 4 /* SkipContextSensitive */ : 0 /* Normal */;
-      argCheckMode |= checkMode & 32 /* IsForStringLiteralArgumentCompletions */;
-      let candidatesForArgumentError;
-      let candidateForArgumentArityError;
-      let candidateForTypeArgumentError;
-      let result;
-      const signatureHelpTrailingComma = !!(checkMode & 16 /* IsForSignatureHelp */) && node.kind === 212 /* CallExpression */ && node.arguments.hasTrailingComma;
-      if (candidates.length > 1) {
-        result = chooseOverload(candidates, subtypeRelation, isSingleNonGenericCandidate, signatureHelpTrailingComma);
-      }
-      if (!result) {
-        result = chooseOverload(candidates, assignableRelation, isSingleNonGenericCandidate, signatureHelpTrailingComma);
-      }
-      if (result) {
-        return result;
-      }
-      result = getCandidateForOverloadFailure(node, candidates, args, !!candidatesOutArray, checkMode);
-      getNodeLinks(node).resolvedSignature = result;
-      if (reportErrors2) {
-        if (candidatesForArgumentError) {
-          if (candidatesForArgumentError.length === 1 || candidatesForArgumentError.length > 3) {
-            const last2 = candidatesForArgumentError[candidatesForArgumentError.length - 1];
-            let chain;
-            if (candidatesForArgumentError.length > 3) {
-              chain = chainDiagnosticMessages(chain, Diagnostics.The_last_overload_gave_the_following_error);
-              chain = chainDiagnosticMessages(chain, Diagnostics.No_overload_matches_this_call);
-            }
-            if (headMessage) {
-              chain = chainDiagnosticMessages(chain, headMessage);
-            }
-            const diags = getSignatureApplicabilityError(
-              node,
-              args,
-              last2,
-              assignableRelation,
-              0 /* Normal */,
-              /*reportErrors*/
-              true,
-              () => chain
-            );
-            if (diags) {
-              for (const d of diags) {
-                if (last2.declaration && candidatesForArgumentError.length > 3) {
-                  addRelatedInfo(d, createDiagnosticForNode(last2.declaration, Diagnostics.The_last_overload_is_declared_here));
-                }
-                addImplementationSuccessElaboration(last2, d);
-                diagnostics.add(d);
-              }
-            } else {
-              Debug.fail("No error for last overload signature");
-            }
-          } else {
-            const allDiagnostics = [];
-            let max = 0;
-            let min2 = Number.MAX_VALUE;
-            let minIndex = 0;
-            let i = 0;
-            for (const c of candidatesForArgumentError) {
-              const chain2 = () => chainDiagnosticMessages(
-                /*details*/
-                void 0,
-                Diagnostics.Overload_0_of_1_2_gave_the_following_error,
-                i + 1,
-                candidates.length,
-                signatureToString(c)
-              );
-              const diags2 = getSignatureApplicabilityError(
-                node,
-                args,
-                c,
-                assignableRelation,
-                0 /* Normal */,
-                /*reportErrors*/
-                true,
-                chain2
-              );
-              if (diags2) {
-                if (diags2.length <= min2) {
-                  min2 = diags2.length;
-                  minIndex = i;
-                }
-                max = Math.max(max, diags2.length);
-                allDiagnostics.push(diags2);
-              } else {
-                Debug.fail("No error for 3 or fewer overload signatures");
-              }
-              i++;
-            }
-            const diags = max > 1 ? allDiagnostics[minIndex] : flatten(allDiagnostics);
-            Debug.assert(diags.length > 0, "No errors reported for 3 or fewer overload signatures");
-            let chain = chainDiagnosticMessages(
-              map(diags, createDiagnosticMessageChainFromDiagnostic),
-              Diagnostics.No_overload_matches_this_call
-            );
-            if (headMessage) {
-              chain = chainDiagnosticMessages(chain, headMessage);
-            }
-            const related = [...flatMap(diags, (d) => d.relatedInformation)];
-            let diag2;
-            if (every(diags, (d) => d.start === diags[0].start && d.length === diags[0].length && d.file === diags[0].file)) {
-              const { file, start, length: length2 } = diags[0];
-              diag2 = { file, start, length: length2, code: chain.code, category: chain.category, messageText: chain, relatedInformation: related };
-            } else {
-              diag2 = createDiagnosticForNodeFromMessageChain(getSourceFileOfNode(node), node, chain, related);
-            }
-            addImplementationSuccessElaboration(candidatesForArgumentError[0], diag2);
-            diagnostics.add(diag2);
-          }
-        } else if (candidateForArgumentArityError) {
-          diagnostics.add(getArgumentArityError(node, [candidateForArgumentArityError], args, headMessage));
-        } else if (candidateForTypeArgumentError) {
-          checkTypeArguments(
-            candidateForTypeArgumentError,
-            node.typeArguments,
-            /*reportErrors*/
-            true,
-            headMessage
-          );
-        } else {
-          const signaturesWithCorrectTypeArgumentArity = filter(signatures, (s) => hasCorrectTypeArgumentArity(s, typeArguments));
-          if (signaturesWithCorrectTypeArgumentArity.length === 0) {
-            diagnostics.add(getTypeArgumentArityError(node, signatures, typeArguments, headMessage));
-          } else {
-            diagnostics.add(getArgumentArityError(node, signaturesWithCorrectTypeArgumentArity, args, headMessage));
-          }
-        }
-      }
-      return result;
-      function addImplementationSuccessElaboration(failed, diagnostic) {
-        var _a, _b;
-        const oldCandidatesForArgumentError = candidatesForArgumentError;
-        const oldCandidateForArgumentArityError = candidateForArgumentArityError;
-        const oldCandidateForTypeArgumentError = candidateForTypeArgumentError;
-        const failedSignatureDeclarations = ((_b = (_a = failed.declaration) == null ? void 0 : _a.symbol) == null ? void 0 : _b.declarations) || emptyArray;
-        const isOverload = failedSignatureDeclarations.length > 1;
-        const implDecl = isOverload ? find(failedSignatureDeclarations, (d) => isFunctionLikeDeclaration(d) && nodeIsPresent(d.body)) : void 0;
-        if (implDecl) {
-          const candidate = getSignatureFromDeclaration(implDecl);
-          const isSingleNonGenericCandidate2 = !candidate.typeParameters;
-          if (chooseOverload([candidate], assignableRelation, isSingleNonGenericCandidate2)) {
-            addRelatedInfo(diagnostic, createDiagnosticForNode(implDecl, Diagnostics.The_call_would_have_succeeded_against_this_implementation_but_implementation_signatures_of_overloads_are_not_externally_visible));
-          }
-        }
-        candidatesForArgumentError = oldCandidatesForArgumentError;
-        candidateForArgumentArityError = oldCandidateForArgumentArityError;
-        candidateForTypeArgumentError = oldCandidateForTypeArgumentError;
-      }
-      function chooseOverload(candidates2, relation, isSingleNonGenericCandidate2, signatureHelpTrailingComma2 = false) {
-        candidatesForArgumentError = void 0;
-        candidateForArgumentArityError = void 0;
-        candidateForTypeArgumentError = void 0;
-        if (isSingleNonGenericCandidate2) {
-          const candidate = candidates2[0];
-          if (some(typeArguments) || !hasCorrectArity(node, args, candidate, signatureHelpTrailingComma2)) {
-            return void 0;
-          }
-          if (getSignatureApplicabilityError(
-            node,
-            args,
-            candidate,
-            relation,
-            0 /* Normal */,
-            /*reportErrors*/
-            false,
-            /*containingMessageChain*/
-            void 0
-          )) {
-            candidatesForArgumentError = [candidate];
-            return void 0;
-          }
-          return candidate;
-        }
-        for (let candidateIndex = 0; candidateIndex < candidates2.length; candidateIndex++) {
-          const candidate = candidates2[candidateIndex];
-          if (!hasCorrectTypeArgumentArity(candidate, typeArguments) || !hasCorrectArity(node, args, candidate, signatureHelpTrailingComma2)) {
-            continue;
-          }
-          let checkCandidate;
-          let inferenceContext;
-          if (candidate.typeParameters) {
-            let typeArgumentTypes;
-            if (some(typeArguments)) {
-              typeArgumentTypes = checkTypeArguments(
-                candidate,
-                typeArguments,
-                /*reportErrors*/
-                false
-              );
-              if (!typeArgumentTypes) {
-                candidateForTypeArgumentError = candidate;
-                continue;
-              }
-            } else {
-              inferenceContext = createInferenceContext(
-                candidate.typeParameters,
-                candidate,
-                /*flags*/
-                isInJSFile(node) ? 2 /* AnyDefault */ : 0 /* None */
-              );
-              typeArgumentTypes = inferTypeArguments(node, candidate, args, argCheckMode | 8 /* SkipGenericFunctions */, inferenceContext);
-              argCheckMode |= inferenceContext.flags & 4 /* SkippedGenericFunction */ ? 8 /* SkipGenericFunctions */ : 0 /* Normal */;
-            }
-            checkCandidate = getSignatureInstantiation(candidate, typeArgumentTypes, isInJSFile(candidate.declaration), inferenceContext && inferenceContext.inferredTypeParameters);
-            if (getNonArrayRestType(candidate) && !hasCorrectArity(node, args, checkCandidate, signatureHelpTrailingComma2)) {
-              candidateForArgumentArityError = checkCandidate;
-              continue;
-            }
-          } else {
-            checkCandidate = candidate;
-          }
-          if (getSignatureApplicabilityError(
-            node,
-            args,
-            checkCandidate,
-            relation,
-            argCheckMode,
-            /*reportErrors*/
-            false,
-            /*containingMessageChain*/
-            void 0
-          )) {
-            (candidatesForArgumentError || (candidatesForArgumentError = [])).push(checkCandidate);
-            continue;
-          }
-          if (argCheckMode) {
-            argCheckMode = checkMode & 32 /* IsForStringLiteralArgumentCompletions */;
-            if (inferenceContext) {
-              const typeArgumentTypes = inferTypeArguments(node, candidate, args, argCheckMode, inferenceContext);
-              checkCandidate = getSignatureInstantiation(candidate, typeArgumentTypes, isInJSFile(candidate.declaration), inferenceContext.inferredTypeParameters);
-              if (getNonArrayRestType(candidate) && !hasCorrectArity(node, args, checkCandidate, signatureHelpTrailingComma2)) {
-                candidateForArgumentArityError = checkCandidate;
-                continue;
-              }
-            }
-            if (getSignatureApplicabilityError(
-              node,
-              args,
-              checkCandidate,
-              relation,
-              argCheckMode,
-              /*reportErrors*/
-              false,
-              /*containingMessageChain*/
-              void 0
-            )) {
-              (candidatesForArgumentError || (candidatesForArgumentError = [])).push(checkCandidate);
-              continue;
-            }
-          }
-          candidates2[candidateIndex] = checkCandidate;
-          return checkCandidate;
-        }
-        return void 0;
-      }
-    }
-    function getCandidateForOverloadFailure(node, candidates, args, hasCandidatesOutArray, checkMode) {
-      Debug.assert(candidates.length > 0);
-      checkNodeDeferred(node);
-      return hasCandidatesOutArray || candidates.length === 1 || candidates.some((c) => !!c.typeParameters) ? pickLongestCandidateSignature(node, candidates, args, checkMode) : createUnionOfSignaturesForOverloadFailure(candidates);
-    }
-    function createUnionOfSignaturesForOverloadFailure(candidates) {
-      const thisParameters = mapDefined(candidates, (c) => c.thisParameter);
-      let thisParameter;
-      if (thisParameters.length) {
-        thisParameter = createCombinedSymbolFromTypes(thisParameters, thisParameters.map(getTypeOfParameter));
-      }
-      const { min: minArgumentCount, max: maxNonRestParam } = minAndMax(candidates, getNumNonRestParameters);
-      const parameters = [];
-      for (let i = 0; i < maxNonRestParam; i++) {
-        const symbols = mapDefined(candidates, (s) => signatureHasRestParameter(s) ? i < s.parameters.length - 1 ? s.parameters[i] : last(s.parameters) : i < s.parameters.length ? s.parameters[i] : void 0);
-        Debug.assert(symbols.length !== 0);
-        parameters.push(createCombinedSymbolFromTypes(symbols, mapDefined(candidates, (candidate) => tryGetTypeAtPosition(candidate, i))));
-      }
-      const restParameterSymbols = mapDefined(candidates, (c) => signatureHasRestParameter(c) ? last(c.parameters) : void 0);
-      let flags = 0 /* None */;
-      if (restParameterSymbols.length !== 0) {
-        const type = createArrayType(getUnionType(mapDefined(candidates, tryGetRestTypeOfSignature), 2 /* Subtype */));
-        parameters.push(createCombinedSymbolForOverloadFailure(restParameterSymbols, type));
-        flags |= 1 /* HasRestParameter */;
-      }
-      if (candidates.some(signatureHasLiteralTypes)) {
-        flags |= 2 /* HasLiteralTypes */;
-      }
-      return createSignature(
-        candidates[0].declaration,
-        /*typeParameters*/
-        void 0,
-        // Before calling this we tested for `!candidates.some(c => !!c.typeParameters)`.
-        thisParameter,
-        parameters,
-        /*resolvedReturnType*/
-        getIntersectionType(candidates.map(getReturnTypeOfSignature)),
-        /*resolvedTypePredicate*/
-        void 0,
-        minArgumentCount,
-        flags
-      );
-    }
-    function getNumNonRestParameters(signature) {
-      const numParams = signature.parameters.length;
-      return signatureHasRestParameter(signature) ? numParams - 1 : numParams;
-    }
-    function createCombinedSymbolFromTypes(sources, types) {
-      return createCombinedSymbolForOverloadFailure(sources, getUnionType(types, 2 /* Subtype */));
-    }
-    function createCombinedSymbolForOverloadFailure(sources, type) {
-      return createSymbolWithType(first(sources), type);
-    }
-    function pickLongestCandidateSignature(node, candidates, args, checkMode) {
-      const bestIndex = getLongestCandidateIndex(candidates, apparentArgumentCount === void 0 ? args.length : apparentArgumentCount);
-      const candidate = candidates[bestIndex];
-      const { typeParameters } = candidate;
-      if (!typeParameters) {
-        return candidate;
-      }
-      const typeArgumentNodes = callLikeExpressionMayHaveTypeArguments(node) ? node.typeArguments : void 0;
-      const instantiated = typeArgumentNodes ? createSignatureInstantiation(candidate, getTypeArgumentsFromNodes(typeArgumentNodes, typeParameters, isInJSFile(node))) : inferSignatureInstantiationForOverloadFailure(node, typeParameters, candidate, args, checkMode);
-      candidates[bestIndex] = instantiated;
-      return instantiated;
-    }
-    function getTypeArgumentsFromNodes(typeArgumentNodes, typeParameters, isJs) {
-      const typeArguments = typeArgumentNodes.map(getTypeOfNode);
-      while (typeArguments.length > typeParameters.length) {
-        typeArguments.pop();
-      }
-      while (typeArguments.length < typeParameters.length) {
-        typeArguments.push(getDefaultFromTypeParameter(typeParameters[typeArguments.length]) || getConstraintOfTypeParameter(typeParameters[typeArguments.length]) || getDefaultTypeArgumentType(isJs));
-      }
-      return typeArguments;
-    }
-    function inferSignatureInstantiationForOverloadFailure(node, typeParameters, candidate, args, checkMode) {
-      const inferenceContext = createInferenceContext(
-        typeParameters,
-        candidate,
-        /*flags*/
-        isInJSFile(node) ? 2 /* AnyDefault */ : 0 /* None */
-      );
-      const typeArgumentTypes = inferTypeArguments(node, candidate, args, checkMode | 4 /* SkipContextSensitive */ | 8 /* SkipGenericFunctions */, inferenceContext);
-      return createSignatureInstantiation(candidate, typeArgumentTypes);
-    }
-    function getLongestCandidateIndex(candidates, argsCount) {
-      let maxParamsIndex = -1;
-      let maxParams = -1;
-      for (let i = 0; i < candidates.length; i++) {
-        const candidate = candidates[i];
-        const paramCount = getParameterCount(candidate);
-        if (hasEffectiveRestParameter(candidate) || paramCount >= argsCount) {
-          return i;
-        }
-        if (paramCount > maxParams) {
-          maxParams = paramCount;
-          maxParamsIndex = i;
-        }
-      }
-      return maxParamsIndex;
-    }
-    function resolveCallExpression(node, candidatesOutArray, checkMode) {
-      if (node.expression.kind === 108 /* SuperKeyword */) {
-        const superType = checkSuperExpression(node.expression);
-        if (isTypeAny(superType)) {
-          for (const arg of node.arguments) {
-            checkExpression(arg);
-          }
-          return anySignature;
-        }
-        if (!isErrorType(superType)) {
-          const baseTypeNode = getEffectiveBaseTypeNode(getContainingClass(node));
-          if (baseTypeNode) {
-            const baseConstructors = getInstantiatedConstructorsForTypeArguments(superType, baseTypeNode.typeArguments, baseTypeNode);
-            return resolveCall(node, baseConstructors, candidatesOutArray, checkMode, 0 /* None */);
-          }
-        }
-        return resolveUntypedCall(node);
-      }
-      let callChainFlags;
-      let funcType = checkExpression(node.expression);
-      if (isCallChain(node)) {
-        const nonOptionalType = getOptionalExpressionType(funcType, node.expression);
-        callChainFlags = nonOptionalType === funcType ? 0 /* None */ : isOutermostOptionalChain(node) ? 16 /* IsOuterCallChain */ : 8 /* IsInnerCallChain */;
-        funcType = nonOptionalType;
-      } else {
-        callChainFlags = 0 /* None */;
-      }
-      funcType = checkNonNullTypeWithReporter(
-        funcType,
-        node.expression,
-        reportCannotInvokePossiblyNullOrUndefinedError
-      );
-      if (funcType === silentNeverType) {
-        return silentNeverSignature;
-      }
-      const apparentType = getApparentType(funcType);
-      if (isErrorType(apparentType)) {
-        return resolveErrorCall(node);
-      }
-      const callSignatures = getSignaturesOfType(apparentType, 0 /* Call */);
-      const numConstructSignatures = getSignaturesOfType(apparentType, 1 /* Construct */).length;
-      if (isUntypedFunctionCall(funcType, apparentType, callSignatures.length, numConstructSignatures)) {
-        if (!isErrorType(funcType) && node.typeArguments) {
-          error(node, Diagnostics.Untyped_function_calls_may_not_accept_type_arguments);
-        }
-        return resolveUntypedCall(node);
-      }
-      if (!callSignatures.length) {
-        if (numConstructSignatures) {
-          error(node, Diagnostics.Value_of_type_0_is_not_callable_Did_you_mean_to_include_new, typeToString(funcType));
-        } else {
-          let relatedInformation;
-          if (node.arguments.length === 1) {
-            const text = getSourceFileOfNode(node).text;
-            if (isLineBreak(text.charCodeAt(skipTrivia(
-              text,
-              node.expression.end,
-              /*stopAfterLineBreak*/
-              true
-            ) - 1))) {
-              relatedInformation = createDiagnosticForNode(node.expression, Diagnostics.Are_you_missing_a_semicolon);
-            }
-          }
-          invocationError(node.expression, apparentType, 0 /* Call */, relatedInformation);
-        }
-        return resolveErrorCall(node);
-      }
-      if (checkMode & 8 /* SkipGenericFunctions */ && !node.typeArguments && callSignatures.some(isGenericFunctionReturningFunction)) {
-        skippedGenericFunction(node, checkMode);
-        return resolvingSignature;
-      }
-      if (callSignatures.some((sig) => isInJSFile(sig.declaration) && !!getJSDocClassTag(sig.declaration))) {
-        error(node, Diagnostics.Value_of_type_0_is_not_callable_Did_you_mean_to_include_new, typeToString(funcType));
-        return resolveErrorCall(node);
-      }
-      return resolveCall(node, callSignatures, candidatesOutArray, checkMode, callChainFlags);
-    }
-    function isGenericFunctionReturningFunction(signature) {
-      return !!(signature.typeParameters && isFunctionType(getReturnTypeOfSignature(signature)));
-    }
-    function isUntypedFunctionCall(funcType, apparentFuncType, numCallSignatures, numConstructSignatures) {
-      return isTypeAny(funcType) || isTypeAny(apparentFuncType) && !!(funcType.flags & 262144 /* TypeParameter */) || !numCallSignatures && !numConstructSignatures && !(apparentFuncType.flags & 1048576 /* Union */) && !(getReducedType(apparentFuncType).flags & 131072 /* Never */) && isTypeAssignableTo(funcType, globalFunctionType);
-    }
-    function resolveNewExpression(node, candidatesOutArray, checkMode) {
-      if (node.arguments && languageVersion < 1 /* ES5 */) {
-        const spreadIndex = getSpreadArgumentIndex(node.arguments);
-        if (spreadIndex >= 0) {
-          error(node.arguments[spreadIndex], Diagnostics.Spread_operator_in_new_expressions_is_only_available_when_targeting_ECMAScript_5_and_higher);
-        }
-      }
-      let expressionType = checkNonNullExpression(node.expression);
-      if (expressionType === silentNeverType) {
-        return silentNeverSignature;
-      }
-      expressionType = getApparentType(expressionType);
-      if (isErrorType(expressionType)) {
-        return resolveErrorCall(node);
-      }
-      if (isTypeAny(expressionType)) {
-        if (node.typeArguments) {
-          error(node, Diagnostics.Untyped_function_calls_may_not_accept_type_arguments);
-        }
-        return resolveUntypedCall(node);
-      }
-      const constructSignatures = getSignaturesOfType(expressionType, 1 /* Construct */);
-      if (constructSignatures.length) {
-        if (!isConstructorAccessible(node, constructSignatures[0])) {
-          return resolveErrorCall(node);
-        }
-        if (someSignature(constructSignatures, (signature) => !!(signature.flags & 4 /* Abstract */))) {
-          error(node, Diagnostics.Cannot_create_an_instance_of_an_abstract_class);
-          return resolveErrorCall(node);
-        }
-        const valueDecl = expressionType.symbol && getClassLikeDeclarationOfSymbol(expressionType.symbol);
-        if (valueDecl && hasSyntacticModifier(valueDecl, 256 /* Abstract */)) {
-          error(node, Diagnostics.Cannot_create_an_instance_of_an_abstract_class);
-          return resolveErrorCall(node);
-        }
-        return resolveCall(node, constructSignatures, candidatesOutArray, checkMode, 0 /* None */);
-      }
-      const callSignatures = getSignaturesOfType(expressionType, 0 /* Call */);
-      if (callSignatures.length) {
-        const signature = resolveCall(node, callSignatures, candidatesOutArray, checkMode, 0 /* None */);
-        if (!noImplicitAny) {
-          if (signature.declaration && !isJSConstructor(signature.declaration) && getReturnTypeOfSignature(signature) !== voidType) {
-            error(node, Diagnostics.Only_a_void_function_can_be_called_with_the_new_keyword);
-          }
-          if (getThisTypeOfSignature(signature) === voidType) {
-            error(node, Diagnostics.A_function_that_is_called_with_the_new_keyword_cannot_have_a_this_type_that_is_void);
-          }
-        }
-        return signature;
-      }
-      invocationError(node.expression, expressionType, 1 /* Construct */);
-      return resolveErrorCall(node);
-    }
-    function someSignature(signatures, f) {
-      if (isArray(signatures)) {
-        return some(signatures, (signature) => someSignature(signature, f));
-      }
-      return signatures.compositeKind === 1048576 /* Union */ ? some(signatures.compositeSignatures, f) : f(signatures);
-    }
-    function typeHasProtectedAccessibleBase(target, type) {
-      const baseTypes = getBaseTypes(type);
-      if (!length(baseTypes)) {
-        return false;
-      }
-      const firstBase = baseTypes[0];
-      if (firstBase.flags & 2097152 /* Intersection */) {
-        const types = firstBase.types;
-        const mixinFlags = findMixins(types);
-        let i = 0;
-        for (const intersectionMember of firstBase.types) {
-          if (!mixinFlags[i]) {
-            if (getObjectFlags(intersectionMember) & (1 /* Class */ | 2 /* Interface */)) {
-              if (intersectionMember.symbol === target) {
-                return true;
-              }
-              if (typeHasProtectedAccessibleBase(target, intersectionMember)) {
-                return true;
-              }
-            }
-          }
-          i++;
-        }
-        return false;
-      }
-      if (firstBase.symbol === target) {
-        return true;
-      }
-      return typeHasProtectedAccessibleBase(target, firstBase);
-    }
-    function isConstructorAccessible(node, signature) {
-      if (!signature || !signature.declaration) {
-        return true;
-      }
-      const declaration = signature.declaration;
-      const modifiers = getSelectedEffectiveModifierFlags(declaration, 24 /* NonPublicAccessibilityModifier */);
-      if (!modifiers || declaration.kind !== 175 /* Constructor */) {
-        return true;
-      }
-      const declaringClassDeclaration = getClassLikeDeclarationOfSymbol(declaration.parent.symbol);
-      const declaringClass = getDeclaredTypeOfSymbol(declaration.parent.symbol);
-      if (!isNodeWithinClass(node, declaringClassDeclaration)) {
-        const containingClass = getContainingClass(node);
-        if (containingClass && modifiers & 16 /* Protected */) {
-          const containingType = getTypeOfNode(containingClass);
-          if (typeHasProtectedAccessibleBase(declaration.parent.symbol, containingType)) {
-            return true;
-          }
-        }
-        if (modifiers & 8 /* Private */) {
-          error(node, Diagnostics.Constructor_of_class_0_is_private_and_only_accessible_within_the_class_declaration, typeToString(declaringClass));
-        }
-        if (modifiers & 16 /* Protected */) {
-          error(node, Diagnostics.Constructor_of_class_0_is_protected_and_only_accessible_within_the_class_declaration, typeToString(declaringClass));
-        }
-        return false;
-      }
-      return true;
-    }
-    function invocationErrorDetails(errorTarget, apparentType, kind) {
-      let errorInfo;
-      const isCall = kind === 0 /* Call */;
-      const awaitedType = getAwaitedType(apparentType);
-      const maybeMissingAwait = awaitedType && getSignaturesOfType(awaitedType, kind).length > 0;
-      if (apparentType.flags & 1048576 /* Union */) {
-        const types = apparentType.types;
-        let hasSignatures = false;
-        for (const constituent of types) {
-          const signatures = getSignaturesOfType(constituent, kind);
-          if (signatures.length !== 0) {
-            hasSignatures = true;
-            if (errorInfo) {
-              break;
-            }
-          } else {
-            if (!errorInfo) {
-              errorInfo = chainDiagnosticMessages(
-                errorInfo,
-                isCall ? Diagnostics.Type_0_has_no_call_signatures : Diagnostics.Type_0_has_no_construct_signatures,
-                typeToString(constituent)
-              );
-              errorInfo = chainDiagnosticMessages(
-                errorInfo,
-                isCall ? Diagnostics.Not_all_constituents_of_type_0_are_callable : Diagnostics.Not_all_constituents_of_type_0_are_constructable,
-                typeToString(apparentType)
-              );
-            }
-            if (hasSignatures) {
-              break;
-            }
-          }
-        }
-        if (!hasSignatures) {
-          errorInfo = chainDiagnosticMessages(
-            /*details*/
-            void 0,
-            isCall ? Diagnostics.No_constituent_of_type_0_is_callable : Diagnostics.No_constituent_of_type_0_is_constructable,
-            typeToString(apparentType)
-          );
-        }
-        if (!errorInfo) {
-          errorInfo = chainDiagnosticMessages(
-            errorInfo,
-            isCall ? Diagnostics.Each_member_of_the_union_type_0_has_signatures_but_none_of_those_signatures_are_compatible_with_each_other : Diagnostics.Each_member_of_the_union_type_0_has_construct_signatures_but_none_of_those_signatures_are_compatible_with_each_other,
-            typeToString(apparentType)
-          );
-        }
-      } else {
-        errorInfo = chainDiagnosticMessages(
-          errorInfo,
-          isCall ? Diagnostics.Type_0_has_no_call_signatures : Diagnostics.Type_0_has_no_construct_signatures,
-          typeToString(apparentType)
-        );
-      }
-      let headMessage = isCall ? Diagnostics.This_expression_is_not_callable : Diagnostics.This_expression_is_not_constructable;
-      if (isCallExpression(errorTarget.parent) && errorTarget.parent.arguments.length === 0) {
-        const { resolvedSymbol } = getNodeLinks(errorTarget);
-        if (resolvedSymbol && resolvedSymbol.flags & 32768 /* GetAccessor */) {
-          headMessage = Diagnostics.This_expression_is_not_callable_because_it_is_a_get_accessor_Did_you_mean_to_use_it_without;
-        }
-      }
-      return {
-        messageChain: chainDiagnosticMessages(errorInfo, headMessage),
-        relatedMessage: maybeMissingAwait ? Diagnostics.Did_you_forget_to_use_await : void 0
-      };
-    }
-    function invocationError(errorTarget, apparentType, kind, relatedInformation) {
-      const { messageChain, relatedMessage: relatedInfo } = invocationErrorDetails(errorTarget, apparentType, kind);
-      const diagnostic = createDiagnosticForNodeFromMessageChain(getSourceFileOfNode(errorTarget), errorTarget, messageChain);
-      if (relatedInfo) {
-        addRelatedInfo(diagnostic, createDiagnosticForNode(errorTarget, relatedInfo));
-      }
-      if (isCallExpression(errorTarget.parent)) {
-        const { start, length: length2 } = getDiagnosticSpanForCallNode(
-          errorTarget.parent,
-          /*doNotIncludeArguments*/
-          true
-        );
-        diagnostic.start = start;
-        diagnostic.length = length2;
-      }
-      diagnostics.add(diagnostic);
-      invocationErrorRecovery(apparentType, kind, relatedInformation ? addRelatedInfo(diagnostic, relatedInformation) : diagnostic);
-    }
-    function invocationErrorRecovery(apparentType, kind, diagnostic) {
-      if (!apparentType.symbol) {
-        return;
-      }
-      const importNode = getSymbolLinks(apparentType.symbol).originatingImport;
-      if (importNode && !isImportCall(importNode)) {
-        const sigs = getSignaturesOfType(getTypeOfSymbol(getSymbolLinks(apparentType.symbol).target), kind);
-        if (!sigs || !sigs.length)
-          return;
-        addRelatedInfo(
-          diagnostic,
-          createDiagnosticForNode(importNode, Diagnostics.Type_originates_at_this_import_A_namespace_style_import_cannot_be_called_or_constructed_and_will_cause_a_failure_at_runtime_Consider_using_a_default_import_or_import_require_here_instead)
-        );
-      }
-    }
-    function resolveTaggedTemplateExpression(node, candidatesOutArray, checkMode) {
-      const tagType = checkExpression(node.tag);
-      const apparentType = getApparentType(tagType);
-      if (isErrorType(apparentType)) {
-        return resolveErrorCall(node);
-      }
-      const callSignatures = getSignaturesOfType(apparentType, 0 /* Call */);
-      const numConstructSignatures = getSignaturesOfType(apparentType, 1 /* Construct */).length;
-      if (isUntypedFunctionCall(tagType, apparentType, callSignatures.length, numConstructSignatures)) {
-        return resolveUntypedCall(node);
-      }
-      if (!callSignatures.length) {
-        if (isArrayLiteralExpression(node.parent)) {
-          const diagnostic = createDiagnosticForNode(node.tag, Diagnostics.It_is_likely_that_you_are_missing_a_comma_to_separate_these_two_template_expressions_They_form_a_tagged_template_expression_which_cannot_be_invoked);
-          diagnostics.add(diagnostic);
-          return resolveErrorCall(node);
-        }
-        invocationError(node.tag, apparentType, 0 /* Call */);
-        return resolveErrorCall(node);
-      }
-      return resolveCall(node, callSignatures, candidatesOutArray, checkMode, 0 /* None */);
-    }
-    function getDiagnosticHeadMessageForDecoratorResolution(node) {
-      switch (node.parent.kind) {
-        case 262 /* ClassDeclaration */:
-        case 230 /* ClassExpression */:
-          return Diagnostics.Unable_to_resolve_signature_of_class_decorator_when_called_as_an_expression;
-        case 168 /* Parameter */:
-          return Diagnostics.Unable_to_resolve_signature_of_parameter_decorator_when_called_as_an_expression;
-        case 171 /* PropertyDeclaration */:
-          return Diagnostics.Unable_to_resolve_signature_of_property_decorator_when_called_as_an_expression;
-        case 173 /* MethodDeclaration */:
-        case 176 /* GetAccessor */:
-        case 177 /* SetAccessor */:
-          return Diagnostics.Unable_to_resolve_signature_of_method_decorator_when_called_as_an_expression;
-        default:
-          return Debug.fail();
-      }
-    }
-    function resolveDecorator(node, candidatesOutArray, checkMode) {
-      const funcType = checkExpression(node.expression);
-      const apparentType = getApparentType(funcType);
-      if (isErrorType(apparentType)) {
-        return resolveErrorCall(node);
-      }
-      const callSignatures = getSignaturesOfType(apparentType, 0 /* Call */);
-      const numConstructSignatures = getSignaturesOfType(apparentType, 1 /* Construct */).length;
-      if (isUntypedFunctionCall(funcType, apparentType, callSignatures.length, numConstructSignatures)) {
-        return resolveUntypedCall(node);
-      }
-      if (isPotentiallyUncalledDecorator(node, callSignatures) && !isParenthesizedExpression(node.expression)) {
-        const nodeStr = getTextOfNode(
-          node.expression,
-          /*includeTrivia*/
-          false
-        );
-        error(node, Diagnostics._0_accepts_too_few_arguments_to_be_used_as_a_decorator_here_Did_you_mean_to_call_it_first_and_write_0, nodeStr);
-        return resolveErrorCall(node);
-      }
-      const headMessage = getDiagnosticHeadMessageForDecoratorResolution(node);
-      if (!callSignatures.length) {
-        const errorDetails = invocationErrorDetails(node.expression, apparentType, 0 /* Call */);
-        const messageChain = chainDiagnosticMessages(errorDetails.messageChain, headMessage);
-        const diag2 = createDiagnosticForNodeFromMessageChain(getSourceFileOfNode(node.expression), node.expression, messageChain);
-        if (errorDetails.relatedMessage) {
-          addRelatedInfo(diag2, createDiagnosticForNode(node.expression, errorDetails.relatedMessage));
-        }
-        diagnostics.add(diag2);
-        invocationErrorRecovery(apparentType, 0 /* Call */, diag2);
-        return resolveErrorCall(node);
-      }
-      return resolveCall(node, callSignatures, candidatesOutArray, checkMode, 0 /* None */, headMessage);
-    }
-    function createSignatureForJSXIntrinsic(node, result) {
-      const namespace = getJsxNamespaceAt(node);
-      const exports = namespace && getExportsOfSymbol(namespace);
-      const typeSymbol = exports && getSymbol2(exports, JsxNames.Element, 788968 /* Type */);
-      const returnNode = typeSymbol && nodeBuilder.symbolToEntityName(typeSymbol, 788968 /* Type */, node);
-      const declaration = factory.createFunctionTypeNode(
-        /*typeParameters*/
-        void 0,
-        [factory.createParameterDeclaration(
-          /*modifiers*/
-          void 0,
-          /*dotDotDotToken*/
-          void 0,
-          "props",
-          /*questionToken*/
-          void 0,
-          nodeBuilder.typeToTypeNode(result, node)
-        )],
-        returnNode ? factory.createTypeReferenceNode(
-          returnNode,
-          /*typeArguments*/
-          void 0
-        ) : factory.createKeywordTypeNode(133 /* AnyKeyword */)
-      );
-      const parameterSymbol = createSymbol(1 /* FunctionScopedVariable */, "props");
-      parameterSymbol.links.type = result;
-      return createSignature(
-        declaration,
-        /*typeParameters*/
-        void 0,
-        /*thisParameter*/
-        void 0,
-        [parameterSymbol],
-        typeSymbol ? getDeclaredTypeOfSymbol(typeSymbol) : errorType,
-        /*resolvedTypePredicate*/
-        void 0,
-        1,
-        0 /* None */
-      );
-    }
-    function resolveJsxOpeningLikeElement(node, candidatesOutArray, checkMode) {
-      if (isJsxIntrinsicTagName(node.tagName)) {
-        const result = getIntrinsicAttributesTypeFromJsxOpeningLikeElement(node);
-        const fakeSignature = createSignatureForJSXIntrinsic(node, result);
-        checkTypeAssignableToAndOptionallyElaborate(checkExpressionWithContextualType(
-          node.attributes,
-          getEffectiveFirstArgumentForJsxSignature(fakeSignature, node),
-          /*inferenceContext*/
-          void 0,
-          0 /* Normal */
-        ), result, node.tagName, node.attributes);
-        if (length(node.typeArguments)) {
-          forEach(node.typeArguments, checkSourceElement);
-          diagnostics.add(createDiagnosticForNodeArray(getSourceFileOfNode(node), node.typeArguments, Diagnostics.Expected_0_type_arguments_but_got_1, 0, length(node.typeArguments)));
-        }
-        return fakeSignature;
-      }
-      const exprTypes = checkExpression(node.tagName);
-      const apparentType = getApparentType(exprTypes);
-      if (isErrorType(apparentType)) {
-        return resolveErrorCall(node);
-      }
-      const signatures = getUninstantiatedJsxSignaturesOfType(exprTypes, node);
-      if (isUntypedFunctionCall(
-        exprTypes,
-        apparentType,
-        signatures.length,
-        /*constructSignatures*/
-        0
-      )) {
-        return resolveUntypedCall(node);
-      }
-      if (signatures.length === 0) {
-        error(node.tagName, Diagnostics.JSX_element_type_0_does_not_have_any_construct_or_call_signatures, getTextOfNode(node.tagName));
-        return resolveErrorCall(node);
-      }
-      return resolveCall(node, signatures, candidatesOutArray, checkMode, 0 /* None */);
-    }
-    function isPotentiallyUncalledDecorator(decorator, signatures) {
-      return signatures.length && every(signatures, (signature) => signature.minArgumentCount === 0 && !signatureHasRestParameter(signature) && signature.parameters.length < getDecoratorArgumentCount(decorator, signature));
-    }
-    function resolveSignature(node, candidatesOutArray, checkMode) {
-      switch (node.kind) {
-        case 212 /* CallExpression */:
-          return resolveCallExpression(node, candidatesOutArray, checkMode);
-        case 213 /* NewExpression */:
-          return resolveNewExpression(node, candidatesOutArray, checkMode);
-        case 214 /* TaggedTemplateExpression */:
-          return resolveTaggedTemplateExpression(node, candidatesOutArray, checkMode);
-        case 169 /* Decorator */:
-          return resolveDecorator(node, candidatesOutArray, checkMode);
-        case 285 /* JsxOpeningElement */:
-        case 284 /* JsxSelfClosingElement */:
-          return resolveJsxOpeningLikeElement(node, candidatesOutArray, checkMode);
-      }
-      Debug.assertNever(node, "Branch in 'resolveSignature' should be unreachable.");
-    }
-    function getResolvedSignature(node, candidatesOutArray, checkMode) {
-      const links = getNodeLinks(node);
-      const cached = links.resolvedSignature;
-      if (cached && cached !== resolvingSignature && !candidatesOutArray) {
-        return cached;
-      }
-      links.resolvedSignature = resolvingSignature;
-      let result = resolveSignature(node, candidatesOutArray, checkMode || 0 /* Normal */);
-      if (result !== resolvingSignature) {
-        if (links.resolvedSignature !== resolvingSignature) {
-          result = links.resolvedSignature;
-        }
-        links.resolvedSignature = flowLoopStart === flowLoopCount ? result : cached;
-      }
-      return result;
-    }
-    function isJSConstructor(node) {
-      var _a;
-      if (!node || !isInJSFile(node)) {
-        return false;
-      }
-      const func = isFunctionDeclaration(node) || isFunctionExpression(node) ? node : (isVariableDeclaration(node) || isPropertyAssignment(node)) && node.initializer && isFunctionExpression(node.initializer) ? node.initializer : void 0;
-      if (func) {
-        if (getJSDocClassTag(node))
-          return true;
-        if (isPropertyAssignment(walkUpParenthesizedExpressions(func.parent)))
-          return false;
-        const symbol = getSymbolOfDeclaration(func);
-        return !!((_a = symbol == null ? void 0 : symbol.members) == null ? void 0 : _a.size);
-      }
-      return false;
-    }
-    function mergeJSSymbols(target, source) {
-      var _a, _b;
-      if (source) {
-        const links = getSymbolLinks(source);
-        if (!links.inferredClassSymbol || !links.inferredClassSymbol.has(getSymbolId(target))) {
-          const inferred = isTransientSymbol(target) ? target : cloneSymbol(target);
-          inferred.exports = inferred.exports || createSymbolTable();
-          inferred.members = inferred.members || createSymbolTable();
-          inferred.flags |= source.flags & 32 /* Class */;
-          if ((_a = source.exports) == null ? void 0 : _a.size) {
-            mergeSymbolTable(inferred.exports, source.exports);
-          }
-          if ((_b = source.members) == null ? void 0 : _b.size) {
-            mergeSymbolTable(inferred.members, source.members);
-          }
-          (links.inferredClassSymbol || (links.inferredClassSymbol = /* @__PURE__ */ new Map())).set(getSymbolId(inferred), inferred);
-          return inferred;
-        }
-        return links.inferredClassSymbol.get(getSymbolId(target));
-      }
-    }
-    function getAssignedClassSymbol(decl) {
-      var _a;
-      const assignmentSymbol = decl && getSymbolOfExpando(
-        decl,
-        /*allowDeclaration*/
-        true
-      );
-      const prototype = (_a = assignmentSymbol == null ? void 0 : assignmentSymbol.exports) == null ? void 0 : _a.get("prototype");
-      const init = (prototype == null ? void 0 : prototype.valueDeclaration) && getAssignedJSPrototype(prototype.valueDeclaration);
-      return init ? getSymbolOfDeclaration(init) : void 0;
-    }
-    function getSymbolOfExpando(node, allowDeclaration) {
-      if (!node.parent) {
-        return void 0;
-      }
-      let name;
-      let decl;
-      if (isVariableDeclaration(node.parent) && node.parent.initializer === node) {
-        if (!isInJSFile(node) && !(isVarConst(node.parent) && isFunctionLikeDeclaration(node))) {
-          return void 0;
-        }
-        name = node.parent.name;
-        decl = node.parent;
-      } else if (isBinaryExpression(node.parent)) {
-        const parentNode = node.parent;
-        const parentNodeOperator = node.parent.operatorToken.kind;
-        if (parentNodeOperator === 64 /* EqualsToken */ && (allowDeclaration || parentNode.right === node)) {
-          name = parentNode.left;
-          decl = name;
-        } else if (parentNodeOperator === 57 /* BarBarToken */ || parentNodeOperator === 61 /* QuestionQuestionToken */) {
-          if (isVariableDeclaration(parentNode.parent) && parentNode.parent.initializer === parentNode) {
-            name = parentNode.parent.name;
-            decl = parentNode.parent;
-          } else if (isBinaryExpression(parentNode.parent) && parentNode.parent.operatorToken.kind === 64 /* EqualsToken */ && (allowDeclaration || parentNode.parent.right === parentNode)) {
-            name = parentNode.parent.left;
-            decl = name;
-          }
-          if (!name || !isBindableStaticNameExpression(name) || !isSameEntityName(name, parentNode.left)) {
-            return void 0;
-          }
-        }
-      } else if (allowDeclaration && isFunctionDeclaration(node)) {
-        name = node.name;
-        decl = node;
-      }
-      if (!decl || !name || !allowDeclaration && !getExpandoInitializer(node, isPrototypeAccess(name))) {
-        return void 0;
-      }
-      return getSymbolOfNode(decl);
-    }
-    function getAssignedJSPrototype(node) {
-      if (!node.parent) {
-        return false;
-      }
-      let parent2 = node.parent;
-      while (parent2 && parent2.kind === 210 /* PropertyAccessExpression */) {
-        parent2 = parent2.parent;
-      }
-      if (parent2 && isBinaryExpression(parent2) && isPrototypeAccess(parent2.left) && parent2.operatorToken.kind === 64 /* EqualsToken */) {
-        const right = getInitializerOfBinaryExpression(parent2);
-        return isObjectLiteralExpression(right) && right;
-      }
-    }
-    function checkCallExpression(node, checkMode) {
-      var _a, _b, _c;
-      checkGrammarTypeArguments(node, node.typeArguments);
-      const signature = getResolvedSignature(
-        node,
-        /*candidatesOutArray*/
-        void 0,
-        checkMode
-      );
-      if (signature === resolvingSignature) {
-        return silentNeverType;
-      }
-      checkDeprecatedSignature(signature, node);
-      if (node.expression.kind === 108 /* SuperKeyword */) {
-        return voidType;
-      }
-      if (node.kind === 213 /* NewExpression */) {
-        const declaration = signature.declaration;
-        if (declaration && declaration.kind !== 175 /* Constructor */ && declaration.kind !== 179 /* ConstructSignature */ && declaration.kind !== 184 /* ConstructorType */ && !(isJSDocSignature(declaration) && ((_b = (_a = getJSDocRoot(declaration)) == null ? void 0 : _a.parent) == null ? void 0 : _b.kind) === 175 /* Constructor */) && !isJSDocConstructSignature(declaration) && !isJSConstructor(declaration)) {
-          if (noImplicitAny) {
-            error(node, Diagnostics.new_expression_whose_target_lacks_a_construct_signature_implicitly_has_an_any_type);
-          }
-          return anyType;
-        }
-      }
-      if (isInJSFile(node) && shouldResolveJsRequire(compilerOptions) && isCommonJsRequire(node)) {
-        return resolveExternalModuleTypeByLiteral(node.arguments[0]);
-      }
-      const returnType = getReturnTypeOfSignature(signature);
-      if (returnType.flags & 12288 /* ESSymbolLike */ && isSymbolOrSymbolForCall(node)) {
-        return getESSymbolLikeTypeForNode(walkUpParenthesizedExpressions(node.parent));
-      }
-      if (node.kind === 212 /* CallExpression */ && !node.questionDotToken && node.parent.kind === 243 /* ExpressionStatement */ && returnType.flags & 16384 /* Void */ && getTypePredicateOfSignature(signature)) {
-        if (!isDottedName(node.expression)) {
-          error(node.expression, Diagnostics.Assertions_require_the_call_target_to_be_an_identifier_or_qualified_name);
-        } else if (!getEffectsSignature(node)) {
-          const diagnostic = error(node.expression, Diagnostics.Assertions_require_every_name_in_the_call_target_to_be_declared_with_an_explicit_type_annotation);
-          getTypeOfDottedName(node.expression, diagnostic);
-        }
-      }
-      if (isInJSFile(node)) {
-        const jsSymbol = getSymbolOfExpando(
-          node,
-          /*allowDeclaration*/
-          false
-        );
-        if ((_c = jsSymbol == null ? void 0 : jsSymbol.exports) == null ? void 0 : _c.size) {
-          const jsAssignmentType = createAnonymousType(jsSymbol, jsSymbol.exports, emptyArray, emptyArray, emptyArray);
-          jsAssignmentType.objectFlags |= 4096 /* JSLiteral */;
-          return getIntersectionType([returnType, jsAssignmentType]);
-        }
-      }
-      return returnType;
-    }
-    function checkDeprecatedSignature(signature, node) {
-      if (signature.declaration && signature.declaration.flags & 268435456 /* Deprecated */) {
-        const suggestionNode = getDeprecatedSuggestionNode(node);
-        const name = tryGetPropertyAccessOrIdentifierToString(getInvokedExpression(node));
-        addDeprecatedSuggestionWithSignature(suggestionNode, signature.declaration, name, signatureToString(signature));
-      }
-    }
-    function getDeprecatedSuggestionNode(node) {
-      node = skipParentheses(node);
-      switch (node.kind) {
-        case 212 /* CallExpression */:
-        case 169 /* Decorator */:
-        case 213 /* NewExpression */:
-          return getDeprecatedSuggestionNode(node.expression);
-        case 214 /* TaggedTemplateExpression */:
-          return getDeprecatedSuggestionNode(node.tag);
-        case 285 /* JsxOpeningElement */:
-        case 284 /* JsxSelfClosingElement */:
-          return getDeprecatedSuggestionNode(node.tagName);
-        case 211 /* ElementAccessExpression */:
-          return node.argumentExpression;
-        case 210 /* PropertyAccessExpression */:
-          return node.name;
-        case 182 /* TypeReference */:
-          const typeReference = node;
-          return isQualifiedName(typeReference.typeName) ? typeReference.typeName.right : typeReference;
-        default:
-          return node;
-      }
-    }
-    function isSymbolOrSymbolForCall(node) {
-      if (!isCallExpression(node))
-        return false;
-      let left = node.expression;
-      if (isPropertyAccessExpression(left) && left.name.escapedText === "for") {
-        left = left.expression;
-      }
-      if (!isIdentifier(left) || left.escapedText !== "Symbol") {
-        return false;
-      }
-      const globalESSymbol = getGlobalESSymbolConstructorSymbol(
-        /*reportErrors*/
-        false
-      );
-      if (!globalESSymbol) {
-        return false;
-      }
-      return globalESSymbol === resolveName(
-        left,
-        "Symbol",
-        111551 /* Value */,
-        /*nameNotFoundMessage*/
-        void 0,
-        /*nameArg*/
-        void 0,
-        /*isUse*/
-        false
-      );
-    }
-    function checkImportCallExpression(node) {
-      checkGrammarImportCallExpression(node);
-      if (node.arguments.length === 0) {
-        return createPromiseReturnType(node, anyType);
-      }
-      const specifier = node.arguments[0];
-      const specifierType = checkExpressionCached(specifier);
-      const optionsType = node.arguments.length > 1 ? checkExpressionCached(node.arguments[1]) : void 0;
-      for (let i = 2; i < node.arguments.length; ++i) {
-        checkExpressionCached(node.arguments[i]);
-      }
-      if (specifierType.flags & 32768 /* Undefined */ || specifierType.flags & 65536 /* Null */ || !isTypeAssignableTo(specifierType, stringType)) {
-        error(specifier, Diagnostics.Dynamic_import_s_specifier_must_be_of_type_string_but_here_has_type_0, typeToString(specifierType));
-      }
-      if (optionsType) {
-        const importCallOptionsType = getGlobalImportCallOptionsType(
-          /*reportErrors*/
-          true
-        );
-        if (importCallOptionsType !== emptyObjectType) {
-          checkTypeAssignableTo(optionsType, getNullableType(importCallOptionsType, 32768 /* Undefined */), node.arguments[1]);
-        }
-      }
-      const moduleSymbol = resolveExternalModuleName(node, specifier);
-      if (moduleSymbol) {
-        const esModuleSymbol = resolveESModuleSymbol(
-          moduleSymbol,
-          specifier,
-          /*dontResolveAlias*/
-          true,
-          /*suppressInteropError*/
-          false
-        );
-        if (esModuleSymbol) {
-          return createPromiseReturnType(
-            node,
-            getTypeWithSyntheticDefaultOnly(getTypeOfSymbol(esModuleSymbol), esModuleSymbol, moduleSymbol, specifier) || getTypeWithSyntheticDefaultImportType(getTypeOfSymbol(esModuleSymbol), esModuleSymbol, moduleSymbol, specifier)
-          );
-        }
-      }
-      return createPromiseReturnType(node, anyType);
-    }
-    function createDefaultPropertyWrapperForModule(symbol, originalSymbol, anonymousSymbol) {
-      const memberTable = createSymbolTable();
-      const newSymbol = createSymbol(2097152 /* Alias */, "default" /* Default */);
-      newSymbol.parent = originalSymbol;
-      newSymbol.links.nameType = getStringLiteralType("default");
-      newSymbol.links.aliasTarget = resolveSymbol(symbol);
-      memberTable.set("default" /* Default */, newSymbol);
-      return createAnonymousType(anonymousSymbol, memberTable, emptyArray, emptyArray, emptyArray);
-    }
-    function getTypeWithSyntheticDefaultOnly(type, symbol, originalSymbol, moduleSpecifier) {
-      const hasDefaultOnly = isOnlyImportedAsDefault(moduleSpecifier);
-      if (hasDefaultOnly && type && !isErrorType(type)) {
-        const synthType = type;
-        if (!synthType.defaultOnlyType) {
-          const type2 = createDefaultPropertyWrapperForModule(symbol, originalSymbol);
-          synthType.defaultOnlyType = type2;
-        }
-        return synthType.defaultOnlyType;
-      }
-      return void 0;
-    }
-    function getTypeWithSyntheticDefaultImportType(type, symbol, originalSymbol, moduleSpecifier) {
-      var _a;
-      if (allowSyntheticDefaultImports && type && !isErrorType(type)) {
-        const synthType = type;
-        if (!synthType.syntheticType) {
-          const file = (_a = originalSymbol.declarations) == null ? void 0 : _a.find(isSourceFile);
-          const hasSyntheticDefault = canHaveSyntheticDefault(
-            file,
-            originalSymbol,
-            /*dontResolveAlias*/
-            false,
-            moduleSpecifier
-          );
-          if (hasSyntheticDefault) {
-            const anonymousSymbol = createSymbol(2048 /* TypeLiteral */, "__type" /* Type */);
-            const defaultContainingObject = createDefaultPropertyWrapperForModule(symbol, originalSymbol, anonymousSymbol);
-            anonymousSymbol.links.type = defaultContainingObject;
-            synthType.syntheticType = isValidSpreadType(type) ? getSpreadType(
-              type,
-              defaultContainingObject,
-              anonymousSymbol,
-              /*objectFlags*/
-              0,
-              /*readonly*/
-              false
-            ) : defaultContainingObject;
-          } else {
-            synthType.syntheticType = type;
-          }
-        }
-        return synthType.syntheticType;
-      }
-      return type;
-    }
-    function isCommonJsRequire(node) {
-      if (!isRequireCall(
-        node,
-        /*requireStringLiteralLikeArgument*/
-        true
-      )) {
-        return false;
-      }
-      if (!isIdentifier(node.expression))
-        return Debug.fail();
-      const resolvedRequire = resolveName(
-        node.expression,
-        node.expression.escapedText,
-        111551 /* Value */,
-        /*nameNotFoundMessage*/
-        void 0,
-        /*nameArg*/
-        void 0,
-        /*isUse*/
-        true
-      );
-      if (resolvedRequire === requireSymbol) {
-        return true;
-      }
-      if (resolvedRequire.flags & 2097152 /* Alias */) {
-        return false;
-      }
-      const targetDeclarationKind = resolvedRequire.flags & 16 /* Function */ ? 261 /* FunctionDeclaration */ : resolvedRequire.flags & 3 /* Variable */ ? 259 /* VariableDeclaration */ : 0 /* Unknown */;
-      if (targetDeclarationKind !== 0 /* Unknown */) {
-        const decl = getDeclarationOfKind(resolvedRequire, targetDeclarationKind);
-        return !!decl && !!(decl.flags & 16777216 /* Ambient */);
-      }
-      return false;
-    }
-    function checkTaggedTemplateExpression(node) {
-      if (!checkGrammarTaggedTemplateChain(node))
-        checkGrammarTypeArguments(node, node.typeArguments);
-      if (languageVersion < 2 /* ES2015 */) {
-        checkExternalEmitHelpers(node, 262144 /* MakeTemplateObject */);
-      }
-      const signature = getResolvedSignature(node);
-      checkDeprecatedSignature(signature, node);
-      return getReturnTypeOfSignature(signature);
-    }
-    function checkAssertion(node, checkMode) {
-      if (node.kind === 215 /* TypeAssertionExpression */) {
-        const file = getSourceFileOfNode(node);
-        if (file && fileExtensionIsOneOf(file.fileName, [".cts" /* Cts */, ".mts" /* Mts */])) {
-          grammarErrorOnNode(node, Diagnostics.This_syntax_is_reserved_in_files_with_the_mts_or_cts_extension_Use_an_as_expression_instead);
-        }
-      }
-      return checkAssertionWorker(node, checkMode);
-    }
-    function isValidConstAssertionArgument(node) {
-      switch (node.kind) {
-        case 11 /* StringLiteral */:
-        case 15 /* NoSubstitutionTemplateLiteral */:
-        case 9 /* NumericLiteral */:
-        case 10 /* BigIntLiteral */:
-        case 112 /* TrueKeyword */:
-        case 97 /* FalseKeyword */:
-        case 208 /* ArrayLiteralExpression */:
-        case 209 /* ObjectLiteralExpression */:
-        case 227 /* TemplateExpression */:
-          return true;
-        case 216 /* ParenthesizedExpression */:
-          return isValidConstAssertionArgument(node.expression);
-        case 223 /* PrefixUnaryExpression */:
-          const op = node.operator;
-          const arg = node.operand;
-          return op === 41 /* MinusToken */ && (arg.kind === 9 /* NumericLiteral */ || arg.kind === 10 /* BigIntLiteral */) || op === 40 /* PlusToken */ && arg.kind === 9 /* NumericLiteral */;
-        case 210 /* PropertyAccessExpression */:
-        case 211 /* ElementAccessExpression */:
-          const expr = skipParentheses(node.expression);
-          const symbol = isEntityNameExpression(expr) ? resolveEntityName(
-            expr,
-            111551 /* Value */,
-            /*ignoreErrors*/
-            true
-          ) : void 0;
-          return !!(symbol && symbol.flags & 384 /* Enum */);
-      }
-      return false;
-    }
-    function checkAssertionWorker(node, checkMode) {
-      const { type, expression } = getAssertionTypeAndExpression(node);
-      const exprType = checkExpression(expression, checkMode);
-      if (isConstTypeReference(type)) {
-        if (!isValidConstAssertionArgument(expression)) {
-          error(expression, Diagnostics.A_const_assertions_can_only_be_applied_to_references_to_enum_members_or_string_number_boolean_array_or_object_literals);
-        }
-        return getRegularTypeOfLiteralType(exprType);
-      }
-      const links = getNodeLinks(node);
-      links.assertionExpressionType = exprType;
-      checkSourceElement(type);
-      checkNodeDeferred(node);
-      return getTypeFromTypeNode(type);
-    }
-    function getAssertionTypeAndExpression(node) {
-      let type;
-      let expression;
-      switch (node.kind) {
-        case 233 /* AsExpression */:
-        case 215 /* TypeAssertionExpression */:
-          type = node.type;
-          expression = node.expression;
-          break;
-        case 216 /* ParenthesizedExpression */:
-          type = getJSDocTypeAssertionType(node);
-          expression = node.expression;
-          break;
-      }
-      return { type, expression };
-    }
-    function checkAssertionDeferred(node) {
-      const { type } = getAssertionTypeAndExpression(node);
-      const errNode = isParenthesizedExpression(node) ? type : node;
-      const links = getNodeLinks(node);
-      Debug.assertIsDefined(links.assertionExpressionType);
-      const exprType = getRegularTypeOfObjectLiteral(getBaseTypeOfLiteralType(links.assertionExpressionType));
-      const targetType = getTypeFromTypeNode(type);
-      if (!isErrorType(targetType)) {
-        addLazyDiagnostic(() => {
-          const widenedType = getWidenedType(exprType);
-          if (!isTypeComparableTo(targetType, widenedType)) {
-            checkTypeComparableTo(
-              exprType,
-              targetType,
-              errNode,
-              Diagnostics.Conversion_of_type_0_to_type_1_may_be_a_mistake_because_neither_type_sufficiently_overlaps_with_the_other_If_this_was_intentional_convert_the_expression_to_unknown_first
-            );
-          }
-        });
-      }
-    }
-    function checkNonNullChain(node) {
-      const leftType = checkExpression(node.expression);
-      const nonOptionalType = getOptionalExpressionType(leftType, node.expression);
-      return propagateOptionalTypeMarker(getNonNullableType(nonOptionalType), node, nonOptionalType !== leftType);
-    }
-    function checkNonNullAssertion(node) {
-      return node.flags & 32 /* OptionalChain */ ? checkNonNullChain(node) : getNonNullableType(checkExpression(node.expression));
-    }
-    function checkExpressionWithTypeArguments(node) {
-      checkGrammarExpressionWithTypeArguments(node);
-      forEach(node.typeArguments, checkSourceElement);
-      if (node.kind === 232 /* ExpressionWithTypeArguments */) {
-        const parent2 = walkUpParenthesizedExpressions(node.parent);
-        if (parent2.kind === 225 /* BinaryExpression */ && parent2.operatorToken.kind === 104 /* InstanceOfKeyword */ && isNodeDescendantOf(node, parent2.right)) {
-          error(node, Diagnostics.The_right_hand_side_of_an_instanceof_expression_must_not_be_an_instantiation_expression);
-        }
-      }
-      const exprType = node.kind === 232 /* ExpressionWithTypeArguments */ ? checkExpression(node.expression) : isThisIdentifier(node.exprName) ? checkThisExpression(node.exprName) : checkExpression(node.exprName);
-      return getInstantiationExpressionType(exprType, node);
-    }
-    function getInstantiationExpressionType(exprType, node) {
-      const typeArguments = node.typeArguments;
-      if (exprType === silentNeverType || isErrorType(exprType) || !some(typeArguments)) {
-        return exprType;
-      }
-      let hasSomeApplicableSignature = false;
-      let nonApplicableType;
-      const result = getInstantiatedType(exprType);
-      const errorType2 = hasSomeApplicableSignature ? nonApplicableType : exprType;
-      if (errorType2) {
-        diagnostics.add(createDiagnosticForNodeArray(getSourceFileOfNode(node), typeArguments, Diagnostics.Type_0_has_no_signatures_for_which_the_type_argument_list_is_applicable, typeToString(errorType2)));
-      }
-      return result;
-      function getInstantiatedType(type) {
-        let hasSignatures = false;
-        let hasApplicableSignature = false;
-        const result2 = getInstantiatedTypePart(type);
-        hasSomeApplicableSignature || (hasSomeApplicableSignature = hasApplicableSignature);
-        if (hasSignatures && !hasApplicableSignature) {
-          nonApplicableType ?? (nonApplicableType = type);
-        }
-        return result2;
-        function getInstantiatedTypePart(type2) {
-          if (type2.flags & 524288 /* Object */) {
-            const resolved = resolveStructuredTypeMembers(type2);
-            const callSignatures = getInstantiatedSignatures(resolved.callSignatures);
-            const constructSignatures = getInstantiatedSignatures(resolved.constructSignatures);
-            hasSignatures || (hasSignatures = resolved.callSignatures.length !== 0 || resolved.constructSignatures.length !== 0);
-            hasApplicableSignature || (hasApplicableSignature = callSignatures.length !== 0 || constructSignatures.length !== 0);
-            if (callSignatures !== resolved.callSignatures || constructSignatures !== resolved.constructSignatures) {
-              const result3 = createAnonymousType(
-                /*symbol*/
-                void 0,
-                resolved.members,
-                callSignatures,
-                constructSignatures,
-                resolved.indexInfos
-              );
-              result3.objectFlags |= 8388608 /* InstantiationExpressionType */;
-              result3.node = node;
-              return result3;
-            }
-          } else if (type2.flags & 58982400 /* InstantiableNonPrimitive */) {
-            const constraint = getBaseConstraintOfType(type2);
-            if (constraint) {
-              const instantiated = getInstantiatedTypePart(constraint);
-              if (instantiated !== constraint) {
-                return instantiated;
-              }
-            }
-          } else if (type2.flags & 1048576 /* Union */) {
-            return mapType(type2, getInstantiatedType);
-          } else if (type2.flags & 2097152 /* Intersection */) {
-            return getIntersectionType(sameMap(type2.types, getInstantiatedTypePart));
-          }
-          return type2;
-        }
-      }
-      function getInstantiatedSignatures(signatures) {
-        const applicableSignatures = filter(signatures, (sig) => !!sig.typeParameters && hasCorrectTypeArgumentArity(sig, typeArguments));
-        return sameMap(applicableSignatures, (sig) => {
-          const typeArgumentTypes = checkTypeArguments(
-            sig,
-            typeArguments,
-            /*reportErrors*/
-            true
-          );
-          return typeArgumentTypes ? getSignatureInstantiation(sig, typeArgumentTypes, isInJSFile(sig.declaration)) : sig;
-        });
-      }
-    }
-    function checkSatisfiesExpression(node) {
-      checkSourceElement(node.type);
-      return checkSatisfiesExpressionWorker(node.expression, node.type);
-    }
-    function checkSatisfiesExpressionWorker(expression, target, checkMode) {
-      const exprType = checkExpression(expression, checkMode);
-      const targetType = getTypeFromTypeNode(target);
-      if (isErrorType(targetType)) {
-        return targetType;
-      }
-      const errorNode = findAncestor(target.parent, (n) => n.kind === 237 /* SatisfiesExpression */ || n.kind === 356 /* JSDocSatisfiesTag */);
-      checkTypeAssignableToAndOptionallyElaborate(exprType, targetType, errorNode, expression, Diagnostics.Type_0_does_not_satisfy_the_expected_type_1);
-      return exprType;
-    }
-    function checkMetaProperty(node) {
-      checkGrammarMetaProperty(node);
-      if (node.keywordToken === 105 /* NewKeyword */) {
-        return checkNewTargetMetaProperty(node);
-      }
-      if (node.keywordToken === 102 /* ImportKeyword */) {
-        return checkImportMetaProperty(node);
-      }
-      return Debug.assertNever(node.keywordToken);
-    }
-    function checkMetaPropertyKeyword(node) {
-      switch (node.keywordToken) {
-        case 102 /* ImportKeyword */:
-          return getGlobalImportMetaExpressionType();
-        case 105 /* NewKeyword */:
-          const type = checkNewTargetMetaProperty(node);
-          return isErrorType(type) ? errorType : createNewTargetExpressionType(type);
-        default:
-          Debug.assertNever(node.keywordToken);
-      }
-    }
-    function checkNewTargetMetaProperty(node) {
-      const container = getNewTargetContainer(node);
-      if (!container) {
-        error(node, Diagnostics.Meta_property_0_is_only_allowed_in_the_body_of_a_function_declaration_function_expression_or_constructor, "new.target");
-        return errorType;
-      } else if (container.kind === 175 /* Constructor */) {
-        const symbol = getSymbolOfDeclaration(container.parent);
-        return getTypeOfSymbol(symbol);
-      } else {
-        const symbol = getSymbolOfDeclaration(container);
-        return getTypeOfSymbol(symbol);
-      }
-    }
-    function checkImportMetaProperty(node) {
-      if (moduleKind === 100 /* Node16 */ || moduleKind === 199 /* NodeNext */) {
-        if (getSourceFileOfNode(node).impliedNodeFormat !== 99 /* ESNext */) {
-          error(node, Diagnostics.The_import_meta_meta_property_is_not_allowed_in_files_which_will_build_into_CommonJS_output);
-        }
-      } else if (moduleKind < 6 /* ES2020 */ && moduleKind !== 4 /* System */) {
-        error(node, Diagnostics.The_import_meta_meta_property_is_only_allowed_when_the_module_option_is_es2020_es2022_esnext_system_node16_or_nodenext);
-      }
-      const file = getSourceFileOfNode(node);
-      Debug.assert(!!(file.flags & 4194304 /* PossiblyContainsImportMeta */), "Containing file is missing import meta node flag.");
-      return node.name.escapedText === "meta" ? getGlobalImportMetaType() : errorType;
-    }
-    function getTypeOfParameter(symbol) {
-      const type = getTypeOfSymbol(symbol);
-      if (strictNullChecks) {
-        const declaration = symbol.valueDeclaration;
-        if (declaration && hasInitializer(declaration)) {
-          return getOptionalType(type);
-        }
-      }
-      return type;
-    }
-    function getTupleElementLabel(d) {
-      Debug.assert(isIdentifier(d.name));
-      return d.name.escapedText;
-    }
-    function getParameterNameAtPosition(signature, pos, overrideRestType) {
-      const paramCount = signature.parameters.length - (signatureHasRestParameter(signature) ? 1 : 0);
-      if (pos < paramCount) {
-        return signature.parameters[pos].escapedName;
-      }
-      const restParameter = signature.parameters[paramCount] || unknownSymbol;
-      const restType = overrideRestType || getTypeOfSymbol(restParameter);
-      if (isTupleType(restType)) {
-        const associatedNames = restType.target.labeledElementDeclarations;
-        const index = pos - paramCount;
-        return associatedNames && getTupleElementLabel(associatedNames[index]) || restParameter.escapedName + "_" + index;
-      }
-      return restParameter.escapedName;
-    }
-    function getParameterIdentifierNameAtPosition(signature, pos) {
-      var _a;
-      if (((_a = signature.declaration) == null ? void 0 : _a.kind) === 323 /* JSDocFunctionType */) {
-        return void 0;
-      }
-      const paramCount = signature.parameters.length - (signatureHasRestParameter(signature) ? 1 : 0);
-      if (pos < paramCount) {
-        const param = signature.parameters[pos];
-        return isParameterDeclarationWithIdentifierName(param) ? [param.escapedName, false] : void 0;
-      }
-      const restParameter = signature.parameters[paramCount] || unknownSymbol;
-      if (!isParameterDeclarationWithIdentifierName(restParameter)) {
-        return void 0;
-      }
-      const restType = getTypeOfSymbol(restParameter);
-      if (isTupleType(restType)) {
-        const associatedNames = restType.target.labeledElementDeclarations;
-        const index = pos - paramCount;
-        const associatedName = associatedNames == null ? void 0 : associatedNames[index];
-        const isRestTupleElement = !!(associatedName == null ? void 0 : associatedName.dotDotDotToken);
-        return associatedName ? [
-          getTupleElementLabel(associatedName),
-          isRestTupleElement
-        ] : void 0;
-      }
-      if (pos === paramCount) {
-        return [restParameter.escapedName, true];
-      }
-      return void 0;
-    }
-    function isParameterDeclarationWithIdentifierName(symbol) {
-      return symbol.valueDeclaration && isParameter(symbol.valueDeclaration) && isIdentifier(symbol.valueDeclaration.name);
-    }
-    function isValidDeclarationForTupleLabel(d) {
-      return d.kind === 201 /* NamedTupleMember */ || isParameter(d) && d.name && isIdentifier(d.name);
-    }
-    function getNameableDeclarationAtPosition(signature, pos) {
-      const paramCount = signature.parameters.length - (signatureHasRestParameter(signature) ? 1 : 0);
-      if (pos < paramCount) {
-        const decl = signature.parameters[pos].valueDeclaration;
-        return decl && isValidDeclarationForTupleLabel(decl) ? decl : void 0;
-      }
-      const restParameter = signature.parameters[paramCount] || unknownSymbol;
-      const restType = getTypeOfSymbol(restParameter);
-      if (isTupleType(restType)) {
-        const associatedNames = restType.target.labeledElementDeclarations;
-        const index = pos - paramCount;
-        return associatedNames && associatedNames[index];
-      }
-      return restParameter.valueDeclaration && isValidDeclarationForTupleLabel(restParameter.valueDeclaration) ? restParameter.valueDeclaration : void 0;
-    }
-    function getTypeAtPosition(signature, pos) {
-      return tryGetTypeAtPosition(signature, pos) || anyType;
-    }
-    function tryGetTypeAtPosition(signature, pos) {
-      const paramCount = signature.parameters.length - (signatureHasRestParameter(signature) ? 1 : 0);
-      if (pos < paramCount) {
-        return getTypeOfParameter(signature.parameters[pos]);
-      }
-      if (signatureHasRestParameter(signature)) {
-        const restType = getTypeOfSymbol(signature.parameters[paramCount]);
-        const index = pos - paramCount;
-        if (!isTupleType(restType) || restType.target.hasRestElement || index < restType.target.fixedLength) {
-          return getIndexedAccessType(restType, getNumberLiteralType(index));
-        }
-      }
-      return void 0;
-    }
-    function getRestTypeAtPosition(source, pos) {
-      const parameterCount = getParameterCount(source);
-      const minArgumentCount = getMinArgumentCount(source);
-      const restType = getEffectiveRestType(source);
-      if (restType && pos >= parameterCount - 1) {
-        return pos === parameterCount - 1 ? restType : createArrayType(getIndexedAccessType(restType, numberType));
-      }
-      const types = [];
-      const flags = [];
-      const names = [];
-      for (let i = pos; i < parameterCount; i++) {
-        if (!restType || i < parameterCount - 1) {
-          types.push(getTypeAtPosition(source, i));
-          flags.push(i < minArgumentCount ? 1 /* Required */ : 2 /* Optional */);
-        } else {
-          types.push(restType);
-          flags.push(8 /* Variadic */);
-        }
-        const name = getNameableDeclarationAtPosition(source, i);
-        if (name) {
-          names.push(name);
-        }
-      }
-      return createTupleType(
-        types,
-        flags,
-        /*readonly*/
-        false,
-        length(names) === length(types) ? names : void 0
-      );
-    }
-    function getParameterCount(signature) {
-      const length2 = signature.parameters.length;
-      if (signatureHasRestParameter(signature)) {
-        const restType = getTypeOfSymbol(signature.parameters[length2 - 1]);
-        if (isTupleType(restType)) {
-          return length2 + restType.target.fixedLength - (restType.target.hasRestElement ? 0 : 1);
-        }
-      }
-      return length2;
-    }
-    function getMinArgumentCount(signature, flags) {
-      const strongArityForUntypedJS = flags & 1 /* StrongArityForUntypedJS */;
-      const voidIsNonOptional = flags & 2 /* VoidIsNonOptional */;
-      if (voidIsNonOptional || signature.resolvedMinArgumentCount === void 0) {
-        let minArgumentCount;
-        if (signatureHasRestParameter(signature)) {
-          const restType = getTypeOfSymbol(signature.parameters[signature.parameters.length - 1]);
-          if (isTupleType(restType)) {
-            const firstOptionalIndex = findIndex(restType.target.elementFlags, (f) => !(f & 1 /* Required */));
-            const requiredCount = firstOptionalIndex < 0 ? restType.target.fixedLength : firstOptionalIndex;
-            if (requiredCount > 0) {
-              minArgumentCount = signature.parameters.length - 1 + requiredCount;
-            }
-          }
-        }
-        if (minArgumentCount === void 0) {
-          if (!strongArityForUntypedJS && signature.flags & 32 /* IsUntypedSignatureInJSFile */) {
-            return 0;
-          }
-          minArgumentCount = signature.minArgumentCount;
-        }
-        if (voidIsNonOptional) {
-          return minArgumentCount;
-        }
-        for (let i = minArgumentCount - 1; i >= 0; i--) {
-          const type = getTypeAtPosition(signature, i);
-          if (filterType(type, acceptsVoid).flags & 131072 /* Never */) {
-            break;
-          }
-          minArgumentCount = i;
-        }
-        signature.resolvedMinArgumentCount = minArgumentCount;
-      }
-      return signature.resolvedMinArgumentCount;
-    }
-    function hasEffectiveRestParameter(signature) {
-      if (signatureHasRestParameter(signature)) {
-        const restType = getTypeOfSymbol(signature.parameters[signature.parameters.length - 1]);
-        return !isTupleType(restType) || restType.target.hasRestElement;
-      }
-      return false;
-    }
-    function getEffectiveRestType(signature) {
-      if (signatureHasRestParameter(signature)) {
-        const restType = getTypeOfSymbol(signature.parameters[signature.parameters.length - 1]);
-        if (!isTupleType(restType)) {
-          return restType;
-        }
-        if (restType.target.hasRestElement) {
-          return sliceTupleType(restType, restType.target.fixedLength);
-        }
-      }
-      return void 0;
-    }
-    function getNonArrayRestType(signature) {
-      const restType = getEffectiveRestType(signature);
-      return restType && !isArrayType(restType) && !isTypeAny(restType) ? restType : void 0;
-    }
-    function getTypeOfFirstParameterOfSignature(signature) {
-      return getTypeOfFirstParameterOfSignatureWithFallback(signature, neverType);
-    }
-    function getTypeOfFirstParameterOfSignatureWithFallback(signature, fallbackType) {
-      return signature.parameters.length > 0 ? getTypeAtPosition(signature, 0) : fallbackType;
-    }
-    function inferFromAnnotatedParameters(signature, context, inferenceContext) {
-      const len = signature.parameters.length - (signatureHasRestParameter(signature) ? 1 : 0);
-      for (let i = 0; i < len; i++) {
-        const declaration = signature.parameters[i].valueDeclaration;
-        if (declaration.type) {
-          const typeNode = getEffectiveTypeAnnotationNode(declaration);
-          if (typeNode) {
-            inferTypes(inferenceContext.inferences, getTypeFromTypeNode(typeNode), getTypeAtPosition(context, i));
-          }
-        }
-      }
-    }
-    function assignContextualParameterTypes(signature, context) {
-      if (context.typeParameters) {
-        if (!signature.typeParameters) {
-          signature.typeParameters = context.typeParameters;
-        } else {
-          return;
-        }
-      }
-      if (context.thisParameter) {
-        const parameter = signature.thisParameter;
-        if (!parameter || parameter.valueDeclaration && !parameter.valueDeclaration.type) {
-          if (!parameter) {
-            signature.thisParameter = createSymbolWithType(
-              context.thisParameter,
-              /*type*/
-              void 0
-            );
-          }
-          assignParameterType(signature.thisParameter, getTypeOfSymbol(context.thisParameter));
-        }
-      }
-      const len = signature.parameters.length - (signatureHasRestParameter(signature) ? 1 : 0);
-      for (let i = 0; i < len; i++) {
-        const parameter = signature.parameters[i];
-        if (!getEffectiveTypeAnnotationNode(parameter.valueDeclaration)) {
-          const contextualParameterType = tryGetTypeAtPosition(context, i);
-          assignParameterType(parameter, contextualParameterType);
-        }
-      }
-      if (signatureHasRestParameter(signature)) {
-        const parameter = last(signature.parameters);
-        if (parameter.valueDeclaration ? !getEffectiveTypeAnnotationNode(parameter.valueDeclaration) : !!(getCheckFlags(parameter) & 65536 /* DeferredType */)) {
-          const contextualParameterType = getRestTypeAtPosition(context, len);
-          assignParameterType(parameter, contextualParameterType);
-        }
-      }
-    }
-    function assignNonContextualParameterTypes(signature) {
-      if (signature.thisParameter) {
-        assignParameterType(signature.thisParameter);
-      }
-      for (const parameter of signature.parameters) {
-        assignParameterType(parameter);
-      }
-    }
-    function assignParameterType(parameter, type) {
-      const links = getSymbolLinks(parameter);
-      if (!links.type) {
-        const declaration = parameter.valueDeclaration;
-        links.type = type || (declaration ? getWidenedTypeForVariableLikeDeclaration(
-          declaration,
-          /*reportErrors*/
-          true
-        ) : getTypeOfSymbol(parameter));
-        if (declaration && declaration.name.kind !== 80 /* Identifier */) {
-          if (links.type === unknownType) {
-            links.type = getTypeFromBindingPattern(declaration.name);
-          }
-          assignBindingElementTypes(declaration.name, links.type);
-        }
-      } else if (type) {
-        Debug.assertEqual(links.type, type, "Parameter symbol already has a cached type which differs from newly assigned type");
-      }
-    }
-    function assignBindingElementTypes(pattern, parentType) {
-      for (const element of pattern.elements) {
-        if (!isOmittedExpression(element)) {
-          const type = getBindingElementTypeFromParentType(element, parentType);
-          if (element.name.kind === 80 /* Identifier */) {
-            getSymbolLinks(getSymbolOfDeclaration(element)).type = type;
-          } else {
-            assignBindingElementTypes(element.name, type);
-          }
-        }
-      }
-    }
-    function createClassDecoratorContextType(classType) {
-      return tryCreateTypeReference(getGlobalClassDecoratorContextType(
-        /*reportErrors*/
-        true
-      ), [classType]);
-    }
-    function createClassMethodDecoratorContextType(thisType, valueType) {
-      return tryCreateTypeReference(getGlobalClassMethodDecoratorContextType(
-        /*reportErrors*/
-        true
-      ), [thisType, valueType]);
-    }
-    function createClassGetterDecoratorContextType(thisType, valueType) {
-      return tryCreateTypeReference(getGlobalClassGetterDecoratorContextType(
-        /*reportErrors*/
-        true
-      ), [thisType, valueType]);
-    }
-    function createClassSetterDecoratorContextType(thisType, valueType) {
-      return tryCreateTypeReference(getGlobalClassSetterDecoratorContextType(
-        /*reportErrors*/
-        true
-      ), [thisType, valueType]);
-    }
-    function createClassAccessorDecoratorContextType(thisType, valueType) {
-      return tryCreateTypeReference(getGlobalClassAccessorDecoratorContextType(
-        /*reportErrors*/
-        true
-      ), [thisType, valueType]);
-    }
-    function createClassFieldDecoratorContextType(thisType, valueType) {
-      return tryCreateTypeReference(getGlobalClassFieldDecoratorContextType(
-        /*reportErrors*/
-        true
-      ), [thisType, valueType]);
-    }
-    function getClassMemberDecoratorContextOverrideType(nameType, isPrivate, isStatic2) {
-      const key = `${isPrivate ? "p" : "P"}${isStatic2 ? "s" : "S"}${nameType.id}`;
-      let overrideType = decoratorContextOverrideTypeCache.get(key);
-      if (!overrideType) {
-        const members = createSymbolTable();
-        members.set("name", createProperty("name", nameType));
-        members.set("private", createProperty("private", isPrivate ? trueType : falseType));
-        members.set("static", createProperty("static", isStatic2 ? trueType : falseType));
-        overrideType = createAnonymousType(
-          /*symbol*/
-          void 0,
-          members,
-          emptyArray,
-          emptyArray,
-          emptyArray
-        );
-        decoratorContextOverrideTypeCache.set(key, overrideType);
-      }
-      return overrideType;
-    }
-    function createClassMemberDecoratorContextTypeForNode(node, thisType, valueType) {
-      const isStatic2 = hasStaticModifier(node);
-      const isPrivate = isPrivateIdentifier(node.name);
-      const nameType = isPrivate ? getStringLiteralType(idText(node.name)) : getLiteralTypeFromPropertyName(node.name);
-      const contextType = isMethodDeclaration(node) ? createClassMethodDecoratorContextType(thisType, valueType) : isGetAccessorDeclaration(node) ? createClassGetterDecoratorContextType(thisType, valueType) : isSetAccessorDeclaration(node) ? createClassSetterDecoratorContextType(thisType, valueType) : isAutoAccessorPropertyDeclaration(node) ? createClassAccessorDecoratorContextType(thisType, valueType) : isPropertyDeclaration(node) ? createClassFieldDecoratorContextType(thisType, valueType) : Debug.failBadSyntaxKind(node);
-      const overrideType = getClassMemberDecoratorContextOverrideType(nameType, isPrivate, isStatic2);
-      return getIntersectionType([contextType, overrideType]);
-    }
-    function createClassAccessorDecoratorTargetType(thisType, valueType) {
-      return tryCreateTypeReference(getGlobalClassAccessorDecoratorTargetType(
-        /*reportErrors*/
-        true
-      ), [thisType, valueType]);
-    }
-    function createClassAccessorDecoratorResultType(thisType, valueType) {
-      return tryCreateTypeReference(getGlobalClassAccessorDecoratorResultType(
-        /*reportErrors*/
-        true
-      ), [thisType, valueType]);
-    }
-    function createClassFieldDecoratorInitializerMutatorType(thisType, valueType) {
-      const thisParam = createParameter("this", thisType);
-      const valueParam = createParameter("value", valueType);
-      return createFunctionType(
-        /*typeParameters*/
-        void 0,
-        thisParam,
-        [valueParam],
-        valueType,
-        /*typePredicate*/
-        void 0,
-        1
-      );
-    }
-    function createESDecoratorCallSignature(targetType, contextType, nonOptionalReturnType) {
-      const targetParam = createParameter("target", targetType);
-      const contextParam = createParameter("context", contextType);
-      const returnType = getUnionType([nonOptionalReturnType, voidType]);
-      return createCallSignature(
-        /*typeParameters*/
-        void 0,
-        /*thisParameter*/
-        void 0,
-        [targetParam, contextParam],
-        returnType
-      );
-    }
-    function getESDecoratorCallSignature(decorator) {
-      const { parent: parent2 } = decorator;
-      const links = getNodeLinks(parent2);
-      if (!links.decoratorSignature) {
-        links.decoratorSignature = anySignature;
-        switch (parent2.kind) {
-          case 262 /* ClassDeclaration */:
-          case 230 /* ClassExpression */: {
-            const node = parent2;
-            const targetType = getTypeOfSymbol(getSymbolOfDeclaration(node));
-            const contextType = createClassDecoratorContextType(targetType);
-            links.decoratorSignature = createESDecoratorCallSignature(targetType, contextType, targetType);
-            break;
-          }
-          case 173 /* MethodDeclaration */:
-          case 176 /* GetAccessor */:
-          case 177 /* SetAccessor */: {
-            const node = parent2;
-            if (!isClassLike(node.parent))
-              break;
-            const valueType = isMethodDeclaration(node) ? getOrCreateTypeFromSignature(getSignatureFromDeclaration(node)) : getTypeOfNode(node);
-            const thisType = hasStaticModifier(node) ? getTypeOfSymbol(getSymbolOfDeclaration(node.parent)) : getDeclaredTypeOfClassOrInterface(getSymbolOfDeclaration(node.parent));
-            const targetType = isGetAccessorDeclaration(node) ? createGetterFunctionType(valueType) : isSetAccessorDeclaration(node) ? createSetterFunctionType(valueType) : valueType;
-            const contextType = createClassMemberDecoratorContextTypeForNode(node, thisType, valueType);
-            const returnType = isGetAccessorDeclaration(node) ? createGetterFunctionType(valueType) : isSetAccessorDeclaration(node) ? createSetterFunctionType(valueType) : valueType;
-            links.decoratorSignature = createESDecoratorCallSignature(targetType, contextType, returnType);
-            break;
-          }
-          case 171 /* PropertyDeclaration */: {
-            const node = parent2;
-            if (!isClassLike(node.parent))
-              break;
-            const valueType = getTypeOfNode(node);
-            const thisType = hasStaticModifier(node) ? getTypeOfSymbol(getSymbolOfDeclaration(node.parent)) : getDeclaredTypeOfClassOrInterface(getSymbolOfDeclaration(node.parent));
-            const targetType = hasAccessorModifier(node) ? createClassAccessorDecoratorTargetType(thisType, valueType) : undefinedType;
-            const contextType = createClassMemberDecoratorContextTypeForNode(node, thisType, valueType);
-            const returnType = hasAccessorModifier(node) ? createClassAccessorDecoratorResultType(thisType, valueType) : createClassFieldDecoratorInitializerMutatorType(thisType, valueType);
-            links.decoratorSignature = createESDecoratorCallSignature(targetType, contextType, returnType);
-            break;
-          }
-        }
-      }
-      return links.decoratorSignature === anySignature ? void 0 : links.decoratorSignature;
-    }
-    function getLegacyDecoratorCallSignature(decorator) {
-      const { parent: parent2 } = decorator;
-      const links = getNodeLinks(parent2);
-      if (!links.decoratorSignature) {
-        links.decoratorSignature = anySignature;
-        switch (parent2.kind) {
-          case 262 /* ClassDeclaration */:
-          case 230 /* ClassExpression */: {
-            const node = parent2;
-            const targetType = getTypeOfSymbol(getSymbolOfDeclaration(node));
-            const targetParam = createParameter("target", targetType);
-            links.decoratorSignature = createCallSignature(
-              /*typeParameters*/
-              void 0,
-              /*thisParameter*/
-              void 0,
-              [targetParam],
-              getUnionType([targetType, voidType])
-            );
-            break;
-          }
-          case 168 /* Parameter */: {
-            const node = parent2;
-            if (!isConstructorDeclaration(node.parent) && !(isMethodDeclaration(node.parent) || isSetAccessorDeclaration(node.parent) && isClassLike(node.parent.parent))) {
-              break;
-            }
-            if (getThisParameter(node.parent) === node) {
-              break;
-            }
-            const index = getThisParameter(node.parent) ? node.parent.parameters.indexOf(node) - 1 : node.parent.parameters.indexOf(node);
-            Debug.assert(index >= 0);
-            const targetType = isConstructorDeclaration(node.parent) ? getTypeOfSymbol(getSymbolOfDeclaration(node.parent.parent)) : getParentTypeOfClassElement(node.parent);
-            const keyType = isConstructorDeclaration(node.parent) ? undefinedType : getClassElementPropertyKeyType(node.parent);
-            const indexType = getNumberLiteralType(index);
-            const targetParam = createParameter("target", targetType);
-            const keyParam = createParameter("propertyKey", keyType);
-            const indexParam = createParameter("parameterIndex", indexType);
-            links.decoratorSignature = createCallSignature(
-              /*typeParameters*/
-              void 0,
-              /*thisParameter*/
-              void 0,
-              [targetParam, keyParam, indexParam],
-              voidType
-            );
-            break;
-          }
-          case 173 /* MethodDeclaration */:
-          case 176 /* GetAccessor */:
-          case 177 /* SetAccessor */:
-          case 171 /* PropertyDeclaration */: {
-            const node = parent2;
-            if (!isClassLike(node.parent))
-              break;
-            const targetType = getParentTypeOfClassElement(node);
-            const targetParam = createParameter("target", targetType);
-            const keyType = getClassElementPropertyKeyType(node);
-            const keyParam = createParameter("propertyKey", keyType);
-            const returnType = isPropertyDeclaration(node) ? voidType : createTypedPropertyDescriptorType(getTypeOfNode(node));
-            const hasPropDesc = languageVersion !== 0 /* ES3 */ && (!isPropertyDeclaration(parent2) || hasAccessorModifier(parent2));
-            if (hasPropDesc) {
-              const descriptorType = createTypedPropertyDescriptorType(getTypeOfNode(node));
-              const descriptorParam = createParameter("descriptor", descriptorType);
-              links.decoratorSignature = createCallSignature(
-                /*typeParameters*/
-                void 0,
-                /*thisParameter*/
-                void 0,
-                [targetParam, keyParam, descriptorParam],
-                getUnionType([returnType, voidType])
-              );
-            } else {
-              links.decoratorSignature = createCallSignature(
-                /*typeParameters*/
-                void 0,
-                /*thisParameter*/
-                void 0,
-                [targetParam, keyParam],
-                getUnionType([returnType, voidType])
-              );
-            }
-            break;
-          }
-        }
-      }
-      return links.decoratorSignature === anySignature ? void 0 : links.decoratorSignature;
-    }
-    function getDecoratorCallSignature(decorator) {
-      return legacyDecorators ? getLegacyDecoratorCallSignature(decorator) : getESDecoratorCallSignature(decorator);
-    }
-    function createPromiseType(promisedType) {
-      const globalPromiseType = getGlobalPromiseType(
-        /*reportErrors*/
-        true
-      );
-      if (globalPromiseType !== emptyGenericType) {
-        promisedType = getAwaitedTypeNoAlias(unwrapAwaitedType(promisedType)) || unknownType;
-        return createTypeReference(globalPromiseType, [promisedType]);
-      }
-      return unknownType;
-    }
-    function createPromiseLikeType(promisedType) {
-      const globalPromiseLikeType = getGlobalPromiseLikeType(
-        /*reportErrors*/
-        true
-      );
-      if (globalPromiseLikeType !== emptyGenericType) {
-        promisedType = getAwaitedTypeNoAlias(unwrapAwaitedType(promisedType)) || unknownType;
-        return createTypeReference(globalPromiseLikeType, [promisedType]);
-      }
-      return unknownType;
-    }
-    function createPromiseReturnType(func, promisedType) {
-      const promiseType = createPromiseType(promisedType);
-      if (promiseType === unknownType) {
-        error(func, isImportCall(func) ? Diagnostics.A_dynamic_import_call_returns_a_Promise_Make_sure_you_have_a_declaration_for_Promise_or_include_ES2015_in_your_lib_option : Diagnostics.An_async_function_or_method_must_return_a_Promise_Make_sure_you_have_a_declaration_for_Promise_or_include_ES2015_in_your_lib_option);
-        return errorType;
-      } else if (!getGlobalPromiseConstructorSymbol(
-        /*reportErrors*/
-        true
-      )) {
-        error(func, isImportCall(func) ? Diagnostics.A_dynamic_import_call_in_ES5_SlashES3_requires_the_Promise_constructor_Make_sure_you_have_a_declaration_for_the_Promise_constructor_or_include_ES2015_in_your_lib_option : Diagnostics.An_async_function_or_method_in_ES5_SlashES3_requires_the_Promise_constructor_Make_sure_you_have_a_declaration_for_the_Promise_constructor_or_include_ES2015_in_your_lib_option);
-      }
-      return promiseType;
-    }
-    function createNewTargetExpressionType(targetType) {
-      const symbol = createSymbol(0 /* None */, "NewTargetExpression");
-      const targetPropertySymbol = createSymbol(4 /* Property */, "target", 8 /* Readonly */);
-      targetPropertySymbol.parent = symbol;
-      targetPropertySymbol.links.type = targetType;
-      const members = createSymbolTable([targetPropertySymbol]);
-      symbol.members = members;
-      return createAnonymousType(symbol, members, emptyArray, emptyArray, emptyArray);
-    }
-    function getReturnTypeFromBody(func, checkMode) {
-      if (!func.body) {
-        return errorType;
-      }
-      const functionFlags = getFunctionFlags(func);
-      const isAsync = (functionFlags & 2 /* Async */) !== 0;
-      const isGenerator = (functionFlags & 1 /* Generator */) !== 0;
-      let returnType;
-      let yieldType;
-      let nextType;
-      let fallbackReturnType = voidType;
-      if (func.body.kind !== 240 /* Block */) {
-        returnType = checkExpressionCached(func.body, checkMode && checkMode & ~8 /* SkipGenericFunctions */);
-        if (isAsync) {
-          returnType = unwrapAwaitedType(checkAwaitedType(
-            returnType,
-            /*withAlias*/
-            false,
-            /*errorNode*/
-            func,
-            Diagnostics.The_return_type_of_an_async_function_must_either_be_a_valid_promise_or_must_not_contain_a_callable_then_member
-          ));
-        }
-      } else if (isGenerator) {
-        const returnTypes = checkAndAggregateReturnExpressionTypes(func, checkMode);
-        if (!returnTypes) {
-          fallbackReturnType = neverType;
-        } else if (returnTypes.length > 0) {
-          returnType = getUnionType(returnTypes, 2 /* Subtype */);
-        }
-        const { yieldTypes, nextTypes } = checkAndAggregateYieldOperandTypes(func, checkMode);
-        yieldType = some(yieldTypes) ? getUnionType(yieldTypes, 2 /* Subtype */) : void 0;
-        nextType = some(nextTypes) ? getIntersectionType(nextTypes) : void 0;
-      } else {
-        const types = checkAndAggregateReturnExpressionTypes(func, checkMode);
-        if (!types) {
-          return functionFlags & 2 /* Async */ ? createPromiseReturnType(func, neverType) : neverType;
-        }
-        if (types.length === 0) {
-          const contextualReturnType = getContextualReturnType(
-            func,
-            /*contextFlags*/
-            void 0
-          );
-          const returnType2 = contextualReturnType && (unwrapReturnType(contextualReturnType, functionFlags) || voidType).flags & 32768 /* Undefined */ ? undefinedType : voidType;
-          return functionFlags & 2 /* Async */ ? createPromiseReturnType(func, returnType2) : (
-            // Async function
-            returnType2
-          );
-        }
-        returnType = getUnionType(types, 2 /* Subtype */);
-      }
-      if (returnType || yieldType || nextType) {
-        if (yieldType)
-          reportErrorsFromWidening(func, yieldType, 3 /* GeneratorYield */);
-        if (returnType)
-          reportErrorsFromWidening(func, returnType, 1 /* FunctionReturn */);
-        if (nextType)
-          reportErrorsFromWidening(func, nextType, 2 /* GeneratorNext */);
-        if (returnType && isUnitType(returnType) || yieldType && isUnitType(yieldType) || nextType && isUnitType(nextType)) {
-          const contextualSignature = getContextualSignatureForFunctionLikeDeclaration(func);
-          const contextualType = !contextualSignature ? void 0 : contextualSignature === getSignatureFromDeclaration(func) ? isGenerator ? void 0 : returnType : instantiateContextualType(
-            getReturnTypeOfSignature(contextualSignature),
-            func,
-            /*contextFlags*/
-            void 0
-          );
-          if (isGenerator) {
-            yieldType = getWidenedLiteralLikeTypeForContextualIterationTypeIfNeeded(yieldType, contextualType, 0 /* Yield */, isAsync);
-            returnType = getWidenedLiteralLikeTypeForContextualIterationTypeIfNeeded(returnType, contextualType, 1 /* Return */, isAsync);
-            nextType = getWidenedLiteralLikeTypeForContextualIterationTypeIfNeeded(nextType, contextualType, 2 /* Next */, isAsync);
-          } else {
-            returnType = getWidenedLiteralLikeTypeForContextualReturnTypeIfNeeded(returnType, contextualType, isAsync);
-          }
-        }
-        if (yieldType)
-          yieldType = getWidenedType(yieldType);
-        if (returnType)
-          returnType = getWidenedType(returnType);
-        if (nextType)
-          nextType = getWidenedType(nextType);
-      }
-      if (isGenerator) {
-        return createGeneratorReturnType(
-          yieldType || neverType,
-          returnType || fallbackReturnType,
-          nextType || getContextualIterationType(2 /* Next */, func) || unknownType,
-          isAsync
-        );
-      } else {
-        return isAsync ? createPromiseType(returnType || fallbackReturnType) : returnType || fallbackReturnType;
-      }
-    }
-    function createGeneratorReturnType(yieldType, returnType, nextType, isAsyncGenerator) {
-      const resolver = isAsyncGenerator ? asyncIterationTypesResolver : syncIterationTypesResolver;
-      const globalGeneratorType = resolver.getGlobalGeneratorType(
-        /*reportErrors*/
-        false
-      );
-      yieldType = resolver.resolveIterationType(
-        yieldType,
-        /*errorNode*/
-        void 0
-      ) || unknownType;
-      returnType = resolver.resolveIterationType(
-        returnType,
-        /*errorNode*/
-        void 0
-      ) || unknownType;
-      nextType = resolver.resolveIterationType(
-        nextType,
-        /*errorNode*/
-        void 0
-      ) || unknownType;
-      if (globalGeneratorType === emptyGenericType) {
-        const globalType = resolver.getGlobalIterableIteratorType(
-          /*reportErrors*/
-          false
-        );
-        const iterationTypes = globalType !== emptyGenericType ? getIterationTypesOfGlobalIterableType(globalType, resolver) : void 0;
-        const iterableIteratorReturnType = iterationTypes ? iterationTypes.returnType : anyType;
-        const iterableIteratorNextType = iterationTypes ? iterationTypes.nextType : undefinedType;
-        if (isTypeAssignableTo(returnType, iterableIteratorReturnType) && isTypeAssignableTo(iterableIteratorNextType, nextType)) {
-          if (globalType !== emptyGenericType) {
-            return createTypeFromGenericGlobalType(globalType, [yieldType]);
-          }
-          resolver.getGlobalIterableIteratorType(
-            /*reportErrors*/
-            true
-          );
-          return emptyObjectType;
-        }
-        resolver.getGlobalGeneratorType(
-          /*reportErrors*/
-          true
-        );
-        return emptyObjectType;
-      }
-      return createTypeFromGenericGlobalType(globalGeneratorType, [yieldType, returnType, nextType]);
-    }
-    function checkAndAggregateYieldOperandTypes(func, checkMode) {
-      const yieldTypes = [];
-      const nextTypes = [];
-      const isAsync = (getFunctionFlags(func) & 2 /* Async */) !== 0;
-      forEachYieldExpression(func.body, (yieldExpression) => {
-        const yieldExpressionType = yieldExpression.expression ? checkExpression(yieldExpression.expression, checkMode) : undefinedWideningType;
-        pushIfUnique(yieldTypes, getYieldedTypeOfYieldExpression(yieldExpression, yieldExpressionType, anyType, isAsync));
-        let nextType;
-        if (yieldExpression.asteriskToken) {
-          const iterationTypes = getIterationTypesOfIterable(
-            yieldExpressionType,
-            isAsync ? 19 /* AsyncYieldStar */ : 17 /* YieldStar */,
-            yieldExpression.expression
-          );
-          nextType = iterationTypes && iterationTypes.nextType;
-        } else {
-          nextType = getContextualType2(
-            yieldExpression,
-            /*contextFlags*/
-            void 0
-          );
-        }
-        if (nextType)
-          pushIfUnique(nextTypes, nextType);
-      });
-      return { yieldTypes, nextTypes };
-    }
-    function getYieldedTypeOfYieldExpression(node, expressionType, sentType, isAsync) {
-      const errorNode = node.expression || node;
-      const yieldedType = node.asteriskToken ? checkIteratedTypeOrElementType(isAsync ? 19 /* AsyncYieldStar */ : 17 /* YieldStar */, expressionType, sentType, errorNode) : expressionType;
-      return !isAsync ? yieldedType : getAwaitedType(yieldedType, errorNode, node.asteriskToken ? Diagnostics.Type_of_iterated_elements_of_a_yield_Asterisk_operand_must_either_be_a_valid_promise_or_must_not_contain_a_callable_then_member : Diagnostics.Type_of_yield_operand_in_an_async_generator_must_either_be_a_valid_promise_or_must_not_contain_a_callable_then_member);
-    }
-    function getNotEqualFactsFromTypeofSwitch(start, end, witnesses) {
-      let facts = 0 /* None */;
-      for (let i = 0; i < witnesses.length; i++) {
-        const witness = i < start || i >= end ? witnesses[i] : void 0;
-        facts |= witness !== void 0 ? typeofNEFacts.get(witness) || 32768 /* TypeofNEHostObject */ : 0;
-      }
-      return facts;
-    }
-    function isExhaustiveSwitchStatement(node) {
-      const links = getNodeLinks(node);
-      if (links.isExhaustive === void 0) {
-        links.isExhaustive = 0;
-        const exhaustive = computeExhaustiveSwitchStatement(node);
-        if (links.isExhaustive === 0) {
-          links.isExhaustive = exhaustive;
-        }
-      } else if (links.isExhaustive === 0) {
-        links.isExhaustive = false;
-      }
-      return links.isExhaustive;
-    }
-    function computeExhaustiveSwitchStatement(node) {
-      if (node.expression.kind === 220 /* TypeOfExpression */) {
-        const witnesses = getSwitchClauseTypeOfWitnesses(node);
-        if (!witnesses) {
-          return false;
-        }
-        const operandConstraint = getBaseConstraintOrType(checkExpressionCached(node.expression.expression));
-        const notEqualFacts = getNotEqualFactsFromTypeofSwitch(0, 0, witnesses);
-        if (operandConstraint.flags & 3 /* AnyOrUnknown */) {
-          return (556800 /* AllTypeofNE */ & notEqualFacts) === 556800 /* AllTypeofNE */;
-        }
-        return !someType(operandConstraint, (t) => (getTypeFacts(t) & notEqualFacts) === notEqualFacts);
-      }
-      const type = checkExpressionCached(node.expression);
-      if (!isLiteralType(type)) {
-        return false;
-      }
-      const switchTypes = getSwitchClauseTypes(node);
-      if (!switchTypes.length || some(switchTypes, isNeitherUnitTypeNorNever)) {
-        return false;
-      }
-      return eachTypeContainedIn(mapType(type, getRegularTypeOfLiteralType), switchTypes);
-    }
-    function functionHasImplicitReturn(func) {
-      return func.endFlowNode && isReachableFlowNode(func.endFlowNode);
-    }
-    function checkAndAggregateReturnExpressionTypes(func, checkMode) {
-      const functionFlags = getFunctionFlags(func);
-      const aggregatedTypes = [];
-      let hasReturnWithNoExpression = functionHasImplicitReturn(func);
-      let hasReturnOfTypeNever = false;
-      forEachReturnStatement(func.body, (returnStatement) => {
-        const expr = returnStatement.expression;
-        if (expr) {
-          if (expr.kind === 212 /* CallExpression */ && expr.expression.kind === 80 /* Identifier */ && checkExpressionCached(expr.expression).symbol === func.symbol) {
-            hasReturnOfTypeNever = true;
-            return;
-          }
-          let type = checkExpressionCached(expr, checkMode && checkMode & ~8 /* SkipGenericFunctions */);
-          if (functionFlags & 2 /* Async */) {
-            type = unwrapAwaitedType(checkAwaitedType(
-              type,
-              /*withAlias*/
-              false,
-              func,
-              Diagnostics.The_return_type_of_an_async_function_must_either_be_a_valid_promise_or_must_not_contain_a_callable_then_member
-            ));
-          }
-          if (type.flags & 131072 /* Never */) {
-            hasReturnOfTypeNever = true;
-          }
-          pushIfUnique(aggregatedTypes, type);
-        } else {
-          hasReturnWithNoExpression = true;
-        }
-      });
-      if (aggregatedTypes.length === 0 && !hasReturnWithNoExpression && (hasReturnOfTypeNever || mayReturnNever(func))) {
-        return void 0;
-      }
-      if (strictNullChecks && aggregatedTypes.length && hasReturnWithNoExpression && !(isJSConstructor(func) && aggregatedTypes.some((t) => t.symbol === func.symbol))) {
-        pushIfUnique(aggregatedTypes, undefinedType);
-      }
-      return aggregatedTypes;
-    }
-    function mayReturnNever(func) {
-      switch (func.kind) {
-        case 217 /* FunctionExpression */:
-        case 218 /* ArrowFunction */:
-          return true;
-        case 173 /* MethodDeclaration */:
-          return func.parent.kind === 209 /* ObjectLiteralExpression */;
-        default:
-          return false;
-      }
-    }
-    function checkAllCodePathsInNonVoidFunctionReturnOrThrow(func, returnType) {
-      addLazyDiagnostic(checkAllCodePathsInNonVoidFunctionReturnOrThrowDiagnostics);
-      return;
-      function checkAllCodePathsInNonVoidFunctionReturnOrThrowDiagnostics() {
-        const functionFlags = getFunctionFlags(func);
-        const type = returnType && unwrapReturnType(returnType, functionFlags);
-        if (type && (maybeTypeOfKind(type, 16384 /* Void */) || type.flags & (1 /* Any */ | 32768 /* Undefined */))) {
-          return;
-        }
-        if (func.kind === 172 /* MethodSignature */ || nodeIsMissing(func.body) || func.body.kind !== 240 /* Block */ || !functionHasImplicitReturn(func)) {
-          return;
-        }
-        const hasExplicitReturn = func.flags & 512 /* HasExplicitReturn */;
-        const errorNode = getEffectiveReturnTypeNode(func) || func;
-        if (type && type.flags & 131072 /* Never */) {
-          error(errorNode, Diagnostics.A_function_returning_never_cannot_have_a_reachable_end_point);
-        } else if (type && !hasExplicitReturn) {
-          error(errorNode, Diagnostics.A_function_whose_declared_type_is_neither_undefined_void_nor_any_must_return_a_value);
-        } else if (type && strictNullChecks && !isTypeAssignableTo(undefinedType, type)) {
-          error(errorNode, Diagnostics.Function_lacks_ending_return_statement_and_return_type_does_not_include_undefined);
-        } else if (compilerOptions.noImplicitReturns) {
-          if (!type) {
-            if (!hasExplicitReturn) {
-              return;
-            }
-            const inferredReturnType = getReturnTypeOfSignature(getSignatureFromDeclaration(func));
-            if (isUnwrappedReturnTypeUndefinedVoidOrAny(func, inferredReturnType)) {
-              return;
-            }
-          }
-          error(errorNode, Diagnostics.Not_all_code_paths_return_a_value);
-        }
-      }
-    }
-    function checkFunctionExpressionOrObjectLiteralMethod(node, checkMode) {
-      Debug.assert(node.kind !== 173 /* MethodDeclaration */ || isObjectLiteralMethod(node));
-      checkNodeDeferred(node);
-      if (isFunctionExpression(node)) {
-        checkCollisionsForDeclarationName(node, node.name);
-      }
-      if (checkMode && checkMode & 4 /* SkipContextSensitive */ && isContextSensitive(node)) {
-        if (!getEffectiveReturnTypeNode(node) && !hasContextSensitiveParameters(node)) {
-          const contextualSignature = getContextualSignature(node);
-          if (contextualSignature && couldContainTypeVariables(getReturnTypeOfSignature(contextualSignature))) {
-            const links = getNodeLinks(node);
-            if (links.contextFreeType) {
-              return links.contextFreeType;
-            }
-            const returnType = getReturnTypeFromBody(node, checkMode);
-            const returnOnlySignature = createSignature(
-              /*declaration*/
-              void 0,
-              /*typeParameters*/
-              void 0,
-              /*thisParameter*/
-              void 0,
-              emptyArray,
-              returnType,
-              /*resolvedTypePredicate*/
-              void 0,
-              0,
-              64 /* IsNonInferrable */
-            );
-            const returnOnlyType = createAnonymousType(node.symbol, emptySymbols, [returnOnlySignature], emptyArray, emptyArray);
-            returnOnlyType.objectFlags |= 262144 /* NonInferrableType */;
-            return links.contextFreeType = returnOnlyType;
-          }
-        }
-        return anyFunctionType;
-      }
-      const hasGrammarError = checkGrammarFunctionLikeDeclaration(node);
-      if (!hasGrammarError && node.kind === 217 /* FunctionExpression */) {
-        checkGrammarForGenerator(node);
-      }
-      contextuallyCheckFunctionExpressionOrObjectLiteralMethod(node, checkMode);
-      return getTypeOfSymbol(getSymbolOfDeclaration(node));
-    }
-    function contextuallyCheckFunctionExpressionOrObjectLiteralMethod(node, checkMode) {
-      const links = getNodeLinks(node);
-      if (!(links.flags & 64 /* ContextChecked */)) {
-        const contextualSignature = getContextualSignature(node);
-        if (!(links.flags & 64 /* ContextChecked */)) {
-          links.flags |= 64 /* ContextChecked */;
-          const signature = firstOrUndefined(getSignaturesOfType(getTypeOfSymbol(getSymbolOfDeclaration(node)), 0 /* Call */));
-          if (!signature) {
-            return;
-          }
-          if (isContextSensitive(node)) {
-            if (contextualSignature) {
-              const inferenceContext = getInferenceContext(node);
-              let instantiatedContextualSignature;
-              if (checkMode && checkMode & 2 /* Inferential */) {
-                inferFromAnnotatedParameters(signature, contextualSignature, inferenceContext);
-                const restType = getEffectiveRestType(contextualSignature);
-                if (restType && restType.flags & 262144 /* TypeParameter */) {
-                  instantiatedContextualSignature = instantiateSignature(contextualSignature, inferenceContext.nonFixingMapper);
-                }
-              }
-              instantiatedContextualSignature || (instantiatedContextualSignature = inferenceContext ? instantiateSignature(contextualSignature, inferenceContext.mapper) : contextualSignature);
-              assignContextualParameterTypes(signature, instantiatedContextualSignature);
-            } else {
-              assignNonContextualParameterTypes(signature);
-            }
-          } else if (contextualSignature && !node.typeParameters && contextualSignature.parameters.length > node.parameters.length) {
-            const inferenceContext = getInferenceContext(node);
-            if (checkMode && checkMode & 2 /* Inferential */) {
-              inferFromAnnotatedParameters(signature, contextualSignature, inferenceContext);
-            }
-          }
-          if (contextualSignature && !getReturnTypeFromAnnotation(node) && !signature.resolvedReturnType) {
-            const returnType = getReturnTypeFromBody(node, checkMode);
-            if (!signature.resolvedReturnType) {
-              signature.resolvedReturnType = returnType;
-            }
-          }
-          checkSignatureDeclaration(node);
-        }
-      }
-    }
-    function checkFunctionExpressionOrObjectLiteralMethodDeferred(node) {
-      Debug.assert(node.kind !== 173 /* MethodDeclaration */ || isObjectLiteralMethod(node));
-      const functionFlags = getFunctionFlags(node);
-      const returnType = getReturnTypeFromAnnotation(node);
-      checkAllCodePathsInNonVoidFunctionReturnOrThrow(node, returnType);
-      if (node.body) {
-        if (!getEffectiveReturnTypeNode(node)) {
-          getReturnTypeOfSignature(getSignatureFromDeclaration(node));
-        }
-        if (node.body.kind === 240 /* Block */) {
-          checkSourceElement(node.body);
-        } else {
-          const exprType = checkExpression(node.body);
-          const returnOrPromisedType = returnType && unwrapReturnType(returnType, functionFlags);
-          if (returnOrPromisedType) {
-            if ((functionFlags & 3 /* AsyncGenerator */) === 2 /* Async */) {
-              const awaitedType = checkAwaitedType(
-                exprType,
-                /*withAlias*/
-                false,
-                node.body,
-                Diagnostics.The_return_type_of_an_async_function_must_either_be_a_valid_promise_or_must_not_contain_a_callable_then_member
-              );
-              checkTypeAssignableToAndOptionallyElaborate(awaitedType, returnOrPromisedType, node.body, node.body);
-            } else {
-              checkTypeAssignableToAndOptionallyElaborate(exprType, returnOrPromisedType, node.body, node.body);
-            }
-          }
-        }
-      }
-    }
-    function checkArithmeticOperandType(operand, type, diagnostic, isAwaitValid = false) {
-      if (!isTypeAssignableTo(type, numberOrBigIntType)) {
-        const awaitedType = isAwaitValid && getAwaitedTypeOfPromise(type);
-        errorAndMaybeSuggestAwait(
-          operand,
-          !!awaitedType && isTypeAssignableTo(awaitedType, numberOrBigIntType),
-          diagnostic
-        );
-        return false;
-      }
-      return true;
-    }
-    function isReadonlyAssignmentDeclaration(d) {
-      if (!isCallExpression(d)) {
-        return false;
-      }
-      if (!isBindableObjectDefinePropertyCall(d)) {
-        return false;
-      }
-      const objectLitType = checkExpressionCached(d.arguments[2]);
-      const valueType = getTypeOfPropertyOfType(objectLitType, "value");
-      if (valueType) {
-        const writableProp = getPropertyOfType(objectLitType, "writable");
-        const writableType = writableProp && getTypeOfSymbol(writableProp);
-        if (!writableType || writableType === falseType || writableType === regularFalseType) {
-          return true;
-        }
-        if (writableProp && writableProp.valueDeclaration && isPropertyAssignment(writableProp.valueDeclaration)) {
-          const initializer = writableProp.valueDeclaration.initializer;
-          const rawOriginalType = checkExpression(initializer);
-          if (rawOriginalType === falseType || rawOriginalType === regularFalseType) {
-            return true;
-          }
-        }
-        return false;
-      }
-      const setProp = getPropertyOfType(objectLitType, "set");
-      return !setProp;
-    }
-    function isReadonlySymbol(symbol) {
-      return !!(getCheckFlags(symbol) & 8 /* Readonly */ || symbol.flags & 4 /* Property */ && getDeclarationModifierFlagsFromSymbol(symbol) & 64 /* Readonly */ || symbol.flags & 3 /* Variable */ && getDeclarationNodeFlagsFromSymbol(symbol) & 2 /* Const */ || symbol.flags & 98304 /* Accessor */ && !(symbol.flags & 65536 /* SetAccessor */) || symbol.flags & 8 /* EnumMember */ || some(symbol.declarations, isReadonlyAssignmentDeclaration));
-    }
-    function isAssignmentToReadonlyEntity(expr, symbol, assignmentKind) {
-      var _a, _b;
-      if (assignmentKind === 0 /* None */) {
-        return false;
-      }
-      if (isReadonlySymbol(symbol)) {
-        if (symbol.flags & 4 /* Property */ && isAccessExpression(expr) && expr.expression.kind === 110 /* ThisKeyword */) {
-          const ctor = getContainingFunction(expr);
-          if (!(ctor && (ctor.kind === 175 /* Constructor */ || isJSConstructor(ctor)))) {
-            return true;
-          }
-          if (symbol.valueDeclaration) {
-            const isAssignmentDeclaration2 = isBinaryExpression(symbol.valueDeclaration);
-            const isLocalPropertyDeclaration = ctor.parent === symbol.valueDeclaration.parent;
-            const isLocalParameterProperty = ctor === symbol.valueDeclaration.parent;
-            const isLocalThisPropertyAssignment = isAssignmentDeclaration2 && ((_a = symbol.parent) == null ? void 0 : _a.valueDeclaration) === ctor.parent;
-            const isLocalThisPropertyAssignmentConstructorFunction = isAssignmentDeclaration2 && ((_b = symbol.parent) == null ? void 0 : _b.valueDeclaration) === ctor;
-            const isWriteableSymbol = isLocalPropertyDeclaration || isLocalParameterProperty || isLocalThisPropertyAssignment || isLocalThisPropertyAssignmentConstructorFunction;
-            return !isWriteableSymbol;
-          }
-        }
-        return true;
-      }
-      if (isAccessExpression(expr)) {
-        const node = skipParentheses(expr.expression);
-        if (node.kind === 80 /* Identifier */) {
-          const symbol2 = getNodeLinks(node).resolvedSymbol;
-          if (symbol2.flags & 2097152 /* Alias */) {
-            const declaration = getDeclarationOfAliasSymbol(symbol2);
-            return !!declaration && declaration.kind === 273 /* NamespaceImport */;
-          }
-        }
-      }
-      return false;
-    }
-    function checkReferenceExpression(expr, invalidReferenceMessage, invalidOptionalChainMessage) {
-      const node = skipOuterExpressions(expr, 6 /* Assertions */ | 1 /* Parentheses */);
-      if (node.kind !== 80 /* Identifier */ && !isAccessExpression(node)) {
-        error(expr, invalidReferenceMessage);
-        return false;
-      }
-      if (node.flags & 32 /* OptionalChain */) {
-        error(expr, invalidOptionalChainMessage);
-        return false;
-      }
-      return true;
-    }
-    function checkDeleteExpression(node) {
-      checkExpression(node.expression);
-      const expr = skipParentheses(node.expression);
-      if (!isAccessExpression(expr)) {
-        error(expr, Diagnostics.The_operand_of_a_delete_operator_must_be_a_property_reference);
-        return booleanType;
-      }
-      if (isPropertyAccessExpression(expr) && isPrivateIdentifier(expr.name)) {
-        error(expr, Diagnostics.The_operand_of_a_delete_operator_cannot_be_a_private_identifier);
-      }
-      const links = getNodeLinks(expr);
-      const symbol = getExportSymbolOfValueSymbolIfExported(links.resolvedSymbol);
-      if (symbol) {
-        if (isReadonlySymbol(symbol)) {
-          error(expr, Diagnostics.The_operand_of_a_delete_operator_cannot_be_a_read_only_property);
-        }
-        checkDeleteExpressionMustBeOptional(expr, symbol);
-      }
-      return booleanType;
-    }
-    function checkDeleteExpressionMustBeOptional(expr, symbol) {
-      const type = getTypeOfSymbol(symbol);
-      if (strictNullChecks && !(type.flags & (3 /* AnyOrUnknown */ | 131072 /* Never */)) && !(exactOptionalPropertyTypes ? symbol.flags & 16777216 /* Optional */ : getTypeFacts(type) & 16777216 /* IsUndefined */)) {
-        error(expr, Diagnostics.The_operand_of_a_delete_operator_must_be_optional);
-      }
-    }
-    function checkTypeOfExpression(node) {
-      checkExpression(node.expression);
-      return typeofType;
-    }
-    function checkVoidExpression(node) {
-      checkExpression(node.expression);
-      return undefinedWideningType;
-    }
-    function checkAwaitExpressionGrammar(node) {
-      const container = getContainingFunctionOrClassStaticBlock(node);
-      if (container && isClassStaticBlockDeclaration(container)) {
-        error(node, Diagnostics.Await_expression_cannot_be_used_inside_a_class_static_block);
-      } else if (!(node.flags & 32768 /* AwaitContext */)) {
-        if (isInTopLevelContext(node)) {
-          const sourceFile = getSourceFileOfNode(node);
-          if (!hasParseDiagnostics(sourceFile)) {
-            let span;
-            if (!isEffectiveExternalModule(sourceFile, compilerOptions)) {
-              span ?? (span = getSpanOfTokenAtPosition(sourceFile, node.pos));
-              const diagnostic = createFileDiagnostic(
-                sourceFile,
-                span.start,
-                span.length,
-                Diagnostics.await_expressions_are_only_allowed_at_the_top_level_of_a_file_when_that_file_is_a_module_but_this_file_has_no_imports_or_exports_Consider_adding_an_empty_export_to_make_this_file_a_module
-              );
-              diagnostics.add(diagnostic);
-            }
-            switch (moduleKind) {
-              case 100 /* Node16 */:
-              case 199 /* NodeNext */:
-                if (sourceFile.impliedNodeFormat === 1 /* CommonJS */) {
-                  span ?? (span = getSpanOfTokenAtPosition(sourceFile, node.pos));
-                  diagnostics.add(
-                    createFileDiagnostic(sourceFile, span.start, span.length, Diagnostics.The_current_file_is_a_CommonJS_module_and_cannot_use_await_at_the_top_level)
-                  );
-                  break;
-                }
-              case 7 /* ES2022 */:
-              case 99 /* ESNext */:
-              case 4 /* System */:
-                if (languageVersion >= 4 /* ES2017 */) {
-                  break;
-                }
-              default:
-                span ?? (span = getSpanOfTokenAtPosition(sourceFile, node.pos));
-                diagnostics.add(
-                  createFileDiagnostic(
-                    sourceFile,
-                    span.start,
-                    span.length,
-                    Diagnostics.Top_level_await_expressions_are_only_allowed_when_the_module_option_is_set_to_es2022_esnext_system_node16_or_nodenext_and_the_target_option_is_set_to_es2017_or_higher
-                  )
-                );
-                break;
-            }
-          }
-        } else {
-          const sourceFile = getSourceFileOfNode(node);
-          if (!hasParseDiagnostics(sourceFile)) {
-            const span = getSpanOfTokenAtPosition(sourceFile, node.pos);
-            const diagnostic = createFileDiagnostic(sourceFile, span.start, span.length, Diagnostics.await_expressions_are_only_allowed_within_async_functions_and_at_the_top_levels_of_modules);
-            if (container && container.kind !== 175 /* Constructor */ && (getFunctionFlags(container) & 2 /* Async */) === 0) {
-              const relatedInfo = createDiagnosticForNode(container, Diagnostics.Did_you_mean_to_mark_this_function_as_async);
-              addRelatedInfo(diagnostic, relatedInfo);
-            }
-            diagnostics.add(diagnostic);
-          }
-        }
-      }
-      if (isInParameterInitializerBeforeContainingFunction(node)) {
-        error(node, Diagnostics.await_expressions_cannot_be_used_in_a_parameter_initializer);
-      }
-    }
-    function checkAwaitExpression(node) {
-      addLazyDiagnostic(() => checkAwaitExpressionGrammar(node));
-      const operandType = checkExpression(node.expression);
-      const awaitedType = checkAwaitedType(
-        operandType,
-        /*withAlias*/
-        true,
-        node,
-        Diagnostics.Type_of_await_operand_must_either_be_a_valid_promise_or_must_not_contain_a_callable_then_member
-      );
-      if (awaitedType === operandType && !isErrorType(awaitedType) && !(operandType.flags & 3 /* AnyOrUnknown */)) {
-        addErrorOrSuggestion(
-          /*isError*/
-          false,
-          createDiagnosticForNode(node, Diagnostics.await_has_no_effect_on_the_type_of_this_expression)
-        );
-      }
-      return awaitedType;
-    }
-    function checkPrefixUnaryExpression(node) {
-      const operandType = checkExpression(node.operand);
-      if (operandType === silentNeverType) {
-        return silentNeverType;
-      }
-      switch (node.operand.kind) {
-        case 9 /* NumericLiteral */:
-          switch (node.operator) {
-            case 41 /* MinusToken */:
-              return getFreshTypeOfLiteralType(getNumberLiteralType(-node.operand.text));
-            case 40 /* PlusToken */:
-              return getFreshTypeOfLiteralType(getNumberLiteralType(+node.operand.text));
-          }
-          break;
-        case 10 /* BigIntLiteral */:
-          if (node.operator === 41 /* MinusToken */) {
-            return getFreshTypeOfLiteralType(getBigIntLiteralType({
-              negative: true,
-              base10Value: parsePseudoBigInt(node.operand.text)
-            }));
-          }
-      }
-      switch (node.operator) {
-        case 40 /* PlusToken */:
-        case 41 /* MinusToken */:
-        case 55 /* TildeToken */:
-          checkNonNullType(operandType, node.operand);
-          if (maybeTypeOfKindConsideringBaseConstraint(operandType, 12288 /* ESSymbolLike */)) {
-            error(node.operand, Diagnostics.The_0_operator_cannot_be_applied_to_type_symbol, tokenToString(node.operator));
-          }
-          if (node.operator === 40 /* PlusToken */) {
-            if (maybeTypeOfKindConsideringBaseConstraint(operandType, 2112 /* BigIntLike */)) {
-              error(node.operand, Diagnostics.Operator_0_cannot_be_applied_to_type_1, tokenToString(node.operator), typeToString(getBaseTypeOfLiteralType(operandType)));
-            }
-            return numberType;
-          }
-          return getUnaryResultType(operandType);
-        case 54 /* ExclamationToken */:
-          checkTruthinessOfType(operandType, node.operand);
-          const facts = getTypeFacts(operandType) & (4194304 /* Truthy */ | 8388608 /* Falsy */);
-          return facts === 4194304 /* Truthy */ ? falseType : facts === 8388608 /* Falsy */ ? trueType : booleanType;
-        case 46 /* PlusPlusToken */:
-        case 47 /* MinusMinusToken */:
-          const ok = checkArithmeticOperandType(
-            node.operand,
-            checkNonNullType(operandType, node.operand),
-            Diagnostics.An_arithmetic_operand_must_be_of_type_any_number_bigint_or_an_enum_type
-          );
-          if (ok) {
-            checkReferenceExpression(
-              node.operand,
-              Diagnostics.The_operand_of_an_increment_or_decrement_operator_must_be_a_variable_or_a_property_access,
-              Diagnostics.The_operand_of_an_increment_or_decrement_operator_may_not_be_an_optional_property_access
-            );
-          }
-          return getUnaryResultType(operandType);
-      }
-      return errorType;
-    }
-    function checkPostfixUnaryExpression(node) {
-      const operandType = checkExpression(node.operand);
-      if (operandType === silentNeverType) {
-        return silentNeverType;
-      }
-      const ok = checkArithmeticOperandType(
-        node.operand,
-        checkNonNullType(operandType, node.operand),
-        Diagnostics.An_arithmetic_operand_must_be_of_type_any_number_bigint_or_an_enum_type
-      );
-      if (ok) {
-        checkReferenceExpression(
-          node.operand,
-          Diagnostics.The_operand_of_an_increment_or_decrement_operator_must_be_a_variable_or_a_property_access,
-          Diagnostics.The_operand_of_an_increment_or_decrement_operator_may_not_be_an_optional_property_access
-        );
-      }
-      return getUnaryResultType(operandType);
-    }
-    function getUnaryResultType(operandType) {
-      if (maybeTypeOfKind(operandType, 2112 /* BigIntLike */)) {
-        return isTypeAssignableToKind(operandType, 3 /* AnyOrUnknown */) || maybeTypeOfKind(operandType, 296 /* NumberLike */) ? numberOrBigIntType : bigintType;
-      }
-      return numberType;
-    }
-    function maybeTypeOfKindConsideringBaseConstraint(type, kind) {
-      if (maybeTypeOfKind(type, kind)) {
-        return true;
-      }
-      const baseConstraint = getBaseConstraintOrType(type);
-      return !!baseConstraint && maybeTypeOfKind(baseConstraint, kind);
-    }
-    function maybeTypeOfKind(type, kind) {
-      if (type.flags & kind) {
-        return true;
-      }
-      if (type.flags & 3145728 /* UnionOrIntersection */) {
-        const types = type.types;
-        for (const t of types) {
-          if (maybeTypeOfKind(t, kind)) {
-            return true;
-          }
-        }
-      }
-      return false;
-    }
-    function isTypeAssignableToKind(source, kind, strict) {
-      if (source.flags & kind) {
-        return true;
-      }
-      if (strict && source.flags & (3 /* AnyOrUnknown */ | 16384 /* Void */ | 32768 /* Undefined */ | 65536 /* Null */)) {
-        return false;
-      }
-      return !!(kind & 296 /* NumberLike */) && isTypeAssignableTo(source, numberType) || !!(kind & 2112 /* BigIntLike */) && isTypeAssignableTo(source, bigintType) || !!(kind & 402653316 /* StringLike */) && isTypeAssignableTo(source, stringType) || !!(kind & 528 /* BooleanLike */) && isTypeAssignableTo(source, booleanType) || !!(kind & 16384 /* Void */) && isTypeAssignableTo(source, voidType) || !!(kind & 131072 /* Never */) && isTypeAssignableTo(source, neverType) || !!(kind & 65536 /* Null */) && isTypeAssignableTo(source, nullType) || !!(kind & 32768 /* Undefined */) && isTypeAssignableTo(source, undefinedType) || !!(kind & 4096 /* ESSymbol */) && isTypeAssignableTo(source, esSymbolType) || !!(kind & 67108864 /* NonPrimitive */) && isTypeAssignableTo(source, nonPrimitiveType);
-    }
-    function allTypesAssignableToKind(source, kind, strict) {
-      return source.flags & 1048576 /* Union */ ? every(source.types, (subType) => allTypesAssignableToKind(subType, kind, strict)) : isTypeAssignableToKind(source, kind, strict);
-    }
-    function isConstEnumObjectType(type) {
-      return !!(getObjectFlags(type) & 16 /* Anonymous */) && !!type.symbol && isConstEnumSymbol(type.symbol);
-    }
-    function isConstEnumSymbol(symbol) {
-      return (symbol.flags & 128 /* ConstEnum */) !== 0;
-    }
-    function checkInstanceOfExpression(left, right, leftType, rightType) {
-      if (leftType === silentNeverType || rightType === silentNeverType) {
-        return silentNeverType;
-      }
-      if (!isTypeAny(leftType) && allTypesAssignableToKind(leftType, 402784252 /* Primitive */)) {
-        error(left, Diagnostics.The_left_hand_side_of_an_instanceof_expression_must_be_of_type_any_an_object_type_or_a_type_parameter);
-      }
-      if (!(isTypeAny(rightType) || typeHasCallOrConstructSignatures(rightType) || isTypeSubtypeOf(rightType, globalFunctionType))) {
-        error(right, Diagnostics.The_right_hand_side_of_an_instanceof_expression_must_be_of_type_any_or_of_a_type_assignable_to_the_Function_interface_type);
-      }
-      return booleanType;
-    }
-    function hasEmptyObjectIntersection(type) {
-      return someType(type, (t) => t === unknownEmptyObjectType || !!(t.flags & 2097152 /* Intersection */) && isEmptyAnonymousObjectType(getBaseConstraintOrType(t)));
-    }
-    function checkInExpression(left, right, leftType, rightType) {
-      if (leftType === silentNeverType || rightType === silentNeverType) {
-        return silentNeverType;
-      }
-      if (isPrivateIdentifier(left)) {
-        if (languageVersion < 99 /* ESNext */) {
-          checkExternalEmitHelpers(left, 2097152 /* ClassPrivateFieldIn */);
-        }
-        if (!getNodeLinks(left).resolvedSymbol && getContainingClass(left)) {
-          const isUncheckedJS = isUncheckedJSSuggestion(
-            left,
-            rightType.symbol,
-            /*excludeClasses*/
-            true
-          );
-          reportNonexistentProperty(left, rightType, isUncheckedJS);
-        }
-      } else {
-        checkTypeAssignableTo(checkNonNullType(leftType, left), stringNumberSymbolType, left);
-      }
-      if (checkTypeAssignableTo(checkNonNullType(rightType, right), nonPrimitiveType, right)) {
-        if (hasEmptyObjectIntersection(rightType)) {
-          error(right, Diagnostics.Type_0_may_represent_a_primitive_value_which_is_not_permitted_as_the_right_operand_of_the_in_operator, typeToString(rightType));
-        }
-      }
-      return booleanType;
-    }
-    function checkObjectLiteralAssignment(node, sourceType, rightIsThis) {
-      const properties = node.properties;
-      if (strictNullChecks && properties.length === 0) {
-        return checkNonNullType(sourceType, node);
-      }
-      for (let i = 0; i < properties.length; i++) {
-        checkObjectLiteralDestructuringPropertyAssignment(node, sourceType, i, properties, rightIsThis);
-      }
-      return sourceType;
-    }
-    function checkObjectLiteralDestructuringPropertyAssignment(node, objectLiteralType, propertyIndex, allProperties, rightIsThis = false) {
-      const properties = node.properties;
-      const property = properties[propertyIndex];
-      if (property.kind === 302 /* PropertyAssignment */ || property.kind === 303 /* ShorthandPropertyAssignment */) {
-        const name = property.name;
-        const exprType = getLiteralTypeFromPropertyName(name);
-        if (isTypeUsableAsPropertyName(exprType)) {
-          const text = getPropertyNameFromType(exprType);
-          const prop = getPropertyOfType(objectLiteralType, text);
-          if (prop) {
-            markPropertyAsReferenced(prop, property, rightIsThis);
-            checkPropertyAccessibility(
-              property,
-              /*isSuper*/
-              false,
-              /*writing*/
-              true,
-              objectLiteralType,
-              prop
-            );
-          }
-        }
-        const elementType = getIndexedAccessType(objectLiteralType, exprType, 32 /* ExpressionPosition */, name);
-        const type = getFlowTypeOfDestructuring(property, elementType);
-        return checkDestructuringAssignment(property.kind === 303 /* ShorthandPropertyAssignment */ ? property : property.initializer, type);
-      } else if (property.kind === 304 /* SpreadAssignment */) {
-        if (propertyIndex < properties.length - 1) {
-          error(property, Diagnostics.A_rest_element_must_be_last_in_a_destructuring_pattern);
-        } else {
-          if (languageVersion < 99 /* ESNext */) {
-            checkExternalEmitHelpers(property, 4 /* Rest */);
-          }
-          const nonRestNames = [];
-          if (allProperties) {
-            for (const otherProperty of allProperties) {
-              if (!isSpreadAssignment(otherProperty)) {
-                nonRestNames.push(otherProperty.name);
-              }
-            }
-          }
-          const type = getRestType(objectLiteralType, nonRestNames, objectLiteralType.symbol);
-          checkGrammarForDisallowedTrailingComma(allProperties, Diagnostics.A_rest_parameter_or_binding_pattern_may_not_have_a_trailing_comma);
-          return checkDestructuringAssignment(property.expression, type);
-        }
-      } else {
-        error(property, Diagnostics.Property_assignment_expected);
-      }
-    }
-    function checkArrayLiteralAssignment(node, sourceType, checkMode) {
-      const elements = node.elements;
-      if (languageVersion < 2 /* ES2015 */ && compilerOptions.downlevelIteration) {
-        checkExternalEmitHelpers(node, 512 /* Read */);
-      }
-      const possiblyOutOfBoundsType = checkIteratedTypeOrElementType(65 /* Destructuring */ | 128 /* PossiblyOutOfBounds */, sourceType, undefinedType, node) || errorType;
-      let inBoundsType = compilerOptions.noUncheckedIndexedAccess ? void 0 : possiblyOutOfBoundsType;
-      for (let i = 0; i < elements.length; i++) {
-        let type = possiblyOutOfBoundsType;
-        if (node.elements[i].kind === 229 /* SpreadElement */) {
-          type = inBoundsType = inBoundsType ?? (checkIteratedTypeOrElementType(65 /* Destructuring */, sourceType, undefinedType, node) || errorType);
-        }
-        checkArrayLiteralDestructuringElementAssignment(node, sourceType, i, type, checkMode);
-      }
-      return sourceType;
-    }
-    function checkArrayLiteralDestructuringElementAssignment(node, sourceType, elementIndex, elementType, checkMode) {
-      const elements = node.elements;
-      const element = elements[elementIndex];
-      if (element.kind !== 231 /* OmittedExpression */) {
-        if (element.kind !== 229 /* SpreadElement */) {
-          const indexType = getNumberLiteralType(elementIndex);
-          if (isArrayLikeType(sourceType)) {
-            const accessFlags = 32 /* ExpressionPosition */ | (hasDefaultValue(element) ? 16 /* NoTupleBoundsCheck */ : 0);
-            const elementType2 = getIndexedAccessTypeOrUndefined(sourceType, indexType, accessFlags, createSyntheticExpression(element, indexType)) || errorType;
-            const assignedType = hasDefaultValue(element) ? getTypeWithFacts(elementType2, 524288 /* NEUndefined */) : elementType2;
-            const type = getFlowTypeOfDestructuring(element, assignedType);
-            return checkDestructuringAssignment(element, type, checkMode);
-          }
-          return checkDestructuringAssignment(element, elementType, checkMode);
-        }
-        if (elementIndex < elements.length - 1) {
-          error(element, Diagnostics.A_rest_element_must_be_last_in_a_destructuring_pattern);
-        } else {
-          const restExpression = element.expression;
-          if (restExpression.kind === 225 /* BinaryExpression */ && restExpression.operatorToken.kind === 64 /* EqualsToken */) {
-            error(restExpression.operatorToken, Diagnostics.A_rest_element_cannot_have_an_initializer);
-          } else {
-            checkGrammarForDisallowedTrailingComma(node.elements, Diagnostics.A_rest_parameter_or_binding_pattern_may_not_have_a_trailing_comma);
-            const type = everyType(sourceType, isTupleType) ? mapType(sourceType, (t) => sliceTupleType(t, elementIndex)) : createArrayType(elementType);
-            return checkDestructuringAssignment(restExpression, type, checkMode);
-          }
-        }
-      }
-      return void 0;
-    }
-    function checkDestructuringAssignment(exprOrAssignment, sourceType, checkMode, rightIsThis) {
-      let target;
-      if (exprOrAssignment.kind === 303 /* ShorthandPropertyAssignment */) {
-        const prop = exprOrAssignment;
-        if (prop.objectAssignmentInitializer) {
-          if (strictNullChecks && !(getTypeFacts(checkExpression(prop.objectAssignmentInitializer)) & 16777216 /* IsUndefined */)) {
-            sourceType = getTypeWithFacts(sourceType, 524288 /* NEUndefined */);
-          }
-          checkBinaryLikeExpression(prop.name, prop.equalsToken, prop.objectAssignmentInitializer, checkMode);
-        }
-        target = exprOrAssignment.name;
-      } else {
-        target = exprOrAssignment;
-      }
-      if (target.kind === 225 /* BinaryExpression */ && target.operatorToken.kind === 64 /* EqualsToken */) {
-        checkBinaryExpression(target, checkMode);
-        target = target.left;
-        if (strictNullChecks) {
-          sourceType = getTypeWithFacts(sourceType, 524288 /* NEUndefined */);
-        }
-      }
-      if (target.kind === 209 /* ObjectLiteralExpression */) {
-        return checkObjectLiteralAssignment(target, sourceType, rightIsThis);
-      }
-      if (target.kind === 208 /* ArrayLiteralExpression */) {
-        return checkArrayLiteralAssignment(target, sourceType, checkMode);
-      }
-      return checkReferenceAssignment(target, sourceType, checkMode);
-    }
-    function checkReferenceAssignment(target, sourceType, checkMode) {
-      const targetType = checkExpression(target, checkMode);
-      const error2 = target.parent.kind === 304 /* SpreadAssignment */ ? Diagnostics.The_target_of_an_object_rest_assignment_must_be_a_variable_or_a_property_access : Diagnostics.The_left_hand_side_of_an_assignment_expression_must_be_a_variable_or_a_property_access;
-      const optionalError = target.parent.kind === 304 /* SpreadAssignment */ ? Diagnostics.The_target_of_an_object_rest_assignment_may_not_be_an_optional_property_access : Diagnostics.The_left_hand_side_of_an_assignment_expression_may_not_be_an_optional_property_access;
-      if (checkReferenceExpression(target, error2, optionalError)) {
-        checkTypeAssignableToAndOptionallyElaborate(sourceType, targetType, target, target);
-      }
-      if (isPrivateIdentifierPropertyAccessExpression(target)) {
-        checkExternalEmitHelpers(target.parent, 1048576 /* ClassPrivateFieldSet */);
-      }
-      return sourceType;
-    }
-    function isSideEffectFree(node) {
-      node = skipParentheses(node);
-      switch (node.kind) {
-        case 80 /* Identifier */:
-        case 11 /* StringLiteral */:
-        case 14 /* RegularExpressionLiteral */:
-        case 214 /* TaggedTemplateExpression */:
-        case 227 /* TemplateExpression */:
-        case 15 /* NoSubstitutionTemplateLiteral */:
-        case 9 /* NumericLiteral */:
-        case 10 /* BigIntLiteral */:
-        case 112 /* TrueKeyword */:
-        case 97 /* FalseKeyword */:
-        case 106 /* NullKeyword */:
-        case 157 /* UndefinedKeyword */:
-        case 217 /* FunctionExpression */:
-        case 230 /* ClassExpression */:
-        case 218 /* ArrowFunction */:
-        case 208 /* ArrayLiteralExpression */:
-        case 209 /* ObjectLiteralExpression */:
-        case 220 /* TypeOfExpression */:
-        case 234 /* NonNullExpression */:
-        case 284 /* JsxSelfClosingElement */:
-        case 283 /* JsxElement */:
-          return true;
-        case 226 /* ConditionalExpression */:
-          return isSideEffectFree(node.whenTrue) && isSideEffectFree(node.whenFalse);
-        case 225 /* BinaryExpression */:
-          if (isAssignmentOperator(node.operatorToken.kind)) {
-            return false;
-          }
-          return isSideEffectFree(node.left) && isSideEffectFree(node.right);
-        case 223 /* PrefixUnaryExpression */:
-        case 224 /* PostfixUnaryExpression */:
-          switch (node.operator) {
-            case 54 /* ExclamationToken */:
-            case 40 /* PlusToken */:
-            case 41 /* MinusToken */:
-            case 55 /* TildeToken */:
-              return true;
-          }
-          return false;
-        case 221 /* VoidExpression */:
-        case 215 /* TypeAssertionExpression */:
-        case 233 /* AsExpression */:
-        default:
-          return false;
-      }
-    }
-    function isTypeEqualityComparableTo(source, target) {
-      return (target.flags & 98304 /* Nullable */) !== 0 || isTypeComparableTo(source, target);
-    }
-    function createCheckBinaryExpression() {
-      const trampoline = createBinaryExpressionTrampoline(onEnter, onLeft, onOperator, onRight, onExit, foldState);
-      return (node, checkMode) => {
-        const result = trampoline(node, checkMode);
-        Debug.assertIsDefined(result);
-        return result;
-      };
-      function onEnter(node, state, checkMode) {
-        if (state) {
-          state.stackIndex++;
-          state.skip = false;
-          setLeftType(
-            state,
-            /*type*/
-            void 0
-          );
-          setLastResult(
-            state,
-            /*type*/
-            void 0
-          );
-        } else {
-          state = {
-            checkMode,
-            skip: false,
-            stackIndex: 0,
-            typeStack: [void 0, void 0]
-          };
-        }
-        if (isInJSFile(node) && getAssignedExpandoInitializer(node)) {
-          state.skip = true;
-          setLastResult(state, checkExpression(node.right, checkMode));
-          return state;
-        }
-        checkGrammarNullishCoalesceWithLogicalExpression(node);
-        const operator = node.operatorToken.kind;
-        if (operator === 64 /* EqualsToken */ && (node.left.kind === 209 /* ObjectLiteralExpression */ || node.left.kind === 208 /* ArrayLiteralExpression */)) {
-          state.skip = true;
-          setLastResult(state, checkDestructuringAssignment(node.left, checkExpression(node.right, checkMode), checkMode, node.right.kind === 110 /* ThisKeyword */));
-          return state;
-        }
-        return state;
-      }
-      function onLeft(left, state, _node) {
-        if (!state.skip) {
-          return maybeCheckExpression(state, left);
-        }
-      }
-      function onOperator(operatorToken, state, node) {
-        if (!state.skip) {
-          const leftType = getLastResult(state);
-          Debug.assertIsDefined(leftType);
-          setLeftType(state, leftType);
-          setLastResult(
-            state,
-            /*type*/
-            void 0
-          );
-          const operator = operatorToken.kind;
-          if (isLogicalOrCoalescingBinaryOperator(operator)) {
-            let parent2 = node.parent;
-            while (parent2.kind === 216 /* ParenthesizedExpression */ || isLogicalOrCoalescingBinaryExpression(parent2)) {
-              parent2 = parent2.parent;
-            }
-            if (operator === 56 /* AmpersandAmpersandToken */ || isIfStatement(parent2)) {
-              checkTestingKnownTruthyCallableOrAwaitableType(node.left, leftType, isIfStatement(parent2) ? parent2.thenStatement : void 0);
-            }
-            checkTruthinessOfType(leftType, node.left);
-          }
-        }
-      }
-      function onRight(right, state, _node) {
-        if (!state.skip) {
-          return maybeCheckExpression(state, right);
-        }
-      }
-      function onExit(node, state) {
-        let result;
-        if (state.skip) {
-          result = getLastResult(state);
-        } else {
-          const leftType = getLeftType(state);
-          Debug.assertIsDefined(leftType);
-          const rightType = getLastResult(state);
-          Debug.assertIsDefined(rightType);
-          result = checkBinaryLikeExpressionWorker(node.left, node.operatorToken, node.right, leftType, rightType, node);
-        }
-        state.skip = false;
-        setLeftType(
-          state,
-          /*type*/
-          void 0
-        );
-        setLastResult(
-          state,
-          /*type*/
-          void 0
-        );
-        state.stackIndex--;
-        return result;
-      }
-      function foldState(state, result, _side) {
-        setLastResult(state, result);
-        return state;
-      }
-      function maybeCheckExpression(state, node) {
-        if (isBinaryExpression(node)) {
-          return node;
-        }
-        setLastResult(state, checkExpression(node, state.checkMode));
-      }
-      function getLeftType(state) {
-        return state.typeStack[state.stackIndex];
-      }
-      function setLeftType(state, type) {
-        state.typeStack[state.stackIndex] = type;
-      }
-      function getLastResult(state) {
-        return state.typeStack[state.stackIndex + 1];
-      }
-      function setLastResult(state, type) {
-        state.typeStack[state.stackIndex + 1] = type;
-      }
-    }
-    function checkGrammarNullishCoalesceWithLogicalExpression(node) {
-      const { left, operatorToken, right } = node;
-      if (operatorToken.kind === 61 /* QuestionQuestionToken */) {
-        if (isBinaryExpression(left) && (left.operatorToken.kind === 57 /* BarBarToken */ || left.operatorToken.kind === 56 /* AmpersandAmpersandToken */)) {
-          grammarErrorOnNode(left, Diagnostics._0_and_1_operations_cannot_be_mixed_without_parentheses, tokenToString(left.operatorToken.kind), tokenToString(operatorToken.kind));
-        }
-        if (isBinaryExpression(right) && (right.operatorToken.kind === 57 /* BarBarToken */ || right.operatorToken.kind === 56 /* AmpersandAmpersandToken */)) {
-          grammarErrorOnNode(right, Diagnostics._0_and_1_operations_cannot_be_mixed_without_parentheses, tokenToString(right.operatorToken.kind), tokenToString(operatorToken.kind));
-        }
-      }
-    }
-    function checkBinaryLikeExpression(left, operatorToken, right, checkMode, errorNode) {
-      const operator = operatorToken.kind;
-      if (operator === 64 /* EqualsToken */ && (left.kind === 209 /* ObjectLiteralExpression */ || left.kind === 208 /* ArrayLiteralExpression */)) {
-        return checkDestructuringAssignment(left, checkExpression(right, checkMode), checkMode, right.kind === 110 /* ThisKeyword */);
-      }
-      let leftType;
-      if (isLogicalOrCoalescingBinaryOperator(operator)) {
-        leftType = checkTruthinessExpression(left, checkMode);
-      } else {
-        leftType = checkExpression(left, checkMode);
-      }
-      const rightType = checkExpression(right, checkMode);
-      return checkBinaryLikeExpressionWorker(left, operatorToken, right, leftType, rightType, errorNode);
-    }
-    function checkBinaryLikeExpressionWorker(left, operatorToken, right, leftType, rightType, errorNode) {
-      const operator = operatorToken.kind;
-      switch (operator) {
-        case 42 /* AsteriskToken */:
-        case 43 /* AsteriskAsteriskToken */:
-        case 67 /* AsteriskEqualsToken */:
-        case 68 /* AsteriskAsteriskEqualsToken */:
-        case 44 /* SlashToken */:
-        case 69 /* SlashEqualsToken */:
-        case 45 /* PercentToken */:
-        case 70 /* PercentEqualsToken */:
-        case 41 /* MinusToken */:
-        case 66 /* MinusEqualsToken */:
-        case 48 /* LessThanLessThanToken */:
-        case 71 /* LessThanLessThanEqualsToken */:
-        case 49 /* GreaterThanGreaterThanToken */:
-        case 72 /* GreaterThanGreaterThanEqualsToken */:
-        case 50 /* GreaterThanGreaterThanGreaterThanToken */:
-        case 73 /* GreaterThanGreaterThanGreaterThanEqualsToken */:
-        case 52 /* BarToken */:
-        case 75 /* BarEqualsToken */:
-        case 53 /* CaretToken */:
-        case 79 /* CaretEqualsToken */:
-        case 51 /* AmpersandToken */:
-        case 74 /* AmpersandEqualsToken */:
-          if (leftType === silentNeverType || rightType === silentNeverType) {
-            return silentNeverType;
-          }
-          leftType = checkNonNullType(leftType, left);
-          rightType = checkNonNullType(rightType, right);
-          let suggestedOperator;
-          if (leftType.flags & 528 /* BooleanLike */ && rightType.flags & 528 /* BooleanLike */ && (suggestedOperator = getSuggestedBooleanOperator(operatorToken.kind)) !== void 0) {
-            error(errorNode || operatorToken, Diagnostics.The_0_operator_is_not_allowed_for_boolean_types_Consider_using_1_instead, tokenToString(operatorToken.kind), tokenToString(suggestedOperator));
-            return numberType;
-          } else {
-            const leftOk = checkArithmeticOperandType(
-              left,
-              leftType,
-              Diagnostics.The_left_hand_side_of_an_arithmetic_operation_must_be_of_type_any_number_bigint_or_an_enum_type,
-              /*isAwaitValid*/
-              true
-            );
-            const rightOk = checkArithmeticOperandType(
-              right,
-              rightType,
-              Diagnostics.The_right_hand_side_of_an_arithmetic_operation_must_be_of_type_any_number_bigint_or_an_enum_type,
-              /*isAwaitValid*/
-              true
-            );
-            let resultType2;
-            if (isTypeAssignableToKind(leftType, 3 /* AnyOrUnknown */) && isTypeAssignableToKind(rightType, 3 /* AnyOrUnknown */) || // Or, if neither could be bigint, implicit coercion results in a number result
-            !(maybeTypeOfKind(leftType, 2112 /* BigIntLike */) || maybeTypeOfKind(rightType, 2112 /* BigIntLike */))) {
-              resultType2 = numberType;
-            } else if (bothAreBigIntLike(leftType, rightType)) {
-              switch (operator) {
-                case 50 /* GreaterThanGreaterThanGreaterThanToken */:
-                case 73 /* GreaterThanGreaterThanGreaterThanEqualsToken */:
-                  reportOperatorError();
-                  break;
-                case 43 /* AsteriskAsteriskToken */:
-                case 68 /* AsteriskAsteriskEqualsToken */:
-                  if (languageVersion < 3 /* ES2016 */) {
-                    error(errorNode, Diagnostics.Exponentiation_cannot_be_performed_on_bigint_values_unless_the_target_option_is_set_to_es2016_or_later);
-                  }
-              }
-              resultType2 = bigintType;
-            } else {
-              reportOperatorError(bothAreBigIntLike);
-              resultType2 = errorType;
-            }
-            if (leftOk && rightOk) {
-              checkAssignmentOperator(resultType2);
-            }
-            return resultType2;
-          }
-        case 40 /* PlusToken */:
-        case 65 /* PlusEqualsToken */:
-          if (leftType === silentNeverType || rightType === silentNeverType) {
-            return silentNeverType;
-          }
-          if (!isTypeAssignableToKind(leftType, 402653316 /* StringLike */) && !isTypeAssignableToKind(rightType, 402653316 /* StringLike */)) {
-            leftType = checkNonNullType(leftType, left);
-            rightType = checkNonNullType(rightType, right);
-          }
-          let resultType;
-          if (isTypeAssignableToKind(
-            leftType,
-            296 /* NumberLike */,
-            /*strict*/
-            true
-          ) && isTypeAssignableToKind(
-            rightType,
-            296 /* NumberLike */,
-            /*strict*/
-            true
-          )) {
-            resultType = numberType;
-          } else if (isTypeAssignableToKind(
-            leftType,
-            2112 /* BigIntLike */,
-            /*strict*/
-            true
-          ) && isTypeAssignableToKind(
-            rightType,
-            2112 /* BigIntLike */,
-            /*strict*/
-            true
-          )) {
-            resultType = bigintType;
-          } else if (isTypeAssignableToKind(
-            leftType,
-            402653316 /* StringLike */,
-            /*strict*/
-            true
-          ) || isTypeAssignableToKind(
-            rightType,
-            402653316 /* StringLike */,
-            /*strict*/
-            true
-          )) {
-            resultType = stringType;
-          } else if (isTypeAny(leftType) || isTypeAny(rightType)) {
-            resultType = isErrorType(leftType) || isErrorType(rightType) ? errorType : anyType;
-          }
-          if (resultType && !checkForDisallowedESSymbolOperand(operator)) {
-            return resultType;
-          }
-          if (!resultType) {
-            const closeEnoughKind = 296 /* NumberLike */ | 2112 /* BigIntLike */ | 402653316 /* StringLike */ | 3 /* AnyOrUnknown */;
-            reportOperatorError((left2, right2) => isTypeAssignableToKind(left2, closeEnoughKind) && isTypeAssignableToKind(right2, closeEnoughKind));
-            return anyType;
-          }
-          if (operator === 65 /* PlusEqualsToken */) {
-            checkAssignmentOperator(resultType);
-          }
-          return resultType;
-        case 30 /* LessThanToken */:
-        case 32 /* GreaterThanToken */:
-        case 33 /* LessThanEqualsToken */:
-        case 34 /* GreaterThanEqualsToken */:
-          if (checkForDisallowedESSymbolOperand(operator)) {
-            leftType = getBaseTypeOfLiteralTypeForComparison(checkNonNullType(leftType, left));
-            rightType = getBaseTypeOfLiteralTypeForComparison(checkNonNullType(rightType, right));
-            reportOperatorErrorUnless((left2, right2) => {
-              if (isTypeAny(left2) || isTypeAny(right2)) {
-                return true;
-              }
-              const leftAssignableToNumber = isTypeAssignableTo(left2, numberOrBigIntType);
-              const rightAssignableToNumber = isTypeAssignableTo(right2, numberOrBigIntType);
-              return leftAssignableToNumber && rightAssignableToNumber || !leftAssignableToNumber && !rightAssignableToNumber && areTypesComparable(left2, right2);
-            });
-          }
-          return booleanType;
-        case 35 /* EqualsEqualsToken */:
-        case 36 /* ExclamationEqualsToken */:
-        case 37 /* EqualsEqualsEqualsToken */:
-        case 38 /* ExclamationEqualsEqualsToken */:
-          if (isLiteralExpressionOfObject(left) || isLiteralExpressionOfObject(right)) {
-            const eqType = operator === 35 /* EqualsEqualsToken */ || operator === 37 /* EqualsEqualsEqualsToken */;
-            error(errorNode, Diagnostics.This_condition_will_always_return_0_since_JavaScript_compares_objects_by_reference_not_value, eqType ? "false" : "true");
-          }
-          checkNaNEquality(errorNode, operator, left, right);
-          reportOperatorErrorUnless((left2, right2) => isTypeEqualityComparableTo(left2, right2) || isTypeEqualityComparableTo(right2, left2));
-          return booleanType;
-        case 104 /* InstanceOfKeyword */:
-          return checkInstanceOfExpression(left, right, leftType, rightType);
-        case 103 /* InKeyword */:
-          return checkInExpression(left, right, leftType, rightType);
-        case 56 /* AmpersandAmpersandToken */:
-        case 77 /* AmpersandAmpersandEqualsToken */: {
-          const resultType2 = getTypeFacts(leftType) & 4194304 /* Truthy */ ? getUnionType([extractDefinitelyFalsyTypes(strictNullChecks ? leftType : getBaseTypeOfLiteralType(rightType)), rightType]) : leftType;
-          if (operator === 77 /* AmpersandAmpersandEqualsToken */) {
-            checkAssignmentOperator(rightType);
-          }
-          return resultType2;
-        }
-        case 57 /* BarBarToken */:
-        case 76 /* BarBarEqualsToken */: {
-          const resultType2 = getTypeFacts(leftType) & 8388608 /* Falsy */ ? getUnionType([getNonNullableType(removeDefinitelyFalsyTypes(leftType)), rightType], 2 /* Subtype */) : leftType;
-          if (operator === 76 /* BarBarEqualsToken */) {
-            checkAssignmentOperator(rightType);
-          }
-          return resultType2;
-        }
-        case 61 /* QuestionQuestionToken */:
-        case 78 /* QuestionQuestionEqualsToken */: {
-          const resultType2 = getTypeFacts(leftType) & 262144 /* EQUndefinedOrNull */ ? getUnionType([getNonNullableType(leftType), rightType], 2 /* Subtype */) : leftType;
-          if (operator === 78 /* QuestionQuestionEqualsToken */) {
-            checkAssignmentOperator(rightType);
-          }
-          return resultType2;
-        }
-        case 64 /* EqualsToken */:
-          const declKind = isBinaryExpression(left.parent) ? getAssignmentDeclarationKind(left.parent) : 0 /* None */;
-          checkAssignmentDeclaration(declKind, rightType);
-          if (isAssignmentDeclaration2(declKind)) {
-            if (!(rightType.flags & 524288 /* Object */) || declKind !== 2 /* ModuleExports */ && declKind !== 6 /* Prototype */ && !isEmptyObjectType(rightType) && !isFunctionObjectType(rightType) && !(getObjectFlags(rightType) & 1 /* Class */)) {
-              checkAssignmentOperator(rightType);
-            }
-            return leftType;
-          } else {
-            checkAssignmentOperator(rightType);
-            return rightType;
-          }
-        case 28 /* CommaToken */:
-          if (!compilerOptions.allowUnreachableCode && isSideEffectFree(left) && !isIndirectCall(left.parent)) {
-            const sf = getSourceFileOfNode(left);
-            const sourceText = sf.text;
-            const start = skipTrivia(sourceText, left.pos);
-            const isInDiag2657 = sf.parseDiagnostics.some((diag2) => {
-              if (diag2.code !== Diagnostics.JSX_expressions_must_have_one_parent_element.code)
-                return false;
-              return textSpanContainsPosition(diag2, start);
-            });
-            if (!isInDiag2657)
-              error(left, Diagnostics.Left_side_of_comma_operator_is_unused_and_has_no_side_effects);
-          }
-          return rightType;
-        default:
-          return Debug.fail();
-      }
-      function bothAreBigIntLike(left2, right2) {
-        return isTypeAssignableToKind(left2, 2112 /* BigIntLike */) && isTypeAssignableToKind(right2, 2112 /* BigIntLike */);
-      }
-      function checkAssignmentDeclaration(kind, rightType2) {
-        if (kind === 2 /* ModuleExports */) {
-          for (const prop of getPropertiesOfObjectType(rightType2)) {
-            const propType = getTypeOfSymbol(prop);
-            if (propType.symbol && propType.symbol.flags & 32 /* Class */) {
-              const name = prop.escapedName;
-              const symbol = resolveName(
-                prop.valueDeclaration,
-                name,
-                788968 /* Type */,
-                /*nameNotFoundMessage*/
-                void 0,
-                name,
-                /*isUse*/
-                false
-              );
-              if ((symbol == null ? void 0 : symbol.declarations) && symbol.declarations.some(isJSDocTypedefTag)) {
-                addDuplicateDeclarationErrorsForSymbols(symbol, Diagnostics.Duplicate_identifier_0, unescapeLeadingUnderscores(name), prop);
-                addDuplicateDeclarationErrorsForSymbols(prop, Diagnostics.Duplicate_identifier_0, unescapeLeadingUnderscores(name), symbol);
-              }
-            }
-          }
-        }
-      }
-      function isIndirectCall(node) {
-        return node.parent.kind === 216 /* ParenthesizedExpression */ && isNumericLiteral(node.left) && node.left.text === "0" && (isCallExpression(node.parent.parent) && node.parent.parent.expression === node.parent || node.parent.parent.kind === 214 /* TaggedTemplateExpression */) && // special-case for "eval" because it's the only non-access case where an indirect call actually affects behavior.
-        (isAccessExpression(node.right) || isIdentifier(node.right) && node.right.escapedText === "eval");
-      }
-      function checkForDisallowedESSymbolOperand(operator2) {
-        const offendingSymbolOperand = maybeTypeOfKindConsideringBaseConstraint(leftType, 12288 /* ESSymbolLike */) ? left : maybeTypeOfKindConsideringBaseConstraint(rightType, 12288 /* ESSymbolLike */) ? right : void 0;
-        if (offendingSymbolOperand) {
-          error(offendingSymbolOperand, Diagnostics.The_0_operator_cannot_be_applied_to_type_symbol, tokenToString(operator2));
-          return false;
-        }
-        return true;
-      }
-      function getSuggestedBooleanOperator(operator2) {
-        switch (operator2) {
-          case 52 /* BarToken */:
-          case 75 /* BarEqualsToken */:
-            return 57 /* BarBarToken */;
-          case 53 /* CaretToken */:
-          case 79 /* CaretEqualsToken */:
-            return 38 /* ExclamationEqualsEqualsToken */;
-          case 51 /* AmpersandToken */:
-          case 74 /* AmpersandEqualsToken */:
-            return 56 /* AmpersandAmpersandToken */;
-          default:
-            return void 0;
-        }
-      }
-      function checkAssignmentOperator(valueType) {
-        if (isAssignmentOperator(operator)) {
-          addLazyDiagnostic(checkAssignmentOperatorWorker);
-        }
-        function checkAssignmentOperatorWorker() {
-          let assigneeType = leftType;
-          if (isCompoundAssignment(operatorToken.kind) && left.kind === 210 /* PropertyAccessExpression */) {
-            assigneeType = checkPropertyAccessExpression(
-              left,
-              /*checkMode*/
-              void 0,
-              /*writeOnly*/
-              true
-            );
-          }
-          if (checkReferenceExpression(
-            left,
-            Diagnostics.The_left_hand_side_of_an_assignment_expression_must_be_a_variable_or_a_property_access,
-            Diagnostics.The_left_hand_side_of_an_assignment_expression_may_not_be_an_optional_property_access
-          )) {
-            let headMessage;
-            if (exactOptionalPropertyTypes && isPropertyAccessExpression(left) && maybeTypeOfKind(valueType, 32768 /* Undefined */)) {
-              const target = getTypeOfPropertyOfType(getTypeOfExpression(left.expression), left.name.escapedText);
-              if (isExactOptionalPropertyMismatch(valueType, target)) {
-                headMessage = Diagnostics.Type_0_is_not_assignable_to_type_1_with_exactOptionalPropertyTypes_Colon_true_Consider_adding_undefined_to_the_type_of_the_target;
-              }
-            }
-            checkTypeAssignableToAndOptionallyElaborate(valueType, assigneeType, left, right, headMessage);
-          }
-        }
-      }
-      function isAssignmentDeclaration2(kind) {
-        var _a;
-        switch (kind) {
-          case 2 /* ModuleExports */:
-            return true;
-          case 1 /* ExportsProperty */:
-          case 5 /* Property */:
-          case 6 /* Prototype */:
-          case 3 /* PrototypeProperty */:
-          case 4 /* ThisProperty */:
-            const symbol = getSymbolOfNode(left);
-            const init = getAssignedExpandoInitializer(right);
-            return !!init && isObjectLiteralExpression(init) && !!((_a = symbol == null ? void 0 : symbol.exports) == null ? void 0 : _a.size);
-          default:
-            return false;
-        }
-      }
-      function reportOperatorErrorUnless(typesAreCompatible) {
-        if (!typesAreCompatible(leftType, rightType)) {
-          reportOperatorError(typesAreCompatible);
-          return true;
-        }
-        return false;
-      }
-      function reportOperatorError(isRelated) {
-        let wouldWorkWithAwait = false;
-        const errNode = errorNode || operatorToken;
-        if (isRelated) {
-          const awaitedLeftType = getAwaitedTypeNoAlias(leftType);
-          const awaitedRightType = getAwaitedTypeNoAlias(rightType);
-          wouldWorkWithAwait = !(awaitedLeftType === leftType && awaitedRightType === rightType) && !!(awaitedLeftType && awaitedRightType) && isRelated(awaitedLeftType, awaitedRightType);
-        }
-        let effectiveLeft = leftType;
-        let effectiveRight = rightType;
-        if (!wouldWorkWithAwait && isRelated) {
-          [effectiveLeft, effectiveRight] = getBaseTypesIfUnrelated(leftType, rightType, isRelated);
-        }
-        const [leftStr, rightStr] = getTypeNamesForErrorDisplay(effectiveLeft, effectiveRight);
-        if (!tryGiveBetterPrimaryError(errNode, wouldWorkWithAwait, leftStr, rightStr)) {
-          errorAndMaybeSuggestAwait(
-            errNode,
-            wouldWorkWithAwait,
-            Diagnostics.Operator_0_cannot_be_applied_to_types_1_and_2,
-            tokenToString(operatorToken.kind),
-            leftStr,
-            rightStr
-          );
-        }
-      }
-      function tryGiveBetterPrimaryError(errNode, maybeMissingAwait, leftStr, rightStr) {
-        switch (operatorToken.kind) {
-          case 37 /* EqualsEqualsEqualsToken */:
-          case 35 /* EqualsEqualsToken */:
-          case 38 /* ExclamationEqualsEqualsToken */:
-          case 36 /* ExclamationEqualsToken */:
-            return errorAndMaybeSuggestAwait(
-              errNode,
-              maybeMissingAwait,
-              Diagnostics.This_comparison_appears_to_be_unintentional_because_the_types_0_and_1_have_no_overlap,
-              leftStr,
-              rightStr
-            );
-          default:
-            return void 0;
-        }
-      }
-      function checkNaNEquality(errorNode2, operator2, left2, right2) {
-        const isLeftNaN = isGlobalNaN(skipParentheses(left2));
-        const isRightNaN = isGlobalNaN(skipParentheses(right2));
-        if (isLeftNaN || isRightNaN) {
-          const err = error(
-            errorNode2,
-            Diagnostics.This_condition_will_always_return_0,
-            tokenToString(operator2 === 37 /* EqualsEqualsEqualsToken */ || operator2 === 35 /* EqualsEqualsToken */ ? 97 /* FalseKeyword */ : 112 /* TrueKeyword */)
-          );
-          if (isLeftNaN && isRightNaN)
-            return;
-          const operatorString = operator2 === 38 /* ExclamationEqualsEqualsToken */ || operator2 === 36 /* ExclamationEqualsToken */ ? tokenToString(54 /* ExclamationToken */) : "";
-          const location = isLeftNaN ? right2 : left2;
-          const expression = skipParentheses(location);
-          addRelatedInfo(err, createDiagnosticForNode(
-            location,
-            Diagnostics.Did_you_mean_0,
-            `${operatorString}Number.isNaN(${isEntityNameExpression(expression) ? entityNameToString(expression) : "..."})`
-          ));
-        }
-      }
-      function isGlobalNaN(expr) {
-        if (isIdentifier(expr) && expr.escapedText === "NaN") {
-          const globalNaNSymbol = getGlobalNaNSymbol();
-          return !!globalNaNSymbol && globalNaNSymbol === getResolvedSymbol(expr);
-        }
-        return false;
-      }
-    }
-    function getBaseTypesIfUnrelated(leftType, rightType, isRelated) {
-      let effectiveLeft = leftType;
-      let effectiveRight = rightType;
-      const leftBase = getBaseTypeOfLiteralType(leftType);
-      const rightBase = getBaseTypeOfLiteralType(rightType);
-      if (!isRelated(leftBase, rightBase)) {
-        effectiveLeft = leftBase;
-        effectiveRight = rightBase;
-      }
-      return [effectiveLeft, effectiveRight];
-    }
-    function checkYieldExpression(node) {
-      addLazyDiagnostic(checkYieldExpressionGrammar);
-      const func = getContainingFunction(node);
-      if (!func)
-        return anyType;
-      const functionFlags = getFunctionFlags(func);
-      if (!(functionFlags & 1 /* Generator */)) {
-        return anyType;
-      }
-      const isAsync = (functionFlags & 2 /* Async */) !== 0;
-      if (node.asteriskToken) {
-        if (isAsync && languageVersion < 99 /* ESNext */) {
-          checkExternalEmitHelpers(node, 26624 /* AsyncDelegatorIncludes */);
-        }
-        if (!isAsync && languageVersion < 2 /* ES2015 */ && compilerOptions.downlevelIteration) {
-          checkExternalEmitHelpers(node, 256 /* Values */);
-        }
-      }
-      const returnType = getReturnTypeFromAnnotation(func);
-      const iterationTypes = returnType && getIterationTypesOfGeneratorFunctionReturnType(returnType, isAsync);
-      const signatureYieldType = iterationTypes && iterationTypes.yieldType || anyType;
-      const signatureNextType = iterationTypes && iterationTypes.nextType || anyType;
-      const resolvedSignatureNextType = isAsync ? getAwaitedType(signatureNextType) || anyType : signatureNextType;
-      const yieldExpressionType = node.expression ? checkExpression(node.expression) : undefinedWideningType;
-      const yieldedType = getYieldedTypeOfYieldExpression(node, yieldExpressionType, resolvedSignatureNextType, isAsync);
-      if (returnType && yieldedType) {
-        checkTypeAssignableToAndOptionallyElaborate(yieldedType, signatureYieldType, node.expression || node, node.expression);
-      }
-      if (node.asteriskToken) {
-        const use = isAsync ? 19 /* AsyncYieldStar */ : 17 /* YieldStar */;
-        return getIterationTypeOfIterable(use, 1 /* Return */, yieldExpressionType, node.expression) || anyType;
-      } else if (returnType) {
-        return getIterationTypeOfGeneratorFunctionReturnType(2 /* Next */, returnType, isAsync) || anyType;
-      }
-      let type = getContextualIterationType(2 /* Next */, func);
-      if (!type) {
-        type = anyType;
-        addLazyDiagnostic(() => {
-          if (noImplicitAny && !expressionResultIsUnused(node)) {
-            const contextualType = getContextualType2(
-              node,
-              /*contextFlags*/
-              void 0
-            );
-            if (!contextualType || isTypeAny(contextualType)) {
-              error(node, Diagnostics.yield_expression_implicitly_results_in_an_any_type_because_its_containing_generator_lacks_a_return_type_annotation);
-            }
-          }
-        });
-      }
-      return type;
-      function checkYieldExpressionGrammar() {
-        if (!(node.flags & 8192 /* YieldContext */)) {
-          grammarErrorOnFirstToken(node, Diagnostics.A_yield_expression_is_only_allowed_in_a_generator_body);
-        }
-        if (isInParameterInitializerBeforeContainingFunction(node)) {
-          error(node, Diagnostics.yield_expressions_cannot_be_used_in_a_parameter_initializer);
-        }
-      }
-    }
-    function checkConditionalExpression(node, checkMode) {
-      const type = checkTruthinessExpression(node.condition);
-      checkTestingKnownTruthyCallableOrAwaitableType(node.condition, type, node.whenTrue);
-      const type1 = checkExpression(node.whenTrue, checkMode);
-      const type2 = checkExpression(node.whenFalse, checkMode);
-      return getUnionType([type1, type2], 2 /* Subtype */);
-    }
-    function isTemplateLiteralContext(node) {
-      const parent2 = node.parent;
-      return isParenthesizedExpression(parent2) && isTemplateLiteralContext(parent2) || isElementAccessExpression(parent2) && parent2.argumentExpression === node;
-    }
-    function checkTemplateExpression(node) {
-      const texts = [node.head.text];
-      const types = [];
-      for (const span of node.templateSpans) {
-        const type = checkExpression(span.expression);
-        if (maybeTypeOfKindConsideringBaseConstraint(type, 12288 /* ESSymbolLike */)) {
-          error(span.expression, Diagnostics.Implicit_conversion_of_a_symbol_to_a_string_will_fail_at_runtime_Consider_wrapping_this_expression_in_String);
-        }
-        texts.push(span.literal.text);
-        types.push(isTypeAssignableTo(type, templateConstraintType) ? type : stringType);
-      }
-      return isConstContext(node) || isTemplateLiteralContext(node) || someType(getContextualType2(
-        node,
-        /*contextFlags*/
-        void 0
-      ) || unknownType, isTemplateLiteralContextualType) ? getTemplateLiteralType(texts, types) : stringType;
-    }
-    function isTemplateLiteralContextualType(type) {
-      return !!(type.flags & (128 /* StringLiteral */ | 134217728 /* TemplateLiteral */) || type.flags & 58982400 /* InstantiableNonPrimitive */ && maybeTypeOfKind(getBaseConstraintOfType(type) || unknownType, 402653316 /* StringLike */));
-    }
-    function getContextNode2(node) {
-      if (isJsxAttributes(node) && !isJsxSelfClosingElement(node.parent)) {
-        return node.parent.parent;
-      }
-      return node;
-    }
-    function checkExpressionWithContextualType(node, contextualType, inferenceContext, checkMode) {
-      const contextNode = getContextNode2(node);
-      pushContextualType(
-        contextNode,
-        contextualType,
-        /*isCache*/
-        false
-      );
-      pushInferenceContext(contextNode, inferenceContext);
-      const type = checkExpression(node, checkMode | 1 /* Contextual */ | (inferenceContext ? 2 /* Inferential */ : 0));
-      if (inferenceContext && inferenceContext.intraExpressionInferenceSites) {
-        inferenceContext.intraExpressionInferenceSites = void 0;
-      }
-      const result = maybeTypeOfKind(type, 2944 /* Literal */) && isLiteralOfContextualType(type, instantiateContextualType(
-        contextualType,
-        node,
-        /*contextFlags*/
-        void 0
-      )) ? getRegularTypeOfLiteralType(type) : type;
-      popInferenceContext();
-      popContextualType();
-      return result;
-    }
-    function checkExpressionCached(node, checkMode) {
-      if (checkMode) {
-        return checkExpression(node, checkMode);
-      }
-      const links = getNodeLinks(node);
-      if (!links.resolvedType) {
-        const saveFlowLoopStart = flowLoopStart;
-        const saveFlowTypeCache = flowTypeCache;
-        flowLoopStart = flowLoopCount;
-        flowTypeCache = void 0;
-        links.resolvedType = checkExpression(node, checkMode);
-        flowTypeCache = saveFlowTypeCache;
-        flowLoopStart = saveFlowLoopStart;
-      }
-      return links.resolvedType;
-    }
-    function isTypeAssertion(node) {
-      node = skipParentheses(
-        node,
-        /*excludeJSDocTypeAssertions*/
-        true
-      );
-      return node.kind === 215 /* TypeAssertionExpression */ || node.kind === 233 /* AsExpression */ || isJSDocTypeAssertion(node);
-    }
-    function checkDeclarationInitializer(declaration, checkMode, contextualType) {
-      const initializer = getEffectiveInitializer(declaration);
-      if (isInJSFile(declaration)) {
-        const typeNode = tryGetJSDocSatisfiesTypeNode(declaration);
-        if (typeNode) {
-          return checkSatisfiesExpressionWorker(initializer, typeNode, checkMode);
-        }
-      }
-      const type = getQuickTypeOfExpression(initializer) || (contextualType ? checkExpressionWithContextualType(
-        initializer,
-        contextualType,
-        /*inferenceContext*/
-        void 0,
-        checkMode || 0 /* Normal */
-      ) : checkExpressionCached(initializer, checkMode));
-      return isParameter(declaration) && declaration.name.kind === 206 /* ArrayBindingPattern */ && isTupleType(type) && !type.target.hasRestElement && getTypeReferenceArity(type) < declaration.name.elements.length ? padTupleType(type, declaration.name) : type;
-    }
-    function padTupleType(type, pattern) {
-      const patternElements = pattern.elements;
-      const elementTypes = getElementTypes(type).slice();
-      const elementFlags = type.target.elementFlags.slice();
-      for (let i = getTypeReferenceArity(type); i < patternElements.length; i++) {
-        const e = patternElements[i];
-        if (i < patternElements.length - 1 || !(e.kind === 207 /* BindingElement */ && e.dotDotDotToken)) {
-          elementTypes.push(!isOmittedExpression(e) && hasDefaultValue(e) ? getTypeFromBindingElement(
-            e,
-            /*includePatternInType*/
-            false,
-            /*reportErrors*/
-            false
-          ) : anyType);
-          elementFlags.push(2 /* Optional */);
-          if (!isOmittedExpression(e) && !hasDefaultValue(e)) {
-            reportImplicitAny(e, anyType);
-          }
-        }
-      }
-      return createTupleType(elementTypes, elementFlags, type.target.readonly);
-    }
-    function widenTypeInferredFromInitializer(declaration, type) {
-      const widened = getCombinedNodeFlags(declaration) & 2 /* Const */ || isDeclarationReadonly(declaration) ? type : getWidenedLiteralType(type);
-      if (isInJSFile(declaration)) {
-        if (isEmptyLiteralType(widened)) {
-          reportImplicitAny(declaration, anyType);
-          return anyType;
-        } else if (isEmptyArrayLiteralType(widened)) {
-          reportImplicitAny(declaration, anyArrayType);
-          return anyArrayType;
-        }
-      }
-      return widened;
-    }
-    function isLiteralOfContextualType(candidateType, contextualType) {
-      if (contextualType) {
-        if (contextualType.flags & 3145728 /* UnionOrIntersection */) {
-          const types = contextualType.types;
-          return some(types, (t) => isLiteralOfContextualType(candidateType, t));
-        }
-        if (contextualType.flags & 58982400 /* InstantiableNonPrimitive */) {
-          const constraint = getBaseConstraintOfType(contextualType) || unknownType;
-          return maybeTypeOfKind(constraint, 4 /* String */) && maybeTypeOfKind(candidateType, 128 /* StringLiteral */) || maybeTypeOfKind(constraint, 8 /* Number */) && maybeTypeOfKind(candidateType, 256 /* NumberLiteral */) || maybeTypeOfKind(constraint, 64 /* BigInt */) && maybeTypeOfKind(candidateType, 2048 /* BigIntLiteral */) || maybeTypeOfKind(constraint, 4096 /* ESSymbol */) && maybeTypeOfKind(candidateType, 8192 /* UniqueESSymbol */) || isLiteralOfContextualType(candidateType, constraint);
-        }
-        return !!(contextualType.flags & (128 /* StringLiteral */ | 4194304 /* Index */ | 134217728 /* TemplateLiteral */ | 268435456 /* StringMapping */) && maybeTypeOfKind(candidateType, 128 /* StringLiteral */) || contextualType.flags & 256 /* NumberLiteral */ && maybeTypeOfKind(candidateType, 256 /* NumberLiteral */) || contextualType.flags & 2048 /* BigIntLiteral */ && maybeTypeOfKind(candidateType, 2048 /* BigIntLiteral */) || contextualType.flags & 512 /* BooleanLiteral */ && maybeTypeOfKind(candidateType, 512 /* BooleanLiteral */) || contextualType.flags & 8192 /* UniqueESSymbol */ && maybeTypeOfKind(candidateType, 8192 /* UniqueESSymbol */));
-      }
-      return false;
-    }
-    function isConstContext(node) {
-      const parent2 = node.parent;
-      return isAssertionExpression(parent2) && isConstTypeReference(parent2.type) || isJSDocTypeAssertion(parent2) && isConstTypeReference(getJSDocTypeAssertionType(parent2)) || isValidConstAssertionArgument(node) && isConstTypeVariable(getContextualType2(node, 0 /* None */)) || (isParenthesizedExpression(parent2) || isArrayLiteralExpression(parent2) || isSpreadElement(parent2)) && isConstContext(parent2) || (isPropertyAssignment(parent2) || isShorthandPropertyAssignment(parent2) || isTemplateSpan(parent2)) && isConstContext(parent2.parent);
-    }
-    function checkExpressionForMutableLocation(node, checkMode, forceTuple) {
-      const type = checkExpression(node, checkMode, forceTuple);
-      return isConstContext(node) || isCommonJsExportedExpression(node) ? getRegularTypeOfLiteralType(type) : isTypeAssertion(node) ? type : getWidenedLiteralLikeTypeForContextualType(type, instantiateContextualType(
-        getContextualType2(
-          node,
-          /*contextFlags*/
-          void 0
-        ),
-        node,
-        /*contextFlags*/
-        void 0
-      ));
-    }
-    function checkPropertyAssignment(node, checkMode) {
-      if (node.name.kind === 166 /* ComputedPropertyName */) {
-        checkComputedPropertyName(node.name);
-      }
-      return checkExpressionForMutableLocation(node.initializer, checkMode);
-    }
-    function checkObjectLiteralMethod(node, checkMode) {
-      checkGrammarMethod(node);
-      if (node.name.kind === 166 /* ComputedPropertyName */) {
-        checkComputedPropertyName(node.name);
-      }
-      const uninstantiatedType = checkFunctionExpressionOrObjectLiteralMethod(node, checkMode);
-      return instantiateTypeWithSingleGenericCallSignature(node, uninstantiatedType, checkMode);
-    }
-    function instantiateTypeWithSingleGenericCallSignature(node, type, checkMode) {
-      if (checkMode && checkMode & (2 /* Inferential */ | 8 /* SkipGenericFunctions */)) {
-        const callSignature = getSingleSignature(
-          type,
-          0 /* Call */,
-          /*allowMembers*/
-          true
-        );
-        const constructSignature = getSingleSignature(
-          type,
-          1 /* Construct */,
-          /*allowMembers*/
-          true
-        );
-        const signature = callSignature || constructSignature;
-        if (signature && signature.typeParameters) {
-          const contextualType = getApparentTypeOfContextualType(node, 2 /* NoConstraints */);
-          if (contextualType) {
-            const contextualSignature = getSingleSignature(
-              getNonNullableType(contextualType),
-              callSignature ? 0 /* Call */ : 1 /* Construct */,
-              /*allowMembers*/
-              false
-            );
-            if (contextualSignature && !contextualSignature.typeParameters) {
-              if (checkMode & 8 /* SkipGenericFunctions */) {
-                skippedGenericFunction(node, checkMode);
-                return anyFunctionType;
-              }
-              const context = getInferenceContext(node);
-              const returnType = context.signature && getReturnTypeOfSignature(context.signature);
-              const returnSignature = returnType && getSingleCallOrConstructSignature(returnType);
-              if (returnSignature && !returnSignature.typeParameters && !every(context.inferences, hasInferenceCandidates)) {
-                const uniqueTypeParameters = getUniqueTypeParameters(context, signature.typeParameters);
-                const instantiatedSignature = getSignatureInstantiationWithoutFillingInTypeArguments(signature, uniqueTypeParameters);
-                const inferences = map(context.inferences, (info) => createInferenceInfo(info.typeParameter));
-                applyToParameterTypes(instantiatedSignature, contextualSignature, (source, target) => {
-                  inferTypes(
-                    inferences,
-                    source,
-                    target,
-                    /*priority*/
-                    0,
-                    /*contravariant*/
-                    true
-                  );
-                });
-                if (some(inferences, hasInferenceCandidates)) {
-                  applyToReturnTypes(instantiatedSignature, contextualSignature, (source, target) => {
-                    inferTypes(inferences, source, target);
-                  });
-                  if (!hasOverlappingInferences(context.inferences, inferences)) {
-                    mergeInferences(context.inferences, inferences);
-                    context.inferredTypeParameters = concatenate(context.inferredTypeParameters, uniqueTypeParameters);
-                    return getOrCreateTypeFromSignature(instantiatedSignature);
-                  }
-                }
-              }
-              return getOrCreateTypeFromSignature(instantiateSignatureInContextOf(signature, contextualSignature, context));
-            }
-          }
-        }
-      }
-      return type;
-    }
-    function skippedGenericFunction(node, checkMode) {
-      if (checkMode & 2 /* Inferential */) {
-        const context = getInferenceContext(node);
-        context.flags |= 4 /* SkippedGenericFunction */;
-      }
-    }
-    function hasInferenceCandidates(info) {
-      return !!(info.candidates || info.contraCandidates);
-    }
-    function hasInferenceCandidatesOrDefault(info) {
-      return !!(info.candidates || info.contraCandidates || hasTypeParameterDefault(info.typeParameter));
-    }
-    function hasOverlappingInferences(a, b) {
-      for (let i = 0; i < a.length; i++) {
-        if (hasInferenceCandidates(a[i]) && hasInferenceCandidates(b[i])) {
-          return true;
-        }
-      }
-      return false;
-    }
-    function mergeInferences(target, source) {
-      for (let i = 0; i < target.length; i++) {
-        if (!hasInferenceCandidates(target[i]) && hasInferenceCandidates(source[i])) {
-          target[i] = source[i];
-        }
-      }
-    }
-    function getUniqueTypeParameters(context, typeParameters) {
-      const result = [];
-      let oldTypeParameters;
-      let newTypeParameters;
-      for (const tp of typeParameters) {
-        const name = tp.symbol.escapedName;
-        if (hasTypeParameterByName(context.inferredTypeParameters, name) || hasTypeParameterByName(result, name)) {
-          const newName = getUniqueTypeParameterName(concatenate(context.inferredTypeParameters, result), name);
-          const symbol = createSymbol(262144 /* TypeParameter */, newName);
-          const newTypeParameter = createTypeParameter(symbol);
-          newTypeParameter.target = tp;
-          oldTypeParameters = append(oldTypeParameters, tp);
-          newTypeParameters = append(newTypeParameters, newTypeParameter);
-          result.push(newTypeParameter);
-        } else {
-          result.push(tp);
-        }
-      }
-      if (newTypeParameters) {
-        const mapper = createTypeMapper(oldTypeParameters, newTypeParameters);
-        for (const tp of newTypeParameters) {
-          tp.mapper = mapper;
-        }
-      }
-      return result;
-    }
-    function hasTypeParameterByName(typeParameters, name) {
-      return some(typeParameters, (tp) => tp.symbol.escapedName === name);
-    }
-    function getUniqueTypeParameterName(typeParameters, baseName) {
-      let len = baseName.length;
-      while (len > 1 && baseName.charCodeAt(len - 1) >= 48 /* _0 */ && baseName.charCodeAt(len - 1) <= 57 /* _9 */)
-        len--;
-      const s = baseName.slice(0, len);
-      for (let index = 1; true; index++) {
-        const augmentedName = s + index;
-        if (!hasTypeParameterByName(typeParameters, augmentedName)) {
-          return augmentedName;
-        }
-      }
-    }
-    function getReturnTypeOfSingleNonGenericCallSignature(funcType) {
-      const signature = getSingleCallSignature(funcType);
-      if (signature && !signature.typeParameters) {
-        return getReturnTypeOfSignature(signature);
-      }
-    }
-    function getReturnTypeOfSingleNonGenericSignatureOfCallChain(expr) {
-      const funcType = checkExpression(expr.expression);
-      const nonOptionalType = getOptionalExpressionType(funcType, expr.expression);
-      const returnType = getReturnTypeOfSingleNonGenericCallSignature(funcType);
-      return returnType && propagateOptionalTypeMarker(returnType, expr, nonOptionalType !== funcType);
-    }
-    function getTypeOfExpression(node) {
-      const quickType = getQuickTypeOfExpression(node);
-      if (quickType) {
-        return quickType;
-      }
-      if (node.flags & 134217728 /* TypeCached */ && flowTypeCache) {
-        const cachedType = flowTypeCache[getNodeId(node)];
-        if (cachedType) {
-          return cachedType;
-        }
-      }
-      const startInvocationCount = flowInvocationCount;
-      const type = checkExpression(node);
-      if (flowInvocationCount !== startInvocationCount) {
-        const cache = flowTypeCache || (flowTypeCache = []);
-        cache[getNodeId(node)] = type;
-        setNodeFlags(node, node.flags | 134217728 /* TypeCached */);
-      }
-      return type;
-    }
-    function getQuickTypeOfExpression(node) {
-      let expr = skipParentheses(
-        node,
-        /*excludeJSDocTypeAssertions*/
-        true
-      );
-      if (isJSDocTypeAssertion(expr)) {
-        const type = getJSDocTypeAssertionType(expr);
-        if (!isConstTypeReference(type)) {
-          return getTypeFromTypeNode(type);
-        }
-      }
-      expr = skipParentheses(node);
-      if (isAwaitExpression(expr)) {
-        const type = getQuickTypeOfExpression(expr.expression);
-        return type ? getAwaitedType(type) : void 0;
-      }
-      if (isCallExpression(expr) && expr.expression.kind !== 108 /* SuperKeyword */ && !isRequireCall(
-        expr,
-        /*requireStringLiteralLikeArgument*/
-        true
-      ) && !isSymbolOrSymbolForCall(expr)) {
-        return isCallChain(expr) ? getReturnTypeOfSingleNonGenericSignatureOfCallChain(expr) : getReturnTypeOfSingleNonGenericCallSignature(checkNonNullExpression(expr.expression));
-      } else if (isAssertionExpression(expr) && !isConstTypeReference(expr.type)) {
-        return getTypeFromTypeNode(expr.type);
-      } else if (isLiteralExpression(node) || isBooleanLiteral(node)) {
-        return checkExpression(node);
-      }
-      return void 0;
-    }
-    function getContextFreeTypeOfExpression(node) {
-      const links = getNodeLinks(node);
-      if (links.contextFreeType) {
-        return links.contextFreeType;
-      }
-      pushContextualType(
-        node,
-        anyType,
-        /*isCache*/
-        false
-      );
-      const type = links.contextFreeType = checkExpression(node, 4 /* SkipContextSensitive */);
-      popContextualType();
-      return type;
-    }
-    function checkExpression(node, checkMode, forceTuple) {
-      var _a, _b;
-      (_a = tracing) == null ? void 0 : _a.push(tracing.Phase.Check, "checkExpression", { kind: node.kind, pos: node.pos, end: node.end, path: node.tracingPath });
-      const saveCurrentNode = currentNode;
-      currentNode = node;
-      instantiationCount = 0;
-      const uninstantiatedType = checkExpressionWorker(node, checkMode, forceTuple);
-      const type = instantiateTypeWithSingleGenericCallSignature(node, uninstantiatedType, checkMode);
-      if (isConstEnumObjectType(type)) {
-        checkConstEnumAccess(node, type);
-      }
-      currentNode = saveCurrentNode;
-      (_b = tracing) == null ? void 0 : _b.pop();
-      return type;
-    }
-    function checkConstEnumAccess(node, type) {
-      const ok = node.parent.kind === 210 /* PropertyAccessExpression */ && node.parent.expression === node || node.parent.kind === 211 /* ElementAccessExpression */ && node.parent.expression === node || ((node.kind === 80 /* Identifier */ || node.kind === 165 /* QualifiedName */) && isInRightSideOfImportOrExportAssignment(node) || node.parent.kind === 185 /* TypeQuery */ && node.parent.exprName === node) || node.parent.kind === 280 /* ExportSpecifier */;
-      if (!ok) {
-        error(node, Diagnostics.const_enums_can_only_be_used_in_property_or_index_access_expressions_or_the_right_hand_side_of_an_import_declaration_or_export_assignment_or_type_query);
-      }
-      if (getIsolatedModules(compilerOptions)) {
-        Debug.assert(!!(type.symbol.flags & 128 /* ConstEnum */));
-        const constEnumDeclaration = type.symbol.valueDeclaration;
-        if (constEnumDeclaration.flags & 16777216 /* Ambient */) {
-          error(node, Diagnostics.Cannot_access_ambient_const_enums_when_0_is_enabled, isolatedModulesLikeFlagName);
-        }
-      }
-    }
-    function checkParenthesizedExpression(node, checkMode) {
-      if (hasJSDocNodes(node)) {
-        if (isJSDocSatisfiesExpression(node)) {
-          return checkSatisfiesExpressionWorker(node.expression, getJSDocSatisfiesExpressionType(node), checkMode);
-        }
-        if (isJSDocTypeAssertion(node)) {
-          return checkAssertionWorker(node, checkMode);
-        }
-      }
-      return checkExpression(node.expression, checkMode);
-    }
-    function checkExpressionWorker(node, checkMode, forceTuple) {
-      const kind = node.kind;
-      if (cancellationToken) {
-        switch (kind) {
-          case 230 /* ClassExpression */:
-          case 217 /* FunctionExpression */:
-          case 218 /* ArrowFunction */:
-            cancellationToken.throwIfCancellationRequested();
-        }
-      }
-      switch (kind) {
-        case 80 /* Identifier */:
-          return checkIdentifier(node, checkMode);
-        case 81 /* PrivateIdentifier */:
-          return checkPrivateIdentifierExpression(node);
-        case 110 /* ThisKeyword */:
-          return checkThisExpression(node);
-        case 108 /* SuperKeyword */:
-          return checkSuperExpression(node);
-        case 106 /* NullKeyword */:
-          return nullWideningType;
-        case 15 /* NoSubstitutionTemplateLiteral */:
-        case 11 /* StringLiteral */:
-          return hasSkipDirectInferenceFlag(node) ? anyType : getFreshTypeOfLiteralType(getStringLiteralType(node.text));
-        case 9 /* NumericLiteral */:
-          checkGrammarNumericLiteral(node);
-          return getFreshTypeOfLiteralType(getNumberLiteralType(+node.text));
-        case 10 /* BigIntLiteral */:
-          checkGrammarBigIntLiteral(node);
-          return getFreshTypeOfLiteralType(getBigIntLiteralType({
-            negative: false,
-            base10Value: parsePseudoBigInt(node.text)
-          }));
-        case 112 /* TrueKeyword */:
-          return trueType;
-        case 97 /* FalseKeyword */:
-          return falseType;
-        case 227 /* TemplateExpression */:
-          return checkTemplateExpression(node);
-        case 14 /* RegularExpressionLiteral */:
-          return globalRegExpType;
-        case 208 /* ArrayLiteralExpression */:
-          return checkArrayLiteral(node, checkMode, forceTuple);
-        case 209 /* ObjectLiteralExpression */:
-          return checkObjectLiteral(node, checkMode);
-        case 210 /* PropertyAccessExpression */:
-          return checkPropertyAccessExpression(node, checkMode);
-        case 165 /* QualifiedName */:
-          return checkQualifiedName(node, checkMode);
-        case 211 /* ElementAccessExpression */:
-          return checkIndexedAccess(node, checkMode);
-        case 212 /* CallExpression */:
-          if (node.expression.kind === 102 /* ImportKeyword */) {
-            return checkImportCallExpression(node);
-          }
-        case 213 /* NewExpression */:
-          return checkCallExpression(node, checkMode);
-        case 214 /* TaggedTemplateExpression */:
-          return checkTaggedTemplateExpression(node);
-        case 216 /* ParenthesizedExpression */:
-          return checkParenthesizedExpression(node, checkMode);
-        case 230 /* ClassExpression */:
-          return checkClassExpression(node);
-        case 217 /* FunctionExpression */:
-        case 218 /* ArrowFunction */:
-          return checkFunctionExpressionOrObjectLiteralMethod(node, checkMode);
-        case 220 /* TypeOfExpression */:
-          return checkTypeOfExpression(node);
-        case 215 /* TypeAssertionExpression */:
-        case 233 /* AsExpression */:
-          return checkAssertion(node, checkMode);
-        case 234 /* NonNullExpression */:
-          return checkNonNullAssertion(node);
-        case 232 /* ExpressionWithTypeArguments */:
-          return checkExpressionWithTypeArguments(node);
-        case 237 /* SatisfiesExpression */:
-          return checkSatisfiesExpression(node);
-        case 235 /* MetaProperty */:
-          return checkMetaProperty(node);
-        case 219 /* DeleteExpression */:
-          return checkDeleteExpression(node);
-        case 221 /* VoidExpression */:
-          return checkVoidExpression(node);
-        case 222 /* AwaitExpression */:
-          return checkAwaitExpression(node);
-        case 223 /* PrefixUnaryExpression */:
-          return checkPrefixUnaryExpression(node);
-        case 224 /* PostfixUnaryExpression */:
-          return checkPostfixUnaryExpression(node);
-        case 225 /* BinaryExpression */:
-          return checkBinaryExpression(node, checkMode);
-        case 226 /* ConditionalExpression */:
-          return checkConditionalExpression(node, checkMode);
-        case 229 /* SpreadElement */:
-          return checkSpreadExpression(node, checkMode);
-        case 231 /* OmittedExpression */:
-          return undefinedWideningType;
-        case 228 /* YieldExpression */:
-          return checkYieldExpression(node);
-        case 236 /* SyntheticExpression */:
-          return checkSyntheticExpression(node);
-        case 293 /* JsxExpression */:
-          return checkJsxExpression(node, checkMode);
-        case 283 /* JsxElement */:
-          return checkJsxElement(node, checkMode);
-        case 284 /* JsxSelfClosingElement */:
-          return checkJsxSelfClosingElement(node, checkMode);
-        case 287 /* JsxFragment */:
-          return checkJsxFragment(node);
-        case 291 /* JsxAttributes */:
-          return checkJsxAttributes(node, checkMode);
-        case 285 /* JsxOpeningElement */:
-          Debug.fail("Shouldn't ever directly check a JsxOpeningElement");
-      }
-      return errorType;
-    }
-    function checkTypeParameter(node) {
-      checkGrammarModifiers(node);
-      if (node.expression) {
-        grammarErrorOnFirstToken(node.expression, Diagnostics.Type_expected);
-      }
-      checkSourceElement(node.constraint);
-      checkSourceElement(node.default);
-      const typeParameter = getDeclaredTypeOfTypeParameter(getSymbolOfDeclaration(node));
-      getBaseConstraintOfType(typeParameter);
-      if (!hasNonCircularTypeParameterDefault(typeParameter)) {
-        error(node.default, Diagnostics.Type_parameter_0_has_a_circular_default, typeToString(typeParameter));
-      }
-      const constraintType = getConstraintOfTypeParameter(typeParameter);
-      const defaultType = getDefaultFromTypeParameter(typeParameter);
-      if (constraintType && defaultType) {
-        checkTypeAssignableTo(defaultType, getTypeWithThisArgument(instantiateType(constraintType, makeUnaryTypeMapper(typeParameter, defaultType)), defaultType), node.default, Diagnostics.Type_0_does_not_satisfy_the_constraint_1);
-      }
-      checkNodeDeferred(node);
-      addLazyDiagnostic(() => checkTypeNameIsReserved(node.name, Diagnostics.Type_parameter_name_cannot_be_0));
-    }
-    function checkTypeParameterDeferred(node) {
-      var _a, _b;
-      if (isInterfaceDeclaration(node.parent) || isClassLike(node.parent) || isTypeAliasDeclaration(node.parent)) {
-        const typeParameter = getDeclaredTypeOfTypeParameter(getSymbolOfDeclaration(node));
-        const modifiers = getTypeParameterModifiers(typeParameter) & (32768 /* In */ | 65536 /* Out */);
-        if (modifiers) {
-          const symbol = getSymbolOfDeclaration(node.parent);
-          if (isTypeAliasDeclaration(node.parent) && !(getObjectFlags(getDeclaredTypeOfSymbol(symbol)) & (16 /* Anonymous */ | 32 /* Mapped */))) {
-            error(node, Diagnostics.Variance_annotations_are_only_supported_in_type_aliases_for_object_function_constructor_and_mapped_types);
-          } else if (modifiers === 32768 /* In */ || modifiers === 65536 /* Out */) {
-            (_a = tracing) == null ? void 0 : _a.push(tracing.Phase.CheckTypes, "checkTypeParameterDeferred", { parent: getTypeId(getDeclaredTypeOfSymbol(symbol)), id: getTypeId(typeParameter) });
-            const source = createMarkerType(symbol, typeParameter, modifiers === 65536 /* Out */ ? markerSubTypeForCheck : markerSuperTypeForCheck);
-            const target = createMarkerType(symbol, typeParameter, modifiers === 65536 /* Out */ ? markerSuperTypeForCheck : markerSubTypeForCheck);
-            const saveVarianceTypeParameter = typeParameter;
-            varianceTypeParameter = typeParameter;
-            checkTypeAssignableTo(source, target, node, Diagnostics.Type_0_is_not_assignable_to_type_1_as_implied_by_variance_annotation);
-            varianceTypeParameter = saveVarianceTypeParameter;
-            (_b = tracing) == null ? void 0 : _b.pop();
-          }
-        }
-      }
-    }
-    function checkParameter(node) {
-      checkGrammarModifiers(node);
-      checkVariableLikeDeclaration(node);
-      const func = getContainingFunction(node);
-      if (hasSyntacticModifier(node, 16476 /* ParameterPropertyModifier */)) {
-        if (!(func.kind === 175 /* Constructor */ && nodeIsPresent(func.body))) {
-          error(node, Diagnostics.A_parameter_property_is_only_allowed_in_a_constructor_implementation);
-        }
-        if (func.kind === 175 /* Constructor */ && isIdentifier(node.name) && node.name.escapedText === "constructor") {
-          error(node.name, Diagnostics.constructor_cannot_be_used_as_a_parameter_property_name);
-        }
-      }
-      if (!node.initializer && isOptionalDeclaration(node) && isBindingPattern(node.name) && func.body) {
-        error(node, Diagnostics.A_binding_pattern_parameter_cannot_be_optional_in_an_implementation_signature);
-      }
-      if (node.name && isIdentifier(node.name) && (node.name.escapedText === "this" || node.name.escapedText === "new")) {
-        if (func.parameters.indexOf(node) !== 0) {
-          error(node, Diagnostics.A_0_parameter_must_be_the_first_parameter, node.name.escapedText);
-        }
-        if (func.kind === 175 /* Constructor */ || func.kind === 179 /* ConstructSignature */ || func.kind === 184 /* ConstructorType */) {
-          error(node, Diagnostics.A_constructor_cannot_have_a_this_parameter);
-        }
-        if (func.kind === 218 /* ArrowFunction */) {
-          error(node, Diagnostics.An_arrow_function_cannot_have_a_this_parameter);
-        }
-        if (func.kind === 176 /* GetAccessor */ || func.kind === 177 /* SetAccessor */) {
-          error(node, Diagnostics.get_and_set_accessors_cannot_declare_this_parameters);
-        }
-      }
-      if (node.dotDotDotToken && !isBindingPattern(node.name) && !isTypeAssignableTo(getReducedType(getTypeOfSymbol(node.symbol)), anyReadonlyArrayType)) {
-        error(node, Diagnostics.A_rest_parameter_must_be_of_an_array_type);
-      }
-    }
-    function checkTypePredicate(node) {
-      const parent2 = getTypePredicateParent(node);
-      if (!parent2) {
-        error(node, Diagnostics.A_type_predicate_is_only_allowed_in_return_type_position_for_functions_and_methods);
-        return;
-      }
-      const signature = getSignatureFromDeclaration(parent2);
-      const typePredicate = getTypePredicateOfSignature(signature);
-      if (!typePredicate) {
-        return;
-      }
-      checkSourceElement(node.type);
-      const { parameterName } = node;
-      if (typePredicate.kind === 0 /* This */ || typePredicate.kind === 2 /* AssertsThis */) {
-        getTypeFromThisTypeNode(parameterName);
-      } else {
-        if (typePredicate.parameterIndex >= 0) {
-          if (signatureHasRestParameter(signature) && typePredicate.parameterIndex === signature.parameters.length - 1) {
-            error(parameterName, Diagnostics.A_type_predicate_cannot_reference_a_rest_parameter);
-          } else {
-            if (typePredicate.type) {
-              const leadingError = () => chainDiagnosticMessages(
-                /*details*/
-                void 0,
-                Diagnostics.A_type_predicate_s_type_must_be_assignable_to_its_parameter_s_type
-              );
-              checkTypeAssignableTo(
-                typePredicate.type,
-                getTypeOfSymbol(signature.parameters[typePredicate.parameterIndex]),
-                node.type,
-                /*headMessage*/
-                void 0,
-                leadingError
-              );
-            }
-          }
-        } else if (parameterName) {
-          let hasReportedError = false;
-          for (const { name } of parent2.parameters) {
-            if (isBindingPattern(name) && checkIfTypePredicateVariableIsDeclaredInBindingPattern(name, parameterName, typePredicate.parameterName)) {
-              hasReportedError = true;
-              break;
-            }
-          }
-          if (!hasReportedError) {
-            error(node.parameterName, Diagnostics.Cannot_find_parameter_0, typePredicate.parameterName);
-          }
-        }
-      }
-    }
-    function getTypePredicateParent(node) {
-      switch (node.parent.kind) {
-        case 218 /* ArrowFunction */:
-        case 178 /* CallSignature */:
-        case 261 /* FunctionDeclaration */:
-        case 217 /* FunctionExpression */:
-        case 183 /* FunctionType */:
-        case 173 /* MethodDeclaration */:
-        case 172 /* MethodSignature */:
-          const parent2 = node.parent;
-          if (node === parent2.type) {
-            return parent2;
-          }
-      }
-    }
-    function checkIfTypePredicateVariableIsDeclaredInBindingPattern(pattern, predicateVariableNode, predicateVariableName) {
-      for (const element of pattern.elements) {
-        if (isOmittedExpression(element)) {
-          continue;
-        }
-        const name = element.name;
-        if (name.kind === 80 /* Identifier */ && name.escapedText === predicateVariableName) {
-          error(
-            predicateVariableNode,
-            Diagnostics.A_type_predicate_cannot_reference_element_0_in_a_binding_pattern,
-            predicateVariableName
-          );
-          return true;
-        } else if (name.kind === 206 /* ArrayBindingPattern */ || name.kind === 205 /* ObjectBindingPattern */) {
-          if (checkIfTypePredicateVariableIsDeclaredInBindingPattern(
-            name,
-            predicateVariableNode,
-            predicateVariableName
-          )) {
-            return true;
-          }
-        }
-      }
-    }
-    function checkSignatureDeclaration(node) {
-      if (node.kind === 180 /* IndexSignature */) {
-        checkGrammarIndexSignature(node);
-      } else if (node.kind === 183 /* FunctionType */ || node.kind === 261 /* FunctionDeclaration */ || node.kind === 184 /* ConstructorType */ || node.kind === 178 /* CallSignature */ || node.kind === 175 /* Constructor */ || node.kind === 179 /* ConstructSignature */) {
-        checkGrammarFunctionLikeDeclaration(node);
-      }
-      const functionFlags = getFunctionFlags(node);
-      if (!(functionFlags & 4 /* Invalid */)) {
-        if ((functionFlags & 3 /* AsyncGenerator */) === 3 /* AsyncGenerator */ && languageVersion < 99 /* ESNext */) {
-          checkExternalEmitHelpers(node, 6144 /* AsyncGeneratorIncludes */);
-        }
-        if ((functionFlags & 3 /* AsyncGenerator */) === 2 /* Async */ && languageVersion < 4 /* ES2017 */) {
-          checkExternalEmitHelpers(node, 64 /* Awaiter */);
-        }
-        if ((functionFlags & 3 /* AsyncGenerator */) !== 0 /* Normal */ && languageVersion < 2 /* ES2015 */) {
-          checkExternalEmitHelpers(node, 128 /* Generator */);
-        }
-      }
-      checkTypeParameters(getEffectiveTypeParameterDeclarations(node));
-      checkUnmatchedJSDocParameters(node);
-      forEach(node.parameters, checkParameter);
-      if (node.type) {
-        checkSourceElement(node.type);
-      }
-      addLazyDiagnostic(checkSignatureDeclarationDiagnostics);
-      function checkSignatureDeclarationDiagnostics() {
-        checkCollisionWithArgumentsInGeneratedCode(node);
-        const returnTypeNode = getEffectiveReturnTypeNode(node);
-        if (noImplicitAny && !returnTypeNode) {
-          switch (node.kind) {
-            case 179 /* ConstructSignature */:
-              error(node, Diagnostics.Construct_signature_which_lacks_return_type_annotation_implicitly_has_an_any_return_type);
-              break;
-            case 178 /* CallSignature */:
-              error(node, Diagnostics.Call_signature_which_lacks_return_type_annotation_implicitly_has_an_any_return_type);
-              break;
-          }
-        }
-        if (returnTypeNode) {
-          const functionFlags2 = getFunctionFlags(node);
-          if ((functionFlags2 & (4 /* Invalid */ | 1 /* Generator */)) === 1 /* Generator */) {
-            const returnType = getTypeFromTypeNode(returnTypeNode);
-            if (returnType === voidType) {
-              error(returnTypeNode, Diagnostics.A_generator_cannot_have_a_void_type_annotation);
-            } else {
-              const generatorYieldType = getIterationTypeOfGeneratorFunctionReturnType(0 /* Yield */, returnType, (functionFlags2 & 2 /* Async */) !== 0) || anyType;
-              const generatorReturnType = getIterationTypeOfGeneratorFunctionReturnType(1 /* Return */, returnType, (functionFlags2 & 2 /* Async */) !== 0) || generatorYieldType;
-              const generatorNextType = getIterationTypeOfGeneratorFunctionReturnType(2 /* Next */, returnType, (functionFlags2 & 2 /* Async */) !== 0) || unknownType;
-              const generatorInstantiation = createGeneratorReturnType(generatorYieldType, generatorReturnType, generatorNextType, !!(functionFlags2 & 2 /* Async */));
-              checkTypeAssignableTo(generatorInstantiation, returnType, returnTypeNode);
-            }
-          } else if ((functionFlags2 & 3 /* AsyncGenerator */) === 2 /* Async */) {
-            checkAsyncFunctionReturnType(node, returnTypeNode);
-          }
-        }
-        if (node.kind !== 180 /* IndexSignature */ && node.kind !== 323 /* JSDocFunctionType */) {
-          registerForUnusedIdentifiersCheck(node);
-        }
-      }
-    }
-    function checkClassForDuplicateDeclarations(node) {
-      const instanceNames = /* @__PURE__ */ new Map();
-      const staticNames = /* @__PURE__ */ new Map();
-      const privateIdentifiers = /* @__PURE__ */ new Map();
-      for (const member of node.members) {
-        if (member.kind === 175 /* Constructor */) {
-          for (const param of member.parameters) {
-            if (isParameterPropertyDeclaration(param, member) && !isBindingPattern(param.name)) {
-              addName(instanceNames, param.name, param.name.escapedText, 3 /* GetOrSetAccessor */);
-            }
-          }
-        } else {
-          const isStaticMember = isStatic(member);
-          const name = member.name;
-          if (!name) {
-            continue;
-          }
-          const isPrivate = isPrivateIdentifier(name);
-          const privateStaticFlags = isPrivate && isStaticMember ? 16 /* PrivateStatic */ : 0;
-          const names = isPrivate ? privateIdentifiers : isStaticMember ? staticNames : instanceNames;
-          const memberName = name && getPropertyNameForPropertyNameNode(name);
-          if (memberName) {
-            switch (member.kind) {
-              case 176 /* GetAccessor */:
-                addName(names, name, memberName, 1 /* GetAccessor */ | privateStaticFlags);
-                break;
-              case 177 /* SetAccessor */:
-                addName(names, name, memberName, 2 /* SetAccessor */ | privateStaticFlags);
-                break;
-              case 171 /* PropertyDeclaration */:
-                addName(names, name, memberName, 3 /* GetOrSetAccessor */ | privateStaticFlags);
-                break;
-              case 173 /* MethodDeclaration */:
-                addName(names, name, memberName, 8 /* Method */ | privateStaticFlags);
-                break;
-            }
-          }
-        }
-      }
-      function addName(names, location, name, meaning) {
-        const prev = names.get(name);
-        if (prev) {
-          if ((prev & 16 /* PrivateStatic */) !== (meaning & 16 /* PrivateStatic */)) {
-            error(location, Diagnostics.Duplicate_identifier_0_Static_and_instance_elements_cannot_share_the_same_private_name, getTextOfNode(location));
-          } else {
-            const prevIsMethod = !!(prev & 8 /* Method */);
-            const isMethod = !!(meaning & 8 /* Method */);
-            if (prevIsMethod || isMethod) {
-              if (prevIsMethod !== isMethod) {
-                error(location, Diagnostics.Duplicate_identifier_0, getTextOfNode(location));
-              }
-            } else if (prev & meaning & ~16 /* PrivateStatic */) {
-              error(location, Diagnostics.Duplicate_identifier_0, getTextOfNode(location));
-            } else {
-              names.set(name, prev | meaning);
-            }
-          }
-        } else {
-          names.set(name, meaning);
-        }
-      }
-    }
-    function checkClassForStaticPropertyNameConflicts(node) {
-      for (const member of node.members) {
-        const memberNameNode = member.name;
-        const isStaticMember = isStatic(member);
-        if (isStaticMember && memberNameNode) {
-          const memberName = getPropertyNameForPropertyNameNode(memberNameNode);
-          switch (memberName) {
-            case "name":
-            case "length":
-            case "caller":
-            case "arguments":
-            case "prototype":
-              const message = Diagnostics.Static_property_0_conflicts_with_built_in_property_Function_0_of_constructor_function_1;
-              const className = getNameOfSymbolAsWritten(getSymbolOfDeclaration(node));
-              error(memberNameNode, message, memberName, className);
-              break;
-          }
-        }
-      }
-    }
-    function checkObjectTypeForDuplicateDeclarations(node) {
-      const names = /* @__PURE__ */ new Map();
-      for (const member of node.members) {
-        if (member.kind === 170 /* PropertySignature */) {
-          let memberName;
-          const name = member.name;
-          switch (name.kind) {
-            case 11 /* StringLiteral */:
-            case 9 /* NumericLiteral */:
-              memberName = name.text;
-              break;
-            case 80 /* Identifier */:
-              memberName = idText(name);
-              break;
-            default:
-              continue;
-          }
-          if (names.get(memberName)) {
-            error(getNameOfDeclaration(member.symbol.valueDeclaration), Diagnostics.Duplicate_identifier_0, memberName);
-            error(member.name, Diagnostics.Duplicate_identifier_0, memberName);
-          } else {
-            names.set(memberName, true);
-          }
-        }
-      }
-    }
-    function checkTypeForDuplicateIndexSignatures(node) {
-      if (node.kind === 263 /* InterfaceDeclaration */) {
-        const nodeSymbol = getSymbolOfDeclaration(node);
-        if (nodeSymbol.declarations && nodeSymbol.declarations.length > 0 && nodeSymbol.declarations[0] !== node) {
-          return;
-        }
-      }
-      const indexSymbol = getIndexSymbol(getSymbolOfDeclaration(node));
-      if (indexSymbol == null ? void 0 : indexSymbol.declarations) {
-        const indexSignatureMap = /* @__PURE__ */ new Map();
-        for (const declaration of indexSymbol.declarations) {
-          if (declaration.parameters.length === 1 && declaration.parameters[0].type) {
-            forEachType(getTypeFromTypeNode(declaration.parameters[0].type), (type) => {
-              const entry = indexSignatureMap.get(getTypeId(type));
-              if (entry) {
-                entry.declarations.push(declaration);
-              } else {
-                indexSignatureMap.set(getTypeId(type), { type, declarations: [declaration] });
-              }
-            });
-          }
-        }
-        indexSignatureMap.forEach((entry) => {
-          if (entry.declarations.length > 1) {
-            for (const declaration of entry.declarations) {
-              error(declaration, Diagnostics.Duplicate_index_signature_for_type_0, typeToString(entry.type));
-            }
-          }
-        });
-      }
-    }
-    function checkPropertyDeclaration(node) {
-      if (!checkGrammarModifiers(node) && !checkGrammarProperty(node))
-        checkGrammarComputedPropertyName(node.name);
-      checkVariableLikeDeclaration(node);
-      setNodeLinksForPrivateIdentifierScope(node);
-      if (hasSyntacticModifier(node, 256 /* Abstract */) && node.kind === 171 /* PropertyDeclaration */ && node.initializer) {
-        error(node, Diagnostics.Property_0_cannot_have_an_initializer_because_it_is_marked_abstract, declarationNameToString(node.name));
-      }
-    }
-    function checkPropertySignature(node) {
-      if (isPrivateIdentifier(node.name)) {
-        error(node, Diagnostics.Private_identifiers_are_not_allowed_outside_class_bodies);
-      }
-      return checkPropertyDeclaration(node);
-    }
-    function checkMethodDeclaration(node) {
-      if (!checkGrammarMethod(node))
-        checkGrammarComputedPropertyName(node.name);
-      if (isMethodDeclaration(node) && node.asteriskToken && isIdentifier(node.name) && idText(node.name) === "constructor") {
-        error(node.name, Diagnostics.Class_constructor_may_not_be_a_generator);
-      }
-      checkFunctionOrMethodDeclaration(node);
-      if (hasSyntacticModifier(node, 256 /* Abstract */) && node.kind === 173 /* MethodDeclaration */ && node.body) {
-        error(node, Diagnostics.Method_0_cannot_have_an_implementation_because_it_is_marked_abstract, declarationNameToString(node.name));
-      }
-      if (isPrivateIdentifier(node.name) && !getContainingClass(node)) {
-        error(node, Diagnostics.Private_identifiers_are_not_allowed_outside_class_bodies);
-      }
-      setNodeLinksForPrivateIdentifierScope(node);
-    }
-    function setNodeLinksForPrivateIdentifierScope(node) {
-      if (isPrivateIdentifier(node.name) && languageVersion < 99 /* ESNext */) {
-        for (let lexicalScope = getEnclosingBlockScopeContainer(node); !!lexicalScope; lexicalScope = getEnclosingBlockScopeContainer(lexicalScope)) {
-          getNodeLinks(lexicalScope).flags |= 4194304 /* ContainsClassWithPrivateIdentifiers */;
-        }
-        if (isClassExpression(node.parent)) {
-          const enclosingIterationStatement = getEnclosingIterationStatement(node.parent);
-          if (enclosingIterationStatement) {
-            getNodeLinks(node.name).flags |= 32768 /* BlockScopedBindingInLoop */;
-            getNodeLinks(enclosingIterationStatement).flags |= 4096 /* LoopWithCapturedBlockScopedBinding */;
-          }
-        }
-      }
-    }
-    function checkClassStaticBlockDeclaration(node) {
-      checkGrammarModifiers(node);
-      forEachChild(node, checkSourceElement);
-    }
-    function checkConstructorDeclaration(node) {
-      checkSignatureDeclaration(node);
-      if (!checkGrammarConstructorTypeParameters(node))
-        checkGrammarConstructorTypeAnnotation(node);
-      checkSourceElement(node.body);
-      const symbol = getSymbolOfDeclaration(node);
-      const firstDeclaration = getDeclarationOfKind(symbol, node.kind);
-      if (node === firstDeclaration) {
-        checkFunctionOrConstructorSymbol(symbol);
-      }
-      if (nodeIsMissing(node.body)) {
-        return;
-      }
-      addLazyDiagnostic(checkConstructorDeclarationDiagnostics);
-      return;
-      function isInstancePropertyWithInitializerOrPrivateIdentifierProperty(n) {
-        if (isPrivateIdentifierClassElementDeclaration(n)) {
-          return true;
-        }
-        return n.kind === 171 /* PropertyDeclaration */ && !isStatic(n) && !!n.initializer;
-      }
-      function checkConstructorDeclarationDiagnostics() {
-        const containingClassDecl = node.parent;
-        if (getClassExtendsHeritageElement(containingClassDecl)) {
-          captureLexicalThis(node.parent, containingClassDecl);
-          const classExtendsNull = classDeclarationExtendsNull(containingClassDecl);
-          const superCall = findFirstSuperCall(node.body);
-          if (superCall) {
-            if (classExtendsNull) {
-              error(superCall, Diagnostics.A_constructor_cannot_contain_a_super_call_when_its_class_extends_null);
-            }
-            const superCallShouldBeRootLevel = (getEmitScriptTarget(compilerOptions) !== 99 /* ESNext */ || !useDefineForClassFields) && (some(node.parent.members, isInstancePropertyWithInitializerOrPrivateIdentifierProperty) || some(node.parameters, (p) => hasSyntacticModifier(p, 16476 /* ParameterPropertyModifier */)));
-            if (superCallShouldBeRootLevel) {
-              if (!superCallIsRootLevelInConstructor(superCall, node.body)) {
-                error(superCall, Diagnostics.A_super_call_must_be_a_root_level_statement_within_a_constructor_of_a_derived_class_that_contains_initialized_properties_parameter_properties_or_private_identifiers);
-              } else {
-                let superCallStatement;
-                for (const statement of node.body.statements) {
-                  if (isExpressionStatement(statement) && isSuperCall(skipOuterExpressions(statement.expression))) {
-                    superCallStatement = statement;
-                    break;
-                  }
-                  if (nodeImmediatelyReferencesSuperOrThis(statement)) {
-                    break;
-                  }
-                }
-                if (superCallStatement === void 0) {
-                  error(node, Diagnostics.A_super_call_must_be_the_first_statement_in_the_constructor_to_refer_to_super_or_this_when_a_derived_class_contains_initialized_properties_parameter_properties_or_private_identifiers);
-                }
-              }
-            }
-          } else if (!classExtendsNull) {
-            error(node, Diagnostics.Constructors_for_derived_classes_must_contain_a_super_call);
-          }
-        }
-      }
-    }
-    function superCallIsRootLevelInConstructor(superCall, body) {
-      const superCallParent = walkUpParenthesizedExpressions(superCall.parent);
-      return isExpressionStatement(superCallParent) && superCallParent.parent === body;
-    }
-    function nodeImmediatelyReferencesSuperOrThis(node) {
-      if (node.kind === 108 /* SuperKeyword */ || node.kind === 110 /* ThisKeyword */) {
-        return true;
-      }
-      if (isThisContainerOrFunctionBlock(node)) {
-        return false;
-      }
-      return !!forEachChild(node, nodeImmediatelyReferencesSuperOrThis);
-    }
-    function checkAccessorDeclaration(node) {
-      if (isIdentifier(node.name) && idText(node.name) === "constructor" && isClassLike(node.parent)) {
-        error(node.name, Diagnostics.Class_constructor_may_not_be_an_accessor);
-      }
-      addLazyDiagnostic(checkAccessorDeclarationDiagnostics);
-      checkSourceElement(node.body);
-      setNodeLinksForPrivateIdentifierScope(node);
-      function checkAccessorDeclarationDiagnostics() {
-        if (!checkGrammarFunctionLikeDeclaration(node) && !checkGrammarAccessor(node))
-          checkGrammarComputedPropertyName(node.name);
-        checkDecorators(node);
-        checkSignatureDeclaration(node);
-        if (node.kind === 176 /* GetAccessor */) {
-          if (!(node.flags & 16777216 /* Ambient */) && nodeIsPresent(node.body) && node.flags & 256 /* HasImplicitReturn */) {
-            if (!(node.flags & 512 /* HasExplicitReturn */)) {
-              error(node.name, Diagnostics.A_get_accessor_must_return_a_value);
-            }
-          }
-        }
-        if (node.name.kind === 166 /* ComputedPropertyName */) {
-          checkComputedPropertyName(node.name);
-        }
-        if (hasBindableName(node)) {
-          const symbol = getSymbolOfDeclaration(node);
-          const getter = getDeclarationOfKind(symbol, 176 /* GetAccessor */);
-          const setter = getDeclarationOfKind(symbol, 177 /* SetAccessor */);
-          if (getter && setter && !(getNodeCheckFlags(getter) & 1 /* TypeChecked */)) {
-            getNodeLinks(getter).flags |= 1 /* TypeChecked */;
-            const getterFlags = getEffectiveModifierFlags(getter);
-            const setterFlags = getEffectiveModifierFlags(setter);
-            if ((getterFlags & 256 /* Abstract */) !== (setterFlags & 256 /* Abstract */)) {
-              error(getter.name, Diagnostics.Accessors_must_both_be_abstract_or_non_abstract);
-              error(setter.name, Diagnostics.Accessors_must_both_be_abstract_or_non_abstract);
-            }
-            if (getterFlags & 16 /* Protected */ && !(setterFlags & (16 /* Protected */ | 8 /* Private */)) || getterFlags & 8 /* Private */ && !(setterFlags & 8 /* Private */)) {
-              error(getter.name, Diagnostics.A_get_accessor_must_be_at_least_as_accessible_as_the_setter);
-              error(setter.name, Diagnostics.A_get_accessor_must_be_at_least_as_accessible_as_the_setter);
-            }
-          }
-        }
-        const returnType = getTypeOfAccessors(getSymbolOfDeclaration(node));
-        if (node.kind === 176 /* GetAccessor */) {
-          checkAllCodePathsInNonVoidFunctionReturnOrThrow(node, returnType);
-        }
-      }
-    }
-    function checkMissingDeclaration(node) {
-      checkDecorators(node);
-    }
-    function getEffectiveTypeArgumentAtIndex(node, typeParameters, index) {
-      if (node.typeArguments && index < node.typeArguments.length) {
-        return getTypeFromTypeNode(node.typeArguments[index]);
-      }
-      return getEffectiveTypeArguments2(node, typeParameters)[index];
-    }
-    function getEffectiveTypeArguments2(node, typeParameters) {
-      return fillMissingTypeArguments(
-        map(node.typeArguments, getTypeFromTypeNode),
-        typeParameters,
-        getMinTypeArgumentCount(typeParameters),
-        isInJSFile(node)
-      );
-    }
-    function checkTypeArgumentConstraints(node, typeParameters) {
-      let typeArguments;
-      let mapper;
-      let result = true;
-      for (let i = 0; i < typeParameters.length; i++) {
-        const constraint = getConstraintOfTypeParameter(typeParameters[i]);
-        if (constraint) {
-          if (!typeArguments) {
-            typeArguments = getEffectiveTypeArguments2(node, typeParameters);
-            mapper = createTypeMapper(typeParameters, typeArguments);
-          }
-          result = result && checkTypeAssignableTo(
-            typeArguments[i],
-            instantiateType(constraint, mapper),
-            node.typeArguments[i],
-            Diagnostics.Type_0_does_not_satisfy_the_constraint_1
-          );
-        }
-      }
-      return result;
-    }
-    function getTypeParametersForTypeAndSymbol(type, symbol) {
-      if (!isErrorType(type)) {
-        return symbol.flags & 524288 /* TypeAlias */ && getSymbolLinks(symbol).typeParameters || (getObjectFlags(type) & 4 /* Reference */ ? type.target.localTypeParameters : void 0);
-      }
-      return void 0;
-    }
-    function getTypeParametersForTypeReferenceOrImport(node) {
-      const type = getTypeFromTypeNode(node);
-      if (!isErrorType(type)) {
-        const symbol = getNodeLinks(node).resolvedSymbol;
-        if (symbol) {
-          return getTypeParametersForTypeAndSymbol(type, symbol);
-        }
-      }
-      return void 0;
-    }
-    function checkTypeReferenceNode(node) {
-      checkGrammarTypeArguments(node, node.typeArguments);
-      if (node.kind === 182 /* TypeReference */ && !isInJSFile(node) && !isInJSDoc(node) && node.typeArguments && node.typeName.end !== node.typeArguments.pos) {
-        const sourceFile = getSourceFileOfNode(node);
-        if (scanTokenAtPosition(sourceFile, node.typeName.end) === 25 /* DotToken */) {
-          grammarErrorAtPos(node, skipTrivia(sourceFile.text, node.typeName.end), 1, Diagnostics.JSDoc_types_can_only_be_used_inside_documentation_comments);
-        }
-      }
-      forEach(node.typeArguments, checkSourceElement);
-      checkTypeReferenceOrImport(node);
-    }
-    function checkTypeReferenceOrImport(node) {
-      const type = getTypeFromTypeNode(node);
-      if (!isErrorType(type)) {
-        if (node.typeArguments) {
-          addLazyDiagnostic(() => {
-            const typeParameters = getTypeParametersForTypeReferenceOrImport(node);
-            if (typeParameters) {
-              checkTypeArgumentConstraints(node, typeParameters);
-            }
-          });
-        }
-        const symbol = getNodeLinks(node).resolvedSymbol;
-        if (symbol) {
-          if (some(symbol.declarations, (d) => isTypeDeclaration(d) && !!(d.flags & 268435456 /* Deprecated */))) {
-            addDeprecatedSuggestion(
-              getDeprecatedSuggestionNode(node),
-              symbol.declarations,
-              symbol.escapedName
-            );
-          }
-        }
-      }
-    }
-    function getTypeArgumentConstraint(node) {
-      const typeReferenceNode = tryCast(node.parent, isTypeReferenceType);
-      if (!typeReferenceNode)
-        return void 0;
-      const typeParameters = getTypeParametersForTypeReferenceOrImport(typeReferenceNode);
-      if (!typeParameters)
-        return void 0;
-      const constraint = getConstraintOfTypeParameter(typeParameters[typeReferenceNode.typeArguments.indexOf(node)]);
-      return constraint && instantiateType(constraint, createTypeMapper(typeParameters, getEffectiveTypeArguments2(typeReferenceNode, typeParameters)));
-    }
-    function checkTypeQuery(node) {
-      getTypeFromTypeQueryNode(node);
-    }
-    function checkTypeLiteral(node) {
-      forEach(node.members, checkSourceElement);
-      addLazyDiagnostic(checkTypeLiteralDiagnostics);
-      function checkTypeLiteralDiagnostics() {
-        const type = getTypeFromTypeLiteralOrFunctionOrConstructorTypeNode(node);
-        checkIndexConstraints(type, type.symbol);
-        checkTypeForDuplicateIndexSignatures(node);
-        checkObjectTypeForDuplicateDeclarations(node);
-      }
-    }
-    function checkArrayType(node) {
-      checkSourceElement(node.elementType);
-    }
-    function checkTupleType(node) {
-      const elementTypes = node.elements;
-      let seenOptionalElement = false;
-      let seenRestElement = false;
-      const hasNamedElement = some(elementTypes, isNamedTupleMember);
-      for (const e of elementTypes) {
-        if (e.kind !== 201 /* NamedTupleMember */ && hasNamedElement) {
-          grammarErrorOnNode(e, Diagnostics.Tuple_members_must_all_have_names_or_all_not_have_names);
-          break;
-        }
-        const flags = getTupleElementFlags(e);
-        if (flags & 8 /* Variadic */) {
-          const type = getTypeFromTypeNode(e.type);
-          if (!isArrayLikeType(type)) {
-            error(e, Diagnostics.A_rest_element_type_must_be_an_array_type);
-            break;
-          }
-          if (isArrayType(type) || isTupleType(type) && type.target.combinedFlags & 4 /* Rest */) {
-            seenRestElement = true;
-          }
-        } else if (flags & 4 /* Rest */) {
-          if (seenRestElement) {
-            grammarErrorOnNode(e, Diagnostics.A_rest_element_cannot_follow_another_rest_element);
-            break;
-          }
-          seenRestElement = true;
-        } else if (flags & 2 /* Optional */) {
-          if (seenRestElement) {
-            grammarErrorOnNode(e, Diagnostics.An_optional_element_cannot_follow_a_rest_element);
-            break;
-          }
-          seenOptionalElement = true;
-        } else if (seenOptionalElement) {
-          grammarErrorOnNode(e, Diagnostics.A_required_element_cannot_follow_an_optional_element);
-          break;
-        }
-      }
-      forEach(node.elements, checkSourceElement);
-      getTypeFromTypeNode(node);
-    }
-    function checkUnionOrIntersectionType(node) {
-      forEach(node.types, checkSourceElement);
-      getTypeFromTypeNode(node);
-    }
-    function checkIndexedAccessIndexType(type, accessNode) {
-      if (!(type.flags & 8388608 /* IndexedAccess */)) {
-        return type;
-      }
-      const objectType = type.objectType;
-      const indexType = type.indexType;
-      if (isTypeAssignableTo(indexType, getIndexType(objectType, 0 /* None */))) {
-        if (accessNode.kind === 211 /* ElementAccessExpression */ && isAssignmentTarget(accessNode) && getObjectFlags(objectType) & 32 /* Mapped */ && getMappedTypeModifiers(objectType) & 1 /* IncludeReadonly */) {
-          error(accessNode, Diagnostics.Index_signature_in_type_0_only_permits_reading, typeToString(objectType));
-        }
-        return type;
-      }
-      const apparentObjectType = getApparentType(objectType);
-      if (getIndexInfoOfType(apparentObjectType, numberType) && isTypeAssignableToKind(indexType, 296 /* NumberLike */)) {
-        return type;
-      }
-      if (isGenericObjectType(objectType)) {
-        const propertyName = getPropertyNameFromIndex(indexType, accessNode);
-        if (propertyName) {
-          const propertySymbol = forEachType(apparentObjectType, (t) => getPropertyOfType(t, propertyName));
-          if (propertySymbol && getDeclarationModifierFlagsFromSymbol(propertySymbol) & 24 /* NonPublicAccessibilityModifier */) {
-            error(accessNode, Diagnostics.Private_or_protected_member_0_cannot_be_accessed_on_a_type_parameter, unescapeLeadingUnderscores(propertyName));
-            return errorType;
-          }
-        }
-      }
-      error(accessNode, Diagnostics.Type_0_cannot_be_used_to_index_type_1, typeToString(indexType), typeToString(objectType));
-      return errorType;
-    }
-    function checkIndexedAccessType(node) {
-      checkSourceElement(node.objectType);
-      checkSourceElement(node.indexType);
-      checkIndexedAccessIndexType(getTypeFromIndexedAccessTypeNode(node), node);
-    }
-    function checkMappedType(node) {
-      checkGrammarMappedType(node);
-      checkSourceElement(node.typeParameter);
-      checkSourceElement(node.nameType);
-      checkSourceElement(node.type);
-      if (!node.type) {
-        reportImplicitAny(node, anyType);
-      }
-      const type = getTypeFromMappedTypeNode(node);
-      const nameType = getNameTypeFromMappedType(type);
-      if (nameType) {
-        checkTypeAssignableTo(nameType, keyofConstraintType, node.nameType);
-      } else {
-        const constraintType = getConstraintTypeFromMappedType(type);
-        checkTypeAssignableTo(constraintType, keyofConstraintType, getEffectiveConstraintOfTypeParameter(node.typeParameter));
-      }
-    }
-    function checkGrammarMappedType(node) {
-      var _a;
-      if ((_a = node.members) == null ? void 0 : _a.length) {
-        return grammarErrorOnNode(node.members[0], Diagnostics.A_mapped_type_may_not_declare_properties_or_methods);
-      }
-    }
-    function checkThisType(node) {
-      getTypeFromThisTypeNode(node);
-    }
-    function checkTypeOperator(node) {
-      checkGrammarTypeOperatorNode(node);
-      checkSourceElement(node.type);
-    }
-    function checkConditionalType(node) {
-      forEachChild(node, checkSourceElement);
-    }
-    function checkInferType(node) {
-      if (!findAncestor(node, (n) => n.parent && n.parent.kind === 193 /* ConditionalType */ && n.parent.extendsType === n)) {
-        grammarErrorOnNode(node, Diagnostics.infer_declarations_are_only_permitted_in_the_extends_clause_of_a_conditional_type);
-      }
-      checkSourceElement(node.typeParameter);
-      const symbol = getSymbolOfDeclaration(node.typeParameter);
-      if (symbol.declarations && symbol.declarations.length > 1) {
-        const links = getSymbolLinks(symbol);
-        if (!links.typeParametersChecked) {
-          links.typeParametersChecked = true;
-          const typeParameter = getDeclaredTypeOfTypeParameter(symbol);
-          const declarations = getDeclarationsOfKind(symbol, 167 /* TypeParameter */);
-          if (!areTypeParametersIdentical(declarations, [typeParameter], (decl) => [decl])) {
-            const name = symbolToString(symbol);
-            for (const declaration of declarations) {
-              error(declaration.name, Diagnostics.All_declarations_of_0_must_have_identical_constraints, name);
-            }
-          }
-        }
-      }
-      registerForUnusedIdentifiersCheck(node);
-    }
-    function checkTemplateLiteralType(node) {
-      for (const span of node.templateSpans) {
-        checkSourceElement(span.type);
-        const type = getTypeFromTypeNode(span.type);
-        checkTypeAssignableTo(type, templateConstraintType, span.type);
-      }
-      getTypeFromTypeNode(node);
-    }
-    function checkImportType(node) {
-      checkSourceElement(node.argument);
-      if (node.assertions) {
-        const override = getResolutionModeOverrideForClause(node.assertions.assertClause, grammarErrorOnNode);
-        if (override) {
-          if (!isNightly()) {
-            grammarErrorOnNode(node.assertions.assertClause, Diagnostics.resolution_mode_assertions_are_unstable_Use_nightly_TypeScript_to_silence_this_error_Try_updating_with_npm_install_D_typescript_next);
-          }
-          if (getEmitModuleResolutionKind(compilerOptions) !== 3 /* Node16 */ && getEmitModuleResolutionKind(compilerOptions) !== 99 /* NodeNext */) {
-            grammarErrorOnNode(node.assertions.assertClause, Diagnostics.resolution_mode_assertions_are_only_supported_when_moduleResolution_is_node16_or_nodenext);
-          }
-        }
-      }
-      checkTypeReferenceOrImport(node);
-    }
-    function checkNamedTupleMember(node) {
-      if (node.dotDotDotToken && node.questionToken) {
-        grammarErrorOnNode(node, Diagnostics.A_tuple_member_cannot_be_both_optional_and_rest);
-      }
-      if (node.type.kind === 189 /* OptionalType */) {
-        grammarErrorOnNode(node.type, Diagnostics.A_labeled_tuple_element_is_declared_as_optional_with_a_question_mark_after_the_name_and_before_the_colon_rather_than_after_the_type);
-      }
-      if (node.type.kind === 190 /* RestType */) {
-        grammarErrorOnNode(node.type, Diagnostics.A_labeled_tuple_element_is_declared_as_rest_with_a_before_the_name_rather_than_before_the_type);
-      }
-      checkSourceElement(node.type);
-      getTypeFromTypeNode(node);
-    }
-    function isPrivateWithinAmbient(node) {
-      return (hasEffectiveModifier(node, 8 /* Private */) || isPrivateIdentifierClassElementDeclaration(node)) && !!(node.flags & 16777216 /* Ambient */);
-    }
-    function getEffectiveDeclarationFlags(n, flagsToCheck) {
-      let flags = getCombinedModifierFlags(n);
-      if (n.parent.kind !== 263 /* InterfaceDeclaration */ && n.parent.kind !== 262 /* ClassDeclaration */ && n.parent.kind !== 230 /* ClassExpression */ && n.flags & 16777216 /* Ambient */) {
-        if (!(flags & 2 /* Ambient */) && !(isModuleBlock(n.parent) && isModuleDeclaration(n.parent.parent) && isGlobalScopeAugmentation(n.parent.parent))) {
-          flags |= 1 /* Export */;
-        }
-        flags |= 2 /* Ambient */;
-      }
-      return flags & flagsToCheck;
-    }
-    function checkFunctionOrConstructorSymbol(symbol) {
-      addLazyDiagnostic(() => checkFunctionOrConstructorSymbolWorker(symbol));
-    }
-    function checkFunctionOrConstructorSymbolWorker(symbol) {
-      function getCanonicalOverload(overloads, implementation) {
-        const implementationSharesContainerWithFirstOverload = implementation !== void 0 && implementation.parent === overloads[0].parent;
-        return implementationSharesContainerWithFirstOverload ? implementation : overloads[0];
-      }
-      function checkFlagAgreementBetweenOverloads(overloads, implementation, flagsToCheck2, someOverloadFlags, allOverloadFlags) {
-        const someButNotAllOverloadFlags = someOverloadFlags ^ allOverloadFlags;
-        if (someButNotAllOverloadFlags !== 0) {
-          const canonicalFlags = getEffectiveDeclarationFlags(getCanonicalOverload(overloads, implementation), flagsToCheck2);
-          forEach(overloads, (o) => {
-            const deviation = getEffectiveDeclarationFlags(o, flagsToCheck2) ^ canonicalFlags;
-            if (deviation & 1 /* Export */) {
-              error(getNameOfDeclaration(o), Diagnostics.Overload_signatures_must_all_be_exported_or_non_exported);
-            } else if (deviation & 2 /* Ambient */) {
-              error(getNameOfDeclaration(o), Diagnostics.Overload_signatures_must_all_be_ambient_or_non_ambient);
-            } else if (deviation & (8 /* Private */ | 16 /* Protected */)) {
-              error(getNameOfDeclaration(o) || o, Diagnostics.Overload_signatures_must_all_be_public_private_or_protected);
-            } else if (deviation & 256 /* Abstract */) {
-              error(getNameOfDeclaration(o), Diagnostics.Overload_signatures_must_all_be_abstract_or_non_abstract);
-            }
-          });
-        }
-      }
-      function checkQuestionTokenAgreementBetweenOverloads(overloads, implementation, someHaveQuestionToken2, allHaveQuestionToken2) {
-        if (someHaveQuestionToken2 !== allHaveQuestionToken2) {
-          const canonicalHasQuestionToken = hasQuestionToken(getCanonicalOverload(overloads, implementation));
-          forEach(overloads, (o) => {
-            const deviation = hasQuestionToken(o) !== canonicalHasQuestionToken;
-            if (deviation) {
-              error(getNameOfDeclaration(o), Diagnostics.Overload_signatures_must_all_be_optional_or_required);
-            }
-          });
-        }
-      }
-      const flagsToCheck = 1 /* Export */ | 2 /* Ambient */ | 8 /* Private */ | 16 /* Protected */ | 256 /* Abstract */;
-      let someNodeFlags = 0 /* None */;
-      let allNodeFlags = flagsToCheck;
-      let someHaveQuestionToken = false;
-      let allHaveQuestionToken = true;
-      let hasOverloads = false;
-      let bodyDeclaration;
-      let lastSeenNonAmbientDeclaration;
-      let previousDeclaration;
-      const declarations = symbol.declarations;
-      const isConstructor = (symbol.flags & 16384 /* Constructor */) !== 0;
-      function reportImplementationExpectedError(node) {
-        if (node.name && nodeIsMissing(node.name)) {
-          return;
-        }
-        let seen = false;
-        const subsequentNode = forEachChild(node.parent, (c) => {
-          if (seen) {
-            return c;
-          } else {
-            seen = c === node;
-          }
-        });
-        if (subsequentNode && subsequentNode.pos === node.end) {
-          if (subsequentNode.kind === node.kind) {
-            const errorNode2 = subsequentNode.name || subsequentNode;
-            const subsequentName = subsequentNode.name;
-            if (node.name && subsequentName && // both are private identifiers
-            (isPrivateIdentifier(node.name) && isPrivateIdentifier(subsequentName) && node.name.escapedText === subsequentName.escapedText || // Both are computed property names
-            isComputedPropertyName(node.name) && isComputedPropertyName(subsequentName) && isTypeIdenticalTo(checkComputedPropertyName(node.name), checkComputedPropertyName(subsequentName)) || // Both are literal property names that are the same.
-            isPropertyNameLiteral(node.name) && isPropertyNameLiteral(subsequentName) && getEscapedTextOfIdentifierOrLiteral(node.name) === getEscapedTextOfIdentifierOrLiteral(subsequentName))) {
-              const reportError = (node.kind === 173 /* MethodDeclaration */ || node.kind === 172 /* MethodSignature */) && isStatic(node) !== isStatic(subsequentNode);
-              if (reportError) {
-                const diagnostic = isStatic(node) ? Diagnostics.Function_overload_must_be_static : Diagnostics.Function_overload_must_not_be_static;
-                error(errorNode2, diagnostic);
-              }
-              return;
-            }
-            if (nodeIsPresent(subsequentNode.body)) {
-              error(errorNode2, Diagnostics.Function_implementation_name_must_be_0, declarationNameToString(node.name));
-              return;
-            }
-          }
-        }
-        const errorNode = node.name || node;
-        if (isConstructor) {
-          error(errorNode, Diagnostics.Constructor_implementation_is_missing);
-        } else {
-          if (hasSyntacticModifier(node, 256 /* Abstract */)) {
-            error(errorNode, Diagnostics.All_declarations_of_an_abstract_method_must_be_consecutive);
-          } else {
-            error(errorNode, Diagnostics.Function_implementation_is_missing_or_not_immediately_following_the_declaration);
-          }
-        }
-      }
-      let duplicateFunctionDeclaration = false;
-      let multipleConstructorImplementation = false;
-      let hasNonAmbientClass = false;
-      const functionDeclarations = [];
-      if (declarations) {
-        for (const current of declarations) {
-          const node = current;
-          const inAmbientContext = node.flags & 16777216 /* Ambient */;
-          const inAmbientContextOrInterface = node.parent && (node.parent.kind === 263 /* InterfaceDeclaration */ || node.parent.kind === 186 /* TypeLiteral */) || inAmbientContext;
-          if (inAmbientContextOrInterface) {
-            previousDeclaration = void 0;
-          }
-          if ((node.kind === 262 /* ClassDeclaration */ || node.kind === 230 /* ClassExpression */) && !inAmbientContext) {
-            hasNonAmbientClass = true;
-          }
-          if (node.kind === 261 /* FunctionDeclaration */ || node.kind === 173 /* MethodDeclaration */ || node.kind === 172 /* MethodSignature */ || node.kind === 175 /* Constructor */) {
-            functionDeclarations.push(node);
-            const currentNodeFlags = getEffectiveDeclarationFlags(node, flagsToCheck);
-            someNodeFlags |= currentNodeFlags;
-            allNodeFlags &= currentNodeFlags;
-            someHaveQuestionToken = someHaveQuestionToken || hasQuestionToken(node);
-            allHaveQuestionToken = allHaveQuestionToken && hasQuestionToken(node);
-            const bodyIsPresent = nodeIsPresent(node.body);
-            if (bodyIsPresent && bodyDeclaration) {
-              if (isConstructor) {
-                multipleConstructorImplementation = true;
-              } else {
-                duplicateFunctionDeclaration = true;
-              }
-            } else if ((previousDeclaration == null ? void 0 : previousDeclaration.parent) === node.parent && previousDeclaration.end !== node.pos) {
-              reportImplementationExpectedError(previousDeclaration);
-            }
-            if (bodyIsPresent) {
-              if (!bodyDeclaration) {
-                bodyDeclaration = node;
-              }
-            } else {
-              hasOverloads = true;
-            }
-            previousDeclaration = node;
-            if (!inAmbientContextOrInterface) {
-              lastSeenNonAmbientDeclaration = node;
-            }
-          }
-          if (isInJSFile(current) && isFunctionLike(current) && current.jsDoc) {
-            for (const node2 of current.jsDoc) {
-              if (node2.tags) {
-                for (const tag of node2.tags) {
-                  if (isJSDocOverloadTag(tag)) {
-                    hasOverloads = true;
-                  }
-                }
-              }
-            }
-          }
-        }
-      }
-      if (multipleConstructorImplementation) {
-        forEach(functionDeclarations, (declaration) => {
-          error(declaration, Diagnostics.Multiple_constructor_implementations_are_not_allowed);
-        });
-      }
-      if (duplicateFunctionDeclaration) {
-        forEach(functionDeclarations, (declaration) => {
-          error(getNameOfDeclaration(declaration) || declaration, Diagnostics.Duplicate_function_implementation);
-        });
-      }
-      if (hasNonAmbientClass && !isConstructor && symbol.flags & 16 /* Function */ && declarations) {
-        const relatedDiagnostics = filter(declarations, (d) => d.kind === 262 /* ClassDeclaration */).map((d) => createDiagnosticForNode(d, Diagnostics.Consider_adding_a_declare_modifier_to_this_class));
-        forEach(declarations, (declaration) => {
-          const diagnostic = declaration.kind === 262 /* ClassDeclaration */ ? Diagnostics.Class_declaration_cannot_implement_overload_list_for_0 : declaration.kind === 261 /* FunctionDeclaration */ ? Diagnostics.Function_with_bodies_can_only_merge_with_classes_that_are_ambient : void 0;
-          if (diagnostic) {
-            addRelatedInfo(
-              error(getNameOfDeclaration(declaration) || declaration, diagnostic, symbolName(symbol)),
-              ...relatedDiagnostics
-            );
-          }
-        });
-      }
-      if (lastSeenNonAmbientDeclaration && !lastSeenNonAmbientDeclaration.body && !hasSyntacticModifier(lastSeenNonAmbientDeclaration, 256 /* Abstract */) && !lastSeenNonAmbientDeclaration.questionToken) {
-        reportImplementationExpectedError(lastSeenNonAmbientDeclaration);
-      }
-      if (hasOverloads) {
-        if (declarations) {
-          checkFlagAgreementBetweenOverloads(declarations, bodyDeclaration, flagsToCheck, someNodeFlags, allNodeFlags);
-          checkQuestionTokenAgreementBetweenOverloads(declarations, bodyDeclaration, someHaveQuestionToken, allHaveQuestionToken);
-        }
-        if (bodyDeclaration) {
-          const signatures = getSignaturesOfSymbol(symbol);
-          const bodySignature = getSignatureFromDeclaration(bodyDeclaration);
-          for (const signature of signatures) {
-            if (!isImplementationCompatibleWithOverload(bodySignature, signature)) {
-              const errorNode = signature.declaration && isJSDocSignature(signature.declaration) ? signature.declaration.parent.tagName : signature.declaration;
-              addRelatedInfo(
-                error(errorNode, Diagnostics.This_overload_signature_is_not_compatible_with_its_implementation_signature),
-                createDiagnosticForNode(bodyDeclaration, Diagnostics.The_implementation_signature_is_declared_here)
-              );
-              break;
-            }
-          }
-        }
-      }
-    }
-    function checkExportsOnMergedDeclarations(node) {
-      addLazyDiagnostic(() => checkExportsOnMergedDeclarationsWorker(node));
-    }
-    function checkExportsOnMergedDeclarationsWorker(node) {
-      let symbol = node.localSymbol;
-      if (!symbol) {
-        symbol = getSymbolOfDeclaration(node);
-        if (!symbol.exportSymbol) {
-          return;
-        }
-      }
-      if (getDeclarationOfKind(symbol, node.kind) !== node) {
-        return;
-      }
-      let exportedDeclarationSpaces = 0 /* None */;
-      let nonExportedDeclarationSpaces = 0 /* None */;
-      let defaultExportedDeclarationSpaces = 0 /* None */;
-      for (const d of symbol.declarations) {
-        const declarationSpaces = getDeclarationSpaces(d);
-        const effectiveDeclarationFlags = getEffectiveDeclarationFlags(d, 1 /* Export */ | 1024 /* Default */);
-        if (effectiveDeclarationFlags & 1 /* Export */) {
-          if (effectiveDeclarationFlags & 1024 /* Default */) {
-            defaultExportedDeclarationSpaces |= declarationSpaces;
-          } else {
-            exportedDeclarationSpaces |= declarationSpaces;
-          }
-        } else {
-          nonExportedDeclarationSpaces |= declarationSpaces;
-        }
-      }
-      const nonDefaultExportedDeclarationSpaces = exportedDeclarationSpaces | nonExportedDeclarationSpaces;
-      const commonDeclarationSpacesForExportsAndLocals = exportedDeclarationSpaces & nonExportedDeclarationSpaces;
-      const commonDeclarationSpacesForDefaultAndNonDefault = defaultExportedDeclarationSpaces & nonDefaultExportedDeclarationSpaces;
-      if (commonDeclarationSpacesForExportsAndLocals || commonDeclarationSpacesForDefaultAndNonDefault) {
-        for (const d of symbol.declarations) {
-          const declarationSpaces = getDeclarationSpaces(d);
-          const name = getNameOfDeclaration(d);
-          if (declarationSpaces & commonDeclarationSpacesForDefaultAndNonDefault) {
-            error(name, Diagnostics.Merged_declaration_0_cannot_include_a_default_export_declaration_Consider_adding_a_separate_export_default_0_declaration_instead, declarationNameToString(name));
-          } else if (declarationSpaces & commonDeclarationSpacesForExportsAndLocals) {
-            error(name, Diagnostics.Individual_declarations_in_merged_declaration_0_must_be_all_exported_or_all_local, declarationNameToString(name));
-          }
-        }
-      }
-      function getDeclarationSpaces(decl) {
-        let d = decl;
-        switch (d.kind) {
-          case 263 /* InterfaceDeclaration */:
-          case 264 /* TypeAliasDeclaration */:
-          case 352 /* JSDocTypedefTag */:
-          case 344 /* JSDocCallbackTag */:
-          case 346 /* JSDocEnumTag */:
-            return 2 /* ExportType */;
-          case 266 /* ModuleDeclaration */:
-            return isAmbientModule(d) || getModuleInstanceState(d) !== 0 /* NonInstantiated */ ? 4 /* ExportNamespace */ | 1 /* ExportValue */ : 4 /* ExportNamespace */;
-          case 262 /* ClassDeclaration */:
-          case 265 /* EnumDeclaration */:
-          case 305 /* EnumMember */:
-            return 2 /* ExportType */ | 1 /* ExportValue */;
-          case 311 /* SourceFile */:
-            return 2 /* ExportType */ | 1 /* ExportValue */ | 4 /* ExportNamespace */;
-          case 276 /* ExportAssignment */:
-          case 225 /* BinaryExpression */:
-            const node2 = d;
-            const expression = isExportAssignment(node2) ? node2.expression : node2.right;
-            if (!isEntityNameExpression(expression)) {
-              return 1 /* ExportValue */;
-            }
-            d = expression;
-          case 270 /* ImportEqualsDeclaration */:
-          case 273 /* NamespaceImport */:
-          case 272 /* ImportClause */:
-            let result = 0 /* None */;
-            const target = resolveAlias(getSymbolOfDeclaration(d));
-            forEach(target.declarations, (d2) => {
-              result |= getDeclarationSpaces(d2);
-            });
-            return result;
-          case 259 /* VariableDeclaration */:
-          case 207 /* BindingElement */:
-          case 261 /* FunctionDeclaration */:
-          case 275 /* ImportSpecifier */:
-          case 80 /* Identifier */:
-            return 1 /* ExportValue */;
-          case 172 /* MethodSignature */:
-          case 170 /* PropertySignature */:
-            return 2 /* ExportType */;
-          default:
-            return Debug.failBadSyntaxKind(d);
-        }
-      }
-    }
-    function getAwaitedTypeOfPromise(type, errorNode, diagnosticMessage, ...args) {
-      const promisedType = getPromisedTypeOfPromise(type, errorNode);
-      return promisedType && getAwaitedType(promisedType, errorNode, diagnosticMessage, ...args);
-    }
-    function getPromisedTypeOfPromise(type, errorNode, thisTypeForErrorOut) {
-      if (isTypeAny(type)) {
-        return void 0;
-      }
-      const typeAsPromise = type;
-      if (typeAsPromise.promisedTypeOfPromise) {
-        return typeAsPromise.promisedTypeOfPromise;
-      }
-      if (isReferenceToType2(type, getGlobalPromiseType(
-        /*reportErrors*/
-        false
-      ))) {
-        return typeAsPromise.promisedTypeOfPromise = getTypeArguments(type)[0];
-      }
-      if (allTypesAssignableToKind(getBaseConstraintOrType(type), 402784252 /* Primitive */ | 131072 /* Never */)) {
-        return void 0;
-      }
-      const thenFunction = getTypeOfPropertyOfType(type, "then");
-      if (isTypeAny(thenFunction)) {
-        return void 0;
-      }
-      const thenSignatures = thenFunction ? getSignaturesOfType(thenFunction, 0 /* Call */) : emptyArray;
-      if (thenSignatures.length === 0) {
-        if (errorNode) {
-          error(errorNode, Diagnostics.A_promise_must_have_a_then_method);
-        }
-        return void 0;
-      }
-      let thisTypeForError;
-      let candidates;
-      for (const thenSignature of thenSignatures) {
-        const thisType = getThisTypeOfSignature(thenSignature);
-        if (thisType && thisType !== voidType && !isTypeRelatedTo(type, thisType, subtypeRelation)) {
-          thisTypeForError = thisType;
-        } else {
-          candidates = append(candidates, thenSignature);
-        }
-      }
-      if (!candidates) {
-        Debug.assertIsDefined(thisTypeForError);
-        if (thisTypeForErrorOut) {
-          thisTypeForErrorOut.value = thisTypeForError;
-        }
-        if (errorNode) {
-          error(errorNode, Diagnostics.The_this_context_of_type_0_is_not_assignable_to_method_s_this_of_type_1, typeToString(type), typeToString(thisTypeForError));
-        }
-        return void 0;
-      }
-      const onfulfilledParameterType = getTypeWithFacts(getUnionType(map(candidates, getTypeOfFirstParameterOfSignature)), 2097152 /* NEUndefinedOrNull */);
-      if (isTypeAny(onfulfilledParameterType)) {
-        return void 0;
-      }
-      const onfulfilledParameterSignatures = getSignaturesOfType(onfulfilledParameterType, 0 /* Call */);
-      if (onfulfilledParameterSignatures.length === 0) {
-        if (errorNode) {
-          error(errorNode, Diagnostics.The_first_parameter_of_the_then_method_of_a_promise_must_be_a_callback);
-        }
-        return void 0;
-      }
-      return typeAsPromise.promisedTypeOfPromise = getUnionType(map(onfulfilledParameterSignatures, getTypeOfFirstParameterOfSignature), 2 /* Subtype */);
-    }
-    function checkAwaitedType(type, withAlias, errorNode, diagnosticMessage, ...args) {
-      const awaitedType = withAlias ? getAwaitedType(type, errorNode, diagnosticMessage, ...args) : getAwaitedTypeNoAlias(type, errorNode, diagnosticMessage, ...args);
-      return awaitedType || errorType;
-    }
-    function isThenableType(type) {
-      if (allTypesAssignableToKind(getBaseConstraintOrType(type), 402784252 /* Primitive */ | 131072 /* Never */)) {
-        return false;
-      }
-      const thenFunction = getTypeOfPropertyOfType(type, "then");
-      return !!thenFunction && getSignaturesOfType(getTypeWithFacts(thenFunction, 2097152 /* NEUndefinedOrNull */), 0 /* Call */).length > 0;
-    }
-    function isAwaitedTypeInstantiation(type) {
-      var _a;
-      if (type.flags & 16777216 /* Conditional */) {
-        const awaitedSymbol = getGlobalAwaitedSymbol(
-          /*reportErrors*/
-          false
-        );
-        return !!awaitedSymbol && type.aliasSymbol === awaitedSymbol && ((_a = type.aliasTypeArguments) == null ? void 0 : _a.length) === 1;
-      }
-      return false;
-    }
-    function unwrapAwaitedType(type) {
-      return type.flags & 1048576 /* Union */ ? mapType(type, unwrapAwaitedType) : isAwaitedTypeInstantiation(type) ? type.aliasTypeArguments[0] : type;
-    }
-    function isAwaitedTypeNeeded(type) {
-      if (isTypeAny(type) || isAwaitedTypeInstantiation(type)) {
-        return false;
-      }
-      if (isGenericObjectType(type)) {
-        const baseConstraint = getBaseConstraintOfType(type);
-        if (baseConstraint ? baseConstraint.flags & 3 /* AnyOrUnknown */ || isEmptyObjectType(baseConstraint) || someType(baseConstraint, isThenableType) : maybeTypeOfKind(type, 8650752 /* TypeVariable */)) {
-          return true;
-        }
-      }
-      return false;
-    }
-    function tryCreateAwaitedType(type) {
-      const awaitedSymbol = getGlobalAwaitedSymbol(
-        /*reportErrors*/
-        true
-      );
-      if (awaitedSymbol) {
-        return getTypeAliasInstantiation(awaitedSymbol, [unwrapAwaitedType(type)]);
-      }
-      return void 0;
-    }
-    function createAwaitedTypeIfNeeded(type) {
-      if (isAwaitedTypeNeeded(type)) {
-        const awaitedType = tryCreateAwaitedType(type);
-        if (awaitedType) {
-          return awaitedType;
-        }
-      }
-      Debug.assert(isAwaitedTypeInstantiation(type) || getPromisedTypeOfPromise(type) === void 0, "type provided should not be a non-generic 'promise'-like.");
-      return type;
-    }
-    function getAwaitedType(type, errorNode, diagnosticMessage, ...args) {
-      const awaitedType = getAwaitedTypeNoAlias(type, errorNode, diagnosticMessage, ...args);
-      return awaitedType && createAwaitedTypeIfNeeded(awaitedType);
-    }
-    function getAwaitedTypeNoAlias(type, errorNode, diagnosticMessage, ...args) {
-      if (isTypeAny(type)) {
-        return type;
-      }
-      if (isAwaitedTypeInstantiation(type)) {
-        return type;
-      }
-      const typeAsAwaitable = type;
-      if (typeAsAwaitable.awaitedTypeOfType) {
-        return typeAsAwaitable.awaitedTypeOfType;
-      }
-      if (type.flags & 1048576 /* Union */) {
-        if (awaitedTypeStack.lastIndexOf(type.id) >= 0) {
-          if (errorNode) {
-            error(errorNode, Diagnostics.Type_is_referenced_directly_or_indirectly_in_the_fulfillment_callback_of_its_own_then_method);
-          }
-          return void 0;
-        }
-        const mapper = errorNode ? (constituentType) => getAwaitedTypeNoAlias(constituentType, errorNode, diagnosticMessage, ...args) : getAwaitedTypeNoAlias;
-        awaitedTypeStack.push(type.id);
-        const mapped = mapType(type, mapper);
-        awaitedTypeStack.pop();
-        return typeAsAwaitable.awaitedTypeOfType = mapped;
-      }
-      if (isAwaitedTypeNeeded(type)) {
-        return typeAsAwaitable.awaitedTypeOfType = type;
-      }
-      const thisTypeForErrorOut = { value: void 0 };
-      const promisedType = getPromisedTypeOfPromise(
-        type,
-        /*errorNode*/
-        void 0,
-        thisTypeForErrorOut
-      );
-      if (promisedType) {
-        if (type.id === promisedType.id || awaitedTypeStack.lastIndexOf(promisedType.id) >= 0) {
-          if (errorNode) {
-            error(errorNode, Diagnostics.Type_is_referenced_directly_or_indirectly_in_the_fulfillment_callback_of_its_own_then_method);
-          }
-          return void 0;
-        }
-        awaitedTypeStack.push(type.id);
-        const awaitedType = getAwaitedTypeNoAlias(promisedType, errorNode, diagnosticMessage, ...args);
-        awaitedTypeStack.pop();
-        if (!awaitedType) {
-          return void 0;
-        }
-        return typeAsAwaitable.awaitedTypeOfType = awaitedType;
-      }
-      if (isThenableType(type)) {
-        if (errorNode) {
-          Debug.assertIsDefined(diagnosticMessage);
-          let chain;
-          if (thisTypeForErrorOut.value) {
-            chain = chainDiagnosticMessages(chain, Diagnostics.The_this_context_of_type_0_is_not_assignable_to_method_s_this_of_type_1, typeToString(type), typeToString(thisTypeForErrorOut.value));
-          }
-          chain = chainDiagnosticMessages(chain, diagnosticMessage, ...args);
-          diagnostics.add(createDiagnosticForNodeFromMessageChain(getSourceFileOfNode(errorNode), errorNode, chain));
-        }
-        return void 0;
-      }
-      return typeAsAwaitable.awaitedTypeOfType = type;
-    }
-    function checkAsyncFunctionReturnType(node, returnTypeNode) {
-      const returnType = getTypeFromTypeNode(returnTypeNode);
-      if (languageVersion >= 2 /* ES2015 */) {
-        if (isErrorType(returnType)) {
-          return;
-        }
-        const globalPromiseType = getGlobalPromiseType(
-          /*reportErrors*/
-          true
-        );
-        if (globalPromiseType !== emptyGenericType && !isReferenceToType2(returnType, globalPromiseType)) {
-          error(returnTypeNode, Diagnostics.The_return_type_of_an_async_function_or_method_must_be_the_global_Promise_T_type_Did_you_mean_to_write_Promise_0, typeToString(getAwaitedTypeNoAlias(returnType) || voidType));
-          return;
-        }
-      } else {
-        markTypeNodeAsReferenced(returnTypeNode);
-        if (isErrorType(returnType)) {
-          return;
-        }
-        const promiseConstructorName = getEntityNameFromTypeNode(returnTypeNode);
-        if (promiseConstructorName === void 0) {
-          error(returnTypeNode, Diagnostics.Type_0_is_not_a_valid_async_function_return_type_in_ES5_SlashES3_because_it_does_not_refer_to_a_Promise_compatible_constructor_value, typeToString(returnType));
-          return;
-        }
-        const promiseConstructorSymbol = resolveEntityName(
-          promiseConstructorName,
-          111551 /* Value */,
-          /*ignoreErrors*/
-          true
-        );
-        const promiseConstructorType = promiseConstructorSymbol ? getTypeOfSymbol(promiseConstructorSymbol) : errorType;
-        if (isErrorType(promiseConstructorType)) {
-          if (promiseConstructorName.kind === 80 /* Identifier */ && promiseConstructorName.escapedText === "Promise" && getTargetType(returnType) === getGlobalPromiseType(
-            /*reportErrors*/
-            false
-          )) {
-            error(returnTypeNode, Diagnostics.An_async_function_or_method_in_ES5_SlashES3_requires_the_Promise_constructor_Make_sure_you_have_a_declaration_for_the_Promise_constructor_or_include_ES2015_in_your_lib_option);
-          } else {
-            error(returnTypeNode, Diagnostics.Type_0_is_not_a_valid_async_function_return_type_in_ES5_SlashES3_because_it_does_not_refer_to_a_Promise_compatible_constructor_value, entityNameToString(promiseConstructorName));
-          }
-          return;
-        }
-        const globalPromiseConstructorLikeType = getGlobalPromiseConstructorLikeType(
-          /*reportErrors*/
-          true
-        );
-        if (globalPromiseConstructorLikeType === emptyObjectType) {
-          error(returnTypeNode, Diagnostics.Type_0_is_not_a_valid_async_function_return_type_in_ES5_SlashES3_because_it_does_not_refer_to_a_Promise_compatible_constructor_value, entityNameToString(promiseConstructorName));
-          return;
-        }
-        if (!checkTypeAssignableTo(
-          promiseConstructorType,
-          globalPromiseConstructorLikeType,
-          returnTypeNode,
-          Diagnostics.Type_0_is_not_a_valid_async_function_return_type_in_ES5_SlashES3_because_it_does_not_refer_to_a_Promise_compatible_constructor_value
-        )) {
-          return;
-        }
-        const rootName = promiseConstructorName && getFirstIdentifier(promiseConstructorName);
-        const collidingSymbol = getSymbol2(node.locals, rootName.escapedText, 111551 /* Value */);
-        if (collidingSymbol) {
-          error(
-            collidingSymbol.valueDeclaration,
-            Diagnostics.Duplicate_identifier_0_Compiler_uses_declaration_1_to_support_async_functions,
-            idText(rootName),
-            entityNameToString(promiseConstructorName)
-          );
-          return;
-        }
-      }
-      checkAwaitedType(
-        returnType,
-        /*withAlias*/
-        false,
-        node,
-        Diagnostics.The_return_type_of_an_async_function_must_either_be_a_valid_promise_or_must_not_contain_a_callable_then_member
-      );
-    }
-    function checkDecorator(node) {
-      const signature = getResolvedSignature(node);
-      checkDeprecatedSignature(signature, node);
-      const returnType = getReturnTypeOfSignature(signature);
-      if (returnType.flags & 1 /* Any */) {
-        return;
-      }
-      const decoratorSignature = getDecoratorCallSignature(node);
-      if (!(decoratorSignature == null ? void 0 : decoratorSignature.resolvedReturnType))
-        return;
-      let headMessage;
-      const expectedReturnType = decoratorSignature.resolvedReturnType;
-      switch (node.parent.kind) {
-        case 262 /* ClassDeclaration */:
-        case 230 /* ClassExpression */:
-          headMessage = Diagnostics.Decorator_function_return_type_0_is_not_assignable_to_type_1;
-          break;
-        case 171 /* PropertyDeclaration */:
-          if (!legacyDecorators) {
-            headMessage = Diagnostics.Decorator_function_return_type_0_is_not_assignable_to_type_1;
-            break;
-          }
-        case 168 /* Parameter */:
-          headMessage = Diagnostics.Decorator_function_return_type_is_0_but_is_expected_to_be_void_or_any;
-          break;
-        case 173 /* MethodDeclaration */:
-        case 176 /* GetAccessor */:
-        case 177 /* SetAccessor */:
-          headMessage = Diagnostics.Decorator_function_return_type_0_is_not_assignable_to_type_1;
-          break;
-        default:
-          return Debug.failBadSyntaxKind(node.parent);
-      }
-      checkTypeAssignableTo(returnType, expectedReturnType, node.expression, headMessage);
-    }
-    function createCallSignature(typeParameters, thisParameter, parameters, returnType, typePredicate, minArgumentCount = parameters.length, flags = 0 /* None */) {
-      const decl = factory.createFunctionTypeNode(
-        /*typeParameters*/
-        void 0,
-        emptyArray,
-        factory.createKeywordTypeNode(133 /* AnyKeyword */)
-      );
-      return createSignature(decl, typeParameters, thisParameter, parameters, returnType, typePredicate, minArgumentCount, flags);
-    }
-    function createFunctionType(typeParameters, thisParameter, parameters, returnType, typePredicate, minArgumentCount, flags) {
-      const signature = createCallSignature(typeParameters, thisParameter, parameters, returnType, typePredicate, minArgumentCount, flags);
-      return getOrCreateTypeFromSignature(signature);
-    }
-    function createGetterFunctionType(type) {
-      return createFunctionType(
-        /*typeParameters*/
-        void 0,
-        /*thisParameter*/
-        void 0,
-        emptyArray,
-        type
-      );
-    }
-    function createSetterFunctionType(type) {
-      const valueParam = createParameter("value", type);
-      return createFunctionType(
-        /*typeParameters*/
-        void 0,
-        /*thisParameter*/
-        void 0,
-        [valueParam],
-        voidType
-      );
-    }
-    function markTypeNodeAsReferenced(node) {
-      markEntityNameOrEntityExpressionAsReference(
-        node && getEntityNameFromTypeNode(node),
-        /*forDecoratorMetadata*/
-        false
-      );
-    }
-    function markEntityNameOrEntityExpressionAsReference(typeName, forDecoratorMetadata) {
-      if (!typeName)
-        return;
-      const rootName = getFirstIdentifier(typeName);
-      const meaning = (typeName.kind === 80 /* Identifier */ ? 788968 /* Type */ : 1920 /* Namespace */) | 2097152 /* Alias */;
-      const rootSymbol = resolveName(
-        rootName,
-        rootName.escapedText,
-        meaning,
-        /*nameNotFoundMessage*/
-        void 0,
-        /*nameArg*/
-        void 0,
-        /*isUse*/
-        true
-      );
-      if (rootSymbol && rootSymbol.flags & 2097152 /* Alias */) {
-        if (canCollectSymbolAliasAccessabilityData && symbolIsValue(rootSymbol) && !isConstEnumOrConstEnumOnlyModule(resolveAlias(rootSymbol)) && !getTypeOnlyAliasDeclaration(rootSymbol)) {
-          markAliasSymbolAsReferenced(rootSymbol);
-        } else if (forDecoratorMetadata && getIsolatedModules(compilerOptions) && getEmitModuleKind(compilerOptions) >= 5 /* ES2015 */ && !symbolIsValue(rootSymbol) && !some(rootSymbol.declarations, isTypeOnlyImportOrExportDeclaration)) {
-          const diag2 = error(typeName, Diagnostics.A_type_referenced_in_a_decorated_signature_must_be_imported_with_import_type_or_a_namespace_import_when_isolatedModules_and_emitDecoratorMetadata_are_enabled);
-          const aliasDeclaration = find(rootSymbol.declarations || emptyArray, isAliasSymbolDeclaration2);
-          if (aliasDeclaration) {
-            addRelatedInfo(diag2, createDiagnosticForNode(aliasDeclaration, Diagnostics._0_was_imported_here, idText(rootName)));
-          }
-        }
-      }
-    }
-    function markDecoratorMedataDataTypeNodeAsReferenced(node) {
-      const entityName = getEntityNameForDecoratorMetadata(node);
-      if (entityName && isEntityName(entityName)) {
-        markEntityNameOrEntityExpressionAsReference(
-          entityName,
-          /*forDecoratorMetadata*/
-          true
-        );
-      }
-    }
-    function getEntityNameForDecoratorMetadata(node) {
-      if (node) {
-        switch (node.kind) {
-          case 192 /* IntersectionType */:
-          case 191 /* UnionType */:
-            return getEntityNameForDecoratorMetadataFromTypeList(node.types);
-          case 193 /* ConditionalType */:
-            return getEntityNameForDecoratorMetadataFromTypeList([node.trueType, node.falseType]);
-          case 195 /* ParenthesizedType */:
-          case 201 /* NamedTupleMember */:
-            return getEntityNameForDecoratorMetadata(node.type);
-          case 182 /* TypeReference */:
-            return node.typeName;
-        }
-      }
-    }
-    function getEntityNameForDecoratorMetadataFromTypeList(types) {
-      let commonEntityName;
-      for (let typeNode of types) {
-        while (typeNode.kind === 195 /* ParenthesizedType */ || typeNode.kind === 201 /* NamedTupleMember */) {
-          typeNode = typeNode.type;
-        }
-        if (typeNode.kind === 146 /* NeverKeyword */) {
-          continue;
-        }
-        if (!strictNullChecks && (typeNode.kind === 200 /* LiteralType */ && typeNode.literal.kind === 106 /* NullKeyword */ || typeNode.kind === 157 /* UndefinedKeyword */)) {
-          continue;
-        }
-        const individualEntityName = getEntityNameForDecoratorMetadata(typeNode);
-        if (!individualEntityName) {
-          return void 0;
-        }
-        if (commonEntityName) {
-          if (!isIdentifier(commonEntityName) || !isIdentifier(individualEntityName) || commonEntityName.escapedText !== individualEntityName.escapedText) {
-            return void 0;
-          }
-        } else {
-          commonEntityName = individualEntityName;
-        }
-      }
-      return commonEntityName;
-    }
-    function getParameterTypeNodeForDecoratorCheck(node) {
-      const typeNode = getEffectiveTypeAnnotationNode(node);
-      return isRestParameter(node) ? getRestParameterElementType(typeNode) : typeNode;
-    }
-    function checkDecorators(node) {
-      if (!canHaveDecorators(node) || !hasDecorators(node) || !node.modifiers || !nodeCanBeDecorated(legacyDecorators, node, node.parent, node.parent.parent)) {
-        return;
-      }
-      const firstDecorator = find(node.modifiers, isDecorator);
-      if (!firstDecorator) {
-        return;
-      }
-      if (legacyDecorators) {
-        checkExternalEmitHelpers(firstDecorator, 8 /* Decorate */);
-        if (node.kind === 168 /* Parameter */) {
-          checkExternalEmitHelpers(firstDecorator, 32 /* Param */);
-        }
-      } else if (languageVersion < 99 /* ESNext */) {
-        checkExternalEmitHelpers(firstDecorator, 8 /* ESDecorateAndRunInitializers */);
-        if (isClassDeclaration(node)) {
-          if (!node.name) {
-            checkExternalEmitHelpers(firstDecorator, 8388608 /* SetFunctionName */);
-          } else {
-            const member = getFirstTransformableStaticClassElement(node);
-            if (member) {
-              checkExternalEmitHelpers(firstDecorator, 8388608 /* SetFunctionName */);
-            }
-          }
-        } else if (!isClassExpression(node)) {
-          if (isPrivateIdentifier(node.name) && (isMethodDeclaration(node) || isAccessor(node) || isAutoAccessorPropertyDeclaration(node))) {
-            checkExternalEmitHelpers(firstDecorator, 8388608 /* SetFunctionName */);
-          }
-          if (isComputedPropertyName(node.name)) {
-            checkExternalEmitHelpers(firstDecorator, 16777216 /* PropKey */);
-          }
-        }
-      }
-      if (compilerOptions.emitDecoratorMetadata) {
-        checkExternalEmitHelpers(firstDecorator, 16 /* Metadata */);
-        switch (node.kind) {
-          case 262 /* ClassDeclaration */:
-            const constructor = getFirstConstructorWithBody(node);
-            if (constructor) {
-              for (const parameter of constructor.parameters) {
-                markDecoratorMedataDataTypeNodeAsReferenced(getParameterTypeNodeForDecoratorCheck(parameter));
-              }
-            }
-            break;
-          case 176 /* GetAccessor */:
-          case 177 /* SetAccessor */:
-            const otherKind = node.kind === 176 /* GetAccessor */ ? 177 /* SetAccessor */ : 176 /* GetAccessor */;
-            const otherAccessor = getDeclarationOfKind(getSymbolOfDeclaration(node), otherKind);
-            markDecoratorMedataDataTypeNodeAsReferenced(getAnnotatedAccessorTypeNode(node) || otherAccessor && getAnnotatedAccessorTypeNode(otherAccessor));
-            break;
-          case 173 /* MethodDeclaration */:
-            for (const parameter of node.parameters) {
-              markDecoratorMedataDataTypeNodeAsReferenced(getParameterTypeNodeForDecoratorCheck(parameter));
-            }
-            markDecoratorMedataDataTypeNodeAsReferenced(getEffectiveReturnTypeNode(node));
-            break;
-          case 171 /* PropertyDeclaration */:
-            markDecoratorMedataDataTypeNodeAsReferenced(getEffectiveTypeAnnotationNode(node));
-            break;
-          case 168 /* Parameter */:
-            markDecoratorMedataDataTypeNodeAsReferenced(getParameterTypeNodeForDecoratorCheck(node));
-            const containingSignature = node.parent;
-            for (const parameter of containingSignature.parameters) {
-              markDecoratorMedataDataTypeNodeAsReferenced(getParameterTypeNodeForDecoratorCheck(parameter));
-            }
-            break;
-        }
-      }
-      for (const modifier of node.modifiers) {
-        if (isDecorator(modifier)) {
-          checkDecorator(modifier);
-        }
-      }
-    }
-    function checkFunctionDeclaration(node) {
-      addLazyDiagnostic(checkFunctionDeclarationDiagnostics);
-      function checkFunctionDeclarationDiagnostics() {
-        checkFunctionOrMethodDeclaration(node);
-        checkGrammarForGenerator(node);
-        checkCollisionsForDeclarationName(node, node.name);
-      }
-    }
-    function checkJSDocTypeAliasTag(node) {
-      if (!node.typeExpression) {
-        error(node.name, Diagnostics.JSDoc_typedef_tag_should_either_have_a_type_annotation_or_be_followed_by_property_or_member_tags);
-      }
-      if (node.name) {
-        checkTypeNameIsReserved(node.name, Diagnostics.Type_alias_name_cannot_be_0);
-      }
-      checkSourceElement(node.typeExpression);
-      checkTypeParameters(getEffectiveTypeParameterDeclarations(node));
-    }
-    function checkJSDocTemplateTag(node) {
-      checkSourceElement(node.constraint);
-      for (const tp of node.typeParameters) {
-        checkSourceElement(tp);
-      }
-    }
-    function checkJSDocTypeTag(node) {
-      checkSourceElement(node.typeExpression);
-    }
-    function checkJSDocSatisfiesTag(node) {
-      checkSourceElement(node.typeExpression);
-      const host2 = getEffectiveJSDocHost(node);
-      if (host2) {
-        const tags = getAllJSDocTags(host2, isJSDocSatisfiesTag);
-        if (length(tags) > 1) {
-          for (let i = 1; i < length(tags); i++) {
-            const tagName = tags[i].tagName;
-            error(tagName, Diagnostics._0_tag_already_specified, idText(tagName));
-          }
-        }
-      }
-    }
-    function checkJSDocLinkLikeTag(node) {
-      if (node.name) {
-        resolveJSDocMemberName(
-          node.name,
-          /*ignoreErrors*/
-          true
-        );
-      }
-    }
-    function checkJSDocParameterTag(node) {
-      checkSourceElement(node.typeExpression);
-    }
-    function checkJSDocPropertyTag(node) {
-      checkSourceElement(node.typeExpression);
-    }
-    function checkJSDocFunctionType(node) {
-      addLazyDiagnostic(checkJSDocFunctionTypeImplicitAny);
-      checkSignatureDeclaration(node);
-      function checkJSDocFunctionTypeImplicitAny() {
-        if (!node.type && !isJSDocConstructSignature(node)) {
-          reportImplicitAny(node, anyType);
-        }
-      }
-    }
-    function checkJSDocImplementsTag(node) {
-      const classLike = getEffectiveJSDocHost(node);
-      if (!classLike || !isClassDeclaration(classLike) && !isClassExpression(classLike)) {
-        error(classLike, Diagnostics.JSDoc_0_is_not_attached_to_a_class, idText(node.tagName));
-      }
-    }
-    function checkJSDocAugmentsTag(node) {
-      const classLike = getEffectiveJSDocHost(node);
-      if (!classLike || !isClassDeclaration(classLike) && !isClassExpression(classLike)) {
-        error(classLike, Diagnostics.JSDoc_0_is_not_attached_to_a_class, idText(node.tagName));
-        return;
-      }
-      const augmentsTags = getJSDocTags(classLike).filter(isJSDocAugmentsTag);
-      Debug.assert(augmentsTags.length > 0);
-      if (augmentsTags.length > 1) {
-        error(augmentsTags[1], Diagnostics.Class_declarations_cannot_have_more_than_one_augments_or_extends_tag);
-      }
-      const name = getIdentifierFromEntityNameExpression(node.class.expression);
-      const extend2 = getClassExtendsHeritageElement(classLike);
-      if (extend2) {
-        const className = getIdentifierFromEntityNameExpression(extend2.expression);
-        if (className && name.escapedText !== className.escapedText) {
-          error(name, Diagnostics.JSDoc_0_1_does_not_match_the_extends_2_clause, idText(node.tagName), idText(name), idText(className));
-        }
-      }
-    }
-    function checkJSDocAccessibilityModifiers(node) {
-      const host2 = getJSDocHost(node);
-      if (host2 && isPrivateIdentifierClassElementDeclaration(host2)) {
-        error(node, Diagnostics.An_accessibility_modifier_cannot_be_used_with_a_private_identifier);
-      }
-    }
-    function getIdentifierFromEntityNameExpression(node) {
-      switch (node.kind) {
-        case 80 /* Identifier */:
-          return node;
-        case 210 /* PropertyAccessExpression */:
-          return node.name;
-        default:
-          return void 0;
-      }
-    }
-    function checkFunctionOrMethodDeclaration(node) {
-      var _a;
-      checkDecorators(node);
-      checkSignatureDeclaration(node);
-      const functionFlags = getFunctionFlags(node);
-      if (node.name && node.name.kind === 166 /* ComputedPropertyName */) {
-        checkComputedPropertyName(node.name);
-      }
-      if (hasBindableName(node)) {
-        const symbol = getSymbolOfDeclaration(node);
-        const localSymbol = node.localSymbol || symbol;
-        const firstDeclaration = (_a = localSymbol.declarations) == null ? void 0 : _a.find(
-          // Get first non javascript function declaration
-          (declaration) => declaration.kind === node.kind && !(declaration.flags & 262144 /* JavaScriptFile */)
-        );
-        if (node === firstDeclaration) {
-          checkFunctionOrConstructorSymbol(localSymbol);
-        }
-        if (symbol.parent) {
-          checkFunctionOrConstructorSymbol(symbol);
-        }
-      }
-      const body = node.kind === 172 /* MethodSignature */ ? void 0 : node.body;
-      checkSourceElement(body);
-      checkAllCodePathsInNonVoidFunctionReturnOrThrow(node, getReturnTypeFromAnnotation(node));
-      addLazyDiagnostic(checkFunctionOrMethodDeclarationDiagnostics);
-      if (isInJSFile(node)) {
-        const typeTag = getJSDocTypeTag(node);
-        if (typeTag && typeTag.typeExpression && !getContextualCallSignature(getTypeFromTypeNode(typeTag.typeExpression), node)) {
-          error(typeTag.typeExpression.type, Diagnostics.The_type_of_a_function_declaration_must_match_the_function_s_signature);
-        }
-      }
-      function checkFunctionOrMethodDeclarationDiagnostics() {
-        if (!getEffectiveReturnTypeNode(node)) {
-          if (nodeIsMissing(body) && !isPrivateWithinAmbient(node)) {
-            reportImplicitAny(node, anyType);
-          }
-          if (functionFlags & 1 /* Generator */ && nodeIsPresent(body)) {
-            getReturnTypeOfSignature(getSignatureFromDeclaration(node));
-          }
-        }
-      }
-    }
-    function registerForUnusedIdentifiersCheck(node) {
-      addLazyDiagnostic(registerForUnusedIdentifiersCheckDiagnostics);
-      function registerForUnusedIdentifiersCheckDiagnostics() {
-        const sourceFile = getSourceFileOfNode(node);
-        let potentiallyUnusedIdentifiers = allPotentiallyUnusedIdentifiers.get(sourceFile.path);
-        if (!potentiallyUnusedIdentifiers) {
-          potentiallyUnusedIdentifiers = [];
-          allPotentiallyUnusedIdentifiers.set(sourceFile.path, potentiallyUnusedIdentifiers);
-        }
-        potentiallyUnusedIdentifiers.push(node);
-      }
-    }
-    function checkUnusedIdentifiers(potentiallyUnusedIdentifiers, addDiagnostic) {
-      for (const node of potentiallyUnusedIdentifiers) {
-        switch (node.kind) {
-          case 262 /* ClassDeclaration */:
-          case 230 /* ClassExpression */:
-            checkUnusedClassMembers(node, addDiagnostic);
-            checkUnusedTypeParameters(node, addDiagnostic);
-            break;
-          case 311 /* SourceFile */:
-          case 266 /* ModuleDeclaration */:
-          case 240 /* Block */:
-          case 268 /* CaseBlock */:
-          case 247 /* ForStatement */:
-          case 248 /* ForInStatement */:
-          case 249 /* ForOfStatement */:
-            checkUnusedLocalsAndParameters(node, addDiagnostic);
-            break;
-          case 175 /* Constructor */:
-          case 217 /* FunctionExpression */:
-          case 261 /* FunctionDeclaration */:
-          case 218 /* ArrowFunction */:
-          case 173 /* MethodDeclaration */:
-          case 176 /* GetAccessor */:
-          case 177 /* SetAccessor */:
-            if (node.body) {
-              checkUnusedLocalsAndParameters(node, addDiagnostic);
-            }
-            checkUnusedTypeParameters(node, addDiagnostic);
-            break;
-          case 172 /* MethodSignature */:
-          case 178 /* CallSignature */:
-          case 179 /* ConstructSignature */:
-          case 183 /* FunctionType */:
-          case 184 /* ConstructorType */:
-          case 264 /* TypeAliasDeclaration */:
-          case 263 /* InterfaceDeclaration */:
-            checkUnusedTypeParameters(node, addDiagnostic);
-            break;
-          case 194 /* InferType */:
-            checkUnusedInferTypeParameter(node, addDiagnostic);
-            break;
-          default:
-            Debug.assertNever(node, "Node should not have been registered for unused identifiers check");
-        }
-      }
-    }
-    function errorUnusedLocal(declaration, name, addDiagnostic) {
-      const node = getNameOfDeclaration(declaration) || declaration;
-      const message = isTypeDeclaration(declaration) ? Diagnostics._0_is_declared_but_never_used : Diagnostics._0_is_declared_but_its_value_is_never_read;
-      addDiagnostic(declaration, 0 /* Local */, createDiagnosticForNode(node, message, name));
-    }
-    function isIdentifierThatStartsWithUnderscore(node) {
-      return isIdentifier(node) && idText(node).charCodeAt(0) === 95 /* _ */;
-    }
-    function checkUnusedClassMembers(node, addDiagnostic) {
-      for (const member of node.members) {
-        switch (member.kind) {
-          case 173 /* MethodDeclaration */:
-          case 171 /* PropertyDeclaration */:
-          case 176 /* GetAccessor */:
-          case 177 /* SetAccessor */:
-            if (member.kind === 177 /* SetAccessor */ && member.symbol.flags & 32768 /* GetAccessor */) {
-              break;
-            }
-            const symbol = getSymbolOfDeclaration(member);
-            if (!symbol.isReferenced && (hasEffectiveModifier(member, 8 /* Private */) || isNamedDeclaration(member) && isPrivateIdentifier(member.name)) && !(member.flags & 16777216 /* Ambient */)) {
-              addDiagnostic(member, 0 /* Local */, createDiagnosticForNode(member.name, Diagnostics._0_is_declared_but_its_value_is_never_read, symbolToString(symbol)));
-            }
-            break;
-          case 175 /* Constructor */:
-            for (const parameter of member.parameters) {
-              if (!parameter.symbol.isReferenced && hasSyntacticModifier(parameter, 8 /* Private */)) {
-                addDiagnostic(parameter, 0 /* Local */, createDiagnosticForNode(parameter.name, Diagnostics.Property_0_is_declared_but_its_value_is_never_read, symbolName(parameter.symbol)));
-              }
-            }
-            break;
-          case 180 /* IndexSignature */:
-          case 239 /* SemicolonClassElement */:
-          case 174 /* ClassStaticBlockDeclaration */:
-            break;
-          default:
-            Debug.fail("Unexpected class member");
-        }
-      }
-    }
-    function checkUnusedInferTypeParameter(node, addDiagnostic) {
-      const { typeParameter } = node;
-      if (isTypeParameterUnused(typeParameter)) {
-        addDiagnostic(node, 1 /* Parameter */, createDiagnosticForNode(node, Diagnostics._0_is_declared_but_its_value_is_never_read, idText(typeParameter.name)));
-      }
-    }
-    function checkUnusedTypeParameters(node, addDiagnostic) {
-      const declarations = getSymbolOfDeclaration(node).declarations;
-      if (!declarations || last(declarations) !== node)
-        return;
-      const typeParameters = getEffectiveTypeParameterDeclarations(node);
-      const seenParentsWithEveryUnused = /* @__PURE__ */ new Set();
-      for (const typeParameter of typeParameters) {
-        if (!isTypeParameterUnused(typeParameter))
-          continue;
-        const name = idText(typeParameter.name);
-        const { parent: parent2 } = typeParameter;
-        if (parent2.kind !== 194 /* InferType */ && parent2.typeParameters.every(isTypeParameterUnused)) {
-          if (tryAddToSet(seenParentsWithEveryUnused, parent2)) {
-            const sourceFile = getSourceFileOfNode(parent2);
-            const range = isJSDocTemplateTag(parent2) ? rangeOfNode(parent2) : rangeOfTypeParameters(sourceFile, parent2.typeParameters);
-            const only = parent2.typeParameters.length === 1;
-            const messageAndArg = only ? [Diagnostics._0_is_declared_but_its_value_is_never_read, name] : [Diagnostics.All_type_parameters_are_unused];
-            addDiagnostic(typeParameter, 1 /* Parameter */, createFileDiagnostic(sourceFile, range.pos, range.end - range.pos, ...messageAndArg));
-          }
-        } else {
-          addDiagnostic(typeParameter, 1 /* Parameter */, createDiagnosticForNode(typeParameter, Diagnostics._0_is_declared_but_its_value_is_never_read, name));
-        }
-      }
-    }
-    function isTypeParameterUnused(typeParameter) {
-      return !(getMergedSymbol(typeParameter.symbol).isReferenced & 262144 /* TypeParameter */) && !isIdentifierThatStartsWithUnderscore(typeParameter.name);
-    }
-    function addToGroup(map2, key, value, getKey) {
-      const keyString = String(getKey(key));
-      const group2 = map2.get(keyString);
-      if (group2) {
-        group2[1].push(value);
-      } else {
-        map2.set(keyString, [key, [value]]);
-      }
-    }
-    function tryGetRootParameterDeclaration(node) {
-      return tryCast(getRootDeclaration(node), isParameter);
-    }
-    function isValidUnusedLocalDeclaration(declaration) {
-      if (isBindingElement(declaration)) {
-        if (isObjectBindingPattern(declaration.parent)) {
-          return !!(declaration.propertyName && isIdentifierThatStartsWithUnderscore(declaration.name));
-        }
-        return isIdentifierThatStartsWithUnderscore(declaration.name);
-      }
-      return isAmbientModule(declaration) || (isVariableDeclaration(declaration) && isForInOrOfStatement(declaration.parent.parent) || isImportedDeclaration(declaration)) && isIdentifierThatStartsWithUnderscore(declaration.name);
-    }
-    function checkUnusedLocalsAndParameters(nodeWithLocals, addDiagnostic) {
-      const unusedImports = /* @__PURE__ */ new Map();
-      const unusedDestructures = /* @__PURE__ */ new Map();
-      const unusedVariables = /* @__PURE__ */ new Map();
-      nodeWithLocals.locals.forEach((local) => {
-        if (local.flags & 262144 /* TypeParameter */ ? !(local.flags & 3 /* Variable */ && !(local.isReferenced & 3 /* Variable */)) : local.isReferenced || local.exportSymbol) {
-          return;
-        }
-        if (local.declarations) {
-          for (const declaration of local.declarations) {
-            if (isValidUnusedLocalDeclaration(declaration)) {
-              continue;
-            }
-            if (isImportedDeclaration(declaration)) {
-              addToGroup(unusedImports, importClauseFromImported(declaration), declaration, getNodeId);
-            } else if (isBindingElement(declaration) && isObjectBindingPattern(declaration.parent)) {
-              const lastElement = last(declaration.parent.elements);
-              if (declaration === lastElement || !last(declaration.parent.elements).dotDotDotToken) {
-                addToGroup(unusedDestructures, declaration.parent, declaration, getNodeId);
-              }
-            } else if (isVariableDeclaration(declaration)) {
-              addToGroup(unusedVariables, declaration.parent, declaration, getNodeId);
-            } else {
-              const parameter = local.valueDeclaration && tryGetRootParameterDeclaration(local.valueDeclaration);
-              const name = local.valueDeclaration && getNameOfDeclaration(local.valueDeclaration);
-              if (parameter && name) {
-                if (!isParameterPropertyDeclaration(parameter, parameter.parent) && !parameterIsThisKeyword(parameter) && !isIdentifierThatStartsWithUnderscore(name)) {
-                  if (isBindingElement(declaration) && isArrayBindingPattern(declaration.parent)) {
-                    addToGroup(unusedDestructures, declaration.parent, declaration, getNodeId);
-                  } else {
-                    addDiagnostic(parameter, 1 /* Parameter */, createDiagnosticForNode(name, Diagnostics._0_is_declared_but_its_value_is_never_read, symbolName(local)));
-                  }
-                }
-              } else {
-                errorUnusedLocal(declaration, symbolName(local), addDiagnostic);
-              }
-            }
-          }
-        }
-      });
-      unusedImports.forEach(([importClause, unuseds]) => {
-        const importDecl = importClause.parent;
-        const nDeclarations = (importClause.name ? 1 : 0) + (importClause.namedBindings ? importClause.namedBindings.kind === 273 /* NamespaceImport */ ? 1 : importClause.namedBindings.elements.length : 0);
-        if (nDeclarations === unuseds.length) {
-          addDiagnostic(importDecl, 0 /* Local */, unuseds.length === 1 ? createDiagnosticForNode(importDecl, Diagnostics._0_is_declared_but_its_value_is_never_read, idText(first(unuseds).name)) : createDiagnosticForNode(importDecl, Diagnostics.All_imports_in_import_declaration_are_unused));
-        } else {
-          for (const unused of unuseds)
-            errorUnusedLocal(unused, idText(unused.name), addDiagnostic);
-        }
-      });
-      unusedDestructures.forEach(([bindingPattern, bindingElements]) => {
-        const kind = tryGetRootParameterDeclaration(bindingPattern.parent) ? 1 /* Parameter */ : 0 /* Local */;
-        if (bindingPattern.elements.length === bindingElements.length) {
-          if (bindingElements.length === 1 && bindingPattern.parent.kind === 259 /* VariableDeclaration */ && bindingPattern.parent.parent.kind === 260 /* VariableDeclarationList */) {
-            addToGroup(unusedVariables, bindingPattern.parent.parent, bindingPattern.parent, getNodeId);
-          } else {
-            addDiagnostic(bindingPattern, kind, bindingElements.length === 1 ? createDiagnosticForNode(bindingPattern, Diagnostics._0_is_declared_but_its_value_is_never_read, bindingNameText(first(bindingElements).name)) : createDiagnosticForNode(bindingPattern, Diagnostics.All_destructured_elements_are_unused));
-          }
-        } else {
-          for (const e of bindingElements) {
-            addDiagnostic(e, kind, createDiagnosticForNode(e, Diagnostics._0_is_declared_but_its_value_is_never_read, bindingNameText(e.name)));
-          }
-        }
-      });
-      unusedVariables.forEach(([declarationList, declarations]) => {
-        if (declarationList.declarations.length === declarations.length) {
-          addDiagnostic(declarationList, 0 /* Local */, declarations.length === 1 ? createDiagnosticForNode(first(declarations).name, Diagnostics._0_is_declared_but_its_value_is_never_read, bindingNameText(first(declarations).name)) : createDiagnosticForNode(declarationList.parent.kind === 242 /* VariableStatement */ ? declarationList.parent : declarationList, Diagnostics.All_variables_are_unused));
-        } else {
-          for (const decl of declarations) {
-            addDiagnostic(decl, 0 /* Local */, createDiagnosticForNode(decl, Diagnostics._0_is_declared_but_its_value_is_never_read, bindingNameText(decl.name)));
-          }
-        }
-      });
-    }
-    function checkPotentialUncheckedRenamedBindingElementsInTypes() {
-      var _a;
-      for (const node of potentialUnusedRenamedBindingElementsInTypes) {
-        if (!((_a = getSymbolOfDeclaration(node)) == null ? void 0 : _a.isReferenced)) {
-          const wrappingDeclaration = walkUpBindingElementsAndPatterns(node);
-          Debug.assert(isParameterDeclaration(wrappingDeclaration), "Only parameter declaration should be checked here");
-          const diagnostic = createDiagnosticForNode(node.name, Diagnostics._0_is_an_unused_renaming_of_1_Did_you_intend_to_use_it_as_a_type_annotation, declarationNameToString(node.name), declarationNameToString(node.propertyName));
-          if (!wrappingDeclaration.type) {
-            addRelatedInfo(
-              diagnostic,
-              createFileDiagnostic(getSourceFileOfNode(wrappingDeclaration), wrappingDeclaration.end, 1, Diagnostics.We_can_only_write_a_type_for_0_by_adding_a_type_for_the_entire_parameter_here, declarationNameToString(node.propertyName))
-            );
-          }
-          diagnostics.add(diagnostic);
-        }
-      }
-    }
-    function bindingNameText(name) {
-      switch (name.kind) {
-        case 80 /* Identifier */:
-          return idText(name);
-        case 206 /* ArrayBindingPattern */:
-        case 205 /* ObjectBindingPattern */:
-          return bindingNameText(cast(first(name.elements), isBindingElement).name);
-        default:
-          return Debug.assertNever(name);
-      }
-    }
-    function isImportedDeclaration(node) {
-      return node.kind === 272 /* ImportClause */ || node.kind === 275 /* ImportSpecifier */ || node.kind === 273 /* NamespaceImport */;
-    }
-    function importClauseFromImported(decl) {
-      return decl.kind === 272 /* ImportClause */ ? decl : decl.kind === 273 /* NamespaceImport */ ? decl.parent : decl.parent.parent;
-    }
-    function checkBlock(node) {
-      if (node.kind === 240 /* Block */) {
-        checkGrammarStatementInAmbientContext(node);
-      }
-      if (isFunctionOrModuleBlock(node)) {
-        const saveFlowAnalysisDisabled = flowAnalysisDisabled;
-        forEach(node.statements, checkSourceElement);
-        flowAnalysisDisabled = saveFlowAnalysisDisabled;
-      } else {
-        forEach(node.statements, checkSourceElement);
-      }
-      if (node.locals) {
-        registerForUnusedIdentifiersCheck(node);
-      }
-    }
-    function checkCollisionWithArgumentsInGeneratedCode(node) {
-      if (languageVersion >= 2 /* ES2015 */ || !hasRestParameter(node) || node.flags & 16777216 /* Ambient */ || nodeIsMissing(node.body)) {
-        return;
-      }
-      forEach(node.parameters, (p) => {
-        if (p.name && !isBindingPattern(p.name) && p.name.escapedText === argumentsSymbol.escapedName) {
-          errorSkippedOn("noEmit", p, Diagnostics.Duplicate_identifier_arguments_Compiler_uses_arguments_to_initialize_rest_parameters);
-        }
-      });
-    }
-    function needCollisionCheckForIdentifier(node, identifier, name) {
-      if ((identifier == null ? void 0 : identifier.escapedText) !== name) {
-        return false;
-      }
-      if (node.kind === 171 /* PropertyDeclaration */ || node.kind === 170 /* PropertySignature */ || node.kind === 173 /* MethodDeclaration */ || node.kind === 172 /* MethodSignature */ || node.kind === 176 /* GetAccessor */ || node.kind === 177 /* SetAccessor */ || node.kind === 302 /* PropertyAssignment */) {
-        return false;
-      }
-      if (node.flags & 16777216 /* Ambient */) {
-        return false;
-      }
-      if (isImportClause(node) || isImportEqualsDeclaration(node) || isImportSpecifier(node)) {
-        if (isTypeOnlyImportOrExportDeclaration(node)) {
-          return false;
-        }
-      }
-      const root = getRootDeclaration(node);
-      if (isParameter(root) && nodeIsMissing(root.parent.body)) {
-        return false;
-      }
-      return true;
-    }
-    function checkIfThisIsCapturedInEnclosingScope(node) {
-      findAncestor(node, (current) => {
-        if (getNodeCheckFlags(current) & 4 /* CaptureThis */) {
-          const isDeclaration2 = node.kind !== 80 /* Identifier */;
-          if (isDeclaration2) {
-            error(getNameOfDeclaration(node), Diagnostics.Duplicate_identifier_this_Compiler_uses_variable_declaration_this_to_capture_this_reference);
-          } else {
-            error(node, Diagnostics.Expression_resolves_to_variable_declaration_this_that_compiler_uses_to_capture_this_reference);
-          }
-          return true;
-        }
-        return false;
-      });
-    }
-    function checkIfNewTargetIsCapturedInEnclosingScope(node) {
-      findAncestor(node, (current) => {
-        if (getNodeCheckFlags(current) & 8 /* CaptureNewTarget */) {
-          const isDeclaration2 = node.kind !== 80 /* Identifier */;
-          if (isDeclaration2) {
-            error(getNameOfDeclaration(node), Diagnostics.Duplicate_identifier_newTarget_Compiler_uses_variable_declaration_newTarget_to_capture_new_target_meta_property_reference);
-          } else {
-            error(node, Diagnostics.Expression_resolves_to_variable_declaration_newTarget_that_compiler_uses_to_capture_new_target_meta_property_reference);
-          }
-          return true;
-        }
-        return false;
-      });
-    }
-    function checkCollisionWithRequireExportsInGeneratedCode(node, name) {
-      if (moduleKind >= 5 /* ES2015 */ && !(moduleKind >= 100 /* Node16 */ && getSourceFileOfNode(node).impliedNodeFormat === 1 /* CommonJS */)) {
-        return;
-      }
-      if (!name || !needCollisionCheckForIdentifier(node, name, "require") && !needCollisionCheckForIdentifier(node, name, "exports")) {
-        return;
-      }
-      if (isModuleDeclaration(node) && getModuleInstanceState(node) !== 1 /* Instantiated */) {
-        return;
-      }
-      const parent2 = getDeclarationContainer(node);
-      if (parent2.kind === 311 /* SourceFile */ && isExternalOrCommonJsModule(parent2)) {
-        errorSkippedOn(
-          "noEmit",
-          name,
-          Diagnostics.Duplicate_identifier_0_Compiler_reserves_name_1_in_top_level_scope_of_a_module,
-          declarationNameToString(name),
-          declarationNameToString(name)
-        );
-      }
-    }
-    function checkCollisionWithGlobalPromiseInGeneratedCode(node, name) {
-      if (!name || languageVersion >= 4 /* ES2017 */ || !needCollisionCheckForIdentifier(node, name, "Promise")) {
-        return;
-      }
-      if (isModuleDeclaration(node) && getModuleInstanceState(node) !== 1 /* Instantiated */) {
-        return;
-      }
-      const parent2 = getDeclarationContainer(node);
-      if (parent2.kind === 311 /* SourceFile */ && isExternalOrCommonJsModule(parent2) && parent2.flags & 2048 /* HasAsyncFunctions */) {
-        errorSkippedOn(
-          "noEmit",
-          name,
-          Diagnostics.Duplicate_identifier_0_Compiler_reserves_name_1_in_top_level_scope_of_a_module_containing_async_functions,
-          declarationNameToString(name),
-          declarationNameToString(name)
-        );
-      }
-    }
-    function recordPotentialCollisionWithWeakMapSetInGeneratedCode(node, name) {
-      if (languageVersion <= 8 /* ES2021 */ && (needCollisionCheckForIdentifier(node, name, "WeakMap") || needCollisionCheckForIdentifier(node, name, "WeakSet"))) {
-        potentialWeakMapSetCollisions.push(node);
-      }
-    }
-    function checkWeakMapSetCollision(node) {
-      const enclosingBlockScope = getEnclosingBlockScopeContainer(node);
-      if (getNodeCheckFlags(enclosingBlockScope) & 4194304 /* ContainsClassWithPrivateIdentifiers */) {
-        Debug.assert(isNamedDeclaration(node) && isIdentifier(node.name) && typeof node.name.escapedText === "string", "The target of a WeakMap/WeakSet collision check should be an identifier");
-        errorSkippedOn("noEmit", node, Diagnostics.Compiler_reserves_name_0_when_emitting_private_identifier_downlevel, node.name.escapedText);
-      }
-    }
-    function recordPotentialCollisionWithReflectInGeneratedCode(node, name) {
-      if (name && languageVersion >= 2 /* ES2015 */ && languageVersion <= 8 /* ES2021 */ && needCollisionCheckForIdentifier(node, name, "Reflect")) {
-        potentialReflectCollisions.push(node);
-      }
-    }
-    function checkReflectCollision(node) {
-      let hasCollision = false;
-      if (isClassExpression(node)) {
-        for (const member of node.members) {
-          if (getNodeCheckFlags(member) & 8388608 /* ContainsSuperPropertyInStaticInitializer */) {
-            hasCollision = true;
-            break;
-          }
-        }
-      } else if (isFunctionExpression(node)) {
-        if (getNodeCheckFlags(node) & 8388608 /* ContainsSuperPropertyInStaticInitializer */) {
-          hasCollision = true;
-        }
-      } else {
-        const container = getEnclosingBlockScopeContainer(node);
-        if (container && getNodeCheckFlags(container) & 8388608 /* ContainsSuperPropertyInStaticInitializer */) {
-          hasCollision = true;
-        }
-      }
-      if (hasCollision) {
-        Debug.assert(isNamedDeclaration(node) && isIdentifier(node.name), "The target of a Reflect collision check should be an identifier");
-        errorSkippedOn(
-          "noEmit",
-          node,
-          Diagnostics.Duplicate_identifier_0_Compiler_reserves_name_1_when_emitting_super_references_in_static_initializers,
-          declarationNameToString(node.name),
-          "Reflect"
-        );
-      }
-    }
-    function checkCollisionsForDeclarationName(node, name) {
-      if (!name)
-        return;
-      checkCollisionWithRequireExportsInGeneratedCode(node, name);
-      checkCollisionWithGlobalPromiseInGeneratedCode(node, name);
-      recordPotentialCollisionWithWeakMapSetInGeneratedCode(node, name);
-      recordPotentialCollisionWithReflectInGeneratedCode(node, name);
-      if (isClassLike(node)) {
-        checkTypeNameIsReserved(name, Diagnostics.Class_name_cannot_be_0);
-        if (!(node.flags & 16777216 /* Ambient */)) {
-          checkClassNameCollisionWithObject(name);
-        }
-      } else if (isEnumDeclaration(node)) {
-        checkTypeNameIsReserved(name, Diagnostics.Enum_name_cannot_be_0);
-      }
-    }
-    function checkVarDeclaredNamesNotShadowed(node) {
-      if ((getCombinedNodeFlags(node) & 3 /* BlockScoped */) !== 0 || isParameterDeclaration(node)) {
-        return;
-      }
-      if (node.kind === 259 /* VariableDeclaration */ && !node.initializer) {
-        return;
-      }
-      const symbol = getSymbolOfDeclaration(node);
-      if (symbol.flags & 1 /* FunctionScopedVariable */) {
-        if (!isIdentifier(node.name))
-          return Debug.fail();
-        const localDeclarationSymbol = resolveName(
-          node,
-          node.name.escapedText,
-          3 /* Variable */,
-          /*nameNotFoundMessage*/
-          void 0,
-          /*nameArg*/
-          void 0,
-          /*isUse*/
-          false
-        );
-        if (localDeclarationSymbol && localDeclarationSymbol !== symbol && localDeclarationSymbol.flags & 2 /* BlockScopedVariable */) {
-          if (getDeclarationNodeFlagsFromSymbol(localDeclarationSymbol) & 3 /* BlockScoped */) {
-            const varDeclList = getAncestor(localDeclarationSymbol.valueDeclaration, 260 /* VariableDeclarationList */);
-            const container = varDeclList.parent.kind === 242 /* VariableStatement */ && varDeclList.parent.parent ? varDeclList.parent.parent : void 0;
-            const namesShareScope = container && (container.kind === 240 /* Block */ && isFunctionLike(container.parent) || container.kind === 267 /* ModuleBlock */ || container.kind === 266 /* ModuleDeclaration */ || container.kind === 311 /* SourceFile */);
-            if (!namesShareScope) {
-              const name = symbolToString(localDeclarationSymbol);
-              error(node, Diagnostics.Cannot_initialize_outer_scoped_variable_0_in_the_same_scope_as_block_scoped_declaration_1, name, name);
-            }
-          }
-        }
-      }
-    }
-    function convertAutoToAny(type) {
-      return type === autoType ? anyType : type === autoArrayType ? anyArrayType : type;
-    }
-    function checkVariableLikeDeclaration(node) {
-      var _a;
-      checkDecorators(node);
-      if (!isBindingElement(node)) {
-        checkSourceElement(node.type);
-      }
-      if (!node.name) {
-        return;
-      }
-      if (node.name.kind === 166 /* ComputedPropertyName */) {
-        checkComputedPropertyName(node.name);
-        if (hasOnlyExpressionInitializer(node) && node.initializer) {
-          checkExpressionCached(node.initializer);
-        }
-      }
-      if (isBindingElement(node)) {
-        if (node.propertyName && isIdentifier(node.name) && isParameterDeclaration(node) && nodeIsMissing(getContainingFunction(node).body)) {
-          potentialUnusedRenamedBindingElementsInTypes.push(node);
-          return;
-        }
-        if (isObjectBindingPattern(node.parent) && node.dotDotDotToken && languageVersion < 5 /* ES2018 */) {
-          checkExternalEmitHelpers(node, 4 /* Rest */);
-        }
-        if (node.propertyName && node.propertyName.kind === 166 /* ComputedPropertyName */) {
-          checkComputedPropertyName(node.propertyName);
-        }
-        const parent2 = node.parent.parent;
-        const parentCheckMode = node.dotDotDotToken ? 64 /* RestBindingElement */ : 0 /* Normal */;
-        const parentType = getTypeForBindingElementParent(parent2, parentCheckMode);
-        const name = node.propertyName || node.name;
-        if (parentType && !isBindingPattern(name)) {
-          const exprType = getLiteralTypeFromPropertyName(name);
-          if (isTypeUsableAsPropertyName(exprType)) {
-            const nameText = getPropertyNameFromType(exprType);
-            const property = getPropertyOfType(parentType, nameText);
-            if (property) {
-              markPropertyAsReferenced(
-                property,
-                /*nodeForCheckWriteOnly*/
-                void 0,
-                /*isSelfTypeAccess*/
-                false
-              );
-              checkPropertyAccessibility(
-                node,
-                !!parent2.initializer && parent2.initializer.kind === 108 /* SuperKeyword */,
-                /*writing*/
-                false,
-                parentType,
-                property
-              );
-            }
-          }
-        }
-      }
-      if (isBindingPattern(node.name)) {
-        if (node.name.kind === 206 /* ArrayBindingPattern */ && languageVersion < 2 /* ES2015 */ && compilerOptions.downlevelIteration) {
-          checkExternalEmitHelpers(node, 512 /* Read */);
-        }
-        forEach(node.name.elements, checkSourceElement);
-      }
-      if (isParameter(node) && node.initializer && nodeIsMissing(getContainingFunction(node).body)) {
-        error(node, Diagnostics.A_parameter_initializer_is_only_allowed_in_a_function_or_constructor_implementation);
-        return;
-      }
-      if (isBindingPattern(node.name)) {
-        if (isInAmbientOrTypeNode(node)) {
-          return;
-        }
-        const needCheckInitializer = hasOnlyExpressionInitializer(node) && node.initializer && node.parent.parent.kind !== 248 /* ForInStatement */;
-        const needCheckWidenedType = !some(node.name.elements, not(isOmittedExpression));
-        if (needCheckInitializer || needCheckWidenedType) {
-          const widenedType = getWidenedTypeForVariableLikeDeclaration(node);
-          if (needCheckInitializer) {
-            const initializerType = checkExpressionCached(node.initializer);
-            if (strictNullChecks && needCheckWidenedType) {
-              checkNonNullNonVoidType(initializerType, node);
-            } else {
-              checkTypeAssignableToAndOptionallyElaborate(initializerType, getWidenedTypeForVariableLikeDeclaration(node), node, node.initializer);
-            }
-          }
-          if (needCheckWidenedType) {
-            if (isArrayBindingPattern(node.name)) {
-              checkIteratedTypeOrElementType(65 /* Destructuring */, widenedType, undefinedType, node);
-            } else if (strictNullChecks) {
-              checkNonNullNonVoidType(widenedType, node);
-            }
-          }
-        }
-        return;
-      }
-      const symbol = getSymbolOfDeclaration(node);
-      if (symbol.flags & 2097152 /* Alias */ && (isVariableDeclarationInitializedToBareOrAccessedRequire(node) || isBindingElementOfBareOrAccessedRequire(node))) {
-        checkAliasSymbol(node);
-        return;
-      }
-      const type = convertAutoToAny(getTypeOfSymbol(symbol));
-      if (node === symbol.valueDeclaration) {
-        const initializer = hasOnlyExpressionInitializer(node) && getEffectiveInitializer(node);
-        if (initializer) {
-          const isJSObjectLiteralInitializer = isInJSFile(node) && isObjectLiteralExpression(initializer) && (initializer.properties.length === 0 || isPrototypeAccess(node.name)) && !!((_a = symbol.exports) == null ? void 0 : _a.size);
-          if (!isJSObjectLiteralInitializer && node.parent.parent.kind !== 248 /* ForInStatement */) {
-            checkTypeAssignableToAndOptionallyElaborate(
-              checkExpressionCached(initializer),
-              type,
-              node,
-              initializer,
-              /*headMessage*/
-              void 0
-            );
-          }
-        }
-        if (symbol.declarations && symbol.declarations.length > 1) {
-          if (some(symbol.declarations, (d) => d !== node && isVariableLike(d) && !areDeclarationFlagsIdentical(d, node))) {
-            error(node.name, Diagnostics.All_declarations_of_0_must_have_identical_modifiers, declarationNameToString(node.name));
-          }
-        }
-      } else {
-        const declarationType = convertAutoToAny(getWidenedTypeForVariableLikeDeclaration(node));
-        if (!isErrorType(type) && !isErrorType(declarationType) && !isTypeIdenticalTo(type, declarationType) && !(symbol.flags & 67108864 /* Assignment */)) {
-          errorNextVariableOrPropertyDeclarationMustHaveSameType(symbol.valueDeclaration, type, node, declarationType);
-        }
-        if (hasOnlyExpressionInitializer(node) && node.initializer) {
-          checkTypeAssignableToAndOptionallyElaborate(
-            checkExpressionCached(node.initializer),
-            declarationType,
-            node,
-            node.initializer,
-            /*headMessage*/
-            void 0
-          );
-        }
-        if (symbol.valueDeclaration && !areDeclarationFlagsIdentical(node, symbol.valueDeclaration)) {
-          error(node.name, Diagnostics.All_declarations_of_0_must_have_identical_modifiers, declarationNameToString(node.name));
-        }
-      }
-      if (node.kind !== 171 /* PropertyDeclaration */ && node.kind !== 170 /* PropertySignature */) {
-        checkExportsOnMergedDeclarations(node);
-        if (node.kind === 259 /* VariableDeclaration */ || node.kind === 207 /* BindingElement */) {
-          checkVarDeclaredNamesNotShadowed(node);
-        }
-        checkCollisionsForDeclarationName(node, node.name);
-      }
-    }
-    function errorNextVariableOrPropertyDeclarationMustHaveSameType(firstDeclaration, firstType, nextDeclaration, nextType) {
-      const nextDeclarationName = getNameOfDeclaration(nextDeclaration);
-      const message = nextDeclaration.kind === 171 /* PropertyDeclaration */ || nextDeclaration.kind === 170 /* PropertySignature */ ? Diagnostics.Subsequent_property_declarations_must_have_the_same_type_Property_0_must_be_of_type_1_but_here_has_type_2 : Diagnostics.Subsequent_variable_declarations_must_have_the_same_type_Variable_0_must_be_of_type_1_but_here_has_type_2;
-      const declName = declarationNameToString(nextDeclarationName);
-      const err = error(
-        nextDeclarationName,
-        message,
-        declName,
-        typeToString(firstType),
-        typeToString(nextType)
-      );
-      if (firstDeclaration) {
-        addRelatedInfo(
-          err,
-          createDiagnosticForNode(firstDeclaration, Diagnostics._0_was_also_declared_here, declName)
-        );
-      }
-    }
-    function areDeclarationFlagsIdentical(left, right) {
-      if (left.kind === 168 /* Parameter */ && right.kind === 259 /* VariableDeclaration */ || left.kind === 259 /* VariableDeclaration */ && right.kind === 168 /* Parameter */) {
-        return true;
-      }
-      if (hasQuestionToken(left) !== hasQuestionToken(right)) {
-        return false;
-      }
-      const interestingFlags = 8 /* Private */ | 16 /* Protected */ | 512 /* Async */ | 256 /* Abstract */ | 64 /* Readonly */ | 32 /* Static */;
-      return getSelectedEffectiveModifierFlags(left, interestingFlags) === getSelectedEffectiveModifierFlags(right, interestingFlags);
-    }
-    function checkVariableDeclaration(node) {
-      var _a, _b;
-      (_a = tracing) == null ? void 0 : _a.push(tracing.Phase.Check, "checkVariableDeclaration", { kind: node.kind, pos: node.pos, end: node.end, path: node.tracingPath });
-      checkGrammarVariableDeclaration(node);
-      checkVariableLikeDeclaration(node);
-      (_b = tracing) == null ? void 0 : _b.pop();
-    }
-    function checkBindingElement(node) {
-      checkGrammarBindingElement(node);
-      return checkVariableLikeDeclaration(node);
-    }
-    function checkVariableStatement(node) {
-      if (!checkGrammarModifiers(node) && !checkGrammarVariableDeclarationList(node.declarationList))
-        checkGrammarForDisallowedLetOrConstStatement(node);
-      forEach(node.declarationList.declarations, checkSourceElement);
-    }
-    function checkExpressionStatement(node) {
-      checkGrammarStatementInAmbientContext(node);
-      checkExpression(node.expression);
-    }
-    function checkIfStatement(node) {
-      checkGrammarStatementInAmbientContext(node);
-      const type = checkTruthinessExpression(node.expression);
-      checkTestingKnownTruthyCallableOrAwaitableType(node.expression, type, node.thenStatement);
-      checkSourceElement(node.thenStatement);
-      if (node.thenStatement.kind === 241 /* EmptyStatement */) {
-        error(node.thenStatement, Diagnostics.The_body_of_an_if_statement_cannot_be_the_empty_statement);
-      }
-      checkSourceElement(node.elseStatement);
-    }
-    function checkTestingKnownTruthyCallableOrAwaitableType(condExpr, condType, body) {
-      if (!strictNullChecks)
-        return;
-      bothHelper(condExpr, body);
-      function bothHelper(condExpr2, body2) {
-        condExpr2 = skipParentheses(condExpr2);
-        helper(condExpr2, body2);
-        while (isBinaryExpression(condExpr2) && (condExpr2.operatorToken.kind === 57 /* BarBarToken */ || condExpr2.operatorToken.kind === 61 /* QuestionQuestionToken */)) {
-          condExpr2 = skipParentheses(condExpr2.left);
-          helper(condExpr2, body2);
-        }
-      }
-      function helper(condExpr2, body2) {
-        const location = isLogicalOrCoalescingBinaryExpression(condExpr2) ? skipParentheses(condExpr2.right) : condExpr2;
-        if (isModuleExportsAccessExpression(location)) {
-          return;
-        }
-        if (isLogicalOrCoalescingBinaryExpression(location)) {
-          bothHelper(location, body2);
-          return;
-        }
-        const type = location === condExpr2 ? condType : checkTruthinessExpression(location);
-        const isPropertyExpressionCast = isPropertyAccessExpression(location) && isTypeAssertion(location.expression);
-        if (!(getTypeFacts(type) & 4194304 /* Truthy */) || isPropertyExpressionCast)
-          return;
-        const callSignatures = getSignaturesOfType(type, 0 /* Call */);
-        const isPromise = !!getAwaitedTypeOfPromise(type);
-        if (callSignatures.length === 0 && !isPromise) {
-          return;
-        }
-        const testedNode = isIdentifier(location) ? location : isPropertyAccessExpression(location) ? location.name : void 0;
-        const testedSymbol = testedNode && getSymbolAtLocation(testedNode);
-        if (!testedSymbol && !isPromise) {
-          return;
-        }
-        const isUsed = testedSymbol && isBinaryExpression(condExpr2.parent) && isSymbolUsedInBinaryExpressionChain(condExpr2.parent, testedSymbol) || testedSymbol && body2 && isSymbolUsedInConditionBody(condExpr2, body2, testedNode, testedSymbol);
-        if (!isUsed) {
-          if (isPromise) {
-            errorAndMaybeSuggestAwait(
-              location,
-              /*maybeMissingAwait*/
-              true,
-              Diagnostics.This_condition_will_always_return_true_since_this_0_is_always_defined,
-              getTypeNameForErrorDisplay(type)
-            );
-          } else {
-            error(location, Diagnostics.This_condition_will_always_return_true_since_this_function_is_always_defined_Did_you_mean_to_call_it_instead);
-          }
-        }
-      }
-    }
-    function isSymbolUsedInConditionBody(expr, body, testedNode, testedSymbol) {
-      return !!forEachChild(body, function check(childNode) {
-        if (isIdentifier(childNode)) {
-          const childSymbol = getSymbolAtLocation(childNode);
-          if (childSymbol && childSymbol === testedSymbol) {
-            if (isIdentifier(expr) || isIdentifier(testedNode) && isBinaryExpression(testedNode.parent)) {
-              return true;
-            }
-            let testedExpression = testedNode.parent;
-            let childExpression = childNode.parent;
-            while (testedExpression && childExpression) {
-              if (isIdentifier(testedExpression) && isIdentifier(childExpression) || testedExpression.kind === 110 /* ThisKeyword */ && childExpression.kind === 110 /* ThisKeyword */) {
-                return getSymbolAtLocation(testedExpression) === getSymbolAtLocation(childExpression);
-              } else if (isPropertyAccessExpression(testedExpression) && isPropertyAccessExpression(childExpression)) {
-                if (getSymbolAtLocation(testedExpression.name) !== getSymbolAtLocation(childExpression.name)) {
-                  return false;
-                }
-                childExpression = childExpression.expression;
-                testedExpression = testedExpression.expression;
-              } else if (isCallExpression(testedExpression) && isCallExpression(childExpression)) {
-                childExpression = childExpression.expression;
-                testedExpression = testedExpression.expression;
-              } else {
-                return false;
-              }
-            }
-          }
-        }
-        return forEachChild(childNode, check);
-      });
-    }
-    function isSymbolUsedInBinaryExpressionChain(node, testedSymbol) {
-      while (isBinaryExpression(node) && node.operatorToken.kind === 56 /* AmpersandAmpersandToken */) {
-        const isUsed = forEachChild(node.right, function visit(child) {
-          if (isIdentifier(child)) {
-            const symbol = getSymbolAtLocation(child);
-            if (symbol && symbol === testedSymbol) {
-              return true;
-            }
-          }
-          return forEachChild(child, visit);
-        });
-        if (isUsed) {
-          return true;
-        }
-        node = node.parent;
-      }
-      return false;
-    }
-    function checkDoStatement(node) {
-      checkGrammarStatementInAmbientContext(node);
-      checkSourceElement(node.statement);
-      checkTruthinessExpression(node.expression);
-    }
-    function checkWhileStatement(node) {
-      checkGrammarStatementInAmbientContext(node);
-      checkTruthinessExpression(node.expression);
-      checkSourceElement(node.statement);
-    }
-    function checkTruthinessOfType(type, node) {
-      if (type.flags & 16384 /* Void */) {
-        error(node, Diagnostics.An_expression_of_type_void_cannot_be_tested_for_truthiness);
-      }
-      return type;
-    }
-    function checkTruthinessExpression(node, checkMode) {
-      return checkTruthinessOfType(checkExpression(node, checkMode), node);
-    }
-    function checkForStatement(node) {
-      if (!checkGrammarStatementInAmbientContext(node)) {
-        if (node.initializer && node.initializer.kind === 260 /* VariableDeclarationList */) {
-          checkGrammarVariableDeclarationList(node.initializer);
-        }
-      }
-      if (node.initializer) {
-        if (node.initializer.kind === 260 /* VariableDeclarationList */) {
-          forEach(node.initializer.declarations, checkVariableDeclaration);
-        } else {
-          checkExpression(node.initializer);
-        }
-      }
-      if (node.condition)
-        checkTruthinessExpression(node.condition);
-      if (node.incrementor)
-        checkExpression(node.incrementor);
-      checkSourceElement(node.statement);
-      if (node.locals) {
-        registerForUnusedIdentifiersCheck(node);
-      }
-    }
-    function checkForOfStatement(node) {
-      checkGrammarForInOrForOfStatement(node);
-      const container = getContainingFunctionOrClassStaticBlock(node);
-      if (node.awaitModifier) {
-        if (container && isClassStaticBlockDeclaration(container)) {
-          grammarErrorOnNode(node.awaitModifier, Diagnostics.For_await_loops_cannot_be_used_inside_a_class_static_block);
-        } else {
-          const functionFlags = getFunctionFlags(container);
-          if ((functionFlags & (4 /* Invalid */ | 2 /* Async */)) === 2 /* Async */ && languageVersion < 99 /* ESNext */) {
-            checkExternalEmitHelpers(node, 16384 /* ForAwaitOfIncludes */);
-          }
-        }
-      } else if (compilerOptions.downlevelIteration && languageVersion < 2 /* ES2015 */) {
-        checkExternalEmitHelpers(node, 256 /* ForOfIncludes */);
-      }
-      if (node.initializer.kind === 260 /* VariableDeclarationList */) {
-        checkForInOrForOfVariableDeclaration(node);
-      } else {
-        const varExpr = node.initializer;
-        const iteratedType = checkRightHandSideOfForOf(node);
-        if (varExpr.kind === 208 /* ArrayLiteralExpression */ || varExpr.kind === 209 /* ObjectLiteralExpression */) {
-          checkDestructuringAssignment(varExpr, iteratedType || errorType);
-        } else {
-          const leftType = checkExpression(varExpr);
-          checkReferenceExpression(
-            varExpr,
-            Diagnostics.The_left_hand_side_of_a_for_of_statement_must_be_a_variable_or_a_property_access,
-            Diagnostics.The_left_hand_side_of_a_for_of_statement_may_not_be_an_optional_property_access
-          );
-          if (iteratedType) {
-            checkTypeAssignableToAndOptionallyElaborate(iteratedType, leftType, varExpr, node.expression);
-          }
-        }
-      }
-      checkSourceElement(node.statement);
-      if (node.locals) {
-        registerForUnusedIdentifiersCheck(node);
-      }
-    }
-    function checkForInStatement(node) {
-      checkGrammarForInOrForOfStatement(node);
-      const rightType = getNonNullableTypeIfNeeded(checkExpression(node.expression));
-      if (node.initializer.kind === 260 /* VariableDeclarationList */) {
-        const variable = node.initializer.declarations[0];
-        if (variable && isBindingPattern(variable.name)) {
-          error(variable.name, Diagnostics.The_left_hand_side_of_a_for_in_statement_cannot_be_a_destructuring_pattern);
-        }
-        checkForInOrForOfVariableDeclaration(node);
-      } else {
-        const varExpr = node.initializer;
-        const leftType = checkExpression(varExpr);
-        if (varExpr.kind === 208 /* ArrayLiteralExpression */ || varExpr.kind === 209 /* ObjectLiteralExpression */) {
-          error(varExpr, Diagnostics.The_left_hand_side_of_a_for_in_statement_cannot_be_a_destructuring_pattern);
-        } else if (!isTypeAssignableTo(getIndexTypeOrString(rightType), leftType)) {
-          error(varExpr, Diagnostics.The_left_hand_side_of_a_for_in_statement_must_be_of_type_string_or_any);
-        } else {
-          checkReferenceExpression(
-            varExpr,
-            Diagnostics.The_left_hand_side_of_a_for_in_statement_must_be_a_variable_or_a_property_access,
-            Diagnostics.The_left_hand_side_of_a_for_in_statement_may_not_be_an_optional_property_access
-          );
-        }
-      }
-      if (rightType === neverType || !isTypeAssignableToKind(rightType, 67108864 /* NonPrimitive */ | 58982400 /* InstantiableNonPrimitive */)) {
-        error(node.expression, Diagnostics.The_right_hand_side_of_a_for_in_statement_must_be_of_type_any_an_object_type_or_a_type_parameter_but_here_has_type_0, typeToString(rightType));
-      }
-      checkSourceElement(node.statement);
-      if (node.locals) {
-        registerForUnusedIdentifiersCheck(node);
-      }
-    }
-    function checkForInOrForOfVariableDeclaration(iterationStatement) {
-      const variableDeclarationList = iterationStatement.initializer;
-      if (variableDeclarationList.declarations.length >= 1) {
-        const decl = variableDeclarationList.declarations[0];
-        checkVariableDeclaration(decl);
-      }
-    }
-    function checkRightHandSideOfForOf(statement) {
-      const use = statement.awaitModifier ? 15 /* ForAwaitOf */ : 13 /* ForOf */;
-      return checkIteratedTypeOrElementType(use, checkNonNullExpression(statement.expression), undefinedType, statement.expression);
-    }
-    function checkIteratedTypeOrElementType(use, inputType, sentType, errorNode) {
-      if (isTypeAny(inputType)) {
-        return inputType;
-      }
-      return getIteratedTypeOrElementType(
-        use,
-        inputType,
-        sentType,
-        errorNode,
-        /*checkAssignability*/
-        true
-      ) || anyType;
-    }
-    function getIteratedTypeOrElementType(use, inputType, sentType, errorNode, checkAssignability) {
-      const allowAsyncIterables = (use & 2 /* AllowsAsyncIterablesFlag */) !== 0;
-      if (inputType === neverType) {
-        reportTypeNotIterableError(errorNode, inputType, allowAsyncIterables);
-        return void 0;
-      }
-      const uplevelIteration = languageVersion >= 2 /* ES2015 */;
-      const downlevelIteration = !uplevelIteration && compilerOptions.downlevelIteration;
-      const possibleOutOfBounds = compilerOptions.noUncheckedIndexedAccess && !!(use & 128 /* PossiblyOutOfBounds */);
-      if (uplevelIteration || downlevelIteration || allowAsyncIterables) {
-        const iterationTypes = getIterationTypesOfIterable(inputType, use, uplevelIteration ? errorNode : void 0);
-        if (checkAssignability) {
-          if (iterationTypes) {
-            const diagnostic = use & 8 /* ForOfFlag */ ? Diagnostics.Cannot_iterate_value_because_the_next_method_of_its_iterator_expects_type_1_but_for_of_will_always_send_0 : use & 32 /* SpreadFlag */ ? Diagnostics.Cannot_iterate_value_because_the_next_method_of_its_iterator_expects_type_1_but_array_spread_will_always_send_0 : use & 64 /* DestructuringFlag */ ? Diagnostics.Cannot_iterate_value_because_the_next_method_of_its_iterator_expects_type_1_but_array_destructuring_will_always_send_0 : use & 16 /* YieldStarFlag */ ? Diagnostics.Cannot_delegate_iteration_to_value_because_the_next_method_of_its_iterator_expects_type_1_but_the_containing_generator_will_always_send_0 : void 0;
-            if (diagnostic) {
-              checkTypeAssignableTo(sentType, iterationTypes.nextType, errorNode, diagnostic);
-            }
-          }
-        }
-        if (iterationTypes || uplevelIteration) {
-          return possibleOutOfBounds ? includeUndefinedInIndexSignature(iterationTypes && iterationTypes.yieldType) : iterationTypes && iterationTypes.yieldType;
-        }
-      }
-      let arrayType = inputType;
-      let reportedError = false;
-      let hasStringConstituent = false;
-      if (use & 4 /* AllowsStringInputFlag */) {
-        if (arrayType.flags & 1048576 /* Union */) {
-          const arrayTypes = inputType.types;
-          const filteredTypes = filter(arrayTypes, (t) => !(t.flags & 402653316 /* StringLike */));
-          if (filteredTypes !== arrayTypes) {
-            arrayType = getUnionType(filteredTypes, 2 /* Subtype */);
-          }
-        } else if (arrayType.flags & 402653316 /* StringLike */) {
-          arrayType = neverType;
-        }
-        hasStringConstituent = arrayType !== inputType;
-        if (hasStringConstituent) {
-          if (languageVersion < 1 /* ES5 */) {
-            if (errorNode) {
-              error(errorNode, Diagnostics.Using_a_string_in_a_for_of_statement_is_only_supported_in_ECMAScript_5_and_higher);
-              reportedError = true;
-            }
-          }
-          if (arrayType.flags & 131072 /* Never */) {
-            return possibleOutOfBounds ? includeUndefinedInIndexSignature(stringType) : stringType;
-          }
-        }
-      }
-      if (!isArrayLikeType(arrayType)) {
-        if (errorNode && !reportedError) {
-          const allowsStrings = !!(use & 4 /* AllowsStringInputFlag */) && !hasStringConstituent;
-          const [defaultDiagnostic, maybeMissingAwait] = getIterationDiagnosticDetails(allowsStrings, downlevelIteration);
-          errorAndMaybeSuggestAwait(
-            errorNode,
-            maybeMissingAwait && !!getAwaitedTypeOfPromise(arrayType),
-            defaultDiagnostic,
-            typeToString(arrayType)
-          );
-        }
-        return hasStringConstituent ? possibleOutOfBounds ? includeUndefinedInIndexSignature(stringType) : stringType : void 0;
-      }
-      const arrayElementType = getIndexTypeOfType(arrayType, numberType);
-      if (hasStringConstituent && arrayElementType) {
-        if (arrayElementType.flags & 402653316 /* StringLike */ && !compilerOptions.noUncheckedIndexedAccess) {
-          return stringType;
-        }
-        return getUnionType(possibleOutOfBounds ? [arrayElementType, stringType, undefinedType] : [arrayElementType, stringType], 2 /* Subtype */);
-      }
-      return use & 128 /* PossiblyOutOfBounds */ ? includeUndefinedInIndexSignature(arrayElementType) : arrayElementType;
-      function getIterationDiagnosticDetails(allowsStrings, downlevelIteration2) {
-        var _a;
-        if (downlevelIteration2) {
-          return allowsStrings ? [Diagnostics.Type_0_is_not_an_array_type_or_a_string_type_or_does_not_have_a_Symbol_iterator_method_that_returns_an_iterator, true] : [Diagnostics.Type_0_is_not_an_array_type_or_does_not_have_a_Symbol_iterator_method_that_returns_an_iterator, true];
-        }
-        const yieldType = getIterationTypeOfIterable(
-          use,
-          0 /* Yield */,
-          inputType,
-          /*errorNode*/
-          void 0
-        );
-        if (yieldType) {
-          return [Diagnostics.Type_0_can_only_be_iterated_through_when_using_the_downlevelIteration_flag_or_with_a_target_of_es2015_or_higher, false];
-        }
-        if (isES2015OrLaterIterable((_a = inputType.symbol) == null ? void 0 : _a.escapedName)) {
-          return [Diagnostics.Type_0_can_only_be_iterated_through_when_using_the_downlevelIteration_flag_or_with_a_target_of_es2015_or_higher, true];
-        }
-        return allowsStrings ? [Diagnostics.Type_0_is_not_an_array_type_or_a_string_type, true] : [Diagnostics.Type_0_is_not_an_array_type, true];
-      }
-    }
-    function isES2015OrLaterIterable(n) {
-      switch (n) {
-        case "Float32Array":
-        case "Float64Array":
-        case "Int16Array":
-        case "Int32Array":
-        case "Int8Array":
-        case "NodeList":
-        case "Uint16Array":
-        case "Uint32Array":
-        case "Uint8Array":
-        case "Uint8ClampedArray":
-          return true;
-      }
-      return false;
-    }
-    function getIterationTypeOfIterable(use, typeKind, inputType, errorNode) {
-      if (isTypeAny(inputType)) {
-        return void 0;
-      }
-      const iterationTypes = getIterationTypesOfIterable(inputType, use, errorNode);
-      return iterationTypes && iterationTypes[getIterationTypesKeyFromIterationTypeKind(typeKind)];
-    }
-    function createIterationTypes(yieldType = neverType, returnType = neverType, nextType = unknownType) {
-      if (yieldType.flags & 67359327 /* Intrinsic */ && returnType.flags & (1 /* Any */ | 131072 /* Never */ | 2 /* Unknown */ | 16384 /* Void */ | 32768 /* Undefined */) && nextType.flags & (1 /* Any */ | 131072 /* Never */ | 2 /* Unknown */ | 16384 /* Void */ | 32768 /* Undefined */)) {
-        const id = getTypeListId([yieldType, returnType, nextType]);
-        let iterationTypes = iterationTypesCache.get(id);
-        if (!iterationTypes) {
-          iterationTypes = { yieldType, returnType, nextType };
-          iterationTypesCache.set(id, iterationTypes);
-        }
-        return iterationTypes;
-      }
-      return { yieldType, returnType, nextType };
-    }
-    function combineIterationTypes(array) {
-      let yieldTypes;
-      let returnTypes;
-      let nextTypes;
-      for (const iterationTypes of array) {
-        if (iterationTypes === void 0 || iterationTypes === noIterationTypes) {
-          continue;
-        }
-        if (iterationTypes === anyIterationTypes) {
-          return anyIterationTypes;
-        }
-        yieldTypes = append(yieldTypes, iterationTypes.yieldType);
-        returnTypes = append(returnTypes, iterationTypes.returnType);
-        nextTypes = append(nextTypes, iterationTypes.nextType);
-      }
-      if (yieldTypes || returnTypes || nextTypes) {
-        return createIterationTypes(
-          yieldTypes && getUnionType(yieldTypes),
-          returnTypes && getUnionType(returnTypes),
-          nextTypes && getIntersectionType(nextTypes)
-        );
-      }
-      return noIterationTypes;
-    }
-    function getCachedIterationTypes(type, cacheKey) {
-      return type[cacheKey];
-    }
-    function setCachedIterationTypes(type, cacheKey, cachedTypes2) {
-      return type[cacheKey] = cachedTypes2;
-    }
-    function getIterationTypesOfIterable(type, use, errorNode) {
-      var _a, _b;
-      if (isTypeAny(type)) {
-        return anyIterationTypes;
-      }
-      if (!(type.flags & 1048576 /* Union */)) {
-        const errorOutputContainer = errorNode ? { errors: void 0 } : void 0;
-        const iterationTypes2 = getIterationTypesOfIterableWorker(type, use, errorNode, errorOutputContainer);
-        if (iterationTypes2 === noIterationTypes) {
-          if (errorNode) {
-            const rootDiag = reportTypeNotIterableError(errorNode, type, !!(use & 2 /* AllowsAsyncIterablesFlag */));
-            if (errorOutputContainer == null ? void 0 : errorOutputContainer.errors) {
-              addRelatedInfo(rootDiag, ...errorOutputContainer.errors);
-            }
-          }
-          return void 0;
-        } else if ((_a = errorOutputContainer == null ? void 0 : errorOutputContainer.errors) == null ? void 0 : _a.length) {
-          for (const diag2 of errorOutputContainer.errors) {
-            diagnostics.add(diag2);
-          }
-        }
-        return iterationTypes2;
-      }
-      const cacheKey = use & 2 /* AllowsAsyncIterablesFlag */ ? "iterationTypesOfAsyncIterable" : "iterationTypesOfIterable";
-      const cachedTypes2 = getCachedIterationTypes(type, cacheKey);
-      if (cachedTypes2)
-        return cachedTypes2 === noIterationTypes ? void 0 : cachedTypes2;
-      let allIterationTypes;
-      for (const constituent of type.types) {
-        const errorOutputContainer = errorNode ? { errors: void 0 } : void 0;
-        const iterationTypes2 = getIterationTypesOfIterableWorker(constituent, use, errorNode, errorOutputContainer);
-        if (iterationTypes2 === noIterationTypes) {
-          if (errorNode) {
-            const rootDiag = reportTypeNotIterableError(errorNode, type, !!(use & 2 /* AllowsAsyncIterablesFlag */));
-            if (errorOutputContainer == null ? void 0 : errorOutputContainer.errors) {
-              addRelatedInfo(rootDiag, ...errorOutputContainer.errors);
-            }
-          }
-          setCachedIterationTypes(type, cacheKey, noIterationTypes);
-          return void 0;
-        } else if ((_b = errorOutputContainer == null ? void 0 : errorOutputContainer.errors) == null ? void 0 : _b.length) {
-          for (const diag2 of errorOutputContainer.errors) {
-            diagnostics.add(diag2);
-          }
-        }
-        allIterationTypes = append(allIterationTypes, iterationTypes2);
-      }
-      const iterationTypes = allIterationTypes ? combineIterationTypes(allIterationTypes) : noIterationTypes;
-      setCachedIterationTypes(type, cacheKey, iterationTypes);
-      return iterationTypes === noIterationTypes ? void 0 : iterationTypes;
-    }
-    function getAsyncFromSyncIterationTypes(iterationTypes, errorNode) {
-      if (iterationTypes === noIterationTypes)
-        return noIterationTypes;
-      if (iterationTypes === anyIterationTypes)
-        return anyIterationTypes;
-      const { yieldType, returnType, nextType } = iterationTypes;
-      if (errorNode) {
-        getGlobalAwaitedSymbol(
-          /*reportErrors*/
-          true
-        );
-      }
-      return createIterationTypes(
-        getAwaitedType(yieldType, errorNode) || anyType,
-        getAwaitedType(returnType, errorNode) || anyType,
-        nextType
-      );
-    }
-    function getIterationTypesOfIterableWorker(type, use, errorNode, errorOutputContainer) {
-      if (isTypeAny(type)) {
-        return anyIterationTypes;
-      }
-      let noCache = false;
-      if (use & 2 /* AllowsAsyncIterablesFlag */) {
-        const iterationTypes = getIterationTypesOfIterableCached(type, asyncIterationTypesResolver) || getIterationTypesOfIterableFast(type, asyncIterationTypesResolver);
-        if (iterationTypes) {
-          if (iterationTypes === noIterationTypes && errorNode) {
-            noCache = true;
-          } else {
-            return use & 8 /* ForOfFlag */ ? getAsyncFromSyncIterationTypes(iterationTypes, errorNode) : iterationTypes;
-          }
-        }
-      }
-      if (use & 1 /* AllowsSyncIterablesFlag */) {
-        let iterationTypes = getIterationTypesOfIterableCached(type, syncIterationTypesResolver) || getIterationTypesOfIterableFast(type, syncIterationTypesResolver);
-        if (iterationTypes) {
-          if (iterationTypes === noIterationTypes && errorNode) {
-            noCache = true;
-          } else {
-            if (use & 2 /* AllowsAsyncIterablesFlag */) {
-              if (iterationTypes !== noIterationTypes) {
-                iterationTypes = getAsyncFromSyncIterationTypes(iterationTypes, errorNode);
-                return noCache ? iterationTypes : setCachedIterationTypes(type, "iterationTypesOfAsyncIterable", iterationTypes);
-              }
-            } else {
-              return iterationTypes;
-            }
-          }
-        }
-      }
-      if (use & 2 /* AllowsAsyncIterablesFlag */) {
-        const iterationTypes = getIterationTypesOfIterableSlow(type, asyncIterationTypesResolver, errorNode, errorOutputContainer, noCache);
-        if (iterationTypes !== noIterationTypes) {
-          return iterationTypes;
-        }
-      }
-      if (use & 1 /* AllowsSyncIterablesFlag */) {
-        let iterationTypes = getIterationTypesOfIterableSlow(type, syncIterationTypesResolver, errorNode, errorOutputContainer, noCache);
-        if (iterationTypes !== noIterationTypes) {
-          if (use & 2 /* AllowsAsyncIterablesFlag */) {
-            iterationTypes = getAsyncFromSyncIterationTypes(iterationTypes, errorNode);
-            return noCache ? iterationTypes : setCachedIterationTypes(type, "iterationTypesOfAsyncIterable", iterationTypes);
-          } else {
-            return iterationTypes;
-          }
-        }
-      }
-      return noIterationTypes;
-    }
-    function getIterationTypesOfIterableCached(type, resolver) {
-      return getCachedIterationTypes(type, resolver.iterableCacheKey);
-    }
-    function getIterationTypesOfGlobalIterableType(globalType, resolver) {
-      const globalIterationTypes = getIterationTypesOfIterableCached(globalType, resolver) || getIterationTypesOfIterableSlow(
-        globalType,
-        resolver,
-        /*errorNode*/
-        void 0,
-        /*errorOutputContainer*/
-        void 0,
-        /*noCache*/
-        false
-      );
-      return globalIterationTypes === noIterationTypes ? defaultIterationTypes : globalIterationTypes;
-    }
-    function getIterationTypesOfIterableFast(type, resolver) {
-      let globalType;
-      if (isReferenceToType2(type, globalType = resolver.getGlobalIterableType(
-        /*reportErrors*/
-        false
-      )) || isReferenceToType2(type, globalType = resolver.getGlobalIterableIteratorType(
-        /*reportErrors*/
-        false
-      ))) {
-        const [yieldType] = getTypeArguments(type);
-        const { returnType, nextType } = getIterationTypesOfGlobalIterableType(globalType, resolver);
-        return setCachedIterationTypes(type, resolver.iterableCacheKey, createIterationTypes(resolver.resolveIterationType(
-          yieldType,
-          /*errorNode*/
-          void 0
-        ) || yieldType, resolver.resolveIterationType(
-          returnType,
-          /*errorNode*/
-          void 0
-        ) || returnType, nextType));
-      }
-      if (isReferenceToType2(type, resolver.getGlobalGeneratorType(
-        /*reportErrors*/
-        false
-      ))) {
-        const [yieldType, returnType, nextType] = getTypeArguments(type);
-        return setCachedIterationTypes(type, resolver.iterableCacheKey, createIterationTypes(resolver.resolveIterationType(
-          yieldType,
-          /*errorNode*/
-          void 0
-        ) || yieldType, resolver.resolveIterationType(
-          returnType,
-          /*errorNode*/
-          void 0
-        ) || returnType, nextType));
-      }
-    }
-    function getPropertyNameForKnownSymbolName(symbolName2) {
-      const ctorType = getGlobalESSymbolConstructorSymbol(
-        /*reportErrors*/
-        false
-      );
-      const uniqueType = ctorType && getTypeOfPropertyOfType(getTypeOfSymbol(ctorType), escapeLeadingUnderscores(symbolName2));
-      return uniqueType && isTypeUsableAsPropertyName(uniqueType) ? getPropertyNameFromType(uniqueType) : `__@${symbolName2}`;
-    }
-    function getIterationTypesOfIterableSlow(type, resolver, errorNode, errorOutputContainer, noCache) {
-      const method = getPropertyOfType(type, getPropertyNameForKnownSymbolName(resolver.iteratorSymbolName));
-      const methodType = method && !(method.flags & 16777216 /* Optional */) ? getTypeOfSymbol(method) : void 0;
-      if (isTypeAny(methodType)) {
-        return noCache ? anyIterationTypes : setCachedIterationTypes(type, resolver.iterableCacheKey, anyIterationTypes);
-      }
-      const signatures = methodType ? getSignaturesOfType(methodType, 0 /* Call */) : void 0;
-      if (!some(signatures)) {
-        return noCache ? noIterationTypes : setCachedIterationTypes(type, resolver.iterableCacheKey, noIterationTypes);
-      }
-      const iteratorType = getIntersectionType(map(signatures, getReturnTypeOfSignature));
-      const iterationTypes = getIterationTypesOfIteratorWorker(iteratorType, resolver, errorNode, errorOutputContainer, noCache) ?? noIterationTypes;
-      return noCache ? iterationTypes : setCachedIterationTypes(type, resolver.iterableCacheKey, iterationTypes);
-    }
-    function reportTypeNotIterableError(errorNode, type, allowAsyncIterables) {
-      const message = allowAsyncIterables ? Diagnostics.Type_0_must_have_a_Symbol_asyncIterator_method_that_returns_an_async_iterator : Diagnostics.Type_0_must_have_a_Symbol_iterator_method_that_returns_an_iterator;
-      const suggestAwait = (
-        // for (const x of Promise<...>) or [...Promise<...>]
-        !!getAwaitedTypeOfPromise(type) || !allowAsyncIterables && isForOfStatement(errorNode.parent) && errorNode.parent.expression === errorNode && getGlobalAsyncIterableType(
-          /*reportErrors*/
-          false
-        ) !== emptyGenericType && isTypeAssignableTo(
-          type,
-          getGlobalAsyncIterableType(
-            /*reportErrors*/
-            false
-          )
-        )
-      );
-      return errorAndMaybeSuggestAwait(errorNode, suggestAwait, message, typeToString(type));
-    }
-    function getIterationTypesOfIterator(type, resolver, errorNode, errorOutputContainer) {
-      return getIterationTypesOfIteratorWorker(
-        type,
-        resolver,
-        errorNode,
-        errorOutputContainer,
-        /*noCache*/
-        false
-      );
-    }
-    function getIterationTypesOfIteratorWorker(type, resolver, errorNode, errorOutputContainer, noCache) {
-      if (isTypeAny(type)) {
-        return anyIterationTypes;
-      }
-      let iterationTypes = getIterationTypesOfIteratorCached(type, resolver) || getIterationTypesOfIteratorFast(type, resolver);
-      if (iterationTypes === noIterationTypes && errorNode) {
-        iterationTypes = void 0;
-        noCache = true;
-      }
-      iterationTypes ?? (iterationTypes = getIterationTypesOfIteratorSlow(type, resolver, errorNode, errorOutputContainer, noCache));
-      return iterationTypes === noIterationTypes ? void 0 : iterationTypes;
-    }
-    function getIterationTypesOfIteratorCached(type, resolver) {
-      return getCachedIterationTypes(type, resolver.iteratorCacheKey);
-    }
-    function getIterationTypesOfIteratorFast(type, resolver) {
-      const globalType = resolver.getGlobalIterableIteratorType(
-        /*reportErrors*/
-        false
-      );
-      if (isReferenceToType2(type, globalType)) {
-        const [yieldType] = getTypeArguments(type);
-        const globalIterationTypes = getIterationTypesOfIteratorCached(globalType, resolver) || getIterationTypesOfIteratorSlow(
-          globalType,
-          resolver,
-          /*errorNode*/
-          void 0,
-          /*errorOutputContainer*/
-          void 0,
-          /*noCache*/
-          false
-        );
-        const { returnType, nextType } = globalIterationTypes === noIterationTypes ? defaultIterationTypes : globalIterationTypes;
-        return setCachedIterationTypes(type, resolver.iteratorCacheKey, createIterationTypes(yieldType, returnType, nextType));
-      }
-      if (isReferenceToType2(type, resolver.getGlobalIteratorType(
-        /*reportErrors*/
-        false
-      )) || isReferenceToType2(type, resolver.getGlobalGeneratorType(
-        /*reportErrors*/
-        false
-      ))) {
-        const [yieldType, returnType, nextType] = getTypeArguments(type);
-        return setCachedIterationTypes(type, resolver.iteratorCacheKey, createIterationTypes(yieldType, returnType, nextType));
-      }
-    }
-    function isIteratorResult(type, kind) {
-      const doneType = getTypeOfPropertyOfType(type, "done") || falseType;
-      return isTypeAssignableTo(kind === 0 /* Yield */ ? falseType : trueType, doneType);
-    }
-    function isYieldIteratorResult(type) {
-      return isIteratorResult(type, 0 /* Yield */);
-    }
-    function isReturnIteratorResult(type) {
-      return isIteratorResult(type, 1 /* Return */);
-    }
-    function getIterationTypesOfIteratorResult(type) {
-      if (isTypeAny(type)) {
-        return anyIterationTypes;
-      }
-      const cachedTypes2 = getCachedIterationTypes(type, "iterationTypesOfIteratorResult");
-      if (cachedTypes2) {
-        return cachedTypes2;
-      }
-      if (isReferenceToType2(type, getGlobalIteratorYieldResultType(
-        /*reportErrors*/
-        false
-      ))) {
-        const yieldType2 = getTypeArguments(type)[0];
-        return setCachedIterationTypes(type, "iterationTypesOfIteratorResult", createIterationTypes(
-          yieldType2,
-          /*returnType*/
-          void 0,
-          /*nextType*/
-          void 0
-        ));
-      }
-      if (isReferenceToType2(type, getGlobalIteratorReturnResultType(
-        /*reportErrors*/
-        false
-      ))) {
-        const returnType2 = getTypeArguments(type)[0];
-        return setCachedIterationTypes(type, "iterationTypesOfIteratorResult", createIterationTypes(
-          /*yieldType*/
-          void 0,
-          returnType2,
-          /*nextType*/
-          void 0
-        ));
-      }
-      const yieldIteratorResult = filterType(type, isYieldIteratorResult);
-      const yieldType = yieldIteratorResult !== neverType ? getTypeOfPropertyOfType(yieldIteratorResult, "value") : void 0;
-      const returnIteratorResult = filterType(type, isReturnIteratorResult);
-      const returnType = returnIteratorResult !== neverType ? getTypeOfPropertyOfType(returnIteratorResult, "value") : void 0;
-      if (!yieldType && !returnType) {
-        return setCachedIterationTypes(type, "iterationTypesOfIteratorResult", noIterationTypes);
-      }
-      return setCachedIterationTypes(type, "iterationTypesOfIteratorResult", createIterationTypes(
-        yieldType,
-        returnType || voidType,
-        /*nextType*/
-        void 0
-      ));
-    }
-    function getIterationTypesOfMethod(type, resolver, methodName, errorNode, errorOutputContainer) {
-      var _a, _b, _c, _d;
-      const method = getPropertyOfType(type, methodName);
-      if (!method && methodName !== "next") {
-        return void 0;
-      }
-      const methodType = method && !(methodName === "next" && method.flags & 16777216 /* Optional */) ? methodName === "next" ? getTypeOfSymbol(method) : getTypeWithFacts(getTypeOfSymbol(method), 2097152 /* NEUndefinedOrNull */) : void 0;
-      if (isTypeAny(methodType)) {
-        return methodName === "next" ? anyIterationTypes : anyIterationTypesExceptNext;
-      }
-      const methodSignatures = methodType ? getSignaturesOfType(methodType, 0 /* Call */) : emptyArray;
-      if (methodSignatures.length === 0) {
-        if (errorNode) {
-          const diagnostic = methodName === "next" ? resolver.mustHaveANextMethodDiagnostic : resolver.mustBeAMethodDiagnostic;
-          if (errorOutputContainer) {
-            errorOutputContainer.errors ?? (errorOutputContainer.errors = []);
-            errorOutputContainer.errors.push(createDiagnosticForNode(errorNode, diagnostic, methodName));
-          } else {
-            error(errorNode, diagnostic, methodName);
-          }
-        }
-        return methodName === "next" ? noIterationTypes : void 0;
-      }
-      if ((methodType == null ? void 0 : methodType.symbol) && methodSignatures.length === 1) {
-        const globalGeneratorType = resolver.getGlobalGeneratorType(
-          /*reportErrors*/
-          false
-        );
-        const globalIteratorType = resolver.getGlobalIteratorType(
-          /*reportErrors*/
-          false
-        );
-        const isGeneratorMethod = ((_b = (_a = globalGeneratorType.symbol) == null ? void 0 : _a.members) == null ? void 0 : _b.get(methodName)) === methodType.symbol;
-        const isIteratorMethod = !isGeneratorMethod && ((_d = (_c = globalIteratorType.symbol) == null ? void 0 : _c.members) == null ? void 0 : _d.get(methodName)) === methodType.symbol;
-        if (isGeneratorMethod || isIteratorMethod) {
-          const globalType = isGeneratorMethod ? globalGeneratorType : globalIteratorType;
-          const { mapper } = methodType;
-          return createIterationTypes(
-            getMappedType(globalType.typeParameters[0], mapper),
-            getMappedType(globalType.typeParameters[1], mapper),
-            methodName === "next" ? getMappedType(globalType.typeParameters[2], mapper) : void 0
-          );
-        }
-      }
-      let methodParameterTypes;
-      let methodReturnTypes;
-      for (const signature of methodSignatures) {
-        if (methodName !== "throw" && some(signature.parameters)) {
-          methodParameterTypes = append(methodParameterTypes, getTypeAtPosition(signature, 0));
-        }
-        methodReturnTypes = append(methodReturnTypes, getReturnTypeOfSignature(signature));
-      }
-      let returnTypes;
-      let nextType;
-      if (methodName !== "throw") {
-        const methodParameterType = methodParameterTypes ? getUnionType(methodParameterTypes) : unknownType;
-        if (methodName === "next") {
-          nextType = methodParameterType;
-        } else if (methodName === "return") {
-          const resolvedMethodParameterType = resolver.resolveIterationType(methodParameterType, errorNode) || anyType;
-          returnTypes = append(returnTypes, resolvedMethodParameterType);
-        }
-      }
-      let yieldType;
-      const methodReturnType = methodReturnTypes ? getIntersectionType(methodReturnTypes) : neverType;
-      const resolvedMethodReturnType = resolver.resolveIterationType(methodReturnType, errorNode) || anyType;
-      const iterationTypes = getIterationTypesOfIteratorResult(resolvedMethodReturnType);
-      if (iterationTypes === noIterationTypes) {
-        if (errorNode) {
-          if (errorOutputContainer) {
-            errorOutputContainer.errors ?? (errorOutputContainer.errors = []);
-            errorOutputContainer.errors.push(createDiagnosticForNode(errorNode, resolver.mustHaveAValueDiagnostic, methodName));
-          } else {
-            error(errorNode, resolver.mustHaveAValueDiagnostic, methodName);
-          }
-        }
-        yieldType = anyType;
-        returnTypes = append(returnTypes, anyType);
-      } else {
-        yieldType = iterationTypes.yieldType;
-        returnTypes = append(returnTypes, iterationTypes.returnType);
-      }
-      return createIterationTypes(yieldType, getUnionType(returnTypes), nextType);
-    }
-    function getIterationTypesOfIteratorSlow(type, resolver, errorNode, errorOutputContainer, noCache) {
-      const iterationTypes = combineIterationTypes([
-        getIterationTypesOfMethod(type, resolver, "next", errorNode, errorOutputContainer),
-        getIterationTypesOfMethod(type, resolver, "return", errorNode, errorOutputContainer),
-        getIterationTypesOfMethod(type, resolver, "throw", errorNode, errorOutputContainer)
-      ]);
-      return noCache ? iterationTypes : setCachedIterationTypes(type, resolver.iteratorCacheKey, iterationTypes);
-    }
-    function getIterationTypeOfGeneratorFunctionReturnType(kind, returnType, isAsyncGenerator) {
-      if (isTypeAny(returnType)) {
-        return void 0;
-      }
-      const iterationTypes = getIterationTypesOfGeneratorFunctionReturnType(returnType, isAsyncGenerator);
-      return iterationTypes && iterationTypes[getIterationTypesKeyFromIterationTypeKind(kind)];
-    }
-    function getIterationTypesOfGeneratorFunctionReturnType(type, isAsyncGenerator) {
-      if (isTypeAny(type)) {
-        return anyIterationTypes;
-      }
-      const use = isAsyncGenerator ? 2 /* AsyncGeneratorReturnType */ : 1 /* GeneratorReturnType */;
-      const resolver = isAsyncGenerator ? asyncIterationTypesResolver : syncIterationTypesResolver;
-      return getIterationTypesOfIterable(
-        type,
-        use,
-        /*errorNode*/
-        void 0
-      ) || getIterationTypesOfIterator(
-        type,
-        resolver,
-        /*errorNode*/
-        void 0,
-        /*errorOutputContainer*/
-        void 0
-      );
-    }
-    function checkBreakOrContinueStatement(node) {
-      if (!checkGrammarStatementInAmbientContext(node))
-        checkGrammarBreakOrContinueStatement(node);
-    }
-    function unwrapReturnType(returnType, functionFlags) {
-      const isGenerator = !!(functionFlags & 1 /* Generator */);
-      const isAsync = !!(functionFlags & 2 /* Async */);
-      if (isGenerator) {
-        const returnIterationType = getIterationTypeOfGeneratorFunctionReturnType(1 /* Return */, returnType, isAsync);
-        if (!returnIterationType) {
-          return errorType;
-        }
-        return isAsync ? getAwaitedTypeNoAlias(unwrapAwaitedType(returnIterationType)) : returnIterationType;
-      }
-      return isAsync ? getAwaitedTypeNoAlias(returnType) || errorType : returnType;
-    }
-    function isUnwrappedReturnTypeUndefinedVoidOrAny(func, returnType) {
-      const type = unwrapReturnType(returnType, getFunctionFlags(func));
-      return !!(type && (maybeTypeOfKind(type, 16384 /* Void */) || type.flags & (1 /* Any */ | 32768 /* Undefined */)));
-    }
-    function checkReturnStatement(node) {
-      if (checkGrammarStatementInAmbientContext(node)) {
-        return;
-      }
-      const container = getContainingFunctionOrClassStaticBlock(node);
-      if (container && isClassStaticBlockDeclaration(container)) {
-        grammarErrorOnFirstToken(node, Diagnostics.A_return_statement_cannot_be_used_inside_a_class_static_block);
-        return;
-      }
-      if (!container) {
-        grammarErrorOnFirstToken(node, Diagnostics.A_return_statement_can_only_be_used_within_a_function_body);
-        return;
-      }
-      const signature = getSignatureFromDeclaration(container);
-      const returnType = getReturnTypeOfSignature(signature);
-      const functionFlags = getFunctionFlags(container);
-      if (strictNullChecks || node.expression || returnType.flags & 131072 /* Never */) {
-        const exprType = node.expression ? checkExpressionCached(node.expression) : undefinedType;
-        if (container.kind === 177 /* SetAccessor */) {
-          if (node.expression) {
-            error(node, Diagnostics.Setters_cannot_return_a_value);
-          }
-        } else if (container.kind === 175 /* Constructor */) {
-          if (node.expression && !checkTypeAssignableToAndOptionallyElaborate(exprType, returnType, node, node.expression)) {
-            error(node, Diagnostics.Return_type_of_constructor_signature_must_be_assignable_to_the_instance_type_of_the_class);
-          }
-        } else if (getReturnTypeFromAnnotation(container)) {
-          const unwrappedReturnType = unwrapReturnType(returnType, functionFlags) ?? returnType;
-          const unwrappedExprType = functionFlags & 2 /* Async */ ? checkAwaitedType(
-            exprType,
-            /*withAlias*/
-            false,
-            node,
-            Diagnostics.The_return_type_of_an_async_function_must_either_be_a_valid_promise_or_must_not_contain_a_callable_then_member
-          ) : exprType;
-          if (unwrappedReturnType) {
-            checkTypeAssignableToAndOptionallyElaborate(unwrappedExprType, unwrappedReturnType, node, node.expression);
-          }
-        }
-      } else if (container.kind !== 175 /* Constructor */ && compilerOptions.noImplicitReturns && !isUnwrappedReturnTypeUndefinedVoidOrAny(container, returnType)) {
-        error(node, Diagnostics.Not_all_code_paths_return_a_value);
-      }
-    }
-    function checkWithStatement(node) {
-      if (!checkGrammarStatementInAmbientContext(node)) {
-        if (node.flags & 32768 /* AwaitContext */) {
-          grammarErrorOnFirstToken(node, Diagnostics.with_statements_are_not_allowed_in_an_async_function_block);
-        }
-      }
-      checkExpression(node.expression);
-      const sourceFile = getSourceFileOfNode(node);
-      if (!hasParseDiagnostics(sourceFile)) {
-        const start = getSpanOfTokenAtPosition(sourceFile, node.pos).start;
-        const end = node.statement.pos;
-        grammarErrorAtPos(sourceFile, start, end - start, Diagnostics.The_with_statement_is_not_supported_All_symbols_in_a_with_block_will_have_type_any);
-      }
-    }
-    function checkSwitchStatement(node) {
-      checkGrammarStatementInAmbientContext(node);
-      let firstDefaultClause;
-      let hasDuplicateDefaultClause = false;
-      const expressionType = checkExpression(node.expression);
-      forEach(node.caseBlock.clauses, (clause) => {
-        if (clause.kind === 296 /* DefaultClause */ && !hasDuplicateDefaultClause) {
-          if (firstDefaultClause === void 0) {
-            firstDefaultClause = clause;
-          } else {
-            grammarErrorOnNode(clause, Diagnostics.A_default_clause_cannot_appear_more_than_once_in_a_switch_statement);
-            hasDuplicateDefaultClause = true;
-          }
-        }
-        if (clause.kind === 295 /* CaseClause */) {
-          addLazyDiagnostic(createLazyCaseClauseDiagnostics(clause));
-        }
-        forEach(clause.statements, checkSourceElement);
-        if (compilerOptions.noFallthroughCasesInSwitch && clause.fallthroughFlowNode && isReachableFlowNode(clause.fallthroughFlowNode)) {
-          error(clause, Diagnostics.Fallthrough_case_in_switch);
-        }
-        function createLazyCaseClauseDiagnostics(clause2) {
-          return () => {
-            const caseType = checkExpression(clause2.expression);
-            if (!isTypeEqualityComparableTo(expressionType, caseType)) {
-              checkTypeComparableTo(
-                caseType,
-                expressionType,
-                clause2.expression,
-                /*headMessage*/
-                void 0
-              );
-            }
-          };
-        }
-      });
-      if (node.caseBlock.locals) {
-        registerForUnusedIdentifiersCheck(node.caseBlock);
-      }
-    }
-    function checkLabeledStatement(node) {
-      if (!checkGrammarStatementInAmbientContext(node)) {
-        findAncestor(node.parent, (current) => {
-          if (isFunctionLike(current)) {
-            return "quit";
-          }
-          if (current.kind === 255 /* LabeledStatement */ && current.label.escapedText === node.label.escapedText) {
-            grammarErrorOnNode(node.label, Diagnostics.Duplicate_label_0, getTextOfNode(node.label));
-            return true;
-          }
-          return false;
-        });
-      }
-      checkSourceElement(node.statement);
-    }
-    function checkThrowStatement(node) {
-      if (!checkGrammarStatementInAmbientContext(node)) {
-        if (isIdentifier(node.expression) && !node.expression.escapedText) {
-          grammarErrorAfterFirstToken(node, Diagnostics.Line_break_not_permitted_here);
-        }
-      }
-      if (node.expression) {
-        checkExpression(node.expression);
-      }
-    }
-    function checkTryStatement(node) {
-      checkGrammarStatementInAmbientContext(node);
-      checkBlock(node.tryBlock);
-      const catchClause = node.catchClause;
-      if (catchClause) {
-        if (catchClause.variableDeclaration) {
-          const declaration = catchClause.variableDeclaration;
-          checkVariableLikeDeclaration(declaration);
-          const typeNode = getEffectiveTypeAnnotationNode(declaration);
-          if (typeNode) {
-            const type = getTypeFromTypeNode(typeNode);
-            if (type && !(type.flags & 3 /* AnyOrUnknown */)) {
-              grammarErrorOnFirstToken(typeNode, Diagnostics.Catch_clause_variable_type_annotation_must_be_any_or_unknown_if_specified);
-            }
-          } else if (declaration.initializer) {
-            grammarErrorOnFirstToken(declaration.initializer, Diagnostics.Catch_clause_variable_cannot_have_an_initializer);
-          } else {
-            const blockLocals = catchClause.block.locals;
-            if (blockLocals) {
-              forEachKey(catchClause.locals, (caughtName) => {
-                const blockLocal = blockLocals.get(caughtName);
-                if ((blockLocal == null ? void 0 : blockLocal.valueDeclaration) && (blockLocal.flags & 2 /* BlockScopedVariable */) !== 0) {
-                  grammarErrorOnNode(blockLocal.valueDeclaration, Diagnostics.Cannot_redeclare_identifier_0_in_catch_clause, unescapeLeadingUnderscores(caughtName));
-                }
-              });
-            }
-          }
-        }
-        checkBlock(catchClause.block);
-      }
-      if (node.finallyBlock) {
-        checkBlock(node.finallyBlock);
-      }
-    }
-    function checkIndexConstraints(type, symbol, isStaticIndex) {
-      const indexInfos = getIndexInfosOfType(type);
-      if (indexInfos.length === 0) {
-        return;
-      }
-      for (const prop of getPropertiesOfObjectType(type)) {
-        if (!(isStaticIndex && prop.flags & 4194304 /* Prototype */)) {
-          checkIndexConstraintForProperty(type, prop, getLiteralTypeFromProperty(
-            prop,
-            8576 /* StringOrNumberLiteralOrUnique */,
-            /*includeNonPublic*/
-            true
-          ), getNonMissingTypeOfSymbol(prop));
-        }
-      }
-      const typeDeclaration = symbol.valueDeclaration;
-      if (typeDeclaration && isClassLike(typeDeclaration)) {
-        for (const member of typeDeclaration.members) {
-          if (!isStatic(member) && !hasBindableName(member)) {
-            const symbol2 = getSymbolOfDeclaration(member);
-            checkIndexConstraintForProperty(type, symbol2, getTypeOfExpression(member.name.expression), getNonMissingTypeOfSymbol(symbol2));
-          }
-        }
-      }
-      if (indexInfos.length > 1) {
-        for (const info of indexInfos) {
-          checkIndexConstraintForIndexSignature(type, info);
-        }
-      }
-    }
-    function checkIndexConstraintForProperty(type, prop, propNameType, propType) {
-      const declaration = prop.valueDeclaration;
-      const name = getNameOfDeclaration(declaration);
-      if (name && isPrivateIdentifier(name)) {
-        return;
-      }
-      const indexInfos = getApplicableIndexInfos(type, propNameType);
-      const interfaceDeclaration = getObjectFlags(type) & 2 /* Interface */ ? getDeclarationOfKind(type.symbol, 263 /* InterfaceDeclaration */) : void 0;
-      const propDeclaration = declaration && declaration.kind === 225 /* BinaryExpression */ || name && name.kind === 166 /* ComputedPropertyName */ ? declaration : void 0;
-      const localPropDeclaration = getParentOfSymbol(prop) === type.symbol ? declaration : void 0;
-      for (const info of indexInfos) {
-        const localIndexDeclaration = info.declaration && getParentOfSymbol(getSymbolOfDeclaration(info.declaration)) === type.symbol ? info.declaration : void 0;
-        const errorNode = localPropDeclaration || localIndexDeclaration || (interfaceDeclaration && !some(getBaseTypes(type), (base) => !!getPropertyOfObjectType(base, prop.escapedName) && !!getIndexTypeOfType(base, info.keyType)) ? interfaceDeclaration : void 0);
-        if (errorNode && !isTypeAssignableTo(propType, info.type)) {
-          const diagnostic = createError(
-            errorNode,
-            Diagnostics.Property_0_of_type_1_is_not_assignable_to_2_index_type_3,
-            symbolToString(prop),
-            typeToString(propType),
-            typeToString(info.keyType),
-            typeToString(info.type)
-          );
-          if (propDeclaration && errorNode !== propDeclaration) {
-            addRelatedInfo(diagnostic, createDiagnosticForNode(propDeclaration, Diagnostics._0_is_declared_here, symbolToString(prop)));
-          }
-          diagnostics.add(diagnostic);
-        }
-      }
-    }
-    function checkIndexConstraintForIndexSignature(type, checkInfo) {
-      const declaration = checkInfo.declaration;
-      const indexInfos = getApplicableIndexInfos(type, checkInfo.keyType);
-      const interfaceDeclaration = getObjectFlags(type) & 2 /* Interface */ ? getDeclarationOfKind(type.symbol, 263 /* InterfaceDeclaration */) : void 0;
-      const localCheckDeclaration = declaration && getParentOfSymbol(getSymbolOfDeclaration(declaration)) === type.symbol ? declaration : void 0;
-      for (const info of indexInfos) {
-        if (info === checkInfo)
-          continue;
-        const localIndexDeclaration = info.declaration && getParentOfSymbol(getSymbolOfDeclaration(info.declaration)) === type.symbol ? info.declaration : void 0;
-        const errorNode = localCheckDeclaration || localIndexDeclaration || (interfaceDeclaration && !some(getBaseTypes(type), (base) => !!getIndexInfoOfType(base, checkInfo.keyType) && !!getIndexTypeOfType(base, info.keyType)) ? interfaceDeclaration : void 0);
-        if (errorNode && !isTypeAssignableTo(checkInfo.type, info.type)) {
-          error(
-            errorNode,
-            Diagnostics._0_index_type_1_is_not_assignable_to_2_index_type_3,
-            typeToString(checkInfo.keyType),
-            typeToString(checkInfo.type),
-            typeToString(info.keyType),
-            typeToString(info.type)
-          );
-        }
-      }
-    }
-    function checkTypeNameIsReserved(name, message) {
-      switch (name.escapedText) {
-        case "any":
-        case "unknown":
-        case "never":
-        case "number":
-        case "bigint":
-        case "boolean":
-        case "string":
-        case "symbol":
-        case "void":
-        case "object":
-          error(name, message, name.escapedText);
-      }
-    }
-    function checkClassNameCollisionWithObject(name) {
-      if (languageVersion >= 1 /* ES5 */ && name.escapedText === "Object" && (moduleKind < 5 /* ES2015 */ || getSourceFileOfNode(name).impliedNodeFormat === 1 /* CommonJS */)) {
-        error(name, Diagnostics.Class_name_cannot_be_Object_when_targeting_ES5_with_module_0, ModuleKind[moduleKind]);
-      }
-    }
-    function checkUnmatchedJSDocParameters(node) {
-      const jsdocParameters = filter(getJSDocTags(node), isJSDocParameterTag);
-      if (!length(jsdocParameters))
-        return;
-      const isJs = isInJSFile(node);
-      const parameters = /* @__PURE__ */ new Set();
-      const excludedParameters = /* @__PURE__ */ new Set();
-      forEach(node.parameters, ({ name }, index) => {
-        if (isIdentifier(name)) {
-          parameters.add(name.escapedText);
-        }
-        if (isBindingPattern(name)) {
-          excludedParameters.add(index);
-        }
-      });
-      const containsArguments = containsArgumentsReference(node);
-      if (containsArguments) {
-        const lastJSDocParamIndex = jsdocParameters.length - 1;
-        const lastJSDocParam = jsdocParameters[lastJSDocParamIndex];
-        if (isJs && lastJSDocParam && isIdentifier(lastJSDocParam.name) && lastJSDocParam.typeExpression && lastJSDocParam.typeExpression.type && !parameters.has(lastJSDocParam.name.escapedText) && !excludedParameters.has(lastJSDocParamIndex) && !isArrayType(getTypeFromTypeNode(lastJSDocParam.typeExpression.type))) {
-          error(lastJSDocParam.name, Diagnostics.JSDoc_param_tag_has_name_0_but_there_is_no_parameter_with_that_name_It_would_match_arguments_if_it_had_an_array_type, idText(lastJSDocParam.name));
-        }
-      } else {
-        forEach(jsdocParameters, ({ name, isNameFirst }, index) => {
-          if (excludedParameters.has(index) || isIdentifier(name) && parameters.has(name.escapedText)) {
-            return;
-          }
-          if (isQualifiedName(name)) {
-            if (isJs) {
-              error(name, Diagnostics.Qualified_name_0_is_not_allowed_without_a_leading_param_object_1, entityNameToString(name), entityNameToString(name.left));
-            }
-          } else {
-            if (!isNameFirst) {
-              errorOrSuggestion(isJs, name, Diagnostics.JSDoc_param_tag_has_name_0_but_there_is_no_parameter_with_that_name, idText(name));
-            }
-          }
-        });
-      }
-    }
-    function checkTypeParameters(typeParameterDeclarations) {
-      let seenDefault = false;
-      if (typeParameterDeclarations) {
-        for (let i = 0; i < typeParameterDeclarations.length; i++) {
-          const node = typeParameterDeclarations[i];
-          checkTypeParameter(node);
-          addLazyDiagnostic(createCheckTypeParameterDiagnostic(node, i));
-        }
-      }
-      function createCheckTypeParameterDiagnostic(node, i) {
-        return () => {
-          if (node.default) {
-            seenDefault = true;
-            checkTypeParametersNotReferenced(node.default, typeParameterDeclarations, i);
-          } else if (seenDefault) {
-            error(node, Diagnostics.Required_type_parameters_may_not_follow_optional_type_parameters);
-          }
-          for (let j = 0; j < i; j++) {
-            if (typeParameterDeclarations[j].symbol === node.symbol) {
-              error(node.name, Diagnostics.Duplicate_identifier_0, declarationNameToString(node.name));
-            }
-          }
-        };
-      }
-    }
-    function checkTypeParametersNotReferenced(root, typeParameters, index) {
-      visit(root);
-      function visit(node) {
-        if (node.kind === 182 /* TypeReference */) {
-          const type = getTypeFromTypeReference(node);
-          if (type.flags & 262144 /* TypeParameter */) {
-            for (let i = index; i < typeParameters.length; i++) {
-              if (type.symbol === getSymbolOfDeclaration(typeParameters[i])) {
-                error(node, Diagnostics.Type_parameter_defaults_can_only_reference_previously_declared_type_parameters);
-              }
-            }
-          }
-        }
-        forEachChild(node, visit);
-      }
-    }
-    function checkTypeParameterListsIdentical(symbol) {
-      if (symbol.declarations && symbol.declarations.length === 1) {
-        return;
-      }
-      const links = getSymbolLinks(symbol);
-      if (!links.typeParametersChecked) {
-        links.typeParametersChecked = true;
-        const declarations = getClassOrInterfaceDeclarationsOfSymbol(symbol);
-        if (!declarations || declarations.length <= 1) {
-          return;
-        }
-        const type = getDeclaredTypeOfSymbol(symbol);
-        if (!areTypeParametersIdentical(declarations, type.localTypeParameters, getEffectiveTypeParameterDeclarations)) {
-          const name = symbolToString(symbol);
-          for (const declaration of declarations) {
-            error(declaration.name, Diagnostics.All_declarations_of_0_must_have_identical_type_parameters, name);
-          }
-        }
-      }
-    }
-    function areTypeParametersIdentical(declarations, targetParameters, getTypeParameterDeclarations) {
-      const maxTypeArgumentCount = length(targetParameters);
-      const minTypeArgumentCount = getMinTypeArgumentCount(targetParameters);
-      for (const declaration of declarations) {
-        const sourceParameters = getTypeParameterDeclarations(declaration);
-        const numTypeParameters = sourceParameters.length;
-        if (numTypeParameters < minTypeArgumentCount || numTypeParameters > maxTypeArgumentCount) {
-          return false;
-        }
-        for (let i = 0; i < numTypeParameters; i++) {
-          const source = sourceParameters[i];
-          const target = targetParameters[i];
-          if (source.name.escapedText !== target.symbol.escapedName) {
-            return false;
-          }
-          const constraint = getEffectiveConstraintOfTypeParameter(source);
-          const sourceConstraint = constraint && getTypeFromTypeNode(constraint);
-          const targetConstraint = getConstraintOfTypeParameter(target);
-          if (sourceConstraint && targetConstraint && !isTypeIdenticalTo(sourceConstraint, targetConstraint)) {
-            return false;
-          }
-          const sourceDefault = source.default && getTypeFromTypeNode(source.default);
-          const targetDefault = getDefaultFromTypeParameter(target);
-          if (sourceDefault && targetDefault && !isTypeIdenticalTo(sourceDefault, targetDefault)) {
-            return false;
-          }
-        }
-      }
-      return true;
-    }
-    function getFirstTransformableStaticClassElement(node) {
-      const willTransformStaticElementsOfDecoratedClass = !legacyDecorators && languageVersion < 99 /* ESNext */ && classOrConstructorParameterIsDecorated(
-        /*useLegacyDecorators*/
-        false,
-        node
-      );
-      const willTransformPrivateElementsOrClassStaticBlocks = languageVersion <= 9 /* ES2022 */;
-      const willTransformInitializers = !useDefineForClassFields || languageVersion < 9 /* ES2022 */;
-      if (willTransformStaticElementsOfDecoratedClass || willTransformPrivateElementsOrClassStaticBlocks) {
-        for (const member of node.members) {
-          if (willTransformStaticElementsOfDecoratedClass && classElementOrClassElementParameterIsDecorated(
-            /*useLegacyDecorators*/
-            false,
-            member,
-            node
-          )) {
-            return firstOrUndefined(getDecorators(node)) ?? node;
-          } else if (willTransformPrivateElementsOrClassStaticBlocks) {
-            if (isClassStaticBlockDeclaration(member)) {
-              return member;
-            } else if (isStatic(member)) {
-              if (isPrivateIdentifierClassElementDeclaration(member) || willTransformInitializers && isInitializedProperty(member)) {
-                return member;
-              }
-            }
-          }
-        }
-      }
-    }
-    function checkClassExpressionExternalHelpers(node) {
-      if (node.name)
-        return;
-      const parent2 = walkUpOuterExpressions(node);
-      if (!isNamedEvaluationSource(parent2))
-        return;
-      const willTransformESDecorators = !legacyDecorators && languageVersion < 99 /* ESNext */;
-      let location;
-      if (willTransformESDecorators && classOrConstructorParameterIsDecorated(
-        /*useLegacyDecorators*/
-        false,
-        node
-      )) {
-        location = firstOrUndefined(getDecorators(node)) ?? node;
-      } else {
-        location = getFirstTransformableStaticClassElement(node);
-      }
-      if (location) {
-        checkExternalEmitHelpers(location, 8388608 /* SetFunctionName */);
-        if ((isPropertyAssignment(parent2) || isPropertyDeclaration(parent2) || isBindingElement(parent2)) && isComputedPropertyName(parent2.name)) {
-          checkExternalEmitHelpers(location, 16777216 /* PropKey */);
-        }
-      }
-    }
-    function checkClassExpression(node) {
-      checkClassLikeDeclaration(node);
-      checkNodeDeferred(node);
-      checkClassExpressionExternalHelpers(node);
-      return getTypeOfSymbol(getSymbolOfDeclaration(node));
-    }
-    function checkClassExpressionDeferred(node) {
-      forEach(node.members, checkSourceElement);
-      registerForUnusedIdentifiersCheck(node);
-    }
-    function checkClassDeclaration(node) {
-      const firstDecorator = find(node.modifiers, isDecorator);
-      if (legacyDecorators && firstDecorator && some(node.members, (p) => hasStaticModifier(p) && isPrivateIdentifierClassElementDeclaration(p))) {
-        grammarErrorOnNode(firstDecorator, Diagnostics.Class_decorators_can_t_be_used_with_static_private_identifier_Consider_removing_the_experimental_decorator);
-      }
-      if (!node.name && !hasSyntacticModifier(node, 1024 /* Default */)) {
-        grammarErrorOnFirstToken(node, Diagnostics.A_class_declaration_without_the_default_modifier_must_have_a_name);
-      }
-      checkClassLikeDeclaration(node);
-      forEach(node.members, checkSourceElement);
-      registerForUnusedIdentifiersCheck(node);
-    }
-    function checkClassLikeDeclaration(node) {
-      checkGrammarClassLikeDeclaration(node);
-      checkDecorators(node);
-      checkCollisionsForDeclarationName(node, node.name);
-      checkTypeParameters(getEffectiveTypeParameterDeclarations(node));
-      checkExportsOnMergedDeclarations(node);
-      const symbol = getSymbolOfDeclaration(node);
-      const type = getDeclaredTypeOfSymbol(symbol);
-      const typeWithThis = getTypeWithThisArgument(type);
-      const staticType = getTypeOfSymbol(symbol);
-      checkTypeParameterListsIdentical(symbol);
-      checkFunctionOrConstructorSymbol(symbol);
-      checkClassForDuplicateDeclarations(node);
-      const nodeInAmbientContext = !!(node.flags & 16777216 /* Ambient */);
-      if (!nodeInAmbientContext) {
-        checkClassForStaticPropertyNameConflicts(node);
-      }
-      const baseTypeNode = getEffectiveBaseTypeNode(node);
-      if (baseTypeNode) {
-        forEach(baseTypeNode.typeArguments, checkSourceElement);
-        if (languageVersion < 2 /* ES2015 */) {
-          checkExternalEmitHelpers(baseTypeNode.parent, 1 /* Extends */);
-        }
-        const extendsNode = getClassExtendsHeritageElement(node);
-        if (extendsNode && extendsNode !== baseTypeNode) {
-          checkExpression(extendsNode.expression);
-        }
-        const baseTypes = getBaseTypes(type);
-        if (baseTypes.length) {
-          addLazyDiagnostic(() => {
-            const baseType = baseTypes[0];
-            const baseConstructorType = getBaseConstructorTypeOfClass(type);
-            const staticBaseType = getApparentType(baseConstructorType);
-            checkBaseTypeAccessibility(staticBaseType, baseTypeNode);
-            checkSourceElement(baseTypeNode.expression);
-            if (some(baseTypeNode.typeArguments)) {
-              forEach(baseTypeNode.typeArguments, checkSourceElement);
-              for (const constructor of getConstructorsForTypeArguments(staticBaseType, baseTypeNode.typeArguments, baseTypeNode)) {
-                if (!checkTypeArgumentConstraints(baseTypeNode, constructor.typeParameters)) {
-                  break;
-                }
-              }
-            }
-            const baseWithThis = getTypeWithThisArgument(baseType, type.thisType);
-            if (!checkTypeAssignableTo(
-              typeWithThis,
-              baseWithThis,
-              /*errorNode*/
-              void 0
-            )) {
-              issueMemberSpecificError(node, typeWithThis, baseWithThis, Diagnostics.Class_0_incorrectly_extends_base_class_1);
-            } else {
-              checkTypeAssignableTo(
-                staticType,
-                getTypeWithoutSignatures(staticBaseType),
-                node.name || node,
-                Diagnostics.Class_static_side_0_incorrectly_extends_base_class_static_side_1
-              );
-            }
-            if (baseConstructorType.flags & 8650752 /* TypeVariable */) {
-              if (!isMixinConstructorType(staticType)) {
-                error(node.name || node, Diagnostics.A_mixin_class_must_have_a_constructor_with_a_single_rest_parameter_of_type_any);
-              } else {
-                const constructSignatures = getSignaturesOfType(baseConstructorType, 1 /* Construct */);
-                if (constructSignatures.some((signature) => signature.flags & 4 /* Abstract */) && !hasSyntacticModifier(node, 256 /* Abstract */)) {
-                  error(node.name || node, Diagnostics.A_mixin_class_that_extends_from_a_type_variable_containing_an_abstract_construct_signature_must_also_be_declared_abstract);
-                }
-              }
-            }
-            if (!(staticBaseType.symbol && staticBaseType.symbol.flags & 32 /* Class */) && !(baseConstructorType.flags & 8650752 /* TypeVariable */)) {
-              const constructors = getInstantiatedConstructorsForTypeArguments(staticBaseType, baseTypeNode.typeArguments, baseTypeNode);
-              if (forEach(constructors, (sig) => !isJSConstructor(sig.declaration) && !isTypeIdenticalTo(getReturnTypeOfSignature(sig), baseType))) {
-                error(baseTypeNode.expression, Diagnostics.Base_constructors_must_all_have_the_same_return_type);
-              }
-            }
-            checkKindsOfPropertyMemberOverrides(type, baseType);
-          });
-        }
-      }
-      checkMembersForOverrideModifier(node, type, typeWithThis, staticType);
-      const implementedTypeNodes = getEffectiveImplementsTypeNodes(node);
-      if (implementedTypeNodes) {
-        for (const typeRefNode of implementedTypeNodes) {
-          if (!isEntityNameExpression(typeRefNode.expression) || isOptionalChain(typeRefNode.expression)) {
-            error(typeRefNode.expression, Diagnostics.A_class_can_only_implement_an_identifier_Slashqualified_name_with_optional_type_arguments);
-          }
-          checkTypeReferenceNode(typeRefNode);
-          addLazyDiagnostic(createImplementsDiagnostics(typeRefNode));
-        }
-      }
-      addLazyDiagnostic(() => {
-        checkIndexConstraints(type, symbol);
-        checkIndexConstraints(
-          staticType,
-          symbol,
-          /*isStaticIndex*/
-          true
-        );
-        checkTypeForDuplicateIndexSignatures(node);
-        checkPropertyInitialization(node);
-      });
-      function createImplementsDiagnostics(typeRefNode) {
-        return () => {
-          const t = getReducedType(getTypeFromTypeNode(typeRefNode));
-          if (!isErrorType(t)) {
-            if (isValidBaseType(t)) {
-              const genericDiag = t.symbol && t.symbol.flags & 32 /* Class */ ? Diagnostics.Class_0_incorrectly_implements_class_1_Did_you_mean_to_extend_1_and_inherit_its_members_as_a_subclass : Diagnostics.Class_0_incorrectly_implements_interface_1;
-              const baseWithThis = getTypeWithThisArgument(t, type.thisType);
-              if (!checkTypeAssignableTo(
-                typeWithThis,
-                baseWithThis,
-                /*errorNode*/
-                void 0
-              )) {
-                issueMemberSpecificError(node, typeWithThis, baseWithThis, genericDiag);
-              }
-            } else {
-              error(typeRefNode, Diagnostics.A_class_can_only_implement_an_object_type_or_intersection_of_object_types_with_statically_known_members);
-            }
-          }
-        };
-      }
-    }
-    function checkMembersForOverrideModifier(node, type, typeWithThis, staticType) {
-      const baseTypeNode = getEffectiveBaseTypeNode(node);
-      const baseTypes = baseTypeNode && getBaseTypes(type);
-      const baseWithThis = (baseTypes == null ? void 0 : baseTypes.length) ? getTypeWithThisArgument(first(baseTypes), type.thisType) : void 0;
-      const baseStaticType = getBaseConstructorTypeOfClass(type);
-      for (const member of node.members) {
-        if (hasAmbientModifier(member)) {
-          continue;
-        }
-        if (isConstructorDeclaration(member)) {
-          forEach(member.parameters, (param) => {
-            if (isParameterPropertyDeclaration(param, member)) {
-              checkExistingMemberForOverrideModifier(
-                node,
-                staticType,
-                baseStaticType,
-                baseWithThis,
-                type,
-                typeWithThis,
-                param,
-                /*memberIsParameterProperty*/
-                true
-              );
-            }
-          });
-        }
-        checkExistingMemberForOverrideModifier(
-          node,
-          staticType,
-          baseStaticType,
-          baseWithThis,
-          type,
-          typeWithThis,
-          member,
-          /*memberIsParameterProperty*/
-          false
-        );
-      }
-    }
-    function checkExistingMemberForOverrideModifier(node, staticType, baseStaticType, baseWithThis, type, typeWithThis, member, memberIsParameterProperty, reportErrors2 = true) {
-      const declaredProp = member.name && getSymbolAtLocation(member.name) || getSymbolAtLocation(member);
-      if (!declaredProp) {
-        return 0 /* Ok */;
-      }
-      return checkMemberForOverrideModifier(
-        node,
-        staticType,
-        baseStaticType,
-        baseWithThis,
-        type,
-        typeWithThis,
-        hasOverrideModifier(member),
-        hasAbstractModifier(member),
-        isStatic(member),
-        memberIsParameterProperty,
-        symbolName(declaredProp),
-        reportErrors2 ? member : void 0
-      );
-    }
-    function checkMemberForOverrideModifier(node, staticType, baseStaticType, baseWithThis, type, typeWithThis, memberHasOverrideModifier, memberHasAbstractModifier, memberIsStatic, memberIsParameterProperty, memberName, errorNode) {
-      const isJs = isInJSFile(node);
-      const nodeInAmbientContext = !!(node.flags & 16777216 /* Ambient */);
-      if (baseWithThis && (memberHasOverrideModifier || compilerOptions.noImplicitOverride)) {
-        const memberEscapedName = escapeLeadingUnderscores(memberName);
-        const thisType = memberIsStatic ? staticType : typeWithThis;
-        const baseType = memberIsStatic ? baseStaticType : baseWithThis;
-        const prop = getPropertyOfType(thisType, memberEscapedName);
-        const baseProp = getPropertyOfType(baseType, memberEscapedName);
-        const baseClassName = typeToString(baseWithThis);
-        if (prop && !baseProp && memberHasOverrideModifier) {
-          if (errorNode) {
-            const suggestion = getSuggestedSymbolForNonexistentClassMember(memberName, baseType);
-            suggestion ? error(
-              errorNode,
-              isJs ? Diagnostics.This_member_cannot_have_a_JSDoc_comment_with_an_override_tag_because_it_is_not_declared_in_the_base_class_0_Did_you_mean_1 : Diagnostics.This_member_cannot_have_an_override_modifier_because_it_is_not_declared_in_the_base_class_0_Did_you_mean_1,
-              baseClassName,
-              symbolToString(suggestion)
-            ) : error(
-              errorNode,
-              isJs ? Diagnostics.This_member_cannot_have_a_JSDoc_comment_with_an_override_tag_because_it_is_not_declared_in_the_base_class_0 : Diagnostics.This_member_cannot_have_an_override_modifier_because_it_is_not_declared_in_the_base_class_0,
-              baseClassName
-            );
-          }
-          return 2 /* HasInvalidOverride */;
-        } else if (prop && (baseProp == null ? void 0 : baseProp.declarations) && compilerOptions.noImplicitOverride && !nodeInAmbientContext) {
-          const baseHasAbstract = some(baseProp.declarations, hasAbstractModifier);
-          if (memberHasOverrideModifier) {
-            return 0 /* Ok */;
-          }
-          if (!baseHasAbstract) {
-            if (errorNode) {
-              const diag2 = memberIsParameterProperty ? isJs ? Diagnostics.This_parameter_property_must_have_a_JSDoc_comment_with_an_override_tag_because_it_overrides_a_member_in_the_base_class_0 : Diagnostics.This_parameter_property_must_have_an_override_modifier_because_it_overrides_a_member_in_base_class_0 : isJs ? Diagnostics.This_member_must_have_a_JSDoc_comment_with_an_override_tag_because_it_overrides_a_member_in_the_base_class_0 : Diagnostics.This_member_must_have_an_override_modifier_because_it_overrides_a_member_in_the_base_class_0;
-              error(errorNode, diag2, baseClassName);
-            }
-            return 1 /* NeedsOverride */;
-          } else if (memberHasAbstractModifier && baseHasAbstract) {
-            if (errorNode) {
-              error(errorNode, Diagnostics.This_member_must_have_an_override_modifier_because_it_overrides_an_abstract_method_that_is_declared_in_the_base_class_0, baseClassName);
-            }
-            return 1 /* NeedsOverride */;
-          }
-        }
-      } else if (memberHasOverrideModifier) {
-        if (errorNode) {
-          const className = typeToString(type);
-          error(
-            errorNode,
-            isJs ? Diagnostics.This_member_cannot_have_a_JSDoc_comment_with_an_override_tag_because_its_containing_class_0_does_not_extend_another_class : Diagnostics.This_member_cannot_have_an_override_modifier_because_its_containing_class_0_does_not_extend_another_class,
-            className
-          );
-        }
-        return 2 /* HasInvalidOverride */;
-      }
-      return 0 /* Ok */;
-    }
-    function issueMemberSpecificError(node, typeWithThis, baseWithThis, broadDiag) {
-      let issuedMemberError = false;
-      for (const member of node.members) {
-        if (isStatic(member)) {
-          continue;
-        }
-        const declaredProp = member.name && getSymbolAtLocation(member.name) || getSymbolAtLocation(member);
-        if (declaredProp) {
-          const prop = getPropertyOfType(typeWithThis, declaredProp.escapedName);
-          const baseProp = getPropertyOfType(baseWithThis, declaredProp.escapedName);
-          if (prop && baseProp) {
-            const rootChain = () => chainDiagnosticMessages(
-              /*details*/
-              void 0,
-              Diagnostics.Property_0_in_type_1_is_not_assignable_to_the_same_property_in_base_type_2,
-              symbolToString(declaredProp),
-              typeToString(typeWithThis),
-              typeToString(baseWithThis)
-            );
-            if (!checkTypeAssignableTo(
-              getTypeOfSymbol(prop),
-              getTypeOfSymbol(baseProp),
-              member.name || member,
-              /*headMessage*/
-              void 0,
-              rootChain
-            )) {
-              issuedMemberError = true;
-            }
-          }
-        }
-      }
-      if (!issuedMemberError) {
-        checkTypeAssignableTo(typeWithThis, baseWithThis, node.name || node, broadDiag);
-      }
-    }
-    function checkBaseTypeAccessibility(type, node) {
-      const signatures = getSignaturesOfType(type, 1 /* Construct */);
-      if (signatures.length) {
-        const declaration = signatures[0].declaration;
-        if (declaration && hasEffectiveModifier(declaration, 8 /* Private */)) {
-          const typeClassDeclaration = getClassLikeDeclarationOfSymbol(type.symbol);
-          if (!isNodeWithinClass(node, typeClassDeclaration)) {
-            error(node, Diagnostics.Cannot_extend_a_class_0_Class_constructor_is_marked_as_private, getFullyQualifiedName(type.symbol));
-          }
-        }
-      }
-    }
-    function getMemberOverrideModifierStatus(node, member, memberSymbol) {
-      if (!member.name) {
-        return 0 /* Ok */;
-      }
-      const classSymbol = getSymbolOfDeclaration(node);
-      const type = getDeclaredTypeOfSymbol(classSymbol);
-      const typeWithThis = getTypeWithThisArgument(type);
-      const staticType = getTypeOfSymbol(classSymbol);
-      const baseTypeNode = getEffectiveBaseTypeNode(node);
-      const baseTypes = baseTypeNode && getBaseTypes(type);
-      const baseWithThis = (baseTypes == null ? void 0 : baseTypes.length) ? getTypeWithThisArgument(first(baseTypes), type.thisType) : void 0;
-      const baseStaticType = getBaseConstructorTypeOfClass(type);
-      const memberHasOverrideModifier = member.parent ? hasOverrideModifier(member) : hasSyntacticModifier(member, 16384 /* Override */);
-      return checkMemberForOverrideModifier(
-        node,
-        staticType,
-        baseStaticType,
-        baseWithThis,
-        type,
-        typeWithThis,
-        memberHasOverrideModifier,
-        hasAbstractModifier(member),
-        isStatic(member),
-        /*memberIsParameterProperty*/
-        false,
-        symbolName(memberSymbol)
-      );
-    }
-    function getTargetSymbol(s) {
-      return getCheckFlags(s) & 1 /* Instantiated */ ? s.links.target : s;
-    }
-    function getClassOrInterfaceDeclarationsOfSymbol(symbol) {
-      return filter(symbol.declarations, (d) => d.kind === 262 /* ClassDeclaration */ || d.kind === 263 /* InterfaceDeclaration */);
-    }
-    function checkKindsOfPropertyMemberOverrides(type, baseType) {
-      var _a, _b, _c, _d;
-      const baseProperties = getPropertiesOfType(baseType);
-      let inheritedAbstractMemberNotImplementedError;
-      basePropertyCheck:
-        for (const baseProperty of baseProperties) {
-          const base = getTargetSymbol(baseProperty);
-          if (base.flags & 4194304 /* Prototype */) {
-            continue;
-          }
-          const baseSymbol = getPropertyOfObjectType(type, base.escapedName);
-          if (!baseSymbol) {
-            continue;
-          }
-          const derived = getTargetSymbol(baseSymbol);
-          const baseDeclarationFlags = getDeclarationModifierFlagsFromSymbol(base);
-          Debug.assert(!!derived, "derived should point to something, even if it is the base class' declaration.");
-          if (derived === base) {
-            const derivedClassDecl = getClassLikeDeclarationOfSymbol(type.symbol);
-            if (baseDeclarationFlags & 256 /* Abstract */ && (!derivedClassDecl || !hasSyntacticModifier(derivedClassDecl, 256 /* Abstract */))) {
-              for (const otherBaseType of getBaseTypes(type)) {
-                if (otherBaseType === baseType)
-                  continue;
-                const baseSymbol2 = getPropertyOfObjectType(otherBaseType, base.escapedName);
-                const derivedElsewhere = baseSymbol2 && getTargetSymbol(baseSymbol2);
-                if (derivedElsewhere && derivedElsewhere !== base) {
-                  continue basePropertyCheck;
-                }
-              }
-              if (!inheritedAbstractMemberNotImplementedError) {
-                inheritedAbstractMemberNotImplementedError = error(
-                  derivedClassDecl,
-                  Diagnostics.Non_abstract_class_0_does_not_implement_all_abstract_members_of_1,
-                  typeToString(type),
-                  typeToString(baseType)
-                );
-              }
-              if (derivedClassDecl.kind === 230 /* ClassExpression */) {
-                addRelatedInfo(
-                  inheritedAbstractMemberNotImplementedError,
-                  createDiagnosticForNode(
-                    baseProperty.valueDeclaration ?? (baseProperty.declarations && first(baseProperty.declarations)) ?? derivedClassDecl,
-                    Diagnostics.Non_abstract_class_expression_does_not_implement_inherited_abstract_member_0_from_class_1,
-                    symbolToString(baseProperty),
-                    typeToString(baseType)
-                  )
-                );
-              } else {
-                addRelatedInfo(
-                  inheritedAbstractMemberNotImplementedError,
-                  createDiagnosticForNode(
-                    baseProperty.valueDeclaration ?? (baseProperty.declarations && first(baseProperty.declarations)) ?? derivedClassDecl,
-                    Diagnostics.Non_abstract_class_0_does_not_implement_inherited_abstract_member_1_from_class_2,
-                    typeToString(type),
-                    symbolToString(baseProperty),
-                    typeToString(baseType)
-                  )
-                );
-              }
-            }
-          } else {
-            const derivedDeclarationFlags = getDeclarationModifierFlagsFromSymbol(derived);
-            if (baseDeclarationFlags & 8 /* Private */ || derivedDeclarationFlags & 8 /* Private */) {
-              continue;
-            }
-            let errorMessage;
-            const basePropertyFlags = base.flags & 98308 /* PropertyOrAccessor */;
-            const derivedPropertyFlags = derived.flags & 98308 /* PropertyOrAccessor */;
-            if (basePropertyFlags && derivedPropertyFlags) {
-              if ((getCheckFlags(base) & 6 /* Synthetic */ ? (_a = base.declarations) == null ? void 0 : _a.some((d) => isPropertyAbstractOrInterface(d, baseDeclarationFlags)) : (_b = base.declarations) == null ? void 0 : _b.every((d) => isPropertyAbstractOrInterface(d, baseDeclarationFlags))) || getCheckFlags(base) & 262144 /* Mapped */ || derived.valueDeclaration && isBinaryExpression(derived.valueDeclaration)) {
-                continue;
-              }
-              const overriddenInstanceProperty = basePropertyFlags !== 4 /* Property */ && derivedPropertyFlags === 4 /* Property */;
-              const overriddenInstanceAccessor = basePropertyFlags === 4 /* Property */ && derivedPropertyFlags !== 4 /* Property */;
-              if (overriddenInstanceProperty || overriddenInstanceAccessor) {
-                const errorMessage2 = overriddenInstanceProperty ? Diagnostics._0_is_defined_as_an_accessor_in_class_1_but_is_overridden_here_in_2_as_an_instance_property : Diagnostics._0_is_defined_as_a_property_in_class_1_but_is_overridden_here_in_2_as_an_accessor;
-                error(getNameOfDeclaration(derived.valueDeclaration) || derived.valueDeclaration, errorMessage2, symbolToString(base), typeToString(baseType), typeToString(type));
-              } else if (useDefineForClassFields) {
-                const uninitialized = (_c = derived.declarations) == null ? void 0 : _c.find((d) => d.kind === 171 /* PropertyDeclaration */ && !d.initializer);
-                if (uninitialized && !(derived.flags & 33554432 /* Transient */) && !(baseDeclarationFlags & 256 /* Abstract */) && !(derivedDeclarationFlags & 256 /* Abstract */) && !((_d = derived.declarations) == null ? void 0 : _d.some((d) => !!(d.flags & 16777216 /* Ambient */)))) {
-                  const constructor = findConstructorDeclaration(getClassLikeDeclarationOfSymbol(type.symbol));
-                  const propName = uninitialized.name;
-                  if (uninitialized.exclamationToken || !constructor || !isIdentifier(propName) || !strictNullChecks || !isPropertyInitializedInConstructor(propName, type, constructor)) {
-                    const errorMessage2 = Diagnostics.Property_0_will_overwrite_the_base_property_in_1_If_this_is_intentional_add_an_initializer_Otherwise_add_a_declare_modifier_or_remove_the_redundant_declaration;
-                    error(getNameOfDeclaration(derived.valueDeclaration) || derived.valueDeclaration, errorMessage2, symbolToString(base), typeToString(baseType));
-                  }
-                }
-              }
-              continue;
-            } else if (isPrototypeProperty(base)) {
-              if (isPrototypeProperty(derived) || derived.flags & 4 /* Property */) {
-                continue;
-              } else {
-                Debug.assert(!!(derived.flags & 98304 /* Accessor */));
-                errorMessage = Diagnostics.Class_0_defines_instance_member_function_1_but_extended_class_2_defines_it_as_instance_member_accessor;
-              }
-            } else if (base.flags & 98304 /* Accessor */) {
-              errorMessage = Diagnostics.Class_0_defines_instance_member_accessor_1_but_extended_class_2_defines_it_as_instance_member_function;
-            } else {
-              errorMessage = Diagnostics.Class_0_defines_instance_member_property_1_but_extended_class_2_defines_it_as_instance_member_function;
-            }
-            error(getNameOfDeclaration(derived.valueDeclaration) || derived.valueDeclaration, errorMessage, typeToString(baseType), symbolToString(base), typeToString(type));
-          }
-        }
-    }
-    function isPropertyAbstractOrInterface(declaration, baseDeclarationFlags) {
-      return baseDeclarationFlags & 256 /* Abstract */ && (!isPropertyDeclaration(declaration) || !declaration.initializer) || isInterfaceDeclaration(declaration.parent);
-    }
-    function getNonInheritedProperties(type, baseTypes, properties) {
-      if (!length(baseTypes)) {
-        return properties;
-      }
-      const seen = /* @__PURE__ */ new Map();
-      forEach(properties, (p) => {
-        seen.set(p.escapedName, p);
-      });
-      for (const base of baseTypes) {
-        const properties2 = getPropertiesOfType(getTypeWithThisArgument(base, type.thisType));
-        for (const prop of properties2) {
-          const existing = seen.get(prop.escapedName);
-          if (existing && prop.parent === existing.parent) {
-            seen.delete(prop.escapedName);
-          }
-        }
-      }
-      return arrayFrom(seen.values());
-    }
-    function checkInheritedPropertiesAreIdentical(type, typeNode) {
-      const baseTypes = getBaseTypes(type);
-      if (baseTypes.length < 2) {
-        return true;
-      }
-      const seen = /* @__PURE__ */ new Map();
-      forEach(resolveDeclaredMembers(type).declaredProperties, (p) => {
-        seen.set(p.escapedName, { prop: p, containingType: type });
-      });
-      let ok = true;
-      for (const base of baseTypes) {
-        const properties = getPropertiesOfType(getTypeWithThisArgument(base, type.thisType));
-        for (const prop of properties) {
-          const existing = seen.get(prop.escapedName);
-          if (!existing) {
-            seen.set(prop.escapedName, { prop, containingType: base });
-          } else {
-            const isInheritedProperty = existing.containingType !== type;
-            if (isInheritedProperty && !isPropertyIdenticalTo(existing.prop, prop)) {
-              ok = false;
-              const typeName1 = typeToString(existing.containingType);
-              const typeName2 = typeToString(base);
-              let errorInfo = chainDiagnosticMessages(
-                /*details*/
-                void 0,
-                Diagnostics.Named_property_0_of_types_1_and_2_are_not_identical,
-                symbolToString(prop),
-                typeName1,
-                typeName2
-              );
-              errorInfo = chainDiagnosticMessages(errorInfo, Diagnostics.Interface_0_cannot_simultaneously_extend_types_1_and_2, typeToString(type), typeName1, typeName2);
-              diagnostics.add(createDiagnosticForNodeFromMessageChain(getSourceFileOfNode(typeNode), typeNode, errorInfo));
-            }
-          }
-        }
-      }
-      return ok;
-    }
-    function checkPropertyInitialization(node) {
-      if (!strictNullChecks || !strictPropertyInitialization || node.flags & 16777216 /* Ambient */) {
-        return;
-      }
-      const constructor = findConstructorDeclaration(node);
-      for (const member of node.members) {
-        if (getEffectiveModifierFlags(member) & 2 /* Ambient */) {
-          continue;
-        }
-        if (!isStatic(member) && isPropertyWithoutInitializer(member)) {
-          const propName = member.name;
-          if (isIdentifier(propName) || isPrivateIdentifier(propName) || isComputedPropertyName(propName)) {
-            const type = getTypeOfSymbol(getSymbolOfDeclaration(member));
-            if (!(type.flags & 3 /* AnyOrUnknown */ || containsUndefinedType(type))) {
-              if (!constructor || !isPropertyInitializedInConstructor(propName, type, constructor)) {
-                error(member.name, Diagnostics.Property_0_has_no_initializer_and_is_not_definitely_assigned_in_the_constructor, declarationNameToString(propName));
-              }
-            }
-          }
-        }
-      }
-    }
-    function isPropertyWithoutInitializer(node) {
-      return node.kind === 171 /* PropertyDeclaration */ && !hasAbstractModifier(node) && !node.exclamationToken && !node.initializer;
-    }
-    function isPropertyInitializedInStaticBlocks(propName, propType, staticBlocks, startPos, endPos) {
-      for (const staticBlock of staticBlocks) {
-        if (staticBlock.pos >= startPos && staticBlock.pos <= endPos) {
-          const reference = factory.createPropertyAccessExpression(factory.createThis(), propName);
-          setParent(reference.expression, reference);
-          setParent(reference, staticBlock);
-          reference.flowNode = staticBlock.returnFlowNode;
-          const flowType = getFlowTypeOfReference(reference, propType, getOptionalType(propType));
-          if (!containsUndefinedType(flowType)) {
-            return true;
-          }
-        }
-      }
-      return false;
-    }
-    function isPropertyInitializedInConstructor(propName, propType, constructor) {
-      const reference = isComputedPropertyName(propName) ? factory.createElementAccessExpression(factory.createThis(), propName.expression) : factory.createPropertyAccessExpression(factory.createThis(), propName);
-      setParent(reference.expression, reference);
-      setParent(reference, constructor);
-      reference.flowNode = constructor.returnFlowNode;
-      const flowType = getFlowTypeOfReference(reference, propType, getOptionalType(propType));
-      return !containsUndefinedType(flowType);
-    }
-    function checkInterfaceDeclaration(node) {
-      if (!checkGrammarModifiers(node))
-        checkGrammarInterfaceDeclaration(node);
-      checkTypeParameters(node.typeParameters);
-      addLazyDiagnostic(() => {
-        checkTypeNameIsReserved(node.name, Diagnostics.Interface_name_cannot_be_0);
-        checkExportsOnMergedDeclarations(node);
-        const symbol = getSymbolOfDeclaration(node);
-        checkTypeParameterListsIdentical(symbol);
-        const firstInterfaceDecl = getDeclarationOfKind(symbol, 263 /* InterfaceDeclaration */);
-        if (node === firstInterfaceDecl) {
-          const type = getDeclaredTypeOfSymbol(symbol);
-          const typeWithThis = getTypeWithThisArgument(type);
-          if (checkInheritedPropertiesAreIdentical(type, node.name)) {
-            for (const baseType of getBaseTypes(type)) {
-              checkTypeAssignableTo(typeWithThis, getTypeWithThisArgument(baseType, type.thisType), node.name, Diagnostics.Interface_0_incorrectly_extends_interface_1);
-            }
-            checkIndexConstraints(type, symbol);
-          }
-        }
-        checkObjectTypeForDuplicateDeclarations(node);
-      });
-      forEach(getInterfaceBaseTypeNodes(node), (heritageElement) => {
-        if (!isEntityNameExpression(heritageElement.expression) || isOptionalChain(heritageElement.expression)) {
-          error(heritageElement.expression, Diagnostics.An_interface_can_only_extend_an_identifier_Slashqualified_name_with_optional_type_arguments);
-        }
-        checkTypeReferenceNode(heritageElement);
-      });
-      forEach(node.members, checkSourceElement);
-      addLazyDiagnostic(() => {
-        checkTypeForDuplicateIndexSignatures(node);
-        registerForUnusedIdentifiersCheck(node);
-      });
-    }
-    function checkTypeAliasDeclaration(node) {
-      checkGrammarModifiers(node);
-      checkTypeNameIsReserved(node.name, Diagnostics.Type_alias_name_cannot_be_0);
-      checkExportsOnMergedDeclarations(node);
-      checkTypeParameters(node.typeParameters);
-      if (node.type.kind === 141 /* IntrinsicKeyword */) {
-        if (!intrinsicTypeKinds.has(node.name.escapedText) || length(node.typeParameters) !== 1) {
-          error(node.type, Diagnostics.The_intrinsic_keyword_can_only_be_used_to_declare_compiler_provided_intrinsic_types);
-        }
-      } else {
-        checkSourceElement(node.type);
-        registerForUnusedIdentifiersCheck(node);
-      }
-    }
-    function computeEnumMemberValues(node) {
-      const nodeLinks2 = getNodeLinks(node);
-      if (!(nodeLinks2.flags & 1024 /* EnumValuesComputed */)) {
-        nodeLinks2.flags |= 1024 /* EnumValuesComputed */;
-        let autoValue = 0;
-        for (const member of node.members) {
-          const value = computeMemberValue(member, autoValue);
-          getNodeLinks(member).enumMemberValue = value;
-          autoValue = typeof value === "number" ? value + 1 : void 0;
-        }
-      }
-    }
-    function computeMemberValue(member, autoValue) {
-      if (isComputedNonLiteralName(member.name)) {
-        error(member.name, Diagnostics.Computed_property_names_are_not_allowed_in_enums);
-      } else {
-        const text = getTextOfPropertyName(member.name);
-        if (isNumericLiteralName(text) && !isInfinityOrNaNString(text)) {
-          error(member.name, Diagnostics.An_enum_member_cannot_have_a_numeric_name);
-        }
-      }
-      if (member.initializer) {
-        return computeConstantValue(member);
-      }
-      if (member.parent.flags & 16777216 /* Ambient */ && !isEnumConst(member.parent)) {
-        return void 0;
-      }
-      if (autoValue !== void 0) {
-        return autoValue;
-      }
-      error(member.name, Diagnostics.Enum_member_must_have_initializer);
-      return void 0;
-    }
-    function computeConstantValue(member) {
-      const isConstEnum = isEnumConst(member.parent);
-      const initializer = member.initializer;
-      const value = evaluate(initializer, member);
-      if (value !== void 0) {
-        if (isConstEnum && typeof value === "number" && !isFinite(value)) {
-          error(initializer, isNaN(value) ? Diagnostics.const_enum_member_initializer_was_evaluated_to_disallowed_value_NaN : Diagnostics.const_enum_member_initializer_was_evaluated_to_a_non_finite_value);
-        }
-      } else if (isConstEnum) {
-        error(initializer, Diagnostics.const_enum_member_initializers_must_be_constant_expressions);
-      } else if (member.parent.flags & 16777216 /* Ambient */) {
-        error(initializer, Diagnostics.In_ambient_enum_declarations_member_initializer_must_be_constant_expression);
-      } else {
-        checkTypeAssignableTo(checkExpression(initializer), numberType, initializer, Diagnostics.Type_0_is_not_assignable_to_type_1_as_required_for_computed_enum_member_values);
-      }
-      return value;
-    }
-    function evaluate(expr, location) {
-      switch (expr.kind) {
-        case 223 /* PrefixUnaryExpression */:
-          const value = evaluate(expr.operand, location);
-          if (typeof value === "number") {
-            switch (expr.operator) {
-              case 40 /* PlusToken */:
-                return value;
-              case 41 /* MinusToken */:
-                return -value;
-              case 55 /* TildeToken */:
-                return ~value;
-            }
-          }
-          break;
-        case 225 /* BinaryExpression */:
-          const left = evaluate(expr.left, location);
-          const right = evaluate(expr.right, location);
-          if (typeof left === "number" && typeof right === "number") {
-            switch (expr.operatorToken.kind) {
-              case 52 /* BarToken */:
-                return left | right;
-              case 51 /* AmpersandToken */:
-                return left & right;
-              case 49 /* GreaterThanGreaterThanToken */:
-                return left >> right;
-              case 50 /* GreaterThanGreaterThanGreaterThanToken */:
-                return left >>> right;
-              case 48 /* LessThanLessThanToken */:
-                return left << right;
-              case 53 /* CaretToken */:
-                return left ^ right;
-              case 42 /* AsteriskToken */:
-                return left * right;
-              case 44 /* SlashToken */:
-                return left / right;
-              case 40 /* PlusToken */:
-                return left + right;
-              case 41 /* MinusToken */:
-                return left - right;
-              case 45 /* PercentToken */:
-                return left % right;
-              case 43 /* AsteriskAsteriskToken */:
-                return left ** right;
-            }
-          } else if ((typeof left === "string" || typeof left === "number") && (typeof right === "string" || typeof right === "number") && expr.operatorToken.kind === 40 /* PlusToken */) {
-            return "" + left + right;
-          }
-          break;
-        case 11 /* StringLiteral */:
-        case 15 /* NoSubstitutionTemplateLiteral */:
-          return expr.text;
-        case 227 /* TemplateExpression */:
-          return evaluateTemplateExpression(expr, location);
-        case 9 /* NumericLiteral */:
-          checkGrammarNumericLiteral(expr);
-          return +expr.text;
-        case 216 /* ParenthesizedExpression */:
-          return evaluate(expr.expression, location);
-        case 80 /* Identifier */:
-          if (isInfinityOrNaNString(expr.escapedText)) {
-            return +expr.escapedText;
-          }
-        case 210 /* PropertyAccessExpression */:
-          if (isEntityNameExpression(expr)) {
-            const symbol = resolveEntityName(
-              expr,
-              111551 /* Value */,
-              /*ignoreErrors*/
-              true
-            );
-            if (symbol) {
-              if (symbol.flags & 8 /* EnumMember */) {
-                return evaluateEnumMember(expr, symbol, location);
-              }
-              if (isConstVariable(symbol)) {
-                const declaration = symbol.valueDeclaration;
-                if (declaration && !declaration.type && declaration.initializer && declaration !== location && isBlockScopedNameDeclaredBeforeUse(declaration, location)) {
-                  return evaluate(declaration.initializer, declaration);
-                }
-              }
-            }
-          }
-          break;
-        case 211 /* ElementAccessExpression */:
-          const root = expr.expression;
-          if (isEntityNameExpression(root) && isStringLiteralLike(expr.argumentExpression)) {
-            const rootSymbol = resolveEntityName(
-              root,
-              111551 /* Value */,
-              /*ignoreErrors*/
-              true
-            );
-            if (rootSymbol && rootSymbol.flags & 384 /* Enum */) {
-              const name = escapeLeadingUnderscores(expr.argumentExpression.text);
-              const member = rootSymbol.exports.get(name);
-              if (member) {
-                return evaluateEnumMember(expr, member, location);
-              }
-            }
-          }
-          break;
-      }
-      return void 0;
-    }
-    function evaluateEnumMember(expr, symbol, location) {
-      const declaration = symbol.valueDeclaration;
-      if (!declaration || declaration === location) {
-        error(expr, Diagnostics.Property_0_is_used_before_being_assigned, symbolToString(symbol));
-        return void 0;
-      }
-      if (!isBlockScopedNameDeclaredBeforeUse(declaration, location)) {
-        error(expr, Diagnostics.A_member_initializer_in_a_enum_declaration_cannot_reference_members_declared_after_it_including_members_defined_in_other_enums);
-        return 0;
-      }
-      return getEnumMemberValue(declaration);
-    }
-    function evaluateTemplateExpression(expr, location) {
-      let result = expr.head.text;
-      for (const span of expr.templateSpans) {
-        const value = evaluate(span.expression, location);
-        if (value === void 0) {
-          return void 0;
-        }
-        result += value;
-        result += span.literal.text;
-      }
-      return result;
-    }
-    function checkEnumDeclaration(node) {
-      addLazyDiagnostic(() => checkEnumDeclarationWorker(node));
-    }
-    function checkEnumDeclarationWorker(node) {
-      checkGrammarModifiers(node);
-      checkCollisionsForDeclarationName(node, node.name);
-      checkExportsOnMergedDeclarations(node);
-      node.members.forEach(checkEnumMember);
-      computeEnumMemberValues(node);
-      const enumSymbol = getSymbolOfDeclaration(node);
-      const firstDeclaration = getDeclarationOfKind(enumSymbol, node.kind);
-      if (node === firstDeclaration) {
-        if (enumSymbol.declarations && enumSymbol.declarations.length > 1) {
-          const enumIsConst = isEnumConst(node);
-          forEach(enumSymbol.declarations, (decl) => {
-            if (isEnumDeclaration(decl) && isEnumConst(decl) !== enumIsConst) {
-              error(getNameOfDeclaration(decl), Diagnostics.Enum_declarations_must_all_be_const_or_non_const);
-            }
-          });
-        }
-        let seenEnumMissingInitialInitializer = false;
-        forEach(enumSymbol.declarations, (declaration) => {
-          if (declaration.kind !== 265 /* EnumDeclaration */) {
-            return false;
-          }
-          const enumDeclaration = declaration;
-          if (!enumDeclaration.members.length) {
-            return false;
-          }
-          const firstEnumMember = enumDeclaration.members[0];
-          if (!firstEnumMember.initializer) {
-            if (seenEnumMissingInitialInitializer) {
-              error(firstEnumMember.name, Diagnostics.In_an_enum_with_multiple_declarations_only_one_declaration_can_omit_an_initializer_for_its_first_enum_element);
-            } else {
-              seenEnumMissingInitialInitializer = true;
-            }
-          }
-        });
-      }
-    }
-    function checkEnumMember(node) {
-      if (isPrivateIdentifier(node.name)) {
-        error(node, Diagnostics.An_enum_member_cannot_be_named_with_a_private_identifier);
-      }
-      if (node.initializer) {
-        checkExpression(node.initializer);
-      }
-    }
-    function getFirstNonAmbientClassOrFunctionDeclaration(symbol) {
-      const declarations = symbol.declarations;
-      if (declarations) {
-        for (const declaration of declarations) {
-          if ((declaration.kind === 262 /* ClassDeclaration */ || declaration.kind === 261 /* FunctionDeclaration */ && nodeIsPresent(declaration.body)) && !(declaration.flags & 16777216 /* Ambient */)) {
-            return declaration;
-          }
-        }
-      }
-      return void 0;
-    }
-    function inSameLexicalScope(node1, node2) {
-      const container1 = getEnclosingBlockScopeContainer(node1);
-      const container2 = getEnclosingBlockScopeContainer(node2);
-      if (isGlobalSourceFile(container1)) {
-        return isGlobalSourceFile(container2);
-      } else if (isGlobalSourceFile(container2)) {
-        return false;
-      } else {
-        return container1 === container2;
-      }
-    }
-    function checkModuleDeclaration(node) {
-      if (node.body) {
-        checkSourceElement(node.body);
-        if (!isGlobalScopeAugmentation(node)) {
-          registerForUnusedIdentifiersCheck(node);
-        }
-      }
-      addLazyDiagnostic(checkModuleDeclarationDiagnostics);
-      function checkModuleDeclarationDiagnostics() {
-        var _a, _b;
-        const isGlobalAugmentation = isGlobalScopeAugmentation(node);
-        const inAmbientContext = node.flags & 16777216 /* Ambient */;
-        if (isGlobalAugmentation && !inAmbientContext) {
-          error(node.name, Diagnostics.Augmentations_for_the_global_scope_should_have_declare_modifier_unless_they_appear_in_already_ambient_context);
-        }
-        const isAmbientExternalModule = isAmbientModule(node);
-        const contextErrorMessage = isAmbientExternalModule ? Diagnostics.An_ambient_module_declaration_is_only_allowed_at_the_top_level_in_a_file : Diagnostics.A_namespace_declaration_is_only_allowed_at_the_top_level_of_a_namespace_or_module;
-        if (checkGrammarModuleElementContext(node, contextErrorMessage)) {
-          return;
-        }
-        if (!checkGrammarModifiers(node)) {
-          if (!inAmbientContext && node.name.kind === 11 /* StringLiteral */) {
-            grammarErrorOnNode(node.name, Diagnostics.Only_ambient_modules_can_use_quoted_names);
-          }
-        }
-        if (isIdentifier(node.name)) {
-          checkCollisionsForDeclarationName(node, node.name);
-        }
-        checkExportsOnMergedDeclarations(node);
-        const symbol = getSymbolOfDeclaration(node);
-        if (symbol.flags & 512 /* ValueModule */ && !inAmbientContext && isInstantiatedModule(node, shouldPreserveConstEnums(compilerOptions))) {
-          if (getIsolatedModules(compilerOptions) && !getSourceFileOfNode(node).externalModuleIndicator) {
-            error(node.name, Diagnostics.Namespaces_are_not_allowed_in_global_script_files_when_0_is_enabled_If_this_file_is_not_intended_to_be_a_global_script_set_moduleDetection_to_force_or_add_an_empty_export_statement, isolatedModulesLikeFlagName);
-          }
-          if (((_a = symbol.declarations) == null ? void 0 : _a.length) > 1) {
-            const firstNonAmbientClassOrFunc = getFirstNonAmbientClassOrFunctionDeclaration(symbol);
-            if (firstNonAmbientClassOrFunc) {
-              if (getSourceFileOfNode(node) !== getSourceFileOfNode(firstNonAmbientClassOrFunc)) {
-                error(node.name, Diagnostics.A_namespace_declaration_cannot_be_in_a_different_file_from_a_class_or_function_with_which_it_is_merged);
-              } else if (node.pos < firstNonAmbientClassOrFunc.pos) {
-                error(node.name, Diagnostics.A_namespace_declaration_cannot_be_located_prior_to_a_class_or_function_with_which_it_is_merged);
-              }
-            }
-            const mergedClass = getDeclarationOfKind(symbol, 262 /* ClassDeclaration */);
-            if (mergedClass && inSameLexicalScope(node, mergedClass)) {
-              getNodeLinks(node).flags |= 2048 /* LexicalModuleMergesWithClass */;
-            }
-          }
-          if (compilerOptions.verbatimModuleSyntax && node.parent.kind === 311 /* SourceFile */ && (moduleKind === 1 /* CommonJS */ || node.parent.impliedNodeFormat === 1 /* CommonJS */)) {
-            const exportModifier = (_b = node.modifiers) == null ? void 0 : _b.find((m) => m.kind === 95 /* ExportKeyword */);
-            if (exportModifier) {
-              error(exportModifier, Diagnostics.A_top_level_export_modifier_cannot_be_used_on_value_declarations_in_a_CommonJS_module_when_verbatimModuleSyntax_is_enabled);
-            }
-          }
-        }
-        if (isAmbientExternalModule) {
-          if (isExternalModuleAugmentation(node)) {
-            const checkBody = isGlobalAugmentation || getSymbolOfDeclaration(node).flags & 33554432 /* Transient */;
-            if (checkBody && node.body) {
-              for (const statement of node.body.statements) {
-                checkModuleAugmentationElement(statement, isGlobalAugmentation);
-              }
-            }
-          } else if (isGlobalSourceFile(node.parent)) {
-            if (isGlobalAugmentation) {
-              error(node.name, Diagnostics.Augmentations_for_the_global_scope_can_only_be_directly_nested_in_external_modules_or_ambient_module_declarations);
-            } else if (isExternalModuleNameRelative(getTextOfIdentifierOrLiteral(node.name))) {
-              error(node.name, Diagnostics.Ambient_module_declaration_cannot_specify_relative_module_name);
-            }
-          } else {
-            if (isGlobalAugmentation) {
-              error(node.name, Diagnostics.Augmentations_for_the_global_scope_can_only_be_directly_nested_in_external_modules_or_ambient_module_declarations);
-            } else {
-              error(node.name, Diagnostics.Ambient_modules_cannot_be_nested_in_other_modules_or_namespaces);
-            }
-          }
-        }
-      }
-    }
-    function checkModuleAugmentationElement(node, isGlobalAugmentation) {
-      switch (node.kind) {
-        case 242 /* VariableStatement */:
-          for (const decl of node.declarationList.declarations) {
-            checkModuleAugmentationElement(decl, isGlobalAugmentation);
-          }
-          break;
-        case 276 /* ExportAssignment */:
-        case 277 /* ExportDeclaration */:
-          grammarErrorOnFirstToken(node, Diagnostics.Exports_and_export_assignments_are_not_permitted_in_module_augmentations);
-          break;
-        case 270 /* ImportEqualsDeclaration */:
-        case 271 /* ImportDeclaration */:
-          grammarErrorOnFirstToken(node, Diagnostics.Imports_are_not_permitted_in_module_augmentations_Consider_moving_them_to_the_enclosing_external_module);
-          break;
-        case 207 /* BindingElement */:
-        case 259 /* VariableDeclaration */:
-          const name = node.name;
-          if (isBindingPattern(name)) {
-            for (const el of name.elements) {
-              checkModuleAugmentationElement(el, isGlobalAugmentation);
-            }
-            break;
-          }
-        case 262 /* ClassDeclaration */:
-        case 265 /* EnumDeclaration */:
-        case 261 /* FunctionDeclaration */:
-        case 263 /* InterfaceDeclaration */:
-        case 266 /* ModuleDeclaration */:
-        case 264 /* TypeAliasDeclaration */:
-          if (isGlobalAugmentation) {
-            return;
-          }
-          break;
-      }
-    }
-    function getFirstNonModuleExportsIdentifier(node) {
-      switch (node.kind) {
-        case 80 /* Identifier */:
-          return node;
-        case 165 /* QualifiedName */:
-          do {
-            node = node.left;
-          } while (node.kind !== 80 /* Identifier */);
-          return node;
-        case 210 /* PropertyAccessExpression */:
-          do {
-            if (isModuleExportsAccessExpression(node.expression) && !isPrivateIdentifier(node.name)) {
-              return node.name;
-            }
-            node = node.expression;
-          } while (node.kind !== 80 /* Identifier */);
-          return node;
-      }
-    }
-    function checkExternalImportOrExportDeclaration(node) {
-      const moduleName = getExternalModuleName(node);
-      if (!moduleName || nodeIsMissing(moduleName)) {
-        return false;
-      }
-      if (!isStringLiteral(moduleName)) {
-        error(moduleName, Diagnostics.String_literal_expected);
-        return false;
-      }
-      const inAmbientExternalModule = node.parent.kind === 267 /* ModuleBlock */ && isAmbientModule(node.parent.parent);
-      if (node.parent.kind !== 311 /* SourceFile */ && !inAmbientExternalModule) {
-        error(moduleName, node.kind === 277 /* ExportDeclaration */ ? Diagnostics.Export_declarations_are_not_permitted_in_a_namespace : Diagnostics.Import_declarations_in_a_namespace_cannot_reference_a_module);
-        return false;
-      }
-      if (inAmbientExternalModule && isExternalModuleNameRelative(moduleName.text)) {
-        if (!isTopLevelInExternalModuleAugmentation(node)) {
-          error(node, Diagnostics.Import_or_export_declaration_in_an_ambient_module_declaration_cannot_reference_module_through_relative_module_name);
-          return false;
-        }
-      }
-      if (!isImportEqualsDeclaration(node) && node.assertClause) {
-        let hasError = false;
-        for (const clause of node.assertClause.elements) {
-          if (!isStringLiteral(clause.value)) {
-            hasError = true;
-            error(clause.value, Diagnostics.Import_assertion_values_must_be_string_literal_expressions);
-          }
-        }
-        return !hasError;
-      }
-      return true;
-    }
-    function checkAliasSymbol(node) {
-      var _a, _b, _c, _d;
-      let symbol = getSymbolOfDeclaration(node);
-      const target = resolveAlias(symbol);
-      if (target !== unknownSymbol) {
-        symbol = getMergedSymbol(symbol.exportSymbol || symbol);
-        if (isInJSFile(node) && !(target.flags & 111551 /* Value */) && !isTypeOnlyImportOrExportDeclaration(node)) {
-          const errorNode = isImportOrExportSpecifier(node) ? node.propertyName || node.name : isNamedDeclaration(node) ? node.name : node;
-          Debug.assert(node.kind !== 279 /* NamespaceExport */);
-          if (node.kind === 280 /* ExportSpecifier */) {
-            const diag2 = error(errorNode, Diagnostics.Types_cannot_appear_in_export_declarations_in_JavaScript_files);
-            const alreadyExportedSymbol = (_b = (_a = getSourceFileOfNode(node).symbol) == null ? void 0 : _a.exports) == null ? void 0 : _b.get((node.propertyName || node.name).escapedText);
-            if (alreadyExportedSymbol === target) {
-              const exportingDeclaration = (_c = alreadyExportedSymbol.declarations) == null ? void 0 : _c.find(isJSDocNode);
-              if (exportingDeclaration) {
-                addRelatedInfo(diag2, createDiagnosticForNode(
-                  exportingDeclaration,
-                  Diagnostics._0_is_automatically_exported_here,
-                  unescapeLeadingUnderscores(alreadyExportedSymbol.escapedName)
-                ));
-              }
-            }
-          } else {
-            Debug.assert(node.kind !== 259 /* VariableDeclaration */);
-            const importDeclaration = findAncestor(node, or(isImportDeclaration, isImportEqualsDeclaration));
-            const moduleSpecifier = (importDeclaration && ((_d = tryGetModuleSpecifierFromDeclaration(importDeclaration)) == null ? void 0 : _d.text)) ?? "...";
-            const importedIdentifier = unescapeLeadingUnderscores(isIdentifier(errorNode) ? errorNode.escapedText : symbol.escapedName);
-            error(
-              errorNode,
-              Diagnostics._0_is_a_type_and_cannot_be_imported_in_JavaScript_files_Use_1_in_a_JSDoc_type_annotation,
-              importedIdentifier,
-              `import("${moduleSpecifier}").${importedIdentifier}`
-            );
-          }
-          return;
-        }
-        const targetFlags = getAllSymbolFlags(target);
-        const excludedMeanings = (symbol.flags & (111551 /* Value */ | 1048576 /* ExportValue */) ? 111551 /* Value */ : 0) | (symbol.flags & 788968 /* Type */ ? 788968 /* Type */ : 0) | (symbol.flags & 1920 /* Namespace */ ? 1920 /* Namespace */ : 0);
-        if (targetFlags & excludedMeanings) {
-          const message = node.kind === 280 /* ExportSpecifier */ ? Diagnostics.Export_declaration_conflicts_with_exported_declaration_of_0 : Diagnostics.Import_declaration_conflicts_with_local_declaration_of_0;
-          error(node, message, symbolToString(symbol));
-        }
-        if (getIsolatedModules(compilerOptions) && !isTypeOnlyImportOrExportDeclaration(node) && !(node.flags & 16777216 /* Ambient */)) {
-          const typeOnlyAlias = getTypeOnlyAliasDeclaration(symbol);
-          const isType = !(targetFlags & 111551 /* Value */);
-          if (isType || typeOnlyAlias) {
-            switch (node.kind) {
-              case 272 /* ImportClause */:
-              case 275 /* ImportSpecifier */:
-              case 270 /* ImportEqualsDeclaration */: {
-                if (compilerOptions.preserveValueImports || compilerOptions.verbatimModuleSyntax) {
-                  Debug.assertIsDefined(node.name, "An ImportClause with a symbol should have a name");
-                  const message = compilerOptions.verbatimModuleSyntax && isInternalModuleImportEqualsDeclaration(node) ? Diagnostics.An_import_alias_cannot_resolve_to_a_type_or_type_only_declaration_when_verbatimModuleSyntax_is_enabled : isType ? compilerOptions.verbatimModuleSyntax ? Diagnostics._0_is_a_type_and_must_be_imported_using_a_type_only_import_when_verbatimModuleSyntax_is_enabled : Diagnostics._0_is_a_type_and_must_be_imported_using_a_type_only_import_when_preserveValueImports_and_isolatedModules_are_both_enabled : compilerOptions.verbatimModuleSyntax ? Diagnostics._0_resolves_to_a_type_only_declaration_and_must_be_imported_using_a_type_only_import_when_verbatimModuleSyntax_is_enabled : Diagnostics._0_resolves_to_a_type_only_declaration_and_must_be_imported_using_a_type_only_import_when_preserveValueImports_and_isolatedModules_are_both_enabled;
-                  const name = idText(node.kind === 275 /* ImportSpecifier */ ? node.propertyName || node.name : node.name);
-                  addTypeOnlyDeclarationRelatedInfo(
-                    error(node, message, name),
-                    isType ? void 0 : typeOnlyAlias,
-                    name
-                  );
-                }
-                if (isType && node.kind === 270 /* ImportEqualsDeclaration */ && hasEffectiveModifier(node, 1 /* Export */)) {
-                  error(node, Diagnostics.Cannot_use_export_import_on_a_type_or_type_only_namespace_when_0_is_enabled, isolatedModulesLikeFlagName);
-                }
-                break;
-              }
-              case 280 /* ExportSpecifier */: {
-                if (compilerOptions.verbatimModuleSyntax || getSourceFileOfNode(typeOnlyAlias) !== getSourceFileOfNode(node)) {
-                  const name = idText(node.propertyName || node.name);
-                  const diagnostic = isType ? error(node, Diagnostics.Re_exporting_a_type_when_0_is_enabled_requires_using_export_type, isolatedModulesLikeFlagName) : error(node, Diagnostics._0_resolves_to_a_type_only_declaration_and_must_be_re_exported_using_a_type_only_re_export_when_1_is_enabled, name, isolatedModulesLikeFlagName);
-                  addTypeOnlyDeclarationRelatedInfo(diagnostic, isType ? void 0 : typeOnlyAlias, name);
-                  break;
-                }
-              }
-            }
-          }
-          if (compilerOptions.verbatimModuleSyntax && node.kind !== 270 /* ImportEqualsDeclaration */ && !isInJSFile(node) && (moduleKind === 1 /* CommonJS */ || getSourceFileOfNode(node).impliedNodeFormat === 1 /* CommonJS */)) {
-            error(node, Diagnostics.ESM_syntax_is_not_allowed_in_a_CommonJS_module_when_verbatimModuleSyntax_is_enabled);
-          }
-        }
-        if (isImportSpecifier(node)) {
-          const targetSymbol = resolveAliasWithDeprecationCheck(symbol, node);
-          if (isDeprecatedSymbol(targetSymbol) && targetSymbol.declarations) {
-            addDeprecatedSuggestion(node, targetSymbol.declarations, targetSymbol.escapedName);
-          }
-        }
-      }
-    }
-    function resolveAliasWithDeprecationCheck(symbol, location) {
-      if (!(symbol.flags & 2097152 /* Alias */) || isDeprecatedSymbol(symbol) || !getDeclarationOfAliasSymbol(symbol)) {
-        return symbol;
-      }
-      const targetSymbol = resolveAlias(symbol);
-      if (targetSymbol === unknownSymbol)
-        return targetSymbol;
-      while (symbol.flags & 2097152 /* Alias */) {
-        const target = getImmediateAliasedSymbol(symbol);
-        if (target) {
-          if (target === targetSymbol)
-            break;
-          if (target.declarations && length(target.declarations)) {
-            if (isDeprecatedSymbol(target)) {
-              addDeprecatedSuggestion(location, target.declarations, target.escapedName);
-              break;
-            } else {
-              if (symbol === targetSymbol)
-                break;
-              symbol = target;
-            }
-          }
-        } else {
-          break;
-        }
-      }
-      return targetSymbol;
-    }
-    function checkImportBinding(node) {
-      checkCollisionsForDeclarationName(node, node.name);
-      checkAliasSymbol(node);
-      if (node.kind === 275 /* ImportSpecifier */ && idText(node.propertyName || node.name) === "default" && getESModuleInterop(compilerOptions) && moduleKind !== 4 /* System */ && (moduleKind < 5 /* ES2015 */ || getSourceFileOfNode(node).impliedNodeFormat === 1 /* CommonJS */)) {
-        checkExternalEmitHelpers(node, 131072 /* ImportDefault */);
-      }
-    }
-    function checkAssertClause(declaration) {
-      var _a;
-      if (declaration.assertClause) {
-        const validForTypeAssertions = isExclusivelyTypeOnlyImportOrExport(declaration);
-        const override = getResolutionModeOverrideForClause(declaration.assertClause, validForTypeAssertions ? grammarErrorOnNode : void 0);
-        if (validForTypeAssertions && override) {
-          if (!isNightly()) {
-            grammarErrorOnNode(declaration.assertClause, Diagnostics.resolution_mode_assertions_are_unstable_Use_nightly_TypeScript_to_silence_this_error_Try_updating_with_npm_install_D_typescript_next);
-          }
-          if (getEmitModuleResolutionKind(compilerOptions) !== 3 /* Node16 */ && getEmitModuleResolutionKind(compilerOptions) !== 99 /* NodeNext */) {
-            return grammarErrorOnNode(declaration.assertClause, Diagnostics.resolution_mode_assertions_are_only_supported_when_moduleResolution_is_node16_or_nodenext);
-          }
-          return;
-        }
-        const mode = moduleKind === 199 /* NodeNext */ && declaration.moduleSpecifier && getUsageModeForExpression(declaration.moduleSpecifier);
-        if (mode !== 99 /* ESNext */ && moduleKind !== 99 /* ESNext */) {
-          return grammarErrorOnNode(
-            declaration.assertClause,
-            moduleKind === 199 /* NodeNext */ ? Diagnostics.Import_assertions_are_not_allowed_on_statements_that_transpile_to_commonjs_require_calls : Diagnostics.Import_assertions_are_only_supported_when_the_module_option_is_set_to_esnext_or_nodenext
-          );
-        }
-        if (isImportDeclaration(declaration) ? (_a = declaration.importClause) == null ? void 0 : _a.isTypeOnly : declaration.isTypeOnly) {
-          return grammarErrorOnNode(declaration.assertClause, Diagnostics.Import_assertions_cannot_be_used_with_type_only_imports_or_exports);
-        }
-        if (override) {
-          return grammarErrorOnNode(declaration.assertClause, Diagnostics.resolution_mode_can_only_be_set_for_type_only_imports);
-        }
-      }
-    }
-    function checkImportDeclaration(node) {
-      if (checkGrammarModuleElementContext(node, isInJSFile(node) ? Diagnostics.An_import_declaration_can_only_be_used_at_the_top_level_of_a_module : Diagnostics.An_import_declaration_can_only_be_used_at_the_top_level_of_a_namespace_or_module)) {
-        return;
-      }
-      if (!checkGrammarModifiers(node) && hasEffectiveModifiers(node)) {
-        grammarErrorOnFirstToken(node, Diagnostics.An_import_declaration_cannot_have_modifiers);
-      }
-      if (checkExternalImportOrExportDeclaration(node)) {
-        const importClause = node.importClause;
-        if (importClause && !checkGrammarImportClause(importClause)) {
-          if (importClause.name) {
-            checkImportBinding(importClause);
-          }
-          if (importClause.namedBindings) {
-            if (importClause.namedBindings.kind === 273 /* NamespaceImport */) {
-              checkImportBinding(importClause.namedBindings);
-              if (moduleKind !== 4 /* System */ && (moduleKind < 5 /* ES2015 */ || getSourceFileOfNode(node).impliedNodeFormat === 1 /* CommonJS */) && getESModuleInterop(compilerOptions)) {
-                checkExternalEmitHelpers(node, 65536 /* ImportStar */);
-              }
-            } else {
-              const moduleExisted = resolveExternalModuleName(node, node.moduleSpecifier);
-              if (moduleExisted) {
-                forEach(importClause.namedBindings.elements, checkImportBinding);
-              }
-            }
-          }
-        }
-      }
-      checkAssertClause(node);
-    }
-    function checkImportEqualsDeclaration(node) {
-      if (checkGrammarModuleElementContext(node, isInJSFile(node) ? Diagnostics.An_import_declaration_can_only_be_used_at_the_top_level_of_a_module : Diagnostics.An_import_declaration_can_only_be_used_at_the_top_level_of_a_namespace_or_module)) {
-        return;
-      }
-      checkGrammarModifiers(node);
-      if (isInternalModuleImportEqualsDeclaration(node) || checkExternalImportOrExportDeclaration(node)) {
-        checkImportBinding(node);
-        if (hasSyntacticModifier(node, 1 /* Export */)) {
-          markExportAsReferenced(node);
-        }
-        if (node.moduleReference.kind !== 282 /* ExternalModuleReference */) {
-          const target = resolveAlias(getSymbolOfDeclaration(node));
-          if (target !== unknownSymbol) {
-            const targetFlags = getAllSymbolFlags(target);
-            if (targetFlags & 111551 /* Value */) {
-              const moduleName = getFirstIdentifier(node.moduleReference);
-              if (!(resolveEntityName(moduleName, 111551 /* Value */ | 1920 /* Namespace */).flags & 1920 /* Namespace */)) {
-                error(moduleName, Diagnostics.Module_0_is_hidden_by_a_local_declaration_with_the_same_name, declarationNameToString(moduleName));
-              }
-            }
-            if (targetFlags & 788968 /* Type */) {
-              checkTypeNameIsReserved(node.name, Diagnostics.Import_name_cannot_be_0);
-            }
-          }
-          if (node.isTypeOnly) {
-            grammarErrorOnNode(node, Diagnostics.An_import_alias_cannot_use_import_type);
-          }
-        } else {
-          if (moduleKind >= 5 /* ES2015 */ && getSourceFileOfNode(node).impliedNodeFormat === void 0 && !node.isTypeOnly && !(node.flags & 16777216 /* Ambient */)) {
-            grammarErrorOnNode(node, Diagnostics.Import_assignment_cannot_be_used_when_targeting_ECMAScript_modules_Consider_using_import_Asterisk_as_ns_from_mod_import_a_from_mod_import_d_from_mod_or_another_module_format_instead);
-          }
-        }
-      }
-    }
-    function checkExportDeclaration(node) {
-      if (checkGrammarModuleElementContext(node, isInJSFile(node) ? Diagnostics.An_export_declaration_can_only_be_used_at_the_top_level_of_a_module : Diagnostics.An_export_declaration_can_only_be_used_at_the_top_level_of_a_namespace_or_module)) {
-        return;
-      }
-      if (!checkGrammarModifiers(node) && hasSyntacticModifiers(node)) {
-        grammarErrorOnFirstToken(node, Diagnostics.An_export_declaration_cannot_have_modifiers);
-      }
-      if (node.moduleSpecifier && node.exportClause && isNamedExports(node.exportClause) && length(node.exportClause.elements) && languageVersion === 0 /* ES3 */) {
-        checkExternalEmitHelpers(node, 4194304 /* CreateBinding */);
-      }
-      checkGrammarExportDeclaration(node);
-      if (!node.moduleSpecifier || checkExternalImportOrExportDeclaration(node)) {
-        if (node.exportClause && !isNamespaceExport(node.exportClause)) {
-          forEach(node.exportClause.elements, checkExportSpecifier);
-          const inAmbientExternalModule = node.parent.kind === 267 /* ModuleBlock */ && isAmbientModule(node.parent.parent);
-          const inAmbientNamespaceDeclaration = !inAmbientExternalModule && node.parent.kind === 267 /* ModuleBlock */ && !node.moduleSpecifier && node.flags & 16777216 /* Ambient */;
-          if (node.parent.kind !== 311 /* SourceFile */ && !inAmbientExternalModule && !inAmbientNamespaceDeclaration) {
-            error(node, Diagnostics.Export_declarations_are_not_permitted_in_a_namespace);
-          }
-        } else {
-          const moduleSymbol = resolveExternalModuleName(node, node.moduleSpecifier);
-          if (moduleSymbol && hasExportAssignmentSymbol(moduleSymbol)) {
-            error(node.moduleSpecifier, Diagnostics.Module_0_uses_export_and_cannot_be_used_with_export_Asterisk, symbolToString(moduleSymbol));
-          } else if (node.exportClause) {
-            checkAliasSymbol(node.exportClause);
-          }
-          if (moduleKind !== 4 /* System */ && (moduleKind < 5 /* ES2015 */ || getSourceFileOfNode(node).impliedNodeFormat === 1 /* CommonJS */)) {
-            if (node.exportClause) {
-              if (getESModuleInterop(compilerOptions)) {
-                checkExternalEmitHelpers(node, 65536 /* ImportStar */);
-              }
-            } else {
-              checkExternalEmitHelpers(node, 32768 /* ExportStar */);
-            }
-          }
-        }
-      }
-      checkAssertClause(node);
-    }
-    function checkGrammarExportDeclaration(node) {
-      var _a;
-      if (node.isTypeOnly && ((_a = node.exportClause) == null ? void 0 : _a.kind) === 278 /* NamedExports */) {
-        return checkGrammarNamedImportsOrExports(node.exportClause);
-      }
-      return false;
-    }
-    function checkGrammarModuleElementContext(node, errorMessage) {
-      const isInAppropriateContext = node.parent.kind === 311 /* SourceFile */ || node.parent.kind === 267 /* ModuleBlock */ || node.parent.kind === 266 /* ModuleDeclaration */;
-      if (!isInAppropriateContext) {
-        grammarErrorOnFirstToken(node, errorMessage);
-      }
-      return !isInAppropriateContext;
-    }
-    function importClauseContainsReferencedImport(importClause) {
-      return forEachImportClauseDeclaration(importClause, (declaration) => {
-        return !!getSymbolOfDeclaration(declaration).isReferenced;
-      });
-    }
-    function importClauseContainsConstEnumUsedAsValue(importClause) {
-      return forEachImportClauseDeclaration(importClause, (declaration) => {
-        return !!getSymbolLinks(getSymbolOfDeclaration(declaration)).constEnumReferenced;
-      });
-    }
-    function canConvertImportDeclarationToTypeOnly(statement) {
-      return isImportDeclaration(statement) && statement.importClause && !statement.importClause.isTypeOnly && importClauseContainsReferencedImport(statement.importClause) && !isReferencedAliasDeclaration(
-        statement.importClause,
-        /*checkChildren*/
-        true
-      ) && !importClauseContainsConstEnumUsedAsValue(statement.importClause);
-    }
-    function canConvertImportEqualsDeclarationToTypeOnly(statement) {
-      return isImportEqualsDeclaration(statement) && isExternalModuleReference(statement.moduleReference) && !statement.isTypeOnly && getSymbolOfDeclaration(statement).isReferenced && !isReferencedAliasDeclaration(
-        statement,
-        /*checkChildren*/
-        false
-      ) && !getSymbolLinks(getSymbolOfDeclaration(statement)).constEnumReferenced;
-    }
-    function checkImportsForTypeOnlyConversion(sourceFile) {
-      if (!canCollectSymbolAliasAccessabilityData) {
-        return;
-      }
-      for (const statement of sourceFile.statements) {
-        if (canConvertImportDeclarationToTypeOnly(statement) || canConvertImportEqualsDeclarationToTypeOnly(statement)) {
-          error(
-            statement,
-            Diagnostics.This_import_is_never_used_as_a_value_and_must_use_import_type_because_importsNotUsedAsValues_is_set_to_error
-          );
-        }
-      }
-    }
-    function checkExportSpecifier(node) {
-      checkAliasSymbol(node);
-      if (getEmitDeclarations(compilerOptions)) {
-        collectLinkedAliases(
-          node.propertyName || node.name,
-          /*setVisibility*/
-          true
-        );
-      }
-      if (!node.parent.parent.moduleSpecifier) {
-        const exportedName = node.propertyName || node.name;
-        const symbol = resolveName(
-          exportedName,
-          exportedName.escapedText,
-          111551 /* Value */ | 788968 /* Type */ | 1920 /* Namespace */ | 2097152 /* Alias */,
-          /*nameNotFoundMessage*/
-          void 0,
-          /*nameArg*/
-          void 0,
-          /*isUse*/
-          true
-        );
-        if (symbol && (symbol === undefinedSymbol || symbol === globalThisSymbol || symbol.declarations && isGlobalSourceFile(getDeclarationContainer(symbol.declarations[0])))) {
-          error(exportedName, Diagnostics.Cannot_export_0_Only_local_declarations_can_be_exported_from_a_module, idText(exportedName));
-        } else {
-          if (!node.isTypeOnly && !node.parent.parent.isTypeOnly) {
-            markExportAsReferenced(node);
-          }
-          const target = symbol && (symbol.flags & 2097152 /* Alias */ ? resolveAlias(symbol) : symbol);
-          if (!target || getAllSymbolFlags(target) & 111551 /* Value */) {
-            checkExpressionCached(node.propertyName || node.name);
-          }
-        }
-      } else {
-        if (getESModuleInterop(compilerOptions) && moduleKind !== 4 /* System */ && (moduleKind < 5 /* ES2015 */ || getSourceFileOfNode(node).impliedNodeFormat === 1 /* CommonJS */) && idText(node.propertyName || node.name) === "default") {
-          checkExternalEmitHelpers(node, 131072 /* ImportDefault */);
-        }
-      }
-    }
-    function checkExportAssignment(node) {
-      const illegalContextMessage = node.isExportEquals ? Diagnostics.An_export_assignment_must_be_at_the_top_level_of_a_file_or_module_declaration : Diagnostics.A_default_export_must_be_at_the_top_level_of_a_file_or_module_declaration;
-      if (checkGrammarModuleElementContext(node, illegalContextMessage)) {
-        return;
-      }
-      const container = node.parent.kind === 311 /* SourceFile */ ? node.parent : node.parent.parent;
-      if (container.kind === 266 /* ModuleDeclaration */ && !isAmbientModule(container)) {
-        if (node.isExportEquals) {
-          error(node, Diagnostics.An_export_assignment_cannot_be_used_in_a_namespace);
-        } else {
-          error(node, Diagnostics.A_default_export_can_only_be_used_in_an_ECMAScript_style_module);
-        }
-        return;
-      }
-      if (!checkGrammarModifiers(node) && hasEffectiveModifiers(node)) {
-        grammarErrorOnFirstToken(node, Diagnostics.An_export_assignment_cannot_have_modifiers);
-      }
-      const typeAnnotationNode = getEffectiveTypeAnnotationNode(node);
-      if (typeAnnotationNode) {
-        checkTypeAssignableTo(checkExpressionCached(node.expression), getTypeFromTypeNode(typeAnnotationNode), node.expression);
-      }
-      const isIllegalExportDefaultInCJS = !node.isExportEquals && !(node.flags & 16777216 /* Ambient */) && compilerOptions.verbatimModuleSyntax && (moduleKind === 1 /* CommonJS */ || getSourceFileOfNode(node).impliedNodeFormat === 1 /* CommonJS */);
-      if (node.expression.kind === 80 /* Identifier */) {
-        const id = node.expression;
-        const sym = getExportSymbolOfValueSymbolIfExported(resolveEntityName(
-          id,
-          67108863 /* All */,
-          /*ignoreErrors*/
-          true,
-          /*dontResolveAlias*/
-          true,
-          node
-        ));
-        if (sym) {
-          markAliasReferenced(sym, id);
-          if (getAllSymbolFlags(sym) & 111551 /* Value */) {
-            checkExpressionCached(id);
-            if (!isIllegalExportDefaultInCJS && !(node.flags & 16777216 /* Ambient */) && compilerOptions.verbatimModuleSyntax && getTypeOnlyAliasDeclaration(sym, 111551 /* Value */)) {
-              error(
-                id,
-                node.isExportEquals ? Diagnostics.An_export_declaration_must_reference_a_real_value_when_verbatimModuleSyntax_is_enabled_but_0_resolves_to_a_type_only_declaration : Diagnostics.An_export_default_must_reference_a_real_value_when_verbatimModuleSyntax_is_enabled_but_0_resolves_to_a_type_only_declaration,
-                idText(id)
-              );
-            }
-          } else if (!isIllegalExportDefaultInCJS && !(node.flags & 16777216 /* Ambient */) && compilerOptions.verbatimModuleSyntax) {
-            error(
-              id,
-              node.isExportEquals ? Diagnostics.An_export_declaration_must_reference_a_value_when_verbatimModuleSyntax_is_enabled_but_0_only_refers_to_a_type : Diagnostics.An_export_default_must_reference_a_value_when_verbatimModuleSyntax_is_enabled_but_0_only_refers_to_a_type,
-              idText(id)
-            );
-          }
-        } else {
-          checkExpressionCached(id);
-        }
-        if (getEmitDeclarations(compilerOptions)) {
-          collectLinkedAliases(
-            id,
-            /*setVisibility*/
-            true
-          );
-        }
-      } else {
-        checkExpressionCached(node.expression);
-      }
-      if (isIllegalExportDefaultInCJS) {
-        error(node, Diagnostics.ESM_syntax_is_not_allowed_in_a_CommonJS_module_when_verbatimModuleSyntax_is_enabled);
-      }
-      checkExternalModuleExports(container);
-      if (node.flags & 16777216 /* Ambient */ && !isEntityNameExpression(node.expression)) {
-        grammarErrorOnNode(node.expression, Diagnostics.The_expression_of_an_export_assignment_must_be_an_identifier_or_qualified_name_in_an_ambient_context);
-      }
-      if (node.isExportEquals) {
-        if (moduleKind >= 5 /* ES2015 */ && (node.flags & 16777216 /* Ambient */ && getSourceFileOfNode(node).impliedNodeFormat === 99 /* ESNext */ || !(node.flags & 16777216 /* Ambient */) && getSourceFileOfNode(node).impliedNodeFormat !== 1 /* CommonJS */)) {
-          grammarErrorOnNode(node, Diagnostics.Export_assignment_cannot_be_used_when_targeting_ECMAScript_modules_Consider_using_export_default_or_another_module_format_instead);
-        } else if (moduleKind === 4 /* System */ && !(node.flags & 16777216 /* Ambient */)) {
-          grammarErrorOnNode(node, Diagnostics.Export_assignment_is_not_supported_when_module_flag_is_system);
-        }
-      }
-    }
-    function hasExportedMembers(moduleSymbol) {
-      return forEachEntry(moduleSymbol.exports, (_, id) => id !== "export=");
-    }
-    function checkExternalModuleExports(node) {
-      const moduleSymbol = getSymbolOfDeclaration(node);
-      const links = getSymbolLinks(moduleSymbol);
-      if (!links.exportsChecked) {
-        const exportEqualsSymbol = moduleSymbol.exports.get("export=");
-        if (exportEqualsSymbol && hasExportedMembers(moduleSymbol)) {
-          const declaration = getDeclarationOfAliasSymbol(exportEqualsSymbol) || exportEqualsSymbol.valueDeclaration;
-          if (declaration && !isTopLevelInExternalModuleAugmentation(declaration) && !isInJSFile(declaration)) {
-            error(declaration, Diagnostics.An_export_assignment_cannot_be_used_in_a_module_with_other_exported_elements);
-          }
-        }
-        const exports = getExportsOfModule(moduleSymbol);
-        if (exports) {
-          exports.forEach(({ declarations, flags }, id) => {
-            if (id === "__export") {
-              return;
-            }
-            if (flags & (1920 /* Namespace */ | 384 /* Enum */)) {
-              return;
-            }
-            const exportedDeclarationsCount = countWhere(declarations, and(isNotOverloadAndNotAccessor, not(isInterfaceDeclaration)));
-            if (flags & 524288 /* TypeAlias */ && exportedDeclarationsCount <= 2) {
-              return;
-            }
-            if (exportedDeclarationsCount > 1) {
-              if (!isDuplicatedCommonJSExport(declarations)) {
-                for (const declaration of declarations) {
-                  if (isNotOverload(declaration)) {
-                    diagnostics.add(createDiagnosticForNode(declaration, Diagnostics.Cannot_redeclare_exported_variable_0, unescapeLeadingUnderscores(id)));
-                  }
-                }
-              }
-            }
-          });
-        }
-        links.exportsChecked = true;
-      }
-    }
-    function isDuplicatedCommonJSExport(declarations) {
-      return declarations && declarations.length > 1 && declarations.every((d) => isInJSFile(d) && isAccessExpression(d) && (isExportsIdentifier(d.expression) || isModuleExportsAccessExpression(d.expression)));
-    }
-    function checkSourceElement(node) {
-      if (node) {
-        const saveCurrentNode = currentNode;
-        currentNode = node;
-        instantiationCount = 0;
-        checkSourceElementWorker(node);
-        currentNode = saveCurrentNode;
-      }
-    }
-    function checkSourceElementWorker(node) {
-      if (canHaveJSDoc(node)) {
-        forEach(node.jsDoc, ({ comment, tags }) => {
-          checkJSDocCommentWorker(comment);
-          forEach(tags, (tag) => {
-            checkJSDocCommentWorker(tag.comment);
-            if (isInJSFile(node)) {
-              checkSourceElement(tag);
-            }
-          });
-        });
-      }
-      const kind = node.kind;
-      if (cancellationToken) {
-        switch (kind) {
-          case 266 /* ModuleDeclaration */:
-          case 262 /* ClassDeclaration */:
-          case 263 /* InterfaceDeclaration */:
-          case 261 /* FunctionDeclaration */:
-            cancellationToken.throwIfCancellationRequested();
-        }
-      }
-      if (kind >= 242 /* FirstStatement */ && kind <= 258 /* LastStatement */ && canHaveFlowNode(node) && node.flowNode && !isReachableFlowNode(node.flowNode)) {
-        errorOrSuggestion(compilerOptions.allowUnreachableCode === false, node, Diagnostics.Unreachable_code_detected);
-      }
-      switch (kind) {
-        case 167 /* TypeParameter */:
-          return checkTypeParameter(node);
-        case 168 /* Parameter */:
-          return checkParameter(node);
-        case 171 /* PropertyDeclaration */:
-          return checkPropertyDeclaration(node);
-        case 170 /* PropertySignature */:
-          return checkPropertySignature(node);
-        case 184 /* ConstructorType */:
-        case 183 /* FunctionType */:
-        case 178 /* CallSignature */:
-        case 179 /* ConstructSignature */:
-        case 180 /* IndexSignature */:
-          return checkSignatureDeclaration(node);
-        case 173 /* MethodDeclaration */:
-        case 172 /* MethodSignature */:
-          return checkMethodDeclaration(node);
-        case 174 /* ClassStaticBlockDeclaration */:
-          return checkClassStaticBlockDeclaration(node);
-        case 175 /* Constructor */:
-          return checkConstructorDeclaration(node);
-        case 176 /* GetAccessor */:
-        case 177 /* SetAccessor */:
-          return checkAccessorDeclaration(node);
-        case 182 /* TypeReference */:
-          return checkTypeReferenceNode(node);
-        case 181 /* TypePredicate */:
-          return checkTypePredicate(node);
-        case 185 /* TypeQuery */:
-          return checkTypeQuery(node);
-        case 186 /* TypeLiteral */:
-          return checkTypeLiteral(node);
-        case 187 /* ArrayType */:
-          return checkArrayType(node);
-        case 188 /* TupleType */:
-          return checkTupleType(node);
-        case 191 /* UnionType */:
-        case 192 /* IntersectionType */:
-          return checkUnionOrIntersectionType(node);
-        case 195 /* ParenthesizedType */:
-        case 189 /* OptionalType */:
-        case 190 /* RestType */:
-          return checkSourceElement(node.type);
-        case 196 /* ThisType */:
-          return checkThisType(node);
-        case 197 /* TypeOperator */:
-          return checkTypeOperator(node);
-        case 193 /* ConditionalType */:
-          return checkConditionalType(node);
-        case 194 /* InferType */:
-          return checkInferType(node);
-        case 202 /* TemplateLiteralType */:
-          return checkTemplateLiteralType(node);
-        case 204 /* ImportType */:
-          return checkImportType(node);
-        case 201 /* NamedTupleMember */:
-          return checkNamedTupleMember(node);
-        case 334 /* JSDocAugmentsTag */:
-          return checkJSDocAugmentsTag(node);
-        case 335 /* JSDocImplementsTag */:
-          return checkJSDocImplementsTag(node);
-        case 352 /* JSDocTypedefTag */:
-        case 344 /* JSDocCallbackTag */:
-        case 346 /* JSDocEnumTag */:
-          return checkJSDocTypeAliasTag(node);
-        case 351 /* JSDocTemplateTag */:
-          return checkJSDocTemplateTag(node);
-        case 350 /* JSDocTypeTag */:
-          return checkJSDocTypeTag(node);
-        case 330 /* JSDocLink */:
-        case 331 /* JSDocLinkCode */:
-        case 332 /* JSDocLinkPlain */:
-          return checkJSDocLinkLikeTag(node);
-        case 347 /* JSDocParameterTag */:
-          return checkJSDocParameterTag(node);
-        case 354 /* JSDocPropertyTag */:
-          return checkJSDocPropertyTag(node);
-        case 323 /* JSDocFunctionType */:
-          checkJSDocFunctionType(node);
-        case 321 /* JSDocNonNullableType */:
-        case 320 /* JSDocNullableType */:
-        case 318 /* JSDocAllType */:
-        case 319 /* JSDocUnknownType */:
-        case 328 /* JSDocTypeLiteral */:
-          checkJSDocTypeIsInJsFile(node);
-          forEachChild(node, checkSourceElement);
-          return;
-        case 324 /* JSDocVariadicType */:
-          checkJSDocVariadicType(node);
-          return;
-        case 315 /* JSDocTypeExpression */:
-          return checkSourceElement(node.type);
-        case 339 /* JSDocPublicTag */:
-        case 341 /* JSDocProtectedTag */:
-        case 340 /* JSDocPrivateTag */:
-          return checkJSDocAccessibilityModifiers(node);
-        case 356 /* JSDocSatisfiesTag */:
-          return checkJSDocSatisfiesTag(node);
-        case 198 /* IndexedAccessType */:
-          return checkIndexedAccessType(node);
-        case 199 /* MappedType */:
-          return checkMappedType(node);
-        case 261 /* FunctionDeclaration */:
-          return checkFunctionDeclaration(node);
-        case 240 /* Block */:
-        case 267 /* ModuleBlock */:
-          return checkBlock(node);
-        case 242 /* VariableStatement */:
-          return checkVariableStatement(node);
-        case 243 /* ExpressionStatement */:
-          return checkExpressionStatement(node);
-        case 244 /* IfStatement */:
-          return checkIfStatement(node);
-        case 245 /* DoStatement */:
-          return checkDoStatement(node);
-        case 246 /* WhileStatement */:
-          return checkWhileStatement(node);
-        case 247 /* ForStatement */:
-          return checkForStatement(node);
-        case 248 /* ForInStatement */:
-          return checkForInStatement(node);
-        case 249 /* ForOfStatement */:
-          return checkForOfStatement(node);
-        case 250 /* ContinueStatement */:
-        case 251 /* BreakStatement */:
-          return checkBreakOrContinueStatement(node);
-        case 252 /* ReturnStatement */:
-          return checkReturnStatement(node);
-        case 253 /* WithStatement */:
-          return checkWithStatement(node);
-        case 254 /* SwitchStatement */:
-          return checkSwitchStatement(node);
-        case 255 /* LabeledStatement */:
-          return checkLabeledStatement(node);
-        case 256 /* ThrowStatement */:
-          return checkThrowStatement(node);
-        case 257 /* TryStatement */:
-          return checkTryStatement(node);
-        case 259 /* VariableDeclaration */:
-          return checkVariableDeclaration(node);
-        case 207 /* BindingElement */:
-          return checkBindingElement(node);
-        case 262 /* ClassDeclaration */:
-          return checkClassDeclaration(node);
-        case 263 /* InterfaceDeclaration */:
-          return checkInterfaceDeclaration(node);
-        case 264 /* TypeAliasDeclaration */:
-          return checkTypeAliasDeclaration(node);
-        case 265 /* EnumDeclaration */:
-          return checkEnumDeclaration(node);
-        case 266 /* ModuleDeclaration */:
-          return checkModuleDeclaration(node);
-        case 271 /* ImportDeclaration */:
-          return checkImportDeclaration(node);
-        case 270 /* ImportEqualsDeclaration */:
-          return checkImportEqualsDeclaration(node);
-        case 277 /* ExportDeclaration */:
-          return checkExportDeclaration(node);
-        case 276 /* ExportAssignment */:
-          return checkExportAssignment(node);
-        case 241 /* EmptyStatement */:
-        case 258 /* DebuggerStatement */:
-          checkGrammarStatementInAmbientContext(node);
-          return;
-        case 281 /* MissingDeclaration */:
-          return checkMissingDeclaration(node);
-      }
-    }
-    function checkJSDocCommentWorker(node) {
-      if (isArray(node)) {
-        forEach(node, (tag) => {
-          if (isJSDocLinkLike(tag)) {
-            checkSourceElement(tag);
-          }
-        });
-      }
-    }
-    function checkJSDocTypeIsInJsFile(node) {
-      if (!isInJSFile(node)) {
-        if (isJSDocNonNullableType(node) || isJSDocNullableType(node)) {
-          const token = tokenToString(isJSDocNonNullableType(node) ? 54 /* ExclamationToken */ : 58 /* QuestionToken */);
-          const diagnostic = node.postfix ? Diagnostics._0_at_the_end_of_a_type_is_not_valid_TypeScript_syntax_Did_you_mean_to_write_1 : Diagnostics._0_at_the_start_of_a_type_is_not_valid_TypeScript_syntax_Did_you_mean_to_write_1;
-          const typeNode = node.type;
-          const type = getTypeFromTypeNode(typeNode);
-          grammarErrorOnNode(node, diagnostic, token, typeToString(
-            isJSDocNullableType(node) && !(type === neverType || type === voidType) ? getUnionType(append([type, undefinedType], node.postfix ? void 0 : nullType)) : type
-          ));
-        } else {
-          grammarErrorOnNode(node, Diagnostics.JSDoc_types_can_only_be_used_inside_documentation_comments);
-        }
-      }
-    }
-    function checkJSDocVariadicType(node) {
-      checkJSDocTypeIsInJsFile(node);
-      checkSourceElement(node.type);
-      const { parent: parent2 } = node;
-      if (isParameter(parent2) && isJSDocFunctionType(parent2.parent)) {
-        if (last(parent2.parent.parameters) !== parent2) {
-          error(node, Diagnostics.A_rest_parameter_must_be_last_in_a_parameter_list);
-        }
-        return;
-      }
-      if (!isJSDocTypeExpression(parent2)) {
-        error(node, Diagnostics.JSDoc_may_only_appear_in_the_last_parameter_of_a_signature);
-      }
-      const paramTag = node.parent.parent;
-      if (!isJSDocParameterTag(paramTag)) {
-        error(node, Diagnostics.JSDoc_may_only_appear_in_the_last_parameter_of_a_signature);
-        return;
-      }
-      const param = getParameterSymbolFromJSDoc(paramTag);
-      if (!param) {
-        return;
-      }
-      const host2 = getHostSignatureFromJSDoc(paramTag);
-      if (!host2 || last(host2.parameters).symbol !== param) {
-        error(node, Diagnostics.A_rest_parameter_must_be_last_in_a_parameter_list);
-      }
-    }
-    function getTypeFromJSDocVariadicType(node) {
-      const type = getTypeFromTypeNode(node.type);
-      const { parent: parent2 } = node;
-      const paramTag = node.parent.parent;
-      if (isJSDocTypeExpression(node.parent) && isJSDocParameterTag(paramTag)) {
-        const host2 = getHostSignatureFromJSDoc(paramTag);
-        const isCallbackTag = isJSDocCallbackTag(paramTag.parent.parent);
-        if (host2 || isCallbackTag) {
-          const lastParamDeclaration = isCallbackTag ? lastOrUndefined(paramTag.parent.parent.typeExpression.parameters) : lastOrUndefined(host2.parameters);
-          const symbol = getParameterSymbolFromJSDoc(paramTag);
-          if (!lastParamDeclaration || symbol && lastParamDeclaration.symbol === symbol && isRestParameter(lastParamDeclaration)) {
-            return createArrayType(type);
-          }
-        }
-      }
-      if (isParameter(parent2) && isJSDocFunctionType(parent2.parent)) {
-        return createArrayType(type);
-      }
-      return addOptionality(type);
-    }
-    function checkNodeDeferred(node) {
-      const enclosingFile = getSourceFileOfNode(node);
-      const links = getNodeLinks(enclosingFile);
-      if (!(links.flags & 1 /* TypeChecked */)) {
-        links.deferredNodes || (links.deferredNodes = /* @__PURE__ */ new Set());
-        links.deferredNodes.add(node);
-      } else {
-        Debug.assert(!links.deferredNodes, "A type-checked file should have no deferred nodes.");
-      }
-    }
-    function checkDeferredNodes(context) {
-      const links = getNodeLinks(context);
-      if (links.deferredNodes) {
-        links.deferredNodes.forEach(checkDeferredNode);
-      }
-      links.deferredNodes = void 0;
-    }
-    function checkDeferredNode(node) {
-      var _a, _b;
-      (_a = tracing) == null ? void 0 : _a.push(tracing.Phase.Check, "checkDeferredNode", { kind: node.kind, pos: node.pos, end: node.end, path: node.tracingPath });
-      const saveCurrentNode = currentNode;
-      currentNode = node;
-      instantiationCount = 0;
-      switch (node.kind) {
-        case 212 /* CallExpression */:
-        case 213 /* NewExpression */:
-        case 214 /* TaggedTemplateExpression */:
-        case 169 /* Decorator */:
-        case 285 /* JsxOpeningElement */:
-          resolveUntypedCall(node);
-          break;
-        case 217 /* FunctionExpression */:
-        case 218 /* ArrowFunction */:
-        case 173 /* MethodDeclaration */:
-        case 172 /* MethodSignature */:
-          checkFunctionExpressionOrObjectLiteralMethodDeferred(node);
-          break;
-        case 176 /* GetAccessor */:
-        case 177 /* SetAccessor */:
-          checkAccessorDeclaration(node);
-          break;
-        case 230 /* ClassExpression */:
-          checkClassExpressionDeferred(node);
-          break;
-        case 167 /* TypeParameter */:
-          checkTypeParameterDeferred(node);
-          break;
-        case 284 /* JsxSelfClosingElement */:
-          checkJsxSelfClosingElementDeferred(node);
-          break;
-        case 283 /* JsxElement */:
-          checkJsxElementDeferred(node);
-          break;
-        case 215 /* TypeAssertionExpression */:
-        case 233 /* AsExpression */:
-        case 216 /* ParenthesizedExpression */:
-          checkAssertionDeferred(node);
-      }
-      currentNode = saveCurrentNode;
-      (_b = tracing) == null ? void 0 : _b.pop();
-    }
-    function checkSourceFile(node) {
-      var _a, _b;
-      (_a = tracing) == null ? void 0 : _a.push(
-        tracing.Phase.Check,
-        "checkSourceFile",
-        { path: node.path },
-        /*separateBeginAndEnd*/
-        true
-      );
-      mark("beforeCheck");
-      checkSourceFileWorker(node);
-      mark("afterCheck");
-      measure("Check", "beforeCheck", "afterCheck");
-      (_b = tracing) == null ? void 0 : _b.pop();
-    }
-    function unusedIsError(kind, isAmbient) {
-      if (isAmbient) {
-        return false;
-      }
-      switch (kind) {
-        case 0 /* Local */:
-          return !!compilerOptions.noUnusedLocals;
-        case 1 /* Parameter */:
-          return !!compilerOptions.noUnusedParameters;
-        default:
-          return Debug.assertNever(kind);
-      }
-    }
-    function getPotentiallyUnusedIdentifiers(sourceFile) {
-      return allPotentiallyUnusedIdentifiers.get(sourceFile.path) || emptyArray;
-    }
-    function checkSourceFileWorker(node) {
-      const links = getNodeLinks(node);
-      if (!(links.flags & 1 /* TypeChecked */)) {
-        if (skipTypeChecking(node, compilerOptions, host)) {
-          return;
-        }
-        checkGrammarSourceFile(node);
-        clear(potentialThisCollisions);
-        clear(potentialNewTargetCollisions);
-        clear(potentialWeakMapSetCollisions);
-        clear(potentialReflectCollisions);
-        clear(potentialUnusedRenamedBindingElementsInTypes);
-        forEach(node.statements, checkSourceElement);
-        checkSourceElement(node.endOfFileToken);
-        checkDeferredNodes(node);
-        if (isExternalOrCommonJsModule(node)) {
-          registerForUnusedIdentifiersCheck(node);
-        }
-        addLazyDiagnostic(() => {
-          if (!node.isDeclarationFile && (compilerOptions.noUnusedLocals || compilerOptions.noUnusedParameters)) {
-            checkUnusedIdentifiers(getPotentiallyUnusedIdentifiers(node), (containingNode, kind, diag2) => {
-              if (!containsParseError(containingNode) && unusedIsError(kind, !!(containingNode.flags & 16777216 /* Ambient */))) {
-                diagnostics.add(diag2);
-              }
-            });
-          }
-          if (!node.isDeclarationFile) {
-            checkPotentialUncheckedRenamedBindingElementsInTypes();
-          }
-        });
-        if (compilerOptions.importsNotUsedAsValues === 2 /* Error */ && !node.isDeclarationFile && isExternalModule(node)) {
-          checkImportsForTypeOnlyConversion(node);
-        }
-        if (isExternalOrCommonJsModule(node)) {
-          checkExternalModuleExports(node);
-        }
-        if (potentialThisCollisions.length) {
-          forEach(potentialThisCollisions, checkIfThisIsCapturedInEnclosingScope);
-          clear(potentialThisCollisions);
-        }
-        if (potentialNewTargetCollisions.length) {
-          forEach(potentialNewTargetCollisions, checkIfNewTargetIsCapturedInEnclosingScope);
-          clear(potentialNewTargetCollisions);
-        }
-        if (potentialWeakMapSetCollisions.length) {
-          forEach(potentialWeakMapSetCollisions, checkWeakMapSetCollision);
-          clear(potentialWeakMapSetCollisions);
-        }
-        if (potentialReflectCollisions.length) {
-          forEach(potentialReflectCollisions, checkReflectCollision);
-          clear(potentialReflectCollisions);
-        }
-        links.flags |= 1 /* TypeChecked */;
-      }
-    }
-    function getDiagnostics2(sourceFile, ct) {
-      try {
-        cancellationToken = ct;
-        return getDiagnosticsWorker(sourceFile);
-      } finally {
-        cancellationToken = void 0;
-      }
-    }
-    function ensurePendingDiagnosticWorkComplete() {
-      for (const cb of deferredDiagnosticsCallbacks) {
-        cb();
-      }
-      deferredDiagnosticsCallbacks = [];
-    }
-    function checkSourceFileWithEagerDiagnostics(sourceFile) {
-      ensurePendingDiagnosticWorkComplete();
-      const oldAddLazyDiagnostics = addLazyDiagnostic;
-      addLazyDiagnostic = (cb) => cb();
-      checkSourceFile(sourceFile);
-      addLazyDiagnostic = oldAddLazyDiagnostics;
-    }
-    function getDiagnosticsWorker(sourceFile) {
-      if (sourceFile) {
-        ensurePendingDiagnosticWorkComplete();
-        const previousGlobalDiagnostics = diagnostics.getGlobalDiagnostics();
-        const previousGlobalDiagnosticsSize = previousGlobalDiagnostics.length;
-        checkSourceFileWithEagerDiagnostics(sourceFile);
-        const semanticDiagnostics = diagnostics.getDiagnostics(sourceFile.fileName);
-        const currentGlobalDiagnostics = diagnostics.getGlobalDiagnostics();
-        if (currentGlobalDiagnostics !== previousGlobalDiagnostics) {
-          const deferredGlobalDiagnostics = relativeComplement(previousGlobalDiagnostics, currentGlobalDiagnostics, compareDiagnostics);
-          return concatenate(deferredGlobalDiagnostics, semanticDiagnostics);
-        } else if (previousGlobalDiagnosticsSize === 0 && currentGlobalDiagnostics.length > 0) {
-          return concatenate(currentGlobalDiagnostics, semanticDiagnostics);
-        }
-        return semanticDiagnostics;
-      }
-      forEach(host.getSourceFiles(), checkSourceFileWithEagerDiagnostics);
-      return diagnostics.getDiagnostics();
-    }
-    function getGlobalDiagnostics() {
-      ensurePendingDiagnosticWorkComplete();
-      return diagnostics.getGlobalDiagnostics();
-    }
-    function getSymbolsInScope(location, meaning) {
-      if (location.flags & 33554432 /* InWithStatement */) {
-        return [];
-      }
-      const symbols = createSymbolTable();
-      let isStaticSymbol = false;
-      populateSymbols();
-      symbols.delete("this" /* This */);
-      return symbolsToArray(symbols);
-      function populateSymbols() {
-        while (location) {
-          if (canHaveLocals(location) && location.locals && !isGlobalSourceFile(location)) {
-            copySymbols(location.locals, meaning);
-          }
-          switch (location.kind) {
-            case 311 /* SourceFile */:
-              if (!isExternalModule(location))
-                break;
-            case 266 /* ModuleDeclaration */:
-              copyLocallyVisibleExportSymbols(getSymbolOfDeclaration(location).exports, meaning & 2623475 /* ModuleMember */);
-              break;
-            case 265 /* EnumDeclaration */:
-              copySymbols(getSymbolOfDeclaration(location).exports, meaning & 8 /* EnumMember */);
-              break;
-            case 230 /* ClassExpression */:
-              const className = location.name;
-              if (className) {
-                copySymbol(location.symbol, meaning);
-              }
-            case 262 /* ClassDeclaration */:
-            case 263 /* InterfaceDeclaration */:
-              if (!isStaticSymbol) {
-                copySymbols(getMembersOfSymbol(getSymbolOfDeclaration(location)), meaning & 788968 /* Type */);
-              }
-              break;
-            case 217 /* FunctionExpression */:
-              const funcName = location.name;
-              if (funcName) {
-                copySymbol(location.symbol, meaning);
-              }
-              break;
-          }
-          if (introducesArgumentsExoticObject(location)) {
-            copySymbol(argumentsSymbol, meaning);
-          }
-          isStaticSymbol = isStatic(location);
-          location = location.parent;
-        }
-        copySymbols(globals, meaning);
-      }
-      function copySymbol(symbol, meaning2) {
-        if (getCombinedLocalAndExportSymbolFlags(symbol) & meaning2) {
-          const id = symbol.escapedName;
-          if (!symbols.has(id)) {
-            symbols.set(id, symbol);
-          }
-        }
-      }
-      function copySymbols(source, meaning2) {
-        if (meaning2) {
-          source.forEach((symbol) => {
-            copySymbol(symbol, meaning2);
-          });
-        }
-      }
-      function copyLocallyVisibleExportSymbols(source, meaning2) {
-        if (meaning2) {
-          source.forEach((symbol) => {
-            if (!getDeclarationOfKind(symbol, 280 /* ExportSpecifier */) && !getDeclarationOfKind(symbol, 279 /* NamespaceExport */)) {
-              copySymbol(symbol, meaning2);
-            }
-          });
-        }
-      }
-    }
-    function isTypeDeclarationName(name) {
-      return name.kind === 80 /* Identifier */ && isTypeDeclaration(name.parent) && getNameOfDeclaration(name.parent) === name;
-    }
-    function isTypeReferenceIdentifier(node) {
-      while (node.parent.kind === 165 /* QualifiedName */) {
-        node = node.parent;
-      }
-      return node.parent.kind === 182 /* TypeReference */;
-    }
-    function isInNameOfExpressionWithTypeArguments(node) {
-      while (node.parent.kind === 210 /* PropertyAccessExpression */) {
-        node = node.parent;
-      }
-      return node.parent.kind === 232 /* ExpressionWithTypeArguments */;
-    }
-    function forEachEnclosingClass(node, callback) {
-      let result;
-      let containingClass = getContainingClass(node);
-      while (containingClass) {
-        if (result = callback(containingClass))
-          break;
-        containingClass = getContainingClass(containingClass);
-      }
-      return result;
-    }
-    function isNodeUsedDuringClassInitialization(node) {
-      return !!findAncestor(node, (element) => {
-        if (isConstructorDeclaration(element) && nodeIsPresent(element.body) || isPropertyDeclaration(element)) {
-          return true;
-        } else if (isClassLike(element) || isFunctionLikeDeclaration(element)) {
-          return "quit";
-        }
-        return false;
-      });
-    }
-    function isNodeWithinClass(node, classDeclaration) {
-      return !!forEachEnclosingClass(node, (n) => n === classDeclaration);
-    }
-    function getLeftSideOfImportEqualsOrExportAssignment(nodeOnRightSide) {
-      while (nodeOnRightSide.parent.kind === 165 /* QualifiedName */) {
-        nodeOnRightSide = nodeOnRightSide.parent;
-      }
-      if (nodeOnRightSide.parent.kind === 270 /* ImportEqualsDeclaration */) {
-        return nodeOnRightSide.parent.moduleReference === nodeOnRightSide ? nodeOnRightSide.parent : void 0;
-      }
-      if (nodeOnRightSide.parent.kind === 276 /* ExportAssignment */) {
-        return nodeOnRightSide.parent.expression === nodeOnRightSide ? nodeOnRightSide.parent : void 0;
-      }
-      return void 0;
-    }
-    function isInRightSideOfImportOrExportAssignment(node) {
-      return getLeftSideOfImportEqualsOrExportAssignment(node) !== void 0;
-    }
-    function getSpecialPropertyAssignmentSymbolFromEntityName(entityName) {
-      const specialPropertyAssignmentKind = getAssignmentDeclarationKind(entityName.parent.parent);
-      switch (specialPropertyAssignmentKind) {
-        case 1 /* ExportsProperty */:
-        case 3 /* PrototypeProperty */:
-          return getSymbolOfNode(entityName.parent);
-        case 4 /* ThisProperty */:
-        case 2 /* ModuleExports */:
-        case 5 /* Property */:
-          return getSymbolOfDeclaration(entityName.parent.parent);
-      }
-    }
-    function isImportTypeQualifierPart(node) {
-      let parent2 = node.parent;
-      while (isQualifiedName(parent2)) {
-        node = parent2;
-        parent2 = parent2.parent;
-      }
-      if (parent2 && parent2.kind === 204 /* ImportType */ && parent2.qualifier === node) {
-        return parent2;
-      }
-      return void 0;
-    }
-    function isThisPropertyAndThisTyped(node) {
-      if (node.expression.kind === 110 /* ThisKeyword */) {
-        const container = getThisContainer(
-          node,
-          /*includeArrowFunctions*/
-          false,
-          /*includeClassComputedPropertyName*/
-          false
-        );
-        if (isFunctionLike(container)) {
-          const containingLiteral = getContainingObjectLiteral(container);
-          if (containingLiteral) {
-            const contextualType = getApparentTypeOfContextualType(
-              containingLiteral,
-              /*contextFlags*/
-              void 0
-            );
-            const type = contextualType && getThisTypeFromContextualType(contextualType);
-            return type && !isTypeAny(type);
-          }
-        }
-      }
-    }
-    function getSymbolOfNameOrPropertyAccessExpression(name) {
-      if (isDeclarationName(name)) {
-        return getSymbolOfNode(name.parent);
-      }
-      if (isInJSFile(name) && name.parent.kind === 210 /* PropertyAccessExpression */ && name.parent === name.parent.parent.left) {
-        if (!isPrivateIdentifier(name) && !isJSDocMemberName(name) && !isThisPropertyAndThisTyped(name.parent)) {
-          const specialPropertyAssignmentSymbol = getSpecialPropertyAssignmentSymbolFromEntityName(name);
-          if (specialPropertyAssignmentSymbol) {
-            return specialPropertyAssignmentSymbol;
-          }
-        }
-      }
-      if (name.parent.kind === 276 /* ExportAssignment */ && isEntityNameExpression(name)) {
-        const success = resolveEntityName(
-          name,
-          /*all meanings*/
-          111551 /* Value */ | 788968 /* Type */ | 1920 /* Namespace */ | 2097152 /* Alias */,
-          /*ignoreErrors*/
-          true
-        );
-        if (success && success !== unknownSymbol) {
-          return success;
-        }
-      } else if (isEntityName(name) && isInRightSideOfImportOrExportAssignment(name)) {
-        const importEqualsDeclaration = getAncestor(name, 270 /* ImportEqualsDeclaration */);
-        Debug.assert(importEqualsDeclaration !== void 0);
-        return getSymbolOfPartOfRightHandSideOfImportEquals(
-          name,
-          /*dontResolveAlias*/
-          true
-        );
-      }
-      if (isEntityName(name)) {
-        const possibleImportNode = isImportTypeQualifierPart(name);
-        if (possibleImportNode) {
-          getTypeFromTypeNode(possibleImportNode);
-          const sym = getNodeLinks(name).resolvedSymbol;
-          return sym === unknownSymbol ? void 0 : sym;
-        }
-      }
-      while (isRightSideOfQualifiedNameOrPropertyAccessOrJSDocMemberName(name)) {
-        name = name.parent;
-      }
-      if (isInNameOfExpressionWithTypeArguments(name)) {
-        let meaning = 0 /* None */;
-        if (name.parent.kind === 232 /* ExpressionWithTypeArguments */) {
-          meaning = isPartOfTypeNode(name) ? 788968 /* Type */ : 111551 /* Value */;
-          if (isExpressionWithTypeArgumentsInClassExtendsClause(name.parent)) {
-            meaning |= 111551 /* Value */;
-          }
-        } else {
-          meaning = 1920 /* Namespace */;
-        }
-        meaning |= 2097152 /* Alias */;
-        const entityNameSymbol = isEntityNameExpression(name) ? resolveEntityName(
-          name,
-          meaning,
-          /*ignoreErrors*/
-          true
-        ) : void 0;
-        if (entityNameSymbol) {
-          return entityNameSymbol;
-        }
-      }
-      if (name.parent.kind === 347 /* JSDocParameterTag */) {
-        return getParameterSymbolFromJSDoc(name.parent);
-      }
-      if (name.parent.kind === 167 /* TypeParameter */ && name.parent.parent.kind === 351 /* JSDocTemplateTag */) {
-        Debug.assert(!isInJSFile(name));
-        const typeParameter = getTypeParameterFromJsDoc(name.parent);
-        return typeParameter && typeParameter.symbol;
-      }
-      if (isExpressionNode(name)) {
-        if (nodeIsMissing(name)) {
-          return void 0;
-        }
-        const isJSDoc2 = findAncestor(name, or(isJSDocLinkLike, isJSDocNameReference, isJSDocMemberName));
-        const meaning = isJSDoc2 ? 788968 /* Type */ | 1920 /* Namespace */ | 111551 /* Value */ : 111551 /* Value */;
-        if (name.kind === 80 /* Identifier */) {
-          if (isJSXTagName(name) && isJsxIntrinsicTagName(name)) {
-            const symbol = getIntrinsicTagSymbol(name.parent);
-            return symbol === unknownSymbol ? void 0 : symbol;
-          }
-          const result = resolveEntityName(
-            name,
-            meaning,
-            /*ignoreErrors*/
-            true,
-            /*dontResolveAlias*/
-            true,
-            getHostSignatureFromJSDoc(name)
-          );
-          if (!result && isJSDoc2) {
-            const container = findAncestor(name, or(isClassLike, isInterfaceDeclaration));
-            if (container) {
-              return resolveJSDocMemberName(
-                name,
-                /*ignoreErrors*/
-                true,
-                getSymbolOfDeclaration(container)
-              );
-            }
-          }
-          if (result && isJSDoc2) {
-            const container = getJSDocHost(name);
-            if (container && isEnumMember(container) && container === result.valueDeclaration) {
-              return resolveEntityName(
-                name,
-                meaning,
-                /*ignoreErrors*/
-                true,
-                /*dontResolveAlias*/
-                true,
-                getSourceFileOfNode(container)
-              ) || result;
-            }
-          }
-          return result;
-        } else if (isPrivateIdentifier(name)) {
-          return getSymbolForPrivateIdentifierExpression(name);
-        } else if (name.kind === 210 /* PropertyAccessExpression */ || name.kind === 165 /* QualifiedName */) {
-          const links = getNodeLinks(name);
-          if (links.resolvedSymbol) {
-            return links.resolvedSymbol;
-          }
-          if (name.kind === 210 /* PropertyAccessExpression */) {
-            checkPropertyAccessExpression(name, 0 /* Normal */);
-            if (!links.resolvedSymbol) {
-              const expressionType = checkExpressionCached(name.expression);
-              const infos = getApplicableIndexInfos(expressionType, getLiteralTypeFromPropertyName(name.name));
-              if (infos.length && expressionType.members) {
-                const resolved = resolveStructuredTypeMembers(expressionType);
-                const symbol = resolved.members.get("__index" /* Index */);
-                if (infos === getIndexInfosOfType(expressionType)) {
-                  links.resolvedSymbol = symbol;
-                } else if (symbol) {
-                  const symbolLinks2 = getSymbolLinks(symbol);
-                  const declarationList = mapDefined(infos, (i) => i.declaration);
-                  const nodeListId = map(declarationList, getNodeId).join(",");
-                  if (!symbolLinks2.filteredIndexSymbolCache) {
-                    symbolLinks2.filteredIndexSymbolCache = /* @__PURE__ */ new Map();
-                  }
-                  if (symbolLinks2.filteredIndexSymbolCache.has(nodeListId)) {
-                    links.resolvedSymbol = symbolLinks2.filteredIndexSymbolCache.get(nodeListId);
-                  } else {
-                    const copy = createSymbol(131072 /* Signature */, "__index" /* Index */);
-                    copy.declarations = mapDefined(infos, (i) => i.declaration);
-                    copy.parent = expressionType.aliasSymbol ? expressionType.aliasSymbol : expressionType.symbol ? expressionType.symbol : getSymbolAtLocation(copy.declarations[0].parent);
-                    symbolLinks2.filteredIndexSymbolCache.set(nodeListId, copy);
-                    links.resolvedSymbol = symbolLinks2.filteredIndexSymbolCache.get(nodeListId);
-                  }
-                }
-              }
-            }
-          } else {
-            checkQualifiedName(name, 0 /* Normal */);
-          }
-          if (!links.resolvedSymbol && isJSDoc2 && isQualifiedName(name)) {
-            return resolveJSDocMemberName(name);
-          }
-          return links.resolvedSymbol;
-        } else if (isJSDocMemberName(name)) {
-          return resolveJSDocMemberName(name);
-        }
-      } else if (isTypeReferenceIdentifier(name)) {
-        const meaning = name.parent.kind === 182 /* TypeReference */ ? 788968 /* Type */ : 1920 /* Namespace */;
-        const symbol = resolveEntityName(
-          name,
-          meaning,
-          /*ignoreErrors*/
-          false,
-          /*dontResolveAlias*/
-          true
-        );
-        return symbol && symbol !== unknownSymbol ? symbol : getUnresolvedSymbolForEntityName(name);
-      }
-      if (name.parent.kind === 181 /* TypePredicate */) {
-        return resolveEntityName(
-          name,
-          /*meaning*/
-          1 /* FunctionScopedVariable */
-        );
-      }
-      return void 0;
-    }
-    function resolveJSDocMemberName(name, ignoreErrors, container) {
-      if (isEntityName(name)) {
-        const meaning = 788968 /* Type */ | 1920 /* Namespace */ | 111551 /* Value */;
-        let symbol = resolveEntityName(
-          name,
-          meaning,
-          ignoreErrors,
-          /*dontResolveAlias*/
-          true,
-          getHostSignatureFromJSDoc(name)
-        );
-        if (!symbol && isIdentifier(name) && container) {
-          symbol = getMergedSymbol(getSymbol2(getExportsOfSymbol(container), name.escapedText, meaning));
-        }
-        if (symbol) {
-          return symbol;
-        }
-      }
-      const left = isIdentifier(name) ? container : resolveJSDocMemberName(name.left, ignoreErrors, container);
-      const right = isIdentifier(name) ? name.escapedText : name.right.escapedText;
-      if (left) {
-        const proto = left.flags & 111551 /* Value */ && getPropertyOfType(getTypeOfSymbol(left), "prototype");
-        const t = proto ? getTypeOfSymbol(proto) : getDeclaredTypeOfSymbol(left);
-        return getPropertyOfType(t, right);
-      }
-    }
-    function getSymbolAtLocation(node, ignoreErrors) {
-      if (isSourceFile(node)) {
-        return isExternalModule(node) ? getMergedSymbol(node.symbol) : void 0;
-      }
-      const { parent: parent2 } = node;
-      const grandParent = parent2.parent;
-      if (node.flags & 33554432 /* InWithStatement */) {
-        return void 0;
-      }
-      if (isDeclarationNameOrImportPropertyName(node)) {
-        const parentSymbol = getSymbolOfDeclaration(parent2);
-        return isImportOrExportSpecifier(node.parent) && node.parent.propertyName === node ? getImmediateAliasedSymbol(parentSymbol) : parentSymbol;
-      } else if (isLiteralComputedPropertyDeclarationName(node)) {
-        return getSymbolOfDeclaration(parent2.parent);
-      }
-      if (node.kind === 80 /* Identifier */) {
-        if (isInRightSideOfImportOrExportAssignment(node)) {
-          return getSymbolOfNameOrPropertyAccessExpression(node);
-        } else if (parent2.kind === 207 /* BindingElement */ && grandParent.kind === 205 /* ObjectBindingPattern */ && node === parent2.propertyName) {
-          const typeOfPattern = getTypeOfNode(grandParent);
-          const propertyDeclaration = getPropertyOfType(typeOfPattern, node.escapedText);
-          if (propertyDeclaration) {
-            return propertyDeclaration;
-          }
-        } else if (isMetaProperty(parent2) && parent2.name === node) {
-          if (parent2.keywordToken === 105 /* NewKeyword */ && idText(node) === "target") {
-            return checkNewTargetMetaProperty(parent2).symbol;
-          }
-          if (parent2.keywordToken === 102 /* ImportKeyword */ && idText(node) === "meta") {
-            return getGlobalImportMetaExpressionType().members.get("meta");
-          }
-          return void 0;
-        }
-      }
-      switch (node.kind) {
-        case 80 /* Identifier */:
-        case 81 /* PrivateIdentifier */:
-        case 210 /* PropertyAccessExpression */:
-        case 165 /* QualifiedName */:
-          if (!isThisInTypeQuery(node)) {
-            return getSymbolOfNameOrPropertyAccessExpression(node);
-          }
-        case 110 /* ThisKeyword */:
-          const container = getThisContainer(
-            node,
-            /*includeArrowFunctions*/
-            false,
-            /*includeClassComputedPropertyName*/
-            false
-          );
-          if (isFunctionLike(container)) {
-            const sig = getSignatureFromDeclaration(container);
-            if (sig.thisParameter) {
-              return sig.thisParameter;
-            }
-          }
-          if (isInExpressionContext(node)) {
-            return checkExpression(node).symbol;
-          }
-        case 196 /* ThisType */:
-          return getTypeFromThisTypeNode(node).symbol;
-        case 108 /* SuperKeyword */:
-          return checkExpression(node).symbol;
-        case 137 /* ConstructorKeyword */:
-          const constructorDeclaration = node.parent;
-          if (constructorDeclaration && constructorDeclaration.kind === 175 /* Constructor */) {
-            return constructorDeclaration.parent.symbol;
-          }
-          return void 0;
-        case 11 /* StringLiteral */:
-        case 15 /* NoSubstitutionTemplateLiteral */:
-          if (isExternalModuleImportEqualsDeclaration(node.parent.parent) && getExternalModuleImportEqualsDeclarationExpression(node.parent.parent) === node || (node.parent.kind === 271 /* ImportDeclaration */ || node.parent.kind === 277 /* ExportDeclaration */) && node.parent.moduleSpecifier === node || (isInJSFile(node) && getEmitModuleResolutionKind(compilerOptions) !== 100 /* Bundler */ && isRequireCall(
-            node.parent,
-            /*requireStringLiteralLikeArgument*/
-            false
-          ) || isImportCall(node.parent)) || isLiteralTypeNode(node.parent) && isLiteralImportTypeNode(node.parent.parent) && node.parent.parent.argument === node.parent) {
-            return resolveExternalModuleName(node, node, ignoreErrors);
-          }
-          if (isCallExpression(parent2) && isBindableObjectDefinePropertyCall(parent2) && parent2.arguments[1] === node) {
-            return getSymbolOfDeclaration(parent2);
-          }
-        case 9 /* NumericLiteral */:
-          const objectType = isElementAccessExpression(parent2) ? parent2.argumentExpression === node ? getTypeOfExpression(parent2.expression) : void 0 : isLiteralTypeNode(parent2) && isIndexedAccessTypeNode(grandParent) ? getTypeFromTypeNode(grandParent.objectType) : void 0;
-          return objectType && getPropertyOfType(objectType, escapeLeadingUnderscores(node.text));
-        case 90 /* DefaultKeyword */:
-        case 100 /* FunctionKeyword */:
-        case 39 /* EqualsGreaterThanToken */:
-        case 86 /* ClassKeyword */:
-          return getSymbolOfNode(node.parent);
-        case 204 /* ImportType */:
-          return isLiteralImportTypeNode(node) ? getSymbolAtLocation(node.argument.literal, ignoreErrors) : void 0;
-        case 95 /* ExportKeyword */:
-          return isExportAssignment(node.parent) ? Debug.checkDefined(node.parent.symbol) : void 0;
-        case 102 /* ImportKeyword */:
-        case 105 /* NewKeyword */:
-          return isMetaProperty(node.parent) ? checkMetaPropertyKeyword(node.parent).symbol : void 0;
-        case 235 /* MetaProperty */:
-          return checkExpression(node).symbol;
-        case 294 /* JsxNamespacedName */:
-          if (isJSXTagName(node) && isJsxIntrinsicTagName(node)) {
-            const symbol = getIntrinsicTagSymbol(node.parent);
-            return symbol === unknownSymbol ? void 0 : symbol;
-          }
-        default:
-          return void 0;
-      }
-    }
-    function getIndexInfosAtLocation(node) {
-      if (isIdentifier(node) && isPropertyAccessExpression(node.parent) && node.parent.name === node) {
-        const keyType = getLiteralTypeFromPropertyName(node);
-        const objectType = getTypeOfExpression(node.parent.expression);
-        const objectTypes = objectType.flags & 1048576 /* Union */ ? objectType.types : [objectType];
-        return flatMap(objectTypes, (t) => filter(getIndexInfosOfType(t), (info) => isApplicableIndexType(keyType, info.keyType)));
-      }
-      return void 0;
-    }
-    function getShorthandAssignmentValueSymbol(location) {
-      if (location && location.kind === 303 /* ShorthandPropertyAssignment */) {
-        return resolveEntityName(location.name, 111551 /* Value */ | 2097152 /* Alias */);
-      }
-      return void 0;
-    }
-    function getExportSpecifierLocalTargetSymbol(node) {
-      if (isExportSpecifier(node)) {
-        return node.parent.parent.moduleSpecifier ? getExternalModuleMember(node.parent.parent, node) : resolveEntityName(node.propertyName || node.name, 111551 /* Value */ | 788968 /* Type */ | 1920 /* Namespace */ | 2097152 /* Alias */);
-      } else {
-        return resolveEntityName(node, 111551 /* Value */ | 788968 /* Type */ | 1920 /* Namespace */ | 2097152 /* Alias */);
-      }
-    }
-    function getTypeOfNode(node) {
-      if (isSourceFile(node) && !isExternalModule(node)) {
-        return errorType;
-      }
-      if (node.flags & 33554432 /* InWithStatement */) {
-        return errorType;
-      }
-      const classDecl = tryGetClassImplementingOrExtendingExpressionWithTypeArguments(node);
-      const classType = classDecl && getDeclaredTypeOfClassOrInterface(getSymbolOfDeclaration(classDecl.class));
-      if (isPartOfTypeNode(node)) {
-        const typeFromTypeNode = getTypeFromTypeNode(node);
-        return classType ? getTypeWithThisArgument(typeFromTypeNode, classType.thisType) : typeFromTypeNode;
-      }
-      if (isExpressionNode(node)) {
-        return getRegularTypeOfExpression(node);
-      }
-      if (classType && !classDecl.isImplements) {
-        const baseType = firstOrUndefined(getBaseTypes(classType));
-        return baseType ? getTypeWithThisArgument(baseType, classType.thisType) : errorType;
-      }
-      if (isTypeDeclaration(node)) {
-        const symbol = getSymbolOfDeclaration(node);
-        return getDeclaredTypeOfSymbol(symbol);
-      }
-      if (isTypeDeclarationName(node)) {
-        const symbol = getSymbolAtLocation(node);
-        return symbol ? getDeclaredTypeOfSymbol(symbol) : errorType;
-      }
-      if (isBindingElement(node)) {
-        return getTypeForVariableLikeDeclaration(
-          node,
-          /*includeOptionality*/
-          true,
-          0 /* Normal */
-        ) || errorType;
-      }
-      if (isDeclaration(node)) {
-        const symbol = getSymbolOfDeclaration(node);
-        return symbol ? getTypeOfSymbol(symbol) : errorType;
-      }
-      if (isDeclarationNameOrImportPropertyName(node)) {
-        const symbol = getSymbolAtLocation(node);
-        if (symbol) {
-          return getTypeOfSymbol(symbol);
-        }
-        return errorType;
-      }
-      if (isBindingPattern(node)) {
-        return getTypeForVariableLikeDeclaration(
-          node.parent,
-          /*includeOptionality*/
-          true,
-          0 /* Normal */
-        ) || errorType;
-      }
-      if (isInRightSideOfImportOrExportAssignment(node)) {
-        const symbol = getSymbolAtLocation(node);
-        if (symbol) {
-          const declaredType = getDeclaredTypeOfSymbol(symbol);
-          return !isErrorType(declaredType) ? declaredType : getTypeOfSymbol(symbol);
-        }
-      }
-      if (isMetaProperty(node.parent) && node.parent.keywordToken === node.kind) {
-        return checkMetaPropertyKeyword(node.parent);
-      }
-      return errorType;
-    }
-    function getTypeOfAssignmentPattern(expr) {
-      Debug.assert(expr.kind === 209 /* ObjectLiteralExpression */ || expr.kind === 208 /* ArrayLiteralExpression */);
-      if (expr.parent.kind === 249 /* ForOfStatement */) {
-        const iteratedType = checkRightHandSideOfForOf(expr.parent);
-        return checkDestructuringAssignment(expr, iteratedType || errorType);
-      }
-      if (expr.parent.kind === 225 /* BinaryExpression */) {
-        const iteratedType = getTypeOfExpression(expr.parent.right);
-        return checkDestructuringAssignment(expr, iteratedType || errorType);
-      }
-      if (expr.parent.kind === 302 /* PropertyAssignment */) {
-        const node2 = cast(expr.parent.parent, isObjectLiteralExpression);
-        const typeOfParentObjectLiteral = getTypeOfAssignmentPattern(node2) || errorType;
-        const propertyIndex = indexOfNode(node2.properties, expr.parent);
-        return checkObjectLiteralDestructuringPropertyAssignment(node2, typeOfParentObjectLiteral, propertyIndex);
-      }
-      const node = cast(expr.parent, isArrayLiteralExpression);
-      const typeOfArrayLiteral = getTypeOfAssignmentPattern(node) || errorType;
-      const elementType = checkIteratedTypeOrElementType(65 /* Destructuring */, typeOfArrayLiteral, undefinedType, expr.parent) || errorType;
-      return checkArrayLiteralDestructuringElementAssignment(node, typeOfArrayLiteral, node.elements.indexOf(expr), elementType);
-    }
-    function getPropertySymbolOfDestructuringAssignment(location) {
-      const typeOfObjectLiteral = getTypeOfAssignmentPattern(cast(location.parent.parent, isAssignmentPattern));
-      return typeOfObjectLiteral && getPropertyOfType(typeOfObjectLiteral, location.escapedText);
-    }
-    function getRegularTypeOfExpression(expr) {
-      if (isRightSideOfQualifiedNameOrPropertyAccess(expr)) {
-        expr = expr.parent;
-      }
-      return getRegularTypeOfLiteralType(getTypeOfExpression(expr));
-    }
-    function getParentTypeOfClassElement(node) {
-      const classSymbol = getSymbolOfNode(node.parent);
-      return isStatic(node) ? getTypeOfSymbol(classSymbol) : getDeclaredTypeOfSymbol(classSymbol);
-    }
-    function getClassElementPropertyKeyType(element) {
-      const name = element.name;
-      switch (name.kind) {
-        case 80 /* Identifier */:
-          return getStringLiteralType(idText(name));
-        case 9 /* NumericLiteral */:
-        case 11 /* StringLiteral */:
-          return getStringLiteralType(name.text);
-        case 166 /* ComputedPropertyName */:
-          const nameType = checkComputedPropertyName(name);
-          return isTypeAssignableToKind(nameType, 12288 /* ESSymbolLike */) ? nameType : stringType;
-        default:
-          return Debug.fail("Unsupported property name.");
-      }
-    }
-    function getAugmentedPropertiesOfType(type) {
-      type = getApparentType(type);
-      const propsByName = createSymbolTable(getPropertiesOfType(type));
-      const functionType = getSignaturesOfType(type, 0 /* Call */).length ? globalCallableFunctionType : getSignaturesOfType(type, 1 /* Construct */).length ? globalNewableFunctionType : void 0;
-      if (functionType) {
-        forEach(getPropertiesOfType(functionType), (p) => {
-          if (!propsByName.has(p.escapedName)) {
-            propsByName.set(p.escapedName, p);
-          }
-        });
-      }
-      return getNamedMembers(propsByName);
-    }
-    function typeHasCallOrConstructSignatures(type) {
-      return getSignaturesOfType(type, 0 /* Call */).length !== 0 || getSignaturesOfType(type, 1 /* Construct */).length !== 0;
-    }
-    function getRootSymbols(symbol) {
-      const roots = getImmediateRootSymbols(symbol);
-      return roots ? flatMap(roots, getRootSymbols) : [symbol];
-    }
-    function getImmediateRootSymbols(symbol) {
-      if (getCheckFlags(symbol) & 6 /* Synthetic */) {
-        return mapDefined(getSymbolLinks(symbol).containingType.types, (type) => getPropertyOfType(type, symbol.escapedName));
-      } else if (symbol.flags & 33554432 /* Transient */) {
-        const { links: { leftSpread, rightSpread, syntheticOrigin } } = symbol;
-        return leftSpread ? [leftSpread, rightSpread] : syntheticOrigin ? [syntheticOrigin] : singleElementArray(tryGetTarget(symbol));
-      }
-      return void 0;
-    }
-    function tryGetTarget(symbol) {
-      let target;
-      let next = symbol;
-      while (next = getSymbolLinks(next).target) {
-        target = next;
-      }
-      return target;
-    }
-    function isArgumentsLocalBinding(nodeIn) {
-      if (isGeneratedIdentifier(nodeIn))
-        return false;
-      const node = getParseTreeNode(nodeIn, isIdentifier);
-      if (!node)
-        return false;
-      const parent2 = node.parent;
-      if (!parent2)
-        return false;
-      const isPropertyName2 = (isPropertyAccessExpression(parent2) || isPropertyAssignment(parent2)) && parent2.name === node;
-      return !isPropertyName2 && getReferencedValueSymbol(node) === argumentsSymbol;
-    }
-    function moduleExportsSomeValue(moduleReferenceExpression) {
-      let moduleSymbol = resolveExternalModuleName(moduleReferenceExpression.parent, moduleReferenceExpression);
-      if (!moduleSymbol || isShorthandAmbientModuleSymbol(moduleSymbol)) {
-        return true;
-      }
-      const hasExportAssignment = hasExportAssignmentSymbol(moduleSymbol);
-      moduleSymbol = resolveExternalModuleSymbol(moduleSymbol);
-      const symbolLinks2 = getSymbolLinks(moduleSymbol);
-      if (symbolLinks2.exportsSomeValue === void 0) {
-        symbolLinks2.exportsSomeValue = hasExportAssignment ? !!(moduleSymbol.flags & 111551 /* Value */) : forEachEntry(getExportsOfModule(moduleSymbol), isValue);
-      }
-      return symbolLinks2.exportsSomeValue;
-      function isValue(s) {
-        s = resolveSymbol(s);
-        return s && !!(getAllSymbolFlags(s) & 111551 /* Value */);
-      }
-    }
-    function isNameOfModuleOrEnumDeclaration(node) {
-      return isModuleOrEnumDeclaration(node.parent) && node === node.parent.name;
-    }
-    function getReferencedExportContainer(nodeIn, prefixLocals) {
-      var _a;
-      const node = getParseTreeNode(nodeIn, isIdentifier);
-      if (node) {
-        let symbol = getReferencedValueSymbol(
-          node,
-          /*startInDeclarationContainer*/
-          isNameOfModuleOrEnumDeclaration(node)
-        );
-        if (symbol) {
-          if (symbol.flags & 1048576 /* ExportValue */) {
-            const exportSymbol = getMergedSymbol(symbol.exportSymbol);
-            if (!prefixLocals && exportSymbol.flags & 944 /* ExportHasLocal */ && !(exportSymbol.flags & 3 /* Variable */)) {
-              return void 0;
-            }
-            symbol = exportSymbol;
-          }
-          const parentSymbol = getParentOfSymbol(symbol);
-          if (parentSymbol) {
-            if (parentSymbol.flags & 512 /* ValueModule */ && ((_a = parentSymbol.valueDeclaration) == null ? void 0 : _a.kind) === 311 /* SourceFile */) {
-              const symbolFile = parentSymbol.valueDeclaration;
-              const referenceFile = getSourceFileOfNode(node);
-              const symbolIsUmdExport = symbolFile !== referenceFile;
-              return symbolIsUmdExport ? void 0 : symbolFile;
-            }
-            return findAncestor(node.parent, (n) => isModuleOrEnumDeclaration(n) && getSymbolOfDeclaration(n) === parentSymbol);
-          }
-        }
-      }
-    }
-    function getReferencedImportDeclaration(nodeIn) {
-      const specifier = getIdentifierGeneratedImportReference(nodeIn);
-      if (specifier) {
-        return specifier;
-      }
-      const node = getParseTreeNode(nodeIn, isIdentifier);
-      if (node) {
-        const symbol = getReferencedValueOrAliasSymbol(node);
-        if (isNonLocalAlias(
-          symbol,
-          /*excludes*/
-          111551 /* Value */
-        ) && !getTypeOnlyAliasDeclaration(symbol, 111551 /* Value */)) {
-          return getDeclarationOfAliasSymbol(symbol);
-        }
-      }
-      return void 0;
-    }
-    function isSymbolOfDestructuredElementOfCatchBinding(symbol) {
-      return symbol.valueDeclaration && isBindingElement(symbol.valueDeclaration) && walkUpBindingElementsAndPatterns(symbol.valueDeclaration).parent.kind === 298 /* CatchClause */;
-    }
-    function isSymbolOfDeclarationWithCollidingName(symbol) {
-      if (symbol.flags & 418 /* BlockScoped */ && symbol.valueDeclaration && !isSourceFile(symbol.valueDeclaration)) {
-        const links = getSymbolLinks(symbol);
-        if (links.isDeclarationWithCollidingName === void 0) {
-          const container = getEnclosingBlockScopeContainer(symbol.valueDeclaration);
-          if (isStatementWithLocals(container) || isSymbolOfDestructuredElementOfCatchBinding(symbol)) {
-            const nodeLinks2 = getNodeLinks(symbol.valueDeclaration);
-            if (resolveName(
-              container.parent,
-              symbol.escapedName,
-              111551 /* Value */,
-              /*nameNotFoundMessage*/
-              void 0,
-              /*nameArg*/
-              void 0,
-              /*isUse*/
-              false
-            )) {
-              links.isDeclarationWithCollidingName = true;
-            } else if (nodeLinks2.flags & 16384 /* CapturedBlockScopedBinding */) {
-              const isDeclaredInLoop = nodeLinks2.flags & 32768 /* BlockScopedBindingInLoop */;
-              const inLoopInitializer = isIterationStatement(
-                container,
-                /*lookInLabeledStatements*/
-                false
-              );
-              const inLoopBodyBlock = container.kind === 240 /* Block */ && isIterationStatement(
-                container.parent,
-                /*lookInLabeledStatements*/
-                false
-              );
-              links.isDeclarationWithCollidingName = !isBlockScopedContainerTopLevel(container) && (!isDeclaredInLoop || !inLoopInitializer && !inLoopBodyBlock);
-            } else {
-              links.isDeclarationWithCollidingName = false;
-            }
-          }
-        }
-        return links.isDeclarationWithCollidingName;
-      }
-      return false;
-    }
-    function getReferencedDeclarationWithCollidingName(nodeIn) {
-      if (!isGeneratedIdentifier(nodeIn)) {
-        const node = getParseTreeNode(nodeIn, isIdentifier);
-        if (node) {
-          const symbol = getReferencedValueSymbol(node);
-          if (symbol && isSymbolOfDeclarationWithCollidingName(symbol)) {
-            return symbol.valueDeclaration;
-          }
-        }
-      }
-      return void 0;
-    }
-    function isDeclarationWithCollidingName(nodeIn) {
-      const node = getParseTreeNode(nodeIn, isDeclaration);
-      if (node) {
-        const symbol = getSymbolOfDeclaration(node);
-        if (symbol) {
-          return isSymbolOfDeclarationWithCollidingName(symbol);
-        }
-      }
-      return false;
-    }
-    function isValueAliasDeclaration(node) {
-      Debug.assert(canCollectSymbolAliasAccessabilityData);
-      switch (node.kind) {
-        case 270 /* ImportEqualsDeclaration */:
-          return isAliasResolvedToValue(getSymbolOfDeclaration(node));
-        case 272 /* ImportClause */:
-        case 273 /* NamespaceImport */:
-        case 275 /* ImportSpecifier */:
-        case 280 /* ExportSpecifier */:
-          const symbol = getSymbolOfDeclaration(node);
-          return !!symbol && isAliasResolvedToValue(symbol) && !getTypeOnlyAliasDeclaration(symbol, 111551 /* Value */);
-        case 277 /* ExportDeclaration */:
-          const exportClause = node.exportClause;
-          return !!exportClause && (isNamespaceExport(exportClause) || some(exportClause.elements, isValueAliasDeclaration));
-        case 276 /* ExportAssignment */:
-          return node.expression && node.expression.kind === 80 /* Identifier */ ? isAliasResolvedToValue(getSymbolOfDeclaration(node)) : true;
-      }
-      return false;
-    }
-    function isTopLevelValueImportEqualsWithEntityName(nodeIn) {
-      const node = getParseTreeNode(nodeIn, isImportEqualsDeclaration);
-      if (node === void 0 || node.parent.kind !== 311 /* SourceFile */ || !isInternalModuleImportEqualsDeclaration(node)) {
-        return false;
-      }
-      const isValue = isAliasResolvedToValue(getSymbolOfDeclaration(node));
-      return isValue && node.moduleReference && !nodeIsMissing(node.moduleReference);
-    }
-    function isAliasResolvedToValue(symbol) {
-      if (!symbol) {
-        return false;
-      }
-      const target = getExportSymbolOfValueSymbolIfExported(resolveAlias(symbol));
-      if (target === unknownSymbol) {
-        return true;
-      }
-      return !!((getAllSymbolFlags(target) ?? -1) & 111551 /* Value */) && (shouldPreserveConstEnums(compilerOptions) || !isConstEnumOrConstEnumOnlyModule(target));
-    }
-    function isConstEnumOrConstEnumOnlyModule(s) {
-      return isConstEnumSymbol(s) || !!s.constEnumOnlyModule;
-    }
-    function isReferencedAliasDeclaration(node, checkChildren) {
-      Debug.assert(canCollectSymbolAliasAccessabilityData);
-      if (isAliasSymbolDeclaration2(node)) {
-        const symbol = getSymbolOfDeclaration(node);
-        const links = symbol && getSymbolLinks(symbol);
-        if (links == null ? void 0 : links.referenced) {
-          return true;
-        }
-        const target = getSymbolLinks(symbol).aliasTarget;
-        if (target && getEffectiveModifierFlags(node) & 1 /* Export */ && getAllSymbolFlags(target) & 111551 /* Value */ && (shouldPreserveConstEnums(compilerOptions) || !isConstEnumOrConstEnumOnlyModule(target))) {
-          return true;
-        }
-      }
-      if (checkChildren) {
-        return !!forEachChild(node, (node2) => isReferencedAliasDeclaration(node2, checkChildren));
-      }
-      return false;
-    }
-    function isImplementationOfOverload(node) {
-      if (nodeIsPresent(node.body)) {
-        if (isGetAccessor(node) || isSetAccessor(node))
-          return false;
-        const symbol = getSymbolOfDeclaration(node);
-        const signaturesOfSymbol = getSignaturesOfSymbol(symbol);
-        return signaturesOfSymbol.length > 1 || // If there is single signature for the symbol, it is overload if that signature isn't coming from the node
-        // e.g.: function foo(a: string): string;
-        //       function foo(a: any) { // This is implementation of the overloads
-        //           return a;
-        //       }
-        signaturesOfSymbol.length === 1 && signaturesOfSymbol[0].declaration !== node;
-      }
-      return false;
-    }
-    function isRequiredInitializedParameter(parameter) {
-      return !!strictNullChecks && !isOptionalParameter(parameter) && !isJSDocParameterTag(parameter) && !!parameter.initializer && !hasSyntacticModifier(parameter, 16476 /* ParameterPropertyModifier */);
-    }
-    function isOptionalUninitializedParameterProperty(parameter) {
-      return strictNullChecks && isOptionalParameter(parameter) && !parameter.initializer && hasSyntacticModifier(parameter, 16476 /* ParameterPropertyModifier */);
-    }
-    function isExpandoFunctionDeclaration(node) {
-      const declaration = getParseTreeNode(node, isFunctionDeclaration);
-      if (!declaration) {
-        return false;
-      }
-      const symbol = getSymbolOfDeclaration(declaration);
-      if (!symbol || !(symbol.flags & 16 /* Function */)) {
-        return false;
-      }
-      return !!forEachEntry(getExportsOfSymbol(symbol), (p) => p.flags & 111551 /* Value */ && p.valueDeclaration && isPropertyAccessExpression(p.valueDeclaration));
-    }
-    function getPropertiesOfContainerFunction(node) {
-      const declaration = getParseTreeNode(node, isFunctionDeclaration);
-      if (!declaration) {
-        return emptyArray;
-      }
-      const symbol = getSymbolOfDeclaration(declaration);
-      return symbol && getPropertiesOfType(getTypeOfSymbol(symbol)) || emptyArray;
-    }
-    function getNodeCheckFlags(node) {
-      var _a;
-      const nodeId = node.id || 0;
-      if (nodeId < 0 || nodeId >= nodeLinks.length)
-        return 0;
-      return ((_a = nodeLinks[nodeId]) == null ? void 0 : _a.flags) || 0;
-    }
-    function getEnumMemberValue(node) {
-      computeEnumMemberValues(node.parent);
-      return getNodeLinks(node).enumMemberValue;
-    }
-    function canHaveConstantValue(node) {
-      switch (node.kind) {
-        case 305 /* EnumMember */:
-        case 210 /* PropertyAccessExpression */:
-        case 211 /* ElementAccessExpression */:
-          return true;
-      }
-      return false;
-    }
-    function getConstantValue2(node) {
-      if (node.kind === 305 /* EnumMember */) {
-        return getEnumMemberValue(node);
-      }
-      const symbol = getNodeLinks(node).resolvedSymbol;
-      if (symbol && symbol.flags & 8 /* EnumMember */) {
-        const member = symbol.valueDeclaration;
-        if (isEnumConst(member.parent)) {
-          return getEnumMemberValue(member);
-        }
-      }
-      return void 0;
-    }
-    function isFunctionType(type) {
-      return !!(type.flags & 524288 /* Object */) && getSignaturesOfType(type, 0 /* Call */).length > 0;
-    }
-    function getTypeReferenceSerializationKind(typeNameIn, location) {
-      var _a;
-      const typeName = getParseTreeNode(typeNameIn, isEntityName);
-      if (!typeName)
-        return 0 /* Unknown */;
-      if (location) {
-        location = getParseTreeNode(location);
-        if (!location)
-          return 0 /* Unknown */;
-      }
-      let isTypeOnly = false;
-      if (isQualifiedName(typeName)) {
-        const rootValueSymbol = resolveEntityName(
-          getFirstIdentifier(typeName),
-          111551 /* Value */,
-          /*ignoreErrors*/
-          true,
-          /*dontResolveAlias*/
-          true,
-          location
-        );
-        isTypeOnly = !!((_a = rootValueSymbol == null ? void 0 : rootValueSymbol.declarations) == null ? void 0 : _a.every(isTypeOnlyImportOrExportDeclaration));
-      }
-      const valueSymbol = resolveEntityName(
-        typeName,
-        111551 /* Value */,
-        /*ignoreErrors*/
-        true,
-        /*dontResolveAlias*/
-        true,
-        location
-      );
-      const resolvedSymbol = valueSymbol && valueSymbol.flags & 2097152 /* Alias */ ? resolveAlias(valueSymbol) : valueSymbol;
-      isTypeOnly || (isTypeOnly = !!(valueSymbol && getTypeOnlyAliasDeclaration(valueSymbol, 111551 /* Value */)));
-      const typeSymbol = resolveEntityName(
-        typeName,
-        788968 /* Type */,
-        /*ignoreErrors*/
-        true,
-        /*dontResolveAlias*/
-        false,
-        location
-      );
-      if (resolvedSymbol && resolvedSymbol === typeSymbol) {
-        const globalPromiseSymbol = getGlobalPromiseConstructorSymbol(
-          /*reportErrors*/
-          false
-        );
-        if (globalPromiseSymbol && resolvedSymbol === globalPromiseSymbol) {
-          return 9 /* Promise */;
-        }
-        const constructorType = getTypeOfSymbol(resolvedSymbol);
-        if (constructorType && isConstructorType(constructorType)) {
-          return isTypeOnly ? 10 /* TypeWithCallSignature */ : 1 /* TypeWithConstructSignatureAndValue */;
-        }
-      }
-      if (!typeSymbol) {
-        return isTypeOnly ? 11 /* ObjectType */ : 0 /* Unknown */;
-      }
-      const type = getDeclaredTypeOfSymbol(typeSymbol);
-      if (isErrorType(type)) {
-        return isTypeOnly ? 11 /* ObjectType */ : 0 /* Unknown */;
-      } else if (type.flags & 3 /* AnyOrUnknown */) {
-        return 11 /* ObjectType */;
-      } else if (isTypeAssignableToKind(type, 16384 /* Void */ | 98304 /* Nullable */ | 131072 /* Never */)) {
-        return 2 /* VoidNullableOrNeverType */;
-      } else if (isTypeAssignableToKind(type, 528 /* BooleanLike */)) {
-        return 6 /* BooleanType */;
-      } else if (isTypeAssignableToKind(type, 296 /* NumberLike */)) {
-        return 3 /* NumberLikeType */;
-      } else if (isTypeAssignableToKind(type, 2112 /* BigIntLike */)) {
-        return 4 /* BigIntLikeType */;
-      } else if (isTypeAssignableToKind(type, 402653316 /* StringLike */)) {
-        return 5 /* StringLikeType */;
-      } else if (isTupleType(type)) {
-        return 7 /* ArrayLikeType */;
-      } else if (isTypeAssignableToKind(type, 12288 /* ESSymbolLike */)) {
-        return 8 /* ESSymbolType */;
-      } else if (isFunctionType(type)) {
-        return 10 /* TypeWithCallSignature */;
-      } else if (isArrayType(type)) {
-        return 7 /* ArrayLikeType */;
-      } else {
-        return 11 /* ObjectType */;
-      }
-    }
-    function createTypeOfDeclaration(declarationIn, enclosingDeclaration, flags, tracker, addUndefined) {
-      const declaration = getParseTreeNode(declarationIn, isVariableLikeOrAccessor);
-      if (!declaration) {
-        return factory.createToken(133 /* AnyKeyword */);
-      }
-      const symbol = getSymbolOfDeclaration(declaration);
-      let type = symbol && !(symbol.flags & (2048 /* TypeLiteral */ | 131072 /* Signature */)) ? getWidenedLiteralType(getTypeOfSymbol(symbol)) : errorType;
-      if (type.flags & 8192 /* UniqueESSymbol */ && type.symbol === symbol) {
-        flags |= 1048576 /* AllowUniqueESSymbolType */;
-      }
-      if (addUndefined) {
-        type = getOptionalType(type);
-      }
-      return nodeBuilder.typeToTypeNode(type, enclosingDeclaration, flags | 1024 /* MultilineObjectLiterals */, tracker);
-    }
-    function createReturnTypeOfSignatureDeclaration(signatureDeclarationIn, enclosingDeclaration, flags, tracker) {
-      const signatureDeclaration = getParseTreeNode(signatureDeclarationIn, isFunctionLike);
-      if (!signatureDeclaration) {
-        return factory.createToken(133 /* AnyKeyword */);
-      }
-      const signature = getSignatureFromDeclaration(signatureDeclaration);
-      return nodeBuilder.typeToTypeNode(getReturnTypeOfSignature(signature), enclosingDeclaration, flags | 1024 /* MultilineObjectLiterals */, tracker);
-    }
-    function createTypeOfExpression(exprIn, enclosingDeclaration, flags, tracker) {
-      const expr = getParseTreeNode(exprIn, isExpression);
-      if (!expr) {
-        return factory.createToken(133 /* AnyKeyword */);
-      }
-      const type = getWidenedType(getRegularTypeOfExpression(expr));
-      return nodeBuilder.typeToTypeNode(type, enclosingDeclaration, flags | 1024 /* MultilineObjectLiterals */, tracker);
-    }
-    function hasGlobalName(name) {
-      return globals.has(escapeLeadingUnderscores(name));
-    }
-    function getReferencedValueSymbol(reference, startInDeclarationContainer) {
-      const resolvedSymbol = getNodeLinks(reference).resolvedSymbol;
-      if (resolvedSymbol) {
-        return resolvedSymbol;
-      }
-      let location = reference;
-      if (startInDeclarationContainer) {
-        const parent2 = reference.parent;
-        if (isDeclaration(parent2) && reference === parent2.name) {
-          location = getDeclarationContainer(parent2);
-        }
-      }
-      return resolveName(
-        location,
-        reference.escapedText,
-        111551 /* Value */ | 1048576 /* ExportValue */ | 2097152 /* Alias */,
-        /*nameNotFoundMessage*/
-        void 0,
-        /*nameArg*/
-        void 0,
-        /*isUse*/
-        true
-      );
-    }
-    function getReferencedValueOrAliasSymbol(reference) {
-      const resolvedSymbol = getNodeLinks(reference).resolvedSymbol;
-      if (resolvedSymbol && resolvedSymbol !== unknownSymbol) {
-        return resolvedSymbol;
-      }
-      return resolveName(
-        reference,
-        reference.escapedText,
-        111551 /* Value */ | 1048576 /* ExportValue */ | 2097152 /* Alias */,
-        /*nameNotFoundMessage*/
-        void 0,
-        /*nameArg*/
-        void 0,
-        /*isUse*/
-        true,
-        /*excludeGlobals*/
-        void 0,
-        /*getSpellingSuggestions*/
-        void 0
-      );
-    }
-    function getReferencedValueDeclaration(referenceIn) {
-      if (!isGeneratedIdentifier(referenceIn)) {
-        const reference = getParseTreeNode(referenceIn, isIdentifier);
-        if (reference) {
-          const symbol = getReferencedValueSymbol(reference);
-          if (symbol) {
-            return getExportSymbolOfValueSymbolIfExported(symbol).valueDeclaration;
-          }
-        }
-      }
-      return void 0;
-    }
-    function getReferencedValueDeclarations(referenceIn) {
-      if (!isGeneratedIdentifier(referenceIn)) {
-        const reference = getParseTreeNode(referenceIn, isIdentifier);
-        if (reference) {
-          const symbol = getReferencedValueSymbol(reference);
-          if (symbol) {
-            return filter(getExportSymbolOfValueSymbolIfExported(symbol).declarations, (declaration) => {
-              switch (declaration.kind) {
-                case 259 /* VariableDeclaration */:
-                case 168 /* Parameter */:
-                case 207 /* BindingElement */:
-                case 171 /* PropertyDeclaration */:
-                case 302 /* PropertyAssignment */:
-                case 303 /* ShorthandPropertyAssignment */:
-                case 305 /* EnumMember */:
-                case 209 /* ObjectLiteralExpression */:
-                case 261 /* FunctionDeclaration */:
-                case 217 /* FunctionExpression */:
-                case 218 /* ArrowFunction */:
-                case 262 /* ClassDeclaration */:
-                case 230 /* ClassExpression */:
-                case 265 /* EnumDeclaration */:
-                case 173 /* MethodDeclaration */:
-                case 176 /* GetAccessor */:
-                case 177 /* SetAccessor */:
-                case 266 /* ModuleDeclaration */:
-                  return true;
-              }
-              return false;
-            });
-          }
-        }
-      }
-      return void 0;
-    }
-    function isLiteralConstDeclaration(node) {
-      if (isDeclarationReadonly(node) || isVariableDeclaration(node) && isVarConst(node)) {
-        return isFreshLiteralType(getTypeOfSymbol(getSymbolOfDeclaration(node)));
-      }
-      return false;
-    }
-    function literalTypeToNode(type, enclosing, tracker) {
-      const enumResult = type.flags & 1056 /* EnumLike */ ? nodeBuilder.symbolToExpression(
-        type.symbol,
-        111551 /* Value */,
-        enclosing,
-        /*flags*/
-        void 0,
-        tracker
-      ) : type === trueType ? factory.createTrue() : type === falseType && factory.createFalse();
-      if (enumResult)
-        return enumResult;
-      const literalValue = type.value;
-      return typeof literalValue === "object" ? factory.createBigIntLiteral(literalValue) : typeof literalValue === "number" ? factory.createNumericLiteral(literalValue) : factory.createStringLiteral(literalValue);
-    }
-    function createLiteralConstValue(node, tracker) {
-      const type = getTypeOfSymbol(getSymbolOfDeclaration(node));
-      return literalTypeToNode(type, node, tracker);
-    }
-    function getJsxFactoryEntity(location) {
-      return location ? (getJsxNamespace(location), getSourceFileOfNode(location).localJsxFactory || _jsxFactoryEntity) : _jsxFactoryEntity;
-    }
-    function getJsxFragmentFactoryEntity(location) {
-      if (location) {
-        const file = getSourceFileOfNode(location);
-        if (file) {
-          if (file.localJsxFragmentFactory) {
-            return file.localJsxFragmentFactory;
-          }
-          const jsxFragPragmas = file.pragmas.get("jsxfrag");
-          const jsxFragPragma = isArray(jsxFragPragmas) ? jsxFragPragmas[0] : jsxFragPragmas;
-          if (jsxFragPragma) {
-            file.localJsxFragmentFactory = parseIsolatedEntityName(jsxFragPragma.arguments.factory, languageVersion);
-            return file.localJsxFragmentFactory;
-          }
-        }
-      }
-      if (compilerOptions.jsxFragmentFactory) {
-        return parseIsolatedEntityName(compilerOptions.jsxFragmentFactory, languageVersion);
-      }
-    }
-    function createResolver() {
-      const resolvedTypeReferenceDirectives = host.getResolvedTypeReferenceDirectives();
-      let fileToDirective;
-      if (resolvedTypeReferenceDirectives) {
-        fileToDirective = /* @__PURE__ */ new Map();
-        resolvedTypeReferenceDirectives.forEach(({ resolvedTypeReferenceDirective }, key, mode) => {
-          if (!(resolvedTypeReferenceDirective == null ? void 0 : resolvedTypeReferenceDirective.resolvedFileName)) {
-            return;
-          }
-          const file = host.getSourceFile(resolvedTypeReferenceDirective.resolvedFileName);
-          if (file) {
-            addReferencedFilesToTypeDirective(file, key, mode);
-          }
-        });
-      }
-      return {
-        getReferencedExportContainer,
-        getReferencedImportDeclaration,
-        getReferencedDeclarationWithCollidingName,
-        isDeclarationWithCollidingName,
-        isValueAliasDeclaration: (nodeIn) => {
-          const node = getParseTreeNode(nodeIn);
-          return node && canCollectSymbolAliasAccessabilityData ? isValueAliasDeclaration(node) : true;
-        },
-        hasGlobalName,
-        isReferencedAliasDeclaration: (nodeIn, checkChildren) => {
-          const node = getParseTreeNode(nodeIn);
-          return node && canCollectSymbolAliasAccessabilityData ? isReferencedAliasDeclaration(node, checkChildren) : true;
-        },
-        getNodeCheckFlags: (nodeIn) => {
-          const node = getParseTreeNode(nodeIn);
-          return node ? getNodeCheckFlags(node) : 0;
-        },
-        isTopLevelValueImportEqualsWithEntityName,
-        isDeclarationVisible,
-        isImplementationOfOverload,
-        isRequiredInitializedParameter,
-        isOptionalUninitializedParameterProperty,
-        isExpandoFunctionDeclaration,
-        getPropertiesOfContainerFunction,
-        createTypeOfDeclaration,
-        createReturnTypeOfSignatureDeclaration,
-        createTypeOfExpression,
-        createLiteralConstValue,
-        isSymbolAccessible,
-        isEntityNameVisible,
-        getConstantValue: (nodeIn) => {
-          const node = getParseTreeNode(nodeIn, canHaveConstantValue);
-          return node ? getConstantValue2(node) : void 0;
-        },
-        collectLinkedAliases,
-        getReferencedValueDeclaration,
-        getReferencedValueDeclarations,
-        getTypeReferenceSerializationKind,
-        isOptionalParameter,
-        moduleExportsSomeValue,
-        isArgumentsLocalBinding,
-        getExternalModuleFileFromDeclaration: (nodeIn) => {
-          const node = getParseTreeNode(nodeIn, hasPossibleExternalModuleReference);
-          return node && getExternalModuleFileFromDeclaration(node);
-        },
-        getTypeReferenceDirectivesForEntityName,
-        getTypeReferenceDirectivesForSymbol,
-        isLiteralConstDeclaration,
-        isLateBound: (nodeIn) => {
-          const node = getParseTreeNode(nodeIn, isDeclaration);
-          const symbol = node && getSymbolOfDeclaration(node);
-          return !!(symbol && getCheckFlags(symbol) & 4096 /* Late */);
-        },
-        getJsxFactoryEntity,
-        getJsxFragmentFactoryEntity,
-        getAllAccessorDeclarations(accessor) {
-          accessor = getParseTreeNode(accessor, isGetOrSetAccessorDeclaration);
-          const otherKind = accessor.kind === 177 /* SetAccessor */ ? 176 /* GetAccessor */ : 177 /* SetAccessor */;
-          const otherAccessor = getDeclarationOfKind(getSymbolOfDeclaration(accessor), otherKind);
-          const firstAccessor = otherAccessor && otherAccessor.pos < accessor.pos ? otherAccessor : accessor;
-          const secondAccessor = otherAccessor && otherAccessor.pos < accessor.pos ? accessor : otherAccessor;
-          const setAccessor = accessor.kind === 177 /* SetAccessor */ ? accessor : otherAccessor;
-          const getAccessor = accessor.kind === 176 /* GetAccessor */ ? accessor : otherAccessor;
-          return {
-            firstAccessor,
-            secondAccessor,
-            setAccessor,
-            getAccessor
-          };
-        },
-        getSymbolOfExternalModuleSpecifier: (moduleName) => resolveExternalModuleNameWorker(
-          moduleName,
-          moduleName,
-          /*moduleNotFoundError*/
-          void 0
-        ),
-        isBindingCapturedByNode: (node, decl) => {
-          const parseNode = getParseTreeNode(node);
-          const parseDecl = getParseTreeNode(decl);
-          return !!parseNode && !!parseDecl && (isVariableDeclaration(parseDecl) || isBindingElement(parseDecl)) && isBindingCapturedByNode(parseNode, parseDecl);
-        },
-        getDeclarationStatementsForSourceFile: (node, flags, tracker, bundled) => {
-          const n = getParseTreeNode(node);
-          Debug.assert(n && n.kind === 311 /* SourceFile */, "Non-sourcefile node passed into getDeclarationsForSourceFile");
-          const sym = getSymbolOfDeclaration(node);
-          if (!sym) {
-            return !node.locals ? [] : nodeBuilder.symbolTableToDeclarationStatements(node.locals, node, flags, tracker, bundled);
-          }
-          return !sym.exports ? [] : nodeBuilder.symbolTableToDeclarationStatements(sym.exports, node, flags, tracker, bundled);
-        },
-        isImportRequiredByAugmentation
-      };
-      function isImportRequiredByAugmentation(node) {
-        const file = getSourceFileOfNode(node);
-        if (!file.symbol)
-          return false;
-        const importTarget = getExternalModuleFileFromDeclaration(node);
-        if (!importTarget)
-          return false;
-        if (importTarget === file)
-          return false;
-        const exports = getExportsOfModule(file.symbol);
-        for (const s of arrayFrom(exports.values())) {
-          if (s.mergeId) {
-            const merged = getMergedSymbol(s);
-            if (merged.declarations) {
-              for (const d of merged.declarations) {
-                const declFile = getSourceFileOfNode(d);
-                if (declFile === importTarget) {
-                  return true;
-                }
-              }
-            }
-          }
-        }
-        return false;
-      }
-      function isInHeritageClause(node) {
-        return node.parent && node.parent.kind === 232 /* ExpressionWithTypeArguments */ && node.parent.parent && node.parent.parent.kind === 297 /* HeritageClause */;
-      }
-      function getTypeReferenceDirectivesForEntityName(node) {
-        if (!fileToDirective) {
-          return void 0;
-        }
-        let meaning;
-        if (node.parent.kind === 166 /* ComputedPropertyName */) {
-          meaning = 111551 /* Value */ | 1048576 /* ExportValue */;
-        } else {
-          meaning = 788968 /* Type */ | 1920 /* Namespace */;
-          if (node.kind === 80 /* Identifier */ && isInTypeQuery(node) || node.kind === 210 /* PropertyAccessExpression */ && !isInHeritageClause(node)) {
-            meaning = 111551 /* Value */ | 1048576 /* ExportValue */;
-          }
-        }
-        const symbol = resolveEntityName(
-          node,
-          meaning,
-          /*ignoreErrors*/
-          true
-        );
-        return symbol && symbol !== unknownSymbol ? getTypeReferenceDirectivesForSymbol(symbol, meaning) : void 0;
-      }
-      function getTypeReferenceDirectivesForSymbol(symbol, meaning) {
-        if (!fileToDirective || !isSymbolFromTypeDeclarationFile(symbol)) {
-          return void 0;
-        }
-        let typeReferenceDirectives;
-        for (const decl of symbol.declarations) {
-          if (decl.symbol && decl.symbol.flags & meaning) {
-            const file = getSourceFileOfNode(decl);
-            const typeReferenceDirective = fileToDirective.get(file.path);
-            if (typeReferenceDirective) {
-              (typeReferenceDirectives || (typeReferenceDirectives = [])).push(typeReferenceDirective);
-            } else {
-              return void 0;
-            }
-          }
-        }
-        return typeReferenceDirectives;
-      }
-      function isSymbolFromTypeDeclarationFile(symbol) {
-        if (!symbol.declarations) {
-          return false;
-        }
-        let current = symbol;
-        while (true) {
-          const parent2 = getParentOfSymbol(current);
-          if (parent2) {
-            current = parent2;
-          } else {
-            break;
-          }
-        }
-        if (current.valueDeclaration && current.valueDeclaration.kind === 311 /* SourceFile */ && current.flags & 512 /* ValueModule */) {
-          return false;
-        }
-        for (const decl of symbol.declarations) {
-          const file = getSourceFileOfNode(decl);
-          if (fileToDirective.has(file.path)) {
-            return true;
-          }
-        }
-        return false;
-      }
-      function addReferencedFilesToTypeDirective(file, key, mode) {
-        if (fileToDirective.has(file.path))
-          return;
-        fileToDirective.set(file.path, [key, mode]);
-        for (const { fileName, resolutionMode } of file.referencedFiles) {
-          const resolvedFile = resolveTripleslashReference(fileName, file.fileName);
-          const referencedFile = host.getSourceFile(resolvedFile);
-          if (referencedFile) {
-            addReferencedFilesToTypeDirective(referencedFile, key, resolutionMode || file.impliedNodeFormat);
-          }
-        }
-      }
-    }
-    function getExternalModuleFileFromDeclaration(declaration) {
-      const specifier = declaration.kind === 266 /* ModuleDeclaration */ ? tryCast(declaration.name, isStringLiteral) : getExternalModuleName(declaration);
-      const moduleSymbol = resolveExternalModuleNameWorker(
-        specifier,
-        specifier,
-        /*moduleNotFoundError*/
-        void 0
-      );
-      if (!moduleSymbol) {
-        return void 0;
-      }
-      return getDeclarationOfKind(moduleSymbol, 311 /* SourceFile */);
-    }
-    function initializeTypeChecker() {
-      for (const file of host.getSourceFiles()) {
-        bindSourceFile(file, compilerOptions);
-      }
-      amalgamatedDuplicates = /* @__PURE__ */ new Map();
-      let augmentations;
-      for (const file of host.getSourceFiles()) {
-        if (file.redirectInfo) {
-          continue;
-        }
-        if (!isExternalOrCommonJsModule(file)) {
-          const fileGlobalThisSymbol = file.locals.get("globalThis");
-          if (fileGlobalThisSymbol == null ? void 0 : fileGlobalThisSymbol.declarations) {
-            for (const declaration of fileGlobalThisSymbol.declarations) {
-              diagnostics.add(createDiagnosticForNode(declaration, Diagnostics.Declaration_name_conflicts_with_built_in_global_identifier_0, "globalThis"));
-            }
-          }
-          mergeSymbolTable(globals, file.locals);
-        }
-        if (file.jsGlobalAugmentations) {
-          mergeSymbolTable(globals, file.jsGlobalAugmentations);
-        }
-        if (file.patternAmbientModules && file.patternAmbientModules.length) {
-          patternAmbientModules = concatenate(patternAmbientModules, file.patternAmbientModules);
-        }
-        if (file.moduleAugmentations.length) {
-          (augmentations || (augmentations = [])).push(file.moduleAugmentations);
-        }
-        if (file.symbol && file.symbol.globalExports) {
-          const source = file.symbol.globalExports;
-          source.forEach((sourceSymbol, id) => {
-            if (!globals.has(id)) {
-              globals.set(id, sourceSymbol);
-            }
-          });
-        }
-      }
-      if (augmentations) {
-        for (const list of augmentations) {
-          for (const augmentation of list) {
-            if (!isGlobalScopeAugmentation(augmentation.parent))
-              continue;
-            mergeModuleAugmentation(augmentation);
-          }
-        }
-      }
-      addToSymbolTable(globals, builtinGlobals, Diagnostics.Declaration_name_conflicts_with_built_in_global_identifier_0);
-      getSymbolLinks(undefinedSymbol).type = undefinedWideningType;
-      getSymbolLinks(argumentsSymbol).type = getGlobalType(
-        "IArguments",
-        /*arity*/
-        0,
-        /*reportErrors*/
-        true
-      );
-      getSymbolLinks(unknownSymbol).type = errorType;
-      getSymbolLinks(globalThisSymbol).type = createObjectType(16 /* Anonymous */, globalThisSymbol);
-      globalArrayType = getGlobalType(
-        "Array",
-        /*arity*/
-        1,
-        /*reportErrors*/
-        true
-      );
-      globalObjectType = getGlobalType(
-        "Object",
-        /*arity*/
-        0,
-        /*reportErrors*/
-        true
-      );
-      globalFunctionType = getGlobalType(
-        "Function",
-        /*arity*/
-        0,
-        /*reportErrors*/
-        true
-      );
-      globalCallableFunctionType = strictBindCallApply && getGlobalType(
-        "CallableFunction",
-        /*arity*/
-        0,
-        /*reportErrors*/
-        true
-      ) || globalFunctionType;
-      globalNewableFunctionType = strictBindCallApply && getGlobalType(
-        "NewableFunction",
-        /*arity*/
-        0,
-        /*reportErrors*/
-        true
-      ) || globalFunctionType;
-      globalStringType = getGlobalType(
-        "String",
-        /*arity*/
-        0,
-        /*reportErrors*/
-        true
-      );
-      globalNumberType = getGlobalType(
-        "Number",
-        /*arity*/
-        0,
-        /*reportErrors*/
-        true
-      );
-      globalBooleanType = getGlobalType(
-        "Boolean",
-        /*arity*/
-        0,
-        /*reportErrors*/
-        true
-      );
-      globalRegExpType = getGlobalType(
-        "RegExp",
-        /*arity*/
-        0,
-        /*reportErrors*/
-        true
-      );
-      anyArrayType = createArrayType(anyType);
-      autoArrayType = createArrayType(autoType);
-      if (autoArrayType === emptyObjectType) {
-        autoArrayType = createAnonymousType(
-          /*symbol*/
-          void 0,
-          emptySymbols,
-          emptyArray,
-          emptyArray,
-          emptyArray
-        );
-      }
-      globalReadonlyArrayType = getGlobalTypeOrUndefined(
-        "ReadonlyArray",
-        /*arity*/
-        1
-      ) || globalArrayType;
-      anyReadonlyArrayType = globalReadonlyArrayType ? createTypeFromGenericGlobalType(globalReadonlyArrayType, [anyType]) : anyArrayType;
-      globalThisType = getGlobalTypeOrUndefined(
-        "ThisType",
-        /*arity*/
-        1
-      );
-      if (augmentations) {
-        for (const list of augmentations) {
-          for (const augmentation of list) {
-            if (isGlobalScopeAugmentation(augmentation.parent))
-              continue;
-            mergeModuleAugmentation(augmentation);
-          }
-        }
-      }
-      amalgamatedDuplicates.forEach(({ firstFile, secondFile, conflictingSymbols }) => {
-        if (conflictingSymbols.size < 8) {
-          conflictingSymbols.forEach(({ isBlockScoped, firstFileLocations, secondFileLocations }, symbolName2) => {
-            const message = isBlockScoped ? Diagnostics.Cannot_redeclare_block_scoped_variable_0 : Diagnostics.Duplicate_identifier_0;
-            for (const node of firstFileLocations) {
-              addDuplicateDeclarationError(node, message, symbolName2, secondFileLocations);
-            }
-            for (const node of secondFileLocations) {
-              addDuplicateDeclarationError(node, message, symbolName2, firstFileLocations);
-            }
-          });
-        } else {
-          const list = arrayFrom(conflictingSymbols.keys()).join(", ");
-          diagnostics.add(addRelatedInfo(
-            createDiagnosticForNode(firstFile, Diagnostics.Definitions_of_the_following_identifiers_conflict_with_those_in_another_file_Colon_0, list),
-            createDiagnosticForNode(secondFile, Diagnostics.Conflicts_are_in_this_file)
-          ));
-          diagnostics.add(addRelatedInfo(
-            createDiagnosticForNode(secondFile, Diagnostics.Definitions_of_the_following_identifiers_conflict_with_those_in_another_file_Colon_0, list),
-            createDiagnosticForNode(firstFile, Diagnostics.Conflicts_are_in_this_file)
-          ));
-        }
-      });
-      amalgamatedDuplicates = void 0;
-    }
-    function checkExternalEmitHelpers(location, helpers) {
-      if ((requestedExternalEmitHelpers & helpers) !== helpers && compilerOptions.importHelpers) {
-        const sourceFile = getSourceFileOfNode(location);
-        if (isEffectiveExternalModule(sourceFile, compilerOptions) && !(location.flags & 16777216 /* Ambient */)) {
-          const helpersModule = resolveHelpersModule(sourceFile, location);
-          if (helpersModule !== unknownSymbol) {
-            const uncheckedHelpers = helpers & ~requestedExternalEmitHelpers;
-            for (let helper = 1 /* FirstEmitHelper */; helper <= 16777216 /* LastEmitHelper */; helper <<= 1) {
-              if (uncheckedHelpers & helper) {
-                for (const name of getHelperNames(helper)) {
-                  if (requestedExternalEmitHelperNames.has(name))
-                    continue;
-                  requestedExternalEmitHelperNames.add(name);
-                  const symbol = resolveSymbol(getSymbol2(getExportsOfModule(helpersModule), escapeLeadingUnderscores(name), 111551 /* Value */));
-                  if (!symbol) {
-                    error(location, Diagnostics.This_syntax_requires_an_imported_helper_named_1_which_does_not_exist_in_0_Consider_upgrading_your_version_of_0, externalHelpersModuleNameText, name);
-                  } else if (helper & 524288 /* ClassPrivateFieldGet */) {
-                    if (!some(getSignaturesOfSymbol(symbol), (signature) => getParameterCount(signature) > 3)) {
-                      error(location, Diagnostics.This_syntax_requires_an_imported_helper_named_1_with_2_parameters_which_is_not_compatible_with_the_one_in_0_Consider_upgrading_your_version_of_0, externalHelpersModuleNameText, name, 4);
-                    }
-                  } else if (helper & 1048576 /* ClassPrivateFieldSet */) {
-                    if (!some(getSignaturesOfSymbol(symbol), (signature) => getParameterCount(signature) > 4)) {
-                      error(location, Diagnostics.This_syntax_requires_an_imported_helper_named_1_with_2_parameters_which_is_not_compatible_with_the_one_in_0_Consider_upgrading_your_version_of_0, externalHelpersModuleNameText, name, 5);
-                    }
-                  } else if (helper & 1024 /* SpreadArray */) {
-                    if (!some(getSignaturesOfSymbol(symbol), (signature) => getParameterCount(signature) > 2)) {
-                      error(location, Diagnostics.This_syntax_requires_an_imported_helper_named_1_with_2_parameters_which_is_not_compatible_with_the_one_in_0_Consider_upgrading_your_version_of_0, externalHelpersModuleNameText, name, 3);
-                    }
-                  }
-                }
-              }
-            }
-          }
-          requestedExternalEmitHelpers |= helpers;
-        }
-      }
-    }
-    function getHelperNames(helper) {
-      switch (helper) {
-        case 1 /* Extends */:
-          return ["__extends"];
-        case 2 /* Assign */:
-          return ["__assign"];
-        case 4 /* Rest */:
-          return ["__rest"];
-        case 8 /* Decorate */:
-          return legacyDecorators ? ["__decorate"] : ["__esDecorate", "__runInitializers"];
-        case 16 /* Metadata */:
-          return ["__metadata"];
-        case 32 /* Param */:
-          return ["__param"];
-        case 64 /* Awaiter */:
-          return ["__awaiter"];
-        case 128 /* Generator */:
-          return ["__generator"];
-        case 256 /* Values */:
-          return ["__values"];
-        case 512 /* Read */:
-          return ["__read"];
-        case 1024 /* SpreadArray */:
-          return ["__spreadArray"];
-        case 2048 /* Await */:
-          return ["__await"];
-        case 4096 /* AsyncGenerator */:
-          return ["__asyncGenerator"];
-        case 8192 /* AsyncDelegator */:
-          return ["__asyncDelegator"];
-        case 16384 /* AsyncValues */:
-          return ["__asyncValues"];
-        case 32768 /* ExportStar */:
-          return ["__exportStar"];
-        case 65536 /* ImportStar */:
-          return ["__importStar"];
-        case 131072 /* ImportDefault */:
-          return ["__importDefault"];
-        case 262144 /* MakeTemplateObject */:
-          return ["__makeTemplateObject"];
-        case 524288 /* ClassPrivateFieldGet */:
-          return ["__classPrivateFieldGet"];
-        case 1048576 /* ClassPrivateFieldSet */:
-          return ["__classPrivateFieldSet"];
-        case 2097152 /* ClassPrivateFieldIn */:
-          return ["__classPrivateFieldIn"];
-        case 4194304 /* CreateBinding */:
-          return ["__createBinding"];
-        case 8388608 /* SetFunctionName */:
-          return ["__setFunctionName"];
-        case 16777216 /* PropKey */:
-          return ["__propKey"];
-        default:
-          return Debug.fail("Unrecognized helper");
-      }
-    }
-    function resolveHelpersModule(node, errorNode) {
-      if (!externalHelpersModule) {
-        externalHelpersModule = resolveExternalModule(node, externalHelpersModuleNameText, Diagnostics.This_syntax_requires_an_imported_helper_but_module_0_cannot_be_found, errorNode) || unknownSymbol;
-      }
-      return externalHelpersModule;
-    }
-    function checkGrammarModifiers(node) {
-      const quickResult = reportObviousDecoratorErrors(node) || reportObviousModifierErrors(node);
-      if (quickResult !== void 0) {
-        return quickResult;
-      }
-      if (isParameter(node) && parameterIsThisKeyword(node)) {
-        return grammarErrorOnFirstToken(node, Diagnostics.Neither_decorators_nor_modifiers_may_be_applied_to_this_parameters);
-      }
-      let lastStatic, lastDeclare, lastAsync, lastOverride, firstDecorator;
-      let flags = 0 /* None */;
-      let sawExportBeforeDecorators = false;
-      let hasLeadingDecorators = false;
-      for (const modifier of node.modifiers) {
-        if (isDecorator(modifier)) {
-          if (!nodeCanBeDecorated(legacyDecorators, node, node.parent, node.parent.parent)) {
-            if (node.kind === 173 /* MethodDeclaration */ && !nodeIsPresent(node.body)) {
-              return grammarErrorOnFirstToken(node, Diagnostics.A_decorator_can_only_decorate_a_method_implementation_not_an_overload);
-            } else {
-              return grammarErrorOnFirstToken(node, Diagnostics.Decorators_are_not_valid_here);
-            }
-          } else if (legacyDecorators && (node.kind === 176 /* GetAccessor */ || node.kind === 177 /* SetAccessor */)) {
-            const accessors = getAllAccessorDeclarations(node.parent.members, node);
-            if (hasDecorators(accessors.firstAccessor) && node === accessors.secondAccessor) {
-              return grammarErrorOnFirstToken(node, Diagnostics.Decorators_cannot_be_applied_to_multiple_get_Slashset_accessors_of_the_same_name);
-            }
-          }
-          if (flags & ~(1025 /* ExportDefault */ | 131072 /* Decorator */)) {
-            return grammarErrorOnNode(modifier, Diagnostics.Decorators_are_not_valid_here);
-          }
-          if (hasLeadingDecorators && flags & 126975 /* Modifier */) {
-            Debug.assertIsDefined(firstDecorator);
-            const sourceFile = getSourceFileOfNode(modifier);
-            if (!hasParseDiagnostics(sourceFile)) {
-              addRelatedInfo(
-                error(modifier, Diagnostics.Decorators_may_not_appear_after_export_or_export_default_if_they_also_appear_before_export),
-                createDiagnosticForNode(firstDecorator, Diagnostics.Decorator_used_before_export_here)
-              );
-              return true;
-            }
-            return false;
-          }
-          flags |= 131072 /* Decorator */;
-          if (!(flags & 126975 /* Modifier */)) {
-            hasLeadingDecorators = true;
-          } else if (flags & 1 /* Export */) {
-            sawExportBeforeDecorators = true;
-          }
-          firstDecorator ?? (firstDecorator = modifier);
-        } else {
-          if (modifier.kind !== 148 /* ReadonlyKeyword */) {
-            if (node.kind === 170 /* PropertySignature */ || node.kind === 172 /* MethodSignature */) {
-              return grammarErrorOnNode(modifier, Diagnostics._0_modifier_cannot_appear_on_a_type_member, tokenToString(modifier.kind));
-            }
-            if (node.kind === 180 /* IndexSignature */ && (modifier.kind !== 126 /* StaticKeyword */ || !isClassLike(node.parent))) {
-              return grammarErrorOnNode(modifier, Diagnostics._0_modifier_cannot_appear_on_an_index_signature, tokenToString(modifier.kind));
-            }
-          }
-          if (modifier.kind !== 103 /* InKeyword */ && modifier.kind !== 147 /* OutKeyword */ && modifier.kind !== 87 /* ConstKeyword */) {
-            if (node.kind === 167 /* TypeParameter */) {
-              return grammarErrorOnNode(modifier, Diagnostics._0_modifier_cannot_appear_on_a_type_parameter, tokenToString(modifier.kind));
-            }
-          }
-          switch (modifier.kind) {
-            case 87 /* ConstKeyword */:
-              if (node.kind !== 265 /* EnumDeclaration */ && node.kind !== 167 /* TypeParameter */) {
-                return grammarErrorOnNode(node, Diagnostics.A_class_member_cannot_have_the_0_keyword, tokenToString(87 /* ConstKeyword */));
-              }
-              const parent2 = node.parent;
-              if (node.kind === 167 /* TypeParameter */ && !(isFunctionLikeDeclaration(parent2) || isClassLike(parent2) || isFunctionTypeNode(parent2) || isConstructorTypeNode(parent2) || isCallSignatureDeclaration(parent2) || isConstructSignatureDeclaration(parent2) || isMethodSignature(parent2))) {
-                return grammarErrorOnNode(modifier, Diagnostics._0_modifier_can_only_appear_on_a_type_parameter_of_a_function_method_or_class, tokenToString(modifier.kind));
-              }
-              break;
-            case 163 /* OverrideKeyword */:
-              if (flags & 16384 /* Override */) {
-                return grammarErrorOnNode(modifier, Diagnostics._0_modifier_already_seen, "override");
-              } else if (flags & 2 /* Ambient */) {
-                return grammarErrorOnNode(modifier, Diagnostics._0_modifier_cannot_be_used_with_1_modifier, "override", "declare");
-              } else if (flags & 64 /* Readonly */) {
-                return grammarErrorOnNode(modifier, Diagnostics._0_modifier_must_precede_1_modifier, "override", "readonly");
-              } else if (flags & 128 /* Accessor */) {
-                return grammarErrorOnNode(modifier, Diagnostics._0_modifier_must_precede_1_modifier, "override", "accessor");
-              } else if (flags & 512 /* Async */) {
-                return grammarErrorOnNode(modifier, Diagnostics._0_modifier_must_precede_1_modifier, "override", "async");
-              }
-              flags |= 16384 /* Override */;
-              lastOverride = modifier;
-              break;
-            case 125 /* PublicKeyword */:
-            case 124 /* ProtectedKeyword */:
-            case 123 /* PrivateKeyword */:
-              const text = visibilityToString(modifierToFlag(modifier.kind));
-              if (flags & 28 /* AccessibilityModifier */) {
-                return grammarErrorOnNode(modifier, Diagnostics.Accessibility_modifier_already_seen);
-              } else if (flags & 16384 /* Override */) {
-                return grammarErrorOnNode(modifier, Diagnostics._0_modifier_must_precede_1_modifier, text, "override");
-              } else if (flags & 32 /* Static */) {
-                return grammarErrorOnNode(modifier, Diagnostics._0_modifier_must_precede_1_modifier, text, "static");
-              } else if (flags & 128 /* Accessor */) {
-                return grammarErrorOnNode(modifier, Diagnostics._0_modifier_must_precede_1_modifier, text, "accessor");
-              } else if (flags & 64 /* Readonly */) {
-                return grammarErrorOnNode(modifier, Diagnostics._0_modifier_must_precede_1_modifier, text, "readonly");
-              } else if (flags & 512 /* Async */) {
-                return grammarErrorOnNode(modifier, Diagnostics._0_modifier_must_precede_1_modifier, text, "async");
-              } else if (node.parent.kind === 267 /* ModuleBlock */ || node.parent.kind === 311 /* SourceFile */) {
-                return grammarErrorOnNode(modifier, Diagnostics._0_modifier_cannot_appear_on_a_module_or_namespace_element, text);
-              } else if (flags & 256 /* Abstract */) {
-                if (modifier.kind === 123 /* PrivateKeyword */) {
-                  return grammarErrorOnNode(modifier, Diagnostics._0_modifier_cannot_be_used_with_1_modifier, text, "abstract");
-                } else {
-                  return grammarErrorOnNode(modifier, Diagnostics._0_modifier_must_precede_1_modifier, text, "abstract");
-                }
-              } else if (isPrivateIdentifierClassElementDeclaration(node)) {
-                return grammarErrorOnNode(modifier, Diagnostics.An_accessibility_modifier_cannot_be_used_with_a_private_identifier);
-              }
-              flags |= modifierToFlag(modifier.kind);
-              break;
-            case 126 /* StaticKeyword */:
-              if (flags & 32 /* Static */) {
-                return grammarErrorOnNode(modifier, Diagnostics._0_modifier_already_seen, "static");
-              } else if (flags & 64 /* Readonly */) {
-                return grammarErrorOnNode(modifier, Diagnostics._0_modifier_must_precede_1_modifier, "static", "readonly");
-              } else if (flags & 512 /* Async */) {
-                return grammarErrorOnNode(modifier, Diagnostics._0_modifier_must_precede_1_modifier, "static", "async");
-              } else if (flags & 128 /* Accessor */) {
-                return grammarErrorOnNode(modifier, Diagnostics._0_modifier_must_precede_1_modifier, "static", "accessor");
-              } else if (node.parent.kind === 267 /* ModuleBlock */ || node.parent.kind === 311 /* SourceFile */) {
-                return grammarErrorOnNode(modifier, Diagnostics._0_modifier_cannot_appear_on_a_module_or_namespace_element, "static");
-              } else if (node.kind === 168 /* Parameter */) {
-                return grammarErrorOnNode(modifier, Diagnostics._0_modifier_cannot_appear_on_a_parameter, "static");
-              } else if (flags & 256 /* Abstract */) {
-                return grammarErrorOnNode(modifier, Diagnostics._0_modifier_cannot_be_used_with_1_modifier, "static", "abstract");
-              } else if (flags & 16384 /* Override */) {
-                return grammarErrorOnNode(modifier, Diagnostics._0_modifier_must_precede_1_modifier, "static", "override");
-              }
-              flags |= 32 /* Static */;
-              lastStatic = modifier;
-              break;
-            case 129 /* AccessorKeyword */:
-              if (flags & 128 /* Accessor */) {
-                return grammarErrorOnNode(modifier, Diagnostics._0_modifier_already_seen, "accessor");
-              } else if (flags & 64 /* Readonly */) {
-                return grammarErrorOnNode(modifier, Diagnostics._0_modifier_cannot_be_used_with_1_modifier, "accessor", "readonly");
-              } else if (flags & 2 /* Ambient */) {
-                return grammarErrorOnNode(modifier, Diagnostics._0_modifier_cannot_be_used_with_1_modifier, "accessor", "declare");
-              } else if (node.kind !== 171 /* PropertyDeclaration */) {
-                return grammarErrorOnNode(modifier, Diagnostics.accessor_modifier_can_only_appear_on_a_property_declaration);
-              }
-              flags |= 128 /* Accessor */;
-              break;
-            case 148 /* ReadonlyKeyword */:
-              if (flags & 64 /* Readonly */) {
-                return grammarErrorOnNode(modifier, Diagnostics._0_modifier_already_seen, "readonly");
-              } else if (node.kind !== 171 /* PropertyDeclaration */ && node.kind !== 170 /* PropertySignature */ && node.kind !== 180 /* IndexSignature */ && node.kind !== 168 /* Parameter */) {
-                return grammarErrorOnNode(modifier, Diagnostics.readonly_modifier_can_only_appear_on_a_property_declaration_or_index_signature);
-              } else if (flags & 128 /* Accessor */) {
-                return grammarErrorOnNode(modifier, Diagnostics._0_modifier_cannot_be_used_with_1_modifier, "readonly", "accessor");
-              }
-              flags |= 64 /* Readonly */;
-              break;
-            case 95 /* ExportKeyword */:
-              if (compilerOptions.verbatimModuleSyntax && !(node.flags & 16777216 /* Ambient */) && node.kind !== 264 /* TypeAliasDeclaration */ && node.kind !== 263 /* InterfaceDeclaration */ && // ModuleDeclaration needs to be checked that it is uninstantiated later
-              node.kind !== 266 /* ModuleDeclaration */ && node.parent.kind === 311 /* SourceFile */ && (moduleKind === 1 /* CommonJS */ || getSourceFileOfNode(node).impliedNodeFormat === 1 /* CommonJS */)) {
-                return grammarErrorOnNode(modifier, Diagnostics.A_top_level_export_modifier_cannot_be_used_on_value_declarations_in_a_CommonJS_module_when_verbatimModuleSyntax_is_enabled);
-              }
-              if (flags & 1 /* Export */) {
-                return grammarErrorOnNode(modifier, Diagnostics._0_modifier_already_seen, "export");
-              } else if (flags & 2 /* Ambient */) {
-                return grammarErrorOnNode(modifier, Diagnostics._0_modifier_must_precede_1_modifier, "export", "declare");
-              } else if (flags & 256 /* Abstract */) {
-                return grammarErrorOnNode(modifier, Diagnostics._0_modifier_must_precede_1_modifier, "export", "abstract");
-              } else if (flags & 512 /* Async */) {
-                return grammarErrorOnNode(modifier, Diagnostics._0_modifier_must_precede_1_modifier, "export", "async");
-              } else if (isClassLike(node.parent)) {
-                return grammarErrorOnNode(modifier, Diagnostics._0_modifier_cannot_appear_on_class_elements_of_this_kind, "export");
-              } else if (node.kind === 168 /* Parameter */) {
-                return grammarErrorOnNode(modifier, Diagnostics._0_modifier_cannot_appear_on_a_parameter, "export");
-              }
-              flags |= 1 /* Export */;
-              break;
-            case 90 /* DefaultKeyword */:
-              const container = node.parent.kind === 311 /* SourceFile */ ? node.parent : node.parent.parent;
-              if (container.kind === 266 /* ModuleDeclaration */ && !isAmbientModule(container)) {
-                return grammarErrorOnNode(modifier, Diagnostics.A_default_export_can_only_be_used_in_an_ECMAScript_style_module);
-              } else if (!(flags & 1 /* Export */)) {
-                return grammarErrorOnNode(modifier, Diagnostics._0_modifier_must_precede_1_modifier, "export", "default");
-              } else if (sawExportBeforeDecorators) {
-                return grammarErrorOnNode(firstDecorator, Diagnostics.Decorators_are_not_valid_here);
-              }
-              flags |= 1024 /* Default */;
-              break;
-            case 138 /* DeclareKeyword */:
-              if (flags & 2 /* Ambient */) {
-                return grammarErrorOnNode(modifier, Diagnostics._0_modifier_already_seen, "declare");
-              } else if (flags & 512 /* Async */) {
-                return grammarErrorOnNode(modifier, Diagnostics._0_modifier_cannot_be_used_in_an_ambient_context, "async");
-              } else if (flags & 16384 /* Override */) {
-                return grammarErrorOnNode(modifier, Diagnostics._0_modifier_cannot_be_used_in_an_ambient_context, "override");
-              } else if (isClassLike(node.parent) && !isPropertyDeclaration(node)) {
-                return grammarErrorOnNode(modifier, Diagnostics._0_modifier_cannot_appear_on_class_elements_of_this_kind, "declare");
-              } else if (node.kind === 168 /* Parameter */) {
-                return grammarErrorOnNode(modifier, Diagnostics._0_modifier_cannot_appear_on_a_parameter, "declare");
-              } else if (node.parent.flags & 16777216 /* Ambient */ && node.parent.kind === 267 /* ModuleBlock */) {
-                return grammarErrorOnNode(modifier, Diagnostics.A_declare_modifier_cannot_be_used_in_an_already_ambient_context);
-              } else if (isPrivateIdentifierClassElementDeclaration(node)) {
-                return grammarErrorOnNode(modifier, Diagnostics._0_modifier_cannot_be_used_with_a_private_identifier, "declare");
-              } else if (flags & 128 /* Accessor */) {
-                return grammarErrorOnNode(modifier, Diagnostics._0_modifier_cannot_be_used_with_1_modifier, "declare", "accessor");
-              }
-              flags |= 2 /* Ambient */;
-              lastDeclare = modifier;
-              break;
-            case 128 /* AbstractKeyword */:
-              if (flags & 256 /* Abstract */) {
-                return grammarErrorOnNode(modifier, Diagnostics._0_modifier_already_seen, "abstract");
-              }
-              if (node.kind !== 262 /* ClassDeclaration */ && node.kind !== 184 /* ConstructorType */) {
-                if (node.kind !== 173 /* MethodDeclaration */ && node.kind !== 171 /* PropertyDeclaration */ && node.kind !== 176 /* GetAccessor */ && node.kind !== 177 /* SetAccessor */) {
-                  return grammarErrorOnNode(modifier, Diagnostics.abstract_modifier_can_only_appear_on_a_class_method_or_property_declaration);
-                }
-                if (!(node.parent.kind === 262 /* ClassDeclaration */ && hasSyntacticModifier(node.parent, 256 /* Abstract */))) {
-                  const message = node.kind === 171 /* PropertyDeclaration */ ? Diagnostics.Abstract_properties_can_only_appear_within_an_abstract_class : Diagnostics.Abstract_methods_can_only_appear_within_an_abstract_class;
-                  return grammarErrorOnNode(modifier, message);
-                }
-                if (flags & 32 /* Static */) {
-                  return grammarErrorOnNode(modifier, Diagnostics._0_modifier_cannot_be_used_with_1_modifier, "static", "abstract");
-                }
-                if (flags & 8 /* Private */) {
-                  return grammarErrorOnNode(modifier, Diagnostics._0_modifier_cannot_be_used_with_1_modifier, "private", "abstract");
-                }
-                if (flags & 512 /* Async */ && lastAsync) {
-                  return grammarErrorOnNode(lastAsync, Diagnostics._0_modifier_cannot_be_used_with_1_modifier, "async", "abstract");
-                }
-                if (flags & 16384 /* Override */) {
-                  return grammarErrorOnNode(modifier, Diagnostics._0_modifier_must_precede_1_modifier, "abstract", "override");
-                }
-                if (flags & 128 /* Accessor */) {
-                  return grammarErrorOnNode(modifier, Diagnostics._0_modifier_must_precede_1_modifier, "abstract", "accessor");
-                }
-              }
-              if (isNamedDeclaration(node) && node.name.kind === 81 /* PrivateIdentifier */) {
-                return grammarErrorOnNode(modifier, Diagnostics._0_modifier_cannot_be_used_with_a_private_identifier, "abstract");
-              }
-              flags |= 256 /* Abstract */;
-              break;
-            case 134 /* AsyncKeyword */:
-              if (flags & 512 /* Async */) {
-                return grammarErrorOnNode(modifier, Diagnostics._0_modifier_already_seen, "async");
-              } else if (flags & 2 /* Ambient */ || node.parent.flags & 16777216 /* Ambient */) {
-                return grammarErrorOnNode(modifier, Diagnostics._0_modifier_cannot_be_used_in_an_ambient_context, "async");
-              } else if (node.kind === 168 /* Parameter */) {
-                return grammarErrorOnNode(modifier, Diagnostics._0_modifier_cannot_appear_on_a_parameter, "async");
-              }
-              if (flags & 256 /* Abstract */) {
-                return grammarErrorOnNode(modifier, Diagnostics._0_modifier_cannot_be_used_with_1_modifier, "async", "abstract");
-              }
-              flags |= 512 /* Async */;
-              lastAsync = modifier;
-              break;
-            case 103 /* InKeyword */:
-            case 147 /* OutKeyword */:
-              const inOutFlag = modifier.kind === 103 /* InKeyword */ ? 32768 /* In */ : 65536 /* Out */;
-              const inOutText = modifier.kind === 103 /* InKeyword */ ? "in" : "out";
-              if (node.kind !== 167 /* TypeParameter */ || !(isInterfaceDeclaration(node.parent) || isClassLike(node.parent) || isTypeAliasDeclaration(node.parent))) {
-                return grammarErrorOnNode(modifier, Diagnostics._0_modifier_can_only_appear_on_a_type_parameter_of_a_class_interface_or_type_alias, inOutText);
-              }
-              if (flags & inOutFlag) {
-                return grammarErrorOnNode(modifier, Diagnostics._0_modifier_already_seen, inOutText);
-              }
-              if (inOutFlag & 32768 /* In */ && flags & 65536 /* Out */) {
-                return grammarErrorOnNode(modifier, Diagnostics._0_modifier_must_precede_1_modifier, "in", "out");
-              }
-              flags |= inOutFlag;
-              break;
-          }
-        }
-      }
-      if (node.kind === 175 /* Constructor */) {
-        if (flags & 32 /* Static */) {
-          return grammarErrorOnNode(lastStatic, Diagnostics._0_modifier_cannot_appear_on_a_constructor_declaration, "static");
-        }
-        if (flags & 16384 /* Override */) {
-          return grammarErrorOnNode(lastOverride, Diagnostics._0_modifier_cannot_appear_on_a_constructor_declaration, "override");
-        }
-        if (flags & 512 /* Async */) {
-          return grammarErrorOnNode(lastAsync, Diagnostics._0_modifier_cannot_appear_on_a_constructor_declaration, "async");
-        }
-        return false;
-      } else if ((node.kind === 271 /* ImportDeclaration */ || node.kind === 270 /* ImportEqualsDeclaration */) && flags & 2 /* Ambient */) {
-        return grammarErrorOnNode(lastDeclare, Diagnostics.A_0_modifier_cannot_be_used_with_an_import_declaration, "declare");
-      } else if (node.kind === 168 /* Parameter */ && flags & 16476 /* ParameterPropertyModifier */ && isBindingPattern(node.name)) {
-        return grammarErrorOnNode(node, Diagnostics.A_parameter_property_may_not_be_declared_using_a_binding_pattern);
-      } else if (node.kind === 168 /* Parameter */ && flags & 16476 /* ParameterPropertyModifier */ && node.dotDotDotToken) {
-        return grammarErrorOnNode(node, Diagnostics.A_parameter_property_cannot_be_declared_using_a_rest_parameter);
-      }
-      if (flags & 512 /* Async */) {
-        return checkGrammarAsyncModifier(node, lastAsync);
-      }
-      return false;
-    }
-    function reportObviousModifierErrors(node) {
-      if (!node.modifiers)
-        return false;
-      const modifier = findFirstIllegalModifier(node);
-      return modifier && grammarErrorOnFirstToken(modifier, Diagnostics.Modifiers_cannot_appear_here);
-    }
-    function findFirstModifierExcept(node, allowedModifier) {
-      const modifier = find(node.modifiers, isModifier);
-      return modifier && modifier.kind !== allowedModifier ? modifier : void 0;
-    }
-    function findFirstIllegalModifier(node) {
-      switch (node.kind) {
-        case 176 /* GetAccessor */:
-        case 177 /* SetAccessor */:
-        case 175 /* Constructor */:
-        case 171 /* PropertyDeclaration */:
-        case 170 /* PropertySignature */:
-        case 173 /* MethodDeclaration */:
-        case 172 /* MethodSignature */:
-        case 180 /* IndexSignature */:
-        case 266 /* ModuleDeclaration */:
-        case 271 /* ImportDeclaration */:
-        case 270 /* ImportEqualsDeclaration */:
-        case 277 /* ExportDeclaration */:
-        case 276 /* ExportAssignment */:
-        case 217 /* FunctionExpression */:
-        case 218 /* ArrowFunction */:
-        case 168 /* Parameter */:
-        case 167 /* TypeParameter */:
-          return void 0;
-        case 174 /* ClassStaticBlockDeclaration */:
-        case 302 /* PropertyAssignment */:
-        case 303 /* ShorthandPropertyAssignment */:
-        case 269 /* NamespaceExportDeclaration */:
-        case 281 /* MissingDeclaration */:
-          return find(node.modifiers, isModifier);
-        default:
-          if (node.parent.kind === 267 /* ModuleBlock */ || node.parent.kind === 311 /* SourceFile */) {
-            return void 0;
-          }
-          switch (node.kind) {
-            case 261 /* FunctionDeclaration */:
-              return findFirstModifierExcept(node, 134 /* AsyncKeyword */);
-            case 262 /* ClassDeclaration */:
-            case 184 /* ConstructorType */:
-              return findFirstModifierExcept(node, 128 /* AbstractKeyword */);
-            case 230 /* ClassExpression */:
-            case 263 /* InterfaceDeclaration */:
-            case 242 /* VariableStatement */:
-            case 264 /* TypeAliasDeclaration */:
-              return find(node.modifiers, isModifier);
-            case 265 /* EnumDeclaration */:
-              return findFirstModifierExcept(node, 87 /* ConstKeyword */);
-            default:
-              Debug.assertNever(node);
-          }
-      }
-    }
-    function reportObviousDecoratorErrors(node) {
-      const decorator = findFirstIllegalDecorator(node);
-      return decorator && grammarErrorOnFirstToken(decorator, Diagnostics.Decorators_are_not_valid_here);
-    }
-    function findFirstIllegalDecorator(node) {
-      return canHaveIllegalDecorators(node) ? find(node.modifiers, isDecorator) : void 0;
-    }
-    function checkGrammarAsyncModifier(node, asyncModifier) {
-      switch (node.kind) {
-        case 173 /* MethodDeclaration */:
-        case 261 /* FunctionDeclaration */:
-        case 217 /* FunctionExpression */:
-        case 218 /* ArrowFunction */:
-          return false;
-      }
-      return grammarErrorOnNode(asyncModifier, Diagnostics._0_modifier_cannot_be_used_here, "async");
-    }
-    function checkGrammarForDisallowedTrailingComma(list, diag2 = Diagnostics.Trailing_comma_not_allowed) {
-      if (list && list.hasTrailingComma) {
-        return grammarErrorAtPos(list[0], list.end - ",".length, ",".length, diag2);
-      }
-      return false;
-    }
-    function checkGrammarTypeParameterList(typeParameters, file) {
-      if (typeParameters && typeParameters.length === 0) {
-        const start = typeParameters.pos - "<".length;
-        const end = skipTrivia(file.text, typeParameters.end) + ">".length;
-        return grammarErrorAtPos(file, start, end - start, Diagnostics.Type_parameter_list_cannot_be_empty);
-      }
-      return false;
-    }
-    function checkGrammarParameterList(parameters) {
-      let seenOptionalParameter = false;
-      const parameterCount = parameters.length;
-      for (let i = 0; i < parameterCount; i++) {
-        const parameter = parameters[i];
-        if (parameter.dotDotDotToken) {
-          if (i !== parameterCount - 1) {
-            return grammarErrorOnNode(parameter.dotDotDotToken, Diagnostics.A_rest_parameter_must_be_last_in_a_parameter_list);
-          }
-          if (!(parameter.flags & 16777216 /* Ambient */)) {
-            checkGrammarForDisallowedTrailingComma(parameters, Diagnostics.A_rest_parameter_or_binding_pattern_may_not_have_a_trailing_comma);
-          }
-          if (parameter.questionToken) {
-            return grammarErrorOnNode(parameter.questionToken, Diagnostics.A_rest_parameter_cannot_be_optional);
-          }
-          if (parameter.initializer) {
-            return grammarErrorOnNode(parameter.name, Diagnostics.A_rest_parameter_cannot_have_an_initializer);
-          }
-        } else if (isOptionalParameter(parameter)) {
-          seenOptionalParameter = true;
-          if (parameter.questionToken && parameter.initializer) {
-            return grammarErrorOnNode(parameter.name, Diagnostics.Parameter_cannot_have_question_mark_and_initializer);
-          }
-        } else if (seenOptionalParameter && !parameter.initializer) {
-          return grammarErrorOnNode(parameter.name, Diagnostics.A_required_parameter_cannot_follow_an_optional_parameter);
-        }
-      }
-    }
-    function getNonSimpleParameters(parameters) {
-      return filter(parameters, (parameter) => !!parameter.initializer || isBindingPattern(parameter.name) || isRestParameter(parameter));
-    }
-    function checkGrammarForUseStrictSimpleParameterList(node) {
-      if (languageVersion >= 3 /* ES2016 */) {
-        const useStrictDirective = node.body && isBlock(node.body) && findUseStrictPrologue(node.body.statements);
-        if (useStrictDirective) {
-          const nonSimpleParameters = getNonSimpleParameters(node.parameters);
-          if (length(nonSimpleParameters)) {
-            forEach(nonSimpleParameters, (parameter) => {
-              addRelatedInfo(
-                error(parameter, Diagnostics.This_parameter_is_not_allowed_with_use_strict_directive),
-                createDiagnosticForNode(useStrictDirective, Diagnostics.use_strict_directive_used_here)
-              );
-            });
-            const diagnostics2 = nonSimpleParameters.map((parameter, index) => index === 0 ? createDiagnosticForNode(parameter, Diagnostics.Non_simple_parameter_declared_here) : createDiagnosticForNode(parameter, Diagnostics.and_here));
-            addRelatedInfo(error(useStrictDirective, Diagnostics.use_strict_directive_cannot_be_used_with_non_simple_parameter_list), ...diagnostics2);
-            return true;
-          }
-        }
-      }
-      return false;
-    }
-    function checkGrammarFunctionLikeDeclaration(node) {
-      const file = getSourceFileOfNode(node);
-      return checkGrammarModifiers(node) || checkGrammarTypeParameterList(node.typeParameters, file) || checkGrammarParameterList(node.parameters) || checkGrammarArrowFunction(node, file) || isFunctionLikeDeclaration(node) && checkGrammarForUseStrictSimpleParameterList(node);
-    }
-    function checkGrammarClassLikeDeclaration(node) {
-      const file = getSourceFileOfNode(node);
-      return checkGrammarClassDeclarationHeritageClauses(node) || checkGrammarTypeParameterList(node.typeParameters, file);
-    }
-    function checkGrammarArrowFunction(node, file) {
-      if (!isArrowFunction(node)) {
-        return false;
-      }
-      if (node.typeParameters && !(length(node.typeParameters) > 1 || node.typeParameters.hasTrailingComma || node.typeParameters[0].constraint)) {
-        if (file && fileExtensionIsOneOf(file.fileName, [".mts" /* Mts */, ".cts" /* Cts */])) {
-          grammarErrorOnNode(node.typeParameters[0], Diagnostics.This_syntax_is_reserved_in_files_with_the_mts_or_cts_extension_Add_a_trailing_comma_or_explicit_constraint);
-        }
-      }
-      const { equalsGreaterThanToken } = node;
-      const startLine = getLineAndCharacterOfPosition(file, equalsGreaterThanToken.pos).line;
-      const endLine = getLineAndCharacterOfPosition(file, equalsGreaterThanToken.end).line;
-      return startLine !== endLine && grammarErrorOnNode(equalsGreaterThanToken, Diagnostics.Line_terminator_not_permitted_before_arrow);
-    }
-    function checkGrammarIndexSignatureParameters(node) {
-      const parameter = node.parameters[0];
-      if (node.parameters.length !== 1) {
-        if (parameter) {
-          return grammarErrorOnNode(parameter.name, Diagnostics.An_index_signature_must_have_exactly_one_parameter);
-        } else {
-          return grammarErrorOnNode(node, Diagnostics.An_index_signature_must_have_exactly_one_parameter);
-        }
-      }
-      checkGrammarForDisallowedTrailingComma(node.parameters, Diagnostics.An_index_signature_cannot_have_a_trailing_comma);
-      if (parameter.dotDotDotToken) {
-        return grammarErrorOnNode(parameter.dotDotDotToken, Diagnostics.An_index_signature_cannot_have_a_rest_parameter);
-      }
-      if (hasEffectiveModifiers(parameter)) {
-        return grammarErrorOnNode(parameter.name, Diagnostics.An_index_signature_parameter_cannot_have_an_accessibility_modifier);
-      }
-      if (parameter.questionToken) {
-        return grammarErrorOnNode(parameter.questionToken, Diagnostics.An_index_signature_parameter_cannot_have_a_question_mark);
-      }
-      if (parameter.initializer) {
-        return grammarErrorOnNode(parameter.name, Diagnostics.An_index_signature_parameter_cannot_have_an_initializer);
-      }
-      if (!parameter.type) {
-        return grammarErrorOnNode(parameter.name, Diagnostics.An_index_signature_parameter_must_have_a_type_annotation);
-      }
-      const type = getTypeFromTypeNode(parameter.type);
-      if (someType(type, (t) => !!(t.flags & 8576 /* StringOrNumberLiteralOrUnique */)) || isGenericType(type)) {
-        return grammarErrorOnNode(parameter.name, Diagnostics.An_index_signature_parameter_type_cannot_be_a_literal_type_or_generic_type_Consider_using_a_mapped_object_type_instead);
-      }
-      if (!everyType(type, isValidIndexKeyType)) {
-        return grammarErrorOnNode(parameter.name, Diagnostics.An_index_signature_parameter_type_must_be_string_number_symbol_or_a_template_literal_type);
-      }
-      if (!node.type) {
-        return grammarErrorOnNode(node, Diagnostics.An_index_signature_must_have_a_type_annotation);
-      }
-      return false;
-    }
-    function checkGrammarIndexSignature(node) {
-      return checkGrammarModifiers(node) || checkGrammarIndexSignatureParameters(node);
-    }
-    function checkGrammarForAtLeastOneTypeArgument(node, typeArguments) {
-      if (typeArguments && typeArguments.length === 0) {
-        const sourceFile = getSourceFileOfNode(node);
-        const start = typeArguments.pos - "<".length;
-        const end = skipTrivia(sourceFile.text, typeArguments.end) + ">".length;
-        return grammarErrorAtPos(sourceFile, start, end - start, Diagnostics.Type_argument_list_cannot_be_empty);
-      }
-      return false;
-    }
-    function checkGrammarTypeArguments(node, typeArguments) {
-      return checkGrammarForDisallowedTrailingComma(typeArguments) || checkGrammarForAtLeastOneTypeArgument(node, typeArguments);
-    }
-    function checkGrammarTaggedTemplateChain(node) {
-      if (node.questionDotToken || node.flags & 32 /* OptionalChain */) {
-        return grammarErrorOnNode(node.template, Diagnostics.Tagged_template_expressions_are_not_permitted_in_an_optional_chain);
-      }
-      return false;
-    }
-    function checkGrammarHeritageClause(node) {
-      const types = node.types;
-      if (checkGrammarForDisallowedTrailingComma(types)) {
-        return true;
-      }
-      if (types && types.length === 0) {
-        const listType = tokenToString(node.token);
-        return grammarErrorAtPos(node, types.pos, 0, Diagnostics._0_list_cannot_be_empty, listType);
-      }
-      return some(types, checkGrammarExpressionWithTypeArguments);
-    }
-    function checkGrammarExpressionWithTypeArguments(node) {
-      if (isExpressionWithTypeArguments(node) && isImportKeyword(node.expression) && node.typeArguments) {
-        return grammarErrorOnNode(node, Diagnostics.This_use_of_import_is_invalid_import_calls_can_be_written_but_they_must_have_parentheses_and_cannot_have_type_arguments);
-      }
-      return checkGrammarTypeArguments(node, node.typeArguments);
-    }
-    function checkGrammarClassDeclarationHeritageClauses(node) {
-      let seenExtendsClause = false;
-      let seenImplementsClause = false;
-      if (!checkGrammarModifiers(node) && node.heritageClauses) {
-        for (const heritageClause of node.heritageClauses) {
-          if (heritageClause.token === 96 /* ExtendsKeyword */) {
-            if (seenExtendsClause) {
-              return grammarErrorOnFirstToken(heritageClause, Diagnostics.extends_clause_already_seen);
-            }
-            if (seenImplementsClause) {
-              return grammarErrorOnFirstToken(heritageClause, Diagnostics.extends_clause_must_precede_implements_clause);
-            }
-            if (heritageClause.types.length > 1) {
-              return grammarErrorOnFirstToken(heritageClause.types[1], Diagnostics.Classes_can_only_extend_a_single_class);
-            }
-            seenExtendsClause = true;
-          } else {
-            Debug.assert(heritageClause.token === 119 /* ImplementsKeyword */);
-            if (seenImplementsClause) {
-              return grammarErrorOnFirstToken(heritageClause, Diagnostics.implements_clause_already_seen);
-            }
-            seenImplementsClause = true;
-          }
-          checkGrammarHeritageClause(heritageClause);
-        }
-      }
-    }
-    function checkGrammarInterfaceDeclaration(node) {
-      let seenExtendsClause = false;
-      if (node.heritageClauses) {
-        for (const heritageClause of node.heritageClauses) {
-          if (heritageClause.token === 96 /* ExtendsKeyword */) {
-            if (seenExtendsClause) {
-              return grammarErrorOnFirstToken(heritageClause, Diagnostics.extends_clause_already_seen);
-            }
-            seenExtendsClause = true;
-          } else {
-            Debug.assert(heritageClause.token === 119 /* ImplementsKeyword */);
-            return grammarErrorOnFirstToken(heritageClause, Diagnostics.Interface_declaration_cannot_have_implements_clause);
-          }
-          checkGrammarHeritageClause(heritageClause);
-        }
-      }
-      return false;
-    }
-    function checkGrammarComputedPropertyName(node) {
-      if (node.kind !== 166 /* ComputedPropertyName */) {
-        return false;
-      }
-      const computedPropertyName = node;
-      if (computedPropertyName.expression.kind === 225 /* BinaryExpression */ && computedPropertyName.expression.operatorToken.kind === 28 /* CommaToken */) {
-        return grammarErrorOnNode(computedPropertyName.expression, Diagnostics.A_comma_expression_is_not_allowed_in_a_computed_property_name);
-      }
-      return false;
-    }
-    function checkGrammarForGenerator(node) {
-      if (node.asteriskToken) {
-        Debug.assert(
-          node.kind === 261 /* FunctionDeclaration */ || node.kind === 217 /* FunctionExpression */ || node.kind === 173 /* MethodDeclaration */
-        );
-        if (node.flags & 16777216 /* Ambient */) {
-          return grammarErrorOnNode(node.asteriskToken, Diagnostics.Generators_are_not_allowed_in_an_ambient_context);
-        }
-        if (!node.body) {
-          return grammarErrorOnNode(node.asteriskToken, Diagnostics.An_overload_signature_cannot_be_declared_as_a_generator);
-        }
-      }
-    }
-    function checkGrammarForInvalidQuestionMark(questionToken, message) {
-      return !!questionToken && grammarErrorOnNode(questionToken, message);
-    }
-    function checkGrammarForInvalidExclamationToken(exclamationToken, message) {
-      return !!exclamationToken && grammarErrorOnNode(exclamationToken, message);
-    }
-    function checkGrammarObjectLiteralExpression(node, inDestructuring) {
-      const seen = /* @__PURE__ */ new Map();
-      for (const prop of node.properties) {
-        if (prop.kind === 304 /* SpreadAssignment */) {
-          if (inDestructuring) {
-            const expression = skipParentheses(prop.expression);
-            if (isArrayLiteralExpression(expression) || isObjectLiteralExpression(expression)) {
-              return grammarErrorOnNode(prop.expression, Diagnostics.A_rest_element_cannot_contain_a_binding_pattern);
-            }
-          }
-          continue;
-        }
-        const name = prop.name;
-        if (name.kind === 166 /* ComputedPropertyName */) {
-          checkGrammarComputedPropertyName(name);
-        }
-        if (prop.kind === 303 /* ShorthandPropertyAssignment */ && !inDestructuring && prop.objectAssignmentInitializer) {
-          grammarErrorOnNode(prop.equalsToken, Diagnostics.Did_you_mean_to_use_a_Colon_An_can_only_follow_a_property_name_when_the_containing_object_literal_is_part_of_a_destructuring_pattern);
-        }
-        if (name.kind === 81 /* PrivateIdentifier */) {
-          grammarErrorOnNode(name, Diagnostics.Private_identifiers_are_not_allowed_outside_class_bodies);
-        }
-        if (canHaveModifiers(prop) && prop.modifiers) {
-          for (const mod of prop.modifiers) {
-            if (isModifier(mod) && (mod.kind !== 134 /* AsyncKeyword */ || prop.kind !== 173 /* MethodDeclaration */)) {
-              grammarErrorOnNode(mod, Diagnostics._0_modifier_cannot_be_used_here, getTextOfNode(mod));
-            }
-          }
-        } else if (canHaveIllegalModifiers(prop) && prop.modifiers) {
-          for (const mod of prop.modifiers) {
-            if (isModifier(mod)) {
-              grammarErrorOnNode(mod, Diagnostics._0_modifier_cannot_be_used_here, getTextOfNode(mod));
-            }
-          }
-        }
-        let currentKind;
-        switch (prop.kind) {
-          case 303 /* ShorthandPropertyAssignment */:
-          case 302 /* PropertyAssignment */:
-            checkGrammarForInvalidExclamationToken(prop.exclamationToken, Diagnostics.A_definite_assignment_assertion_is_not_permitted_in_this_context);
-            checkGrammarForInvalidQuestionMark(prop.questionToken, Diagnostics.An_object_member_cannot_be_declared_optional);
-            if (name.kind === 9 /* NumericLiteral */) {
-              checkGrammarNumericLiteral(name);
-            }
-            currentKind = 4 /* PropertyAssignment */;
-            break;
-          case 173 /* MethodDeclaration */:
-            currentKind = 8 /* Method */;
-            break;
-          case 176 /* GetAccessor */:
-            currentKind = 1 /* GetAccessor */;
-            break;
-          case 177 /* SetAccessor */:
-            currentKind = 2 /* SetAccessor */;
-            break;
-          default:
-            Debug.assertNever(prop, "Unexpected syntax kind:" + prop.kind);
-        }
-        if (!inDestructuring) {
-          const effectiveName = getEffectivePropertyNameForPropertyNameNode(name);
-          if (effectiveName === void 0) {
-            continue;
-          }
-          const existingKind = seen.get(effectiveName);
-          if (!existingKind) {
-            seen.set(effectiveName, currentKind);
-          } else {
-            if (currentKind & 8 /* Method */ && existingKind & 8 /* Method */) {
-              grammarErrorOnNode(name, Diagnostics.Duplicate_identifier_0, getTextOfNode(name));
-            } else if (currentKind & 4 /* PropertyAssignment */ && existingKind & 4 /* PropertyAssignment */) {
-              grammarErrorOnNode(name, Diagnostics.An_object_literal_cannot_have_multiple_properties_with_the_same_name, getTextOfNode(name));
-            } else if (currentKind & 3 /* GetOrSetAccessor */ && existingKind & 3 /* GetOrSetAccessor */) {
-              if (existingKind !== 3 /* GetOrSetAccessor */ && currentKind !== existingKind) {
-                seen.set(effectiveName, currentKind | existingKind);
-              } else {
-                return grammarErrorOnNode(name, Diagnostics.An_object_literal_cannot_have_multiple_get_Slashset_accessors_with_the_same_name);
-              }
-            } else {
-              return grammarErrorOnNode(name, Diagnostics.An_object_literal_cannot_have_property_and_accessor_with_the_same_name);
-            }
-          }
-        }
-      }
-    }
-    function checkGrammarJsxElement(node) {
-      checkGrammarJsxName(node.tagName);
-      checkGrammarTypeArguments(node, node.typeArguments);
-      const seen = /* @__PURE__ */ new Map();
-      for (const attr of node.attributes.properties) {
-        if (attr.kind === 292 /* JsxSpreadAttribute */) {
-          continue;
-        }
-        const { name, initializer } = attr;
-        const escapedText = getEscapedTextOfJsxAttributeName(name);
-        if (!seen.get(escapedText)) {
-          seen.set(escapedText, true);
-        } else {
-          return grammarErrorOnNode(name, Diagnostics.JSX_elements_cannot_have_multiple_attributes_with_the_same_name);
-        }
-        if (initializer && initializer.kind === 293 /* JsxExpression */ && !initializer.expression) {
-          return grammarErrorOnNode(initializer, Diagnostics.JSX_attributes_must_only_be_assigned_a_non_empty_expression);
-        }
-      }
-    }
-    function checkGrammarJsxName(node) {
-      if (isPropertyAccessExpression(node) && isJsxNamespacedName(node.expression)) {
-        return grammarErrorOnNode(node.expression, Diagnostics.JSX_property_access_expressions_cannot_include_JSX_namespace_names);
-      }
-      if (isJsxNamespacedName(node) && getJSXTransformEnabled(compilerOptions) && !isIntrinsicJsxName(node.namespace.escapedText)) {
-        return grammarErrorOnNode(node, Diagnostics.React_components_cannot_include_JSX_namespace_names);
-      }
-    }
-    function checkGrammarJsxExpression(node) {
-      if (node.expression && isCommaSequence(node.expression)) {
-        return grammarErrorOnNode(node.expression, Diagnostics.JSX_expressions_may_not_use_the_comma_operator_Did_you_mean_to_write_an_array);
-      }
-    }
-    function checkGrammarForInOrForOfStatement(forInOrOfStatement) {
-      if (checkGrammarStatementInAmbientContext(forInOrOfStatement)) {
-        return true;
-      }
-      if (forInOrOfStatement.kind === 249 /* ForOfStatement */ && forInOrOfStatement.awaitModifier) {
-        if (!(forInOrOfStatement.flags & 32768 /* AwaitContext */)) {
-          const sourceFile = getSourceFileOfNode(forInOrOfStatement);
-          if (isInTopLevelContext(forInOrOfStatement)) {
-            if (!hasParseDiagnostics(sourceFile)) {
-              if (!isEffectiveExternalModule(sourceFile, compilerOptions)) {
-                diagnostics.add(createDiagnosticForNode(
-                  forInOrOfStatement.awaitModifier,
-                  Diagnostics.for_await_loops_are_only_allowed_at_the_top_level_of_a_file_when_that_file_is_a_module_but_this_file_has_no_imports_or_exports_Consider_adding_an_empty_export_to_make_this_file_a_module
-                ));
-              }
-              switch (moduleKind) {
-                case 100 /* Node16 */:
-                case 199 /* NodeNext */:
-                  if (sourceFile.impliedNodeFormat === 1 /* CommonJS */) {
-                    diagnostics.add(
-                      createDiagnosticForNode(forInOrOfStatement.awaitModifier, Diagnostics.The_current_file_is_a_CommonJS_module_and_cannot_use_await_at_the_top_level)
-                    );
-                    break;
-                  }
-                case 7 /* ES2022 */:
-                case 99 /* ESNext */:
-                case 4 /* System */:
-                  if (languageVersion >= 4 /* ES2017 */) {
-                    break;
-                  }
-                default:
-                  diagnostics.add(
-                    createDiagnosticForNode(
-                      forInOrOfStatement.awaitModifier,
-                      Diagnostics.Top_level_for_await_loops_are_only_allowed_when_the_module_option_is_set_to_es2022_esnext_system_node16_or_nodenext_and_the_target_option_is_set_to_es2017_or_higher
-                    )
-                  );
-                  break;
-              }
-            }
-          } else {
-            if (!hasParseDiagnostics(sourceFile)) {
-              const diagnostic = createDiagnosticForNode(forInOrOfStatement.awaitModifier, Diagnostics.for_await_loops_are_only_allowed_within_async_functions_and_at_the_top_levels_of_modules);
-              const func = getContainingFunction(forInOrOfStatement);
-              if (func && func.kind !== 175 /* Constructor */) {
-                Debug.assert((getFunctionFlags(func) & 2 /* Async */) === 0, "Enclosing function should never be an async function.");
-                const relatedInfo = createDiagnosticForNode(func, Diagnostics.Did_you_mean_to_mark_this_function_as_async);
-                addRelatedInfo(diagnostic, relatedInfo);
-              }
-              diagnostics.add(diagnostic);
-              return true;
-            }
-          }
-          return false;
-        }
-      }
-      if (isForOfStatement(forInOrOfStatement) && !(forInOrOfStatement.flags & 32768 /* AwaitContext */) && isIdentifier(forInOrOfStatement.initializer) && forInOrOfStatement.initializer.escapedText === "async") {
-        grammarErrorOnNode(forInOrOfStatement.initializer, Diagnostics.The_left_hand_side_of_a_for_of_statement_may_not_be_async);
-        return false;
-      }
-      if (forInOrOfStatement.initializer.kind === 260 /* VariableDeclarationList */) {
-        const variableList = forInOrOfStatement.initializer;
-        if (!checkGrammarVariableDeclarationList(variableList)) {
-          const declarations = variableList.declarations;
-          if (!declarations.length) {
-            return false;
-          }
-          if (declarations.length > 1) {
-            const diagnostic = forInOrOfStatement.kind === 248 /* ForInStatement */ ? Diagnostics.Only_a_single_variable_declaration_is_allowed_in_a_for_in_statement : Diagnostics.Only_a_single_variable_declaration_is_allowed_in_a_for_of_statement;
-            return grammarErrorOnFirstToken(variableList.declarations[1], diagnostic);
-          }
-          const firstDeclaration = declarations[0];
-          if (firstDeclaration.initializer) {
-            const diagnostic = forInOrOfStatement.kind === 248 /* ForInStatement */ ? Diagnostics.The_variable_declaration_of_a_for_in_statement_cannot_have_an_initializer : Diagnostics.The_variable_declaration_of_a_for_of_statement_cannot_have_an_initializer;
-            return grammarErrorOnNode(firstDeclaration.name, diagnostic);
-          }
-          if (firstDeclaration.type) {
-            const diagnostic = forInOrOfStatement.kind === 248 /* ForInStatement */ ? Diagnostics.The_left_hand_side_of_a_for_in_statement_cannot_use_a_type_annotation : Diagnostics.The_left_hand_side_of_a_for_of_statement_cannot_use_a_type_annotation;
-            return grammarErrorOnNode(firstDeclaration, diagnostic);
-          }
-        }
-      }
-      return false;
-    }
-    function checkGrammarAccessor(accessor) {
-      if (!(accessor.flags & 16777216 /* Ambient */) && accessor.parent.kind !== 186 /* TypeLiteral */ && accessor.parent.kind !== 263 /* InterfaceDeclaration */) {
-        if (languageVersion < 1 /* ES5 */) {
-          return grammarErrorOnNode(accessor.name, Diagnostics.Accessors_are_only_available_when_targeting_ECMAScript_5_and_higher);
-        }
-        if (languageVersion < 2 /* ES2015 */ && isPrivateIdentifier(accessor.name)) {
-          return grammarErrorOnNode(accessor.name, Diagnostics.Private_identifiers_are_only_available_when_targeting_ECMAScript_2015_and_higher);
-        }
-        if (accessor.body === void 0 && !hasSyntacticModifier(accessor, 256 /* Abstract */)) {
-          return grammarErrorAtPos(accessor, accessor.end - 1, ";".length, Diagnostics._0_expected, "{");
-        }
-      }
-      if (accessor.body) {
-        if (hasSyntacticModifier(accessor, 256 /* Abstract */)) {
-          return grammarErrorOnNode(accessor, Diagnostics.An_abstract_accessor_cannot_have_an_implementation);
-        }
-        if (accessor.parent.kind === 186 /* TypeLiteral */ || accessor.parent.kind === 263 /* InterfaceDeclaration */) {
-          return grammarErrorOnNode(accessor.body, Diagnostics.An_implementation_cannot_be_declared_in_ambient_contexts);
-        }
-      }
-      if (accessor.typeParameters) {
-        return grammarErrorOnNode(accessor.name, Diagnostics.An_accessor_cannot_have_type_parameters);
-      }
-      if (!doesAccessorHaveCorrectParameterCount(accessor)) {
-        return grammarErrorOnNode(
-          accessor.name,
-          accessor.kind === 176 /* GetAccessor */ ? Diagnostics.A_get_accessor_cannot_have_parameters : Diagnostics.A_set_accessor_must_have_exactly_one_parameter
-        );
-      }
-      if (accessor.kind === 177 /* SetAccessor */) {
-        if (accessor.type) {
-          return grammarErrorOnNode(accessor.name, Diagnostics.A_set_accessor_cannot_have_a_return_type_annotation);
-        }
-        const parameter = Debug.checkDefined(getSetAccessorValueParameter(accessor), "Return value does not match parameter count assertion.");
-        if (parameter.dotDotDotToken) {
-          return grammarErrorOnNode(parameter.dotDotDotToken, Diagnostics.A_set_accessor_cannot_have_rest_parameter);
-        }
-        if (parameter.questionToken) {
-          return grammarErrorOnNode(parameter.questionToken, Diagnostics.A_set_accessor_cannot_have_an_optional_parameter);
-        }
-        if (parameter.initializer) {
-          return grammarErrorOnNode(accessor.name, Diagnostics.A_set_accessor_parameter_cannot_have_an_initializer);
-        }
-      }
-      return false;
-    }
-    function doesAccessorHaveCorrectParameterCount(accessor) {
-      return getAccessorThisParameter(accessor) || accessor.parameters.length === (accessor.kind === 176 /* GetAccessor */ ? 0 : 1);
-    }
-    function getAccessorThisParameter(accessor) {
-      if (accessor.parameters.length === (accessor.kind === 176 /* GetAccessor */ ? 1 : 2)) {
-        return getThisParameter(accessor);
-      }
-    }
-    function checkGrammarTypeOperatorNode(node) {
-      if (node.operator === 158 /* UniqueKeyword */) {
-        if (node.type.kind !== 155 /* SymbolKeyword */) {
-          return grammarErrorOnNode(node.type, Diagnostics._0_expected, tokenToString(155 /* SymbolKeyword */));
-        }
-        let parent2 = walkUpParenthesizedTypes(node.parent);
-        if (isInJSFile(parent2) && isJSDocTypeExpression(parent2)) {
-          const host2 = getJSDocHost(parent2);
-          if (host2) {
-            parent2 = getSingleVariableOfVariableStatement(host2) || host2;
-          }
-        }
-        switch (parent2.kind) {
-          case 259 /* VariableDeclaration */:
-            const decl = parent2;
-            if (decl.name.kind !== 80 /* Identifier */) {
-              return grammarErrorOnNode(node, Diagnostics.unique_symbol_types_may_not_be_used_on_a_variable_declaration_with_a_binding_name);
-            }
-            if (!isVariableDeclarationInVariableStatement(decl)) {
-              return grammarErrorOnNode(node, Diagnostics.unique_symbol_types_are_only_allowed_on_variables_in_a_variable_statement);
-            }
-            if (!(decl.parent.flags & 2 /* Const */)) {
-              return grammarErrorOnNode(parent2.name, Diagnostics.A_variable_whose_type_is_a_unique_symbol_type_must_be_const);
-            }
-            break;
-          case 171 /* PropertyDeclaration */:
-            if (!isStatic(parent2) || !hasEffectiveReadonlyModifier(parent2)) {
-              return grammarErrorOnNode(parent2.name, Diagnostics.A_property_of_a_class_whose_type_is_a_unique_symbol_type_must_be_both_static_and_readonly);
-            }
-            break;
-          case 170 /* PropertySignature */:
-            if (!hasSyntacticModifier(parent2, 64 /* Readonly */)) {
-              return grammarErrorOnNode(parent2.name, Diagnostics.A_property_of_an_interface_or_type_literal_whose_type_is_a_unique_symbol_type_must_be_readonly);
-            }
-            break;
-          default:
-            return grammarErrorOnNode(node, Diagnostics.unique_symbol_types_are_not_allowed_here);
-        }
-      } else if (node.operator === 148 /* ReadonlyKeyword */) {
-        if (node.type.kind !== 187 /* ArrayType */ && node.type.kind !== 188 /* TupleType */) {
-          return grammarErrorOnFirstToken(node, Diagnostics.readonly_type_modifier_is_only_permitted_on_array_and_tuple_literal_types, tokenToString(155 /* SymbolKeyword */));
-        }
-      }
-    }
-    function checkGrammarForInvalidDynamicName(node, message) {
-      if (isNonBindableDynamicName(node)) {
-        return grammarErrorOnNode(node, message);
-      }
-    }
-    function checkGrammarMethod(node) {
-      if (checkGrammarFunctionLikeDeclaration(node)) {
-        return true;
-      }
-      if (node.kind === 173 /* MethodDeclaration */) {
-        if (node.parent.kind === 209 /* ObjectLiteralExpression */) {
-          if (node.modifiers && !(node.modifiers.length === 1 && first(node.modifiers).kind === 134 /* AsyncKeyword */)) {
-            return grammarErrorOnFirstToken(node, Diagnostics.Modifiers_cannot_appear_here);
-          } else if (checkGrammarForInvalidQuestionMark(node.questionToken, Diagnostics.An_object_member_cannot_be_declared_optional)) {
-            return true;
-          } else if (checkGrammarForInvalidExclamationToken(node.exclamationToken, Diagnostics.A_definite_assignment_assertion_is_not_permitted_in_this_context)) {
-            return true;
-          } else if (node.body === void 0) {
-            return grammarErrorAtPos(node, node.end - 1, ";".length, Diagnostics._0_expected, "{");
-          }
-        }
-        if (checkGrammarForGenerator(node)) {
-          return true;
-        }
-      }
-      if (isClassLike(node.parent)) {
-        if (languageVersion < 2 /* ES2015 */ && isPrivateIdentifier(node.name)) {
-          return grammarErrorOnNode(node.name, Diagnostics.Private_identifiers_are_only_available_when_targeting_ECMAScript_2015_and_higher);
-        }
-        if (node.flags & 16777216 /* Ambient */) {
-          return checkGrammarForInvalidDynamicName(node.name, Diagnostics.A_computed_property_name_in_an_ambient_context_must_refer_to_an_expression_whose_type_is_a_literal_type_or_a_unique_symbol_type);
-        } else if (node.kind === 173 /* MethodDeclaration */ && !node.body) {
-          return checkGrammarForInvalidDynamicName(node.name, Diagnostics.A_computed_property_name_in_a_method_overload_must_refer_to_an_expression_whose_type_is_a_literal_type_or_a_unique_symbol_type);
-        }
-      } else if (node.parent.kind === 263 /* InterfaceDeclaration */) {
-        return checkGrammarForInvalidDynamicName(node.name, Diagnostics.A_computed_property_name_in_an_interface_must_refer_to_an_expression_whose_type_is_a_literal_type_or_a_unique_symbol_type);
-      } else if (node.parent.kind === 186 /* TypeLiteral */) {
-        return checkGrammarForInvalidDynamicName(node.name, Diagnostics.A_computed_property_name_in_a_type_literal_must_refer_to_an_expression_whose_type_is_a_literal_type_or_a_unique_symbol_type);
-      }
-    }
-    function checkGrammarBreakOrContinueStatement(node) {
-      let current = node;
-      while (current) {
-        if (isFunctionLikeOrClassStaticBlockDeclaration(current)) {
-          return grammarErrorOnNode(node, Diagnostics.Jump_target_cannot_cross_function_boundary);
-        }
-        switch (current.kind) {
-          case 255 /* LabeledStatement */:
-            if (node.label && current.label.escapedText === node.label.escapedText) {
-              const isMisplacedContinueLabel = node.kind === 250 /* ContinueStatement */ && !isIterationStatement(
-                current.statement,
-                /*lookInLabeledStatements*/
-                true
-              );
-              if (isMisplacedContinueLabel) {
-                return grammarErrorOnNode(node, Diagnostics.A_continue_statement_can_only_jump_to_a_label_of_an_enclosing_iteration_statement);
-              }
-              return false;
-            }
-            break;
-          case 254 /* SwitchStatement */:
-            if (node.kind === 251 /* BreakStatement */ && !node.label) {
-              return false;
-            }
-            break;
-          default:
-            if (isIterationStatement(
-              current,
-              /*lookInLabeledStatements*/
-              false
-            ) && !node.label) {
-              return false;
-            }
-            break;
-        }
-        current = current.parent;
-      }
-      if (node.label) {
-        const message = node.kind === 251 /* BreakStatement */ ? Diagnostics.A_break_statement_can_only_jump_to_a_label_of_an_enclosing_statement : Diagnostics.A_continue_statement_can_only_jump_to_a_label_of_an_enclosing_iteration_statement;
-        return grammarErrorOnNode(node, message);
-      } else {
-        const message = node.kind === 251 /* BreakStatement */ ? Diagnostics.A_break_statement_can_only_be_used_within_an_enclosing_iteration_or_switch_statement : Diagnostics.A_continue_statement_can_only_be_used_within_an_enclosing_iteration_statement;
-        return grammarErrorOnNode(node, message);
-      }
-    }
-    function checkGrammarBindingElement(node) {
-      if (node.dotDotDotToken) {
-        const elements = node.parent.elements;
-        if (node !== last(elements)) {
-          return grammarErrorOnNode(node, Diagnostics.A_rest_element_must_be_last_in_a_destructuring_pattern);
-        }
-        checkGrammarForDisallowedTrailingComma(elements, Diagnostics.A_rest_parameter_or_binding_pattern_may_not_have_a_trailing_comma);
-        if (node.propertyName) {
-          return grammarErrorOnNode(node.name, Diagnostics.A_rest_element_cannot_have_a_property_name);
-        }
-      }
-      if (node.dotDotDotToken && node.initializer) {
-        return grammarErrorAtPos(node, node.initializer.pos - 1, 1, Diagnostics.A_rest_element_cannot_have_an_initializer);
-      }
-    }
-    function isStringOrNumberLiteralExpression(expr) {
-      return isStringOrNumericLiteralLike(expr) || expr.kind === 223 /* PrefixUnaryExpression */ && expr.operator === 41 /* MinusToken */ && expr.operand.kind === 9 /* NumericLiteral */;
-    }
-    function isBigIntLiteralExpression(expr) {
-      return expr.kind === 10 /* BigIntLiteral */ || expr.kind === 223 /* PrefixUnaryExpression */ && expr.operator === 41 /* MinusToken */ && expr.operand.kind === 10 /* BigIntLiteral */;
-    }
-    function isSimpleLiteralEnumReference(expr) {
-      if ((isPropertyAccessExpression(expr) || isElementAccessExpression(expr) && isStringOrNumberLiteralExpression(expr.argumentExpression)) && isEntityNameExpression(expr.expression)) {
-        return !!(checkExpressionCached(expr).flags & 1056 /* EnumLike */);
-      }
-    }
-    function checkAmbientInitializer(node) {
-      const initializer = node.initializer;
-      if (initializer) {
-        const isInvalidInitializer = !(isStringOrNumberLiteralExpression(initializer) || isSimpleLiteralEnumReference(initializer) || initializer.kind === 112 /* TrueKeyword */ || initializer.kind === 97 /* FalseKeyword */ || isBigIntLiteralExpression(initializer));
-        const isConstOrReadonly = isDeclarationReadonly(node) || isVariableDeclaration(node) && isVarConst(node);
-        if (isConstOrReadonly && !node.type) {
-          if (isInvalidInitializer) {
-            return grammarErrorOnNode(initializer, Diagnostics.A_const_initializer_in_an_ambient_context_must_be_a_string_or_numeric_literal_or_literal_enum_reference);
-          }
-        } else {
-          return grammarErrorOnNode(initializer, Diagnostics.Initializers_are_not_allowed_in_ambient_contexts);
-        }
-      }
-    }
-    function checkGrammarVariableDeclaration(node) {
-      if (node.parent.parent.kind !== 248 /* ForInStatement */ && node.parent.parent.kind !== 249 /* ForOfStatement */) {
-        if (node.flags & 16777216 /* Ambient */) {
-          checkAmbientInitializer(node);
-        } else if (!node.initializer) {
-          if (isBindingPattern(node.name) && !isBindingPattern(node.parent)) {
-            return grammarErrorOnNode(node, Diagnostics.A_destructuring_declaration_must_have_an_initializer);
-          }
-          if (isVarConst(node)) {
-            return grammarErrorOnNode(node, Diagnostics.const_declarations_must_be_initialized);
-          }
-        }
-      }
-      if (node.exclamationToken && (node.parent.parent.kind !== 242 /* VariableStatement */ || !node.type || node.initializer || node.flags & 16777216 /* Ambient */)) {
-        const message = node.initializer ? Diagnostics.Declarations_with_initializers_cannot_also_have_definite_assignment_assertions : !node.type ? Diagnostics.Declarations_with_definite_assignment_assertions_must_also_have_type_annotations : Diagnostics.A_definite_assignment_assertion_is_not_permitted_in_this_context;
-        return grammarErrorOnNode(node.exclamationToken, message);
-      }
-      if ((moduleKind < 5 /* ES2015 */ || getSourceFileOfNode(node).impliedNodeFormat === 1 /* CommonJS */) && moduleKind !== 4 /* System */ && !(node.parent.parent.flags & 16777216 /* Ambient */) && hasSyntacticModifier(node.parent.parent, 1 /* Export */)) {
-        checkESModuleMarker(node.name);
-      }
-      const checkLetConstNames = isLet(node) || isVarConst(node);
-      return checkLetConstNames && checkGrammarNameInLetOrConstDeclarations(node.name);
-    }
-    function checkESModuleMarker(name) {
-      if (name.kind === 80 /* Identifier */) {
-        if (idText(name) === "__esModule") {
-          return grammarErrorOnNodeSkippedOn("noEmit", name, Diagnostics.Identifier_expected_esModule_is_reserved_as_an_exported_marker_when_transforming_ECMAScript_modules);
-        }
-      } else {
-        const elements = name.elements;
-        for (const element of elements) {
-          if (!isOmittedExpression(element)) {
-            return checkESModuleMarker(element.name);
-          }
-        }
-      }
-      return false;
-    }
-    function checkGrammarNameInLetOrConstDeclarations(name) {
-      if (name.kind === 80 /* Identifier */) {
-        if (name.escapedText === "let") {
-          return grammarErrorOnNode(name, Diagnostics.let_is_not_allowed_to_be_used_as_a_name_in_let_or_const_declarations);
-        }
-      } else {
-        const elements = name.elements;
-        for (const element of elements) {
-          if (!isOmittedExpression(element)) {
-            checkGrammarNameInLetOrConstDeclarations(element.name);
-          }
-        }
-      }
-      return false;
-    }
-    function checkGrammarVariableDeclarationList(declarationList) {
-      const declarations = declarationList.declarations;
-      if (checkGrammarForDisallowedTrailingComma(declarationList.declarations)) {
-        return true;
-      }
-      if (!declarationList.declarations.length) {
-        return grammarErrorAtPos(declarationList, declarations.pos, declarations.end - declarations.pos, Diagnostics.Variable_declaration_list_cannot_be_empty);
-      }
-      return false;
-    }
-    function allowLetAndConstDeclarations(parent2) {
-      switch (parent2.kind) {
-        case 244 /* IfStatement */:
-        case 245 /* DoStatement */:
-        case 246 /* WhileStatement */:
-        case 253 /* WithStatement */:
-        case 247 /* ForStatement */:
-        case 248 /* ForInStatement */:
-        case 249 /* ForOfStatement */:
-          return false;
-        case 255 /* LabeledStatement */:
-          return allowLetAndConstDeclarations(parent2.parent);
-      }
-      return true;
-    }
-    function checkGrammarForDisallowedLetOrConstStatement(node) {
-      if (!allowLetAndConstDeclarations(node.parent)) {
-        if (isLet(node.declarationList)) {
-          return grammarErrorOnNode(node, Diagnostics.let_declarations_can_only_be_declared_inside_a_block);
-        } else if (isVarConst(node.declarationList)) {
-          return grammarErrorOnNode(node, Diagnostics.const_declarations_can_only_be_declared_inside_a_block);
-        }
-      }
-    }
-    function checkGrammarMetaProperty(node) {
-      const escapedText = node.name.escapedText;
-      switch (node.keywordToken) {
-        case 105 /* NewKeyword */:
-          if (escapedText !== "target") {
-            return grammarErrorOnNode(node.name, Diagnostics._0_is_not_a_valid_meta_property_for_keyword_1_Did_you_mean_2, unescapeLeadingUnderscores(node.name.escapedText), tokenToString(node.keywordToken), "target");
-          }
-          break;
-        case 102 /* ImportKeyword */:
-          if (escapedText !== "meta") {
-            return grammarErrorOnNode(node.name, Diagnostics._0_is_not_a_valid_meta_property_for_keyword_1_Did_you_mean_2, unescapeLeadingUnderscores(node.name.escapedText), tokenToString(node.keywordToken), "meta");
-          }
-          break;
-      }
-    }
-    function hasParseDiagnostics(sourceFile) {
-      return sourceFile.parseDiagnostics.length > 0;
-    }
-    function grammarErrorOnFirstToken(node, message, ...args) {
-      const sourceFile = getSourceFileOfNode(node);
-      if (!hasParseDiagnostics(sourceFile)) {
-        const span = getSpanOfTokenAtPosition(sourceFile, node.pos);
-        diagnostics.add(createFileDiagnostic(sourceFile, span.start, span.length, message, ...args));
-        return true;
-      }
-      return false;
-    }
-    function grammarErrorAtPos(nodeForSourceFile, start, length2, message, ...args) {
-      const sourceFile = getSourceFileOfNode(nodeForSourceFile);
-      if (!hasParseDiagnostics(sourceFile)) {
-        diagnostics.add(createFileDiagnostic(sourceFile, start, length2, message, ...args));
-        return true;
-      }
-      return false;
-    }
-    function grammarErrorOnNodeSkippedOn(key, node, message, ...args) {
-      const sourceFile = getSourceFileOfNode(node);
-      if (!hasParseDiagnostics(sourceFile)) {
-        errorSkippedOn(key, node, message, ...args);
-        return true;
-      }
-      return false;
-    }
-    function grammarErrorOnNode(node, message, ...args) {
-      const sourceFile = getSourceFileOfNode(node);
-      if (!hasParseDiagnostics(sourceFile)) {
-        diagnostics.add(createDiagnosticForNode(node, message, ...args));
-        return true;
-      }
-      return false;
-    }
-    function checkGrammarConstructorTypeParameters(node) {
-      const jsdocTypeParameters = isInJSFile(node) ? getJSDocTypeParameterDeclarations(node) : void 0;
-      const range = node.typeParameters || jsdocTypeParameters && firstOrUndefined(jsdocTypeParameters);
-      if (range) {
-        const pos = range.pos === range.end ? range.pos : skipTrivia(getSourceFileOfNode(node).text, range.pos);
-        return grammarErrorAtPos(node, pos, range.end - pos, Diagnostics.Type_parameters_cannot_appear_on_a_constructor_declaration);
-      }
-    }
-    function checkGrammarConstructorTypeAnnotation(node) {
-      const type = node.type || getEffectiveReturnTypeNode(node);
-      if (type) {
-        return grammarErrorOnNode(type, Diagnostics.Type_annotation_cannot_appear_on_a_constructor_declaration);
-      }
-    }
-    function checkGrammarProperty(node) {
-      if (isComputedPropertyName(node.name) && isBinaryExpression(node.name.expression) && node.name.expression.operatorToken.kind === 103 /* InKeyword */) {
-        return grammarErrorOnNode(node.parent.members[0], Diagnostics.A_mapped_type_may_not_declare_properties_or_methods);
-      }
-      if (isClassLike(node.parent)) {
-        if (isStringLiteral(node.name) && node.name.text === "constructor") {
-          return grammarErrorOnNode(node.name, Diagnostics.Classes_may_not_have_a_field_named_constructor);
-        }
-        if (checkGrammarForInvalidDynamicName(node.name, Diagnostics.A_computed_property_name_in_a_class_property_declaration_must_have_a_simple_literal_type_or_a_unique_symbol_type)) {
-          return true;
-        }
-        if (languageVersion < 2 /* ES2015 */ && isPrivateIdentifier(node.name)) {
-          return grammarErrorOnNode(node.name, Diagnostics.Private_identifiers_are_only_available_when_targeting_ECMAScript_2015_and_higher);
-        }
-        if (languageVersion < 2 /* ES2015 */ && isAutoAccessorPropertyDeclaration(node)) {
-          return grammarErrorOnNode(node.name, Diagnostics.Properties_with_the_accessor_modifier_are_only_available_when_targeting_ECMAScript_2015_and_higher);
-        }
-        if (isAutoAccessorPropertyDeclaration(node) && checkGrammarForInvalidQuestionMark(node.questionToken, Diagnostics.An_accessor_property_cannot_be_declared_optional)) {
-          return true;
-        }
-      } else if (node.parent.kind === 263 /* InterfaceDeclaration */) {
-        if (checkGrammarForInvalidDynamicName(node.name, Diagnostics.A_computed_property_name_in_an_interface_must_refer_to_an_expression_whose_type_is_a_literal_type_or_a_unique_symbol_type)) {
-          return true;
-        }
-        Debug.assertNode(node, isPropertySignature);
-        if (node.initializer) {
-          return grammarErrorOnNode(node.initializer, Diagnostics.An_interface_property_cannot_have_an_initializer);
-        }
-      } else if (isTypeLiteralNode(node.parent)) {
-        if (checkGrammarForInvalidDynamicName(node.name, Diagnostics.A_computed_property_name_in_a_type_literal_must_refer_to_an_expression_whose_type_is_a_literal_type_or_a_unique_symbol_type)) {
-          return true;
-        }
-        Debug.assertNode(node, isPropertySignature);
-        if (node.initializer) {
-          return grammarErrorOnNode(node.initializer, Diagnostics.A_type_literal_property_cannot_have_an_initializer);
-        }
-      }
-      if (node.flags & 16777216 /* Ambient */) {
-        checkAmbientInitializer(node);
-      }
-      if (isPropertyDeclaration(node) && node.exclamationToken && (!isClassLike(node.parent) || !node.type || node.initializer || node.flags & 16777216 /* Ambient */ || isStatic(node) || hasAbstractModifier(node))) {
-        const message = node.initializer ? Diagnostics.Declarations_with_initializers_cannot_also_have_definite_assignment_assertions : !node.type ? Diagnostics.Declarations_with_definite_assignment_assertions_must_also_have_type_annotations : Diagnostics.A_definite_assignment_assertion_is_not_permitted_in_this_context;
-        return grammarErrorOnNode(node.exclamationToken, message);
-      }
-    }
-    function checkGrammarTopLevelElementForRequiredDeclareModifier(node) {
-      if (node.kind === 263 /* InterfaceDeclaration */ || node.kind === 264 /* TypeAliasDeclaration */ || node.kind === 271 /* ImportDeclaration */ || node.kind === 270 /* ImportEqualsDeclaration */ || node.kind === 277 /* ExportDeclaration */ || node.kind === 276 /* ExportAssignment */ || node.kind === 269 /* NamespaceExportDeclaration */ || hasSyntacticModifier(node, 2 /* Ambient */ | 1 /* Export */ | 1024 /* Default */)) {
-        return false;
-      }
-      return grammarErrorOnFirstToken(node, Diagnostics.Top_level_declarations_in_d_ts_files_must_start_with_either_a_declare_or_export_modifier);
-    }
-    function checkGrammarTopLevelElementsForRequiredDeclareModifier(file) {
-      for (const decl of file.statements) {
-        if (isDeclaration(decl) || decl.kind === 242 /* VariableStatement */) {
-          if (checkGrammarTopLevelElementForRequiredDeclareModifier(decl)) {
-            return true;
-          }
-        }
-      }
-      return false;
-    }
-    function checkGrammarSourceFile(node) {
-      return !!(node.flags & 16777216 /* Ambient */) && checkGrammarTopLevelElementsForRequiredDeclareModifier(node);
-    }
-    function checkGrammarStatementInAmbientContext(node) {
-      if (node.flags & 16777216 /* Ambient */) {
-        const links = getNodeLinks(node);
-        if (!links.hasReportedStatementInAmbientContext && (isFunctionLike(node.parent) || isAccessor(node.parent))) {
-          return getNodeLinks(node).hasReportedStatementInAmbientContext = grammarErrorOnFirstToken(node, Diagnostics.An_implementation_cannot_be_declared_in_ambient_contexts);
-        }
-        if (node.parent.kind === 240 /* Block */ || node.parent.kind === 267 /* ModuleBlock */ || node.parent.kind === 311 /* SourceFile */) {
-          const links2 = getNodeLinks(node.parent);
-          if (!links2.hasReportedStatementInAmbientContext) {
-            return links2.hasReportedStatementInAmbientContext = grammarErrorOnFirstToken(node, Diagnostics.Statements_are_not_allowed_in_ambient_contexts);
-          }
-        } else {
-        }
-      }
-      return false;
-    }
-    function checkGrammarNumericLiteral(node) {
-      const isFractional = getTextOfNode(node).indexOf(".") !== -1;
-      const isScientific = node.numericLiteralFlags & 16 /* Scientific */;
-      if (isFractional || isScientific) {
-        return;
-      }
-      const value = +node.text;
-      if (value <= 2 ** 53 - 1) {
-        return;
-      }
-      addErrorOrSuggestion(
-        /*isError*/
-        false,
-        createDiagnosticForNode(node, Diagnostics.Numeric_literals_with_absolute_values_equal_to_2_53_or_greater_are_too_large_to_be_represented_accurately_as_integers)
-      );
-    }
-    function checkGrammarBigIntLiteral(node) {
-      const literalType = isLiteralTypeNode(node.parent) || isPrefixUnaryExpression(node.parent) && isLiteralTypeNode(node.parent.parent);
-      if (!literalType) {
-        if (languageVersion < 7 /* ES2020 */) {
-          if (grammarErrorOnNode(node, Diagnostics.BigInt_literals_are_not_available_when_targeting_lower_than_ES2020)) {
-            return true;
-          }
-        }
-      }
-      return false;
-    }
-    function grammarErrorAfterFirstToken(node, message, ...args) {
-      const sourceFile = getSourceFileOfNode(node);
-      if (!hasParseDiagnostics(sourceFile)) {
-        const span = getSpanOfTokenAtPosition(sourceFile, node.pos);
-        diagnostics.add(createFileDiagnostic(
-          sourceFile,
-          textSpanEnd(span),
-          /*length*/
-          0,
-          message,
-          ...args
-        ));
-        return true;
-      }
-      return false;
-    }
-    function getAmbientModules() {
-      if (!ambientModulesCache) {
-        ambientModulesCache = [];
-        globals.forEach((global2, sym) => {
-          if (ambientModuleSymbolRegex.test(sym)) {
-            ambientModulesCache.push(global2);
-          }
-        });
-      }
-      return ambientModulesCache;
-    }
-    function checkGrammarImportClause(node) {
-      var _a;
-      if (node.isTypeOnly && node.name && node.namedBindings) {
-        return grammarErrorOnNode(node, Diagnostics.A_type_only_import_can_specify_a_default_import_or_named_bindings_but_not_both);
-      }
-      if (node.isTypeOnly && ((_a = node.namedBindings) == null ? void 0 : _a.kind) === 274 /* NamedImports */) {
-        return checkGrammarNamedImportsOrExports(node.namedBindings);
-      }
-      return false;
-    }
-    function checkGrammarNamedImportsOrExports(namedBindings) {
-      return !!forEach(namedBindings.elements, (specifier) => {
-        if (specifier.isTypeOnly) {
-          return grammarErrorOnFirstToken(
-            specifier,
-            specifier.kind === 275 /* ImportSpecifier */ ? Diagnostics.The_type_modifier_cannot_be_used_on_a_named_import_when_import_type_is_used_on_its_import_statement : Diagnostics.The_type_modifier_cannot_be_used_on_a_named_export_when_export_type_is_used_on_its_export_statement
-          );
-        }
-      });
-    }
-    function checkGrammarImportCallExpression(node) {
-      if (compilerOptions.verbatimModuleSyntax && moduleKind === 1 /* CommonJS */) {
-        return grammarErrorOnNode(node, Diagnostics.ESM_syntax_is_not_allowed_in_a_CommonJS_module_when_verbatimModuleSyntax_is_enabled);
-      }
-      if (moduleKind === 5 /* ES2015 */) {
-        return grammarErrorOnNode(node, Diagnostics.Dynamic_imports_are_only_supported_when_the_module_flag_is_set_to_es2020_es2022_esnext_commonjs_amd_system_umd_node16_or_nodenext);
-      }
-      if (node.typeArguments) {
-        return grammarErrorOnNode(node, Diagnostics.This_use_of_import_is_invalid_import_calls_can_be_written_but_they_must_have_parentheses_and_cannot_have_type_arguments);
-      }
-      const nodeArguments = node.arguments;
-      if (moduleKind !== 99 /* ESNext */ && moduleKind !== 199 /* NodeNext */ && moduleKind !== 100 /* Node16 */) {
-        checkGrammarForDisallowedTrailingComma(nodeArguments);
-        if (nodeArguments.length > 1) {
-          const assertionArgument = nodeArguments[1];
-          return grammarErrorOnNode(assertionArgument, Diagnostics.Dynamic_imports_only_support_a_second_argument_when_the_module_option_is_set_to_esnext_node16_or_nodenext);
-        }
-      }
-      if (nodeArguments.length === 0 || nodeArguments.length > 2) {
-        return grammarErrorOnNode(node, Diagnostics.Dynamic_imports_can_only_accept_a_module_specifier_and_an_optional_assertion_as_arguments);
-      }
-      const spreadElement = find(nodeArguments, isSpreadElement);
-      if (spreadElement) {
-        return grammarErrorOnNode(spreadElement, Diagnostics.Argument_of_dynamic_import_cannot_be_spread_element);
-      }
-      return false;
-    }
-    function findMatchingTypeReferenceOrTypeAliasReference(source, unionTarget) {
-      const sourceObjectFlags = getObjectFlags(source);
-      if (sourceObjectFlags & (4 /* Reference */ | 16 /* Anonymous */) && unionTarget.flags & 1048576 /* Union */) {
-        return find(unionTarget.types, (target) => {
-          if (target.flags & 524288 /* Object */) {
-            const overlapObjFlags = sourceObjectFlags & getObjectFlags(target);
-            if (overlapObjFlags & 4 /* Reference */) {
-              return source.target === target.target;
-            }
-            if (overlapObjFlags & 16 /* Anonymous */) {
-              return !!source.aliasSymbol && source.aliasSymbol === target.aliasSymbol;
-            }
-          }
-          return false;
-        });
-      }
-    }
-    function findBestTypeForObjectLiteral(source, unionTarget) {
-      if (getObjectFlags(source) & 128 /* ObjectLiteral */ && someType(unionTarget, isArrayLikeType)) {
-        return find(unionTarget.types, (t) => !isArrayLikeType(t));
-      }
-    }
-    function findBestTypeForInvokable(source, unionTarget) {
-      let signatureKind = 0 /* Call */;
-      const hasSignatures = getSignaturesOfType(source, signatureKind).length > 0 || (signatureKind = 1 /* Construct */, getSignaturesOfType(source, signatureKind).length > 0);
-      if (hasSignatures) {
-        return find(unionTarget.types, (t) => getSignaturesOfType(t, signatureKind).length > 0);
-      }
-    }
-    function findMostOverlappyType(source, unionTarget) {
-      let bestMatch;
-      if (!(source.flags & (402784252 /* Primitive */ | 406847488 /* InstantiablePrimitive */))) {
-        let matchingCount = 0;
-        for (const target of unionTarget.types) {
-          if (!(target.flags & (402784252 /* Primitive */ | 406847488 /* InstantiablePrimitive */))) {
-            const overlap = getIntersectionType([getIndexType(source), getIndexType(target)]);
-            if (overlap.flags & 4194304 /* Index */) {
-              return target;
-            } else if (isUnitType(overlap) || overlap.flags & 1048576 /* Union */) {
-              const len = overlap.flags & 1048576 /* Union */ ? countWhere(overlap.types, isUnitType) : 1;
-              if (len >= matchingCount) {
-                bestMatch = target;
-                matchingCount = len;
-              }
-            }
-          }
-        }
-      }
-      return bestMatch;
-    }
-    function filterPrimitivesIfContainsNonPrimitive(type) {
-      if (maybeTypeOfKind(type, 67108864 /* NonPrimitive */)) {
-        const result = filterType(type, (t) => !(t.flags & 402784252 /* Primitive */));
-        if (!(result.flags & 131072 /* Never */)) {
-          return result;
-        }
-      }
-      return type;
-    }
-    function findMatchingDiscriminantType(source, target, isRelatedTo) {
-      if (target.flags & 1048576 /* Union */ && source.flags & (2097152 /* Intersection */ | 524288 /* Object */)) {
-        const match = getMatchingUnionConstituentForType(target, source);
-        if (match) {
-          return match;
-        }
-        const sourceProperties = getPropertiesOfType(source);
-        if (sourceProperties) {
-          const sourcePropertiesFiltered = findDiscriminantProperties(sourceProperties, target);
-          if (sourcePropertiesFiltered) {
-            const discriminated = discriminateTypeByDiscriminableItems(target, map(sourcePropertiesFiltered, (p) => [() => getTypeOfSymbol(p), p.escapedName]), isRelatedTo);
-            if (discriminated !== target) {
-              return discriminated;
-            }
-          }
-        }
-      }
-      return void 0;
-    }
-    function getEffectivePropertyNameForPropertyNameNode(node) {
-      const name = getPropertyNameForPropertyNameNode(node);
-      return name ? name : isComputedPropertyName(node) && isEntityNameExpression(node.expression) ? tryGetNameFromEntityNameExpression(node.expression) : void 0;
-    }
-  }
-  function isNotAccessor(declaration) {
-    return !isAccessor(declaration);
-  }
-  function isNotOverload(declaration) {
-    return declaration.kind !== 261 /* FunctionDeclaration */ && declaration.kind !== 173 /* MethodDeclaration */ || !!declaration.body;
-  }
-  function isDeclarationNameOrImportPropertyName(name) {
-    switch (name.parent.kind) {
-      case 275 /* ImportSpecifier */:
-      case 280 /* ExportSpecifier */:
-        return isIdentifier(name);
-      default:
-        return isDeclarationName(name);
-    }
-  }
-  function getIterationTypesKeyFromIterationTypeKind(typeKind) {
-    switch (typeKind) {
-      case 0 /* Yield */:
-        return "yieldType";
-      case 1 /* Return */:
-        return "returnType";
-      case 2 /* Next */:
-        return "nextType";
-    }
-  }
-  function signatureHasRestParameter(s) {
-    return !!(s.flags & 1 /* HasRestParameter */);
-  }
-  function signatureHasLiteralTypes(s) {
-    return !!(s.flags & 2 /* HasLiteralTypes */);
-  }
-  function createBasicNodeBuilderModuleSpecifierResolutionHost(host) {
-    return {
-      getCommonSourceDirectory: !!host.getCommonSourceDirectory ? () => host.getCommonSourceDirectory() : () => "",
-      getCurrentDirectory: () => host.getCurrentDirectory(),
-      getSymlinkCache: maybeBind(host, host.getSymlinkCache),
-      getPackageJsonInfoCache: () => {
-        var _a;
-        return (_a = host.getPackageJsonInfoCache) == null ? void 0 : _a.call(host);
-      },
-      useCaseSensitiveFileNames: maybeBind(host, host.useCaseSensitiveFileNames),
-      redirectTargetsMap: host.redirectTargetsMap,
-      getProjectReferenceRedirect: (fileName) => host.getProjectReferenceRedirect(fileName),
-      isSourceOfProjectReferenceRedirect: (fileName) => host.isSourceOfProjectReferenceRedirect(fileName),
-      fileExists: (fileName) => host.fileExists(fileName),
-      getFileIncludeReasons: () => host.getFileIncludeReasons(),
-      readFile: host.readFile ? (fileName) => host.readFile(fileName) : void 0
-    };
-  }
-  var ambientModuleSymbolRegex, anon, nextSymbolId, nextNodeId, nextMergeId, nextFlowId, TypeFacts, typeofNEFacts, CheckMode, SignatureCheckMode, isNotOverloadAndNotAccessor, intrinsicTypeKinds, SymbolLinks, JsxNames, SymbolTrackerImpl;
-  var init_checker = __esm({
-    "src/compiler/checker.ts"() {
-      "use strict";
-      init_ts2();
-      init_ts_moduleSpecifiers();
-      init_ts_performance();
-      ambientModuleSymbolRegex = /^".+"$/;
-      anon = "(anonymous)";
-      nextSymbolId = 1;
-      nextNodeId = 1;
-      nextMergeId = 1;
-      nextFlowId = 1;
-      TypeFacts = /* @__PURE__ */ ((TypeFacts3) => {
-        TypeFacts3[TypeFacts3["None"] = 0] = "None";
-        TypeFacts3[TypeFacts3["TypeofEQString"] = 1] = "TypeofEQString";
-        TypeFacts3[TypeFacts3["TypeofEQNumber"] = 2] = "TypeofEQNumber";
-        TypeFacts3[TypeFacts3["TypeofEQBigInt"] = 4] = "TypeofEQBigInt";
-        TypeFacts3[TypeFacts3["TypeofEQBoolean"] = 8] = "TypeofEQBoolean";
-        TypeFacts3[TypeFacts3["TypeofEQSymbol"] = 16] = "TypeofEQSymbol";
-        TypeFacts3[TypeFacts3["TypeofEQObject"] = 32] = "TypeofEQObject";
-        TypeFacts3[TypeFacts3["TypeofEQFunction"] = 64] = "TypeofEQFunction";
-        TypeFacts3[TypeFacts3["TypeofEQHostObject"] = 128] = "TypeofEQHostObject";
-        TypeFacts3[TypeFacts3["TypeofNEString"] = 256] = "TypeofNEString";
-        TypeFacts3[TypeFacts3["TypeofNENumber"] = 512] = "TypeofNENumber";
-        TypeFacts3[TypeFacts3["TypeofNEBigInt"] = 1024] = "TypeofNEBigInt";
-        TypeFacts3[TypeFacts3["TypeofNEBoolean"] = 2048] = "TypeofNEBoolean";
-        TypeFacts3[TypeFacts3["TypeofNESymbol"] = 4096] = "TypeofNESymbol";
-        TypeFacts3[TypeFacts3["TypeofNEObject"] = 8192] = "TypeofNEObject";
-        TypeFacts3[TypeFacts3["TypeofNEFunction"] = 16384] = "TypeofNEFunction";
-        TypeFacts3[TypeFacts3["TypeofNEHostObject"] = 32768] = "TypeofNEHostObject";
-        TypeFacts3[TypeFacts3["EQUndefined"] = 65536] = "EQUndefined";
-        TypeFacts3[TypeFacts3["EQNull"] = 131072] = "EQNull";
-        TypeFacts3[TypeFacts3["EQUndefinedOrNull"] = 262144] = "EQUndefinedOrNull";
-        TypeFacts3[TypeFacts3["NEUndefined"] = 524288] = "NEUndefined";
-        TypeFacts3[TypeFacts3["NENull"] = 1048576] = "NENull";
-        TypeFacts3[TypeFacts3["NEUndefinedOrNull"] = 2097152] = "NEUndefinedOrNull";
-        TypeFacts3[TypeFacts3["Truthy"] = 4194304] = "Truthy";
-        TypeFacts3[TypeFacts3["Falsy"] = 8388608] = "Falsy";
-        TypeFacts3[TypeFacts3["IsUndefined"] = 16777216] = "IsUndefined";
-        TypeFacts3[TypeFacts3["IsNull"] = 33554432] = "IsNull";
-        TypeFacts3[TypeFacts3["IsUndefinedOrNull"] = 50331648] = "IsUndefinedOrNull";
-        TypeFacts3[TypeFacts3["All"] = 134217727] = "All";
-        TypeFacts3[TypeFacts3["BaseStringStrictFacts"] = 3735041] = "BaseStringStrictFacts";
-        TypeFacts3[TypeFacts3["BaseStringFacts"] = 12582401] = "BaseStringFacts";
-        TypeFacts3[TypeFacts3["StringStrictFacts"] = 16317953] = "StringStrictFacts";
-        TypeFacts3[TypeFacts3["StringFacts"] = 16776705] = "StringFacts";
-        TypeFacts3[TypeFacts3["EmptyStringStrictFacts"] = 12123649] = "EmptyStringStrictFacts";
-        TypeFacts3[TypeFacts3["EmptyStringFacts"] = 12582401 /* BaseStringFacts */] = "EmptyStringFacts";
-        TypeFacts3[TypeFacts3["NonEmptyStringStrictFacts"] = 7929345] = "NonEmptyStringStrictFacts";
-        TypeFacts3[TypeFacts3["NonEmptyStringFacts"] = 16776705] = "NonEmptyStringFacts";
-        TypeFacts3[TypeFacts3["BaseNumberStrictFacts"] = 3734786] = "BaseNumberStrictFacts";
-        TypeFacts3[TypeFacts3["BaseNumberFacts"] = 12582146] = "BaseNumberFacts";
-        TypeFacts3[TypeFacts3["NumberStrictFacts"] = 16317698] = "NumberStrictFacts";
-        TypeFacts3[TypeFacts3["NumberFacts"] = 16776450] = "NumberFacts";
-        TypeFacts3[TypeFacts3["ZeroNumberStrictFacts"] = 12123394] = "ZeroNumberStrictFacts";
-        TypeFacts3[TypeFacts3["ZeroNumberFacts"] = 12582146 /* BaseNumberFacts */] = "ZeroNumberFacts";
-        TypeFacts3[TypeFacts3["NonZeroNumberStrictFacts"] = 7929090] = "NonZeroNumberStrictFacts";
-        TypeFacts3[TypeFacts3["NonZeroNumberFacts"] = 16776450] = "NonZeroNumberFacts";
-        TypeFacts3[TypeFacts3["BaseBigIntStrictFacts"] = 3734276] = "BaseBigIntStrictFacts";
-        TypeFacts3[TypeFacts3["BaseBigIntFacts"] = 12581636] = "BaseBigIntFacts";
-        TypeFacts3[TypeFacts3["BigIntStrictFacts"] = 16317188] = "BigIntStrictFacts";
-        TypeFacts3[TypeFacts3["BigIntFacts"] = 16775940] = "BigIntFacts";
-        TypeFacts3[TypeFacts3["ZeroBigIntStrictFacts"] = 12122884] = "ZeroBigIntStrictFacts";
-        TypeFacts3[TypeFacts3["ZeroBigIntFacts"] = 12581636 /* BaseBigIntFacts */] = "ZeroBigIntFacts";
-        TypeFacts3[TypeFacts3["NonZeroBigIntStrictFacts"] = 7928580] = "NonZeroBigIntStrictFacts";
-        TypeFacts3[TypeFacts3["NonZeroBigIntFacts"] = 16775940] = "NonZeroBigIntFacts";
-        TypeFacts3[TypeFacts3["BaseBooleanStrictFacts"] = 3733256] = "BaseBooleanStrictFacts";
-        TypeFacts3[TypeFacts3["BaseBooleanFacts"] = 12580616] = "BaseBooleanFacts";
-        TypeFacts3[TypeFacts3["BooleanStrictFacts"] = 16316168] = "BooleanStrictFacts";
-        TypeFacts3[TypeFacts3["BooleanFacts"] = 16774920] = "BooleanFacts";
-        TypeFacts3[TypeFacts3["FalseStrictFacts"] = 12121864] = "FalseStrictFacts";
-        TypeFacts3[TypeFacts3["FalseFacts"] = 12580616 /* BaseBooleanFacts */] = "FalseFacts";
-        TypeFacts3[TypeFacts3["TrueStrictFacts"] = 7927560] = "TrueStrictFacts";
-        TypeFacts3[TypeFacts3["TrueFacts"] = 16774920] = "TrueFacts";
-        TypeFacts3[TypeFacts3["SymbolStrictFacts"] = 7925520] = "SymbolStrictFacts";
-        TypeFacts3[TypeFacts3["SymbolFacts"] = 16772880] = "SymbolFacts";
-        TypeFacts3[TypeFacts3["ObjectStrictFacts"] = 7888800] = "ObjectStrictFacts";
-        TypeFacts3[TypeFacts3["ObjectFacts"] = 16736160] = "ObjectFacts";
-        TypeFacts3[TypeFacts3["FunctionStrictFacts"] = 7880640] = "FunctionStrictFacts";
-        TypeFacts3[TypeFacts3["FunctionFacts"] = 16728e3] = "FunctionFacts";
-        TypeFacts3[TypeFacts3["VoidFacts"] = 9830144] = "VoidFacts";
-        TypeFacts3[TypeFacts3["UndefinedFacts"] = 26607360] = "UndefinedFacts";
-        TypeFacts3[TypeFacts3["NullFacts"] = 42917664] = "NullFacts";
-        TypeFacts3[TypeFacts3["EmptyObjectStrictFacts"] = 83427327] = "EmptyObjectStrictFacts";
-        TypeFacts3[TypeFacts3["EmptyObjectFacts"] = 83886079] = "EmptyObjectFacts";
-        TypeFacts3[TypeFacts3["UnknownFacts"] = 83886079] = "UnknownFacts";
-        TypeFacts3[TypeFacts3["AllTypeofNE"] = 556800] = "AllTypeofNE";
-        TypeFacts3[TypeFacts3["OrFactsMask"] = 8256] = "OrFactsMask";
-        TypeFacts3[TypeFacts3["AndFactsMask"] = 134209471] = "AndFactsMask";
-        return TypeFacts3;
-      })(TypeFacts || {});
-      typeofNEFacts = new Map(Object.entries({
-        string: 256 /* TypeofNEString */,
-        number: 512 /* TypeofNENumber */,
-        bigint: 1024 /* TypeofNEBigInt */,
-        boolean: 2048 /* TypeofNEBoolean */,
-        symbol: 4096 /* TypeofNESymbol */,
-        undefined: 524288 /* NEUndefined */,
-        object: 8192 /* TypeofNEObject */,
-        function: 16384 /* TypeofNEFunction */
-      }));
-      CheckMode = /* @__PURE__ */ ((CheckMode3) => {
-        CheckMode3[CheckMode3["Normal"] = 0] = "Normal";
-        CheckMode3[CheckMode3["Contextual"] = 1] = "Contextual";
-        CheckMode3[CheckMode3["Inferential"] = 2] = "Inferential";
-        CheckMode3[CheckMode3["SkipContextSensitive"] = 4] = "SkipContextSensitive";
-        CheckMode3[CheckMode3["SkipGenericFunctions"] = 8] = "SkipGenericFunctions";
-        CheckMode3[CheckMode3["IsForSignatureHelp"] = 16] = "IsForSignatureHelp";
-        CheckMode3[CheckMode3["IsForStringLiteralArgumentCompletions"] = 32] = "IsForStringLiteralArgumentCompletions";
-        CheckMode3[CheckMode3["RestBindingElement"] = 64] = "RestBindingElement";
-        return CheckMode3;
-      })(CheckMode || {});
-      SignatureCheckMode = /* @__PURE__ */ ((SignatureCheckMode3) => {
-        SignatureCheckMode3[SignatureCheckMode3["None"] = 0] = "None";
-        SignatureCheckMode3[SignatureCheckMode3["BivariantCallback"] = 1] = "BivariantCallback";
-        SignatureCheckMode3[SignatureCheckMode3["StrictCallback"] = 2] = "StrictCallback";
-        SignatureCheckMode3[SignatureCheckMode3["IgnoreReturnTypes"] = 4] = "IgnoreReturnTypes";
-        SignatureCheckMode3[SignatureCheckMode3["StrictArity"] = 8] = "StrictArity";
-        SignatureCheckMode3[SignatureCheckMode3["StrictTopSignature"] = 16] = "StrictTopSignature";
-        SignatureCheckMode3[SignatureCheckMode3["Callback"] = 3] = "Callback";
-        return SignatureCheckMode3;
-      })(SignatureCheckMode || {});
-      isNotOverloadAndNotAccessor = and(isNotOverload, isNotAccessor);
-      intrinsicTypeKinds = new Map(Object.entries({
-        Uppercase: 0 /* Uppercase */,
-        Lowercase: 1 /* Lowercase */,
-        Capitalize: 2 /* Capitalize */,
-        Uncapitalize: 3 /* Uncapitalize */
-      }));
-      SymbolLinks = class {
-      };
-      ((JsxNames2) => {
-        JsxNames2.JSX = "JSX";
-        JsxNames2.IntrinsicElements = "IntrinsicElements";
-        JsxNames2.ElementClass = "ElementClass";
-        JsxNames2.ElementAttributesPropertyNameContainer = "ElementAttributesProperty";
-        JsxNames2.ElementChildrenAttributeNameContainer = "ElementChildrenAttribute";
-        JsxNames2.Element = "Element";
-        JsxNames2.ElementType = "ElementType";
-        JsxNames2.IntrinsicAttributes = "IntrinsicAttributes";
-        JsxNames2.IntrinsicClassAttributes = "IntrinsicClassAttributes";
-        JsxNames2.LibraryManagedAttributes = "LibraryManagedAttributes";
-      })(JsxNames || (JsxNames = {}));
-      SymbolTrackerImpl = class {
-        constructor(context, tracker, moduleResolverHost) {
-          this.moduleResolverHost = void 0;
-          this.inner = void 0;
-          this.disableTrackSymbol = false;
-          var _a;
-          while (tracker instanceof SymbolTrackerImpl) {
-            tracker = tracker.inner;
-          }
-          this.inner = tracker;
-          this.moduleResolverHost = moduleResolverHost;
-          this.context = context;
-          this.canTrackSymbol = !!((_a = this.inner) == null ? void 0 : _a.trackSymbol);
-        }
-        trackSymbol(symbol, enclosingDeclaration, meaning) {
-          var _a;
-          if (((_a = this.inner) == null ? void 0 : _a.trackSymbol) && !this.disableTrackSymbol) {
-            if (this.inner.trackSymbol(symbol, enclosingDeclaration, meaning)) {
-              this.onDiagnosticReported();
-              return true;
-            }
-          }
-          return false;
-        }
-        reportInaccessibleThisError() {
-          var _a;
-          if ((_a = this.inner) == null ? void 0 : _a.reportInaccessibleThisError) {
-            this.onDiagnosticReported();
-            this.inner.reportInaccessibleThisError();
-          }
-        }
-        reportPrivateInBaseOfClassExpression(propertyName) {
-          var _a;
-          if ((_a = this.inner) == null ? void 0 : _a.reportPrivateInBaseOfClassExpression) {
-            this.onDiagnosticReported();
-            this.inner.reportPrivateInBaseOfClassExpression(propertyName);
-          }
-        }
-        reportInaccessibleUniqueSymbolError() {
-          var _a;
-          if ((_a = this.inner) == null ? void 0 : _a.reportInaccessibleUniqueSymbolError) {
-            this.onDiagnosticReported();
-            this.inner.reportInaccessibleUniqueSymbolError();
-          }
-        }
-        reportCyclicStructureError() {
-          var _a;
-          if ((_a = this.inner) == null ? void 0 : _a.reportCyclicStructureError) {
-            this.onDiagnosticReported();
-            this.inner.reportCyclicStructureError();
-          }
-        }
-        reportLikelyUnsafeImportRequiredError(specifier) {
-          var _a;
-          if ((_a = this.inner) == null ? void 0 : _a.reportLikelyUnsafeImportRequiredError) {
-            this.onDiagnosticReported();
-            this.inner.reportLikelyUnsafeImportRequiredError(specifier);
-          }
-        }
-        reportTruncationError() {
-          var _a;
-          if ((_a = this.inner) == null ? void 0 : _a.reportTruncationError) {
-            this.onDiagnosticReported();
-            this.inner.reportTruncationError();
-          }
-        }
-        trackReferencedAmbientModule(decl, symbol) {
-          var _a;
-          if ((_a = this.inner) == null ? void 0 : _a.trackReferencedAmbientModule) {
-            this.onDiagnosticReported();
-            this.inner.trackReferencedAmbientModule(decl, symbol);
-          }
-        }
-        trackExternalModuleSymbolOfImportTypeNode(symbol) {
-          var _a;
-          if ((_a = this.inner) == null ? void 0 : _a.trackExternalModuleSymbolOfImportTypeNode) {
-            this.onDiagnosticReported();
-            this.inner.trackExternalModuleSymbolOfImportTypeNode(symbol);
-          }
-        }
-        reportNonlocalAugmentation(containingFile, parentSymbol, augmentingSymbol) {
-          var _a;
-          if ((_a = this.inner) == null ? void 0 : _a.reportNonlocalAugmentation) {
-            this.onDiagnosticReported();
-            this.inner.reportNonlocalAugmentation(containingFile, parentSymbol, augmentingSymbol);
-          }
-        }
-        reportNonSerializableProperty(propertyName) {
-          var _a;
-          if ((_a = this.inner) == null ? void 0 : _a.reportNonSerializableProperty) {
-            this.onDiagnosticReported();
-            this.inner.reportNonSerializableProperty(propertyName);
-          }
-        }
-        reportImportTypeNodeResolutionModeOverride() {
-          var _a;
-          if ((_a = this.inner) == null ? void 0 : _a.reportImportTypeNodeResolutionModeOverride) {
-            this.onDiagnosticReported();
-            this.inner.reportImportTypeNodeResolutionModeOverride();
-          }
-        }
-        onDiagnosticReported() {
-          this.context.reportedDiagnostic = true;
-        }
-      };
-    }
-  });
-
-  // src/compiler/visitorPublic.ts
-  function visitNode(node, visitor, test, lift) {
-    if (node === void 0) {
-      return node;
-    }
-    const visited = visitor(node);
-    let visitedNode;
-    if (visited === void 0) {
-      return void 0;
-    } else if (isArray(visited)) {
-      visitedNode = (lift || extractSingleNode)(visited);
-    } else {
-      visitedNode = visited;
-    }
-    Debug.assertNode(visitedNode, test);
-    return visitedNode;
-  }
-  function visitNodes2(nodes, visitor, test, start, count) {
-    if (nodes === void 0) {
-      return nodes;
-    }
-    const length2 = nodes.length;
-    if (start === void 0 || start < 0) {
-      start = 0;
-    }
-    if (count === void 0 || count > length2 - start) {
-      count = length2 - start;
-    }
-    let hasTrailingComma;
-    let pos = -1;
-    let end = -1;
-    if (start > 0 || count < length2) {
-      hasTrailingComma = nodes.hasTrailingComma && start + count === length2;
-    } else {
-      pos = nodes.pos;
-      end = nodes.end;
-      hasTrailingComma = nodes.hasTrailingComma;
-    }
-    const updated = visitArrayWorker(nodes, visitor, test, start, count);
-    if (updated !== nodes) {
-      const updatedArray = factory.createNodeArray(updated, hasTrailingComma);
-      setTextRangePosEnd(updatedArray, pos, end);
-      return updatedArray;
-    }
-    return nodes;
-  }
-  function visitArray(nodes, visitor, test, start, count) {
-    if (nodes === void 0) {
-      return nodes;
-    }
-    const length2 = nodes.length;
-    if (start === void 0 || start < 0) {
-      start = 0;
-    }
-    if (count === void 0 || count > length2 - start) {
-      count = length2 - start;
-    }
-    return visitArrayWorker(nodes, visitor, test, start, count);
-  }
-  function visitArrayWorker(nodes, visitor, test, start, count) {
-    let updated;
-    const length2 = nodes.length;
-    if (start > 0 || count < length2) {
-      updated = [];
-    }
-    for (let i = 0; i < count; i++) {
-      const node = nodes[i + start];
-      const visited = node !== void 0 ? visitor ? visitor(node) : node : void 0;
-      if (updated !== void 0 || visited === void 0 || visited !== node) {
-        if (updated === void 0) {
-          updated = nodes.slice(0, i);
-          Debug.assertEachNode(updated, test);
-        }
-        if (visited) {
-          if (isArray(visited)) {
-            for (const visitedNode of visited) {
-              Debug.assertNode(visitedNode, test);
-              updated.push(visitedNode);
-            }
-          } else {
-            Debug.assertNode(visited, test);
-            updated.push(visited);
-          }
-        }
-      }
-    }
-    if (updated) {
-      return updated;
-    }
-    Debug.assertEachNode(nodes, test);
-    return nodes;
-  }
-  function visitLexicalEnvironment(statements, visitor, context, start, ensureUseStrict, nodesVisitor = visitNodes2) {
-    context.startLexicalEnvironment();
-    statements = nodesVisitor(statements, visitor, isStatement, start);
-    if (ensureUseStrict)
-      statements = context.factory.ensureUseStrict(statements);
-    return factory.mergeLexicalEnvironment(statements, context.endLexicalEnvironment());
-  }
-  function visitParameterList(nodes, visitor, context, nodesVisitor = visitNodes2) {
-    let updated;
-    context.startLexicalEnvironment();
-    if (nodes) {
-      context.setLexicalEnvironmentFlags(1 /* InParameters */, true);
-      updated = nodesVisitor(nodes, visitor, isParameter);
-      if (context.getLexicalEnvironmentFlags() & 2 /* VariablesHoistedInParameters */ && getEmitScriptTarget(context.getCompilerOptions()) >= 2 /* ES2015 */) {
-        updated = addDefaultValueAssignmentsIfNeeded(updated, context);
-      }
-      context.setLexicalEnvironmentFlags(1 /* InParameters */, false);
-    }
-    context.suspendLexicalEnvironment();
-    return updated;
-  }
-  function addDefaultValueAssignmentsIfNeeded(parameters, context) {
-    let result;
-    for (let i = 0; i < parameters.length; i++) {
-      const parameter = parameters[i];
-      const updated = addDefaultValueAssignmentIfNeeded(parameter, context);
-      if (result || updated !== parameter) {
-        if (!result)
-          result = parameters.slice(0, i);
-        result[i] = updated;
-      }
-    }
-    if (result) {
-      return setTextRange(context.factory.createNodeArray(result, parameters.hasTrailingComma), parameters);
-    }
-    return parameters;
-  }
-  function addDefaultValueAssignmentIfNeeded(parameter, context) {
-    return parameter.dotDotDotToken ? parameter : isBindingPattern(parameter.name) ? addDefaultValueAssignmentForBindingPattern(parameter, context) : parameter.initializer ? addDefaultValueAssignmentForInitializer(parameter, parameter.name, parameter.initializer, context) : parameter;
-  }
-  function addDefaultValueAssignmentForBindingPattern(parameter, context) {
-    const { factory: factory2 } = context;
-    context.addInitializationStatement(
-      factory2.createVariableStatement(
-        /*modifiers*/
-        void 0,
-        factory2.createVariableDeclarationList([
-          factory2.createVariableDeclaration(
-            parameter.name,
-            /*exclamationToken*/
-            void 0,
-            parameter.type,
-            parameter.initializer ? factory2.createConditionalExpression(
-              factory2.createStrictEquality(
-                factory2.getGeneratedNameForNode(parameter),
-                factory2.createVoidZero()
-              ),
-              /*questionToken*/
-              void 0,
-              parameter.initializer,
-              /*colonToken*/
-              void 0,
-              factory2.getGeneratedNameForNode(parameter)
-            ) : factory2.getGeneratedNameForNode(parameter)
-          )
-        ])
-      )
-    );
-    return factory2.updateParameterDeclaration(
-      parameter,
-      parameter.modifiers,
-      parameter.dotDotDotToken,
-      factory2.getGeneratedNameForNode(parameter),
-      parameter.questionToken,
-      parameter.type,
-      /*initializer*/
-      void 0
-    );
-  }
-  function addDefaultValueAssignmentForInitializer(parameter, name, initializer, context) {
-    const factory2 = context.factory;
-    context.addInitializationStatement(
-      factory2.createIfStatement(
-        factory2.createTypeCheck(factory2.cloneNode(name), "undefined"),
-        setEmitFlags(
-          setTextRange(
-            factory2.createBlock([
-              factory2.createExpressionStatement(
-                setEmitFlags(
-                  setTextRange(
-                    factory2.createAssignment(
-                      setEmitFlags(factory2.cloneNode(name), 96 /* NoSourceMap */),
-                      setEmitFlags(initializer, 96 /* NoSourceMap */ | getEmitFlags(initializer) | 3072 /* NoComments */)
-                    ),
-                    parameter
-                  ),
-                  3072 /* NoComments */
-                )
-              )
-            ]),
-            parameter
-          ),
-          1 /* SingleLine */ | 64 /* NoTrailingSourceMap */ | 768 /* NoTokenSourceMaps */ | 3072 /* NoComments */
-        )
-      )
-    );
-    return factory2.updateParameterDeclaration(
-      parameter,
-      parameter.modifiers,
-      parameter.dotDotDotToken,
-      parameter.name,
-      parameter.questionToken,
-      parameter.type,
-      /*initializer*/
-      void 0
-    );
-  }
-  function visitFunctionBody(node, visitor, context, nodeVisitor = visitNode) {
-    context.resumeLexicalEnvironment();
-    const updated = nodeVisitor(node, visitor, isConciseBody);
-    const declarations = context.endLexicalEnvironment();
-    if (some(declarations)) {
-      if (!updated) {
-        return context.factory.createBlock(declarations);
-      }
-      const block = context.factory.converters.convertToFunctionBlock(updated);
-      const statements = factory.mergeLexicalEnvironment(block.statements, declarations);
-      return context.factory.updateBlock(block, statements);
-    }
-    return updated;
-  }
-  function visitIterationBody(body, visitor, context, nodeVisitor = visitNode) {
-    context.startBlockScope();
-    const updated = nodeVisitor(body, visitor, isStatement, context.factory.liftToBlock);
-    Debug.assert(updated);
-    const declarations = context.endBlockScope();
-    if (some(declarations)) {
-      if (isBlock(updated)) {
-        declarations.push(...updated.statements);
-        return context.factory.updateBlock(updated, declarations);
-      }
-      declarations.push(updated);
-      return context.factory.createBlock(declarations);
-    }
-    return updated;
-  }
-  function visitCommaListElements(elements, visitor, discardVisitor = visitor) {
-    if (discardVisitor === visitor || elements.length <= 1) {
-      return visitNodes2(elements, visitor, isExpression);
-    }
-    let i = 0;
-    const length2 = elements.length;
-    return visitNodes2(elements, (node) => {
-      const discarded = i < length2 - 1;
-      i++;
-      return discarded ? discardVisitor(node) : visitor(node);
-    }, isExpression);
-  }
-  function visitEachChild(node, visitor, context, nodesVisitor = visitNodes2, tokenVisitor, nodeVisitor = visitNode) {
-    if (node === void 0) {
-      return void 0;
-    }
-    const fn = visitEachChildTable[node.kind];
-    return fn === void 0 ? node : fn(node, visitor, context, nodesVisitor, nodeVisitor, tokenVisitor);
-  }
-  function extractSingleNode(nodes) {
-    Debug.assert(nodes.length <= 1, "Too many nodes written to output.");
-    return singleOrUndefined(nodes);
-  }
-  var visitEachChildTable;
-  var init_visitorPublic = __esm({
-    "src/compiler/visitorPublic.ts"() {
-      "use strict";
-      init_ts2();
-      visitEachChildTable = {
-        [165 /* QualifiedName */]: function visitEachChildOfQualifiedName(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
-          return context.factory.updateQualifiedName(
-            node,
-            Debug.checkDefined(nodeVisitor(node.left, visitor, isEntityName)),
-            Debug.checkDefined(nodeVisitor(node.right, visitor, isIdentifier))
-          );
-        },
-        [166 /* ComputedPropertyName */]: function visitEachChildOfComputedPropertyName(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
-          return context.factory.updateComputedPropertyName(
-            node,
-            Debug.checkDefined(nodeVisitor(node.expression, visitor, isExpression))
-          );
-        },
-        // Signature elements
-        [167 /* TypeParameter */]: function visitEachChildOfTypeParameterDeclaration(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) {
-          return context.factory.updateTypeParameterDeclaration(
-            node,
-            nodesVisitor(node.modifiers, visitor, isModifier),
-            Debug.checkDefined(nodeVisitor(node.name, visitor, isIdentifier)),
-            nodeVisitor(node.constraint, visitor, isTypeNode),
-            nodeVisitor(node.default, visitor, isTypeNode)
-          );
-        },
-        [168 /* Parameter */]: function visitEachChildOfParameterDeclaration(node, visitor, context, nodesVisitor, nodeVisitor, tokenVisitor) {
-          return context.factory.updateParameterDeclaration(
-            node,
-            nodesVisitor(node.modifiers, visitor, isModifierLike),
-            tokenVisitor ? nodeVisitor(node.dotDotDotToken, tokenVisitor, isDotDotDotToken) : node.dotDotDotToken,
-            Debug.checkDefined(nodeVisitor(node.name, visitor, isBindingName)),
-            tokenVisitor ? nodeVisitor(node.questionToken, tokenVisitor, isQuestionToken) : node.questionToken,
-            nodeVisitor(node.type, visitor, isTypeNode),
-            nodeVisitor(node.initializer, visitor, isExpression)
-          );
-        },
-        [169 /* Decorator */]: function visitEachChildOfDecorator(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
-          return context.factory.updateDecorator(
-            node,
-            Debug.checkDefined(nodeVisitor(node.expression, visitor, isExpression))
-          );
-        },
-        // Type elements
-        [170 /* PropertySignature */]: function visitEachChildOfPropertySignature(node, visitor, context, nodesVisitor, nodeVisitor, tokenVisitor) {
-          return context.factory.updatePropertySignature(
-            node,
-            nodesVisitor(node.modifiers, visitor, isModifier),
-            Debug.checkDefined(nodeVisitor(node.name, visitor, isPropertyName)),
-            tokenVisitor ? nodeVisitor(node.questionToken, tokenVisitor, isQuestionToken) : node.questionToken,
-            nodeVisitor(node.type, visitor, isTypeNode)
-          );
-        },
-        [171 /* PropertyDeclaration */]: function visitEachChildOfPropertyDeclaration(node, visitor, context, nodesVisitor, nodeVisitor, tokenVisitor) {
-          return context.factory.updatePropertyDeclaration(
-            node,
-            nodesVisitor(node.modifiers, visitor, isModifierLike),
-            Debug.checkDefined(nodeVisitor(node.name, visitor, isPropertyName)),
-            // QuestionToken and ExclamationToken are mutually exclusive in PropertyDeclaration
-            tokenVisitor ? nodeVisitor(node.questionToken ?? node.exclamationToken, tokenVisitor, isQuestionOrExclamationToken) : node.questionToken ?? node.exclamationToken,
-            nodeVisitor(node.type, visitor, isTypeNode),
-            nodeVisitor(node.initializer, visitor, isExpression)
-          );
-        },
-        [172 /* MethodSignature */]: function visitEachChildOfMethodSignature(node, visitor, context, nodesVisitor, nodeVisitor, tokenVisitor) {
-          return context.factory.updateMethodSignature(
-            node,
-            nodesVisitor(node.modifiers, visitor, isModifier),
-            Debug.checkDefined(nodeVisitor(node.name, visitor, isPropertyName)),
-            tokenVisitor ? nodeVisitor(node.questionToken, tokenVisitor, isQuestionToken) : node.questionToken,
-            nodesVisitor(node.typeParameters, visitor, isTypeParameterDeclaration),
-            nodesVisitor(node.parameters, visitor, isParameter),
-            nodeVisitor(node.type, visitor, isTypeNode)
-          );
-        },
-        [173 /* MethodDeclaration */]: function visitEachChildOfMethodDeclaration(node, visitor, context, nodesVisitor, nodeVisitor, tokenVisitor) {
-          return context.factory.updateMethodDeclaration(
-            node,
-            nodesVisitor(node.modifiers, visitor, isModifierLike),
-            tokenVisitor ? nodeVisitor(node.asteriskToken, tokenVisitor, isAsteriskToken) : node.asteriskToken,
-            Debug.checkDefined(nodeVisitor(node.name, visitor, isPropertyName)),
-            tokenVisitor ? nodeVisitor(node.questionToken, tokenVisitor, isQuestionToken) : node.questionToken,
-            nodesVisitor(node.typeParameters, visitor, isTypeParameterDeclaration),
-            visitParameterList(node.parameters, visitor, context, nodesVisitor),
-            nodeVisitor(node.type, visitor, isTypeNode),
-            visitFunctionBody(node.body, visitor, context, nodeVisitor)
-          );
-        },
-        [175 /* Constructor */]: function visitEachChildOfConstructorDeclaration(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) {
-          return context.factory.updateConstructorDeclaration(
-            node,
-            nodesVisitor(node.modifiers, visitor, isModifierLike),
-            visitParameterList(node.parameters, visitor, context, nodesVisitor),
-            visitFunctionBody(node.body, visitor, context, nodeVisitor)
-          );
-        },
-        [176 /* GetAccessor */]: function visitEachChildOfGetAccessorDeclaration(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) {
-          return context.factory.updateGetAccessorDeclaration(
-            node,
-            nodesVisitor(node.modifiers, visitor, isModifierLike),
-            Debug.checkDefined(nodeVisitor(node.name, visitor, isPropertyName)),
-            visitParameterList(node.parameters, visitor, context, nodesVisitor),
-            nodeVisitor(node.type, visitor, isTypeNode),
-            visitFunctionBody(node.body, visitor, context, nodeVisitor)
-          );
-        },
-        [177 /* SetAccessor */]: function visitEachChildOfSetAccessorDeclaration(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) {
-          return context.factory.updateSetAccessorDeclaration(
-            node,
-            nodesVisitor(node.modifiers, visitor, isModifierLike),
-            Debug.checkDefined(nodeVisitor(node.name, visitor, isPropertyName)),
-            visitParameterList(node.parameters, visitor, context, nodesVisitor),
-            visitFunctionBody(node.body, visitor, context, nodeVisitor)
-          );
-        },
-        [174 /* ClassStaticBlockDeclaration */]: function visitEachChildOfClassStaticBlockDeclaration(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
-          context.startLexicalEnvironment();
-          context.suspendLexicalEnvironment();
-          return context.factory.updateClassStaticBlockDeclaration(
-            node,
-            visitFunctionBody(node.body, visitor, context, nodeVisitor)
-          );
-        },
-        [178 /* CallSignature */]: function visitEachChildOfCallSignatureDeclaration(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) {
-          return context.factory.updateCallSignature(
-            node,
-            nodesVisitor(node.typeParameters, visitor, isTypeParameterDeclaration),
-            nodesVisitor(node.parameters, visitor, isParameter),
-            nodeVisitor(node.type, visitor, isTypeNode)
-          );
-        },
-        [179 /* ConstructSignature */]: function visitEachChildOfConstructSignatureDeclaration(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) {
-          return context.factory.updateConstructSignature(
-            node,
-            nodesVisitor(node.typeParameters, visitor, isTypeParameterDeclaration),
-            nodesVisitor(node.parameters, visitor, isParameter),
-            nodeVisitor(node.type, visitor, isTypeNode)
-          );
-        },
-        [180 /* IndexSignature */]: function visitEachChildOfIndexSignatureDeclaration(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) {
-          return context.factory.updateIndexSignature(
-            node,
-            nodesVisitor(node.modifiers, visitor, isModifierLike),
-            nodesVisitor(node.parameters, visitor, isParameter),
-            Debug.checkDefined(nodeVisitor(node.type, visitor, isTypeNode))
-          );
-        },
-        // Types
-        [181 /* TypePredicate */]: function visitEachChildOfTypePredicateNode(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
-          return context.factory.updateTypePredicateNode(
-            node,
-            nodeVisitor(node.assertsModifier, visitor, isAssertsKeyword),
-            Debug.checkDefined(nodeVisitor(node.parameterName, visitor, isIdentifierOrThisTypeNode)),
-            nodeVisitor(node.type, visitor, isTypeNode)
-          );
-        },
-        [182 /* TypeReference */]: function visitEachChildOfTypeReferenceNode(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) {
-          return context.factory.updateTypeReferenceNode(
-            node,
-            Debug.checkDefined(nodeVisitor(node.typeName, visitor, isEntityName)),
-            nodesVisitor(node.typeArguments, visitor, isTypeNode)
-          );
-        },
-        [183 /* FunctionType */]: function visitEachChildOfFunctionTypeNode(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) {
-          return context.factory.updateFunctionTypeNode(
-            node,
-            nodesVisitor(node.typeParameters, visitor, isTypeParameterDeclaration),
-            nodesVisitor(node.parameters, visitor, isParameter),
-            Debug.checkDefined(nodeVisitor(node.type, visitor, isTypeNode))
-          );
-        },
-        [184 /* ConstructorType */]: function visitEachChildOfConstructorTypeNode(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) {
-          return context.factory.updateConstructorTypeNode(
-            node,
-            nodesVisitor(node.modifiers, visitor, isModifier),
-            nodesVisitor(node.typeParameters, visitor, isTypeParameterDeclaration),
-            nodesVisitor(node.parameters, visitor, isParameter),
-            Debug.checkDefined(nodeVisitor(node.type, visitor, isTypeNode))
-          );
-        },
-        [185 /* TypeQuery */]: function visitEachChildOfTypeQueryNode(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) {
-          return context.factory.updateTypeQueryNode(
-            node,
-            Debug.checkDefined(nodeVisitor(node.exprName, visitor, isEntityName)),
-            nodesVisitor(node.typeArguments, visitor, isTypeNode)
-          );
-        },
-        [186 /* TypeLiteral */]: function visitEachChildOfTypeLiteralNode(node, visitor, context, nodesVisitor, _nodeVisitor, _tokenVisitor) {
-          return context.factory.updateTypeLiteralNode(
-            node,
-            nodesVisitor(node.members, visitor, isTypeElement)
-          );
-        },
-        [187 /* ArrayType */]: function visitEachChildOfArrayTypeNode(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
-          return context.factory.updateArrayTypeNode(
-            node,
-            Debug.checkDefined(nodeVisitor(node.elementType, visitor, isTypeNode))
-          );
-        },
-        [188 /* TupleType */]: function visitEachChildOfTupleTypeNode(node, visitor, context, nodesVisitor, _nodeVisitor, _tokenVisitor) {
-          return context.factory.updateTupleTypeNode(
-            node,
-            nodesVisitor(node.elements, visitor, isTypeNode)
-          );
-        },
-        [189 /* OptionalType */]: function visitEachChildOfOptionalTypeNode(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
-          return context.factory.updateOptionalTypeNode(
-            node,
-            Debug.checkDefined(nodeVisitor(node.type, visitor, isTypeNode))
-          );
-        },
-        [190 /* RestType */]: function visitEachChildOfRestTypeNode(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
-          return context.factory.updateRestTypeNode(
-            node,
-            Debug.checkDefined(nodeVisitor(node.type, visitor, isTypeNode))
-          );
-        },
-        [191 /* UnionType */]: function visitEachChildOfUnionTypeNode(node, visitor, context, nodesVisitor, _nodeVisitor, _tokenVisitor) {
-          return context.factory.updateUnionTypeNode(
-            node,
-            nodesVisitor(node.types, visitor, isTypeNode)
-          );
-        },
-        [192 /* IntersectionType */]: function visitEachChildOfIntersectionTypeNode(node, visitor, context, nodesVisitor, _nodeVisitor, _tokenVisitor) {
-          return context.factory.updateIntersectionTypeNode(
-            node,
-            nodesVisitor(node.types, visitor, isTypeNode)
-          );
-        },
-        [193 /* ConditionalType */]: function visitEachChildOfConditionalTypeNode(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
-          return context.factory.updateConditionalTypeNode(
-            node,
-            Debug.checkDefined(nodeVisitor(node.checkType, visitor, isTypeNode)),
-            Debug.checkDefined(nodeVisitor(node.extendsType, visitor, isTypeNode)),
-            Debug.checkDefined(nodeVisitor(node.trueType, visitor, isTypeNode)),
-            Debug.checkDefined(nodeVisitor(node.falseType, visitor, isTypeNode))
-          );
-        },
-        [194 /* InferType */]: function visitEachChildOfInferTypeNode(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
-          return context.factory.updateInferTypeNode(
-            node,
-            Debug.checkDefined(nodeVisitor(node.typeParameter, visitor, isTypeParameterDeclaration))
-          );
-        },
-        [204 /* ImportType */]: function visitEachChildOfImportTypeNode(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) {
-          return context.factory.updateImportTypeNode(
-            node,
-            Debug.checkDefined(nodeVisitor(node.argument, visitor, isTypeNode)),
-            nodeVisitor(node.assertions, visitor, isImportTypeAssertionContainer),
-            nodeVisitor(node.qualifier, visitor, isEntityName),
-            nodesVisitor(node.typeArguments, visitor, isTypeNode),
-            node.isTypeOf
-          );
-        },
-        [301 /* ImportTypeAssertionContainer */]: function visitEachChildOfImportTypeAssertionContainer(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
-          return context.factory.updateImportTypeAssertionContainer(
-            node,
-            Debug.checkDefined(nodeVisitor(node.assertClause, visitor, isAssertClause)),
-            node.multiLine
-          );
-        },
-        [201 /* NamedTupleMember */]: function visitEachChildOfNamedTupleMember(node, visitor, context, _nodesVisitor, nodeVisitor, tokenVisitor) {
-          return context.factory.updateNamedTupleMember(
-            node,
-            tokenVisitor ? nodeVisitor(node.dotDotDotToken, tokenVisitor, isDotDotDotToken) : node.dotDotDotToken,
-            Debug.checkDefined(nodeVisitor(node.name, visitor, isIdentifier)),
-            tokenVisitor ? nodeVisitor(node.questionToken, tokenVisitor, isQuestionToken) : node.questionToken,
-            Debug.checkDefined(nodeVisitor(node.type, visitor, isTypeNode))
-          );
-        },
-        [195 /* ParenthesizedType */]: function visitEachChildOfParenthesizedType(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
-          return context.factory.updateParenthesizedType(
-            node,
-            Debug.checkDefined(nodeVisitor(node.type, visitor, isTypeNode))
-          );
-        },
-        [197 /* TypeOperator */]: function visitEachChildOfTypeOperatorNode(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
-          return context.factory.updateTypeOperatorNode(
-            node,
-            Debug.checkDefined(nodeVisitor(node.type, visitor, isTypeNode))
-          );
-        },
-        [198 /* IndexedAccessType */]: function visitEachChildOfIndexedAccessType(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
-          return context.factory.updateIndexedAccessTypeNode(
-            node,
-            Debug.checkDefined(nodeVisitor(node.objectType, visitor, isTypeNode)),
-            Debug.checkDefined(nodeVisitor(node.indexType, visitor, isTypeNode))
-          );
-        },
-        [199 /* MappedType */]: function visitEachChildOfMappedType(node, visitor, context, nodesVisitor, nodeVisitor, tokenVisitor) {
-          return context.factory.updateMappedTypeNode(
-            node,
-            tokenVisitor ? nodeVisitor(node.readonlyToken, tokenVisitor, isReadonlyKeywordOrPlusOrMinusToken) : node.readonlyToken,
-            Debug.checkDefined(nodeVisitor(node.typeParameter, visitor, isTypeParameterDeclaration)),
-            nodeVisitor(node.nameType, visitor, isTypeNode),
-            tokenVisitor ? nodeVisitor(node.questionToken, tokenVisitor, isQuestionOrPlusOrMinusToken) : node.questionToken,
-            nodeVisitor(node.type, visitor, isTypeNode),
-            nodesVisitor(node.members, visitor, isTypeElement)
-          );
-        },
-        [200 /* LiteralType */]: function visitEachChildOfLiteralTypeNode(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
-          return context.factory.updateLiteralTypeNode(
-            node,
-            Debug.checkDefined(nodeVisitor(node.literal, visitor, isLiteralTypeLiteral))
-          );
-        },
-        [202 /* TemplateLiteralType */]: function visitEachChildOfTemplateLiteralType(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) {
-          return context.factory.updateTemplateLiteralType(
-            node,
-            Debug.checkDefined(nodeVisitor(node.head, visitor, isTemplateHead)),
-            nodesVisitor(node.templateSpans, visitor, isTemplateLiteralTypeSpan)
-          );
-        },
-        [203 /* TemplateLiteralTypeSpan */]: function visitEachChildOfTemplateLiteralTypeSpan(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
-          return context.factory.updateTemplateLiteralTypeSpan(
-            node,
-            Debug.checkDefined(nodeVisitor(node.type, visitor, isTypeNode)),
-            Debug.checkDefined(nodeVisitor(node.literal, visitor, isTemplateMiddleOrTemplateTail))
-          );
-        },
-        // Binding patterns
-        [205 /* ObjectBindingPattern */]: function visitEachChildOfObjectBindingPattern(node, visitor, context, nodesVisitor, _nodeVisitor, _tokenVisitor) {
-          return context.factory.updateObjectBindingPattern(
-            node,
-            nodesVisitor(node.elements, visitor, isBindingElement)
-          );
-        },
-        [206 /* ArrayBindingPattern */]: function visitEachChildOfArrayBindingPattern(node, visitor, context, nodesVisitor, _nodeVisitor, _tokenVisitor) {
-          return context.factory.updateArrayBindingPattern(
-            node,
-            nodesVisitor(node.elements, visitor, isArrayBindingElement)
-          );
-        },
-        [207 /* BindingElement */]: function visitEachChildOfBindingElement(node, visitor, context, _nodesVisitor, nodeVisitor, tokenVisitor) {
-          return context.factory.updateBindingElement(
-            node,
-            tokenVisitor ? nodeVisitor(node.dotDotDotToken, tokenVisitor, isDotDotDotToken) : node.dotDotDotToken,
-            nodeVisitor(node.propertyName, visitor, isPropertyName),
-            Debug.checkDefined(nodeVisitor(node.name, visitor, isBindingName)),
-            nodeVisitor(node.initializer, visitor, isExpression)
-          );
-        },
-        // Expression
-        [208 /* ArrayLiteralExpression */]: function visitEachChildOfArrayLiteralExpression(node, visitor, context, nodesVisitor, _nodeVisitor, _tokenVisitor) {
-          return context.factory.updateArrayLiteralExpression(
-            node,
-            nodesVisitor(node.elements, visitor, isExpression)
-          );
-        },
-        [209 /* ObjectLiteralExpression */]: function visitEachChildOfObjectLiteralExpression(node, visitor, context, nodesVisitor, _nodeVisitor, _tokenVisitor) {
-          return context.factory.updateObjectLiteralExpression(
-            node,
-            nodesVisitor(node.properties, visitor, isObjectLiteralElementLike)
-          );
-        },
-        [210 /* PropertyAccessExpression */]: function visitEachChildOfPropertyAccessExpression(node, visitor, context, _nodesVisitor, nodeVisitor, tokenVisitor) {
-          return isPropertyAccessChain(node) ? context.factory.updatePropertyAccessChain(
-            node,
-            Debug.checkDefined(nodeVisitor(node.expression, visitor, isExpression)),
-            tokenVisitor ? nodeVisitor(node.questionDotToken, tokenVisitor, isQuestionDotToken) : node.questionDotToken,
-            Debug.checkDefined(nodeVisitor(node.name, visitor, isMemberName))
-          ) : context.factory.updatePropertyAccessExpression(
-            node,
-            Debug.checkDefined(nodeVisitor(node.expression, visitor, isExpression)),
-            Debug.checkDefined(nodeVisitor(node.name, visitor, isMemberName))
-          );
-        },
-        [211 /* ElementAccessExpression */]: function visitEachChildOfElementAccessExpression(node, visitor, context, _nodesVisitor, nodeVisitor, tokenVisitor) {
-          return isElementAccessChain(node) ? context.factory.updateElementAccessChain(
-            node,
-            Debug.checkDefined(nodeVisitor(node.expression, visitor, isExpression)),
-            tokenVisitor ? nodeVisitor(node.questionDotToken, tokenVisitor, isQuestionDotToken) : node.questionDotToken,
-            Debug.checkDefined(nodeVisitor(node.argumentExpression, visitor, isExpression))
-          ) : context.factory.updateElementAccessExpression(
-            node,
-            Debug.checkDefined(nodeVisitor(node.expression, visitor, isExpression)),
-            Debug.checkDefined(nodeVisitor(node.argumentExpression, visitor, isExpression))
-          );
-        },
-        [212 /* CallExpression */]: function visitEachChildOfCallExpression(node, visitor, context, nodesVisitor, nodeVisitor, tokenVisitor) {
-          return isCallChain(node) ? context.factory.updateCallChain(
-            node,
-            Debug.checkDefined(nodeVisitor(node.expression, visitor, isExpression)),
-            tokenVisitor ? nodeVisitor(node.questionDotToken, tokenVisitor, isQuestionDotToken) : node.questionDotToken,
-            nodesVisitor(node.typeArguments, visitor, isTypeNode),
-            nodesVisitor(node.arguments, visitor, isExpression)
-          ) : context.factory.updateCallExpression(
-            node,
-            Debug.checkDefined(nodeVisitor(node.expression, visitor, isExpression)),
-            nodesVisitor(node.typeArguments, visitor, isTypeNode),
-            nodesVisitor(node.arguments, visitor, isExpression)
-          );
-        },
-        [213 /* NewExpression */]: function visitEachChildOfNewExpression(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) {
-          return context.factory.updateNewExpression(
-            node,
-            Debug.checkDefined(nodeVisitor(node.expression, visitor, isExpression)),
-            nodesVisitor(node.typeArguments, visitor, isTypeNode),
-            nodesVisitor(node.arguments, visitor, isExpression)
-          );
-        },
-        [214 /* TaggedTemplateExpression */]: function visitEachChildOfTaggedTemplateExpression(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) {
-          return context.factory.updateTaggedTemplateExpression(
-            node,
-            Debug.checkDefined(nodeVisitor(node.tag, visitor, isExpression)),
-            nodesVisitor(node.typeArguments, visitor, isTypeNode),
-            Debug.checkDefined(nodeVisitor(node.template, visitor, isTemplateLiteral))
-          );
-        },
-        [215 /* TypeAssertionExpression */]: function visitEachChildOfTypeAssertionExpression(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
-          return context.factory.updateTypeAssertion(
-            node,
-            Debug.checkDefined(nodeVisitor(node.type, visitor, isTypeNode)),
-            Debug.checkDefined(nodeVisitor(node.expression, visitor, isExpression))
-          );
-        },
-        [216 /* ParenthesizedExpression */]: function visitEachChildOfParenthesizedExpression(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
-          return context.factory.updateParenthesizedExpression(
-            node,
-            Debug.checkDefined(nodeVisitor(node.expression, visitor, isExpression))
-          );
-        },
-        [217 /* FunctionExpression */]: function visitEachChildOfFunctionExpression(node, visitor, context, nodesVisitor, nodeVisitor, tokenVisitor) {
-          return context.factory.updateFunctionExpression(
-            node,
-            nodesVisitor(node.modifiers, visitor, isModifier),
-            tokenVisitor ? nodeVisitor(node.asteriskToken, tokenVisitor, isAsteriskToken) : node.asteriskToken,
-            nodeVisitor(node.name, visitor, isIdentifier),
-            nodesVisitor(node.typeParameters, visitor, isTypeParameterDeclaration),
-            visitParameterList(node.parameters, visitor, context, nodesVisitor),
-            nodeVisitor(node.type, visitor, isTypeNode),
-            visitFunctionBody(node.body, visitor, context, nodeVisitor)
-          );
-        },
-        [218 /* ArrowFunction */]: function visitEachChildOfArrowFunction(node, visitor, context, nodesVisitor, nodeVisitor, tokenVisitor) {
-          return context.factory.updateArrowFunction(
-            node,
-            nodesVisitor(node.modifiers, visitor, isModifier),
-            nodesVisitor(node.typeParameters, visitor, isTypeParameterDeclaration),
-            visitParameterList(node.parameters, visitor, context, nodesVisitor),
-            nodeVisitor(node.type, visitor, isTypeNode),
-            tokenVisitor ? Debug.checkDefined(nodeVisitor(node.equalsGreaterThanToken, tokenVisitor, isEqualsGreaterThanToken)) : node.equalsGreaterThanToken,
-            visitFunctionBody(node.body, visitor, context, nodeVisitor)
-          );
-        },
-        [219 /* DeleteExpression */]: function visitEachChildOfDeleteExpression(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
-          return context.factory.updateDeleteExpression(
-            node,
-            Debug.checkDefined(nodeVisitor(node.expression, visitor, isExpression))
-          );
-        },
-        [220 /* TypeOfExpression */]: function visitEachChildOfTypeOfExpression(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
-          return context.factory.updateTypeOfExpression(
-            node,
-            Debug.checkDefined(nodeVisitor(node.expression, visitor, isExpression))
-          );
-        },
-        [221 /* VoidExpression */]: function visitEachChildOfVoidExpression(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
-          return context.factory.updateVoidExpression(
-            node,
-            Debug.checkDefined(nodeVisitor(node.expression, visitor, isExpression))
-          );
-        },
-        [222 /* AwaitExpression */]: function visitEachChildOfAwaitExpression(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
-          return context.factory.updateAwaitExpression(
-            node,
-            Debug.checkDefined(nodeVisitor(node.expression, visitor, isExpression))
-          );
-        },
-        [223 /* PrefixUnaryExpression */]: function visitEachChildOfPrefixUnaryExpression(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
-          return context.factory.updatePrefixUnaryExpression(
-            node,
-            Debug.checkDefined(nodeVisitor(node.operand, visitor, isExpression))
-          );
-        },
-        [224 /* PostfixUnaryExpression */]: function visitEachChildOfPostfixUnaryExpression(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
-          return context.factory.updatePostfixUnaryExpression(
-            node,
-            Debug.checkDefined(nodeVisitor(node.operand, visitor, isExpression))
-          );
-        },
-        [225 /* BinaryExpression */]: function visitEachChildOfBinaryExpression(node, visitor, context, _nodesVisitor, nodeVisitor, tokenVisitor) {
-          return context.factory.updateBinaryExpression(
-            node,
-            Debug.checkDefined(nodeVisitor(node.left, visitor, isExpression)),
-            tokenVisitor ? Debug.checkDefined(nodeVisitor(node.operatorToken, tokenVisitor, isBinaryOperatorToken)) : node.operatorToken,
-            Debug.checkDefined(nodeVisitor(node.right, visitor, isExpression))
-          );
-        },
-        [226 /* ConditionalExpression */]: function visitEachChildOfConditionalExpression(node, visitor, context, _nodesVisitor, nodeVisitor, tokenVisitor) {
-          return context.factory.updateConditionalExpression(
-            node,
-            Debug.checkDefined(nodeVisitor(node.condition, visitor, isExpression)),
-            tokenVisitor ? Debug.checkDefined(nodeVisitor(node.questionToken, tokenVisitor, isQuestionToken)) : node.questionToken,
-            Debug.checkDefined(nodeVisitor(node.whenTrue, visitor, isExpression)),
-            tokenVisitor ? Debug.checkDefined(nodeVisitor(node.colonToken, tokenVisitor, isColonToken)) : node.colonToken,
-            Debug.checkDefined(nodeVisitor(node.whenFalse, visitor, isExpression))
-          );
-        },
-        [227 /* TemplateExpression */]: function visitEachChildOfTemplateExpression(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) {
-          return context.factory.updateTemplateExpression(
-            node,
-            Debug.checkDefined(nodeVisitor(node.head, visitor, isTemplateHead)),
-            nodesVisitor(node.templateSpans, visitor, isTemplateSpan)
-          );
-        },
-        [228 /* YieldExpression */]: function visitEachChildOfYieldExpression(node, visitor, context, _nodesVisitor, nodeVisitor, tokenVisitor) {
-          return context.factory.updateYieldExpression(
-            node,
-            tokenVisitor ? nodeVisitor(node.asteriskToken, tokenVisitor, isAsteriskToken) : node.asteriskToken,
-            nodeVisitor(node.expression, visitor, isExpression)
-          );
-        },
-        [229 /* SpreadElement */]: function visitEachChildOfSpreadElement(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
-          return context.factory.updateSpreadElement(
-            node,
-            Debug.checkDefined(nodeVisitor(node.expression, visitor, isExpression))
-          );
-        },
-        [230 /* ClassExpression */]: function visitEachChildOfClassExpression(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) {
-          return context.factory.updateClassExpression(
-            node,
-            nodesVisitor(node.modifiers, visitor, isModifierLike),
-            nodeVisitor(node.name, visitor, isIdentifier),
-            nodesVisitor(node.typeParameters, visitor, isTypeParameterDeclaration),
-            nodesVisitor(node.heritageClauses, visitor, isHeritageClause),
-            nodesVisitor(node.members, visitor, isClassElement)
-          );
-        },
-        [232 /* ExpressionWithTypeArguments */]: function visitEachChildOfExpressionWithTypeArguments(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) {
-          return context.factory.updateExpressionWithTypeArguments(
-            node,
-            Debug.checkDefined(nodeVisitor(node.expression, visitor, isExpression)),
-            nodesVisitor(node.typeArguments, visitor, isTypeNode)
-          );
-        },
-        [233 /* AsExpression */]: function visitEachChildOfAsExpression(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
-          return context.factory.updateAsExpression(
-            node,
-            Debug.checkDefined(nodeVisitor(node.expression, visitor, isExpression)),
-            Debug.checkDefined(nodeVisitor(node.type, visitor, isTypeNode))
-          );
-        },
-        [237 /* SatisfiesExpression */]: function visitEachChildOfSatisfiesExpression(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
-          return context.factory.updateSatisfiesExpression(
-            node,
-            Debug.checkDefined(nodeVisitor(node.expression, visitor, isExpression)),
-            Debug.checkDefined(nodeVisitor(node.type, visitor, isTypeNode))
-          );
-        },
-        [234 /* NonNullExpression */]: function visitEachChildOfNonNullExpression(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
-          return isOptionalChain(node) ? context.factory.updateNonNullChain(
-            node,
-            Debug.checkDefined(nodeVisitor(node.expression, visitor, isExpression))
-          ) : context.factory.updateNonNullExpression(
-            node,
-            Debug.checkDefined(nodeVisitor(node.expression, visitor, isExpression))
-          );
-        },
-        [235 /* MetaProperty */]: function visitEachChildOfMetaProperty(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
-          return context.factory.updateMetaProperty(
-            node,
-            Debug.checkDefined(nodeVisitor(node.name, visitor, isIdentifier))
-          );
-        },
-        // Misc
-        [238 /* TemplateSpan */]: function visitEachChildOfTemplateSpan(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
-          return context.factory.updateTemplateSpan(
-            node,
-            Debug.checkDefined(nodeVisitor(node.expression, visitor, isExpression)),
-            Debug.checkDefined(nodeVisitor(node.literal, visitor, isTemplateMiddleOrTemplateTail))
-          );
-        },
-        // Element
-        [240 /* Block */]: function visitEachChildOfBlock(node, visitor, context, nodesVisitor, _nodeVisitor, _tokenVisitor) {
-          return context.factory.updateBlock(
-            node,
-            nodesVisitor(node.statements, visitor, isStatement)
-          );
-        },
-        [242 /* VariableStatement */]: function visitEachChildOfVariableStatement(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) {
-          return context.factory.updateVariableStatement(
-            node,
-            nodesVisitor(node.modifiers, visitor, isModifierLike),
-            Debug.checkDefined(nodeVisitor(node.declarationList, visitor, isVariableDeclarationList))
-          );
-        },
-        [243 /* ExpressionStatement */]: function visitEachChildOfExpressionStatement(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
-          return context.factory.updateExpressionStatement(
-            node,
-            Debug.checkDefined(nodeVisitor(node.expression, visitor, isExpression))
-          );
-        },
-        [244 /* IfStatement */]: function visitEachChildOfIfStatement(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
-          return context.factory.updateIfStatement(
-            node,
-            Debug.checkDefined(nodeVisitor(node.expression, visitor, isExpression)),
-            Debug.checkDefined(nodeVisitor(node.thenStatement, visitor, isStatement, context.factory.liftToBlock)),
-            nodeVisitor(node.elseStatement, visitor, isStatement, context.factory.liftToBlock)
-          );
-        },
-        [245 /* DoStatement */]: function visitEachChildOfDoStatement(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
-          return context.factory.updateDoStatement(
-            node,
-            visitIterationBody(node.statement, visitor, context, nodeVisitor),
-            Debug.checkDefined(nodeVisitor(node.expression, visitor, isExpression))
-          );
-        },
-        [246 /* WhileStatement */]: function visitEachChildOfWhileStatement(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
-          return context.factory.updateWhileStatement(
-            node,
-            Debug.checkDefined(nodeVisitor(node.expression, visitor, isExpression)),
-            visitIterationBody(node.statement, visitor, context, nodeVisitor)
-          );
-        },
-        [247 /* ForStatement */]: function visitEachChildOfForStatement(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
-          return context.factory.updateForStatement(
-            node,
-            nodeVisitor(node.initializer, visitor, isForInitializer),
-            nodeVisitor(node.condition, visitor, isExpression),
-            nodeVisitor(node.incrementor, visitor, isExpression),
-            visitIterationBody(node.statement, visitor, context, nodeVisitor)
-          );
-        },
-        [248 /* ForInStatement */]: function visitEachChildOfForInStatement(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
-          return context.factory.updateForInStatement(
-            node,
-            Debug.checkDefined(nodeVisitor(node.initializer, visitor, isForInitializer)),
-            Debug.checkDefined(nodeVisitor(node.expression, visitor, isExpression)),
-            visitIterationBody(node.statement, visitor, context, nodeVisitor)
-          );
-        },
-        [249 /* ForOfStatement */]: function visitEachChildOfForOfStatement(node, visitor, context, _nodesVisitor, nodeVisitor, tokenVisitor) {
-          return context.factory.updateForOfStatement(
-            node,
-            tokenVisitor ? nodeVisitor(node.awaitModifier, tokenVisitor, isAwaitKeyword) : node.awaitModifier,
-            Debug.checkDefined(nodeVisitor(node.initializer, visitor, isForInitializer)),
-            Debug.checkDefined(nodeVisitor(node.expression, visitor, isExpression)),
-            visitIterationBody(node.statement, visitor, context, nodeVisitor)
-          );
-        },
-        [250 /* ContinueStatement */]: function visitEachChildOfContinueStatement(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
-          return context.factory.updateContinueStatement(
-            node,
-            nodeVisitor(node.label, visitor, isIdentifier)
-          );
-        },
-        [251 /* BreakStatement */]: function visitEachChildOfBreakStatement(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
-          return context.factory.updateBreakStatement(
-            node,
-            nodeVisitor(node.label, visitor, isIdentifier)
-          );
-        },
-        [252 /* ReturnStatement */]: function visitEachChildOfReturnStatement(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
-          return context.factory.updateReturnStatement(
-            node,
-            nodeVisitor(node.expression, visitor, isExpression)
-          );
-        },
-        [253 /* WithStatement */]: function visitEachChildOfWithStatement(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
-          return context.factory.updateWithStatement(
-            node,
-            Debug.checkDefined(nodeVisitor(node.expression, visitor, isExpression)),
-            Debug.checkDefined(nodeVisitor(node.statement, visitor, isStatement, context.factory.liftToBlock))
-          );
-        },
-        [254 /* SwitchStatement */]: function visitEachChildOfSwitchStatement(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
-          return context.factory.updateSwitchStatement(
-            node,
-            Debug.checkDefined(nodeVisitor(node.expression, visitor, isExpression)),
-            Debug.checkDefined(nodeVisitor(node.caseBlock, visitor, isCaseBlock))
-          );
-        },
-        [255 /* LabeledStatement */]: function visitEachChildOfLabeledStatement(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
-          return context.factory.updateLabeledStatement(
-            node,
-            Debug.checkDefined(nodeVisitor(node.label, visitor, isIdentifier)),
-            Debug.checkDefined(nodeVisitor(node.statement, visitor, isStatement, context.factory.liftToBlock))
-          );
-        },
-        [256 /* ThrowStatement */]: function visitEachChildOfThrowStatement(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
-          return context.factory.updateThrowStatement(
-            node,
-            Debug.checkDefined(nodeVisitor(node.expression, visitor, isExpression))
-          );
-        },
-        [257 /* TryStatement */]: function visitEachChildOfTryStatement(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
-          return context.factory.updateTryStatement(
-            node,
-            Debug.checkDefined(nodeVisitor(node.tryBlock, visitor, isBlock)),
-            nodeVisitor(node.catchClause, visitor, isCatchClause),
-            nodeVisitor(node.finallyBlock, visitor, isBlock)
-          );
-        },
-        [259 /* VariableDeclaration */]: function visitEachChildOfVariableDeclaration(node, visitor, context, _nodesVisitor, nodeVisitor, tokenVisitor) {
-          return context.factory.updateVariableDeclaration(
-            node,
-            Debug.checkDefined(nodeVisitor(node.name, visitor, isBindingName)),
-            tokenVisitor ? nodeVisitor(node.exclamationToken, tokenVisitor, isExclamationToken) : node.exclamationToken,
-            nodeVisitor(node.type, visitor, isTypeNode),
-            nodeVisitor(node.initializer, visitor, isExpression)
-          );
-        },
-        [260 /* VariableDeclarationList */]: function visitEachChildOfVariableDeclarationList(node, visitor, context, nodesVisitor, _nodeVisitor, _tokenVisitor) {
-          return context.factory.updateVariableDeclarationList(
-            node,
-            nodesVisitor(node.declarations, visitor, isVariableDeclaration)
-          );
-        },
-        [261 /* FunctionDeclaration */]: function visitEachChildOfFunctionDeclaration(node, visitor, context, nodesVisitor, nodeVisitor, tokenVisitor) {
-          return context.factory.updateFunctionDeclaration(
-            node,
-            nodesVisitor(node.modifiers, visitor, isModifier),
-            tokenVisitor ? nodeVisitor(node.asteriskToken, tokenVisitor, isAsteriskToken) : node.asteriskToken,
-            nodeVisitor(node.name, visitor, isIdentifier),
-            nodesVisitor(node.typeParameters, visitor, isTypeParameterDeclaration),
-            visitParameterList(node.parameters, visitor, context, nodesVisitor),
-            nodeVisitor(node.type, visitor, isTypeNode),
-            visitFunctionBody(node.body, visitor, context, nodeVisitor)
-          );
-        },
-        [262 /* ClassDeclaration */]: function visitEachChildOfClassDeclaration(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) {
-          return context.factory.updateClassDeclaration(
-            node,
-            nodesVisitor(node.modifiers, visitor, isModifierLike),
-            nodeVisitor(node.name, visitor, isIdentifier),
-            nodesVisitor(node.typeParameters, visitor, isTypeParameterDeclaration),
-            nodesVisitor(node.heritageClauses, visitor, isHeritageClause),
-            nodesVisitor(node.members, visitor, isClassElement)
-          );
-        },
-        [263 /* InterfaceDeclaration */]: function visitEachChildOfInterfaceDeclaration(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) {
-          return context.factory.updateInterfaceDeclaration(
-            node,
-            nodesVisitor(node.modifiers, visitor, isModifierLike),
-            Debug.checkDefined(nodeVisitor(node.name, visitor, isIdentifier)),
-            nodesVisitor(node.typeParameters, visitor, isTypeParameterDeclaration),
-            nodesVisitor(node.heritageClauses, visitor, isHeritageClause),
-            nodesVisitor(node.members, visitor, isTypeElement)
-          );
-        },
-        [264 /* TypeAliasDeclaration */]: function visitEachChildOfTypeAliasDeclaration(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) {
-          return context.factory.updateTypeAliasDeclaration(
-            node,
-            nodesVisitor(node.modifiers, visitor, isModifierLike),
-            Debug.checkDefined(nodeVisitor(node.name, visitor, isIdentifier)),
-            nodesVisitor(node.typeParameters, visitor, isTypeParameterDeclaration),
-            Debug.checkDefined(nodeVisitor(node.type, visitor, isTypeNode))
-          );
-        },
-        [265 /* EnumDeclaration */]: function visitEachChildOfEnumDeclaration(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) {
-          return context.factory.updateEnumDeclaration(
-            node,
-            nodesVisitor(node.modifiers, visitor, isModifierLike),
-            Debug.checkDefined(nodeVisitor(node.name, visitor, isIdentifier)),
-            nodesVisitor(node.members, visitor, isEnumMember)
-          );
-        },
-        [266 /* ModuleDeclaration */]: function visitEachChildOfModuleDeclaration(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) {
-          return context.factory.updateModuleDeclaration(
-            node,
-            nodesVisitor(node.modifiers, visitor, isModifierLike),
-            Debug.checkDefined(nodeVisitor(node.name, visitor, isModuleName)),
-            nodeVisitor(node.body, visitor, isModuleBody)
-          );
-        },
-        [267 /* ModuleBlock */]: function visitEachChildOfModuleBlock(node, visitor, context, nodesVisitor, _nodeVisitor, _tokenVisitor) {
-          return context.factory.updateModuleBlock(
-            node,
-            nodesVisitor(node.statements, visitor, isStatement)
-          );
-        },
-        [268 /* CaseBlock */]: function visitEachChildOfCaseBlock(node, visitor, context, nodesVisitor, _nodeVisitor, _tokenVisitor) {
-          return context.factory.updateCaseBlock(
-            node,
-            nodesVisitor(node.clauses, visitor, isCaseOrDefaultClause)
-          );
-        },
-        [269 /* NamespaceExportDeclaration */]: function visitEachChildOfNamespaceExportDeclaration(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
-          return context.factory.updateNamespaceExportDeclaration(
-            node,
-            Debug.checkDefined(nodeVisitor(node.name, visitor, isIdentifier))
-          );
-        },
-        [270 /* ImportEqualsDeclaration */]: function visitEachChildOfImportEqualsDeclaration(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) {
-          return context.factory.updateImportEqualsDeclaration(
-            node,
-            nodesVisitor(node.modifiers, visitor, isModifierLike),
-            node.isTypeOnly,
-            Debug.checkDefined(nodeVisitor(node.name, visitor, isIdentifier)),
-            Debug.checkDefined(nodeVisitor(node.moduleReference, visitor, isModuleReference))
-          );
-        },
-        [271 /* ImportDeclaration */]: function visitEachChildOfImportDeclaration(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) {
-          return context.factory.updateImportDeclaration(
-            node,
-            nodesVisitor(node.modifiers, visitor, isModifierLike),
-            nodeVisitor(node.importClause, visitor, isImportClause),
-            Debug.checkDefined(nodeVisitor(node.moduleSpecifier, visitor, isExpression)),
-            nodeVisitor(node.assertClause, visitor, isAssertClause)
-          );
-        },
-        [299 /* AssertClause */]: function visitEachChildOfAssertClause(node, visitor, context, nodesVisitor, _nodeVisitor, _tokenVisitor) {
-          return context.factory.updateAssertClause(
-            node,
-            nodesVisitor(node.elements, visitor, isAssertEntry),
-            node.multiLine
-          );
-        },
-        [300 /* AssertEntry */]: function visitEachChildOfAssertEntry(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
-          return context.factory.updateAssertEntry(
-            node,
-            Debug.checkDefined(nodeVisitor(node.name, visitor, isAssertionKey)),
-            Debug.checkDefined(nodeVisitor(node.value, visitor, isExpression))
-          );
-        },
-        [272 /* ImportClause */]: function visitEachChildOfImportClause(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
-          return context.factory.updateImportClause(
-            node,
-            node.isTypeOnly,
-            nodeVisitor(node.name, visitor, isIdentifier),
-            nodeVisitor(node.namedBindings, visitor, isNamedImportBindings)
-          );
-        },
-        [273 /* NamespaceImport */]: function visitEachChildOfNamespaceImport(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
-          return context.factory.updateNamespaceImport(
-            node,
-            Debug.checkDefined(nodeVisitor(node.name, visitor, isIdentifier))
-          );
-        },
-        [279 /* NamespaceExport */]: function visitEachChildOfNamespaceExport(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
-          return context.factory.updateNamespaceExport(
-            node,
-            Debug.checkDefined(nodeVisitor(node.name, visitor, isIdentifier))
-          );
-        },
-        [274 /* NamedImports */]: function visitEachChildOfNamedImports(node, visitor, context, nodesVisitor, _nodeVisitor, _tokenVisitor) {
-          return context.factory.updateNamedImports(
-            node,
-            nodesVisitor(node.elements, visitor, isImportSpecifier)
-          );
-        },
-        [275 /* ImportSpecifier */]: function visitEachChildOfImportSpecifier(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
-          return context.factory.updateImportSpecifier(
-            node,
-            node.isTypeOnly,
-            nodeVisitor(node.propertyName, visitor, isIdentifier),
-            Debug.checkDefined(nodeVisitor(node.name, visitor, isIdentifier))
-          );
-        },
-        [276 /* ExportAssignment */]: function visitEachChildOfExportAssignment(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) {
-          return context.factory.updateExportAssignment(
-            node,
-            nodesVisitor(node.modifiers, visitor, isModifierLike),
-            Debug.checkDefined(nodeVisitor(node.expression, visitor, isExpression))
-          );
-        },
-        [277 /* ExportDeclaration */]: function visitEachChildOfExportDeclaration(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) {
-          return context.factory.updateExportDeclaration(
-            node,
-            nodesVisitor(node.modifiers, visitor, isModifierLike),
-            node.isTypeOnly,
-            nodeVisitor(node.exportClause, visitor, isNamedExportBindings),
-            nodeVisitor(node.moduleSpecifier, visitor, isExpression),
-            nodeVisitor(node.assertClause, visitor, isAssertClause)
-          );
-        },
-        [278 /* NamedExports */]: function visitEachChildOfNamedExports(node, visitor, context, nodesVisitor, _nodeVisitor, _tokenVisitor) {
-          return context.factory.updateNamedExports(
-            node,
-            nodesVisitor(node.elements, visitor, isExportSpecifier)
-          );
-        },
-        [280 /* ExportSpecifier */]: function visitEachChildOfExportSpecifier(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
-          return context.factory.updateExportSpecifier(
-            node,
-            node.isTypeOnly,
-            nodeVisitor(node.propertyName, visitor, isIdentifier),
-            Debug.checkDefined(nodeVisitor(node.name, visitor, isIdentifier))
-          );
-        },
-        // Module references
-        [282 /* ExternalModuleReference */]: function visitEachChildOfExternalModuleReference(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
-          return context.factory.updateExternalModuleReference(
-            node,
-            Debug.checkDefined(nodeVisitor(node.expression, visitor, isExpression))
-          );
-        },
-        // JSX
-        [283 /* JsxElement */]: function visitEachChildOfJsxElement(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) {
-          return context.factory.updateJsxElement(
-            node,
-            Debug.checkDefined(nodeVisitor(node.openingElement, visitor, isJsxOpeningElement)),
-            nodesVisitor(node.children, visitor, isJsxChild),
-            Debug.checkDefined(nodeVisitor(node.closingElement, visitor, isJsxClosingElement))
-          );
-        },
-        [284 /* JsxSelfClosingElement */]: function visitEachChildOfJsxSelfClosingElement(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) {
-          return context.factory.updateJsxSelfClosingElement(
-            node,
-            Debug.checkDefined(nodeVisitor(node.tagName, visitor, isJsxTagNameExpression)),
-            nodesVisitor(node.typeArguments, visitor, isTypeNode),
-            Debug.checkDefined(nodeVisitor(node.attributes, visitor, isJsxAttributes))
-          );
-        },
-        [285 /* JsxOpeningElement */]: function visitEachChildOfJsxOpeningElement(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) {
-          return context.factory.updateJsxOpeningElement(
-            node,
-            Debug.checkDefined(nodeVisitor(node.tagName, visitor, isJsxTagNameExpression)),
-            nodesVisitor(node.typeArguments, visitor, isTypeNode),
-            Debug.checkDefined(nodeVisitor(node.attributes, visitor, isJsxAttributes))
-          );
-        },
-        [286 /* JsxClosingElement */]: function visitEachChildOfJsxClosingElement(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
-          return context.factory.updateJsxClosingElement(
-            node,
-            Debug.checkDefined(nodeVisitor(node.tagName, visitor, isJsxTagNameExpression))
-          );
-        },
-        [294 /* JsxNamespacedName */]: function forEachChildInJsxNamespacedName2(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
-          return context.factory.updateJsxNamespacedName(
-            node,
-            Debug.checkDefined(nodeVisitor(node.namespace, visitor, isIdentifier)),
-            Debug.checkDefined(nodeVisitor(node.name, visitor, isIdentifier))
-          );
-        },
-        [287 /* JsxFragment */]: function visitEachChildOfJsxFragment(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) {
-          return context.factory.updateJsxFragment(
-            node,
-            Debug.checkDefined(nodeVisitor(node.openingFragment, visitor, isJsxOpeningFragment)),
-            nodesVisitor(node.children, visitor, isJsxChild),
-            Debug.checkDefined(nodeVisitor(node.closingFragment, visitor, isJsxClosingFragment))
-          );
-        },
-        [290 /* JsxAttribute */]: function visitEachChildOfJsxAttribute(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
-          return context.factory.updateJsxAttribute(
-            node,
-            Debug.checkDefined(nodeVisitor(node.name, visitor, isJsxAttributeName)),
-            nodeVisitor(node.initializer, visitor, isStringLiteralOrJsxExpression)
-          );
-        },
-        [291 /* JsxAttributes */]: function visitEachChildOfJsxAttributes(node, visitor, context, nodesVisitor, _nodeVisitor, _tokenVisitor) {
-          return context.factory.updateJsxAttributes(
-            node,
-            nodesVisitor(node.properties, visitor, isJsxAttributeLike)
-          );
-        },
-        [292 /* JsxSpreadAttribute */]: function visitEachChildOfJsxSpreadAttribute(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
-          return context.factory.updateJsxSpreadAttribute(
-            node,
-            Debug.checkDefined(nodeVisitor(node.expression, visitor, isExpression))
-          );
-        },
-        [293 /* JsxExpression */]: function visitEachChildOfJsxExpression(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
-          return context.factory.updateJsxExpression(
-            node,
-            nodeVisitor(node.expression, visitor, isExpression)
-          );
-        },
-        // Clauses
-        [295 /* CaseClause */]: function visitEachChildOfCaseClause(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) {
-          return context.factory.updateCaseClause(
-            node,
-            Debug.checkDefined(nodeVisitor(node.expression, visitor, isExpression)),
-            nodesVisitor(node.statements, visitor, isStatement)
-          );
-        },
-        [296 /* DefaultClause */]: function visitEachChildOfDefaultClause(node, visitor, context, nodesVisitor, _nodeVisitor, _tokenVisitor) {
-          return context.factory.updateDefaultClause(
-            node,
-            nodesVisitor(node.statements, visitor, isStatement)
-          );
-        },
-        [297 /* HeritageClause */]: function visitEachChildOfHeritageClause(node, visitor, context, nodesVisitor, _nodeVisitor, _tokenVisitor) {
-          return context.factory.updateHeritageClause(
-            node,
-            nodesVisitor(node.types, visitor, isExpressionWithTypeArguments)
-          );
-        },
-        [298 /* CatchClause */]: function visitEachChildOfCatchClause(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
-          return context.factory.updateCatchClause(
-            node,
-            nodeVisitor(node.variableDeclaration, visitor, isVariableDeclaration),
-            Debug.checkDefined(nodeVisitor(node.block, visitor, isBlock))
-          );
-        },
-        // Property assignments
-        [302 /* PropertyAssignment */]: function visitEachChildOfPropertyAssignment(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
-          return context.factory.updatePropertyAssignment(
-            node,
-            Debug.checkDefined(nodeVisitor(node.name, visitor, isPropertyName)),
-            Debug.checkDefined(nodeVisitor(node.initializer, visitor, isExpression))
-          );
-        },
-        [303 /* ShorthandPropertyAssignment */]: function visitEachChildOfShorthandPropertyAssignment(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
-          return context.factory.updateShorthandPropertyAssignment(
-            node,
-            Debug.checkDefined(nodeVisitor(node.name, visitor, isIdentifier)),
-            nodeVisitor(node.objectAssignmentInitializer, visitor, isExpression)
-          );
-        },
-        [304 /* SpreadAssignment */]: function visitEachChildOfSpreadAssignment(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
-          return context.factory.updateSpreadAssignment(
-            node,
-            Debug.checkDefined(nodeVisitor(node.expression, visitor, isExpression))
-          );
-        },
-        // Enum
-        [305 /* EnumMember */]: function visitEachChildOfEnumMember(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
-          return context.factory.updateEnumMember(
-            node,
-            Debug.checkDefined(nodeVisitor(node.name, visitor, isPropertyName)),
-            nodeVisitor(node.initializer, visitor, isExpression)
-          );
-        },
-        // Top-level nodes
-        [311 /* SourceFile */]: function visitEachChildOfSourceFile(node, visitor, context, _nodesVisitor, _nodeVisitor, _tokenVisitor) {
-          return context.factory.updateSourceFile(
-            node,
-            visitLexicalEnvironment(node.statements, visitor, context)
-          );
-        },
-        // Transformation nodes
-        [359 /* PartiallyEmittedExpression */]: function visitEachChildOfPartiallyEmittedExpression(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
-          return context.factory.updatePartiallyEmittedExpression(
-            node,
-            Debug.checkDefined(nodeVisitor(node.expression, visitor, isExpression))
-          );
-        },
-        [360 /* CommaListExpression */]: function visitEachChildOfCommaListExpression(node, visitor, context, nodesVisitor, _nodeVisitor, _tokenVisitor) {
-          return context.factory.updateCommaListExpression(
-            node,
-            nodesVisitor(node.elements, visitor, isExpression)
-          );
-        }
-      };
-    }
-  });
-
-  // src/compiler/sourcemap.ts
-  function createSourceMapGenerator(host, file, sourceRoot, sourcesDirectoryPath, generatorOptions) {
-    var { enter, exit } = generatorOptions.extendedDiagnostics ? createTimer("Source Map", "beforeSourcemap", "afterSourcemap") : nullTimer;
-    var rawSources = [];
-    var sources = [];
-    var sourceToSourceIndexMap = /* @__PURE__ */ new Map();
-    var sourcesContent;
-    var names = [];
-    var nameToNameIndexMap;
-    var mappingCharCodes = [];
-    var mappings = "";
-    var lastGeneratedLine = 0;
-    var lastGeneratedCharacter = 0;
-    var lastSourceIndex = 0;
-    var lastSourceLine = 0;
-    var lastSourceCharacter = 0;
-    var lastNameIndex = 0;
-    var hasLast = false;
-    var pendingGeneratedLine = 0;
-    var pendingGeneratedCharacter = 0;
-    var pendingSourceIndex = 0;
-    var pendingSourceLine = 0;
-    var pendingSourceCharacter = 0;
-    var pendingNameIndex = 0;
-    var hasPending = false;
-    var hasPendingSource = false;
-    var hasPendingName = false;
-    return {
-      getSources: () => rawSources,
-      addSource,
-      setSourceContent,
-      addName,
-      addMapping,
-      appendSourceMap,
-      toJSON,
-      toString: () => JSON.stringify(toJSON())
-    };
-    function addSource(fileName) {
-      enter();
-      const source = getRelativePathToDirectoryOrUrl(
-        sourcesDirectoryPath,
-        fileName,
-        host.getCurrentDirectory(),
-        host.getCanonicalFileName,
-        /*isAbsolutePathAnUrl*/
-        true
-      );
-      let sourceIndex = sourceToSourceIndexMap.get(source);
-      if (sourceIndex === void 0) {
-        sourceIndex = sources.length;
-        sources.push(source);
-        rawSources.push(fileName);
-        sourceToSourceIndexMap.set(source, sourceIndex);
-      }
-      exit();
-      return sourceIndex;
-    }
-    function setSourceContent(sourceIndex, content) {
-      enter();
-      if (content !== null) {
-        if (!sourcesContent)
-          sourcesContent = [];
-        while (sourcesContent.length < sourceIndex) {
-          sourcesContent.push(null);
-        }
-        sourcesContent[sourceIndex] = content;
-      }
-      exit();
-    }
-    function addName(name) {
-      enter();
-      if (!nameToNameIndexMap)
-        nameToNameIndexMap = /* @__PURE__ */ new Map();
-      let nameIndex = nameToNameIndexMap.get(name);
-      if (nameIndex === void 0) {
-        nameIndex = names.length;
-        names.push(name);
-        nameToNameIndexMap.set(name, nameIndex);
-      }
-      exit();
-      return nameIndex;
-    }
-    function isNewGeneratedPosition(generatedLine, generatedCharacter) {
-      return !hasPending || pendingGeneratedLine !== generatedLine || pendingGeneratedCharacter !== generatedCharacter;
-    }
-    function isBacktrackingSourcePosition(sourceIndex, sourceLine, sourceCharacter) {
-      return sourceIndex !== void 0 && sourceLine !== void 0 && sourceCharacter !== void 0 && pendingSourceIndex === sourceIndex && (pendingSourceLine > sourceLine || pendingSourceLine === sourceLine && pendingSourceCharacter > sourceCharacter);
-    }
-    function addMapping(generatedLine, generatedCharacter, sourceIndex, sourceLine, sourceCharacter, nameIndex) {
-      Debug.assert(generatedLine >= pendingGeneratedLine, "generatedLine cannot backtrack");
-      Debug.assert(generatedCharacter >= 0, "generatedCharacter cannot be negative");
-      Debug.assert(sourceIndex === void 0 || sourceIndex >= 0, "sourceIndex cannot be negative");
-      Debug.assert(sourceLine === void 0 || sourceLine >= 0, "sourceLine cannot be negative");
-      Debug.assert(sourceCharacter === void 0 || sourceCharacter >= 0, "sourceCharacter cannot be negative");
-      enter();
-      if (isNewGeneratedPosition(generatedLine, generatedCharacter) || isBacktrackingSourcePosition(sourceIndex, sourceLine, sourceCharacter)) {
-        commitPendingMapping();
-        pendingGeneratedLine = generatedLine;
-        pendingGeneratedCharacter = generatedCharacter;
-        hasPendingSource = false;
-        hasPendingName = false;
-        hasPending = true;
-      }
-      if (sourceIndex !== void 0 && sourceLine !== void 0 && sourceCharacter !== void 0) {
-        pendingSourceIndex = sourceIndex;
-        pendingSourceLine = sourceLine;
-        pendingSourceCharacter = sourceCharacter;
-        hasPendingSource = true;
-        if (nameIndex !== void 0) {
-          pendingNameIndex = nameIndex;
-          hasPendingName = true;
-        }
-      }
-      exit();
-    }
-    function appendSourceMap(generatedLine, generatedCharacter, map2, sourceMapPath, start, end) {
-      Debug.assert(generatedLine >= pendingGeneratedLine, "generatedLine cannot backtrack");
-      Debug.assert(generatedCharacter >= 0, "generatedCharacter cannot be negative");
-      enter();
-      const sourceIndexToNewSourceIndexMap = [];
-      let nameIndexToNewNameIndexMap;
-      const mappingIterator = decodeMappings(map2.mappings);
-      for (const raw of mappingIterator) {
-        if (end && (raw.generatedLine > end.line || raw.generatedLine === end.line && raw.generatedCharacter > end.character)) {
-          break;
-        }
-        if (start && (raw.generatedLine < start.line || start.line === raw.generatedLine && raw.generatedCharacter < start.character)) {
-          continue;
-        }
-        let newSourceIndex;
-        let newSourceLine;
-        let newSourceCharacter;
-        let newNameIndex;
-        if (raw.sourceIndex !== void 0) {
-          newSourceIndex = sourceIndexToNewSourceIndexMap[raw.sourceIndex];
-          if (newSourceIndex === void 0) {
-            const rawPath = map2.sources[raw.sourceIndex];
-            const relativePath = map2.sourceRoot ? combinePaths(map2.sourceRoot, rawPath) : rawPath;
-            const combinedPath = combinePaths(getDirectoryPath(sourceMapPath), relativePath);
-            sourceIndexToNewSourceIndexMap[raw.sourceIndex] = newSourceIndex = addSource(combinedPath);
-            if (map2.sourcesContent && typeof map2.sourcesContent[raw.sourceIndex] === "string") {
-              setSourceContent(newSourceIndex, map2.sourcesContent[raw.sourceIndex]);
-            }
-          }
-          newSourceLine = raw.sourceLine;
-          newSourceCharacter = raw.sourceCharacter;
-          if (map2.names && raw.nameIndex !== void 0) {
-            if (!nameIndexToNewNameIndexMap)
-              nameIndexToNewNameIndexMap = [];
-            newNameIndex = nameIndexToNewNameIndexMap[raw.nameIndex];
-            if (newNameIndex === void 0) {
-              nameIndexToNewNameIndexMap[raw.nameIndex] = newNameIndex = addName(map2.names[raw.nameIndex]);
-            }
-          }
-        }
-        const rawGeneratedLine = raw.generatedLine - (start ? start.line : 0);
-        const newGeneratedLine = rawGeneratedLine + generatedLine;
-        const rawGeneratedCharacter = start && start.line === raw.generatedLine ? raw.generatedCharacter - start.character : raw.generatedCharacter;
-        const newGeneratedCharacter = rawGeneratedLine === 0 ? rawGeneratedCharacter + generatedCharacter : rawGeneratedCharacter;
-        addMapping(newGeneratedLine, newGeneratedCharacter, newSourceIndex, newSourceLine, newSourceCharacter, newNameIndex);
-      }
-      exit();
-    }
-    function shouldCommitMapping() {
-      return !hasLast || lastGeneratedLine !== pendingGeneratedLine || lastGeneratedCharacter !== pendingGeneratedCharacter || lastSourceIndex !== pendingSourceIndex || lastSourceLine !== pendingSourceLine || lastSourceCharacter !== pendingSourceCharacter || lastNameIndex !== pendingNameIndex;
-    }
-    function appendMappingCharCode(charCode) {
-      mappingCharCodes.push(charCode);
-      if (mappingCharCodes.length >= 1024) {
-        flushMappingBuffer();
-      }
-    }
-    function commitPendingMapping() {
-      if (!hasPending || !shouldCommitMapping()) {
-        return;
-      }
-      enter();
-      if (lastGeneratedLine < pendingGeneratedLine) {
-        do {
-          appendMappingCharCode(59 /* semicolon */);
-          lastGeneratedLine++;
-        } while (lastGeneratedLine < pendingGeneratedLine);
-        lastGeneratedCharacter = 0;
-      } else {
-        Debug.assertEqual(lastGeneratedLine, pendingGeneratedLine, "generatedLine cannot backtrack");
-        if (hasLast) {
-          appendMappingCharCode(44 /* comma */);
-        }
-      }
-      appendBase64VLQ(pendingGeneratedCharacter - lastGeneratedCharacter);
-      lastGeneratedCharacter = pendingGeneratedCharacter;
-      if (hasPendingSource) {
-        appendBase64VLQ(pendingSourceIndex - lastSourceIndex);
-        lastSourceIndex = pendingSourceIndex;
-        appendBase64VLQ(pendingSourceLine - lastSourceLine);
-        lastSourceLine = pendingSourceLine;
-        appendBase64VLQ(pendingSourceCharacter - lastSourceCharacter);
-        lastSourceCharacter = pendingSourceCharacter;
-        if (hasPendingName) {
-          appendBase64VLQ(pendingNameIndex - lastNameIndex);
-          lastNameIndex = pendingNameIndex;
-        }
-      }
-      hasLast = true;
-      exit();
-    }
-    function flushMappingBuffer() {
-      if (mappingCharCodes.length > 0) {
-        mappings += String.fromCharCode.apply(void 0, mappingCharCodes);
-        mappingCharCodes.length = 0;
-      }
-    }
-    function toJSON() {
-      commitPendingMapping();
-      flushMappingBuffer();
-      return {
-        version: 3,
-        file,
-        sourceRoot,
-        sources,
-        names,
-        mappings,
-        sourcesContent
-      };
-    }
-    function appendBase64VLQ(inValue) {
-      if (inValue < 0) {
-        inValue = (-inValue << 1) + 1;
-      } else {
-        inValue = inValue << 1;
-      }
-      do {
-        let currentDigit = inValue & 31;
-        inValue = inValue >> 5;
-        if (inValue > 0) {
-          currentDigit = currentDigit | 32;
-        }
-        appendMappingCharCode(base64FormatEncode(currentDigit));
-      } while (inValue > 0);
-    }
-  }
-  function getLineInfo(text, lineStarts) {
-    return {
-      getLineCount: () => lineStarts.length,
-      getLineText: (line) => text.substring(lineStarts[line], lineStarts[line + 1])
-    };
-  }
-  function tryGetSourceMappingURL(lineInfo) {
-    for (let index = lineInfo.getLineCount() - 1; index >= 0; index--) {
-      const line = lineInfo.getLineText(index);
-      const comment = sourceMapCommentRegExp.exec(line);
-      if (comment) {
-        return trimStringEnd(comment[1]);
-      } else if (!line.match(whitespaceOrMapCommentRegExp)) {
-        break;
-      }
-    }
-  }
-  function isStringOrNull(x) {
-    return typeof x === "string" || x === null;
-  }
-  function isRawSourceMap(x) {
-    return x !== null && typeof x === "object" && x.version === 3 && typeof x.file === "string" && typeof x.mappings === "string" && isArray(x.sources) && every(x.sources, isString) && (x.sourceRoot === void 0 || x.sourceRoot === null || typeof x.sourceRoot === "string") && (x.sourcesContent === void 0 || x.sourcesContent === null || isArray(x.sourcesContent) && every(x.sourcesContent, isStringOrNull)) && (x.names === void 0 || x.names === null || isArray(x.names) && every(x.names, isString));
-  }
-  function tryParseRawSourceMap(text) {
-    try {
-      const parsed = JSON.parse(text);
-      if (isRawSourceMap(parsed)) {
-        return parsed;
-      }
-    } catch {
-    }
-    return void 0;
-  }
-  function decodeMappings(mappings) {
-    let done = false;
-    let pos = 0;
-    let generatedLine = 0;
-    let generatedCharacter = 0;
-    let sourceIndex = 0;
-    let sourceLine = 0;
-    let sourceCharacter = 0;
-    let nameIndex = 0;
-    let error;
-    return {
-      get pos() {
-        return pos;
-      },
-      get error() {
-        return error;
-      },
-      get state() {
-        return captureMapping(
-          /*hasSource*/
-          true,
-          /*hasName*/
-          true
-        );
-      },
-      next() {
-        while (!done && pos < mappings.length) {
-          const ch = mappings.charCodeAt(pos);
-          if (ch === 59 /* semicolon */) {
-            generatedLine++;
-            generatedCharacter = 0;
-            pos++;
-            continue;
-          }
-          if (ch === 44 /* comma */) {
-            pos++;
-            continue;
-          }
-          let hasSource = false;
-          let hasName = false;
-          generatedCharacter += base64VLQFormatDecode();
-          if (hasReportedError())
-            return stopIterating();
-          if (generatedCharacter < 0)
-            return setErrorAndStopIterating("Invalid generatedCharacter found");
-          if (!isSourceMappingSegmentEnd()) {
-            hasSource = true;
-            sourceIndex += base64VLQFormatDecode();
-            if (hasReportedError())
-              return stopIterating();
-            if (sourceIndex < 0)
-              return setErrorAndStopIterating("Invalid sourceIndex found");
-            if (isSourceMappingSegmentEnd())
-              return setErrorAndStopIterating("Unsupported Format: No entries after sourceIndex");
-            sourceLine += base64VLQFormatDecode();
-            if (hasReportedError())
-              return stopIterating();
-            if (sourceLine < 0)
-              return setErrorAndStopIterating("Invalid sourceLine found");
-            if (isSourceMappingSegmentEnd())
-              return setErrorAndStopIterating("Unsupported Format: No entries after sourceLine");
-            sourceCharacter += base64VLQFormatDecode();
-            if (hasReportedError())
-              return stopIterating();
-            if (sourceCharacter < 0)
-              return setErrorAndStopIterating("Invalid sourceCharacter found");
-            if (!isSourceMappingSegmentEnd()) {
-              hasName = true;
-              nameIndex += base64VLQFormatDecode();
-              if (hasReportedError())
-                return stopIterating();
-              if (nameIndex < 0)
-                return setErrorAndStopIterating("Invalid nameIndex found");
-              if (!isSourceMappingSegmentEnd())
-                return setErrorAndStopIterating("Unsupported Error Format: Entries after nameIndex");
-            }
-          }
-          return { value: captureMapping(hasSource, hasName), done };
-        }
-        return stopIterating();
-      },
-      [Symbol.iterator]() {
-        return this;
-      }
-    };
-    function captureMapping(hasSource, hasName) {
-      return {
-        generatedLine,
-        generatedCharacter,
-        sourceIndex: hasSource ? sourceIndex : void 0,
-        sourceLine: hasSource ? sourceLine : void 0,
-        sourceCharacter: hasSource ? sourceCharacter : void 0,
-        nameIndex: hasName ? nameIndex : void 0
-      };
-    }
-    function stopIterating() {
-      done = true;
-      return { value: void 0, done: true };
-    }
-    function setError(message) {
-      if (error === void 0) {
-        error = message;
-      }
-    }
-    function setErrorAndStopIterating(message) {
-      setError(message);
-      return stopIterating();
-    }
-    function hasReportedError() {
-      return error !== void 0;
-    }
-    function isSourceMappingSegmentEnd() {
-      return pos === mappings.length || mappings.charCodeAt(pos) === 44 /* comma */ || mappings.charCodeAt(pos) === 59 /* semicolon */;
-    }
-    function base64VLQFormatDecode() {
-      let moreDigits = true;
-      let shiftCount = 0;
-      let value = 0;
-      for (; moreDigits; pos++) {
-        if (pos >= mappings.length)
-          return setError("Error in decoding base64VLQFormatDecode, past the mapping string"), -1;
-        const currentByte = base64FormatDecode(mappings.charCodeAt(pos));
-        if (currentByte === -1)
-          return setError("Invalid character in VLQ"), -1;
-        moreDigits = (currentByte & 32) !== 0;
-        value = value | (currentByte & 31) << shiftCount;
-        shiftCount += 5;
-      }
-      if ((value & 1) === 0) {
-        value = value >> 1;
-      } else {
-        value = value >> 1;
-        value = -value;
-      }
-      return value;
-    }
-  }
-  function sameMapping(left, right) {
-    return left === right || left.generatedLine === right.generatedLine && left.generatedCharacter === right.generatedCharacter && left.sourceIndex === right.sourceIndex && left.sourceLine === right.sourceLine && left.sourceCharacter === right.sourceCharacter && left.nameIndex === right.nameIndex;
-  }
-  function isSourceMapping(mapping) {
-    return mapping.sourceIndex !== void 0 && mapping.sourceLine !== void 0 && mapping.sourceCharacter !== void 0;
-  }
-  function base64FormatEncode(value) {
-    return value >= 0 && value < 26 ? 65 /* A */ + value : value >= 26 && value < 52 ? 97 /* a */ + value - 26 : value >= 52 && value < 62 ? 48 /* _0 */ + value - 52 : value === 62 ? 43 /* plus */ : value === 63 ? 47 /* slash */ : Debug.fail(`${value}: not a base64 value`);
-  }
-  function base64FormatDecode(ch) {
-    return ch >= 65 /* A */ && ch <= 90 /* Z */ ? ch - 65 /* A */ : ch >= 97 /* a */ && ch <= 122 /* z */ ? ch - 97 /* a */ + 26 : ch >= 48 /* _0 */ && ch <= 57 /* _9 */ ? ch - 48 /* _0 */ + 52 : ch === 43 /* plus */ ? 62 : ch === 47 /* slash */ ? 63 : -1;
-  }
-  function isSourceMappedPosition(value) {
-    return value.sourceIndex !== void 0 && value.sourcePosition !== void 0;
-  }
-  function sameMappedPosition(left, right) {
-    return left.generatedPosition === right.generatedPosition && left.sourceIndex === right.sourceIndex && left.sourcePosition === right.sourcePosition;
-  }
-  function compareSourcePositions(left, right) {
-    Debug.assert(left.sourceIndex === right.sourceIndex);
-    return compareValues(left.sourcePosition, right.sourcePosition);
-  }
-  function compareGeneratedPositions(left, right) {
-    return compareValues(left.generatedPosition, right.generatedPosition);
-  }
-  function getSourcePositionOfMapping(value) {
-    return value.sourcePosition;
-  }
-  function getGeneratedPositionOfMapping(value) {
-    return value.generatedPosition;
-  }
-  function createDocumentPositionMapper(host, map2, mapPath) {
-    const mapDirectory = getDirectoryPath(mapPath);
-    const sourceRoot = map2.sourceRoot ? getNormalizedAbsolutePath(map2.sourceRoot, mapDirectory) : mapDirectory;
-    const generatedAbsoluteFilePath = getNormalizedAbsolutePath(map2.file, mapDirectory);
-    const generatedFile = host.getSourceFileLike(generatedAbsoluteFilePath);
-    const sourceFileAbsolutePaths = map2.sources.map((source) => getNormalizedAbsolutePath(source, sourceRoot));
-    const sourceToSourceIndexMap = new Map(sourceFileAbsolutePaths.map((source, i) => [host.getCanonicalFileName(source), i]));
-    let decodedMappings;
-    let generatedMappings;
-    let sourceMappings;
-    return {
-      getSourcePosition,
-      getGeneratedPosition
-    };
-    function processMapping(mapping) {
-      const generatedPosition = generatedFile !== void 0 ? getPositionOfLineAndCharacter(
-        generatedFile,
-        mapping.generatedLine,
-        mapping.generatedCharacter,
-        /*allowEdits*/
-        true
-      ) : -1;
-      let source;
-      let sourcePosition;
-      if (isSourceMapping(mapping)) {
-        const sourceFile = host.getSourceFileLike(sourceFileAbsolutePaths[mapping.sourceIndex]);
-        source = map2.sources[mapping.sourceIndex];
-        sourcePosition = sourceFile !== void 0 ? getPositionOfLineAndCharacter(
-          sourceFile,
-          mapping.sourceLine,
-          mapping.sourceCharacter,
-          /*allowEdits*/
-          true
-        ) : -1;
-      }
-      return {
-        generatedPosition,
-        source,
-        sourceIndex: mapping.sourceIndex,
-        sourcePosition,
-        nameIndex: mapping.nameIndex
-      };
-    }
-    function getDecodedMappings() {
-      if (decodedMappings === void 0) {
-        const decoder = decodeMappings(map2.mappings);
-        const mappings = arrayFrom(decoder, processMapping);
-        if (decoder.error !== void 0) {
-          if (host.log) {
-            host.log(`Encountered error while decoding sourcemap: ${decoder.error}`);
-          }
-          decodedMappings = emptyArray;
-        } else {
-          decodedMappings = mappings;
-        }
-      }
-      return decodedMappings;
-    }
-    function getSourceMappings(sourceIndex) {
-      if (sourceMappings === void 0) {
-        const lists = [];
-        for (const mapping of getDecodedMappings()) {
-          if (!isSourceMappedPosition(mapping))
-            continue;
-          let list = lists[mapping.sourceIndex];
-          if (!list)
-            lists[mapping.sourceIndex] = list = [];
-          list.push(mapping);
-        }
-        sourceMappings = lists.map((list) => sortAndDeduplicate(list, compareSourcePositions, sameMappedPosition));
-      }
-      return sourceMappings[sourceIndex];
-    }
-    function getGeneratedMappings() {
-      if (generatedMappings === void 0) {
-        const list = [];
-        for (const mapping of getDecodedMappings()) {
-          list.push(mapping);
-        }
-        generatedMappings = sortAndDeduplicate(list, compareGeneratedPositions, sameMappedPosition);
-      }
-      return generatedMappings;
-    }
-    function getGeneratedPosition(loc) {
-      const sourceIndex = sourceToSourceIndexMap.get(host.getCanonicalFileName(loc.fileName));
-      if (sourceIndex === void 0)
-        return loc;
-      const sourceMappings2 = getSourceMappings(sourceIndex);
-      if (!some(sourceMappings2))
-        return loc;
-      let targetIndex = binarySearchKey(sourceMappings2, loc.pos, getSourcePositionOfMapping, compareValues);
-      if (targetIndex < 0) {
-        targetIndex = ~targetIndex;
-      }
-      const mapping = sourceMappings2[targetIndex];
-      if (mapping === void 0 || mapping.sourceIndex !== sourceIndex) {
-        return loc;
-      }
-      return { fileName: generatedAbsoluteFilePath, pos: mapping.generatedPosition };
-    }
-    function getSourcePosition(loc) {
-      const generatedMappings2 = getGeneratedMappings();
-      if (!some(generatedMappings2))
-        return loc;
-      let targetIndex = binarySearchKey(generatedMappings2, loc.pos, getGeneratedPositionOfMapping, compareValues);
-      if (targetIndex < 0) {
-        targetIndex = ~targetIndex;
-      }
-      const mapping = generatedMappings2[targetIndex];
-      if (mapping === void 0 || !isSourceMappedPosition(mapping)) {
-        return loc;
-      }
-      return { fileName: sourceFileAbsolutePaths[mapping.sourceIndex], pos: mapping.sourcePosition };
-    }
-  }
-  var sourceMapCommentRegExpDontCareLineStart, sourceMapCommentRegExp, whitespaceOrMapCommentRegExp, identitySourceMapConsumer;
-  var init_sourcemap = __esm({
-    "src/compiler/sourcemap.ts"() {
-      "use strict";
-      init_ts2();
-      init_ts_performance();
-      sourceMapCommentRegExpDontCareLineStart = /\/\/[@#] source[M]appingURL=(.+)\r?\n?$/;
-      sourceMapCommentRegExp = /^\/\/[@#] source[M]appingURL=(.+)\r?\n?$/;
-      whitespaceOrMapCommentRegExp = /^\s*(\/\/[@#] .*)?$/;
-      identitySourceMapConsumer = {
-        getSourcePosition: identity,
-        getGeneratedPosition: identity
-      };
-    }
-  });
-
-  // src/compiler/transformers/utilities.ts
-  function getOriginalNodeId(node) {
-    node = getOriginalNode(node);
-    return node ? getNodeId(node) : 0;
-  }
-  function containsDefaultReference(node) {
-    if (!node)
-      return false;
-    if (!isNamedImports(node))
-      return false;
-    return some(node.elements, isNamedDefaultReference);
-  }
-  function isNamedDefaultReference(e) {
-    return e.propertyName !== void 0 && e.propertyName.escapedText === "default" /* Default */;
-  }
-  function chainBundle(context, transformSourceFile) {
-    return transformSourceFileOrBundle;
-    function transformSourceFileOrBundle(node) {
-      return node.kind === 311 /* SourceFile */ ? transformSourceFile(node) : transformBundle(node);
-    }
-    function transformBundle(node) {
-      return context.factory.createBundle(map(node.sourceFiles, transformSourceFile), node.prepends);
-    }
-  }
-  function getExportNeedsImportStarHelper(node) {
-    return !!getNamespaceDeclarationNode(node);
-  }
-  function getImportNeedsImportStarHelper(node) {
-    if (!!getNamespaceDeclarationNode(node)) {
-      return true;
-    }
-    const bindings = node.importClause && node.importClause.namedBindings;
-    if (!bindings) {
-      return false;
-    }
-    if (!isNamedImports(bindings))
-      return false;
-    let defaultRefCount = 0;
-    for (const binding of bindings.elements) {
-      if (isNamedDefaultReference(binding)) {
-        defaultRefCount++;
-      }
-    }
-    return defaultRefCount > 0 && defaultRefCount !== bindings.elements.length || !!(bindings.elements.length - defaultRefCount) && isDefaultImport(node);
-  }
-  function getImportNeedsImportDefaultHelper(node) {
-    return !getImportNeedsImportStarHelper(node) && (isDefaultImport(node) || !!node.importClause && isNamedImports(node.importClause.namedBindings) && containsDefaultReference(node.importClause.namedBindings));
-  }
-  function collectExternalModuleInfo(context, sourceFile, resolver, compilerOptions) {
-    const externalImports = [];
-    const exportSpecifiers = createMultiMap();
-    const exportedBindings = [];
-    const uniqueExports = /* @__PURE__ */ new Map();
-    let exportedNames;
-    let hasExportDefault = false;
-    let exportEquals;
-    let hasExportStarsToExportValues = false;
-    let hasImportStar = false;
-    let hasImportDefault = false;
-    for (const node of sourceFile.statements) {
-      switch (node.kind) {
-        case 271 /* ImportDeclaration */:
-          externalImports.push(node);
-          if (!hasImportStar && getImportNeedsImportStarHelper(node)) {
-            hasImportStar = true;
-          }
-          if (!hasImportDefault && getImportNeedsImportDefaultHelper(node)) {
-            hasImportDefault = true;
-          }
-          break;
-        case 270 /* ImportEqualsDeclaration */:
-          if (node.moduleReference.kind === 282 /* ExternalModuleReference */) {
-            externalImports.push(node);
-          }
-          break;
-        case 277 /* ExportDeclaration */:
-          if (node.moduleSpecifier) {
-            if (!node.exportClause) {
-              externalImports.push(node);
-              hasExportStarsToExportValues = true;
-            } else {
-              externalImports.push(node);
-              if (isNamedExports(node.exportClause)) {
-                addExportedNamesForExportDeclaration(node);
-              } else {
-                const name = node.exportClause.name;
-                if (!uniqueExports.get(idText(name))) {
-                  multiMapSparseArrayAdd(exportedBindings, getOriginalNodeId(node), name);
-                  uniqueExports.set(idText(name), true);
-                  exportedNames = append(exportedNames, name);
-                }
-                hasImportStar = true;
-              }
-            }
-          } else {
-            addExportedNamesForExportDeclaration(node);
-          }
-          break;
-        case 276 /* ExportAssignment */:
-          if (node.isExportEquals && !exportEquals) {
-            exportEquals = node;
-          }
-          break;
-        case 242 /* VariableStatement */:
-          if (hasSyntacticModifier(node, 1 /* Export */)) {
-            for (const decl of node.declarationList.declarations) {
-              exportedNames = collectExportedVariableInfo(decl, uniqueExports, exportedNames, exportedBindings);
-            }
-          }
-          break;
-        case 261 /* FunctionDeclaration */:
-          if (hasSyntacticModifier(node, 1 /* Export */)) {
-            if (hasSyntacticModifier(node, 1024 /* Default */)) {
-              if (!hasExportDefault) {
-                multiMapSparseArrayAdd(exportedBindings, getOriginalNodeId(node), context.factory.getDeclarationName(node));
-                hasExportDefault = true;
-              }
-            } else {
-              const name = node.name;
-              if (!uniqueExports.get(idText(name))) {
-                multiMapSparseArrayAdd(exportedBindings, getOriginalNodeId(node), name);
-                uniqueExports.set(idText(name), true);
-                exportedNames = append(exportedNames, name);
-              }
-            }
-          }
-          break;
-        case 262 /* ClassDeclaration */:
-          if (hasSyntacticModifier(node, 1 /* Export */)) {
-            if (hasSyntacticModifier(node, 1024 /* Default */)) {
-              if (!hasExportDefault) {
-                multiMapSparseArrayAdd(exportedBindings, getOriginalNodeId(node), context.factory.getDeclarationName(node));
-                hasExportDefault = true;
-              }
-            } else {
-              const name = node.name;
-              if (name && !uniqueExports.get(idText(name))) {
-                multiMapSparseArrayAdd(exportedBindings, getOriginalNodeId(node), name);
-                uniqueExports.set(idText(name), true);
-                exportedNames = append(exportedNames, name);
-              }
-            }
-          }
-          break;
-      }
-    }
-    const externalHelpersImportDeclaration = createExternalHelpersImportDeclarationIfNeeded(context.factory, context.getEmitHelperFactory(), sourceFile, compilerOptions, hasExportStarsToExportValues, hasImportStar, hasImportDefault);
-    if (externalHelpersImportDeclaration) {
-      externalImports.unshift(externalHelpersImportDeclaration);
-    }
-    return { externalImports, exportSpecifiers, exportEquals, hasExportStarsToExportValues, exportedBindings, exportedNames, externalHelpersImportDeclaration };
-    function addExportedNamesForExportDeclaration(node) {
-      for (const specifier of cast(node.exportClause, isNamedExports).elements) {
-        if (!uniqueExports.get(idText(specifier.name))) {
-          const name = specifier.propertyName || specifier.name;
-          if (!node.moduleSpecifier) {
-            exportSpecifiers.add(idText(name), specifier);
-          }
-          const decl = resolver.getReferencedImportDeclaration(name) || resolver.getReferencedValueDeclaration(name);
-          if (decl) {
-            multiMapSparseArrayAdd(exportedBindings, getOriginalNodeId(decl), specifier.name);
-          }
-          uniqueExports.set(idText(specifier.name), true);
-          exportedNames = append(exportedNames, specifier.name);
-        }
-      }
-    }
-  }
-  function collectExportedVariableInfo(decl, uniqueExports, exportedNames, exportedBindings) {
-    if (isBindingPattern(decl.name)) {
-      for (const element of decl.name.elements) {
-        if (!isOmittedExpression(element)) {
-          exportedNames = collectExportedVariableInfo(element, uniqueExports, exportedNames, exportedBindings);
-        }
-      }
-    } else if (!isGeneratedIdentifier(decl.name)) {
-      const text = idText(decl.name);
-      if (!uniqueExports.get(text)) {
-        uniqueExports.set(text, true);
-        exportedNames = append(exportedNames, decl.name);
-        if (isLocalName(decl.name)) {
-          multiMapSparseArrayAdd(exportedBindings, getOriginalNodeId(decl), decl.name);
-        }
-      }
-    }
-    return exportedNames;
-  }
-  function multiMapSparseArrayAdd(map2, key, value) {
-    let values = map2[key];
-    if (values) {
-      values.push(value);
-    } else {
-      map2[key] = values = [value];
-    }
-    return values;
-  }
-  function isSimpleCopiableExpression(expression) {
-    return isStringLiteralLike(expression) || expression.kind === 9 /* NumericLiteral */ || isKeyword(expression.kind) || isIdentifier(expression);
-  }
-  function isSimpleInlineableExpression(expression) {
-    return !isIdentifier(expression) && isSimpleCopiableExpression(expression);
-  }
-  function isCompoundAssignment(kind) {
-    return kind >= 65 /* FirstCompoundAssignment */ && kind <= 79 /* LastCompoundAssignment */;
-  }
-  function getNonAssignmentOperatorForCompoundAssignment(kind) {
-    switch (kind) {
-      case 65 /* PlusEqualsToken */:
-        return 40 /* PlusToken */;
-      case 66 /* MinusEqualsToken */:
-        return 41 /* MinusToken */;
-      case 67 /* AsteriskEqualsToken */:
-        return 42 /* AsteriskToken */;
-      case 68 /* AsteriskAsteriskEqualsToken */:
-        return 43 /* AsteriskAsteriskToken */;
-      case 69 /* SlashEqualsToken */:
-        return 44 /* SlashToken */;
-      case 70 /* PercentEqualsToken */:
-        return 45 /* PercentToken */;
-      case 71 /* LessThanLessThanEqualsToken */:
-        return 48 /* LessThanLessThanToken */;
-      case 72 /* GreaterThanGreaterThanEqualsToken */:
-        return 49 /* GreaterThanGreaterThanToken */;
-      case 73 /* GreaterThanGreaterThanGreaterThanEqualsToken */:
-        return 50 /* GreaterThanGreaterThanGreaterThanToken */;
-      case 74 /* AmpersandEqualsToken */:
-        return 51 /* AmpersandToken */;
-      case 75 /* BarEqualsToken */:
-        return 52 /* BarToken */;
-      case 79 /* CaretEqualsToken */:
-        return 53 /* CaretToken */;
-      case 76 /* BarBarEqualsToken */:
-        return 57 /* BarBarToken */;
-      case 77 /* AmpersandAmpersandEqualsToken */:
-        return 56 /* AmpersandAmpersandToken */;
-      case 78 /* QuestionQuestionEqualsToken */:
-        return 61 /* QuestionQuestionToken */;
-    }
-  }
-  function getSuperCallFromStatement(statement) {
-    if (!isExpressionStatement(statement)) {
-      return void 0;
-    }
-    const expression = skipParentheses(statement.expression);
-    return isSuperCall(expression) ? expression : void 0;
-  }
-  function findSuperStatementIndex(statements, indexAfterLastPrologueStatement) {
-    for (let i = indexAfterLastPrologueStatement; i < statements.length; i += 1) {
-      const statement = statements[i];
-      if (getSuperCallFromStatement(statement)) {
-        return i;
-      }
-    }
-    return -1;
-  }
-  function getProperties(node, requireInitializer, isStatic2) {
-    return filter(node.members, (m) => isInitializedOrStaticProperty(m, requireInitializer, isStatic2));
-  }
-  function isStaticPropertyDeclarationOrClassStaticBlockDeclaration(element) {
-    return isStaticPropertyDeclaration(element) || isClassStaticBlockDeclaration(element);
-  }
-  function getStaticPropertiesAndClassStaticBlock(node) {
-    return filter(node.members, isStaticPropertyDeclarationOrClassStaticBlockDeclaration);
-  }
-  function isInitializedOrStaticProperty(member, requireInitializer, isStatic2) {
-    return isPropertyDeclaration(member) && (!!member.initializer || !requireInitializer) && hasStaticModifier(member) === isStatic2;
-  }
-  function isStaticPropertyDeclaration(member) {
-    return isPropertyDeclaration(member) && hasStaticModifier(member);
-  }
-  function isInitializedProperty(member) {
-    return member.kind === 171 /* PropertyDeclaration */ && member.initializer !== void 0;
-  }
-  function isNonStaticMethodOrAccessorWithPrivateName(member) {
-    return !isStatic(member) && (isMethodOrAccessor(member) || isAutoAccessorPropertyDeclaration(member)) && isPrivateIdentifier(member.name);
-  }
-  function getDecoratorsOfParameters(node) {
-    let decorators;
-    if (node) {
-      const parameters = node.parameters;
-      const firstParameterIsThis = parameters.length > 0 && parameterIsThisKeyword(parameters[0]);
-      const firstParameterOffset = firstParameterIsThis ? 1 : 0;
-      const numParameters = firstParameterIsThis ? parameters.length - 1 : parameters.length;
-      for (let i = 0; i < numParameters; i++) {
-        const parameter = parameters[i + firstParameterOffset];
-        if (decorators || hasDecorators(parameter)) {
-          if (!decorators) {
-            decorators = new Array(numParameters);
-          }
-          decorators[i] = getDecorators(parameter);
-        }
-      }
-    }
-    return decorators;
-  }
-  function getAllDecoratorsOfClass(node) {
-    const decorators = getDecorators(node);
-    const parameters = getDecoratorsOfParameters(getFirstConstructorWithBody(node));
-    if (!some(decorators) && !some(parameters)) {
-      return void 0;
-    }
-    return {
-      decorators,
-      parameters
-    };
-  }
-  function getAllDecoratorsOfClassElement(member, parent2, useLegacyDecorators) {
-    switch (member.kind) {
-      case 176 /* GetAccessor */:
-      case 177 /* SetAccessor */:
-        if (!useLegacyDecorators) {
-          return getAllDecoratorsOfMethod(member);
-        }
-        return getAllDecoratorsOfAccessors(member, parent2);
-      case 173 /* MethodDeclaration */:
-        return getAllDecoratorsOfMethod(member);
-      case 171 /* PropertyDeclaration */:
-        return getAllDecoratorsOfProperty(member);
-      default:
-        return void 0;
-    }
-  }
-  function getAllDecoratorsOfAccessors(accessor, parent2) {
-    if (!accessor.body) {
-      return void 0;
-    }
-    const { firstAccessor, secondAccessor, getAccessor, setAccessor } = getAllAccessorDeclarations(parent2.members, accessor);
-    const firstAccessorWithDecorators = hasDecorators(firstAccessor) ? firstAccessor : secondAccessor && hasDecorators(secondAccessor) ? secondAccessor : void 0;
-    if (!firstAccessorWithDecorators || accessor !== firstAccessorWithDecorators) {
-      return void 0;
-    }
-    const decorators = getDecorators(firstAccessorWithDecorators);
-    const parameters = getDecoratorsOfParameters(setAccessor);
-    if (!some(decorators) && !some(parameters)) {
-      return void 0;
-    }
-    return {
-      decorators,
-      parameters,
-      getDecorators: getAccessor && getDecorators(getAccessor),
-      setDecorators: setAccessor && getDecorators(setAccessor)
-    };
-  }
-  function getAllDecoratorsOfMethod(method) {
-    if (!method.body) {
-      return void 0;
-    }
-    const decorators = getDecorators(method);
-    const parameters = getDecoratorsOfParameters(method);
-    if (!some(decorators) && !some(parameters)) {
-      return void 0;
-    }
-    return { decorators, parameters };
-  }
-  function getAllDecoratorsOfProperty(property) {
-    const decorators = getDecorators(property);
-    if (!some(decorators)) {
-      return void 0;
-    }
-    return { decorators };
-  }
-  function walkUpLexicalEnvironments(env, cb) {
-    while (env) {
-      const result = cb(env);
-      if (result !== void 0)
-        return result;
-      env = env.previous;
-    }
-  }
-  function newPrivateEnvironment(data) {
-    return { data };
-  }
-  function getPrivateIdentifier(privateEnv, name) {
-    var _a, _b;
-    return isGeneratedPrivateIdentifier(name) ? (_a = privateEnv == null ? void 0 : privateEnv.generatedIdentifiers) == null ? void 0 : _a.get(getNodeForGeneratedName(name)) : (_b = privateEnv == null ? void 0 : privateEnv.identifiers) == null ? void 0 : _b.get(name.escapedText);
-  }
-  function setPrivateIdentifier(privateEnv, name, entry) {
-    if (isGeneratedPrivateIdentifier(name)) {
-      privateEnv.generatedIdentifiers ?? (privateEnv.generatedIdentifiers = /* @__PURE__ */ new Map());
-      privateEnv.generatedIdentifiers.set(getNodeForGeneratedName(name), entry);
-    } else {
-      privateEnv.identifiers ?? (privateEnv.identifiers = /* @__PURE__ */ new Map());
-      privateEnv.identifiers.set(name.escapedText, entry);
-    }
-  }
-  function accessPrivateIdentifier(env, name) {
-    return walkUpLexicalEnvironments(env, (env2) => getPrivateIdentifier(env2.privateEnv, name));
-  }
-  var init_utilities3 = __esm({
-    "src/compiler/transformers/utilities.ts"() {
-      "use strict";
-      init_ts2();
-    }
-  });
-
-  // src/compiler/transformers/destructuring.ts
-  function flattenDestructuringAssignment(node, visitor, context, level, needsValue, createAssignmentCallback) {
-    let location = node;
-    let value;
-    if (isDestructuringAssignment(node)) {
-      value = node.right;
-      while (isEmptyArrayLiteral(node.left) || isEmptyObjectLiteral(node.left)) {
-        if (isDestructuringAssignment(value)) {
-          location = node = value;
-          value = node.right;
-        } else {
-          return Debug.checkDefined(visitNode(value, visitor, isExpression));
-        }
-      }
-    }
-    let expressions;
-    const flattenContext = {
-      context,
-      level,
-      downlevelIteration: !!context.getCompilerOptions().downlevelIteration,
-      hoistTempVariables: true,
-      emitExpression,
-      emitBindingOrAssignment,
-      createArrayBindingOrAssignmentPattern: (elements) => makeArrayAssignmentPattern(context.factory, elements),
-      createObjectBindingOrAssignmentPattern: (elements) => makeObjectAssignmentPattern(context.factory, elements),
-      createArrayBindingOrAssignmentElement: makeAssignmentElement,
-      visitor
-    };
-    if (value) {
-      value = visitNode(value, visitor, isExpression);
-      Debug.assert(value);
-      if (isIdentifier(value) && bindingOrAssignmentElementAssignsToName(node, value.escapedText) || bindingOrAssignmentElementContainsNonLiteralComputedName(node)) {
-        value = ensureIdentifier(
-          flattenContext,
-          value,
-          /*reuseIdentifierExpressions*/
-          false,
-          location
-        );
-      } else if (needsValue) {
-        value = ensureIdentifier(
-          flattenContext,
-          value,
-          /*reuseIdentifierExpressions*/
-          true,
-          location
-        );
-      } else if (nodeIsSynthesized(node)) {
-        location = value;
-      }
-    }
-    flattenBindingOrAssignmentElement(
-      flattenContext,
-      node,
-      value,
-      location,
-      /*skipInitializer*/
-      isDestructuringAssignment(node)
-    );
-    if (value && needsValue) {
-      if (!some(expressions)) {
-        return value;
-      }
-      expressions.push(value);
-    }
-    return context.factory.inlineExpressions(expressions) || context.factory.createOmittedExpression();
-    function emitExpression(expression) {
-      expressions = append(expressions, expression);
-    }
-    function emitBindingOrAssignment(target, value2, location2, original) {
-      Debug.assertNode(target, createAssignmentCallback ? isIdentifier : isExpression);
-      const expression = createAssignmentCallback ? createAssignmentCallback(target, value2, location2) : setTextRange(
-        context.factory.createAssignment(Debug.checkDefined(visitNode(target, visitor, isExpression)), value2),
-        location2
-      );
-      expression.original = original;
-      emitExpression(expression);
-    }
-  }
-  function bindingOrAssignmentElementAssignsToName(element, escapedName) {
-    const target = getTargetOfBindingOrAssignmentElement(element);
-    if (isBindingOrAssignmentPattern(target)) {
-      return bindingOrAssignmentPatternAssignsToName(target, escapedName);
-    } else if (isIdentifier(target)) {
-      return target.escapedText === escapedName;
-    }
-    return false;
-  }
-  function bindingOrAssignmentPatternAssignsToName(pattern, escapedName) {
-    const elements = getElementsOfBindingOrAssignmentPattern(pattern);
-    for (const element of elements) {
-      if (bindingOrAssignmentElementAssignsToName(element, escapedName)) {
-        return true;
-      }
-    }
-    return false;
-  }
-  function bindingOrAssignmentElementContainsNonLiteralComputedName(element) {
-    const propertyName = tryGetPropertyNameOfBindingOrAssignmentElement(element);
-    if (propertyName && isComputedPropertyName(propertyName) && !isLiteralExpression(propertyName.expression)) {
-      return true;
-    }
-    const target = getTargetOfBindingOrAssignmentElement(element);
-    return !!target && isBindingOrAssignmentPattern(target) && bindingOrAssignmentPatternContainsNonLiteralComputedName(target);
-  }
-  function bindingOrAssignmentPatternContainsNonLiteralComputedName(pattern) {
-    return !!forEach(getElementsOfBindingOrAssignmentPattern(pattern), bindingOrAssignmentElementContainsNonLiteralComputedName);
-  }
-  function flattenDestructuringBinding(node, visitor, context, level, rval, hoistTempVariables = false, skipInitializer) {
-    let pendingExpressions;
-    const pendingDeclarations = [];
-    const declarations = [];
-    const flattenContext = {
-      context,
-      level,
-      downlevelIteration: !!context.getCompilerOptions().downlevelIteration,
-      hoistTempVariables,
-      emitExpression,
-      emitBindingOrAssignment,
-      createArrayBindingOrAssignmentPattern: (elements) => makeArrayBindingPattern(context.factory, elements),
-      createObjectBindingOrAssignmentPattern: (elements) => makeObjectBindingPattern(context.factory, elements),
-      createArrayBindingOrAssignmentElement: (name) => makeBindingElement(context.factory, name),
-      visitor
-    };
-    if (isVariableDeclaration(node)) {
-      let initializer = getInitializerOfBindingOrAssignmentElement(node);
-      if (initializer && (isIdentifier(initializer) && bindingOrAssignmentElementAssignsToName(node, initializer.escapedText) || bindingOrAssignmentElementContainsNonLiteralComputedName(node))) {
-        initializer = ensureIdentifier(
-          flattenContext,
-          Debug.checkDefined(visitNode(initializer, flattenContext.visitor, isExpression)),
-          /*reuseIdentifierExpressions*/
-          false,
-          initializer
-        );
-        node = context.factory.updateVariableDeclaration(
-          node,
-          node.name,
-          /*exclamationToken*/
-          void 0,
-          /*type*/
-          void 0,
-          initializer
-        );
-      }
-    }
-    flattenBindingOrAssignmentElement(flattenContext, node, rval, node, skipInitializer);
-    if (pendingExpressions) {
-      const temp = context.factory.createTempVariable(
-        /*recordTempVariable*/
-        void 0
-      );
-      if (hoistTempVariables) {
-        const value = context.factory.inlineExpressions(pendingExpressions);
-        pendingExpressions = void 0;
-        emitBindingOrAssignment(
-          temp,
-          value,
-          /*location*/
-          void 0,
-          /*original*/
-          void 0
-        );
-      } else {
-        context.hoistVariableDeclaration(temp);
-        const pendingDeclaration = last(pendingDeclarations);
-        pendingDeclaration.pendingExpressions = append(
-          pendingDeclaration.pendingExpressions,
-          context.factory.createAssignment(temp, pendingDeclaration.value)
-        );
-        addRange(pendingDeclaration.pendingExpressions, pendingExpressions);
-        pendingDeclaration.value = temp;
-      }
-    }
-    for (const { pendingExpressions: pendingExpressions2, name, value, location, original } of pendingDeclarations) {
-      const variable = context.factory.createVariableDeclaration(
-        name,
-        /*exclamationToken*/
-        void 0,
-        /*type*/
-        void 0,
-        pendingExpressions2 ? context.factory.inlineExpressions(append(pendingExpressions2, value)) : value
-      );
-      variable.original = original;
-      setTextRange(variable, location);
-      declarations.push(variable);
-    }
-    return declarations;
-    function emitExpression(value) {
-      pendingExpressions = append(pendingExpressions, value);
-    }
-    function emitBindingOrAssignment(target, value, location, original) {
-      Debug.assertNode(target, isBindingName);
-      if (pendingExpressions) {
-        value = context.factory.inlineExpressions(append(pendingExpressions, value));
-        pendingExpressions = void 0;
-      }
-      pendingDeclarations.push({ pendingExpressions, name: target, value, location, original });
-    }
-  }
-  function flattenBindingOrAssignmentElement(flattenContext, element, value, location, skipInitializer) {
-    const bindingTarget = getTargetOfBindingOrAssignmentElement(element);
-    if (!skipInitializer) {
-      const initializer = visitNode(getInitializerOfBindingOrAssignmentElement(element), flattenContext.visitor, isExpression);
-      if (initializer) {
-        if (value) {
-          value = createDefaultValueCheck(flattenContext, value, initializer, location);
-          if (!isSimpleInlineableExpression(initializer) && isBindingOrAssignmentPattern(bindingTarget)) {
-            value = ensureIdentifier(
-              flattenContext,
-              value,
-              /*reuseIdentifierExpressions*/
-              true,
-              location
-            );
-          }
-        } else {
-          value = initializer;
-        }
-      } else if (!value) {
-        value = flattenContext.context.factory.createVoidZero();
-      }
-    }
-    if (isObjectBindingOrAssignmentPattern(bindingTarget)) {
-      flattenObjectBindingOrAssignmentPattern(flattenContext, element, bindingTarget, value, location);
-    } else if (isArrayBindingOrAssignmentPattern(bindingTarget)) {
-      flattenArrayBindingOrAssignmentPattern(flattenContext, element, bindingTarget, value, location);
-    } else {
-      flattenContext.emitBindingOrAssignment(
-        bindingTarget,
-        value,
-        location,
-        /*original*/
-        element
-      );
-    }
-  }
-  function flattenObjectBindingOrAssignmentPattern(flattenContext, parent2, pattern, value, location) {
-    const elements = getElementsOfBindingOrAssignmentPattern(pattern);
-    const numElements = elements.length;
-    if (numElements !== 1) {
-      const reuseIdentifierExpressions = !isDeclarationBindingElement(parent2) || numElements !== 0;
-      value = ensureIdentifier(flattenContext, value, reuseIdentifierExpressions, location);
-    }
-    let bindingElements;
-    let computedTempVariables;
-    for (let i = 0; i < numElements; i++) {
-      const element = elements[i];
-      if (!getRestIndicatorOfBindingOrAssignmentElement(element)) {
-        const propertyName = getPropertyNameOfBindingOrAssignmentElement(element);
-        if (flattenContext.level >= 1 /* ObjectRest */ && !(element.transformFlags & (32768 /* ContainsRestOrSpread */ | 65536 /* ContainsObjectRestOrSpread */)) && !(getTargetOfBindingOrAssignmentElement(element).transformFlags & (32768 /* ContainsRestOrSpread */ | 65536 /* ContainsObjectRestOrSpread */)) && !isComputedPropertyName(propertyName)) {
-          bindingElements = append(bindingElements, visitNode(element, flattenContext.visitor, isBindingOrAssignmentElement));
-        } else {
-          if (bindingElements) {
-            flattenContext.emitBindingOrAssignment(flattenContext.createObjectBindingOrAssignmentPattern(bindingElements), value, location, pattern);
-            bindingElements = void 0;
-          }
-          const rhsValue = createDestructuringPropertyAccess(flattenContext, value, propertyName);
-          if (isComputedPropertyName(propertyName)) {
-            computedTempVariables = append(computedTempVariables, rhsValue.argumentExpression);
-          }
-          flattenBindingOrAssignmentElement(
-            flattenContext,
-            element,
-            rhsValue,
-            /*location*/
-            element
-          );
-        }
-      } else if (i === numElements - 1) {
-        if (bindingElements) {
-          flattenContext.emitBindingOrAssignment(flattenContext.createObjectBindingOrAssignmentPattern(bindingElements), value, location, pattern);
-          bindingElements = void 0;
-        }
-        const rhsValue = flattenContext.context.getEmitHelperFactory().createRestHelper(value, elements, computedTempVariables, pattern);
-        flattenBindingOrAssignmentElement(flattenContext, element, rhsValue, element);
-      }
-    }
-    if (bindingElements) {
-      flattenContext.emitBindingOrAssignment(flattenContext.createObjectBindingOrAssignmentPattern(bindingElements), value, location, pattern);
-    }
-  }
-  function flattenArrayBindingOrAssignmentPattern(flattenContext, parent2, pattern, value, location) {
-    const elements = getElementsOfBindingOrAssignmentPattern(pattern);
-    const numElements = elements.length;
-    if (flattenContext.level < 1 /* ObjectRest */ && flattenContext.downlevelIteration) {
-      value = ensureIdentifier(
-        flattenContext,
-        setTextRange(
-          flattenContext.context.getEmitHelperFactory().createReadHelper(
-            value,
-            numElements > 0 && getRestIndicatorOfBindingOrAssignmentElement(elements[numElements - 1]) ? void 0 : numElements
-          ),
-          location
-        ),
-        /*reuseIdentifierExpressions*/
-        false,
-        location
-      );
-    } else if (numElements !== 1 && (flattenContext.level < 1 /* ObjectRest */ || numElements === 0) || every(elements, isOmittedExpression)) {
-      const reuseIdentifierExpressions = !isDeclarationBindingElement(parent2) || numElements !== 0;
-      value = ensureIdentifier(flattenContext, value, reuseIdentifierExpressions, location);
-    }
-    let bindingElements;
-    let restContainingElements;
-    for (let i = 0; i < numElements; i++) {
-      const element = elements[i];
-      if (flattenContext.level >= 1 /* ObjectRest */) {
-        if (element.transformFlags & 65536 /* ContainsObjectRestOrSpread */ || flattenContext.hasTransformedPriorElement && !isSimpleBindingOrAssignmentElement(element)) {
-          flattenContext.hasTransformedPriorElement = true;
-          const temp = flattenContext.context.factory.createTempVariable(
-            /*recordTempVariable*/
-            void 0
-          );
-          if (flattenContext.hoistTempVariables) {
-            flattenContext.context.hoistVariableDeclaration(temp);
-          }
-          restContainingElements = append(restContainingElements, [temp, element]);
-          bindingElements = append(bindingElements, flattenContext.createArrayBindingOrAssignmentElement(temp));
-        } else {
-          bindingElements = append(bindingElements, element);
-        }
-      } else if (isOmittedExpression(element)) {
-        continue;
-      } else if (!getRestIndicatorOfBindingOrAssignmentElement(element)) {
-        const rhsValue = flattenContext.context.factory.createElementAccessExpression(value, i);
-        flattenBindingOrAssignmentElement(
-          flattenContext,
-          element,
-          rhsValue,
-          /*location*/
-          element
-        );
-      } else if (i === numElements - 1) {
-        const rhsValue = flattenContext.context.factory.createArraySliceCall(value, i);
-        flattenBindingOrAssignmentElement(
-          flattenContext,
-          element,
-          rhsValue,
-          /*location*/
-          element
-        );
-      }
-    }
-    if (bindingElements) {
-      flattenContext.emitBindingOrAssignment(flattenContext.createArrayBindingOrAssignmentPattern(bindingElements), value, location, pattern);
-    }
-    if (restContainingElements) {
-      for (const [id, element] of restContainingElements) {
-        flattenBindingOrAssignmentElement(flattenContext, element, id, element);
-      }
-    }
-  }
-  function isSimpleBindingOrAssignmentElement(element) {
-    const target = getTargetOfBindingOrAssignmentElement(element);
-    if (!target || isOmittedExpression(target))
-      return true;
-    const propertyName = tryGetPropertyNameOfBindingOrAssignmentElement(element);
-    if (propertyName && !isPropertyNameLiteral(propertyName))
-      return false;
-    const initializer = getInitializerOfBindingOrAssignmentElement(element);
-    if (initializer && !isSimpleInlineableExpression(initializer))
-      return false;
-    if (isBindingOrAssignmentPattern(target))
-      return every(getElementsOfBindingOrAssignmentPattern(target), isSimpleBindingOrAssignmentElement);
-    return isIdentifier(target);
-  }
-  function createDefaultValueCheck(flattenContext, value, defaultValue, location) {
-    value = ensureIdentifier(
-      flattenContext,
-      value,
-      /*reuseIdentifierExpressions*/
-      true,
-      location
-    );
-    return flattenContext.context.factory.createConditionalExpression(
-      flattenContext.context.factory.createTypeCheck(value, "undefined"),
-      /*questionToken*/
-      void 0,
-      defaultValue,
-      /*colonToken*/
-      void 0,
-      value
-    );
-  }
-  function createDestructuringPropertyAccess(flattenContext, value, propertyName) {
-    const { factory: factory2 } = flattenContext.context;
-    if (isComputedPropertyName(propertyName)) {
-      const argumentExpression = ensureIdentifier(
-        flattenContext,
-        Debug.checkDefined(visitNode(propertyName.expression, flattenContext.visitor, isExpression)),
-        /*reuseIdentifierExpressions*/
-        false,
-        /*location*/
-        propertyName
-      );
-      return flattenContext.context.factory.createElementAccessExpression(value, argumentExpression);
-    } else if (isStringOrNumericLiteralLike(propertyName)) {
-      const argumentExpression = factory2.cloneNode(propertyName);
-      return flattenContext.context.factory.createElementAccessExpression(value, argumentExpression);
-    } else {
-      const name = flattenContext.context.factory.createIdentifier(idText(propertyName));
-      return flattenContext.context.factory.createPropertyAccessExpression(value, name);
-    }
-  }
-  function ensureIdentifier(flattenContext, value, reuseIdentifierExpressions, location) {
-    if (isIdentifier(value) && reuseIdentifierExpressions) {
-      return value;
-    } else {
-      const temp = flattenContext.context.factory.createTempVariable(
-        /*recordTempVariable*/
-        void 0
-      );
-      if (flattenContext.hoistTempVariables) {
-        flattenContext.context.hoistVariableDeclaration(temp);
-        flattenContext.emitExpression(setTextRange(flattenContext.context.factory.createAssignment(temp, value), location));
-      } else {
-        flattenContext.emitBindingOrAssignment(
-          temp,
-          value,
-          location,
-          /*original*/
-          void 0
-        );
-      }
-      return temp;
-    }
-  }
-  function makeArrayBindingPattern(factory2, elements) {
-    Debug.assertEachNode(elements, isArrayBindingElement);
-    return factory2.createArrayBindingPattern(elements);
-  }
-  function makeArrayAssignmentPattern(factory2, elements) {
-    Debug.assertEachNode(elements, isArrayBindingOrAssignmentElement);
-    return factory2.createArrayLiteralExpression(map(elements, factory2.converters.convertToArrayAssignmentElement));
-  }
-  function makeObjectBindingPattern(factory2, elements) {
-    Debug.assertEachNode(elements, isBindingElement);
-    return factory2.createObjectBindingPattern(elements);
-  }
-  function makeObjectAssignmentPattern(factory2, elements) {
-    Debug.assertEachNode(elements, isObjectBindingOrAssignmentElement);
-    return factory2.createObjectLiteralExpression(map(elements, factory2.converters.convertToObjectAssignmentElement));
-  }
-  function makeBindingElement(factory2, name) {
-    return factory2.createBindingElement(
-      /*dotDotDotToken*/
-      void 0,
-      /*propertyName*/
-      void 0,
-      name
-    );
-  }
-  function makeAssignmentElement(name) {
-    return name;
-  }
-  var FlattenLevel;
-  var init_destructuring = __esm({
-    "src/compiler/transformers/destructuring.ts"() {
-      "use strict";
-      init_ts2();
-      FlattenLevel = /* @__PURE__ */ ((FlattenLevel2) => {
-        FlattenLevel2[FlattenLevel2["All"] = 0] = "All";
-        FlattenLevel2[FlattenLevel2["ObjectRest"] = 1] = "ObjectRest";
-        return FlattenLevel2;
-      })(FlattenLevel || {});
-    }
-  });
-
-  // src/compiler/transformers/taggedTemplate.ts
-  function processTaggedTemplateExpression(context, node, visitor, currentSourceFile, recordTaggedTemplateString, level) {
-    const tag = visitNode(node.tag, visitor, isExpression);
-    Debug.assert(tag);
-    const templateArguments = [void 0];
-    const cookedStrings = [];
-    const rawStrings = [];
-    const template = node.template;
-    if (level === 0 /* LiftRestriction */ && !hasInvalidEscape(template)) {
-      return visitEachChild(node, visitor, context);
-    }
-    const { factory: factory2 } = context;
-    if (isNoSubstitutionTemplateLiteral(template)) {
-      cookedStrings.push(createTemplateCooked(factory2, template));
-      rawStrings.push(getRawLiteral(factory2, template, currentSourceFile));
-    } else {
-      cookedStrings.push(createTemplateCooked(factory2, template.head));
-      rawStrings.push(getRawLiteral(factory2, template.head, currentSourceFile));
-      for (const templateSpan of template.templateSpans) {
-        cookedStrings.push(createTemplateCooked(factory2, templateSpan.literal));
-        rawStrings.push(getRawLiteral(factory2, templateSpan.literal, currentSourceFile));
-        templateArguments.push(Debug.checkDefined(visitNode(templateSpan.expression, visitor, isExpression)));
-      }
-    }
-    const helperCall = context.getEmitHelperFactory().createTemplateObjectHelper(
-      factory2.createArrayLiteralExpression(cookedStrings),
-      factory2.createArrayLiteralExpression(rawStrings)
-    );
-    if (isExternalModule(currentSourceFile)) {
-      const tempVar = factory2.createUniqueName("templateObject");
-      recordTaggedTemplateString(tempVar);
-      templateArguments[0] = factory2.createLogicalOr(
-        tempVar,
-        factory2.createAssignment(
-          tempVar,
-          helperCall
-        )
-      );
-    } else {
-      templateArguments[0] = helperCall;
-    }
-    return factory2.createCallExpression(
-      tag,
-      /*typeArguments*/
-      void 0,
-      templateArguments
-    );
-  }
-  function createTemplateCooked(factory2, template) {
-    return template.templateFlags & 26656 /* IsInvalid */ ? factory2.createVoidZero() : factory2.createStringLiteral(template.text);
-  }
-  function getRawLiteral(factory2, node, currentSourceFile) {
-    let text = node.rawText;
-    if (text === void 0) {
-      Debug.assertIsDefined(
-        currentSourceFile,
-        "Template literal node is missing 'rawText' and does not have a source file. Possibly bad transform."
-      );
-      text = getSourceTextOfNodeFromSourceFile(currentSourceFile, node);
-      const isLast = node.kind === 15 /* NoSubstitutionTemplateLiteral */ || node.kind === 18 /* TemplateTail */;
-      text = text.substring(1, text.length - (isLast ? 1 : 2));
-    }
-    text = text.replace(/\r\n?/g, "\n");
-    return setTextRange(factory2.createStringLiteral(text), node);
-  }
-  var ProcessLevel;
-  var init_taggedTemplate = __esm({
-    "src/compiler/transformers/taggedTemplate.ts"() {
-      "use strict";
-      init_ts2();
-      ProcessLevel = /* @__PURE__ */ ((ProcessLevel2) => {
-        ProcessLevel2[ProcessLevel2["LiftRestriction"] = 0] = "LiftRestriction";
-        ProcessLevel2[ProcessLevel2["All"] = 1] = "All";
-        return ProcessLevel2;
-      })(ProcessLevel || {});
-    }
-  });
-
-  // src/compiler/transformers/ts.ts
-  function transformTypeScript(context) {
-    const {
-      factory: factory2,
-      getEmitHelperFactory: emitHelpers,
-      startLexicalEnvironment,
-      resumeLexicalEnvironment,
-      endLexicalEnvironment,
-      hoistVariableDeclaration
-    } = context;
-    const resolver = context.getEmitResolver();
-    const compilerOptions = context.getCompilerOptions();
-    const languageVersion = getEmitScriptTarget(compilerOptions);
-    const moduleKind = getEmitModuleKind(compilerOptions);
-    const legacyDecorators = !!compilerOptions.experimentalDecorators;
-    const typeSerializer = compilerOptions.emitDecoratorMetadata ? createRuntimeTypeSerializer(context) : void 0;
-    const previousOnEmitNode = context.onEmitNode;
-    const previousOnSubstituteNode = context.onSubstituteNode;
-    context.onEmitNode = onEmitNode;
-    context.onSubstituteNode = onSubstituteNode;
-    context.enableSubstitution(210 /* PropertyAccessExpression */);
-    context.enableSubstitution(211 /* ElementAccessExpression */);
-    let currentSourceFile;
-    let currentNamespace;
-    let currentNamespaceContainerName;
-    let currentLexicalScope;
-    let currentScopeFirstDeclarationsOfName;
-    let currentClassHasParameterProperties;
-    let enabledSubstitutions;
-    let applicableSubstitutions;
-    return transformSourceFileOrBundle;
-    function transformSourceFileOrBundle(node) {
-      if (node.kind === 312 /* Bundle */) {
-        return transformBundle(node);
-      }
-      return transformSourceFile(node);
-    }
-    function transformBundle(node) {
-      return factory2.createBundle(node.sourceFiles.map(transformSourceFile), mapDefined(node.prepends, (prepend) => {
-        if (prepend.kind === 314 /* InputFiles */) {
-          return createUnparsedSourceFile(prepend, "js");
-        }
-        return prepend;
-      }));
-    }
-    function transformSourceFile(node) {
-      if (node.isDeclarationFile) {
-        return node;
-      }
-      currentSourceFile = node;
-      const visited = saveStateAndInvoke(node, visitSourceFile);
-      addEmitHelpers(visited, context.readEmitHelpers());
-      currentSourceFile = void 0;
-      return visited;
-    }
-    function saveStateAndInvoke(node, f) {
-      const savedCurrentScope = currentLexicalScope;
-      const savedCurrentScopeFirstDeclarationsOfName = currentScopeFirstDeclarationsOfName;
-      const savedCurrentClassHasParameterProperties = currentClassHasParameterProperties;
-      onBeforeVisitNode(node);
-      const visited = f(node);
-      if (currentLexicalScope !== savedCurrentScope) {
-        currentScopeFirstDeclarationsOfName = savedCurrentScopeFirstDeclarationsOfName;
-      }
-      currentLexicalScope = savedCurrentScope;
-      currentClassHasParameterProperties = savedCurrentClassHasParameterProperties;
-      return visited;
-    }
-    function onBeforeVisitNode(node) {
-      switch (node.kind) {
-        case 311 /* SourceFile */:
-        case 268 /* CaseBlock */:
-        case 267 /* ModuleBlock */:
-        case 240 /* Block */:
-          currentLexicalScope = node;
-          currentScopeFirstDeclarationsOfName = void 0;
-          break;
-        case 262 /* ClassDeclaration */:
-        case 261 /* FunctionDeclaration */:
-          if (hasSyntacticModifier(node, 2 /* Ambient */)) {
-            break;
-          }
-          if (node.name) {
-            recordEmittedDeclarationInScope(node);
-          } else {
-            Debug.assert(node.kind === 262 /* ClassDeclaration */ || hasSyntacticModifier(node, 1024 /* Default */));
-          }
-          break;
-      }
-    }
-    function visitor(node) {
-      return saveStateAndInvoke(node, visitorWorker);
-    }
-    function visitorWorker(node) {
-      if (node.transformFlags & 1 /* ContainsTypeScript */) {
-        return visitTypeScript(node);
-      }
-      return node;
-    }
-    function sourceElementVisitor(node) {
-      return saveStateAndInvoke(node, sourceElementVisitorWorker);
-    }
-    function sourceElementVisitorWorker(node) {
-      switch (node.kind) {
-        case 271 /* ImportDeclaration */:
-        case 270 /* ImportEqualsDeclaration */:
-        case 276 /* ExportAssignment */:
-        case 277 /* ExportDeclaration */:
-          return visitElidableStatement(node);
-        default:
-          return visitorWorker(node);
-      }
-    }
-    function visitElidableStatement(node) {
-      const parsed = getParseTreeNode(node);
-      if (parsed !== node) {
-        if (node.transformFlags & 1 /* ContainsTypeScript */) {
-          return visitEachChild(node, visitor, context);
-        }
-        return node;
-      }
-      switch (node.kind) {
-        case 271 /* ImportDeclaration */:
-          return visitImportDeclaration(node);
-        case 270 /* ImportEqualsDeclaration */:
-          return visitImportEqualsDeclaration(node);
-        case 276 /* ExportAssignment */:
-          return visitExportAssignment(node);
-        case 277 /* ExportDeclaration */:
-          return visitExportDeclaration(node);
-        default:
-          Debug.fail("Unhandled ellided statement");
-      }
-    }
-    function namespaceElementVisitor(node) {
-      return saveStateAndInvoke(node, namespaceElementVisitorWorker);
-    }
-    function namespaceElementVisitorWorker(node) {
-      if (node.kind === 277 /* ExportDeclaration */ || node.kind === 271 /* ImportDeclaration */ || node.kind === 272 /* ImportClause */ || node.kind === 270 /* ImportEqualsDeclaration */ && node.moduleReference.kind === 282 /* ExternalModuleReference */) {
-        return void 0;
-      } else if (node.transformFlags & 1 /* ContainsTypeScript */ || hasSyntacticModifier(node, 1 /* Export */)) {
-        return visitTypeScript(node);
-      }
-      return node;
-    }
-    function getClassElementVisitor(parent2) {
-      return (node) => saveStateAndInvoke(node, (n) => classElementVisitorWorker(n, parent2));
-    }
-    function classElementVisitorWorker(node, parent2) {
-      switch (node.kind) {
-        case 175 /* Constructor */:
-          return visitConstructor(node);
-        case 171 /* PropertyDeclaration */:
-          return visitPropertyDeclaration(node, parent2);
-        case 176 /* GetAccessor */:
-          return visitGetAccessor(node, parent2);
-        case 177 /* SetAccessor */:
-          return visitSetAccessor(node, parent2);
-        case 173 /* MethodDeclaration */:
-          return visitMethodDeclaration(node, parent2);
-        case 174 /* ClassStaticBlockDeclaration */:
-          return visitEachChild(node, visitor, context);
-        case 239 /* SemicolonClassElement */:
-          return node;
-        case 180 /* IndexSignature */:
-          return;
-        default:
-          return Debug.failBadSyntaxKind(node);
-      }
-    }
-    function getObjectLiteralElementVisitor(parent2) {
-      return (node) => saveStateAndInvoke(node, (n) => objectLiteralElementVisitorWorker(n, parent2));
-    }
-    function objectLiteralElementVisitorWorker(node, parent2) {
-      switch (node.kind) {
-        case 302 /* PropertyAssignment */:
-        case 303 /* ShorthandPropertyAssignment */:
-        case 304 /* SpreadAssignment */:
-          return visitor(node);
-        case 176 /* GetAccessor */:
-          return visitGetAccessor(node, parent2);
-        case 177 /* SetAccessor */:
-          return visitSetAccessor(node, parent2);
-        case 173 /* MethodDeclaration */:
-          return visitMethodDeclaration(node, parent2);
-        default:
-          return Debug.failBadSyntaxKind(node);
-      }
-    }
-    function decoratorElidingVisitor(node) {
-      return isDecorator(node) ? void 0 : visitor(node);
-    }
-    function modifierElidingVisitor(node) {
-      return isModifier(node) ? void 0 : visitor(node);
-    }
-    function modifierVisitor(node) {
-      if (isDecorator(node))
-        return void 0;
-      if (modifierToFlag(node.kind) & 117086 /* TypeScriptModifier */) {
-        return void 0;
-      } else if (currentNamespace && node.kind === 95 /* ExportKeyword */) {
-        return void 0;
-      }
-      return node;
-    }
-    function visitTypeScript(node) {
-      if (isStatement(node) && hasSyntacticModifier(node, 2 /* Ambient */)) {
-        return factory2.createNotEmittedStatement(node);
-      }
-      switch (node.kind) {
-        case 95 /* ExportKeyword */:
-        case 90 /* DefaultKeyword */:
-          return currentNamespace ? void 0 : node;
-        case 125 /* PublicKeyword */:
-        case 123 /* PrivateKeyword */:
-        case 124 /* ProtectedKeyword */:
-        case 128 /* AbstractKeyword */:
-        case 163 /* OverrideKeyword */:
-        case 87 /* ConstKeyword */:
-        case 138 /* DeclareKeyword */:
-        case 148 /* ReadonlyKeyword */:
-        case 103 /* InKeyword */:
-        case 147 /* OutKeyword */:
-        case 187 /* ArrayType */:
-        case 188 /* TupleType */:
-        case 189 /* OptionalType */:
-        case 190 /* RestType */:
-        case 186 /* TypeLiteral */:
-        case 181 /* TypePredicate */:
-        case 167 /* TypeParameter */:
-        case 133 /* AnyKeyword */:
-        case 159 /* UnknownKeyword */:
-        case 136 /* BooleanKeyword */:
-        case 154 /* StringKeyword */:
-        case 150 /* NumberKeyword */:
-        case 146 /* NeverKeyword */:
-        case 116 /* VoidKeyword */:
-        case 155 /* SymbolKeyword */:
-        case 184 /* ConstructorType */:
-        case 183 /* FunctionType */:
-        case 185 /* TypeQuery */:
-        case 182 /* TypeReference */:
-        case 191 /* UnionType */:
-        case 192 /* IntersectionType */:
-        case 193 /* ConditionalType */:
-        case 195 /* ParenthesizedType */:
-        case 196 /* ThisType */:
-        case 197 /* TypeOperator */:
-        case 198 /* IndexedAccessType */:
-        case 199 /* MappedType */:
-        case 200 /* LiteralType */:
-        case 180 /* IndexSignature */:
-          return void 0;
-        case 264 /* TypeAliasDeclaration */:
-          return factory2.createNotEmittedStatement(node);
-        case 269 /* NamespaceExportDeclaration */:
-          return void 0;
-        case 263 /* InterfaceDeclaration */:
-          return factory2.createNotEmittedStatement(node);
-        case 262 /* ClassDeclaration */:
-          return visitClassDeclaration(node);
-        case 230 /* ClassExpression */:
-          return visitClassExpression(node);
-        case 297 /* HeritageClause */:
-          return visitHeritageClause(node);
-        case 232 /* ExpressionWithTypeArguments */:
-          return visitExpressionWithTypeArguments(node);
-        case 209 /* ObjectLiteralExpression */:
-          return visitObjectLiteralExpression(node);
-        case 175 /* Constructor */:
-        case 171 /* PropertyDeclaration */:
-        case 173 /* MethodDeclaration */:
-        case 176 /* GetAccessor */:
-        case 177 /* SetAccessor */:
-        case 174 /* ClassStaticBlockDeclaration */:
-          return Debug.fail("Class and object literal elements must be visited with their respective visitors");
-        case 261 /* FunctionDeclaration */:
-          return visitFunctionDeclaration(node);
-        case 217 /* FunctionExpression */:
-          return visitFunctionExpression(node);
-        case 218 /* ArrowFunction */:
-          return visitArrowFunction(node);
-        case 168 /* Parameter */:
-          return visitParameter(node);
-        case 216 /* ParenthesizedExpression */:
-          return visitParenthesizedExpression(node);
-        case 215 /* TypeAssertionExpression */:
-        case 233 /* AsExpression */:
-          return visitAssertionExpression(node);
-        case 237 /* SatisfiesExpression */:
-          return visitSatisfiesExpression(node);
-        case 212 /* CallExpression */:
-          return visitCallExpression(node);
-        case 213 /* NewExpression */:
-          return visitNewExpression(node);
-        case 214 /* TaggedTemplateExpression */:
-          return visitTaggedTemplateExpression(node);
-        case 234 /* NonNullExpression */:
-          return visitNonNullExpression(node);
-        case 265 /* EnumDeclaration */:
-          return visitEnumDeclaration(node);
-        case 242 /* VariableStatement */:
-          return visitVariableStatement(node);
-        case 259 /* VariableDeclaration */:
-          return visitVariableDeclaration(node);
-        case 266 /* ModuleDeclaration */:
-          return visitModuleDeclaration(node);
-        case 270 /* ImportEqualsDeclaration */:
-          return visitImportEqualsDeclaration(node);
-        case 284 /* JsxSelfClosingElement */:
-          return visitJsxSelfClosingElement(node);
-        case 285 /* JsxOpeningElement */:
-          return visitJsxJsxOpeningElement(node);
-        default:
-          return visitEachChild(node, visitor, context);
-      }
-    }
-    function visitSourceFile(node) {
-      const alwaysStrict = getStrictOptionValue(compilerOptions, "alwaysStrict") && !(isExternalModule(node) && moduleKind >= 5 /* ES2015 */) && !isJsonSourceFile(node);
-      return factory2.updateSourceFile(
-        node,
-        visitLexicalEnvironment(
-          node.statements,
-          sourceElementVisitor,
-          context,
-          /*start*/
-          0,
-          alwaysStrict
-        )
-      );
-    }
-    function visitObjectLiteralExpression(node) {
-      return factory2.updateObjectLiteralExpression(
-        node,
-        visitNodes2(node.properties, getObjectLiteralElementVisitor(node), isObjectLiteralElementLike)
-      );
-    }
-    function getClassFacts(node) {
-      let facts = 0 /* None */;
-      if (some(getProperties(
-        node,
-        /*requireInitializer*/
-        true,
-        /*isStatic*/
-        true
-      )))
-        facts |= 1 /* HasStaticInitializedProperties */;
-      const extendsClauseElement = getEffectiveBaseTypeNode(node);
-      if (extendsClauseElement && skipOuterExpressions(extendsClauseElement.expression).kind !== 106 /* NullKeyword */)
-        facts |= 64 /* IsDerivedClass */;
-      if (classOrConstructorParameterIsDecorated(legacyDecorators, node))
-        facts |= 2 /* HasClassOrConstructorParameterDecorators */;
-      if (childIsDecorated(legacyDecorators, node))
-        facts |= 4 /* HasMemberDecorators */;
-      if (isExportOfNamespace(node))
-        facts |= 8 /* IsExportOfNamespace */;
-      else if (isDefaultExternalModuleExport(node))
-        facts |= 32 /* IsDefaultExternalExport */;
-      else if (isNamedExternalModuleExport(node))
-        facts |= 16 /* IsNamedExternalExport */;
-      return facts;
-    }
-    function hasTypeScriptClassSyntax(node) {
-      return !!(node.transformFlags & 8192 /* ContainsTypeScriptClassSyntax */);
-    }
-    function isClassLikeDeclarationWithTypeScriptSyntax(node) {
-      return hasDecorators(node) || some(node.typeParameters) || some(node.heritageClauses, hasTypeScriptClassSyntax) || some(node.members, hasTypeScriptClassSyntax);
-    }
-    function visitClassDeclaration(node) {
-      const facts = getClassFacts(node);
-      const promoteToIIFE = languageVersion <= 1 /* ES5 */ && !!(facts & 7 /* MayNeedImmediatelyInvokedFunctionExpression */);
-      if (!isClassLikeDeclarationWithTypeScriptSyntax(node) && !classOrConstructorParameterIsDecorated(legacyDecorators, node) && !isExportOfNamespace(node)) {
-        return factory2.updateClassDeclaration(
-          node,
-          visitNodes2(node.modifiers, modifierVisitor, isModifier),
-          node.name,
-          /*typeParameters*/
-          void 0,
-          visitNodes2(node.heritageClauses, visitor, isHeritageClause),
-          visitNodes2(node.members, getClassElementVisitor(node), isClassElement)
-        );
-      }
-      if (promoteToIIFE) {
-        context.startLexicalEnvironment();
-      }
-      const moveModifiers = promoteToIIFE || facts & 8 /* IsExportOfNamespace */;
-      let modifiers = moveModifiers ? visitNodes2(node.modifiers, modifierElidingVisitor, isModifierLike) : visitNodes2(node.modifiers, visitor, isModifierLike);
-      if (facts & 2 /* HasClassOrConstructorParameterDecorators */) {
-        modifiers = injectClassTypeMetadata(modifiers, node);
-      }
-      const needsName = moveModifiers && !node.name || facts & 4 /* HasMemberDecorators */ || facts & 1 /* HasStaticInitializedProperties */;
-      const name = needsName ? node.name ?? factory2.getGeneratedNameForNode(node) : node.name;
-      const classDeclaration = factory2.updateClassDeclaration(
-        node,
-        modifiers,
-        name,
-        /*typeParameters*/
-        void 0,
-        visitNodes2(node.heritageClauses, visitor, isHeritageClause),
-        transformClassMembers(node)
-      );
-      let emitFlags = getEmitFlags(node);
-      if (facts & 1 /* HasStaticInitializedProperties */) {
-        emitFlags |= 64 /* NoTrailingSourceMap */;
-      }
-      setEmitFlags(classDeclaration, emitFlags);
-      let statement;
-      if (promoteToIIFE) {
-        const statements = [classDeclaration];
-        const closingBraceLocation = createTokenRange(skipTrivia(currentSourceFile.text, node.members.end), 20 /* CloseBraceToken */);
-        const localName = factory2.getInternalName(node);
-        const outer = factory2.createPartiallyEmittedExpression(localName);
-        setTextRangeEnd(outer, closingBraceLocation.end);
-        setEmitFlags(outer, 3072 /* NoComments */);
-        const returnStatement = factory2.createReturnStatement(outer);
-        setTextRangePos(returnStatement, closingBraceLocation.pos);
-        setEmitFlags(returnStatement, 3072 /* NoComments */ | 768 /* NoTokenSourceMaps */);
-        statements.push(returnStatement);
-        insertStatementsAfterStandardPrologue(statements, context.endLexicalEnvironment());
-        const iife = factory2.createImmediatelyInvokedArrowFunction(statements);
-        setInternalEmitFlags(iife, 1 /* TypeScriptClassWrapper */);
-        const modifiers2 = facts & 16 /* IsNamedExternalExport */ ? factory2.createModifiersFromModifierFlags(1 /* Export */) : void 0;
-        const varStatement = factory2.createVariableStatement(
-          modifiers2,
-          factory2.createVariableDeclarationList([
-            factory2.createVariableDeclaration(
-              factory2.getLocalName(
-                node,
-                /*allowComments*/
-                false,
-                /*allowSourceMaps*/
-                false
-              ),
-              /*exclamationToken*/
-              void 0,
-              /*type*/
-              void 0,
-              iife
-            )
-          ], 1 /* Let */)
-        );
-        setOriginalNode(varStatement, node);
-        setCommentRange(varStatement, node);
-        setSourceMapRange(varStatement, moveRangePastDecorators(node));
-        startOnNewLine(varStatement);
-        statement = varStatement;
-      } else {
-        statement = classDeclaration;
-      }
-      if (moveModifiers) {
-        if (facts & 8 /* IsExportOfNamespace */) {
-          return [
-            statement,
-            createExportMemberAssignmentStatement(node)
-          ];
-        }
-        if (facts & 32 /* IsDefaultExternalExport */) {
-          return [
-            statement,
-            factory2.createExportDefault(factory2.getLocalName(
-              node,
-              /*allowComments*/
-              false,
-              /*allowSourceMaps*/
-              true
-            ))
-          ];
-        }
-        if (facts & 16 /* IsNamedExternalExport */ && !promoteToIIFE) {
-          return [
-            statement,
-            factory2.createExternalModuleExport(factory2.getLocalName(
-              node,
-              /*allowComments*/
-              false,
-              /*allowSourceMaps*/
-              true
-            ))
-          ];
-        }
-      }
-      return statement;
-    }
-    function visitClassExpression(node) {
-      let modifiers = visitNodes2(node.modifiers, modifierElidingVisitor, isModifierLike);
-      if (classOrConstructorParameterIsDecorated(legacyDecorators, node)) {
-        modifiers = injectClassTypeMetadata(modifiers, node);
-      }
-      return factory2.updateClassExpression(
-        node,
-        modifiers,
-        node.name,
-        /*typeParameters*/
-        void 0,
-        visitNodes2(node.heritageClauses, visitor, isHeritageClause),
-        transformClassMembers(node)
-      );
-    }
-    function transformClassMembers(node) {
-      const members = visitNodes2(node.members, getClassElementVisitor(node), isClassElement);
-      let newMembers;
-      const constructor = getFirstConstructorWithBody(node);
-      const parametersWithPropertyAssignments = constructor && filter(constructor.parameters, (p) => isParameterPropertyDeclaration(p, constructor));
-      if (parametersWithPropertyAssignments) {
-        for (const parameter of parametersWithPropertyAssignments) {
-          const parameterProperty = factory2.createPropertyDeclaration(
-            /*modifiers*/
-            void 0,
-            parameter.name,
-            /*questionOrExclamationToken*/
-            void 0,
-            /*type*/
-            void 0,
-            /*initializer*/
-            void 0
-          );
-          setOriginalNode(parameterProperty, parameter);
-          newMembers = append(newMembers, parameterProperty);
-        }
-      }
-      if (newMembers) {
-        newMembers = addRange(newMembers, members);
-        return setTextRange(
-          factory2.createNodeArray(newMembers),
-          /*location*/
-          node.members
-        );
-      }
-      return members;
-    }
-    function injectClassTypeMetadata(modifiers, node) {
-      const metadata = getTypeMetadata(node, node);
-      if (some(metadata)) {
-        const modifiersArray = [];
-        addRange(modifiersArray, takeWhile(modifiers, isExportOrDefaultModifier));
-        addRange(modifiersArray, filter(modifiers, isDecorator));
-        addRange(modifiersArray, metadata);
-        addRange(modifiersArray, filter(skipWhile(modifiers, isExportOrDefaultModifier), isModifier));
-        modifiers = setTextRange(factory2.createNodeArray(modifiersArray), modifiers);
-      }
-      return modifiers;
-    }
-    function injectClassElementTypeMetadata(modifiers, node, container) {
-      if (isClassLike(container) && classElementOrClassElementParameterIsDecorated(legacyDecorators, node, container)) {
-        const metadata = getTypeMetadata(node, container);
-        if (some(metadata)) {
-          const modifiersArray = [];
-          addRange(modifiersArray, filter(modifiers, isDecorator));
-          addRange(modifiersArray, metadata);
-          addRange(modifiersArray, filter(modifiers, isModifier));
-          modifiers = setTextRange(factory2.createNodeArray(modifiersArray), modifiers);
-        }
-      }
-      return modifiers;
-    }
-    function getTypeMetadata(node, container) {
-      if (!legacyDecorators)
-        return void 0;
-      return USE_NEW_TYPE_METADATA_FORMAT ? getNewTypeMetadata(node, container) : getOldTypeMetadata(node, container);
-    }
-    function getOldTypeMetadata(node, container) {
-      if (typeSerializer) {
-        let decorators;
-        if (shouldAddTypeMetadata(node)) {
-          const typeMetadata = emitHelpers().createMetadataHelper("design:type", typeSerializer.serializeTypeOfNode({ currentLexicalScope, currentNameScope: container }, node));
-          decorators = append(decorators, factory2.createDecorator(typeMetadata));
-        }
-        if (shouldAddParamTypesMetadata(node)) {
-          const paramTypesMetadata = emitHelpers().createMetadataHelper("design:paramtypes", typeSerializer.serializeParameterTypesOfNode({ currentLexicalScope, currentNameScope: container }, node, container));
-          decorators = append(decorators, factory2.createDecorator(paramTypesMetadata));
-        }
-        if (shouldAddReturnTypeMetadata(node)) {
-          const returnTypeMetadata = emitHelpers().createMetadataHelper("design:returntype", typeSerializer.serializeReturnTypeOfNode({ currentLexicalScope, currentNameScope: container }, node));
-          decorators = append(decorators, factory2.createDecorator(returnTypeMetadata));
-        }
-        return decorators;
-      }
-    }
-    function getNewTypeMetadata(node, container) {
-      if (typeSerializer) {
-        let properties;
-        if (shouldAddTypeMetadata(node)) {
-          const typeProperty = factory2.createPropertyAssignment("type", factory2.createArrowFunction(
-            /*modifiers*/
-            void 0,
-            /*typeParameters*/
-            void 0,
-            [],
-            /*type*/
-            void 0,
-            factory2.createToken(39 /* EqualsGreaterThanToken */),
-            typeSerializer.serializeTypeOfNode({ currentLexicalScope, currentNameScope: container }, node)
-          ));
-          properties = append(properties, typeProperty);
-        }
-        if (shouldAddParamTypesMetadata(node)) {
-          const paramTypeProperty = factory2.createPropertyAssignment("paramTypes", factory2.createArrowFunction(
-            /*modifiers*/
-            void 0,
-            /*typeParameters*/
-            void 0,
-            [],
-            /*type*/
-            void 0,
-            factory2.createToken(39 /* EqualsGreaterThanToken */),
-            typeSerializer.serializeParameterTypesOfNode({ currentLexicalScope, currentNameScope: container }, node, container)
-          ));
-          properties = append(properties, paramTypeProperty);
-        }
-        if (shouldAddReturnTypeMetadata(node)) {
-          const returnTypeProperty = factory2.createPropertyAssignment("returnType", factory2.createArrowFunction(
-            /*modifiers*/
-            void 0,
-            /*typeParameters*/
-            void 0,
-            [],
-            /*type*/
-            void 0,
-            factory2.createToken(39 /* EqualsGreaterThanToken */),
-            typeSerializer.serializeReturnTypeOfNode({ currentLexicalScope, currentNameScope: container }, node)
-          ));
-          properties = append(properties, returnTypeProperty);
-        }
-        if (properties) {
-          const typeInfoMetadata = emitHelpers().createMetadataHelper("design:typeinfo", factory2.createObjectLiteralExpression(
-            properties,
-            /*multiLine*/
-            true
-          ));
-          return [factory2.createDecorator(typeInfoMetadata)];
-        }
-      }
-    }
-    function shouldAddTypeMetadata(node) {
-      const kind = node.kind;
-      return kind === 173 /* MethodDeclaration */ || kind === 176 /* GetAccessor */ || kind === 177 /* SetAccessor */ || kind === 171 /* PropertyDeclaration */;
-    }
-    function shouldAddReturnTypeMetadata(node) {
-      return node.kind === 173 /* MethodDeclaration */;
-    }
-    function shouldAddParamTypesMetadata(node) {
-      switch (node.kind) {
-        case 262 /* ClassDeclaration */:
-        case 230 /* ClassExpression */:
-          return getFirstConstructorWithBody(node) !== void 0;
-        case 173 /* MethodDeclaration */:
-        case 176 /* GetAccessor */:
-        case 177 /* SetAccessor */:
-          return true;
-      }
-      return false;
-    }
-    function getExpressionForPropertyName(member, generateNameForComputedPropertyName) {
-      const name = member.name;
-      if (isPrivateIdentifier(name)) {
-        return factory2.createIdentifier("");
-      } else if (isComputedPropertyName(name)) {
-        return generateNameForComputedPropertyName && !isSimpleInlineableExpression(name.expression) ? factory2.getGeneratedNameForNode(name) : name.expression;
-      } else if (isIdentifier(name)) {
-        return factory2.createStringLiteral(idText(name));
-      } else {
-        return factory2.cloneNode(name);
-      }
-    }
-    function visitPropertyNameOfClassElement(member) {
-      const name = member.name;
-      if (isComputedPropertyName(name) && (!hasStaticModifier(member) && currentClassHasParameterProperties || hasDecorators(member) && legacyDecorators)) {
-        const expression = visitNode(name.expression, visitor, isExpression);
-        Debug.assert(expression);
-        const innerExpression = skipPartiallyEmittedExpressions(expression);
-        if (!isSimpleInlineableExpression(innerExpression)) {
-          const generatedName = factory2.getGeneratedNameForNode(name);
-          hoistVariableDeclaration(generatedName);
-          return factory2.updateComputedPropertyName(name, factory2.createAssignment(generatedName, expression));
-        }
-      }
-      return Debug.checkDefined(visitNode(name, visitor, isPropertyName));
-    }
-    function visitHeritageClause(node) {
-      if (node.token === 119 /* ImplementsKeyword */) {
-        return void 0;
-      }
-      return visitEachChild(node, visitor, context);
-    }
-    function visitExpressionWithTypeArguments(node) {
-      return factory2.updateExpressionWithTypeArguments(
-        node,
-        Debug.checkDefined(visitNode(node.expression, visitor, isLeftHandSideExpression)),
-        /*typeArguments*/
-        void 0
-      );
-    }
-    function shouldEmitFunctionLikeDeclaration(node) {
-      return !nodeIsMissing(node.body);
-    }
-    function visitPropertyDeclaration(node, parent2) {
-      const isAmbient = node.flags & 16777216 /* Ambient */ || hasSyntacticModifier(node, 256 /* Abstract */);
-      if (isAmbient && !(legacyDecorators && hasDecorators(node))) {
-        return void 0;
-      }
-      let modifiers = isClassLike(parent2) ? !isAmbient ? visitNodes2(node.modifiers, visitor, isModifierLike) : visitNodes2(node.modifiers, modifierElidingVisitor, isModifierLike) : visitNodes2(node.modifiers, decoratorElidingVisitor, isModifierLike);
-      modifiers = injectClassElementTypeMetadata(modifiers, node, parent2);
-      if (isAmbient) {
-        return factory2.updatePropertyDeclaration(
-          node,
-          concatenate(modifiers, factory2.createModifiersFromModifierFlags(2 /* Ambient */)),
-          Debug.checkDefined(visitNode(node.name, visitor, isPropertyName)),
-          /*questionOrExclamationToken*/
-          void 0,
-          /*type*/
-          void 0,
-          /*initializer*/
-          void 0
-        );
-      }
-      return factory2.updatePropertyDeclaration(
-        node,
-        modifiers,
-        visitPropertyNameOfClassElement(node),
-        /*questionOrExclamationToken*/
-        void 0,
-        /*type*/
-        void 0,
-        visitNode(node.initializer, visitor, isExpression)
-      );
-    }
-    function visitConstructor(node) {
-      if (!shouldEmitFunctionLikeDeclaration(node)) {
-        return void 0;
-      }
-      return factory2.updateConstructorDeclaration(
-        node,
-        /*modifiers*/
-        void 0,
-        visitParameterList(node.parameters, visitor, context),
-        transformConstructorBody(node.body, node)
-      );
-    }
-    function transformConstructorBody(body, constructor) {
-      const parametersWithPropertyAssignments = constructor && filter(constructor.parameters, (p) => isParameterPropertyDeclaration(p, constructor));
-      if (!some(parametersWithPropertyAssignments)) {
-        return visitFunctionBody(body, visitor, context);
-      }
-      let statements = [];
-      resumeLexicalEnvironment();
-      const prologueStatementCount = factory2.copyPrologue(
-        body.statements,
-        statements,
-        /*ensureUseStrict*/
-        false,
-        visitor
-      );
-      const superStatementIndex = findSuperStatementIndex(body.statements, prologueStatementCount);
-      if (superStatementIndex >= 0) {
-        addRange(
-          statements,
-          visitNodes2(body.statements, visitor, isStatement, prologueStatementCount, superStatementIndex + 1 - prologueStatementCount)
-        );
-      }
-      const parameterPropertyAssignments = mapDefined(parametersWithPropertyAssignments, transformParameterWithPropertyAssignment);
-      if (superStatementIndex >= 0) {
-        addRange(statements, parameterPropertyAssignments);
-      } else {
-        statements = [
-          ...statements.slice(0, prologueStatementCount),
-          ...parameterPropertyAssignments,
-          ...statements.slice(prologueStatementCount)
-        ];
-      }
-      const start = superStatementIndex >= 0 ? superStatementIndex + 1 : prologueStatementCount;
-      addRange(statements, visitNodes2(body.statements, visitor, isStatement, start));
-      statements = factory2.mergeLexicalEnvironment(statements, endLexicalEnvironment());
-      const block = factory2.createBlock(
-        setTextRange(factory2.createNodeArray(statements), body.statements),
-        /*multiLine*/
-        true
-      );
-      setTextRange(
-        block,
-        /*location*/
-        body
-      );
-      setOriginalNode(block, body);
-      return block;
-    }
-    function transformParameterWithPropertyAssignment(node) {
-      const name = node.name;
-      if (!isIdentifier(name)) {
-        return void 0;
-      }
-      const propertyName = setParent(setTextRange(factory2.cloneNode(name), name), name.parent);
-      setEmitFlags(propertyName, 3072 /* NoComments */ | 96 /* NoSourceMap */);
-      const localName = setParent(setTextRange(factory2.cloneNode(name), name), name.parent);
-      setEmitFlags(localName, 3072 /* NoComments */);
-      return startOnNewLine(
-        removeAllComments(
-          setTextRange(
-            setOriginalNode(
-              factory2.createExpressionStatement(
-                factory2.createAssignment(
-                  setTextRange(
-                    factory2.createPropertyAccessExpression(
-                      factory2.createThis(),
-                      propertyName
-                    ),
-                    node.name
-                  ),
-                  localName
-                )
-              ),
-              node
-            ),
-            moveRangePos(node, -1)
-          )
-        )
-      );
-    }
-    function visitMethodDeclaration(node, parent2) {
-      if (!(node.transformFlags & 1 /* ContainsTypeScript */)) {
-        return node;
-      }
-      if (!shouldEmitFunctionLikeDeclaration(node)) {
-        return void 0;
-      }
-      let modifiers = isClassLike(parent2) ? visitNodes2(node.modifiers, visitor, isModifierLike) : visitNodes2(node.modifiers, decoratorElidingVisitor, isModifierLike);
-      modifiers = injectClassElementTypeMetadata(modifiers, node, parent2);
-      return factory2.updateMethodDeclaration(
-        node,
-        modifiers,
-        node.asteriskToken,
-        visitPropertyNameOfClassElement(node),
-        /*questionToken*/
-        void 0,
-        /*typeParameters*/
-        void 0,
-        visitParameterList(node.parameters, visitor, context),
-        /*type*/
-        void 0,
-        visitFunctionBody(node.body, visitor, context)
-      );
-    }
-    function shouldEmitAccessorDeclaration(node) {
-      return !(nodeIsMissing(node.body) && hasSyntacticModifier(node, 256 /* Abstract */));
-    }
-    function visitGetAccessor(node, parent2) {
-      if (!(node.transformFlags & 1 /* ContainsTypeScript */)) {
-        return node;
-      }
-      if (!shouldEmitAccessorDeclaration(node)) {
-        return void 0;
-      }
-      let modifiers = isClassLike(parent2) ? visitNodes2(node.modifiers, visitor, isModifierLike) : visitNodes2(node.modifiers, decoratorElidingVisitor, isModifierLike);
-      modifiers = injectClassElementTypeMetadata(modifiers, node, parent2);
-      return factory2.updateGetAccessorDeclaration(
-        node,
-        modifiers,
-        visitPropertyNameOfClassElement(node),
-        visitParameterList(node.parameters, visitor, context),
-        /*type*/
-        void 0,
-        visitFunctionBody(node.body, visitor, context) || factory2.createBlock([])
-      );
-    }
-    function visitSetAccessor(node, parent2) {
-      if (!(node.transformFlags & 1 /* ContainsTypeScript */)) {
-        return node;
-      }
-      if (!shouldEmitAccessorDeclaration(node)) {
-        return void 0;
-      }
-      let modifiers = isClassLike(parent2) ? visitNodes2(node.modifiers, visitor, isModifierLike) : visitNodes2(node.modifiers, decoratorElidingVisitor, isModifierLike);
-      modifiers = injectClassElementTypeMetadata(modifiers, node, parent2);
-      return factory2.updateSetAccessorDeclaration(
-        node,
-        modifiers,
-        visitPropertyNameOfClassElement(node),
-        visitParameterList(node.parameters, visitor, context),
-        visitFunctionBody(node.body, visitor, context) || factory2.createBlock([])
-      );
-    }
-    function visitFunctionDeclaration(node) {
-      if (!shouldEmitFunctionLikeDeclaration(node)) {
-        return factory2.createNotEmittedStatement(node);
-      }
-      const updated = factory2.updateFunctionDeclaration(
-        node,
-        visitNodes2(node.modifiers, modifierVisitor, isModifier),
-        node.asteriskToken,
-        node.name,
-        /*typeParameters*/
-        void 0,
-        visitParameterList(node.parameters, visitor, context),
-        /*type*/
-        void 0,
-        visitFunctionBody(node.body, visitor, context) || factory2.createBlock([])
-      );
-      if (isExportOfNamespace(node)) {
-        const statements = [updated];
-        addExportMemberAssignment(statements, node);
-        return statements;
-      }
-      return updated;
-    }
-    function visitFunctionExpression(node) {
-      if (!shouldEmitFunctionLikeDeclaration(node)) {
-        return factory2.createOmittedExpression();
-      }
-      const updated = factory2.updateFunctionExpression(
-        node,
-        visitNodes2(node.modifiers, modifierVisitor, isModifier),
-        node.asteriskToken,
-        node.name,
-        /*typeParameters*/
-        void 0,
-        visitParameterList(node.parameters, visitor, context),
-        /*type*/
-        void 0,
-        visitFunctionBody(node.body, visitor, context) || factory2.createBlock([])
-      );
-      return updated;
-    }
-    function visitArrowFunction(node) {
-      const updated = factory2.updateArrowFunction(
-        node,
-        visitNodes2(node.modifiers, modifierVisitor, isModifier),
-        /*typeParameters*/
-        void 0,
-        visitParameterList(node.parameters, visitor, context),
-        /*type*/
-        void 0,
-        node.equalsGreaterThanToken,
-        visitFunctionBody(node.body, visitor, context)
-      );
-      return updated;
-    }
-    function visitParameter(node) {
-      if (parameterIsThisKeyword(node)) {
-        return void 0;
-      }
-      const updated = factory2.updateParameterDeclaration(
-        node,
-        visitNodes2(node.modifiers, (node2) => isDecorator(node2) ? visitor(node2) : void 0, isModifierLike),
-        node.dotDotDotToken,
-        Debug.checkDefined(visitNode(node.name, visitor, isBindingName)),
-        /*questionToken*/
-        void 0,
-        /*type*/
-        void 0,
-        visitNode(node.initializer, visitor, isExpression)
-      );
-      if (updated !== node) {
-        setCommentRange(updated, node);
-        setTextRange(updated, moveRangePastModifiers(node));
-        setSourceMapRange(updated, moveRangePastModifiers(node));
-        setEmitFlags(updated.name, 64 /* NoTrailingSourceMap */);
-      }
-      return updated;
-    }
-    function visitVariableStatement(node) {
-      if (isExportOfNamespace(node)) {
-        const variables = getInitializedVariables(node.declarationList);
-        if (variables.length === 0) {
-          return void 0;
-        }
-        return setTextRange(
-          factory2.createExpressionStatement(
-            factory2.inlineExpressions(
-              map(variables, transformInitializedVariable)
-            )
-          ),
-          node
-        );
-      } else {
-        return visitEachChild(node, visitor, context);
-      }
-    }
-    function transformInitializedVariable(node) {
-      const name = node.name;
-      if (isBindingPattern(name)) {
-        return flattenDestructuringAssignment(
-          node,
-          visitor,
-          context,
-          0 /* All */,
-          /*needsValue*/
-          false,
-          createNamespaceExportExpression
-        );
-      } else {
-        return setTextRange(
-          factory2.createAssignment(
-            getNamespaceMemberNameWithSourceMapsAndWithoutComments(name),
-            Debug.checkDefined(visitNode(node.initializer, visitor, isExpression))
-          ),
-          /*location*/
-          node
-        );
-      }
-    }
-    function visitVariableDeclaration(node) {
-      const updated = factory2.updateVariableDeclaration(
-        node,
-        Debug.checkDefined(visitNode(node.name, visitor, isBindingName)),
-        /*exclamationToken*/
-        void 0,
-        /*type*/
-        void 0,
-        visitNode(node.initializer, visitor, isExpression)
-      );
-      if (node.type) {
-        setTypeNode(updated.name, node.type);
-      }
-      return updated;
-    }
-    function visitParenthesizedExpression(node) {
-      const innerExpression = skipOuterExpressions(node.expression, ~6 /* Assertions */);
-      if (isAssertionExpression(innerExpression)) {
-        const expression = visitNode(node.expression, visitor, isExpression);
-        Debug.assert(expression);
-        return factory2.createPartiallyEmittedExpression(expression, node);
-      }
-      return visitEachChild(node, visitor, context);
-    }
-    function visitAssertionExpression(node) {
-      const expression = visitNode(node.expression, visitor, isExpression);
-      Debug.assert(expression);
-      return factory2.createPartiallyEmittedExpression(expression, node);
-    }
-    function visitNonNullExpression(node) {
-      const expression = visitNode(node.expression, visitor, isLeftHandSideExpression);
-      Debug.assert(expression);
-      return factory2.createPartiallyEmittedExpression(expression, node);
-    }
-    function visitSatisfiesExpression(node) {
-      const expression = visitNode(node.expression, visitor, isExpression);
-      Debug.assert(expression);
-      return factory2.createPartiallyEmittedExpression(expression, node);
-    }
-    function visitCallExpression(node) {
-      return factory2.updateCallExpression(
-        node,
-        Debug.checkDefined(visitNode(node.expression, visitor, isExpression)),
-        /*typeArguments*/
-        void 0,
-        visitNodes2(node.arguments, visitor, isExpression)
-      );
-    }
-    function visitNewExpression(node) {
-      return factory2.updateNewExpression(
-        node,
-        Debug.checkDefined(visitNode(node.expression, visitor, isExpression)),
-        /*typeArguments*/
-        void 0,
-        visitNodes2(node.arguments, visitor, isExpression)
-      );
-    }
-    function visitTaggedTemplateExpression(node) {
-      return factory2.updateTaggedTemplateExpression(
-        node,
-        Debug.checkDefined(visitNode(node.tag, visitor, isExpression)),
-        /*typeArguments*/
-        void 0,
-        Debug.checkDefined(visitNode(node.template, visitor, isTemplateLiteral))
-      );
-    }
-    function visitJsxSelfClosingElement(node) {
-      return factory2.updateJsxSelfClosingElement(
-        node,
-        Debug.checkDefined(visitNode(node.tagName, visitor, isJsxTagNameExpression)),
-        /*typeArguments*/
-        void 0,
-        Debug.checkDefined(visitNode(node.attributes, visitor, isJsxAttributes))
-      );
-    }
-    function visitJsxJsxOpeningElement(node) {
-      return factory2.updateJsxOpeningElement(
-        node,
-        Debug.checkDefined(visitNode(node.tagName, visitor, isJsxTagNameExpression)),
-        /*typeArguments*/
-        void 0,
-        Debug.checkDefined(visitNode(node.attributes, visitor, isJsxAttributes))
-      );
-    }
-    function shouldEmitEnumDeclaration(node) {
-      return !isEnumConst(node) || shouldPreserveConstEnums(compilerOptions);
-    }
-    function visitEnumDeclaration(node) {
-      if (!shouldEmitEnumDeclaration(node)) {
-        return factory2.createNotEmittedStatement(node);
-      }
-      const statements = [];
-      let emitFlags = 4 /* AdviseOnEmitNode */;
-      const varAdded = addVarForEnumOrModuleDeclaration(statements, node);
-      if (varAdded) {
-        if (moduleKind !== 4 /* System */ || currentLexicalScope !== currentSourceFile) {
-          emitFlags |= 1024 /* NoLeadingComments */;
-        }
-      }
-      const parameterName = getNamespaceParameterName(node);
-      const containerName = getNamespaceContainerName(node);
-      const exportName = isExportOfNamespace(node) ? factory2.getExternalModuleOrNamespaceExportName(
-        currentNamespaceContainerName,
-        node,
-        /*allowComments*/
-        false,
-        /*allowSourceMaps*/
-        true
-      ) : factory2.getDeclarationName(
-        node,
-        /*allowComments*/
-        false,
-        /*allowSourceMaps*/
-        true
-      );
-      let moduleArg = factory2.createLogicalOr(
-        exportName,
-        factory2.createAssignment(
-          exportName,
-          factory2.createObjectLiteralExpression()
-        )
-      );
-      if (isExportOfNamespace(node)) {
-        const localName = factory2.getLocalName(
-          node,
-          /*allowComments*/
-          false,
-          /*allowSourceMaps*/
-          true
-        );
-        moduleArg = factory2.createAssignment(localName, moduleArg);
-      }
-      const enumStatement = factory2.createExpressionStatement(
-        factory2.createCallExpression(
-          factory2.createFunctionExpression(
-            /*modifiers*/
-            void 0,
-            /*asteriskToken*/
-            void 0,
-            /*name*/
-            void 0,
-            /*typeParameters*/
-            void 0,
-            [factory2.createParameterDeclaration(
-              /*modifiers*/
-              void 0,
-              /*dotDotDotToken*/
-              void 0,
-              parameterName
-            )],
-            /*type*/
-            void 0,
-            transformEnumBody(node, containerName)
-          ),
-          /*typeArguments*/
-          void 0,
-          [moduleArg]
-        )
-      );
-      setOriginalNode(enumStatement, node);
-      if (varAdded) {
-        setSyntheticLeadingComments(enumStatement, void 0);
-        setSyntheticTrailingComments(enumStatement, void 0);
-      }
-      setTextRange(enumStatement, node);
-      addEmitFlags(enumStatement, emitFlags);
-      statements.push(enumStatement);
-      return statements;
-    }
-    function transformEnumBody(node, localName) {
-      const savedCurrentNamespaceLocalName = currentNamespaceContainerName;
-      currentNamespaceContainerName = localName;
-      const statements = [];
-      startLexicalEnvironment();
-      const members = map(node.members, transformEnumMember);
-      insertStatementsAfterStandardPrologue(statements, endLexicalEnvironment());
-      addRange(statements, members);
-      currentNamespaceContainerName = savedCurrentNamespaceLocalName;
-      return factory2.createBlock(
-        setTextRange(
-          factory2.createNodeArray(statements),
-          /*location*/
-          node.members
-        ),
-        /*multiLine*/
-        true
-      );
-    }
-    function transformEnumMember(member) {
-      const name = getExpressionForPropertyName(
-        member,
-        /*generateNameForComputedPropertyName*/
-        false
-      );
-      const valueExpression = transformEnumMemberDeclarationValue(member);
-      const innerAssignment = factory2.createAssignment(
-        factory2.createElementAccessExpression(
-          currentNamespaceContainerName,
-          name
-        ),
-        valueExpression
-      );
-      const outerAssignment = valueExpression.kind === 11 /* StringLiteral */ ? innerAssignment : factory2.createAssignment(
-        factory2.createElementAccessExpression(
-          currentNamespaceContainerName,
-          innerAssignment
-        ),
-        name
-      );
-      return setTextRange(
-        factory2.createExpressionStatement(
-          setTextRange(
-            outerAssignment,
-            member
-          )
-        ),
-        member
-      );
-    }
-    function transformEnumMemberDeclarationValue(member) {
-      const value = resolver.getConstantValue(member);
-      if (value !== void 0) {
-        return typeof value === "string" ? factory2.createStringLiteral(value) : factory2.createNumericLiteral(value);
-      } else {
-        enableSubstitutionForNonQualifiedEnumMembers();
-        if (member.initializer) {
-          return Debug.checkDefined(visitNode(member.initializer, visitor, isExpression));
-        } else {
-          return factory2.createVoidZero();
-        }
-      }
-    }
-    function shouldEmitModuleDeclaration(nodeIn) {
-      const node = getParseTreeNode(nodeIn, isModuleDeclaration);
-      if (!node) {
-        return true;
-      }
-      return isInstantiatedModule(node, shouldPreserveConstEnums(compilerOptions));
-    }
-    function recordEmittedDeclarationInScope(node) {
-      if (!currentScopeFirstDeclarationsOfName) {
-        currentScopeFirstDeclarationsOfName = /* @__PURE__ */ new Map();
-      }
-      const name = declaredNameInScope(node);
-      if (!currentScopeFirstDeclarationsOfName.has(name)) {
-        currentScopeFirstDeclarationsOfName.set(name, node);
-      }
-    }
-    function isFirstEmittedDeclarationInScope(node) {
-      if (currentScopeFirstDeclarationsOfName) {
-        const name = declaredNameInScope(node);
-        return currentScopeFirstDeclarationsOfName.get(name) === node;
-      }
-      return true;
-    }
-    function declaredNameInScope(node) {
-      Debug.assertNode(node.name, isIdentifier);
-      return node.name.escapedText;
-    }
-    function addVarForEnumOrModuleDeclaration(statements, node) {
-      const varDecl = factory2.createVariableDeclaration(factory2.getLocalName(
-        node,
-        /*allowComments*/
-        false,
-        /*allowSourceMaps*/
-        true
-      ));
-      const varFlags = currentLexicalScope.kind === 311 /* SourceFile */ ? 0 /* None */ : 1 /* Let */;
-      const statement = factory2.createVariableStatement(
-        visitNodes2(node.modifiers, modifierVisitor, isModifier),
-        factory2.createVariableDeclarationList([varDecl], varFlags)
-      );
-      setOriginalNode(varDecl, node);
-      setSyntheticLeadingComments(varDecl, void 0);
-      setSyntheticTrailingComments(varDecl, void 0);
-      setOriginalNode(statement, node);
-      recordEmittedDeclarationInScope(node);
-      if (isFirstEmittedDeclarationInScope(node)) {
-        if (node.kind === 265 /* EnumDeclaration */) {
-          setSourceMapRange(statement.declarationList, node);
-        } else {
-          setSourceMapRange(statement, node);
-        }
-        setCommentRange(statement, node);
-        addEmitFlags(statement, 2048 /* NoTrailingComments */);
-        statements.push(statement);
-        return true;
-      }
-      return false;
-    }
-    function visitModuleDeclaration(node) {
-      if (!shouldEmitModuleDeclaration(node)) {
-        return factory2.createNotEmittedStatement(node);
-      }
-      Debug.assertNode(node.name, isIdentifier, "A TypeScript namespace should have an Identifier name.");
-      enableSubstitutionForNamespaceExports();
-      const statements = [];
-      let emitFlags = 4 /* AdviseOnEmitNode */;
-      const varAdded = addVarForEnumOrModuleDeclaration(statements, node);
-      if (varAdded) {
-        if (moduleKind !== 4 /* System */ || currentLexicalScope !== currentSourceFile) {
-          emitFlags |= 1024 /* NoLeadingComments */;
-        }
-      }
-      const parameterName = getNamespaceParameterName(node);
-      const containerName = getNamespaceContainerName(node);
-      const exportName = isExportOfNamespace(node) ? factory2.getExternalModuleOrNamespaceExportName(
-        currentNamespaceContainerName,
-        node,
-        /*allowComments*/
-        false,
-        /*allowSourceMaps*/
-        true
-      ) : factory2.getDeclarationName(
-        node,
-        /*allowComments*/
-        false,
-        /*allowSourceMaps*/
-        true
-      );
-      let moduleArg = factory2.createLogicalOr(
-        exportName,
-        factory2.createAssignment(
-          exportName,
-          factory2.createObjectLiteralExpression()
-        )
-      );
-      if (isExportOfNamespace(node)) {
-        const localName = factory2.getLocalName(
-          node,
-          /*allowComments*/
-          false,
-          /*allowSourceMaps*/
-          true
-        );
-        moduleArg = factory2.createAssignment(localName, moduleArg);
-      }
-      const moduleStatement = factory2.createExpressionStatement(
-        factory2.createCallExpression(
-          factory2.createFunctionExpression(
-            /*modifiers*/
-            void 0,
-            /*asteriskToken*/
-            void 0,
-            /*name*/
-            void 0,
-            /*typeParameters*/
-            void 0,
-            [factory2.createParameterDeclaration(
-              /*modifiers*/
-              void 0,
-              /*dotDotDotToken*/
-              void 0,
-              parameterName
-            )],
-            /*type*/
-            void 0,
-            transformModuleBody(node, containerName)
-          ),
-          /*typeArguments*/
-          void 0,
-          [moduleArg]
-        )
-      );
-      setOriginalNode(moduleStatement, node);
-      if (varAdded) {
-        setSyntheticLeadingComments(moduleStatement, void 0);
-        setSyntheticTrailingComments(moduleStatement, void 0);
-      }
-      setTextRange(moduleStatement, node);
-      addEmitFlags(moduleStatement, emitFlags);
-      statements.push(moduleStatement);
-      return statements;
-    }
-    function transformModuleBody(node, namespaceLocalName) {
-      const savedCurrentNamespaceContainerName = currentNamespaceContainerName;
-      const savedCurrentNamespace = currentNamespace;
-      const savedCurrentScopeFirstDeclarationsOfName = currentScopeFirstDeclarationsOfName;
-      currentNamespaceContainerName = namespaceLocalName;
-      currentNamespace = node;
-      currentScopeFirstDeclarationsOfName = void 0;
-      const statements = [];
-      startLexicalEnvironment();
-      let statementsLocation;
-      let blockLocation;
-      if (node.body) {
-        if (node.body.kind === 267 /* ModuleBlock */) {
-          saveStateAndInvoke(node.body, (body) => addRange(statements, visitNodes2(body.statements, namespaceElementVisitor, isStatement)));
-          statementsLocation = node.body.statements;
-          blockLocation = node.body;
-        } else {
-          const result = visitModuleDeclaration(node.body);
-          if (result) {
-            if (isArray(result)) {
-              addRange(statements, result);
-            } else {
-              statements.push(result);
-            }
-          }
-          const moduleBlock = getInnerMostModuleDeclarationFromDottedModule(node).body;
-          statementsLocation = moveRangePos(moduleBlock.statements, -1);
-        }
-      }
-      insertStatementsAfterStandardPrologue(statements, endLexicalEnvironment());
-      currentNamespaceContainerName = savedCurrentNamespaceContainerName;
-      currentNamespace = savedCurrentNamespace;
-      currentScopeFirstDeclarationsOfName = savedCurrentScopeFirstDeclarationsOfName;
-      const block = factory2.createBlock(
-        setTextRange(
-          factory2.createNodeArray(statements),
-          /*location*/
-          statementsLocation
-        ),
-        /*multiLine*/
-        true
-      );
-      setTextRange(block, blockLocation);
-      if (!node.body || node.body.kind !== 267 /* ModuleBlock */) {
-        setEmitFlags(block, getEmitFlags(block) | 3072 /* NoComments */);
-      }
-      return block;
-    }
-    function getInnerMostModuleDeclarationFromDottedModule(moduleDeclaration) {
-      if (moduleDeclaration.body.kind === 266 /* ModuleDeclaration */) {
-        const recursiveInnerModule = getInnerMostModuleDeclarationFromDottedModule(moduleDeclaration.body);
-        return recursiveInnerModule || moduleDeclaration.body;
-      }
-    }
-    function visitImportDeclaration(node) {
-      if (!node.importClause) {
-        return node;
-      }
-      if (node.importClause.isTypeOnly) {
-        return void 0;
-      }
-      const importClause = visitNode(node.importClause, visitImportClause, isImportClause);
-      return importClause || compilerOptions.importsNotUsedAsValues === 1 /* Preserve */ || compilerOptions.importsNotUsedAsValues === 2 /* Error */ ? factory2.updateImportDeclaration(
-        node,
-        /*modifiers*/
-        void 0,
-        importClause,
-        node.moduleSpecifier,
-        node.assertClause
-      ) : void 0;
-    }
-    function visitImportClause(node) {
-      Debug.assert(!node.isTypeOnly);
-      const name = shouldEmitAliasDeclaration(node) ? node.name : void 0;
-      const namedBindings = visitNode(node.namedBindings, visitNamedImportBindings, isNamedImportBindings);
-      return name || namedBindings ? factory2.updateImportClause(
-        node,
-        /*isTypeOnly*/
-        false,
-        name,
-        namedBindings
-      ) : void 0;
-    }
-    function visitNamedImportBindings(node) {
-      if (node.kind === 273 /* NamespaceImport */) {
-        return shouldEmitAliasDeclaration(node) ? node : void 0;
-      } else {
-        const allowEmpty = compilerOptions.verbatimModuleSyntax || compilerOptions.preserveValueImports && (compilerOptions.importsNotUsedAsValues === 1 /* Preserve */ || compilerOptions.importsNotUsedAsValues === 2 /* Error */);
-        const elements = visitNodes2(node.elements, visitImportSpecifier, isImportSpecifier);
-        return allowEmpty || some(elements) ? factory2.updateNamedImports(node, elements) : void 0;
-      }
-    }
-    function visitImportSpecifier(node) {
-      return !node.isTypeOnly && shouldEmitAliasDeclaration(node) ? node : void 0;
-    }
-    function visitExportAssignment(node) {
-      return compilerOptions.verbatimModuleSyntax || resolver.isValueAliasDeclaration(node) ? visitEachChild(node, visitor, context) : void 0;
-    }
-    function visitExportDeclaration(node) {
-      if (node.isTypeOnly) {
-        return void 0;
-      }
-      if (!node.exportClause || isNamespaceExport(node.exportClause)) {
-        return node;
-      }
-      const allowEmpty = compilerOptions.verbatimModuleSyntax || !!node.moduleSpecifier && (compilerOptions.importsNotUsedAsValues === 1 /* Preserve */ || compilerOptions.importsNotUsedAsValues === 2 /* Error */);
-      const exportClause = visitNode(
-        node.exportClause,
-        (bindings) => visitNamedExportBindings(bindings, allowEmpty),
-        isNamedExportBindings
-      );
-      return exportClause ? factory2.updateExportDeclaration(
-        node,
-        /*modifiers*/
-        void 0,
-        node.isTypeOnly,
-        exportClause,
-        node.moduleSpecifier,
-        node.assertClause
-      ) : void 0;
-    }
-    function visitNamedExports(node, allowEmpty) {
-      const elements = visitNodes2(node.elements, visitExportSpecifier, isExportSpecifier);
-      return allowEmpty || some(elements) ? factory2.updateNamedExports(node, elements) : void 0;
-    }
-    function visitNamespaceExports(node) {
-      return factory2.updateNamespaceExport(node, Debug.checkDefined(visitNode(node.name, visitor, isIdentifier)));
-    }
-    function visitNamedExportBindings(node, allowEmpty) {
-      return isNamespaceExport(node) ? visitNamespaceExports(node) : visitNamedExports(node, allowEmpty);
-    }
-    function visitExportSpecifier(node) {
-      return !node.isTypeOnly && (compilerOptions.verbatimModuleSyntax || resolver.isValueAliasDeclaration(node)) ? node : void 0;
-    }
-    function shouldEmitImportEqualsDeclaration(node) {
-      return shouldEmitAliasDeclaration(node) || !isExternalModule(currentSourceFile) && resolver.isTopLevelValueImportEqualsWithEntityName(node);
-    }
-    function visitImportEqualsDeclaration(node) {
-      if (node.isTypeOnly) {
-        return void 0;
-      }
-      if (isExternalModuleImportEqualsDeclaration(node)) {
-        const isReferenced = shouldEmitAliasDeclaration(node);
-        if (!isReferenced && compilerOptions.importsNotUsedAsValues === 1 /* Preserve */) {
-          return setOriginalNode(
-            setTextRange(
-              factory2.createImportDeclaration(
-                /*modifiers*/
-                void 0,
-                /*importClause*/
-                void 0,
-                node.moduleReference.expression,
-                /*assertClause*/
-                void 0
-              ),
-              node
-            ),
-            node
-          );
-        }
-        return isReferenced ? visitEachChild(node, visitor, context) : void 0;
-      }
-      if (!shouldEmitImportEqualsDeclaration(node)) {
-        return void 0;
-      }
-      const moduleReference = createExpressionFromEntityName(factory2, node.moduleReference);
-      setEmitFlags(moduleReference, 3072 /* NoComments */ | 4096 /* NoNestedComments */);
-      if (isNamedExternalModuleExport(node) || !isExportOfNamespace(node)) {
-        return setOriginalNode(
-          setTextRange(
-            factory2.createVariableStatement(
-              visitNodes2(node.modifiers, modifierVisitor, isModifier),
-              factory2.createVariableDeclarationList([
-                setOriginalNode(
-                  factory2.createVariableDeclaration(
-                    node.name,
-                    /*exclamationToken*/
-                    void 0,
-                    /*type*/
-                    void 0,
-                    moduleReference
-                  ),
-                  node
-                )
-              ])
-            ),
-            node
-          ),
-          node
-        );
-      } else {
-        return setOriginalNode(
-          createNamespaceExport(
-            node.name,
-            moduleReference,
-            node
-          ),
-          node
-        );
-      }
-    }
-    function isExportOfNamespace(node) {
-      return currentNamespace !== void 0 && hasSyntacticModifier(node, 1 /* Export */);
-    }
-    function isExternalModuleExport(node) {
-      return currentNamespace === void 0 && hasSyntacticModifier(node, 1 /* Export */);
-    }
-    function isNamedExternalModuleExport(node) {
-      return isExternalModuleExport(node) && !hasSyntacticModifier(node, 1024 /* Default */);
-    }
-    function isDefaultExternalModuleExport(node) {
-      return isExternalModuleExport(node) && hasSyntacticModifier(node, 1024 /* Default */);
-    }
-    function createExportMemberAssignmentStatement(node) {
-      const expression = factory2.createAssignment(
-        factory2.getExternalModuleOrNamespaceExportName(
-          currentNamespaceContainerName,
-          node,
-          /*allowComments*/
-          false,
-          /*allowSourceMaps*/
-          true
-        ),
-        factory2.getLocalName(node)
-      );
-      setSourceMapRange(expression, createRange(node.name ? node.name.pos : node.pos, node.end));
-      const statement = factory2.createExpressionStatement(expression);
-      setSourceMapRange(statement, createRange(-1, node.end));
-      return statement;
-    }
-    function addExportMemberAssignment(statements, node) {
-      statements.push(createExportMemberAssignmentStatement(node));
-    }
-    function createNamespaceExport(exportName, exportValue, location) {
-      return setTextRange(
-        factory2.createExpressionStatement(
-          factory2.createAssignment(
-            factory2.getNamespaceMemberName(
-              currentNamespaceContainerName,
-              exportName,
-              /*allowComments*/
-              false,
-              /*allowSourceMaps*/
-              true
-            ),
-            exportValue
-          )
-        ),
-        location
-      );
-    }
-    function createNamespaceExportExpression(exportName, exportValue, location) {
-      return setTextRange(factory2.createAssignment(getNamespaceMemberNameWithSourceMapsAndWithoutComments(exportName), exportValue), location);
-    }
-    function getNamespaceMemberNameWithSourceMapsAndWithoutComments(name) {
-      return factory2.getNamespaceMemberName(
-        currentNamespaceContainerName,
-        name,
-        /*allowComments*/
-        false,
-        /*allowSourceMaps*/
-        true
-      );
-    }
-    function getNamespaceParameterName(node) {
-      const name = factory2.getGeneratedNameForNode(node);
-      setSourceMapRange(name, node.name);
-      return name;
-    }
-    function getNamespaceContainerName(node) {
-      return factory2.getGeneratedNameForNode(node);
-    }
-    function enableSubstitutionForNonQualifiedEnumMembers() {
-      if ((enabledSubstitutions & 8 /* NonQualifiedEnumMembers */) === 0) {
-        enabledSubstitutions |= 8 /* NonQualifiedEnumMembers */;
-        context.enableSubstitution(80 /* Identifier */);
-      }
-    }
-    function enableSubstitutionForNamespaceExports() {
-      if ((enabledSubstitutions & 2 /* NamespaceExports */) === 0) {
-        enabledSubstitutions |= 2 /* NamespaceExports */;
-        context.enableSubstitution(80 /* Identifier */);
-        context.enableSubstitution(303 /* ShorthandPropertyAssignment */);
-        context.enableEmitNotification(266 /* ModuleDeclaration */);
-      }
-    }
-    function isTransformedModuleDeclaration(node) {
-      return getOriginalNode(node).kind === 266 /* ModuleDeclaration */;
-    }
-    function isTransformedEnumDeclaration(node) {
-      return getOriginalNode(node).kind === 265 /* EnumDeclaration */;
-    }
-    function onEmitNode(hint, node, emitCallback) {
-      const savedApplicableSubstitutions = applicableSubstitutions;
-      const savedCurrentSourceFile = currentSourceFile;
-      if (isSourceFile(node)) {
-        currentSourceFile = node;
-      }
-      if (enabledSubstitutions & 2 /* NamespaceExports */ && isTransformedModuleDeclaration(node)) {
-        applicableSubstitutions |= 2 /* NamespaceExports */;
-      }
-      if (enabledSubstitutions & 8 /* NonQualifiedEnumMembers */ && isTransformedEnumDeclaration(node)) {
-        applicableSubstitutions |= 8 /* NonQualifiedEnumMembers */;
-      }
-      previousOnEmitNode(hint, node, emitCallback);
-      applicableSubstitutions = savedApplicableSubstitutions;
-      currentSourceFile = savedCurrentSourceFile;
-    }
-    function onSubstituteNode(hint, node) {
-      node = previousOnSubstituteNode(hint, node);
-      if (hint === 1 /* Expression */) {
-        return substituteExpression(node);
-      } else if (isShorthandPropertyAssignment(node)) {
-        return substituteShorthandPropertyAssignment(node);
-      }
-      return node;
-    }
-    function substituteShorthandPropertyAssignment(node) {
-      if (enabledSubstitutions & 2 /* NamespaceExports */) {
-        const name = node.name;
-        const exportedName = trySubstituteNamespaceExportedName(name);
-        if (exportedName) {
-          if (node.objectAssignmentInitializer) {
-            const initializer = factory2.createAssignment(exportedName, node.objectAssignmentInitializer);
-            return setTextRange(factory2.createPropertyAssignment(name, initializer), node);
-          }
-          return setTextRange(factory2.createPropertyAssignment(name, exportedName), node);
-        }
-      }
-      return node;
-    }
-    function substituteExpression(node) {
-      switch (node.kind) {
-        case 80 /* Identifier */:
-          return substituteExpressionIdentifier(node);
-        case 210 /* PropertyAccessExpression */:
-          return substitutePropertyAccessExpression(node);
-        case 211 /* ElementAccessExpression */:
-          return substituteElementAccessExpression(node);
-      }
-      return node;
-    }
-    function substituteExpressionIdentifier(node) {
-      return trySubstituteNamespaceExportedName(node) || node;
-    }
-    function trySubstituteNamespaceExportedName(node) {
-      if (enabledSubstitutions & applicableSubstitutions && !isGeneratedIdentifier(node) && !isLocalName(node)) {
-        const container = resolver.getReferencedExportContainer(
-          node,
-          /*prefixLocals*/
-          false
-        );
-        if (container && container.kind !== 311 /* SourceFile */) {
-          const substitute = applicableSubstitutions & 2 /* NamespaceExports */ && container.kind === 266 /* ModuleDeclaration */ || applicableSubstitutions & 8 /* NonQualifiedEnumMembers */ && container.kind === 265 /* EnumDeclaration */;
-          if (substitute) {
-            return setTextRange(
-              factory2.createPropertyAccessExpression(factory2.getGeneratedNameForNode(container), node),
-              /*location*/
-              node
-            );
-          }
-        }
-      }
-      return void 0;
-    }
-    function substitutePropertyAccessExpression(node) {
-      return substituteConstantValue(node);
-    }
-    function substituteElementAccessExpression(node) {
-      return substituteConstantValue(node);
-    }
-    function safeMultiLineComment(value) {
-      return value.replace(/\*\//g, "*_/");
-    }
-    function substituteConstantValue(node) {
-      const constantValue = tryGetConstEnumValue(node);
-      if (constantValue !== void 0) {
-        setConstantValue(node, constantValue);
-        const substitute = typeof constantValue === "string" ? factory2.createStringLiteral(constantValue) : factory2.createNumericLiteral(constantValue);
-        if (!compilerOptions.removeComments) {
-          const originalNode = getOriginalNode(node, isAccessExpression);
-          addSyntheticTrailingComment(substitute, 3 /* MultiLineCommentTrivia */, ` ${safeMultiLineComment(getTextOfNode(originalNode))} `);
-        }
-        return substitute;
-      }
-      return node;
-    }
-    function tryGetConstEnumValue(node) {
-      if (getIsolatedModules(compilerOptions)) {
-        return void 0;
-      }
-      return isPropertyAccessExpression(node) || isElementAccessExpression(node) ? resolver.getConstantValue(node) : void 0;
-    }
-    function shouldEmitAliasDeclaration(node) {
-      return compilerOptions.verbatimModuleSyntax || isInJSFile(node) || (compilerOptions.preserveValueImports ? resolver.isValueAliasDeclaration(node) : resolver.isReferencedAliasDeclaration(node));
-    }
-  }
-  var USE_NEW_TYPE_METADATA_FORMAT;
-  var init_ts = __esm({
-    "src/compiler/transformers/ts.ts"() {
-      "use strict";
-      init_ts2();
-      USE_NEW_TYPE_METADATA_FORMAT = false;
-    }
-  });
-
-  // src/compiler/transformers/classFields.ts
-  function transformClassFields(context) {
-    const {
-      factory: factory2,
-      getEmitHelperFactory: emitHelpers,
-      hoistVariableDeclaration,
-      endLexicalEnvironment,
-      startLexicalEnvironment,
-      resumeLexicalEnvironment,
-      addBlockScopedVariable
-    } = context;
-    const resolver = context.getEmitResolver();
-    const compilerOptions = context.getCompilerOptions();
-    const languageVersion = getEmitScriptTarget(compilerOptions);
-    const useDefineForClassFields = getUseDefineForClassFields(compilerOptions);
-    const legacyDecorators = !!compilerOptions.experimentalDecorators;
-    const shouldTransformInitializersUsingSet = !useDefineForClassFields;
-    const shouldTransformInitializersUsingDefine = useDefineForClassFields && languageVersion < 9 /* ES2022 */;
-    const shouldTransformInitializers = shouldTransformInitializersUsingSet || shouldTransformInitializersUsingDefine;
-    const shouldTransformPrivateElementsOrClassStaticBlocks = languageVersion < 9 /* ES2022 */;
-    const shouldTransformAutoAccessors = languageVersion < 99 /* ESNext */ ? -1 /* True */ : !useDefineForClassFields ? 3 /* Maybe */ : 0 /* False */;
-    const shouldTransformThisInStaticInitializers = languageVersion < 9 /* ES2022 */;
-    const shouldTransformSuperInStaticInitializers = shouldTransformThisInStaticInitializers && languageVersion >= 2 /* ES2015 */;
-    const shouldTransformAnything = shouldTransformInitializers || shouldTransformPrivateElementsOrClassStaticBlocks || shouldTransformAutoAccessors === -1 /* True */;
-    const previousOnSubstituteNode = context.onSubstituteNode;
-    context.onSubstituteNode = onSubstituteNode;
-    const previousOnEmitNode = context.onEmitNode;
-    context.onEmitNode = onEmitNode;
-    let shouldTransformPrivateStaticElementsInFile = false;
-    let enabledSubstitutions;
-    let classAliases;
-    let pendingExpressions;
-    let pendingStatements;
-    let lexicalEnvironment;
-    const lexicalEnvironmentMap = /* @__PURE__ */ new Map();
-    let currentClassContainer;
-    let currentStaticPropertyDeclarationOrStaticBlock;
-    let shouldSubstituteThisWithClassThis = false;
-    let previousShouldSubstituteThisWithClassThis = false;
-    return chainBundle(context, transformSourceFile);
-    function transformSourceFile(node) {
-      if (node.isDeclarationFile) {
-        return node;
-      }
-      lexicalEnvironment = void 0;
-      shouldTransformPrivateStaticElementsInFile = !!(getInternalEmitFlags(node) & 32 /* TransformPrivateStaticElements */);
-      if (!shouldTransformAnything && !shouldTransformPrivateStaticElementsInFile) {
-        return node;
-      }
-      const visited = visitEachChild(node, visitor, context);
-      addEmitHelpers(visited, context.readEmitHelpers());
-      return visited;
-    }
-    function modifierVisitor(node) {
-      switch (node.kind) {
-        case 129 /* AccessorKeyword */:
-          return shouldTransformAutoAccessorsInCurrentClass() ? void 0 : node;
-        default:
-          return tryCast(node, isModifier);
-      }
-    }
-    function visitor(node) {
-      if (!(node.transformFlags & 16777216 /* ContainsClassFields */) && !(node.transformFlags & 134234112 /* ContainsLexicalThisOrSuper */)) {
-        return node;
-      }
-      switch (node.kind) {
-        case 129 /* AccessorKeyword */:
-          return Debug.fail("Use `modifierVisitor` instead.");
-        case 262 /* ClassDeclaration */:
-          return visitClassDeclaration(node);
-        case 230 /* ClassExpression */:
-          return visitClassExpression(
-            node,
-            /*referencedName*/
-            void 0
-          );
-        case 174 /* ClassStaticBlockDeclaration */:
-        case 171 /* PropertyDeclaration */:
-          return Debug.fail("Use `classElementVisitor` instead.");
-        case 302 /* PropertyAssignment */:
-          return visitPropertyAssignment(node);
-        case 242 /* VariableStatement */:
-          return visitVariableStatement(node);
-        case 259 /* VariableDeclaration */:
-          return visitVariableDeclaration(node);
-        case 168 /* Parameter */:
-          return visitParameterDeclaration(node);
-        case 207 /* BindingElement */:
-          return visitBindingElement(node);
-        case 276 /* ExportAssignment */:
-          return visitExportAssignment(node);
-        case 81 /* PrivateIdentifier */:
-          return visitPrivateIdentifier(node);
-        case 210 /* PropertyAccessExpression */:
-          return visitPropertyAccessExpression(node);
-        case 211 /* ElementAccessExpression */:
-          return visitElementAccessExpression(node);
-        case 223 /* PrefixUnaryExpression */:
-        case 224 /* PostfixUnaryExpression */:
-          return visitPreOrPostfixUnaryExpression(
-            node,
-            /*discarded*/
-            false
-          );
-        case 225 /* BinaryExpression */:
-          return visitBinaryExpression(
-            node,
-            /*discarded*/
-            false
-          );
-        case 216 /* ParenthesizedExpression */:
-          return visitParenthesizedExpression(
-            node,
-            /*discarded*/
-            false,
-            /*referencedName*/
-            void 0
-          );
-        case 212 /* CallExpression */:
-          return visitCallExpression(node);
-        case 243 /* ExpressionStatement */:
-          return visitExpressionStatement(node);
-        case 214 /* TaggedTemplateExpression */:
-          return visitTaggedTemplateExpression(node);
-        case 247 /* ForStatement */:
-          return visitForStatement(node);
-        case 261 /* FunctionDeclaration */:
-        case 217 /* FunctionExpression */:
-        case 175 /* Constructor */:
-        case 173 /* MethodDeclaration */:
-        case 176 /* GetAccessor */:
-        case 177 /* SetAccessor */: {
-          return setCurrentStaticPropertyDeclarationOrStaticBlockAnd(
-            /*current*/
-            void 0,
-            fallbackVisitor,
-            node
-          );
-        }
-        default:
-          return fallbackVisitor(node);
-      }
-    }
-    function fallbackVisitor(node) {
-      return visitEachChild(node, visitor, context);
-    }
-    function namedEvaluationVisitor(node, referencedName) {
-      switch (node.kind) {
-        case 359 /* PartiallyEmittedExpression */:
-          return visitPartiallyEmittedExpression(
-            node,
-            /*discarded*/
-            false,
-            referencedName
-          );
-        case 216 /* ParenthesizedExpression */:
-          return visitParenthesizedExpression(
-            node,
-            /*discarded*/
-            false,
-            referencedName
-          );
-        case 230 /* ClassExpression */:
-          return visitClassExpression(node, referencedName);
-        default:
-          return visitor(node);
-      }
-    }
-    function discardedValueVisitor(node) {
-      switch (node.kind) {
-        case 223 /* PrefixUnaryExpression */:
-        case 224 /* PostfixUnaryExpression */:
-          return visitPreOrPostfixUnaryExpression(
-            node,
-            /*discarded*/
-            true
-          );
-        case 225 /* BinaryExpression */:
-          return visitBinaryExpression(
-            node,
-            /*discarded*/
-            true
-          );
-        case 360 /* CommaListExpression */:
-          return visitCommaListExpression(
-            node,
-            /*discarded*/
-            true
-          );
-        case 216 /* ParenthesizedExpression */:
-          return visitParenthesizedExpression(
-            node,
-            /*discarded*/
-            true,
-            /*referencedName*/
-            void 0
-          );
-        default:
-          return visitor(node);
-      }
-    }
-    function heritageClauseVisitor(node) {
-      switch (node.kind) {
-        case 297 /* HeritageClause */:
-          return visitEachChild(node, heritageClauseVisitor, context);
-        case 232 /* ExpressionWithTypeArguments */:
-          return visitExpressionWithTypeArgumentsInHeritageClause(node);
-        default:
-          return visitor(node);
-      }
-    }
-    function assignmentTargetVisitor(node) {
-      switch (node.kind) {
-        case 209 /* ObjectLiteralExpression */:
-        case 208 /* ArrayLiteralExpression */:
-          return visitAssignmentPattern(node);
-        default:
-          return visitor(node);
-      }
-    }
-    function classElementVisitor(node) {
-      switch (node.kind) {
-        case 175 /* Constructor */:
-          return visitConstructorDeclaration(node);
-        case 176 /* GetAccessor */:
-        case 177 /* SetAccessor */:
-        case 173 /* MethodDeclaration */:
-          return setCurrentStaticPropertyDeclarationOrStaticBlockAnd(
-            /*current*/
-            void 0,
-            visitMethodOrAccessorDeclaration,
-            node
-          );
-        case 171 /* PropertyDeclaration */:
-          return setCurrentStaticPropertyDeclarationOrStaticBlockAnd(
-            /*current*/
-            void 0,
-            visitPropertyDeclaration,
-            node
-          );
-        case 174 /* ClassStaticBlockDeclaration */:
-          return visitClassStaticBlockDeclaration(node);
-        case 166 /* ComputedPropertyName */:
-          return visitComputedPropertyName(node);
-        case 239 /* SemicolonClassElement */:
-          return node;
-        default:
-          return isModifierLike(node) ? modifierVisitor(node) : visitor(node);
-      }
-    }
-    function propertyNameVisitor(node) {
-      switch (node.kind) {
-        case 166 /* ComputedPropertyName */:
-          return visitComputedPropertyName(node);
-        default:
-          return visitor(node);
-      }
-    }
-    function accessorFieldResultVisitor(node) {
-      switch (node.kind) {
-        case 171 /* PropertyDeclaration */:
-          return transformFieldInitializer(node);
-        case 176 /* GetAccessor */:
-        case 177 /* SetAccessor */:
-          return classElementVisitor(node);
-        default:
-          Debug.assertMissingNode(node, "Expected node to either be a PropertyDeclaration, GetAccessorDeclaration, or SetAccessorDeclaration");
-          break;
-      }
-    }
-    function visitPrivateIdentifier(node) {
-      if (!shouldTransformPrivateElementsOrClassStaticBlocks) {
-        return node;
-      }
-      if (isStatement(node.parent)) {
-        return node;
-      }
-      return setOriginalNode(factory2.createIdentifier(""), node);
-    }
-    function transformPrivateIdentifierInInExpression(node) {
-      const info = accessPrivateIdentifier2(node.left);
-      if (info) {
-        const receiver = visitNode(node.right, visitor, isExpression);
-        return setOriginalNode(
-          emitHelpers().createClassPrivateFieldInHelper(info.brandCheckIdentifier, receiver),
-          node
-        );
-      }
-      return visitEachChild(node, visitor, context);
-    }
-    function visitPropertyAssignment(node) {
-      if (isNamedEvaluation(node, isAnonymousClassNeedingAssignedName)) {
-        const { referencedName, name } = visitReferencedPropertyName(node.name);
-        const initializer = visitNode(node.initializer, (node2) => namedEvaluationVisitor(node2, referencedName), isExpression);
-        return factory2.updatePropertyAssignment(node, name, initializer);
-      }
-      return visitEachChild(node, visitor, context);
-    }
-    function visitVariableStatement(node) {
-      const savedPendingStatements = pendingStatements;
-      pendingStatements = [];
-      const visitedNode = visitEachChild(node, visitor, context);
-      const statement = some(pendingStatements) ? [visitedNode, ...pendingStatements] : visitedNode;
-      pendingStatements = savedPendingStatements;
-      return statement;
-    }
-    function getAssignedNameOfIdentifier(name, initializer) {
-      const originalClass = getOriginalNode(initializer, isClassLike);
-      return originalClass && !originalClass.name && hasSyntacticModifier(originalClass, 1024 /* Default */) ? factory2.createStringLiteral("default") : factory2.createStringLiteralFromNode(name);
-    }
-    function visitVariableDeclaration(node) {
-      if (isNamedEvaluation(node, isAnonymousClassNeedingAssignedName)) {
-        const assignedName = getAssignedNameOfIdentifier(node.name, node.initializer);
-        const name = visitNode(node.name, visitor, isBindingName);
-        const initializer = visitNode(node.initializer, (node2) => namedEvaluationVisitor(node2, assignedName), isExpression);
-        return factory2.updateVariableDeclaration(
-          node,
-          name,
-          /*exclamationToken*/
-          void 0,
-          /*type*/
-          void 0,
-          initializer
-        );
-      }
-      return visitEachChild(node, visitor, context);
-    }
-    function visitParameterDeclaration(node) {
-      if (isNamedEvaluation(node, isAnonymousClassNeedingAssignedName)) {
-        const assignedName = getAssignedNameOfIdentifier(node.name, node.initializer);
-        const name = visitNode(node.name, visitor, isBindingName);
-        const initializer = visitNode(node.initializer, (node2) => namedEvaluationVisitor(node2, assignedName), isExpression);
-        return factory2.updateParameterDeclaration(
-          node,
-          /*modifiers*/
-          void 0,
-          /*dotDotDotToken*/
-          void 0,
-          name,
-          /*questionToken*/
-          void 0,
-          /*type*/
-          void 0,
-          initializer
-        );
-      }
-      return visitEachChild(node, visitor, context);
-    }
-    function visitBindingElement(node) {
-      if (isNamedEvaluation(node, isAnonymousClassNeedingAssignedName)) {
-        const assignedName = getAssignedNameOfIdentifier(node.name, node.initializer);
-        const propertyName = visitNode(node.propertyName, visitor, isPropertyName);
-        const name = visitNode(node.name, visitor, isBindingName);
-        const initializer = visitNode(node.initializer, (node2) => namedEvaluationVisitor(node2, assignedName), isExpression);
-        return factory2.updateBindingElement(
-          node,
-          /*dotDotDotToken*/
-          void 0,
-          propertyName,
-          name,
-          initializer
-        );
-      }
-      return visitEachChild(node, visitor, context);
-    }
-    function visitExportAssignment(node) {
-      if (isNamedEvaluation(node, isAnonymousClassNeedingAssignedName)) {
-        const assignedName = factory2.createStringLiteral(node.isExportEquals ? "" : "default");
-        const modifiers = visitNodes2(node.modifiers, modifierVisitor, isModifier);
-        const expression = visitNode(node.expression, (node2) => namedEvaluationVisitor(node2, assignedName), isExpression);
-        return factory2.updateExportAssignment(node, modifiers, expression);
-      }
-      return visitEachChild(node, visitor, context);
-    }
-    function injectPendingExpressions(expression) {
-      if (some(pendingExpressions)) {
-        if (isParenthesizedExpression(expression)) {
-          pendingExpressions.push(expression.expression);
-          expression = factory2.updateParenthesizedExpression(expression, factory2.inlineExpressions(pendingExpressions));
-        } else {
-          pendingExpressions.push(expression);
-          expression = factory2.inlineExpressions(pendingExpressions);
-        }
-        pendingExpressions = void 0;
-      }
-      return expression;
-    }
-    function visitComputedPropertyName(node) {
-      const expression = visitNode(node.expression, visitor, isExpression);
-      return factory2.updateComputedPropertyName(node, injectPendingExpressions(expression));
-    }
-    function visitConstructorDeclaration(node) {
-      if (currentClassContainer) {
-        return transformConstructor(node, currentClassContainer);
-      }
-      return fallbackVisitor(node);
-    }
-    function shouldTransformClassElementToWeakMap(node) {
-      if (shouldTransformPrivateElementsOrClassStaticBlocks)
-        return true;
-      if (hasStaticModifier(node) && getInternalEmitFlags(node) & 32 /* TransformPrivateStaticElements */)
-        return true;
-      return false;
-    }
-    function visitMethodOrAccessorDeclaration(node) {
-      Debug.assert(!hasDecorators(node));
-      if (!isPrivateIdentifierClassElementDeclaration(node) || !shouldTransformClassElementToWeakMap(node)) {
-        return visitEachChild(node, classElementVisitor, context);
-      }
-      const info = accessPrivateIdentifier2(node.name);
-      Debug.assert(info, "Undeclared private name for property declaration.");
-      if (!info.isValid) {
-        return node;
-      }
-      const functionName = getHoistedFunctionName(node);
-      if (functionName) {
-        getPendingExpressions().push(
-          factory2.createAssignment(
-            functionName,
-            factory2.createFunctionExpression(
-              filter(node.modifiers, (m) => isModifier(m) && !isStaticModifier(m) && !isAccessorModifier(m)),
-              node.asteriskToken,
-              functionName,
-              /*typeParameters*/
-              void 0,
-              visitParameterList(node.parameters, visitor, context),
-              /*type*/
-              void 0,
-              visitFunctionBody(node.body, visitor, context)
-            )
-          )
-        );
-      }
-      return void 0;
-    }
-    function setCurrentStaticPropertyDeclarationOrStaticBlockAnd(current, visitor2, arg) {
-      const savedCurrentStaticPropertyDeclarationOrStaticBlock = currentStaticPropertyDeclarationOrStaticBlock;
-      currentStaticPropertyDeclarationOrStaticBlock = current;
-      const result = visitor2(arg);
-      currentStaticPropertyDeclarationOrStaticBlock = savedCurrentStaticPropertyDeclarationOrStaticBlock;
-      return result;
-    }
-    function getHoistedFunctionName(node) {
-      Debug.assert(isPrivateIdentifier(node.name));
-      const info = accessPrivateIdentifier2(node.name);
-      Debug.assert(info, "Undeclared private name for property declaration.");
-      if (info.kind === "m" /* Method */) {
-        return info.methodName;
-      }
-      if (info.kind === "a" /* Accessor */) {
-        if (isGetAccessor(node)) {
-          return info.getterName;
-        }
-        if (isSetAccessor(node)) {
-          return info.setterName;
-        }
-      }
-    }
-    function transformAutoAccessor(node) {
-      const commentRange = getCommentRange(node);
-      const sourceMapRange = getSourceMapRange(node);
-      const name = node.name;
-      let getterName = name;
-      let setterName = name;
-      if (isComputedPropertyName(name) && !isSimpleInlineableExpression(name.expression)) {
-        const cacheAssignment = findComputedPropertyNameCacheAssignment(name);
-        if (cacheAssignment) {
-          getterName = factory2.updateComputedPropertyName(name, visitNode(name.expression, visitor, isExpression));
-          setterName = factory2.updateComputedPropertyName(name, cacheAssignment.left);
-        } else {
-          const temp = factory2.createTempVariable(hoistVariableDeclaration);
-          setSourceMapRange(temp, name.expression);
-          const expression = visitNode(name.expression, visitor, isExpression);
-          const assignment = factory2.createAssignment(temp, expression);
-          setSourceMapRange(assignment, name.expression);
-          getterName = factory2.updateComputedPropertyName(name, assignment);
-          setterName = factory2.updateComputedPropertyName(name, temp);
-        }
-      }
-      const modifiers = visitNodes2(node.modifiers, modifierVisitor, isModifier);
-      const backingField = createAccessorPropertyBackingField(factory2, node, modifiers, node.initializer);
-      setOriginalNode(backingField, node);
-      setEmitFlags(backingField, 3072 /* NoComments */);
-      setSourceMapRange(backingField, sourceMapRange);
-      const getter = createAccessorPropertyGetRedirector(factory2, node, modifiers, getterName);
-      setOriginalNode(getter, node);
-      setCommentRange(getter, commentRange);
-      setSourceMapRange(getter, sourceMapRange);
-      const setter = createAccessorPropertySetRedirector(factory2, node, modifiers, setterName);
-      setOriginalNode(setter, node);
-      setEmitFlags(setter, 3072 /* NoComments */);
-      setSourceMapRange(setter, sourceMapRange);
-      return visitArray([backingField, getter, setter], accessorFieldResultVisitor, isClassElement);
-    }
-    function transformPrivateFieldInitializer(node) {
-      if (shouldTransformClassElementToWeakMap(node)) {
-        const info = accessPrivateIdentifier2(node.name);
-        Debug.assert(info, "Undeclared private name for property declaration.");
-        if (!info.isValid) {
-          return node;
-        }
-        if (info.isStatic && !shouldTransformPrivateElementsOrClassStaticBlocks) {
-          const statement = transformPropertyOrClassStaticBlock(node, factory2.createThis());
-          if (statement) {
-            return factory2.createClassStaticBlockDeclaration(factory2.createBlock(
-              [statement],
-              /*multiLine*/
-              true
-            ));
-          }
-        }
-        return void 0;
-      }
-      if (shouldTransformInitializersUsingSet && !isStatic(node) && (lexicalEnvironment == null ? void 0 : lexicalEnvironment.data) && lexicalEnvironment.data.facts & 16 /* WillHoistInitializersToConstructor */) {
-        return factory2.updatePropertyDeclaration(
-          node,
-          visitNodes2(node.modifiers, visitor, isModifierLike),
-          node.name,
-          /*questionOrExclamationToken*/
-          void 0,
-          /*type*/
-          void 0,
-          /*initializer*/
-          void 0
-        );
-      }
-      if (isNamedEvaluation(node, isAnonymousClassNeedingAssignedName)) {
-        const { referencedName, name } = visitReferencedPropertyName(node.name);
-        return factory2.updatePropertyDeclaration(
-          node,
-          visitNodes2(node.modifiers, modifierVisitor, isModifier),
-          name,
-          /*questionOrExclamationToken*/
-          void 0,
-          /*type*/
-          void 0,
-          visitNode(node.initializer, (child) => namedEvaluationVisitor(child, referencedName), isExpression)
-        );
-      }
-      return factory2.updatePropertyDeclaration(
-        node,
-        visitNodes2(node.modifiers, modifierVisitor, isModifier),
-        visitNode(node.name, propertyNameVisitor, isPropertyName),
-        /*questionOrExclamationToken*/
-        void 0,
-        /*type*/
-        void 0,
-        visitNode(node.initializer, visitor, isExpression)
-      );
-    }
-    function transformPublicFieldInitializer(node) {
-      if (shouldTransformInitializers && !isAutoAccessorPropertyDeclaration(node)) {
-        const expr = getPropertyNameExpressionIfNeeded(
-          node.name,
-          /*shouldHoist*/
-          !!node.initializer || useDefineForClassFields,
-          /*captureReferencedName*/
-          isNamedEvaluation(node, isAnonymousClassNeedingAssignedName)
-        );
-        if (expr) {
-          getPendingExpressions().push(...flattenCommaList(expr));
-        }
-        if (isStatic(node) && !shouldTransformPrivateElementsOrClassStaticBlocks) {
-          const initializerStatement = transformPropertyOrClassStaticBlock(node, factory2.createThis());
-          if (initializerStatement) {
-            const staticBlock = factory2.createClassStaticBlockDeclaration(
-              factory2.createBlock([initializerStatement])
-            );
-            setOriginalNode(staticBlock, node);
-            setCommentRange(staticBlock, node);
-            setCommentRange(initializerStatement, { pos: -1, end: -1 });
-            setSyntheticLeadingComments(initializerStatement, void 0);
-            setSyntheticTrailingComments(initializerStatement, void 0);
-            return staticBlock;
-          }
-        }
-        return void 0;
-      }
-      return factory2.updatePropertyDeclaration(
-        node,
-        visitNodes2(node.modifiers, modifierVisitor, isModifier),
-        visitNode(node.name, propertyNameVisitor, isPropertyName),
-        /*questionOrExclamationToken*/
-        void 0,
-        /*type*/
-        void 0,
-        visitNode(node.initializer, visitor, isExpression)
-      );
-    }
-    function transformFieldInitializer(node) {
-      Debug.assert(!hasDecorators(node), "Decorators should already have been transformed and elided.");
-      return isPrivateIdentifierClassElementDeclaration(node) ? transformPrivateFieldInitializer(node) : transformPublicFieldInitializer(node);
-    }
-    function shouldTransformAutoAccessorsInCurrentClass() {
-      return shouldTransformAutoAccessors === -1 /* True */ || shouldTransformAutoAccessors === 3 /* Maybe */ && !!(lexicalEnvironment == null ? void 0 : lexicalEnvironment.data) && !!(lexicalEnvironment.data.facts & 16 /* WillHoistInitializersToConstructor */);
-    }
-    function visitPropertyDeclaration(node) {
-      if (isAutoAccessorPropertyDeclaration(node) && (shouldTransformAutoAccessorsInCurrentClass() || hasStaticModifier(node) && getInternalEmitFlags(node) & 32 /* TransformPrivateStaticElements */)) {
-        return transformAutoAccessor(node);
-      }
-      return transformFieldInitializer(node);
-    }
-    function createPrivateIdentifierAccess(info, receiver) {
-      return createPrivateIdentifierAccessHelper(info, visitNode(receiver, visitor, isExpression));
-    }
-    function createPrivateIdentifierAccessHelper(info, receiver) {
-      setCommentRange(receiver, moveRangePos(receiver, -1));
-      switch (info.kind) {
-        case "a" /* Accessor */:
-          return emitHelpers().createClassPrivateFieldGetHelper(
-            receiver,
-            info.brandCheckIdentifier,
-            info.kind,
-            info.getterName
-          );
-        case "m" /* Method */:
-          return emitHelpers().createClassPrivateFieldGetHelper(
-            receiver,
-            info.brandCheckIdentifier,
-            info.kind,
-            info.methodName
-          );
-        case "f" /* Field */:
-          return emitHelpers().createClassPrivateFieldGetHelper(
-            receiver,
-            info.brandCheckIdentifier,
-            info.kind,
-            info.isStatic ? info.variableName : void 0
-          );
-        case "untransformed":
-          return Debug.fail("Access helpers should not be created for untransformed private elements");
-        default:
-          Debug.assertNever(info, "Unknown private element type");
-      }
-    }
-    function visitPropertyAccessExpression(node) {
-      if (isPrivateIdentifier(node.name)) {
-        const privateIdentifierInfo = accessPrivateIdentifier2(node.name);
-        if (privateIdentifierInfo) {
-          return setTextRange(
-            setOriginalNode(
-              createPrivateIdentifierAccess(privateIdentifierInfo, node.expression),
-              node
-            ),
-            node
-          );
-        }
-      }
-      if (shouldTransformSuperInStaticInitializers && isSuperProperty(node) && isIdentifier(node.name) && currentStaticPropertyDeclarationOrStaticBlock && (lexicalEnvironment == null ? void 0 : lexicalEnvironment.data)) {
-        const { classConstructor, superClassReference, facts } = lexicalEnvironment.data;
-        if (facts & 1 /* ClassWasDecorated */) {
-          return visitInvalidSuperProperty(node);
-        }
-        if (classConstructor && superClassReference) {
-          const superProperty = factory2.createReflectGetCall(
-            superClassReference,
-            factory2.createStringLiteralFromNode(node.name),
-            classConstructor
-          );
-          setOriginalNode(superProperty, node.expression);
-          setTextRange(superProperty, node.expression);
-          return superProperty;
-        }
-      }
-      return visitEachChild(node, visitor, context);
-    }
-    function visitElementAccessExpression(node) {
-      if (shouldTransformSuperInStaticInitializers && isSuperProperty(node) && currentStaticPropertyDeclarationOrStaticBlock && (lexicalEnvironment == null ? void 0 : lexicalEnvironment.data)) {
-        const { classConstructor, superClassReference, facts } = lexicalEnvironment.data;
-        if (facts & 1 /* ClassWasDecorated */) {
-          return visitInvalidSuperProperty(node);
-        }
-        if (classConstructor && superClassReference) {
-          const superProperty = factory2.createReflectGetCall(
-            superClassReference,
-            visitNode(node.argumentExpression, visitor, isExpression),
-            classConstructor
-          );
-          setOriginalNode(superProperty, node.expression);
-          setTextRange(superProperty, node.expression);
-          return superProperty;
-        }
-      }
-      return visitEachChild(node, visitor, context);
-    }
-    function visitPreOrPostfixUnaryExpression(node, discarded) {
-      if (node.operator === 46 /* PlusPlusToken */ || node.operator === 47 /* MinusMinusToken */) {
-        const operand = skipParentheses(node.operand);
-        if (isPrivateIdentifierPropertyAccessExpression(operand)) {
-          let info;
-          if (info = accessPrivateIdentifier2(operand.name)) {
-            const receiver = visitNode(operand.expression, visitor, isExpression);
-            const { readExpression, initializeExpression } = createCopiableReceiverExpr(receiver);
-            let expression = createPrivateIdentifierAccess(info, readExpression);
-            const temp = isPrefixUnaryExpression(node) || discarded ? void 0 : factory2.createTempVariable(hoistVariableDeclaration);
-            expression = expandPreOrPostfixIncrementOrDecrementExpression(factory2, node, expression, hoistVariableDeclaration, temp);
-            expression = createPrivateIdentifierAssignment(
-              info,
-              initializeExpression || readExpression,
-              expression,
-              64 /* EqualsToken */
-            );
-            setOriginalNode(expression, node);
-            setTextRange(expression, node);
-            if (temp) {
-              expression = factory2.createComma(expression, temp);
-              setTextRange(expression, node);
-            }
-            return expression;
-          }
-        } else if (shouldTransformSuperInStaticInitializers && isSuperProperty(operand) && currentStaticPropertyDeclarationOrStaticBlock && (lexicalEnvironment == null ? void 0 : lexicalEnvironment.data)) {
-          const { classConstructor, superClassReference, facts } = lexicalEnvironment.data;
-          if (facts & 1 /* ClassWasDecorated */) {
-            const expression = visitInvalidSuperProperty(operand);
-            return isPrefixUnaryExpression(node) ? factory2.updatePrefixUnaryExpression(node, expression) : factory2.updatePostfixUnaryExpression(node, expression);
-          }
-          if (classConstructor && superClassReference) {
-            let setterName;
-            let getterName;
-            if (isPropertyAccessExpression(operand)) {
-              if (isIdentifier(operand.name)) {
-                getterName = setterName = factory2.createStringLiteralFromNode(operand.name);
-              }
-            } else {
-              if (isSimpleInlineableExpression(operand.argumentExpression)) {
-                getterName = setterName = operand.argumentExpression;
-              } else {
-                getterName = factory2.createTempVariable(hoistVariableDeclaration);
-                setterName = factory2.createAssignment(getterName, visitNode(operand.argumentExpression, visitor, isExpression));
-              }
-            }
-            if (setterName && getterName) {
-              let expression = factory2.createReflectGetCall(superClassReference, getterName, classConstructor);
-              setTextRange(expression, operand);
-              const temp = discarded ? void 0 : factory2.createTempVariable(hoistVariableDeclaration);
-              expression = expandPreOrPostfixIncrementOrDecrementExpression(factory2, node, expression, hoistVariableDeclaration, temp);
-              expression = factory2.createReflectSetCall(superClassReference, setterName, expression, classConstructor);
-              setOriginalNode(expression, node);
-              setTextRange(expression, node);
-              if (temp) {
-                expression = factory2.createComma(expression, temp);
-                setTextRange(expression, node);
-              }
-              return expression;
-            }
-          }
-        }
-      }
-      return visitEachChild(node, visitor, context);
-    }
-    function visitForStatement(node) {
-      return factory2.updateForStatement(
-        node,
-        visitNode(node.initializer, discardedValueVisitor, isForInitializer),
-        visitNode(node.condition, visitor, isExpression),
-        visitNode(node.incrementor, discardedValueVisitor, isExpression),
-        visitIterationBody(node.statement, visitor, context)
-      );
-    }
-    function visitExpressionStatement(node) {
-      return factory2.updateExpressionStatement(
-        node,
-        visitNode(node.expression, discardedValueVisitor, isExpression)
-      );
-    }
-    function createCopiableReceiverExpr(receiver) {
-      const clone2 = nodeIsSynthesized(receiver) ? receiver : factory2.cloneNode(receiver);
-      if (isSimpleInlineableExpression(receiver)) {
-        return { readExpression: clone2, initializeExpression: void 0 };
-      }
-      const readExpression = factory2.createTempVariable(hoistVariableDeclaration);
-      const initializeExpression = factory2.createAssignment(readExpression, clone2);
-      return { readExpression, initializeExpression };
-    }
-    function visitCallExpression(node) {
-      var _a;
-      if (isPrivateIdentifierPropertyAccessExpression(node.expression) && accessPrivateIdentifier2(node.expression.name)) {
-        const { thisArg, target } = factory2.createCallBinding(node.expression, hoistVariableDeclaration, languageVersion);
-        if (isCallChain(node)) {
-          return factory2.updateCallChain(
-            node,
-            factory2.createPropertyAccessChain(visitNode(target, visitor, isExpression), node.questionDotToken, "call"),
-            /*questionDotToken*/
-            void 0,
-            /*typeArguments*/
-            void 0,
-            [visitNode(thisArg, visitor, isExpression), ...visitNodes2(node.arguments, visitor, isExpression)]
-          );
-        }
-        return factory2.updateCallExpression(
-          node,
-          factory2.createPropertyAccessExpression(visitNode(target, visitor, isExpression), "call"),
-          /*typeArguments*/
-          void 0,
-          [visitNode(thisArg, visitor, isExpression), ...visitNodes2(node.arguments, visitor, isExpression)]
-        );
-      }
-      if (shouldTransformSuperInStaticInitializers && isSuperProperty(node.expression) && currentStaticPropertyDeclarationOrStaticBlock && ((_a = lexicalEnvironment == null ? void 0 : lexicalEnvironment.data) == null ? void 0 : _a.classConstructor)) {
-        const invocation = factory2.createFunctionCallCall(
-          visitNode(node.expression, visitor, isExpression),
-          lexicalEnvironment.data.classConstructor,
-          visitNodes2(node.arguments, visitor, isExpression)
-        );
-        setOriginalNode(invocation, node);
-        setTextRange(invocation, node);
-        return invocation;
-      }
-      return visitEachChild(node, visitor, context);
-    }
-    function visitTaggedTemplateExpression(node) {
-      var _a;
-      if (isPrivateIdentifierPropertyAccessExpression(node.tag) && accessPrivateIdentifier2(node.tag.name)) {
-        const { thisArg, target } = factory2.createCallBinding(node.tag, hoistVariableDeclaration, languageVersion);
-        return factory2.updateTaggedTemplateExpression(
-          node,
-          factory2.createCallExpression(
-            factory2.createPropertyAccessExpression(visitNode(target, visitor, isExpression), "bind"),
-            /*typeArguments*/
-            void 0,
-            [visitNode(thisArg, visitor, isExpression)]
-          ),
-          /*typeArguments*/
-          void 0,
-          visitNode(node.template, visitor, isTemplateLiteral)
-        );
-      }
-      if (shouldTransformSuperInStaticInitializers && isSuperProperty(node.tag) && currentStaticPropertyDeclarationOrStaticBlock && ((_a = lexicalEnvironment == null ? void 0 : lexicalEnvironment.data) == null ? void 0 : _a.classConstructor)) {
-        const invocation = factory2.createFunctionBindCall(
-          visitNode(node.tag, visitor, isExpression),
-          lexicalEnvironment.data.classConstructor,
-          []
-        );
-        setOriginalNode(invocation, node);
-        setTextRange(invocation, node);
-        return factory2.updateTaggedTemplateExpression(
-          node,
-          invocation,
-          /*typeArguments*/
-          void 0,
-          visitNode(node.template, visitor, isTemplateLiteral)
-        );
-      }
-      return visitEachChild(node, visitor, context);
-    }
-    function transformClassStaticBlockDeclaration(node) {
-      if (lexicalEnvironment) {
-        lexicalEnvironmentMap.set(getOriginalNode(node), lexicalEnvironment);
-      }
-      if (shouldTransformPrivateElementsOrClassStaticBlocks) {
-        startLexicalEnvironment();
-        let statements = setCurrentStaticPropertyDeclarationOrStaticBlockAnd(
-          node,
-          (statements2) => visitNodes2(statements2, visitor, isStatement),
-          node.body.statements
-        );
-        statements = factory2.mergeLexicalEnvironment(statements, endLexicalEnvironment());
-        const iife = factory2.createImmediatelyInvokedArrowFunction(statements);
-        setOriginalNode(iife, node);
-        setTextRange(iife, node);
-        addEmitFlags(iife, 4 /* AdviseOnEmitNode */);
-        return iife;
-      }
-    }
-    function isAnonymousClassNeedingAssignedName(node) {
-      if (isClassExpression(node) && !node.name) {
-        const staticPropertiesOrClassStaticBlocks = getStaticPropertiesAndClassStaticBlock(node);
-        const classStaticBlock = find(staticPropertiesOrClassStaticBlocks, isClassStaticBlockDeclaration);
-        if (classStaticBlock) {
-          for (const statement of classStaticBlock.body.statements) {
-            if (isExpressionStatement(statement) && isCallToHelper(statement.expression, "___setFunctionName")) {
-              return false;
-            }
-          }
-        }
-        const hasTransformableStatics = (shouldTransformPrivateElementsOrClassStaticBlocks || !!(getInternalEmitFlags(node) && 32 /* TransformPrivateStaticElements */)) && some(staticPropertiesOrClassStaticBlocks, (node2) => isClassStaticBlockDeclaration(node2) || isPrivateIdentifierClassElementDeclaration(node2) || shouldTransformInitializers && isInitializedProperty(node2));
-        return hasTransformableStatics;
-      }
-      return false;
-    }
-    function visitBinaryExpression(node, discarded) {
-      if (isDestructuringAssignment(node)) {
-        const savedPendingExpressions = pendingExpressions;
-        pendingExpressions = void 0;
-        node = factory2.updateBinaryExpression(
-          node,
-          visitNode(node.left, assignmentTargetVisitor, isExpression),
-          node.operatorToken,
-          visitNode(node.right, visitor, isExpression)
-        );
-        const expr = some(pendingExpressions) ? factory2.inlineExpressions(compact([...pendingExpressions, node])) : node;
-        pendingExpressions = savedPendingExpressions;
-        return expr;
-      }
-      if (isAssignmentExpression(node)) {
-        if (isNamedEvaluation(node, isAnonymousClassNeedingAssignedName)) {
-          const assignedName = getAssignedNameOfIdentifier(node.left, node.right);
-          const left2 = visitNode(node.left, visitor, isExpression);
-          const right = visitNode(node.right, (node2) => namedEvaluationVisitor(node2, assignedName), isExpression);
-          return factory2.updateBinaryExpression(node, left2, node.operatorToken, right);
-        }
-        const left = skipOuterExpressions(node.left, 8 /* PartiallyEmittedExpressions */ | 1 /* Parentheses */);
-        if (isPrivateIdentifierPropertyAccessExpression(left)) {
-          const info = accessPrivateIdentifier2(left.name);
-          if (info) {
-            return setTextRange(
-              setOriginalNode(
-                createPrivateIdentifierAssignment(info, left.expression, node.right, node.operatorToken.kind),
-                node
-              ),
-              node
-            );
-          }
-        } else if (shouldTransformSuperInStaticInitializers && isSuperProperty(node.left) && currentStaticPropertyDeclarationOrStaticBlock && (lexicalEnvironment == null ? void 0 : lexicalEnvironment.data)) {
-          const { classConstructor, superClassReference, facts } = lexicalEnvironment.data;
-          if (facts & 1 /* ClassWasDecorated */) {
-            return factory2.updateBinaryExpression(
-              node,
-              visitInvalidSuperProperty(node.left),
-              node.operatorToken,
-              visitNode(node.right, visitor, isExpression)
-            );
-          }
-          if (classConstructor && superClassReference) {
-            let setterName = isElementAccessExpression(node.left) ? visitNode(node.left.argumentExpression, visitor, isExpression) : isIdentifier(node.left.name) ? factory2.createStringLiteralFromNode(node.left.name) : void 0;
-            if (setterName) {
-              let expression = visitNode(node.right, visitor, isExpression);
-              if (isCompoundAssignment(node.operatorToken.kind)) {
-                let getterName = setterName;
-                if (!isSimpleInlineableExpression(setterName)) {
-                  getterName = factory2.createTempVariable(hoistVariableDeclaration);
-                  setterName = factory2.createAssignment(getterName, setterName);
-                }
-                const superPropertyGet = factory2.createReflectGetCall(
-                  superClassReference,
-                  getterName,
-                  classConstructor
-                );
-                setOriginalNode(superPropertyGet, node.left);
-                setTextRange(superPropertyGet, node.left);
-                expression = factory2.createBinaryExpression(
-                  superPropertyGet,
-                  getNonAssignmentOperatorForCompoundAssignment(node.operatorToken.kind),
-                  expression
-                );
-                setTextRange(expression, node);
-              }
-              const temp = discarded ? void 0 : factory2.createTempVariable(hoistVariableDeclaration);
-              if (temp) {
-                expression = factory2.createAssignment(temp, expression);
-                setTextRange(temp, node);
-              }
-              expression = factory2.createReflectSetCall(
-                superClassReference,
-                setterName,
-                expression,
-                classConstructor
-              );
-              setOriginalNode(expression, node);
-              setTextRange(expression, node);
-              if (temp) {
-                expression = factory2.createComma(expression, temp);
-                setTextRange(expression, node);
-              }
-              return expression;
-            }
-          }
-        }
-      }
-      if (isPrivateIdentifierInExpression(node)) {
-        return transformPrivateIdentifierInInExpression(node);
-      }
-      return visitEachChild(node, visitor, context);
-    }
-    function visitCommaListExpression(node, discarded) {
-      const elements = discarded ? visitCommaListElements(node.elements, discardedValueVisitor) : visitCommaListElements(node.elements, visitor, discardedValueVisitor);
-      return factory2.updateCommaListExpression(node, elements);
-    }
-    function visitParenthesizedExpression(node, discarded, referencedName) {
-      const visitorFunc = discarded ? discardedValueVisitor : referencedName ? (node2) => namedEvaluationVisitor(node2, referencedName) : visitor;
-      const expression = visitNode(node.expression, visitorFunc, isExpression);
-      return factory2.updateParenthesizedExpression(node, expression);
-    }
-    function visitPartiallyEmittedExpression(node, discarded, referencedName) {
-      const visitorFunc = discarded ? discardedValueVisitor : referencedName ? (node2) => namedEvaluationVisitor(node2, referencedName) : visitor;
-      const expression = visitNode(node.expression, visitorFunc, isExpression);
-      return factory2.updatePartiallyEmittedExpression(node, expression);
-    }
-    function visitReferencedPropertyName(node) {
-      if (isPropertyNameLiteral(node) || isPrivateIdentifier(node)) {
-        const referencedName2 = factory2.createStringLiteralFromNode(node);
-        const name2 = visitNode(node, visitor, isPropertyName);
-        return { referencedName: referencedName2, name: name2 };
-      }
-      if (isPropertyNameLiteral(node.expression) && !isIdentifier(node.expression)) {
-        const referencedName2 = factory2.createStringLiteralFromNode(node.expression);
-        const name2 = visitNode(node, visitor, isPropertyName);
-        return { referencedName: referencedName2, name: name2 };
-      }
-      const referencedName = factory2.createTempVariable(hoistVariableDeclaration);
-      const key = emitHelpers().createPropKeyHelper(visitNode(node.expression, visitor, isExpression));
-      const assignment = factory2.createAssignment(referencedName, key);
-      const name = factory2.updateComputedPropertyName(node, injectPendingExpressions(assignment));
-      return { referencedName, name };
-    }
-    function createPrivateIdentifierAssignment(info, receiver, right, operator) {
-      receiver = visitNode(receiver, visitor, isExpression);
-      right = visitNode(right, visitor, isExpression);
-      if (isCompoundAssignment(operator)) {
-        const { readExpression, initializeExpression } = createCopiableReceiverExpr(receiver);
-        receiver = initializeExpression || readExpression;
-        right = factory2.createBinaryExpression(
-          createPrivateIdentifierAccessHelper(info, readExpression),
-          getNonAssignmentOperatorForCompoundAssignment(operator),
-          right
-        );
-      }
-      setCommentRange(receiver, moveRangePos(receiver, -1));
-      switch (info.kind) {
-        case "a" /* Accessor */:
-          return emitHelpers().createClassPrivateFieldSetHelper(
-            receiver,
-            info.brandCheckIdentifier,
-            right,
-            info.kind,
-            info.setterName
-          );
-        case "m" /* Method */:
-          return emitHelpers().createClassPrivateFieldSetHelper(
-            receiver,
-            info.brandCheckIdentifier,
-            right,
-            info.kind,
-            /*f*/
-            void 0
-          );
-        case "f" /* Field */:
-          return emitHelpers().createClassPrivateFieldSetHelper(
-            receiver,
-            info.brandCheckIdentifier,
-            right,
-            info.kind,
-            info.isStatic ? info.variableName : void 0
-          );
-        case "untransformed":
-          return Debug.fail("Access helpers should not be created for untransformed private elements");
-        default:
-          Debug.assertNever(info, "Unknown private element type");
-      }
-    }
-    function getPrivateInstanceMethodsAndAccessors(node) {
-      return filter(node.members, isNonStaticMethodOrAccessorWithPrivateName);
-    }
-    function getClassFacts(node) {
-      let facts = 0 /* None */;
-      const original = getOriginalNode(node);
-      if (isClassDeclaration(original) && classOrConstructorParameterIsDecorated(legacyDecorators, original)) {
-        facts |= 1 /* ClassWasDecorated */;
-      }
-      let containsPublicInstanceFields = false;
-      let containsInitializedPublicInstanceFields = false;
-      let containsInstancePrivateElements = false;
-      let containsInstanceAutoAccessors = false;
-      for (const member of node.members) {
-        if (isStatic(member)) {
-          if (member.name && (isPrivateIdentifier(member.name) || isAutoAccessorPropertyDeclaration(member)) && shouldTransformPrivateElementsOrClassStaticBlocks) {
-            facts |= 2 /* NeedsClassConstructorReference */;
-          }
-          if (isPropertyDeclaration(member) || isClassStaticBlockDeclaration(member)) {
-            if (shouldTransformThisInStaticInitializers && member.transformFlags & 16384 /* ContainsLexicalThis */) {
-              facts |= 8 /* NeedsSubstitutionForThisInClassStaticField */;
-              if (!(facts & 1 /* ClassWasDecorated */)) {
-                facts |= 2 /* NeedsClassConstructorReference */;
-              }
-            }
-            if (shouldTransformSuperInStaticInitializers && member.transformFlags & 134217728 /* ContainsLexicalSuper */) {
-              if (!(facts & 1 /* ClassWasDecorated */)) {
-                facts |= 2 /* NeedsClassConstructorReference */ | 4 /* NeedsClassSuperReference */;
-              }
-            }
-          }
-        } else if (!hasAbstractModifier(getOriginalNode(member))) {
-          if (isAutoAccessorPropertyDeclaration(member)) {
-            containsInstanceAutoAccessors = true;
-            containsInstancePrivateElements || (containsInstancePrivateElements = isPrivateIdentifierClassElementDeclaration(member));
-          } else if (isPrivateIdentifierClassElementDeclaration(member)) {
-            containsInstancePrivateElements = true;
-          } else if (isPropertyDeclaration(member)) {
-            containsPublicInstanceFields = true;
-            containsInitializedPublicInstanceFields || (containsInitializedPublicInstanceFields = !!member.initializer);
-          }
-        }
-      }
-      const willHoistInitializersToConstructor = shouldTransformInitializersUsingDefine && containsPublicInstanceFields || shouldTransformInitializersUsingSet && containsInitializedPublicInstanceFields || shouldTransformPrivateElementsOrClassStaticBlocks && containsInstancePrivateElements || shouldTransformPrivateElementsOrClassStaticBlocks && containsInstanceAutoAccessors && shouldTransformAutoAccessors === -1 /* True */;
-      if (willHoistInitializersToConstructor) {
-        facts |= 16 /* WillHoistInitializersToConstructor */;
-      }
-      return facts;
-    }
-    function visitExpressionWithTypeArgumentsInHeritageClause(node) {
-      var _a;
-      const facts = ((_a = lexicalEnvironment == null ? void 0 : lexicalEnvironment.data) == null ? void 0 : _a.facts) || 0 /* None */;
-      if (facts & 4 /* NeedsClassSuperReference */) {
-        const temp = factory2.createTempVariable(
-          hoistVariableDeclaration,
-          /*reservedInNestedScopes*/
-          true
-        );
-        getClassLexicalEnvironment().superClassReference = temp;
-        return factory2.updateExpressionWithTypeArguments(
-          node,
-          factory2.createAssignment(
-            temp,
-            visitNode(node.expression, visitor, isExpression)
-          ),
-          /*typeArguments*/
-          void 0
-        );
-      }
-      return visitEachChild(node, visitor, context);
-    }
-    function visitInNewClassLexicalEnvironment(node, referencedName, visitor2) {
-      const savedCurrentClassContainer = currentClassContainer;
-      const savedPendingExpressions = pendingExpressions;
-      const savedLexicalEnvironment = lexicalEnvironment;
-      currentClassContainer = node;
-      pendingExpressions = void 0;
-      startClassLexicalEnvironment();
-      const shouldAlwaysTransformPrivateStaticElements = getInternalEmitFlags(node) & 32 /* TransformPrivateStaticElements */;
-      if (shouldTransformPrivateElementsOrClassStaticBlocks || shouldAlwaysTransformPrivateStaticElements) {
-        const name = getNameOfDeclaration(node);
-        if (name && isIdentifier(name)) {
-          getPrivateIdentifierEnvironment().data.className = name;
-        }
-      }
-      if (shouldTransformPrivateElementsOrClassStaticBlocks) {
-        const privateInstanceMethodsAndAccessors = getPrivateInstanceMethodsAndAccessors(node);
-        if (some(privateInstanceMethodsAndAccessors)) {
-          getPrivateIdentifierEnvironment().data.weakSetName = createHoistedVariableForClass(
-            "instances",
-            privateInstanceMethodsAndAccessors[0].name
-          );
-        }
-      }
-      const facts = getClassFacts(node);
-      if (facts) {
-        getClassLexicalEnvironment().facts = facts;
-      }
-      if (facts & 8 /* NeedsSubstitutionForThisInClassStaticField */) {
-        enableSubstitutionForClassStaticThisOrSuperReference();
-      }
-      const result = visitor2(node, facts, referencedName);
-      endClassLexicalEnvironment();
-      Debug.assert(lexicalEnvironment === savedLexicalEnvironment);
-      currentClassContainer = savedCurrentClassContainer;
-      pendingExpressions = savedPendingExpressions;
-      return result;
-    }
-    function visitClassDeclaration(node) {
-      return visitInNewClassLexicalEnvironment(
-        node,
-        /*referencedName*/
-        void 0,
-        visitClassDeclarationInNewClassLexicalEnvironment
-      );
-    }
-    function visitClassDeclarationInNewClassLexicalEnvironment(node, facts) {
-      var _a, _b;
-      let pendingClassReferenceAssignment;
-      if (facts & 2 /* NeedsClassConstructorReference */) {
-        if (shouldTransformPrivateElementsOrClassStaticBlocks && ((_a = node.emitNode) == null ? void 0 : _a.classThis)) {
-          getClassLexicalEnvironment().classConstructor = node.emitNode.classThis;
-          pendingClassReferenceAssignment = factory2.createAssignment(node.emitNode.classThis, factory2.getInternalName(node));
-        } else {
-          const temp = factory2.createTempVariable(
-            hoistVariableDeclaration,
-            /*reservedInNestedScopes*/
-            true
-          );
-          getClassLexicalEnvironment().classConstructor = factory2.cloneNode(temp);
-          pendingClassReferenceAssignment = factory2.createAssignment(temp, factory2.getInternalName(node));
-        }
-        if ((_b = node.emitNode) == null ? void 0 : _b.classThis) {
-          getClassLexicalEnvironment().classThis = node.emitNode.classThis;
-        }
-      }
-      const isExport = hasSyntacticModifier(node, 1 /* Export */);
-      const isDefault = hasSyntacticModifier(node, 1024 /* Default */);
-      let modifiers = visitNodes2(node.modifiers, modifierVisitor, isModifier);
-      const heritageClauses = visitNodes2(node.heritageClauses, heritageClauseVisitor, isHeritageClause);
-      const { members, prologue } = transformClassMembers(node);
-      const statements = [];
-      if (pendingClassReferenceAssignment) {
-        getPendingExpressions().unshift(pendingClassReferenceAssignment);
-      }
-      if (some(pendingExpressions)) {
-        statements.push(factory2.createExpressionStatement(factory2.inlineExpressions(pendingExpressions)));
-      }
-      if (shouldTransformInitializersUsingSet || shouldTransformPrivateElementsOrClassStaticBlocks || getInternalEmitFlags(node) & 32 /* TransformPrivateStaticElements */) {
-        const staticProperties = getStaticPropertiesAndClassStaticBlock(node);
-        if (some(staticProperties)) {
-          addPropertyOrClassStaticBlockStatements(statements, staticProperties, factory2.getInternalName(node));
-        }
-      }
-      if (statements.length > 0 && isExport && isDefault) {
-        modifiers = visitNodes2(modifiers, (node2) => isExportOrDefaultModifier(node2) ? void 0 : node2, isModifier);
-        statements.push(factory2.createExportAssignment(
-          /*modifiers*/
-          void 0,
-          /*isExportEquals*/
-          false,
-          factory2.getLocalName(
-            node,
-            /*allowComments*/
-            false,
-            /*allowSourceMaps*/
-            true
-          )
-        ));
-      }
-      const classDecl = factory2.updateClassDeclaration(
-        node,
-        modifiers,
-        node.name,
-        /*typeParameters*/
-        void 0,
-        heritageClauses,
-        members
-      );
-      statements.unshift(classDecl);
-      if (prologue) {
-        statements.unshift(factory2.createExpressionStatement(prologue));
-      }
-      return statements;
-    }
-    function visitClassExpression(node, referencedName) {
-      return visitInNewClassLexicalEnvironment(node, referencedName, visitClassExpressionInNewClassLexicalEnvironment);
-    }
-    function visitClassExpressionInNewClassLexicalEnvironment(node, facts, referencedName) {
-      var _a, _b, _c, _d;
-      const isDecoratedClassDeclaration = !!(facts & 1 /* ClassWasDecorated */);
-      const staticPropertiesOrClassStaticBlocks = getStaticPropertiesAndClassStaticBlock(node);
-      const isClassWithConstructorReference = resolver.getNodeCheckFlags(node) & 1048576 /* ClassWithConstructorReference */;
-      let temp;
-      function createClassTempVar() {
-        var _a2;
-        if (shouldTransformPrivateElementsOrClassStaticBlocks && ((_a2 = node.emitNode) == null ? void 0 : _a2.classThis)) {
-          return getClassLexicalEnvironment().classConstructor = node.emitNode.classThis;
-        }
-        const classCheckFlags = resolver.getNodeCheckFlags(node);
-        const isClassWithConstructorReference2 = classCheckFlags & 1048576 /* ClassWithConstructorReference */;
-        const requiresBlockScopedVar = classCheckFlags & 32768 /* BlockScopedBindingInLoop */;
-        const temp2 = factory2.createTempVariable(requiresBlockScopedVar ? addBlockScopedVariable : hoistVariableDeclaration, !!isClassWithConstructorReference2);
-        getClassLexicalEnvironment().classConstructor = factory2.cloneNode(temp2);
-        return temp2;
-      }
-      if ((_a = node.emitNode) == null ? void 0 : _a.classThis) {
-        getClassLexicalEnvironment().classThis = node.emitNode.classThis;
-      }
-      if (facts & 2 /* NeedsClassConstructorReference */) {
-        temp ?? (temp = createClassTempVar());
-      }
-      const modifiers = visitNodes2(node.modifiers, modifierVisitor, isModifier);
-      const heritageClauses = visitNodes2(node.heritageClauses, heritageClauseVisitor, isHeritageClause);
-      const { members, prologue } = transformClassMembers(node);
-      let classExpression = factory2.updateClassExpression(
-        node,
-        modifiers,
-        node.name,
-        /*typeParameters*/
-        void 0,
-        heritageClauses,
-        members
-      );
-      const expressions = [];
-      if (prologue) {
-        expressions.push(prologue);
-      }
-      const hasTransformableStatics = (shouldTransformPrivateElementsOrClassStaticBlocks || getInternalEmitFlags(node) & 32 /* TransformPrivateStaticElements */) && some(staticPropertiesOrClassStaticBlocks, (node2) => isClassStaticBlockDeclaration(node2) || isPrivateIdentifierClassElementDeclaration(node2) || shouldTransformInitializers && isInitializedProperty(node2));
-      if (hasTransformableStatics || some(pendingExpressions) || referencedName) {
-        if (isDecoratedClassDeclaration) {
-          Debug.assertIsDefined(pendingStatements, "Decorated classes transformed by TypeScript are expected to be within a variable declaration.");
-          if (some(pendingExpressions)) {
-            addRange(pendingStatements, map(pendingExpressions, factory2.createExpressionStatement));
-          }
-          if (referencedName) {
-            if (shouldTransformPrivateElementsOrClassStaticBlocks) {
-              const setNameExpression = emitHelpers().createSetFunctionNameHelper(temp ?? ((_b = node.emitNode) == null ? void 0 : _b.classThis) ?? factory2.getInternalName(node), referencedName);
-              pendingStatements.push(factory2.createExpressionStatement(setNameExpression));
-            } else {
-              const setNameExpression = emitHelpers().createSetFunctionNameHelper(factory2.createThis(), referencedName);
-              classExpression = factory2.updateClassExpression(
-                classExpression,
-                classExpression.modifiers,
-                classExpression.name,
-                classExpression.typeParameters,
-                classExpression.heritageClauses,
-                [
-                  factory2.createClassStaticBlockDeclaration(
-                    factory2.createBlock([
-                      factory2.createExpressionStatement(setNameExpression)
-                    ])
-                  ),
-                  ...classExpression.members
-                ]
-              );
-            }
-          }
-          if (some(staticPropertiesOrClassStaticBlocks)) {
-            addPropertyOrClassStaticBlockStatements(pendingStatements, staticPropertiesOrClassStaticBlocks, ((_c = node.emitNode) == null ? void 0 : _c.classThis) ?? factory2.getInternalName(node));
-          }
-          if (temp) {
-            expressions.push(factory2.createAssignment(temp, classExpression));
-          } else if (shouldTransformPrivateElementsOrClassStaticBlocks && ((_d = node.emitNode) == null ? void 0 : _d.classThis)) {
-            expressions.push(factory2.createAssignment(node.emitNode.classThis, classExpression));
-          } else {
-            expressions.push(classExpression);
-          }
-        } else {
-          temp ?? (temp = createClassTempVar());
-          if (isClassWithConstructorReference) {
-            enableSubstitutionForClassAliases();
-            const alias = factory2.cloneNode(temp);
-            alias.emitNode.autoGenerate.flags &= ~8 /* ReservedInNestedScopes */;
-            classAliases[getOriginalNodeId(node)] = alias;
-          }
-          expressions.push(factory2.createAssignment(temp, classExpression));
-          addRange(expressions, pendingExpressions);
-          if (referencedName) {
-            expressions.push(emitHelpers().createSetFunctionNameHelper(temp, referencedName));
-          }
-          addRange(expressions, generateInitializedPropertyExpressionsOrClassStaticBlock(staticPropertiesOrClassStaticBlocks, temp));
-          expressions.push(factory2.cloneNode(temp));
-        }
-      } else {
-        expressions.push(classExpression);
-      }
-      if (expressions.length > 1) {
-        addEmitFlags(classExpression, 131072 /* Indented */);
-        expressions.forEach(startOnNewLine);
-      }
-      return factory2.inlineExpressions(expressions);
-    }
-    function visitClassStaticBlockDeclaration(node) {
-      if (!shouldTransformPrivateElementsOrClassStaticBlocks) {
-        return visitEachChild(node, visitor, context);
-      }
-      return void 0;
-    }
-    function transformClassMembers(node) {
-      const shouldTransformPrivateStaticElementsInClass = !!(getInternalEmitFlags(node) & 32 /* TransformPrivateStaticElements */);
-      if (shouldTransformPrivateElementsOrClassStaticBlocks || shouldTransformPrivateStaticElementsInFile) {
-        for (const member of node.members) {
-          if (isPrivateIdentifierClassElementDeclaration(member)) {
-            if (shouldTransformClassElementToWeakMap(member)) {
-              addPrivateIdentifierToEnvironment(member, member.name, addPrivateIdentifierClassElementToEnvironment);
-            } else {
-              const privateEnv = getPrivateIdentifierEnvironment();
-              setPrivateIdentifier(privateEnv, member.name, { kind: "untransformed" });
-            }
-          }
-        }
-        if (shouldTransformPrivateElementsOrClassStaticBlocks) {
-          if (some(getPrivateInstanceMethodsAndAccessors(node))) {
-            createBrandCheckWeakSetForPrivateMethods();
-          }
-        }
-        if (shouldTransformAutoAccessorsInCurrentClass()) {
-          for (const member of node.members) {
-            if (isAutoAccessorPropertyDeclaration(member)) {
-              const storageName = factory2.getGeneratedPrivateNameForNode(
-                member.name,
-                /*prefix*/
-                void 0,
-                "_accessor_storage"
-              );
-              if (shouldTransformPrivateElementsOrClassStaticBlocks || shouldTransformPrivateStaticElementsInClass && hasStaticModifier(member)) {
-                addPrivateIdentifierToEnvironment(member, storageName, addPrivateIdentifierPropertyDeclarationToEnvironment);
-              } else {
-                const privateEnv = getPrivateIdentifierEnvironment();
-                setPrivateIdentifier(privateEnv, storageName, { kind: "untransformed" });
-              }
-            }
-          }
-        }
-      }
-      let members = visitNodes2(node.members, classElementVisitor, isClassElement);
-      let syntheticConstructor;
-      if (!some(members, isConstructorDeclaration)) {
-        syntheticConstructor = transformConstructor(
-          /*constructor*/
-          void 0,
-          node
-        );
-      }
-      let prologue;
-      let syntheticStaticBlock;
-      if (!shouldTransformPrivateElementsOrClassStaticBlocks && some(pendingExpressions)) {
-        let statement = factory2.createExpressionStatement(factory2.inlineExpressions(pendingExpressions));
-        if (statement.transformFlags & 134234112 /* ContainsLexicalThisOrSuper */) {
-          const temp = factory2.createTempVariable(hoistVariableDeclaration);
-          const arrow = factory2.createArrowFunction(
-            /*modifiers*/
-            void 0,
-            /*typeParameters*/
-            void 0,
-            /*parameters*/
-            [],
-            /*type*/
-            void 0,
-            /*equalsGreaterThanToken*/
-            void 0,
-            factory2.createBlock([statement])
-          );
-          prologue = factory2.createAssignment(temp, arrow);
-          statement = factory2.createExpressionStatement(factory2.createCallExpression(
-            temp,
-            /*typeArguments*/
-            void 0,
-            []
-          ));
-        }
-        const block = factory2.createBlock([statement]);
-        syntheticStaticBlock = factory2.createClassStaticBlockDeclaration(block);
-        pendingExpressions = void 0;
-      }
-      if (syntheticConstructor || syntheticStaticBlock) {
-        let membersArray;
-        membersArray = append(membersArray, syntheticConstructor);
-        membersArray = append(membersArray, syntheticStaticBlock);
-        membersArray = addRange(membersArray, members);
-        members = setTextRange(
-          factory2.createNodeArray(membersArray),
-          /*location*/
-          node.members
-        );
-      }
-      return { members, prologue };
-    }
-    function createBrandCheckWeakSetForPrivateMethods() {
-      const { weakSetName } = getPrivateIdentifierEnvironment().data;
-      Debug.assert(weakSetName, "weakSetName should be set in private identifier environment");
-      getPendingExpressions().push(
-        factory2.createAssignment(
-          weakSetName,
-          factory2.createNewExpression(
-            factory2.createIdentifier("WeakSet"),
-            /*typeArguments*/
-            void 0,
-            []
-          )
-        )
-      );
-    }
-    function transformConstructor(constructor, container) {
-      constructor = visitNode(constructor, visitor, isConstructorDeclaration);
-      if (!(lexicalEnvironment == null ? void 0 : lexicalEnvironment.data) || !(lexicalEnvironment.data.facts & 16 /* WillHoistInitializersToConstructor */)) {
-        return constructor;
-      }
-      const extendsClauseElement = getEffectiveBaseTypeNode(container);
-      const isDerivedClass = !!(extendsClauseElement && skipOuterExpressions(extendsClauseElement.expression).kind !== 106 /* NullKeyword */);
-      const parameters = visitParameterList(constructor ? constructor.parameters : void 0, visitor, context);
-      const body = transformConstructorBody(container, constructor, isDerivedClass);
-      if (!body) {
-        return constructor;
-      }
-      if (constructor) {
-        Debug.assert(parameters);
-        return factory2.updateConstructorDeclaration(
-          constructor,
-          /*modifiers*/
-          void 0,
-          parameters,
-          body
-        );
-      }
-      return startOnNewLine(
-        setOriginalNode(
-          setTextRange(
-            factory2.createConstructorDeclaration(
-              /*modifiers*/
-              void 0,
-              parameters ?? [],
-              body
-            ),
-            constructor || container
-          ),
-          constructor
-        )
-      );
-    }
-    function transformConstructorBody(node, constructor, isDerivedClass) {
-      var _a;
-      const instanceProperties = getProperties(
-        node,
-        /*requireInitializer*/
-        false,
-        /*isStatic*/
-        false
-      );
-      let properties = instanceProperties;
-      if (!useDefineForClassFields) {
-        properties = filter(properties, (property) => !!property.initializer || isPrivateIdentifier(property.name) || hasAccessorModifier(property));
-      }
-      const privateMethodsAndAccessors = getPrivateInstanceMethodsAndAccessors(node);
-      const needsConstructorBody = some(properties) || some(privateMethodsAndAccessors);
-      if (!constructor && !needsConstructorBody) {
-        return visitFunctionBody(
-          /*node*/
-          void 0,
-          visitor,
-          context
-        );
-      }
-      resumeLexicalEnvironment();
-      const needsSyntheticConstructor = !constructor && isDerivedClass;
-      let indexOfFirstStatementAfterSuperAndPrologue = 0;
-      let prologueStatementCount = 0;
-      let superStatementIndex = -1;
-      let statements = [];
-      if ((_a = constructor == null ? void 0 : constructor.body) == null ? void 0 : _a.statements) {
-        prologueStatementCount = factory2.copyPrologue(
-          constructor.body.statements,
-          statements,
-          /*ensureUseStrict*/
-          false,
-          visitor
-        );
-        superStatementIndex = findSuperStatementIndex(constructor.body.statements, prologueStatementCount);
-        if (superStatementIndex >= 0) {
-          indexOfFirstStatementAfterSuperAndPrologue = superStatementIndex + 1;
-          statements = [
-            ...statements.slice(0, prologueStatementCount),
-            ...visitNodes2(constructor.body.statements, visitor, isStatement, prologueStatementCount, indexOfFirstStatementAfterSuperAndPrologue - prologueStatementCount),
-            ...statements.slice(prologueStatementCount)
-          ];
-        } else if (prologueStatementCount >= 0) {
-          indexOfFirstStatementAfterSuperAndPrologue = prologueStatementCount;
-        }
-      }
-      if (needsSyntheticConstructor) {
-        statements.push(
-          factory2.createExpressionStatement(
-            factory2.createCallExpression(
-              factory2.createSuper(),
-              /*typeArguments*/
-              void 0,
-              [factory2.createSpreadElement(factory2.createIdentifier("arguments"))]
-            )
-          )
-        );
-      }
-      let parameterPropertyDeclarationCount = 0;
-      if (constructor == null ? void 0 : constructor.body) {
-        for (let i = indexOfFirstStatementAfterSuperAndPrologue; i < constructor.body.statements.length; i++) {
-          const statement = constructor.body.statements[i];
-          if (isParameterPropertyDeclaration(getOriginalNode(statement), constructor)) {
-            parameterPropertyDeclarationCount++;
-          } else {
-            break;
-          }
-        }
-        if (parameterPropertyDeclarationCount > 0) {
-          indexOfFirstStatementAfterSuperAndPrologue += parameterPropertyDeclarationCount;
-        }
-      }
-      const receiver = factory2.createThis();
-      addInstanceMethodStatements(statements, privateMethodsAndAccessors, receiver);
-      if (constructor) {
-        const parameterProperties = filter(instanceProperties, (prop) => isParameterPropertyDeclaration(getOriginalNode(prop), constructor));
-        const nonParameterProperties = filter(properties, (prop) => !isParameterPropertyDeclaration(getOriginalNode(prop), constructor));
-        addPropertyOrClassStaticBlockStatements(statements, parameterProperties, receiver);
-        addPropertyOrClassStaticBlockStatements(statements, nonParameterProperties, receiver);
-      } else {
-        addPropertyOrClassStaticBlockStatements(statements, properties, receiver);
-      }
-      if (constructor) {
-        addRange(statements, visitNodes2(constructor.body.statements, visitor, isStatement, indexOfFirstStatementAfterSuperAndPrologue));
-      }
-      statements = factory2.mergeLexicalEnvironment(statements, endLexicalEnvironment());
-      if (statements.length === 0 && !constructor) {
-        return void 0;
-      }
-      const multiLine = (constructor == null ? void 0 : constructor.body) && constructor.body.statements.length >= statements.length ? constructor.body.multiLine ?? statements.length > 0 : statements.length > 0;
-      return setTextRange(
-        factory2.createBlock(
-          setTextRange(
-            factory2.createNodeArray(statements),
-            /*location*/
-            constructor ? constructor.body.statements : node.members
-          ),
-          multiLine
-        ),
-        /*location*/
-        constructor ? constructor.body : void 0
-      );
-    }
-    function addPropertyOrClassStaticBlockStatements(statements, properties, receiver) {
-      for (const property of properties) {
-        if (isStatic(property) && !shouldTransformPrivateElementsOrClassStaticBlocks) {
-          continue;
-        }
-        const statement = transformPropertyOrClassStaticBlock(property, receiver);
-        if (!statement) {
-          continue;
-        }
-        statements.push(statement);
-      }
-    }
-    function transformPropertyOrClassStaticBlock(property, receiver) {
-      const expression = isClassStaticBlockDeclaration(property) ? transformClassStaticBlockDeclaration(property) : transformProperty(property, receiver);
-      if (!expression) {
-        return void 0;
-      }
-      const statement = factory2.createExpressionStatement(expression);
-      setOriginalNode(statement, property);
-      addEmitFlags(statement, getEmitFlags(property) & 3072 /* NoComments */);
-      setCommentRange(statement, property);
-      const propertyOriginalNode = getOriginalNode(property);
-      if (isParameter(propertyOriginalNode)) {
-        setSourceMapRange(statement, propertyOriginalNode);
-        removeAllComments(statement);
-      } else {
-        setSourceMapRange(statement, moveRangePastModifiers(property));
-      }
-      setSyntheticLeadingComments(expression, void 0);
-      setSyntheticTrailingComments(expression, void 0);
-      if (hasAccessorModifier(propertyOriginalNode)) {
-        addEmitFlags(statement, 3072 /* NoComments */);
-      }
-      return statement;
-    }
-    function generateInitializedPropertyExpressionsOrClassStaticBlock(propertiesOrClassStaticBlocks, receiver) {
-      const expressions = [];
-      for (const property of propertiesOrClassStaticBlocks) {
-        const expression = isClassStaticBlockDeclaration(property) ? transformClassStaticBlockDeclaration(property) : transformProperty(property, receiver);
-        if (!expression) {
-          continue;
-        }
-        startOnNewLine(expression);
-        setOriginalNode(expression, property);
-        addEmitFlags(expression, getEmitFlags(property) & 3072 /* NoComments */);
-        setSourceMapRange(expression, moveRangePastModifiers(property));
-        setCommentRange(expression, property);
-        expressions.push(expression);
-      }
-      return expressions;
-    }
-    function transformProperty(property, receiver) {
-      var _a;
-      const savedCurrentStaticPropertyDeclarationOrStaticBlock = currentStaticPropertyDeclarationOrStaticBlock;
-      const transformed = transformPropertyWorker(property, receiver);
-      if (transformed && hasStaticModifier(property) && ((_a = lexicalEnvironment == null ? void 0 : lexicalEnvironment.data) == null ? void 0 : _a.facts)) {
-        setOriginalNode(transformed, property);
-        addEmitFlags(transformed, 4 /* AdviseOnEmitNode */);
-        setSourceMapRange(transformed, getSourceMapRange(property.name));
-        lexicalEnvironmentMap.set(getOriginalNode(property), lexicalEnvironment);
-      }
-      currentStaticPropertyDeclarationOrStaticBlock = savedCurrentStaticPropertyDeclarationOrStaticBlock;
-      return transformed;
-    }
-    function transformPropertyWorker(property, receiver) {
-      const emitAssignment = !useDefineForClassFields;
-      let referencedName;
-      if (isNamedEvaluation(property, isAnonymousClassNeedingAssignedName)) {
-        if (isPropertyNameLiteral(property.name) || isPrivateIdentifier(property.name)) {
-          referencedName = factory2.createStringLiteralFromNode(property.name);
-        } else if (isPropertyNameLiteral(property.name.expression) && !isIdentifier(property.name.expression)) {
-          referencedName = factory2.createStringLiteralFromNode(property.name.expression);
-        } else {
-          referencedName = factory2.getGeneratedNameForNode(property.name);
-        }
-      }
-      const propertyName = hasAccessorModifier(property) ? factory2.getGeneratedPrivateNameForNode(property.name) : isComputedPropertyName(property.name) && !isSimpleInlineableExpression(property.name.expression) ? factory2.updateComputedPropertyName(property.name, factory2.getGeneratedNameForNode(property.name)) : property.name;
-      if (hasStaticModifier(property)) {
-        currentStaticPropertyDeclarationOrStaticBlock = property;
-      }
-      const initializerVisitor = referencedName ? (child) => namedEvaluationVisitor(child, referencedName) : visitor;
-      if (isPrivateIdentifier(propertyName) && shouldTransformClassElementToWeakMap(property)) {
-        const privateIdentifierInfo = accessPrivateIdentifier2(propertyName);
-        if (privateIdentifierInfo) {
-          if (privateIdentifierInfo.kind === "f" /* Field */) {
-            if (!privateIdentifierInfo.isStatic) {
-              return createPrivateInstanceFieldInitializer(
-                factory2,
-                receiver,
-                visitNode(property.initializer, initializerVisitor, isExpression),
-                privateIdentifierInfo.brandCheckIdentifier
-              );
-            } else {
-              return createPrivateStaticFieldInitializer(
-                factory2,
-                privateIdentifierInfo.variableName,
-                visitNode(property.initializer, initializerVisitor, isExpression)
-              );
-            }
-          } else {
-            return void 0;
-          }
-        } else {
-          Debug.fail("Undeclared private name for property declaration.");
-        }
-      }
-      if ((isPrivateIdentifier(propertyName) || hasStaticModifier(property)) && !property.initializer) {
-        return void 0;
-      }
-      const propertyOriginalNode = getOriginalNode(property);
-      if (hasSyntacticModifier(propertyOriginalNode, 256 /* Abstract */)) {
-        return void 0;
-      }
-      let initializer = visitNode(property.initializer, initializerVisitor, isExpression);
-      if (isParameterPropertyDeclaration(propertyOriginalNode, propertyOriginalNode.parent) && isIdentifier(propertyName)) {
-        const localName = factory2.cloneNode(propertyName);
-        if (initializer) {
-          if (isParenthesizedExpression(initializer) && isCommaExpression(initializer.expression) && isCallToHelper(initializer.expression.left, "___runInitializers") && isVoidExpression(initializer.expression.right) && isNumericLiteral(initializer.expression.right.expression)) {
-            initializer = initializer.expression.left;
-          }
-          initializer = factory2.inlineExpressions([initializer, localName]);
-        } else {
-          initializer = localName;
-        }
-        setEmitFlags(propertyName, 3072 /* NoComments */ | 96 /* NoSourceMap */);
-        setSourceMapRange(localName, propertyOriginalNode.name);
-        setEmitFlags(localName, 3072 /* NoComments */);
-      } else {
-        initializer ?? (initializer = factory2.createVoidZero());
-      }
-      if (emitAssignment || isPrivateIdentifier(propertyName)) {
-        const memberAccess = createMemberAccessForPropertyName(
-          factory2,
-          receiver,
-          propertyName,
-          /*location*/
-          propertyName
-        );
-        addEmitFlags(memberAccess, 1024 /* NoLeadingComments */);
-        const expression = factory2.createAssignment(memberAccess, initializer);
-        return expression;
-      } else {
-        const name = isComputedPropertyName(propertyName) ? propertyName.expression : isIdentifier(propertyName) ? factory2.createStringLiteral(unescapeLeadingUnderscores(propertyName.escapedText)) : propertyName;
-        const descriptor = factory2.createPropertyDescriptor({ value: initializer, configurable: true, writable: true, enumerable: true });
-        return factory2.createObjectDefinePropertyCall(receiver, name, descriptor);
-      }
-    }
-    function enableSubstitutionForClassAliases() {
-      if ((enabledSubstitutions & 1 /* ClassAliases */) === 0) {
-        enabledSubstitutions |= 1 /* ClassAliases */;
-        context.enableSubstitution(80 /* Identifier */);
-        classAliases = [];
-      }
-    }
-    function enableSubstitutionForClassStaticThisOrSuperReference() {
-      if ((enabledSubstitutions & 2 /* ClassStaticThisOrSuperReference */) === 0) {
-        enabledSubstitutions |= 2 /* ClassStaticThisOrSuperReference */;
-        context.enableSubstitution(110 /* ThisKeyword */);
-        context.enableEmitNotification(261 /* FunctionDeclaration */);
-        context.enableEmitNotification(217 /* FunctionExpression */);
-        context.enableEmitNotification(175 /* Constructor */);
-        context.enableEmitNotification(176 /* GetAccessor */);
-        context.enableEmitNotification(177 /* SetAccessor */);
-        context.enableEmitNotification(173 /* MethodDeclaration */);
-        context.enableEmitNotification(171 /* PropertyDeclaration */);
-        context.enableEmitNotification(166 /* ComputedPropertyName */);
-      }
-    }
-    function addInstanceMethodStatements(statements, methods, receiver) {
-      if (!shouldTransformPrivateElementsOrClassStaticBlocks || !some(methods)) {
-        return;
-      }
-      const { weakSetName } = getPrivateIdentifierEnvironment().data;
-      Debug.assert(weakSetName, "weakSetName should be set in private identifier environment");
-      statements.push(
-        factory2.createExpressionStatement(
-          createPrivateInstanceMethodInitializer(factory2, receiver, weakSetName)
-        )
-      );
-    }
-    function visitInvalidSuperProperty(node) {
-      return isPropertyAccessExpression(node) ? factory2.updatePropertyAccessExpression(
-        node,
-        factory2.createVoidZero(),
-        node.name
-      ) : factory2.updateElementAccessExpression(
-        node,
-        factory2.createVoidZero(),
-        visitNode(node.argumentExpression, visitor, isExpression)
-      );
-    }
-    function getPropertyNameExpressionIfNeeded(name, shouldHoist, captureReferencedName) {
-      if (isComputedPropertyName(name)) {
-        const cacheAssignment = findComputedPropertyNameCacheAssignment(name);
-        let expression = visitNode(name.expression, visitor, isExpression);
-        const innerExpression = skipPartiallyEmittedExpressions(expression);
-        const inlinable = isSimpleInlineableExpression(innerExpression);
-        const alreadyTransformed = !!cacheAssignment || isAssignmentExpression(innerExpression) && isGeneratedIdentifier(innerExpression.left);
-        if (!alreadyTransformed && !inlinable && shouldHoist) {
-          const generatedName = factory2.getGeneratedNameForNode(name);
-          if (resolver.getNodeCheckFlags(name) & 32768 /* BlockScopedBindingInLoop */) {
-            addBlockScopedVariable(generatedName);
-          } else {
-            hoistVariableDeclaration(generatedName);
-          }
-          if (captureReferencedName) {
-            expression = emitHelpers().createPropKeyHelper(expression);
-          }
-          return factory2.createAssignment(generatedName, expression);
-        }
-        return inlinable || isIdentifier(innerExpression) ? void 0 : expression;
-      }
-    }
-    function startClassLexicalEnvironment() {
-      lexicalEnvironment = { previous: lexicalEnvironment, data: void 0 };
-    }
-    function endClassLexicalEnvironment() {
-      lexicalEnvironment = lexicalEnvironment == null ? void 0 : lexicalEnvironment.previous;
-    }
-    function getClassLexicalEnvironment() {
-      Debug.assert(lexicalEnvironment);
-      return lexicalEnvironment.data ?? (lexicalEnvironment.data = {
-        facts: 0 /* None */,
-        classConstructor: void 0,
-        classThis: void 0,
-        superClassReference: void 0
-        // privateIdentifierEnvironment: undefined,
-      });
-    }
-    function getPrivateIdentifierEnvironment() {
-      Debug.assert(lexicalEnvironment);
-      return lexicalEnvironment.privateEnv ?? (lexicalEnvironment.privateEnv = newPrivateEnvironment({
-        className: void 0,
-        weakSetName: void 0
-      }));
-    }
-    function getPendingExpressions() {
-      return pendingExpressions ?? (pendingExpressions = []);
-    }
-    function addPrivateIdentifierClassElementToEnvironment(node, name, lex, privateEnv, isStatic2, isValid, previousInfo) {
-      if (isAutoAccessorPropertyDeclaration(node)) {
-        addPrivateIdentifierAutoAccessorPropertyDeclarationToEnvironment(node, name, lex, privateEnv, isStatic2, isValid, previousInfo);
-      } else if (isPropertyDeclaration(node)) {
-        addPrivateIdentifierPropertyDeclarationToEnvironment(node, name, lex, privateEnv, isStatic2, isValid, previousInfo);
-      } else if (isMethodDeclaration(node)) {
-        addPrivateIdentifierMethodDeclarationToEnvironment(node, name, lex, privateEnv, isStatic2, isValid, previousInfo);
-      } else if (isGetAccessorDeclaration(node)) {
-        addPrivateIdentifierGetAccessorDeclarationToEnvironment(node, name, lex, privateEnv, isStatic2, isValid, previousInfo);
-      } else if (isSetAccessorDeclaration(node)) {
-        addPrivateIdentifierSetAccessorDeclarationToEnvironment(node, name, lex, privateEnv, isStatic2, isValid, previousInfo);
-      }
-    }
-    function addPrivateIdentifierPropertyDeclarationToEnvironment(_node, name, lex, privateEnv, isStatic2, isValid, _previousInfo) {
-      if (isStatic2) {
-        const brandCheckIdentifier = Debug.checkDefined(lex.classThis ?? lex.classConstructor, "classConstructor should be set in private identifier environment");
-        const variableName = createHoistedVariableForPrivateName(name);
-        setPrivateIdentifier(privateEnv, name, {
-          kind: "f" /* Field */,
-          isStatic: true,
-          brandCheckIdentifier,
-          variableName,
-          isValid
-        });
-      } else {
-        const weakMapName = createHoistedVariableForPrivateName(name);
-        setPrivateIdentifier(privateEnv, name, {
-          kind: "f" /* Field */,
-          isStatic: false,
-          brandCheckIdentifier: weakMapName,
-          isValid
-        });
-        getPendingExpressions().push(factory2.createAssignment(
-          weakMapName,
-          factory2.createNewExpression(
-            factory2.createIdentifier("WeakMap"),
-            /*typeArguments*/
-            void 0,
-            []
-          )
-        ));
-      }
-    }
-    function addPrivateIdentifierMethodDeclarationToEnvironment(_node, name, lex, privateEnv, isStatic2, isValid, _previousInfo) {
-      const methodName = createHoistedVariableForPrivateName(name);
-      const brandCheckIdentifier = isStatic2 ? Debug.checkDefined(lex.classThis ?? lex.classConstructor, "classConstructor should be set in private identifier environment") : Debug.checkDefined(privateEnv.data.weakSetName, "weakSetName should be set in private identifier environment");
-      setPrivateIdentifier(privateEnv, name, {
-        kind: "m" /* Method */,
-        methodName,
-        brandCheckIdentifier,
-        isStatic: isStatic2,
-        isValid
-      });
-    }
-    function addPrivateIdentifierGetAccessorDeclarationToEnvironment(_node, name, lex, privateEnv, isStatic2, isValid, previousInfo) {
-      const getterName = createHoistedVariableForPrivateName(name, "_get");
-      const brandCheckIdentifier = isStatic2 ? Debug.checkDefined(lex.classThis ?? lex.classConstructor, "classConstructor should be set in private identifier environment") : Debug.checkDefined(privateEnv.data.weakSetName, "weakSetName should be set in private identifier environment");
-      if ((previousInfo == null ? void 0 : previousInfo.kind) === "a" /* Accessor */ && previousInfo.isStatic === isStatic2 && !previousInfo.getterName) {
-        previousInfo.getterName = getterName;
-      } else {
-        setPrivateIdentifier(privateEnv, name, {
-          kind: "a" /* Accessor */,
-          getterName,
-          setterName: void 0,
-          brandCheckIdentifier,
-          isStatic: isStatic2,
-          isValid
-        });
-      }
-    }
-    function addPrivateIdentifierSetAccessorDeclarationToEnvironment(_node, name, lex, privateEnv, isStatic2, isValid, previousInfo) {
-      const setterName = createHoistedVariableForPrivateName(name, "_set");
-      const brandCheckIdentifier = isStatic2 ? Debug.checkDefined(lex.classThis ?? lex.classConstructor, "classConstructor should be set in private identifier environment") : Debug.checkDefined(privateEnv.data.weakSetName, "weakSetName should be set in private identifier environment");
-      if ((previousInfo == null ? void 0 : previousInfo.kind) === "a" /* Accessor */ && previousInfo.isStatic === isStatic2 && !previousInfo.setterName) {
-        previousInfo.setterName = setterName;
-      } else {
-        setPrivateIdentifier(privateEnv, name, {
-          kind: "a" /* Accessor */,
-          getterName: void 0,
-          setterName,
-          brandCheckIdentifier,
-          isStatic: isStatic2,
-          isValid
-        });
-      }
-    }
-    function addPrivateIdentifierAutoAccessorPropertyDeclarationToEnvironment(_node, name, lex, privateEnv, isStatic2, isValid, _previousInfo) {
-      const getterName = createHoistedVariableForPrivateName(name, "_get");
-      const setterName = createHoistedVariableForPrivateName(name, "_set");
-      const brandCheckIdentifier = isStatic2 ? Debug.checkDefined(lex.classThis ?? lex.classConstructor, "classConstructor should be set in private identifier environment") : Debug.checkDefined(privateEnv.data.weakSetName, "weakSetName should be set in private identifier environment");
-      setPrivateIdentifier(privateEnv, name, {
-        kind: "a" /* Accessor */,
-        getterName,
-        setterName,
-        brandCheckIdentifier,
-        isStatic: isStatic2,
-        isValid
-      });
-    }
-    function addPrivateIdentifierToEnvironment(node, name, addDeclaration) {
-      const lex = getClassLexicalEnvironment();
-      const privateEnv = getPrivateIdentifierEnvironment();
-      const previousInfo = getPrivateIdentifier(privateEnv, name);
-      const isStatic2 = hasStaticModifier(node);
-      const isValid = !isReservedPrivateName(name) && previousInfo === void 0;
-      addDeclaration(node, name, lex, privateEnv, isStatic2, isValid, previousInfo);
-    }
-    function createHoistedVariableForClass(name, node, suffix) {
-      const { className } = getPrivateIdentifierEnvironment().data;
-      const prefix = className ? { prefix: "_", node: className, suffix: "_" } : "_";
-      const identifier = typeof name === "object" ? factory2.getGeneratedNameForNode(name, 16 /* Optimistic */ | 8 /* ReservedInNestedScopes */, prefix, suffix) : typeof name === "string" ? factory2.createUniqueName(name, 16 /* Optimistic */, prefix, suffix) : factory2.createTempVariable(
-        /*recordTempVariable*/
-        void 0,
-        /*reservedInNestedScopes*/
-        true,
-        prefix,
-        suffix
-      );
-      if (resolver.getNodeCheckFlags(node) & 32768 /* BlockScopedBindingInLoop */) {
-        addBlockScopedVariable(identifier);
-      } else {
-        hoistVariableDeclaration(identifier);
-      }
-      return identifier;
-    }
-    function createHoistedVariableForPrivateName(name, suffix) {
-      const text = tryGetTextOfPropertyName(name);
-      return createHoistedVariableForClass((text == null ? void 0 : text.substring(1)) ?? name, name, suffix);
-    }
-    function accessPrivateIdentifier2(name) {
-      const info = accessPrivateIdentifier(lexicalEnvironment, name);
-      return (info == null ? void 0 : info.kind) === "untransformed" ? void 0 : info;
-    }
-    function wrapPrivateIdentifierForDestructuringTarget(node) {
-      const parameter = factory2.getGeneratedNameForNode(node);
-      const info = accessPrivateIdentifier2(node.name);
-      if (!info) {
-        return visitEachChild(node, visitor, context);
-      }
-      let receiver = node.expression;
-      if (isThisProperty(node) || isSuperProperty(node) || !isSimpleCopiableExpression(node.expression)) {
-        receiver = factory2.createTempVariable(
-          hoistVariableDeclaration,
-          /*reservedInNestedScopes*/
-          true
-        );
-        getPendingExpressions().push(factory2.createBinaryExpression(receiver, 64 /* EqualsToken */, visitNode(node.expression, visitor, isExpression)));
-      }
-      return factory2.createAssignmentTargetWrapper(
-        parameter,
-        createPrivateIdentifierAssignment(
-          info,
-          receiver,
-          parameter,
-          64 /* EqualsToken */
-        )
-      );
-    }
-    function visitDestructuringAssignmentTarget(node) {
-      if (isObjectLiteralExpression(node) || isArrayLiteralExpression(node)) {
-        return visitAssignmentPattern(node);
-      }
-      if (isPrivateIdentifierPropertyAccessExpression(node)) {
-        return wrapPrivateIdentifierForDestructuringTarget(node);
-      } else if (shouldTransformSuperInStaticInitializers && isSuperProperty(node) && currentStaticPropertyDeclarationOrStaticBlock && (lexicalEnvironment == null ? void 0 : lexicalEnvironment.data)) {
-        const { classConstructor, superClassReference, facts } = lexicalEnvironment.data;
-        if (facts & 1 /* ClassWasDecorated */) {
-          return visitInvalidSuperProperty(node);
-        } else if (classConstructor && superClassReference) {
-          const name = isElementAccessExpression(node) ? visitNode(node.argumentExpression, visitor, isExpression) : isIdentifier(node.name) ? factory2.createStringLiteralFromNode(node.name) : void 0;
-          if (name) {
-            const temp = factory2.createTempVariable(
-              /*recordTempVariable*/
-              void 0
-            );
-            return factory2.createAssignmentTargetWrapper(
-              temp,
-              factory2.createReflectSetCall(
-                superClassReference,
-                name,
-                temp,
-                classConstructor
-              )
-            );
-          }
-        }
-      }
-      return visitEachChild(node, visitor, context);
-    }
-    function visitAssignmentElement(node) {
-      if (isNamedEvaluation(node, isAnonymousClassNeedingAssignedName)) {
-        const left = visitDestructuringAssignmentTarget(node.left);
-        const assignedName = getAssignedNameOfIdentifier(node.left, node.right);
-        const right = visitNode(node.right, (node2) => namedEvaluationVisitor(node2, assignedName), isExpression);
-        return factory2.updateBinaryExpression(node, left, node.operatorToken, right);
-      }
-      if (isAssignmentExpression(
-        node,
-        /*excludeCompoundAssignment*/
-        true
-      )) {
-        const left = visitDestructuringAssignmentTarget(node.left);
-        const right = visitNode(node.right, visitor, isExpression);
-        return factory2.updateBinaryExpression(node, left, node.operatorToken, right);
-      }
-      return visitDestructuringAssignmentTarget(node);
-    }
-    function visitAssignmentRestElement(node) {
-      if (isLeftHandSideExpression(node.expression)) {
-        const expression = visitDestructuringAssignmentTarget(node.expression);
-        return factory2.updateSpreadElement(node, expression);
-      }
-      return visitEachChild(node, visitor, context);
-    }
-    function visitArrayAssignmentElement(node) {
-      if (isArrayBindingOrAssignmentElement(node)) {
-        if (isSpreadElement(node))
-          return visitAssignmentRestElement(node);
-        if (!isOmittedExpression(node))
-          return visitAssignmentElement(node);
-      }
-      return visitEachChild(node, visitor, context);
-    }
-    function visitAssignmentProperty(node) {
-      const name = visitNode(node.name, visitor, isPropertyName);
-      if (isAssignmentExpression(
-        node.initializer,
-        /*excludeCompoundAssignment*/
-        true
-      )) {
-        const assignmentElement = visitAssignmentElement(node.initializer);
-        return factory2.updatePropertyAssignment(node, name, assignmentElement);
-      }
-      if (isLeftHandSideExpression(node.initializer)) {
-        const assignmentElement = visitDestructuringAssignmentTarget(node.initializer);
-        return factory2.updatePropertyAssignment(node, name, assignmentElement);
-      }
-      return visitEachChild(node, visitor, context);
-    }
-    function visitShorthandAssignmentProperty(node) {
-      if (isNamedEvaluation(node, isAnonymousClassNeedingAssignedName)) {
-        const assignedName = getAssignedNameOfIdentifier(node.name, node.objectAssignmentInitializer);
-        const objectAssignmentInitializer = visitNode(node.objectAssignmentInitializer, (node2) => namedEvaluationVisitor(node2, assignedName), isExpression);
-        return factory2.updateShorthandPropertyAssignment(node, node.name, objectAssignmentInitializer);
-      }
-      return visitEachChild(node, visitor, context);
-    }
-    function visitAssignmentRestProperty(node) {
-      if (isLeftHandSideExpression(node.expression)) {
-        const expression = visitDestructuringAssignmentTarget(node.expression);
-        return factory2.updateSpreadAssignment(node, expression);
-      }
-      return visitEachChild(node, visitor, context);
-    }
-    function visitObjectAssignmentElement(node) {
-      Debug.assertNode(node, isObjectBindingOrAssignmentElement);
-      if (isSpreadAssignment(node))
-        return visitAssignmentRestProperty(node);
-      if (isShorthandPropertyAssignment(node))
-        return visitShorthandAssignmentProperty(node);
-      if (isPropertyAssignment(node))
-        return visitAssignmentProperty(node);
-      return visitEachChild(node, visitor, context);
-    }
-    function visitAssignmentPattern(node) {
-      if (isArrayLiteralExpression(node)) {
-        return factory2.updateArrayLiteralExpression(
-          node,
-          visitNodes2(node.elements, visitArrayAssignmentElement, isExpression)
-        );
-      } else {
-        return factory2.updateObjectLiteralExpression(
-          node,
-          visitNodes2(node.properties, visitObjectAssignmentElement, isObjectLiteralElementLike)
-        );
-      }
-    }
-    function onEmitNode(hint, node, emitCallback) {
-      const original = getOriginalNode(node);
-      const lex = lexicalEnvironmentMap.get(original);
-      if (lex) {
-        const savedLexicalEnvironment = lexicalEnvironment;
-        const savedPreviousShouldSubstituteThisWithClassThis = previousShouldSubstituteThisWithClassThis;
-        lexicalEnvironment = lex;
-        previousShouldSubstituteThisWithClassThis = shouldSubstituteThisWithClassThis;
-        shouldSubstituteThisWithClassThis = !isClassStaticBlockDeclaration(original) || !(getInternalEmitFlags(original) & 32 /* TransformPrivateStaticElements */);
-        previousOnEmitNode(hint, node, emitCallback);
-        shouldSubstituteThisWithClassThis = previousShouldSubstituteThisWithClassThis;
-        previousShouldSubstituteThisWithClassThis = savedPreviousShouldSubstituteThisWithClassThis;
-        lexicalEnvironment = savedLexicalEnvironment;
-        return;
-      }
-      switch (node.kind) {
-        case 217 /* FunctionExpression */:
-          if (isArrowFunction(original) || getEmitFlags(node) & 524288 /* AsyncFunctionBody */) {
-            break;
-          }
-        case 261 /* FunctionDeclaration */:
-        case 175 /* Constructor */:
-        case 176 /* GetAccessor */:
-        case 177 /* SetAccessor */:
-        case 173 /* MethodDeclaration */:
-        case 171 /* PropertyDeclaration */: {
-          const savedLexicalEnvironment = lexicalEnvironment;
-          const savedPreviousShouldSubstituteThisWithClassThis = previousShouldSubstituteThisWithClassThis;
-          lexicalEnvironment = void 0;
-          previousShouldSubstituteThisWithClassThis = shouldSubstituteThisWithClassThis;
-          shouldSubstituteThisWithClassThis = false;
-          previousOnEmitNode(hint, node, emitCallback);
-          shouldSubstituteThisWithClassThis = previousShouldSubstituteThisWithClassThis;
-          previousShouldSubstituteThisWithClassThis = savedPreviousShouldSubstituteThisWithClassThis;
-          lexicalEnvironment = savedLexicalEnvironment;
-          return;
-        }
-        case 166 /* ComputedPropertyName */: {
-          const savedLexicalEnvironment = lexicalEnvironment;
-          const savedShouldSubstituteThisWithClassThis = shouldSubstituteThisWithClassThis;
-          lexicalEnvironment = lexicalEnvironment == null ? void 0 : lexicalEnvironment.previous;
-          shouldSubstituteThisWithClassThis = previousShouldSubstituteThisWithClassThis;
-          previousOnEmitNode(hint, node, emitCallback);
-          shouldSubstituteThisWithClassThis = savedShouldSubstituteThisWithClassThis;
-          lexicalEnvironment = savedLexicalEnvironment;
-          return;
-        }
-      }
-      previousOnEmitNode(hint, node, emitCallback);
-    }
-    function onSubstituteNode(hint, node) {
-      node = previousOnSubstituteNode(hint, node);
-      if (hint === 1 /* Expression */) {
-        return substituteExpression(node);
-      }
-      return node;
-    }
-    function substituteExpression(node) {
-      switch (node.kind) {
-        case 80 /* Identifier */:
-          return substituteExpressionIdentifier(node);
-        case 110 /* ThisKeyword */:
-          return substituteThisExpression(node);
-      }
-      return node;
-    }
-    function substituteThisExpression(node) {
-      if (enabledSubstitutions & 2 /* ClassStaticThisOrSuperReference */ && (lexicalEnvironment == null ? void 0 : lexicalEnvironment.data)) {
-        const { facts, classConstructor, classThis } = lexicalEnvironment.data;
-        if (facts & 1 /* ClassWasDecorated */ && legacyDecorators) {
-          return factory2.createParenthesizedExpression(factory2.createVoidZero());
-        }
-        const substituteThis = shouldSubstituteThisWithClassThis ? classThis ?? classConstructor : classConstructor;
-        if (substituteThis) {
-          return setTextRange(
-            setOriginalNode(
-              factory2.cloneNode(substituteThis),
-              node
-            ),
-            node
-          );
-        }
-      }
-      return node;
-    }
-    function substituteExpressionIdentifier(node) {
-      return trySubstituteClassAlias(node) || node;
-    }
-    function trySubstituteClassAlias(node) {
-      if (enabledSubstitutions & 1 /* ClassAliases */) {
-        if (resolver.getNodeCheckFlags(node) & 2097152 /* ConstructorReferenceInClass */) {
-          const declaration = resolver.getReferencedValueDeclaration(node);
-          if (declaration) {
-            const classAlias = classAliases[declaration.id];
-            if (classAlias) {
-              const clone2 = factory2.cloneNode(classAlias);
-              setSourceMapRange(clone2, node);
-              setCommentRange(clone2, node);
-              return clone2;
-            }
-          }
-        }
-      }
-      return void 0;
-    }
-  }
-  function createPrivateStaticFieldInitializer(factory2, variableName, initializer) {
-    return factory2.createAssignment(
-      variableName,
-      factory2.createObjectLiteralExpression([
-        factory2.createPropertyAssignment("value", initializer || factory2.createVoidZero())
-      ])
-    );
-  }
-  function createPrivateInstanceFieldInitializer(factory2, receiver, initializer, weakMapName) {
-    return factory2.createCallExpression(
-      factory2.createPropertyAccessExpression(weakMapName, "set"),
-      /*typeArguments*/
-      void 0,
-      [receiver, initializer || factory2.createVoidZero()]
-    );
-  }
-  function createPrivateInstanceMethodInitializer(factory2, receiver, weakSetName) {
-    return factory2.createCallExpression(
-      factory2.createPropertyAccessExpression(weakSetName, "add"),
-      /*typeArguments*/
-      void 0,
-      [receiver]
-    );
-  }
-  function isReservedPrivateName(node) {
-    return !isGeneratedPrivateIdentifier(node) && node.escapedText === "#constructor";
-  }
-  function isPrivateIdentifierInExpression(node) {
-    return isPrivateIdentifier(node.left) && node.operatorToken.kind === 103 /* InKeyword */;
-  }
-  var init_classFields = __esm({
-    "src/compiler/transformers/classFields.ts"() {
-      "use strict";
-      init_ts2();
-    }
-  });
-
-  // src/compiler/transformers/typeSerializer.ts
-  function createRuntimeTypeSerializer(context) {
-    const {
-      factory: factory2,
-      hoistVariableDeclaration
-    } = context;
-    const resolver = context.getEmitResolver();
-    const compilerOptions = context.getCompilerOptions();
-    const languageVersion = getEmitScriptTarget(compilerOptions);
-    const strictNullChecks = getStrictOptionValue(compilerOptions, "strictNullChecks");
-    let currentLexicalScope;
-    let currentNameScope;
-    return {
-      serializeTypeNode: (serializerContext, node) => setSerializerContextAnd(serializerContext, serializeTypeNode, node),
-      serializeTypeOfNode: (serializerContext, node) => setSerializerContextAnd(serializerContext, serializeTypeOfNode, node),
-      serializeParameterTypesOfNode: (serializerContext, node, container) => setSerializerContextAnd(serializerContext, serializeParameterTypesOfNode, node, container),
-      serializeReturnTypeOfNode: (serializerContext, node) => setSerializerContextAnd(serializerContext, serializeReturnTypeOfNode, node)
-    };
-    function setSerializerContextAnd(serializerContext, cb, node, arg) {
-      const savedCurrentLexicalScope = currentLexicalScope;
-      const savedCurrentNameScope = currentNameScope;
-      currentLexicalScope = serializerContext.currentLexicalScope;
-      currentNameScope = serializerContext.currentNameScope;
-      const result = arg === void 0 ? cb(node) : cb(node, arg);
-      currentLexicalScope = savedCurrentLexicalScope;
-      currentNameScope = savedCurrentNameScope;
-      return result;
-    }
-    function getAccessorTypeNode(node) {
-      const accessors = resolver.getAllAccessorDeclarations(node);
-      return accessors.setAccessor && getSetAccessorTypeAnnotationNode(accessors.setAccessor) || accessors.getAccessor && getEffectiveReturnTypeNode(accessors.getAccessor);
-    }
-    function serializeTypeOfNode(node) {
-      switch (node.kind) {
-        case 171 /* PropertyDeclaration */:
-        case 168 /* Parameter */:
-          return serializeTypeNode(node.type);
-        case 177 /* SetAccessor */:
-        case 176 /* GetAccessor */:
-          return serializeTypeNode(getAccessorTypeNode(node));
-        case 262 /* ClassDeclaration */:
-        case 230 /* ClassExpression */:
-        case 173 /* MethodDeclaration */:
-          return factory2.createIdentifier("Function");
-        default:
-          return factory2.createVoidZero();
-      }
-    }
-    function serializeParameterTypesOfNode(node, container) {
-      const valueDeclaration = isClassLike(node) ? getFirstConstructorWithBody(node) : isFunctionLike(node) && nodeIsPresent(node.body) ? node : void 0;
-      const expressions = [];
-      if (valueDeclaration) {
-        const parameters = getParametersOfDecoratedDeclaration(valueDeclaration, container);
-        const numParameters = parameters.length;
-        for (let i = 0; i < numParameters; i++) {
-          const parameter = parameters[i];
-          if (i === 0 && isIdentifier(parameter.name) && parameter.name.escapedText === "this") {
-            continue;
-          }
-          if (parameter.dotDotDotToken) {
-            expressions.push(serializeTypeNode(getRestParameterElementType(parameter.type)));
-          } else {
-            expressions.push(serializeTypeOfNode(parameter));
-          }
-        }
-      }
-      return factory2.createArrayLiteralExpression(expressions);
-    }
-    function getParametersOfDecoratedDeclaration(node, container) {
-      if (container && node.kind === 176 /* GetAccessor */) {
-        const { setAccessor } = getAllAccessorDeclarations(container.members, node);
-        if (setAccessor) {
-          return setAccessor.parameters;
-        }
-      }
-      return node.parameters;
-    }
-    function serializeReturnTypeOfNode(node) {
-      if (isFunctionLike(node) && node.type) {
-        return serializeTypeNode(node.type);
-      } else if (isAsyncFunction(node)) {
-        return factory2.createIdentifier("Promise");
-      }
-      return factory2.createVoidZero();
-    }
-    function serializeTypeNode(node) {
-      if (node === void 0) {
-        return factory2.createIdentifier("Object");
-      }
-      node = skipTypeParentheses(node);
-      switch (node.kind) {
-        case 116 /* VoidKeyword */:
-        case 157 /* UndefinedKeyword */:
-        case 146 /* NeverKeyword */:
-          return factory2.createVoidZero();
-        case 183 /* FunctionType */:
-        case 184 /* ConstructorType */:
-          return factory2.createIdentifier("Function");
-        case 187 /* ArrayType */:
-        case 188 /* TupleType */:
-          return factory2.createIdentifier("Array");
-        case 181 /* TypePredicate */:
-          return node.assertsModifier ? factory2.createVoidZero() : factory2.createIdentifier("Boolean");
-        case 136 /* BooleanKeyword */:
-          return factory2.createIdentifier("Boolean");
-        case 202 /* TemplateLiteralType */:
-        case 154 /* StringKeyword */:
-          return factory2.createIdentifier("String");
-        case 151 /* ObjectKeyword */:
-          return factory2.createIdentifier("Object");
-        case 200 /* LiteralType */:
-          return serializeLiteralOfLiteralTypeNode(node.literal);
-        case 150 /* NumberKeyword */:
-          return factory2.createIdentifier("Number");
-        case 162 /* BigIntKeyword */:
-          return getGlobalConstructor("BigInt", 7 /* ES2020 */);
-        case 155 /* SymbolKeyword */:
-          return getGlobalConstructor("Symbol", 2 /* ES2015 */);
-        case 182 /* TypeReference */:
-          return serializeTypeReferenceNode(node);
-        case 192 /* IntersectionType */:
-          return serializeUnionOrIntersectionConstituents(
-            node.types,
-            /*isIntersection*/
-            true
-          );
-        case 191 /* UnionType */:
-          return serializeUnionOrIntersectionConstituents(
-            node.types,
-            /*isIntersection*/
-            false
-          );
-        case 193 /* ConditionalType */:
-          return serializeUnionOrIntersectionConstituents(
-            [node.trueType, node.falseType],
-            /*isIntersection*/
-            false
-          );
-        case 197 /* TypeOperator */:
-          if (node.operator === 148 /* ReadonlyKeyword */) {
-            return serializeTypeNode(node.type);
-          }
-          break;
-        case 185 /* TypeQuery */:
-        case 198 /* IndexedAccessType */:
-        case 199 /* MappedType */:
-        case 186 /* TypeLiteral */:
-        case 133 /* AnyKeyword */:
-        case 159 /* UnknownKeyword */:
-        case 196 /* ThisType */:
-        case 204 /* ImportType */:
-          break;
-        case 318 /* JSDocAllType */:
-        case 319 /* JSDocUnknownType */:
-        case 323 /* JSDocFunctionType */:
-        case 324 /* JSDocVariadicType */:
-        case 325 /* JSDocNamepathType */:
-          break;
-        case 320 /* JSDocNullableType */:
-        case 321 /* JSDocNonNullableType */:
-        case 322 /* JSDocOptionalType */:
-          return serializeTypeNode(node.type);
-        default:
-          return Debug.failBadSyntaxKind(node);
-      }
-      return factory2.createIdentifier("Object");
-    }
-    function serializeLiteralOfLiteralTypeNode(node) {
-      switch (node.kind) {
-        case 11 /* StringLiteral */:
-        case 15 /* NoSubstitutionTemplateLiteral */:
-          return factory2.createIdentifier("String");
-        case 223 /* PrefixUnaryExpression */: {
-          const operand = node.operand;
-          switch (operand.kind) {
-            case 9 /* NumericLiteral */:
-            case 10 /* BigIntLiteral */:
-              return serializeLiteralOfLiteralTypeNode(operand);
-            default:
-              return Debug.failBadSyntaxKind(operand);
-          }
-        }
-        case 9 /* NumericLiteral */:
-          return factory2.createIdentifier("Number");
-        case 10 /* BigIntLiteral */:
-          return getGlobalConstructor("BigInt", 7 /* ES2020 */);
-        case 112 /* TrueKeyword */:
-        case 97 /* FalseKeyword */:
-          return factory2.createIdentifier("Boolean");
-        case 106 /* NullKeyword */:
-          return factory2.createVoidZero();
-        default:
-          return Debug.failBadSyntaxKind(node);
-      }
-    }
-    function serializeUnionOrIntersectionConstituents(types, isIntersection) {
-      let serializedType;
-      for (let typeNode of types) {
-        typeNode = skipTypeParentheses(typeNode);
-        if (typeNode.kind === 146 /* NeverKeyword */) {
-          if (isIntersection)
-            return factory2.createVoidZero();
-          continue;
-        }
-        if (typeNode.kind === 159 /* UnknownKeyword */) {
-          if (!isIntersection)
-            return factory2.createIdentifier("Object");
-          continue;
-        }
-        if (typeNode.kind === 133 /* AnyKeyword */) {
-          return factory2.createIdentifier("Object");
-        }
-        if (!strictNullChecks && (isLiteralTypeNode(typeNode) && typeNode.literal.kind === 106 /* NullKeyword */ || typeNode.kind === 157 /* UndefinedKeyword */)) {
-          continue;
-        }
-        const serializedConstituent = serializeTypeNode(typeNode);
-        if (isIdentifier(serializedConstituent) && serializedConstituent.escapedText === "Object") {
-          return serializedConstituent;
-        }
-        if (serializedType) {
-          if (!equateSerializedTypeNodes(serializedType, serializedConstituent)) {
-            return factory2.createIdentifier("Object");
-          }
-        } else {
-          serializedType = serializedConstituent;
-        }
-      }
-      return serializedType ?? factory2.createVoidZero();
-    }
-    function equateSerializedTypeNodes(left, right) {
-      return (
-        // temp vars used in fallback
-        isGeneratedIdentifier(left) ? isGeneratedIdentifier(right) : (
-          // entity names
-          isIdentifier(left) ? isIdentifier(right) && left.escapedText === right.escapedText : isPropertyAccessExpression(left) ? isPropertyAccessExpression(right) && equateSerializedTypeNodes(left.expression, right.expression) && equateSerializedTypeNodes(left.name, right.name) : (
-            // `void 0`
-            isVoidExpression(left) ? isVoidExpression(right) && isNumericLiteral(left.expression) && left.expression.text === "0" && isNumericLiteral(right.expression) && right.expression.text === "0" : (
-              // `"undefined"` or `"function"` in `typeof` checks
-              isStringLiteral(left) ? isStringLiteral(right) && left.text === right.text : (
-                // used in `typeof` checks for fallback
-                isTypeOfExpression(left) ? isTypeOfExpression(right) && equateSerializedTypeNodes(left.expression, right.expression) : (
-                  // parens in `typeof` checks with temps
-                  isParenthesizedExpression(left) ? isParenthesizedExpression(right) && equateSerializedTypeNodes(left.expression, right.expression) : (
-                    // conditionals used in fallback
-                    isConditionalExpression(left) ? isConditionalExpression(right) && equateSerializedTypeNodes(left.condition, right.condition) && equateSerializedTypeNodes(left.whenTrue, right.whenTrue) && equateSerializedTypeNodes(left.whenFalse, right.whenFalse) : (
-                      // logical binary and assignments used in fallback
-                      isBinaryExpression(left) ? isBinaryExpression(right) && left.operatorToken.kind === right.operatorToken.kind && equateSerializedTypeNodes(left.left, right.left) && equateSerializedTypeNodes(left.right, right.right) : false
-                    )
-                  )
-                )
-              )
-            )
-          )
-        )
-      );
-    }
-    function serializeTypeReferenceNode(node) {
-      const kind = resolver.getTypeReferenceSerializationKind(node.typeName, currentNameScope ?? currentLexicalScope);
-      switch (kind) {
-        case 0 /* Unknown */:
-          if (findAncestor(node, (n) => n.parent && isConditionalTypeNode(n.parent) && (n.parent.trueType === n || n.parent.falseType === n))) {
-            return factory2.createIdentifier("Object");
-          }
-          const serialized = serializeEntityNameAsExpressionFallback(node.typeName);
-          const temp = factory2.createTempVariable(hoistVariableDeclaration);
-          return factory2.createConditionalExpression(
-            factory2.createTypeCheck(factory2.createAssignment(temp, serialized), "function"),
-            /*questionToken*/
-            void 0,
-            temp,
-            /*colonToken*/
-            void 0,
-            factory2.createIdentifier("Object")
-          );
-        case 1 /* TypeWithConstructSignatureAndValue */:
-          return serializeEntityNameAsExpression(node.typeName);
-        case 2 /* VoidNullableOrNeverType */:
-          return factory2.createVoidZero();
-        case 4 /* BigIntLikeType */:
-          return getGlobalConstructor("BigInt", 7 /* ES2020 */);
-        case 6 /* BooleanType */:
-          return factory2.createIdentifier("Boolean");
-        case 3 /* NumberLikeType */:
-          return factory2.createIdentifier("Number");
-        case 5 /* StringLikeType */:
-          return factory2.createIdentifier("String");
-        case 7 /* ArrayLikeType */:
-          return factory2.createIdentifier("Array");
-        case 8 /* ESSymbolType */:
-          return getGlobalConstructor("Symbol", 2 /* ES2015 */);
-        case 10 /* TypeWithCallSignature */:
-          return factory2.createIdentifier("Function");
-        case 9 /* Promise */:
-          return factory2.createIdentifier("Promise");
-        case 11 /* ObjectType */:
-          return factory2.createIdentifier("Object");
-        default:
-          return Debug.assertNever(kind);
-      }
-    }
-    function createCheckedValue(left, right) {
-      return factory2.createLogicalAnd(
-        factory2.createStrictInequality(factory2.createTypeOfExpression(left), factory2.createStringLiteral("undefined")),
-        right
-      );
-    }
-    function serializeEntityNameAsExpressionFallback(node) {
-      if (node.kind === 80 /* Identifier */) {
-        const copied = serializeEntityNameAsExpression(node);
-        return createCheckedValue(copied, copied);
-      }
-      if (node.left.kind === 80 /* Identifier */) {
-        return createCheckedValue(serializeEntityNameAsExpression(node.left), serializeEntityNameAsExpression(node));
-      }
-      const left = serializeEntityNameAsExpressionFallback(node.left);
-      const temp = factory2.createTempVariable(hoistVariableDeclaration);
-      return factory2.createLogicalAnd(
-        factory2.createLogicalAnd(
-          left.left,
-          factory2.createStrictInequality(factory2.createAssignment(temp, left.right), factory2.createVoidZero())
-        ),
-        factory2.createPropertyAccessExpression(temp, node.right)
-      );
-    }
-    function serializeEntityNameAsExpression(node) {
-      switch (node.kind) {
-        case 80 /* Identifier */:
-          const name = setParent(setTextRange(parseNodeFactory.cloneNode(node), node), node.parent);
-          name.original = void 0;
-          setParent(name, getParseTreeNode(currentLexicalScope));
-          return name;
-        case 165 /* QualifiedName */:
-          return serializeQualifiedNameAsExpression(node);
-      }
-    }
-    function serializeQualifiedNameAsExpression(node) {
-      return factory2.createPropertyAccessExpression(serializeEntityNameAsExpression(node.left), node.right);
-    }
-    function getGlobalConstructorWithFallback(name) {
-      return factory2.createConditionalExpression(
-        factory2.createTypeCheck(factory2.createIdentifier(name), "function"),
-        /*questionToken*/
-        void 0,
-        factory2.createIdentifier(name),
-        /*colonToken*/
-        void 0,
-        factory2.createIdentifier("Object")
-      );
-    }
-    function getGlobalConstructor(name, minLanguageVersion) {
-      return languageVersion < minLanguageVersion ? getGlobalConstructorWithFallback(name) : factory2.createIdentifier(name);
-    }
-  }
-  var init_typeSerializer = __esm({
-    "src/compiler/transformers/typeSerializer.ts"() {
-      "use strict";
-      init_ts2();
-    }
-  });
-
-  // src/compiler/transformers/legacyDecorators.ts
-  function transformLegacyDecorators(context) {
-    const {
-      factory: factory2,
-      getEmitHelperFactory: emitHelpers,
-      hoistVariableDeclaration
-    } = context;
-    const resolver = context.getEmitResolver();
-    const compilerOptions = context.getCompilerOptions();
-    const languageVersion = getEmitScriptTarget(compilerOptions);
-    const previousOnSubstituteNode = context.onSubstituteNode;
-    context.onSubstituteNode = onSubstituteNode;
-    let classAliases;
-    return chainBundle(context, transformSourceFile);
-    function transformSourceFile(node) {
-      const visited = visitEachChild(node, visitor, context);
-      addEmitHelpers(visited, context.readEmitHelpers());
-      return visited;
-    }
-    function modifierVisitor(node) {
-      return isDecorator(node) ? void 0 : node;
-    }
-    function visitor(node) {
-      if (!(node.transformFlags & 33554432 /* ContainsDecorators */)) {
-        return node;
-      }
-      switch (node.kind) {
-        case 169 /* Decorator */:
-          return void 0;
-        case 262 /* ClassDeclaration */:
-          return visitClassDeclaration(node);
-        case 230 /* ClassExpression */:
-          return visitClassExpression(node);
-        case 175 /* Constructor */:
-          return visitConstructorDeclaration(node);
-        case 173 /* MethodDeclaration */:
-          return visitMethodDeclaration(node);
-        case 177 /* SetAccessor */:
-          return visitSetAccessorDeclaration(node);
-        case 176 /* GetAccessor */:
-          return visitGetAccessorDeclaration(node);
-        case 171 /* PropertyDeclaration */:
-          return visitPropertyDeclaration(node);
-        case 168 /* Parameter */:
-          return visitParameterDeclaration(node);
-        default:
-          return visitEachChild(node, visitor, context);
-      }
-    }
-    function visitClassDeclaration(node) {
-      if (!(classOrConstructorParameterIsDecorated(
-        /*useLegacyDecorators*/
-        true,
-        node
-      ) || childIsDecorated(
-        /*useLegacyDecorators*/
-        true,
-        node
-      ))) {
-        return visitEachChild(node, visitor, context);
-      }
-      const statements = classOrConstructorParameterIsDecorated(
-        /*useLegacyDecorators*/
-        true,
-        node
-      ) ? transformClassDeclarationWithClassDecorators(node, node.name) : transformClassDeclarationWithoutClassDecorators(node, node.name);
-      return singleOrMany(statements);
-    }
-    function decoratorContainsPrivateIdentifierInExpression(decorator) {
-      return !!(decorator.transformFlags & 536870912 /* ContainsPrivateIdentifierInExpression */);
-    }
-    function parameterDecoratorsContainPrivateIdentifierInExpression(parameterDecorators) {
-      return some(parameterDecorators, decoratorContainsPrivateIdentifierInExpression);
-    }
-    function hasClassElementWithDecoratorContainingPrivateIdentifierInExpression(node) {
-      for (const member of node.members) {
-        if (!canHaveDecorators(member))
-          continue;
-        const allDecorators = getAllDecoratorsOfClassElement(
-          member,
-          node,
-          /*useLegacyDecorators*/
-          true
-        );
-        if (some(allDecorators == null ? void 0 : allDecorators.decorators, decoratorContainsPrivateIdentifierInExpression))
-          return true;
-        if (some(allDecorators == null ? void 0 : allDecorators.parameters, parameterDecoratorsContainPrivateIdentifierInExpression))
-          return true;
-      }
-      return false;
-    }
-    function transformDecoratorsOfClassElements(node, members) {
-      let decorationStatements = [];
-      addClassElementDecorationStatements(
-        decorationStatements,
-        node,
-        /*isStatic*/
-        false
-      );
-      addClassElementDecorationStatements(
-        decorationStatements,
-        node,
-        /*isStatic*/
-        true
-      );
-      if (hasClassElementWithDecoratorContainingPrivateIdentifierInExpression(node)) {
-        members = setTextRange(factory2.createNodeArray([
-          ...members,
-          factory2.createClassStaticBlockDeclaration(
-            factory2.createBlock(
-              decorationStatements,
-              /*multiLine*/
-              true
-            )
-          )
-        ]), members);
-        decorationStatements = void 0;
-      }
-      return { decorationStatements, members };
-    }
-    function transformClassDeclarationWithoutClassDecorators(node, name) {
-      const modifiers = visitNodes2(node.modifiers, modifierVisitor, isModifier);
-      const heritageClauses = visitNodes2(node.heritageClauses, visitor, isHeritageClause);
-      let members = visitNodes2(node.members, visitor, isClassElement);
-      let decorationStatements = [];
-      ({ members, decorationStatements } = transformDecoratorsOfClassElements(node, members));
-      const updated = factory2.updateClassDeclaration(
-        node,
-        modifiers,
-        name,
-        /*typeParameters*/
-        void 0,
-        heritageClauses,
-        members
-      );
-      return addRange([updated], decorationStatements);
-    }
-    function transformClassDeclarationWithClassDecorators(node, name) {
-      const isExport = hasSyntacticModifier(node, 1 /* Export */);
-      const isDefault = hasSyntacticModifier(node, 1024 /* Default */);
-      const modifiers = visitNodes2(node.modifiers, (node2) => isExportOrDefaultModifier(node2) || isDecorator(node2) ? void 0 : node2, isModifierLike);
-      const location = moveRangePastModifiers(node);
-      const classAlias = getClassAliasIfNeeded(node);
-      const declName = languageVersion < 2 /* ES2015 */ ? factory2.getInternalName(
-        node,
-        /*allowComments*/
-        false,
-        /*allowSourceMaps*/
-        true
-      ) : factory2.getLocalName(
-        node,
-        /*allowComments*/
-        false,
-        /*allowSourceMaps*/
-        true
-      );
-      const heritageClauses = visitNodes2(node.heritageClauses, visitor, isHeritageClause);
-      let members = visitNodes2(node.members, visitor, isClassElement);
-      let decorationStatements = [];
-      ({ members, decorationStatements } = transformDecoratorsOfClassElements(node, members));
-      const assignClassAliasInStaticBlock = languageVersion >= 9 /* ES2022 */ && !!classAlias && some(members, (member) => isPropertyDeclaration(member) && hasSyntacticModifier(member, 32 /* Static */) || isClassStaticBlockDeclaration(member));
-      if (assignClassAliasInStaticBlock) {
-        members = setTextRange(factory2.createNodeArray([
-          factory2.createClassStaticBlockDeclaration(
-            factory2.createBlock([
-              factory2.createExpressionStatement(
-                factory2.createAssignment(classAlias, factory2.createThis())
-              )
-            ])
-          ),
-          ...members
-        ]), members);
-      }
-      const classExpression = factory2.createClassExpression(
-        modifiers,
-        name && isGeneratedIdentifier(name) ? void 0 : name,
-        /*typeParameters*/
-        void 0,
-        heritageClauses,
-        members
-      );
-      setOriginalNode(classExpression, node);
-      setTextRange(classExpression, location);
-      const varDecl = factory2.createVariableDeclaration(
-        declName,
-        /*exclamationToken*/
-        void 0,
-        /*type*/
-        void 0,
-        classAlias && !assignClassAliasInStaticBlock ? factory2.createAssignment(classAlias, classExpression) : classExpression
-      );
-      setOriginalNode(varDecl, node);
-      let varModifiers;
-      if (isExport && !isDefault) {
-        varModifiers = factory2.createModifiersFromModifierFlags(1 /* Export */);
-      }
-      const statement = factory2.createVariableStatement(
-        varModifiers,
-        factory2.createVariableDeclarationList([
-          varDecl
-        ], 1 /* Let */)
-      );
-      setOriginalNode(statement, node);
-      setTextRange(statement, location);
-      setCommentRange(statement, node);
-      const statements = [statement];
-      addRange(statements, decorationStatements);
-      addConstructorDecorationStatement(statements, node);
-      if (isExport && isDefault) {
-        statements.push(factory2.createExportAssignment(
-          /*modifiers*/
-          void 0,
-          /*isExportEquals*/
-          false,
-          declName
-        ));
-      }
-      return statements;
-    }
-    function visitClassExpression(node) {
-      return factory2.updateClassExpression(
-        node,
-        visitNodes2(node.modifiers, modifierVisitor, isModifier),
-        node.name,
-        /*typeParameters*/
-        void 0,
-        visitNodes2(node.heritageClauses, visitor, isHeritageClause),
-        visitNodes2(node.members, visitor, isClassElement)
-      );
-    }
-    function visitConstructorDeclaration(node) {
-      return factory2.updateConstructorDeclaration(
-        node,
-        visitNodes2(node.modifiers, modifierVisitor, isModifier),
-        visitNodes2(node.parameters, visitor, isParameter),
-        visitNode(node.body, visitor, isBlock)
-      );
-    }
-    function finishClassElement(updated, original) {
-      if (updated !== original) {
-        setCommentRange(updated, original);
-        setSourceMapRange(updated, moveRangePastModifiers(original));
-      }
-      return updated;
-    }
-    function visitMethodDeclaration(node) {
-      return finishClassElement(factory2.updateMethodDeclaration(
-        node,
-        visitNodes2(node.modifiers, modifierVisitor, isModifier),
-        node.asteriskToken,
-        Debug.checkDefined(visitNode(node.name, visitor, isPropertyName)),
-        /*questionToken*/
-        void 0,
-        /*typeParameters*/
-        void 0,
-        visitNodes2(node.parameters, visitor, isParameter),
-        /*type*/
-        void 0,
-        visitNode(node.body, visitor, isBlock)
-      ), node);
-    }
-    function visitGetAccessorDeclaration(node) {
-      return finishClassElement(factory2.updateGetAccessorDeclaration(
-        node,
-        visitNodes2(node.modifiers, modifierVisitor, isModifier),
-        Debug.checkDefined(visitNode(node.name, visitor, isPropertyName)),
-        visitNodes2(node.parameters, visitor, isParameter),
-        /*type*/
-        void 0,
-        visitNode(node.body, visitor, isBlock)
-      ), node);
-    }
-    function visitSetAccessorDeclaration(node) {
-      return finishClassElement(factory2.updateSetAccessorDeclaration(
-        node,
-        visitNodes2(node.modifiers, modifierVisitor, isModifier),
-        Debug.checkDefined(visitNode(node.name, visitor, isPropertyName)),
-        visitNodes2(node.parameters, visitor, isParameter),
-        visitNode(node.body, visitor, isBlock)
-      ), node);
-    }
-    function visitPropertyDeclaration(node) {
-      if (node.flags & 16777216 /* Ambient */ || hasSyntacticModifier(node, 2 /* Ambient */)) {
-        return void 0;
-      }
-      return finishClassElement(factory2.updatePropertyDeclaration(
-        node,
-        visitNodes2(node.modifiers, modifierVisitor, isModifier),
-        Debug.checkDefined(visitNode(node.name, visitor, isPropertyName)),
-        /*questionOrExclamationToken*/
-        void 0,
-        /*type*/
-        void 0,
-        visitNode(node.initializer, visitor, isExpression)
-      ), node);
-    }
-    function visitParameterDeclaration(node) {
-      const updated = factory2.updateParameterDeclaration(
-        node,
-        elideNodes(factory2, node.modifiers),
-        node.dotDotDotToken,
-        Debug.checkDefined(visitNode(node.name, visitor, isBindingName)),
-        /*questionToken*/
-        void 0,
-        /*type*/
-        void 0,
-        visitNode(node.initializer, visitor, isExpression)
-      );
-      if (updated !== node) {
-        setCommentRange(updated, node);
-        setTextRange(updated, moveRangePastModifiers(node));
-        setSourceMapRange(updated, moveRangePastModifiers(node));
-        setEmitFlags(updated.name, 64 /* NoTrailingSourceMap */);
-      }
-      return updated;
-    }
-    function isSyntheticMetadataDecorator(node) {
-      return isCallToHelper(node.expression, "___metadata");
-    }
-    function transformAllDecoratorsOfDeclaration(allDecorators) {
-      if (!allDecorators) {
-        return void 0;
-      }
-      const { false: decorators, true: metadata } = groupBy(allDecorators.decorators, isSyntheticMetadataDecorator);
-      const decoratorExpressions = [];
-      addRange(decoratorExpressions, map(decorators, transformDecorator));
-      addRange(decoratorExpressions, flatMap(allDecorators.parameters, transformDecoratorsOfParameter));
-      addRange(decoratorExpressions, map(metadata, transformDecorator));
-      return decoratorExpressions;
-    }
-    function addClassElementDecorationStatements(statements, node, isStatic2) {
-      addRange(statements, map(generateClassElementDecorationExpressions(node, isStatic2), (expr) => factory2.createExpressionStatement(expr)));
-    }
-    function isDecoratedClassElement(member, isStaticElement, parent2) {
-      return nodeOrChildIsDecorated(
-        /*useLegacyDecorators*/
-        true,
-        member,
-        parent2
-      ) && isStaticElement === isStatic(member);
-    }
-    function getDecoratedClassElements(node, isStatic2) {
-      return filter(node.members, (m) => isDecoratedClassElement(m, isStatic2, node));
-    }
-    function generateClassElementDecorationExpressions(node, isStatic2) {
-      const members = getDecoratedClassElements(node, isStatic2);
-      let expressions;
-      for (const member of members) {
-        expressions = append(expressions, generateClassElementDecorationExpression(node, member));
-      }
-      return expressions;
-    }
-    function generateClassElementDecorationExpression(node, member) {
-      const allDecorators = getAllDecoratorsOfClassElement(
-        member,
-        node,
-        /*useLegacyDecorators*/
-        true
-      );
-      const decoratorExpressions = transformAllDecoratorsOfDeclaration(allDecorators);
-      if (!decoratorExpressions) {
-        return void 0;
-      }
-      const prefix = getClassMemberPrefix(node, member);
-      const memberName = getExpressionForPropertyName(
-        member,
-        /*generateNameForComputedPropertyName*/
-        !hasSyntacticModifier(member, 2 /* Ambient */)
-      );
-      const descriptor = languageVersion > 0 /* ES3 */ ? isPropertyDeclaration(member) && !hasAccessorModifier(member) ? factory2.createVoidZero() : factory2.createNull() : void 0;
-      const helper = emitHelpers().createDecorateHelper(
-        decoratorExpressions,
-        prefix,
-        memberName,
-        descriptor
-      );
-      setEmitFlags(helper, 3072 /* NoComments */);
-      setSourceMapRange(helper, moveRangePastModifiers(member));
-      return helper;
-    }
-    function addConstructorDecorationStatement(statements, node) {
-      const expression = generateConstructorDecorationExpression(node);
-      if (expression) {
-        statements.push(setOriginalNode(factory2.createExpressionStatement(expression), node));
-      }
-    }
-    function generateConstructorDecorationExpression(node) {
-      const allDecorators = getAllDecoratorsOfClass(node);
-      const decoratorExpressions = transformAllDecoratorsOfDeclaration(allDecorators);
-      if (!decoratorExpressions) {
-        return void 0;
-      }
-      const classAlias = classAliases && classAliases[getOriginalNodeId(node)];
-      const localName = languageVersion < 2 /* ES2015 */ ? factory2.getInternalName(
-        node,
-        /*allowComments*/
-        false,
-        /*allowSourceMaps*/
-        true
-      ) : factory2.getDeclarationName(
-        node,
-        /*allowComments*/
-        false,
-        /*allowSourceMaps*/
-        true
-      );
-      const decorate = emitHelpers().createDecorateHelper(decoratorExpressions, localName);
-      const expression = factory2.createAssignment(localName, classAlias ? factory2.createAssignment(classAlias, decorate) : decorate);
-      setEmitFlags(expression, 3072 /* NoComments */);
-      setSourceMapRange(expression, moveRangePastModifiers(node));
-      return expression;
-    }
-    function transformDecorator(decorator) {
-      return Debug.checkDefined(visitNode(decorator.expression, visitor, isExpression));
-    }
-    function transformDecoratorsOfParameter(decorators, parameterOffset) {
-      let expressions;
-      if (decorators) {
-        expressions = [];
-        for (const decorator of decorators) {
-          const helper = emitHelpers().createParamHelper(
-            transformDecorator(decorator),
-            parameterOffset
-          );
-          setTextRange(helper, decorator.expression);
-          setEmitFlags(helper, 3072 /* NoComments */);
-          expressions.push(helper);
-        }
-      }
-      return expressions;
-    }
-    function getExpressionForPropertyName(member, generateNameForComputedPropertyName) {
-      const name = member.name;
-      if (isPrivateIdentifier(name)) {
-        return factory2.createIdentifier("");
-      } else if (isComputedPropertyName(name)) {
-        return generateNameForComputedPropertyName && !isSimpleInlineableExpression(name.expression) ? factory2.getGeneratedNameForNode(name) : name.expression;
-      } else if (isIdentifier(name)) {
-        return factory2.createStringLiteral(idText(name));
-      } else {
-        return factory2.cloneNode(name);
-      }
-    }
-    function enableSubstitutionForClassAliases() {
-      if (!classAliases) {
-        context.enableSubstitution(80 /* Identifier */);
-        classAliases = [];
-      }
-    }
-    function getClassAliasIfNeeded(node) {
-      if (resolver.getNodeCheckFlags(node) & 1048576 /* ClassWithConstructorReference */) {
-        enableSubstitutionForClassAliases();
-        const classAlias = factory2.createUniqueName(node.name && !isGeneratedIdentifier(node.name) ? idText(node.name) : "default");
-        classAliases[getOriginalNodeId(node)] = classAlias;
-        hoistVariableDeclaration(classAlias);
-        return classAlias;
-      }
-    }
-    function getClassPrototype(node) {
-      return factory2.createPropertyAccessExpression(factory2.getDeclarationName(node), "prototype");
-    }
-    function getClassMemberPrefix(node, member) {
-      return isStatic(member) ? factory2.getDeclarationName(node) : getClassPrototype(node);
-    }
-    function onSubstituteNode(hint, node) {
-      node = previousOnSubstituteNode(hint, node);
-      if (hint === 1 /* Expression */) {
-        return substituteExpression(node);
-      }
-      return node;
-    }
-    function substituteExpression(node) {
-      switch (node.kind) {
-        case 80 /* Identifier */:
-          return substituteExpressionIdentifier(node);
-      }
-      return node;
-    }
-    function substituteExpressionIdentifier(node) {
-      return trySubstituteClassAlias(node) ?? node;
-    }
-    function trySubstituteClassAlias(node) {
-      if (classAliases) {
-        if (resolver.getNodeCheckFlags(node) & 2097152 /* ConstructorReferenceInClass */) {
-          const declaration = resolver.getReferencedValueDeclaration(node);
-          if (declaration) {
-            const classAlias = classAliases[declaration.id];
-            if (classAlias) {
-              const clone2 = factory2.cloneNode(classAlias);
-              setSourceMapRange(clone2, node);
-              setCommentRange(clone2, node);
-              return clone2;
-            }
-          }
-        }
-      }
-      return void 0;
-    }
-  }
-  var init_legacyDecorators = __esm({
-    "src/compiler/transformers/legacyDecorators.ts"() {
-      "use strict";
-      init_ts2();
-    }
-  });
-
-  // src/compiler/transformers/esDecorators.ts
-  function transformESDecorators(context) {
-    const {
-      factory: factory2,
-      getEmitHelperFactory: emitHelpers,
-      startLexicalEnvironment,
-      endLexicalEnvironment,
-      hoistVariableDeclaration
-    } = context;
-    const compilerOptions = context.getCompilerOptions();
-    const languageVersion = getEmitScriptTarget(compilerOptions);
-    let top;
-    let classInfo;
-    let classThis;
-    let classSuper;
-    let pendingExpressions;
-    let shouldTransformPrivateStaticElementsInFile;
-    return chainBundle(context, transformSourceFile);
-    function transformSourceFile(node) {
-      top = void 0;
-      shouldTransformPrivateStaticElementsInFile = false;
-      const visited = visitEachChild(node, visitor, context);
-      addEmitHelpers(visited, context.readEmitHelpers());
-      if (shouldTransformPrivateStaticElementsInFile) {
-        addInternalEmitFlags(visited, 32 /* TransformPrivateStaticElements */);
-        shouldTransformPrivateStaticElementsInFile = false;
-      }
-      return visited;
-    }
-    function updateState() {
-      classInfo = void 0;
-      classThis = void 0;
-      classSuper = void 0;
-      switch (top == null ? void 0 : top.kind) {
-        case "class":
-          classInfo = top.classInfo;
-          break;
-        case "class-element":
-          classInfo = top.next.classInfo;
-          classThis = top.classThis;
-          classSuper = top.classSuper;
-          break;
-        case "name":
-          const grandparent = top.next.next.next;
-          if ((grandparent == null ? void 0 : grandparent.kind) === "class-element") {
-            classInfo = grandparent.next.classInfo;
-            classThis = grandparent.classThis;
-            classSuper = grandparent.classSuper;
-          }
-          break;
-      }
-    }
-    function enterClass(classInfo2) {
-      top = { kind: "class", next: top, classInfo: classInfo2, savedPendingExpressions: pendingExpressions };
-      pendingExpressions = void 0;
-      updateState();
-    }
-    function exitClass() {
-      Debug.assert((top == null ? void 0 : top.kind) === "class", "Incorrect value for top.kind.", () => `Expected top.kind to be 'class' but got '${top == null ? void 0 : top.kind}' instead.`);
-      pendingExpressions = top.savedPendingExpressions;
-      top = top.next;
-      updateState();
-    }
-    function enterClassElement(node) {
-      var _a, _b;
-      Debug.assert((top == null ? void 0 : top.kind) === "class", "Incorrect value for top.kind.", () => `Expected top.kind to be 'class' but got '${top == null ? void 0 : top.kind}' instead.`);
-      top = { kind: "class-element", next: top };
-      if (isClassStaticBlockDeclaration(node) || isPropertyDeclaration(node) && hasStaticModifier(node)) {
-        top.classThis = (_a = top.next.classInfo) == null ? void 0 : _a.classThis;
-        top.classSuper = (_b = top.next.classInfo) == null ? void 0 : _b.classSuper;
-      }
-      updateState();
-    }
-    function exitClassElement() {
-      var _a;
-      Debug.assert((top == null ? void 0 : top.kind) === "class-element", "Incorrect value for top.kind.", () => `Expected top.kind to be 'class-element' but got '${top == null ? void 0 : top.kind}' instead.`);
-      Debug.assert(((_a = top.next) == null ? void 0 : _a.kind) === "class", "Incorrect value for top.next.kind.", () => {
-        var _a2;
-        return `Expected top.next.kind to be 'class' but got '${(_a2 = top.next) == null ? void 0 : _a2.kind}' instead.`;
-      });
-      top = top.next;
-      updateState();
-    }
-    function enterName() {
-      Debug.assert((top == null ? void 0 : top.kind) === "class-element", "Incorrect value for top.kind.", () => `Expected top.kind to be 'class-element' but got '${top == null ? void 0 : top.kind}' instead.`);
-      top = { kind: "name", next: top };
-      updateState();
-    }
-    function exitName() {
-      Debug.assert((top == null ? void 0 : top.kind) === "name", "Incorrect value for top.kind.", () => `Expected top.kind to be 'name' but got '${top == null ? void 0 : top.kind}' instead.`);
-      top = top.next;
-      updateState();
-    }
-    function enterOther() {
-      if ((top == null ? void 0 : top.kind) === "other") {
-        Debug.assert(!pendingExpressions);
-        top.depth++;
-      } else {
-        top = { kind: "other", next: top, depth: 0, savedPendingExpressions: pendingExpressions };
-        pendingExpressions = void 0;
-        updateState();
-      }
-    }
-    function exitOther() {
-      Debug.assert((top == null ? void 0 : top.kind) === "other", "Incorrect value for top.kind.", () => `Expected top.kind to be 'other' but got '${top == null ? void 0 : top.kind}' instead.`);
-      if (top.depth > 0) {
-        Debug.assert(!pendingExpressions);
-        top.depth--;
-      } else {
-        pendingExpressions = top.savedPendingExpressions;
-        top = top.next;
-        updateState();
-      }
-    }
-    function shouldVisitNode(node) {
-      return !!(node.transformFlags & 33554432 /* ContainsDecorators */) || !!classThis && !!(node.transformFlags & 16384 /* ContainsLexicalThis */) || !!classThis && !!classSuper && !!(node.transformFlags & 134217728 /* ContainsLexicalSuper */);
-    }
-    function visitor(node) {
-      if (!shouldVisitNode(node)) {
-        return node;
-      }
-      switch (node.kind) {
-        case 169 /* Decorator */:
-          return Debug.fail("Use `modifierVisitor` instead.");
-        case 262 /* ClassDeclaration */:
-          return visitClassDeclaration(node);
-        case 230 /* ClassExpression */:
-          return visitClassExpression(
-            node,
-            /*referencedName*/
-            void 0
-          );
-        case 175 /* Constructor */:
-        case 171 /* PropertyDeclaration */:
-        case 174 /* ClassStaticBlockDeclaration */:
-          return Debug.fail("Not supported outside of a class. Use 'classElementVisitor' instead.");
-        case 168 /* Parameter */:
-          return visitParameterDeclaration(node);
-        case 225 /* BinaryExpression */:
-          return visitBinaryExpression(
-            node,
-            /*discarded*/
-            false
-          );
-        case 302 /* PropertyAssignment */:
-          return visitPropertyAssignment(node);
-        case 259 /* VariableDeclaration */:
-          return visitVariableDeclaration(node);
-        case 207 /* BindingElement */:
-          return visitBindingElement(node);
-        case 276 /* ExportAssignment */:
-          return visitExportAssignment(node);
-        case 110 /* ThisKeyword */:
-          return visitThisExpression(node);
-        case 247 /* ForStatement */:
-          return visitForStatement(node);
-        case 243 /* ExpressionStatement */:
-          return visitExpressionStatement(node);
-        case 360 /* CommaListExpression */:
-          return visitCommaListExpression(
-            node,
-            /*discarded*/
-            false
-          );
-        case 216 /* ParenthesizedExpression */:
-          return visitParenthesizedExpression(
-            node,
-            /*discarded*/
-            false,
-            /*referencedName*/
-            void 0
-          );
-        case 359 /* PartiallyEmittedExpression */:
-          return visitPartiallyEmittedExpression(
-            node,
-            /*discarded*/
-            false,
-            /*referencedName*/
-            void 0
-          );
-        case 212 /* CallExpression */:
-          return visitCallExpression(node);
-        case 214 /* TaggedTemplateExpression */:
-          return visitTaggedTemplateExpression(node);
-        case 223 /* PrefixUnaryExpression */:
-        case 224 /* PostfixUnaryExpression */:
-          return visitPreOrPostfixUnaryExpression(
-            node,
-            /*discarded*/
-            false
-          );
-        case 210 /* PropertyAccessExpression */:
-          return visitPropertyAccessExpression(node);
-        case 211 /* ElementAccessExpression */:
-          return visitElementAccessExpression(node);
-        case 166 /* ComputedPropertyName */:
-          return visitComputedPropertyName(node);
-        case 173 /* MethodDeclaration */:
-        case 177 /* SetAccessor */:
-        case 176 /* GetAccessor */:
-        case 217 /* FunctionExpression */:
-        case 261 /* FunctionDeclaration */: {
-          enterOther();
-          const result = visitEachChild(node, fallbackVisitor, context);
-          exitOther();
-          return result;
-        }
-        default:
-          return visitEachChild(node, fallbackVisitor, context);
-      }
-    }
-    function fallbackVisitor(node) {
-      switch (node.kind) {
-        case 169 /* Decorator */:
-          return void 0;
-        default:
-          return visitor(node);
-      }
-    }
-    function modifierVisitor(node) {
-      switch (node.kind) {
-        case 169 /* Decorator */:
-          return void 0;
-        default:
-          return node;
-      }
-    }
-    function classElementVisitor(node) {
-      switch (node.kind) {
-        case 175 /* Constructor */:
-          return visitConstructorDeclaration(node);
-        case 173 /* MethodDeclaration */:
-          return visitMethodDeclaration(node);
-        case 176 /* GetAccessor */:
-          return visitGetAccessorDeclaration(node);
-        case 177 /* SetAccessor */:
-          return visitSetAccessorDeclaration(node);
-        case 171 /* PropertyDeclaration */:
-          return visitPropertyDeclaration(node);
-        case 174 /* ClassStaticBlockDeclaration */:
-          return visitClassStaticBlockDeclaration(node);
-        default:
-          return visitor(node);
-      }
-    }
-    function namedEvaluationVisitor(node, referencedName) {
-      switch (node.kind) {
-        case 359 /* PartiallyEmittedExpression */:
-          return visitPartiallyEmittedExpression(
-            node,
-            /*discarded*/
-            false,
-            referencedName
-          );
-        case 216 /* ParenthesizedExpression */:
-          return visitParenthesizedExpression(
-            node,
-            /*discarded*/
-            false,
-            referencedName
-          );
-        case 230 /* ClassExpression */:
-          return visitClassExpression(node, referencedName);
-        default:
-          return visitor(node);
-      }
-    }
-    function discardedValueVisitor(node) {
-      switch (node.kind) {
-        case 223 /* PrefixUnaryExpression */:
-        case 224 /* PostfixUnaryExpression */:
-          return visitPreOrPostfixUnaryExpression(
-            node,
-            /*discarded*/
-            true
-          );
-        case 225 /* BinaryExpression */:
-          return visitBinaryExpression(
-            node,
-            /*discarded*/
-            true
-          );
-        case 360 /* CommaListExpression */:
-          return visitCommaListExpression(
-            node,
-            /*discarded*/
-            true
-          );
-        case 216 /* ParenthesizedExpression */:
-          return visitParenthesizedExpression(
-            node,
-            /*discarded*/
-            true,
-            /*referencedName*/
-            void 0
-          );
-        default:
-          return visitor(node);
-      }
-    }
-    function getHelperVariableName(node) {
-      let declarationName = node.name && isIdentifier(node.name) && !isGeneratedIdentifier(node.name) ? idText(node.name) : node.name && isPrivateIdentifier(node.name) && !isGeneratedIdentifier(node.name) ? idText(node.name).slice(1) : node.name && isStringLiteral(node.name) && isIdentifierText(node.name.text, 99 /* ESNext */) ? node.name.text : isClassLike(node) ? "class" : "member";
-      if (isGetAccessor(node))
-        declarationName = `get_${declarationName}`;
-      if (isSetAccessor(node))
-        declarationName = `set_${declarationName}`;
-      if (node.name && isPrivateIdentifier(node.name))
-        declarationName = `private_${declarationName}`;
-      if (isStatic(node))
-        declarationName = `static_${declarationName}`;
-      return "_" + declarationName;
-    }
-    function createHelperVariable(node, suffix) {
-      return factory2.createUniqueName(`${getHelperVariableName(node)}_${suffix}`, 16 /* Optimistic */ | 8 /* ReservedInNestedScopes */);
-    }
-    function createLet(name, initializer) {
-      return factory2.createVariableStatement(
-        /*modifiers*/
-        void 0,
-        factory2.createVariableDeclarationList([
-          factory2.createVariableDeclaration(
-            name,
-            /*exclamationToken*/
-            void 0,
-            /*type*/
-            void 0,
-            initializer
-          )
-        ], 1 /* Let */)
-      );
-    }
-    function createClassInfo(node) {
-      let instanceExtraInitializersName;
-      let staticExtraInitializersName;
-      let hasStaticInitializers = false;
-      let hasNonAmbientInstanceFields = false;
-      let hasStaticPrivateClassElements = false;
-      for (const member of node.members) {
-        if (isNamedClassElement(member) && nodeOrChildIsDecorated(
-          /*useLegacyDecorators*/
-          false,
-          member,
-          node
-        )) {
-          if (hasStaticModifier(member)) {
-            staticExtraInitializersName ?? (staticExtraInitializersName = factory2.createUniqueName("_staticExtraInitializers", 16 /* Optimistic */));
-          } else {
-            instanceExtraInitializersName ?? (instanceExtraInitializersName = factory2.createUniqueName("_instanceExtraInitializers", 16 /* Optimistic */));
-          }
-        }
-        if (isClassStaticBlockDeclaration(member)) {
-          hasStaticInitializers = true;
-        } else if (isPropertyDeclaration(member)) {
-          if (hasStaticModifier(member)) {
-            hasStaticInitializers || (hasStaticInitializers = !!member.initializer || hasDecorators(member));
-          } else {
-            hasNonAmbientInstanceFields || (hasNonAmbientInstanceFields = !isAmbientPropertyDeclaration(member));
-          }
-        }
-        if ((isPrivateIdentifierClassElementDeclaration(member) || isAutoAccessorPropertyDeclaration(member)) && hasStaticModifier(member)) {
-          hasStaticPrivateClassElements = true;
-        }
-        if (staticExtraInitializersName && instanceExtraInitializersName && hasStaticInitializers && hasNonAmbientInstanceFields && hasStaticPrivateClassElements) {
-          break;
-        }
-      }
-      return {
-        class: node,
-        instanceExtraInitializersName,
-        staticExtraInitializersName,
-        hasStaticInitializers,
-        hasNonAmbientInstanceFields,
-        hasStaticPrivateClassElements
-      };
-    }
-    function containsLexicalSuperInStaticInitializer(node) {
-      for (const member of node.members) {
-        if (isClassStaticBlockDeclaration(member) || isPropertyDeclaration(member) && hasStaticModifier(member)) {
-          if (member.transformFlags & 134217728 /* ContainsLexicalSuper */) {
-            return true;
-          }
-        }
-      }
-      return false;
-    }
-    function transformClassLike(node, className) {
-      var _a;
-      startLexicalEnvironment();
-      const classReference = factory2.getLocalName(
-        node,
-        /*allowComments*/
-        false,
-        /*allowSourceMaps*/
-        false,
-        /*ignoreAssignedName*/
-        true
-      );
-      const classInfo2 = createClassInfo(node);
-      const classDefinitionStatements = [];
-      let leadingBlockStatements;
-      let trailingBlockStatements;
-      let syntheticConstructor;
-      let heritageClauses;
-      let shouldTransformPrivateStaticElementsInClass = false;
-      const classDecorators = transformAllDecoratorsOfDeclaration(getAllDecoratorsOfClass(node));
-      if (classDecorators) {
-        classInfo2.classDecoratorsName = factory2.createUniqueName("_classDecorators", 16 /* Optimistic */);
-        classInfo2.classDescriptorName = factory2.createUniqueName("_classDescriptor", 16 /* Optimistic */);
-        classInfo2.classExtraInitializersName = factory2.createUniqueName("_classExtraInitializers", 16 /* Optimistic */);
-        classInfo2.classThis = factory2.createUniqueName("_classThis", 16 /* Optimistic */);
-        classDefinitionStatements.push(
-          createLet(classInfo2.classDecoratorsName, factory2.createArrayLiteralExpression(classDecorators)),
-          createLet(classInfo2.classDescriptorName),
-          createLet(classInfo2.classExtraInitializersName, factory2.createArrayLiteralExpression()),
-          createLet(classInfo2.classThis)
-        );
-        if (classInfo2.hasStaticPrivateClassElements) {
-          shouldTransformPrivateStaticElementsInClass = true;
-          shouldTransformPrivateStaticElementsInFile = true;
-        }
-      }
-      if (classDecorators && containsLexicalSuperInStaticInitializer(node)) {
-        const extendsClause = getHeritageClause(node.heritageClauses, 96 /* ExtendsKeyword */);
-        const extendsElement = extendsClause && firstOrUndefined(extendsClause.types);
-        const extendsExpression = extendsElement && visitNode(extendsElement.expression, visitor, isExpression);
-        if (extendsExpression) {
-          classInfo2.classSuper = factory2.createUniqueName("_classSuper", 16 /* Optimistic */);
-          const unwrapped = skipOuterExpressions(extendsExpression);
-          const safeExtendsExpression = isClassExpression(unwrapped) && !unwrapped.name || isFunctionExpression(unwrapped) && !unwrapped.name || isArrowFunction(unwrapped) ? factory2.createComma(factory2.createNumericLiteral(0), extendsExpression) : extendsExpression;
-          classDefinitionStatements.push(createLet(classInfo2.classSuper, safeExtendsExpression));
-          const updatedExtendsElement = factory2.updateExpressionWithTypeArguments(
-            extendsElement,
-            classInfo2.classSuper,
-            /*typeArguments*/
-            void 0
-          );
-          const updatedExtendsClause = factory2.updateHeritageClause(extendsClause, [updatedExtendsElement]);
-          heritageClauses = factory2.createNodeArray([updatedExtendsClause]);
-        }
-      } else {
-        heritageClauses = visitNodes2(node.heritageClauses, visitor, isHeritageClause);
-      }
-      const renamedClassThis = classInfo2.classThis ?? factory2.createThis();
-      const needsSetNameHelper = !((_a = getOriginalNode(node, isClassLike)) == null ? void 0 : _a.name) && (classDecorators || !isStringLiteral(className) || !isEmptyStringLiteral(className));
-      if (needsSetNameHelper) {
-        const setNameExpr = emitHelpers().createSetFunctionNameHelper(factory2.createThis(), className);
-        leadingBlockStatements = append(leadingBlockStatements, factory2.createExpressionStatement(setNameExpr));
-      }
-      enterClass(classInfo2);
-      let members = visitNodes2(node.members, classElementVisitor, isClassElement);
-      if (pendingExpressions) {
-        let outerThis;
-        for (let expression of pendingExpressions) {
-          expression = visitNode(expression, function thisVisitor(node2) {
-            if (!(node2.transformFlags & 16384 /* ContainsLexicalThis */)) {
-              return node2;
-            }
-            switch (node2.kind) {
-              case 110 /* ThisKeyword */:
-                if (!outerThis) {
-                  outerThis = factory2.createUniqueName("_outerThis", 16 /* Optimistic */);
-                  classDefinitionStatements.unshift(createLet(outerThis, factory2.createThis()));
-                }
-                return outerThis;
-              default:
-                return visitEachChild(node2, thisVisitor, context);
-            }
-          }, isExpression);
-          const statement = factory2.createExpressionStatement(expression);
-          leadingBlockStatements = append(leadingBlockStatements, statement);
-        }
-        pendingExpressions = void 0;
-      }
-      exitClass();
-      if (classInfo2.instanceExtraInitializersName && !getFirstConstructorWithBody(node)) {
-        const initializerStatements = prepareConstructor(node, classInfo2);
-        if (initializerStatements) {
-          const extendsClauseElement = getEffectiveBaseTypeNode(node);
-          const isDerivedClass = !!(extendsClauseElement && skipOuterExpressions(extendsClauseElement.expression).kind !== 106 /* NullKeyword */);
-          const constructorStatements = [];
-          if (isDerivedClass) {
-            const spreadArguments = factory2.createSpreadElement(factory2.createIdentifier("arguments"));
-            const superCall = factory2.createCallExpression(
-              factory2.createSuper(),
-              /*typeArguments*/
-              void 0,
-              [spreadArguments]
-            );
-            constructorStatements.push(factory2.createExpressionStatement(superCall));
-          }
-          addRange(constructorStatements, initializerStatements);
-          const constructorBody = factory2.createBlock(
-            constructorStatements,
-            /*multiLine*/
-            true
-          );
-          syntheticConstructor = factory2.createConstructorDeclaration(
-            /*modifiers*/
-            void 0,
-            [],
-            constructorBody
-          );
-        }
-      }
-      if (classInfo2.staticExtraInitializersName) {
-        classDefinitionStatements.push(
-          createLet(classInfo2.staticExtraInitializersName, factory2.createArrayLiteralExpression())
-        );
-      }
-      if (classInfo2.instanceExtraInitializersName) {
-        classDefinitionStatements.push(
-          createLet(classInfo2.instanceExtraInitializersName, factory2.createArrayLiteralExpression())
-        );
-      }
-      if (classInfo2.memberInfos) {
-        forEachEntry(classInfo2.memberInfos, (memberInfo, member) => {
-          if (isStatic(member)) {
-            classDefinitionStatements.push(createLet(memberInfo.memberDecoratorsName));
-            if (memberInfo.memberInitializersName) {
-              classDefinitionStatements.push(createLet(memberInfo.memberInitializersName, factory2.createArrayLiteralExpression()));
-            }
-            if (memberInfo.memberDescriptorName) {
-              classDefinitionStatements.push(createLet(memberInfo.memberDescriptorName));
-            }
-          }
-        });
-      }
-      if (classInfo2.memberInfos) {
-        forEachEntry(classInfo2.memberInfos, (memberInfo, member) => {
-          if (!isStatic(member)) {
-            classDefinitionStatements.push(createLet(memberInfo.memberDecoratorsName));
-            if (memberInfo.memberInitializersName) {
-              classDefinitionStatements.push(createLet(memberInfo.memberInitializersName, factory2.createArrayLiteralExpression()));
-            }
-            if (memberInfo.memberDescriptorName) {
-              classDefinitionStatements.push(createLet(memberInfo.memberDescriptorName));
-            }
-          }
-        });
-      }
-      leadingBlockStatements = addRange(leadingBlockStatements, classInfo2.staticNonFieldDecorationStatements);
-      leadingBlockStatements = addRange(leadingBlockStatements, classInfo2.nonStaticNonFieldDecorationStatements);
-      leadingBlockStatements = addRange(leadingBlockStatements, classInfo2.staticFieldDecorationStatements);
-      leadingBlockStatements = addRange(leadingBlockStatements, classInfo2.nonStaticFieldDecorationStatements);
-      if (classInfo2.classDescriptorName && classInfo2.classDecoratorsName && classInfo2.classExtraInitializersName && classInfo2.classThis) {
-        leadingBlockStatements ?? (leadingBlockStatements = []);
-        const valueProperty = factory2.createPropertyAssignment("value", factory2.createThis());
-        const classDescriptor = factory2.createObjectLiteralExpression([valueProperty]);
-        const classDescriptorAssignment = factory2.createAssignment(classInfo2.classDescriptorName, classDescriptor);
-        const classNameReference = factory2.createPropertyAccessExpression(factory2.createThis(), "name");
-        const esDecorateHelper2 = emitHelpers().createESDecorateHelper(
-          factory2.createNull(),
-          classDescriptorAssignment,
-          classInfo2.classDecoratorsName,
-          { kind: "class", name: classNameReference },
-          factory2.createNull(),
-          classInfo2.classExtraInitializersName
-        );
-        const esDecorateStatement = factory2.createExpressionStatement(esDecorateHelper2);
-        setSourceMapRange(esDecorateStatement, moveRangePastDecorators(node));
-        leadingBlockStatements.push(esDecorateStatement);
-        const classDescriptorValueReference = factory2.createPropertyAccessExpression(classInfo2.classDescriptorName, "value");
-        const classThisAssignment = factory2.createAssignment(classInfo2.classThis, classDescriptorValueReference);
-        const classReferenceAssignment = factory2.createAssignment(classReference, classThisAssignment);
-        leadingBlockStatements.push(factory2.createExpressionStatement(classReferenceAssignment));
-      }
-      if (classInfo2.staticExtraInitializersName) {
-        const runStaticInitializersHelper = emitHelpers().createRunInitializersHelper(renamedClassThis, classInfo2.staticExtraInitializersName);
-        const runStaticInitializersStatement = factory2.createExpressionStatement(runStaticInitializersHelper);
-        setSourceMapRange(runStaticInitializersStatement, node.name ?? moveRangePastDecorators(node));
-        leadingBlockStatements = append(leadingBlockStatements, runStaticInitializersStatement);
-      }
-      if (classInfo2.classExtraInitializersName) {
-        const runClassInitializersHelper = emitHelpers().createRunInitializersHelper(renamedClassThis, classInfo2.classExtraInitializersName);
-        const runClassInitializersStatement = factory2.createExpressionStatement(runClassInitializersHelper);
-        setSourceMapRange(runClassInitializersStatement, node.name ?? moveRangePastDecorators(node));
-        trailingBlockStatements = append(trailingBlockStatements, runClassInitializersStatement);
-      }
-      if (leadingBlockStatements && trailingBlockStatements && !classInfo2.hasStaticInitializers) {
-        addRange(leadingBlockStatements, trailingBlockStatements);
-        trailingBlockStatements = void 0;
-      }
-      let newMembers = members;
-      if (leadingBlockStatements) {
-        const leadingStaticBlockBody = factory2.createBlock(
-          leadingBlockStatements,
-          /*multiLine*/
-          true
-        );
-        const leadingStaticBlock = factory2.createClassStaticBlockDeclaration(leadingStaticBlockBody);
-        if (shouldTransformPrivateStaticElementsInClass) {
-          setInternalEmitFlags(leadingStaticBlock, 32 /* TransformPrivateStaticElements */);
-        }
-        newMembers = [leadingStaticBlock, ...newMembers];
-      }
-      if (syntheticConstructor) {
-        newMembers = [...newMembers, syntheticConstructor];
-      }
-      if (trailingBlockStatements) {
-        const trailingStaticBlockBody = factory2.createBlock(
-          trailingBlockStatements,
-          /*multiLine*/
-          true
-        );
-        const trailingStaticBlock = factory2.createClassStaticBlockDeclaration(trailingStaticBlockBody);
-        newMembers = [...newMembers, trailingStaticBlock];
-      }
-      if (newMembers !== members) {
-        members = setTextRange(factory2.createNodeArray(newMembers), members);
-      }
-      const lexicalEnvironment = endLexicalEnvironment();
-      let classExpression;
-      if (classDecorators) {
-        classExpression = factory2.createClassExpression(
-          /*modifiers*/
-          void 0,
-          /*name*/
-          void 0,
-          /*typeParameters*/
-          void 0,
-          heritageClauses,
-          members
-        );
-        const classReferenceDeclaration = factory2.createVariableDeclaration(
-          classReference,
-          /*exclamationToken*/
-          void 0,
-          /*type*/
-          void 0,
-          classExpression
-        );
-        const classReferenceVarDeclList = factory2.createVariableDeclarationList([classReferenceDeclaration]);
-        const returnExpr = classInfo2.classThis ? factory2.createAssignment(classReference, classInfo2.classThis) : classReference;
-        classDefinitionStatements.push(
-          factory2.createVariableStatement(
-            /*modifiers*/
-            void 0,
-            classReferenceVarDeclList
-          ),
-          factory2.createReturnStatement(returnExpr)
-        );
-      } else {
-        classExpression = factory2.createClassExpression(
-          /*modifiers*/
-          void 0,
-          node.name,
-          /*typeParameters*/
-          void 0,
-          heritageClauses,
-          members
-        );
-        classDefinitionStatements.push(factory2.createReturnStatement(classExpression));
-      }
-      if (shouldTransformPrivateStaticElementsInClass) {
-        addInternalEmitFlags(classExpression, 32 /* TransformPrivateStaticElements */);
-        for (const member of classExpression.members) {
-          if ((isPrivateIdentifierClassElementDeclaration(member) || isAutoAccessorPropertyDeclaration(member)) && hasStaticModifier(member)) {
-            addInternalEmitFlags(member, 32 /* TransformPrivateStaticElements */);
-          }
-        }
-      }
-      setOriginalNode(classExpression, node);
-      getOrCreateEmitNode(classExpression).classThis = classInfo2.classThis;
-      return factory2.createImmediatelyInvokedArrowFunction(factory2.mergeLexicalEnvironment(classDefinitionStatements, lexicalEnvironment));
-    }
-    function isDecoratedClassLike(node) {
-      return classOrConstructorParameterIsDecorated(
-        /*useLegacyDecorators*/
-        false,
-        node
-      ) || childIsDecorated(
-        /*useLegacyDecorators*/
-        false,
-        node
-      );
-    }
-    function visitClassDeclaration(node) {
-      if (isDecoratedClassLike(node)) {
-        if (hasSyntacticModifier(node, 1 /* Export */) && hasSyntacticModifier(node, 1024 /* Default */)) {
-          const originalClass = getOriginalNode(node, isClassLike) ?? node;
-          const className = originalClass.name ? factory2.createStringLiteralFromNode(originalClass.name) : factory2.createStringLiteral("default");
-          const iife = transformClassLike(node, className);
-          const statement = factory2.createExportDefault(iife);
-          setOriginalNode(statement, node);
-          setCommentRange(statement, getCommentRange(node));
-          setSourceMapRange(statement, moveRangePastDecorators(node));
-          return statement;
-        } else {
-          Debug.assertIsDefined(node.name, "A class declaration that is not a default export must have a name.");
-          const iife = transformClassLike(node, factory2.createStringLiteralFromNode(node.name));
-          const modifiers = visitNodes2(node.modifiers, modifierVisitor, isModifier);
-          const declName = languageVersion <= 2 /* ES2015 */ ? factory2.getInternalName(
-            node,
-            /*allowComments*/
-            false,
-            /*allowSourceMaps*/
-            true
-          ) : factory2.getLocalName(
-            node,
-            /*allowComments*/
-            false,
-            /*allowSourceMaps*/
-            true
-          );
-          const varDecl = factory2.createVariableDeclaration(
-            declName,
-            /*exclamationToken*/
-            void 0,
-            /*type*/
-            void 0,
-            iife
-          );
-          setOriginalNode(varDecl, node);
-          const varDecls = factory2.createVariableDeclarationList([varDecl], 1 /* Let */);
-          const statement = factory2.createVariableStatement(modifiers, varDecls);
-          setOriginalNode(statement, node);
-          setCommentRange(statement, getCommentRange(node));
-          return statement;
-        }
-      } else {
-        const modifiers = visitNodes2(node.modifiers, modifierVisitor, isModifier);
-        const heritageClauses = visitNodes2(node.heritageClauses, visitor, isHeritageClause);
-        enterClass(
-          /*classInfo*/
-          void 0
-        );
-        const members = visitNodes2(node.members, classElementVisitor, isClassElement);
-        exitClass();
-        return factory2.updateClassDeclaration(
-          node,
-          modifiers,
-          node.name,
-          /*typeParameters*/
-          void 0,
-          heritageClauses,
-          members
-        );
-      }
-    }
-    function visitClassExpression(node, referencedName) {
-      if (isDecoratedClassLike(node)) {
-        const className = node.name ? factory2.createStringLiteralFromNode(node.name) : referencedName ?? factory2.createStringLiteral("");
-        const iife = transformClassLike(node, className);
-        setOriginalNode(iife, node);
-        return iife;
-      } else {
-        const modifiers = visitNodes2(node.modifiers, modifierVisitor, isModifier);
-        const heritageClauses = visitNodes2(node.heritageClauses, visitor, isHeritageClause);
-        enterClass(
-          /*classInfo*/
-          void 0
-        );
-        const members = visitNodes2(node.members, classElementVisitor, isClassElement);
-        exitClass();
-        return factory2.updateClassExpression(
-          node,
-          modifiers,
-          node.name,
-          /*typeParameters*/
-          void 0,
-          heritageClauses,
-          members
-        );
-      }
-    }
-    function prepareConstructor(_parent, classInfo2) {
-      if (classInfo2.instanceExtraInitializersName && !classInfo2.hasNonAmbientInstanceFields) {
-        const statements = [];
-        statements.push(
-          factory2.createExpressionStatement(
-            emitHelpers().createRunInitializersHelper(
-              factory2.createThis(),
-              classInfo2.instanceExtraInitializersName
-            )
-          )
-        );
-        return statements;
-      }
-    }
-    function visitConstructorDeclaration(node) {
-      enterClassElement(node);
-      const modifiers = visitNodes2(node.modifiers, modifierVisitor, isModifier);
-      const parameters = visitNodes2(node.parameters, visitor, isParameter);
-      let body;
-      if (node.body && classInfo) {
-        const initializerStatements = prepareConstructor(classInfo.class, classInfo);
-        if (initializerStatements) {
-          const statements = [];
-          const nonPrologueStart = factory2.copyPrologue(
-            node.body.statements,
-            statements,
-            /*ensureUseStrict*/
-            false,
-            visitor
-          );
-          const superStatementIndex = findSuperStatementIndex(node.body.statements, nonPrologueStart);
-          if (superStatementIndex >= 0) {
-            addRange(statements, visitNodes2(node.body.statements, visitor, isStatement, nonPrologueStart, superStatementIndex + 1 - nonPrologueStart));
-            addRange(statements, initializerStatements);
-            addRange(statements, visitNodes2(node.body.statements, visitor, isStatement, superStatementIndex + 1));
-          } else {
-            addRange(statements, initializerStatements);
-            addRange(statements, visitNodes2(node.body.statements, visitor, isStatement));
-          }
-          body = factory2.createBlock(
-            statements,
-            /*multiLine*/
-            true
-          );
-          setOriginalNode(body, node.body);
-          setTextRange(body, node.body);
-        }
-      }
-      body ?? (body = visitNode(node.body, visitor, isBlock));
-      exitClassElement();
-      return factory2.updateConstructorDeclaration(node, modifiers, parameters, body);
-    }
-    function finishClassElement(updated, original) {
-      if (updated !== original) {
-        setCommentRange(updated, original);
-        setSourceMapRange(updated, moveRangePastDecorators(original));
-      }
-      return updated;
-    }
-    function partialTransformClassElement(member, useNamedEvaluation, classInfo2, createDescriptor) {
-      let referencedName;
-      let name;
-      let initializersName;
-      let thisArg;
-      let descriptorName;
-      if (!classInfo2) {
-        const modifiers2 = visitNodes2(member.modifiers, modifierVisitor, isModifier);
-        enterName();
-        if (useNamedEvaluation) {
-          ({ referencedName, name } = visitReferencedPropertyName(member.name));
-        } else {
-          name = visitPropertyName(member.name);
-        }
-        exitName();
-        return { modifiers: modifiers2, referencedName, name, initializersName, descriptorName, thisArg };
-      }
-      const memberDecorators = transformAllDecoratorsOfDeclaration(getAllDecoratorsOfClassElement(
-        member,
-        classInfo2.class,
-        /*useLegacyDecorators*/
-        false
-      ));
-      const modifiers = visitNodes2(member.modifiers, modifierVisitor, isModifier);
-      if (memberDecorators) {
-        const memberDecoratorsName = createHelperVariable(member, "decorators");
-        const memberDecoratorsArray = factory2.createArrayLiteralExpression(memberDecorators);
-        const memberDecoratorsAssignment = factory2.createAssignment(memberDecoratorsName, memberDecoratorsArray);
-        const memberInfo = { memberDecoratorsName };
-        classInfo2.memberInfos ?? (classInfo2.memberInfos = /* @__PURE__ */ new Map());
-        classInfo2.memberInfos.set(member, memberInfo);
-        pendingExpressions ?? (pendingExpressions = []);
-        pendingExpressions.push(memberDecoratorsAssignment);
-        const statements = isMethodOrAccessor(member) || isAutoAccessorPropertyDeclaration(member) ? isStatic(member) ? classInfo2.staticNonFieldDecorationStatements ?? (classInfo2.staticNonFieldDecorationStatements = []) : classInfo2.nonStaticNonFieldDecorationStatements ?? (classInfo2.nonStaticNonFieldDecorationStatements = []) : isPropertyDeclaration(member) && !isAutoAccessorPropertyDeclaration(member) ? isStatic(member) ? classInfo2.staticFieldDecorationStatements ?? (classInfo2.staticFieldDecorationStatements = []) : classInfo2.nonStaticFieldDecorationStatements ?? (classInfo2.nonStaticFieldDecorationStatements = []) : Debug.fail();
-        const kind = isGetAccessorDeclaration(member) ? "getter" : isSetAccessorDeclaration(member) ? "setter" : isMethodDeclaration(member) ? "method" : isAutoAccessorPropertyDeclaration(member) ? "accessor" : isPropertyDeclaration(member) ? "field" : Debug.fail();
-        let propertyName;
-        if (isIdentifier(member.name) || isPrivateIdentifier(member.name)) {
-          propertyName = { computed: false, name: member.name };
-        } else if (isPropertyNameLiteral(member.name)) {
-          propertyName = { computed: true, name: factory2.createStringLiteralFromNode(member.name) };
-        } else {
-          const expression = member.name.expression;
-          if (isPropertyNameLiteral(expression) && !isIdentifier(expression)) {
-            propertyName = { computed: true, name: factory2.createStringLiteralFromNode(expression) };
-          } else {
-            enterName();
-            ({ referencedName, name } = visitReferencedPropertyName(member.name));
-            propertyName = { computed: true, name: referencedName };
-            exitName();
-          }
-        }
-        const context2 = {
-          kind,
-          name: propertyName,
-          static: isStatic(member),
-          private: isPrivateIdentifier(member.name),
-          access: {
-            // 15.7.3 CreateDecoratorAccessObject (kind, name)
-            // 2. If _kind_ is ~field~, ~method~, ~accessor~, or ~getter~, then ...
-            get: isPropertyDeclaration(member) || isGetAccessorDeclaration(member) || isMethodDeclaration(member),
-            // 3. If _kind_ is ~field~, ~accessor~, or ~setter~, then ...
-            set: isPropertyDeclaration(member) || isSetAccessorDeclaration(member)
-          }
-        };
-        const extraInitializers = isStatic(member) ? classInfo2.staticExtraInitializersName ?? (classInfo2.staticExtraInitializersName = factory2.createUniqueName("_staticExtraInitializers", 16 /* Optimistic */)) : classInfo2.instanceExtraInitializersName ?? (classInfo2.instanceExtraInitializersName = factory2.createUniqueName("_instanceExtraInitializers", 16 /* Optimistic */));
-        if (isMethodOrAccessor(member)) {
-          let descriptor;
-          if (isPrivateIdentifierClassElementDeclaration(member) && createDescriptor) {
-            descriptor = createDescriptor(member, visitNodes2(modifiers, (node) => tryCast(node, isAsyncModifier), isModifier));
-            memberInfo.memberDescriptorName = descriptorName = createHelperVariable(member, "descriptor");
-            descriptor = factory2.createAssignment(descriptorName, descriptor);
-          }
-          const esDecorateExpression = emitHelpers().createESDecorateHelper(factory2.createThis(), descriptor ?? factory2.createNull(), memberDecoratorsName, context2, factory2.createNull(), extraInitializers);
-          const esDecorateStatement = factory2.createExpressionStatement(esDecorateExpression);
-          setSourceMapRange(esDecorateStatement, moveRangePastDecorators(member));
-          statements.push(esDecorateStatement);
-        } else if (isPropertyDeclaration(member)) {
-          initializersName = memberInfo.memberInitializersName ?? (memberInfo.memberInitializersName = createHelperVariable(member, "initializers"));
-          if (isStatic(member)) {
-            thisArg = classInfo2.classThis;
-          }
-          let descriptor;
-          if (isPrivateIdentifierClassElementDeclaration(member) && hasAccessorModifier(member) && createDescriptor) {
-            descriptor = createDescriptor(
-              member,
-              /*modifiers*/
-              void 0
-            );
-            memberInfo.memberDescriptorName = descriptorName = createHelperVariable(member, "descriptor");
-            descriptor = factory2.createAssignment(descriptorName, descriptor);
-          }
-          const esDecorateExpression = emitHelpers().createESDecorateHelper(
-            isAutoAccessorPropertyDeclaration(member) ? factory2.createThis() : factory2.createNull(),
-            descriptor ?? factory2.createNull(),
-            memberDecoratorsName,
-            context2,
-            initializersName,
-            extraInitializers
-          );
-          const esDecorateStatement = factory2.createExpressionStatement(esDecorateExpression);
-          setSourceMapRange(esDecorateStatement, moveRangePastDecorators(member));
-          statements.push(esDecorateStatement);
-        }
-      }
-      if (name === void 0) {
-        enterName();
-        if (useNamedEvaluation) {
-          ({ referencedName, name } = visitReferencedPropertyName(member.name));
-        } else {
-          name = visitPropertyName(member.name);
-        }
-        exitName();
-      }
-      if (!some(modifiers) && (isMethodDeclaration(member) || isPropertyDeclaration(member))) {
-        setEmitFlags(name, 1024 /* NoLeadingComments */);
-      }
-      return { modifiers, referencedName, name, initializersName, descriptorName, thisArg };
-    }
-    function visitMethodDeclaration(node) {
-      enterClassElement(node);
-      const { modifiers, name, descriptorName } = partialTransformClassElement(
-        node,
-        /*useNamedEvaluation*/
-        false,
-        classInfo,
-        createMethodDescriptorObject
-      );
-      if (descriptorName) {
-        exitClassElement();
-        return finishClassElement(createMethodDescriptorForwarder(modifiers, name, descriptorName), node);
-      } else {
-        const parameters = visitNodes2(node.parameters, visitor, isParameter);
-        const body = visitNode(node.body, visitor, isBlock);
-        exitClassElement();
-        return finishClassElement(factory2.updateMethodDeclaration(
-          node,
-          modifiers,
-          node.asteriskToken,
-          name,
-          /*questionToken*/
-          void 0,
-          /*typeParameters*/
-          void 0,
-          parameters,
-          /*type*/
-          void 0,
-          body
-        ), node);
-      }
-    }
-    function visitGetAccessorDeclaration(node) {
-      enterClassElement(node);
-      const { modifiers, name, descriptorName } = partialTransformClassElement(
-        node,
-        /*useNamedEvaluation*/
-        false,
-        classInfo,
-        createGetAccessorDescriptorObject
-      );
-      if (descriptorName) {
-        exitClassElement();
-        return finishClassElement(createGetAccessorDescriptorForwarder(modifiers, name, descriptorName), node);
-      } else {
-        const parameters = visitNodes2(node.parameters, visitor, isParameter);
-        const body = visitNode(node.body, visitor, isBlock);
-        exitClassElement();
-        return finishClassElement(factory2.updateGetAccessorDeclaration(
-          node,
-          modifiers,
-          name,
-          parameters,
-          /*type*/
-          void 0,
-          body
-        ), node);
-      }
-    }
-    function visitSetAccessorDeclaration(node) {
-      enterClassElement(node);
-      const { modifiers, name, descriptorName } = partialTransformClassElement(
-        node,
-        /*useNamedEvaluation*/
-        false,
-        classInfo,
-        createSetAccessorDescriptorObject
-      );
-      if (descriptorName) {
-        exitClassElement();
-        return finishClassElement(createSetAccessorDescriptorForwarder(modifiers, name, descriptorName), node);
-      } else {
-        const parameters = visitNodes2(node.parameters, visitor, isParameter);
-        const body = visitNode(node.body, visitor, isBlock);
-        exitClassElement();
-        return finishClassElement(factory2.updateSetAccessorDeclaration(node, modifiers, name, parameters, body), node);
-      }
-    }
-    function visitClassStaticBlockDeclaration(node) {
-      enterClassElement(node);
-      if (classInfo)
-        classInfo.hasStaticInitializers = true;
-      const result = visitEachChild(node, visitor, context);
-      exitClassElement();
-      return result;
-    }
-    function visitPropertyDeclaration(node) {
-      enterClassElement(node);
-      Debug.assert(!isAmbientPropertyDeclaration(node), "Not yet implemented.");
-      const useNamedEvaluation = isNamedEvaluation(node, isAnonymousClassNeedingAssignedName);
-      const { modifiers, name, referencedName, initializersName, descriptorName, thisArg } = partialTransformClassElement(node, useNamedEvaluation, classInfo, hasAccessorModifier(node) ? createAccessorPropertyDescriptorObject : void 0);
-      startLexicalEnvironment();
-      let initializer = referencedName ? visitNode(node.initializer, (node2) => namedEvaluationVisitor(node2, referencedName), isExpression) : visitNode(node.initializer, visitor, isExpression);
-      if (initializersName) {
-        initializer = emitHelpers().createRunInitializersHelper(
-          thisArg ?? factory2.createThis(),
-          initializersName,
-          initializer ?? factory2.createVoidZero()
-        );
-      }
-      if (!isStatic(node) && (classInfo == null ? void 0 : classInfo.instanceExtraInitializersName) && !(classInfo == null ? void 0 : classInfo.hasInjectedInstanceInitializers)) {
-        classInfo.hasInjectedInstanceInitializers = true;
-        initializer ?? (initializer = factory2.createVoidZero());
-        initializer = factory2.createParenthesizedExpression(factory2.createComma(
-          emitHelpers().createRunInitializersHelper(
-            factory2.createThis(),
-            classInfo.instanceExtraInitializersName
-          ),
-          initializer
-        ));
-      }
-      if (isStatic(node) && classInfo && initializer) {
-        classInfo.hasStaticInitializers = true;
-      }
-      const declarations = endLexicalEnvironment();
-      if (some(declarations)) {
-        initializer = factory2.createImmediatelyInvokedArrowFunction([
-          ...declarations,
-          factory2.createReturnStatement(initializer)
-        ]);
-      }
-      exitClassElement();
-      if (hasAccessorModifier(node) && descriptorName) {
-        const commentRange = getCommentRange(node);
-        const sourceMapRange = getSourceMapRange(node);
-        const name2 = node.name;
-        let getterName = name2;
-        let setterName = name2;
-        if (isComputedPropertyName(name2) && !isSimpleInlineableExpression(name2.expression)) {
-          const cacheAssignment = findComputedPropertyNameCacheAssignment(name2);
-          if (cacheAssignment) {
-            getterName = factory2.updateComputedPropertyName(name2, visitNode(name2.expression, visitor, isExpression));
-            setterName = factory2.updateComputedPropertyName(name2, cacheAssignment.left);
-          } else {
-            const temp = factory2.createTempVariable(hoistVariableDeclaration);
-            setSourceMapRange(temp, name2.expression);
-            const expression = visitNode(name2.expression, visitor, isExpression);
-            const assignment = factory2.createAssignment(temp, expression);
-            setSourceMapRange(assignment, name2.expression);
-            getterName = factory2.updateComputedPropertyName(name2, assignment);
-            setterName = factory2.updateComputedPropertyName(name2, temp);
-          }
-        }
-        const modifiersWithoutAccessor = visitNodes2(modifiers, (node2) => node2.kind !== 129 /* AccessorKeyword */ ? node2 : void 0, isModifier);
-        const backingField = createAccessorPropertyBackingField(factory2, node, modifiersWithoutAccessor, initializer);
-        setOriginalNode(backingField, node);
-        setEmitFlags(backingField, 3072 /* NoComments */);
-        setSourceMapRange(backingField, sourceMapRange);
-        setSourceMapRange(backingField.name, node.name);
-        const getter = createGetAccessorDescriptorForwarder(modifiersWithoutAccessor, getterName, descriptorName);
-        setOriginalNode(getter, node);
-        setCommentRange(getter, commentRange);
-        setSourceMapRange(getter, sourceMapRange);
-        const setter = createSetAccessorDescriptorForwarder(modifiersWithoutAccessor, setterName, descriptorName);
-        setOriginalNode(setter, node);
-        setEmitFlags(setter, 3072 /* NoComments */);
-        setSourceMapRange(setter, sourceMapRange);
-        return [backingField, getter, setter];
-      }
-      return finishClassElement(factory2.updatePropertyDeclaration(
-        node,
-        modifiers,
-        name,
-        /*questionOrExclamationToken*/
-        void 0,
-        /*type*/
-        void 0,
-        initializer
-      ), node);
-    }
-    function visitThisExpression(node) {
-      return classThis ?? node;
-    }
-    function visitCallExpression(node) {
-      if (isSuperProperty(node.expression) && classThis) {
-        const expression = visitNode(node.expression, visitor, isExpression);
-        const argumentsList = visitNodes2(node.arguments, visitor, isExpression);
-        const invocation = factory2.createFunctionCallCall(expression, classThis, argumentsList);
-        setOriginalNode(invocation, node);
-        setTextRange(invocation, node);
-        return invocation;
-      }
-      return visitEachChild(node, visitor, context);
-    }
-    function visitTaggedTemplateExpression(node) {
-      if (isSuperProperty(node.tag) && classThis) {
-        const tag = visitNode(node.tag, visitor, isExpression);
-        const boundTag = factory2.createFunctionBindCall(tag, classThis, []);
-        setOriginalNode(boundTag, node);
-        setTextRange(boundTag, node);
-        const template = visitNode(node.template, visitor, isTemplateLiteral);
-        return factory2.updateTaggedTemplateExpression(
-          node,
-          boundTag,
-          /*typeArguments*/
-          void 0,
-          template
-        );
-      }
-      return visitEachChild(node, visitor, context);
-    }
-    function visitPropertyAccessExpression(node) {
-      if (isSuperProperty(node) && isIdentifier(node.name) && classThis && classSuper) {
-        const propertyName = factory2.createStringLiteralFromNode(node.name);
-        const superProperty = factory2.createReflectGetCall(classSuper, propertyName, classThis);
-        setOriginalNode(superProperty, node.expression);
-        setTextRange(superProperty, node.expression);
-        return superProperty;
-      }
-      return visitEachChild(node, visitor, context);
-    }
-    function visitElementAccessExpression(node) {
-      if (isSuperProperty(node) && classThis && classSuper) {
-        const propertyName = visitNode(node.argumentExpression, visitor, isExpression);
-        const superProperty = factory2.createReflectGetCall(classSuper, propertyName, classThis);
-        setOriginalNode(superProperty, node.expression);
-        setTextRange(superProperty, node.expression);
-        return superProperty;
-      }
-      return visitEachChild(node, visitor, context);
-    }
-    function visitParameterDeclaration(node) {
-      let updated;
-      if (isNamedEvaluation(node, isAnonymousClassNeedingAssignedName)) {
-        const assignedName = getAssignedNameOfIdentifier(node.name, node.initializer);
-        const name = visitNode(node.name, visitor, isBindingName);
-        const initializer = visitNode(node.initializer, (node2) => namedEvaluationVisitor(node2, assignedName), isExpression);
-        updated = factory2.updateParameterDeclaration(
-          node,
-          /*modifiers*/
-          void 0,
-          /*dotDotDotToken*/
-          void 0,
-          name,
-          /*questionToken*/
-          void 0,
-          /*type*/
-          void 0,
-          initializer
-        );
-      } else {
-        updated = factory2.updateParameterDeclaration(
-          node,
-          /*modifiers*/
-          void 0,
-          node.dotDotDotToken,
-          visitNode(node.name, visitor, isBindingName),
-          /*questionToken*/
-          void 0,
-          /*type*/
-          void 0,
-          visitNode(node.initializer, visitor, isExpression)
-        );
-      }
-      if (updated !== node) {
-        setCommentRange(updated, node);
-        setTextRange(updated, moveRangePastModifiers(node));
-        setSourceMapRange(updated, moveRangePastModifiers(node));
-        setEmitFlags(updated.name, 64 /* NoTrailingSourceMap */);
-      }
-      return updated;
-    }
-    function isAnonymousClassNeedingAssignedName(node) {
-      return isClassExpression(node) && !node.name && isDecoratedClassLike(node);
-    }
-    function visitForStatement(node) {
-      return factory2.updateForStatement(
-        node,
-        visitNode(node.initializer, discardedValueVisitor, isForInitializer),
-        visitNode(node.condition, visitor, isExpression),
-        visitNode(node.incrementor, discardedValueVisitor, isExpression),
-        visitIterationBody(node.statement, visitor, context)
-      );
-    }
-    function visitExpressionStatement(node) {
-      return visitEachChild(node, discardedValueVisitor, context);
-    }
-    function visitBinaryExpression(node, discarded) {
-      if (isDestructuringAssignment(node)) {
-        const left = visitAssignmentPattern(node.left);
-        const right = visitNode(node.right, visitor, isExpression);
-        return factory2.updateBinaryExpression(node, left, node.operatorToken, right);
-      }
-      if (isAssignmentExpression(node)) {
-        if (isNamedEvaluation(node, isAnonymousClassNeedingAssignedName)) {
-          const assignedName = getAssignedNameOfIdentifier(node.left, node.right);
-          const left = visitNode(node.left, visitor, isExpression);
-          const right = visitNode(node.right, (node2) => namedEvaluationVisitor(node2, assignedName), isExpression);
-          return factory2.updateBinaryExpression(node, left, node.operatorToken, right);
-        }
-        if (isSuperProperty(node.left) && classThis && classSuper) {
-          let setterName = isElementAccessExpression(node.left) ? visitNode(node.left.argumentExpression, visitor, isExpression) : isIdentifier(node.left.name) ? factory2.createStringLiteralFromNode(node.left.name) : void 0;
-          if (setterName) {
-            let expression = visitNode(node.right, visitor, isExpression);
-            if (isCompoundAssignment(node.operatorToken.kind)) {
-              let getterName = setterName;
-              if (!isSimpleInlineableExpression(setterName)) {
-                getterName = factory2.createTempVariable(hoistVariableDeclaration);
-                setterName = factory2.createAssignment(getterName, setterName);
-              }
-              const superPropertyGet = factory2.createReflectGetCall(
-                classSuper,
-                getterName,
-                classThis
-              );
-              setOriginalNode(superPropertyGet, node.left);
-              setTextRange(superPropertyGet, node.left);
-              expression = factory2.createBinaryExpression(
-                superPropertyGet,
-                getNonAssignmentOperatorForCompoundAssignment(node.operatorToken.kind),
-                expression
-              );
-              setTextRange(expression, node);
-            }
-            const temp = discarded ? void 0 : factory2.createTempVariable(hoistVariableDeclaration);
-            if (temp) {
-              expression = factory2.createAssignment(temp, expression);
-              setTextRange(temp, node);
-            }
-            expression = factory2.createReflectSetCall(
-              classSuper,
-              setterName,
-              expression,
-              classThis
-            );
-            setOriginalNode(expression, node);
-            setTextRange(expression, node);
-            if (temp) {
-              expression = factory2.createComma(expression, temp);
-              setTextRange(expression, node);
-            }
-            return expression;
-          }
-        }
-      }
-      if (node.operatorToken.kind === 28 /* CommaToken */) {
-        const left = visitNode(node.left, discardedValueVisitor, isExpression);
-        const right = visitNode(node.right, discarded ? discardedValueVisitor : visitor, isExpression);
-        return factory2.updateBinaryExpression(node, left, node.operatorToken, right);
-      }
-      return visitEachChild(node, visitor, context);
-    }
-    function visitPreOrPostfixUnaryExpression(node, discarded) {
-      if (node.operator === 46 /* PlusPlusToken */ || node.operator === 47 /* MinusMinusToken */) {
-        const operand = skipParentheses(node.operand);
-        if (isSuperProperty(operand) && classThis && classSuper) {
-          let setterName = isElementAccessExpression(operand) ? visitNode(operand.argumentExpression, visitor, isExpression) : isIdentifier(operand.name) ? factory2.createStringLiteralFromNode(operand.name) : void 0;
-          if (setterName) {
-            let getterName = setterName;
-            if (!isSimpleInlineableExpression(setterName)) {
-              getterName = factory2.createTempVariable(hoistVariableDeclaration);
-              setterName = factory2.createAssignment(getterName, setterName);
-            }
-            let expression = factory2.createReflectGetCall(classSuper, getterName, classThis);
-            setOriginalNode(expression, node);
-            setTextRange(expression, node);
-            const temp = discarded ? void 0 : factory2.createTempVariable(hoistVariableDeclaration);
-            expression = expandPreOrPostfixIncrementOrDecrementExpression(factory2, node, expression, hoistVariableDeclaration, temp);
-            expression = factory2.createReflectSetCall(classSuper, setterName, expression, classThis);
-            setOriginalNode(expression, node);
-            setTextRange(expression, node);
-            if (temp) {
-              expression = factory2.createComma(expression, temp);
-              setTextRange(expression, node);
-            }
-            return expression;
-          }
-        }
-      }
-      return visitEachChild(node, visitor, context);
-    }
-    function visitCommaListExpression(node, discarded) {
-      const elements = discarded ? visitCommaListElements(node.elements, discardedValueVisitor) : visitCommaListElements(node.elements, visitor, discardedValueVisitor);
-      return factory2.updateCommaListExpression(node, elements);
-    }
-    function visitReferencedPropertyName(node) {
-      if (isPropertyNameLiteral(node) || isPrivateIdentifier(node)) {
-        const referencedName2 = factory2.createStringLiteralFromNode(node);
-        const name2 = visitNode(node, visitor, isPropertyName);
-        return { referencedName: referencedName2, name: name2 };
-      }
-      if (isPropertyNameLiteral(node.expression) && !isIdentifier(node.expression)) {
-        const referencedName2 = factory2.createStringLiteralFromNode(node.expression);
-        const name2 = visitNode(node, visitor, isPropertyName);
-        return { referencedName: referencedName2, name: name2 };
-      }
-      const referencedName = factory2.getGeneratedNameForNode(node);
-      hoistVariableDeclaration(referencedName);
-      const key = emitHelpers().createPropKeyHelper(visitNode(node.expression, visitor, isExpression));
-      const assignment = factory2.createAssignment(referencedName, key);
-      const name = factory2.updateComputedPropertyName(node, injectPendingExpressions(assignment));
-      return { referencedName, name };
-    }
-    function visitPropertyName(node) {
-      if (isComputedPropertyName(node)) {
-        return visitComputedPropertyName(node);
-      }
-      return visitNode(node, visitor, isPropertyName);
-    }
-    function visitComputedPropertyName(node) {
-      let expression = visitNode(node.expression, visitor, isExpression);
-      if (!isSimpleInlineableExpression(expression)) {
-        expression = injectPendingExpressions(expression);
-      }
-      return factory2.updateComputedPropertyName(node, expression);
-    }
-    function visitPropertyAssignment(node) {
-      if (isNamedEvaluation(node, isAnonymousClassNeedingAssignedName)) {
-        const { referencedName, name } = visitReferencedPropertyName(node.name);
-        const initializer = visitNode(node.initializer, (node2) => namedEvaluationVisitor(node2, referencedName), isExpression);
-        return factory2.updatePropertyAssignment(node, name, initializer);
-      }
-      return visitEachChild(node, visitor, context);
-    }
-    function visitVariableDeclaration(node) {
-      if (isNamedEvaluation(node, isAnonymousClassNeedingAssignedName)) {
-        const assignedName = getAssignedNameOfIdentifier(node.name, node.initializer);
-        const name = visitNode(node.name, visitor, isBindingName);
-        const initializer = visitNode(node.initializer, (node2) => namedEvaluationVisitor(node2, assignedName), isExpression);
-        return factory2.updateVariableDeclaration(
-          node,
-          name,
-          /*exclamationToken*/
-          void 0,
-          /*type*/
-          void 0,
-          initializer
-        );
-      }
-      return visitEachChild(node, visitor, context);
-    }
-    function visitBindingElement(node) {
-      if (isNamedEvaluation(node, isAnonymousClassNeedingAssignedName)) {
-        const assignedName = getAssignedNameOfIdentifier(node.name, node.initializer);
-        const propertyName = visitNode(node.propertyName, visitor, isPropertyName);
-        const name = visitNode(node.name, visitor, isBindingName);
-        const initializer = visitNode(node.initializer, (node2) => namedEvaluationVisitor(node2, assignedName), isExpression);
-        return factory2.updateBindingElement(
-          node,
-          /*dotDotDotToken*/
-          void 0,
-          propertyName,
-          name,
-          initializer
-        );
-      }
-      return visitEachChild(node, visitor, context);
-    }
-    function visitDestructuringAssignmentTarget(node) {
-      if (isObjectLiteralExpression(node) || isArrayLiteralExpression(node)) {
-        return visitAssignmentPattern(node);
-      }
-      if (isSuperProperty(node) && classThis && classSuper) {
-        const propertyName = isElementAccessExpression(node) ? visitNode(node.argumentExpression, visitor, isExpression) : isIdentifier(node.name) ? factory2.createStringLiteralFromNode(node.name) : void 0;
-        if (propertyName) {
-          const paramName = factory2.createTempVariable(
-            /*recordTempVariable*/
-            void 0
-          );
-          const expression = factory2.createAssignmentTargetWrapper(
-            paramName,
-            factory2.createReflectSetCall(
-              classSuper,
-              propertyName,
-              paramName,
-              classThis
-            )
-          );
-          setOriginalNode(expression, node);
-          setTextRange(expression, node);
-          return expression;
-        }
-      }
-      return visitEachChild(node, visitor, context);
-    }
-    function visitAssignmentElement(node) {
-      if (isAssignmentExpression(
-        node,
-        /*excludeCompoundAssignment*/
-        true
-      )) {
-        const assignmentTarget = visitDestructuringAssignmentTarget(node.left);
-        let initializer;
-        if (isNamedEvaluation(node, isAnonymousClassNeedingAssignedName)) {
-          const assignedName = getAssignedNameOfIdentifier(node.left, node.right);
-          initializer = visitNode(node.right, (node2) => namedEvaluationVisitor(node2, assignedName), isExpression);
-        } else {
-          initializer = visitNode(node.right, visitor, isExpression);
-        }
-        return factory2.updateBinaryExpression(node, assignmentTarget, node.operatorToken, initializer);
-      } else {
-        return visitDestructuringAssignmentTarget(node);
-      }
-    }
-    function visitAssignmentRestElement(node) {
-      if (isLeftHandSideExpression(node.expression)) {
-        const expression = visitDestructuringAssignmentTarget(node.expression);
-        return factory2.updateSpreadElement(node, expression);
-      }
-      return visitEachChild(node, visitor, context);
-    }
-    function visitArrayAssignmentElement(node) {
-      Debug.assertNode(node, isArrayBindingOrAssignmentElement);
-      if (isSpreadElement(node))
-        return visitAssignmentRestElement(node);
-      if (!isOmittedExpression(node))
-        return visitAssignmentElement(node);
-      return visitEachChild(node, visitor, context);
-    }
-    function visitAssignmentProperty(node) {
-      const name = visitNode(node.name, visitor, isPropertyName);
-      if (isAssignmentExpression(
-        node.initializer,
-        /*excludeCompoundAssignment*/
-        true
-      )) {
-        const assignmentElement = visitAssignmentElement(node.initializer);
-        return factory2.updatePropertyAssignment(node, name, assignmentElement);
-      }
-      if (isLeftHandSideExpression(node.initializer)) {
-        const assignmentElement = visitDestructuringAssignmentTarget(node.initializer);
-        return factory2.updatePropertyAssignment(node, name, assignmentElement);
-      }
-      return visitEachChild(node, visitor, context);
-    }
-    function visitShorthandAssignmentProperty(node) {
-      if (isNamedEvaluation(node, isAnonymousClassNeedingAssignedName)) {
-        const assignedName = getAssignedNameOfIdentifier(node.name, node.objectAssignmentInitializer);
-        const name = visitNode(node.name, visitor, isIdentifier);
-        const objectAssignmentInitializer = visitNode(node.objectAssignmentInitializer, (node2) => namedEvaluationVisitor(node2, assignedName), isExpression);
-        return factory2.updateShorthandPropertyAssignment(node, name, objectAssignmentInitializer);
-      }
-      return visitEachChild(node, visitor, context);
-    }
-    function visitAssignmentRestProperty(node) {
-      if (isLeftHandSideExpression(node.expression)) {
-        const expression = visitDestructuringAssignmentTarget(node.expression);
-        return factory2.updateSpreadAssignment(node, expression);
-      }
-      return visitEachChild(node, visitor, context);
-    }
-    function visitObjectAssignmentElement(node) {
-      Debug.assertNode(node, isObjectBindingOrAssignmentElement);
-      if (isSpreadAssignment(node))
-        return visitAssignmentRestProperty(node);
-      if (isShorthandPropertyAssignment(node))
-        return visitShorthandAssignmentProperty(node);
-      if (isPropertyAssignment(node))
-        return visitAssignmentProperty(node);
-      return visitEachChild(node, visitor, context);
-    }
-    function visitAssignmentPattern(node) {
-      if (isArrayLiteralExpression(node)) {
-        const elements = visitNodes2(node.elements, visitArrayAssignmentElement, isExpression);
-        return factory2.updateArrayLiteralExpression(node, elements);
-      } else {
-        const properties = visitNodes2(node.properties, visitObjectAssignmentElement, isObjectLiteralElementLike);
-        return factory2.updateObjectLiteralExpression(node, properties);
-      }
-    }
-    function visitExportAssignment(node) {
-      if (isNamedEvaluation(node, isAnonymousClassNeedingAssignedName)) {
-        const referencedName = factory2.createStringLiteral(node.isExportEquals ? "" : "default");
-        const modifiers = visitNodes2(node.modifiers, modifierVisitor, isModifier);
-        const expression = visitNode(node.expression, (node2) => namedEvaluationVisitor(node2, referencedName), isExpression);
-        return factory2.updateExportAssignment(node, modifiers, expression);
-      }
-      return visitEachChild(node, visitor, context);
-    }
-    function visitParenthesizedExpression(node, discarded, referencedName) {
-      const visitorFunc = discarded ? discardedValueVisitor : referencedName ? (node2) => namedEvaluationVisitor(node2, referencedName) : visitor;
-      const expression = visitNode(node.expression, visitorFunc, isExpression);
-      return factory2.updateParenthesizedExpression(node, expression);
-    }
-    function visitPartiallyEmittedExpression(node, discarded, referencedName) {
-      const visitorFunc = discarded ? discardedValueVisitor : referencedName ? (node2) => namedEvaluationVisitor(node2, referencedName) : visitor;
-      const expression = visitNode(node.expression, visitorFunc, isExpression);
-      return factory2.updatePartiallyEmittedExpression(node, expression);
-    }
-    function injectPendingExpressions(expression) {
-      if (some(pendingExpressions)) {
-        if (isParenthesizedExpression(expression)) {
-          pendingExpressions.push(expression.expression);
-          expression = factory2.updateParenthesizedExpression(expression, factory2.inlineExpressions(pendingExpressions));
-        } else {
-          pendingExpressions.push(expression);
-          expression = factory2.inlineExpressions(pendingExpressions);
-        }
-        pendingExpressions = void 0;
-      }
-      return expression;
-    }
-    function transformAllDecoratorsOfDeclaration(allDecorators) {
-      if (!allDecorators) {
-        return void 0;
-      }
-      const decoratorExpressions = [];
-      addRange(decoratorExpressions, map(allDecorators.decorators, transformDecorator));
-      return decoratorExpressions;
-    }
-    function transformDecorator(decorator) {
-      const expression = visitNode(decorator.expression, visitor, isExpression);
-      setEmitFlags(expression, 3072 /* NoComments */);
-      return expression;
-    }
-    function createDescriptorMethod(original, name, modifiers, asteriskToken, kind, parameters, body) {
-      const func = factory2.createFunctionExpression(
-        modifiers,
-        asteriskToken,
-        /*name*/
-        void 0,
-        /*typeParameters*/
-        void 0,
-        parameters,
-        /*type*/
-        void 0,
-        body ?? factory2.createBlock([])
-      );
-      setOriginalNode(func, original);
-      setSourceMapRange(func, moveRangePastDecorators(original));
-      setEmitFlags(func, 3072 /* NoComments */);
-      const prefix = kind === "get" || kind === "set" ? kind : void 0;
-      const functionName = factory2.createStringLiteralFromNode(
-        name,
-        /*isSingleQuote*/
-        void 0
-      );
-      const namedFunction = emitHelpers().createSetFunctionNameHelper(func, functionName, prefix);
-      const method = factory2.createPropertyAssignment(factory2.createIdentifier(kind), namedFunction);
-      setOriginalNode(method, original);
-      setSourceMapRange(method, moveRangePastDecorators(original));
-      setEmitFlags(method, 3072 /* NoComments */);
-      return method;
-    }
-    function createMethodDescriptorObject(node, modifiers) {
-      return factory2.createObjectLiteralExpression([
-        createDescriptorMethod(
-          node,
-          node.name,
-          modifiers,
-          node.asteriskToken,
-          "value",
-          visitNodes2(node.parameters, visitor, isParameter),
-          visitNode(node.body, visitor, isBlock)
-        )
-      ]);
-    }
-    function createGetAccessorDescriptorObject(node, modifiers) {
-      return factory2.createObjectLiteralExpression([
-        createDescriptorMethod(
-          node,
-          node.name,
-          modifiers,
-          /*asteriskToken*/
-          void 0,
-          "get",
-          [],
-          visitNode(node.body, visitor, isBlock)
-        )
-      ]);
-    }
-    function createSetAccessorDescriptorObject(node, modifiers) {
-      return factory2.createObjectLiteralExpression([
-        createDescriptorMethod(
-          node,
-          node.name,
-          modifiers,
-          /*asteriskToken*/
-          void 0,
-          "set",
-          visitNodes2(node.parameters, visitor, isParameter),
-          visitNode(node.body, visitor, isBlock)
-        )
-      ]);
-    }
-    function createAccessorPropertyDescriptorObject(node, modifiers) {
-      return factory2.createObjectLiteralExpression([
-        createDescriptorMethod(
-          node,
-          node.name,
-          modifiers,
-          /*asteriskToken*/
-          void 0,
-          "get",
-          [],
-          factory2.createBlock([
-            factory2.createReturnStatement(
-              factory2.createPropertyAccessExpression(
-                factory2.createThis(),
-                factory2.getGeneratedPrivateNameForNode(node.name)
-              )
-            )
-          ])
-        ),
-        createDescriptorMethod(
-          node,
-          node.name,
-          modifiers,
-          /*asteriskToken*/
-          void 0,
-          "set",
-          [factory2.createParameterDeclaration(
-            /*modifiers*/
-            void 0,
-            /*dotDotDotToken*/
-            void 0,
-            "value"
-          )],
-          factory2.createBlock([
-            factory2.createExpressionStatement(
-              factory2.createAssignment(
-                factory2.createPropertyAccessExpression(
-                  factory2.createThis(),
-                  factory2.getGeneratedPrivateNameForNode(node.name)
-                ),
-                factory2.createIdentifier("value")
-              )
-            )
-          ])
-        )
-      ]);
-    }
-    function createMethodDescriptorForwarder(modifiers, name, descriptorName) {
-      modifiers = visitNodes2(modifiers, (node) => isStaticModifier(node) ? node : void 0, isModifier);
-      return factory2.createGetAccessorDeclaration(
-        modifiers,
-        name,
-        [],
-        /*type*/
-        void 0,
-        factory2.createBlock([
-          factory2.createReturnStatement(
-            factory2.createPropertyAccessExpression(
-              descriptorName,
-              factory2.createIdentifier("value")
-            )
-          )
-        ])
-      );
-    }
-    function createGetAccessorDescriptorForwarder(modifiers, name, descriptorName) {
-      modifiers = visitNodes2(modifiers, (node) => isStaticModifier(node) ? node : void 0, isModifier);
-      return factory2.createGetAccessorDeclaration(
-        modifiers,
-        name,
-        [],
-        /*type*/
-        void 0,
-        factory2.createBlock([
-          factory2.createReturnStatement(
-            factory2.createFunctionCallCall(
-              factory2.createPropertyAccessExpression(
-                descriptorName,
-                factory2.createIdentifier("get")
-              ),
-              factory2.createThis(),
-              []
-            )
-          )
-        ])
-      );
-    }
-    function createSetAccessorDescriptorForwarder(modifiers, name, descriptorName) {
-      modifiers = visitNodes2(modifiers, (node) => isStaticModifier(node) ? node : void 0, isModifier);
-      return factory2.createSetAccessorDeclaration(
-        modifiers,
-        name,
-        [factory2.createParameterDeclaration(
-          /*modifiers*/
-          void 0,
-          /*dotDotDotToken*/
-          void 0,
-          "value"
-        )],
-        factory2.createBlock([
-          factory2.createReturnStatement(
-            factory2.createFunctionCallCall(
-              factory2.createPropertyAccessExpression(
-                descriptorName,
-                factory2.createIdentifier("set")
-              ),
-              factory2.createThis(),
-              [factory2.createIdentifier("value")]
-            )
-          )
-        ])
-      );
-    }
-    function getAssignedNameOfIdentifier(name, initializer) {
-      const originalClass = getOriginalNode(initializer, isClassLike);
-      return originalClass && !originalClass.name && hasSyntacticModifier(originalClass, 1024 /* Default */) ? factory2.createStringLiteral("default") : factory2.createStringLiteralFromNode(name);
-    }
-  }
-  var init_esDecorators = __esm({
-    "src/compiler/transformers/esDecorators.ts"() {
-      "use strict";
-      init_ts2();
-    }
-  });
-
-  // src/compiler/transformers/es2017.ts
-  function transformES2017(context) {
-    const {
-      factory: factory2,
-      getEmitHelperFactory: emitHelpers,
-      resumeLexicalEnvironment,
-      endLexicalEnvironment,
-      hoistVariableDeclaration
-    } = context;
-    const resolver = context.getEmitResolver();
-    const compilerOptions = context.getCompilerOptions();
-    const languageVersion = getEmitScriptTarget(compilerOptions);
-    let enabledSubstitutions;
-    let enclosingSuperContainerFlags = 0;
-    let enclosingFunctionParameterNames;
-    let capturedSuperProperties;
-    let hasSuperElementAccess;
-    const substitutedSuperAccessors = [];
-    let contextFlags = 0 /* None */;
-    const previousOnEmitNode = context.onEmitNode;
-    const previousOnSubstituteNode = context.onSubstituteNode;
-    context.onEmitNode = onEmitNode;
-    context.onSubstituteNode = onSubstituteNode;
-    return chainBundle(context, transformSourceFile);
-    function transformSourceFile(node) {
-      if (node.isDeclarationFile) {
-        return node;
-      }
-      setContextFlag(1 /* NonTopLevel */, false);
-      setContextFlag(2 /* HasLexicalThis */, !isEffectiveStrictModeSourceFile(node, compilerOptions));
-      const visited = visitEachChild(node, visitor, context);
-      addEmitHelpers(visited, context.readEmitHelpers());
-      return visited;
-    }
-    function setContextFlag(flag, val) {
-      contextFlags = val ? contextFlags | flag : contextFlags & ~flag;
-    }
-    function inContext(flags) {
-      return (contextFlags & flags) !== 0;
-    }
-    function inTopLevelContext() {
-      return !inContext(1 /* NonTopLevel */);
-    }
-    function inHasLexicalThisContext() {
-      return inContext(2 /* HasLexicalThis */);
-    }
-    function doWithContext(flags, cb, value) {
-      const contextFlagsToSet = flags & ~contextFlags;
-      if (contextFlagsToSet) {
-        setContextFlag(
-          contextFlagsToSet,
-          /*val*/
-          true
-        );
-        const result = cb(value);
-        setContextFlag(
-          contextFlagsToSet,
-          /*val*/
-          false
-        );
-        return result;
-      }
-      return cb(value);
-    }
-    function visitDefault(node) {
-      return visitEachChild(node, visitor, context);
-    }
-    function visitor(node) {
-      if ((node.transformFlags & 256 /* ContainsES2017 */) === 0) {
-        return node;
-      }
-      switch (node.kind) {
-        case 134 /* AsyncKeyword */:
-          return void 0;
-        case 222 /* AwaitExpression */:
-          return visitAwaitExpression(node);
-        case 173 /* MethodDeclaration */:
-          return doWithContext(1 /* NonTopLevel */ | 2 /* HasLexicalThis */, visitMethodDeclaration, node);
-        case 261 /* FunctionDeclaration */:
-          return doWithContext(1 /* NonTopLevel */ | 2 /* HasLexicalThis */, visitFunctionDeclaration, node);
-        case 217 /* FunctionExpression */:
-          return doWithContext(1 /* NonTopLevel */ | 2 /* HasLexicalThis */, visitFunctionExpression, node);
-        case 218 /* ArrowFunction */:
-          return doWithContext(1 /* NonTopLevel */, visitArrowFunction, node);
-        case 210 /* PropertyAccessExpression */:
-          if (capturedSuperProperties && isPropertyAccessExpression(node) && node.expression.kind === 108 /* SuperKeyword */) {
-            capturedSuperProperties.add(node.name.escapedText);
-          }
-          return visitEachChild(node, visitor, context);
-        case 211 /* ElementAccessExpression */:
-          if (capturedSuperProperties && node.expression.kind === 108 /* SuperKeyword */) {
-            hasSuperElementAccess = true;
-          }
-          return visitEachChild(node, visitor, context);
-        case 176 /* GetAccessor */:
-          return doWithContext(1 /* NonTopLevel */ | 2 /* HasLexicalThis */, visitGetAccessorDeclaration, node);
-        case 177 /* SetAccessor */:
-          return doWithContext(1 /* NonTopLevel */ | 2 /* HasLexicalThis */, visitSetAccessorDeclaration, node);
-        case 175 /* Constructor */:
-          return doWithContext(1 /* NonTopLevel */ | 2 /* HasLexicalThis */, visitConstructorDeclaration, node);
-        case 262 /* ClassDeclaration */:
-        case 230 /* ClassExpression */:
-          return doWithContext(1 /* NonTopLevel */ | 2 /* HasLexicalThis */, visitDefault, node);
-        default:
-          return visitEachChild(node, visitor, context);
-      }
-    }
-    function asyncBodyVisitor(node) {
-      if (isNodeWithPossibleHoistedDeclaration(node)) {
-        switch (node.kind) {
-          case 242 /* VariableStatement */:
-            return visitVariableStatementInAsyncBody(node);
-          case 247 /* ForStatement */:
-            return visitForStatementInAsyncBody(node);
-          case 248 /* ForInStatement */:
-            return visitForInStatementInAsyncBody(node);
-          case 249 /* ForOfStatement */:
-            return visitForOfStatementInAsyncBody(node);
-          case 298 /* CatchClause */:
-            return visitCatchClauseInAsyncBody(node);
-          case 240 /* Block */:
-          case 254 /* SwitchStatement */:
-          case 268 /* CaseBlock */:
-          case 295 /* CaseClause */:
-          case 296 /* DefaultClause */:
-          case 257 /* TryStatement */:
-          case 245 /* DoStatement */:
-          case 246 /* WhileStatement */:
-          case 244 /* IfStatement */:
-          case 253 /* WithStatement */:
-          case 255 /* LabeledStatement */:
-            return visitEachChild(node, asyncBodyVisitor, context);
-          default:
-            return Debug.assertNever(node, "Unhandled node.");
-        }
-      }
-      return visitor(node);
-    }
-    function visitCatchClauseInAsyncBody(node) {
-      const catchClauseNames = /* @__PURE__ */ new Set();
-      recordDeclarationName(node.variableDeclaration, catchClauseNames);
-      let catchClauseUnshadowedNames;
-      catchClauseNames.forEach((_, escapedName) => {
-        if (enclosingFunctionParameterNames.has(escapedName)) {
-          if (!catchClauseUnshadowedNames) {
-            catchClauseUnshadowedNames = new Set(enclosingFunctionParameterNames);
-          }
-          catchClauseUnshadowedNames.delete(escapedName);
-        }
-      });
-      if (catchClauseUnshadowedNames) {
-        const savedEnclosingFunctionParameterNames = enclosingFunctionParameterNames;
-        enclosingFunctionParameterNames = catchClauseUnshadowedNames;
-        const result = visitEachChild(node, asyncBodyVisitor, context);
-        enclosingFunctionParameterNames = savedEnclosingFunctionParameterNames;
-        return result;
-      } else {
-        return visitEachChild(node, asyncBodyVisitor, context);
-      }
-    }
-    function visitVariableStatementInAsyncBody(node) {
-      if (isVariableDeclarationListWithCollidingName(node.declarationList)) {
-        const expression = visitVariableDeclarationListWithCollidingNames(
-          node.declarationList,
-          /*hasReceiver*/
-          false
-        );
-        return expression ? factory2.createExpressionStatement(expression) : void 0;
-      }
-      return visitEachChild(node, visitor, context);
-    }
-    function visitForInStatementInAsyncBody(node) {
-      return factory2.updateForInStatement(
-        node,
-        isVariableDeclarationListWithCollidingName(node.initializer) ? visitVariableDeclarationListWithCollidingNames(
-          node.initializer,
-          /*hasReceiver*/
-          true
-        ) : Debug.checkDefined(visitNode(node.initializer, visitor, isForInitializer)),
-        Debug.checkDefined(visitNode(node.expression, visitor, isExpression)),
-        visitIterationBody(node.statement, asyncBodyVisitor, context)
-      );
-    }
-    function visitForOfStatementInAsyncBody(node) {
-      return factory2.updateForOfStatement(
-        node,
-        visitNode(node.awaitModifier, visitor, isAwaitKeyword),
-        isVariableDeclarationListWithCollidingName(node.initializer) ? visitVariableDeclarationListWithCollidingNames(
-          node.initializer,
-          /*hasReceiver*/
-          true
-        ) : Debug.checkDefined(visitNode(node.initializer, visitor, isForInitializer)),
-        Debug.checkDefined(visitNode(node.expression, visitor, isExpression)),
-        visitIterationBody(node.statement, asyncBodyVisitor, context)
-      );
-    }
-    function visitForStatementInAsyncBody(node) {
-      const initializer = node.initializer;
-      return factory2.updateForStatement(
-        node,
-        isVariableDeclarationListWithCollidingName(initializer) ? visitVariableDeclarationListWithCollidingNames(
-          initializer,
-          /*hasReceiver*/
-          false
-        ) : visitNode(node.initializer, visitor, isForInitializer),
-        visitNode(node.condition, visitor, isExpression),
-        visitNode(node.incrementor, visitor, isExpression),
-        visitIterationBody(node.statement, asyncBodyVisitor, context)
-      );
-    }
-    function visitAwaitExpression(node) {
-      if (inTopLevelContext()) {
-        return visitEachChild(node, visitor, context);
-      }
-      return setOriginalNode(
-        setTextRange(
-          factory2.createYieldExpression(
-            /*asteriskToken*/
-            void 0,
-            visitNode(node.expression, visitor, isExpression)
-          ),
-          node
-        ),
-        node
-      );
-    }
-    function visitConstructorDeclaration(node) {
-      return factory2.updateConstructorDeclaration(
-        node,
-        visitNodes2(node.modifiers, visitor, isModifier),
-        visitParameterList(node.parameters, visitor, context),
-        transformMethodBody(node)
-      );
-    }
-    function visitMethodDeclaration(node) {
-      return factory2.updateMethodDeclaration(
-        node,
-        visitNodes2(node.modifiers, visitor, isModifierLike),
-        node.asteriskToken,
-        node.name,
-        /*questionToken*/
-        void 0,
-        /*typeParameters*/
-        void 0,
-        visitParameterList(node.parameters, visitor, context),
-        /*type*/
-        void 0,
-        getFunctionFlags(node) & 2 /* Async */ ? transformAsyncFunctionBody(node) : transformMethodBody(node)
-      );
-    }
-    function visitGetAccessorDeclaration(node) {
-      return factory2.updateGetAccessorDeclaration(
-        node,
-        visitNodes2(node.modifiers, visitor, isModifierLike),
-        node.name,
-        visitParameterList(node.parameters, visitor, context),
-        /*type*/
-        void 0,
-        transformMethodBody(node)
-      );
-    }
-    function visitSetAccessorDeclaration(node) {
-      return factory2.updateSetAccessorDeclaration(
-        node,
-        visitNodes2(node.modifiers, visitor, isModifierLike),
-        node.name,
-        visitParameterList(node.parameters, visitor, context),
-        transformMethodBody(node)
-      );
-    }
-    function visitFunctionDeclaration(node) {
-      return factory2.updateFunctionDeclaration(
-        node,
-        visitNodes2(node.modifiers, visitor, isModifierLike),
-        node.asteriskToken,
-        node.name,
-        /*typeParameters*/
-        void 0,
-        visitParameterList(node.parameters, visitor, context),
-        /*type*/
-        void 0,
-        getFunctionFlags(node) & 2 /* Async */ ? transformAsyncFunctionBody(node) : visitFunctionBody(node.body, visitor, context)
-      );
-    }
-    function visitFunctionExpression(node) {
-      return factory2.updateFunctionExpression(
-        node,
-        visitNodes2(node.modifiers, visitor, isModifier),
-        node.asteriskToken,
-        node.name,
-        /*typeParameters*/
-        void 0,
-        visitParameterList(node.parameters, visitor, context),
-        /*type*/
-        void 0,
-        getFunctionFlags(node) & 2 /* Async */ ? transformAsyncFunctionBody(node) : visitFunctionBody(node.body, visitor, context)
-      );
-    }
-    function visitArrowFunction(node) {
-      return factory2.updateArrowFunction(
-        node,
-        visitNodes2(node.modifiers, visitor, isModifier),
-        /*typeParameters*/
-        void 0,
-        visitParameterList(node.parameters, visitor, context),
-        /*type*/
-        void 0,
-        node.equalsGreaterThanToken,
-        getFunctionFlags(node) & 2 /* Async */ ? transformAsyncFunctionBody(node) : visitFunctionBody(node.body, visitor, context)
-      );
-    }
-    function recordDeclarationName({ name }, names) {
-      if (isIdentifier(name)) {
-        names.add(name.escapedText);
-      } else {
-        for (const element of name.elements) {
-          if (!isOmittedExpression(element)) {
-            recordDeclarationName(element, names);
-          }
-        }
-      }
-    }
-    function isVariableDeclarationListWithCollidingName(node) {
-      return !!node && isVariableDeclarationList(node) && !(node.flags & 3 /* BlockScoped */) && node.declarations.some(collidesWithParameterName);
-    }
-    function visitVariableDeclarationListWithCollidingNames(node, hasReceiver) {
-      hoistVariableDeclarationList(node);
-      const variables = getInitializedVariables(node);
-      if (variables.length === 0) {
-        if (hasReceiver) {
-          return visitNode(factory2.converters.convertToAssignmentElementTarget(node.declarations[0].name), visitor, isExpression);
-        }
-        return void 0;
-      }
-      return factory2.inlineExpressions(map(variables, transformInitializedVariable));
-    }
-    function hoistVariableDeclarationList(node) {
-      forEach(node.declarations, hoistVariable);
-    }
-    function hoistVariable({ name }) {
-      if (isIdentifier(name)) {
-        hoistVariableDeclaration(name);
-      } else {
-        for (const element of name.elements) {
-          if (!isOmittedExpression(element)) {
-            hoistVariable(element);
-          }
-        }
-      }
-    }
-    function transformInitializedVariable(node) {
-      const converted = setSourceMapRange(
-        factory2.createAssignment(
-          factory2.converters.convertToAssignmentElementTarget(node.name),
-          node.initializer
-        ),
-        node
-      );
-      return Debug.checkDefined(visitNode(converted, visitor, isExpression));
-    }
-    function collidesWithParameterName({ name }) {
-      if (isIdentifier(name)) {
-        return enclosingFunctionParameterNames.has(name.escapedText);
-      } else {
-        for (const element of name.elements) {
-          if (!isOmittedExpression(element) && collidesWithParameterName(element)) {
-            return true;
-          }
-        }
-      }
-      return false;
-    }
-    function transformMethodBody(node) {
-      Debug.assertIsDefined(node.body);
-      const savedCapturedSuperProperties = capturedSuperProperties;
-      const savedHasSuperElementAccess = hasSuperElementAccess;
-      capturedSuperProperties = /* @__PURE__ */ new Set();
-      hasSuperElementAccess = false;
-      let updated = visitFunctionBody(node.body, visitor, context);
-      const originalMethod = getOriginalNode(node, isFunctionLikeDeclaration);
-      const emitSuperHelpers = languageVersion >= 2 /* ES2015 */ && resolver.getNodeCheckFlags(node) & (256 /* MethodWithSuperPropertyAssignmentInAsync */ | 128 /* MethodWithSuperPropertyAccessInAsync */) && (getFunctionFlags(originalMethod) & 3 /* AsyncGenerator */) !== 3 /* AsyncGenerator */;
-      if (emitSuperHelpers) {
-        enableSubstitutionForAsyncMethodsWithSuper();
-        if (capturedSuperProperties.size) {
-          const variableStatement = createSuperAccessVariableStatement(factory2, resolver, node, capturedSuperProperties);
-          substitutedSuperAccessors[getNodeId(variableStatement)] = true;
-          const statements = updated.statements.slice();
-          insertStatementsAfterStandardPrologue(statements, [variableStatement]);
-          updated = factory2.updateBlock(updated, statements);
-        }
-        if (hasSuperElementAccess) {
-          if (resolver.getNodeCheckFlags(node) & 256 /* MethodWithSuperPropertyAssignmentInAsync */) {
-            addEmitHelper(updated, advancedAsyncSuperHelper);
-          } else if (resolver.getNodeCheckFlags(node) & 128 /* MethodWithSuperPropertyAccessInAsync */) {
-            addEmitHelper(updated, asyncSuperHelper);
-          }
-        }
-      }
-      capturedSuperProperties = savedCapturedSuperProperties;
-      hasSuperElementAccess = savedHasSuperElementAccess;
-      return updated;
-    }
-    function transformAsyncFunctionBody(node) {
-      resumeLexicalEnvironment();
-      const original = getOriginalNode(node, isFunctionLike);
-      const nodeType = original.type;
-      const promiseConstructor = languageVersion < 2 /* ES2015 */ ? getPromiseConstructor(nodeType) : void 0;
-      const isArrowFunction2 = node.kind === 218 /* ArrowFunction */;
-      const hasLexicalArguments = (resolver.getNodeCheckFlags(node) & 512 /* CaptureArguments */) !== 0;
-      const savedEnclosingFunctionParameterNames = enclosingFunctionParameterNames;
-      enclosingFunctionParameterNames = /* @__PURE__ */ new Set();
-      for (const parameter of node.parameters) {
-        recordDeclarationName(parameter, enclosingFunctionParameterNames);
-      }
-      const savedCapturedSuperProperties = capturedSuperProperties;
-      const savedHasSuperElementAccess = hasSuperElementAccess;
-      if (!isArrowFunction2) {
-        capturedSuperProperties = /* @__PURE__ */ new Set();
-        hasSuperElementAccess = false;
-      }
-      let result;
-      if (!isArrowFunction2) {
-        const statements = [];
-        const statementOffset = factory2.copyPrologue(
-          node.body.statements,
-          statements,
-          /*ensureUseStrict*/
-          false,
-          visitor
-        );
-        statements.push(
-          factory2.createReturnStatement(
-            emitHelpers().createAwaiterHelper(
-              inHasLexicalThisContext(),
-              hasLexicalArguments,
-              promiseConstructor,
-              transformAsyncFunctionBodyWorker(node.body, statementOffset)
-            )
-          )
-        );
-        insertStatementsAfterStandardPrologue(statements, endLexicalEnvironment());
-        const emitSuperHelpers = languageVersion >= 2 /* ES2015 */ && resolver.getNodeCheckFlags(node) & (256 /* MethodWithSuperPropertyAssignmentInAsync */ | 128 /* MethodWithSuperPropertyAccessInAsync */);
-        if (emitSuperHelpers) {
-          enableSubstitutionForAsyncMethodsWithSuper();
-          if (capturedSuperProperties.size) {
-            const variableStatement = createSuperAccessVariableStatement(factory2, resolver, node, capturedSuperProperties);
-            substitutedSuperAccessors[getNodeId(variableStatement)] = true;
-            insertStatementsAfterStandardPrologue(statements, [variableStatement]);
-          }
-        }
-        const block = factory2.createBlock(
-          statements,
-          /*multiLine*/
-          true
-        );
-        setTextRange(block, node.body);
-        if (emitSuperHelpers && hasSuperElementAccess) {
-          if (resolver.getNodeCheckFlags(node) & 256 /* MethodWithSuperPropertyAssignmentInAsync */) {
-            addEmitHelper(block, advancedAsyncSuperHelper);
-          } else if (resolver.getNodeCheckFlags(node) & 128 /* MethodWithSuperPropertyAccessInAsync */) {
-            addEmitHelper(block, asyncSuperHelper);
-          }
-        }
-        result = block;
-      } else {
-        const expression = emitHelpers().createAwaiterHelper(
-          inHasLexicalThisContext(),
-          hasLexicalArguments,
-          promiseConstructor,
-          transformAsyncFunctionBodyWorker(node.body)
-        );
-        const declarations = endLexicalEnvironment();
-        if (some(declarations)) {
-          const block = factory2.converters.convertToFunctionBlock(expression);
-          result = factory2.updateBlock(block, setTextRange(factory2.createNodeArray(concatenate(declarations, block.statements)), block.statements));
-        } else {
-          result = expression;
-        }
-      }
-      enclosingFunctionParameterNames = savedEnclosingFunctionParameterNames;
-      if (!isArrowFunction2) {
-        capturedSuperProperties = savedCapturedSuperProperties;
-        hasSuperElementAccess = savedHasSuperElementAccess;
-      }
-      return result;
-    }
-    function transformAsyncFunctionBodyWorker(body, start) {
-      if (isBlock(body)) {
-        return factory2.updateBlock(body, visitNodes2(body.statements, asyncBodyVisitor, isStatement, start));
-      } else {
-        return factory2.converters.convertToFunctionBlock(Debug.checkDefined(visitNode(body, asyncBodyVisitor, isConciseBody)));
-      }
-    }
-    function getPromiseConstructor(type) {
-      const typeName = type && getEntityNameFromTypeNode(type);
-      if (typeName && isEntityName(typeName)) {
-        const serializationKind = resolver.getTypeReferenceSerializationKind(typeName);
-        if (serializationKind === 1 /* TypeWithConstructSignatureAndValue */ || serializationKind === 0 /* Unknown */) {
-          return typeName;
-        }
-      }
-      return void 0;
-    }
-    function enableSubstitutionForAsyncMethodsWithSuper() {
-      if ((enabledSubstitutions & 1 /* AsyncMethodsWithSuper */) === 0) {
-        enabledSubstitutions |= 1 /* AsyncMethodsWithSuper */;
-        context.enableSubstitution(212 /* CallExpression */);
-        context.enableSubstitution(210 /* PropertyAccessExpression */);
-        context.enableSubstitution(211 /* ElementAccessExpression */);
-        context.enableEmitNotification(262 /* ClassDeclaration */);
-        context.enableEmitNotification(173 /* MethodDeclaration */);
-        context.enableEmitNotification(176 /* GetAccessor */);
-        context.enableEmitNotification(177 /* SetAccessor */);
-        context.enableEmitNotification(175 /* Constructor */);
-        context.enableEmitNotification(242 /* VariableStatement */);
-      }
-    }
-    function onEmitNode(hint, node, emitCallback) {
-      if (enabledSubstitutions & 1 /* AsyncMethodsWithSuper */ && isSuperContainer(node)) {
-        const superContainerFlags = resolver.getNodeCheckFlags(node) & (128 /* MethodWithSuperPropertyAccessInAsync */ | 256 /* MethodWithSuperPropertyAssignmentInAsync */);
-        if (superContainerFlags !== enclosingSuperContainerFlags) {
-          const savedEnclosingSuperContainerFlags = enclosingSuperContainerFlags;
-          enclosingSuperContainerFlags = superContainerFlags;
-          previousOnEmitNode(hint, node, emitCallback);
-          enclosingSuperContainerFlags = savedEnclosingSuperContainerFlags;
-          return;
-        }
-      } else if (enabledSubstitutions && substitutedSuperAccessors[getNodeId(node)]) {
-        const savedEnclosingSuperContainerFlags = enclosingSuperContainerFlags;
-        enclosingSuperContainerFlags = 0;
-        previousOnEmitNode(hint, node, emitCallback);
-        enclosingSuperContainerFlags = savedEnclosingSuperContainerFlags;
-        return;
-      }
-      previousOnEmitNode(hint, node, emitCallback);
-    }
-    function onSubstituteNode(hint, node) {
-      node = previousOnSubstituteNode(hint, node);
-      if (hint === 1 /* Expression */ && enclosingSuperContainerFlags) {
-        return substituteExpression(node);
-      }
-      return node;
-    }
-    function substituteExpression(node) {
-      switch (node.kind) {
-        case 210 /* PropertyAccessExpression */:
-          return substitutePropertyAccessExpression(node);
-        case 211 /* ElementAccessExpression */:
-          return substituteElementAccessExpression(node);
-        case 212 /* CallExpression */:
-          return substituteCallExpression(node);
-      }
-      return node;
-    }
-    function substitutePropertyAccessExpression(node) {
-      if (node.expression.kind === 108 /* SuperKeyword */) {
-        return setTextRange(
-          factory2.createPropertyAccessExpression(
-            factory2.createUniqueName("_super", 16 /* Optimistic */ | 32 /* FileLevel */),
-            node.name
-          ),
-          node
-        );
-      }
-      return node;
-    }
-    function substituteElementAccessExpression(node) {
-      if (node.expression.kind === 108 /* SuperKeyword */) {
-        return createSuperElementAccessInAsyncMethod(
-          node.argumentExpression,
-          node
-        );
-      }
-      return node;
-    }
-    function substituteCallExpression(node) {
-      const expression = node.expression;
-      if (isSuperProperty(expression)) {
-        const argumentExpression = isPropertyAccessExpression(expression) ? substitutePropertyAccessExpression(expression) : substituteElementAccessExpression(expression);
-        return factory2.createCallExpression(
-          factory2.createPropertyAccessExpression(argumentExpression, "call"),
-          /*typeArguments*/
-          void 0,
-          [
-            factory2.createThis(),
-            ...node.arguments
-          ]
-        );
-      }
-      return node;
-    }
-    function isSuperContainer(node) {
-      const kind = node.kind;
-      return kind === 262 /* ClassDeclaration */ || kind === 175 /* Constructor */ || kind === 173 /* MethodDeclaration */ || kind === 176 /* GetAccessor */ || kind === 177 /* SetAccessor */;
-    }
-    function createSuperElementAccessInAsyncMethod(argumentExpression, location) {
-      if (enclosingSuperContainerFlags & 256 /* MethodWithSuperPropertyAssignmentInAsync */) {
-        return setTextRange(
-          factory2.createPropertyAccessExpression(
-            factory2.createCallExpression(
-              factory2.createUniqueName("_superIndex", 16 /* Optimistic */ | 32 /* FileLevel */),
-              /*typeArguments*/
-              void 0,
-              [argumentExpression]
-            ),
-            "value"
-          ),
-          location
-        );
-      } else {
-        return setTextRange(
-          factory2.createCallExpression(
-            factory2.createUniqueName("_superIndex", 16 /* Optimistic */ | 32 /* FileLevel */),
-            /*typeArguments*/
-            void 0,
-            [argumentExpression]
-          ),
-          location
-        );
-      }
-    }
-  }
-  function createSuperAccessVariableStatement(factory2, resolver, node, names) {
-    const hasBinding = (resolver.getNodeCheckFlags(node) & 256 /* MethodWithSuperPropertyAssignmentInAsync */) !== 0;
-    const accessors = [];
-    names.forEach((_, key) => {
-      const name = unescapeLeadingUnderscores(key);
-      const getterAndSetter = [];
-      getterAndSetter.push(factory2.createPropertyAssignment(
-        "get",
-        factory2.createArrowFunction(
-          /*modifiers*/
-          void 0,
-          /*typeParameters*/
-          void 0,
-          /* parameters */
-          [],
-          /*type*/
-          void 0,
-          /*equalsGreaterThanToken*/
-          void 0,
-          setEmitFlags(
-            factory2.createPropertyAccessExpression(
-              setEmitFlags(
-                factory2.createSuper(),
-                8 /* NoSubstitution */
-              ),
-              name
-            ),
-            8 /* NoSubstitution */
-          )
-        )
-      ));
-      if (hasBinding) {
-        getterAndSetter.push(
-          factory2.createPropertyAssignment(
-            "set",
-            factory2.createArrowFunction(
-              /*modifiers*/
-              void 0,
-              /*typeParameters*/
-              void 0,
-              /* parameters */
-              [
-                factory2.createParameterDeclaration(
-                  /*modifiers*/
-                  void 0,
-                  /*dotDotDotToken*/
-                  void 0,
-                  "v",
-                  /*questionToken*/
-                  void 0,
-                  /*type*/
-                  void 0,
-                  /*initializer*/
-                  void 0
-                )
-              ],
-              /*type*/
-              void 0,
-              /*equalsGreaterThanToken*/
-              void 0,
-              factory2.createAssignment(
-                setEmitFlags(
-                  factory2.createPropertyAccessExpression(
-                    setEmitFlags(
-                      factory2.createSuper(),
-                      8 /* NoSubstitution */
-                    ),
-                    name
-                  ),
-                  8 /* NoSubstitution */
-                ),
-                factory2.createIdentifier("v")
-              )
-            )
-          )
-        );
-      }
-      accessors.push(
-        factory2.createPropertyAssignment(
-          name,
-          factory2.createObjectLiteralExpression(getterAndSetter)
-        )
-      );
-    });
-    return factory2.createVariableStatement(
-      /*modifiers*/
-      void 0,
-      factory2.createVariableDeclarationList(
-        [
-          factory2.createVariableDeclaration(
-            factory2.createUniqueName("_super", 16 /* Optimistic */ | 32 /* FileLevel */),
-            /*exclamationToken*/
-            void 0,
-            /*type*/
-            void 0,
-            factory2.createCallExpression(
-              factory2.createPropertyAccessExpression(
-                factory2.createIdentifier("Object"),
-                "create"
-              ),
-              /*typeArguments*/
-              void 0,
-              [
-                factory2.createNull(),
-                factory2.createObjectLiteralExpression(
-                  accessors,
-                  /*multiLine*/
-                  true
-                )
-              ]
-            )
-          )
-        ],
-        2 /* Const */
-      )
-    );
-  }
-  var init_es2017 = __esm({
-    "src/compiler/transformers/es2017.ts"() {
-      "use strict";
-      init_ts2();
-    }
-  });
-
-  // src/compiler/transformers/es2018.ts
-  function transformES2018(context) {
-    const {
-      factory: factory2,
-      getEmitHelperFactory: emitHelpers,
-      resumeLexicalEnvironment,
-      endLexicalEnvironment,
-      hoistVariableDeclaration
-    } = context;
-    const resolver = context.getEmitResolver();
-    const compilerOptions = context.getCompilerOptions();
-    const languageVersion = getEmitScriptTarget(compilerOptions);
-    const previousOnEmitNode = context.onEmitNode;
-    context.onEmitNode = onEmitNode;
-    const previousOnSubstituteNode = context.onSubstituteNode;
-    context.onSubstituteNode = onSubstituteNode;
-    let exportedVariableStatement = false;
-    let enabledSubstitutions;
-    let enclosingFunctionFlags;
-    let parametersWithPrecedingObjectRestOrSpread;
-    let enclosingSuperContainerFlags = 0;
-    let hierarchyFacts = 0;
-    let currentSourceFile;
-    let taggedTemplateStringDeclarations;
-    let capturedSuperProperties;
-    let hasSuperElementAccess;
-    const substitutedSuperAccessors = [];
-    return chainBundle(context, transformSourceFile);
-    function affectsSubtree(excludeFacts, includeFacts) {
-      return hierarchyFacts !== (hierarchyFacts & ~excludeFacts | includeFacts);
-    }
-    function enterSubtree(excludeFacts, includeFacts) {
-      const ancestorFacts = hierarchyFacts;
-      hierarchyFacts = (hierarchyFacts & ~excludeFacts | includeFacts) & 3 /* AncestorFactsMask */;
-      return ancestorFacts;
-    }
-    function exitSubtree(ancestorFacts) {
-      hierarchyFacts = ancestorFacts;
-    }
-    function recordTaggedTemplateString(temp) {
-      taggedTemplateStringDeclarations = append(
-        taggedTemplateStringDeclarations,
-        factory2.createVariableDeclaration(temp)
-      );
-    }
-    function transformSourceFile(node) {
-      if (node.isDeclarationFile) {
-        return node;
-      }
-      currentSourceFile = node;
-      const visited = visitSourceFile(node);
-      addEmitHelpers(visited, context.readEmitHelpers());
-      currentSourceFile = void 0;
-      taggedTemplateStringDeclarations = void 0;
-      return visited;
-    }
-    function visitor(node) {
-      return visitorWorker(
-        node,
-        /*expressionResultIsUnused*/
-        false
-      );
-    }
-    function visitorWithUnusedExpressionResult(node) {
-      return visitorWorker(
-        node,
-        /*expressionResultIsUnused*/
-        true
-      );
-    }
-    function visitorNoAsyncModifier(node) {
-      if (node.kind === 134 /* AsyncKeyword */) {
-        return void 0;
-      }
-      return node;
-    }
-    function doWithHierarchyFacts(cb, value, excludeFacts, includeFacts) {
-      if (affectsSubtree(excludeFacts, includeFacts)) {
-        const ancestorFacts = enterSubtree(excludeFacts, includeFacts);
-        const result = cb(value);
-        exitSubtree(ancestorFacts);
-        return result;
-      }
-      return cb(value);
-    }
-    function visitDefault(node) {
-      return visitEachChild(node, visitor, context);
-    }
-    function visitorWorker(node, expressionResultIsUnused2) {
-      if ((node.transformFlags & 128 /* ContainsES2018 */) === 0) {
-        return node;
-      }
-      switch (node.kind) {
-        case 222 /* AwaitExpression */:
-          return visitAwaitExpression(node);
-        case 228 /* YieldExpression */:
-          return visitYieldExpression(node);
-        case 252 /* ReturnStatement */:
-          return visitReturnStatement(node);
-        case 255 /* LabeledStatement */:
-          return visitLabeledStatement(node);
-        case 209 /* ObjectLiteralExpression */:
-          return visitObjectLiteralExpression(node);
-        case 225 /* BinaryExpression */:
-          return visitBinaryExpression(node, expressionResultIsUnused2);
-        case 360 /* CommaListExpression */:
-          return visitCommaListExpression(node, expressionResultIsUnused2);
-        case 298 /* CatchClause */:
-          return visitCatchClause(node);
-        case 242 /* VariableStatement */:
-          return visitVariableStatement(node);
-        case 259 /* VariableDeclaration */:
-          return visitVariableDeclaration(node);
-        case 245 /* DoStatement */:
-        case 246 /* WhileStatement */:
-        case 248 /* ForInStatement */:
-          return doWithHierarchyFacts(
-            visitDefault,
-            node,
-            0 /* IterationStatementExcludes */,
-            2 /* IterationStatementIncludes */
-          );
-        case 249 /* ForOfStatement */:
-          return visitForOfStatement(
-            node,
-            /*outermostLabeledStatement*/
-            void 0
-          );
-        case 247 /* ForStatement */:
-          return doWithHierarchyFacts(
-            visitForStatement,
-            node,
-            0 /* IterationStatementExcludes */,
-            2 /* IterationStatementIncludes */
-          );
-        case 221 /* VoidExpression */:
-          return visitVoidExpression(node);
-        case 175 /* Constructor */:
-          return doWithHierarchyFacts(
-            visitConstructorDeclaration,
-            node,
-            2 /* ClassOrFunctionExcludes */,
-            1 /* ClassOrFunctionIncludes */
-          );
-        case 173 /* MethodDeclaration */:
-          return doWithHierarchyFacts(
-            visitMethodDeclaration,
-            node,
-            2 /* ClassOrFunctionExcludes */,
-            1 /* ClassOrFunctionIncludes */
-          );
-        case 176 /* GetAccessor */:
-          return doWithHierarchyFacts(
-            visitGetAccessorDeclaration,
-            node,
-            2 /* ClassOrFunctionExcludes */,
-            1 /* ClassOrFunctionIncludes */
-          );
-        case 177 /* SetAccessor */:
-          return doWithHierarchyFacts(
-            visitSetAccessorDeclaration,
-            node,
-            2 /* ClassOrFunctionExcludes */,
-            1 /* ClassOrFunctionIncludes */
-          );
-        case 261 /* FunctionDeclaration */:
-          return doWithHierarchyFacts(
-            visitFunctionDeclaration,
-            node,
-            2 /* ClassOrFunctionExcludes */,
-            1 /* ClassOrFunctionIncludes */
-          );
-        case 217 /* FunctionExpression */:
-          return doWithHierarchyFacts(
-            visitFunctionExpression,
-            node,
-            2 /* ClassOrFunctionExcludes */,
-            1 /* ClassOrFunctionIncludes */
-          );
-        case 218 /* ArrowFunction */:
-          return doWithHierarchyFacts(
-            visitArrowFunction,
-            node,
-            2 /* ArrowFunctionExcludes */,
-            0 /* ArrowFunctionIncludes */
-          );
-        case 168 /* Parameter */:
-          return visitParameter(node);
-        case 243 /* ExpressionStatement */:
-          return visitExpressionStatement(node);
-        case 216 /* ParenthesizedExpression */:
-          return visitParenthesizedExpression(node, expressionResultIsUnused2);
-        case 214 /* TaggedTemplateExpression */:
-          return visitTaggedTemplateExpression(node);
-        case 210 /* PropertyAccessExpression */:
-          if (capturedSuperProperties && isPropertyAccessExpression(node) && node.expression.kind === 108 /* SuperKeyword */) {
-            capturedSuperProperties.add(node.name.escapedText);
-          }
-          return visitEachChild(node, visitor, context);
-        case 211 /* ElementAccessExpression */:
-          if (capturedSuperProperties && node.expression.kind === 108 /* SuperKeyword */) {
-            hasSuperElementAccess = true;
-          }
-          return visitEachChild(node, visitor, context);
-        case 262 /* ClassDeclaration */:
-        case 230 /* ClassExpression */:
-          return doWithHierarchyFacts(
-            visitDefault,
-            node,
-            2 /* ClassOrFunctionExcludes */,
-            1 /* ClassOrFunctionIncludes */
-          );
-        default:
-          return visitEachChild(node, visitor, context);
-      }
-    }
-    function visitAwaitExpression(node) {
-      if (enclosingFunctionFlags & 2 /* Async */ && enclosingFunctionFlags & 1 /* Generator */) {
-        return setOriginalNode(
-          setTextRange(
-            factory2.createYieldExpression(
-              /*asteriskToken*/
-              void 0,
-              emitHelpers().createAwaitHelper(visitNode(node.expression, visitor, isExpression))
-            ),
-            /*location*/
-            node
-          ),
-          node
-        );
-      }
-      return visitEachChild(node, visitor, context);
-    }
-    function visitYieldExpression(node) {
-      if (enclosingFunctionFlags & 2 /* Async */ && enclosingFunctionFlags & 1 /* Generator */) {
-        if (node.asteriskToken) {
-          const expression = visitNode(Debug.checkDefined(node.expression), visitor, isExpression);
-          return setOriginalNode(
-            setTextRange(
-              factory2.createYieldExpression(
-                /*asteriskToken*/
-                void 0,
-                emitHelpers().createAwaitHelper(
-                  factory2.updateYieldExpression(
-                    node,
-                    node.asteriskToken,
-                    setTextRange(
-                      emitHelpers().createAsyncDelegatorHelper(
-                        setTextRange(
-                          emitHelpers().createAsyncValuesHelper(expression),
-                          expression
-                        )
-                      ),
-                      expression
-                    )
-                  )
-                )
-              ),
-              node
-            ),
-            node
-          );
-        }
-        return setOriginalNode(
-          setTextRange(
-            factory2.createYieldExpression(
-              /*asteriskToken*/
-              void 0,
-              createDownlevelAwait(
-                node.expression ? visitNode(node.expression, visitor, isExpression) : factory2.createVoidZero()
-              )
-            ),
-            node
-          ),
-          node
-        );
-      }
-      return visitEachChild(node, visitor, context);
-    }
-    function visitReturnStatement(node) {
-      if (enclosingFunctionFlags & 2 /* Async */ && enclosingFunctionFlags & 1 /* Generator */) {
-        return factory2.updateReturnStatement(node, createDownlevelAwait(
-          node.expression ? visitNode(node.expression, visitor, isExpression) : factory2.createVoidZero()
-        ));
-      }
-      return visitEachChild(node, visitor, context);
-    }
-    function visitLabeledStatement(node) {
-      if (enclosingFunctionFlags & 2 /* Async */) {
-        const statement = unwrapInnermostStatementOfLabel(node);
-        if (statement.kind === 249 /* ForOfStatement */ && statement.awaitModifier) {
-          return visitForOfStatement(statement, node);
-        }
-        return factory2.restoreEnclosingLabel(visitNode(statement, visitor, isStatement, factory2.liftToBlock), node);
-      }
-      return visitEachChild(node, visitor, context);
-    }
-    function chunkObjectLiteralElements(elements) {
-      let chunkObject;
-      const objects = [];
-      for (const e of elements) {
-        if (e.kind === 304 /* SpreadAssignment */) {
-          if (chunkObject) {
-            objects.push(factory2.createObjectLiteralExpression(chunkObject));
-            chunkObject = void 0;
-          }
-          const target = e.expression;
-          objects.push(visitNode(target, visitor, isExpression));
-        } else {
-          chunkObject = append(chunkObject, e.kind === 302 /* PropertyAssignment */ ? factory2.createPropertyAssignment(e.name, visitNode(e.initializer, visitor, isExpression)) : visitNode(e, visitor, isObjectLiteralElementLike));
-        }
-      }
-      if (chunkObject) {
-        objects.push(factory2.createObjectLiteralExpression(chunkObject));
-      }
-      return objects;
-    }
-    function visitObjectLiteralExpression(node) {
-      if (node.transformFlags & 65536 /* ContainsObjectRestOrSpread */) {
-        const objects = chunkObjectLiteralElements(node.properties);
-        if (objects.length && objects[0].kind !== 209 /* ObjectLiteralExpression */) {
-          objects.unshift(factory2.createObjectLiteralExpression());
-        }
-        let expression = objects[0];
-        if (objects.length > 1) {
-          for (let i = 1; i < objects.length; i++) {
-            expression = emitHelpers().createAssignHelper([expression, objects[i]]);
-          }
-          return expression;
-        } else {
-          return emitHelpers().createAssignHelper(objects);
-        }
-      }
-      return visitEachChild(node, visitor, context);
-    }
-    function visitExpressionStatement(node) {
-      return visitEachChild(node, visitorWithUnusedExpressionResult, context);
-    }
-    function visitParenthesizedExpression(node, expressionResultIsUnused2) {
-      return visitEachChild(node, expressionResultIsUnused2 ? visitorWithUnusedExpressionResult : visitor, context);
-    }
-    function visitSourceFile(node) {
-      const ancestorFacts = enterSubtree(
-        2 /* SourceFileExcludes */,
-        isEffectiveStrictModeSourceFile(node, compilerOptions) ? 0 /* StrictModeSourceFileIncludes */ : 1 /* SourceFileIncludes */
-      );
-      exportedVariableStatement = false;
-      const visited = visitEachChild(node, visitor, context);
-      const statement = concatenate(visited.statements, taggedTemplateStringDeclarations && [
-        factory2.createVariableStatement(
-          /*modifiers*/
-          void 0,
-          factory2.createVariableDeclarationList(taggedTemplateStringDeclarations)
-        )
-      ]);
-      const result = factory2.updateSourceFile(visited, setTextRange(factory2.createNodeArray(statement), node.statements));
-      exitSubtree(ancestorFacts);
-      return result;
-    }
-    function visitTaggedTemplateExpression(node) {
-      return processTaggedTemplateExpression(
-        context,
-        node,
-        visitor,
-        currentSourceFile,
-        recordTaggedTemplateString,
-        0 /* LiftRestriction */
-      );
-    }
-    function visitBinaryExpression(node, expressionResultIsUnused2) {
-      if (isDestructuringAssignment(node) && containsObjectRestOrSpread(node.left)) {
-        return flattenDestructuringAssignment(
-          node,
-          visitor,
-          context,
-          1 /* ObjectRest */,
-          !expressionResultIsUnused2
-        );
-      }
-      if (node.operatorToken.kind === 28 /* CommaToken */) {
-        return factory2.updateBinaryExpression(
-          node,
-          visitNode(node.left, visitorWithUnusedExpressionResult, isExpression),
-          node.operatorToken,
-          visitNode(node.right, expressionResultIsUnused2 ? visitorWithUnusedExpressionResult : visitor, isExpression)
-        );
-      }
-      return visitEachChild(node, visitor, context);
-    }
-    function visitCommaListExpression(node, expressionResultIsUnused2) {
-      if (expressionResultIsUnused2) {
-        return visitEachChild(node, visitorWithUnusedExpressionResult, context);
-      }
-      let result;
-      for (let i = 0; i < node.elements.length; i++) {
-        const element = node.elements[i];
-        const visited = visitNode(element, i < node.elements.length - 1 ? visitorWithUnusedExpressionResult : visitor, isExpression);
-        if (result || visited !== element) {
-          result || (result = node.elements.slice(0, i));
-          result.push(visited);
-        }
-      }
-      const elements = result ? setTextRange(factory2.createNodeArray(result), node.elements) : node.elements;
-      return factory2.updateCommaListExpression(node, elements);
-    }
-    function visitCatchClause(node) {
-      if (node.variableDeclaration && isBindingPattern(node.variableDeclaration.name) && node.variableDeclaration.name.transformFlags & 65536 /* ContainsObjectRestOrSpread */) {
-        const name = factory2.getGeneratedNameForNode(node.variableDeclaration.name);
-        const updatedDecl = factory2.updateVariableDeclaration(
-          node.variableDeclaration,
-          node.variableDeclaration.name,
-          /*exclamationToken*/
-          void 0,
-          /*type*/
-          void 0,
-          name
-        );
-        const visitedBindings = flattenDestructuringBinding(updatedDecl, visitor, context, 1 /* ObjectRest */);
-        let block = visitNode(node.block, visitor, isBlock);
-        if (some(visitedBindings)) {
-          block = factory2.updateBlock(block, [
-            factory2.createVariableStatement(
-              /*modifiers*/
-              void 0,
-              visitedBindings
-            ),
-            ...block.statements
-          ]);
-        }
-        return factory2.updateCatchClause(
-          node,
-          factory2.updateVariableDeclaration(
-            node.variableDeclaration,
-            name,
-            /*exclamationToken*/
-            void 0,
-            /*type*/
-            void 0,
-            /*initializer*/
-            void 0
-          ),
-          block
-        );
-      }
-      return visitEachChild(node, visitor, context);
-    }
-    function visitVariableStatement(node) {
-      if (hasSyntacticModifier(node, 1 /* Export */)) {
-        const savedExportedVariableStatement = exportedVariableStatement;
-        exportedVariableStatement = true;
-        const visited = visitEachChild(node, visitor, context);
-        exportedVariableStatement = savedExportedVariableStatement;
-        return visited;
-      }
-      return visitEachChild(node, visitor, context);
-    }
-    function visitVariableDeclaration(node) {
-      if (exportedVariableStatement) {
-        const savedExportedVariableStatement = exportedVariableStatement;
-        exportedVariableStatement = false;
-        const visited = visitVariableDeclarationWorker(
-          node,
-          /*exportedVariableStatement*/
-          true
-        );
-        exportedVariableStatement = savedExportedVariableStatement;
-        return visited;
-      }
-      return visitVariableDeclarationWorker(
-        node,
-        /*exportedVariableStatement*/
-        false
-      );
-    }
-    function visitVariableDeclarationWorker(node, exportedVariableStatement2) {
-      if (isBindingPattern(node.name) && node.name.transformFlags & 65536 /* ContainsObjectRestOrSpread */) {
-        return flattenDestructuringBinding(
-          node,
-          visitor,
-          context,
-          1 /* ObjectRest */,
-          /*rval*/
-          void 0,
-          exportedVariableStatement2
-        );
-      }
-      return visitEachChild(node, visitor, context);
-    }
-    function visitForStatement(node) {
-      return factory2.updateForStatement(
-        node,
-        visitNode(node.initializer, visitorWithUnusedExpressionResult, isForInitializer),
-        visitNode(node.condition, visitor, isExpression),
-        visitNode(node.incrementor, visitorWithUnusedExpressionResult, isExpression),
-        visitIterationBody(node.statement, visitor, context)
-      );
-    }
-    function visitVoidExpression(node) {
-      return visitEachChild(node, visitorWithUnusedExpressionResult, context);
-    }
-    function visitForOfStatement(node, outermostLabeledStatement) {
-      const ancestorFacts = enterSubtree(0 /* IterationStatementExcludes */, 2 /* IterationStatementIncludes */);
-      if (node.initializer.transformFlags & 65536 /* ContainsObjectRestOrSpread */ || isAssignmentPattern(node.initializer) && containsObjectRestOrSpread(node.initializer)) {
-        node = transformForOfStatementWithObjectRest(node);
-      }
-      const result = node.awaitModifier ? transformForAwaitOfStatement(node, outermostLabeledStatement, ancestorFacts) : factory2.restoreEnclosingLabel(visitEachChild(node, visitor, context), outermostLabeledStatement);
-      exitSubtree(ancestorFacts);
-      return result;
-    }
-    function transformForOfStatementWithObjectRest(node) {
-      const initializerWithoutParens = skipParentheses(node.initializer);
-      if (isVariableDeclarationList(initializerWithoutParens) || isAssignmentPattern(initializerWithoutParens)) {
-        let bodyLocation;
-        let statementsLocation;
-        const temp = factory2.createTempVariable(
-          /*recordTempVariable*/
-          void 0
-        );
-        const statements = [createForOfBindingStatement(factory2, initializerWithoutParens, temp)];
-        if (isBlock(node.statement)) {
-          addRange(statements, node.statement.statements);
-          bodyLocation = node.statement;
-          statementsLocation = node.statement.statements;
-        } else if (node.statement) {
-          append(statements, node.statement);
-          bodyLocation = node.statement;
-          statementsLocation = node.statement;
-        }
-        return factory2.updateForOfStatement(
-          node,
-          node.awaitModifier,
-          setTextRange(
-            factory2.createVariableDeclarationList(
-              [
-                setTextRange(factory2.createVariableDeclaration(temp), node.initializer)
-              ],
-              1 /* Let */
-            ),
-            node.initializer
-          ),
-          node.expression,
-          setTextRange(
-            factory2.createBlock(
-              setTextRange(factory2.createNodeArray(statements), statementsLocation),
-              /*multiLine*/
-              true
-            ),
-            bodyLocation
-          )
-        );
-      }
-      return node;
-    }
-    function convertForOfStatementHead(node, boundValue, nonUserCode) {
-      const value = factory2.createTempVariable(hoistVariableDeclaration);
-      const iteratorValueExpression = factory2.createAssignment(value, boundValue);
-      const iteratorValueStatement = factory2.createExpressionStatement(iteratorValueExpression);
-      setSourceMapRange(iteratorValueStatement, node.expression);
-      const exitNonUserCodeExpression = factory2.createAssignment(nonUserCode, factory2.createFalse());
-      const exitNonUserCodeStatement = factory2.createExpressionStatement(exitNonUserCodeExpression);
-      setSourceMapRange(exitNonUserCodeStatement, node.expression);
-      const statements = [iteratorValueStatement, exitNonUserCodeStatement];
-      const binding = createForOfBindingStatement(factory2, node.initializer, value);
-      statements.push(visitNode(binding, visitor, isStatement));
-      let bodyLocation;
-      let statementsLocation;
-      const statement = visitIterationBody(node.statement, visitor, context);
-      if (isBlock(statement)) {
-        addRange(statements, statement.statements);
-        bodyLocation = statement;
-        statementsLocation = statement.statements;
-      } else {
-        statements.push(statement);
-      }
-      return setTextRange(
-        factory2.createBlock(
-          setTextRange(factory2.createNodeArray(statements), statementsLocation),
-          /*multiLine*/
-          true
-        ),
-        bodyLocation
-      );
-    }
-    function createDownlevelAwait(expression) {
-      return enclosingFunctionFlags & 1 /* Generator */ ? factory2.createYieldExpression(
-        /*asteriskToken*/
-        void 0,
-        emitHelpers().createAwaitHelper(expression)
-      ) : factory2.createAwaitExpression(expression);
-    }
-    function transformForAwaitOfStatement(node, outermostLabeledStatement, ancestorFacts) {
-      const expression = visitNode(node.expression, visitor, isExpression);
-      const iterator = isIdentifier(expression) ? factory2.getGeneratedNameForNode(expression) : factory2.createTempVariable(
-        /*recordTempVariable*/
-        void 0
-      );
-      const result = isIdentifier(expression) ? factory2.getGeneratedNameForNode(iterator) : factory2.createTempVariable(
-        /*recordTempVariable*/
-        void 0
-      );
-      const nonUserCode = factory2.createTempVariable(
-        /*recordTempVariable*/
-        void 0
-      );
-      const done = factory2.createTempVariable(hoistVariableDeclaration);
-      const errorRecord = factory2.createUniqueName("e");
-      const catchVariable = factory2.getGeneratedNameForNode(errorRecord);
-      const returnMethod = factory2.createTempVariable(
-        /*recordTempVariable*/
-        void 0
-      );
-      const callValues = setTextRange(emitHelpers().createAsyncValuesHelper(expression), node.expression);
-      const callNext = factory2.createCallExpression(
-        factory2.createPropertyAccessExpression(iterator, "next"),
-        /*typeArguments*/
-        void 0,
-        []
-      );
-      const getDone = factory2.createPropertyAccessExpression(result, "done");
-      const getValue = factory2.createPropertyAccessExpression(result, "value");
-      const callReturn = factory2.createFunctionCallCall(returnMethod, iterator, []);
-      hoistVariableDeclaration(errorRecord);
-      hoistVariableDeclaration(returnMethod);
-      const initializer = ancestorFacts & 2 /* IterationContainer */ ? factory2.inlineExpressions([factory2.createAssignment(errorRecord, factory2.createVoidZero()), callValues]) : callValues;
-      const forStatement = setEmitFlags(
-        setTextRange(
-          factory2.createForStatement(
-            /*initializer*/
-            setEmitFlags(
-              setTextRange(
-                factory2.createVariableDeclarationList([
-                  factory2.createVariableDeclaration(
-                    nonUserCode,
-                    /*exclamationToken*/
-                    void 0,
-                    /*type*/
-                    void 0,
-                    factory2.createTrue()
-                  ),
-                  setTextRange(factory2.createVariableDeclaration(
-                    iterator,
-                    /*exclamationToken*/
-                    void 0,
-                    /*type*/
-                    void 0,
-                    initializer
-                  ), node.expression),
-                  factory2.createVariableDeclaration(result)
-                ]),
-                node.expression
-              ),
-              4194304 /* NoHoisting */
-            ),
-            /*condition*/
-            factory2.inlineExpressions([
-              factory2.createAssignment(result, createDownlevelAwait(callNext)),
-              factory2.createAssignment(done, getDone),
-              factory2.createLogicalNot(done)
-            ]),
-            /*incrementor*/
-            factory2.createAssignment(nonUserCode, factory2.createTrue()),
-            /*statement*/
-            convertForOfStatementHead(node, getValue, nonUserCode)
-          ),
-          /*location*/
-          node
-        ),
-        512 /* NoTokenTrailingSourceMaps */
-      );
-      setOriginalNode(forStatement, node);
-      return factory2.createTryStatement(
-        factory2.createBlock([
-          factory2.restoreEnclosingLabel(
-            forStatement,
-            outermostLabeledStatement
-          )
-        ]),
-        factory2.createCatchClause(
-          factory2.createVariableDeclaration(catchVariable),
-          setEmitFlags(
-            factory2.createBlock([
-              factory2.createExpressionStatement(
-                factory2.createAssignment(
-                  errorRecord,
-                  factory2.createObjectLiteralExpression([
-                    factory2.createPropertyAssignment("error", catchVariable)
-                  ])
-                )
-              )
-            ]),
-            1 /* SingleLine */
-          )
-        ),
-        factory2.createBlock([
-          factory2.createTryStatement(
-            /*tryBlock*/
-            factory2.createBlock([
-              setEmitFlags(
-                factory2.createIfStatement(
-                  factory2.createLogicalAnd(
-                    factory2.createLogicalAnd(
-                      factory2.createLogicalNot(nonUserCode),
-                      factory2.createLogicalNot(done)
-                    ),
-                    factory2.createAssignment(
-                      returnMethod,
-                      factory2.createPropertyAccessExpression(iterator, "return")
-                    )
-                  ),
-                  factory2.createExpressionStatement(createDownlevelAwait(callReturn))
-                ),
-                1 /* SingleLine */
-              )
-            ]),
-            /*catchClause*/
-            void 0,
-            /*finallyBlock*/
-            setEmitFlags(
-              factory2.createBlock([
-                setEmitFlags(
-                  factory2.createIfStatement(
-                    errorRecord,
-                    factory2.createThrowStatement(
-                      factory2.createPropertyAccessExpression(errorRecord, "error")
-                    )
-                  ),
-                  1 /* SingleLine */
-                )
-              ]),
-              1 /* SingleLine */
-            )
-          )
-        ])
-      );
-    }
-    function parameterVisitor(node) {
-      Debug.assertNode(node, isParameter);
-      return visitParameter(node);
-    }
-    function visitParameter(node) {
-      if (parametersWithPrecedingObjectRestOrSpread == null ? void 0 : parametersWithPrecedingObjectRestOrSpread.has(node)) {
-        return factory2.updateParameterDeclaration(
-          node,
-          /*modifiers*/
-          void 0,
-          node.dotDotDotToken,
-          isBindingPattern(node.name) ? factory2.getGeneratedNameForNode(node) : node.name,
-          /*questionToken*/
-          void 0,
-          /*type*/
-          void 0,
-          /*initializer*/
-          void 0
-        );
-      }
-      if (node.transformFlags & 65536 /* ContainsObjectRestOrSpread */) {
-        return factory2.updateParameterDeclaration(
-          node,
-          /*modifiers*/
-          void 0,
-          node.dotDotDotToken,
-          factory2.getGeneratedNameForNode(node),
-          /*questionToken*/
-          void 0,
-          /*type*/
-          void 0,
-          visitNode(node.initializer, visitor, isExpression)
-        );
-      }
-      return visitEachChild(node, visitor, context);
-    }
-    function collectParametersWithPrecedingObjectRestOrSpread(node) {
-      let parameters;
-      for (const parameter of node.parameters) {
-        if (parameters) {
-          parameters.add(parameter);
-        } else if (parameter.transformFlags & 65536 /* ContainsObjectRestOrSpread */) {
-          parameters = /* @__PURE__ */ new Set();
-        }
-      }
-      return parameters;
-    }
-    function visitConstructorDeclaration(node) {
-      const savedEnclosingFunctionFlags = enclosingFunctionFlags;
-      const savedParametersWithPrecedingObjectRestOrSpread = parametersWithPrecedingObjectRestOrSpread;
-      enclosingFunctionFlags = getFunctionFlags(node);
-      parametersWithPrecedingObjectRestOrSpread = collectParametersWithPrecedingObjectRestOrSpread(node);
-      const updated = factory2.updateConstructorDeclaration(
-        node,
-        node.modifiers,
-        visitParameterList(node.parameters, parameterVisitor, context),
-        transformFunctionBody2(node)
-      );
-      enclosingFunctionFlags = savedEnclosingFunctionFlags;
-      parametersWithPrecedingObjectRestOrSpread = savedParametersWithPrecedingObjectRestOrSpread;
-      return updated;
-    }
-    function visitGetAccessorDeclaration(node) {
-      const savedEnclosingFunctionFlags = enclosingFunctionFlags;
-      const savedParametersWithPrecedingObjectRestOrSpread = parametersWithPrecedingObjectRestOrSpread;
-      enclosingFunctionFlags = getFunctionFlags(node);
-      parametersWithPrecedingObjectRestOrSpread = collectParametersWithPrecedingObjectRestOrSpread(node);
-      const updated = factory2.updateGetAccessorDeclaration(
-        node,
-        node.modifiers,
-        visitNode(node.name, visitor, isPropertyName),
-        visitParameterList(node.parameters, parameterVisitor, context),
-        /*type*/
-        void 0,
-        transformFunctionBody2(node)
-      );
-      enclosingFunctionFlags = savedEnclosingFunctionFlags;
-      parametersWithPrecedingObjectRestOrSpread = savedParametersWithPrecedingObjectRestOrSpread;
-      return updated;
-    }
-    function visitSetAccessorDeclaration(node) {
-      const savedEnclosingFunctionFlags = enclosingFunctionFlags;
-      const savedParametersWithPrecedingObjectRestOrSpread = parametersWithPrecedingObjectRestOrSpread;
-      enclosingFunctionFlags = getFunctionFlags(node);
-      parametersWithPrecedingObjectRestOrSpread = collectParametersWithPrecedingObjectRestOrSpread(node);
-      const updated = factory2.updateSetAccessorDeclaration(
-        node,
-        node.modifiers,
-        visitNode(node.name, visitor, isPropertyName),
-        visitParameterList(node.parameters, parameterVisitor, context),
-        transformFunctionBody2(node)
-      );
-      enclosingFunctionFlags = savedEnclosingFunctionFlags;
-      parametersWithPrecedingObjectRestOrSpread = savedParametersWithPrecedingObjectRestOrSpread;
-      return updated;
-    }
-    function visitMethodDeclaration(node) {
-      const savedEnclosingFunctionFlags = enclosingFunctionFlags;
-      const savedParametersWithPrecedingObjectRestOrSpread = parametersWithPrecedingObjectRestOrSpread;
-      enclosingFunctionFlags = getFunctionFlags(node);
-      parametersWithPrecedingObjectRestOrSpread = collectParametersWithPrecedingObjectRestOrSpread(node);
-      const updated = factory2.updateMethodDeclaration(
-        node,
-        enclosingFunctionFlags & 1 /* Generator */ ? visitNodes2(node.modifiers, visitorNoAsyncModifier, isModifierLike) : node.modifiers,
-        enclosingFunctionFlags & 2 /* Async */ ? void 0 : node.asteriskToken,
-        visitNode(node.name, visitor, isPropertyName),
-        visitNode(
-          /*node*/
-          void 0,
-          visitor,
-          isQuestionToken
-        ),
-        /*typeParameters*/
-        void 0,
-        visitParameterList(node.parameters, parameterVisitor, context),
-        /*type*/
-        void 0,
-        enclosingFunctionFlags & 2 /* Async */ && enclosingFunctionFlags & 1 /* Generator */ ? transformAsyncGeneratorFunctionBody(node) : transformFunctionBody2(node)
-      );
-      enclosingFunctionFlags = savedEnclosingFunctionFlags;
-      parametersWithPrecedingObjectRestOrSpread = savedParametersWithPrecedingObjectRestOrSpread;
-      return updated;
-    }
-    function visitFunctionDeclaration(node) {
-      const savedEnclosingFunctionFlags = enclosingFunctionFlags;
-      const savedParametersWithPrecedingObjectRestOrSpread = parametersWithPrecedingObjectRestOrSpread;
-      enclosingFunctionFlags = getFunctionFlags(node);
-      parametersWithPrecedingObjectRestOrSpread = collectParametersWithPrecedingObjectRestOrSpread(node);
-      const updated = factory2.updateFunctionDeclaration(
-        node,
-        enclosingFunctionFlags & 1 /* Generator */ ? visitNodes2(node.modifiers, visitorNoAsyncModifier, isModifier) : node.modifiers,
-        enclosingFunctionFlags & 2 /* Async */ ? void 0 : node.asteriskToken,
-        node.name,
-        /*typeParameters*/
-        void 0,
-        visitParameterList(node.parameters, parameterVisitor, context),
-        /*type*/
-        void 0,
-        enclosingFunctionFlags & 2 /* Async */ && enclosingFunctionFlags & 1 /* Generator */ ? transformAsyncGeneratorFunctionBody(node) : transformFunctionBody2(node)
-      );
-      enclosingFunctionFlags = savedEnclosingFunctionFlags;
-      parametersWithPrecedingObjectRestOrSpread = savedParametersWithPrecedingObjectRestOrSpread;
-      return updated;
-    }
-    function visitArrowFunction(node) {
-      const savedEnclosingFunctionFlags = enclosingFunctionFlags;
-      const savedParametersWithPrecedingObjectRestOrSpread = parametersWithPrecedingObjectRestOrSpread;
-      enclosingFunctionFlags = getFunctionFlags(node);
-      parametersWithPrecedingObjectRestOrSpread = collectParametersWithPrecedingObjectRestOrSpread(node);
-      const updated = factory2.updateArrowFunction(
-        node,
-        node.modifiers,
-        /*typeParameters*/
-        void 0,
-        visitParameterList(node.parameters, parameterVisitor, context),
-        /*type*/
-        void 0,
-        node.equalsGreaterThanToken,
-        transformFunctionBody2(node)
-      );
-      enclosingFunctionFlags = savedEnclosingFunctionFlags;
-      parametersWithPrecedingObjectRestOrSpread = savedParametersWithPrecedingObjectRestOrSpread;
-      return updated;
-    }
-    function visitFunctionExpression(node) {
-      const savedEnclosingFunctionFlags = enclosingFunctionFlags;
-      const savedParametersWithPrecedingObjectRestOrSpread = parametersWithPrecedingObjectRestOrSpread;
-      enclosingFunctionFlags = getFunctionFlags(node);
-      parametersWithPrecedingObjectRestOrSpread = collectParametersWithPrecedingObjectRestOrSpread(node);
-      const updated = factory2.updateFunctionExpression(
-        node,
-        enclosingFunctionFlags & 1 /* Generator */ ? visitNodes2(node.modifiers, visitorNoAsyncModifier, isModifier) : node.modifiers,
-        enclosingFunctionFlags & 2 /* Async */ ? void 0 : node.asteriskToken,
-        node.name,
-        /*typeParameters*/
-        void 0,
-        visitParameterList(node.parameters, parameterVisitor, context),
-        /*type*/
-        void 0,
-        enclosingFunctionFlags & 2 /* Async */ && enclosingFunctionFlags & 1 /* Generator */ ? transformAsyncGeneratorFunctionBody(node) : transformFunctionBody2(node)
-      );
-      enclosingFunctionFlags = savedEnclosingFunctionFlags;
-      parametersWithPrecedingObjectRestOrSpread = savedParametersWithPrecedingObjectRestOrSpread;
-      return updated;
-    }
-    function transformAsyncGeneratorFunctionBody(node) {
-      resumeLexicalEnvironment();
-      const statements = [];
-      const statementOffset = factory2.copyPrologue(
-        node.body.statements,
-        statements,
-        /*ensureUseStrict*/
-        false,
-        visitor
-      );
-      appendObjectRestAssignmentsIfNeeded(statements, node);
-      const savedCapturedSuperProperties = capturedSuperProperties;
-      const savedHasSuperElementAccess = hasSuperElementAccess;
-      capturedSuperProperties = /* @__PURE__ */ new Set();
-      hasSuperElementAccess = false;
-      const returnStatement = factory2.createReturnStatement(
-        emitHelpers().createAsyncGeneratorHelper(
-          factory2.createFunctionExpression(
-            /*modifiers*/
-            void 0,
-            factory2.createToken(42 /* AsteriskToken */),
-            node.name && factory2.getGeneratedNameForNode(node.name),
-            /*typeParameters*/
-            void 0,
-            /*parameters*/
-            [],
-            /*type*/
-            void 0,
-            factory2.updateBlock(
-              node.body,
-              visitLexicalEnvironment(node.body.statements, visitor, context, statementOffset)
-            )
-          ),
-          !!(hierarchyFacts & 1 /* HasLexicalThis */)
-        )
-      );
-      const emitSuperHelpers = languageVersion >= 2 /* ES2015 */ && resolver.getNodeCheckFlags(node) & (256 /* MethodWithSuperPropertyAssignmentInAsync */ | 128 /* MethodWithSuperPropertyAccessInAsync */);
-      if (emitSuperHelpers) {
-        enableSubstitutionForAsyncMethodsWithSuper();
-        const variableStatement = createSuperAccessVariableStatement(factory2, resolver, node, capturedSuperProperties);
-        substitutedSuperAccessors[getNodeId(variableStatement)] = true;
-        insertStatementsAfterStandardPrologue(statements, [variableStatement]);
-      }
-      statements.push(returnStatement);
-      insertStatementsAfterStandardPrologue(statements, endLexicalEnvironment());
-      const block = factory2.updateBlock(node.body, statements);
-      if (emitSuperHelpers && hasSuperElementAccess) {
-        if (resolver.getNodeCheckFlags(node) & 256 /* MethodWithSuperPropertyAssignmentInAsync */) {
-          addEmitHelper(block, advancedAsyncSuperHelper);
-        } else if (resolver.getNodeCheckFlags(node) & 128 /* MethodWithSuperPropertyAccessInAsync */) {
-          addEmitHelper(block, asyncSuperHelper);
-        }
-      }
-      capturedSuperProperties = savedCapturedSuperProperties;
-      hasSuperElementAccess = savedHasSuperElementAccess;
-      return block;
-    }
-    function transformFunctionBody2(node) {
-      resumeLexicalEnvironment();
-      let statementOffset = 0;
-      const statements = [];
-      const body = visitNode(node.body, visitor, isConciseBody) ?? factory2.createBlock([]);
-      if (isBlock(body)) {
-        statementOffset = factory2.copyPrologue(
-          body.statements,
-          statements,
-          /*ensureUseStrict*/
-          false,
-          visitor
-        );
-      }
-      addRange(statements, appendObjectRestAssignmentsIfNeeded(
-        /*statements*/
-        void 0,
-        node
-      ));
-      const leadingStatements = endLexicalEnvironment();
-      if (statementOffset > 0 || some(statements) || some(leadingStatements)) {
-        const block = factory2.converters.convertToFunctionBlock(
-          body,
-          /*multiLine*/
-          true
-        );
-        insertStatementsAfterStandardPrologue(statements, leadingStatements);
-        addRange(statements, block.statements.slice(statementOffset));
-        return factory2.updateBlock(block, setTextRange(factory2.createNodeArray(statements), block.statements));
-      }
-      return body;
-    }
-    function appendObjectRestAssignmentsIfNeeded(statements, node) {
-      let containsPrecedingObjectRestOrSpread = false;
-      for (const parameter of node.parameters) {
-        if (containsPrecedingObjectRestOrSpread) {
-          if (isBindingPattern(parameter.name)) {
-            if (parameter.name.elements.length > 0) {
-              const declarations = flattenDestructuringBinding(
-                parameter,
-                visitor,
-                context,
-                0 /* All */,
-                factory2.getGeneratedNameForNode(parameter)
-              );
-              if (some(declarations)) {
-                const declarationList = factory2.createVariableDeclarationList(declarations);
-                const statement = factory2.createVariableStatement(
-                  /*modifiers*/
-                  void 0,
-                  declarationList
-                );
-                setEmitFlags(statement, 2097152 /* CustomPrologue */);
-                statements = append(statements, statement);
-              }
-            } else if (parameter.initializer) {
-              const name = factory2.getGeneratedNameForNode(parameter);
-              const initializer = visitNode(parameter.initializer, visitor, isExpression);
-              const assignment = factory2.createAssignment(name, initializer);
-              const statement = factory2.createExpressionStatement(assignment);
-              setEmitFlags(statement, 2097152 /* CustomPrologue */);
-              statements = append(statements, statement);
-            }
-          } else if (parameter.initializer) {
-            const name = factory2.cloneNode(parameter.name);
-            setTextRange(name, parameter.name);
-            setEmitFlags(name, 96 /* NoSourceMap */);
-            const initializer = visitNode(parameter.initializer, visitor, isExpression);
-            addEmitFlags(initializer, 96 /* NoSourceMap */ | 3072 /* NoComments */);
-            const assignment = factory2.createAssignment(name, initializer);
-            setTextRange(assignment, parameter);
-            setEmitFlags(assignment, 3072 /* NoComments */);
-            const block = factory2.createBlock([factory2.createExpressionStatement(assignment)]);
-            setTextRange(block, parameter);
-            setEmitFlags(block, 1 /* SingleLine */ | 64 /* NoTrailingSourceMap */ | 768 /* NoTokenSourceMaps */ | 3072 /* NoComments */);
-            const typeCheck = factory2.createTypeCheck(factory2.cloneNode(parameter.name), "undefined");
-            const statement = factory2.createIfStatement(typeCheck, block);
-            startOnNewLine(statement);
-            setTextRange(statement, parameter);
-            setEmitFlags(statement, 768 /* NoTokenSourceMaps */ | 64 /* NoTrailingSourceMap */ | 2097152 /* CustomPrologue */ | 3072 /* NoComments */);
-            statements = append(statements, statement);
-          }
-        } else if (parameter.transformFlags & 65536 /* ContainsObjectRestOrSpread */) {
-          containsPrecedingObjectRestOrSpread = true;
-          const declarations = flattenDestructuringBinding(
-            parameter,
-            visitor,
-            context,
-            1 /* ObjectRest */,
-            factory2.getGeneratedNameForNode(parameter),
-            /*hoistTempVariables*/
-            false,
-            /*skipInitializer*/
-            true
-          );
-          if (some(declarations)) {
-            const declarationList = factory2.createVariableDeclarationList(declarations);
-            const statement = factory2.createVariableStatement(
-              /*modifiers*/
-              void 0,
-              declarationList
-            );
-            setEmitFlags(statement, 2097152 /* CustomPrologue */);
-            statements = append(statements, statement);
-          }
-        }
-      }
-      return statements;
-    }
-    function enableSubstitutionForAsyncMethodsWithSuper() {
-      if ((enabledSubstitutions & 1 /* AsyncMethodsWithSuper */) === 0) {
-        enabledSubstitutions |= 1 /* AsyncMethodsWithSuper */;
-        context.enableSubstitution(212 /* CallExpression */);
-        context.enableSubstitution(210 /* PropertyAccessExpression */);
-        context.enableSubstitution(211 /* ElementAccessExpression */);
-        context.enableEmitNotification(262 /* ClassDeclaration */);
-        context.enableEmitNotification(173 /* MethodDeclaration */);
-        context.enableEmitNotification(176 /* GetAccessor */);
-        context.enableEmitNotification(177 /* SetAccessor */);
-        context.enableEmitNotification(175 /* Constructor */);
-        context.enableEmitNotification(242 /* VariableStatement */);
-      }
-    }
-    function onEmitNode(hint, node, emitCallback) {
-      if (enabledSubstitutions & 1 /* AsyncMethodsWithSuper */ && isSuperContainer(node)) {
-        const superContainerFlags = resolver.getNodeCheckFlags(node) & (128 /* MethodWithSuperPropertyAccessInAsync */ | 256 /* MethodWithSuperPropertyAssignmentInAsync */);
-        if (superContainerFlags !== enclosingSuperContainerFlags) {
-          const savedEnclosingSuperContainerFlags = enclosingSuperContainerFlags;
-          enclosingSuperContainerFlags = superContainerFlags;
-          previousOnEmitNode(hint, node, emitCallback);
-          enclosingSuperContainerFlags = savedEnclosingSuperContainerFlags;
-          return;
-        }
-      } else if (enabledSubstitutions && substitutedSuperAccessors[getNodeId(node)]) {
-        const savedEnclosingSuperContainerFlags = enclosingSuperContainerFlags;
-        enclosingSuperContainerFlags = 0;
-        previousOnEmitNode(hint, node, emitCallback);
-        enclosingSuperContainerFlags = savedEnclosingSuperContainerFlags;
-        return;
-      }
-      previousOnEmitNode(hint, node, emitCallback);
-    }
-    function onSubstituteNode(hint, node) {
-      node = previousOnSubstituteNode(hint, node);
-      if (hint === 1 /* Expression */ && enclosingSuperContainerFlags) {
-        return substituteExpression(node);
-      }
-      return node;
-    }
-    function substituteExpression(node) {
-      switch (node.kind) {
-        case 210 /* PropertyAccessExpression */:
-          return substitutePropertyAccessExpression(node);
-        case 211 /* ElementAccessExpression */:
-          return substituteElementAccessExpression(node);
-        case 212 /* CallExpression */:
-          return substituteCallExpression(node);
-      }
-      return node;
-    }
-    function substitutePropertyAccessExpression(node) {
-      if (node.expression.kind === 108 /* SuperKeyword */) {
-        return setTextRange(
-          factory2.createPropertyAccessExpression(
-            factory2.createUniqueName("_super", 16 /* Optimistic */ | 32 /* FileLevel */),
-            node.name
-          ),
-          node
-        );
-      }
-      return node;
-    }
-    function substituteElementAccessExpression(node) {
-      if (node.expression.kind === 108 /* SuperKeyword */) {
-        return createSuperElementAccessInAsyncMethod(
-          node.argumentExpression,
-          node
-        );
-      }
-      return node;
-    }
-    function substituteCallExpression(node) {
-      const expression = node.expression;
-      if (isSuperProperty(expression)) {
-        const argumentExpression = isPropertyAccessExpression(expression) ? substitutePropertyAccessExpression(expression) : substituteElementAccessExpression(expression);
-        return factory2.createCallExpression(
-          factory2.createPropertyAccessExpression(argumentExpression, "call"),
-          /*typeArguments*/
-          void 0,
-          [
-            factory2.createThis(),
-            ...node.arguments
-          ]
-        );
-      }
-      return node;
-    }
-    function isSuperContainer(node) {
-      const kind = node.kind;
-      return kind === 262 /* ClassDeclaration */ || kind === 175 /* Constructor */ || kind === 173 /* MethodDeclaration */ || kind === 176 /* GetAccessor */ || kind === 177 /* SetAccessor */;
-    }
-    function createSuperElementAccessInAsyncMethod(argumentExpression, location) {
-      if (enclosingSuperContainerFlags & 256 /* MethodWithSuperPropertyAssignmentInAsync */) {
-        return setTextRange(
-          factory2.createPropertyAccessExpression(
-            factory2.createCallExpression(
-              factory2.createIdentifier("_superIndex"),
-              /*typeArguments*/
-              void 0,
-              [argumentExpression]
-            ),
-            "value"
-          ),
-          location
-        );
-      } else {
-        return setTextRange(
-          factory2.createCallExpression(
-            factory2.createIdentifier("_superIndex"),
-            /*typeArguments*/
-            void 0,
-            [argumentExpression]
-          ),
-          location
-        );
-      }
-    }
-  }
-  var init_es2018 = __esm({
-    "src/compiler/transformers/es2018.ts"() {
-      "use strict";
-      init_ts2();
-    }
-  });
-
-  // src/compiler/transformers/es2019.ts
-  function transformES2019(context) {
-    const factory2 = context.factory;
-    return chainBundle(context, transformSourceFile);
-    function transformSourceFile(node) {
-      if (node.isDeclarationFile) {
-        return node;
-      }
-      return visitEachChild(node, visitor, context);
-    }
-    function visitor(node) {
-      if ((node.transformFlags & 64 /* ContainsES2019 */) === 0) {
-        return node;
-      }
-      switch (node.kind) {
-        case 298 /* CatchClause */:
-          return visitCatchClause(node);
-        default:
-          return visitEachChild(node, visitor, context);
-      }
-    }
-    function visitCatchClause(node) {
-      if (!node.variableDeclaration) {
-        return factory2.updateCatchClause(
-          node,
-          factory2.createVariableDeclaration(factory2.createTempVariable(
-            /*recordTempVariable*/
-            void 0
-          )),
-          visitNode(node.block, visitor, isBlock)
-        );
-      }
-      return visitEachChild(node, visitor, context);
-    }
-  }
-  var init_es2019 = __esm({
-    "src/compiler/transformers/es2019.ts"() {
-      "use strict";
-      init_ts2();
-    }
-  });
-
-  // src/compiler/transformers/es2020.ts
-  function transformES2020(context) {
-    const {
-      factory: factory2,
-      hoistVariableDeclaration
-    } = context;
-    return chainBundle(context, transformSourceFile);
-    function transformSourceFile(node) {
-      if (node.isDeclarationFile) {
-        return node;
-      }
-      return visitEachChild(node, visitor, context);
-    }
-    function visitor(node) {
-      if ((node.transformFlags & 32 /* ContainsES2020 */) === 0) {
-        return node;
-      }
-      switch (node.kind) {
-        case 212 /* CallExpression */: {
-          const updated = visitNonOptionalCallExpression(
-            node,
-            /*captureThisArg*/
-            false
-          );
-          Debug.assertNotNode(updated, isSyntheticReference);
-          return updated;
-        }
-        case 210 /* PropertyAccessExpression */:
-        case 211 /* ElementAccessExpression */:
-          if (isOptionalChain(node)) {
-            const updated = visitOptionalExpression(
-              node,
-              /*captureThisArg*/
-              false,
-              /*isDelete*/
-              false
-            );
-            Debug.assertNotNode(updated, isSyntheticReference);
-            return updated;
-          }
-          return visitEachChild(node, visitor, context);
-        case 225 /* BinaryExpression */:
-          if (node.operatorToken.kind === 61 /* QuestionQuestionToken */) {
-            return transformNullishCoalescingExpression(node);
-          }
-          return visitEachChild(node, visitor, context);
-        case 219 /* DeleteExpression */:
-          return visitDeleteExpression(node);
-        default:
-          return visitEachChild(node, visitor, context);
-      }
-    }
-    function flattenChain(chain) {
-      Debug.assertNotNode(chain, isNonNullChain);
-      const links = [chain];
-      while (!chain.questionDotToken && !isTaggedTemplateExpression(chain)) {
-        chain = cast(skipPartiallyEmittedExpressions(chain.expression), isOptionalChain);
-        Debug.assertNotNode(chain, isNonNullChain);
-        links.unshift(chain);
-      }
-      return { expression: chain.expression, chain: links };
-    }
-    function visitNonOptionalParenthesizedExpression(node, captureThisArg, isDelete) {
-      const expression = visitNonOptionalExpression(node.expression, captureThisArg, isDelete);
-      if (isSyntheticReference(expression)) {
-        return factory2.createSyntheticReferenceExpression(factory2.updateParenthesizedExpression(node, expression.expression), expression.thisArg);
-      }
-      return factory2.updateParenthesizedExpression(node, expression);
-    }
-    function visitNonOptionalPropertyOrElementAccessExpression(node, captureThisArg, isDelete) {
-      if (isOptionalChain(node)) {
-        return visitOptionalExpression(node, captureThisArg, isDelete);
-      }
-      let expression = visitNode(node.expression, visitor, isExpression);
-      Debug.assertNotNode(expression, isSyntheticReference);
-      let thisArg;
-      if (captureThisArg) {
-        if (!isSimpleCopiableExpression(expression)) {
-          thisArg = factory2.createTempVariable(hoistVariableDeclaration);
-          expression = factory2.createAssignment(thisArg, expression);
-        } else {
-          thisArg = expression;
-        }
-      }
-      expression = node.kind === 210 /* PropertyAccessExpression */ ? factory2.updatePropertyAccessExpression(node, expression, visitNode(node.name, visitor, isIdentifier)) : factory2.updateElementAccessExpression(node, expression, visitNode(node.argumentExpression, visitor, isExpression));
-      return thisArg ? factory2.createSyntheticReferenceExpression(expression, thisArg) : expression;
-    }
-    function visitNonOptionalCallExpression(node, captureThisArg) {
-      if (isOptionalChain(node)) {
-        return visitOptionalExpression(
-          node,
-          captureThisArg,
-          /*isDelete*/
-          false
-        );
-      }
-      if (isParenthesizedExpression(node.expression) && isOptionalChain(skipParentheses(node.expression))) {
-        const expression = visitNonOptionalParenthesizedExpression(
-          node.expression,
-          /*captureThisArg*/
-          true,
-          /*isDelete*/
-          false
-        );
-        const args = visitNodes2(node.arguments, visitor, isExpression);
-        if (isSyntheticReference(expression)) {
-          return setTextRange(factory2.createFunctionCallCall(expression.expression, expression.thisArg, args), node);
-        }
-        return factory2.updateCallExpression(
-          node,
-          expression,
-          /*typeArguments*/
-          void 0,
-          args
-        );
-      }
-      return visitEachChild(node, visitor, context);
-    }
-    function visitNonOptionalExpression(node, captureThisArg, isDelete) {
-      switch (node.kind) {
-        case 216 /* ParenthesizedExpression */:
-          return visitNonOptionalParenthesizedExpression(node, captureThisArg, isDelete);
-        case 210 /* PropertyAccessExpression */:
-        case 211 /* ElementAccessExpression */:
-          return visitNonOptionalPropertyOrElementAccessExpression(node, captureThisArg, isDelete);
-        case 212 /* CallExpression */:
-          return visitNonOptionalCallExpression(node, captureThisArg);
-        default:
-          return visitNode(node, visitor, isExpression);
-      }
-    }
-    function visitOptionalExpression(node, captureThisArg, isDelete) {
-      const { expression, chain } = flattenChain(node);
-      const left = visitNonOptionalExpression(
-        skipPartiallyEmittedExpressions(expression),
-        isCallChain(chain[0]),
-        /*isDelete*/
-        false
-      );
-      let leftThisArg = isSyntheticReference(left) ? left.thisArg : void 0;
-      let capturedLeft = isSyntheticReference(left) ? left.expression : left;
-      let leftExpression = factory2.restoreOuterExpressions(expression, capturedLeft, 8 /* PartiallyEmittedExpressions */);
-      if (!isSimpleCopiableExpression(capturedLeft)) {
-        capturedLeft = factory2.createTempVariable(hoistVariableDeclaration);
-        leftExpression = factory2.createAssignment(capturedLeft, leftExpression);
-      }
-      let rightExpression = capturedLeft;
-      let thisArg;
-      for (let i = 0; i < chain.length; i++) {
-        const segment = chain[i];
-        switch (segment.kind) {
-          case 210 /* PropertyAccessExpression */:
-          case 211 /* ElementAccessExpression */:
-            if (i === chain.length - 1 && captureThisArg) {
-              if (!isSimpleCopiableExpression(rightExpression)) {
-                thisArg = factory2.createTempVariable(hoistVariableDeclaration);
-                rightExpression = factory2.createAssignment(thisArg, rightExpression);
-              } else {
-                thisArg = rightExpression;
-              }
-            }
-            rightExpression = segment.kind === 210 /* PropertyAccessExpression */ ? factory2.createPropertyAccessExpression(rightExpression, visitNode(segment.name, visitor, isIdentifier)) : factory2.createElementAccessExpression(rightExpression, visitNode(segment.argumentExpression, visitor, isExpression));
-            break;
-          case 212 /* CallExpression */:
-            if (i === 0 && leftThisArg) {
-              if (!isGeneratedIdentifier(leftThisArg)) {
-                leftThisArg = factory2.cloneNode(leftThisArg);
-                addEmitFlags(leftThisArg, 3072 /* NoComments */);
-              }
-              rightExpression = factory2.createFunctionCallCall(
-                rightExpression,
-                leftThisArg.kind === 108 /* SuperKeyword */ ? factory2.createThis() : leftThisArg,
-                visitNodes2(segment.arguments, visitor, isExpression)
-              );
-            } else {
-              rightExpression = factory2.createCallExpression(
-                rightExpression,
-                /*typeArguments*/
-                void 0,
-                visitNodes2(segment.arguments, visitor, isExpression)
-              );
-            }
-            break;
-        }
-        setOriginalNode(rightExpression, segment);
-      }
-      const target = isDelete ? factory2.createConditionalExpression(
-        createNotNullCondition(
-          leftExpression,
-          capturedLeft,
-          /*invert*/
-          true
-        ),
-        /*questionToken*/
-        void 0,
-        factory2.createTrue(),
-        /*colonToken*/
-        void 0,
-        factory2.createDeleteExpression(rightExpression)
-      ) : factory2.createConditionalExpression(
-        createNotNullCondition(
-          leftExpression,
-          capturedLeft,
-          /*invert*/
-          true
-        ),
-        /*questionToken*/
-        void 0,
-        factory2.createVoidZero(),
-        /*colonToken*/
-        void 0,
-        rightExpression
-      );
-      setTextRange(target, node);
-      return thisArg ? factory2.createSyntheticReferenceExpression(target, thisArg) : target;
-    }
-    function createNotNullCondition(left, right, invert) {
-      return factory2.createBinaryExpression(
-        factory2.createBinaryExpression(
-          left,
-          factory2.createToken(invert ? 37 /* EqualsEqualsEqualsToken */ : 38 /* ExclamationEqualsEqualsToken */),
-          factory2.createNull()
-        ),
-        factory2.createToken(invert ? 57 /* BarBarToken */ : 56 /* AmpersandAmpersandToken */),
-        factory2.createBinaryExpression(
-          right,
-          factory2.createToken(invert ? 37 /* EqualsEqualsEqualsToken */ : 38 /* ExclamationEqualsEqualsToken */),
-          factory2.createVoidZero()
-        )
-      );
-    }
-    function transformNullishCoalescingExpression(node) {
-      let left = visitNode(node.left, visitor, isExpression);
-      let right = left;
-      if (!isSimpleCopiableExpression(left)) {
-        right = factory2.createTempVariable(hoistVariableDeclaration);
-        left = factory2.createAssignment(right, left);
-      }
-      return setTextRange(factory2.createConditionalExpression(
-        createNotNullCondition(left, right),
-        /*questionToken*/
-        void 0,
-        right,
-        /*colonToken*/
-        void 0,
-        visitNode(node.right, visitor, isExpression)
-      ), node);
-    }
-    function visitDeleteExpression(node) {
-      return isOptionalChain(skipParentheses(node.expression)) ? setOriginalNode(visitNonOptionalExpression(
-        node.expression,
-        /*captureThisArg*/
-        false,
-        /*isDelete*/
-        true
-      ), node) : factory2.updateDeleteExpression(node, visitNode(node.expression, visitor, isExpression));
-    }
-  }
-  var init_es2020 = __esm({
-    "src/compiler/transformers/es2020.ts"() {
-      "use strict";
-      init_ts2();
-    }
-  });
-
-  // src/compiler/transformers/es2021.ts
-  function transformES2021(context) {
-    const {
-      hoistVariableDeclaration,
-      factory: factory2
-    } = context;
-    return chainBundle(context, transformSourceFile);
-    function transformSourceFile(node) {
-      if (node.isDeclarationFile) {
-        return node;
-      }
-      return visitEachChild(node, visitor, context);
-    }
-    function visitor(node) {
-      if ((node.transformFlags & 16 /* ContainsES2021 */) === 0) {
-        return node;
-      }
-      if (isLogicalOrCoalescingAssignmentExpression(node)) {
-        return transformLogicalAssignment(node);
-      }
-      return visitEachChild(node, visitor, context);
-    }
-    function transformLogicalAssignment(binaryExpression) {
-      const operator = binaryExpression.operatorToken;
-      const nonAssignmentOperator = getNonAssignmentOperatorForCompoundAssignment(operator.kind);
-      let left = skipParentheses(visitNode(binaryExpression.left, visitor, isLeftHandSideExpression));
-      let assignmentTarget = left;
-      const right = skipParentheses(visitNode(binaryExpression.right, visitor, isExpression));
-      if (isAccessExpression(left)) {
-        const propertyAccessTargetSimpleCopiable = isSimpleCopiableExpression(left.expression);
-        const propertyAccessTarget = propertyAccessTargetSimpleCopiable ? left.expression : factory2.createTempVariable(hoistVariableDeclaration);
-        const propertyAccessTargetAssignment = propertyAccessTargetSimpleCopiable ? left.expression : factory2.createAssignment(
-          propertyAccessTarget,
-          left.expression
-        );
-        if (isPropertyAccessExpression(left)) {
-          assignmentTarget = factory2.createPropertyAccessExpression(
-            propertyAccessTarget,
-            left.name
-          );
-          left = factory2.createPropertyAccessExpression(
-            propertyAccessTargetAssignment,
-            left.name
-          );
-        } else {
-          const elementAccessArgumentSimpleCopiable = isSimpleCopiableExpression(left.argumentExpression);
-          const elementAccessArgument = elementAccessArgumentSimpleCopiable ? left.argumentExpression : factory2.createTempVariable(hoistVariableDeclaration);
-          assignmentTarget = factory2.createElementAccessExpression(
-            propertyAccessTarget,
-            elementAccessArgument
-          );
-          left = factory2.createElementAccessExpression(
-            propertyAccessTargetAssignment,
-            elementAccessArgumentSimpleCopiable ? left.argumentExpression : factory2.createAssignment(
-              elementAccessArgument,
-              left.argumentExpression
-            )
-          );
-        }
-      }
-      return factory2.createBinaryExpression(
-        left,
-        nonAssignmentOperator,
-        factory2.createParenthesizedExpression(
-          factory2.createAssignment(
-            assignmentTarget,
-            right
-          )
-        )
-      );
-    }
-  }
-  var init_es2021 = __esm({
-    "src/compiler/transformers/es2021.ts"() {
-      "use strict";
-      init_ts2();
-    }
-  });
-
-  // src/compiler/transformers/esnext.ts
-  function transformESNext(context) {
-    return chainBundle(context, transformSourceFile);
-    function transformSourceFile(node) {
-      if (node.isDeclarationFile) {
-        return node;
-      }
-      return visitEachChild(node, visitor, context);
-    }
-    function visitor(node) {
-      if ((node.transformFlags & 4 /* ContainsESNext */) === 0) {
-        return node;
-      }
-      switch (node.kind) {
-        default:
-          return visitEachChild(node, visitor, context);
-      }
-    }
-  }
-  var init_esnext = __esm({
-    "src/compiler/transformers/esnext.ts"() {
-      "use strict";
-      init_ts2();
-    }
-  });
-
-  // src/compiler/transformers/jsx.ts
-  function transformJsx(context) {
-    const {
-      factory: factory2,
-      getEmitHelperFactory: emitHelpers
-    } = context;
-    const compilerOptions = context.getCompilerOptions();
-    let currentSourceFile;
-    let currentFileState;
-    return chainBundle(context, transformSourceFile);
-    function getCurrentFileNameExpression() {
-      if (currentFileState.filenameDeclaration) {
-        return currentFileState.filenameDeclaration.name;
-      }
-      const declaration = factory2.createVariableDeclaration(
-        factory2.createUniqueName("_jsxFileName", 16 /* Optimistic */ | 32 /* FileLevel */),
-        /*exclamationToken*/
-        void 0,
-        /*type*/
-        void 0,
-        factory2.createStringLiteral(currentSourceFile.fileName)
-      );
-      currentFileState.filenameDeclaration = declaration;
-      return currentFileState.filenameDeclaration.name;
-    }
-    function getJsxFactoryCalleePrimitive(isStaticChildren) {
-      return compilerOptions.jsx === 5 /* ReactJSXDev */ ? "jsxDEV" : isStaticChildren ? "jsxs" : "jsx";
-    }
-    function getJsxFactoryCallee(isStaticChildren) {
-      const type = getJsxFactoryCalleePrimitive(isStaticChildren);
-      return getImplicitImportForName(type);
-    }
-    function getImplicitJsxFragmentReference() {
-      return getImplicitImportForName("Fragment");
-    }
-    function getImplicitImportForName(name) {
-      var _a, _b;
-      const importSource = name === "createElement" ? currentFileState.importSpecifier : getJSXRuntimeImport(currentFileState.importSpecifier, compilerOptions);
-      const existing = (_b = (_a = currentFileState.utilizedImplicitRuntimeImports) == null ? void 0 : _a.get(importSource)) == null ? void 0 : _b.get(name);
-      if (existing) {
-        return existing.name;
-      }
-      if (!currentFileState.utilizedImplicitRuntimeImports) {
-        currentFileState.utilizedImplicitRuntimeImports = /* @__PURE__ */ new Map();
-      }
-      let specifierSourceImports = currentFileState.utilizedImplicitRuntimeImports.get(importSource);
-      if (!specifierSourceImports) {
-        specifierSourceImports = /* @__PURE__ */ new Map();
-        currentFileState.utilizedImplicitRuntimeImports.set(importSource, specifierSourceImports);
-      }
-      const generatedName = factory2.createUniqueName(`_${name}`, 16 /* Optimistic */ | 32 /* FileLevel */ | 64 /* AllowNameSubstitution */);
-      const specifier = factory2.createImportSpecifier(
-        /*isTypeOnly*/
-        false,
-        factory2.createIdentifier(name),
-        generatedName
-      );
-      setIdentifierGeneratedImportReference(generatedName, specifier);
-      specifierSourceImports.set(name, specifier);
-      return generatedName;
-    }
-    function transformSourceFile(node) {
-      if (node.isDeclarationFile) {
-        return node;
-      }
-      currentSourceFile = node;
-      currentFileState = {};
-      currentFileState.importSpecifier = getJSXImplicitImportBase(compilerOptions, node);
-      let visited = visitEachChild(node, visitor, context);
-      addEmitHelpers(visited, context.readEmitHelpers());
-      let statements = visited.statements;
-      if (currentFileState.filenameDeclaration) {
-        statements = insertStatementAfterCustomPrologue(statements.slice(), factory2.createVariableStatement(
-          /*modifiers*/
-          void 0,
-          factory2.createVariableDeclarationList([currentFileState.filenameDeclaration], 2 /* Const */)
-        ));
-      }
-      if (currentFileState.utilizedImplicitRuntimeImports) {
-        for (const [importSource, importSpecifiersMap] of arrayFrom(currentFileState.utilizedImplicitRuntimeImports.entries())) {
-          if (isExternalModule(node)) {
-            const importStatement = factory2.createImportDeclaration(
-              /*modifiers*/
-              void 0,
-              factory2.createImportClause(
-                /*isTypeOnly*/
-                false,
-                /*name*/
-                void 0,
-                factory2.createNamedImports(arrayFrom(importSpecifiersMap.values()))
-              ),
-              factory2.createStringLiteral(importSource),
-              /*assertClause*/
-              void 0
-            );
-            setParentRecursive(
-              importStatement,
-              /*incremental*/
-              false
-            );
-            statements = insertStatementAfterCustomPrologue(statements.slice(), importStatement);
-          } else if (isExternalOrCommonJsModule(node)) {
-            const requireStatement = factory2.createVariableStatement(
-              /*modifiers*/
-              void 0,
-              factory2.createVariableDeclarationList([
-                factory2.createVariableDeclaration(
-                  factory2.createObjectBindingPattern(arrayFrom(importSpecifiersMap.values(), (s) => factory2.createBindingElement(
-                    /*dotDotDotToken*/
-                    void 0,
-                    s.propertyName,
-                    s.name
-                  ))),
-                  /*exclamationToken*/
-                  void 0,
-                  /*type*/
-                  void 0,
-                  factory2.createCallExpression(
-                    factory2.createIdentifier("require"),
-                    /*typeArguments*/
-                    void 0,
-                    [factory2.createStringLiteral(importSource)]
-                  )
-                )
-              ], 2 /* Const */)
-            );
-            setParentRecursive(
-              requireStatement,
-              /*incremental*/
-              false
-            );
-            statements = insertStatementAfterCustomPrologue(statements.slice(), requireStatement);
-          } else {
-          }
-        }
-      }
-      if (statements !== visited.statements) {
-        visited = factory2.updateSourceFile(visited, statements);
-      }
-      currentFileState = void 0;
-      return visited;
-    }
-    function visitor(node) {
-      if (node.transformFlags & 2 /* ContainsJsx */) {
-        return visitorWorker(node);
-      } else {
-        return node;
-      }
-    }
-    function visitorWorker(node) {
-      switch (node.kind) {
-        case 283 /* JsxElement */:
-          return visitJsxElement(
-            node,
-            /*isChild*/
-            false
-          );
-        case 284 /* JsxSelfClosingElement */:
-          return visitJsxSelfClosingElement(
-            node,
-            /*isChild*/
-            false
-          );
-        case 287 /* JsxFragment */:
-          return visitJsxFragment(
-            node,
-            /*isChild*/
-            false
-          );
-        case 293 /* JsxExpression */:
-          return visitJsxExpression(node);
-        default:
-          return visitEachChild(node, visitor, context);
-      }
-    }
-    function transformJsxChildToExpression(node) {
-      switch (node.kind) {
-        case 12 /* JsxText */:
-          return visitJsxText(node);
-        case 293 /* JsxExpression */:
-          return visitJsxExpression(node);
-        case 283 /* JsxElement */:
-          return visitJsxElement(
-            node,
-            /*isChild*/
-            true
-          );
-        case 284 /* JsxSelfClosingElement */:
-          return visitJsxSelfClosingElement(
-            node,
-            /*isChild*/
-            true
-          );
-        case 287 /* JsxFragment */:
-          return visitJsxFragment(
-            node,
-            /*isChild*/
-            true
-          );
-        default:
-          return Debug.failBadSyntaxKind(node);
-      }
-    }
-    function hasProto(obj) {
-      return obj.properties.some((p) => isPropertyAssignment(p) && (isIdentifier(p.name) && idText(p.name) === "__proto__" || isStringLiteral(p.name) && p.name.text === "__proto__"));
-    }
-    function hasKeyAfterPropsSpread(node) {
-      let spread = false;
-      for (const elem of node.attributes.properties) {
-        if (isJsxSpreadAttribute(elem) && (!isObjectLiteralExpression(elem.expression) || elem.expression.properties.some(isSpreadAssignment))) {
-          spread = true;
-        } else if (spread && isJsxAttribute(elem) && isIdentifier(elem.name) && elem.name.escapedText === "key") {
-          return true;
-        }
-      }
-      return false;
-    }
-    function shouldUseCreateElement(node) {
-      return currentFileState.importSpecifier === void 0 || hasKeyAfterPropsSpread(node);
-    }
-    function visitJsxElement(node, isChild) {
-      const tagTransform = shouldUseCreateElement(node.openingElement) ? visitJsxOpeningLikeElementCreateElement : visitJsxOpeningLikeElementJSX;
-      return tagTransform(
-        node.openingElement,
-        node.children,
-        isChild,
-        /*location*/
-        node
-      );
-    }
-    function visitJsxSelfClosingElement(node, isChild) {
-      const tagTransform = shouldUseCreateElement(node) ? visitJsxOpeningLikeElementCreateElement : visitJsxOpeningLikeElementJSX;
-      return tagTransform(
-        node,
-        /*children*/
-        void 0,
-        isChild,
-        /*location*/
-        node
-      );
-    }
-    function visitJsxFragment(node, isChild) {
-      const tagTransform = currentFileState.importSpecifier === void 0 ? visitJsxOpeningFragmentCreateElement : visitJsxOpeningFragmentJSX;
-      return tagTransform(
-        node.openingFragment,
-        node.children,
-        isChild,
-        /*location*/
-        node
-      );
-    }
-    function convertJsxChildrenToChildrenPropObject(children) {
-      const prop = convertJsxChildrenToChildrenPropAssignment(children);
-      return prop && factory2.createObjectLiteralExpression([prop]);
-    }
-    function convertJsxChildrenToChildrenPropAssignment(children) {
-      const nonWhitespaceChildren = getSemanticJsxChildren(children);
-      if (length(nonWhitespaceChildren) === 1 && !nonWhitespaceChildren[0].dotDotDotToken) {
-        const result2 = transformJsxChildToExpression(nonWhitespaceChildren[0]);
-        return result2 && factory2.createPropertyAssignment("children", result2);
-      }
-      const result = mapDefined(children, transformJsxChildToExpression);
-      return length(result) ? factory2.createPropertyAssignment("children", factory2.createArrayLiteralExpression(result)) : void 0;
-    }
-    function visitJsxOpeningLikeElementJSX(node, children, isChild, location) {
-      const tagName = getTagName(node);
-      const childrenProp = children && children.length ? convertJsxChildrenToChildrenPropAssignment(children) : void 0;
-      const keyAttr = find(node.attributes.properties, (p) => !!p.name && isIdentifier(p.name) && p.name.escapedText === "key");
-      const attrs = keyAttr ? filter(node.attributes.properties, (p) => p !== keyAttr) : node.attributes.properties;
-      const objectProperties = length(attrs) ? transformJsxAttributesToObjectProps(attrs, childrenProp) : factory2.createObjectLiteralExpression(childrenProp ? [childrenProp] : emptyArray);
-      return visitJsxOpeningLikeElementOrFragmentJSX(
-        tagName,
-        objectProperties,
-        keyAttr,
-        children || emptyArray,
-        isChild,
-        location
-      );
-    }
-    function visitJsxOpeningLikeElementOrFragmentJSX(tagName, objectProperties, keyAttr, children, isChild, location) {
-      var _a;
-      const nonWhitespaceChildren = getSemanticJsxChildren(children);
-      const isStaticChildren = length(nonWhitespaceChildren) > 1 || !!((_a = nonWhitespaceChildren[0]) == null ? void 0 : _a.dotDotDotToken);
-      const args = [tagName, objectProperties];
-      if (keyAttr) {
-        args.push(transformJsxAttributeInitializer(keyAttr.initializer));
-      }
-      if (compilerOptions.jsx === 5 /* ReactJSXDev */) {
-        const originalFile = getOriginalNode(currentSourceFile);
-        if (originalFile && isSourceFile(originalFile)) {
-          if (keyAttr === void 0) {
-            args.push(factory2.createVoidZero());
-          }
-          args.push(isStaticChildren ? factory2.createTrue() : factory2.createFalse());
-          const lineCol = getLineAndCharacterOfPosition(originalFile, location.pos);
-          args.push(factory2.createObjectLiteralExpression([
-            factory2.createPropertyAssignment("fileName", getCurrentFileNameExpression()),
-            factory2.createPropertyAssignment("lineNumber", factory2.createNumericLiteral(lineCol.line + 1)),
-            factory2.createPropertyAssignment("columnNumber", factory2.createNumericLiteral(lineCol.character + 1))
-          ]));
-          args.push(factory2.createThis());
-        }
-      }
-      const element = setTextRange(
-        factory2.createCallExpression(
-          getJsxFactoryCallee(isStaticChildren),
-          /*typeArguments*/
-          void 0,
-          args
-        ),
-        location
-      );
-      if (isChild) {
-        startOnNewLine(element);
-      }
-      return element;
-    }
-    function visitJsxOpeningLikeElementCreateElement(node, children, isChild, location) {
-      const tagName = getTagName(node);
-      const attrs = node.attributes.properties;
-      const objectProperties = length(attrs) ? transformJsxAttributesToObjectProps(attrs) : factory2.createNull();
-      const callee = currentFileState.importSpecifier === void 0 ? createJsxFactoryExpression(
-        factory2,
-        context.getEmitResolver().getJsxFactoryEntity(currentSourceFile),
-        compilerOptions.reactNamespace,
-        // TODO: GH#18217
-        node
-      ) : getImplicitImportForName("createElement");
-      const element = createExpressionForJsxElement(
-        factory2,
-        callee,
-        tagName,
-        objectProperties,
-        mapDefined(children, transformJsxChildToExpression),
-        location
-      );
-      if (isChild) {
-        startOnNewLine(element);
-      }
-      return element;
-    }
-    function visitJsxOpeningFragmentJSX(_node, children, isChild, location) {
-      let childrenProps;
-      if (children && children.length) {
-        const result = convertJsxChildrenToChildrenPropObject(children);
-        if (result) {
-          childrenProps = result;
-        }
-      }
-      return visitJsxOpeningLikeElementOrFragmentJSX(
-        getImplicitJsxFragmentReference(),
-        childrenProps || factory2.createObjectLiteralExpression([]),
-        /*keyAttr*/
-        void 0,
-        children,
-        isChild,
-        location
-      );
-    }
-    function visitJsxOpeningFragmentCreateElement(node, children, isChild, location) {
-      const element = createExpressionForJsxFragment(
-        factory2,
-        context.getEmitResolver().getJsxFactoryEntity(currentSourceFile),
-        context.getEmitResolver().getJsxFragmentFactoryEntity(currentSourceFile),
-        compilerOptions.reactNamespace,
-        // TODO: GH#18217
-        mapDefined(children, transformJsxChildToExpression),
-        node,
-        location
-      );
-      if (isChild) {
-        startOnNewLine(element);
-      }
-      return element;
-    }
-    function transformJsxSpreadAttributeToProps(node) {
-      if (isObjectLiteralExpression(node.expression) && !hasProto(node.expression)) {
-        return node.expression.properties;
-      }
-      return factory2.createSpreadAssignment(Debug.checkDefined(visitNode(node.expression, visitor, isExpression)));
-    }
-    function transformJsxAttributesToObjectProps(attrs, children) {
-      const target = getEmitScriptTarget(compilerOptions);
-      return target && target >= 5 /* ES2018 */ ? factory2.createObjectLiteralExpression(transformJsxAttributesToProps(attrs, children)) : transformJsxAttributesToExpression(attrs, children);
-    }
-    function transformJsxAttributesToProps(attrs, children) {
-      const props = flatten(spanMap(attrs, isJsxSpreadAttribute, (attrs2, isSpread) => flatten(map(attrs2, (attr) => isSpread ? transformJsxSpreadAttributeToProps(attr) : transformJsxAttributeToObjectLiteralElement(attr)))));
-      if (children) {
-        props.push(children);
-      }
-      return props;
-    }
-    function transformJsxAttributesToExpression(attrs, children) {
-      const expressions = [];
-      let properties = [];
-      for (const attr of attrs) {
-        if (isJsxSpreadAttribute(attr)) {
-          if (isObjectLiteralExpression(attr.expression) && !hasProto(attr.expression)) {
-            for (const prop of attr.expression.properties) {
-              if (isSpreadAssignment(prop)) {
-                finishObjectLiteralIfNeeded();
-                expressions.push(prop.expression);
-                continue;
-              }
-              properties.push(prop);
-            }
-            continue;
-          }
-          finishObjectLiteralIfNeeded();
-          expressions.push(Debug.checkDefined(visitNode(attr.expression, visitor, isExpression)));
-          continue;
-        }
-        properties.push(transformJsxAttributeToObjectLiteralElement(attr));
-      }
-      if (children) {
-        properties.push(children);
-      }
-      finishObjectLiteralIfNeeded();
-      if (expressions.length && !isObjectLiteralExpression(expressions[0])) {
-        expressions.unshift(factory2.createObjectLiteralExpression());
-      }
-      return singleOrUndefined(expressions) || emitHelpers().createAssignHelper(expressions);
-      function finishObjectLiteralIfNeeded() {
-        if (properties.length) {
-          expressions.push(factory2.createObjectLiteralExpression(properties));
-          properties = [];
-        }
-      }
-    }
-    function transformJsxAttributeToObjectLiteralElement(node) {
-      const name = getAttributeName(node);
-      const expression = transformJsxAttributeInitializer(node.initializer);
-      return factory2.createPropertyAssignment(name, expression);
-    }
-    function transformJsxAttributeInitializer(node) {
-      if (node === void 0) {
-        return factory2.createTrue();
-      }
-      if (node.kind === 11 /* StringLiteral */) {
-        const singleQuote = node.singleQuote !== void 0 ? node.singleQuote : !isStringDoubleQuoted(node, currentSourceFile);
-        const literal = factory2.createStringLiteral(tryDecodeEntities(node.text) || node.text, singleQuote);
-        return setTextRange(literal, node);
-      }
-      if (node.kind === 293 /* JsxExpression */) {
-        if (node.expression === void 0) {
-          return factory2.createTrue();
-        }
-        return Debug.checkDefined(visitNode(node.expression, visitor, isExpression));
-      }
-      if (isJsxElement(node)) {
-        return visitJsxElement(
-          node,
-          /*isChild*/
-          false
-        );
-      }
-      if (isJsxSelfClosingElement(node)) {
-        return visitJsxSelfClosingElement(
-          node,
-          /*isChild*/
-          false
-        );
-      }
-      if (isJsxFragment(node)) {
-        return visitJsxFragment(
-          node,
-          /*isChild*/
-          false
-        );
-      }
-      return Debug.failBadSyntaxKind(node);
-    }
-    function visitJsxText(node) {
-      const fixed = fixupWhitespaceAndDecodeEntities(node.text);
-      return fixed === void 0 ? void 0 : factory2.createStringLiteral(fixed);
-    }
-    function fixupWhitespaceAndDecodeEntities(text) {
-      let acc;
-      let firstNonWhitespace = 0;
-      let lastNonWhitespace = -1;
-      for (let i = 0; i < text.length; i++) {
-        const c = text.charCodeAt(i);
-        if (isLineBreak(c)) {
-          if (firstNonWhitespace !== -1 && lastNonWhitespace !== -1) {
-            acc = addLineOfJsxText(acc, text.substr(firstNonWhitespace, lastNonWhitespace - firstNonWhitespace + 1));
-          }
-          firstNonWhitespace = -1;
-        } else if (!isWhiteSpaceSingleLine(c)) {
-          lastNonWhitespace = i;
-          if (firstNonWhitespace === -1) {
-            firstNonWhitespace = i;
-          }
-        }
-      }
-      return firstNonWhitespace !== -1 ? addLineOfJsxText(acc, text.substr(firstNonWhitespace)) : acc;
-    }
-    function addLineOfJsxText(acc, trimmedLine) {
-      const decoded = decodeEntities(trimmedLine);
-      return acc === void 0 ? decoded : acc + " " + decoded;
-    }
-    function decodeEntities(text) {
-      return text.replace(/&((#((\d+)|x([\da-fA-F]+)))|(\w+));/g, (match, _all, _number, _digits, decimal, hex, word) => {
-        if (decimal) {
-          return utf16EncodeAsString(parseInt(decimal, 10));
-        } else if (hex) {
-          return utf16EncodeAsString(parseInt(hex, 16));
-        } else {
-          const ch = entities.get(word);
-          return ch ? utf16EncodeAsString(ch) : match;
-        }
-      });
-    }
-    function tryDecodeEntities(text) {
-      const decoded = decodeEntities(text);
-      return decoded === text ? void 0 : decoded;
-    }
-    function getTagName(node) {
-      if (node.kind === 283 /* JsxElement */) {
-        return getTagName(node.openingElement);
-      } else {
-        const tagName = node.tagName;
-        if (isIdentifier(tagName) && isIntrinsicJsxName(tagName.escapedText)) {
-          return factory2.createStringLiteral(idText(tagName));
-        } else if (isJsxNamespacedName(tagName)) {
-          return factory2.createStringLiteral(idText(tagName.namespace) + ":" + idText(tagName.name));
-        } else {
-          return createExpressionFromEntityName(factory2, tagName);
-        }
-      }
-    }
-    function getAttributeName(node) {
-      const name = node.name;
-      if (isIdentifier(name)) {
-        const text = idText(name);
-        return /^[A-Za-z_]\w*$/.test(text) ? name : factory2.createStringLiteral(text);
-      }
-      return factory2.createStringLiteral(idText(name.namespace) + ":" + idText(name.name));
-    }
-    function visitJsxExpression(node) {
-      const expression = visitNode(node.expression, visitor, isExpression);
-      return node.dotDotDotToken ? factory2.createSpreadElement(expression) : expression;
-    }
-  }
-  var entities;
-  var init_jsx = __esm({
-    "src/compiler/transformers/jsx.ts"() {
-      "use strict";
-      init_ts2();
-      entities = new Map(Object.entries({
-        quot: 34,
-        amp: 38,
-        apos: 39,
-        lt: 60,
-        gt: 62,
-        nbsp: 160,
-        iexcl: 161,
-        cent: 162,
-        pound: 163,
-        curren: 164,
-        yen: 165,
-        brvbar: 166,
-        sect: 167,
-        uml: 168,
-        copy: 169,
-        ordf: 170,
-        laquo: 171,
-        not: 172,
-        shy: 173,
-        reg: 174,
-        macr: 175,
-        deg: 176,
-        plusmn: 177,
-        sup2: 178,
-        sup3: 179,
-        acute: 180,
-        micro: 181,
-        para: 182,
-        middot: 183,
-        cedil: 184,
-        sup1: 185,
-        ordm: 186,
-        raquo: 187,
-        frac14: 188,
-        frac12: 189,
-        frac34: 190,
-        iquest: 191,
-        Agrave: 192,
-        Aacute: 193,
-        Acirc: 194,
-        Atilde: 195,
-        Auml: 196,
-        Aring: 197,
-        AElig: 198,
-        Ccedil: 199,
-        Egrave: 200,
-        Eacute: 201,
-        Ecirc: 202,
-        Euml: 203,
-        Igrave: 204,
-        Iacute: 205,
-        Icirc: 206,
-        Iuml: 207,
-        ETH: 208,
-        Ntilde: 209,
-        Ograve: 210,
-        Oacute: 211,
-        Ocirc: 212,
-        Otilde: 213,
-        Ouml: 214,
-        times: 215,
-        Oslash: 216,
-        Ugrave: 217,
-        Uacute: 218,
-        Ucirc: 219,
-        Uuml: 220,
-        Yacute: 221,
-        THORN: 222,
-        szlig: 223,
-        agrave: 224,
-        aacute: 225,
-        acirc: 226,
-        atilde: 227,
-        auml: 228,
-        aring: 229,
-        aelig: 230,
-        ccedil: 231,
-        egrave: 232,
-        eacute: 233,
-        ecirc: 234,
-        euml: 235,
-        igrave: 236,
-        iacute: 237,
-        icirc: 238,
-        iuml: 239,
-        eth: 240,
-        ntilde: 241,
-        ograve: 242,
-        oacute: 243,
-        ocirc: 244,
-        otilde: 245,
-        ouml: 246,
-        divide: 247,
-        oslash: 248,
-        ugrave: 249,
-        uacute: 250,
-        ucirc: 251,
-        uuml: 252,
-        yacute: 253,
-        thorn: 254,
-        yuml: 255,
-        OElig: 338,
-        oelig: 339,
-        Scaron: 352,
-        scaron: 353,
-        Yuml: 376,
-        fnof: 402,
-        circ: 710,
-        tilde: 732,
-        Alpha: 913,
-        Beta: 914,
-        Gamma: 915,
-        Delta: 916,
-        Epsilon: 917,
-        Zeta: 918,
-        Eta: 919,
-        Theta: 920,
-        Iota: 921,
-        Kappa: 922,
-        Lambda: 923,
-        Mu: 924,
-        Nu: 925,
-        Xi: 926,
-        Omicron: 927,
-        Pi: 928,
-        Rho: 929,
-        Sigma: 931,
-        Tau: 932,
-        Upsilon: 933,
-        Phi: 934,
-        Chi: 935,
-        Psi: 936,
-        Omega: 937,
-        alpha: 945,
-        beta: 946,
-        gamma: 947,
-        delta: 948,
-        epsilon: 949,
-        zeta: 950,
-        eta: 951,
-        theta: 952,
-        iota: 953,
-        kappa: 954,
-        lambda: 955,
-        mu: 956,
-        nu: 957,
-        xi: 958,
-        omicron: 959,
-        pi: 960,
-        rho: 961,
-        sigmaf: 962,
-        sigma: 963,
-        tau: 964,
-        upsilon: 965,
-        phi: 966,
-        chi: 967,
-        psi: 968,
-        omega: 969,
-        thetasym: 977,
-        upsih: 978,
-        piv: 982,
-        ensp: 8194,
-        emsp: 8195,
-        thinsp: 8201,
-        zwnj: 8204,
-        zwj: 8205,
-        lrm: 8206,
-        rlm: 8207,
-        ndash: 8211,
-        mdash: 8212,
-        lsquo: 8216,
-        rsquo: 8217,
-        sbquo: 8218,
-        ldquo: 8220,
-        rdquo: 8221,
-        bdquo: 8222,
-        dagger: 8224,
-        Dagger: 8225,
-        bull: 8226,
-        hellip: 8230,
-        permil: 8240,
-        prime: 8242,
-        Prime: 8243,
-        lsaquo: 8249,
-        rsaquo: 8250,
-        oline: 8254,
-        frasl: 8260,
-        euro: 8364,
-        image: 8465,
-        weierp: 8472,
-        real: 8476,
-        trade: 8482,
-        alefsym: 8501,
-        larr: 8592,
-        uarr: 8593,
-        rarr: 8594,
-        darr: 8595,
-        harr: 8596,
-        crarr: 8629,
-        lArr: 8656,
-        uArr: 8657,
-        rArr: 8658,
-        dArr: 8659,
-        hArr: 8660,
-        forall: 8704,
-        part: 8706,
-        exist: 8707,
-        empty: 8709,
-        nabla: 8711,
-        isin: 8712,
-        notin: 8713,
-        ni: 8715,
-        prod: 8719,
-        sum: 8721,
-        minus: 8722,
-        lowast: 8727,
-        radic: 8730,
-        prop: 8733,
-        infin: 8734,
-        ang: 8736,
-        and: 8743,
-        or: 8744,
-        cap: 8745,
-        cup: 8746,
-        int: 8747,
-        there4: 8756,
-        sim: 8764,
-        cong: 8773,
-        asymp: 8776,
-        ne: 8800,
-        equiv: 8801,
-        le: 8804,
-        ge: 8805,
-        sub: 8834,
-        sup: 8835,
-        nsub: 8836,
-        sube: 8838,
-        supe: 8839,
-        oplus: 8853,
-        otimes: 8855,
-        perp: 8869,
-        sdot: 8901,
-        lceil: 8968,
-        rceil: 8969,
-        lfloor: 8970,
-        rfloor: 8971,
-        lang: 9001,
-        rang: 9002,
-        loz: 9674,
-        spades: 9824,
-        clubs: 9827,
-        hearts: 9829,
-        diams: 9830
-      }));
-    }
-  });
-
-  // src/compiler/transformers/es2016.ts
-  function transformES2016(context) {
-    const {
-      factory: factory2,
-      hoistVariableDeclaration
-    } = context;
-    return chainBundle(context, transformSourceFile);
-    function transformSourceFile(node) {
-      if (node.isDeclarationFile) {
-        return node;
-      }
-      return visitEachChild(node, visitor, context);
-    }
-    function visitor(node) {
-      if ((node.transformFlags & 512 /* ContainsES2016 */) === 0) {
-        return node;
-      }
-      switch (node.kind) {
-        case 225 /* BinaryExpression */:
-          return visitBinaryExpression(node);
-        default:
-          return visitEachChild(node, visitor, context);
-      }
-    }
-    function visitBinaryExpression(node) {
-      switch (node.operatorToken.kind) {
-        case 68 /* AsteriskAsteriskEqualsToken */:
-          return visitExponentiationAssignmentExpression(node);
-        case 43 /* AsteriskAsteriskToken */:
-          return visitExponentiationExpression(node);
-        default:
-          return visitEachChild(node, visitor, context);
-      }
-    }
-    function visitExponentiationAssignmentExpression(node) {
-      let target;
-      let value;
-      const left = visitNode(node.left, visitor, isExpression);
-      const right = visitNode(node.right, visitor, isExpression);
-      if (isElementAccessExpression(left)) {
-        const expressionTemp = factory2.createTempVariable(hoistVariableDeclaration);
-        const argumentExpressionTemp = factory2.createTempVariable(hoistVariableDeclaration);
-        target = setTextRange(
-          factory2.createElementAccessExpression(
-            setTextRange(factory2.createAssignment(expressionTemp, left.expression), left.expression),
-            setTextRange(factory2.createAssignment(argumentExpressionTemp, left.argumentExpression), left.argumentExpression)
-          ),
-          left
-        );
-        value = setTextRange(
-          factory2.createElementAccessExpression(
-            expressionTemp,
-            argumentExpressionTemp
-          ),
-          left
-        );
-      } else if (isPropertyAccessExpression(left)) {
-        const expressionTemp = factory2.createTempVariable(hoistVariableDeclaration);
-        target = setTextRange(
-          factory2.createPropertyAccessExpression(
-            setTextRange(factory2.createAssignment(expressionTemp, left.expression), left.expression),
-            left.name
-          ),
-          left
-        );
-        value = setTextRange(
-          factory2.createPropertyAccessExpression(
-            expressionTemp,
-            left.name
-          ),
-          left
-        );
-      } else {
-        target = left;
-        value = left;
-      }
-      return setTextRange(
-        factory2.createAssignment(
-          target,
-          setTextRange(factory2.createGlobalMethodCall("Math", "pow", [value, right]), node)
-        ),
-        node
-      );
-    }
-    function visitExponentiationExpression(node) {
-      const left = visitNode(node.left, visitor, isExpression);
-      const right = visitNode(node.right, visitor, isExpression);
-      return setTextRange(factory2.createGlobalMethodCall("Math", "pow", [left, right]), node);
-    }
-  }
-  var init_es2016 = __esm({
-    "src/compiler/transformers/es2016.ts"() {
-      "use strict";
-      init_ts2();
-    }
-  });
-
-  // src/compiler/transformers/es2015.ts
-  function createSpreadSegment(kind, expression) {
-    return { kind, expression };
-  }
-  function transformES2015(context) {
-    const {
-      factory: factory2,
-      getEmitHelperFactory: emitHelpers,
-      startLexicalEnvironment,
-      resumeLexicalEnvironment,
-      endLexicalEnvironment,
-      hoistVariableDeclaration
-    } = context;
-    const compilerOptions = context.getCompilerOptions();
-    const resolver = context.getEmitResolver();
-    const previousOnSubstituteNode = context.onSubstituteNode;
-    const previousOnEmitNode = context.onEmitNode;
-    context.onEmitNode = onEmitNode;
-    context.onSubstituteNode = onSubstituteNode;
-    let currentSourceFile;
-    let currentText;
-    let hierarchyFacts;
-    let taggedTemplateStringDeclarations;
-    function recordTaggedTemplateString(temp) {
-      taggedTemplateStringDeclarations = append(
-        taggedTemplateStringDeclarations,
-        factory2.createVariableDeclaration(temp)
-      );
-    }
-    let convertedLoopState;
-    let enabledSubstitutions;
-    return chainBundle(context, transformSourceFile);
-    function transformSourceFile(node) {
-      if (node.isDeclarationFile) {
-        return node;
-      }
-      currentSourceFile = node;
-      currentText = node.text;
-      const visited = visitSourceFile(node);
-      addEmitHelpers(visited, context.readEmitHelpers());
-      currentSourceFile = void 0;
-      currentText = void 0;
-      taggedTemplateStringDeclarations = void 0;
-      hierarchyFacts = 0 /* None */;
-      return visited;
-    }
-    function enterSubtree(excludeFacts, includeFacts) {
-      const ancestorFacts = hierarchyFacts;
-      hierarchyFacts = (hierarchyFacts & ~excludeFacts | includeFacts) & 32767 /* AncestorFactsMask */;
-      return ancestorFacts;
-    }
-    function exitSubtree(ancestorFacts, excludeFacts, includeFacts) {
-      hierarchyFacts = (hierarchyFacts & ~excludeFacts | includeFacts) & -32768 /* SubtreeFactsMask */ | ancestorFacts;
-    }
-    function isReturnVoidStatementInConstructorWithCapturedSuper(node) {
-      return (hierarchyFacts & 8192 /* ConstructorWithCapturedSuper */) !== 0 && node.kind === 252 /* ReturnStatement */ && !node.expression;
-    }
-    function isOrMayContainReturnCompletion(node) {
-      return node.transformFlags & 4194304 /* ContainsHoistedDeclarationOrCompletion */ && (isReturnStatement(node) || isIfStatement(node) || isWithStatement(node) || isSwitchStatement(node) || isCaseBlock(node) || isCaseClause(node) || isDefaultClause(node) || isTryStatement(node) || isCatchClause(node) || isLabeledStatement(node) || isIterationStatement(
-        node,
-        /*lookInLabeledStatements*/
-        false
-      ) || isBlock(node));
-    }
-    function shouldVisitNode(node) {
-      return (node.transformFlags & 1024 /* ContainsES2015 */) !== 0 || convertedLoopState !== void 0 || hierarchyFacts & 8192 /* ConstructorWithCapturedSuper */ && isOrMayContainReturnCompletion(node) || isIterationStatement(
-        node,
-        /*lookInLabeledStatements*/
-        false
-      ) && shouldConvertIterationStatement(node) || (getInternalEmitFlags(node) & 1 /* TypeScriptClassWrapper */) !== 0;
-    }
-    function visitor(node) {
-      return shouldVisitNode(node) ? visitorWorker(
-        node,
-        /*expressionResultIsUnused*/
-        false
-      ) : node;
-    }
-    function visitorWithUnusedExpressionResult(node) {
-      return shouldVisitNode(node) ? visitorWorker(
-        node,
-        /*expressionResultIsUnused*/
-        true
-      ) : node;
-    }
-    function classWrapperStatementVisitor(node) {
-      if (shouldVisitNode(node)) {
-        const original = getOriginalNode(node);
-        if (isPropertyDeclaration(original) && hasStaticModifier(original)) {
-          const ancestorFacts = enterSubtree(
-            32670 /* StaticInitializerExcludes */,
-            16449 /* StaticInitializerIncludes */
-          );
-          const result = visitorWorker(
-            node,
-            /*expressionResultIsUnused*/
-            false
-          );
-          exitSubtree(ancestorFacts, 98304 /* FunctionSubtreeExcludes */, 0 /* None */);
-          return result;
-        }
-        return visitorWorker(
-          node,
-          /*expressionResultIsUnused*/
-          false
-        );
-      }
-      return node;
-    }
-    function callExpressionVisitor(node) {
-      if (node.kind === 108 /* SuperKeyword */) {
-        return visitSuperKeyword(
-          /*isExpressionOfCall*/
-          true
-        );
-      }
-      return visitor(node);
-    }
-    function visitorWorker(node, expressionResultIsUnused2) {
-      switch (node.kind) {
-        case 126 /* StaticKeyword */:
-          return void 0;
-        case 262 /* ClassDeclaration */:
-          return visitClassDeclaration(node);
-        case 230 /* ClassExpression */:
-          return visitClassExpression(node);
-        case 168 /* Parameter */:
-          return visitParameter(node);
-        case 261 /* FunctionDeclaration */:
-          return visitFunctionDeclaration(node);
-        case 218 /* ArrowFunction */:
-          return visitArrowFunction(node);
-        case 217 /* FunctionExpression */:
-          return visitFunctionExpression(node);
-        case 259 /* VariableDeclaration */:
-          return visitVariableDeclaration(node);
-        case 80 /* Identifier */:
-          return visitIdentifier(node);
-        case 260 /* VariableDeclarationList */:
-          return visitVariableDeclarationList(node);
-        case 254 /* SwitchStatement */:
-          return visitSwitchStatement(node);
-        case 268 /* CaseBlock */:
-          return visitCaseBlock(node);
-        case 240 /* Block */:
-          return visitBlock(
-            node,
-            /*isFunctionBody*/
-            false
-          );
-        case 251 /* BreakStatement */:
-        case 250 /* ContinueStatement */:
-          return visitBreakOrContinueStatement(node);
-        case 255 /* LabeledStatement */:
-          return visitLabeledStatement(node);
-        case 245 /* DoStatement */:
-        case 246 /* WhileStatement */:
-          return visitDoOrWhileStatement(
-            node,
-            /*outermostLabeledStatement*/
-            void 0
-          );
-        case 247 /* ForStatement */:
-          return visitForStatement(
-            node,
-            /*outermostLabeledStatement*/
-            void 0
-          );
-        case 248 /* ForInStatement */:
-          return visitForInStatement(
-            node,
-            /*outermostLabeledStatement*/
-            void 0
-          );
-        case 249 /* ForOfStatement */:
-          return visitForOfStatement(
-            node,
-            /*outermostLabeledStatement*/
-            void 0
-          );
-        case 243 /* ExpressionStatement */:
-          return visitExpressionStatement(node);
-        case 209 /* ObjectLiteralExpression */:
-          return visitObjectLiteralExpression(node);
-        case 298 /* CatchClause */:
-          return visitCatchClause(node);
-        case 303 /* ShorthandPropertyAssignment */:
-          return visitShorthandPropertyAssignment(node);
-        case 166 /* ComputedPropertyName */:
-          return visitComputedPropertyName(node);
-        case 208 /* ArrayLiteralExpression */:
-          return visitArrayLiteralExpression(node);
-        case 212 /* CallExpression */:
-          return visitCallExpression(node);
-        case 213 /* NewExpression */:
-          return visitNewExpression(node);
-        case 216 /* ParenthesizedExpression */:
-          return visitParenthesizedExpression(node, expressionResultIsUnused2);
-        case 225 /* BinaryExpression */:
-          return visitBinaryExpression(node, expressionResultIsUnused2);
-        case 360 /* CommaListExpression */:
-          return visitCommaListExpression(node, expressionResultIsUnused2);
-        case 15 /* NoSubstitutionTemplateLiteral */:
-        case 16 /* TemplateHead */:
-        case 17 /* TemplateMiddle */:
-        case 18 /* TemplateTail */:
-          return visitTemplateLiteral(node);
-        case 11 /* StringLiteral */:
-          return visitStringLiteral(node);
-        case 9 /* NumericLiteral */:
-          return visitNumericLiteral(node);
-        case 214 /* TaggedTemplateExpression */:
-          return visitTaggedTemplateExpression(node);
-        case 227 /* TemplateExpression */:
-          return visitTemplateExpression(node);
-        case 228 /* YieldExpression */:
-          return visitYieldExpression(node);
-        case 229 /* SpreadElement */:
-          return visitSpreadElement(node);
-        case 108 /* SuperKeyword */:
-          return visitSuperKeyword(
-            /*isExpressionOfCall*/
-            false
-          );
-        case 110 /* ThisKeyword */:
-          return visitThisKeyword(node);
-        case 235 /* MetaProperty */:
-          return visitMetaProperty(node);
-        case 173 /* MethodDeclaration */:
-          return visitMethodDeclaration(node);
-        case 176 /* GetAccessor */:
-        case 177 /* SetAccessor */:
-          return visitAccessorDeclaration(node);
-        case 242 /* VariableStatement */:
-          return visitVariableStatement(node);
-        case 252 /* ReturnStatement */:
-          return visitReturnStatement(node);
-        case 221 /* VoidExpression */:
-          return visitVoidExpression(node);
-        default:
-          return visitEachChild(node, visitor, context);
-      }
-    }
-    function visitSourceFile(node) {
-      const ancestorFacts = enterSubtree(8064 /* SourceFileExcludes */, 64 /* SourceFileIncludes */);
-      const prologue = [];
-      const statements = [];
-      startLexicalEnvironment();
-      const statementOffset = factory2.copyPrologue(
-        node.statements,
-        prologue,
-        /*ensureUseStrict*/
-        false,
-        visitor
-      );
-      addRange(statements, visitNodes2(node.statements, visitor, isStatement, statementOffset));
-      if (taggedTemplateStringDeclarations) {
-        statements.push(
-          factory2.createVariableStatement(
-            /*modifiers*/
-            void 0,
-            factory2.createVariableDeclarationList(taggedTemplateStringDeclarations)
-          )
-        );
-      }
-      factory2.mergeLexicalEnvironment(prologue, endLexicalEnvironment());
-      insertCaptureThisForNodeIfNeeded(prologue, node);
-      exitSubtree(ancestorFacts, 0 /* None */, 0 /* None */);
-      return factory2.updateSourceFile(
-        node,
-        setTextRange(factory2.createNodeArray(concatenate(prologue, statements)), node.statements)
-      );
-    }
-    function visitSwitchStatement(node) {
-      if (convertedLoopState !== void 0) {
-        const savedAllowedNonLabeledJumps = convertedLoopState.allowedNonLabeledJumps;
-        convertedLoopState.allowedNonLabeledJumps |= 2 /* Break */;
-        const result = visitEachChild(node, visitor, context);
-        convertedLoopState.allowedNonLabeledJumps = savedAllowedNonLabeledJumps;
-        return result;
-      }
-      return visitEachChild(node, visitor, context);
-    }
-    function visitCaseBlock(node) {
-      const ancestorFacts = enterSubtree(7104 /* BlockScopeExcludes */, 0 /* BlockScopeIncludes */);
-      const updated = visitEachChild(node, visitor, context);
-      exitSubtree(ancestorFacts, 0 /* None */, 0 /* None */);
-      return updated;
-    }
-    function returnCapturedThis(node) {
-      return setOriginalNode(factory2.createReturnStatement(factory2.createUniqueName("_this", 16 /* Optimistic */ | 32 /* FileLevel */)), node);
-    }
-    function visitReturnStatement(node) {
-      if (convertedLoopState) {
-        convertedLoopState.nonLocalJumps |= 8 /* Return */;
-        if (isReturnVoidStatementInConstructorWithCapturedSuper(node)) {
-          node = returnCapturedThis(node);
-        }
-        return factory2.createReturnStatement(
-          factory2.createObjectLiteralExpression(
-            [
-              factory2.createPropertyAssignment(
-                factory2.createIdentifier("value"),
-                node.expression ? Debug.checkDefined(visitNode(node.expression, visitor, isExpression)) : factory2.createVoidZero()
-              )
-            ]
-          )
-        );
-      } else if (isReturnVoidStatementInConstructorWithCapturedSuper(node)) {
-        return returnCapturedThis(node);
-      }
-      return visitEachChild(node, visitor, context);
-    }
-    function visitThisKeyword(node) {
-      if (hierarchyFacts & 2 /* ArrowFunction */ && !(hierarchyFacts & 16384 /* StaticInitializer */)) {
-        hierarchyFacts |= 65536 /* CapturedLexicalThis */;
-      }
-      if (convertedLoopState) {
-        if (hierarchyFacts & 2 /* ArrowFunction */) {
-          convertedLoopState.containsLexicalThis = true;
-          return node;
-        }
-        return convertedLoopState.thisName || (convertedLoopState.thisName = factory2.createUniqueName("this"));
-      }
-      return node;
-    }
-    function visitVoidExpression(node) {
-      return visitEachChild(node, visitorWithUnusedExpressionResult, context);
-    }
-    function visitIdentifier(node) {
-      if (convertedLoopState) {
-        if (resolver.isArgumentsLocalBinding(node)) {
-          return convertedLoopState.argumentsName || (convertedLoopState.argumentsName = factory2.createUniqueName("arguments"));
-        }
-      }
-      if (node.flags & 128 /* IdentifierHasExtendedUnicodeEscape */) {
-        return setOriginalNode(setTextRange(
-          factory2.createIdentifier(unescapeLeadingUnderscores(node.escapedText)),
-          node
-        ), node);
-      }
-      return node;
-    }
-    function visitBreakOrContinueStatement(node) {
-      if (convertedLoopState) {
-        const jump = node.kind === 251 /* BreakStatement */ ? 2 /* Break */ : 4 /* Continue */;
-        const canUseBreakOrContinue = node.label && convertedLoopState.labels && convertedLoopState.labels.get(idText(node.label)) || !node.label && convertedLoopState.allowedNonLabeledJumps & jump;
-        if (!canUseBreakOrContinue) {
-          let labelMarker;
-          const label = node.label;
-          if (!label) {
-            if (node.kind === 251 /* BreakStatement */) {
-              convertedLoopState.nonLocalJumps |= 2 /* Break */;
-              labelMarker = "break";
-            } else {
-              convertedLoopState.nonLocalJumps |= 4 /* Continue */;
-              labelMarker = "continue";
-            }
-          } else {
-            if (node.kind === 251 /* BreakStatement */) {
-              labelMarker = `break-${label.escapedText}`;
-              setLabeledJump(
-                convertedLoopState,
-                /*isBreak*/
-                true,
-                idText(label),
-                labelMarker
-              );
-            } else {
-              labelMarker = `continue-${label.escapedText}`;
-              setLabeledJump(
-                convertedLoopState,
-                /*isBreak*/
-                false,
-                idText(label),
-                labelMarker
-              );
-            }
-          }
-          let returnExpression = factory2.createStringLiteral(labelMarker);
-          if (convertedLoopState.loopOutParameters.length) {
-            const outParams = convertedLoopState.loopOutParameters;
-            let expr;
-            for (let i = 0; i < outParams.length; i++) {
-              const copyExpr = copyOutParameter(outParams[i], 1 /* ToOutParameter */);
-              if (i === 0) {
-                expr = copyExpr;
-              } else {
-                expr = factory2.createBinaryExpression(expr, 28 /* CommaToken */, copyExpr);
-              }
-            }
-            returnExpression = factory2.createBinaryExpression(expr, 28 /* CommaToken */, returnExpression);
-          }
-          return factory2.createReturnStatement(returnExpression);
-        }
-      }
-      return visitEachChild(node, visitor, context);
-    }
-    function visitClassDeclaration(node) {
-      const variable = factory2.createVariableDeclaration(
-        factory2.getLocalName(
-          node,
-          /*allowComments*/
-          true
-        ),
-        /*exclamationToken*/
-        void 0,
-        /*type*/
-        void 0,
-        transformClassLikeDeclarationToExpression(node)
-      );
-      setOriginalNode(variable, node);
-      const statements = [];
-      const statement = factory2.createVariableStatement(
-        /*modifiers*/
-        void 0,
-        factory2.createVariableDeclarationList([variable])
-      );
-      setOriginalNode(statement, node);
-      setTextRange(statement, node);
-      startOnNewLine(statement);
-      statements.push(statement);
-      if (hasSyntacticModifier(node, 1 /* Export */)) {
-        const exportStatement = hasSyntacticModifier(node, 1024 /* Default */) ? factory2.createExportDefault(factory2.getLocalName(node)) : factory2.createExternalModuleExport(factory2.getLocalName(node));
-        setOriginalNode(exportStatement, statement);
-        statements.push(exportStatement);
-      }
-      return singleOrMany(statements);
-    }
-    function visitClassExpression(node) {
-      return transformClassLikeDeclarationToExpression(node);
-    }
-    function transformClassLikeDeclarationToExpression(node) {
-      if (node.name) {
-        enableSubstitutionsForBlockScopedBindings();
-      }
-      const extendsClauseElement = getClassExtendsHeritageElement(node);
-      const classFunction = factory2.createFunctionExpression(
-        /*modifiers*/
-        void 0,
-        /*asteriskToken*/
-        void 0,
-        /*name*/
-        void 0,
-        /*typeParameters*/
-        void 0,
-        extendsClauseElement ? [factory2.createParameterDeclaration(
-          /*modifiers*/
-          void 0,
-          /*dotDotDotToken*/
-          void 0,
-          factory2.createUniqueName("_super", 16 /* Optimistic */ | 32 /* FileLevel */)
-        )] : [],
-        /*type*/
-        void 0,
-        transformClassBody(node, extendsClauseElement)
-      );
-      setEmitFlags(classFunction, getEmitFlags(node) & 131072 /* Indented */ | 1048576 /* ReuseTempVariableScope */);
-      const inner = factory2.createPartiallyEmittedExpression(classFunction);
-      setTextRangeEnd(inner, node.end);
-      setEmitFlags(inner, 3072 /* NoComments */);
-      const outer = factory2.createPartiallyEmittedExpression(inner);
-      setTextRangeEnd(outer, skipTrivia(currentText, node.pos));
-      setEmitFlags(outer, 3072 /* NoComments */);
-      const result = factory2.createParenthesizedExpression(
-        factory2.createCallExpression(
-          outer,
-          /*typeArguments*/
-          void 0,
-          extendsClauseElement ? [Debug.checkDefined(visitNode(extendsClauseElement.expression, visitor, isExpression))] : []
-        )
-      );
-      addSyntheticLeadingComment(result, 3 /* MultiLineCommentTrivia */, "* @class ");
-      return result;
-    }
-    function transformClassBody(node, extendsClauseElement) {
-      const statements = [];
-      const name = factory2.getInternalName(node);
-      const constructorLikeName = isIdentifierANonContextualKeyword(name) ? factory2.getGeneratedNameForNode(name) : name;
-      startLexicalEnvironment();
-      addExtendsHelperIfNeeded(statements, node, extendsClauseElement);
-      addConstructor(statements, node, constructorLikeName, extendsClauseElement);
-      addClassMembers(statements, node);
-      const closingBraceLocation = createTokenRange(skipTrivia(currentText, node.members.end), 20 /* CloseBraceToken */);
-      const outer = factory2.createPartiallyEmittedExpression(constructorLikeName);
-      setTextRangeEnd(outer, closingBraceLocation.end);
-      setEmitFlags(outer, 3072 /* NoComments */);
-      const statement = factory2.createReturnStatement(outer);
-      setTextRangePos(statement, closingBraceLocation.pos);
-      setEmitFlags(statement, 3072 /* NoComments */ | 768 /* NoTokenSourceMaps */);
-      statements.push(statement);
-      insertStatementsAfterStandardPrologue(statements, endLexicalEnvironment());
-      const block = factory2.createBlock(
-        setTextRange(
-          factory2.createNodeArray(statements),
-          /*location*/
-          node.members
-        ),
-        /*multiLine*/
-        true
-      );
-      setEmitFlags(block, 3072 /* NoComments */);
-      return block;
-    }
-    function addExtendsHelperIfNeeded(statements, node, extendsClauseElement) {
-      if (extendsClauseElement) {
-        statements.push(
-          setTextRange(
-            factory2.createExpressionStatement(
-              emitHelpers().createExtendsHelper(factory2.getInternalName(node))
-            ),
-            /*location*/
-            extendsClauseElement
-          )
-        );
-      }
-    }
-    function addConstructor(statements, node, name, extendsClauseElement) {
-      const savedConvertedLoopState = convertedLoopState;
-      convertedLoopState = void 0;
-      const ancestorFacts = enterSubtree(32662 /* ConstructorExcludes */, 73 /* ConstructorIncludes */);
-      const constructor = getFirstConstructorWithBody(node);
-      const hasSynthesizedSuper = hasSynthesizedDefaultSuperCall(constructor, extendsClauseElement !== void 0);
-      const constructorFunction = factory2.createFunctionDeclaration(
-        /*modifiers*/
-        void 0,
-        /*asteriskToken*/
-        void 0,
-        name,
-        /*typeParameters*/
-        void 0,
-        transformConstructorParameters(constructor, hasSynthesizedSuper),
-        /*type*/
-        void 0,
-        transformConstructorBody(constructor, node, extendsClauseElement, hasSynthesizedSuper)
-      );
-      setTextRange(constructorFunction, constructor || node);
-      if (extendsClauseElement) {
-        setEmitFlags(constructorFunction, 16 /* CapturesThis */);
-      }
-      statements.push(constructorFunction);
-      exitSubtree(ancestorFacts, 98304 /* FunctionSubtreeExcludes */, 0 /* None */);
-      convertedLoopState = savedConvertedLoopState;
-    }
-    function transformConstructorParameters(constructor, hasSynthesizedSuper) {
-      return visitParameterList(constructor && !hasSynthesizedSuper ? constructor.parameters : void 0, visitor, context) || [];
-    }
-    function createDefaultConstructorBody(node, isDerivedClass) {
-      const statements = [];
-      resumeLexicalEnvironment();
-      factory2.mergeLexicalEnvironment(statements, endLexicalEnvironment());
-      if (isDerivedClass) {
-        statements.push(factory2.createReturnStatement(createDefaultSuperCallOrThis()));
-      }
-      const statementsArray = factory2.createNodeArray(statements);
-      setTextRange(statementsArray, node.members);
-      const block = factory2.createBlock(
-        statementsArray,
-        /*multiLine*/
-        true
-      );
-      setTextRange(block, node);
-      setEmitFlags(block, 3072 /* NoComments */);
-      return block;
-    }
-    function transformConstructorBody(constructor, node, extendsClauseElement, hasSynthesizedSuper) {
-      const isDerivedClass = !!extendsClauseElement && skipOuterExpressions(extendsClauseElement.expression).kind !== 106 /* NullKeyword */;
-      if (!constructor)
-        return createDefaultConstructorBody(node, isDerivedClass);
-      const prologue = [];
-      const statements = [];
-      resumeLexicalEnvironment();
-      const existingPrologue = takeWhile(constructor.body.statements, isPrologueDirective);
-      const { superCall, superStatementIndex } = findSuperCallAndStatementIndex(constructor.body.statements, existingPrologue);
-      const postSuperStatementsStart = superStatementIndex === -1 ? existingPrologue.length : superStatementIndex + 1;
-      let statementOffset = postSuperStatementsStart;
-      if (!hasSynthesizedSuper)
-        statementOffset = factory2.copyStandardPrologue(
-          constructor.body.statements,
-          prologue,
-          statementOffset,
-          /*ensureUseStrict*/
-          false
-        );
-      if (!hasSynthesizedSuper)
-        statementOffset = factory2.copyCustomPrologue(
-          constructor.body.statements,
-          statements,
-          statementOffset,
-          visitor,
-          /*filter*/
-          void 0
-        );
-      let superCallExpression;
-      if (hasSynthesizedSuper) {
-        superCallExpression = createDefaultSuperCallOrThis();
-      } else if (superCall) {
-        superCallExpression = visitSuperCallInBody(superCall);
-      }
-      if (superCallExpression) {
-        hierarchyFacts |= 8192 /* ConstructorWithCapturedSuper */;
-      }
-      addDefaultValueAssignmentsIfNeeded2(prologue, constructor);
-      addRestParameterIfNeeded(prologue, constructor, hasSynthesizedSuper);
-      addRange(statements, visitNodes2(
-        constructor.body.statements,
-        visitor,
-        isStatement,
-        /*start*/
-        statementOffset
-      ));
-      factory2.mergeLexicalEnvironment(prologue, endLexicalEnvironment());
-      insertCaptureNewTargetIfNeeded(
-        prologue,
-        constructor,
-        /*copyOnWrite*/
-        false
-      );
-      if (isDerivedClass || superCallExpression) {
-        if (superCallExpression && postSuperStatementsStart === constructor.body.statements.length && !(constructor.body.transformFlags & 16384 /* ContainsLexicalThis */)) {
-          const superCall2 = cast(cast(superCallExpression, isBinaryExpression).left, isCallExpression);
-          const returnStatement = factory2.createReturnStatement(superCallExpression);
-          setCommentRange(returnStatement, getCommentRange(superCall2));
-          setEmitFlags(superCall2, 3072 /* NoComments */);
-          statements.push(returnStatement);
-        } else {
-          if (superStatementIndex <= existingPrologue.length) {
-            insertCaptureThisForNode(statements, constructor, superCallExpression || createActualThis());
-          } else {
-            insertCaptureThisForNode(prologue, constructor, createActualThis());
-            if (superCallExpression) {
-              insertSuperThisCaptureThisForNode(statements, superCallExpression);
-            }
-          }
-          if (!isSufficientlyCoveredByReturnStatements(constructor.body)) {
-            statements.push(factory2.createReturnStatement(factory2.createUniqueName("_this", 16 /* Optimistic */ | 32 /* FileLevel */)));
-          }
-        }
-      } else {
-        insertCaptureThisForNodeIfNeeded(prologue, constructor);
-      }
-      const body = factory2.createBlock(
-        setTextRange(
-          factory2.createNodeArray(
-            [
-              ...existingPrologue,
-              ...prologue,
-              ...superStatementIndex <= existingPrologue.length ? emptyArray : visitNodes2(constructor.body.statements, visitor, isStatement, existingPrologue.length, superStatementIndex - existingPrologue.length),
-              ...statements
-            ]
-          ),
-          /*location*/
-          constructor.body.statements
-        ),
-        /*multiLine*/
-        true
-      );
-      setTextRange(body, constructor.body);
-      return body;
-    }
-    function findSuperCallAndStatementIndex(originalBodyStatements, existingPrologue) {
-      for (let i = existingPrologue.length; i < originalBodyStatements.length; i += 1) {
-        const superCall = getSuperCallFromStatement(originalBodyStatements[i]);
-        if (superCall) {
-          return {
-            superCall,
-            superStatementIndex: i
-          };
-        }
-      }
-      return {
-        superStatementIndex: -1
-      };
-    }
-    function isSufficientlyCoveredByReturnStatements(statement) {
-      if (statement.kind === 252 /* ReturnStatement */) {
-        return true;
-      } else if (statement.kind === 244 /* IfStatement */) {
-        const ifStatement = statement;
-        if (ifStatement.elseStatement) {
-          return isSufficientlyCoveredByReturnStatements(ifStatement.thenStatement) && isSufficientlyCoveredByReturnStatements(ifStatement.elseStatement);
-        }
-      } else if (statement.kind === 240 /* Block */) {
-        const lastStatement = lastOrUndefined(statement.statements);
-        if (lastStatement && isSufficientlyCoveredByReturnStatements(lastStatement)) {
-          return true;
-        }
-      }
-      return false;
-    }
-    function createActualThis() {
-      return setEmitFlags(factory2.createThis(), 8 /* NoSubstitution */);
-    }
-    function createDefaultSuperCallOrThis() {
-      return factory2.createLogicalOr(
-        factory2.createLogicalAnd(
-          factory2.createStrictInequality(
-            factory2.createUniqueName("_super", 16 /* Optimistic */ | 32 /* FileLevel */),
-            factory2.createNull()
-          ),
-          factory2.createFunctionApplyCall(
-            factory2.createUniqueName("_super", 16 /* Optimistic */ | 32 /* FileLevel */),
-            createActualThis(),
-            factory2.createIdentifier("arguments")
-          )
-        ),
-        createActualThis()
-      );
-    }
-    function visitParameter(node) {
-      if (node.dotDotDotToken) {
-        return void 0;
-      } else if (isBindingPattern(node.name)) {
-        return setOriginalNode(
-          setTextRange(
-            factory2.createParameterDeclaration(
-              /*modifiers*/
-              void 0,
-              /*dotDotDotToken*/
-              void 0,
-              factory2.getGeneratedNameForNode(node),
-              /*questionToken*/
-              void 0,
-              /*type*/
-              void 0,
-              /*initializer*/
-              void 0
-            ),
-            /*location*/
-            node
-          ),
-          /*original*/
-          node
-        );
-      } else if (node.initializer) {
-        return setOriginalNode(
-          setTextRange(
-            factory2.createParameterDeclaration(
-              /*modifiers*/
-              void 0,
-              /*dotDotDotToken*/
-              void 0,
-              node.name,
-              /*questionToken*/
-              void 0,
-              /*type*/
-              void 0,
-              /*initializer*/
-              void 0
-            ),
-            /*location*/
-            node
-          ),
-          /*original*/
-          node
-        );
-      } else {
-        return node;
-      }
-    }
-    function hasDefaultValueOrBindingPattern(node) {
-      return node.initializer !== void 0 || isBindingPattern(node.name);
-    }
-    function addDefaultValueAssignmentsIfNeeded2(statements, node) {
-      if (!some(node.parameters, hasDefaultValueOrBindingPattern)) {
-        return false;
-      }
-      let added = false;
-      for (const parameter of node.parameters) {
-        const { name, initializer, dotDotDotToken } = parameter;
-        if (dotDotDotToken) {
-          continue;
-        }
-        if (isBindingPattern(name)) {
-          added = insertDefaultValueAssignmentForBindingPattern(statements, parameter, name, initializer) || added;
-        } else if (initializer) {
-          insertDefaultValueAssignmentForInitializer(statements, parameter, name, initializer);
-          added = true;
-        }
-      }
-      return added;
-    }
-    function insertDefaultValueAssignmentForBindingPattern(statements, parameter, name, initializer) {
-      if (name.elements.length > 0) {
-        insertStatementAfterCustomPrologue(
-          statements,
-          setEmitFlags(
-            factory2.createVariableStatement(
-              /*modifiers*/
-              void 0,
-              factory2.createVariableDeclarationList(
-                flattenDestructuringBinding(
-                  parameter,
-                  visitor,
-                  context,
-                  0 /* All */,
-                  factory2.getGeneratedNameForNode(parameter)
-                )
-              )
-            ),
-            2097152 /* CustomPrologue */
-          )
-        );
-        return true;
-      } else if (initializer) {
-        insertStatementAfterCustomPrologue(
-          statements,
-          setEmitFlags(
-            factory2.createExpressionStatement(
-              factory2.createAssignment(
-                factory2.getGeneratedNameForNode(parameter),
-                Debug.checkDefined(visitNode(initializer, visitor, isExpression))
-              )
-            ),
-            2097152 /* CustomPrologue */
-          )
-        );
-        return true;
-      }
-      return false;
-    }
-    function insertDefaultValueAssignmentForInitializer(statements, parameter, name, initializer) {
-      initializer = Debug.checkDefined(visitNode(initializer, visitor, isExpression));
-      const statement = factory2.createIfStatement(
-        factory2.createTypeCheck(factory2.cloneNode(name), "undefined"),
-        setEmitFlags(
-          setTextRange(
-            factory2.createBlock([
-              factory2.createExpressionStatement(
-                setEmitFlags(
-                  setTextRange(
-                    factory2.createAssignment(
-                      // TODO(rbuckton): Does this need to be parented?
-                      setEmitFlags(setParent(setTextRange(factory2.cloneNode(name), name), name.parent), 96 /* NoSourceMap */),
-                      setEmitFlags(initializer, 96 /* NoSourceMap */ | getEmitFlags(initializer) | 3072 /* NoComments */)
-                    ),
-                    parameter
-                  ),
-                  3072 /* NoComments */
-                )
-              )
-            ]),
-            parameter
-          ),
-          1 /* SingleLine */ | 64 /* NoTrailingSourceMap */ | 768 /* NoTokenSourceMaps */ | 3072 /* NoComments */
-        )
-      );
-      startOnNewLine(statement);
-      setTextRange(statement, parameter);
-      setEmitFlags(statement, 768 /* NoTokenSourceMaps */ | 64 /* NoTrailingSourceMap */ | 2097152 /* CustomPrologue */ | 3072 /* NoComments */);
-      insertStatementAfterCustomPrologue(statements, statement);
-    }
-    function shouldAddRestParameter(node, inConstructorWithSynthesizedSuper) {
-      return !!(node && node.dotDotDotToken && !inConstructorWithSynthesizedSuper);
-    }
-    function addRestParameterIfNeeded(statements, node, inConstructorWithSynthesizedSuper) {
-      const prologueStatements = [];
-      const parameter = lastOrUndefined(node.parameters);
-      if (!shouldAddRestParameter(parameter, inConstructorWithSynthesizedSuper)) {
-        return false;
-      }
-      const declarationName = parameter.name.kind === 80 /* Identifier */ ? setParent(setTextRange(factory2.cloneNode(parameter.name), parameter.name), parameter.name.parent) : factory2.createTempVariable(
-        /*recordTempVariable*/
-        void 0
-      );
-      setEmitFlags(declarationName, 96 /* NoSourceMap */);
-      const expressionName = parameter.name.kind === 80 /* Identifier */ ? factory2.cloneNode(parameter.name) : declarationName;
-      const restIndex = node.parameters.length - 1;
-      const temp = factory2.createLoopVariable();
-      prologueStatements.push(
-        setEmitFlags(
-          setTextRange(
-            factory2.createVariableStatement(
-              /*modifiers*/
-              void 0,
-              factory2.createVariableDeclarationList([
-                factory2.createVariableDeclaration(
-                  declarationName,
-                  /*exclamationToken*/
-                  void 0,
-                  /*type*/
-                  void 0,
-                  factory2.createArrayLiteralExpression([])
-                )
-              ])
-            ),
-            /*location*/
-            parameter
-          ),
-          2097152 /* CustomPrologue */
-        )
-      );
-      const forStatement = factory2.createForStatement(
-        setTextRange(
-          factory2.createVariableDeclarationList([
-            factory2.createVariableDeclaration(
-              temp,
-              /*exclamationToken*/
-              void 0,
-              /*type*/
-              void 0,
-              factory2.createNumericLiteral(restIndex)
-            )
-          ]),
-          parameter
-        ),
-        setTextRange(
-          factory2.createLessThan(
-            temp,
-            factory2.createPropertyAccessExpression(factory2.createIdentifier("arguments"), "length")
-          ),
-          parameter
-        ),
-        setTextRange(factory2.createPostfixIncrement(temp), parameter),
-        factory2.createBlock([
-          startOnNewLine(
-            setTextRange(
-              factory2.createExpressionStatement(
-                factory2.createAssignment(
-                  factory2.createElementAccessExpression(
-                    expressionName,
-                    restIndex === 0 ? temp : factory2.createSubtract(temp, factory2.createNumericLiteral(restIndex))
-                  ),
-                  factory2.createElementAccessExpression(factory2.createIdentifier("arguments"), temp)
-                )
-              ),
-              /*location*/
-              parameter
-            )
-          )
-        ])
-      );
-      setEmitFlags(forStatement, 2097152 /* CustomPrologue */);
-      startOnNewLine(forStatement);
-      prologueStatements.push(forStatement);
-      if (parameter.name.kind !== 80 /* Identifier */) {
-        prologueStatements.push(
-          setEmitFlags(
-            setTextRange(
-              factory2.createVariableStatement(
-                /*modifiers*/
-                void 0,
-                factory2.createVariableDeclarationList(
-                  flattenDestructuringBinding(parameter, visitor, context, 0 /* All */, expressionName)
-                )
-              ),
-              parameter
-            ),
-            2097152 /* CustomPrologue */
-          )
-        );
-      }
-      insertStatementsAfterCustomPrologue(statements, prologueStatements);
-      return true;
-    }
-    function insertCaptureThisForNodeIfNeeded(statements, node) {
-      if (hierarchyFacts & 65536 /* CapturedLexicalThis */ && node.kind !== 218 /* ArrowFunction */) {
-        insertCaptureThisForNode(statements, node, factory2.createThis());
-        return true;
-      }
-      return false;
-    }
-    function insertSuperThisCaptureThisForNode(statements, superExpression) {
-      enableSubstitutionsForCapturedThis();
-      const assignSuperExpression = factory2.createExpressionStatement(
-        factory2.createBinaryExpression(
-          factory2.createThis(),
-          64 /* EqualsToken */,
-          superExpression
-        )
-      );
-      insertStatementAfterCustomPrologue(statements, assignSuperExpression);
-      setCommentRange(assignSuperExpression, getOriginalNode(superExpression).parent);
-    }
-    function insertCaptureThisForNode(statements, node, initializer) {
-      enableSubstitutionsForCapturedThis();
-      const captureThisStatement = factory2.createVariableStatement(
-        /*modifiers*/
-        void 0,
-        factory2.createVariableDeclarationList([
-          factory2.createVariableDeclaration(
-            factory2.createUniqueName("_this", 16 /* Optimistic */ | 32 /* FileLevel */),
-            /*exclamationToken*/
-            void 0,
-            /*type*/
-            void 0,
-            initializer
-          )
-        ])
-      );
-      setEmitFlags(captureThisStatement, 3072 /* NoComments */ | 2097152 /* CustomPrologue */);
-      setSourceMapRange(captureThisStatement, node);
-      insertStatementAfterCustomPrologue(statements, captureThisStatement);
-    }
-    function insertCaptureNewTargetIfNeeded(statements, node, copyOnWrite) {
-      if (hierarchyFacts & 32768 /* NewTarget */) {
-        let newTarget;
-        switch (node.kind) {
-          case 218 /* ArrowFunction */:
-            return statements;
-          case 173 /* MethodDeclaration */:
-          case 176 /* GetAccessor */:
-          case 177 /* SetAccessor */:
-            newTarget = factory2.createVoidZero();
-            break;
-          case 175 /* Constructor */:
-            newTarget = factory2.createPropertyAccessExpression(
-              setEmitFlags(factory2.createThis(), 8 /* NoSubstitution */),
-              "constructor"
-            );
-            break;
-          case 261 /* FunctionDeclaration */:
-          case 217 /* FunctionExpression */:
-            newTarget = factory2.createConditionalExpression(
-              factory2.createLogicalAnd(
-                setEmitFlags(factory2.createThis(), 8 /* NoSubstitution */),
-                factory2.createBinaryExpression(
-                  setEmitFlags(factory2.createThis(), 8 /* NoSubstitution */),
-                  104 /* InstanceOfKeyword */,
-                  factory2.getLocalName(node)
-                )
-              ),
-              /*questionToken*/
-              void 0,
-              factory2.createPropertyAccessExpression(
-                setEmitFlags(factory2.createThis(), 8 /* NoSubstitution */),
-                "constructor"
-              ),
-              /*colonToken*/
-              void 0,
-              factory2.createVoidZero()
-            );
-            break;
-          default:
-            return Debug.failBadSyntaxKind(node);
-        }
-        const captureNewTargetStatement = factory2.createVariableStatement(
-          /*modifiers*/
-          void 0,
-          factory2.createVariableDeclarationList([
-            factory2.createVariableDeclaration(
-              factory2.createUniqueName("_newTarget", 16 /* Optimistic */ | 32 /* FileLevel */),
-              /*exclamationToken*/
-              void 0,
-              /*type*/
-              void 0,
-              newTarget
-            )
-          ])
-        );
-        setEmitFlags(captureNewTargetStatement, 3072 /* NoComments */ | 2097152 /* CustomPrologue */);
-        if (copyOnWrite) {
-          statements = statements.slice();
-        }
-        insertStatementAfterCustomPrologue(statements, captureNewTargetStatement);
-      }
-      return statements;
-    }
-    function addClassMembers(statements, node) {
-      for (const member of node.members) {
-        switch (member.kind) {
-          case 239 /* SemicolonClassElement */:
-            statements.push(transformSemicolonClassElementToStatement(member));
-            break;
-          case 173 /* MethodDeclaration */:
-            statements.push(transformClassMethodDeclarationToStatement(getClassMemberPrefix(node, member), member, node));
-            break;
-          case 176 /* GetAccessor */:
-          case 177 /* SetAccessor */:
-            const accessors = getAllAccessorDeclarations(node.members, member);
-            if (member === accessors.firstAccessor) {
-              statements.push(transformAccessorsToStatement(getClassMemberPrefix(node, member), accessors, node));
-            }
-            break;
-          case 175 /* Constructor */:
-          case 174 /* ClassStaticBlockDeclaration */:
-            break;
-          default:
-            Debug.failBadSyntaxKind(member, currentSourceFile && currentSourceFile.fileName);
-            break;
-        }
-      }
-    }
-    function transformSemicolonClassElementToStatement(member) {
-      return setTextRange(factory2.createEmptyStatement(), member);
-    }
-    function transformClassMethodDeclarationToStatement(receiver, member, container) {
-      const commentRange = getCommentRange(member);
-      const sourceMapRange = getSourceMapRange(member);
-      const memberFunction = transformFunctionLikeToExpression(
-        member,
-        /*location*/
-        member,
-        /*name*/
-        void 0,
-        container
-      );
-      const propertyName = visitNode(member.name, visitor, isPropertyName);
-      Debug.assert(propertyName);
-      let e;
-      if (!isPrivateIdentifier(propertyName) && getUseDefineForClassFields(context.getCompilerOptions())) {
-        const name = isComputedPropertyName(propertyName) ? propertyName.expression : isIdentifier(propertyName) ? factory2.createStringLiteral(unescapeLeadingUnderscores(propertyName.escapedText)) : propertyName;
-        e = factory2.createObjectDefinePropertyCall(receiver, name, factory2.createPropertyDescriptor({ value: memberFunction, enumerable: false, writable: true, configurable: true }));
-      } else {
-        const memberName = createMemberAccessForPropertyName(
-          factory2,
-          receiver,
-          propertyName,
-          /*location*/
-          member.name
-        );
-        e = factory2.createAssignment(memberName, memberFunction);
-      }
-      setEmitFlags(memberFunction, 3072 /* NoComments */);
-      setSourceMapRange(memberFunction, sourceMapRange);
-      const statement = setTextRange(
-        factory2.createExpressionStatement(e),
-        /*location*/
-        member
-      );
-      setOriginalNode(statement, member);
-      setCommentRange(statement, commentRange);
-      setEmitFlags(statement, 96 /* NoSourceMap */);
-      return statement;
-    }
-    function transformAccessorsToStatement(receiver, accessors, container) {
-      const statement = factory2.createExpressionStatement(transformAccessorsToExpression(
-        receiver,
-        accessors,
-        container,
-        /*startsOnNewLine*/
-        false
-      ));
-      setEmitFlags(statement, 3072 /* NoComments */);
-      setSourceMapRange(statement, getSourceMapRange(accessors.firstAccessor));
-      return statement;
-    }
-    function transformAccessorsToExpression(receiver, { firstAccessor, getAccessor, setAccessor }, container, startsOnNewLine) {
-      const target = setParent(setTextRange(factory2.cloneNode(receiver), receiver), receiver.parent);
-      setEmitFlags(target, 3072 /* NoComments */ | 64 /* NoTrailingSourceMap */);
-      setSourceMapRange(target, firstAccessor.name);
-      const visitedAccessorName = visitNode(firstAccessor.name, visitor, isPropertyName);
-      Debug.assert(visitedAccessorName);
-      if (isPrivateIdentifier(visitedAccessorName)) {
-        return Debug.failBadSyntaxKind(visitedAccessorName, "Encountered unhandled private identifier while transforming ES2015.");
-      }
-      const propertyName = createExpressionForPropertyName(factory2, visitedAccessorName);
-      setEmitFlags(propertyName, 3072 /* NoComments */ | 32 /* NoLeadingSourceMap */);
-      setSourceMapRange(propertyName, firstAccessor.name);
-      const properties = [];
-      if (getAccessor) {
-        const getterFunction = transformFunctionLikeToExpression(
-          getAccessor,
-          /*location*/
-          void 0,
-          /*name*/
-          void 0,
-          container
-        );
-        setSourceMapRange(getterFunction, getSourceMapRange(getAccessor));
-        setEmitFlags(getterFunction, 1024 /* NoLeadingComments */);
-        const getter = factory2.createPropertyAssignment("get", getterFunction);
-        setCommentRange(getter, getCommentRange(getAccessor));
-        properties.push(getter);
-      }
-      if (setAccessor) {
-        const setterFunction = transformFunctionLikeToExpression(
-          setAccessor,
-          /*location*/
-          void 0,
-          /*name*/
-          void 0,
-          container
-        );
-        setSourceMapRange(setterFunction, getSourceMapRange(setAccessor));
-        setEmitFlags(setterFunction, 1024 /* NoLeadingComments */);
-        const setter = factory2.createPropertyAssignment("set", setterFunction);
-        setCommentRange(setter, getCommentRange(setAccessor));
-        properties.push(setter);
-      }
-      properties.push(
-        factory2.createPropertyAssignment("enumerable", getAccessor || setAccessor ? factory2.createFalse() : factory2.createTrue()),
-        factory2.createPropertyAssignment("configurable", factory2.createTrue())
-      );
-      const call = factory2.createCallExpression(
-        factory2.createPropertyAccessExpression(factory2.createIdentifier("Object"), "defineProperty"),
-        /*typeArguments*/
-        void 0,
-        [
-          target,
-          propertyName,
-          factory2.createObjectLiteralExpression(
-            properties,
-            /*multiLine*/
-            true
-          )
-        ]
-      );
-      if (startsOnNewLine) {
-        startOnNewLine(call);
-      }
-      return call;
-    }
-    function visitArrowFunction(node) {
-      if (node.transformFlags & 16384 /* ContainsLexicalThis */ && !(hierarchyFacts & 16384 /* StaticInitializer */)) {
-        hierarchyFacts |= 65536 /* CapturedLexicalThis */;
-      }
-      const savedConvertedLoopState = convertedLoopState;
-      convertedLoopState = void 0;
-      const ancestorFacts = enterSubtree(15232 /* ArrowFunctionExcludes */, 66 /* ArrowFunctionIncludes */);
-      const func = factory2.createFunctionExpression(
-        /*modifiers*/
-        void 0,
-        /*asteriskToken*/
-        void 0,
-        /*name*/
-        void 0,
-        /*typeParameters*/
-        void 0,
-        visitParameterList(node.parameters, visitor, context),
-        /*type*/
-        void 0,
-        transformFunctionBody2(node)
-      );
-      setTextRange(func, node);
-      setOriginalNode(func, node);
-      setEmitFlags(func, 16 /* CapturesThis */);
-      exitSubtree(ancestorFacts, 0 /* ArrowFunctionSubtreeExcludes */, 0 /* None */);
-      convertedLoopState = savedConvertedLoopState;
-      return func;
-    }
-    function visitFunctionExpression(node) {
-      const ancestorFacts = getEmitFlags(node) & 524288 /* AsyncFunctionBody */ ? enterSubtree(32662 /* AsyncFunctionBodyExcludes */, 69 /* AsyncFunctionBodyIncludes */) : enterSubtree(32670 /* FunctionExcludes */, 65 /* FunctionIncludes */);
-      const savedConvertedLoopState = convertedLoopState;
-      convertedLoopState = void 0;
-      const parameters = visitParameterList(node.parameters, visitor, context);
-      const body = transformFunctionBody2(node);
-      const name = hierarchyFacts & 32768 /* NewTarget */ ? factory2.getLocalName(node) : node.name;
-      exitSubtree(ancestorFacts, 98304 /* FunctionSubtreeExcludes */, 0 /* None */);
-      convertedLoopState = savedConvertedLoopState;
-      return factory2.updateFunctionExpression(
-        node,
-        /*modifiers*/
-        void 0,
-        node.asteriskToken,
-        name,
-        /*typeParameters*/
-        void 0,
-        parameters,
-        /*type*/
-        void 0,
-        body
-      );
-    }
-    function visitFunctionDeclaration(node) {
-      const savedConvertedLoopState = convertedLoopState;
-      convertedLoopState = void 0;
-      const ancestorFacts = enterSubtree(32670 /* FunctionExcludes */, 65 /* FunctionIncludes */);
-      const parameters = visitParameterList(node.parameters, visitor, context);
-      const body = transformFunctionBody2(node);
-      const name = hierarchyFacts & 32768 /* NewTarget */ ? factory2.getLocalName(node) : node.name;
-      exitSubtree(ancestorFacts, 98304 /* FunctionSubtreeExcludes */, 0 /* None */);
-      convertedLoopState = savedConvertedLoopState;
-      return factory2.updateFunctionDeclaration(
-        node,
-        visitNodes2(node.modifiers, visitor, isModifier),
-        node.asteriskToken,
-        name,
-        /*typeParameters*/
-        void 0,
-        parameters,
-        /*type*/
-        void 0,
-        body
-      );
-    }
-    function transformFunctionLikeToExpression(node, location, name, container) {
-      const savedConvertedLoopState = convertedLoopState;
-      convertedLoopState = void 0;
-      const ancestorFacts = container && isClassLike(container) && !isStatic(node) ? enterSubtree(32670 /* FunctionExcludes */, 65 /* FunctionIncludes */ | 8 /* NonStaticClassElement */) : enterSubtree(32670 /* FunctionExcludes */, 65 /* FunctionIncludes */);
-      const parameters = visitParameterList(node.parameters, visitor, context);
-      const body = transformFunctionBody2(node);
-      if (hierarchyFacts & 32768 /* NewTarget */ && !name && (node.kind === 261 /* FunctionDeclaration */ || node.kind === 217 /* FunctionExpression */)) {
-        name = factory2.getGeneratedNameForNode(node);
-      }
-      exitSubtree(ancestorFacts, 98304 /* FunctionSubtreeExcludes */, 0 /* None */);
-      convertedLoopState = savedConvertedLoopState;
-      return setOriginalNode(
-        setTextRange(
-          factory2.createFunctionExpression(
-            /*modifiers*/
-            void 0,
-            node.asteriskToken,
-            name,
-            /*typeParameters*/
-            void 0,
-            parameters,
-            /*type*/
-            void 0,
-            body
-          ),
-          location
-        ),
-        /*original*/
-        node
-      );
-    }
-    function transformFunctionBody2(node) {
-      let multiLine = false;
-      let singleLine = false;
-      let statementsLocation;
-      let closeBraceLocation;
-      const prologue = [];
-      const statements = [];
-      const body = node.body;
-      let statementOffset;
-      resumeLexicalEnvironment();
-      if (isBlock(body)) {
-        statementOffset = factory2.copyStandardPrologue(
-          body.statements,
-          prologue,
-          0,
-          /*ensureUseStrict*/
-          false
-        );
-        statementOffset = factory2.copyCustomPrologue(body.statements, statements, statementOffset, visitor, isHoistedFunction);
-        statementOffset = factory2.copyCustomPrologue(body.statements, statements, statementOffset, visitor, isHoistedVariableStatement);
-      }
-      multiLine = addDefaultValueAssignmentsIfNeeded2(statements, node) || multiLine;
-      multiLine = addRestParameterIfNeeded(
-        statements,
-        node,
-        /*inConstructorWithSynthesizedSuper*/
-        false
-      ) || multiLine;
-      if (isBlock(body)) {
-        statementOffset = factory2.copyCustomPrologue(body.statements, statements, statementOffset, visitor);
-        statementsLocation = body.statements;
-        addRange(statements, visitNodes2(body.statements, visitor, isStatement, statementOffset));
-        if (!multiLine && body.multiLine) {
-          multiLine = true;
-        }
-      } else {
-        Debug.assert(node.kind === 218 /* ArrowFunction */);
-        statementsLocation = moveRangeEnd(body, -1);
-        const equalsGreaterThanToken = node.equalsGreaterThanToken;
-        if (!nodeIsSynthesized(equalsGreaterThanToken) && !nodeIsSynthesized(body)) {
-          if (rangeEndIsOnSameLineAsRangeStart(equalsGreaterThanToken, body, currentSourceFile)) {
-            singleLine = true;
-          } else {
-            multiLine = true;
-          }
-        }
-        const expression = visitNode(body, visitor, isExpression);
-        const returnStatement = factory2.createReturnStatement(expression);
-        setTextRange(returnStatement, body);
-        moveSyntheticComments(returnStatement, body);
-        setEmitFlags(returnStatement, 768 /* NoTokenSourceMaps */ | 64 /* NoTrailingSourceMap */ | 2048 /* NoTrailingComments */);
-        statements.push(returnStatement);
-        closeBraceLocation = body;
-      }
-      factory2.mergeLexicalEnvironment(prologue, endLexicalEnvironment());
-      insertCaptureNewTargetIfNeeded(
-        prologue,
-        node,
-        /*copyOnWrite*/
-        false
-      );
-      insertCaptureThisForNodeIfNeeded(prologue, node);
-      if (some(prologue)) {
-        multiLine = true;
-      }
-      statements.unshift(...prologue);
-      if (isBlock(body) && arrayIsEqualTo(statements, body.statements)) {
-        return body;
-      }
-      const block = factory2.createBlock(setTextRange(factory2.createNodeArray(statements), statementsLocation), multiLine);
-      setTextRange(block, node.body);
-      if (!multiLine && singleLine) {
-        setEmitFlags(block, 1 /* SingleLine */);
-      }
-      if (closeBraceLocation) {
-        setTokenSourceMapRange(block, 20 /* CloseBraceToken */, closeBraceLocation);
-      }
-      setOriginalNode(block, node.body);
-      return block;
-    }
-    function visitBlock(node, isFunctionBody2) {
-      if (isFunctionBody2) {
-        return visitEachChild(node, visitor, context);
-      }
-      const ancestorFacts = hierarchyFacts & 256 /* IterationStatement */ ? enterSubtree(7104 /* IterationStatementBlockExcludes */, 512 /* IterationStatementBlockIncludes */) : enterSubtree(6976 /* BlockExcludes */, 128 /* BlockIncludes */);
-      const updated = visitEachChild(node, visitor, context);
-      exitSubtree(ancestorFacts, 0 /* None */, 0 /* None */);
-      return updated;
-    }
-    function visitExpressionStatement(node) {
-      return visitEachChild(node, visitorWithUnusedExpressionResult, context);
-    }
-    function visitParenthesizedExpression(node, expressionResultIsUnused2) {
-      return visitEachChild(node, expressionResultIsUnused2 ? visitorWithUnusedExpressionResult : visitor, context);
-    }
-    function visitBinaryExpression(node, expressionResultIsUnused2) {
-      if (isDestructuringAssignment(node)) {
-        return flattenDestructuringAssignment(
-          node,
-          visitor,
-          context,
-          0 /* All */,
-          !expressionResultIsUnused2
-        );
-      }
-      if (node.operatorToken.kind === 28 /* CommaToken */) {
-        return factory2.updateBinaryExpression(
-          node,
-          Debug.checkDefined(visitNode(node.left, visitorWithUnusedExpressionResult, isExpression)),
-          node.operatorToken,
-          Debug.checkDefined(visitNode(node.right, expressionResultIsUnused2 ? visitorWithUnusedExpressionResult : visitor, isExpression))
-        );
-      }
-      return visitEachChild(node, visitor, context);
-    }
-    function visitCommaListExpression(node, expressionResultIsUnused2) {
-      if (expressionResultIsUnused2) {
-        return visitEachChild(node, visitorWithUnusedExpressionResult, context);
-      }
-      let result;
-      for (let i = 0; i < node.elements.length; i++) {
-        const element = node.elements[i];
-        const visited = visitNode(element, i < node.elements.length - 1 ? visitorWithUnusedExpressionResult : visitor, isExpression);
-        if (result || visited !== element) {
-          result || (result = node.elements.slice(0, i));
-          Debug.assert(visited);
-          result.push(visited);
-        }
-      }
-      const elements = result ? setTextRange(factory2.createNodeArray(result), node.elements) : node.elements;
-      return factory2.updateCommaListExpression(node, elements);
-    }
-    function isVariableStatementOfTypeScriptClassWrapper(node) {
-      return node.declarationList.declarations.length === 1 && !!node.declarationList.declarations[0].initializer && !!(getInternalEmitFlags(node.declarationList.declarations[0].initializer) & 1 /* TypeScriptClassWrapper */);
-    }
-    function visitVariableStatement(node) {
-      const ancestorFacts = enterSubtree(0 /* None */, hasSyntacticModifier(node, 1 /* Export */) ? 32 /* ExportedVariableStatement */ : 0 /* None */);
-      let updated;
-      if (convertedLoopState && (node.declarationList.flags & 3 /* BlockScoped */) === 0 && !isVariableStatementOfTypeScriptClassWrapper(node)) {
-        let assignments;
-        for (const decl of node.declarationList.declarations) {
-          hoistVariableDeclarationDeclaredInConvertedLoop(convertedLoopState, decl);
-          if (decl.initializer) {
-            let assignment;
-            if (isBindingPattern(decl.name)) {
-              assignment = flattenDestructuringAssignment(
-                decl,
-                visitor,
-                context,
-                0 /* All */
-              );
-            } else {
-              assignment = factory2.createBinaryExpression(decl.name, 64 /* EqualsToken */, Debug.checkDefined(visitNode(decl.initializer, visitor, isExpression)));
-              setTextRange(assignment, decl);
-            }
-            assignments = append(assignments, assignment);
-          }
-        }
-        if (assignments) {
-          updated = setTextRange(factory2.createExpressionStatement(factory2.inlineExpressions(assignments)), node);
-        } else {
-          updated = void 0;
-        }
-      } else {
-        updated = visitEachChild(node, visitor, context);
-      }
-      exitSubtree(ancestorFacts, 0 /* None */, 0 /* None */);
-      return updated;
-    }
-    function visitVariableDeclarationList(node) {
-      if (node.flags & 3 /* BlockScoped */ || node.transformFlags & 524288 /* ContainsBindingPattern */) {
-        if (node.flags & 3 /* BlockScoped */) {
-          enableSubstitutionsForBlockScopedBindings();
-        }
-        const declarations = visitNodes2(node.declarations, node.flags & 1 /* Let */ ? visitVariableDeclarationInLetDeclarationList : visitVariableDeclaration, isVariableDeclaration);
-        const declarationList = factory2.createVariableDeclarationList(declarations);
-        setOriginalNode(declarationList, node);
-        setTextRange(declarationList, node);
-        setCommentRange(declarationList, node);
-        if (node.transformFlags & 524288 /* ContainsBindingPattern */ && (isBindingPattern(node.declarations[0].name) || isBindingPattern(last(node.declarations).name))) {
-          setSourceMapRange(declarationList, getRangeUnion(declarations));
-        }
-        return declarationList;
-      }
-      return visitEachChild(node, visitor, context);
-    }
-    function getRangeUnion(declarations) {
-      let pos = -1, end = -1;
-      for (const node of declarations) {
-        pos = pos === -1 ? node.pos : node.pos === -1 ? pos : Math.min(pos, node.pos);
-        end = Math.max(end, node.end);
-      }
-      return createRange(pos, end);
-    }
-    function shouldEmitExplicitInitializerForLetDeclaration(node) {
-      const flags = resolver.getNodeCheckFlags(node);
-      const isCapturedInFunction = flags & 16384 /* CapturedBlockScopedBinding */;
-      const isDeclaredInLoop = flags & 32768 /* BlockScopedBindingInLoop */;
-      const emittedAsTopLevel = (hierarchyFacts & 64 /* TopLevel */) !== 0 || isCapturedInFunction && isDeclaredInLoop && (hierarchyFacts & 512 /* IterationStatementBlock */) !== 0;
-      const emitExplicitInitializer = !emittedAsTopLevel && (hierarchyFacts & 4096 /* ForInOrForOfStatement */) === 0 && (!resolver.isDeclarationWithCollidingName(node) || isDeclaredInLoop && !isCapturedInFunction && (hierarchyFacts & (2048 /* ForStatement */ | 4096 /* ForInOrForOfStatement */)) === 0);
-      return emitExplicitInitializer;
-    }
-    function visitVariableDeclarationInLetDeclarationList(node) {
-      const name = node.name;
-      if (isBindingPattern(name)) {
-        return visitVariableDeclaration(node);
-      }
-      if (!node.initializer && shouldEmitExplicitInitializerForLetDeclaration(node)) {
-        return factory2.updateVariableDeclaration(
-          node,
-          node.name,
-          /*exclamationToken*/
-          void 0,
-          /*type*/
-          void 0,
-          factory2.createVoidZero()
-        );
-      }
-      return visitEachChild(node, visitor, context);
-    }
-    function visitVariableDeclaration(node) {
-      const ancestorFacts = enterSubtree(32 /* ExportedVariableStatement */, 0 /* None */);
-      let updated;
-      if (isBindingPattern(node.name)) {
-        updated = flattenDestructuringBinding(
-          node,
-          visitor,
-          context,
-          0 /* All */,
-          /*rval*/
-          void 0,
-          (ancestorFacts & 32 /* ExportedVariableStatement */) !== 0
-        );
-      } else {
-        updated = visitEachChild(node, visitor, context);
-      }
-      exitSubtree(ancestorFacts, 0 /* None */, 0 /* None */);
-      return updated;
-    }
-    function recordLabel(node) {
-      convertedLoopState.labels.set(idText(node.label), true);
-    }
-    function resetLabel(node) {
-      convertedLoopState.labels.set(idText(node.label), false);
-    }
-    function visitLabeledStatement(node) {
-      if (convertedLoopState && !convertedLoopState.labels) {
-        convertedLoopState.labels = /* @__PURE__ */ new Map();
-      }
-      const statement = unwrapInnermostStatementOfLabel(node, convertedLoopState && recordLabel);
-      return isIterationStatement(
-        statement,
-        /*lookInLabeledStatements*/
-        false
-      ) ? visitIterationStatement(
-        statement,
-        /*outermostLabeledStatement*/
-        node
-      ) : factory2.restoreEnclosingLabel(Debug.checkDefined(visitNode(statement, visitor, isStatement, factory2.liftToBlock)), node, convertedLoopState && resetLabel);
-    }
-    function visitIterationStatement(node, outermostLabeledStatement) {
-      switch (node.kind) {
-        case 245 /* DoStatement */:
-        case 246 /* WhileStatement */:
-          return visitDoOrWhileStatement(node, outermostLabeledStatement);
-        case 247 /* ForStatement */:
-          return visitForStatement(node, outermostLabeledStatement);
-        case 248 /* ForInStatement */:
-          return visitForInStatement(node, outermostLabeledStatement);
-        case 249 /* ForOfStatement */:
-          return visitForOfStatement(node, outermostLabeledStatement);
-      }
-    }
-    function visitIterationStatementWithFacts(excludeFacts, includeFacts, node, outermostLabeledStatement, convert) {
-      const ancestorFacts = enterSubtree(excludeFacts, includeFacts);
-      const updated = convertIterationStatementBodyIfNecessary(node, outermostLabeledStatement, ancestorFacts, convert);
-      exitSubtree(ancestorFacts, 0 /* None */, 0 /* None */);
-      return updated;
-    }
-    function visitDoOrWhileStatement(node, outermostLabeledStatement) {
-      return visitIterationStatementWithFacts(
-        0 /* DoOrWhileStatementExcludes */,
-        1280 /* DoOrWhileStatementIncludes */,
-        node,
-        outermostLabeledStatement
-      );
-    }
-    function visitForStatement(node, outermostLabeledStatement) {
-      return visitIterationStatementWithFacts(
-        5056 /* ForStatementExcludes */,
-        3328 /* ForStatementIncludes */,
-        node,
-        outermostLabeledStatement
-      );
-    }
-    function visitEachChildOfForStatement2(node) {
-      return factory2.updateForStatement(
-        node,
-        visitNode(node.initializer, visitorWithUnusedExpressionResult, isForInitializer),
-        visitNode(node.condition, visitor, isExpression),
-        visitNode(node.incrementor, visitorWithUnusedExpressionResult, isExpression),
-        Debug.checkDefined(visitNode(node.statement, visitor, isStatement, factory2.liftToBlock))
-      );
-    }
-    function visitForInStatement(node, outermostLabeledStatement) {
-      return visitIterationStatementWithFacts(
-        3008 /* ForInOrForOfStatementExcludes */,
-        5376 /* ForInOrForOfStatementIncludes */,
-        node,
-        outermostLabeledStatement
-      );
-    }
-    function visitForOfStatement(node, outermostLabeledStatement) {
-      return visitIterationStatementWithFacts(
-        3008 /* ForInOrForOfStatementExcludes */,
-        5376 /* ForInOrForOfStatementIncludes */,
-        node,
-        outermostLabeledStatement,
-        compilerOptions.downlevelIteration ? convertForOfStatementForIterable : convertForOfStatementForArray
-      );
-    }
-    function convertForOfStatementHead(node, boundValue, convertedLoopBodyStatements) {
-      const statements = [];
-      const initializer = node.initializer;
-      if (isVariableDeclarationList(initializer)) {
-        if (node.initializer.flags & 3 /* BlockScoped */) {
-          enableSubstitutionsForBlockScopedBindings();
-        }
-        const firstOriginalDeclaration = firstOrUndefined(initializer.declarations);
-        if (firstOriginalDeclaration && isBindingPattern(firstOriginalDeclaration.name)) {
-          const declarations = flattenDestructuringBinding(
-            firstOriginalDeclaration,
-            visitor,
-            context,
-            0 /* All */,
-            boundValue
-          );
-          const declarationList = setTextRange(factory2.createVariableDeclarationList(declarations), node.initializer);
-          setOriginalNode(declarationList, node.initializer);
-          setSourceMapRange(declarationList, createRange(declarations[0].pos, last(declarations).end));
-          statements.push(
-            factory2.createVariableStatement(
-              /*modifiers*/
-              void 0,
-              declarationList
-            )
-          );
-        } else {
-          statements.push(
-            setTextRange(
-              factory2.createVariableStatement(
-                /*modifiers*/
-                void 0,
-                setOriginalNode(
-                  setTextRange(
-                    factory2.createVariableDeclarationList([
-                      factory2.createVariableDeclaration(
-                        firstOriginalDeclaration ? firstOriginalDeclaration.name : factory2.createTempVariable(
-                          /*recordTempVariable*/
-                          void 0
-                        ),
-                        /*exclamationToken*/
-                        void 0,
-                        /*type*/
-                        void 0,
-                        boundValue
-                      )
-                    ]),
-                    moveRangePos(initializer, -1)
-                  ),
-                  initializer
-                )
-              ),
-              moveRangeEnd(initializer, -1)
-            )
-          );
-        }
-      } else {
-        const assignment = factory2.createAssignment(initializer, boundValue);
-        if (isDestructuringAssignment(assignment)) {
-          statements.push(factory2.createExpressionStatement(visitBinaryExpression(
-            assignment,
-            /*expressionResultIsUnused*/
-            true
-          )));
-        } else {
-          setTextRangeEnd(assignment, initializer.end);
-          statements.push(setTextRange(factory2.createExpressionStatement(Debug.checkDefined(visitNode(assignment, visitor, isExpression))), moveRangeEnd(initializer, -1)));
-        }
-      }
-      if (convertedLoopBodyStatements) {
-        return createSyntheticBlockForConvertedStatements(addRange(statements, convertedLoopBodyStatements));
-      } else {
-        const statement = visitNode(node.statement, visitor, isStatement, factory2.liftToBlock);
-        Debug.assert(statement);
-        if (isBlock(statement)) {
-          return factory2.updateBlock(statement, setTextRange(factory2.createNodeArray(concatenate(statements, statement.statements)), statement.statements));
-        } else {
-          statements.push(statement);
-          return createSyntheticBlockForConvertedStatements(statements);
-        }
-      }
-    }
-    function createSyntheticBlockForConvertedStatements(statements) {
-      return setEmitFlags(
-        factory2.createBlock(
-          factory2.createNodeArray(statements),
-          /*multiLine*/
-          true
-        ),
-        96 /* NoSourceMap */ | 768 /* NoTokenSourceMaps */
-      );
-    }
-    function convertForOfStatementForArray(node, outermostLabeledStatement, convertedLoopBodyStatements) {
-      const expression = visitNode(node.expression, visitor, isExpression);
-      Debug.assert(expression);
-      const counter = factory2.createLoopVariable();
-      const rhsReference = isIdentifier(expression) ? factory2.getGeneratedNameForNode(expression) : factory2.createTempVariable(
-        /*recordTempVariable*/
-        void 0
-      );
-      setEmitFlags(expression, 96 /* NoSourceMap */ | getEmitFlags(expression));
-      const forStatement = setTextRange(
-        factory2.createForStatement(
-          /*initializer*/
-          setEmitFlags(
-            setTextRange(
-              factory2.createVariableDeclarationList([
-                setTextRange(factory2.createVariableDeclaration(
-                  counter,
-                  /*exclamationToken*/
-                  void 0,
-                  /*type*/
-                  void 0,
-                  factory2.createNumericLiteral(0)
-                ), moveRangePos(node.expression, -1)),
-                setTextRange(factory2.createVariableDeclaration(
-                  rhsReference,
-                  /*exclamationToken*/
-                  void 0,
-                  /*type*/
-                  void 0,
-                  expression
-                ), node.expression)
-              ]),
-              node.expression
-            ),
-            4194304 /* NoHoisting */
-          ),
-          /*condition*/
-          setTextRange(
-            factory2.createLessThan(
-              counter,
-              factory2.createPropertyAccessExpression(rhsReference, "length")
-            ),
-            node.expression
-          ),
-          /*incrementor*/
-          setTextRange(factory2.createPostfixIncrement(counter), node.expression),
-          /*statement*/
-          convertForOfStatementHead(
-            node,
-            factory2.createElementAccessExpression(rhsReference, counter),
-            convertedLoopBodyStatements
-          )
-        ),
-        /*location*/
-        node
-      );
-      setEmitFlags(forStatement, 512 /* NoTokenTrailingSourceMaps */);
-      setTextRange(forStatement, node);
-      return factory2.restoreEnclosingLabel(forStatement, outermostLabeledStatement, convertedLoopState && resetLabel);
-    }
-    function convertForOfStatementForIterable(node, outermostLabeledStatement, convertedLoopBodyStatements, ancestorFacts) {
-      const expression = visitNode(node.expression, visitor, isExpression);
-      Debug.assert(expression);
-      const iterator = isIdentifier(expression) ? factory2.getGeneratedNameForNode(expression) : factory2.createTempVariable(
-        /*recordTempVariable*/
-        void 0
-      );
-      const result = isIdentifier(expression) ? factory2.getGeneratedNameForNode(iterator) : factory2.createTempVariable(
-        /*recordTempVariable*/
-        void 0
-      );
-      const errorRecord = factory2.createUniqueName("e");
-      const catchVariable = factory2.getGeneratedNameForNode(errorRecord);
-      const returnMethod = factory2.createTempVariable(
-        /*recordTempVariable*/
-        void 0
-      );
-      const values = setTextRange(emitHelpers().createValuesHelper(expression), node.expression);
-      const next = factory2.createCallExpression(
-        factory2.createPropertyAccessExpression(iterator, "next"),
-        /*typeArguments*/
-        void 0,
-        []
-      );
-      hoistVariableDeclaration(errorRecord);
-      hoistVariableDeclaration(returnMethod);
-      const initializer = ancestorFacts & 1024 /* IterationContainer */ ? factory2.inlineExpressions([factory2.createAssignment(errorRecord, factory2.createVoidZero()), values]) : values;
-      const forStatement = setEmitFlags(
-        setTextRange(
-          factory2.createForStatement(
-            /*initializer*/
-            setEmitFlags(
-              setTextRange(
-                factory2.createVariableDeclarationList([
-                  setTextRange(factory2.createVariableDeclaration(
-                    iterator,
-                    /*exclamationToken*/
-                    void 0,
-                    /*type*/
-                    void 0,
-                    initializer
-                  ), node.expression),
-                  factory2.createVariableDeclaration(
-                    result,
-                    /*exclamationToken*/
-                    void 0,
-                    /*type*/
-                    void 0,
-                    next
-                  )
-                ]),
-                node.expression
-              ),
-              4194304 /* NoHoisting */
-            ),
-            /*condition*/
-            factory2.createLogicalNot(factory2.createPropertyAccessExpression(result, "done")),
-            /*incrementor*/
-            factory2.createAssignment(result, next),
-            /*statement*/
-            convertForOfStatementHead(
-              node,
-              factory2.createPropertyAccessExpression(result, "value"),
-              convertedLoopBodyStatements
-            )
-          ),
-          /*location*/
-          node
-        ),
-        512 /* NoTokenTrailingSourceMaps */
-      );
-      return factory2.createTryStatement(
-        factory2.createBlock([
-          factory2.restoreEnclosingLabel(
-            forStatement,
-            outermostLabeledStatement,
-            convertedLoopState && resetLabel
-          )
-        ]),
-        factory2.createCatchClause(
-          factory2.createVariableDeclaration(catchVariable),
-          setEmitFlags(
-            factory2.createBlock([
-              factory2.createExpressionStatement(
-                factory2.createAssignment(
-                  errorRecord,
-                  factory2.createObjectLiteralExpression([
-                    factory2.createPropertyAssignment("error", catchVariable)
-                  ])
-                )
-              )
-            ]),
-            1 /* SingleLine */
-          )
-        ),
-        factory2.createBlock([
-          factory2.createTryStatement(
-            /*tryBlock*/
-            factory2.createBlock([
-              setEmitFlags(
-                factory2.createIfStatement(
-                  factory2.createLogicalAnd(
-                    factory2.createLogicalAnd(
-                      result,
-                      factory2.createLogicalNot(
-                        factory2.createPropertyAccessExpression(result, "done")
-                      )
-                    ),
-                    factory2.createAssignment(
-                      returnMethod,
-                      factory2.createPropertyAccessExpression(iterator, "return")
-                    )
-                  ),
-                  factory2.createExpressionStatement(
-                    factory2.createFunctionCallCall(returnMethod, iterator, [])
-                  )
-                ),
-                1 /* SingleLine */
-              )
-            ]),
-            /*catchClause*/
-            void 0,
-            /*finallyBlock*/
-            setEmitFlags(
-              factory2.createBlock([
-                setEmitFlags(
-                  factory2.createIfStatement(
-                    errorRecord,
-                    factory2.createThrowStatement(
-                      factory2.createPropertyAccessExpression(errorRecord, "error")
-                    )
-                  ),
-                  1 /* SingleLine */
-                )
-              ]),
-              1 /* SingleLine */
-            )
-          )
-        ])
-      );
-    }
-    function visitObjectLiteralExpression(node) {
-      const properties = node.properties;
-      let numInitialProperties = -1, hasComputed = false;
-      for (let i = 0; i < properties.length; i++) {
-        const property = properties[i];
-        if (property.transformFlags & 1048576 /* ContainsYield */ && hierarchyFacts & 4 /* AsyncFunctionBody */ || (hasComputed = Debug.checkDefined(property.name).kind === 166 /* ComputedPropertyName */)) {
-          numInitialProperties = i;
-          break;
-        }
-      }
-      if (numInitialProperties < 0) {
-        return visitEachChild(node, visitor, context);
-      }
-      const temp = factory2.createTempVariable(hoistVariableDeclaration);
-      const expressions = [];
-      const assignment = factory2.createAssignment(
-        temp,
-        setEmitFlags(
-          factory2.createObjectLiteralExpression(
-            visitNodes2(properties, visitor, isObjectLiteralElementLike, 0, numInitialProperties),
-            node.multiLine
-          ),
-          hasComputed ? 131072 /* Indented */ : 0
-        )
-      );
-      if (node.multiLine) {
-        startOnNewLine(assignment);
-      }
-      expressions.push(assignment);
-      addObjectLiteralMembers(expressions, node, temp, numInitialProperties);
-      expressions.push(node.multiLine ? startOnNewLine(setParent(setTextRange(factory2.cloneNode(temp), temp), temp.parent)) : temp);
-      return factory2.inlineExpressions(expressions);
-    }
-    function shouldConvertPartOfIterationStatement(node) {
-      return (resolver.getNodeCheckFlags(node) & 8192 /* ContainsCapturedBlockScopeBinding */) !== 0;
-    }
-    function shouldConvertInitializerOfForStatement(node) {
-      return isForStatement(node) && !!node.initializer && shouldConvertPartOfIterationStatement(node.initializer);
-    }
-    function shouldConvertConditionOfForStatement(node) {
-      return isForStatement(node) && !!node.condition && shouldConvertPartOfIterationStatement(node.condition);
-    }
-    function shouldConvertIncrementorOfForStatement(node) {
-      return isForStatement(node) && !!node.incrementor && shouldConvertPartOfIterationStatement(node.incrementor);
-    }
-    function shouldConvertIterationStatement(node) {
-      return shouldConvertBodyOfIterationStatement(node) || shouldConvertInitializerOfForStatement(node);
-    }
-    function shouldConvertBodyOfIterationStatement(node) {
-      return (resolver.getNodeCheckFlags(node) & 4096 /* LoopWithCapturedBlockScopedBinding */) !== 0;
-    }
-    function hoistVariableDeclarationDeclaredInConvertedLoop(state, node) {
-      if (!state.hoistedLocalVariables) {
-        state.hoistedLocalVariables = [];
-      }
-      visit(node.name);
-      function visit(node2) {
-        if (node2.kind === 80 /* Identifier */) {
-          state.hoistedLocalVariables.push(node2);
-        } else {
-          for (const element of node2.elements) {
-            if (!isOmittedExpression(element)) {
-              visit(element.name);
-            }
-          }
-        }
-      }
-    }
-    function convertIterationStatementBodyIfNecessary(node, outermostLabeledStatement, ancestorFacts, convert) {
-      if (!shouldConvertIterationStatement(node)) {
-        let saveAllowedNonLabeledJumps;
-        if (convertedLoopState) {
-          saveAllowedNonLabeledJumps = convertedLoopState.allowedNonLabeledJumps;
-          convertedLoopState.allowedNonLabeledJumps = 2 /* Break */ | 4 /* Continue */;
-        }
-        const result = convert ? convert(
-          node,
-          outermostLabeledStatement,
-          /*convertedLoopBodyStatements*/
-          void 0,
-          ancestorFacts
-        ) : factory2.restoreEnclosingLabel(
-          isForStatement(node) ? visitEachChildOfForStatement2(node) : visitEachChild(node, visitor, context),
-          outermostLabeledStatement,
-          convertedLoopState && resetLabel
-        );
-        if (convertedLoopState) {
-          convertedLoopState.allowedNonLabeledJumps = saveAllowedNonLabeledJumps;
-        }
-        return result;
-      }
-      const currentState = createConvertedLoopState(node);
-      const statements = [];
-      const outerConvertedLoopState = convertedLoopState;
-      convertedLoopState = currentState;
-      const initializerFunction = shouldConvertInitializerOfForStatement(node) ? createFunctionForInitializerOfForStatement(node, currentState) : void 0;
-      const bodyFunction = shouldConvertBodyOfIterationStatement(node) ? createFunctionForBodyOfIterationStatement(node, currentState, outerConvertedLoopState) : void 0;
-      convertedLoopState = outerConvertedLoopState;
-      if (initializerFunction)
-        statements.push(initializerFunction.functionDeclaration);
-      if (bodyFunction)
-        statements.push(bodyFunction.functionDeclaration);
-      addExtraDeclarationsForConvertedLoop(statements, currentState, outerConvertedLoopState);
-      if (initializerFunction) {
-        statements.push(generateCallToConvertedLoopInitializer(initializerFunction.functionName, initializerFunction.containsYield));
-      }
-      let loop;
-      if (bodyFunction) {
-        if (convert) {
-          loop = convert(node, outermostLabeledStatement, bodyFunction.part, ancestorFacts);
-        } else {
-          const clone2 = convertIterationStatementCore(node, initializerFunction, factory2.createBlock(
-            bodyFunction.part,
-            /*multiLine*/
-            true
-          ));
-          loop = factory2.restoreEnclosingLabel(clone2, outermostLabeledStatement, convertedLoopState && resetLabel);
-        }
-      } else {
-        const clone2 = convertIterationStatementCore(node, initializerFunction, Debug.checkDefined(visitNode(node.statement, visitor, isStatement, factory2.liftToBlock)));
-        loop = factory2.restoreEnclosingLabel(clone2, outermostLabeledStatement, convertedLoopState && resetLabel);
-      }
-      statements.push(loop);
-      return statements;
-    }
-    function convertIterationStatementCore(node, initializerFunction, convertedLoopBody) {
-      switch (node.kind) {
-        case 247 /* ForStatement */:
-          return convertForStatement(node, initializerFunction, convertedLoopBody);
-        case 248 /* ForInStatement */:
-          return convertForInStatement(node, convertedLoopBody);
-        case 249 /* ForOfStatement */:
-          return convertForOfStatement(node, convertedLoopBody);
-        case 245 /* DoStatement */:
-          return convertDoStatement(node, convertedLoopBody);
-        case 246 /* WhileStatement */:
-          return convertWhileStatement(node, convertedLoopBody);
-        default:
-          return Debug.failBadSyntaxKind(node, "IterationStatement expected");
-      }
-    }
-    function convertForStatement(node, initializerFunction, convertedLoopBody) {
-      const shouldConvertCondition = node.condition && shouldConvertPartOfIterationStatement(node.condition);
-      const shouldConvertIncrementor = shouldConvertCondition || node.incrementor && shouldConvertPartOfIterationStatement(node.incrementor);
-      return factory2.updateForStatement(
-        node,
-        visitNode(initializerFunction ? initializerFunction.part : node.initializer, visitorWithUnusedExpressionResult, isForInitializer),
-        visitNode(shouldConvertCondition ? void 0 : node.condition, visitor, isExpression),
-        visitNode(shouldConvertIncrementor ? void 0 : node.incrementor, visitorWithUnusedExpressionResult, isExpression),
-        convertedLoopBody
-      );
-    }
-    function convertForOfStatement(node, convertedLoopBody) {
-      return factory2.updateForOfStatement(
-        node,
-        /*awaitModifier*/
-        void 0,
-        Debug.checkDefined(visitNode(node.initializer, visitor, isForInitializer)),
-        Debug.checkDefined(visitNode(node.expression, visitor, isExpression)),
-        convertedLoopBody
-      );
-    }
-    function convertForInStatement(node, convertedLoopBody) {
-      return factory2.updateForInStatement(
-        node,
-        Debug.checkDefined(visitNode(node.initializer, visitor, isForInitializer)),
-        Debug.checkDefined(visitNode(node.expression, visitor, isExpression)),
-        convertedLoopBody
-      );
-    }
-    function convertDoStatement(node, convertedLoopBody) {
-      return factory2.updateDoStatement(
-        node,
-        convertedLoopBody,
-        Debug.checkDefined(visitNode(node.expression, visitor, isExpression))
-      );
-    }
-    function convertWhileStatement(node, convertedLoopBody) {
-      return factory2.updateWhileStatement(
-        node,
-        Debug.checkDefined(visitNode(node.expression, visitor, isExpression)),
-        convertedLoopBody
-      );
-    }
-    function createConvertedLoopState(node) {
-      let loopInitializer;
-      switch (node.kind) {
-        case 247 /* ForStatement */:
-        case 248 /* ForInStatement */:
-        case 249 /* ForOfStatement */:
-          const initializer = node.initializer;
-          if (initializer && initializer.kind === 260 /* VariableDeclarationList */) {
-            loopInitializer = initializer;
-          }
-          break;
-      }
-      const loopParameters = [];
-      const loopOutParameters = [];
-      if (loopInitializer && getCombinedNodeFlags(loopInitializer) & 3 /* BlockScoped */) {
-        const hasCapturedBindingsInForHead = shouldConvertInitializerOfForStatement(node) || shouldConvertConditionOfForStatement(node) || shouldConvertIncrementorOfForStatement(node);
-        for (const decl of loopInitializer.declarations) {
-          processLoopVariableDeclaration(node, decl, loopParameters, loopOutParameters, hasCapturedBindingsInForHead);
-        }
-      }
-      const currentState = { loopParameters, loopOutParameters };
-      if (convertedLoopState) {
-        if (convertedLoopState.argumentsName) {
-          currentState.argumentsName = convertedLoopState.argumentsName;
-        }
-        if (convertedLoopState.thisName) {
-          currentState.thisName = convertedLoopState.thisName;
-        }
-        if (convertedLoopState.hoistedLocalVariables) {
-          currentState.hoistedLocalVariables = convertedLoopState.hoistedLocalVariables;
-        }
-      }
-      return currentState;
-    }
-    function addExtraDeclarationsForConvertedLoop(statements, state, outerState) {
-      let extraVariableDeclarations;
-      if (state.argumentsName) {
-        if (outerState) {
-          outerState.argumentsName = state.argumentsName;
-        } else {
-          (extraVariableDeclarations || (extraVariableDeclarations = [])).push(
-            factory2.createVariableDeclaration(
-              state.argumentsName,
-              /*exclamationToken*/
-              void 0,
-              /*type*/
-              void 0,
-              factory2.createIdentifier("arguments")
-            )
-          );
-        }
-      }
-      if (state.thisName) {
-        if (outerState) {
-          outerState.thisName = state.thisName;
-        } else {
-          (extraVariableDeclarations || (extraVariableDeclarations = [])).push(
-            factory2.createVariableDeclaration(
-              state.thisName,
-              /*exclamationToken*/
-              void 0,
-              /*type*/
-              void 0,
-              factory2.createIdentifier("this")
-            )
-          );
-        }
-      }
-      if (state.hoistedLocalVariables) {
-        if (outerState) {
-          outerState.hoistedLocalVariables = state.hoistedLocalVariables;
-        } else {
-          if (!extraVariableDeclarations) {
-            extraVariableDeclarations = [];
-          }
-          for (const identifier of state.hoistedLocalVariables) {
-            extraVariableDeclarations.push(factory2.createVariableDeclaration(identifier));
-          }
-        }
-      }
-      if (state.loopOutParameters.length) {
-        if (!extraVariableDeclarations) {
-          extraVariableDeclarations = [];
-        }
-        for (const outParam of state.loopOutParameters) {
-          extraVariableDeclarations.push(factory2.createVariableDeclaration(outParam.outParamName));
-        }
-      }
-      if (state.conditionVariable) {
-        if (!extraVariableDeclarations) {
-          extraVariableDeclarations = [];
-        }
-        extraVariableDeclarations.push(factory2.createVariableDeclaration(
-          state.conditionVariable,
-          /*exclamationToken*/
-          void 0,
-          /*type*/
-          void 0,
-          factory2.createFalse()
-        ));
-      }
-      if (extraVariableDeclarations) {
-        statements.push(factory2.createVariableStatement(
-          /*modifiers*/
-          void 0,
-          factory2.createVariableDeclarationList(extraVariableDeclarations)
-        ));
-      }
-    }
-    function createOutVariable(p) {
-      return factory2.createVariableDeclaration(
-        p.originalName,
-        /*exclamationToken*/
-        void 0,
-        /*type*/
-        void 0,
-        p.outParamName
-      );
-    }
-    function createFunctionForInitializerOfForStatement(node, currentState) {
-      const functionName = factory2.createUniqueName("_loop_init");
-      const containsYield = (node.initializer.transformFlags & 1048576 /* ContainsYield */) !== 0;
-      let emitFlags = 0 /* None */;
-      if (currentState.containsLexicalThis)
-        emitFlags |= 16 /* CapturesThis */;
-      if (containsYield && hierarchyFacts & 4 /* AsyncFunctionBody */)
-        emitFlags |= 524288 /* AsyncFunctionBody */;
-      const statements = [];
-      statements.push(factory2.createVariableStatement(
-        /*modifiers*/
-        void 0,
-        node.initializer
-      ));
-      copyOutParameters(currentState.loopOutParameters, 2 /* Initializer */, 1 /* ToOutParameter */, statements);
-      const functionDeclaration = factory2.createVariableStatement(
-        /*modifiers*/
-        void 0,
-        setEmitFlags(
-          factory2.createVariableDeclarationList([
-            factory2.createVariableDeclaration(
-              functionName,
-              /*exclamationToken*/
-              void 0,
-              /*type*/
-              void 0,
-              setEmitFlags(
-                factory2.createFunctionExpression(
-                  /*modifiers*/
-                  void 0,
-                  containsYield ? factory2.createToken(42 /* AsteriskToken */) : void 0,
-                  /*name*/
-                  void 0,
-                  /*typeParameters*/
-                  void 0,
-                  /*parameters*/
-                  void 0,
-                  /*type*/
-                  void 0,
-                  Debug.checkDefined(visitNode(
-                    factory2.createBlock(
-                      statements,
-                      /*multiLine*/
-                      true
-                    ),
-                    visitor,
-                    isBlock
-                  ))
-                ),
-                emitFlags
-              )
-            )
-          ]),
-          4194304 /* NoHoisting */
-        )
-      );
-      const part = factory2.createVariableDeclarationList(map(currentState.loopOutParameters, createOutVariable));
-      return { functionName, containsYield, functionDeclaration, part };
-    }
-    function createFunctionForBodyOfIterationStatement(node, currentState, outerState) {
-      const functionName = factory2.createUniqueName("_loop");
-      startLexicalEnvironment();
-      const statement = visitNode(node.statement, visitor, isStatement, factory2.liftToBlock);
-      const lexicalEnvironment = endLexicalEnvironment();
-      const statements = [];
-      if (shouldConvertConditionOfForStatement(node) || shouldConvertIncrementorOfForStatement(node)) {
-        currentState.conditionVariable = factory2.createUniqueName("inc");
-        if (node.incrementor) {
-          statements.push(factory2.createIfStatement(
-            currentState.conditionVariable,
-            factory2.createExpressionStatement(Debug.checkDefined(visitNode(node.incrementor, visitor, isExpression))),
-            factory2.createExpressionStatement(factory2.createAssignment(currentState.conditionVariable, factory2.createTrue()))
-          ));
-        } else {
-          statements.push(factory2.createIfStatement(
-            factory2.createLogicalNot(currentState.conditionVariable),
-            factory2.createExpressionStatement(factory2.createAssignment(currentState.conditionVariable, factory2.createTrue()))
-          ));
-        }
-        if (shouldConvertConditionOfForStatement(node)) {
-          statements.push(factory2.createIfStatement(
-            factory2.createPrefixUnaryExpression(54 /* ExclamationToken */, Debug.checkDefined(visitNode(node.condition, visitor, isExpression))),
-            Debug.checkDefined(visitNode(factory2.createBreakStatement(), visitor, isStatement))
-          ));
-        }
-      }
-      Debug.assert(statement);
-      if (isBlock(statement)) {
-        addRange(statements, statement.statements);
-      } else {
-        statements.push(statement);
-      }
-      copyOutParameters(currentState.loopOutParameters, 1 /* Body */, 1 /* ToOutParameter */, statements);
-      insertStatementsAfterStandardPrologue(statements, lexicalEnvironment);
-      const loopBody = factory2.createBlock(
-        statements,
-        /*multiLine*/
-        true
-      );
-      if (isBlock(statement))
-        setOriginalNode(loopBody, statement);
-      const containsYield = (node.statement.transformFlags & 1048576 /* ContainsYield */) !== 0;
-      let emitFlags = 1048576 /* ReuseTempVariableScope */;
-      if (currentState.containsLexicalThis)
-        emitFlags |= 16 /* CapturesThis */;
-      if (containsYield && (hierarchyFacts & 4 /* AsyncFunctionBody */) !== 0)
-        emitFlags |= 524288 /* AsyncFunctionBody */;
-      const functionDeclaration = factory2.createVariableStatement(
-        /*modifiers*/
-        void 0,
-        setEmitFlags(
-          factory2.createVariableDeclarationList(
-            [
-              factory2.createVariableDeclaration(
-                functionName,
-                /*exclamationToken*/
-                void 0,
-                /*type*/
-                void 0,
-                setEmitFlags(
-                  factory2.createFunctionExpression(
-                    /*modifiers*/
-                    void 0,
-                    containsYield ? factory2.createToken(42 /* AsteriskToken */) : void 0,
-                    /*name*/
-                    void 0,
-                    /*typeParameters*/
-                    void 0,
-                    currentState.loopParameters,
-                    /*type*/
-                    void 0,
-                    loopBody
-                  ),
-                  emitFlags
-                )
-              )
-            ]
-          ),
-          4194304 /* NoHoisting */
-        )
-      );
-      const part = generateCallToConvertedLoop(functionName, currentState, outerState, containsYield);
-      return { functionName, containsYield, functionDeclaration, part };
-    }
-    function copyOutParameter(outParam, copyDirection) {
-      const source = copyDirection === 0 /* ToOriginal */ ? outParam.outParamName : outParam.originalName;
-      const target = copyDirection === 0 /* ToOriginal */ ? outParam.originalName : outParam.outParamName;
-      return factory2.createBinaryExpression(target, 64 /* EqualsToken */, source);
-    }
-    function copyOutParameters(outParams, partFlags, copyDirection, statements) {
-      for (const outParam of outParams) {
-        if (outParam.flags & partFlags) {
-          statements.push(factory2.createExpressionStatement(copyOutParameter(outParam, copyDirection)));
-        }
-      }
-    }
-    function generateCallToConvertedLoopInitializer(initFunctionExpressionName, containsYield) {
-      const call = factory2.createCallExpression(
-        initFunctionExpressionName,
-        /*typeArguments*/
-        void 0,
-        []
-      );
-      const callResult = containsYield ? factory2.createYieldExpression(
-        factory2.createToken(42 /* AsteriskToken */),
-        setEmitFlags(call, 8388608 /* Iterator */)
-      ) : call;
-      return factory2.createExpressionStatement(callResult);
-    }
-    function generateCallToConvertedLoop(loopFunctionExpressionName, state, outerState, containsYield) {
-      const statements = [];
-      const isSimpleLoop = !(state.nonLocalJumps & ~4 /* Continue */) && !state.labeledNonLocalBreaks && !state.labeledNonLocalContinues;
-      const call = factory2.createCallExpression(
-        loopFunctionExpressionName,
-        /*typeArguments*/
-        void 0,
-        map(state.loopParameters, (p) => p.name)
-      );
-      const callResult = containsYield ? factory2.createYieldExpression(
-        factory2.createToken(42 /* AsteriskToken */),
-        setEmitFlags(call, 8388608 /* Iterator */)
-      ) : call;
-      if (isSimpleLoop) {
-        statements.push(factory2.createExpressionStatement(callResult));
-        copyOutParameters(state.loopOutParameters, 1 /* Body */, 0 /* ToOriginal */, statements);
-      } else {
-        const loopResultName = factory2.createUniqueName("state");
-        const stateVariable = factory2.createVariableStatement(
-          /*modifiers*/
-          void 0,
-          factory2.createVariableDeclarationList(
-            [factory2.createVariableDeclaration(
-              loopResultName,
-              /*exclamationToken*/
-              void 0,
-              /*type*/
-              void 0,
-              callResult
-            )]
-          )
-        );
-        statements.push(stateVariable);
-        copyOutParameters(state.loopOutParameters, 1 /* Body */, 0 /* ToOriginal */, statements);
-        if (state.nonLocalJumps & 8 /* Return */) {
-          let returnStatement;
-          if (outerState) {
-            outerState.nonLocalJumps |= 8 /* Return */;
-            returnStatement = factory2.createReturnStatement(loopResultName);
-          } else {
-            returnStatement = factory2.createReturnStatement(factory2.createPropertyAccessExpression(loopResultName, "value"));
-          }
-          statements.push(
-            factory2.createIfStatement(
-              factory2.createTypeCheck(loopResultName, "object"),
-              returnStatement
-            )
-          );
-        }
-        if (state.nonLocalJumps & 2 /* Break */) {
-          statements.push(
-            factory2.createIfStatement(
-              factory2.createStrictEquality(
-                loopResultName,
-                factory2.createStringLiteral("break")
-              ),
-              factory2.createBreakStatement()
-            )
-          );
-        }
-        if (state.labeledNonLocalBreaks || state.labeledNonLocalContinues) {
-          const caseClauses = [];
-          processLabeledJumps(
-            state.labeledNonLocalBreaks,
-            /*isBreak*/
-            true,
-            loopResultName,
-            outerState,
-            caseClauses
-          );
-          processLabeledJumps(
-            state.labeledNonLocalContinues,
-            /*isBreak*/
-            false,
-            loopResultName,
-            outerState,
-            caseClauses
-          );
-          statements.push(
-            factory2.createSwitchStatement(
-              loopResultName,
-              factory2.createCaseBlock(caseClauses)
-            )
-          );
-        }
-      }
-      return statements;
-    }
-    function setLabeledJump(state, isBreak, labelText, labelMarker) {
-      if (isBreak) {
-        if (!state.labeledNonLocalBreaks) {
-          state.labeledNonLocalBreaks = /* @__PURE__ */ new Map();
-        }
-        state.labeledNonLocalBreaks.set(labelText, labelMarker);
-      } else {
-        if (!state.labeledNonLocalContinues) {
-          state.labeledNonLocalContinues = /* @__PURE__ */ new Map();
-        }
-        state.labeledNonLocalContinues.set(labelText, labelMarker);
-      }
-    }
-    function processLabeledJumps(table, isBreak, loopResultName, outerLoop, caseClauses) {
-      if (!table) {
-        return;
-      }
-      table.forEach((labelMarker, labelText) => {
-        const statements = [];
-        if (!outerLoop || outerLoop.labels && outerLoop.labels.get(labelText)) {
-          const label = factory2.createIdentifier(labelText);
-          statements.push(isBreak ? factory2.createBreakStatement(label) : factory2.createContinueStatement(label));
-        } else {
-          setLabeledJump(outerLoop, isBreak, labelText, labelMarker);
-          statements.push(factory2.createReturnStatement(loopResultName));
-        }
-        caseClauses.push(factory2.createCaseClause(factory2.createStringLiteral(labelMarker), statements));
-      });
-    }
-    function processLoopVariableDeclaration(container, decl, loopParameters, loopOutParameters, hasCapturedBindingsInForHead) {
-      const name = decl.name;
-      if (isBindingPattern(name)) {
-        for (const element of name.elements) {
-          if (!isOmittedExpression(element)) {
-            processLoopVariableDeclaration(container, element, loopParameters, loopOutParameters, hasCapturedBindingsInForHead);
-          }
-        }
-      } else {
-        loopParameters.push(factory2.createParameterDeclaration(
-          /*modifiers*/
-          void 0,
-          /*dotDotDotToken*/
-          void 0,
-          name
-        ));
-        const checkFlags = resolver.getNodeCheckFlags(decl);
-        if (checkFlags & 262144 /* NeedsLoopOutParameter */ || hasCapturedBindingsInForHead) {
-          const outParamName = factory2.createUniqueName("out_" + idText(name));
-          let flags = 0 /* None */;
-          if (checkFlags & 262144 /* NeedsLoopOutParameter */) {
-            flags |= 1 /* Body */;
-          }
-          if (isForStatement(container)) {
-            if (container.initializer && resolver.isBindingCapturedByNode(container.initializer, decl)) {
-              flags |= 2 /* Initializer */;
-            }
-            if (container.condition && resolver.isBindingCapturedByNode(container.condition, decl) || container.incrementor && resolver.isBindingCapturedByNode(container.incrementor, decl)) {
-              flags |= 1 /* Body */;
-            }
-          }
-          loopOutParameters.push({ flags, originalName: name, outParamName });
-        }
-      }
-    }
-    function addObjectLiteralMembers(expressions, node, receiver, start) {
-      const properties = node.properties;
-      const numProperties = properties.length;
-      for (let i = start; i < numProperties; i++) {
-        const property = properties[i];
-        switch (property.kind) {
-          case 176 /* GetAccessor */:
-          case 177 /* SetAccessor */:
-            const accessors = getAllAccessorDeclarations(node.properties, property);
-            if (property === accessors.firstAccessor) {
-              expressions.push(transformAccessorsToExpression(receiver, accessors, node, !!node.multiLine));
-            }
-            break;
-          case 173 /* MethodDeclaration */:
-            expressions.push(transformObjectLiteralMethodDeclarationToExpression(property, receiver, node, node.multiLine));
-            break;
-          case 302 /* PropertyAssignment */:
-            expressions.push(transformPropertyAssignmentToExpression(property, receiver, node.multiLine));
-            break;
-          case 303 /* ShorthandPropertyAssignment */:
-            expressions.push(transformShorthandPropertyAssignmentToExpression(property, receiver, node.multiLine));
-            break;
-          default:
-            Debug.failBadSyntaxKind(node);
-            break;
-        }
-      }
-    }
-    function transformPropertyAssignmentToExpression(property, receiver, startsOnNewLine) {
-      const expression = factory2.createAssignment(
-        createMemberAccessForPropertyName(
-          factory2,
-          receiver,
-          Debug.checkDefined(visitNode(property.name, visitor, isPropertyName))
-        ),
-        Debug.checkDefined(visitNode(property.initializer, visitor, isExpression))
-      );
-      setTextRange(expression, property);
-      if (startsOnNewLine) {
-        startOnNewLine(expression);
-      }
-      return expression;
-    }
-    function transformShorthandPropertyAssignmentToExpression(property, receiver, startsOnNewLine) {
-      const expression = factory2.createAssignment(
-        createMemberAccessForPropertyName(
-          factory2,
-          receiver,
-          Debug.checkDefined(visitNode(property.name, visitor, isPropertyName))
-        ),
-        factory2.cloneNode(property.name)
-      );
-      setTextRange(expression, property);
-      if (startsOnNewLine) {
-        startOnNewLine(expression);
-      }
-      return expression;
-    }
-    function transformObjectLiteralMethodDeclarationToExpression(method, receiver, container, startsOnNewLine) {
-      const expression = factory2.createAssignment(
-        createMemberAccessForPropertyName(
-          factory2,
-          receiver,
-          Debug.checkDefined(visitNode(method.name, visitor, isPropertyName))
-        ),
-        transformFunctionLikeToExpression(
-          method,
-          /*location*/
-          method,
-          /*name*/
-          void 0,
-          container
-        )
-      );
-      setTextRange(expression, method);
-      if (startsOnNewLine) {
-        startOnNewLine(expression);
-      }
-      return expression;
-    }
-    function visitCatchClause(node) {
-      const ancestorFacts = enterSubtree(7104 /* BlockScopeExcludes */, 0 /* BlockScopeIncludes */);
-      let updated;
-      Debug.assert(!!node.variableDeclaration, "Catch clause variable should always be present when downleveling ES2015.");
-      if (isBindingPattern(node.variableDeclaration.name)) {
-        const temp = factory2.createTempVariable(
-          /*recordTempVariable*/
-          void 0
-        );
-        const newVariableDeclaration = factory2.createVariableDeclaration(temp);
-        setTextRange(newVariableDeclaration, node.variableDeclaration);
-        const vars = flattenDestructuringBinding(
-          node.variableDeclaration,
-          visitor,
-          context,
-          0 /* All */,
-          temp
-        );
-        const list = factory2.createVariableDeclarationList(vars);
-        setTextRange(list, node.variableDeclaration);
-        const destructure = factory2.createVariableStatement(
-          /*modifiers*/
-          void 0,
-          list
-        );
-        updated = factory2.updateCatchClause(node, newVariableDeclaration, addStatementToStartOfBlock(node.block, destructure));
-      } else {
-        updated = visitEachChild(node, visitor, context);
-      }
-      exitSubtree(ancestorFacts, 0 /* None */, 0 /* None */);
-      return updated;
-    }
-    function addStatementToStartOfBlock(block, statement) {
-      const transformedStatements = visitNodes2(block.statements, visitor, isStatement);
-      return factory2.updateBlock(block, [statement, ...transformedStatements]);
-    }
-    function visitMethodDeclaration(node) {
-      Debug.assert(!isComputedPropertyName(node.name));
-      const functionExpression = transformFunctionLikeToExpression(
-        node,
-        /*location*/
-        moveRangePos(node, -1),
-        /*name*/
-        void 0,
-        /*container*/
-        void 0
-      );
-      setEmitFlags(functionExpression, 1024 /* NoLeadingComments */ | getEmitFlags(functionExpression));
-      return setTextRange(
-        factory2.createPropertyAssignment(
-          node.name,
-          functionExpression
-        ),
-        /*location*/
-        node
-      );
-    }
-    function visitAccessorDeclaration(node) {
-      Debug.assert(!isComputedPropertyName(node.name));
-      const savedConvertedLoopState = convertedLoopState;
-      convertedLoopState = void 0;
-      const ancestorFacts = enterSubtree(32670 /* FunctionExcludes */, 65 /* FunctionIncludes */);
-      let updated;
-      const parameters = visitParameterList(node.parameters, visitor, context);
-      const body = transformFunctionBody2(node);
-      if (node.kind === 176 /* GetAccessor */) {
-        updated = factory2.updateGetAccessorDeclaration(node, node.modifiers, node.name, parameters, node.type, body);
-      } else {
-        updated = factory2.updateSetAccessorDeclaration(node, node.modifiers, node.name, parameters, body);
-      }
-      exitSubtree(ancestorFacts, 98304 /* FunctionSubtreeExcludes */, 0 /* None */);
-      convertedLoopState = savedConvertedLoopState;
-      return updated;
-    }
-    function visitShorthandPropertyAssignment(node) {
-      return setTextRange(
-        factory2.createPropertyAssignment(
-          node.name,
-          visitIdentifier(factory2.cloneNode(node.name))
-        ),
-        /*location*/
-        node
-      );
-    }
-    function visitComputedPropertyName(node) {
-      return visitEachChild(node, visitor, context);
-    }
-    function visitYieldExpression(node) {
-      return visitEachChild(node, visitor, context);
-    }
-    function visitArrayLiteralExpression(node) {
-      if (some(node.elements, isSpreadElement)) {
-        return transformAndSpreadElements(
-          node.elements,
-          /*isArgumentList*/
-          false,
-          !!node.multiLine,
-          /*hasTrailingComma*/
-          !!node.elements.hasTrailingComma
-        );
-      }
-      return visitEachChild(node, visitor, context);
-    }
-    function visitCallExpression(node) {
-      if (getInternalEmitFlags(node) & 1 /* TypeScriptClassWrapper */) {
-        return visitTypeScriptClassWrapper(node);
-      }
-      const expression = skipOuterExpressions(node.expression);
-      if (expression.kind === 108 /* SuperKeyword */ || isSuperProperty(expression) || some(node.arguments, isSpreadElement)) {
-        return visitCallExpressionWithPotentialCapturedThisAssignment(
-          node,
-          /*assignToCapturedThis*/
-          true
-        );
-      }
-      return factory2.updateCallExpression(
-        node,
-        Debug.checkDefined(visitNode(node.expression, callExpressionVisitor, isExpression)),
-        /*typeArguments*/
-        void 0,
-        visitNodes2(node.arguments, visitor, isExpression)
-      );
-    }
-    function visitTypeScriptClassWrapper(node) {
-      const body = cast(cast(skipOuterExpressions(node.expression), isArrowFunction).body, isBlock);
-      const isVariableStatementWithInitializer = (stmt) => isVariableStatement(stmt) && !!first(stmt.declarationList.declarations).initializer;
-      const savedConvertedLoopState = convertedLoopState;
-      convertedLoopState = void 0;
-      const bodyStatements = visitNodes2(body.statements, classWrapperStatementVisitor, isStatement);
-      convertedLoopState = savedConvertedLoopState;
-      const classStatements = filter(bodyStatements, isVariableStatementWithInitializer);
-      const remainingStatements = filter(bodyStatements, (stmt) => !isVariableStatementWithInitializer(stmt));
-      const varStatement = cast(first(classStatements), isVariableStatement);
-      const variable = varStatement.declarationList.declarations[0];
-      const initializer = skipOuterExpressions(variable.initializer);
-      let aliasAssignment = tryCast(initializer, isAssignmentExpression);
-      if (!aliasAssignment && isBinaryExpression(initializer) && initializer.operatorToken.kind === 28 /* CommaToken */) {
-        aliasAssignment = tryCast(initializer.left, isAssignmentExpression);
-      }
-      const call = cast(aliasAssignment ? skipOuterExpressions(aliasAssignment.right) : initializer, isCallExpression);
-      const func = cast(skipOuterExpressions(call.expression), isFunctionExpression);
-      const funcStatements = func.body.statements;
-      let classBodyStart = 0;
-      let classBodyEnd = -1;
-      const statements = [];
-      if (aliasAssignment) {
-        const extendsCall = tryCast(funcStatements[classBodyStart], isExpressionStatement);
-        if (extendsCall) {
-          statements.push(extendsCall);
-          classBodyStart++;
-        }
-        statements.push(funcStatements[classBodyStart]);
-        classBodyStart++;
-        statements.push(
-          factory2.createExpressionStatement(
-            factory2.createAssignment(
-              aliasAssignment.left,
-              cast(variable.name, isIdentifier)
-            )
-          )
-        );
-      }
-      while (!isReturnStatement(elementAt(funcStatements, classBodyEnd))) {
-        classBodyEnd--;
-      }
-      addRange(statements, funcStatements, classBodyStart, classBodyEnd);
-      if (classBodyEnd < -1) {
-        addRange(statements, funcStatements, classBodyEnd + 1);
-      }
-      const returnStatement = tryCast(elementAt(funcStatements, classBodyEnd), isReturnStatement);
-      for (const statement of remainingStatements) {
-        if (isReturnStatement(statement) && (returnStatement == null ? void 0 : returnStatement.expression) && !isIdentifier(returnStatement.expression)) {
-          statements.push(returnStatement);
-        } else {
-          statements.push(statement);
-        }
-      }
-      addRange(
-        statements,
-        classStatements,
-        /*start*/
-        1
-      );
-      return factory2.restoreOuterExpressions(
-        node.expression,
-        factory2.restoreOuterExpressions(
-          variable.initializer,
-          factory2.restoreOuterExpressions(
-            aliasAssignment && aliasAssignment.right,
-            factory2.updateCallExpression(
-              call,
-              factory2.restoreOuterExpressions(
-                call.expression,
-                factory2.updateFunctionExpression(
-                  func,
-                  /*modifiers*/
-                  void 0,
-                  /*asteriskToken*/
-                  void 0,
-                  /*name*/
-                  void 0,
-                  /*typeParameters*/
-                  void 0,
-                  func.parameters,
-                  /*type*/
-                  void 0,
-                  factory2.updateBlock(
-                    func.body,
-                    statements
-                  )
-                )
-              ),
-              /*typeArguments*/
-              void 0,
-              call.arguments
-            )
-          )
-        )
-      );
-    }
-    function visitSuperCallInBody(node) {
-      return visitCallExpressionWithPotentialCapturedThisAssignment(
-        node,
-        /*assignToCapturedThis*/
-        false
-      );
-    }
-    function visitCallExpressionWithPotentialCapturedThisAssignment(node, assignToCapturedThis) {
-      if (node.transformFlags & 32768 /* ContainsRestOrSpread */ || node.expression.kind === 108 /* SuperKeyword */ || isSuperProperty(skipOuterExpressions(node.expression))) {
-        const { target, thisArg } = factory2.createCallBinding(node.expression, hoistVariableDeclaration);
-        if (node.expression.kind === 108 /* SuperKeyword */) {
-          setEmitFlags(thisArg, 8 /* NoSubstitution */);
-        }
-        let resultingCall;
-        if (node.transformFlags & 32768 /* ContainsRestOrSpread */) {
-          resultingCall = factory2.createFunctionApplyCall(
-            Debug.checkDefined(visitNode(target, callExpressionVisitor, isExpression)),
-            node.expression.kind === 108 /* SuperKeyword */ ? thisArg : Debug.checkDefined(visitNode(thisArg, visitor, isExpression)),
-            transformAndSpreadElements(
-              node.arguments,
-              /*isArgumentList*/
-              true,
-              /*multiLine*/
-              false,
-              /*hasTrailingComma*/
-              false
-            )
-          );
-        } else {
-          resultingCall = setTextRange(
-            factory2.createFunctionCallCall(
-              Debug.checkDefined(visitNode(target, callExpressionVisitor, isExpression)),
-              node.expression.kind === 108 /* SuperKeyword */ ? thisArg : Debug.checkDefined(visitNode(thisArg, visitor, isExpression)),
-              visitNodes2(node.arguments, visitor, isExpression)
-            ),
-            node
-          );
-        }
-        if (node.expression.kind === 108 /* SuperKeyword */) {
-          const initializer = factory2.createLogicalOr(
-            resultingCall,
-            createActualThis()
-          );
-          resultingCall = assignToCapturedThis ? factory2.createAssignment(factory2.createUniqueName("_this", 16 /* Optimistic */ | 32 /* FileLevel */), initializer) : initializer;
-        }
-        return setOriginalNode(resultingCall, node);
-      }
-      return visitEachChild(node, visitor, context);
-    }
-    function visitNewExpression(node) {
-      if (some(node.arguments, isSpreadElement)) {
-        const { target, thisArg } = factory2.createCallBinding(factory2.createPropertyAccessExpression(node.expression, "bind"), hoistVariableDeclaration);
-        return factory2.createNewExpression(
-          factory2.createFunctionApplyCall(
-            Debug.checkDefined(visitNode(target, visitor, isExpression)),
-            thisArg,
-            transformAndSpreadElements(
-              factory2.createNodeArray([factory2.createVoidZero(), ...node.arguments]),
-              /*isArgumentList*/
-              true,
-              /*multiLine*/
-              false,
-              /*hasTrailingComma*/
-              false
-            )
-          ),
-          /*typeArguments*/
-          void 0,
-          []
-        );
-      }
-      return visitEachChild(node, visitor, context);
-    }
-    function transformAndSpreadElements(elements, isArgumentList, multiLine, hasTrailingComma) {
-      const numElements = elements.length;
-      const segments = flatten(
-        // As we visit each element, we return one of two functions to use as the "key":
-        // - `visitSpanOfSpreads` for one or more contiguous `...` spread expressions, i.e. `...a, ...b` in `[1, 2, ...a, ...b]`
-        // - `visitSpanOfNonSpreads` for one or more contiguous non-spread elements, i.e. `1, 2`, in `[1, 2, ...a, ...b]`
-        spanMap(
-          elements,
-          partitionSpread,
-          (partition, visitPartition, _start, end) => visitPartition(partition, multiLine, hasTrailingComma && end === numElements)
-        )
-      );
-      if (segments.length === 1) {
-        const firstSegment = segments[0];
-        if (isArgumentList && !compilerOptions.downlevelIteration || isPackedArrayLiteral(firstSegment.expression) || isCallToHelper(firstSegment.expression, "___spreadArray")) {
-          return firstSegment.expression;
-        }
-      }
-      const helpers = emitHelpers();
-      const startsWithSpread = segments[0].kind !== 0 /* None */;
-      let expression = startsWithSpread ? factory2.createArrayLiteralExpression() : segments[0].expression;
-      for (let i = startsWithSpread ? 0 : 1; i < segments.length; i++) {
-        const segment = segments[i];
-        expression = helpers.createSpreadArrayHelper(
-          expression,
-          segment.expression,
-          segment.kind === 1 /* UnpackedSpread */ && !isArgumentList
-        );
-      }
-      return expression;
-    }
-    function partitionSpread(node) {
-      return isSpreadElement(node) ? visitSpanOfSpreads : visitSpanOfNonSpreads;
-    }
-    function visitSpanOfSpreads(chunk) {
-      return map(chunk, visitExpressionOfSpread);
-    }
-    function visitExpressionOfSpread(node) {
-      Debug.assertNode(node, isSpreadElement);
-      let expression = visitNode(node.expression, visitor, isExpression);
-      Debug.assert(expression);
-      const isCallToReadHelper = isCallToHelper(expression, "___read");
-      let kind = isCallToReadHelper || isPackedArrayLiteral(expression) ? 2 /* PackedSpread */ : 1 /* UnpackedSpread */;
-      if (compilerOptions.downlevelIteration && kind === 1 /* UnpackedSpread */ && !isArrayLiteralExpression(expression) && !isCallToReadHelper) {
-        expression = emitHelpers().createReadHelper(
-          expression,
-          /*count*/
-          void 0
-        );
-        kind = 2 /* PackedSpread */;
-      }
-      return createSpreadSegment(kind, expression);
-    }
-    function visitSpanOfNonSpreads(chunk, multiLine, hasTrailingComma) {
-      const expression = factory2.createArrayLiteralExpression(
-        visitNodes2(factory2.createNodeArray(chunk, hasTrailingComma), visitor, isExpression),
-        multiLine
-      );
-      return createSpreadSegment(0 /* None */, expression);
-    }
-    function visitSpreadElement(node) {
-      return visitNode(node.expression, visitor, isExpression);
-    }
-    function visitTemplateLiteral(node) {
-      return setTextRange(factory2.createStringLiteral(node.text), node);
-    }
-    function visitStringLiteral(node) {
-      if (node.hasExtendedUnicodeEscape) {
-        return setTextRange(factory2.createStringLiteral(node.text), node);
-      }
-      return node;
-    }
-    function visitNumericLiteral(node) {
-      if (node.numericLiteralFlags & 384 /* BinaryOrOctalSpecifier */) {
-        return setTextRange(factory2.createNumericLiteral(node.text), node);
-      }
-      return node;
-    }
-    function visitTaggedTemplateExpression(node) {
-      return processTaggedTemplateExpression(
-        context,
-        node,
-        visitor,
-        currentSourceFile,
-        recordTaggedTemplateString,
-        1 /* All */
-      );
-    }
-    function visitTemplateExpression(node) {
-      let expression = factory2.createStringLiteral(node.head.text);
-      for (const span of node.templateSpans) {
-        const args = [Debug.checkDefined(visitNode(span.expression, visitor, isExpression))];
-        if (span.literal.text.length > 0) {
-          args.push(factory2.createStringLiteral(span.literal.text));
-        }
-        expression = factory2.createCallExpression(
-          factory2.createPropertyAccessExpression(expression, "concat"),
-          /*typeArguments*/
-          void 0,
-          args
-        );
-      }
-      return setTextRange(expression, node);
-    }
-    function visitSuperKeyword(isExpressionOfCall) {
-      return hierarchyFacts & 8 /* NonStaticClassElement */ && !isExpressionOfCall ? factory2.createPropertyAccessExpression(factory2.createUniqueName("_super", 16 /* Optimistic */ | 32 /* FileLevel */), "prototype") : factory2.createUniqueName("_super", 16 /* Optimistic */ | 32 /* FileLevel */);
-    }
-    function visitMetaProperty(node) {
-      if (node.keywordToken === 105 /* NewKeyword */ && node.name.escapedText === "target") {
-        hierarchyFacts |= 32768 /* NewTarget */;
-        return factory2.createUniqueName("_newTarget", 16 /* Optimistic */ | 32 /* FileLevel */);
-      }
-      return node;
-    }
-    function onEmitNode(hint, node, emitCallback) {
-      if (enabledSubstitutions & 1 /* CapturedThis */ && isFunctionLike(node)) {
-        const ancestorFacts = enterSubtree(
-          32670 /* FunctionExcludes */,
-          getEmitFlags(node) & 16 /* CapturesThis */ ? 65 /* FunctionIncludes */ | 16 /* CapturesThis */ : 65 /* FunctionIncludes */
-        );
-        previousOnEmitNode(hint, node, emitCallback);
-        exitSubtree(ancestorFacts, 0 /* None */, 0 /* None */);
-        return;
-      }
-      previousOnEmitNode(hint, node, emitCallback);
-    }
-    function enableSubstitutionsForBlockScopedBindings() {
-      if ((enabledSubstitutions & 2 /* BlockScopedBindings */) === 0) {
-        enabledSubstitutions |= 2 /* BlockScopedBindings */;
-        context.enableSubstitution(80 /* Identifier */);
-      }
-    }
-    function enableSubstitutionsForCapturedThis() {
-      if ((enabledSubstitutions & 1 /* CapturedThis */) === 0) {
-        enabledSubstitutions |= 1 /* CapturedThis */;
-        context.enableSubstitution(110 /* ThisKeyword */);
-        context.enableEmitNotification(175 /* Constructor */);
-        context.enableEmitNotification(173 /* MethodDeclaration */);
-        context.enableEmitNotification(176 /* GetAccessor */);
-        context.enableEmitNotification(177 /* SetAccessor */);
-        context.enableEmitNotification(218 /* ArrowFunction */);
-        context.enableEmitNotification(217 /* FunctionExpression */);
-        context.enableEmitNotification(261 /* FunctionDeclaration */);
-      }
-    }
-    function onSubstituteNode(hint, node) {
-      node = previousOnSubstituteNode(hint, node);
-      if (hint === 1 /* Expression */) {
-        return substituteExpression(node);
-      }
-      if (isIdentifier(node)) {
-        return substituteIdentifier(node);
-      }
-      return node;
-    }
-    function substituteIdentifier(node) {
-      if (enabledSubstitutions & 2 /* BlockScopedBindings */ && !isInternalName(node)) {
-        const original = getParseTreeNode(node, isIdentifier);
-        if (original && isNameOfDeclarationWithCollidingName(original)) {
-          return setTextRange(factory2.getGeneratedNameForNode(original), node);
-        }
-      }
-      return node;
-    }
-    function isNameOfDeclarationWithCollidingName(node) {
-      switch (node.parent.kind) {
-        case 207 /* BindingElement */:
-        case 262 /* ClassDeclaration */:
-        case 265 /* EnumDeclaration */:
-        case 259 /* VariableDeclaration */:
-          return node.parent.name === node && resolver.isDeclarationWithCollidingName(node.parent);
-      }
-      return false;
-    }
-    function substituteExpression(node) {
-      switch (node.kind) {
-        case 80 /* Identifier */:
-          return substituteExpressionIdentifier(node);
-        case 110 /* ThisKeyword */:
-          return substituteThisKeyword(node);
-      }
-      return node;
-    }
-    function substituteExpressionIdentifier(node) {
-      if (enabledSubstitutions & 2 /* BlockScopedBindings */ && !isInternalName(node)) {
-        const declaration = resolver.getReferencedDeclarationWithCollidingName(node);
-        if (declaration && !(isClassLike(declaration) && isPartOfClassBody(declaration, node))) {
-          return setTextRange(factory2.getGeneratedNameForNode(getNameOfDeclaration(declaration)), node);
-        }
-      }
-      return node;
-    }
-    function isPartOfClassBody(declaration, node) {
-      let currentNode = getParseTreeNode(node);
-      if (!currentNode || currentNode === declaration || currentNode.end <= declaration.pos || currentNode.pos >= declaration.end) {
-        return false;
-      }
-      const blockScope = getEnclosingBlockScopeContainer(declaration);
-      while (currentNode) {
-        if (currentNode === blockScope || currentNode === declaration) {
-          return false;
-        }
-        if (isClassElement(currentNode) && currentNode.parent === declaration) {
-          return true;
-        }
-        currentNode = currentNode.parent;
-      }
-      return false;
-    }
-    function substituteThisKeyword(node) {
-      if (enabledSubstitutions & 1 /* CapturedThis */ && hierarchyFacts & 16 /* CapturesThis */) {
-        return setTextRange(factory2.createUniqueName("_this", 16 /* Optimistic */ | 32 /* FileLevel */), node);
-      }
-      return node;
-    }
-    function getClassMemberPrefix(node, member) {
-      return isStatic(member) ? factory2.getInternalName(node) : factory2.createPropertyAccessExpression(factory2.getInternalName(node), "prototype");
-    }
-    function hasSynthesizedDefaultSuperCall(constructor, hasExtendsClause) {
-      if (!constructor || !hasExtendsClause) {
-        return false;
-      }
-      if (some(constructor.parameters)) {
-        return false;
-      }
-      const statement = firstOrUndefined(constructor.body.statements);
-      if (!statement || !nodeIsSynthesized(statement) || statement.kind !== 243 /* ExpressionStatement */) {
-        return false;
-      }
-      const statementExpression = statement.expression;
-      if (!nodeIsSynthesized(statementExpression) || statementExpression.kind !== 212 /* CallExpression */) {
-        return false;
-      }
-      const callTarget = statementExpression.expression;
-      if (!nodeIsSynthesized(callTarget) || callTarget.kind !== 108 /* SuperKeyword */) {
-        return false;
-      }
-      const callArgument = singleOrUndefined(statementExpression.arguments);
-      if (!callArgument || !nodeIsSynthesized(callArgument) || callArgument.kind !== 229 /* SpreadElement */) {
-        return false;
-      }
-      const expression = callArgument.expression;
-      return isIdentifier(expression) && expression.escapedText === "arguments";
-    }
-  }
-  var init_es2015 = __esm({
-    "src/compiler/transformers/es2015.ts"() {
-      "use strict";
-      init_ts2();
-    }
-  });
-
-  // src/compiler/transformers/es5.ts
-  function transformES5(context) {
-    const { factory: factory2 } = context;
-    const compilerOptions = context.getCompilerOptions();
-    let previousOnEmitNode;
-    let noSubstitution;
-    if (compilerOptions.jsx === 1 /* Preserve */ || compilerOptions.jsx === 3 /* ReactNative */) {
-      previousOnEmitNode = context.onEmitNode;
-      context.onEmitNode = onEmitNode;
-      context.enableEmitNotification(285 /* JsxOpeningElement */);
-      context.enableEmitNotification(286 /* JsxClosingElement */);
-      context.enableEmitNotification(284 /* JsxSelfClosingElement */);
-      noSubstitution = [];
-    }
-    const previousOnSubstituteNode = context.onSubstituteNode;
-    context.onSubstituteNode = onSubstituteNode;
-    context.enableSubstitution(210 /* PropertyAccessExpression */);
-    context.enableSubstitution(302 /* PropertyAssignment */);
-    return chainBundle(context, transformSourceFile);
-    function transformSourceFile(node) {
-      return node;
-    }
-    function onEmitNode(hint, node, emitCallback) {
-      switch (node.kind) {
-        case 285 /* JsxOpeningElement */:
-        case 286 /* JsxClosingElement */:
-        case 284 /* JsxSelfClosingElement */:
-          const tagName = node.tagName;
-          noSubstitution[getOriginalNodeId(tagName)] = true;
-          break;
-      }
-      previousOnEmitNode(hint, node, emitCallback);
-    }
-    function onSubstituteNode(hint, node) {
-      if (node.id && noSubstitution && noSubstitution[node.id]) {
-        return previousOnSubstituteNode(hint, node);
-      }
-      node = previousOnSubstituteNode(hint, node);
-      if (isPropertyAccessExpression(node)) {
-        return substitutePropertyAccessExpression(node);
-      } else if (isPropertyAssignment(node)) {
-        return substitutePropertyAssignment(node);
-      }
-      return node;
-    }
-    function substitutePropertyAccessExpression(node) {
-      if (isPrivateIdentifier(node.name)) {
-        return node;
-      }
-      const literalName = trySubstituteReservedName(node.name);
-      if (literalName) {
-        return setTextRange(factory2.createElementAccessExpression(node.expression, literalName), node);
-      }
-      return node;
-    }
-    function substitutePropertyAssignment(node) {
-      const literalName = isIdentifier(node.name) && trySubstituteReservedName(node.name);
-      if (literalName) {
-        return factory2.updatePropertyAssignment(node, literalName, node.initializer);
-      }
-      return node;
-    }
-    function trySubstituteReservedName(name) {
-      const token = identifierToKeywordKind(name);
-      if (token !== void 0 && token >= 83 /* FirstReservedWord */ && token <= 118 /* LastReservedWord */) {
-        return setTextRange(factory2.createStringLiteralFromNode(name), name);
-      }
-      return void 0;
-    }
-  }
-  var init_es5 = __esm({
-    "src/compiler/transformers/es5.ts"() {
-      "use strict";
-      init_ts2();
-    }
-  });
-
-  // src/compiler/transformers/generators.ts
-  function getInstructionName(instruction) {
-    switch (instruction) {
-      case 2 /* Return */:
-        return "return";
-      case 3 /* Break */:
-        return "break";
-      case 4 /* Yield */:
-        return "yield";
-      case 5 /* YieldStar */:
-        return "yield*";
-      case 7 /* Endfinally */:
-        return "endfinally";
-      default:
-        return void 0;
-    }
-  }
-  function transformGenerators(context) {
-    const {
-      factory: factory2,
-      getEmitHelperFactory: emitHelpers,
-      resumeLexicalEnvironment,
-      endLexicalEnvironment,
-      hoistFunctionDeclaration,
-      hoistVariableDeclaration
-    } = context;
-    const compilerOptions = context.getCompilerOptions();
-    const languageVersion = getEmitScriptTarget(compilerOptions);
-    const resolver = context.getEmitResolver();
-    const previousOnSubstituteNode = context.onSubstituteNode;
-    context.onSubstituteNode = onSubstituteNode;
-    let renamedCatchVariables;
-    let renamedCatchVariableDeclarations;
-    let inGeneratorFunctionBody;
-    let inStatementContainingYield;
-    let blocks;
-    let blockOffsets;
-    let blockActions;
-    let blockStack;
-    let labelOffsets;
-    let labelExpressions;
-    let nextLabelId = 1;
-    let operations;
-    let operationArguments;
-    let operationLocations;
-    let state;
-    let blockIndex = 0;
-    let labelNumber = 0;
-    let labelNumbers;
-    let lastOperationWasAbrupt;
-    let lastOperationWasCompletion;
-    let clauses;
-    let statements;
-    let exceptionBlockStack;
-    let currentExceptionBlock;
-    let withBlockStack;
-    return chainBundle(context, transformSourceFile);
-    function transformSourceFile(node) {
-      if (node.isDeclarationFile || (node.transformFlags & 2048 /* ContainsGenerator */) === 0) {
-        return node;
-      }
-      const visited = visitEachChild(node, visitor, context);
-      addEmitHelpers(visited, context.readEmitHelpers());
-      return visited;
-    }
-    function visitor(node) {
-      const transformFlags = node.transformFlags;
-      if (inStatementContainingYield) {
-        return visitJavaScriptInStatementContainingYield(node);
-      } else if (inGeneratorFunctionBody) {
-        return visitJavaScriptInGeneratorFunctionBody(node);
-      } else if (isFunctionLikeDeclaration(node) && node.asteriskToken) {
-        return visitGenerator(node);
-      } else if (transformFlags & 2048 /* ContainsGenerator */) {
-        return visitEachChild(node, visitor, context);
-      } else {
-        return node;
-      }
-    }
-    function visitJavaScriptInStatementContainingYield(node) {
-      switch (node.kind) {
-        case 245 /* DoStatement */:
-          return visitDoStatement(node);
-        case 246 /* WhileStatement */:
-          return visitWhileStatement(node);
-        case 254 /* SwitchStatement */:
-          return visitSwitchStatement(node);
-        case 255 /* LabeledStatement */:
-          return visitLabeledStatement(node);
-        default:
-          return visitJavaScriptInGeneratorFunctionBody(node);
-      }
-    }
-    function visitJavaScriptInGeneratorFunctionBody(node) {
-      switch (node.kind) {
-        case 261 /* FunctionDeclaration */:
-          return visitFunctionDeclaration(node);
-        case 217 /* FunctionExpression */:
-          return visitFunctionExpression(node);
-        case 176 /* GetAccessor */:
-        case 177 /* SetAccessor */:
-          return visitAccessorDeclaration(node);
-        case 242 /* VariableStatement */:
-          return visitVariableStatement(node);
-        case 247 /* ForStatement */:
-          return visitForStatement(node);
-        case 248 /* ForInStatement */:
-          return visitForInStatement(node);
-        case 251 /* BreakStatement */:
-          return visitBreakStatement(node);
-        case 250 /* ContinueStatement */:
-          return visitContinueStatement(node);
-        case 252 /* ReturnStatement */:
-          return visitReturnStatement(node);
-        default:
-          if (node.transformFlags & 1048576 /* ContainsYield */) {
-            return visitJavaScriptContainingYield(node);
-          } else if (node.transformFlags & (2048 /* ContainsGenerator */ | 4194304 /* ContainsHoistedDeclarationOrCompletion */)) {
-            return visitEachChild(node, visitor, context);
-          } else {
-            return node;
-          }
-      }
-    }
-    function visitJavaScriptContainingYield(node) {
-      switch (node.kind) {
-        case 225 /* BinaryExpression */:
-          return visitBinaryExpression(node);
-        case 360 /* CommaListExpression */:
-          return visitCommaListExpression(node);
-        case 226 /* ConditionalExpression */:
-          return visitConditionalExpression(node);
-        case 228 /* YieldExpression */:
-          return visitYieldExpression(node);
-        case 208 /* ArrayLiteralExpression */:
-          return visitArrayLiteralExpression(node);
-        case 209 /* ObjectLiteralExpression */:
-          return visitObjectLiteralExpression(node);
-        case 211 /* ElementAccessExpression */:
-          return visitElementAccessExpression(node);
-        case 212 /* CallExpression */:
-          return visitCallExpression(node);
-        case 213 /* NewExpression */:
-          return visitNewExpression(node);
-        default:
-          return visitEachChild(node, visitor, context);
-      }
-    }
-    function visitGenerator(node) {
-      switch (node.kind) {
-        case 261 /* FunctionDeclaration */:
-          return visitFunctionDeclaration(node);
-        case 217 /* FunctionExpression */:
-          return visitFunctionExpression(node);
-        default:
-          return Debug.failBadSyntaxKind(node);
-      }
-    }
-    function visitFunctionDeclaration(node) {
-      if (node.asteriskToken) {
-        node = setOriginalNode(
-          setTextRange(
-            factory2.createFunctionDeclaration(
-              node.modifiers,
-              /*asteriskToken*/
-              void 0,
-              node.name,
-              /*typeParameters*/
-              void 0,
-              visitParameterList(node.parameters, visitor, context),
-              /*type*/
-              void 0,
-              transformGeneratorFunctionBody(node.body)
-            ),
-            /*location*/
-            node
-          ),
-          node
-        );
-      } else {
-        const savedInGeneratorFunctionBody = inGeneratorFunctionBody;
-        const savedInStatementContainingYield = inStatementContainingYield;
-        inGeneratorFunctionBody = false;
-        inStatementContainingYield = false;
-        node = visitEachChild(node, visitor, context);
-        inGeneratorFunctionBody = savedInGeneratorFunctionBody;
-        inStatementContainingYield = savedInStatementContainingYield;
-      }
-      if (inGeneratorFunctionBody) {
-        hoistFunctionDeclaration(node);
-        return void 0;
-      } else {
-        return node;
-      }
-    }
-    function visitFunctionExpression(node) {
-      if (node.asteriskToken) {
-        node = setOriginalNode(
-          setTextRange(
-            factory2.createFunctionExpression(
-              /*modifiers*/
-              void 0,
-              /*asteriskToken*/
-              void 0,
-              node.name,
-              /*typeParameters*/
-              void 0,
-              visitParameterList(node.parameters, visitor, context),
-              /*type*/
-              void 0,
-              transformGeneratorFunctionBody(node.body)
-            ),
-            /*location*/
-            node
-          ),
-          node
-        );
-      } else {
-        const savedInGeneratorFunctionBody = inGeneratorFunctionBody;
-        const savedInStatementContainingYield = inStatementContainingYield;
-        inGeneratorFunctionBody = false;
-        inStatementContainingYield = false;
-        node = visitEachChild(node, visitor, context);
-        inGeneratorFunctionBody = savedInGeneratorFunctionBody;
-        inStatementContainingYield = savedInStatementContainingYield;
-      }
-      return node;
-    }
-    function visitAccessorDeclaration(node) {
-      const savedInGeneratorFunctionBody = inGeneratorFunctionBody;
-      const savedInStatementContainingYield = inStatementContainingYield;
-      inGeneratorFunctionBody = false;
-      inStatementContainingYield = false;
-      node = visitEachChild(node, visitor, context);
-      inGeneratorFunctionBody = savedInGeneratorFunctionBody;
-      inStatementContainingYield = savedInStatementContainingYield;
-      return node;
-    }
-    function transformGeneratorFunctionBody(body) {
-      const statements2 = [];
-      const savedInGeneratorFunctionBody = inGeneratorFunctionBody;
-      const savedInStatementContainingYield = inStatementContainingYield;
-      const savedBlocks = blocks;
-      const savedBlockOffsets = blockOffsets;
-      const savedBlockActions = blockActions;
-      const savedBlockStack = blockStack;
-      const savedLabelOffsets = labelOffsets;
-      const savedLabelExpressions = labelExpressions;
-      const savedNextLabelId = nextLabelId;
-      const savedOperations = operations;
-      const savedOperationArguments = operationArguments;
-      const savedOperationLocations = operationLocations;
-      const savedState = state;
-      inGeneratorFunctionBody = true;
-      inStatementContainingYield = false;
-      blocks = void 0;
-      blockOffsets = void 0;
-      blockActions = void 0;
-      blockStack = void 0;
-      labelOffsets = void 0;
-      labelExpressions = void 0;
-      nextLabelId = 1;
-      operations = void 0;
-      operationArguments = void 0;
-      operationLocations = void 0;
-      state = factory2.createTempVariable(
-        /*recordTempVariable*/
-        void 0
-      );
-      resumeLexicalEnvironment();
-      const statementOffset = factory2.copyPrologue(
-        body.statements,
-        statements2,
-        /*ensureUseStrict*/
-        false,
-        visitor
-      );
-      transformAndEmitStatements(body.statements, statementOffset);
-      const buildResult = build2();
-      insertStatementsAfterStandardPrologue(statements2, endLexicalEnvironment());
-      statements2.push(factory2.createReturnStatement(buildResult));
-      inGeneratorFunctionBody = savedInGeneratorFunctionBody;
-      inStatementContainingYield = savedInStatementContainingYield;
-      blocks = savedBlocks;
-      blockOffsets = savedBlockOffsets;
-      blockActions = savedBlockActions;
-      blockStack = savedBlockStack;
-      labelOffsets = savedLabelOffsets;
-      labelExpressions = savedLabelExpressions;
-      nextLabelId = savedNextLabelId;
-      operations = savedOperations;
-      operationArguments = savedOperationArguments;
-      operationLocations = savedOperationLocations;
-      state = savedState;
-      return setTextRange(factory2.createBlock(statements2, body.multiLine), body);
-    }
-    function visitVariableStatement(node) {
-      if (node.transformFlags & 1048576 /* ContainsYield */) {
-        transformAndEmitVariableDeclarationList(node.declarationList);
-        return void 0;
-      } else {
-        if (getEmitFlags(node) & 2097152 /* CustomPrologue */) {
-          return node;
-        }
-        for (const variable of node.declarationList.declarations) {
-          hoistVariableDeclaration(variable.name);
-        }
-        const variables = getInitializedVariables(node.declarationList);
-        if (variables.length === 0) {
-          return void 0;
-        }
-        return setSourceMapRange(
-          factory2.createExpressionStatement(
-            factory2.inlineExpressions(
-              map(variables, transformInitializedVariable)
-            )
-          ),
-          node
-        );
-      }
-    }
-    function visitBinaryExpression(node) {
-      const assoc = getExpressionAssociativity(node);
-      switch (assoc) {
-        case 0 /* Left */:
-          return visitLeftAssociativeBinaryExpression(node);
-        case 1 /* Right */:
-          return visitRightAssociativeBinaryExpression(node);
-        default:
-          return Debug.assertNever(assoc);
-      }
-    }
-    function visitRightAssociativeBinaryExpression(node) {
-      const { left, right } = node;
-      if (containsYield(right)) {
-        let target;
-        switch (left.kind) {
-          case 210 /* PropertyAccessExpression */:
-            target = factory2.updatePropertyAccessExpression(
-              left,
-              cacheExpression(Debug.checkDefined(visitNode(left.expression, visitor, isLeftHandSideExpression))),
-              left.name
-            );
-            break;
-          case 211 /* ElementAccessExpression */:
-            target = factory2.updateElementAccessExpression(
-              left,
-              cacheExpression(Debug.checkDefined(visitNode(left.expression, visitor, isLeftHandSideExpression))),
-              cacheExpression(Debug.checkDefined(visitNode(left.argumentExpression, visitor, isExpression)))
-            );
-            break;
-          default:
-            target = Debug.checkDefined(visitNode(left, visitor, isExpression));
-            break;
-        }
-        const operator = node.operatorToken.kind;
-        if (isCompoundAssignment(operator)) {
-          return setTextRange(
-            factory2.createAssignment(
-              target,
-              setTextRange(
-                factory2.createBinaryExpression(
-                  cacheExpression(target),
-                  getNonAssignmentOperatorForCompoundAssignment(operator),
-                  Debug.checkDefined(visitNode(right, visitor, isExpression))
-                ),
-                node
-              )
-            ),
-            node
-          );
-        } else {
-          return factory2.updateBinaryExpression(node, target, node.operatorToken, Debug.checkDefined(visitNode(right, visitor, isExpression)));
-        }
-      }
-      return visitEachChild(node, visitor, context);
-    }
-    function visitLeftAssociativeBinaryExpression(node) {
-      if (containsYield(node.right)) {
-        if (isLogicalOperator(node.operatorToken.kind)) {
-          return visitLogicalBinaryExpression(node);
-        } else if (node.operatorToken.kind === 28 /* CommaToken */) {
-          return visitCommaExpression(node);
-        }
-        return factory2.updateBinaryExpression(
-          node,
-          cacheExpression(Debug.checkDefined(visitNode(node.left, visitor, isExpression))),
-          node.operatorToken,
-          Debug.checkDefined(visitNode(node.right, visitor, isExpression))
-        );
-      }
-      return visitEachChild(node, visitor, context);
-    }
-    function visitCommaExpression(node) {
-      let pendingExpressions = [];
-      visit(node.left);
-      visit(node.right);
-      return factory2.inlineExpressions(pendingExpressions);
-      function visit(node2) {
-        if (isBinaryExpression(node2) && node2.operatorToken.kind === 28 /* CommaToken */) {
-          visit(node2.left);
-          visit(node2.right);
-        } else {
-          if (containsYield(node2) && pendingExpressions.length > 0) {
-            emitWorker(1 /* Statement */, [factory2.createExpressionStatement(factory2.inlineExpressions(pendingExpressions))]);
-            pendingExpressions = [];
-          }
-          pendingExpressions.push(Debug.checkDefined(visitNode(node2, visitor, isExpression)));
-        }
-      }
-    }
-    function visitCommaListExpression(node) {
-      let pendingExpressions = [];
-      for (const elem of node.elements) {
-        if (isBinaryExpression(elem) && elem.operatorToken.kind === 28 /* CommaToken */) {
-          pendingExpressions.push(visitCommaExpression(elem));
-        } else {
-          if (containsYield(elem) && pendingExpressions.length > 0) {
-            emitWorker(1 /* Statement */, [factory2.createExpressionStatement(factory2.inlineExpressions(pendingExpressions))]);
-            pendingExpressions = [];
-          }
-          pendingExpressions.push(Debug.checkDefined(visitNode(elem, visitor, isExpression)));
-        }
-      }
-      return factory2.inlineExpressions(pendingExpressions);
-    }
-    function visitLogicalBinaryExpression(node) {
-      const resultLabel = defineLabel();
-      const resultLocal = declareLocal();
-      emitAssignment(
-        resultLocal,
-        Debug.checkDefined(visitNode(node.left, visitor, isExpression)),
-        /*location*/
-        node.left
-      );
-      if (node.operatorToken.kind === 56 /* AmpersandAmpersandToken */) {
-        emitBreakWhenFalse(
-          resultLabel,
-          resultLocal,
-          /*location*/
-          node.left
-        );
-      } else {
-        emitBreakWhenTrue(
-          resultLabel,
-          resultLocal,
-          /*location*/
-          node.left
-        );
-      }
-      emitAssignment(
-        resultLocal,
-        Debug.checkDefined(visitNode(node.right, visitor, isExpression)),
-        /*location*/
-        node.right
-      );
-      markLabel(resultLabel);
-      return resultLocal;
-    }
-    function visitConditionalExpression(node) {
-      if (containsYield(node.whenTrue) || containsYield(node.whenFalse)) {
-        const whenFalseLabel = defineLabel();
-        const resultLabel = defineLabel();
-        const resultLocal = declareLocal();
-        emitBreakWhenFalse(
-          whenFalseLabel,
-          Debug.checkDefined(visitNode(node.condition, visitor, isExpression)),
-          /*location*/
-          node.condition
-        );
-        emitAssignment(
-          resultLocal,
-          Debug.checkDefined(visitNode(node.whenTrue, visitor, isExpression)),
-          /*location*/
-          node.whenTrue
-        );
-        emitBreak(resultLabel);
-        markLabel(whenFalseLabel);
-        emitAssignment(
-          resultLocal,
-          Debug.checkDefined(visitNode(node.whenFalse, visitor, isExpression)),
-          /*location*/
-          node.whenFalse
-        );
-        markLabel(resultLabel);
-        return resultLocal;
-      }
-      return visitEachChild(node, visitor, context);
-    }
-    function visitYieldExpression(node) {
-      const resumeLabel = defineLabel();
-      const expression = visitNode(node.expression, visitor, isExpression);
-      if (node.asteriskToken) {
-        const iterator = (getEmitFlags(node.expression) & 8388608 /* Iterator */) === 0 ? setTextRange(emitHelpers().createValuesHelper(expression), node) : expression;
-        emitYieldStar(
-          iterator,
-          /*location*/
-          node
-        );
-      } else {
-        emitYield(
-          expression,
-          /*location*/
-          node
-        );
-      }
-      markLabel(resumeLabel);
-      return createGeneratorResume(
-        /*location*/
-        node
-      );
-    }
-    function visitArrayLiteralExpression(node) {
-      return visitElements(
-        node.elements,
-        /*leadingElement*/
-        void 0,
-        /*location*/
-        void 0,
-        node.multiLine
-      );
-    }
-    function visitElements(elements, leadingElement, location, multiLine) {
-      const numInitialElements = countInitialNodesWithoutYield(elements);
-      let temp;
-      if (numInitialElements > 0) {
-        temp = declareLocal();
-        const initialElements = visitNodes2(elements, visitor, isExpression, 0, numInitialElements);
-        emitAssignment(
-          temp,
-          factory2.createArrayLiteralExpression(
-            leadingElement ? [leadingElement, ...initialElements] : initialElements
-          )
-        );
-        leadingElement = void 0;
-      }
-      const expressions = reduceLeft(elements, reduceElement, [], numInitialElements);
-      return temp ? factory2.createArrayConcatCall(temp, [factory2.createArrayLiteralExpression(expressions, multiLine)]) : setTextRange(
-        factory2.createArrayLiteralExpression(leadingElement ? [leadingElement, ...expressions] : expressions, multiLine),
-        location
-      );
-      function reduceElement(expressions2, element) {
-        if (containsYield(element) && expressions2.length > 0) {
-          const hasAssignedTemp = temp !== void 0;
-          if (!temp) {
-            temp = declareLocal();
-          }
-          emitAssignment(
-            temp,
-            hasAssignedTemp ? factory2.createArrayConcatCall(
-              temp,
-              [factory2.createArrayLiteralExpression(expressions2, multiLine)]
-            ) : factory2.createArrayLiteralExpression(
-              leadingElement ? [leadingElement, ...expressions2] : expressions2,
-              multiLine
-            )
-          );
-          leadingElement = void 0;
-          expressions2 = [];
-        }
-        expressions2.push(Debug.checkDefined(visitNode(element, visitor, isExpression)));
-        return expressions2;
-      }
-    }
-    function visitObjectLiteralExpression(node) {
-      const properties = node.properties;
-      const multiLine = node.multiLine;
-      const numInitialProperties = countInitialNodesWithoutYield(properties);
-      const temp = declareLocal();
-      emitAssignment(
-        temp,
-        factory2.createObjectLiteralExpression(
-          visitNodes2(properties, visitor, isObjectLiteralElementLike, 0, numInitialProperties),
-          multiLine
-        )
-      );
-      const expressions = reduceLeft(properties, reduceProperty, [], numInitialProperties);
-      expressions.push(multiLine ? startOnNewLine(setParent(setTextRange(factory2.cloneNode(temp), temp), temp.parent)) : temp);
-      return factory2.inlineExpressions(expressions);
-      function reduceProperty(expressions2, property) {
-        if (containsYield(property) && expressions2.length > 0) {
-          emitStatement(factory2.createExpressionStatement(factory2.inlineExpressions(expressions2)));
-          expressions2 = [];
-        }
-        const expression = createExpressionForObjectLiteralElementLike(factory2, node, property, temp);
-        const visited = visitNode(expression, visitor, isExpression);
-        if (visited) {
-          if (multiLine) {
-            startOnNewLine(visited);
-          }
-          expressions2.push(visited);
-        }
-        return expressions2;
-      }
-    }
-    function visitElementAccessExpression(node) {
-      if (containsYield(node.argumentExpression)) {
-        return factory2.updateElementAccessExpression(
-          node,
-          cacheExpression(Debug.checkDefined(visitNode(node.expression, visitor, isLeftHandSideExpression))),
-          Debug.checkDefined(visitNode(node.argumentExpression, visitor, isExpression))
-        );
-      }
-      return visitEachChild(node, visitor, context);
-    }
-    function visitCallExpression(node) {
-      if (!isImportCall(node) && forEach(node.arguments, containsYield)) {
-        const { target, thisArg } = factory2.createCallBinding(
-          node.expression,
-          hoistVariableDeclaration,
-          languageVersion,
-          /*cacheIdentifiers*/
-          true
-        );
-        return setOriginalNode(
-          setTextRange(
-            factory2.createFunctionApplyCall(
-              cacheExpression(Debug.checkDefined(visitNode(target, visitor, isLeftHandSideExpression))),
-              thisArg,
-              visitElements(node.arguments)
-            ),
-            node
-          ),
-          node
-        );
-      }
-      return visitEachChild(node, visitor, context);
-    }
-    function visitNewExpression(node) {
-      if (forEach(node.arguments, containsYield)) {
-        const { target, thisArg } = factory2.createCallBinding(factory2.createPropertyAccessExpression(node.expression, "bind"), hoistVariableDeclaration);
-        return setOriginalNode(
-          setTextRange(
-            factory2.createNewExpression(
-              factory2.createFunctionApplyCall(
-                cacheExpression(Debug.checkDefined(visitNode(target, visitor, isExpression))),
-                thisArg,
-                visitElements(
-                  node.arguments,
-                  /*leadingElement*/
-                  factory2.createVoidZero()
-                )
-              ),
-              /*typeArguments*/
-              void 0,
-              []
-            ),
-            node
-          ),
-          node
-        );
-      }
-      return visitEachChild(node, visitor, context);
-    }
-    function transformAndEmitStatements(statements2, start = 0) {
-      const numStatements = statements2.length;
-      for (let i = start; i < numStatements; i++) {
-        transformAndEmitStatement(statements2[i]);
-      }
-    }
-    function transformAndEmitEmbeddedStatement(node) {
-      if (isBlock(node)) {
-        transformAndEmitStatements(node.statements);
-      } else {
-        transformAndEmitStatement(node);
-      }
-    }
-    function transformAndEmitStatement(node) {
-      const savedInStatementContainingYield = inStatementContainingYield;
-      if (!inStatementContainingYield) {
-        inStatementContainingYield = containsYield(node);
-      }
-      transformAndEmitStatementWorker(node);
-      inStatementContainingYield = savedInStatementContainingYield;
-    }
-    function transformAndEmitStatementWorker(node) {
-      switch (node.kind) {
-        case 240 /* Block */:
-          return transformAndEmitBlock(node);
-        case 243 /* ExpressionStatement */:
-          return transformAndEmitExpressionStatement(node);
-        case 244 /* IfStatement */:
-          return transformAndEmitIfStatement(node);
-        case 245 /* DoStatement */:
-          return transformAndEmitDoStatement(node);
-        case 246 /* WhileStatement */:
-          return transformAndEmitWhileStatement(node);
-        case 247 /* ForStatement */:
-          return transformAndEmitForStatement(node);
-        case 248 /* ForInStatement */:
-          return transformAndEmitForInStatement(node);
-        case 250 /* ContinueStatement */:
-          return transformAndEmitContinueStatement(node);
-        case 251 /* BreakStatement */:
-          return transformAndEmitBreakStatement(node);
-        case 252 /* ReturnStatement */:
-          return transformAndEmitReturnStatement(node);
-        case 253 /* WithStatement */:
-          return transformAndEmitWithStatement(node);
-        case 254 /* SwitchStatement */:
-          return transformAndEmitSwitchStatement(node);
-        case 255 /* LabeledStatement */:
-          return transformAndEmitLabeledStatement(node);
-        case 256 /* ThrowStatement */:
-          return transformAndEmitThrowStatement(node);
-        case 257 /* TryStatement */:
-          return transformAndEmitTryStatement(node);
-        default:
-          return emitStatement(visitNode(node, visitor, isStatement));
-      }
-    }
-    function transformAndEmitBlock(node) {
-      if (containsYield(node)) {
-        transformAndEmitStatements(node.statements);
-      } else {
-        emitStatement(visitNode(node, visitor, isStatement));
-      }
-    }
-    function transformAndEmitExpressionStatement(node) {
-      emitStatement(visitNode(node, visitor, isStatement));
-    }
-    function transformAndEmitVariableDeclarationList(node) {
-      for (const variable of node.declarations) {
-        const name = factory2.cloneNode(variable.name);
-        setCommentRange(name, variable.name);
-        hoistVariableDeclaration(name);
-      }
-      const variables = getInitializedVariables(node);
-      const numVariables = variables.length;
-      let variablesWritten = 0;
-      let pendingExpressions = [];
-      while (variablesWritten < numVariables) {
-        for (let i = variablesWritten; i < numVariables; i++) {
-          const variable = variables[i];
-          if (containsYield(variable.initializer) && pendingExpressions.length > 0) {
-            break;
-          }
-          pendingExpressions.push(transformInitializedVariable(variable));
-        }
-        if (pendingExpressions.length) {
-          emitStatement(factory2.createExpressionStatement(factory2.inlineExpressions(pendingExpressions)));
-          variablesWritten += pendingExpressions.length;
-          pendingExpressions = [];
-        }
-      }
-      return void 0;
-    }
-    function transformInitializedVariable(node) {
-      return setSourceMapRange(
-        factory2.createAssignment(
-          setSourceMapRange(factory2.cloneNode(node.name), node.name),
-          Debug.checkDefined(visitNode(node.initializer, visitor, isExpression))
-        ),
-        node
-      );
-    }
-    function transformAndEmitIfStatement(node) {
-      if (containsYield(node)) {
-        if (containsYield(node.thenStatement) || containsYield(node.elseStatement)) {
-          const endLabel = defineLabel();
-          const elseLabel = node.elseStatement ? defineLabel() : void 0;
-          emitBreakWhenFalse(
-            node.elseStatement ? elseLabel : endLabel,
-            Debug.checkDefined(visitNode(node.expression, visitor, isExpression)),
-            /*location*/
-            node.expression
-          );
-          transformAndEmitEmbeddedStatement(node.thenStatement);
-          if (node.elseStatement) {
-            emitBreak(endLabel);
-            markLabel(elseLabel);
-            transformAndEmitEmbeddedStatement(node.elseStatement);
-          }
-          markLabel(endLabel);
-        } else {
-          emitStatement(visitNode(node, visitor, isStatement));
-        }
-      } else {
-        emitStatement(visitNode(node, visitor, isStatement));
-      }
-    }
-    function transformAndEmitDoStatement(node) {
-      if (containsYield(node)) {
-        const conditionLabel = defineLabel();
-        const loopLabel = defineLabel();
-        beginLoopBlock(
-          /*continueLabel*/
-          conditionLabel
-        );
-        markLabel(loopLabel);
-        transformAndEmitEmbeddedStatement(node.statement);
-        markLabel(conditionLabel);
-        emitBreakWhenTrue(loopLabel, Debug.checkDefined(visitNode(node.expression, visitor, isExpression)));
-        endLoopBlock();
-      } else {
-        emitStatement(visitNode(node, visitor, isStatement));
-      }
-    }
-    function visitDoStatement(node) {
-      if (inStatementContainingYield) {
-        beginScriptLoopBlock();
-        node = visitEachChild(node, visitor, context);
-        endLoopBlock();
-        return node;
-      } else {
-        return visitEachChild(node, visitor, context);
-      }
-    }
-    function transformAndEmitWhileStatement(node) {
-      if (containsYield(node)) {
-        const loopLabel = defineLabel();
-        const endLabel = beginLoopBlock(loopLabel);
-        markLabel(loopLabel);
-        emitBreakWhenFalse(endLabel, Debug.checkDefined(visitNode(node.expression, visitor, isExpression)));
-        transformAndEmitEmbeddedStatement(node.statement);
-        emitBreak(loopLabel);
-        endLoopBlock();
-      } else {
-        emitStatement(visitNode(node, visitor, isStatement));
-      }
-    }
-    function visitWhileStatement(node) {
-      if (inStatementContainingYield) {
-        beginScriptLoopBlock();
-        node = visitEachChild(node, visitor, context);
-        endLoopBlock();
-        return node;
-      } else {
-        return visitEachChild(node, visitor, context);
-      }
-    }
-    function transformAndEmitForStatement(node) {
-      if (containsYield(node)) {
-        const conditionLabel = defineLabel();
-        const incrementLabel = defineLabel();
-        const endLabel = beginLoopBlock(incrementLabel);
-        if (node.initializer) {
-          const initializer = node.initializer;
-          if (isVariableDeclarationList(initializer)) {
-            transformAndEmitVariableDeclarationList(initializer);
-          } else {
-            emitStatement(
-              setTextRange(
-                factory2.createExpressionStatement(
-                  Debug.checkDefined(visitNode(initializer, visitor, isExpression))
-                ),
-                initializer
-              )
-            );
-          }
-        }
-        markLabel(conditionLabel);
-        if (node.condition) {
-          emitBreakWhenFalse(endLabel, Debug.checkDefined(visitNode(node.condition, visitor, isExpression)));
-        }
-        transformAndEmitEmbeddedStatement(node.statement);
-        markLabel(incrementLabel);
-        if (node.incrementor) {
-          emitStatement(
-            setTextRange(
-              factory2.createExpressionStatement(
-                Debug.checkDefined(visitNode(node.incrementor, visitor, isExpression))
-              ),
-              node.incrementor
-            )
-          );
-        }
-        emitBreak(conditionLabel);
-        endLoopBlock();
-      } else {
-        emitStatement(visitNode(node, visitor, isStatement));
-      }
-    }
-    function visitForStatement(node) {
-      if (inStatementContainingYield) {
-        beginScriptLoopBlock();
-      }
-      const initializer = node.initializer;
-      if (initializer && isVariableDeclarationList(initializer)) {
-        for (const variable of initializer.declarations) {
-          hoistVariableDeclaration(variable.name);
-        }
-        const variables = getInitializedVariables(initializer);
-        node = factory2.updateForStatement(
-          node,
-          variables.length > 0 ? factory2.inlineExpressions(map(variables, transformInitializedVariable)) : void 0,
-          visitNode(node.condition, visitor, isExpression),
-          visitNode(node.incrementor, visitor, isExpression),
-          visitIterationBody(node.statement, visitor, context)
-        );
-      } else {
-        node = visitEachChild(node, visitor, context);
-      }
-      if (inStatementContainingYield) {
-        endLoopBlock();
-      }
-      return node;
-    }
-    function transformAndEmitForInStatement(node) {
-      if (containsYield(node)) {
-        const obj = declareLocal();
-        const keysArray = declareLocal();
-        const key = declareLocal();
-        const keysIndex = factory2.createLoopVariable();
-        const initializer = node.initializer;
-        hoistVariableDeclaration(keysIndex);
-        emitAssignment(obj, Debug.checkDefined(visitNode(node.expression, visitor, isExpression)));
-        emitAssignment(keysArray, factory2.createArrayLiteralExpression());
-        emitStatement(
-          factory2.createForInStatement(
-            key,
-            obj,
-            factory2.createExpressionStatement(
-              factory2.createCallExpression(
-                factory2.createPropertyAccessExpression(keysArray, "push"),
-                /*typeArguments*/
-                void 0,
-                [key]
-              )
-            )
-          )
-        );
-        emitAssignment(keysIndex, factory2.createNumericLiteral(0));
-        const conditionLabel = defineLabel();
-        const incrementLabel = defineLabel();
-        const endLoopLabel = beginLoopBlock(incrementLabel);
-        markLabel(conditionLabel);
-        emitBreakWhenFalse(endLoopLabel, factory2.createLessThan(keysIndex, factory2.createPropertyAccessExpression(keysArray, "length")));
-        emitAssignment(key, factory2.createElementAccessExpression(keysArray, keysIndex));
-        emitBreakWhenFalse(incrementLabel, factory2.createBinaryExpression(key, 103 /* InKeyword */, obj));
-        let variable;
-        if (isVariableDeclarationList(initializer)) {
-          for (const variable2 of initializer.declarations) {
-            hoistVariableDeclaration(variable2.name);
-          }
-          variable = factory2.cloneNode(initializer.declarations[0].name);
-        } else {
-          variable = Debug.checkDefined(visitNode(initializer, visitor, isExpression));
-          Debug.assert(isLeftHandSideExpression(variable));
-        }
-        emitAssignment(variable, key);
-        transformAndEmitEmbeddedStatement(node.statement);
-        markLabel(incrementLabel);
-        emitStatement(factory2.createExpressionStatement(factory2.createPostfixIncrement(keysIndex)));
-        emitBreak(conditionLabel);
-        endLoopBlock();
-      } else {
-        emitStatement(visitNode(node, visitor, isStatement));
-      }
-    }
-    function visitForInStatement(node) {
-      if (inStatementContainingYield) {
-        beginScriptLoopBlock();
-      }
-      const initializer = node.initializer;
-      if (isVariableDeclarationList(initializer)) {
-        for (const variable of initializer.declarations) {
-          hoistVariableDeclaration(variable.name);
-        }
-        node = factory2.updateForInStatement(
-          node,
-          initializer.declarations[0].name,
-          Debug.checkDefined(visitNode(node.expression, visitor, isExpression)),
-          Debug.checkDefined(visitNode(node.statement, visitor, isStatement, factory2.liftToBlock))
-        );
-      } else {
-        node = visitEachChild(node, visitor, context);
-      }
-      if (inStatementContainingYield) {
-        endLoopBlock();
-      }
-      return node;
-    }
-    function transformAndEmitContinueStatement(node) {
-      const label = findContinueTarget(node.label ? idText(node.label) : void 0);
-      if (label > 0) {
-        emitBreak(
-          label,
-          /*location*/
-          node
-        );
-      } else {
-        emitStatement(node);
-      }
-    }
-    function visitContinueStatement(node) {
-      if (inStatementContainingYield) {
-        const label = findContinueTarget(node.label && idText(node.label));
-        if (label > 0) {
-          return createInlineBreak(
-            label,
-            /*location*/
-            node
-          );
-        }
-      }
-      return visitEachChild(node, visitor, context);
-    }
-    function transformAndEmitBreakStatement(node) {
-      const label = findBreakTarget(node.label ? idText(node.label) : void 0);
-      if (label > 0) {
-        emitBreak(
-          label,
-          /*location*/
-          node
-        );
-      } else {
-        emitStatement(node);
-      }
-    }
-    function visitBreakStatement(node) {
-      if (inStatementContainingYield) {
-        const label = findBreakTarget(node.label && idText(node.label));
-        if (label > 0) {
-          return createInlineBreak(
-            label,
-            /*location*/
-            node
-          );
-        }
-      }
-      return visitEachChild(node, visitor, context);
-    }
-    function transformAndEmitReturnStatement(node) {
-      emitReturn(
-        visitNode(node.expression, visitor, isExpression),
-        /*location*/
-        node
-      );
-    }
-    function visitReturnStatement(node) {
-      return createInlineReturn(
-        visitNode(node.expression, visitor, isExpression),
-        /*location*/
-        node
-      );
-    }
-    function transformAndEmitWithStatement(node) {
-      if (containsYield(node)) {
-        beginWithBlock(cacheExpression(Debug.checkDefined(visitNode(node.expression, visitor, isExpression))));
-        transformAndEmitEmbeddedStatement(node.statement);
-        endWithBlock();
-      } else {
-        emitStatement(visitNode(node, visitor, isStatement));
-      }
-    }
-    function transformAndEmitSwitchStatement(node) {
-      if (containsYield(node.caseBlock)) {
-        const caseBlock = node.caseBlock;
-        const numClauses = caseBlock.clauses.length;
-        const endLabel = beginSwitchBlock();
-        const expression = cacheExpression(Debug.checkDefined(visitNode(node.expression, visitor, isExpression)));
-        const clauseLabels = [];
-        let defaultClauseIndex = -1;
-        for (let i = 0; i < numClauses; i++) {
-          const clause = caseBlock.clauses[i];
-          clauseLabels.push(defineLabel());
-          if (clause.kind === 296 /* DefaultClause */ && defaultClauseIndex === -1) {
-            defaultClauseIndex = i;
-          }
-        }
-        let clausesWritten = 0;
-        let pendingClauses = [];
-        while (clausesWritten < numClauses) {
-          let defaultClausesSkipped = 0;
-          for (let i = clausesWritten; i < numClauses; i++) {
-            const clause = caseBlock.clauses[i];
-            if (clause.kind === 295 /* CaseClause */) {
-              if (containsYield(clause.expression) && pendingClauses.length > 0) {
-                break;
-              }
-              pendingClauses.push(
-                factory2.createCaseClause(
-                  Debug.checkDefined(visitNode(clause.expression, visitor, isExpression)),
-                  [
-                    createInlineBreak(
-                      clauseLabels[i],
-                      /*location*/
-                      clause.expression
-                    )
-                  ]
-                )
-              );
-            } else {
-              defaultClausesSkipped++;
-            }
-          }
-          if (pendingClauses.length) {
-            emitStatement(factory2.createSwitchStatement(expression, factory2.createCaseBlock(pendingClauses)));
-            clausesWritten += pendingClauses.length;
-            pendingClauses = [];
-          }
-          if (defaultClausesSkipped > 0) {
-            clausesWritten += defaultClausesSkipped;
-            defaultClausesSkipped = 0;
-          }
-        }
-        if (defaultClauseIndex >= 0) {
-          emitBreak(clauseLabels[defaultClauseIndex]);
-        } else {
-          emitBreak(endLabel);
-        }
-        for (let i = 0; i < numClauses; i++) {
-          markLabel(clauseLabels[i]);
-          transformAndEmitStatements(caseBlock.clauses[i].statements);
-        }
-        endSwitchBlock();
-      } else {
-        emitStatement(visitNode(node, visitor, isStatement));
-      }
-    }
-    function visitSwitchStatement(node) {
-      if (inStatementContainingYield) {
-        beginScriptSwitchBlock();
-      }
-      node = visitEachChild(node, visitor, context);
-      if (inStatementContainingYield) {
-        endSwitchBlock();
-      }
-      return node;
-    }
-    function transformAndEmitLabeledStatement(node) {
-      if (containsYield(node)) {
-        beginLabeledBlock(idText(node.label));
-        transformAndEmitEmbeddedStatement(node.statement);
-        endLabeledBlock();
-      } else {
-        emitStatement(visitNode(node, visitor, isStatement));
-      }
-    }
-    function visitLabeledStatement(node) {
-      if (inStatementContainingYield) {
-        beginScriptLabeledBlock(idText(node.label));
-      }
-      node = visitEachChild(node, visitor, context);
-      if (inStatementContainingYield) {
-        endLabeledBlock();
-      }
-      return node;
-    }
-    function transformAndEmitThrowStatement(node) {
-      emitThrow(
-        Debug.checkDefined(visitNode(node.expression ?? factory2.createVoidZero(), visitor, isExpression)),
-        /*location*/
-        node
-      );
-    }
-    function transformAndEmitTryStatement(node) {
-      if (containsYield(node)) {
-        beginExceptionBlock();
-        transformAndEmitEmbeddedStatement(node.tryBlock);
-        if (node.catchClause) {
-          beginCatchBlock(node.catchClause.variableDeclaration);
-          transformAndEmitEmbeddedStatement(node.catchClause.block);
-        }
-        if (node.finallyBlock) {
-          beginFinallyBlock();
-          transformAndEmitEmbeddedStatement(node.finallyBlock);
-        }
-        endExceptionBlock();
-      } else {
-        emitStatement(visitEachChild(node, visitor, context));
-      }
-    }
-    function containsYield(node) {
-      return !!node && (node.transformFlags & 1048576 /* ContainsYield */) !== 0;
-    }
-    function countInitialNodesWithoutYield(nodes) {
-      const numNodes = nodes.length;
-      for (let i = 0; i < numNodes; i++) {
-        if (containsYield(nodes[i])) {
-          return i;
-        }
-      }
-      return -1;
-    }
-    function onSubstituteNode(hint, node) {
-      node = previousOnSubstituteNode(hint, node);
-      if (hint === 1 /* Expression */) {
-        return substituteExpression(node);
-      }
-      return node;
-    }
-    function substituteExpression(node) {
-      if (isIdentifier(node)) {
-        return substituteExpressionIdentifier(node);
-      }
-      return node;
-    }
-    function substituteExpressionIdentifier(node) {
-      if (!isGeneratedIdentifier(node) && renamedCatchVariables && renamedCatchVariables.has(idText(node))) {
-        const original = getOriginalNode(node);
-        if (isIdentifier(original) && original.parent) {
-          const declaration = resolver.getReferencedValueDeclaration(original);
-          if (declaration) {
-            const name = renamedCatchVariableDeclarations[getOriginalNodeId(declaration)];
-            if (name) {
-              const clone2 = setParent(setTextRange(factory2.cloneNode(name), name), name.parent);
-              setSourceMapRange(clone2, node);
-              setCommentRange(clone2, node);
-              return clone2;
-            }
-          }
-        }
-      }
-      return node;
-    }
-    function cacheExpression(node) {
-      if (isGeneratedIdentifier(node) || getEmitFlags(node) & 8192 /* HelperName */) {
-        return node;
-      }
-      const temp = factory2.createTempVariable(hoistVariableDeclaration);
-      emitAssignment(
-        temp,
-        node,
-        /*location*/
-        node
-      );
-      return temp;
-    }
-    function declareLocal(name) {
-      const temp = name ? factory2.createUniqueName(name) : factory2.createTempVariable(
-        /*recordTempVariable*/
-        void 0
-      );
-      hoistVariableDeclaration(temp);
-      return temp;
-    }
-    function defineLabel() {
-      if (!labelOffsets) {
-        labelOffsets = [];
-      }
-      const label = nextLabelId;
-      nextLabelId++;
-      labelOffsets[label] = -1;
-      return label;
-    }
-    function markLabel(label) {
-      Debug.assert(labelOffsets !== void 0, "No labels were defined.");
-      labelOffsets[label] = operations ? operations.length : 0;
-    }
-    function beginBlock(block) {
-      if (!blocks) {
-        blocks = [];
-        blockActions = [];
-        blockOffsets = [];
-        blockStack = [];
-      }
-      const index = blockActions.length;
-      blockActions[index] = 0 /* Open */;
-      blockOffsets[index] = operations ? operations.length : 0;
-      blocks[index] = block;
-      blockStack.push(block);
-      return index;
-    }
-    function endBlock() {
-      const block = peekBlock();
-      if (block === void 0)
-        return Debug.fail("beginBlock was never called.");
-      const index = blockActions.length;
-      blockActions[index] = 1 /* Close */;
-      blockOffsets[index] = operations ? operations.length : 0;
-      blocks[index] = block;
-      blockStack.pop();
-      return block;
-    }
-    function peekBlock() {
-      return lastOrUndefined(blockStack);
-    }
-    function peekBlockKind() {
-      const block = peekBlock();
-      return block && block.kind;
-    }
-    function beginWithBlock(expression) {
-      const startLabel = defineLabel();
-      const endLabel = defineLabel();
-      markLabel(startLabel);
-      beginBlock({
-        kind: 1 /* With */,
-        expression,
-        startLabel,
-        endLabel
-      });
-    }
-    function endWithBlock() {
-      Debug.assert(peekBlockKind() === 1 /* With */);
-      const block = endBlock();
-      markLabel(block.endLabel);
-    }
-    function beginExceptionBlock() {
-      const startLabel = defineLabel();
-      const endLabel = defineLabel();
-      markLabel(startLabel);
-      beginBlock({
-        kind: 0 /* Exception */,
-        state: 0 /* Try */,
-        startLabel,
-        endLabel
-      });
-      emitNop();
-      return endLabel;
-    }
-    function beginCatchBlock(variable) {
-      Debug.assert(peekBlockKind() === 0 /* Exception */);
-      let name;
-      if (isGeneratedIdentifier(variable.name)) {
-        name = variable.name;
-        hoistVariableDeclaration(variable.name);
-      } else {
-        const text = idText(variable.name);
-        name = declareLocal(text);
-        if (!renamedCatchVariables) {
-          renamedCatchVariables = /* @__PURE__ */ new Map();
-          renamedCatchVariableDeclarations = [];
-          context.enableSubstitution(80 /* Identifier */);
-        }
-        renamedCatchVariables.set(text, true);
-        renamedCatchVariableDeclarations[getOriginalNodeId(variable)] = name;
-      }
-      const exception = peekBlock();
-      Debug.assert(exception.state < 1 /* Catch */);
-      const endLabel = exception.endLabel;
-      emitBreak(endLabel);
-      const catchLabel = defineLabel();
-      markLabel(catchLabel);
-      exception.state = 1 /* Catch */;
-      exception.catchVariable = name;
-      exception.catchLabel = catchLabel;
-      emitAssignment(name, factory2.createCallExpression(
-        factory2.createPropertyAccessExpression(state, "sent"),
-        /*typeArguments*/
-        void 0,
-        []
-      ));
-      emitNop();
-    }
-    function beginFinallyBlock() {
-      Debug.assert(peekBlockKind() === 0 /* Exception */);
-      const exception = peekBlock();
-      Debug.assert(exception.state < 2 /* Finally */);
-      const endLabel = exception.endLabel;
-      emitBreak(endLabel);
-      const finallyLabel = defineLabel();
-      markLabel(finallyLabel);
-      exception.state = 2 /* Finally */;
-      exception.finallyLabel = finallyLabel;
-    }
-    function endExceptionBlock() {
-      Debug.assert(peekBlockKind() === 0 /* Exception */);
-      const exception = endBlock();
-      const state2 = exception.state;
-      if (state2 < 2 /* Finally */) {
-        emitBreak(exception.endLabel);
-      } else {
-        emitEndfinally();
-      }
-      markLabel(exception.endLabel);
-      emitNop();
-      exception.state = 3 /* Done */;
-    }
-    function beginScriptLoopBlock() {
-      beginBlock({
-        kind: 3 /* Loop */,
-        isScript: true,
-        breakLabel: -1,
-        continueLabel: -1
-      });
-    }
-    function beginLoopBlock(continueLabel) {
-      const breakLabel = defineLabel();
-      beginBlock({
-        kind: 3 /* Loop */,
-        isScript: false,
-        breakLabel,
-        continueLabel
-      });
-      return breakLabel;
-    }
-    function endLoopBlock() {
-      Debug.assert(peekBlockKind() === 3 /* Loop */);
-      const block = endBlock();
-      const breakLabel = block.breakLabel;
-      if (!block.isScript) {
-        markLabel(breakLabel);
-      }
-    }
-    function beginScriptSwitchBlock() {
-      beginBlock({
-        kind: 2 /* Switch */,
-        isScript: true,
-        breakLabel: -1
-      });
-    }
-    function beginSwitchBlock() {
-      const breakLabel = defineLabel();
-      beginBlock({
-        kind: 2 /* Switch */,
-        isScript: false,
-        breakLabel
-      });
-      return breakLabel;
-    }
-    function endSwitchBlock() {
-      Debug.assert(peekBlockKind() === 2 /* Switch */);
-      const block = endBlock();
-      const breakLabel = block.breakLabel;
-      if (!block.isScript) {
-        markLabel(breakLabel);
-      }
-    }
-    function beginScriptLabeledBlock(labelText) {
-      beginBlock({
-        kind: 4 /* Labeled */,
-        isScript: true,
-        labelText,
-        breakLabel: -1
-      });
-    }
-    function beginLabeledBlock(labelText) {
-      const breakLabel = defineLabel();
-      beginBlock({
-        kind: 4 /* Labeled */,
-        isScript: false,
-        labelText,
-        breakLabel
-      });
-    }
-    function endLabeledBlock() {
-      Debug.assert(peekBlockKind() === 4 /* Labeled */);
-      const block = endBlock();
-      if (!block.isScript) {
-        markLabel(block.breakLabel);
-      }
-    }
-    function supportsUnlabeledBreak(block) {
-      return block.kind === 2 /* Switch */ || block.kind === 3 /* Loop */;
-    }
-    function supportsLabeledBreakOrContinue(block) {
-      return block.kind === 4 /* Labeled */;
-    }
-    function supportsUnlabeledContinue(block) {
-      return block.kind === 3 /* Loop */;
-    }
-    function hasImmediateContainingLabeledBlock(labelText, start) {
-      for (let j = start; j >= 0; j--) {
-        const containingBlock = blockStack[j];
-        if (supportsLabeledBreakOrContinue(containingBlock)) {
-          if (containingBlock.labelText === labelText) {
-            return true;
-          }
-        } else {
-          break;
-        }
-      }
-      return false;
-    }
-    function findBreakTarget(labelText) {
-      if (blockStack) {
-        if (labelText) {
-          for (let i = blockStack.length - 1; i >= 0; i--) {
-            const block = blockStack[i];
-            if (supportsLabeledBreakOrContinue(block) && block.labelText === labelText) {
-              return block.breakLabel;
-            } else if (supportsUnlabeledBreak(block) && hasImmediateContainingLabeledBlock(labelText, i - 1)) {
-              return block.breakLabel;
-            }
-          }
-        } else {
-          for (let i = blockStack.length - 1; i >= 0; i--) {
-            const block = blockStack[i];
-            if (supportsUnlabeledBreak(block)) {
-              return block.breakLabel;
-            }
-          }
-        }
-      }
-      return 0;
-    }
-    function findContinueTarget(labelText) {
-      if (blockStack) {
-        if (labelText) {
-          for (let i = blockStack.length - 1; i >= 0; i--) {
-            const block = blockStack[i];
-            if (supportsUnlabeledContinue(block) && hasImmediateContainingLabeledBlock(labelText, i - 1)) {
-              return block.continueLabel;
-            }
-          }
-        } else {
-          for (let i = blockStack.length - 1; i >= 0; i--) {
-            const block = blockStack[i];
-            if (supportsUnlabeledContinue(block)) {
-              return block.continueLabel;
-            }
-          }
-        }
-      }
-      return 0;
-    }
-    function createLabel(label) {
-      if (label !== void 0 && label > 0) {
-        if (labelExpressions === void 0) {
-          labelExpressions = [];
-        }
-        const expression = factory2.createNumericLiteral(-1);
-        if (labelExpressions[label] === void 0) {
-          labelExpressions[label] = [expression];
-        } else {
-          labelExpressions[label].push(expression);
-        }
-        return expression;
-      }
-      return factory2.createOmittedExpression();
-    }
-    function createInstruction(instruction) {
-      const literal = factory2.createNumericLiteral(instruction);
-      addSyntheticTrailingComment(literal, 3 /* MultiLineCommentTrivia */, getInstructionName(instruction));
-      return literal;
-    }
-    function createInlineBreak(label, location) {
-      Debug.assertLessThan(0, label, "Invalid label");
-      return setTextRange(
-        factory2.createReturnStatement(
-          factory2.createArrayLiteralExpression([
-            createInstruction(3 /* Break */),
-            createLabel(label)
-          ])
-        ),
-        location
-      );
-    }
-    function createInlineReturn(expression, location) {
-      return setTextRange(
-        factory2.createReturnStatement(
-          factory2.createArrayLiteralExpression(
-            expression ? [createInstruction(2 /* Return */), expression] : [createInstruction(2 /* Return */)]
-          )
-        ),
-        location
-      );
-    }
-    function createGeneratorResume(location) {
-      return setTextRange(
-        factory2.createCallExpression(
-          factory2.createPropertyAccessExpression(state, "sent"),
-          /*typeArguments*/
-          void 0,
-          []
-        ),
-        location
-      );
-    }
-    function emitNop() {
-      emitWorker(0 /* Nop */);
-    }
-    function emitStatement(node) {
-      if (node) {
-        emitWorker(1 /* Statement */, [node]);
-      } else {
-        emitNop();
-      }
-    }
-    function emitAssignment(left, right, location) {
-      emitWorker(2 /* Assign */, [left, right], location);
-    }
-    function emitBreak(label, location) {
-      emitWorker(3 /* Break */, [label], location);
-    }
-    function emitBreakWhenTrue(label, condition, location) {
-      emitWorker(4 /* BreakWhenTrue */, [label, condition], location);
-    }
-    function emitBreakWhenFalse(label, condition, location) {
-      emitWorker(5 /* BreakWhenFalse */, [label, condition], location);
-    }
-    function emitYieldStar(expression, location) {
-      emitWorker(7 /* YieldStar */, [expression], location);
-    }
-    function emitYield(expression, location) {
-      emitWorker(6 /* Yield */, [expression], location);
-    }
-    function emitReturn(expression, location) {
-      emitWorker(8 /* Return */, [expression], location);
-    }
-    function emitThrow(expression, location) {
-      emitWorker(9 /* Throw */, [expression], location);
-    }
-    function emitEndfinally() {
-      emitWorker(10 /* Endfinally */);
-    }
-    function emitWorker(code, args, location) {
-      if (operations === void 0) {
-        operations = [];
-        operationArguments = [];
-        operationLocations = [];
-      }
-      if (labelOffsets === void 0) {
-        markLabel(defineLabel());
-      }
-      const operationIndex = operations.length;
-      operations[operationIndex] = code;
-      operationArguments[operationIndex] = args;
-      operationLocations[operationIndex] = location;
-    }
-    function build2() {
-      blockIndex = 0;
-      labelNumber = 0;
-      labelNumbers = void 0;
-      lastOperationWasAbrupt = false;
-      lastOperationWasCompletion = false;
-      clauses = void 0;
-      statements = void 0;
-      exceptionBlockStack = void 0;
-      currentExceptionBlock = void 0;
-      withBlockStack = void 0;
-      const buildResult = buildStatements();
-      return emitHelpers().createGeneratorHelper(
-        setEmitFlags(
-          factory2.createFunctionExpression(
-            /*modifiers*/
-            void 0,
-            /*asteriskToken*/
-            void 0,
-            /*name*/
-            void 0,
-            /*typeParameters*/
-            void 0,
-            [factory2.createParameterDeclaration(
-              /*modifiers*/
-              void 0,
-              /*dotDotDotToken*/
-              void 0,
-              state
-            )],
-            /*type*/
-            void 0,
-            factory2.createBlock(
-              buildResult,
-              /*multiLine*/
-              buildResult.length > 0
-            )
-          ),
-          1048576 /* ReuseTempVariableScope */
-        )
-      );
-    }
-    function buildStatements() {
-      if (operations) {
-        for (let operationIndex = 0; operationIndex < operations.length; operationIndex++) {
-          writeOperation(operationIndex);
-        }
-        flushFinalLabel(operations.length);
-      } else {
-        flushFinalLabel(0);
-      }
-      if (clauses) {
-        const labelExpression = factory2.createPropertyAccessExpression(state, "label");
-        const switchStatement = factory2.createSwitchStatement(labelExpression, factory2.createCaseBlock(clauses));
-        return [startOnNewLine(switchStatement)];
-      }
-      if (statements) {
-        return statements;
-      }
-      return [];
-    }
-    function flushLabel() {
-      if (!statements) {
-        return;
-      }
-      appendLabel(
-        /*markLabelEnd*/
-        !lastOperationWasAbrupt
-      );
-      lastOperationWasAbrupt = false;
-      lastOperationWasCompletion = false;
-      labelNumber++;
-    }
-    function flushFinalLabel(operationIndex) {
-      if (isFinalLabelReachable(operationIndex)) {
-        tryEnterLabel(operationIndex);
-        withBlockStack = void 0;
-        writeReturn(
-          /*expression*/
-          void 0,
-          /*operationLocation*/
-          void 0
-        );
-      }
-      if (statements && clauses) {
-        appendLabel(
-          /*markLabelEnd*/
-          false
-        );
-      }
-      updateLabelExpressions();
-    }
-    function isFinalLabelReachable(operationIndex) {
-      if (!lastOperationWasCompletion) {
-        return true;
-      }
-      if (!labelOffsets || !labelExpressions) {
-        return false;
-      }
-      for (let label = 0; label < labelOffsets.length; label++) {
-        if (labelOffsets[label] === operationIndex && labelExpressions[label]) {
-          return true;
-        }
-      }
-      return false;
-    }
-    function appendLabel(markLabelEnd) {
-      if (!clauses) {
-        clauses = [];
-      }
-      if (statements) {
-        if (withBlockStack) {
-          for (let i = withBlockStack.length - 1; i >= 0; i--) {
-            const withBlock = withBlockStack[i];
-            statements = [factory2.createWithStatement(withBlock.expression, factory2.createBlock(statements))];
-          }
-        }
-        if (currentExceptionBlock) {
-          const { startLabel, catchLabel, finallyLabel, endLabel } = currentExceptionBlock;
-          statements.unshift(
-            factory2.createExpressionStatement(
-              factory2.createCallExpression(
-                factory2.createPropertyAccessExpression(factory2.createPropertyAccessExpression(state, "trys"), "push"),
-                /*typeArguments*/
-                void 0,
-                [
-                  factory2.createArrayLiteralExpression([
-                    createLabel(startLabel),
-                    createLabel(catchLabel),
-                    createLabel(finallyLabel),
-                    createLabel(endLabel)
-                  ])
-                ]
-              )
-            )
-          );
-          currentExceptionBlock = void 0;
-        }
-        if (markLabelEnd) {
-          statements.push(
-            factory2.createExpressionStatement(
-              factory2.createAssignment(
-                factory2.createPropertyAccessExpression(state, "label"),
-                factory2.createNumericLiteral(labelNumber + 1)
-              )
-            )
-          );
-        }
-      }
-      clauses.push(
-        factory2.createCaseClause(
-          factory2.createNumericLiteral(labelNumber),
-          statements || []
-        )
-      );
-      statements = void 0;
-    }
-    function tryEnterLabel(operationIndex) {
-      if (!labelOffsets) {
-        return;
-      }
-      for (let label = 0; label < labelOffsets.length; label++) {
-        if (labelOffsets[label] === operationIndex) {
-          flushLabel();
-          if (labelNumbers === void 0) {
-            labelNumbers = [];
-          }
-          if (labelNumbers[labelNumber] === void 0) {
-            labelNumbers[labelNumber] = [label];
-          } else {
-            labelNumbers[labelNumber].push(label);
-          }
-        }
-      }
-    }
-    function updateLabelExpressions() {
-      if (labelExpressions !== void 0 && labelNumbers !== void 0) {
-        for (let labelNumber2 = 0; labelNumber2 < labelNumbers.length; labelNumber2++) {
-          const labels = labelNumbers[labelNumber2];
-          if (labels !== void 0) {
-            for (const label of labels) {
-              const expressions = labelExpressions[label];
-              if (expressions !== void 0) {
-                for (const expression of expressions) {
-                  expression.text = String(labelNumber2);
-                }
-              }
-            }
-          }
-        }
-      }
-    }
-    function tryEnterOrLeaveBlock(operationIndex) {
-      if (blocks) {
-        for (; blockIndex < blockActions.length && blockOffsets[blockIndex] <= operationIndex; blockIndex++) {
-          const block = blocks[blockIndex];
-          const blockAction = blockActions[blockIndex];
-          switch (block.kind) {
-            case 0 /* Exception */:
-              if (blockAction === 0 /* Open */) {
-                if (!exceptionBlockStack) {
-                  exceptionBlockStack = [];
-                }
-                if (!statements) {
-                  statements = [];
-                }
-                exceptionBlockStack.push(currentExceptionBlock);
-                currentExceptionBlock = block;
-              } else if (blockAction === 1 /* Close */) {
-                currentExceptionBlock = exceptionBlockStack.pop();
-              }
-              break;
-            case 1 /* With */:
-              if (blockAction === 0 /* Open */) {
-                if (!withBlockStack) {
-                  withBlockStack = [];
-                }
-                withBlockStack.push(block);
-              } else if (blockAction === 1 /* Close */) {
-                withBlockStack.pop();
-              }
-              break;
-          }
-        }
-      }
-    }
-    function writeOperation(operationIndex) {
-      tryEnterLabel(operationIndex);
-      tryEnterOrLeaveBlock(operationIndex);
-      if (lastOperationWasAbrupt) {
-        return;
-      }
-      lastOperationWasAbrupt = false;
-      lastOperationWasCompletion = false;
-      const opcode = operations[operationIndex];
-      if (opcode === 0 /* Nop */) {
-        return;
-      } else if (opcode === 10 /* Endfinally */) {
-        return writeEndfinally();
-      }
-      const args = operationArguments[operationIndex];
-      if (opcode === 1 /* Statement */) {
-        return writeStatement(args[0]);
-      }
-      const location = operationLocations[operationIndex];
-      switch (opcode) {
-        case 2 /* Assign */:
-          return writeAssign(args[0], args[1], location);
-        case 3 /* Break */:
-          return writeBreak(args[0], location);
-        case 4 /* BreakWhenTrue */:
-          return writeBreakWhenTrue(args[0], args[1], location);
-        case 5 /* BreakWhenFalse */:
-          return writeBreakWhenFalse(args[0], args[1], location);
-        case 6 /* Yield */:
-          return writeYield(args[0], location);
-        case 7 /* YieldStar */:
-          return writeYieldStar(args[0], location);
-        case 8 /* Return */:
-          return writeReturn(args[0], location);
-        case 9 /* Throw */:
-          return writeThrow(args[0], location);
-      }
-    }
-    function writeStatement(statement) {
-      if (statement) {
-        if (!statements) {
-          statements = [statement];
-        } else {
-          statements.push(statement);
-        }
-      }
-    }
-    function writeAssign(left, right, operationLocation) {
-      writeStatement(setTextRange(factory2.createExpressionStatement(factory2.createAssignment(left, right)), operationLocation));
-    }
-    function writeThrow(expression, operationLocation) {
-      lastOperationWasAbrupt = true;
-      lastOperationWasCompletion = true;
-      writeStatement(setTextRange(factory2.createThrowStatement(expression), operationLocation));
-    }
-    function writeReturn(expression, operationLocation) {
-      lastOperationWasAbrupt = true;
-      lastOperationWasCompletion = true;
-      writeStatement(
-        setEmitFlags(
-          setTextRange(
-            factory2.createReturnStatement(
-              factory2.createArrayLiteralExpression(
-                expression ? [createInstruction(2 /* Return */), expression] : [createInstruction(2 /* Return */)]
-              )
-            ),
-            operationLocation
-          ),
-          768 /* NoTokenSourceMaps */
-        )
-      );
-    }
-    function writeBreak(label, operationLocation) {
-      lastOperationWasAbrupt = true;
-      writeStatement(
-        setEmitFlags(
-          setTextRange(
-            factory2.createReturnStatement(
-              factory2.createArrayLiteralExpression([
-                createInstruction(3 /* Break */),
-                createLabel(label)
-              ])
-            ),
-            operationLocation
-          ),
-          768 /* NoTokenSourceMaps */
-        )
-      );
-    }
-    function writeBreakWhenTrue(label, condition, operationLocation) {
-      writeStatement(
-        setEmitFlags(
-          factory2.createIfStatement(
-            condition,
-            setEmitFlags(
-              setTextRange(
-                factory2.createReturnStatement(
-                  factory2.createArrayLiteralExpression([
-                    createInstruction(3 /* Break */),
-                    createLabel(label)
-                  ])
-                ),
-                operationLocation
-              ),
-              768 /* NoTokenSourceMaps */
-            )
-          ),
-          1 /* SingleLine */
-        )
-      );
-    }
-    function writeBreakWhenFalse(label, condition, operationLocation) {
-      writeStatement(
-        setEmitFlags(
-          factory2.createIfStatement(
-            factory2.createLogicalNot(condition),
-            setEmitFlags(
-              setTextRange(
-                factory2.createReturnStatement(
-                  factory2.createArrayLiteralExpression([
-                    createInstruction(3 /* Break */),
-                    createLabel(label)
-                  ])
-                ),
-                operationLocation
-              ),
-              768 /* NoTokenSourceMaps */
-            )
-          ),
-          1 /* SingleLine */
-        )
-      );
-    }
-    function writeYield(expression, operationLocation) {
-      lastOperationWasAbrupt = true;
-      writeStatement(
-        setEmitFlags(
-          setTextRange(
-            factory2.createReturnStatement(
-              factory2.createArrayLiteralExpression(
-                expression ? [createInstruction(4 /* Yield */), expression] : [createInstruction(4 /* Yield */)]
-              )
-            ),
-            operationLocation
-          ),
-          768 /* NoTokenSourceMaps */
-        )
-      );
-    }
-    function writeYieldStar(expression, operationLocation) {
-      lastOperationWasAbrupt = true;
-      writeStatement(
-        setEmitFlags(
-          setTextRange(
-            factory2.createReturnStatement(
-              factory2.createArrayLiteralExpression([
-                createInstruction(5 /* YieldStar */),
-                expression
-              ])
-            ),
-            operationLocation
-          ),
-          768 /* NoTokenSourceMaps */
-        )
-      );
-    }
-    function writeEndfinally() {
-      lastOperationWasAbrupt = true;
-      writeStatement(
-        factory2.createReturnStatement(
-          factory2.createArrayLiteralExpression([
-            createInstruction(7 /* Endfinally */)
-          ])
-        )
-      );
-    }
-  }
-  var init_generators = __esm({
-    "src/compiler/transformers/generators.ts"() {
-      "use strict";
-      init_ts2();
-    }
-  });
-
-  // src/compiler/transformers/module/module.ts
-  function transformModule(context) {
-    function getTransformModuleDelegate(moduleKind2) {
-      switch (moduleKind2) {
-        case 2 /* AMD */:
-          return transformAMDModule;
-        case 3 /* UMD */:
-          return transformUMDModule;
-        default:
-          return transformCommonJSModule;
-      }
-    }
-    const {
-      factory: factory2,
-      getEmitHelperFactory: emitHelpers,
-      startLexicalEnvironment,
-      endLexicalEnvironment,
-      hoistVariableDeclaration
-    } = context;
-    const compilerOptions = context.getCompilerOptions();
-    const resolver = context.getEmitResolver();
-    const host = context.getEmitHost();
-    const languageVersion = getEmitScriptTarget(compilerOptions);
-    const moduleKind = getEmitModuleKind(compilerOptions);
-    const previousOnSubstituteNode = context.onSubstituteNode;
-    const previousOnEmitNode = context.onEmitNode;
-    context.onSubstituteNode = onSubstituteNode;
-    context.onEmitNode = onEmitNode;
-    context.enableSubstitution(212 /* CallExpression */);
-    context.enableSubstitution(214 /* TaggedTemplateExpression */);
-    context.enableSubstitution(80 /* Identifier */);
-    context.enableSubstitution(225 /* BinaryExpression */);
-    context.enableSubstitution(303 /* ShorthandPropertyAssignment */);
-    context.enableEmitNotification(311 /* SourceFile */);
-    const moduleInfoMap = [];
-    let currentSourceFile;
-    let currentModuleInfo;
-    const noSubstitution = [];
-    let needUMDDynamicImportHelper;
-    return chainBundle(context, transformSourceFile);
-    function transformSourceFile(node) {
-      if (node.isDeclarationFile || !(isEffectiveExternalModule(node, compilerOptions) || node.transformFlags & 8388608 /* ContainsDynamicImport */ || isJsonSourceFile(node) && hasJsonModuleEmitEnabled(compilerOptions) && outFile(compilerOptions))) {
-        return node;
-      }
-      currentSourceFile = node;
-      currentModuleInfo = collectExternalModuleInfo(context, node, resolver, compilerOptions);
-      moduleInfoMap[getOriginalNodeId(node)] = currentModuleInfo;
-      const transformModule2 = getTransformModuleDelegate(moduleKind);
-      const updated = transformModule2(node);
-      currentSourceFile = void 0;
-      currentModuleInfo = void 0;
-      needUMDDynamicImportHelper = false;
-      return updated;
-    }
-    function shouldEmitUnderscoreUnderscoreESModule() {
-      if (!currentModuleInfo.exportEquals && isExternalModule(currentSourceFile)) {
-        return true;
-      }
-      return false;
-    }
-    function transformCommonJSModule(node) {
-      startLexicalEnvironment();
-      const statements = [];
-      const ensureUseStrict = getStrictOptionValue(compilerOptions, "alwaysStrict") || !compilerOptions.noImplicitUseStrict && isExternalModule(currentSourceFile);
-      const statementOffset = factory2.copyPrologue(node.statements, statements, ensureUseStrict && !isJsonSourceFile(node), topLevelVisitor);
-      if (shouldEmitUnderscoreUnderscoreESModule()) {
-        append(statements, createUnderscoreUnderscoreESModule());
-      }
-      if (length(currentModuleInfo.exportedNames)) {
-        const chunkSize = 50;
-        for (let i = 0; i < currentModuleInfo.exportedNames.length; i += chunkSize) {
-          append(
-            statements,
-            factory2.createExpressionStatement(
-              reduceLeft(
-                currentModuleInfo.exportedNames.slice(i, i + chunkSize),
-                (prev, nextId) => factory2.createAssignment(factory2.createPropertyAccessExpression(factory2.createIdentifier("exports"), factory2.createIdentifier(idText(nextId))), prev),
-                factory2.createVoidZero()
-              )
-            )
-          );
-        }
-      }
-      append(statements, visitNode(currentModuleInfo.externalHelpersImportDeclaration, topLevelVisitor, isStatement));
-      addRange(statements, visitNodes2(node.statements, topLevelVisitor, isStatement, statementOffset));
-      addExportEqualsIfNeeded(
-        statements,
-        /*emitAsReturn*/
-        false
-      );
-      insertStatementsAfterStandardPrologue(statements, endLexicalEnvironment());
-      const updated = factory2.updateSourceFile(node, setTextRange(factory2.createNodeArray(statements), node.statements));
-      addEmitHelpers(updated, context.readEmitHelpers());
-      return updated;
-    }
-    function transformAMDModule(node) {
-      const define = factory2.createIdentifier("define");
-      const moduleName = tryGetModuleNameFromFile(factory2, node, host, compilerOptions);
-      const jsonSourceFile = isJsonSourceFile(node) && node;
-      const { aliasedModuleNames, unaliasedModuleNames, importAliasNames } = collectAsynchronousDependencies(
-        node,
-        /*includeNonAmdDependencies*/
-        true
-      );
-      const updated = factory2.updateSourceFile(
-        node,
-        setTextRange(
-          factory2.createNodeArray([
-            factory2.createExpressionStatement(
-              factory2.createCallExpression(
-                define,
-                /*typeArguments*/
-                void 0,
-                [
-                  // Add the module name (if provided).
-                  ...moduleName ? [moduleName] : [],
-                  // Add the dependency array argument:
-                  //
-                  //     ["require", "exports", module1", "module2", ...]
-                  factory2.createArrayLiteralExpression(jsonSourceFile ? emptyArray : [
-                    factory2.createStringLiteral("require"),
-                    factory2.createStringLiteral("exports"),
-                    ...aliasedModuleNames,
-                    ...unaliasedModuleNames
-                  ]),
-                  // Add the module body function argument:
-                  //
-                  //     function (require, exports, module1, module2) ...
-                  jsonSourceFile ? jsonSourceFile.statements.length ? jsonSourceFile.statements[0].expression : factory2.createObjectLiteralExpression() : factory2.createFunctionExpression(
-                    /*modifiers*/
-                    void 0,
-                    /*asteriskToken*/
-                    void 0,
-                    /*name*/
-                    void 0,
-                    /*typeParameters*/
-                    void 0,
-                    [
-                      factory2.createParameterDeclaration(
-                        /*modifiers*/
-                        void 0,
-                        /*dotDotDotToken*/
-                        void 0,
-                        "require"
-                      ),
-                      factory2.createParameterDeclaration(
-                        /*modifiers*/
-                        void 0,
-                        /*dotDotDotToken*/
-                        void 0,
-                        "exports"
-                      ),
-                      ...importAliasNames
-                    ],
-                    /*type*/
-                    void 0,
-                    transformAsynchronousModuleBody(node)
-                  )
-                ]
-              )
-            )
-          ]),
-          /*location*/
-          node.statements
-        )
-      );
-      addEmitHelpers(updated, context.readEmitHelpers());
-      return updated;
-    }
-    function transformUMDModule(node) {
-      const { aliasedModuleNames, unaliasedModuleNames, importAliasNames } = collectAsynchronousDependencies(
-        node,
-        /*includeNonAmdDependencies*/
-        false
-      );
-      const moduleName = tryGetModuleNameFromFile(factory2, node, host, compilerOptions);
-      const umdHeader = factory2.createFunctionExpression(
-        /*modifiers*/
-        void 0,
-        /*asteriskToken*/
-        void 0,
-        /*name*/
-        void 0,
-        /*typeParameters*/
-        void 0,
-        [factory2.createParameterDeclaration(
-          /*modifiers*/
-          void 0,
-          /*dotDotDotToken*/
-          void 0,
-          "factory"
-        )],
-        /*type*/
-        void 0,
-        setTextRange(
-          factory2.createBlock(
-            [
-              factory2.createIfStatement(
-                factory2.createLogicalAnd(
-                  factory2.createTypeCheck(factory2.createIdentifier("module"), "object"),
-                  factory2.createTypeCheck(factory2.createPropertyAccessExpression(factory2.createIdentifier("module"), "exports"), "object")
-                ),
-                factory2.createBlock([
-                  factory2.createVariableStatement(
-                    /*modifiers*/
-                    void 0,
-                    [
-                      factory2.createVariableDeclaration(
-                        "v",
-                        /*exclamationToken*/
-                        void 0,
-                        /*type*/
-                        void 0,
-                        factory2.createCallExpression(
-                          factory2.createIdentifier("factory"),
-                          /*typeArguments*/
-                          void 0,
-                          [
-                            factory2.createIdentifier("require"),
-                            factory2.createIdentifier("exports")
-                          ]
-                        )
-                      )
-                    ]
-                  ),
-                  setEmitFlags(
-                    factory2.createIfStatement(
-                      factory2.createStrictInequality(
-                        factory2.createIdentifier("v"),
-                        factory2.createIdentifier("undefined")
-                      ),
-                      factory2.createExpressionStatement(
-                        factory2.createAssignment(
-                          factory2.createPropertyAccessExpression(factory2.createIdentifier("module"), "exports"),
-                          factory2.createIdentifier("v")
-                        )
-                      )
-                    ),
-                    1 /* SingleLine */
-                  )
-                ]),
-                factory2.createIfStatement(
-                  factory2.createLogicalAnd(
-                    factory2.createTypeCheck(factory2.createIdentifier("define"), "function"),
-                    factory2.createPropertyAccessExpression(factory2.createIdentifier("define"), "amd")
-                  ),
-                  factory2.createBlock([
-                    factory2.createExpressionStatement(
-                      factory2.createCallExpression(
-                        factory2.createIdentifier("define"),
-                        /*typeArguments*/
-                        void 0,
-                        [
-                          // Add the module name (if provided).
-                          ...moduleName ? [moduleName] : [],
-                          factory2.createArrayLiteralExpression([
-                            factory2.createStringLiteral("require"),
-                            factory2.createStringLiteral("exports"),
-                            ...aliasedModuleNames,
-                            ...unaliasedModuleNames
-                          ]),
-                          factory2.createIdentifier("factory")
-                        ]
-                      )
-                    )
-                  ])
-                )
-              )
-            ],
-            /*multiLine*/
-            true
-          ),
-          /*location*/
-          void 0
-        )
-      );
-      const updated = factory2.updateSourceFile(
-        node,
-        setTextRange(
-          factory2.createNodeArray([
-            factory2.createExpressionStatement(
-              factory2.createCallExpression(
-                umdHeader,
-                /*typeArguments*/
-                void 0,
-                [
-                  // Add the module body function argument:
-                  //
-                  //     function (require, exports) ...
-                  factory2.createFunctionExpression(
-                    /*modifiers*/
-                    void 0,
-                    /*asteriskToken*/
-                    void 0,
-                    /*name*/
-                    void 0,
-                    /*typeParameters*/
-                    void 0,
-                    [
-                      factory2.createParameterDeclaration(
-                        /*modifiers*/
-                        void 0,
-                        /*dotDotDotToken*/
-                        void 0,
-                        "require"
-                      ),
-                      factory2.createParameterDeclaration(
-                        /*modifiers*/
-                        void 0,
-                        /*dotDotDotToken*/
-                        void 0,
-                        "exports"
-                      ),
-                      ...importAliasNames
-                    ],
-                    /*type*/
-                    void 0,
-                    transformAsynchronousModuleBody(node)
-                  )
-                ]
-              )
-            )
-          ]),
-          /*location*/
-          node.statements
-        )
-      );
-      addEmitHelpers(updated, context.readEmitHelpers());
-      return updated;
-    }
-    function collectAsynchronousDependencies(node, includeNonAmdDependencies) {
-      const aliasedModuleNames = [];
-      const unaliasedModuleNames = [];
-      const importAliasNames = [];
-      for (const amdDependency of node.amdDependencies) {
-        if (amdDependency.name) {
-          aliasedModuleNames.push(factory2.createStringLiteral(amdDependency.path));
-          importAliasNames.push(factory2.createParameterDeclaration(
-            /*modifiers*/
-            void 0,
-            /*dotDotDotToken*/
-            void 0,
-            amdDependency.name
-          ));
-        } else {
-          unaliasedModuleNames.push(factory2.createStringLiteral(amdDependency.path));
-        }
-      }
-      for (const importNode of currentModuleInfo.externalImports) {
-        const externalModuleName = getExternalModuleNameLiteral(factory2, importNode, currentSourceFile, host, resolver, compilerOptions);
-        const importAliasName = getLocalNameForExternalImport(factory2, importNode, currentSourceFile);
-        if (externalModuleName) {
-          if (includeNonAmdDependencies && importAliasName) {
-            setEmitFlags(importAliasName, 8 /* NoSubstitution */);
-            aliasedModuleNames.push(externalModuleName);
-            importAliasNames.push(factory2.createParameterDeclaration(
-              /*modifiers*/
-              void 0,
-              /*dotDotDotToken*/
-              void 0,
-              importAliasName
-            ));
-          } else {
-            unaliasedModuleNames.push(externalModuleName);
-          }
-        }
-      }
-      return { aliasedModuleNames, unaliasedModuleNames, importAliasNames };
-    }
-    function getAMDImportExpressionForImport(node) {
-      if (isImportEqualsDeclaration(node) || isExportDeclaration(node) || !getExternalModuleNameLiteral(factory2, node, currentSourceFile, host, resolver, compilerOptions)) {
-        return void 0;
-      }
-      const name = getLocalNameForExternalImport(factory2, node, currentSourceFile);
-      const expr = getHelperExpressionForImport(node, name);
-      if (expr === name) {
-        return void 0;
-      }
-      return factory2.createExpressionStatement(factory2.createAssignment(name, expr));
-    }
-    function transformAsynchronousModuleBody(node) {
-      startLexicalEnvironment();
-      const statements = [];
-      const statementOffset = factory2.copyPrologue(
-        node.statements,
-        statements,
-        /*ensureUseStrict*/
-        !compilerOptions.noImplicitUseStrict,
-        topLevelVisitor
-      );
-      if (shouldEmitUnderscoreUnderscoreESModule()) {
-        append(statements, createUnderscoreUnderscoreESModule());
-      }
-      if (length(currentModuleInfo.exportedNames)) {
-        append(statements, factory2.createExpressionStatement(reduceLeft(currentModuleInfo.exportedNames, (prev, nextId) => factory2.createAssignment(factory2.createPropertyAccessExpression(factory2.createIdentifier("exports"), factory2.createIdentifier(idText(nextId))), prev), factory2.createVoidZero())));
-      }
-      append(statements, visitNode(currentModuleInfo.externalHelpersImportDeclaration, topLevelVisitor, isStatement));
-      if (moduleKind === 2 /* AMD */) {
-        addRange(statements, mapDefined(currentModuleInfo.externalImports, getAMDImportExpressionForImport));
-      }
-      addRange(statements, visitNodes2(node.statements, topLevelVisitor, isStatement, statementOffset));
-      addExportEqualsIfNeeded(
-        statements,
-        /*emitAsReturn*/
-        true
-      );
-      insertStatementsAfterStandardPrologue(statements, endLexicalEnvironment());
-      const body = factory2.createBlock(
-        statements,
-        /*multiLine*/
-        true
-      );
-      if (needUMDDynamicImportHelper) {
-        addEmitHelper(body, dynamicImportUMDHelper);
-      }
-      return body;
-    }
-    function addExportEqualsIfNeeded(statements, emitAsReturn) {
-      if (currentModuleInfo.exportEquals) {
-        const expressionResult = visitNode(currentModuleInfo.exportEquals.expression, visitor, isExpression);
-        if (expressionResult) {
-          if (emitAsReturn) {
-            const statement = factory2.createReturnStatement(expressionResult);
-            setTextRange(statement, currentModuleInfo.exportEquals);
-            setEmitFlags(statement, 768 /* NoTokenSourceMaps */ | 3072 /* NoComments */);
-            statements.push(statement);
-          } else {
-            const statement = factory2.createExpressionStatement(
-              factory2.createAssignment(
-                factory2.createPropertyAccessExpression(
-                  factory2.createIdentifier("module"),
-                  "exports"
-                ),
-                expressionResult
-              )
-            );
-            setTextRange(statement, currentModuleInfo.exportEquals);
-            setEmitFlags(statement, 3072 /* NoComments */);
-            statements.push(statement);
-          }
-        }
-      }
-    }
-    function topLevelVisitor(node) {
-      switch (node.kind) {
-        case 271 /* ImportDeclaration */:
-          return visitImportDeclaration(node);
-        case 270 /* ImportEqualsDeclaration */:
-          return visitImportEqualsDeclaration(node);
-        case 277 /* ExportDeclaration */:
-          return visitExportDeclaration(node);
-        case 276 /* ExportAssignment */:
-          return visitExportAssignment(node);
-        case 261 /* FunctionDeclaration */:
-          return visitFunctionDeclaration(node);
-        case 262 /* ClassDeclaration */:
-          return visitClassDeclaration(node);
-        default:
-          return topLevelNestedVisitor(node);
-      }
-    }
-    function topLevelNestedVisitor(node) {
-      switch (node.kind) {
-        case 242 /* VariableStatement */:
-          return visitVariableStatement(node);
-        case 261 /* FunctionDeclaration */:
-          return visitFunctionDeclaration(node);
-        case 262 /* ClassDeclaration */:
-          return visitClassDeclaration(node);
-        case 247 /* ForStatement */:
-          return visitForStatement(
-            node,
-            /*isTopLevel*/
-            true
-          );
-        case 248 /* ForInStatement */:
-          return visitForInStatement(node);
-        case 249 /* ForOfStatement */:
-          return visitForOfStatement(node);
-        case 245 /* DoStatement */:
-          return visitDoStatement(node);
-        case 246 /* WhileStatement */:
-          return visitWhileStatement(node);
-        case 255 /* LabeledStatement */:
-          return visitLabeledStatement(node);
-        case 253 /* WithStatement */:
-          return visitWithStatement(node);
-        case 244 /* IfStatement */:
-          return visitIfStatement(node);
-        case 254 /* SwitchStatement */:
-          return visitSwitchStatement(node);
-        case 268 /* CaseBlock */:
-          return visitCaseBlock(node);
-        case 295 /* CaseClause */:
-          return visitCaseClause(node);
-        case 296 /* DefaultClause */:
-          return visitDefaultClause(node);
-        case 257 /* TryStatement */:
-          return visitTryStatement(node);
-        case 298 /* CatchClause */:
-          return visitCatchClause(node);
-        case 240 /* Block */:
-          return visitBlock(node);
-        default:
-          return visitor(node);
-      }
-    }
-    function visitorWorker(node, valueIsDiscarded) {
-      if (!(node.transformFlags & (8388608 /* ContainsDynamicImport */ | 4096 /* ContainsDestructuringAssignment */ | 268435456 /* ContainsUpdateExpressionForIdentifier */))) {
-        return node;
-      }
-      switch (node.kind) {
-        case 247 /* ForStatement */:
-          return visitForStatement(
-            node,
-            /*isTopLevel*/
-            false
-          );
-        case 243 /* ExpressionStatement */:
-          return visitExpressionStatement(node);
-        case 216 /* ParenthesizedExpression */:
-          return visitParenthesizedExpression(node, valueIsDiscarded);
-        case 359 /* PartiallyEmittedExpression */:
-          return visitPartiallyEmittedExpression(node, valueIsDiscarded);
-        case 212 /* CallExpression */:
-          if (isImportCall(node) && currentSourceFile.impliedNodeFormat === void 0) {
-            return visitImportCallExpression(node);
-          }
-          break;
-        case 225 /* BinaryExpression */:
-          if (isDestructuringAssignment(node)) {
-            return visitDestructuringAssignment(node, valueIsDiscarded);
-          }
-          break;
-        case 223 /* PrefixUnaryExpression */:
-        case 224 /* PostfixUnaryExpression */:
-          return visitPreOrPostfixUnaryExpression(node, valueIsDiscarded);
-      }
-      return visitEachChild(node, visitor, context);
-    }
-    function visitor(node) {
-      return visitorWorker(
-        node,
-        /*valueIsDiscarded*/
-        false
-      );
-    }
-    function discardedValueVisitor(node) {
-      return visitorWorker(
-        node,
-        /*valueIsDiscarded*/
-        true
-      );
-    }
-    function destructuringNeedsFlattening(node) {
-      if (isObjectLiteralExpression(node)) {
-        for (const elem of node.properties) {
-          switch (elem.kind) {
-            case 302 /* PropertyAssignment */:
-              if (destructuringNeedsFlattening(elem.initializer)) {
-                return true;
-              }
-              break;
-            case 303 /* ShorthandPropertyAssignment */:
-              if (destructuringNeedsFlattening(elem.name)) {
-                return true;
-              }
-              break;
-            case 304 /* SpreadAssignment */:
-              if (destructuringNeedsFlattening(elem.expression)) {
-                return true;
-              }
-              break;
-            case 173 /* MethodDeclaration */:
-            case 176 /* GetAccessor */:
-            case 177 /* SetAccessor */:
-              return false;
-            default:
-              Debug.assertNever(elem, "Unhandled object member kind");
-          }
-        }
-      } else if (isArrayLiteralExpression(node)) {
-        for (const elem of node.elements) {
-          if (isSpreadElement(elem)) {
-            if (destructuringNeedsFlattening(elem.expression)) {
-              return true;
-            }
-          } else if (destructuringNeedsFlattening(elem)) {
-            return true;
-          }
-        }
-      } else if (isIdentifier(node)) {
-        return length(getExports(node)) > (isExportName(node) ? 1 : 0);
-      }
-      return false;
-    }
-    function visitDestructuringAssignment(node, valueIsDiscarded) {
-      if (destructuringNeedsFlattening(node.left)) {
-        return flattenDestructuringAssignment(node, visitor, context, 0 /* All */, !valueIsDiscarded, createAllExportExpressions);
-      }
-      return visitEachChild(node, visitor, context);
-    }
-    function visitForStatement(node, isTopLevel) {
-      if (isTopLevel && node.initializer && isVariableDeclarationList(node.initializer) && !(node.initializer.flags & 3 /* BlockScoped */)) {
-        const exportStatements = appendExportsOfVariableDeclarationList(
-          /*statements*/
-          void 0,
-          node.initializer,
-          /*isForInOrOfInitializer*/
-          false
-        );
-        if (exportStatements) {
-          const statements = [];
-          const varDeclList = visitNode(node.initializer, discardedValueVisitor, isVariableDeclarationList);
-          const varStatement = factory2.createVariableStatement(
-            /*modifiers*/
-            void 0,
-            varDeclList
-          );
-          statements.push(varStatement);
-          addRange(statements, exportStatements);
-          const condition = visitNode(node.condition, visitor, isExpression);
-          const incrementor = visitNode(node.incrementor, discardedValueVisitor, isExpression);
-          const body = visitIterationBody(node.statement, isTopLevel ? topLevelNestedVisitor : visitor, context);
-          statements.push(factory2.updateForStatement(
-            node,
-            /*initializer*/
-            void 0,
-            condition,
-            incrementor,
-            body
-          ));
-          return statements;
-        }
-      }
-      return factory2.updateForStatement(
-        node,
-        visitNode(node.initializer, discardedValueVisitor, isForInitializer),
-        visitNode(node.condition, visitor, isExpression),
-        visitNode(node.incrementor, discardedValueVisitor, isExpression),
-        visitIterationBody(node.statement, isTopLevel ? topLevelNestedVisitor : visitor, context)
-      );
-    }
-    function visitForInStatement(node) {
-      if (isVariableDeclarationList(node.initializer) && !(node.initializer.flags & 3 /* BlockScoped */)) {
-        const exportStatements = appendExportsOfVariableDeclarationList(
-          /*statements*/
-          void 0,
-          node.initializer,
-          /*isForInOrOfInitializer*/
-          true
-        );
-        if (some(exportStatements)) {
-          const initializer = visitNode(node.initializer, discardedValueVisitor, isForInitializer);
-          const expression = visitNode(node.expression, visitor, isExpression);
-          const body = visitIterationBody(node.statement, topLevelNestedVisitor, context);
-          const mergedBody = isBlock(body) ? factory2.updateBlock(body, [...exportStatements, ...body.statements]) : factory2.createBlock(
-            [...exportStatements, body],
-            /*multiLine*/
-            true
-          );
-          return factory2.updateForInStatement(node, initializer, expression, mergedBody);
-        }
-      }
-      return factory2.updateForInStatement(
-        node,
-        visitNode(node.initializer, discardedValueVisitor, isForInitializer),
-        visitNode(node.expression, visitor, isExpression),
-        visitIterationBody(node.statement, topLevelNestedVisitor, context)
-      );
-    }
-    function visitForOfStatement(node) {
-      if (isVariableDeclarationList(node.initializer) && !(node.initializer.flags & 3 /* BlockScoped */)) {
-        const exportStatements = appendExportsOfVariableDeclarationList(
-          /*statements*/
-          void 0,
-          node.initializer,
-          /*isForInOrOfInitializer*/
-          true
-        );
-        const initializer = visitNode(node.initializer, discardedValueVisitor, isForInitializer);
-        const expression = visitNode(node.expression, visitor, isExpression);
-        let body = visitIterationBody(node.statement, topLevelNestedVisitor, context);
-        if (some(exportStatements)) {
-          body = isBlock(body) ? factory2.updateBlock(body, [...exportStatements, ...body.statements]) : factory2.createBlock(
-            [...exportStatements, body],
-            /*multiLine*/
-            true
-          );
-        }
-        return factory2.updateForOfStatement(node, node.awaitModifier, initializer, expression, body);
-      }
-      return factory2.updateForOfStatement(
-        node,
-        node.awaitModifier,
-        visitNode(node.initializer, discardedValueVisitor, isForInitializer),
-        visitNode(node.expression, visitor, isExpression),
-        visitIterationBody(node.statement, topLevelNestedVisitor, context)
-      );
-    }
-    function visitDoStatement(node) {
-      return factory2.updateDoStatement(
-        node,
-        visitIterationBody(node.statement, topLevelNestedVisitor, context),
-        visitNode(node.expression, visitor, isExpression)
-      );
-    }
-    function visitWhileStatement(node) {
-      return factory2.updateWhileStatement(
-        node,
-        visitNode(node.expression, visitor, isExpression),
-        visitIterationBody(node.statement, topLevelNestedVisitor, context)
-      );
-    }
-    function visitLabeledStatement(node) {
-      return factory2.updateLabeledStatement(
-        node,
-        node.label,
-        Debug.checkDefined(visitNode(node.statement, topLevelNestedVisitor, isStatement, factory2.liftToBlock))
-      );
-    }
-    function visitWithStatement(node) {
-      return factory2.updateWithStatement(
-        node,
-        visitNode(node.expression, visitor, isExpression),
-        Debug.checkDefined(visitNode(node.statement, topLevelNestedVisitor, isStatement, factory2.liftToBlock))
-      );
-    }
-    function visitIfStatement(node) {
-      return factory2.updateIfStatement(
-        node,
-        visitNode(node.expression, visitor, isExpression),
-        Debug.checkDefined(visitNode(node.thenStatement, topLevelNestedVisitor, isStatement, factory2.liftToBlock)),
-        visitNode(node.elseStatement, topLevelNestedVisitor, isStatement, factory2.liftToBlock)
-      );
-    }
-    function visitSwitchStatement(node) {
-      return factory2.updateSwitchStatement(
-        node,
-        visitNode(node.expression, visitor, isExpression),
-        Debug.checkDefined(visitNode(node.caseBlock, topLevelNestedVisitor, isCaseBlock))
-      );
-    }
-    function visitCaseBlock(node) {
-      return factory2.updateCaseBlock(
-        node,
-        visitNodes2(node.clauses, topLevelNestedVisitor, isCaseOrDefaultClause)
-      );
-    }
-    function visitCaseClause(node) {
-      return factory2.updateCaseClause(
-        node,
-        visitNode(node.expression, visitor, isExpression),
-        visitNodes2(node.statements, topLevelNestedVisitor, isStatement)
-      );
-    }
-    function visitDefaultClause(node) {
-      return visitEachChild(node, topLevelNestedVisitor, context);
-    }
-    function visitTryStatement(node) {
-      return visitEachChild(node, topLevelNestedVisitor, context);
-    }
-    function visitCatchClause(node) {
-      return factory2.updateCatchClause(
-        node,
-        node.variableDeclaration,
-        Debug.checkDefined(visitNode(node.block, topLevelNestedVisitor, isBlock))
-      );
-    }
-    function visitBlock(node) {
-      node = visitEachChild(node, topLevelNestedVisitor, context);
-      return node;
-    }
-    function visitExpressionStatement(node) {
-      return factory2.updateExpressionStatement(
-        node,
-        visitNode(node.expression, discardedValueVisitor, isExpression)
-      );
-    }
-    function visitParenthesizedExpression(node, valueIsDiscarded) {
-      return factory2.updateParenthesizedExpression(node, visitNode(node.expression, valueIsDiscarded ? discardedValueVisitor : visitor, isExpression));
-    }
-    function visitPartiallyEmittedExpression(node, valueIsDiscarded) {
-      return factory2.updatePartiallyEmittedExpression(node, visitNode(node.expression, valueIsDiscarded ? discardedValueVisitor : visitor, isExpression));
-    }
-    function visitPreOrPostfixUnaryExpression(node, valueIsDiscarded) {
-      if ((node.operator === 46 /* PlusPlusToken */ || node.operator === 47 /* MinusMinusToken */) && isIdentifier(node.operand) && !isGeneratedIdentifier(node.operand) && !isLocalName(node.operand) && !isDeclarationNameOfEnumOrNamespace(node.operand)) {
-        const exportedNames = getExports(node.operand);
-        if (exportedNames) {
-          let temp;
-          let expression = visitNode(node.operand, visitor, isExpression);
-          if (isPrefixUnaryExpression(node)) {
-            expression = factory2.updatePrefixUnaryExpression(node, expression);
-          } else {
-            expression = factory2.updatePostfixUnaryExpression(node, expression);
-            if (!valueIsDiscarded) {
-              temp = factory2.createTempVariable(hoistVariableDeclaration);
-              expression = factory2.createAssignment(temp, expression);
-              setTextRange(expression, node);
-            }
-            expression = factory2.createComma(expression, factory2.cloneNode(node.operand));
-            setTextRange(expression, node);
-          }
-          for (const exportName of exportedNames) {
-            noSubstitution[getNodeId(expression)] = true;
-            expression = createExportExpression(exportName, expression);
-            setTextRange(expression, node);
-          }
-          if (temp) {
-            noSubstitution[getNodeId(expression)] = true;
-            expression = factory2.createComma(expression, temp);
-            setTextRange(expression, node);
-          }
-          return expression;
-        }
-      }
-      return visitEachChild(node, visitor, context);
-    }
-    function visitImportCallExpression(node) {
-      if (moduleKind === 0 /* None */ && languageVersion >= 7 /* ES2020 */) {
-        return visitEachChild(node, visitor, context);
-      }
-      const externalModuleName = getExternalModuleNameLiteral(factory2, node, currentSourceFile, host, resolver, compilerOptions);
-      const firstArgument = visitNode(firstOrUndefined(node.arguments), visitor, isExpression);
-      const argument = externalModuleName && (!firstArgument || !isStringLiteral(firstArgument) || firstArgument.text !== externalModuleName.text) ? externalModuleName : firstArgument;
-      const containsLexicalThis = !!(node.transformFlags & 16384 /* ContainsLexicalThis */);
-      switch (compilerOptions.module) {
-        case 2 /* AMD */:
-          return createImportCallExpressionAMD(argument, containsLexicalThis);
-        case 3 /* UMD */:
-          return createImportCallExpressionUMD(argument ?? factory2.createVoidZero(), containsLexicalThis);
-        case 1 /* CommonJS */:
-        default:
-          return createImportCallExpressionCommonJS(argument);
-      }
-    }
-    function createImportCallExpressionUMD(arg, containsLexicalThis) {
-      needUMDDynamicImportHelper = true;
-      if (isSimpleCopiableExpression(arg)) {
-        const argClone = isGeneratedIdentifier(arg) ? arg : isStringLiteral(arg) ? factory2.createStringLiteralFromNode(arg) : setEmitFlags(setTextRange(factory2.cloneNode(arg), arg), 3072 /* NoComments */);
-        return factory2.createConditionalExpression(
-          /*condition*/
-          factory2.createIdentifier("__syncRequire"),
-          /*questionToken*/
-          void 0,
-          /*whenTrue*/
-          createImportCallExpressionCommonJS(arg),
-          /*colonToken*/
-          void 0,
-          /*whenFalse*/
-          createImportCallExpressionAMD(argClone, containsLexicalThis)
-        );
-      } else {
-        const temp = factory2.createTempVariable(hoistVariableDeclaration);
-        return factory2.createComma(factory2.createAssignment(temp, arg), factory2.createConditionalExpression(
-          /*condition*/
-          factory2.createIdentifier("__syncRequire"),
-          /*questionToken*/
-          void 0,
-          /*whenTrue*/
-          createImportCallExpressionCommonJS(
-            temp,
-            /*isInlineable*/
-            true
-          ),
-          /*colonToken*/
-          void 0,
-          /*whenFalse*/
-          createImportCallExpressionAMD(temp, containsLexicalThis)
-        ));
-      }
-    }
-    function createImportCallExpressionAMD(arg, containsLexicalThis) {
-      const resolve = factory2.createUniqueName("resolve");
-      const reject = factory2.createUniqueName("reject");
-      const parameters = [
-        factory2.createParameterDeclaration(
-          /*modifiers*/
-          void 0,
-          /*dotDotDotToken*/
-          void 0,
-          /*name*/
-          resolve
-        ),
-        factory2.createParameterDeclaration(
-          /*modifiers*/
-          void 0,
-          /*dotDotDotToken*/
-          void 0,
-          /*name*/
-          reject
-        )
-      ];
-      const body = factory2.createBlock([
-        factory2.createExpressionStatement(
-          factory2.createCallExpression(
-            factory2.createIdentifier("require"),
-            /*typeArguments*/
-            void 0,
-            [factory2.createArrayLiteralExpression([arg || factory2.createOmittedExpression()]), resolve, reject]
-          )
-        )
-      ]);
-      let func;
-      if (languageVersion >= 2 /* ES2015 */) {
-        func = factory2.createArrowFunction(
-          /*modifiers*/
-          void 0,
-          /*typeParameters*/
-          void 0,
-          parameters,
-          /*type*/
-          void 0,
-          /*equalsGreaterThanToken*/
-          void 0,
-          body
-        );
-      } else {
-        func = factory2.createFunctionExpression(
-          /*modifiers*/
-          void 0,
-          /*asteriskToken*/
-          void 0,
-          /*name*/
-          void 0,
-          /*typeParameters*/
-          void 0,
-          parameters,
-          /*type*/
-          void 0,
-          body
-        );
-        if (containsLexicalThis) {
-          setEmitFlags(func, 16 /* CapturesThis */);
-        }
-      }
-      const promise = factory2.createNewExpression(
-        factory2.createIdentifier("Promise"),
-        /*typeArguments*/
-        void 0,
-        [func]
-      );
-      if (getESModuleInterop(compilerOptions)) {
-        return factory2.createCallExpression(
-          factory2.createPropertyAccessExpression(promise, factory2.createIdentifier("then")),
-          /*typeArguments*/
-          void 0,
-          [emitHelpers().createImportStarCallbackHelper()]
-        );
-      }
-      return promise;
-    }
-    function createImportCallExpressionCommonJS(arg, isInlineable) {
-      const needSyncEval = arg && !isSimpleInlineableExpression(arg) && !isInlineable;
-      const promiseResolveCall = factory2.createCallExpression(
-        factory2.createPropertyAccessExpression(factory2.createIdentifier("Promise"), "resolve"),
-        /*typeArguments*/
-        void 0,
-        /*argumentsArray*/
-        needSyncEval ? languageVersion >= 2 /* ES2015 */ ? [
-          factory2.createTemplateExpression(factory2.createTemplateHead(""), [
-            factory2.createTemplateSpan(arg, factory2.createTemplateTail(""))
-          ])
-        ] : [
-          factory2.createCallExpression(
-            factory2.createPropertyAccessExpression(factory2.createStringLiteral(""), "concat"),
-            /*typeArguments*/
-            void 0,
-            [arg]
-          )
-        ] : []
-      );
-      let requireCall = factory2.createCallExpression(
-        factory2.createIdentifier("require"),
-        /*typeArguments*/
-        void 0,
-        needSyncEval ? [factory2.createIdentifier("s")] : arg ? [arg] : []
-      );
-      if (getESModuleInterop(compilerOptions)) {
-        requireCall = emitHelpers().createImportStarHelper(requireCall);
-      }
-      const parameters = needSyncEval ? [
-        factory2.createParameterDeclaration(
-          /*modifiers*/
-          void 0,
-          /*dotDotDotToken*/
-          void 0,
-          /*name*/
-          "s"
-        )
-      ] : [];
-      let func;
-      if (languageVersion >= 2 /* ES2015 */) {
-        func = factory2.createArrowFunction(
-          /*modifiers*/
-          void 0,
-          /*typeParameters*/
-          void 0,
-          /*parameters*/
-          parameters,
-          /*type*/
-          void 0,
-          /*equalsGreaterThanToken*/
-          void 0,
-          requireCall
-        );
-      } else {
-        func = factory2.createFunctionExpression(
-          /*modifiers*/
-          void 0,
-          /*asteriskToken*/
-          void 0,
-          /*name*/
-          void 0,
-          /*typeParameters*/
-          void 0,
-          /*parameters*/
-          parameters,
-          /*type*/
-          void 0,
-          factory2.createBlock([factory2.createReturnStatement(requireCall)])
-        );
-      }
-      const downleveledImport = factory2.createCallExpression(
-        factory2.createPropertyAccessExpression(promiseResolveCall, "then"),
-        /*typeArguments*/
-        void 0,
-        [func]
-      );
-      return downleveledImport;
-    }
-    function getHelperExpressionForExport(node, innerExpr) {
-      if (!getESModuleInterop(compilerOptions) || getInternalEmitFlags(node) & 2 /* NeverApplyImportHelper */) {
-        return innerExpr;
-      }
-      if (getExportNeedsImportStarHelper(node)) {
-        return emitHelpers().createImportStarHelper(innerExpr);
-      }
-      return innerExpr;
-    }
-    function getHelperExpressionForImport(node, innerExpr) {
-      if (!getESModuleInterop(compilerOptions) || getInternalEmitFlags(node) & 2 /* NeverApplyImportHelper */) {
-        return innerExpr;
-      }
-      if (getImportNeedsImportStarHelper(node)) {
-        return emitHelpers().createImportStarHelper(innerExpr);
-      }
-      if (getImportNeedsImportDefaultHelper(node)) {
-        return emitHelpers().createImportDefaultHelper(innerExpr);
-      }
-      return innerExpr;
-    }
-    function visitImportDeclaration(node) {
-      let statements;
-      const namespaceDeclaration = getNamespaceDeclarationNode(node);
-      if (moduleKind !== 2 /* AMD */) {
-        if (!node.importClause) {
-          return setOriginalNode(setTextRange(factory2.createExpressionStatement(createRequireCall2(node)), node), node);
-        } else {
-          const variables = [];
-          if (namespaceDeclaration && !isDefaultImport(node)) {
-            variables.push(
-              factory2.createVariableDeclaration(
-                factory2.cloneNode(namespaceDeclaration.name),
-                /*exclamationToken*/
-                void 0,
-                /*type*/
-                void 0,
-                getHelperExpressionForImport(node, createRequireCall2(node))
-              )
-            );
-          } else {
-            variables.push(
-              factory2.createVariableDeclaration(
-                factory2.getGeneratedNameForNode(node),
-                /*exclamationToken*/
-                void 0,
-                /*type*/
-                void 0,
-                getHelperExpressionForImport(node, createRequireCall2(node))
-              )
-            );
-            if (namespaceDeclaration && isDefaultImport(node)) {
-              variables.push(
-                factory2.createVariableDeclaration(
-                  factory2.cloneNode(namespaceDeclaration.name),
-                  /*exclamationToken*/
-                  void 0,
-                  /*type*/
-                  void 0,
-                  factory2.getGeneratedNameForNode(node)
-                )
-              );
-            }
-          }
-          statements = append(
-            statements,
-            setOriginalNode(
-              setTextRange(
-                factory2.createVariableStatement(
-                  /*modifiers*/
-                  void 0,
-                  factory2.createVariableDeclarationList(
-                    variables,
-                    languageVersion >= 2 /* ES2015 */ ? 2 /* Const */ : 0 /* None */
-                  )
-                ),
-                /*location*/
-                node
-              ),
-              /*original*/
-              node
-            )
-          );
-        }
-      } else if (namespaceDeclaration && isDefaultImport(node)) {
-        statements = append(
-          statements,
-          factory2.createVariableStatement(
-            /*modifiers*/
-            void 0,
-            factory2.createVariableDeclarationList(
-              [
-                setOriginalNode(
-                  setTextRange(
-                    factory2.createVariableDeclaration(
-                      factory2.cloneNode(namespaceDeclaration.name),
-                      /*exclamationToken*/
-                      void 0,
-                      /*type*/
-                      void 0,
-                      factory2.getGeneratedNameForNode(node)
-                    ),
-                    /*location*/
-                    node
-                  ),
-                  /*original*/
-                  node
-                )
-              ],
-              languageVersion >= 2 /* ES2015 */ ? 2 /* Const */ : 0 /* None */
-            )
-          )
-        );
-      }
-      statements = appendExportsOfImportDeclaration(statements, node);
-      return singleOrMany(statements);
-    }
-    function createRequireCall2(importNode) {
-      const moduleName = getExternalModuleNameLiteral(factory2, importNode, currentSourceFile, host, resolver, compilerOptions);
-      const args = [];
-      if (moduleName) {
-        args.push(moduleName);
-      }
-      return factory2.createCallExpression(
-        factory2.createIdentifier("require"),
-        /*typeArguments*/
-        void 0,
-        args
-      );
-    }
-    function visitImportEqualsDeclaration(node) {
-      Debug.assert(isExternalModuleImportEqualsDeclaration(node), "import= for internal module references should be handled in an earlier transformer.");
-      let statements;
-      if (moduleKind !== 2 /* AMD */) {
-        if (hasSyntacticModifier(node, 1 /* Export */)) {
-          statements = append(
-            statements,
-            setOriginalNode(
-              setTextRange(
-                factory2.createExpressionStatement(
-                  createExportExpression(
-                    node.name,
-                    createRequireCall2(node)
-                  )
-                ),
-                node
-              ),
-              node
-            )
-          );
-        } else {
-          statements = append(
-            statements,
-            setOriginalNode(
-              setTextRange(
-                factory2.createVariableStatement(
-                  /*modifiers*/
-                  void 0,
-                  factory2.createVariableDeclarationList(
-                    [
-                      factory2.createVariableDeclaration(
-                        factory2.cloneNode(node.name),
-                        /*exclamationToken*/
-                        void 0,
-                        /*type*/
-                        void 0,
-                        createRequireCall2(node)
-                      )
-                    ],
-                    /*flags*/
-                    languageVersion >= 2 /* ES2015 */ ? 2 /* Const */ : 0 /* None */
-                  )
-                ),
-                node
-              ),
-              node
-            )
-          );
-        }
-      } else {
-        if (hasSyntacticModifier(node, 1 /* Export */)) {
-          statements = append(
-            statements,
-            setOriginalNode(
-              setTextRange(
-                factory2.createExpressionStatement(
-                  createExportExpression(factory2.getExportName(node), factory2.getLocalName(node))
-                ),
-                node
-              ),
-              node
-            )
-          );
-        }
-      }
-      statements = appendExportsOfImportEqualsDeclaration(statements, node);
-      return singleOrMany(statements);
-    }
-    function visitExportDeclaration(node) {
-      if (!node.moduleSpecifier) {
-        return void 0;
-      }
-      const generatedName = factory2.getGeneratedNameForNode(node);
-      if (node.exportClause && isNamedExports(node.exportClause)) {
-        const statements = [];
-        if (moduleKind !== 2 /* AMD */) {
-          statements.push(
-            setOriginalNode(
-              setTextRange(
-                factory2.createVariableStatement(
-                  /*modifiers*/
-                  void 0,
-                  factory2.createVariableDeclarationList([
-                    factory2.createVariableDeclaration(
-                      generatedName,
-                      /*exclamationToken*/
-                      void 0,
-                      /*type*/
-                      void 0,
-                      createRequireCall2(node)
-                    )
-                  ])
-                ),
-                /*location*/
-                node
-              ),
-              /* original */
-              node
-            )
-          );
-        }
-        for (const specifier of node.exportClause.elements) {
-          if (languageVersion === 0 /* ES3 */) {
-            statements.push(
-              setOriginalNode(
-                setTextRange(
-                  factory2.createExpressionStatement(
-                    emitHelpers().createCreateBindingHelper(generatedName, factory2.createStringLiteralFromNode(specifier.propertyName || specifier.name), specifier.propertyName ? factory2.createStringLiteralFromNode(specifier.name) : void 0)
-                  ),
-                  specifier
-                ),
-                specifier
-              )
-            );
-          } else {
-            const exportNeedsImportDefault = !!getESModuleInterop(compilerOptions) && !(getInternalEmitFlags(node) & 2 /* NeverApplyImportHelper */) && idText(specifier.propertyName || specifier.name) === "default";
-            const exportedValue = factory2.createPropertyAccessExpression(
-              exportNeedsImportDefault ? emitHelpers().createImportDefaultHelper(generatedName) : generatedName,
-              specifier.propertyName || specifier.name
-            );
-            statements.push(
-              setOriginalNode(
-                setTextRange(
-                  factory2.createExpressionStatement(
-                    createExportExpression(
-                      factory2.getExportName(specifier),
-                      exportedValue,
-                      /*location*/
-                      void 0,
-                      /*liveBinding*/
-                      true
-                    )
-                  ),
-                  specifier
-                ),
-                specifier
-              )
-            );
-          }
-        }
-        return singleOrMany(statements);
-      } else if (node.exportClause) {
-        const statements = [];
-        statements.push(
-          setOriginalNode(
-            setTextRange(
-              factory2.createExpressionStatement(
-                createExportExpression(
-                  factory2.cloneNode(node.exportClause.name),
-                  getHelperExpressionForExport(node, moduleKind !== 2 /* AMD */ ? createRequireCall2(node) : isExportNamespaceAsDefaultDeclaration(node) ? generatedName : factory2.createIdentifier(idText(node.exportClause.name)))
-                )
-              ),
-              node
-            ),
-            node
-          )
-        );
-        return singleOrMany(statements);
-      } else {
-        return setOriginalNode(
-          setTextRange(
-            factory2.createExpressionStatement(
-              emitHelpers().createExportStarHelper(moduleKind !== 2 /* AMD */ ? createRequireCall2(node) : generatedName)
-            ),
-            node
-          ),
-          node
-        );
-      }
-    }
-    function visitExportAssignment(node) {
-      if (node.isExportEquals) {
-        return void 0;
-      }
-      return createExportStatement(
-        factory2.createIdentifier("default"),
-        visitNode(node.expression, visitor, isExpression),
-        /*location*/
-        node,
-        /*allowComments*/
-        true
-      );
-    }
-    function visitFunctionDeclaration(node) {
-      let statements;
-      if (hasSyntacticModifier(node, 1 /* Export */)) {
-        statements = append(
-          statements,
-          setOriginalNode(
-            setTextRange(
-              factory2.createFunctionDeclaration(
-                visitNodes2(node.modifiers, modifierVisitor, isModifier),
-                node.asteriskToken,
-                factory2.getDeclarationName(
-                  node,
-                  /*allowComments*/
-                  true,
-                  /*allowSourceMaps*/
-                  true
-                ),
-                /*typeParameters*/
-                void 0,
-                visitNodes2(node.parameters, visitor, isParameter),
-                /*type*/
-                void 0,
-                visitEachChild(node.body, visitor, context)
-              ),
-              /*location*/
-              node
-            ),
-            /*original*/
-            node
-          )
-        );
-      } else {
-        statements = append(statements, visitEachChild(node, visitor, context));
-      }
-      statements = appendExportsOfHoistedDeclaration(statements, node);
-      return singleOrMany(statements);
-    }
-    function visitClassDeclaration(node) {
-      let statements;
-      if (hasSyntacticModifier(node, 1 /* Export */)) {
-        statements = append(
-          statements,
-          setOriginalNode(
-            setTextRange(
-              factory2.createClassDeclaration(
-                visitNodes2(node.modifiers, modifierVisitor, isModifierLike),
-                factory2.getDeclarationName(
-                  node,
-                  /*allowComments*/
-                  true,
-                  /*allowSourceMaps*/
-                  true
-                ),
-                /*typeParameters*/
-                void 0,
-                visitNodes2(node.heritageClauses, visitor, isHeritageClause),
-                visitNodes2(node.members, visitor, isClassElement)
-              ),
-              node
-            ),
-            node
-          )
-        );
-      } else {
-        statements = append(statements, visitEachChild(node, visitor, context));
-      }
-      statements = appendExportsOfHoistedDeclaration(statements, node);
-      return singleOrMany(statements);
-    }
-    function visitVariableStatement(node) {
-      let statements;
-      let variables;
-      let expressions;
-      if (hasSyntacticModifier(node, 1 /* Export */)) {
-        let modifiers;
-        let removeCommentsOnExpressions = false;
-        for (const variable of node.declarationList.declarations) {
-          if (isIdentifier(variable.name) && isLocalName(variable.name)) {
-            if (!modifiers) {
-              modifiers = visitNodes2(node.modifiers, modifierVisitor, isModifier);
-            }
-            if (variable.initializer) {
-              const updatedVariable = factory2.updateVariableDeclaration(
-                variable,
-                variable.name,
-                /*exclamationToken*/
-                void 0,
-                /*type*/
-                void 0,
-                createExportExpression(
-                  variable.name,
-                  visitNode(variable.initializer, visitor, isExpression)
-                )
-              );
-              variables = append(variables, updatedVariable);
-            } else {
-              variables = append(variables, variable);
-            }
-          } else if (variable.initializer) {
-            if (!isBindingPattern(variable.name) && (isArrowFunction(variable.initializer) || isFunctionExpression(variable.initializer) || isClassExpression(variable.initializer))) {
-              const expression = factory2.createAssignment(
-                setTextRange(
-                  factory2.createPropertyAccessExpression(
-                    factory2.createIdentifier("exports"),
-                    variable.name
-                  ),
-                  /*location*/
-                  variable.name
-                ),
-                factory2.createIdentifier(getTextOfIdentifierOrLiteral(variable.name))
-              );
-              const updatedVariable = factory2.createVariableDeclaration(
-                variable.name,
-                variable.exclamationToken,
-                variable.type,
-                visitNode(variable.initializer, visitor, isExpression)
-              );
-              variables = append(variables, updatedVariable);
-              expressions = append(expressions, expression);
-              removeCommentsOnExpressions = true;
-            } else {
-              expressions = append(expressions, transformInitializedVariable(variable));
-            }
-          }
-        }
-        if (variables) {
-          statements = append(statements, factory2.updateVariableStatement(node, modifiers, factory2.updateVariableDeclarationList(node.declarationList, variables)));
-        }
-        if (expressions) {
-          const statement = setOriginalNode(setTextRange(factory2.createExpressionStatement(factory2.inlineExpressions(expressions)), node), node);
-          if (removeCommentsOnExpressions) {
-            removeAllComments(statement);
-          }
-          statements = append(statements, statement);
-        }
-      } else {
-        statements = append(statements, visitEachChild(node, visitor, context));
-      }
-      statements = appendExportsOfVariableStatement(statements, node);
-      return singleOrMany(statements);
-    }
-    function createAllExportExpressions(name, value, location) {
-      const exportedNames = getExports(name);
-      if (exportedNames) {
-        let expression = isExportName(name) ? value : factory2.createAssignment(name, value);
-        for (const exportName of exportedNames) {
-          setEmitFlags(expression, 8 /* NoSubstitution */);
-          expression = createExportExpression(
-            exportName,
-            expression,
-            /*location*/
-            location
-          );
-        }
-        return expression;
-      }
-      return factory2.createAssignment(name, value);
-    }
-    function transformInitializedVariable(node) {
-      if (isBindingPattern(node.name)) {
-        return flattenDestructuringAssignment(
-          visitNode(node, visitor, isInitializedVariable),
-          visitor,
-          context,
-          0 /* All */,
-          /*needsValue*/
-          false,
-          createAllExportExpressions
-        );
-      } else {
-        return factory2.createAssignment(
-          setTextRange(
-            factory2.createPropertyAccessExpression(
-              factory2.createIdentifier("exports"),
-              node.name
-            ),
-            /*location*/
-            node.name
-          ),
-          node.initializer ? visitNode(node.initializer, visitor, isExpression) : factory2.createVoidZero()
-        );
-      }
-    }
-    function appendExportsOfImportDeclaration(statements, decl) {
-      if (currentModuleInfo.exportEquals) {
-        return statements;
-      }
-      const importClause = decl.importClause;
-      if (!importClause) {
-        return statements;
-      }
-      if (importClause.name) {
-        statements = appendExportsOfDeclaration(statements, importClause);
-      }
-      const namedBindings = importClause.namedBindings;
-      if (namedBindings) {
-        switch (namedBindings.kind) {
-          case 273 /* NamespaceImport */:
-            statements = appendExportsOfDeclaration(statements, namedBindings);
-            break;
-          case 274 /* NamedImports */:
-            for (const importBinding of namedBindings.elements) {
-              statements = appendExportsOfDeclaration(
-                statements,
-                importBinding,
-                /*liveBinding*/
-                true
-              );
-            }
-            break;
-        }
-      }
-      return statements;
-    }
-    function appendExportsOfImportEqualsDeclaration(statements, decl) {
-      if (currentModuleInfo.exportEquals) {
-        return statements;
-      }
-      return appendExportsOfDeclaration(statements, decl);
-    }
-    function appendExportsOfVariableStatement(statements, node) {
-      return appendExportsOfVariableDeclarationList(
-        statements,
-        node.declarationList,
-        /*isForInOrOfInitializer*/
-        false
-      );
-    }
-    function appendExportsOfVariableDeclarationList(statements, node, isForInOrOfInitializer) {
-      if (currentModuleInfo.exportEquals) {
-        return statements;
-      }
-      for (const decl of node.declarations) {
-        statements = appendExportsOfBindingElement(statements, decl, isForInOrOfInitializer);
-      }
-      return statements;
-    }
-    function appendExportsOfBindingElement(statements, decl, isForInOrOfInitializer) {
-      if (currentModuleInfo.exportEquals) {
-        return statements;
-      }
-      if (isBindingPattern(decl.name)) {
-        for (const element of decl.name.elements) {
-          if (!isOmittedExpression(element)) {
-            statements = appendExportsOfBindingElement(statements, element, isForInOrOfInitializer);
-          }
-        }
-      } else if (!isGeneratedIdentifier(decl.name) && (!isVariableDeclaration(decl) || decl.initializer || isForInOrOfInitializer)) {
-        statements = appendExportsOfDeclaration(statements, decl);
-      }
-      return statements;
-    }
-    function appendExportsOfHoistedDeclaration(statements, decl) {
-      if (currentModuleInfo.exportEquals) {
-        return statements;
-      }
-      if (hasSyntacticModifier(decl, 1 /* Export */)) {
-        const exportName = hasSyntacticModifier(decl, 1024 /* Default */) ? factory2.createIdentifier("default") : factory2.getDeclarationName(decl);
-        statements = appendExportStatement(
-          statements,
-          exportName,
-          factory2.getLocalName(decl),
-          /*location*/
-          decl
-        );
-      }
-      if (decl.name) {
-        statements = appendExportsOfDeclaration(statements, decl);
-      }
-      return statements;
-    }
-    function appendExportsOfDeclaration(statements, decl, liveBinding) {
-      const name = factory2.getDeclarationName(decl);
-      const exportSpecifiers = currentModuleInfo.exportSpecifiers.get(idText(name));
-      if (exportSpecifiers) {
-        for (const exportSpecifier of exportSpecifiers) {
-          statements = appendExportStatement(
-            statements,
-            exportSpecifier.name,
-            name,
-            /*location*/
-            exportSpecifier.name,
-            /*allowComments*/
-            void 0,
-            liveBinding
-          );
-        }
-      }
-      return statements;
-    }
-    function appendExportStatement(statements, exportName, expression, location, allowComments, liveBinding) {
-      statements = append(statements, createExportStatement(exportName, expression, location, allowComments, liveBinding));
-      return statements;
-    }
-    function createUnderscoreUnderscoreESModule() {
-      let statement;
-      if (languageVersion === 0 /* ES3 */) {
-        statement = factory2.createExpressionStatement(
-          createExportExpression(
-            factory2.createIdentifier("__esModule"),
-            factory2.createTrue()
-          )
-        );
-      } else {
-        statement = factory2.createExpressionStatement(
-          factory2.createCallExpression(
-            factory2.createPropertyAccessExpression(factory2.createIdentifier("Object"), "defineProperty"),
-            /*typeArguments*/
-            void 0,
-            [
-              factory2.createIdentifier("exports"),
-              factory2.createStringLiteral("__esModule"),
-              factory2.createObjectLiteralExpression([
-                factory2.createPropertyAssignment("value", factory2.createTrue())
-              ])
-            ]
-          )
-        );
-      }
-      setEmitFlags(statement, 2097152 /* CustomPrologue */);
-      return statement;
-    }
-    function createExportStatement(name, value, location, allowComments, liveBinding) {
-      const statement = setTextRange(factory2.createExpressionStatement(createExportExpression(
-        name,
-        value,
-        /*location*/
-        void 0,
-        liveBinding
-      )), location);
-      startOnNewLine(statement);
-      if (!allowComments) {
-        setEmitFlags(statement, 3072 /* NoComments */);
-      }
-      return statement;
-    }
-    function createExportExpression(name, value, location, liveBinding) {
-      return setTextRange(
-        liveBinding && languageVersion !== 0 /* ES3 */ ? factory2.createCallExpression(
-          factory2.createPropertyAccessExpression(
-            factory2.createIdentifier("Object"),
-            "defineProperty"
-          ),
-          /*typeArguments*/
-          void 0,
-          [
-            factory2.createIdentifier("exports"),
-            factory2.createStringLiteralFromNode(name),
-            factory2.createObjectLiteralExpression([
-              factory2.createPropertyAssignment("enumerable", factory2.createTrue()),
-              factory2.createPropertyAssignment("get", factory2.createFunctionExpression(
-                /*modifiers*/
-                void 0,
-                /*asteriskToken*/
-                void 0,
-                /*name*/
-                void 0,
-                /*typeParameters*/
-                void 0,
-                /*parameters*/
-                [],
-                /*type*/
-                void 0,
-                factory2.createBlock([factory2.createReturnStatement(value)])
-              ))
-            ])
-          ]
-        ) : factory2.createAssignment(
-          factory2.createPropertyAccessExpression(
-            factory2.createIdentifier("exports"),
-            factory2.cloneNode(name)
-          ),
-          value
-        ),
-        location
-      );
-    }
-    function modifierVisitor(node) {
-      switch (node.kind) {
-        case 95 /* ExportKeyword */:
-        case 90 /* DefaultKeyword */:
-          return void 0;
-      }
-      return node;
-    }
-    function onEmitNode(hint, node, emitCallback) {
-      if (node.kind === 311 /* SourceFile */) {
-        currentSourceFile = node;
-        currentModuleInfo = moduleInfoMap[getOriginalNodeId(currentSourceFile)];
-        previousOnEmitNode(hint, node, emitCallback);
-        currentSourceFile = void 0;
-        currentModuleInfo = void 0;
-      } else {
-        previousOnEmitNode(hint, node, emitCallback);
-      }
-    }
-    function onSubstituteNode(hint, node) {
-      node = previousOnSubstituteNode(hint, node);
-      if (node.id && noSubstitution[node.id]) {
-        return node;
-      }
-      if (hint === 1 /* Expression */) {
-        return substituteExpression(node);
-      } else if (isShorthandPropertyAssignment(node)) {
-        return substituteShorthandPropertyAssignment(node);
-      }
-      return node;
-    }
-    function substituteShorthandPropertyAssignment(node) {
-      const name = node.name;
-      const exportedOrImportedName = substituteExpressionIdentifier(name);
-      if (exportedOrImportedName !== name) {
-        if (node.objectAssignmentInitializer) {
-          const initializer = factory2.createAssignment(exportedOrImportedName, node.objectAssignmentInitializer);
-          return setTextRange(factory2.createPropertyAssignment(name, initializer), node);
-        }
-        return setTextRange(factory2.createPropertyAssignment(name, exportedOrImportedName), node);
-      }
-      return node;
-    }
-    function substituteExpression(node) {
-      switch (node.kind) {
-        case 80 /* Identifier */:
-          return substituteExpressionIdentifier(node);
-        case 212 /* CallExpression */:
-          return substituteCallExpression(node);
-        case 214 /* TaggedTemplateExpression */:
-          return substituteTaggedTemplateExpression(node);
-        case 225 /* BinaryExpression */:
-          return substituteBinaryExpression(node);
-      }
-      return node;
-    }
-    function substituteCallExpression(node) {
-      if (isIdentifier(node.expression)) {
-        const expression = substituteExpressionIdentifier(node.expression);
-        noSubstitution[getNodeId(expression)] = true;
-        if (!isIdentifier(expression) && !(getEmitFlags(node.expression) & 8192 /* HelperName */)) {
-          return addInternalEmitFlags(
-            factory2.updateCallExpression(
-              node,
-              expression,
-              /*typeArguments*/
-              void 0,
-              node.arguments
-            ),
-            16 /* IndirectCall */
-          );
-        }
-      }
-      return node;
-    }
-    function substituteTaggedTemplateExpression(node) {
-      if (isIdentifier(node.tag)) {
-        const tag = substituteExpressionIdentifier(node.tag);
-        noSubstitution[getNodeId(tag)] = true;
-        if (!isIdentifier(tag) && !(getEmitFlags(node.tag) & 8192 /* HelperName */)) {
-          return addInternalEmitFlags(
-            factory2.updateTaggedTemplateExpression(
-              node,
-              tag,
-              /*typeArguments*/
-              void 0,
-              node.template
-            ),
-            16 /* IndirectCall */
-          );
-        }
-      }
-      return node;
-    }
-    function substituteExpressionIdentifier(node) {
-      var _a, _b;
-      if (getEmitFlags(node) & 8192 /* HelperName */) {
-        const externalHelpersModuleName = getExternalHelpersModuleName(currentSourceFile);
-        if (externalHelpersModuleName) {
-          return factory2.createPropertyAccessExpression(externalHelpersModuleName, node);
-        }
-        return node;
-      } else if (!(isGeneratedIdentifier(node) && !(node.emitNode.autoGenerate.flags & 64 /* AllowNameSubstitution */)) && !isLocalName(node)) {
-        const exportContainer = resolver.getReferencedExportContainer(node, isExportName(node));
-        if (exportContainer && exportContainer.kind === 311 /* SourceFile */) {
-          return setTextRange(
-            factory2.createPropertyAccessExpression(
-              factory2.createIdentifier("exports"),
-              factory2.cloneNode(node)
-            ),
-            /*location*/
-            node
-          );
-        }
-        const importDeclaration = resolver.getReferencedImportDeclaration(node);
-        if (importDeclaration) {
-          if (isImportClause(importDeclaration)) {
-            return setTextRange(
-              factory2.createPropertyAccessExpression(
-                factory2.getGeneratedNameForNode(importDeclaration.parent),
-                factory2.createIdentifier("default")
-              ),
-              /*location*/
-              node
-            );
-          } else if (isImportSpecifier(importDeclaration)) {
-            const name = importDeclaration.propertyName || importDeclaration.name;
-            return setTextRange(
-              factory2.createPropertyAccessExpression(
-                factory2.getGeneratedNameForNode(((_b = (_a = importDeclaration.parent) == null ? void 0 : _a.parent) == null ? void 0 : _b.parent) || importDeclaration),
-                factory2.cloneNode(name)
-              ),
-              /*location*/
-              node
-            );
-          }
-        }
-      }
-      return node;
-    }
-    function substituteBinaryExpression(node) {
-      if (isAssignmentOperator(node.operatorToken.kind) && isIdentifier(node.left) && !isGeneratedIdentifier(node.left) && !isLocalName(node.left)) {
-        const exportedNames = getExports(node.left);
-        if (exportedNames) {
-          let expression = node;
-          for (const exportName of exportedNames) {
-            noSubstitution[getNodeId(expression)] = true;
-            expression = createExportExpression(
-              exportName,
-              expression,
-              /*location*/
-              node
-            );
-          }
-          return expression;
-        }
-      }
-      return node;
-    }
-    function getExports(name) {
-      if (!isGeneratedIdentifier(name)) {
-        const importDeclaration = resolver.getReferencedImportDeclaration(name);
-        if (importDeclaration) {
-          return currentModuleInfo == null ? void 0 : currentModuleInfo.exportedBindings[getOriginalNodeId(importDeclaration)];
-        }
-        const bindingsSet = /* @__PURE__ */ new Set();
-        const declarations = resolver.getReferencedValueDeclarations(name);
-        if (declarations) {
-          for (const declaration of declarations) {
-            const bindings = currentModuleInfo == null ? void 0 : currentModuleInfo.exportedBindings[getOriginalNodeId(declaration)];
-            if (bindings) {
-              for (const binding of bindings) {
-                bindingsSet.add(binding);
-              }
-            }
-          }
-          if (bindingsSet.size) {
-            return arrayFrom(bindingsSet);
-          }
-        }
-      }
-    }
-  }
-  var dynamicImportUMDHelper;
-  var init_module = __esm({
-    "src/compiler/transformers/module/module.ts"() {
-      "use strict";
-      init_ts2();
-      dynamicImportUMDHelper = {
-        name: "typescript:dynamicimport-sync-require",
-        scoped: true,
-        text: `
-            var __syncRequire = typeof module === "object" && typeof module.exports === "object";`
-      };
-    }
-  });
-
-  // src/compiler/transformers/module/system.ts
-  function transformSystemModule(context) {
-    const {
-      factory: factory2,
-      startLexicalEnvironment,
-      endLexicalEnvironment,
-      hoistVariableDeclaration
-    } = context;
-    const compilerOptions = context.getCompilerOptions();
-    const resolver = context.getEmitResolver();
-    const host = context.getEmitHost();
-    const previousOnSubstituteNode = context.onSubstituteNode;
-    const previousOnEmitNode = context.onEmitNode;
-    context.onSubstituteNode = onSubstituteNode;
-    context.onEmitNode = onEmitNode;
-    context.enableSubstitution(80 /* Identifier */);
-    context.enableSubstitution(303 /* ShorthandPropertyAssignment */);
-    context.enableSubstitution(225 /* BinaryExpression */);
-    context.enableSubstitution(235 /* MetaProperty */);
-    context.enableEmitNotification(311 /* SourceFile */);
-    const moduleInfoMap = [];
-    const exportFunctionsMap = [];
-    const noSubstitutionMap = [];
-    const contextObjectMap = [];
-    let currentSourceFile;
-    let moduleInfo;
-    let exportFunction;
-    let contextObject;
-    let hoistedStatements;
-    let enclosingBlockScopedContainer;
-    let noSubstitution;
-    return chainBundle(context, transformSourceFile);
-    function transformSourceFile(node) {
-      if (node.isDeclarationFile || !(isEffectiveExternalModule(node, compilerOptions) || node.transformFlags & 8388608 /* ContainsDynamicImport */)) {
-        return node;
-      }
-      const id = getOriginalNodeId(node);
-      currentSourceFile = node;
-      enclosingBlockScopedContainer = node;
-      moduleInfo = moduleInfoMap[id] = collectExternalModuleInfo(context, node, resolver, compilerOptions);
-      exportFunction = factory2.createUniqueName("exports");
-      exportFunctionsMap[id] = exportFunction;
-      contextObject = contextObjectMap[id] = factory2.createUniqueName("context");
-      const dependencyGroups = collectDependencyGroups(moduleInfo.externalImports);
-      const moduleBodyBlock = createSystemModuleBody(node, dependencyGroups);
-      const moduleBodyFunction = factory2.createFunctionExpression(
-        /*modifiers*/
-        void 0,
-        /*asteriskToken*/
-        void 0,
-        /*name*/
-        void 0,
-        /*typeParameters*/
-        void 0,
-        [
-          factory2.createParameterDeclaration(
-            /*modifiers*/
-            void 0,
-            /*dotDotDotToken*/
-            void 0,
-            exportFunction
-          ),
-          factory2.createParameterDeclaration(
-            /*modifiers*/
-            void 0,
-            /*dotDotDotToken*/
-            void 0,
-            contextObject
-          )
-        ],
-        /*type*/
-        void 0,
-        moduleBodyBlock
-      );
-      const moduleName = tryGetModuleNameFromFile(factory2, node, host, compilerOptions);
-      const dependencies = factory2.createArrayLiteralExpression(map(dependencyGroups, (dependencyGroup) => dependencyGroup.name));
-      const updated = setEmitFlags(
-        factory2.updateSourceFile(
-          node,
-          setTextRange(
-            factory2.createNodeArray([
-              factory2.createExpressionStatement(
-                factory2.createCallExpression(
-                  factory2.createPropertyAccessExpression(factory2.createIdentifier("System"), "register"),
-                  /*typeArguments*/
-                  void 0,
-                  moduleName ? [moduleName, dependencies, moduleBodyFunction] : [dependencies, moduleBodyFunction]
-                )
-              )
-            ]),
-            node.statements
-          )
-        ),
-        2048 /* NoTrailingComments */
-      );
-      if (!outFile(compilerOptions)) {
-        moveEmitHelpers(updated, moduleBodyBlock, (helper) => !helper.scoped);
-      }
-      if (noSubstitution) {
-        noSubstitutionMap[id] = noSubstitution;
-        noSubstitution = void 0;
-      }
-      currentSourceFile = void 0;
-      moduleInfo = void 0;
-      exportFunction = void 0;
-      contextObject = void 0;
-      hoistedStatements = void 0;
-      enclosingBlockScopedContainer = void 0;
-      return updated;
-    }
-    function collectDependencyGroups(externalImports) {
-      const groupIndices = /* @__PURE__ */ new Map();
-      const dependencyGroups = [];
-      for (const externalImport of externalImports) {
-        const externalModuleName = getExternalModuleNameLiteral(factory2, externalImport, currentSourceFile, host, resolver, compilerOptions);
-        if (externalModuleName) {
-          const text = externalModuleName.text;
-          const groupIndex = groupIndices.get(text);
-          if (groupIndex !== void 0) {
-            dependencyGroups[groupIndex].externalImports.push(externalImport);
-          } else {
-            groupIndices.set(text, dependencyGroups.length);
-            dependencyGroups.push({
-              name: externalModuleName,
-              externalImports: [externalImport]
-            });
-          }
-        }
-      }
-      return dependencyGroups;
-    }
-    function createSystemModuleBody(node, dependencyGroups) {
-      const statements = [];
-      startLexicalEnvironment();
-      const ensureUseStrict = getStrictOptionValue(compilerOptions, "alwaysStrict") || !compilerOptions.noImplicitUseStrict && isExternalModule(currentSourceFile);
-      const statementOffset = factory2.copyPrologue(node.statements, statements, ensureUseStrict, topLevelVisitor);
-      statements.push(
-        factory2.createVariableStatement(
-          /*modifiers*/
-          void 0,
-          factory2.createVariableDeclarationList([
-            factory2.createVariableDeclaration(
-              "__moduleName",
-              /*exclamationToken*/
-              void 0,
-              /*type*/
-              void 0,
-              factory2.createLogicalAnd(
-                contextObject,
-                factory2.createPropertyAccessExpression(contextObject, "id")
-              )
-            )
-          ])
-        )
-      );
-      visitNode(moduleInfo.externalHelpersImportDeclaration, topLevelVisitor, isStatement);
-      const executeStatements = visitNodes2(node.statements, topLevelVisitor, isStatement, statementOffset);
-      addRange(statements, hoistedStatements);
-      insertStatementsAfterStandardPrologue(statements, endLexicalEnvironment());
-      const exportStarFunction = addExportStarIfNeeded(statements);
-      const modifiers = node.transformFlags & 2097152 /* ContainsAwait */ ? factory2.createModifiersFromModifierFlags(512 /* Async */) : void 0;
-      const moduleObject = factory2.createObjectLiteralExpression(
-        [
-          factory2.createPropertyAssignment(
-            "setters",
-            createSettersArray(exportStarFunction, dependencyGroups)
-          ),
-          factory2.createPropertyAssignment(
-            "execute",
-            factory2.createFunctionExpression(
-              modifiers,
-              /*asteriskToken*/
-              void 0,
-              /*name*/
-              void 0,
-              /*typeParameters*/
-              void 0,
-              /*parameters*/
-              [],
-              /*type*/
-              void 0,
-              factory2.createBlock(
-                executeStatements,
-                /*multiLine*/
-                true
-              )
-            )
-          )
-        ],
-        /*multiLine*/
-        true
-      );
-      statements.push(factory2.createReturnStatement(moduleObject));
-      return factory2.createBlock(
-        statements,
-        /*multiLine*/
-        true
-      );
-    }
-    function addExportStarIfNeeded(statements) {
-      if (!moduleInfo.hasExportStarsToExportValues) {
-        return;
-      }
-      if (!moduleInfo.exportedNames && moduleInfo.exportSpecifiers.size === 0) {
-        let hasExportDeclarationWithExportClause = false;
-        for (const externalImport of moduleInfo.externalImports) {
-          if (externalImport.kind === 277 /* ExportDeclaration */ && externalImport.exportClause) {
-            hasExportDeclarationWithExportClause = true;
-            break;
-          }
-        }
-        if (!hasExportDeclarationWithExportClause) {
-          const exportStarFunction2 = createExportStarFunction(
-            /*localNames*/
-            void 0
-          );
-          statements.push(exportStarFunction2);
-          return exportStarFunction2.name;
-        }
-      }
-      const exportedNames = [];
-      if (moduleInfo.exportedNames) {
-        for (const exportedLocalName of moduleInfo.exportedNames) {
-          if (exportedLocalName.escapedText === "default") {
-            continue;
-          }
-          exportedNames.push(
-            factory2.createPropertyAssignment(
-              factory2.createStringLiteralFromNode(exportedLocalName),
-              factory2.createTrue()
-            )
-          );
-        }
-      }
-      const exportedNamesStorageRef = factory2.createUniqueName("exportedNames");
-      statements.push(
-        factory2.createVariableStatement(
-          /*modifiers*/
-          void 0,
-          factory2.createVariableDeclarationList([
-            factory2.createVariableDeclaration(
-              exportedNamesStorageRef,
-              /*exclamationToken*/
-              void 0,
-              /*type*/
-              void 0,
-              factory2.createObjectLiteralExpression(
-                exportedNames,
-                /*multiLine*/
-                true
-              )
-            )
-          ])
-        )
-      );
-      const exportStarFunction = createExportStarFunction(exportedNamesStorageRef);
-      statements.push(exportStarFunction);
-      return exportStarFunction.name;
-    }
-    function createExportStarFunction(localNames) {
-      const exportStarFunction = factory2.createUniqueName("exportStar");
-      const m = factory2.createIdentifier("m");
-      const n = factory2.createIdentifier("n");
-      const exports = factory2.createIdentifier("exports");
-      let condition = factory2.createStrictInequality(n, factory2.createStringLiteral("default"));
-      if (localNames) {
-        condition = factory2.createLogicalAnd(
-          condition,
-          factory2.createLogicalNot(
-            factory2.createCallExpression(
-              factory2.createPropertyAccessExpression(localNames, "hasOwnProperty"),
-              /*typeArguments*/
-              void 0,
-              [n]
-            )
-          )
-        );
-      }
-      return factory2.createFunctionDeclaration(
-        /*modifiers*/
-        void 0,
-        /*asteriskToken*/
-        void 0,
-        exportStarFunction,
-        /*typeParameters*/
-        void 0,
-        [factory2.createParameterDeclaration(
-          /*modifiers*/
-          void 0,
-          /*dotDotDotToken*/
-          void 0,
-          m
-        )],
-        /*type*/
-        void 0,
-        factory2.createBlock(
-          [
-            factory2.createVariableStatement(
-              /*modifiers*/
-              void 0,
-              factory2.createVariableDeclarationList([
-                factory2.createVariableDeclaration(
-                  exports,
-                  /*exclamationToken*/
-                  void 0,
-                  /*type*/
-                  void 0,
-                  factory2.createObjectLiteralExpression([])
-                )
-              ])
-            ),
-            factory2.createForInStatement(
-              factory2.createVariableDeclarationList([
-                factory2.createVariableDeclaration(n)
-              ]),
-              m,
-              factory2.createBlock([
-                setEmitFlags(
-                  factory2.createIfStatement(
-                    condition,
-                    factory2.createExpressionStatement(
-                      factory2.createAssignment(
-                        factory2.createElementAccessExpression(exports, n),
-                        factory2.createElementAccessExpression(m, n)
-                      )
-                    )
-                  ),
-                  1 /* SingleLine */
-                )
-              ])
-            ),
-            factory2.createExpressionStatement(
-              factory2.createCallExpression(
-                exportFunction,
-                /*typeArguments*/
-                void 0,
-                [exports]
-              )
-            )
-          ],
-          /*multiLine*/
-          true
-        )
-      );
-    }
-    function createSettersArray(exportStarFunction, dependencyGroups) {
-      const setters = [];
-      for (const group2 of dependencyGroups) {
-        const localName = forEach(group2.externalImports, (i) => getLocalNameForExternalImport(factory2, i, currentSourceFile));
-        const parameterName = localName ? factory2.getGeneratedNameForNode(localName) : factory2.createUniqueName("");
-        const statements = [];
-        for (const entry of group2.externalImports) {
-          const importVariableName = getLocalNameForExternalImport(factory2, entry, currentSourceFile);
-          switch (entry.kind) {
-            case 271 /* ImportDeclaration */:
-              if (!entry.importClause) {
-                break;
-              }
-            case 270 /* ImportEqualsDeclaration */:
-              Debug.assert(importVariableName !== void 0);
-              statements.push(
-                factory2.createExpressionStatement(
-                  factory2.createAssignment(importVariableName, parameterName)
-                )
-              );
-              if (hasSyntacticModifier(entry, 1 /* Export */)) {
-                statements.push(
-                  factory2.createExpressionStatement(
-                    factory2.createCallExpression(
-                      exportFunction,
-                      /*typeArguments*/
-                      void 0,
-                      [
-                        factory2.createStringLiteral(idText(importVariableName)),
-                        parameterName
-                      ]
-                    )
-                  )
-                );
-              }
-              break;
-            case 277 /* ExportDeclaration */:
-              Debug.assert(importVariableName !== void 0);
-              if (entry.exportClause) {
-                if (isNamedExports(entry.exportClause)) {
-                  const properties = [];
-                  for (const e of entry.exportClause.elements) {
-                    properties.push(
-                      factory2.createPropertyAssignment(
-                        factory2.createStringLiteral(idText(e.name)),
-                        factory2.createElementAccessExpression(
-                          parameterName,
-                          factory2.createStringLiteral(idText(e.propertyName || e.name))
-                        )
-                      )
-                    );
-                  }
-                  statements.push(
-                    factory2.createExpressionStatement(
-                      factory2.createCallExpression(
-                        exportFunction,
-                        /*typeArguments*/
-                        void 0,
-                        [factory2.createObjectLiteralExpression(
-                          properties,
-                          /*multiLine*/
-                          true
-                        )]
-                      )
-                    )
-                  );
-                } else {
-                  statements.push(
-                    factory2.createExpressionStatement(
-                      factory2.createCallExpression(
-                        exportFunction,
-                        /*typeArguments*/
-                        void 0,
-                        [
-                          factory2.createStringLiteral(idText(entry.exportClause.name)),
-                          parameterName
-                        ]
-                      )
-                    )
-                  );
-                }
-              } else {
-                statements.push(
-                  factory2.createExpressionStatement(
-                    factory2.createCallExpression(
-                      exportStarFunction,
-                      /*typeArguments*/
-                      void 0,
-                      [parameterName]
-                    )
-                  )
-                );
-              }
-              break;
-          }
-        }
-        setters.push(
-          factory2.createFunctionExpression(
-            /*modifiers*/
-            void 0,
-            /*asteriskToken*/
-            void 0,
-            /*name*/
-            void 0,
-            /*typeParameters*/
-            void 0,
-            [factory2.createParameterDeclaration(
-              /*modifiers*/
-              void 0,
-              /*dotDotDotToken*/
-              void 0,
-              parameterName
-            )],
-            /*type*/
-            void 0,
-            factory2.createBlock(
-              statements,
-              /*multiLine*/
-              true
-            )
-          )
-        );
-      }
-      return factory2.createArrayLiteralExpression(
-        setters,
-        /*multiLine*/
-        true
-      );
-    }
-    function topLevelVisitor(node) {
-      switch (node.kind) {
-        case 271 /* ImportDeclaration */:
-          return visitImportDeclaration(node);
-        case 270 /* ImportEqualsDeclaration */:
-          return visitImportEqualsDeclaration(node);
-        case 277 /* ExportDeclaration */:
-          return visitExportDeclaration(node);
-        case 276 /* ExportAssignment */:
-          return visitExportAssignment(node);
-        default:
-          return topLevelNestedVisitor(node);
-      }
-    }
-    function visitImportDeclaration(node) {
-      let statements;
-      if (node.importClause) {
-        hoistVariableDeclaration(getLocalNameForExternalImport(factory2, node, currentSourceFile));
-      }
-      return singleOrMany(appendExportsOfImportDeclaration(statements, node));
-    }
-    function visitExportDeclaration(node) {
-      Debug.assertIsDefined(node);
-      return void 0;
-    }
-    function visitImportEqualsDeclaration(node) {
-      Debug.assert(isExternalModuleImportEqualsDeclaration(node), "import= for internal module references should be handled in an earlier transformer.");
-      let statements;
-      hoistVariableDeclaration(getLocalNameForExternalImport(factory2, node, currentSourceFile));
-      return singleOrMany(appendExportsOfImportEqualsDeclaration(statements, node));
-    }
-    function visitExportAssignment(node) {
-      if (node.isExportEquals) {
-        return void 0;
-      }
-      const expression = visitNode(node.expression, visitor, isExpression);
-      return createExportStatement(
-        factory2.createIdentifier("default"),
-        expression,
-        /*allowComments*/
-        true
-      );
-    }
-    function visitFunctionDeclaration(node) {
-      if (hasSyntacticModifier(node, 1 /* Export */)) {
-        hoistedStatements = append(
-          hoistedStatements,
-          factory2.updateFunctionDeclaration(
-            node,
-            visitNodes2(node.modifiers, modifierVisitor, isModifierLike),
-            node.asteriskToken,
-            factory2.getDeclarationName(
-              node,
-              /*allowComments*/
-              true,
-              /*allowSourceMaps*/
-              true
-            ),
-            /*typeParameters*/
-            void 0,
-            visitNodes2(node.parameters, visitor, isParameter),
-            /*type*/
-            void 0,
-            visitNode(node.body, visitor, isBlock)
-          )
-        );
-      } else {
-        hoistedStatements = append(hoistedStatements, visitEachChild(node, visitor, context));
-      }
-      hoistedStatements = appendExportsOfHoistedDeclaration(hoistedStatements, node);
-      return void 0;
-    }
-    function visitClassDeclaration(node) {
-      let statements;
-      const name = factory2.getLocalName(node);
-      hoistVariableDeclaration(name);
-      statements = append(
-        statements,
-        setTextRange(
-          factory2.createExpressionStatement(
-            factory2.createAssignment(
-              name,
-              setTextRange(
-                factory2.createClassExpression(
-                  visitNodes2(node.modifiers, modifierVisitor, isModifierLike),
-                  node.name,
-                  /*typeParameters*/
-                  void 0,
-                  visitNodes2(node.heritageClauses, visitor, isHeritageClause),
-                  visitNodes2(node.members, visitor, isClassElement)
-                ),
-                node
-              )
-            )
-          ),
-          node
-        )
-      );
-      statements = appendExportsOfHoistedDeclaration(statements, node);
-      return singleOrMany(statements);
-    }
-    function visitVariableStatement(node) {
-      if (!shouldHoistVariableDeclarationList(node.declarationList)) {
-        return visitNode(node, visitor, isStatement);
-      }
-      let expressions;
-      const isExportedDeclaration = hasSyntacticModifier(node, 1 /* Export */);
-      for (const variable of node.declarationList.declarations) {
-        if (variable.initializer) {
-          expressions = append(expressions, transformInitializedVariable(variable, isExportedDeclaration));
-        } else {
-          hoistBindingElement(variable);
-        }
-      }
-      let statements;
-      if (expressions) {
-        statements = append(statements, setTextRange(factory2.createExpressionStatement(factory2.inlineExpressions(expressions)), node));
-      }
-      statements = appendExportsOfVariableStatement(
-        statements,
-        node,
-        /*exportSelf*/
-        false
-      );
-      return singleOrMany(statements);
-    }
-    function hoistBindingElement(node) {
-      if (isBindingPattern(node.name)) {
-        for (const element of node.name.elements) {
-          if (!isOmittedExpression(element)) {
-            hoistBindingElement(element);
-          }
-        }
-      } else {
-        hoistVariableDeclaration(factory2.cloneNode(node.name));
-      }
-    }
-    function shouldHoistVariableDeclarationList(node) {
-      return (getEmitFlags(node) & 4194304 /* NoHoisting */) === 0 && (enclosingBlockScopedContainer.kind === 311 /* SourceFile */ || (getOriginalNode(node).flags & 3 /* BlockScoped */) === 0);
-    }
-    function transformInitializedVariable(node, isExportedDeclaration) {
-      const createAssignment = isExportedDeclaration ? createExportedVariableAssignment : createNonExportedVariableAssignment;
-      return isBindingPattern(node.name) ? flattenDestructuringAssignment(
-        node,
-        visitor,
-        context,
-        0 /* All */,
-        /*needsValue*/
-        false,
-        createAssignment
-      ) : node.initializer ? createAssignment(node.name, visitNode(node.initializer, visitor, isExpression)) : node.name;
-    }
-    function createExportedVariableAssignment(name, value, location) {
-      return createVariableAssignment(
-        name,
-        value,
-        location,
-        /*isExportedDeclaration*/
-        true
-      );
-    }
-    function createNonExportedVariableAssignment(name, value, location) {
-      return createVariableAssignment(
-        name,
-        value,
-        location,
-        /*isExportedDeclaration*/
-        false
-      );
-    }
-    function createVariableAssignment(name, value, location, isExportedDeclaration) {
-      hoistVariableDeclaration(factory2.cloneNode(name));
-      return isExportedDeclaration ? createExportExpression(name, preventSubstitution(setTextRange(factory2.createAssignment(name, value), location))) : preventSubstitution(setTextRange(factory2.createAssignment(name, value), location));
-    }
-    function appendExportsOfImportDeclaration(statements, decl) {
-      if (moduleInfo.exportEquals) {
-        return statements;
-      }
-      const importClause = decl.importClause;
-      if (!importClause) {
-        return statements;
-      }
-      if (importClause.name) {
-        statements = appendExportsOfDeclaration(statements, importClause);
-      }
-      const namedBindings = importClause.namedBindings;
-      if (namedBindings) {
-        switch (namedBindings.kind) {
-          case 273 /* NamespaceImport */:
-            statements = appendExportsOfDeclaration(statements, namedBindings);
-            break;
-          case 274 /* NamedImports */:
-            for (const importBinding of namedBindings.elements) {
-              statements = appendExportsOfDeclaration(statements, importBinding);
-            }
-            break;
-        }
-      }
-      return statements;
-    }
-    function appendExportsOfImportEqualsDeclaration(statements, decl) {
-      if (moduleInfo.exportEquals) {
-        return statements;
-      }
-      return appendExportsOfDeclaration(statements, decl);
-    }
-    function appendExportsOfVariableStatement(statements, node, exportSelf) {
-      if (moduleInfo.exportEquals) {
-        return statements;
-      }
-      for (const decl of node.declarationList.declarations) {
-        if (decl.initializer || exportSelf) {
-          statements = appendExportsOfBindingElement(statements, decl, exportSelf);
-        }
-      }
-      return statements;
-    }
-    function appendExportsOfBindingElement(statements, decl, exportSelf) {
-      if (moduleInfo.exportEquals) {
-        return statements;
-      }
-      if (isBindingPattern(decl.name)) {
-        for (const element of decl.name.elements) {
-          if (!isOmittedExpression(element)) {
-            statements = appendExportsOfBindingElement(statements, element, exportSelf);
-          }
-        }
-      } else if (!isGeneratedIdentifier(decl.name)) {
-        let excludeName;
-        if (exportSelf) {
-          statements = appendExportStatement(statements, decl.name, factory2.getLocalName(decl));
-          excludeName = idText(decl.name);
-        }
-        statements = appendExportsOfDeclaration(statements, decl, excludeName);
-      }
-      return statements;
-    }
-    function appendExportsOfHoistedDeclaration(statements, decl) {
-      if (moduleInfo.exportEquals) {
-        return statements;
-      }
-      let excludeName;
-      if (hasSyntacticModifier(decl, 1 /* Export */)) {
-        const exportName = hasSyntacticModifier(decl, 1024 /* Default */) ? factory2.createStringLiteral("default") : decl.name;
-        statements = appendExportStatement(statements, exportName, factory2.getLocalName(decl));
-        excludeName = getTextOfIdentifierOrLiteral(exportName);
-      }
-      if (decl.name) {
-        statements = appendExportsOfDeclaration(statements, decl, excludeName);
-      }
-      return statements;
-    }
-    function appendExportsOfDeclaration(statements, decl, excludeName) {
-      if (moduleInfo.exportEquals) {
-        return statements;
-      }
-      const name = factory2.getDeclarationName(decl);
-      const exportSpecifiers = moduleInfo.exportSpecifiers.get(idText(name));
-      if (exportSpecifiers) {
-        for (const exportSpecifier of exportSpecifiers) {
-          if (exportSpecifier.name.escapedText !== excludeName) {
-            statements = appendExportStatement(statements, exportSpecifier.name, name);
-          }
-        }
-      }
-      return statements;
-    }
-    function appendExportStatement(statements, exportName, expression, allowComments) {
-      statements = append(statements, createExportStatement(exportName, expression, allowComments));
-      return statements;
-    }
-    function createExportStatement(name, value, allowComments) {
-      const statement = factory2.createExpressionStatement(createExportExpression(name, value));
-      startOnNewLine(statement);
-      if (!allowComments) {
-        setEmitFlags(statement, 3072 /* NoComments */);
-      }
-      return statement;
-    }
-    function createExportExpression(name, value) {
-      const exportName = isIdentifier(name) ? factory2.createStringLiteralFromNode(name) : name;
-      setEmitFlags(value, getEmitFlags(value) | 3072 /* NoComments */);
-      return setCommentRange(factory2.createCallExpression(
-        exportFunction,
-        /*typeArguments*/
-        void 0,
-        [exportName, value]
-      ), value);
-    }
-    function topLevelNestedVisitor(node) {
-      switch (node.kind) {
-        case 242 /* VariableStatement */:
-          return visitVariableStatement(node);
-        case 261 /* FunctionDeclaration */:
-          return visitFunctionDeclaration(node);
-        case 262 /* ClassDeclaration */:
-          return visitClassDeclaration(node);
-        case 247 /* ForStatement */:
-          return visitForStatement(
-            node,
-            /*isTopLevel*/
-            true
-          );
-        case 248 /* ForInStatement */:
-          return visitForInStatement(node);
-        case 249 /* ForOfStatement */:
-          return visitForOfStatement(node);
-        case 245 /* DoStatement */:
-          return visitDoStatement(node);
-        case 246 /* WhileStatement */:
-          return visitWhileStatement(node);
-        case 255 /* LabeledStatement */:
-          return visitLabeledStatement(node);
-        case 253 /* WithStatement */:
-          return visitWithStatement(node);
-        case 244 /* IfStatement */:
-          return visitIfStatement(node);
-        case 254 /* SwitchStatement */:
-          return visitSwitchStatement(node);
-        case 268 /* CaseBlock */:
-          return visitCaseBlock(node);
-        case 295 /* CaseClause */:
-          return visitCaseClause(node);
-        case 296 /* DefaultClause */:
-          return visitDefaultClause(node);
-        case 257 /* TryStatement */:
-          return visitTryStatement(node);
-        case 298 /* CatchClause */:
-          return visitCatchClause(node);
-        case 240 /* Block */:
-          return visitBlock(node);
-        default:
-          return visitor(node);
-      }
-    }
-    function visitForStatement(node, isTopLevel) {
-      const savedEnclosingBlockScopedContainer = enclosingBlockScopedContainer;
-      enclosingBlockScopedContainer = node;
-      node = factory2.updateForStatement(
-        node,
-        visitNode(node.initializer, isTopLevel ? visitForInitializer : discardedValueVisitor, isForInitializer),
-        visitNode(node.condition, visitor, isExpression),
-        visitNode(node.incrementor, discardedValueVisitor, isExpression),
-        visitIterationBody(node.statement, isTopLevel ? topLevelNestedVisitor : visitor, context)
-      );
-      enclosingBlockScopedContainer = savedEnclosingBlockScopedContainer;
-      return node;
-    }
-    function visitForInStatement(node) {
-      const savedEnclosingBlockScopedContainer = enclosingBlockScopedContainer;
-      enclosingBlockScopedContainer = node;
-      node = factory2.updateForInStatement(
-        node,
-        visitForInitializer(node.initializer),
-        visitNode(node.expression, visitor, isExpression),
-        visitIterationBody(node.statement, topLevelNestedVisitor, context)
-      );
-      enclosingBlockScopedContainer = savedEnclosingBlockScopedContainer;
-      return node;
-    }
-    function visitForOfStatement(node) {
-      const savedEnclosingBlockScopedContainer = enclosingBlockScopedContainer;
-      enclosingBlockScopedContainer = node;
-      node = factory2.updateForOfStatement(
-        node,
-        node.awaitModifier,
-        visitForInitializer(node.initializer),
-        visitNode(node.expression, visitor, isExpression),
-        visitIterationBody(node.statement, topLevelNestedVisitor, context)
-      );
-      enclosingBlockScopedContainer = savedEnclosingBlockScopedContainer;
-      return node;
-    }
-    function shouldHoistForInitializer(node) {
-      return isVariableDeclarationList(node) && shouldHoistVariableDeclarationList(node);
-    }
-    function visitForInitializer(node) {
-      if (shouldHoistForInitializer(node)) {
-        let expressions;
-        for (const variable of node.declarations) {
-          expressions = append(expressions, transformInitializedVariable(
-            variable,
-            /*isExportedDeclaration*/
-            false
-          ));
-          if (!variable.initializer) {
-            hoistBindingElement(variable);
-          }
-        }
-        return expressions ? factory2.inlineExpressions(expressions) : factory2.createOmittedExpression();
-      } else {
-        return visitNode(node, discardedValueVisitor, isForInitializer);
-      }
-    }
-    function visitDoStatement(node) {
-      return factory2.updateDoStatement(
-        node,
-        visitIterationBody(node.statement, topLevelNestedVisitor, context),
-        visitNode(node.expression, visitor, isExpression)
-      );
-    }
-    function visitWhileStatement(node) {
-      return factory2.updateWhileStatement(
-        node,
-        visitNode(node.expression, visitor, isExpression),
-        visitIterationBody(node.statement, topLevelNestedVisitor, context)
-      );
-    }
-    function visitLabeledStatement(node) {
-      return factory2.updateLabeledStatement(
-        node,
-        node.label,
-        Debug.checkDefined(visitNode(node.statement, topLevelNestedVisitor, isStatement, factory2.liftToBlock))
-      );
-    }
-    function visitWithStatement(node) {
-      return factory2.updateWithStatement(
-        node,
-        visitNode(node.expression, visitor, isExpression),
-        Debug.checkDefined(visitNode(node.statement, topLevelNestedVisitor, isStatement, factory2.liftToBlock))
-      );
-    }
-    function visitIfStatement(node) {
-      return factory2.updateIfStatement(
-        node,
-        visitNode(node.expression, visitor, isExpression),
-        Debug.checkDefined(visitNode(node.thenStatement, topLevelNestedVisitor, isStatement, factory2.liftToBlock)),
-        visitNode(node.elseStatement, topLevelNestedVisitor, isStatement, factory2.liftToBlock)
-      );
-    }
-    function visitSwitchStatement(node) {
-      return factory2.updateSwitchStatement(
-        node,
-        visitNode(node.expression, visitor, isExpression),
-        Debug.checkDefined(visitNode(node.caseBlock, topLevelNestedVisitor, isCaseBlock))
-      );
-    }
-    function visitCaseBlock(node) {
-      const savedEnclosingBlockScopedContainer = enclosingBlockScopedContainer;
-      enclosingBlockScopedContainer = node;
-      node = factory2.updateCaseBlock(
-        node,
-        visitNodes2(node.clauses, topLevelNestedVisitor, isCaseOrDefaultClause)
-      );
-      enclosingBlockScopedContainer = savedEnclosingBlockScopedContainer;
-      return node;
-    }
-    function visitCaseClause(node) {
-      return factory2.updateCaseClause(
-        node,
-        visitNode(node.expression, visitor, isExpression),
-        visitNodes2(node.statements, topLevelNestedVisitor, isStatement)
-      );
-    }
-    function visitDefaultClause(node) {
-      return visitEachChild(node, topLevelNestedVisitor, context);
-    }
-    function visitTryStatement(node) {
-      return visitEachChild(node, topLevelNestedVisitor, context);
-    }
-    function visitCatchClause(node) {
-      const savedEnclosingBlockScopedContainer = enclosingBlockScopedContainer;
-      enclosingBlockScopedContainer = node;
-      node = factory2.updateCatchClause(
-        node,
-        node.variableDeclaration,
-        Debug.checkDefined(visitNode(node.block, topLevelNestedVisitor, isBlock))
-      );
-      enclosingBlockScopedContainer = savedEnclosingBlockScopedContainer;
-      return node;
-    }
-    function visitBlock(node) {
-      const savedEnclosingBlockScopedContainer = enclosingBlockScopedContainer;
-      enclosingBlockScopedContainer = node;
-      node = visitEachChild(node, topLevelNestedVisitor, context);
-      enclosingBlockScopedContainer = savedEnclosingBlockScopedContainer;
-      return node;
-    }
-    function visitorWorker(node, valueIsDiscarded) {
-      if (!(node.transformFlags & (4096 /* ContainsDestructuringAssignment */ | 8388608 /* ContainsDynamicImport */ | 268435456 /* ContainsUpdateExpressionForIdentifier */))) {
-        return node;
-      }
-      switch (node.kind) {
-        case 247 /* ForStatement */:
-          return visitForStatement(
-            node,
-            /*isTopLevel*/
-            false
-          );
-        case 243 /* ExpressionStatement */:
-          return visitExpressionStatement(node);
-        case 216 /* ParenthesizedExpression */:
-          return visitParenthesizedExpression(node, valueIsDiscarded);
-        case 359 /* PartiallyEmittedExpression */:
-          return visitPartiallyEmittedExpression(node, valueIsDiscarded);
-        case 225 /* BinaryExpression */:
-          if (isDestructuringAssignment(node)) {
-            return visitDestructuringAssignment(node, valueIsDiscarded);
-          }
-          break;
-        case 212 /* CallExpression */:
-          if (isImportCall(node)) {
-            return visitImportCallExpression(node);
-          }
-          break;
-        case 223 /* PrefixUnaryExpression */:
-        case 224 /* PostfixUnaryExpression */:
-          return visitPrefixOrPostfixUnaryExpression(node, valueIsDiscarded);
-      }
-      return visitEachChild(node, visitor, context);
-    }
-    function visitor(node) {
-      return visitorWorker(
-        node,
-        /*valueIsDiscarded*/
-        false
-      );
-    }
-    function discardedValueVisitor(node) {
-      return visitorWorker(
-        node,
-        /*valueIsDiscarded*/
-        true
-      );
-    }
-    function visitExpressionStatement(node) {
-      return factory2.updateExpressionStatement(node, visitNode(node.expression, discardedValueVisitor, isExpression));
-    }
-    function visitParenthesizedExpression(node, valueIsDiscarded) {
-      return factory2.updateParenthesizedExpression(node, visitNode(node.expression, valueIsDiscarded ? discardedValueVisitor : visitor, isExpression));
-    }
-    function visitPartiallyEmittedExpression(node, valueIsDiscarded) {
-      return factory2.updatePartiallyEmittedExpression(node, visitNode(node.expression, valueIsDiscarded ? discardedValueVisitor : visitor, isExpression));
-    }
-    function visitImportCallExpression(node) {
-      const externalModuleName = getExternalModuleNameLiteral(factory2, node, currentSourceFile, host, resolver, compilerOptions);
-      const firstArgument = visitNode(firstOrUndefined(node.arguments), visitor, isExpression);
-      const argument = externalModuleName && (!firstArgument || !isStringLiteral(firstArgument) || firstArgument.text !== externalModuleName.text) ? externalModuleName : firstArgument;
-      return factory2.createCallExpression(
-        factory2.createPropertyAccessExpression(
-          contextObject,
-          factory2.createIdentifier("import")
-        ),
-        /*typeArguments*/
-        void 0,
-        argument ? [argument] : []
-      );
-    }
-    function visitDestructuringAssignment(node, valueIsDiscarded) {
-      if (hasExportedReferenceInDestructuringTarget(node.left)) {
-        return flattenDestructuringAssignment(
-          node,
-          visitor,
-          context,
-          0 /* All */,
-          !valueIsDiscarded
-        );
-      }
-      return visitEachChild(node, visitor, context);
-    }
-    function hasExportedReferenceInDestructuringTarget(node) {
-      if (isAssignmentExpression(
-        node,
-        /*excludeCompoundAssignment*/
-        true
-      )) {
-        return hasExportedReferenceInDestructuringTarget(node.left);
-      } else if (isSpreadElement(node)) {
-        return hasExportedReferenceInDestructuringTarget(node.expression);
-      } else if (isObjectLiteralExpression(node)) {
-        return some(node.properties, hasExportedReferenceInDestructuringTarget);
-      } else if (isArrayLiteralExpression(node)) {
-        return some(node.elements, hasExportedReferenceInDestructuringTarget);
-      } else if (isShorthandPropertyAssignment(node)) {
-        return hasExportedReferenceInDestructuringTarget(node.name);
-      } else if (isPropertyAssignment(node)) {
-        return hasExportedReferenceInDestructuringTarget(node.initializer);
-      } else if (isIdentifier(node)) {
-        const container = resolver.getReferencedExportContainer(node);
-        return container !== void 0 && container.kind === 311 /* SourceFile */;
-      } else {
-        return false;
-      }
-    }
-    function visitPrefixOrPostfixUnaryExpression(node, valueIsDiscarded) {
-      if ((node.operator === 46 /* PlusPlusToken */ || node.operator === 47 /* MinusMinusToken */) && isIdentifier(node.operand) && !isGeneratedIdentifier(node.operand) && !isLocalName(node.operand) && !isDeclarationNameOfEnumOrNamespace(node.operand)) {
-        const exportedNames = getExports(node.operand);
-        if (exportedNames) {
-          let temp;
-          let expression = visitNode(node.operand, visitor, isExpression);
-          if (isPrefixUnaryExpression(node)) {
-            expression = factory2.updatePrefixUnaryExpression(node, expression);
-          } else {
-            expression = factory2.updatePostfixUnaryExpression(node, expression);
-            if (!valueIsDiscarded) {
-              temp = factory2.createTempVariable(hoistVariableDeclaration);
-              expression = factory2.createAssignment(temp, expression);
-              setTextRange(expression, node);
-            }
-            expression = factory2.createComma(expression, factory2.cloneNode(node.operand));
-            setTextRange(expression, node);
-          }
-          for (const exportName of exportedNames) {
-            expression = createExportExpression(exportName, preventSubstitution(expression));
-          }
-          if (temp) {
-            expression = factory2.createComma(expression, temp);
-            setTextRange(expression, node);
-          }
-          return expression;
-        }
-      }
-      return visitEachChild(node, visitor, context);
-    }
-    function modifierVisitor(node) {
-      switch (node.kind) {
-        case 95 /* ExportKeyword */:
-        case 90 /* DefaultKeyword */:
-          return void 0;
-      }
-      return node;
-    }
-    function onEmitNode(hint, node, emitCallback) {
-      if (node.kind === 311 /* SourceFile */) {
-        const id = getOriginalNodeId(node);
-        currentSourceFile = node;
-        moduleInfo = moduleInfoMap[id];
-        exportFunction = exportFunctionsMap[id];
-        noSubstitution = noSubstitutionMap[id];
-        contextObject = contextObjectMap[id];
-        if (noSubstitution) {
-          delete noSubstitutionMap[id];
-        }
-        previousOnEmitNode(hint, node, emitCallback);
-        currentSourceFile = void 0;
-        moduleInfo = void 0;
-        exportFunction = void 0;
-        contextObject = void 0;
-        noSubstitution = void 0;
-      } else {
-        previousOnEmitNode(hint, node, emitCallback);
-      }
-    }
-    function onSubstituteNode(hint, node) {
-      node = previousOnSubstituteNode(hint, node);
-      if (isSubstitutionPrevented(node)) {
-        return node;
-      }
-      if (hint === 1 /* Expression */) {
-        return substituteExpression(node);
-      } else if (hint === 4 /* Unspecified */) {
-        return substituteUnspecified(node);
-      }
-      return node;
-    }
-    function substituteUnspecified(node) {
-      switch (node.kind) {
-        case 303 /* ShorthandPropertyAssignment */:
-          return substituteShorthandPropertyAssignment(node);
-      }
-      return node;
-    }
-    function substituteShorthandPropertyAssignment(node) {
-      var _a, _b;
-      const name = node.name;
-      if (!isGeneratedIdentifier(name) && !isLocalName(name)) {
-        const importDeclaration = resolver.getReferencedImportDeclaration(name);
-        if (importDeclaration) {
-          if (isImportClause(importDeclaration)) {
-            return setTextRange(
-              factory2.createPropertyAssignment(
-                factory2.cloneNode(name),
-                factory2.createPropertyAccessExpression(
-                  factory2.getGeneratedNameForNode(importDeclaration.parent),
-                  factory2.createIdentifier("default")
-                )
-              ),
-              /*location*/
-              node
-            );
-          } else if (isImportSpecifier(importDeclaration)) {
-            return setTextRange(
-              factory2.createPropertyAssignment(
-                factory2.cloneNode(name),
-                factory2.createPropertyAccessExpression(
-                  factory2.getGeneratedNameForNode(((_b = (_a = importDeclaration.parent) == null ? void 0 : _a.parent) == null ? void 0 : _b.parent) || importDeclaration),
-                  factory2.cloneNode(importDeclaration.propertyName || importDeclaration.name)
-                )
-              ),
-              /*location*/
-              node
-            );
-          }
-        }
-      }
-      return node;
-    }
-    function substituteExpression(node) {
-      switch (node.kind) {
-        case 80 /* Identifier */:
-          return substituteExpressionIdentifier(node);
-        case 225 /* BinaryExpression */:
-          return substituteBinaryExpression(node);
-        case 235 /* MetaProperty */:
-          return substituteMetaProperty(node);
-      }
-      return node;
-    }
-    function substituteExpressionIdentifier(node) {
-      var _a, _b;
-      if (getEmitFlags(node) & 8192 /* HelperName */) {
-        const externalHelpersModuleName = getExternalHelpersModuleName(currentSourceFile);
-        if (externalHelpersModuleName) {
-          return factory2.createPropertyAccessExpression(externalHelpersModuleName, node);
-        }
-        return node;
-      }
-      if (!isGeneratedIdentifier(node) && !isLocalName(node)) {
-        const importDeclaration = resolver.getReferencedImportDeclaration(node);
-        if (importDeclaration) {
-          if (isImportClause(importDeclaration)) {
-            return setTextRange(
-              factory2.createPropertyAccessExpression(
-                factory2.getGeneratedNameForNode(importDeclaration.parent),
-                factory2.createIdentifier("default")
-              ),
-              /*location*/
-              node
-            );
-          } else if (isImportSpecifier(importDeclaration)) {
-            return setTextRange(
-              factory2.createPropertyAccessExpression(
-                factory2.getGeneratedNameForNode(((_b = (_a = importDeclaration.parent) == null ? void 0 : _a.parent) == null ? void 0 : _b.parent) || importDeclaration),
-                factory2.cloneNode(importDeclaration.propertyName || importDeclaration.name)
-              ),
-              /*location*/
-              node
-            );
-          }
-        }
-      }
-      return node;
-    }
-    function substituteBinaryExpression(node) {
-      if (isAssignmentOperator(node.operatorToken.kind) && isIdentifier(node.left) && !isGeneratedIdentifier(node.left) && !isLocalName(node.left)) {
-        const exportedNames = getExports(node.left);
-        if (exportedNames) {
-          let expression = node;
-          for (const exportName of exportedNames) {
-            expression = createExportExpression(exportName, preventSubstitution(expression));
-          }
-          return expression;
-        }
-      }
-      return node;
-    }
-    function substituteMetaProperty(node) {
-      if (isImportMeta(node)) {
-        return factory2.createPropertyAccessExpression(contextObject, factory2.createIdentifier("meta"));
-      }
-      return node;
-    }
-    function getExports(name) {
-      let exportedNames;
-      const valueDeclaration = getReferencedDeclaration(name);
-      if (valueDeclaration) {
-        const exportContainer = resolver.getReferencedExportContainer(
-          name,
-          /*prefixLocals*/
-          false
-        );
-        if (exportContainer && exportContainer.kind === 311 /* SourceFile */) {
-          exportedNames = append(exportedNames, factory2.getDeclarationName(valueDeclaration));
-        }
-        exportedNames = addRange(exportedNames, moduleInfo == null ? void 0 : moduleInfo.exportedBindings[getOriginalNodeId(valueDeclaration)]);
-      }
-      return exportedNames;
-    }
-    function getReferencedDeclaration(name) {
-      if (!isGeneratedIdentifier(name)) {
-        const importDeclaration = resolver.getReferencedImportDeclaration(name);
-        if (importDeclaration)
-          return importDeclaration;
-        const valueDeclaration = resolver.getReferencedValueDeclaration(name);
-        if (valueDeclaration && (moduleInfo == null ? void 0 : moduleInfo.exportedBindings[getOriginalNodeId(valueDeclaration)]))
-          return valueDeclaration;
-        const declarations = resolver.getReferencedValueDeclarations(name);
-        if (declarations) {
-          for (const declaration of declarations) {
-            if (declaration !== valueDeclaration && (moduleInfo == null ? void 0 : moduleInfo.exportedBindings[getOriginalNodeId(declaration)]))
-              return declaration;
-          }
-        }
-        return valueDeclaration;
-      }
-    }
-    function preventSubstitution(node) {
-      if (noSubstitution === void 0)
-        noSubstitution = [];
-      noSubstitution[getNodeId(node)] = true;
-      return node;
-    }
-    function isSubstitutionPrevented(node) {
-      return noSubstitution && node.id && noSubstitution[node.id];
-    }
-  }
-  var init_system = __esm({
-    "src/compiler/transformers/module/system.ts"() {
-      "use strict";
-      init_ts2();
-    }
-  });
-
-  // src/compiler/transformers/module/esnextAnd2015.ts
-  function transformECMAScriptModule(context) {
-    const {
-      factory: factory2,
-      getEmitHelperFactory: emitHelpers
-    } = context;
-    const host = context.getEmitHost();
-    const resolver = context.getEmitResolver();
-    const compilerOptions = context.getCompilerOptions();
-    const languageVersion = getEmitScriptTarget(compilerOptions);
-    const previousOnEmitNode = context.onEmitNode;
-    const previousOnSubstituteNode = context.onSubstituteNode;
-    context.onEmitNode = onEmitNode;
-    context.onSubstituteNode = onSubstituteNode;
-    context.enableEmitNotification(311 /* SourceFile */);
-    context.enableSubstitution(80 /* Identifier */);
-    let helperNameSubstitutions;
-    let currentSourceFile;
-    let importRequireStatements;
-    return chainBundle(context, transformSourceFile);
-    function transformSourceFile(node) {
-      if (node.isDeclarationFile) {
-        return node;
-      }
-      if (isExternalModule(node) || getIsolatedModules(compilerOptions)) {
-        currentSourceFile = node;
-        importRequireStatements = void 0;
-        let result = updateExternalModule(node);
-        currentSourceFile = void 0;
-        if (importRequireStatements) {
-          result = factory2.updateSourceFile(
-            result,
-            setTextRange(factory2.createNodeArray(insertStatementsAfterCustomPrologue(result.statements.slice(), importRequireStatements)), result.statements)
-          );
-        }
-        if (!isExternalModule(node) || some(result.statements, isExternalModuleIndicator)) {
-          return result;
-        }
-        return factory2.updateSourceFile(
-          result,
-          setTextRange(factory2.createNodeArray([...result.statements, createEmptyExports(factory2)]), result.statements)
-        );
-      }
-      return node;
-    }
-    function updateExternalModule(node) {
-      const externalHelpersImportDeclaration = createExternalHelpersImportDeclarationIfNeeded(factory2, emitHelpers(), node, compilerOptions);
-      if (externalHelpersImportDeclaration) {
-        const statements = [];
-        const statementOffset = factory2.copyPrologue(node.statements, statements);
-        append(statements, externalHelpersImportDeclaration);
-        addRange(statements, visitNodes2(node.statements, visitor, isStatement, statementOffset));
-        return factory2.updateSourceFile(
-          node,
-          setTextRange(factory2.createNodeArray(statements), node.statements)
-        );
-      } else {
-        return visitEachChild(node, visitor, context);
-      }
-    }
-    function visitor(node) {
-      switch (node.kind) {
-        case 270 /* ImportEqualsDeclaration */:
-          return getEmitModuleKind(compilerOptions) >= 100 /* Node16 */ ? visitImportEqualsDeclaration(node) : void 0;
-        case 276 /* ExportAssignment */:
-          return visitExportAssignment(node);
-        case 277 /* ExportDeclaration */:
-          const exportDecl = node;
-          return visitExportDeclaration(exportDecl);
-      }
-      return node;
-    }
-    function createRequireCall2(importNode) {
-      const moduleName = getExternalModuleNameLiteral(factory2, importNode, Debug.checkDefined(currentSourceFile), host, resolver, compilerOptions);
-      const args = [];
-      if (moduleName) {
-        args.push(moduleName);
-      }
-      if (!importRequireStatements) {
-        const createRequireName = factory2.createUniqueName("_createRequire", 16 /* Optimistic */ | 32 /* FileLevel */);
-        const importStatement = factory2.createImportDeclaration(
-          /*modifiers*/
-          void 0,
-          factory2.createImportClause(
-            /*isTypeOnly*/
-            false,
-            /*name*/
-            void 0,
-            factory2.createNamedImports([
-              factory2.createImportSpecifier(
-                /*isTypeOnly*/
-                false,
-                factory2.createIdentifier("createRequire"),
-                createRequireName
-              )
-            ])
-          ),
-          factory2.createStringLiteral("module")
-        );
-        const requireHelperName = factory2.createUniqueName("__require", 16 /* Optimistic */ | 32 /* FileLevel */);
-        const requireStatement = factory2.createVariableStatement(
-          /*modifiers*/
-          void 0,
-          factory2.createVariableDeclarationList(
-            [
-              factory2.createVariableDeclaration(
-                requireHelperName,
-                /*exclamationToken*/
-                void 0,
-                /*type*/
-                void 0,
-                factory2.createCallExpression(
-                  factory2.cloneNode(createRequireName),
-                  /*typeArguments*/
-                  void 0,
-                  [
-                    factory2.createPropertyAccessExpression(factory2.createMetaProperty(102 /* ImportKeyword */, factory2.createIdentifier("meta")), factory2.createIdentifier("url"))
-                  ]
-                )
-              )
-            ],
-            /*flags*/
-            languageVersion >= 2 /* ES2015 */ ? 2 /* Const */ : 0 /* None */
-          )
-        );
-        importRequireStatements = [importStatement, requireStatement];
-      }
-      const name = importRequireStatements[1].declarationList.declarations[0].name;
-      Debug.assertNode(name, isIdentifier);
-      return factory2.createCallExpression(
-        factory2.cloneNode(name),
-        /*typeArguments*/
-        void 0,
-        args
-      );
-    }
-    function visitImportEqualsDeclaration(node) {
-      Debug.assert(isExternalModuleImportEqualsDeclaration(node), "import= for internal module references should be handled in an earlier transformer.");
-      let statements;
-      statements = append(
-        statements,
-        setOriginalNode(
-          setTextRange(
-            factory2.createVariableStatement(
-              /*modifiers*/
-              void 0,
-              factory2.createVariableDeclarationList(
-                [
-                  factory2.createVariableDeclaration(
-                    factory2.cloneNode(node.name),
-                    /*exclamationToken*/
-                    void 0,
-                    /*type*/
-                    void 0,
-                    createRequireCall2(node)
-                  )
-                ],
-                /*flags*/
-                languageVersion >= 2 /* ES2015 */ ? 2 /* Const */ : 0 /* None */
-              )
-            ),
-            node
-          ),
-          node
-        )
-      );
-      statements = appendExportsOfImportEqualsDeclaration(statements, node);
-      return singleOrMany(statements);
-    }
-    function appendExportsOfImportEqualsDeclaration(statements, node) {
-      if (hasSyntacticModifier(node, 1 /* Export */)) {
-        statements = append(statements, factory2.createExportDeclaration(
-          /*modifiers*/
-          void 0,
-          node.isTypeOnly,
-          factory2.createNamedExports([factory2.createExportSpecifier(
-            /*isTypeOnly*/
-            false,
-            /*propertyName*/
-            void 0,
-            idText(node.name)
-          )])
-        ));
-      }
-      return statements;
-    }
-    function visitExportAssignment(node) {
-      return node.isExportEquals ? void 0 : node;
-    }
-    function visitExportDeclaration(node) {
-      if (compilerOptions.module !== void 0 && compilerOptions.module > 5 /* ES2015 */) {
-        return node;
-      }
-      if (!node.exportClause || !isNamespaceExport(node.exportClause) || !node.moduleSpecifier) {
-        return node;
-      }
-      const oldIdentifier = node.exportClause.name;
-      const synthName = factory2.getGeneratedNameForNode(oldIdentifier);
-      const importDecl = factory2.createImportDeclaration(
-        /*modifiers*/
-        void 0,
-        factory2.createImportClause(
-          /*isTypeOnly*/
-          false,
-          /*name*/
-          void 0,
-          factory2.createNamespaceImport(
-            synthName
-          )
-        ),
-        node.moduleSpecifier,
-        node.assertClause
-      );
-      setOriginalNode(importDecl, node.exportClause);
-      const exportDecl = isExportNamespaceAsDefaultDeclaration(node) ? factory2.createExportDefault(synthName) : factory2.createExportDeclaration(
-        /*modifiers*/
-        void 0,
-        /*isTypeOnly*/
-        false,
-        factory2.createNamedExports([factory2.createExportSpecifier(
-          /*isTypeOnly*/
-          false,
-          synthName,
-          oldIdentifier
-        )])
-      );
-      setOriginalNode(exportDecl, node);
-      return [importDecl, exportDecl];
-    }
-    function onEmitNode(hint, node, emitCallback) {
-      if (isSourceFile(node)) {
-        if ((isExternalModule(node) || getIsolatedModules(compilerOptions)) && compilerOptions.importHelpers) {
-          helperNameSubstitutions = /* @__PURE__ */ new Map();
-        }
-        previousOnEmitNode(hint, node, emitCallback);
-        helperNameSubstitutions = void 0;
-      } else {
-        previousOnEmitNode(hint, node, emitCallback);
-      }
-    }
-    function onSubstituteNode(hint, node) {
-      node = previousOnSubstituteNode(hint, node);
-      if (helperNameSubstitutions && isIdentifier(node) && getEmitFlags(node) & 8192 /* HelperName */) {
-        return substituteHelperName(node);
-      }
-      return node;
-    }
-    function substituteHelperName(node) {
-      const name = idText(node);
-      let substitution = helperNameSubstitutions.get(name);
-      if (!substitution) {
-        helperNameSubstitutions.set(name, substitution = factory2.createUniqueName(name, 16 /* Optimistic */ | 32 /* FileLevel */));
-      }
-      return substitution;
-    }
-  }
-  var init_esnextAnd2015 = __esm({
-    "src/compiler/transformers/module/esnextAnd2015.ts"() {
-      "use strict";
-      init_ts2();
-    }
-  });
-
-  // src/compiler/transformers/module/node.ts
-  function transformNodeModule(context) {
-    const previousOnSubstituteNode = context.onSubstituteNode;
-    const previousOnEmitNode = context.onEmitNode;
-    const esmTransform = transformECMAScriptModule(context);
-    const esmOnSubstituteNode = context.onSubstituteNode;
-    const esmOnEmitNode = context.onEmitNode;
-    context.onSubstituteNode = previousOnSubstituteNode;
-    context.onEmitNode = previousOnEmitNode;
-    const cjsTransform = transformModule(context);
-    const cjsOnSubstituteNode = context.onSubstituteNode;
-    const cjsOnEmitNode = context.onEmitNode;
-    context.onSubstituteNode = onSubstituteNode;
-    context.onEmitNode = onEmitNode;
-    context.enableSubstitution(311 /* SourceFile */);
-    context.enableEmitNotification(311 /* SourceFile */);
-    let currentSourceFile;
-    return transformSourceFileOrBundle;
-    function onSubstituteNode(hint, node) {
-      if (isSourceFile(node)) {
-        currentSourceFile = node;
-        return previousOnSubstituteNode(hint, node);
-      } else {
-        if (!currentSourceFile) {
-          return previousOnSubstituteNode(hint, node);
-        }
-        if (currentSourceFile.impliedNodeFormat === 99 /* ESNext */) {
-          return esmOnSubstituteNode(hint, node);
-        }
-        return cjsOnSubstituteNode(hint, node);
-      }
-    }
-    function onEmitNode(hint, node, emitCallback) {
-      if (isSourceFile(node)) {
-        currentSourceFile = node;
-      }
-      if (!currentSourceFile) {
-        return previousOnEmitNode(hint, node, emitCallback);
-      }
-      if (currentSourceFile.impliedNodeFormat === 99 /* ESNext */) {
-        return esmOnEmitNode(hint, node, emitCallback);
-      }
-      return cjsOnEmitNode(hint, node, emitCallback);
-    }
-    function getModuleTransformForFile(file) {
-      return file.impliedNodeFormat === 99 /* ESNext */ ? esmTransform : cjsTransform;
-    }
-    function transformSourceFile(node) {
-      if (node.isDeclarationFile) {
-        return node;
-      }
-      currentSourceFile = node;
-      const result = getModuleTransformForFile(node)(node);
-      currentSourceFile = void 0;
-      Debug.assert(isSourceFile(result));
-      return result;
-    }
-    function transformSourceFileOrBundle(node) {
-      return node.kind === 311 /* SourceFile */ ? transformSourceFile(node) : transformBundle(node);
-    }
-    function transformBundle(node) {
-      return context.factory.createBundle(map(node.sourceFiles, transformSourceFile), node.prepends);
-    }
-  }
-  var init_node = __esm({
-    "src/compiler/transformers/module/node.ts"() {
-      "use strict";
-      init_ts2();
-    }
-  });
-
-  // src/compiler/transformers/declarations/diagnostics.ts
-  function canProduceDiagnostics(node) {
-    return isVariableDeclaration(node) || isPropertyDeclaration(node) || isPropertySignature(node) || isBindingElement(node) || isSetAccessor(node) || isGetAccessor(node) || isConstructSignatureDeclaration(node) || isCallSignatureDeclaration(node) || isMethodDeclaration(node) || isMethodSignature(node) || isFunctionDeclaration(node) || isParameter(node) || isTypeParameterDeclaration(node) || isExpressionWithTypeArguments(node) || isImportEqualsDeclaration(node) || isTypeAliasDeclaration(node) || isConstructorDeclaration(node) || isIndexSignatureDeclaration(node) || isPropertyAccessExpression(node) || isElementAccessExpression(node) || isBinaryExpression(node) || isJSDocTypeAlias(node);
-  }
-  function createGetSymbolAccessibilityDiagnosticForNodeName(node) {
-    if (isSetAccessor(node) || isGetAccessor(node)) {
-      return getAccessorNameVisibilityError;
-    } else if (isMethodSignature(node) || isMethodDeclaration(node)) {
-      return getMethodNameVisibilityError;
-    } else {
-      return createGetSymbolAccessibilityDiagnosticForNode(node);
-    }
-    function getAccessorNameVisibilityError(symbolAccessibilityResult) {
-      const diagnosticMessage = getAccessorNameVisibilityDiagnosticMessage(symbolAccessibilityResult);
-      return diagnosticMessage !== void 0 ? {
-        diagnosticMessage,
-        errorNode: node,
-        typeName: node.name
-      } : void 0;
-    }
-    function getAccessorNameVisibilityDiagnosticMessage(symbolAccessibilityResult) {
-      if (isStatic(node)) {
-        return symbolAccessibilityResult.errorModuleName ? symbolAccessibilityResult.accessibility === 2 /* CannotBeNamed */ ? Diagnostics.Public_static_property_0_of_exported_class_has_or_is_using_name_1_from_external_module_2_but_cannot_be_named : Diagnostics.Public_static_property_0_of_exported_class_has_or_is_using_name_1_from_private_module_2 : Diagnostics.Public_static_property_0_of_exported_class_has_or_is_using_private_name_1;
-      } else if (node.parent.kind === 262 /* ClassDeclaration */) {
-        return symbolAccessibilityResult.errorModuleName ? symbolAccessibilityResult.accessibility === 2 /* CannotBeNamed */ ? Diagnostics.Public_property_0_of_exported_class_has_or_is_using_name_1_from_external_module_2_but_cannot_be_named : Diagnostics.Public_property_0_of_exported_class_has_or_is_using_name_1_from_private_module_2 : Diagnostics.Public_property_0_of_exported_class_has_or_is_using_private_name_1;
-      } else {
-        return symbolAccessibilityResult.errorModuleName ? Diagnostics.Property_0_of_exported_interface_has_or_is_using_name_1_from_private_module_2 : Diagnostics.Property_0_of_exported_interface_has_or_is_using_private_name_1;
-      }
-    }
-    function getMethodNameVisibilityError(symbolAccessibilityResult) {
-      const diagnosticMessage = getMethodNameVisibilityDiagnosticMessage(symbolAccessibilityResult);
-      return diagnosticMessage !== void 0 ? {
-        diagnosticMessage,
-        errorNode: node,
-        typeName: node.name
-      } : void 0;
-    }
-    function getMethodNameVisibilityDiagnosticMessage(symbolAccessibilityResult) {
-      if (isStatic(node)) {
-        return symbolAccessibilityResult.errorModuleName ? symbolAccessibilityResult.accessibility === 2 /* CannotBeNamed */ ? Diagnostics.Public_static_method_0_of_exported_class_has_or_is_using_name_1_from_external_module_2_but_cannot_be_named : Diagnostics.Public_static_method_0_of_exported_class_has_or_is_using_name_1_from_private_module_2 : Diagnostics.Public_static_method_0_of_exported_class_has_or_is_using_private_name_1;
-      } else if (node.parent.kind === 262 /* ClassDeclaration */) {
-        return symbolAccessibilityResult.errorModuleName ? symbolAccessibilityResult.accessibility === 2 /* CannotBeNamed */ ? Diagnostics.Public_method_0_of_exported_class_has_or_is_using_name_1_from_external_module_2_but_cannot_be_named : Diagnostics.Public_method_0_of_exported_class_has_or_is_using_name_1_from_private_module_2 : Diagnostics.Public_method_0_of_exported_class_has_or_is_using_private_name_1;
-      } else {
-        return symbolAccessibilityResult.errorModuleName ? Diagnostics.Method_0_of_exported_interface_has_or_is_using_name_1_from_private_module_2 : Diagnostics.Method_0_of_exported_interface_has_or_is_using_private_name_1;
-      }
-    }
-  }
-  function createGetSymbolAccessibilityDiagnosticForNode(node) {
-    if (isVariableDeclaration(node) || isPropertyDeclaration(node) || isPropertySignature(node) || isPropertyAccessExpression(node) || isElementAccessExpression(node) || isBinaryExpression(node) || isBindingElement(node) || isConstructorDeclaration(node)) {
-      return getVariableDeclarationTypeVisibilityError;
-    } else if (isSetAccessor(node) || isGetAccessor(node)) {
-      return getAccessorDeclarationTypeVisibilityError;
-    } else if (isConstructSignatureDeclaration(node) || isCallSignatureDeclaration(node) || isMethodDeclaration(node) || isMethodSignature(node) || isFunctionDeclaration(node) || isIndexSignatureDeclaration(node)) {
-      return getReturnTypeVisibilityError;
-    } else if (isParameter(node)) {
-      if (isParameterPropertyDeclaration(node, node.parent) && hasSyntacticModifier(node.parent, 8 /* Private */)) {
-        return getVariableDeclarationTypeVisibilityError;
-      }
-      return getParameterDeclarationTypeVisibilityError;
-    } else if (isTypeParameterDeclaration(node)) {
-      return getTypeParameterConstraintVisibilityError;
-    } else if (isExpressionWithTypeArguments(node)) {
-      return getHeritageClauseVisibilityError;
-    } else if (isImportEqualsDeclaration(node)) {
-      return getImportEntityNameVisibilityError;
-    } else if (isTypeAliasDeclaration(node) || isJSDocTypeAlias(node)) {
-      return getTypeAliasDeclarationVisibilityError;
-    } else {
-      return Debug.assertNever(node, `Attempted to set a declaration diagnostic context for unhandled node kind: ${Debug.formatSyntaxKind(node.kind)}`);
-    }
-    function getVariableDeclarationTypeVisibilityDiagnosticMessage(symbolAccessibilityResult) {
-      if (node.kind === 259 /* VariableDeclaration */ || node.kind === 207 /* BindingElement */) {
-        return symbolAccessibilityResult.errorModuleName ? symbolAccessibilityResult.accessibility === 2 /* CannotBeNamed */ ? Diagnostics.Exported_variable_0_has_or_is_using_name_1_from_external_module_2_but_cannot_be_named : Diagnostics.Exported_variable_0_has_or_is_using_name_1_from_private_module_2 : Diagnostics.Exported_variable_0_has_or_is_using_private_name_1;
-      } else if (node.kind === 171 /* PropertyDeclaration */ || node.kind === 210 /* PropertyAccessExpression */ || node.kind === 211 /* ElementAccessExpression */ || node.kind === 225 /* BinaryExpression */ || node.kind === 170 /* PropertySignature */ || node.kind === 168 /* Parameter */ && hasSyntacticModifier(node.parent, 8 /* Private */)) {
-        if (isStatic(node)) {
-          return symbolAccessibilityResult.errorModuleName ? symbolAccessibilityResult.accessibility === 2 /* CannotBeNamed */ ? Diagnostics.Public_static_property_0_of_exported_class_has_or_is_using_name_1_from_external_module_2_but_cannot_be_named : Diagnostics.Public_static_property_0_of_exported_class_has_or_is_using_name_1_from_private_module_2 : Diagnostics.Public_static_property_0_of_exported_class_has_or_is_using_private_name_1;
-        } else if (node.parent.kind === 262 /* ClassDeclaration */ || node.kind === 168 /* Parameter */) {
-          return symbolAccessibilityResult.errorModuleName ? symbolAccessibilityResult.accessibility === 2 /* CannotBeNamed */ ? Diagnostics.Public_property_0_of_exported_class_has_or_is_using_name_1_from_external_module_2_but_cannot_be_named : Diagnostics.Public_property_0_of_exported_class_has_or_is_using_name_1_from_private_module_2 : Diagnostics.Public_property_0_of_exported_class_has_or_is_using_private_name_1;
-        } else {
-          return symbolAccessibilityResult.errorModuleName ? Diagnostics.Property_0_of_exported_interface_has_or_is_using_name_1_from_private_module_2 : Diagnostics.Property_0_of_exported_interface_has_or_is_using_private_name_1;
-        }
-      }
-    }
-    function getVariableDeclarationTypeVisibilityError(symbolAccessibilityResult) {
-      const diagnosticMessage = getVariableDeclarationTypeVisibilityDiagnosticMessage(symbolAccessibilityResult);
-      return diagnosticMessage !== void 0 ? {
-        diagnosticMessage,
-        errorNode: node,
-        typeName: node.name
-      } : void 0;
-    }
-    function getAccessorDeclarationTypeVisibilityError(symbolAccessibilityResult) {
-      let diagnosticMessage;
-      if (node.kind === 177 /* SetAccessor */) {
-        if (isStatic(node)) {
-          diagnosticMessage = symbolAccessibilityResult.errorModuleName ? Diagnostics.Parameter_type_of_public_static_setter_0_from_exported_class_has_or_is_using_name_1_from_private_module_2 : Diagnostics.Parameter_type_of_public_static_setter_0_from_exported_class_has_or_is_using_private_name_1;
-        } else {
-          diagnosticMessage = symbolAccessibilityResult.errorModuleName ? Diagnostics.Parameter_type_of_public_setter_0_from_exported_class_has_or_is_using_name_1_from_private_module_2 : Diagnostics.Parameter_type_of_public_setter_0_from_exported_class_has_or_is_using_private_name_1;
-        }
-      } else {
-        if (isStatic(node)) {
-          diagnosticMessage = symbolAccessibilityResult.errorModuleName ? symbolAccessibilityResult.accessibility === 2 /* CannotBeNamed */ ? Diagnostics.Return_type_of_public_static_getter_0_from_exported_class_has_or_is_using_name_1_from_external_module_2_but_cannot_be_named : Diagnostics.Return_type_of_public_static_getter_0_from_exported_class_has_or_is_using_name_1_from_private_module_2 : Diagnostics.Return_type_of_public_static_getter_0_from_exported_class_has_or_is_using_private_name_1;
-        } else {
-          diagnosticMessage = symbolAccessibilityResult.errorModuleName ? symbolAccessibilityResult.accessibility === 2 /* CannotBeNamed */ ? Diagnostics.Return_type_of_public_getter_0_from_exported_class_has_or_is_using_name_1_from_external_module_2_but_cannot_be_named : Diagnostics.Return_type_of_public_getter_0_from_exported_class_has_or_is_using_name_1_from_private_module_2 : Diagnostics.Return_type_of_public_getter_0_from_exported_class_has_or_is_using_private_name_1;
-        }
-      }
-      return {
-        diagnosticMessage,
-        errorNode: node.name,
-        typeName: node.name
-      };
-    }
-    function getReturnTypeVisibilityError(symbolAccessibilityResult) {
-      let diagnosticMessage;
-      switch (node.kind) {
-        case 179 /* ConstructSignature */:
-          diagnosticMessage = symbolAccessibilityResult.errorModuleName ? Diagnostics.Return_type_of_constructor_signature_from_exported_interface_has_or_is_using_name_0_from_private_module_1 : Diagnostics.Return_type_of_constructor_signature_from_exported_interface_has_or_is_using_private_name_0;
-          break;
-        case 178 /* CallSignature */:
-          diagnosticMessage = symbolAccessibilityResult.errorModuleName ? Diagnostics.Return_type_of_call_signature_from_exported_interface_has_or_is_using_name_0_from_private_module_1 : Diagnostics.Return_type_of_call_signature_from_exported_interface_has_or_is_using_private_name_0;
-          break;
-        case 180 /* IndexSignature */:
-          diagnosticMessage = symbolAccessibilityResult.errorModuleName ? Diagnostics.Return_type_of_index_signature_from_exported_interface_has_or_is_using_name_0_from_private_module_1 : Diagnostics.Return_type_of_index_signature_from_exported_interface_has_or_is_using_private_name_0;
-          break;
-        case 173 /* MethodDeclaration */:
-        case 172 /* MethodSignature */:
-          if (isStatic(node)) {
-            diagnosticMessage = symbolAccessibilityResult.errorModuleName ? symbolAccessibilityResult.accessibility === 2 /* CannotBeNamed */ ? Diagnostics.Return_type_of_public_static_method_from_exported_class_has_or_is_using_name_0_from_external_module_1_but_cannot_be_named : Diagnostics.Return_type_of_public_static_method_from_exported_class_has_or_is_using_name_0_from_private_module_1 : Diagnostics.Return_type_of_public_static_method_from_exported_class_has_or_is_using_private_name_0;
-          } else if (node.parent.kind === 262 /* ClassDeclaration */) {
-            diagnosticMessage = symbolAccessibilityResult.errorModuleName ? symbolAccessibilityResult.accessibility === 2 /* CannotBeNamed */ ? Diagnostics.Return_type_of_public_method_from_exported_class_has_or_is_using_name_0_from_external_module_1_but_cannot_be_named : Diagnostics.Return_type_of_public_method_from_exported_class_has_or_is_using_name_0_from_private_module_1 : Diagnostics.Return_type_of_public_method_from_exported_class_has_or_is_using_private_name_0;
-          } else {
-            diagnosticMessage = symbolAccessibilityResult.errorModuleName ? Diagnostics.Return_type_of_method_from_exported_interface_has_or_is_using_name_0_from_private_module_1 : Diagnostics.Return_type_of_method_from_exported_interface_has_or_is_using_private_name_0;
-          }
-          break;
-        case 261 /* FunctionDeclaration */:
-          diagnosticMessage = symbolAccessibilityResult.errorModuleName ? symbolAccessibilityResult.accessibility === 2 /* CannotBeNamed */ ? Diagnostics.Return_type_of_exported_function_has_or_is_using_name_0_from_external_module_1_but_cannot_be_named : Diagnostics.Return_type_of_exported_function_has_or_is_using_name_0_from_private_module_1 : Diagnostics.Return_type_of_exported_function_has_or_is_using_private_name_0;
-          break;
-        default:
-          return Debug.fail("This is unknown kind for signature: " + node.kind);
-      }
-      return {
-        diagnosticMessage,
-        errorNode: node.name || node
-      };
-    }
-    function getParameterDeclarationTypeVisibilityError(symbolAccessibilityResult) {
-      const diagnosticMessage = getParameterDeclarationTypeVisibilityDiagnosticMessage(symbolAccessibilityResult);
-      return diagnosticMessage !== void 0 ? {
-        diagnosticMessage,
-        errorNode: node,
-        typeName: node.name
-      } : void 0;
-    }
-    function getParameterDeclarationTypeVisibilityDiagnosticMessage(symbolAccessibilityResult) {
-      switch (node.parent.kind) {
-        case 175 /* Constructor */:
-          return symbolAccessibilityResult.errorModuleName ? symbolAccessibilityResult.accessibility === 2 /* CannotBeNamed */ ? Diagnostics.Parameter_0_of_constructor_from_exported_class_has_or_is_using_name_1_from_external_module_2_but_cannot_be_named : Diagnostics.Parameter_0_of_constructor_from_exported_class_has_or_is_using_name_1_from_private_module_2 : Diagnostics.Parameter_0_of_constructor_from_exported_class_has_or_is_using_private_name_1;
-        case 179 /* ConstructSignature */:
-        case 184 /* ConstructorType */:
-          return symbolAccessibilityResult.errorModuleName ? Diagnostics.Parameter_0_of_constructor_signature_from_exported_interface_has_or_is_using_name_1_from_private_module_2 : Diagnostics.Parameter_0_of_constructor_signature_from_exported_interface_has_or_is_using_private_name_1;
-        case 178 /* CallSignature */:
-          return symbolAccessibilityResult.errorModuleName ? Diagnostics.Parameter_0_of_call_signature_from_exported_interface_has_or_is_using_name_1_from_private_module_2 : Diagnostics.Parameter_0_of_call_signature_from_exported_interface_has_or_is_using_private_name_1;
-        case 180 /* IndexSignature */:
-          return symbolAccessibilityResult.errorModuleName ? Diagnostics.Parameter_0_of_index_signature_from_exported_interface_has_or_is_using_name_1_from_private_module_2 : Diagnostics.Parameter_0_of_index_signature_from_exported_interface_has_or_is_using_private_name_1;
-        case 173 /* MethodDeclaration */:
-        case 172 /* MethodSignature */:
-          if (isStatic(node.parent)) {
-            return symbolAccessibilityResult.errorModuleName ? symbolAccessibilityResult.accessibility === 2 /* CannotBeNamed */ ? Diagnostics.Parameter_0_of_public_static_method_from_exported_class_has_or_is_using_name_1_from_external_module_2_but_cannot_be_named : Diagnostics.Parameter_0_of_public_static_method_from_exported_class_has_or_is_using_name_1_from_private_module_2 : Diagnostics.Parameter_0_of_public_static_method_from_exported_class_has_or_is_using_private_name_1;
-          } else if (node.parent.parent.kind === 262 /* ClassDeclaration */) {
-            return symbolAccessibilityResult.errorModuleName ? symbolAccessibilityResult.accessibility === 2 /* CannotBeNamed */ ? Diagnostics.Parameter_0_of_public_method_from_exported_class_has_or_is_using_name_1_from_external_module_2_but_cannot_be_named : Diagnostics.Parameter_0_of_public_method_from_exported_class_has_or_is_using_name_1_from_private_module_2 : Diagnostics.Parameter_0_of_public_method_from_exported_class_has_or_is_using_private_name_1;
-          } else {
-            return symbolAccessibilityResult.errorModuleName ? Diagnostics.Parameter_0_of_method_from_exported_interface_has_or_is_using_name_1_from_private_module_2 : Diagnostics.Parameter_0_of_method_from_exported_interface_has_or_is_using_private_name_1;
-          }
-        case 261 /* FunctionDeclaration */:
-        case 183 /* FunctionType */:
-          return symbolAccessibilityResult.errorModuleName ? symbolAccessibilityResult.accessibility === 2 /* CannotBeNamed */ ? Diagnostics.Parameter_0_of_exported_function_has_or_is_using_name_1_from_external_module_2_but_cannot_be_named : Diagnostics.Parameter_0_of_exported_function_has_or_is_using_name_1_from_private_module_2 : Diagnostics.Parameter_0_of_exported_function_has_or_is_using_private_name_1;
-        case 177 /* SetAccessor */:
-        case 176 /* GetAccessor */:
-          return symbolAccessibilityResult.errorModuleName ? symbolAccessibilityResult.accessibility === 2 /* CannotBeNamed */ ? Diagnostics.Parameter_0_of_accessor_has_or_is_using_name_1_from_external_module_2_but_cannot_be_named : Diagnostics.Parameter_0_of_accessor_has_or_is_using_name_1_from_private_module_2 : Diagnostics.Parameter_0_of_accessor_has_or_is_using_private_name_1;
-        default:
-          return Debug.fail(`Unknown parent for parameter: ${Debug.formatSyntaxKind(node.parent.kind)}`);
-      }
-    }
-    function getTypeParameterConstraintVisibilityError() {
-      let diagnosticMessage;
-      switch (node.parent.kind) {
-        case 262 /* ClassDeclaration */:
-          diagnosticMessage = Diagnostics.Type_parameter_0_of_exported_class_has_or_is_using_private_name_1;
-          break;
-        case 263 /* InterfaceDeclaration */:
-          diagnosticMessage = Diagnostics.Type_parameter_0_of_exported_interface_has_or_is_using_private_name_1;
-          break;
-        case 199 /* MappedType */:
-          diagnosticMessage = Diagnostics.Type_parameter_0_of_exported_mapped_object_type_is_using_private_name_1;
-          break;
-        case 184 /* ConstructorType */:
-        case 179 /* ConstructSignature */:
-          diagnosticMessage = Diagnostics.Type_parameter_0_of_constructor_signature_from_exported_interface_has_or_is_using_private_name_1;
-          break;
-        case 178 /* CallSignature */:
-          diagnosticMessage = Diagnostics.Type_parameter_0_of_call_signature_from_exported_interface_has_or_is_using_private_name_1;
-          break;
-        case 173 /* MethodDeclaration */:
-        case 172 /* MethodSignature */:
-          if (isStatic(node.parent)) {
-            diagnosticMessage = Diagnostics.Type_parameter_0_of_public_static_method_from_exported_class_has_or_is_using_private_name_1;
-          } else if (node.parent.parent.kind === 262 /* ClassDeclaration */) {
-            diagnosticMessage = Diagnostics.Type_parameter_0_of_public_method_from_exported_class_has_or_is_using_private_name_1;
-          } else {
-            diagnosticMessage = Diagnostics.Type_parameter_0_of_method_from_exported_interface_has_or_is_using_private_name_1;
-          }
-          break;
-        case 183 /* FunctionType */:
-        case 261 /* FunctionDeclaration */:
-          diagnosticMessage = Diagnostics.Type_parameter_0_of_exported_function_has_or_is_using_private_name_1;
-          break;
-        case 194 /* InferType */:
-          diagnosticMessage = Diagnostics.Extends_clause_for_inferred_type_0_has_or_is_using_private_name_1;
-          break;
-        case 264 /* TypeAliasDeclaration */:
-          diagnosticMessage = Diagnostics.Type_parameter_0_of_exported_type_alias_has_or_is_using_private_name_1;
-          break;
-        default:
-          return Debug.fail("This is unknown parent for type parameter: " + node.parent.kind);
-      }
-      return {
-        diagnosticMessage,
-        errorNode: node,
-        typeName: node.name
-      };
-    }
-    function getHeritageClauseVisibilityError() {
-      let diagnosticMessage;
-      if (isClassDeclaration(node.parent.parent)) {
-        diagnosticMessage = isHeritageClause(node.parent) && node.parent.token === 119 /* ImplementsKeyword */ ? Diagnostics.Implements_clause_of_exported_class_0_has_or_is_using_private_name_1 : node.parent.parent.name ? Diagnostics.extends_clause_of_exported_class_0_has_or_is_using_private_name_1 : Diagnostics.extends_clause_of_exported_class_has_or_is_using_private_name_0;
-      } else {
-        diagnosticMessage = Diagnostics.extends_clause_of_exported_interface_0_has_or_is_using_private_name_1;
-      }
-      return {
-        diagnosticMessage,
-        errorNode: node,
-        typeName: getNameOfDeclaration(node.parent.parent)
-      };
-    }
-    function getImportEntityNameVisibilityError() {
-      return {
-        diagnosticMessage: Diagnostics.Import_declaration_0_is_using_private_name_1,
-        errorNode: node,
-        typeName: node.name
-      };
-    }
-    function getTypeAliasDeclarationVisibilityError(symbolAccessibilityResult) {
-      return {
-        diagnosticMessage: symbolAccessibilityResult.errorModuleName ? Diagnostics.Exported_type_alias_0_has_or_is_using_private_name_1_from_module_2 : Diagnostics.Exported_type_alias_0_has_or_is_using_private_name_1,
-        errorNode: isJSDocTypeAlias(node) ? Debug.checkDefined(node.typeExpression) : node.type,
-        typeName: isJSDocTypeAlias(node) ? getNameOfDeclaration(node) : node.name
-      };
-    }
-  }
-  var init_diagnostics = __esm({
-    "src/compiler/transformers/declarations/diagnostics.ts"() {
-      "use strict";
-      init_ts2();
-    }
-  });
-
-  // src/compiler/transformers/declarations.ts
-  function getDeclarationDiagnostics(host, resolver, file) {
-    const compilerOptions = host.getCompilerOptions();
-    const result = transformNodes(
-      resolver,
-      host,
-      factory,
-      compilerOptions,
-      file ? [file] : filter(host.getSourceFiles(), isSourceFileNotJson),
-      [transformDeclarations],
-      /*allowDtsFiles*/
-      false
-    );
-    return result.diagnostics;
-  }
-  function hasInternalAnnotation(range, currentSourceFile) {
-    const comment = currentSourceFile.text.substring(range.pos, range.end);
-    return stringContains(comment, "@internal");
-  }
-  function isInternalDeclaration(node, currentSourceFile) {
-    const parseTreeNode = getParseTreeNode(node);
-    if (parseTreeNode && parseTreeNode.kind === 168 /* Parameter */) {
-      const paramIdx = parseTreeNode.parent.parameters.indexOf(parseTreeNode);
-      const previousSibling = paramIdx > 0 ? parseTreeNode.parent.parameters[paramIdx - 1] : void 0;
-      const text = currentSourceFile.text;
-      const commentRanges = previousSibling ? concatenate(
-        // to handle
-        // ... parameters, /** @internal */
-        // public param: string
-        getTrailingCommentRanges(text, skipTrivia(
-          text,
-          previousSibling.end + 1,
-          /*stopAfterLineBreak*/
-          false,
-          /*stopAtComments*/
-          true
-        )),
-        getLeadingCommentRanges(text, node.pos)
-      ) : getTrailingCommentRanges(text, skipTrivia(
-        text,
-        node.pos,
-        /*stopAfterLineBreak*/
-        false,
-        /*stopAtComments*/
-        true
-      ));
-      return commentRanges && commentRanges.length && hasInternalAnnotation(last(commentRanges), currentSourceFile);
-    }
-    const leadingCommentRanges = parseTreeNode && getLeadingCommentRangesOfNode(parseTreeNode, currentSourceFile);
-    return !!forEach(leadingCommentRanges, (range) => {
-      return hasInternalAnnotation(range, currentSourceFile);
-    });
-  }
-  function transformDeclarations(context) {
-    const throwDiagnostic = () => Debug.fail("Diagnostic emitted without context");
-    let getSymbolAccessibilityDiagnostic = throwDiagnostic;
-    let needsDeclare = true;
-    let isBundledEmit = false;
-    let resultHasExternalModuleIndicator = false;
-    let needsScopeFixMarker = false;
-    let resultHasScopeMarker = false;
-    let enclosingDeclaration;
-    let necessaryTypeReferences;
-    let lateMarkedStatements;
-    let lateStatementReplacementMap;
-    let suppressNewDiagnosticContexts;
-    let exportedModulesFromDeclarationEmit;
-    const { factory: factory2 } = context;
-    const host = context.getEmitHost();
-    const symbolTracker = {
-      trackSymbol,
-      reportInaccessibleThisError,
-      reportInaccessibleUniqueSymbolError,
-      reportCyclicStructureError,
-      reportPrivateInBaseOfClassExpression,
-      reportLikelyUnsafeImportRequiredError,
-      reportTruncationError,
-      moduleResolverHost: host,
-      trackReferencedAmbientModule,
-      trackExternalModuleSymbolOfImportTypeNode,
-      reportNonlocalAugmentation,
-      reportNonSerializableProperty,
-      reportImportTypeNodeResolutionModeOverride
-    };
-    let errorNameNode;
-    let errorFallbackNode;
-    let currentSourceFile;
-    let refs;
-    let libs2;
-    let emittedImports;
-    const resolver = context.getEmitResolver();
-    const options = context.getCompilerOptions();
-    const { noResolve, stripInternal } = options;
-    return transformRoot;
-    function recordTypeReferenceDirectivesIfNecessary(typeReferenceDirectives) {
-      if (!typeReferenceDirectives) {
-        return;
-      }
-      necessaryTypeReferences = necessaryTypeReferences || /* @__PURE__ */ new Set();
-      for (const ref of typeReferenceDirectives) {
-        necessaryTypeReferences.add(ref);
-      }
-    }
-    function trackReferencedAmbientModule(node, symbol) {
-      const directives = resolver.getTypeReferenceDirectivesForSymbol(symbol, 67108863 /* All */);
-      if (length(directives)) {
-        return recordTypeReferenceDirectivesIfNecessary(directives);
-      }
-      const container = getSourceFileOfNode(node);
-      refs.set(getOriginalNodeId(container), container);
-    }
-    function handleSymbolAccessibilityError(symbolAccessibilityResult) {
-      if (symbolAccessibilityResult.accessibility === 0 /* Accessible */) {
-        if (symbolAccessibilityResult && symbolAccessibilityResult.aliasesToMakeVisible) {
-          if (!lateMarkedStatements) {
-            lateMarkedStatements = symbolAccessibilityResult.aliasesToMakeVisible;
-          } else {
-            for (const ref of symbolAccessibilityResult.aliasesToMakeVisible) {
-              pushIfUnique(lateMarkedStatements, ref);
-            }
-          }
-        }
-      } else {
-        const errorInfo = getSymbolAccessibilityDiagnostic(symbolAccessibilityResult);
-        if (errorInfo) {
-          if (errorInfo.typeName) {
-            context.addDiagnostic(createDiagnosticForNode(
-              symbolAccessibilityResult.errorNode || errorInfo.errorNode,
-              errorInfo.diagnosticMessage,
-              getTextOfNode(errorInfo.typeName),
-              symbolAccessibilityResult.errorSymbolName,
-              symbolAccessibilityResult.errorModuleName
-            ));
-          } else {
-            context.addDiagnostic(createDiagnosticForNode(
-              symbolAccessibilityResult.errorNode || errorInfo.errorNode,
-              errorInfo.diagnosticMessage,
-              symbolAccessibilityResult.errorSymbolName,
-              symbolAccessibilityResult.errorModuleName
-            ));
-          }
-          return true;
-        }
-      }
-      return false;
-    }
-    function trackExternalModuleSymbolOfImportTypeNode(symbol) {
-      if (!isBundledEmit) {
-        (exportedModulesFromDeclarationEmit || (exportedModulesFromDeclarationEmit = [])).push(symbol);
-      }
-    }
-    function trackSymbol(symbol, enclosingDeclaration2, meaning) {
-      if (symbol.flags & 262144 /* TypeParameter */)
-        return false;
-      const issuedDiagnostic = handleSymbolAccessibilityError(resolver.isSymbolAccessible(
-        symbol,
-        enclosingDeclaration2,
-        meaning,
-        /*shouldComputeAliasToMarkVisible*/
-        true
-      ));
-      recordTypeReferenceDirectivesIfNecessary(resolver.getTypeReferenceDirectivesForSymbol(symbol, meaning));
-      return issuedDiagnostic;
-    }
-    function reportPrivateInBaseOfClassExpression(propertyName) {
-      if (errorNameNode || errorFallbackNode) {
-        context.addDiagnostic(
-          createDiagnosticForNode(errorNameNode || errorFallbackNode, Diagnostics.Property_0_of_exported_class_expression_may_not_be_private_or_protected, propertyName)
-        );
-      }
-    }
-    function errorDeclarationNameWithFallback() {
-      return errorNameNode ? declarationNameToString(errorNameNode) : errorFallbackNode && getNameOfDeclaration(errorFallbackNode) ? declarationNameToString(getNameOfDeclaration(errorFallbackNode)) : errorFallbackNode && isExportAssignment(errorFallbackNode) ? errorFallbackNode.isExportEquals ? "export=" : "default" : "(Missing)";
-    }
-    function reportInaccessibleUniqueSymbolError() {
-      if (errorNameNode || errorFallbackNode) {
-        context.addDiagnostic(createDiagnosticForNode(
-          errorNameNode || errorFallbackNode,
-          Diagnostics.The_inferred_type_of_0_references_an_inaccessible_1_type_A_type_annotation_is_necessary,
-          errorDeclarationNameWithFallback(),
-          "unique symbol"
-        ));
-      }
-    }
-    function reportCyclicStructureError() {
-      if (errorNameNode || errorFallbackNode) {
-        context.addDiagnostic(createDiagnosticForNode(
-          errorNameNode || errorFallbackNode,
-          Diagnostics.The_inferred_type_of_0_references_a_type_with_a_cyclic_structure_which_cannot_be_trivially_serialized_A_type_annotation_is_necessary,
-          errorDeclarationNameWithFallback()
-        ));
-      }
-    }
-    function reportInaccessibleThisError() {
-      if (errorNameNode || errorFallbackNode) {
-        context.addDiagnostic(createDiagnosticForNode(
-          errorNameNode || errorFallbackNode,
-          Diagnostics.The_inferred_type_of_0_references_an_inaccessible_1_type_A_type_annotation_is_necessary,
-          errorDeclarationNameWithFallback(),
-          "this"
-        ));
-      }
-    }
-    function reportLikelyUnsafeImportRequiredError(specifier) {
-      if (errorNameNode || errorFallbackNode) {
-        context.addDiagnostic(createDiagnosticForNode(
-          errorNameNode || errorFallbackNode,
-          Diagnostics.The_inferred_type_of_0_cannot_be_named_without_a_reference_to_1_This_is_likely_not_portable_A_type_annotation_is_necessary,
-          errorDeclarationNameWithFallback(),
-          specifier
-        ));
-      }
-    }
-    function reportTruncationError() {
-      if (errorNameNode || errorFallbackNode) {
-        context.addDiagnostic(createDiagnosticForNode(errorNameNode || errorFallbackNode, Diagnostics.The_inferred_type_of_this_node_exceeds_the_maximum_length_the_compiler_will_serialize_An_explicit_type_annotation_is_needed));
-      }
-    }
-    function reportNonlocalAugmentation(containingFile, parentSymbol, symbol) {
-      var _a;
-      const primaryDeclaration = (_a = parentSymbol.declarations) == null ? void 0 : _a.find((d) => getSourceFileOfNode(d) === containingFile);
-      const augmentingDeclarations = filter(symbol.declarations, (d) => getSourceFileOfNode(d) !== containingFile);
-      if (primaryDeclaration && augmentingDeclarations) {
-        for (const augmentations of augmentingDeclarations) {
-          context.addDiagnostic(addRelatedInfo(
-            createDiagnosticForNode(augmentations, Diagnostics.Declaration_augments_declaration_in_another_file_This_cannot_be_serialized),
-            createDiagnosticForNode(primaryDeclaration, Diagnostics.This_is_the_declaration_being_augmented_Consider_moving_the_augmenting_declaration_into_the_same_file)
-          ));
-        }
-      }
-    }
-    function reportNonSerializableProperty(propertyName) {
-      if (errorNameNode || errorFallbackNode) {
-        context.addDiagnostic(createDiagnosticForNode(errorNameNode || errorFallbackNode, Diagnostics.The_type_of_this_node_cannot_be_serialized_because_its_property_0_cannot_be_serialized, propertyName));
-      }
-    }
-    function reportImportTypeNodeResolutionModeOverride() {
-      if (!isNightly() && (errorNameNode || errorFallbackNode)) {
-        context.addDiagnostic(createDiagnosticForNode(errorNameNode || errorFallbackNode, Diagnostics.The_type_of_this_expression_cannot_be_named_without_a_resolution_mode_assertion_which_is_an_unstable_feature_Use_nightly_TypeScript_to_silence_this_error_Try_updating_with_npm_install_D_typescript_next));
-      }
-    }
-    function transformDeclarationsForJS(sourceFile, bundled) {
-      const oldDiag = getSymbolAccessibilityDiagnostic;
-      getSymbolAccessibilityDiagnostic = (s) => s.errorNode && canProduceDiagnostics(s.errorNode) ? createGetSymbolAccessibilityDiagnosticForNode(s.errorNode)(s) : {
-        diagnosticMessage: s.errorModuleName ? Diagnostics.Declaration_emit_for_this_file_requires_using_private_name_0_from_module_1_An_explicit_type_annotation_may_unblock_declaration_emit : Diagnostics.Declaration_emit_for_this_file_requires_using_private_name_0_An_explicit_type_annotation_may_unblock_declaration_emit,
-        errorNode: s.errorNode || sourceFile
-      };
-      const result = resolver.getDeclarationStatementsForSourceFile(sourceFile, declarationEmitNodeBuilderFlags, symbolTracker, bundled);
-      getSymbolAccessibilityDiagnostic = oldDiag;
-      return result;
-    }
-    function transformRoot(node) {
-      if (node.kind === 311 /* SourceFile */ && node.isDeclarationFile) {
-        return node;
-      }
-      if (node.kind === 312 /* Bundle */) {
-        isBundledEmit = true;
-        refs = /* @__PURE__ */ new Map();
-        libs2 = /* @__PURE__ */ new Map();
-        let hasNoDefaultLib = false;
-        const bundle = factory2.createBundle(map(
-          node.sourceFiles,
-          (sourceFile) => {
-            if (sourceFile.isDeclarationFile)
-              return void 0;
-            hasNoDefaultLib = hasNoDefaultLib || sourceFile.hasNoDefaultLib;
-            currentSourceFile = sourceFile;
-            enclosingDeclaration = sourceFile;
-            lateMarkedStatements = void 0;
-            suppressNewDiagnosticContexts = false;
-            lateStatementReplacementMap = /* @__PURE__ */ new Map();
-            getSymbolAccessibilityDiagnostic = throwDiagnostic;
-            needsScopeFixMarker = false;
-            resultHasScopeMarker = false;
-            collectReferences(sourceFile, refs);
-            collectLibs(sourceFile, libs2);
-            if (isExternalOrCommonJsModule(sourceFile) || isJsonSourceFile(sourceFile)) {
-              resultHasExternalModuleIndicator = false;
-              needsDeclare = false;
-              const statements = isSourceFileJS(sourceFile) ? factory2.createNodeArray(transformDeclarationsForJS(
-                sourceFile,
-                /*bundled*/
-                true
-              )) : visitNodes2(sourceFile.statements, visitDeclarationStatements, isStatement);
-              const newFile = factory2.updateSourceFile(
-                sourceFile,
-                [factory2.createModuleDeclaration(
-                  [factory2.createModifier(138 /* DeclareKeyword */)],
-                  factory2.createStringLiteral(getResolvedExternalModuleName(context.getEmitHost(), sourceFile)),
-                  factory2.createModuleBlock(setTextRange(factory2.createNodeArray(transformAndReplaceLatePaintedStatements(statements)), sourceFile.statements))
-                )],
-                /*isDeclarationFile*/
-                true,
-                /*referencedFiles*/
-                [],
-                /*typeReferences*/
-                [],
-                /*hasNoDefaultLib*/
-                false,
-                /*libReferences*/
-                []
-              );
-              return newFile;
-            }
-            needsDeclare = true;
-            const updated2 = isSourceFileJS(sourceFile) ? factory2.createNodeArray(transformDeclarationsForJS(sourceFile)) : visitNodes2(sourceFile.statements, visitDeclarationStatements, isStatement);
-            return factory2.updateSourceFile(
-              sourceFile,
-              transformAndReplaceLatePaintedStatements(updated2),
-              /*isDeclarationFile*/
-              true,
-              /*referencedFiles*/
-              [],
-              /*typeReferences*/
-              [],
-              /*hasNoDefaultLib*/
-              false,
-              /*libReferences*/
-              []
-            );
-          }
-        ), mapDefined(node.prepends, (prepend) => {
-          if (prepend.kind === 314 /* InputFiles */) {
-            const sourceFile = createUnparsedSourceFile(prepend, "dts", stripInternal);
-            hasNoDefaultLib = hasNoDefaultLib || !!sourceFile.hasNoDefaultLib;
-            collectReferences(sourceFile, refs);
-            recordTypeReferenceDirectivesIfNecessary(map(sourceFile.typeReferenceDirectives, (ref) => [ref.fileName, ref.resolutionMode]));
-            collectLibs(sourceFile, libs2);
-            return sourceFile;
-          }
-          return prepend;
-        }));
-        bundle.syntheticFileReferences = [];
-        bundle.syntheticTypeReferences = getFileReferencesForUsedTypeReferences();
-        bundle.syntheticLibReferences = getLibReferences();
-        bundle.hasNoDefaultLib = hasNoDefaultLib;
-        const outputFilePath2 = getDirectoryPath(normalizeSlashes(getOutputPathsFor(
-          node,
-          host,
-          /*forceDtsPaths*/
-          true
-        ).declarationFilePath));
-        const referenceVisitor2 = mapReferencesIntoArray(bundle.syntheticFileReferences, outputFilePath2);
-        refs.forEach(referenceVisitor2);
-        return bundle;
-      }
-      needsDeclare = true;
-      needsScopeFixMarker = false;
-      resultHasScopeMarker = false;
-      enclosingDeclaration = node;
-      currentSourceFile = node;
-      getSymbolAccessibilityDiagnostic = throwDiagnostic;
-      isBundledEmit = false;
-      resultHasExternalModuleIndicator = false;
-      suppressNewDiagnosticContexts = false;
-      lateMarkedStatements = void 0;
-      lateStatementReplacementMap = /* @__PURE__ */ new Map();
-      necessaryTypeReferences = void 0;
-      refs = collectReferences(currentSourceFile, /* @__PURE__ */ new Map());
-      libs2 = collectLibs(currentSourceFile, /* @__PURE__ */ new Map());
-      const references = [];
-      const outputFilePath = getDirectoryPath(normalizeSlashes(getOutputPathsFor(
-        node,
-        host,
-        /*forceDtsPaths*/
-        true
-      ).declarationFilePath));
-      const referenceVisitor = mapReferencesIntoArray(references, outputFilePath);
-      let combinedStatements;
-      if (isSourceFileJS(currentSourceFile)) {
-        combinedStatements = factory2.createNodeArray(transformDeclarationsForJS(node));
-        refs.forEach(referenceVisitor);
-        emittedImports = filter(combinedStatements, isAnyImportSyntax);
-      } else {
-        const statements = visitNodes2(node.statements, visitDeclarationStatements, isStatement);
-        combinedStatements = setTextRange(factory2.createNodeArray(transformAndReplaceLatePaintedStatements(statements)), node.statements);
-        refs.forEach(referenceVisitor);
-        emittedImports = filter(combinedStatements, isAnyImportSyntax);
-        if (isExternalModule(node) && (!resultHasExternalModuleIndicator || needsScopeFixMarker && !resultHasScopeMarker)) {
-          combinedStatements = setTextRange(factory2.createNodeArray([...combinedStatements, createEmptyExports(factory2)]), combinedStatements);
-        }
-      }
-      const updated = factory2.updateSourceFile(
-        node,
-        combinedStatements,
-        /*isDeclarationFile*/
-        true,
-        references,
-        getFileReferencesForUsedTypeReferences(),
-        node.hasNoDefaultLib,
-        getLibReferences()
-      );
-      updated.exportedModulesFromDeclarationEmit = exportedModulesFromDeclarationEmit;
-      return updated;
-      function getLibReferences() {
-        return arrayFrom(libs2.keys(), (lib) => ({ fileName: lib, pos: -1, end: -1 }));
-      }
-      function getFileReferencesForUsedTypeReferences() {
-        return necessaryTypeReferences ? mapDefined(arrayFrom(necessaryTypeReferences.keys()), getFileReferenceForSpecifierModeTuple) : [];
-      }
-      function getFileReferenceForSpecifierModeTuple([typeName, mode]) {
-        if (emittedImports) {
-          for (const importStatement of emittedImports) {
-            if (isImportEqualsDeclaration(importStatement) && isExternalModuleReference(importStatement.moduleReference)) {
-              const expr = importStatement.moduleReference.expression;
-              if (isStringLiteralLike(expr) && expr.text === typeName) {
-                return void 0;
-              }
-            } else if (isImportDeclaration(importStatement) && isStringLiteral(importStatement.moduleSpecifier) && importStatement.moduleSpecifier.text === typeName) {
-              return void 0;
-            }
-          }
-        }
-        return { fileName: typeName, pos: -1, end: -1, ...mode ? { resolutionMode: mode } : void 0 };
-      }
-      function mapReferencesIntoArray(references2, outputFilePath2) {
-        return (file) => {
-          let declFileName;
-          if (file.isDeclarationFile) {
-            declFileName = file.fileName;
-          } else {
-            if (isBundledEmit && contains(node.sourceFiles, file))
-              return;
-            const paths = getOutputPathsFor(
-              file,
-              host,
-              /*forceDtsPaths*/
-              true
-            );
-            declFileName = paths.declarationFilePath || paths.jsFilePath || file.fileName;
-          }
-          if (declFileName) {
-            const specifier = getModuleSpecifier(
-              options,
-              currentSourceFile,
-              toPath(outputFilePath2, host.getCurrentDirectory(), host.getCanonicalFileName),
-              toPath(declFileName, host.getCurrentDirectory(), host.getCanonicalFileName),
-              host
-            );
-            if (!pathIsRelative(specifier)) {
-              recordTypeReferenceDirectivesIfNecessary([[
-                specifier,
-                /*mode*/
-                void 0
-              ]]);
-              return;
-            }
-            let fileName = getRelativePathToDirectoryOrUrl(
-              outputFilePath2,
-              declFileName,
-              host.getCurrentDirectory(),
-              host.getCanonicalFileName,
-              /*isAbsolutePathAnUrl*/
-              false
-            );
-            if (startsWith(fileName, "./") && hasExtension(fileName)) {
-              fileName = fileName.substring(2);
-            }
-            if (startsWith(fileName, "node_modules/") || pathContainsNodeModules(fileName)) {
-              return;
-            }
-            references2.push({ pos: -1, end: -1, fileName });
-          }
-        };
-      }
-    }
-    function collectReferences(sourceFile, ret) {
-      if (noResolve || !isUnparsedSource(sourceFile) && isSourceFileJS(sourceFile))
-        return ret;
-      forEach(sourceFile.referencedFiles, (f) => {
-        const elem = host.getSourceFileFromReference(sourceFile, f);
-        if (elem) {
-          ret.set(getOriginalNodeId(elem), elem);
-        }
-      });
-      return ret;
-    }
-    function collectLibs(sourceFile, ret) {
-      forEach(sourceFile.libReferenceDirectives, (ref) => {
-        const lib = host.getLibFileFromReference(ref);
-        if (lib) {
-          ret.set(toFileNameLowerCase(ref.fileName), true);
-        }
-      });
-      return ret;
-    }
-    function filterBindingPatternInitializersAndRenamings(name) {
-      if (name.kind === 80 /* Identifier */) {
-        return name;
-      } else {
-        if (name.kind === 206 /* ArrayBindingPattern */) {
-          return factory2.updateArrayBindingPattern(name, visitNodes2(name.elements, visitBindingElement, isArrayBindingElement));
-        } else {
-          return factory2.updateObjectBindingPattern(name, visitNodes2(name.elements, visitBindingElement, isBindingElement));
-        }
-      }
-      function visitBindingElement(elem) {
-        if (elem.kind === 231 /* OmittedExpression */) {
-          return elem;
-        }
-        if (elem.propertyName && isIdentifier(elem.propertyName) && isIdentifier(elem.name) && !elem.symbol.isReferenced && !isIdentifierANonContextualKeyword(elem.propertyName)) {
-          return factory2.updateBindingElement(
-            elem,
-            elem.dotDotDotToken,
-            /*propertyName*/
-            void 0,
-            elem.propertyName,
-            shouldPrintWithInitializer(elem) ? elem.initializer : void 0
-          );
-        }
-        return factory2.updateBindingElement(
-          elem,
-          elem.dotDotDotToken,
-          elem.propertyName,
-          filterBindingPatternInitializersAndRenamings(elem.name),
-          shouldPrintWithInitializer(elem) ? elem.initializer : void 0
-        );
-      }
-    }
-    function ensureParameter(p, modifierMask, type) {
-      let oldDiag;
-      if (!suppressNewDiagnosticContexts) {
-        oldDiag = getSymbolAccessibilityDiagnostic;
-        getSymbolAccessibilityDiagnostic = createGetSymbolAccessibilityDiagnosticForNode(p);
-      }
-      const newParam = factory2.updateParameterDeclaration(
-        p,
-        maskModifiers(factory2, p, modifierMask),
-        p.dotDotDotToken,
-        filterBindingPatternInitializersAndRenamings(p.name),
-        resolver.isOptionalParameter(p) ? p.questionToken || factory2.createToken(58 /* QuestionToken */) : void 0,
-        ensureType(
-          p,
-          type || p.type,
-          /*ignorePrivate*/
-          true
-        ),
-        // Ignore private param props, since this type is going straight back into a param
-        ensureNoInitializer(p)
-      );
-      if (!suppressNewDiagnosticContexts) {
-        getSymbolAccessibilityDiagnostic = oldDiag;
-      }
-      return newParam;
-    }
-    function shouldPrintWithInitializer(node) {
-      return canHaveLiteralInitializer(node) && resolver.isLiteralConstDeclaration(getParseTreeNode(node));
-    }
-    function ensureNoInitializer(node) {
-      if (shouldPrintWithInitializer(node)) {
-        return resolver.createLiteralConstValue(getParseTreeNode(node), symbolTracker);
-      }
-      return void 0;
-    }
-    function ensureType(node, type, ignorePrivate) {
-      if (!ignorePrivate && hasEffectiveModifier(node, 8 /* Private */)) {
-        return;
-      }
-      if (shouldPrintWithInitializer(node)) {
-        return;
-      }
-      const shouldUseResolverType = node.kind === 168 /* Parameter */ && (resolver.isRequiredInitializedParameter(node) || resolver.isOptionalUninitializedParameterProperty(node));
-      if (type && !shouldUseResolverType) {
-        return visitNode(type, visitDeclarationSubtree, isTypeNode);
-      }
-      if (!getParseTreeNode(node)) {
-        return type ? visitNode(type, visitDeclarationSubtree, isTypeNode) : factory2.createKeywordTypeNode(133 /* AnyKeyword */);
-      }
-      if (node.kind === 177 /* SetAccessor */) {
-        return factory2.createKeywordTypeNode(133 /* AnyKeyword */);
-      }
-      errorNameNode = node.name;
-      let oldDiag;
-      if (!suppressNewDiagnosticContexts) {
-        oldDiag = getSymbolAccessibilityDiagnostic;
-        getSymbolAccessibilityDiagnostic = createGetSymbolAccessibilityDiagnosticForNode(node);
-      }
-      if (node.kind === 259 /* VariableDeclaration */ || node.kind === 207 /* BindingElement */) {
-        return cleanup(resolver.createTypeOfDeclaration(node, enclosingDeclaration, declarationEmitNodeBuilderFlags, symbolTracker));
-      }
-      if (node.kind === 168 /* Parameter */ || node.kind === 171 /* PropertyDeclaration */ || node.kind === 170 /* PropertySignature */) {
-        if (isPropertySignature(node) || !node.initializer)
-          return cleanup(resolver.createTypeOfDeclaration(node, enclosingDeclaration, declarationEmitNodeBuilderFlags, symbolTracker, shouldUseResolverType));
-        return cleanup(resolver.createTypeOfDeclaration(node, enclosingDeclaration, declarationEmitNodeBuilderFlags, symbolTracker, shouldUseResolverType) || resolver.createTypeOfExpression(node.initializer, enclosingDeclaration, declarationEmitNodeBuilderFlags, symbolTracker));
-      }
-      return cleanup(resolver.createReturnTypeOfSignatureDeclaration(node, enclosingDeclaration, declarationEmitNodeBuilderFlags, symbolTracker));
-      function cleanup(returnValue) {
-        errorNameNode = void 0;
-        if (!suppressNewDiagnosticContexts) {
-          getSymbolAccessibilityDiagnostic = oldDiag;
-        }
-        return returnValue || factory2.createKeywordTypeNode(133 /* AnyKeyword */);
-      }
-    }
-    function isDeclarationAndNotVisible(node) {
-      node = getParseTreeNode(node);
-      switch (node.kind) {
-        case 261 /* FunctionDeclaration */:
-        case 266 /* ModuleDeclaration */:
-        case 263 /* InterfaceDeclaration */:
-        case 262 /* ClassDeclaration */:
-        case 264 /* TypeAliasDeclaration */:
-        case 265 /* EnumDeclaration */:
-          return !resolver.isDeclarationVisible(node);
-        case 259 /* VariableDeclaration */:
-          return !getBindingNameVisible(node);
-        case 270 /* ImportEqualsDeclaration */:
-        case 271 /* ImportDeclaration */:
-        case 277 /* ExportDeclaration */:
-        case 276 /* ExportAssignment */:
-          return false;
-        case 174 /* ClassStaticBlockDeclaration */:
-          return true;
-      }
-      return false;
-    }
-    function shouldEmitFunctionProperties(input) {
-      var _a;
-      if (input.body) {
-        return true;
-      }
-      const overloadSignatures = (_a = input.symbol.declarations) == null ? void 0 : _a.filter((decl) => isFunctionDeclaration(decl) && !decl.body);
-      return !overloadSignatures || overloadSignatures.indexOf(input) === overloadSignatures.length - 1;
-    }
-    function getBindingNameVisible(elem) {
-      if (isOmittedExpression(elem)) {
-        return false;
-      }
-      if (isBindingPattern(elem.name)) {
-        return some(elem.name.elements, getBindingNameVisible);
-      } else {
-        return resolver.isDeclarationVisible(elem);
-      }
-    }
-    function updateParamsList(node, params, modifierMask) {
-      if (hasEffectiveModifier(node, 8 /* Private */)) {
-        return factory2.createNodeArray();
-      }
-      const newParams = map(params, (p) => ensureParameter(p, modifierMask));
-      if (!newParams) {
-        return factory2.createNodeArray();
-      }
-      return factory2.createNodeArray(newParams, params.hasTrailingComma);
-    }
-    function updateAccessorParamsList(input, isPrivate) {
-      let newParams;
-      if (!isPrivate) {
-        const thisParameter = getThisParameter(input);
-        if (thisParameter) {
-          newParams = [ensureParameter(thisParameter)];
-        }
-      }
-      if (isSetAccessorDeclaration(input)) {
-        let newValueParameter;
-        if (!isPrivate) {
-          const valueParameter = getSetAccessorValueParameter(input);
-          if (valueParameter) {
-            const accessorType = getTypeAnnotationFromAllAccessorDeclarations(input, resolver.getAllAccessorDeclarations(input));
-            newValueParameter = ensureParameter(
-              valueParameter,
-              /*modifierMask*/
-              void 0,
-              accessorType
-            );
-          }
-        }
-        if (!newValueParameter) {
-          newValueParameter = factory2.createParameterDeclaration(
-            /*modifiers*/
-            void 0,
-            /*dotDotDotToken*/
-            void 0,
-            "value"
-          );
-        }
-        newParams = append(newParams, newValueParameter);
-      }
-      return factory2.createNodeArray(newParams || emptyArray);
-    }
-    function ensureTypeParams(node, params) {
-      return hasEffectiveModifier(node, 8 /* Private */) ? void 0 : visitNodes2(params, visitDeclarationSubtree, isTypeParameterDeclaration);
-    }
-    function isEnclosingDeclaration(node) {
-      return isSourceFile(node) || isTypeAliasDeclaration(node) || isModuleDeclaration(node) || isClassDeclaration(node) || isInterfaceDeclaration(node) || isFunctionLike(node) || isIndexSignatureDeclaration(node) || isMappedTypeNode(node);
-    }
-    function checkEntityNameVisibility(entityName, enclosingDeclaration2) {
-      const visibilityResult = resolver.isEntityNameVisible(entityName, enclosingDeclaration2);
-      handleSymbolAccessibilityError(visibilityResult);
-      recordTypeReferenceDirectivesIfNecessary(resolver.getTypeReferenceDirectivesForEntityName(entityName));
-    }
-    function preserveJsDoc(updated, original) {
-      if (hasJSDocNodes(updated) && hasJSDocNodes(original)) {
-        updated.jsDoc = original.jsDoc;
-      }
-      return setCommentRange(updated, getCommentRange(original));
-    }
-    function rewriteModuleSpecifier(parent2, input) {
-      if (!input)
-        return void 0;
-      resultHasExternalModuleIndicator = resultHasExternalModuleIndicator || parent2.kind !== 266 /* ModuleDeclaration */ && parent2.kind !== 204 /* ImportType */;
-      if (isStringLiteralLike(input)) {
-        if (isBundledEmit) {
-          const newName = getExternalModuleNameFromDeclaration(context.getEmitHost(), resolver, parent2);
-          if (newName) {
-            return factory2.createStringLiteral(newName);
-          }
-        } else {
-          const symbol = resolver.getSymbolOfExternalModuleSpecifier(input);
-          if (symbol) {
-            (exportedModulesFromDeclarationEmit || (exportedModulesFromDeclarationEmit = [])).push(symbol);
-          }
-        }
-      }
-      return input;
-    }
-    function transformImportEqualsDeclaration(decl) {
-      if (!resolver.isDeclarationVisible(decl))
-        return;
-      if (decl.moduleReference.kind === 282 /* ExternalModuleReference */) {
-        const specifier = getExternalModuleImportEqualsDeclarationExpression(decl);
-        return factory2.updateImportEqualsDeclaration(
-          decl,
-          decl.modifiers,
-          decl.isTypeOnly,
-          decl.name,
-          factory2.updateExternalModuleReference(decl.moduleReference, rewriteModuleSpecifier(decl, specifier))
-        );
-      } else {
-        const oldDiag = getSymbolAccessibilityDiagnostic;
-        getSymbolAccessibilityDiagnostic = createGetSymbolAccessibilityDiagnosticForNode(decl);
-        checkEntityNameVisibility(decl.moduleReference, enclosingDeclaration);
-        getSymbolAccessibilityDiagnostic = oldDiag;
-        return decl;
-      }
-    }
-    function transformImportDeclaration(decl) {
-      if (!decl.importClause) {
-        return factory2.updateImportDeclaration(
-          decl,
-          decl.modifiers,
-          decl.importClause,
-          rewriteModuleSpecifier(decl, decl.moduleSpecifier),
-          getResolutionModeOverrideForClauseInNightly(decl.assertClause)
-        );
-      }
-      const visibleDefaultBinding = decl.importClause && decl.importClause.name && resolver.isDeclarationVisible(decl.importClause) ? decl.importClause.name : void 0;
-      if (!decl.importClause.namedBindings) {
-        return visibleDefaultBinding && factory2.updateImportDeclaration(decl, decl.modifiers, factory2.updateImportClause(
-          decl.importClause,
-          decl.importClause.isTypeOnly,
-          visibleDefaultBinding,
-          /*namedBindings*/
-          void 0
-        ), rewriteModuleSpecifier(decl, decl.moduleSpecifier), getResolutionModeOverrideForClauseInNightly(decl.assertClause));
-      }
-      if (decl.importClause.namedBindings.kind === 273 /* NamespaceImport */) {
-        const namedBindings = resolver.isDeclarationVisible(decl.importClause.namedBindings) ? decl.importClause.namedBindings : (
-          /*namedBindings*/
-          void 0
-        );
-        return visibleDefaultBinding || namedBindings ? factory2.updateImportDeclaration(decl, decl.modifiers, factory2.updateImportClause(
-          decl.importClause,
-          decl.importClause.isTypeOnly,
-          visibleDefaultBinding,
-          namedBindings
-        ), rewriteModuleSpecifier(decl, decl.moduleSpecifier), getResolutionModeOverrideForClauseInNightly(decl.assertClause)) : void 0;
-      }
-      const bindingList = mapDefined(decl.importClause.namedBindings.elements, (b) => resolver.isDeclarationVisible(b) ? b : void 0);
-      if (bindingList && bindingList.length || visibleDefaultBinding) {
-        return factory2.updateImportDeclaration(
-          decl,
-          decl.modifiers,
-          factory2.updateImportClause(
-            decl.importClause,
-            decl.importClause.isTypeOnly,
-            visibleDefaultBinding,
-            bindingList && bindingList.length ? factory2.updateNamedImports(decl.importClause.namedBindings, bindingList) : void 0
-          ),
-          rewriteModuleSpecifier(decl, decl.moduleSpecifier),
-          getResolutionModeOverrideForClauseInNightly(decl.assertClause)
-        );
-      }
-      if (resolver.isImportRequiredByAugmentation(decl)) {
-        return factory2.updateImportDeclaration(
-          decl,
-          decl.modifiers,
-          /*importClause*/
-          void 0,
-          rewriteModuleSpecifier(decl, decl.moduleSpecifier),
-          getResolutionModeOverrideForClauseInNightly(decl.assertClause)
-        );
-      }
-    }
-    function getResolutionModeOverrideForClauseInNightly(assertClause) {
-      const mode = getResolutionModeOverrideForClause(assertClause);
-      if (mode !== void 0) {
-        if (!isNightly()) {
-          context.addDiagnostic(createDiagnosticForNode(assertClause, Diagnostics.resolution_mode_assertions_are_unstable_Use_nightly_TypeScript_to_silence_this_error_Try_updating_with_npm_install_D_typescript_next));
-        }
-        return assertClause;
-      }
-      return void 0;
-    }
-    function transformAndReplaceLatePaintedStatements(statements) {
-      while (length(lateMarkedStatements)) {
-        const i = lateMarkedStatements.shift();
-        if (!isLateVisibilityPaintedStatement(i)) {
-          return Debug.fail(`Late replaced statement was found which is not handled by the declaration transformer!: ${Debug.formatSyntaxKind(i.kind)}`);
-        }
-        const priorNeedsDeclare = needsDeclare;
-        needsDeclare = i.parent && isSourceFile(i.parent) && !(isExternalModule(i.parent) && isBundledEmit);
-        const result = transformTopLevelDeclaration(i);
-        needsDeclare = priorNeedsDeclare;
-        lateStatementReplacementMap.set(getOriginalNodeId(i), result);
-      }
-      return visitNodes2(statements, visitLateVisibilityMarkedStatements, isStatement);
-      function visitLateVisibilityMarkedStatements(statement) {
-        if (isLateVisibilityPaintedStatement(statement)) {
-          const key = getOriginalNodeId(statement);
-          if (lateStatementReplacementMap.has(key)) {
-            const result = lateStatementReplacementMap.get(key);
-            lateStatementReplacementMap.delete(key);
-            if (result) {
-              if (isArray(result) ? some(result, needsScopeMarker) : needsScopeMarker(result)) {
-                needsScopeFixMarker = true;
-              }
-              if (isSourceFile(statement.parent) && (isArray(result) ? some(result, isExternalModuleIndicator) : isExternalModuleIndicator(result))) {
-                resultHasExternalModuleIndicator = true;
-              }
-            }
-            return result;
-          }
-        }
-        return statement;
-      }
-    }
-    function visitDeclarationSubtree(input) {
-      if (shouldStripInternal(input))
-        return;
-      if (isDeclaration(input)) {
-        if (isDeclarationAndNotVisible(input))
-          return;
-        if (hasDynamicName(input) && !resolver.isLateBound(getParseTreeNode(input))) {
-          return;
-        }
-      }
-      if (isFunctionLike(input) && resolver.isImplementationOfOverload(input))
-        return;
-      if (isSemicolonClassElement(input))
-        return;
-      let previousEnclosingDeclaration;
-      if (isEnclosingDeclaration(input)) {
-        previousEnclosingDeclaration = enclosingDeclaration;
-        enclosingDeclaration = input;
-      }
-      const oldDiag = getSymbolAccessibilityDiagnostic;
-      const canProduceDiagnostic = canProduceDiagnostics(input);
-      const oldWithinObjectLiteralType = suppressNewDiagnosticContexts;
-      let shouldEnterSuppressNewDiagnosticsContextContext = (input.kind === 186 /* TypeLiteral */ || input.kind === 199 /* MappedType */) && input.parent.kind !== 264 /* TypeAliasDeclaration */;
-      if (isMethodDeclaration(input) || isMethodSignature(input)) {
-        if (hasEffectiveModifier(input, 8 /* Private */)) {
-          if (input.symbol && input.symbol.declarations && input.symbol.declarations[0] !== input)
-            return;
-          return cleanup(factory2.createPropertyDeclaration(
-            ensureModifiers(input),
-            input.name,
-            /*questionOrExclamationToken*/
-            void 0,
-            /*type*/
-            void 0,
-            /*initializer*/
-            void 0
-          ));
-        }
-      }
-      if (canProduceDiagnostic && !suppressNewDiagnosticContexts) {
-        getSymbolAccessibilityDiagnostic = createGetSymbolAccessibilityDiagnosticForNode(input);
-      }
-      if (isTypeQueryNode(input)) {
-        checkEntityNameVisibility(input.exprName, enclosingDeclaration);
-      }
-      if (shouldEnterSuppressNewDiagnosticsContextContext) {
-        suppressNewDiagnosticContexts = true;
-      }
-      if (isProcessedComponent(input)) {
-        switch (input.kind) {
-          case 232 /* ExpressionWithTypeArguments */: {
-            if (isEntityName(input.expression) || isEntityNameExpression(input.expression)) {
-              checkEntityNameVisibility(input.expression, enclosingDeclaration);
-            }
-            const node = visitEachChild(input, visitDeclarationSubtree, context);
-            return cleanup(factory2.updateExpressionWithTypeArguments(node, node.expression, node.typeArguments));
-          }
-          case 182 /* TypeReference */: {
-            checkEntityNameVisibility(input.typeName, enclosingDeclaration);
-            const node = visitEachChild(input, visitDeclarationSubtree, context);
-            return cleanup(factory2.updateTypeReferenceNode(node, node.typeName, node.typeArguments));
-          }
-          case 179 /* ConstructSignature */:
-            return cleanup(factory2.updateConstructSignature(
-              input,
-              ensureTypeParams(input, input.typeParameters),
-              updateParamsList(input, input.parameters),
-              ensureType(input, input.type)
-            ));
-          case 175 /* Constructor */: {
-            const ctor = factory2.createConstructorDeclaration(
-              /*modifiers*/
-              ensureModifiers(input),
-              updateParamsList(input, input.parameters, 0 /* None */),
-              /*body*/
-              void 0
-            );
-            return cleanup(ctor);
-          }
-          case 173 /* MethodDeclaration */: {
-            if (isPrivateIdentifier(input.name)) {
-              return cleanup(
-                /*returnValue*/
-                void 0
-              );
-            }
-            const sig = factory2.createMethodDeclaration(
-              ensureModifiers(input),
-              /*asteriskToken*/
-              void 0,
-              input.name,
-              input.questionToken,
-              ensureTypeParams(input, input.typeParameters),
-              updateParamsList(input, input.parameters),
-              ensureType(input, input.type),
-              /*body*/
-              void 0
-            );
-            return cleanup(sig);
-          }
-          case 176 /* GetAccessor */: {
-            if (isPrivateIdentifier(input.name)) {
-              return cleanup(
-                /*returnValue*/
-                void 0
-              );
-            }
-            const accessorType = getTypeAnnotationFromAllAccessorDeclarations(input, resolver.getAllAccessorDeclarations(input));
-            return cleanup(factory2.updateGetAccessorDeclaration(
-              input,
-              ensureModifiers(input),
-              input.name,
-              updateAccessorParamsList(input, hasEffectiveModifier(input, 8 /* Private */)),
-              ensureType(input, accessorType),
-              /*body*/
-              void 0
-            ));
-          }
-          case 177 /* SetAccessor */: {
-            if (isPrivateIdentifier(input.name)) {
-              return cleanup(
-                /*returnValue*/
-                void 0
-              );
-            }
-            return cleanup(factory2.updateSetAccessorDeclaration(
-              input,
-              ensureModifiers(input),
-              input.name,
-              updateAccessorParamsList(input, hasEffectiveModifier(input, 8 /* Private */)),
-              /*body*/
-              void 0
-            ));
-          }
-          case 171 /* PropertyDeclaration */:
-            if (isPrivateIdentifier(input.name)) {
-              return cleanup(
-                /*returnValue*/
-                void 0
-              );
-            }
-            return cleanup(factory2.updatePropertyDeclaration(
-              input,
-              ensureModifiers(input),
-              input.name,
-              input.questionToken,
-              ensureType(input, input.type),
-              ensureNoInitializer(input)
-            ));
-          case 170 /* PropertySignature */:
-            if (isPrivateIdentifier(input.name)) {
-              return cleanup(
-                /*returnValue*/
-                void 0
-              );
-            }
-            return cleanup(factory2.updatePropertySignature(
-              input,
-              ensureModifiers(input),
-              input.name,
-              input.questionToken,
-              ensureType(input, input.type)
-            ));
-          case 172 /* MethodSignature */: {
-            if (isPrivateIdentifier(input.name)) {
-              return cleanup(
-                /*returnValue*/
-                void 0
-              );
-            }
-            return cleanup(factory2.updateMethodSignature(
-              input,
-              ensureModifiers(input),
-              input.name,
-              input.questionToken,
-              ensureTypeParams(input, input.typeParameters),
-              updateParamsList(input, input.parameters),
-              ensureType(input, input.type)
-            ));
-          }
-          case 178 /* CallSignature */: {
-            return cleanup(factory2.updateCallSignature(
-              input,
-              ensureTypeParams(input, input.typeParameters),
-              updateParamsList(input, input.parameters),
-              ensureType(input, input.type)
-            ));
-          }
-          case 180 /* IndexSignature */: {
-            return cleanup(factory2.updateIndexSignature(
-              input,
-              ensureModifiers(input),
-              updateParamsList(input, input.parameters),
-              visitNode(input.type, visitDeclarationSubtree, isTypeNode) || factory2.createKeywordTypeNode(133 /* AnyKeyword */)
-            ));
-          }
-          case 259 /* VariableDeclaration */: {
-            if (isBindingPattern(input.name)) {
-              return recreateBindingPattern(input.name);
-            }
-            shouldEnterSuppressNewDiagnosticsContextContext = true;
-            suppressNewDiagnosticContexts = true;
-            return cleanup(factory2.updateVariableDeclaration(
-              input,
-              input.name,
-              /*exclamationToken*/
-              void 0,
-              ensureType(input, input.type),
-              ensureNoInitializer(input)
-            ));
-          }
-          case 167 /* TypeParameter */: {
-            if (isPrivateMethodTypeParameter(input) && (input.default || input.constraint)) {
-              return cleanup(factory2.updateTypeParameterDeclaration(
-                input,
-                input.modifiers,
-                input.name,
-                /*constraint*/
-                void 0,
-                /*defaultType*/
-                void 0
-              ));
-            }
-            return cleanup(visitEachChild(input, visitDeclarationSubtree, context));
-          }
-          case 193 /* ConditionalType */: {
-            const checkType = visitNode(input.checkType, visitDeclarationSubtree, isTypeNode);
-            const extendsType = visitNode(input.extendsType, visitDeclarationSubtree, isTypeNode);
-            const oldEnclosingDecl = enclosingDeclaration;
-            enclosingDeclaration = input.trueType;
-            const trueType = visitNode(input.trueType, visitDeclarationSubtree, isTypeNode);
-            enclosingDeclaration = oldEnclosingDecl;
-            const falseType = visitNode(input.falseType, visitDeclarationSubtree, isTypeNode);
-            Debug.assert(checkType);
-            Debug.assert(extendsType);
-            Debug.assert(trueType);
-            Debug.assert(falseType);
-            return cleanup(factory2.updateConditionalTypeNode(input, checkType, extendsType, trueType, falseType));
-          }
-          case 183 /* FunctionType */: {
-            return cleanup(factory2.updateFunctionTypeNode(input, visitNodes2(input.typeParameters, visitDeclarationSubtree, isTypeParameterDeclaration), updateParamsList(input, input.parameters), Debug.checkDefined(visitNode(input.type, visitDeclarationSubtree, isTypeNode))));
-          }
-          case 184 /* ConstructorType */: {
-            return cleanup(factory2.updateConstructorTypeNode(input, ensureModifiers(input), visitNodes2(input.typeParameters, visitDeclarationSubtree, isTypeParameterDeclaration), updateParamsList(input, input.parameters), Debug.checkDefined(visitNode(input.type, visitDeclarationSubtree, isTypeNode))));
-          }
-          case 204 /* ImportType */: {
-            if (!isLiteralImportTypeNode(input))
-              return cleanup(input);
-            return cleanup(factory2.updateImportTypeNode(
-              input,
-              factory2.updateLiteralTypeNode(input.argument, rewriteModuleSpecifier(input, input.argument.literal)),
-              input.assertions,
-              input.qualifier,
-              visitNodes2(input.typeArguments, visitDeclarationSubtree, isTypeNode),
-              input.isTypeOf
-            ));
-          }
-          default:
-            Debug.assertNever(input, `Attempted to process unhandled node kind: ${Debug.formatSyntaxKind(input.kind)}`);
-        }
-      }
-      if (isTupleTypeNode(input) && getLineAndCharacterOfPosition(currentSourceFile, input.pos).line === getLineAndCharacterOfPosition(currentSourceFile, input.end).line) {
-        setEmitFlags(input, 1 /* SingleLine */);
-      }
-      return cleanup(visitEachChild(input, visitDeclarationSubtree, context));
-      function cleanup(returnValue) {
-        if (returnValue && canProduceDiagnostic && hasDynamicName(input)) {
-          checkName(input);
-        }
-        if (isEnclosingDeclaration(input)) {
-          enclosingDeclaration = previousEnclosingDeclaration;
-        }
-        if (canProduceDiagnostic && !suppressNewDiagnosticContexts) {
-          getSymbolAccessibilityDiagnostic = oldDiag;
-        }
-        if (shouldEnterSuppressNewDiagnosticsContextContext) {
-          suppressNewDiagnosticContexts = oldWithinObjectLiteralType;
-        }
-        if (returnValue === input) {
-          return returnValue;
-        }
-        return returnValue && setOriginalNode(preserveJsDoc(returnValue, input), input);
-      }
-    }
-    function isPrivateMethodTypeParameter(node) {
-      return node.parent.kind === 173 /* MethodDeclaration */ && hasEffectiveModifier(node.parent, 8 /* Private */);
-    }
-    function visitDeclarationStatements(input) {
-      if (!isPreservedDeclarationStatement(input)) {
-        return;
-      }
-      if (shouldStripInternal(input))
-        return;
-      switch (input.kind) {
-        case 277 /* ExportDeclaration */: {
-          if (isSourceFile(input.parent)) {
-            resultHasExternalModuleIndicator = true;
-          }
-          resultHasScopeMarker = true;
-          return factory2.updateExportDeclaration(
-            input,
-            input.modifiers,
-            input.isTypeOnly,
-            input.exportClause,
-            rewriteModuleSpecifier(input, input.moduleSpecifier),
-            getResolutionModeOverrideForClause(input.assertClause) ? input.assertClause : void 0
-          );
-        }
-        case 276 /* ExportAssignment */: {
-          if (isSourceFile(input.parent)) {
-            resultHasExternalModuleIndicator = true;
-          }
-          resultHasScopeMarker = true;
-          if (input.expression.kind === 80 /* Identifier */) {
-            return input;
-          } else {
-            const newId = factory2.createUniqueName("_default", 16 /* Optimistic */);
-            getSymbolAccessibilityDiagnostic = () => ({
-              diagnosticMessage: Diagnostics.Default_export_of_the_module_has_or_is_using_private_name_0,
-              errorNode: input
-            });
-            errorFallbackNode = input;
-            const varDecl = factory2.createVariableDeclaration(
-              newId,
-              /*exclamationToken*/
-              void 0,
-              resolver.createTypeOfExpression(input.expression, input, declarationEmitNodeBuilderFlags, symbolTracker),
-              /*initializer*/
-              void 0
-            );
-            errorFallbackNode = void 0;
-            const statement = factory2.createVariableStatement(needsDeclare ? [factory2.createModifier(138 /* DeclareKeyword */)] : [], factory2.createVariableDeclarationList([varDecl], 2 /* Const */));
-            preserveJsDoc(statement, input);
-            removeAllComments(input);
-            return [statement, factory2.updateExportAssignment(input, input.modifiers, newId)];
-          }
-        }
-      }
-      const result = transformTopLevelDeclaration(input);
-      lateStatementReplacementMap.set(getOriginalNodeId(input), result);
-      return input;
-    }
-    function stripExportModifiers(statement) {
-      if (isImportEqualsDeclaration(statement) || hasEffectiveModifier(statement, 1024 /* Default */) || !canHaveModifiers(statement)) {
-        return statement;
-      }
-      const modifiers = factory2.createModifiersFromModifierFlags(getEffectiveModifierFlags(statement) & (258047 /* All */ ^ 1 /* Export */));
-      return factory2.updateModifiers(statement, modifiers);
-    }
-    function transformTopLevelDeclaration(input) {
-      if (lateMarkedStatements) {
-        while (orderedRemoveItem(lateMarkedStatements, input))
-          ;
-      }
-      if (shouldStripInternal(input))
-        return;
-      switch (input.kind) {
-        case 270 /* ImportEqualsDeclaration */: {
-          return transformImportEqualsDeclaration(input);
-        }
-        case 271 /* ImportDeclaration */: {
-          return transformImportDeclaration(input);
-        }
-      }
-      if (isDeclaration(input) && isDeclarationAndNotVisible(input))
-        return;
-      if (isFunctionLike(input) && resolver.isImplementationOfOverload(input))
-        return;
-      let previousEnclosingDeclaration;
-      if (isEnclosingDeclaration(input)) {
-        previousEnclosingDeclaration = enclosingDeclaration;
-        enclosingDeclaration = input;
-      }
-      const canProdiceDiagnostic = canProduceDiagnostics(input);
-      const oldDiag = getSymbolAccessibilityDiagnostic;
-      if (canProdiceDiagnostic) {
-        getSymbolAccessibilityDiagnostic = createGetSymbolAccessibilityDiagnosticForNode(input);
-      }
-      const previousNeedsDeclare = needsDeclare;
-      switch (input.kind) {
-        case 264 /* TypeAliasDeclaration */: {
-          needsDeclare = false;
-          const clean2 = cleanup(factory2.updateTypeAliasDeclaration(
-            input,
-            ensureModifiers(input),
-            input.name,
-            visitNodes2(input.typeParameters, visitDeclarationSubtree, isTypeParameterDeclaration),
-            Debug.checkDefined(visitNode(input.type, visitDeclarationSubtree, isTypeNode))
-          ));
-          needsDeclare = previousNeedsDeclare;
-          return clean2;
-        }
-        case 263 /* InterfaceDeclaration */: {
-          return cleanup(factory2.updateInterfaceDeclaration(
-            input,
-            ensureModifiers(input),
-            input.name,
-            ensureTypeParams(input, input.typeParameters),
-            transformHeritageClauses(input.heritageClauses),
-            visitNodes2(input.members, visitDeclarationSubtree, isTypeElement)
-          ));
-        }
-        case 261 /* FunctionDeclaration */: {
-          const clean2 = cleanup(factory2.updateFunctionDeclaration(
-            input,
-            ensureModifiers(input),
-            /*asteriskToken*/
-            void 0,
-            input.name,
-            ensureTypeParams(input, input.typeParameters),
-            updateParamsList(input, input.parameters),
-            ensureType(input, input.type),
-            /*body*/
-            void 0
-          ));
-          if (clean2 && resolver.isExpandoFunctionDeclaration(input) && shouldEmitFunctionProperties(input)) {
-            const props = resolver.getPropertiesOfContainerFunction(input);
-            const fakespace = parseNodeFactory.createModuleDeclaration(
-              /*modifiers*/
-              void 0,
-              clean2.name || factory2.createIdentifier("_default"),
-              factory2.createModuleBlock([]),
-              16 /* Namespace */
-            );
-            setParent(fakespace, enclosingDeclaration);
-            fakespace.locals = createSymbolTable(props);
-            fakespace.symbol = props[0].parent;
-            const exportMappings = [];
-            let declarations = mapDefined(props, (p) => {
-              if (!p.valueDeclaration || !(isPropertyAccessExpression(p.valueDeclaration) || isElementAccessExpression(p.valueDeclaration) || isBinaryExpression(p.valueDeclaration))) {
-                return void 0;
-              }
-              const nameStr = unescapeLeadingUnderscores(p.escapedName);
-              if (!isIdentifierText(nameStr, 99 /* ESNext */)) {
-                return void 0;
-              }
-              getSymbolAccessibilityDiagnostic = createGetSymbolAccessibilityDiagnosticForNode(p.valueDeclaration);
-              const type = resolver.createTypeOfDeclaration(p.valueDeclaration, fakespace, declarationEmitNodeBuilderFlags, symbolTracker);
-              getSymbolAccessibilityDiagnostic = oldDiag;
-              const isNonContextualKeywordName = isStringANonContextualKeyword(nameStr);
-              const name = isNonContextualKeywordName ? factory2.getGeneratedNameForNode(p.valueDeclaration) : factory2.createIdentifier(nameStr);
-              if (isNonContextualKeywordName) {
-                exportMappings.push([name, nameStr]);
-              }
-              const varDecl = factory2.createVariableDeclaration(
-                name,
-                /*exclamationToken*/
-                void 0,
-                type,
-                /*initializer*/
-                void 0
-              );
-              return factory2.createVariableStatement(isNonContextualKeywordName ? void 0 : [factory2.createToken(95 /* ExportKeyword */)], factory2.createVariableDeclarationList([varDecl]));
-            });
-            if (!exportMappings.length) {
-              declarations = mapDefined(declarations, (declaration) => factory2.updateModifiers(declaration, 0 /* None */));
-            } else {
-              declarations.push(factory2.createExportDeclaration(
-                /*modifiers*/
-                void 0,
-                /*isTypeOnly*/
-                false,
-                factory2.createNamedExports(map(exportMappings, ([gen, exp]) => {
-                  return factory2.createExportSpecifier(
-                    /*isTypeOnly*/
-                    false,
-                    gen,
-                    exp
-                  );
-                }))
-              ));
-            }
-            const namespaceDecl = factory2.createModuleDeclaration(ensureModifiers(input), input.name, factory2.createModuleBlock(declarations), 16 /* Namespace */);
-            if (!hasEffectiveModifier(clean2, 1024 /* Default */)) {
-              return [clean2, namespaceDecl];
-            }
-            const modifiers = factory2.createModifiersFromModifierFlags(getEffectiveModifierFlags(clean2) & ~1025 /* ExportDefault */ | 2 /* Ambient */);
-            const cleanDeclaration = factory2.updateFunctionDeclaration(
-              clean2,
-              modifiers,
-              /*asteriskToken*/
-              void 0,
-              clean2.name,
-              clean2.typeParameters,
-              clean2.parameters,
-              clean2.type,
-              /*body*/
-              void 0
-            );
-            const namespaceDeclaration = factory2.updateModuleDeclaration(
-              namespaceDecl,
-              modifiers,
-              namespaceDecl.name,
-              namespaceDecl.body
-            );
-            const exportDefaultDeclaration = factory2.createExportAssignment(
-              /*modifiers*/
-              void 0,
-              /*isExportEquals*/
-              false,
-              namespaceDecl.name
-            );
-            if (isSourceFile(input.parent)) {
-              resultHasExternalModuleIndicator = true;
-            }
-            resultHasScopeMarker = true;
-            return [cleanDeclaration, namespaceDeclaration, exportDefaultDeclaration];
-          } else {
-            return clean2;
-          }
-        }
-        case 266 /* ModuleDeclaration */: {
-          needsDeclare = false;
-          const inner = input.body;
-          if (inner && inner.kind === 267 /* ModuleBlock */) {
-            const oldNeedsScopeFix = needsScopeFixMarker;
-            const oldHasScopeFix = resultHasScopeMarker;
-            resultHasScopeMarker = false;
-            needsScopeFixMarker = false;
-            const statements = visitNodes2(inner.statements, visitDeclarationStatements, isStatement);
-            let lateStatements = transformAndReplaceLatePaintedStatements(statements);
-            if (input.flags & 16777216 /* Ambient */) {
-              needsScopeFixMarker = false;
-            }
-            if (!isGlobalScopeAugmentation(input) && !hasScopeMarker2(lateStatements) && !resultHasScopeMarker) {
-              if (needsScopeFixMarker) {
-                lateStatements = factory2.createNodeArray([...lateStatements, createEmptyExports(factory2)]);
-              } else {
-                lateStatements = visitNodes2(lateStatements, stripExportModifiers, isStatement);
-              }
-            }
-            const body = factory2.updateModuleBlock(inner, lateStatements);
-            needsDeclare = previousNeedsDeclare;
-            needsScopeFixMarker = oldNeedsScopeFix;
-            resultHasScopeMarker = oldHasScopeFix;
-            const mods = ensureModifiers(input);
-            return cleanup(factory2.updateModuleDeclaration(
-              input,
-              mods,
-              isExternalModuleAugmentation(input) ? rewriteModuleSpecifier(input, input.name) : input.name,
-              body
-            ));
-          } else {
-            needsDeclare = previousNeedsDeclare;
-            const mods = ensureModifiers(input);
-            needsDeclare = false;
-            visitNode(inner, visitDeclarationStatements);
-            const id = getOriginalNodeId(inner);
-            const body = lateStatementReplacementMap.get(id);
-            lateStatementReplacementMap.delete(id);
-            return cleanup(factory2.updateModuleDeclaration(
-              input,
-              mods,
-              input.name,
-              body
-            ));
-          }
-        }
-        case 262 /* ClassDeclaration */: {
-          errorNameNode = input.name;
-          errorFallbackNode = input;
-          const modifiers = factory2.createNodeArray(ensureModifiers(input));
-          const typeParameters = ensureTypeParams(input, input.typeParameters);
-          const ctor = getFirstConstructorWithBody(input);
-          let parameterProperties;
-          if (ctor) {
-            const oldDiag2 = getSymbolAccessibilityDiagnostic;
-            parameterProperties = compact(flatMap(ctor.parameters, (param) => {
-              if (!hasSyntacticModifier(param, 16476 /* ParameterPropertyModifier */) || shouldStripInternal(param))
-                return;
-              getSymbolAccessibilityDiagnostic = createGetSymbolAccessibilityDiagnosticForNode(param);
-              if (param.name.kind === 80 /* Identifier */) {
-                return preserveJsDoc(factory2.createPropertyDeclaration(
-                  ensureModifiers(param),
-                  param.name,
-                  param.questionToken,
-                  ensureType(param, param.type),
-                  ensureNoInitializer(param)
-                ), param);
-              } else {
-                return walkBindingPattern(param.name);
-              }
-              function walkBindingPattern(pattern) {
-                let elems;
-                for (const elem of pattern.elements) {
-                  if (isOmittedExpression(elem))
-                    continue;
-                  if (isBindingPattern(elem.name)) {
-                    elems = concatenate(elems, walkBindingPattern(elem.name));
-                  }
-                  elems = elems || [];
-                  elems.push(factory2.createPropertyDeclaration(
-                    ensureModifiers(param),
-                    elem.name,
-                    /*questionOrExclamationToken*/
-                    void 0,
-                    ensureType(
-                      elem,
-                      /*type*/
-                      void 0
-                    ),
-                    /*initializer*/
-                    void 0
-                  ));
-                }
-                return elems;
-              }
-            }));
-            getSymbolAccessibilityDiagnostic = oldDiag2;
-          }
-          const hasPrivateIdentifier = some(input.members, (member) => !!member.name && isPrivateIdentifier(member.name));
-          const privateIdentifier = hasPrivateIdentifier ? [
-            factory2.createPropertyDeclaration(
-              /*modifiers*/
-              void 0,
-              factory2.createPrivateIdentifier("#private"),
-              /*questionOrExclamationToken*/
-              void 0,
-              /*type*/
-              void 0,
-              /*initializer*/
-              void 0
-            )
-          ] : void 0;
-          const memberNodes = concatenate(concatenate(privateIdentifier, parameterProperties), visitNodes2(input.members, visitDeclarationSubtree, isClassElement));
-          const members = factory2.createNodeArray(memberNodes);
-          const extendsClause = getEffectiveBaseTypeNode(input);
-          if (extendsClause && !isEntityNameExpression(extendsClause.expression) && extendsClause.expression.kind !== 106 /* NullKeyword */) {
-            const oldId = input.name ? unescapeLeadingUnderscores(input.name.escapedText) : "default";
-            const newId = factory2.createUniqueName(`${oldId}_base`, 16 /* Optimistic */);
-            getSymbolAccessibilityDiagnostic = () => ({
-              diagnosticMessage: Diagnostics.extends_clause_of_exported_class_0_has_or_is_using_private_name_1,
-              errorNode: extendsClause,
-              typeName: input.name
-            });
-            const varDecl = factory2.createVariableDeclaration(
-              newId,
-              /*exclamationToken*/
-              void 0,
-              resolver.createTypeOfExpression(extendsClause.expression, input, declarationEmitNodeBuilderFlags, symbolTracker),
-              /*initializer*/
-              void 0
-            );
-            const statement = factory2.createVariableStatement(needsDeclare ? [factory2.createModifier(138 /* DeclareKeyword */)] : [], factory2.createVariableDeclarationList([varDecl], 2 /* Const */));
-            const heritageClauses = factory2.createNodeArray(map(input.heritageClauses, (clause) => {
-              if (clause.token === 96 /* ExtendsKeyword */) {
-                const oldDiag2 = getSymbolAccessibilityDiagnostic;
-                getSymbolAccessibilityDiagnostic = createGetSymbolAccessibilityDiagnosticForNode(clause.types[0]);
-                const newClause = factory2.updateHeritageClause(clause, map(clause.types, (t) => factory2.updateExpressionWithTypeArguments(t, newId, visitNodes2(t.typeArguments, visitDeclarationSubtree, isTypeNode))));
-                getSymbolAccessibilityDiagnostic = oldDiag2;
-                return newClause;
-              }
-              return factory2.updateHeritageClause(clause, visitNodes2(factory2.createNodeArray(filter(clause.types, (t) => isEntityNameExpression(t.expression) || t.expression.kind === 106 /* NullKeyword */)), visitDeclarationSubtree, isExpressionWithTypeArguments));
-            }));
-            return [statement, cleanup(factory2.updateClassDeclaration(
-              input,
-              modifiers,
-              input.name,
-              typeParameters,
-              heritageClauses,
-              members
-            ))];
-          } else {
-            const heritageClauses = transformHeritageClauses(input.heritageClauses);
-            return cleanup(factory2.updateClassDeclaration(
-              input,
-              modifiers,
-              input.name,
-              typeParameters,
-              heritageClauses,
-              members
-            ));
-          }
-        }
-        case 242 /* VariableStatement */: {
-          return cleanup(transformVariableStatement(input));
-        }
-        case 265 /* EnumDeclaration */: {
-          return cleanup(factory2.updateEnumDeclaration(input, factory2.createNodeArray(ensureModifiers(input)), input.name, factory2.createNodeArray(mapDefined(input.members, (m) => {
-            if (shouldStripInternal(m))
-              return;
-            const constValue = resolver.getConstantValue(m);
-            return preserveJsDoc(factory2.updateEnumMember(m, m.name, constValue !== void 0 ? typeof constValue === "string" ? factory2.createStringLiteral(constValue) : factory2.createNumericLiteral(constValue) : void 0), m);
-          }))));
-        }
-      }
-      return Debug.assertNever(input, `Unhandled top-level node in declaration emit: ${Debug.formatSyntaxKind(input.kind)}`);
-      function cleanup(node) {
-        if (isEnclosingDeclaration(input)) {
-          enclosingDeclaration = previousEnclosingDeclaration;
-        }
-        if (canProdiceDiagnostic) {
-          getSymbolAccessibilityDiagnostic = oldDiag;
-        }
-        if (input.kind === 266 /* ModuleDeclaration */) {
-          needsDeclare = previousNeedsDeclare;
-        }
-        if (node === input) {
-          return node;
-        }
-        errorFallbackNode = void 0;
-        errorNameNode = void 0;
-        return node && setOriginalNode(preserveJsDoc(node, input), input);
-      }
-    }
-    function transformVariableStatement(input) {
-      if (!forEach(input.declarationList.declarations, getBindingNameVisible))
-        return;
-      const nodes = visitNodes2(input.declarationList.declarations, visitDeclarationSubtree, isVariableDeclaration);
-      if (!length(nodes))
-        return;
-      return factory2.updateVariableStatement(input, factory2.createNodeArray(ensureModifiers(input)), factory2.updateVariableDeclarationList(input.declarationList, nodes));
-    }
-    function recreateBindingPattern(d) {
-      return flatten(mapDefined(d.elements, (e) => recreateBindingElement(e)));
-    }
-    function recreateBindingElement(e) {
-      if (e.kind === 231 /* OmittedExpression */) {
-        return;
-      }
-      if (e.name) {
-        if (!getBindingNameVisible(e))
-          return;
-        if (isBindingPattern(e.name)) {
-          return recreateBindingPattern(e.name);
-        } else {
-          return factory2.createVariableDeclaration(
-            e.name,
-            /*exclamationToken*/
-            void 0,
-            ensureType(
-              e,
-              /*type*/
-              void 0
-            ),
-            /*initializer*/
-            void 0
-          );
-        }
-      }
-    }
-    function checkName(node) {
-      let oldDiag;
-      if (!suppressNewDiagnosticContexts) {
-        oldDiag = getSymbolAccessibilityDiagnostic;
-        getSymbolAccessibilityDiagnostic = createGetSymbolAccessibilityDiagnosticForNodeName(node);
-      }
-      errorNameNode = node.name;
-      Debug.assert(resolver.isLateBound(getParseTreeNode(node)));
-      const decl = node;
-      const entityName = decl.name.expression;
-      checkEntityNameVisibility(entityName, enclosingDeclaration);
-      if (!suppressNewDiagnosticContexts) {
-        getSymbolAccessibilityDiagnostic = oldDiag;
-      }
-      errorNameNode = void 0;
-    }
-    function shouldStripInternal(node) {
-      return !!stripInternal && !!node && isInternalDeclaration(node, currentSourceFile);
-    }
-    function isScopeMarker2(node) {
-      return isExportAssignment(node) || isExportDeclaration(node);
-    }
-    function hasScopeMarker2(statements) {
-      return some(statements, isScopeMarker2);
-    }
-    function ensureModifiers(node) {
-      const currentFlags = getEffectiveModifierFlags(node);
-      const newFlags = ensureModifierFlags(node);
-      if (currentFlags === newFlags) {
-        return visitArray(node.modifiers, (n) => tryCast(n, isModifier), isModifier);
-      }
-      return factory2.createModifiersFromModifierFlags(newFlags);
-    }
-    function ensureModifierFlags(node) {
-      let mask2 = 258047 /* All */ ^ (4 /* Public */ | 512 /* Async */ | 16384 /* Override */);
-      let additions = needsDeclare && !isAlwaysType(node) ? 2 /* Ambient */ : 0 /* None */;
-      const parentIsFile = node.parent.kind === 311 /* SourceFile */;
-      if (!parentIsFile || isBundledEmit && parentIsFile && isExternalModule(node.parent)) {
-        mask2 ^= 2 /* Ambient */;
-        additions = 0 /* None */;
-      }
-      return maskModifierFlags(node, mask2, additions);
-    }
-    function getTypeAnnotationFromAllAccessorDeclarations(node, accessors) {
-      let accessorType = getTypeAnnotationFromAccessor(node);
-      if (!accessorType && node !== accessors.firstAccessor) {
-        accessorType = getTypeAnnotationFromAccessor(accessors.firstAccessor);
-        getSymbolAccessibilityDiagnostic = createGetSymbolAccessibilityDiagnosticForNode(accessors.firstAccessor);
-      }
-      if (!accessorType && accessors.secondAccessor && node !== accessors.secondAccessor) {
-        accessorType = getTypeAnnotationFromAccessor(accessors.secondAccessor);
-        getSymbolAccessibilityDiagnostic = createGetSymbolAccessibilityDiagnosticForNode(accessors.secondAccessor);
-      }
-      return accessorType;
-    }
-    function transformHeritageClauses(nodes) {
-      return factory2.createNodeArray(filter(map(nodes, (clause) => factory2.updateHeritageClause(clause, visitNodes2(factory2.createNodeArray(filter(clause.types, (t) => {
-        return isEntityNameExpression(t.expression) || clause.token === 96 /* ExtendsKeyword */ && t.expression.kind === 106 /* NullKeyword */;
-      })), visitDeclarationSubtree, isExpressionWithTypeArguments))), (clause) => clause.types && !!clause.types.length));
-    }
-  }
-  function isAlwaysType(node) {
-    if (node.kind === 263 /* InterfaceDeclaration */) {
-      return true;
-    }
-    return false;
-  }
-  function maskModifiers(factory2, node, modifierMask, modifierAdditions) {
-    return factory2.createModifiersFromModifierFlags(maskModifierFlags(node, modifierMask, modifierAdditions));
-  }
-  function maskModifierFlags(node, modifierMask = 258047 /* All */ ^ 4 /* Public */, modifierAdditions = 0 /* None */) {
-    let flags = getEffectiveModifierFlags(node) & modifierMask | modifierAdditions;
-    if (flags & 1024 /* Default */ && !(flags & 1 /* Export */)) {
-      flags ^= 1 /* Export */;
-    }
-    if (flags & 1024 /* Default */ && flags & 2 /* Ambient */) {
-      flags ^= 2 /* Ambient */;
-    }
-    return flags;
-  }
-  function getTypeAnnotationFromAccessor(accessor) {
-    if (accessor) {
-      return accessor.kind === 176 /* GetAccessor */ ? accessor.type : accessor.parameters.length > 0 ? accessor.parameters[0].type : void 0;
-    }
-  }
-  function canHaveLiteralInitializer(node) {
-    switch (node.kind) {
-      case 171 /* PropertyDeclaration */:
-      case 170 /* PropertySignature */:
-        return !hasEffectiveModifier(node, 8 /* Private */);
-      case 168 /* Parameter */:
-      case 259 /* VariableDeclaration */:
-        return true;
-    }
-    return false;
-  }
-  function isPreservedDeclarationStatement(node) {
-    switch (node.kind) {
-      case 261 /* FunctionDeclaration */:
-      case 266 /* ModuleDeclaration */:
-      case 270 /* ImportEqualsDeclaration */:
-      case 263 /* InterfaceDeclaration */:
-      case 262 /* ClassDeclaration */:
-      case 264 /* TypeAliasDeclaration */:
-      case 265 /* EnumDeclaration */:
-      case 242 /* VariableStatement */:
-      case 271 /* ImportDeclaration */:
-      case 277 /* ExportDeclaration */:
-      case 276 /* ExportAssignment */:
-        return true;
-    }
-    return false;
-  }
-  function isProcessedComponent(node) {
-    switch (node.kind) {
-      case 179 /* ConstructSignature */:
-      case 175 /* Constructor */:
-      case 173 /* MethodDeclaration */:
-      case 176 /* GetAccessor */:
-      case 177 /* SetAccessor */:
-      case 171 /* PropertyDeclaration */:
-      case 170 /* PropertySignature */:
-      case 172 /* MethodSignature */:
-      case 178 /* CallSignature */:
-      case 180 /* IndexSignature */:
-      case 259 /* VariableDeclaration */:
-      case 167 /* TypeParameter */:
-      case 232 /* ExpressionWithTypeArguments */:
-      case 182 /* TypeReference */:
-      case 193 /* ConditionalType */:
-      case 183 /* FunctionType */:
-      case 184 /* ConstructorType */:
-      case 204 /* ImportType */:
-        return true;
-    }
-    return false;
-  }
-  var declarationEmitNodeBuilderFlags;
-  var init_declarations = __esm({
-    "src/compiler/transformers/declarations.ts"() {
-      "use strict";
-      init_ts2();
-      init_ts_moduleSpecifiers();
-      declarationEmitNodeBuilderFlags = 1024 /* MultilineObjectLiterals */ | 2048 /* WriteClassExpressionAsTypeLiteral */ | 4096 /* UseTypeOfFunction */ | 8 /* UseStructuralFallback */ | 524288 /* AllowEmptyTuple */ | 4 /* GenerateNamesForShadowedTypeParams */ | 1 /* NoTruncation */;
-    }
-  });
-
-  // src/compiler/transformer.ts
-  function getModuleTransformer(moduleKind) {
-    switch (moduleKind) {
-      case 99 /* ESNext */:
-      case 7 /* ES2022 */:
-      case 6 /* ES2020 */:
-      case 5 /* ES2015 */:
-        return transformECMAScriptModule;
-      case 4 /* System */:
-        return transformSystemModule;
-      case 100 /* Node16 */:
-      case 199 /* NodeNext */:
-        return transformNodeModule;
-      default:
-        return transformModule;
-    }
-  }
-  function getTransformers(compilerOptions, customTransformers, emitOnly) {
-    return {
-      scriptTransformers: getScriptTransformers(compilerOptions, customTransformers, emitOnly),
-      declarationTransformers: getDeclarationTransformers(customTransformers)
-    };
-  }
-  function getScriptTransformers(compilerOptions, customTransformers, emitOnly) {
-    if (emitOnly)
-      return emptyArray;
-    const languageVersion = getEmitScriptTarget(compilerOptions);
-    const moduleKind = getEmitModuleKind(compilerOptions);
-    const useDefineForClassFields = getUseDefineForClassFields(compilerOptions);
-    const transformers = [];
-    addRange(transformers, customTransformers && map(customTransformers.before, wrapScriptTransformerFactory));
-    transformers.push(transformTypeScript);
-    if (compilerOptions.experimentalDecorators) {
-      transformers.push(transformLegacyDecorators);
-    } else if (languageVersion < 99 /* ESNext */ || !useDefineForClassFields) {
-      transformers.push(transformESDecorators);
-    }
-    transformers.push(transformClassFields);
-    if (getJSXTransformEnabled(compilerOptions)) {
-      transformers.push(transformJsx);
-    }
-    if (languageVersion < 99 /* ESNext */) {
-      transformers.push(transformESNext);
-    }
-    if (languageVersion < 8 /* ES2021 */) {
-      transformers.push(transformES2021);
-    }
-    if (languageVersion < 7 /* ES2020 */) {
-      transformers.push(transformES2020);
-    }
-    if (languageVersion < 6 /* ES2019 */) {
-      transformers.push(transformES2019);
-    }
-    if (languageVersion < 5 /* ES2018 */) {
-      transformers.push(transformES2018);
-    }
-    if (languageVersion < 4 /* ES2017 */) {
-      transformers.push(transformES2017);
-    }
-    if (languageVersion < 3 /* ES2016 */) {
-      transformers.push(transformES2016);
-    }
-    if (languageVersion < 2 /* ES2015 */) {
-      transformers.push(transformES2015);
-      transformers.push(transformGenerators);
-    }
-    transformers.push(getModuleTransformer(moduleKind));
-    if (languageVersion < 1 /* ES5 */) {
-      transformers.push(transformES5);
-    }
-    addRange(transformers, customTransformers && map(customTransformers.after, wrapScriptTransformerFactory));
-    return transformers;
-  }
-  function getDeclarationTransformers(customTransformers) {
-    const transformers = [];
-    transformers.push(transformDeclarations);
-    addRange(transformers, customTransformers && map(customTransformers.afterDeclarations, wrapDeclarationTransformerFactory));
-    return transformers;
-  }
-  function wrapCustomTransformer(transformer) {
-    return (node) => isBundle(node) ? transformer.transformBundle(node) : transformer.transformSourceFile(node);
-  }
-  function wrapCustomTransformerFactory(transformer, handleDefault) {
-    return (context) => {
-      const customTransformer = transformer(context);
-      return typeof customTransformer === "function" ? handleDefault(context, customTransformer) : wrapCustomTransformer(customTransformer);
-    };
-  }
-  function wrapScriptTransformerFactory(transformer) {
-    return wrapCustomTransformerFactory(transformer, chainBundle);
-  }
-  function wrapDeclarationTransformerFactory(transformer) {
-    return wrapCustomTransformerFactory(transformer, (_, node) => node);
-  }
-  function noEmitSubstitution(_hint, node) {
-    return node;
-  }
-  function noEmitNotification(hint, node, callback) {
-    callback(hint, node);
-  }
-  function transformNodes(resolver, host, factory2, options, nodes, transformers, allowDtsFiles) {
-    var _a, _b;
-    const enabledSyntaxKindFeatures = new Array(362 /* Count */);
-    let lexicalEnvironmentVariableDeclarations;
-    let lexicalEnvironmentFunctionDeclarations;
-    let lexicalEnvironmentStatements;
-    let lexicalEnvironmentFlags = 0 /* None */;
-    let lexicalEnvironmentVariableDeclarationsStack = [];
-    let lexicalEnvironmentFunctionDeclarationsStack = [];
-    let lexicalEnvironmentStatementsStack = [];
-    let lexicalEnvironmentFlagsStack = [];
-    let lexicalEnvironmentStackOffset = 0;
-    let lexicalEnvironmentSuspended = false;
-    let blockScopedVariableDeclarationsStack = [];
-    let blockScopeStackOffset = 0;
-    let blockScopedVariableDeclarations;
-    let emitHelpers;
-    let onSubstituteNode = noEmitSubstitution;
-    let onEmitNode = noEmitNotification;
-    let state = 0 /* Uninitialized */;
-    const diagnostics = [];
-    const context = {
-      factory: factory2,
-      getCompilerOptions: () => options,
-      getEmitResolver: () => resolver,
-      // TODO: GH#18217
-      getEmitHost: () => host,
-      // TODO: GH#18217
-      getEmitHelperFactory: memoize(() => createEmitHelperFactory(context)),
-      startLexicalEnvironment,
-      suspendLexicalEnvironment,
-      resumeLexicalEnvironment,
-      endLexicalEnvironment,
-      setLexicalEnvironmentFlags,
-      getLexicalEnvironmentFlags,
-      hoistVariableDeclaration,
-      hoistFunctionDeclaration,
-      addInitializationStatement,
-      startBlockScope,
-      endBlockScope,
-      addBlockScopedVariable,
-      requestEmitHelper,
-      readEmitHelpers,
-      enableSubstitution,
-      enableEmitNotification,
-      isSubstitutionEnabled,
-      isEmitNotificationEnabled,
-      get onSubstituteNode() {
-        return onSubstituteNode;
-      },
-      set onSubstituteNode(value) {
-        Debug.assert(state < 1 /* Initialized */, "Cannot modify transformation hooks after initialization has completed.");
-        Debug.assert(value !== void 0, "Value must not be 'undefined'");
-        onSubstituteNode = value;
-      },
-      get onEmitNode() {
-        return onEmitNode;
-      },
-      set onEmitNode(value) {
-        Debug.assert(state < 1 /* Initialized */, "Cannot modify transformation hooks after initialization has completed.");
-        Debug.assert(value !== void 0, "Value must not be 'undefined'");
-        onEmitNode = value;
-      },
-      addDiagnostic(diag2) {
-        diagnostics.push(diag2);
-      }
-    };
-    for (const node of nodes) {
-      disposeEmitNodes(getSourceFileOfNode(getParseTreeNode(node)));
-    }
-    mark("beforeTransform");
-    const transformersWithContext = transformers.map((t) => t(context));
-    const transformation = (node) => {
-      for (const transform2 of transformersWithContext) {
-        node = transform2(node);
-      }
-      return node;
-    };
-    state = 1 /* Initialized */;
-    const transformed = [];
-    for (const node of nodes) {
-      (_a = tracing) == null ? void 0 : _a.push(tracing.Phase.Emit, "transformNodes", node.kind === 311 /* SourceFile */ ? { path: node.path } : { kind: node.kind, pos: node.pos, end: node.end });
-      transformed.push((allowDtsFiles ? transformation : transformRoot)(node));
-      (_b = tracing) == null ? void 0 : _b.pop();
-    }
-    state = 2 /* Completed */;
-    mark("afterTransform");
-    measure("transformTime", "beforeTransform", "afterTransform");
-    return {
-      transformed,
-      substituteNode,
-      emitNodeWithNotification,
-      isEmitNotificationEnabled,
-      dispose,
-      diagnostics
-    };
-    function transformRoot(node) {
-      return node && (!isSourceFile(node) || !node.isDeclarationFile) ? transformation(node) : node;
-    }
-    function enableSubstitution(kind) {
-      Debug.assert(state < 2 /* Completed */, "Cannot modify the transformation context after transformation has completed.");
-      enabledSyntaxKindFeatures[kind] |= 1 /* Substitution */;
-    }
-    function isSubstitutionEnabled(node) {
-      return (enabledSyntaxKindFeatures[node.kind] & 1 /* Substitution */) !== 0 && (getEmitFlags(node) & 8 /* NoSubstitution */) === 0;
-    }
-    function substituteNode(hint, node) {
-      Debug.assert(state < 3 /* Disposed */, "Cannot substitute a node after the result is disposed.");
-      return node && isSubstitutionEnabled(node) && onSubstituteNode(hint, node) || node;
-    }
-    function enableEmitNotification(kind) {
-      Debug.assert(state < 2 /* Completed */, "Cannot modify the transformation context after transformation has completed.");
-      enabledSyntaxKindFeatures[kind] |= 2 /* EmitNotifications */;
-    }
-    function isEmitNotificationEnabled(node) {
-      return (enabledSyntaxKindFeatures[node.kind] & 2 /* EmitNotifications */) !== 0 || (getEmitFlags(node) & 4 /* AdviseOnEmitNode */) !== 0;
-    }
-    function emitNodeWithNotification(hint, node, emitCallback) {
-      Debug.assert(state < 3 /* Disposed */, "Cannot invoke TransformationResult callbacks after the result is disposed.");
-      if (node) {
-        if (isEmitNotificationEnabled(node)) {
-          onEmitNode(hint, node, emitCallback);
-        } else {
-          emitCallback(hint, node);
-        }
-      }
-    }
-    function hoistVariableDeclaration(name) {
-      Debug.assert(state > 0 /* Uninitialized */, "Cannot modify the lexical environment during initialization.");
-      Debug.assert(state < 2 /* Completed */, "Cannot modify the lexical environment after transformation has completed.");
-      const decl = setEmitFlags(factory2.createVariableDeclaration(name), 128 /* NoNestedSourceMaps */);
-      if (!lexicalEnvironmentVariableDeclarations) {
-        lexicalEnvironmentVariableDeclarations = [decl];
-      } else {
-        lexicalEnvironmentVariableDeclarations.push(decl);
-      }
-      if (lexicalEnvironmentFlags & 1 /* InParameters */) {
-        lexicalEnvironmentFlags |= 2 /* VariablesHoistedInParameters */;
-      }
-    }
-    function hoistFunctionDeclaration(func) {
-      Debug.assert(state > 0 /* Uninitialized */, "Cannot modify the lexical environment during initialization.");
-      Debug.assert(state < 2 /* Completed */, "Cannot modify the lexical environment after transformation has completed.");
-      setEmitFlags(func, 2097152 /* CustomPrologue */);
-      if (!lexicalEnvironmentFunctionDeclarations) {
-        lexicalEnvironmentFunctionDeclarations = [func];
-      } else {
-        lexicalEnvironmentFunctionDeclarations.push(func);
-      }
-    }
-    function addInitializationStatement(node) {
-      Debug.assert(state > 0 /* Uninitialized */, "Cannot modify the lexical environment during initialization.");
-      Debug.assert(state < 2 /* Completed */, "Cannot modify the lexical environment after transformation has completed.");
-      setEmitFlags(node, 2097152 /* CustomPrologue */);
-      if (!lexicalEnvironmentStatements) {
-        lexicalEnvironmentStatements = [node];
-      } else {
-        lexicalEnvironmentStatements.push(node);
-      }
-    }
-    function startLexicalEnvironment() {
-      Debug.assert(state > 0 /* Uninitialized */, "Cannot modify the lexical environment during initialization.");
-      Debug.assert(state < 2 /* Completed */, "Cannot modify the lexical environment after transformation has completed.");
-      Debug.assert(!lexicalEnvironmentSuspended, "Lexical environment is suspended.");
-      lexicalEnvironmentVariableDeclarationsStack[lexicalEnvironmentStackOffset] = lexicalEnvironmentVariableDeclarations;
-      lexicalEnvironmentFunctionDeclarationsStack[lexicalEnvironmentStackOffset] = lexicalEnvironmentFunctionDeclarations;
-      lexicalEnvironmentStatementsStack[lexicalEnvironmentStackOffset] = lexicalEnvironmentStatements;
-      lexicalEnvironmentFlagsStack[lexicalEnvironmentStackOffset] = lexicalEnvironmentFlags;
-      lexicalEnvironmentStackOffset++;
-      lexicalEnvironmentVariableDeclarations = void 0;
-      lexicalEnvironmentFunctionDeclarations = void 0;
-      lexicalEnvironmentStatements = void 0;
-      lexicalEnvironmentFlags = 0 /* None */;
-    }
-    function suspendLexicalEnvironment() {
-      Debug.assert(state > 0 /* Uninitialized */, "Cannot modify the lexical environment during initialization.");
-      Debug.assert(state < 2 /* Completed */, "Cannot modify the lexical environment after transformation has completed.");
-      Debug.assert(!lexicalEnvironmentSuspended, "Lexical environment is already suspended.");
-      lexicalEnvironmentSuspended = true;
-    }
-    function resumeLexicalEnvironment() {
-      Debug.assert(state > 0 /* Uninitialized */, "Cannot modify the lexical environment during initialization.");
-      Debug.assert(state < 2 /* Completed */, "Cannot modify the lexical environment after transformation has completed.");
-      Debug.assert(lexicalEnvironmentSuspended, "Lexical environment is not suspended.");
-      lexicalEnvironmentSuspended = false;
-    }
-    function endLexicalEnvironment() {
-      Debug.assert(state > 0 /* Uninitialized */, "Cannot modify the lexical environment during initialization.");
-      Debug.assert(state < 2 /* Completed */, "Cannot modify the lexical environment after transformation has completed.");
-      Debug.assert(!lexicalEnvironmentSuspended, "Lexical environment is suspended.");
-      let statements;
-      if (lexicalEnvironmentVariableDeclarations || lexicalEnvironmentFunctionDeclarations || lexicalEnvironmentStatements) {
-        if (lexicalEnvironmentFunctionDeclarations) {
-          statements = [...lexicalEnvironmentFunctionDeclarations];
-        }
-        if (lexicalEnvironmentVariableDeclarations) {
-          const statement = factory2.createVariableStatement(
-            /*modifiers*/
-            void 0,
-            factory2.createVariableDeclarationList(lexicalEnvironmentVariableDeclarations)
-          );
-          setEmitFlags(statement, 2097152 /* CustomPrologue */);
-          if (!statements) {
-            statements = [statement];
-          } else {
-            statements.push(statement);
-          }
-        }
-        if (lexicalEnvironmentStatements) {
-          if (!statements) {
-            statements = [...lexicalEnvironmentStatements];
-          } else {
-            statements = [...statements, ...lexicalEnvironmentStatements];
-          }
-        }
-      }
-      lexicalEnvironmentStackOffset--;
-      lexicalEnvironmentVariableDeclarations = lexicalEnvironmentVariableDeclarationsStack[lexicalEnvironmentStackOffset];
-      lexicalEnvironmentFunctionDeclarations = lexicalEnvironmentFunctionDeclarationsStack[lexicalEnvironmentStackOffset];
-      lexicalEnvironmentStatements = lexicalEnvironmentStatementsStack[lexicalEnvironmentStackOffset];
-      lexicalEnvironmentFlags = lexicalEnvironmentFlagsStack[lexicalEnvironmentStackOffset];
-      if (lexicalEnvironmentStackOffset === 0) {
-        lexicalEnvironmentVariableDeclarationsStack = [];
-        lexicalEnvironmentFunctionDeclarationsStack = [];
-        lexicalEnvironmentStatementsStack = [];
-        lexicalEnvironmentFlagsStack = [];
-      }
-      return statements;
-    }
-    function setLexicalEnvironmentFlags(flags, value) {
-      lexicalEnvironmentFlags = value ? lexicalEnvironmentFlags | flags : lexicalEnvironmentFlags & ~flags;
-    }
-    function getLexicalEnvironmentFlags() {
-      return lexicalEnvironmentFlags;
-    }
-    function startBlockScope() {
-      Debug.assert(state > 0 /* Uninitialized */, "Cannot start a block scope during initialization.");
-      Debug.assert(state < 2 /* Completed */, "Cannot start a block scope after transformation has completed.");
-      blockScopedVariableDeclarationsStack[blockScopeStackOffset] = blockScopedVariableDeclarations;
-      blockScopeStackOffset++;
-      blockScopedVariableDeclarations = void 0;
-    }
-    function endBlockScope() {
-      Debug.assert(state > 0 /* Uninitialized */, "Cannot end a block scope during initialization.");
-      Debug.assert(state < 2 /* Completed */, "Cannot end a block scope after transformation has completed.");
-      const statements = some(blockScopedVariableDeclarations) ? [
-        factory2.createVariableStatement(
-          /*modifiers*/
-          void 0,
-          factory2.createVariableDeclarationList(
-            blockScopedVariableDeclarations.map((identifier) => factory2.createVariableDeclaration(identifier)),
-            1 /* Let */
-          )
-        )
-      ] : void 0;
-      blockScopeStackOffset--;
-      blockScopedVariableDeclarations = blockScopedVariableDeclarationsStack[blockScopeStackOffset];
-      if (blockScopeStackOffset === 0) {
-        blockScopedVariableDeclarationsStack = [];
-      }
-      return statements;
-    }
-    function addBlockScopedVariable(name) {
-      Debug.assert(blockScopeStackOffset > 0, "Cannot add a block scoped variable outside of an iteration body.");
-      (blockScopedVariableDeclarations || (blockScopedVariableDeclarations = [])).push(name);
-    }
-    function requestEmitHelper(helper) {
-      Debug.assert(state > 0 /* Uninitialized */, "Cannot modify the transformation context during initialization.");
-      Debug.assert(state < 2 /* Completed */, "Cannot modify the transformation context after transformation has completed.");
-      Debug.assert(!helper.scoped, "Cannot request a scoped emit helper.");
-      if (helper.dependencies) {
-        for (const h of helper.dependencies) {
-          requestEmitHelper(h);
-        }
-      }
-      emitHelpers = append(emitHelpers, helper);
-    }
-    function readEmitHelpers() {
-      Debug.assert(state > 0 /* Uninitialized */, "Cannot modify the transformation context during initialization.");
-      Debug.assert(state < 2 /* Completed */, "Cannot modify the transformation context after transformation has completed.");
-      const helpers = emitHelpers;
-      emitHelpers = void 0;
-      return helpers;
-    }
-    function dispose() {
-      if (state < 3 /* Disposed */) {
-        for (const node of nodes) {
-          disposeEmitNodes(getSourceFileOfNode(getParseTreeNode(node)));
-        }
-        lexicalEnvironmentVariableDeclarations = void 0;
-        lexicalEnvironmentVariableDeclarationsStack = void 0;
-        lexicalEnvironmentFunctionDeclarations = void 0;
-        lexicalEnvironmentFunctionDeclarationsStack = void 0;
-        onSubstituteNode = void 0;
-        onEmitNode = void 0;
-        emitHelpers = void 0;
-        state = 3 /* Disposed */;
-      }
-    }
-  }
-  var noTransformers, nullTransformationContext;
-  var init_transformer = __esm({
-    "src/compiler/transformer.ts"() {
-      "use strict";
-      init_ts2();
-      init_ts_performance();
-      noTransformers = { scriptTransformers: emptyArray, declarationTransformers: emptyArray };
-      nullTransformationContext = {
-        factory,
-        // eslint-disable-line object-shorthand
-        getCompilerOptions: () => ({}),
-        getEmitResolver: notImplemented,
-        getEmitHost: notImplemented,
-        getEmitHelperFactory: notImplemented,
-        startLexicalEnvironment: noop,
-        resumeLexicalEnvironment: noop,
-        suspendLexicalEnvironment: noop,
-        endLexicalEnvironment: returnUndefined,
-        setLexicalEnvironmentFlags: noop,
-        getLexicalEnvironmentFlags: () => 0,
-        hoistVariableDeclaration: noop,
-        hoistFunctionDeclaration: noop,
-        addInitializationStatement: noop,
-        startBlockScope: noop,
-        endBlockScope: returnUndefined,
-        addBlockScopedVariable: noop,
-        requestEmitHelper: noop,
-        readEmitHelpers: notImplemented,
-        enableSubstitution: noop,
-        enableEmitNotification: noop,
-        isSubstitutionEnabled: notImplemented,
-        isEmitNotificationEnabled: notImplemented,
-        onSubstituteNode: noEmitSubstitution,
-        onEmitNode: noEmitNotification,
-        addDiagnostic: noop
-      };
-    }
-  });
-
-  // src/compiler/emitter.ts
-  function isBuildInfoFile(file) {
-    return fileExtensionIs(file, ".tsbuildinfo" /* TsBuildInfo */);
-  }
-  function forEachEmittedFile(host, action, sourceFilesOrTargetSourceFile, forceDtsEmit = false, onlyBuildInfo, includeBuildInfo) {
-    const sourceFiles = isArray(sourceFilesOrTargetSourceFile) ? sourceFilesOrTargetSourceFile : getSourceFilesToEmit(host, sourceFilesOrTargetSourceFile, forceDtsEmit);
-    const options = host.getCompilerOptions();
-    if (outFile(options)) {
-      const prepends = host.getPrependNodes();
-      if (sourceFiles.length || prepends.length) {
-        const bundle = factory.createBundle(sourceFiles, prepends);
-        const result = action(getOutputPathsFor(bundle, host, forceDtsEmit), bundle);
-        if (result) {
-          return result;
-        }
-      }
-    } else {
-      if (!onlyBuildInfo) {
-        for (const sourceFile of sourceFiles) {
-          const result = action(getOutputPathsFor(sourceFile, host, forceDtsEmit), sourceFile);
-          if (result) {
-            return result;
-          }
-        }
-      }
-      if (includeBuildInfo) {
-        const buildInfoPath = getTsBuildInfoEmitOutputFilePath(options);
-        if (buildInfoPath)
-          return action(
-            { buildInfoPath },
-            /*sourceFileOrBundle*/
-            void 0
-          );
-      }
-    }
-  }
-  function getTsBuildInfoEmitOutputFilePath(options) {
-    const configFile = options.configFilePath;
-    if (!isIncrementalCompilation(options))
-      return void 0;
-    if (options.tsBuildInfoFile)
-      return options.tsBuildInfoFile;
-    const outPath = outFile(options);
-    let buildInfoExtensionLess;
-    if (outPath) {
-      buildInfoExtensionLess = removeFileExtension(outPath);
-    } else {
-      if (!configFile)
-        return void 0;
-      const configFileExtensionLess = removeFileExtension(configFile);
-      buildInfoExtensionLess = options.outDir ? options.rootDir ? resolvePath(options.outDir, getRelativePathFromDirectory(
-        options.rootDir,
-        configFileExtensionLess,
-        /*ignoreCase*/
-        true
-      )) : combinePaths(options.outDir, getBaseFileName(configFileExtensionLess)) : configFileExtensionLess;
-    }
-    return buildInfoExtensionLess + ".tsbuildinfo" /* TsBuildInfo */;
-  }
-  function getOutputPathsForBundle(options, forceDtsPaths) {
-    const outPath = outFile(options);
-    const jsFilePath = options.emitDeclarationOnly ? void 0 : outPath;
-    const sourceMapFilePath = jsFilePath && getSourceMapFilePath(jsFilePath, options);
-    const declarationFilePath = forceDtsPaths || getEmitDeclarations(options) ? removeFileExtension(outPath) + ".d.ts" /* Dts */ : void 0;
-    const declarationMapPath = declarationFilePath && getAreDeclarationMapsEnabled(options) ? declarationFilePath + ".map" : void 0;
-    const buildInfoPath = getTsBuildInfoEmitOutputFilePath(options);
-    return { jsFilePath, sourceMapFilePath, declarationFilePath, declarationMapPath, buildInfoPath };
-  }
-  function getOutputPathsFor(sourceFile, host, forceDtsPaths) {
-    const options = host.getCompilerOptions();
-    if (sourceFile.kind === 312 /* Bundle */) {
-      return getOutputPathsForBundle(options, forceDtsPaths);
-    } else {
-      const ownOutputFilePath = getOwnEmitOutputFilePath(sourceFile.fileName, host, getOutputExtension(sourceFile.fileName, options));
-      const isJsonFile = isJsonSourceFile(sourceFile);
-      const isJsonEmittedToSameLocation = isJsonFile && comparePaths(sourceFile.fileName, ownOutputFilePath, host.getCurrentDirectory(), !host.useCaseSensitiveFileNames()) === 0 /* EqualTo */;
-      const jsFilePath = options.emitDeclarationOnly || isJsonEmittedToSameLocation ? void 0 : ownOutputFilePath;
-      const sourceMapFilePath = !jsFilePath || isJsonSourceFile(sourceFile) ? void 0 : getSourceMapFilePath(jsFilePath, options);
-      const declarationFilePath = forceDtsPaths || getEmitDeclarations(options) && !isJsonFile ? getDeclarationEmitOutputFilePath(sourceFile.fileName, host) : void 0;
-      const declarationMapPath = declarationFilePath && getAreDeclarationMapsEnabled(options) ? declarationFilePath + ".map" : void 0;
-      return { jsFilePath, sourceMapFilePath, declarationFilePath, declarationMapPath, buildInfoPath: void 0 };
-    }
-  }
-  function getSourceMapFilePath(jsFilePath, options) {
-    return options.sourceMap && !options.inlineSourceMap ? jsFilePath + ".map" : void 0;
-  }
-  function getOutputExtension(fileName, options) {
-    return fileExtensionIs(fileName, ".json" /* Json */) ? ".json" /* Json */ : options.jsx === 1 /* Preserve */ && fileExtensionIsOneOf(fileName, [".jsx" /* Jsx */, ".tsx" /* Tsx */]) ? ".jsx" /* Jsx */ : fileExtensionIsOneOf(fileName, [".mts" /* Mts */, ".mjs" /* Mjs */]) ? ".mjs" /* Mjs */ : fileExtensionIsOneOf(fileName, [".cts" /* Cts */, ".cjs" /* Cjs */]) ? ".cjs" /* Cjs */ : ".js" /* Js */;
-  }
-  function getOutputPathWithoutChangingExt(inputFileName, configFile, ignoreCase, outputDir, getCommonSourceDirectory2) {
-    return outputDir ? resolvePath(
-      outputDir,
-      getRelativePathFromDirectory(getCommonSourceDirectory2 ? getCommonSourceDirectory2() : getCommonSourceDirectoryOfConfig(configFile, ignoreCase), inputFileName, ignoreCase)
-    ) : inputFileName;
-  }
-  function getOutputDeclarationFileName(inputFileName, configFile, ignoreCase, getCommonSourceDirectory2) {
-    return changeExtension(
-      getOutputPathWithoutChangingExt(inputFileName, configFile, ignoreCase, configFile.options.declarationDir || configFile.options.outDir, getCommonSourceDirectory2),
-      getDeclarationEmitExtensionForPath(inputFileName)
-    );
-  }
-  function getOutputJSFileName(inputFileName, configFile, ignoreCase, getCommonSourceDirectory2) {
-    if (configFile.options.emitDeclarationOnly)
-      return void 0;
-    const isJsonFile = fileExtensionIs(inputFileName, ".json" /* Json */);
-    const outputFileName = changeExtension(
-      getOutputPathWithoutChangingExt(inputFileName, configFile, ignoreCase, configFile.options.outDir, getCommonSourceDirectory2),
-      getOutputExtension(inputFileName, configFile.options)
-    );
-    return !isJsonFile || comparePaths(inputFileName, outputFileName, Debug.checkDefined(configFile.options.configFilePath), ignoreCase) !== 0 /* EqualTo */ ? outputFileName : void 0;
-  }
-  function createAddOutput() {
-    let outputs;
-    return { addOutput, getOutputs };
-    function addOutput(path) {
-      if (path) {
-        (outputs || (outputs = [])).push(path);
-      }
-    }
-    function getOutputs() {
-      return outputs || emptyArray;
-    }
-  }
-  function getSingleOutputFileNames(configFile, addOutput) {
-    const { jsFilePath, sourceMapFilePath, declarationFilePath, declarationMapPath, buildInfoPath } = getOutputPathsForBundle(
-      configFile.options,
-      /*forceDtsPaths*/
-      false
-    );
-    addOutput(jsFilePath);
-    addOutput(sourceMapFilePath);
-    addOutput(declarationFilePath);
-    addOutput(declarationMapPath);
-    addOutput(buildInfoPath);
-  }
-  function getOwnOutputFileNames(configFile, inputFileName, ignoreCase, addOutput, getCommonSourceDirectory2) {
-    if (isDeclarationFileName(inputFileName))
-      return;
-    const js = getOutputJSFileName(inputFileName, configFile, ignoreCase, getCommonSourceDirectory2);
-    addOutput(js);
-    if (fileExtensionIs(inputFileName, ".json" /* Json */))
-      return;
-    if (js && configFile.options.sourceMap) {
-      addOutput(`${js}.map`);
-    }
-    if (getEmitDeclarations(configFile.options)) {
-      const dts = getOutputDeclarationFileName(inputFileName, configFile, ignoreCase, getCommonSourceDirectory2);
-      addOutput(dts);
-      if (configFile.options.declarationMap) {
-        addOutput(`${dts}.map`);
-      }
-    }
-  }
-  function getCommonSourceDirectory(options, emittedFiles, currentDirectory, getCanonicalFileName, checkSourceFilesBelongToPath) {
-    let commonSourceDirectory;
-    if (options.rootDir) {
-      commonSourceDirectory = getNormalizedAbsolutePath(options.rootDir, currentDirectory);
-      checkSourceFilesBelongToPath == null ? void 0 : checkSourceFilesBelongToPath(options.rootDir);
-    } else if (options.composite && options.configFilePath) {
-      commonSourceDirectory = getDirectoryPath(normalizeSlashes(options.configFilePath));
-      checkSourceFilesBelongToPath == null ? void 0 : checkSourceFilesBelongToPath(commonSourceDirectory);
-    } else {
-      commonSourceDirectory = computeCommonSourceDirectoryOfFilenames(emittedFiles(), currentDirectory, getCanonicalFileName);
-    }
-    if (commonSourceDirectory && commonSourceDirectory[commonSourceDirectory.length - 1] !== directorySeparator) {
-      commonSourceDirectory += directorySeparator;
-    }
-    return commonSourceDirectory;
-  }
-  function getCommonSourceDirectoryOfConfig({ options, fileNames }, ignoreCase) {
-    return getCommonSourceDirectory(
-      options,
-      () => filter(fileNames, (file) => !(options.noEmitForJsFiles && fileExtensionIsOneOf(file, supportedJSExtensionsFlat)) && !isDeclarationFileName(file)),
-      getDirectoryPath(normalizeSlashes(Debug.checkDefined(options.configFilePath))),
-      createGetCanonicalFileName(!ignoreCase)
-    );
-  }
-  function getAllProjectOutputs(configFile, ignoreCase) {
-    const { addOutput, getOutputs } = createAddOutput();
-    if (outFile(configFile.options)) {
-      getSingleOutputFileNames(configFile, addOutput);
-    } else {
-      const getCommonSourceDirectory2 = memoize(() => getCommonSourceDirectoryOfConfig(configFile, ignoreCase));
-      for (const inputFileName of configFile.fileNames) {
-        getOwnOutputFileNames(configFile, inputFileName, ignoreCase, addOutput, getCommonSourceDirectory2);
-      }
-      addOutput(getTsBuildInfoEmitOutputFilePath(configFile.options));
-    }
-    return getOutputs();
-  }
-  function getOutputFileNames(commandLine, inputFileName, ignoreCase) {
-    inputFileName = normalizePath(inputFileName);
-    Debug.assert(contains(commandLine.fileNames, inputFileName), `Expected fileName to be present in command line`);
-    const { addOutput, getOutputs } = createAddOutput();
-    if (outFile(commandLine.options)) {
-      getSingleOutputFileNames(commandLine, addOutput);
-    } else {
-      getOwnOutputFileNames(commandLine, inputFileName, ignoreCase, addOutput);
-    }
-    return getOutputs();
-  }
-  function getFirstProjectOutput(configFile, ignoreCase) {
-    if (outFile(configFile.options)) {
-      const { jsFilePath, declarationFilePath } = getOutputPathsForBundle(
-        configFile.options,
-        /*forceDtsPaths*/
-        false
-      );
-      return Debug.checkDefined(jsFilePath || declarationFilePath, `project ${configFile.options.configFilePath} expected to have at least one output`);
-    }
-    const getCommonSourceDirectory2 = memoize(() => getCommonSourceDirectoryOfConfig(configFile, ignoreCase));
-    for (const inputFileName of configFile.fileNames) {
-      if (isDeclarationFileName(inputFileName))
-        continue;
-      const jsFilePath = getOutputJSFileName(inputFileName, configFile, ignoreCase, getCommonSourceDirectory2);
-      if (jsFilePath)
-        return jsFilePath;
-      if (fileExtensionIs(inputFileName, ".json" /* Json */))
-        continue;
-      if (getEmitDeclarations(configFile.options)) {
-        return getOutputDeclarationFileName(inputFileName, configFile, ignoreCase, getCommonSourceDirectory2);
-      }
-    }
-    const buildInfoPath = getTsBuildInfoEmitOutputFilePath(configFile.options);
-    if (buildInfoPath)
-      return buildInfoPath;
-    return Debug.fail(`project ${configFile.options.configFilePath} expected to have at least one output`);
-  }
-  function emitFiles(resolver, host, targetSourceFile, { scriptTransformers, declarationTransformers }, emitOnly, onlyBuildInfo, forceDtsEmit) {
-    var compilerOptions = host.getCompilerOptions();
-    var sourceMapDataList = compilerOptions.sourceMap || compilerOptions.inlineSourceMap || getAreDeclarationMapsEnabled(compilerOptions) ? [] : void 0;
-    var emittedFilesList = compilerOptions.listEmittedFiles ? [] : void 0;
-    var emitterDiagnostics = createDiagnosticCollection();
-    var newLine = getNewLineCharacter(compilerOptions);
-    var writer = createTextWriter(newLine);
-    var { enter, exit } = createTimer("printTime", "beforePrint", "afterPrint");
-    var bundleBuildInfo;
-    var emitSkipped = false;
-    enter();
-    forEachEmittedFile(
-      host,
-      emitSourceFileOrBundle,
-      getSourceFilesToEmit(host, targetSourceFile, forceDtsEmit),
-      forceDtsEmit,
-      onlyBuildInfo,
-      !targetSourceFile
-    );
-    exit();
-    return {
-      emitSkipped,
-      diagnostics: emitterDiagnostics.getDiagnostics(),
-      emittedFiles: emittedFilesList,
-      sourceMaps: sourceMapDataList
-    };
-    function emitSourceFileOrBundle({ jsFilePath, sourceMapFilePath, declarationFilePath, declarationMapPath, buildInfoPath }, sourceFileOrBundle) {
-      var _a, _b, _c, _d, _e, _f;
-      let buildInfoDirectory;
-      if (buildInfoPath && sourceFileOrBundle && isBundle(sourceFileOrBundle)) {
-        buildInfoDirectory = getDirectoryPath(getNormalizedAbsolutePath(buildInfoPath, host.getCurrentDirectory()));
-        bundleBuildInfo = {
-          commonSourceDirectory: relativeToBuildInfo(host.getCommonSourceDirectory()),
-          sourceFiles: sourceFileOrBundle.sourceFiles.map((file) => relativeToBuildInfo(getNormalizedAbsolutePath(file.fileName, host.getCurrentDirectory())))
-        };
-      }
-      (_a = tracing) == null ? void 0 : _a.push(tracing.Phase.Emit, "emitJsFileOrBundle", { jsFilePath });
-      emitJsFileOrBundle(sourceFileOrBundle, jsFilePath, sourceMapFilePath, relativeToBuildInfo);
-      (_b = tracing) == null ? void 0 : _b.pop();
-      (_c = tracing) == null ? void 0 : _c.push(tracing.Phase.Emit, "emitDeclarationFileOrBundle", { declarationFilePath });
-      emitDeclarationFileOrBundle(sourceFileOrBundle, declarationFilePath, declarationMapPath, relativeToBuildInfo);
-      (_d = tracing) == null ? void 0 : _d.pop();
-      (_e = tracing) == null ? void 0 : _e.push(tracing.Phase.Emit, "emitBuildInfo", { buildInfoPath });
-      emitBuildInfo(bundleBuildInfo, buildInfoPath);
-      (_f = tracing) == null ? void 0 : _f.pop();
-      if (!emitSkipped && emittedFilesList) {
-        if (!emitOnly) {
-          if (jsFilePath) {
-            emittedFilesList.push(jsFilePath);
-          }
-          if (sourceMapFilePath) {
-            emittedFilesList.push(sourceMapFilePath);
-          }
-          if (buildInfoPath) {
-            emittedFilesList.push(buildInfoPath);
-          }
-        }
-        if (emitOnly !== 0 /* Js */) {
-          if (declarationFilePath) {
-            emittedFilesList.push(declarationFilePath);
-          }
-          if (declarationMapPath) {
-            emittedFilesList.push(declarationMapPath);
-          }
-        }
-      }
-      function relativeToBuildInfo(path) {
-        return ensurePathIsNonModuleName(getRelativePathFromDirectory(buildInfoDirectory, path, host.getCanonicalFileName));
-      }
-    }
-    function emitBuildInfo(bundle, buildInfoPath) {
-      if (!buildInfoPath || targetSourceFile || emitSkipped)
-        return;
-      if (host.isEmitBlocked(buildInfoPath)) {
-        emitSkipped = true;
-        return;
-      }
-      const buildInfo = host.getBuildInfo(bundle) || createBuildInfo(
-        /*program*/
-        void 0,
-        bundle
-      );
-      writeFile(
-        host,
-        emitterDiagnostics,
-        buildInfoPath,
-        getBuildInfoText(buildInfo),
-        /*writeByteOrderMark*/
-        false,
-        /*sourceFiles*/
-        void 0,
-        { buildInfo }
-      );
-    }
-    function emitJsFileOrBundle(sourceFileOrBundle, jsFilePath, sourceMapFilePath, relativeToBuildInfo) {
-      if (!sourceFileOrBundle || emitOnly || !jsFilePath) {
-        return;
-      }
-      if (host.isEmitBlocked(jsFilePath) || compilerOptions.noEmit) {
-        emitSkipped = true;
-        return;
-      }
-      const transform2 = transformNodes(
-        resolver,
-        host,
-        factory,
-        compilerOptions,
-        [sourceFileOrBundle],
-        scriptTransformers,
-        /*allowDtsFiles*/
-        false
-      );
-      const printerOptions = {
-        removeComments: compilerOptions.removeComments,
-        newLine: compilerOptions.newLine,
-        noEmitHelpers: compilerOptions.noEmitHelpers,
-        module: compilerOptions.module,
-        target: compilerOptions.target,
-        sourceMap: compilerOptions.sourceMap,
-        inlineSourceMap: compilerOptions.inlineSourceMap,
-        inlineSources: compilerOptions.inlineSources,
-        extendedDiagnostics: compilerOptions.extendedDiagnostics,
-        writeBundleFileInfo: !!bundleBuildInfo,
-        relativeToBuildInfo
-      };
-      const printer = createPrinter(printerOptions, {
-        // resolver hooks
-        hasGlobalName: resolver.hasGlobalName,
-        // transform hooks
-        onEmitNode: transform2.emitNodeWithNotification,
-        isEmitNotificationEnabled: transform2.isEmitNotificationEnabled,
-        substituteNode: transform2.substituteNode
-      });
-      Debug.assert(transform2.transformed.length === 1, "Should only see one output from the transform");
-      printSourceFileOrBundle(jsFilePath, sourceMapFilePath, transform2, printer, compilerOptions);
-      transform2.dispose();
-      if (bundleBuildInfo)
-        bundleBuildInfo.js = printer.bundleFileInfo;
-    }
-    function emitDeclarationFileOrBundle(sourceFileOrBundle, declarationFilePath, declarationMapPath, relativeToBuildInfo) {
-      if (!sourceFileOrBundle || emitOnly === 0 /* Js */)
-        return;
-      if (!declarationFilePath) {
-        if (emitOnly || compilerOptions.emitDeclarationOnly)
-          emitSkipped = true;
-        return;
-      }
-      const sourceFiles = isSourceFile(sourceFileOrBundle) ? [sourceFileOrBundle] : sourceFileOrBundle.sourceFiles;
-      const filesForEmit = forceDtsEmit ? sourceFiles : filter(sourceFiles, isSourceFileNotJson);
-      const inputListOrBundle = outFile(compilerOptions) ? [factory.createBundle(filesForEmit, !isSourceFile(sourceFileOrBundle) ? sourceFileOrBundle.prepends : void 0)] : filesForEmit;
-      if (emitOnly && !getEmitDeclarations(compilerOptions)) {
-        filesForEmit.forEach(collectLinkedAliases);
-      }
-      const declarationTransform = transformNodes(
-        resolver,
-        host,
-        factory,
-        compilerOptions,
-        inputListOrBundle,
-        declarationTransformers,
-        /*allowDtsFiles*/
-        false
-      );
-      if (length(declarationTransform.diagnostics)) {
-        for (const diagnostic of declarationTransform.diagnostics) {
-          emitterDiagnostics.add(diagnostic);
-        }
-      }
-      const printerOptions = {
-        removeComments: compilerOptions.removeComments,
-        newLine: compilerOptions.newLine,
-        noEmitHelpers: true,
-        module: compilerOptions.module,
-        target: compilerOptions.target,
-        sourceMap: !forceDtsEmit && compilerOptions.declarationMap,
-        inlineSourceMap: compilerOptions.inlineSourceMap,
-        extendedDiagnostics: compilerOptions.extendedDiagnostics,
-        onlyPrintJsDocStyle: true,
-        writeBundleFileInfo: !!bundleBuildInfo,
-        recordInternalSection: !!bundleBuildInfo,
-        relativeToBuildInfo
-      };
-      const declarationPrinter = createPrinter(printerOptions, {
-        // resolver hooks
-        hasGlobalName: resolver.hasGlobalName,
-        // transform hooks
-        onEmitNode: declarationTransform.emitNodeWithNotification,
-        isEmitNotificationEnabled: declarationTransform.isEmitNotificationEnabled,
-        substituteNode: declarationTransform.substituteNode
-      });
-      const declBlocked = !!declarationTransform.diagnostics && !!declarationTransform.diagnostics.length || !!host.isEmitBlocked(declarationFilePath) || !!compilerOptions.noEmit;
-      emitSkipped = emitSkipped || declBlocked;
-      if (!declBlocked || forceDtsEmit) {
-        Debug.assert(declarationTransform.transformed.length === 1, "Should only see one output from the decl transform");
-        printSourceFileOrBundle(
-          declarationFilePath,
-          declarationMapPath,
-          declarationTransform,
-          declarationPrinter,
-          {
-            sourceMap: printerOptions.sourceMap,
-            sourceRoot: compilerOptions.sourceRoot,
-            mapRoot: compilerOptions.mapRoot,
-            extendedDiagnostics: compilerOptions.extendedDiagnostics
-            // Explicitly do not passthru either `inline` option
-          }
-        );
-      }
-      declarationTransform.dispose();
-      if (bundleBuildInfo)
-        bundleBuildInfo.dts = declarationPrinter.bundleFileInfo;
-    }
-    function collectLinkedAliases(node) {
-      if (isExportAssignment(node)) {
-        if (node.expression.kind === 80 /* Identifier */) {
-          resolver.collectLinkedAliases(
-            node.expression,
-            /*setVisibility*/
-            true
-          );
-        }
-        return;
-      } else if (isExportSpecifier(node)) {
-        resolver.collectLinkedAliases(
-          node.propertyName || node.name,
-          /*setVisibility*/
-          true
-        );
-        return;
-      }
-      forEachChild(node, collectLinkedAliases);
-    }
-    function printSourceFileOrBundle(jsFilePath, sourceMapFilePath, transform2, printer, mapOptions) {
-      const sourceFileOrBundle = transform2.transformed[0];
-      const bundle = sourceFileOrBundle.kind === 312 /* Bundle */ ? sourceFileOrBundle : void 0;
-      const sourceFile = sourceFileOrBundle.kind === 311 /* SourceFile */ ? sourceFileOrBundle : void 0;
-      const sourceFiles = bundle ? bundle.sourceFiles : [sourceFile];
-      let sourceMapGenerator;
-      if (shouldEmitSourceMaps(mapOptions, sourceFileOrBundle)) {
-        sourceMapGenerator = createSourceMapGenerator(
-          host,
-          getBaseFileName(normalizeSlashes(jsFilePath)),
-          getSourceRoot(mapOptions),
-          getSourceMapDirectory(mapOptions, jsFilePath, sourceFile),
-          mapOptions
-        );
-      }
-      if (bundle) {
-        printer.writeBundle(bundle, writer, sourceMapGenerator);
-      } else {
-        printer.writeFile(sourceFile, writer, sourceMapGenerator);
-      }
-      let sourceMapUrlPos;
-      if (sourceMapGenerator) {
-        if (sourceMapDataList) {
-          sourceMapDataList.push({
-            inputSourceFileNames: sourceMapGenerator.getSources(),
-            sourceMap: sourceMapGenerator.toJSON()
-          });
-        }
-        const sourceMappingURL = getSourceMappingURL(
-          mapOptions,
-          sourceMapGenerator,
-          jsFilePath,
-          sourceMapFilePath,
-          sourceFile
-        );
-        if (sourceMappingURL) {
-          if (!writer.isAtStartOfLine())
-            writer.rawWrite(newLine);
-          sourceMapUrlPos = writer.getTextPos();
-          writer.writeComment(`//# ${"sourceMappingURL"}=${sourceMappingURL}`);
-        }
-        if (sourceMapFilePath) {
-          const sourceMap = sourceMapGenerator.toString();
-          writeFile(
-            host,
-            emitterDiagnostics,
-            sourceMapFilePath,
-            sourceMap,
-            /*writeByteOrderMark*/
-            false,
-            sourceFiles
-          );
-          if (printer.bundleFileInfo)
-            printer.bundleFileInfo.mapHash = computeSignature(sourceMap, host);
-        }
-      } else {
-        writer.writeLine();
-      }
-      const text = writer.getText();
-      writeFile(host, emitterDiagnostics, jsFilePath, text, !!compilerOptions.emitBOM, sourceFiles, { sourceMapUrlPos, diagnostics: transform2.diagnostics });
-      if (printer.bundleFileInfo)
-        printer.bundleFileInfo.hash = computeSignature(text, host);
-      writer.clear();
-    }
-    function shouldEmitSourceMaps(mapOptions, sourceFileOrBundle) {
-      return (mapOptions.sourceMap || mapOptions.inlineSourceMap) && (sourceFileOrBundle.kind !== 311 /* SourceFile */ || !fileExtensionIs(sourceFileOrBundle.fileName, ".json" /* Json */));
-    }
-    function getSourceRoot(mapOptions) {
-      const sourceRoot = normalizeSlashes(mapOptions.sourceRoot || "");
-      return sourceRoot ? ensureTrailingDirectorySeparator(sourceRoot) : sourceRoot;
-    }
-    function getSourceMapDirectory(mapOptions, filePath, sourceFile) {
-      if (mapOptions.sourceRoot)
-        return host.getCommonSourceDirectory();
-      if (mapOptions.mapRoot) {
-        let sourceMapDir = normalizeSlashes(mapOptions.mapRoot);
-        if (sourceFile) {
-          sourceMapDir = getDirectoryPath(getSourceFilePathInNewDir(sourceFile.fileName, host, sourceMapDir));
-        }
-        if (getRootLength(sourceMapDir) === 0) {
-          sourceMapDir = combinePaths(host.getCommonSourceDirectory(), sourceMapDir);
-        }
-        return sourceMapDir;
-      }
-      return getDirectoryPath(normalizePath(filePath));
-    }
-    function getSourceMappingURL(mapOptions, sourceMapGenerator, filePath, sourceMapFilePath, sourceFile) {
-      if (mapOptions.inlineSourceMap) {
-        const sourceMapText = sourceMapGenerator.toString();
-        const base64SourceMapText = base64encode(sys, sourceMapText);
-        return `data:application/json;base64,${base64SourceMapText}`;
-      }
-      const sourceMapFile = getBaseFileName(normalizeSlashes(Debug.checkDefined(sourceMapFilePath)));
-      if (mapOptions.mapRoot) {
-        let sourceMapDir = normalizeSlashes(mapOptions.mapRoot);
-        if (sourceFile) {
-          sourceMapDir = getDirectoryPath(getSourceFilePathInNewDir(sourceFile.fileName, host, sourceMapDir));
-        }
-        if (getRootLength(sourceMapDir) === 0) {
-          sourceMapDir = combinePaths(host.getCommonSourceDirectory(), sourceMapDir);
-          return encodeURI(
-            getRelativePathToDirectoryOrUrl(
-              getDirectoryPath(normalizePath(filePath)),
-              // get the relative sourceMapDir path based on jsFilePath
-              combinePaths(sourceMapDir, sourceMapFile),
-              // this is where user expects to see sourceMap
-              host.getCurrentDirectory(),
-              host.getCanonicalFileName,
-              /*isAbsolutePathAnUrl*/
-              true
-            )
-          );
-        } else {
-          return encodeURI(combinePaths(sourceMapDir, sourceMapFile));
-        }
-      }
-      return encodeURI(sourceMapFile);
-    }
-  }
-  function createBuildInfo(program, bundle) {
-    return { bundle, program, version };
-  }
-  function getBuildInfoText(buildInfo) {
-    return JSON.stringify(buildInfo);
-  }
-  function getBuildInfo(buildInfoFile, buildInfoText) {
-    return readJsonOrUndefined(buildInfoFile, buildInfoText);
-  }
-  function createSourceFilesFromBundleBuildInfo(bundle, buildInfoDirectory, host) {
-    var _a;
-    const jsBundle = Debug.checkDefined(bundle.js);
-    const prologueMap = ((_a = jsBundle.sources) == null ? void 0 : _a.prologues) && arrayToMap(jsBundle.sources.prologues, (prologueInfo) => prologueInfo.file);
-    return bundle.sourceFiles.map((fileName, index) => {
-      const prologueInfo = prologueMap == null ? void 0 : prologueMap.get(index);
-      const statements = prologueInfo == null ? void 0 : prologueInfo.directives.map((directive) => {
-        const literal = setTextRange(factory.createStringLiteral(directive.expression.text), directive.expression);
-        const statement = setTextRange(factory.createExpressionStatement(literal), directive);
-        setParent(literal, statement);
-        return statement;
-      });
-      const eofToken = factory.createToken(1 /* EndOfFileToken */);
-      const sourceFile = factory.createSourceFile(statements ?? [], eofToken, 0 /* None */);
-      sourceFile.fileName = getRelativePathFromDirectory(
-        host.getCurrentDirectory(),
-        getNormalizedAbsolutePath(fileName, buildInfoDirectory),
-        !host.useCaseSensitiveFileNames()
-      );
-      sourceFile.text = (prologueInfo == null ? void 0 : prologueInfo.text) ?? "";
-      setTextRangePosWidth(sourceFile, 0, (prologueInfo == null ? void 0 : prologueInfo.text.length) ?? 0);
-      setEachParent(sourceFile.statements, sourceFile);
-      setTextRangePosWidth(eofToken, sourceFile.end, 0);
-      setParent(eofToken, sourceFile);
-      return sourceFile;
-    });
-  }
-  function emitUsingBuildInfo(config, host, getCommandLine, customTransformers) {
-    var _a, _b;
-    (_a = tracing) == null ? void 0 : _a.push(
-      tracing.Phase.Emit,
-      "emitUsingBuildInfo",
-      {},
-      /*separateBeginAndEnd*/
-      true
-    );
-    mark("beforeEmit");
-    const result = emitUsingBuildInfoWorker(config, host, getCommandLine, customTransformers);
-    mark("afterEmit");
-    measure("Emit", "beforeEmit", "afterEmit");
-    (_b = tracing) == null ? void 0 : _b.pop();
-    return result;
-  }
-  function emitUsingBuildInfoWorker(config, host, getCommandLine, customTransformers) {
-    const { buildInfoPath, jsFilePath, sourceMapFilePath, declarationFilePath, declarationMapPath } = getOutputPathsForBundle(
-      config.options,
-      /*forceDtsPaths*/
-      false
-    );
-    const buildInfo = host.getBuildInfo(buildInfoPath, config.options.configFilePath);
-    if (!buildInfo)
-      return buildInfoPath;
-    if (!buildInfo.bundle || !buildInfo.bundle.js || declarationFilePath && !buildInfo.bundle.dts)
-      return buildInfoPath;
-    const jsFileText = host.readFile(Debug.checkDefined(jsFilePath));
-    if (!jsFileText)
-      return jsFilePath;
-    if (computeSignature(jsFileText, host) !== buildInfo.bundle.js.hash)
-      return jsFilePath;
-    const sourceMapText = sourceMapFilePath && host.readFile(sourceMapFilePath);
-    if (sourceMapFilePath && !sourceMapText || config.options.inlineSourceMap)
-      return sourceMapFilePath || "inline sourcemap decoding";
-    if (sourceMapFilePath && computeSignature(sourceMapText, host) !== buildInfo.bundle.js.mapHash)
-      return sourceMapFilePath;
-    const declarationText = declarationFilePath && host.readFile(declarationFilePath);
-    if (declarationFilePath && !declarationText)
-      return declarationFilePath;
-    if (declarationFilePath && computeSignature(declarationText, host) !== buildInfo.bundle.dts.hash)
-      return declarationFilePath;
-    const declarationMapText = declarationMapPath && host.readFile(declarationMapPath);
-    if (declarationMapPath && !declarationMapText || config.options.inlineSourceMap)
-      return declarationMapPath || "inline sourcemap decoding";
-    if (declarationMapPath && computeSignature(declarationMapText, host) !== buildInfo.bundle.dts.mapHash)
-      return declarationMapPath;
-    const buildInfoDirectory = getDirectoryPath(getNormalizedAbsolutePath(buildInfoPath, host.getCurrentDirectory()));
-    const ownPrependInput = createInputFilesWithFileTexts(
-      jsFilePath,
-      jsFileText,
-      sourceMapFilePath,
-      sourceMapText,
-      declarationFilePath,
-      declarationText,
-      declarationMapPath,
-      declarationMapText,
-      buildInfoPath,
-      buildInfo,
-      /*oldFileOfCurrentEmit*/
-      true
-    );
-    const outputFiles = [];
-    const prependNodes = createPrependNodes(config.projectReferences, getCommandLine, (f) => host.readFile(f), host);
-    const sourceFilesForJsEmit = createSourceFilesFromBundleBuildInfo(buildInfo.bundle, buildInfoDirectory, host);
-    let changedDtsText;
-    let changedDtsData;
-    const emitHost = {
-      getPrependNodes: memoize(() => [...prependNodes, ownPrependInput]),
-      getCanonicalFileName: host.getCanonicalFileName,
-      getCommonSourceDirectory: () => getNormalizedAbsolutePath(buildInfo.bundle.commonSourceDirectory, buildInfoDirectory),
-      getCompilerOptions: () => config.options,
-      getCurrentDirectory: () => host.getCurrentDirectory(),
-      getSourceFile: returnUndefined,
-      getSourceFileByPath: returnUndefined,
-      getSourceFiles: () => sourceFilesForJsEmit,
-      getLibFileFromReference: notImplemented,
-      isSourceFileFromExternalLibrary: returnFalse,
-      getResolvedProjectReferenceToRedirect: returnUndefined,
-      getProjectReferenceRedirect: returnUndefined,
-      isSourceOfProjectReferenceRedirect: returnFalse,
-      writeFile: (name, text, writeByteOrderMark, _onError, _sourceFiles, data) => {
-        switch (name) {
-          case jsFilePath:
-            if (jsFileText === text)
-              return;
-            break;
-          case sourceMapFilePath:
-            if (sourceMapText === text)
-              return;
-            break;
-          case buildInfoPath:
-            break;
-          case declarationFilePath:
-            if (declarationText === text)
-              return;
-            changedDtsText = text;
-            changedDtsData = data;
-            break;
-          case declarationMapPath:
-            if (declarationMapText === text)
-              return;
-            break;
-          default:
-            Debug.fail(`Unexpected path: ${name}`);
-        }
-        outputFiles.push({ name, text, writeByteOrderMark, data });
-      },
-      isEmitBlocked: returnFalse,
-      readFile: (f) => host.readFile(f),
-      fileExists: (f) => host.fileExists(f),
-      useCaseSensitiveFileNames: () => host.useCaseSensitiveFileNames(),
-      getBuildInfo: (bundle) => {
-        const program = buildInfo.program;
-        if (program && changedDtsText !== void 0 && config.options.composite) {
-          program.outSignature = computeSignature(changedDtsText, host, changedDtsData);
-        }
-        const { js, dts, sourceFiles } = buildInfo.bundle;
-        bundle.js.sources = js.sources;
-        if (dts) {
-          bundle.dts.sources = dts.sources;
-        }
-        bundle.sourceFiles = sourceFiles;
-        return createBuildInfo(program, bundle);
-      },
-      getSourceFileFromReference: returnUndefined,
-      redirectTargetsMap: createMultiMap(),
-      getFileIncludeReasons: notImplemented,
-      createHash: maybeBind(host, host.createHash)
-    };
-    emitFiles(
-      notImplementedResolver,
-      emitHost,
-      /*targetSourceFile*/
-      void 0,
-      getTransformers(config.options, customTransformers)
-    );
-    return outputFiles;
-  }
-  function createPrinter(printerOptions = {}, handlers = {}) {
-    var {
-      hasGlobalName,
-      onEmitNode = noEmitNotification,
-      isEmitNotificationEnabled,
-      substituteNode = noEmitSubstitution,
-      onBeforeEmitNode,
-      onAfterEmitNode,
-      onBeforeEmitNodeArray,
-      onAfterEmitNodeArray,
-      onBeforeEmitToken,
-      onAfterEmitToken
-    } = handlers;
-    var extendedDiagnostics = !!printerOptions.extendedDiagnostics;
-    var newLine = getNewLineCharacter(printerOptions);
-    var moduleKind = getEmitModuleKind(printerOptions);
-    var bundledHelpers = /* @__PURE__ */ new Map();
-    var currentSourceFile;
-    var nodeIdToGeneratedName;
-    var nodeIdToGeneratedPrivateName;
-    var autoGeneratedIdToGeneratedName;
-    var generatedNames;
-    var formattedNameTempFlagsStack;
-    var formattedNameTempFlags;
-    var privateNameTempFlagsStack;
-    var privateNameTempFlags;
-    var tempFlagsStack;
-    var tempFlags;
-    var reservedNamesStack;
-    var reservedNames;
-    var reservedPrivateNamesStack;
-    var reservedPrivateNames;
-    var preserveSourceNewlines = printerOptions.preserveSourceNewlines;
-    var nextListElementPos;
-    var writer;
-    var ownWriter;
-    var write = writeBase;
-    var isOwnFileEmit;
-    var bundleFileInfo = printerOptions.writeBundleFileInfo ? { sections: [] } : void 0;
-    var relativeToBuildInfo = bundleFileInfo ? Debug.checkDefined(printerOptions.relativeToBuildInfo) : void 0;
-    var recordInternalSection = printerOptions.recordInternalSection;
-    var sourceFileTextPos = 0;
-    var sourceFileTextKind = "text" /* Text */;
-    var sourceMapsDisabled = true;
-    var sourceMapGenerator;
-    var sourceMapSource;
-    var sourceMapSourceIndex = -1;
-    var mostRecentlyAddedSourceMapSource;
-    var mostRecentlyAddedSourceMapSourceIndex = -1;
-    var containerPos = -1;
-    var containerEnd = -1;
-    var declarationListContainerEnd = -1;
-    var currentLineMap;
-    var detachedCommentsInfo;
-    var hasWrittenComment = false;
-    var commentsDisabled = !!printerOptions.removeComments;
-    var lastSubstitution;
-    var currentParenthesizerRule;
-    var { enter: enterComment, exit: exitComment } = createTimerIf(extendedDiagnostics, "commentTime", "beforeComment", "afterComment");
-    var parenthesizer = factory.parenthesizer;
-    var typeArgumentParenthesizerRuleSelector = {
-      select: (index) => index === 0 ? parenthesizer.parenthesizeLeadingTypeArgument : void 0
-    };
-    var emitBinaryExpression = createEmitBinaryExpression();
-    reset2();
-    return {
-      // public API
-      printNode,
-      printList,
-      printFile,
-      printBundle,
-      // internal API
-      writeNode,
-      writeList,
-      writeFile: writeFile2,
-      writeBundle,
-      bundleFileInfo
-    };
-    function printNode(hint, node, sourceFile) {
-      switch (hint) {
-        case 0 /* SourceFile */:
-          Debug.assert(isSourceFile(node), "Expected a SourceFile node.");
-          break;
-        case 2 /* IdentifierName */:
-          Debug.assert(isIdentifier(node), "Expected an Identifier node.");
-          break;
-        case 1 /* Expression */:
-          Debug.assert(isExpression(node), "Expected an Expression node.");
-          break;
-      }
-      switch (node.kind) {
-        case 311 /* SourceFile */:
-          return printFile(node);
-        case 312 /* Bundle */:
-          return printBundle(node);
-        case 313 /* UnparsedSource */:
-          return printUnparsedSource(node);
-      }
-      writeNode(hint, node, sourceFile, beginPrint());
-      return endPrint();
-    }
-    function printList(format, nodes, sourceFile) {
-      writeList(format, nodes, sourceFile, beginPrint());
-      return endPrint();
-    }
-    function printBundle(bundle) {
-      writeBundle(
-        bundle,
-        beginPrint(),
-        /*sourceMapGenerator*/
-        void 0
-      );
-      return endPrint();
-    }
-    function printFile(sourceFile) {
-      writeFile2(
-        sourceFile,
-        beginPrint(),
-        /*sourceMapGenerator*/
-        void 0
-      );
-      return endPrint();
-    }
-    function printUnparsedSource(unparsed) {
-      writeUnparsedSource(unparsed, beginPrint());
-      return endPrint();
-    }
-    function writeNode(hint, node, sourceFile, output) {
-      const previousWriter = writer;
-      setWriter(
-        output,
-        /*_sourceMapGenerator*/
-        void 0
-      );
-      print(hint, node, sourceFile);
-      reset2();
-      writer = previousWriter;
-    }
-    function writeList(format, nodes, sourceFile, output) {
-      const previousWriter = writer;
-      setWriter(
-        output,
-        /*_sourceMapGenerator*/
-        void 0
-      );
-      if (sourceFile) {
-        setSourceFile(sourceFile);
-      }
-      emitList(
-        /*parentNode*/
-        void 0,
-        nodes,
-        format
-      );
-      reset2();
-      writer = previousWriter;
-    }
-    function getTextPosWithWriteLine() {
-      return writer.getTextPosWithWriteLine ? writer.getTextPosWithWriteLine() : writer.getTextPos();
-    }
-    function updateOrPushBundleFileTextLike(pos, end, kind) {
-      const last2 = lastOrUndefined(bundleFileInfo.sections);
-      if (last2 && last2.kind === kind) {
-        last2.end = end;
-      } else {
-        bundleFileInfo.sections.push({ pos, end, kind });
-      }
-    }
-    function recordBundleFileInternalSectionStart(node) {
-      if (recordInternalSection && bundleFileInfo && currentSourceFile && (isDeclaration(node) || isVariableStatement(node)) && isInternalDeclaration(node, currentSourceFile) && sourceFileTextKind !== "internal" /* Internal */) {
-        const prevSourceFileTextKind = sourceFileTextKind;
-        recordBundleFileTextLikeSection(writer.getTextPos());
-        sourceFileTextPos = getTextPosWithWriteLine();
-        sourceFileTextKind = "internal" /* Internal */;
-        return prevSourceFileTextKind;
-      }
-      return void 0;
-    }
-    function recordBundleFileInternalSectionEnd(prevSourceFileTextKind) {
-      if (prevSourceFileTextKind) {
-        recordBundleFileTextLikeSection(writer.getTextPos());
-        sourceFileTextPos = getTextPosWithWriteLine();
-        sourceFileTextKind = prevSourceFileTextKind;
-      }
-    }
-    function recordBundleFileTextLikeSection(end) {
-      if (sourceFileTextPos < end) {
-        updateOrPushBundleFileTextLike(sourceFileTextPos, end, sourceFileTextKind);
-        return true;
-      }
-      return false;
-    }
-    function writeBundle(bundle, output, sourceMapGenerator2) {
-      isOwnFileEmit = false;
-      const previousWriter = writer;
-      setWriter(output, sourceMapGenerator2);
-      emitShebangIfNeeded(bundle);
-      emitPrologueDirectivesIfNeeded(bundle);
-      emitHelpers(bundle);
-      emitSyntheticTripleSlashReferencesIfNeeded(bundle);
-      for (const prepend of bundle.prepends) {
-        writeLine();
-        const pos = writer.getTextPos();
-        const savedSections = bundleFileInfo && bundleFileInfo.sections;
-        if (savedSections)
-          bundleFileInfo.sections = [];
-        print(
-          4 /* Unspecified */,
-          prepend,
-          /*sourceFile*/
-          void 0
-        );
-        if (bundleFileInfo) {
-          const newSections = bundleFileInfo.sections;
-          bundleFileInfo.sections = savedSections;
-          if (prepend.oldFileOfCurrentEmit)
-            bundleFileInfo.sections.push(...newSections);
-          else {
-            newSections.forEach((section) => Debug.assert(isBundleFileTextLike(section)));
-            bundleFileInfo.sections.push({
-              pos,
-              end: writer.getTextPos(),
-              kind: "prepend" /* Prepend */,
-              data: relativeToBuildInfo(prepend.fileName),
-              texts: newSections
-            });
-          }
-        }
-      }
-      sourceFileTextPos = getTextPosWithWriteLine();
-      for (const sourceFile of bundle.sourceFiles) {
-        print(0 /* SourceFile */, sourceFile, sourceFile);
-      }
-      if (bundleFileInfo && bundle.sourceFiles.length) {
-        const end = writer.getTextPos();
-        if (recordBundleFileTextLikeSection(end)) {
-          const prologues = getPrologueDirectivesFromBundledSourceFiles(bundle);
-          if (prologues) {
-            if (!bundleFileInfo.sources)
-              bundleFileInfo.sources = {};
-            bundleFileInfo.sources.prologues = prologues;
-          }
-          const helpers = getHelpersFromBundledSourceFiles(bundle);
-          if (helpers) {
-            if (!bundleFileInfo.sources)
-              bundleFileInfo.sources = {};
-            bundleFileInfo.sources.helpers = helpers;
-          }
-        }
-      }
-      reset2();
-      writer = previousWriter;
-    }
-    function writeUnparsedSource(unparsed, output) {
-      const previousWriter = writer;
-      setWriter(
-        output,
-        /*_sourceMapGenerator*/
-        void 0
-      );
-      print(
-        4 /* Unspecified */,
-        unparsed,
-        /*sourceFile*/
-        void 0
-      );
-      reset2();
-      writer = previousWriter;
-    }
-    function writeFile2(sourceFile, output, sourceMapGenerator2) {
-      isOwnFileEmit = true;
-      const previousWriter = writer;
-      setWriter(output, sourceMapGenerator2);
-      emitShebangIfNeeded(sourceFile);
-      emitPrologueDirectivesIfNeeded(sourceFile);
-      print(0 /* SourceFile */, sourceFile, sourceFile);
-      reset2();
-      writer = previousWriter;
-    }
-    function beginPrint() {
-      return ownWriter || (ownWriter = createTextWriter(newLine));
-    }
-    function endPrint() {
-      const text = ownWriter.getText();
-      ownWriter.clear();
-      return text;
-    }
-    function print(hint, node, sourceFile) {
-      if (sourceFile) {
-        setSourceFile(sourceFile);
-      }
-      pipelineEmit(
-        hint,
-        node,
-        /*parenthesizerRule*/
-        void 0
-      );
-    }
-    function setSourceFile(sourceFile) {
-      currentSourceFile = sourceFile;
-      currentLineMap = void 0;
-      detachedCommentsInfo = void 0;
-      if (sourceFile) {
-        setSourceMapSource(sourceFile);
-      }
-    }
-    function setWriter(_writer, _sourceMapGenerator) {
-      if (_writer && printerOptions.omitTrailingSemicolon) {
-        _writer = getTrailingSemicolonDeferringWriter(_writer);
-      }
-      writer = _writer;
-      sourceMapGenerator = _sourceMapGenerator;
-      sourceMapsDisabled = !writer || !sourceMapGenerator;
-    }
-    function reset2() {
-      nodeIdToGeneratedName = [];
-      nodeIdToGeneratedPrivateName = [];
-      autoGeneratedIdToGeneratedName = [];
-      generatedNames = /* @__PURE__ */ new Set();
-      formattedNameTempFlagsStack = [];
-      formattedNameTempFlags = /* @__PURE__ */ new Map();
-      privateNameTempFlagsStack = [];
-      privateNameTempFlags = 0 /* Auto */;
-      tempFlagsStack = [];
-      tempFlags = 0 /* Auto */;
-      reservedNamesStack = [];
-      reservedNames = void 0;
-      reservedPrivateNamesStack = [];
-      reservedPrivateNames = void 0;
-      currentSourceFile = void 0;
-      currentLineMap = void 0;
-      detachedCommentsInfo = void 0;
-      setWriter(
-        /*output*/
-        void 0,
-        /*_sourceMapGenerator*/
-        void 0
-      );
-    }
-    function getCurrentLineMap() {
-      return currentLineMap || (currentLineMap = getLineStarts(Debug.checkDefined(currentSourceFile)));
-    }
-    function emit(node, parenthesizerRule) {
-      if (node === void 0)
-        return;
-      const prevSourceFileTextKind = recordBundleFileInternalSectionStart(node);
-      pipelineEmit(4 /* Unspecified */, node, parenthesizerRule);
-      recordBundleFileInternalSectionEnd(prevSourceFileTextKind);
-    }
-    function emitIdentifierName(node) {
-      if (node === void 0)
-        return;
-      pipelineEmit(
-        2 /* IdentifierName */,
-        node,
-        /*parenthesizerRule*/
-        void 0
-      );
-    }
-    function emitExpression(node, parenthesizerRule) {
-      if (node === void 0)
-        return;
-      pipelineEmit(1 /* Expression */, node, parenthesizerRule);
-    }
-    function emitJsxAttributeValue(node) {
-      pipelineEmit(isStringLiteral(node) ? 6 /* JsxAttributeValue */ : 4 /* Unspecified */, node);
-    }
-    function beforeEmitNode(node) {
-      if (preserveSourceNewlines && getInternalEmitFlags(node) & 4 /* IgnoreSourceNewlines */) {
-        preserveSourceNewlines = false;
-      }
-    }
-    function afterEmitNode(savedPreserveSourceNewlines) {
-      preserveSourceNewlines = savedPreserveSourceNewlines;
-    }
-    function pipelineEmit(emitHint, node, parenthesizerRule) {
-      currentParenthesizerRule = parenthesizerRule;
-      const pipelinePhase = getPipelinePhase(0 /* Notification */, emitHint, node);
-      pipelinePhase(emitHint, node);
-      currentParenthesizerRule = void 0;
-    }
-    function shouldEmitComments(node) {
-      return !commentsDisabled && !isSourceFile(node);
-    }
-    function shouldEmitSourceMaps(node) {
-      return !sourceMapsDisabled && !isSourceFile(node) && !isInJsonFile(node) && !isUnparsedSource(node) && !isUnparsedPrepend(node);
-    }
-    function getPipelinePhase(phase, emitHint, node) {
-      switch (phase) {
-        case 0 /* Notification */:
-          if (onEmitNode !== noEmitNotification && (!isEmitNotificationEnabled || isEmitNotificationEnabled(node))) {
-            return pipelineEmitWithNotification;
-          }
-        case 1 /* Substitution */:
-          if (substituteNode !== noEmitSubstitution && (lastSubstitution = substituteNode(emitHint, node) || node) !== node) {
-            if (currentParenthesizerRule) {
-              lastSubstitution = currentParenthesizerRule(lastSubstitution);
-            }
-            return pipelineEmitWithSubstitution;
-          }
-        case 2 /* Comments */:
-          if (shouldEmitComments(node)) {
-            return pipelineEmitWithComments;
-          }
-        case 3 /* SourceMaps */:
-          if (shouldEmitSourceMaps(node)) {
-            return pipelineEmitWithSourceMaps;
-          }
-        case 4 /* Emit */:
-          return pipelineEmitWithHint;
-        default:
-          return Debug.assertNever(phase);
-      }
-    }
-    function getNextPipelinePhase(currentPhase, emitHint, node) {
-      return getPipelinePhase(currentPhase + 1, emitHint, node);
-    }
-    function pipelineEmitWithNotification(hint, node) {
-      const pipelinePhase = getNextPipelinePhase(0 /* Notification */, hint, node);
-      onEmitNode(hint, node, pipelinePhase);
-    }
-    function pipelineEmitWithHint(hint, node) {
-      onBeforeEmitNode == null ? void 0 : onBeforeEmitNode(node);
-      if (preserveSourceNewlines) {
-        const savedPreserveSourceNewlines = preserveSourceNewlines;
-        beforeEmitNode(node);
-        pipelineEmitWithHintWorker(hint, node);
-        afterEmitNode(savedPreserveSourceNewlines);
-      } else {
-        pipelineEmitWithHintWorker(hint, node);
-      }
-      onAfterEmitNode == null ? void 0 : onAfterEmitNode(node);
-      currentParenthesizerRule = void 0;
-    }
-    function pipelineEmitWithHintWorker(hint, node, allowSnippets = true) {
-      if (allowSnippets) {
-        const snippet = getSnippetElement(node);
-        if (snippet) {
-          return emitSnippetNode(hint, node, snippet);
-        }
-      }
-      if (hint === 0 /* SourceFile */)
-        return emitSourceFile(cast(node, isSourceFile));
-      if (hint === 2 /* IdentifierName */)
-        return emitIdentifier(cast(node, isIdentifier));
-      if (hint === 6 /* JsxAttributeValue */)
-        return emitLiteral(
-          cast(node, isStringLiteral),
-          /*jsxAttributeEscape*/
-          true
-        );
-      if (hint === 3 /* MappedTypeParameter */)
-        return emitMappedTypeParameter(cast(node, isTypeParameterDeclaration));
-      if (hint === 5 /* EmbeddedStatement */) {
-        Debug.assertNode(node, isEmptyStatement);
-        return emitEmptyStatement(
-          /*isEmbeddedStatement*/
-          true
-        );
-      }
-      if (hint === 4 /* Unspecified */) {
-        switch (node.kind) {
-          case 16 /* TemplateHead */:
-          case 17 /* TemplateMiddle */:
-          case 18 /* TemplateTail */:
-            return emitLiteral(
-              node,
-              /*jsxAttributeEscape*/
-              false
-            );
-          case 80 /* Identifier */:
-            return emitIdentifier(node);
-          case 81 /* PrivateIdentifier */:
-            return emitPrivateIdentifier(node);
-          case 165 /* QualifiedName */:
-            return emitQualifiedName(node);
-          case 166 /* ComputedPropertyName */:
-            return emitComputedPropertyName(node);
-          case 167 /* TypeParameter */:
-            return emitTypeParameter(node);
-          case 168 /* Parameter */:
-            return emitParameter(node);
-          case 169 /* Decorator */:
-            return emitDecorator(node);
-          case 170 /* PropertySignature */:
-            return emitPropertySignature(node);
-          case 171 /* PropertyDeclaration */:
-            return emitPropertyDeclaration(node);
-          case 172 /* MethodSignature */:
-            return emitMethodSignature(node);
-          case 173 /* MethodDeclaration */:
-            return emitMethodDeclaration(node);
-          case 174 /* ClassStaticBlockDeclaration */:
-            return emitClassStaticBlockDeclaration(node);
-          case 175 /* Constructor */:
-            return emitConstructor(node);
-          case 176 /* GetAccessor */:
-          case 177 /* SetAccessor */:
-            return emitAccessorDeclaration(node);
-          case 178 /* CallSignature */:
-            return emitCallSignature(node);
-          case 179 /* ConstructSignature */:
-            return emitConstructSignature(node);
-          case 180 /* IndexSignature */:
-            return emitIndexSignature(node);
-          case 181 /* TypePredicate */:
-            return emitTypePredicate(node);
-          case 182 /* TypeReference */:
-            return emitTypeReference(node);
-          case 183 /* FunctionType */:
-            return emitFunctionType(node);
-          case 184 /* ConstructorType */:
-            return emitConstructorType(node);
-          case 185 /* TypeQuery */:
-            return emitTypeQuery(node);
-          case 186 /* TypeLiteral */:
-            return emitTypeLiteral(node);
-          case 187 /* ArrayType */:
-            return emitArrayType(node);
-          case 188 /* TupleType */:
-            return emitTupleType(node);
-          case 189 /* OptionalType */:
-            return emitOptionalType(node);
-          case 191 /* UnionType */:
-            return emitUnionType(node);
-          case 192 /* IntersectionType */:
-            return emitIntersectionType(node);
-          case 193 /* ConditionalType */:
-            return emitConditionalType(node);
-          case 194 /* InferType */:
-            return emitInferType(node);
-          case 195 /* ParenthesizedType */:
-            return emitParenthesizedType(node);
-          case 232 /* ExpressionWithTypeArguments */:
-            return emitExpressionWithTypeArguments(node);
-          case 196 /* ThisType */:
-            return emitThisType();
-          case 197 /* TypeOperator */:
-            return emitTypeOperator(node);
-          case 198 /* IndexedAccessType */:
-            return emitIndexedAccessType(node);
-          case 199 /* MappedType */:
-            return emitMappedType(node);
-          case 200 /* LiteralType */:
-            return emitLiteralType(node);
-          case 201 /* NamedTupleMember */:
-            return emitNamedTupleMember(node);
-          case 202 /* TemplateLiteralType */:
-            return emitTemplateType(node);
-          case 203 /* TemplateLiteralTypeSpan */:
-            return emitTemplateTypeSpan(node);
-          case 204 /* ImportType */:
-            return emitImportTypeNode(node);
-          case 205 /* ObjectBindingPattern */:
-            return emitObjectBindingPattern(node);
-          case 206 /* ArrayBindingPattern */:
-            return emitArrayBindingPattern(node);
-          case 207 /* BindingElement */:
-            return emitBindingElement(node);
-          case 238 /* TemplateSpan */:
-            return emitTemplateSpan(node);
-          case 239 /* SemicolonClassElement */:
-            return emitSemicolonClassElement();
-          case 240 /* Block */:
-            return emitBlock(node);
-          case 242 /* VariableStatement */:
-            return emitVariableStatement(node);
-          case 241 /* EmptyStatement */:
-            return emitEmptyStatement(
-              /*isEmbeddedStatement*/
-              false
-            );
-          case 243 /* ExpressionStatement */:
-            return emitExpressionStatement(node);
-          case 244 /* IfStatement */:
-            return emitIfStatement(node);
-          case 245 /* DoStatement */:
-            return emitDoStatement(node);
-          case 246 /* WhileStatement */:
-            return emitWhileStatement(node);
-          case 247 /* ForStatement */:
-            return emitForStatement(node);
-          case 248 /* ForInStatement */:
-            return emitForInStatement(node);
-          case 249 /* ForOfStatement */:
-            return emitForOfStatement(node);
-          case 250 /* ContinueStatement */:
-            return emitContinueStatement(node);
-          case 251 /* BreakStatement */:
-            return emitBreakStatement(node);
-          case 252 /* ReturnStatement */:
-            return emitReturnStatement(node);
-          case 253 /* WithStatement */:
-            return emitWithStatement(node);
-          case 254 /* SwitchStatement */:
-            return emitSwitchStatement(node);
-          case 255 /* LabeledStatement */:
-            return emitLabeledStatement(node);
-          case 256 /* ThrowStatement */:
-            return emitThrowStatement(node);
-          case 257 /* TryStatement */:
-            return emitTryStatement(node);
-          case 258 /* DebuggerStatement */:
-            return emitDebuggerStatement(node);
-          case 259 /* VariableDeclaration */:
-            return emitVariableDeclaration(node);
-          case 260 /* VariableDeclarationList */:
-            return emitVariableDeclarationList(node);
-          case 261 /* FunctionDeclaration */:
-            return emitFunctionDeclaration(node);
-          case 262 /* ClassDeclaration */:
-            return emitClassDeclaration(node);
-          case 263 /* InterfaceDeclaration */:
-            return emitInterfaceDeclaration(node);
-          case 264 /* TypeAliasDeclaration */:
-            return emitTypeAliasDeclaration(node);
-          case 265 /* EnumDeclaration */:
-            return emitEnumDeclaration(node);
-          case 266 /* ModuleDeclaration */:
-            return emitModuleDeclaration(node);
-          case 267 /* ModuleBlock */:
-            return emitModuleBlock(node);
-          case 268 /* CaseBlock */:
-            return emitCaseBlock(node);
-          case 269 /* NamespaceExportDeclaration */:
-            return emitNamespaceExportDeclaration(node);
-          case 270 /* ImportEqualsDeclaration */:
-            return emitImportEqualsDeclaration(node);
-          case 271 /* ImportDeclaration */:
-            return emitImportDeclaration(node);
-          case 272 /* ImportClause */:
-            return emitImportClause(node);
-          case 273 /* NamespaceImport */:
-            return emitNamespaceImport(node);
-          case 279 /* NamespaceExport */:
-            return emitNamespaceExport(node);
-          case 274 /* NamedImports */:
-            return emitNamedImports(node);
-          case 275 /* ImportSpecifier */:
-            return emitImportSpecifier(node);
-          case 276 /* ExportAssignment */:
-            return emitExportAssignment(node);
-          case 277 /* ExportDeclaration */:
-            return emitExportDeclaration(node);
-          case 278 /* NamedExports */:
-            return emitNamedExports(node);
-          case 280 /* ExportSpecifier */:
-            return emitExportSpecifier(node);
-          case 299 /* AssertClause */:
-            return emitAssertClause(node);
-          case 300 /* AssertEntry */:
-            return emitAssertEntry(node);
-          case 281 /* MissingDeclaration */:
-            return;
-          case 282 /* ExternalModuleReference */:
-            return emitExternalModuleReference(node);
-          case 12 /* JsxText */:
-            return emitJsxText(node);
-          case 285 /* JsxOpeningElement */:
-          case 288 /* JsxOpeningFragment */:
-            return emitJsxOpeningElementOrFragment(node);
-          case 286 /* JsxClosingElement */:
-          case 289 /* JsxClosingFragment */:
-            return emitJsxClosingElementOrFragment(node);
-          case 290 /* JsxAttribute */:
-            return emitJsxAttribute(node);
-          case 291 /* JsxAttributes */:
-            return emitJsxAttributes(node);
-          case 292 /* JsxSpreadAttribute */:
-            return emitJsxSpreadAttribute(node);
-          case 293 /* JsxExpression */:
-            return emitJsxExpression(node);
-          case 294 /* JsxNamespacedName */:
-            return emitJsxNamespacedName(node);
-          case 295 /* CaseClause */:
-            return emitCaseClause(node);
-          case 296 /* DefaultClause */:
-            return emitDefaultClause(node);
-          case 297 /* HeritageClause */:
-            return emitHeritageClause(node);
-          case 298 /* CatchClause */:
-            return emitCatchClause(node);
-          case 302 /* PropertyAssignment */:
-            return emitPropertyAssignment(node);
-          case 303 /* ShorthandPropertyAssignment */:
-            return emitShorthandPropertyAssignment(node);
-          case 304 /* SpreadAssignment */:
-            return emitSpreadAssignment(node);
-          case 305 /* EnumMember */:
-            return emitEnumMember(node);
-          case 306 /* UnparsedPrologue */:
-            return writeUnparsedNode(node);
-          case 313 /* UnparsedSource */:
-          case 307 /* UnparsedPrepend */:
-            return emitUnparsedSourceOrPrepend(node);
-          case 308 /* UnparsedText */:
-          case 309 /* UnparsedInternalText */:
-            return emitUnparsedTextLike(node);
-          case 310 /* UnparsedSyntheticReference */:
-            return emitUnparsedSyntheticReference(node);
-          case 311 /* SourceFile */:
-            return emitSourceFile(node);
-          case 312 /* Bundle */:
-            return Debug.fail("Bundles should be printed using printBundle");
-          case 314 /* InputFiles */:
-            return Debug.fail("InputFiles should not be printed");
-          case 315 /* JSDocTypeExpression */:
-            return emitJSDocTypeExpression(node);
-          case 316 /* JSDocNameReference */:
-            return emitJSDocNameReference(node);
-          case 318 /* JSDocAllType */:
-            return writePunctuation("*");
-          case 319 /* JSDocUnknownType */:
-            return writePunctuation("?");
-          case 320 /* JSDocNullableType */:
-            return emitJSDocNullableType(node);
-          case 321 /* JSDocNonNullableType */:
-            return emitJSDocNonNullableType(node);
-          case 322 /* JSDocOptionalType */:
-            return emitJSDocOptionalType(node);
-          case 323 /* JSDocFunctionType */:
-            return emitJSDocFunctionType(node);
-          case 190 /* RestType */:
-          case 324 /* JSDocVariadicType */:
-            return emitRestOrJSDocVariadicType(node);
-          case 325 /* JSDocNamepathType */:
-            return;
-          case 326 /* JSDoc */:
-            return emitJSDoc(node);
-          case 328 /* JSDocTypeLiteral */:
-            return emitJSDocTypeLiteral(node);
-          case 329 /* JSDocSignature */:
-            return emitJSDocSignature(node);
-          case 333 /* JSDocTag */:
-          case 338 /* JSDocClassTag */:
-          case 343 /* JSDocOverrideTag */:
-            return emitJSDocSimpleTag(node);
-          case 334 /* JSDocAugmentsTag */:
-          case 335 /* JSDocImplementsTag */:
-            return emitJSDocHeritageTag(node);
-          case 336 /* JSDocAuthorTag */:
-          case 337 /* JSDocDeprecatedTag */:
-            return;
-          case 339 /* JSDocPublicTag */:
-          case 340 /* JSDocPrivateTag */:
-          case 341 /* JSDocProtectedTag */:
-          case 342 /* JSDocReadonlyTag */:
-            return;
-          case 344 /* JSDocCallbackTag */:
-            return emitJSDocCallbackTag(node);
-          case 345 /* JSDocOverloadTag */:
-            return emitJSDocOverloadTag(node);
-          case 347 /* JSDocParameterTag */:
-          case 354 /* JSDocPropertyTag */:
-            return emitJSDocPropertyLikeTag(node);
-          case 346 /* JSDocEnumTag */:
-          case 348 /* JSDocReturnTag */:
-          case 349 /* JSDocThisTag */:
-          case 350 /* JSDocTypeTag */:
-          case 355 /* JSDocThrowsTag */:
-          case 356 /* JSDocSatisfiesTag */:
-            return emitJSDocSimpleTypedTag(node);
-          case 351 /* JSDocTemplateTag */:
-            return emitJSDocTemplateTag(node);
-          case 352 /* JSDocTypedefTag */:
-            return emitJSDocTypedefTag(node);
-          case 353 /* JSDocSeeTag */:
-            return emitJSDocSeeTag(node);
-          case 358 /* NotEmittedStatement */:
-            return;
-        }
-        if (isExpression(node)) {
-          hint = 1 /* Expression */;
-          if (substituteNode !== noEmitSubstitution) {
-            const substitute = substituteNode(hint, node) || node;
-            if (substitute !== node) {
-              node = substitute;
-              if (currentParenthesizerRule) {
-                node = currentParenthesizerRule(node);
-              }
-            }
-          }
-        }
-      }
-      if (hint === 1 /* Expression */) {
-        switch (node.kind) {
-          case 9 /* NumericLiteral */:
-          case 10 /* BigIntLiteral */:
-            return emitNumericOrBigIntLiteral(node);
-          case 11 /* StringLiteral */:
-          case 14 /* RegularExpressionLiteral */:
-          case 15 /* NoSubstitutionTemplateLiteral */:
-            return emitLiteral(
-              node,
-              /*jsxAttributeEscape*/
-              false
-            );
-          case 80 /* Identifier */:
-            return emitIdentifier(node);
-          case 81 /* PrivateIdentifier */:
-            return emitPrivateIdentifier(node);
-          case 208 /* ArrayLiteralExpression */:
-            return emitArrayLiteralExpression(node);
-          case 209 /* ObjectLiteralExpression */:
-            return emitObjectLiteralExpression(node);
-          case 210 /* PropertyAccessExpression */:
-            return emitPropertyAccessExpression(node);
-          case 211 /* ElementAccessExpression */:
-            return emitElementAccessExpression(node);
-          case 212 /* CallExpression */:
-            return emitCallExpression(node);
-          case 213 /* NewExpression */:
-            return emitNewExpression(node);
-          case 214 /* TaggedTemplateExpression */:
-            return emitTaggedTemplateExpression(node);
-          case 215 /* TypeAssertionExpression */:
-            return emitTypeAssertionExpression(node);
-          case 216 /* ParenthesizedExpression */:
-            return emitParenthesizedExpression(node);
-          case 217 /* FunctionExpression */:
-            return emitFunctionExpression(node);
-          case 218 /* ArrowFunction */:
-            return emitArrowFunction(node);
-          case 219 /* DeleteExpression */:
-            return emitDeleteExpression(node);
-          case 220 /* TypeOfExpression */:
-            return emitTypeOfExpression(node);
-          case 221 /* VoidExpression */:
-            return emitVoidExpression(node);
-          case 222 /* AwaitExpression */:
-            return emitAwaitExpression(node);
-          case 223 /* PrefixUnaryExpression */:
-            return emitPrefixUnaryExpression(node);
-          case 224 /* PostfixUnaryExpression */:
-            return emitPostfixUnaryExpression(node);
-          case 225 /* BinaryExpression */:
-            return emitBinaryExpression(node);
-          case 226 /* ConditionalExpression */:
-            return emitConditionalExpression(node);
-          case 227 /* TemplateExpression */:
-            return emitTemplateExpression(node);
-          case 228 /* YieldExpression */:
-            return emitYieldExpression(node);
-          case 229 /* SpreadElement */:
-            return emitSpreadElement(node);
-          case 230 /* ClassExpression */:
-            return emitClassExpression(node);
-          case 231 /* OmittedExpression */:
-            return;
-          case 233 /* AsExpression */:
-            return emitAsExpression(node);
-          case 234 /* NonNullExpression */:
-            return emitNonNullExpression(node);
-          case 232 /* ExpressionWithTypeArguments */:
-            return emitExpressionWithTypeArguments(node);
-          case 237 /* SatisfiesExpression */:
-            return emitSatisfiesExpression(node);
-          case 235 /* MetaProperty */:
-            return emitMetaProperty(node);
-          case 236 /* SyntheticExpression */:
-            return Debug.fail("SyntheticExpression should never be printed.");
-          case 281 /* MissingDeclaration */:
-            return;
-          case 283 /* JsxElement */:
-            return emitJsxElement(node);
-          case 284 /* JsxSelfClosingElement */:
-            return emitJsxSelfClosingElement(node);
-          case 287 /* JsxFragment */:
-            return emitJsxFragment(node);
-          case 357 /* SyntaxList */:
-            return Debug.fail("SyntaxList should not be printed");
-          case 358 /* NotEmittedStatement */:
-            return;
-          case 359 /* PartiallyEmittedExpression */:
-            return emitPartiallyEmittedExpression(node);
-          case 360 /* CommaListExpression */:
-            return emitCommaList(node);
-          case 361 /* SyntheticReferenceExpression */:
-            return Debug.fail("SyntheticReferenceExpression should not be printed");
-        }
-      }
-      if (isKeyword(node.kind))
-        return writeTokenNode(node, writeKeyword);
-      if (isTokenKind(node.kind))
-        return writeTokenNode(node, writePunctuation);
-      Debug.fail(`Unhandled SyntaxKind: ${Debug.formatSyntaxKind(node.kind)}.`);
-    }
-    function emitMappedTypeParameter(node) {
-      emit(node.name);
-      writeSpace();
-      writeKeyword("in");
-      writeSpace();
-      emit(node.constraint);
-    }
-    function pipelineEmitWithSubstitution(hint, node) {
-      const pipelinePhase = getNextPipelinePhase(1 /* Substitution */, hint, node);
-      Debug.assertIsDefined(lastSubstitution);
-      node = lastSubstitution;
-      lastSubstitution = void 0;
-      pipelinePhase(hint, node);
-    }
-    function getHelpersFromBundledSourceFiles(bundle) {
-      let result;
-      if (moduleKind === 0 /* None */ || printerOptions.noEmitHelpers) {
-        return void 0;
-      }
-      const bundledHelpers2 = /* @__PURE__ */ new Map();
-      for (const sourceFile of bundle.sourceFiles) {
-        const shouldSkip = getExternalHelpersModuleName(sourceFile) !== void 0;
-        const helpers = getSortedEmitHelpers(sourceFile);
-        if (!helpers)
-          continue;
-        for (const helper of helpers) {
-          if (!helper.scoped && !shouldSkip && !bundledHelpers2.get(helper.name)) {
-            bundledHelpers2.set(helper.name, true);
-            (result || (result = [])).push(helper.name);
-          }
-        }
-      }
-      return result;
-    }
-    function emitHelpers(node) {
-      let helpersEmitted = false;
-      const bundle = node.kind === 312 /* Bundle */ ? node : void 0;
-      if (bundle && moduleKind === 0 /* None */) {
-        return;
-      }
-      const numPrepends = bundle ? bundle.prepends.length : 0;
-      const numNodes = bundle ? bundle.sourceFiles.length + numPrepends : 1;
-      for (let i = 0; i < numNodes; i++) {
-        const currentNode = bundle ? i < numPrepends ? bundle.prepends[i] : bundle.sourceFiles[i - numPrepends] : node;
-        const sourceFile = isSourceFile(currentNode) ? currentNode : isUnparsedSource(currentNode) ? void 0 : currentSourceFile;
-        const shouldSkip = printerOptions.noEmitHelpers || !!sourceFile && hasRecordedExternalHelpers(sourceFile);
-        const shouldBundle = (isSourceFile(currentNode) || isUnparsedSource(currentNode)) && !isOwnFileEmit;
-        const helpers = isUnparsedSource(currentNode) ? currentNode.helpers : getSortedEmitHelpers(currentNode);
-        if (helpers) {
-          for (const helper of helpers) {
-            if (!helper.scoped) {
-              if (shouldSkip)
-                continue;
-              if (shouldBundle) {
-                if (bundledHelpers.get(helper.name)) {
-                  continue;
-                }
-                bundledHelpers.set(helper.name, true);
-              }
-            } else if (bundle) {
-              continue;
-            }
-            const pos = getTextPosWithWriteLine();
-            if (typeof helper.text === "string") {
-              writeLines(helper.text);
-            } else {
-              writeLines(helper.text(makeFileLevelOptimisticUniqueName));
-            }
-            if (bundleFileInfo)
-              bundleFileInfo.sections.push({ pos, end: writer.getTextPos(), kind: "emitHelpers" /* EmitHelpers */, data: helper.name });
-            helpersEmitted = true;
-          }
-        }
-      }
-      return helpersEmitted;
-    }
-    function getSortedEmitHelpers(node) {
-      const helpers = getEmitHelpers(node);
-      return helpers && stableSort(helpers, compareEmitHelpers);
-    }
-    function emitNumericOrBigIntLiteral(node) {
-      emitLiteral(
-        node,
-        /*jsxAttributeEscape*/
-        false
-      );
-    }
-    function emitLiteral(node, jsxAttributeEscape) {
-      const text = getLiteralTextOfNode(node, printerOptions.neverAsciiEscape, jsxAttributeEscape);
-      if ((printerOptions.sourceMap || printerOptions.inlineSourceMap) && (node.kind === 11 /* StringLiteral */ || isTemplateLiteralKind(node.kind))) {
-        writeLiteral(text);
-      } else {
-        writeStringLiteral(text);
-      }
-    }
-    function emitUnparsedSourceOrPrepend(unparsed) {
-      for (const text of unparsed.texts) {
-        writeLine();
-        emit(text);
-      }
-    }
-    function writeUnparsedNode(unparsed) {
-      writer.rawWrite(unparsed.parent.text.substring(unparsed.pos, unparsed.end));
-    }
-    function emitUnparsedTextLike(unparsed) {
-      const pos = getTextPosWithWriteLine();
-      writeUnparsedNode(unparsed);
-      if (bundleFileInfo) {
-        updateOrPushBundleFileTextLike(
-          pos,
-          writer.getTextPos(),
-          unparsed.kind === 308 /* UnparsedText */ ? "text" /* Text */ : "internal" /* Internal */
-        );
-      }
-    }
-    function emitUnparsedSyntheticReference(unparsed) {
-      const pos = getTextPosWithWriteLine();
-      writeUnparsedNode(unparsed);
-      if (bundleFileInfo) {
-        const section = clone(unparsed.section);
-        section.pos = pos;
-        section.end = writer.getTextPos();
-        bundleFileInfo.sections.push(section);
-      }
-    }
-    function emitSnippetNode(hint, node, snippet) {
-      switch (snippet.kind) {
-        case 1 /* Placeholder */:
-          emitPlaceholder(hint, node, snippet);
-          break;
-        case 0 /* TabStop */:
-          emitTabStop(hint, node, snippet);
-          break;
-      }
-    }
-    function emitPlaceholder(hint, node, snippet) {
-      nonEscapingWrite(`\${${snippet.order}:`);
-      pipelineEmitWithHintWorker(
-        hint,
-        node,
-        /*allowSnippets*/
-        false
-      );
-      nonEscapingWrite(`}`);
-    }
-    function emitTabStop(hint, node, snippet) {
-      Debug.assert(
-        node.kind === 241 /* EmptyStatement */,
-        `A tab stop cannot be attached to a node of kind ${Debug.formatSyntaxKind(node.kind)}.`
-      );
-      Debug.assert(
-        hint !== 5 /* EmbeddedStatement */,
-        `A tab stop cannot be attached to an embedded statement.`
-      );
-      nonEscapingWrite(`$${snippet.order}`);
-    }
-    function emitIdentifier(node) {
-      const writeText = node.symbol ? writeSymbol : write;
-      writeText(getTextOfNode2(
-        node,
-        /*includeTrivia*/
-        false
-      ), node.symbol);
-      emitList(node, getIdentifierTypeArguments(node), 53776 /* TypeParameters */);
-    }
-    function emitPrivateIdentifier(node) {
-      write(getTextOfNode2(
-        node,
-        /*includeTrivia*/
-        false
-      ));
-    }
-    function emitQualifiedName(node) {
-      emitEntityName(node.left);
-      writePunctuation(".");
-      emit(node.right);
-    }
-    function emitEntityName(node) {
-      if (node.kind === 80 /* Identifier */) {
-        emitExpression(node);
-      } else {
-        emit(node);
-      }
-    }
-    function emitComputedPropertyName(node) {
-      const savedPrivateNameTempFlags = privateNameTempFlags;
-      const savedReservedMemberNames = reservedPrivateNames;
-      popPrivateNameGenerationScope();
-      writePunctuation("[");
-      emitExpression(node.expression, parenthesizer.parenthesizeExpressionOfComputedPropertyName);
-      writePunctuation("]");
-      pushPrivateNameGenerationScope(savedPrivateNameTempFlags, savedReservedMemberNames);
-    }
-    function emitTypeParameter(node) {
-      emitModifierList(node, node.modifiers);
-      emit(node.name);
-      if (node.constraint) {
-        writeSpace();
-        writeKeyword("extends");
-        writeSpace();
-        emit(node.constraint);
-      }
-      if (node.default) {
-        writeSpace();
-        writeOperator("=");
-        writeSpace();
-        emit(node.default);
-      }
-    }
-    function emitParameter(node) {
-      emitDecoratorsAndModifiers(
-        node,
-        node.modifiers,
-        /*allowDecorators*/
-        true
-      );
-      emit(node.dotDotDotToken);
-      emitNodeWithWriter(node.name, writeParameter);
-      emit(node.questionToken);
-      if (node.parent && node.parent.kind === 323 /* JSDocFunctionType */ && !node.name) {
-        emit(node.type);
-      } else {
-        emitTypeAnnotation(node.type);
-      }
-      emitInitializer(node.initializer, node.type ? node.type.end : node.questionToken ? node.questionToken.end : node.name ? node.name.end : node.modifiers ? node.modifiers.end : node.pos, node, parenthesizer.parenthesizeExpressionForDisallowedComma);
-    }
-    function emitDecorator(decorator) {
-      writePunctuation("@");
-      emitExpression(decorator.expression, parenthesizer.parenthesizeLeftSideOfAccess);
-    }
-    function emitPropertySignature(node) {
-      emitModifierList(node, node.modifiers);
-      emitNodeWithWriter(node.name, writeProperty);
-      emit(node.questionToken);
-      emitTypeAnnotation(node.type);
-      writeTrailingSemicolon();
-    }
-    function emitPropertyDeclaration(node) {
-      emitDecoratorsAndModifiers(
-        node,
-        node.modifiers,
-        /*allowDecorators*/
-        true
-      );
-      emit(node.name);
-      emit(node.questionToken);
-      emit(node.exclamationToken);
-      emitTypeAnnotation(node.type);
-      emitInitializer(node.initializer, node.type ? node.type.end : node.questionToken ? node.questionToken.end : node.name.end, node);
-      writeTrailingSemicolon();
-    }
-    function emitMethodSignature(node) {
-      pushNameGenerationScope(node);
-      emitModifierList(node, node.modifiers);
-      emit(node.name);
-      emit(node.questionToken);
-      emitTypeParameters(node, node.typeParameters);
-      emitParameters(node, node.parameters);
-      emitTypeAnnotation(node.type);
-      writeTrailingSemicolon();
-      popNameGenerationScope(node);
-    }
-    function emitMethodDeclaration(node) {
-      emitDecoratorsAndModifiers(
-        node,
-        node.modifiers,
-        /*allowDecorators*/
-        true
-      );
-      emit(node.asteriskToken);
-      emit(node.name);
-      emit(node.questionToken);
-      emitSignatureAndBody(node, emitSignatureHead);
-    }
-    function emitClassStaticBlockDeclaration(node) {
-      writeKeyword("static");
-      emitBlockFunctionBody(node.body);
-    }
-    function emitConstructor(node) {
-      emitDecoratorsAndModifiers(
-        node,
-        node.modifiers,
-        /*allowDecorators*/
-        false
-      );
-      writeKeyword("constructor");
-      emitSignatureAndBody(node, emitSignatureHead);
-    }
-    function emitAccessorDeclaration(node) {
-      const pos = emitDecoratorsAndModifiers(
-        node,
-        node.modifiers,
-        /*allowDecorators*/
-        true
-      );
-      const token = node.kind === 176 /* GetAccessor */ ? 139 /* GetKeyword */ : 153 /* SetKeyword */;
-      emitTokenWithComment(token, pos, writeKeyword, node);
-      writeSpace();
-      emit(node.name);
-      emitSignatureAndBody(node, emitSignatureHead);
-    }
-    function emitCallSignature(node) {
-      pushNameGenerationScope(node);
-      emitTypeParameters(node, node.typeParameters);
-      emitParameters(node, node.parameters);
-      emitTypeAnnotation(node.type);
-      writeTrailingSemicolon();
-      popNameGenerationScope(node);
-    }
-    function emitConstructSignature(node) {
-      pushNameGenerationScope(node);
-      writeKeyword("new");
-      writeSpace();
-      emitTypeParameters(node, node.typeParameters);
-      emitParameters(node, node.parameters);
-      emitTypeAnnotation(node.type);
-      writeTrailingSemicolon();
-      popNameGenerationScope(node);
-    }
-    function emitIndexSignature(node) {
-      emitDecoratorsAndModifiers(
-        node,
-        node.modifiers,
-        /*allowDecorators*/
-        false
-      );
-      emitParametersForIndexSignature(node, node.parameters);
-      emitTypeAnnotation(node.type);
-      writeTrailingSemicolon();
-    }
-    function emitTemplateTypeSpan(node) {
-      emit(node.type);
-      emit(node.literal);
-    }
-    function emitSemicolonClassElement() {
-      writeTrailingSemicolon();
-    }
-    function emitTypePredicate(node) {
-      if (node.assertsModifier) {
-        emit(node.assertsModifier);
-        writeSpace();
-      }
-      emit(node.parameterName);
-      if (node.type) {
-        writeSpace();
-        writeKeyword("is");
-        writeSpace();
-        emit(node.type);
-      }
-    }
-    function emitTypeReference(node) {
-      emit(node.typeName);
-      emitTypeArguments(node, node.typeArguments);
-    }
-    function emitFunctionType(node) {
-      pushNameGenerationScope(node);
-      emitTypeParameters(node, node.typeParameters);
-      emitParametersForArrow(node, node.parameters);
-      writeSpace();
-      writePunctuation("=>");
-      writeSpace();
-      emit(node.type);
-      popNameGenerationScope(node);
-    }
-    function emitJSDocFunctionType(node) {
-      writeKeyword("function");
-      emitParameters(node, node.parameters);
-      writePunctuation(":");
-      emit(node.type);
-    }
-    function emitJSDocNullableType(node) {
-      writePunctuation("?");
-      emit(node.type);
-    }
-    function emitJSDocNonNullableType(node) {
-      writePunctuation("!");
-      emit(node.type);
-    }
-    function emitJSDocOptionalType(node) {
-      emit(node.type);
-      writePunctuation("=");
-    }
-    function emitConstructorType(node) {
-      pushNameGenerationScope(node);
-      emitModifierList(node, node.modifiers);
-      writeKeyword("new");
-      writeSpace();
-      emitTypeParameters(node, node.typeParameters);
-      emitParameters(node, node.parameters);
-      writeSpace();
-      writePunctuation("=>");
-      writeSpace();
-      emit(node.type);
-      popNameGenerationScope(node);
-    }
-    function emitTypeQuery(node) {
-      writeKeyword("typeof");
-      writeSpace();
-      emit(node.exprName);
-      emitTypeArguments(node, node.typeArguments);
-    }
-    function emitTypeLiteral(node) {
-      pushPrivateNameGenerationScope(
-        0 /* Auto */,
-        /*newReservedMemberNames*/
-        void 0
-      );
-      writePunctuation("{");
-      const flags = getEmitFlags(node) & 1 /* SingleLine */ ? 768 /* SingleLineTypeLiteralMembers */ : 32897 /* MultiLineTypeLiteralMembers */;
-      emitList(node, node.members, flags | 524288 /* NoSpaceIfEmpty */);
-      writePunctuation("}");
-      popPrivateNameGenerationScope();
-    }
-    function emitArrayType(node) {
-      emit(node.elementType, parenthesizer.parenthesizeNonArrayTypeOfPostfixType);
-      writePunctuation("[");
-      writePunctuation("]");
-    }
-    function emitRestOrJSDocVariadicType(node) {
-      writePunctuation("...");
-      emit(node.type);
-    }
-    function emitTupleType(node) {
-      emitTokenWithComment(23 /* OpenBracketToken */, node.pos, writePunctuation, node);
-      const flags = getEmitFlags(node) & 1 /* SingleLine */ ? 528 /* SingleLineTupleTypeElements */ : 657 /* MultiLineTupleTypeElements */;
-      emitList(node, node.elements, flags | 524288 /* NoSpaceIfEmpty */, parenthesizer.parenthesizeElementTypeOfTupleType);
-      emitTokenWithComment(24 /* CloseBracketToken */, node.elements.end, writePunctuation, node);
-    }
-    function emitNamedTupleMember(node) {
-      emit(node.dotDotDotToken);
-      emit(node.name);
-      emit(node.questionToken);
-      emitTokenWithComment(59 /* ColonToken */, node.name.end, writePunctuation, node);
-      writeSpace();
-      emit(node.type);
-    }
-    function emitOptionalType(node) {
-      emit(node.type, parenthesizer.parenthesizeTypeOfOptionalType);
-      writePunctuation("?");
-    }
-    function emitUnionType(node) {
-      emitList(node, node.types, 516 /* UnionTypeConstituents */, parenthesizer.parenthesizeConstituentTypeOfUnionType);
-    }
-    function emitIntersectionType(node) {
-      emitList(node, node.types, 520 /* IntersectionTypeConstituents */, parenthesizer.parenthesizeConstituentTypeOfIntersectionType);
-    }
-    function emitConditionalType(node) {
-      emit(node.checkType, parenthesizer.parenthesizeCheckTypeOfConditionalType);
-      writeSpace();
-      writeKeyword("extends");
-      writeSpace();
-      emit(node.extendsType, parenthesizer.parenthesizeExtendsTypeOfConditionalType);
-      writeSpace();
-      writePunctuation("?");
-      writeSpace();
-      emit(node.trueType);
-      writeSpace();
-      writePunctuation(":");
-      writeSpace();
-      emit(node.falseType);
-    }
-    function emitInferType(node) {
-      writeKeyword("infer");
-      writeSpace();
-      emit(node.typeParameter);
-    }
-    function emitParenthesizedType(node) {
-      writePunctuation("(");
-      emit(node.type);
-      writePunctuation(")");
-    }
-    function emitThisType() {
-      writeKeyword("this");
-    }
-    function emitTypeOperator(node) {
-      writeTokenText(node.operator, writeKeyword);
-      writeSpace();
-      const parenthesizerRule = node.operator === 148 /* ReadonlyKeyword */ ? parenthesizer.parenthesizeOperandOfReadonlyTypeOperator : parenthesizer.parenthesizeOperandOfTypeOperator;
-      emit(node.type, parenthesizerRule);
-    }
-    function emitIndexedAccessType(node) {
-      emit(node.objectType, parenthesizer.parenthesizeNonArrayTypeOfPostfixType);
-      writePunctuation("[");
-      emit(node.indexType);
-      writePunctuation("]");
-    }
-    function emitMappedType(node) {
-      const emitFlags = getEmitFlags(node);
-      writePunctuation("{");
-      if (emitFlags & 1 /* SingleLine */) {
-        writeSpace();
-      } else {
-        writeLine();
-        increaseIndent();
-      }
-      if (node.readonlyToken) {
-        emit(node.readonlyToken);
-        if (node.readonlyToken.kind !== 148 /* ReadonlyKeyword */) {
-          writeKeyword("readonly");
-        }
-        writeSpace();
-      }
-      writePunctuation("[");
-      pipelineEmit(3 /* MappedTypeParameter */, node.typeParameter);
-      if (node.nameType) {
-        writeSpace();
-        writeKeyword("as");
-        writeSpace();
-        emit(node.nameType);
-      }
-      writePunctuation("]");
-      if (node.questionToken) {
-        emit(node.questionToken);
-        if (node.questionToken.kind !== 58 /* QuestionToken */) {
-          writePunctuation("?");
-        }
-      }
-      writePunctuation(":");
-      writeSpace();
-      emit(node.type);
-      writeTrailingSemicolon();
-      if (emitFlags & 1 /* SingleLine */) {
-        writeSpace();
-      } else {
-        writeLine();
-        decreaseIndent();
-      }
-      emitList(node, node.members, 2 /* PreserveLines */);
-      writePunctuation("}");
-    }
-    function emitLiteralType(node) {
-      emitExpression(node.literal);
-    }
-    function emitTemplateType(node) {
-      emit(node.head);
-      emitList(node, node.templateSpans, 262144 /* TemplateExpressionSpans */);
-    }
-    function emitImportTypeNode(node) {
-      if (node.isTypeOf) {
-        writeKeyword("typeof");
-        writeSpace();
-      }
-      writeKeyword("import");
-      writePunctuation("(");
-      emit(node.argument);
-      if (node.assertions) {
-        writePunctuation(",");
-        writeSpace();
-        writePunctuation("{");
-        writeSpace();
-        writeKeyword("assert");
-        writePunctuation(":");
-        writeSpace();
-        const elements = node.assertions.assertClause.elements;
-        emitList(node.assertions.assertClause, elements, 526226 /* ImportClauseEntries */);
-        writeSpace();
-        writePunctuation("}");
-      }
-      writePunctuation(")");
-      if (node.qualifier) {
-        writePunctuation(".");
-        emit(node.qualifier);
-      }
-      emitTypeArguments(node, node.typeArguments);
-    }
-    function emitObjectBindingPattern(node) {
-      writePunctuation("{");
-      emitList(node, node.elements, 525136 /* ObjectBindingPatternElements */);
-      writePunctuation("}");
-    }
-    function emitArrayBindingPattern(node) {
-      writePunctuation("[");
-      emitList(node, node.elements, 524880 /* ArrayBindingPatternElements */);
-      writePunctuation("]");
-    }
-    function emitBindingElement(node) {
-      emit(node.dotDotDotToken);
-      if (node.propertyName) {
-        emit(node.propertyName);
-        writePunctuation(":");
-        writeSpace();
-      }
-      emit(node.name);
-      emitInitializer(node.initializer, node.name.end, node, parenthesizer.parenthesizeExpressionForDisallowedComma);
-    }
-    function emitArrayLiteralExpression(node) {
-      const elements = node.elements;
-      const preferNewLine = node.multiLine ? 65536 /* PreferNewLine */ : 0 /* None */;
-      emitExpressionList(node, elements, 8914 /* ArrayLiteralExpressionElements */ | preferNewLine, parenthesizer.parenthesizeExpressionForDisallowedComma);
-    }
-    function emitObjectLiteralExpression(node) {
-      pushPrivateNameGenerationScope(
-        0 /* Auto */,
-        /*newReservedMemberNames*/
-        void 0
-      );
-      forEach(node.properties, generateMemberNames);
-      const indentedFlag = getEmitFlags(node) & 131072 /* Indented */;
-      if (indentedFlag) {
-        increaseIndent();
-      }
-      const preferNewLine = node.multiLine ? 65536 /* PreferNewLine */ : 0 /* None */;
-      const allowTrailingComma = currentSourceFile && currentSourceFile.languageVersion >= 1 /* ES5 */ && !isJsonSourceFile(currentSourceFile) ? 64 /* AllowTrailingComma */ : 0 /* None */;
-      emitList(node, node.properties, 526226 /* ObjectLiteralExpressionProperties */ | allowTrailingComma | preferNewLine);
-      if (indentedFlag) {
-        decreaseIndent();
-      }
-      popPrivateNameGenerationScope();
-    }
-    function emitPropertyAccessExpression(node) {
-      emitExpression(node.expression, parenthesizer.parenthesizeLeftSideOfAccess);
-      const token = node.questionDotToken || setTextRangePosEnd(factory.createToken(25 /* DotToken */), node.expression.end, node.name.pos);
-      const linesBeforeDot = getLinesBetweenNodes(node, node.expression, token);
-      const linesAfterDot = getLinesBetweenNodes(node, token, node.name);
-      writeLinesAndIndent(
-        linesBeforeDot,
-        /*writeSpaceIfNotIndenting*/
-        false
-      );
-      const shouldEmitDotDot = token.kind !== 29 /* QuestionDotToken */ && mayNeedDotDotForPropertyAccess(node.expression) && !writer.hasTrailingComment() && !writer.hasTrailingWhitespace();
-      if (shouldEmitDotDot) {
-        writePunctuation(".");
-      }
-      if (node.questionDotToken) {
-        emit(token);
-      } else {
-        emitTokenWithComment(token.kind, node.expression.end, writePunctuation, node);
-      }
-      writeLinesAndIndent(
-        linesAfterDot,
-        /*writeSpaceIfNotIndenting*/
-        false
-      );
-      emit(node.name);
-      decreaseIndentIf(linesBeforeDot, linesAfterDot);
-    }
-    function mayNeedDotDotForPropertyAccess(expression) {
-      expression = skipPartiallyEmittedExpressions(expression);
-      if (isNumericLiteral(expression)) {
-        const text = getLiteralTextOfNode(
-          expression,
-          /*neverAsciiEscape*/
-          true,
-          /*jsxAttributeEscape*/
-          false
-        );
-        return !(expression.numericLiteralFlags & 448 /* WithSpecifier */) && !stringContains(text, tokenToString(25 /* DotToken */)) && !stringContains(text, String.fromCharCode(69 /* E */)) && !stringContains(text, String.fromCharCode(101 /* e */));
-      } else if (isAccessExpression(expression)) {
-        const constantValue = getConstantValue(expression);
-        return typeof constantValue === "number" && isFinite(constantValue) && Math.floor(constantValue) === constantValue;
-      }
-    }
-    function emitElementAccessExpression(node) {
-      emitExpression(node.expression, parenthesizer.parenthesizeLeftSideOfAccess);
-      emit(node.questionDotToken);
-      emitTokenWithComment(23 /* OpenBracketToken */, node.expression.end, writePunctuation, node);
-      emitExpression(node.argumentExpression);
-      emitTokenWithComment(24 /* CloseBracketToken */, node.argumentExpression.end, writePunctuation, node);
-    }
-    function emitCallExpression(node) {
-      const indirectCall = getInternalEmitFlags(node) & 16 /* IndirectCall */;
-      if (indirectCall) {
-        writePunctuation("(");
-        writeLiteral("0");
-        writePunctuation(",");
-        writeSpace();
-      }
-      emitExpression(node.expression, parenthesizer.parenthesizeLeftSideOfAccess);
-      if (indirectCall) {
-        writePunctuation(")");
-      }
-      emit(node.questionDotToken);
-      emitTypeArguments(node, node.typeArguments);
-      emitExpressionList(node, node.arguments, 2576 /* CallExpressionArguments */, parenthesizer.parenthesizeExpressionForDisallowedComma);
-    }
-    function emitNewExpression(node) {
-      emitTokenWithComment(105 /* NewKeyword */, node.pos, writeKeyword, node);
-      writeSpace();
-      emitExpression(node.expression, parenthesizer.parenthesizeExpressionOfNew);
-      emitTypeArguments(node, node.typeArguments);
-      emitExpressionList(node, node.arguments, 18960 /* NewExpressionArguments */, parenthesizer.parenthesizeExpressionForDisallowedComma);
-    }
-    function emitTaggedTemplateExpression(node) {
-      const indirectCall = getInternalEmitFlags(node) & 16 /* IndirectCall */;
-      if (indirectCall) {
-        writePunctuation("(");
-        writeLiteral("0");
-        writePunctuation(",");
-        writeSpace();
-      }
-      emitExpression(node.tag, parenthesizer.parenthesizeLeftSideOfAccess);
-      if (indirectCall) {
-        writePunctuation(")");
-      }
-      emitTypeArguments(node, node.typeArguments);
-      writeSpace();
-      emitExpression(node.template);
-    }
-    function emitTypeAssertionExpression(node) {
-      writePunctuation("<");
-      emit(node.type);
-      writePunctuation(">");
-      emitExpression(node.expression, parenthesizer.parenthesizeOperandOfPrefixUnary);
-    }
-    function emitParenthesizedExpression(node) {
-      const openParenPos = emitTokenWithComment(21 /* OpenParenToken */, node.pos, writePunctuation, node);
-      const indented = writeLineSeparatorsAndIndentBefore(node.expression, node);
-      emitExpression(
-        node.expression,
-        /*parenthesizerRule*/
-        void 0
-      );
-      writeLineSeparatorsAfter(node.expression, node);
-      decreaseIndentIf(indented);
-      emitTokenWithComment(22 /* CloseParenToken */, node.expression ? node.expression.end : openParenPos, writePunctuation, node);
-    }
-    function emitFunctionExpression(node) {
-      generateNameIfNeeded(node.name);
-      emitFunctionDeclarationOrExpression(node);
-    }
-    function emitArrowFunction(node) {
-      emitModifierList(node, node.modifiers);
-      emitSignatureAndBody(node, emitArrowFunctionHead);
-    }
-    function emitArrowFunctionHead(node) {
-      emitTypeParameters(node, node.typeParameters);
-      emitParametersForArrow(node, node.parameters);
-      emitTypeAnnotation(node.type);
-      writeSpace();
-      emit(node.equalsGreaterThanToken);
-    }
-    function emitDeleteExpression(node) {
-      emitTokenWithComment(91 /* DeleteKeyword */, node.pos, writeKeyword, node);
-      writeSpace();
-      emitExpression(node.expression, parenthesizer.parenthesizeOperandOfPrefixUnary);
-    }
-    function emitTypeOfExpression(node) {
-      emitTokenWithComment(114 /* TypeOfKeyword */, node.pos, writeKeyword, node);
-      writeSpace();
-      emitExpression(node.expression, parenthesizer.parenthesizeOperandOfPrefixUnary);
-    }
-    function emitVoidExpression(node) {
-      emitTokenWithComment(116 /* VoidKeyword */, node.pos, writeKeyword, node);
-      writeSpace();
-      emitExpression(node.expression, parenthesizer.parenthesizeOperandOfPrefixUnary);
-    }
-    function emitAwaitExpression(node) {
-      emitTokenWithComment(135 /* AwaitKeyword */, node.pos, writeKeyword, node);
-      writeSpace();
-      emitExpression(node.expression, parenthesizer.parenthesizeOperandOfPrefixUnary);
-    }
-    function emitPrefixUnaryExpression(node) {
-      writeTokenText(node.operator, writeOperator);
-      if (shouldEmitWhitespaceBeforeOperand(node)) {
-        writeSpace();
-      }
-      emitExpression(node.operand, parenthesizer.parenthesizeOperandOfPrefixUnary);
-    }
-    function shouldEmitWhitespaceBeforeOperand(node) {
-      const operand = node.operand;
-      return operand.kind === 223 /* PrefixUnaryExpression */ && (node.operator === 40 /* PlusToken */ && (operand.operator === 40 /* PlusToken */ || operand.operator === 46 /* PlusPlusToken */) || node.operator === 41 /* MinusToken */ && (operand.operator === 41 /* MinusToken */ || operand.operator === 47 /* MinusMinusToken */));
-    }
-    function emitPostfixUnaryExpression(node) {
-      emitExpression(node.operand, parenthesizer.parenthesizeOperandOfPostfixUnary);
-      writeTokenText(node.operator, writeOperator);
-    }
-    function createEmitBinaryExpression() {
-      return createBinaryExpressionTrampoline(
-        onEnter,
-        onLeft,
-        onOperator,
-        onRight,
-        onExit,
-        /*foldState*/
-        void 0
-      );
-      function onEnter(node, state) {
-        if (state) {
-          state.stackIndex++;
-          state.preserveSourceNewlinesStack[state.stackIndex] = preserveSourceNewlines;
-          state.containerPosStack[state.stackIndex] = containerPos;
-          state.containerEndStack[state.stackIndex] = containerEnd;
-          state.declarationListContainerEndStack[state.stackIndex] = declarationListContainerEnd;
-          const emitComments2 = state.shouldEmitCommentsStack[state.stackIndex] = shouldEmitComments(node);
-          const emitSourceMaps = state.shouldEmitSourceMapsStack[state.stackIndex] = shouldEmitSourceMaps(node);
-          onBeforeEmitNode == null ? void 0 : onBeforeEmitNode(node);
-          if (emitComments2)
-            emitCommentsBeforeNode(node);
-          if (emitSourceMaps)
-            emitSourceMapsBeforeNode(node);
-          beforeEmitNode(node);
-        } else {
-          state = {
-            stackIndex: 0,
-            preserveSourceNewlinesStack: [void 0],
-            containerPosStack: [-1],
-            containerEndStack: [-1],
-            declarationListContainerEndStack: [-1],
-            shouldEmitCommentsStack: [false],
-            shouldEmitSourceMapsStack: [false]
-          };
-        }
-        return state;
-      }
-      function onLeft(next, _workArea, parent2) {
-        return maybeEmitExpression(next, parent2, "left");
-      }
-      function onOperator(operatorToken, _state, node) {
-        const isCommaOperator = operatorToken.kind !== 28 /* CommaToken */;
-        const linesBeforeOperator = getLinesBetweenNodes(node, node.left, operatorToken);
-        const linesAfterOperator = getLinesBetweenNodes(node, operatorToken, node.right);
-        writeLinesAndIndent(linesBeforeOperator, isCommaOperator);
-        emitLeadingCommentsOfPosition(operatorToken.pos);
-        writeTokenNode(operatorToken, operatorToken.kind === 103 /* InKeyword */ ? writeKeyword : writeOperator);
-        emitTrailingCommentsOfPosition(
-          operatorToken.end,
-          /*prefixSpace*/
-          true
-        );
-        writeLinesAndIndent(
-          linesAfterOperator,
-          /*writeSpaceIfNotIndenting*/
-          true
-        );
-      }
-      function onRight(next, _workArea, parent2) {
-        return maybeEmitExpression(next, parent2, "right");
-      }
-      function onExit(node, state) {
-        const linesBeforeOperator = getLinesBetweenNodes(node, node.left, node.operatorToken);
-        const linesAfterOperator = getLinesBetweenNodes(node, node.operatorToken, node.right);
-        decreaseIndentIf(linesBeforeOperator, linesAfterOperator);
-        if (state.stackIndex > 0) {
-          const savedPreserveSourceNewlines = state.preserveSourceNewlinesStack[state.stackIndex];
-          const savedContainerPos = state.containerPosStack[state.stackIndex];
-          const savedContainerEnd = state.containerEndStack[state.stackIndex];
-          const savedDeclarationListContainerEnd = state.declarationListContainerEndStack[state.stackIndex];
-          const shouldEmitComments2 = state.shouldEmitCommentsStack[state.stackIndex];
-          const shouldEmitSourceMaps2 = state.shouldEmitSourceMapsStack[state.stackIndex];
-          afterEmitNode(savedPreserveSourceNewlines);
-          if (shouldEmitSourceMaps2)
-            emitSourceMapsAfterNode(node);
-          if (shouldEmitComments2)
-            emitCommentsAfterNode(node, savedContainerPos, savedContainerEnd, savedDeclarationListContainerEnd);
-          onAfterEmitNode == null ? void 0 : onAfterEmitNode(node);
-          state.stackIndex--;
-        }
-      }
-      function maybeEmitExpression(next, parent2, side) {
-        const parenthesizerRule = side === "left" ? parenthesizer.getParenthesizeLeftSideOfBinaryForOperator(parent2.operatorToken.kind) : parenthesizer.getParenthesizeRightSideOfBinaryForOperator(parent2.operatorToken.kind);
-        let pipelinePhase = getPipelinePhase(0 /* Notification */, 1 /* Expression */, next);
-        if (pipelinePhase === pipelineEmitWithSubstitution) {
-          Debug.assertIsDefined(lastSubstitution);
-          next = parenthesizerRule(cast(lastSubstitution, isExpression));
-          pipelinePhase = getNextPipelinePhase(1 /* Substitution */, 1 /* Expression */, next);
-          lastSubstitution = void 0;
-        }
-        if (pipelinePhase === pipelineEmitWithComments || pipelinePhase === pipelineEmitWithSourceMaps || pipelinePhase === pipelineEmitWithHint) {
-          if (isBinaryExpression(next)) {
-            return next;
-          }
-        }
-        currentParenthesizerRule = parenthesizerRule;
-        pipelinePhase(1 /* Expression */, next);
-      }
-    }
-    function emitConditionalExpression(node) {
-      const linesBeforeQuestion = getLinesBetweenNodes(node, node.condition, node.questionToken);
-      const linesAfterQuestion = getLinesBetweenNodes(node, node.questionToken, node.whenTrue);
-      const linesBeforeColon = getLinesBetweenNodes(node, node.whenTrue, node.colonToken);
-      const linesAfterColon = getLinesBetweenNodes(node, node.colonToken, node.whenFalse);
-      emitExpression(node.condition, parenthesizer.parenthesizeConditionOfConditionalExpression);
-      writeLinesAndIndent(
-        linesBeforeQuestion,
-        /*writeSpaceIfNotIndenting*/
-        true
-      );
-      emit(node.questionToken);
-      writeLinesAndIndent(
-        linesAfterQuestion,
-        /*writeSpaceIfNotIndenting*/
-        true
-      );
-      emitExpression(node.whenTrue, parenthesizer.parenthesizeBranchOfConditionalExpression);
-      decreaseIndentIf(linesBeforeQuestion, linesAfterQuestion);
-      writeLinesAndIndent(
-        linesBeforeColon,
-        /*writeSpaceIfNotIndenting*/
-        true
-      );
-      emit(node.colonToken);
-      writeLinesAndIndent(
-        linesAfterColon,
-        /*writeSpaceIfNotIndenting*/
-        true
-      );
-      emitExpression(node.whenFalse, parenthesizer.parenthesizeBranchOfConditionalExpression);
-      decreaseIndentIf(linesBeforeColon, linesAfterColon);
-    }
-    function emitTemplateExpression(node) {
-      emit(node.head);
-      emitList(node, node.templateSpans, 262144 /* TemplateExpressionSpans */);
-    }
-    function emitYieldExpression(node) {
-      emitTokenWithComment(127 /* YieldKeyword */, node.pos, writeKeyword, node);
-      emit(node.asteriskToken);
-      emitExpressionWithLeadingSpace(node.expression && parenthesizeExpressionForNoAsi(node.expression), parenthesizeExpressionForNoAsiAndDisallowedComma);
-    }
-    function emitSpreadElement(node) {
-      emitTokenWithComment(26 /* DotDotDotToken */, node.pos, writePunctuation, node);
-      emitExpression(node.expression, parenthesizer.parenthesizeExpressionForDisallowedComma);
-    }
-    function emitClassExpression(node) {
-      generateNameIfNeeded(node.name);
-      emitClassDeclarationOrExpression(node);
-    }
-    function emitExpressionWithTypeArguments(node) {
-      emitExpression(node.expression, parenthesizer.parenthesizeLeftSideOfAccess);
-      emitTypeArguments(node, node.typeArguments);
-    }
-    function emitAsExpression(node) {
-      emitExpression(
-        node.expression,
-        /*parenthesizerRule*/
-        void 0
-      );
-      if (node.type) {
-        writeSpace();
-        writeKeyword("as");
-        writeSpace();
-        emit(node.type);
-      }
-    }
-    function emitNonNullExpression(node) {
-      emitExpression(node.expression, parenthesizer.parenthesizeLeftSideOfAccess);
-      writeOperator("!");
-    }
-    function emitSatisfiesExpression(node) {
-      emitExpression(
-        node.expression,
-        /*parenthesizerRule*/
-        void 0
-      );
-      if (node.type) {
-        writeSpace();
-        writeKeyword("satisfies");
-        writeSpace();
-        emit(node.type);
-      }
-    }
-    function emitMetaProperty(node) {
-      writeToken(node.keywordToken, node.pos, writePunctuation);
-      writePunctuation(".");
-      emit(node.name);
-    }
-    function emitTemplateSpan(node) {
-      emitExpression(node.expression);
-      emit(node.literal);
-    }
-    function emitBlock(node) {
-      emitBlockStatements(
-        node,
-        /*forceSingleLine*/
-        !node.multiLine && isEmptyBlock(node)
-      );
-    }
-    function emitBlockStatements(node, forceSingleLine) {
-      emitTokenWithComment(
-        19 /* OpenBraceToken */,
-        node.pos,
-        writePunctuation,
-        /*contextNode*/
-        node
-      );
-      const format = forceSingleLine || getEmitFlags(node) & 1 /* SingleLine */ ? 768 /* SingleLineBlockStatements */ : 129 /* MultiLineBlockStatements */;
-      emitList(node, node.statements, format);
-      emitTokenWithComment(
-        20 /* CloseBraceToken */,
-        node.statements.end,
-        writePunctuation,
-        /*contextNode*/
-        node,
-        /*indentLeading*/
-        !!(format & 1 /* MultiLine */)
-      );
-    }
-    function emitVariableStatement(node) {
-      emitDecoratorsAndModifiers(
-        node,
-        node.modifiers,
-        /*allowDecorators*/
-        false
-      );
-      emit(node.declarationList);
-      writeTrailingSemicolon();
-    }
-    function emitEmptyStatement(isEmbeddedStatement) {
-      if (isEmbeddedStatement) {
-        writePunctuation(";");
-      } else {
-        writeTrailingSemicolon();
-      }
-    }
-    function emitExpressionStatement(node) {
-      emitExpression(node.expression, parenthesizer.parenthesizeExpressionOfExpressionStatement);
-      if (!currentSourceFile || !isJsonSourceFile(currentSourceFile) || nodeIsSynthesized(node.expression)) {
-        writeTrailingSemicolon();
-      }
-    }
-    function emitIfStatement(node) {
-      const openParenPos = emitTokenWithComment(101 /* IfKeyword */, node.pos, writeKeyword, node);
-      writeSpace();
-      emitTokenWithComment(21 /* OpenParenToken */, openParenPos, writePunctuation, node);
-      emitExpression(node.expression);
-      emitTokenWithComment(22 /* CloseParenToken */, node.expression.end, writePunctuation, node);
-      emitEmbeddedStatement(node, node.thenStatement);
-      if (node.elseStatement) {
-        writeLineOrSpace(node, node.thenStatement, node.elseStatement);
-        emitTokenWithComment(93 /* ElseKeyword */, node.thenStatement.end, writeKeyword, node);
-        if (node.elseStatement.kind === 244 /* IfStatement */) {
-          writeSpace();
-          emit(node.elseStatement);
-        } else {
-          emitEmbeddedStatement(node, node.elseStatement);
-        }
-      }
-    }
-    function emitWhileClause(node, startPos) {
-      const openParenPos = emitTokenWithComment(117 /* WhileKeyword */, startPos, writeKeyword, node);
-      writeSpace();
-      emitTokenWithComment(21 /* OpenParenToken */, openParenPos, writePunctuation, node);
-      emitExpression(node.expression);
-      emitTokenWithComment(22 /* CloseParenToken */, node.expression.end, writePunctuation, node);
-    }
-    function emitDoStatement(node) {
-      emitTokenWithComment(92 /* DoKeyword */, node.pos, writeKeyword, node);
-      emitEmbeddedStatement(node, node.statement);
-      if (isBlock(node.statement) && !preserveSourceNewlines) {
-        writeSpace();
-      } else {
-        writeLineOrSpace(node, node.statement, node.expression);
-      }
-      emitWhileClause(node, node.statement.end);
-      writeTrailingSemicolon();
-    }
-    function emitWhileStatement(node) {
-      emitWhileClause(node, node.pos);
-      emitEmbeddedStatement(node, node.statement);
-    }
-    function emitForStatement(node) {
-      const openParenPos = emitTokenWithComment(99 /* ForKeyword */, node.pos, writeKeyword, node);
-      writeSpace();
-      let pos = emitTokenWithComment(
-        21 /* OpenParenToken */,
-        openParenPos,
-        writePunctuation,
-        /*contextNode*/
-        node
-      );
-      emitForBinding(node.initializer);
-      pos = emitTokenWithComment(27 /* SemicolonToken */, node.initializer ? node.initializer.end : pos, writePunctuation, node);
-      emitExpressionWithLeadingSpace(node.condition);
-      pos = emitTokenWithComment(27 /* SemicolonToken */, node.condition ? node.condition.end : pos, writePunctuation, node);
-      emitExpressionWithLeadingSpace(node.incrementor);
-      emitTokenWithComment(22 /* CloseParenToken */, node.incrementor ? node.incrementor.end : pos, writePunctuation, node);
-      emitEmbeddedStatement(node, node.statement);
-    }
-    function emitForInStatement(node) {
-      const openParenPos = emitTokenWithComment(99 /* ForKeyword */, node.pos, writeKeyword, node);
-      writeSpace();
-      emitTokenWithComment(21 /* OpenParenToken */, openParenPos, writePunctuation, node);
-      emitForBinding(node.initializer);
-      writeSpace();
-      emitTokenWithComment(103 /* InKeyword */, node.initializer.end, writeKeyword, node);
-      writeSpace();
-      emitExpression(node.expression);
-      emitTokenWithComment(22 /* CloseParenToken */, node.expression.end, writePunctuation, node);
-      emitEmbeddedStatement(node, node.statement);
-    }
-    function emitForOfStatement(node) {
-      const openParenPos = emitTokenWithComment(99 /* ForKeyword */, node.pos, writeKeyword, node);
-      writeSpace();
-      emitWithTrailingSpace(node.awaitModifier);
-      emitTokenWithComment(21 /* OpenParenToken */, openParenPos, writePunctuation, node);
-      emitForBinding(node.initializer);
-      writeSpace();
-      emitTokenWithComment(164 /* OfKeyword */, node.initializer.end, writeKeyword, node);
-      writeSpace();
-      emitExpression(node.expression);
-      emitTokenWithComment(22 /* CloseParenToken */, node.expression.end, writePunctuation, node);
-      emitEmbeddedStatement(node, node.statement);
-    }
-    function emitForBinding(node) {
-      if (node !== void 0) {
-        if (node.kind === 260 /* VariableDeclarationList */) {
-          emit(node);
-        } else {
-          emitExpression(node);
-        }
-      }
-    }
-    function emitContinueStatement(node) {
-      emitTokenWithComment(88 /* ContinueKeyword */, node.pos, writeKeyword, node);
-      emitWithLeadingSpace(node.label);
-      writeTrailingSemicolon();
-    }
-    function emitBreakStatement(node) {
-      emitTokenWithComment(83 /* BreakKeyword */, node.pos, writeKeyword, node);
-      emitWithLeadingSpace(node.label);
-      writeTrailingSemicolon();
-    }
-    function emitTokenWithComment(token, pos, writer2, contextNode, indentLeading) {
-      const node = getParseTreeNode(contextNode);
-      const isSimilarNode = node && node.kind === contextNode.kind;
-      const startPos = pos;
-      if (isSimilarNode && currentSourceFile) {
-        pos = skipTrivia(currentSourceFile.text, pos);
-      }
-      if (isSimilarNode && contextNode.pos !== startPos) {
-        const needsIndent = indentLeading && currentSourceFile && !positionsAreOnSameLine(startPos, pos, currentSourceFile);
-        if (needsIndent) {
-          increaseIndent();
-        }
-        emitLeadingCommentsOfPosition(startPos);
-        if (needsIndent) {
-          decreaseIndent();
-        }
-      }
-      pos = writeTokenText(token, writer2, pos);
-      if (isSimilarNode && contextNode.end !== pos) {
-        const isJsxExprContext = contextNode.kind === 293 /* JsxExpression */;
-        emitTrailingCommentsOfPosition(
-          pos,
-          /*prefixSpace*/
-          !isJsxExprContext,
-          /*forceNoNewline*/
-          isJsxExprContext
-        );
-      }
-      return pos;
-    }
-    function commentWillEmitNewLine(node) {
-      return node.kind === 2 /* SingleLineCommentTrivia */ || !!node.hasTrailingNewLine;
-    }
-    function willEmitLeadingNewLine(node) {
-      if (!currentSourceFile)
-        return false;
-      if (some(getLeadingCommentRanges(currentSourceFile.text, node.pos), commentWillEmitNewLine))
-        return true;
-      if (some(getSyntheticLeadingComments(node), commentWillEmitNewLine))
-        return true;
-      if (isPartiallyEmittedExpression(node)) {
-        if (node.pos !== node.expression.pos) {
-          if (some(getTrailingCommentRanges(currentSourceFile.text, node.expression.pos), commentWillEmitNewLine))
-            return true;
-        }
-        return willEmitLeadingNewLine(node.expression);
-      }
-      return false;
-    }
-    function parenthesizeExpressionForNoAsi(node) {
-      if (!commentsDisabled && isPartiallyEmittedExpression(node) && willEmitLeadingNewLine(node)) {
-        const parseNode = getParseTreeNode(node);
-        if (parseNode && isParenthesizedExpression(parseNode)) {
-          const parens = factory.createParenthesizedExpression(node.expression);
-          setOriginalNode(parens, node);
-          setTextRange(parens, parseNode);
-          return parens;
-        }
-        return factory.createParenthesizedExpression(node);
-      }
-      return node;
-    }
-    function parenthesizeExpressionForNoAsiAndDisallowedComma(node) {
-      return parenthesizeExpressionForNoAsi(parenthesizer.parenthesizeExpressionForDisallowedComma(node));
-    }
-    function emitReturnStatement(node) {
-      emitTokenWithComment(
-        107 /* ReturnKeyword */,
-        node.pos,
-        writeKeyword,
-        /*contextNode*/
-        node
-      );
-      emitExpressionWithLeadingSpace(node.expression && parenthesizeExpressionForNoAsi(node.expression), parenthesizeExpressionForNoAsi);
-      writeTrailingSemicolon();
-    }
-    function emitWithStatement(node) {
-      const openParenPos = emitTokenWithComment(118 /* WithKeyword */, node.pos, writeKeyword, node);
-      writeSpace();
-      emitTokenWithComment(21 /* OpenParenToken */, openParenPos, writePunctuation, node);
-      emitExpression(node.expression);
-      emitTokenWithComment(22 /* CloseParenToken */, node.expression.end, writePunctuation, node);
-      emitEmbeddedStatement(node, node.statement);
-    }
-    function emitSwitchStatement(node) {
-      const openParenPos = emitTokenWithComment(109 /* SwitchKeyword */, node.pos, writeKeyword, node);
-      writeSpace();
-      emitTokenWithComment(21 /* OpenParenToken */, openParenPos, writePunctuation, node);
-      emitExpression(node.expression);
-      emitTokenWithComment(22 /* CloseParenToken */, node.expression.end, writePunctuation, node);
-      writeSpace();
-      emit(node.caseBlock);
-    }
-    function emitLabeledStatement(node) {
-      emit(node.label);
-      emitTokenWithComment(59 /* ColonToken */, node.label.end, writePunctuation, node);
-      writeSpace();
-      emit(node.statement);
-    }
-    function emitThrowStatement(node) {
-      emitTokenWithComment(111 /* ThrowKeyword */, node.pos, writeKeyword, node);
-      emitExpressionWithLeadingSpace(parenthesizeExpressionForNoAsi(node.expression), parenthesizeExpressionForNoAsi);
-      writeTrailingSemicolon();
-    }
-    function emitTryStatement(node) {
-      emitTokenWithComment(113 /* TryKeyword */, node.pos, writeKeyword, node);
-      writeSpace();
-      emit(node.tryBlock);
-      if (node.catchClause) {
-        writeLineOrSpace(node, node.tryBlock, node.catchClause);
-        emit(node.catchClause);
-      }
-      if (node.finallyBlock) {
-        writeLineOrSpace(node, node.catchClause || node.tryBlock, node.finallyBlock);
-        emitTokenWithComment(98 /* FinallyKeyword */, (node.catchClause || node.tryBlock).end, writeKeyword, node);
-        writeSpace();
-        emit(node.finallyBlock);
-      }
-    }
-    function emitDebuggerStatement(node) {
-      writeToken(89 /* DebuggerKeyword */, node.pos, writeKeyword);
-      writeTrailingSemicolon();
-    }
-    function emitVariableDeclaration(node) {
-      var _a, _b, _c;
-      emit(node.name);
-      emit(node.exclamationToken);
-      emitTypeAnnotation(node.type);
-      emitInitializer(node.initializer, ((_a = node.type) == null ? void 0 : _a.end) ?? ((_c = (_b = node.name.emitNode) == null ? void 0 : _b.typeNode) == null ? void 0 : _c.end) ?? node.name.end, node, parenthesizer.parenthesizeExpressionForDisallowedComma);
-    }
-    function emitVariableDeclarationList(node) {
-      writeKeyword(isLet(node) ? "let" : isVarConst(node) ? "const" : "var");
-      writeSpace();
-      emitList(node, node.declarations, 528 /* VariableDeclarationList */);
-    }
-    function emitFunctionDeclaration(node) {
-      emitFunctionDeclarationOrExpression(node);
-    }
-    function emitFunctionDeclarationOrExpression(node) {
-      emitDecoratorsAndModifiers(
-        node,
-        node.modifiers,
-        /*allowDecorators*/
-        false
-      );
-      writeKeyword("function");
-      emit(node.asteriskToken);
-      writeSpace();
-      emitIdentifierName(node.name);
-      emitSignatureAndBody(node, emitSignatureHead);
-    }
-    function emitSignatureAndBody(node, emitSignatureHead2) {
-      const body = node.body;
-      if (body) {
-        if (isBlock(body)) {
-          const indentedFlag = getEmitFlags(node) & 131072 /* Indented */;
-          if (indentedFlag) {
-            increaseIndent();
-          }
-          pushNameGenerationScope(node);
-          forEach(node.parameters, generateNames);
-          generateNames(node.body);
-          emitSignatureHead2(node);
-          emitBlockFunctionBody(body);
-          popNameGenerationScope(node);
-          if (indentedFlag) {
-            decreaseIndent();
-          }
-        } else {
-          emitSignatureHead2(node);
-          writeSpace();
-          emitExpression(body, parenthesizer.parenthesizeConciseBodyOfArrowFunction);
-        }
-      } else {
-        emitSignatureHead2(node);
-        writeTrailingSemicolon();
-      }
-    }
-    function emitSignatureHead(node) {
-      emitTypeParameters(node, node.typeParameters);
-      emitParameters(node, node.parameters);
-      emitTypeAnnotation(node.type);
-    }
-    function shouldEmitBlockFunctionBodyOnSingleLine(body) {
-      if (getEmitFlags(body) & 1 /* SingleLine */) {
-        return true;
-      }
-      if (body.multiLine) {
-        return false;
-      }
-      if (!nodeIsSynthesized(body) && currentSourceFile && !rangeIsOnSingleLine(body, currentSourceFile)) {
-        return false;
-      }
-      if (getLeadingLineTerminatorCount(body, firstOrUndefined(body.statements), 2 /* PreserveLines */) || getClosingLineTerminatorCount(body, lastOrUndefined(body.statements), 2 /* PreserveLines */, body.statements)) {
-        return false;
-      }
-      let previousStatement;
-      for (const statement of body.statements) {
-        if (getSeparatingLineTerminatorCount(previousStatement, statement, 2 /* PreserveLines */) > 0) {
-          return false;
-        }
-        previousStatement = statement;
-      }
-      return true;
-    }
-    function emitBlockFunctionBody(body) {
-      onBeforeEmitNode == null ? void 0 : onBeforeEmitNode(body);
-      writeSpace();
-      writePunctuation("{");
-      increaseIndent();
-      const emitBlockFunctionBody2 = shouldEmitBlockFunctionBodyOnSingleLine(body) ? emitBlockFunctionBodyOnSingleLine : emitBlockFunctionBodyWorker;
-      emitBodyWithDetachedComments(body, body.statements, emitBlockFunctionBody2);
-      decreaseIndent();
-      writeToken(20 /* CloseBraceToken */, body.statements.end, writePunctuation, body);
-      onAfterEmitNode == null ? void 0 : onAfterEmitNode(body);
-    }
-    function emitBlockFunctionBodyOnSingleLine(body) {
-      emitBlockFunctionBodyWorker(
-        body,
-        /*emitBlockFunctionBodyOnSingleLine*/
-        true
-      );
-    }
-    function emitBlockFunctionBodyWorker(body, emitBlockFunctionBodyOnSingleLine2) {
-      const statementOffset = emitPrologueDirectives(body.statements);
-      const pos = writer.getTextPos();
-      emitHelpers(body);
-      if (statementOffset === 0 && pos === writer.getTextPos() && emitBlockFunctionBodyOnSingleLine2) {
-        decreaseIndent();
-        emitList(body, body.statements, 768 /* SingleLineFunctionBodyStatements */);
-        increaseIndent();
-      } else {
-        emitList(
-          body,
-          body.statements,
-          1 /* MultiLineFunctionBodyStatements */,
-          /*parenthesizerRule*/
-          void 0,
-          statementOffset
-        );
-      }
-    }
-    function emitClassDeclaration(node) {
-      emitClassDeclarationOrExpression(node);
-    }
-    function emitClassDeclarationOrExpression(node) {
-      pushPrivateNameGenerationScope(
-        0 /* Auto */,
-        /*newReservedMemberNames*/
-        void 0
-      );
-      forEach(node.members, generateMemberNames);
-      emitDecoratorsAndModifiers(
-        node,
-        node.modifiers,
-        /*allowDecorators*/
-        true
-      );
-      emitTokenWithComment(86 /* ClassKeyword */, moveRangePastModifiers(node).pos, writeKeyword, node);
-      if (node.name) {
-        writeSpace();
-        emitIdentifierName(node.name);
-      }
-      const indentedFlag = getEmitFlags(node) & 131072 /* Indented */;
-      if (indentedFlag) {
-        increaseIndent();
-      }
-      emitTypeParameters(node, node.typeParameters);
-      emitList(node, node.heritageClauses, 0 /* ClassHeritageClauses */);
-      writeSpace();
-      writePunctuation("{");
-      emitList(node, node.members, 129 /* ClassMembers */);
-      writePunctuation("}");
-      if (indentedFlag) {
-        decreaseIndent();
-      }
-      popPrivateNameGenerationScope();
-    }
-    function emitInterfaceDeclaration(node) {
-      pushPrivateNameGenerationScope(
-        0 /* Auto */,
-        /*newReservedMemberNames*/
-        void 0
-      );
-      emitDecoratorsAndModifiers(
-        node,
-        node.modifiers,
-        /*allowDecorators*/
-        false
-      );
-      writeKeyword("interface");
-      writeSpace();
-      emit(node.name);
-      emitTypeParameters(node, node.typeParameters);
-      emitList(node, node.heritageClauses, 512 /* HeritageClauses */);
-      writeSpace();
-      writePunctuation("{");
-      emitList(node, node.members, 129 /* InterfaceMembers */);
-      writePunctuation("}");
-      popPrivateNameGenerationScope();
-    }
-    function emitTypeAliasDeclaration(node) {
-      emitDecoratorsAndModifiers(
-        node,
-        node.modifiers,
-        /*allowDecorators*/
-        false
-      );
-      writeKeyword("type");
-      writeSpace();
-      emit(node.name);
-      emitTypeParameters(node, node.typeParameters);
-      writeSpace();
-      writePunctuation("=");
-      writeSpace();
-      emit(node.type);
-      writeTrailingSemicolon();
-    }
-    function emitEnumDeclaration(node) {
-      emitDecoratorsAndModifiers(
-        node,
-        node.modifiers,
-        /*allowDecorators*/
-        false
-      );
-      writeKeyword("enum");
-      writeSpace();
-      emit(node.name);
-      writeSpace();
-      writePunctuation("{");
-      emitList(node, node.members, 145 /* EnumMembers */);
-      writePunctuation("}");
-    }
-    function emitModuleDeclaration(node) {
-      emitDecoratorsAndModifiers(
-        node,
-        node.modifiers,
-        /*allowDecorators*/
-        false
-      );
-      if (~node.flags & 1024 /* GlobalAugmentation */) {
-        writeKeyword(node.flags & 16 /* Namespace */ ? "namespace" : "module");
-        writeSpace();
-      }
-      emit(node.name);
-      let body = node.body;
-      if (!body)
-        return writeTrailingSemicolon();
-      while (body && isModuleDeclaration(body)) {
-        writePunctuation(".");
-        emit(body.name);
-        body = body.body;
-      }
-      writeSpace();
-      emit(body);
-    }
-    function emitModuleBlock(node) {
-      pushNameGenerationScope(node);
-      forEach(node.statements, generateNames);
-      emitBlockStatements(
-        node,
-        /*forceSingleLine*/
-        isEmptyBlock(node)
-      );
-      popNameGenerationScope(node);
-    }
-    function emitCaseBlock(node) {
-      emitTokenWithComment(19 /* OpenBraceToken */, node.pos, writePunctuation, node);
-      emitList(node, node.clauses, 129 /* CaseBlockClauses */);
-      emitTokenWithComment(
-        20 /* CloseBraceToken */,
-        node.clauses.end,
-        writePunctuation,
-        node,
-        /*indentLeading*/
-        true
-      );
-    }
-    function emitImportEqualsDeclaration(node) {
-      emitDecoratorsAndModifiers(
-        node,
-        node.modifiers,
-        /*allowDecorators*/
-        false
-      );
-      emitTokenWithComment(102 /* ImportKeyword */, node.modifiers ? node.modifiers.end : node.pos, writeKeyword, node);
-      writeSpace();
-      if (node.isTypeOnly) {
-        emitTokenWithComment(156 /* TypeKeyword */, node.pos, writeKeyword, node);
-        writeSpace();
-      }
-      emit(node.name);
-      writeSpace();
-      emitTokenWithComment(64 /* EqualsToken */, node.name.end, writePunctuation, node);
-      writeSpace();
-      emitModuleReference(node.moduleReference);
-      writeTrailingSemicolon();
-    }
-    function emitModuleReference(node) {
-      if (node.kind === 80 /* Identifier */) {
-        emitExpression(node);
-      } else {
-        emit(node);
-      }
-    }
-    function emitImportDeclaration(node) {
-      emitDecoratorsAndModifiers(
-        node,
-        node.modifiers,
-        /*allowDecorators*/
-        false
-      );
-      emitTokenWithComment(102 /* ImportKeyword */, node.modifiers ? node.modifiers.end : node.pos, writeKeyword, node);
-      writeSpace();
-      if (node.importClause) {
-        emit(node.importClause);
-        writeSpace();
-        emitTokenWithComment(160 /* FromKeyword */, node.importClause.end, writeKeyword, node);
-        writeSpace();
-      }
-      emitExpression(node.moduleSpecifier);
-      if (node.assertClause) {
-        emitWithLeadingSpace(node.assertClause);
-      }
-      writeTrailingSemicolon();
-    }
-    function emitImportClause(node) {
-      if (node.isTypeOnly) {
-        emitTokenWithComment(156 /* TypeKeyword */, node.pos, writeKeyword, node);
-        writeSpace();
-      }
-      emit(node.name);
-      if (node.name && node.namedBindings) {
-        emitTokenWithComment(28 /* CommaToken */, node.name.end, writePunctuation, node);
-        writeSpace();
-      }
-      emit(node.namedBindings);
-    }
-    function emitNamespaceImport(node) {
-      const asPos = emitTokenWithComment(42 /* AsteriskToken */, node.pos, writePunctuation, node);
-      writeSpace();
-      emitTokenWithComment(130 /* AsKeyword */, asPos, writeKeyword, node);
-      writeSpace();
-      emit(node.name);
-    }
-    function emitNamedImports(node) {
-      emitNamedImportsOrExports(node);
-    }
-    function emitImportSpecifier(node) {
-      emitImportOrExportSpecifier(node);
-    }
-    function emitExportAssignment(node) {
-      const nextPos = emitTokenWithComment(95 /* ExportKeyword */, node.pos, writeKeyword, node);
-      writeSpace();
-      if (node.isExportEquals) {
-        emitTokenWithComment(64 /* EqualsToken */, nextPos, writeOperator, node);
-      } else {
-        emitTokenWithComment(90 /* DefaultKeyword */, nextPos, writeKeyword, node);
-      }
-      writeSpace();
-      emitExpression(node.expression, node.isExportEquals ? parenthesizer.getParenthesizeRightSideOfBinaryForOperator(64 /* EqualsToken */) : parenthesizer.parenthesizeExpressionOfExportDefault);
-      writeTrailingSemicolon();
-    }
-    function emitExportDeclaration(node) {
-      emitDecoratorsAndModifiers(
-        node,
-        node.modifiers,
-        /*allowDecorators*/
-        false
-      );
-      let nextPos = emitTokenWithComment(95 /* ExportKeyword */, node.pos, writeKeyword, node);
-      writeSpace();
-      if (node.isTypeOnly) {
-        nextPos = emitTokenWithComment(156 /* TypeKeyword */, nextPos, writeKeyword, node);
-        writeSpace();
-      }
-      if (node.exportClause) {
-        emit(node.exportClause);
-      } else {
-        nextPos = emitTokenWithComment(42 /* AsteriskToken */, nextPos, writePunctuation, node);
-      }
-      if (node.moduleSpecifier) {
-        writeSpace();
-        const fromPos = node.exportClause ? node.exportClause.end : nextPos;
-        emitTokenWithComment(160 /* FromKeyword */, fromPos, writeKeyword, node);
-        writeSpace();
-        emitExpression(node.moduleSpecifier);
-      }
-      if (node.assertClause) {
-        emitWithLeadingSpace(node.assertClause);
-      }
-      writeTrailingSemicolon();
-    }
-    function emitAssertClause(node) {
-      emitTokenWithComment(132 /* AssertKeyword */, node.pos, writeKeyword, node);
-      writeSpace();
-      const elements = node.elements;
-      emitList(node, elements, 526226 /* ImportClauseEntries */);
-    }
-    function emitAssertEntry(node) {
-      emit(node.name);
-      writePunctuation(":");
-      writeSpace();
-      const value = node.value;
-      if ((getEmitFlags(value) & 1024 /* NoLeadingComments */) === 0) {
-        const commentRange = getCommentRange(value);
-        emitTrailingCommentsOfPosition(commentRange.pos);
-      }
-      emit(value);
-    }
-    function emitNamespaceExportDeclaration(node) {
-      let nextPos = emitTokenWithComment(95 /* ExportKeyword */, node.pos, writeKeyword, node);
-      writeSpace();
-      nextPos = emitTokenWithComment(130 /* AsKeyword */, nextPos, writeKeyword, node);
-      writeSpace();
-      nextPos = emitTokenWithComment(145 /* NamespaceKeyword */, nextPos, writeKeyword, node);
-      writeSpace();
-      emit(node.name);
-      writeTrailingSemicolon();
-    }
-    function emitNamespaceExport(node) {
-      const asPos = emitTokenWithComment(42 /* AsteriskToken */, node.pos, writePunctuation, node);
-      writeSpace();
-      emitTokenWithComment(130 /* AsKeyword */, asPos, writeKeyword, node);
-      writeSpace();
-      emit(node.name);
-    }
-    function emitNamedExports(node) {
-      emitNamedImportsOrExports(node);
-    }
-    function emitExportSpecifier(node) {
-      emitImportOrExportSpecifier(node);
-    }
-    function emitNamedImportsOrExports(node) {
-      writePunctuation("{");
-      emitList(node, node.elements, 525136 /* NamedImportsOrExportsElements */);
-      writePunctuation("}");
-    }
-    function emitImportOrExportSpecifier(node) {
-      if (node.isTypeOnly) {
-        writeKeyword("type");
-        writeSpace();
-      }
-      if (node.propertyName) {
-        emit(node.propertyName);
-        writeSpace();
-        emitTokenWithComment(130 /* AsKeyword */, node.propertyName.end, writeKeyword, node);
-        writeSpace();
-      }
-      emit(node.name);
-    }
-    function emitExternalModuleReference(node) {
-      writeKeyword("require");
-      writePunctuation("(");
-      emitExpression(node.expression);
-      writePunctuation(")");
-    }
-    function emitJsxElement(node) {
-      emit(node.openingElement);
-      emitList(node, node.children, 262144 /* JsxElementOrFragmentChildren */);
-      emit(node.closingElement);
-    }
-    function emitJsxSelfClosingElement(node) {
-      writePunctuation("<");
-      emitJsxTagName(node.tagName);
-      emitTypeArguments(node, node.typeArguments);
-      writeSpace();
-      emit(node.attributes);
-      writePunctuation("/>");
-    }
-    function emitJsxFragment(node) {
-      emit(node.openingFragment);
-      emitList(node, node.children, 262144 /* JsxElementOrFragmentChildren */);
-      emit(node.closingFragment);
-    }
-    function emitJsxOpeningElementOrFragment(node) {
-      writePunctuation("<");
-      if (isJsxOpeningElement(node)) {
-        const indented = writeLineSeparatorsAndIndentBefore(node.tagName, node);
-        emitJsxTagName(node.tagName);
-        emitTypeArguments(node, node.typeArguments);
-        if (node.attributes.properties && node.attributes.properties.length > 0) {
-          writeSpace();
-        }
-        emit(node.attributes);
-        writeLineSeparatorsAfter(node.attributes, node);
-        decreaseIndentIf(indented);
-      }
-      writePunctuation(">");
-    }
-    function emitJsxText(node) {
-      writer.writeLiteral(node.text);
-    }
-    function emitJsxClosingElementOrFragment(node) {
-      writePunctuation("");
-    }
-    function emitJsxAttributes(node) {
-      emitList(node, node.properties, 262656 /* JsxElementAttributes */);
-    }
-    function emitJsxAttribute(node) {
-      emit(node.name);
-      emitNodeWithPrefix("=", writePunctuation, node.initializer, emitJsxAttributeValue);
-    }
-    function emitJsxSpreadAttribute(node) {
-      writePunctuation("{...");
-      emitExpression(node.expression);
-      writePunctuation("}");
-    }
-    function hasTrailingCommentsAtPosition(pos) {
-      let result = false;
-      forEachTrailingCommentRange((currentSourceFile == null ? void 0 : currentSourceFile.text) || "", pos + 1, () => result = true);
-      return result;
-    }
-    function hasLeadingCommentsAtPosition(pos) {
-      let result = false;
-      forEachLeadingCommentRange((currentSourceFile == null ? void 0 : currentSourceFile.text) || "", pos + 1, () => result = true);
-      return result;
-    }
-    function hasCommentsAtPosition(pos) {
-      return hasTrailingCommentsAtPosition(pos) || hasLeadingCommentsAtPosition(pos);
-    }
-    function emitJsxExpression(node) {
-      var _a;
-      if (node.expression || !commentsDisabled && !nodeIsSynthesized(node) && hasCommentsAtPosition(node.pos)) {
-        const isMultiline = currentSourceFile && !nodeIsSynthesized(node) && getLineAndCharacterOfPosition(currentSourceFile, node.pos).line !== getLineAndCharacterOfPosition(currentSourceFile, node.end).line;
-        if (isMultiline) {
-          writer.increaseIndent();
-        }
-        const end = emitTokenWithComment(19 /* OpenBraceToken */, node.pos, writePunctuation, node);
-        emit(node.dotDotDotToken);
-        emitExpression(node.expression);
-        emitTokenWithComment(20 /* CloseBraceToken */, ((_a = node.expression) == null ? void 0 : _a.end) || end, writePunctuation, node);
-        if (isMultiline) {
-          writer.decreaseIndent();
-        }
-      }
-    }
-    function emitJsxNamespacedName(node) {
-      emitIdentifierName(node.namespace);
-      writePunctuation(":");
-      emitIdentifierName(node.name);
-    }
-    function emitJsxTagName(node) {
-      if (node.kind === 80 /* Identifier */) {
-        emitExpression(node);
-      } else {
-        emit(node);
-      }
-    }
-    function emitCaseClause(node) {
-      emitTokenWithComment(84 /* CaseKeyword */, node.pos, writeKeyword, node);
-      writeSpace();
-      emitExpression(node.expression, parenthesizer.parenthesizeExpressionForDisallowedComma);
-      emitCaseOrDefaultClauseRest(node, node.statements, node.expression.end);
-    }
-    function emitDefaultClause(node) {
-      const pos = emitTokenWithComment(90 /* DefaultKeyword */, node.pos, writeKeyword, node);
-      emitCaseOrDefaultClauseRest(node, node.statements, pos);
-    }
-    function emitCaseOrDefaultClauseRest(parentNode, statements, colonPos) {
-      const emitAsSingleStatement = statements.length === 1 && // treat synthesized nodes as located on the same line for emit purposes
-      (!currentSourceFile || nodeIsSynthesized(parentNode) || nodeIsSynthesized(statements[0]) || rangeStartPositionsAreOnSameLine(parentNode, statements[0], currentSourceFile));
-      let format = 163969 /* CaseOrDefaultClauseStatements */;
-      if (emitAsSingleStatement) {
-        writeToken(59 /* ColonToken */, colonPos, writePunctuation, parentNode);
-        writeSpace();
-        format &= ~(1 /* MultiLine */ | 128 /* Indented */);
-      } else {
-        emitTokenWithComment(59 /* ColonToken */, colonPos, writePunctuation, parentNode);
-      }
-      emitList(parentNode, statements, format);
-    }
-    function emitHeritageClause(node) {
-      writeSpace();
-      writeTokenText(node.token, writeKeyword);
-      writeSpace();
-      emitList(node, node.types, 528 /* HeritageClauseTypes */);
-    }
-    function emitCatchClause(node) {
-      const openParenPos = emitTokenWithComment(85 /* CatchKeyword */, node.pos, writeKeyword, node);
-      writeSpace();
-      if (node.variableDeclaration) {
-        emitTokenWithComment(21 /* OpenParenToken */, openParenPos, writePunctuation, node);
-        emit(node.variableDeclaration);
-        emitTokenWithComment(22 /* CloseParenToken */, node.variableDeclaration.end, writePunctuation, node);
-        writeSpace();
-      }
-      emit(node.block);
-    }
-    function emitPropertyAssignment(node) {
-      emit(node.name);
-      writePunctuation(":");
-      writeSpace();
-      const initializer = node.initializer;
-      if ((getEmitFlags(initializer) & 1024 /* NoLeadingComments */) === 0) {
-        const commentRange = getCommentRange(initializer);
-        emitTrailingCommentsOfPosition(commentRange.pos);
-      }
-      emitExpression(initializer, parenthesizer.parenthesizeExpressionForDisallowedComma);
-    }
-    function emitShorthandPropertyAssignment(node) {
-      emit(node.name);
-      if (node.objectAssignmentInitializer) {
-        writeSpace();
-        writePunctuation("=");
-        writeSpace();
-        emitExpression(node.objectAssignmentInitializer, parenthesizer.parenthesizeExpressionForDisallowedComma);
-      }
-    }
-    function emitSpreadAssignment(node) {
-      if (node.expression) {
-        emitTokenWithComment(26 /* DotDotDotToken */, node.pos, writePunctuation, node);
-        emitExpression(node.expression, parenthesizer.parenthesizeExpressionForDisallowedComma);
-      }
-    }
-    function emitEnumMember(node) {
-      emit(node.name);
-      emitInitializer(node.initializer, node.name.end, node, parenthesizer.parenthesizeExpressionForDisallowedComma);
-    }
-    function emitJSDoc(node) {
-      write("/**");
-      if (node.comment) {
-        const text = getTextOfJSDocComment(node.comment);
-        if (text) {
-          const lines = text.split(/\r\n?|\n/g);
-          for (const line of lines) {
-            writeLine();
-            writeSpace();
-            writePunctuation("*");
-            writeSpace();
-            write(line);
-          }
-        }
-      }
-      if (node.tags) {
-        if (node.tags.length === 1 && node.tags[0].kind === 350 /* JSDocTypeTag */ && !node.comment) {
-          writeSpace();
-          emit(node.tags[0]);
-        } else {
-          emitList(node, node.tags, 33 /* JSDocComment */);
-        }
-      }
-      writeSpace();
-      write("*/");
-    }
-    function emitJSDocSimpleTypedTag(tag) {
-      emitJSDocTagName(tag.tagName);
-      emitJSDocTypeExpression(tag.typeExpression);
-      emitJSDocComment(tag.comment);
-    }
-    function emitJSDocSeeTag(tag) {
-      emitJSDocTagName(tag.tagName);
-      emit(tag.name);
-      emitJSDocComment(tag.comment);
-    }
-    function emitJSDocNameReference(node) {
-      writeSpace();
-      writePunctuation("{");
-      emit(node.name);
-      writePunctuation("}");
-    }
-    function emitJSDocHeritageTag(tag) {
-      emitJSDocTagName(tag.tagName);
-      writeSpace();
-      writePunctuation("{");
-      emit(tag.class);
-      writePunctuation("}");
-      emitJSDocComment(tag.comment);
-    }
-    function emitJSDocTemplateTag(tag) {
-      emitJSDocTagName(tag.tagName);
-      emitJSDocTypeExpression(tag.constraint);
-      writeSpace();
-      emitList(tag, tag.typeParameters, 528 /* CommaListElements */);
-      emitJSDocComment(tag.comment);
-    }
-    function emitJSDocTypedefTag(tag) {
-      emitJSDocTagName(tag.tagName);
-      if (tag.typeExpression) {
-        if (tag.typeExpression.kind === 315 /* JSDocTypeExpression */) {
-          emitJSDocTypeExpression(tag.typeExpression);
-        } else {
-          writeSpace();
-          writePunctuation("{");
-          write("Object");
-          if (tag.typeExpression.isArrayType) {
-            writePunctuation("[");
-            writePunctuation("]");
-          }
-          writePunctuation("}");
-        }
-      }
-      if (tag.fullName) {
-        writeSpace();
-        emit(tag.fullName);
-      }
-      emitJSDocComment(tag.comment);
-      if (tag.typeExpression && tag.typeExpression.kind === 328 /* JSDocTypeLiteral */) {
-        emitJSDocTypeLiteral(tag.typeExpression);
-      }
-    }
-    function emitJSDocCallbackTag(tag) {
-      emitJSDocTagName(tag.tagName);
-      if (tag.name) {
-        writeSpace();
-        emit(tag.name);
-      }
-      emitJSDocComment(tag.comment);
-      emitJSDocSignature(tag.typeExpression);
-    }
-    function emitJSDocOverloadTag(tag) {
-      emitJSDocComment(tag.comment);
-      emitJSDocSignature(tag.typeExpression);
-    }
-    function emitJSDocSimpleTag(tag) {
-      emitJSDocTagName(tag.tagName);
-      emitJSDocComment(tag.comment);
-    }
-    function emitJSDocTypeLiteral(lit) {
-      emitList(lit, factory.createNodeArray(lit.jsDocPropertyTags), 33 /* JSDocComment */);
-    }
-    function emitJSDocSignature(sig) {
-      if (sig.typeParameters) {
-        emitList(sig, factory.createNodeArray(sig.typeParameters), 33 /* JSDocComment */);
-      }
-      if (sig.parameters) {
-        emitList(sig, factory.createNodeArray(sig.parameters), 33 /* JSDocComment */);
-      }
-      if (sig.type) {
-        writeLine();
-        writeSpace();
-        writePunctuation("*");
-        writeSpace();
-        emit(sig.type);
-      }
-    }
-    function emitJSDocPropertyLikeTag(param) {
-      emitJSDocTagName(param.tagName);
-      emitJSDocTypeExpression(param.typeExpression);
-      writeSpace();
-      if (param.isBracketed) {
-        writePunctuation("[");
-      }
-      emit(param.name);
-      if (param.isBracketed) {
-        writePunctuation("]");
-      }
-      emitJSDocComment(param.comment);
-    }
-    function emitJSDocTagName(tagName) {
-      writePunctuation("@");
-      emit(tagName);
-    }
-    function emitJSDocComment(comment) {
-      const text = getTextOfJSDocComment(comment);
-      if (text) {
-        writeSpace();
-        write(text);
-      }
-    }
-    function emitJSDocTypeExpression(typeExpression) {
-      if (typeExpression) {
-        writeSpace();
-        writePunctuation("{");
-        emit(typeExpression.type);
-        writePunctuation("}");
-      }
-    }
-    function emitSourceFile(node) {
-      writeLine();
-      const statements = node.statements;
-      const shouldEmitDetachedComment = statements.length === 0 || !isPrologueDirective(statements[0]) || nodeIsSynthesized(statements[0]);
-      if (shouldEmitDetachedComment) {
-        emitBodyWithDetachedComments(node, statements, emitSourceFileWorker);
-        return;
-      }
-      emitSourceFileWorker(node);
-    }
-    function emitSyntheticTripleSlashReferencesIfNeeded(node) {
-      emitTripleSlashDirectives(!!node.hasNoDefaultLib, node.syntheticFileReferences || [], node.syntheticTypeReferences || [], node.syntheticLibReferences || []);
-      for (const prepend of node.prepends) {
-        if (isUnparsedSource(prepend) && prepend.syntheticReferences) {
-          for (const ref of prepend.syntheticReferences) {
-            emit(ref);
-            writeLine();
-          }
-        }
-      }
-    }
-    function emitTripleSlashDirectivesIfNeeded(node) {
-      if (node.isDeclarationFile)
-        emitTripleSlashDirectives(node.hasNoDefaultLib, node.referencedFiles, node.typeReferenceDirectives, node.libReferenceDirectives);
-    }
-    function emitTripleSlashDirectives(hasNoDefaultLib, files, types, libs2) {
-      if (hasNoDefaultLib) {
-        const pos = writer.getTextPos();
-        writeComment(`/// `);
-        if (bundleFileInfo)
-          bundleFileInfo.sections.push({ pos, end: writer.getTextPos(), kind: "no-default-lib" /* NoDefaultLib */ });
-        writeLine();
-      }
-      if (currentSourceFile && currentSourceFile.moduleName) {
-        writeComment(`/// `);
-        writeLine();
-      }
-      if (currentSourceFile && currentSourceFile.amdDependencies) {
-        for (const dep of currentSourceFile.amdDependencies) {
-          if (dep.name) {
-            writeComment(`/// `);
-          } else {
-            writeComment(`/// `);
-          }
-          writeLine();
-        }
-      }
-      for (const directive of files) {
-        const pos = writer.getTextPos();
-        writeComment(`/// `);
-        if (bundleFileInfo)
-          bundleFileInfo.sections.push({ pos, end: writer.getTextPos(), kind: "reference" /* Reference */, data: directive.fileName });
-        writeLine();
-      }
-      for (const directive of types) {
-        const pos = writer.getTextPos();
-        const resolutionMode = directive.resolutionMode && directive.resolutionMode !== (currentSourceFile == null ? void 0 : currentSourceFile.impliedNodeFormat) ? `resolution-mode="${directive.resolutionMode === 99 /* ESNext */ ? "import" : "require"}"` : "";
-        writeComment(`/// `);
-        if (bundleFileInfo)
-          bundleFileInfo.sections.push({ pos, end: writer.getTextPos(), kind: !directive.resolutionMode ? "type" /* Type */ : directive.resolutionMode === 99 /* ESNext */ ? "type-import" /* TypeResolutionModeImport */ : "type-require" /* TypeResolutionModeRequire */, data: directive.fileName });
-        writeLine();
-      }
-      for (const directive of libs2) {
-        const pos = writer.getTextPos();
-        writeComment(`/// `);
-        if (bundleFileInfo)
-          bundleFileInfo.sections.push({ pos, end: writer.getTextPos(), kind: "lib" /* Lib */, data: directive.fileName });
-        writeLine();
-      }
-    }
-    function emitSourceFileWorker(node) {
-      const statements = node.statements;
-      pushNameGenerationScope(node);
-      forEach(node.statements, generateNames);
-      emitHelpers(node);
-      const index = findIndex(statements, (statement) => !isPrologueDirective(statement));
-      emitTripleSlashDirectivesIfNeeded(node);
-      emitList(
-        node,
-        statements,
-        1 /* MultiLine */,
-        /*parenthesizerRule*/
-        void 0,
-        index === -1 ? statements.length : index
-      );
-      popNameGenerationScope(node);
-    }
-    function emitPartiallyEmittedExpression(node) {
-      const emitFlags = getEmitFlags(node);
-      if (!(emitFlags & 1024 /* NoLeadingComments */) && node.pos !== node.expression.pos) {
-        emitTrailingCommentsOfPosition(node.expression.pos);
-      }
-      emitExpression(node.expression);
-      if (!(emitFlags & 2048 /* NoTrailingComments */) && node.end !== node.expression.end) {
-        emitLeadingCommentsOfPosition(node.expression.end);
-      }
-    }
-    function emitCommaList(node) {
-      emitExpressionList(
-        node,
-        node.elements,
-        528 /* CommaListElements */,
-        /*parenthesizerRule*/
-        void 0
-      );
-    }
-    function emitPrologueDirectives(statements, sourceFile, seenPrologueDirectives, recordBundleFileSection) {
-      let needsToSetSourceFile = !!sourceFile;
-      for (let i = 0; i < statements.length; i++) {
-        const statement = statements[i];
-        if (isPrologueDirective(statement)) {
-          const shouldEmitPrologueDirective = seenPrologueDirectives ? !seenPrologueDirectives.has(statement.expression.text) : true;
-          if (shouldEmitPrologueDirective) {
-            if (needsToSetSourceFile) {
-              needsToSetSourceFile = false;
-              setSourceFile(sourceFile);
-            }
-            writeLine();
-            const pos = writer.getTextPos();
-            emit(statement);
-            if (recordBundleFileSection && bundleFileInfo)
-              bundleFileInfo.sections.push({ pos, end: writer.getTextPos(), kind: "prologue" /* Prologue */, data: statement.expression.text });
-            if (seenPrologueDirectives) {
-              seenPrologueDirectives.add(statement.expression.text);
-            }
-          }
-        } else {
-          return i;
-        }
-      }
-      return statements.length;
-    }
-    function emitUnparsedPrologues(prologues, seenPrologueDirectives) {
-      for (const prologue of prologues) {
-        if (!seenPrologueDirectives.has(prologue.data)) {
-          writeLine();
-          const pos = writer.getTextPos();
-          emit(prologue);
-          if (bundleFileInfo)
-            bundleFileInfo.sections.push({ pos, end: writer.getTextPos(), kind: "prologue" /* Prologue */, data: prologue.data });
-          if (seenPrologueDirectives) {
-            seenPrologueDirectives.add(prologue.data);
-          }
-        }
-      }
-    }
-    function emitPrologueDirectivesIfNeeded(sourceFileOrBundle) {
-      if (isSourceFile(sourceFileOrBundle)) {
-        emitPrologueDirectives(sourceFileOrBundle.statements, sourceFileOrBundle);
-      } else {
-        const seenPrologueDirectives = /* @__PURE__ */ new Set();
-        for (const prepend of sourceFileOrBundle.prepends) {
-          emitUnparsedPrologues(prepend.prologues, seenPrologueDirectives);
-        }
-        for (const sourceFile of sourceFileOrBundle.sourceFiles) {
-          emitPrologueDirectives(
-            sourceFile.statements,
-            sourceFile,
-            seenPrologueDirectives,
-            /*recordBundleFileSection*/
-            true
-          );
-        }
-        setSourceFile(void 0);
-      }
-    }
-    function getPrologueDirectivesFromBundledSourceFiles(bundle) {
-      const seenPrologueDirectives = /* @__PURE__ */ new Set();
-      let prologues;
-      for (let index = 0; index < bundle.sourceFiles.length; index++) {
-        const sourceFile = bundle.sourceFiles[index];
-        let directives;
-        let end = 0;
-        for (const statement of sourceFile.statements) {
-          if (!isPrologueDirective(statement))
-            break;
-          if (seenPrologueDirectives.has(statement.expression.text))
-            continue;
-          seenPrologueDirectives.add(statement.expression.text);
-          (directives || (directives = [])).push({
-            pos: statement.pos,
-            end: statement.end,
-            expression: {
-              pos: statement.expression.pos,
-              end: statement.expression.end,
-              text: statement.expression.text
-            }
-          });
-          end = end < statement.end ? statement.end : end;
-        }
-        if (directives)
-          (prologues || (prologues = [])).push({ file: index, text: sourceFile.text.substring(0, end), directives });
-      }
-      return prologues;
-    }
-    function emitShebangIfNeeded(sourceFileOrBundle) {
-      if (isSourceFile(sourceFileOrBundle) || isUnparsedSource(sourceFileOrBundle)) {
-        const shebang = getShebang(sourceFileOrBundle.text);
-        if (shebang) {
-          writeComment(shebang);
-          writeLine();
-          return true;
-        }
-      } else {
-        for (const prepend of sourceFileOrBundle.prepends) {
-          Debug.assertNode(prepend, isUnparsedSource);
-          if (emitShebangIfNeeded(prepend)) {
-            return true;
-          }
-        }
-        for (const sourceFile of sourceFileOrBundle.sourceFiles) {
-          if (emitShebangIfNeeded(sourceFile)) {
-            return true;
-          }
-        }
-      }
-    }
-    function emitNodeWithWriter(node, writer2) {
-      if (!node)
-        return;
-      const savedWrite = write;
-      write = writer2;
-      emit(node);
-      write = savedWrite;
-    }
-    function emitDecoratorsAndModifiers(node, modifiers, allowDecorators) {
-      if (modifiers == null ? void 0 : modifiers.length) {
-        if (every(modifiers, isModifier)) {
-          return emitModifierList(node, modifiers);
-        }
-        if (every(modifiers, isDecorator)) {
-          if (allowDecorators) {
-            return emitDecoratorList(node, modifiers);
-          }
-          return node.pos;
-        }
-        onBeforeEmitNodeArray == null ? void 0 : onBeforeEmitNodeArray(modifiers);
-        let lastMode;
-        let mode;
-        let start = 0;
-        let pos = 0;
-        let lastModifier;
-        while (start < modifiers.length) {
-          while (pos < modifiers.length) {
-            lastModifier = modifiers[pos];
-            mode = isDecorator(lastModifier) ? "decorators" : "modifiers";
-            if (lastMode === void 0) {
-              lastMode = mode;
-            } else if (mode !== lastMode) {
-              break;
-            }
-            pos++;
-          }
-          const textRange = { pos: -1, end: -1 };
-          if (start === 0)
-            textRange.pos = modifiers.pos;
-          if (pos === modifiers.length - 1)
-            textRange.end = modifiers.end;
-          if (lastMode === "modifiers" || allowDecorators) {
-            emitNodeListItems(
-              emit,
-              node,
-              modifiers,
-              lastMode === "modifiers" ? 2359808 /* Modifiers */ : 2146305 /* Decorators */,
-              /*parenthesizerRule*/
-              void 0,
-              start,
-              pos - start,
-              /*hasTrailingComma*/
-              false,
-              textRange
-            );
-          }
-          start = pos;
-          lastMode = mode;
-          pos++;
-        }
-        onAfterEmitNodeArray == null ? void 0 : onAfterEmitNodeArray(modifiers);
-        if (lastModifier && !positionIsSynthesized(lastModifier.end)) {
-          return lastModifier.end;
-        }
-      }
-      return node.pos;
-    }
-    function emitModifierList(node, modifiers) {
-      emitList(node, modifiers, 2359808 /* Modifiers */);
-      const lastModifier = lastOrUndefined(modifiers);
-      return lastModifier && !positionIsSynthesized(lastModifier.end) ? lastModifier.end : node.pos;
-    }
-    function emitTypeAnnotation(node) {
-      if (node) {
-        writePunctuation(":");
-        writeSpace();
-        emit(node);
-      }
-    }
-    function emitInitializer(node, equalCommentStartPos, container, parenthesizerRule) {
-      if (node) {
-        writeSpace();
-        emitTokenWithComment(64 /* EqualsToken */, equalCommentStartPos, writeOperator, container);
-        writeSpace();
-        emitExpression(node, parenthesizerRule);
-      }
-    }
-    function emitNodeWithPrefix(prefix, prefixWriter, node, emit2) {
-      if (node) {
-        prefixWriter(prefix);
-        emit2(node);
-      }
-    }
-    function emitWithLeadingSpace(node) {
-      if (node) {
-        writeSpace();
-        emit(node);
-      }
-    }
-    function emitExpressionWithLeadingSpace(node, parenthesizerRule) {
-      if (node) {
-        writeSpace();
-        emitExpression(node, parenthesizerRule);
-      }
-    }
-    function emitWithTrailingSpace(node) {
-      if (node) {
-        emit(node);
-        writeSpace();
-      }
-    }
-    function emitEmbeddedStatement(parent2, node) {
-      if (isBlock(node) || getEmitFlags(parent2) & 1 /* SingleLine */ || preserveSourceNewlines && !getLeadingLineTerminatorCount(parent2, node, 0 /* None */)) {
-        writeSpace();
-        emit(node);
-      } else {
-        writeLine();
-        increaseIndent();
-        if (isEmptyStatement(node)) {
-          pipelineEmit(5 /* EmbeddedStatement */, node);
-        } else {
-          emit(node);
-        }
-        decreaseIndent();
-      }
-    }
-    function emitDecoratorList(parentNode, decorators) {
-      emitList(parentNode, decorators, 2146305 /* Decorators */);
-      const lastDecorator = lastOrUndefined(decorators);
-      return lastDecorator && !positionIsSynthesized(lastDecorator.end) ? lastDecorator.end : parentNode.pos;
-    }
-    function emitTypeArguments(parentNode, typeArguments) {
-      emitList(parentNode, typeArguments, 53776 /* TypeArguments */, typeArgumentParenthesizerRuleSelector);
-    }
-    function emitTypeParameters(parentNode, typeParameters) {
-      if (isFunctionLike(parentNode) && parentNode.typeArguments) {
-        return emitTypeArguments(parentNode, parentNode.typeArguments);
-      }
-      emitList(parentNode, typeParameters, 53776 /* TypeParameters */);
-    }
-    function emitParameters(parentNode, parameters) {
-      emitList(parentNode, parameters, 2576 /* Parameters */);
-    }
-    function canEmitSimpleArrowHead(parentNode, parameters) {
-      const parameter = singleOrUndefined(parameters);
-      return parameter && parameter.pos === parentNode.pos && isArrowFunction(parentNode) && !parentNode.type && !some(parentNode.modifiers) && !some(parentNode.typeParameters) && !some(parameter.modifiers) && !parameter.dotDotDotToken && !parameter.questionToken && !parameter.type && !parameter.initializer && isIdentifier(parameter.name);
-    }
-    function emitParametersForArrow(parentNode, parameters) {
-      if (canEmitSimpleArrowHead(parentNode, parameters)) {
-        emitList(parentNode, parameters, 2576 /* Parameters */ & ~2048 /* Parenthesis */);
-      } else {
-        emitParameters(parentNode, parameters);
-      }
-    }
-    function emitParametersForIndexSignature(parentNode, parameters) {
-      emitList(parentNode, parameters, 8848 /* IndexSignatureParameters */);
-    }
-    function writeDelimiter(format) {
-      switch (format & 60 /* DelimitersMask */) {
-        case 0 /* None */:
-          break;
-        case 16 /* CommaDelimited */:
-          writePunctuation(",");
-          break;
-        case 4 /* BarDelimited */:
-          writeSpace();
-          writePunctuation("|");
-          break;
-        case 32 /* AsteriskDelimited */:
-          writeSpace();
-          writePunctuation("*");
-          writeSpace();
-          break;
-        case 8 /* AmpersandDelimited */:
-          writeSpace();
-          writePunctuation("&");
-          break;
-      }
-    }
-    function emitList(parentNode, children, format, parenthesizerRule, start, count) {
-      emitNodeList(
-        emit,
-        parentNode,
-        children,
-        format | (parentNode && getEmitFlags(parentNode) & 2 /* MultiLine */ ? 65536 /* PreferNewLine */ : 0),
-        parenthesizerRule,
-        start,
-        count
-      );
-    }
-    function emitExpressionList(parentNode, children, format, parenthesizerRule, start, count) {
-      emitNodeList(emitExpression, parentNode, children, format, parenthesizerRule, start, count);
-    }
-    function emitNodeList(emit2, parentNode, children, format, parenthesizerRule, start = 0, count = children ? children.length - start : 0) {
-      const isUndefined = children === void 0;
-      if (isUndefined && format & 16384 /* OptionalIfUndefined */) {
-        return;
-      }
-      const isEmpty = children === void 0 || start >= children.length || count === 0;
-      if (isEmpty && format & 32768 /* OptionalIfEmpty */) {
-        onBeforeEmitNodeArray == null ? void 0 : onBeforeEmitNodeArray(children);
-        onAfterEmitNodeArray == null ? void 0 : onAfterEmitNodeArray(children);
-        return;
-      }
-      if (format & 15360 /* BracketsMask */) {
-        writePunctuation(getOpeningBracket(format));
-        if (isEmpty && children) {
-          emitTrailingCommentsOfPosition(
-            children.pos,
-            /*prefixSpace*/
-            true
-          );
-        }
-      }
-      onBeforeEmitNodeArray == null ? void 0 : onBeforeEmitNodeArray(children);
-      if (isEmpty) {
-        if (format & 1 /* MultiLine */ && !(preserveSourceNewlines && (!parentNode || currentSourceFile && rangeIsOnSingleLine(parentNode, currentSourceFile)))) {
-          writeLine();
-        } else if (format & 256 /* SpaceBetweenBraces */ && !(format & 524288 /* NoSpaceIfEmpty */)) {
-          writeSpace();
-        }
-      } else {
-        emitNodeListItems(emit2, parentNode, children, format, parenthesizerRule, start, count, children.hasTrailingComma, children);
-      }
-      onAfterEmitNodeArray == null ? void 0 : onAfterEmitNodeArray(children);
-      if (format & 15360 /* BracketsMask */) {
-        if (isEmpty && children) {
-          emitLeadingCommentsOfPosition(children.end);
-        }
-        writePunctuation(getClosingBracket(format));
-      }
-    }
-    function emitNodeListItems(emit2, parentNode, children, format, parenthesizerRule, start, count, hasTrailingComma, childrenTextRange) {
-      const mayEmitInterveningComments = (format & 262144 /* NoInterveningComments */) === 0;
-      let shouldEmitInterveningComments = mayEmitInterveningComments;
-      const leadingLineTerminatorCount = getLeadingLineTerminatorCount(parentNode, children[start], format);
-      if (leadingLineTerminatorCount) {
-        writeLine(leadingLineTerminatorCount);
-        shouldEmitInterveningComments = false;
-      } else if (format & 256 /* SpaceBetweenBraces */) {
-        writeSpace();
-      }
-      if (format & 128 /* Indented */) {
-        increaseIndent();
-      }
-      const emitListItem = getEmitListItem(emit2, parenthesizerRule);
-      let previousSibling;
-      let previousSourceFileTextKind;
-      let shouldDecreaseIndentAfterEmit = false;
-      for (let i = 0; i < count; i++) {
-        const child = children[start + i];
-        if (format & 32 /* AsteriskDelimited */) {
-          writeLine();
-          writeDelimiter(format);
-        } else if (previousSibling) {
-          if (format & 60 /* DelimitersMask */ && previousSibling.end !== (parentNode ? parentNode.end : -1)) {
-            const previousSiblingEmitFlags = getEmitFlags(previousSibling);
-            if (!(previousSiblingEmitFlags & 2048 /* NoTrailingComments */)) {
-              emitLeadingCommentsOfPosition(previousSibling.end);
-            }
-          }
-          writeDelimiter(format);
-          recordBundleFileInternalSectionEnd(previousSourceFileTextKind);
-          const separatingLineTerminatorCount = getSeparatingLineTerminatorCount(previousSibling, child, format);
-          if (separatingLineTerminatorCount > 0) {
-            if ((format & (3 /* LinesMask */ | 128 /* Indented */)) === 0 /* SingleLine */) {
-              increaseIndent();
-              shouldDecreaseIndentAfterEmit = true;
-            }
-            writeLine(separatingLineTerminatorCount);
-            shouldEmitInterveningComments = false;
-          } else if (previousSibling && format & 512 /* SpaceBetweenSiblings */) {
-            writeSpace();
-          }
-        }
-        previousSourceFileTextKind = recordBundleFileInternalSectionStart(child);
-        if (shouldEmitInterveningComments) {
-          const commentRange = getCommentRange(child);
-          emitTrailingCommentsOfPosition(commentRange.pos);
-        } else {
-          shouldEmitInterveningComments = mayEmitInterveningComments;
-        }
-        nextListElementPos = child.pos;
-        emitListItem(child, emit2, parenthesizerRule, i);
-        if (shouldDecreaseIndentAfterEmit) {
-          decreaseIndent();
-          shouldDecreaseIndentAfterEmit = false;
-        }
-        previousSibling = child;
-      }
-      const emitFlags = previousSibling ? getEmitFlags(previousSibling) : 0;
-      const skipTrailingComments = commentsDisabled || !!(emitFlags & 2048 /* NoTrailingComments */);
-      const emitTrailingComma = hasTrailingComma && format & 64 /* AllowTrailingComma */ && format & 16 /* CommaDelimited */;
-      if (emitTrailingComma) {
-        if (previousSibling && !skipTrailingComments) {
-          emitTokenWithComment(28 /* CommaToken */, previousSibling.end, writePunctuation, previousSibling);
-        } else {
-          writePunctuation(",");
-        }
-      }
-      if (previousSibling && (parentNode ? parentNode.end : -1) !== previousSibling.end && format & 60 /* DelimitersMask */ && !skipTrailingComments) {
-        emitLeadingCommentsOfPosition(emitTrailingComma && (childrenTextRange == null ? void 0 : childrenTextRange.end) ? childrenTextRange.end : previousSibling.end);
-      }
-      if (format & 128 /* Indented */) {
-        decreaseIndent();
-      }
-      recordBundleFileInternalSectionEnd(previousSourceFileTextKind);
-      const closingLineTerminatorCount = getClosingLineTerminatorCount(parentNode, children[start + count - 1], format, childrenTextRange);
-      if (closingLineTerminatorCount) {
-        writeLine(closingLineTerminatorCount);
-      } else if (format & (2097152 /* SpaceAfterList */ | 256 /* SpaceBetweenBraces */)) {
-        writeSpace();
-      }
-    }
-    function writeLiteral(s) {
-      writer.writeLiteral(s);
-    }
-    function writeStringLiteral(s) {
-      writer.writeStringLiteral(s);
-    }
-    function writeBase(s) {
-      writer.write(s);
-    }
-    function writeSymbol(s, sym) {
-      writer.writeSymbol(s, sym);
-    }
-    function writePunctuation(s) {
-      writer.writePunctuation(s);
-    }
-    function writeTrailingSemicolon() {
-      writer.writeTrailingSemicolon(";");
-    }
-    function writeKeyword(s) {
-      writer.writeKeyword(s);
-    }
-    function writeOperator(s) {
-      writer.writeOperator(s);
-    }
-    function writeParameter(s) {
-      writer.writeParameter(s);
-    }
-    function writeComment(s) {
-      writer.writeComment(s);
-    }
-    function writeSpace() {
-      writer.writeSpace(" ");
-    }
-    function writeProperty(s) {
-      writer.writeProperty(s);
-    }
-    function nonEscapingWrite(s) {
-      if (writer.nonEscapingWrite) {
-        writer.nonEscapingWrite(s);
-      } else {
-        writer.write(s);
-      }
-    }
-    function writeLine(count = 1) {
-      for (let i = 0; i < count; i++) {
-        writer.writeLine(i > 0);
-      }
-    }
-    function increaseIndent() {
-      writer.increaseIndent();
-    }
-    function decreaseIndent() {
-      writer.decreaseIndent();
-    }
-    function writeToken(token, pos, writer2, contextNode) {
-      return !sourceMapsDisabled ? emitTokenWithSourceMap(contextNode, token, writer2, pos, writeTokenText) : writeTokenText(token, writer2, pos);
-    }
-    function writeTokenNode(node, writer2) {
-      if (onBeforeEmitToken) {
-        onBeforeEmitToken(node);
-      }
-      writer2(tokenToString(node.kind));
-      if (onAfterEmitToken) {
-        onAfterEmitToken(node);
-      }
-    }
-    function writeTokenText(token, writer2, pos) {
-      const tokenString = tokenToString(token);
-      writer2(tokenString);
-      return pos < 0 ? pos : pos + tokenString.length;
-    }
-    function writeLineOrSpace(parentNode, prevChildNode, nextChildNode) {
-      if (getEmitFlags(parentNode) & 1 /* SingleLine */) {
-        writeSpace();
-      } else if (preserveSourceNewlines) {
-        const lines = getLinesBetweenNodes(parentNode, prevChildNode, nextChildNode);
-        if (lines) {
-          writeLine(lines);
-        } else {
-          writeSpace();
-        }
-      } else {
-        writeLine();
-      }
-    }
-    function writeLines(text) {
-      const lines = text.split(/\r\n?|\n/g);
-      const indentation = guessIndentation(lines);
-      for (const lineText of lines) {
-        const line = indentation ? lineText.slice(indentation) : lineText;
-        if (line.length) {
-          writeLine();
-          write(line);
-        }
-      }
-    }
-    function writeLinesAndIndent(lineCount, writeSpaceIfNotIndenting) {
-      if (lineCount) {
-        increaseIndent();
-        writeLine(lineCount);
-      } else if (writeSpaceIfNotIndenting) {
-        writeSpace();
-      }
-    }
-    function decreaseIndentIf(value1, value2) {
-      if (value1) {
-        decreaseIndent();
-      }
-      if (value2) {
-        decreaseIndent();
-      }
-    }
-    function getLeadingLineTerminatorCount(parentNode, firstChild, format) {
-      if (format & 2 /* PreserveLines */ || preserveSourceNewlines) {
-        if (format & 65536 /* PreferNewLine */) {
-          return 1;
-        }
-        if (firstChild === void 0) {
-          return !parentNode || currentSourceFile && rangeIsOnSingleLine(parentNode, currentSourceFile) ? 0 : 1;
-        }
-        if (firstChild.pos === nextListElementPos) {
-          return 0;
-        }
-        if (firstChild.kind === 12 /* JsxText */) {
-          return 0;
-        }
-        if (currentSourceFile && parentNode && !positionIsSynthesized(parentNode.pos) && !nodeIsSynthesized(firstChild) && (!firstChild.parent || getOriginalNode(firstChild.parent) === getOriginalNode(parentNode))) {
-          if (preserveSourceNewlines) {
-            return getEffectiveLines(
-              (includeComments) => getLinesBetweenPositionAndPrecedingNonWhitespaceCharacter(
-                firstChild.pos,
-                parentNode.pos,
-                currentSourceFile,
-                includeComments
-              )
-            );
-          }
-          return rangeStartPositionsAreOnSameLine(parentNode, firstChild, currentSourceFile) ? 0 : 1;
-        }
-        if (synthesizedNodeStartsOnNewLine(firstChild, format)) {
-          return 1;
-        }
-      }
-      return format & 1 /* MultiLine */ ? 1 : 0;
-    }
-    function getSeparatingLineTerminatorCount(previousNode, nextNode, format) {
-      if (format & 2 /* PreserveLines */ || preserveSourceNewlines) {
-        if (previousNode === void 0 || nextNode === void 0) {
-          return 0;
-        }
-        if (nextNode.kind === 12 /* JsxText */) {
-          return 0;
-        } else if (currentSourceFile && !nodeIsSynthesized(previousNode) && !nodeIsSynthesized(nextNode)) {
-          if (preserveSourceNewlines && siblingNodePositionsAreComparable(previousNode, nextNode)) {
-            return getEffectiveLines(
-              (includeComments) => getLinesBetweenRangeEndAndRangeStart(
-                previousNode,
-                nextNode,
-                currentSourceFile,
-                includeComments
-              )
-            );
-          } else if (!preserveSourceNewlines && originalNodesHaveSameParent(previousNode, nextNode)) {
-            return rangeEndIsOnSameLineAsRangeStart(previousNode, nextNode, currentSourceFile) ? 0 : 1;
-          }
-          return format & 65536 /* PreferNewLine */ ? 1 : 0;
-        } else if (synthesizedNodeStartsOnNewLine(previousNode, format) || synthesizedNodeStartsOnNewLine(nextNode, format)) {
-          return 1;
-        }
-      } else if (getStartsOnNewLine(nextNode)) {
-        return 1;
-      }
-      return format & 1 /* MultiLine */ ? 1 : 0;
-    }
-    function getClosingLineTerminatorCount(parentNode, lastChild, format, childrenTextRange) {
-      if (format & 2 /* PreserveLines */ || preserveSourceNewlines) {
-        if (format & 65536 /* PreferNewLine */) {
-          return 1;
-        }
-        if (lastChild === void 0) {
-          return !parentNode || currentSourceFile && rangeIsOnSingleLine(parentNode, currentSourceFile) ? 0 : 1;
-        }
-        if (currentSourceFile && parentNode && !positionIsSynthesized(parentNode.pos) && !nodeIsSynthesized(lastChild) && (!lastChild.parent || lastChild.parent === parentNode)) {
-          if (preserveSourceNewlines) {
-            const end = childrenTextRange && !positionIsSynthesized(childrenTextRange.end) ? childrenTextRange.end : lastChild.end;
-            return getEffectiveLines(
-              (includeComments) => getLinesBetweenPositionAndNextNonWhitespaceCharacter(
-                end,
-                parentNode.end,
-                currentSourceFile,
-                includeComments
-              )
-            );
-          }
-          return rangeEndPositionsAreOnSameLine(parentNode, lastChild, currentSourceFile) ? 0 : 1;
-        }
-        if (synthesizedNodeStartsOnNewLine(lastChild, format)) {
-          return 1;
-        }
-      }
-      if (format & 1 /* MultiLine */ && !(format & 131072 /* NoTrailingNewLine */)) {
-        return 1;
-      }
-      return 0;
-    }
-    function getEffectiveLines(getLineDifference) {
-      Debug.assert(!!preserveSourceNewlines);
-      const lines = getLineDifference(
-        /*includeComments*/
-        true
-      );
-      if (lines === 0) {
-        return getLineDifference(
-          /*includeComments*/
-          false
-        );
-      }
-      return lines;
-    }
-    function writeLineSeparatorsAndIndentBefore(node, parent2) {
-      const leadingNewlines = preserveSourceNewlines && getLeadingLineTerminatorCount(parent2, node, 0 /* None */);
-      if (leadingNewlines) {
-        writeLinesAndIndent(
-          leadingNewlines,
-          /*writeSpaceIfNotIndenting*/
-          false
-        );
-      }
-      return !!leadingNewlines;
-    }
-    function writeLineSeparatorsAfter(node, parent2) {
-      const trailingNewlines = preserveSourceNewlines && getClosingLineTerminatorCount(
-        parent2,
-        node,
-        0 /* None */,
-        /*childrenTextRange*/
-        void 0
-      );
-      if (trailingNewlines) {
-        writeLine(trailingNewlines);
-      }
-    }
-    function synthesizedNodeStartsOnNewLine(node, format) {
-      if (nodeIsSynthesized(node)) {
-        const startsOnNewLine = getStartsOnNewLine(node);
-        if (startsOnNewLine === void 0) {
-          return (format & 65536 /* PreferNewLine */) !== 0;
-        }
-        return startsOnNewLine;
-      }
-      return (format & 65536 /* PreferNewLine */) !== 0;
-    }
-    function getLinesBetweenNodes(parent2, node1, node2) {
-      if (getEmitFlags(parent2) & 262144 /* NoIndentation */) {
-        return 0;
-      }
-      parent2 = skipSynthesizedParentheses(parent2);
-      node1 = skipSynthesizedParentheses(node1);
-      node2 = skipSynthesizedParentheses(node2);
-      if (getStartsOnNewLine(node2)) {
-        return 1;
-      }
-      if (currentSourceFile && !nodeIsSynthesized(parent2) && !nodeIsSynthesized(node1) && !nodeIsSynthesized(node2)) {
-        if (preserveSourceNewlines) {
-          return getEffectiveLines(
-            (includeComments) => getLinesBetweenRangeEndAndRangeStart(
-              node1,
-              node2,
-              currentSourceFile,
-              includeComments
-            )
-          );
-        }
-        return rangeEndIsOnSameLineAsRangeStart(node1, node2, currentSourceFile) ? 0 : 1;
-      }
-      return 0;
-    }
-    function isEmptyBlock(block) {
-      return block.statements.length === 0 && (!currentSourceFile || rangeEndIsOnSameLineAsRangeStart(block, block, currentSourceFile));
-    }
-    function skipSynthesizedParentheses(node) {
-      while (node.kind === 216 /* ParenthesizedExpression */ && nodeIsSynthesized(node)) {
-        node = node.expression;
-      }
-      return node;
-    }
-    function getTextOfNode2(node, includeTrivia) {
-      if (isGeneratedIdentifier(node) || isGeneratedPrivateIdentifier(node)) {
-        return generateName(node);
-      }
-      if (isStringLiteral(node) && node.textSourceNode) {
-        return getTextOfNode2(node.textSourceNode, includeTrivia);
-      }
-      const sourceFile = currentSourceFile;
-      const canUseSourceFile = !!sourceFile && !!node.parent && !nodeIsSynthesized(node);
-      if (isMemberName(node)) {
-        if (!canUseSourceFile || getSourceFileOfNode(node) !== getOriginalNode(sourceFile)) {
-          return idText(node);
-        }
-      } else if (isJsxNamespacedName(node)) {
-        if (!canUseSourceFile || getSourceFileOfNode(node) !== getOriginalNode(sourceFile)) {
-          return getTextOfJsxNamespacedName(node);
-        }
-      } else {
-        Debug.assertNode(node, isLiteralExpression);
-        if (!canUseSourceFile) {
-          return node.text;
-        }
-      }
-      return getSourceTextOfNodeFromSourceFile(sourceFile, node, includeTrivia);
-    }
-    function getLiteralTextOfNode(node, neverAsciiEscape, jsxAttributeEscape) {
-      if (node.kind === 11 /* StringLiteral */ && node.textSourceNode) {
-        const textSourceNode = node.textSourceNode;
-        if (isIdentifier(textSourceNode) || isPrivateIdentifier(textSourceNode) || isNumericLiteral(textSourceNode) || isJsxNamespacedName(textSourceNode)) {
-          const text = isNumericLiteral(textSourceNode) ? textSourceNode.text : getTextOfNode2(textSourceNode);
-          return jsxAttributeEscape ? `"${escapeJsxAttributeString(text)}"` : neverAsciiEscape || getEmitFlags(node) & 16777216 /* NoAsciiEscaping */ ? `"${escapeString(text)}"` : `"${escapeNonAsciiString(text)}"`;
-        } else {
-          return getLiteralTextOfNode(textSourceNode, neverAsciiEscape, jsxAttributeEscape);
-        }
-      }
-      const flags = (neverAsciiEscape ? 1 /* NeverAsciiEscape */ : 0) | (jsxAttributeEscape ? 2 /* JsxAttributeEscape */ : 0) | (printerOptions.terminateUnterminatedLiterals ? 4 /* TerminateUnterminatedLiterals */ : 0) | (printerOptions.target && printerOptions.target === 99 /* ESNext */ ? 8 /* AllowNumericSeparator */ : 0);
-      return getLiteralText(node, currentSourceFile, flags);
-    }
-    function pushNameGenerationScope(node) {
-      if (node && getEmitFlags(node) & 1048576 /* ReuseTempVariableScope */) {
-        return;
-      }
-      tempFlagsStack.push(tempFlags);
-      tempFlags = 0 /* Auto */;
-      formattedNameTempFlagsStack.push(formattedNameTempFlags);
-      formattedNameTempFlags = void 0;
-      reservedNamesStack.push(reservedNames);
-    }
-    function popNameGenerationScope(node) {
-      if (node && getEmitFlags(node) & 1048576 /* ReuseTempVariableScope */) {
-        return;
-      }
-      tempFlags = tempFlagsStack.pop();
-      formattedNameTempFlags = formattedNameTempFlagsStack.pop();
-      reservedNames = reservedNamesStack.pop();
-    }
-    function reserveNameInNestedScopes(name) {
-      if (!reservedNames || reservedNames === lastOrUndefined(reservedNamesStack)) {
-        reservedNames = /* @__PURE__ */ new Set();
-      }
-      reservedNames.add(name);
-    }
-    function pushPrivateNameGenerationScope(newPrivateNameTempFlags, newReservedMemberNames) {
-      privateNameTempFlagsStack.push(privateNameTempFlags);
-      privateNameTempFlags = newPrivateNameTempFlags;
-      reservedPrivateNamesStack.push(reservedNames);
-      reservedPrivateNames = newReservedMemberNames;
-    }
-    function popPrivateNameGenerationScope() {
-      privateNameTempFlags = privateNameTempFlagsStack.pop();
-      reservedPrivateNames = reservedPrivateNamesStack.pop();
-    }
-    function reservePrivateNameInNestedScopes(name) {
-      if (!reservedPrivateNames || reservedPrivateNames === lastOrUndefined(reservedPrivateNamesStack)) {
-        reservedPrivateNames = /* @__PURE__ */ new Set();
-      }
-      reservedPrivateNames.add(name);
-    }
-    function generateNames(node) {
-      if (!node)
-        return;
-      switch (node.kind) {
-        case 240 /* Block */:
-          forEach(node.statements, generateNames);
-          break;
-        case 255 /* LabeledStatement */:
-        case 253 /* WithStatement */:
-        case 245 /* DoStatement */:
-        case 246 /* WhileStatement */:
-          generateNames(node.statement);
-          break;
-        case 244 /* IfStatement */:
-          generateNames(node.thenStatement);
-          generateNames(node.elseStatement);
-          break;
-        case 247 /* ForStatement */:
-        case 249 /* ForOfStatement */:
-        case 248 /* ForInStatement */:
-          generateNames(node.initializer);
-          generateNames(node.statement);
-          break;
-        case 254 /* SwitchStatement */:
-          generateNames(node.caseBlock);
-          break;
-        case 268 /* CaseBlock */:
-          forEach(node.clauses, generateNames);
-          break;
-        case 295 /* CaseClause */:
-        case 296 /* DefaultClause */:
-          forEach(node.statements, generateNames);
-          break;
-        case 257 /* TryStatement */:
-          generateNames(node.tryBlock);
-          generateNames(node.catchClause);
-          generateNames(node.finallyBlock);
-          break;
-        case 298 /* CatchClause */:
-          generateNames(node.variableDeclaration);
-          generateNames(node.block);
-          break;
-        case 242 /* VariableStatement */:
-          generateNames(node.declarationList);
-          break;
-        case 260 /* VariableDeclarationList */:
-          forEach(node.declarations, generateNames);
-          break;
-        case 259 /* VariableDeclaration */:
-        case 168 /* Parameter */:
-        case 207 /* BindingElement */:
-        case 262 /* ClassDeclaration */:
-          generateNameIfNeeded(node.name);
-          break;
-        case 261 /* FunctionDeclaration */:
-          generateNameIfNeeded(node.name);
-          if (getEmitFlags(node) & 1048576 /* ReuseTempVariableScope */) {
-            forEach(node.parameters, generateNames);
-            generateNames(node.body);
-          }
-          break;
-        case 205 /* ObjectBindingPattern */:
-        case 206 /* ArrayBindingPattern */:
-          forEach(node.elements, generateNames);
-          break;
-        case 271 /* ImportDeclaration */:
-          generateNames(node.importClause);
-          break;
-        case 272 /* ImportClause */:
-          generateNameIfNeeded(node.name);
-          generateNames(node.namedBindings);
-          break;
-        case 273 /* NamespaceImport */:
-          generateNameIfNeeded(node.name);
-          break;
-        case 279 /* NamespaceExport */:
-          generateNameIfNeeded(node.name);
-          break;
-        case 274 /* NamedImports */:
-          forEach(node.elements, generateNames);
-          break;
-        case 275 /* ImportSpecifier */:
-          generateNameIfNeeded(node.propertyName || node.name);
-          break;
-      }
-    }
-    function generateMemberNames(node) {
-      if (!node)
-        return;
-      switch (node.kind) {
-        case 302 /* PropertyAssignment */:
-        case 303 /* ShorthandPropertyAssignment */:
-        case 171 /* PropertyDeclaration */:
-        case 173 /* MethodDeclaration */:
-        case 176 /* GetAccessor */:
-        case 177 /* SetAccessor */:
-          generateNameIfNeeded(node.name);
-          break;
-      }
-    }
-    function generateNameIfNeeded(name) {
-      if (name) {
-        if (isGeneratedIdentifier(name) || isGeneratedPrivateIdentifier(name)) {
-          generateName(name);
-        } else if (isBindingPattern(name)) {
-          generateNames(name);
-        }
-      }
-    }
-    function generateName(name) {
-      const autoGenerate = name.emitNode.autoGenerate;
-      if ((autoGenerate.flags & 7 /* KindMask */) === 4 /* Node */) {
-        return generateNameCached(getNodeForGeneratedName(name), isPrivateIdentifier(name), autoGenerate.flags, autoGenerate.prefix, autoGenerate.suffix);
-      } else {
-        const autoGenerateId = autoGenerate.id;
-        return autoGeneratedIdToGeneratedName[autoGenerateId] || (autoGeneratedIdToGeneratedName[autoGenerateId] = makeName(name));
-      }
-    }
-    function generateNameCached(node, privateName, flags, prefix, suffix) {
-      const nodeId = getNodeId(node);
-      const cache = privateName ? nodeIdToGeneratedPrivateName : nodeIdToGeneratedName;
-      return cache[nodeId] || (cache[nodeId] = generateNameForNode(node, privateName, flags ?? 0 /* None */, formatGeneratedNamePart(prefix, generateName), formatGeneratedNamePart(suffix)));
-    }
-    function isUniqueName(name, privateName) {
-      return isFileLevelUniqueNameInCurrentFile(name, privateName) && !isReservedName(name, privateName) && !generatedNames.has(name);
-    }
-    function isReservedName(name, privateName) {
-      return privateName ? !!(reservedPrivateNames == null ? void 0 : reservedPrivateNames.has(name)) : !!(reservedNames == null ? void 0 : reservedNames.has(name));
-    }
-    function isFileLevelUniqueNameInCurrentFile(name, _isPrivate) {
-      return currentSourceFile ? isFileLevelUniqueName(currentSourceFile, name, hasGlobalName) : true;
-    }
-    function isUniqueLocalName(name, container) {
-      for (let node = container; node && isNodeDescendantOf(node, container); node = node.nextContainer) {
-        if (canHaveLocals(node) && node.locals) {
-          const local = node.locals.get(escapeLeadingUnderscores(name));
-          if (local && local.flags & (111551 /* Value */ | 1048576 /* ExportValue */ | 2097152 /* Alias */)) {
-            return false;
-          }
-        }
-      }
-      return true;
-    }
-    function getTempFlags(formattedNameKey) {
-      switch (formattedNameKey) {
-        case "":
-          return tempFlags;
-        case "#":
-          return privateNameTempFlags;
-        default:
-          return (formattedNameTempFlags == null ? void 0 : formattedNameTempFlags.get(formattedNameKey)) ?? 0 /* Auto */;
-      }
-    }
-    function setTempFlags(formattedNameKey, flags) {
-      switch (formattedNameKey) {
-        case "":
-          tempFlags = flags;
-          break;
-        case "#":
-          privateNameTempFlags = flags;
-          break;
-        default:
-          formattedNameTempFlags ?? (formattedNameTempFlags = /* @__PURE__ */ new Map());
-          formattedNameTempFlags.set(formattedNameKey, flags);
-          break;
-      }
-    }
-    function makeTempVariableName(flags, reservedInNestedScopes, privateName, prefix, suffix) {
-      if (prefix.length > 0 && prefix.charCodeAt(0) === 35 /* hash */) {
-        prefix = prefix.slice(1);
-      }
-      const key = formatGeneratedName(privateName, prefix, "", suffix);
-      let tempFlags2 = getTempFlags(key);
-      if (flags && !(tempFlags2 & flags)) {
-        const name = flags === 268435456 /* _i */ ? "_i" : "_n";
-        const fullName = formatGeneratedName(privateName, prefix, name, suffix);
-        if (isUniqueName(fullName, privateName)) {
-          tempFlags2 |= flags;
-          if (privateName) {
-            reservePrivateNameInNestedScopes(fullName);
-          } else if (reservedInNestedScopes) {
-            reserveNameInNestedScopes(fullName);
-          }
-          setTempFlags(key, tempFlags2);
-          return fullName;
-        }
-      }
-      while (true) {
-        const count = tempFlags2 & 268435455 /* CountMask */;
-        tempFlags2++;
-        if (count !== 8 && count !== 13) {
-          const name = count < 26 ? "_" + String.fromCharCode(97 /* a */ + count) : "_" + (count - 26);
-          const fullName = formatGeneratedName(privateName, prefix, name, suffix);
-          if (isUniqueName(fullName, privateName)) {
-            if (privateName) {
-              reservePrivateNameInNestedScopes(fullName);
-            } else if (reservedInNestedScopes) {
-              reserveNameInNestedScopes(fullName);
-            }
-            setTempFlags(key, tempFlags2);
-            return fullName;
-          }
-        }
-      }
-    }
-    function makeUniqueName2(baseName, checkFn = isUniqueName, optimistic, scoped, privateName, prefix, suffix) {
-      if (baseName.length > 0 && baseName.charCodeAt(0) === 35 /* hash */) {
-        baseName = baseName.slice(1);
-      }
-      if (prefix.length > 0 && prefix.charCodeAt(0) === 35 /* hash */) {
-        prefix = prefix.slice(1);
-      }
-      if (optimistic) {
-        const fullName = formatGeneratedName(privateName, prefix, baseName, suffix);
-        if (checkFn(fullName, privateName)) {
-          if (privateName) {
-            reservePrivateNameInNestedScopes(fullName);
-          } else if (scoped) {
-            reserveNameInNestedScopes(fullName);
-          } else {
-            generatedNames.add(fullName);
-          }
-          return fullName;
-        }
-      }
-      if (baseName.charCodeAt(baseName.length - 1) !== 95 /* _ */) {
-        baseName += "_";
-      }
-      let i = 1;
-      while (true) {
-        const fullName = formatGeneratedName(privateName, prefix, baseName + i, suffix);
-        if (checkFn(fullName, privateName)) {
-          if (privateName) {
-            reservePrivateNameInNestedScopes(fullName);
-          } else if (scoped) {
-            reserveNameInNestedScopes(fullName);
-          } else {
-            generatedNames.add(fullName);
-          }
-          return fullName;
-        }
-        i++;
-      }
-    }
-    function makeFileLevelOptimisticUniqueName(name) {
-      return makeUniqueName2(
-        name,
-        isFileLevelUniqueNameInCurrentFile,
-        /*optimistic*/
-        true,
-        /*scoped*/
-        false,
-        /*privateName*/
-        false,
-        /*prefix*/
-        "",
-        /*suffix*/
-        ""
-      );
-    }
-    function generateNameForModuleOrEnum(node) {
-      const name = getTextOfNode2(node.name);
-      return isUniqueLocalName(name, tryCast(node, canHaveLocals)) ? name : makeUniqueName2(
-        name,
-        isUniqueName,
-        /*optimistic*/
-        false,
-        /*scoped*/
-        false,
-        /*privateName*/
-        false,
-        /*prefix*/
-        "",
-        /*suffix*/
-        ""
-      );
-    }
-    function generateNameForImportOrExportDeclaration(node) {
-      const expr = getExternalModuleName(node);
-      const baseName = isStringLiteral(expr) ? makeIdentifierFromModuleName(expr.text) : "module";
-      return makeUniqueName2(
-        baseName,
-        isUniqueName,
-        /*optimistic*/
-        false,
-        /*scoped*/
-        false,
-        /*privateName*/
-        false,
-        /*prefix*/
-        "",
-        /*suffix*/
-        ""
-      );
-    }
-    function generateNameForExportDefault() {
-      return makeUniqueName2(
-        "default",
-        isUniqueName,
-        /*optimistic*/
-        false,
-        /*scoped*/
-        false,
-        /*privateName*/
-        false,
-        /*prefix*/
-        "",
-        /*suffix*/
-        ""
-      );
-    }
-    function generateNameForClassExpression() {
-      return makeUniqueName2(
-        "class",
-        isUniqueName,
-        /*optimistic*/
-        false,
-        /*scoped*/
-        false,
-        /*privateName*/
-        false,
-        /*prefix*/
-        "",
-        /*suffix*/
-        ""
-      );
-    }
-    function generateNameForMethodOrAccessor(node, privateName, prefix, suffix) {
-      if (isIdentifier(node.name)) {
-        return generateNameCached(node.name, privateName);
-      }
-      return makeTempVariableName(
-        0 /* Auto */,
-        /*reservedInNestedScopes*/
-        false,
-        privateName,
-        prefix,
-        suffix
-      );
-    }
-    function generateNameForNode(node, privateName, flags, prefix, suffix) {
-      switch (node.kind) {
-        case 80 /* Identifier */:
-        case 81 /* PrivateIdentifier */:
-          return makeUniqueName2(
-            getTextOfNode2(node),
-            isUniqueName,
-            !!(flags & 16 /* Optimistic */),
-            !!(flags & 8 /* ReservedInNestedScopes */),
-            privateName,
-            prefix,
-            suffix
-          );
-        case 266 /* ModuleDeclaration */:
-        case 265 /* EnumDeclaration */:
-          Debug.assert(!prefix && !suffix && !privateName);
-          return generateNameForModuleOrEnum(node);
-        case 271 /* ImportDeclaration */:
-        case 277 /* ExportDeclaration */:
-          Debug.assert(!prefix && !suffix && !privateName);
-          return generateNameForImportOrExportDeclaration(node);
-        case 261 /* FunctionDeclaration */:
-        case 262 /* ClassDeclaration */: {
-          Debug.assert(!prefix && !suffix && !privateName);
-          const name = node.name;
-          if (name && !isGeneratedIdentifier(name)) {
-            return generateNameForNode(
-              name,
-              /*privateName*/
-              false,
-              flags,
-              prefix,
-              suffix
-            );
-          }
-          return generateNameForExportDefault();
-        }
-        case 276 /* ExportAssignment */:
-          Debug.assert(!prefix && !suffix && !privateName);
-          return generateNameForExportDefault();
-        case 230 /* ClassExpression */:
-          Debug.assert(!prefix && !suffix && !privateName);
-          return generateNameForClassExpression();
-        case 173 /* MethodDeclaration */:
-        case 176 /* GetAccessor */:
-        case 177 /* SetAccessor */:
-          return generateNameForMethodOrAccessor(node, privateName, prefix, suffix);
-        case 166 /* ComputedPropertyName */:
-          return makeTempVariableName(
-            0 /* Auto */,
-            /*reservedInNestedScopes*/
-            true,
-            privateName,
-            prefix,
-            suffix
-          );
-        default:
-          return makeTempVariableName(
-            0 /* Auto */,
-            /*reservedInNestedScopes*/
-            false,
-            privateName,
-            prefix,
-            suffix
-          );
-      }
-    }
-    function makeName(name) {
-      const autoGenerate = name.emitNode.autoGenerate;
-      const prefix = formatGeneratedNamePart(autoGenerate.prefix, generateName);
-      const suffix = formatGeneratedNamePart(autoGenerate.suffix);
-      switch (autoGenerate.flags & 7 /* KindMask */) {
-        case 1 /* Auto */:
-          return makeTempVariableName(0 /* Auto */, !!(autoGenerate.flags & 8 /* ReservedInNestedScopes */), isPrivateIdentifier(name), prefix, suffix);
-        case 2 /* Loop */:
-          Debug.assertNode(name, isIdentifier);
-          return makeTempVariableName(
-            268435456 /* _i */,
-            !!(autoGenerate.flags & 8 /* ReservedInNestedScopes */),
-            /*privateName*/
-            false,
-            prefix,
-            suffix
-          );
-        case 3 /* Unique */:
-          return makeUniqueName2(
-            idText(name),
-            autoGenerate.flags & 32 /* FileLevel */ ? isFileLevelUniqueNameInCurrentFile : isUniqueName,
-            !!(autoGenerate.flags & 16 /* Optimistic */),
-            !!(autoGenerate.flags & 8 /* ReservedInNestedScopes */),
-            isPrivateIdentifier(name),
-            prefix,
-            suffix
-          );
-      }
-      return Debug.fail(`Unsupported GeneratedIdentifierKind: ${Debug.formatEnum(
-        autoGenerate.flags & 7 /* KindMask */,
-        GeneratedIdentifierFlags,
-        /*isFlags*/
-        true
-      )}.`);
-    }
-    function pipelineEmitWithComments(hint, node) {
-      const pipelinePhase = getNextPipelinePhase(2 /* Comments */, hint, node);
-      const savedContainerPos = containerPos;
-      const savedContainerEnd = containerEnd;
-      const savedDeclarationListContainerEnd = declarationListContainerEnd;
-      emitCommentsBeforeNode(node);
-      pipelinePhase(hint, node);
-      emitCommentsAfterNode(node, savedContainerPos, savedContainerEnd, savedDeclarationListContainerEnd);
-    }
-    function emitCommentsBeforeNode(node) {
-      const emitFlags = getEmitFlags(node);
-      const commentRange = getCommentRange(node);
-      emitLeadingCommentsOfNode(node, emitFlags, commentRange.pos, commentRange.end);
-      if (emitFlags & 4096 /* NoNestedComments */) {
-        commentsDisabled = true;
-      }
-    }
-    function emitCommentsAfterNode(node, savedContainerPos, savedContainerEnd, savedDeclarationListContainerEnd) {
-      const emitFlags = getEmitFlags(node);
-      const commentRange = getCommentRange(node);
-      if (emitFlags & 4096 /* NoNestedComments */) {
-        commentsDisabled = false;
-      }
-      emitTrailingCommentsOfNode(node, emitFlags, commentRange.pos, commentRange.end, savedContainerPos, savedContainerEnd, savedDeclarationListContainerEnd);
-      const typeNode = getTypeNode(node);
-      if (typeNode) {
-        emitTrailingCommentsOfNode(node, emitFlags, typeNode.pos, typeNode.end, savedContainerPos, savedContainerEnd, savedDeclarationListContainerEnd);
-      }
-    }
-    function emitLeadingCommentsOfNode(node, emitFlags, pos, end) {
-      enterComment();
-      hasWrittenComment = false;
-      const skipLeadingComments = pos < 0 || (emitFlags & 1024 /* NoLeadingComments */) !== 0 || node.kind === 12 /* JsxText */;
-      const skipTrailingComments = end < 0 || (emitFlags & 2048 /* NoTrailingComments */) !== 0 || node.kind === 12 /* JsxText */;
-      if ((pos > 0 || end > 0) && pos !== end) {
-        if (!skipLeadingComments) {
-          emitLeadingComments(
-            pos,
-            /*isEmittedNode*/
-            node.kind !== 358 /* NotEmittedStatement */
-          );
-        }
-        if (!skipLeadingComments || pos >= 0 && (emitFlags & 1024 /* NoLeadingComments */) !== 0) {
-          containerPos = pos;
-        }
-        if (!skipTrailingComments || end >= 0 && (emitFlags & 2048 /* NoTrailingComments */) !== 0) {
-          containerEnd = end;
-          if (node.kind === 260 /* VariableDeclarationList */) {
-            declarationListContainerEnd = end;
-          }
-        }
-      }
-      forEach(getSyntheticLeadingComments(node), emitLeadingSynthesizedComment);
-      exitComment();
-    }
-    function emitTrailingCommentsOfNode(node, emitFlags, pos, end, savedContainerPos, savedContainerEnd, savedDeclarationListContainerEnd) {
-      enterComment();
-      const skipTrailingComments = end < 0 || (emitFlags & 2048 /* NoTrailingComments */) !== 0 || node.kind === 12 /* JsxText */;
-      forEach(getSyntheticTrailingComments(node), emitTrailingSynthesizedComment);
-      if ((pos > 0 || end > 0) && pos !== end) {
-        containerPos = savedContainerPos;
-        containerEnd = savedContainerEnd;
-        declarationListContainerEnd = savedDeclarationListContainerEnd;
-        if (!skipTrailingComments && node.kind !== 358 /* NotEmittedStatement */) {
-          emitTrailingComments(end);
-        }
-      }
-      exitComment();
-    }
-    function emitLeadingSynthesizedComment(comment) {
-      if (comment.hasLeadingNewline || comment.kind === 2 /* SingleLineCommentTrivia */) {
-        writer.writeLine();
-      }
-      writeSynthesizedComment(comment);
-      if (comment.hasTrailingNewLine || comment.kind === 2 /* SingleLineCommentTrivia */) {
-        writer.writeLine();
-      } else {
-        writer.writeSpace(" ");
-      }
-    }
-    function emitTrailingSynthesizedComment(comment) {
-      if (!writer.isAtStartOfLine()) {
-        writer.writeSpace(" ");
-      }
-      writeSynthesizedComment(comment);
-      if (comment.hasTrailingNewLine) {
-        writer.writeLine();
-      }
-    }
-    function writeSynthesizedComment(comment) {
-      const text = formatSynthesizedComment(comment);
-      const lineMap = comment.kind === 3 /* MultiLineCommentTrivia */ ? computeLineStarts(text) : void 0;
-      writeCommentRange(text, lineMap, writer, 0, text.length, newLine);
-    }
-    function formatSynthesizedComment(comment) {
-      return comment.kind === 3 /* MultiLineCommentTrivia */ ? `/*${comment.text}*/` : `//${comment.text}`;
-    }
-    function emitBodyWithDetachedComments(node, detachedRange, emitCallback) {
-      enterComment();
-      const { pos, end } = detachedRange;
-      const emitFlags = getEmitFlags(node);
-      const skipLeadingComments = pos < 0 || (emitFlags & 1024 /* NoLeadingComments */) !== 0;
-      const skipTrailingComments = commentsDisabled || end < 0 || (emitFlags & 2048 /* NoTrailingComments */) !== 0;
-      if (!skipLeadingComments) {
-        emitDetachedCommentsAndUpdateCommentsInfo(detachedRange);
-      }
-      exitComment();
-      if (emitFlags & 4096 /* NoNestedComments */ && !commentsDisabled) {
-        commentsDisabled = true;
-        emitCallback(node);
-        commentsDisabled = false;
-      } else {
-        emitCallback(node);
-      }
-      enterComment();
-      if (!skipTrailingComments) {
-        emitLeadingComments(
-          detachedRange.end,
-          /*isEmittedNode*/
-          true
-        );
-        if (hasWrittenComment && !writer.isAtStartOfLine()) {
-          writer.writeLine();
-        }
-      }
-      exitComment();
-    }
-    function originalNodesHaveSameParent(nodeA, nodeB) {
-      nodeA = getOriginalNode(nodeA);
-      return nodeA.parent && nodeA.parent === getOriginalNode(nodeB).parent;
-    }
-    function siblingNodePositionsAreComparable(previousNode, nextNode) {
-      if (nextNode.pos < previousNode.end) {
-        return false;
-      }
-      previousNode = getOriginalNode(previousNode);
-      nextNode = getOriginalNode(nextNode);
-      const parent2 = previousNode.parent;
-      if (!parent2 || parent2 !== nextNode.parent) {
-        return false;
-      }
-      const parentNodeArray = getContainingNodeArray(previousNode);
-      const prevNodeIndex = parentNodeArray == null ? void 0 : parentNodeArray.indexOf(previousNode);
-      return prevNodeIndex !== void 0 && prevNodeIndex > -1 && parentNodeArray.indexOf(nextNode) === prevNodeIndex + 1;
-    }
-    function emitLeadingComments(pos, isEmittedNode) {
-      hasWrittenComment = false;
-      if (isEmittedNode) {
-        if (pos === 0 && (currentSourceFile == null ? void 0 : currentSourceFile.isDeclarationFile)) {
-          forEachLeadingCommentToEmit(pos, emitNonTripleSlashLeadingComment);
-        } else {
-          forEachLeadingCommentToEmit(pos, emitLeadingComment);
-        }
-      } else if (pos === 0) {
-        forEachLeadingCommentToEmit(pos, emitTripleSlashLeadingComment);
-      }
-    }
-    function emitTripleSlashLeadingComment(commentPos, commentEnd, kind, hasTrailingNewLine, rangePos) {
-      if (isTripleSlashComment(commentPos, commentEnd)) {
-        emitLeadingComment(commentPos, commentEnd, kind, hasTrailingNewLine, rangePos);
-      }
-    }
-    function emitNonTripleSlashLeadingComment(commentPos, commentEnd, kind, hasTrailingNewLine, rangePos) {
-      if (!isTripleSlashComment(commentPos, commentEnd)) {
-        emitLeadingComment(commentPos, commentEnd, kind, hasTrailingNewLine, rangePos);
-      }
-    }
-    function shouldWriteComment(text, pos) {
-      if (printerOptions.onlyPrintJsDocStyle) {
-        return isJSDocLikeText(text, pos) || isPinnedComment(text, pos);
-      }
-      return true;
-    }
-    function emitLeadingComment(commentPos, commentEnd, kind, hasTrailingNewLine, rangePos) {
-      if (!currentSourceFile || !shouldWriteComment(currentSourceFile.text, commentPos))
-        return;
-      if (!hasWrittenComment) {
-        emitNewLineBeforeLeadingCommentOfPosition(getCurrentLineMap(), writer, rangePos, commentPos);
-        hasWrittenComment = true;
-      }
-      emitPos(commentPos);
-      writeCommentRange(currentSourceFile.text, getCurrentLineMap(), writer, commentPos, commentEnd, newLine);
-      emitPos(commentEnd);
-      if (hasTrailingNewLine) {
-        writer.writeLine();
-      } else if (kind === 3 /* MultiLineCommentTrivia */) {
-        writer.writeSpace(" ");
-      }
-    }
-    function emitLeadingCommentsOfPosition(pos) {
-      if (commentsDisabled || pos === -1) {
-        return;
-      }
-      emitLeadingComments(
-        pos,
-        /*isEmittedNode*/
-        true
-      );
-    }
-    function emitTrailingComments(pos) {
-      forEachTrailingCommentToEmit(pos, emitTrailingComment);
-    }
-    function emitTrailingComment(commentPos, commentEnd, _kind, hasTrailingNewLine) {
-      if (!currentSourceFile || !shouldWriteComment(currentSourceFile.text, commentPos))
-        return;
-      if (!writer.isAtStartOfLine()) {
-        writer.writeSpace(" ");
-      }
-      emitPos(commentPos);
-      writeCommentRange(currentSourceFile.text, getCurrentLineMap(), writer, commentPos, commentEnd, newLine);
-      emitPos(commentEnd);
-      if (hasTrailingNewLine) {
-        writer.writeLine();
-      }
-    }
-    function emitTrailingCommentsOfPosition(pos, prefixSpace, forceNoNewline) {
-      if (commentsDisabled) {
-        return;
-      }
-      enterComment();
-      forEachTrailingCommentToEmit(pos, prefixSpace ? emitTrailingComment : forceNoNewline ? emitTrailingCommentOfPositionNoNewline : emitTrailingCommentOfPosition);
-      exitComment();
-    }
-    function emitTrailingCommentOfPositionNoNewline(commentPos, commentEnd, kind) {
-      if (!currentSourceFile)
-        return;
-      emitPos(commentPos);
-      writeCommentRange(currentSourceFile.text, getCurrentLineMap(), writer, commentPos, commentEnd, newLine);
-      emitPos(commentEnd);
-      if (kind === 2 /* SingleLineCommentTrivia */) {
-        writer.writeLine();
-      }
-    }
-    function emitTrailingCommentOfPosition(commentPos, commentEnd, _kind, hasTrailingNewLine) {
-      if (!currentSourceFile)
-        return;
-      emitPos(commentPos);
-      writeCommentRange(currentSourceFile.text, getCurrentLineMap(), writer, commentPos, commentEnd, newLine);
-      emitPos(commentEnd);
-      if (hasTrailingNewLine) {
-        writer.writeLine();
-      } else {
-        writer.writeSpace(" ");
-      }
-    }
-    function forEachLeadingCommentToEmit(pos, cb) {
-      if (currentSourceFile && (containerPos === -1 || pos !== containerPos)) {
-        if (hasDetachedComments(pos)) {
-          forEachLeadingCommentWithoutDetachedComments(cb);
-        } else {
-          forEachLeadingCommentRange(
-            currentSourceFile.text,
-            pos,
-            cb,
-            /*state*/
-            pos
-          );
-        }
-      }
-    }
-    function forEachTrailingCommentToEmit(end, cb) {
-      if (currentSourceFile && (containerEnd === -1 || end !== containerEnd && end !== declarationListContainerEnd)) {
-        forEachTrailingCommentRange(currentSourceFile.text, end, cb);
-      }
-    }
-    function hasDetachedComments(pos) {
-      return detachedCommentsInfo !== void 0 && last(detachedCommentsInfo).nodePos === pos;
-    }
-    function forEachLeadingCommentWithoutDetachedComments(cb) {
-      if (!currentSourceFile)
-        return;
-      const pos = last(detachedCommentsInfo).detachedCommentEndPos;
-      if (detachedCommentsInfo.length - 1) {
-        detachedCommentsInfo.pop();
-      } else {
-        detachedCommentsInfo = void 0;
-      }
-      forEachLeadingCommentRange(
-        currentSourceFile.text,
-        pos,
-        cb,
-        /*state*/
-        pos
-      );
-    }
-    function emitDetachedCommentsAndUpdateCommentsInfo(range) {
-      const currentDetachedCommentInfo = currentSourceFile && emitDetachedComments(currentSourceFile.text, getCurrentLineMap(), writer, emitComment, range, newLine, commentsDisabled);
-      if (currentDetachedCommentInfo) {
-        if (detachedCommentsInfo) {
-          detachedCommentsInfo.push(currentDetachedCommentInfo);
-        } else {
-          detachedCommentsInfo = [currentDetachedCommentInfo];
-        }
-      }
-    }
-    function emitComment(text, lineMap, writer2, commentPos, commentEnd, newLine2) {
-      if (!currentSourceFile || !shouldWriteComment(currentSourceFile.text, commentPos))
-        return;
-      emitPos(commentPos);
-      writeCommentRange(text, lineMap, writer2, commentPos, commentEnd, newLine2);
-      emitPos(commentEnd);
-    }
-    function isTripleSlashComment(commentPos, commentEnd) {
-      return !!currentSourceFile && isRecognizedTripleSlashComment(currentSourceFile.text, commentPos, commentEnd);
-    }
-    function getParsedSourceMap(node) {
-      if (node.parsedSourceMap === void 0 && node.sourceMapText !== void 0) {
-        node.parsedSourceMap = tryParseRawSourceMap(node.sourceMapText) || false;
-      }
-      return node.parsedSourceMap || void 0;
-    }
-    function pipelineEmitWithSourceMaps(hint, node) {
-      const pipelinePhase = getNextPipelinePhase(3 /* SourceMaps */, hint, node);
-      emitSourceMapsBeforeNode(node);
-      pipelinePhase(hint, node);
-      emitSourceMapsAfterNode(node);
-    }
-    function emitSourceMapsBeforeNode(node) {
-      const emitFlags = getEmitFlags(node);
-      const sourceMapRange = getSourceMapRange(node);
-      if (isUnparsedNode(node)) {
-        Debug.assertIsDefined(node.parent, "UnparsedNodes must have parent pointers");
-        const parsed = getParsedSourceMap(node.parent);
-        if (parsed && sourceMapGenerator) {
-          sourceMapGenerator.appendSourceMap(
-            writer.getLine(),
-            writer.getColumn(),
-            parsed,
-            node.parent.sourceMapPath,
-            node.parent.getLineAndCharacterOfPosition(node.pos),
-            node.parent.getLineAndCharacterOfPosition(node.end)
-          );
-        }
-      } else {
-        const source = sourceMapRange.source || sourceMapSource;
-        if (node.kind !== 358 /* NotEmittedStatement */ && (emitFlags & 32 /* NoLeadingSourceMap */) === 0 && sourceMapRange.pos >= 0) {
-          emitSourcePos(sourceMapRange.source || sourceMapSource, skipSourceTrivia(source, sourceMapRange.pos));
-        }
-        if (emitFlags & 128 /* NoNestedSourceMaps */) {
-          sourceMapsDisabled = true;
-        }
-      }
-    }
-    function emitSourceMapsAfterNode(node) {
-      const emitFlags = getEmitFlags(node);
-      const sourceMapRange = getSourceMapRange(node);
-      if (!isUnparsedNode(node)) {
-        if (emitFlags & 128 /* NoNestedSourceMaps */) {
-          sourceMapsDisabled = false;
-        }
-        if (node.kind !== 358 /* NotEmittedStatement */ && (emitFlags & 64 /* NoTrailingSourceMap */) === 0 && sourceMapRange.end >= 0) {
-          emitSourcePos(sourceMapRange.source || sourceMapSource, sourceMapRange.end);
-        }
-      }
-    }
-    function skipSourceTrivia(source, pos) {
-      return source.skipTrivia ? source.skipTrivia(pos) : skipTrivia(source.text, pos);
-    }
-    function emitPos(pos) {
-      if (sourceMapsDisabled || positionIsSynthesized(pos) || isJsonSourceMapSource(sourceMapSource)) {
-        return;
-      }
-      const { line: sourceLine, character: sourceCharacter } = getLineAndCharacterOfPosition(sourceMapSource, pos);
-      sourceMapGenerator.addMapping(
-        writer.getLine(),
-        writer.getColumn(),
-        sourceMapSourceIndex,
-        sourceLine,
-        sourceCharacter,
-        /*nameIndex*/
-        void 0
-      );
-    }
-    function emitSourcePos(source, pos) {
-      if (source !== sourceMapSource) {
-        const savedSourceMapSource = sourceMapSource;
-        const savedSourceMapSourceIndex = sourceMapSourceIndex;
-        setSourceMapSource(source);
-        emitPos(pos);
-        resetSourceMapSource(savedSourceMapSource, savedSourceMapSourceIndex);
-      } else {
-        emitPos(pos);
-      }
-    }
-    function emitTokenWithSourceMap(node, token, writer2, tokenPos, emitCallback) {
-      if (sourceMapsDisabled || node && isInJsonFile(node)) {
-        return emitCallback(token, writer2, tokenPos);
-      }
-      const emitNode = node && node.emitNode;
-      const emitFlags = emitNode && emitNode.flags || 0 /* None */;
-      const range = emitNode && emitNode.tokenSourceMapRanges && emitNode.tokenSourceMapRanges[token];
-      const source = range && range.source || sourceMapSource;
-      tokenPos = skipSourceTrivia(source, range ? range.pos : tokenPos);
-      if ((emitFlags & 256 /* NoTokenLeadingSourceMaps */) === 0 && tokenPos >= 0) {
-        emitSourcePos(source, tokenPos);
-      }
-      tokenPos = emitCallback(token, writer2, tokenPos);
-      if (range)
-        tokenPos = range.end;
-      if ((emitFlags & 512 /* NoTokenTrailingSourceMaps */) === 0 && tokenPos >= 0) {
-        emitSourcePos(source, tokenPos);
-      }
-      return tokenPos;
-    }
-    function setSourceMapSource(source) {
-      if (sourceMapsDisabled) {
-        return;
-      }
-      sourceMapSource = source;
-      if (source === mostRecentlyAddedSourceMapSource) {
-        sourceMapSourceIndex = mostRecentlyAddedSourceMapSourceIndex;
-        return;
-      }
-      if (isJsonSourceMapSource(source)) {
-        return;
-      }
-      sourceMapSourceIndex = sourceMapGenerator.addSource(source.fileName);
-      if (printerOptions.inlineSources) {
-        sourceMapGenerator.setSourceContent(sourceMapSourceIndex, source.text);
-      }
-      mostRecentlyAddedSourceMapSource = source;
-      mostRecentlyAddedSourceMapSourceIndex = sourceMapSourceIndex;
-    }
-    function resetSourceMapSource(source, sourceIndex) {
-      sourceMapSource = source;
-      sourceMapSourceIndex = sourceIndex;
-    }
-    function isJsonSourceMapSource(sourceFile) {
-      return fileExtensionIs(sourceFile.fileName, ".json" /* Json */);
-    }
-  }
-  function createBracketsMap() {
-    const brackets2 = [];
-    brackets2[1024 /* Braces */] = ["{", "}"];
-    brackets2[2048 /* Parenthesis */] = ["(", ")"];
-    brackets2[4096 /* AngleBrackets */] = ["<", ">"];
-    brackets2[8192 /* SquareBrackets */] = ["[", "]"];
-    return brackets2;
-  }
-  function getOpeningBracket(format) {
-    return brackets[format & 15360 /* BracketsMask */][0];
-  }
-  function getClosingBracket(format) {
-    return brackets[format & 15360 /* BracketsMask */][1];
-  }
-  function emitListItemNoParenthesizer(node, emit, _parenthesizerRule, _index) {
-    emit(node);
-  }
-  function emitListItemWithParenthesizerRuleSelector(node, emit, parenthesizerRuleSelector, index) {
-    emit(node, parenthesizerRuleSelector.select(index));
-  }
-  function emitListItemWithParenthesizerRule(node, emit, parenthesizerRule, _index) {
-    emit(node, parenthesizerRule);
-  }
-  function getEmitListItem(emit, parenthesizerRule) {
-    return emit.length === 1 ? emitListItemNoParenthesizer : typeof parenthesizerRule === "object" ? emitListItemWithParenthesizerRuleSelector : emitListItemWithParenthesizerRule;
-  }
-  var brackets, notImplementedResolver, createPrinterWithDefaults, createPrinterWithRemoveComments, createPrinterWithRemoveCommentsNeverAsciiEscape, createPrinterWithRemoveCommentsOmitTrailingSemicolon;
-  var init_emitter = __esm({
-    "src/compiler/emitter.ts"() {
-      "use strict";
-      init_ts2();
-      init_ts2();
-      init_ts_performance();
-      brackets = createBracketsMap();
-      notImplementedResolver = {
-        hasGlobalName: notImplemented,
-        getReferencedExportContainer: notImplemented,
-        getReferencedImportDeclaration: notImplemented,
-        getReferencedDeclarationWithCollidingName: notImplemented,
-        isDeclarationWithCollidingName: notImplemented,
-        isValueAliasDeclaration: notImplemented,
-        isReferencedAliasDeclaration: notImplemented,
-        isTopLevelValueImportEqualsWithEntityName: notImplemented,
-        getNodeCheckFlags: notImplemented,
-        isDeclarationVisible: notImplemented,
-        isLateBound: (_node) => false,
-        collectLinkedAliases: notImplemented,
-        isImplementationOfOverload: notImplemented,
-        isRequiredInitializedParameter: notImplemented,
-        isOptionalUninitializedParameterProperty: notImplemented,
-        isExpandoFunctionDeclaration: notImplemented,
-        getPropertiesOfContainerFunction: notImplemented,
-        createTypeOfDeclaration: notImplemented,
-        createReturnTypeOfSignatureDeclaration: notImplemented,
-        createTypeOfExpression: notImplemented,
-        createLiteralConstValue: notImplemented,
-        isSymbolAccessible: notImplemented,
-        isEntityNameVisible: notImplemented,
-        // Returns the constant value this property access resolves to: notImplemented, or 'undefined' for a non-constant
-        getConstantValue: notImplemented,
-        getReferencedValueDeclaration: notImplemented,
-        getReferencedValueDeclarations: notImplemented,
-        getTypeReferenceSerializationKind: notImplemented,
-        isOptionalParameter: notImplemented,
-        moduleExportsSomeValue: notImplemented,
-        isArgumentsLocalBinding: notImplemented,
-        getExternalModuleFileFromDeclaration: notImplemented,
-        getTypeReferenceDirectivesForEntityName: notImplemented,
-        getTypeReferenceDirectivesForSymbol: notImplemented,
-        isLiteralConstDeclaration: notImplemented,
-        getJsxFactoryEntity: notImplemented,
-        getJsxFragmentFactoryEntity: notImplemented,
-        getAllAccessorDeclarations: notImplemented,
-        getSymbolOfExternalModuleSpecifier: notImplemented,
-        isBindingCapturedByNode: notImplemented,
-        getDeclarationStatementsForSourceFile: notImplemented,
-        isImportRequiredByAugmentation: notImplemented
-      };
-      createPrinterWithDefaults = /* @__PURE__ */ memoize(() => createPrinter({}));
-      createPrinterWithRemoveComments = /* @__PURE__ */ memoize(() => createPrinter({ removeComments: true }));
-      createPrinterWithRemoveCommentsNeverAsciiEscape = /* @__PURE__ */ memoize(() => createPrinter({ removeComments: true, neverAsciiEscape: true }));
-      createPrinterWithRemoveCommentsOmitTrailingSemicolon = /* @__PURE__ */ memoize(() => createPrinter({ removeComments: true, omitTrailingSemicolon: true }));
-    }
-  });
-
-  // src/compiler/watchUtilities.ts
-  function createCachedDirectoryStructureHost(host, currentDirectory, useCaseSensitiveFileNames) {
-    if (!host.getDirectories || !host.readDirectory) {
-      return void 0;
-    }
-    const cachedReadDirectoryResult = /* @__PURE__ */ new Map();
-    const getCanonicalFileName = createGetCanonicalFileName(useCaseSensitiveFileNames);
-    return {
-      useCaseSensitiveFileNames,
-      fileExists,
-      readFile: (path, encoding) => host.readFile(path, encoding),
-      directoryExists: host.directoryExists && directoryExists,
-      getDirectories,
-      readDirectory,
-      createDirectory: host.createDirectory && createDirectory,
-      writeFile: host.writeFile && writeFile2,
-      addOrDeleteFileOrDirectory,
-      addOrDeleteFile,
-      clearCache,
-      realpath: host.realpath && realpath
-    };
-    function toPath3(fileName) {
-      return toPath(fileName, currentDirectory, getCanonicalFileName);
-    }
-    function getCachedFileSystemEntries(rootDirPath) {
-      return cachedReadDirectoryResult.get(ensureTrailingDirectorySeparator(rootDirPath));
-    }
-    function getCachedFileSystemEntriesForBaseDir(path) {
-      const entries = getCachedFileSystemEntries(getDirectoryPath(path));
-      if (!entries) {
-        return entries;
-      }
-      if (!entries.sortedAndCanonicalizedFiles) {
-        entries.sortedAndCanonicalizedFiles = entries.files.map(getCanonicalFileName).sort();
-        entries.sortedAndCanonicalizedDirectories = entries.directories.map(getCanonicalFileName).sort();
-      }
-      return entries;
-    }
-    function getBaseNameOfFileName(fileName) {
-      return getBaseFileName(normalizePath(fileName));
-    }
-    function createCachedFileSystemEntries(rootDir, rootDirPath) {
-      var _a;
-      if (!host.realpath || ensureTrailingDirectorySeparator(toPath3(host.realpath(rootDir))) === rootDirPath) {
-        const resultFromHost = {
-          files: map(host.readDirectory(
-            rootDir,
-            /*extensions*/
-            void 0,
-            /*exclude*/
-            void 0,
-            /*include*/
-            ["*.*"]
-          ), getBaseNameOfFileName) || [],
-          directories: host.getDirectories(rootDir) || []
-        };
-        cachedReadDirectoryResult.set(ensureTrailingDirectorySeparator(rootDirPath), resultFromHost);
-        return resultFromHost;
-      }
-      if ((_a = host.directoryExists) == null ? void 0 : _a.call(host, rootDir)) {
-        cachedReadDirectoryResult.set(rootDirPath, false);
-        return false;
-      }
-      return void 0;
-    }
-    function tryReadDirectory2(rootDir, rootDirPath) {
-      rootDirPath = ensureTrailingDirectorySeparator(rootDirPath);
-      const cachedResult = getCachedFileSystemEntries(rootDirPath);
-      if (cachedResult) {
-        return cachedResult;
-      }
-      try {
-        return createCachedFileSystemEntries(rootDir, rootDirPath);
-      } catch (_e) {
-        Debug.assert(!cachedReadDirectoryResult.has(ensureTrailingDirectorySeparator(rootDirPath)));
-        return void 0;
-      }
-    }
-    function hasEntry(entries, name) {
-      const index = binarySearch(entries, name, identity, compareStringsCaseSensitive);
-      return index >= 0;
-    }
-    function writeFile2(fileName, data, writeByteOrderMark) {
-      const path = toPath3(fileName);
-      const result = getCachedFileSystemEntriesForBaseDir(path);
-      if (result) {
-        updateFilesOfFileSystemEntry(
-          result,
-          getBaseNameOfFileName(fileName),
-          /*fileExists*/
-          true
-        );
-      }
-      return host.writeFile(fileName, data, writeByteOrderMark);
-    }
-    function fileExists(fileName) {
-      const path = toPath3(fileName);
-      const result = getCachedFileSystemEntriesForBaseDir(path);
-      return result && hasEntry(result.sortedAndCanonicalizedFiles, getCanonicalFileName(getBaseNameOfFileName(fileName))) || host.fileExists(fileName);
-    }
-    function directoryExists(dirPath) {
-      const path = toPath3(dirPath);
-      return cachedReadDirectoryResult.has(ensureTrailingDirectorySeparator(path)) || host.directoryExists(dirPath);
-    }
-    function createDirectory(dirPath) {
-      const path = toPath3(dirPath);
-      const result = getCachedFileSystemEntriesForBaseDir(path);
-      if (result) {
-        const baseName = getBaseNameOfFileName(dirPath);
-        const canonicalizedBaseName = getCanonicalFileName(baseName);
-        const canonicalizedDirectories = result.sortedAndCanonicalizedDirectories;
-        if (insertSorted(canonicalizedDirectories, canonicalizedBaseName, compareStringsCaseSensitive)) {
-          result.directories.push(baseName);
-        }
-      }
-      host.createDirectory(dirPath);
-    }
-    function getDirectories(rootDir) {
-      const rootDirPath = toPath3(rootDir);
-      const result = tryReadDirectory2(rootDir, rootDirPath);
-      if (result) {
-        return result.directories.slice();
-      }
-      return host.getDirectories(rootDir);
-    }
-    function readDirectory(rootDir, extensions, excludes, includes, depth) {
-      const rootDirPath = toPath3(rootDir);
-      const rootResult = tryReadDirectory2(rootDir, rootDirPath);
-      let rootSymLinkResult;
-      if (rootResult !== void 0) {
-        return matchFiles(rootDir, extensions, excludes, includes, useCaseSensitiveFileNames, currentDirectory, depth, getFileSystemEntries, realpath);
-      }
-      return host.readDirectory(rootDir, extensions, excludes, includes, depth);
-      function getFileSystemEntries(dir) {
-        const path = toPath3(dir);
-        if (path === rootDirPath) {
-          return rootResult || getFileSystemEntriesFromHost(dir, path);
-        }
-        const result = tryReadDirectory2(dir, path);
-        return result !== void 0 ? result || getFileSystemEntriesFromHost(dir, path) : emptyFileSystemEntries;
-      }
-      function getFileSystemEntriesFromHost(dir, path) {
-        if (rootSymLinkResult && path === rootDirPath)
-          return rootSymLinkResult;
-        const result = {
-          files: map(host.readDirectory(
-            dir,
-            /*extensions*/
-            void 0,
-            /*exclude*/
-            void 0,
-            /*include*/
-            ["*.*"]
-          ), getBaseNameOfFileName) || emptyArray,
-          directories: host.getDirectories(dir) || emptyArray
-        };
-        if (path === rootDirPath)
-          rootSymLinkResult = result;
-        return result;
-      }
-    }
-    function realpath(s) {
-      return host.realpath ? host.realpath(s) : s;
-    }
-    function addOrDeleteFileOrDirectory(fileOrDirectory, fileOrDirectoryPath) {
-      const existingResult = getCachedFileSystemEntries(fileOrDirectoryPath);
-      if (existingResult !== void 0) {
-        clearCache();
-        return void 0;
-      }
-      const parentResult = getCachedFileSystemEntriesForBaseDir(fileOrDirectoryPath);
-      if (!parentResult) {
-        return void 0;
-      }
-      if (!host.directoryExists) {
-        clearCache();
-        return void 0;
-      }
-      const baseName = getBaseNameOfFileName(fileOrDirectory);
-      const fsQueryResult = {
-        fileExists: host.fileExists(fileOrDirectoryPath),
-        directoryExists: host.directoryExists(fileOrDirectoryPath)
-      };
-      if (fsQueryResult.directoryExists || hasEntry(parentResult.sortedAndCanonicalizedDirectories, getCanonicalFileName(baseName))) {
-        clearCache();
-      } else {
-        updateFilesOfFileSystemEntry(parentResult, baseName, fsQueryResult.fileExists);
-      }
-      return fsQueryResult;
-    }
-    function addOrDeleteFile(fileName, filePath, eventKind) {
-      if (eventKind === 1 /* Changed */) {
-        return;
-      }
-      const parentResult = getCachedFileSystemEntriesForBaseDir(filePath);
-      if (parentResult) {
-        updateFilesOfFileSystemEntry(parentResult, getBaseNameOfFileName(fileName), eventKind === 0 /* Created */);
-      }
-    }
-    function updateFilesOfFileSystemEntry(parentResult, baseName, fileExists2) {
-      const canonicalizedFiles = parentResult.sortedAndCanonicalizedFiles;
-      const canonicalizedBaseName = getCanonicalFileName(baseName);
-      if (fileExists2) {
-        if (insertSorted(canonicalizedFiles, canonicalizedBaseName, compareStringsCaseSensitive)) {
-          parentResult.files.push(baseName);
-        }
-      } else {
-        const sortedIndex = binarySearch(canonicalizedFiles, canonicalizedBaseName, identity, compareStringsCaseSensitive);
-        if (sortedIndex >= 0) {
-          canonicalizedFiles.splice(sortedIndex, 1);
-          const unsortedIndex = parentResult.files.findIndex((entry) => getCanonicalFileName(entry) === canonicalizedBaseName);
-          parentResult.files.splice(unsortedIndex, 1);
-        }
-      }
-    }
-    function clearCache() {
-      cachedReadDirectoryResult.clear();
-    }
-  }
-  function updateSharedExtendedConfigFileWatcher(projectPath, options, extendedConfigFilesMap, createExtendedConfigFileWatch, toPath3) {
-    var _a;
-    const extendedConfigs = arrayToMap(((_a = options == null ? void 0 : options.configFile) == null ? void 0 : _a.extendedSourceFiles) || emptyArray, toPath3);
-    extendedConfigFilesMap.forEach((watcher, extendedConfigFilePath) => {
-      if (!extendedConfigs.has(extendedConfigFilePath)) {
-        watcher.projects.delete(projectPath);
-        watcher.close();
-      }
-    });
-    extendedConfigs.forEach((extendedConfigFileName, extendedConfigFilePath) => {
-      const existing = extendedConfigFilesMap.get(extendedConfigFilePath);
-      if (existing) {
-        existing.projects.add(projectPath);
-      } else {
-        extendedConfigFilesMap.set(extendedConfigFilePath, {
-          projects: /* @__PURE__ */ new Set([projectPath]),
-          watcher: createExtendedConfigFileWatch(extendedConfigFileName, extendedConfigFilePath),
-          close: () => {
-            const existing2 = extendedConfigFilesMap.get(extendedConfigFilePath);
-            if (!existing2 || existing2.projects.size !== 0)
-              return;
-            existing2.watcher.close();
-            extendedConfigFilesMap.delete(extendedConfigFilePath);
-          }
-        });
-      }
-    });
-  }
-  function clearSharedExtendedConfigFileWatcher(projectPath, extendedConfigFilesMap) {
-    extendedConfigFilesMap.forEach((watcher) => {
-      if (watcher.projects.delete(projectPath))
-        watcher.close();
-    });
-  }
-  function cleanExtendedConfigCache(extendedConfigCache, extendedConfigFilePath, toPath3) {
-    if (!extendedConfigCache.delete(extendedConfigFilePath))
-      return;
-    extendedConfigCache.forEach(({ extendedResult }, key) => {
-      var _a;
-      if ((_a = extendedResult.extendedSourceFiles) == null ? void 0 : _a.some((extendedFile) => toPath3(extendedFile) === extendedConfigFilePath)) {
-        cleanExtendedConfigCache(extendedConfigCache, key, toPath3);
-      }
-    });
-  }
-  function updatePackageJsonWatch(lookups, packageJsonWatches, createPackageJsonWatch) {
-    const newMap = new Map(lookups);
-    mutateMap(
-      packageJsonWatches,
-      newMap,
-      {
-        createNewValue: createPackageJsonWatch,
-        onDeleteValue: closeFileWatcher
-      }
-    );
-  }
-  function updateMissingFilePathsWatch(program, missingFileWatches, createMissingFileWatch) {
-    const missingFilePaths = program.getMissingFilePaths();
-    const newMissingFilePathMap = arrayToMap(missingFilePaths, identity, returnTrue);
-    mutateMap(
-      missingFileWatches,
-      newMissingFilePathMap,
-      {
-        // Watch the missing files
-        createNewValue: createMissingFileWatch,
-        // Files that are no longer missing (e.g. because they are no longer required)
-        // should no longer be watched.
-        onDeleteValue: closeFileWatcher
-      }
-    );
-  }
-  function updateWatchingWildcardDirectories(existingWatchedForWildcards, wildcardDirectories, watchDirectory) {
-    mutateMap(
-      existingWatchedForWildcards,
-      wildcardDirectories,
-      {
-        // Create new watch and recursive info
-        createNewValue: createWildcardDirectoryWatcher,
-        // Close existing watch thats not needed any more
-        onDeleteValue: closeFileWatcherOf,
-        // Close existing watch that doesnt match in the flags
-        onExistingValue: updateWildcardDirectoryWatcher
-      }
-    );
-    function createWildcardDirectoryWatcher(directory, flags) {
-      return {
-        watcher: watchDirectory(directory, flags),
-        flags
-      };
-    }
-    function updateWildcardDirectoryWatcher(existingWatcher, flags, directory) {
-      if (existingWatcher.flags === flags) {
-        return;
-      }
-      existingWatcher.watcher.close();
-      existingWatchedForWildcards.set(directory, createWildcardDirectoryWatcher(directory, flags));
-    }
-  }
-  function isIgnoredFileFromWildCardWatching({
-    watchedDirPath,
-    fileOrDirectory,
-    fileOrDirectoryPath,
-    configFileName,
-    options,
-    program,
-    extraFileExtensions,
-    currentDirectory,
-    useCaseSensitiveFileNames,
-    writeLog,
-    toPath: toPath3
-  }) {
-    const newPath = removeIgnoredPath(fileOrDirectoryPath);
-    if (!newPath) {
-      writeLog(`Project: ${configFileName} Detected ignored path: ${fileOrDirectory}`);
-      return true;
-    }
-    fileOrDirectoryPath = newPath;
-    if (fileOrDirectoryPath === watchedDirPath)
-      return false;
-    if (hasExtension(fileOrDirectoryPath) && !isSupportedSourceFileName(fileOrDirectory, options, extraFileExtensions)) {
-      writeLog(`Project: ${configFileName} Detected file add/remove of non supported extension: ${fileOrDirectory}`);
-      return true;
-    }
-    if (isExcludedFile(fileOrDirectory, options.configFile.configFileSpecs, getNormalizedAbsolutePath(getDirectoryPath(configFileName), currentDirectory), useCaseSensitiveFileNames, currentDirectory)) {
-      writeLog(`Project: ${configFileName} Detected excluded file: ${fileOrDirectory}`);
-      return true;
-    }
-    if (!program)
-      return false;
-    if (outFile(options) || options.outDir)
-      return false;
-    if (isDeclarationFileName(fileOrDirectoryPath)) {
-      if (options.declarationDir)
-        return false;
-    } else if (!fileExtensionIsOneOf(fileOrDirectoryPath, supportedJSExtensionsFlat)) {
-      return false;
-    }
-    const filePathWithoutExtension = removeFileExtension(fileOrDirectoryPath);
-    const realProgram = isArray(program) ? void 0 : isBuilderProgram(program) ? program.getProgramOrUndefined() : program;
-    const builderProgram = !realProgram && !isArray(program) ? program : void 0;
-    if (hasSourceFile(filePathWithoutExtension + ".ts" /* Ts */) || hasSourceFile(filePathWithoutExtension + ".tsx" /* Tsx */)) {
-      writeLog(`Project: ${configFileName} Detected output file: ${fileOrDirectory}`);
-      return true;
-    }
-    return false;
-    function hasSourceFile(file) {
-      return realProgram ? !!realProgram.getSourceFileByPath(file) : builderProgram ? builderProgram.getState().fileInfos.has(file) : !!find(program, (rootFile) => toPath3(rootFile) === file);
-    }
-  }
-  function isBuilderProgram(program) {
-    return !!program.getState;
-  }
-  function isEmittedFileOfProgram(program, file) {
-    if (!program) {
-      return false;
-    }
-    return program.isEmittedFile(file);
-  }
-  function getWatchFactory(host, watchLogLevel, log, getDetailWatchInfo) {
-    setSysLog(watchLogLevel === 2 /* Verbose */ ? log : noop);
-    const plainInvokeFactory = {
-      watchFile: (file, callback, pollingInterval, options) => host.watchFile(file, callback, pollingInterval, options),
-      watchDirectory: (directory, callback, flags, options) => host.watchDirectory(directory, callback, (flags & 1 /* Recursive */) !== 0, options)
-    };
-    const triggerInvokingFactory = watchLogLevel !== 0 /* None */ ? {
-      watchFile: createTriggerLoggingAddWatch("watchFile"),
-      watchDirectory: createTriggerLoggingAddWatch("watchDirectory")
-    } : void 0;
-    const factory2 = watchLogLevel === 2 /* Verbose */ ? {
-      watchFile: createFileWatcherWithLogging,
-      watchDirectory: createDirectoryWatcherWithLogging
-    } : triggerInvokingFactory || plainInvokeFactory;
-    const excludeWatcherFactory = watchLogLevel === 2 /* Verbose */ ? createExcludeWatcherWithLogging : returnNoopFileWatcher;
-    return {
-      watchFile: createExcludeHandlingAddWatch("watchFile"),
-      watchDirectory: createExcludeHandlingAddWatch("watchDirectory")
-    };
-    function createExcludeHandlingAddWatch(key) {
-      return (file, cb, flags, options, detailInfo1, detailInfo2) => {
-        var _a;
-        return !matchesExclude(file, key === "watchFile" ? options == null ? void 0 : options.excludeFiles : options == null ? void 0 : options.excludeDirectories, useCaseSensitiveFileNames(), ((_a = host.getCurrentDirectory) == null ? void 0 : _a.call(host)) || "") ? factory2[key].call(
-          /*thisArgs*/
-          void 0,
-          file,
-          cb,
-          flags,
-          options,
-          detailInfo1,
-          detailInfo2
-        ) : excludeWatcherFactory(file, flags, options, detailInfo1, detailInfo2);
-      };
-    }
-    function useCaseSensitiveFileNames() {
-      return typeof host.useCaseSensitiveFileNames === "boolean" ? host.useCaseSensitiveFileNames : host.useCaseSensitiveFileNames();
-    }
-    function createExcludeWatcherWithLogging(file, flags, options, detailInfo1, detailInfo2) {
-      log(`ExcludeWatcher:: Added:: ${getWatchInfo(file, flags, options, detailInfo1, detailInfo2, getDetailWatchInfo)}`);
-      return {
-        close: () => log(`ExcludeWatcher:: Close:: ${getWatchInfo(file, flags, options, detailInfo1, detailInfo2, getDetailWatchInfo)}`)
-      };
-    }
-    function createFileWatcherWithLogging(file, cb, flags, options, detailInfo1, detailInfo2) {
-      log(`FileWatcher:: Added:: ${getWatchInfo(file, flags, options, detailInfo1, detailInfo2, getDetailWatchInfo)}`);
-      const watcher = triggerInvokingFactory.watchFile(file, cb, flags, options, detailInfo1, detailInfo2);
-      return {
-        close: () => {
-          log(`FileWatcher:: Close:: ${getWatchInfo(file, flags, options, detailInfo1, detailInfo2, getDetailWatchInfo)}`);
-          watcher.close();
-        }
-      };
-    }
-    function createDirectoryWatcherWithLogging(file, cb, flags, options, detailInfo1, detailInfo2) {
-      const watchInfo = `DirectoryWatcher:: Added:: ${getWatchInfo(file, flags, options, detailInfo1, detailInfo2, getDetailWatchInfo)}`;
-      log(watchInfo);
-      const start = timestamp();
-      const watcher = triggerInvokingFactory.watchDirectory(file, cb, flags, options, detailInfo1, detailInfo2);
-      const elapsed = timestamp() - start;
-      log(`Elapsed:: ${elapsed}ms ${watchInfo}`);
-      return {
-        close: () => {
-          const watchInfo2 = `DirectoryWatcher:: Close:: ${getWatchInfo(file, flags, options, detailInfo1, detailInfo2, getDetailWatchInfo)}`;
-          log(watchInfo2);
-          const start2 = timestamp();
-          watcher.close();
-          const elapsed2 = timestamp() - start2;
-          log(`Elapsed:: ${elapsed2}ms ${watchInfo2}`);
-        }
-      };
-    }
-    function createTriggerLoggingAddWatch(key) {
-      return (file, cb, flags, options, detailInfo1, detailInfo2) => plainInvokeFactory[key].call(
-        /*thisArgs*/
-        void 0,
-        file,
-        (...args) => {
-          const triggerredInfo = `${key === "watchFile" ? "FileWatcher" : "DirectoryWatcher"}:: Triggered with ${args[0]} ${args[1] !== void 0 ? args[1] : ""}:: ${getWatchInfo(file, flags, options, detailInfo1, detailInfo2, getDetailWatchInfo)}`;
-          log(triggerredInfo);
-          const start = timestamp();
-          cb.call(
-            /*thisArg*/
-            void 0,
-            ...args
-          );
-          const elapsed = timestamp() - start;
-          log(`Elapsed:: ${elapsed}ms ${triggerredInfo}`);
-        },
-        flags,
-        options,
-        detailInfo1,
-        detailInfo2
-      );
-    }
-    function getWatchInfo(file, flags, options, detailInfo1, detailInfo2, getDetailWatchInfo2) {
-      return `WatchInfo: ${file} ${flags} ${JSON.stringify(options)} ${getDetailWatchInfo2 ? getDetailWatchInfo2(detailInfo1, detailInfo2) : detailInfo2 === void 0 ? detailInfo1 : `${detailInfo1} ${detailInfo2}`}`;
-    }
-  }
-  function getFallbackOptions(options) {
-    const fallbackPolling = options == null ? void 0 : options.fallbackPolling;
-    return {
-      watchFile: fallbackPolling !== void 0 ? fallbackPolling : 1 /* PriorityPollingInterval */
-    };
-  }
-  function closeFileWatcherOf(objWithWatcher) {
-    objWithWatcher.watcher.close();
-  }
-  var ConfigFileProgramReloadLevel, WatchLogLevel;
-  var init_watchUtilities = __esm({
-    "src/compiler/watchUtilities.ts"() {
-      "use strict";
-      init_ts2();
-      ConfigFileProgramReloadLevel = /* @__PURE__ */ ((ConfigFileProgramReloadLevel2) => {
-        ConfigFileProgramReloadLevel2[ConfigFileProgramReloadLevel2["None"] = 0] = "None";
-        ConfigFileProgramReloadLevel2[ConfigFileProgramReloadLevel2["Partial"] = 1] = "Partial";
-        ConfigFileProgramReloadLevel2[ConfigFileProgramReloadLevel2["Full"] = 2] = "Full";
-        return ConfigFileProgramReloadLevel2;
-      })(ConfigFileProgramReloadLevel || {});
-      WatchLogLevel = /* @__PURE__ */ ((WatchLogLevel2) => {
-        WatchLogLevel2[WatchLogLevel2["None"] = 0] = "None";
-        WatchLogLevel2[WatchLogLevel2["TriggerOnly"] = 1] = "TriggerOnly";
-        WatchLogLevel2[WatchLogLevel2["Verbose"] = 2] = "Verbose";
-        return WatchLogLevel2;
-      })(WatchLogLevel || {});
-    }
-  });
-
-  // src/compiler/program.ts
-  function findConfigFile(searchPath, fileExists, configName = "tsconfig.json") {
-    return forEachAncestorDirectory(searchPath, (ancestor) => {
-      const fileName = combinePaths(ancestor, configName);
-      return fileExists(fileName) ? fileName : void 0;
-    });
-  }
-  function resolveTripleslashReference(moduleName, containingFile) {
-    const basePath = getDirectoryPath(containingFile);
-    const referencedFileName = isRootedDiskPath(moduleName) ? moduleName : combinePaths(basePath, moduleName);
-    return normalizePath(referencedFileName);
-  }
-  function computeCommonSourceDirectoryOfFilenames(fileNames, currentDirectory, getCanonicalFileName) {
-    let commonPathComponents;
-    const failed = forEach(fileNames, (sourceFile) => {
-      const sourcePathComponents = getNormalizedPathComponents(sourceFile, currentDirectory);
-      sourcePathComponents.pop();
-      if (!commonPathComponents) {
-        commonPathComponents = sourcePathComponents;
-        return;
-      }
-      const n = Math.min(commonPathComponents.length, sourcePathComponents.length);
-      for (let i = 0; i < n; i++) {
-        if (getCanonicalFileName(commonPathComponents[i]) !== getCanonicalFileName(sourcePathComponents[i])) {
-          if (i === 0) {
-            return true;
-          }
-          commonPathComponents.length = i;
-          break;
-        }
-      }
-      if (sourcePathComponents.length < commonPathComponents.length) {
-        commonPathComponents.length = sourcePathComponents.length;
-      }
-    });
-    if (failed) {
-      return "";
-    }
-    if (!commonPathComponents) {
-      return currentDirectory;
-    }
-    return getPathFromPathComponents(commonPathComponents);
-  }
-  function createCompilerHost(options, setParentNodes) {
-    return createCompilerHostWorker(options, setParentNodes);
-  }
-  function createGetSourceFile(readFile, getCompilerOptions, setParentNodes) {
-    return (fileName, languageVersionOrOptions, onError) => {
-      let text;
-      try {
-        mark("beforeIORead");
-        text = readFile(fileName, getCompilerOptions().charset);
-        mark("afterIORead");
-        measure("I/O Read", "beforeIORead", "afterIORead");
-      } catch (e) {
-        if (onError) {
-          onError(e.message);
-        }
-        text = "";
-      }
-      return text !== void 0 ? createSourceFile(fileName, text, languageVersionOrOptions, setParentNodes) : void 0;
-    };
-  }
-  function createWriteFileMeasuringIO(actualWriteFile, createDirectory, directoryExists) {
-    return (fileName, data, writeByteOrderMark, onError) => {
-      try {
-        mark("beforeIOWrite");
-        writeFileEnsuringDirectories(
-          fileName,
-          data,
-          writeByteOrderMark,
-          actualWriteFile,
-          createDirectory,
-          directoryExists
-        );
-        mark("afterIOWrite");
-        measure("I/O Write", "beforeIOWrite", "afterIOWrite");
-      } catch (e) {
-        if (onError) {
-          onError(e.message);
-        }
-      }
-    };
-  }
-  function createCompilerHostWorker(options, setParentNodes, system = sys) {
-    const existingDirectories = /* @__PURE__ */ new Map();
-    const getCanonicalFileName = createGetCanonicalFileName(system.useCaseSensitiveFileNames);
-    function directoryExists(directoryPath) {
-      if (existingDirectories.has(directoryPath)) {
-        return true;
-      }
-      if ((compilerHost.directoryExists || system.directoryExists)(directoryPath)) {
-        existingDirectories.set(directoryPath, true);
-        return true;
-      }
-      return false;
-    }
-    function getDefaultLibLocation() {
-      return getDirectoryPath(normalizePath(system.getExecutingFilePath()));
-    }
-    const newLine = getNewLineCharacter(options);
-    const realpath = system.realpath && ((path) => system.realpath(path));
-    const compilerHost = {
-      getSourceFile: createGetSourceFile((fileName) => compilerHost.readFile(fileName), () => options, setParentNodes),
-      getDefaultLibLocation,
-      getDefaultLibFileName: (options2) => combinePaths(getDefaultLibLocation(), getDefaultLibFileName(options2)),
-      writeFile: createWriteFileMeasuringIO(
-        (path, data, writeByteOrderMark) => system.writeFile(path, data, writeByteOrderMark),
-        (path) => (compilerHost.createDirectory || system.createDirectory)(path),
-        (path) => directoryExists(path)
-      ),
-      getCurrentDirectory: memoize(() => system.getCurrentDirectory()),
-      useCaseSensitiveFileNames: () => system.useCaseSensitiveFileNames,
-      getCanonicalFileName,
-      getNewLine: () => newLine,
-      fileExists: (fileName) => system.fileExists(fileName),
-      readFile: (fileName) => system.readFile(fileName),
-      trace: (s) => system.write(s + newLine),
-      directoryExists: (directoryName) => system.directoryExists(directoryName),
-      getEnvironmentVariable: (name) => system.getEnvironmentVariable ? system.getEnvironmentVariable(name) : "",
-      getDirectories: (path) => system.getDirectories(path),
-      realpath,
-      readDirectory: (path, extensions, include, exclude, depth) => system.readDirectory(path, extensions, include, exclude, depth),
-      createDirectory: (d) => system.createDirectory(d),
-      createHash: maybeBind(system, system.createHash)
-    };
-    return compilerHost;
-  }
-  function changeCompilerHostLikeToUseCache(host, toPath3, getSourceFile) {
-    const originalReadFile = host.readFile;
-    const originalFileExists = host.fileExists;
-    const originalDirectoryExists = host.directoryExists;
-    const originalCreateDirectory = host.createDirectory;
-    const originalWriteFile = host.writeFile;
-    const readFileCache = /* @__PURE__ */ new Map();
-    const fileExistsCache = /* @__PURE__ */ new Map();
-    const directoryExistsCache = /* @__PURE__ */ new Map();
-    const sourceFileCache = /* @__PURE__ */ new Map();
-    const readFileWithCache = (fileName) => {
-      const key = toPath3(fileName);
-      const value = readFileCache.get(key);
-      if (value !== void 0)
-        return value !== false ? value : void 0;
-      return setReadFileCache(key, fileName);
-    };
-    const setReadFileCache = (key, fileName) => {
-      const newValue = originalReadFile.call(host, fileName);
-      readFileCache.set(key, newValue !== void 0 ? newValue : false);
-      return newValue;
-    };
-    host.readFile = (fileName) => {
-      const key = toPath3(fileName);
-      const value = readFileCache.get(key);
-      if (value !== void 0)
-        return value !== false ? value : void 0;
-      if (!fileExtensionIs(fileName, ".json" /* Json */) && !isBuildInfoFile(fileName)) {
-        return originalReadFile.call(host, fileName);
-      }
-      return setReadFileCache(key, fileName);
-    };
-    const getSourceFileWithCache = getSourceFile ? (fileName, languageVersionOrOptions, onError, shouldCreateNewSourceFile) => {
-      const key = toPath3(fileName);
-      const impliedNodeFormat = typeof languageVersionOrOptions === "object" ? languageVersionOrOptions.impliedNodeFormat : void 0;
-      const forImpliedNodeFormat = sourceFileCache.get(impliedNodeFormat);
-      const value = forImpliedNodeFormat == null ? void 0 : forImpliedNodeFormat.get(key);
-      if (value)
-        return value;
-      const sourceFile = getSourceFile(fileName, languageVersionOrOptions, onError, shouldCreateNewSourceFile);
-      if (sourceFile && (isDeclarationFileName(fileName) || fileExtensionIs(fileName, ".json" /* Json */))) {
-        sourceFileCache.set(impliedNodeFormat, (forImpliedNodeFormat || /* @__PURE__ */ new Map()).set(key, sourceFile));
-      }
-      return sourceFile;
-    } : void 0;
-    host.fileExists = (fileName) => {
-      const key = toPath3(fileName);
-      const value = fileExistsCache.get(key);
-      if (value !== void 0)
-        return value;
-      const newValue = originalFileExists.call(host, fileName);
-      fileExistsCache.set(key, !!newValue);
-      return newValue;
-    };
-    if (originalWriteFile) {
-      host.writeFile = (fileName, data, ...rest) => {
-        const key = toPath3(fileName);
-        fileExistsCache.delete(key);
-        const value = readFileCache.get(key);
-        if (value !== void 0 && value !== data) {
-          readFileCache.delete(key);
-          sourceFileCache.forEach((map2) => map2.delete(key));
-        } else if (getSourceFileWithCache) {
-          sourceFileCache.forEach((map2) => {
-            const sourceFile = map2.get(key);
-            if (sourceFile && sourceFile.text !== data) {
-              map2.delete(key);
-            }
-          });
-        }
-        originalWriteFile.call(host, fileName, data, ...rest);
-      };
-    }
-    if (originalDirectoryExists) {
-      host.directoryExists = (directory) => {
-        const key = toPath3(directory);
-        const value = directoryExistsCache.get(key);
-        if (value !== void 0)
-          return value;
-        const newValue = originalDirectoryExists.call(host, directory);
-        directoryExistsCache.set(key, !!newValue);
-        return newValue;
-      };
-      if (originalCreateDirectory) {
-        host.createDirectory = (directory) => {
-          const key = toPath3(directory);
-          directoryExistsCache.delete(key);
-          originalCreateDirectory.call(host, directory);
-        };
-      }
-    }
-    return {
-      originalReadFile,
-      originalFileExists,
-      originalDirectoryExists,
-      originalCreateDirectory,
-      originalWriteFile,
-      getSourceFileWithCache,
-      readFileWithCache
-    };
-  }
-  function getPreEmitDiagnostics(program, sourceFile, cancellationToken) {
-    let diagnostics;
-    diagnostics = addRange(diagnostics, program.getConfigFileParsingDiagnostics());
-    diagnostics = addRange(diagnostics, program.getOptionsDiagnostics(cancellationToken));
-    diagnostics = addRange(diagnostics, program.getSyntacticDiagnostics(sourceFile, cancellationToken));
-    diagnostics = addRange(diagnostics, program.getGlobalDiagnostics(cancellationToken));
-    diagnostics = addRange(diagnostics, program.getSemanticDiagnostics(sourceFile, cancellationToken));
-    if (getEmitDeclarations(program.getCompilerOptions())) {
-      diagnostics = addRange(diagnostics, program.getDeclarationDiagnostics(sourceFile, cancellationToken));
-    }
-    return sortAndDeduplicateDiagnostics(diagnostics || emptyArray);
-  }
-  function formatDiagnostics(diagnostics, host) {
-    let output = "";
-    for (const diagnostic of diagnostics) {
-      output += formatDiagnostic(diagnostic, host);
-    }
-    return output;
-  }
-  function formatDiagnostic(diagnostic, host) {
-    const errorMessage = `${diagnosticCategoryName(diagnostic)} TS${diagnostic.code}: ${flattenDiagnosticMessageText(diagnostic.messageText, host.getNewLine())}${host.getNewLine()}`;
-    if (diagnostic.file) {
-      const { line, character } = getLineAndCharacterOfPosition(diagnostic.file, diagnostic.start);
-      const fileName = diagnostic.file.fileName;
-      const relativeFileName = convertToRelativePath(fileName, host.getCurrentDirectory(), (fileName2) => host.getCanonicalFileName(fileName2));
-      return `${relativeFileName}(${line + 1},${character + 1}): ` + errorMessage;
-    }
-    return errorMessage;
-  }
-  function getCategoryFormat(category) {
-    switch (category) {
-      case 1 /* Error */:
-        return "\x1B[91m" /* Red */;
-      case 0 /* Warning */:
-        return "\x1B[93m" /* Yellow */;
-      case 2 /* Suggestion */:
-        return Debug.fail("Should never get an Info diagnostic on the command line.");
-      case 3 /* Message */:
-        return "\x1B[94m" /* Blue */;
-    }
-  }
-  function formatColorAndReset(text, formatStyle) {
-    return formatStyle + text + resetEscapeSequence;
-  }
-  function formatCodeSpan(file, start, length2, indent2, squiggleColor, host) {
-    const { line: firstLine, character: firstLineChar } = getLineAndCharacterOfPosition(file, start);
-    const { line: lastLine, character: lastLineChar } = getLineAndCharacterOfPosition(file, start + length2);
-    const lastLineInFile = getLineAndCharacterOfPosition(file, file.text.length).line;
-    const hasMoreThanFiveLines = lastLine - firstLine >= 4;
-    let gutterWidth = (lastLine + 1 + "").length;
-    if (hasMoreThanFiveLines) {
-      gutterWidth = Math.max(ellipsis.length, gutterWidth);
-    }
-    let context = "";
-    for (let i = firstLine; i <= lastLine; i++) {
-      context += host.getNewLine();
-      if (hasMoreThanFiveLines && firstLine + 1 < i && i < lastLine - 1) {
-        context += indent2 + formatColorAndReset(padLeft(ellipsis, gutterWidth), gutterStyleSequence) + gutterSeparator + host.getNewLine();
-        i = lastLine - 1;
-      }
-      const lineStart = getPositionOfLineAndCharacter(file, i, 0);
-      const lineEnd = i < lastLineInFile ? getPositionOfLineAndCharacter(file, i + 1, 0) : file.text.length;
-      let lineContent = file.text.slice(lineStart, lineEnd);
-      lineContent = trimStringEnd(lineContent);
-      lineContent = lineContent.replace(/\t/g, " ");
-      context += indent2 + formatColorAndReset(padLeft(i + 1 + "", gutterWidth), gutterStyleSequence) + gutterSeparator;
-      context += lineContent + host.getNewLine();
-      context += indent2 + formatColorAndReset(padLeft("", gutterWidth), gutterStyleSequence) + gutterSeparator;
-      context += squiggleColor;
-      if (i === firstLine) {
-        const lastCharForLine = i === lastLine ? lastLineChar : void 0;
-        context += lineContent.slice(0, firstLineChar).replace(/\S/g, " ");
-        context += lineContent.slice(firstLineChar, lastCharForLine).replace(/./g, "~");
-      } else if (i === lastLine) {
-        context += lineContent.slice(0, lastLineChar).replace(/./g, "~");
-      } else {
-        context += lineContent.replace(/./g, "~");
-      }
-      context += resetEscapeSequence;
-    }
-    return context;
-  }
-  function formatLocation(file, start, host, color = formatColorAndReset) {
-    const { line: firstLine, character: firstLineChar } = getLineAndCharacterOfPosition(file, start);
-    const relativeFileName = host ? convertToRelativePath(file.fileName, host.getCurrentDirectory(), (fileName) => host.getCanonicalFileName(fileName)) : file.fileName;
-    let output = "";
-    output += color(relativeFileName, "\x1B[96m" /* Cyan */);
-    output += ":";
-    output += color(`${firstLine + 1}`, "\x1B[93m" /* Yellow */);
-    output += ":";
-    output += color(`${firstLineChar + 1}`, "\x1B[93m" /* Yellow */);
-    return output;
-  }
-  function formatDiagnosticsWithColorAndContext(diagnostics, host) {
-    let output = "";
-    for (const diagnostic of diagnostics) {
-      if (diagnostic.file) {
-        const { file, start } = diagnostic;
-        output += formatLocation(file, start, host);
-        output += " - ";
-      }
-      output += formatColorAndReset(diagnosticCategoryName(diagnostic), getCategoryFormat(diagnostic.category));
-      output += formatColorAndReset(` TS${diagnostic.code}: `, "\x1B[90m" /* Grey */);
-      output += flattenDiagnosticMessageText(diagnostic.messageText, host.getNewLine());
-      if (diagnostic.file && diagnostic.code !== Diagnostics.File_appears_to_be_binary.code) {
-        output += host.getNewLine();
-        output += formatCodeSpan(diagnostic.file, diagnostic.start, diagnostic.length, "", getCategoryFormat(diagnostic.category), host);
-      }
-      if (diagnostic.relatedInformation) {
-        output += host.getNewLine();
-        for (const { file, start, length: length2, messageText } of diagnostic.relatedInformation) {
-          if (file) {
-            output += host.getNewLine();
-            output += halfIndent + formatLocation(file, start, host);
-            output += formatCodeSpan(file, start, length2, indent, "\x1B[96m" /* Cyan */, host);
-          }
-          output += host.getNewLine();
-          output += indent + flattenDiagnosticMessageText(messageText, host.getNewLine());
-        }
-      }
-      output += host.getNewLine();
-    }
-    return output;
-  }
-  function flattenDiagnosticMessageText(diag2, newLine, indent2 = 0) {
-    if (isString(diag2)) {
-      return diag2;
-    } else if (diag2 === void 0) {
-      return "";
-    }
-    let result = "";
-    if (indent2) {
-      result += newLine;
-      for (let i = 0; i < indent2; i++) {
-        result += "  ";
-      }
-    }
-    result += diag2.messageText;
-    indent2++;
-    if (diag2.next) {
-      for (const kid of diag2.next) {
-        result += flattenDiagnosticMessageText(kid, newLine, indent2);
-      }
-    }
-    return result;
-  }
-  function getModeForFileReference(ref, containingFileMode) {
-    return (isString(ref) ? containingFileMode : ref.resolutionMode) || containingFileMode;
-  }
-  function getModeForResolutionAtIndex(file, index) {
-    if (file.impliedNodeFormat === void 0)
-      return void 0;
-    return getModeForUsageLocation(file, getModuleNameStringLiteralAt(file, index));
-  }
-  function isExclusivelyTypeOnlyImportOrExport(decl) {
-    var _a;
-    if (isExportDeclaration(decl)) {
-      return decl.isTypeOnly;
-    }
-    if ((_a = decl.importClause) == null ? void 0 : _a.isTypeOnly) {
-      return true;
-    }
-    return false;
-  }
-  function getModeForUsageLocation(file, usage) {
-    var _a, _b;
-    if (file.impliedNodeFormat === void 0)
-      return void 0;
-    if (isImportDeclaration(usage.parent) || isExportDeclaration(usage.parent)) {
-      const isTypeOnly = isExclusivelyTypeOnlyImportOrExport(usage.parent);
-      if (isTypeOnly) {
-        const override = getResolutionModeOverrideForClause(usage.parent.assertClause);
-        if (override) {
-          return override;
-        }
-      }
-    }
-    if (usage.parent.parent && isImportTypeNode(usage.parent.parent)) {
-      const override = getResolutionModeOverrideForClause((_a = usage.parent.parent.assertions) == null ? void 0 : _a.assertClause);
-      if (override) {
-        return override;
-      }
-    }
-    if (file.impliedNodeFormat !== 99 /* ESNext */) {
-      return isImportCall(walkUpParenthesizedExpressions(usage.parent)) ? 99 /* ESNext */ : 1 /* CommonJS */;
-    }
-    const exprParentParent = (_b = walkUpParenthesizedExpressions(usage.parent)) == null ? void 0 : _b.parent;
-    return exprParentParent && isImportEqualsDeclaration(exprParentParent) ? 1 /* CommonJS */ : 99 /* ESNext */;
-  }
-  function getResolutionModeOverrideForClause(clause, grammarErrorOnNode) {
-    if (!clause)
-      return void 0;
-    if (length(clause.elements) !== 1) {
-      grammarErrorOnNode == null ? void 0 : grammarErrorOnNode(clause, Diagnostics.Type_import_assertions_should_have_exactly_one_key_resolution_mode_with_value_import_or_require);
-      return void 0;
-    }
-    const elem = clause.elements[0];
-    if (!isStringLiteralLike(elem.name))
-      return void 0;
-    if (elem.name.text !== "resolution-mode") {
-      grammarErrorOnNode == null ? void 0 : grammarErrorOnNode(elem.name, Diagnostics.resolution_mode_is_the_only_valid_key_for_type_import_assertions);
-      return void 0;
-    }
-    if (!isStringLiteralLike(elem.value))
-      return void 0;
-    if (elem.value.text !== "import" && elem.value.text !== "require") {
-      grammarErrorOnNode == null ? void 0 : grammarErrorOnNode(elem.value, Diagnostics.resolution_mode_should_be_either_require_or_import);
-      return void 0;
-    }
-    return elem.value.text === "import" ? 99 /* ESNext */ : 1 /* CommonJS */;
-  }
-  function getModuleResolutionName(literal) {
-    return literal.text;
-  }
-  function createModuleResolutionLoader(containingFile, redirectedReference, options, host, cache) {
-    return {
-      nameAndMode: moduleResolutionNameAndModeGetter,
-      resolve: (moduleName, resolutionMode) => resolveModuleName(
-        moduleName,
-        containingFile,
-        options,
-        host,
-        cache,
-        redirectedReference,
-        resolutionMode
-      )
-    };
-  }
-  function getTypeReferenceResolutionName(entry) {
-    return !isString(entry) ? toFileNameLowerCase(entry.fileName) : entry;
-  }
-  function createTypeReferenceResolutionLoader(containingFile, redirectedReference, options, host, cache) {
-    return {
-      nameAndMode: typeReferenceResolutionNameAndModeGetter,
-      resolve: (typeRef, resoluionMode) => resolveTypeReferenceDirective(
-        typeRef,
-        containingFile,
-        options,
-        host,
-        redirectedReference,
-        cache,
-        resoluionMode
-      )
-    };
-  }
-  function loadWithModeAwareCache(entries, containingFile, redirectedReference, options, containingSourceFile, host, resolutionCache, createLoader) {
-    if (entries.length === 0)
-      return emptyArray;
-    const resolutions = [];
-    const cache = /* @__PURE__ */ new Map();
-    const loader = createLoader(containingFile, redirectedReference, options, host, resolutionCache);
-    for (const entry of entries) {
-      const name = loader.nameAndMode.getName(entry);
-      const mode = loader.nameAndMode.getMode(entry, containingSourceFile);
-      const key = createModeAwareCacheKey(name, mode);
-      let result = cache.get(key);
-      if (!result) {
-        cache.set(key, result = loader.resolve(name, mode));
-      }
-      resolutions.push(result);
-    }
-    return resolutions;
-  }
-  function forEachResolvedProjectReference(resolvedProjectReferences, cb) {
-    return forEachProjectReference(
-      /*projectReferences*/
-      void 0,
-      resolvedProjectReferences,
-      (resolvedRef, parent2) => resolvedRef && cb(resolvedRef, parent2)
-    );
-  }
-  function forEachProjectReference(projectReferences, resolvedProjectReferences, cbResolvedRef, cbRef) {
-    let seenResolvedRefs;
-    return worker(
-      projectReferences,
-      resolvedProjectReferences,
-      /*parent*/
-      void 0
-    );
-    function worker(projectReferences2, resolvedProjectReferences2, parent2) {
-      if (cbRef) {
-        const result = cbRef(projectReferences2, parent2);
-        if (result)
-          return result;
-      }
-      return forEach(resolvedProjectReferences2, (resolvedRef, index) => {
-        if (resolvedRef && (seenResolvedRefs == null ? void 0 : seenResolvedRefs.has(resolvedRef.sourceFile.path))) {
-          return void 0;
-        }
-        const result = cbResolvedRef(resolvedRef, parent2, index);
-        if (result || !resolvedRef)
-          return result;
-        (seenResolvedRefs || (seenResolvedRefs = /* @__PURE__ */ new Set())).add(resolvedRef.sourceFile.path);
-        return worker(resolvedRef.commandLine.projectReferences, resolvedRef.references, resolvedRef);
-      });
-    }
-  }
-  function getInferredLibraryNameResolveFrom(options, currentDirectory, libFileName) {
-    const containingDirectory = options.configFilePath ? getDirectoryPath(options.configFilePath) : currentDirectory;
-    return combinePaths(containingDirectory, `__lib_node_modules_lookup_${libFileName}__.ts`);
-  }
-  function getLibraryNameFromLibFileName(libFileName) {
-    const components = libFileName.split(".");
-    let path = components[1];
-    let i = 2;
-    while (components[i] && components[i] !== "d") {
-      path += (i === 2 ? "/" : "-") + components[i];
-      i++;
-    }
-    return "@typescript/lib-" + path;
-  }
-  function getLibFileNameFromLibReference(libReference) {
-    const libName = toFileNameLowerCase(libReference.fileName);
-    const libFileName = libMap.get(libName);
-    return { libName, libFileName };
-  }
-  function isReferencedFile(reason) {
-    switch (reason == null ? void 0 : reason.kind) {
-      case 3 /* Import */:
-      case 4 /* ReferenceFile */:
-      case 5 /* TypeReferenceDirective */:
-      case 7 /* LibReferenceDirective */:
-        return true;
-      default:
-        return false;
-    }
-  }
-  function isReferenceFileLocation(location) {
-    return location.pos !== void 0;
-  }
-  function getReferencedFileLocation(getSourceFileByPath, ref) {
-    var _a, _b, _c, _d, _e, _f;
-    const file = Debug.checkDefined(getSourceFileByPath(ref.file));
-    const { kind, index } = ref;
-    let pos, end, packageId, resolutionMode;
-    switch (kind) {
-      case 3 /* Import */:
-        const importLiteral = getModuleNameStringLiteralAt(file, index);
-        packageId = (_c = (_b = (_a = file.resolvedModules) == null ? void 0 : _a.get(importLiteral.text, getModeForResolutionAtIndex(file, index))) == null ? void 0 : _b.resolvedModule) == null ? void 0 : _c.packageId;
-        if (importLiteral.pos === -1)
-          return { file, packageId, text: importLiteral.text };
-        pos = skipTrivia(file.text, importLiteral.pos);
-        end = importLiteral.end;
-        break;
-      case 4 /* ReferenceFile */:
-        ({ pos, end } = file.referencedFiles[index]);
-        break;
-      case 5 /* TypeReferenceDirective */:
-        ({ pos, end, resolutionMode } = file.typeReferenceDirectives[index]);
-        packageId = (_f = (_e = (_d = file.resolvedTypeReferenceDirectiveNames) == null ? void 0 : _d.get(toFileNameLowerCase(file.typeReferenceDirectives[index].fileName), resolutionMode || file.impliedNodeFormat)) == null ? void 0 : _e.resolvedTypeReferenceDirective) == null ? void 0 : _f.packageId;
-        break;
-      case 7 /* LibReferenceDirective */:
-        ({ pos, end } = file.libReferenceDirectives[index]);
-        break;
-      default:
-        return Debug.assertNever(kind);
-    }
-    return { file, pos, end, packageId };
-  }
-  function isProgramUptoDate(program, rootFileNames, newOptions, getSourceVersion, fileExists, hasInvalidatedResolutions, hasInvalidatedLibResolutions, hasChangedAutomaticTypeDirectiveNames, getParsedCommandLine, projectReferences) {
-    if (!program || (hasChangedAutomaticTypeDirectiveNames == null ? void 0 : hasChangedAutomaticTypeDirectiveNames()))
-      return false;
-    if (!arrayIsEqualTo(program.getRootFileNames(), rootFileNames))
-      return false;
-    let seenResolvedRefs;
-    if (!arrayIsEqualTo(program.getProjectReferences(), projectReferences, projectReferenceUptoDate))
-      return false;
-    if (program.getSourceFiles().some(sourceFileNotUptoDate))
-      return false;
-    if (program.getMissingFilePaths().some(fileExists))
-      return false;
-    const currentOptions = program.getCompilerOptions();
-    if (!compareDataObjects(currentOptions, newOptions))
-      return false;
-    if (program.resolvedLibReferences && forEachEntry(program.resolvedLibReferences, (_value, libFileName) => hasInvalidatedLibResolutions(libFileName)))
-      return false;
-    if (currentOptions.configFile && newOptions.configFile)
-      return currentOptions.configFile.text === newOptions.configFile.text;
-    return true;
-    function sourceFileNotUptoDate(sourceFile) {
-      return !sourceFileVersionUptoDate(sourceFile) || hasInvalidatedResolutions(sourceFile.path);
-    }
-    function sourceFileVersionUptoDate(sourceFile) {
-      return sourceFile.version === getSourceVersion(sourceFile.resolvedPath, sourceFile.fileName);
-    }
-    function projectReferenceUptoDate(oldRef, newRef, index) {
-      return projectReferenceIsEqualTo(oldRef, newRef) && resolvedProjectReferenceUptoDate(program.getResolvedProjectReferences()[index], oldRef);
-    }
-    function resolvedProjectReferenceUptoDate(oldResolvedRef, oldRef) {
-      if (oldResolvedRef) {
-        if (contains(seenResolvedRefs, oldResolvedRef))
-          return true;
-        const refPath2 = resolveProjectReferencePath(oldRef);
-        const newParsedCommandLine = getParsedCommandLine(refPath2);
-        if (!newParsedCommandLine)
-          return false;
-        if (oldResolvedRef.commandLine.options.configFile !== newParsedCommandLine.options.configFile)
-          return false;
-        if (!arrayIsEqualTo(oldResolvedRef.commandLine.fileNames, newParsedCommandLine.fileNames))
-          return false;
-        (seenResolvedRefs || (seenResolvedRefs = [])).push(oldResolvedRef);
-        return !forEach(oldResolvedRef.references, (childResolvedRef, index) => !resolvedProjectReferenceUptoDate(childResolvedRef, oldResolvedRef.commandLine.projectReferences[index]));
-      }
-      const refPath = resolveProjectReferencePath(oldRef);
-      return !getParsedCommandLine(refPath);
-    }
-  }
-  function getConfigFileParsingDiagnostics(configFileParseResult) {
-    return configFileParseResult.options.configFile ? [...configFileParseResult.options.configFile.parseDiagnostics, ...configFileParseResult.errors] : configFileParseResult.errors;
-  }
-  function getImpliedNodeFormatForFile(fileName, packageJsonInfoCache, host, options) {
-    const result = getImpliedNodeFormatForFileWorker(fileName, packageJsonInfoCache, host, options);
-    return typeof result === "object" ? result.impliedNodeFormat : result;
-  }
-  function getImpliedNodeFormatForFileWorker(fileName, packageJsonInfoCache, host, options) {
-    switch (getEmitModuleResolutionKind(options)) {
-      case 3 /* Node16 */:
-      case 99 /* NodeNext */:
-        return fileExtensionIsOneOf(fileName, [".d.mts" /* Dmts */, ".mts" /* Mts */, ".mjs" /* Mjs */]) ? 99 /* ESNext */ : fileExtensionIsOneOf(fileName, [".d.cts" /* Dcts */, ".cts" /* Cts */, ".cjs" /* Cjs */]) ? 1 /* CommonJS */ : fileExtensionIsOneOf(fileName, [".d.ts" /* Dts */, ".ts" /* Ts */, ".tsx" /* Tsx */, ".js" /* Js */, ".jsx" /* Jsx */]) ? lookupFromPackageJson() : void 0;
-      default:
-        return void 0;
-    }
-    function lookupFromPackageJson() {
-      const state = getTemporaryModuleResolutionState(packageJsonInfoCache, host, options);
-      const packageJsonLocations = [];
-      state.failedLookupLocations = packageJsonLocations;
-      state.affectingLocations = packageJsonLocations;
-      const packageJsonScope = getPackageScopeForPath(fileName, state);
-      const impliedNodeFormat = (packageJsonScope == null ? void 0 : packageJsonScope.contents.packageJsonContent.type) === "module" ? 99 /* ESNext */ : 1 /* CommonJS */;
-      return { impliedNodeFormat, packageJsonLocations, packageJsonScope };
-    }
-  }
-  function shouldProgramCreateNewSourceFiles(program, newOptions) {
-    if (!program)
-      return false;
-    return optionsHaveChanges(program.getCompilerOptions(), newOptions, sourceFileAffectingCompilerOptions);
-  }
-  function createCreateProgramOptions(rootNames, options, host, oldProgram, configFileParsingDiagnostics, typeScriptVersion3) {
-    return {
-      rootNames,
-      options,
-      host,
-      oldProgram,
-      configFileParsingDiagnostics,
-      typeScriptVersion: typeScriptVersion3
-    };
-  }
-  function createProgram(rootNamesOrOptions, _options, _host, _oldProgram, _configFileParsingDiagnostics) {
-    var _a, _b, _c, _d, _e, _f, _g, _h, _i, _j, _k, _l, _m, _n, _o, _p;
-    const createProgramOptions = isArray(rootNamesOrOptions) ? createCreateProgramOptions(rootNamesOrOptions, _options, _host, _oldProgram, _configFileParsingDiagnostics) : rootNamesOrOptions;
-    const { rootNames, options, configFileParsingDiagnostics, projectReferences, typeScriptVersion: typeScriptVersion3 } = createProgramOptions;
-    let { oldProgram } = createProgramOptions;
-    const reportInvalidIgnoreDeprecations = memoize(() => createOptionValueDiagnostic("ignoreDeprecations", Diagnostics.Invalid_value_for_ignoreDeprecations));
-    let processingDefaultLibFiles;
-    let processingOtherFiles;
-    let files;
-    let symlinks;
-    let commonSourceDirectory;
-    let typeChecker;
-    let classifiableNames;
-    const ambientModuleNameToUnmodifiedFileName = /* @__PURE__ */ new Map();
-    let fileReasons = createMultiMap();
-    const cachedBindAndCheckDiagnosticsForFile = {};
-    const cachedDeclarationDiagnosticsForFile = {};
-    let resolvedTypeReferenceDirectives = createModeAwareCache();
-    let fileProcessingDiagnostics;
-    let automaticTypeDirectiveNames;
-    let automaticTypeDirectiveResolutions;
-    let resolvedLibReferences;
-    let resolvedLibProcessing;
-    let packageMap;
-    const maxNodeModuleJsDepth = typeof options.maxNodeModuleJsDepth === "number" ? options.maxNodeModuleJsDepth : 0;
-    let currentNodeModulesDepth = 0;
-    const modulesWithElidedImports = /* @__PURE__ */ new Map();
-    const sourceFilesFoundSearchingNodeModules = /* @__PURE__ */ new Map();
-    (_a = tracing) == null ? void 0 : _a.push(
-      tracing.Phase.Program,
-      "createProgram",
-      { configFilePath: options.configFilePath, rootDir: options.rootDir },
-      /*separateBeginAndEnd*/
-      true
-    );
-    mark("beforeProgram");
-    const host = createProgramOptions.host || createCompilerHost(options);
-    const configParsingHost = parseConfigHostFromCompilerHostLike(host);
-    let skipDefaultLib = options.noLib;
-    const getDefaultLibraryFileName = memoize(() => host.getDefaultLibFileName(options));
-    const defaultLibraryPath = host.getDefaultLibLocation ? host.getDefaultLibLocation() : getDirectoryPath(getDefaultLibraryFileName());
-    const programDiagnostics = createDiagnosticCollection();
-    const currentDirectory = host.getCurrentDirectory();
-    const supportedExtensions = getSupportedExtensions(options);
-    const supportedExtensionsWithJsonIfResolveJsonModule = getSupportedExtensionsWithJsonIfResolveJsonModule(options, supportedExtensions);
-    const hasEmitBlockingDiagnostics = /* @__PURE__ */ new Map();
-    let _compilerOptionsObjectLiteralSyntax;
-    let moduleResolutionCache;
-    let actualResolveModuleNamesWorker;
-    const hasInvalidatedResolutions = host.hasInvalidatedResolutions || returnFalse;
-    if (host.resolveModuleNameLiterals) {
-      actualResolveModuleNamesWorker = host.resolveModuleNameLiterals.bind(host);
-      moduleResolutionCache = (_b = host.getModuleResolutionCache) == null ? void 0 : _b.call(host);
-    } else if (host.resolveModuleNames) {
-      actualResolveModuleNamesWorker = (moduleNames, containingFile, redirectedReference, options2, containingSourceFile, reusedNames) => host.resolveModuleNames(
-        moduleNames.map(getModuleResolutionName),
-        containingFile,
-        reusedNames == null ? void 0 : reusedNames.map(getModuleResolutionName),
-        redirectedReference,
-        options2,
-        containingSourceFile
-      ).map(
-        (resolved) => resolved ? resolved.extension !== void 0 ? { resolvedModule: resolved } : (
-          // An older host may have omitted extension, in which case we should infer it from the file extension of resolvedFileName.
-          { resolvedModule: { ...resolved, extension: extensionFromPath(resolved.resolvedFileName) } }
-        ) : emptyResolution
-      );
-      moduleResolutionCache = (_c = host.getModuleResolutionCache) == null ? void 0 : _c.call(host);
-    } else {
-      moduleResolutionCache = createModuleResolutionCache(currentDirectory, getCanonicalFileName, options);
-      actualResolveModuleNamesWorker = (moduleNames, containingFile, redirectedReference, options2, containingSourceFile) => loadWithModeAwareCache(
-        moduleNames,
-        containingFile,
-        redirectedReference,
-        options2,
-        containingSourceFile,
-        host,
-        moduleResolutionCache,
-        createModuleResolutionLoader
-      );
-    }
-    let actualResolveTypeReferenceDirectiveNamesWorker;
-    if (host.resolveTypeReferenceDirectiveReferences) {
-      actualResolveTypeReferenceDirectiveNamesWorker = host.resolveTypeReferenceDirectiveReferences.bind(host);
-    } else if (host.resolveTypeReferenceDirectives) {
-      actualResolveTypeReferenceDirectiveNamesWorker = (typeDirectiveNames, containingFile, redirectedReference, options2, containingSourceFile) => host.resolveTypeReferenceDirectives(
-        typeDirectiveNames.map(getTypeReferenceResolutionName),
-        containingFile,
-        redirectedReference,
-        options2,
-        containingSourceFile == null ? void 0 : containingSourceFile.impliedNodeFormat
-      ).map((resolvedTypeReferenceDirective) => ({ resolvedTypeReferenceDirective }));
-    } else {
-      const typeReferenceDirectiveResolutionCache = createTypeReferenceDirectiveResolutionCache(
-        currentDirectory,
-        getCanonicalFileName,
-        /*options*/
-        void 0,
-        moduleResolutionCache == null ? void 0 : moduleResolutionCache.getPackageJsonInfoCache()
-      );
-      actualResolveTypeReferenceDirectiveNamesWorker = (typeDirectiveNames, containingFile, redirectedReference, options2, containingSourceFile) => loadWithModeAwareCache(
-        typeDirectiveNames,
-        containingFile,
-        redirectedReference,
-        options2,
-        containingSourceFile,
-        host,
-        typeReferenceDirectiveResolutionCache,
-        createTypeReferenceResolutionLoader
-      );
-    }
-    const hasInvalidatedLibResolutions = host.hasInvalidatedLibResolutions || returnFalse;
-    let actualResolveLibrary;
-    if (host.resolveLibrary) {
-      actualResolveLibrary = host.resolveLibrary.bind(host);
-    } else {
-      const libraryResolutionCache = createModuleResolutionCache(currentDirectory, getCanonicalFileName, options, moduleResolutionCache == null ? void 0 : moduleResolutionCache.getPackageJsonInfoCache());
-      actualResolveLibrary = (libraryName, resolveFrom, options2) => resolveLibrary(libraryName, resolveFrom, options2, host, libraryResolutionCache);
-    }
-    const packageIdToSourceFile = /* @__PURE__ */ new Map();
-    let sourceFileToPackageName = /* @__PURE__ */ new Map();
-    let redirectTargetsMap = createMultiMap();
-    let usesUriStyleNodeCoreModules = false;
-    const filesByName = /* @__PURE__ */ new Map();
-    let missingFilePaths;
-    const filesByNameIgnoreCase = host.useCaseSensitiveFileNames() ? /* @__PURE__ */ new Map() : void 0;
-    let resolvedProjectReferences;
-    let projectReferenceRedirects;
-    let mapFromFileToProjectReferenceRedirects;
-    let mapFromToProjectReferenceRedirectSource;
-    const useSourceOfProjectReferenceRedirect = !!((_d = host.useSourceOfProjectReferenceRedirect) == null ? void 0 : _d.call(host)) && !options.disableSourceOfProjectReferenceRedirect;
-    const { onProgramCreateComplete, fileExists, directoryExists } = updateHostForUseSourceOfProjectReferenceRedirect({
-      compilerHost: host,
-      getSymlinkCache,
-      useSourceOfProjectReferenceRedirect,
-      toPath: toPath3,
-      getResolvedProjectReferences,
-      getSourceOfProjectReferenceRedirect,
-      forEachResolvedProjectReference: forEachResolvedProjectReference2
-    });
-    const readFile = host.readFile.bind(host);
-    (_e = tracing) == null ? void 0 : _e.push(tracing.Phase.Program, "shouldProgramCreateNewSourceFiles", { hasOldProgram: !!oldProgram });
-    const shouldCreateNewSourceFile = shouldProgramCreateNewSourceFiles(oldProgram, options);
-    (_f = tracing) == null ? void 0 : _f.pop();
-    let structureIsReused;
-    (_g = tracing) == null ? void 0 : _g.push(tracing.Phase.Program, "tryReuseStructureFromOldProgram", {});
-    structureIsReused = tryReuseStructureFromOldProgram();
-    (_h = tracing) == null ? void 0 : _h.pop();
-    if (structureIsReused !== 2 /* Completely */) {
-      processingDefaultLibFiles = [];
-      processingOtherFiles = [];
-      if (projectReferences) {
-        if (!resolvedProjectReferences) {
-          resolvedProjectReferences = projectReferences.map(parseProjectReferenceConfigFile);
-        }
-        if (rootNames.length) {
-          resolvedProjectReferences == null ? void 0 : resolvedProjectReferences.forEach((parsedRef, index) => {
-            if (!parsedRef)
-              return;
-            const out = outFile(parsedRef.commandLine.options);
-            if (useSourceOfProjectReferenceRedirect) {
-              if (out || getEmitModuleKind(parsedRef.commandLine.options) === 0 /* None */) {
-                for (const fileName of parsedRef.commandLine.fileNames) {
-                  processProjectReferenceFile(fileName, { kind: 1 /* SourceFromProjectReference */, index });
-                }
-              }
-            } else {
-              if (out) {
-                processProjectReferenceFile(changeExtension(out, ".d.ts"), { kind: 2 /* OutputFromProjectReference */, index });
-              } else if (getEmitModuleKind(parsedRef.commandLine.options) === 0 /* None */) {
-                const getCommonSourceDirectory3 = memoize(() => getCommonSourceDirectoryOfConfig(parsedRef.commandLine, !host.useCaseSensitiveFileNames()));
-                for (const fileName of parsedRef.commandLine.fileNames) {
-                  if (!isDeclarationFileName(fileName) && !fileExtensionIs(fileName, ".json" /* Json */)) {
-                    processProjectReferenceFile(getOutputDeclarationFileName(fileName, parsedRef.commandLine, !host.useCaseSensitiveFileNames(), getCommonSourceDirectory3), { kind: 2 /* OutputFromProjectReference */, index });
-                  }
-                }
-              }
-            }
-          });
-        }
-      }
-      (_i = tracing) == null ? void 0 : _i.push(tracing.Phase.Program, "processRootFiles", { count: rootNames.length });
-      forEach(rootNames, (name, index) => processRootFile(
-        name,
-        /*isDefaultLib*/
-        false,
-        /*ignoreNoDefaultLib*/
-        false,
-        { kind: 0 /* RootFile */, index }
-      ));
-      (_j = tracing) == null ? void 0 : _j.pop();
-      automaticTypeDirectiveNames ?? (automaticTypeDirectiveNames = rootNames.length ? getAutomaticTypeDirectiveNames(options, host) : emptyArray);
-      automaticTypeDirectiveResolutions = createModeAwareCache();
-      if (automaticTypeDirectiveNames.length) {
-        (_k = tracing) == null ? void 0 : _k.push(tracing.Phase.Program, "processTypeReferences", { count: automaticTypeDirectiveNames.length });
-        const containingDirectory = options.configFilePath ? getDirectoryPath(options.configFilePath) : currentDirectory;
-        const containingFilename = combinePaths(containingDirectory, inferredTypesContainingFile);
-        const resolutions = resolveTypeReferenceDirectiveNamesReusingOldState(automaticTypeDirectiveNames, containingFilename);
-        for (let i = 0; i < automaticTypeDirectiveNames.length; i++) {
-          automaticTypeDirectiveResolutions.set(
-            automaticTypeDirectiveNames[i],
-            /*mode*/
-            void 0,
-            resolutions[i]
-          );
-          processTypeReferenceDirective(
-            automaticTypeDirectiveNames[i],
-            /*mode*/
-            void 0,
-            resolutions[i],
-            {
-              kind: 8 /* AutomaticTypeDirectiveFile */,
-              typeReference: automaticTypeDirectiveNames[i],
-              packageId: (_m = (_l = resolutions[i]) == null ? void 0 : _l.resolvedTypeReferenceDirective) == null ? void 0 : _m.packageId
-            }
-          );
-        }
-        (_n = tracing) == null ? void 0 : _n.pop();
-      }
-      if (rootNames.length && !skipDefaultLib) {
-        const defaultLibraryFileName = getDefaultLibraryFileName();
-        if (!options.lib && defaultLibraryFileName) {
-          processRootFile(
-            defaultLibraryFileName,
-            /*isDefaultLib*/
-            true,
-            /*ignoreNoDefaultLib*/
-            false,
-            { kind: 6 /* LibFile */ }
-          );
-        } else {
-          forEach(options.lib, (libFileName, index) => {
-            processRootFile(
-              pathForLibFile(libFileName),
-              /*isDefaultLib*/
-              true,
-              /*ignoreNoDefaultLib*/
-              false,
-              { kind: 6 /* LibFile */, index }
-            );
-          });
-        }
-      }
-      missingFilePaths = arrayFrom(mapDefinedIterator(filesByName.entries(), ([path, file]) => file === void 0 ? path : void 0));
-      files = stableSort(processingDefaultLibFiles, compareDefaultLibFiles).concat(processingOtherFiles);
-      processingDefaultLibFiles = void 0;
-      processingOtherFiles = void 0;
-    }
-    Debug.assert(!!missingFilePaths);
-    if (oldProgram && host.onReleaseOldSourceFile) {
-      const oldSourceFiles = oldProgram.getSourceFiles();
-      for (const oldSourceFile of oldSourceFiles) {
-        const newFile = getSourceFileByPath(oldSourceFile.resolvedPath);
-        if (shouldCreateNewSourceFile || !newFile || newFile.impliedNodeFormat !== oldSourceFile.impliedNodeFormat || // old file wasn't redirect but new file is
-        oldSourceFile.resolvedPath === oldSourceFile.path && newFile.resolvedPath !== oldSourceFile.path) {
-          host.onReleaseOldSourceFile(oldSourceFile, oldProgram.getCompilerOptions(), !!getSourceFileByPath(oldSourceFile.path));
-        }
-      }
-      if (!host.getParsedCommandLine) {
-        oldProgram.forEachResolvedProjectReference((resolvedProjectReference) => {
-          if (!getResolvedProjectReferenceByPath(resolvedProjectReference.sourceFile.path)) {
-            host.onReleaseOldSourceFile(
-              resolvedProjectReference.sourceFile,
-              oldProgram.getCompilerOptions(),
-              /*hasSourceFileByPath*/
-              false
-            );
-          }
-        });
-      }
-    }
-    if (oldProgram && host.onReleaseParsedCommandLine) {
-      forEachProjectReference(
-        oldProgram.getProjectReferences(),
-        oldProgram.getResolvedProjectReferences(),
-        (oldResolvedRef, parent2, index) => {
-          const oldReference = (parent2 == null ? void 0 : parent2.commandLine.projectReferences[index]) || oldProgram.getProjectReferences()[index];
-          const oldRefPath = resolveProjectReferencePath(oldReference);
-          if (!(projectReferenceRedirects == null ? void 0 : projectReferenceRedirects.has(toPath3(oldRefPath)))) {
-            host.onReleaseParsedCommandLine(oldRefPath, oldResolvedRef, oldProgram.getCompilerOptions());
-          }
-        }
-      );
-    }
-    oldProgram = void 0;
-    resolvedLibProcessing = void 0;
-    const program = {
-      getRootFileNames: () => rootNames,
-      getSourceFile,
-      getSourceFileByPath,
-      getSourceFiles: () => files,
-      getMissingFilePaths: () => missingFilePaths,
-      // TODO: GH#18217
-      getModuleResolutionCache: () => moduleResolutionCache,
-      getFilesByNameMap: () => filesByName,
-      getCompilerOptions: () => options,
-      getSyntacticDiagnostics,
-      getOptionsDiagnostics,
-      getGlobalDiagnostics,
-      getSemanticDiagnostics,
-      getCachedSemanticDiagnostics,
-      getSuggestionDiagnostics,
-      getDeclarationDiagnostics: getDeclarationDiagnostics2,
-      getBindAndCheckDiagnostics,
-      getProgramDiagnostics,
-      getTypeChecker,
-      getClassifiableNames,
-      getCommonSourceDirectory: getCommonSourceDirectory2,
-      emit,
-      getCurrentDirectory: () => currentDirectory,
-      getNodeCount: () => getTypeChecker().getNodeCount(),
-      getIdentifierCount: () => getTypeChecker().getIdentifierCount(),
-      getSymbolCount: () => getTypeChecker().getSymbolCount(),
-      getTypeCount: () => getTypeChecker().getTypeCount(),
-      getInstantiationCount: () => getTypeChecker().getInstantiationCount(),
-      getRelationCacheSizes: () => getTypeChecker().getRelationCacheSizes(),
-      getFileProcessingDiagnostics: () => fileProcessingDiagnostics,
-      getResolvedTypeReferenceDirectives: () => resolvedTypeReferenceDirectives,
-      getAutomaticTypeDirectiveNames: () => automaticTypeDirectiveNames,
-      getAutomaticTypeDirectiveResolutions: () => automaticTypeDirectiveResolutions,
-      isSourceFileFromExternalLibrary,
-      isSourceFileDefaultLibrary,
-      getSourceFileFromReference,
-      getLibFileFromReference,
-      sourceFileToPackageName,
-      redirectTargetsMap,
-      usesUriStyleNodeCoreModules,
-      resolvedLibReferences,
-      getCurrentPackagesMap: () => packageMap,
-      typesPackageExists,
-      packageBundlesTypes,
-      isEmittedFile,
-      getConfigFileParsingDiagnostics: getConfigFileParsingDiagnostics2,
-      getProjectReferences,
-      getResolvedProjectReferences,
-      getProjectReferenceRedirect,
-      getResolvedProjectReferenceToRedirect,
-      getResolvedProjectReferenceByPath,
-      forEachResolvedProjectReference: forEachResolvedProjectReference2,
-      isSourceOfProjectReferenceRedirect,
-      emitBuildInfo,
-      fileExists,
-      readFile,
-      directoryExists,
-      getSymlinkCache,
-      realpath: (_o = host.realpath) == null ? void 0 : _o.bind(host),
-      useCaseSensitiveFileNames: () => host.useCaseSensitiveFileNames(),
-      getCanonicalFileName,
-      getFileIncludeReasons: () => fileReasons,
-      structureIsReused,
-      writeFile: writeFile2
-    };
-    onProgramCreateComplete();
-    fileProcessingDiagnostics == null ? void 0 : fileProcessingDiagnostics.forEach((diagnostic) => {
-      switch (diagnostic.kind) {
-        case 1 /* FilePreprocessingFileExplainingDiagnostic */:
-          return programDiagnostics.add(createDiagnosticExplainingFile(diagnostic.file && getSourceFileByPath(diagnostic.file), diagnostic.fileProcessingReason, diagnostic.diagnostic, diagnostic.args || emptyArray));
-        case 0 /* FilePreprocessingReferencedDiagnostic */:
-          const { file, pos, end } = getReferencedFileLocation(getSourceFileByPath, diagnostic.reason);
-          return programDiagnostics.add(createFileDiagnostic(file, Debug.checkDefined(pos), Debug.checkDefined(end) - pos, diagnostic.diagnostic, ...diagnostic.args || emptyArray));
-        case 2 /* ResolutionDiagnostics */:
-          return diagnostic.diagnostics.forEach((d) => programDiagnostics.add(d));
-        default:
-          Debug.assertNever(diagnostic);
-      }
-    });
-    verifyCompilerOptions();
-    mark("afterProgram");
-    measure("Program", "beforeProgram", "afterProgram");
-    (_p = tracing) == null ? void 0 : _p.pop();
-    return program;
-    function getPackagesMap() {
-      if (packageMap)
-        return packageMap;
-      packageMap = /* @__PURE__ */ new Map();
-      files.forEach((sf) => {
-        if (!sf.resolvedModules)
-          return;
-        sf.resolvedModules.forEach(({ resolvedModule }) => {
-          if (resolvedModule == null ? void 0 : resolvedModule.packageId)
-            packageMap.set(resolvedModule.packageId.name, resolvedModule.extension === ".d.ts" /* Dts */ || !!packageMap.get(resolvedModule.packageId.name));
-        });
-      });
-      return packageMap;
-    }
-    function typesPackageExists(packageName) {
-      return getPackagesMap().has(getTypesPackageName(packageName));
-    }
-    function packageBundlesTypes(packageName) {
-      return !!getPackagesMap().get(packageName);
-    }
-    function addResolutionDiagnostics(resolution) {
-      var _a2;
-      if (!((_a2 = resolution.resolutionDiagnostics) == null ? void 0 : _a2.length))
-        return;
-      (fileProcessingDiagnostics ?? (fileProcessingDiagnostics = [])).push({
-        kind: 2 /* ResolutionDiagnostics */,
-        diagnostics: resolution.resolutionDiagnostics
-      });
-    }
-    function addResolutionDiagnosticsFromResolutionOrCache(containingFile, name, resolution, mode) {
-      if (host.resolveModuleNameLiterals || !host.resolveModuleNames)
-        return addResolutionDiagnostics(resolution);
-      if (!moduleResolutionCache || isExternalModuleNameRelative(name))
-        return;
-      const containingFileName = getNormalizedAbsolutePath(containingFile.originalFileName, currentDirectory);
-      const containingDir = getDirectoryPath(containingFileName);
-      const redirectedReference = getRedirectReferenceForResolution(containingFile);
-      const fromCache = moduleResolutionCache.getFromNonRelativeNameCache(name, mode, containingDir, redirectedReference);
-      if (fromCache)
-        addResolutionDiagnostics(fromCache);
-    }
-    function resolveModuleNamesWorker(moduleNames, containingFile, reusedNames) {
-      var _a2, _b2;
-      if (!moduleNames.length)
-        return emptyArray;
-      const containingFileName = getNormalizedAbsolutePath(containingFile.originalFileName, currentDirectory);
-      const redirectedReference = getRedirectReferenceForResolution(containingFile);
-      (_a2 = tracing) == null ? void 0 : _a2.push(tracing.Phase.Program, "resolveModuleNamesWorker", { containingFileName });
-      mark("beforeResolveModule");
-      const result = actualResolveModuleNamesWorker(moduleNames, containingFileName, redirectedReference, options, containingFile, reusedNames);
-      mark("afterResolveModule");
-      measure("ResolveModule", "beforeResolveModule", "afterResolveModule");
-      (_b2 = tracing) == null ? void 0 : _b2.pop();
-      return result;
-    }
-    function resolveTypeReferenceDirectiveNamesWorker(typeDirectiveNames, containingFile, reusedNames) {
-      var _a2, _b2;
-      if (!typeDirectiveNames.length)
-        return [];
-      const containingSourceFile = !isString(containingFile) ? containingFile : void 0;
-      const containingFileName = !isString(containingFile) ? getNormalizedAbsolutePath(containingFile.originalFileName, currentDirectory) : containingFile;
-      const redirectedReference = containingSourceFile && getRedirectReferenceForResolution(containingSourceFile);
-      (_a2 = tracing) == null ? void 0 : _a2.push(tracing.Phase.Program, "resolveTypeReferenceDirectiveNamesWorker", { containingFileName });
-      mark("beforeResolveTypeReference");
-      const result = actualResolveTypeReferenceDirectiveNamesWorker(typeDirectiveNames, containingFileName, redirectedReference, options, containingSourceFile, reusedNames);
-      mark("afterResolveTypeReference");
-      measure("ResolveTypeReference", "beforeResolveTypeReference", "afterResolveTypeReference");
-      (_b2 = tracing) == null ? void 0 : _b2.pop();
-      return result;
-    }
-    function getRedirectReferenceForResolution(file) {
-      const redirect = getResolvedProjectReferenceToRedirect(file.originalFileName);
-      if (redirect || !isDeclarationFileName(file.originalFileName))
-        return redirect;
-      const resultFromDts = getRedirectReferenceForResolutionFromSourceOfProject(file.path);
-      if (resultFromDts)
-        return resultFromDts;
-      if (!host.realpath || !options.preserveSymlinks || !stringContains(file.originalFileName, nodeModulesPathPart))
-        return void 0;
-      const realDeclarationPath = toPath3(host.realpath(file.originalFileName));
-      return realDeclarationPath === file.path ? void 0 : getRedirectReferenceForResolutionFromSourceOfProject(realDeclarationPath);
-    }
-    function getRedirectReferenceForResolutionFromSourceOfProject(filePath) {
-      const source = getSourceOfProjectReferenceRedirect(filePath);
-      if (isString(source))
-        return getResolvedProjectReferenceToRedirect(source);
-      if (!source)
-        return void 0;
-      return forEachResolvedProjectReference2((resolvedRef) => {
-        const out = outFile(resolvedRef.commandLine.options);
-        if (!out)
-          return void 0;
-        return toPath3(out) === filePath ? resolvedRef : void 0;
-      });
-    }
-    function compareDefaultLibFiles(a, b) {
-      return compareValues(getDefaultLibFilePriority(a), getDefaultLibFilePriority(b));
-    }
-    function getDefaultLibFilePriority(a) {
-      if (containsPath(
-        defaultLibraryPath,
-        a.fileName,
-        /*ignoreCase*/
-        false
-      )) {
-        const basename = getBaseFileName(a.fileName);
-        if (basename === "lib.d.ts" || basename === "lib.es6.d.ts")
-          return 0;
-        const name = removeSuffix(removePrefix(basename, "lib."), ".d.ts");
-        const index = libs.indexOf(name);
-        if (index !== -1)
-          return index + 1;
-      }
-      return libs.length + 2;
-    }
-    function toPath3(fileName) {
-      return toPath(fileName, currentDirectory, getCanonicalFileName);
-    }
-    function getCommonSourceDirectory2() {
-      if (commonSourceDirectory === void 0) {
-        const emittedFiles = filter(files, (file) => sourceFileMayBeEmitted(file, program));
-        commonSourceDirectory = getCommonSourceDirectory(
-          options,
-          () => mapDefined(emittedFiles, (file) => file.isDeclarationFile ? void 0 : file.fileName),
-          currentDirectory,
-          getCanonicalFileName,
-          (commonSourceDirectory2) => checkSourceFilesBelongToPath(emittedFiles, commonSourceDirectory2)
-        );
-      }
-      return commonSourceDirectory;
-    }
-    function getClassifiableNames() {
-      var _a2;
-      if (!classifiableNames) {
-        getTypeChecker();
-        classifiableNames = /* @__PURE__ */ new Set();
-        for (const sourceFile of files) {
-          (_a2 = sourceFile.classifiableNames) == null ? void 0 : _a2.forEach((value) => classifiableNames.add(value));
-        }
-      }
-      return classifiableNames;
-    }
-    function resolveModuleNamesReusingOldState(moduleNames, file) {
-      var _a2;
-      if (structureIsReused === 0 /* Not */ && !file.ambientModuleNames.length) {
-        return resolveModuleNamesWorker(
-          moduleNames,
-          file,
-          /*reusedNames*/
-          void 0
-        );
-      }
-      const oldSourceFile = oldProgram && oldProgram.getSourceFile(file.fileName);
-      if (oldSourceFile !== file && file.resolvedModules) {
-        const result2 = [];
-        for (const moduleName of moduleNames) {
-          const resolvedModule = file.resolvedModules.get(moduleName.text, getModeForUsageLocation(file, moduleName));
-          result2.push(resolvedModule);
-        }
-        return result2;
-      }
-      let unknownModuleNames;
-      let result;
-      let reusedNames;
-      const predictedToResolveToAmbientModuleMarker = emptyResolution;
-      for (let i = 0; i < moduleNames.length; i++) {
-        const moduleName = moduleNames[i];
-        if (file === oldSourceFile && !hasInvalidatedResolutions(oldSourceFile.path)) {
-          const mode = getModeForUsageLocation(file, moduleName);
-          const oldResolution = (_a2 = oldSourceFile.resolvedModules) == null ? void 0 : _a2.get(moduleName.text, mode);
-          if (oldResolution == null ? void 0 : oldResolution.resolvedModule) {
-            if (isTraceEnabled(options, host)) {
-              trace(
-                host,
-                oldResolution.resolvedModule.packageId ? Diagnostics.Reusing_resolution_of_module_0_from_1_of_old_program_it_was_successfully_resolved_to_2_with_Package_ID_3 : Diagnostics.Reusing_resolution_of_module_0_from_1_of_old_program_it_was_successfully_resolved_to_2,
-                moduleName.text,
-                getNormalizedAbsolutePath(file.originalFileName, currentDirectory),
-                oldResolution.resolvedModule.resolvedFileName,
-                oldResolution.resolvedModule.packageId && packageIdToString(oldResolution.resolvedModule.packageId)
-              );
-            }
-            (result ?? (result = new Array(moduleNames.length)))[i] = oldResolution;
-            (reusedNames ?? (reusedNames = [])).push(moduleName);
-            continue;
-          }
-        }
-        let resolvesToAmbientModuleInNonModifiedFile = false;
-        if (contains(file.ambientModuleNames, moduleName.text)) {
-          resolvesToAmbientModuleInNonModifiedFile = true;
-          if (isTraceEnabled(options, host)) {
-            trace(host, Diagnostics.Module_0_was_resolved_as_locally_declared_ambient_module_in_file_1, moduleName.text, getNormalizedAbsolutePath(file.originalFileName, currentDirectory));
-          }
-        } else {
-          resolvesToAmbientModuleInNonModifiedFile = moduleNameResolvesToAmbientModuleInNonModifiedFile(moduleName);
-        }
-        if (resolvesToAmbientModuleInNonModifiedFile) {
-          (result || (result = new Array(moduleNames.length)))[i] = predictedToResolveToAmbientModuleMarker;
-        } else {
-          (unknownModuleNames ?? (unknownModuleNames = [])).push(moduleName);
-        }
-      }
-      const resolutions = unknownModuleNames && unknownModuleNames.length ? resolveModuleNamesWorker(unknownModuleNames, file, reusedNames) : emptyArray;
-      if (!result) {
-        Debug.assert(resolutions.length === moduleNames.length);
-        return resolutions;
-      }
-      let j = 0;
-      for (let i = 0; i < result.length; i++) {
-        if (!result[i]) {
-          result[i] = resolutions[j];
-          j++;
-        }
-      }
-      Debug.assert(j === resolutions.length);
-      return result;
-      function moduleNameResolvesToAmbientModuleInNonModifiedFile(moduleName) {
-        const resolutionToFile = getResolvedModule(oldSourceFile, moduleName.text, getModeForUsageLocation(file, moduleName));
-        const resolvedFile = resolutionToFile && oldProgram.getSourceFile(resolutionToFile.resolvedFileName);
-        if (resolutionToFile && resolvedFile) {
-          return false;
-        }
-        const unmodifiedFile = ambientModuleNameToUnmodifiedFileName.get(moduleName.text);
-        if (!unmodifiedFile) {
-          return false;
-        }
-        if (isTraceEnabled(options, host)) {
-          trace(host, Diagnostics.Module_0_was_resolved_as_ambient_module_declared_in_1_since_this_file_was_not_modified, moduleName.text, unmodifiedFile);
-        }
-        return true;
-      }
-    }
-    function resolveTypeReferenceDirectiveNamesReusingOldState(typeDirectiveNames, containingFile) {
-      var _a2;
-      if (structureIsReused === 0 /* Not */) {
-        return resolveTypeReferenceDirectiveNamesWorker(
-          typeDirectiveNames,
-          containingFile,
-          /*reusedNames*/
-          void 0
-        );
-      }
-      const oldSourceFile = !isString(containingFile) ? oldProgram && oldProgram.getSourceFile(containingFile.fileName) : void 0;
-      if (!isString(containingFile)) {
-        if (oldSourceFile !== containingFile && containingFile.resolvedTypeReferenceDirectiveNames) {
-          const result2 = [];
-          for (const typeDirectiveName of typeDirectiveNames) {
-            const resolvedTypeReferenceDirective = containingFile.resolvedTypeReferenceDirectiveNames.get(getTypeReferenceResolutionName(typeDirectiveName), getModeForFileReference(typeDirectiveName, containingFile.impliedNodeFormat));
-            result2.push(resolvedTypeReferenceDirective);
-          }
-          return result2;
-        }
-      }
-      let unknownTypeReferenceDirectiveNames;
-      let result;
-      let reusedNames;
-      const containingSourceFile = !isString(containingFile) ? containingFile : void 0;
-      const canReuseResolutions = !isString(containingFile) ? containingFile === oldSourceFile && !hasInvalidatedResolutions(oldSourceFile.path) : !hasInvalidatedResolutions(toPath3(containingFile));
-      for (let i = 0; i < typeDirectiveNames.length; i++) {
-        const entry = typeDirectiveNames[i];
-        if (canReuseResolutions) {
-          const typeDirectiveName = getTypeReferenceResolutionName(entry);
-          const mode = getModeForFileReference(entry, containingSourceFile == null ? void 0 : containingSourceFile.impliedNodeFormat);
-          const oldResolution = (_a2 = !isString(containingFile) ? oldSourceFile == null ? void 0 : oldSourceFile.resolvedTypeReferenceDirectiveNames : oldProgram == null ? void 0 : oldProgram.getAutomaticTypeDirectiveResolutions()) == null ? void 0 : _a2.get(typeDirectiveName, mode);
-          if (oldResolution == null ? void 0 : oldResolution.resolvedTypeReferenceDirective) {
-            if (isTraceEnabled(options, host)) {
-              trace(
-                host,
-                oldResolution.resolvedTypeReferenceDirective.packageId ? Diagnostics.Reusing_resolution_of_type_reference_directive_0_from_1_of_old_program_it_was_successfully_resolved_to_2_with_Package_ID_3 : Diagnostics.Reusing_resolution_of_type_reference_directive_0_from_1_of_old_program_it_was_successfully_resolved_to_2,
-                typeDirectiveName,
-                !isString(containingFile) ? getNormalizedAbsolutePath(containingFile.originalFileName, currentDirectory) : containingFile,
-                oldResolution.resolvedTypeReferenceDirective.resolvedFileName,
-                oldResolution.resolvedTypeReferenceDirective.packageId && packageIdToString(oldResolution.resolvedTypeReferenceDirective.packageId)
-              );
-            }
-            (result ?? (result = new Array(typeDirectiveNames.length)))[i] = oldResolution;
-            (reusedNames ?? (reusedNames = [])).push(entry);
-            continue;
-          }
-        }
-        (unknownTypeReferenceDirectiveNames ?? (unknownTypeReferenceDirectiveNames = [])).push(entry);
-      }
-      if (!unknownTypeReferenceDirectiveNames)
-        return result || emptyArray;
-      const resolutions = resolveTypeReferenceDirectiveNamesWorker(
-        unknownTypeReferenceDirectiveNames,
-        containingFile,
-        reusedNames
-      );
-      if (!result) {
-        Debug.assert(resolutions.length === typeDirectiveNames.length);
-        return resolutions;
-      }
-      let j = 0;
-      for (let i = 0; i < result.length; i++) {
-        if (!result[i]) {
-          result[i] = resolutions[j];
-          j++;
-        }
-      }
-      Debug.assert(j === resolutions.length);
-      return result;
-    }
-    function canReuseProjectReferences() {
-      return !forEachProjectReference(
-        oldProgram.getProjectReferences(),
-        oldProgram.getResolvedProjectReferences(),
-        (oldResolvedRef, parent2, index) => {
-          const newRef = (parent2 ? parent2.commandLine.projectReferences : projectReferences)[index];
-          const newResolvedRef = parseProjectReferenceConfigFile(newRef);
-          if (oldResolvedRef) {
-            return !newResolvedRef || newResolvedRef.sourceFile !== oldResolvedRef.sourceFile || !arrayIsEqualTo(oldResolvedRef.commandLine.fileNames, newResolvedRef.commandLine.fileNames);
-          } else {
-            return newResolvedRef !== void 0;
-          }
-        },
-        (oldProjectReferences, parent2) => {
-          const newReferences = parent2 ? getResolvedProjectReferenceByPath(parent2.sourceFile.path).commandLine.projectReferences : projectReferences;
-          return !arrayIsEqualTo(oldProjectReferences, newReferences, projectReferenceIsEqualTo);
-        }
-      );
-    }
-    function tryReuseStructureFromOldProgram() {
-      var _a2;
-      if (!oldProgram) {
-        return 0 /* Not */;
-      }
-      const oldOptions = oldProgram.getCompilerOptions();
-      if (changesAffectModuleResolution(oldOptions, options)) {
-        return 0 /* Not */;
-      }
-      const oldRootNames = oldProgram.getRootFileNames();
-      if (!arrayIsEqualTo(oldRootNames, rootNames)) {
-        return 0 /* Not */;
-      }
-      if (!canReuseProjectReferences()) {
-        return 0 /* Not */;
-      }
-      if (projectReferences) {
-        resolvedProjectReferences = projectReferences.map(parseProjectReferenceConfigFile);
-      }
-      const newSourceFiles = [];
-      const modifiedSourceFiles = [];
-      structureIsReused = 2 /* Completely */;
-      if (oldProgram.getMissingFilePaths().some((missingFilePath) => host.fileExists(missingFilePath))) {
-        return 0 /* Not */;
-      }
-      const oldSourceFiles = oldProgram.getSourceFiles();
-      let SeenPackageName;
-      ((SeenPackageName2) => {
-        SeenPackageName2[SeenPackageName2["Exists"] = 0] = "Exists";
-        SeenPackageName2[SeenPackageName2["Modified"] = 1] = "Modified";
-      })(SeenPackageName || (SeenPackageName = {}));
-      const seenPackageNames = /* @__PURE__ */ new Map();
-      for (const oldSourceFile of oldSourceFiles) {
-        const sourceFileOptions = getCreateSourceFileOptions(oldSourceFile.fileName, moduleResolutionCache, host, options);
-        let newSourceFile = host.getSourceFileByPath ? host.getSourceFileByPath(
-          oldSourceFile.fileName,
-          oldSourceFile.resolvedPath,
-          sourceFileOptions,
-          /*onError*/
-          void 0,
-          shouldCreateNewSourceFile || sourceFileOptions.impliedNodeFormat !== oldSourceFile.impliedNodeFormat
-        ) : host.getSourceFile(
-          oldSourceFile.fileName,
-          sourceFileOptions,
-          /*onError*/
-          void 0,
-          shouldCreateNewSourceFile || sourceFileOptions.impliedNodeFormat !== oldSourceFile.impliedNodeFormat
-        );
-        if (!newSourceFile) {
-          return 0 /* Not */;
-        }
-        newSourceFile.packageJsonLocations = ((_a2 = sourceFileOptions.packageJsonLocations) == null ? void 0 : _a2.length) ? sourceFileOptions.packageJsonLocations : void 0;
-        newSourceFile.packageJsonScope = sourceFileOptions.packageJsonScope;
-        Debug.assert(!newSourceFile.redirectInfo, "Host should not return a redirect source file from `getSourceFile`");
-        let fileChanged;
-        if (oldSourceFile.redirectInfo) {
-          if (newSourceFile !== oldSourceFile.redirectInfo.unredirected) {
-            return 0 /* Not */;
-          }
-          fileChanged = false;
-          newSourceFile = oldSourceFile;
-        } else if (oldProgram.redirectTargetsMap.has(oldSourceFile.path)) {
-          if (newSourceFile !== oldSourceFile) {
-            return 0 /* Not */;
-          }
-          fileChanged = false;
-        } else {
-          fileChanged = newSourceFile !== oldSourceFile;
-        }
-        newSourceFile.path = oldSourceFile.path;
-        newSourceFile.originalFileName = oldSourceFile.originalFileName;
-        newSourceFile.resolvedPath = oldSourceFile.resolvedPath;
-        newSourceFile.fileName = oldSourceFile.fileName;
-        const packageName = oldProgram.sourceFileToPackageName.get(oldSourceFile.path);
-        if (packageName !== void 0) {
-          const prevKind = seenPackageNames.get(packageName);
-          const newKind = fileChanged ? 1 /* Modified */ : 0 /* Exists */;
-          if (prevKind !== void 0 && newKind === 1 /* Modified */ || prevKind === 1 /* Modified */) {
-            return 0 /* Not */;
-          }
-          seenPackageNames.set(packageName, newKind);
-        }
-        if (fileChanged) {
-          if (oldSourceFile.impliedNodeFormat !== newSourceFile.impliedNodeFormat) {
-            structureIsReused = 1 /* SafeModules */;
-          } else if (!arrayIsEqualTo(oldSourceFile.libReferenceDirectives, newSourceFile.libReferenceDirectives, fileReferenceIsEqualTo)) {
-            structureIsReused = 1 /* SafeModules */;
-          } else if (oldSourceFile.hasNoDefaultLib !== newSourceFile.hasNoDefaultLib) {
-            structureIsReused = 1 /* SafeModules */;
-          } else if (!arrayIsEqualTo(oldSourceFile.referencedFiles, newSourceFile.referencedFiles, fileReferenceIsEqualTo)) {
-            structureIsReused = 1 /* SafeModules */;
-          } else {
-            collectExternalModuleReferences(newSourceFile);
-            if (!arrayIsEqualTo(oldSourceFile.imports, newSourceFile.imports, moduleNameIsEqualTo)) {
-              structureIsReused = 1 /* SafeModules */;
-            } else if (!arrayIsEqualTo(oldSourceFile.moduleAugmentations, newSourceFile.moduleAugmentations, moduleNameIsEqualTo)) {
-              structureIsReused = 1 /* SafeModules */;
-            } else if ((oldSourceFile.flags & 6291456 /* PermanentlySetIncrementalFlags */) !== (newSourceFile.flags & 6291456 /* PermanentlySetIncrementalFlags */)) {
-              structureIsReused = 1 /* SafeModules */;
-            } else if (!arrayIsEqualTo(oldSourceFile.typeReferenceDirectives, newSourceFile.typeReferenceDirectives, fileReferenceIsEqualTo)) {
-              structureIsReused = 1 /* SafeModules */;
-            }
-          }
-          modifiedSourceFiles.push({ oldFile: oldSourceFile, newFile: newSourceFile });
-        } else if (hasInvalidatedResolutions(oldSourceFile.path)) {
-          structureIsReused = 1 /* SafeModules */;
-          modifiedSourceFiles.push({ oldFile: oldSourceFile, newFile: newSourceFile });
-        }
-        newSourceFiles.push(newSourceFile);
-      }
-      if (structureIsReused !== 2 /* Completely */) {
-        return structureIsReused;
-      }
-      const modifiedFiles = modifiedSourceFiles.map((f) => f.oldFile);
-      for (const oldFile of oldSourceFiles) {
-        if (!contains(modifiedFiles, oldFile)) {
-          for (const moduleName of oldFile.ambientModuleNames) {
-            ambientModuleNameToUnmodifiedFileName.set(moduleName, oldFile.fileName);
-          }
-        }
-      }
-      for (const { oldFile: oldSourceFile, newFile: newSourceFile } of modifiedSourceFiles) {
-        const moduleNames = getModuleNames(newSourceFile);
-        const resolutions = resolveModuleNamesReusingOldState(moduleNames, newSourceFile);
-        const resolutionsChanged = hasChangesInResolutions(moduleNames, newSourceFile, resolutions, oldSourceFile.resolvedModules, moduleResolutionIsEqualTo, moduleResolutionNameAndModeGetter);
-        if (resolutionsChanged) {
-          structureIsReused = 1 /* SafeModules */;
-          newSourceFile.resolvedModules = zipToModeAwareCache(newSourceFile, moduleNames, resolutions, moduleResolutionNameAndModeGetter);
-        } else {
-          newSourceFile.resolvedModules = oldSourceFile.resolvedModules;
-        }
-        const typesReferenceDirectives = newSourceFile.typeReferenceDirectives;
-        const typeReferenceResolutions = resolveTypeReferenceDirectiveNamesReusingOldState(typesReferenceDirectives, newSourceFile);
-        const typeReferenceResolutionsChanged = hasChangesInResolutions(typesReferenceDirectives, newSourceFile, typeReferenceResolutions, oldSourceFile.resolvedTypeReferenceDirectiveNames, typeDirectiveIsEqualTo, typeReferenceResolutionNameAndModeGetter);
-        if (typeReferenceResolutionsChanged) {
-          structureIsReused = 1 /* SafeModules */;
-          newSourceFile.resolvedTypeReferenceDirectiveNames = zipToModeAwareCache(newSourceFile, typesReferenceDirectives, typeReferenceResolutions, typeReferenceResolutionNameAndModeGetter);
-        } else {
-          newSourceFile.resolvedTypeReferenceDirectiveNames = oldSourceFile.resolvedTypeReferenceDirectiveNames;
-        }
-      }
-      if (structureIsReused !== 2 /* Completely */) {
-        return structureIsReused;
-      }
-      if (changesAffectingProgramStructure(oldOptions, options)) {
-        return 1 /* SafeModules */;
-      }
-      if (oldProgram.resolvedLibReferences && forEachEntry(oldProgram.resolvedLibReferences, (resolution, libFileName) => pathForLibFileWorker(libFileName).actual !== resolution.actual)) {
-        return 1 /* SafeModules */;
-      }
-      if (host.hasChangedAutomaticTypeDirectiveNames) {
-        if (host.hasChangedAutomaticTypeDirectiveNames())
-          return 1 /* SafeModules */;
-      } else {
-        automaticTypeDirectiveNames = getAutomaticTypeDirectiveNames(options, host);
-        if (!arrayIsEqualTo(oldProgram.getAutomaticTypeDirectiveNames(), automaticTypeDirectiveNames))
-          return 1 /* SafeModules */;
-      }
-      missingFilePaths = oldProgram.getMissingFilePaths();
-      Debug.assert(newSourceFiles.length === oldProgram.getSourceFiles().length);
-      for (const newSourceFile of newSourceFiles) {
-        filesByName.set(newSourceFile.path, newSourceFile);
-      }
-      const oldFilesByNameMap = oldProgram.getFilesByNameMap();
-      oldFilesByNameMap.forEach((oldFile, path) => {
-        if (!oldFile) {
-          filesByName.set(path, oldFile);
-          return;
-        }
-        if (oldFile.path === path) {
-          if (oldProgram.isSourceFileFromExternalLibrary(oldFile)) {
-            sourceFilesFoundSearchingNodeModules.set(oldFile.path, true);
-          }
-          return;
-        }
-        filesByName.set(path, filesByName.get(oldFile.path));
-      });
-      files = newSourceFiles;
-      fileReasons = oldProgram.getFileIncludeReasons();
-      fileProcessingDiagnostics = oldProgram.getFileProcessingDiagnostics();
-      resolvedTypeReferenceDirectives = oldProgram.getResolvedTypeReferenceDirectives();
-      automaticTypeDirectiveNames = oldProgram.getAutomaticTypeDirectiveNames();
-      automaticTypeDirectiveResolutions = oldProgram.getAutomaticTypeDirectiveResolutions();
-      sourceFileToPackageName = oldProgram.sourceFileToPackageName;
-      redirectTargetsMap = oldProgram.redirectTargetsMap;
-      usesUriStyleNodeCoreModules = oldProgram.usesUriStyleNodeCoreModules;
-      resolvedLibReferences = oldProgram.resolvedLibReferences;
-      packageMap = oldProgram.getCurrentPackagesMap();
-      return 2 /* Completely */;
-    }
-    function getEmitHost(writeFileCallback) {
-      return {
-        getPrependNodes,
-        getCanonicalFileName,
-        getCommonSourceDirectory: program.getCommonSourceDirectory,
-        getCompilerOptions: program.getCompilerOptions,
-        getCurrentDirectory: () => currentDirectory,
-        getSourceFile: program.getSourceFile,
-        getSourceFileByPath: program.getSourceFileByPath,
-        getSourceFiles: program.getSourceFiles,
-        getLibFileFromReference: program.getLibFileFromReference,
-        isSourceFileFromExternalLibrary,
-        getResolvedProjectReferenceToRedirect,
-        getProjectReferenceRedirect,
-        isSourceOfProjectReferenceRedirect,
-        getSymlinkCache,
-        writeFile: writeFileCallback || writeFile2,
-        isEmitBlocked,
-        readFile: (f) => host.readFile(f),
-        fileExists: (f) => {
-          const path = toPath3(f);
-          if (getSourceFileByPath(path))
-            return true;
-          if (contains(missingFilePaths, path))
-            return false;
-          return host.fileExists(f);
-        },
-        useCaseSensitiveFileNames: () => host.useCaseSensitiveFileNames(),
-        getBuildInfo: (bundle) => {
-          var _a2;
-          return (_a2 = program.getBuildInfo) == null ? void 0 : _a2.call(program, bundle);
-        },
-        getSourceFileFromReference: (file, ref) => program.getSourceFileFromReference(file, ref),
-        redirectTargetsMap,
-        getFileIncludeReasons: program.getFileIncludeReasons,
-        createHash: maybeBind(host, host.createHash)
-      };
-    }
-    function writeFile2(fileName, text, writeByteOrderMark, onError, sourceFiles, data) {
-      host.writeFile(fileName, text, writeByteOrderMark, onError, sourceFiles, data);
-    }
-    function emitBuildInfo(writeFileCallback) {
-      var _a2, _b2;
-      Debug.assert(!outFile(options));
-      (_a2 = tracing) == null ? void 0 : _a2.push(
-        tracing.Phase.Emit,
-        "emitBuildInfo",
-        {},
-        /*separateBeginAndEnd*/
-        true
-      );
-      mark("beforeEmit");
-      const emitResult = emitFiles(
-        notImplementedResolver,
-        getEmitHost(writeFileCallback),
-        /*targetSourceFile*/
-        void 0,
-        /*transformers*/
-        noTransformers,
-        /*emitOnly*/
-        false,
-        /*onlyBuildInfo*/
-        true
-      );
-      mark("afterEmit");
-      measure("Emit", "beforeEmit", "afterEmit");
-      (_b2 = tracing) == null ? void 0 : _b2.pop();
-      return emitResult;
-    }
-    function getResolvedProjectReferences() {
-      return resolvedProjectReferences;
-    }
-    function getProjectReferences() {
-      return projectReferences;
-    }
-    function getPrependNodes() {
-      return createPrependNodes(
-        projectReferences,
-        (_ref, index) => {
-          var _a2;
-          return (_a2 = resolvedProjectReferences[index]) == null ? void 0 : _a2.commandLine;
-        },
-        (fileName) => {
-          const path = toPath3(fileName);
-          const sourceFile = getSourceFileByPath(path);
-          return sourceFile ? sourceFile.text : filesByName.has(path) ? void 0 : host.readFile(path);
-        },
-        host
-      );
-    }
-    function isSourceFileFromExternalLibrary(file) {
-      return !!sourceFilesFoundSearchingNodeModules.get(file.path);
-    }
-    function isSourceFileDefaultLibrary(file) {
-      if (!file.isDeclarationFile) {
-        return false;
-      }
-      if (file.hasNoDefaultLib) {
-        return true;
-      }
-      if (!options.noLib) {
-        return false;
-      }
-      const equalityComparer = host.useCaseSensitiveFileNames() ? equateStringsCaseSensitive : equateStringsCaseInsensitive;
-      if (!options.lib) {
-        return equalityComparer(file.fileName, getDefaultLibraryFileName());
-      } else {
-        return some(options.lib, (libFileName) => equalityComparer(file.fileName, resolvedLibReferences.get(libFileName).actual));
-      }
-    }
-    function getTypeChecker() {
-      return typeChecker || (typeChecker = createTypeChecker(program));
-    }
-    function emit(sourceFile, writeFileCallback, cancellationToken, emitOnly, transformers, forceDtsEmit) {
-      var _a2, _b2;
-      (_a2 = tracing) == null ? void 0 : _a2.push(
-        tracing.Phase.Emit,
-        "emit",
-        { path: sourceFile == null ? void 0 : sourceFile.path },
-        /*separateBeginAndEnd*/
-        true
-      );
-      const result = runWithCancellationToken(() => emitWorker(program, sourceFile, writeFileCallback, cancellationToken, emitOnly, transformers, forceDtsEmit));
-      (_b2 = tracing) == null ? void 0 : _b2.pop();
-      return result;
-    }
-    function isEmitBlocked(emitFileName) {
-      return hasEmitBlockingDiagnostics.has(toPath3(emitFileName));
-    }
-    function emitWorker(program2, sourceFile, writeFileCallback, cancellationToken, emitOnly, customTransformers, forceDtsEmit) {
-      if (!forceDtsEmit) {
-        const result = handleNoEmitOptions(program2, sourceFile, writeFileCallback, cancellationToken);
-        if (result)
-          return result;
-      }
-      const emitResolver = getTypeChecker().getEmitResolver(outFile(options) ? void 0 : sourceFile, cancellationToken);
-      mark("beforeEmit");
-      const emitResult = emitFiles(
-        emitResolver,
-        getEmitHost(writeFileCallback),
-        sourceFile,
-        getTransformers(options, customTransformers, emitOnly),
-        emitOnly,
-        /*onlyBuildInfo*/
-        false,
-        forceDtsEmit
-      );
-      mark("afterEmit");
-      measure("Emit", "beforeEmit", "afterEmit");
-      return emitResult;
-    }
-    function getSourceFile(fileName) {
-      return getSourceFileByPath(toPath3(fileName));
-    }
-    function getSourceFileByPath(path) {
-      return filesByName.get(path) || void 0;
-    }
-    function getDiagnosticsHelper(sourceFile, getDiagnostics2, cancellationToken) {
-      if (sourceFile) {
-        return sortAndDeduplicateDiagnostics(getDiagnostics2(sourceFile, cancellationToken));
-      }
-      return sortAndDeduplicateDiagnostics(flatMap(program.getSourceFiles(), (sourceFile2) => {
-        if (cancellationToken) {
-          cancellationToken.throwIfCancellationRequested();
-        }
-        return getDiagnostics2(sourceFile2, cancellationToken);
-      }));
-    }
-    function getSyntacticDiagnostics(sourceFile, cancellationToken) {
-      return getDiagnosticsHelper(sourceFile, getSyntacticDiagnosticsForFile, cancellationToken);
-    }
-    function getSemanticDiagnostics(sourceFile, cancellationToken) {
-      return getDiagnosticsHelper(sourceFile, getSemanticDiagnosticsForFile, cancellationToken);
-    }
-    function getCachedSemanticDiagnostics(sourceFile) {
-      var _a2;
-      return sourceFile ? (_a2 = cachedBindAndCheckDiagnosticsForFile.perFile) == null ? void 0 : _a2.get(sourceFile.path) : cachedBindAndCheckDiagnosticsForFile.allDiagnostics;
-    }
-    function getBindAndCheckDiagnostics(sourceFile, cancellationToken) {
-      return getBindAndCheckDiagnosticsForFile(sourceFile, cancellationToken);
-    }
-    function getProgramDiagnostics(sourceFile) {
-      var _a2;
-      if (skipTypeChecking(sourceFile, options, program)) {
-        return emptyArray;
-      }
-      const programDiagnosticsInFile = programDiagnostics.getDiagnostics(sourceFile.fileName);
-      if (!((_a2 = sourceFile.commentDirectives) == null ? void 0 : _a2.length)) {
-        return programDiagnosticsInFile;
-      }
-      return getDiagnosticsWithPrecedingDirectives(sourceFile, sourceFile.commentDirectives, programDiagnosticsInFile).diagnostics;
-    }
-    function getDeclarationDiagnostics2(sourceFile, cancellationToken) {
-      const options2 = program.getCompilerOptions();
-      if (!sourceFile || outFile(options2)) {
-        return getDeclarationDiagnosticsWorker(sourceFile, cancellationToken);
-      } else {
-        return getDiagnosticsHelper(sourceFile, getDeclarationDiagnosticsForFile, cancellationToken);
-      }
-    }
-    function getSyntacticDiagnosticsForFile(sourceFile) {
-      if (isSourceFileJS(sourceFile)) {
-        if (!sourceFile.additionalSyntacticDiagnostics) {
-          sourceFile.additionalSyntacticDiagnostics = getJSSyntacticDiagnosticsForFile(sourceFile);
-        }
-        return concatenate(sourceFile.additionalSyntacticDiagnostics, sourceFile.parseDiagnostics);
-      }
-      return sourceFile.parseDiagnostics;
-    }
-    function runWithCancellationToken(func) {
-      try {
-        return func();
-      } catch (e) {
-        if (e instanceof OperationCanceledException) {
-          typeChecker = void 0;
-        }
-        throw e;
-      }
-    }
-    function getSemanticDiagnosticsForFile(sourceFile, cancellationToken) {
-      return concatenate(
-        filterSemanticDiagnostics(getBindAndCheckDiagnosticsForFile(sourceFile, cancellationToken), options),
-        getProgramDiagnostics(sourceFile)
-      );
-    }
-    function getBindAndCheckDiagnosticsForFile(sourceFile, cancellationToken) {
-      return getAndCacheDiagnostics(sourceFile, cancellationToken, cachedBindAndCheckDiagnosticsForFile, getBindAndCheckDiagnosticsForFileNoCache);
-    }
-    function getBindAndCheckDiagnosticsForFileNoCache(sourceFile, cancellationToken) {
-      return runWithCancellationToken(() => {
-        if (skipTypeChecking(sourceFile, options, program)) {
-          return emptyArray;
-        }
-        const typeChecker2 = getTypeChecker();
-        Debug.assert(!!sourceFile.bindDiagnostics);
-        const isJs = sourceFile.scriptKind === 1 /* JS */ || sourceFile.scriptKind === 2 /* JSX */;
-        const isCheckJs = isJs && isCheckJsEnabledForFile(sourceFile, options);
-        const isPlainJs = isPlainJsFile(sourceFile, options.checkJs);
-        const isTsNoCheck = !!sourceFile.checkJsDirective && sourceFile.checkJsDirective.enabled === false;
-        const includeBindAndCheckDiagnostics = !isTsNoCheck && (sourceFile.scriptKind === 3 /* TS */ || sourceFile.scriptKind === 4 /* TSX */ || sourceFile.scriptKind === 5 /* External */ || isPlainJs || isCheckJs || sourceFile.scriptKind === 7 /* Deferred */);
-        let bindDiagnostics = includeBindAndCheckDiagnostics ? sourceFile.bindDiagnostics : emptyArray;
-        let checkDiagnostics = includeBindAndCheckDiagnostics ? typeChecker2.getDiagnostics(sourceFile, cancellationToken) : emptyArray;
-        if (isPlainJs) {
-          bindDiagnostics = filter(bindDiagnostics, (d) => plainJSErrors.has(d.code));
-          checkDiagnostics = filter(checkDiagnostics, (d) => plainJSErrors.has(d.code));
-        }
-        return getMergedBindAndCheckDiagnostics(sourceFile, includeBindAndCheckDiagnostics && !isPlainJs, bindDiagnostics, checkDiagnostics, isCheckJs ? sourceFile.jsDocDiagnostics : void 0);
-      });
-    }
-    function getMergedBindAndCheckDiagnostics(sourceFile, includeBindAndCheckDiagnostics, ...allDiagnostics) {
-      var _a2;
-      const flatDiagnostics = flatten(allDiagnostics);
-      if (!includeBindAndCheckDiagnostics || !((_a2 = sourceFile.commentDirectives) == null ? void 0 : _a2.length)) {
-        return flatDiagnostics;
-      }
-      const { diagnostics, directives } = getDiagnosticsWithPrecedingDirectives(sourceFile, sourceFile.commentDirectives, flatDiagnostics);
-      for (const errorExpectation of directives.getUnusedExpectations()) {
-        diagnostics.push(createDiagnosticForRange(sourceFile, errorExpectation.range, Diagnostics.Unused_ts_expect_error_directive));
-      }
-      return diagnostics;
-    }
-    function getDiagnosticsWithPrecedingDirectives(sourceFile, commentDirectives, flatDiagnostics) {
-      const directives = createCommentDirectivesMap(sourceFile, commentDirectives);
-      const diagnostics = flatDiagnostics.filter((diagnostic) => markPrecedingCommentDirectiveLine(diagnostic, directives) === -1);
-      return { diagnostics, directives };
-    }
-    function getSuggestionDiagnostics(sourceFile, cancellationToken) {
-      return runWithCancellationToken(() => {
-        return getTypeChecker().getSuggestionDiagnostics(sourceFile, cancellationToken);
-      });
-    }
-    function markPrecedingCommentDirectiveLine(diagnostic, directives) {
-      const { file, start } = diagnostic;
-      if (!file) {
-        return -1;
-      }
-      const lineStarts = getLineStarts(file);
-      let line = computeLineAndCharacterOfPosition(lineStarts, start).line - 1;
-      while (line >= 0) {
-        if (directives.markUsed(line)) {
-          return line;
-        }
-        const lineText = file.text.slice(lineStarts[line], lineStarts[line + 1]).trim();
-        if (lineText !== "" && !/^(\s*)\/\/(.*)$/.test(lineText)) {
-          return -1;
-        }
-        line--;
-      }
-      return -1;
-    }
-    function getJSSyntacticDiagnosticsForFile(sourceFile) {
-      return runWithCancellationToken(() => {
-        const diagnostics = [];
-        walk(sourceFile, sourceFile);
-        forEachChildRecursively(sourceFile, walk, walkArray);
-        return diagnostics;
-        function walk(node, parent2) {
-          switch (parent2.kind) {
-            case 168 /* Parameter */:
-            case 171 /* PropertyDeclaration */:
-            case 173 /* MethodDeclaration */:
-              if (parent2.questionToken === node) {
-                diagnostics.push(createDiagnosticForNode2(node, Diagnostics.The_0_modifier_can_only_be_used_in_TypeScript_files, "?"));
-                return "skip";
-              }
-            case 172 /* MethodSignature */:
-            case 175 /* Constructor */:
-            case 176 /* GetAccessor */:
-            case 177 /* SetAccessor */:
-            case 217 /* FunctionExpression */:
-            case 261 /* FunctionDeclaration */:
-            case 218 /* ArrowFunction */:
-            case 259 /* VariableDeclaration */:
-              if (parent2.type === node) {
-                diagnostics.push(createDiagnosticForNode2(node, Diagnostics.Type_annotations_can_only_be_used_in_TypeScript_files));
-                return "skip";
-              }
-          }
-          switch (node.kind) {
-            case 272 /* ImportClause */:
-              if (node.isTypeOnly) {
-                diagnostics.push(createDiagnosticForNode2(parent2, Diagnostics._0_declarations_can_only_be_used_in_TypeScript_files, "import type"));
-                return "skip";
-              }
-              break;
-            case 277 /* ExportDeclaration */:
-              if (node.isTypeOnly) {
-                diagnostics.push(createDiagnosticForNode2(node, Diagnostics._0_declarations_can_only_be_used_in_TypeScript_files, "export type"));
-                return "skip";
-              }
-              break;
-            case 275 /* ImportSpecifier */:
-            case 280 /* ExportSpecifier */:
-              if (node.isTypeOnly) {
-                diagnostics.push(createDiagnosticForNode2(node, Diagnostics._0_declarations_can_only_be_used_in_TypeScript_files, isImportSpecifier(node) ? "import...type" : "export...type"));
-                return "skip";
-              }
-              break;
-            case 270 /* ImportEqualsDeclaration */:
-              diagnostics.push(createDiagnosticForNode2(node, Diagnostics.import_can_only_be_used_in_TypeScript_files));
-              return "skip";
-            case 276 /* ExportAssignment */:
-              if (node.isExportEquals) {
-                diagnostics.push(createDiagnosticForNode2(node, Diagnostics.export_can_only_be_used_in_TypeScript_files));
-                return "skip";
-              }
-              break;
-            case 297 /* HeritageClause */:
-              const heritageClause = node;
-              if (heritageClause.token === 119 /* ImplementsKeyword */) {
-                diagnostics.push(createDiagnosticForNode2(node, Diagnostics.implements_clauses_can_only_be_used_in_TypeScript_files));
-                return "skip";
-              }
-              break;
-            case 263 /* InterfaceDeclaration */:
-              const interfaceKeyword = tokenToString(120 /* InterfaceKeyword */);
-              Debug.assertIsDefined(interfaceKeyword);
-              diagnostics.push(createDiagnosticForNode2(node, Diagnostics._0_declarations_can_only_be_used_in_TypeScript_files, interfaceKeyword));
-              return "skip";
-            case 266 /* ModuleDeclaration */:
-              const moduleKeyword = node.flags & 16 /* Namespace */ ? tokenToString(145 /* NamespaceKeyword */) : tokenToString(144 /* ModuleKeyword */);
-              Debug.assertIsDefined(moduleKeyword);
-              diagnostics.push(createDiagnosticForNode2(node, Diagnostics._0_declarations_can_only_be_used_in_TypeScript_files, moduleKeyword));
-              return "skip";
-            case 264 /* TypeAliasDeclaration */:
-              diagnostics.push(createDiagnosticForNode2(node, Diagnostics.Type_aliases_can_only_be_used_in_TypeScript_files));
-              return "skip";
-            case 265 /* EnumDeclaration */:
-              const enumKeyword = Debug.checkDefined(tokenToString(94 /* EnumKeyword */));
-              diagnostics.push(createDiagnosticForNode2(node, Diagnostics._0_declarations_can_only_be_used_in_TypeScript_files, enumKeyword));
-              return "skip";
-            case 234 /* NonNullExpression */:
-              diagnostics.push(createDiagnosticForNode2(node, Diagnostics.Non_null_assertions_can_only_be_used_in_TypeScript_files));
-              return "skip";
-            case 233 /* AsExpression */:
-              diagnostics.push(createDiagnosticForNode2(node.type, Diagnostics.Type_assertion_expressions_can_only_be_used_in_TypeScript_files));
-              return "skip";
-            case 237 /* SatisfiesExpression */:
-              diagnostics.push(createDiagnosticForNode2(node.type, Diagnostics.Type_satisfaction_expressions_can_only_be_used_in_TypeScript_files));
-              return "skip";
-            case 215 /* TypeAssertionExpression */:
-              Debug.fail();
-          }
-        }
-        function walkArray(nodes, parent2) {
-          if (canHaveIllegalDecorators(parent2)) {
-            const decorator = find(parent2.modifiers, isDecorator);
-            if (decorator) {
-              diagnostics.push(createDiagnosticForNode2(decorator, Diagnostics.Decorators_are_not_valid_here));
-            }
-          } else if (canHaveDecorators(parent2) && parent2.modifiers) {
-            const decoratorIndex = findIndex(parent2.modifiers, isDecorator);
-            if (decoratorIndex >= 0) {
-              if (isParameter(parent2) && !options.experimentalDecorators) {
-                diagnostics.push(createDiagnosticForNode2(parent2.modifiers[decoratorIndex], Diagnostics.Decorators_are_not_valid_here));
-              } else if (isClassDeclaration(parent2)) {
-                const exportIndex = findIndex(parent2.modifiers, isExportModifier);
-                if (exportIndex >= 0) {
-                  const defaultIndex = findIndex(parent2.modifiers, isDefaultModifier);
-                  if (decoratorIndex > exportIndex && defaultIndex >= 0 && decoratorIndex < defaultIndex) {
-                    diagnostics.push(createDiagnosticForNode2(parent2.modifiers[decoratorIndex], Diagnostics.Decorators_are_not_valid_here));
-                  } else if (exportIndex >= 0 && decoratorIndex < exportIndex) {
-                    const trailingDecoratorIndex = findIndex(parent2.modifiers, isDecorator, exportIndex);
-                    if (trailingDecoratorIndex >= 0) {
-                      diagnostics.push(addRelatedInfo(
-                        createDiagnosticForNode2(parent2.modifiers[trailingDecoratorIndex], Diagnostics.Decorators_may_not_appear_after_export_or_export_default_if_they_also_appear_before_export),
-                        createDiagnosticForNode2(parent2.modifiers[decoratorIndex], Diagnostics.Decorator_used_before_export_here)
-                      ));
-                    }
-                  }
-                }
-              }
-            }
-          }
-          switch (parent2.kind) {
-            case 262 /* ClassDeclaration */:
-            case 230 /* ClassExpression */:
-            case 173 /* MethodDeclaration */:
-            case 175 /* Constructor */:
-            case 176 /* GetAccessor */:
-            case 177 /* SetAccessor */:
-            case 217 /* FunctionExpression */:
-            case 261 /* FunctionDeclaration */:
-            case 218 /* ArrowFunction */:
-              if (nodes === parent2.typeParameters) {
-                diagnostics.push(createDiagnosticForNodeArray2(nodes, Diagnostics.Type_parameter_declarations_can_only_be_used_in_TypeScript_files));
-                return "skip";
-              }
-            case 242 /* VariableStatement */:
-              if (nodes === parent2.modifiers) {
-                checkModifiers(parent2.modifiers, parent2.kind === 242 /* VariableStatement */);
-                return "skip";
-              }
-              break;
-            case 171 /* PropertyDeclaration */:
-              if (nodes === parent2.modifiers) {
-                for (const modifier of nodes) {
-                  if (isModifier(modifier) && modifier.kind !== 126 /* StaticKeyword */ && modifier.kind !== 129 /* AccessorKeyword */) {
-                    diagnostics.push(createDiagnosticForNode2(modifier, Diagnostics.The_0_modifier_can_only_be_used_in_TypeScript_files, tokenToString(modifier.kind)));
-                  }
-                }
-                return "skip";
-              }
-              break;
-            case 168 /* Parameter */:
-              if (nodes === parent2.modifiers && some(nodes, isModifier)) {
-                diagnostics.push(createDiagnosticForNodeArray2(nodes, Diagnostics.Parameter_modifiers_can_only_be_used_in_TypeScript_files));
-                return "skip";
-              }
-              break;
-            case 212 /* CallExpression */:
-            case 213 /* NewExpression */:
-            case 232 /* ExpressionWithTypeArguments */:
-            case 284 /* JsxSelfClosingElement */:
-            case 285 /* JsxOpeningElement */:
-            case 214 /* TaggedTemplateExpression */:
-              if (nodes === parent2.typeArguments) {
-                diagnostics.push(createDiagnosticForNodeArray2(nodes, Diagnostics.Type_arguments_can_only_be_used_in_TypeScript_files));
-                return "skip";
-              }
-              break;
-          }
-        }
-        function checkModifiers(modifiers, isConstValid) {
-          for (const modifier of modifiers) {
-            switch (modifier.kind) {
-              case 87 /* ConstKeyword */:
-                if (isConstValid) {
-                  continue;
-                }
-              case 125 /* PublicKeyword */:
-              case 123 /* PrivateKeyword */:
-              case 124 /* ProtectedKeyword */:
-              case 148 /* ReadonlyKeyword */:
-              case 138 /* DeclareKeyword */:
-              case 128 /* AbstractKeyword */:
-              case 163 /* OverrideKeyword */:
-              case 103 /* InKeyword */:
-              case 147 /* OutKeyword */:
-                diagnostics.push(createDiagnosticForNode2(modifier, Diagnostics.The_0_modifier_can_only_be_used_in_TypeScript_files, tokenToString(modifier.kind)));
-                break;
-              case 126 /* StaticKeyword */:
-              case 95 /* ExportKeyword */:
-              case 90 /* DefaultKeyword */:
-              case 129 /* AccessorKeyword */:
-            }
-          }
-        }
-        function createDiagnosticForNodeArray2(nodes, message, ...args) {
-          const start = nodes.pos;
-          return createFileDiagnostic(sourceFile, start, nodes.end - start, message, ...args);
-        }
-        function createDiagnosticForNode2(node, message, ...args) {
-          return createDiagnosticForNodeInSourceFile(sourceFile, node, message, ...args);
-        }
-      });
-    }
-    function getDeclarationDiagnosticsWorker(sourceFile, cancellationToken) {
-      return getAndCacheDiagnostics(sourceFile, cancellationToken, cachedDeclarationDiagnosticsForFile, getDeclarationDiagnosticsForFileNoCache);
-    }
-    function getDeclarationDiagnosticsForFileNoCache(sourceFile, cancellationToken) {
-      return runWithCancellationToken(() => {
-        const resolver = getTypeChecker().getEmitResolver(sourceFile, cancellationToken);
-        return getDeclarationDiagnostics(getEmitHost(noop), resolver, sourceFile) || emptyArray;
-      });
-    }
-    function getAndCacheDiagnostics(sourceFile, cancellationToken, cache, getDiagnostics2) {
-      var _a2;
-      const cachedResult = sourceFile ? (_a2 = cache.perFile) == null ? void 0 : _a2.get(sourceFile.path) : cache.allDiagnostics;
-      if (cachedResult) {
-        return cachedResult;
-      }
-      const result = getDiagnostics2(sourceFile, cancellationToken);
-      if (sourceFile) {
-        (cache.perFile || (cache.perFile = /* @__PURE__ */ new Map())).set(sourceFile.path, result);
-      } else {
-        cache.allDiagnostics = result;
-      }
-      return result;
-    }
-    function getDeclarationDiagnosticsForFile(sourceFile, cancellationToken) {
-      return sourceFile.isDeclarationFile ? [] : getDeclarationDiagnosticsWorker(sourceFile, cancellationToken);
-    }
-    function getOptionsDiagnostics() {
-      return sortAndDeduplicateDiagnostics(concatenate(
-        programDiagnostics.getGlobalDiagnostics(),
-        getOptionsDiagnosticsOfConfigFile()
-      ));
-    }
-    function getOptionsDiagnosticsOfConfigFile() {
-      if (!options.configFile)
-        return emptyArray;
-      let diagnostics = programDiagnostics.getDiagnostics(options.configFile.fileName);
-      forEachResolvedProjectReference2((resolvedRef) => {
-        diagnostics = concatenate(diagnostics, programDiagnostics.getDiagnostics(resolvedRef.sourceFile.fileName));
-      });
-      return diagnostics;
-    }
-    function getGlobalDiagnostics() {
-      return rootNames.length ? sortAndDeduplicateDiagnostics(getTypeChecker().getGlobalDiagnostics().slice()) : emptyArray;
-    }
-    function getConfigFileParsingDiagnostics2() {
-      return configFileParsingDiagnostics || emptyArray;
-    }
-    function processRootFile(fileName, isDefaultLib, ignoreNoDefaultLib, reason) {
-      processSourceFile(
-        normalizePath(fileName),
-        isDefaultLib,
-        ignoreNoDefaultLib,
-        /*packageId*/
-        void 0,
-        reason
-      );
-    }
-    function fileReferenceIsEqualTo(a, b) {
-      return a.fileName === b.fileName;
-    }
-    function moduleNameIsEqualTo(a, b) {
-      return a.kind === 80 /* Identifier */ ? b.kind === 80 /* Identifier */ && a.escapedText === b.escapedText : b.kind === 11 /* StringLiteral */ && a.text === b.text;
-    }
-    function createSyntheticImport(text, file) {
-      const externalHelpersModuleReference = factory.createStringLiteral(text);
-      const importDecl = factory.createImportDeclaration(
-        /*modifiers*/
-        void 0,
-        /*importClause*/
-        void 0,
-        externalHelpersModuleReference,
-        /*assertClause*/
-        void 0
-      );
-      addInternalEmitFlags(importDecl, 2 /* NeverApplyImportHelper */);
-      setParent(externalHelpersModuleReference, importDecl);
-      setParent(importDecl, file);
-      externalHelpersModuleReference.flags &= ~8 /* Synthesized */;
-      importDecl.flags &= ~8 /* Synthesized */;
-      return externalHelpersModuleReference;
-    }
-    function collectExternalModuleReferences(file) {
-      if (file.imports) {
-        return;
-      }
-      const isJavaScriptFile = isSourceFileJS(file);
-      const isExternalModuleFile = isExternalModule(file);
-      let imports;
-      let moduleAugmentations;
-      let ambientModules;
-      if ((getIsolatedModules(options) || isExternalModuleFile) && !file.isDeclarationFile) {
-        if (options.importHelpers) {
-          imports = [createSyntheticImport(externalHelpersModuleNameText, file)];
-        }
-        const jsxImport = getJSXRuntimeImport(getJSXImplicitImportBase(options, file), options);
-        if (jsxImport) {
-          (imports || (imports = [])).push(createSyntheticImport(jsxImport, file));
-        }
-      }
-      for (const node of file.statements) {
-        collectModuleReferences(
-          node,
-          /*inAmbientModule*/
-          false
-        );
-      }
-      const shouldProcessRequires = isJavaScriptFile && shouldResolveJsRequire(options);
-      if (file.flags & 2097152 /* PossiblyContainsDynamicImport */ || shouldProcessRequires) {
-        collectDynamicImportOrRequireCalls(file);
-      }
-      file.imports = imports || emptyArray;
-      file.moduleAugmentations = moduleAugmentations || emptyArray;
-      file.ambientModuleNames = ambientModules || emptyArray;
-      return;
-      function collectModuleReferences(node, inAmbientModule) {
-        if (isAnyImportOrReExport(node)) {
-          const moduleNameExpr = getExternalModuleName(node);
-          if (moduleNameExpr && isStringLiteral(moduleNameExpr) && moduleNameExpr.text && (!inAmbientModule || !isExternalModuleNameRelative(moduleNameExpr.text))) {
-            setParentRecursive(
-              node,
-              /*incremental*/
-              false
-            );
-            imports = append(imports, moduleNameExpr);
-            if (!usesUriStyleNodeCoreModules && currentNodeModulesDepth === 0 && !file.isDeclarationFile) {
-              usesUriStyleNodeCoreModules = startsWith(moduleNameExpr.text, "node:");
-            }
-          }
-        } else if (isModuleDeclaration(node)) {
-          if (isAmbientModule(node) && (inAmbientModule || hasSyntacticModifier(node, 2 /* Ambient */) || file.isDeclarationFile)) {
-            node.name.parent = node;
-            const nameText = getTextOfIdentifierOrLiteral(node.name);
-            if (isExternalModuleFile || inAmbientModule && !isExternalModuleNameRelative(nameText)) {
-              (moduleAugmentations || (moduleAugmentations = [])).push(node.name);
-            } else if (!inAmbientModule) {
-              if (file.isDeclarationFile) {
-                (ambientModules || (ambientModules = [])).push(nameText);
-              }
-              const body = node.body;
-              if (body) {
-                for (const statement of body.statements) {
-                  collectModuleReferences(
-                    statement,
-                    /*inAmbientModule*/
-                    true
-                  );
-                }
-              }
-            }
-          }
-        }
-      }
-      function collectDynamicImportOrRequireCalls(file2) {
-        const r = /import|require/g;
-        while (r.exec(file2.text) !== null) {
-          const node = getNodeAtPosition(file2, r.lastIndex);
-          if (shouldProcessRequires && isRequireCall(
-            node,
-            /*requireStringLiteralLikeArgument*/
-            true
-          )) {
-            setParentRecursive(
-              node,
-              /*incremental*/
-              false
-            );
-            imports = append(imports, node.arguments[0]);
-          } else if (isImportCall(node) && node.arguments.length >= 1 && isStringLiteralLike(node.arguments[0])) {
-            setParentRecursive(
-              node,
-              /*incremental*/
-              false
-            );
-            imports = append(imports, node.arguments[0]);
-          } else if (isLiteralImportTypeNode(node)) {
-            setParentRecursive(
-              node,
-              /*incremental*/
-              false
-            );
-            imports = append(imports, node.argument.literal);
-          }
-        }
-      }
-      function getNodeAtPosition(sourceFile, position) {
-        let current = sourceFile;
-        const getContainingChild = (child) => {
-          if (child.pos <= position && (position < child.end || position === child.end && child.kind === 1 /* EndOfFileToken */)) {
-            return child;
-          }
-        };
-        while (true) {
-          const child = isJavaScriptFile && hasJSDocNodes(current) && forEach(current.jsDoc, getContainingChild) || forEachChild(current, getContainingChild);
-          if (!child) {
-            return current;
-          }
-          current = child;
-        }
-      }
-    }
-    function getLibFileFromReference(ref) {
-      var _a2;
-      const { libFileName } = getLibFileNameFromLibReference(ref);
-      const actualFileName = libFileName && ((_a2 = resolvedLibReferences == null ? void 0 : resolvedLibReferences.get(libFileName)) == null ? void 0 : _a2.actual);
-      return actualFileName !== void 0 ? getSourceFile(actualFileName) : void 0;
-    }
-    function getSourceFileFromReference(referencingFile, ref) {
-      return getSourceFileFromReferenceWorker(resolveTripleslashReference(ref.fileName, referencingFile.fileName), getSourceFile);
-    }
-    function getSourceFileFromReferenceWorker(fileName, getSourceFile2, fail, reason) {
-      if (hasExtension(fileName)) {
-        const canonicalFileName = host.getCanonicalFileName(fileName);
-        if (!options.allowNonTsExtensions && !forEach(flatten(supportedExtensionsWithJsonIfResolveJsonModule), (extension) => fileExtensionIs(canonicalFileName, extension))) {
-          if (fail) {
-            if (hasJSFileExtension(canonicalFileName)) {
-              fail(Diagnostics.File_0_is_a_JavaScript_file_Did_you_mean_to_enable_the_allowJs_option, fileName);
-            } else {
-              fail(Diagnostics.File_0_has_an_unsupported_extension_The_only_supported_extensions_are_1, fileName, "'" + flatten(supportedExtensions).join("', '") + "'");
-            }
-          }
-          return void 0;
-        }
-        const sourceFile = getSourceFile2(fileName);
-        if (fail) {
-          if (!sourceFile) {
-            const redirect = getProjectReferenceRedirect(fileName);
-            if (redirect) {
-              fail(Diagnostics.Output_file_0_has_not_been_built_from_source_file_1, redirect, fileName);
-            } else {
-              fail(Diagnostics.File_0_not_found, fileName);
-            }
-          } else if (isReferencedFile(reason) && canonicalFileName === host.getCanonicalFileName(getSourceFileByPath(reason.file).fileName)) {
-            fail(Diagnostics.A_file_cannot_have_a_reference_to_itself);
-          }
-        }
-        return sourceFile;
-      } else {
-        const sourceFileNoExtension = options.allowNonTsExtensions && getSourceFile2(fileName);
-        if (sourceFileNoExtension)
-          return sourceFileNoExtension;
-        if (fail && options.allowNonTsExtensions) {
-          fail(Diagnostics.File_0_not_found, fileName);
-          return void 0;
-        }
-        const sourceFileWithAddedExtension = forEach(supportedExtensions[0], (extension) => getSourceFile2(fileName + extension));
-        if (fail && !sourceFileWithAddedExtension)
-          fail(Diagnostics.Could_not_resolve_the_path_0_with_the_extensions_Colon_1, fileName, "'" + flatten(supportedExtensions).join("', '") + "'");
-        return sourceFileWithAddedExtension;
-      }
-    }
-    function processSourceFile(fileName, isDefaultLib, ignoreNoDefaultLib, packageId, reason) {
-      getSourceFileFromReferenceWorker(
-        fileName,
-        (fileName2) => findSourceFile(fileName2, isDefaultLib, ignoreNoDefaultLib, reason, packageId),
-        // TODO: GH#18217
-        (diagnostic, ...args) => addFilePreprocessingFileExplainingDiagnostic(
-          /*file*/
-          void 0,
-          reason,
-          diagnostic,
-          args
-        ),
-        reason
-      );
-    }
-    function processProjectReferenceFile(fileName, reason) {
-      return processSourceFile(
-        fileName,
-        /*isDefaultLib*/
-        false,
-        /*ignoreNoDefaultLib*/
-        false,
-        /*packageId*/
-        void 0,
-        reason
-      );
-    }
-    function reportFileNamesDifferOnlyInCasingError(fileName, existingFile, reason) {
-      const hasExistingReasonToReportErrorOn = !isReferencedFile(reason) && some(fileReasons.get(existingFile.path), isReferencedFile);
-      if (hasExistingReasonToReportErrorOn) {
-        addFilePreprocessingFileExplainingDiagnostic(existingFile, reason, Diagnostics.Already_included_file_name_0_differs_from_file_name_1_only_in_casing, [existingFile.fileName, fileName]);
-      } else {
-        addFilePreprocessingFileExplainingDiagnostic(existingFile, reason, Diagnostics.File_name_0_differs_from_already_included_file_name_1_only_in_casing, [fileName, existingFile.fileName]);
-      }
-    }
-    function createRedirectedSourceFile(redirectTarget, unredirected, fileName, path, resolvedPath, originalFileName, sourceFileOptions) {
-      var _a2;
-      const redirect = parseNodeFactory.createRedirectedSourceFile({ redirectTarget, unredirected });
-      redirect.fileName = fileName;
-      redirect.path = path;
-      redirect.resolvedPath = resolvedPath;
-      redirect.originalFileName = originalFileName;
-      redirect.packageJsonLocations = ((_a2 = sourceFileOptions.packageJsonLocations) == null ? void 0 : _a2.length) ? sourceFileOptions.packageJsonLocations : void 0;
-      redirect.packageJsonScope = sourceFileOptions.packageJsonScope;
-      sourceFilesFoundSearchingNodeModules.set(path, currentNodeModulesDepth > 0);
-      return redirect;
-    }
-    function findSourceFile(fileName, isDefaultLib, ignoreNoDefaultLib, reason, packageId) {
-      var _a2, _b2;
-      (_a2 = tracing) == null ? void 0 : _a2.push(tracing.Phase.Program, "findSourceFile", {
-        fileName,
-        isDefaultLib: isDefaultLib || void 0,
-        fileIncludeKind: FileIncludeKind[reason.kind]
-      });
-      const result = findSourceFileWorker(fileName, isDefaultLib, ignoreNoDefaultLib, reason, packageId);
-      (_b2 = tracing) == null ? void 0 : _b2.pop();
-      return result;
-    }
-    function getCreateSourceFileOptions(fileName, moduleResolutionCache2, host2, options2) {
-      const result = getImpliedNodeFormatForFileWorker(getNormalizedAbsolutePath(fileName, currentDirectory), moduleResolutionCache2 == null ? void 0 : moduleResolutionCache2.getPackageJsonInfoCache(), host2, options2);
-      const languageVersion = getEmitScriptTarget(options2);
-      const setExternalModuleIndicator2 = getSetExternalModuleIndicator(options2);
-      return typeof result === "object" ? { ...result, languageVersion, setExternalModuleIndicator: setExternalModuleIndicator2 } : { languageVersion, impliedNodeFormat: result, setExternalModuleIndicator: setExternalModuleIndicator2 };
-    }
-    function findSourceFileWorker(fileName, isDefaultLib, ignoreNoDefaultLib, reason, packageId) {
-      var _a2, _b2;
-      const path = toPath3(fileName);
-      if (useSourceOfProjectReferenceRedirect) {
-        let source = getSourceOfProjectReferenceRedirect(path);
-        if (!source && host.realpath && options.preserveSymlinks && isDeclarationFileName(fileName) && stringContains(fileName, nodeModulesPathPart)) {
-          const realPath2 = toPath3(host.realpath(fileName));
-          if (realPath2 !== path)
-            source = getSourceOfProjectReferenceRedirect(realPath2);
-        }
-        if (source) {
-          const file2 = isString(source) ? findSourceFile(source, isDefaultLib, ignoreNoDefaultLib, reason, packageId) : void 0;
-          if (file2)
-            addFileToFilesByName(
-              file2,
-              path,
-              /*redirectedPath*/
-              void 0
-            );
-          return file2;
-        }
-      }
-      const originalFileName = fileName;
-      if (filesByName.has(path)) {
-        const file2 = filesByName.get(path);
-        addFileIncludeReason(file2 || void 0, reason);
-        if (file2 && !(options.forceConsistentCasingInFileNames === false)) {
-          const checkedName = file2.fileName;
-          const isRedirect = toPath3(checkedName) !== toPath3(fileName);
-          if (isRedirect) {
-            fileName = getProjectReferenceRedirect(fileName) || fileName;
-          }
-          const checkedAbsolutePath = getNormalizedAbsolutePathWithoutRoot(checkedName, currentDirectory);
-          const inputAbsolutePath = getNormalizedAbsolutePathWithoutRoot(fileName, currentDirectory);
-          if (checkedAbsolutePath !== inputAbsolutePath) {
-            reportFileNamesDifferOnlyInCasingError(fileName, file2, reason);
-          }
-        }
-        if (file2 && sourceFilesFoundSearchingNodeModules.get(file2.path) && currentNodeModulesDepth === 0) {
-          sourceFilesFoundSearchingNodeModules.set(file2.path, false);
-          if (!options.noResolve) {
-            processReferencedFiles(file2, isDefaultLib);
-            processTypeReferenceDirectives(file2);
-          }
-          if (!options.noLib) {
-            processLibReferenceDirectives(file2);
-          }
-          modulesWithElidedImports.set(file2.path, false);
-          processImportedModules(file2);
-        } else if (file2 && modulesWithElidedImports.get(file2.path)) {
-          if (currentNodeModulesDepth < maxNodeModuleJsDepth) {
-            modulesWithElidedImports.set(file2.path, false);
-            processImportedModules(file2);
-          }
-        }
-        return file2 || void 0;
-      }
-      let redirectedPath;
-      if (isReferencedFile(reason) && !useSourceOfProjectReferenceRedirect) {
-        const redirectProject = getProjectReferenceRedirectProject(fileName);
-        if (redirectProject) {
-          if (outFile(redirectProject.commandLine.options)) {
-            return void 0;
-          }
-          const redirect = getProjectReferenceOutputName(redirectProject, fileName);
-          fileName = redirect;
-          redirectedPath = toPath3(redirect);
-        }
-      }
-      const sourceFileOptions = getCreateSourceFileOptions(fileName, moduleResolutionCache, host, options);
-      const file = host.getSourceFile(
-        fileName,
-        sourceFileOptions,
-        (hostErrorMessage) => addFilePreprocessingFileExplainingDiagnostic(
-          /*file*/
-          void 0,
-          reason,
-          Diagnostics.Cannot_read_file_0_Colon_1,
-          [fileName, hostErrorMessage]
-        ),
-        shouldCreateNewSourceFile || ((_a2 = oldProgram == null ? void 0 : oldProgram.getSourceFileByPath(toPath3(fileName))) == null ? void 0 : _a2.impliedNodeFormat) !== sourceFileOptions.impliedNodeFormat
-      );
-      if (packageId) {
-        const packageIdKey = packageIdToString(packageId);
-        const fileFromPackageId = packageIdToSourceFile.get(packageIdKey);
-        if (fileFromPackageId) {
-          const dupFile = createRedirectedSourceFile(fileFromPackageId, file, fileName, path, toPath3(fileName), originalFileName, sourceFileOptions);
-          redirectTargetsMap.add(fileFromPackageId.path, fileName);
-          addFileToFilesByName(dupFile, path, redirectedPath);
-          addFileIncludeReason(dupFile, reason);
-          sourceFileToPackageName.set(path, packageIdToPackageName(packageId));
-          processingOtherFiles.push(dupFile);
-          return dupFile;
-        } else if (file) {
-          packageIdToSourceFile.set(packageIdKey, file);
-          sourceFileToPackageName.set(path, packageIdToPackageName(packageId));
-        }
-      }
-      addFileToFilesByName(file, path, redirectedPath);
-      if (file) {
-        sourceFilesFoundSearchingNodeModules.set(path, currentNodeModulesDepth > 0);
-        file.fileName = fileName;
-        file.path = path;
-        file.resolvedPath = toPath3(fileName);
-        file.originalFileName = originalFileName;
-        file.packageJsonLocations = ((_b2 = sourceFileOptions.packageJsonLocations) == null ? void 0 : _b2.length) ? sourceFileOptions.packageJsonLocations : void 0;
-        file.packageJsonScope = sourceFileOptions.packageJsonScope;
-        addFileIncludeReason(file, reason);
-        if (host.useCaseSensitiveFileNames()) {
-          const pathLowerCase = toFileNameLowerCase(path);
-          const existingFile = filesByNameIgnoreCase.get(pathLowerCase);
-          if (existingFile) {
-            reportFileNamesDifferOnlyInCasingError(fileName, existingFile, reason);
-          } else {
-            filesByNameIgnoreCase.set(pathLowerCase, file);
-          }
-        }
-        skipDefaultLib = skipDefaultLib || file.hasNoDefaultLib && !ignoreNoDefaultLib;
-        if (!options.noResolve) {
-          processReferencedFiles(file, isDefaultLib);
-          processTypeReferenceDirectives(file);
-        }
-        if (!options.noLib) {
-          processLibReferenceDirectives(file);
-        }
-        processImportedModules(file);
-        if (isDefaultLib) {
-          processingDefaultLibFiles.push(file);
-        } else {
-          processingOtherFiles.push(file);
-        }
-      }
-      return file;
-    }
-    function addFileIncludeReason(file, reason) {
-      if (file)
-        fileReasons.add(file.path, reason);
-    }
-    function addFileToFilesByName(file, path, redirectedPath) {
-      if (redirectedPath) {
-        filesByName.set(redirectedPath, file);
-        filesByName.set(path, file || false);
-      } else {
-        filesByName.set(path, file);
-      }
-    }
-    function getProjectReferenceRedirect(fileName) {
-      const referencedProject = getProjectReferenceRedirectProject(fileName);
-      return referencedProject && getProjectReferenceOutputName(referencedProject, fileName);
-    }
-    function getProjectReferenceRedirectProject(fileName) {
-      if (!resolvedProjectReferences || !resolvedProjectReferences.length || isDeclarationFileName(fileName) || fileExtensionIs(fileName, ".json" /* Json */)) {
-        return void 0;
-      }
-      return getResolvedProjectReferenceToRedirect(fileName);
-    }
-    function getProjectReferenceOutputName(referencedProject, fileName) {
-      const out = outFile(referencedProject.commandLine.options);
-      return out ? changeExtension(out, ".d.ts" /* Dts */) : getOutputDeclarationFileName(fileName, referencedProject.commandLine, !host.useCaseSensitiveFileNames());
-    }
-    function getResolvedProjectReferenceToRedirect(fileName) {
-      if (mapFromFileToProjectReferenceRedirects === void 0) {
-        mapFromFileToProjectReferenceRedirects = /* @__PURE__ */ new Map();
-        forEachResolvedProjectReference2((referencedProject) => {
-          if (toPath3(options.configFilePath) !== referencedProject.sourceFile.path) {
-            referencedProject.commandLine.fileNames.forEach((f) => mapFromFileToProjectReferenceRedirects.set(toPath3(f), referencedProject.sourceFile.path));
-          }
-        });
-      }
-      const referencedProjectPath = mapFromFileToProjectReferenceRedirects.get(toPath3(fileName));
-      return referencedProjectPath && getResolvedProjectReferenceByPath(referencedProjectPath);
-    }
-    function forEachResolvedProjectReference2(cb) {
-      return forEachResolvedProjectReference(resolvedProjectReferences, cb);
-    }
-    function getSourceOfProjectReferenceRedirect(path) {
-      if (!isDeclarationFileName(path))
-        return void 0;
-      if (mapFromToProjectReferenceRedirectSource === void 0) {
-        mapFromToProjectReferenceRedirectSource = /* @__PURE__ */ new Map();
-        forEachResolvedProjectReference2((resolvedRef) => {
-          const out = outFile(resolvedRef.commandLine.options);
-          if (out) {
-            const outputDts = changeExtension(out, ".d.ts" /* Dts */);
-            mapFromToProjectReferenceRedirectSource.set(toPath3(outputDts), true);
-          } else {
-            const getCommonSourceDirectory3 = memoize(() => getCommonSourceDirectoryOfConfig(resolvedRef.commandLine, !host.useCaseSensitiveFileNames()));
-            forEach(resolvedRef.commandLine.fileNames, (fileName) => {
-              if (!isDeclarationFileName(fileName) && !fileExtensionIs(fileName, ".json" /* Json */)) {
-                const outputDts = getOutputDeclarationFileName(fileName, resolvedRef.commandLine, !host.useCaseSensitiveFileNames(), getCommonSourceDirectory3);
-                mapFromToProjectReferenceRedirectSource.set(toPath3(outputDts), fileName);
-              }
-            });
-          }
-        });
-      }
-      return mapFromToProjectReferenceRedirectSource.get(path);
-    }
-    function isSourceOfProjectReferenceRedirect(fileName) {
-      return useSourceOfProjectReferenceRedirect && !!getResolvedProjectReferenceToRedirect(fileName);
-    }
-    function getResolvedProjectReferenceByPath(projectReferencePath) {
-      if (!projectReferenceRedirects) {
-        return void 0;
-      }
-      return projectReferenceRedirects.get(projectReferencePath) || void 0;
-    }
-    function processReferencedFiles(file, isDefaultLib) {
-      forEach(file.referencedFiles, (ref, index) => {
-        processSourceFile(
-          resolveTripleslashReference(ref.fileName, file.fileName),
-          isDefaultLib,
-          /*ignoreNoDefaultLib*/
-          false,
-          /*packageId*/
-          void 0,
-          { kind: 4 /* ReferenceFile */, file: file.path, index }
-        );
-      });
-    }
-    function processTypeReferenceDirectives(file) {
-      const typeDirectives = file.typeReferenceDirectives;
-      if (!typeDirectives.length) {
-        file.resolvedTypeReferenceDirectiveNames = void 0;
-        return;
-      }
-      const resolutions = resolveTypeReferenceDirectiveNamesReusingOldState(typeDirectives, file);
-      for (let index = 0; index < typeDirectives.length; index++) {
-        const ref = file.typeReferenceDirectives[index];
-        const resolvedTypeReferenceDirective = resolutions[index];
-        const fileName = toFileNameLowerCase(ref.fileName);
-        setResolvedTypeReferenceDirective(file, fileName, resolvedTypeReferenceDirective, getModeForFileReference(ref, file.impliedNodeFormat));
-        const mode = ref.resolutionMode || file.impliedNodeFormat;
-        if (mode && getEmitModuleResolutionKind(options) !== 3 /* Node16 */ && getEmitModuleResolutionKind(options) !== 99 /* NodeNext */) {
-          (fileProcessingDiagnostics ?? (fileProcessingDiagnostics = [])).push({
-            kind: 2 /* ResolutionDiagnostics */,
-            diagnostics: [
-              createDiagnosticForRange(file, ref, Diagnostics.resolution_mode_assertions_are_only_supported_when_moduleResolution_is_node16_or_nodenext)
-            ]
-          });
-        }
-        processTypeReferenceDirective(fileName, mode, resolvedTypeReferenceDirective, { kind: 5 /* TypeReferenceDirective */, file: file.path, index });
-      }
-    }
-    function processTypeReferenceDirective(typeReferenceDirective, mode, resolution, reason) {
-      var _a2, _b2;
-      (_a2 = tracing) == null ? void 0 : _a2.push(tracing.Phase.Program, "processTypeReferenceDirective", { directive: typeReferenceDirective, hasResolved: !!resolution.resolvedTypeReferenceDirective, refKind: reason.kind, refPath: isReferencedFile(reason) ? reason.file : void 0 });
-      processTypeReferenceDirectiveWorker(typeReferenceDirective, mode, resolution, reason);
-      (_b2 = tracing) == null ? void 0 : _b2.pop();
-    }
-    function processTypeReferenceDirectiveWorker(typeReferenceDirective, mode, resolution, reason) {
-      var _a2;
-      addResolutionDiagnostics(resolution);
-      const previousResolution = (_a2 = resolvedTypeReferenceDirectives.get(typeReferenceDirective, mode)) == null ? void 0 : _a2.resolvedTypeReferenceDirective;
-      if (previousResolution && previousResolution.primary) {
-        return;
-      }
-      let saveResolution = true;
-      const { resolvedTypeReferenceDirective } = resolution;
-      if (resolvedTypeReferenceDirective) {
-        if (resolvedTypeReferenceDirective.isExternalLibraryImport)
-          currentNodeModulesDepth++;
-        if (resolvedTypeReferenceDirective.primary) {
-          processSourceFile(
-            resolvedTypeReferenceDirective.resolvedFileName,
-            /*isDefaultLib*/
-            false,
-            /*ignoreNoDefaultLib*/
-            false,
-            resolvedTypeReferenceDirective.packageId,
-            reason
-          );
-        } else {
-          if (previousResolution) {
-            if (resolvedTypeReferenceDirective.resolvedFileName !== previousResolution.resolvedFileName) {
-              const otherFileText = host.readFile(resolvedTypeReferenceDirective.resolvedFileName);
-              const existingFile = getSourceFile(previousResolution.resolvedFileName);
-              if (otherFileText !== existingFile.text) {
-                addFilePreprocessingFileExplainingDiagnostic(
-                  existingFile,
-                  reason,
-                  Diagnostics.Conflicting_definitions_for_0_found_at_1_and_2_Consider_installing_a_specific_version_of_this_library_to_resolve_the_conflict,
-                  [typeReferenceDirective, resolvedTypeReferenceDirective.resolvedFileName, previousResolution.resolvedFileName]
-                );
-              }
-            }
-            saveResolution = false;
-          } else {
-            processSourceFile(
-              resolvedTypeReferenceDirective.resolvedFileName,
-              /*isDefaultLib*/
-              false,
-              /*ignoreNoDefaultLib*/
-              false,
-              resolvedTypeReferenceDirective.packageId,
-              reason
-            );
-          }
-        }
-        if (resolvedTypeReferenceDirective.isExternalLibraryImport)
-          currentNodeModulesDepth--;
-      } else {
-        addFilePreprocessingFileExplainingDiagnostic(
-          /*file*/
-          void 0,
-          reason,
-          Diagnostics.Cannot_find_type_definition_file_for_0,
-          [typeReferenceDirective]
-        );
-      }
-      if (saveResolution) {
-        resolvedTypeReferenceDirectives.set(typeReferenceDirective, mode, resolution);
-      }
-    }
-    function pathForLibFile(libFileName) {
-      const existing = resolvedLibReferences == null ? void 0 : resolvedLibReferences.get(libFileName);
-      if (existing)
-        return existing.actual;
-      const result = pathForLibFileWorker(libFileName);
-      (resolvedLibReferences ?? (resolvedLibReferences = /* @__PURE__ */ new Map())).set(libFileName, result);
-      return result.actual;
-    }
-    function pathForLibFileWorker(libFileName) {
-      var _a2, _b2, _c2, _d2, _e2;
-      const existing = resolvedLibProcessing == null ? void 0 : resolvedLibProcessing.get(libFileName);
-      if (existing)
-        return existing;
-      if (structureIsReused !== 0 /* Not */ && oldProgram && !hasInvalidatedLibResolutions(libFileName)) {
-        const oldResolution = (_a2 = oldProgram.resolvedLibReferences) == null ? void 0 : _a2.get(libFileName);
-        if (oldResolution) {
-          if (oldResolution.resolution && isTraceEnabled(options, host)) {
-            const libraryName2 = getLibraryNameFromLibFileName(libFileName);
-            const resolveFrom2 = getInferredLibraryNameResolveFrom(options, currentDirectory, libFileName);
-            trace(
-              host,
-              oldResolution.resolution.resolvedModule ? oldResolution.resolution.resolvedModule.packageId ? Diagnostics.Reusing_resolution_of_module_0_from_1_of_old_program_it_was_successfully_resolved_to_2_with_Package_ID_3 : Diagnostics.Reusing_resolution_of_module_0_from_1_of_old_program_it_was_successfully_resolved_to_2 : Diagnostics.Reusing_resolution_of_module_0_from_1_of_old_program_it_was_not_resolved,
-              libraryName2,
-              getNormalizedAbsolutePath(resolveFrom2, currentDirectory),
-              (_b2 = oldResolution.resolution.resolvedModule) == null ? void 0 : _b2.resolvedFileName,
-              ((_c2 = oldResolution.resolution.resolvedModule) == null ? void 0 : _c2.packageId) && packageIdToString(oldResolution.resolution.resolvedModule.packageId)
-            );
-          }
-          (resolvedLibProcessing ?? (resolvedLibProcessing = /* @__PURE__ */ new Map())).set(libFileName, oldResolution);
-          return oldResolution;
-        }
-      }
-      const libraryName = getLibraryNameFromLibFileName(libFileName);
-      const resolveFrom = getInferredLibraryNameResolveFrom(options, currentDirectory, libFileName);
-      (_d2 = tracing) == null ? void 0 : _d2.push(tracing.Phase.Program, "resolveLibrary", { resolveFrom });
-      mark("beforeResolveLibrary");
-      const resolution = actualResolveLibrary(libraryName, resolveFrom, options, libFileName);
-      mark("afterResolveLibrary");
-      measure("ResolveLibrary", "beforeResolveLibrary", "afterResolveLibrary");
-      (_e2 = tracing) == null ? void 0 : _e2.pop();
-      const result = {
-        resolution,
-        actual: resolution.resolvedModule ? resolution.resolvedModule.resolvedFileName : combinePaths(defaultLibraryPath, libFileName)
-      };
-      (resolvedLibProcessing ?? (resolvedLibProcessing = /* @__PURE__ */ new Map())).set(libFileName, result);
-      return result;
-    }
-    function processLibReferenceDirectives(file) {
-      forEach(file.libReferenceDirectives, (libReference, index) => {
-        const { libName, libFileName } = getLibFileNameFromLibReference(libReference);
-        if (libFileName) {
-          processRootFile(
-            pathForLibFile(libFileName),
-            /*isDefaultLib*/
-            true,
-            /*ignoreNoDefaultLib*/
-            true,
-            { kind: 7 /* LibReferenceDirective */, file: file.path, index }
-          );
-        } else {
-          const unqualifiedLibName = removeSuffix(removePrefix(libName, "lib."), ".d.ts");
-          const suggestion = getSpellingSuggestion(unqualifiedLibName, libs, identity);
-          const diagnostic = suggestion ? Diagnostics.Cannot_find_lib_definition_for_0_Did_you_mean_1 : Diagnostics.Cannot_find_lib_definition_for_0;
-          const args = suggestion ? [libName, suggestion] : [libName];
-          (fileProcessingDiagnostics || (fileProcessingDiagnostics = [])).push({
-            kind: 0 /* FilePreprocessingReferencedDiagnostic */,
-            reason: { kind: 7 /* LibReferenceDirective */, file: file.path, index },
-            diagnostic,
-            args
-          });
-        }
-      });
-    }
-    function getCanonicalFileName(fileName) {
-      return host.getCanonicalFileName(fileName);
-    }
-    function processImportedModules(file) {
-      var _a2;
-      collectExternalModuleReferences(file);
-      if (file.imports.length || file.moduleAugmentations.length) {
-        const moduleNames = getModuleNames(file);
-        const resolutions = resolveModuleNamesReusingOldState(moduleNames, file);
-        Debug.assert(resolutions.length === moduleNames.length);
-        const optionsForFile = (useSourceOfProjectReferenceRedirect ? (_a2 = getRedirectReferenceForResolution(file)) == null ? void 0 : _a2.commandLine.options : void 0) || options;
-        for (let index = 0; index < moduleNames.length; index++) {
-          const resolution = resolutions[index].resolvedModule;
-          const moduleName = moduleNames[index].text;
-          const mode = getModeForUsageLocation(file, moduleNames[index]);
-          setResolvedModule(file, moduleName, resolutions[index], mode);
-          addResolutionDiagnosticsFromResolutionOrCache(file, moduleName, resolutions[index], mode);
-          if (!resolution) {
-            continue;
-          }
-          const isFromNodeModulesSearch = resolution.isExternalLibraryImport;
-          const isJsFile = !resolutionExtensionIsTSOrJson(resolution.extension);
-          const isJsFileFromNodeModules = isFromNodeModulesSearch && isJsFile;
-          const resolvedFileName = resolution.resolvedFileName;
-          if (isFromNodeModulesSearch) {
-            currentNodeModulesDepth++;
-          }
-          const elideImport = isJsFileFromNodeModules && currentNodeModulesDepth > maxNodeModuleJsDepth;
-          const shouldAddFile = resolvedFileName && !getResolutionDiagnostic(optionsForFile, resolution, file) && !optionsForFile.noResolve && index < file.imports.length && !elideImport && !(isJsFile && !getAllowJSCompilerOption(optionsForFile)) && (isInJSFile(file.imports[index]) || !(file.imports[index].flags & 8388608 /* JSDoc */));
-          if (elideImport) {
-            modulesWithElidedImports.set(file.path, true);
-          } else if (shouldAddFile) {
-            findSourceFile(
-              resolvedFileName,
-              /*isDefaultLib*/
-              false,
-              /*ignoreNoDefaultLib*/
-              false,
-              { kind: 3 /* Import */, file: file.path, index },
-              resolution.packageId
-            );
-          }
-          if (isFromNodeModulesSearch) {
-            currentNodeModulesDepth--;
-          }
-        }
-      } else {
-        file.resolvedModules = void 0;
-      }
-    }
-    function checkSourceFilesBelongToPath(sourceFiles, rootDirectory) {
-      let allFilesBelongToPath = true;
-      const absoluteRootDirectoryPath = host.getCanonicalFileName(getNormalizedAbsolutePath(rootDirectory, currentDirectory));
-      for (const sourceFile of sourceFiles) {
-        if (!sourceFile.isDeclarationFile) {
-          const absoluteSourceFilePath = host.getCanonicalFileName(getNormalizedAbsolutePath(sourceFile.fileName, currentDirectory));
-          if (absoluteSourceFilePath.indexOf(absoluteRootDirectoryPath) !== 0) {
-            addProgramDiagnosticExplainingFile(
-              sourceFile,
-              Diagnostics.File_0_is_not_under_rootDir_1_rootDir_is_expected_to_contain_all_source_files,
-              [sourceFile.fileName, rootDirectory]
-            );
-            allFilesBelongToPath = false;
-          }
-        }
-      }
-      return allFilesBelongToPath;
-    }
-    function parseProjectReferenceConfigFile(ref) {
-      if (!projectReferenceRedirects) {
-        projectReferenceRedirects = /* @__PURE__ */ new Map();
-      }
-      const refPath = resolveProjectReferencePath(ref);
-      const sourceFilePath = toPath3(refPath);
-      const fromCache = projectReferenceRedirects.get(sourceFilePath);
-      if (fromCache !== void 0) {
-        return fromCache || void 0;
-      }
-      let commandLine;
-      let sourceFile;
-      if (host.getParsedCommandLine) {
-        commandLine = host.getParsedCommandLine(refPath);
-        if (!commandLine) {
-          addFileToFilesByName(
-            /*file*/
-            void 0,
-            sourceFilePath,
-            /*redirectedPath*/
-            void 0
-          );
-          projectReferenceRedirects.set(sourceFilePath, false);
-          return void 0;
-        }
-        sourceFile = Debug.checkDefined(commandLine.options.configFile);
-        Debug.assert(!sourceFile.path || sourceFile.path === sourceFilePath);
-        addFileToFilesByName(
-          sourceFile,
-          sourceFilePath,
-          /*redirectedPath*/
-          void 0
-        );
-      } else {
-        const basePath = getNormalizedAbsolutePath(getDirectoryPath(refPath), currentDirectory);
-        sourceFile = host.getSourceFile(refPath, 100 /* JSON */);
-        addFileToFilesByName(
-          sourceFile,
-          sourceFilePath,
-          /*redirectedPath*/
-          void 0
-        );
-        if (sourceFile === void 0) {
-          projectReferenceRedirects.set(sourceFilePath, false);
-          return void 0;
-        }
-        commandLine = parseJsonSourceFileConfigFileContent(
-          sourceFile,
-          configParsingHost,
-          basePath,
-          /*existingOptions*/
-          void 0,
-          refPath
-        );
-      }
-      sourceFile.fileName = refPath;
-      sourceFile.path = sourceFilePath;
-      sourceFile.resolvedPath = sourceFilePath;
-      sourceFile.originalFileName = refPath;
-      const resolvedRef = { commandLine, sourceFile };
-      projectReferenceRedirects.set(sourceFilePath, resolvedRef);
-      if (commandLine.projectReferences) {
-        resolvedRef.references = commandLine.projectReferences.map(parseProjectReferenceConfigFile);
-      }
-      return resolvedRef;
-    }
-    function verifyCompilerOptions() {
-      if (options.strictPropertyInitialization && !getStrictOptionValue(options, "strictNullChecks")) {
-        createDiagnosticForOptionName(Diagnostics.Option_0_cannot_be_specified_without_specifying_option_1, "strictPropertyInitialization", "strictNullChecks");
-      }
-      if (options.exactOptionalPropertyTypes && !getStrictOptionValue(options, "strictNullChecks")) {
-        createDiagnosticForOptionName(Diagnostics.Option_0_cannot_be_specified_without_specifying_option_1, "exactOptionalPropertyTypes", "strictNullChecks");
-      }
-      if (options.isolatedModules || options.verbatimModuleSyntax) {
-        if (options.out) {
-          createDiagnosticForOptionName(Diagnostics.Option_0_cannot_be_specified_with_option_1, "out", options.verbatimModuleSyntax ? "verbatimModuleSyntax" : "isolatedModules");
-        }
-        if (options.outFile) {
-          createDiagnosticForOptionName(Diagnostics.Option_0_cannot_be_specified_with_option_1, "outFile", options.verbatimModuleSyntax ? "verbatimModuleSyntax" : "isolatedModules");
-        }
-      }
-      if (options.inlineSourceMap) {
-        if (options.sourceMap) {
-          createDiagnosticForOptionName(Diagnostics.Option_0_cannot_be_specified_with_option_1, "sourceMap", "inlineSourceMap");
-        }
-        if (options.mapRoot) {
-          createDiagnosticForOptionName(Diagnostics.Option_0_cannot_be_specified_with_option_1, "mapRoot", "inlineSourceMap");
-        }
-      }
-      if (options.composite) {
-        if (options.declaration === false) {
-          createDiagnosticForOptionName(Diagnostics.Composite_projects_may_not_disable_declaration_emit, "declaration");
-        }
-        if (options.incremental === false) {
-          createDiagnosticForOptionName(Diagnostics.Composite_projects_may_not_disable_incremental_compilation, "declaration");
-        }
-      }
-      const outputFile = outFile(options);
-      if (options.tsBuildInfoFile) {
-        if (!isIncrementalCompilation(options)) {
-          createDiagnosticForOptionName(Diagnostics.Option_0_cannot_be_specified_without_specifying_option_1_or_option_2, "tsBuildInfoFile", "incremental", "composite");
-        }
-      } else if (options.incremental && !outputFile && !options.configFilePath) {
-        programDiagnostics.add(createCompilerDiagnostic(Diagnostics.Option_incremental_can_only_be_specified_using_tsconfig_emitting_to_single_file_or_when_option_tsBuildInfoFile_is_specified));
-      }
-      verifyDeprecatedCompilerOptions();
-      verifyProjectReferences();
-      if (options.composite) {
-        const rootPaths = new Set(rootNames.map(toPath3));
-        for (const file of files) {
-          if (sourceFileMayBeEmitted(file, program) && !rootPaths.has(file.path)) {
-            addProgramDiagnosticExplainingFile(
-              file,
-              Diagnostics.File_0_is_not_listed_within_the_file_list_of_project_1_Projects_must_list_all_files_or_use_an_include_pattern,
-              [file.fileName, options.configFilePath || ""]
-            );
-          }
-        }
-      }
-      if (options.paths) {
-        for (const key in options.paths) {
-          if (!hasProperty(options.paths, key)) {
-            continue;
-          }
-          if (!hasZeroOrOneAsteriskCharacter(key)) {
-            createDiagnosticForOptionPaths(
-              /*onKey*/
-              true,
-              key,
-              Diagnostics.Pattern_0_can_have_at_most_one_Asterisk_character,
-              key
-            );
-          }
-          if (isArray(options.paths[key])) {
-            const len = options.paths[key].length;
-            if (len === 0) {
-              createDiagnosticForOptionPaths(
-                /*onKey*/
-                false,
-                key,
-                Diagnostics.Substitutions_for_pattern_0_shouldn_t_be_an_empty_array,
-                key
-              );
-            }
-            for (let i = 0; i < len; i++) {
-              const subst = options.paths[key][i];
-              const typeOfSubst = typeof subst;
-              if (typeOfSubst === "string") {
-                if (!hasZeroOrOneAsteriskCharacter(subst)) {
-                  createDiagnosticForOptionPathKeyValue(key, i, Diagnostics.Substitution_0_in_pattern_1_can_have_at_most_one_Asterisk_character, subst, key);
-                }
-                if (!options.baseUrl && !pathIsRelative(subst) && !pathIsAbsolute(subst)) {
-                  createDiagnosticForOptionPathKeyValue(key, i, Diagnostics.Non_relative_paths_are_not_allowed_when_baseUrl_is_not_set_Did_you_forget_a_leading_Slash);
-                }
-              } else {
-                createDiagnosticForOptionPathKeyValue(key, i, Diagnostics.Substitution_0_for_pattern_1_has_incorrect_type_expected_string_got_2, subst, key, typeOfSubst);
-              }
-            }
-          } else {
-            createDiagnosticForOptionPaths(
-              /*onKey*/
-              false,
-              key,
-              Diagnostics.Substitutions_for_pattern_0_should_be_an_array,
-              key
-            );
-          }
-        }
-      }
-      if (!options.sourceMap && !options.inlineSourceMap) {
-        if (options.inlineSources) {
-          createDiagnosticForOptionName(Diagnostics.Option_0_can_only_be_used_when_either_option_inlineSourceMap_or_option_sourceMap_is_provided, "inlineSources");
-        }
-        if (options.sourceRoot) {
-          createDiagnosticForOptionName(Diagnostics.Option_0_can_only_be_used_when_either_option_inlineSourceMap_or_option_sourceMap_is_provided, "sourceRoot");
-        }
-      }
-      if (options.out && options.outFile) {
-        createDiagnosticForOptionName(Diagnostics.Option_0_cannot_be_specified_with_option_1, "out", "outFile");
-      }
-      if (options.mapRoot && !(options.sourceMap || options.declarationMap)) {
-        createDiagnosticForOptionName(Diagnostics.Option_0_cannot_be_specified_without_specifying_option_1_or_option_2, "mapRoot", "sourceMap", "declarationMap");
-      }
-      if (options.declarationDir) {
-        if (!getEmitDeclarations(options)) {
-          createDiagnosticForOptionName(Diagnostics.Option_0_cannot_be_specified_without_specifying_option_1_or_option_2, "declarationDir", "declaration", "composite");
-        }
-        if (outputFile) {
-          createDiagnosticForOptionName(Diagnostics.Option_0_cannot_be_specified_with_option_1, "declarationDir", options.out ? "out" : "outFile");
-        }
-      }
-      if (options.declarationMap && !getEmitDeclarations(options)) {
-        createDiagnosticForOptionName(Diagnostics.Option_0_cannot_be_specified_without_specifying_option_1_or_option_2, "declarationMap", "declaration", "composite");
-      }
-      if (options.lib && options.noLib) {
-        createDiagnosticForOptionName(Diagnostics.Option_0_cannot_be_specified_with_option_1, "lib", "noLib");
-      }
-      if (options.noImplicitUseStrict && getStrictOptionValue(options, "alwaysStrict")) {
-        createDiagnosticForOptionName(Diagnostics.Option_0_cannot_be_specified_with_option_1, "noImplicitUseStrict", "alwaysStrict");
-      }
-      const languageVersion = getEmitScriptTarget(options);
-      const firstNonAmbientExternalModuleSourceFile = find(files, (f) => isExternalModule(f) && !f.isDeclarationFile);
-      if (options.isolatedModules || options.verbatimModuleSyntax) {
-        if (options.module === 0 /* None */ && languageVersion < 2 /* ES2015 */ && options.isolatedModules) {
-          createDiagnosticForOptionName(Diagnostics.Option_isolatedModules_can_only_be_used_when_either_option_module_is_provided_or_option_target_is_ES2015_or_higher, "isolatedModules", "target");
-        }
-        if (options.preserveConstEnums === false) {
-          createDiagnosticForOptionName(Diagnostics.Option_preserveConstEnums_cannot_be_disabled_when_0_is_enabled, options.verbatimModuleSyntax ? "verbatimModuleSyntax" : "isolatedModules", "preserveConstEnums");
-        }
-      } else if (firstNonAmbientExternalModuleSourceFile && languageVersion < 2 /* ES2015 */ && options.module === 0 /* None */) {
-        const span = getErrorSpanForNode(firstNonAmbientExternalModuleSourceFile, typeof firstNonAmbientExternalModuleSourceFile.externalModuleIndicator === "boolean" ? firstNonAmbientExternalModuleSourceFile : firstNonAmbientExternalModuleSourceFile.externalModuleIndicator);
-        programDiagnostics.add(createFileDiagnostic(firstNonAmbientExternalModuleSourceFile, span.start, span.length, Diagnostics.Cannot_use_imports_exports_or_module_augmentations_when_module_is_none));
-      }
-      if (outputFile && !options.emitDeclarationOnly) {
-        if (options.module && !(options.module === 2 /* AMD */ || options.module === 4 /* System */)) {
-          createDiagnosticForOptionName(Diagnostics.Only_amd_and_system_modules_are_supported_alongside_0, options.out ? "out" : "outFile", "module");
-        } else if (options.module === void 0 && firstNonAmbientExternalModuleSourceFile) {
-          const span = getErrorSpanForNode(firstNonAmbientExternalModuleSourceFile, typeof firstNonAmbientExternalModuleSourceFile.externalModuleIndicator === "boolean" ? firstNonAmbientExternalModuleSourceFile : firstNonAmbientExternalModuleSourceFile.externalModuleIndicator);
-          programDiagnostics.add(createFileDiagnostic(firstNonAmbientExternalModuleSourceFile, span.start, span.length, Diagnostics.Cannot_compile_modules_using_option_0_unless_the_module_flag_is_amd_or_system, options.out ? "out" : "outFile"));
-        }
-      }
-      if (getResolveJsonModule(options)) {
-        if (getEmitModuleResolutionKind(options) === 1 /* Classic */) {
-          createDiagnosticForOptionName(Diagnostics.Option_resolveJsonModule_cannot_be_specified_when_moduleResolution_is_set_to_classic, "resolveJsonModule");
-        } else if (!hasJsonModuleEmitEnabled(options)) {
-          createDiagnosticForOptionName(Diagnostics.Option_resolveJsonModule_can_only_be_specified_when_module_code_generation_is_commonjs_amd_es2015_or_esNext, "resolveJsonModule", "module");
-        }
-      }
-      if (options.outDir || // there is --outDir specified
-      options.rootDir || // there is --rootDir specified
-      options.sourceRoot || // there is --sourceRoot specified
-      options.mapRoot) {
-        const dir = getCommonSourceDirectory2();
-        if (options.outDir && dir === "" && files.some((file) => getRootLength(file.fileName) > 1)) {
-          createDiagnosticForOptionName(Diagnostics.Cannot_find_the_common_subdirectory_path_for_the_input_files, "outDir");
-        }
-      }
-      if (options.useDefineForClassFields && languageVersion === 0 /* ES3 */) {
-        createDiagnosticForOptionName(Diagnostics.Option_0_cannot_be_specified_when_option_target_is_ES3, "useDefineForClassFields");
-      }
-      if (options.checkJs && !getAllowJSCompilerOption(options)) {
-        programDiagnostics.add(createCompilerDiagnostic(Diagnostics.Option_0_cannot_be_specified_without_specifying_option_1, "checkJs", "allowJs"));
-      }
-      if (options.emitDeclarationOnly) {
-        if (!getEmitDeclarations(options)) {
-          createDiagnosticForOptionName(Diagnostics.Option_0_cannot_be_specified_without_specifying_option_1_or_option_2, "emitDeclarationOnly", "declaration", "composite");
-        }
-        if (options.noEmit) {
-          createDiagnosticForOptionName(Diagnostics.Option_0_cannot_be_specified_with_option_1, "emitDeclarationOnly", "noEmit");
-        }
-      }
-      if (options.emitDecoratorMetadata && !options.experimentalDecorators) {
-        createDiagnosticForOptionName(Diagnostics.Option_0_cannot_be_specified_without_specifying_option_1, "emitDecoratorMetadata", "experimentalDecorators");
-      }
-      if (options.jsxFactory) {
-        if (options.reactNamespace) {
-          createDiagnosticForOptionName(Diagnostics.Option_0_cannot_be_specified_with_option_1, "reactNamespace", "jsxFactory");
-        }
-        if (options.jsx === 4 /* ReactJSX */ || options.jsx === 5 /* ReactJSXDev */) {
-          createDiagnosticForOptionName(Diagnostics.Option_0_cannot_be_specified_when_option_jsx_is_1, "jsxFactory", inverseJsxOptionMap.get("" + options.jsx));
-        }
-        if (!parseIsolatedEntityName(options.jsxFactory, languageVersion)) {
-          createOptionValueDiagnostic("jsxFactory", Diagnostics.Invalid_value_for_jsxFactory_0_is_not_a_valid_identifier_or_qualified_name, options.jsxFactory);
-        }
-      } else if (options.reactNamespace && !isIdentifierText(options.reactNamespace, languageVersion)) {
-        createOptionValueDiagnostic("reactNamespace", Diagnostics.Invalid_value_for_reactNamespace_0_is_not_a_valid_identifier, options.reactNamespace);
-      }
-      if (options.jsxFragmentFactory) {
-        if (!options.jsxFactory) {
-          createDiagnosticForOptionName(Diagnostics.Option_0_cannot_be_specified_without_specifying_option_1, "jsxFragmentFactory", "jsxFactory");
-        }
-        if (options.jsx === 4 /* ReactJSX */ || options.jsx === 5 /* ReactJSXDev */) {
-          createDiagnosticForOptionName(Diagnostics.Option_0_cannot_be_specified_when_option_jsx_is_1, "jsxFragmentFactory", inverseJsxOptionMap.get("" + options.jsx));
-        }
-        if (!parseIsolatedEntityName(options.jsxFragmentFactory, languageVersion)) {
-          createOptionValueDiagnostic("jsxFragmentFactory", Diagnostics.Invalid_value_for_jsxFragmentFactory_0_is_not_a_valid_identifier_or_qualified_name, options.jsxFragmentFactory);
-        }
-      }
-      if (options.reactNamespace) {
-        if (options.jsx === 4 /* ReactJSX */ || options.jsx === 5 /* ReactJSXDev */) {
-          createDiagnosticForOptionName(Diagnostics.Option_0_cannot_be_specified_when_option_jsx_is_1, "reactNamespace", inverseJsxOptionMap.get("" + options.jsx));
-        }
-      }
-      if (options.jsxImportSource) {
-        if (options.jsx === 2 /* React */) {
-          createDiagnosticForOptionName(Diagnostics.Option_0_cannot_be_specified_when_option_jsx_is_1, "jsxImportSource", inverseJsxOptionMap.get("" + options.jsx));
-        }
-      }
-      if (options.preserveValueImports && getEmitModuleKind(options) < 5 /* ES2015 */) {
-        createDiagnosticForOptionName(Diagnostics.Option_0_can_only_be_used_when_module_is_set_to_es2015_or_later, "preserveValueImports");
-      }
-      const moduleKind = getEmitModuleKind(options);
-      if (options.verbatimModuleSyntax) {
-        if (moduleKind === 2 /* AMD */ || moduleKind === 3 /* UMD */ || moduleKind === 4 /* System */) {
-          createDiagnosticForOptionName(Diagnostics.Option_verbatimModuleSyntax_cannot_be_used_when_module_is_set_to_UMD_AMD_or_System, "verbatimModuleSyntax");
-        }
-        if (options.preserveValueImports) {
-          createRedundantOptionDiagnostic("preserveValueImports", "verbatimModuleSyntax");
-        }
-        if (options.importsNotUsedAsValues) {
-          createRedundantOptionDiagnostic("importsNotUsedAsValues", "verbatimModuleSyntax");
-        }
-      }
-      if (options.allowImportingTsExtensions && !(options.noEmit || options.emitDeclarationOnly)) {
-        createOptionValueDiagnostic("allowImportingTsExtensions", Diagnostics.Option_allowImportingTsExtensions_can_only_be_used_when_either_noEmit_or_emitDeclarationOnly_is_set);
-      }
-      const moduleResolution = getEmitModuleResolutionKind(options);
-      if (options.resolvePackageJsonExports && !moduleResolutionSupportsPackageJsonExportsAndImports(moduleResolution)) {
-        createDiagnosticForOptionName(Diagnostics.Option_0_can_only_be_used_when_moduleResolution_is_set_to_node16_nodenext_or_bundler, "resolvePackageJsonExports");
-      }
-      if (options.resolvePackageJsonImports && !moduleResolutionSupportsPackageJsonExportsAndImports(moduleResolution)) {
-        createDiagnosticForOptionName(Diagnostics.Option_0_can_only_be_used_when_moduleResolution_is_set_to_node16_nodenext_or_bundler, "resolvePackageJsonImports");
-      }
-      if (options.customConditions && !moduleResolutionSupportsPackageJsonExportsAndImports(moduleResolution)) {
-        createDiagnosticForOptionName(Diagnostics.Option_0_can_only_be_used_when_moduleResolution_is_set_to_node16_nodenext_or_bundler, "customConditions");
-      }
-      if (moduleResolution === 100 /* Bundler */ && !emitModuleKindIsNonNodeESM(moduleKind)) {
-        createOptionValueDiagnostic("moduleResolution", Diagnostics.Option_0_can_only_be_used_when_module_is_set_to_es2015_or_later, "bundler");
-      }
-      if (!options.noEmit && !options.suppressOutputPathCheck) {
-        const emitHost = getEmitHost();
-        const emitFilesSeen = /* @__PURE__ */ new Set();
-        forEachEmittedFile(emitHost, (emitFileNames) => {
-          if (!options.emitDeclarationOnly) {
-            verifyEmitFilePath(emitFileNames.jsFilePath, emitFilesSeen);
-          }
-          verifyEmitFilePath(emitFileNames.declarationFilePath, emitFilesSeen);
-        });
-      }
-      function verifyEmitFilePath(emitFileName, emitFilesSeen) {
-        if (emitFileName) {
-          const emitFilePath = toPath3(emitFileName);
-          if (filesByName.has(emitFilePath)) {
-            let chain;
-            if (!options.configFilePath) {
-              chain = chainDiagnosticMessages(
-                /*details*/
-                void 0,
-                Diagnostics.Adding_a_tsconfig_json_file_will_help_organize_projects_that_contain_both_TypeScript_and_JavaScript_files_Learn_more_at_https_Colon_Slash_Slashaka_ms_Slashtsconfig
-              );
-            }
-            chain = chainDiagnosticMessages(chain, Diagnostics.Cannot_write_file_0_because_it_would_overwrite_input_file, emitFileName);
-            blockEmittingOfFile(emitFileName, createCompilerDiagnosticFromMessageChain(chain));
-          }
-          const emitFileKey = !host.useCaseSensitiveFileNames() ? toFileNameLowerCase(emitFilePath) : emitFilePath;
-          if (emitFilesSeen.has(emitFileKey)) {
-            blockEmittingOfFile(emitFileName, createCompilerDiagnostic(Diagnostics.Cannot_write_file_0_because_it_would_be_overwritten_by_multiple_input_files, emitFileName));
-          } else {
-            emitFilesSeen.add(emitFileKey);
-          }
-        }
-      }
-    }
-    function getIgnoreDeprecationsVersion() {
-      const ignoreDeprecations = options.ignoreDeprecations;
-      if (ignoreDeprecations) {
-        if (ignoreDeprecations === "5.0") {
-          return new Version(ignoreDeprecations);
-        }
-        reportInvalidIgnoreDeprecations();
-      }
-      return Version.zero;
-    }
-    function checkDeprecations(deprecatedIn, removedIn, createDiagnostic, fn) {
-      const deprecatedInVersion = new Version(deprecatedIn);
-      const removedInVersion = new Version(removedIn);
-      const typescriptVersion = new Version(typeScriptVersion3 || versionMajorMinor);
-      const ignoreDeprecationsVersion = getIgnoreDeprecationsVersion();
-      const mustBeRemoved = !(removedInVersion.compareTo(typescriptVersion) === 1 /* GreaterThan */);
-      const canBeSilenced = !mustBeRemoved && ignoreDeprecationsVersion.compareTo(deprecatedInVersion) === -1 /* LessThan */;
-      if (mustBeRemoved || canBeSilenced) {
-        fn((name, value, useInstead) => {
-          if (mustBeRemoved) {
-            if (value === void 0) {
-              createDiagnostic(name, value, useInstead, Diagnostics.Option_0_has_been_removed_Please_remove_it_from_your_configuration, name);
-            } else {
-              createDiagnostic(name, value, useInstead, Diagnostics.Option_0_1_has_been_removed_Please_remove_it_from_your_configuration, name, value);
-            }
-          } else {
-            if (value === void 0) {
-              createDiagnostic(name, value, useInstead, Diagnostics.Option_0_is_deprecated_and_will_stop_functioning_in_TypeScript_1_Specify_compilerOption_ignoreDeprecations_Colon_2_to_silence_this_error, name, removedIn, deprecatedIn);
-            } else {
-              createDiagnostic(name, value, useInstead, Diagnostics.Option_0_1_is_deprecated_and_will_stop_functioning_in_TypeScript_2_Specify_compilerOption_ignoreDeprecations_Colon_3_to_silence_this_error, name, value, removedIn, deprecatedIn);
-            }
-          }
-        });
-      }
-    }
-    function verifyDeprecatedCompilerOptions() {
-      function createDiagnostic(name, value, useInstead, message, ...args) {
-        if (useInstead) {
-          const details = chainDiagnosticMessages(
-            /*details*/
-            void 0,
-            Diagnostics.Use_0_instead,
-            useInstead
-          );
-          const chain = chainDiagnosticMessages(details, message, ...args);
-          createDiagnosticForOption(
-            /*onKey*/
-            !value,
-            name,
-            /*option2*/
-            void 0,
-            chain
-          );
-        } else {
-          createDiagnosticForOption(
-            /*onKey*/
-            !value,
-            name,
-            /*option2*/
-            void 0,
-            message,
-            ...args
-          );
-        }
-      }
-      checkDeprecations("5.0", "5.5", createDiagnostic, (createDeprecatedDiagnostic) => {
-        if (options.target === 0 /* ES3 */) {
-          createDeprecatedDiagnostic("target", "ES3");
-        }
-        if (options.noImplicitUseStrict) {
-          createDeprecatedDiagnostic("noImplicitUseStrict");
-        }
-        if (options.keyofStringsOnly) {
-          createDeprecatedDiagnostic("keyofStringsOnly");
-        }
-        if (options.suppressExcessPropertyErrors) {
-          createDeprecatedDiagnostic("suppressExcessPropertyErrors");
-        }
-        if (options.suppressImplicitAnyIndexErrors) {
-          createDeprecatedDiagnostic("suppressImplicitAnyIndexErrors");
-        }
-        if (options.noStrictGenericChecks) {
-          createDeprecatedDiagnostic("noStrictGenericChecks");
-        }
-        if (options.charset) {
-          createDeprecatedDiagnostic("charset");
-        }
-        if (options.out) {
-          createDeprecatedDiagnostic(
-            "out",
-            /*value*/
-            void 0,
-            "outFile"
-          );
-        }
-        if (options.importsNotUsedAsValues) {
-          createDeprecatedDiagnostic(
-            "importsNotUsedAsValues",
-            /*value*/
-            void 0,
-            "verbatimModuleSyntax"
-          );
-        }
-        if (options.preserveValueImports) {
-          createDeprecatedDiagnostic(
-            "preserveValueImports",
-            /*value*/
-            void 0,
-            "verbatimModuleSyntax"
-          );
-        }
-      });
-    }
-    function verifyDeprecatedProjectReference(ref, parentFile, index) {
-      function createDiagnostic(_name, _value, _useInstead, message, ...args) {
-        createDiagnosticForReference(parentFile, index, message, ...args);
-      }
-      checkDeprecations("5.0", "5.5", createDiagnostic, (createDeprecatedDiagnostic) => {
-        if (ref.prepend) {
-          createDeprecatedDiagnostic("prepend");
-        }
-      });
-    }
-    function createDiagnosticExplainingFile(file, fileProcessingReason, diagnostic, args) {
-      var _a2;
-      let fileIncludeReasons;
-      let relatedInfo;
-      let locationReason = isReferencedFile(fileProcessingReason) ? fileProcessingReason : void 0;
-      if (file)
-        (_a2 = fileReasons.get(file.path)) == null ? void 0 : _a2.forEach(processReason);
-      if (fileProcessingReason)
-        processReason(fileProcessingReason);
-      if (locationReason && (fileIncludeReasons == null ? void 0 : fileIncludeReasons.length) === 1)
-        fileIncludeReasons = void 0;
-      const location = locationReason && getReferencedFileLocation(getSourceFileByPath, locationReason);
-      const fileIncludeReasonDetails = fileIncludeReasons && chainDiagnosticMessages(fileIncludeReasons, Diagnostics.The_file_is_in_the_program_because_Colon);
-      const redirectInfo = file && explainIfFileIsRedirectAndImpliedFormat(file);
-      const chain = chainDiagnosticMessages(redirectInfo ? fileIncludeReasonDetails ? [fileIncludeReasonDetails, ...redirectInfo] : redirectInfo : fileIncludeReasonDetails, diagnostic, ...args || emptyArray);
-      return location && isReferenceFileLocation(location) ? createFileDiagnosticFromMessageChain(location.file, location.pos, location.end - location.pos, chain, relatedInfo) : createCompilerDiagnosticFromMessageChain(chain, relatedInfo);
-      function processReason(reason) {
-        (fileIncludeReasons || (fileIncludeReasons = [])).push(fileIncludeReasonToDiagnostics(program, reason));
-        if (!locationReason && isReferencedFile(reason)) {
-          locationReason = reason;
-        } else if (locationReason !== reason) {
-          relatedInfo = append(relatedInfo, fileIncludeReasonToRelatedInformation(reason));
-        }
-        if (reason === fileProcessingReason)
-          fileProcessingReason = void 0;
-      }
-    }
-    function addFilePreprocessingFileExplainingDiagnostic(file, fileProcessingReason, diagnostic, args) {
-      (fileProcessingDiagnostics || (fileProcessingDiagnostics = [])).push({
-        kind: 1 /* FilePreprocessingFileExplainingDiagnostic */,
-        file: file && file.path,
-        fileProcessingReason,
-        diagnostic,
-        args
-      });
-    }
-    function addProgramDiagnosticExplainingFile(file, diagnostic, args) {
-      programDiagnostics.add(createDiagnosticExplainingFile(
-        file,
-        /*fileProcessingReason*/
-        void 0,
-        diagnostic,
-        args
-      ));
-    }
-    function fileIncludeReasonToRelatedInformation(reason) {
-      if (isReferencedFile(reason)) {
-        const referenceLocation = getReferencedFileLocation(getSourceFileByPath, reason);
-        let message2;
-        switch (reason.kind) {
-          case 3 /* Import */:
-            message2 = Diagnostics.File_is_included_via_import_here;
-            break;
-          case 4 /* ReferenceFile */:
-            message2 = Diagnostics.File_is_included_via_reference_here;
-            break;
-          case 5 /* TypeReferenceDirective */:
-            message2 = Diagnostics.File_is_included_via_type_library_reference_here;
-            break;
-          case 7 /* LibReferenceDirective */:
-            message2 = Diagnostics.File_is_included_via_library_reference_here;
-            break;
-          default:
-            Debug.assertNever(reason);
-        }
-        return isReferenceFileLocation(referenceLocation) ? createFileDiagnostic(
-          referenceLocation.file,
-          referenceLocation.pos,
-          referenceLocation.end - referenceLocation.pos,
-          message2
-        ) : void 0;
-      }
-      if (!options.configFile)
-        return void 0;
-      let configFileNode;
-      let message;
-      switch (reason.kind) {
-        case 0 /* RootFile */:
-          if (!options.configFile.configFileSpecs)
-            return void 0;
-          const fileName = getNormalizedAbsolutePath(rootNames[reason.index], currentDirectory);
-          const matchedByFiles = getMatchedFileSpec(program, fileName);
-          if (matchedByFiles) {
-            configFileNode = getTsConfigPropArrayElementValue(options.configFile, "files", matchedByFiles);
-            message = Diagnostics.File_is_matched_by_files_list_specified_here;
-            break;
-          }
-          const matchedByInclude = getMatchedIncludeSpec(program, fileName);
-          if (!matchedByInclude || !isString(matchedByInclude))
-            return void 0;
-          configFileNode = getTsConfigPropArrayElementValue(options.configFile, "include", matchedByInclude);
-          message = Diagnostics.File_is_matched_by_include_pattern_specified_here;
-          break;
-        case 1 /* SourceFromProjectReference */:
-        case 2 /* OutputFromProjectReference */:
-          const referencedResolvedRef = Debug.checkDefined(resolvedProjectReferences == null ? void 0 : resolvedProjectReferences[reason.index]);
-          const referenceInfo = forEachProjectReference(
-            projectReferences,
-            resolvedProjectReferences,
-            (resolvedRef, parent2, index2) => resolvedRef === referencedResolvedRef ? { sourceFile: (parent2 == null ? void 0 : parent2.sourceFile) || options.configFile, index: index2 } : void 0
-          );
-          if (!referenceInfo)
-            return void 0;
-          const { sourceFile, index } = referenceInfo;
-          const referencesSyntax = forEachTsConfigPropArray(
-            sourceFile,
-            "references",
-            (property) => isArrayLiteralExpression(property.initializer) ? property.initializer : void 0
-          );
-          return referencesSyntax && referencesSyntax.elements.length > index ? createDiagnosticForNodeInSourceFile(
-            sourceFile,
-            referencesSyntax.elements[index],
-            reason.kind === 2 /* OutputFromProjectReference */ ? Diagnostics.File_is_output_from_referenced_project_specified_here : Diagnostics.File_is_source_from_referenced_project_specified_here
-          ) : void 0;
-        case 8 /* AutomaticTypeDirectiveFile */:
-          if (!options.types)
-            return void 0;
-          configFileNode = getOptionsSyntaxByArrayElementValue("types", reason.typeReference);
-          message = Diagnostics.File_is_entry_point_of_type_library_specified_here;
-          break;
-        case 6 /* LibFile */:
-          if (reason.index !== void 0) {
-            configFileNode = getOptionsSyntaxByArrayElementValue("lib", options.lib[reason.index]);
-            message = Diagnostics.File_is_library_specified_here;
-            break;
-          }
-          const target = forEachEntry(targetOptionDeclaration.type, (value, key) => value === getEmitScriptTarget(options) ? key : void 0);
-          configFileNode = target ? getOptionsSyntaxByValue("target", target) : void 0;
-          message = Diagnostics.File_is_default_library_for_target_specified_here;
-          break;
-        default:
-          Debug.assertNever(reason);
-      }
-      return configFileNode && createDiagnosticForNodeInSourceFile(
-        options.configFile,
-        configFileNode,
-        message
-      );
-    }
-    function verifyProjectReferences() {
-      const buildInfoPath = !options.suppressOutputPathCheck ? getTsBuildInfoEmitOutputFilePath(options) : void 0;
-      forEachProjectReference(projectReferences, resolvedProjectReferences, (resolvedRef, parent2, index) => {
-        const ref = (parent2 ? parent2.commandLine.projectReferences : projectReferences)[index];
-        const parentFile = parent2 && parent2.sourceFile;
-        verifyDeprecatedProjectReference(ref, parentFile, index);
-        if (!resolvedRef) {
-          createDiagnosticForReference(parentFile, index, Diagnostics.File_0_not_found, ref.path);
-          return;
-        }
-        const options2 = resolvedRef.commandLine.options;
-        if (!options2.composite || options2.noEmit) {
-          const inputs = parent2 ? parent2.commandLine.fileNames : rootNames;
-          if (inputs.length) {
-            if (!options2.composite)
-              createDiagnosticForReference(parentFile, index, Diagnostics.Referenced_project_0_must_have_setting_composite_Colon_true, ref.path);
-            if (options2.noEmit)
-              createDiagnosticForReference(parentFile, index, Diagnostics.Referenced_project_0_may_not_disable_emit, ref.path);
-          }
-        }
-        if (ref.prepend) {
-          const out = outFile(options2);
-          if (out) {
-            if (!host.fileExists(out)) {
-              createDiagnosticForReference(parentFile, index, Diagnostics.Output_file_0_from_project_1_does_not_exist, out, ref.path);
-            }
-          } else {
-            createDiagnosticForReference(parentFile, index, Diagnostics.Cannot_prepend_project_0_because_it_does_not_have_outFile_set, ref.path);
-          }
-        }
-        if (!parent2 && buildInfoPath && buildInfoPath === getTsBuildInfoEmitOutputFilePath(options2)) {
-          createDiagnosticForReference(parentFile, index, Diagnostics.Cannot_write_file_0_because_it_will_overwrite_tsbuildinfo_file_generated_by_referenced_project_1, buildInfoPath, ref.path);
-          hasEmitBlockingDiagnostics.set(toPath3(buildInfoPath), true);
-        }
-      });
-    }
-    function createDiagnosticForOptionPathKeyValue(key, valueIndex, message, ...args) {
-      let needCompilerDiagnostic = true;
-      forEachOptionPathsSyntax((pathProp) => {
-        if (isObjectLiteralExpression(pathProp.initializer)) {
-          forEachPropertyAssignment(pathProp.initializer, key, (keyProps) => {
-            const initializer = keyProps.initializer;
-            if (isArrayLiteralExpression(initializer) && initializer.elements.length > valueIndex) {
-              programDiagnostics.add(createDiagnosticForNodeInSourceFile(options.configFile, initializer.elements[valueIndex], message, ...args));
-              needCompilerDiagnostic = false;
-            }
-          });
-        }
-      });
-      if (needCompilerDiagnostic) {
-        programDiagnostics.add(createCompilerDiagnostic(message, ...args));
-      }
-    }
-    function createDiagnosticForOptionPaths(onKey, key, message, ...args) {
-      let needCompilerDiagnostic = true;
-      forEachOptionPathsSyntax((pathProp) => {
-        if (isObjectLiteralExpression(pathProp.initializer) && createOptionDiagnosticInObjectLiteralSyntax(
-          pathProp.initializer,
-          onKey,
-          key,
-          /*key2*/
-          void 0,
-          message,
-          ...args
-        )) {
-          needCompilerDiagnostic = false;
-        }
-      });
-      if (needCompilerDiagnostic) {
-        programDiagnostics.add(createCompilerDiagnostic(message, ...args));
-      }
-    }
-    function forEachOptionsSyntaxByName(name, callback) {
-      return forEachPropertyAssignment(getCompilerOptionsObjectLiteralSyntax(), name, callback);
-    }
-    function forEachOptionPathsSyntax(callback) {
-      return forEachOptionsSyntaxByName("paths", callback);
-    }
-    function getOptionsSyntaxByValue(name, value) {
-      return forEachOptionsSyntaxByName(name, (property) => isStringLiteral(property.initializer) && property.initializer.text === value ? property.initializer : void 0);
-    }
-    function getOptionsSyntaxByArrayElementValue(name, value) {
-      const compilerOptionsObjectLiteralSyntax = getCompilerOptionsObjectLiteralSyntax();
-      return compilerOptionsObjectLiteralSyntax && getPropertyArrayElementValue(compilerOptionsObjectLiteralSyntax, name, value);
-    }
-    function createDiagnosticForOptionName(message, option1, option2, option3) {
-      createDiagnosticForOption(
-        /*onKey*/
-        true,
-        option1,
-        option2,
-        message,
-        option1,
-        option2,
-        option3
-      );
-    }
-    function createOptionValueDiagnostic(option1, message, ...args) {
-      createDiagnosticForOption(
-        /*onKey*/
-        false,
-        option1,
-        /*option2*/
-        void 0,
-        message,
-        ...args
-      );
-    }
-    function createDiagnosticForReference(sourceFile, index, message, ...args) {
-      const referencesSyntax = forEachTsConfigPropArray(
-        sourceFile || options.configFile,
-        "references",
-        (property) => isArrayLiteralExpression(property.initializer) ? property.initializer : void 0
-      );
-      if (referencesSyntax && referencesSyntax.elements.length > index) {
-        programDiagnostics.add(createDiagnosticForNodeInSourceFile(sourceFile || options.configFile, referencesSyntax.elements[index], message, ...args));
-      } else {
-        programDiagnostics.add(createCompilerDiagnostic(message, ...args));
-      }
-    }
-    function createDiagnosticForOption(onKey, option1, option2, message, ...args) {
-      const compilerOptionsObjectLiteralSyntax = getCompilerOptionsObjectLiteralSyntax();
-      const needCompilerDiagnostic = !compilerOptionsObjectLiteralSyntax || !createOptionDiagnosticInObjectLiteralSyntax(compilerOptionsObjectLiteralSyntax, onKey, option1, option2, message, ...args);
-      if (needCompilerDiagnostic) {
-        if ("messageText" in message) {
-          programDiagnostics.add(createCompilerDiagnosticFromMessageChain(message));
-        } else {
-          programDiagnostics.add(createCompilerDiagnostic(message, ...args));
-        }
-      }
-    }
-    function getCompilerOptionsObjectLiteralSyntax() {
-      if (_compilerOptionsObjectLiteralSyntax === void 0) {
-        _compilerOptionsObjectLiteralSyntax = forEachPropertyAssignment(
-          getTsConfigObjectLiteralExpression(options.configFile),
-          "compilerOptions",
-          (prop) => isObjectLiteralExpression(prop.initializer) ? prop.initializer : void 0
-        ) || false;
-      }
-      return _compilerOptionsObjectLiteralSyntax || void 0;
-    }
-    function createOptionDiagnosticInObjectLiteralSyntax(objectLiteral, onKey, key1, key2, message, ...args) {
-      let needsCompilerDiagnostic = false;
-      forEachPropertyAssignment(objectLiteral, key1, (prop) => {
-        if ("messageText" in message) {
-          programDiagnostics.add(createDiagnosticForNodeFromMessageChain(options.configFile, onKey ? prop.name : prop.initializer, message));
-        } else {
-          programDiagnostics.add(createDiagnosticForNodeInSourceFile(options.configFile, onKey ? prop.name : prop.initializer, message, ...args));
-        }
-        needsCompilerDiagnostic = true;
-      }, key2);
-      return needsCompilerDiagnostic;
-    }
-    function createRedundantOptionDiagnostic(errorOnOption, redundantWithOption) {
-      const compilerOptionsObjectLiteralSyntax = getCompilerOptionsObjectLiteralSyntax();
-      if (compilerOptionsObjectLiteralSyntax) {
-        createOptionDiagnosticInObjectLiteralSyntax(
-          compilerOptionsObjectLiteralSyntax,
-          /*onKey*/
-          true,
-          errorOnOption,
-          /*key2*/
-          void 0,
-          Diagnostics.Option_0_is_redundant_and_cannot_be_specified_with_option_1,
-          errorOnOption,
-          redundantWithOption
-        );
-      } else {
-        createDiagnosticForOptionName(Diagnostics.Option_0_is_redundant_and_cannot_be_specified_with_option_1, errorOnOption, redundantWithOption);
-      }
-    }
-    function blockEmittingOfFile(emitFileName, diag2) {
-      hasEmitBlockingDiagnostics.set(toPath3(emitFileName), true);
-      programDiagnostics.add(diag2);
-    }
-    function isEmittedFile(file) {
-      if (options.noEmit) {
-        return false;
-      }
-      const filePath = toPath3(file);
-      if (getSourceFileByPath(filePath)) {
-        return false;
-      }
-      const out = outFile(options);
-      if (out) {
-        return isSameFile(filePath, out) || isSameFile(filePath, removeFileExtension(out) + ".d.ts" /* Dts */);
-      }
-      if (options.declarationDir && containsPath(options.declarationDir, filePath, currentDirectory, !host.useCaseSensitiveFileNames())) {
-        return true;
-      }
-      if (options.outDir) {
-        return containsPath(options.outDir, filePath, currentDirectory, !host.useCaseSensitiveFileNames());
-      }
-      if (fileExtensionIsOneOf(filePath, supportedJSExtensionsFlat) || isDeclarationFileName(filePath)) {
-        const filePathWithoutExtension = removeFileExtension(filePath);
-        return !!getSourceFileByPath(filePathWithoutExtension + ".ts" /* Ts */) || !!getSourceFileByPath(filePathWithoutExtension + ".tsx" /* Tsx */);
-      }
-      return false;
-    }
-    function isSameFile(file1, file2) {
-      return comparePaths(file1, file2, currentDirectory, !host.useCaseSensitiveFileNames()) === 0 /* EqualTo */;
-    }
-    function getSymlinkCache() {
-      if (host.getSymlinkCache) {
-        return host.getSymlinkCache();
-      }
-      if (!symlinks) {
-        symlinks = createSymlinkCache(currentDirectory, getCanonicalFileName);
-      }
-      if (files && automaticTypeDirectiveResolutions && !symlinks.hasProcessedResolutions()) {
-        symlinks.setSymlinksFromResolutions(files, automaticTypeDirectiveResolutions);
-      }
-      return symlinks;
-    }
-  }
-  function updateHostForUseSourceOfProjectReferenceRedirect(host) {
-    let setOfDeclarationDirectories;
-    const originalFileExists = host.compilerHost.fileExists;
-    const originalDirectoryExists = host.compilerHost.directoryExists;
-    const originalGetDirectories = host.compilerHost.getDirectories;
-    const originalRealpath = host.compilerHost.realpath;
-    if (!host.useSourceOfProjectReferenceRedirect)
-      return { onProgramCreateComplete: noop, fileExists };
-    host.compilerHost.fileExists = fileExists;
-    let directoryExists;
-    if (originalDirectoryExists) {
-      directoryExists = host.compilerHost.directoryExists = (path) => {
-        if (originalDirectoryExists.call(host.compilerHost, path)) {
-          handleDirectoryCouldBeSymlink(path);
-          return true;
-        }
-        if (!host.getResolvedProjectReferences())
-          return false;
-        if (!setOfDeclarationDirectories) {
-          setOfDeclarationDirectories = /* @__PURE__ */ new Set();
-          host.forEachResolvedProjectReference((ref) => {
-            const out = outFile(ref.commandLine.options);
-            if (out) {
-              setOfDeclarationDirectories.add(getDirectoryPath(host.toPath(out)));
-            } else {
-              const declarationDir = ref.commandLine.options.declarationDir || ref.commandLine.options.outDir;
-              if (declarationDir) {
-                setOfDeclarationDirectories.add(host.toPath(declarationDir));
-              }
-            }
-          });
-        }
-        return fileOrDirectoryExistsUsingSource(
-          path,
-          /*isFile*/
-          false
-        );
-      };
-    }
-    if (originalGetDirectories) {
-      host.compilerHost.getDirectories = (path) => !host.getResolvedProjectReferences() || originalDirectoryExists && originalDirectoryExists.call(host.compilerHost, path) ? originalGetDirectories.call(host.compilerHost, path) : [];
-    }
-    if (originalRealpath) {
-      host.compilerHost.realpath = (s) => {
-        var _a;
-        return ((_a = host.getSymlinkCache().getSymlinkedFiles()) == null ? void 0 : _a.get(host.toPath(s))) || originalRealpath.call(host.compilerHost, s);
-      };
-    }
-    return { onProgramCreateComplete, fileExists, directoryExists };
-    function onProgramCreateComplete() {
-      host.compilerHost.fileExists = originalFileExists;
-      host.compilerHost.directoryExists = originalDirectoryExists;
-      host.compilerHost.getDirectories = originalGetDirectories;
-    }
-    function fileExists(file) {
-      if (originalFileExists.call(host.compilerHost, file))
-        return true;
-      if (!host.getResolvedProjectReferences())
-        return false;
-      if (!isDeclarationFileName(file))
-        return false;
-      return fileOrDirectoryExistsUsingSource(
-        file,
-        /*isFile*/
-        true
-      );
-    }
-    function fileExistsIfProjectReferenceDts(file) {
-      const source = host.getSourceOfProjectReferenceRedirect(host.toPath(file));
-      return source !== void 0 ? isString(source) ? originalFileExists.call(host.compilerHost, source) : true : void 0;
-    }
-    function directoryExistsIfProjectReferenceDeclDir(dir) {
-      const dirPath = host.toPath(dir);
-      const dirPathWithTrailingDirectorySeparator = `${dirPath}${directorySeparator}`;
-      return forEachKey(
-        setOfDeclarationDirectories,
-        (declDirPath) => dirPath === declDirPath || // Any parent directory of declaration dir
-        startsWith(declDirPath, dirPathWithTrailingDirectorySeparator) || // Any directory inside declaration dir
-        startsWith(dirPath, `${declDirPath}/`)
-      );
-    }
-    function handleDirectoryCouldBeSymlink(directory) {
-      var _a;
-      if (!host.getResolvedProjectReferences() || containsIgnoredPath(directory))
-        return;
-      if (!originalRealpath || !stringContains(directory, nodeModulesPathPart))
-        return;
-      const symlinkCache = host.getSymlinkCache();
-      const directoryPath = ensureTrailingDirectorySeparator(host.toPath(directory));
-      if ((_a = symlinkCache.getSymlinkedDirectories()) == null ? void 0 : _a.has(directoryPath))
-        return;
-      const real = normalizePath(originalRealpath.call(host.compilerHost, directory));
-      let realPath2;
-      if (real === directory || (realPath2 = ensureTrailingDirectorySeparator(host.toPath(real))) === directoryPath) {
-        symlinkCache.setSymlinkedDirectory(directoryPath, false);
-        return;
-      }
-      symlinkCache.setSymlinkedDirectory(directory, {
-        real: ensureTrailingDirectorySeparator(real),
-        realPath: realPath2
-      });
-    }
-    function fileOrDirectoryExistsUsingSource(fileOrDirectory, isFile) {
-      var _a;
-      const fileOrDirectoryExistsUsingSource2 = isFile ? (file) => fileExistsIfProjectReferenceDts(file) : (dir) => directoryExistsIfProjectReferenceDeclDir(dir);
-      const result = fileOrDirectoryExistsUsingSource2(fileOrDirectory);
-      if (result !== void 0)
-        return result;
-      const symlinkCache = host.getSymlinkCache();
-      const symlinkedDirectories = symlinkCache.getSymlinkedDirectories();
-      if (!symlinkedDirectories)
-        return false;
-      const fileOrDirectoryPath = host.toPath(fileOrDirectory);
-      if (!stringContains(fileOrDirectoryPath, nodeModulesPathPart))
-        return false;
-      if (isFile && ((_a = symlinkCache.getSymlinkedFiles()) == null ? void 0 : _a.has(fileOrDirectoryPath)))
-        return true;
-      return firstDefinedIterator(
-        symlinkedDirectories.entries(),
-        ([directoryPath, symlinkedDirectory]) => {
-          if (!symlinkedDirectory || !startsWith(fileOrDirectoryPath, directoryPath))
-            return void 0;
-          const result2 = fileOrDirectoryExistsUsingSource2(fileOrDirectoryPath.replace(directoryPath, symlinkedDirectory.realPath));
-          if (isFile && result2) {
-            const absolutePath = getNormalizedAbsolutePath(fileOrDirectory, host.compilerHost.getCurrentDirectory());
-            symlinkCache.setSymlinkedFile(
-              fileOrDirectoryPath,
-              `${symlinkedDirectory.real}${absolutePath.replace(new RegExp(directoryPath, "i"), "")}`
-            );
-          }
-          return result2;
-        }
-      ) || false;
-    }
-  }
-  function handleNoEmitOptions(program, sourceFile, writeFile2, cancellationToken) {
-    const options = program.getCompilerOptions();
-    if (options.noEmit) {
-      program.getSemanticDiagnostics(sourceFile, cancellationToken);
-      return sourceFile || outFile(options) ? emitSkippedWithNoDiagnostics : program.emitBuildInfo(writeFile2, cancellationToken);
-    }
-    if (!options.noEmitOnError)
-      return void 0;
-    let diagnostics = [
-      ...program.getOptionsDiagnostics(cancellationToken),
-      ...program.getSyntacticDiagnostics(sourceFile, cancellationToken),
-      ...program.getGlobalDiagnostics(cancellationToken),
-      ...program.getSemanticDiagnostics(sourceFile, cancellationToken)
-    ];
-    if (diagnostics.length === 0 && getEmitDeclarations(program.getCompilerOptions())) {
-      diagnostics = program.getDeclarationDiagnostics(
-        /*sourceFile*/
-        void 0,
-        cancellationToken
-      );
-    }
-    if (!diagnostics.length)
-      return void 0;
-    let emittedFiles;
-    if (!sourceFile && !outFile(options)) {
-      const emitResult = program.emitBuildInfo(writeFile2, cancellationToken);
-      if (emitResult.diagnostics)
-        diagnostics = [...diagnostics, ...emitResult.diagnostics];
-      emittedFiles = emitResult.emittedFiles;
-    }
-    return { diagnostics, sourceMaps: void 0, emittedFiles, emitSkipped: true };
-  }
-  function filterSemanticDiagnostics(diagnostic, option) {
-    return filter(diagnostic, (d) => !d.skippedOn || !option[d.skippedOn]);
-  }
-  function parseConfigHostFromCompilerHostLike(host, directoryStructureHost = host) {
-    return {
-      fileExists: (f) => directoryStructureHost.fileExists(f),
-      readDirectory(root, extensions, excludes, includes, depth) {
-        Debug.assertIsDefined(directoryStructureHost.readDirectory, "'CompilerHost.readDirectory' must be implemented to correctly process 'projectReferences'");
-        return directoryStructureHost.readDirectory(root, extensions, excludes, includes, depth);
-      },
-      readFile: (f) => directoryStructureHost.readFile(f),
-      useCaseSensitiveFileNames: host.useCaseSensitiveFileNames(),
-      getCurrentDirectory: () => host.getCurrentDirectory(),
-      onUnRecoverableConfigFileDiagnostic: host.onUnRecoverableConfigFileDiagnostic || returnUndefined,
-      trace: host.trace ? (s) => host.trace(s) : void 0
-    };
-  }
-  function createPrependNodes(projectReferences, getCommandLine, readFile, host) {
-    if (!projectReferences)
-      return emptyArray;
-    let nodes;
-    for (let i = 0; i < projectReferences.length; i++) {
-      const ref = projectReferences[i];
-      const resolvedRefOpts = getCommandLine(ref, i);
-      if (ref.prepend && resolvedRefOpts && resolvedRefOpts.options) {
-        const out = outFile(resolvedRefOpts.options);
-        if (!out)
-          continue;
-        const { jsFilePath, sourceMapFilePath, declarationFilePath, declarationMapPath, buildInfoPath } = getOutputPathsForBundle(
-          resolvedRefOpts.options,
-          /*forceDtsPaths*/
-          true
-        );
-        const node = createInputFilesWithFilePaths(readFile, jsFilePath, sourceMapFilePath, declarationFilePath, declarationMapPath, buildInfoPath, host, resolvedRefOpts.options);
-        (nodes || (nodes = [])).push(node);
-      }
-    }
-    return nodes || emptyArray;
-  }
-  function resolveProjectReferencePath(ref) {
-    return resolveConfigFileProjectName(ref.path);
-  }
-  function getResolutionDiagnostic(options, { extension }, { isDeclarationFile }) {
-    switch (extension) {
-      case ".ts" /* Ts */:
-      case ".d.ts" /* Dts */:
-      case ".mts" /* Mts */:
-      case ".d.mts" /* Dmts */:
-      case ".cts" /* Cts */:
-      case ".d.cts" /* Dcts */:
-        return void 0;
-      case ".tsx" /* Tsx */:
-        return needJsx();
-      case ".jsx" /* Jsx */:
-        return needJsx() || needAllowJs();
-      case ".js" /* Js */:
-      case ".mjs" /* Mjs */:
-      case ".cjs" /* Cjs */:
-        return needAllowJs();
-      case ".json" /* Json */:
-        return needResolveJsonModule();
-      default:
-        return needAllowArbitraryExtensions();
-    }
-    function needJsx() {
-      return options.jsx ? void 0 : Diagnostics.Module_0_was_resolved_to_1_but_jsx_is_not_set;
-    }
-    function needAllowJs() {
-      return getAllowJSCompilerOption(options) || !getStrictOptionValue(options, "noImplicitAny") ? void 0 : Diagnostics.Could_not_find_a_declaration_file_for_module_0_1_implicitly_has_an_any_type;
-    }
-    function needResolveJsonModule() {
-      return getResolveJsonModule(options) ? void 0 : Diagnostics.Module_0_was_resolved_to_1_but_resolveJsonModule_is_not_used;
-    }
-    function needAllowArbitraryExtensions() {
-      return isDeclarationFile || options.allowArbitraryExtensions ? void 0 : Diagnostics.Module_0_was_resolved_to_1_but_allowArbitraryExtensions_is_not_set;
-    }
-  }
-  function getModuleNames({ imports, moduleAugmentations }) {
-    const res = imports.map((i) => i);
-    for (const aug of moduleAugmentations) {
-      if (aug.kind === 11 /* StringLiteral */) {
-        res.push(aug);
-      }
-    }
-    return res;
-  }
-  function getModuleNameStringLiteralAt({ imports, moduleAugmentations }, index) {
-    if (index < imports.length)
-      return imports[index];
-    let augIndex = imports.length;
-    for (const aug of moduleAugmentations) {
-      if (aug.kind === 11 /* StringLiteral */) {
-        if (index === augIndex)
-          return aug;
-        augIndex++;
-      }
-    }
-    Debug.fail("should never ask for module name at index higher than possible module name");
-  }
-  var ForegroundColorEscapeSequences, gutterStyleSequence, gutterSeparator, resetEscapeSequence, ellipsis, halfIndent, indent, emptyResolution, moduleResolutionNameAndModeGetter, typeReferenceResolutionNameAndModeGetter, inferredTypesContainingFile, plainJSErrors, emitSkippedWithNoDiagnostics;
-  var init_program = __esm({
-    "src/compiler/program.ts"() {
-      "use strict";
-      init_ts2();
-      init_ts_performance();
-      ForegroundColorEscapeSequences = /* @__PURE__ */ ((ForegroundColorEscapeSequences2) => {
-        ForegroundColorEscapeSequences2["Grey"] = "\x1B[90m";
-        ForegroundColorEscapeSequences2["Red"] = "\x1B[91m";
-        ForegroundColorEscapeSequences2["Yellow"] = "\x1B[93m";
-        ForegroundColorEscapeSequences2["Blue"] = "\x1B[94m";
-        ForegroundColorEscapeSequences2["Cyan"] = "\x1B[96m";
-        return ForegroundColorEscapeSequences2;
-      })(ForegroundColorEscapeSequences || {});
-      gutterStyleSequence = "\x1B[7m";
-      gutterSeparator = " ";
-      resetEscapeSequence = "\x1B[0m";
-      ellipsis = "...";
-      halfIndent = "  ";
-      indent = "    ";
-      emptyResolution = {
-        resolvedModule: void 0,
-        resolvedTypeReferenceDirective: void 0
-      };
-      moduleResolutionNameAndModeGetter = {
-        getName: getModuleResolutionName,
-        getMode: (entry, file) => getModeForUsageLocation(file, entry)
-      };
-      typeReferenceResolutionNameAndModeGetter = {
-        getName: getTypeReferenceResolutionName,
-        getMode: (entry, file) => getModeForFileReference(entry, file == null ? void 0 : file.impliedNodeFormat)
-      };
-      inferredTypesContainingFile = "__inferred type names__.ts";
-      plainJSErrors = /* @__PURE__ */ new Set([
-        // binder errors
-        Diagnostics.Cannot_redeclare_block_scoped_variable_0.code,
-        Diagnostics.A_module_cannot_have_multiple_default_exports.code,
-        Diagnostics.Another_export_default_is_here.code,
-        Diagnostics.The_first_export_default_is_here.code,
-        Diagnostics.Identifier_expected_0_is_a_reserved_word_at_the_top_level_of_a_module.code,
-        Diagnostics.Identifier_expected_0_is_a_reserved_word_in_strict_mode_Modules_are_automatically_in_strict_mode.code,
-        Diagnostics.Identifier_expected_0_is_a_reserved_word_that_cannot_be_used_here.code,
-        Diagnostics.constructor_is_a_reserved_word.code,
-        Diagnostics.delete_cannot_be_called_on_an_identifier_in_strict_mode.code,
-        Diagnostics.Code_contained_in_a_class_is_evaluated_in_JavaScript_s_strict_mode_which_does_not_allow_this_use_of_0_For_more_information_see_https_Colon_Slash_Slashdeveloper_mozilla_org_Slashen_US_Slashdocs_SlashWeb_SlashJavaScript_SlashReference_SlashStrict_mode.code,
-        Diagnostics.Invalid_use_of_0_Modules_are_automatically_in_strict_mode.code,
-        Diagnostics.Invalid_use_of_0_in_strict_mode.code,
-        Diagnostics.A_label_is_not_allowed_here.code,
-        Diagnostics.with_statements_are_not_allowed_in_strict_mode.code,
-        // grammar errors
-        Diagnostics.A_break_statement_can_only_be_used_within_an_enclosing_iteration_or_switch_statement.code,
-        Diagnostics.A_break_statement_can_only_jump_to_a_label_of_an_enclosing_statement.code,
-        Diagnostics.A_class_declaration_without_the_default_modifier_must_have_a_name.code,
-        Diagnostics.A_class_member_cannot_have_the_0_keyword.code,
-        Diagnostics.A_comma_expression_is_not_allowed_in_a_computed_property_name.code,
-        Diagnostics.A_continue_statement_can_only_be_used_within_an_enclosing_iteration_statement.code,
-        Diagnostics.A_continue_statement_can_only_jump_to_a_label_of_an_enclosing_iteration_statement.code,
-        Diagnostics.A_continue_statement_can_only_jump_to_a_label_of_an_enclosing_iteration_statement.code,
-        Diagnostics.A_default_clause_cannot_appear_more_than_once_in_a_switch_statement.code,
-        Diagnostics.A_default_export_must_be_at_the_top_level_of_a_file_or_module_declaration.code,
-        Diagnostics.A_definite_assignment_assertion_is_not_permitted_in_this_context.code,
-        Diagnostics.A_destructuring_declaration_must_have_an_initializer.code,
-        Diagnostics.A_get_accessor_cannot_have_parameters.code,
-        Diagnostics.A_rest_element_cannot_contain_a_binding_pattern.code,
-        Diagnostics.A_rest_element_cannot_have_a_property_name.code,
-        Diagnostics.A_rest_element_cannot_have_an_initializer.code,
-        Diagnostics.A_rest_element_must_be_last_in_a_destructuring_pattern.code,
-        Diagnostics.A_rest_parameter_cannot_have_an_initializer.code,
-        Diagnostics.A_rest_parameter_must_be_last_in_a_parameter_list.code,
-        Diagnostics.A_rest_parameter_or_binding_pattern_may_not_have_a_trailing_comma.code,
-        Diagnostics.A_return_statement_cannot_be_used_inside_a_class_static_block.code,
-        Diagnostics.A_set_accessor_cannot_have_rest_parameter.code,
-        Diagnostics.A_set_accessor_must_have_exactly_one_parameter.code,
-        Diagnostics.An_export_declaration_can_only_be_used_at_the_top_level_of_a_module.code,
-        Diagnostics.An_export_declaration_cannot_have_modifiers.code,
-        Diagnostics.An_import_declaration_can_only_be_used_at_the_top_level_of_a_module.code,
-        Diagnostics.An_import_declaration_cannot_have_modifiers.code,
-        Diagnostics.An_object_member_cannot_be_declared_optional.code,
-        Diagnostics.Argument_of_dynamic_import_cannot_be_spread_element.code,
-        Diagnostics.Cannot_assign_to_private_method_0_Private_methods_are_not_writable.code,
-        Diagnostics.Cannot_redeclare_identifier_0_in_catch_clause.code,
-        Diagnostics.Catch_clause_variable_cannot_have_an_initializer.code,
-        Diagnostics.Class_decorators_can_t_be_used_with_static_private_identifier_Consider_removing_the_experimental_decorator.code,
-        Diagnostics.Classes_can_only_extend_a_single_class.code,
-        Diagnostics.Classes_may_not_have_a_field_named_constructor.code,
-        Diagnostics.Did_you_mean_to_use_a_Colon_An_can_only_follow_a_property_name_when_the_containing_object_literal_is_part_of_a_destructuring_pattern.code,
-        Diagnostics.Duplicate_label_0.code,
-        Diagnostics.Dynamic_imports_can_only_accept_a_module_specifier_and_an_optional_assertion_as_arguments.code,
-        Diagnostics.For_await_loops_cannot_be_used_inside_a_class_static_block.code,
-        Diagnostics.JSX_attributes_must_only_be_assigned_a_non_empty_expression.code,
-        Diagnostics.JSX_elements_cannot_have_multiple_attributes_with_the_same_name.code,
-        Diagnostics.JSX_expressions_may_not_use_the_comma_operator_Did_you_mean_to_write_an_array.code,
-        Diagnostics.JSX_property_access_expressions_cannot_include_JSX_namespace_names.code,
-        Diagnostics.Jump_target_cannot_cross_function_boundary.code,
-        Diagnostics.Line_terminator_not_permitted_before_arrow.code,
-        Diagnostics.Modifiers_cannot_appear_here.code,
-        Diagnostics.Only_a_single_variable_declaration_is_allowed_in_a_for_in_statement.code,
-        Diagnostics.Only_a_single_variable_declaration_is_allowed_in_a_for_of_statement.code,
-        Diagnostics.Private_identifiers_are_not_allowed_outside_class_bodies.code,
-        Diagnostics.Private_identifiers_are_only_allowed_in_class_bodies_and_may_only_be_used_as_part_of_a_class_member_declaration_property_access_or_on_the_left_hand_side_of_an_in_expression.code,
-        Diagnostics.Property_0_is_not_accessible_outside_class_1_because_it_has_a_private_identifier.code,
-        Diagnostics.Tagged_template_expressions_are_not_permitted_in_an_optional_chain.code,
-        Diagnostics.The_left_hand_side_of_a_for_of_statement_may_not_be_async.code,
-        Diagnostics.The_variable_declaration_of_a_for_in_statement_cannot_have_an_initializer.code,
-        Diagnostics.The_variable_declaration_of_a_for_of_statement_cannot_have_an_initializer.code,
-        Diagnostics.Trailing_comma_not_allowed.code,
-        Diagnostics.Variable_declaration_list_cannot_be_empty.code,
-        Diagnostics._0_and_1_operations_cannot_be_mixed_without_parentheses.code,
-        Diagnostics._0_expected.code,
-        Diagnostics._0_is_not_a_valid_meta_property_for_keyword_1_Did_you_mean_2.code,
-        Diagnostics._0_list_cannot_be_empty.code,
-        Diagnostics._0_modifier_already_seen.code,
-        Diagnostics._0_modifier_cannot_appear_on_a_constructor_declaration.code,
-        Diagnostics._0_modifier_cannot_appear_on_a_module_or_namespace_element.code,
-        Diagnostics._0_modifier_cannot_appear_on_a_parameter.code,
-        Diagnostics._0_modifier_cannot_appear_on_class_elements_of_this_kind.code,
-        Diagnostics._0_modifier_cannot_be_used_here.code,
-        Diagnostics._0_modifier_must_precede_1_modifier.code,
-        Diagnostics.const_declarations_can_only_be_declared_inside_a_block.code,
-        Diagnostics.const_declarations_must_be_initialized.code,
-        Diagnostics.extends_clause_already_seen.code,
-        Diagnostics.let_declarations_can_only_be_declared_inside_a_block.code,
-        Diagnostics.let_is_not_allowed_to_be_used_as_a_name_in_let_or_const_declarations.code,
-        Diagnostics.Class_constructor_may_not_be_a_generator.code,
-        Diagnostics.Class_constructor_may_not_be_an_accessor.code,
-        Diagnostics.await_expressions_are_only_allowed_within_async_functions_and_at_the_top_levels_of_modules.code
-      ]);
-      emitSkippedWithNoDiagnostics = { diagnostics: emptyArray, sourceMaps: void 0, emittedFiles: void 0, emitSkipped: true };
-    }
-  });
-
-  // src/compiler/builderStatePublic.ts
-  var init_builderStatePublic = __esm({
-    "src/compiler/builderStatePublic.ts"() {
-      "use strict";
-    }
-  });
-
-  // src/compiler/builderState.ts
-  function getFileEmitOutput(program, sourceFile, emitOnlyDtsFiles, cancellationToken, customTransformers, forceDtsEmit) {
-    const outputFiles = [];
-    const { emitSkipped, diagnostics } = program.emit(sourceFile, writeFile2, cancellationToken, emitOnlyDtsFiles, customTransformers, forceDtsEmit);
-    return { outputFiles, emitSkipped, diagnostics };
-    function writeFile2(fileName, text, writeByteOrderMark) {
-      outputFiles.push({ name: fileName, writeByteOrderMark, text });
-    }
-  }
-  var BuilderState;
-  var init_builderState = __esm({
-    "src/compiler/builderState.ts"() {
-      "use strict";
-      init_ts2();
-      ((BuilderState2) => {
-        function createManyToManyPathMap() {
-          function create2(forward, reverse, deleted) {
-            const map2 = {
-              getKeys: (v) => reverse.get(v),
-              getValues: (k) => forward.get(k),
-              keys: () => forward.keys(),
-              deleteKey: (k) => {
-                (deleted || (deleted = /* @__PURE__ */ new Set())).add(k);
-                const set = forward.get(k);
-                if (!set) {
-                  return false;
-                }
-                set.forEach((v) => deleteFromMultimap(reverse, v, k));
-                forward.delete(k);
-                return true;
-              },
-              set: (k, vSet) => {
-                deleted == null ? void 0 : deleted.delete(k);
-                const existingVSet = forward.get(k);
-                forward.set(k, vSet);
-                existingVSet == null ? void 0 : existingVSet.forEach((v) => {
-                  if (!vSet.has(v)) {
-                    deleteFromMultimap(reverse, v, k);
-                  }
-                });
-                vSet.forEach((v) => {
-                  if (!(existingVSet == null ? void 0 : existingVSet.has(v))) {
-                    addToMultimap(reverse, v, k);
-                  }
-                });
-                return map2;
-              }
-            };
-            return map2;
-          }
-          return create2(
-            /* @__PURE__ */ new Map(),
-            /* @__PURE__ */ new Map(),
-            /*deleted*/
-            void 0
-          );
-        }
-        BuilderState2.createManyToManyPathMap = createManyToManyPathMap;
-        function addToMultimap(map2, k, v) {
-          let set = map2.get(k);
-          if (!set) {
-            set = /* @__PURE__ */ new Set();
-            map2.set(k, set);
-          }
-          set.add(v);
-        }
-        function deleteFromMultimap(map2, k, v) {
-          const set = map2.get(k);
-          if (set == null ? void 0 : set.delete(v)) {
-            if (!set.size) {
-              map2.delete(k);
-            }
-            return true;
-          }
-          return false;
-        }
-        function getReferencedFilesFromImportedModuleSymbol(symbol) {
-          return mapDefined(symbol.declarations, (declaration) => {
-            var _a;
-            return (_a = getSourceFileOfNode(declaration)) == null ? void 0 : _a.resolvedPath;
-          });
-        }
-        function getReferencedFilesFromImportLiteral(checker, importName) {
-          const symbol = checker.getSymbolAtLocation(importName);
-          return symbol && getReferencedFilesFromImportedModuleSymbol(symbol);
-        }
-        function getReferencedFileFromFileName(program, fileName, sourceFileDirectory, getCanonicalFileName) {
-          return toPath(program.getProjectReferenceRedirect(fileName) || fileName, sourceFileDirectory, getCanonicalFileName);
-        }
-        function getReferencedFiles(program, sourceFile, getCanonicalFileName) {
-          let referencedFiles;
-          if (sourceFile.imports && sourceFile.imports.length > 0) {
-            const checker = program.getTypeChecker();
-            for (const importName of sourceFile.imports) {
-              const declarationSourceFilePaths = getReferencedFilesFromImportLiteral(checker, importName);
-              declarationSourceFilePaths == null ? void 0 : declarationSourceFilePaths.forEach(addReferencedFile);
-            }
-          }
-          const sourceFileDirectory = getDirectoryPath(sourceFile.resolvedPath);
-          if (sourceFile.referencedFiles && sourceFile.referencedFiles.length > 0) {
-            for (const referencedFile of sourceFile.referencedFiles) {
-              const referencedPath = getReferencedFileFromFileName(program, referencedFile.fileName, sourceFileDirectory, getCanonicalFileName);
-              addReferencedFile(referencedPath);
-            }
-          }
-          if (sourceFile.resolvedTypeReferenceDirectiveNames) {
-            sourceFile.resolvedTypeReferenceDirectiveNames.forEach(({ resolvedTypeReferenceDirective }) => {
-              if (!resolvedTypeReferenceDirective) {
-                return;
-              }
-              const fileName = resolvedTypeReferenceDirective.resolvedFileName;
-              const typeFilePath = getReferencedFileFromFileName(program, fileName, sourceFileDirectory, getCanonicalFileName);
-              addReferencedFile(typeFilePath);
-            });
-          }
-          if (sourceFile.moduleAugmentations.length) {
-            const checker = program.getTypeChecker();
-            for (const moduleName of sourceFile.moduleAugmentations) {
-              if (!isStringLiteral(moduleName))
-                continue;
-              const symbol = checker.getSymbolAtLocation(moduleName);
-              if (!symbol)
-                continue;
-              addReferenceFromAmbientModule(symbol);
-            }
-          }
-          for (const ambientModule of program.getTypeChecker().getAmbientModules()) {
-            if (ambientModule.declarations && ambientModule.declarations.length > 1) {
-              addReferenceFromAmbientModule(ambientModule);
-            }
-          }
-          return referencedFiles;
-          function addReferenceFromAmbientModule(symbol) {
-            if (!symbol.declarations) {
-              return;
-            }
-            for (const declaration of symbol.declarations) {
-              const declarationSourceFile = getSourceFileOfNode(declaration);
-              if (declarationSourceFile && declarationSourceFile !== sourceFile) {
-                addReferencedFile(declarationSourceFile.resolvedPath);
-              }
-            }
-          }
-          function addReferencedFile(referencedPath) {
-            (referencedFiles || (referencedFiles = /* @__PURE__ */ new Set())).add(referencedPath);
-          }
-        }
-        function canReuseOldState(newReferencedMap, oldState) {
-          return oldState && !oldState.referencedMap === !newReferencedMap;
-        }
-        BuilderState2.canReuseOldState = canReuseOldState;
-        function create(newProgram, oldState, disableUseFileVersionAsSignature) {
-          var _a, _b, _c;
-          const fileInfos = /* @__PURE__ */ new Map();
-          const options = newProgram.getCompilerOptions();
-          const isOutFile = outFile(options);
-          const referencedMap = options.module !== 0 /* None */ && !isOutFile ? createManyToManyPathMap() : void 0;
-          const exportedModulesMap = referencedMap ? createManyToManyPathMap() : void 0;
-          const useOldState = canReuseOldState(referencedMap, oldState);
-          newProgram.getTypeChecker();
-          for (const sourceFile of newProgram.getSourceFiles()) {
-            const version2 = Debug.checkDefined(sourceFile.version, "Program intended to be used with Builder should have source files with versions set");
-            const oldUncommittedSignature = useOldState ? (_a = oldState.oldSignatures) == null ? void 0 : _a.get(sourceFile.resolvedPath) : void 0;
-            const signature = oldUncommittedSignature === void 0 ? useOldState ? (_b = oldState.fileInfos.get(sourceFile.resolvedPath)) == null ? void 0 : _b.signature : void 0 : oldUncommittedSignature || void 0;
-            if (referencedMap) {
-              const newReferences = getReferencedFiles(newProgram, sourceFile, newProgram.getCanonicalFileName);
-              if (newReferences) {
-                referencedMap.set(sourceFile.resolvedPath, newReferences);
-              }
-              if (useOldState) {
-                const oldUncommittedExportedModules = (_c = oldState.oldExportedModulesMap) == null ? void 0 : _c.get(sourceFile.resolvedPath);
-                const exportedModules = oldUncommittedExportedModules === void 0 ? oldState.exportedModulesMap.getValues(sourceFile.resolvedPath) : oldUncommittedExportedModules || void 0;
-                if (exportedModules) {
-                  exportedModulesMap.set(sourceFile.resolvedPath, exportedModules);
-                }
-              }
-            }
-            fileInfos.set(sourceFile.resolvedPath, {
-              version: version2,
-              signature,
-              // No need to calculate affectsGlobalScope with --out since its not used at all
-              affectsGlobalScope: !isOutFile ? isFileAffectingGlobalScope(sourceFile) || void 0 : void 0,
-              impliedFormat: sourceFile.impliedNodeFormat
-            });
-          }
-          return {
-            fileInfos,
-            referencedMap,
-            exportedModulesMap,
-            useFileVersionAsSignature: !disableUseFileVersionAsSignature && !useOldState
-          };
-        }
-        BuilderState2.create = create;
-        function releaseCache2(state) {
-          state.allFilesExcludingDefaultLibraryFile = void 0;
-          state.allFileNames = void 0;
-        }
-        BuilderState2.releaseCache = releaseCache2;
-        function getFilesAffectedBy(state, programOfThisState, path, cancellationToken, host) {
-          var _a, _b;
-          const result = getFilesAffectedByWithOldState(
-            state,
-            programOfThisState,
-            path,
-            cancellationToken,
-            host
-          );
-          (_a = state.oldSignatures) == null ? void 0 : _a.clear();
-          (_b = state.oldExportedModulesMap) == null ? void 0 : _b.clear();
-          return result;
-        }
-        BuilderState2.getFilesAffectedBy = getFilesAffectedBy;
-        function getFilesAffectedByWithOldState(state, programOfThisState, path, cancellationToken, host) {
-          const sourceFile = programOfThisState.getSourceFileByPath(path);
-          if (!sourceFile) {
-            return emptyArray;
-          }
-          if (!updateShapeSignature(state, programOfThisState, sourceFile, cancellationToken, host)) {
-            return [sourceFile];
-          }
-          return (state.referencedMap ? getFilesAffectedByUpdatedShapeWhenModuleEmit : getFilesAffectedByUpdatedShapeWhenNonModuleEmit)(state, programOfThisState, sourceFile, cancellationToken, host);
-        }
-        BuilderState2.getFilesAffectedByWithOldState = getFilesAffectedByWithOldState;
-        function updateSignatureOfFile(state, signature, path) {
-          state.fileInfos.get(path).signature = signature;
-          (state.hasCalledUpdateShapeSignature || (state.hasCalledUpdateShapeSignature = /* @__PURE__ */ new Set())).add(path);
-        }
-        BuilderState2.updateSignatureOfFile = updateSignatureOfFile;
-        function computeDtsSignature(programOfThisState, sourceFile, cancellationToken, host, onNewSignature) {
-          programOfThisState.emit(
-            sourceFile,
-            (fileName, text, _writeByteOrderMark, _onError, sourceFiles, data) => {
-              Debug.assert(isDeclarationFileName(fileName), `File extension for signature expected to be dts: Got:: ${fileName}`);
-              onNewSignature(computeSignatureWithDiagnostics(
-                programOfThisState,
-                sourceFile,
-                text,
-                host,
-                data
-              ), sourceFiles);
-            },
-            cancellationToken,
-            /*emitOnly*/
-            true,
-            /*customTransformers*/
-            void 0,
-            /*forceDtsEmit*/
-            true
-          );
-        }
-        BuilderState2.computeDtsSignature = computeDtsSignature;
-        function updateShapeSignature(state, programOfThisState, sourceFile, cancellationToken, host, useFileVersionAsSignature = state.useFileVersionAsSignature) {
-          var _a;
-          if ((_a = state.hasCalledUpdateShapeSignature) == null ? void 0 : _a.has(sourceFile.resolvedPath))
-            return false;
-          const info = state.fileInfos.get(sourceFile.resolvedPath);
-          const prevSignature = info.signature;
-          let latestSignature;
-          if (!sourceFile.isDeclarationFile && !useFileVersionAsSignature) {
-            computeDtsSignature(programOfThisState, sourceFile, cancellationToken, host, (signature, sourceFiles) => {
-              latestSignature = signature;
-              if (latestSignature !== prevSignature) {
-                updateExportedModules(state, sourceFile, sourceFiles[0].exportedModulesFromDeclarationEmit);
-              }
-            });
-          }
-          if (latestSignature === void 0) {
-            latestSignature = sourceFile.version;
-            if (state.exportedModulesMap && latestSignature !== prevSignature) {
-              (state.oldExportedModulesMap || (state.oldExportedModulesMap = /* @__PURE__ */ new Map())).set(sourceFile.resolvedPath, state.exportedModulesMap.getValues(sourceFile.resolvedPath) || false);
-              const references = state.referencedMap ? state.referencedMap.getValues(sourceFile.resolvedPath) : void 0;
-              if (references) {
-                state.exportedModulesMap.set(sourceFile.resolvedPath, references);
-              } else {
-                state.exportedModulesMap.deleteKey(sourceFile.resolvedPath);
-              }
-            }
-          }
-          (state.oldSignatures || (state.oldSignatures = /* @__PURE__ */ new Map())).set(sourceFile.resolvedPath, prevSignature || false);
-          (state.hasCalledUpdateShapeSignature || (state.hasCalledUpdateShapeSignature = /* @__PURE__ */ new Set())).add(sourceFile.resolvedPath);
-          info.signature = latestSignature;
-          return latestSignature !== prevSignature;
-        }
-        BuilderState2.updateShapeSignature = updateShapeSignature;
-        function updateExportedModules(state, sourceFile, exportedModulesFromDeclarationEmit) {
-          if (!state.exportedModulesMap)
-            return;
-          (state.oldExportedModulesMap || (state.oldExportedModulesMap = /* @__PURE__ */ new Map())).set(sourceFile.resolvedPath, state.exportedModulesMap.getValues(sourceFile.resolvedPath) || false);
-          const exportedModules = getExportedModules(exportedModulesFromDeclarationEmit);
-          if (exportedModules) {
-            state.exportedModulesMap.set(sourceFile.resolvedPath, exportedModules);
-          } else {
-            state.exportedModulesMap.deleteKey(sourceFile.resolvedPath);
-          }
-        }
-        BuilderState2.updateExportedModules = updateExportedModules;
-        function getExportedModules(exportedModulesFromDeclarationEmit) {
-          let exportedModules;
-          exportedModulesFromDeclarationEmit == null ? void 0 : exportedModulesFromDeclarationEmit.forEach(
-            (symbol) => getReferencedFilesFromImportedModuleSymbol(symbol).forEach(
-              (path) => (exportedModules ?? (exportedModules = /* @__PURE__ */ new Set())).add(path)
-            )
-          );
-          return exportedModules;
-        }
-        BuilderState2.getExportedModules = getExportedModules;
-        function getAllDependencies(state, programOfThisState, sourceFile) {
-          const compilerOptions = programOfThisState.getCompilerOptions();
-          if (outFile(compilerOptions)) {
-            return getAllFileNames(state, programOfThisState);
-          }
-          if (!state.referencedMap || isFileAffectingGlobalScope(sourceFile)) {
-            return getAllFileNames(state, programOfThisState);
-          }
-          const seenMap = /* @__PURE__ */ new Set();
-          const queue = [sourceFile.resolvedPath];
-          while (queue.length) {
-            const path = queue.pop();
-            if (!seenMap.has(path)) {
-              seenMap.add(path);
-              const references = state.referencedMap.getValues(path);
-              if (references) {
-                for (const key of references.keys()) {
-                  queue.push(key);
-                }
-              }
-            }
-          }
-          return arrayFrom(mapDefinedIterator(seenMap.keys(), (path) => {
-            var _a;
-            return ((_a = programOfThisState.getSourceFileByPath(path)) == null ? void 0 : _a.fileName) ?? path;
-          }));
-        }
-        BuilderState2.getAllDependencies = getAllDependencies;
-        function getAllFileNames(state, programOfThisState) {
-          if (!state.allFileNames) {
-            const sourceFiles = programOfThisState.getSourceFiles();
-            state.allFileNames = sourceFiles === emptyArray ? emptyArray : sourceFiles.map((file) => file.fileName);
-          }
-          return state.allFileNames;
-        }
-        function getReferencedByPaths(state, referencedFilePath) {
-          const keys = state.referencedMap.getKeys(referencedFilePath);
-          return keys ? arrayFrom(keys.keys()) : [];
-        }
-        BuilderState2.getReferencedByPaths = getReferencedByPaths;
-        function containsOnlyAmbientModules(sourceFile) {
-          for (const statement of sourceFile.statements) {
-            if (!isModuleWithStringLiteralName(statement)) {
-              return false;
-            }
-          }
-          return true;
-        }
-        function containsGlobalScopeAugmentation(sourceFile) {
-          return some(sourceFile.moduleAugmentations, (augmentation) => isGlobalScopeAugmentation(augmentation.parent));
-        }
-        function isFileAffectingGlobalScope(sourceFile) {
-          return containsGlobalScopeAugmentation(sourceFile) || !isExternalOrCommonJsModule(sourceFile) && !isJsonSourceFile(sourceFile) && !containsOnlyAmbientModules(sourceFile);
-        }
-        function getAllFilesExcludingDefaultLibraryFile(state, programOfThisState, firstSourceFile) {
-          if (state.allFilesExcludingDefaultLibraryFile) {
-            return state.allFilesExcludingDefaultLibraryFile;
-          }
-          let result;
-          if (firstSourceFile)
-            addSourceFile(firstSourceFile);
-          for (const sourceFile of programOfThisState.getSourceFiles()) {
-            if (sourceFile !== firstSourceFile) {
-              addSourceFile(sourceFile);
-            }
-          }
-          state.allFilesExcludingDefaultLibraryFile = result || emptyArray;
-          return state.allFilesExcludingDefaultLibraryFile;
-          function addSourceFile(sourceFile) {
-            if (!programOfThisState.isSourceFileDefaultLibrary(sourceFile)) {
-              (result || (result = [])).push(sourceFile);
-            }
-          }
-        }
-        BuilderState2.getAllFilesExcludingDefaultLibraryFile = getAllFilesExcludingDefaultLibraryFile;
-        function getFilesAffectedByUpdatedShapeWhenNonModuleEmit(state, programOfThisState, sourceFileWithUpdatedShape) {
-          const compilerOptions = programOfThisState.getCompilerOptions();
-          if (compilerOptions && outFile(compilerOptions)) {
-            return [sourceFileWithUpdatedShape];
-          }
-          return getAllFilesExcludingDefaultLibraryFile(state, programOfThisState, sourceFileWithUpdatedShape);
-        }
-        function getFilesAffectedByUpdatedShapeWhenModuleEmit(state, programOfThisState, sourceFileWithUpdatedShape, cancellationToken, host) {
-          if (isFileAffectingGlobalScope(sourceFileWithUpdatedShape)) {
-            return getAllFilesExcludingDefaultLibraryFile(state, programOfThisState, sourceFileWithUpdatedShape);
-          }
-          const compilerOptions = programOfThisState.getCompilerOptions();
-          if (compilerOptions && (getIsolatedModules(compilerOptions) || outFile(compilerOptions))) {
-            return [sourceFileWithUpdatedShape];
-          }
-          const seenFileNamesMap = /* @__PURE__ */ new Map();
-          seenFileNamesMap.set(sourceFileWithUpdatedShape.resolvedPath, sourceFileWithUpdatedShape);
-          const queue = getReferencedByPaths(state, sourceFileWithUpdatedShape.resolvedPath);
-          while (queue.length > 0) {
-            const currentPath = queue.pop();
-            if (!seenFileNamesMap.has(currentPath)) {
-              const currentSourceFile = programOfThisState.getSourceFileByPath(currentPath);
-              seenFileNamesMap.set(currentPath, currentSourceFile);
-              if (currentSourceFile && updateShapeSignature(state, programOfThisState, currentSourceFile, cancellationToken, host)) {
-                queue.push(...getReferencedByPaths(state, currentSourceFile.resolvedPath));
-              }
-            }
-          }
-          return arrayFrom(mapDefinedIterator(seenFileNamesMap.values(), (value) => value));
-        }
-      })(BuilderState || (BuilderState = {}));
-    }
-  });
-
-  // src/compiler/builder.ts
-  function getBuilderFileEmit(options) {
-    let result = 1 /* Js */;
-    if (options.sourceMap)
-      result = result | 2 /* JsMap */;
-    if (options.inlineSourceMap)
-      result = result | 4 /* JsInlineMap */;
-    if (getEmitDeclarations(options))
-      result = result | 8 /* Dts */;
-    if (options.declarationMap)
-      result = result | 16 /* DtsMap */;
-    if (options.emitDeclarationOnly)
-      result = result & 24 /* AllDts */;
-    return result;
-  }
-  function getPendingEmitKind(optionsOrEmitKind, oldOptionsOrEmitKind) {
-    const oldEmitKind = oldOptionsOrEmitKind && (isNumber(oldOptionsOrEmitKind) ? oldOptionsOrEmitKind : getBuilderFileEmit(oldOptionsOrEmitKind));
-    const emitKind = isNumber(optionsOrEmitKind) ? optionsOrEmitKind : getBuilderFileEmit(optionsOrEmitKind);
-    if (oldEmitKind === emitKind)
-      return 0 /* None */;
-    if (!oldEmitKind || !emitKind)
-      return emitKind;
-    const diff = oldEmitKind ^ emitKind;
-    let result = 0 /* None */;
-    if (diff & 7 /* AllJs */)
-      result = emitKind & 7 /* AllJs */;
-    if (diff & 24 /* AllDts */)
-      result = result | emitKind & 24 /* AllDts */;
-    return result;
-  }
-  function hasSameKeys(map1, map2) {
-    return map1 === map2 || map1 !== void 0 && map2 !== void 0 && map1.size === map2.size && !forEachKey(map1, (key) => !map2.has(key));
-  }
-  function createBuilderProgramState(newProgram, oldState) {
-    var _a, _b;
-    const state = BuilderState.create(
-      newProgram,
-      oldState,
-      /*disableUseFileVersionAsSignature*/
-      false
-    );
-    state.program = newProgram;
-    const compilerOptions = newProgram.getCompilerOptions();
-    state.compilerOptions = compilerOptions;
-    const outFilePath = outFile(compilerOptions);
-    if (!outFilePath) {
-      state.semanticDiagnosticsPerFile = /* @__PURE__ */ new Map();
-    } else if (compilerOptions.composite && (oldState == null ? void 0 : oldState.outSignature) && outFilePath === outFile(oldState == null ? void 0 : oldState.compilerOptions)) {
-      state.outSignature = oldState.outSignature && getEmitSignatureFromOldSignature(compilerOptions, oldState.compilerOptions, oldState.outSignature);
-    }
-    state.changedFilesSet = /* @__PURE__ */ new Set();
-    state.latestChangedDtsFile = compilerOptions.composite ? oldState == null ? void 0 : oldState.latestChangedDtsFile : void 0;
-    const useOldState = BuilderState.canReuseOldState(state.referencedMap, oldState);
-    const oldCompilerOptions = useOldState ? oldState.compilerOptions : void 0;
-    const canCopySemanticDiagnostics = useOldState && oldState.semanticDiagnosticsPerFile && !!state.semanticDiagnosticsPerFile && !compilerOptionsAffectSemanticDiagnostics(compilerOptions, oldCompilerOptions);
-    const canCopyEmitSignatures = compilerOptions.composite && (oldState == null ? void 0 : oldState.emitSignatures) && !outFilePath && !compilerOptionsAffectDeclarationPath(compilerOptions, oldState.compilerOptions);
-    if (useOldState) {
-      (_a = oldState.changedFilesSet) == null ? void 0 : _a.forEach((value) => state.changedFilesSet.add(value));
-      if (!outFilePath && ((_b = oldState.affectedFilesPendingEmit) == null ? void 0 : _b.size)) {
-        state.affectedFilesPendingEmit = new Map(oldState.affectedFilesPendingEmit);
-        state.seenAffectedFiles = /* @__PURE__ */ new Set();
-      }
-      state.programEmitPending = oldState.programEmitPending;
-    } else {
-      state.buildInfoEmitPending = true;
-    }
-    const referencedMap = state.referencedMap;
-    const oldReferencedMap = useOldState ? oldState.referencedMap : void 0;
-    const copyDeclarationFileDiagnostics = canCopySemanticDiagnostics && !compilerOptions.skipLibCheck === !oldCompilerOptions.skipLibCheck;
-    const copyLibFileDiagnostics = copyDeclarationFileDiagnostics && !compilerOptions.skipDefaultLibCheck === !oldCompilerOptions.skipDefaultLibCheck;
-    state.fileInfos.forEach((info, sourceFilePath) => {
-      let oldInfo;
-      let newReferences;
-      if (!useOldState || // File wasn't present in old state
-      !(oldInfo = oldState.fileInfos.get(sourceFilePath)) || // versions dont match
-      oldInfo.version !== info.version || // Implied formats dont match
-      oldInfo.impliedFormat !== info.impliedFormat || // Referenced files changed
-      !hasSameKeys(newReferences = referencedMap && referencedMap.getValues(sourceFilePath), oldReferencedMap && oldReferencedMap.getValues(sourceFilePath)) || // Referenced file was deleted in the new program
-      newReferences && forEachKey(newReferences, (path) => !state.fileInfos.has(path) && oldState.fileInfos.has(path))) {
-        addFileToChangeSet(state, sourceFilePath);
-      } else if (canCopySemanticDiagnostics) {
-        const sourceFile = newProgram.getSourceFileByPath(sourceFilePath);
-        if (sourceFile.isDeclarationFile && !copyDeclarationFileDiagnostics)
-          return;
-        if (sourceFile.hasNoDefaultLib && !copyLibFileDiagnostics)
-          return;
-        const diagnostics = oldState.semanticDiagnosticsPerFile.get(sourceFilePath);
-        if (diagnostics) {
-          state.semanticDiagnosticsPerFile.set(
-            sourceFilePath,
-            oldState.hasReusableDiagnostic ? convertToDiagnostics(diagnostics, newProgram) : repopulateDiagnostics(diagnostics, newProgram)
-          );
-          if (!state.semanticDiagnosticsFromOldState) {
-            state.semanticDiagnosticsFromOldState = /* @__PURE__ */ new Set();
-          }
-          state.semanticDiagnosticsFromOldState.add(sourceFilePath);
-        }
-      }
-      if (canCopyEmitSignatures) {
-        const oldEmitSignature = oldState.emitSignatures.get(sourceFilePath);
-        if (oldEmitSignature) {
-          (state.emitSignatures ?? (state.emitSignatures = /* @__PURE__ */ new Map())).set(sourceFilePath, getEmitSignatureFromOldSignature(compilerOptions, oldState.compilerOptions, oldEmitSignature));
-        }
-      }
-    });
-    if (useOldState && forEachEntry(oldState.fileInfos, (info, sourceFilePath) => {
-      if (state.fileInfos.has(sourceFilePath))
-        return false;
-      if (outFilePath || info.affectsGlobalScope)
-        return true;
-      state.buildInfoEmitPending = true;
-      return false;
-    })) {
-      BuilderState.getAllFilesExcludingDefaultLibraryFile(
-        state,
-        newProgram,
-        /*firstSourceFile*/
-        void 0
-      ).forEach((file) => addFileToChangeSet(state, file.resolvedPath));
-    } else if (oldCompilerOptions) {
-      const pendingEmitKind = compilerOptionsAffectEmit(compilerOptions, oldCompilerOptions) ? getBuilderFileEmit(compilerOptions) : getPendingEmitKind(compilerOptions, oldCompilerOptions);
-      if (pendingEmitKind !== 0 /* None */) {
-        if (!outFilePath) {
-          newProgram.getSourceFiles().forEach((f) => {
-            if (!state.changedFilesSet.has(f.resolvedPath)) {
-              addToAffectedFilesPendingEmit(
-                state,
-                f.resolvedPath,
-                pendingEmitKind
-              );
-            }
-          });
-          Debug.assert(!state.seenAffectedFiles || !state.seenAffectedFiles.size);
-          state.seenAffectedFiles = state.seenAffectedFiles || /* @__PURE__ */ new Set();
-          state.buildInfoEmitPending = true;
-        } else {
-          state.programEmitPending = state.programEmitPending ? state.programEmitPending | pendingEmitKind : pendingEmitKind;
-        }
-      }
-    }
-    if (outFilePath && !state.changedFilesSet.size) {
-      if (useOldState)
-        state.bundle = oldState.bundle;
-      if (some(newProgram.getProjectReferences(), (ref) => !!ref.prepend))
-        state.programEmitPending = getBuilderFileEmit(compilerOptions);
-    }
-    return state;
-  }
-  function addFileToChangeSet(state, path) {
-    state.changedFilesSet.add(path);
-    state.buildInfoEmitPending = true;
-    state.programEmitPending = void 0;
-  }
-  function getEmitSignatureFromOldSignature(options, oldOptions, oldEmitSignature) {
-    return !!options.declarationMap === !!oldOptions.declarationMap ? (
-      // Use same format of signature
-      oldEmitSignature
-    ) : (
-      // Convert to different format
-      isString(oldEmitSignature) ? [oldEmitSignature] : oldEmitSignature[0]
-    );
-  }
-  function repopulateDiagnostics(diagnostics, newProgram) {
-    if (!diagnostics.length)
-      return diagnostics;
-    return sameMap(diagnostics, (diag2) => {
-      if (isString(diag2.messageText))
-        return diag2;
-      const repopulatedChain = convertOrRepopulateDiagnosticMessageChain(diag2.messageText, diag2.file, newProgram, (chain) => {
-        var _a;
-        return (_a = chain.repopulateInfo) == null ? void 0 : _a.call(chain);
-      });
-      return repopulatedChain === diag2.messageText ? diag2 : { ...diag2, messageText: repopulatedChain };
-    });
-  }
-  function convertOrRepopulateDiagnosticMessageChain(chain, sourceFile, newProgram, repopulateInfo) {
-    const info = repopulateInfo(chain);
-    if (info) {
-      return {
-        ...createModuleNotFoundChain(sourceFile, newProgram, info.moduleReference, info.mode, info.packageName || info.moduleReference),
-        next: convertOrRepopulateDiagnosticMessageChainArray(chain.next, sourceFile, newProgram, repopulateInfo)
-      };
-    }
-    const next = convertOrRepopulateDiagnosticMessageChainArray(chain.next, sourceFile, newProgram, repopulateInfo);
-    return next === chain.next ? chain : { ...chain, next };
-  }
-  function convertOrRepopulateDiagnosticMessageChainArray(array, sourceFile, newProgram, repopulateInfo) {
-    return sameMap(array, (chain) => convertOrRepopulateDiagnosticMessageChain(chain, sourceFile, newProgram, repopulateInfo));
-  }
-  function convertToDiagnostics(diagnostics, newProgram) {
-    if (!diagnostics.length)
-      return emptyArray;
-    let buildInfoDirectory;
-    return diagnostics.map((diagnostic) => {
-      const result = convertToDiagnosticRelatedInformation(diagnostic, newProgram, toPathInBuildInfoDirectory);
-      result.reportsUnnecessary = diagnostic.reportsUnnecessary;
-      result.reportsDeprecated = diagnostic.reportDeprecated;
-      result.source = diagnostic.source;
-      result.skippedOn = diagnostic.skippedOn;
-      const { relatedInformation } = diagnostic;
-      result.relatedInformation = relatedInformation ? relatedInformation.length ? relatedInformation.map((r) => convertToDiagnosticRelatedInformation(r, newProgram, toPathInBuildInfoDirectory)) : [] : void 0;
-      return result;
-    });
-    function toPathInBuildInfoDirectory(path) {
-      buildInfoDirectory ?? (buildInfoDirectory = getDirectoryPath(getNormalizedAbsolutePath(getTsBuildInfoEmitOutputFilePath(newProgram.getCompilerOptions()), newProgram.getCurrentDirectory())));
-      return toPath(path, buildInfoDirectory, newProgram.getCanonicalFileName);
-    }
-  }
-  function convertToDiagnosticRelatedInformation(diagnostic, newProgram, toPath3) {
-    const { file } = diagnostic;
-    const sourceFile = file ? newProgram.getSourceFileByPath(toPath3(file)) : void 0;
-    return {
-      ...diagnostic,
-      file: sourceFile,
-      messageText: isString(diagnostic.messageText) ? diagnostic.messageText : convertOrRepopulateDiagnosticMessageChain(diagnostic.messageText, sourceFile, newProgram, (chain) => chain.info)
-    };
-  }
-  function releaseCache(state) {
-    BuilderState.releaseCache(state);
-    state.program = void 0;
-  }
-  function backupBuilderProgramEmitState(state) {
-    const outFilePath = outFile(state.compilerOptions);
-    Debug.assert(!state.changedFilesSet.size || outFilePath);
-    return {
-      affectedFilesPendingEmit: state.affectedFilesPendingEmit && new Map(state.affectedFilesPendingEmit),
-      seenEmittedFiles: state.seenEmittedFiles && new Map(state.seenEmittedFiles),
-      programEmitPending: state.programEmitPending,
-      emitSignatures: state.emitSignatures && new Map(state.emitSignatures),
-      outSignature: state.outSignature,
-      latestChangedDtsFile: state.latestChangedDtsFile,
-      hasChangedEmitSignature: state.hasChangedEmitSignature,
-      changedFilesSet: outFilePath ? new Set(state.changedFilesSet) : void 0
-    };
-  }
-  function restoreBuilderProgramEmitState(state, savedEmitState) {
-    state.affectedFilesPendingEmit = savedEmitState.affectedFilesPendingEmit;
-    state.seenEmittedFiles = savedEmitState.seenEmittedFiles;
-    state.programEmitPending = savedEmitState.programEmitPending;
-    state.emitSignatures = savedEmitState.emitSignatures;
-    state.outSignature = savedEmitState.outSignature;
-    state.latestChangedDtsFile = savedEmitState.latestChangedDtsFile;
-    state.hasChangedEmitSignature = savedEmitState.hasChangedEmitSignature;
-    if (savedEmitState.changedFilesSet)
-      state.changedFilesSet = savedEmitState.changedFilesSet;
-  }
-  function assertSourceFileOkWithoutNextAffectedCall(state, sourceFile) {
-    Debug.assert(!sourceFile || !state.affectedFiles || state.affectedFiles[state.affectedFilesIndex - 1] !== sourceFile || !state.semanticDiagnosticsPerFile.has(sourceFile.resolvedPath));
-  }
-  function getNextAffectedFile(state, cancellationToken, host) {
-    var _a, _b;
-    while (true) {
-      const { affectedFiles } = state;
-      if (affectedFiles) {
-        const seenAffectedFiles = state.seenAffectedFiles;
-        let affectedFilesIndex = state.affectedFilesIndex;
-        while (affectedFilesIndex < affectedFiles.length) {
-          const affectedFile = affectedFiles[affectedFilesIndex];
-          if (!seenAffectedFiles.has(affectedFile.resolvedPath)) {
-            state.affectedFilesIndex = affectedFilesIndex;
-            addToAffectedFilesPendingEmit(state, affectedFile.resolvedPath, getBuilderFileEmit(state.compilerOptions));
-            handleDtsMayChangeOfAffectedFile(
-              state,
-              affectedFile,
-              cancellationToken,
-              host
-            );
-            return affectedFile;
-          }
-          affectedFilesIndex++;
-        }
-        state.changedFilesSet.delete(state.currentChangedFilePath);
-        state.currentChangedFilePath = void 0;
-        (_a = state.oldSignatures) == null ? void 0 : _a.clear();
-        (_b = state.oldExportedModulesMap) == null ? void 0 : _b.clear();
-        state.affectedFiles = void 0;
-      }
-      const nextKey = state.changedFilesSet.keys().next();
-      if (nextKey.done) {
-        return void 0;
-      }
-      const program = Debug.checkDefined(state.program);
-      const compilerOptions = program.getCompilerOptions();
-      if (outFile(compilerOptions)) {
-        Debug.assert(!state.semanticDiagnosticsPerFile);
-        return program;
-      }
-      state.affectedFiles = BuilderState.getFilesAffectedByWithOldState(
-        state,
-        program,
-        nextKey.value,
-        cancellationToken,
-        host
-      );
-      state.currentChangedFilePath = nextKey.value;
-      state.affectedFilesIndex = 0;
-      if (!state.seenAffectedFiles)
-        state.seenAffectedFiles = /* @__PURE__ */ new Set();
-    }
-  }
-  function clearAffectedFilesPendingEmit(state, emitOnlyDtsFiles) {
-    var _a;
-    if (!((_a = state.affectedFilesPendingEmit) == null ? void 0 : _a.size))
-      return;
-    if (!emitOnlyDtsFiles)
-      return state.affectedFilesPendingEmit = void 0;
-    state.affectedFilesPendingEmit.forEach((emitKind, path) => {
-      const pending = emitKind & 7 /* AllJs */;
-      if (!pending)
-        state.affectedFilesPendingEmit.delete(path);
-      else
-        state.affectedFilesPendingEmit.set(path, pending);
-    });
-  }
-  function getNextAffectedFilePendingEmit(state, emitOnlyDtsFiles) {
-    var _a;
-    if (!((_a = state.affectedFilesPendingEmit) == null ? void 0 : _a.size))
-      return void 0;
-    return forEachEntry(state.affectedFilesPendingEmit, (emitKind, path) => {
-      var _a2;
-      const affectedFile = state.program.getSourceFileByPath(path);
-      if (!affectedFile || !sourceFileMayBeEmitted(affectedFile, state.program)) {
-        state.affectedFilesPendingEmit.delete(path);
-        return void 0;
-      }
-      const seenKind = (_a2 = state.seenEmittedFiles) == null ? void 0 : _a2.get(affectedFile.resolvedPath);
-      let pendingKind = getPendingEmitKind(emitKind, seenKind);
-      if (emitOnlyDtsFiles)
-        pendingKind = pendingKind & 24 /* AllDts */;
-      if (pendingKind)
-        return { affectedFile, emitKind: pendingKind };
-    });
-  }
-  function removeDiagnosticsOfLibraryFiles(state) {
-    if (!state.cleanedDiagnosticsOfLibFiles) {
-      state.cleanedDiagnosticsOfLibFiles = true;
-      const program = Debug.checkDefined(state.program);
-      const options = program.getCompilerOptions();
-      forEach(
-        program.getSourceFiles(),
-        (f) => program.isSourceFileDefaultLibrary(f) && !skipTypeChecking(f, options, program) && removeSemanticDiagnosticsOf(state, f.resolvedPath)
-      );
-    }
-  }
-  function handleDtsMayChangeOfAffectedFile(state, affectedFile, cancellationToken, host) {
-    removeSemanticDiagnosticsOf(state, affectedFile.resolvedPath);
-    if (state.allFilesExcludingDefaultLibraryFile === state.affectedFiles) {
-      removeDiagnosticsOfLibraryFiles(state);
-      BuilderState.updateShapeSignature(
-        state,
-        Debug.checkDefined(state.program),
-        affectedFile,
-        cancellationToken,
-        host
-      );
-      return;
-    }
-    if (state.compilerOptions.assumeChangesOnlyAffectDirectDependencies)
-      return;
-    handleDtsMayChangeOfReferencingExportOfAffectedFile(
-      state,
-      affectedFile,
-      cancellationToken,
-      host
-    );
-  }
-  function handleDtsMayChangeOf(state, path, cancellationToken, host) {
-    removeSemanticDiagnosticsOf(state, path);
-    if (!state.changedFilesSet.has(path)) {
-      const program = Debug.checkDefined(state.program);
-      const sourceFile = program.getSourceFileByPath(path);
-      if (sourceFile) {
-        BuilderState.updateShapeSignature(
-          state,
-          program,
-          sourceFile,
-          cancellationToken,
-          host,
-          /*useFileVersionAsSignature*/
-          true
-        );
-        if (getEmitDeclarations(state.compilerOptions)) {
-          addToAffectedFilesPendingEmit(state, path, state.compilerOptions.declarationMap ? 24 /* AllDts */ : 8 /* Dts */);
-        }
-      }
-    }
-  }
-  function removeSemanticDiagnosticsOf(state, path) {
-    if (!state.semanticDiagnosticsFromOldState) {
-      return true;
-    }
-    state.semanticDiagnosticsFromOldState.delete(path);
-    state.semanticDiagnosticsPerFile.delete(path);
-    return !state.semanticDiagnosticsFromOldState.size;
-  }
-  function isChangedSignature(state, path) {
-    const oldSignature = Debug.checkDefined(state.oldSignatures).get(path) || void 0;
-    const newSignature = Debug.checkDefined(state.fileInfos.get(path)).signature;
-    return newSignature !== oldSignature;
-  }
-  function handleDtsMayChangeOfGlobalScope(state, filePath, cancellationToken, host) {
-    var _a;
-    if (!((_a = state.fileInfos.get(filePath)) == null ? void 0 : _a.affectsGlobalScope))
-      return false;
-    BuilderState.getAllFilesExcludingDefaultLibraryFile(
-      state,
-      state.program,
-      /*firstSourceFile*/
-      void 0
-    ).forEach((file) => handleDtsMayChangeOf(
-      state,
-      file.resolvedPath,
-      cancellationToken,
-      host
-    ));
-    removeDiagnosticsOfLibraryFiles(state);
-    return true;
-  }
-  function handleDtsMayChangeOfReferencingExportOfAffectedFile(state, affectedFile, cancellationToken, host) {
-    var _a;
-    if (!state.exportedModulesMap || !state.changedFilesSet.has(affectedFile.resolvedPath))
-      return;
-    if (!isChangedSignature(state, affectedFile.resolvedPath))
-      return;
-    if (getIsolatedModules(state.compilerOptions)) {
-      const seenFileNamesMap = /* @__PURE__ */ new Map();
-      seenFileNamesMap.set(affectedFile.resolvedPath, true);
-      const queue = BuilderState.getReferencedByPaths(state, affectedFile.resolvedPath);
-      while (queue.length > 0) {
-        const currentPath = queue.pop();
-        if (!seenFileNamesMap.has(currentPath)) {
-          seenFileNamesMap.set(currentPath, true);
-          if (handleDtsMayChangeOfGlobalScope(state, currentPath, cancellationToken, host))
-            return;
-          handleDtsMayChangeOf(state, currentPath, cancellationToken, host);
-          if (isChangedSignature(state, currentPath)) {
-            const currentSourceFile = Debug.checkDefined(state.program).getSourceFileByPath(currentPath);
-            queue.push(...BuilderState.getReferencedByPaths(state, currentSourceFile.resolvedPath));
-          }
-        }
-      }
-    }
-    const seenFileAndExportsOfFile = /* @__PURE__ */ new Set();
-    (_a = state.exportedModulesMap.getKeys(affectedFile.resolvedPath)) == null ? void 0 : _a.forEach((exportedFromPath) => {
-      if (handleDtsMayChangeOfGlobalScope(state, exportedFromPath, cancellationToken, host))
-        return true;
-      const references = state.referencedMap.getKeys(exportedFromPath);
-      return references && forEachKey(
-        references,
-        (filePath) => handleDtsMayChangeOfFileAndExportsOfFile(
-          state,
-          filePath,
-          seenFileAndExportsOfFile,
-          cancellationToken,
-          host
-        )
-      );
-    });
-  }
-  function handleDtsMayChangeOfFileAndExportsOfFile(state, filePath, seenFileAndExportsOfFile, cancellationToken, host) {
-    var _a, _b;
-    if (!tryAddToSet(seenFileAndExportsOfFile, filePath))
-      return void 0;
-    if (handleDtsMayChangeOfGlobalScope(state, filePath, cancellationToken, host))
-      return true;
-    handleDtsMayChangeOf(state, filePath, cancellationToken, host);
-    (_a = state.exportedModulesMap.getKeys(filePath)) == null ? void 0 : _a.forEach(
-      (exportedFromPath) => handleDtsMayChangeOfFileAndExportsOfFile(
-        state,
-        exportedFromPath,
-        seenFileAndExportsOfFile,
-        cancellationToken,
-        host
-      )
-    );
-    (_b = state.referencedMap.getKeys(filePath)) == null ? void 0 : _b.forEach(
-      (referencingFilePath) => !seenFileAndExportsOfFile.has(referencingFilePath) && // Not already removed diagnostic file
-      handleDtsMayChangeOf(
-        // Dont add to seen since this is not yet done with the export removal
-        state,
-        referencingFilePath,
-        cancellationToken,
-        host
-      )
-    );
-    return void 0;
-  }
-  function getSemanticDiagnosticsOfFile(state, sourceFile, cancellationToken) {
-    return concatenate(
-      getBinderAndCheckerDiagnosticsOfFile(state, sourceFile, cancellationToken),
-      Debug.checkDefined(state.program).getProgramDiagnostics(sourceFile)
-    );
-  }
-  function getBinderAndCheckerDiagnosticsOfFile(state, sourceFile, cancellationToken) {
-    const path = sourceFile.resolvedPath;
-    if (state.semanticDiagnosticsPerFile) {
-      const cachedDiagnostics = state.semanticDiagnosticsPerFile.get(path);
-      if (cachedDiagnostics) {
-        return filterSemanticDiagnostics(cachedDiagnostics, state.compilerOptions);
-      }
-    }
-    const diagnostics = Debug.checkDefined(state.program).getBindAndCheckDiagnostics(sourceFile, cancellationToken);
-    if (state.semanticDiagnosticsPerFile) {
-      state.semanticDiagnosticsPerFile.set(path, diagnostics);
-    }
-    return filterSemanticDiagnostics(diagnostics, state.compilerOptions);
-  }
-  function isProgramBundleEmitBuildInfo(info) {
-    return !!outFile(info.options || {});
-  }
-  function getBuildInfo2(state, bundle) {
-    var _a, _b, _c;
-    const currentDirectory = Debug.checkDefined(state.program).getCurrentDirectory();
-    const buildInfoDirectory = getDirectoryPath(getNormalizedAbsolutePath(getTsBuildInfoEmitOutputFilePath(state.compilerOptions), currentDirectory));
-    const latestChangedDtsFile = state.latestChangedDtsFile ? relativeToBuildInfoEnsuringAbsolutePath(state.latestChangedDtsFile) : void 0;
-    const fileNames = [];
-    const fileNameToFileId = /* @__PURE__ */ new Map();
-    const root = [];
-    if (outFile(state.compilerOptions)) {
-      const fileInfos2 = arrayFrom(state.fileInfos.entries(), ([key, value]) => {
-        const fileId = toFileId(key);
-        tryAddRoot(key, fileId);
-        return value.impliedFormat ? { version: value.version, impliedFormat: value.impliedFormat, signature: void 0, affectsGlobalScope: void 0 } : value.version;
-      });
-      const program2 = {
-        fileNames,
-        fileInfos: fileInfos2,
-        root,
-        options: convertToProgramBuildInfoCompilerOptions(state.compilerOptions),
-        outSignature: state.outSignature,
-        latestChangedDtsFile,
-        pendingEmit: !state.programEmitPending ? void 0 : (
-          // Pending is undefined or None is encoded as undefined
-          state.programEmitPending === getBuilderFileEmit(state.compilerOptions) ? false : (
-            // Pending emit is same as deteremined by compilerOptions
-            state.programEmitPending
-          )
-        )
-        // Actual value
-      };
-      const { js, dts, commonSourceDirectory, sourceFiles } = bundle;
-      state.bundle = bundle = {
-        commonSourceDirectory,
-        sourceFiles,
-        js: js || (!state.compilerOptions.emitDeclarationOnly ? (_a = state.bundle) == null ? void 0 : _a.js : void 0),
-        dts: dts || (getEmitDeclarations(state.compilerOptions) ? (_b = state.bundle) == null ? void 0 : _b.dts : void 0)
-      };
-      return createBuildInfo(program2, bundle);
-    }
-    let fileIdsList;
-    let fileNamesToFileIdListId;
-    let emitSignatures;
-    const fileInfos = arrayFrom(state.fileInfos.entries(), ([key, value]) => {
-      var _a2, _b2;
-      const fileId = toFileId(key);
-      tryAddRoot(key, fileId);
-      Debug.assert(fileNames[fileId - 1] === relativeToBuildInfo(key));
-      const oldSignature = (_a2 = state.oldSignatures) == null ? void 0 : _a2.get(key);
-      const actualSignature = oldSignature !== void 0 ? oldSignature || void 0 : value.signature;
-      if (state.compilerOptions.composite) {
-        const file = state.program.getSourceFileByPath(key);
-        if (!isJsonSourceFile(file) && sourceFileMayBeEmitted(file, state.program)) {
-          const emitSignature = (_b2 = state.emitSignatures) == null ? void 0 : _b2.get(key);
-          if (emitSignature !== actualSignature) {
-            (emitSignatures || (emitSignatures = [])).push(emitSignature === void 0 ? fileId : (
-              // There is no emit, encode as false
-              // fileId, signature: emptyArray if signature only differs in dtsMap option than our own compilerOptions otherwise EmitSignature
-              [fileId, !isString(emitSignature) && emitSignature[0] === actualSignature ? emptyArray : emitSignature]
-            ));
-          }
-        }
-      }
-      return value.version === actualSignature ? value.affectsGlobalScope || value.impliedFormat ? (
-        // If file version is same as signature, dont serialize signature
-        { version: value.version, signature: void 0, affectsGlobalScope: value.affectsGlobalScope, impliedFormat: value.impliedFormat }
-      ) : (
-        // If file info only contains version and signature and both are same we can just write string
-        value.version
-      ) : actualSignature !== void 0 ? (
-        // If signature is not same as version, encode signature in the fileInfo
-        oldSignature === void 0 ? (
-          // If we havent computed signature, use fileInfo as is
-          value
-        ) : (
-          // Serialize fileInfo with new updated signature
-          { version: value.version, signature: actualSignature, affectsGlobalScope: value.affectsGlobalScope, impliedFormat: value.impliedFormat }
-        )
-      ) : (
-        // Signature of the FileInfo is undefined, serialize it as false
-        { version: value.version, signature: false, affectsGlobalScope: value.affectsGlobalScope, impliedFormat: value.impliedFormat }
-      );
-    });
-    let referencedMap;
-    if (state.referencedMap) {
-      referencedMap = arrayFrom(state.referencedMap.keys()).sort(compareStringsCaseSensitive).map((key) => [
-        toFileId(key),
-        toFileIdListId(state.referencedMap.getValues(key))
-      ]);
-    }
-    let exportedModulesMap;
-    if (state.exportedModulesMap) {
-      exportedModulesMap = mapDefined(arrayFrom(state.exportedModulesMap.keys()).sort(compareStringsCaseSensitive), (key) => {
-        var _a2;
-        const oldValue = (_a2 = state.oldExportedModulesMap) == null ? void 0 : _a2.get(key);
-        if (oldValue === void 0)
-          return [toFileId(key), toFileIdListId(state.exportedModulesMap.getValues(key))];
-        if (oldValue)
-          return [toFileId(key), toFileIdListId(oldValue)];
-        return void 0;
-      });
-    }
-    let semanticDiagnosticsPerFile;
-    if (state.semanticDiagnosticsPerFile) {
-      for (const key of arrayFrom(state.semanticDiagnosticsPerFile.keys()).sort(compareStringsCaseSensitive)) {
-        const value = state.semanticDiagnosticsPerFile.get(key);
-        (semanticDiagnosticsPerFile || (semanticDiagnosticsPerFile = [])).push(
-          value.length ? [
-            toFileId(key),
-            convertToReusableDiagnostics(value, relativeToBuildInfo)
-          ] : toFileId(key)
-        );
-      }
-    }
-    let affectedFilesPendingEmit;
-    if ((_c = state.affectedFilesPendingEmit) == null ? void 0 : _c.size) {
-      const fullEmitForOptions = getBuilderFileEmit(state.compilerOptions);
-      const seenFiles = /* @__PURE__ */ new Set();
-      for (const path of arrayFrom(state.affectedFilesPendingEmit.keys()).sort(compareStringsCaseSensitive)) {
-        if (tryAddToSet(seenFiles, path)) {
-          const file = state.program.getSourceFileByPath(path);
-          if (!file || !sourceFileMayBeEmitted(file, state.program))
-            continue;
-          const fileId = toFileId(path), pendingEmit = state.affectedFilesPendingEmit.get(path);
-          (affectedFilesPendingEmit || (affectedFilesPendingEmit = [])).push(
-            pendingEmit === fullEmitForOptions ? fileId : (
-              // Pending full emit per options
-              pendingEmit === 8 /* Dts */ ? [fileId] : (
-                // Pending on Dts only
-                [fileId, pendingEmit]
-              )
-            )
-            // Anything else
-          );
-        }
-      }
-    }
-    let changeFileSet;
-    if (state.changedFilesSet.size) {
-      for (const path of arrayFrom(state.changedFilesSet.keys()).sort(compareStringsCaseSensitive)) {
-        (changeFileSet || (changeFileSet = [])).push(toFileId(path));
-      }
-    }
-    const program = {
-      fileNames,
-      fileInfos,
-      root,
-      options: convertToProgramBuildInfoCompilerOptions(state.compilerOptions),
-      fileIdsList,
-      referencedMap,
-      exportedModulesMap,
-      semanticDiagnosticsPerFile,
-      affectedFilesPendingEmit,
-      changeFileSet,
-      emitSignatures,
-      latestChangedDtsFile
-    };
-    return createBuildInfo(program, bundle);
-    function relativeToBuildInfoEnsuringAbsolutePath(path) {
-      return relativeToBuildInfo(getNormalizedAbsolutePath(path, currentDirectory));
-    }
-    function relativeToBuildInfo(path) {
-      return ensurePathIsNonModuleName(getRelativePathFromDirectory(buildInfoDirectory, path, state.program.getCanonicalFileName));
-    }
-    function toFileId(path) {
-      let fileId = fileNameToFileId.get(path);
-      if (fileId === void 0) {
-        fileNames.push(relativeToBuildInfo(path));
-        fileNameToFileId.set(path, fileId = fileNames.length);
-      }
-      return fileId;
-    }
-    function toFileIdListId(set) {
-      const fileIds = arrayFrom(set.keys(), toFileId).sort(compareValues);
-      const key = fileIds.join();
-      let fileIdListId = fileNamesToFileIdListId == null ? void 0 : fileNamesToFileIdListId.get(key);
-      if (fileIdListId === void 0) {
-        (fileIdsList || (fileIdsList = [])).push(fileIds);
-        (fileNamesToFileIdListId || (fileNamesToFileIdListId = /* @__PURE__ */ new Map())).set(key, fileIdListId = fileIdsList.length);
-      }
-      return fileIdListId;
-    }
-    function tryAddRoot(path, fileId) {
-      const file = state.program.getSourceFile(path);
-      if (!state.program.getFileIncludeReasons().get(file.path).some((r) => r.kind === 0 /* RootFile */))
-        return;
-      if (!root.length)
-        return root.push(fileId);
-      const last2 = root[root.length - 1];
-      const isLastStartEnd = isArray(last2);
-      if (isLastStartEnd && last2[1] === fileId - 1)
-        return last2[1] = fileId;
-      if (isLastStartEnd || root.length === 1 || last2 !== fileId - 1)
-        return root.push(fileId);
-      const lastButOne = root[root.length - 2];
-      if (!isNumber(lastButOne) || lastButOne !== last2 - 1)
-        return root.push(fileId);
-      root[root.length - 2] = [lastButOne, fileId];
-      return root.length = root.length - 1;
-    }
-    function convertToProgramBuildInfoCompilerOptions(options) {
-      let result;
-      const { optionsNameMap } = getOptionsNameMap();
-      for (const name of getOwnKeys(options).sort(compareStringsCaseSensitive)) {
-        const optionInfo = optionsNameMap.get(name.toLowerCase());
-        if (optionInfo == null ? void 0 : optionInfo.affectsBuildInfo) {
-          (result || (result = {}))[name] = convertToReusableCompilerOptionValue(
-            optionInfo,
-            options[name],
-            relativeToBuildInfoEnsuringAbsolutePath
-          );
-        }
-      }
-      return result;
-    }
-  }
-  function convertToReusableCompilerOptionValue(option, value, relativeToBuildInfo) {
-    if (option) {
-      Debug.assert(option.type !== "listOrElement");
-      if (option.type === "list") {
-        const values = value;
-        if (option.element.isFilePath && values.length) {
-          return values.map(relativeToBuildInfo);
-        }
-      } else if (option.isFilePath) {
-        return relativeToBuildInfo(value);
-      }
-    }
-    return value;
-  }
-  function convertToReusableDiagnostics(diagnostics, relativeToBuildInfo) {
-    Debug.assert(!!diagnostics.length);
-    return diagnostics.map((diagnostic) => {
-      const result = convertToReusableDiagnosticRelatedInformation(diagnostic, relativeToBuildInfo);
-      result.reportsUnnecessary = diagnostic.reportsUnnecessary;
-      result.reportDeprecated = diagnostic.reportsDeprecated;
-      result.source = diagnostic.source;
-      result.skippedOn = diagnostic.skippedOn;
-      const { relatedInformation } = diagnostic;
-      result.relatedInformation = relatedInformation ? relatedInformation.length ? relatedInformation.map((r) => convertToReusableDiagnosticRelatedInformation(r, relativeToBuildInfo)) : [] : void 0;
-      return result;
-    });
-  }
-  function convertToReusableDiagnosticRelatedInformation(diagnostic, relativeToBuildInfo) {
-    const { file } = diagnostic;
-    return {
-      ...diagnostic,
-      file: file ? relativeToBuildInfo(file.resolvedPath) : void 0,
-      messageText: isString(diagnostic.messageText) ? diagnostic.messageText : convertToReusableDiagnosticMessageChain(diagnostic.messageText)
-    };
-  }
-  function convertToReusableDiagnosticMessageChain(chain) {
-    if (chain.repopulateInfo) {
-      return {
-        info: chain.repopulateInfo(),
-        next: convertToReusableDiagnosticMessageChainArray(chain.next)
-      };
-    }
-    const next = convertToReusableDiagnosticMessageChainArray(chain.next);
-    return next === chain.next ? chain : { ...chain, next };
-  }
-  function convertToReusableDiagnosticMessageChainArray(array) {
-    if (!array)
-      return array;
-    return forEach(array, (chain, index) => {
-      const reusable = convertToReusableDiagnosticMessageChain(chain);
-      if (chain === reusable)
-        return void 0;
-      const result = index > 0 ? array.slice(0, index - 1) : [];
-      result.push(reusable);
-      for (let i = index + 1; i < array.length; i++) {
-        result.push(convertToReusableDiagnosticMessageChain(array[i]));
-      }
-      return result;
-    }) || array;
-  }
-  function getBuilderCreationParameters(newProgramOrRootNames, hostOrOptions, oldProgramOrHost, configFileParsingDiagnosticsOrOldProgram, configFileParsingDiagnostics, projectReferences) {
-    let host;
-    let newProgram;
-    let oldProgram;
-    if (newProgramOrRootNames === void 0) {
-      Debug.assert(hostOrOptions === void 0);
-      host = oldProgramOrHost;
-      oldProgram = configFileParsingDiagnosticsOrOldProgram;
-      Debug.assert(!!oldProgram);
-      newProgram = oldProgram.getProgram();
-    } else if (isArray(newProgramOrRootNames)) {
-      oldProgram = configFileParsingDiagnosticsOrOldProgram;
-      newProgram = createProgram({
-        rootNames: newProgramOrRootNames,
-        options: hostOrOptions,
-        host: oldProgramOrHost,
-        oldProgram: oldProgram && oldProgram.getProgramOrUndefined(),
-        configFileParsingDiagnostics,
-        projectReferences
-      });
-      host = oldProgramOrHost;
-    } else {
-      newProgram = newProgramOrRootNames;
-      host = hostOrOptions;
-      oldProgram = oldProgramOrHost;
-      configFileParsingDiagnostics = configFileParsingDiagnosticsOrOldProgram;
-    }
-    return { host, newProgram, oldProgram, configFileParsingDiagnostics: configFileParsingDiagnostics || emptyArray };
-  }
-  function getTextHandlingSourceMapForSignature(text, data) {
-    return (data == null ? void 0 : data.sourceMapUrlPos) !== void 0 ? text.substring(0, data.sourceMapUrlPos) : text;
-  }
-  function computeSignatureWithDiagnostics(program, sourceFile, text, host, data) {
-    var _a;
-    text = getTextHandlingSourceMapForSignature(text, data);
-    let sourceFileDirectory;
-    if ((_a = data == null ? void 0 : data.diagnostics) == null ? void 0 : _a.length) {
-      text += data.diagnostics.map(
-        (diagnostic) => `${locationInfo(diagnostic)}${DiagnosticCategory[diagnostic.category]}${diagnostic.code}: ${flattenDiagnosticMessageText2(diagnostic.messageText)}`
-      ).join("\n");
-    }
-    return (host.createHash ?? generateDjb2Hash)(text);
-    function flattenDiagnosticMessageText2(diagnostic) {
-      return isString(diagnostic) ? diagnostic : diagnostic === void 0 ? "" : !diagnostic.next ? diagnostic.messageText : diagnostic.messageText + diagnostic.next.map(flattenDiagnosticMessageText2).join("\n");
-    }
-    function locationInfo(diagnostic) {
-      if (diagnostic.file.resolvedPath === sourceFile.resolvedPath)
-        return `(${diagnostic.start},${diagnostic.length})`;
-      if (sourceFileDirectory === void 0)
-        sourceFileDirectory = getDirectoryPath(sourceFile.resolvedPath);
-      return `${ensurePathIsNonModuleName(getRelativePathFromDirectory(
-        sourceFileDirectory,
-        diagnostic.file.resolvedPath,
-        program.getCanonicalFileName
-      ))}(${diagnostic.start},${diagnostic.length})`;
-    }
-  }
-  function computeSignature(text, host, data) {
-    return (host.createHash ?? generateDjb2Hash)(getTextHandlingSourceMapForSignature(text, data));
-  }
-  function createBuilderProgram(kind, { newProgram, host, oldProgram, configFileParsingDiagnostics }) {
-    let oldState = oldProgram && oldProgram.getState();
-    if (oldState && newProgram === oldState.program && configFileParsingDiagnostics === newProgram.getConfigFileParsingDiagnostics()) {
-      newProgram = void 0;
-      oldState = void 0;
-      return oldProgram;
-    }
-    const state = createBuilderProgramState(newProgram, oldState);
-    newProgram.getBuildInfo = (bundle) => getBuildInfo2(state, bundle);
-    newProgram = void 0;
-    oldProgram = void 0;
-    oldState = void 0;
-    const getState = () => state;
-    const builderProgram = createRedirectedBuilderProgram(getState, configFileParsingDiagnostics);
-    builderProgram.getState = getState;
-    builderProgram.saveEmitState = () => backupBuilderProgramEmitState(state);
-    builderProgram.restoreEmitState = (saved) => restoreBuilderProgramEmitState(state, saved);
-    builderProgram.hasChangedEmitSignature = () => !!state.hasChangedEmitSignature;
-    builderProgram.getAllDependencies = (sourceFile) => BuilderState.getAllDependencies(state, Debug.checkDefined(state.program), sourceFile);
-    builderProgram.getSemanticDiagnostics = getSemanticDiagnostics;
-    builderProgram.emit = emit;
-    builderProgram.releaseProgram = () => releaseCache(state);
-    if (kind === 0 /* SemanticDiagnosticsBuilderProgram */) {
-      builderProgram.getSemanticDiagnosticsOfNextAffectedFile = getSemanticDiagnosticsOfNextAffectedFile;
-    } else if (kind === 1 /* EmitAndSemanticDiagnosticsBuilderProgram */) {
-      builderProgram.getSemanticDiagnosticsOfNextAffectedFile = getSemanticDiagnosticsOfNextAffectedFile;
-      builderProgram.emitNextAffectedFile = emitNextAffectedFile;
-      builderProgram.emitBuildInfo = emitBuildInfo;
-    } else {
-      notImplemented();
-    }
-    return builderProgram;
-    function emitBuildInfo(writeFile2, cancellationToken) {
-      if (state.buildInfoEmitPending) {
-        const result = Debug.checkDefined(state.program).emitBuildInfo(writeFile2 || maybeBind(host, host.writeFile), cancellationToken);
-        state.buildInfoEmitPending = false;
-        return result;
-      }
-      return emitSkippedWithNoDiagnostics;
-    }
-    function emitNextAffectedFile(writeFile2, cancellationToken, emitOnlyDtsFiles, customTransformers) {
-      var _a, _b, _c;
-      let affected = getNextAffectedFile(state, cancellationToken, host);
-      const programEmitKind = getBuilderFileEmit(state.compilerOptions);
-      let emitKind = emitOnlyDtsFiles ? programEmitKind & 24 /* AllDts */ : programEmitKind;
-      if (!affected) {
-        if (!outFile(state.compilerOptions)) {
-          const pendingAffectedFile = getNextAffectedFilePendingEmit(state, emitOnlyDtsFiles);
-          if (!pendingAffectedFile) {
-            if (!state.buildInfoEmitPending)
-              return void 0;
-            const affected2 = state.program;
-            const result2 = affected2.emitBuildInfo(writeFile2 || maybeBind(host, host.writeFile), cancellationToken);
-            state.buildInfoEmitPending = false;
-            return { result: result2, affected: affected2 };
-          }
-          ({ affectedFile: affected, emitKind } = pendingAffectedFile);
-        } else {
-          if (!state.programEmitPending)
-            return void 0;
-          emitKind = state.programEmitPending;
-          if (emitOnlyDtsFiles)
-            emitKind = emitKind & 24 /* AllDts */;
-          if (!emitKind)
-            return void 0;
-          affected = state.program;
-        }
-      }
-      let emitOnly;
-      if (emitKind & 7 /* AllJs */)
-        emitOnly = 0 /* Js */;
-      if (emitKind & 24 /* AllDts */)
-        emitOnly = emitOnly === void 0 ? 1 /* Dts */ : void 0;
-      if (affected === state.program) {
-        state.programEmitPending = state.changedFilesSet.size ? getPendingEmitKind(programEmitKind, emitKind) : state.programEmitPending ? getPendingEmitKind(state.programEmitPending, emitKind) : void 0;
-      }
-      const result = state.program.emit(
-        affected === state.program ? void 0 : affected,
-        getWriteFileCallback(writeFile2, customTransformers),
-        cancellationToken,
-        emitOnly,
-        customTransformers
-      );
-      if (affected !== state.program) {
-        const affectedSourceFile = affected;
-        state.seenAffectedFiles.add(affectedSourceFile.resolvedPath);
-        if (state.affectedFilesIndex !== void 0)
-          state.affectedFilesIndex++;
-        state.buildInfoEmitPending = true;
-        const existing = ((_a = state.seenEmittedFiles) == null ? void 0 : _a.get(affectedSourceFile.resolvedPath)) || 0 /* None */;
-        (state.seenEmittedFiles ?? (state.seenEmittedFiles = /* @__PURE__ */ new Map())).set(affectedSourceFile.resolvedPath, emitKind | existing);
-        const existingPending = ((_b = state.affectedFilesPendingEmit) == null ? void 0 : _b.get(affectedSourceFile.resolvedPath)) || programEmitKind;
-        const pendingKind = getPendingEmitKind(existingPending, emitKind | existing);
-        if (pendingKind)
-          (state.affectedFilesPendingEmit ?? (state.affectedFilesPendingEmit = /* @__PURE__ */ new Map())).set(affectedSourceFile.resolvedPath, pendingKind);
-        else
-          (_c = state.affectedFilesPendingEmit) == null ? void 0 : _c.delete(affectedSourceFile.resolvedPath);
-      } else {
-        state.changedFilesSet.clear();
-      }
-      return { result, affected };
-    }
-    function getWriteFileCallback(writeFile2, customTransformers) {
-      if (!getEmitDeclarations(state.compilerOptions))
-        return writeFile2 || maybeBind(host, host.writeFile);
-      return (fileName, text, writeByteOrderMark, onError, sourceFiles, data) => {
-        var _a, _b, _c, _d;
-        if (isDeclarationFileName(fileName)) {
-          if (!outFile(state.compilerOptions)) {
-            Debug.assert((sourceFiles == null ? void 0 : sourceFiles.length) === 1);
-            let emitSignature;
-            if (!customTransformers) {
-              const file = sourceFiles[0];
-              const info = state.fileInfos.get(file.resolvedPath);
-              if (info.signature === file.version) {
-                const signature = computeSignatureWithDiagnostics(
-                  state.program,
-                  file,
-                  text,
-                  host,
-                  data
-                );
-                if (!((_a = data == null ? void 0 : data.diagnostics) == null ? void 0 : _a.length))
-                  emitSignature = signature;
-                if (signature !== file.version) {
-                  if (host.storeFilesChangingSignatureDuringEmit)
-                    (state.filesChangingSignature ?? (state.filesChangingSignature = /* @__PURE__ */ new Set())).add(file.resolvedPath);
-                  if (state.exportedModulesMap)
-                    BuilderState.updateExportedModules(state, file, file.exportedModulesFromDeclarationEmit);
-                  if (state.affectedFiles) {
-                    const existing = (_b = state.oldSignatures) == null ? void 0 : _b.get(file.resolvedPath);
-                    if (existing === void 0)
-                      (state.oldSignatures ?? (state.oldSignatures = /* @__PURE__ */ new Map())).set(file.resolvedPath, info.signature || false);
-                    info.signature = signature;
-                  } else {
-                    info.signature = signature;
-                    (_c = state.oldExportedModulesMap) == null ? void 0 : _c.clear();
-                  }
-                }
-              }
-            }
-            if (state.compilerOptions.composite) {
-              const filePath = sourceFiles[0].resolvedPath;
-              emitSignature = handleNewSignature((_d = state.emitSignatures) == null ? void 0 : _d.get(filePath), emitSignature);
-              if (!emitSignature)
-                return;
-              (state.emitSignatures ?? (state.emitSignatures = /* @__PURE__ */ new Map())).set(filePath, emitSignature);
-            }
-          } else if (state.compilerOptions.composite) {
-            const newSignature = handleNewSignature(
-              state.outSignature,
-              /*newSignature*/
-              void 0
-            );
-            if (!newSignature)
-              return;
-            state.outSignature = newSignature;
-          }
-        }
-        if (writeFile2)
-          writeFile2(fileName, text, writeByteOrderMark, onError, sourceFiles, data);
-        else if (host.writeFile)
-          host.writeFile(fileName, text, writeByteOrderMark, onError, sourceFiles, data);
-        else
-          state.program.writeFile(fileName, text, writeByteOrderMark, onError, sourceFiles, data);
-        function handleNewSignature(oldSignatureFormat, newSignature) {
-          const oldSignature = !oldSignatureFormat || isString(oldSignatureFormat) ? oldSignatureFormat : oldSignatureFormat[0];
-          newSignature ?? (newSignature = computeSignature(text, host, data));
-          if (newSignature === oldSignature) {
-            if (oldSignatureFormat === oldSignature)
-              return void 0;
-            else if (data)
-              data.differsOnlyInMap = true;
-            else
-              data = { differsOnlyInMap: true };
-          } else {
-            state.hasChangedEmitSignature = true;
-            state.latestChangedDtsFile = fileName;
-          }
-          return newSignature;
-        }
-      };
-    }
-    function emit(targetSourceFile, writeFile2, cancellationToken, emitOnlyDtsFiles, customTransformers) {
-      if (kind === 1 /* EmitAndSemanticDiagnosticsBuilderProgram */) {
-        assertSourceFileOkWithoutNextAffectedCall(state, targetSourceFile);
-      }
-      const result = handleNoEmitOptions(builderProgram, targetSourceFile, writeFile2, cancellationToken);
-      if (result)
-        return result;
-      if (!targetSourceFile) {
-        if (kind === 1 /* EmitAndSemanticDiagnosticsBuilderProgram */) {
-          let sourceMaps = [];
-          let emitSkipped = false;
-          let diagnostics;
-          let emittedFiles = [];
-          let affectedEmitResult;
-          while (affectedEmitResult = emitNextAffectedFile(writeFile2, cancellationToken, emitOnlyDtsFiles, customTransformers)) {
-            emitSkipped = emitSkipped || affectedEmitResult.result.emitSkipped;
-            diagnostics = addRange(diagnostics, affectedEmitResult.result.diagnostics);
-            emittedFiles = addRange(emittedFiles, affectedEmitResult.result.emittedFiles);
-            sourceMaps = addRange(sourceMaps, affectedEmitResult.result.sourceMaps);
-          }
-          return {
-            emitSkipped,
-            diagnostics: diagnostics || emptyArray,
-            emittedFiles,
-            sourceMaps
-          };
-        } else {
-          clearAffectedFilesPendingEmit(state, emitOnlyDtsFiles);
-        }
-      }
-      return Debug.checkDefined(state.program).emit(
-        targetSourceFile,
-        getWriteFileCallback(writeFile2, customTransformers),
-        cancellationToken,
-        emitOnlyDtsFiles,
-        customTransformers
-      );
-    }
-    function getSemanticDiagnosticsOfNextAffectedFile(cancellationToken, ignoreSourceFile) {
-      while (true) {
-        const affected = getNextAffectedFile(state, cancellationToken, host);
-        let result;
-        if (!affected)
-          return void 0;
-        else if (affected !== state.program) {
-          const affectedSourceFile = affected;
-          if (!ignoreSourceFile || !ignoreSourceFile(affectedSourceFile)) {
-            result = getSemanticDiagnosticsOfFile(state, affectedSourceFile, cancellationToken);
-          }
-          state.seenAffectedFiles.add(affectedSourceFile.resolvedPath);
-          state.affectedFilesIndex++;
-          state.buildInfoEmitPending = true;
-          if (!result)
-            continue;
-        } else {
-          result = state.program.getSemanticDiagnostics(
-            /*sourceFile*/
-            void 0,
-            cancellationToken
-          );
-          state.changedFilesSet.clear();
-          state.programEmitPending = getBuilderFileEmit(state.compilerOptions);
-        }
-        return { result, affected };
-      }
-    }
-    function getSemanticDiagnostics(sourceFile, cancellationToken) {
-      assertSourceFileOkWithoutNextAffectedCall(state, sourceFile);
-      const compilerOptions = Debug.checkDefined(state.program).getCompilerOptions();
-      if (outFile(compilerOptions)) {
-        Debug.assert(!state.semanticDiagnosticsPerFile);
-        return Debug.checkDefined(state.program).getSemanticDiagnostics(sourceFile, cancellationToken);
-      }
-      if (sourceFile) {
-        return getSemanticDiagnosticsOfFile(state, sourceFile, cancellationToken);
-      }
-      while (getSemanticDiagnosticsOfNextAffectedFile(cancellationToken)) {
-      }
-      let diagnostics;
-      for (const sourceFile2 of Debug.checkDefined(state.program).getSourceFiles()) {
-        diagnostics = addRange(diagnostics, getSemanticDiagnosticsOfFile(state, sourceFile2, cancellationToken));
-      }
-      return diagnostics || emptyArray;
-    }
-  }
-  function addToAffectedFilesPendingEmit(state, affectedFilePendingEmit, kind) {
-    var _a;
-    const existingKind = ((_a = state.affectedFilesPendingEmit) == null ? void 0 : _a.get(affectedFilePendingEmit)) || 0 /* None */;
-    (state.affectedFilesPendingEmit ?? (state.affectedFilesPendingEmit = /* @__PURE__ */ new Map())).set(affectedFilePendingEmit, existingKind | kind);
-  }
-  function toBuilderStateFileInfoForMultiEmit(fileInfo) {
-    return isString(fileInfo) ? { version: fileInfo, signature: fileInfo, affectsGlobalScope: void 0, impliedFormat: void 0 } : isString(fileInfo.signature) ? fileInfo : { version: fileInfo.version, signature: fileInfo.signature === false ? void 0 : fileInfo.version, affectsGlobalScope: fileInfo.affectsGlobalScope, impliedFormat: fileInfo.impliedFormat };
-  }
-  function toBuilderFileEmit(value, fullEmitForOptions) {
-    return isNumber(value) ? fullEmitForOptions : value[1] || 8 /* Dts */;
-  }
-  function toProgramEmitPending(value, options) {
-    return !value ? getBuilderFileEmit(options || {}) : value;
-  }
-  function createBuilderProgramUsingProgramBuildInfo(buildInfo, buildInfoPath, host) {
-    var _a, _b, _c, _d;
-    const program = buildInfo.program;
-    const buildInfoDirectory = getDirectoryPath(getNormalizedAbsolutePath(buildInfoPath, host.getCurrentDirectory()));
-    const getCanonicalFileName = createGetCanonicalFileName(host.useCaseSensitiveFileNames());
-    let state;
-    const filePaths = (_a = program.fileNames) == null ? void 0 : _a.map(toPathInBuildInfoDirectory);
-    let filePathsSetList;
-    const latestChangedDtsFile = program.latestChangedDtsFile ? toAbsolutePath(program.latestChangedDtsFile) : void 0;
-    if (isProgramBundleEmitBuildInfo(program)) {
-      const fileInfos = /* @__PURE__ */ new Map();
-      program.fileInfos.forEach((fileInfo, index) => {
-        const path = toFilePath(index + 1);
-        fileInfos.set(path, isString(fileInfo) ? { version: fileInfo, signature: void 0, affectsGlobalScope: void 0, impliedFormat: void 0 } : fileInfo);
-      });
-      state = {
-        fileInfos,
-        compilerOptions: program.options ? convertToOptionsWithAbsolutePaths(program.options, toAbsolutePath) : {},
-        latestChangedDtsFile,
-        outSignature: program.outSignature,
-        programEmitPending: program.pendingEmit === void 0 ? void 0 : toProgramEmitPending(program.pendingEmit, program.options),
-        bundle: buildInfo.bundle
-      };
-    } else {
-      filePathsSetList = (_b = program.fileIdsList) == null ? void 0 : _b.map((fileIds) => new Set(fileIds.map(toFilePath)));
-      const fileInfos = /* @__PURE__ */ new Map();
-      const emitSignatures = ((_c = program.options) == null ? void 0 : _c.composite) && !outFile(program.options) ? /* @__PURE__ */ new Map() : void 0;
-      program.fileInfos.forEach((fileInfo, index) => {
-        const path = toFilePath(index + 1);
-        const stateFileInfo = toBuilderStateFileInfoForMultiEmit(fileInfo);
-        fileInfos.set(path, stateFileInfo);
-        if (emitSignatures && stateFileInfo.signature)
-          emitSignatures.set(path, stateFileInfo.signature);
-      });
-      (_d = program.emitSignatures) == null ? void 0 : _d.forEach((value) => {
-        if (isNumber(value))
-          emitSignatures.delete(toFilePath(value));
-        else {
-          const key = toFilePath(value[0]);
-          emitSignatures.set(
-            key,
-            !isString(value[1]) && !value[1].length ? (
-              // File signature is emit signature but differs in map
-              [emitSignatures.get(key)]
-            ) : value[1]
-          );
-        }
-      });
-      const fullEmitForOptions = program.affectedFilesPendingEmit ? getBuilderFileEmit(program.options || {}) : void 0;
-      state = {
-        fileInfos,
-        compilerOptions: program.options ? convertToOptionsWithAbsolutePaths(program.options, toAbsolutePath) : {},
-        referencedMap: toManyToManyPathMap(program.referencedMap),
-        exportedModulesMap: toManyToManyPathMap(program.exportedModulesMap),
-        semanticDiagnosticsPerFile: program.semanticDiagnosticsPerFile && arrayToMap(program.semanticDiagnosticsPerFile, (value) => toFilePath(isNumber(value) ? value : value[0]), (value) => isNumber(value) ? emptyArray : value[1]),
-        hasReusableDiagnostic: true,
-        affectedFilesPendingEmit: program.affectedFilesPendingEmit && arrayToMap(program.affectedFilesPendingEmit, (value) => toFilePath(isNumber(value) ? value : value[0]), (value) => toBuilderFileEmit(value, fullEmitForOptions)),
-        changedFilesSet: new Set(map(program.changeFileSet, toFilePath)),
-        latestChangedDtsFile,
-        emitSignatures: (emitSignatures == null ? void 0 : emitSignatures.size) ? emitSignatures : void 0
-      };
-    }
-    return {
-      getState: () => state,
-      saveEmitState: noop,
-      restoreEmitState: noop,
-      getProgram: notImplemented,
-      getProgramOrUndefined: returnUndefined,
-      releaseProgram: noop,
-      getCompilerOptions: () => state.compilerOptions,
-      getSourceFile: notImplemented,
-      getSourceFiles: notImplemented,
-      getOptionsDiagnostics: notImplemented,
-      getGlobalDiagnostics: notImplemented,
-      getConfigFileParsingDiagnostics: notImplemented,
-      getSyntacticDiagnostics: notImplemented,
-      getDeclarationDiagnostics: notImplemented,
-      getSemanticDiagnostics: notImplemented,
-      emit: notImplemented,
-      getAllDependencies: notImplemented,
-      getCurrentDirectory: notImplemented,
-      emitNextAffectedFile: notImplemented,
-      getSemanticDiagnosticsOfNextAffectedFile: notImplemented,
-      emitBuildInfo: notImplemented,
-      close: noop,
-      hasChangedEmitSignature: returnFalse
-    };
-    function toPathInBuildInfoDirectory(path) {
-      return toPath(path, buildInfoDirectory, getCanonicalFileName);
-    }
-    function toAbsolutePath(path) {
-      return getNormalizedAbsolutePath(path, buildInfoDirectory);
-    }
-    function toFilePath(fileId) {
-      return filePaths[fileId - 1];
-    }
-    function toFilePathsSet(fileIdsListId) {
-      return filePathsSetList[fileIdsListId - 1];
-    }
-    function toManyToManyPathMap(referenceMap) {
-      if (!referenceMap) {
-        return void 0;
-      }
-      const map2 = BuilderState.createManyToManyPathMap();
-      referenceMap.forEach(
-        ([fileId, fileIdListId]) => map2.set(toFilePath(fileId), toFilePathsSet(fileIdListId))
-      );
-      return map2;
-    }
-  }
-  function getBuildInfoFileVersionMap(program, buildInfoPath, host) {
-    const buildInfoDirectory = getDirectoryPath(getNormalizedAbsolutePath(buildInfoPath, host.getCurrentDirectory()));
-    const getCanonicalFileName = createGetCanonicalFileName(host.useCaseSensitiveFileNames());
-    const fileInfos = /* @__PURE__ */ new Map();
-    let rootIndex = 0;
-    const roots = [];
-    program.fileInfos.forEach((fileInfo, index) => {
-      const path = toPath(program.fileNames[index], buildInfoDirectory, getCanonicalFileName);
-      const version2 = isString(fileInfo) ? fileInfo : fileInfo.version;
-      fileInfos.set(path, version2);
-      if (rootIndex < program.root.length) {
-        const current = program.root[rootIndex];
-        const fileId = index + 1;
-        if (isArray(current)) {
-          if (current[0] <= fileId && fileId <= current[1]) {
-            roots.push(path);
-            if (current[1] === fileId)
-              rootIndex++;
-          }
-        } else if (current === fileId) {
-          roots.push(path);
-          rootIndex++;
-        }
-      }
-    });
-    return { fileInfos, roots };
-  }
-  function createRedirectedBuilderProgram(getState, configFileParsingDiagnostics) {
-    return {
-      getState: notImplemented,
-      saveEmitState: noop,
-      restoreEmitState: noop,
-      getProgram,
-      getProgramOrUndefined: () => getState().program,
-      releaseProgram: () => getState().program = void 0,
-      getCompilerOptions: () => getState().compilerOptions,
-      getSourceFile: (fileName) => getProgram().getSourceFile(fileName),
-      getSourceFiles: () => getProgram().getSourceFiles(),
-      getOptionsDiagnostics: (cancellationToken) => getProgram().getOptionsDiagnostics(cancellationToken),
-      getGlobalDiagnostics: (cancellationToken) => getProgram().getGlobalDiagnostics(cancellationToken),
-      getConfigFileParsingDiagnostics: () => configFileParsingDiagnostics,
-      getSyntacticDiagnostics: (sourceFile, cancellationToken) => getProgram().getSyntacticDiagnostics(sourceFile, cancellationToken),
-      getDeclarationDiagnostics: (sourceFile, cancellationToken) => getProgram().getDeclarationDiagnostics(sourceFile, cancellationToken),
-      getSemanticDiagnostics: (sourceFile, cancellationToken) => getProgram().getSemanticDiagnostics(sourceFile, cancellationToken),
-      emit: (sourceFile, writeFile2, cancellationToken, emitOnlyDts, customTransformers) => getProgram().emit(sourceFile, writeFile2, cancellationToken, emitOnlyDts, customTransformers),
-      emitBuildInfo: (writeFile2, cancellationToken) => getProgram().emitBuildInfo(writeFile2, cancellationToken),
-      getAllDependencies: notImplemented,
-      getCurrentDirectory: () => getProgram().getCurrentDirectory(),
-      close: noop
-    };
-    function getProgram() {
-      return Debug.checkDefined(getState().program);
-    }
-  }
-  var BuilderFileEmit, BuilderProgramKind;
-  var init_builder = __esm({
-    "src/compiler/builder.ts"() {
-      "use strict";
-      init_ts2();
-      BuilderFileEmit = /* @__PURE__ */ ((BuilderFileEmit2) => {
-        BuilderFileEmit2[BuilderFileEmit2["None"] = 0] = "None";
-        BuilderFileEmit2[BuilderFileEmit2["Js"] = 1] = "Js";
-        BuilderFileEmit2[BuilderFileEmit2["JsMap"] = 2] = "JsMap";
-        BuilderFileEmit2[BuilderFileEmit2["JsInlineMap"] = 4] = "JsInlineMap";
-        BuilderFileEmit2[BuilderFileEmit2["Dts"] = 8] = "Dts";
-        BuilderFileEmit2[BuilderFileEmit2["DtsMap"] = 16] = "DtsMap";
-        BuilderFileEmit2[BuilderFileEmit2["AllJs"] = 7] = "AllJs";
-        BuilderFileEmit2[BuilderFileEmit2["AllDts"] = 24] = "AllDts";
-        BuilderFileEmit2[BuilderFileEmit2["All"] = 31] = "All";
-        return BuilderFileEmit2;
-      })(BuilderFileEmit || {});
-      BuilderProgramKind = /* @__PURE__ */ ((BuilderProgramKind2) => {
-        BuilderProgramKind2[BuilderProgramKind2["SemanticDiagnosticsBuilderProgram"] = 0] = "SemanticDiagnosticsBuilderProgram";
-        BuilderProgramKind2[BuilderProgramKind2["EmitAndSemanticDiagnosticsBuilderProgram"] = 1] = "EmitAndSemanticDiagnosticsBuilderProgram";
-        return BuilderProgramKind2;
-      })(BuilderProgramKind || {});
-    }
-  });
-
-  // src/compiler/builderPublic.ts
-  function createSemanticDiagnosticsBuilderProgram(newProgramOrRootNames, hostOrOptions, oldProgramOrHost, configFileParsingDiagnosticsOrOldProgram, configFileParsingDiagnostics, projectReferences) {
-    return createBuilderProgram(0 /* SemanticDiagnosticsBuilderProgram */, getBuilderCreationParameters(newProgramOrRootNames, hostOrOptions, oldProgramOrHost, configFileParsingDiagnosticsOrOldProgram, configFileParsingDiagnostics, projectReferences));
-  }
-  function createEmitAndSemanticDiagnosticsBuilderProgram(newProgramOrRootNames, hostOrOptions, oldProgramOrHost, configFileParsingDiagnosticsOrOldProgram, configFileParsingDiagnostics, projectReferences) {
-    return createBuilderProgram(1 /* EmitAndSemanticDiagnosticsBuilderProgram */, getBuilderCreationParameters(newProgramOrRootNames, hostOrOptions, oldProgramOrHost, configFileParsingDiagnosticsOrOldProgram, configFileParsingDiagnostics, projectReferences));
-  }
-  function createAbstractBuilder(newProgramOrRootNames, hostOrOptions, oldProgramOrHost, configFileParsingDiagnosticsOrOldProgram, configFileParsingDiagnostics, projectReferences) {
-    const { newProgram, configFileParsingDiagnostics: newConfigFileParsingDiagnostics } = getBuilderCreationParameters(newProgramOrRootNames, hostOrOptions, oldProgramOrHost, configFileParsingDiagnosticsOrOldProgram, configFileParsingDiagnostics, projectReferences);
-    return createRedirectedBuilderProgram(() => ({ program: newProgram, compilerOptions: newProgram.getCompilerOptions() }), newConfigFileParsingDiagnostics);
-  }
-  var init_builderPublic = __esm({
-    "src/compiler/builderPublic.ts"() {
-      "use strict";
-      init_ts2();
-    }
-  });
-
-  // src/compiler/resolutionCache.ts
-  function removeIgnoredPath(path) {
-    if (endsWith(path, "/node_modules/.staging")) {
-      return removeSuffix(path, "/.staging");
-    }
-    return some(ignoredPaths, (searchPath) => stringContains(path, searchPath)) ? void 0 : path;
-  }
-  function perceivedOsRootLengthForWatching(pathComponents2, length2) {
-    if (length2 <= 1)
-      return 1;
-    let userCheckIndex = 1;
-    let isDosStyle = pathComponents2[0].search(/[a-zA-Z]:/) === 0;
-    if (pathComponents2[0] !== directorySeparator && !isDosStyle && // Non dos style paths
-    pathComponents2[1].search(/[a-zA-Z]\$$/) === 0) {
-      if (length2 === 2)
-        return 2;
-      userCheckIndex = 2;
-      isDosStyle = true;
-    }
-    if (isDosStyle && !pathComponents2[userCheckIndex].match(/^users$/i)) {
-      return userCheckIndex;
-    }
-    return userCheckIndex + 2;
-  }
-  function canWatchDirectoryOrFile(pathComponents2, length2) {
-    if (length2 === void 0)
-      length2 = pathComponents2.length;
-    if (length2 <= 2)
-      return false;
-    const perceivedOsRootLength = perceivedOsRootLengthForWatching(pathComponents2, length2);
-    return length2 > perceivedOsRootLength + 1;
-  }
-  function canWatchAtTypes(atTypes) {
-    return canWatchAffectedPackageJsonOrNodeModulesOfAtTypes(getDirectoryPath(atTypes));
-  }
-  function isInDirectoryPath(dirComponents, fileOrDirComponents) {
-    if (fileOrDirComponents.length < fileOrDirComponents.length)
-      return false;
-    for (let i = 0; i < dirComponents.length; i++) {
-      if (fileOrDirComponents[i] !== dirComponents[i])
-        return false;
-    }
-    return true;
-  }
-  function canWatchAffectedPackageJsonOrNodeModulesOfAtTypes(fileOrDirPath) {
-    return canWatchDirectoryOrFile(getPathComponents(fileOrDirPath));
-  }
-  function canWatchAffectingLocation(filePath) {
-    return canWatchAffectedPackageJsonOrNodeModulesOfAtTypes(filePath);
-  }
-  function getDirectoryToWatchFailedLookupLocation(failedLookupLocation, failedLookupLocationPath, rootDir, rootPath, rootPathComponents, getCurrentDirectory) {
-    const failedLookupPathComponents = getPathComponents(failedLookupLocationPath);
-    failedLookupLocation = isRootedDiskPath(failedLookupLocation) ? normalizePath(failedLookupLocation) : getNormalizedAbsolutePath(failedLookupLocation, getCurrentDirectory());
-    const failedLookupComponents = getPathComponents(failedLookupLocation);
-    const perceivedOsRootLength = perceivedOsRootLengthForWatching(failedLookupPathComponents, failedLookupPathComponents.length);
-    if (failedLookupPathComponents.length <= perceivedOsRootLength + 1)
-      return void 0;
-    const nodeModulesIndex = failedLookupPathComponents.indexOf("node_modules");
-    if (nodeModulesIndex !== -1 && nodeModulesIndex + 1 <= perceivedOsRootLength + 1)
-      return void 0;
-    if (isInDirectoryPath(rootPathComponents, failedLookupPathComponents)) {
-      if (failedLookupPathComponents.length > rootPathComponents.length + 1) {
-        return getDirectoryOfFailedLookupWatch(failedLookupComponents, failedLookupPathComponents, Math.max(rootPathComponents.length + 1, perceivedOsRootLength + 1));
-      } else {
-        return {
-          dir: rootDir,
-          dirPath: rootPath,
-          nonRecursive: true
-        };
-      }
-    }
-    return getDirectoryToWatchFromFailedLookupLocationDirectory(
-      failedLookupComponents,
-      failedLookupPathComponents,
-      failedLookupPathComponents.length - 1,
-      perceivedOsRootLength,
-      nodeModulesIndex,
-      rootPathComponents
-    );
-  }
-  function getDirectoryToWatchFromFailedLookupLocationDirectory(dirComponents, dirPathComponents, dirPathComponentsLength, perceivedOsRootLength, nodeModulesIndex, rootPathComponents) {
-    if (nodeModulesIndex !== -1) {
-      return getDirectoryOfFailedLookupWatch(dirComponents, dirPathComponents, nodeModulesIndex + 1);
-    }
-    let nonRecursive = true;
-    let length2 = dirPathComponentsLength;
-    for (let i = 0; i < dirPathComponentsLength; i++) {
-      if (dirPathComponents[i] !== rootPathComponents[i]) {
-        nonRecursive = false;
-        length2 = Math.max(i + 1, perceivedOsRootLength + 1);
-        break;
-      }
-    }
-    return getDirectoryOfFailedLookupWatch(dirComponents, dirPathComponents, length2, nonRecursive);
-  }
-  function getDirectoryOfFailedLookupWatch(dirComponents, dirPathComponents, length2, nonRecursive) {
-    return {
-      dir: getPathFromPathComponents(dirComponents, length2),
-      dirPath: getPathFromPathComponents(dirPathComponents, length2),
-      nonRecursive
-    };
-  }
-  function getDirectoryToWatchFailedLookupLocationFromTypeRoot(typeRoot, typeRootPath, rootPath, rootPathComponents, getCurrentDirectory, filterCustomPath) {
-    const typeRootPathComponents = getPathComponents(typeRootPath);
-    if (isInDirectoryPath(rootPathComponents, typeRootPathComponents)) {
-      return rootPath;
-    }
-    typeRoot = isRootedDiskPath(typeRoot) ? normalizePath(typeRoot) : getNormalizedAbsolutePath(typeRoot, getCurrentDirectory());
-    const toWatch = getDirectoryToWatchFromFailedLookupLocationDirectory(
-      getPathComponents(typeRoot),
-      typeRootPathComponents,
-      typeRootPathComponents.length,
-      perceivedOsRootLengthForWatching(typeRootPathComponents, typeRootPathComponents.length),
-      typeRootPathComponents.indexOf("node_modules"),
-      rootPathComponents
-    );
-    return toWatch && filterCustomPath(toWatch.dirPath) ? toWatch.dirPath : void 0;
-  }
-  function getRootDirectoryOfResolutionCache(rootDirForResolution, getCurrentDirectory) {
-    const normalized = getNormalizedAbsolutePath(rootDirForResolution, getCurrentDirectory());
-    return !isDiskPathRoot(normalized) ? removeTrailingDirectorySeparator(normalized) : normalized;
-  }
-  function getRootPathSplitLength(rootPath) {
-    return rootPath.split(directorySeparator).length - (hasTrailingDirectorySeparator(rootPath) ? 1 : 0);
-  }
-  function createResolutionCache(resolutionHost, rootDirForResolution, logChangesWhenResolvingModule) {
-    let filesWithChangedSetOfUnresolvedImports;
-    let filesWithInvalidatedResolutions;
-    let filesWithInvalidatedNonRelativeUnresolvedImports;
-    const nonRelativeExternalModuleResolutions = createMultiMap();
-    const resolutionsWithFailedLookups = /* @__PURE__ */ new Set();
-    const resolutionsWithOnlyAffectingLocations = /* @__PURE__ */ new Set();
-    const resolvedFileToResolution = /* @__PURE__ */ new Map();
-    const impliedFormatPackageJsons = /* @__PURE__ */ new Map();
-    let hasChangedAutomaticTypeDirectiveNames = false;
-    let affectingPathChecksForFile;
-    let affectingPathChecks;
-    let failedLookupChecks;
-    let startsWithPathChecks;
-    let isInDirectoryChecks;
-    let allModuleAndTypeResolutionsAreInvalidated = false;
-    const getCurrentDirectory = memoize(() => resolutionHost.getCurrentDirectory());
-    const cachedDirectoryStructureHost = resolutionHost.getCachedDirectoryStructureHost();
-    const resolvedModuleNames = /* @__PURE__ */ new Map();
-    const moduleResolutionCache = createModuleResolutionCache(
-      getCurrentDirectory(),
-      resolutionHost.getCanonicalFileName,
-      resolutionHost.getCompilationSettings()
-    );
-    const resolvedTypeReferenceDirectives = /* @__PURE__ */ new Map();
-    const typeReferenceDirectiveResolutionCache = createTypeReferenceDirectiveResolutionCache(
-      getCurrentDirectory(),
-      resolutionHost.getCanonicalFileName,
-      resolutionHost.getCompilationSettings(),
-      moduleResolutionCache.getPackageJsonInfoCache()
-    );
-    const resolvedLibraries = /* @__PURE__ */ new Map();
-    const libraryResolutionCache = createModuleResolutionCache(
-      getCurrentDirectory(),
-      resolutionHost.getCanonicalFileName,
-      getOptionsForLibraryResolution(resolutionHost.getCompilationSettings()),
-      moduleResolutionCache.getPackageJsonInfoCache()
-    );
-    const directoryWatchesOfFailedLookups = /* @__PURE__ */ new Map();
-    const fileWatchesOfAffectingLocations = /* @__PURE__ */ new Map();
-    const rootDir = getRootDirectoryOfResolutionCache(rootDirForResolution, getCurrentDirectory);
-    const rootPath = resolutionHost.toPath(rootDir);
-    const rootPathComponents = getPathComponents(rootPath);
-    const typeRootsWatches = /* @__PURE__ */ new Map();
-    return {
-      getModuleResolutionCache: () => moduleResolutionCache,
-      startRecordingFilesWithChangedResolutions,
-      finishRecordingFilesWithChangedResolutions,
-      // perDirectoryResolvedModuleNames and perDirectoryResolvedTypeReferenceDirectives could be non empty if there was exception during program update
-      // (between startCachingPerDirectoryResolution and finishCachingPerDirectoryResolution)
-      startCachingPerDirectoryResolution,
-      finishCachingPerDirectoryResolution,
-      resolveModuleNameLiterals,
-      resolveTypeReferenceDirectiveReferences,
-      resolveLibrary: resolveLibrary2,
-      resolveSingleModuleNameWithoutWatching,
-      removeResolutionsFromProjectReferenceRedirects,
-      removeResolutionsOfFile,
-      hasChangedAutomaticTypeDirectiveNames: () => hasChangedAutomaticTypeDirectiveNames,
-      invalidateResolutionOfFile,
-      invalidateResolutionsOfFailedLookupLocations,
-      setFilesWithInvalidatedNonRelativeUnresolvedImports,
-      createHasInvalidatedResolutions,
-      isFileWithInvalidatedNonRelativeUnresolvedImports,
-      updateTypeRootsWatch,
-      closeTypeRootsWatch,
-      clear: clear2,
-      onChangesAffectModuleResolution
-    };
-    function getResolvedModule2(resolution) {
-      return resolution.resolvedModule;
-    }
-    function getResolvedTypeReferenceDirective2(resolution) {
-      return resolution.resolvedTypeReferenceDirective;
-    }
-    function clear2() {
-      clearMap(directoryWatchesOfFailedLookups, closeFileWatcherOf);
-      clearMap(fileWatchesOfAffectingLocations, closeFileWatcherOf);
-      nonRelativeExternalModuleResolutions.clear();
-      closeTypeRootsWatch();
-      resolvedModuleNames.clear();
-      resolvedTypeReferenceDirectives.clear();
-      resolvedFileToResolution.clear();
-      resolutionsWithFailedLookups.clear();
-      resolutionsWithOnlyAffectingLocations.clear();
-      failedLookupChecks = void 0;
-      startsWithPathChecks = void 0;
-      isInDirectoryChecks = void 0;
-      affectingPathChecks = void 0;
-      affectingPathChecksForFile = void 0;
-      allModuleAndTypeResolutionsAreInvalidated = false;
-      moduleResolutionCache.clear();
-      typeReferenceDirectiveResolutionCache.clear();
-      moduleResolutionCache.update(resolutionHost.getCompilationSettings());
-      typeReferenceDirectiveResolutionCache.update(resolutionHost.getCompilationSettings());
-      libraryResolutionCache.clear();
-      impliedFormatPackageJsons.clear();
-      resolvedLibraries.clear();
-      hasChangedAutomaticTypeDirectiveNames = false;
-    }
-    function onChangesAffectModuleResolution() {
-      allModuleAndTypeResolutionsAreInvalidated = true;
-      moduleResolutionCache.clearAllExceptPackageJsonInfoCache();
-      typeReferenceDirectiveResolutionCache.clearAllExceptPackageJsonInfoCache();
-      moduleResolutionCache.update(resolutionHost.getCompilationSettings());
-      typeReferenceDirectiveResolutionCache.update(resolutionHost.getCompilationSettings());
-    }
-    function startRecordingFilesWithChangedResolutions() {
-      filesWithChangedSetOfUnresolvedImports = [];
-    }
-    function finishRecordingFilesWithChangedResolutions() {
-      const collected = filesWithChangedSetOfUnresolvedImports;
-      filesWithChangedSetOfUnresolvedImports = void 0;
-      return collected;
-    }
-    function isFileWithInvalidatedNonRelativeUnresolvedImports(path) {
-      if (!filesWithInvalidatedNonRelativeUnresolvedImports) {
-        return false;
-      }
-      const value = filesWithInvalidatedNonRelativeUnresolvedImports.get(path);
-      return !!value && !!value.length;
-    }
-    function createHasInvalidatedResolutions(customHasInvalidatedResolutions, customHasInvalidatedLibResolutions) {
-      invalidateResolutionsOfFailedLookupLocations();
-      const collected = filesWithInvalidatedResolutions;
-      filesWithInvalidatedResolutions = void 0;
-      return {
-        hasInvalidatedResolutions: (path) => customHasInvalidatedResolutions(path) || allModuleAndTypeResolutionsAreInvalidated || !!(collected == null ? void 0 : collected.has(path)) || isFileWithInvalidatedNonRelativeUnresolvedImports(path),
-        hasInvalidatedLibResolutions: (libFileName) => {
-          var _a;
-          return customHasInvalidatedLibResolutions(libFileName) || !!((_a = resolvedLibraries == null ? void 0 : resolvedLibraries.get(libFileName)) == null ? void 0 : _a.isInvalidated);
-        }
-      };
-    }
-    function startCachingPerDirectoryResolution() {
-      moduleResolutionCache.clearAllExceptPackageJsonInfoCache();
-      typeReferenceDirectiveResolutionCache.clearAllExceptPackageJsonInfoCache();
-      libraryResolutionCache.clearAllExceptPackageJsonInfoCache();
-      nonRelativeExternalModuleResolutions.forEach(watchFailedLookupLocationOfNonRelativeModuleResolutions);
-      nonRelativeExternalModuleResolutions.clear();
-    }
-    function cleanupLibResolutionWatching(newProgram) {
-      resolvedLibraries.forEach((resolution, libFileName) => {
-        var _a;
-        if (!((_a = newProgram == null ? void 0 : newProgram.resolvedLibReferences) == null ? void 0 : _a.has(libFileName))) {
-          stopWatchFailedLookupLocationOfResolution(
-            resolution,
-            resolutionHost.toPath(getInferredLibraryNameResolveFrom(newProgram.getCompilerOptions(), getCurrentDirectory(), libFileName)),
-            getResolvedModule2
-          );
-          resolvedLibraries.delete(libFileName);
-        }
-      });
-    }
-    function finishCachingPerDirectoryResolution(newProgram, oldProgram) {
-      filesWithInvalidatedNonRelativeUnresolvedImports = void 0;
-      allModuleAndTypeResolutionsAreInvalidated = false;
-      nonRelativeExternalModuleResolutions.forEach(watchFailedLookupLocationOfNonRelativeModuleResolutions);
-      nonRelativeExternalModuleResolutions.clear();
-      if (newProgram !== oldProgram) {
-        cleanupLibResolutionWatching(newProgram);
-        newProgram == null ? void 0 : newProgram.getSourceFiles().forEach((newFile) => {
-          var _a;
-          const expected = isExternalOrCommonJsModule(newFile) ? ((_a = newFile.packageJsonLocations) == null ? void 0 : _a.length) ?? 0 : 0;
-          const existing = impliedFormatPackageJsons.get(newFile.path) ?? emptyArray;
-          for (let i = existing.length; i < expected; i++) {
-            createFileWatcherOfAffectingLocation(
-              newFile.packageJsonLocations[i],
-              /*forResolution*/
-              false
-            );
-          }
-          if (existing.length > expected) {
-            for (let i = expected; i < existing.length; i++) {
-              fileWatchesOfAffectingLocations.get(existing[i]).files--;
-            }
-          }
-          if (expected)
-            impliedFormatPackageJsons.set(newFile.path, newFile.packageJsonLocations);
-          else
-            impliedFormatPackageJsons.delete(newFile.path);
-        });
-        impliedFormatPackageJsons.forEach((existing, path) => {
-          if (!(newProgram == null ? void 0 : newProgram.getSourceFileByPath(path))) {
-            existing.forEach((location) => fileWatchesOfAffectingLocations.get(location).files--);
-            impliedFormatPackageJsons.delete(path);
-          }
-        });
-      }
-      directoryWatchesOfFailedLookups.forEach((watcher, path) => {
-        if (watcher.refCount === 0) {
-          directoryWatchesOfFailedLookups.delete(path);
-          watcher.watcher.close();
-        }
-      });
-      fileWatchesOfAffectingLocations.forEach((watcher, path) => {
-        if (watcher.files === 0 && watcher.resolutions === 0) {
-          fileWatchesOfAffectingLocations.delete(path);
-          watcher.watcher.close();
-        }
-      });
-      hasChangedAutomaticTypeDirectiveNames = false;
-    }
-    function resolveModuleName2(moduleName, containingFile, compilerOptions, redirectedReference, mode) {
-      var _a;
-      const host = ((_a = resolutionHost.getCompilerHost) == null ? void 0 : _a.call(resolutionHost)) || resolutionHost;
-      const primaryResult = resolveModuleName(moduleName, containingFile, compilerOptions, host, moduleResolutionCache, redirectedReference, mode);
-      if (!resolutionHost.getGlobalCache) {
-        return primaryResult;
-      }
-      const globalCache = resolutionHost.getGlobalCache();
-      if (globalCache !== void 0 && !isExternalModuleNameRelative(moduleName) && !(primaryResult.resolvedModule && extensionIsTS(primaryResult.resolvedModule.extension))) {
-        const { resolvedModule, failedLookupLocations, affectingLocations, resolutionDiagnostics } = loadModuleFromGlobalCache(
-          Debug.checkDefined(resolutionHost.globalCacheResolutionModuleName)(moduleName),
-          resolutionHost.projectName,
-          compilerOptions,
-          host,
-          globalCache,
-          moduleResolutionCache
-        );
-        if (resolvedModule) {
-          primaryResult.resolvedModule = resolvedModule;
-          primaryResult.failedLookupLocations = updateResolutionField(primaryResult.failedLookupLocations, failedLookupLocations);
-          primaryResult.affectingLocations = updateResolutionField(primaryResult.affectingLocations, affectingLocations);
-          primaryResult.resolutionDiagnostics = updateResolutionField(primaryResult.resolutionDiagnostics, resolutionDiagnostics);
-          return primaryResult;
-        }
-      }
-      return primaryResult;
-    }
-    function createModuleResolutionLoader2(containingFile, redirectedReference, options) {
-      return {
-        nameAndMode: moduleResolutionNameAndModeGetter,
-        resolve: (moduleName, resoluionMode) => resolveModuleName2(
-          moduleName,
-          containingFile,
-          options,
-          redirectedReference,
-          resoluionMode
-        )
-      };
-    }
-    function resolveNamesWithLocalCache({
-      entries,
-      containingFile,
-      containingSourceFile,
-      redirectedReference,
-      options,
-      perFileCache,
-      reusedNames,
-      loader,
-      getResolutionWithResolvedFileName,
-      deferWatchingNonRelativeResolution,
-      shouldRetryResolution,
-      logChanges
-    }) {
-      var _a;
-      const path = resolutionHost.toPath(containingFile);
-      const resolutionsInFile = perFileCache.get(path) || perFileCache.set(path, createModeAwareCache()).get(path);
-      const resolvedModules = [];
-      const hasInvalidatedNonRelativeUnresolvedImport = logChanges && isFileWithInvalidatedNonRelativeUnresolvedImports(path);
-      const program = resolutionHost.getCurrentProgram();
-      const oldRedirect = program && program.getResolvedProjectReferenceToRedirect(containingFile);
-      const unmatchedRedirects = oldRedirect ? !redirectedReference || redirectedReference.sourceFile.path !== oldRedirect.sourceFile.path : !!redirectedReference;
-      const seenNamesInFile = createModeAwareCache();
-      for (const entry of entries) {
-        const name = loader.nameAndMode.getName(entry);
-        const mode = loader.nameAndMode.getMode(entry, containingSourceFile);
-        let resolution = resolutionsInFile.get(name, mode);
-        if (!seenNamesInFile.has(name, mode) && (allModuleAndTypeResolutionsAreInvalidated || unmatchedRedirects || !resolution || resolution.isInvalidated || // If the name is unresolved import that was invalidated, recalculate
-        hasInvalidatedNonRelativeUnresolvedImport && !isExternalModuleNameRelative(name) && shouldRetryResolution(resolution))) {
-          const existingResolution = resolution;
-          resolution = loader.resolve(name, mode);
-          if (resolutionHost.onDiscoveredSymlink && resolutionIsSymlink(resolution)) {
-            resolutionHost.onDiscoveredSymlink();
-          }
-          resolutionsInFile.set(name, mode, resolution);
-          watchFailedLookupLocationsOfExternalModuleResolutions(name, resolution, path, getResolutionWithResolvedFileName, deferWatchingNonRelativeResolution);
-          if (existingResolution) {
-            stopWatchFailedLookupLocationOfResolution(existingResolution, path, getResolutionWithResolvedFileName);
-          }
-          if (logChanges && filesWithChangedSetOfUnresolvedImports && !resolutionIsEqualTo(existingResolution, resolution)) {
-            filesWithChangedSetOfUnresolvedImports.push(path);
-            logChanges = false;
-          }
-        } else {
-          const host = ((_a = resolutionHost.getCompilerHost) == null ? void 0 : _a.call(resolutionHost)) || resolutionHost;
-          if (isTraceEnabled(options, host) && !seenNamesInFile.has(name, mode)) {
-            const resolved = getResolutionWithResolvedFileName(resolution);
-            trace(
-              host,
-              perFileCache === resolvedModuleNames ? (resolved == null ? void 0 : resolved.resolvedFileName) ? resolved.packageId ? Diagnostics.Reusing_resolution_of_module_0_from_1_of_old_program_it_was_successfully_resolved_to_2_with_Package_ID_3 : Diagnostics.Reusing_resolution_of_module_0_from_1_of_old_program_it_was_successfully_resolved_to_2 : Diagnostics.Reusing_resolution_of_module_0_from_1_of_old_program_it_was_not_resolved : (resolved == null ? void 0 : resolved.resolvedFileName) ? resolved.packageId ? Diagnostics.Reusing_resolution_of_type_reference_directive_0_from_1_of_old_program_it_was_successfully_resolved_to_2_with_Package_ID_3 : Diagnostics.Reusing_resolution_of_type_reference_directive_0_from_1_of_old_program_it_was_successfully_resolved_to_2 : Diagnostics.Reusing_resolution_of_type_reference_directive_0_from_1_of_old_program_it_was_not_resolved,
-              name,
-              containingFile,
-              resolved == null ? void 0 : resolved.resolvedFileName,
-              (resolved == null ? void 0 : resolved.packageId) && packageIdToString(resolved.packageId)
-            );
-          }
-        }
-        Debug.assert(resolution !== void 0 && !resolution.isInvalidated);
-        seenNamesInFile.set(name, mode, true);
-        resolvedModules.push(resolution);
-      }
-      reusedNames == null ? void 0 : reusedNames.forEach((entry) => seenNamesInFile.set(
-        loader.nameAndMode.getName(entry),
-        loader.nameAndMode.getMode(entry, containingSourceFile),
-        true
-      ));
-      if (resolutionsInFile.size() !== seenNamesInFile.size()) {
-        resolutionsInFile.forEach((resolution, name, mode) => {
-          if (!seenNamesInFile.has(name, mode)) {
-            stopWatchFailedLookupLocationOfResolution(resolution, path, getResolutionWithResolvedFileName);
-            resolutionsInFile.delete(name, mode);
-          }
-        });
-      }
-      return resolvedModules;
-      function resolutionIsEqualTo(oldResolution, newResolution) {
-        if (oldResolution === newResolution) {
-          return true;
-        }
-        if (!oldResolution || !newResolution) {
-          return false;
-        }
-        const oldResult = getResolutionWithResolvedFileName(oldResolution);
-        const newResult = getResolutionWithResolvedFileName(newResolution);
-        if (oldResult === newResult) {
-          return true;
-        }
-        if (!oldResult || !newResult) {
-          return false;
-        }
-        return oldResult.resolvedFileName === newResult.resolvedFileName;
-      }
-    }
-    function resolveTypeReferenceDirectiveReferences(typeDirectiveReferences, containingFile, redirectedReference, options, containingSourceFile, reusedNames) {
-      var _a;
-      return resolveNamesWithLocalCache({
-        entries: typeDirectiveReferences,
-        containingFile,
-        containingSourceFile,
-        redirectedReference,
-        options,
-        reusedNames,
-        perFileCache: resolvedTypeReferenceDirectives,
-        loader: createTypeReferenceResolutionLoader(
-          containingFile,
-          redirectedReference,
-          options,
-          ((_a = resolutionHost.getCompilerHost) == null ? void 0 : _a.call(resolutionHost)) || resolutionHost,
-          typeReferenceDirectiveResolutionCache
-        ),
-        getResolutionWithResolvedFileName: getResolvedTypeReferenceDirective2,
-        shouldRetryResolution: (resolution) => resolution.resolvedTypeReferenceDirective === void 0,
-        deferWatchingNonRelativeResolution: false
-      });
-    }
-    function resolveModuleNameLiterals(moduleLiterals, containingFile, redirectedReference, options, containingSourceFile, reusedNames) {
-      return resolveNamesWithLocalCache({
-        entries: moduleLiterals,
-        containingFile,
-        containingSourceFile,
-        redirectedReference,
-        options,
-        reusedNames,
-        perFileCache: resolvedModuleNames,
-        loader: createModuleResolutionLoader2(
-          containingFile,
-          redirectedReference,
-          options
-        ),
-        getResolutionWithResolvedFileName: getResolvedModule2,
-        shouldRetryResolution: (resolution) => !resolution.resolvedModule || !resolutionExtensionIsTSOrJson(resolution.resolvedModule.extension),
-        logChanges: logChangesWhenResolvingModule,
-        deferWatchingNonRelativeResolution: true
-        // Defer non relative resolution watch because we could be using ambient modules
-      });
-    }
-    function resolveLibrary2(libraryName, resolveFrom, options, libFileName) {
-      var _a;
-      const host = ((_a = resolutionHost.getCompilerHost) == null ? void 0 : _a.call(resolutionHost)) || resolutionHost;
-      let resolution = resolvedLibraries == null ? void 0 : resolvedLibraries.get(libFileName);
-      if (!resolution || resolution.isInvalidated) {
-        const existingResolution = resolution;
-        resolution = resolveLibrary(libraryName, resolveFrom, options, host, libraryResolutionCache);
-        const path = resolutionHost.toPath(resolveFrom);
-        watchFailedLookupLocationsOfExternalModuleResolutions(
-          libraryName,
-          resolution,
-          path,
-          getResolvedModule2,
-          /*deferWatchingNonRelativeResolution*/
-          false
-        );
-        resolvedLibraries.set(libFileName, resolution);
-        if (existingResolution) {
-          stopWatchFailedLookupLocationOfResolution(existingResolution, path, getResolvedModule2);
-        }
-      } else {
-        if (isTraceEnabled(options, host)) {
-          const resolved = getResolvedModule2(resolution);
-          trace(
-            host,
-            (resolved == null ? void 0 : resolved.resolvedFileName) ? resolved.packageId ? Diagnostics.Reusing_resolution_of_module_0_from_1_of_old_program_it_was_successfully_resolved_to_2_with_Package_ID_3 : Diagnostics.Reusing_resolution_of_module_0_from_1_of_old_program_it_was_successfully_resolved_to_2 : Diagnostics.Reusing_resolution_of_module_0_from_1_of_old_program_it_was_not_resolved,
-            libraryName,
-            resolveFrom,
-            resolved == null ? void 0 : resolved.resolvedFileName,
-            (resolved == null ? void 0 : resolved.packageId) && packageIdToString(resolved.packageId)
-          );
-        }
-      }
-      return resolution;
-    }
-    function resolveSingleModuleNameWithoutWatching(moduleName, containingFile) {
-      const path = resolutionHost.toPath(containingFile);
-      const resolutionsInFile = resolvedModuleNames.get(path);
-      const resolution = resolutionsInFile == null ? void 0 : resolutionsInFile.get(
-        moduleName,
-        /*mode*/
-        void 0
-      );
-      if (resolution && !resolution.isInvalidated)
-        return resolution;
-      return resolveModuleName2(moduleName, containingFile, resolutionHost.getCompilationSettings());
-    }
-    function isNodeModulesAtTypesDirectory(dirPath) {
-      return endsWith(dirPath, "/node_modules/@types");
-    }
-    function watchFailedLookupLocationsOfExternalModuleResolutions(name, resolution, filePath, getResolutionWithResolvedFileName, deferWatchingNonRelativeResolution) {
-      var _a;
-      if (resolution.refCount) {
-        resolution.refCount++;
-        Debug.assertIsDefined(resolution.files);
-      } else {
-        resolution.refCount = 1;
-        Debug.assert(!((_a = resolution.files) == null ? void 0 : _a.size));
-        if (!deferWatchingNonRelativeResolution || isExternalModuleNameRelative(name)) {
-          watchFailedLookupLocationOfResolution(resolution);
-        } else {
-          nonRelativeExternalModuleResolutions.add(name, resolution);
-        }
-        const resolved = getResolutionWithResolvedFileName(resolution);
-        if (resolved && resolved.resolvedFileName) {
-          const key = resolutionHost.toPath(resolved.resolvedFileName);
-          let resolutions = resolvedFileToResolution.get(key);
-          if (!resolutions)
-            resolvedFileToResolution.set(key, resolutions = /* @__PURE__ */ new Set());
-          resolutions.add(resolution);
-        }
-      }
-      (resolution.files ?? (resolution.files = /* @__PURE__ */ new Set())).add(filePath);
-    }
-    function watchFailedLookupLocation(failedLookupLocation, setAtRoot) {
-      const failedLookupLocationPath = resolutionHost.toPath(failedLookupLocation);
-      const toWatch = getDirectoryToWatchFailedLookupLocation(
-        failedLookupLocation,
-        failedLookupLocationPath,
-        rootDir,
-        rootPath,
-        rootPathComponents,
-        getCurrentDirectory
-      );
-      if (toWatch) {
-        const { dir, dirPath, nonRecursive } = toWatch;
-        if (dirPath === rootPath) {
-          Debug.assert(nonRecursive);
-          setAtRoot = true;
-        } else {
-          setDirectoryWatcher(dir, dirPath, nonRecursive);
-        }
-      }
-      return setAtRoot;
-    }
-    function watchFailedLookupLocationOfResolution(resolution) {
-      Debug.assert(!!resolution.refCount);
-      const { failedLookupLocations, affectingLocations, node10Result } = resolution;
-      if (!(failedLookupLocations == null ? void 0 : failedLookupLocations.length) && !(affectingLocations == null ? void 0 : affectingLocations.length) && !node10Result)
-        return;
-      if ((failedLookupLocations == null ? void 0 : failedLookupLocations.length) || node10Result)
-        resolutionsWithFailedLookups.add(resolution);
-      let setAtRoot = false;
-      if (failedLookupLocations) {
-        for (const failedLookupLocation of failedLookupLocations) {
-          setAtRoot = watchFailedLookupLocation(failedLookupLocation, setAtRoot);
-        }
-      }
-      if (node10Result)
-        setAtRoot = watchFailedLookupLocation(node10Result, setAtRoot);
-      if (setAtRoot) {
-        setDirectoryWatcher(
-          rootDir,
-          rootPath,
-          /*nonRecursive*/
-          true
-        );
-      }
-      watchAffectingLocationsOfResolution(resolution, !(failedLookupLocations == null ? void 0 : failedLookupLocations.length) && !node10Result);
-    }
-    function watchAffectingLocationsOfResolution(resolution, addToResolutionsWithOnlyAffectingLocations) {
-      Debug.assert(!!resolution.refCount);
-      const { affectingLocations } = resolution;
-      if (!(affectingLocations == null ? void 0 : affectingLocations.length))
-        return;
-      if (addToResolutionsWithOnlyAffectingLocations)
-        resolutionsWithOnlyAffectingLocations.add(resolution);
-      for (const affectingLocation of affectingLocations) {
-        createFileWatcherOfAffectingLocation(
-          affectingLocation,
-          /*forResolution*/
-          true
-        );
-      }
-    }
-    function createFileWatcherOfAffectingLocation(affectingLocation, forResolution) {
-      const fileWatcher = fileWatchesOfAffectingLocations.get(affectingLocation);
-      if (fileWatcher) {
-        if (forResolution)
-          fileWatcher.resolutions++;
-        else
-          fileWatcher.files++;
-        return;
-      }
-      let locationToWatch = affectingLocation;
-      if (resolutionHost.realpath) {
-        locationToWatch = resolutionHost.realpath(affectingLocation);
-        if (affectingLocation !== locationToWatch) {
-          const fileWatcher2 = fileWatchesOfAffectingLocations.get(locationToWatch);
-          if (fileWatcher2) {
-            if (forResolution)
-              fileWatcher2.resolutions++;
-            else
-              fileWatcher2.files++;
-            fileWatcher2.paths.add(affectingLocation);
-            fileWatchesOfAffectingLocations.set(affectingLocation, fileWatcher2);
-            return;
-          }
-        }
-      }
-      const paths = /* @__PURE__ */ new Set();
-      paths.add(locationToWatch);
-      let actualWatcher = canWatchAffectingLocation(resolutionHost.toPath(locationToWatch)) ? resolutionHost.watchAffectingFileLocation(locationToWatch, (fileName, eventKind) => {
-        cachedDirectoryStructureHost == null ? void 0 : cachedDirectoryStructureHost.addOrDeleteFile(fileName, resolutionHost.toPath(locationToWatch), eventKind);
-        const packageJsonMap = moduleResolutionCache.getPackageJsonInfoCache().getInternalMap();
-        paths.forEach((path) => {
-          if (watcher.resolutions)
-            (affectingPathChecks ?? (affectingPathChecks = /* @__PURE__ */ new Set())).add(path);
-          if (watcher.files)
-            (affectingPathChecksForFile ?? (affectingPathChecksForFile = /* @__PURE__ */ new Set())).add(path);
-          packageJsonMap == null ? void 0 : packageJsonMap.delete(resolutionHost.toPath(path));
-        });
-        resolutionHost.scheduleInvalidateResolutionsOfFailedLookupLocations();
-      }) : noopFileWatcher;
-      const watcher = {
-        watcher: actualWatcher !== noopFileWatcher ? {
-          close: () => {
-            actualWatcher.close();
-            actualWatcher = noopFileWatcher;
-          }
-        } : actualWatcher,
-        resolutions: forResolution ? 1 : 0,
-        files: forResolution ? 0 : 1,
-        paths
-      };
-      fileWatchesOfAffectingLocations.set(locationToWatch, watcher);
-      if (affectingLocation !== locationToWatch) {
-        fileWatchesOfAffectingLocations.set(affectingLocation, watcher);
-        paths.add(affectingLocation);
-      }
-    }
-    function watchFailedLookupLocationOfNonRelativeModuleResolutions(resolutions, name) {
-      const program = resolutionHost.getCurrentProgram();
-      if (!program || !program.getTypeChecker().tryFindAmbientModuleWithoutAugmentations(name)) {
-        resolutions.forEach(watchFailedLookupLocationOfResolution);
-      } else {
-        resolutions.forEach((resolution) => watchAffectingLocationsOfResolution(
-          resolution,
-          /*addToResolutionsWithOnlyAffectingLocations*/
-          true
-        ));
-      }
-    }
-    function setDirectoryWatcher(dir, dirPath, nonRecursive) {
-      const dirWatcher = directoryWatchesOfFailedLookups.get(dirPath);
-      if (dirWatcher) {
-        Debug.assert(!!nonRecursive === !!dirWatcher.nonRecursive);
-        dirWatcher.refCount++;
-      } else {
-        directoryWatchesOfFailedLookups.set(dirPath, { watcher: createDirectoryWatcher(dir, dirPath, nonRecursive), refCount: 1, nonRecursive });
-      }
-    }
-    function stopWatchFailedLookupLocation(failedLookupLocation, removeAtRoot) {
-      const failedLookupLocationPath = resolutionHost.toPath(failedLookupLocation);
-      const toWatch = getDirectoryToWatchFailedLookupLocation(
-        failedLookupLocation,
-        failedLookupLocationPath,
-        rootDir,
-        rootPath,
-        rootPathComponents,
-        getCurrentDirectory
-      );
-      if (toWatch) {
-        const { dirPath } = toWatch;
-        if (dirPath === rootPath) {
-          removeAtRoot = true;
-        } else {
-          removeDirectoryWatcher(dirPath);
-        }
-      }
-      return removeAtRoot;
-    }
-    function stopWatchFailedLookupLocationOfResolution(resolution, filePath, getResolutionWithResolvedFileName) {
-      Debug.checkDefined(resolution.files).delete(filePath);
-      resolution.refCount--;
-      if (resolution.refCount) {
-        return;
-      }
-      const resolved = getResolutionWithResolvedFileName(resolution);
-      if (resolved && resolved.resolvedFileName) {
-        const key = resolutionHost.toPath(resolved.resolvedFileName);
-        const resolutions = resolvedFileToResolution.get(key);
-        if ((resolutions == null ? void 0 : resolutions.delete(resolution)) && !resolutions.size)
-          resolvedFileToResolution.delete(key);
-      }
-      const { failedLookupLocations, affectingLocations, node10Result } = resolution;
-      if (resolutionsWithFailedLookups.delete(resolution)) {
-        let removeAtRoot = false;
-        if (failedLookupLocations) {
-          for (const failedLookupLocation of failedLookupLocations) {
-            removeAtRoot = stopWatchFailedLookupLocation(failedLookupLocation, removeAtRoot);
-          }
-        }
-        if (node10Result)
-          removeAtRoot = stopWatchFailedLookupLocation(node10Result, removeAtRoot);
-        if (removeAtRoot)
-          removeDirectoryWatcher(rootPath);
-      } else if (affectingLocations == null ? void 0 : affectingLocations.length) {
-        resolutionsWithOnlyAffectingLocations.delete(resolution);
-      }
-      if (affectingLocations) {
-        for (const affectingLocation of affectingLocations) {
-          const watcher = fileWatchesOfAffectingLocations.get(affectingLocation);
-          watcher.resolutions--;
-        }
-      }
-    }
-    function removeDirectoryWatcher(dirPath) {
-      const dirWatcher = directoryWatchesOfFailedLookups.get(dirPath);
-      dirWatcher.refCount--;
-    }
-    function createDirectoryWatcher(directory, dirPath, nonRecursive) {
-      return resolutionHost.watchDirectoryOfFailedLookupLocation(directory, (fileOrDirectory) => {
-        const fileOrDirectoryPath = resolutionHost.toPath(fileOrDirectory);
-        if (cachedDirectoryStructureHost) {
-          cachedDirectoryStructureHost.addOrDeleteFileOrDirectory(fileOrDirectory, fileOrDirectoryPath);
-        }
-        scheduleInvalidateResolutionOfFailedLookupLocation(fileOrDirectoryPath, dirPath === fileOrDirectoryPath);
-      }, nonRecursive ? 0 /* None */ : 1 /* Recursive */);
-    }
-    function removeResolutionsOfFileFromCache(cache, filePath, getResolutionWithResolvedFileName) {
-      const resolutions = cache.get(filePath);
-      if (resolutions) {
-        resolutions.forEach((resolution) => stopWatchFailedLookupLocationOfResolution(resolution, filePath, getResolutionWithResolvedFileName));
-        cache.delete(filePath);
-      }
-    }
-    function removeResolutionsFromProjectReferenceRedirects(filePath) {
-      if (!fileExtensionIs(filePath, ".json" /* Json */))
-        return;
-      const program = resolutionHost.getCurrentProgram();
-      if (!program)
-        return;
-      const resolvedProjectReference = program.getResolvedProjectReferenceByPath(filePath);
-      if (!resolvedProjectReference)
-        return;
-      resolvedProjectReference.commandLine.fileNames.forEach((f) => removeResolutionsOfFile(resolutionHost.toPath(f)));
-    }
-    function removeResolutionsOfFile(filePath) {
-      removeResolutionsOfFileFromCache(resolvedModuleNames, filePath, getResolvedModule2);
-      removeResolutionsOfFileFromCache(resolvedTypeReferenceDirectives, filePath, getResolvedTypeReferenceDirective2);
-    }
-    function invalidateResolutions(resolutions, canInvalidate) {
-      if (!resolutions)
-        return false;
-      let invalidated = false;
-      resolutions.forEach((resolution) => {
-        if (resolution.isInvalidated || !canInvalidate(resolution))
-          return;
-        resolution.isInvalidated = invalidated = true;
-        for (const containingFilePath of Debug.checkDefined(resolution.files)) {
-          (filesWithInvalidatedResolutions ?? (filesWithInvalidatedResolutions = /* @__PURE__ */ new Set())).add(containingFilePath);
-          hasChangedAutomaticTypeDirectiveNames = hasChangedAutomaticTypeDirectiveNames || endsWith(containingFilePath, inferredTypesContainingFile);
-        }
-      });
-      return invalidated;
-    }
-    function invalidateResolutionOfFile(filePath) {
-      removeResolutionsOfFile(filePath);
-      const prevHasChangedAutomaticTypeDirectiveNames = hasChangedAutomaticTypeDirectiveNames;
-      if (invalidateResolutions(resolvedFileToResolution.get(filePath), returnTrue) && hasChangedAutomaticTypeDirectiveNames && !prevHasChangedAutomaticTypeDirectiveNames) {
-        resolutionHost.onChangedAutomaticTypeDirectiveNames();
-      }
-    }
-    function setFilesWithInvalidatedNonRelativeUnresolvedImports(filesMap) {
-      Debug.assert(filesWithInvalidatedNonRelativeUnresolvedImports === filesMap || filesWithInvalidatedNonRelativeUnresolvedImports === void 0);
-      filesWithInvalidatedNonRelativeUnresolvedImports = filesMap;
-    }
-    function scheduleInvalidateResolutionOfFailedLookupLocation(fileOrDirectoryPath, isCreatingWatchedDirectory) {
-      if (isCreatingWatchedDirectory) {
-        (isInDirectoryChecks || (isInDirectoryChecks = /* @__PURE__ */ new Set())).add(fileOrDirectoryPath);
-      } else {
-        const updatedPath = removeIgnoredPath(fileOrDirectoryPath);
-        if (!updatedPath)
-          return false;
-        fileOrDirectoryPath = updatedPath;
-        if (resolutionHost.fileIsOpen(fileOrDirectoryPath)) {
-          return false;
-        }
-        const dirOfFileOrDirectory = getDirectoryPath(fileOrDirectoryPath);
-        if (isNodeModulesAtTypesDirectory(fileOrDirectoryPath) || isNodeModulesDirectory(fileOrDirectoryPath) || isNodeModulesAtTypesDirectory(dirOfFileOrDirectory) || isNodeModulesDirectory(dirOfFileOrDirectory)) {
-          (failedLookupChecks || (failedLookupChecks = /* @__PURE__ */ new Set())).add(fileOrDirectoryPath);
-          (startsWithPathChecks || (startsWithPathChecks = /* @__PURE__ */ new Set())).add(fileOrDirectoryPath);
-        } else {
-          if (isEmittedFileOfProgram(resolutionHost.getCurrentProgram(), fileOrDirectoryPath)) {
-            return false;
-          }
-          if (fileExtensionIs(fileOrDirectoryPath, ".map")) {
-            return false;
-          }
-          (failedLookupChecks || (failedLookupChecks = /* @__PURE__ */ new Set())).add(fileOrDirectoryPath);
-          const packagePath = parseNodeModuleFromPath(
-            fileOrDirectoryPath,
-            /*isFolder*/
-            true
-          );
-          if (packagePath)
-            (startsWithPathChecks || (startsWithPathChecks = /* @__PURE__ */ new Set())).add(packagePath);
-        }
-      }
-      resolutionHost.scheduleInvalidateResolutionsOfFailedLookupLocations();
-    }
-    function invalidatePackageJsonMap() {
-      const packageJsonMap = moduleResolutionCache.getPackageJsonInfoCache().getInternalMap();
-      if (packageJsonMap && (failedLookupChecks || startsWithPathChecks || isInDirectoryChecks)) {
-        packageJsonMap.forEach((_value, path) => isInvalidatedFailedLookup(path) ? packageJsonMap.delete(path) : void 0);
-      }
-    }
-    function invalidateResolutionsOfFailedLookupLocations() {
-      var _a;
-      if (allModuleAndTypeResolutionsAreInvalidated) {
-        affectingPathChecksForFile = void 0;
-        invalidatePackageJsonMap();
-        if (failedLookupChecks || startsWithPathChecks || isInDirectoryChecks || affectingPathChecks) {
-          invalidateResolutions(resolvedLibraries, canInvalidateFailedLookupResolution);
-        }
-        failedLookupChecks = void 0;
-        startsWithPathChecks = void 0;
-        isInDirectoryChecks = void 0;
-        affectingPathChecks = void 0;
-        return true;
-      }
-      let invalidated = false;
-      if (affectingPathChecksForFile) {
-        (_a = resolutionHost.getCurrentProgram()) == null ? void 0 : _a.getSourceFiles().forEach((f) => {
-          if (some(f.packageJsonLocations, (location) => affectingPathChecksForFile.has(location))) {
-            (filesWithInvalidatedResolutions ?? (filesWithInvalidatedResolutions = /* @__PURE__ */ new Set())).add(f.path);
-            invalidated = true;
-          }
-        });
-        affectingPathChecksForFile = void 0;
-      }
-      if (!failedLookupChecks && !startsWithPathChecks && !isInDirectoryChecks && !affectingPathChecks) {
-        return invalidated;
-      }
-      invalidated = invalidateResolutions(resolutionsWithFailedLookups, canInvalidateFailedLookupResolution) || invalidated;
-      invalidatePackageJsonMap();
-      failedLookupChecks = void 0;
-      startsWithPathChecks = void 0;
-      isInDirectoryChecks = void 0;
-      invalidated = invalidateResolutions(resolutionsWithOnlyAffectingLocations, canInvalidatedFailedLookupResolutionWithAffectingLocation) || invalidated;
-      affectingPathChecks = void 0;
-      return invalidated;
-    }
-    function canInvalidateFailedLookupResolution(resolution) {
-      var _a;
-      if (canInvalidatedFailedLookupResolutionWithAffectingLocation(resolution))
-        return true;
-      if (!failedLookupChecks && !startsWithPathChecks && !isInDirectoryChecks)
-        return false;
-      return ((_a = resolution.failedLookupLocations) == null ? void 0 : _a.some((location) => isInvalidatedFailedLookup(resolutionHost.toPath(location)))) || !!resolution.node10Result && isInvalidatedFailedLookup(resolutionHost.toPath(resolution.node10Result));
-    }
-    function isInvalidatedFailedLookup(locationPath) {
-      return (failedLookupChecks == null ? void 0 : failedLookupChecks.has(locationPath)) || firstDefinedIterator((startsWithPathChecks == null ? void 0 : startsWithPathChecks.keys()) || [], (fileOrDirectoryPath) => startsWith(locationPath, fileOrDirectoryPath) ? true : void 0) || firstDefinedIterator((isInDirectoryChecks == null ? void 0 : isInDirectoryChecks.keys()) || [], (dirPath) => locationPath.length > dirPath.length && startsWith(locationPath, dirPath) && (isDiskPathRoot(dirPath) || locationPath[dirPath.length] === directorySeparator) ? true : void 0);
-    }
-    function canInvalidatedFailedLookupResolutionWithAffectingLocation(resolution) {
-      var _a;
-      return !!affectingPathChecks && ((_a = resolution.affectingLocations) == null ? void 0 : _a.some((location) => affectingPathChecks.has(location)));
-    }
-    function closeTypeRootsWatch() {
-      clearMap(typeRootsWatches, closeFileWatcher);
-    }
-    function createTypeRootsWatch(typeRootPath, typeRoot) {
-      return canWatchTypeRootPath(typeRootPath) ? resolutionHost.watchTypeRootsDirectory(typeRoot, (fileOrDirectory) => {
-        const fileOrDirectoryPath = resolutionHost.toPath(fileOrDirectory);
-        if (cachedDirectoryStructureHost) {
-          cachedDirectoryStructureHost.addOrDeleteFileOrDirectory(fileOrDirectory, fileOrDirectoryPath);
-        }
-        hasChangedAutomaticTypeDirectiveNames = true;
-        resolutionHost.onChangedAutomaticTypeDirectiveNames();
-        const dirPath = getDirectoryToWatchFailedLookupLocationFromTypeRoot(
-          typeRoot,
-          typeRootPath,
-          rootPath,
-          rootPathComponents,
-          getCurrentDirectory,
-          (dirPath2) => directoryWatchesOfFailedLookups.has(dirPath2)
-        );
-        if (dirPath) {
-          scheduleInvalidateResolutionOfFailedLookupLocation(fileOrDirectoryPath, dirPath === fileOrDirectoryPath);
-        }
-      }, 1 /* Recursive */) : noopFileWatcher;
-    }
-    function updateTypeRootsWatch() {
-      const options = resolutionHost.getCompilationSettings();
-      if (options.types) {
-        closeTypeRootsWatch();
-        return;
-      }
-      const typeRoots = getEffectiveTypeRoots(options, { getCurrentDirectory });
-      if (typeRoots) {
-        mutateMap(
-          typeRootsWatches,
-          arrayToMap(typeRoots, (tr) => resolutionHost.toPath(tr)),
-          {
-            createNewValue: createTypeRootsWatch,
-            onDeleteValue: closeFileWatcher
-          }
-        );
-      } else {
-        closeTypeRootsWatch();
-      }
-    }
-    function canWatchTypeRootPath(typeRoot) {
-      if (resolutionHost.getCompilationSettings().typeRoots)
-        return true;
-      return canWatchAtTypes(resolutionHost.toPath(typeRoot));
-    }
-  }
-  function resolutionIsSymlink(resolution) {
-    var _a, _b;
-    return !!(((_a = resolution.resolvedModule) == null ? void 0 : _a.originalPath) || ((_b = resolution.resolvedTypeReferenceDirective) == null ? void 0 : _b.originalPath));
-  }
-  var init_resolutionCache = __esm({
-    "src/compiler/resolutionCache.ts"() {
-      "use strict";
-      init_ts2();
-    }
-  });
-
-  // src/compiler/watch.ts
-  function createDiagnosticReporter(system, pretty) {
-    const host = system === sys && sysFormatDiagnosticsHost ? sysFormatDiagnosticsHost : {
-      getCurrentDirectory: () => system.getCurrentDirectory(),
-      getNewLine: () => system.newLine,
-      getCanonicalFileName: createGetCanonicalFileName(system.useCaseSensitiveFileNames)
-    };
-    if (!pretty) {
-      return (diagnostic) => system.write(formatDiagnostic(diagnostic, host));
-    }
-    const diagnostics = new Array(1);
-    return (diagnostic) => {
-      diagnostics[0] = diagnostic;
-      system.write(formatDiagnosticsWithColorAndContext(diagnostics, host) + host.getNewLine());
-      diagnostics[0] = void 0;
-    };
-  }
-  function clearScreenIfNotWatchingForFileChanges(system, diagnostic, options) {
-    if (system.clearScreen && !options.preserveWatchOutput && !options.extendedDiagnostics && !options.diagnostics && contains(screenStartingMessageCodes, diagnostic.code)) {
-      system.clearScreen();
-      return true;
-    }
-    return false;
-  }
-  function getPlainDiagnosticFollowingNewLines(diagnostic, newLine) {
-    return contains(screenStartingMessageCodes, diagnostic.code) ? newLine + newLine : newLine;
-  }
-  function getLocaleTimeString(system) {
-    return !system.now ? (/* @__PURE__ */ new Date()).toLocaleTimeString() : (
-      // On some systems / builds of Node, there's a non-breaking space between the time and AM/PM.
-      // This branch is solely for testing, so just switch it to a normal space for baseline stability.
-      // See:
-      //     - https://github.com/nodejs/node/issues/45171
-      //     - https://github.com/nodejs/node/issues/45753
-      system.now().toLocaleTimeString("en-US", { timeZone: "UTC" }).replace("\u202F", " ")
-    );
-  }
-  function createWatchStatusReporter(system, pretty) {
-    return pretty ? (diagnostic, newLine, options) => {
-      clearScreenIfNotWatchingForFileChanges(system, diagnostic, options);
-      let output = `[${formatColorAndReset(getLocaleTimeString(system), "\x1B[90m" /* Grey */)}] `;
-      output += `${flattenDiagnosticMessageText(diagnostic.messageText, system.newLine)}${newLine + newLine}`;
-      system.write(output);
-    } : (diagnostic, newLine, options) => {
-      let output = "";
-      if (!clearScreenIfNotWatchingForFileChanges(system, diagnostic, options)) {
-        output += newLine;
-      }
-      output += `${getLocaleTimeString(system)} - `;
-      output += `${flattenDiagnosticMessageText(diagnostic.messageText, system.newLine)}${getPlainDiagnosticFollowingNewLines(diagnostic, newLine)}`;
-      system.write(output);
-    };
-  }
-  function parseConfigFileWithSystem(configFileName, optionsToExtend, extendedConfigCache, watchOptionsToExtend, system, reportDiagnostic) {
-    const host = system;
-    host.onUnRecoverableConfigFileDiagnostic = (diagnostic) => reportUnrecoverableDiagnostic(system, reportDiagnostic, diagnostic);
-    const result = getParsedCommandLineOfConfigFile(configFileName, optionsToExtend, host, extendedConfigCache, watchOptionsToExtend);
-    host.onUnRecoverableConfigFileDiagnostic = void 0;
-    return result;
-  }
-  function getErrorCountForSummary(diagnostics) {
-    return countWhere(diagnostics, (diagnostic) => diagnostic.category === 1 /* Error */);
-  }
-  function getFilesInErrorForSummary(diagnostics) {
-    const filesInError = filter(diagnostics, (diagnostic) => diagnostic.category === 1 /* Error */).map(
-      (errorDiagnostic) => {
-        if (errorDiagnostic.file === void 0)
-          return;
-        return `${errorDiagnostic.file.fileName}`;
-      }
-    );
-    return filesInError.map((fileName) => {
-      if (fileName === void 0) {
-        return void 0;
-      }
-      const diagnosticForFileName = find(
-        diagnostics,
-        (diagnostic) => diagnostic.file !== void 0 && diagnostic.file.fileName === fileName
-      );
-      if (diagnosticForFileName !== void 0) {
-        const { line } = getLineAndCharacterOfPosition(diagnosticForFileName.file, diagnosticForFileName.start);
-        return {
-          fileName,
-          line: line + 1
-        };
-      }
-    });
-  }
-  function getWatchErrorSummaryDiagnosticMessage(errorCount) {
-    return errorCount === 1 ? Diagnostics.Found_1_error_Watching_for_file_changes : Diagnostics.Found_0_errors_Watching_for_file_changes;
-  }
-  function prettyPathForFileError(error, cwd) {
-    const line = formatColorAndReset(":" + error.line, "\x1B[90m" /* Grey */);
-    if (pathIsAbsolute(error.fileName) && pathIsAbsolute(cwd)) {
-      return getRelativePathFromDirectory(
-        cwd,
-        error.fileName,
-        /*ignoreCase*/
-        false
-      ) + line;
-    }
-    return error.fileName + line;
-  }
-  function getErrorSummaryText(errorCount, filesInError, newLine, host) {
-    if (errorCount === 0)
-      return "";
-    const nonNilFiles = filesInError.filter((fileInError) => fileInError !== void 0);
-    const distinctFileNamesWithLines = nonNilFiles.map((fileInError) => `${fileInError.fileName}:${fileInError.line}`).filter((value, index, self) => self.indexOf(value) === index);
-    const firstFileReference = nonNilFiles[0] && prettyPathForFileError(nonNilFiles[0], host.getCurrentDirectory());
-    let messageAndArgs;
-    if (errorCount === 1) {
-      messageAndArgs = filesInError[0] !== void 0 ? [Diagnostics.Found_1_error_in_0, firstFileReference] : [Diagnostics.Found_1_error];
-    } else {
-      messageAndArgs = distinctFileNamesWithLines.length === 0 ? [Diagnostics.Found_0_errors, errorCount] : distinctFileNamesWithLines.length === 1 ? [Diagnostics.Found_0_errors_in_the_same_file_starting_at_Colon_1, errorCount, firstFileReference] : [Diagnostics.Found_0_errors_in_1_files, errorCount, distinctFileNamesWithLines.length];
-    }
-    const d = createCompilerDiagnostic(...messageAndArgs);
-    const suffix = distinctFileNamesWithLines.length > 1 ? createTabularErrorsDisplay(nonNilFiles, host) : "";
-    return `${newLine}${flattenDiagnosticMessageText(d.messageText, newLine)}${newLine}${newLine}${suffix}`;
-  }
-  function createTabularErrorsDisplay(filesInError, host) {
-    const distinctFiles = filesInError.filter((value, index, self) => index === self.findIndex((file) => (file == null ? void 0 : file.fileName) === (value == null ? void 0 : value.fileName)));
-    if (distinctFiles.length === 0)
-      return "";
-    const numberLength = (num) => Math.log(num) * Math.LOG10E + 1;
-    const fileToErrorCount = distinctFiles.map((file) => [file, countWhere(filesInError, (fileInError) => fileInError.fileName === file.fileName)]);
-    const maxErrors = fileToErrorCount.reduce((acc, value) => Math.max(acc, value[1] || 0), 0);
-    const headerRow = Diagnostics.Errors_Files.message;
-    const leftColumnHeadingLength = headerRow.split(" ")[0].length;
-    const leftPaddingGoal = Math.max(leftColumnHeadingLength, numberLength(maxErrors));
-    const headerPadding = Math.max(numberLength(maxErrors) - leftColumnHeadingLength, 0);
-    let tabularData = "";
-    tabularData += " ".repeat(headerPadding) + headerRow + "\n";
-    fileToErrorCount.forEach((row) => {
-      const [file, errorCount] = row;
-      const errorCountDigitsLength = Math.log(errorCount) * Math.LOG10E + 1 | 0;
-      const leftPadding = errorCountDigitsLength < leftPaddingGoal ? " ".repeat(leftPaddingGoal - errorCountDigitsLength) : "";
-      const fileRef = prettyPathForFileError(file, host.getCurrentDirectory());
-      tabularData += `${leftPadding}${errorCount}  ${fileRef}
-`;
-    });
-    return tabularData;
-  }
-  function isBuilderProgram2(program) {
-    return !!program.getState;
-  }
-  function listFiles(program, write) {
-    const options = program.getCompilerOptions();
-    if (options.explainFiles) {
-      explainFiles(isBuilderProgram2(program) ? program.getProgram() : program, write);
-    } else if (options.listFiles || options.listFilesOnly) {
-      forEach(program.getSourceFiles(), (file) => {
-        write(file.fileName);
-      });
-    }
-  }
-  function explainFiles(program, write) {
-    var _a, _b;
-    const reasons = program.getFileIncludeReasons();
-    const relativeFileName = (fileName) => convertToRelativePath(fileName, program.getCurrentDirectory(), program.getCanonicalFileName);
-    for (const file of program.getSourceFiles()) {
-      write(`${toFileName(file, relativeFileName)}`);
-      (_a = reasons.get(file.path)) == null ? void 0 : _a.forEach((reason) => write(`  ${fileIncludeReasonToDiagnostics(program, reason, relativeFileName).messageText}`));
-      (_b = explainIfFileIsRedirectAndImpliedFormat(file, relativeFileName)) == null ? void 0 : _b.forEach((d) => write(`  ${d.messageText}`));
-    }
-  }
-  function explainIfFileIsRedirectAndImpliedFormat(file, fileNameConvertor) {
-    var _a;
-    let result;
-    if (file.path !== file.resolvedPath) {
-      (result ?? (result = [])).push(chainDiagnosticMessages(
-        /*details*/
-        void 0,
-        Diagnostics.File_is_output_of_project_reference_source_0,
-        toFileName(file.originalFileName, fileNameConvertor)
-      ));
-    }
-    if (file.redirectInfo) {
-      (result ?? (result = [])).push(chainDiagnosticMessages(
-        /*details*/
-        void 0,
-        Diagnostics.File_redirects_to_file_0,
-        toFileName(file.redirectInfo.redirectTarget, fileNameConvertor)
-      ));
-    }
-    if (isExternalOrCommonJsModule(file)) {
-      switch (file.impliedNodeFormat) {
-        case 99 /* ESNext */:
-          if (file.packageJsonScope) {
-            (result ?? (result = [])).push(chainDiagnosticMessages(
-              /*details*/
-              void 0,
-              Diagnostics.File_is_ECMAScript_module_because_0_has_field_type_with_value_module,
-              toFileName(last(file.packageJsonLocations), fileNameConvertor)
-            ));
-          }
-          break;
-        case 1 /* CommonJS */:
-          if (file.packageJsonScope) {
-            (result ?? (result = [])).push(chainDiagnosticMessages(
-              /*details*/
-              void 0,
-              file.packageJsonScope.contents.packageJsonContent.type ? Diagnostics.File_is_CommonJS_module_because_0_has_field_type_whose_value_is_not_module : Diagnostics.File_is_CommonJS_module_because_0_does_not_have_field_type,
-              toFileName(last(file.packageJsonLocations), fileNameConvertor)
-            ));
-          } else if ((_a = file.packageJsonLocations) == null ? void 0 : _a.length) {
-            (result ?? (result = [])).push(chainDiagnosticMessages(
-              /*details*/
-              void 0,
-              Diagnostics.File_is_CommonJS_module_because_package_json_was_not_found
-            ));
-          }
-          break;
-      }
-    }
-    return result;
-  }
-  function getMatchedFileSpec(program, fileName) {
-    var _a;
-    const configFile = program.getCompilerOptions().configFile;
-    if (!((_a = configFile == null ? void 0 : configFile.configFileSpecs) == null ? void 0 : _a.validatedFilesSpec))
-      return void 0;
-    const filePath = program.getCanonicalFileName(fileName);
-    const basePath = getDirectoryPath(getNormalizedAbsolutePath(configFile.fileName, program.getCurrentDirectory()));
-    return find(configFile.configFileSpecs.validatedFilesSpec, (fileSpec) => program.getCanonicalFileName(getNormalizedAbsolutePath(fileSpec, basePath)) === filePath);
-  }
-  function getMatchedIncludeSpec(program, fileName) {
-    var _a, _b;
-    const configFile = program.getCompilerOptions().configFile;
-    if (!((_a = configFile == null ? void 0 : configFile.configFileSpecs) == null ? void 0 : _a.validatedIncludeSpecs))
-      return void 0;
-    if (configFile.configFileSpecs.isDefaultIncludeSpec)
-      return true;
-    const isJsonFile = fileExtensionIs(fileName, ".json" /* Json */);
-    const basePath = getDirectoryPath(getNormalizedAbsolutePath(configFile.fileName, program.getCurrentDirectory()));
-    const useCaseSensitiveFileNames = program.useCaseSensitiveFileNames();
-    return find((_b = configFile == null ? void 0 : configFile.configFileSpecs) == null ? void 0 : _b.validatedIncludeSpecs, (includeSpec) => {
-      if (isJsonFile && !endsWith(includeSpec, ".json" /* Json */))
-        return false;
-      const pattern = getPatternFromSpec(includeSpec, basePath, "files");
-      return !!pattern && getRegexFromPattern(`(${pattern})$`, useCaseSensitiveFileNames).test(fileName);
-    });
-  }
-  function fileIncludeReasonToDiagnostics(program, reason, fileNameConvertor) {
-    var _a, _b;
-    const options = program.getCompilerOptions();
-    if (isReferencedFile(reason)) {
-      const referenceLocation = getReferencedFileLocation((path) => program.getSourceFileByPath(path), reason);
-      const referenceText = isReferenceFileLocation(referenceLocation) ? referenceLocation.file.text.substring(referenceLocation.pos, referenceLocation.end) : `"${referenceLocation.text}"`;
-      let message;
-      Debug.assert(isReferenceFileLocation(referenceLocation) || reason.kind === 3 /* Import */, "Only synthetic references are imports");
-      switch (reason.kind) {
-        case 3 /* Import */:
-          if (isReferenceFileLocation(referenceLocation)) {
-            message = referenceLocation.packageId ? Diagnostics.Imported_via_0_from_file_1_with_packageId_2 : Diagnostics.Imported_via_0_from_file_1;
-          } else if (referenceLocation.text === externalHelpersModuleNameText) {
-            message = referenceLocation.packageId ? Diagnostics.Imported_via_0_from_file_1_with_packageId_2_to_import_importHelpers_as_specified_in_compilerOptions : Diagnostics.Imported_via_0_from_file_1_to_import_importHelpers_as_specified_in_compilerOptions;
-          } else {
-            message = referenceLocation.packageId ? Diagnostics.Imported_via_0_from_file_1_with_packageId_2_to_import_jsx_and_jsxs_factory_functions : Diagnostics.Imported_via_0_from_file_1_to_import_jsx_and_jsxs_factory_functions;
-          }
-          break;
-        case 4 /* ReferenceFile */:
-          Debug.assert(!referenceLocation.packageId);
-          message = Diagnostics.Referenced_via_0_from_file_1;
-          break;
-        case 5 /* TypeReferenceDirective */:
-          message = referenceLocation.packageId ? Diagnostics.Type_library_referenced_via_0_from_file_1_with_packageId_2 : Diagnostics.Type_library_referenced_via_0_from_file_1;
-          break;
-        case 7 /* LibReferenceDirective */:
-          Debug.assert(!referenceLocation.packageId);
-          message = Diagnostics.Library_referenced_via_0_from_file_1;
-          break;
-        default:
-          Debug.assertNever(reason);
-      }
-      return chainDiagnosticMessages(
-        /*details*/
-        void 0,
-        message,
-        referenceText,
-        toFileName(referenceLocation.file, fileNameConvertor),
-        referenceLocation.packageId && packageIdToString(referenceLocation.packageId)
-      );
-    }
-    switch (reason.kind) {
-      case 0 /* RootFile */:
-        if (!((_a = options.configFile) == null ? void 0 : _a.configFileSpecs))
-          return chainDiagnosticMessages(
-            /*details*/
-            void 0,
-            Diagnostics.Root_file_specified_for_compilation
-          );
-        const fileName = getNormalizedAbsolutePath(program.getRootFileNames()[reason.index], program.getCurrentDirectory());
-        const matchedByFiles = getMatchedFileSpec(program, fileName);
-        if (matchedByFiles)
-          return chainDiagnosticMessages(
-            /*details*/
-            void 0,
-            Diagnostics.Part_of_files_list_in_tsconfig_json
-          );
-        const matchedByInclude = getMatchedIncludeSpec(program, fileName);
-        return isString(matchedByInclude) ? chainDiagnosticMessages(
-          /*details*/
-          void 0,
-          Diagnostics.Matched_by_include_pattern_0_in_1,
-          matchedByInclude,
-          toFileName(options.configFile, fileNameConvertor)
-        ) : (
-          // Could be additional files specified as roots or matched by default include
-          chainDiagnosticMessages(
-            /*details*/
-            void 0,
-            matchedByInclude ? Diagnostics.Matched_by_default_include_pattern_Asterisk_Asterisk_Slash_Asterisk : Diagnostics.Root_file_specified_for_compilation
-          )
-        );
-      case 1 /* SourceFromProjectReference */:
-      case 2 /* OutputFromProjectReference */:
-        const isOutput = reason.kind === 2 /* OutputFromProjectReference */;
-        const referencedResolvedRef = Debug.checkDefined((_b = program.getResolvedProjectReferences()) == null ? void 0 : _b[reason.index]);
-        return chainDiagnosticMessages(
-          /*details*/
-          void 0,
-          outFile(options) ? isOutput ? Diagnostics.Output_from_referenced_project_0_included_because_1_specified : Diagnostics.Source_from_referenced_project_0_included_because_1_specified : isOutput ? Diagnostics.Output_from_referenced_project_0_included_because_module_is_specified_as_none : Diagnostics.Source_from_referenced_project_0_included_because_module_is_specified_as_none,
-          toFileName(referencedResolvedRef.sourceFile.fileName, fileNameConvertor),
-          options.outFile ? "--outFile" : "--out"
-        );
-      case 8 /* AutomaticTypeDirectiveFile */: {
-        const messageAndArgs = options.types ? reason.packageId ? [Diagnostics.Entry_point_of_type_library_0_specified_in_compilerOptions_with_packageId_1, reason.typeReference, packageIdToString(reason.packageId)] : [Diagnostics.Entry_point_of_type_library_0_specified_in_compilerOptions, reason.typeReference] : reason.packageId ? [Diagnostics.Entry_point_for_implicit_type_library_0_with_packageId_1, reason.typeReference, packageIdToString(reason.packageId)] : [Diagnostics.Entry_point_for_implicit_type_library_0, reason.typeReference];
-        return chainDiagnosticMessages(
-          /*details*/
-          void 0,
-          ...messageAndArgs
-        );
-      }
-      case 6 /* LibFile */: {
-        if (reason.index !== void 0)
-          return chainDiagnosticMessages(
-            /*details*/
-            void 0,
-            Diagnostics.Library_0_specified_in_compilerOptions,
-            options.lib[reason.index]
-          );
-        const target = forEachEntry(targetOptionDeclaration.type, (value, key) => value === getEmitScriptTarget(options) ? key : void 0);
-        const messageAndArgs = target ? [Diagnostics.Default_library_for_target_0, target] : [Diagnostics.Default_library];
-        return chainDiagnosticMessages(
-          /*details*/
-          void 0,
-          ...messageAndArgs
-        );
-      }
-      default:
-        Debug.assertNever(reason);
-    }
-  }
-  function toFileName(file, fileNameConvertor) {
-    const fileName = isString(file) ? file : file.fileName;
-    return fileNameConvertor ? fileNameConvertor(fileName) : fileName;
-  }
-  function emitFilesAndReportErrors(program, reportDiagnostic, write, reportSummary, writeFile2, cancellationToken, emitOnlyDtsFiles, customTransformers) {
-    const isListFilesOnly = !!program.getCompilerOptions().listFilesOnly;
-    const allDiagnostics = program.getConfigFileParsingDiagnostics().slice();
-    const configFileParsingDiagnosticsLength = allDiagnostics.length;
-    addRange(allDiagnostics, program.getSyntacticDiagnostics(
-      /*sourceFile*/
-      void 0,
-      cancellationToken
-    ));
-    if (allDiagnostics.length === configFileParsingDiagnosticsLength) {
-      addRange(allDiagnostics, program.getOptionsDiagnostics(cancellationToken));
-      if (!isListFilesOnly) {
-        addRange(allDiagnostics, program.getGlobalDiagnostics(cancellationToken));
-        if (allDiagnostics.length === configFileParsingDiagnosticsLength) {
-          addRange(allDiagnostics, program.getSemanticDiagnostics(
-            /*sourceFile*/
-            void 0,
-            cancellationToken
-          ));
-        }
-      }
-    }
-    const emitResult = isListFilesOnly ? { emitSkipped: true, diagnostics: emptyArray } : program.emit(
-      /*targetSourceFile*/
-      void 0,
-      writeFile2,
-      cancellationToken,
-      emitOnlyDtsFiles,
-      customTransformers
-    );
-    const { emittedFiles, diagnostics: emitDiagnostics } = emitResult;
-    addRange(allDiagnostics, emitDiagnostics);
-    const diagnostics = sortAndDeduplicateDiagnostics(allDiagnostics);
-    diagnostics.forEach(reportDiagnostic);
-    if (write) {
-      const currentDir = program.getCurrentDirectory();
-      forEach(emittedFiles, (file) => {
-        const filepath = getNormalizedAbsolutePath(file, currentDir);
-        write(`TSFILE: ${filepath}`);
-      });
-      listFiles(program, write);
-    }
-    if (reportSummary) {
-      reportSummary(getErrorCountForSummary(diagnostics), getFilesInErrorForSummary(diagnostics));
-    }
-    return {
-      emitResult,
-      diagnostics
-    };
-  }
-  function emitFilesAndReportErrorsAndGetExitStatus(program, reportDiagnostic, write, reportSummary, writeFile2, cancellationToken, emitOnlyDtsFiles, customTransformers) {
-    const { emitResult, diagnostics } = emitFilesAndReportErrors(
-      program,
-      reportDiagnostic,
-      write,
-      reportSummary,
-      writeFile2,
-      cancellationToken,
-      emitOnlyDtsFiles,
-      customTransformers
-    );
-    if (emitResult.emitSkipped && diagnostics.length > 0) {
-      return 1 /* DiagnosticsPresent_OutputsSkipped */;
-    } else if (diagnostics.length > 0) {
-      return 2 /* DiagnosticsPresent_OutputsGenerated */;
-    }
-    return 0 /* Success */;
-  }
-  function createWatchHost(system = sys, reportWatchStatus2) {
-    const onWatchStatusChange = reportWatchStatus2 || createWatchStatusReporter(system);
-    return {
-      onWatchStatusChange,
-      watchFile: maybeBind(system, system.watchFile) || returnNoopFileWatcher,
-      watchDirectory: maybeBind(system, system.watchDirectory) || returnNoopFileWatcher,
-      setTimeout: maybeBind(system, system.setTimeout) || noop,
-      clearTimeout: maybeBind(system, system.clearTimeout) || noop
-    };
-  }
-  function createWatchFactory(host, options) {
-    const watchLogLevel = host.trace ? options.extendedDiagnostics ? 2 /* Verbose */ : options.diagnostics ? 1 /* TriggerOnly */ : 0 /* None */ : 0 /* None */;
-    const writeLog = watchLogLevel !== 0 /* None */ ? (s) => host.trace(s) : noop;
-    const result = getWatchFactory(host, watchLogLevel, writeLog);
-    result.writeLog = writeLog;
-    return result;
-  }
-  function createCompilerHostFromProgramHost(host, getCompilerOptions, directoryStructureHost = host) {
-    const useCaseSensitiveFileNames = host.useCaseSensitiveFileNames();
-    const compilerHost = {
-      getSourceFile: createGetSourceFile(
-        (fileName, encoding) => !encoding ? compilerHost.readFile(fileName) : host.readFile(fileName, encoding),
-        getCompilerOptions,
-        /*setParentNodes*/
-        void 0
-      ),
-      getDefaultLibLocation: maybeBind(host, host.getDefaultLibLocation),
-      getDefaultLibFileName: (options) => host.getDefaultLibFileName(options),
-      writeFile: createWriteFileMeasuringIO(
-        (path, data, writeByteOrderMark) => host.writeFile(path, data, writeByteOrderMark),
-        (path) => host.createDirectory(path),
-        (path) => host.directoryExists(path)
-      ),
-      getCurrentDirectory: memoize(() => host.getCurrentDirectory()),
-      useCaseSensitiveFileNames: () => useCaseSensitiveFileNames,
-      getCanonicalFileName: createGetCanonicalFileName(useCaseSensitiveFileNames),
-      getNewLine: () => getNewLineCharacter(getCompilerOptions()),
-      fileExists: (f) => host.fileExists(f),
-      readFile: (f) => host.readFile(f),
-      trace: maybeBind(host, host.trace),
-      directoryExists: maybeBind(directoryStructureHost, directoryStructureHost.directoryExists),
-      getDirectories: maybeBind(directoryStructureHost, directoryStructureHost.getDirectories),
-      realpath: maybeBind(host, host.realpath),
-      getEnvironmentVariable: maybeBind(host, host.getEnvironmentVariable) || (() => ""),
-      createHash: maybeBind(host, host.createHash),
-      readDirectory: maybeBind(host, host.readDirectory),
-      storeFilesChangingSignatureDuringEmit: host.storeFilesChangingSignatureDuringEmit
-    };
-    return compilerHost;
-  }
-  function getSourceFileVersionAsHashFromText(host, text) {
-    if (text.match(sourceMapCommentRegExpDontCareLineStart)) {
-      let lineEnd = text.length;
-      let lineStart = lineEnd;
-      for (let pos = lineEnd - 1; pos >= 0; pos--) {
-        const ch = text.charCodeAt(pos);
-        switch (ch) {
-          case 10 /* lineFeed */:
-            if (pos && text.charCodeAt(pos - 1) === 13 /* carriageReturn */) {
-              pos--;
-            }
-          case 13 /* carriageReturn */:
-            break;
-          default:
-            if (ch < 127 /* maxAsciiCharacter */ || !isLineBreak(ch)) {
-              lineStart = pos;
-              continue;
-            }
-            break;
-        }
-        const line = text.substring(lineStart, lineEnd);
-        if (line.match(sourceMapCommentRegExp)) {
-          text = text.substring(0, lineStart);
-          break;
-        } else if (!line.match(whitespaceOrMapCommentRegExp)) {
-          break;
-        }
-        lineEnd = lineStart;
-      }
-    }
-    return (host.createHash || generateDjb2Hash)(text);
-  }
-  function setGetSourceFileAsHashVersioned(compilerHost) {
-    const originalGetSourceFile = compilerHost.getSourceFile;
-    compilerHost.getSourceFile = (...args) => {
-      const result = originalGetSourceFile.call(compilerHost, ...args);
-      if (result) {
-        result.version = getSourceFileVersionAsHashFromText(compilerHost, result.text);
-      }
-      return result;
-    };
-  }
-  function createProgramHost(system, createProgram2) {
-    const getDefaultLibLocation = memoize(() => getDirectoryPath(normalizePath(system.getExecutingFilePath())));
-    return {
-      useCaseSensitiveFileNames: () => system.useCaseSensitiveFileNames,
-      getNewLine: () => system.newLine,
-      getCurrentDirectory: memoize(() => system.getCurrentDirectory()),
-      getDefaultLibLocation,
-      getDefaultLibFileName: (options) => combinePaths(getDefaultLibLocation(), getDefaultLibFileName(options)),
-      fileExists: (path) => system.fileExists(path),
-      readFile: (path, encoding) => system.readFile(path, encoding),
-      directoryExists: (path) => system.directoryExists(path),
-      getDirectories: (path) => system.getDirectories(path),
-      readDirectory: (path, extensions, exclude, include, depth) => system.readDirectory(path, extensions, exclude, include, depth),
-      realpath: maybeBind(system, system.realpath),
-      getEnvironmentVariable: maybeBind(system, system.getEnvironmentVariable),
-      trace: (s) => system.write(s + system.newLine),
-      createDirectory: (path) => system.createDirectory(path),
-      writeFile: (path, data, writeByteOrderMark) => system.writeFile(path, data, writeByteOrderMark),
-      createHash: maybeBind(system, system.createHash),
-      createProgram: createProgram2 || createEmitAndSemanticDiagnosticsBuilderProgram,
-      storeFilesChangingSignatureDuringEmit: system.storeFilesChangingSignatureDuringEmit,
-      now: maybeBind(system, system.now)
-    };
-  }
-  function createWatchCompilerHost(system = sys, createProgram2, reportDiagnostic, reportWatchStatus2) {
-    const write = (s) => system.write(s + system.newLine);
-    const result = createProgramHost(system, createProgram2);
-    copyProperties(result, createWatchHost(system, reportWatchStatus2));
-    result.afterProgramCreate = (builderProgram) => {
-      const compilerOptions = builderProgram.getCompilerOptions();
-      const newLine = getNewLineCharacter(compilerOptions);
-      emitFilesAndReportErrors(
-        builderProgram,
-        reportDiagnostic,
-        write,
-        (errorCount) => result.onWatchStatusChange(
-          createCompilerDiagnostic(getWatchErrorSummaryDiagnosticMessage(errorCount), errorCount),
-          newLine,
-          compilerOptions,
-          errorCount
-        )
-      );
-    };
-    return result;
-  }
-  function reportUnrecoverableDiagnostic(system, reportDiagnostic, diagnostic) {
-    reportDiagnostic(diagnostic);
-    system.exit(1 /* DiagnosticsPresent_OutputsSkipped */);
-  }
-  function createWatchCompilerHostOfConfigFile({
-    configFileName,
-    optionsToExtend,
-    watchOptionsToExtend,
-    extraFileExtensions,
-    system,
-    createProgram: createProgram2,
-    reportDiagnostic,
-    reportWatchStatus: reportWatchStatus2
-  }) {
-    const diagnosticReporter = reportDiagnostic || createDiagnosticReporter(system);
-    const host = createWatchCompilerHost(system, createProgram2, diagnosticReporter, reportWatchStatus2);
-    host.onUnRecoverableConfigFileDiagnostic = (diagnostic) => reportUnrecoverableDiagnostic(system, diagnosticReporter, diagnostic);
-    host.configFileName = configFileName;
-    host.optionsToExtend = optionsToExtend;
-    host.watchOptionsToExtend = watchOptionsToExtend;
-    host.extraFileExtensions = extraFileExtensions;
-    return host;
-  }
-  function createWatchCompilerHostOfFilesAndCompilerOptions({
-    rootFiles,
-    options,
-    watchOptions,
-    projectReferences,
-    system,
-    createProgram: createProgram2,
-    reportDiagnostic,
-    reportWatchStatus: reportWatchStatus2
-  }) {
-    const host = createWatchCompilerHost(system, createProgram2, reportDiagnostic || createDiagnosticReporter(system), reportWatchStatus2);
-    host.rootFiles = rootFiles;
-    host.options = options;
-    host.watchOptions = watchOptions;
-    host.projectReferences = projectReferences;
-    return host;
-  }
-  function performIncrementalCompilation(input) {
-    const system = input.system || sys;
-    const host = input.host || (input.host = createIncrementalCompilerHost(input.options, system));
-    const builderProgram = createIncrementalProgram(input);
-    const exitStatus = emitFilesAndReportErrorsAndGetExitStatus(
-      builderProgram,
-      input.reportDiagnostic || createDiagnosticReporter(system),
-      (s) => host.trace && host.trace(s),
-      input.reportErrorSummary || input.options.pretty ? (errorCount, filesInError) => system.write(getErrorSummaryText(errorCount, filesInError, system.newLine, host)) : void 0
-    );
-    if (input.afterProgramEmitAndDiagnostics)
-      input.afterProgramEmitAndDiagnostics(builderProgram);
-    return exitStatus;
-  }
-  var sysFormatDiagnosticsHost, screenStartingMessageCodes, noopFileWatcher, returnNoopFileWatcher, WatchType;
-  var init_watch = __esm({
-    "src/compiler/watch.ts"() {
-      "use strict";
-      init_ts2();
-      sysFormatDiagnosticsHost = sys ? {
-        getCurrentDirectory: () => sys.getCurrentDirectory(),
-        getNewLine: () => sys.newLine,
-        getCanonicalFileName: createGetCanonicalFileName(sys.useCaseSensitiveFileNames)
-      } : void 0;
-      screenStartingMessageCodes = [
-        Diagnostics.Starting_compilation_in_watch_mode.code,
-        Diagnostics.File_change_detected_Starting_incremental_compilation.code
-      ];
-      noopFileWatcher = { close: noop };
-      returnNoopFileWatcher = () => noopFileWatcher;
-      WatchType = {
-        ConfigFile: "Config file",
-        ExtendedConfigFile: "Extended config file",
-        SourceFile: "Source file",
-        MissingFile: "Missing file",
-        WildcardDirectory: "Wild card directory",
-        FailedLookupLocations: "Failed Lookup Locations",
-        AffectingFileLocation: "File location affecting resolution",
-        TypeRoots: "Type roots",
-        ConfigFileOfReferencedProject: "Config file of referened project",
-        ExtendedConfigOfReferencedProject: "Extended config file of referenced project",
-        WildcardDirectoryOfReferencedProject: "Wild card directory of referenced project",
-        PackageJson: "package.json file",
-        ClosedScriptInfo: "Closed Script info",
-        ConfigFileForInferredRoot: "Config file for the inferred project root",
-        NodeModules: "node_modules for closed script infos and package.jsons affecting module specifier cache",
-        MissingSourceMapFile: "Missing source map file",
-        NoopConfigFileForInferredRoot: "Noop Config file for the inferred project root",
-        MissingGeneratedFile: "Missing generated file",
-        NodeModulesForModuleSpecifierCache: "node_modules for module specifier cache invalidation",
-        TypingInstallerLocationFile: "File location for typing installer",
-        TypingInstallerLocationDirectory: "Directory location for typing installer"
-      };
-    }
-  });
-
-  // src/compiler/watchPublic.ts
-  function readBuilderProgram(compilerOptions, host) {
-    const buildInfoPath = getTsBuildInfoEmitOutputFilePath(compilerOptions);
-    if (!buildInfoPath)
-      return void 0;
-    let buildInfo;
-    if (host.getBuildInfo) {
-      buildInfo = host.getBuildInfo(buildInfoPath, compilerOptions.configFilePath);
-    } else {
-      const content = host.readFile(buildInfoPath);
-      if (!content)
-        return void 0;
-      buildInfo = getBuildInfo(buildInfoPath, content);
-    }
-    if (!buildInfo || buildInfo.version !== version || !buildInfo.program)
-      return void 0;
-    return createBuilderProgramUsingProgramBuildInfo(buildInfo, buildInfoPath, host);
-  }
-  function createIncrementalCompilerHost(options, system = sys) {
-    const host = createCompilerHostWorker(
-      options,
-      /*setParentNodes*/
-      void 0,
-      system
-    );
-    host.createHash = maybeBind(system, system.createHash);
-    host.storeFilesChangingSignatureDuringEmit = system.storeFilesChangingSignatureDuringEmit;
-    setGetSourceFileAsHashVersioned(host);
-    changeCompilerHostLikeToUseCache(host, (fileName) => toPath(fileName, host.getCurrentDirectory(), host.getCanonicalFileName));
-    return host;
-  }
-  function createIncrementalProgram({
-    rootNames,
-    options,
-    configFileParsingDiagnostics,
-    projectReferences,
-    host,
-    createProgram: createProgram2
-  }) {
-    host = host || createIncrementalCompilerHost(options);
-    createProgram2 = createProgram2 || createEmitAndSemanticDiagnosticsBuilderProgram;
-    const oldProgram = readBuilderProgram(options, host);
-    return createProgram2(rootNames, options, host, oldProgram, configFileParsingDiagnostics, projectReferences);
-  }
-  function createWatchCompilerHost2(rootFilesOrConfigFileName, options, system, createProgram2, reportDiagnostic, reportWatchStatus2, projectReferencesOrWatchOptionsToExtend, watchOptionsOrExtraFileExtensions) {
-    if (isArray(rootFilesOrConfigFileName)) {
-      return createWatchCompilerHostOfFilesAndCompilerOptions({
-        rootFiles: rootFilesOrConfigFileName,
-        options,
-        watchOptions: watchOptionsOrExtraFileExtensions,
-        projectReferences: projectReferencesOrWatchOptionsToExtend,
-        system,
-        createProgram: createProgram2,
-        reportDiagnostic,
-        reportWatchStatus: reportWatchStatus2
-      });
-    } else {
-      return createWatchCompilerHostOfConfigFile({
-        configFileName: rootFilesOrConfigFileName,
-        optionsToExtend: options,
-        watchOptionsToExtend: projectReferencesOrWatchOptionsToExtend,
-        extraFileExtensions: watchOptionsOrExtraFileExtensions,
-        system,
-        createProgram: createProgram2,
-        reportDiagnostic,
-        reportWatchStatus: reportWatchStatus2
-      });
-    }
-  }
-  function createWatchProgram(host) {
-    let builderProgram;
-    let reloadLevel;
-    let missingFilesMap;
-    let watchedWildcardDirectories;
-    let timerToUpdateProgram;
-    let timerToInvalidateFailedLookupResolutions;
-    let parsedConfigs;
-    let sharedExtendedConfigFileWatchers;
-    let extendedConfigCache = host.extendedConfigCache;
-    let reportFileChangeDetectedOnCreateProgram = false;
-    const sourceFilesCache = /* @__PURE__ */ new Map();
-    let missingFilePathsRequestedForRelease;
-    let hasChangedCompilerOptions = false;
-    const useCaseSensitiveFileNames = host.useCaseSensitiveFileNames();
-    const currentDirectory = host.getCurrentDirectory();
-    const { configFileName, optionsToExtend: optionsToExtendForConfigFile = {}, watchOptionsToExtend, extraFileExtensions, createProgram: createProgram2 } = host;
-    let { rootFiles: rootFileNames, options: compilerOptions, watchOptions, projectReferences } = host;
-    let wildcardDirectories;
-    let configFileParsingDiagnostics;
-    let canConfigFileJsonReportNoInputFiles = false;
-    let hasChangedConfigFileParsingErrors = false;
-    const cachedDirectoryStructureHost = configFileName === void 0 ? void 0 : createCachedDirectoryStructureHost(host, currentDirectory, useCaseSensitiveFileNames);
-    const directoryStructureHost = cachedDirectoryStructureHost || host;
-    const parseConfigFileHost = parseConfigHostFromCompilerHostLike(host, directoryStructureHost);
-    let newLine = updateNewLine();
-    if (configFileName && host.configFileParsingResult) {
-      setConfigFileParsingResult(host.configFileParsingResult);
-      newLine = updateNewLine();
-    }
-    reportWatchDiagnostic(Diagnostics.Starting_compilation_in_watch_mode);
-    if (configFileName && !host.configFileParsingResult) {
-      newLine = getNewLineCharacter(optionsToExtendForConfigFile);
-      Debug.assert(!rootFileNames);
-      parseConfigFile2();
-      newLine = updateNewLine();
-    }
-    Debug.assert(compilerOptions);
-    Debug.assert(rootFileNames);
-    const { watchFile: watchFile2, watchDirectory, writeLog } = createWatchFactory(host, compilerOptions);
-    const getCanonicalFileName = createGetCanonicalFileName(useCaseSensitiveFileNames);
-    writeLog(`Current directory: ${currentDirectory} CaseSensitiveFileNames: ${useCaseSensitiveFileNames}`);
-    let configFileWatcher;
-    if (configFileName) {
-      configFileWatcher = watchFile2(configFileName, scheduleProgramReload, 2e3 /* High */, watchOptions, WatchType.ConfigFile);
-    }
-    const compilerHost = createCompilerHostFromProgramHost(host, () => compilerOptions, directoryStructureHost);
-    setGetSourceFileAsHashVersioned(compilerHost);
-    const getNewSourceFile = compilerHost.getSourceFile;
-    compilerHost.getSourceFile = (fileName, ...args) => getVersionedSourceFileByPath(fileName, toPath3(fileName), ...args);
-    compilerHost.getSourceFileByPath = getVersionedSourceFileByPath;
-    compilerHost.getNewLine = () => newLine;
-    compilerHost.fileExists = fileExists;
-    compilerHost.onReleaseOldSourceFile = onReleaseOldSourceFile;
-    compilerHost.onReleaseParsedCommandLine = onReleaseParsedCommandLine;
-    compilerHost.toPath = toPath3;
-    compilerHost.getCompilationSettings = () => compilerOptions;
-    compilerHost.useSourceOfProjectReferenceRedirect = maybeBind(host, host.useSourceOfProjectReferenceRedirect);
-    compilerHost.watchDirectoryOfFailedLookupLocation = (dir, cb, flags) => watchDirectory(dir, cb, flags, watchOptions, WatchType.FailedLookupLocations);
-    compilerHost.watchAffectingFileLocation = (file, cb) => watchFile2(file, cb, 2e3 /* High */, watchOptions, WatchType.AffectingFileLocation);
-    compilerHost.watchTypeRootsDirectory = (dir, cb, flags) => watchDirectory(dir, cb, flags, watchOptions, WatchType.TypeRoots);
-    compilerHost.getCachedDirectoryStructureHost = () => cachedDirectoryStructureHost;
-    compilerHost.scheduleInvalidateResolutionsOfFailedLookupLocations = scheduleInvalidateResolutionsOfFailedLookupLocations;
-    compilerHost.onInvalidatedResolution = scheduleProgramUpdate;
-    compilerHost.onChangedAutomaticTypeDirectiveNames = scheduleProgramUpdate;
-    compilerHost.fileIsOpen = returnFalse;
-    compilerHost.getCurrentProgram = getCurrentProgram;
-    compilerHost.writeLog = writeLog;
-    compilerHost.getParsedCommandLine = getParsedCommandLine;
-    const resolutionCache = createResolutionCache(
-      compilerHost,
-      configFileName ? getDirectoryPath(getNormalizedAbsolutePath(configFileName, currentDirectory)) : currentDirectory,
-      /*logChangesWhenResolvingModule*/
-      false
-    );
-    compilerHost.resolveModuleNameLiterals = maybeBind(host, host.resolveModuleNameLiterals);
-    compilerHost.resolveModuleNames = maybeBind(host, host.resolveModuleNames);
-    if (!compilerHost.resolveModuleNameLiterals && !compilerHost.resolveModuleNames) {
-      compilerHost.resolveModuleNameLiterals = resolutionCache.resolveModuleNameLiterals.bind(resolutionCache);
-    }
-    compilerHost.resolveTypeReferenceDirectiveReferences = maybeBind(host, host.resolveTypeReferenceDirectiveReferences);
-    compilerHost.resolveTypeReferenceDirectives = maybeBind(host, host.resolveTypeReferenceDirectives);
-    if (!compilerHost.resolveTypeReferenceDirectiveReferences && !compilerHost.resolveTypeReferenceDirectives) {
-      compilerHost.resolveTypeReferenceDirectiveReferences = resolutionCache.resolveTypeReferenceDirectiveReferences.bind(resolutionCache);
-    }
-    compilerHost.resolveLibrary = !host.resolveLibrary ? resolutionCache.resolveLibrary.bind(resolutionCache) : host.resolveLibrary.bind(host);
-    compilerHost.getModuleResolutionCache = host.resolveModuleNameLiterals || host.resolveModuleNames ? maybeBind(host, host.getModuleResolutionCache) : () => resolutionCache.getModuleResolutionCache();
-    const userProvidedResolution = !!host.resolveModuleNameLiterals || !!host.resolveTypeReferenceDirectiveReferences || !!host.resolveModuleNames || !!host.resolveTypeReferenceDirectives;
-    const customHasInvalidatedResolutions = userProvidedResolution ? maybeBind(host, host.hasInvalidatedResolutions) || returnTrue : returnFalse;
-    const customHasInvalidLibResolutions = host.resolveLibrary ? maybeBind(host, host.hasInvalidatedLibResolutions) || returnTrue : returnFalse;
-    builderProgram = readBuilderProgram(compilerOptions, compilerHost);
-    synchronizeProgram();
-    watchConfigFileWildCardDirectories();
-    if (configFileName)
-      updateExtendedConfigFilesWatches(toPath3(configFileName), compilerOptions, watchOptions, WatchType.ExtendedConfigFile);
-    return configFileName ? { getCurrentProgram: getCurrentBuilderProgram, getProgram: updateProgram, close } : { getCurrentProgram: getCurrentBuilderProgram, getProgram: updateProgram, updateRootFileNames, close };
-    function close() {
-      clearInvalidateResolutionsOfFailedLookupLocations();
-      resolutionCache.clear();
-      clearMap(sourceFilesCache, (value) => {
-        if (value && value.fileWatcher) {
-          value.fileWatcher.close();
-          value.fileWatcher = void 0;
-        }
-      });
-      if (configFileWatcher) {
-        configFileWatcher.close();
-        configFileWatcher = void 0;
-      }
-      extendedConfigCache == null ? void 0 : extendedConfigCache.clear();
-      extendedConfigCache = void 0;
-      if (sharedExtendedConfigFileWatchers) {
-        clearMap(sharedExtendedConfigFileWatchers, closeFileWatcherOf);
-        sharedExtendedConfigFileWatchers = void 0;
-      }
-      if (watchedWildcardDirectories) {
-        clearMap(watchedWildcardDirectories, closeFileWatcherOf);
-        watchedWildcardDirectories = void 0;
-      }
-      if (missingFilesMap) {
-        clearMap(missingFilesMap, closeFileWatcher);
-        missingFilesMap = void 0;
-      }
-      if (parsedConfigs) {
-        clearMap(parsedConfigs, (config) => {
-          var _a;
-          (_a = config.watcher) == null ? void 0 : _a.close();
-          config.watcher = void 0;
-          if (config.watchedDirectories)
-            clearMap(config.watchedDirectories, closeFileWatcherOf);
-          config.watchedDirectories = void 0;
-        });
-        parsedConfigs = void 0;
-      }
-    }
-    function getCurrentBuilderProgram() {
-      return builderProgram;
-    }
-    function getCurrentProgram() {
-      return builderProgram && builderProgram.getProgramOrUndefined();
-    }
-    function synchronizeProgram() {
-      writeLog(`Synchronizing program`);
-      Debug.assert(compilerOptions);
-      Debug.assert(rootFileNames);
-      clearInvalidateResolutionsOfFailedLookupLocations();
-      const program = getCurrentBuilderProgram();
-      if (hasChangedCompilerOptions) {
-        newLine = updateNewLine();
-        if (program && changesAffectModuleResolution(program.getCompilerOptions(), compilerOptions)) {
-          debugger;
-          resolutionCache.onChangesAffectModuleResolution();
-        }
-      }
-      const { hasInvalidatedResolutions, hasInvalidatedLibResolutions } = resolutionCache.createHasInvalidatedResolutions(customHasInvalidatedResolutions, customHasInvalidLibResolutions);
-      const {
-        originalReadFile,
-        originalFileExists,
-        originalDirectoryExists,
-        originalCreateDirectory,
-        originalWriteFile,
-        readFileWithCache
-      } = changeCompilerHostLikeToUseCache(compilerHost, toPath3);
-      if (isProgramUptoDate(getCurrentProgram(), rootFileNames, compilerOptions, (path) => getSourceVersion(path, readFileWithCache), (fileName) => compilerHost.fileExists(fileName), hasInvalidatedResolutions, hasInvalidatedLibResolutions, hasChangedAutomaticTypeDirectiveNames, getParsedCommandLine, projectReferences)) {
-        if (hasChangedConfigFileParsingErrors) {
-          if (reportFileChangeDetectedOnCreateProgram) {
-            reportWatchDiagnostic(Diagnostics.File_change_detected_Starting_incremental_compilation);
-          }
-          builderProgram = createProgram2(
-            /*rootNames*/
-            void 0,
-            /*options*/
-            void 0,
-            compilerHost,
-            builderProgram,
-            configFileParsingDiagnostics,
-            projectReferences
-          );
-          hasChangedConfigFileParsingErrors = false;
-        }
-      } else {
-        if (reportFileChangeDetectedOnCreateProgram) {
-          reportWatchDiagnostic(Diagnostics.File_change_detected_Starting_incremental_compilation);
-        }
-        createNewProgram(hasInvalidatedResolutions, hasInvalidatedLibResolutions);
-      }
-      reportFileChangeDetectedOnCreateProgram = false;
-      if (host.afterProgramCreate && program !== builderProgram) {
-        host.afterProgramCreate(builderProgram);
-      }
-      compilerHost.readFile = originalReadFile;
-      compilerHost.fileExists = originalFileExists;
-      compilerHost.directoryExists = originalDirectoryExists;
-      compilerHost.createDirectory = originalCreateDirectory;
-      compilerHost.writeFile = originalWriteFile;
-      return builderProgram;
-    }
-    function createNewProgram(hasInvalidatedResolutions, hasInvalidatedLibResolutions) {
-      writeLog("CreatingProgramWith::");
-      writeLog(`  roots: ${JSON.stringify(rootFileNames)}`);
-      writeLog(`  options: ${JSON.stringify(compilerOptions)}`);
-      if (projectReferences)
-        writeLog(`  projectReferences: ${JSON.stringify(projectReferences)}`);
-      const needsUpdateInTypeRootWatch = hasChangedCompilerOptions || !getCurrentProgram();
-      hasChangedCompilerOptions = false;
-      hasChangedConfigFileParsingErrors = false;
-      resolutionCache.startCachingPerDirectoryResolution();
-      compilerHost.hasInvalidatedResolutions = hasInvalidatedResolutions;
-      compilerHost.hasInvalidatedLibResolutions = hasInvalidatedLibResolutions;
-      compilerHost.hasChangedAutomaticTypeDirectiveNames = hasChangedAutomaticTypeDirectiveNames;
-      const oldProgram = getCurrentProgram();
-      builderProgram = createProgram2(rootFileNames, compilerOptions, compilerHost, builderProgram, configFileParsingDiagnostics, projectReferences);
-      resolutionCache.finishCachingPerDirectoryResolution(builderProgram.getProgram(), oldProgram);
-      updateMissingFilePathsWatch(builderProgram.getProgram(), missingFilesMap || (missingFilesMap = /* @__PURE__ */ new Map()), watchMissingFilePath);
-      if (needsUpdateInTypeRootWatch) {
-        resolutionCache.updateTypeRootsWatch();
-      }
-      if (missingFilePathsRequestedForRelease) {
-        for (const missingFilePath of missingFilePathsRequestedForRelease) {
-          if (!missingFilesMap.has(missingFilePath)) {
-            sourceFilesCache.delete(missingFilePath);
-          }
-        }
-        missingFilePathsRequestedForRelease = void 0;
-      }
-    }
-    function updateRootFileNames(files) {
-      Debug.assert(!configFileName, "Cannot update root file names with config file watch mode");
-      rootFileNames = files;
-      scheduleProgramUpdate();
-    }
-    function updateNewLine() {
-      return getNewLineCharacter(compilerOptions || optionsToExtendForConfigFile);
-    }
-    function toPath3(fileName) {
-      return toPath(fileName, currentDirectory, getCanonicalFileName);
-    }
-    function isFileMissingOnHost(hostSourceFile) {
-      return typeof hostSourceFile === "boolean";
-    }
-    function isFilePresenceUnknownOnHost(hostSourceFile) {
-      return typeof hostSourceFile.version === "boolean";
-    }
-    function fileExists(fileName) {
-      const path = toPath3(fileName);
-      if (isFileMissingOnHost(sourceFilesCache.get(path))) {
-        return false;
-      }
-      return directoryStructureHost.fileExists(fileName);
-    }
-    function getVersionedSourceFileByPath(fileName, path, languageVersionOrOptions, onError, shouldCreateNewSourceFile) {
-      const hostSourceFile = sourceFilesCache.get(path);
-      if (isFileMissingOnHost(hostSourceFile)) {
-        return void 0;
-      }
-      if (hostSourceFile === void 0 || shouldCreateNewSourceFile || isFilePresenceUnknownOnHost(hostSourceFile)) {
-        const sourceFile = getNewSourceFile(fileName, languageVersionOrOptions, onError);
-        if (hostSourceFile) {
-          if (sourceFile) {
-            hostSourceFile.sourceFile = sourceFile;
-            hostSourceFile.version = sourceFile.version;
-            if (!hostSourceFile.fileWatcher) {
-              hostSourceFile.fileWatcher = watchFilePath(path, fileName, onSourceFileChange, 250 /* Low */, watchOptions, WatchType.SourceFile);
-            }
-          } else {
-            if (hostSourceFile.fileWatcher) {
-              hostSourceFile.fileWatcher.close();
-            }
-            sourceFilesCache.set(path, false);
-          }
-        } else {
-          if (sourceFile) {
-            const fileWatcher = watchFilePath(path, fileName, onSourceFileChange, 250 /* Low */, watchOptions, WatchType.SourceFile);
-            sourceFilesCache.set(path, { sourceFile, version: sourceFile.version, fileWatcher });
-          } else {
-            sourceFilesCache.set(path, false);
-          }
-        }
-        return sourceFile;
-      }
-      return hostSourceFile.sourceFile;
-    }
-    function nextSourceFileVersion(path) {
-      const hostSourceFile = sourceFilesCache.get(path);
-      if (hostSourceFile !== void 0) {
-        if (isFileMissingOnHost(hostSourceFile)) {
-          sourceFilesCache.set(path, { version: false });
-        } else {
-          hostSourceFile.version = false;
-        }
-      }
-    }
-    function getSourceVersion(path, readFileWithCache) {
-      const hostSourceFile = sourceFilesCache.get(path);
-      if (!hostSourceFile)
-        return void 0;
-      if (hostSourceFile.version)
-        return hostSourceFile.version;
-      const text = readFileWithCache(path);
-      return text !== void 0 ? getSourceFileVersionAsHashFromText(compilerHost, text) : void 0;
-    }
-    function onReleaseOldSourceFile(oldSourceFile, _oldOptions, hasSourceFileByPath) {
-      const hostSourceFileInfo = sourceFilesCache.get(oldSourceFile.resolvedPath);
-      if (hostSourceFileInfo !== void 0) {
-        if (isFileMissingOnHost(hostSourceFileInfo)) {
-          (missingFilePathsRequestedForRelease || (missingFilePathsRequestedForRelease = [])).push(oldSourceFile.path);
-        } else if (hostSourceFileInfo.sourceFile === oldSourceFile) {
-          if (hostSourceFileInfo.fileWatcher) {
-            hostSourceFileInfo.fileWatcher.close();
-          }
-          sourceFilesCache.delete(oldSourceFile.resolvedPath);
-          if (!hasSourceFileByPath) {
-            resolutionCache.removeResolutionsOfFile(oldSourceFile.path);
-          }
-        }
-      }
-    }
-    function reportWatchDiagnostic(message) {
-      if (host.onWatchStatusChange) {
-        host.onWatchStatusChange(createCompilerDiagnostic(message), newLine, compilerOptions || optionsToExtendForConfigFile);
-      }
-    }
-    function hasChangedAutomaticTypeDirectiveNames() {
-      return resolutionCache.hasChangedAutomaticTypeDirectiveNames();
-    }
-    function clearInvalidateResolutionsOfFailedLookupLocations() {
-      if (!timerToInvalidateFailedLookupResolutions)
-        return false;
-      host.clearTimeout(timerToInvalidateFailedLookupResolutions);
-      timerToInvalidateFailedLookupResolutions = void 0;
-      return true;
-    }
-    function scheduleInvalidateResolutionsOfFailedLookupLocations() {
-      if (!host.setTimeout || !host.clearTimeout) {
-        return resolutionCache.invalidateResolutionsOfFailedLookupLocations();
-      }
-      const pending = clearInvalidateResolutionsOfFailedLookupLocations();
-      writeLog(`Scheduling invalidateFailedLookup${pending ? ", Cancelled earlier one" : ""}`);
-      timerToInvalidateFailedLookupResolutions = host.setTimeout(invalidateResolutionsOfFailedLookup, 250, "timerToInvalidateFailedLookupResolutions");
-    }
-    function invalidateResolutionsOfFailedLookup() {
-      timerToInvalidateFailedLookupResolutions = void 0;
-      if (resolutionCache.invalidateResolutionsOfFailedLookupLocations()) {
-        scheduleProgramUpdate();
-      }
-    }
-    function scheduleProgramUpdate() {
-      if (!host.setTimeout || !host.clearTimeout) {
-        return;
-      }
-      if (timerToUpdateProgram) {
-        host.clearTimeout(timerToUpdateProgram);
-      }
-      writeLog("Scheduling update");
-      timerToUpdateProgram = host.setTimeout(updateProgramWithWatchStatus, 250, "timerToUpdateProgram");
-    }
-    function scheduleProgramReload() {
-      Debug.assert(!!configFileName);
-      reloadLevel = 2 /* Full */;
-      scheduleProgramUpdate();
-    }
-    function updateProgramWithWatchStatus() {
-      timerToUpdateProgram = void 0;
-      reportFileChangeDetectedOnCreateProgram = true;
-      updateProgram();
-    }
-    function updateProgram() {
-      var _a, _b, _c, _d;
-      switch (reloadLevel) {
-        case 1 /* Partial */:
-          (_a = perfLogger) == null ? void 0 : _a.logStartUpdateProgram("PartialConfigReload");
-          reloadFileNamesFromConfigFile();
-          break;
-        case 2 /* Full */:
-          (_b = perfLogger) == null ? void 0 : _b.logStartUpdateProgram("FullConfigReload");
-          reloadConfigFile();
-          break;
-        default:
-          (_c = perfLogger) == null ? void 0 : _c.logStartUpdateProgram("SynchronizeProgram");
-          synchronizeProgram();
-          break;
-      }
-      (_d = perfLogger) == null ? void 0 : _d.logStopUpdateProgram("Done");
-      return getCurrentBuilderProgram();
-    }
-    function reloadFileNamesFromConfigFile() {
-      writeLog("Reloading new file names and options");
-      Debug.assert(compilerOptions);
-      Debug.assert(configFileName);
-      reloadLevel = 0 /* None */;
-      rootFileNames = getFileNamesFromConfigSpecs(compilerOptions.configFile.configFileSpecs, getNormalizedAbsolutePath(getDirectoryPath(configFileName), currentDirectory), compilerOptions, parseConfigFileHost, extraFileExtensions);
-      if (updateErrorForNoInputFiles(rootFileNames, getNormalizedAbsolutePath(configFileName, currentDirectory), compilerOptions.configFile.configFileSpecs, configFileParsingDiagnostics, canConfigFileJsonReportNoInputFiles)) {
-        hasChangedConfigFileParsingErrors = true;
-      }
-      synchronizeProgram();
-    }
-    function reloadConfigFile() {
-      Debug.assert(configFileName);
-      writeLog(`Reloading config file: ${configFileName}`);
-      reloadLevel = 0 /* None */;
-      if (cachedDirectoryStructureHost) {
-        cachedDirectoryStructureHost.clearCache();
-      }
-      parseConfigFile2();
-      hasChangedCompilerOptions = true;
-      synchronizeProgram();
-      watchConfigFileWildCardDirectories();
-      updateExtendedConfigFilesWatches(toPath3(configFileName), compilerOptions, watchOptions, WatchType.ExtendedConfigFile);
-    }
-    function parseConfigFile2() {
-      Debug.assert(configFileName);
-      setConfigFileParsingResult(getParsedCommandLineOfConfigFile(
-        configFileName,
-        optionsToExtendForConfigFile,
-        parseConfigFileHost,
-        extendedConfigCache || (extendedConfigCache = /* @__PURE__ */ new Map()),
-        watchOptionsToExtend,
-        extraFileExtensions
-      ));
-    }
-    function setConfigFileParsingResult(configFileParseResult) {
-      rootFileNames = configFileParseResult.fileNames;
-      compilerOptions = configFileParseResult.options;
-      watchOptions = configFileParseResult.watchOptions;
-      projectReferences = configFileParseResult.projectReferences;
-      wildcardDirectories = configFileParseResult.wildcardDirectories;
-      configFileParsingDiagnostics = getConfigFileParsingDiagnostics(configFileParseResult).slice();
-      canConfigFileJsonReportNoInputFiles = canJsonReportNoInputFiles(configFileParseResult.raw);
-      hasChangedConfigFileParsingErrors = true;
-    }
-    function getParsedCommandLine(configFileName2) {
-      const configPath = toPath3(configFileName2);
-      let config = parsedConfigs == null ? void 0 : parsedConfigs.get(configPath);
-      if (config) {
-        if (!config.reloadLevel)
-          return config.parsedCommandLine;
-        if (config.parsedCommandLine && config.reloadLevel === 1 /* Partial */ && !host.getParsedCommandLine) {
-          writeLog("Reloading new file names and options");
-          Debug.assert(compilerOptions);
-          const fileNames = getFileNamesFromConfigSpecs(
-            config.parsedCommandLine.options.configFile.configFileSpecs,
-            getNormalizedAbsolutePath(getDirectoryPath(configFileName2), currentDirectory),
-            compilerOptions,
-            parseConfigFileHost
-          );
-          config.parsedCommandLine = { ...config.parsedCommandLine, fileNames };
-          config.reloadLevel = void 0;
-          return config.parsedCommandLine;
-        }
-      }
-      writeLog(`Loading config file: ${configFileName2}`);
-      const parsedCommandLine = host.getParsedCommandLine ? host.getParsedCommandLine(configFileName2) : getParsedCommandLineFromConfigFileHost(configFileName2);
-      if (config) {
-        config.parsedCommandLine = parsedCommandLine;
-        config.reloadLevel = void 0;
-      } else {
-        (parsedConfigs || (parsedConfigs = /* @__PURE__ */ new Map())).set(configPath, config = { parsedCommandLine });
-      }
-      watchReferencedProject(configFileName2, configPath, config);
-      return parsedCommandLine;
-    }
-    function getParsedCommandLineFromConfigFileHost(configFileName2) {
-      const onUnRecoverableConfigFileDiagnostic = parseConfigFileHost.onUnRecoverableConfigFileDiagnostic;
-      parseConfigFileHost.onUnRecoverableConfigFileDiagnostic = noop;
-      const parsedCommandLine = getParsedCommandLineOfConfigFile(
-        configFileName2,
-        /*optionsToExtend*/
-        void 0,
-        parseConfigFileHost,
-        extendedConfigCache || (extendedConfigCache = /* @__PURE__ */ new Map()),
-        watchOptionsToExtend
-      );
-      parseConfigFileHost.onUnRecoverableConfigFileDiagnostic = onUnRecoverableConfigFileDiagnostic;
-      return parsedCommandLine;
-    }
-    function onReleaseParsedCommandLine(fileName) {
-      var _a;
-      const path = toPath3(fileName);
-      const config = parsedConfigs == null ? void 0 : parsedConfigs.get(path);
-      if (!config)
-        return;
-      parsedConfigs.delete(path);
-      if (config.watchedDirectories)
-        clearMap(config.watchedDirectories, closeFileWatcherOf);
-      (_a = config.watcher) == null ? void 0 : _a.close();
-      clearSharedExtendedConfigFileWatcher(path, sharedExtendedConfigFileWatchers);
-    }
-    function watchFilePath(path, file, callback, pollingInterval, options, watchType) {
-      return watchFile2(file, (fileName, eventKind) => callback(fileName, eventKind, path), pollingInterval, options, watchType);
-    }
-    function onSourceFileChange(fileName, eventKind, path) {
-      updateCachedSystemWithFile(fileName, path, eventKind);
-      if (eventKind === 2 /* Deleted */ && sourceFilesCache.has(path)) {
-        resolutionCache.invalidateResolutionOfFile(path);
-      }
-      nextSourceFileVersion(path);
-      scheduleProgramUpdate();
-    }
-    function updateCachedSystemWithFile(fileName, path, eventKind) {
-      if (cachedDirectoryStructureHost) {
-        cachedDirectoryStructureHost.addOrDeleteFile(fileName, path, eventKind);
-      }
-    }
-    function watchMissingFilePath(missingFilePath) {
-      return (parsedConfigs == null ? void 0 : parsedConfigs.has(missingFilePath)) ? noopFileWatcher : watchFilePath(missingFilePath, missingFilePath, onMissingFileChange, 500 /* Medium */, watchOptions, WatchType.MissingFile);
-    }
-    function onMissingFileChange(fileName, eventKind, missingFilePath) {
-      updateCachedSystemWithFile(fileName, missingFilePath, eventKind);
-      if (eventKind === 0 /* Created */ && missingFilesMap.has(missingFilePath)) {
-        missingFilesMap.get(missingFilePath).close();
-        missingFilesMap.delete(missingFilePath);
-        nextSourceFileVersion(missingFilePath);
-        scheduleProgramUpdate();
-      }
-    }
-    function watchConfigFileWildCardDirectories() {
-      if (wildcardDirectories) {
-        updateWatchingWildcardDirectories(
-          watchedWildcardDirectories || (watchedWildcardDirectories = /* @__PURE__ */ new Map()),
-          new Map(Object.entries(wildcardDirectories)),
-          watchWildcardDirectory
-        );
-      } else if (watchedWildcardDirectories) {
-        clearMap(watchedWildcardDirectories, closeFileWatcherOf);
-      }
-    }
-    function watchWildcardDirectory(directory, flags) {
-      return watchDirectory(
-        directory,
-        (fileOrDirectory) => {
-          Debug.assert(configFileName);
-          Debug.assert(compilerOptions);
-          const fileOrDirectoryPath = toPath3(fileOrDirectory);
-          if (cachedDirectoryStructureHost) {
-            cachedDirectoryStructureHost.addOrDeleteFileOrDirectory(fileOrDirectory, fileOrDirectoryPath);
-          }
-          nextSourceFileVersion(fileOrDirectoryPath);
-          if (isIgnoredFileFromWildCardWatching({
-            watchedDirPath: toPath3(directory),
-            fileOrDirectory,
-            fileOrDirectoryPath,
-            configFileName,
-            extraFileExtensions,
-            options: compilerOptions,
-            program: getCurrentBuilderProgram() || rootFileNames,
-            currentDirectory,
-            useCaseSensitiveFileNames,
-            writeLog,
-            toPath: toPath3
-          }))
-            return;
-          if (reloadLevel !== 2 /* Full */) {
-            reloadLevel = 1 /* Partial */;
-            scheduleProgramUpdate();
-          }
-        },
-        flags,
-        watchOptions,
-        WatchType.WildcardDirectory
-      );
-    }
-    function updateExtendedConfigFilesWatches(forProjectPath, options, watchOptions2, watchType) {
-      updateSharedExtendedConfigFileWatcher(
-        forProjectPath,
-        options,
-        sharedExtendedConfigFileWatchers || (sharedExtendedConfigFileWatchers = /* @__PURE__ */ new Map()),
-        (extendedConfigFileName, extendedConfigFilePath) => watchFile2(
-          extendedConfigFileName,
-          (_fileName, eventKind) => {
-            var _a;
-            updateCachedSystemWithFile(extendedConfigFileName, extendedConfigFilePath, eventKind);
-            if (extendedConfigCache)
-              cleanExtendedConfigCache(extendedConfigCache, extendedConfigFilePath, toPath3);
-            const projects = (_a = sharedExtendedConfigFileWatchers.get(extendedConfigFilePath)) == null ? void 0 : _a.projects;
-            if (!(projects == null ? void 0 : projects.size))
-              return;
-            projects.forEach((projectPath) => {
-              if (configFileName && toPath3(configFileName) === projectPath) {
-                reloadLevel = 2 /* Full */;
-              } else {
-                const config = parsedConfigs == null ? void 0 : parsedConfigs.get(projectPath);
-                if (config)
-                  config.reloadLevel = 2 /* Full */;
-                resolutionCache.removeResolutionsFromProjectReferenceRedirects(projectPath);
-              }
-              scheduleProgramUpdate();
-            });
-          },
-          2e3 /* High */,
-          watchOptions2,
-          watchType
-        ),
-        toPath3
-      );
-    }
-    function watchReferencedProject(configFileName2, configPath, commandLine) {
-      var _a, _b, _c, _d, _e;
-      commandLine.watcher || (commandLine.watcher = watchFile2(
-        configFileName2,
-        (_fileName, eventKind) => {
-          updateCachedSystemWithFile(configFileName2, configPath, eventKind);
-          const config = parsedConfigs == null ? void 0 : parsedConfigs.get(configPath);
-          if (config)
-            config.reloadLevel = 2 /* Full */;
-          resolutionCache.removeResolutionsFromProjectReferenceRedirects(configPath);
-          scheduleProgramUpdate();
-        },
-        2e3 /* High */,
-        ((_a = commandLine.parsedCommandLine) == null ? void 0 : _a.watchOptions) || watchOptions,
-        WatchType.ConfigFileOfReferencedProject
-      ));
-      if ((_b = commandLine.parsedCommandLine) == null ? void 0 : _b.wildcardDirectories) {
-        updateWatchingWildcardDirectories(
-          commandLine.watchedDirectories || (commandLine.watchedDirectories = /* @__PURE__ */ new Map()),
-          new Map(Object.entries((_c = commandLine.parsedCommandLine) == null ? void 0 : _c.wildcardDirectories)),
-          (directory, flags) => {
-            var _a2;
-            return watchDirectory(
-              directory,
-              (fileOrDirectory) => {
-                const fileOrDirectoryPath = toPath3(fileOrDirectory);
-                if (cachedDirectoryStructureHost) {
-                  cachedDirectoryStructureHost.addOrDeleteFileOrDirectory(fileOrDirectory, fileOrDirectoryPath);
-                }
-                nextSourceFileVersion(fileOrDirectoryPath);
-                const config = parsedConfigs == null ? void 0 : parsedConfigs.get(configPath);
-                if (!(config == null ? void 0 : config.parsedCommandLine))
-                  return;
-                if (isIgnoredFileFromWildCardWatching({
-                  watchedDirPath: toPath3(directory),
-                  fileOrDirectory,
-                  fileOrDirectoryPath,
-                  configFileName: configFileName2,
-                  options: config.parsedCommandLine.options,
-                  program: config.parsedCommandLine.fileNames,
-                  currentDirectory,
-                  useCaseSensitiveFileNames,
-                  writeLog,
-                  toPath: toPath3
-                }))
-                  return;
-                if (config.reloadLevel !== 2 /* Full */) {
-                  config.reloadLevel = 1 /* Partial */;
-                  scheduleProgramUpdate();
-                }
-              },
-              flags,
-              ((_a2 = commandLine.parsedCommandLine) == null ? void 0 : _a2.watchOptions) || watchOptions,
-              WatchType.WildcardDirectoryOfReferencedProject
-            );
-          }
-        );
-      } else if (commandLine.watchedDirectories) {
-        clearMap(commandLine.watchedDirectories, closeFileWatcherOf);
-        commandLine.watchedDirectories = void 0;
-      }
-      updateExtendedConfigFilesWatches(
-        configPath,
-        (_d = commandLine.parsedCommandLine) == null ? void 0 : _d.options,
-        ((_e = commandLine.parsedCommandLine) == null ? void 0 : _e.watchOptions) || watchOptions,
-        WatchType.ExtendedConfigOfReferencedProject
-      );
-    }
-  }
-  var init_watchPublic = __esm({
-    "src/compiler/watchPublic.ts"() {
-      "use strict";
-      init_ts2();
-    }
-  });
-
-  // src/compiler/tsbuild.ts
-  function resolveConfigFileProjectName(project) {
-    if (fileExtensionIs(project, ".json" /* Json */)) {
-      return project;
-    }
-    return combinePaths(project, "tsconfig.json");
-  }
-  var UpToDateStatusType;
-  var init_tsbuild = __esm({
-    "src/compiler/tsbuild.ts"() {
-      "use strict";
-      init_ts2();
-      UpToDateStatusType = /* @__PURE__ */ ((UpToDateStatusType2) => {
-        UpToDateStatusType2[UpToDateStatusType2["Unbuildable"] = 0] = "Unbuildable";
-        UpToDateStatusType2[UpToDateStatusType2["UpToDate"] = 1] = "UpToDate";
-        UpToDateStatusType2[UpToDateStatusType2["UpToDateWithUpstreamTypes"] = 2] = "UpToDateWithUpstreamTypes";
-        UpToDateStatusType2[UpToDateStatusType2["OutOfDateWithPrepend"] = 3] = "OutOfDateWithPrepend";
-        UpToDateStatusType2[UpToDateStatusType2["OutputMissing"] = 4] = "OutputMissing";
-        UpToDateStatusType2[UpToDateStatusType2["ErrorReadingFile"] = 5] = "ErrorReadingFile";
-        UpToDateStatusType2[UpToDateStatusType2["OutOfDateWithSelf"] = 6] = "OutOfDateWithSelf";
-        UpToDateStatusType2[UpToDateStatusType2["OutOfDateWithUpstream"] = 7] = "OutOfDateWithUpstream";
-        UpToDateStatusType2[UpToDateStatusType2["OutOfDateBuildInfo"] = 8] = "OutOfDateBuildInfo";
-        UpToDateStatusType2[UpToDateStatusType2["OutOfDateOptions"] = 9] = "OutOfDateOptions";
-        UpToDateStatusType2[UpToDateStatusType2["OutOfDateRoots"] = 10] = "OutOfDateRoots";
-        UpToDateStatusType2[UpToDateStatusType2["UpstreamOutOfDate"] = 11] = "UpstreamOutOfDate";
-        UpToDateStatusType2[UpToDateStatusType2["UpstreamBlocked"] = 12] = "UpstreamBlocked";
-        UpToDateStatusType2[UpToDateStatusType2["ComputingUpstream"] = 13] = "ComputingUpstream";
-        UpToDateStatusType2[UpToDateStatusType2["TsVersionOutputOfDate"] = 14] = "TsVersionOutputOfDate";
-        UpToDateStatusType2[UpToDateStatusType2["UpToDateWithInputFileText"] = 15] = "UpToDateWithInputFileText";
-        UpToDateStatusType2[UpToDateStatusType2["ContainerOnly"] = 16] = "ContainerOnly";
-        UpToDateStatusType2[UpToDateStatusType2["ForceBuild"] = 17] = "ForceBuild";
-        return UpToDateStatusType2;
-      })(UpToDateStatusType || {});
-    }
-  });
-
-  // src/compiler/tsbuildPublic.ts
-  function getOrCreateValueFromConfigFileMap(configFileMap, resolved, createT) {
-    const existingValue = configFileMap.get(resolved);
-    let newValue;
-    if (!existingValue) {
-      newValue = createT();
-      configFileMap.set(resolved, newValue);
-    }
-    return existingValue || newValue;
-  }
-  function getOrCreateValueMapFromConfigFileMap(configFileMap, resolved) {
-    return getOrCreateValueFromConfigFileMap(configFileMap, resolved, () => /* @__PURE__ */ new Map());
-  }
-  function getCurrentTime(host) {
-    return host.now ? host.now() : /* @__PURE__ */ new Date();
-  }
-  function isCircularBuildOrder(buildOrder) {
-    return !!buildOrder && !!buildOrder.buildOrder;
-  }
-  function getBuildOrderFromAnyBuildOrder(anyBuildOrder) {
-    return isCircularBuildOrder(anyBuildOrder) ? anyBuildOrder.buildOrder : anyBuildOrder;
-  }
-  function createBuilderStatusReporter(system, pretty) {
-    return (diagnostic) => {
-      let output = pretty ? `[${formatColorAndReset(getLocaleTimeString(system), "\x1B[90m" /* Grey */)}] ` : `${getLocaleTimeString(system)} - `;
-      output += `${flattenDiagnosticMessageText(diagnostic.messageText, system.newLine)}${system.newLine + system.newLine}`;
-      system.write(output);
-    };
-  }
-  function createSolutionBuilderHostBase(system, createProgram2, reportDiagnostic, reportSolutionBuilderStatus) {
-    const host = createProgramHost(system, createProgram2);
-    host.getModifiedTime = system.getModifiedTime ? (path) => system.getModifiedTime(path) : returnUndefined;
-    host.setModifiedTime = system.setModifiedTime ? (path, date) => system.setModifiedTime(path, date) : noop;
-    host.deleteFile = system.deleteFile ? (path) => system.deleteFile(path) : noop;
-    host.reportDiagnostic = reportDiagnostic || createDiagnosticReporter(system);
-    host.reportSolutionBuilderStatus = reportSolutionBuilderStatus || createBuilderStatusReporter(system);
-    host.now = maybeBind(system, system.now);
-    return host;
-  }
-  function createSolutionBuilderHost(system = sys, createProgram2, reportDiagnostic, reportSolutionBuilderStatus, reportErrorSummary2) {
-    const host = createSolutionBuilderHostBase(system, createProgram2, reportDiagnostic, reportSolutionBuilderStatus);
-    host.reportErrorSummary = reportErrorSummary2;
-    return host;
-  }
-  function createSolutionBuilderWithWatchHost(system = sys, createProgram2, reportDiagnostic, reportSolutionBuilderStatus, reportWatchStatus2) {
-    const host = createSolutionBuilderHostBase(system, createProgram2, reportDiagnostic, reportSolutionBuilderStatus);
-    const watchHost = createWatchHost(system, reportWatchStatus2);
-    copyProperties(host, watchHost);
-    return host;
-  }
-  function getCompilerOptionsOfBuildOptions(buildOptions) {
-    const result = {};
-    commonOptionsWithBuild.forEach((option) => {
-      if (hasProperty(buildOptions, option.name))
-        result[option.name] = buildOptions[option.name];
-    });
-    return result;
-  }
-  function createSolutionBuilder(host, rootNames, defaultOptions) {
-    return createSolutionBuilderWorker(
-      /*watch*/
-      false,
-      host,
-      rootNames,
-      defaultOptions
-    );
-  }
-  function createSolutionBuilderWithWatch(host, rootNames, defaultOptions, baseWatchOptions) {
-    return createSolutionBuilderWorker(
-      /*watch*/
-      true,
-      host,
-      rootNames,
-      defaultOptions,
-      baseWatchOptions
-    );
-  }
-  function createSolutionBuilderState(watch, hostOrHostWithWatch, rootNames, options, baseWatchOptions) {
-    const host = hostOrHostWithWatch;
-    const hostWithWatch = hostOrHostWithWatch;
-    const baseCompilerOptions = getCompilerOptionsOfBuildOptions(options);
-    const compilerHost = createCompilerHostFromProgramHost(host, () => state.projectCompilerOptions);
-    setGetSourceFileAsHashVersioned(compilerHost);
-    compilerHost.getParsedCommandLine = (fileName) => parseConfigFile(state, fileName, toResolvedConfigFilePath(state, fileName));
-    compilerHost.resolveModuleNameLiterals = maybeBind(host, host.resolveModuleNameLiterals);
-    compilerHost.resolveTypeReferenceDirectiveReferences = maybeBind(host, host.resolveTypeReferenceDirectiveReferences);
-    compilerHost.resolveLibrary = maybeBind(host, host.resolveLibrary);
-    compilerHost.resolveModuleNames = maybeBind(host, host.resolveModuleNames);
-    compilerHost.resolveTypeReferenceDirectives = maybeBind(host, host.resolveTypeReferenceDirectives);
-    compilerHost.getModuleResolutionCache = maybeBind(host, host.getModuleResolutionCache);
-    let moduleResolutionCache, typeReferenceDirectiveResolutionCache;
-    if (!compilerHost.resolveModuleNameLiterals && !compilerHost.resolveModuleNames) {
-      moduleResolutionCache = createModuleResolutionCache(compilerHost.getCurrentDirectory(), compilerHost.getCanonicalFileName);
-      compilerHost.resolveModuleNameLiterals = (moduleNames, containingFile, redirectedReference, options2, containingSourceFile) => loadWithModeAwareCache(
-        moduleNames,
-        containingFile,
-        redirectedReference,
-        options2,
-        containingSourceFile,
-        host,
-        moduleResolutionCache,
-        createModuleResolutionLoader
-      );
-      compilerHost.getModuleResolutionCache = () => moduleResolutionCache;
-    }
-    if (!compilerHost.resolveTypeReferenceDirectiveReferences && !compilerHost.resolveTypeReferenceDirectives) {
-      typeReferenceDirectiveResolutionCache = createTypeReferenceDirectiveResolutionCache(
-        compilerHost.getCurrentDirectory(),
-        compilerHost.getCanonicalFileName,
-        /*options*/
-        void 0,
-        moduleResolutionCache == null ? void 0 : moduleResolutionCache.getPackageJsonInfoCache()
-      );
-      compilerHost.resolveTypeReferenceDirectiveReferences = (typeDirectiveNames, containingFile, redirectedReference, options2, containingSourceFile) => loadWithModeAwareCache(
-        typeDirectiveNames,
-        containingFile,
-        redirectedReference,
-        options2,
-        containingSourceFile,
-        host,
-        typeReferenceDirectiveResolutionCache,
-        createTypeReferenceResolutionLoader
-      );
-    }
-    let libraryResolutionCache;
-    if (!compilerHost.resolveLibrary) {
-      libraryResolutionCache = createModuleResolutionCache(
-        compilerHost.getCurrentDirectory(),
-        compilerHost.getCanonicalFileName,
-        /*options*/
-        void 0,
-        moduleResolutionCache == null ? void 0 : moduleResolutionCache.getPackageJsonInfoCache()
-      );
-      compilerHost.resolveLibrary = (libraryName, resolveFrom, options2) => resolveLibrary(
-        libraryName,
-        resolveFrom,
-        options2,
-        host,
-        libraryResolutionCache
-      );
-    }
-    compilerHost.getBuildInfo = (fileName, configFilePath) => getBuildInfo3(
-      state,
-      fileName,
-      toResolvedConfigFilePath(state, configFilePath),
-      /*modifiedTime*/
-      void 0
-    );
-    const { watchFile: watchFile2, watchDirectory, writeLog } = createWatchFactory(hostWithWatch, options);
-    const state = {
-      host,
-      hostWithWatch,
-      parseConfigFileHost: parseConfigHostFromCompilerHostLike(host),
-      write: maybeBind(host, host.trace),
-      // State of solution
-      options,
-      baseCompilerOptions,
-      rootNames,
-      baseWatchOptions,
-      resolvedConfigFilePaths: /* @__PURE__ */ new Map(),
-      configFileCache: /* @__PURE__ */ new Map(),
-      projectStatus: /* @__PURE__ */ new Map(),
-      extendedConfigCache: /* @__PURE__ */ new Map(),
-      buildInfoCache: /* @__PURE__ */ new Map(),
-      outputTimeStamps: /* @__PURE__ */ new Map(),
-      builderPrograms: /* @__PURE__ */ new Map(),
-      diagnostics: /* @__PURE__ */ new Map(),
-      projectPendingBuild: /* @__PURE__ */ new Map(),
-      projectErrorsReported: /* @__PURE__ */ new Map(),
-      compilerHost,
-      moduleResolutionCache,
-      typeReferenceDirectiveResolutionCache,
-      libraryResolutionCache,
-      // Mutable state
-      buildOrder: void 0,
-      readFileWithCache: (f) => host.readFile(f),
-      projectCompilerOptions: baseCompilerOptions,
-      cache: void 0,
-      allProjectBuildPending: true,
-      needsSummary: true,
-      watchAllProjectsPending: watch,
-      // Watch state
-      watch,
-      allWatchedWildcardDirectories: /* @__PURE__ */ new Map(),
-      allWatchedInputFiles: /* @__PURE__ */ new Map(),
-      allWatchedConfigFiles: /* @__PURE__ */ new Map(),
-      allWatchedExtendedConfigFiles: /* @__PURE__ */ new Map(),
-      allWatchedPackageJsonFiles: /* @__PURE__ */ new Map(),
-      filesWatched: /* @__PURE__ */ new Map(),
-      lastCachedPackageJsonLookups: /* @__PURE__ */ new Map(),
-      timerToBuildInvalidatedProject: void 0,
-      reportFileChangeDetected: false,
-      watchFile: watchFile2,
-      watchDirectory,
-      writeLog
-    };
-    return state;
-  }
-  function toPath2(state, fileName) {
-    return toPath(fileName, state.compilerHost.getCurrentDirectory(), state.compilerHost.getCanonicalFileName);
-  }
-  function toResolvedConfigFilePath(state, fileName) {
-    const { resolvedConfigFilePaths } = state;
-    const path = resolvedConfigFilePaths.get(fileName);
-    if (path !== void 0)
-      return path;
-    const resolvedPath = toPath2(state, fileName);
-    resolvedConfigFilePaths.set(fileName, resolvedPath);
-    return resolvedPath;
-  }
-  function isParsedCommandLine(entry) {
-    return !!entry.options;
-  }
-  function getCachedParsedConfigFile(state, configFilePath) {
-    const value = state.configFileCache.get(configFilePath);
-    return value && isParsedCommandLine(value) ? value : void 0;
-  }
-  function parseConfigFile(state, configFileName, configFilePath) {
-    const { configFileCache } = state;
-    const value = configFileCache.get(configFilePath);
-    if (value) {
-      return isParsedCommandLine(value) ? value : void 0;
-    }
-    mark("SolutionBuilder::beforeConfigFileParsing");
-    let diagnostic;
-    const { parseConfigFileHost, baseCompilerOptions, baseWatchOptions, extendedConfigCache, host } = state;
-    let parsed;
-    if (host.getParsedCommandLine) {
-      parsed = host.getParsedCommandLine(configFileName);
-      if (!parsed)
-        diagnostic = createCompilerDiagnostic(Diagnostics.File_0_not_found, configFileName);
-    } else {
-      parseConfigFileHost.onUnRecoverableConfigFileDiagnostic = (d) => diagnostic = d;
-      parsed = getParsedCommandLineOfConfigFile(configFileName, baseCompilerOptions, parseConfigFileHost, extendedConfigCache, baseWatchOptions);
-      parseConfigFileHost.onUnRecoverableConfigFileDiagnostic = noop;
-    }
-    configFileCache.set(configFilePath, parsed || diagnostic);
-    mark("SolutionBuilder::afterConfigFileParsing");
-    measure("SolutionBuilder::Config file parsing", "SolutionBuilder::beforeConfigFileParsing", "SolutionBuilder::afterConfigFileParsing");
-    return parsed;
-  }
-  function resolveProjectName(state, name) {
-    return resolveConfigFileProjectName(resolvePath(state.compilerHost.getCurrentDirectory(), name));
-  }
-  function createBuildOrder(state, roots) {
-    const temporaryMarks = /* @__PURE__ */ new Map();
-    const permanentMarks = /* @__PURE__ */ new Map();
-    const circularityReportStack = [];
-    let buildOrder;
-    let circularDiagnostics;
-    for (const root of roots) {
-      visit(root);
-    }
-    return circularDiagnostics ? { buildOrder: buildOrder || emptyArray, circularDiagnostics } : buildOrder || emptyArray;
-    function visit(configFileName, inCircularContext) {
-      const projPath = toResolvedConfigFilePath(state, configFileName);
-      if (permanentMarks.has(projPath))
-        return;
-      if (temporaryMarks.has(projPath)) {
-        if (!inCircularContext) {
-          (circularDiagnostics || (circularDiagnostics = [])).push(
-            createCompilerDiagnostic(
-              Diagnostics.Project_references_may_not_form_a_circular_graph_Cycle_detected_Colon_0,
-              circularityReportStack.join("\r\n")
-            )
-          );
-        }
-        return;
-      }
-      temporaryMarks.set(projPath, true);
-      circularityReportStack.push(configFileName);
-      const parsed = parseConfigFile(state, configFileName, projPath);
-      if (parsed && parsed.projectReferences) {
-        for (const ref of parsed.projectReferences) {
-          const resolvedRefPath = resolveProjectName(state, ref.path);
-          visit(resolvedRefPath, inCircularContext || ref.circular);
-        }
-      }
-      circularityReportStack.pop();
-      permanentMarks.set(projPath, true);
-      (buildOrder || (buildOrder = [])).push(configFileName);
-    }
-  }
-  function getBuildOrder(state) {
-    return state.buildOrder || createStateBuildOrder(state);
-  }
-  function createStateBuildOrder(state) {
-    const buildOrder = createBuildOrder(state, state.rootNames.map((f) => resolveProjectName(state, f)));
-    state.resolvedConfigFilePaths.clear();
-    const currentProjects = new Map(
-      getBuildOrderFromAnyBuildOrder(buildOrder).map(
-        (resolved) => [toResolvedConfigFilePath(state, resolved), true]
-      )
-    );
-    const noopOnDelete = { onDeleteValue: noop };
-    mutateMapSkippingNewValues(state.configFileCache, currentProjects, noopOnDelete);
-    mutateMapSkippingNewValues(state.projectStatus, currentProjects, noopOnDelete);
-    mutateMapSkippingNewValues(state.builderPrograms, currentProjects, noopOnDelete);
-    mutateMapSkippingNewValues(state.diagnostics, currentProjects, noopOnDelete);
-    mutateMapSkippingNewValues(state.projectPendingBuild, currentProjects, noopOnDelete);
-    mutateMapSkippingNewValues(state.projectErrorsReported, currentProjects, noopOnDelete);
-    mutateMapSkippingNewValues(state.buildInfoCache, currentProjects, noopOnDelete);
-    mutateMapSkippingNewValues(state.outputTimeStamps, currentProjects, noopOnDelete);
-    if (state.watch) {
-      mutateMapSkippingNewValues(
-        state.allWatchedConfigFiles,
-        currentProjects,
-        { onDeleteValue: closeFileWatcher }
-      );
-      state.allWatchedExtendedConfigFiles.forEach((watcher) => {
-        watcher.projects.forEach((project) => {
-          if (!currentProjects.has(project)) {
-            watcher.projects.delete(project);
-          }
-        });
-        watcher.close();
-      });
-      mutateMapSkippingNewValues(
-        state.allWatchedWildcardDirectories,
-        currentProjects,
-        { onDeleteValue: (existingMap) => existingMap.forEach(closeFileWatcherOf) }
-      );
-      mutateMapSkippingNewValues(
-        state.allWatchedInputFiles,
-        currentProjects,
-        { onDeleteValue: (existingMap) => existingMap.forEach(closeFileWatcher) }
-      );
-      mutateMapSkippingNewValues(
-        state.allWatchedPackageJsonFiles,
-        currentProjects,
-        { onDeleteValue: (existingMap) => existingMap.forEach(closeFileWatcher) }
-      );
-    }
-    return state.buildOrder = buildOrder;
-  }
-  function getBuildOrderFor(state, project, onlyReferences) {
-    const resolvedProject = project && resolveProjectName(state, project);
-    const buildOrderFromState = getBuildOrder(state);
-    if (isCircularBuildOrder(buildOrderFromState))
-      return buildOrderFromState;
-    if (resolvedProject) {
-      const projectPath = toResolvedConfigFilePath(state, resolvedProject);
-      const projectIndex = findIndex(
-        buildOrderFromState,
-        (configFileName) => toResolvedConfigFilePath(state, configFileName) === projectPath
-      );
-      if (projectIndex === -1)
-        return void 0;
-    }
-    const buildOrder = resolvedProject ? createBuildOrder(state, [resolvedProject]) : buildOrderFromState;
-    Debug.assert(!isCircularBuildOrder(buildOrder));
-    Debug.assert(!onlyReferences || resolvedProject !== void 0);
-    Debug.assert(!onlyReferences || buildOrder[buildOrder.length - 1] === resolvedProject);
-    return onlyReferences ? buildOrder.slice(0, buildOrder.length - 1) : buildOrder;
-  }
-  function enableCache(state) {
-    if (state.cache) {
-      disableCache(state);
-    }
-    const { compilerHost, host } = state;
-    const originalReadFileWithCache = state.readFileWithCache;
-    const originalGetSourceFile = compilerHost.getSourceFile;
-    const {
-      originalReadFile,
-      originalFileExists,
-      originalDirectoryExists,
-      originalCreateDirectory,
-      originalWriteFile,
-      getSourceFileWithCache,
-      readFileWithCache
-    } = changeCompilerHostLikeToUseCache(
-      host,
-      (fileName) => toPath2(state, fileName),
-      (...args) => originalGetSourceFile.call(compilerHost, ...args)
-    );
-    state.readFileWithCache = readFileWithCache;
-    compilerHost.getSourceFile = getSourceFileWithCache;
-    state.cache = {
-      originalReadFile,
-      originalFileExists,
-      originalDirectoryExists,
-      originalCreateDirectory,
-      originalWriteFile,
-      originalReadFileWithCache,
-      originalGetSourceFile
-    };
-  }
-  function disableCache(state) {
-    if (!state.cache)
-      return;
-    const { cache, host, compilerHost, extendedConfigCache, moduleResolutionCache, typeReferenceDirectiveResolutionCache, libraryResolutionCache } = state;
-    host.readFile = cache.originalReadFile;
-    host.fileExists = cache.originalFileExists;
-    host.directoryExists = cache.originalDirectoryExists;
-    host.createDirectory = cache.originalCreateDirectory;
-    host.writeFile = cache.originalWriteFile;
-    compilerHost.getSourceFile = cache.originalGetSourceFile;
-    state.readFileWithCache = cache.originalReadFileWithCache;
-    extendedConfigCache.clear();
-    moduleResolutionCache == null ? void 0 : moduleResolutionCache.clear();
-    typeReferenceDirectiveResolutionCache == null ? void 0 : typeReferenceDirectiveResolutionCache.clear();
-    libraryResolutionCache == null ? void 0 : libraryResolutionCache.clear();
-    state.cache = void 0;
-  }
-  function clearProjectStatus(state, resolved) {
-    state.projectStatus.delete(resolved);
-    state.diagnostics.delete(resolved);
-  }
-  function addProjToQueue({ projectPendingBuild }, proj, reloadLevel) {
-    const value = projectPendingBuild.get(proj);
-    if (value === void 0) {
-      projectPendingBuild.set(proj, reloadLevel);
-    } else if (value < reloadLevel) {
-      projectPendingBuild.set(proj, reloadLevel);
-    }
-  }
-  function setupInitialBuild(state, cancellationToken) {
-    if (!state.allProjectBuildPending)
-      return;
-    state.allProjectBuildPending = false;
-    if (state.options.watch)
-      reportWatchStatus(state, Diagnostics.Starting_compilation_in_watch_mode);
-    enableCache(state);
-    const buildOrder = getBuildOrderFromAnyBuildOrder(getBuildOrder(state));
-    buildOrder.forEach(
-      (configFileName) => state.projectPendingBuild.set(
-        toResolvedConfigFilePath(state, configFileName),
-        0 /* None */
-      )
-    );
-    if (cancellationToken) {
-      cancellationToken.throwIfCancellationRequested();
-    }
-  }
-  function doneInvalidatedProject(state, projectPath) {
-    state.projectPendingBuild.delete(projectPath);
-    return state.diagnostics.has(projectPath) ? 1 /* DiagnosticsPresent_OutputsSkipped */ : 0 /* Success */;
-  }
-  function createUpdateOutputFileStampsProject(state, project, projectPath, config, buildOrder) {
-    let updateOutputFileStampsPending = true;
-    return {
-      kind: 2 /* UpdateOutputFileStamps */,
-      project,
-      projectPath,
-      buildOrder,
-      getCompilerOptions: () => config.options,
-      getCurrentDirectory: () => state.compilerHost.getCurrentDirectory(),
-      updateOutputFileStatmps: () => {
-        updateOutputTimestamps(state, config, projectPath);
-        updateOutputFileStampsPending = false;
-      },
-      done: () => {
-        if (updateOutputFileStampsPending) {
-          updateOutputTimestamps(state, config, projectPath);
-        }
-        mark("SolutionBuilder::Timestamps only updates");
-        return doneInvalidatedProject(state, projectPath);
-      }
-    };
-  }
-  function createBuildOrUpdateInvalidedProject(kind, state, project, projectPath, projectIndex, config, buildOrder) {
-    let step = kind === 0 /* Build */ ? 0 /* CreateProgram */ : 4 /* EmitBundle */;
-    let program;
-    let buildResult;
-    let invalidatedProjectOfBundle;
-    return kind === 0 /* Build */ ? {
-      kind,
-      project,
-      projectPath,
-      buildOrder,
-      getCompilerOptions: () => config.options,
-      getCurrentDirectory: () => state.compilerHost.getCurrentDirectory(),
-      getBuilderProgram: () => withProgramOrUndefined(identity),
-      getProgram: () => withProgramOrUndefined(
-        (program2) => program2.getProgramOrUndefined()
-      ),
-      getSourceFile: (fileName) => withProgramOrUndefined(
-        (program2) => program2.getSourceFile(fileName)
-      ),
-      getSourceFiles: () => withProgramOrEmptyArray(
-        (program2) => program2.getSourceFiles()
-      ),
-      getOptionsDiagnostics: (cancellationToken) => withProgramOrEmptyArray(
-        (program2) => program2.getOptionsDiagnostics(cancellationToken)
-      ),
-      getGlobalDiagnostics: (cancellationToken) => withProgramOrEmptyArray(
-        (program2) => program2.getGlobalDiagnostics(cancellationToken)
-      ),
-      getConfigFileParsingDiagnostics: () => withProgramOrEmptyArray(
-        (program2) => program2.getConfigFileParsingDiagnostics()
-      ),
-      getSyntacticDiagnostics: (sourceFile, cancellationToken) => withProgramOrEmptyArray(
-        (program2) => program2.getSyntacticDiagnostics(sourceFile, cancellationToken)
-      ),
-      getAllDependencies: (sourceFile) => withProgramOrEmptyArray(
-        (program2) => program2.getAllDependencies(sourceFile)
-      ),
-      getSemanticDiagnostics: (sourceFile, cancellationToken) => withProgramOrEmptyArray(
-        (program2) => program2.getSemanticDiagnostics(sourceFile, cancellationToken)
-      ),
-      getSemanticDiagnosticsOfNextAffectedFile: (cancellationToken, ignoreSourceFile) => withProgramOrUndefined(
-        (program2) => program2.getSemanticDiagnosticsOfNextAffectedFile && program2.getSemanticDiagnosticsOfNextAffectedFile(cancellationToken, ignoreSourceFile)
-      ),
-      emit: (targetSourceFile, writeFile2, cancellationToken, emitOnlyDtsFiles, customTransformers) => {
-        if (targetSourceFile || emitOnlyDtsFiles) {
-          return withProgramOrUndefined(
-            (program2) => {
-              var _a, _b;
-              return program2.emit(targetSourceFile, writeFile2, cancellationToken, emitOnlyDtsFiles, customTransformers || ((_b = (_a = state.host).getCustomTransformers) == null ? void 0 : _b.call(_a, project)));
-            }
-          );
-        }
-        executeSteps(2 /* SemanticDiagnostics */, cancellationToken);
-        if (step === 5 /* EmitBuildInfo */) {
-          return emitBuildInfo(writeFile2, cancellationToken);
-        }
-        if (step !== 3 /* Emit */)
-          return void 0;
-        return emit(writeFile2, cancellationToken, customTransformers);
-      },
-      done
-    } : {
-      kind,
-      project,
-      projectPath,
-      buildOrder,
-      getCompilerOptions: () => config.options,
-      getCurrentDirectory: () => state.compilerHost.getCurrentDirectory(),
-      emit: (writeFile2, customTransformers) => {
-        if (step !== 4 /* EmitBundle */)
-          return invalidatedProjectOfBundle;
-        return emitBundle(writeFile2, customTransformers);
-      },
-      done
-    };
-    function done(cancellationToken, writeFile2, customTransformers) {
-      executeSteps(8 /* Done */, cancellationToken, writeFile2, customTransformers);
-      if (kind === 0 /* Build */)
-        mark("SolutionBuilder::Projects built");
-      else
-        mark("SolutionBuilder::Bundles updated");
-      return doneInvalidatedProject(state, projectPath);
-    }
-    function withProgramOrUndefined(action) {
-      executeSteps(0 /* CreateProgram */);
-      return program && action(program);
-    }
-    function withProgramOrEmptyArray(action) {
-      return withProgramOrUndefined(action) || emptyArray;
-    }
-    function createProgram2() {
-      var _a, _b;
-      Debug.assert(program === void 0);
-      if (state.options.dry) {
-        reportStatus(state, Diagnostics.A_non_dry_build_would_build_project_0, project);
-        buildResult = 1 /* Success */;
-        step = 7 /* QueueReferencingProjects */;
-        return;
-      }
-      if (state.options.verbose)
-        reportStatus(state, Diagnostics.Building_project_0, project);
-      if (config.fileNames.length === 0) {
-        reportAndStoreErrors(state, projectPath, getConfigFileParsingDiagnostics(config));
-        buildResult = 0 /* None */;
-        step = 7 /* QueueReferencingProjects */;
-        return;
-      }
-      const { host, compilerHost } = state;
-      state.projectCompilerOptions = config.options;
-      (_a = state.moduleResolutionCache) == null ? void 0 : _a.update(config.options);
-      (_b = state.typeReferenceDirectiveResolutionCache) == null ? void 0 : _b.update(config.options);
-      program = host.createProgram(
-        config.fileNames,
-        config.options,
-        compilerHost,
-        getOldProgram(state, projectPath, config),
-        getConfigFileParsingDiagnostics(config),
-        config.projectReferences
-      );
-      if (state.watch) {
-        state.lastCachedPackageJsonLookups.set(projectPath, state.moduleResolutionCache && map(
-          state.moduleResolutionCache.getPackageJsonInfoCache().entries(),
-          ([path, data]) => [state.host.realpath && data ? toPath2(state, state.host.realpath(path)) : path, data]
-        ));
-        state.builderPrograms.set(projectPath, program);
-      }
-      step++;
-    }
-    function handleDiagnostics(diagnostics, errorFlags, errorType) {
-      if (diagnostics.length) {
-        ({ buildResult, step } = buildErrors(
-          state,
-          projectPath,
-          program,
-          config,
-          diagnostics,
-          errorFlags,
-          errorType
-        ));
-      } else {
-        step++;
-      }
-    }
-    function getSyntaxDiagnostics(cancellationToken) {
-      Debug.assertIsDefined(program);
-      handleDiagnostics(
-        [
-          ...program.getConfigFileParsingDiagnostics(),
-          ...program.getOptionsDiagnostics(cancellationToken),
-          ...program.getGlobalDiagnostics(cancellationToken),
-          ...program.getSyntacticDiagnostics(
-            /*sourceFile*/
-            void 0,
-            cancellationToken
-          )
-        ],
-        8 /* SyntaxErrors */,
-        "Syntactic"
-      );
-    }
-    function getSemanticDiagnostics(cancellationToken) {
-      handleDiagnostics(
-        Debug.checkDefined(program).getSemanticDiagnostics(
-          /*sourceFile*/
-          void 0,
-          cancellationToken
-        ),
-        16 /* TypeErrors */,
-        "Semantic"
-      );
-    }
-    function emit(writeFileCallback, cancellationToken, customTransformers) {
-      var _a, _b, _c;
-      Debug.assertIsDefined(program);
-      Debug.assert(step === 3 /* Emit */);
-      const saved = program.saveEmitState();
-      let declDiagnostics;
-      const reportDeclarationDiagnostics = (d) => (declDiagnostics || (declDiagnostics = [])).push(d);
-      const outputFiles = [];
-      const { emitResult } = emitFilesAndReportErrors(
-        program,
-        reportDeclarationDiagnostics,
-        /*write*/
-        void 0,
-        /*reportSummary*/
-        void 0,
-        (name, text, writeByteOrderMark, _onError, _sourceFiles, data) => outputFiles.push({ name, text, writeByteOrderMark, data }),
-        cancellationToken,
-        /*emitOnlyDtsFiles*/
-        false,
-        customTransformers || ((_b = (_a = state.host).getCustomTransformers) == null ? void 0 : _b.call(_a, project))
-      );
-      if (declDiagnostics) {
-        program.restoreEmitState(saved);
-        ({ buildResult, step } = buildErrors(
-          state,
-          projectPath,
-          program,
-          config,
-          declDiagnostics,
-          32 /* DeclarationEmitErrors */,
-          "Declaration file"
-        ));
-        return {
-          emitSkipped: true,
-          diagnostics: emitResult.diagnostics
-        };
-      }
-      const { host, compilerHost } = state;
-      const resultFlags = ((_c = program.hasChangedEmitSignature) == null ? void 0 : _c.call(program)) ? 0 /* None */ : 2 /* DeclarationOutputUnchanged */;
-      const emitterDiagnostics = createDiagnosticCollection();
-      const emittedOutputs = /* @__PURE__ */ new Map();
-      const options = program.getCompilerOptions();
-      const isIncremental = isIncrementalCompilation(options);
-      let outputTimeStampMap;
-      let now;
-      outputFiles.forEach(({ name, text, writeByteOrderMark, data }) => {
-        const path = toPath2(state, name);
-        emittedOutputs.set(toPath2(state, name), name);
-        if (data == null ? void 0 : data.buildInfo)
-          setBuildInfo(state, data.buildInfo, projectPath, options, resultFlags);
-        const modifiedTime = (data == null ? void 0 : data.differsOnlyInMap) ? getModifiedTime(state.host, name) : void 0;
-        writeFile(writeFileCallback ? { writeFile: writeFileCallback } : compilerHost, emitterDiagnostics, name, text, writeByteOrderMark);
-        if (data == null ? void 0 : data.differsOnlyInMap)
-          state.host.setModifiedTime(name, modifiedTime);
-        else if (!isIncremental && state.watch) {
-          (outputTimeStampMap || (outputTimeStampMap = getOutputTimeStampMap(state, projectPath))).set(path, now || (now = getCurrentTime(state.host)));
-        }
-      });
-      finishEmit(
-        emitterDiagnostics,
-        emittedOutputs,
-        outputFiles.length ? outputFiles[0].name : getFirstProjectOutput(config, !host.useCaseSensitiveFileNames()),
-        resultFlags
-      );
-      return emitResult;
-    }
-    function emitBuildInfo(writeFileCallback, cancellationToken) {
-      Debug.assertIsDefined(program);
-      Debug.assert(step === 5 /* EmitBuildInfo */);
-      const emitResult = program.emitBuildInfo((name, text, writeByteOrderMark, onError, sourceFiles, data) => {
-        if (data == null ? void 0 : data.buildInfo)
-          setBuildInfo(state, data.buildInfo, projectPath, program.getCompilerOptions(), 2 /* DeclarationOutputUnchanged */);
-        if (writeFileCallback)
-          writeFileCallback(name, text, writeByteOrderMark, onError, sourceFiles, data);
-        else
-          state.compilerHost.writeFile(name, text, writeByteOrderMark, onError, sourceFiles, data);
-      }, cancellationToken);
-      if (emitResult.diagnostics.length) {
-        reportErrors(state, emitResult.diagnostics);
-        state.diagnostics.set(projectPath, [...state.diagnostics.get(projectPath), ...emitResult.diagnostics]);
-        buildResult = 64 /* EmitErrors */ & buildResult;
-      }
-      if (emitResult.emittedFiles && state.write) {
-        emitResult.emittedFiles.forEach((name) => listEmittedFile(state, config, name));
-      }
-      afterProgramDone(state, program, config);
-      step = 7 /* QueueReferencingProjects */;
-      return emitResult;
-    }
-    function finishEmit(emitterDiagnostics, emittedOutputs, oldestOutputFileName, resultFlags) {
-      const emitDiagnostics = emitterDiagnostics.getDiagnostics();
-      if (emitDiagnostics.length) {
-        ({ buildResult, step } = buildErrors(
-          state,
-          projectPath,
-          program,
-          config,
-          emitDiagnostics,
-          64 /* EmitErrors */,
-          "Emit"
-        ));
-        return emitDiagnostics;
-      }
-      if (state.write) {
-        emittedOutputs.forEach((name) => listEmittedFile(state, config, name));
-      }
-      updateOutputTimestampsWorker(state, config, projectPath, Diagnostics.Updating_unchanged_output_timestamps_of_project_0, emittedOutputs);
-      state.diagnostics.delete(projectPath);
-      state.projectStatus.set(projectPath, {
-        type: 1 /* UpToDate */,
-        oldestOutputFileName
-      });
-      afterProgramDone(state, program, config);
-      step = 7 /* QueueReferencingProjects */;
-      buildResult = resultFlags;
-      return emitDiagnostics;
-    }
-    function emitBundle(writeFileCallback, customTransformers) {
-      var _a, _b, _c, _d;
-      Debug.assert(kind === 1 /* UpdateBundle */);
-      if (state.options.dry) {
-        reportStatus(state, Diagnostics.A_non_dry_build_would_update_output_of_project_0, project);
-        buildResult = 1 /* Success */;
-        step = 7 /* QueueReferencingProjects */;
-        return void 0;
-      }
-      if (state.options.verbose)
-        reportStatus(state, Diagnostics.Updating_output_of_project_0, project);
-      const { compilerHost } = state;
-      state.projectCompilerOptions = config.options;
-      (_b = (_a = state.host).beforeEmitBundle) == null ? void 0 : _b.call(_a, config);
-      const outputFiles = emitUsingBuildInfo(
-        config,
-        compilerHost,
-        (ref) => {
-          const refName = resolveProjectName(state, ref.path);
-          return parseConfigFile(state, refName, toResolvedConfigFilePath(state, refName));
-        },
-        customTransformers || ((_d = (_c = state.host).getCustomTransformers) == null ? void 0 : _d.call(_c, project))
-      );
-      if (isString(outputFiles)) {
-        reportStatus(state, Diagnostics.Cannot_update_output_of_project_0_because_there_was_error_reading_file_1, project, relName(state, outputFiles));
-        step = 6 /* BuildInvalidatedProjectOfBundle */;
-        return invalidatedProjectOfBundle = createBuildOrUpdateInvalidedProject(
-          0 /* Build */,
-          state,
-          project,
-          projectPath,
-          projectIndex,
-          config,
-          buildOrder
-        );
-      }
-      Debug.assert(!!outputFiles.length);
-      const emitterDiagnostics = createDiagnosticCollection();
-      const emittedOutputs = /* @__PURE__ */ new Map();
-      let resultFlags = 2 /* DeclarationOutputUnchanged */;
-      const existingBuildInfo = state.buildInfoCache.get(projectPath).buildInfo || void 0;
-      outputFiles.forEach(({ name, text, writeByteOrderMark, data }) => {
-        var _a2, _b2;
-        emittedOutputs.set(toPath2(state, name), name);
-        if (data == null ? void 0 : data.buildInfo) {
-          if (((_a2 = data.buildInfo.program) == null ? void 0 : _a2.outSignature) !== ((_b2 = existingBuildInfo == null ? void 0 : existingBuildInfo.program) == null ? void 0 : _b2.outSignature)) {
-            resultFlags &= ~2 /* DeclarationOutputUnchanged */;
-          }
-          setBuildInfo(state, data.buildInfo, projectPath, config.options, resultFlags);
-        }
-        writeFile(writeFileCallback ? { writeFile: writeFileCallback } : compilerHost, emitterDiagnostics, name, text, writeByteOrderMark);
-      });
-      const emitDiagnostics = finishEmit(
-        emitterDiagnostics,
-        emittedOutputs,
-        outputFiles[0].name,
-        resultFlags
-      );
-      return { emitSkipped: false, diagnostics: emitDiagnostics };
-    }
-    function executeSteps(till, cancellationToken, writeFile2, customTransformers) {
-      while (step <= till && step < 8 /* Done */) {
-        const currentStep = step;
-        switch (step) {
-          case 0 /* CreateProgram */:
-            createProgram2();
-            break;
-          case 1 /* SyntaxDiagnostics */:
-            getSyntaxDiagnostics(cancellationToken);
-            break;
-          case 2 /* SemanticDiagnostics */:
-            getSemanticDiagnostics(cancellationToken);
-            break;
-          case 3 /* Emit */:
-            emit(writeFile2, cancellationToken, customTransformers);
-            break;
-          case 5 /* EmitBuildInfo */:
-            emitBuildInfo(writeFile2, cancellationToken);
-            break;
-          case 4 /* EmitBundle */:
-            emitBundle(writeFile2, customTransformers);
-            break;
-          case 6 /* BuildInvalidatedProjectOfBundle */:
-            Debug.checkDefined(invalidatedProjectOfBundle).done(cancellationToken, writeFile2, customTransformers);
-            step = 8 /* Done */;
-            break;
-          case 7 /* QueueReferencingProjects */:
-            queueReferencingProjects(state, project, projectPath, projectIndex, config, buildOrder, Debug.checkDefined(buildResult));
-            step++;
-            break;
-          case 8 /* Done */:
-          default:
-            assertType(step);
-        }
-        Debug.assert(step > currentStep);
-      }
-    }
-  }
-  function needsBuild({ options }, status, config) {
-    if (status.type !== 3 /* OutOfDateWithPrepend */ || options.force)
-      return true;
-    return config.fileNames.length === 0 || !!getConfigFileParsingDiagnostics(config).length || !isIncrementalCompilation(config.options);
-  }
-  function getNextInvalidatedProjectCreateInfo(state, buildOrder, reportQueue) {
-    if (!state.projectPendingBuild.size)
-      return void 0;
-    if (isCircularBuildOrder(buildOrder))
-      return void 0;
-    const { options, projectPendingBuild } = state;
-    for (let projectIndex = 0; projectIndex < buildOrder.length; projectIndex++) {
-      const project = buildOrder[projectIndex];
-      const projectPath = toResolvedConfigFilePath(state, project);
-      const reloadLevel = state.projectPendingBuild.get(projectPath);
-      if (reloadLevel === void 0)
-        continue;
-      if (reportQueue) {
-        reportQueue = false;
-        reportBuildQueue(state, buildOrder);
-      }
-      const config = parseConfigFile(state, project, projectPath);
-      if (!config) {
-        reportParseConfigFileDiagnostic(state, projectPath);
-        projectPendingBuild.delete(projectPath);
-        continue;
-      }
-      if (reloadLevel === 2 /* Full */) {
-        watchConfigFile(state, project, projectPath, config);
-        watchExtendedConfigFiles(state, projectPath, config);
-        watchWildCardDirectories(state, project, projectPath, config);
-        watchInputFiles(state, project, projectPath, config);
-        watchPackageJsonFiles(state, project, projectPath, config);
-      } else if (reloadLevel === 1 /* Partial */) {
-        config.fileNames = getFileNamesFromConfigSpecs(config.options.configFile.configFileSpecs, getDirectoryPath(project), config.options, state.parseConfigFileHost);
-        updateErrorForNoInputFiles(config.fileNames, project, config.options.configFile.configFileSpecs, config.errors, canJsonReportNoInputFiles(config.raw));
-        watchInputFiles(state, project, projectPath, config);
-        watchPackageJsonFiles(state, project, projectPath, config);
-      }
-      const status = getUpToDateStatus(state, config, projectPath);
-      if (!options.force) {
-        if (status.type === 1 /* UpToDate */) {
-          verboseReportProjectStatus(state, project, status);
-          reportAndStoreErrors(state, projectPath, getConfigFileParsingDiagnostics(config));
-          projectPendingBuild.delete(projectPath);
-          if (options.dry) {
-            reportStatus(state, Diagnostics.Project_0_is_up_to_date, project);
-          }
-          continue;
-        }
-        if (status.type === 2 /* UpToDateWithUpstreamTypes */ || status.type === 15 /* UpToDateWithInputFileText */) {
-          reportAndStoreErrors(state, projectPath, getConfigFileParsingDiagnostics(config));
-          return {
-            kind: 2 /* UpdateOutputFileStamps */,
-            status,
-            project,
-            projectPath,
-            projectIndex,
-            config
-          };
-        }
-      }
-      if (status.type === 12 /* UpstreamBlocked */) {
-        verboseReportProjectStatus(state, project, status);
-        reportAndStoreErrors(state, projectPath, getConfigFileParsingDiagnostics(config));
-        projectPendingBuild.delete(projectPath);
-        if (options.verbose) {
-          reportStatus(
-            state,
-            status.upstreamProjectBlocked ? Diagnostics.Skipping_build_of_project_0_because_its_dependency_1_was_not_built : Diagnostics.Skipping_build_of_project_0_because_its_dependency_1_has_errors,
-            project,
-            status.upstreamProjectName
-          );
-        }
-        continue;
-      }
-      if (status.type === 16 /* ContainerOnly */) {
-        verboseReportProjectStatus(state, project, status);
-        reportAndStoreErrors(state, projectPath, getConfigFileParsingDiagnostics(config));
-        projectPendingBuild.delete(projectPath);
-        continue;
-      }
-      return {
-        kind: needsBuild(state, status, config) ? 0 /* Build */ : 1 /* UpdateBundle */,
-        status,
-        project,
-        projectPath,
-        projectIndex,
-        config
-      };
-    }
-    return void 0;
-  }
-  function createInvalidatedProjectWithInfo(state, info, buildOrder) {
-    verboseReportProjectStatus(state, info.project, info.status);
-    return info.kind !== 2 /* UpdateOutputFileStamps */ ? createBuildOrUpdateInvalidedProject(
-      info.kind,
-      state,
-      info.project,
-      info.projectPath,
-      info.projectIndex,
-      info.config,
-      buildOrder
-    ) : createUpdateOutputFileStampsProject(
-      state,
-      info.project,
-      info.projectPath,
-      info.config,
-      buildOrder
-    );
-  }
-  function getNextInvalidatedProject(state, buildOrder, reportQueue) {
-    const info = getNextInvalidatedProjectCreateInfo(state, buildOrder, reportQueue);
-    if (!info)
-      return info;
-    return createInvalidatedProjectWithInfo(state, info, buildOrder);
-  }
-  function listEmittedFile({ write }, proj, file) {
-    if (write && proj.options.listEmittedFiles) {
-      write(`TSFILE: ${file}`);
-    }
-  }
-  function getOldProgram({ options, builderPrograms, compilerHost }, proj, parsed) {
-    if (options.force)
-      return void 0;
-    const value = builderPrograms.get(proj);
-    if (value)
-      return value;
-    return readBuilderProgram(parsed.options, compilerHost);
-  }
-  function afterProgramDone(state, program, config) {
-    if (program) {
-      if (state.write)
-        listFiles(program, state.write);
-      if (state.host.afterProgramEmitAndDiagnostics) {
-        state.host.afterProgramEmitAndDiagnostics(program);
-      }
-      program.releaseProgram();
-    } else if (state.host.afterEmitBundle) {
-      state.host.afterEmitBundle(config);
-    }
-    state.projectCompilerOptions = state.baseCompilerOptions;
-  }
-  function buildErrors(state, resolvedPath, program, config, diagnostics, buildResult, errorType) {
-    const canEmitBuildInfo = program && !outFile(program.getCompilerOptions());
-    reportAndStoreErrors(state, resolvedPath, diagnostics);
-    state.projectStatus.set(resolvedPath, { type: 0 /* Unbuildable */, reason: `${errorType} errors` });
-    if (canEmitBuildInfo)
-      return { buildResult, step: 5 /* EmitBuildInfo */ };
-    afterProgramDone(state, program, config);
-    return { buildResult, step: 7 /* QueueReferencingProjects */ };
-  }
-  function isFileWatcherWithModifiedTime(value) {
-    return !!value.watcher;
-  }
-  function getModifiedTime2(state, fileName) {
-    const path = toPath2(state, fileName);
-    const existing = state.filesWatched.get(path);
-    if (state.watch && !!existing) {
-      if (!isFileWatcherWithModifiedTime(existing))
-        return existing;
-      if (existing.modifiedTime)
-        return existing.modifiedTime;
-    }
-    const result = getModifiedTime(state.host, fileName);
-    if (state.watch) {
-      if (existing)
-        existing.modifiedTime = result;
-      else
-        state.filesWatched.set(path, result);
-    }
-    return result;
-  }
-  function watchFile(state, file, callback, pollingInterval, options, watchType, project) {
-    const path = toPath2(state, file);
-    const existing = state.filesWatched.get(path);
-    if (existing && isFileWatcherWithModifiedTime(existing)) {
-      existing.callbacks.push(callback);
-    } else {
-      const watcher = state.watchFile(
-        file,
-        (fileName, eventKind, modifiedTime) => {
-          const existing2 = Debug.checkDefined(state.filesWatched.get(path));
-          Debug.assert(isFileWatcherWithModifiedTime(existing2));
-          existing2.modifiedTime = modifiedTime;
-          existing2.callbacks.forEach((cb) => cb(fileName, eventKind, modifiedTime));
-        },
-        pollingInterval,
-        options,
-        watchType,
-        project
-      );
-      state.filesWatched.set(path, { callbacks: [callback], watcher, modifiedTime: existing });
-    }
-    return {
-      close: () => {
-        const existing2 = Debug.checkDefined(state.filesWatched.get(path));
-        Debug.assert(isFileWatcherWithModifiedTime(existing2));
-        if (existing2.callbacks.length === 1) {
-          state.filesWatched.delete(path);
-          closeFileWatcherOf(existing2);
-        } else {
-          unorderedRemoveItem(existing2.callbacks, callback);
-        }
-      }
-    };
-  }
-  function getOutputTimeStampMap(state, resolvedConfigFilePath) {
-    if (!state.watch)
-      return void 0;
-    let result = state.outputTimeStamps.get(resolvedConfigFilePath);
-    if (!result)
-      state.outputTimeStamps.set(resolvedConfigFilePath, result = /* @__PURE__ */ new Map());
-    return result;
-  }
-  function setBuildInfo(state, buildInfo, resolvedConfigPath, options, resultFlags) {
-    const buildInfoPath = getTsBuildInfoEmitOutputFilePath(options);
-    const existing = getBuildInfoCacheEntry(state, buildInfoPath, resolvedConfigPath);
-    const modifiedTime = getCurrentTime(state.host);
-    if (existing) {
-      existing.buildInfo = buildInfo;
-      existing.modifiedTime = modifiedTime;
-      if (!(resultFlags & 2 /* DeclarationOutputUnchanged */))
-        existing.latestChangedDtsTime = modifiedTime;
-    } else {
-      state.buildInfoCache.set(resolvedConfigPath, {
-        path: toPath2(state, buildInfoPath),
-        buildInfo,
-        modifiedTime,
-        latestChangedDtsTime: resultFlags & 2 /* DeclarationOutputUnchanged */ ? void 0 : modifiedTime
-      });
-    }
-  }
-  function getBuildInfoCacheEntry(state, buildInfoPath, resolvedConfigPath) {
-    const path = toPath2(state, buildInfoPath);
-    const existing = state.buildInfoCache.get(resolvedConfigPath);
-    return (existing == null ? void 0 : existing.path) === path ? existing : void 0;
-  }
-  function getBuildInfo3(state, buildInfoPath, resolvedConfigPath, modifiedTime) {
-    const path = toPath2(state, buildInfoPath);
-    const existing = state.buildInfoCache.get(resolvedConfigPath);
-    if (existing !== void 0 && existing.path === path) {
-      return existing.buildInfo || void 0;
-    }
-    const value = state.readFileWithCache(buildInfoPath);
-    const buildInfo = value ? getBuildInfo(buildInfoPath, value) : void 0;
-    state.buildInfoCache.set(resolvedConfigPath, { path, buildInfo: buildInfo || false, modifiedTime: modifiedTime || missingFileModifiedTime });
-    return buildInfo;
-  }
-  function checkConfigFileUpToDateStatus(state, configFile, oldestOutputFileTime, oldestOutputFileName) {
-    const tsconfigTime = getModifiedTime2(state, configFile);
-    if (oldestOutputFileTime < tsconfigTime) {
-      return {
-        type: 6 /* OutOfDateWithSelf */,
-        outOfDateOutputFileName: oldestOutputFileName,
-        newerInputFileName: configFile
-      };
-    }
-  }
-  function getUpToDateStatusWorker(state, project, resolvedPath) {
-    var _a, _b;
-    if (!project.fileNames.length && !canJsonReportNoInputFiles(project.raw)) {
-      return {
-        type: 16 /* ContainerOnly */
-      };
-    }
-    let referenceStatuses;
-    const force = !!state.options.force;
-    if (project.projectReferences) {
-      state.projectStatus.set(resolvedPath, { type: 13 /* ComputingUpstream */ });
-      for (const ref of project.projectReferences) {
-        const resolvedRef = resolveProjectReferencePath(ref);
-        const resolvedRefPath = toResolvedConfigFilePath(state, resolvedRef);
-        const resolvedConfig = parseConfigFile(state, resolvedRef, resolvedRefPath);
-        const refStatus = getUpToDateStatus(state, resolvedConfig, resolvedRefPath);
-        if (refStatus.type === 13 /* ComputingUpstream */ || refStatus.type === 16 /* ContainerOnly */) {
-          continue;
-        }
-        if (refStatus.type === 0 /* Unbuildable */ || refStatus.type === 12 /* UpstreamBlocked */) {
-          return {
-            type: 12 /* UpstreamBlocked */,
-            upstreamProjectName: ref.path,
-            upstreamProjectBlocked: refStatus.type === 12 /* UpstreamBlocked */
-          };
-        }
-        if (refStatus.type !== 1 /* UpToDate */) {
-          return {
-            type: 11 /* UpstreamOutOfDate */,
-            upstreamProjectName: ref.path
-          };
-        }
-        if (!force)
-          (referenceStatuses || (referenceStatuses = [])).push({ ref, refStatus, resolvedRefPath, resolvedConfig });
-      }
-    }
-    if (force)
-      return { type: 17 /* ForceBuild */ };
-    const { host } = state;
-    const buildInfoPath = getTsBuildInfoEmitOutputFilePath(project.options);
-    let oldestOutputFileName;
-    let oldestOutputFileTime = maximumDate;
-    let buildInfoTime;
-    let buildInfoProgram;
-    let buildInfoVersionMap;
-    if (buildInfoPath) {
-      const buildInfoCacheEntry2 = getBuildInfoCacheEntry(state, buildInfoPath, resolvedPath);
-      buildInfoTime = (buildInfoCacheEntry2 == null ? void 0 : buildInfoCacheEntry2.modifiedTime) || getModifiedTime(host, buildInfoPath);
-      if (buildInfoTime === missingFileModifiedTime) {
-        if (!buildInfoCacheEntry2) {
-          state.buildInfoCache.set(resolvedPath, {
-            path: toPath2(state, buildInfoPath),
-            buildInfo: false,
-            modifiedTime: buildInfoTime
-          });
-        }
-        return {
-          type: 4 /* OutputMissing */,
-          missingOutputFileName: buildInfoPath
-        };
-      }
-      const buildInfo = getBuildInfo3(state, buildInfoPath, resolvedPath, buildInfoTime);
-      if (!buildInfo) {
-        return {
-          type: 5 /* ErrorReadingFile */,
-          fileName: buildInfoPath
-        };
-      }
-      if ((buildInfo.bundle || buildInfo.program) && buildInfo.version !== version) {
-        return {
-          type: 14 /* TsVersionOutputOfDate */,
-          version: buildInfo.version
-        };
-      }
-      if (buildInfo.program) {
-        if (((_a = buildInfo.program.changeFileSet) == null ? void 0 : _a.length) || (!project.options.noEmit ? (_b = buildInfo.program.affectedFilesPendingEmit) == null ? void 0 : _b.length : some(buildInfo.program.semanticDiagnosticsPerFile, isArray))) {
-          return {
-            type: 8 /* OutOfDateBuildInfo */,
-            buildInfoFile: buildInfoPath
-          };
-        }
-        if (!project.options.noEmit && getPendingEmitKind(project.options, buildInfo.program.options || {})) {
-          return {
-            type: 9 /* OutOfDateOptions */,
-            buildInfoFile: buildInfoPath
-          };
-        }
-        buildInfoProgram = buildInfo.program;
-      }
-      oldestOutputFileTime = buildInfoTime;
-      oldestOutputFileName = buildInfoPath;
-    }
-    let newestInputFileName = void 0;
-    let newestInputFileTime = minimumDate;
-    let pseudoInputUpToDate = false;
-    const seenRoots = /* @__PURE__ */ new Set();
-    for (const inputFile of project.fileNames) {
-      const inputTime = getModifiedTime2(state, inputFile);
-      if (inputTime === missingFileModifiedTime) {
-        return {
-          type: 0 /* Unbuildable */,
-          reason: `${inputFile} does not exist`
-        };
-      }
-      if (buildInfoTime && buildInfoTime < inputTime) {
-        let version2;
-        let currentVersion;
-        if (buildInfoProgram) {
-          if (!buildInfoVersionMap)
-            buildInfoVersionMap = getBuildInfoFileVersionMap(buildInfoProgram, buildInfoPath, host);
-          version2 = buildInfoVersionMap.fileInfos.get(toPath2(state, inputFile));
-          const text = version2 ? state.readFileWithCache(inputFile) : void 0;
-          currentVersion = text !== void 0 ? getSourceFileVersionAsHashFromText(host, text) : void 0;
-          if (version2 && version2 === currentVersion)
-            pseudoInputUpToDate = true;
-        }
-        if (!version2 || version2 !== currentVersion) {
-          return {
-            type: 6 /* OutOfDateWithSelf */,
-            outOfDateOutputFileName: buildInfoPath,
-            newerInputFileName: inputFile
-          };
-        }
-      }
-      if (inputTime > newestInputFileTime) {
-        newestInputFileName = inputFile;
-        newestInputFileTime = inputTime;
-      }
-      if (buildInfoProgram)
-        seenRoots.add(toPath2(state, inputFile));
-    }
-    if (buildInfoProgram) {
-      if (!buildInfoVersionMap)
-        buildInfoVersionMap = getBuildInfoFileVersionMap(buildInfoProgram, buildInfoPath, host);
-      for (const existingRoot of buildInfoVersionMap.roots) {
-        if (!seenRoots.has(existingRoot)) {
-          return {
-            type: 10 /* OutOfDateRoots */,
-            buildInfoFile: buildInfoPath,
-            inputFile: existingRoot
-          };
-        }
-      }
-    }
-    if (!buildInfoPath) {
-      const outputs = getAllProjectOutputs(project, !host.useCaseSensitiveFileNames());
-      const outputTimeStampMap = getOutputTimeStampMap(state, resolvedPath);
-      for (const output of outputs) {
-        const path = toPath2(state, output);
-        let outputTime = outputTimeStampMap == null ? void 0 : outputTimeStampMap.get(path);
-        if (!outputTime) {
-          outputTime = getModifiedTime(state.host, output);
-          outputTimeStampMap == null ? void 0 : outputTimeStampMap.set(path, outputTime);
-        }
-        if (outputTime === missingFileModifiedTime) {
-          return {
-            type: 4 /* OutputMissing */,
-            missingOutputFileName: output
-          };
-        }
-        if (outputTime < newestInputFileTime) {
-          return {
-            type: 6 /* OutOfDateWithSelf */,
-            outOfDateOutputFileName: output,
-            newerInputFileName: newestInputFileName
-          };
-        }
-        if (outputTime < oldestOutputFileTime) {
-          oldestOutputFileTime = outputTime;
-          oldestOutputFileName = output;
-        }
-      }
-    }
-    const buildInfoCacheEntry = state.buildInfoCache.get(resolvedPath);
-    let pseudoUpToDate = false;
-    let usesPrepend = false;
-    let upstreamChangedProject;
-    if (referenceStatuses) {
-      for (const { ref, refStatus, resolvedConfig, resolvedRefPath } of referenceStatuses) {
-        usesPrepend = usesPrepend || !!ref.prepend;
-        if (refStatus.newestInputFileTime && refStatus.newestInputFileTime <= oldestOutputFileTime) {
-          continue;
-        }
-        if (buildInfoCacheEntry && hasSameBuildInfo(state, buildInfoCacheEntry, resolvedRefPath)) {
-          return {
-            type: 7 /* OutOfDateWithUpstream */,
-            outOfDateOutputFileName: buildInfoPath,
-            newerProjectName: ref.path
-          };
-        }
-        const newestDeclarationFileContentChangedTime = getLatestChangedDtsTime(state, resolvedConfig.options, resolvedRefPath);
-        if (newestDeclarationFileContentChangedTime && newestDeclarationFileContentChangedTime <= oldestOutputFileTime) {
-          pseudoUpToDate = true;
-          upstreamChangedProject = ref.path;
-          continue;
-        }
-        Debug.assert(oldestOutputFileName !== void 0, "Should have an oldest output filename here");
-        return {
-          type: 7 /* OutOfDateWithUpstream */,
-          outOfDateOutputFileName: oldestOutputFileName,
-          newerProjectName: ref.path
-        };
-      }
-    }
-    const configStatus = checkConfigFileUpToDateStatus(state, project.options.configFilePath, oldestOutputFileTime, oldestOutputFileName);
-    if (configStatus)
-      return configStatus;
-    const extendedConfigStatus = forEach(project.options.configFile.extendedSourceFiles || emptyArray, (configFile) => checkConfigFileUpToDateStatus(state, configFile, oldestOutputFileTime, oldestOutputFileName));
-    if (extendedConfigStatus)
-      return extendedConfigStatus;
-    const dependentPackageFileStatus = forEach(
-      state.lastCachedPackageJsonLookups.get(resolvedPath) || emptyArray,
-      ([path]) => checkConfigFileUpToDateStatus(state, path, oldestOutputFileTime, oldestOutputFileName)
-    );
-    if (dependentPackageFileStatus)
-      return dependentPackageFileStatus;
-    if (usesPrepend && pseudoUpToDate) {
-      return {
-        type: 3 /* OutOfDateWithPrepend */,
-        outOfDateOutputFileName: oldestOutputFileName,
-        newerProjectName: upstreamChangedProject
-      };
-    }
-    return {
-      type: pseudoUpToDate ? 2 /* UpToDateWithUpstreamTypes */ : pseudoInputUpToDate ? 15 /* UpToDateWithInputFileText */ : 1 /* UpToDate */,
-      newestInputFileTime,
-      newestInputFileName,
-      oldestOutputFileName
-    };
-  }
-  function hasSameBuildInfo(state, buildInfoCacheEntry, resolvedRefPath) {
-    const refBuildInfo = state.buildInfoCache.get(resolvedRefPath);
-    return refBuildInfo.path === buildInfoCacheEntry.path;
-  }
-  function getUpToDateStatus(state, project, resolvedPath) {
-    if (project === void 0) {
-      return { type: 0 /* Unbuildable */, reason: "File deleted mid-build" };
-    }
-    const prior = state.projectStatus.get(resolvedPath);
-    if (prior !== void 0) {
-      return prior;
-    }
-    mark("SolutionBuilder::beforeUpToDateCheck");
-    const actual = getUpToDateStatusWorker(state, project, resolvedPath);
-    mark("SolutionBuilder::afterUpToDateCheck");
-    measure("SolutionBuilder::Up-to-date check", "SolutionBuilder::beforeUpToDateCheck", "SolutionBuilder::afterUpToDateCheck");
-    state.projectStatus.set(resolvedPath, actual);
-    return actual;
-  }
-  function updateOutputTimestampsWorker(state, proj, projectPath, verboseMessage, skipOutputs) {
-    if (proj.options.noEmit)
-      return;
-    let now;
-    const buildInfoPath = getTsBuildInfoEmitOutputFilePath(proj.options);
-    if (buildInfoPath) {
-      if (!(skipOutputs == null ? void 0 : skipOutputs.has(toPath2(state, buildInfoPath)))) {
-        if (!!state.options.verbose)
-          reportStatus(state, verboseMessage, proj.options.configFilePath);
-        state.host.setModifiedTime(buildInfoPath, now = getCurrentTime(state.host));
-        getBuildInfoCacheEntry(state, buildInfoPath, projectPath).modifiedTime = now;
-      }
-      state.outputTimeStamps.delete(projectPath);
-      return;
-    }
-    const { host } = state;
-    const outputs = getAllProjectOutputs(proj, !host.useCaseSensitiveFileNames());
-    const outputTimeStampMap = getOutputTimeStampMap(state, projectPath);
-    const modifiedOutputs = outputTimeStampMap ? /* @__PURE__ */ new Set() : void 0;
-    if (!skipOutputs || outputs.length !== skipOutputs.size) {
-      let reportVerbose = !!state.options.verbose;
-      for (const file of outputs) {
-        const path = toPath2(state, file);
-        if (skipOutputs == null ? void 0 : skipOutputs.has(path))
-          continue;
-        if (reportVerbose) {
-          reportVerbose = false;
-          reportStatus(state, verboseMessage, proj.options.configFilePath);
-        }
-        host.setModifiedTime(file, now || (now = getCurrentTime(state.host)));
-        if (outputTimeStampMap) {
-          outputTimeStampMap.set(path, now);
-          modifiedOutputs.add(path);
-        }
-      }
-    }
-    outputTimeStampMap == null ? void 0 : outputTimeStampMap.forEach((_value, key) => {
-      if (!(skipOutputs == null ? void 0 : skipOutputs.has(key)) && !modifiedOutputs.has(key))
-        outputTimeStampMap.delete(key);
-    });
-  }
-  function getLatestChangedDtsTime(state, options, resolvedConfigPath) {
-    if (!options.composite)
-      return void 0;
-    const entry = Debug.checkDefined(state.buildInfoCache.get(resolvedConfigPath));
-    if (entry.latestChangedDtsTime !== void 0)
-      return entry.latestChangedDtsTime || void 0;
-    const latestChangedDtsTime = entry.buildInfo && entry.buildInfo.program && entry.buildInfo.program.latestChangedDtsFile ? state.host.getModifiedTime(getNormalizedAbsolutePath(entry.buildInfo.program.latestChangedDtsFile, getDirectoryPath(entry.path))) : void 0;
-    entry.latestChangedDtsTime = latestChangedDtsTime || false;
-    return latestChangedDtsTime;
-  }
-  function updateOutputTimestamps(state, proj, resolvedPath) {
-    if (state.options.dry) {
-      return reportStatus(state, Diagnostics.A_non_dry_build_would_update_timestamps_for_output_of_project_0, proj.options.configFilePath);
-    }
-    updateOutputTimestampsWorker(state, proj, resolvedPath, Diagnostics.Updating_output_timestamps_of_project_0);
-    state.projectStatus.set(resolvedPath, {
-      type: 1 /* UpToDate */,
-      oldestOutputFileName: getFirstProjectOutput(proj, !state.host.useCaseSensitiveFileNames())
-    });
-  }
-  function queueReferencingProjects(state, project, projectPath, projectIndex, config, buildOrder, buildResult) {
-    if (buildResult & 124 /* AnyErrors */)
-      return;
-    if (!config.options.composite)
-      return;
-    for (let index = projectIndex + 1; index < buildOrder.length; index++) {
-      const nextProject = buildOrder[index];
-      const nextProjectPath = toResolvedConfigFilePath(state, nextProject);
-      if (state.projectPendingBuild.has(nextProjectPath))
-        continue;
-      const nextProjectConfig = parseConfigFile(state, nextProject, nextProjectPath);
-      if (!nextProjectConfig || !nextProjectConfig.projectReferences)
-        continue;
-      for (const ref of nextProjectConfig.projectReferences) {
-        const resolvedRefPath = resolveProjectName(state, ref.path);
-        if (toResolvedConfigFilePath(state, resolvedRefPath) !== projectPath)
-          continue;
-        const status = state.projectStatus.get(nextProjectPath);
-        if (status) {
-          switch (status.type) {
-            case 1 /* UpToDate */:
-              if (buildResult & 2 /* DeclarationOutputUnchanged */) {
-                if (ref.prepend) {
-                  state.projectStatus.set(nextProjectPath, {
-                    type: 3 /* OutOfDateWithPrepend */,
-                    outOfDateOutputFileName: status.oldestOutputFileName,
-                    newerProjectName: project
-                  });
-                } else {
-                  status.type = 2 /* UpToDateWithUpstreamTypes */;
-                }
-                break;
-              }
-            case 15 /* UpToDateWithInputFileText */:
-            case 2 /* UpToDateWithUpstreamTypes */:
-            case 3 /* OutOfDateWithPrepend */:
-              if (!(buildResult & 2 /* DeclarationOutputUnchanged */)) {
-                state.projectStatus.set(nextProjectPath, {
-                  type: 7 /* OutOfDateWithUpstream */,
-                  outOfDateOutputFileName: status.type === 3 /* OutOfDateWithPrepend */ ? status.outOfDateOutputFileName : status.oldestOutputFileName,
-                  newerProjectName: project
-                });
-              }
-              break;
-            case 12 /* UpstreamBlocked */:
-              if (toResolvedConfigFilePath(state, resolveProjectName(state, status.upstreamProjectName)) === projectPath) {
-                clearProjectStatus(state, nextProjectPath);
-              }
-              break;
-          }
-        }
-        addProjToQueue(state, nextProjectPath, 0 /* None */);
-        break;
-      }
-    }
-  }
-  function build(state, project, cancellationToken, writeFile2, getCustomTransformers, onlyReferences) {
-    mark("SolutionBuilder::beforeBuild");
-    const result = buildWorker(state, project, cancellationToken, writeFile2, getCustomTransformers, onlyReferences);
-    mark("SolutionBuilder::afterBuild");
-    measure("SolutionBuilder::Build", "SolutionBuilder::beforeBuild", "SolutionBuilder::afterBuild");
-    return result;
-  }
-  function buildWorker(state, project, cancellationToken, writeFile2, getCustomTransformers, onlyReferences) {
-    const buildOrder = getBuildOrderFor(state, project, onlyReferences);
-    if (!buildOrder)
-      return 3 /* InvalidProject_OutputsSkipped */;
-    setupInitialBuild(state, cancellationToken);
-    let reportQueue = true;
-    let successfulProjects = 0;
-    while (true) {
-      const invalidatedProject = getNextInvalidatedProject(state, buildOrder, reportQueue);
-      if (!invalidatedProject)
-        break;
-      reportQueue = false;
-      invalidatedProject.done(cancellationToken, writeFile2, getCustomTransformers == null ? void 0 : getCustomTransformers(invalidatedProject.project));
-      if (!state.diagnostics.has(invalidatedProject.projectPath))
-        successfulProjects++;
-    }
-    disableCache(state);
-    reportErrorSummary(state, buildOrder);
-    startWatching(state, buildOrder);
-    return isCircularBuildOrder(buildOrder) ? 4 /* ProjectReferenceCycle_OutputsSkipped */ : !buildOrder.some((p) => state.diagnostics.has(toResolvedConfigFilePath(state, p))) ? 0 /* Success */ : successfulProjects ? 2 /* DiagnosticsPresent_OutputsGenerated */ : 1 /* DiagnosticsPresent_OutputsSkipped */;
-  }
-  function clean(state, project, onlyReferences) {
-    mark("SolutionBuilder::beforeClean");
-    const result = cleanWorker(state, project, onlyReferences);
-    mark("SolutionBuilder::afterClean");
-    measure("SolutionBuilder::Clean", "SolutionBuilder::beforeClean", "SolutionBuilder::afterClean");
-    return result;
-  }
-  function cleanWorker(state, project, onlyReferences) {
-    const buildOrder = getBuildOrderFor(state, project, onlyReferences);
-    if (!buildOrder)
-      return 3 /* InvalidProject_OutputsSkipped */;
-    if (isCircularBuildOrder(buildOrder)) {
-      reportErrors(state, buildOrder.circularDiagnostics);
-      return 4 /* ProjectReferenceCycle_OutputsSkipped */;
-    }
-    const { options, host } = state;
-    const filesToDelete = options.dry ? [] : void 0;
-    for (const proj of buildOrder) {
-      const resolvedPath = toResolvedConfigFilePath(state, proj);
-      const parsed = parseConfigFile(state, proj, resolvedPath);
-      if (parsed === void 0) {
-        reportParseConfigFileDiagnostic(state, resolvedPath);
-        continue;
-      }
-      const outputs = getAllProjectOutputs(parsed, !host.useCaseSensitiveFileNames());
-      if (!outputs.length)
-        continue;
-      const inputFileNames = new Set(parsed.fileNames.map((f) => toPath2(state, f)));
-      for (const output of outputs) {
-        if (inputFileNames.has(toPath2(state, output)))
-          continue;
-        if (host.fileExists(output)) {
-          if (filesToDelete) {
-            filesToDelete.push(output);
-          } else {
-            host.deleteFile(output);
-            invalidateProject(state, resolvedPath, 0 /* None */);
-          }
-        }
-      }
-    }
-    if (filesToDelete) {
-      reportStatus(state, Diagnostics.A_non_dry_build_would_delete_the_following_files_Colon_0, filesToDelete.map((f) => `\r
- * ${f}`).join(""));
-    }
-    return 0 /* Success */;
-  }
-  function invalidateProject(state, resolved, reloadLevel) {
-    if (state.host.getParsedCommandLine && reloadLevel === 1 /* Partial */) {
-      reloadLevel = 2 /* Full */;
-    }
-    if (reloadLevel === 2 /* Full */) {
-      state.configFileCache.delete(resolved);
-      state.buildOrder = void 0;
-    }
-    state.needsSummary = true;
-    clearProjectStatus(state, resolved);
-    addProjToQueue(state, resolved, reloadLevel);
-    enableCache(state);
-  }
-  function invalidateProjectAndScheduleBuilds(state, resolvedPath, reloadLevel) {
-    state.reportFileChangeDetected = true;
-    invalidateProject(state, resolvedPath, reloadLevel);
-    scheduleBuildInvalidatedProject(
-      state,
-      250,
-      /*changeDetected*/
-      true
-    );
-  }
-  function scheduleBuildInvalidatedProject(state, time, changeDetected) {
-    const { hostWithWatch } = state;
-    if (!hostWithWatch.setTimeout || !hostWithWatch.clearTimeout) {
-      return;
-    }
-    if (state.timerToBuildInvalidatedProject) {
-      hostWithWatch.clearTimeout(state.timerToBuildInvalidatedProject);
-    }
-    state.timerToBuildInvalidatedProject = hostWithWatch.setTimeout(buildNextInvalidatedProject, time, "timerToBuildInvalidatedProject", state, changeDetected);
-  }
-  function buildNextInvalidatedProject(_timeoutType, state, changeDetected) {
-    mark("SolutionBuilder::beforeBuild");
-    const buildOrder = buildNextInvalidatedProjectWorker(state, changeDetected);
-    mark("SolutionBuilder::afterBuild");
-    measure("SolutionBuilder::Build", "SolutionBuilder::beforeBuild", "SolutionBuilder::afterBuild");
-    if (buildOrder)
-      reportErrorSummary(state, buildOrder);
-  }
-  function buildNextInvalidatedProjectWorker(state, changeDetected) {
-    state.timerToBuildInvalidatedProject = void 0;
-    if (state.reportFileChangeDetected) {
-      state.reportFileChangeDetected = false;
-      state.projectErrorsReported.clear();
-      reportWatchStatus(state, Diagnostics.File_change_detected_Starting_incremental_compilation);
-    }
-    let projectsBuilt = 0;
-    const buildOrder = getBuildOrder(state);
-    const invalidatedProject = getNextInvalidatedProject(
-      state,
-      buildOrder,
-      /*reportQueue*/
-      false
-    );
-    if (invalidatedProject) {
-      invalidatedProject.done();
-      projectsBuilt++;
-      while (state.projectPendingBuild.size) {
-        if (state.timerToBuildInvalidatedProject)
-          return;
-        const info = getNextInvalidatedProjectCreateInfo(
-          state,
-          buildOrder,
-          /*reportQueue*/
-          false
-        );
-        if (!info)
-          break;
-        if (info.kind !== 2 /* UpdateOutputFileStamps */ && (changeDetected || projectsBuilt === 5)) {
-          scheduleBuildInvalidatedProject(
-            state,
-            100,
-            /*changeDetected*/
-            false
-          );
-          return;
-        }
-        const project = createInvalidatedProjectWithInfo(state, info, buildOrder);
-        project.done();
-        if (info.kind !== 2 /* UpdateOutputFileStamps */)
-          projectsBuilt++;
-      }
-    }
-    disableCache(state);
-    return buildOrder;
-  }
-  function watchConfigFile(state, resolved, resolvedPath, parsed) {
-    if (!state.watch || state.allWatchedConfigFiles.has(resolvedPath))
-      return;
-    state.allWatchedConfigFiles.set(resolvedPath, watchFile(
-      state,
-      resolved,
-      () => invalidateProjectAndScheduleBuilds(state, resolvedPath, 2 /* Full */),
-      2e3 /* High */,
-      parsed == null ? void 0 : parsed.watchOptions,
-      WatchType.ConfigFile,
-      resolved
-    ));
-  }
-  function watchExtendedConfigFiles(state, resolvedPath, parsed) {
-    updateSharedExtendedConfigFileWatcher(
-      resolvedPath,
-      parsed == null ? void 0 : parsed.options,
-      state.allWatchedExtendedConfigFiles,
-      (extendedConfigFileName, extendedConfigFilePath) => watchFile(
-        state,
-        extendedConfigFileName,
-        () => {
-          var _a;
-          return (_a = state.allWatchedExtendedConfigFiles.get(extendedConfigFilePath)) == null ? void 0 : _a.projects.forEach((projectConfigFilePath) => invalidateProjectAndScheduleBuilds(state, projectConfigFilePath, 2 /* Full */));
-        },
-        2e3 /* High */,
-        parsed == null ? void 0 : parsed.watchOptions,
-        WatchType.ExtendedConfigFile
-      ),
-      (fileName) => toPath2(state, fileName)
-    );
-  }
-  function watchWildCardDirectories(state, resolved, resolvedPath, parsed) {
-    if (!state.watch)
-      return;
-    updateWatchingWildcardDirectories(
-      getOrCreateValueMapFromConfigFileMap(state.allWatchedWildcardDirectories, resolvedPath),
-      new Map(Object.entries(parsed.wildcardDirectories)),
-      (dir, flags) => state.watchDirectory(
-        dir,
-        (fileOrDirectory) => {
-          var _a;
-          if (isIgnoredFileFromWildCardWatching({
-            watchedDirPath: toPath2(state, dir),
-            fileOrDirectory,
-            fileOrDirectoryPath: toPath2(state, fileOrDirectory),
-            configFileName: resolved,
-            currentDirectory: state.compilerHost.getCurrentDirectory(),
-            options: parsed.options,
-            program: state.builderPrograms.get(resolvedPath) || ((_a = getCachedParsedConfigFile(state, resolvedPath)) == null ? void 0 : _a.fileNames),
-            useCaseSensitiveFileNames: state.parseConfigFileHost.useCaseSensitiveFileNames,
-            writeLog: (s) => state.writeLog(s),
-            toPath: (fileName) => toPath2(state, fileName)
-          }))
-            return;
-          invalidateProjectAndScheduleBuilds(state, resolvedPath, 1 /* Partial */);
-        },
-        flags,
-        parsed == null ? void 0 : parsed.watchOptions,
-        WatchType.WildcardDirectory,
-        resolved
-      )
-    );
-  }
-  function watchInputFiles(state, resolved, resolvedPath, parsed) {
-    if (!state.watch)
-      return;
-    mutateMap(
-      getOrCreateValueMapFromConfigFileMap(state.allWatchedInputFiles, resolvedPath),
-      arrayToMap(parsed.fileNames, (fileName) => toPath2(state, fileName)),
-      {
-        createNewValue: (_path, input) => watchFile(
-          state,
-          input,
-          () => invalidateProjectAndScheduleBuilds(state, resolvedPath, 0 /* None */),
-          250 /* Low */,
-          parsed == null ? void 0 : parsed.watchOptions,
-          WatchType.SourceFile,
-          resolved
-        ),
-        onDeleteValue: closeFileWatcher
-      }
-    );
-  }
-  function watchPackageJsonFiles(state, resolved, resolvedPath, parsed) {
-    if (!state.watch || !state.lastCachedPackageJsonLookups)
-      return;
-    mutateMap(
-      getOrCreateValueMapFromConfigFileMap(state.allWatchedPackageJsonFiles, resolvedPath),
-      new Map(state.lastCachedPackageJsonLookups.get(resolvedPath)),
-      {
-        createNewValue: (path, _input) => watchFile(
-          state,
-          path,
-          () => invalidateProjectAndScheduleBuilds(state, resolvedPath, 0 /* None */),
-          2e3 /* High */,
-          parsed == null ? void 0 : parsed.watchOptions,
-          WatchType.PackageJson,
-          resolved
-        ),
-        onDeleteValue: closeFileWatcher
-      }
-    );
-  }
-  function startWatching(state, buildOrder) {
-    if (!state.watchAllProjectsPending)
-      return;
-    mark("SolutionBuilder::beforeWatcherCreation");
-    state.watchAllProjectsPending = false;
-    for (const resolved of getBuildOrderFromAnyBuildOrder(buildOrder)) {
-      const resolvedPath = toResolvedConfigFilePath(state, resolved);
-      const cfg = parseConfigFile(state, resolved, resolvedPath);
-      watchConfigFile(state, resolved, resolvedPath, cfg);
-      watchExtendedConfigFiles(state, resolvedPath, cfg);
-      if (cfg) {
-        watchWildCardDirectories(state, resolved, resolvedPath, cfg);
-        watchInputFiles(state, resolved, resolvedPath, cfg);
-        watchPackageJsonFiles(state, resolved, resolvedPath, cfg);
-      }
-    }
-    mark("SolutionBuilder::afterWatcherCreation");
-    measure("SolutionBuilder::Watcher creation", "SolutionBuilder::beforeWatcherCreation", "SolutionBuilder::afterWatcherCreation");
-  }
-  function stopWatching(state) {
-    clearMap(state.allWatchedConfigFiles, closeFileWatcher);
-    clearMap(state.allWatchedExtendedConfigFiles, closeFileWatcherOf);
-    clearMap(state.allWatchedWildcardDirectories, (watchedWildcardDirectories) => clearMap(watchedWildcardDirectories, closeFileWatcherOf));
-    clearMap(state.allWatchedInputFiles, (watchedWildcardDirectories) => clearMap(watchedWildcardDirectories, closeFileWatcher));
-    clearMap(state.allWatchedPackageJsonFiles, (watchedPacageJsonFiles) => clearMap(watchedPacageJsonFiles, closeFileWatcher));
-  }
-  function createSolutionBuilderWorker(watch, hostOrHostWithWatch, rootNames, options, baseWatchOptions) {
-    const state = createSolutionBuilderState(watch, hostOrHostWithWatch, rootNames, options, baseWatchOptions);
-    return {
-      build: (project, cancellationToken, writeFile2, getCustomTransformers) => build(state, project, cancellationToken, writeFile2, getCustomTransformers),
-      clean: (project) => clean(state, project),
-      buildReferences: (project, cancellationToken, writeFile2, getCustomTransformers) => build(
-        state,
-        project,
-        cancellationToken,
-        writeFile2,
-        getCustomTransformers,
-        /*onlyReferences*/
-        true
-      ),
-      cleanReferences: (project) => clean(
-        state,
-        project,
-        /*onlyReferences*/
-        true
-      ),
-      getNextInvalidatedProject: (cancellationToken) => {
-        setupInitialBuild(state, cancellationToken);
-        return getNextInvalidatedProject(
-          state,
-          getBuildOrder(state),
-          /*reportQueue*/
-          false
-        );
-      },
-      getBuildOrder: () => getBuildOrder(state),
-      getUpToDateStatusOfProject: (project) => {
-        const configFileName = resolveProjectName(state, project);
-        const configFilePath = toResolvedConfigFilePath(state, configFileName);
-        return getUpToDateStatus(state, parseConfigFile(state, configFileName, configFilePath), configFilePath);
-      },
-      invalidateProject: (configFilePath, reloadLevel) => invalidateProject(state, configFilePath, reloadLevel || 0 /* None */),
-      close: () => stopWatching(state)
-    };
-  }
-  function relName(state, path) {
-    return convertToRelativePath(path, state.compilerHost.getCurrentDirectory(), state.compilerHost.getCanonicalFileName);
-  }
-  function reportStatus(state, message, ...args) {
-    state.host.reportSolutionBuilderStatus(createCompilerDiagnostic(message, ...args));
-  }
-  function reportWatchStatus(state, message, ...args) {
-    var _a, _b;
-    (_b = (_a = state.hostWithWatch).onWatchStatusChange) == null ? void 0 : _b.call(_a, createCompilerDiagnostic(message, ...args), state.host.getNewLine(), state.baseCompilerOptions);
-  }
-  function reportErrors({ host }, errors) {
-    errors.forEach((err) => host.reportDiagnostic(err));
-  }
-  function reportAndStoreErrors(state, proj, errors) {
-    reportErrors(state, errors);
-    state.projectErrorsReported.set(proj, true);
-    if (errors.length) {
-      state.diagnostics.set(proj, errors);
-    }
-  }
-  function reportParseConfigFileDiagnostic(state, proj) {
-    reportAndStoreErrors(state, proj, [state.configFileCache.get(proj)]);
-  }
-  function reportErrorSummary(state, buildOrder) {
-    if (!state.needsSummary)
-      return;
-    state.needsSummary = false;
-    const canReportSummary = state.watch || !!state.host.reportErrorSummary;
-    const { diagnostics } = state;
-    let totalErrors = 0;
-    let filesInError = [];
-    if (isCircularBuildOrder(buildOrder)) {
-      reportBuildQueue(state, buildOrder.buildOrder);
-      reportErrors(state, buildOrder.circularDiagnostics);
-      if (canReportSummary)
-        totalErrors += getErrorCountForSummary(buildOrder.circularDiagnostics);
-      if (canReportSummary)
-        filesInError = [...filesInError, ...getFilesInErrorForSummary(buildOrder.circularDiagnostics)];
-    } else {
-      buildOrder.forEach((project) => {
-        const projectPath = toResolvedConfigFilePath(state, project);
-        if (!state.projectErrorsReported.has(projectPath)) {
-          reportErrors(state, diagnostics.get(projectPath) || emptyArray);
-        }
-      });
-      if (canReportSummary)
-        diagnostics.forEach((singleProjectErrors) => totalErrors += getErrorCountForSummary(singleProjectErrors));
-      if (canReportSummary)
-        diagnostics.forEach((singleProjectErrors) => [...filesInError, ...getFilesInErrorForSummary(singleProjectErrors)]);
-    }
-    if (state.watch) {
-      reportWatchStatus(state, getWatchErrorSummaryDiagnosticMessage(totalErrors), totalErrors);
-    } else if (state.host.reportErrorSummary) {
-      state.host.reportErrorSummary(totalErrors, filesInError);
-    }
-  }
-  function reportBuildQueue(state, buildQueue) {
-    if (state.options.verbose) {
-      reportStatus(state, Diagnostics.Projects_in_this_build_Colon_0, buildQueue.map((s) => "\r\n    * " + relName(state, s)).join(""));
-    }
-  }
-  function reportUpToDateStatus(state, configFileName, status) {
-    switch (status.type) {
-      case 6 /* OutOfDateWithSelf */:
-        return reportStatus(
-          state,
-          Diagnostics.Project_0_is_out_of_date_because_output_1_is_older_than_input_2,
-          relName(state, configFileName),
-          relName(state, status.outOfDateOutputFileName),
-          relName(state, status.newerInputFileName)
-        );
-      case 7 /* OutOfDateWithUpstream */:
-        return reportStatus(
-          state,
-          Diagnostics.Project_0_is_out_of_date_because_output_1_is_older_than_input_2,
-          relName(state, configFileName),
-          relName(state, status.outOfDateOutputFileName),
-          relName(state, status.newerProjectName)
-        );
-      case 4 /* OutputMissing */:
-        return reportStatus(
-          state,
-          Diagnostics.Project_0_is_out_of_date_because_output_file_1_does_not_exist,
-          relName(state, configFileName),
-          relName(state, status.missingOutputFileName)
-        );
-      case 5 /* ErrorReadingFile */:
-        return reportStatus(
-          state,
-          Diagnostics.Project_0_is_out_of_date_because_there_was_error_reading_file_1,
-          relName(state, configFileName),
-          relName(state, status.fileName)
-        );
-      case 8 /* OutOfDateBuildInfo */:
-        return reportStatus(
-          state,
-          Diagnostics.Project_0_is_out_of_date_because_buildinfo_file_1_indicates_that_some_of_the_changes_were_not_emitted,
-          relName(state, configFileName),
-          relName(state, status.buildInfoFile)
-        );
-      case 9 /* OutOfDateOptions */:
-        return reportStatus(
-          state,
-          Diagnostics.Project_0_is_out_of_date_because_buildinfo_file_1_indicates_there_is_change_in_compilerOptions,
-          relName(state, configFileName),
-          relName(state, status.buildInfoFile)
-        );
-      case 10 /* OutOfDateRoots */:
-        return reportStatus(
-          state,
-          Diagnostics.Project_0_is_out_of_date_because_buildinfo_file_1_indicates_that_file_2_was_root_file_of_compilation_but_not_any_more,
-          relName(state, configFileName),
-          relName(state, status.buildInfoFile),
-          relName(state, status.inputFile)
-        );
-      case 1 /* UpToDate */:
-        if (status.newestInputFileTime !== void 0) {
-          return reportStatus(
-            state,
-            Diagnostics.Project_0_is_up_to_date_because_newest_input_1_is_older_than_output_2,
-            relName(state, configFileName),
-            relName(state, status.newestInputFileName || ""),
-            relName(state, status.oldestOutputFileName || "")
-          );
-        }
-        break;
-      case 3 /* OutOfDateWithPrepend */:
-        return reportStatus(
-          state,
-          Diagnostics.Project_0_is_out_of_date_because_output_of_its_dependency_1_has_changed,
-          relName(state, configFileName),
-          relName(state, status.newerProjectName)
-        );
-      case 2 /* UpToDateWithUpstreamTypes */:
-        return reportStatus(
-          state,
-          Diagnostics.Project_0_is_up_to_date_with_d_ts_files_from_its_dependencies,
-          relName(state, configFileName)
-        );
-      case 15 /* UpToDateWithInputFileText */:
-        return reportStatus(
-          state,
-          Diagnostics.Project_0_is_up_to_date_but_needs_to_update_timestamps_of_output_files_that_are_older_than_input_files,
-          relName(state, configFileName)
-        );
-      case 11 /* UpstreamOutOfDate */:
-        return reportStatus(
-          state,
-          Diagnostics.Project_0_is_out_of_date_because_its_dependency_1_is_out_of_date,
-          relName(state, configFileName),
-          relName(state, status.upstreamProjectName)
-        );
-      case 12 /* UpstreamBlocked */:
-        return reportStatus(
-          state,
-          status.upstreamProjectBlocked ? Diagnostics.Project_0_can_t_be_built_because_its_dependency_1_was_not_built : Diagnostics.Project_0_can_t_be_built_because_its_dependency_1_has_errors,
-          relName(state, configFileName),
-          relName(state, status.upstreamProjectName)
-        );
-      case 0 /* Unbuildable */:
-        return reportStatus(
-          state,
-          Diagnostics.Failed_to_parse_file_0_Colon_1,
-          relName(state, configFileName),
-          status.reason
-        );
-      case 14 /* TsVersionOutputOfDate */:
-        return reportStatus(
-          state,
-          Diagnostics.Project_0_is_out_of_date_because_output_for_it_was_generated_with_version_1_that_differs_with_current_version_2,
-          relName(state, configFileName),
-          status.version,
-          version
-        );
-      case 17 /* ForceBuild */:
-        return reportStatus(
-          state,
-          Diagnostics.Project_0_is_being_forcibly_rebuilt,
-          relName(state, configFileName)
-        );
-      case 16 /* ContainerOnly */:
-      case 13 /* ComputingUpstream */:
-        break;
-      default:
-        assertType(status);
-    }
-  }
-  function verboseReportProjectStatus(state, configFileName, status) {
-    if (state.options.verbose) {
-      reportUpToDateStatus(state, configFileName, status);
-    }
-  }
-  var minimumDate, maximumDate, InvalidatedProjectKind;
-  var init_tsbuildPublic = __esm({
-    "src/compiler/tsbuildPublic.ts"() {
-      "use strict";
-      init_ts2();
-      init_ts_performance();
-      minimumDate = /* @__PURE__ */ new Date(-864e13);
-      maximumDate = /* @__PURE__ */ new Date(864e13);
-      InvalidatedProjectKind = /* @__PURE__ */ ((InvalidatedProjectKind2) => {
-        InvalidatedProjectKind2[InvalidatedProjectKind2["Build"] = 0] = "Build";
-        InvalidatedProjectKind2[InvalidatedProjectKind2["UpdateBundle"] = 1] = "UpdateBundle";
-        InvalidatedProjectKind2[InvalidatedProjectKind2["UpdateOutputFileStamps"] = 2] = "UpdateOutputFileStamps";
-        return InvalidatedProjectKind2;
-      })(InvalidatedProjectKind || {});
-    }
-  });
-
-  // src/compiler/_namespaces/ts.ts
-  var init_ts2 = __esm({
-    "src/compiler/_namespaces/ts.ts"() {
-      "use strict";
-      init_corePublic();
-      init_core();
-      init_debug();
-      init_semver();
-      init_performanceCore();
-      init_perfLogger();
-      init_tracing();
-      init_types();
-      init_sys();
-      init_path();
-      init_diagnosticInformationMap_generated();
-      init_scanner();
-      init_utilitiesPublic();
-      init_utilities();
-      init_baseNodeFactory();
-      init_parenthesizerRules();
-      init_nodeConverters();
-      init_nodeFactory();
-      init_emitNode();
-      init_emitHelpers();
-      init_nodeTests();
-      init_utilities2();
-      init_utilitiesPublic2();
-      init_parser();
-      init_commandLineParser();
-      init_moduleNameResolver();
-      init_binder();
-      init_symbolWalker();
-      init_checker();
-      init_visitorPublic();
-      init_sourcemap();
-      init_utilities3();
-      init_destructuring();
-      init_taggedTemplate();
-      init_ts();
-      init_classFields();
-      init_typeSerializer();
-      init_legacyDecorators();
-      init_esDecorators();
-      init_es2017();
-      init_es2018();
-      init_es2019();
-      init_es2020();
-      init_es2021();
-      init_esnext();
-      init_jsx();
-      init_es2016();
-      init_es2015();
-      init_es5();
-      init_generators();
-      init_module();
-      init_system();
-      init_esnextAnd2015();
-      init_node();
-      init_diagnostics();
-      init_declarations();
-      init_transformer();
-      init_emitter();
-      init_watchUtilities();
-      init_program();
-      init_builderStatePublic();
-      init_builderState();
-      init_builder();
-      init_builderPublic();
-      init_resolutionCache();
-      init_watch();
-      init_watchPublic();
-      init_tsbuild();
-      init_tsbuildPublic();
-      init_ts_moduleSpecifiers();
-      init_ts_performance();
-    }
-  });
-
-  // src/jsTyping/jsTyping.ts
-  function isTypingUpToDate(cachedTyping, availableTypingVersions) {
-    const availableVersion = new Version(getProperty(availableTypingVersions, `ts${versionMajorMinor}`) || getProperty(availableTypingVersions, "latest"));
-    return availableVersion.compareTo(cachedTyping.version) <= 0;
-  }
-  function nonRelativeModuleNameForTypingCache(moduleName) {
-    return nodeCoreModules.has(moduleName) ? "node" : moduleName;
-  }
-  function loadSafeList(host, safeListPath) {
-    const result = readConfigFile(safeListPath, (path) => host.readFile(path));
-    return new Map(Object.entries(result.config));
-  }
-  function loadTypesMap(host, typesMapPath) {
-    var _a;
-    const result = readConfigFile(typesMapPath, (path) => host.readFile(path));
-    if ((_a = result.config) == null ? void 0 : _a.simpleMap) {
-      return new Map(Object.entries(result.config.simpleMap));
-    }
-    return void 0;
-  }
-  function discoverTypings(host, log, fileNames, projectRootPath, safeList, packageNameToTypingLocation, typeAcquisition, unresolvedImports, typesRegistry, compilerOptions) {
-    if (!typeAcquisition || !typeAcquisition.enable) {
-      return { cachedTypingPaths: [], newTypingNames: [], filesToWatch: [] };
-    }
-    const inferredTypings = /* @__PURE__ */ new Map();
-    fileNames = mapDefined(fileNames, (fileName) => {
-      const path = normalizePath(fileName);
-      if (hasJSFileExtension(path)) {
-        return path;
-      }
-    });
-    const filesToWatch = [];
-    if (typeAcquisition.include)
-      addInferredTypings(typeAcquisition.include, "Explicitly included types");
-    const exclude = typeAcquisition.exclude || [];
-    if (!compilerOptions.types) {
-      const possibleSearchDirs = new Set(fileNames.map(getDirectoryPath));
-      possibleSearchDirs.add(projectRootPath);
-      possibleSearchDirs.forEach((searchDir) => {
-        getTypingNames(searchDir, "bower.json", "bower_components", filesToWatch);
-        getTypingNames(searchDir, "package.json", "node_modules", filesToWatch);
-      });
-    }
-    if (!typeAcquisition.disableFilenameBasedTypeAcquisition) {
-      getTypingNamesFromSourceFileNames(fileNames);
-    }
-    if (unresolvedImports) {
-      const module2 = deduplicate(
-        unresolvedImports.map(nonRelativeModuleNameForTypingCache),
-        equateStringsCaseSensitive,
-        compareStringsCaseSensitive
-      );
-      addInferredTypings(module2, "Inferred typings from unresolved imports");
-    }
-    packageNameToTypingLocation.forEach((typing, name) => {
-      const registryEntry = typesRegistry.get(name);
-      if (inferredTypings.has(name) && inferredTypings.get(name) === void 0 && registryEntry !== void 0 && isTypingUpToDate(typing, registryEntry)) {
-        inferredTypings.set(name, typing.typingLocation);
-      }
-    });
-    for (const excludeTypingName of exclude) {
-      const didDelete = inferredTypings.delete(excludeTypingName);
-      if (didDelete && log)
-        log(`Typing for ${excludeTypingName} is in exclude list, will be ignored.`);
-    }
-    const newTypingNames = [];
-    const cachedTypingPaths = [];
-    inferredTypings.forEach((inferred, typing) => {
-      if (inferred !== void 0) {
-        cachedTypingPaths.push(inferred);
-      } else {
-        newTypingNames.push(typing);
-      }
-    });
-    const result = { cachedTypingPaths, newTypingNames, filesToWatch };
-    if (log)
-      log(`Result: ${JSON.stringify(result)}`);
-    return result;
-    function addInferredTyping(typingName) {
-      if (!inferredTypings.has(typingName)) {
-        inferredTypings.set(typingName, void 0);
-      }
-    }
-    function addInferredTypings(typingNames, message) {
-      if (log)
-        log(`${message}: ${JSON.stringify(typingNames)}`);
-      forEach(typingNames, addInferredTyping);
-    }
-    function getTypingNames(projectRootPath2, manifestName, modulesDirName, filesToWatch2) {
-      const manifestPath = combinePaths(projectRootPath2, manifestName);
-      let manifest;
-      let manifestTypingNames;
-      if (host.fileExists(manifestPath)) {
-        filesToWatch2.push(manifestPath);
-        manifest = readConfigFile(manifestPath, (path) => host.readFile(path)).config;
-        manifestTypingNames = flatMap([manifest.dependencies, manifest.devDependencies, manifest.optionalDependencies, manifest.peerDependencies], getOwnKeys);
-        addInferredTypings(manifestTypingNames, `Typing names in '${manifestPath}' dependencies`);
-      }
-      const packagesFolderPath = combinePaths(projectRootPath2, modulesDirName);
-      filesToWatch2.push(packagesFolderPath);
-      if (!host.directoryExists(packagesFolderPath)) {
-        return;
-      }
-      const packageNames = [];
-      const dependencyManifestNames = manifestTypingNames ? manifestTypingNames.map((typingName) => combinePaths(packagesFolderPath, typingName, manifestName)) : host.readDirectory(
-        packagesFolderPath,
-        [".json" /* Json */],
-        /*excludes*/
-        void 0,
-        /*includes*/
-        void 0,
-        /*depth*/
-        3
-      ).filter((manifestPath2) => {
-        if (getBaseFileName(manifestPath2) !== manifestName) {
-          return false;
-        }
-        const pathComponents2 = getPathComponents(normalizePath(manifestPath2));
-        const isScoped = pathComponents2[pathComponents2.length - 3][0] === "@";
-        return isScoped && toFileNameLowerCase(pathComponents2[pathComponents2.length - 4]) === modulesDirName || // `node_modules/@foo/bar`
-        !isScoped && toFileNameLowerCase(pathComponents2[pathComponents2.length - 3]) === modulesDirName;
-      });
-      if (log)
-        log(`Searching for typing names in ${packagesFolderPath}; all files: ${JSON.stringify(dependencyManifestNames)}`);
-      for (const manifestPath2 of dependencyManifestNames) {
-        const normalizedFileName = normalizePath(manifestPath2);
-        const result2 = readConfigFile(normalizedFileName, (path) => host.readFile(path));
-        const manifest2 = result2.config;
-        if (!manifest2.name) {
-          continue;
-        }
-        const ownTypes = manifest2.types || manifest2.typings;
-        if (ownTypes) {
-          const absolutePath = getNormalizedAbsolutePath(ownTypes, getDirectoryPath(normalizedFileName));
-          if (host.fileExists(absolutePath)) {
-            if (log)
-              log(`    Package '${manifest2.name}' provides its own types.`);
-            inferredTypings.set(manifest2.name, absolutePath);
-          } else {
-            if (log)
-              log(`    Package '${manifest2.name}' provides its own types but they are missing.`);
-          }
-        } else {
-          packageNames.push(manifest2.name);
-        }
-      }
-      addInferredTypings(packageNames, "    Found package names");
-    }
-    function getTypingNamesFromSourceFileNames(fileNames2) {
-      const fromFileNames = mapDefined(fileNames2, (j) => {
-        if (!hasJSFileExtension(j))
-          return void 0;
-        const inferredTypingName = removeFileExtension(toFileNameLowerCase(getBaseFileName(j)));
-        const cleanedTypingName = removeMinAndVersionNumbers(inferredTypingName);
-        return safeList.get(cleanedTypingName);
-      });
-      if (fromFileNames.length) {
-        addInferredTypings(fromFileNames, "Inferred typings from file names");
-      }
-      const hasJsxFile = some(fileNames2, (f) => fileExtensionIs(f, ".jsx" /* Jsx */));
-      if (hasJsxFile) {
-        if (log)
-          log(`Inferred 'react' typings due to presence of '.jsx' extension`);
-        addInferredTyping("react");
-      }
-    }
-  }
-  function validatePackageName(packageName) {
-    return validatePackageNameWorker(
-      packageName,
-      /*supportScopedPackage*/
-      true
-    );
-  }
-  function validatePackageNameWorker(packageName, supportScopedPackage) {
-    if (!packageName) {
-      return 1 /* EmptyName */;
-    }
-    if (packageName.length > maxPackageNameLength) {
-      return 2 /* NameTooLong */;
-    }
-    if (packageName.charCodeAt(0) === 46 /* dot */) {
-      return 3 /* NameStartsWithDot */;
-    }
-    if (packageName.charCodeAt(0) === 95 /* _ */) {
-      return 4 /* NameStartsWithUnderscore */;
-    }
-    if (supportScopedPackage) {
-      const matches = /^@([^/]+)\/([^/]+)$/.exec(packageName);
-      if (matches) {
-        const scopeResult = validatePackageNameWorker(
-          matches[1],
-          /*supportScopedPackage*/
-          false
-        );
-        if (scopeResult !== 0 /* Ok */) {
-          return { name: matches[1], isScopeName: true, result: scopeResult };
-        }
-        const packageResult = validatePackageNameWorker(
-          matches[2],
-          /*supportScopedPackage*/
-          false
-        );
-        if (packageResult !== 0 /* Ok */) {
-          return { name: matches[2], isScopeName: false, result: packageResult };
-        }
-        return 0 /* Ok */;
-      }
-    }
-    if (encodeURIComponent(packageName) !== packageName) {
-      return 5 /* NameContainsNonURISafeCharacters */;
-    }
-    return 0 /* Ok */;
-  }
-  function renderPackageNameValidationFailure(result, typing) {
-    return typeof result === "object" ? renderPackageNameValidationFailureWorker(typing, result.result, result.name, result.isScopeName) : renderPackageNameValidationFailureWorker(
-      typing,
-      result,
-      typing,
-      /*isScopeName*/
-      false
-    );
-  }
-  function renderPackageNameValidationFailureWorker(typing, result, name, isScopeName) {
-    const kind = isScopeName ? "Scope" : "Package";
-    switch (result) {
-      case 1 /* EmptyName */:
-        return `'${typing}':: ${kind} name '${name}' cannot be empty`;
-      case 2 /* NameTooLong */:
-        return `'${typing}':: ${kind} name '${name}' should be less than ${maxPackageNameLength} characters`;
-      case 3 /* NameStartsWithDot */:
-        return `'${typing}':: ${kind} name '${name}' cannot start with '.'`;
-      case 4 /* NameStartsWithUnderscore */:
-        return `'${typing}':: ${kind} name '${name}' cannot start with '_'`;
-      case 5 /* NameContainsNonURISafeCharacters */:
-        return `'${typing}':: ${kind} name '${name}' contains non URI safe characters`;
-      case 0 /* Ok */:
-        return Debug.fail();
-      default:
-        Debug.assertNever(result);
-    }
-  }
-  var unprefixedNodeCoreModuleList, prefixedNodeCoreModuleList, nodeCoreModuleList, nodeCoreModules, NameValidationResult, maxPackageNameLength;
-  var init_jsTyping = __esm({
-    "src/jsTyping/jsTyping.ts"() {
-      "use strict";
-      init_ts3();
-      unprefixedNodeCoreModuleList = [
-        "assert",
-        "assert/strict",
-        "async_hooks",
-        "buffer",
-        "child_process",
-        "cluster",
-        "console",
-        "constants",
-        "crypto",
-        "dgram",
-        "diagnostics_channel",
-        "dns",
-        "dns/promises",
-        "domain",
-        "events",
-        "fs",
-        "fs/promises",
-        "http",
-        "https",
-        "http2",
-        "inspector",
-        "module",
-        "net",
-        "os",
-        "path",
-        "perf_hooks",
-        "process",
-        "punycode",
-        "querystring",
-        "readline",
-        "repl",
-        "stream",
-        "stream/promises",
-        "string_decoder",
-        "timers",
-        "timers/promises",
-        "tls",
-        "trace_events",
-        "tty",
-        "url",
-        "util",
-        "util/types",
-        "v8",
-        "vm",
-        "wasi",
-        "worker_threads",
-        "zlib"
-      ];
-      prefixedNodeCoreModuleList = unprefixedNodeCoreModuleList.map((name) => `node:${name}`);
-      nodeCoreModuleList = [...unprefixedNodeCoreModuleList, ...prefixedNodeCoreModuleList];
-      nodeCoreModules = new Set(nodeCoreModuleList);
-      NameValidationResult = /* @__PURE__ */ ((NameValidationResult2) => {
-        NameValidationResult2[NameValidationResult2["Ok"] = 0] = "Ok";
-        NameValidationResult2[NameValidationResult2["EmptyName"] = 1] = "EmptyName";
-        NameValidationResult2[NameValidationResult2["NameTooLong"] = 2] = "NameTooLong";
-        NameValidationResult2[NameValidationResult2["NameStartsWithDot"] = 3] = "NameStartsWithDot";
-        NameValidationResult2[NameValidationResult2["NameStartsWithUnderscore"] = 4] = "NameStartsWithUnderscore";
-        NameValidationResult2[NameValidationResult2["NameContainsNonURISafeCharacters"] = 5] = "NameContainsNonURISafeCharacters";
-        return NameValidationResult2;
-      })(NameValidationResult || {});
-      maxPackageNameLength = 214;
-    }
-  });
-
-  // src/jsTyping/_namespaces/ts.JsTyping.ts
-  var ts_JsTyping_exports = {};
-  __export(ts_JsTyping_exports, {
-    NameValidationResult: () => NameValidationResult,
-    discoverTypings: () => discoverTypings,
-    isTypingUpToDate: () => isTypingUpToDate,
-    loadSafeList: () => loadSafeList,
-    loadTypesMap: () => loadTypesMap,
-    nodeCoreModuleList: () => nodeCoreModuleList,
-    nodeCoreModules: () => nodeCoreModules,
-    nonRelativeModuleNameForTypingCache: () => nonRelativeModuleNameForTypingCache,
-    prefixedNodeCoreModuleList: () => prefixedNodeCoreModuleList,
-    renderPackageNameValidationFailure: () => renderPackageNameValidationFailure,
-    validatePackageName: () => validatePackageName
-  });
-  var init_ts_JsTyping = __esm({
-    "src/jsTyping/_namespaces/ts.JsTyping.ts"() {
-      "use strict";
-      init_jsTyping();
-    }
-  });
-
-  // src/jsTyping/shared.ts
-  function hasArgument(argumentName) {
-    return sys.args.indexOf(argumentName) >= 0;
-  }
-  function findArgument(argumentName) {
-    const index = sys.args.indexOf(argumentName);
-    return index >= 0 && index < sys.args.length - 1 ? sys.args[index + 1] : void 0;
-  }
-  function nowString() {
-    const d = /* @__PURE__ */ new Date();
-    return `${padLeft(d.getHours().toString(), 2, "0")}:${padLeft(d.getMinutes().toString(), 2, "0")}:${padLeft(d.getSeconds().toString(), 2, "0")}.${padLeft(d.getMilliseconds().toString(), 3, "0")}`;
-  }
-  var ActionSet, ActionInvalidate, ActionPackageInstalled, EventTypesRegistry, EventBeginInstallTypes, EventEndInstallTypes, EventInitializationFailed, ActionWatchTypingLocations, Arguments;
-  var init_shared = __esm({
-    "src/jsTyping/shared.ts"() {
-      "use strict";
-      init_ts3();
-      ActionSet = "action::set";
-      ActionInvalidate = "action::invalidate";
-      ActionPackageInstalled = "action::packageInstalled";
-      EventTypesRegistry = "event::typesRegistry";
-      EventBeginInstallTypes = "event::beginInstallTypes";
-      EventEndInstallTypes = "event::endInstallTypes";
-      EventInitializationFailed = "event::initializationFailed";
-      ActionWatchTypingLocations = "action::watchTypingLocations";
-      ((Arguments2) => {
-        Arguments2.GlobalCacheLocation = "--globalTypingsCacheLocation";
-        Arguments2.LogFile = "--logFile";
-        Arguments2.EnableTelemetry = "--enableTelemetry";
-        Arguments2.TypingSafeListLocation = "--typingSafeListLocation";
-        Arguments2.TypesMapLocation = "--typesMapLocation";
-        Arguments2.NpmLocation = "--npmLocation";
-        Arguments2.ValidateDefaultNpmLocation = "--validateDefaultNpmLocation";
-      })(Arguments || (Arguments = {}));
-    }
-  });
-
-  // src/jsTyping/types.ts
-  var init_types2 = __esm({
-    "src/jsTyping/types.ts"() {
-      "use strict";
-    }
-  });
-
-  // src/jsTyping/_namespaces/ts.server.ts
-  var ts_server_exports = {};
-  __export(ts_server_exports, {
-    ActionInvalidate: () => ActionInvalidate,
-    ActionPackageInstalled: () => ActionPackageInstalled,
-    ActionSet: () => ActionSet,
-    ActionWatchTypingLocations: () => ActionWatchTypingLocations,
-    Arguments: () => Arguments,
-    EventBeginInstallTypes: () => EventBeginInstallTypes,
-    EventEndInstallTypes: () => EventEndInstallTypes,
-    EventInitializationFailed: () => EventInitializationFailed,
-    EventTypesRegistry: () => EventTypesRegistry,
-    findArgument: () => findArgument,
-    hasArgument: () => hasArgument,
-    nowString: () => nowString
-  });
-  var init_ts_server = __esm({
-    "src/jsTyping/_namespaces/ts.server.ts"() {
-      "use strict";
-      init_shared();
-      init_types2();
-    }
-  });
-
-  // src/jsTyping/_namespaces/ts.ts
-  var init_ts3 = __esm({
-    "src/jsTyping/_namespaces/ts.ts"() {
-      "use strict";
-      init_ts2();
-      init_ts_JsTyping();
-      init_ts_server();
-    }
-  });
-
-  // src/services/types.ts
-  function getDefaultFormatCodeSettings(newLineCharacter) {
-    return {
-      indentSize: 4,
-      tabSize: 4,
-      newLineCharacter: newLineCharacter || "\n",
-      convertTabsToSpaces: true,
-      indentStyle: 2 /* Smart */,
-      insertSpaceAfterConstructor: false,
-      insertSpaceAfterCommaDelimiter: true,
-      insertSpaceAfterSemicolonInForStatements: true,
-      insertSpaceBeforeAndAfterBinaryOperators: true,
-      insertSpaceAfterKeywordsInControlFlowStatements: true,
-      insertSpaceAfterFunctionKeywordForAnonymousFunctions: false,
-      insertSpaceAfterOpeningAndBeforeClosingNonemptyParenthesis: false,
-      insertSpaceAfterOpeningAndBeforeClosingNonemptyBrackets: false,
-      insertSpaceAfterOpeningAndBeforeClosingNonemptyBraces: true,
-      insertSpaceAfterOpeningAndBeforeClosingTemplateStringBraces: false,
-      insertSpaceAfterOpeningAndBeforeClosingJsxExpressionBraces: false,
-      insertSpaceBeforeFunctionParenthesis: false,
-      placeOpenBraceOnNewLineForFunctions: false,
-      placeOpenBraceOnNewLineForControlBlocks: false,
-      semicolons: "ignore" /* Ignore */,
-      trimTrailingWhitespace: true,
-      indentSwitchCase: true
-    };
-  }
-  var ScriptSnapshot, PackageJsonDependencyGroup, PackageJsonAutoImportPreference, LanguageServiceMode, emptyOptions, SemanticClassificationFormat, OrganizeImportsMode, CompletionTriggerKind, InlayHintKind, HighlightSpanKind, IndentStyle, SemicolonPreference, testFormatSettings, SymbolDisplayPartKind, CompletionInfoFlags, OutliningSpanKind, OutputFileType, EndOfLineState, TokenClass, ScriptElementKind, ScriptElementKindModifier, ClassificationTypeNames, ClassificationType;
-  var init_types3 = __esm({
-    "src/services/types.ts"() {
-      "use strict";
-      ((ScriptSnapshot2) => {
-        class StringScriptSnapshot {
-          constructor(text) {
-            this.text = text;
-          }
-          getText(start, end) {
-            return start === 0 && end === this.text.length ? this.text : this.text.substring(start, end);
-          }
-          getLength() {
-            return this.text.length;
-          }
-          getChangeRange() {
-            return void 0;
-          }
-        }
-        function fromString(text) {
-          return new StringScriptSnapshot(text);
-        }
-        ScriptSnapshot2.fromString = fromString;
-      })(ScriptSnapshot || (ScriptSnapshot = {}));
-      PackageJsonDependencyGroup = /* @__PURE__ */ ((PackageJsonDependencyGroup2) => {
-        PackageJsonDependencyGroup2[PackageJsonDependencyGroup2["Dependencies"] = 1] = "Dependencies";
-        PackageJsonDependencyGroup2[PackageJsonDependencyGroup2["DevDependencies"] = 2] = "DevDependencies";
-        PackageJsonDependencyGroup2[PackageJsonDependencyGroup2["PeerDependencies"] = 4] = "PeerDependencies";
-        PackageJsonDependencyGroup2[PackageJsonDependencyGroup2["OptionalDependencies"] = 8] = "OptionalDependencies";
-        PackageJsonDependencyGroup2[PackageJsonDependencyGroup2["All"] = 15] = "All";
-        return PackageJsonDependencyGroup2;
-      })(PackageJsonDependencyGroup || {});
-      PackageJsonAutoImportPreference = /* @__PURE__ */ ((PackageJsonAutoImportPreference2) => {
-        PackageJsonAutoImportPreference2[PackageJsonAutoImportPreference2["Off"] = 0] = "Off";
-        PackageJsonAutoImportPreference2[PackageJsonAutoImportPreference2["On"] = 1] = "On";
-        PackageJsonAutoImportPreference2[PackageJsonAutoImportPreference2["Auto"] = 2] = "Auto";
-        return PackageJsonAutoImportPreference2;
-      })(PackageJsonAutoImportPreference || {});
-      LanguageServiceMode = /* @__PURE__ */ ((LanguageServiceMode2) => {
-        LanguageServiceMode2[LanguageServiceMode2["Semantic"] = 0] = "Semantic";
-        LanguageServiceMode2[LanguageServiceMode2["PartialSemantic"] = 1] = "PartialSemantic";
-        LanguageServiceMode2[LanguageServiceMode2["Syntactic"] = 2] = "Syntactic";
-        return LanguageServiceMode2;
-      })(LanguageServiceMode || {});
-      emptyOptions = {};
-      SemanticClassificationFormat = /* @__PURE__ */ ((SemanticClassificationFormat3) => {
-        SemanticClassificationFormat3["Original"] = "original";
-        SemanticClassificationFormat3["TwentyTwenty"] = "2020";
-        return SemanticClassificationFormat3;
-      })(SemanticClassificationFormat || {});
-      OrganizeImportsMode = /* @__PURE__ */ ((OrganizeImportsMode2) => {
-        OrganizeImportsMode2["All"] = "All";
-        OrganizeImportsMode2["SortAndCombine"] = "SortAndCombine";
-        OrganizeImportsMode2["RemoveUnused"] = "RemoveUnused";
-        return OrganizeImportsMode2;
-      })(OrganizeImportsMode || {});
-      CompletionTriggerKind = /* @__PURE__ */ ((CompletionTriggerKind2) => {
-        CompletionTriggerKind2[CompletionTriggerKind2["Invoked"] = 1] = "Invoked";
-        CompletionTriggerKind2[CompletionTriggerKind2["TriggerCharacter"] = 2] = "TriggerCharacter";
-        CompletionTriggerKind2[CompletionTriggerKind2["TriggerForIncompleteCompletions"] = 3] = "TriggerForIncompleteCompletions";
-        return CompletionTriggerKind2;
-      })(CompletionTriggerKind || {});
-      InlayHintKind = /* @__PURE__ */ ((InlayHintKind2) => {
-        InlayHintKind2["Type"] = "Type";
-        InlayHintKind2["Parameter"] = "Parameter";
-        InlayHintKind2["Enum"] = "Enum";
-        return InlayHintKind2;
-      })(InlayHintKind || {});
-      HighlightSpanKind = /* @__PURE__ */ ((HighlightSpanKind2) => {
-        HighlightSpanKind2["none"] = "none";
-        HighlightSpanKind2["definition"] = "definition";
-        HighlightSpanKind2["reference"] = "reference";
-        HighlightSpanKind2["writtenReference"] = "writtenReference";
-        return HighlightSpanKind2;
-      })(HighlightSpanKind || {});
-      IndentStyle = /* @__PURE__ */ ((IndentStyle2) => {
-        IndentStyle2[IndentStyle2["None"] = 0] = "None";
-        IndentStyle2[IndentStyle2["Block"] = 1] = "Block";
-        IndentStyle2[IndentStyle2["Smart"] = 2] = "Smart";
-        return IndentStyle2;
-      })(IndentStyle || {});
-      SemicolonPreference = /* @__PURE__ */ ((SemicolonPreference2) => {
-        SemicolonPreference2["Ignore"] = "ignore";
-        SemicolonPreference2["Insert"] = "insert";
-        SemicolonPreference2["Remove"] = "remove";
-        return SemicolonPreference2;
-      })(SemicolonPreference || {});
-      testFormatSettings = getDefaultFormatCodeSettings("\n");
-      SymbolDisplayPartKind = /* @__PURE__ */ ((SymbolDisplayPartKind2) => {
-        SymbolDisplayPartKind2[SymbolDisplayPartKind2["aliasName"] = 0] = "aliasName";
-        SymbolDisplayPartKind2[SymbolDisplayPartKind2["className"] = 1] = "className";
-        SymbolDisplayPartKind2[SymbolDisplayPartKind2["enumName"] = 2] = "enumName";
-        SymbolDisplayPartKind2[SymbolDisplayPartKind2["fieldName"] = 3] = "fieldName";
-        SymbolDisplayPartKind2[SymbolDisplayPartKind2["interfaceName"] = 4] = "interfaceName";
-        SymbolDisplayPartKind2[SymbolDisplayPartKind2["keyword"] = 5] = "keyword";
-        SymbolDisplayPartKind2[SymbolDisplayPartKind2["lineBreak"] = 6] = "lineBreak";
-        SymbolDisplayPartKind2[SymbolDisplayPartKind2["numericLiteral"] = 7] = "numericLiteral";
-        SymbolDisplayPartKind2[SymbolDisplayPartKind2["stringLiteral"] = 8] = "stringLiteral";
-        SymbolDisplayPartKind2[SymbolDisplayPartKind2["localName"] = 9] = "localName";
-        SymbolDisplayPartKind2[SymbolDisplayPartKind2["methodName"] = 10] = "methodName";
-        SymbolDisplayPartKind2[SymbolDisplayPartKind2["moduleName"] = 11] = "moduleName";
-        SymbolDisplayPartKind2[SymbolDisplayPartKind2["operator"] = 12] = "operator";
-        SymbolDisplayPartKind2[SymbolDisplayPartKind2["parameterName"] = 13] = "parameterName";
-        SymbolDisplayPartKind2[SymbolDisplayPartKind2["propertyName"] = 14] = "propertyName";
-        SymbolDisplayPartKind2[SymbolDisplayPartKind2["punctuation"] = 15] = "punctuation";
-        SymbolDisplayPartKind2[SymbolDisplayPartKind2["space"] = 16] = "space";
-        SymbolDisplayPartKind2[SymbolDisplayPartKind2["text"] = 17] = "text";
-        SymbolDisplayPartKind2[SymbolDisplayPartKind2["typeParameterName"] = 18] = "typeParameterName";
-        SymbolDisplayPartKind2[SymbolDisplayPartKind2["enumMemberName"] = 19] = "enumMemberName";
-        SymbolDisplayPartKind2[SymbolDisplayPartKind2["functionName"] = 20] = "functionName";
-        SymbolDisplayPartKind2[SymbolDisplayPartKind2["regularExpressionLiteral"] = 21] = "regularExpressionLiteral";
-        SymbolDisplayPartKind2[SymbolDisplayPartKind2["link"] = 22] = "link";
-        SymbolDisplayPartKind2[SymbolDisplayPartKind2["linkName"] = 23] = "linkName";
-        SymbolDisplayPartKind2[SymbolDisplayPartKind2["linkText"] = 24] = "linkText";
-        return SymbolDisplayPartKind2;
-      })(SymbolDisplayPartKind || {});
-      CompletionInfoFlags = /* @__PURE__ */ ((CompletionInfoFlags2) => {
-        CompletionInfoFlags2[CompletionInfoFlags2["None"] = 0] = "None";
-        CompletionInfoFlags2[CompletionInfoFlags2["MayIncludeAutoImports"] = 1] = "MayIncludeAutoImports";
-        CompletionInfoFlags2[CompletionInfoFlags2["IsImportStatementCompletion"] = 2] = "IsImportStatementCompletion";
-        CompletionInfoFlags2[CompletionInfoFlags2["IsContinuation"] = 4] = "IsContinuation";
-        CompletionInfoFlags2[CompletionInfoFlags2["ResolvedModuleSpecifiers"] = 8] = "ResolvedModuleSpecifiers";
-        CompletionInfoFlags2[CompletionInfoFlags2["ResolvedModuleSpecifiersBeyondLimit"] = 16] = "ResolvedModuleSpecifiersBeyondLimit";
-        CompletionInfoFlags2[CompletionInfoFlags2["MayIncludeMethodSnippets"] = 32] = "MayIncludeMethodSnippets";
-        return CompletionInfoFlags2;
-      })(CompletionInfoFlags || {});
-      OutliningSpanKind = /* @__PURE__ */ ((OutliningSpanKind2) => {
-        OutliningSpanKind2["Comment"] = "comment";
-        OutliningSpanKind2["Region"] = "region";
-        OutliningSpanKind2["Code"] = "code";
-        OutliningSpanKind2["Imports"] = "imports";
-        return OutliningSpanKind2;
-      })(OutliningSpanKind || {});
-      OutputFileType = /* @__PURE__ */ ((OutputFileType2) => {
-        OutputFileType2[OutputFileType2["JavaScript"] = 0] = "JavaScript";
-        OutputFileType2[OutputFileType2["SourceMap"] = 1] = "SourceMap";
-        OutputFileType2[OutputFileType2["Declaration"] = 2] = "Declaration";
-        return OutputFileType2;
-      })(OutputFileType || {});
-      EndOfLineState = /* @__PURE__ */ ((EndOfLineState3) => {
-        EndOfLineState3[EndOfLineState3["None"] = 0] = "None";
-        EndOfLineState3[EndOfLineState3["InMultiLineCommentTrivia"] = 1] = "InMultiLineCommentTrivia";
-        EndOfLineState3[EndOfLineState3["InSingleQuoteStringLiteral"] = 2] = "InSingleQuoteStringLiteral";
-        EndOfLineState3[EndOfLineState3["InDoubleQuoteStringLiteral"] = 3] = "InDoubleQuoteStringLiteral";
-        EndOfLineState3[EndOfLineState3["InTemplateHeadOrNoSubstitutionTemplate"] = 4] = "InTemplateHeadOrNoSubstitutionTemplate";
-        EndOfLineState3[EndOfLineState3["InTemplateMiddleOrTail"] = 5] = "InTemplateMiddleOrTail";
-        EndOfLineState3[EndOfLineState3["InTemplateSubstitutionPosition"] = 6] = "InTemplateSubstitutionPosition";
-        return EndOfLineState3;
-      })(EndOfLineState || {});
-      TokenClass = /* @__PURE__ */ ((TokenClass2) => {
-        TokenClass2[TokenClass2["Punctuation"] = 0] = "Punctuation";
-        TokenClass2[TokenClass2["Keyword"] = 1] = "Keyword";
-        TokenClass2[TokenClass2["Operator"] = 2] = "Operator";
-        TokenClass2[TokenClass2["Comment"] = 3] = "Comment";
-        TokenClass2[TokenClass2["Whitespace"] = 4] = "Whitespace";
-        TokenClass2[TokenClass2["Identifier"] = 5] = "Identifier";
-        TokenClass2[TokenClass2["NumberLiteral"] = 6] = "NumberLiteral";
-        TokenClass2[TokenClass2["BigIntLiteral"] = 7] = "BigIntLiteral";
-        TokenClass2[TokenClass2["StringLiteral"] = 8] = "StringLiteral";
-        TokenClass2[TokenClass2["RegExpLiteral"] = 9] = "RegExpLiteral";
-        return TokenClass2;
-      })(TokenClass || {});
-      ScriptElementKind = /* @__PURE__ */ ((ScriptElementKind2) => {
-        ScriptElementKind2["unknown"] = "";
-        ScriptElementKind2["warning"] = "warning";
-        ScriptElementKind2["keyword"] = "keyword";
-        ScriptElementKind2["scriptElement"] = "script";
-        ScriptElementKind2["moduleElement"] = "module";
-        ScriptElementKind2["classElement"] = "class";
-        ScriptElementKind2["localClassElement"] = "local class";
-        ScriptElementKind2["interfaceElement"] = "interface";
-        ScriptElementKind2["typeElement"] = "type";
-        ScriptElementKind2["enumElement"] = "enum";
-        ScriptElementKind2["enumMemberElement"] = "enum member";
-        ScriptElementKind2["variableElement"] = "var";
-        ScriptElementKind2["localVariableElement"] = "local var";
-        ScriptElementKind2["functionElement"] = "function";
-        ScriptElementKind2["localFunctionElement"] = "local function";
-        ScriptElementKind2["memberFunctionElement"] = "method";
-        ScriptElementKind2["memberGetAccessorElement"] = "getter";
-        ScriptElementKind2["memberSetAccessorElement"] = "setter";
-        ScriptElementKind2["memberVariableElement"] = "property";
-        ScriptElementKind2["memberAccessorVariableElement"] = "accessor";
-        ScriptElementKind2["constructorImplementationElement"] = "constructor";
-        ScriptElementKind2["callSignatureElement"] = "call";
-        ScriptElementKind2["indexSignatureElement"] = "index";
-        ScriptElementKind2["constructSignatureElement"] = "construct";
-        ScriptElementKind2["parameterElement"] = "parameter";
-        ScriptElementKind2["typeParameterElement"] = "type parameter";
-        ScriptElementKind2["primitiveType"] = "primitive type";
-        ScriptElementKind2["label"] = "label";
-        ScriptElementKind2["alias"] = "alias";
-        ScriptElementKind2["constElement"] = "const";
-        ScriptElementKind2["letElement"] = "let";
-        ScriptElementKind2["directory"] = "directory";
-        ScriptElementKind2["externalModuleName"] = "external module name";
-        ScriptElementKind2["jsxAttribute"] = "JSX attribute";
-        ScriptElementKind2["string"] = "string";
-        ScriptElementKind2["link"] = "link";
-        ScriptElementKind2["linkName"] = "link name";
-        ScriptElementKind2["linkText"] = "link text";
-        return ScriptElementKind2;
-      })(ScriptElementKind || {});
-      ScriptElementKindModifier = /* @__PURE__ */ ((ScriptElementKindModifier2) => {
-        ScriptElementKindModifier2["none"] = "";
-        ScriptElementKindModifier2["publicMemberModifier"] = "public";
-        ScriptElementKindModifier2["privateMemberModifier"] = "private";
-        ScriptElementKindModifier2["protectedMemberModifier"] = "protected";
-        ScriptElementKindModifier2["exportedModifier"] = "export";
-        ScriptElementKindModifier2["ambientModifier"] = "declare";
-        ScriptElementKindModifier2["staticModifier"] = "static";
-        ScriptElementKindModifier2["abstractModifier"] = "abstract";
-        ScriptElementKindModifier2["optionalModifier"] = "optional";
-        ScriptElementKindModifier2["deprecatedModifier"] = "deprecated";
-        ScriptElementKindModifier2["dtsModifier"] = ".d.ts";
-        ScriptElementKindModifier2["tsModifier"] = ".ts";
-        ScriptElementKindModifier2["tsxModifier"] = ".tsx";
-        ScriptElementKindModifier2["jsModifier"] = ".js";
-        ScriptElementKindModifier2["jsxModifier"] = ".jsx";
-        ScriptElementKindModifier2["jsonModifier"] = ".json";
-        ScriptElementKindModifier2["dmtsModifier"] = ".d.mts";
-        ScriptElementKindModifier2["mtsModifier"] = ".mts";
-        ScriptElementKindModifier2["mjsModifier"] = ".mjs";
-        ScriptElementKindModifier2["dctsModifier"] = ".d.cts";
-        ScriptElementKindModifier2["ctsModifier"] = ".cts";
-        ScriptElementKindModifier2["cjsModifier"] = ".cjs";
-        return ScriptElementKindModifier2;
-      })(ScriptElementKindModifier || {});
-      ClassificationTypeNames = /* @__PURE__ */ ((ClassificationTypeNames2) => {
-        ClassificationTypeNames2["comment"] = "comment";
-        ClassificationTypeNames2["identifier"] = "identifier";
-        ClassificationTypeNames2["keyword"] = "keyword";
-        ClassificationTypeNames2["numericLiteral"] = "number";
-        ClassificationTypeNames2["bigintLiteral"] = "bigint";
-        ClassificationTypeNames2["operator"] = "operator";
-        ClassificationTypeNames2["stringLiteral"] = "string";
-        ClassificationTypeNames2["whiteSpace"] = "whitespace";
-        ClassificationTypeNames2["text"] = "text";
-        ClassificationTypeNames2["punctuation"] = "punctuation";
-        ClassificationTypeNames2["className"] = "class name";
-        ClassificationTypeNames2["enumName"] = "enum name";
-        ClassificationTypeNames2["interfaceName"] = "interface name";
-        ClassificationTypeNames2["moduleName"] = "module name";
-        ClassificationTypeNames2["typeParameterName"] = "type parameter name";
-        ClassificationTypeNames2["typeAliasName"] = "type alias name";
-        ClassificationTypeNames2["parameterName"] = "parameter name";
-        ClassificationTypeNames2["docCommentTagName"] = "doc comment tag name";
-        ClassificationTypeNames2["jsxOpenTagName"] = "jsx open tag name";
-        ClassificationTypeNames2["jsxCloseTagName"] = "jsx close tag name";
-        ClassificationTypeNames2["jsxSelfClosingTagName"] = "jsx self closing tag name";
-        ClassificationTypeNames2["jsxAttribute"] = "jsx attribute";
-        ClassificationTypeNames2["jsxText"] = "jsx text";
-        ClassificationTypeNames2["jsxAttributeStringLiteralValue"] = "jsx attribute string literal value";
-        return ClassificationTypeNames2;
-      })(ClassificationTypeNames || {});
-      ClassificationType = /* @__PURE__ */ ((ClassificationType2) => {
-        ClassificationType2[ClassificationType2["comment"] = 1] = "comment";
-        ClassificationType2[ClassificationType2["identifier"] = 2] = "identifier";
-        ClassificationType2[ClassificationType2["keyword"] = 3] = "keyword";
-        ClassificationType2[ClassificationType2["numericLiteral"] = 4] = "numericLiteral";
-        ClassificationType2[ClassificationType2["operator"] = 5] = "operator";
-        ClassificationType2[ClassificationType2["stringLiteral"] = 6] = "stringLiteral";
-        ClassificationType2[ClassificationType2["regularExpressionLiteral"] = 7] = "regularExpressionLiteral";
-        ClassificationType2[ClassificationType2["whiteSpace"] = 8] = "whiteSpace";
-        ClassificationType2[ClassificationType2["text"] = 9] = "text";
-        ClassificationType2[ClassificationType2["punctuation"] = 10] = "punctuation";
-        ClassificationType2[ClassificationType2["className"] = 11] = "className";
-        ClassificationType2[ClassificationType2["enumName"] = 12] = "enumName";
-        ClassificationType2[ClassificationType2["interfaceName"] = 13] = "interfaceName";
-        ClassificationType2[ClassificationType2["moduleName"] = 14] = "moduleName";
-        ClassificationType2[ClassificationType2["typeParameterName"] = 15] = "typeParameterName";
-        ClassificationType2[ClassificationType2["typeAliasName"] = 16] = "typeAliasName";
-        ClassificationType2[ClassificationType2["parameterName"] = 17] = "parameterName";
-        ClassificationType2[ClassificationType2["docCommentTagName"] = 18] = "docCommentTagName";
-        ClassificationType2[ClassificationType2["jsxOpenTagName"] = 19] = "jsxOpenTagName";
-        ClassificationType2[ClassificationType2["jsxCloseTagName"] = 20] = "jsxCloseTagName";
-        ClassificationType2[ClassificationType2["jsxSelfClosingTagName"] = 21] = "jsxSelfClosingTagName";
-        ClassificationType2[ClassificationType2["jsxAttribute"] = 22] = "jsxAttribute";
-        ClassificationType2[ClassificationType2["jsxText"] = 23] = "jsxText";
-        ClassificationType2[ClassificationType2["jsxAttributeStringLiteralValue"] = 24] = "jsxAttributeStringLiteralValue";
-        ClassificationType2[ClassificationType2["bigintLiteral"] = 25] = "bigintLiteral";
-        return ClassificationType2;
-      })(ClassificationType || {});
-    }
-  });
-
-  // src/services/utilities.ts
-  function getMeaningFromDeclaration(node) {
-    switch (node.kind) {
-      case 259 /* VariableDeclaration */:
-        return isInJSFile(node) && getJSDocEnumTag(node) ? 7 /* All */ : 1 /* Value */;
-      case 168 /* Parameter */:
-      case 207 /* BindingElement */:
-      case 171 /* PropertyDeclaration */:
-      case 170 /* PropertySignature */:
-      case 302 /* PropertyAssignment */:
-      case 303 /* ShorthandPropertyAssignment */:
-      case 173 /* MethodDeclaration */:
-      case 172 /* MethodSignature */:
-      case 175 /* Constructor */:
-      case 176 /* GetAccessor */:
-      case 177 /* SetAccessor */:
-      case 261 /* FunctionDeclaration */:
-      case 217 /* FunctionExpression */:
-      case 218 /* ArrowFunction */:
-      case 298 /* CatchClause */:
-      case 290 /* JsxAttribute */:
-        return 1 /* Value */;
-      case 167 /* TypeParameter */:
-      case 263 /* InterfaceDeclaration */:
-      case 264 /* TypeAliasDeclaration */:
-      case 186 /* TypeLiteral */:
-        return 2 /* Type */;
-      case 352 /* JSDocTypedefTag */:
-        return node.name === void 0 ? 1 /* Value */ | 2 /* Type */ : 2 /* Type */;
-      case 305 /* EnumMember */:
-      case 262 /* ClassDeclaration */:
-        return 1 /* Value */ | 2 /* Type */;
-      case 266 /* ModuleDeclaration */:
-        if (isAmbientModule(node)) {
-          return 4 /* Namespace */ | 1 /* Value */;
-        } else if (getModuleInstanceState(node) === 1 /* Instantiated */) {
-          return 4 /* Namespace */ | 1 /* Value */;
-        } else {
-          return 4 /* Namespace */;
-        }
-      case 265 /* EnumDeclaration */:
-      case 274 /* NamedImports */:
-      case 275 /* ImportSpecifier */:
-      case 270 /* ImportEqualsDeclaration */:
-      case 271 /* ImportDeclaration */:
-      case 276 /* ExportAssignment */:
-      case 277 /* ExportDeclaration */:
-        return 7 /* All */;
-      case 311 /* SourceFile */:
-        return 4 /* Namespace */ | 1 /* Value */;
-    }
-    return 7 /* All */;
-  }
-  function getMeaningFromLocation(node) {
-    node = getAdjustedReferenceLocation(node);
-    const parent2 = node.parent;
-    if (node.kind === 311 /* SourceFile */) {
-      return 1 /* Value */;
-    } else if (isExportAssignment(parent2) || isExportSpecifier(parent2) || isExternalModuleReference(parent2) || isImportSpecifier(parent2) || isImportClause(parent2) || isImportEqualsDeclaration(parent2) && node === parent2.name) {
-      return 7 /* All */;
-    } else if (isInRightSideOfInternalImportEqualsDeclaration(node)) {
-      return getMeaningFromRightHandSideOfImportEquals(node);
-    } else if (isDeclarationName(node)) {
-      return getMeaningFromDeclaration(parent2);
-    } else if (isEntityName(node) && findAncestor(node, or(isJSDocNameReference, isJSDocLinkLike, isJSDocMemberName))) {
-      return 7 /* All */;
-    } else if (isTypeReference(node)) {
-      return 2 /* Type */;
-    } else if (isNamespaceReference(node)) {
-      return 4 /* Namespace */;
-    } else if (isTypeParameterDeclaration(parent2)) {
-      Debug.assert(isJSDocTemplateTag(parent2.parent));
-      return 2 /* Type */;
-    } else if (isLiteralTypeNode(parent2)) {
-      return 2 /* Type */ | 1 /* Value */;
-    } else {
-      return 1 /* Value */;
-    }
-  }
-  function getMeaningFromRightHandSideOfImportEquals(node) {
-    const name = node.kind === 165 /* QualifiedName */ ? node : isQualifiedName(node.parent) && node.parent.right === node ? node.parent : void 0;
-    return name && name.parent.kind === 270 /* ImportEqualsDeclaration */ ? 7 /* All */ : 4 /* Namespace */;
-  }
-  function isInRightSideOfInternalImportEqualsDeclaration(node) {
-    while (node.parent.kind === 165 /* QualifiedName */) {
-      node = node.parent;
-    }
-    return isInternalModuleImportEqualsDeclaration(node.parent) && node.parent.moduleReference === node;
-  }
-  function isNamespaceReference(node) {
-    return isQualifiedNameNamespaceReference(node) || isPropertyAccessNamespaceReference(node);
-  }
-  function isQualifiedNameNamespaceReference(node) {
-    let root = node;
-    let isLastClause = true;
-    if (root.parent.kind === 165 /* QualifiedName */) {
-      while (root.parent && root.parent.kind === 165 /* QualifiedName */) {
-        root = root.parent;
-      }
-      isLastClause = root.right === node;
-    }
-    return root.parent.kind === 182 /* TypeReference */ && !isLastClause;
-  }
-  function isPropertyAccessNamespaceReference(node) {
-    let root = node;
-    let isLastClause = true;
-    if (root.parent.kind === 210 /* PropertyAccessExpression */) {
-      while (root.parent && root.parent.kind === 210 /* PropertyAccessExpression */) {
-        root = root.parent;
-      }
-      isLastClause = root.name === node;
-    }
-    if (!isLastClause && root.parent.kind === 232 /* ExpressionWithTypeArguments */ && root.parent.parent.kind === 297 /* HeritageClause */) {
-      const decl = root.parent.parent.parent;
-      return decl.kind === 262 /* ClassDeclaration */ && root.parent.parent.token === 119 /* ImplementsKeyword */ || decl.kind === 263 /* InterfaceDeclaration */ && root.parent.parent.token === 96 /* ExtendsKeyword */;
-    }
-    return false;
-  }
-  function isTypeReference(node) {
-    if (isRightSideOfQualifiedNameOrPropertyAccess(node)) {
-      node = node.parent;
-    }
-    switch (node.kind) {
-      case 110 /* ThisKeyword */:
-        return !isExpressionNode(node);
-      case 196 /* ThisType */:
-        return true;
-    }
-    switch (node.parent.kind) {
-      case 182 /* TypeReference */:
-        return true;
-      case 204 /* ImportType */:
-        return !node.parent.isTypeOf;
-      case 232 /* ExpressionWithTypeArguments */:
-        return isPartOfTypeNode(node.parent);
-    }
-    return false;
-  }
-  function isCallExpressionTarget(node, includeElementAccess = false, skipPastOuterExpressions = false) {
-    return isCalleeWorker(node, isCallExpression, selectExpressionOfCallOrNewExpressionOrDecorator, includeElementAccess, skipPastOuterExpressions);
-  }
-  function isNewExpressionTarget(node, includeElementAccess = false, skipPastOuterExpressions = false) {
-    return isCalleeWorker(node, isNewExpression, selectExpressionOfCallOrNewExpressionOrDecorator, includeElementAccess, skipPastOuterExpressions);
-  }
-  function isCallOrNewExpressionTarget(node, includeElementAccess = false, skipPastOuterExpressions = false) {
-    return isCalleeWorker(node, isCallOrNewExpression, selectExpressionOfCallOrNewExpressionOrDecorator, includeElementAccess, skipPastOuterExpressions);
-  }
-  function isTaggedTemplateTag(node, includeElementAccess = false, skipPastOuterExpressions = false) {
-    return isCalleeWorker(node, isTaggedTemplateExpression, selectTagOfTaggedTemplateExpression, includeElementAccess, skipPastOuterExpressions);
-  }
-  function isDecoratorTarget(node, includeElementAccess = false, skipPastOuterExpressions = false) {
-    return isCalleeWorker(node, isDecorator, selectExpressionOfCallOrNewExpressionOrDecorator, includeElementAccess, skipPastOuterExpressions);
-  }
-  function isJsxOpeningLikeElementTagName(node, includeElementAccess = false, skipPastOuterExpressions = false) {
-    return isCalleeWorker(node, isJsxOpeningLikeElement, selectTagNameOfJsxOpeningLikeElement, includeElementAccess, skipPastOuterExpressions);
-  }
-  function selectExpressionOfCallOrNewExpressionOrDecorator(node) {
-    return node.expression;
-  }
-  function selectTagOfTaggedTemplateExpression(node) {
-    return node.tag;
-  }
-  function selectTagNameOfJsxOpeningLikeElement(node) {
-    return node.tagName;
-  }
-  function isCalleeWorker(node, pred, calleeSelector, includeElementAccess, skipPastOuterExpressions) {
-    let target = includeElementAccess ? climbPastPropertyOrElementAccess(node) : climbPastPropertyAccess(node);
-    if (skipPastOuterExpressions) {
-      target = skipOuterExpressions(target);
-    }
-    return !!target && !!target.parent && pred(target.parent) && calleeSelector(target.parent) === target;
-  }
-  function climbPastPropertyAccess(node) {
-    return isRightSideOfPropertyAccess(node) ? node.parent : node;
-  }
-  function climbPastPropertyOrElementAccess(node) {
-    return isRightSideOfPropertyAccess(node) || isArgumentExpressionOfElementAccess(node) ? node.parent : node;
-  }
-  function getTargetLabel(referenceNode, labelName) {
-    while (referenceNode) {
-      if (referenceNode.kind === 255 /* LabeledStatement */ && referenceNode.label.escapedText === labelName) {
-        return referenceNode.label;
-      }
-      referenceNode = referenceNode.parent;
-    }
-    return void 0;
-  }
-  function hasPropertyAccessExpressionWithName(node, funcName) {
-    if (!isPropertyAccessExpression(node.expression)) {
-      return false;
-    }
-    return node.expression.name.text === funcName;
-  }
-  function isJumpStatementTarget(node) {
-    var _a;
-    return isIdentifier(node) && ((_a = tryCast(node.parent, isBreakOrContinueStatement)) == null ? void 0 : _a.label) === node;
-  }
-  function isLabelOfLabeledStatement(node) {
-    var _a;
-    return isIdentifier(node) && ((_a = tryCast(node.parent, isLabeledStatement)) == null ? void 0 : _a.label) === node;
-  }
-  function isLabelName(node) {
-    return isLabelOfLabeledStatement(node) || isJumpStatementTarget(node);
-  }
-  function isTagName(node) {
-    var _a;
-    return ((_a = tryCast(node.parent, isJSDocTag)) == null ? void 0 : _a.tagName) === node;
-  }
-  function isRightSideOfQualifiedName(node) {
-    var _a;
-    return ((_a = tryCast(node.parent, isQualifiedName)) == null ? void 0 : _a.right) === node;
-  }
-  function isRightSideOfPropertyAccess(node) {
-    var _a;
-    return ((_a = tryCast(node.parent, isPropertyAccessExpression)) == null ? void 0 : _a.name) === node;
-  }
-  function isArgumentExpressionOfElementAccess(node) {
-    var _a;
-    return ((_a = tryCast(node.parent, isElementAccessExpression)) == null ? void 0 : _a.argumentExpression) === node;
-  }
-  function isNameOfModuleDeclaration(node) {
-    var _a;
-    return ((_a = tryCast(node.parent, isModuleDeclaration)) == null ? void 0 : _a.name) === node;
-  }
-  function isNameOfFunctionDeclaration(node) {
-    var _a;
-    return isIdentifier(node) && ((_a = tryCast(node.parent, isFunctionLike)) == null ? void 0 : _a.name) === node;
-  }
-  function isLiteralNameOfPropertyDeclarationOrIndexAccess(node) {
-    switch (node.parent.kind) {
-      case 171 /* PropertyDeclaration */:
-      case 170 /* PropertySignature */:
-      case 302 /* PropertyAssignment */:
-      case 305 /* EnumMember */:
-      case 173 /* MethodDeclaration */:
-      case 172 /* MethodSignature */:
-      case 176 /* GetAccessor */:
-      case 177 /* SetAccessor */:
-      case 266 /* ModuleDeclaration */:
-        return getNameOfDeclaration(node.parent) === node;
-      case 211 /* ElementAccessExpression */:
-        return node.parent.argumentExpression === node;
-      case 166 /* ComputedPropertyName */:
-        return true;
-      case 200 /* LiteralType */:
-        return node.parent.parent.kind === 198 /* IndexedAccessType */;
-      default:
-        return false;
-    }
-  }
-  function isExpressionOfExternalModuleImportEqualsDeclaration(node) {
-    return isExternalModuleImportEqualsDeclaration(node.parent.parent) && getExternalModuleImportEqualsDeclarationExpression(node.parent.parent) === node;
-  }
-  function getContainerNode(node) {
-    if (isJSDocTypeAlias(node)) {
-      node = node.parent.parent;
-    }
-    while (true) {
-      node = node.parent;
-      if (!node) {
-        return void 0;
-      }
-      switch (node.kind) {
-        case 311 /* SourceFile */:
-        case 173 /* MethodDeclaration */:
-        case 172 /* MethodSignature */:
-        case 261 /* FunctionDeclaration */:
-        case 217 /* FunctionExpression */:
-        case 176 /* GetAccessor */:
-        case 177 /* SetAccessor */:
-        case 262 /* ClassDeclaration */:
-        case 263 /* InterfaceDeclaration */:
-        case 265 /* EnumDeclaration */:
-        case 266 /* ModuleDeclaration */:
-          return node;
-      }
-    }
-  }
-  function getNodeKind(node) {
-    switch (node.kind) {
-      case 311 /* SourceFile */:
-        return isExternalModule(node) ? "module" /* moduleElement */ : "script" /* scriptElement */;
-      case 266 /* ModuleDeclaration */:
-        return "module" /* moduleElement */;
-      case 262 /* ClassDeclaration */:
-      case 230 /* ClassExpression */:
-        return "class" /* classElement */;
-      case 263 /* InterfaceDeclaration */:
-        return "interface" /* interfaceElement */;
-      case 264 /* TypeAliasDeclaration */:
-      case 344 /* JSDocCallbackTag */:
-      case 352 /* JSDocTypedefTag */:
-        return "type" /* typeElement */;
-      case 265 /* EnumDeclaration */:
-        return "enum" /* enumElement */;
-      case 259 /* VariableDeclaration */:
-        return getKindOfVariableDeclaration(node);
-      case 207 /* BindingElement */:
-        return getKindOfVariableDeclaration(getRootDeclaration(node));
-      case 218 /* ArrowFunction */:
-      case 261 /* FunctionDeclaration */:
-      case 217 /* FunctionExpression */:
-        return "function" /* functionElement */;
-      case 176 /* GetAccessor */:
-        return "getter" /* memberGetAccessorElement */;
-      case 177 /* SetAccessor */:
-        return "setter" /* memberSetAccessorElement */;
-      case 173 /* MethodDeclaration */:
-      case 172 /* MethodSignature */:
-        return "method" /* memberFunctionElement */;
-      case 302 /* PropertyAssignment */:
-        const { initializer } = node;
-        return isFunctionLike(initializer) ? "method" /* memberFunctionElement */ : "property" /* memberVariableElement */;
-      case 171 /* PropertyDeclaration */:
-      case 170 /* PropertySignature */:
-      case 303 /* ShorthandPropertyAssignment */:
-      case 304 /* SpreadAssignment */:
-        return "property" /* memberVariableElement */;
-      case 180 /* IndexSignature */:
-        return "index" /* indexSignatureElement */;
-      case 179 /* ConstructSignature */:
-        return "construct" /* constructSignatureElement */;
-      case 178 /* CallSignature */:
-        return "call" /* callSignatureElement */;
-      case 175 /* Constructor */:
-      case 174 /* ClassStaticBlockDeclaration */:
-        return "constructor" /* constructorImplementationElement */;
-      case 167 /* TypeParameter */:
-        return "type parameter" /* typeParameterElement */;
-      case 305 /* EnumMember */:
-        return "enum member" /* enumMemberElement */;
-      case 168 /* Parameter */:
-        return hasSyntacticModifier(node, 16476 /* ParameterPropertyModifier */) ? "property" /* memberVariableElement */ : "parameter" /* parameterElement */;
-      case 270 /* ImportEqualsDeclaration */:
-      case 275 /* ImportSpecifier */:
-      case 280 /* ExportSpecifier */:
-      case 273 /* NamespaceImport */:
-      case 279 /* NamespaceExport */:
-        return "alias" /* alias */;
-      case 225 /* BinaryExpression */:
-        const kind = getAssignmentDeclarationKind(node);
-        const { right } = node;
-        switch (kind) {
-          case 7 /* ObjectDefinePropertyValue */:
-          case 8 /* ObjectDefinePropertyExports */:
-          case 9 /* ObjectDefinePrototypeProperty */:
-          case 0 /* None */:
-            return "" /* unknown */;
-          case 1 /* ExportsProperty */:
-          case 2 /* ModuleExports */:
-            const rightKind = getNodeKind(right);
-            return rightKind === "" /* unknown */ ? "const" /* constElement */ : rightKind;
-          case 3 /* PrototypeProperty */:
-            return isFunctionExpression(right) ? "method" /* memberFunctionElement */ : "property" /* memberVariableElement */;
-          case 4 /* ThisProperty */:
-            return "property" /* memberVariableElement */;
-          case 5 /* Property */:
-            return isFunctionExpression(right) ? "method" /* memberFunctionElement */ : "property" /* memberVariableElement */;
-          case 6 /* Prototype */:
-            return "local class" /* localClassElement */;
-          default: {
-            assertType(kind);
-            return "" /* unknown */;
-          }
-        }
-      case 80 /* Identifier */:
-        return isImportClause(node.parent) ? "alias" /* alias */ : "" /* unknown */;
-      case 276 /* ExportAssignment */:
-        const scriptKind = getNodeKind(node.expression);
-        return scriptKind === "" /* unknown */ ? "const" /* constElement */ : scriptKind;
-      default:
-        return "" /* unknown */;
-    }
-    function getKindOfVariableDeclaration(v) {
-      return isVarConst(v) ? "const" /* constElement */ : isLet(v) ? "let" /* letElement */ : "var" /* variableElement */;
-    }
-  }
-  function isThis(node) {
-    switch (node.kind) {
-      case 110 /* ThisKeyword */:
-        return true;
-      case 80 /* Identifier */:
-        return identifierIsThisKeyword(node) && node.parent.kind === 168 /* Parameter */;
-      default:
-        return false;
-    }
-  }
-  function getLineStartPositionForPosition(position, sourceFile) {
-    const lineStarts = getLineStarts(sourceFile);
-    const line = sourceFile.getLineAndCharacterOfPosition(position).line;
-    return lineStarts[line];
-  }
-  function rangeContainsRange(r1, r2) {
-    return startEndContainsRange(r1.pos, r1.end, r2);
-  }
-  function rangeContainsRangeExclusive(r1, r2) {
-    return rangeContainsPositionExclusive(r1, r2.pos) && rangeContainsPositionExclusive(r1, r2.end);
-  }
-  function rangeContainsPosition(r, pos) {
-    return r.pos <= pos && pos <= r.end;
-  }
-  function rangeContainsPositionExclusive(r, pos) {
-    return r.pos < pos && pos < r.end;
-  }
-  function startEndContainsRange(start, end, range) {
-    return start <= range.pos && end >= range.end;
-  }
-  function rangeContainsStartEnd(range, start, end) {
-    return range.pos <= start && range.end >= end;
-  }
-  function rangeOverlapsWithStartEnd(r1, start, end) {
-    return startEndOverlapsWithStartEnd(r1.pos, r1.end, start, end);
-  }
-  function nodeOverlapsWithStartEnd(node, sourceFile, start, end) {
-    return startEndOverlapsWithStartEnd(node.getStart(sourceFile), node.end, start, end);
-  }
-  function startEndOverlapsWithStartEnd(start1, end1, start2, end2) {
-    const start = Math.max(start1, start2);
-    const end = Math.min(end1, end2);
-    return start < end;
-  }
-  function positionBelongsToNode(candidate, position, sourceFile) {
-    Debug.assert(candidate.pos <= position);
-    return position < candidate.end || !isCompletedNode(candidate, sourceFile);
-  }
-  function isCompletedNode(n, sourceFile) {
-    if (n === void 0 || nodeIsMissing(n)) {
-      return false;
-    }
-    switch (n.kind) {
-      case 262 /* ClassDeclaration */:
-      case 263 /* InterfaceDeclaration */:
-      case 265 /* EnumDeclaration */:
-      case 209 /* ObjectLiteralExpression */:
-      case 205 /* ObjectBindingPattern */:
-      case 186 /* TypeLiteral */:
-      case 240 /* Block */:
-      case 267 /* ModuleBlock */:
-      case 268 /* CaseBlock */:
-      case 274 /* NamedImports */:
-      case 278 /* NamedExports */:
-        return nodeEndsWith(n, 20 /* CloseBraceToken */, sourceFile);
-      case 298 /* CatchClause */:
-        return isCompletedNode(n.block, sourceFile);
-      case 213 /* NewExpression */:
-        if (!n.arguments) {
-          return true;
-        }
-      case 212 /* CallExpression */:
-      case 216 /* ParenthesizedExpression */:
-      case 195 /* ParenthesizedType */:
-        return nodeEndsWith(n, 22 /* CloseParenToken */, sourceFile);
-      case 183 /* FunctionType */:
-      case 184 /* ConstructorType */:
-        return isCompletedNode(n.type, sourceFile);
-      case 175 /* Constructor */:
-      case 176 /* GetAccessor */:
-      case 177 /* SetAccessor */:
-      case 261 /* FunctionDeclaration */:
-      case 217 /* FunctionExpression */:
-      case 173 /* MethodDeclaration */:
-      case 172 /* MethodSignature */:
-      case 179 /* ConstructSignature */:
-      case 178 /* CallSignature */:
-      case 218 /* ArrowFunction */:
-        if (n.body) {
-          return isCompletedNode(n.body, sourceFile);
-        }
-        if (n.type) {
-          return isCompletedNode(n.type, sourceFile);
-        }
-        return hasChildOfKind(n, 22 /* CloseParenToken */, sourceFile);
-      case 266 /* ModuleDeclaration */:
-        return !!n.body && isCompletedNode(n.body, sourceFile);
-      case 244 /* IfStatement */:
-        if (n.elseStatement) {
-          return isCompletedNode(n.elseStatement, sourceFile);
-        }
-        return isCompletedNode(n.thenStatement, sourceFile);
-      case 243 /* ExpressionStatement */:
-        return isCompletedNode(n.expression, sourceFile) || hasChildOfKind(n, 27 /* SemicolonToken */, sourceFile);
-      case 208 /* ArrayLiteralExpression */:
-      case 206 /* ArrayBindingPattern */:
-      case 211 /* ElementAccessExpression */:
-      case 166 /* ComputedPropertyName */:
-      case 188 /* TupleType */:
-        return nodeEndsWith(n, 24 /* CloseBracketToken */, sourceFile);
-      case 180 /* IndexSignature */:
-        if (n.type) {
-          return isCompletedNode(n.type, sourceFile);
-        }
-        return hasChildOfKind(n, 24 /* CloseBracketToken */, sourceFile);
-      case 295 /* CaseClause */:
-      case 296 /* DefaultClause */:
-        return false;
-      case 247 /* ForStatement */:
-      case 248 /* ForInStatement */:
-      case 249 /* ForOfStatement */:
-      case 246 /* WhileStatement */:
-        return isCompletedNode(n.statement, sourceFile);
-      case 245 /* DoStatement */:
-        return hasChildOfKind(n, 117 /* WhileKeyword */, sourceFile) ? nodeEndsWith(n, 22 /* CloseParenToken */, sourceFile) : isCompletedNode(n.statement, sourceFile);
-      case 185 /* TypeQuery */:
-        return isCompletedNode(n.exprName, sourceFile);
-      case 220 /* TypeOfExpression */:
-      case 219 /* DeleteExpression */:
-      case 221 /* VoidExpression */:
-      case 228 /* YieldExpression */:
-      case 229 /* SpreadElement */:
-        const unaryWordExpression = n;
-        return isCompletedNode(unaryWordExpression.expression, sourceFile);
-      case 214 /* TaggedTemplateExpression */:
-        return isCompletedNode(n.template, sourceFile);
-      case 227 /* TemplateExpression */:
-        const lastSpan = lastOrUndefined(n.templateSpans);
-        return isCompletedNode(lastSpan, sourceFile);
-      case 238 /* TemplateSpan */:
-        return nodeIsPresent(n.literal);
-      case 277 /* ExportDeclaration */:
-      case 271 /* ImportDeclaration */:
-        return nodeIsPresent(n.moduleSpecifier);
-      case 223 /* PrefixUnaryExpression */:
-        return isCompletedNode(n.operand, sourceFile);
-      case 225 /* BinaryExpression */:
-        return isCompletedNode(n.right, sourceFile);
-      case 226 /* ConditionalExpression */:
-        return isCompletedNode(n.whenFalse, sourceFile);
-      default:
-        return true;
-    }
-  }
-  function nodeEndsWith(n, expectedLastToken, sourceFile) {
-    const children = n.getChildren(sourceFile);
-    if (children.length) {
-      const lastChild = last(children);
-      if (lastChild.kind === expectedLastToken) {
-        return true;
-      } else if (lastChild.kind === 27 /* SemicolonToken */ && children.length !== 1) {
-        return children[children.length - 2].kind === expectedLastToken;
-      }
-    }
-    return false;
-  }
-  function findListItemInfo(node) {
-    const list = findContainingList(node);
-    if (!list) {
-      return void 0;
-    }
-    const children = list.getChildren();
-    const listItemIndex = indexOfNode(children, node);
-    return {
-      listItemIndex,
-      list
-    };
-  }
-  function hasChildOfKind(n, kind, sourceFile) {
-    return !!findChildOfKind(n, kind, sourceFile);
-  }
-  function findChildOfKind(n, kind, sourceFile) {
-    return find(n.getChildren(sourceFile), (c) => c.kind === kind);
-  }
-  function findContainingList(node) {
-    const syntaxList = find(node.parent.getChildren(), (c) => isSyntaxList(c) && rangeContainsRange(c, node));
-    Debug.assert(!syntaxList || contains(syntaxList.getChildren(), node));
-    return syntaxList;
-  }
-  function isDefaultModifier2(node) {
-    return node.kind === 90 /* DefaultKeyword */;
-  }
-  function isClassKeyword(node) {
-    return node.kind === 86 /* ClassKeyword */;
-  }
-  function isFunctionKeyword(node) {
-    return node.kind === 100 /* FunctionKeyword */;
-  }
-  function getAdjustedLocationForClass(node) {
-    if (isNamedDeclaration(node)) {
-      return node.name;
-    }
-    if (isClassDeclaration(node)) {
-      const defaultModifier = node.modifiers && find(node.modifiers, isDefaultModifier2);
-      if (defaultModifier)
-        return defaultModifier;
-    }
-    if (isClassExpression(node)) {
-      const classKeyword = find(node.getChildren(), isClassKeyword);
-      if (classKeyword)
-        return classKeyword;
-    }
-  }
-  function getAdjustedLocationForFunction(node) {
-    if (isNamedDeclaration(node)) {
-      return node.name;
-    }
-    if (isFunctionDeclaration(node)) {
-      const defaultModifier = find(node.modifiers, isDefaultModifier2);
-      if (defaultModifier)
-        return defaultModifier;
-    }
-    if (isFunctionExpression(node)) {
-      const functionKeyword = find(node.getChildren(), isFunctionKeyword);
-      if (functionKeyword)
-        return functionKeyword;
-    }
-  }
-  function getAncestorTypeNode(node) {
-    let lastTypeNode;
-    findAncestor(node, (a) => {
-      if (isTypeNode(a)) {
-        lastTypeNode = a;
-      }
-      return !isQualifiedName(a.parent) && !isTypeNode(a.parent) && !isTypeElement(a.parent);
-    });
-    return lastTypeNode;
-  }
-  function getContextualTypeFromParentOrAncestorTypeNode(node, checker) {
-    if (node.flags & (8388608 /* JSDoc */ & ~262144 /* JavaScriptFile */))
-      return void 0;
-    const contextualType = getContextualTypeFromParent(node, checker);
-    if (contextualType)
-      return contextualType;
-    const ancestorTypeNode = getAncestorTypeNode(node);
-    return ancestorTypeNode && checker.getTypeAtLocation(ancestorTypeNode);
-  }
-  function getAdjustedLocationForDeclaration(node, forRename) {
-    if (!forRename) {
-      switch (node.kind) {
-        case 262 /* ClassDeclaration */:
-        case 230 /* ClassExpression */:
-          return getAdjustedLocationForClass(node);
-        case 261 /* FunctionDeclaration */:
-        case 217 /* FunctionExpression */:
-          return getAdjustedLocationForFunction(node);
-        case 175 /* Constructor */:
-          return node;
-      }
-    }
-    if (isNamedDeclaration(node)) {
-      return node.name;
-    }
-  }
-  function getAdjustedLocationForImportDeclaration(node, forRename) {
-    if (node.importClause) {
-      if (node.importClause.name && node.importClause.namedBindings) {
-        return;
-      }
-      if (node.importClause.name) {
-        return node.importClause.name;
-      }
-      if (node.importClause.namedBindings) {
-        if (isNamedImports(node.importClause.namedBindings)) {
-          const onlyBinding = singleOrUndefined(node.importClause.namedBindings.elements);
-          if (!onlyBinding) {
-            return;
-          }
-          return onlyBinding.name;
-        } else if (isNamespaceImport(node.importClause.namedBindings)) {
-          return node.importClause.namedBindings.name;
-        }
-      }
-    }
-    if (!forRename) {
-      return node.moduleSpecifier;
-    }
-  }
-  function getAdjustedLocationForExportDeclaration(node, forRename) {
-    if (node.exportClause) {
-      if (isNamedExports(node.exportClause)) {
-        const onlyBinding = singleOrUndefined(node.exportClause.elements);
-        if (!onlyBinding) {
-          return;
-        }
-        return node.exportClause.elements[0].name;
-      } else if (isNamespaceExport(node.exportClause)) {
-        return node.exportClause.name;
-      }
-    }
-    if (!forRename) {
-      return node.moduleSpecifier;
-    }
-  }
-  function getAdjustedLocationForHeritageClause(node) {
-    if (node.types.length === 1) {
-      return node.types[0].expression;
-    }
-  }
-  function getAdjustedLocation(node, forRename) {
-    const { parent: parent2 } = node;
-    if (isModifier(node) && (forRename || node.kind !== 90 /* DefaultKeyword */) ? canHaveModifiers(parent2) && contains(parent2.modifiers, node) : node.kind === 86 /* ClassKeyword */ ? isClassDeclaration(parent2) || isClassExpression(node) : node.kind === 100 /* FunctionKeyword */ ? isFunctionDeclaration(parent2) || isFunctionExpression(node) : node.kind === 120 /* InterfaceKeyword */ ? isInterfaceDeclaration(parent2) : node.kind === 94 /* EnumKeyword */ ? isEnumDeclaration(parent2) : node.kind === 156 /* TypeKeyword */ ? isTypeAliasDeclaration(parent2) : node.kind === 145 /* NamespaceKeyword */ || node.kind === 144 /* ModuleKeyword */ ? isModuleDeclaration(parent2) : node.kind === 102 /* ImportKeyword */ ? isImportEqualsDeclaration(parent2) : node.kind === 139 /* GetKeyword */ ? isGetAccessorDeclaration(parent2) : node.kind === 153 /* SetKeyword */ && isSetAccessorDeclaration(parent2)) {
-      const location = getAdjustedLocationForDeclaration(parent2, forRename);
-      if (location) {
-        return location;
-      }
-    }
-    if ((node.kind === 115 /* VarKeyword */ || node.kind === 87 /* ConstKeyword */ || node.kind === 121 /* LetKeyword */) && isVariableDeclarationList(parent2) && parent2.declarations.length === 1) {
-      const decl = parent2.declarations[0];
-      if (isIdentifier(decl.name)) {
-        return decl.name;
-      }
-    }
-    if (node.kind === 156 /* TypeKeyword */) {
-      if (isImportClause(parent2) && parent2.isTypeOnly) {
-        const location = getAdjustedLocationForImportDeclaration(parent2.parent, forRename);
-        if (location) {
-          return location;
-        }
-      }
-      if (isExportDeclaration(parent2) && parent2.isTypeOnly) {
-        const location = getAdjustedLocationForExportDeclaration(parent2, forRename);
-        if (location) {
-          return location;
-        }
-      }
-    }
-    if (node.kind === 130 /* AsKeyword */) {
-      if (isImportSpecifier(parent2) && parent2.propertyName || isExportSpecifier(parent2) && parent2.propertyName || isNamespaceImport(parent2) || isNamespaceExport(parent2)) {
-        return parent2.name;
-      }
-      if (isExportDeclaration(parent2) && parent2.exportClause && isNamespaceExport(parent2.exportClause)) {
-        return parent2.exportClause.name;
-      }
-    }
-    if (node.kind === 102 /* ImportKeyword */ && isImportDeclaration(parent2)) {
-      const location = getAdjustedLocationForImportDeclaration(parent2, forRename);
-      if (location) {
-        return location;
-      }
-    }
-    if (node.kind === 95 /* ExportKeyword */) {
-      if (isExportDeclaration(parent2)) {
-        const location = getAdjustedLocationForExportDeclaration(parent2, forRename);
-        if (location) {
-          return location;
-        }
-      }
-      if (isExportAssignment(parent2)) {
-        return skipOuterExpressions(parent2.expression);
-      }
-    }
-    if (node.kind === 149 /* RequireKeyword */ && isExternalModuleReference(parent2)) {
-      return parent2.expression;
-    }
-    if (node.kind === 160 /* FromKeyword */ && (isImportDeclaration(parent2) || isExportDeclaration(parent2)) && parent2.moduleSpecifier) {
-      return parent2.moduleSpecifier;
-    }
-    if ((node.kind === 96 /* ExtendsKeyword */ || node.kind === 119 /* ImplementsKeyword */) && isHeritageClause(parent2) && parent2.token === node.kind) {
-      const location = getAdjustedLocationForHeritageClause(parent2);
-      if (location) {
-        return location;
-      }
-    }
-    if (node.kind === 96 /* ExtendsKeyword */) {
-      if (isTypeParameterDeclaration(parent2) && parent2.constraint && isTypeReferenceNode(parent2.constraint)) {
-        return parent2.constraint.typeName;
-      }
-      if (isConditionalTypeNode(parent2) && isTypeReferenceNode(parent2.extendsType)) {
-        return parent2.extendsType.typeName;
-      }
-    }
-    if (node.kind === 140 /* InferKeyword */ && isInferTypeNode(parent2)) {
-      return parent2.typeParameter.name;
-    }
-    if (node.kind === 103 /* InKeyword */ && isTypeParameterDeclaration(parent2) && isMappedTypeNode(parent2.parent)) {
-      return parent2.name;
-    }
-    if (node.kind === 143 /* KeyOfKeyword */ && isTypeOperatorNode(parent2) && parent2.operator === 143 /* KeyOfKeyword */ && isTypeReferenceNode(parent2.type)) {
-      return parent2.type.typeName;
-    }
-    if (node.kind === 148 /* ReadonlyKeyword */ && isTypeOperatorNode(parent2) && parent2.operator === 148 /* ReadonlyKeyword */ && isArrayTypeNode(parent2.type) && isTypeReferenceNode(parent2.type.elementType)) {
-      return parent2.type.elementType.typeName;
-    }
-    if (!forRename) {
-      if (node.kind === 105 /* NewKeyword */ && isNewExpression(parent2) || node.kind === 116 /* VoidKeyword */ && isVoidExpression(parent2) || node.kind === 114 /* TypeOfKeyword */ && isTypeOfExpression(parent2) || node.kind === 135 /* AwaitKeyword */ && isAwaitExpression(parent2) || node.kind === 127 /* YieldKeyword */ && isYieldExpression(parent2) || node.kind === 91 /* DeleteKeyword */ && isDeleteExpression(parent2)) {
-        if (parent2.expression) {
-          return skipOuterExpressions(parent2.expression);
-        }
-      }
-      if ((node.kind === 103 /* InKeyword */ || node.kind === 104 /* InstanceOfKeyword */) && isBinaryExpression(parent2) && parent2.operatorToken === node) {
-        return skipOuterExpressions(parent2.right);
-      }
-      if (node.kind === 130 /* AsKeyword */ && isAsExpression(parent2) && isTypeReferenceNode(parent2.type)) {
-        return parent2.type.typeName;
-      }
-      if (node.kind === 103 /* InKeyword */ && isForInStatement(parent2) || node.kind === 164 /* OfKeyword */ && isForOfStatement(parent2)) {
-        return skipOuterExpressions(parent2.expression);
-      }
-    }
-    return node;
-  }
-  function getAdjustedReferenceLocation(node) {
-    return getAdjustedLocation(
-      node,
-      /*forRename*/
-      false
-    );
-  }
-  function getAdjustedRenameLocation(node) {
-    return getAdjustedLocation(
-      node,
-      /*forRename*/
-      true
-    );
-  }
-  function getTouchingPropertyName(sourceFile, position) {
-    return getTouchingToken(sourceFile, position, (n) => isPropertyNameLiteral(n) || isKeyword(n.kind) || isPrivateIdentifier(n));
-  }
-  function getTouchingToken(sourceFile, position, includePrecedingTokenAtEndPosition) {
-    return getTokenAtPositionWorker(
-      sourceFile,
-      position,
-      /*allowPositionInLeadingTrivia*/
-      false,
-      includePrecedingTokenAtEndPosition,
-      /*includeEndPosition*/
-      false
-    );
-  }
-  function getTokenAtPosition(sourceFile, position) {
-    return getTokenAtPositionWorker(
-      sourceFile,
-      position,
-      /*allowPositionInLeadingTrivia*/
-      true,
-      /*includePrecedingTokenAtEndPosition*/
-      void 0,
-      /*includeEndPosition*/
-      false
-    );
-  }
-  function getTokenAtPositionWorker(sourceFile, position, allowPositionInLeadingTrivia, includePrecedingTokenAtEndPosition, includeEndPosition) {
-    let current = sourceFile;
-    let foundToken;
-    outer:
-      while (true) {
-        const children = current.getChildren(sourceFile);
-        const i = binarySearchKey(children, position, (_, i2) => i2, (middle, _) => {
-          const end = children[middle].getEnd();
-          if (end < position) {
-            return -1 /* LessThan */;
-          }
-          const start = allowPositionInLeadingTrivia ? children[middle].getFullStart() : children[middle].getStart(
-            sourceFile,
-            /*includeJsDocComment*/
-            true
-          );
-          if (start > position) {
-            return 1 /* GreaterThan */;
-          }
-          if (nodeContainsPosition(children[middle], start, end)) {
-            if (children[middle - 1]) {
-              if (nodeContainsPosition(children[middle - 1])) {
-                return 1 /* GreaterThan */;
-              }
-            }
-            return 0 /* EqualTo */;
-          }
-          if (includePrecedingTokenAtEndPosition && start === position && children[middle - 1] && children[middle - 1].getEnd() === position && nodeContainsPosition(children[middle - 1])) {
-            return 1 /* GreaterThan */;
-          }
-          return -1 /* LessThan */;
-        });
-        if (foundToken) {
-          return foundToken;
-        }
-        if (i >= 0 && children[i]) {
-          current = children[i];
-          continue outer;
-        }
-        return current;
-      }
-    function nodeContainsPosition(node, start, end) {
-      end ?? (end = node.getEnd());
-      if (end < position) {
-        return false;
-      }
-      start ?? (start = allowPositionInLeadingTrivia ? node.getFullStart() : node.getStart(
-        sourceFile,
-        /*includeJsDocComment*/
-        true
-      ));
-      if (start > position) {
-        return false;
-      }
-      if (position < end || position === end && (node.kind === 1 /* EndOfFileToken */ || includeEndPosition)) {
-        return true;
-      } else if (includePrecedingTokenAtEndPosition && end === position) {
-        const previousToken = findPrecedingToken(position, sourceFile, node);
-        if (previousToken && includePrecedingTokenAtEndPosition(previousToken)) {
-          foundToken = previousToken;
-          return true;
-        }
-      }
-      return false;
-    }
-  }
-  function findFirstNonJsxWhitespaceToken(sourceFile, position) {
-    let tokenAtPosition = getTokenAtPosition(sourceFile, position);
-    while (isWhiteSpaceOnlyJsxText(tokenAtPosition)) {
-      const nextToken = findNextToken(tokenAtPosition, tokenAtPosition.parent, sourceFile);
-      if (!nextToken)
-        return;
-      tokenAtPosition = nextToken;
-    }
-    return tokenAtPosition;
-  }
-  function findTokenOnLeftOfPosition(file, position) {
-    const tokenAtPosition = getTokenAtPosition(file, position);
-    if (isToken(tokenAtPosition) && position > tokenAtPosition.getStart(file) && position < tokenAtPosition.getEnd()) {
-      return tokenAtPosition;
-    }
-    return findPrecedingToken(position, file);
-  }
-  function findNextToken(previousToken, parent2, sourceFile) {
-    return find2(parent2);
-    function find2(n) {
-      if (isToken(n) && n.pos === previousToken.end) {
-        return n;
-      }
-      return firstDefined(n.getChildren(sourceFile), (child) => {
-        const shouldDiveInChildNode = (
-          // previous token is enclosed somewhere in the child
-          child.pos <= previousToken.pos && child.end > previousToken.end || // previous token ends exactly at the beginning of child
-          child.pos === previousToken.end
-        );
-        return shouldDiveInChildNode && nodeHasTokens(child, sourceFile) ? find2(child) : void 0;
-      });
-    }
-  }
-  function findPrecedingToken(position, sourceFile, startNode2, excludeJsdoc) {
-    const result = find2(startNode2 || sourceFile);
-    Debug.assert(!(result && isWhiteSpaceOnlyJsxText(result)));
-    return result;
-    function find2(n) {
-      if (isNonWhitespaceToken(n) && n.kind !== 1 /* EndOfFileToken */) {
-        return n;
-      }
-      const children = n.getChildren(sourceFile);
-      const i = binarySearchKey(children, position, (_, i2) => i2, (middle, _) => {
-        if (position < children[middle].end) {
-          if (!children[middle - 1] || position >= children[middle - 1].end) {
-            return 0 /* EqualTo */;
-          }
-          return 1 /* GreaterThan */;
-        }
-        return -1 /* LessThan */;
-      });
-      if (i >= 0 && children[i]) {
-        const child = children[i];
-        if (position < child.end) {
-          const start = child.getStart(
-            sourceFile,
-            /*includeJsDoc*/
-            !excludeJsdoc
-          );
-          const lookInPreviousChild = start >= position || // cursor in the leading trivia
-          !nodeHasTokens(child, sourceFile) || isWhiteSpaceOnlyJsxText(child);
-          if (lookInPreviousChild) {
-            const candidate2 = findRightmostChildNodeWithTokens(
-              children,
-              /*exclusiveStartPosition*/
-              i,
-              sourceFile,
-              n.kind
-            );
-            if (candidate2) {
-              if (!excludeJsdoc && isJSDocCommentContainingNode(candidate2) && candidate2.getChildren(sourceFile).length) {
-                return find2(candidate2);
-              }
-              return findRightmostToken(candidate2, sourceFile);
-            }
-            return void 0;
-          } else {
-            return find2(child);
-          }
-        }
-      }
-      Debug.assert(startNode2 !== void 0 || n.kind === 311 /* SourceFile */ || n.kind === 1 /* EndOfFileToken */ || isJSDocCommentContainingNode(n));
-      const candidate = findRightmostChildNodeWithTokens(
-        children,
-        /*exclusiveStartPosition*/
-        children.length,
-        sourceFile,
-        n.kind
-      );
-      return candidate && findRightmostToken(candidate, sourceFile);
-    }
-  }
-  function isNonWhitespaceToken(n) {
-    return isToken(n) && !isWhiteSpaceOnlyJsxText(n);
-  }
-  function findRightmostToken(n, sourceFile) {
-    if (isNonWhitespaceToken(n)) {
-      return n;
-    }
-    const children = n.getChildren(sourceFile);
-    if (children.length === 0) {
-      return n;
-    }
-    const candidate = findRightmostChildNodeWithTokens(
-      children,
-      /*exclusiveStartPosition*/
-      children.length,
-      sourceFile,
-      n.kind
-    );
-    return candidate && findRightmostToken(candidate, sourceFile);
-  }
-  function findRightmostChildNodeWithTokens(children, exclusiveStartPosition, sourceFile, parentKind) {
-    for (let i = exclusiveStartPosition - 1; i >= 0; i--) {
-      const child = children[i];
-      if (isWhiteSpaceOnlyJsxText(child)) {
-        if (i === 0 && (parentKind === 12 /* JsxText */ || parentKind === 284 /* JsxSelfClosingElement */)) {
-          Debug.fail("`JsxText` tokens should not be the first child of `JsxElement | JsxSelfClosingElement`");
-        }
-      } else if (nodeHasTokens(children[i], sourceFile)) {
-        return children[i];
-      }
-    }
-  }
-  function isInString(sourceFile, position, previousToken = findPrecedingToken(position, sourceFile)) {
-    if (previousToken && isStringTextContainingNode(previousToken)) {
-      const start = previousToken.getStart(sourceFile);
-      const end = previousToken.getEnd();
-      if (start < position && position < end) {
-        return true;
-      }
-      if (position === end) {
-        return !!previousToken.isUnterminated;
-      }
-    }
-    return false;
-  }
-  function isInsideJsxElementOrAttribute(sourceFile, position) {
-    const token = getTokenAtPosition(sourceFile, position);
-    if (!token) {
-      return false;
-    }
-    if (token.kind === 12 /* JsxText */) {
-      return true;
-    }
-    if (token.kind === 30 /* LessThanToken */ && token.parent.kind === 12 /* JsxText */) {
-      return true;
-    }
-    if (token.kind === 30 /* LessThanToken */ && token.parent.kind === 293 /* JsxExpression */) {
-      return true;
-    }
-    if (token && token.kind === 20 /* CloseBraceToken */ && token.parent.kind === 293 /* JsxExpression */) {
-      return true;
-    }
-    if (token.kind === 30 /* LessThanToken */ && token.parent.kind === 286 /* JsxClosingElement */) {
-      return true;
-    }
-    return false;
-  }
-  function isWhiteSpaceOnlyJsxText(node) {
-    return isJsxText(node) && node.containsOnlyTriviaWhiteSpaces;
-  }
-  function isInTemplateString(sourceFile, position) {
-    const token = getTokenAtPosition(sourceFile, position);
-    return isTemplateLiteralKind(token.kind) && position > token.getStart(sourceFile);
-  }
-  function isInJSXText(sourceFile, position) {
-    const token = getTokenAtPosition(sourceFile, position);
-    if (isJsxText(token)) {
-      return true;
-    }
-    if (token.kind === 19 /* OpenBraceToken */ && isJsxExpression(token.parent) && isJsxElement(token.parent.parent)) {
-      return true;
-    }
-    if (token.kind === 30 /* LessThanToken */ && isJsxOpeningLikeElement(token.parent) && isJsxElement(token.parent.parent)) {
-      return true;
-    }
-    return false;
-  }
-  function isInsideJsxElement(sourceFile, position) {
-    function isInsideJsxElementTraversal(node) {
-      while (node) {
-        if (node.kind >= 284 /* JsxSelfClosingElement */ && node.kind <= 293 /* JsxExpression */ || node.kind === 12 /* JsxText */ || node.kind === 30 /* LessThanToken */ || node.kind === 32 /* GreaterThanToken */ || node.kind === 80 /* Identifier */ || node.kind === 20 /* CloseBraceToken */ || node.kind === 19 /* OpenBraceToken */ || node.kind === 44 /* SlashToken */) {
-          node = node.parent;
-        } else if (node.kind === 283 /* JsxElement */) {
-          if (position > node.getStart(sourceFile))
-            return true;
-          node = node.parent;
-        } else {
-          return false;
-        }
-      }
-      return false;
-    }
-    return isInsideJsxElementTraversal(getTokenAtPosition(sourceFile, position));
-  }
-  function findPrecedingMatchingToken(token, matchingTokenKind, sourceFile) {
-    const closeTokenText = tokenToString(token.kind);
-    const matchingTokenText = tokenToString(matchingTokenKind);
-    const tokenFullStart = token.getFullStart();
-    const bestGuessIndex = sourceFile.text.lastIndexOf(matchingTokenText, tokenFullStart);
-    if (bestGuessIndex === -1) {
-      return void 0;
-    }
-    if (sourceFile.text.lastIndexOf(closeTokenText, tokenFullStart - 1) < bestGuessIndex) {
-      const nodeAtGuess = findPrecedingToken(bestGuessIndex + 1, sourceFile);
-      if (nodeAtGuess && nodeAtGuess.kind === matchingTokenKind) {
-        return nodeAtGuess;
-      }
-    }
-    const tokenKind = token.kind;
-    let remainingMatchingTokens = 0;
-    while (true) {
-      const preceding = findPrecedingToken(token.getFullStart(), sourceFile);
-      if (!preceding) {
-        return void 0;
-      }
-      token = preceding;
-      if (token.kind === matchingTokenKind) {
-        if (remainingMatchingTokens === 0) {
-          return token;
-        }
-        remainingMatchingTokens--;
-      } else if (token.kind === tokenKind) {
-        remainingMatchingTokens++;
-      }
-    }
-  }
-  function removeOptionality(type, isOptionalExpression, isOptionalChain2) {
-    return isOptionalExpression ? type.getNonNullableType() : isOptionalChain2 ? type.getNonOptionalType() : type;
-  }
-  function isPossiblyTypeArgumentPosition(token, sourceFile, checker) {
-    const info = getPossibleTypeArgumentsInfo(token, sourceFile);
-    return info !== void 0 && (isPartOfTypeNode(info.called) || getPossibleGenericSignatures(info.called, info.nTypeArguments, checker).length !== 0 || isPossiblyTypeArgumentPosition(info.called, sourceFile, checker));
-  }
-  function getPossibleGenericSignatures(called, typeArgumentCount, checker) {
-    let type = checker.getTypeAtLocation(called);
-    if (isOptionalChain(called.parent)) {
-      type = removeOptionality(
-        type,
-        isOptionalChainRoot(called.parent),
-        /*isOptionalChain*/
-        true
-      );
-    }
-    const signatures = isNewExpression(called.parent) ? type.getConstructSignatures() : type.getCallSignatures();
-    return signatures.filter((candidate) => !!candidate.typeParameters && candidate.typeParameters.length >= typeArgumentCount);
-  }
-  function getPossibleTypeArgumentsInfo(tokenIn, sourceFile) {
-    if (sourceFile.text.lastIndexOf("<", tokenIn ? tokenIn.pos : sourceFile.text.length) === -1) {
-      return void 0;
-    }
-    let token = tokenIn;
-    let remainingLessThanTokens = 0;
-    let nTypeArguments = 0;
-    while (token) {
-      switch (token.kind) {
-        case 30 /* LessThanToken */:
-          token = findPrecedingToken(token.getFullStart(), sourceFile);
-          if (token && token.kind === 29 /* QuestionDotToken */) {
-            token = findPrecedingToken(token.getFullStart(), sourceFile);
-          }
-          if (!token || !isIdentifier(token))
-            return void 0;
-          if (!remainingLessThanTokens) {
-            return isDeclarationName(token) ? void 0 : { called: token, nTypeArguments };
-          }
-          remainingLessThanTokens--;
-          break;
-        case 50 /* GreaterThanGreaterThanGreaterThanToken */:
-          remainingLessThanTokens = 3;
-          break;
-        case 49 /* GreaterThanGreaterThanToken */:
-          remainingLessThanTokens = 2;
-          break;
-        case 32 /* GreaterThanToken */:
-          remainingLessThanTokens++;
-          break;
-        case 20 /* CloseBraceToken */:
-          token = findPrecedingMatchingToken(token, 19 /* OpenBraceToken */, sourceFile);
-          if (!token)
-            return void 0;
-          break;
-        case 22 /* CloseParenToken */:
-          token = findPrecedingMatchingToken(token, 21 /* OpenParenToken */, sourceFile);
-          if (!token)
-            return void 0;
-          break;
-        case 24 /* CloseBracketToken */:
-          token = findPrecedingMatchingToken(token, 23 /* OpenBracketToken */, sourceFile);
-          if (!token)
-            return void 0;
-          break;
-        case 28 /* CommaToken */:
-          nTypeArguments++;
-          break;
-        case 39 /* EqualsGreaterThanToken */:
-        case 80 /* Identifier */:
-        case 11 /* StringLiteral */:
-        case 9 /* NumericLiteral */:
-        case 10 /* BigIntLiteral */:
-        case 112 /* TrueKeyword */:
-        case 97 /* FalseKeyword */:
-        case 114 /* TypeOfKeyword */:
-        case 96 /* ExtendsKeyword */:
-        case 143 /* KeyOfKeyword */:
-        case 25 /* DotToken */:
-        case 52 /* BarToken */:
-        case 58 /* QuestionToken */:
-        case 59 /* ColonToken */:
-          break;
-        default:
-          if (isTypeNode(token)) {
-            break;
-          }
-          return void 0;
-      }
-      token = findPrecedingToken(token.getFullStart(), sourceFile);
-    }
-    return void 0;
-  }
-  function isInComment(sourceFile, position, tokenAtPosition) {
-    return ts_formatting_exports.getRangeOfEnclosingComment(
-      sourceFile,
-      position,
-      /*precedingToken*/
-      void 0,
-      tokenAtPosition
-    );
-  }
-  function hasDocComment(sourceFile, position) {
-    const token = getTokenAtPosition(sourceFile, position);
-    return !!findAncestor(token, isJSDoc);
-  }
-  function nodeHasTokens(n, sourceFile) {
-    return n.kind === 1 /* EndOfFileToken */ ? !!n.jsDoc : n.getWidth(sourceFile) !== 0;
-  }
-  function getNodeModifiers(node, excludeFlags = 0 /* None */) {
-    const result = [];
-    const flags = isDeclaration(node) ? getCombinedNodeFlagsAlwaysIncludeJSDoc(node) & ~excludeFlags : 0 /* None */;
-    if (flags & 8 /* Private */)
-      result.push("private" /* privateMemberModifier */);
-    if (flags & 16 /* Protected */)
-      result.push("protected" /* protectedMemberModifier */);
-    if (flags & 4 /* Public */)
-      result.push("public" /* publicMemberModifier */);
-    if (flags & 32 /* Static */ || isClassStaticBlockDeclaration(node))
-      result.push("static" /* staticModifier */);
-    if (flags & 256 /* Abstract */)
-      result.push("abstract" /* abstractModifier */);
-    if (flags & 1 /* Export */)
-      result.push("export" /* exportedModifier */);
-    if (flags & 8192 /* Deprecated */)
-      result.push("deprecated" /* deprecatedModifier */);
-    if (node.flags & 16777216 /* Ambient */)
-      result.push("declare" /* ambientModifier */);
-    if (node.kind === 276 /* ExportAssignment */)
-      result.push("export" /* exportedModifier */);
-    return result.length > 0 ? result.join(",") : "" /* none */;
-  }
-  function getTypeArgumentOrTypeParameterList(node) {
-    if (node.kind === 182 /* TypeReference */ || node.kind === 212 /* CallExpression */) {
-      return node.typeArguments;
-    }
-    if (isFunctionLike(node) || node.kind === 262 /* ClassDeclaration */ || node.kind === 263 /* InterfaceDeclaration */) {
-      return node.typeParameters;
-    }
-    return void 0;
-  }
-  function isComment(kind) {
-    return kind === 2 /* SingleLineCommentTrivia */ || kind === 3 /* MultiLineCommentTrivia */;
-  }
-  function isStringOrRegularExpressionOrTemplateLiteral(kind) {
-    if (kind === 11 /* StringLiteral */ || kind === 14 /* RegularExpressionLiteral */ || isTemplateLiteralKind(kind)) {
-      return true;
-    }
-    return false;
-  }
-  function areIntersectedTypesAvoidingStringReduction(checker, t1, t2) {
-    return !!(t1.flags & 4 /* String */) && checker.isEmptyAnonymousObjectType(t2);
-  }
-  function isStringAndEmptyAnonymousObjectIntersection(type) {
-    if (!type.isIntersection()) {
-      return false;
-    }
-    const { types, checker } = type;
-    return types.length === 2 && (areIntersectedTypesAvoidingStringReduction(checker, types[0], types[1]) || areIntersectedTypesAvoidingStringReduction(checker, types[1], types[0]));
-  }
-  function isInsideTemplateLiteral(node, position, sourceFile) {
-    return isTemplateLiteralKind(node.kind) && (node.getStart(sourceFile) < position && position < node.end) || !!node.isUnterminated && position === node.end;
-  }
-  function isAccessibilityModifier(kind) {
-    switch (kind) {
-      case 125 /* PublicKeyword */:
-      case 123 /* PrivateKeyword */:
-      case 124 /* ProtectedKeyword */:
-        return true;
-    }
-    return false;
-  }
-  function cloneCompilerOptions(options) {
-    const result = clone(options);
-    setConfigFileInOptions(result, options && options.configFile);
-    return result;
-  }
-  function isArrayLiteralOrObjectLiteralDestructuringPattern(node) {
-    if (node.kind === 208 /* ArrayLiteralExpression */ || node.kind === 209 /* ObjectLiteralExpression */) {
-      if (node.parent.kind === 225 /* BinaryExpression */ && node.parent.left === node && node.parent.operatorToken.kind === 64 /* EqualsToken */) {
-        return true;
-      }
-      if (node.parent.kind === 249 /* ForOfStatement */ && node.parent.initializer === node) {
-        return true;
-      }
-      if (isArrayLiteralOrObjectLiteralDestructuringPattern(node.parent.kind === 302 /* PropertyAssignment */ ? node.parent.parent : node.parent)) {
-        return true;
-      }
-    }
-    return false;
-  }
-  function isInReferenceComment(sourceFile, position) {
-    return isInReferenceCommentWorker(
-      sourceFile,
-      position,
-      /*shouldBeReference*/
-      true
-    );
-  }
-  function isInNonReferenceComment(sourceFile, position) {
-    return isInReferenceCommentWorker(
-      sourceFile,
-      position,
-      /*shouldBeReference*/
-      false
-    );
-  }
-  function isInReferenceCommentWorker(sourceFile, position, shouldBeReference) {
-    const range = isInComment(
-      sourceFile,
-      position,
-      /*tokenAtPosition*/
-      void 0
-    );
-    return !!range && shouldBeReference === tripleSlashDirectivePrefixRegex.test(sourceFile.text.substring(range.pos, range.end));
-  }
-  function getReplacementSpanForContextToken(contextToken) {
-    if (!contextToken)
-      return void 0;
-    switch (contextToken.kind) {
-      case 11 /* StringLiteral */:
-      case 15 /* NoSubstitutionTemplateLiteral */:
-        return createTextSpanFromStringLiteralLikeContent(contextToken);
-      default:
-        return createTextSpanFromNode(contextToken);
-    }
-  }
-  function createTextSpanFromNode(node, sourceFile, endNode2) {
-    return createTextSpanFromBounds(node.getStart(sourceFile), (endNode2 || node).getEnd());
-  }
-  function createTextSpanFromStringLiteralLikeContent(node) {
-    if (node.isUnterminated)
-      return void 0;
-    return createTextSpanFromBounds(node.getStart() + 1, node.getEnd() - 1);
-  }
-  function createTextRangeFromNode(node, sourceFile) {
-    return createRange(node.getStart(sourceFile), node.end);
-  }
-  function createTextSpanFromRange(range) {
-    return createTextSpanFromBounds(range.pos, range.end);
-  }
-  function createTextRangeFromSpan(span) {
-    return createRange(span.start, span.start + span.length);
-  }
-  function createTextChangeFromStartLength(start, length2, newText) {
-    return createTextChange(createTextSpan(start, length2), newText);
-  }
-  function createTextChange(span, newText) {
-    return { span, newText };
-  }
-  function isTypeKeyword(kind) {
-    return contains(typeKeywords, kind);
-  }
-  function isTypeKeywordToken(node) {
-    return node.kind === 156 /* TypeKeyword */;
-  }
-  function isTypeKeywordTokenOrIdentifier(node) {
-    return isTypeKeywordToken(node) || isIdentifier(node) && node.text === "type";
-  }
-  function isExternalModuleSymbol(moduleSymbol) {
-    return !!(moduleSymbol.flags & 1536 /* Module */) && moduleSymbol.name.charCodeAt(0) === 34 /* doubleQuote */;
-  }
-  function nodeSeenTracker() {
-    const seen = [];
-    return (node) => {
-      const id = getNodeId(node);
-      return !seen[id] && (seen[id] = true);
-    };
-  }
-  function getSnapshotText(snap) {
-    return snap.getText(0, snap.getLength());
-  }
-  function repeatString(str, count) {
-    let result = "";
-    for (let i = 0; i < count; i++) {
-      result += str;
-    }
-    return result;
-  }
-  function skipConstraint(type) {
-    return type.isTypeParameter() ? type.getConstraint() || type : type;
-  }
-  function getNameFromPropertyName(name) {
-    return name.kind === 166 /* ComputedPropertyName */ ? isStringOrNumericLiteralLike(name.expression) ? name.expression.text : void 0 : isPrivateIdentifier(name) ? idText(name) : getTextOfIdentifierOrLiteral(name);
-  }
-  function programContainsModules(program) {
-    return program.getSourceFiles().some((s) => !s.isDeclarationFile && !program.isSourceFileFromExternalLibrary(s) && !!(s.externalModuleIndicator || s.commonJsModuleIndicator));
-  }
-  function programContainsEsModules(program) {
-    return program.getSourceFiles().some((s) => !s.isDeclarationFile && !program.isSourceFileFromExternalLibrary(s) && !!s.externalModuleIndicator);
-  }
-  function compilerOptionsIndicateEsModules(compilerOptions) {
-    return !!compilerOptions.module || getEmitScriptTarget(compilerOptions) >= 2 /* ES2015 */ || !!compilerOptions.noEmit;
-  }
-  function createModuleSpecifierResolutionHost(program, host) {
-    return {
-      fileExists: (fileName) => program.fileExists(fileName),
-      getCurrentDirectory: () => host.getCurrentDirectory(),
-      readFile: maybeBind(host, host.readFile),
-      useCaseSensitiveFileNames: maybeBind(host, host.useCaseSensitiveFileNames),
-      getSymlinkCache: maybeBind(host, host.getSymlinkCache) || program.getSymlinkCache,
-      getModuleSpecifierCache: maybeBind(host, host.getModuleSpecifierCache),
-      getPackageJsonInfoCache: () => {
-        var _a;
-        return (_a = program.getModuleResolutionCache()) == null ? void 0 : _a.getPackageJsonInfoCache();
-      },
-      getGlobalTypingsCacheLocation: maybeBind(host, host.getGlobalTypingsCacheLocation),
-      redirectTargetsMap: program.redirectTargetsMap,
-      getProjectReferenceRedirect: (fileName) => program.getProjectReferenceRedirect(fileName),
-      isSourceOfProjectReferenceRedirect: (fileName) => program.isSourceOfProjectReferenceRedirect(fileName),
-      getNearestAncestorDirectoryWithPackageJson: maybeBind(host, host.getNearestAncestorDirectoryWithPackageJson),
-      getFileIncludeReasons: () => program.getFileIncludeReasons()
-    };
-  }
-  function getModuleSpecifierResolverHost(program, host) {
-    return {
-      ...createModuleSpecifierResolutionHost(program, host),
-      getCommonSourceDirectory: () => program.getCommonSourceDirectory()
-    };
-  }
-  function moduleResolutionUsesNodeModules(moduleResolution) {
-    return moduleResolution === 2 /* Node10 */ || moduleResolution >= 3 /* Node16 */ && moduleResolution <= 99 /* NodeNext */ || moduleResolution === 100 /* Bundler */;
-  }
-  function makeImportIfNecessary(defaultImport, namedImports, moduleSpecifier, quotePreference) {
-    return defaultImport || namedImports && namedImports.length ? makeImport(defaultImport, namedImports, moduleSpecifier, quotePreference) : void 0;
-  }
-  function makeImport(defaultImport, namedImports, moduleSpecifier, quotePreference, isTypeOnly) {
-    return factory.createImportDeclaration(
-      /*modifiers*/
-      void 0,
-      defaultImport || namedImports ? factory.createImportClause(!!isTypeOnly, defaultImport, namedImports && namedImports.length ? factory.createNamedImports(namedImports) : void 0) : void 0,
-      typeof moduleSpecifier === "string" ? makeStringLiteral(moduleSpecifier, quotePreference) : moduleSpecifier,
-      /*assertClause*/
-      void 0
-    );
-  }
-  function makeStringLiteral(text, quotePreference) {
-    return factory.createStringLiteral(text, quotePreference === 0 /* Single */);
-  }
-  function quotePreferenceFromString(str, sourceFile) {
-    return isStringDoubleQuoted(str, sourceFile) ? 1 /* Double */ : 0 /* Single */;
-  }
-  function getQuotePreference(sourceFile, preferences) {
-    if (preferences.quotePreference && preferences.quotePreference !== "auto") {
-      return preferences.quotePreference === "single" ? 0 /* Single */ : 1 /* Double */;
-    } else {
-      const firstModuleSpecifier = sourceFile.imports && find(sourceFile.imports, (n) => isStringLiteral(n) && !nodeIsSynthesized(n.parent));
-      return firstModuleSpecifier ? quotePreferenceFromString(firstModuleSpecifier, sourceFile) : 1 /* Double */;
-    }
-  }
-  function getQuoteFromPreference(qp) {
-    switch (qp) {
-      case 0 /* Single */:
-        return "'";
-      case 1 /* Double */:
-        return '"';
-      default:
-        return Debug.assertNever(qp);
-    }
-  }
-  function symbolNameNoDefault(symbol) {
-    const escaped = symbolEscapedNameNoDefault(symbol);
-    return escaped === void 0 ? void 0 : unescapeLeadingUnderscores(escaped);
-  }
-  function symbolEscapedNameNoDefault(symbol) {
-    if (symbol.escapedName !== "default" /* Default */) {
-      return symbol.escapedName;
-    }
-    return firstDefined(symbol.declarations, (decl) => {
-      const name = getNameOfDeclaration(decl);
-      return name && name.kind === 80 /* Identifier */ ? name.escapedText : void 0;
-    });
-  }
-  function isModuleSpecifierLike(node) {
-    return isStringLiteralLike(node) && (isExternalModuleReference(node.parent) || isImportDeclaration(node.parent) || isRequireCall(
-      node.parent,
-      /*requireStringLiteralLikeArgument*/
-      false
-    ) && node.parent.arguments[0] === node || isImportCall(node.parent) && node.parent.arguments[0] === node);
-  }
-  function isObjectBindingElementWithoutPropertyName(bindingElement) {
-    return isBindingElement(bindingElement) && isObjectBindingPattern(bindingElement.parent) && isIdentifier(bindingElement.name) && !bindingElement.propertyName;
-  }
-  function getPropertySymbolFromBindingElement(checker, bindingElement) {
-    const typeOfPattern = checker.getTypeAtLocation(bindingElement.parent);
-    return typeOfPattern && checker.getPropertyOfType(typeOfPattern, bindingElement.name.text);
-  }
-  function getParentNodeInSpan(node, file, span) {
-    if (!node)
-      return void 0;
-    while (node.parent) {
-      if (isSourceFile(node.parent) || !spanContainsNode(span, node.parent, file)) {
-        return node;
-      }
-      node = node.parent;
-    }
-  }
-  function spanContainsNode(span, node, file) {
-    return textSpanContainsPosition(span, node.getStart(file)) && node.getEnd() <= textSpanEnd(span);
-  }
-  function findModifier(node, kind) {
-    return canHaveModifiers(node) ? find(node.modifiers, (m) => m.kind === kind) : void 0;
-  }
-  function insertImports(changes, sourceFile, imports, blankLineBetween, preferences) {
-    const decl = isArray(imports) ? imports[0] : imports;
-    const importKindPredicate = decl.kind === 242 /* VariableStatement */ ? isRequireVariableStatement : isAnyImportSyntax;
-    const existingImportStatements = filter(sourceFile.statements, importKindPredicate);
-    let sortKind = isArray(imports) ? ts_OrganizeImports_exports.detectImportDeclarationSorting(imports, preferences) : 3 /* Both */;
-    const comparer = ts_OrganizeImports_exports.getOrganizeImportsComparer(preferences, sortKind === 2 /* CaseInsensitive */);
-    const sortedNewImports = isArray(imports) ? stableSort(imports, (a, b) => ts_OrganizeImports_exports.compareImportsOrRequireStatements(a, b, comparer)) : [imports];
-    if (!existingImportStatements.length) {
-      changes.insertNodesAtTopOfFile(sourceFile, sortedNewImports, blankLineBetween);
-    } else if (existingImportStatements && (sortKind = ts_OrganizeImports_exports.detectImportDeclarationSorting(existingImportStatements, preferences))) {
-      const comparer2 = ts_OrganizeImports_exports.getOrganizeImportsComparer(preferences, sortKind === 2 /* CaseInsensitive */);
-      for (const newImport of sortedNewImports) {
-        const insertionIndex = ts_OrganizeImports_exports.getImportDeclarationInsertionIndex(existingImportStatements, newImport, comparer2);
-        if (insertionIndex === 0) {
-          const options = existingImportStatements[0] === sourceFile.statements[0] ? { leadingTriviaOption: ts_textChanges_exports.LeadingTriviaOption.Exclude } : {};
-          changes.insertNodeBefore(
-            sourceFile,
-            existingImportStatements[0],
-            newImport,
-            /*blankLineBetween*/
-            false,
-            options
-          );
-        } else {
-          const prevImport = existingImportStatements[insertionIndex - 1];
-          changes.insertNodeAfter(sourceFile, prevImport, newImport);
-        }
-      }
-    } else {
-      const lastExistingImport = lastOrUndefined(existingImportStatements);
-      if (lastExistingImport) {
-        changes.insertNodesAfter(sourceFile, lastExistingImport, sortedNewImports);
-      } else {
-        changes.insertNodesAtTopOfFile(sourceFile, sortedNewImports, blankLineBetween);
-      }
-    }
-  }
-  function getTypeKeywordOfTypeOnlyImport(importClause, sourceFile) {
-    Debug.assert(importClause.isTypeOnly);
-    return cast(importClause.getChildAt(0, sourceFile), isTypeKeywordToken);
-  }
-  function textSpansEqual(a, b) {
-    return !!a && !!b && a.start === b.start && a.length === b.length;
-  }
-  function documentSpansEqual(a, b) {
-    return a.fileName === b.fileName && textSpansEqual(a.textSpan, b.textSpan);
-  }
-  function forEachUnique(array, callback) {
-    if (array) {
-      for (let i = 0; i < array.length; i++) {
-        if (array.indexOf(array[i]) === i) {
-          const result = callback(array[i], i);
-          if (result) {
-            return result;
-          }
-        }
-      }
-    }
-    return void 0;
-  }
-  function isTextWhiteSpaceLike(text, startPos, endPos) {
-    for (let i = startPos; i < endPos; i++) {
-      if (!isWhiteSpaceLike(text.charCodeAt(i))) {
-        return false;
-      }
-    }
-    return true;
-  }
-  function getMappedLocation(location, sourceMapper, fileExists) {
-    const mapsTo = sourceMapper.tryGetSourcePosition(location);
-    return mapsTo && (!fileExists || fileExists(normalizePath(mapsTo.fileName)) ? mapsTo : void 0);
-  }
-  function getMappedDocumentSpan(documentSpan, sourceMapper, fileExists) {
-    const { fileName, textSpan } = documentSpan;
-    const newPosition = getMappedLocation({ fileName, pos: textSpan.start }, sourceMapper, fileExists);
-    if (!newPosition)
-      return void 0;
-    const newEndPosition = getMappedLocation({ fileName, pos: textSpan.start + textSpan.length }, sourceMapper, fileExists);
-    const newLength = newEndPosition ? newEndPosition.pos - newPosition.pos : textSpan.length;
-    return {
-      fileName: newPosition.fileName,
-      textSpan: {
-        start: newPosition.pos,
-        length: newLength
-      },
-      originalFileName: documentSpan.fileName,
-      originalTextSpan: documentSpan.textSpan,
-      contextSpan: getMappedContextSpan(documentSpan, sourceMapper, fileExists),
-      originalContextSpan: documentSpan.contextSpan
-    };
-  }
-  function getMappedContextSpan(documentSpan, sourceMapper, fileExists) {
-    const contextSpanStart = documentSpan.contextSpan && getMappedLocation(
-      { fileName: documentSpan.fileName, pos: documentSpan.contextSpan.start },
-      sourceMapper,
-      fileExists
-    );
-    const contextSpanEnd = documentSpan.contextSpan && getMappedLocation(
-      { fileName: documentSpan.fileName, pos: documentSpan.contextSpan.start + documentSpan.contextSpan.length },
-      sourceMapper,
-      fileExists
-    );
-    return contextSpanStart && contextSpanEnd ? { start: contextSpanStart.pos, length: contextSpanEnd.pos - contextSpanStart.pos } : void 0;
-  }
-  function isFirstDeclarationOfSymbolParameter(symbol) {
-    const declaration = symbol.declarations ? firstOrUndefined(symbol.declarations) : void 0;
-    return !!findAncestor(declaration, (n) => isParameter(n) ? true : isBindingElement(n) || isObjectBindingPattern(n) || isArrayBindingPattern(n) ? false : "quit");
-  }
-  function getDisplayPartWriter() {
-    const absoluteMaximumLength = defaultMaximumTruncationLength * 10;
-    let displayParts;
-    let lineStart;
-    let indent2;
-    let length2;
-    resetWriter();
-    const unknownWrite = (text) => writeKind(text, 17 /* text */);
-    return {
-      displayParts: () => {
-        const finalText = displayParts.length && displayParts[displayParts.length - 1].text;
-        if (length2 > absoluteMaximumLength && finalText && finalText !== "...") {
-          if (!isWhiteSpaceLike(finalText.charCodeAt(finalText.length - 1))) {
-            displayParts.push(displayPart(" ", 16 /* space */));
-          }
-          displayParts.push(displayPart("...", 15 /* punctuation */));
-        }
-        return displayParts;
-      },
-      writeKeyword: (text) => writeKind(text, 5 /* keyword */),
-      writeOperator: (text) => writeKind(text, 12 /* operator */),
-      writePunctuation: (text) => writeKind(text, 15 /* punctuation */),
-      writeTrailingSemicolon: (text) => writeKind(text, 15 /* punctuation */),
-      writeSpace: (text) => writeKind(text, 16 /* space */),
-      writeStringLiteral: (text) => writeKind(text, 8 /* stringLiteral */),
-      writeParameter: (text) => writeKind(text, 13 /* parameterName */),
-      writeProperty: (text) => writeKind(text, 14 /* propertyName */),
-      writeLiteral: (text) => writeKind(text, 8 /* stringLiteral */),
-      writeSymbol,
-      writeLine,
-      write: unknownWrite,
-      writeComment: unknownWrite,
-      getText: () => "",
-      getTextPos: () => 0,
-      getColumn: () => 0,
-      getLine: () => 0,
-      isAtStartOfLine: () => false,
-      hasTrailingWhitespace: () => false,
-      hasTrailingComment: () => false,
-      rawWrite: notImplemented,
-      getIndent: () => indent2,
-      increaseIndent: () => {
-        indent2++;
-      },
-      decreaseIndent: () => {
-        indent2--;
-      },
-      clear: resetWriter
-    };
-    function writeIndent() {
-      if (length2 > absoluteMaximumLength)
-        return;
-      if (lineStart) {
-        const indentString = getIndentString(indent2);
-        if (indentString) {
-          length2 += indentString.length;
-          displayParts.push(displayPart(indentString, 16 /* space */));
-        }
-        lineStart = false;
-      }
-    }
-    function writeKind(text, kind) {
-      if (length2 > absoluteMaximumLength)
-        return;
-      writeIndent();
-      length2 += text.length;
-      displayParts.push(displayPart(text, kind));
-    }
-    function writeSymbol(text, symbol) {
-      if (length2 > absoluteMaximumLength)
-        return;
-      writeIndent();
-      length2 += text.length;
-      displayParts.push(symbolPart(text, symbol));
-    }
-    function writeLine() {
-      if (length2 > absoluteMaximumLength)
-        return;
-      length2 += 1;
-      displayParts.push(lineBreakPart());
-      lineStart = true;
-    }
-    function resetWriter() {
-      displayParts = [];
-      lineStart = true;
-      indent2 = 0;
-      length2 = 0;
-    }
-  }
-  function symbolPart(text, symbol) {
-    return displayPart(text, displayPartKind(symbol));
-    function displayPartKind(symbol2) {
-      const flags = symbol2.flags;
-      if (flags & 3 /* Variable */) {
-        return isFirstDeclarationOfSymbolParameter(symbol2) ? 13 /* parameterName */ : 9 /* localName */;
-      }
-      if (flags & 4 /* Property */)
-        return 14 /* propertyName */;
-      if (flags & 32768 /* GetAccessor */)
-        return 14 /* propertyName */;
-      if (flags & 65536 /* SetAccessor */)
-        return 14 /* propertyName */;
-      if (flags & 8 /* EnumMember */)
-        return 19 /* enumMemberName */;
-      if (flags & 16 /* Function */)
-        return 20 /* functionName */;
-      if (flags & 32 /* Class */)
-        return 1 /* className */;
-      if (flags & 64 /* Interface */)
-        return 4 /* interfaceName */;
-      if (flags & 384 /* Enum */)
-        return 2 /* enumName */;
-      if (flags & 1536 /* Module */)
-        return 11 /* moduleName */;
-      if (flags & 8192 /* Method */)
-        return 10 /* methodName */;
-      if (flags & 262144 /* TypeParameter */)
-        return 18 /* typeParameterName */;
-      if (flags & 524288 /* TypeAlias */)
-        return 0 /* aliasName */;
-      if (flags & 2097152 /* Alias */)
-        return 0 /* aliasName */;
-      return 17 /* text */;
-    }
-  }
-  function displayPart(text, kind) {
-    return { text, kind: SymbolDisplayPartKind[kind] };
-  }
-  function spacePart() {
-    return displayPart(" ", 16 /* space */);
-  }
-  function keywordPart(kind) {
-    return displayPart(tokenToString(kind), 5 /* keyword */);
-  }
-  function punctuationPart(kind) {
-    return displayPart(tokenToString(kind), 15 /* punctuation */);
-  }
-  function operatorPart(kind) {
-    return displayPart(tokenToString(kind), 12 /* operator */);
-  }
-  function parameterNamePart(text) {
-    return displayPart(text, 13 /* parameterName */);
-  }
-  function propertyNamePart(text) {
-    return displayPart(text, 14 /* propertyName */);
-  }
-  function textOrKeywordPart(text) {
-    const kind = stringToToken(text);
-    return kind === void 0 ? textPart(text) : keywordPart(kind);
-  }
-  function textPart(text) {
-    return displayPart(text, 17 /* text */);
-  }
-  function typeAliasNamePart(text) {
-    return displayPart(text, 0 /* aliasName */);
-  }
-  function typeParameterNamePart(text) {
-    return displayPart(text, 18 /* typeParameterName */);
-  }
-  function linkTextPart(text) {
-    return displayPart(text, 24 /* linkText */);
-  }
-  function linkNamePart(text, target) {
-    return {
-      text,
-      kind: SymbolDisplayPartKind[23 /* linkName */],
-      target: {
-        fileName: getSourceFileOfNode(target).fileName,
-        textSpan: createTextSpanFromNode(target)
-      }
-    };
-  }
-  function linkPart(text) {
-    return displayPart(text, 22 /* link */);
-  }
-  function buildLinkParts(link, checker) {
-    var _a;
-    const prefix = isJSDocLink(link) ? "link" : isJSDocLinkCode(link) ? "linkcode" : "linkplain";
-    const parts = [linkPart(`{@${prefix} `)];
-    if (!link.name) {
-      if (link.text) {
-        parts.push(linkTextPart(link.text));
-      }
-    } else {
-      const symbol = checker == null ? void 0 : checker.getSymbolAtLocation(link.name);
-      const suffix = findLinkNameEnd(link.text);
-      const name = getTextOfNode(link.name) + link.text.slice(0, suffix);
-      const text = skipSeparatorFromLinkText(link.text.slice(suffix));
-      const decl = (symbol == null ? void 0 : symbol.valueDeclaration) || ((_a = symbol == null ? void 0 : symbol.declarations) == null ? void 0 : _a[0]);
-      if (decl) {
-        parts.push(linkNamePart(name, decl));
-        if (text)
-          parts.push(linkTextPart(text));
-      } else {
-        parts.push(linkTextPart(name + (suffix ? "" : " ") + text));
-      }
-    }
-    parts.push(linkPart("}"));
-    return parts;
-  }
-  function skipSeparatorFromLinkText(text) {
-    let pos = 0;
-    if (text.charCodeAt(pos++) === 124 /* bar */) {
-      while (pos < text.length && text.charCodeAt(pos) === 32 /* space */)
-        pos++;
-      return text.slice(pos);
-    }
-    return text;
-  }
-  function findLinkNameEnd(text) {
-    let pos = text.indexOf("://");
-    if (pos === 0) {
-      while (pos < text.length && text.charCodeAt(pos) !== 124 /* bar */)
-        pos++;
-      return pos;
-    }
-    if (text.indexOf("()") === 0)
-      return 2;
-    if (text.charAt(0) === "<") {
-      let brackets2 = 0;
-      let i = 0;
-      while (i < text.length) {
-        if (text[i] === "<")
-          brackets2++;
-        if (text[i] === ">")
-          brackets2--;
-        i++;
-        if (!brackets2)
-          return i;
-      }
-    }
-    return 0;
-  }
-  function getNewLineOrDefaultFromHost(host, formatSettings) {
-    var _a;
-    return (formatSettings == null ? void 0 : formatSettings.newLineCharacter) || ((_a = host.getNewLine) == null ? void 0 : _a.call(host)) || lineFeed2;
-  }
-  function lineBreakPart() {
-    return displayPart("\n", 6 /* lineBreak */);
-  }
-  function mapToDisplayParts(writeDisplayParts) {
-    try {
-      writeDisplayParts(displayPartWriter);
-      return displayPartWriter.displayParts();
-    } finally {
-      displayPartWriter.clear();
-    }
-  }
-  function typeToDisplayParts(typechecker, type, enclosingDeclaration, flags = 0 /* None */) {
-    return mapToDisplayParts((writer) => {
-      typechecker.writeType(type, enclosingDeclaration, flags | 1024 /* MultilineObjectLiterals */ | 16384 /* UseAliasDefinedOutsideCurrentScope */, writer);
-    });
-  }
-  function symbolToDisplayParts(typeChecker, symbol, enclosingDeclaration, meaning, flags = 0 /* None */) {
-    return mapToDisplayParts((writer) => {
-      typeChecker.writeSymbol(symbol, enclosingDeclaration, meaning, flags | 8 /* UseAliasDefinedOutsideCurrentScope */, writer);
-    });
-  }
-  function signatureToDisplayParts(typechecker, signature, enclosingDeclaration, flags = 0 /* None */) {
-    flags |= 16384 /* UseAliasDefinedOutsideCurrentScope */ | 1024 /* MultilineObjectLiterals */ | 32 /* WriteTypeArgumentsOfSignature */ | 8192 /* OmitParameterModifiers */;
-    return mapToDisplayParts((writer) => {
-      typechecker.writeSignature(
-        signature,
-        enclosingDeclaration,
-        flags,
-        /*kind*/
-        void 0,
-        writer
-      );
-    });
-  }
-  function nodeToDisplayParts(node, enclosingDeclaration) {
-    const file = enclosingDeclaration.getSourceFile();
-    return mapToDisplayParts((writer) => {
-      const printer = createPrinterWithRemoveCommentsOmitTrailingSemicolon();
-      printer.writeNode(4 /* Unspecified */, node, file, writer);
-    });
-  }
-  function isImportOrExportSpecifierName(location) {
-    return !!location.parent && isImportOrExportSpecifier(location.parent) && location.parent.propertyName === location;
-  }
-  function getScriptKind(fileName, host) {
-    return ensureScriptKind(fileName, host.getScriptKind && host.getScriptKind(fileName));
-  }
-  function getSymbolTarget(symbol, checker) {
-    let next = symbol;
-    while (isAliasSymbol(next) || isTransientSymbol(next) && next.links.target) {
-      if (isTransientSymbol(next) && next.links.target) {
-        next = next.links.target;
-      } else {
-        next = skipAlias(next, checker);
-      }
-    }
-    return next;
-  }
-  function isAliasSymbol(symbol) {
-    return (symbol.flags & 2097152 /* Alias */) !== 0;
-  }
-  function getUniqueSymbolId(symbol, checker) {
-    return getSymbolId(skipAlias(symbol, checker));
-  }
-  function getFirstNonSpaceCharacterPosition(text, position) {
-    while (isWhiteSpaceLike(text.charCodeAt(position))) {
-      position += 1;
-    }
-    return position;
-  }
-  function getPrecedingNonSpaceCharacterPosition(text, position) {
-    while (position > -1 && isWhiteSpaceSingleLine(text.charCodeAt(position))) {
-      position -= 1;
-    }
-    return position + 1;
-  }
-  function getSynthesizedDeepClone(node, includeTrivia = true) {
-    const clone2 = node && getSynthesizedDeepCloneWorker(node);
-    if (clone2 && !includeTrivia)
-      suppressLeadingAndTrailingTrivia(clone2);
-    return clone2;
-  }
-  function getSynthesizedDeepCloneWithReplacements(node, includeTrivia, replaceNode) {
-    let clone2 = replaceNode(node);
-    if (clone2) {
-      setOriginalNode(clone2, node);
-    } else {
-      clone2 = getSynthesizedDeepCloneWorker(node, replaceNode);
-    }
-    if (clone2 && !includeTrivia)
-      suppressLeadingAndTrailingTrivia(clone2);
-    return clone2;
-  }
-  function getSynthesizedDeepCloneWorker(node, replaceNode) {
-    const nodeClone = replaceNode ? (n) => getSynthesizedDeepCloneWithReplacements(
-      n,
-      /*includeTrivia*/
-      true,
-      replaceNode
-    ) : getSynthesizedDeepClone;
-    const nodesClone = replaceNode ? (ns) => ns && getSynthesizedDeepClonesWithReplacements(
-      ns,
-      /*includeTrivia*/
-      true,
-      replaceNode
-    ) : (ns) => ns && getSynthesizedDeepClones(ns);
-    const visited = visitEachChild(node, nodeClone, nullTransformationContext, nodesClone, nodeClone);
-    if (visited === node) {
-      const clone2 = isStringLiteral(node) ? setOriginalNode(factory.createStringLiteralFromNode(node), node) : isNumericLiteral(node) ? setOriginalNode(factory.createNumericLiteral(node.text, node.numericLiteralFlags), node) : factory.cloneNode(node);
-      return setTextRange(clone2, node);
-    }
-    visited.parent = void 0;
-    return visited;
-  }
-  function getSynthesizedDeepClones(nodes, includeTrivia = true) {
-    if (nodes) {
-      const cloned = factory.createNodeArray(nodes.map((n) => getSynthesizedDeepClone(n, includeTrivia)), nodes.hasTrailingComma);
-      setTextRange(cloned, nodes);
-      return cloned;
-    }
-    return nodes;
-  }
-  function getSynthesizedDeepClonesWithReplacements(nodes, includeTrivia, replaceNode) {
-    return factory.createNodeArray(nodes.map((n) => getSynthesizedDeepCloneWithReplacements(n, includeTrivia, replaceNode)), nodes.hasTrailingComma);
-  }
-  function suppressLeadingAndTrailingTrivia(node) {
-    suppressLeadingTrivia(node);
-    suppressTrailingTrivia(node);
-  }
-  function suppressLeadingTrivia(node) {
-    addEmitFlagsRecursively(node, 1024 /* NoLeadingComments */, getFirstChild);
-  }
-  function suppressTrailingTrivia(node) {
-    addEmitFlagsRecursively(node, 2048 /* NoTrailingComments */, getLastChild);
-  }
-  function copyComments(sourceNode, targetNode) {
-    const sourceFile = sourceNode.getSourceFile();
-    const text = sourceFile.text;
-    if (hasLeadingLineBreak(sourceNode, text)) {
-      copyLeadingComments(sourceNode, targetNode, sourceFile);
-    } else {
-      copyTrailingAsLeadingComments(sourceNode, targetNode, sourceFile);
-    }
-    copyTrailingComments(sourceNode, targetNode, sourceFile);
-  }
-  function hasLeadingLineBreak(node, text) {
-    const start = node.getFullStart();
-    const end = node.getStart();
-    for (let i = start; i < end; i++) {
-      if (text.charCodeAt(i) === 10 /* lineFeed */)
-        return true;
-    }
-    return false;
-  }
-  function addEmitFlagsRecursively(node, flag, getChild) {
-    addEmitFlags(node, flag);
-    const child = getChild(node);
-    if (child)
-      addEmitFlagsRecursively(child, flag, getChild);
-  }
-  function getFirstChild(node) {
-    return node.forEachChild((child) => child);
-  }
-  function getUniqueName(baseName, sourceFile) {
-    let nameText = baseName;
-    for (let i = 1; !isFileLevelUniqueName(sourceFile, nameText); i++) {
-      nameText = `${baseName}_${i}`;
-    }
-    return nameText;
-  }
-  function getRenameLocation(edits, renameFilename, name, preferLastLocation) {
-    let delta = 0;
-    let lastPos = -1;
-    for (const { fileName, textChanges: textChanges2 } of edits) {
-      Debug.assert(fileName === renameFilename);
-      for (const change of textChanges2) {
-        const { span, newText } = change;
-        const index = indexInTextChange(newText, escapeString(name));
-        if (index !== -1) {
-          lastPos = span.start + delta + index;
-          if (!preferLastLocation) {
-            return lastPos;
-          }
-        }
-        delta += newText.length - span.length;
-      }
-    }
-    Debug.assert(preferLastLocation);
-    Debug.assert(lastPos >= 0);
-    return lastPos;
-  }
-  function copyLeadingComments(sourceNode, targetNode, sourceFile, commentKind, hasTrailingNewLine) {
-    forEachLeadingCommentRange(sourceFile.text, sourceNode.pos, getAddCommentsFunction(targetNode, sourceFile, commentKind, hasTrailingNewLine, addSyntheticLeadingComment));
-  }
-  function copyTrailingComments(sourceNode, targetNode, sourceFile, commentKind, hasTrailingNewLine) {
-    forEachTrailingCommentRange(sourceFile.text, sourceNode.end, getAddCommentsFunction(targetNode, sourceFile, commentKind, hasTrailingNewLine, addSyntheticTrailingComment));
-  }
-  function copyTrailingAsLeadingComments(sourceNode, targetNode, sourceFile, commentKind, hasTrailingNewLine) {
-    forEachTrailingCommentRange(sourceFile.text, sourceNode.pos, getAddCommentsFunction(targetNode, sourceFile, commentKind, hasTrailingNewLine, addSyntheticLeadingComment));
-  }
-  function getAddCommentsFunction(targetNode, sourceFile, commentKind, hasTrailingNewLine, cb) {
-    return (pos, end, kind, htnl) => {
-      if (kind === 3 /* MultiLineCommentTrivia */) {
-        pos += 2;
-        end -= 2;
-      } else {
-        pos += 2;
-      }
-      cb(targetNode, commentKind || kind, sourceFile.text.slice(pos, end), hasTrailingNewLine !== void 0 ? hasTrailingNewLine : htnl);
-    };
-  }
-  function indexInTextChange(change, name) {
-    if (startsWith(change, name))
-      return 0;
-    let idx = change.indexOf(" " + name);
-    if (idx === -1)
-      idx = change.indexOf("." + name);
-    if (idx === -1)
-      idx = change.indexOf('"' + name);
-    return idx === -1 ? -1 : idx + 1;
-  }
-  function needsParentheses(expression) {
-    return isBinaryExpression(expression) && expression.operatorToken.kind === 28 /* CommaToken */ || isObjectLiteralExpression(expression) || isAsExpression(expression) && isObjectLiteralExpression(expression.expression);
-  }
-  function getContextualTypeFromParent(node, checker, contextFlags) {
-    const parent2 = walkUpParenthesizedExpressions(node.parent);
-    switch (parent2.kind) {
-      case 213 /* NewExpression */:
-        return checker.getContextualType(parent2, contextFlags);
-      case 225 /* BinaryExpression */: {
-        const { left, operatorToken, right } = parent2;
-        return isEqualityOperatorKind(operatorToken.kind) ? checker.getTypeAtLocation(node === right ? left : right) : checker.getContextualType(node, contextFlags);
-      }
-      case 295 /* CaseClause */:
-        return getSwitchedType(parent2, checker);
-      default:
-        return checker.getContextualType(node, contextFlags);
-    }
-  }
-  function quote(sourceFile, preferences, text) {
-    const quotePreference = getQuotePreference(sourceFile, preferences);
-    const quoted = JSON.stringify(text);
-    return quotePreference === 0 /* Single */ ? `'${stripQuotes(quoted).replace(/'/g, "\\'").replace(/\\"/g, '"')}'` : quoted;
-  }
-  function isEqualityOperatorKind(kind) {
-    switch (kind) {
-      case 37 /* EqualsEqualsEqualsToken */:
-      case 35 /* EqualsEqualsToken */:
-      case 38 /* ExclamationEqualsEqualsToken */:
-      case 36 /* ExclamationEqualsToken */:
-        return true;
-      default:
-        return false;
-    }
-  }
-  function isStringLiteralOrTemplate(node) {
-    switch (node.kind) {
-      case 11 /* StringLiteral */:
-      case 15 /* NoSubstitutionTemplateLiteral */:
-      case 227 /* TemplateExpression */:
-      case 214 /* TaggedTemplateExpression */:
-        return true;
-      default:
-        return false;
-    }
-  }
-  function hasIndexSignature(type) {
-    return !!type.getStringIndexType() || !!type.getNumberIndexType();
-  }
-  function getSwitchedType(caseClause, checker) {
-    return checker.getTypeAtLocation(caseClause.parent.parent.expression);
-  }
-  function getTypeNodeIfAccessible(type, enclosingScope, program, host) {
-    const checker = program.getTypeChecker();
-    let typeIsAccessible = true;
-    const notAccessible = () => typeIsAccessible = false;
-    const res = checker.typeToTypeNode(type, enclosingScope, 1 /* NoTruncation */, {
-      trackSymbol: (symbol, declaration, meaning) => {
-        typeIsAccessible = typeIsAccessible && checker.isSymbolAccessible(
-          symbol,
-          declaration,
-          meaning,
-          /*shouldComputeAliasToMarkVisible*/
-          false
-        ).accessibility === 0 /* Accessible */;
-        return !typeIsAccessible;
-      },
-      reportInaccessibleThisError: notAccessible,
-      reportPrivateInBaseOfClassExpression: notAccessible,
-      reportInaccessibleUniqueSymbolError: notAccessible,
-      moduleResolverHost: getModuleSpecifierResolverHost(program, host)
-    });
-    return typeIsAccessible ? res : void 0;
-  }
-  function syntaxRequiresTrailingCommaOrSemicolonOrASI(kind) {
-    return kind === 178 /* CallSignature */ || kind === 179 /* ConstructSignature */ || kind === 180 /* IndexSignature */ || kind === 170 /* PropertySignature */ || kind === 172 /* MethodSignature */;
-  }
-  function syntaxRequiresTrailingFunctionBlockOrSemicolonOrASI(kind) {
-    return kind === 261 /* FunctionDeclaration */ || kind === 175 /* Constructor */ || kind === 173 /* MethodDeclaration */ || kind === 176 /* GetAccessor */ || kind === 177 /* SetAccessor */;
-  }
-  function syntaxRequiresTrailingModuleBlockOrSemicolonOrASI(kind) {
-    return kind === 266 /* ModuleDeclaration */;
-  }
-  function syntaxRequiresTrailingSemicolonOrASI(kind) {
-    return kind === 242 /* VariableStatement */ || kind === 243 /* ExpressionStatement */ || kind === 245 /* DoStatement */ || kind === 250 /* ContinueStatement */ || kind === 251 /* BreakStatement */ || kind === 252 /* ReturnStatement */ || kind === 256 /* ThrowStatement */ || kind === 258 /* DebuggerStatement */ || kind === 171 /* PropertyDeclaration */ || kind === 264 /* TypeAliasDeclaration */ || kind === 271 /* ImportDeclaration */ || kind === 270 /* ImportEqualsDeclaration */ || kind === 277 /* ExportDeclaration */ || kind === 269 /* NamespaceExportDeclaration */ || kind === 276 /* ExportAssignment */;
-  }
-  function nodeIsASICandidate(node, sourceFile) {
-    const lastToken = node.getLastToken(sourceFile);
-    if (lastToken && lastToken.kind === 27 /* SemicolonToken */) {
-      return false;
-    }
-    if (syntaxRequiresTrailingCommaOrSemicolonOrASI(node.kind)) {
-      if (lastToken && lastToken.kind === 28 /* CommaToken */) {
-        return false;
-      }
-    } else if (syntaxRequiresTrailingModuleBlockOrSemicolonOrASI(node.kind)) {
-      const lastChild = last(node.getChildren(sourceFile));
-      if (lastChild && isModuleBlock(lastChild)) {
-        return false;
-      }
-    } else if (syntaxRequiresTrailingFunctionBlockOrSemicolonOrASI(node.kind)) {
-      const lastChild = last(node.getChildren(sourceFile));
-      if (lastChild && isFunctionBlock(lastChild)) {
-        return false;
-      }
-    } else if (!syntaxRequiresTrailingSemicolonOrASI(node.kind)) {
-      return false;
-    }
-    if (node.kind === 245 /* DoStatement */) {
-      return true;
-    }
-    const topNode = findAncestor(node, (ancestor) => !ancestor.parent);
-    const nextToken = findNextToken(node, topNode, sourceFile);
-    if (!nextToken || nextToken.kind === 20 /* CloseBraceToken */) {
-      return true;
-    }
-    const startLine = sourceFile.getLineAndCharacterOfPosition(node.getEnd()).line;
-    const endLine = sourceFile.getLineAndCharacterOfPosition(nextToken.getStart(sourceFile)).line;
-    return startLine !== endLine;
-  }
-  function positionIsASICandidate(pos, context, sourceFile) {
-    const contextAncestor = findAncestor(context, (ancestor) => {
-      if (ancestor.end !== pos) {
-        return "quit";
-      }
-      return syntaxMayBeASICandidate(ancestor.kind);
-    });
-    return !!contextAncestor && nodeIsASICandidate(contextAncestor, sourceFile);
-  }
-  function probablyUsesSemicolons(sourceFile) {
-    let withSemicolon = 0;
-    let withoutSemicolon = 0;
-    const nStatementsToObserve = 5;
-    forEachChild(sourceFile, function visit(node) {
-      if (syntaxRequiresTrailingSemicolonOrASI(node.kind)) {
-        const lastToken = node.getLastToken(sourceFile);
-        if ((lastToken == null ? void 0 : lastToken.kind) === 27 /* SemicolonToken */) {
-          withSemicolon++;
-        } else {
-          withoutSemicolon++;
-        }
-      } else if (syntaxRequiresTrailingCommaOrSemicolonOrASI(node.kind)) {
-        const lastToken = node.getLastToken(sourceFile);
-        if ((lastToken == null ? void 0 : lastToken.kind) === 27 /* SemicolonToken */) {
-          withSemicolon++;
-        } else if (lastToken && lastToken.kind !== 28 /* CommaToken */) {
-          const lastTokenLine = getLineAndCharacterOfPosition(sourceFile, lastToken.getStart(sourceFile)).line;
-          const nextTokenLine = getLineAndCharacterOfPosition(sourceFile, getSpanOfTokenAtPosition(sourceFile, lastToken.end).start).line;
-          if (lastTokenLine !== nextTokenLine) {
-            withoutSemicolon++;
-          }
-        }
-      }
-      if (withSemicolon + withoutSemicolon >= nStatementsToObserve) {
-        return true;
-      }
-      return forEachChild(node, visit);
-    });
-    if (withSemicolon === 0 && withoutSemicolon <= 1) {
-      return true;
-    }
-    return withSemicolon / withoutSemicolon > 1 / nStatementsToObserve;
-  }
-  function tryGetDirectories(host, directoryName) {
-    return tryIOAndConsumeErrors(host, host.getDirectories, directoryName) || [];
-  }
-  function tryReadDirectory(host, path, extensions, exclude, include) {
-    return tryIOAndConsumeErrors(host, host.readDirectory, path, extensions, exclude, include) || emptyArray;
-  }
-  function tryFileExists(host, path) {
-    return tryIOAndConsumeErrors(host, host.fileExists, path);
-  }
-  function tryDirectoryExists(host, path) {
-    return tryAndIgnoreErrors(() => directoryProbablyExists(path, host)) || false;
-  }
-  function tryAndIgnoreErrors(cb) {
-    try {
-      return cb();
-    } catch {
-      return void 0;
-    }
-  }
-  function tryIOAndConsumeErrors(host, toApply, ...args) {
-    return tryAndIgnoreErrors(() => toApply && toApply.apply(host, args));
-  }
-  function findPackageJsons(startDirectory, host, stopDirectory) {
-    const paths = [];
-    forEachAncestorDirectory(startDirectory, (ancestor) => {
-      if (ancestor === stopDirectory) {
-        return true;
-      }
-      const currentConfigPath = combinePaths(ancestor, "package.json");
-      if (tryFileExists(host, currentConfigPath)) {
-        paths.push(currentConfigPath);
-      }
-    });
-    return paths;
-  }
-  function findPackageJson(directory, host) {
-    let packageJson;
-    forEachAncestorDirectory(directory, (ancestor) => {
-      if (ancestor === "node_modules")
-        return true;
-      packageJson = findConfigFile(ancestor, (f) => tryFileExists(host, f), "package.json");
-      if (packageJson) {
-        return true;
-      }
-    });
-    return packageJson;
-  }
-  function getPackageJsonsVisibleToFile(fileName, host) {
-    if (!host.fileExists) {
-      return [];
-    }
-    const packageJsons = [];
-    forEachAncestorDirectory(getDirectoryPath(fileName), (ancestor) => {
-      const packageJsonFileName = combinePaths(ancestor, "package.json");
-      if (host.fileExists(packageJsonFileName)) {
-        const info = createPackageJsonInfo(packageJsonFileName, host);
-        if (info) {
-          packageJsons.push(info);
-        }
-      }
-    });
-    return packageJsons;
-  }
-  function createPackageJsonInfo(fileName, host) {
-    if (!host.readFile) {
-      return void 0;
-    }
-    const dependencyKeys = ["dependencies", "devDependencies", "optionalDependencies", "peerDependencies"];
-    const stringContent = host.readFile(fileName) || "";
-    const content = tryParseJson(stringContent);
-    const info = {};
-    if (content) {
-      for (const key of dependencyKeys) {
-        const dependencies = content[key];
-        if (!dependencies) {
-          continue;
-        }
-        const dependencyMap = /* @__PURE__ */ new Map();
-        for (const packageName in dependencies) {
-          dependencyMap.set(packageName, dependencies[packageName]);
-        }
-        info[key] = dependencyMap;
-      }
-    }
-    const dependencyGroups = [
-      [1 /* Dependencies */, info.dependencies],
-      [2 /* DevDependencies */, info.devDependencies],
-      [8 /* OptionalDependencies */, info.optionalDependencies],
-      [4 /* PeerDependencies */, info.peerDependencies]
-    ];
-    return {
-      ...info,
-      parseable: !!content,
-      fileName,
-      get,
-      has(dependencyName, inGroups) {
-        return !!get(dependencyName, inGroups);
-      }
-    };
-    function get(dependencyName, inGroups = 15 /* All */) {
-      for (const [group2, deps] of dependencyGroups) {
-        if (deps && inGroups & group2) {
-          const dep = deps.get(dependencyName);
-          if (dep !== void 0) {
-            return dep;
-          }
-        }
-      }
-    }
-  }
-  function createPackageJsonImportFilter(fromFile, preferences, host) {
-    const packageJsons = (host.getPackageJsonsVisibleToFile && host.getPackageJsonsVisibleToFile(fromFile.fileName) || getPackageJsonsVisibleToFile(fromFile.fileName, host)).filter((p) => p.parseable);
-    let usesNodeCoreModules;
-    let ambientModuleCache;
-    let sourceFileCache;
-    return {
-      allowsImportingAmbientModule,
-      allowsImportingSourceFile,
-      allowsImportingSpecifier
-    };
-    function moduleSpecifierIsCoveredByPackageJson(specifier) {
-      const packageName = getNodeModuleRootSpecifier(specifier);
-      for (const packageJson of packageJsons) {
-        if (packageJson.has(packageName) || packageJson.has(getTypesPackageName(packageName))) {
-          return true;
-        }
-      }
-      return false;
-    }
-    function allowsImportingAmbientModule(moduleSymbol, moduleSpecifierResolutionHost) {
-      if (!packageJsons.length || !moduleSymbol.valueDeclaration) {
-        return true;
-      }
-      if (!ambientModuleCache) {
-        ambientModuleCache = /* @__PURE__ */ new Map();
-      } else {
-        const cached = ambientModuleCache.get(moduleSymbol);
-        if (cached !== void 0) {
-          return cached;
-        }
-      }
-      const declaredModuleSpecifier = stripQuotes(moduleSymbol.getName());
-      if (isAllowedCoreNodeModulesImport(declaredModuleSpecifier)) {
-        ambientModuleCache.set(moduleSymbol, true);
-        return true;
-      }
-      const declaringSourceFile = moduleSymbol.valueDeclaration.getSourceFile();
-      const declaringNodeModuleName = getNodeModulesPackageNameFromFileName(declaringSourceFile.fileName, moduleSpecifierResolutionHost);
-      if (typeof declaringNodeModuleName === "undefined") {
-        ambientModuleCache.set(moduleSymbol, true);
-        return true;
-      }
-      const result = moduleSpecifierIsCoveredByPackageJson(declaringNodeModuleName) || moduleSpecifierIsCoveredByPackageJson(declaredModuleSpecifier);
-      ambientModuleCache.set(moduleSymbol, result);
-      return result;
-    }
-    function allowsImportingSourceFile(sourceFile, moduleSpecifierResolutionHost) {
-      if (!packageJsons.length) {
-        return true;
-      }
-      if (!sourceFileCache) {
-        sourceFileCache = /* @__PURE__ */ new Map();
-      } else {
-        const cached = sourceFileCache.get(sourceFile);
-        if (cached !== void 0) {
-          return cached;
-        }
-      }
-      const moduleSpecifier = getNodeModulesPackageNameFromFileName(sourceFile.fileName, moduleSpecifierResolutionHost);
-      if (!moduleSpecifier) {
-        sourceFileCache.set(sourceFile, true);
-        return true;
-      }
-      const result = moduleSpecifierIsCoveredByPackageJson(moduleSpecifier);
-      sourceFileCache.set(sourceFile, result);
-      return result;
-    }
-    function allowsImportingSpecifier(moduleSpecifier) {
-      if (!packageJsons.length || isAllowedCoreNodeModulesImport(moduleSpecifier)) {
-        return true;
-      }
-      if (pathIsRelative(moduleSpecifier) || isRootedDiskPath(moduleSpecifier)) {
-        return true;
-      }
-      return moduleSpecifierIsCoveredByPackageJson(moduleSpecifier);
-    }
-    function isAllowedCoreNodeModulesImport(moduleSpecifier) {
-      if (isSourceFileJS(fromFile) && ts_JsTyping_exports.nodeCoreModules.has(moduleSpecifier)) {
-        if (usesNodeCoreModules === void 0) {
-          usesNodeCoreModules = consumesNodeCoreModules(fromFile);
-        }
-        if (usesNodeCoreModules) {
-          return true;
-        }
-      }
-      return false;
-    }
-    function getNodeModulesPackageNameFromFileName(importedFileName, moduleSpecifierResolutionHost) {
-      if (!stringContains(importedFileName, "node_modules")) {
-        return void 0;
-      }
-      const specifier = ts_moduleSpecifiers_exports.getNodeModulesPackageName(
-        host.getCompilationSettings(),
-        fromFile,
-        importedFileName,
-        moduleSpecifierResolutionHost,
-        preferences
-      );
-      if (!specifier) {
-        return void 0;
-      }
-      if (!pathIsRelative(specifier) && !isRootedDiskPath(specifier)) {
-        return getNodeModuleRootSpecifier(specifier);
-      }
-    }
-    function getNodeModuleRootSpecifier(fullSpecifier) {
-      const components = getPathComponents(getPackageNameFromTypesPackageName(fullSpecifier)).slice(1);
-      if (startsWith(components[0], "@")) {
-        return `${components[0]}/${components[1]}`;
-      }
-      return components[0];
-    }
-  }
-  function tryParseJson(text) {
-    try {
-      return JSON.parse(text);
-    } catch {
-      return void 0;
-    }
-  }
-  function consumesNodeCoreModules(sourceFile) {
-    return some(sourceFile.imports, ({ text }) => ts_JsTyping_exports.nodeCoreModules.has(text));
-  }
-  function isInsideNodeModules(fileOrDirectory) {
-    return contains(getPathComponents(fileOrDirectory), "node_modules");
-  }
-  function isDiagnosticWithLocation(diagnostic) {
-    return diagnostic.file !== void 0 && diagnostic.start !== void 0 && diagnostic.length !== void 0;
-  }
-  function findDiagnosticForNode(node, sortedFileDiagnostics) {
-    const span = createTextSpanFromNode(node);
-    const index = binarySearchKey(sortedFileDiagnostics, span, identity, compareTextSpans);
-    if (index >= 0) {
-      const diagnostic = sortedFileDiagnostics[index];
-      Debug.assertEqual(diagnostic.file, node.getSourceFile(), "Diagnostics proided to 'findDiagnosticForNode' must be from a single SourceFile");
-      return cast(diagnostic, isDiagnosticWithLocation);
-    }
-  }
-  function getDiagnosticsWithinSpan(span, sortedFileDiagnostics) {
-    var _a;
-    let index = binarySearchKey(sortedFileDiagnostics, span.start, (diag2) => diag2.start, compareValues);
-    if (index < 0) {
-      index = ~index;
-    }
-    while (((_a = sortedFileDiagnostics[index - 1]) == null ? void 0 : _a.start) === span.start) {
-      index--;
-    }
-    const result = [];
-    const end = textSpanEnd(span);
-    while (true) {
-      const diagnostic = tryCast(sortedFileDiagnostics[index], isDiagnosticWithLocation);
-      if (!diagnostic || diagnostic.start > end) {
-        break;
-      }
-      if (textSpanContainsTextSpan(span, diagnostic)) {
-        result.push(diagnostic);
-      }
-      index++;
-    }
-    return result;
-  }
-  function getRefactorContextSpan({ startPosition, endPosition }) {
-    return createTextSpanFromBounds(startPosition, endPosition === void 0 ? startPosition : endPosition);
-  }
-  function getFixableErrorSpanExpression(sourceFile, span) {
-    const token = getTokenAtPosition(sourceFile, span.start);
-    const expression = findAncestor(token, (node) => {
-      if (node.getStart(sourceFile) < span.start || node.getEnd() > textSpanEnd(span)) {
-        return "quit";
-      }
-      return isExpression(node) && textSpansEqual(span, createTextSpanFromNode(node, sourceFile));
-    });
-    return expression;
-  }
-  function mapOneOrMany(valueOrArray, f, resultSelector = identity) {
-    return valueOrArray ? isArray(valueOrArray) ? resultSelector(map(valueOrArray, f)) : f(valueOrArray, 0) : void 0;
-  }
-  function firstOrOnly(valueOrArray) {
-    return isArray(valueOrArray) ? first(valueOrArray) : valueOrArray;
-  }
-  function getNamesForExportedSymbol(symbol, scriptTarget) {
-    if (needsNameFromDeclaration(symbol)) {
-      const fromDeclaration = getDefaultLikeExportNameFromDeclaration(symbol);
-      if (fromDeclaration)
-        return fromDeclaration;
-      const fileNameCase = ts_codefix_exports.moduleSymbolToValidIdentifier(
-        getSymbolParentOrFail(symbol),
-        scriptTarget,
-        /*forceCapitalize*/
-        false
-      );
-      const capitalized = ts_codefix_exports.moduleSymbolToValidIdentifier(
-        getSymbolParentOrFail(symbol),
-        scriptTarget,
-        /*forceCapitalize*/
-        true
-      );
-      if (fileNameCase === capitalized)
-        return fileNameCase;
-      return [fileNameCase, capitalized];
-    }
-    return symbol.name;
-  }
-  function getNameForExportedSymbol(symbol, scriptTarget, preferCapitalized) {
-    if (needsNameFromDeclaration(symbol)) {
-      return getDefaultLikeExportNameFromDeclaration(symbol) || ts_codefix_exports.moduleSymbolToValidIdentifier(getSymbolParentOrFail(symbol), scriptTarget, !!preferCapitalized);
-    }
-    return symbol.name;
-  }
-  function needsNameFromDeclaration(symbol) {
-    return !(symbol.flags & 33554432 /* Transient */) && (symbol.escapedName === "export=" /* ExportEquals */ || symbol.escapedName === "default" /* Default */);
-  }
-  function getDefaultLikeExportNameFromDeclaration(symbol) {
-    return firstDefined(
-      symbol.declarations,
-      (d) => {
-        var _a, _b;
-        return isExportAssignment(d) ? (_a = tryCast(skipOuterExpressions(d.expression), isIdentifier)) == null ? void 0 : _a.text : (_b = tryCast(getNameOfDeclaration(d), isIdentifier)) == null ? void 0 : _b.text;
-      }
-    );
-  }
-  function getSymbolParentOrFail(symbol) {
-    var _a;
-    return Debug.checkDefined(
-      symbol.parent,
-      `Symbol parent was undefined. Flags: ${Debug.formatSymbolFlags(symbol.flags)}. Declarations: ${(_a = symbol.declarations) == null ? void 0 : _a.map((d) => {
-        const kind = Debug.formatSyntaxKind(d.kind);
-        const inJS = isInJSFile(d);
-        const { expression } = d;
-        return (inJS ? "[JS]" : "") + kind + (expression ? ` (expression: ${Debug.formatSyntaxKind(expression.kind)})` : "");
-      }).join(", ")}.`
-    );
-  }
-  function stringContainsAt(haystack, needle, startIndex) {
-    const needleLength = needle.length;
-    if (needleLength + startIndex > haystack.length) {
-      return false;
-    }
-    for (let i = 0; i < needleLength; i++) {
-      if (needle.charCodeAt(i) !== haystack.charCodeAt(i + startIndex))
-        return false;
-    }
-    return true;
-  }
-  function startsWithUnderscore(name) {
-    return name.charCodeAt(0) === 95 /* _ */;
-  }
-  function isGlobalDeclaration(declaration) {
-    return !isNonGlobalDeclaration(declaration);
-  }
-  function isNonGlobalDeclaration(declaration) {
-    const sourceFile = declaration.getSourceFile();
-    if (!sourceFile.externalModuleIndicator && !sourceFile.commonJsModuleIndicator) {
-      return false;
-    }
-    return isInJSFile(declaration) || !findAncestor(declaration, (d) => isModuleDeclaration(d) && isGlobalScopeAugmentation(d));
-  }
-  function isDeprecatedDeclaration(decl) {
-    return !!(getCombinedNodeFlagsAlwaysIncludeJSDoc(decl) & 8192 /* Deprecated */);
-  }
-  function shouldUseUriStyleNodeCoreModules(file, program) {
-    const decisionFromFile = firstDefined(file.imports, (node) => {
-      if (ts_JsTyping_exports.nodeCoreModules.has(node.text)) {
-        return startsWith(node.text, "node:");
-      }
-    });
-    return decisionFromFile ?? program.usesUriStyleNodeCoreModules;
-  }
-  function getNewLineKind(newLineCharacter) {
-    return newLineCharacter === "\n" ? 1 /* LineFeed */ : 0 /* CarriageReturnLineFeed */;
-  }
-  function diagnosticToString(diag2) {
-    return isArray(diag2) ? formatStringFromArgs(getLocaleSpecificMessage(diag2[0]), diag2.slice(1)) : getLocaleSpecificMessage(diag2);
-  }
-  function getFormatCodeSettingsForWriting({ options }, sourceFile) {
-    const shouldAutoDetectSemicolonPreference = !options.semicolons || options.semicolons === "ignore" /* Ignore */;
-    const shouldRemoveSemicolons = options.semicolons === "remove" /* Remove */ || shouldAutoDetectSemicolonPreference && !probablyUsesSemicolons(sourceFile);
-    return {
-      ...options,
-      semicolons: shouldRemoveSemicolons ? "remove" /* Remove */ : "ignore" /* Ignore */
-    };
-  }
-  function jsxModeNeedsExplicitImport(jsx) {
-    return jsx === 2 /* React */ || jsx === 3 /* ReactNative */;
-  }
-  function isSourceFileFromLibrary(program, node) {
-    return program.isSourceFileFromExternalLibrary(node) || program.isSourceFileDefaultLibrary(node);
-  }
-  function newCaseClauseTracker(checker, clauses) {
-    const existingStrings = /* @__PURE__ */ new Set();
-    const existingNumbers = /* @__PURE__ */ new Set();
-    const existingBigInts = /* @__PURE__ */ new Set();
-    for (const clause of clauses) {
-      if (!isDefaultClause(clause)) {
-        const expression = skipParentheses(clause.expression);
-        if (isLiteralExpression(expression)) {
-          switch (expression.kind) {
-            case 15 /* NoSubstitutionTemplateLiteral */:
-            case 11 /* StringLiteral */:
-              existingStrings.add(expression.text);
-              break;
-            case 9 /* NumericLiteral */:
-              existingNumbers.add(parseInt(expression.text));
-              break;
-            case 10 /* BigIntLiteral */:
-              const parsedBigInt = parseBigInt(endsWith(expression.text, "n") ? expression.text.slice(0, -1) : expression.text);
-              if (parsedBigInt) {
-                existingBigInts.add(pseudoBigIntToString(parsedBigInt));
-              }
-              break;
-          }
-        } else {
-          const symbol = checker.getSymbolAtLocation(clause.expression);
-          if (symbol && symbol.valueDeclaration && isEnumMember(symbol.valueDeclaration)) {
-            const enumValue = checker.getConstantValue(symbol.valueDeclaration);
-            if (enumValue !== void 0) {
-              addValue(enumValue);
-            }
-          }
-        }
-      }
-    }
-    return {
-      addValue,
-      hasValue
-    };
-    function addValue(value) {
-      switch (typeof value) {
-        case "string":
-          existingStrings.add(value);
-          break;
-        case "number":
-          existingNumbers.add(value);
-      }
-    }
-    function hasValue(value) {
-      switch (typeof value) {
-        case "string":
-          return existingStrings.has(value);
-        case "number":
-          return existingNumbers.has(value);
-        case "object":
-          return existingBigInts.has(pseudoBigIntToString(value));
-      }
-    }
-  }
-  function fileShouldUseJavaScriptRequire(file, program, host, preferRequire) {
-    var _a;
-    const fileName = typeof file === "string" ? file : file.fileName;
-    if (!hasJSFileExtension(fileName)) {
-      return false;
-    }
-    const compilerOptions = program.getCompilerOptions();
-    const moduleKind = getEmitModuleKind(compilerOptions);
-    const impliedNodeFormat = typeof file === "string" ? getImpliedNodeFormatForFile(toPath(file, host.getCurrentDirectory(), hostGetCanonicalFileName(host)), (_a = program.getPackageJsonInfoCache) == null ? void 0 : _a.call(program), host, compilerOptions) : file.impliedNodeFormat;
-    if (impliedNodeFormat === 99 /* ESNext */) {
-      return false;
-    }
-    if (impliedNodeFormat === 1 /* CommonJS */) {
-      return true;
-    }
-    if (compilerOptions.verbatimModuleSyntax && moduleKind === 1 /* CommonJS */) {
-      return true;
-    }
-    if (compilerOptions.verbatimModuleSyntax && emitModuleKindIsNonNodeESM(moduleKind)) {
-      return false;
-    }
-    if (typeof file === "object") {
-      if (file.commonJsModuleIndicator) {
-        return true;
-      }
-      if (file.externalModuleIndicator) {
-        return false;
-      }
-    }
-    return preferRequire;
-  }
-  var scanner, SemanticMeaning, tripleSlashDirectivePrefixRegex, typeKeywords, QuotePreference, displayPartWriter, lineFeed2, ANONYMOUS, syntaxMayBeASICandidate;
-  var init_utilities4 = __esm({
-    "src/services/utilities.ts"() {
-      "use strict";
-      init_ts4();
-      scanner = createScanner(
-        99 /* Latest */,
-        /*skipTrivia*/
-        true
-      );
-      SemanticMeaning = /* @__PURE__ */ ((SemanticMeaning3) => {
-        SemanticMeaning3[SemanticMeaning3["None"] = 0] = "None";
-        SemanticMeaning3[SemanticMeaning3["Value"] = 1] = "Value";
-        SemanticMeaning3[SemanticMeaning3["Type"] = 2] = "Type";
-        SemanticMeaning3[SemanticMeaning3["Namespace"] = 4] = "Namespace";
-        SemanticMeaning3[SemanticMeaning3["All"] = 7] = "All";
-        return SemanticMeaning3;
-      })(SemanticMeaning || {});
-      tripleSlashDirectivePrefixRegex = /^\/\/\/\s* {
-        QuotePreference7[QuotePreference7["Single"] = 0] = "Single";
-        QuotePreference7[QuotePreference7["Double"] = 1] = "Double";
-        return QuotePreference7;
-      })(QuotePreference || {});
-      displayPartWriter = getDisplayPartWriter();
-      lineFeed2 = "\n";
-      ANONYMOUS = "anonymous function";
-      syntaxMayBeASICandidate = or(
-        syntaxRequiresTrailingCommaOrSemicolonOrASI,
-        syntaxRequiresTrailingFunctionBlockOrSemicolonOrASI,
-        syntaxRequiresTrailingModuleBlockOrSemicolonOrASI,
-        syntaxRequiresTrailingSemicolonOrASI
-      );
-    }
-  });
-
-  // src/services/exportInfoMap.ts
-  function createCacheableExportInfoMap(host) {
-    let exportInfoId = 1;
-    const exportInfo = createMultiMap();
-    const symbols = /* @__PURE__ */ new Map();
-    const packages = /* @__PURE__ */ new Map();
-    let usableByFileName;
-    const cache = {
-      isUsableByFile: (importingFile) => importingFile === usableByFileName,
-      isEmpty: () => !exportInfo.size,
-      clear: () => {
-        exportInfo.clear();
-        symbols.clear();
-        usableByFileName = void 0;
-      },
-      add: (importingFile, symbol, symbolTableKey, moduleSymbol, moduleFile, exportKind, isFromPackageJson, checker) => {
-        if (importingFile !== usableByFileName) {
-          cache.clear();
-          usableByFileName = importingFile;
-        }
-        let packageName;
-        if (moduleFile) {
-          const nodeModulesPathParts = getNodeModulePathParts(moduleFile.fileName);
-          if (nodeModulesPathParts) {
-            const { topLevelNodeModulesIndex, topLevelPackageNameIndex, packageRootIndex } = nodeModulesPathParts;
-            packageName = unmangleScopedPackageName(getPackageNameFromTypesPackageName(moduleFile.fileName.substring(topLevelPackageNameIndex + 1, packageRootIndex)));
-            if (startsWith(importingFile, moduleFile.path.substring(0, topLevelNodeModulesIndex))) {
-              const prevDeepestNodeModulesPath = packages.get(packageName);
-              const nodeModulesPath = moduleFile.fileName.substring(0, topLevelPackageNameIndex + 1);
-              if (prevDeepestNodeModulesPath) {
-                const prevDeepestNodeModulesIndex = prevDeepestNodeModulesPath.indexOf(nodeModulesPathPart);
-                if (topLevelNodeModulesIndex > prevDeepestNodeModulesIndex) {
-                  packages.set(packageName, nodeModulesPath);
-                }
-              } else {
-                packages.set(packageName, nodeModulesPath);
-              }
-            }
-          }
-        }
-        const isDefault = exportKind === 1 /* Default */;
-        const namedSymbol = isDefault && getLocalSymbolForExportDefault(symbol) || symbol;
-        const names = exportKind === 0 /* Named */ || isExternalModuleSymbol(namedSymbol) ? unescapeLeadingUnderscores(symbolTableKey) : getNamesForExportedSymbol(
-          namedSymbol,
-          /*scriptTarget*/
-          void 0
-        );
-        const symbolName2 = typeof names === "string" ? names : names[0];
-        const capitalizedSymbolName = typeof names === "string" ? void 0 : names[1];
-        const moduleName = stripQuotes(moduleSymbol.name);
-        const id = exportInfoId++;
-        const target = skipAlias(symbol, checker);
-        const storedSymbol = symbol.flags & 33554432 /* Transient */ ? void 0 : symbol;
-        const storedModuleSymbol = moduleSymbol.flags & 33554432 /* Transient */ ? void 0 : moduleSymbol;
-        if (!storedSymbol || !storedModuleSymbol)
-          symbols.set(id, [symbol, moduleSymbol]);
-        exportInfo.add(key(symbolName2, symbol, isExternalModuleNameRelative(moduleName) ? void 0 : moduleName, checker), {
-          id,
-          symbolTableKey,
-          symbolName: symbolName2,
-          capitalizedSymbolName,
-          moduleName,
-          moduleFile,
-          moduleFileName: moduleFile == null ? void 0 : moduleFile.fileName,
-          packageName,
-          exportKind,
-          targetFlags: target.flags,
-          isFromPackageJson,
-          symbol: storedSymbol,
-          moduleSymbol: storedModuleSymbol
-        });
-      },
-      get: (importingFile, key2) => {
-        if (importingFile !== usableByFileName)
-          return;
-        const result = exportInfo.get(key2);
-        return result == null ? void 0 : result.map(rehydrateCachedInfo);
-      },
-      search: (importingFile, preferCapitalized, matches, action) => {
-        if (importingFile !== usableByFileName)
-          return;
-        return forEachEntry(exportInfo, (info, key2) => {
-          const { symbolName: symbolName2, ambientModuleName } = parseKey(key2);
-          const name = preferCapitalized && info[0].capitalizedSymbolName || symbolName2;
-          if (matches(name, info[0].targetFlags)) {
-            const rehydrated = info.map(rehydrateCachedInfo);
-            const filtered = rehydrated.filter((r, i) => isNotShadowedByDeeperNodeModulesPackage(r, info[i].packageName));
-            if (filtered.length) {
-              const res = action(filtered, name, !!ambientModuleName, key2);
-              if (res !== void 0)
-                return res;
-            }
-          }
-        });
-      },
-      releaseSymbols: () => {
-        symbols.clear();
-      },
-      onFileChanged: (oldSourceFile, newSourceFile, typeAcquisitionEnabled) => {
-        if (fileIsGlobalOnly(oldSourceFile) && fileIsGlobalOnly(newSourceFile)) {
-          return false;
-        }
-        if (usableByFileName && usableByFileName !== newSourceFile.path || // If ATA is enabled, auto-imports uses existing imports to guess whether you want auto-imports from node.
-        // Adding or removing imports from node could change the outcome of that guess, so could change the suggestions list.
-        typeAcquisitionEnabled && consumesNodeCoreModules(oldSourceFile) !== consumesNodeCoreModules(newSourceFile) || // Module agumentation and ambient module changes can add or remove exports available to be auto-imported.
-        // Changes elsewhere in the file can change the *type* of an export in a module augmentation,
-        // but type info is gathered in getCompletionEntryDetails, which doesn't use the cache.
-        !arrayIsEqualTo(oldSourceFile.moduleAugmentations, newSourceFile.moduleAugmentations) || !ambientModuleDeclarationsAreEqual(oldSourceFile, newSourceFile)) {
-          cache.clear();
-          return true;
-        }
-        usableByFileName = newSourceFile.path;
-        return false;
-      }
-    };
-    if (Debug.isDebugging) {
-      Object.defineProperty(cache, "__cache", { get: () => exportInfo });
-    }
-    return cache;
-    function rehydrateCachedInfo(info) {
-      if (info.symbol && info.moduleSymbol)
-        return info;
-      const { id, exportKind, targetFlags, isFromPackageJson, moduleFileName } = info;
-      const [cachedSymbol, cachedModuleSymbol] = symbols.get(id) || emptyArray;
-      if (cachedSymbol && cachedModuleSymbol) {
-        return {
-          symbol: cachedSymbol,
-          moduleSymbol: cachedModuleSymbol,
-          moduleFileName,
-          exportKind,
-          targetFlags,
-          isFromPackageJson
-        };
-      }
-      const checker = (isFromPackageJson ? host.getPackageJsonAutoImportProvider() : host.getCurrentProgram()).getTypeChecker();
-      const moduleSymbol = info.moduleSymbol || cachedModuleSymbol || Debug.checkDefined(info.moduleFile ? checker.getMergedSymbol(info.moduleFile.symbol) : checker.tryFindAmbientModule(info.moduleName));
-      const symbol = info.symbol || cachedSymbol || Debug.checkDefined(
-        exportKind === 2 /* ExportEquals */ ? checker.resolveExternalModuleSymbol(moduleSymbol) : checker.tryGetMemberInModuleExportsAndProperties(unescapeLeadingUnderscores(info.symbolTableKey), moduleSymbol),
-        `Could not find symbol '${info.symbolName}' by key '${info.symbolTableKey}' in module ${moduleSymbol.name}`
-      );
-      symbols.set(id, [symbol, moduleSymbol]);
-      return {
-        symbol,
-        moduleSymbol,
-        moduleFileName,
-        exportKind,
-        targetFlags,
-        isFromPackageJson
-      };
-    }
-    function key(importedName, symbol, ambientModuleName, checker) {
-      const moduleKey = ambientModuleName || "";
-      return `${importedName}|${getSymbolId(skipAlias(symbol, checker))}|${moduleKey}`;
-    }
-    function parseKey(key2) {
-      const symbolName2 = key2.substring(0, key2.indexOf("|"));
-      const moduleKey = key2.substring(key2.lastIndexOf("|") + 1);
-      const ambientModuleName = moduleKey === "" ? void 0 : moduleKey;
-      return { symbolName: symbolName2, ambientModuleName };
-    }
-    function fileIsGlobalOnly(file) {
-      return !file.commonJsModuleIndicator && !file.externalModuleIndicator && !file.moduleAugmentations && !file.ambientModuleNames;
-    }
-    function ambientModuleDeclarationsAreEqual(oldSourceFile, newSourceFile) {
-      if (!arrayIsEqualTo(oldSourceFile.ambientModuleNames, newSourceFile.ambientModuleNames)) {
-        return false;
-      }
-      let oldFileStatementIndex = -1;
-      let newFileStatementIndex = -1;
-      for (const ambientModuleName of newSourceFile.ambientModuleNames) {
-        const isMatchingModuleDeclaration = (node) => isNonGlobalAmbientModule(node) && node.name.text === ambientModuleName;
-        oldFileStatementIndex = findIndex(oldSourceFile.statements, isMatchingModuleDeclaration, oldFileStatementIndex + 1);
-        newFileStatementIndex = findIndex(newSourceFile.statements, isMatchingModuleDeclaration, newFileStatementIndex + 1);
-        if (oldSourceFile.statements[oldFileStatementIndex] !== newSourceFile.statements[newFileStatementIndex]) {
-          return false;
-        }
-      }
-      return true;
-    }
-    function isNotShadowedByDeeperNodeModulesPackage(info, packageName) {
-      if (!packageName || !info.moduleFileName)
-        return true;
-      const typingsCacheLocation = host.getGlobalTypingsCacheLocation();
-      if (typingsCacheLocation && startsWith(info.moduleFileName, typingsCacheLocation))
-        return true;
-      const packageDeepestNodeModulesPath = packages.get(packageName);
-      return !packageDeepestNodeModulesPath || startsWith(info.moduleFileName, packageDeepestNodeModulesPath);
-    }
-  }
-  function isImportableFile(program, from, to, preferences, packageJsonFilter, moduleSpecifierResolutionHost, moduleSpecifierCache) {
-    var _a;
-    if (from === to)
-      return false;
-    const cachedResult = moduleSpecifierCache == null ? void 0 : moduleSpecifierCache.get(from.path, to.path, preferences, {});
-    if ((cachedResult == null ? void 0 : cachedResult.isBlockedByPackageJsonDependencies) !== void 0) {
-      return !cachedResult.isBlockedByPackageJsonDependencies;
-    }
-    const getCanonicalFileName = hostGetCanonicalFileName(moduleSpecifierResolutionHost);
-    const globalTypingsCache = (_a = moduleSpecifierResolutionHost.getGlobalTypingsCacheLocation) == null ? void 0 : _a.call(moduleSpecifierResolutionHost);
-    const hasImportablePath = !!ts_moduleSpecifiers_exports.forEachFileNameOfModule(
-      from.fileName,
-      to.fileName,
-      moduleSpecifierResolutionHost,
-      /*preferSymlinks*/
-      false,
-      (toPath3) => {
-        const toFile = program.getSourceFile(toPath3);
-        return (toFile === to || !toFile) && isImportablePath(from.fileName, toPath3, getCanonicalFileName, globalTypingsCache);
-      }
-    );
-    if (packageJsonFilter) {
-      const isAutoImportable = hasImportablePath && packageJsonFilter.allowsImportingSourceFile(to, moduleSpecifierResolutionHost);
-      moduleSpecifierCache == null ? void 0 : moduleSpecifierCache.setBlockedByPackageJsonDependencies(from.path, to.path, preferences, {}, !isAutoImportable);
-      return isAutoImportable;
-    }
-    return hasImportablePath;
-  }
-  function isImportablePath(fromPath, toPath3, getCanonicalFileName, globalCachePath) {
-    const toNodeModules = forEachAncestorDirectory(toPath3, (ancestor) => getBaseFileName(ancestor) === "node_modules" ? ancestor : void 0);
-    const toNodeModulesParent = toNodeModules && getDirectoryPath(getCanonicalFileName(toNodeModules));
-    return toNodeModulesParent === void 0 || startsWith(getCanonicalFileName(fromPath), toNodeModulesParent) || !!globalCachePath && startsWith(getCanonicalFileName(globalCachePath), toNodeModulesParent);
-  }
-  function forEachExternalModuleToImportFrom(program, host, preferences, useAutoImportProvider, cb) {
-    var _a, _b;
-    const useCaseSensitiveFileNames = hostUsesCaseSensitiveFileNames(host);
-    const excludePatterns = preferences.autoImportFileExcludePatterns && mapDefined(preferences.autoImportFileExcludePatterns, (spec) => {
-      const pattern = getPatternFromSpec(spec, "", "exclude");
-      return pattern ? getRegexFromPattern(pattern, useCaseSensitiveFileNames) : void 0;
-    });
-    forEachExternalModule(program.getTypeChecker(), program.getSourceFiles(), excludePatterns, (module2, file) => cb(
-      module2,
-      file,
-      program,
-      /*isFromPackageJson*/
-      false
-    ));
-    const autoImportProvider = useAutoImportProvider && ((_a = host.getPackageJsonAutoImportProvider) == null ? void 0 : _a.call(host));
-    if (autoImportProvider) {
-      const start = timestamp();
-      const checker = program.getTypeChecker();
-      forEachExternalModule(autoImportProvider.getTypeChecker(), autoImportProvider.getSourceFiles(), excludePatterns, (module2, file) => {
-        if (file && !program.getSourceFile(file.fileName) || !file && !checker.resolveName(
-          module2.name,
-          /*location*/
-          void 0,
-          1536 /* Module */,
-          /*excludeGlobals*/
-          false
-        )) {
-          cb(
-            module2,
-            file,
-            autoImportProvider,
-            /*isFromPackageJson*/
-            true
-          );
-        }
-      });
-      (_b = host.log) == null ? void 0 : _b.call(host, `forEachExternalModuleToImportFrom autoImportProvider: ${timestamp() - start}`);
-    }
-  }
-  function forEachExternalModule(checker, allSourceFiles, excludePatterns, cb) {
-    var _a;
-    const isExcluded = excludePatterns && ((fileName) => excludePatterns.some((p) => p.test(fileName)));
-    for (const ambient of checker.getAmbientModules()) {
-      if (!stringContains(ambient.name, "*") && !(excludePatterns && ((_a = ambient.declarations) == null ? void 0 : _a.every((d) => isExcluded(d.getSourceFile().fileName))))) {
-        cb(
-          ambient,
-          /*sourceFile*/
-          void 0
-        );
-      }
-    }
-    for (const sourceFile of allSourceFiles) {
-      if (isExternalOrCommonJsModule(sourceFile) && !(isExcluded == null ? void 0 : isExcluded(sourceFile.fileName))) {
-        cb(checker.getMergedSymbol(sourceFile.symbol), sourceFile);
-      }
-    }
-  }
-  function getExportInfoMap(importingFile, host, program, preferences, cancellationToken) {
-    var _a, _b, _c, _d, _e;
-    const start = timestamp();
-    (_a = host.getPackageJsonAutoImportProvider) == null ? void 0 : _a.call(host);
-    const cache = ((_b = host.getCachedExportInfoMap) == null ? void 0 : _b.call(host)) || createCacheableExportInfoMap({
-      getCurrentProgram: () => program,
-      getPackageJsonAutoImportProvider: () => {
-        var _a2;
-        return (_a2 = host.getPackageJsonAutoImportProvider) == null ? void 0 : _a2.call(host);
-      },
-      getGlobalTypingsCacheLocation: () => {
-        var _a2;
-        return (_a2 = host.getGlobalTypingsCacheLocation) == null ? void 0 : _a2.call(host);
-      }
-    });
-    if (cache.isUsableByFile(importingFile.path)) {
-      (_c = host.log) == null ? void 0 : _c.call(host, "getExportInfoMap: cache hit");
-      return cache;
-    }
-    (_d = host.log) == null ? void 0 : _d.call(host, "getExportInfoMap: cache miss or empty; calculating new results");
-    const compilerOptions = program.getCompilerOptions();
-    let moduleCount = 0;
-    try {
-      forEachExternalModuleToImportFrom(
-        program,
-        host,
-        preferences,
-        /*useAutoImportProvider*/
-        true,
-        (moduleSymbol, moduleFile, program2, isFromPackageJson) => {
-          if (++moduleCount % 100 === 0)
-            cancellationToken == null ? void 0 : cancellationToken.throwIfCancellationRequested();
-          const seenExports = /* @__PURE__ */ new Map();
-          const checker = program2.getTypeChecker();
-          const defaultInfo = getDefaultLikeExportInfo(moduleSymbol, checker, compilerOptions);
-          if (defaultInfo && isImportableSymbol(defaultInfo.symbol, checker)) {
-            cache.add(
-              importingFile.path,
-              defaultInfo.symbol,
-              defaultInfo.exportKind === 1 /* Default */ ? "default" /* Default */ : "export=" /* ExportEquals */,
-              moduleSymbol,
-              moduleFile,
-              defaultInfo.exportKind,
-              isFromPackageJson,
-              checker
-            );
-          }
-          checker.forEachExportAndPropertyOfModule(moduleSymbol, (exported, key) => {
-            if (exported !== (defaultInfo == null ? void 0 : defaultInfo.symbol) && isImportableSymbol(exported, checker) && addToSeen(seenExports, key)) {
-              cache.add(
-                importingFile.path,
-                exported,
-                key,
-                moduleSymbol,
-                moduleFile,
-                0 /* Named */,
-                isFromPackageJson,
-                checker
-              );
-            }
-          });
-        }
-      );
-    } catch (err) {
-      cache.clear();
-      throw err;
-    }
-    (_e = host.log) == null ? void 0 : _e.call(host, `getExportInfoMap: done in ${timestamp() - start} ms`);
-    return cache;
-  }
-  function getDefaultLikeExportInfo(moduleSymbol, checker, compilerOptions) {
-    const exported = getDefaultLikeExportWorker(moduleSymbol, checker);
-    if (!exported)
-      return void 0;
-    const { symbol, exportKind } = exported;
-    const info = getDefaultExportInfoWorker(symbol, checker, compilerOptions);
-    return info && { symbol, exportKind, ...info };
-  }
-  function isImportableSymbol(symbol, checker) {
-    return !checker.isUndefinedSymbol(symbol) && !checker.isUnknownSymbol(symbol) && !isKnownSymbol(symbol) && !isPrivateIdentifierSymbol(symbol);
-  }
-  function getDefaultLikeExportWorker(moduleSymbol, checker) {
-    const exportEquals = checker.resolveExternalModuleSymbol(moduleSymbol);
-    if (exportEquals !== moduleSymbol)
-      return { symbol: exportEquals, exportKind: 2 /* ExportEquals */ };
-    const defaultExport = checker.tryGetMemberInModuleExports("default" /* Default */, moduleSymbol);
-    if (defaultExport)
-      return { symbol: defaultExport, exportKind: 1 /* Default */ };
-  }
-  function getDefaultExportInfoWorker(defaultExport, checker, compilerOptions) {
-    const localSymbol = getLocalSymbolForExportDefault(defaultExport);
-    if (localSymbol)
-      return { resolvedSymbol: localSymbol, name: localSymbol.name };
-    const name = getNameForExportDefault(defaultExport);
-    if (name !== void 0)
-      return { resolvedSymbol: defaultExport, name };
-    if (defaultExport.flags & 2097152 /* Alias */) {
-      const aliased = checker.getImmediateAliasedSymbol(defaultExport);
-      if (aliased && aliased.parent) {
-        return getDefaultExportInfoWorker(aliased, checker, compilerOptions);
-      }
-    }
-    if (defaultExport.escapedName !== "default" /* Default */ && defaultExport.escapedName !== "export=" /* ExportEquals */) {
-      return { resolvedSymbol: defaultExport, name: defaultExport.getName() };
-    }
-    return { resolvedSymbol: defaultExport, name: getNameForExportedSymbol(defaultExport, compilerOptions.target) };
-  }
-  function getNameForExportDefault(symbol) {
-    return symbol.declarations && firstDefined(symbol.declarations, (declaration) => {
-      var _a;
-      if (isExportAssignment(declaration)) {
-        return (_a = tryCast(skipOuterExpressions(declaration.expression), isIdentifier)) == null ? void 0 : _a.text;
-      } else if (isExportSpecifier(declaration)) {
-        Debug.assert(declaration.name.text === "default" /* Default */, "Expected the specifier to be a default export");
-        return declaration.propertyName && declaration.propertyName.text;
-      }
-    });
-  }
-  var ImportKind, ExportKind;
-  var init_exportInfoMap = __esm({
-    "src/services/exportInfoMap.ts"() {
-      "use strict";
-      init_ts4();
-      ImportKind = /* @__PURE__ */ ((ImportKind2) => {
-        ImportKind2[ImportKind2["Named"] = 0] = "Named";
-        ImportKind2[ImportKind2["Default"] = 1] = "Default";
-        ImportKind2[ImportKind2["Namespace"] = 2] = "Namespace";
-        ImportKind2[ImportKind2["CommonJS"] = 3] = "CommonJS";
-        return ImportKind2;
-      })(ImportKind || {});
-      ExportKind = /* @__PURE__ */ ((ExportKind3) => {
-        ExportKind3[ExportKind3["Named"] = 0] = "Named";
-        ExportKind3[ExportKind3["Default"] = 1] = "Default";
-        ExportKind3[ExportKind3["ExportEquals"] = 2] = "ExportEquals";
-        ExportKind3[ExportKind3["UMD"] = 3] = "UMD";
-        return ExportKind3;
-      })(ExportKind || {});
-    }
-  });
-
-  // src/services/classifier.ts
-  function createClassifier() {
-    const scanner2 = createScanner(
-      99 /* Latest */,
-      /*skipTrivia*/
-      false
-    );
-    function getClassificationsForLine(text, lexState, syntacticClassifierAbsent) {
-      return convertClassificationsToResult(getEncodedLexicalClassifications(text, lexState, syntacticClassifierAbsent), text);
-    }
-    function getEncodedLexicalClassifications(text, lexState, syntacticClassifierAbsent) {
-      let token = 0 /* Unknown */;
-      let lastNonTriviaToken = 0 /* Unknown */;
-      const templateStack = [];
-      const { prefix, pushTemplate } = getPrefixFromLexState(lexState);
-      text = prefix + text;
-      const offset = prefix.length;
-      if (pushTemplate) {
-        templateStack.push(16 /* TemplateHead */);
-      }
-      scanner2.setText(text);
-      let endOfLineState = 0 /* None */;
-      const spans = [];
-      let angleBracketStack = 0;
-      do {
-        token = scanner2.scan();
-        if (!isTrivia(token)) {
-          handleToken();
-          lastNonTriviaToken = token;
-        }
-        const end = scanner2.getTokenEnd();
-        pushEncodedClassification(scanner2.getTokenStart(), end, offset, classFromKind(token), spans);
-        if (end >= text.length) {
-          const end2 = getNewEndOfLineState(scanner2, token, lastOrUndefined(templateStack));
-          if (end2 !== void 0) {
-            endOfLineState = end2;
-          }
-        }
-      } while (token !== 1 /* EndOfFileToken */);
-      function handleToken() {
-        switch (token) {
-          case 44 /* SlashToken */:
-          case 69 /* SlashEqualsToken */:
-            if (!noRegexTable[lastNonTriviaToken] && scanner2.reScanSlashToken() === 14 /* RegularExpressionLiteral */) {
-              token = 14 /* RegularExpressionLiteral */;
-            }
-            break;
-          case 30 /* LessThanToken */:
-            if (lastNonTriviaToken === 80 /* Identifier */) {
-              angleBracketStack++;
-            }
-            break;
-          case 32 /* GreaterThanToken */:
-            if (angleBracketStack > 0) {
-              angleBracketStack--;
-            }
-            break;
-          case 133 /* AnyKeyword */:
-          case 154 /* StringKeyword */:
-          case 150 /* NumberKeyword */:
-          case 136 /* BooleanKeyword */:
-          case 155 /* SymbolKeyword */:
-            if (angleBracketStack > 0 && !syntacticClassifierAbsent) {
-              token = 80 /* Identifier */;
-            }
-            break;
-          case 16 /* TemplateHead */:
-            templateStack.push(token);
-            break;
-          case 19 /* OpenBraceToken */:
-            if (templateStack.length > 0) {
-              templateStack.push(token);
-            }
-            break;
-          case 20 /* CloseBraceToken */:
-            if (templateStack.length > 0) {
-              const lastTemplateStackToken = lastOrUndefined(templateStack);
-              if (lastTemplateStackToken === 16 /* TemplateHead */) {
-                token = scanner2.reScanTemplateToken(
-                  /*isTaggedTemplate*/
-                  false
-                );
-                if (token === 18 /* TemplateTail */) {
-                  templateStack.pop();
-                } else {
-                  Debug.assertEqual(token, 17 /* TemplateMiddle */, "Should have been a template middle.");
-                }
-              } else {
-                Debug.assertEqual(lastTemplateStackToken, 19 /* OpenBraceToken */, "Should have been an open brace");
-                templateStack.pop();
-              }
-            }
-            break;
-          default:
-            if (!isKeyword(token)) {
-              break;
-            }
-            if (lastNonTriviaToken === 25 /* DotToken */) {
-              token = 80 /* Identifier */;
-            } else if (isKeyword(lastNonTriviaToken) && isKeyword(token) && !canFollow(lastNonTriviaToken, token)) {
-              token = 80 /* Identifier */;
-            }
-        }
-      }
-      return { endOfLineState, spans };
-    }
-    return { getClassificationsForLine, getEncodedLexicalClassifications };
-  }
-  function getNewEndOfLineState(scanner2, token, lastOnTemplateStack) {
-    switch (token) {
-      case 11 /* StringLiteral */: {
-        if (!scanner2.isUnterminated())
-          return void 0;
-        const tokenText = scanner2.getTokenText();
-        const lastCharIndex = tokenText.length - 1;
-        let numBackslashes = 0;
-        while (tokenText.charCodeAt(lastCharIndex - numBackslashes) === 92 /* backslash */) {
-          numBackslashes++;
-        }
-        if ((numBackslashes & 1) === 0)
-          return void 0;
-        return tokenText.charCodeAt(0) === 34 /* doubleQuote */ ? 3 /* InDoubleQuoteStringLiteral */ : 2 /* InSingleQuoteStringLiteral */;
-      }
-      case 3 /* MultiLineCommentTrivia */:
-        return scanner2.isUnterminated() ? 1 /* InMultiLineCommentTrivia */ : void 0;
-      default:
-        if (isTemplateLiteralKind(token)) {
-          if (!scanner2.isUnterminated()) {
-            return void 0;
-          }
-          switch (token) {
-            case 18 /* TemplateTail */:
-              return 5 /* InTemplateMiddleOrTail */;
-            case 15 /* NoSubstitutionTemplateLiteral */:
-              return 4 /* InTemplateHeadOrNoSubstitutionTemplate */;
-            default:
-              return Debug.fail("Only 'NoSubstitutionTemplateLiteral's and 'TemplateTail's can be unterminated; got SyntaxKind #" + token);
-          }
-        }
-        return lastOnTemplateStack === 16 /* TemplateHead */ ? 6 /* InTemplateSubstitutionPosition */ : void 0;
-    }
-  }
-  function pushEncodedClassification(start, end, offset, classification, result) {
-    if (classification === 8 /* whiteSpace */) {
-      return;
-    }
-    if (start === 0 && offset > 0) {
-      start += offset;
-    }
-    const length2 = end - start;
-    if (length2 > 0) {
-      result.push(start - offset, length2, classification);
-    }
-  }
-  function convertClassificationsToResult(classifications, text) {
-    const entries = [];
-    const dense = classifications.spans;
-    let lastEnd = 0;
-    for (let i = 0; i < dense.length; i += 3) {
-      const start = dense[i];
-      const length2 = dense[i + 1];
-      const type = dense[i + 2];
-      if (lastEnd >= 0) {
-        const whitespaceLength2 = start - lastEnd;
-        if (whitespaceLength2 > 0) {
-          entries.push({ length: whitespaceLength2, classification: 4 /* Whitespace */ });
-        }
-      }
-      entries.push({ length: length2, classification: convertClassification(type) });
-      lastEnd = start + length2;
-    }
-    const whitespaceLength = text.length - lastEnd;
-    if (whitespaceLength > 0) {
-      entries.push({ length: whitespaceLength, classification: 4 /* Whitespace */ });
-    }
-    return { entries, finalLexState: classifications.endOfLineState };
-  }
-  function convertClassification(type) {
-    switch (type) {
-      case 1 /* comment */:
-        return 3 /* Comment */;
-      case 3 /* keyword */:
-        return 1 /* Keyword */;
-      case 4 /* numericLiteral */:
-        return 6 /* NumberLiteral */;
-      case 25 /* bigintLiteral */:
-        return 7 /* BigIntLiteral */;
-      case 5 /* operator */:
-        return 2 /* Operator */;
-      case 6 /* stringLiteral */:
-        return 8 /* StringLiteral */;
-      case 8 /* whiteSpace */:
-        return 4 /* Whitespace */;
-      case 10 /* punctuation */:
-        return 0 /* Punctuation */;
-      case 2 /* identifier */:
-      case 11 /* className */:
-      case 12 /* enumName */:
-      case 13 /* interfaceName */:
-      case 14 /* moduleName */:
-      case 15 /* typeParameterName */:
-      case 16 /* typeAliasName */:
-      case 9 /* text */:
-      case 17 /* parameterName */:
-        return 5 /* Identifier */;
-      default:
-        return void 0;
-    }
-  }
-  function canFollow(keyword1, keyword2) {
-    if (!isAccessibilityModifier(keyword1)) {
-      return true;
-    }
-    switch (keyword2) {
-      case 139 /* GetKeyword */:
-      case 153 /* SetKeyword */:
-      case 137 /* ConstructorKeyword */:
-      case 126 /* StaticKeyword */:
-      case 129 /* AccessorKeyword */:
-        return true;
-      default:
-        return false;
-    }
-  }
-  function getPrefixFromLexState(lexState) {
-    switch (lexState) {
-      case 3 /* InDoubleQuoteStringLiteral */:
-        return { prefix: '"\\\n' };
-      case 2 /* InSingleQuoteStringLiteral */:
-        return { prefix: "'\\\n" };
-      case 1 /* InMultiLineCommentTrivia */:
-        return { prefix: "/*\n" };
-      case 4 /* InTemplateHeadOrNoSubstitutionTemplate */:
-        return { prefix: "`\n" };
-      case 5 /* InTemplateMiddleOrTail */:
-        return { prefix: "}\n", pushTemplate: true };
-      case 6 /* InTemplateSubstitutionPosition */:
-        return { prefix: "", pushTemplate: true };
-      case 0 /* None */:
-        return { prefix: "" };
-      default:
-        return Debug.assertNever(lexState);
-    }
-  }
-  function isBinaryExpressionOperatorToken(token) {
-    switch (token) {
-      case 42 /* AsteriskToken */:
-      case 44 /* SlashToken */:
-      case 45 /* PercentToken */:
-      case 40 /* PlusToken */:
-      case 41 /* MinusToken */:
-      case 48 /* LessThanLessThanToken */:
-      case 49 /* GreaterThanGreaterThanToken */:
-      case 50 /* GreaterThanGreaterThanGreaterThanToken */:
-      case 30 /* LessThanToken */:
-      case 32 /* GreaterThanToken */:
-      case 33 /* LessThanEqualsToken */:
-      case 34 /* GreaterThanEqualsToken */:
-      case 104 /* InstanceOfKeyword */:
-      case 103 /* InKeyword */:
-      case 130 /* AsKeyword */:
-      case 152 /* SatisfiesKeyword */:
-      case 35 /* EqualsEqualsToken */:
-      case 36 /* ExclamationEqualsToken */:
-      case 37 /* EqualsEqualsEqualsToken */:
-      case 38 /* ExclamationEqualsEqualsToken */:
-      case 51 /* AmpersandToken */:
-      case 53 /* CaretToken */:
-      case 52 /* BarToken */:
-      case 56 /* AmpersandAmpersandToken */:
-      case 57 /* BarBarToken */:
-      case 75 /* BarEqualsToken */:
-      case 74 /* AmpersandEqualsToken */:
-      case 79 /* CaretEqualsToken */:
-      case 71 /* LessThanLessThanEqualsToken */:
-      case 72 /* GreaterThanGreaterThanEqualsToken */:
-      case 73 /* GreaterThanGreaterThanGreaterThanEqualsToken */:
-      case 65 /* PlusEqualsToken */:
-      case 66 /* MinusEqualsToken */:
-      case 67 /* AsteriskEqualsToken */:
-      case 69 /* SlashEqualsToken */:
-      case 70 /* PercentEqualsToken */:
-      case 64 /* EqualsToken */:
-      case 28 /* CommaToken */:
-      case 61 /* QuestionQuestionToken */:
-      case 76 /* BarBarEqualsToken */:
-      case 77 /* AmpersandAmpersandEqualsToken */:
-      case 78 /* QuestionQuestionEqualsToken */:
-        return true;
-      default:
-        return false;
-    }
-  }
-  function isPrefixUnaryExpressionOperatorToken(token) {
-    switch (token) {
-      case 40 /* PlusToken */:
-      case 41 /* MinusToken */:
-      case 55 /* TildeToken */:
-      case 54 /* ExclamationToken */:
-      case 46 /* PlusPlusToken */:
-      case 47 /* MinusMinusToken */:
-        return true;
-      default:
-        return false;
-    }
-  }
-  function classFromKind(token) {
-    if (isKeyword(token)) {
-      return 3 /* keyword */;
-    } else if (isBinaryExpressionOperatorToken(token) || isPrefixUnaryExpressionOperatorToken(token)) {
-      return 5 /* operator */;
-    } else if (token >= 19 /* FirstPunctuation */ && token <= 79 /* LastPunctuation */) {
-      return 10 /* punctuation */;
-    }
-    switch (token) {
-      case 9 /* NumericLiteral */:
-        return 4 /* numericLiteral */;
-      case 10 /* BigIntLiteral */:
-        return 25 /* bigintLiteral */;
-      case 11 /* StringLiteral */:
-        return 6 /* stringLiteral */;
-      case 14 /* RegularExpressionLiteral */:
-        return 7 /* regularExpressionLiteral */;
-      case 7 /* ConflictMarkerTrivia */:
-      case 3 /* MultiLineCommentTrivia */:
-      case 2 /* SingleLineCommentTrivia */:
-        return 1 /* comment */;
-      case 5 /* WhitespaceTrivia */:
-      case 4 /* NewLineTrivia */:
-        return 8 /* whiteSpace */;
-      case 80 /* Identifier */:
-      default:
-        if (isTemplateLiteralKind(token)) {
-          return 6 /* stringLiteral */;
-        }
-        return 2 /* identifier */;
-    }
-  }
-  function getSemanticClassifications(typeChecker, cancellationToken, sourceFile, classifiableNames, span) {
-    return convertClassificationsToSpans(getEncodedSemanticClassifications(typeChecker, cancellationToken, sourceFile, classifiableNames, span));
-  }
-  function checkForClassificationCancellation(cancellationToken, kind) {
-    switch (kind) {
-      case 266 /* ModuleDeclaration */:
-      case 262 /* ClassDeclaration */:
-      case 263 /* InterfaceDeclaration */:
-      case 261 /* FunctionDeclaration */:
-      case 230 /* ClassExpression */:
-      case 217 /* FunctionExpression */:
-      case 218 /* ArrowFunction */:
-        cancellationToken.throwIfCancellationRequested();
-    }
-  }
-  function getEncodedSemanticClassifications(typeChecker, cancellationToken, sourceFile, classifiableNames, span) {
-    const spans = [];
-    sourceFile.forEachChild(function cb(node) {
-      if (!node || !textSpanIntersectsWith(span, node.pos, node.getFullWidth())) {
-        return;
-      }
-      checkForClassificationCancellation(cancellationToken, node.kind);
-      if (isIdentifier(node) && !nodeIsMissing(node) && classifiableNames.has(node.escapedText)) {
-        const symbol = typeChecker.getSymbolAtLocation(node);
-        const type = symbol && classifySymbol(symbol, getMeaningFromLocation(node), typeChecker);
-        if (type) {
-          pushClassification(node.getStart(sourceFile), node.getEnd(), type);
-        }
-      }
-      node.forEachChild(cb);
-    });
-    return { spans, endOfLineState: 0 /* None */ };
-    function pushClassification(start, end, type) {
-      const length2 = end - start;
-      Debug.assert(length2 > 0, `Classification had non-positive length of ${length2}`);
-      spans.push(start);
-      spans.push(length2);
-      spans.push(type);
-    }
-  }
-  function classifySymbol(symbol, meaningAtPosition, checker) {
-    const flags = symbol.getFlags();
-    if ((flags & 2885600 /* Classifiable */) === 0 /* None */) {
-      return void 0;
-    } else if (flags & 32 /* Class */) {
-      return 11 /* className */;
-    } else if (flags & 384 /* Enum */) {
-      return 12 /* enumName */;
-    } else if (flags & 524288 /* TypeAlias */) {
-      return 16 /* typeAliasName */;
-    } else if (flags & 1536 /* Module */) {
-      return meaningAtPosition & 4 /* Namespace */ || meaningAtPosition & 1 /* Value */ && hasValueSideModule(symbol) ? 14 /* moduleName */ : void 0;
-    } else if (flags & 2097152 /* Alias */) {
-      return classifySymbol(checker.getAliasedSymbol(symbol), meaningAtPosition, checker);
-    } else if (meaningAtPosition & 2 /* Type */) {
-      return flags & 64 /* Interface */ ? 13 /* interfaceName */ : flags & 262144 /* TypeParameter */ ? 15 /* typeParameterName */ : void 0;
-    } else {
-      return void 0;
-    }
-  }
-  function hasValueSideModule(symbol) {
-    return some(symbol.declarations, (declaration) => isModuleDeclaration(declaration) && getModuleInstanceState(declaration) === 1 /* Instantiated */);
-  }
-  function getClassificationTypeName(type) {
-    switch (type) {
-      case 1 /* comment */:
-        return "comment" /* comment */;
-      case 2 /* identifier */:
-        return "identifier" /* identifier */;
-      case 3 /* keyword */:
-        return "keyword" /* keyword */;
-      case 4 /* numericLiteral */:
-        return "number" /* numericLiteral */;
-      case 25 /* bigintLiteral */:
-        return "bigint" /* bigintLiteral */;
-      case 5 /* operator */:
-        return "operator" /* operator */;
-      case 6 /* stringLiteral */:
-        return "string" /* stringLiteral */;
-      case 8 /* whiteSpace */:
-        return "whitespace" /* whiteSpace */;
-      case 9 /* text */:
-        return "text" /* text */;
-      case 10 /* punctuation */:
-        return "punctuation" /* punctuation */;
-      case 11 /* className */:
-        return "class name" /* className */;
-      case 12 /* enumName */:
-        return "enum name" /* enumName */;
-      case 13 /* interfaceName */:
-        return "interface name" /* interfaceName */;
-      case 14 /* moduleName */:
-        return "module name" /* moduleName */;
-      case 15 /* typeParameterName */:
-        return "type parameter name" /* typeParameterName */;
-      case 16 /* typeAliasName */:
-        return "type alias name" /* typeAliasName */;
-      case 17 /* parameterName */:
-        return "parameter name" /* parameterName */;
-      case 18 /* docCommentTagName */:
-        return "doc comment tag name" /* docCommentTagName */;
-      case 19 /* jsxOpenTagName */:
-        return "jsx open tag name" /* jsxOpenTagName */;
-      case 20 /* jsxCloseTagName */:
-        return "jsx close tag name" /* jsxCloseTagName */;
-      case 21 /* jsxSelfClosingTagName */:
-        return "jsx self closing tag name" /* jsxSelfClosingTagName */;
-      case 22 /* jsxAttribute */:
-        return "jsx attribute" /* jsxAttribute */;
-      case 23 /* jsxText */:
-        return "jsx text" /* jsxText */;
-      case 24 /* jsxAttributeStringLiteralValue */:
-        return "jsx attribute string literal value" /* jsxAttributeStringLiteralValue */;
-      default:
-        return void 0;
-    }
-  }
-  function convertClassificationsToSpans(classifications) {
-    Debug.assert(classifications.spans.length % 3 === 0);
-    const dense = classifications.spans;
-    const result = [];
-    for (let i = 0; i < dense.length; i += 3) {
-      result.push({
-        textSpan: createTextSpan(dense[i], dense[i + 1]),
-        classificationType: getClassificationTypeName(dense[i + 2])
-      });
-    }
-    return result;
-  }
-  function getSyntacticClassifications(cancellationToken, sourceFile, span) {
-    return convertClassificationsToSpans(getEncodedSyntacticClassifications(cancellationToken, sourceFile, span));
-  }
-  function getEncodedSyntacticClassifications(cancellationToken, sourceFile, span) {
-    const spanStart = span.start;
-    const spanLength = span.length;
-    const triviaScanner = createScanner(
-      99 /* Latest */,
-      /*skipTrivia*/
-      false,
-      sourceFile.languageVariant,
-      sourceFile.text
-    );
-    const mergeConflictScanner = createScanner(
-      99 /* Latest */,
-      /*skipTrivia*/
-      false,
-      sourceFile.languageVariant,
-      sourceFile.text
-    );
-    const result = [];
-    processElement(sourceFile);
-    return { spans: result, endOfLineState: 0 /* None */ };
-    function pushClassification(start, length2, type) {
-      result.push(start);
-      result.push(length2);
-      result.push(type);
-    }
-    function classifyLeadingTriviaAndGetTokenStart(token) {
-      triviaScanner.resetTokenState(token.pos);
-      while (true) {
-        const start = triviaScanner.getTokenEnd();
-        if (!couldStartTrivia(sourceFile.text, start)) {
-          return start;
-        }
-        const kind = triviaScanner.scan();
-        const end = triviaScanner.getTokenEnd();
-        const width = end - start;
-        if (!isTrivia(kind)) {
-          return start;
-        }
-        switch (kind) {
-          case 4 /* NewLineTrivia */:
-          case 5 /* WhitespaceTrivia */:
-            continue;
-          case 2 /* SingleLineCommentTrivia */:
-          case 3 /* MultiLineCommentTrivia */:
-            classifyComment(token, kind, start, width);
-            triviaScanner.resetTokenState(end);
-            continue;
-          case 7 /* ConflictMarkerTrivia */:
-            const text = sourceFile.text;
-            const ch = text.charCodeAt(start);
-            if (ch === 60 /* lessThan */ || ch === 62 /* greaterThan */) {
-              pushClassification(start, width, 1 /* comment */);
-              continue;
-            }
-            Debug.assert(ch === 124 /* bar */ || ch === 61 /* equals */);
-            classifyDisabledMergeCode(text, start, end);
-            break;
-          case 6 /* ShebangTrivia */:
-            break;
-          default:
-            Debug.assertNever(kind);
-        }
-      }
-    }
-    function classifyComment(token, kind, start, width) {
-      if (kind === 3 /* MultiLineCommentTrivia */) {
-        const docCommentAndDiagnostics = parseIsolatedJSDocComment(sourceFile.text, start, width);
-        if (docCommentAndDiagnostics && docCommentAndDiagnostics.jsDoc) {
-          setParent(docCommentAndDiagnostics.jsDoc, token);
-          classifyJSDocComment(docCommentAndDiagnostics.jsDoc);
-          return;
-        }
-      } else if (kind === 2 /* SingleLineCommentTrivia */) {
-        if (tryClassifyTripleSlashComment(start, width)) {
-          return;
-        }
-      }
-      pushCommentRange(start, width);
-    }
-    function pushCommentRange(start, width) {
-      pushClassification(start, width, 1 /* comment */);
-    }
-    function classifyJSDocComment(docComment) {
-      var _a, _b, _c, _d, _e, _f, _g, _h;
-      let pos = docComment.pos;
-      if (docComment.tags) {
-        for (const tag of docComment.tags) {
-          if (tag.pos !== pos) {
-            pushCommentRange(pos, tag.pos - pos);
-          }
-          pushClassification(tag.pos, 1, 10 /* punctuation */);
-          pushClassification(tag.tagName.pos, tag.tagName.end - tag.tagName.pos, 18 /* docCommentTagName */);
-          pos = tag.tagName.end;
-          let commentStart = tag.tagName.end;
-          switch (tag.kind) {
-            case 347 /* JSDocParameterTag */:
-              const param = tag;
-              processJSDocParameterTag(param);
-              commentStart = param.isNameFirst && ((_a = param.typeExpression) == null ? void 0 : _a.end) || param.name.end;
-              break;
-            case 354 /* JSDocPropertyTag */:
-              const prop = tag;
-              commentStart = prop.isNameFirst && ((_b = prop.typeExpression) == null ? void 0 : _b.end) || prop.name.end;
-              break;
-            case 351 /* JSDocTemplateTag */:
-              processJSDocTemplateTag(tag);
-              pos = tag.end;
-              commentStart = tag.typeParameters.end;
-              break;
-            case 352 /* JSDocTypedefTag */:
-              const type = tag;
-              commentStart = ((_c = type.typeExpression) == null ? void 0 : _c.kind) === 315 /* JSDocTypeExpression */ && ((_d = type.fullName) == null ? void 0 : _d.end) || ((_e = type.typeExpression) == null ? void 0 : _e.end) || commentStart;
-              break;
-            case 344 /* JSDocCallbackTag */:
-              commentStart = tag.typeExpression.end;
-              break;
-            case 350 /* JSDocTypeTag */:
-              processElement(tag.typeExpression);
-              pos = tag.end;
-              commentStart = tag.typeExpression.end;
-              break;
-            case 349 /* JSDocThisTag */:
-            case 346 /* JSDocEnumTag */:
-              commentStart = tag.typeExpression.end;
-              break;
-            case 348 /* JSDocReturnTag */:
-              processElement(tag.typeExpression);
-              pos = tag.end;
-              commentStart = ((_f = tag.typeExpression) == null ? void 0 : _f.end) || commentStart;
-              break;
-            case 353 /* JSDocSeeTag */:
-              commentStart = ((_g = tag.name) == null ? void 0 : _g.end) || commentStart;
-              break;
-            case 334 /* JSDocAugmentsTag */:
-            case 335 /* JSDocImplementsTag */:
-              commentStart = tag.class.end;
-              break;
-            case 355 /* JSDocThrowsTag */:
-              processElement(tag.typeExpression);
-              pos = tag.end;
-              commentStart = ((_h = tag.typeExpression) == null ? void 0 : _h.end) || commentStart;
-              break;
-          }
-          if (typeof tag.comment === "object") {
-            pushCommentRange(tag.comment.pos, tag.comment.end - tag.comment.pos);
-          } else if (typeof tag.comment === "string") {
-            pushCommentRange(commentStart, tag.end - commentStart);
-          }
-        }
-      }
-      if (pos !== docComment.end) {
-        pushCommentRange(pos, docComment.end - pos);
-      }
-      return;
-      function processJSDocParameterTag(tag) {
-        if (tag.isNameFirst) {
-          pushCommentRange(pos, tag.name.pos - pos);
-          pushClassification(tag.name.pos, tag.name.end - tag.name.pos, 17 /* parameterName */);
-          pos = tag.name.end;
-        }
-        if (tag.typeExpression) {
-          pushCommentRange(pos, tag.typeExpression.pos - pos);
-          processElement(tag.typeExpression);
-          pos = tag.typeExpression.end;
-        }
-        if (!tag.isNameFirst) {
-          pushCommentRange(pos, tag.name.pos - pos);
-          pushClassification(tag.name.pos, tag.name.end - tag.name.pos, 17 /* parameterName */);
-          pos = tag.name.end;
-        }
-      }
-    }
-    function tryClassifyTripleSlashComment(start, width) {
-      const tripleSlashXMLCommentRegEx = /^(\/\/\/\s*)(<)(?:(\S+)((?:[^/]|\/[^>])*)(\/>)?)?/im;
-      const attributeRegex = /(\s)(\S+)(\s*)(=)(\s*)('[^']+'|"[^"]+")/img;
-      const text = sourceFile.text.substr(start, width);
-      const match = tripleSlashXMLCommentRegEx.exec(text);
-      if (!match) {
-        return false;
-      }
-      if (!match[3] || !(match[3] in commentPragmas)) {
-        return false;
-      }
-      let pos = start;
-      pushCommentRange(pos, match[1].length);
-      pos += match[1].length;
-      pushClassification(pos, match[2].length, 10 /* punctuation */);
-      pos += match[2].length;
-      pushClassification(pos, match[3].length, 21 /* jsxSelfClosingTagName */);
-      pos += match[3].length;
-      const attrText = match[4];
-      let attrPos = pos;
-      while (true) {
-        const attrMatch = attributeRegex.exec(attrText);
-        if (!attrMatch) {
-          break;
-        }
-        const newAttrPos = pos + attrMatch.index + attrMatch[1].length;
-        if (newAttrPos > attrPos) {
-          pushCommentRange(attrPos, newAttrPos - attrPos);
-          attrPos = newAttrPos;
-        }
-        pushClassification(attrPos, attrMatch[2].length, 22 /* jsxAttribute */);
-        attrPos += attrMatch[2].length;
-        if (attrMatch[3].length) {
-          pushCommentRange(attrPos, attrMatch[3].length);
-          attrPos += attrMatch[3].length;
-        }
-        pushClassification(attrPos, attrMatch[4].length, 5 /* operator */);
-        attrPos += attrMatch[4].length;
-        if (attrMatch[5].length) {
-          pushCommentRange(attrPos, attrMatch[5].length);
-          attrPos += attrMatch[5].length;
-        }
-        pushClassification(attrPos, attrMatch[6].length, 24 /* jsxAttributeStringLiteralValue */);
-        attrPos += attrMatch[6].length;
-      }
-      pos += match[4].length;
-      if (pos > attrPos) {
-        pushCommentRange(attrPos, pos - attrPos);
-      }
-      if (match[5]) {
-        pushClassification(pos, match[5].length, 10 /* punctuation */);
-        pos += match[5].length;
-      }
-      const end = start + width;
-      if (pos < end) {
-        pushCommentRange(pos, end - pos);
-      }
-      return true;
-    }
-    function processJSDocTemplateTag(tag) {
-      for (const child of tag.getChildren()) {
-        processElement(child);
-      }
-    }
-    function classifyDisabledMergeCode(text, start, end) {
-      let i;
-      for (i = start; i < end; i++) {
-        if (isLineBreak(text.charCodeAt(i))) {
-          break;
-        }
-      }
-      pushClassification(start, i - start, 1 /* comment */);
-      mergeConflictScanner.resetTokenState(i);
-      while (mergeConflictScanner.getTokenEnd() < end) {
-        classifyDisabledCodeToken();
-      }
-    }
-    function classifyDisabledCodeToken() {
-      const start = mergeConflictScanner.getTokenEnd();
-      const tokenKind = mergeConflictScanner.scan();
-      const end = mergeConflictScanner.getTokenEnd();
-      const type = classifyTokenType(tokenKind);
-      if (type) {
-        pushClassification(start, end - start, type);
-      }
-    }
-    function tryClassifyNode(node) {
-      if (isJSDoc(node)) {
-        return true;
-      }
-      if (nodeIsMissing(node)) {
-        return true;
-      }
-      const classifiedElementName = tryClassifyJsxElementName(node);
-      if (!isToken(node) && node.kind !== 12 /* JsxText */ && classifiedElementName === void 0) {
-        return false;
-      }
-      const tokenStart = node.kind === 12 /* JsxText */ ? node.pos : classifyLeadingTriviaAndGetTokenStart(node);
-      const tokenWidth = node.end - tokenStart;
-      Debug.assert(tokenWidth >= 0);
-      if (tokenWidth > 0) {
-        const type = classifiedElementName || classifyTokenType(node.kind, node);
-        if (type) {
-          pushClassification(tokenStart, tokenWidth, type);
-        }
-      }
-      return true;
-    }
-    function tryClassifyJsxElementName(token) {
-      switch (token.parent && token.parent.kind) {
-        case 285 /* JsxOpeningElement */:
-          if (token.parent.tagName === token) {
-            return 19 /* jsxOpenTagName */;
-          }
-          break;
-        case 286 /* JsxClosingElement */:
-          if (token.parent.tagName === token) {
-            return 20 /* jsxCloseTagName */;
-          }
-          break;
-        case 284 /* JsxSelfClosingElement */:
-          if (token.parent.tagName === token) {
-            return 21 /* jsxSelfClosingTagName */;
-          }
-          break;
-        case 290 /* JsxAttribute */:
-          if (token.parent.name === token) {
-            return 22 /* jsxAttribute */;
-          }
-          break;
-      }
-      return void 0;
-    }
-    function classifyTokenType(tokenKind, token) {
-      if (isKeyword(tokenKind)) {
-        return 3 /* keyword */;
-      }
-      if (tokenKind === 30 /* LessThanToken */ || tokenKind === 32 /* GreaterThanToken */) {
-        if (token && getTypeArgumentOrTypeParameterList(token.parent)) {
-          return 10 /* punctuation */;
-        }
-      }
-      if (isPunctuation(tokenKind)) {
-        if (token) {
-          const parent2 = token.parent;
-          if (tokenKind === 64 /* EqualsToken */) {
-            if (parent2.kind === 259 /* VariableDeclaration */ || parent2.kind === 171 /* PropertyDeclaration */ || parent2.kind === 168 /* Parameter */ || parent2.kind === 290 /* JsxAttribute */) {
-              return 5 /* operator */;
-            }
-          }
-          if (parent2.kind === 225 /* BinaryExpression */ || parent2.kind === 223 /* PrefixUnaryExpression */ || parent2.kind === 224 /* PostfixUnaryExpression */ || parent2.kind === 226 /* ConditionalExpression */) {
-            return 5 /* operator */;
-          }
-        }
-        return 10 /* punctuation */;
-      } else if (tokenKind === 9 /* NumericLiteral */) {
-        return 4 /* numericLiteral */;
-      } else if (tokenKind === 10 /* BigIntLiteral */) {
-        return 25 /* bigintLiteral */;
-      } else if (tokenKind === 11 /* StringLiteral */) {
-        return token && token.parent.kind === 290 /* JsxAttribute */ ? 24 /* jsxAttributeStringLiteralValue */ : 6 /* stringLiteral */;
-      } else if (tokenKind === 14 /* RegularExpressionLiteral */) {
-        return 6 /* stringLiteral */;
-      } else if (isTemplateLiteralKind(tokenKind)) {
-        return 6 /* stringLiteral */;
-      } else if (tokenKind === 12 /* JsxText */) {
-        return 23 /* jsxText */;
-      } else if (tokenKind === 80 /* Identifier */) {
-        if (token) {
-          switch (token.parent.kind) {
-            case 262 /* ClassDeclaration */:
-              if (token.parent.name === token) {
-                return 11 /* className */;
-              }
-              return;
-            case 167 /* TypeParameter */:
-              if (token.parent.name === token) {
-                return 15 /* typeParameterName */;
-              }
-              return;
-            case 263 /* InterfaceDeclaration */:
-              if (token.parent.name === token) {
-                return 13 /* interfaceName */;
-              }
-              return;
-            case 265 /* EnumDeclaration */:
-              if (token.parent.name === token) {
-                return 12 /* enumName */;
-              }
-              return;
-            case 266 /* ModuleDeclaration */:
-              if (token.parent.name === token) {
-                return 14 /* moduleName */;
-              }
-              return;
-            case 168 /* Parameter */:
-              if (token.parent.name === token) {
-                return isThisIdentifier(token) ? 3 /* keyword */ : 17 /* parameterName */;
-              }
-              return;
-          }
-          if (isConstTypeReference(token.parent)) {
-            return 3 /* keyword */;
-          }
-        }
-        return 2 /* identifier */;
-      }
-    }
-    function processElement(element) {
-      if (!element) {
-        return;
-      }
-      if (decodedTextSpanIntersectsWith(spanStart, spanLength, element.pos, element.getFullWidth())) {
-        checkForClassificationCancellation(cancellationToken, element.kind);
-        for (const child of element.getChildren(sourceFile)) {
-          if (!tryClassifyNode(child)) {
-            processElement(child);
-          }
-        }
-      }
-    }
-  }
-  var noRegexTable;
-  var init_classifier = __esm({
-    "src/services/classifier.ts"() {
-      "use strict";
-      init_ts4();
-      noRegexTable = arrayToNumericMap([
-        80 /* Identifier */,
-        11 /* StringLiteral */,
-        9 /* NumericLiteral */,
-        10 /* BigIntLiteral */,
-        14 /* RegularExpressionLiteral */,
-        110 /* ThisKeyword */,
-        46 /* PlusPlusToken */,
-        47 /* MinusMinusToken */,
-        22 /* CloseParenToken */,
-        24 /* CloseBracketToken */,
-        20 /* CloseBraceToken */,
-        112 /* TrueKeyword */,
-        97 /* FalseKeyword */
-      ], (token) => token, () => true);
-    }
-  });
-
-  // src/services/documentHighlights.ts
-  var DocumentHighlights;
-  var init_documentHighlights = __esm({
-    "src/services/documentHighlights.ts"() {
-      "use strict";
-      init_ts4();
-      ((DocumentHighlights2) => {
-        function getDocumentHighlights(program, cancellationToken, sourceFile, position, sourceFilesToSearch) {
-          const node = getTouchingPropertyName(sourceFile, position);
-          if (node.parent && (isJsxOpeningElement(node.parent) && node.parent.tagName === node || isJsxClosingElement(node.parent))) {
-            const { openingElement, closingElement } = node.parent.parent;
-            const highlightSpans = [openingElement, closingElement].map(({ tagName }) => getHighlightSpanForNode(tagName, sourceFile));
-            return [{ fileName: sourceFile.fileName, highlightSpans }];
-          }
-          return getSemanticDocumentHighlights(position, node, program, cancellationToken, sourceFilesToSearch) || getSyntacticDocumentHighlights(node, sourceFile);
-        }
-        DocumentHighlights2.getDocumentHighlights = getDocumentHighlights;
-        function getHighlightSpanForNode(node, sourceFile) {
-          return {
-            fileName: sourceFile.fileName,
-            textSpan: createTextSpanFromNode(node, sourceFile),
-            kind: "none" /* none */
-          };
-        }
-        function getSemanticDocumentHighlights(position, node, program, cancellationToken, sourceFilesToSearch) {
-          const sourceFilesSet = new Set(sourceFilesToSearch.map((f) => f.fileName));
-          const referenceEntries = ts_FindAllReferences_exports.getReferenceEntriesForNode(
-            position,
-            node,
-            program,
-            sourceFilesToSearch,
-            cancellationToken,
-            /*options*/
-            void 0,
-            sourceFilesSet
-          );
-          if (!referenceEntries)
-            return void 0;
-          const map2 = arrayToMultiMap(referenceEntries.map(ts_FindAllReferences_exports.toHighlightSpan), (e) => e.fileName, (e) => e.span);
-          const getCanonicalFileName = createGetCanonicalFileName(program.useCaseSensitiveFileNames());
-          return arrayFrom(mapDefinedIterator(map2.entries(), ([fileName, highlightSpans]) => {
-            if (!sourceFilesSet.has(fileName)) {
-              if (!program.redirectTargetsMap.has(toPath(fileName, program.getCurrentDirectory(), getCanonicalFileName))) {
-                return void 0;
-              }
-              const redirectTarget = program.getSourceFile(fileName);
-              const redirect = find(sourceFilesToSearch, (f) => !!f.redirectInfo && f.redirectInfo.redirectTarget === redirectTarget);
-              fileName = redirect.fileName;
-              Debug.assert(sourceFilesSet.has(fileName));
-            }
-            return { fileName, highlightSpans };
-          }));
-        }
-        function getSyntacticDocumentHighlights(node, sourceFile) {
-          const highlightSpans = getHighlightSpans(node, sourceFile);
-          return highlightSpans && [{ fileName: sourceFile.fileName, highlightSpans }];
-        }
-        function getHighlightSpans(node, sourceFile) {
-          switch (node.kind) {
-            case 101 /* IfKeyword */:
-            case 93 /* ElseKeyword */:
-              return isIfStatement(node.parent) ? getIfElseOccurrences(node.parent, sourceFile) : void 0;
-            case 107 /* ReturnKeyword */:
-              return useParent(node.parent, isReturnStatement, getReturnOccurrences);
-            case 111 /* ThrowKeyword */:
-              return useParent(node.parent, isThrowStatement, getThrowOccurrences);
-            case 113 /* TryKeyword */:
-            case 85 /* CatchKeyword */:
-            case 98 /* FinallyKeyword */:
-              const tryStatement = node.kind === 85 /* CatchKeyword */ ? node.parent.parent : node.parent;
-              return useParent(tryStatement, isTryStatement, getTryCatchFinallyOccurrences);
-            case 109 /* SwitchKeyword */:
-              return useParent(node.parent, isSwitchStatement, getSwitchCaseDefaultOccurrences);
-            case 84 /* CaseKeyword */:
-            case 90 /* DefaultKeyword */: {
-              if (isDefaultClause(node.parent) || isCaseClause(node.parent)) {
-                return useParent(node.parent.parent.parent, isSwitchStatement, getSwitchCaseDefaultOccurrences);
-              }
-              return void 0;
-            }
-            case 83 /* BreakKeyword */:
-            case 88 /* ContinueKeyword */:
-              return useParent(node.parent, isBreakOrContinueStatement, getBreakOrContinueStatementOccurrences);
-            case 99 /* ForKeyword */:
-            case 117 /* WhileKeyword */:
-            case 92 /* DoKeyword */:
-              return useParent(node.parent, (n) => isIterationStatement(
-                n,
-                /*lookInLabeledStatements*/
-                true
-              ), getLoopBreakContinueOccurrences);
-            case 137 /* ConstructorKeyword */:
-              return getFromAllDeclarations(isConstructorDeclaration, [137 /* ConstructorKeyword */]);
-            case 139 /* GetKeyword */:
-            case 153 /* SetKeyword */:
-              return getFromAllDeclarations(isAccessor, [139 /* GetKeyword */, 153 /* SetKeyword */]);
-            case 135 /* AwaitKeyword */:
-              return useParent(node.parent, isAwaitExpression, getAsyncAndAwaitOccurrences);
-            case 134 /* AsyncKeyword */:
-              return highlightSpans(getAsyncAndAwaitOccurrences(node));
-            case 127 /* YieldKeyword */:
-              return highlightSpans(getYieldOccurrences(node));
-            case 103 /* InKeyword */:
-              return void 0;
-            default:
-              return isModifierKind(node.kind) && (isDeclaration(node.parent) || isVariableStatement(node.parent)) ? highlightSpans(getModifierOccurrences(node.kind, node.parent)) : void 0;
-          }
-          function getFromAllDeclarations(nodeTest, keywords) {
-            return useParent(node.parent, nodeTest, (decl) => {
-              var _a;
-              return mapDefined((_a = tryCast(decl, canHaveSymbol)) == null ? void 0 : _a.symbol.declarations, (d) => nodeTest(d) ? find(d.getChildren(sourceFile), (c) => contains(keywords, c.kind)) : void 0);
-            });
-          }
-          function useParent(node2, nodeTest, getNodes4) {
-            return nodeTest(node2) ? highlightSpans(getNodes4(node2, sourceFile)) : void 0;
-          }
-          function highlightSpans(nodes) {
-            return nodes && nodes.map((node2) => getHighlightSpanForNode(node2, sourceFile));
-          }
-        }
-        function aggregateOwnedThrowStatements(node) {
-          if (isThrowStatement(node)) {
-            return [node];
-          } else if (isTryStatement(node)) {
-            return concatenate(
-              node.catchClause ? aggregateOwnedThrowStatements(node.catchClause) : node.tryBlock && aggregateOwnedThrowStatements(node.tryBlock),
-              node.finallyBlock && aggregateOwnedThrowStatements(node.finallyBlock)
-            );
-          }
-          return isFunctionLike(node) ? void 0 : flatMapChildren(node, aggregateOwnedThrowStatements);
-        }
-        function getThrowStatementOwner(throwStatement) {
-          let child = throwStatement;
-          while (child.parent) {
-            const parent2 = child.parent;
-            if (isFunctionBlock(parent2) || parent2.kind === 311 /* SourceFile */) {
-              return parent2;
-            }
-            if (isTryStatement(parent2) && parent2.tryBlock === child && parent2.catchClause) {
-              return child;
-            }
-            child = parent2;
-          }
-          return void 0;
-        }
-        function aggregateAllBreakAndContinueStatements(node) {
-          return isBreakOrContinueStatement(node) ? [node] : isFunctionLike(node) ? void 0 : flatMapChildren(node, aggregateAllBreakAndContinueStatements);
-        }
-        function flatMapChildren(node, cb) {
-          const result = [];
-          node.forEachChild((child) => {
-            const value = cb(child);
-            if (value !== void 0) {
-              result.push(...toArray(value));
-            }
-          });
-          return result;
-        }
-        function ownsBreakOrContinueStatement(owner, statement) {
-          const actualOwner = getBreakOrContinueOwner(statement);
-          return !!actualOwner && actualOwner === owner;
-        }
-        function getBreakOrContinueOwner(statement) {
-          return findAncestor(statement, (node) => {
-            switch (node.kind) {
-              case 254 /* SwitchStatement */:
-                if (statement.kind === 250 /* ContinueStatement */) {
-                  return false;
-                }
-              case 247 /* ForStatement */:
-              case 248 /* ForInStatement */:
-              case 249 /* ForOfStatement */:
-              case 246 /* WhileStatement */:
-              case 245 /* DoStatement */:
-                return !statement.label || isLabeledBy(node, statement.label.escapedText);
-              default:
-                return isFunctionLike(node) && "quit";
-            }
-          });
-        }
-        function getModifierOccurrences(modifier, declaration) {
-          return mapDefined(getNodesToSearchForModifier(declaration, modifierToFlag(modifier)), (node) => findModifier(node, modifier));
-        }
-        function getNodesToSearchForModifier(declaration, modifierFlag) {
-          const container = declaration.parent;
-          switch (container.kind) {
-            case 267 /* ModuleBlock */:
-            case 311 /* SourceFile */:
-            case 240 /* Block */:
-            case 295 /* CaseClause */:
-            case 296 /* DefaultClause */:
-              if (modifierFlag & 256 /* Abstract */ && isClassDeclaration(declaration)) {
-                return [...declaration.members, declaration];
-              } else {
-                return container.statements;
-              }
-            case 175 /* Constructor */:
-            case 173 /* MethodDeclaration */:
-            case 261 /* FunctionDeclaration */:
-              return [...container.parameters, ...isClassLike(container.parent) ? container.parent.members : []];
-            case 262 /* ClassDeclaration */:
-            case 230 /* ClassExpression */:
-            case 263 /* InterfaceDeclaration */:
-            case 186 /* TypeLiteral */:
-              const nodes = container.members;
-              if (modifierFlag & (28 /* AccessibilityModifier */ | 64 /* Readonly */)) {
-                const constructor = find(container.members, isConstructorDeclaration);
-                if (constructor) {
-                  return [...nodes, ...constructor.parameters];
-                }
-              } else if (modifierFlag & 256 /* Abstract */) {
-                return [...nodes, container];
-              }
-              return nodes;
-            case 209 /* ObjectLiteralExpression */:
-              return void 0;
-            default:
-              Debug.assertNever(container, "Invalid container kind.");
-          }
-        }
-        function pushKeywordIf(keywordList, token, ...expected) {
-          if (token && contains(expected, token.kind)) {
-            keywordList.push(token);
-            return true;
-          }
-          return false;
-        }
-        function getLoopBreakContinueOccurrences(loopNode) {
-          const keywords = [];
-          if (pushKeywordIf(keywords, loopNode.getFirstToken(), 99 /* ForKeyword */, 117 /* WhileKeyword */, 92 /* DoKeyword */)) {
-            if (loopNode.kind === 245 /* DoStatement */) {
-              const loopTokens = loopNode.getChildren();
-              for (let i = loopTokens.length - 1; i >= 0; i--) {
-                if (pushKeywordIf(keywords, loopTokens[i], 117 /* WhileKeyword */)) {
-                  break;
-                }
-              }
-            }
-          }
-          forEach(aggregateAllBreakAndContinueStatements(loopNode.statement), (statement) => {
-            if (ownsBreakOrContinueStatement(loopNode, statement)) {
-              pushKeywordIf(keywords, statement.getFirstToken(), 83 /* BreakKeyword */, 88 /* ContinueKeyword */);
-            }
-          });
-          return keywords;
-        }
-        function getBreakOrContinueStatementOccurrences(breakOrContinueStatement) {
-          const owner = getBreakOrContinueOwner(breakOrContinueStatement);
-          if (owner) {
-            switch (owner.kind) {
-              case 247 /* ForStatement */:
-              case 248 /* ForInStatement */:
-              case 249 /* ForOfStatement */:
-              case 245 /* DoStatement */:
-              case 246 /* WhileStatement */:
-                return getLoopBreakContinueOccurrences(owner);
-              case 254 /* SwitchStatement */:
-                return getSwitchCaseDefaultOccurrences(owner);
-            }
-          }
-          return void 0;
-        }
-        function getSwitchCaseDefaultOccurrences(switchStatement) {
-          const keywords = [];
-          pushKeywordIf(keywords, switchStatement.getFirstToken(), 109 /* SwitchKeyword */);
-          forEach(switchStatement.caseBlock.clauses, (clause) => {
-            pushKeywordIf(keywords, clause.getFirstToken(), 84 /* CaseKeyword */, 90 /* DefaultKeyword */);
-            forEach(aggregateAllBreakAndContinueStatements(clause), (statement) => {
-              if (ownsBreakOrContinueStatement(switchStatement, statement)) {
-                pushKeywordIf(keywords, statement.getFirstToken(), 83 /* BreakKeyword */);
-              }
-            });
-          });
-          return keywords;
-        }
-        function getTryCatchFinallyOccurrences(tryStatement, sourceFile) {
-          const keywords = [];
-          pushKeywordIf(keywords, tryStatement.getFirstToken(), 113 /* TryKeyword */);
-          if (tryStatement.catchClause) {
-            pushKeywordIf(keywords, tryStatement.catchClause.getFirstToken(), 85 /* CatchKeyword */);
-          }
-          if (tryStatement.finallyBlock) {
-            const finallyKeyword = findChildOfKind(tryStatement, 98 /* FinallyKeyword */, sourceFile);
-            pushKeywordIf(keywords, finallyKeyword, 98 /* FinallyKeyword */);
-          }
-          return keywords;
-        }
-        function getThrowOccurrences(throwStatement, sourceFile) {
-          const owner = getThrowStatementOwner(throwStatement);
-          if (!owner) {
-            return void 0;
-          }
-          const keywords = [];
-          forEach(aggregateOwnedThrowStatements(owner), (throwStatement2) => {
-            keywords.push(findChildOfKind(throwStatement2, 111 /* ThrowKeyword */, sourceFile));
-          });
-          if (isFunctionBlock(owner)) {
-            forEachReturnStatement(owner, (returnStatement) => {
-              keywords.push(findChildOfKind(returnStatement, 107 /* ReturnKeyword */, sourceFile));
-            });
-          }
-          return keywords;
-        }
-        function getReturnOccurrences(returnStatement, sourceFile) {
-          const func = getContainingFunction(returnStatement);
-          if (!func) {
-            return void 0;
-          }
-          const keywords = [];
-          forEachReturnStatement(cast(func.body, isBlock), (returnStatement2) => {
-            keywords.push(findChildOfKind(returnStatement2, 107 /* ReturnKeyword */, sourceFile));
-          });
-          forEach(aggregateOwnedThrowStatements(func.body), (throwStatement) => {
-            keywords.push(findChildOfKind(throwStatement, 111 /* ThrowKeyword */, sourceFile));
-          });
-          return keywords;
-        }
-        function getAsyncAndAwaitOccurrences(node) {
-          const func = getContainingFunction(node);
-          if (!func) {
-            return void 0;
-          }
-          const keywords = [];
-          if (func.modifiers) {
-            func.modifiers.forEach((modifier) => {
-              pushKeywordIf(keywords, modifier, 134 /* AsyncKeyword */);
-            });
-          }
-          forEachChild(func, (child) => {
-            traverseWithoutCrossingFunction(child, (node2) => {
-              if (isAwaitExpression(node2)) {
-                pushKeywordIf(keywords, node2.getFirstToken(), 135 /* AwaitKeyword */);
-              }
-            });
-          });
-          return keywords;
-        }
-        function getYieldOccurrences(node) {
-          const func = getContainingFunction(node);
-          if (!func) {
-            return void 0;
-          }
-          const keywords = [];
-          forEachChild(func, (child) => {
-            traverseWithoutCrossingFunction(child, (node2) => {
-              if (isYieldExpression(node2)) {
-                pushKeywordIf(keywords, node2.getFirstToken(), 127 /* YieldKeyword */);
-              }
-            });
-          });
-          return keywords;
-        }
-        function traverseWithoutCrossingFunction(node, cb) {
-          cb(node);
-          if (!isFunctionLike(node) && !isClassLike(node) && !isInterfaceDeclaration(node) && !isModuleDeclaration(node) && !isTypeAliasDeclaration(node) && !isTypeNode(node)) {
-            forEachChild(node, (child) => traverseWithoutCrossingFunction(child, cb));
-          }
-        }
-        function getIfElseOccurrences(ifStatement, sourceFile) {
-          const keywords = getIfElseKeywords(ifStatement, sourceFile);
-          const result = [];
-          for (let i = 0; i < keywords.length; i++) {
-            if (keywords[i].kind === 93 /* ElseKeyword */ && i < keywords.length - 1) {
-              const elseKeyword = keywords[i];
-              const ifKeyword = keywords[i + 1];
-              let shouldCombineElseAndIf = true;
-              for (let j = ifKeyword.getStart(sourceFile) - 1; j >= elseKeyword.end; j--) {
-                if (!isWhiteSpaceSingleLine(sourceFile.text.charCodeAt(j))) {
-                  shouldCombineElseAndIf = false;
-                  break;
-                }
-              }
-              if (shouldCombineElseAndIf) {
-                result.push({
-                  fileName: sourceFile.fileName,
-                  textSpan: createTextSpanFromBounds(elseKeyword.getStart(), ifKeyword.end),
-                  kind: "reference" /* reference */
-                });
-                i++;
-                continue;
-              }
-            }
-            result.push(getHighlightSpanForNode(keywords[i], sourceFile));
-          }
-          return result;
-        }
-        function getIfElseKeywords(ifStatement, sourceFile) {
-          const keywords = [];
-          while (isIfStatement(ifStatement.parent) && ifStatement.parent.elseStatement === ifStatement) {
-            ifStatement = ifStatement.parent;
-          }
-          while (true) {
-            const children = ifStatement.getChildren(sourceFile);
-            pushKeywordIf(keywords, children[0], 101 /* IfKeyword */);
-            for (let i = children.length - 1; i >= 0; i--) {
-              if (pushKeywordIf(keywords, children[i], 93 /* ElseKeyword */)) {
-                break;
-              }
-            }
-            if (!ifStatement.elseStatement || !isIfStatement(ifStatement.elseStatement)) {
-              break;
-            }
-            ifStatement = ifStatement.elseStatement;
-          }
-          return keywords;
-        }
-        function isLabeledBy(node, labelName) {
-          return !!findAncestor(node.parent, (owner) => !isLabeledStatement(owner) ? "quit" : owner.label.escapedText === labelName);
-        }
-      })(DocumentHighlights || (DocumentHighlights = {}));
-    }
-  });
-
-  // src/services/documentRegistry.ts
-  function isDocumentRegistryEntry(entry) {
-    return !!entry.sourceFile;
-  }
-  function createDocumentRegistry(useCaseSensitiveFileNames, currentDirectory) {
-    return createDocumentRegistryInternal(useCaseSensitiveFileNames, currentDirectory);
-  }
-  function createDocumentRegistryInternal(useCaseSensitiveFileNames, currentDirectory = "", externalCache) {
-    const buckets = /* @__PURE__ */ new Map();
-    const getCanonicalFileName = createGetCanonicalFileName(!!useCaseSensitiveFileNames);
-    function reportStats() {
-      const bucketInfoArray = arrayFrom(buckets.keys()).filter((name) => name && name.charAt(0) === "_").map((name) => {
-        const entries = buckets.get(name);
-        const sourceFiles = [];
-        entries.forEach((entry, name2) => {
-          if (isDocumentRegistryEntry(entry)) {
-            sourceFiles.push({
-              name: name2,
-              scriptKind: entry.sourceFile.scriptKind,
-              refCount: entry.languageServiceRefCount
-            });
-          } else {
-            entry.forEach((value, scriptKind) => sourceFiles.push({ name: name2, scriptKind, refCount: value.languageServiceRefCount }));
-          }
-        });
-        sourceFiles.sort((x, y) => y.refCount - x.refCount);
-        return {
-          bucket: name,
-          sourceFiles
-        };
-      });
-      return JSON.stringify(bucketInfoArray, void 0, 2);
-    }
-    function getCompilationSettings(settingsOrHost) {
-      if (typeof settingsOrHost.getCompilationSettings === "function") {
-        return settingsOrHost.getCompilationSettings();
-      }
-      return settingsOrHost;
-    }
-    function acquireDocument(fileName, compilationSettings, scriptSnapshot, version2, scriptKind, languageVersionOrOptions) {
-      const path = toPath(fileName, currentDirectory, getCanonicalFileName);
-      const key = getKeyForCompilationSettings(getCompilationSettings(compilationSettings));
-      return acquireDocumentWithKey(fileName, path, compilationSettings, key, scriptSnapshot, version2, scriptKind, languageVersionOrOptions);
-    }
-    function acquireDocumentWithKey(fileName, path, compilationSettings, key, scriptSnapshot, version2, scriptKind, languageVersionOrOptions) {
-      return acquireOrUpdateDocument(
-        fileName,
-        path,
-        compilationSettings,
-        key,
-        scriptSnapshot,
-        version2,
-        /*acquiring*/
-        true,
-        scriptKind,
-        languageVersionOrOptions
-      );
-    }
-    function updateDocument(fileName, compilationSettings, scriptSnapshot, version2, scriptKind, languageVersionOrOptions) {
-      const path = toPath(fileName, currentDirectory, getCanonicalFileName);
-      const key = getKeyForCompilationSettings(getCompilationSettings(compilationSettings));
-      return updateDocumentWithKey(fileName, path, compilationSettings, key, scriptSnapshot, version2, scriptKind, languageVersionOrOptions);
-    }
-    function updateDocumentWithKey(fileName, path, compilationSettings, key, scriptSnapshot, version2, scriptKind, languageVersionOrOptions) {
-      return acquireOrUpdateDocument(
-        fileName,
-        path,
-        getCompilationSettings(compilationSettings),
-        key,
-        scriptSnapshot,
-        version2,
-        /*acquiring*/
-        false,
-        scriptKind,
-        languageVersionOrOptions
-      );
-    }
-    function getDocumentRegistryEntry(bucketEntry, scriptKind) {
-      const entry = isDocumentRegistryEntry(bucketEntry) ? bucketEntry : bucketEntry.get(Debug.checkDefined(scriptKind, "If there are more than one scriptKind's for same document the scriptKind should be provided"));
-      Debug.assert(scriptKind === void 0 || !entry || entry.sourceFile.scriptKind === scriptKind, `Script kind should match provided ScriptKind:${scriptKind} and sourceFile.scriptKind: ${entry == null ? void 0 : entry.sourceFile.scriptKind}, !entry: ${!entry}`);
-      return entry;
-    }
-    function acquireOrUpdateDocument(fileName, path, compilationSettingsOrHost, key, scriptSnapshot, version2, acquiring, scriptKind, languageVersionOrOptions) {
-      var _a, _b, _c, _d;
-      scriptKind = ensureScriptKind(fileName, scriptKind);
-      const compilationSettings = getCompilationSettings(compilationSettingsOrHost);
-      const host = compilationSettingsOrHost === compilationSettings ? void 0 : compilationSettingsOrHost;
-      const scriptTarget = scriptKind === 6 /* JSON */ ? 100 /* JSON */ : getEmitScriptTarget(compilationSettings);
-      const sourceFileOptions = typeof languageVersionOrOptions === "object" ? languageVersionOrOptions : {
-        languageVersion: scriptTarget,
-        impliedNodeFormat: host && getImpliedNodeFormatForFile(path, (_d = (_c = (_b = (_a = host.getCompilerHost) == null ? void 0 : _a.call(host)) == null ? void 0 : _b.getModuleResolutionCache) == null ? void 0 : _c.call(_b)) == null ? void 0 : _d.getPackageJsonInfoCache(), host, compilationSettings),
-        setExternalModuleIndicator: getSetExternalModuleIndicator(compilationSettings)
-      };
-      sourceFileOptions.languageVersion = scriptTarget;
-      const oldBucketCount = buckets.size;
-      const keyWithMode = getDocumentRegistryBucketKeyWithMode(key, sourceFileOptions.impliedNodeFormat);
-      const bucket = getOrUpdate(buckets, keyWithMode, () => /* @__PURE__ */ new Map());
-      if (tracing) {
-        if (buckets.size > oldBucketCount) {
-          tracing.instant(tracing.Phase.Session, "createdDocumentRegistryBucket", { configFilePath: compilationSettings.configFilePath, key: keyWithMode });
-        }
-        const otherBucketKey = !isDeclarationFileName(path) && forEachEntry(buckets, (bucket2, bucketKey) => bucketKey !== keyWithMode && bucket2.has(path) && bucketKey);
-        if (otherBucketKey) {
-          tracing.instant(tracing.Phase.Session, "documentRegistryBucketOverlap", { path, key1: otherBucketKey, key2: keyWithMode });
-        }
-      }
-      const bucketEntry = bucket.get(path);
-      let entry = bucketEntry && getDocumentRegistryEntry(bucketEntry, scriptKind);
-      if (!entry && externalCache) {
-        const sourceFile = externalCache.getDocument(keyWithMode, path);
-        if (sourceFile) {
-          Debug.assert(acquiring);
-          entry = {
-            sourceFile,
-            languageServiceRefCount: 0
-          };
-          setBucketEntry();
-        }
-      }
-      if (!entry) {
-        const sourceFile = createLanguageServiceSourceFile(
-          fileName,
-          scriptSnapshot,
-          sourceFileOptions,
-          version2,
-          /*setNodeParents*/
-          false,
-          scriptKind
-        );
-        if (externalCache) {
-          externalCache.setDocument(keyWithMode, path, sourceFile);
-        }
-        entry = {
-          sourceFile,
-          languageServiceRefCount: 1
-        };
-        setBucketEntry();
-      } else {
-        if (entry.sourceFile.version !== version2) {
-          entry.sourceFile = updateLanguageServiceSourceFile(
-            entry.sourceFile,
-            scriptSnapshot,
-            version2,
-            scriptSnapshot.getChangeRange(entry.sourceFile.scriptSnapshot)
-          );
-          if (externalCache) {
-            externalCache.setDocument(keyWithMode, path, entry.sourceFile);
-          }
-        }
-        if (acquiring) {
-          entry.languageServiceRefCount++;
-        }
-      }
-      Debug.assert(entry.languageServiceRefCount !== 0);
-      return entry.sourceFile;
-      function setBucketEntry() {
-        if (!bucketEntry) {
-          bucket.set(path, entry);
-        } else if (isDocumentRegistryEntry(bucketEntry)) {
-          const scriptKindMap = /* @__PURE__ */ new Map();
-          scriptKindMap.set(bucketEntry.sourceFile.scriptKind, bucketEntry);
-          scriptKindMap.set(scriptKind, entry);
-          bucket.set(path, scriptKindMap);
-        } else {
-          bucketEntry.set(scriptKind, entry);
-        }
-      }
-    }
-    function releaseDocument(fileName, compilationSettings, scriptKind, impliedNodeFormat) {
-      const path = toPath(fileName, currentDirectory, getCanonicalFileName);
-      const key = getKeyForCompilationSettings(compilationSettings);
-      return releaseDocumentWithKey(path, key, scriptKind, impliedNodeFormat);
-    }
-    function releaseDocumentWithKey(path, key, scriptKind, impliedNodeFormat) {
-      const bucket = Debug.checkDefined(buckets.get(getDocumentRegistryBucketKeyWithMode(key, impliedNodeFormat)));
-      const bucketEntry = bucket.get(path);
-      const entry = getDocumentRegistryEntry(bucketEntry, scriptKind);
-      entry.languageServiceRefCount--;
-      Debug.assert(entry.languageServiceRefCount >= 0);
-      if (entry.languageServiceRefCount === 0) {
-        if (isDocumentRegistryEntry(bucketEntry)) {
-          bucket.delete(path);
-        } else {
-          bucketEntry.delete(scriptKind);
-          if (bucketEntry.size === 1) {
-            bucket.set(path, firstDefinedIterator(bucketEntry.values(), identity));
-          }
-        }
-      }
-    }
-    function getLanguageServiceRefCounts(path, scriptKind) {
-      return arrayFrom(buckets.entries(), ([key, bucket]) => {
-        const bucketEntry = bucket.get(path);
-        const entry = bucketEntry && getDocumentRegistryEntry(bucketEntry, scriptKind);
-        return [key, entry && entry.languageServiceRefCount];
-      });
-    }
-    return {
-      acquireDocument,
-      acquireDocumentWithKey,
-      updateDocument,
-      updateDocumentWithKey,
-      releaseDocument,
-      releaseDocumentWithKey,
-      getLanguageServiceRefCounts,
-      reportStats,
-      getKeyForCompilationSettings
-    };
-  }
-  function getKeyForCompilationSettings(settings) {
-    return getKeyForCompilerOptions(settings, sourceFileAffectingCompilerOptions);
-  }
-  function getDocumentRegistryBucketKeyWithMode(key, mode) {
-    return mode ? `${key}|${mode}` : key;
-  }
-  var init_documentRegistry = __esm({
-    "src/services/documentRegistry.ts"() {
-      "use strict";
-      init_ts4();
-    }
-  });
-
-  // src/services/getEditsForFileRename.ts
-  function getEditsForFileRename(program, oldFileOrDirPath, newFileOrDirPath, host, formatContext, preferences, sourceMapper) {
-    const useCaseSensitiveFileNames = hostUsesCaseSensitiveFileNames(host);
-    const getCanonicalFileName = createGetCanonicalFileName(useCaseSensitiveFileNames);
-    const oldToNew = getPathUpdater(oldFileOrDirPath, newFileOrDirPath, getCanonicalFileName, sourceMapper);
-    const newToOld = getPathUpdater(newFileOrDirPath, oldFileOrDirPath, getCanonicalFileName, sourceMapper);
-    return ts_textChanges_exports.ChangeTracker.with({ host, formatContext, preferences }, (changeTracker) => {
-      updateTsconfigFiles(program, changeTracker, oldToNew, oldFileOrDirPath, newFileOrDirPath, host.getCurrentDirectory(), useCaseSensitiveFileNames);
-      updateImports(program, changeTracker, oldToNew, newToOld, host, getCanonicalFileName);
-    });
-  }
-  function getPathUpdater(oldFileOrDirPath, newFileOrDirPath, getCanonicalFileName, sourceMapper) {
-    const canonicalOldPath = getCanonicalFileName(oldFileOrDirPath);
-    return (path) => {
-      const originalPath = sourceMapper && sourceMapper.tryGetSourcePosition({ fileName: path, pos: 0 });
-      const updatedPath = getUpdatedPath(originalPath ? originalPath.fileName : path);
-      return originalPath ? updatedPath === void 0 ? void 0 : makeCorrespondingRelativeChange(originalPath.fileName, updatedPath, path, getCanonicalFileName) : updatedPath;
-    };
-    function getUpdatedPath(pathToUpdate) {
-      if (getCanonicalFileName(pathToUpdate) === canonicalOldPath)
-        return newFileOrDirPath;
-      const suffix = tryRemoveDirectoryPrefix(pathToUpdate, canonicalOldPath, getCanonicalFileName);
-      return suffix === void 0 ? void 0 : newFileOrDirPath + "/" + suffix;
-    }
-  }
-  function makeCorrespondingRelativeChange(a0, b0, a1, getCanonicalFileName) {
-    const rel = getRelativePathFromFile(a0, b0, getCanonicalFileName);
-    return combinePathsSafe(getDirectoryPath(a1), rel);
-  }
-  function updateTsconfigFiles(program, changeTracker, oldToNew, oldFileOrDirPath, newFileOrDirPath, currentDirectory, useCaseSensitiveFileNames) {
-    const { configFile } = program.getCompilerOptions();
-    if (!configFile)
-      return;
-    const configDir = getDirectoryPath(configFile.fileName);
-    const jsonObjectLiteral = getTsConfigObjectLiteralExpression(configFile);
-    if (!jsonObjectLiteral)
-      return;
-    forEachProperty(jsonObjectLiteral, (property, propertyName) => {
-      switch (propertyName) {
-        case "files":
-        case "include":
-        case "exclude": {
-          const foundExactMatch = updatePaths(property);
-          if (foundExactMatch || propertyName !== "include" || !isArrayLiteralExpression(property.initializer))
-            return;
-          const includes = mapDefined(property.initializer.elements, (e) => isStringLiteral(e) ? e.text : void 0);
-          if (includes.length === 0)
-            return;
-          const matchers = getFileMatcherPatterns(
-            configDir,
-            /*excludes*/
-            [],
-            includes,
-            useCaseSensitiveFileNames,
-            currentDirectory
-          );
-          if (getRegexFromPattern(Debug.checkDefined(matchers.includeFilePattern), useCaseSensitiveFileNames).test(oldFileOrDirPath) && !getRegexFromPattern(Debug.checkDefined(matchers.includeFilePattern), useCaseSensitiveFileNames).test(newFileOrDirPath)) {
-            changeTracker.insertNodeAfter(configFile, last(property.initializer.elements), factory.createStringLiteral(relativePath(newFileOrDirPath)));
-          }
-          return;
-        }
-        case "compilerOptions":
-          forEachProperty(property.initializer, (property2, propertyName2) => {
-            const option = getOptionFromName(propertyName2);
-            Debug.assert((option == null ? void 0 : option.type) !== "listOrElement");
-            if (option && (option.isFilePath || option.type === "list" && option.element.isFilePath)) {
-              updatePaths(property2);
-            } else if (propertyName2 === "paths") {
-              forEachProperty(property2.initializer, (pathsProperty) => {
-                if (!isArrayLiteralExpression(pathsProperty.initializer))
-                  return;
-                for (const e of pathsProperty.initializer.elements) {
-                  tryUpdateString(e);
-                }
-              });
-            }
-          });
-          return;
-      }
-    });
-    function updatePaths(property) {
-      const elements = isArrayLiteralExpression(property.initializer) ? property.initializer.elements : [property.initializer];
-      let foundExactMatch = false;
-      for (const element of elements) {
-        foundExactMatch = tryUpdateString(element) || foundExactMatch;
-      }
-      return foundExactMatch;
-    }
-    function tryUpdateString(element) {
-      if (!isStringLiteral(element))
-        return false;
-      const elementFileName = combinePathsSafe(configDir, element.text);
-      const updated = oldToNew(elementFileName);
-      if (updated !== void 0) {
-        changeTracker.replaceRangeWithText(configFile, createStringRange(element, configFile), relativePath(updated));
-        return true;
-      }
-      return false;
-    }
-    function relativePath(path) {
-      return getRelativePathFromDirectory(
-        configDir,
-        path,
-        /*ignoreCase*/
-        !useCaseSensitiveFileNames
-      );
-    }
-  }
-  function updateImports(program, changeTracker, oldToNew, newToOld, host, getCanonicalFileName) {
-    const allFiles = program.getSourceFiles();
-    for (const sourceFile of allFiles) {
-      const newFromOld = oldToNew(sourceFile.fileName);
-      const newImportFromPath = newFromOld ?? sourceFile.fileName;
-      const newImportFromDirectory = getDirectoryPath(newImportFromPath);
-      const oldFromNew = newToOld(sourceFile.fileName);
-      const oldImportFromPath = oldFromNew || sourceFile.fileName;
-      const oldImportFromDirectory = getDirectoryPath(oldImportFromPath);
-      const importingSourceFileMoved = newFromOld !== void 0 || oldFromNew !== void 0;
-      updateImportsWorker(
-        sourceFile,
-        changeTracker,
-        (referenceText) => {
-          if (!pathIsRelative(referenceText))
-            return void 0;
-          const oldAbsolute = combinePathsSafe(oldImportFromDirectory, referenceText);
-          const newAbsolute = oldToNew(oldAbsolute);
-          return newAbsolute === void 0 ? void 0 : ensurePathIsNonModuleName(getRelativePathFromDirectory(newImportFromDirectory, newAbsolute, getCanonicalFileName));
-        },
-        (importLiteral) => {
-          const importedModuleSymbol = program.getTypeChecker().getSymbolAtLocation(importLiteral);
-          if ((importedModuleSymbol == null ? void 0 : importedModuleSymbol.declarations) && importedModuleSymbol.declarations.some((d) => isAmbientModule(d)))
-            return void 0;
-          const toImport = oldFromNew !== void 0 ? getSourceFileToImportFromResolved(
-            importLiteral,
-            resolveModuleName(importLiteral.text, oldImportFromPath, program.getCompilerOptions(), host),
-            oldToNew,
-            allFiles
-          ) : getSourceFileToImport(importedModuleSymbol, importLiteral, sourceFile, program, host, oldToNew);
-          return toImport !== void 0 && (toImport.updated || importingSourceFileMoved && pathIsRelative(importLiteral.text)) ? ts_moduleSpecifiers_exports.updateModuleSpecifier(program.getCompilerOptions(), sourceFile, getCanonicalFileName(newImportFromPath), toImport.newFileName, createModuleSpecifierResolutionHost(program, host), importLiteral.text) : void 0;
-        }
-      );
-    }
-  }
-  function combineNormal(pathA, pathB) {
-    return normalizePath(combinePaths(pathA, pathB));
-  }
-  function combinePathsSafe(pathA, pathB) {
-    return ensurePathIsNonModuleName(combineNormal(pathA, pathB));
-  }
-  function getSourceFileToImport(importedModuleSymbol, importLiteral, importingSourceFile, program, host, oldToNew) {
-    var _a;
-    if (importedModuleSymbol) {
-      const oldFileName = find(importedModuleSymbol.declarations, isSourceFile).fileName;
-      const newFileName = oldToNew(oldFileName);
-      return newFileName === void 0 ? { newFileName: oldFileName, updated: false } : { newFileName, updated: true };
-    } else {
-      const mode = getModeForUsageLocation(importingSourceFile, importLiteral);
-      const resolved = host.resolveModuleNameLiterals || !host.resolveModuleNames ? (_a = importingSourceFile.resolvedModules) == null ? void 0 : _a.get(importLiteral.text, mode) : host.getResolvedModuleWithFailedLookupLocationsFromCache && host.getResolvedModuleWithFailedLookupLocationsFromCache(importLiteral.text, importingSourceFile.fileName, mode);
-      return getSourceFileToImportFromResolved(importLiteral, resolved, oldToNew, program.getSourceFiles());
-    }
-  }
-  function getSourceFileToImportFromResolved(importLiteral, resolved, oldToNew, sourceFiles) {
-    if (!resolved)
-      return void 0;
-    if (resolved.resolvedModule) {
-      const result2 = tryChange(resolved.resolvedModule.resolvedFileName);
-      if (result2)
-        return result2;
-    }
-    const result = forEach(resolved.failedLookupLocations, tryChangeWithIgnoringPackageJsonExisting) || pathIsRelative(importLiteral.text) && forEach(resolved.failedLookupLocations, tryChangeWithIgnoringPackageJson);
-    if (result)
-      return result;
-    return resolved.resolvedModule && { newFileName: resolved.resolvedModule.resolvedFileName, updated: false };
-    function tryChangeWithIgnoringPackageJsonExisting(oldFileName) {
-      const newFileName = oldToNew(oldFileName);
-      return newFileName && find(sourceFiles, (src) => src.fileName === newFileName) ? tryChangeWithIgnoringPackageJson(oldFileName) : void 0;
-    }
-    function tryChangeWithIgnoringPackageJson(oldFileName) {
-      return !endsWith(oldFileName, "/package.json") ? tryChange(oldFileName) : void 0;
-    }
-    function tryChange(oldFileName) {
-      const newFileName = oldToNew(oldFileName);
-      return newFileName && { newFileName, updated: true };
-    }
-  }
-  function updateImportsWorker(sourceFile, changeTracker, updateRef, updateImport2) {
-    for (const ref of sourceFile.referencedFiles || emptyArray) {
-      const updated = updateRef(ref.fileName);
-      if (updated !== void 0 && updated !== sourceFile.text.slice(ref.pos, ref.end))
-        changeTracker.replaceRangeWithText(sourceFile, ref, updated);
-    }
-    for (const importStringLiteral of sourceFile.imports) {
-      const updated = updateImport2(importStringLiteral);
-      if (updated !== void 0 && updated !== importStringLiteral.text)
-        changeTracker.replaceRangeWithText(sourceFile, createStringRange(importStringLiteral, sourceFile), updated);
-    }
-  }
-  function createStringRange(node, sourceFile) {
-    return createRange(node.getStart(sourceFile) + 1, node.end - 1);
-  }
-  function forEachProperty(objectLiteral, cb) {
-    if (!isObjectLiteralExpression(objectLiteral))
-      return;
-    for (const property of objectLiteral.properties) {
-      if (isPropertyAssignment(property) && isStringLiteral(property.name)) {
-        cb(property, property.name.text);
-      }
-    }
-  }
-  var init_getEditsForFileRename = __esm({
-    "src/services/getEditsForFileRename.ts"() {
-      "use strict";
-      init_ts4();
-    }
-  });
-
-  // src/services/patternMatcher.ts
-  function createPatternMatch(kind, isCaseSensitive) {
-    return {
-      kind,
-      isCaseSensitive
-    };
-  }
-  function createPatternMatcher(pattern) {
-    const stringToWordSpans = /* @__PURE__ */ new Map();
-    const dotSeparatedSegments = pattern.trim().split(".").map((p) => createSegment(p.trim()));
-    if (dotSeparatedSegments.some((segment) => !segment.subWordTextChunks.length))
-      return void 0;
-    return {
-      getFullMatch: (containers, candidate) => getFullMatch(containers, candidate, dotSeparatedSegments, stringToWordSpans),
-      getMatchForLastSegmentOfPattern: (candidate) => matchSegment(candidate, last(dotSeparatedSegments), stringToWordSpans),
-      patternContainsDots: dotSeparatedSegments.length > 1
-    };
-  }
-  function getFullMatch(candidateContainers, candidate, dotSeparatedSegments, stringToWordSpans) {
-    const candidateMatch = matchSegment(candidate, last(dotSeparatedSegments), stringToWordSpans);
-    if (!candidateMatch) {
-      return void 0;
-    }
-    if (dotSeparatedSegments.length - 1 > candidateContainers.length) {
-      return void 0;
-    }
-    let bestMatch;
-    for (let i = dotSeparatedSegments.length - 2, j = candidateContainers.length - 1; i >= 0; i -= 1, j -= 1) {
-      bestMatch = betterMatch(bestMatch, matchSegment(candidateContainers[j], dotSeparatedSegments[i], stringToWordSpans));
-    }
-    return bestMatch;
-  }
-  function getWordSpans(word, stringToWordSpans) {
-    let spans = stringToWordSpans.get(word);
-    if (!spans) {
-      stringToWordSpans.set(word, spans = breakIntoWordSpans(word));
-    }
-    return spans;
-  }
-  function matchTextChunk(candidate, chunk, stringToWordSpans) {
-    const index = indexOfIgnoringCase(candidate, chunk.textLowerCase);
-    if (index === 0) {
-      return createPatternMatch(
-        chunk.text.length === candidate.length ? 0 /* exact */ : 1 /* prefix */,
-        /*isCaseSensitive:*/
-        startsWith(candidate, chunk.text)
-      );
-    }
-    if (chunk.isLowerCase) {
-      if (index === -1)
-        return void 0;
-      const wordSpans = getWordSpans(candidate, stringToWordSpans);
-      for (const span of wordSpans) {
-        if (partStartsWith(
-          candidate,
-          span,
-          chunk.text,
-          /*ignoreCase*/
-          true
-        )) {
-          return createPatternMatch(
-            2 /* substring */,
-            /*isCaseSensitive:*/
-            partStartsWith(
-              candidate,
-              span,
-              chunk.text,
-              /*ignoreCase*/
-              false
-            )
-          );
-        }
-      }
-      if (chunk.text.length < candidate.length && isUpperCaseLetter(candidate.charCodeAt(index))) {
-        return createPatternMatch(
-          2 /* substring */,
-          /*isCaseSensitive*/
-          false
-        );
-      }
-    } else {
-      if (candidate.indexOf(chunk.text) > 0) {
-        return createPatternMatch(
-          2 /* substring */,
-          /*isCaseSensitive*/
-          true
-        );
-      }
-      if (chunk.characterSpans.length > 0) {
-        const candidateParts = getWordSpans(candidate, stringToWordSpans);
-        const isCaseSensitive = tryCamelCaseMatch(
-          candidate,
-          candidateParts,
-          chunk,
-          /*ignoreCase*/
-          false
-        ) ? true : tryCamelCaseMatch(
-          candidate,
-          candidateParts,
-          chunk,
-          /*ignoreCase*/
-          true
-        ) ? false : void 0;
-        if (isCaseSensitive !== void 0) {
-          return createPatternMatch(3 /* camelCase */, isCaseSensitive);
-        }
-      }
-    }
-  }
-  function matchSegment(candidate, segment, stringToWordSpans) {
-    if (every2(segment.totalTextChunk.text, (ch) => ch !== 32 /* space */ && ch !== 42 /* asterisk */)) {
-      const match = matchTextChunk(candidate, segment.totalTextChunk, stringToWordSpans);
-      if (match)
-        return match;
-    }
-    const subWordTextChunks = segment.subWordTextChunks;
-    let bestMatch;
-    for (const subWordTextChunk of subWordTextChunks) {
-      bestMatch = betterMatch(bestMatch, matchTextChunk(candidate, subWordTextChunk, stringToWordSpans));
-    }
-    return bestMatch;
-  }
-  function betterMatch(a, b) {
-    return min([a, b], compareMatches);
-  }
-  function compareMatches(a, b) {
-    return a === void 0 ? 1 /* GreaterThan */ : b === void 0 ? -1 /* LessThan */ : compareValues(a.kind, b.kind) || compareBooleans(!a.isCaseSensitive, !b.isCaseSensitive);
-  }
-  function partStartsWith(candidate, candidateSpan, pattern, ignoreCase, patternSpan = { start: 0, length: pattern.length }) {
-    return patternSpan.length <= candidateSpan.length && everyInRange(0, patternSpan.length, (i) => equalChars(pattern.charCodeAt(patternSpan.start + i), candidate.charCodeAt(candidateSpan.start + i), ignoreCase));
-  }
-  function equalChars(ch1, ch2, ignoreCase) {
-    return ignoreCase ? toLowerCase2(ch1) === toLowerCase2(ch2) : ch1 === ch2;
-  }
-  function tryCamelCaseMatch(candidate, candidateParts, chunk, ignoreCase) {
-    const chunkCharacterSpans = chunk.characterSpans;
-    let currentCandidate = 0;
-    let currentChunkSpan = 0;
-    let firstMatch;
-    let contiguous;
-    while (true) {
-      if (currentChunkSpan === chunkCharacterSpans.length) {
-        return true;
-      } else if (currentCandidate === candidateParts.length) {
-        return false;
-      }
-      let candidatePart = candidateParts[currentCandidate];
-      let gotOneMatchThisCandidate = false;
-      for (; currentChunkSpan < chunkCharacterSpans.length; currentChunkSpan++) {
-        const chunkCharacterSpan = chunkCharacterSpans[currentChunkSpan];
-        if (gotOneMatchThisCandidate) {
-          if (!isUpperCaseLetter(chunk.text.charCodeAt(chunkCharacterSpans[currentChunkSpan - 1].start)) || !isUpperCaseLetter(chunk.text.charCodeAt(chunkCharacterSpans[currentChunkSpan].start))) {
-            break;
-          }
-        }
-        if (!partStartsWith(candidate, candidatePart, chunk.text, ignoreCase, chunkCharacterSpan)) {
-          break;
-        }
-        gotOneMatchThisCandidate = true;
-        firstMatch = firstMatch === void 0 ? currentCandidate : firstMatch;
-        contiguous = contiguous === void 0 ? true : contiguous;
-        candidatePart = createTextSpan(candidatePart.start + chunkCharacterSpan.length, candidatePart.length - chunkCharacterSpan.length);
-      }
-      if (!gotOneMatchThisCandidate && contiguous !== void 0) {
-        contiguous = false;
-      }
-      currentCandidate++;
-    }
-  }
-  function createSegment(text) {
-    return {
-      totalTextChunk: createTextChunk(text),
-      subWordTextChunks: breakPatternIntoTextChunks(text)
-    };
-  }
-  function isUpperCaseLetter(ch) {
-    if (ch >= 65 /* A */ && ch <= 90 /* Z */) {
-      return true;
-    }
-    if (ch < 127 /* maxAsciiCharacter */ || !isUnicodeIdentifierStart(ch, 99 /* Latest */)) {
-      return false;
-    }
-    const str = String.fromCharCode(ch);
-    return str === str.toUpperCase();
-  }
-  function isLowerCaseLetter(ch) {
-    if (ch >= 97 /* a */ && ch <= 122 /* z */) {
-      return true;
-    }
-    if (ch < 127 /* maxAsciiCharacter */ || !isUnicodeIdentifierStart(ch, 99 /* Latest */)) {
-      return false;
-    }
-    const str = String.fromCharCode(ch);
-    return str === str.toLowerCase();
-  }
-  function indexOfIgnoringCase(str, value) {
-    const n = str.length - value.length;
-    for (let start = 0; start <= n; start++) {
-      if (every2(value, (valueChar, i) => toLowerCase2(str.charCodeAt(i + start)) === valueChar)) {
-        return start;
-      }
-    }
-    return -1;
-  }
-  function toLowerCase2(ch) {
-    if (ch >= 65 /* A */ && ch <= 90 /* Z */) {
-      return 97 /* a */ + (ch - 65 /* A */);
-    }
-    if (ch < 127 /* maxAsciiCharacter */) {
-      return ch;
-    }
-    return String.fromCharCode(ch).toLowerCase().charCodeAt(0);
-  }
-  function isDigit2(ch) {
-    return ch >= 48 /* _0 */ && ch <= 57 /* _9 */;
-  }
-  function isWordChar(ch) {
-    return isUpperCaseLetter(ch) || isLowerCaseLetter(ch) || isDigit2(ch) || ch === 95 /* _ */ || ch === 36 /* $ */;
-  }
-  function breakPatternIntoTextChunks(pattern) {
-    const result = [];
-    let wordStart = 0;
-    let wordLength = 0;
-    for (let i = 0; i < pattern.length; i++) {
-      const ch = pattern.charCodeAt(i);
-      if (isWordChar(ch)) {
-        if (wordLength === 0) {
-          wordStart = i;
-        }
-        wordLength++;
-      } else {
-        if (wordLength > 0) {
-          result.push(createTextChunk(pattern.substr(wordStart, wordLength)));
-          wordLength = 0;
-        }
-      }
-    }
-    if (wordLength > 0) {
-      result.push(createTextChunk(pattern.substr(wordStart, wordLength)));
-    }
-    return result;
-  }
-  function createTextChunk(text) {
-    const textLowerCase = text.toLowerCase();
-    return {
-      text,
-      textLowerCase,
-      isLowerCase: text === textLowerCase,
-      characterSpans: breakIntoCharacterSpans(text)
-    };
-  }
-  function breakIntoCharacterSpans(identifier) {
-    return breakIntoSpans(
-      identifier,
-      /*word*/
-      false
-    );
-  }
-  function breakIntoWordSpans(identifier) {
-    return breakIntoSpans(
-      identifier,
-      /*word*/
-      true
-    );
-  }
-  function breakIntoSpans(identifier, word) {
-    const result = [];
-    let wordStart = 0;
-    for (let i = 1; i < identifier.length; i++) {
-      const lastIsDigit = isDigit2(identifier.charCodeAt(i - 1));
-      const currentIsDigit = isDigit2(identifier.charCodeAt(i));
-      const hasTransitionFromLowerToUpper = transitionFromLowerToUpper(identifier, word, i);
-      const hasTransitionFromUpperToLower = word && transitionFromUpperToLower(identifier, i, wordStart);
-      if (charIsPunctuation(identifier.charCodeAt(i - 1)) || charIsPunctuation(identifier.charCodeAt(i)) || lastIsDigit !== currentIsDigit || hasTransitionFromLowerToUpper || hasTransitionFromUpperToLower) {
-        if (!isAllPunctuation(identifier, wordStart, i)) {
-          result.push(createTextSpan(wordStart, i - wordStart));
-        }
-        wordStart = i;
-      }
-    }
-    if (!isAllPunctuation(identifier, wordStart, identifier.length)) {
-      result.push(createTextSpan(wordStart, identifier.length - wordStart));
-    }
-    return result;
-  }
-  function charIsPunctuation(ch) {
-    switch (ch) {
-      case 33 /* exclamation */:
-      case 34 /* doubleQuote */:
-      case 35 /* hash */:
-      case 37 /* percent */:
-      case 38 /* ampersand */:
-      case 39 /* singleQuote */:
-      case 40 /* openParen */:
-      case 41 /* closeParen */:
-      case 42 /* asterisk */:
-      case 44 /* comma */:
-      case 45 /* minus */:
-      case 46 /* dot */:
-      case 47 /* slash */:
-      case 58 /* colon */:
-      case 59 /* semicolon */:
-      case 63 /* question */:
-      case 64 /* at */:
-      case 91 /* openBracket */:
-      case 92 /* backslash */:
-      case 93 /* closeBracket */:
-      case 95 /* _ */:
-      case 123 /* openBrace */:
-      case 125 /* closeBrace */:
-        return true;
-    }
-    return false;
-  }
-  function isAllPunctuation(identifier, start, end) {
-    return every2(identifier, (ch) => charIsPunctuation(ch) && ch !== 95 /* _ */, start, end);
-  }
-  function transitionFromUpperToLower(identifier, index, wordStart) {
-    return index !== wordStart && index + 1 < identifier.length && isUpperCaseLetter(identifier.charCodeAt(index)) && isLowerCaseLetter(identifier.charCodeAt(index + 1)) && every2(identifier, isUpperCaseLetter, wordStart, index);
-  }
-  function transitionFromLowerToUpper(identifier, word, index) {
-    const lastIsUpper = isUpperCaseLetter(identifier.charCodeAt(index - 1));
-    const currentIsUpper = isUpperCaseLetter(identifier.charCodeAt(index));
-    return currentIsUpper && (!word || !lastIsUpper);
-  }
-  function everyInRange(start, end, pred) {
-    for (let i = start; i < end; i++) {
-      if (!pred(i)) {
-        return false;
-      }
-    }
-    return true;
-  }
-  function every2(s, pred, start = 0, end = s.length) {
-    return everyInRange(start, end, (i) => pred(s.charCodeAt(i), i));
-  }
-  var PatternMatchKind;
-  var init_patternMatcher = __esm({
-    "src/services/patternMatcher.ts"() {
-      "use strict";
-      init_ts4();
-      PatternMatchKind = /* @__PURE__ */ ((PatternMatchKind2) => {
-        PatternMatchKind2[PatternMatchKind2["exact"] = 0] = "exact";
-        PatternMatchKind2[PatternMatchKind2["prefix"] = 1] = "prefix";
-        PatternMatchKind2[PatternMatchKind2["substring"] = 2] = "substring";
-        PatternMatchKind2[PatternMatchKind2["camelCase"] = 3] = "camelCase";
-        return PatternMatchKind2;
-      })(PatternMatchKind || {});
-    }
-  });
-
-  // src/services/preProcess.ts
-  function preProcessFile(sourceText, readImportFiles = true, detectJavaScriptImports = false) {
-    const pragmaContext = {
-      languageVersion: 1 /* ES5 */,
-      // controls whether the token scanner considers unicode identifiers or not - shouldn't matter, since we're only using it for trivia
-      pragmas: void 0,
-      checkJsDirective: void 0,
-      referencedFiles: [],
-      typeReferenceDirectives: [],
-      libReferenceDirectives: [],
-      amdDependencies: [],
-      hasNoDefaultLib: void 0,
-      moduleName: void 0
-    };
-    const importedFiles = [];
-    let ambientExternalModules;
-    let lastToken;
-    let currentToken;
-    let braceNesting = 0;
-    let externalModule = false;
-    function nextToken() {
-      lastToken = currentToken;
-      currentToken = scanner.scan();
-      if (currentToken === 19 /* OpenBraceToken */) {
-        braceNesting++;
-      } else if (currentToken === 20 /* CloseBraceToken */) {
-        braceNesting--;
-      }
-      return currentToken;
-    }
-    function getFileReference() {
-      const fileName = scanner.getTokenValue();
-      const pos = scanner.getTokenStart();
-      return { fileName, pos, end: pos + fileName.length };
-    }
-    function recordAmbientExternalModule() {
-      if (!ambientExternalModules) {
-        ambientExternalModules = [];
-      }
-      ambientExternalModules.push({ ref: getFileReference(), depth: braceNesting });
-    }
-    function recordModuleName() {
-      importedFiles.push(getFileReference());
-      markAsExternalModuleIfTopLevel();
-    }
-    function markAsExternalModuleIfTopLevel() {
-      if (braceNesting === 0) {
-        externalModule = true;
-      }
-    }
-    function tryConsumeDeclare() {
-      let token = scanner.getToken();
-      if (token === 138 /* DeclareKeyword */) {
-        token = nextToken();
-        if (token === 144 /* ModuleKeyword */) {
-          token = nextToken();
-          if (token === 11 /* StringLiteral */) {
-            recordAmbientExternalModule();
-          }
-        }
-        return true;
-      }
-      return false;
-    }
-    function tryConsumeImport() {
-      if (lastToken === 25 /* DotToken */) {
-        return false;
-      }
-      let token = scanner.getToken();
-      if (token === 102 /* ImportKeyword */) {
-        token = nextToken();
-        if (token === 21 /* OpenParenToken */) {
-          token = nextToken();
-          if (token === 11 /* StringLiteral */ || token === 15 /* NoSubstitutionTemplateLiteral */) {
-            recordModuleName();
-            return true;
-          }
-        } else if (token === 11 /* StringLiteral */) {
-          recordModuleName();
-          return true;
-        } else {
-          if (token === 156 /* TypeKeyword */) {
-            const skipTypeKeyword = scanner.lookAhead(() => {
-              const token2 = scanner.scan();
-              return token2 !== 160 /* FromKeyword */ && (token2 === 42 /* AsteriskToken */ || token2 === 19 /* OpenBraceToken */ || token2 === 80 /* Identifier */ || isKeyword(token2));
-            });
-            if (skipTypeKeyword) {
-              token = nextToken();
-            }
-          }
-          if (token === 80 /* Identifier */ || isKeyword(token)) {
-            token = nextToken();
-            if (token === 160 /* FromKeyword */) {
-              token = nextToken();
-              if (token === 11 /* StringLiteral */) {
-                recordModuleName();
-                return true;
-              }
-            } else if (token === 64 /* EqualsToken */) {
-              if (tryConsumeRequireCall(
-                /*skipCurrentToken*/
-                true
-              )) {
-                return true;
-              }
-            } else if (token === 28 /* CommaToken */) {
-              token = nextToken();
-            } else {
-              return true;
-            }
-          }
-          if (token === 19 /* OpenBraceToken */) {
-            token = nextToken();
-            while (token !== 20 /* CloseBraceToken */ && token !== 1 /* EndOfFileToken */) {
-              token = nextToken();
-            }
-            if (token === 20 /* CloseBraceToken */) {
-              token = nextToken();
-              if (token === 160 /* FromKeyword */) {
-                token = nextToken();
-                if (token === 11 /* StringLiteral */) {
-                  recordModuleName();
-                }
-              }
-            }
-          } else if (token === 42 /* AsteriskToken */) {
-            token = nextToken();
-            if (token === 130 /* AsKeyword */) {
-              token = nextToken();
-              if (token === 80 /* Identifier */ || isKeyword(token)) {
-                token = nextToken();
-                if (token === 160 /* FromKeyword */) {
-                  token = nextToken();
-                  if (token === 11 /* StringLiteral */) {
-                    recordModuleName();
-                  }
-                }
-              }
-            }
-          }
-        }
-        return true;
-      }
-      return false;
-    }
-    function tryConsumeExport() {
-      let token = scanner.getToken();
-      if (token === 95 /* ExportKeyword */) {
-        markAsExternalModuleIfTopLevel();
-        token = nextToken();
-        if (token === 156 /* TypeKeyword */) {
-          const skipTypeKeyword = scanner.lookAhead(() => {
-            const token2 = scanner.scan();
-            return token2 === 42 /* AsteriskToken */ || token2 === 19 /* OpenBraceToken */;
-          });
-          if (skipTypeKeyword) {
-            token = nextToken();
-          }
-        }
-        if (token === 19 /* OpenBraceToken */) {
-          token = nextToken();
-          while (token !== 20 /* CloseBraceToken */ && token !== 1 /* EndOfFileToken */) {
-            token = nextToken();
-          }
-          if (token === 20 /* CloseBraceToken */) {
-            token = nextToken();
-            if (token === 160 /* FromKeyword */) {
-              token = nextToken();
-              if (token === 11 /* StringLiteral */) {
-                recordModuleName();
-              }
-            }
-          }
-        } else if (token === 42 /* AsteriskToken */) {
-          token = nextToken();
-          if (token === 160 /* FromKeyword */) {
-            token = nextToken();
-            if (token === 11 /* StringLiteral */) {
-              recordModuleName();
-            }
-          }
-        } else if (token === 102 /* ImportKeyword */) {
-          token = nextToken();
-          if (token === 156 /* TypeKeyword */) {
-            const skipTypeKeyword = scanner.lookAhead(() => {
-              const token2 = scanner.scan();
-              return token2 === 80 /* Identifier */ || isKeyword(token2);
-            });
-            if (skipTypeKeyword) {
-              token = nextToken();
-            }
-          }
-          if (token === 80 /* Identifier */ || isKeyword(token)) {
-            token = nextToken();
-            if (token === 64 /* EqualsToken */) {
-              if (tryConsumeRequireCall(
-                /*skipCurrentToken*/
-                true
-              )) {
-                return true;
-              }
-            }
-          }
-        }
-        return true;
-      }
-      return false;
-    }
-    function tryConsumeRequireCall(skipCurrentToken, allowTemplateLiterals = false) {
-      let token = skipCurrentToken ? nextToken() : scanner.getToken();
-      if (token === 149 /* RequireKeyword */) {
-        token = nextToken();
-        if (token === 21 /* OpenParenToken */) {
-          token = nextToken();
-          if (token === 11 /* StringLiteral */ || allowTemplateLiterals && token === 15 /* NoSubstitutionTemplateLiteral */) {
-            recordModuleName();
-          }
-        }
-        return true;
-      }
-      return false;
-    }
-    function tryConsumeDefine() {
-      let token = scanner.getToken();
-      if (token === 80 /* Identifier */ && scanner.getTokenValue() === "define") {
-        token = nextToken();
-        if (token !== 21 /* OpenParenToken */) {
-          return true;
-        }
-        token = nextToken();
-        if (token === 11 /* StringLiteral */ || token === 15 /* NoSubstitutionTemplateLiteral */) {
-          token = nextToken();
-          if (token === 28 /* CommaToken */) {
-            token = nextToken();
-          } else {
-            return true;
-          }
-        }
-        if (token !== 23 /* OpenBracketToken */) {
-          return true;
-        }
-        token = nextToken();
-        while (token !== 24 /* CloseBracketToken */ && token !== 1 /* EndOfFileToken */) {
-          if (token === 11 /* StringLiteral */ || token === 15 /* NoSubstitutionTemplateLiteral */) {
-            recordModuleName();
-          }
-          token = nextToken();
-        }
-        return true;
-      }
-      return false;
-    }
-    function processImports() {
-      scanner.setText(sourceText);
-      nextToken();
-      while (true) {
-        if (scanner.getToken() === 1 /* EndOfFileToken */) {
-          break;
-        }
-        if (scanner.getToken() === 16 /* TemplateHead */) {
-          const stack = [scanner.getToken()];
-          loop:
-            while (length(stack)) {
-              const token = scanner.scan();
-              switch (token) {
-                case 1 /* EndOfFileToken */:
-                  break loop;
-                case 102 /* ImportKeyword */:
-                  tryConsumeImport();
-                  break;
-                case 16 /* TemplateHead */:
-                  stack.push(token);
-                  break;
-                case 19 /* OpenBraceToken */:
-                  if (length(stack)) {
-                    stack.push(token);
-                  }
-                  break;
-                case 20 /* CloseBraceToken */:
-                  if (length(stack)) {
-                    if (lastOrUndefined(stack) === 16 /* TemplateHead */) {
-                      if (scanner.reScanTemplateToken(
-                        /*isTaggedTemplate*/
-                        false
-                      ) === 18 /* TemplateTail */) {
-                        stack.pop();
-                      }
-                    } else {
-                      stack.pop();
-                    }
-                  }
-                  break;
-              }
-            }
-          nextToken();
-        }
-        if (tryConsumeDeclare() || tryConsumeImport() || tryConsumeExport() || detectJavaScriptImports && (tryConsumeRequireCall(
-          /*skipCurrentToken*/
-          false,
-          /*allowTemplateLiterals*/
-          true
-        ) || tryConsumeDefine())) {
-          continue;
-        } else {
-          nextToken();
-        }
-      }
-      scanner.setText(void 0);
-    }
-    if (readImportFiles) {
-      processImports();
-    }
-    processCommentPragmas(pragmaContext, sourceText);
-    processPragmasIntoFields(pragmaContext, noop);
-    if (externalModule) {
-      if (ambientExternalModules) {
-        for (const decl of ambientExternalModules) {
-          importedFiles.push(decl.ref);
-        }
-      }
-      return { referencedFiles: pragmaContext.referencedFiles, typeReferenceDirectives: pragmaContext.typeReferenceDirectives, libReferenceDirectives: pragmaContext.libReferenceDirectives, importedFiles, isLibFile: !!pragmaContext.hasNoDefaultLib, ambientExternalModules: void 0 };
-    } else {
-      let ambientModuleNames;
-      if (ambientExternalModules) {
-        for (const decl of ambientExternalModules) {
-          if (decl.depth === 0) {
-            if (!ambientModuleNames) {
-              ambientModuleNames = [];
-            }
-            ambientModuleNames.push(decl.ref.fileName);
-          } else {
-            importedFiles.push(decl.ref);
-          }
-        }
-      }
-      return { referencedFiles: pragmaContext.referencedFiles, typeReferenceDirectives: pragmaContext.typeReferenceDirectives, libReferenceDirectives: pragmaContext.libReferenceDirectives, importedFiles, isLibFile: !!pragmaContext.hasNoDefaultLib, ambientExternalModules: ambientModuleNames };
-    }
-  }
-  var init_preProcess = __esm({
-    "src/services/preProcess.ts"() {
-      "use strict";
-      init_ts4();
-    }
-  });
-
-  // src/services/sourcemaps.ts
-  function getSourceMapper(host) {
-    const getCanonicalFileName = createGetCanonicalFileName(host.useCaseSensitiveFileNames());
-    const currentDirectory = host.getCurrentDirectory();
-    const sourceFileLike = /* @__PURE__ */ new Map();
-    const documentPositionMappers = /* @__PURE__ */ new Map();
-    return { tryGetSourcePosition, tryGetGeneratedPosition, toLineColumnOffset, clearCache };
-    function toPath3(fileName) {
-      return toPath(fileName, currentDirectory, getCanonicalFileName);
-    }
-    function getDocumentPositionMapper2(generatedFileName, sourceFileName) {
-      const path = toPath3(generatedFileName);
-      const value = documentPositionMappers.get(path);
-      if (value)
-        return value;
-      let mapper;
-      if (host.getDocumentPositionMapper) {
-        mapper = host.getDocumentPositionMapper(generatedFileName, sourceFileName);
-      } else if (host.readFile) {
-        const file = getSourceFileLike(generatedFileName);
-        mapper = file && getDocumentPositionMapper(
-          { getSourceFileLike, getCanonicalFileName, log: (s) => host.log(s) },
-          generatedFileName,
-          getLineInfo(file.text, getLineStarts(file)),
-          (f) => !host.fileExists || host.fileExists(f) ? host.readFile(f) : void 0
-        );
-      }
-      documentPositionMappers.set(path, mapper || identitySourceMapConsumer);
-      return mapper || identitySourceMapConsumer;
-    }
-    function tryGetSourcePosition(info) {
-      if (!isDeclarationFileName(info.fileName))
-        return void 0;
-      const file = getSourceFile(info.fileName);
-      if (!file)
-        return void 0;
-      const newLoc = getDocumentPositionMapper2(info.fileName).getSourcePosition(info);
-      return !newLoc || newLoc === info ? void 0 : tryGetSourcePosition(newLoc) || newLoc;
-    }
-    function tryGetGeneratedPosition(info) {
-      if (isDeclarationFileName(info.fileName))
-        return void 0;
-      const sourceFile = getSourceFile(info.fileName);
-      if (!sourceFile)
-        return void 0;
-      const program = host.getProgram();
-      if (program.isSourceOfProjectReferenceRedirect(sourceFile.fileName)) {
-        return void 0;
-      }
-      const options = program.getCompilerOptions();
-      const outPath = outFile(options);
-      const declarationPath = outPath ? removeFileExtension(outPath) + ".d.ts" /* Dts */ : getDeclarationEmitOutputFilePathWorker(info.fileName, program.getCompilerOptions(), currentDirectory, program.getCommonSourceDirectory(), getCanonicalFileName);
-      if (declarationPath === void 0)
-        return void 0;
-      const newLoc = getDocumentPositionMapper2(declarationPath, info.fileName).getGeneratedPosition(info);
-      return newLoc === info ? void 0 : newLoc;
-    }
-    function getSourceFile(fileName) {
-      const program = host.getProgram();
-      if (!program)
-        return void 0;
-      const path = toPath3(fileName);
-      const file = program.getSourceFileByPath(path);
-      return file && file.resolvedPath === path ? file : void 0;
-    }
-    function getOrCreateSourceFileLike(fileName) {
-      const path = toPath3(fileName);
-      const fileFromCache = sourceFileLike.get(path);
-      if (fileFromCache !== void 0)
-        return fileFromCache ? fileFromCache : void 0;
-      if (!host.readFile || host.fileExists && !host.fileExists(path)) {
-        sourceFileLike.set(path, false);
-        return void 0;
-      }
-      const text = host.readFile(path);
-      const file = text ? createSourceFileLike(text) : false;
-      sourceFileLike.set(path, file);
-      return file ? file : void 0;
-    }
-    function getSourceFileLike(fileName) {
-      return !host.getSourceFileLike ? getSourceFile(fileName) || getOrCreateSourceFileLike(fileName) : host.getSourceFileLike(fileName);
-    }
-    function toLineColumnOffset(fileName, position) {
-      const file = getSourceFileLike(fileName);
-      return file.getLineAndCharacterOfPosition(position);
-    }
-    function clearCache() {
-      sourceFileLike.clear();
-      documentPositionMappers.clear();
-    }
-  }
-  function getDocumentPositionMapper(host, generatedFileName, generatedFileLineInfo, readMapFile) {
-    let mapFileName = tryGetSourceMappingURL(generatedFileLineInfo);
-    if (mapFileName) {
-      const match = base64UrlRegExp.exec(mapFileName);
-      if (match) {
-        if (match[1]) {
-          const base64Object = match[1];
-          return convertDocumentToSourceMapper(host, base64decode(sys, base64Object), generatedFileName);
-        }
-        mapFileName = void 0;
-      }
-    }
-    const possibleMapLocations = [];
-    if (mapFileName) {
-      possibleMapLocations.push(mapFileName);
-    }
-    possibleMapLocations.push(generatedFileName + ".map");
-    const originalMapFileName = mapFileName && getNormalizedAbsolutePath(mapFileName, getDirectoryPath(generatedFileName));
-    for (const location of possibleMapLocations) {
-      const mapFileName2 = getNormalizedAbsolutePath(location, getDirectoryPath(generatedFileName));
-      const mapFileContents = readMapFile(mapFileName2, originalMapFileName);
-      if (isString(mapFileContents)) {
-        return convertDocumentToSourceMapper(host, mapFileContents, mapFileName2);
-      }
-      if (mapFileContents !== void 0) {
-        return mapFileContents || void 0;
-      }
-    }
-    return void 0;
-  }
-  function convertDocumentToSourceMapper(host, contents, mapFileName) {
-    const map2 = tryParseRawSourceMap(contents);
-    if (!map2 || !map2.sources || !map2.file || !map2.mappings) {
-      return void 0;
-    }
-    if (map2.sourcesContent && map2.sourcesContent.some(isString))
-      return void 0;
-    return createDocumentPositionMapper(host, map2, mapFileName);
-  }
-  function createSourceFileLike(text, lineMap) {
-    return {
-      text,
-      lineMap,
-      getLineAndCharacterOfPosition(pos) {
-        return computeLineAndCharacterOfPosition(getLineStarts(this), pos);
-      }
-    };
-  }
-  var base64UrlRegExp;
-  var init_sourcemaps = __esm({
-    "src/services/sourcemaps.ts"() {
-      "use strict";
-      init_ts4();
-      base64UrlRegExp = /^data:(?:application\/json(?:;charset=[uU][tT][fF]-8);base64,([A-Za-z0-9+\/=]+)$)?/;
-    }
-  });
-
-  // src/services/suggestionDiagnostics.ts
-  function computeSuggestionDiagnostics(sourceFile, program, cancellationToken) {
-    program.getSemanticDiagnostics(sourceFile, cancellationToken);
-    const diags = [];
-    const checker = program.getTypeChecker();
-    const isCommonJSFile = sourceFile.impliedNodeFormat === 1 /* CommonJS */ || fileExtensionIsOneOf(sourceFile.fileName, [".cts" /* Cts */, ".cjs" /* Cjs */]);
-    if (!isCommonJSFile && sourceFile.commonJsModuleIndicator && (programContainsEsModules(program) || compilerOptionsIndicateEsModules(program.getCompilerOptions())) && containsTopLevelCommonjs(sourceFile)) {
-      diags.push(createDiagnosticForNode(getErrorNodeFromCommonJsIndicator(sourceFile.commonJsModuleIndicator), Diagnostics.File_is_a_CommonJS_module_it_may_be_converted_to_an_ES_module));
-    }
-    const isJsFile = isSourceFileJS(sourceFile);
-    visitedNestedConvertibleFunctions.clear();
-    check(sourceFile);
-    if (getAllowSyntheticDefaultImports(program.getCompilerOptions())) {
-      for (const moduleSpecifier of sourceFile.imports) {
-        const importNode = importFromModuleSpecifier(moduleSpecifier);
-        const name = importNameForConvertToDefaultImport(importNode);
-        if (!name)
-          continue;
-        const module2 = getResolvedModule(sourceFile, moduleSpecifier.text, getModeForUsageLocation(sourceFile, moduleSpecifier));
-        const resolvedFile = module2 && program.getSourceFile(module2.resolvedFileName);
-        if (resolvedFile && resolvedFile.externalModuleIndicator && resolvedFile.externalModuleIndicator !== true && isExportAssignment(resolvedFile.externalModuleIndicator) && resolvedFile.externalModuleIndicator.isExportEquals) {
-          diags.push(createDiagnosticForNode(name, Diagnostics.Import_may_be_converted_to_a_default_import));
-        }
-      }
-    }
-    addRange(diags, sourceFile.bindSuggestionDiagnostics);
-    addRange(diags, program.getSuggestionDiagnostics(sourceFile, cancellationToken));
-    return diags.sort((d1, d2) => d1.start - d2.start);
-    function check(node) {
-      if (isJsFile) {
-        if (canBeConvertedToClass(node, checker)) {
-          diags.push(createDiagnosticForNode(isVariableDeclaration(node.parent) ? node.parent.name : node, Diagnostics.This_constructor_function_may_be_converted_to_a_class_declaration));
-        }
-      } else {
-        if (isVariableStatement(node) && node.parent === sourceFile && node.declarationList.flags & 2 /* Const */ && node.declarationList.declarations.length === 1) {
-          const init = node.declarationList.declarations[0].initializer;
-          if (init && isRequireCall(
-            init,
-            /*requireStringLiteralLikeArgument*/
-            true
-          )) {
-            diags.push(createDiagnosticForNode(init, Diagnostics.require_call_may_be_converted_to_an_import));
-          }
-        }
-        const jsdocTypedefNode = ts_codefix_exports.getJSDocTypedefNode(node);
-        if (jsdocTypedefNode) {
-          diags.push(createDiagnosticForNode(jsdocTypedefNode, Diagnostics.JSDoc_typedef_may_be_converted_to_TypeScript_type));
-        }
-        if (ts_codefix_exports.parameterShouldGetTypeFromJSDoc(node)) {
-          diags.push(createDiagnosticForNode(node.name || node, Diagnostics.JSDoc_types_may_be_moved_to_TypeScript_types));
-        }
-      }
-      if (canBeConvertedToAsync(node)) {
-        addConvertToAsyncFunctionDiagnostics(node, checker, diags);
-      }
-      node.forEachChild(check);
-    }
-  }
-  function containsTopLevelCommonjs(sourceFile) {
-    return sourceFile.statements.some((statement) => {
-      switch (statement.kind) {
-        case 242 /* VariableStatement */:
-          return statement.declarationList.declarations.some((decl) => !!decl.initializer && isRequireCall(
-            propertyAccessLeftHandSide(decl.initializer),
-            /*requireStringLiteralLikeArgument*/
-            true
-          ));
-        case 243 /* ExpressionStatement */: {
-          const { expression } = statement;
-          if (!isBinaryExpression(expression))
-            return isRequireCall(
-              expression,
-              /*requireStringLiteralLikeArgument*/
-              true
-            );
-          const kind = getAssignmentDeclarationKind(expression);
-          return kind === 1 /* ExportsProperty */ || kind === 2 /* ModuleExports */;
-        }
-        default:
-          return false;
-      }
-    });
-  }
-  function propertyAccessLeftHandSide(node) {
-    return isPropertyAccessExpression(node) ? propertyAccessLeftHandSide(node.expression) : node;
-  }
-  function importNameForConvertToDefaultImport(node) {
-    switch (node.kind) {
-      case 271 /* ImportDeclaration */:
-        const { importClause, moduleSpecifier } = node;
-        return importClause && !importClause.name && importClause.namedBindings && importClause.namedBindings.kind === 273 /* NamespaceImport */ && isStringLiteral(moduleSpecifier) ? importClause.namedBindings.name : void 0;
-      case 270 /* ImportEqualsDeclaration */:
-        return node.name;
-      default:
-        return void 0;
-    }
-  }
-  function addConvertToAsyncFunctionDiagnostics(node, checker, diags) {
-    if (isConvertibleFunction(node, checker) && !visitedNestedConvertibleFunctions.has(getKeyFromNode(node))) {
-      diags.push(createDiagnosticForNode(
-        !node.name && isVariableDeclaration(node.parent) && isIdentifier(node.parent.name) ? node.parent.name : node,
-        Diagnostics.This_may_be_converted_to_an_async_function
-      ));
-    }
-  }
-  function isConvertibleFunction(node, checker) {
-    return !isAsyncFunction(node) && node.body && isBlock(node.body) && hasReturnStatementWithPromiseHandler(node.body, checker) && returnsPromise(node, checker);
-  }
-  function returnsPromise(node, checker) {
-    const signature = checker.getSignatureFromDeclaration(node);
-    const returnType = signature ? checker.getReturnTypeOfSignature(signature) : void 0;
-    return !!returnType && !!checker.getPromisedTypeOfPromise(returnType);
-  }
-  function getErrorNodeFromCommonJsIndicator(commonJsModuleIndicator) {
-    return isBinaryExpression(commonJsModuleIndicator) ? commonJsModuleIndicator.left : commonJsModuleIndicator;
-  }
-  function hasReturnStatementWithPromiseHandler(body, checker) {
-    return !!forEachReturnStatement(body, (statement) => isReturnStatementWithFixablePromiseHandler(statement, checker));
-  }
-  function isReturnStatementWithFixablePromiseHandler(node, checker) {
-    return isReturnStatement(node) && !!node.expression && isFixablePromiseHandler(node.expression, checker);
-  }
-  function isFixablePromiseHandler(node, checker) {
-    if (!isPromiseHandler(node) || !hasSupportedNumberOfArguments(node) || !node.arguments.every((arg) => isFixablePromiseArgument(arg, checker))) {
-      return false;
-    }
-    let currentNode = node.expression.expression;
-    while (isPromiseHandler(currentNode) || isPropertyAccessExpression(currentNode)) {
-      if (isCallExpression(currentNode)) {
-        if (!hasSupportedNumberOfArguments(currentNode) || !currentNode.arguments.every((arg) => isFixablePromiseArgument(arg, checker))) {
-          return false;
-        }
-        currentNode = currentNode.expression.expression;
-      } else {
-        currentNode = currentNode.expression;
-      }
-    }
-    return true;
-  }
-  function isPromiseHandler(node) {
-    return isCallExpression(node) && (hasPropertyAccessExpressionWithName(node, "then") || hasPropertyAccessExpressionWithName(node, "catch") || hasPropertyAccessExpressionWithName(node, "finally"));
-  }
-  function hasSupportedNumberOfArguments(node) {
-    const name = node.expression.name.text;
-    const maxArguments = name === "then" ? 2 : name === "catch" ? 1 : name === "finally" ? 1 : 0;
-    if (node.arguments.length > maxArguments)
-      return false;
-    if (node.arguments.length < maxArguments)
-      return true;
-    return maxArguments === 1 || some(node.arguments, (arg) => {
-      return arg.kind === 106 /* NullKeyword */ || isIdentifier(arg) && arg.text === "undefined";
-    });
-  }
-  function isFixablePromiseArgument(arg, checker) {
-    switch (arg.kind) {
-      case 261 /* FunctionDeclaration */:
-      case 217 /* FunctionExpression */:
-        const functionFlags = getFunctionFlags(arg);
-        if (functionFlags & 1 /* Generator */) {
-          return false;
-        }
-      case 218 /* ArrowFunction */:
-        visitedNestedConvertibleFunctions.set(getKeyFromNode(arg), true);
-      case 106 /* NullKeyword */:
-        return true;
-      case 80 /* Identifier */:
-      case 210 /* PropertyAccessExpression */: {
-        const symbol = checker.getSymbolAtLocation(arg);
-        if (!symbol) {
-          return false;
-        }
-        return checker.isUndefinedSymbol(symbol) || some(skipAlias(symbol, checker).declarations, (d) => isFunctionLike(d) || hasInitializer(d) && !!d.initializer && isFunctionLike(d.initializer));
-      }
-      default:
-        return false;
-    }
-  }
-  function getKeyFromNode(exp) {
-    return `${exp.pos.toString()}:${exp.end.toString()}`;
-  }
-  function canBeConvertedToClass(node, checker) {
-    var _a, _b, _c, _d;
-    if (isFunctionExpression(node)) {
-      if (isVariableDeclaration(node.parent) && ((_a = node.symbol.members) == null ? void 0 : _a.size)) {
-        return true;
-      }
-      const symbol = checker.getSymbolOfExpando(
-        node,
-        /*allowDeclaration*/
-        false
-      );
-      return !!(symbol && (((_b = symbol.exports) == null ? void 0 : _b.size) || ((_c = symbol.members) == null ? void 0 : _c.size)));
-    }
-    if (isFunctionDeclaration(node)) {
-      return !!((_d = node.symbol.members) == null ? void 0 : _d.size);
-    }
-    return false;
-  }
-  function canBeConvertedToAsync(node) {
-    switch (node.kind) {
-      case 261 /* FunctionDeclaration */:
-      case 173 /* MethodDeclaration */:
-      case 217 /* FunctionExpression */:
-      case 218 /* ArrowFunction */:
-        return true;
-      default:
-        return false;
-    }
-  }
-  var visitedNestedConvertibleFunctions;
-  var init_suggestionDiagnostics = __esm({
-    "src/services/suggestionDiagnostics.ts"() {
-      "use strict";
-      init_ts4();
-      visitedNestedConvertibleFunctions = /* @__PURE__ */ new Map();
-    }
-  });
-
-  // src/services/transpile.ts
-  function transpileModule(input, transpileOptions) {
-    const diagnostics = [];
-    const options = transpileOptions.compilerOptions ? fixupCompilerOptions(transpileOptions.compilerOptions, diagnostics) : {};
-    const defaultOptions = getDefaultCompilerOptions2();
-    for (const key in defaultOptions) {
-      if (hasProperty(defaultOptions, key) && options[key] === void 0) {
-        options[key] = defaultOptions[key];
-      }
-    }
-    for (const option of transpileOptionValueCompilerOptions) {
-      if (options.verbatimModuleSyntax && optionsRedundantWithVerbatimModuleSyntax.has(option.name)) {
-        continue;
-      }
-      options[option.name] = option.transpileOptionValue;
-    }
-    options.suppressOutputPathCheck = true;
-    options.allowNonTsExtensions = true;
-    const newLine = getNewLineCharacter(options);
-    const compilerHost = {
-      getSourceFile: (fileName) => fileName === normalizePath(inputFileName) ? sourceFile : void 0,
-      writeFile: (name, text) => {
-        if (fileExtensionIs(name, ".map")) {
-          Debug.assertEqual(sourceMapText, void 0, "Unexpected multiple source map outputs, file:", name);
-          sourceMapText = text;
-        } else {
-          Debug.assertEqual(outputText, void 0, "Unexpected multiple outputs, file:", name);
-          outputText = text;
-        }
-      },
-      getDefaultLibFileName: () => "lib.d.ts",
-      useCaseSensitiveFileNames: () => false,
-      getCanonicalFileName: (fileName) => fileName,
-      getCurrentDirectory: () => "",
-      getNewLine: () => newLine,
-      fileExists: (fileName) => fileName === inputFileName,
-      readFile: () => "",
-      directoryExists: () => true,
-      getDirectories: () => []
-    };
-    const inputFileName = transpileOptions.fileName || (transpileOptions.compilerOptions && transpileOptions.compilerOptions.jsx ? "module.tsx" : "module.ts");
-    const sourceFile = createSourceFile(
-      inputFileName,
-      input,
-      {
-        languageVersion: getEmitScriptTarget(options),
-        impliedNodeFormat: getImpliedNodeFormatForFile(
-          toPath(inputFileName, "", compilerHost.getCanonicalFileName),
-          /*packageJsonInfoCache*/
-          void 0,
-          compilerHost,
-          options
-        ),
-        setExternalModuleIndicator: getSetExternalModuleIndicator(options)
-      }
-    );
-    if (transpileOptions.moduleName) {
-      sourceFile.moduleName = transpileOptions.moduleName;
-    }
-    if (transpileOptions.renamedDependencies) {
-      sourceFile.renamedDependencies = new Map(Object.entries(transpileOptions.renamedDependencies));
-    }
-    let outputText;
-    let sourceMapText;
-    const program = createProgram([inputFileName], options, compilerHost);
-    if (transpileOptions.reportDiagnostics) {
-      addRange(
-        /*to*/
-        diagnostics,
-        /*from*/
-        program.getSyntacticDiagnostics(sourceFile)
-      );
-      addRange(
-        /*to*/
-        diagnostics,
-        /*from*/
-        program.getOptionsDiagnostics()
-      );
-    }
-    program.emit(
-      /*targetSourceFile*/
-      void 0,
-      /*writeFile*/
-      void 0,
-      /*cancellationToken*/
-      void 0,
-      /*emitOnlyDtsFiles*/
-      void 0,
-      transpileOptions.transformers
-    );
-    if (outputText === void 0)
-      return Debug.fail("Output generation failed");
-    return { outputText, diagnostics, sourceMapText };
-  }
-  function transpile(input, compilerOptions, fileName, diagnostics, moduleName) {
-    const output = transpileModule(input, { compilerOptions, fileName, reportDiagnostics: !!diagnostics, moduleName });
-    addRange(diagnostics, output.diagnostics);
-    return output.outputText;
-  }
-  function fixupCompilerOptions(options, diagnostics) {
-    commandLineOptionsStringToEnum = commandLineOptionsStringToEnum || filter(optionDeclarations, (o) => typeof o.type === "object" && !forEachEntry(o.type, (v) => typeof v !== "number"));
-    options = cloneCompilerOptions(options);
-    for (const opt of commandLineOptionsStringToEnum) {
-      if (!hasProperty(options, opt.name)) {
-        continue;
-      }
-      const value = options[opt.name];
-      if (isString(value)) {
-        options[opt.name] = parseCustomTypeOption(opt, value, diagnostics);
-      } else {
-        if (!forEachEntry(opt.type, (v) => v === value)) {
-          diagnostics.push(createCompilerDiagnosticForInvalidCustomType(opt));
-        }
-      }
-    }
-    return options;
-  }
-  var optionsRedundantWithVerbatimModuleSyntax, commandLineOptionsStringToEnum;
-  var init_transpile = __esm({
-    "src/services/transpile.ts"() {
-      "use strict";
-      init_ts4();
-      optionsRedundantWithVerbatimModuleSyntax = /* @__PURE__ */ new Set([
-        "isolatedModules",
-        "preserveValueImports",
-        "importsNotUsedAsValues"
-      ]);
-    }
-  });
-
-  // src/services/navigateTo.ts
-  function getNavigateToItems(sourceFiles, checker, cancellationToken, searchValue, maxResultCount, excludeDtsFiles) {
-    const patternMatcher = createPatternMatcher(searchValue);
-    if (!patternMatcher)
-      return emptyArray;
-    const rawItems = [];
-    for (const sourceFile of sourceFiles) {
-      cancellationToken.throwIfCancellationRequested();
-      if (excludeDtsFiles && sourceFile.isDeclarationFile) {
-        continue;
-      }
-      sourceFile.getNamedDeclarations().forEach((declarations, name) => {
-        getItemsFromNamedDeclaration(patternMatcher, name, declarations, checker, sourceFile.fileName, rawItems);
-      });
-    }
-    rawItems.sort(compareNavigateToItems);
-    return (maxResultCount === void 0 ? rawItems : rawItems.slice(0, maxResultCount)).map(createNavigateToItem);
-  }
-  function getItemsFromNamedDeclaration(patternMatcher, name, declarations, checker, fileName, rawItems) {
-    const match = patternMatcher.getMatchForLastSegmentOfPattern(name);
-    if (!match) {
-      return;
-    }
-    for (const declaration of declarations) {
-      if (!shouldKeepItem(declaration, checker))
-        continue;
-      if (patternMatcher.patternContainsDots) {
-        const fullMatch = patternMatcher.getFullMatch(getContainers(declaration), name);
-        if (fullMatch) {
-          rawItems.push({ name, fileName, matchKind: fullMatch.kind, isCaseSensitive: fullMatch.isCaseSensitive, declaration });
-        }
-      } else {
-        rawItems.push({ name, fileName, matchKind: match.kind, isCaseSensitive: match.isCaseSensitive, declaration });
-      }
-    }
-  }
-  function shouldKeepItem(declaration, checker) {
-    switch (declaration.kind) {
-      case 272 /* ImportClause */:
-      case 275 /* ImportSpecifier */:
-      case 270 /* ImportEqualsDeclaration */:
-        const importer = checker.getSymbolAtLocation(declaration.name);
-        const imported = checker.getAliasedSymbol(importer);
-        return importer.escapedName !== imported.escapedName;
-      default:
-        return true;
-    }
-  }
-  function tryAddSingleDeclarationName(declaration, containers) {
-    const name = getNameOfDeclaration(declaration);
-    return !!name && (pushLiteral(name, containers) || name.kind === 166 /* ComputedPropertyName */ && tryAddComputedPropertyName(name.expression, containers));
-  }
-  function tryAddComputedPropertyName(expression, containers) {
-    return pushLiteral(expression, containers) || isPropertyAccessExpression(expression) && (containers.push(expression.name.text), true) && tryAddComputedPropertyName(expression.expression, containers);
-  }
-  function pushLiteral(node, containers) {
-    return isPropertyNameLiteral(node) && (containers.push(getTextOfIdentifierOrLiteral(node)), true);
-  }
-  function getContainers(declaration) {
-    const containers = [];
-    const name = getNameOfDeclaration(declaration);
-    if (name && name.kind === 166 /* ComputedPropertyName */ && !tryAddComputedPropertyName(name.expression, containers)) {
-      return emptyArray;
-    }
-    containers.shift();
-    let container = getContainerNode(declaration);
-    while (container) {
-      if (!tryAddSingleDeclarationName(container, containers)) {
-        return emptyArray;
-      }
-      container = getContainerNode(container);
-    }
-    return containers.reverse();
-  }
-  function compareNavigateToItems(i1, i2) {
-    return compareValues(i1.matchKind, i2.matchKind) || compareStringsCaseSensitiveUI(i1.name, i2.name);
-  }
-  function createNavigateToItem(rawItem) {
-    const declaration = rawItem.declaration;
-    const container = getContainerNode(declaration);
-    const containerName = container && getNameOfDeclaration(container);
-    return {
-      name: rawItem.name,
-      kind: getNodeKind(declaration),
-      kindModifiers: getNodeModifiers(declaration),
-      matchKind: PatternMatchKind[rawItem.matchKind],
-      isCaseSensitive: rawItem.isCaseSensitive,
-      fileName: rawItem.fileName,
-      textSpan: createTextSpanFromNode(declaration),
-      // TODO(jfreeman): What should be the containerName when the container has a computed name?
-      containerName: containerName ? containerName.text : "",
-      containerKind: containerName ? getNodeKind(container) : "" /* unknown */
-    };
-  }
-  var init_navigateTo = __esm({
-    "src/services/navigateTo.ts"() {
-      "use strict";
-      init_ts4();
-    }
-  });
-
-  // src/services/_namespaces/ts.NavigateTo.ts
-  var ts_NavigateTo_exports = {};
-  __export(ts_NavigateTo_exports, {
-    getNavigateToItems: () => getNavigateToItems
-  });
-  var init_ts_NavigateTo = __esm({
-    "src/services/_namespaces/ts.NavigateTo.ts"() {
-      "use strict";
-      init_navigateTo();
-    }
-  });
-
-  // src/services/navigationBar.ts
-  function getNavigationBarItems(sourceFile, cancellationToken) {
-    curCancellationToken = cancellationToken;
-    curSourceFile = sourceFile;
-    try {
-      return map(primaryNavBarMenuItems(rootNavigationBarNode(sourceFile)), convertToPrimaryNavBarMenuItem);
-    } finally {
-      reset();
-    }
-  }
-  function getNavigationTree(sourceFile, cancellationToken) {
-    curCancellationToken = cancellationToken;
-    curSourceFile = sourceFile;
-    try {
-      return convertToTree(rootNavigationBarNode(sourceFile));
-    } finally {
-      reset();
-    }
-  }
-  function reset() {
-    curSourceFile = void 0;
-    curCancellationToken = void 0;
-    parentsStack = [];
-    parent = void 0;
-    emptyChildItemArray = [];
-  }
-  function nodeText(node) {
-    return cleanText(node.getText(curSourceFile));
-  }
-  function navigationBarNodeKind(n) {
-    return n.node.kind;
-  }
-  function pushChild(parent2, child) {
-    if (parent2.children) {
-      parent2.children.push(child);
-    } else {
-      parent2.children = [child];
-    }
-  }
-  function rootNavigationBarNode(sourceFile) {
-    Debug.assert(!parentsStack.length);
-    const root = { node: sourceFile, name: void 0, additionalNodes: void 0, parent: void 0, children: void 0, indent: 0 };
-    parent = root;
-    for (const statement of sourceFile.statements) {
-      addChildrenRecursively(statement);
-    }
-    endNode();
-    Debug.assert(!parent && !parentsStack.length);
-    return root;
-  }
-  function addLeafNode(node, name) {
-    pushChild(parent, emptyNavigationBarNode(node, name));
-  }
-  function emptyNavigationBarNode(node, name) {
-    return {
-      node,
-      name: name || (isDeclaration(node) || isExpression(node) ? getNameOfDeclaration(node) : void 0),
-      additionalNodes: void 0,
-      parent,
-      children: void 0,
-      indent: parent.indent + 1
-    };
-  }
-  function addTrackedEs5Class(name) {
-    if (!trackedEs5Classes) {
-      trackedEs5Classes = /* @__PURE__ */ new Map();
-    }
-    trackedEs5Classes.set(name, true);
-  }
-  function endNestedNodes(depth) {
-    for (let i = 0; i < depth; i++)
-      endNode();
-  }
-  function startNestedNodes(targetNode, entityName) {
-    const names = [];
-    while (!isPropertyNameLiteral(entityName)) {
-      const name = getNameOrArgument(entityName);
-      const nameText = getElementOrPropertyAccessName(entityName);
-      entityName = entityName.expression;
-      if (nameText === "prototype" || isPrivateIdentifier(name))
-        continue;
-      names.push(name);
-    }
-    names.push(entityName);
-    for (let i = names.length - 1; i > 0; i--) {
-      const name = names[i];
-      startNode(targetNode, name);
-    }
-    return [names.length - 1, names[0]];
-  }
-  function startNode(node, name) {
-    const navNode = emptyNavigationBarNode(node, name);
-    pushChild(parent, navNode);
-    parentsStack.push(parent);
-    trackedEs5ClassesStack.push(trackedEs5Classes);
-    trackedEs5Classes = void 0;
-    parent = navNode;
-  }
-  function endNode() {
-    if (parent.children) {
-      mergeChildren(parent.children, parent);
-      sortChildren(parent.children);
-    }
-    parent = parentsStack.pop();
-    trackedEs5Classes = trackedEs5ClassesStack.pop();
-  }
-  function addNodeWithRecursiveChild(node, child, name) {
-    startNode(node, name);
-    addChildrenRecursively(child);
-    endNode();
-  }
-  function addNodeWithRecursiveInitializer(node) {
-    if (node.initializer && isFunctionOrClassExpression(node.initializer)) {
-      startNode(node);
-      forEachChild(node.initializer, addChildrenRecursively);
-      endNode();
-    } else {
-      addNodeWithRecursiveChild(node, node.initializer);
-    }
-  }
-  function hasNavigationBarName(node) {
-    return !hasDynamicName(node) || node.kind !== 225 /* BinaryExpression */ && isPropertyAccessExpression(node.name.expression) && isIdentifier(node.name.expression.expression) && idText(node.name.expression.expression) === "Symbol";
-  }
-  function addChildrenRecursively(node) {
-    curCancellationToken.throwIfCancellationRequested();
-    if (!node || isToken(node)) {
-      return;
-    }
-    switch (node.kind) {
-      case 175 /* Constructor */:
-        const ctr = node;
-        addNodeWithRecursiveChild(ctr, ctr.body);
-        for (const param of ctr.parameters) {
-          if (isParameterPropertyDeclaration(param, ctr)) {
-            addLeafNode(param);
-          }
-        }
-        break;
-      case 173 /* MethodDeclaration */:
-      case 176 /* GetAccessor */:
-      case 177 /* SetAccessor */:
-      case 172 /* MethodSignature */:
-        if (hasNavigationBarName(node)) {
-          addNodeWithRecursiveChild(node, node.body);
-        }
-        break;
-      case 171 /* PropertyDeclaration */:
-        if (hasNavigationBarName(node)) {
-          addNodeWithRecursiveInitializer(node);
-        }
-        break;
-      case 170 /* PropertySignature */:
-        if (hasNavigationBarName(node)) {
-          addLeafNode(node);
-        }
-        break;
-      case 272 /* ImportClause */:
-        const importClause = node;
-        if (importClause.name) {
-          addLeafNode(importClause.name);
-        }
-        const { namedBindings } = importClause;
-        if (namedBindings) {
-          if (namedBindings.kind === 273 /* NamespaceImport */) {
-            addLeafNode(namedBindings);
-          } else {
-            for (const element of namedBindings.elements) {
-              addLeafNode(element);
-            }
-          }
-        }
-        break;
-      case 303 /* ShorthandPropertyAssignment */:
-        addNodeWithRecursiveChild(node, node.name);
-        break;
-      case 304 /* SpreadAssignment */:
-        const { expression } = node;
-        isIdentifier(expression) ? addLeafNode(node, expression) : addLeafNode(node);
-        break;
-      case 207 /* BindingElement */:
-      case 302 /* PropertyAssignment */:
-      case 259 /* VariableDeclaration */: {
-        const child = node;
-        if (isBindingPattern(child.name)) {
-          addChildrenRecursively(child.name);
-        } else {
-          addNodeWithRecursiveInitializer(child);
-        }
-        break;
-      }
-      case 261 /* FunctionDeclaration */:
-        const nameNode = node.name;
-        if (nameNode && isIdentifier(nameNode)) {
-          addTrackedEs5Class(nameNode.text);
-        }
-        addNodeWithRecursiveChild(node, node.body);
-        break;
-      case 218 /* ArrowFunction */:
-      case 217 /* FunctionExpression */:
-        addNodeWithRecursiveChild(node, node.body);
-        break;
-      case 265 /* EnumDeclaration */:
-        startNode(node);
-        for (const member of node.members) {
-          if (!isComputedProperty(member)) {
-            addLeafNode(member);
-          }
-        }
-        endNode();
-        break;
-      case 262 /* ClassDeclaration */:
-      case 230 /* ClassExpression */:
-      case 263 /* InterfaceDeclaration */:
-        startNode(node);
-        for (const member of node.members) {
-          addChildrenRecursively(member);
-        }
-        endNode();
-        break;
-      case 266 /* ModuleDeclaration */:
-        addNodeWithRecursiveChild(node, getInteriorModule(node).body);
-        break;
-      case 276 /* ExportAssignment */: {
-        const expression2 = node.expression;
-        const child = isObjectLiteralExpression(expression2) || isCallExpression(expression2) ? expression2 : isArrowFunction(expression2) || isFunctionExpression(expression2) ? expression2.body : void 0;
-        if (child) {
-          startNode(node);
-          addChildrenRecursively(child);
-          endNode();
-        } else {
-          addLeafNode(node);
-        }
-        break;
-      }
-      case 280 /* ExportSpecifier */:
-      case 270 /* ImportEqualsDeclaration */:
-      case 180 /* IndexSignature */:
-      case 178 /* CallSignature */:
-      case 179 /* ConstructSignature */:
-      case 264 /* TypeAliasDeclaration */:
-        addLeafNode(node);
-        break;
-      case 212 /* CallExpression */:
-      case 225 /* BinaryExpression */: {
-        const special = getAssignmentDeclarationKind(node);
-        switch (special) {
-          case 1 /* ExportsProperty */:
-          case 2 /* ModuleExports */:
-            addNodeWithRecursiveChild(node, node.right);
-            return;
-          case 6 /* Prototype */:
-          case 3 /* PrototypeProperty */: {
-            const binaryExpression = node;
-            const assignmentTarget = binaryExpression.left;
-            const prototypeAccess = special === 3 /* PrototypeProperty */ ? assignmentTarget.expression : assignmentTarget;
-            let depth = 0;
-            let className;
-            if (isIdentifier(prototypeAccess.expression)) {
-              addTrackedEs5Class(prototypeAccess.expression.text);
-              className = prototypeAccess.expression;
-            } else {
-              [depth, className] = startNestedNodes(binaryExpression, prototypeAccess.expression);
-            }
-            if (special === 6 /* Prototype */) {
-              if (isObjectLiteralExpression(binaryExpression.right)) {
-                if (binaryExpression.right.properties.length > 0) {
-                  startNode(binaryExpression, className);
-                  forEachChild(binaryExpression.right, addChildrenRecursively);
-                  endNode();
-                }
-              }
-            } else if (isFunctionExpression(binaryExpression.right) || isArrowFunction(binaryExpression.right)) {
-              addNodeWithRecursiveChild(
-                node,
-                binaryExpression.right,
-                className
-              );
-            } else {
-              startNode(binaryExpression, className);
-              addNodeWithRecursiveChild(node, binaryExpression.right, assignmentTarget.name);
-              endNode();
-            }
-            endNestedNodes(depth);
-            return;
-          }
-          case 7 /* ObjectDefinePropertyValue */:
-          case 9 /* ObjectDefinePrototypeProperty */: {
-            const defineCall = node;
-            const className = special === 7 /* ObjectDefinePropertyValue */ ? defineCall.arguments[0] : defineCall.arguments[0].expression;
-            const memberName = defineCall.arguments[1];
-            const [depth, classNameIdentifier] = startNestedNodes(node, className);
-            startNode(node, classNameIdentifier);
-            startNode(node, setTextRange(factory.createIdentifier(memberName.text), memberName));
-            addChildrenRecursively(node.arguments[2]);
-            endNode();
-            endNode();
-            endNestedNodes(depth);
-            return;
-          }
-          case 5 /* Property */: {
-            const binaryExpression = node;
-            const assignmentTarget = binaryExpression.left;
-            const targetFunction = assignmentTarget.expression;
-            if (isIdentifier(targetFunction) && getElementOrPropertyAccessName(assignmentTarget) !== "prototype" && trackedEs5Classes && trackedEs5Classes.has(targetFunction.text)) {
-              if (isFunctionExpression(binaryExpression.right) || isArrowFunction(binaryExpression.right)) {
-                addNodeWithRecursiveChild(node, binaryExpression.right, targetFunction);
-              } else if (isBindableStaticAccessExpression(assignmentTarget)) {
-                startNode(binaryExpression, targetFunction);
-                addNodeWithRecursiveChild(binaryExpression.left, binaryExpression.right, getNameOrArgument(assignmentTarget));
-                endNode();
-              }
-              return;
-            }
-            break;
-          }
-          case 4 /* ThisProperty */:
-          case 0 /* None */:
-          case 8 /* ObjectDefinePropertyExports */:
-            break;
-          default:
-            Debug.assertNever(special);
-        }
-      }
-      default:
-        if (hasJSDocNodes(node)) {
-          forEach(node.jsDoc, (jsDoc) => {
-            forEach(jsDoc.tags, (tag) => {
-              if (isJSDocTypeAlias(tag)) {
-                addLeafNode(tag);
-              }
-            });
-          });
-        }
-        forEachChild(node, addChildrenRecursively);
-    }
-  }
-  function mergeChildren(children, node) {
-    const nameToItems = /* @__PURE__ */ new Map();
-    filterMutate(children, (child, index) => {
-      const declName = child.name || getNameOfDeclaration(child.node);
-      const name = declName && nodeText(declName);
-      if (!name) {
-        return true;
-      }
-      const itemsWithSameName = nameToItems.get(name);
-      if (!itemsWithSameName) {
-        nameToItems.set(name, child);
-        return true;
-      }
-      if (itemsWithSameName instanceof Array) {
-        for (const itemWithSameName of itemsWithSameName) {
-          if (tryMerge(itemWithSameName, child, index, node)) {
-            return false;
-          }
-        }
-        itemsWithSameName.push(child);
-        return true;
-      } else {
-        const itemWithSameName = itemsWithSameName;
-        if (tryMerge(itemWithSameName, child, index, node)) {
-          return false;
-        }
-        nameToItems.set(name, [itemWithSameName, child]);
-        return true;
-      }
-    });
-  }
-  function tryMergeEs5Class(a, b, bIndex, parent2) {
-    function isPossibleConstructor(node) {
-      return isFunctionExpression(node) || isFunctionDeclaration(node) || isVariableDeclaration(node);
-    }
-    const bAssignmentDeclarationKind = isBinaryExpression(b.node) || isCallExpression(b.node) ? getAssignmentDeclarationKind(b.node) : 0 /* None */;
-    const aAssignmentDeclarationKind = isBinaryExpression(a.node) || isCallExpression(a.node) ? getAssignmentDeclarationKind(a.node) : 0 /* None */;
-    if (isEs5ClassMember[bAssignmentDeclarationKind] && isEs5ClassMember[aAssignmentDeclarationKind] || isPossibleConstructor(a.node) && isEs5ClassMember[bAssignmentDeclarationKind] || isPossibleConstructor(b.node) && isEs5ClassMember[aAssignmentDeclarationKind] || isClassDeclaration(a.node) && isSynthesized(a.node) && isEs5ClassMember[bAssignmentDeclarationKind] || isClassDeclaration(b.node) && isEs5ClassMember[aAssignmentDeclarationKind] || isClassDeclaration(a.node) && isSynthesized(a.node) && isPossibleConstructor(b.node) || isClassDeclaration(b.node) && isPossibleConstructor(a.node) && isSynthesized(a.node)) {
-      let lastANode = a.additionalNodes && lastOrUndefined(a.additionalNodes) || a.node;
-      if (!isClassDeclaration(a.node) && !isClassDeclaration(b.node) || isPossibleConstructor(a.node) || isPossibleConstructor(b.node)) {
-        const ctorFunction = isPossibleConstructor(a.node) ? a.node : isPossibleConstructor(b.node) ? b.node : void 0;
-        if (ctorFunction !== void 0) {
-          const ctorNode = setTextRange(
-            factory.createConstructorDeclaration(
-              /*modifiers*/
-              void 0,
-              [],
-              /*body*/
-              void 0
-            ),
-            ctorFunction
-          );
-          const ctor = emptyNavigationBarNode(ctorNode);
-          ctor.indent = a.indent + 1;
-          ctor.children = a.node === ctorFunction ? a.children : b.children;
-          a.children = a.node === ctorFunction ? concatenate([ctor], b.children || [b]) : concatenate(a.children || [{ ...a }], [ctor]);
-        } else {
-          if (a.children || b.children) {
-            a.children = concatenate(a.children || [{ ...a }], b.children || [b]);
-            if (a.children) {
-              mergeChildren(a.children, a);
-              sortChildren(a.children);
-            }
-          }
-        }
-        lastANode = a.node = setTextRange(factory.createClassDeclaration(
-          /*modifiers*/
-          void 0,
-          a.name || factory.createIdentifier("__class__"),
-          /*typeParameters*/
-          void 0,
-          /*heritageClauses*/
-          void 0,
-          []
-        ), a.node);
-      } else {
-        a.children = concatenate(a.children, b.children);
-        if (a.children) {
-          mergeChildren(a.children, a);
-        }
-      }
-      const bNode = b.node;
-      if (parent2.children[bIndex - 1].node.end === lastANode.end) {
-        setTextRange(lastANode, { pos: lastANode.pos, end: bNode.end });
-      } else {
-        if (!a.additionalNodes)
-          a.additionalNodes = [];
-        a.additionalNodes.push(setTextRange(factory.createClassDeclaration(
-          /*modifiers*/
-          void 0,
-          a.name || factory.createIdentifier("__class__"),
-          /*typeParameters*/
-          void 0,
-          /*heritageClauses*/
-          void 0,
-          []
-        ), b.node));
-      }
-      return true;
-    }
-    return bAssignmentDeclarationKind === 0 /* None */ ? false : true;
-  }
-  function tryMerge(a, b, bIndex, parent2) {
-    if (tryMergeEs5Class(a, b, bIndex, parent2)) {
-      return true;
-    }
-    if (shouldReallyMerge(a.node, b.node, parent2)) {
-      merge(a, b);
-      return true;
-    }
-    return false;
-  }
-  function shouldReallyMerge(a, b, parent2) {
-    if (a.kind !== b.kind || a.parent !== b.parent && !(isOwnChild(a, parent2) && isOwnChild(b, parent2))) {
-      return false;
-    }
-    switch (a.kind) {
-      case 171 /* PropertyDeclaration */:
-      case 173 /* MethodDeclaration */:
-      case 176 /* GetAccessor */:
-      case 177 /* SetAccessor */:
-        return isStatic(a) === isStatic(b);
-      case 266 /* ModuleDeclaration */:
-        return areSameModule(a, b) && getFullyQualifiedModuleName(a) === getFullyQualifiedModuleName(b);
-      default:
-        return true;
-    }
-  }
-  function isSynthesized(node) {
-    return !!(node.flags & 8 /* Synthesized */);
-  }
-  function isOwnChild(n, parent2) {
-    const par = isModuleBlock(n.parent) ? n.parent.parent : n.parent;
-    return par === parent2.node || contains(parent2.additionalNodes, par);
-  }
-  function areSameModule(a, b) {
-    if (!a.body || !b.body) {
-      return a.body === b.body;
-    }
-    return a.body.kind === b.body.kind && (a.body.kind !== 266 /* ModuleDeclaration */ || areSameModule(a.body, b.body));
-  }
-  function merge(target, source) {
-    target.additionalNodes = target.additionalNodes || [];
-    target.additionalNodes.push(source.node);
-    if (source.additionalNodes) {
-      target.additionalNodes.push(...source.additionalNodes);
-    }
-    target.children = concatenate(target.children, source.children);
-    if (target.children) {
-      mergeChildren(target.children, target);
-      sortChildren(target.children);
-    }
-  }
-  function sortChildren(children) {
-    children.sort(compareChildren);
-  }
-  function compareChildren(child1, child2) {
-    return compareStringsCaseSensitiveUI(tryGetName(child1.node), tryGetName(child2.node)) || compareValues(navigationBarNodeKind(child1), navigationBarNodeKind(child2));
-  }
-  function tryGetName(node) {
-    if (node.kind === 266 /* ModuleDeclaration */) {
-      return getModuleName(node);
-    }
-    const declName = getNameOfDeclaration(node);
-    if (declName && isPropertyName(declName)) {
-      const propertyName = getPropertyNameForPropertyNameNode(declName);
-      return propertyName && unescapeLeadingUnderscores(propertyName);
-    }
-    switch (node.kind) {
-      case 217 /* FunctionExpression */:
-      case 218 /* ArrowFunction */:
-      case 230 /* ClassExpression */:
-        return getFunctionOrClassName(node);
-      default:
-        return void 0;
-    }
-  }
-  function getItemName(node, name) {
-    if (node.kind === 266 /* ModuleDeclaration */) {
-      return cleanText(getModuleName(node));
-    }
-    if (name) {
-      const text = isIdentifier(name) ? name.text : isElementAccessExpression(name) ? `[${nodeText(name.argumentExpression)}]` : nodeText(name);
-      if (text.length > 0) {
-        return cleanText(text);
-      }
-    }
-    switch (node.kind) {
-      case 311 /* SourceFile */:
-        const sourceFile = node;
-        return isExternalModule(sourceFile) ? `"${escapeString(getBaseFileName(removeFileExtension(normalizePath(sourceFile.fileName))))}"` : "";
-      case 276 /* ExportAssignment */:
-        return isExportAssignment(node) && node.isExportEquals ? "export=" /* ExportEquals */ : "default" /* Default */;
-      case 218 /* ArrowFunction */:
-      case 261 /* FunctionDeclaration */:
-      case 217 /* FunctionExpression */:
-      case 262 /* ClassDeclaration */:
-      case 230 /* ClassExpression */:
-        if (getSyntacticModifierFlags(node) & 1024 /* Default */) {
-          return "default";
-        }
-        return getFunctionOrClassName(node);
-      case 175 /* Constructor */:
-        return "constructor";
-      case 179 /* ConstructSignature */:
-        return "new()";
-      case 178 /* CallSignature */:
-        return "()";
-      case 180 /* IndexSignature */:
-        return "[]";
-      default:
-        return "";
-    }
-  }
-  function primaryNavBarMenuItems(root) {
-    const primaryNavBarMenuItems2 = [];
-    function recur(item) {
-      if (shouldAppearInPrimaryNavBarMenu(item)) {
-        primaryNavBarMenuItems2.push(item);
-        if (item.children) {
-          for (const child of item.children) {
-            recur(child);
-          }
-        }
-      }
-    }
-    recur(root);
-    return primaryNavBarMenuItems2;
-    function shouldAppearInPrimaryNavBarMenu(item) {
-      if (item.children) {
-        return true;
-      }
-      switch (navigationBarNodeKind(item)) {
-        case 262 /* ClassDeclaration */:
-        case 230 /* ClassExpression */:
-        case 265 /* EnumDeclaration */:
-        case 263 /* InterfaceDeclaration */:
-        case 266 /* ModuleDeclaration */:
-        case 311 /* SourceFile */:
-        case 264 /* TypeAliasDeclaration */:
-        case 352 /* JSDocTypedefTag */:
-        case 344 /* JSDocCallbackTag */:
-          return true;
-        case 218 /* ArrowFunction */:
-        case 261 /* FunctionDeclaration */:
-        case 217 /* FunctionExpression */:
-          return isTopLevelFunctionDeclaration(item);
-        default:
-          return false;
-      }
-      function isTopLevelFunctionDeclaration(item2) {
-        if (!item2.node.body) {
-          return false;
-        }
-        switch (navigationBarNodeKind(item2.parent)) {
-          case 267 /* ModuleBlock */:
-          case 311 /* SourceFile */:
-          case 173 /* MethodDeclaration */:
-          case 175 /* Constructor */:
-            return true;
-          default:
-            return false;
-        }
-      }
-    }
-  }
-  function convertToTree(n) {
-    return {
-      text: getItemName(n.node, n.name),
-      kind: getNodeKind(n.node),
-      kindModifiers: getModifiers2(n.node),
-      spans: getSpans(n),
-      nameSpan: n.name && getNodeSpan(n.name),
-      childItems: map(n.children, convertToTree)
-    };
-  }
-  function convertToPrimaryNavBarMenuItem(n) {
-    return {
-      text: getItemName(n.node, n.name),
-      kind: getNodeKind(n.node),
-      kindModifiers: getModifiers2(n.node),
-      spans: getSpans(n),
-      childItems: map(n.children, convertToSecondaryNavBarMenuItem) || emptyChildItemArray,
-      indent: n.indent,
-      bolded: false,
-      grayed: false
-    };
-    function convertToSecondaryNavBarMenuItem(n2) {
-      return {
-        text: getItemName(n2.node, n2.name),
-        kind: getNodeKind(n2.node),
-        kindModifiers: getNodeModifiers(n2.node),
-        spans: getSpans(n2),
-        childItems: emptyChildItemArray,
-        indent: 0,
-        bolded: false,
-        grayed: false
-      };
-    }
-  }
-  function getSpans(n) {
-    const spans = [getNodeSpan(n.node)];
-    if (n.additionalNodes) {
-      for (const node of n.additionalNodes) {
-        spans.push(getNodeSpan(node));
-      }
-    }
-    return spans;
-  }
-  function getModuleName(moduleDeclaration) {
-    if (isAmbientModule(moduleDeclaration)) {
-      return getTextOfNode(moduleDeclaration.name);
-    }
-    return getFullyQualifiedModuleName(moduleDeclaration);
-  }
-  function getFullyQualifiedModuleName(moduleDeclaration) {
-    const result = [getTextOfIdentifierOrLiteral(moduleDeclaration.name)];
-    while (moduleDeclaration.body && moduleDeclaration.body.kind === 266 /* ModuleDeclaration */) {
-      moduleDeclaration = moduleDeclaration.body;
-      result.push(getTextOfIdentifierOrLiteral(moduleDeclaration.name));
-    }
-    return result.join(".");
-  }
-  function getInteriorModule(decl) {
-    return decl.body && isModuleDeclaration(decl.body) ? getInteriorModule(decl.body) : decl;
-  }
-  function isComputedProperty(member) {
-    return !member.name || member.name.kind === 166 /* ComputedPropertyName */;
-  }
-  function getNodeSpan(node) {
-    return node.kind === 311 /* SourceFile */ ? createTextSpanFromRange(node) : createTextSpanFromNode(node, curSourceFile);
-  }
-  function getModifiers2(node) {
-    if (node.parent && node.parent.kind === 259 /* VariableDeclaration */) {
-      node = node.parent;
-    }
-    return getNodeModifiers(node);
-  }
-  function getFunctionOrClassName(node) {
-    const { parent: parent2 } = node;
-    if (node.name && getFullWidth(node.name) > 0) {
-      return cleanText(declarationNameToString(node.name));
-    } else if (isVariableDeclaration(parent2)) {
-      return cleanText(declarationNameToString(parent2.name));
-    } else if (isBinaryExpression(parent2) && parent2.operatorToken.kind === 64 /* EqualsToken */) {
-      return nodeText(parent2.left).replace(whiteSpaceRegex, "");
-    } else if (isPropertyAssignment(parent2)) {
-      return nodeText(parent2.name);
-    } else if (getSyntacticModifierFlags(node) & 1024 /* Default */) {
-      return "default";
-    } else if (isClassLike(node)) {
-      return "";
-    } else if (isCallExpression(parent2)) {
-      let name = getCalledExpressionName(parent2.expression);
-      if (name !== void 0) {
-        name = cleanText(name);
-        if (name.length > maxLength) {
-          return `${name} callback`;
-        }
-        const args = cleanText(mapDefined(parent2.arguments, (a) => isStringLiteralLike(a) ? a.getText(curSourceFile) : void 0).join(", "));
-        return `${name}(${args}) callback`;
-      }
-    }
-    return "";
-  }
-  function getCalledExpressionName(expr) {
-    if (isIdentifier(expr)) {
-      return expr.text;
-    } else if (isPropertyAccessExpression(expr)) {
-      const left = getCalledExpressionName(expr.expression);
-      const right = expr.name.text;
-      return left === void 0 ? right : `${left}.${right}`;
-    } else {
-      return void 0;
-    }
-  }
-  function isFunctionOrClassExpression(node) {
-    switch (node.kind) {
-      case 218 /* ArrowFunction */:
-      case 217 /* FunctionExpression */:
-      case 230 /* ClassExpression */:
-        return true;
-      default:
-        return false;
-    }
-  }
-  function cleanText(text) {
-    text = text.length > maxLength ? text.substring(0, maxLength) + "..." : text;
-    return text.replace(/\\?(\r?\n|\r|\u2028|\u2029)/g, "");
-  }
-  var whiteSpaceRegex, maxLength, curCancellationToken, curSourceFile, parentsStack, parent, trackedEs5ClassesStack, trackedEs5Classes, emptyChildItemArray, isEs5ClassMember;
-  var init_navigationBar = __esm({
-    "src/services/navigationBar.ts"() {
-      "use strict";
-      init_ts4();
-      whiteSpaceRegex = /\s+/g;
-      maxLength = 150;
-      parentsStack = [];
-      trackedEs5ClassesStack = [];
-      emptyChildItemArray = [];
-      isEs5ClassMember = {
-        [5 /* Property */]: true,
-        [3 /* PrototypeProperty */]: true,
-        [7 /* ObjectDefinePropertyValue */]: true,
-        [9 /* ObjectDefinePrototypeProperty */]: true,
-        [0 /* None */]: false,
-        [1 /* ExportsProperty */]: false,
-        [2 /* ModuleExports */]: false,
-        [8 /* ObjectDefinePropertyExports */]: false,
-        [6 /* Prototype */]: true,
-        [4 /* ThisProperty */]: false
-      };
-    }
-  });
-
-  // src/services/_namespaces/ts.NavigationBar.ts
-  var ts_NavigationBar_exports = {};
-  __export(ts_NavigationBar_exports, {
-    getNavigationBarItems: () => getNavigationBarItems,
-    getNavigationTree: () => getNavigationTree
-  });
-  var init_ts_NavigationBar = __esm({
-    "src/services/_namespaces/ts.NavigationBar.ts"() {
-      "use strict";
-      init_navigationBar();
-    }
-  });
-
-  // src/services/refactorProvider.ts
-  function registerRefactor(name, refactor) {
-    refactors.set(name, refactor);
-  }
-  function getApplicableRefactors(context, includeInteractiveActions) {
-    return arrayFrom(flatMapIterator(refactors.values(), (refactor) => {
-      var _a;
-      return context.cancellationToken && context.cancellationToken.isCancellationRequested() || !((_a = refactor.kinds) == null ? void 0 : _a.some((kind) => refactorKindBeginsWith(kind, context.kind))) ? void 0 : refactor.getAvailableActions(context, includeInteractiveActions);
-    }));
-  }
-  function getEditsForRefactor(context, refactorName13, actionName2, interactiveRefactorArguments) {
-    const refactor = refactors.get(refactorName13);
-    return refactor && refactor.getEditsForAction(context, actionName2, interactiveRefactorArguments);
-  }
-  var refactors;
-  var init_refactorProvider = __esm({
-    "src/services/refactorProvider.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_refactor();
-      refactors = /* @__PURE__ */ new Map();
-    }
-  });
-
-  // src/services/refactors/convertExport.ts
-  function getInfo2(context, considerPartialSpans = true) {
-    const { file, program } = context;
-    const span = getRefactorContextSpan(context);
-    const token = getTokenAtPosition(file, span.start);
-    const exportNode = !!(token.parent && getSyntacticModifierFlags(token.parent) & 1 /* Export */) && considerPartialSpans ? token.parent : getParentNodeInSpan(token, file, span);
-    if (!exportNode || !isSourceFile(exportNode.parent) && !(isModuleBlock(exportNode.parent) && isAmbientModule(exportNode.parent.parent))) {
-      return { error: getLocaleSpecificMessage(Diagnostics.Could_not_find_export_statement) };
-    }
-    const checker = program.getTypeChecker();
-    const exportingModuleSymbol = getExportingModuleSymbol(exportNode.parent, checker);
-    const flags = getSyntacticModifierFlags(exportNode) || (isExportAssignment(exportNode) && !exportNode.isExportEquals ? 1025 /* ExportDefault */ : 0 /* None */);
-    const wasDefault = !!(flags & 1024 /* Default */);
-    if (!(flags & 1 /* Export */) || !wasDefault && exportingModuleSymbol.exports.has("default" /* Default */)) {
-      return { error: getLocaleSpecificMessage(Diagnostics.This_file_already_has_a_default_export) };
-    }
-    const noSymbolError = (id) => isIdentifier(id) && checker.getSymbolAtLocation(id) ? void 0 : { error: getLocaleSpecificMessage(Diagnostics.Can_only_convert_named_export) };
-    switch (exportNode.kind) {
-      case 261 /* FunctionDeclaration */:
-      case 262 /* ClassDeclaration */:
-      case 263 /* InterfaceDeclaration */:
-      case 265 /* EnumDeclaration */:
-      case 264 /* TypeAliasDeclaration */:
-      case 266 /* ModuleDeclaration */: {
-        const node = exportNode;
-        if (!node.name)
-          return void 0;
-        return noSymbolError(node.name) || { exportNode: node, exportName: node.name, wasDefault, exportingModuleSymbol };
-      }
-      case 242 /* VariableStatement */: {
-        const vs = exportNode;
-        if (!(vs.declarationList.flags & 2 /* Const */) || vs.declarationList.declarations.length !== 1) {
-          return void 0;
-        }
-        const decl = first(vs.declarationList.declarations);
-        if (!decl.initializer)
-          return void 0;
-        Debug.assert(!wasDefault, "Can't have a default flag here");
-        return noSymbolError(decl.name) || { exportNode: vs, exportName: decl.name, wasDefault, exportingModuleSymbol };
-      }
-      case 276 /* ExportAssignment */: {
-        const node = exportNode;
-        if (node.isExportEquals)
-          return void 0;
-        return noSymbolError(node.expression) || { exportNode: node, exportName: node.expression, wasDefault, exportingModuleSymbol };
-      }
-      default:
-        return void 0;
-    }
-  }
-  function doChange(exportingSourceFile, program, info, changes, cancellationToken) {
-    changeExport(exportingSourceFile, info, changes, program.getTypeChecker());
-    changeImports(program, info, changes, cancellationToken);
-  }
-  function changeExport(exportingSourceFile, { wasDefault, exportNode, exportName }, changes, checker) {
-    if (wasDefault) {
-      if (isExportAssignment(exportNode) && !exportNode.isExportEquals) {
-        const exp = exportNode.expression;
-        const spec = makeExportSpecifier(exp.text, exp.text);
-        changes.replaceNode(exportingSourceFile, exportNode, factory.createExportDeclaration(
-          /*modifiers*/
-          void 0,
-          /*isTypeOnly*/
-          false,
-          factory.createNamedExports([spec])
-        ));
-      } else {
-        changes.delete(exportingSourceFile, Debug.checkDefined(findModifier(exportNode, 90 /* DefaultKeyword */), "Should find a default keyword in modifier list"));
-      }
-    } else {
-      const exportKeyword = Debug.checkDefined(findModifier(exportNode, 95 /* ExportKeyword */), "Should find an export keyword in modifier list");
-      switch (exportNode.kind) {
-        case 261 /* FunctionDeclaration */:
-        case 262 /* ClassDeclaration */:
-        case 263 /* InterfaceDeclaration */:
-          changes.insertNodeAfter(exportingSourceFile, exportKeyword, factory.createToken(90 /* DefaultKeyword */));
-          break;
-        case 242 /* VariableStatement */:
-          const decl = first(exportNode.declarationList.declarations);
-          if (!ts_FindAllReferences_exports.Core.isSymbolReferencedInFile(exportName, checker, exportingSourceFile) && !decl.type) {
-            changes.replaceNode(exportingSourceFile, exportNode, factory.createExportDefault(Debug.checkDefined(decl.initializer, "Initializer was previously known to be present")));
-            break;
-          }
-        case 265 /* EnumDeclaration */:
-        case 264 /* TypeAliasDeclaration */:
-        case 266 /* ModuleDeclaration */:
-          changes.deleteModifier(exportingSourceFile, exportKeyword);
-          changes.insertNodeAfter(exportingSourceFile, exportNode, factory.createExportDefault(factory.createIdentifier(exportName.text)));
-          break;
-        default:
-          Debug.fail(`Unexpected exportNode kind ${exportNode.kind}`);
-      }
-    }
-  }
-  function changeImports(program, { wasDefault, exportName, exportingModuleSymbol }, changes, cancellationToken) {
-    const checker = program.getTypeChecker();
-    const exportSymbol = Debug.checkDefined(checker.getSymbolAtLocation(exportName), "Export name should resolve to a symbol");
-    ts_FindAllReferences_exports.Core.eachExportReference(program.getSourceFiles(), checker, cancellationToken, exportSymbol, exportingModuleSymbol, exportName.text, wasDefault, (ref) => {
-      if (exportName === ref)
-        return;
-      const importingSourceFile = ref.getSourceFile();
-      if (wasDefault) {
-        changeDefaultToNamedImport(importingSourceFile, ref, changes, exportName.text);
-      } else {
-        changeNamedToDefaultImport(importingSourceFile, ref, changes);
-      }
-    });
-  }
-  function changeDefaultToNamedImport(importingSourceFile, ref, changes, exportName) {
-    const { parent: parent2 } = ref;
-    switch (parent2.kind) {
-      case 210 /* PropertyAccessExpression */:
-        changes.replaceNode(importingSourceFile, ref, factory.createIdentifier(exportName));
-        break;
-      case 275 /* ImportSpecifier */:
-      case 280 /* ExportSpecifier */: {
-        const spec = parent2;
-        changes.replaceNode(importingSourceFile, spec, makeImportSpecifier(exportName, spec.name.text));
-        break;
-      }
-      case 272 /* ImportClause */: {
-        const clause = parent2;
-        Debug.assert(clause.name === ref, "Import clause name should match provided ref");
-        const spec = makeImportSpecifier(exportName, ref.text);
-        const { namedBindings } = clause;
-        if (!namedBindings) {
-          changes.replaceNode(importingSourceFile, ref, factory.createNamedImports([spec]));
-        } else if (namedBindings.kind === 273 /* NamespaceImport */) {
-          changes.deleteRange(importingSourceFile, { pos: ref.getStart(importingSourceFile), end: namedBindings.getStart(importingSourceFile) });
-          const quotePreference = isStringLiteral(clause.parent.moduleSpecifier) ? quotePreferenceFromString(clause.parent.moduleSpecifier, importingSourceFile) : 1 /* Double */;
-          const newImport = makeImport(
-            /*defaultImport*/
-            void 0,
-            [makeImportSpecifier(exportName, ref.text)],
-            clause.parent.moduleSpecifier,
-            quotePreference
-          );
-          changes.insertNodeAfter(importingSourceFile, clause.parent, newImport);
-        } else {
-          changes.delete(importingSourceFile, ref);
-          changes.insertNodeAtEndOfList(importingSourceFile, namedBindings.elements, spec);
-        }
-        break;
-      }
-      case 204 /* ImportType */:
-        const importTypeNode = parent2;
-        changes.replaceNode(importingSourceFile, parent2, factory.createImportTypeNode(importTypeNode.argument, importTypeNode.assertions, factory.createIdentifier(exportName), importTypeNode.typeArguments, importTypeNode.isTypeOf));
-        break;
-      default:
-        Debug.failBadSyntaxKind(parent2);
-    }
-  }
-  function changeNamedToDefaultImport(importingSourceFile, ref, changes) {
-    const parent2 = ref.parent;
-    switch (parent2.kind) {
-      case 210 /* PropertyAccessExpression */:
-        changes.replaceNode(importingSourceFile, ref, factory.createIdentifier("default"));
-        break;
-      case 275 /* ImportSpecifier */: {
-        const defaultImport = factory.createIdentifier(parent2.name.text);
-        if (parent2.parent.elements.length === 1) {
-          changes.replaceNode(importingSourceFile, parent2.parent, defaultImport);
-        } else {
-          changes.delete(importingSourceFile, parent2);
-          changes.insertNodeBefore(importingSourceFile, parent2.parent, defaultImport);
-        }
-        break;
-      }
-      case 280 /* ExportSpecifier */: {
-        changes.replaceNode(importingSourceFile, parent2, makeExportSpecifier("default", parent2.name.text));
-        break;
-      }
-      default:
-        Debug.assertNever(parent2, `Unexpected parent kind ${parent2.kind}`);
-    }
-  }
-  function makeImportSpecifier(propertyName, name) {
-    return factory.createImportSpecifier(
-      /*isTypeOnly*/
-      false,
-      propertyName === name ? void 0 : factory.createIdentifier(propertyName),
-      factory.createIdentifier(name)
-    );
-  }
-  function makeExportSpecifier(propertyName, name) {
-    return factory.createExportSpecifier(
-      /*isTypeOnly*/
-      false,
-      propertyName === name ? void 0 : factory.createIdentifier(propertyName),
-      factory.createIdentifier(name)
-    );
-  }
-  function getExportingModuleSymbol(parent2, checker) {
-    if (isSourceFile(parent2)) {
-      return parent2.symbol;
-    }
-    const symbol = parent2.parent.symbol;
-    if (symbol.valueDeclaration && isExternalModuleAugmentation(symbol.valueDeclaration)) {
-      return checker.getMergedSymbol(symbol);
-    }
-    return symbol;
-  }
-  var refactorName, defaultToNamedAction, namedToDefaultAction;
-  var init_convertExport = __esm({
-    "src/services/refactors/convertExport.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_refactor();
-      refactorName = "Convert export";
-      defaultToNamedAction = {
-        name: "Convert default export to named export",
-        description: Diagnostics.Convert_default_export_to_named_export.message,
-        kind: "refactor.rewrite.export.named"
-      };
-      namedToDefaultAction = {
-        name: "Convert named export to default export",
-        description: Diagnostics.Convert_named_export_to_default_export.message,
-        kind: "refactor.rewrite.export.default"
-      };
-      registerRefactor(refactorName, {
-        kinds: [
-          defaultToNamedAction.kind,
-          namedToDefaultAction.kind
-        ],
-        getAvailableActions: function getRefactorActionsToConvertBetweenNamedAndDefaultExports(context) {
-          const info = getInfo2(context, context.triggerReason === "invoked");
-          if (!info)
-            return emptyArray;
-          if (!isRefactorErrorInfo(info)) {
-            const action = info.wasDefault ? defaultToNamedAction : namedToDefaultAction;
-            return [{ name: refactorName, description: action.description, actions: [action] }];
-          }
-          if (context.preferences.provideRefactorNotApplicableReason) {
-            return [
-              { name: refactorName, description: Diagnostics.Convert_default_export_to_named_export.message, actions: [
-                { ...defaultToNamedAction, notApplicableReason: info.error },
-                { ...namedToDefaultAction, notApplicableReason: info.error }
-              ] }
-            ];
-          }
-          return emptyArray;
-        },
-        getEditsForAction: function getRefactorEditsToConvertBetweenNamedAndDefaultExports(context, actionName2) {
-          Debug.assert(actionName2 === defaultToNamedAction.name || actionName2 === namedToDefaultAction.name, "Unexpected action name");
-          const info = getInfo2(context);
-          Debug.assert(info && !isRefactorErrorInfo(info), "Expected applicable refactor info");
-          const edits = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange(context.file, context.program, info, t, context.cancellationToken));
-          return { edits, renameFilename: void 0, renameLocation: void 0 };
-        }
-      });
-    }
-  });
-
-  // src/services/refactors/convertImport.ts
-  function getImportConversionInfo(context, considerPartialSpans = true) {
-    const { file } = context;
-    const span = getRefactorContextSpan(context);
-    const token = getTokenAtPosition(file, span.start);
-    const importDecl = considerPartialSpans ? findAncestor(token, isImportDeclaration) : getParentNodeInSpan(token, file, span);
-    if (!importDecl || !isImportDeclaration(importDecl))
-      return { error: "Selection is not an import declaration." };
-    const end = span.start + span.length;
-    const nextToken = findNextToken(importDecl, importDecl.parent, file);
-    if (nextToken && end > nextToken.getStart())
-      return void 0;
-    const { importClause } = importDecl;
-    if (!importClause) {
-      return { error: getLocaleSpecificMessage(Diagnostics.Could_not_find_import_clause) };
-    }
-    if (!importClause.namedBindings) {
-      return { error: getLocaleSpecificMessage(Diagnostics.Could_not_find_namespace_import_or_named_imports) };
-    }
-    if (importClause.namedBindings.kind === 273 /* NamespaceImport */) {
-      return { convertTo: 0 /* Named */, import: importClause.namedBindings };
-    }
-    const shouldUseDefault = getShouldUseDefault(context.program, importClause);
-    return shouldUseDefault ? { convertTo: 1 /* Default */, import: importClause.namedBindings } : { convertTo: 2 /* Namespace */, import: importClause.namedBindings };
-  }
-  function getShouldUseDefault(program, importClause) {
-    return getAllowSyntheticDefaultImports(program.getCompilerOptions()) && isExportEqualsModule(importClause.parent.moduleSpecifier, program.getTypeChecker());
-  }
-  function doChange2(sourceFile, program, changes, info) {
-    const checker = program.getTypeChecker();
-    if (info.convertTo === 0 /* Named */) {
-      doChangeNamespaceToNamed(sourceFile, checker, changes, info.import, getAllowSyntheticDefaultImports(program.getCompilerOptions()));
-    } else {
-      doChangeNamedToNamespaceOrDefault(sourceFile, program, changes, info.import, info.convertTo === 1 /* Default */);
-    }
-  }
-  function doChangeNamespaceToNamed(sourceFile, checker, changes, toConvert, allowSyntheticDefaultImports) {
-    let usedAsNamespaceOrDefault = false;
-    const nodesToReplace = [];
-    const conflictingNames = /* @__PURE__ */ new Map();
-    ts_FindAllReferences_exports.Core.eachSymbolReferenceInFile(toConvert.name, checker, sourceFile, (id) => {
-      if (!isPropertyAccessOrQualifiedName(id.parent)) {
-        usedAsNamespaceOrDefault = true;
-      } else {
-        const exportName = getRightOfPropertyAccessOrQualifiedName(id.parent).text;
-        if (checker.resolveName(
-          exportName,
-          id,
-          67108863 /* All */,
-          /*excludeGlobals*/
-          true
-        )) {
-          conflictingNames.set(exportName, true);
-        }
-        Debug.assert(getLeftOfPropertyAccessOrQualifiedName(id.parent) === id, "Parent expression should match id");
-        nodesToReplace.push(id.parent);
-      }
-    });
-    const exportNameToImportName = /* @__PURE__ */ new Map();
-    for (const propertyAccessOrQualifiedName of nodesToReplace) {
-      const exportName = getRightOfPropertyAccessOrQualifiedName(propertyAccessOrQualifiedName).text;
-      let importName = exportNameToImportName.get(exportName);
-      if (importName === void 0) {
-        exportNameToImportName.set(exportName, importName = conflictingNames.has(exportName) ? getUniqueName(exportName, sourceFile) : exportName);
-      }
-      changes.replaceNode(sourceFile, propertyAccessOrQualifiedName, factory.createIdentifier(importName));
-    }
-    const importSpecifiers = [];
-    exportNameToImportName.forEach((name, propertyName) => {
-      importSpecifiers.push(factory.createImportSpecifier(
-        /*isTypeOnly*/
-        false,
-        name === propertyName ? void 0 : factory.createIdentifier(propertyName),
-        factory.createIdentifier(name)
-      ));
-    });
-    const importDecl = toConvert.parent.parent;
-    if (usedAsNamespaceOrDefault && !allowSyntheticDefaultImports) {
-      changes.insertNodeAfter(sourceFile, importDecl, updateImport(
-        importDecl,
-        /*defaultImportName*/
-        void 0,
-        importSpecifiers
-      ));
-    } else {
-      changes.replaceNode(sourceFile, importDecl, updateImport(importDecl, usedAsNamespaceOrDefault ? factory.createIdentifier(toConvert.name.text) : void 0, importSpecifiers));
-    }
-  }
-  function getRightOfPropertyAccessOrQualifiedName(propertyAccessOrQualifiedName) {
-    return isPropertyAccessExpression(propertyAccessOrQualifiedName) ? propertyAccessOrQualifiedName.name : propertyAccessOrQualifiedName.right;
-  }
-  function getLeftOfPropertyAccessOrQualifiedName(propertyAccessOrQualifiedName) {
-    return isPropertyAccessExpression(propertyAccessOrQualifiedName) ? propertyAccessOrQualifiedName.expression : propertyAccessOrQualifiedName.left;
-  }
-  function doChangeNamedToNamespaceOrDefault(sourceFile, program, changes, toConvert, shouldUseDefault = getShouldUseDefault(program, toConvert.parent)) {
-    const checker = program.getTypeChecker();
-    const importDecl = toConvert.parent.parent;
-    const { moduleSpecifier } = importDecl;
-    const toConvertSymbols = /* @__PURE__ */ new Set();
-    toConvert.elements.forEach((namedImport) => {
-      const symbol = checker.getSymbolAtLocation(namedImport.name);
-      if (symbol) {
-        toConvertSymbols.add(symbol);
-      }
-    });
-    const preferredName = moduleSpecifier && isStringLiteral(moduleSpecifier) ? ts_codefix_exports.moduleSpecifierToValidIdentifier(moduleSpecifier.text, 99 /* ESNext */) : "module";
-    function hasNamespaceNameConflict(namedImport) {
-      return !!ts_FindAllReferences_exports.Core.eachSymbolReferenceInFile(namedImport.name, checker, sourceFile, (id) => {
-        const symbol = checker.resolveName(
-          preferredName,
-          id,
-          67108863 /* All */,
-          /*excludeGlobals*/
-          true
-        );
-        if (symbol) {
-          if (toConvertSymbols.has(symbol)) {
-            return isExportSpecifier(id.parent);
-          }
-          return true;
-        }
-        return false;
-      });
-    }
-    const namespaceNameConflicts = toConvert.elements.some(hasNamespaceNameConflict);
-    const namespaceImportName = namespaceNameConflicts ? getUniqueName(preferredName, sourceFile) : preferredName;
-    const neededNamedImports = /* @__PURE__ */ new Set();
-    for (const element of toConvert.elements) {
-      const propertyName = (element.propertyName || element.name).text;
-      ts_FindAllReferences_exports.Core.eachSymbolReferenceInFile(element.name, checker, sourceFile, (id) => {
-        const access = factory.createPropertyAccessExpression(factory.createIdentifier(namespaceImportName), propertyName);
-        if (isShorthandPropertyAssignment(id.parent)) {
-          changes.replaceNode(sourceFile, id.parent, factory.createPropertyAssignment(id.text, access));
-        } else if (isExportSpecifier(id.parent)) {
-          neededNamedImports.add(element);
-        } else {
-          changes.replaceNode(sourceFile, id, access);
-        }
-      });
-    }
-    changes.replaceNode(sourceFile, toConvert, shouldUseDefault ? factory.createIdentifier(namespaceImportName) : factory.createNamespaceImport(factory.createIdentifier(namespaceImportName)));
-    if (neededNamedImports.size) {
-      const newNamedImports = arrayFrom(neededNamedImports.values(), (element) => factory.createImportSpecifier(element.isTypeOnly, element.propertyName && factory.createIdentifier(element.propertyName.text), factory.createIdentifier(element.name.text)));
-      changes.insertNodeAfter(sourceFile, toConvert.parent.parent, updateImport(
-        importDecl,
-        /*defaultImportName*/
-        void 0,
-        newNamedImports
-      ));
-    }
-  }
-  function isExportEqualsModule(moduleSpecifier, checker) {
-    const externalModule = checker.resolveExternalModuleName(moduleSpecifier);
-    if (!externalModule)
-      return false;
-    const exportEquals = checker.resolveExternalModuleSymbol(externalModule);
-    return externalModule !== exportEquals;
-  }
-  function updateImport(old, defaultImportName, elements) {
-    return factory.createImportDeclaration(
-      /*modifiers*/
-      void 0,
-      factory.createImportClause(
-        /*isTypeOnly*/
-        false,
-        defaultImportName,
-        elements && elements.length ? factory.createNamedImports(elements) : void 0
-      ),
-      old.moduleSpecifier,
-      /*assertClause*/
-      void 0
-    );
-  }
-  var refactorName2, actions;
-  var init_convertImport = __esm({
-    "src/services/refactors/convertImport.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_refactor();
-      refactorName2 = "Convert import";
-      actions = {
-        [0 /* Named */]: {
-          name: "Convert namespace import to named imports",
-          description: Diagnostics.Convert_namespace_import_to_named_imports.message,
-          kind: "refactor.rewrite.import.named"
-        },
-        [2 /* Namespace */]: {
-          name: "Convert named imports to namespace import",
-          description: Diagnostics.Convert_named_imports_to_namespace_import.message,
-          kind: "refactor.rewrite.import.namespace"
-        },
-        [1 /* Default */]: {
-          name: "Convert named imports to default import",
-          description: Diagnostics.Convert_named_imports_to_default_import.message,
-          kind: "refactor.rewrite.import.default"
-        }
-      };
-      registerRefactor(refactorName2, {
-        kinds: getOwnValues(actions).map((a) => a.kind),
-        getAvailableActions: function getRefactorActionsToConvertBetweenNamedAndNamespacedImports(context) {
-          const info = getImportConversionInfo(context, context.triggerReason === "invoked");
-          if (!info)
-            return emptyArray;
-          if (!isRefactorErrorInfo(info)) {
-            const action = actions[info.convertTo];
-            return [{ name: refactorName2, description: action.description, actions: [action] }];
-          }
-          if (context.preferences.provideRefactorNotApplicableReason) {
-            return getOwnValues(actions).map((action) => ({
-              name: refactorName2,
-              description: action.description,
-              actions: [{ ...action, notApplicableReason: info.error }]
-            }));
-          }
-          return emptyArray;
-        },
-        getEditsForAction: function getRefactorEditsToConvertBetweenNamedAndNamespacedImports(context, actionName2) {
-          Debug.assert(some(getOwnValues(actions), (action) => action.name === actionName2), "Unexpected action name");
-          const info = getImportConversionInfo(context);
-          Debug.assert(info && !isRefactorErrorInfo(info), "Expected applicable refactor info");
-          const edits = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange2(context.file, context.program, t, info));
-          return { edits, renameFilename: void 0, renameLocation: void 0 };
-        }
-      });
-    }
-  });
-
-  // src/services/refactors/extractType.ts
-  function getRangeToExtract(context, considerEmptySpans = true) {
-    const { file, startPosition } = context;
-    const isJS = isSourceFileJS(file);
-    const current = getTokenAtPosition(file, startPosition);
-    const range = createTextRangeFromSpan(getRefactorContextSpan(context));
-    const cursorRequest = range.pos === range.end && considerEmptySpans;
-    const selection = findAncestor(current, (node) => node.parent && isTypeNode(node) && !rangeContainsSkipTrivia(range, node.parent, file) && (cursorRequest || nodeOverlapsWithStartEnd(current, file, range.pos, range.end)));
-    if (!selection || !isTypeNode(selection))
-      return { error: getLocaleSpecificMessage(Diagnostics.Selection_is_not_a_valid_type_node) };
-    const checker = context.program.getTypeChecker();
-    const enclosingNode = getEnclosingNode(selection, isJS);
-    if (enclosingNode === void 0)
-      return { error: getLocaleSpecificMessage(Diagnostics.No_type_could_be_extracted_from_this_type_node) };
-    const typeParameters = collectTypeParameters(checker, selection, enclosingNode, file);
-    if (!typeParameters)
-      return { error: getLocaleSpecificMessage(Diagnostics.No_type_could_be_extracted_from_this_type_node) };
-    const typeElements = flattenTypeLiteralNodeReference(checker, selection);
-    return { isJS, selection, enclosingNode, typeParameters, typeElements };
-  }
-  function flattenTypeLiteralNodeReference(checker, node) {
-    if (!node)
-      return void 0;
-    if (isIntersectionTypeNode(node)) {
-      const result = [];
-      const seen = /* @__PURE__ */ new Map();
-      for (const type of node.types) {
-        const flattenedTypeMembers = flattenTypeLiteralNodeReference(checker, type);
-        if (!flattenedTypeMembers || !flattenedTypeMembers.every((type2) => type2.name && addToSeen(seen, getNameFromPropertyName(type2.name)))) {
-          return void 0;
-        }
-        addRange(result, flattenedTypeMembers);
-      }
-      return result;
-    } else if (isParenthesizedTypeNode(node)) {
-      return flattenTypeLiteralNodeReference(checker, node.type);
-    } else if (isTypeLiteralNode(node)) {
-      return node.members;
-    }
-    return void 0;
-  }
-  function rangeContainsSkipTrivia(r1, node, file) {
-    return rangeContainsStartEnd(r1, skipTrivia(file.text, node.pos), node.end);
-  }
-  function collectTypeParameters(checker, selection, enclosingNode, file) {
-    const result = [];
-    return visitor(selection) ? void 0 : result;
-    function visitor(node) {
-      if (isTypeReferenceNode(node)) {
-        if (isIdentifier(node.typeName)) {
-          const typeName = node.typeName;
-          const symbol = checker.resolveName(
-            typeName.text,
-            typeName,
-            262144 /* TypeParameter */,
-            /*excludeGlobals*/
-            true
-          );
-          for (const decl of (symbol == null ? void 0 : symbol.declarations) || emptyArray) {
-            if (isTypeParameterDeclaration(decl) && decl.getSourceFile() === file) {
-              if (decl.name.escapedText === typeName.escapedText && rangeContainsSkipTrivia(decl, selection, file)) {
-                return true;
-              }
-              if (rangeContainsSkipTrivia(enclosingNode, decl, file) && !rangeContainsSkipTrivia(selection, decl, file)) {
-                pushIfUnique(result, decl);
-                break;
-              }
-            }
-          }
-        }
-      } else if (isInferTypeNode(node)) {
-        const conditionalTypeNode = findAncestor(node, (n) => isConditionalTypeNode(n) && rangeContainsSkipTrivia(n.extendsType, node, file));
-        if (!conditionalTypeNode || !rangeContainsSkipTrivia(selection, conditionalTypeNode, file)) {
-          return true;
-        }
-      } else if (isTypePredicateNode(node) || isThisTypeNode(node)) {
-        const functionLikeNode = findAncestor(node.parent, isFunctionLike);
-        if (functionLikeNode && functionLikeNode.type && rangeContainsSkipTrivia(functionLikeNode.type, node, file) && !rangeContainsSkipTrivia(selection, functionLikeNode, file)) {
-          return true;
-        }
-      } else if (isTypeQueryNode(node)) {
-        if (isIdentifier(node.exprName)) {
-          const symbol = checker.resolveName(
-            node.exprName.text,
-            node.exprName,
-            111551 /* Value */,
-            /*excludeGlobals*/
-            false
-          );
-          if ((symbol == null ? void 0 : symbol.valueDeclaration) && rangeContainsSkipTrivia(enclosingNode, symbol.valueDeclaration, file) && !rangeContainsSkipTrivia(selection, symbol.valueDeclaration, file)) {
-            return true;
-          }
-        } else {
-          if (isThisIdentifier(node.exprName.left) && !rangeContainsSkipTrivia(selection, node.parent, file)) {
-            return true;
-          }
-        }
-      }
-      if (file && isTupleTypeNode(node) && getLineAndCharacterOfPosition(file, node.pos).line === getLineAndCharacterOfPosition(file, node.end).line) {
-        setEmitFlags(node, 1 /* SingleLine */);
-      }
-      return forEachChild(node, visitor);
-    }
-  }
-  function doTypeAliasChange(changes, file, name, info) {
-    const { enclosingNode, selection, typeParameters } = info;
-    const newTypeNode = factory.createTypeAliasDeclaration(
-      /*modifiers*/
-      void 0,
-      name,
-      typeParameters.map((id) => factory.updateTypeParameterDeclaration(
-        id,
-        id.modifiers,
-        id.name,
-        id.constraint,
-        /*defaultType*/
-        void 0
-      )),
-      selection
-    );
-    changes.insertNodeBefore(
-      file,
-      enclosingNode,
-      ignoreSourceNewlines(newTypeNode),
-      /*blankLineBetween*/
-      true
-    );
-    changes.replaceNode(file, selection, factory.createTypeReferenceNode(name, typeParameters.map((id) => factory.createTypeReferenceNode(
-      id.name,
-      /*typeArguments*/
-      void 0
-    ))), { leadingTriviaOption: ts_textChanges_exports.LeadingTriviaOption.Exclude, trailingTriviaOption: ts_textChanges_exports.TrailingTriviaOption.ExcludeWhitespace });
-  }
-  function doInterfaceChange(changes, file, name, info) {
-    var _a;
-    const { enclosingNode, selection, typeParameters, typeElements } = info;
-    const newTypeNode = factory.createInterfaceDeclaration(
-      /*modifiers*/
-      void 0,
-      name,
-      typeParameters,
-      /*heritageClauses*/
-      void 0,
-      typeElements
-    );
-    setTextRange(newTypeNode, (_a = typeElements[0]) == null ? void 0 : _a.parent);
-    changes.insertNodeBefore(
-      file,
-      enclosingNode,
-      ignoreSourceNewlines(newTypeNode),
-      /*blankLineBetween*/
-      true
-    );
-    changes.replaceNode(file, selection, factory.createTypeReferenceNode(name, typeParameters.map((id) => factory.createTypeReferenceNode(
-      id.name,
-      /*typeArguments*/
-      void 0
-    ))), { leadingTriviaOption: ts_textChanges_exports.LeadingTriviaOption.Exclude, trailingTriviaOption: ts_textChanges_exports.TrailingTriviaOption.ExcludeWhitespace });
-  }
-  function doTypedefChange(changes, context, file, name, info) {
-    var _a;
-    const { enclosingNode, selection, typeParameters } = info;
-    setEmitFlags(selection, 3072 /* NoComments */ | 4096 /* NoNestedComments */);
-    const node = factory.createJSDocTypedefTag(
-      factory.createIdentifier("typedef"),
-      factory.createJSDocTypeExpression(selection),
-      factory.createIdentifier(name)
-    );
-    const templates = [];
-    forEach(typeParameters, (typeParameter) => {
-      const constraint = getEffectiveConstraintOfTypeParameter(typeParameter);
-      const parameter = factory.createTypeParameterDeclaration(
-        /*modifiers*/
-        void 0,
-        typeParameter.name
-      );
-      const template = factory.createJSDocTemplateTag(
-        factory.createIdentifier("template"),
-        constraint && cast(constraint, isJSDocTypeExpression),
-        [parameter]
-      );
-      templates.push(template);
-    });
-    const jsDoc = factory.createJSDocComment(
-      /*comment*/
-      void 0,
-      factory.createNodeArray(concatenate(templates, [node]))
-    );
-    if (isJSDoc(enclosingNode)) {
-      const pos = enclosingNode.getStart(file);
-      const newLineCharacter = getNewLineOrDefaultFromHost(context.host, (_a = context.formatContext) == null ? void 0 : _a.options);
-      changes.insertNodeAt(file, enclosingNode.getStart(file), jsDoc, {
-        suffix: newLineCharacter + newLineCharacter + file.text.slice(getPrecedingNonSpaceCharacterPosition(file.text, pos - 1), pos)
-      });
-    } else {
-      changes.insertNodeBefore(
-        file,
-        enclosingNode,
-        jsDoc,
-        /*blankLineBetween*/
-        true
-      );
-    }
-    changes.replaceNode(file, selection, factory.createTypeReferenceNode(name, typeParameters.map((id) => factory.createTypeReferenceNode(
-      id.name,
-      /*typeArguments*/
-      void 0
-    ))));
-  }
-  function getEnclosingNode(node, isJS) {
-    return findAncestor(node, isStatement) || (isJS ? findAncestor(node, isJSDoc) : void 0);
-  }
-  var refactorName3, extractToTypeAliasAction, extractToInterfaceAction, extractToTypeDefAction;
-  var init_extractType = __esm({
-    "src/services/refactors/extractType.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_refactor();
-      refactorName3 = "Extract type";
-      extractToTypeAliasAction = {
-        name: "Extract to type alias",
-        description: getLocaleSpecificMessage(Diagnostics.Extract_to_type_alias),
-        kind: "refactor.extract.type"
-      };
-      extractToInterfaceAction = {
-        name: "Extract to interface",
-        description: getLocaleSpecificMessage(Diagnostics.Extract_to_interface),
-        kind: "refactor.extract.interface"
-      };
-      extractToTypeDefAction = {
-        name: "Extract to typedef",
-        description: getLocaleSpecificMessage(Diagnostics.Extract_to_typedef),
-        kind: "refactor.extract.typedef"
-      };
-      registerRefactor(refactorName3, {
-        kinds: [
-          extractToTypeAliasAction.kind,
-          extractToInterfaceAction.kind,
-          extractToTypeDefAction.kind
-        ],
-        getAvailableActions: function getRefactorActionsToExtractType(context) {
-          const info = getRangeToExtract(context, context.triggerReason === "invoked");
-          if (!info)
-            return emptyArray;
-          if (!isRefactorErrorInfo(info)) {
-            return [{
-              name: refactorName3,
-              description: getLocaleSpecificMessage(Diagnostics.Extract_type),
-              actions: info.isJS ? [extractToTypeDefAction] : append([extractToTypeAliasAction], info.typeElements && extractToInterfaceAction)
-            }];
-          }
-          if (context.preferences.provideRefactorNotApplicableReason) {
-            return [{
-              name: refactorName3,
-              description: getLocaleSpecificMessage(Diagnostics.Extract_type),
-              actions: [
-                { ...extractToTypeDefAction, notApplicableReason: info.error },
-                { ...extractToTypeAliasAction, notApplicableReason: info.error },
-                { ...extractToInterfaceAction, notApplicableReason: info.error }
-              ]
-            }];
-          }
-          return emptyArray;
-        },
-        getEditsForAction: function getRefactorEditsToExtractType(context, actionName2) {
-          const { file } = context;
-          const info = getRangeToExtract(context);
-          Debug.assert(info && !isRefactorErrorInfo(info), "Expected to find a range to extract");
-          const name = getUniqueName("NewType", file);
-          const edits = ts_textChanges_exports.ChangeTracker.with(context, (changes) => {
-            switch (actionName2) {
-              case extractToTypeAliasAction.name:
-                Debug.assert(!info.isJS, "Invalid actionName/JS combo");
-                return doTypeAliasChange(changes, file, name, info);
-              case extractToTypeDefAction.name:
-                Debug.assert(info.isJS, "Invalid actionName/JS combo");
-                return doTypedefChange(changes, context, file, name, info);
-              case extractToInterfaceAction.name:
-                Debug.assert(!info.isJS && !!info.typeElements, "Invalid actionName/JS combo");
-                return doInterfaceChange(changes, file, name, info);
-              default:
-                Debug.fail("Unexpected action name");
-            }
-          });
-          const renameFilename = file.fileName;
-          const renameLocation = getRenameLocation(
-            edits,
-            renameFilename,
-            name,
-            /*preferLastLocation*/
-            false
-          );
-          return { edits, renameFilename, renameLocation };
-        }
-      });
-    }
-  });
-
-  // src/services/refactors/helpers.ts
-  function isRefactorErrorInfo(info) {
-    return info.error !== void 0;
-  }
-  function refactorKindBeginsWith(known, requested) {
-    if (!requested)
-      return true;
-    return known.substr(0, requested.length) === requested;
-  }
-  var init_helpers = __esm({
-    "src/services/refactors/helpers.ts"() {
-      "use strict";
-    }
-  });
-
-  // src/services/refactors/moveToNewFile.ts
-  function doChange3(oldFile, program, toMove, changes, host, preferences, context) {
-    const checker = program.getTypeChecker();
-    const usage = getUsageInfo(oldFile, toMove.all, checker);
-    const newFilename = createNewFileName(oldFile, program, context, host);
-    changes.createNewFile(oldFile, newFilename, getNewStatementsAndRemoveFromOldFile(oldFile, usage, changes, toMove, program, host, newFilename, preferences));
-    addNewFileToTsconfig(program, changes, oldFile.fileName, newFilename, hostGetCanonicalFileName(host));
-  }
-  function getNewStatementsAndRemoveFromOldFile(oldFile, usage, changes, toMove, program, host, newFilename, preferences) {
-    const checker = program.getTypeChecker();
-    const prologueDirectives = takeWhile(oldFile.statements, isPrologueDirective);
-    if (oldFile.externalModuleIndicator === void 0 && oldFile.commonJsModuleIndicator === void 0 && usage.oldImportsNeededByTargetFile.size === 0) {
-      deleteMovedStatements(oldFile, toMove.ranges, changes);
-      return [...prologueDirectives, ...toMove.all];
-    }
-    const useEsModuleSyntax = !fileShouldUseJavaScriptRequire(newFilename, program, host, !!oldFile.commonJsModuleIndicator);
-    const quotePreference = getQuotePreference(oldFile, preferences);
-    const importsFromNewFile = createOldFileImportsFromTargetFile(oldFile, usage.oldFileImportsFromTargetFile, newFilename, program, host, useEsModuleSyntax, quotePreference);
-    if (importsFromNewFile) {
-      insertImports(
-        changes,
-        oldFile,
-        importsFromNewFile,
-        /*blankLineBetween*/
-        true,
-        preferences
-      );
-    }
-    deleteUnusedOldImports(oldFile, toMove.all, changes, usage.unusedImportsFromOldFile, checker);
-    deleteMovedStatements(oldFile, toMove.ranges, changes);
-    updateImportsInOtherFiles(changes, program, host, oldFile, usage.movedSymbols, newFilename, quotePreference);
-    const imports = getNewFileImportsAndAddExportInOldFile(oldFile, usage.oldImportsNeededByTargetFile, usage.targetFileImportsFromOldFile, changes, checker, program, host, useEsModuleSyntax, quotePreference);
-    const body = addExports(oldFile, toMove.all, usage.oldFileImportsFromTargetFile, useEsModuleSyntax);
-    if (imports.length && body.length) {
-      return [
-        ...prologueDirectives,
-        ...imports,
-        4 /* NewLineTrivia */,
-        ...body
-      ];
-    }
-    return [
-      ...prologueDirectives,
-      ...imports,
-      ...body
-    ];
-  }
-  function getNewFileImportsAndAddExportInOldFile(oldFile, importsToCopy, newFileImportsFromOldFile, changes, checker, program, host, useEsModuleSyntax, quotePreference) {
-    const copiedOldImports = [];
-    for (const oldStatement of oldFile.statements) {
-      forEachImportInStatement(oldStatement, (i) => {
-        append(copiedOldImports, filterImport(i, moduleSpecifierFromImport(i), (name) => importsToCopy.has(checker.getSymbolAtLocation(name))));
-      });
-    }
-    let oldFileDefault;
-    const oldFileNamedImports = [];
-    const markSeenTop = nodeSeenTracker();
-    newFileImportsFromOldFile.forEach((symbol) => {
-      if (!symbol.declarations) {
-        return;
-      }
-      for (const decl of symbol.declarations) {
-        if (!isTopLevelDeclaration(decl))
-          continue;
-        const name = nameOfTopLevelDeclaration(decl);
-        if (!name)
-          continue;
-        const top = getTopLevelDeclarationStatement(decl);
-        if (markSeenTop(top)) {
-          addExportToChanges(oldFile, top, name, changes, useEsModuleSyntax);
-        }
-        if (hasSyntacticModifier(decl, 1024 /* Default */)) {
-          oldFileDefault = name;
-        } else {
-          oldFileNamedImports.push(name.text);
-        }
-      }
-    });
-    append(copiedOldImports, makeImportOrRequire(oldFile, oldFileDefault, oldFileNamedImports, getBaseFileName(oldFile.fileName), program, host, useEsModuleSyntax, quotePreference));
-    return copiedOldImports;
-  }
-  var refactorName4, description, moveToNewFileAction;
-  var init_moveToNewFile = __esm({
-    "src/services/refactors/moveToNewFile.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_refactor();
-      refactorName4 = "Move to a new file";
-      description = getLocaleSpecificMessage(Diagnostics.Move_to_a_new_file);
-      moveToNewFileAction = {
-        name: refactorName4,
-        description,
-        kind: "refactor.move.newFile"
-      };
-      registerRefactor(refactorName4, {
-        kinds: [moveToNewFileAction.kind],
-        getAvailableActions: function getRefactorActionsToMoveToNewFile(context) {
-          const statements = getStatementsToMove(context);
-          if (context.preferences.allowTextChangesInNewFiles && statements) {
-            return [{ name: refactorName4, description, actions: [moveToNewFileAction] }];
-          }
-          if (context.preferences.provideRefactorNotApplicableReason) {
-            return [{
-              name: refactorName4,
-              description,
-              actions: [{ ...moveToNewFileAction, notApplicableReason: getLocaleSpecificMessage(Diagnostics.Selection_is_not_a_valid_statement_or_statements) }]
-            }];
-          }
-          return emptyArray;
-        },
-        getEditsForAction: function getRefactorEditsToMoveToNewFile(context, actionName2) {
-          Debug.assert(actionName2 === refactorName4, "Wrong refactor invoked");
-          const statements = Debug.checkDefined(getStatementsToMove(context));
-          const edits = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange3(context.file, context.program, statements, t, context.host, context.preferences, context));
-          return { edits, renameFilename: void 0, renameLocation: void 0 };
-        }
-      });
-    }
-  });
-
-  // src/services/refactors/moveToFile.ts
-  function doChange4(context, oldFile, targetFile, program, toMove, changes, host, preferences) {
-    const checker = program.getTypeChecker();
-    const usage = getUsageInfo(oldFile, toMove.all, checker);
-    if (!host.fileExists(targetFile)) {
-      changes.createNewFile(oldFile, targetFile, getNewStatementsAndRemoveFromOldFile2(oldFile, targetFile, usage, changes, toMove, program, host, preferences));
-      addNewFileToTsconfig(program, changes, oldFile.fileName, targetFile, hostGetCanonicalFileName(host));
-    } else {
-      const targetSourceFile = Debug.checkDefined(program.getSourceFile(targetFile));
-      const importAdder = ts_codefix_exports.createImportAdder(targetSourceFile, context.program, context.preferences, context.host);
-      getNewStatementsAndRemoveFromOldFile2(oldFile, targetSourceFile, usage, changes, toMove, program, host, preferences, importAdder);
-    }
-  }
-  function getNewStatementsAndRemoveFromOldFile2(oldFile, targetFile, usage, changes, toMove, program, host, preferences, importAdder) {
-    const checker = program.getTypeChecker();
-    const prologueDirectives = takeWhile(oldFile.statements, isPrologueDirective);
-    if (oldFile.externalModuleIndicator === void 0 && oldFile.commonJsModuleIndicator === void 0 && usage.oldImportsNeededByTargetFile.size === 0 && usage.targetFileImportsFromOldFile.size === 0 && typeof targetFile === "string") {
-      deleteMovedStatements(oldFile, toMove.ranges, changes);
-      return [...prologueDirectives, ...toMove.all];
-    }
-    const targetFileName = typeof targetFile === "string" ? targetFile : targetFile.fileName;
-    const useEsModuleSyntax = !fileShouldUseJavaScriptRequire(targetFileName, program, host, !!oldFile.commonJsModuleIndicator);
-    const quotePreference = getQuotePreference(oldFile, preferences);
-    const importsFromTargetFile = createOldFileImportsFromTargetFile(oldFile, usage.oldFileImportsFromTargetFile, targetFileName, program, host, useEsModuleSyntax, quotePreference);
-    if (importsFromTargetFile) {
-      insertImports(
-        changes,
-        oldFile,
-        importsFromTargetFile,
-        /*blankLineBetween*/
-        true,
-        preferences
-      );
-    }
-    deleteUnusedOldImports(oldFile, toMove.all, changes, usage.unusedImportsFromOldFile, checker);
-    deleteMovedStatements(oldFile, toMove.ranges, changes);
-    updateImportsInOtherFiles(changes, program, host, oldFile, usage.movedSymbols, targetFileName, quotePreference);
-    const imports = getTargetFileImportsAndAddExportInOldFile(oldFile, targetFileName, usage.oldImportsNeededByTargetFile, usage.targetFileImportsFromOldFile, changes, checker, program, host, useEsModuleSyntax, quotePreference, importAdder);
-    const body = addExports(oldFile, toMove.all, usage.oldFileImportsFromTargetFile, useEsModuleSyntax);
-    if (typeof targetFile !== "string") {
-      if (targetFile.statements.length > 0) {
-        changes.insertNodesAfter(targetFile, targetFile.statements[targetFile.statements.length - 1], body);
-      } else {
-        changes.insertNodesAtEndOfFile(
-          targetFile,
-          body,
-          /*blankLineBetween*/
-          false
-        );
-      }
-      if (imports.length > 0) {
-        insertImports(
-          changes,
-          targetFile,
-          imports,
-          /*blankLineBetween*/
-          true,
-          preferences
-        );
-      }
-    }
-    if (importAdder) {
-      importAdder.writeFixes(changes);
-    }
-    if (imports.length && body.length) {
-      return [
-        ...prologueDirectives,
-        ...imports,
-        4 /* NewLineTrivia */,
-        ...body
-      ];
-    }
-    return [
-      ...prologueDirectives,
-      ...imports,
-      ...body
-    ];
-  }
-  function getTargetFileImportsAndAddExportInOldFile(oldFile, targetFile, importsToCopy, targetFileImportsFromOldFile, changes, checker, program, host, useEsModuleSyntax, quotePreference, importAdder) {
-    const copiedOldImports = [];
-    if (importAdder) {
-      importsToCopy.forEach((isValidTypeOnlyUseSite, symbol) => {
-        try {
-          importAdder.addImportFromExportedSymbol(skipAlias(symbol, checker), isValidTypeOnlyUseSite);
-        } catch {
-          for (const oldStatement of oldFile.statements) {
-            forEachImportInStatement(oldStatement, (i) => {
-              append(copiedOldImports, filterImport(i, factory.createStringLiteral(moduleSpecifierFromImport(i).text), (name) => importsToCopy.has(checker.getSymbolAtLocation(name))));
-            });
-          }
-        }
-      });
-    } else {
-      const targetSourceFile = program.getSourceFile(targetFile);
-      for (const oldStatement of oldFile.statements) {
-        forEachImportInStatement(oldStatement, (i) => {
-          var _a, _b;
-          const moduleSpecifier = moduleSpecifierFromImport(i);
-          const resolved = (_a = oldFile.resolvedModules) == null ? void 0 : _a.get(moduleSpecifier.text, getModeForUsageLocation(oldFile, moduleSpecifier));
-          const fileName = (_b = resolved == null ? void 0 : resolved.resolvedModule) == null ? void 0 : _b.resolvedFileName;
-          if (fileName && targetSourceFile) {
-            const newModuleSpecifier = getModuleSpecifier(program.getCompilerOptions(), targetSourceFile, targetSourceFile.path, fileName, createModuleSpecifierResolutionHost(program, host));
-            append(copiedOldImports, filterImport(i, makeStringLiteral(newModuleSpecifier, quotePreference), (name) => importsToCopy.has(checker.getSymbolAtLocation(name))));
-          } else {
-            append(copiedOldImports, filterImport(i, factory.createStringLiteral(moduleSpecifierFromImport(i).text), (name) => importsToCopy.has(checker.getSymbolAtLocation(name))));
-          }
-        });
-      }
-    }
-    const targetFileSourceFile = program.getSourceFile(targetFile);
-    let oldFileDefault;
-    const oldFileNamedImports = [];
-    const markSeenTop = nodeSeenTracker();
-    targetFileImportsFromOldFile.forEach((symbol) => {
-      if (!symbol.declarations) {
-        return;
-      }
-      for (const decl of symbol.declarations) {
-        if (!isTopLevelDeclaration(decl))
-          continue;
-        const name = nameOfTopLevelDeclaration(decl);
-        if (!name)
-          continue;
-        const top = getTopLevelDeclarationStatement(decl);
-        if (markSeenTop(top)) {
-          addExportToChanges(oldFile, top, name, changes, useEsModuleSyntax);
-        }
-        if (importAdder && checker.isUnknownSymbol(symbol)) {
-          importAdder.addImportFromExportedSymbol(skipAlias(symbol, checker));
-        } else {
-          if (hasSyntacticModifier(decl, 1024 /* Default */)) {
-            oldFileDefault = name;
-          } else {
-            oldFileNamedImports.push(name.text);
-          }
-        }
-      }
-    });
-    return targetFileSourceFile ? append(copiedOldImports, makeImportOrRequire(targetFileSourceFile, oldFileDefault, oldFileNamedImports, oldFile.fileName, program, host, useEsModuleSyntax, quotePreference)) : append(copiedOldImports, makeImportOrRequire(oldFile, oldFileDefault, oldFileNamedImports, oldFile.fileName, program, host, useEsModuleSyntax, quotePreference));
-  }
-  function addNewFileToTsconfig(program, changes, oldFileName, newFileNameWithExtension, getCanonicalFileName) {
-    const cfg = program.getCompilerOptions().configFile;
-    if (!cfg)
-      return;
-    const newFileAbsolutePath = normalizePath(combinePaths(oldFileName, "..", newFileNameWithExtension));
-    const newFilePath = getRelativePathFromFile(cfg.fileName, newFileAbsolutePath, getCanonicalFileName);
-    const cfgObject = cfg.statements[0] && tryCast(cfg.statements[0].expression, isObjectLiteralExpression);
-    const filesProp = cfgObject && find(cfgObject.properties, (prop) => isPropertyAssignment(prop) && isStringLiteral(prop.name) && prop.name.text === "files");
-    if (filesProp && isArrayLiteralExpression(filesProp.initializer)) {
-      changes.insertNodeInListAfter(cfg, last(filesProp.initializer.elements), factory.createStringLiteral(newFilePath), filesProp.initializer.elements);
-    }
-  }
-  function deleteMovedStatements(sourceFile, moved, changes) {
-    for (const { first: first2, afterLast } of moved) {
-      changes.deleteNodeRangeExcludingEnd(sourceFile, first2, afterLast);
-    }
-  }
-  function deleteUnusedOldImports(oldFile, toMove, changes, toDelete, checker) {
-    for (const statement of oldFile.statements) {
-      if (contains(toMove, statement))
-        continue;
-      forEachImportInStatement(statement, (i) => deleteUnusedImports(oldFile, i, changes, (name) => toDelete.has(checker.getSymbolAtLocation(name))));
-    }
-  }
-  function updateImportsInOtherFiles(changes, program, host, oldFile, movedSymbols, targetFileName, quotePreference) {
-    const checker = program.getTypeChecker();
-    for (const sourceFile of program.getSourceFiles()) {
-      if (sourceFile === oldFile)
-        continue;
-      for (const statement of sourceFile.statements) {
-        forEachImportInStatement(statement, (importNode) => {
-          if (checker.getSymbolAtLocation(moduleSpecifierFromImport(importNode)) !== oldFile.symbol)
-            return;
-          const shouldMove = (name) => {
-            const symbol = isBindingElement(name.parent) ? getPropertySymbolFromBindingElement(checker, name.parent) : skipAlias(checker.getSymbolAtLocation(name), checker);
-            return !!symbol && movedSymbols.has(symbol);
-          };
-          deleteUnusedImports(sourceFile, importNode, changes, shouldMove);
-          const pathToTargetFileWithExtension = resolvePath(getDirectoryPath(oldFile.path), targetFileName);
-          const newModuleSpecifier = getModuleSpecifier(program.getCompilerOptions(), sourceFile, sourceFile.path, pathToTargetFileWithExtension, createModuleSpecifierResolutionHost(program, host));
-          const newImportDeclaration = filterImport(importNode, makeStringLiteral(newModuleSpecifier, quotePreference), shouldMove);
-          if (newImportDeclaration)
-            changes.insertNodeAfter(sourceFile, statement, newImportDeclaration);
-          const ns = getNamespaceLikeImport(importNode);
-          if (ns)
-            updateNamespaceLikeImport(changes, sourceFile, checker, movedSymbols, newModuleSpecifier, ns, importNode, quotePreference);
-        });
-      }
-    }
-  }
-  function getNamespaceLikeImport(node) {
-    switch (node.kind) {
-      case 271 /* ImportDeclaration */:
-        return node.importClause && node.importClause.namedBindings && node.importClause.namedBindings.kind === 273 /* NamespaceImport */ ? node.importClause.namedBindings.name : void 0;
-      case 270 /* ImportEqualsDeclaration */:
-        return node.name;
-      case 259 /* VariableDeclaration */:
-        return tryCast(node.name, isIdentifier);
-      default:
-        return Debug.assertNever(node, `Unexpected node kind ${node.kind}`);
-    }
-  }
-  function updateNamespaceLikeImport(changes, sourceFile, checker, movedSymbols, newModuleSpecifier, oldImportId, oldImportNode, quotePreference) {
-    const preferredNewNamespaceName = ts_codefix_exports.moduleSpecifierToValidIdentifier(newModuleSpecifier, 99 /* ESNext */);
-    let needUniqueName = false;
-    const toChange = [];
-    ts_FindAllReferences_exports.Core.eachSymbolReferenceInFile(oldImportId, checker, sourceFile, (ref) => {
-      if (!isPropertyAccessExpression(ref.parent))
-        return;
-      needUniqueName = needUniqueName || !!checker.resolveName(
-        preferredNewNamespaceName,
-        ref,
-        67108863 /* All */,
-        /*excludeGlobals*/
-        true
-      );
-      if (movedSymbols.has(checker.getSymbolAtLocation(ref.parent.name))) {
-        toChange.push(ref);
-      }
-    });
-    if (toChange.length) {
-      const newNamespaceName = needUniqueName ? getUniqueName(preferredNewNamespaceName, sourceFile) : preferredNewNamespaceName;
-      for (const ref of toChange) {
-        changes.replaceNode(sourceFile, ref, factory.createIdentifier(newNamespaceName));
-      }
-      changes.insertNodeAfter(sourceFile, oldImportNode, updateNamespaceLikeImportNode(oldImportNode, preferredNewNamespaceName, newModuleSpecifier, quotePreference));
-    }
-  }
-  function updateNamespaceLikeImportNode(node, newNamespaceName, newModuleSpecifier, quotePreference) {
-    const newNamespaceId = factory.createIdentifier(newNamespaceName);
-    const newModuleString = makeStringLiteral(newModuleSpecifier, quotePreference);
-    switch (node.kind) {
-      case 271 /* ImportDeclaration */:
-        return factory.createImportDeclaration(
-          /*modifiers*/
-          void 0,
-          factory.createImportClause(
-            /*isTypeOnly*/
-            false,
-            /*name*/
-            void 0,
-            factory.createNamespaceImport(newNamespaceId)
-          ),
-          newModuleString,
-          /*assertClause*/
-          void 0
-        );
-      case 270 /* ImportEqualsDeclaration */:
-        return factory.createImportEqualsDeclaration(
-          /*modifiers*/
-          void 0,
-          /*isTypeOnly*/
-          false,
-          newNamespaceId,
-          factory.createExternalModuleReference(newModuleString)
-        );
-      case 259 /* VariableDeclaration */:
-        return factory.createVariableDeclaration(
-          newNamespaceId,
-          /*exclamationToken*/
-          void 0,
-          /*type*/
-          void 0,
-          createRequireCall(newModuleString)
-        );
-      default:
-        return Debug.assertNever(node, `Unexpected node kind ${node.kind}`);
-    }
-  }
-  function createRequireCall(moduleSpecifier) {
-    return factory.createCallExpression(
-      factory.createIdentifier("require"),
-      /*typeArguments*/
-      void 0,
-      [moduleSpecifier]
-    );
-  }
-  function moduleSpecifierFromImport(i) {
-    return i.kind === 271 /* ImportDeclaration */ ? i.moduleSpecifier : i.kind === 270 /* ImportEqualsDeclaration */ ? i.moduleReference.expression : i.initializer.arguments[0];
-  }
-  function forEachImportInStatement(statement, cb) {
-    if (isImportDeclaration(statement)) {
-      if (isStringLiteral(statement.moduleSpecifier))
-        cb(statement);
-    } else if (isImportEqualsDeclaration(statement)) {
-      if (isExternalModuleReference(statement.moduleReference) && isStringLiteralLike(statement.moduleReference.expression)) {
-        cb(statement);
-      }
-    } else if (isVariableStatement(statement)) {
-      for (const decl of statement.declarationList.declarations) {
-        if (decl.initializer && isRequireCall(
-          decl.initializer,
-          /*requireStringLiteralLikeArgument*/
-          true
-        )) {
-          cb(decl);
-        }
-      }
-    }
-  }
-  function createOldFileImportsFromTargetFile(sourceFile, targetFileNeedExport, targetFileNameWithExtension, program, host, useEs6Imports, quotePreference) {
-    let defaultImport;
-    const imports = [];
-    targetFileNeedExport.forEach((symbol) => {
-      if (symbol.escapedName === "default" /* Default */) {
-        defaultImport = factory.createIdentifier(symbolNameNoDefault(symbol));
-      } else {
-        imports.push(symbol.name);
-      }
-    });
-    return makeImportOrRequire(sourceFile, defaultImport, imports, targetFileNameWithExtension, program, host, useEs6Imports, quotePreference);
-  }
-  function makeImportOrRequire(sourceFile, defaultImport, imports, targetFileNameWithExtension, program, host, useEs6Imports, quotePreference) {
-    const pathToTargetFile = resolvePath(getDirectoryPath(sourceFile.path), targetFileNameWithExtension);
-    const pathToTargetFileWithCorrectExtension = getModuleSpecifier(program.getCompilerOptions(), sourceFile, sourceFile.path, pathToTargetFile, createModuleSpecifierResolutionHost(program, host));
-    if (useEs6Imports) {
-      const specifiers = imports.map((i) => factory.createImportSpecifier(
-        /*isTypeOnly*/
-        false,
-        /*propertyName*/
-        void 0,
-        factory.createIdentifier(i)
-      ));
-      return makeImportIfNecessary(defaultImport, specifiers, pathToTargetFileWithCorrectExtension, quotePreference);
-    } else {
-      Debug.assert(!defaultImport, "No default import should exist");
-      const bindingElements = imports.map((i) => factory.createBindingElement(
-        /*dotDotDotToken*/
-        void 0,
-        /*propertyName*/
-        void 0,
-        i
-      ));
-      return bindingElements.length ? makeVariableStatement(
-        factory.createObjectBindingPattern(bindingElements),
-        /*type*/
-        void 0,
-        createRequireCall(makeStringLiteral(pathToTargetFileWithCorrectExtension, quotePreference))
-      ) : void 0;
-    }
-  }
-  function makeVariableStatement(name, type, initializer, flags = 2 /* Const */) {
-    return factory.createVariableStatement(
-      /*modifiers*/
-      void 0,
-      factory.createVariableDeclarationList([factory.createVariableDeclaration(
-        name,
-        /*exclamationToken*/
-        void 0,
-        type,
-        initializer
-      )], flags)
-    );
-  }
-  function addExports(sourceFile, toMove, needExport, useEs6Exports) {
-    return flatMap(toMove, (statement) => {
-      if (isTopLevelDeclarationStatement(statement) && !isExported(sourceFile, statement, useEs6Exports) && forEachTopLevelDeclaration(statement, (d) => {
-        var _a;
-        return needExport.has(Debug.checkDefined((_a = tryCast(d, canHaveSymbol)) == null ? void 0 : _a.symbol));
-      })) {
-        const exports = addExport(getSynthesizedDeepClone(statement), useEs6Exports);
-        if (exports)
-          return exports;
-      }
-      return getSynthesizedDeepClone(statement);
-    });
-  }
-  function isExported(sourceFile, decl, useEs6Exports, name) {
-    var _a;
-    if (useEs6Exports) {
-      return !isExpressionStatement(decl) && hasSyntacticModifier(decl, 1 /* Export */) || !!(name && sourceFile.symbol && ((_a = sourceFile.symbol.exports) == null ? void 0 : _a.has(name.escapedText)));
-    }
-    return !!sourceFile.symbol && !!sourceFile.symbol.exports && getNamesToExportInCommonJS(decl).some((name2) => sourceFile.symbol.exports.has(escapeLeadingUnderscores(name2)));
-  }
-  function deleteUnusedImports(sourceFile, importDecl, changes, isUnused) {
-    switch (importDecl.kind) {
-      case 271 /* ImportDeclaration */:
-        deleteUnusedImportsInDeclaration(sourceFile, importDecl, changes, isUnused);
-        break;
-      case 270 /* ImportEqualsDeclaration */:
-        if (isUnused(importDecl.name)) {
-          changes.delete(sourceFile, importDecl);
-        }
-        break;
-      case 259 /* VariableDeclaration */:
-        deleteUnusedImportsInVariableDeclaration(sourceFile, importDecl, changes, isUnused);
-        break;
-      default:
-        Debug.assertNever(importDecl, `Unexpected import decl kind ${importDecl.kind}`);
-    }
-  }
-  function deleteUnusedImportsInDeclaration(sourceFile, importDecl, changes, isUnused) {
-    if (!importDecl.importClause)
-      return;
-    const { name, namedBindings } = importDecl.importClause;
-    const defaultUnused = !name || isUnused(name);
-    const namedBindingsUnused = !namedBindings || (namedBindings.kind === 273 /* NamespaceImport */ ? isUnused(namedBindings.name) : namedBindings.elements.length !== 0 && namedBindings.elements.every((e) => isUnused(e.name)));
-    if (defaultUnused && namedBindingsUnused) {
-      changes.delete(sourceFile, importDecl);
-    } else {
-      if (name && defaultUnused) {
-        changes.delete(sourceFile, name);
-      }
-      if (namedBindings) {
-        if (namedBindingsUnused) {
-          changes.replaceNode(
-            sourceFile,
-            importDecl.importClause,
-            factory.updateImportClause(
-              importDecl.importClause,
-              importDecl.importClause.isTypeOnly,
-              name,
-              /*namedBindings*/
-              void 0
-            )
-          );
-        } else if (namedBindings.kind === 274 /* NamedImports */) {
-          for (const element of namedBindings.elements) {
-            if (isUnused(element.name))
-              changes.delete(sourceFile, element);
-          }
-        }
-      }
-    }
-  }
-  function deleteUnusedImportsInVariableDeclaration(sourceFile, varDecl, changes, isUnused) {
-    const { name } = varDecl;
-    switch (name.kind) {
-      case 80 /* Identifier */:
-        if (isUnused(name)) {
-          if (varDecl.initializer && isRequireCall(
-            varDecl.initializer,
-            /*requireStringLiteralLikeArgument*/
-            true
-          )) {
-            changes.delete(
-              sourceFile,
-              isVariableDeclarationList(varDecl.parent) && length(varDecl.parent.declarations) === 1 ? varDecl.parent.parent : varDecl
-            );
-          } else {
-            changes.delete(sourceFile, name);
-          }
-        }
-        break;
-      case 206 /* ArrayBindingPattern */:
-        break;
-      case 205 /* ObjectBindingPattern */:
-        if (name.elements.every((e) => isIdentifier(e.name) && isUnused(e.name))) {
-          changes.delete(
-            sourceFile,
-            isVariableDeclarationList(varDecl.parent) && varDecl.parent.declarations.length === 1 ? varDecl.parent.parent : varDecl
-          );
-        } else {
-          for (const element of name.elements) {
-            if (isIdentifier(element.name) && isUnused(element.name)) {
-              changes.delete(sourceFile, element.name);
-            }
-          }
-        }
-        break;
-    }
-  }
-  function isTopLevelDeclarationStatement(node) {
-    Debug.assert(isSourceFile(node.parent), "Node parent should be a SourceFile");
-    return isNonVariableTopLevelDeclaration(node) || isVariableStatement(node);
-  }
-  function addExport(decl, useEs6Exports) {
-    return useEs6Exports ? [addEs6Export(decl)] : addCommonjsExport(decl);
-  }
-  function addEs6Export(d) {
-    const modifiers = canHaveModifiers(d) ? concatenate([factory.createModifier(95 /* ExportKeyword */)], getModifiers(d)) : void 0;
-    switch (d.kind) {
-      case 261 /* FunctionDeclaration */:
-        return factory.updateFunctionDeclaration(d, modifiers, d.asteriskToken, d.name, d.typeParameters, d.parameters, d.type, d.body);
-      case 262 /* ClassDeclaration */:
-        const decorators = canHaveDecorators(d) ? getDecorators(d) : void 0;
-        return factory.updateClassDeclaration(d, concatenate(decorators, modifiers), d.name, d.typeParameters, d.heritageClauses, d.members);
-      case 242 /* VariableStatement */:
-        return factory.updateVariableStatement(d, modifiers, d.declarationList);
-      case 266 /* ModuleDeclaration */:
-        return factory.updateModuleDeclaration(d, modifiers, d.name, d.body);
-      case 265 /* EnumDeclaration */:
-        return factory.updateEnumDeclaration(d, modifiers, d.name, d.members);
-      case 264 /* TypeAliasDeclaration */:
-        return factory.updateTypeAliasDeclaration(d, modifiers, d.name, d.typeParameters, d.type);
-      case 263 /* InterfaceDeclaration */:
-        return factory.updateInterfaceDeclaration(d, modifiers, d.name, d.typeParameters, d.heritageClauses, d.members);
-      case 270 /* ImportEqualsDeclaration */:
-        return factory.updateImportEqualsDeclaration(d, modifiers, d.isTypeOnly, d.name, d.moduleReference);
-      case 243 /* ExpressionStatement */:
-        return Debug.fail();
-      default:
-        return Debug.assertNever(d, `Unexpected declaration kind ${d.kind}`);
-    }
-  }
-  function addCommonjsExport(decl) {
-    return [decl, ...getNamesToExportInCommonJS(decl).map(createExportAssignment)];
-  }
-  function createExportAssignment(name) {
-    return factory.createExpressionStatement(
-      factory.createBinaryExpression(
-        factory.createPropertyAccessExpression(factory.createIdentifier("exports"), factory.createIdentifier(name)),
-        64 /* EqualsToken */,
-        factory.createIdentifier(name)
-      )
-    );
-  }
-  function getNamesToExportInCommonJS(decl) {
-    switch (decl.kind) {
-      case 261 /* FunctionDeclaration */:
-      case 262 /* ClassDeclaration */:
-        return [decl.name.text];
-      case 242 /* VariableStatement */:
-        return mapDefined(decl.declarationList.declarations, (d) => isIdentifier(d.name) ? d.name.text : void 0);
-      case 266 /* ModuleDeclaration */:
-      case 265 /* EnumDeclaration */:
-      case 264 /* TypeAliasDeclaration */:
-      case 263 /* InterfaceDeclaration */:
-      case 270 /* ImportEqualsDeclaration */:
-        return emptyArray;
-      case 243 /* ExpressionStatement */:
-        return Debug.fail("Can't export an ExpressionStatement");
-      default:
-        return Debug.assertNever(decl, `Unexpected decl kind ${decl.kind}`);
-    }
-  }
-  function filterImport(i, moduleSpecifier, keep) {
-    switch (i.kind) {
-      case 271 /* ImportDeclaration */: {
-        const clause = i.importClause;
-        if (!clause)
-          return void 0;
-        const defaultImport = clause.name && keep(clause.name) ? clause.name : void 0;
-        const namedBindings = clause.namedBindings && filterNamedBindings(clause.namedBindings, keep);
-        return defaultImport || namedBindings ? factory.createImportDeclaration(
-          /*modifiers*/
-          void 0,
-          factory.createImportClause(clause.isTypeOnly, defaultImport, namedBindings),
-          getSynthesizedDeepClone(moduleSpecifier),
-          /*assertClause*/
-          void 0
-        ) : void 0;
-      }
-      case 270 /* ImportEqualsDeclaration */:
-        return keep(i.name) ? i : void 0;
-      case 259 /* VariableDeclaration */: {
-        const name = filterBindingName(i.name, keep);
-        return name ? makeVariableStatement(name, i.type, createRequireCall(moduleSpecifier), i.parent.flags) : void 0;
-      }
-      default:
-        return Debug.assertNever(i, `Unexpected import kind ${i.kind}`);
-    }
-  }
-  function filterNamedBindings(namedBindings, keep) {
-    if (namedBindings.kind === 273 /* NamespaceImport */) {
-      return keep(namedBindings.name) ? namedBindings : void 0;
-    } else {
-      const newElements = namedBindings.elements.filter((e) => keep(e.name));
-      return newElements.length ? factory.createNamedImports(newElements) : void 0;
-    }
-  }
-  function filterBindingName(name, keep) {
-    switch (name.kind) {
-      case 80 /* Identifier */:
-        return keep(name) ? name : void 0;
-      case 206 /* ArrayBindingPattern */:
-        return name;
-      case 205 /* ObjectBindingPattern */: {
-        const newElements = name.elements.filter((prop) => prop.propertyName || !isIdentifier(prop.name) || keep(prop.name));
-        return newElements.length ? factory.createObjectBindingPattern(newElements) : void 0;
-      }
-    }
-  }
-  function nameOfTopLevelDeclaration(d) {
-    return isExpressionStatement(d) ? tryCast(d.expression.left.name, isIdentifier) : tryCast(d.name, isIdentifier);
-  }
-  function getTopLevelDeclarationStatement(d) {
-    switch (d.kind) {
-      case 259 /* VariableDeclaration */:
-        return d.parent.parent;
-      case 207 /* BindingElement */:
-        return getTopLevelDeclarationStatement(
-          cast(d.parent.parent, (p) => isVariableDeclaration(p) || isBindingElement(p))
-        );
-      default:
-        return d;
-    }
-  }
-  function addExportToChanges(sourceFile, decl, name, changes, useEs6Exports) {
-    if (isExported(sourceFile, decl, useEs6Exports, name))
-      return;
-    if (useEs6Exports) {
-      if (!isExpressionStatement(decl))
-        changes.insertExportModifier(sourceFile, decl);
-    } else {
-      const names = getNamesToExportInCommonJS(decl);
-      if (names.length !== 0)
-        changes.insertNodesAfter(sourceFile, decl, names.map(createExportAssignment));
-    }
-  }
-  function createNewFileName(oldFile, program, context, host) {
-    const checker = program.getTypeChecker();
-    const toMove = getStatementsToMove(context);
-    let usage;
-    if (toMove) {
-      usage = getUsageInfo(oldFile, toMove.all, checker);
-      const currentDirectory = getDirectoryPath(oldFile.fileName);
-      const extension = extensionFromPath(oldFile.fileName);
-      const newFileName = combinePaths(
-        // new file is always placed in the same directory as the old file
-        currentDirectory,
-        // ensures the filename computed below isn't already taken
-        makeUniqueFilename(
-          // infers a name for the new file from the symbols being moved
-          inferNewFileName(usage.oldFileImportsFromTargetFile, usage.movedSymbols),
-          extension,
-          currentDirectory,
-          host
-        )
-      ) + extension;
-      return newFileName;
-    }
-    return "";
-  }
-  function getRangeToMove(context) {
-    const { file } = context;
-    const range = createTextRangeFromSpan(getRefactorContextSpan(context));
-    const { statements } = file;
-    const startNodeIndex = findIndex(statements, (s) => s.end > range.pos);
-    if (startNodeIndex === -1)
-      return void 0;
-    const startStatement = statements[startNodeIndex];
-    if (isNamedDeclaration(startStatement) && startStatement.name && rangeContainsRange(startStatement.name, range)) {
-      return { toMove: [statements[startNodeIndex]], afterLast: statements[startNodeIndex + 1] };
-    }
-    if (range.pos > startStatement.getStart(file))
-      return void 0;
-    const afterEndNodeIndex = findIndex(statements, (s) => s.end > range.end, startNodeIndex);
-    if (afterEndNodeIndex !== -1 && (afterEndNodeIndex === 0 || statements[afterEndNodeIndex].getStart(file) < range.end))
-      return void 0;
-    return {
-      toMove: statements.slice(startNodeIndex, afterEndNodeIndex === -1 ? statements.length : afterEndNodeIndex),
-      afterLast: afterEndNodeIndex === -1 ? void 0 : statements[afterEndNodeIndex]
-    };
-  }
-  function getStatementsToMove(context) {
-    const rangeToMove = getRangeToMove(context);
-    if (rangeToMove === void 0)
-      return void 0;
-    const all = [];
-    const ranges = [];
-    const { toMove, afterLast } = rangeToMove;
-    getRangesWhere(toMove, isAllowedStatementToMove, (start, afterEndIndex) => {
-      for (let i = start; i < afterEndIndex; i++)
-        all.push(toMove[i]);
-      ranges.push({ first: toMove[start], afterLast });
-    });
-    return all.length === 0 ? void 0 : { all, ranges };
-  }
-  function isAllowedStatementToMove(statement) {
-    return !isPureImport(statement) && !isPrologueDirective(statement);
-  }
-  function isPureImport(node) {
-    switch (node.kind) {
-      case 271 /* ImportDeclaration */:
-        return true;
-      case 270 /* ImportEqualsDeclaration */:
-        return !hasSyntacticModifier(node, 1 /* Export */);
-      case 242 /* VariableStatement */:
-        return node.declarationList.declarations.every((d) => !!d.initializer && isRequireCall(
-          d.initializer,
-          /*requireStringLiteralLikeArgument*/
-          true
-        ));
-      default:
-        return false;
-    }
-  }
-  function getUsageInfo(oldFile, toMove, checker) {
-    const movedSymbols = /* @__PURE__ */ new Set();
-    const oldImportsNeededByTargetFile = /* @__PURE__ */ new Map();
-    const targetFileImportsFromOldFile = /* @__PURE__ */ new Set();
-    const containsJsx = find(toMove, (statement) => !!(statement.transformFlags & 2 /* ContainsJsx */));
-    const jsxNamespaceSymbol = getJsxNamespaceSymbol(containsJsx);
-    if (jsxNamespaceSymbol) {
-      oldImportsNeededByTargetFile.set(jsxNamespaceSymbol, false);
-    }
-    for (const statement of toMove) {
-      forEachTopLevelDeclaration(statement, (decl) => {
-        movedSymbols.add(Debug.checkDefined(isExpressionStatement(decl) ? checker.getSymbolAtLocation(decl.expression.left) : decl.symbol, "Need a symbol here"));
-      });
-    }
-    for (const statement of toMove) {
-      forEachReference(statement, checker, (symbol, isValidTypeOnlyUseSite) => {
-        if (!symbol.declarations)
-          return;
-        for (const decl of symbol.declarations) {
-          if (isInImport(decl)) {
-            const prevIsTypeOnly = oldImportsNeededByTargetFile.get(symbol);
-            oldImportsNeededByTargetFile.set(symbol, prevIsTypeOnly === void 0 ? isValidTypeOnlyUseSite : prevIsTypeOnly && isValidTypeOnlyUseSite);
-          } else if (isTopLevelDeclaration(decl) && sourceFileOfTopLevelDeclaration(decl) === oldFile && !movedSymbols.has(symbol)) {
-            targetFileImportsFromOldFile.add(symbol);
-          }
-        }
-      });
-    }
-    const unusedImportsFromOldFile = new Set(oldImportsNeededByTargetFile.keys());
-    const oldFileImportsFromTargetFile = /* @__PURE__ */ new Set();
-    for (const statement of oldFile.statements) {
-      if (contains(toMove, statement))
-        continue;
-      if (jsxNamespaceSymbol && !!(statement.transformFlags & 2 /* ContainsJsx */)) {
-        unusedImportsFromOldFile.delete(jsxNamespaceSymbol);
-      }
-      forEachReference(statement, checker, (symbol) => {
-        if (movedSymbols.has(symbol))
-          oldFileImportsFromTargetFile.add(symbol);
-        unusedImportsFromOldFile.delete(symbol);
-      });
-    }
-    return { movedSymbols, targetFileImportsFromOldFile, oldFileImportsFromTargetFile, oldImportsNeededByTargetFile, unusedImportsFromOldFile };
-    function getJsxNamespaceSymbol(containsJsx2) {
-      if (containsJsx2 === void 0) {
-        return void 0;
-      }
-      const jsxNamespace = checker.getJsxNamespace(containsJsx2);
-      const jsxNamespaceSymbol2 = checker.resolveName(
-        jsxNamespace,
-        containsJsx2,
-        1920 /* Namespace */,
-        /*excludeGlobals*/
-        true
-      );
-      return !!jsxNamespaceSymbol2 && some(jsxNamespaceSymbol2.declarations, isInImport) ? jsxNamespaceSymbol2 : void 0;
-    }
-  }
-  function makeUniqueFilename(proposedFilename, extension, inDirectory, host) {
-    let newFilename = proposedFilename;
-    for (let i = 1; ; i++) {
-      const name = combinePaths(inDirectory, newFilename + extension);
-      if (!host.fileExists(name))
-        return newFilename;
-      newFilename = `${proposedFilename}.${i}`;
-    }
-  }
-  function inferNewFileName(importsFromNewFile, movedSymbols) {
-    return forEachKey(importsFromNewFile, symbolNameNoDefault) || forEachKey(movedSymbols, symbolNameNoDefault) || "newFile";
-  }
-  function forEachReference(node, checker, onReference) {
-    node.forEachChild(function cb(node2) {
-      if (isIdentifier(node2) && !isDeclarationName(node2)) {
-        const sym = checker.getSymbolAtLocation(node2);
-        if (sym)
-          onReference(sym, isValidTypeOnlyAliasUseSite(node2));
-      } else {
-        node2.forEachChild(cb);
-      }
-    });
-  }
-  function forEachTopLevelDeclaration(statement, cb) {
-    switch (statement.kind) {
-      case 261 /* FunctionDeclaration */:
-      case 262 /* ClassDeclaration */:
-      case 266 /* ModuleDeclaration */:
-      case 265 /* EnumDeclaration */:
-      case 264 /* TypeAliasDeclaration */:
-      case 263 /* InterfaceDeclaration */:
-      case 270 /* ImportEqualsDeclaration */:
-        return cb(statement);
-      case 242 /* VariableStatement */:
-        return firstDefined(statement.declarationList.declarations, (decl) => forEachTopLevelDeclarationInBindingName(decl.name, cb));
-      case 243 /* ExpressionStatement */: {
-        const { expression } = statement;
-        return isBinaryExpression(expression) && getAssignmentDeclarationKind(expression) === 1 /* ExportsProperty */ ? cb(statement) : void 0;
-      }
-    }
-  }
-  function isInImport(decl) {
-    switch (decl.kind) {
-      case 270 /* ImportEqualsDeclaration */:
-      case 275 /* ImportSpecifier */:
-      case 272 /* ImportClause */:
-      case 273 /* NamespaceImport */:
-        return true;
-      case 259 /* VariableDeclaration */:
-        return isVariableDeclarationInImport(decl);
-      case 207 /* BindingElement */:
-        return isVariableDeclaration(decl.parent.parent) && isVariableDeclarationInImport(decl.parent.parent);
-      default:
-        return false;
-    }
-  }
-  function isVariableDeclarationInImport(decl) {
-    return isSourceFile(decl.parent.parent.parent) && !!decl.initializer && isRequireCall(
-      decl.initializer,
-      /*requireStringLiteralLikeArgument*/
-      true
-    );
-  }
-  function isTopLevelDeclaration(node) {
-    return isNonVariableTopLevelDeclaration(node) && isSourceFile(node.parent) || isVariableDeclaration(node) && isSourceFile(node.parent.parent.parent);
-  }
-  function sourceFileOfTopLevelDeclaration(node) {
-    return isVariableDeclaration(node) ? node.parent.parent.parent : node.parent;
-  }
-  function forEachTopLevelDeclarationInBindingName(name, cb) {
-    switch (name.kind) {
-      case 80 /* Identifier */:
-        return cb(cast(name.parent, (x) => isVariableDeclaration(x) || isBindingElement(x)));
-      case 206 /* ArrayBindingPattern */:
-      case 205 /* ObjectBindingPattern */:
-        return firstDefined(name.elements, (em) => isOmittedExpression(em) ? void 0 : forEachTopLevelDeclarationInBindingName(em.name, cb));
-      default:
-        return Debug.assertNever(name, `Unexpected name kind ${name.kind}`);
-    }
-  }
-  function isNonVariableTopLevelDeclaration(node) {
-    switch (node.kind) {
-      case 261 /* FunctionDeclaration */:
-      case 262 /* ClassDeclaration */:
-      case 266 /* ModuleDeclaration */:
-      case 265 /* EnumDeclaration */:
-      case 264 /* TypeAliasDeclaration */:
-      case 263 /* InterfaceDeclaration */:
-      case 270 /* ImportEqualsDeclaration */:
-        return true;
-      default:
-        return false;
-    }
-  }
-  var refactorNameForMoveToFile, description2, moveToFileAction;
-  var init_moveToFile = __esm({
-    "src/services/refactors/moveToFile.ts"() {
-      "use strict";
-      init_moduleSpecifiers();
-      init_ts4();
-      init_refactorProvider();
-      refactorNameForMoveToFile = "Move to file";
-      description2 = getLocaleSpecificMessage(Diagnostics.Move_to_file);
-      moveToFileAction = {
-        name: "Move to file",
-        description: description2,
-        kind: "refactor.move.file"
-      };
-      registerRefactor(refactorNameForMoveToFile, {
-        kinds: [moveToFileAction.kind],
-        getAvailableActions: function getRefactorActionsToMoveToFile(context, interactiveRefactorArguments) {
-          const statements = getStatementsToMove(context);
-          if (!interactiveRefactorArguments) {
-            return emptyArray;
-          }
-          if (context.preferences.allowTextChangesInNewFiles && statements) {
-            return [{ name: refactorNameForMoveToFile, description: description2, actions: [moveToFileAction] }];
-          }
-          if (context.preferences.provideRefactorNotApplicableReason) {
-            return [{
-              name: refactorNameForMoveToFile,
-              description: description2,
-              actions: [{ ...moveToFileAction, notApplicableReason: getLocaleSpecificMessage(Diagnostics.Selection_is_not_a_valid_statement_or_statements) }]
-            }];
-          }
-          return emptyArray;
-        },
-        getEditsForAction: function getRefactorEditsToMoveToFile(context, actionName2, interactiveRefactorArguments) {
-          Debug.assert(actionName2 === refactorNameForMoveToFile, "Wrong refactor invoked");
-          const statements = Debug.checkDefined(getStatementsToMove(context));
-          Debug.assert(interactiveRefactorArguments, "No interactive refactor arguments available");
-          const targetFile = interactiveRefactorArguments.targetFile;
-          if (hasJSFileExtension(targetFile) || hasTSFileExtension(targetFile)) {
-            const edits = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange4(context, context.file, interactiveRefactorArguments.targetFile, context.program, statements, t, context.host, context.preferences));
-            return { edits, renameFilename: void 0, renameLocation: void 0 };
-          }
-          return { edits: [], renameFilename: void 0, renameLocation: void 0, notApplicableReason: getLocaleSpecificMessage(Diagnostics.Cannot_move_to_file_selected_file_is_invalid) };
-        }
-      });
-    }
-  });
-
-  // src/services/refactors/convertOverloadListToSingleSignature.ts
-  function getRefactorActionsToConvertOverloadsToOneSignature(context) {
-    const { file, startPosition, program } = context;
-    const info = getConvertableOverloadListAtPosition(file, startPosition, program);
-    if (!info)
-      return emptyArray;
-    return [{
-      name: refactorName5,
-      description: refactorDescription,
-      actions: [functionOverloadAction]
-    }];
-  }
-  function getRefactorEditsToConvertOverloadsToOneSignature(context) {
-    const { file, startPosition, program } = context;
-    const signatureDecls = getConvertableOverloadListAtPosition(file, startPosition, program);
-    if (!signatureDecls)
-      return void 0;
-    const checker = program.getTypeChecker();
-    const lastDeclaration = signatureDecls[signatureDecls.length - 1];
-    let updated = lastDeclaration;
-    switch (lastDeclaration.kind) {
-      case 172 /* MethodSignature */: {
-        updated = factory.updateMethodSignature(
-          lastDeclaration,
-          lastDeclaration.modifiers,
-          lastDeclaration.name,
-          lastDeclaration.questionToken,
-          lastDeclaration.typeParameters,
-          getNewParametersForCombinedSignature(signatureDecls),
-          lastDeclaration.type
-        );
-        break;
-      }
-      case 173 /* MethodDeclaration */: {
-        updated = factory.updateMethodDeclaration(
-          lastDeclaration,
-          lastDeclaration.modifiers,
-          lastDeclaration.asteriskToken,
-          lastDeclaration.name,
-          lastDeclaration.questionToken,
-          lastDeclaration.typeParameters,
-          getNewParametersForCombinedSignature(signatureDecls),
-          lastDeclaration.type,
-          lastDeclaration.body
-        );
-        break;
-      }
-      case 178 /* CallSignature */: {
-        updated = factory.updateCallSignature(
-          lastDeclaration,
-          lastDeclaration.typeParameters,
-          getNewParametersForCombinedSignature(signatureDecls),
-          lastDeclaration.type
-        );
-        break;
-      }
-      case 175 /* Constructor */: {
-        updated = factory.updateConstructorDeclaration(
-          lastDeclaration,
-          lastDeclaration.modifiers,
-          getNewParametersForCombinedSignature(signatureDecls),
-          lastDeclaration.body
-        );
-        break;
-      }
-      case 179 /* ConstructSignature */: {
-        updated = factory.updateConstructSignature(
-          lastDeclaration,
-          lastDeclaration.typeParameters,
-          getNewParametersForCombinedSignature(signatureDecls),
-          lastDeclaration.type
-        );
-        break;
-      }
-      case 261 /* FunctionDeclaration */: {
-        updated = factory.updateFunctionDeclaration(
-          lastDeclaration,
-          lastDeclaration.modifiers,
-          lastDeclaration.asteriskToken,
-          lastDeclaration.name,
-          lastDeclaration.typeParameters,
-          getNewParametersForCombinedSignature(signatureDecls),
-          lastDeclaration.type,
-          lastDeclaration.body
-        );
-        break;
-      }
-      default:
-        return Debug.failBadSyntaxKind(lastDeclaration, "Unhandled signature kind in overload list conversion refactoring");
-    }
-    if (updated === lastDeclaration) {
-      return;
-    }
-    const edits = ts_textChanges_exports.ChangeTracker.with(context, (t) => {
-      t.replaceNodeRange(file, signatureDecls[0], signatureDecls[signatureDecls.length - 1], updated);
-    });
-    return { renameFilename: void 0, renameLocation: void 0, edits };
-    function getNewParametersForCombinedSignature(signatureDeclarations) {
-      const lastSig = signatureDeclarations[signatureDeclarations.length - 1];
-      if (isFunctionLikeDeclaration(lastSig) && lastSig.body) {
-        signatureDeclarations = signatureDeclarations.slice(0, signatureDeclarations.length - 1);
-      }
-      return factory.createNodeArray([
-        factory.createParameterDeclaration(
-          /*modifiers*/
-          void 0,
-          factory.createToken(26 /* DotDotDotToken */),
-          "args",
-          /*questionToken*/
-          void 0,
-          factory.createUnionTypeNode(map(signatureDeclarations, convertSignatureParametersToTuple))
-        )
-      ]);
-    }
-    function convertSignatureParametersToTuple(decl) {
-      const members = map(decl.parameters, convertParameterToNamedTupleMember);
-      return setEmitFlags(factory.createTupleTypeNode(members), some(members, (m) => !!length(getSyntheticLeadingComments(m))) ? 0 /* None */ : 1 /* SingleLine */);
-    }
-    function convertParameterToNamedTupleMember(p) {
-      Debug.assert(isIdentifier(p.name));
-      const result = setTextRange(factory.createNamedTupleMember(
-        p.dotDotDotToken,
-        p.name,
-        p.questionToken,
-        p.type || factory.createKeywordTypeNode(133 /* AnyKeyword */)
-      ), p);
-      const parameterDocComment = p.symbol && p.symbol.getDocumentationComment(checker);
-      if (parameterDocComment) {
-        const newComment = displayPartsToString(parameterDocComment);
-        if (newComment.length) {
-          setSyntheticLeadingComments(result, [{
-            text: `*
-${newComment.split("\n").map((c) => ` * ${c}`).join("\n")}
- `,
-            kind: 3 /* MultiLineCommentTrivia */,
-            pos: -1,
-            end: -1,
-            hasTrailingNewLine: true,
-            hasLeadingNewline: true
-          }]);
-        }
-      }
-      return result;
-    }
-  }
-  function isConvertableSignatureDeclaration(d) {
-    switch (d.kind) {
-      case 172 /* MethodSignature */:
-      case 173 /* MethodDeclaration */:
-      case 178 /* CallSignature */:
-      case 175 /* Constructor */:
-      case 179 /* ConstructSignature */:
-      case 261 /* FunctionDeclaration */:
-        return true;
-    }
-    return false;
-  }
-  function getConvertableOverloadListAtPosition(file, startPosition, program) {
-    const node = getTokenAtPosition(file, startPosition);
-    const containingDecl = findAncestor(node, isConvertableSignatureDeclaration);
-    if (!containingDecl) {
-      return;
-    }
-    if (isFunctionLikeDeclaration(containingDecl) && containingDecl.body && rangeContainsPosition(containingDecl.body, startPosition)) {
-      return;
-    }
-    const checker = program.getTypeChecker();
-    const signatureSymbol = containingDecl.symbol;
-    if (!signatureSymbol) {
-      return;
-    }
-    const decls = signatureSymbol.declarations;
-    if (length(decls) <= 1) {
-      return;
-    }
-    if (!every(decls, (d) => getSourceFileOfNode(d) === file)) {
-      return;
-    }
-    if (!isConvertableSignatureDeclaration(decls[0])) {
-      return;
-    }
-    const kindOne = decls[0].kind;
-    if (!every(decls, (d) => d.kind === kindOne)) {
-      return;
-    }
-    const signatureDecls = decls;
-    if (some(signatureDecls, (d) => !!d.typeParameters || some(d.parameters, (p) => !!p.modifiers || !isIdentifier(p.name)))) {
-      return;
-    }
-    const signatures = mapDefined(signatureDecls, (d) => checker.getSignatureFromDeclaration(d));
-    if (length(signatures) !== length(decls)) {
-      return;
-    }
-    const returnOne = checker.getReturnTypeOfSignature(signatures[0]);
-    if (!every(signatures, (s) => checker.getReturnTypeOfSignature(s) === returnOne)) {
-      return;
-    }
-    return signatureDecls;
-  }
-  var refactorName5, refactorDescription, functionOverloadAction;
-  var init_convertOverloadListToSingleSignature = __esm({
-    "src/services/refactors/convertOverloadListToSingleSignature.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_refactor();
-      refactorName5 = "Convert overload list to single signature";
-      refactorDescription = Diagnostics.Convert_overload_list_to_single_signature.message;
-      functionOverloadAction = {
-        name: refactorName5,
-        description: refactorDescription,
-        kind: "refactor.rewrite.function.overloadList"
-      };
-      registerRefactor(refactorName5, {
-        kinds: [functionOverloadAction.kind],
-        getEditsForAction: getRefactorEditsToConvertOverloadsToOneSignature,
-        getAvailableActions: getRefactorActionsToConvertOverloadsToOneSignature
-      });
-    }
-  });
-
-  // src/services/refactors/addOrRemoveBracesToArrowFunction.ts
-  function getRefactorActionsToRemoveFunctionBraces(context) {
-    const { file, startPosition, triggerReason } = context;
-    const info = getConvertibleArrowFunctionAtPosition(file, startPosition, triggerReason === "invoked");
-    if (!info)
-      return emptyArray;
-    if (!isRefactorErrorInfo(info)) {
-      return [{
-        name: refactorName6,
-        description: refactorDescription2,
-        actions: [
-          info.addBraces ? addBracesAction : removeBracesAction
-        ]
-      }];
-    }
-    if (context.preferences.provideRefactorNotApplicableReason) {
-      return [{
-        name: refactorName6,
-        description: refactorDescription2,
-        actions: [
-          { ...addBracesAction, notApplicableReason: info.error },
-          { ...removeBracesAction, notApplicableReason: info.error }
-        ]
-      }];
-    }
-    return emptyArray;
-  }
-  function getRefactorEditsToRemoveFunctionBraces(context, actionName2) {
-    const { file, startPosition } = context;
-    const info = getConvertibleArrowFunctionAtPosition(file, startPosition);
-    Debug.assert(info && !isRefactorErrorInfo(info), "Expected applicable refactor info");
-    const { expression, returnStatement, func } = info;
-    let body;
-    if (actionName2 === addBracesAction.name) {
-      const returnStatement2 = factory.createReturnStatement(expression);
-      body = factory.createBlock(
-        [returnStatement2],
-        /*multiLine*/
-        true
-      );
-      copyLeadingComments(
-        expression,
-        returnStatement2,
-        file,
-        3 /* MultiLineCommentTrivia */,
-        /*hasTrailingNewLine*/
-        true
-      );
-    } else if (actionName2 === removeBracesAction.name && returnStatement) {
-      const actualExpression = expression || factory.createVoidZero();
-      body = needsParentheses(actualExpression) ? factory.createParenthesizedExpression(actualExpression) : actualExpression;
-      copyTrailingAsLeadingComments(
-        returnStatement,
-        body,
-        file,
-        3 /* MultiLineCommentTrivia */,
-        /*hasTrailingNewLine*/
-        false
-      );
-      copyLeadingComments(
-        returnStatement,
-        body,
-        file,
-        3 /* MultiLineCommentTrivia */,
-        /*hasTrailingNewLine*/
-        false
-      );
-      copyTrailingComments(
-        returnStatement,
-        body,
-        file,
-        3 /* MultiLineCommentTrivia */,
-        /*hasTrailingNewLine*/
-        false
-      );
-    } else {
-      Debug.fail("invalid action");
-    }
-    const edits = ts_textChanges_exports.ChangeTracker.with(context, (t) => {
-      t.replaceNode(file, func.body, body);
-    });
-    return { renameFilename: void 0, renameLocation: void 0, edits };
-  }
-  function getConvertibleArrowFunctionAtPosition(file, startPosition, considerFunctionBodies = true, kind) {
-    const node = getTokenAtPosition(file, startPosition);
-    const func = getContainingFunction(node);
-    if (!func) {
-      return {
-        error: getLocaleSpecificMessage(Diagnostics.Could_not_find_a_containing_arrow_function)
-      };
-    }
-    if (!isArrowFunction(func)) {
-      return {
-        error: getLocaleSpecificMessage(Diagnostics.Containing_function_is_not_an_arrow_function)
-      };
-    }
-    if (!rangeContainsRange(func, node) || rangeContainsRange(func.body, node) && !considerFunctionBodies) {
-      return void 0;
-    }
-    if (refactorKindBeginsWith(addBracesAction.kind, kind) && isExpression(func.body)) {
-      return { func, addBraces: true, expression: func.body };
-    } else if (refactorKindBeginsWith(removeBracesAction.kind, kind) && isBlock(func.body) && func.body.statements.length === 1) {
-      const firstStatement = first(func.body.statements);
-      if (isReturnStatement(firstStatement)) {
-        return { func, addBraces: false, expression: firstStatement.expression, returnStatement: firstStatement };
-      }
-    }
-    return void 0;
-  }
-  var refactorName6, refactorDescription2, addBracesAction, removeBracesAction;
-  var init_addOrRemoveBracesToArrowFunction = __esm({
-    "src/services/refactors/addOrRemoveBracesToArrowFunction.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_refactor();
-      refactorName6 = "Add or remove braces in an arrow function";
-      refactorDescription2 = Diagnostics.Add_or_remove_braces_in_an_arrow_function.message;
-      addBracesAction = {
-        name: "Add braces to arrow function",
-        description: Diagnostics.Add_braces_to_arrow_function.message,
-        kind: "refactor.rewrite.arrow.braces.add"
-      };
-      removeBracesAction = {
-        name: "Remove braces from arrow function",
-        description: Diagnostics.Remove_braces_from_arrow_function.message,
-        kind: "refactor.rewrite.arrow.braces.remove"
-      };
-      registerRefactor(refactorName6, {
-        kinds: [removeBracesAction.kind],
-        getEditsForAction: getRefactorEditsToRemoveFunctionBraces,
-        getAvailableActions: getRefactorActionsToRemoveFunctionBraces
-      });
-    }
-  });
-
-  // src/services/_namespaces/ts.refactor.addOrRemoveBracesToArrowFunction.ts
-  var ts_refactor_addOrRemoveBracesToArrowFunction_exports = {};
-  var init_ts_refactor_addOrRemoveBracesToArrowFunction = __esm({
-    "src/services/_namespaces/ts.refactor.addOrRemoveBracesToArrowFunction.ts"() {
-      "use strict";
-      init_convertOverloadListToSingleSignature();
-      init_addOrRemoveBracesToArrowFunction();
-    }
-  });
-
-  // src/services/refactors/convertArrowFunctionOrFunctionExpression.ts
-  function getRefactorActionsToConvertFunctionExpressions(context) {
-    const { file, startPosition, program, kind } = context;
-    const info = getFunctionInfo(file, startPosition, program);
-    if (!info)
-      return emptyArray;
-    const { selectedVariableDeclaration, func } = info;
-    const possibleActions = [];
-    const errors = [];
-    if (refactorKindBeginsWith(toNamedFunctionAction.kind, kind)) {
-      const error = selectedVariableDeclaration || isArrowFunction(func) && isVariableDeclaration(func.parent) ? void 0 : getLocaleSpecificMessage(Diagnostics.Could_not_convert_to_named_function);
-      if (error) {
-        errors.push({ ...toNamedFunctionAction, notApplicableReason: error });
-      } else {
-        possibleActions.push(toNamedFunctionAction);
-      }
-    }
-    if (refactorKindBeginsWith(toAnonymousFunctionAction.kind, kind)) {
-      const error = !selectedVariableDeclaration && isArrowFunction(func) ? void 0 : getLocaleSpecificMessage(Diagnostics.Could_not_convert_to_anonymous_function);
-      if (error) {
-        errors.push({ ...toAnonymousFunctionAction, notApplicableReason: error });
-      } else {
-        possibleActions.push(toAnonymousFunctionAction);
-      }
-    }
-    if (refactorKindBeginsWith(toArrowFunctionAction.kind, kind)) {
-      const error = isFunctionExpression(func) ? void 0 : getLocaleSpecificMessage(Diagnostics.Could_not_convert_to_arrow_function);
-      if (error) {
-        errors.push({ ...toArrowFunctionAction, notApplicableReason: error });
-      } else {
-        possibleActions.push(toArrowFunctionAction);
-      }
-    }
-    return [{
-      name: refactorName7,
-      description: refactorDescription3,
-      actions: possibleActions.length === 0 && context.preferences.provideRefactorNotApplicableReason ? errors : possibleActions
-    }];
-  }
-  function getRefactorEditsToConvertFunctionExpressions(context, actionName2) {
-    const { file, startPosition, program } = context;
-    const info = getFunctionInfo(file, startPosition, program);
-    if (!info)
-      return void 0;
-    const { func } = info;
-    const edits = [];
-    switch (actionName2) {
-      case toAnonymousFunctionAction.name:
-        edits.push(...getEditInfoForConvertToAnonymousFunction(context, func));
-        break;
-      case toNamedFunctionAction.name:
-        const variableInfo = getVariableInfo(func);
-        if (!variableInfo)
-          return void 0;
-        edits.push(...getEditInfoForConvertToNamedFunction(context, func, variableInfo));
-        break;
-      case toArrowFunctionAction.name:
-        if (!isFunctionExpression(func))
-          return void 0;
-        edits.push(...getEditInfoForConvertToArrowFunction(context, func));
-        break;
-      default:
-        return Debug.fail("invalid action");
-    }
-    return { renameFilename: void 0, renameLocation: void 0, edits };
-  }
-  function containingThis(node) {
-    let containsThis = false;
-    node.forEachChild(function checkThis(child) {
-      if (isThis(child)) {
-        containsThis = true;
-        return;
-      }
-      if (!isClassLike(child) && !isFunctionDeclaration(child) && !isFunctionExpression(child)) {
-        forEachChild(child, checkThis);
-      }
-    });
-    return containsThis;
-  }
-  function getFunctionInfo(file, startPosition, program) {
-    const token = getTokenAtPosition(file, startPosition);
-    const typeChecker = program.getTypeChecker();
-    const func = tryGetFunctionFromVariableDeclaration(file, typeChecker, token.parent);
-    if (func && !containingThis(func.body) && !typeChecker.containsArgumentsReference(func)) {
-      return { selectedVariableDeclaration: true, func };
-    }
-    const maybeFunc = getContainingFunction(token);
-    if (maybeFunc && (isFunctionExpression(maybeFunc) || isArrowFunction(maybeFunc)) && !rangeContainsRange(maybeFunc.body, token) && !containingThis(maybeFunc.body) && !typeChecker.containsArgumentsReference(maybeFunc)) {
-      if (isFunctionExpression(maybeFunc) && isFunctionReferencedInFile(file, typeChecker, maybeFunc))
-        return void 0;
-      return { selectedVariableDeclaration: false, func: maybeFunc };
-    }
-    return void 0;
-  }
-  function isSingleVariableDeclaration(parent2) {
-    return isVariableDeclaration(parent2) || isVariableDeclarationList(parent2) && parent2.declarations.length === 1;
-  }
-  function tryGetFunctionFromVariableDeclaration(sourceFile, typeChecker, parent2) {
-    if (!isSingleVariableDeclaration(parent2)) {
-      return void 0;
-    }
-    const variableDeclaration = isVariableDeclaration(parent2) ? parent2 : first(parent2.declarations);
-    const initializer = variableDeclaration.initializer;
-    if (initializer && (isArrowFunction(initializer) || isFunctionExpression(initializer) && !isFunctionReferencedInFile(sourceFile, typeChecker, initializer))) {
-      return initializer;
-    }
-    return void 0;
-  }
-  function convertToBlock(body) {
-    if (isExpression(body)) {
-      const returnStatement = factory.createReturnStatement(body);
-      const file = body.getSourceFile();
-      setTextRange(returnStatement, body);
-      suppressLeadingAndTrailingTrivia(returnStatement);
-      copyTrailingAsLeadingComments(
-        body,
-        returnStatement,
-        file,
-        /*commentKind*/
-        void 0,
-        /*hasTrailingNewLine*/
-        true
-      );
-      return factory.createBlock(
-        [returnStatement],
-        /*multiLine*/
-        true
-      );
-    } else {
-      return body;
-    }
-  }
-  function getVariableInfo(func) {
-    const variableDeclaration = func.parent;
-    if (!isVariableDeclaration(variableDeclaration) || !isVariableDeclarationInVariableStatement(variableDeclaration))
-      return void 0;
-    const variableDeclarationList = variableDeclaration.parent;
-    const statement = variableDeclarationList.parent;
-    if (!isVariableDeclarationList(variableDeclarationList) || !isVariableStatement(statement) || !isIdentifier(variableDeclaration.name))
-      return void 0;
-    return { variableDeclaration, variableDeclarationList, statement, name: variableDeclaration.name };
-  }
-  function getEditInfoForConvertToAnonymousFunction(context, func) {
-    const { file } = context;
-    const body = convertToBlock(func.body);
-    const newNode = factory.createFunctionExpression(
-      func.modifiers,
-      func.asteriskToken,
-      /*name*/
-      void 0,
-      func.typeParameters,
-      func.parameters,
-      func.type,
-      body
-    );
-    return ts_textChanges_exports.ChangeTracker.with(context, (t) => t.replaceNode(file, func, newNode));
-  }
-  function getEditInfoForConvertToNamedFunction(context, func, variableInfo) {
-    const { file } = context;
-    const body = convertToBlock(func.body);
-    const { variableDeclaration, variableDeclarationList, statement, name } = variableInfo;
-    suppressLeadingTrivia(statement);
-    const modifiersFlags = getCombinedModifierFlags(variableDeclaration) & 1 /* Export */ | getEffectiveModifierFlags(func);
-    const modifiers = factory.createModifiersFromModifierFlags(modifiersFlags);
-    const newNode = factory.createFunctionDeclaration(length(modifiers) ? modifiers : void 0, func.asteriskToken, name, func.typeParameters, func.parameters, func.type, body);
-    if (variableDeclarationList.declarations.length === 1) {
-      return ts_textChanges_exports.ChangeTracker.with(context, (t) => t.replaceNode(file, statement, newNode));
-    } else {
-      return ts_textChanges_exports.ChangeTracker.with(context, (t) => {
-        t.delete(file, variableDeclaration);
-        t.insertNodeAfter(file, statement, newNode);
-      });
-    }
-  }
-  function getEditInfoForConvertToArrowFunction(context, func) {
-    const { file } = context;
-    const statements = func.body.statements;
-    const head = statements[0];
-    let body;
-    if (canBeConvertedToExpression(func.body, head)) {
-      body = head.expression;
-      suppressLeadingAndTrailingTrivia(body);
-      copyComments(head, body);
-    } else {
-      body = func.body;
-    }
-    const newNode = factory.createArrowFunction(func.modifiers, func.typeParameters, func.parameters, func.type, factory.createToken(39 /* EqualsGreaterThanToken */), body);
-    return ts_textChanges_exports.ChangeTracker.with(context, (t) => t.replaceNode(file, func, newNode));
-  }
-  function canBeConvertedToExpression(body, head) {
-    return body.statements.length === 1 && (isReturnStatement(head) && !!head.expression);
-  }
-  function isFunctionReferencedInFile(sourceFile, typeChecker, node) {
-    return !!node.name && ts_FindAllReferences_exports.Core.isSymbolReferencedInFile(node.name, typeChecker, sourceFile);
-  }
-  var refactorName7, refactorDescription3, toAnonymousFunctionAction, toNamedFunctionAction, toArrowFunctionAction;
-  var init_convertArrowFunctionOrFunctionExpression = __esm({
-    "src/services/refactors/convertArrowFunctionOrFunctionExpression.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_refactor();
-      refactorName7 = "Convert arrow function or function expression";
-      refactorDescription3 = getLocaleSpecificMessage(Diagnostics.Convert_arrow_function_or_function_expression);
-      toAnonymousFunctionAction = {
-        name: "Convert to anonymous function",
-        description: getLocaleSpecificMessage(Diagnostics.Convert_to_anonymous_function),
-        kind: "refactor.rewrite.function.anonymous"
-      };
-      toNamedFunctionAction = {
-        name: "Convert to named function",
-        description: getLocaleSpecificMessage(Diagnostics.Convert_to_named_function),
-        kind: "refactor.rewrite.function.named"
-      };
-      toArrowFunctionAction = {
-        name: "Convert to arrow function",
-        description: getLocaleSpecificMessage(Diagnostics.Convert_to_arrow_function),
-        kind: "refactor.rewrite.function.arrow"
-      };
-      registerRefactor(refactorName7, {
-        kinds: [
-          toAnonymousFunctionAction.kind,
-          toNamedFunctionAction.kind,
-          toArrowFunctionAction.kind
-        ],
-        getEditsForAction: getRefactorEditsToConvertFunctionExpressions,
-        getAvailableActions: getRefactorActionsToConvertFunctionExpressions
-      });
-    }
-  });
-
-  // src/services/_namespaces/ts.refactor.convertArrowFunctionOrFunctionExpression.ts
-  var ts_refactor_convertArrowFunctionOrFunctionExpression_exports = {};
-  var init_ts_refactor_convertArrowFunctionOrFunctionExpression = __esm({
-    "src/services/_namespaces/ts.refactor.convertArrowFunctionOrFunctionExpression.ts"() {
-      "use strict";
-      init_convertArrowFunctionOrFunctionExpression();
-    }
-  });
-
-  // src/services/refactors/convertParamsToDestructuredObject.ts
-  function getRefactorActionsToConvertParametersToDestructuredObject(context) {
-    const { file, startPosition } = context;
-    const isJSFile = isSourceFileJS(file);
-    if (isJSFile)
-      return emptyArray;
-    const functionDeclaration = getFunctionDeclarationAtPosition(file, startPosition, context.program.getTypeChecker());
-    if (!functionDeclaration)
-      return emptyArray;
-    return [{
-      name: refactorName8,
-      description: refactorDescription4,
-      actions: [toDestructuredAction]
-    }];
-  }
-  function getRefactorEditsToConvertParametersToDestructuredObject(context, actionName2) {
-    Debug.assert(actionName2 === refactorName8, "Unexpected action name");
-    const { file, startPosition, program, cancellationToken, host } = context;
-    const functionDeclaration = getFunctionDeclarationAtPosition(file, startPosition, program.getTypeChecker());
-    if (!functionDeclaration || !cancellationToken)
-      return void 0;
-    const groupedReferences = getGroupedReferences(functionDeclaration, program, cancellationToken);
-    if (groupedReferences.valid) {
-      const edits = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange5(file, program, host, t, functionDeclaration, groupedReferences));
-      return { renameFilename: void 0, renameLocation: void 0, edits };
-    }
-    return { edits: [] };
-  }
-  function doChange5(sourceFile, program, host, changes, functionDeclaration, groupedReferences) {
-    const signature = groupedReferences.signature;
-    const newFunctionDeclarationParams = map(createNewParameters(functionDeclaration, program, host), (param) => getSynthesizedDeepClone(param));
-    if (signature) {
-      const newSignatureParams = map(createNewParameters(signature, program, host), (param) => getSynthesizedDeepClone(param));
-      replaceParameters(signature, newSignatureParams);
-    }
-    replaceParameters(functionDeclaration, newFunctionDeclarationParams);
-    const functionCalls = sortAndDeduplicate(
-      groupedReferences.functionCalls,
-      /*comparer*/
-      (a, b) => compareValues(a.pos, b.pos)
-    );
-    for (const call of functionCalls) {
-      if (call.arguments && call.arguments.length) {
-        const newArgument = getSynthesizedDeepClone(
-          createNewArgument(functionDeclaration, call.arguments),
-          /*includeTrivia*/
-          true
-        );
-        changes.replaceNodeRange(
-          getSourceFileOfNode(call),
-          first(call.arguments),
-          last(call.arguments),
-          newArgument,
-          { leadingTriviaOption: ts_textChanges_exports.LeadingTriviaOption.IncludeAll, trailingTriviaOption: ts_textChanges_exports.TrailingTriviaOption.Include }
-        );
-      }
-    }
-    function replaceParameters(declarationOrSignature, parameterDeclarations) {
-      changes.replaceNodeRangeWithNodes(
-        sourceFile,
-        first(declarationOrSignature.parameters),
-        last(declarationOrSignature.parameters),
-        parameterDeclarations,
-        {
-          joiner: ", ",
-          // indentation is set to 0 because otherwise the object parameter will be indented if there is a `this` parameter
-          indentation: 0,
-          leadingTriviaOption: ts_textChanges_exports.LeadingTriviaOption.IncludeAll,
-          trailingTriviaOption: ts_textChanges_exports.TrailingTriviaOption.Include
-        }
-      );
-    }
-  }
-  function getGroupedReferences(functionDeclaration, program, cancellationToken) {
-    const functionNames = getFunctionNames(functionDeclaration);
-    const classNames = isConstructorDeclaration(functionDeclaration) ? getClassNames(functionDeclaration) : [];
-    const names = deduplicate([...functionNames, ...classNames], equateValues);
-    const checker = program.getTypeChecker();
-    const references = flatMap(
-      names,
-      /*mapfn*/
-      (name) => ts_FindAllReferences_exports.getReferenceEntriesForNode(-1, name, program, program.getSourceFiles(), cancellationToken)
-    );
-    const groupedReferences = groupReferences(references);
-    if (!every(
-      groupedReferences.declarations,
-      /*callback*/
-      (decl) => contains(names, decl)
-    )) {
-      groupedReferences.valid = false;
-    }
-    return groupedReferences;
-    function groupReferences(referenceEntries) {
-      const classReferences = { accessExpressions: [], typeUsages: [] };
-      const groupedReferences2 = { functionCalls: [], declarations: [], classReferences, valid: true };
-      const functionSymbols = map(functionNames, getSymbolTargetAtLocation);
-      const classSymbols = map(classNames, getSymbolTargetAtLocation);
-      const isConstructor = isConstructorDeclaration(functionDeclaration);
-      const contextualSymbols = map(functionNames, (name) => getSymbolForContextualType(name, checker));
-      for (const entry of referenceEntries) {
-        if (entry.kind === ts_FindAllReferences_exports.EntryKind.Span) {
-          groupedReferences2.valid = false;
-          continue;
-        }
-        if (contains(contextualSymbols, getSymbolTargetAtLocation(entry.node))) {
-          if (isValidMethodSignature(entry.node.parent)) {
-            groupedReferences2.signature = entry.node.parent;
-            continue;
-          }
-          const call = entryToFunctionCall(entry);
-          if (call) {
-            groupedReferences2.functionCalls.push(call);
-            continue;
-          }
-        }
-        const contextualSymbol = getSymbolForContextualType(entry.node, checker);
-        if (contextualSymbol && contains(contextualSymbols, contextualSymbol)) {
-          const decl = entryToDeclaration(entry);
-          if (decl) {
-            groupedReferences2.declarations.push(decl);
-            continue;
-          }
-        }
-        if (contains(functionSymbols, getSymbolTargetAtLocation(entry.node)) || isNewExpressionTarget(entry.node)) {
-          const importOrExportReference = entryToImportOrExport(entry);
-          if (importOrExportReference) {
-            continue;
-          }
-          const decl = entryToDeclaration(entry);
-          if (decl) {
-            groupedReferences2.declarations.push(decl);
-            continue;
-          }
-          const call = entryToFunctionCall(entry);
-          if (call) {
-            groupedReferences2.functionCalls.push(call);
-            continue;
-          }
-        }
-        if (isConstructor && contains(classSymbols, getSymbolTargetAtLocation(entry.node))) {
-          const importOrExportReference = entryToImportOrExport(entry);
-          if (importOrExportReference) {
-            continue;
-          }
-          const decl = entryToDeclaration(entry);
-          if (decl) {
-            groupedReferences2.declarations.push(decl);
-            continue;
-          }
-          const accessExpression = entryToAccessExpression(entry);
-          if (accessExpression) {
-            classReferences.accessExpressions.push(accessExpression);
-            continue;
-          }
-          if (isClassDeclaration(functionDeclaration.parent)) {
-            const type = entryToType(entry);
-            if (type) {
-              classReferences.typeUsages.push(type);
-              continue;
-            }
-          }
-        }
-        groupedReferences2.valid = false;
-      }
-      return groupedReferences2;
-    }
-    function getSymbolTargetAtLocation(node) {
-      const symbol = checker.getSymbolAtLocation(node);
-      return symbol && getSymbolTarget(symbol, checker);
-    }
-  }
-  function getSymbolForContextualType(node, checker) {
-    const element = getContainingObjectLiteralElement(node);
-    if (element) {
-      const contextualType = checker.getContextualTypeForObjectLiteralElement(element);
-      const symbol = contextualType == null ? void 0 : contextualType.getSymbol();
-      if (symbol && !(getCheckFlags(symbol) & 6 /* Synthetic */)) {
-        return symbol;
-      }
-    }
-  }
-  function entryToImportOrExport(entry) {
-    const node = entry.node;
-    if (isImportSpecifier(node.parent) || isImportClause(node.parent) || isImportEqualsDeclaration(node.parent) || isNamespaceImport(node.parent)) {
-      return node;
-    }
-    if (isExportSpecifier(node.parent) || isExportAssignment(node.parent)) {
-      return node;
-    }
-    return void 0;
-  }
-  function entryToDeclaration(entry) {
-    if (isDeclaration(entry.node.parent)) {
-      return entry.node;
-    }
-    return void 0;
-  }
-  function entryToFunctionCall(entry) {
-    if (entry.node.parent) {
-      const functionReference = entry.node;
-      const parent2 = functionReference.parent;
-      switch (parent2.kind) {
-        case 212 /* CallExpression */:
-        case 213 /* NewExpression */:
-          const callOrNewExpression = tryCast(parent2, isCallOrNewExpression);
-          if (callOrNewExpression && callOrNewExpression.expression === functionReference) {
-            return callOrNewExpression;
-          }
-          break;
-        case 210 /* PropertyAccessExpression */:
-          const propertyAccessExpression = tryCast(parent2, isPropertyAccessExpression);
-          if (propertyAccessExpression && propertyAccessExpression.parent && propertyAccessExpression.name === functionReference) {
-            const callOrNewExpression2 = tryCast(propertyAccessExpression.parent, isCallOrNewExpression);
-            if (callOrNewExpression2 && callOrNewExpression2.expression === propertyAccessExpression) {
-              return callOrNewExpression2;
-            }
-          }
-          break;
-        case 211 /* ElementAccessExpression */:
-          const elementAccessExpression = tryCast(parent2, isElementAccessExpression);
-          if (elementAccessExpression && elementAccessExpression.parent && elementAccessExpression.argumentExpression === functionReference) {
-            const callOrNewExpression2 = tryCast(elementAccessExpression.parent, isCallOrNewExpression);
-            if (callOrNewExpression2 && callOrNewExpression2.expression === elementAccessExpression) {
-              return callOrNewExpression2;
-            }
-          }
-          break;
-      }
-    }
-    return void 0;
-  }
-  function entryToAccessExpression(entry) {
-    if (entry.node.parent) {
-      const reference = entry.node;
-      const parent2 = reference.parent;
-      switch (parent2.kind) {
-        case 210 /* PropertyAccessExpression */:
-          const propertyAccessExpression = tryCast(parent2, isPropertyAccessExpression);
-          if (propertyAccessExpression && propertyAccessExpression.expression === reference) {
-            return propertyAccessExpression;
-          }
-          break;
-        case 211 /* ElementAccessExpression */:
-          const elementAccessExpression = tryCast(parent2, isElementAccessExpression);
-          if (elementAccessExpression && elementAccessExpression.expression === reference) {
-            return elementAccessExpression;
-          }
-          break;
-      }
-    }
-    return void 0;
-  }
-  function entryToType(entry) {
-    const reference = entry.node;
-    if (getMeaningFromLocation(reference) === 2 /* Type */ || isExpressionWithTypeArgumentsInClassExtendsClause(reference.parent)) {
-      return reference;
-    }
-    return void 0;
-  }
-  function getFunctionDeclarationAtPosition(file, startPosition, checker) {
-    const node = getTouchingToken(file, startPosition);
-    const functionDeclaration = getContainingFunctionDeclaration(node);
-    if (isTopLevelJSDoc(node))
-      return void 0;
-    if (functionDeclaration && isValidFunctionDeclaration(functionDeclaration, checker) && rangeContainsRange(functionDeclaration, node) && !(functionDeclaration.body && rangeContainsRange(functionDeclaration.body, node)))
-      return functionDeclaration;
-    return void 0;
-  }
-  function isTopLevelJSDoc(node) {
-    const containingJSDoc = findAncestor(node, isJSDocNode);
-    if (containingJSDoc) {
-      const containingNonJSDoc = findAncestor(containingJSDoc, (n) => !isJSDocNode(n));
-      return !!containingNonJSDoc && isFunctionLikeDeclaration(containingNonJSDoc);
-    }
-    return false;
-  }
-  function isValidMethodSignature(node) {
-    return isMethodSignature(node) && (isInterfaceDeclaration(node.parent) || isTypeLiteralNode(node.parent));
-  }
-  function isValidFunctionDeclaration(functionDeclaration, checker) {
-    var _a;
-    if (!isValidParameterNodeArray(functionDeclaration.parameters, checker))
-      return false;
-    switch (functionDeclaration.kind) {
-      case 261 /* FunctionDeclaration */:
-        return hasNameOrDefault(functionDeclaration) && isSingleImplementation(functionDeclaration, checker);
-      case 173 /* MethodDeclaration */:
-        if (isObjectLiteralExpression(functionDeclaration.parent)) {
-          const contextualSymbol = getSymbolForContextualType(functionDeclaration.name, checker);
-          return ((_a = contextualSymbol == null ? void 0 : contextualSymbol.declarations) == null ? void 0 : _a.length) === 1 && isSingleImplementation(functionDeclaration, checker);
-        }
-        return isSingleImplementation(functionDeclaration, checker);
-      case 175 /* Constructor */:
-        if (isClassDeclaration(functionDeclaration.parent)) {
-          return hasNameOrDefault(functionDeclaration.parent) && isSingleImplementation(functionDeclaration, checker);
-        } else {
-          return isValidVariableDeclaration(functionDeclaration.parent.parent) && isSingleImplementation(functionDeclaration, checker);
-        }
-      case 217 /* FunctionExpression */:
-      case 218 /* ArrowFunction */:
-        return isValidVariableDeclaration(functionDeclaration.parent);
-    }
-    return false;
-  }
-  function isSingleImplementation(functionDeclaration, checker) {
-    return !!functionDeclaration.body && !checker.isImplementationOfOverload(functionDeclaration);
-  }
-  function hasNameOrDefault(functionOrClassDeclaration) {
-    if (!functionOrClassDeclaration.name) {
-      const defaultKeyword = findModifier(functionOrClassDeclaration, 90 /* DefaultKeyword */);
-      return !!defaultKeyword;
-    }
-    return true;
-  }
-  function isValidParameterNodeArray(parameters, checker) {
-    return getRefactorableParametersLength(parameters) >= minimumParameterLength && every(
-      parameters,
-      /*callback*/
-      (paramDecl) => isValidParameterDeclaration(paramDecl, checker)
-    );
-  }
-  function isValidParameterDeclaration(parameterDeclaration, checker) {
-    if (isRestParameter(parameterDeclaration)) {
-      const type = checker.getTypeAtLocation(parameterDeclaration);
-      if (!checker.isArrayType(type) && !checker.isTupleType(type))
-        return false;
-    }
-    return !parameterDeclaration.modifiers && isIdentifier(parameterDeclaration.name);
-  }
-  function isValidVariableDeclaration(node) {
-    return isVariableDeclaration(node) && isVarConst(node) && isIdentifier(node.name) && !node.type;
-  }
-  function hasThisParameter(parameters) {
-    return parameters.length > 0 && isThis(parameters[0].name);
-  }
-  function getRefactorableParametersLength(parameters) {
-    if (hasThisParameter(parameters)) {
-      return parameters.length - 1;
-    }
-    return parameters.length;
-  }
-  function getRefactorableParameters(parameters) {
-    if (hasThisParameter(parameters)) {
-      parameters = factory.createNodeArray(parameters.slice(1), parameters.hasTrailingComma);
-    }
-    return parameters;
-  }
-  function createPropertyOrShorthandAssignment(name, initializer) {
-    if (isIdentifier(initializer) && getTextOfIdentifierOrLiteral(initializer) === name) {
-      return factory.createShorthandPropertyAssignment(name);
-    }
-    return factory.createPropertyAssignment(name, initializer);
-  }
-  function createNewArgument(functionDeclaration, functionArguments) {
-    const parameters = getRefactorableParameters(functionDeclaration.parameters);
-    const hasRestParameter2 = isRestParameter(last(parameters));
-    const nonRestArguments = hasRestParameter2 ? functionArguments.slice(0, parameters.length - 1) : functionArguments;
-    const properties = map(nonRestArguments, (arg, i) => {
-      const parameterName = getParameterName(parameters[i]);
-      const property = createPropertyOrShorthandAssignment(parameterName, arg);
-      suppressLeadingAndTrailingTrivia(property.name);
-      if (isPropertyAssignment(property))
-        suppressLeadingAndTrailingTrivia(property.initializer);
-      copyComments(arg, property);
-      return property;
-    });
-    if (hasRestParameter2 && functionArguments.length >= parameters.length) {
-      const restArguments = functionArguments.slice(parameters.length - 1);
-      const restProperty = factory.createPropertyAssignment(getParameterName(last(parameters)), factory.createArrayLiteralExpression(restArguments));
-      properties.push(restProperty);
-    }
-    const objectLiteral = factory.createObjectLiteralExpression(
-      properties,
-      /*multiLine*/
-      false
-    );
-    return objectLiteral;
-  }
-  function createNewParameters(functionDeclaration, program, host) {
-    const checker = program.getTypeChecker();
-    const refactorableParameters = getRefactorableParameters(functionDeclaration.parameters);
-    const bindingElements = map(refactorableParameters, createBindingElementFromParameterDeclaration);
-    const objectParameterName = factory.createObjectBindingPattern(bindingElements);
-    const objectParameterType = createParameterTypeNode(refactorableParameters);
-    let objectInitializer;
-    if (every(refactorableParameters, isOptionalParameter)) {
-      objectInitializer = factory.createObjectLiteralExpression();
-    }
-    const objectParameter = factory.createParameterDeclaration(
-      /*modifiers*/
-      void 0,
-      /*dotDotDotToken*/
-      void 0,
-      objectParameterName,
-      /*questionToken*/
-      void 0,
-      objectParameterType,
-      objectInitializer
-    );
-    if (hasThisParameter(functionDeclaration.parameters)) {
-      const thisParameter = functionDeclaration.parameters[0];
-      const newThisParameter = factory.createParameterDeclaration(
-        /*modifiers*/
-        void 0,
-        /*dotDotDotToken*/
-        void 0,
-        thisParameter.name,
-        /*questionToken*/
-        void 0,
-        thisParameter.type
-      );
-      suppressLeadingAndTrailingTrivia(newThisParameter.name);
-      copyComments(thisParameter.name, newThisParameter.name);
-      if (thisParameter.type) {
-        suppressLeadingAndTrailingTrivia(newThisParameter.type);
-        copyComments(thisParameter.type, newThisParameter.type);
-      }
-      return factory.createNodeArray([newThisParameter, objectParameter]);
-    }
-    return factory.createNodeArray([objectParameter]);
-    function createBindingElementFromParameterDeclaration(parameterDeclaration) {
-      const element = factory.createBindingElement(
-        /*dotDotDotToken*/
-        void 0,
-        /*propertyName*/
-        void 0,
-        getParameterName(parameterDeclaration),
-        isRestParameter(parameterDeclaration) && isOptionalParameter(parameterDeclaration) ? factory.createArrayLiteralExpression() : parameterDeclaration.initializer
-      );
-      suppressLeadingAndTrailingTrivia(element);
-      if (parameterDeclaration.initializer && element.initializer) {
-        copyComments(parameterDeclaration.initializer, element.initializer);
-      }
-      return element;
-    }
-    function createParameterTypeNode(parameters) {
-      const members = map(parameters, createPropertySignatureFromParameterDeclaration);
-      const typeNode = addEmitFlags(factory.createTypeLiteralNode(members), 1 /* SingleLine */);
-      return typeNode;
-    }
-    function createPropertySignatureFromParameterDeclaration(parameterDeclaration) {
-      let parameterType = parameterDeclaration.type;
-      if (!parameterType && (parameterDeclaration.initializer || isRestParameter(parameterDeclaration))) {
-        parameterType = getTypeNode3(parameterDeclaration);
-      }
-      const propertySignature = factory.createPropertySignature(
-        /*modifiers*/
-        void 0,
-        getParameterName(parameterDeclaration),
-        isOptionalParameter(parameterDeclaration) ? factory.createToken(58 /* QuestionToken */) : parameterDeclaration.questionToken,
-        parameterType
-      );
-      suppressLeadingAndTrailingTrivia(propertySignature);
-      copyComments(parameterDeclaration.name, propertySignature.name);
-      if (parameterDeclaration.type && propertySignature.type) {
-        copyComments(parameterDeclaration.type, propertySignature.type);
-      }
-      return propertySignature;
-    }
-    function getTypeNode3(node) {
-      const type = checker.getTypeAtLocation(node);
-      return getTypeNodeIfAccessible(type, node, program, host);
-    }
-    function isOptionalParameter(parameterDeclaration) {
-      if (isRestParameter(parameterDeclaration)) {
-        const type = checker.getTypeAtLocation(parameterDeclaration);
-        return !checker.isTupleType(type);
-      }
-      return checker.isOptionalParameter(parameterDeclaration);
-    }
-  }
-  function getParameterName(paramDeclaration) {
-    return getTextOfIdentifierOrLiteral(paramDeclaration.name);
-  }
-  function getClassNames(constructorDeclaration) {
-    switch (constructorDeclaration.parent.kind) {
-      case 262 /* ClassDeclaration */:
-        const classDeclaration = constructorDeclaration.parent;
-        if (classDeclaration.name)
-          return [classDeclaration.name];
-        const defaultModifier = Debug.checkDefined(
-          findModifier(classDeclaration, 90 /* DefaultKeyword */),
-          "Nameless class declaration should be a default export"
-        );
-        return [defaultModifier];
-      case 230 /* ClassExpression */:
-        const classExpression = constructorDeclaration.parent;
-        const variableDeclaration = constructorDeclaration.parent.parent;
-        const className = classExpression.name;
-        if (className)
-          return [className, variableDeclaration.name];
-        return [variableDeclaration.name];
-    }
-  }
-  function getFunctionNames(functionDeclaration) {
-    switch (functionDeclaration.kind) {
-      case 261 /* FunctionDeclaration */:
-        if (functionDeclaration.name)
-          return [functionDeclaration.name];
-        const defaultModifier = Debug.checkDefined(
-          findModifier(functionDeclaration, 90 /* DefaultKeyword */),
-          "Nameless function declaration should be a default export"
-        );
-        return [defaultModifier];
-      case 173 /* MethodDeclaration */:
-        return [functionDeclaration.name];
-      case 175 /* Constructor */:
-        const ctrKeyword = Debug.checkDefined(
-          findChildOfKind(functionDeclaration, 137 /* ConstructorKeyword */, functionDeclaration.getSourceFile()),
-          "Constructor declaration should have constructor keyword"
-        );
-        if (functionDeclaration.parent.kind === 230 /* ClassExpression */) {
-          const variableDeclaration = functionDeclaration.parent.parent;
-          return [variableDeclaration.name, ctrKeyword];
-        }
-        return [ctrKeyword];
-      case 218 /* ArrowFunction */:
-        return [functionDeclaration.parent.name];
-      case 217 /* FunctionExpression */:
-        if (functionDeclaration.name)
-          return [functionDeclaration.name, functionDeclaration.parent.name];
-        return [functionDeclaration.parent.name];
-      default:
-        return Debug.assertNever(functionDeclaration, `Unexpected function declaration kind ${functionDeclaration.kind}`);
-    }
-  }
-  var refactorName8, minimumParameterLength, refactorDescription4, toDestructuredAction;
-  var init_convertParamsToDestructuredObject = __esm({
-    "src/services/refactors/convertParamsToDestructuredObject.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_refactor();
-      refactorName8 = "Convert parameters to destructured object";
-      minimumParameterLength = 1;
-      refactorDescription4 = getLocaleSpecificMessage(Diagnostics.Convert_parameters_to_destructured_object);
-      toDestructuredAction = {
-        name: refactorName8,
-        description: refactorDescription4,
-        kind: "refactor.rewrite.parameters.toDestructured"
-      };
-      registerRefactor(refactorName8, {
-        kinds: [toDestructuredAction.kind],
-        getEditsForAction: getRefactorEditsToConvertParametersToDestructuredObject,
-        getAvailableActions: getRefactorActionsToConvertParametersToDestructuredObject
-      });
-    }
-  });
-
-  // src/services/_namespaces/ts.refactor.convertParamsToDestructuredObject.ts
-  var ts_refactor_convertParamsToDestructuredObject_exports = {};
-  var init_ts_refactor_convertParamsToDestructuredObject = __esm({
-    "src/services/_namespaces/ts.refactor.convertParamsToDestructuredObject.ts"() {
-      "use strict";
-      init_convertParamsToDestructuredObject();
-    }
-  });
-
-  // src/services/refactors/convertStringOrTemplateLiteral.ts
-  function getRefactorActionsToConvertToTemplateString(context) {
-    const { file, startPosition } = context;
-    const node = getNodeOrParentOfParentheses(file, startPosition);
-    const maybeBinary = getParentBinaryExpression(node);
-    const refactorInfo = { name: refactorName9, description: refactorDescription5, actions: [] };
-    if (isBinaryExpression(maybeBinary) && treeToArray(maybeBinary).isValidConcatenation) {
-      refactorInfo.actions.push(convertStringAction);
-      return [refactorInfo];
-    } else if (context.preferences.provideRefactorNotApplicableReason) {
-      refactorInfo.actions.push({
-        ...convertStringAction,
-        notApplicableReason: getLocaleSpecificMessage(Diagnostics.Can_only_convert_string_concatenation)
-      });
-      return [refactorInfo];
-    }
-    return emptyArray;
-  }
-  function getNodeOrParentOfParentheses(file, startPosition) {
-    const node = getTokenAtPosition(file, startPosition);
-    const nestedBinary = getParentBinaryExpression(node);
-    const isNonStringBinary = !treeToArray(nestedBinary).isValidConcatenation;
-    if (isNonStringBinary && isParenthesizedExpression(nestedBinary.parent) && isBinaryExpression(nestedBinary.parent.parent)) {
-      return nestedBinary.parent.parent;
-    }
-    return node;
-  }
-  function getRefactorEditsToConvertToTemplateString(context, actionName2) {
-    const { file, startPosition } = context;
-    const node = getNodeOrParentOfParentheses(file, startPosition);
-    switch (actionName2) {
-      case refactorDescription5:
-        return { edits: getEditsForToTemplateLiteral(context, node) };
-      default:
-        return Debug.fail("invalid action");
-    }
-  }
-  function getEditsForToTemplateLiteral(context, node) {
-    const maybeBinary = getParentBinaryExpression(node);
-    const file = context.file;
-    const templateLiteral = nodesToTemplate(treeToArray(maybeBinary), file);
-    const trailingCommentRanges = getTrailingCommentRanges(file.text, maybeBinary.end);
-    if (trailingCommentRanges) {
-      const lastComment = trailingCommentRanges[trailingCommentRanges.length - 1];
-      const trailingRange = { pos: trailingCommentRanges[0].pos, end: lastComment.end };
-      return ts_textChanges_exports.ChangeTracker.with(context, (t) => {
-        t.deleteRange(file, trailingRange);
-        t.replaceNode(file, maybeBinary, templateLiteral);
-      });
-    } else {
-      return ts_textChanges_exports.ChangeTracker.with(context, (t) => t.replaceNode(file, maybeBinary, templateLiteral));
-    }
-  }
-  function isNotEqualsOperator(node) {
-    return node.operatorToken.kind !== 64 /* EqualsToken */;
-  }
-  function getParentBinaryExpression(expr) {
-    const container = findAncestor(expr.parent, (n) => {
-      switch (n.kind) {
-        case 210 /* PropertyAccessExpression */:
-        case 211 /* ElementAccessExpression */:
-          return false;
-        case 227 /* TemplateExpression */:
-        case 225 /* BinaryExpression */:
-          return !(isBinaryExpression(n.parent) && isNotEqualsOperator(n.parent));
-        default:
-          return "quit";
-      }
-    });
-    return container || expr;
-  }
-  function treeToArray(current) {
-    const loop = (current2) => {
-      if (!isBinaryExpression(current2)) {
-        return {
-          nodes: [current2],
-          operators: [],
-          validOperators: true,
-          hasString: isStringLiteral(current2) || isNoSubstitutionTemplateLiteral(current2)
-        };
-      }
-      const { nodes: nodes2, operators: operators2, hasString: leftHasString, validOperators: leftOperatorValid } = loop(current2.left);
-      if (!(leftHasString || isStringLiteral(current2.right) || isTemplateExpression(current2.right))) {
-        return { nodes: [current2], operators: [], hasString: false, validOperators: true };
-      }
-      const currentOperatorValid = current2.operatorToken.kind === 40 /* PlusToken */;
-      const validOperators2 = leftOperatorValid && currentOperatorValid;
-      nodes2.push(current2.right);
-      operators2.push(current2.operatorToken);
-      return { nodes: nodes2, operators: operators2, hasString: true, validOperators: validOperators2 };
-    };
-    const { nodes, operators, validOperators, hasString } = loop(current);
-    return { nodes, operators, isValidConcatenation: validOperators && hasString };
-  }
-  function escapeRawStringForTemplate(s) {
-    return s.replace(/\\.|[$`]/g, (m) => m[0] === "\\" ? m : "\\" + m);
-  }
-  function getRawTextOfTemplate(node) {
-    const rightShaving = isTemplateHead(node) || isTemplateMiddle(node) ? -2 : -1;
-    return getTextOfNode(node).slice(1, rightShaving);
-  }
-  function concatConsecutiveString(index, nodes) {
-    const indexes = [];
-    let text = "", rawText = "";
-    while (index < nodes.length) {
-      const node = nodes[index];
-      if (isStringLiteralLike(node)) {
-        text += node.text;
-        rawText += escapeRawStringForTemplate(getTextOfNode(node).slice(1, -1));
-        indexes.push(index);
-        index++;
-      } else if (isTemplateExpression(node)) {
-        text += node.head.text;
-        rawText += getRawTextOfTemplate(node.head);
-        break;
-      } else {
-        break;
-      }
-    }
-    return [index, text, rawText, indexes];
-  }
-  function nodesToTemplate({ nodes, operators }, file) {
-    const copyOperatorComments = copyTrailingOperatorComments(operators, file);
-    const copyCommentFromStringLiterals = copyCommentFromMultiNode(nodes, file, copyOperatorComments);
-    const [begin, headText, rawHeadText, headIndexes] = concatConsecutiveString(0, nodes);
-    if (begin === nodes.length) {
-      const noSubstitutionTemplateLiteral = factory.createNoSubstitutionTemplateLiteral(headText, rawHeadText);
-      copyCommentFromStringLiterals(headIndexes, noSubstitutionTemplateLiteral);
-      return noSubstitutionTemplateLiteral;
-    }
-    const templateSpans = [];
-    const templateHead = factory.createTemplateHead(headText, rawHeadText);
-    copyCommentFromStringLiterals(headIndexes, templateHead);
-    for (let i = begin; i < nodes.length; i++) {
-      const currentNode = getExpressionFromParenthesesOrExpression(nodes[i]);
-      copyOperatorComments(i, currentNode);
-      const [newIndex, subsequentText, rawSubsequentText, stringIndexes] = concatConsecutiveString(i + 1, nodes);
-      i = newIndex - 1;
-      const isLast = i === nodes.length - 1;
-      if (isTemplateExpression(currentNode)) {
-        const spans = map(currentNode.templateSpans, (span, index) => {
-          copyExpressionComments(span);
-          const isLastSpan = index === currentNode.templateSpans.length - 1;
-          const text = span.literal.text + (isLastSpan ? subsequentText : "");
-          const rawText = getRawTextOfTemplate(span.literal) + (isLastSpan ? rawSubsequentText : "");
-          return factory.createTemplateSpan(span.expression, isLast && isLastSpan ? factory.createTemplateTail(text, rawText) : factory.createTemplateMiddle(text, rawText));
-        });
-        templateSpans.push(...spans);
-      } else {
-        const templatePart = isLast ? factory.createTemplateTail(subsequentText, rawSubsequentText) : factory.createTemplateMiddle(subsequentText, rawSubsequentText);
-        copyCommentFromStringLiterals(stringIndexes, templatePart);
-        templateSpans.push(factory.createTemplateSpan(currentNode, templatePart));
-      }
-    }
-    return factory.createTemplateExpression(templateHead, templateSpans);
-  }
-  function copyExpressionComments(node) {
-    const file = node.getSourceFile();
-    copyTrailingComments(
-      node,
-      node.expression,
-      file,
-      3 /* MultiLineCommentTrivia */,
-      /*hasTrailingNewLine*/
-      false
-    );
-    copyTrailingAsLeadingComments(
-      node.expression,
-      node.expression,
-      file,
-      3 /* MultiLineCommentTrivia */,
-      /*hasTrailingNewLine*/
-      false
-    );
-  }
-  function getExpressionFromParenthesesOrExpression(node) {
-    if (isParenthesizedExpression(node)) {
-      copyExpressionComments(node);
-      node = node.expression;
-    }
-    return node;
-  }
-  var refactorName9, refactorDescription5, convertStringAction, copyTrailingOperatorComments, copyCommentFromMultiNode;
-  var init_convertStringOrTemplateLiteral = __esm({
-    "src/services/refactors/convertStringOrTemplateLiteral.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_refactor();
-      refactorName9 = "Convert to template string";
-      refactorDescription5 = getLocaleSpecificMessage(Diagnostics.Convert_to_template_string);
-      convertStringAction = {
-        name: refactorName9,
-        description: refactorDescription5,
-        kind: "refactor.rewrite.string"
-      };
-      registerRefactor(refactorName9, {
-        kinds: [convertStringAction.kind],
-        getEditsForAction: getRefactorEditsToConvertToTemplateString,
-        getAvailableActions: getRefactorActionsToConvertToTemplateString
-      });
-      copyTrailingOperatorComments = (operators, file) => (index, targetNode) => {
-        if (index < operators.length) {
-          copyTrailingComments(
-            operators[index],
-            targetNode,
-            file,
-            3 /* MultiLineCommentTrivia */,
-            /*hasTrailingNewLine*/
-            false
-          );
-        }
-      };
-      copyCommentFromMultiNode = (nodes, file, copyOperatorComments) => (indexes, targetNode) => {
-        while (indexes.length > 0) {
-          const index = indexes.shift();
-          copyTrailingComments(
-            nodes[index],
-            targetNode,
-            file,
-            3 /* MultiLineCommentTrivia */,
-            /*hasTrailingNewLine*/
-            false
-          );
-          copyOperatorComments(index, targetNode);
-        }
-      };
-    }
-  });
-
-  // src/services/_namespaces/ts.refactor.convertStringOrTemplateLiteral.ts
-  var ts_refactor_convertStringOrTemplateLiteral_exports = {};
-  var init_ts_refactor_convertStringOrTemplateLiteral = __esm({
-    "src/services/_namespaces/ts.refactor.convertStringOrTemplateLiteral.ts"() {
-      "use strict";
-      init_convertStringOrTemplateLiteral();
-    }
-  });
-
-  // src/services/refactors/convertToOptionalChainExpression.ts
-  function getRefactorActionsToConvertToOptionalChain(context) {
-    const info = getInfo3(context, context.triggerReason === "invoked");
-    if (!info)
-      return emptyArray;
-    if (!isRefactorErrorInfo(info)) {
-      return [{
-        name: refactorName10,
-        description: convertToOptionalChainExpressionMessage,
-        actions: [toOptionalChainAction]
-      }];
-    }
-    if (context.preferences.provideRefactorNotApplicableReason) {
-      return [{
-        name: refactorName10,
-        description: convertToOptionalChainExpressionMessage,
-        actions: [{ ...toOptionalChainAction, notApplicableReason: info.error }]
-      }];
-    }
-    return emptyArray;
-  }
-  function getRefactorEditsToConvertToOptionalChain(context, actionName2) {
-    const info = getInfo3(context);
-    Debug.assert(info && !isRefactorErrorInfo(info), "Expected applicable refactor info");
-    const edits = ts_textChanges_exports.ChangeTracker.with(
-      context,
-      (t) => doChange6(context.file, context.program.getTypeChecker(), t, info, actionName2)
-    );
-    return { edits, renameFilename: void 0, renameLocation: void 0 };
-  }
-  function isValidExpression(node) {
-    return isBinaryExpression(node) || isConditionalExpression(node);
-  }
-  function isValidStatement(node) {
-    return isExpressionStatement(node) || isReturnStatement(node) || isVariableStatement(node);
-  }
-  function isValidExpressionOrStatement(node) {
-    return isValidExpression(node) || isValidStatement(node);
-  }
-  function getInfo3(context, considerEmptySpans = true) {
-    const { file, program } = context;
-    const span = getRefactorContextSpan(context);
-    const forEmptySpan = span.length === 0;
-    if (forEmptySpan && !considerEmptySpans)
-      return void 0;
-    const startToken = getTokenAtPosition(file, span.start);
-    const endToken = findTokenOnLeftOfPosition(file, span.start + span.length);
-    const adjustedSpan = createTextSpanFromBounds(startToken.pos, endToken && endToken.end >= startToken.pos ? endToken.getEnd() : startToken.getEnd());
-    const parent2 = forEmptySpan ? getValidParentNodeOfEmptySpan(startToken) : getValidParentNodeContainingSpan(startToken, adjustedSpan);
-    const expression = parent2 && isValidExpressionOrStatement(parent2) ? getExpression(parent2) : void 0;
-    if (!expression)
-      return { error: getLocaleSpecificMessage(Diagnostics.Could_not_find_convertible_access_expression) };
-    const checker = program.getTypeChecker();
-    return isConditionalExpression(expression) ? getConditionalInfo(expression, checker) : getBinaryInfo(expression);
-  }
-  function getConditionalInfo(expression, checker) {
-    const condition = expression.condition;
-    const finalExpression = getFinalExpressionInChain(expression.whenTrue);
-    if (!finalExpression || checker.isNullableType(checker.getTypeAtLocation(finalExpression))) {
-      return { error: getLocaleSpecificMessage(Diagnostics.Could_not_find_convertible_access_expression) };
-    }
-    if ((isPropertyAccessExpression(condition) || isIdentifier(condition)) && getMatchingStart(condition, finalExpression.expression)) {
-      return { finalExpression, occurrences: [condition], expression };
-    } else if (isBinaryExpression(condition)) {
-      const occurrences = getOccurrencesInExpression(finalExpression.expression, condition);
-      return occurrences ? { finalExpression, occurrences, expression } : { error: getLocaleSpecificMessage(Diagnostics.Could_not_find_matching_access_expressions) };
-    }
-  }
-  function getBinaryInfo(expression) {
-    if (expression.operatorToken.kind !== 56 /* AmpersandAmpersandToken */) {
-      return { error: getLocaleSpecificMessage(Diagnostics.Can_only_convert_logical_AND_access_chains) };
-    }
-    const finalExpression = getFinalExpressionInChain(expression.right);
-    if (!finalExpression)
-      return { error: getLocaleSpecificMessage(Diagnostics.Could_not_find_convertible_access_expression) };
-    const occurrences = getOccurrencesInExpression(finalExpression.expression, expression.left);
-    return occurrences ? { finalExpression, occurrences, expression } : { error: getLocaleSpecificMessage(Diagnostics.Could_not_find_matching_access_expressions) };
-  }
-  function getOccurrencesInExpression(matchTo, expression) {
-    const occurrences = [];
-    while (isBinaryExpression(expression) && expression.operatorToken.kind === 56 /* AmpersandAmpersandToken */) {
-      const match = getMatchingStart(skipParentheses(matchTo), skipParentheses(expression.right));
-      if (!match) {
-        break;
-      }
-      occurrences.push(match);
-      matchTo = match;
-      expression = expression.left;
-    }
-    const finalMatch = getMatchingStart(matchTo, expression);
-    if (finalMatch) {
-      occurrences.push(finalMatch);
-    }
-    return occurrences.length > 0 ? occurrences : void 0;
-  }
-  function getMatchingStart(chain, subchain) {
-    if (!isIdentifier(subchain) && !isPropertyAccessExpression(subchain) && !isElementAccessExpression(subchain)) {
-      return void 0;
-    }
-    return chainStartsWith(chain, subchain) ? subchain : void 0;
-  }
-  function chainStartsWith(chain, subchain) {
-    while (isCallExpression(chain) || isPropertyAccessExpression(chain) || isElementAccessExpression(chain)) {
-      if (getTextOfChainNode(chain) === getTextOfChainNode(subchain))
-        break;
-      chain = chain.expression;
-    }
-    while (isPropertyAccessExpression(chain) && isPropertyAccessExpression(subchain) || isElementAccessExpression(chain) && isElementAccessExpression(subchain)) {
-      if (getTextOfChainNode(chain) !== getTextOfChainNode(subchain))
-        return false;
-      chain = chain.expression;
-      subchain = subchain.expression;
-    }
-    return isIdentifier(chain) && isIdentifier(subchain) && chain.getText() === subchain.getText();
-  }
-  function getTextOfChainNode(node) {
-    if (isIdentifier(node) || isStringOrNumericLiteralLike(node)) {
-      return node.getText();
-    }
-    if (isPropertyAccessExpression(node)) {
-      return getTextOfChainNode(node.name);
-    }
-    if (isElementAccessExpression(node)) {
-      return getTextOfChainNode(node.argumentExpression);
-    }
-    return void 0;
-  }
-  function getValidParentNodeContainingSpan(node, span) {
-    while (node.parent) {
-      if (isValidExpressionOrStatement(node) && span.length !== 0 && node.end >= span.start + span.length) {
-        return node;
-      }
-      node = node.parent;
-    }
-    return void 0;
-  }
-  function getValidParentNodeOfEmptySpan(node) {
-    while (node.parent) {
-      if (isValidExpressionOrStatement(node) && !isValidExpressionOrStatement(node.parent)) {
-        return node;
-      }
-      node = node.parent;
-    }
-    return void 0;
-  }
-  function getExpression(node) {
-    if (isValidExpression(node)) {
-      return node;
-    }
-    if (isVariableStatement(node)) {
-      const variable = getSingleVariableOfVariableStatement(node);
-      const initializer = variable == null ? void 0 : variable.initializer;
-      return initializer && isValidExpression(initializer) ? initializer : void 0;
-    }
-    return node.expression && isValidExpression(node.expression) ? node.expression : void 0;
-  }
-  function getFinalExpressionInChain(node) {
-    node = skipParentheses(node);
-    if (isBinaryExpression(node)) {
-      return getFinalExpressionInChain(node.left);
-    } else if ((isPropertyAccessExpression(node) || isElementAccessExpression(node) || isCallExpression(node)) && !isOptionalChain(node)) {
-      return node;
-    }
-    return void 0;
-  }
-  function convertOccurrences(checker, toConvert, occurrences) {
-    if (isPropertyAccessExpression(toConvert) || isElementAccessExpression(toConvert) || isCallExpression(toConvert)) {
-      const chain = convertOccurrences(checker, toConvert.expression, occurrences);
-      const lastOccurrence = occurrences.length > 0 ? occurrences[occurrences.length - 1] : void 0;
-      const isOccurrence = (lastOccurrence == null ? void 0 : lastOccurrence.getText()) === toConvert.expression.getText();
-      if (isOccurrence)
-        occurrences.pop();
-      if (isCallExpression(toConvert)) {
-        return isOccurrence ? factory.createCallChain(chain, factory.createToken(29 /* QuestionDotToken */), toConvert.typeArguments, toConvert.arguments) : factory.createCallChain(chain, toConvert.questionDotToken, toConvert.typeArguments, toConvert.arguments);
-      } else if (isPropertyAccessExpression(toConvert)) {
-        return isOccurrence ? factory.createPropertyAccessChain(chain, factory.createToken(29 /* QuestionDotToken */), toConvert.name) : factory.createPropertyAccessChain(chain, toConvert.questionDotToken, toConvert.name);
-      } else if (isElementAccessExpression(toConvert)) {
-        return isOccurrence ? factory.createElementAccessChain(chain, factory.createToken(29 /* QuestionDotToken */), toConvert.argumentExpression) : factory.createElementAccessChain(chain, toConvert.questionDotToken, toConvert.argumentExpression);
-      }
-    }
-    return toConvert;
-  }
-  function doChange6(sourceFile, checker, changes, info, _actionName) {
-    const { finalExpression, occurrences, expression } = info;
-    const firstOccurrence = occurrences[occurrences.length - 1];
-    const convertedChain = convertOccurrences(checker, finalExpression, occurrences);
-    if (convertedChain && (isPropertyAccessExpression(convertedChain) || isElementAccessExpression(convertedChain) || isCallExpression(convertedChain))) {
-      if (isBinaryExpression(expression)) {
-        changes.replaceNodeRange(sourceFile, firstOccurrence, finalExpression, convertedChain);
-      } else if (isConditionalExpression(expression)) {
-        changes.replaceNode(
-          sourceFile,
-          expression,
-          factory.createBinaryExpression(convertedChain, factory.createToken(61 /* QuestionQuestionToken */), expression.whenFalse)
-        );
-      }
-    }
-  }
-  var refactorName10, convertToOptionalChainExpressionMessage, toOptionalChainAction;
-  var init_convertToOptionalChainExpression = __esm({
-    "src/services/refactors/convertToOptionalChainExpression.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_refactor();
-      refactorName10 = "Convert to optional chain expression";
-      convertToOptionalChainExpressionMessage = getLocaleSpecificMessage(Diagnostics.Convert_to_optional_chain_expression);
-      toOptionalChainAction = {
-        name: refactorName10,
-        description: convertToOptionalChainExpressionMessage,
-        kind: "refactor.rewrite.expression.optionalChain"
-      };
-      registerRefactor(refactorName10, {
-        kinds: [toOptionalChainAction.kind],
-        getEditsForAction: getRefactorEditsToConvertToOptionalChain,
-        getAvailableActions: getRefactorActionsToConvertToOptionalChain
-      });
-    }
-  });
-
-  // src/services/_namespaces/ts.refactor.convertToOptionalChainExpression.ts
-  var ts_refactor_convertToOptionalChainExpression_exports = {};
-  var init_ts_refactor_convertToOptionalChainExpression = __esm({
-    "src/services/_namespaces/ts.refactor.convertToOptionalChainExpression.ts"() {
-      "use strict";
-      init_convertToOptionalChainExpression();
-    }
-  });
-
-  // src/services/refactors/extractSymbol.ts
-  function getRefactorActionsToExtractSymbol(context) {
-    const requestedRefactor = context.kind;
-    const rangeToExtract = getRangeToExtract2(context.file, getRefactorContextSpan(context), context.triggerReason === "invoked");
-    const targetRange = rangeToExtract.targetRange;
-    if (targetRange === void 0) {
-      if (!rangeToExtract.errors || rangeToExtract.errors.length === 0 || !context.preferences.provideRefactorNotApplicableReason) {
-        return emptyArray;
-      }
-      const errors = [];
-      if (refactorKindBeginsWith(extractFunctionAction.kind, requestedRefactor)) {
-        errors.push({
-          name: refactorName11,
-          description: extractFunctionAction.description,
-          actions: [{ ...extractFunctionAction, notApplicableReason: getStringError(rangeToExtract.errors) }]
-        });
-      }
-      if (refactorKindBeginsWith(extractConstantAction.kind, requestedRefactor)) {
-        errors.push({
-          name: refactorName11,
-          description: extractConstantAction.description,
-          actions: [{ ...extractConstantAction, notApplicableReason: getStringError(rangeToExtract.errors) }]
-        });
-      }
-      return errors;
-    }
-    const extractions = getPossibleExtractions(targetRange, context);
-    if (extractions === void 0) {
-      return emptyArray;
-    }
-    const functionActions = [];
-    const usedFunctionNames = /* @__PURE__ */ new Map();
-    let innermostErrorFunctionAction;
-    const constantActions = [];
-    const usedConstantNames = /* @__PURE__ */ new Map();
-    let innermostErrorConstantAction;
-    let i = 0;
-    for (const { functionExtraction, constantExtraction } of extractions) {
-      if (refactorKindBeginsWith(extractFunctionAction.kind, requestedRefactor)) {
-        const description3 = functionExtraction.description;
-        if (functionExtraction.errors.length === 0) {
-          if (!usedFunctionNames.has(description3)) {
-            usedFunctionNames.set(description3, true);
-            functionActions.push({
-              description: description3,
-              name: `function_scope_${i}`,
-              kind: extractFunctionAction.kind
-            });
-          }
-        } else if (!innermostErrorFunctionAction) {
-          innermostErrorFunctionAction = {
-            description: description3,
-            name: `function_scope_${i}`,
-            notApplicableReason: getStringError(functionExtraction.errors),
-            kind: extractFunctionAction.kind
-          };
-        }
-      }
-      if (refactorKindBeginsWith(extractConstantAction.kind, requestedRefactor)) {
-        const description3 = constantExtraction.description;
-        if (constantExtraction.errors.length === 0) {
-          if (!usedConstantNames.has(description3)) {
-            usedConstantNames.set(description3, true);
-            constantActions.push({
-              description: description3,
-              name: `constant_scope_${i}`,
-              kind: extractConstantAction.kind
-            });
-          }
-        } else if (!innermostErrorConstantAction) {
-          innermostErrorConstantAction = {
-            description: description3,
-            name: `constant_scope_${i}`,
-            notApplicableReason: getStringError(constantExtraction.errors),
-            kind: extractConstantAction.kind
-          };
-        }
-      }
-      i++;
-    }
-    const infos = [];
-    if (functionActions.length) {
-      infos.push({
-        name: refactorName11,
-        description: getLocaleSpecificMessage(Diagnostics.Extract_function),
-        actions: functionActions
-      });
-    } else if (context.preferences.provideRefactorNotApplicableReason && innermostErrorFunctionAction) {
-      infos.push({
-        name: refactorName11,
-        description: getLocaleSpecificMessage(Diagnostics.Extract_function),
-        actions: [innermostErrorFunctionAction]
-      });
-    }
-    if (constantActions.length) {
-      infos.push({
-        name: refactorName11,
-        description: getLocaleSpecificMessage(Diagnostics.Extract_constant),
-        actions: constantActions
-      });
-    } else if (context.preferences.provideRefactorNotApplicableReason && innermostErrorConstantAction) {
-      infos.push({
-        name: refactorName11,
-        description: getLocaleSpecificMessage(Diagnostics.Extract_constant),
-        actions: [innermostErrorConstantAction]
-      });
-    }
-    return infos.length ? infos : emptyArray;
-    function getStringError(errors) {
-      let error = errors[0].messageText;
-      if (typeof error !== "string") {
-        error = error.messageText;
-      }
-      return error;
-    }
-  }
-  function getRefactorEditsToExtractSymbol(context, actionName2) {
-    const rangeToExtract = getRangeToExtract2(context.file, getRefactorContextSpan(context));
-    const targetRange = rangeToExtract.targetRange;
-    const parsedFunctionIndexMatch = /^function_scope_(\d+)$/.exec(actionName2);
-    if (parsedFunctionIndexMatch) {
-      const index = +parsedFunctionIndexMatch[1];
-      Debug.assert(isFinite(index), "Expected to parse a finite number from the function scope index");
-      return getFunctionExtractionAtIndex(targetRange, context, index);
-    }
-    const parsedConstantIndexMatch = /^constant_scope_(\d+)$/.exec(actionName2);
-    if (parsedConstantIndexMatch) {
-      const index = +parsedConstantIndexMatch[1];
-      Debug.assert(isFinite(index), "Expected to parse a finite number from the constant scope index");
-      return getConstantExtractionAtIndex(targetRange, context, index);
-    }
-    Debug.fail("Unrecognized action name");
-  }
-  function getRangeToExtract2(sourceFile, span, invoked = true) {
-    const { length: length2 } = span;
-    if (length2 === 0 && !invoked) {
-      return { errors: [createFileDiagnostic(sourceFile, span.start, length2, Messages.cannotExtractEmpty)] };
-    }
-    const cursorRequest = length2 === 0 && invoked;
-    const startToken = findFirstNonJsxWhitespaceToken(sourceFile, span.start);
-    const endToken = findTokenOnLeftOfPosition(sourceFile, textSpanEnd(span));
-    const adjustedSpan = startToken && endToken && invoked ? getAdjustedSpanFromNodes(startToken, endToken, sourceFile) : span;
-    const start = cursorRequest ? getExtractableParent(startToken) : getParentNodeInSpan(startToken, sourceFile, adjustedSpan);
-    const end = cursorRequest ? start : getParentNodeInSpan(endToken, sourceFile, adjustedSpan);
-    let rangeFacts = 0 /* None */;
-    let thisNode;
-    if (!start || !end) {
-      return { errors: [createFileDiagnostic(sourceFile, span.start, length2, Messages.cannotExtractRange)] };
-    }
-    if (start.flags & 8388608 /* JSDoc */) {
-      return { errors: [createFileDiagnostic(sourceFile, span.start, length2, Messages.cannotExtractJSDoc)] };
-    }
-    if (start.parent !== end.parent) {
-      return { errors: [createFileDiagnostic(sourceFile, span.start, length2, Messages.cannotExtractRange)] };
-    }
-    if (start !== end) {
-      if (!isBlockLike(start.parent)) {
-        return { errors: [createFileDiagnostic(sourceFile, span.start, length2, Messages.cannotExtractRange)] };
-      }
-      const statements = [];
-      for (const statement of start.parent.statements) {
-        if (statement === start || statements.length) {
-          const errors2 = checkNode(statement);
-          if (errors2) {
-            return { errors: errors2 };
-          }
-          statements.push(statement);
-        }
-        if (statement === end) {
-          break;
-        }
-      }
-      if (!statements.length) {
-        return { errors: [createFileDiagnostic(sourceFile, span.start, length2, Messages.cannotExtractRange)] };
-      }
-      return { targetRange: { range: statements, facts: rangeFacts, thisNode } };
-    }
-    if (isReturnStatement(start) && !start.expression) {
-      return { errors: [createFileDiagnostic(sourceFile, span.start, length2, Messages.cannotExtractRange)] };
-    }
-    const node = refineNode(start);
-    const errors = checkRootNode(node) || checkNode(node);
-    if (errors) {
-      return { errors };
-    }
-    return { targetRange: { range: getStatementOrExpressionRange(node), facts: rangeFacts, thisNode } };
-    function refineNode(node2) {
-      if (isReturnStatement(node2)) {
-        if (node2.expression) {
-          return node2.expression;
-        }
-      } else if (isVariableStatement(node2) || isVariableDeclarationList(node2)) {
-        const declarations = isVariableStatement(node2) ? node2.declarationList.declarations : node2.declarations;
-        let numInitializers = 0;
-        let lastInitializer;
-        for (const declaration of declarations) {
-          if (declaration.initializer) {
-            numInitializers++;
-            lastInitializer = declaration.initializer;
-          }
-        }
-        if (numInitializers === 1) {
-          return lastInitializer;
-        }
-      } else if (isVariableDeclaration(node2)) {
-        if (node2.initializer) {
-          return node2.initializer;
-        }
-      }
-      return node2;
-    }
-    function checkRootNode(node2) {
-      if (isIdentifier(isExpressionStatement(node2) ? node2.expression : node2)) {
-        return [createDiagnosticForNode(node2, Messages.cannotExtractIdentifier)];
-      }
-      return void 0;
-    }
-    function checkForStaticContext(nodeToCheck, containingClass) {
-      let current = nodeToCheck;
-      while (current !== containingClass) {
-        if (current.kind === 171 /* PropertyDeclaration */) {
-          if (isStatic(current)) {
-            rangeFacts |= 32 /* InStaticRegion */;
-          }
-          break;
-        } else if (current.kind === 168 /* Parameter */) {
-          const ctorOrMethod = getContainingFunction(current);
-          if (ctorOrMethod.kind === 175 /* Constructor */) {
-            rangeFacts |= 32 /* InStaticRegion */;
-          }
-          break;
-        } else if (current.kind === 173 /* MethodDeclaration */) {
-          if (isStatic(current)) {
-            rangeFacts |= 32 /* InStaticRegion */;
-          }
-        }
-        current = current.parent;
-      }
-    }
-    function checkNode(nodeToCheck) {
-      let PermittedJumps;
-      ((PermittedJumps2) => {
-        PermittedJumps2[PermittedJumps2["None"] = 0] = "None";
-        PermittedJumps2[PermittedJumps2["Break"] = 1] = "Break";
-        PermittedJumps2[PermittedJumps2["Continue"] = 2] = "Continue";
-        PermittedJumps2[PermittedJumps2["Return"] = 4] = "Return";
-      })(PermittedJumps || (PermittedJumps = {}));
-      Debug.assert(nodeToCheck.pos <= nodeToCheck.end, "This failure could trigger https://github.com/Microsoft/TypeScript/issues/20809 (1)");
-      Debug.assert(!positionIsSynthesized(nodeToCheck.pos), "This failure could trigger https://github.com/Microsoft/TypeScript/issues/20809 (2)");
-      if (!isStatement(nodeToCheck) && !(isExpressionNode(nodeToCheck) && isExtractableExpression(nodeToCheck)) && !isStringLiteralJsxAttribute(nodeToCheck)) {
-        return [createDiagnosticForNode(nodeToCheck, Messages.statementOrExpressionExpected)];
-      }
-      if (nodeToCheck.flags & 16777216 /* Ambient */) {
-        return [createDiagnosticForNode(nodeToCheck, Messages.cannotExtractAmbientBlock)];
-      }
-      const containingClass = getContainingClass(nodeToCheck);
-      if (containingClass) {
-        checkForStaticContext(nodeToCheck, containingClass);
-      }
-      let errors2;
-      let permittedJumps = 4 /* Return */;
-      let seenLabels;
-      visit(nodeToCheck);
-      if (rangeFacts & 8 /* UsesThis */) {
-        const container = getThisContainer(
-          nodeToCheck,
-          /*includeArrowFunctions*/
-          false,
-          /*includeClassComputedPropertyName*/
-          false
-        );
-        if (container.kind === 261 /* FunctionDeclaration */ || container.kind === 173 /* MethodDeclaration */ && container.parent.kind === 209 /* ObjectLiteralExpression */ || container.kind === 217 /* FunctionExpression */) {
-          rangeFacts |= 16 /* UsesThisInFunction */;
-        }
-      }
-      return errors2;
-      function visit(node2) {
-        if (errors2) {
-          return true;
-        }
-        if (isDeclaration(node2)) {
-          const declaringNode = node2.kind === 259 /* VariableDeclaration */ ? node2.parent.parent : node2;
-          if (hasSyntacticModifier(declaringNode, 1 /* Export */)) {
-            (errors2 || (errors2 = [])).push(createDiagnosticForNode(node2, Messages.cannotExtractExportedEntity));
-            return true;
-          }
-        }
-        switch (node2.kind) {
-          case 271 /* ImportDeclaration */:
-            (errors2 || (errors2 = [])).push(createDiagnosticForNode(node2, Messages.cannotExtractImport));
-            return true;
-          case 276 /* ExportAssignment */:
-            (errors2 || (errors2 = [])).push(createDiagnosticForNode(node2, Messages.cannotExtractExportedEntity));
-            return true;
-          case 108 /* SuperKeyword */:
-            if (node2.parent.kind === 212 /* CallExpression */) {
-              const containingClass2 = getContainingClass(node2);
-              if (containingClass2 === void 0 || containingClass2.pos < span.start || containingClass2.end >= span.start + span.length) {
-                (errors2 || (errors2 = [])).push(createDiagnosticForNode(node2, Messages.cannotExtractSuper));
-                return true;
-              }
-            } else {
-              rangeFacts |= 8 /* UsesThis */;
-              thisNode = node2;
-            }
-            break;
-          case 218 /* ArrowFunction */:
-            forEachChild(node2, function check(n) {
-              if (isThis(n)) {
-                rangeFacts |= 8 /* UsesThis */;
-                thisNode = node2;
-              } else if (isClassLike(n) || isFunctionLike(n) && !isArrowFunction(n)) {
-                return false;
-              } else {
-                forEachChild(n, check);
-              }
-            });
-          case 262 /* ClassDeclaration */:
-          case 261 /* FunctionDeclaration */:
-            if (isSourceFile(node2.parent) && node2.parent.externalModuleIndicator === void 0) {
-              (errors2 || (errors2 = [])).push(createDiagnosticForNode(node2, Messages.functionWillNotBeVisibleInTheNewScope));
-            }
-          case 230 /* ClassExpression */:
-          case 217 /* FunctionExpression */:
-          case 173 /* MethodDeclaration */:
-          case 175 /* Constructor */:
-          case 176 /* GetAccessor */:
-          case 177 /* SetAccessor */:
-            return false;
-        }
-        const savedPermittedJumps = permittedJumps;
-        switch (node2.kind) {
-          case 244 /* IfStatement */:
-            permittedJumps &= ~4 /* Return */;
-            break;
-          case 257 /* TryStatement */:
-            permittedJumps = 0 /* None */;
-            break;
-          case 240 /* Block */:
-            if (node2.parent && node2.parent.kind === 257 /* TryStatement */ && node2.parent.finallyBlock === node2) {
-              permittedJumps = 4 /* Return */;
-            }
-            break;
-          case 296 /* DefaultClause */:
-          case 295 /* CaseClause */:
-            permittedJumps |= 1 /* Break */;
-            break;
-          default:
-            if (isIterationStatement(
-              node2,
-              /*lookInLabeledStatements*/
-              false
-            )) {
-              permittedJumps |= 1 /* Break */ | 2 /* Continue */;
-            }
-            break;
-        }
-        switch (node2.kind) {
-          case 196 /* ThisType */:
-          case 110 /* ThisKeyword */:
-            rangeFacts |= 8 /* UsesThis */;
-            thisNode = node2;
-            break;
-          case 255 /* LabeledStatement */: {
-            const label = node2.label;
-            (seenLabels || (seenLabels = [])).push(label.escapedText);
-            forEachChild(node2, visit);
-            seenLabels.pop();
-            break;
-          }
-          case 251 /* BreakStatement */:
-          case 250 /* ContinueStatement */: {
-            const label = node2.label;
-            if (label) {
-              if (!contains(seenLabels, label.escapedText)) {
-                (errors2 || (errors2 = [])).push(createDiagnosticForNode(node2, Messages.cannotExtractRangeContainingLabeledBreakOrContinueStatementWithTargetOutsideOfTheRange));
-              }
-            } else {
-              if (!(permittedJumps & (node2.kind === 251 /* BreakStatement */ ? 1 /* Break */ : 2 /* Continue */))) {
-                (errors2 || (errors2 = [])).push(createDiagnosticForNode(node2, Messages.cannotExtractRangeContainingConditionalBreakOrContinueStatements));
-              }
-            }
-            break;
-          }
-          case 222 /* AwaitExpression */:
-            rangeFacts |= 4 /* IsAsyncFunction */;
-            break;
-          case 228 /* YieldExpression */:
-            rangeFacts |= 2 /* IsGenerator */;
-            break;
-          case 252 /* ReturnStatement */:
-            if (permittedJumps & 4 /* Return */) {
-              rangeFacts |= 1 /* HasReturn */;
-            } else {
-              (errors2 || (errors2 = [])).push(createDiagnosticForNode(node2, Messages.cannotExtractRangeContainingConditionalReturnStatement));
-            }
-            break;
-          default:
-            forEachChild(node2, visit);
-            break;
-        }
-        permittedJumps = savedPermittedJumps;
-      }
-    }
-  }
-  function getAdjustedSpanFromNodes(startNode2, endNode2, sourceFile) {
-    const start = startNode2.getStart(sourceFile);
-    let end = endNode2.getEnd();
-    if (sourceFile.text.charCodeAt(end) === 59 /* semicolon */) {
-      end++;
-    }
-    return { start, length: end - start };
-  }
-  function getStatementOrExpressionRange(node) {
-    if (isStatement(node)) {
-      return [node];
-    }
-    if (isExpressionNode(node)) {
-      return isExpressionStatement(node.parent) ? [node.parent] : node;
-    }
-    if (isStringLiteralJsxAttribute(node)) {
-      return node;
-    }
-    return void 0;
-  }
-  function isScope(node) {
-    return isArrowFunction(node) ? isFunctionBody(node.body) : isFunctionLikeDeclaration(node) || isSourceFile(node) || isModuleBlock(node) || isClassLike(node);
-  }
-  function collectEnclosingScopes(range) {
-    let current = isReadonlyArray(range.range) ? first(range.range) : range.range;
-    if (range.facts & 8 /* UsesThis */ && !(range.facts & 16 /* UsesThisInFunction */)) {
-      const containingClass = getContainingClass(current);
-      if (containingClass) {
-        const containingFunction = findAncestor(current, isFunctionLikeDeclaration);
-        return containingFunction ? [containingFunction, containingClass] : [containingClass];
-      }
-    }
-    const scopes = [];
-    while (true) {
-      current = current.parent;
-      if (current.kind === 168 /* Parameter */) {
-        current = findAncestor(current, (parent2) => isFunctionLikeDeclaration(parent2)).parent;
-      }
-      if (isScope(current)) {
-        scopes.push(current);
-        if (current.kind === 311 /* SourceFile */) {
-          return scopes;
-        }
-      }
-    }
-  }
-  function getFunctionExtractionAtIndex(targetRange, context, requestedChangesIndex) {
-    const { scopes, readsAndWrites: { target, usagesPerScope, functionErrorsPerScope, exposedVariableDeclarations } } = getPossibleExtractionsWorker(targetRange, context);
-    Debug.assert(!functionErrorsPerScope[requestedChangesIndex].length, "The extraction went missing? How?");
-    context.cancellationToken.throwIfCancellationRequested();
-    return extractFunctionInScope(target, scopes[requestedChangesIndex], usagesPerScope[requestedChangesIndex], exposedVariableDeclarations, targetRange, context);
-  }
-  function getConstantExtractionAtIndex(targetRange, context, requestedChangesIndex) {
-    const { scopes, readsAndWrites: { target, usagesPerScope, constantErrorsPerScope, exposedVariableDeclarations } } = getPossibleExtractionsWorker(targetRange, context);
-    Debug.assert(!constantErrorsPerScope[requestedChangesIndex].length, "The extraction went missing? How?");
-    Debug.assert(exposedVariableDeclarations.length === 0, "Extract constant accepted a range containing a variable declaration?");
-    context.cancellationToken.throwIfCancellationRequested();
-    const expression = isExpression(target) ? target : target.statements[0].expression;
-    return extractConstantInScope(expression, scopes[requestedChangesIndex], usagesPerScope[requestedChangesIndex], targetRange.facts, context);
-  }
-  function getPossibleExtractions(targetRange, context) {
-    const { scopes, readsAndWrites: { functionErrorsPerScope, constantErrorsPerScope } } = getPossibleExtractionsWorker(targetRange, context);
-    const extractions = scopes.map((scope, i) => {
-      const functionDescriptionPart = getDescriptionForFunctionInScope(scope);
-      const constantDescriptionPart = getDescriptionForConstantInScope(scope);
-      const scopeDescription = isFunctionLikeDeclaration(scope) ? getDescriptionForFunctionLikeDeclaration(scope) : isClassLike(scope) ? getDescriptionForClassLikeDeclaration(scope) : getDescriptionForModuleLikeDeclaration(scope);
-      let functionDescription;
-      let constantDescription;
-      if (scopeDescription === 1 /* Global */) {
-        functionDescription = formatStringFromArgs(getLocaleSpecificMessage(Diagnostics.Extract_to_0_in_1_scope), [functionDescriptionPart, "global"]);
-        constantDescription = formatStringFromArgs(getLocaleSpecificMessage(Diagnostics.Extract_to_0_in_1_scope), [constantDescriptionPart, "global"]);
-      } else if (scopeDescription === 0 /* Module */) {
-        functionDescription = formatStringFromArgs(getLocaleSpecificMessage(Diagnostics.Extract_to_0_in_1_scope), [functionDescriptionPart, "module"]);
-        constantDescription = formatStringFromArgs(getLocaleSpecificMessage(Diagnostics.Extract_to_0_in_1_scope), [constantDescriptionPart, "module"]);
-      } else {
-        functionDescription = formatStringFromArgs(getLocaleSpecificMessage(Diagnostics.Extract_to_0_in_1), [functionDescriptionPart, scopeDescription]);
-        constantDescription = formatStringFromArgs(getLocaleSpecificMessage(Diagnostics.Extract_to_0_in_1), [constantDescriptionPart, scopeDescription]);
-      }
-      if (i === 0 && !isClassLike(scope)) {
-        constantDescription = formatStringFromArgs(getLocaleSpecificMessage(Diagnostics.Extract_to_0_in_enclosing_scope), [constantDescriptionPart]);
-      }
-      return {
-        functionExtraction: {
-          description: functionDescription,
-          errors: functionErrorsPerScope[i]
-        },
-        constantExtraction: {
-          description: constantDescription,
-          errors: constantErrorsPerScope[i]
-        }
-      };
-    });
-    return extractions;
-  }
-  function getPossibleExtractionsWorker(targetRange, context) {
-    const { file: sourceFile } = context;
-    const scopes = collectEnclosingScopes(targetRange);
-    const enclosingTextRange = getEnclosingTextRange(targetRange, sourceFile);
-    const readsAndWrites = collectReadsAndWrites(
-      targetRange,
-      scopes,
-      enclosingTextRange,
-      sourceFile,
-      context.program.getTypeChecker(),
-      context.cancellationToken
-    );
-    return { scopes, readsAndWrites };
-  }
-  function getDescriptionForFunctionInScope(scope) {
-    return isFunctionLikeDeclaration(scope) ? "inner function" : isClassLike(scope) ? "method" : "function";
-  }
-  function getDescriptionForConstantInScope(scope) {
-    return isClassLike(scope) ? "readonly field" : "constant";
-  }
-  function getDescriptionForFunctionLikeDeclaration(scope) {
-    switch (scope.kind) {
-      case 175 /* Constructor */:
-        return "constructor";
-      case 217 /* FunctionExpression */:
-      case 261 /* FunctionDeclaration */:
-        return scope.name ? `function '${scope.name.text}'` : ANONYMOUS;
-      case 218 /* ArrowFunction */:
-        return "arrow function";
-      case 173 /* MethodDeclaration */:
-        return `method '${scope.name.getText()}'`;
-      case 176 /* GetAccessor */:
-        return `'get ${scope.name.getText()}'`;
-      case 177 /* SetAccessor */:
-        return `'set ${scope.name.getText()}'`;
-      default:
-        Debug.assertNever(scope, `Unexpected scope kind ${scope.kind}`);
-    }
-  }
-  function getDescriptionForClassLikeDeclaration(scope) {
-    return scope.kind === 262 /* ClassDeclaration */ ? scope.name ? `class '${scope.name.text}'` : "anonymous class declaration" : scope.name ? `class expression '${scope.name.text}'` : "anonymous class expression";
-  }
-  function getDescriptionForModuleLikeDeclaration(scope) {
-    return scope.kind === 267 /* ModuleBlock */ ? `namespace '${scope.parent.name.getText()}'` : scope.externalModuleIndicator ? 0 /* Module */ : 1 /* Global */;
-  }
-  function extractFunctionInScope(node, scope, { usages: usagesInScope, typeParameterUsages, substitutions }, exposedVariableDeclarations, range, context) {
-    const checker = context.program.getTypeChecker();
-    const scriptTarget = getEmitScriptTarget(context.program.getCompilerOptions());
-    const importAdder = ts_codefix_exports.createImportAdder(context.file, context.program, context.preferences, context.host);
-    const file = scope.getSourceFile();
-    const functionNameText = getUniqueName(isClassLike(scope) ? "newMethod" : "newFunction", file);
-    const isJS = isInJSFile(scope);
-    const functionName = factory.createIdentifier(functionNameText);
-    let returnType;
-    const parameters = [];
-    const callArguments = [];
-    let writes;
-    usagesInScope.forEach((usage, name) => {
-      let typeNode;
-      if (!isJS) {
-        let type = checker.getTypeOfSymbolAtLocation(usage.symbol, usage.node);
-        type = checker.getBaseTypeOfLiteralType(type);
-        typeNode = ts_codefix_exports.typeToAutoImportableTypeNode(checker, importAdder, type, scope, scriptTarget, 1 /* NoTruncation */);
-      }
-      const paramDecl = factory.createParameterDeclaration(
-        /*modifiers*/
-        void 0,
-        /*dotDotDotToken*/
-        void 0,
-        /*name*/
-        name,
-        /*questionToken*/
-        void 0,
-        typeNode
-      );
-      parameters.push(paramDecl);
-      if (usage.usage === 2 /* Write */) {
-        (writes || (writes = [])).push(usage);
-      }
-      callArguments.push(factory.createIdentifier(name));
-    });
-    const typeParametersAndDeclarations = arrayFrom(typeParameterUsages.values(), (type) => ({ type, declaration: getFirstDeclarationBeforePosition(type, context.startPosition) }));
-    const sortedTypeParametersAndDeclarations = typeParametersAndDeclarations.sort(compareTypesByDeclarationOrder);
-    const typeParameters = sortedTypeParametersAndDeclarations.length === 0 ? void 0 : mapDefined(sortedTypeParametersAndDeclarations, ({ declaration }) => declaration);
-    const callTypeArguments = typeParameters !== void 0 ? typeParameters.map((decl) => factory.createTypeReferenceNode(
-      decl.name,
-      /*typeArguments*/
-      void 0
-    )) : void 0;
-    if (isExpression(node) && !isJS) {
-      const contextualType = checker.getContextualType(node);
-      returnType = checker.typeToTypeNode(contextualType, scope, 1 /* NoTruncation */);
-    }
-    const { body, returnValueProperty } = transformFunctionBody(node, exposedVariableDeclarations, writes, substitutions, !!(range.facts & 1 /* HasReturn */));
-    suppressLeadingAndTrailingTrivia(body);
-    let newFunction;
-    const callThis = !!(range.facts & 16 /* UsesThisInFunction */);
-    if (isClassLike(scope)) {
-      const modifiers = isJS ? [] : [factory.createModifier(123 /* PrivateKeyword */)];
-      if (range.facts & 32 /* InStaticRegion */) {
-        modifiers.push(factory.createModifier(126 /* StaticKeyword */));
-      }
-      if (range.facts & 4 /* IsAsyncFunction */) {
-        modifiers.push(factory.createModifier(134 /* AsyncKeyword */));
-      }
-      newFunction = factory.createMethodDeclaration(
-        modifiers.length ? modifiers : void 0,
-        range.facts & 2 /* IsGenerator */ ? factory.createToken(42 /* AsteriskToken */) : void 0,
-        functionName,
-        /*questionToken*/
-        void 0,
-        typeParameters,
-        parameters,
-        returnType,
-        body
-      );
-    } else {
-      if (callThis) {
-        parameters.unshift(
-          factory.createParameterDeclaration(
-            /*modifiers*/
-            void 0,
-            /*dotDotDotToken*/
-            void 0,
-            /*name*/
-            "this",
-            /*questionToken*/
-            void 0,
-            checker.typeToTypeNode(
-              checker.getTypeAtLocation(range.thisNode),
-              scope,
-              1 /* NoTruncation */
-            ),
-            /*initializer*/
-            void 0
-          )
-        );
-      }
-      newFunction = factory.createFunctionDeclaration(
-        range.facts & 4 /* IsAsyncFunction */ ? [factory.createToken(134 /* AsyncKeyword */)] : void 0,
-        range.facts & 2 /* IsGenerator */ ? factory.createToken(42 /* AsteriskToken */) : void 0,
-        functionName,
-        typeParameters,
-        parameters,
-        returnType,
-        body
-      );
-    }
-    const changeTracker = ts_textChanges_exports.ChangeTracker.fromContext(context);
-    const minInsertionPos = (isReadonlyArray(range.range) ? last(range.range) : range.range).end;
-    const nodeToInsertBefore = getNodeToInsertFunctionBefore(minInsertionPos, scope);
-    if (nodeToInsertBefore) {
-      changeTracker.insertNodeBefore(
-        context.file,
-        nodeToInsertBefore,
-        newFunction,
-        /*blankLineBetween*/
-        true
-      );
-    } else {
-      changeTracker.insertNodeAtEndOfScope(context.file, scope, newFunction);
-    }
-    importAdder.writeFixes(changeTracker);
-    const newNodes = [];
-    const called = getCalledExpression(scope, range, functionNameText);
-    if (callThis) {
-      callArguments.unshift(factory.createIdentifier("this"));
-    }
-    let call = factory.createCallExpression(
-      callThis ? factory.createPropertyAccessExpression(
-        called,
-        "call"
-      ) : called,
-      callTypeArguments,
-      // Note that no attempt is made to take advantage of type argument inference
-      callArguments
-    );
-    if (range.facts & 2 /* IsGenerator */) {
-      call = factory.createYieldExpression(factory.createToken(42 /* AsteriskToken */), call);
-    }
-    if (range.facts & 4 /* IsAsyncFunction */) {
-      call = factory.createAwaitExpression(call);
-    }
-    if (isInJSXContent(node)) {
-      call = factory.createJsxExpression(
-        /*dotDotDotToken*/
-        void 0,
-        call
-      );
-    }
-    if (exposedVariableDeclarations.length && !writes) {
-      Debug.assert(!returnValueProperty, "Expected no returnValueProperty");
-      Debug.assert(!(range.facts & 1 /* HasReturn */), "Expected RangeFacts.HasReturn flag to be unset");
-      if (exposedVariableDeclarations.length === 1) {
-        const variableDeclaration = exposedVariableDeclarations[0];
-        newNodes.push(factory.createVariableStatement(
-          /*modifiers*/
-          void 0,
-          factory.createVariableDeclarationList(
-            [factory.createVariableDeclaration(
-              getSynthesizedDeepClone(variableDeclaration.name),
-              /*exclamationToken*/
-              void 0,
-              /*type*/
-              getSynthesizedDeepClone(variableDeclaration.type),
-              /*initializer*/
-              call
-            )],
-            variableDeclaration.parent.flags
-          )
-        ));
-      } else {
-        const bindingElements = [];
-        const typeElements = [];
-        let commonNodeFlags = exposedVariableDeclarations[0].parent.flags;
-        let sawExplicitType = false;
-        for (const variableDeclaration of exposedVariableDeclarations) {
-          bindingElements.push(factory.createBindingElement(
-            /*dotDotDotToken*/
-            void 0,
-            /*propertyName*/
-            void 0,
-            /*name*/
-            getSynthesizedDeepClone(variableDeclaration.name)
-          ));
-          const variableType = checker.typeToTypeNode(
-            checker.getBaseTypeOfLiteralType(checker.getTypeAtLocation(variableDeclaration)),
-            scope,
-            1 /* NoTruncation */
-          );
-          typeElements.push(factory.createPropertySignature(
-            /*modifiers*/
-            void 0,
-            /*name*/
-            variableDeclaration.symbol.name,
-            /*questionToken*/
-            void 0,
-            /*type*/
-            variableType
-          ));
-          sawExplicitType = sawExplicitType || variableDeclaration.type !== void 0;
-          commonNodeFlags = commonNodeFlags & variableDeclaration.parent.flags;
-        }
-        const typeLiteral = sawExplicitType ? factory.createTypeLiteralNode(typeElements) : void 0;
-        if (typeLiteral) {
-          setEmitFlags(typeLiteral, 1 /* SingleLine */);
-        }
-        newNodes.push(factory.createVariableStatement(
-          /*modifiers*/
-          void 0,
-          factory.createVariableDeclarationList(
-            [factory.createVariableDeclaration(
-              factory.createObjectBindingPattern(bindingElements),
-              /*exclamationToken*/
-              void 0,
-              /*type*/
-              typeLiteral,
-              /*initializer*/
-              call
-            )],
-            commonNodeFlags
-          )
-        ));
-      }
-    } else if (exposedVariableDeclarations.length || writes) {
-      if (exposedVariableDeclarations.length) {
-        for (const variableDeclaration of exposedVariableDeclarations) {
-          let flags = variableDeclaration.parent.flags;
-          if (flags & 2 /* Const */) {
-            flags = flags & ~2 /* Const */ | 1 /* Let */;
-          }
-          newNodes.push(factory.createVariableStatement(
-            /*modifiers*/
-            void 0,
-            factory.createVariableDeclarationList(
-              [factory.createVariableDeclaration(
-                variableDeclaration.symbol.name,
-                /*exclamationToken*/
-                void 0,
-                getTypeDeepCloneUnionUndefined(variableDeclaration.type)
-              )],
-              flags
-            )
-          ));
-        }
-      }
-      if (returnValueProperty) {
-        newNodes.push(factory.createVariableStatement(
-          /*modifiers*/
-          void 0,
-          factory.createVariableDeclarationList(
-            [factory.createVariableDeclaration(
-              returnValueProperty,
-              /*exclamationToken*/
-              void 0,
-              getTypeDeepCloneUnionUndefined(returnType)
-            )],
-            1 /* Let */
-          )
-        ));
-      }
-      const assignments = getPropertyAssignmentsForWritesAndVariableDeclarations(exposedVariableDeclarations, writes);
-      if (returnValueProperty) {
-        assignments.unshift(factory.createShorthandPropertyAssignment(returnValueProperty));
-      }
-      if (assignments.length === 1) {
-        Debug.assert(!returnValueProperty, "Shouldn't have returnValueProperty here");
-        newNodes.push(factory.createExpressionStatement(factory.createAssignment(assignments[0].name, call)));
-        if (range.facts & 1 /* HasReturn */) {
-          newNodes.push(factory.createReturnStatement());
-        }
-      } else {
-        newNodes.push(factory.createExpressionStatement(factory.createAssignment(factory.createObjectLiteralExpression(assignments), call)));
-        if (returnValueProperty) {
-          newNodes.push(factory.createReturnStatement(factory.createIdentifier(returnValueProperty)));
-        }
-      }
-    } else {
-      if (range.facts & 1 /* HasReturn */) {
-        newNodes.push(factory.createReturnStatement(call));
-      } else if (isReadonlyArray(range.range)) {
-        newNodes.push(factory.createExpressionStatement(call));
-      } else {
-        newNodes.push(call);
-      }
-    }
-    if (isReadonlyArray(range.range)) {
-      changeTracker.replaceNodeRangeWithNodes(context.file, first(range.range), last(range.range), newNodes);
-    } else {
-      changeTracker.replaceNodeWithNodes(context.file, range.range, newNodes);
-    }
-    const edits = changeTracker.getChanges();
-    const renameRange = isReadonlyArray(range.range) ? first(range.range) : range.range;
-    const renameFilename = renameRange.getSourceFile().fileName;
-    const renameLocation = getRenameLocation(
-      edits,
-      renameFilename,
-      functionNameText,
-      /*preferLastLocation*/
-      false
-    );
-    return { renameFilename, renameLocation, edits };
-    function getTypeDeepCloneUnionUndefined(typeNode) {
-      if (typeNode === void 0) {
-        return void 0;
-      }
-      const clone2 = getSynthesizedDeepClone(typeNode);
-      let withoutParens = clone2;
-      while (isParenthesizedTypeNode(withoutParens)) {
-        withoutParens = withoutParens.type;
-      }
-      return isUnionTypeNode(withoutParens) && find(withoutParens.types, (t) => t.kind === 157 /* UndefinedKeyword */) ? clone2 : factory.createUnionTypeNode([clone2, factory.createKeywordTypeNode(157 /* UndefinedKeyword */)]);
-    }
-  }
-  function extractConstantInScope(node, scope, { substitutions }, rangeFacts, context) {
-    const checker = context.program.getTypeChecker();
-    const file = scope.getSourceFile();
-    const localNameText = isPropertyAccessExpression(node) && !isClassLike(scope) && !checker.resolveName(
-      node.name.text,
-      node,
-      111551 /* Value */,
-      /*excludeGlobals*/
-      false
-    ) && !isPrivateIdentifier(node.name) && !identifierToKeywordKind(node.name) ? node.name.text : getUniqueName(isClassLike(scope) ? "newProperty" : "newLocal", file);
-    const isJS = isInJSFile(scope);
-    let variableType = isJS || !checker.isContextSensitive(node) ? void 0 : checker.typeToTypeNode(checker.getContextualType(node), scope, 1 /* NoTruncation */);
-    let initializer = transformConstantInitializer(skipParentheses(node), substitutions);
-    ({ variableType, initializer } = transformFunctionInitializerAndType(variableType, initializer));
-    suppressLeadingAndTrailingTrivia(initializer);
-    const changeTracker = ts_textChanges_exports.ChangeTracker.fromContext(context);
-    if (isClassLike(scope)) {
-      Debug.assert(!isJS, "Cannot extract to a JS class");
-      const modifiers = [];
-      modifiers.push(factory.createModifier(123 /* PrivateKeyword */));
-      if (rangeFacts & 32 /* InStaticRegion */) {
-        modifiers.push(factory.createModifier(126 /* StaticKeyword */));
-      }
-      modifiers.push(factory.createModifier(148 /* ReadonlyKeyword */));
-      const newVariable = factory.createPropertyDeclaration(
-        modifiers,
-        localNameText,
-        /*questionOrExclamationToken*/
-        void 0,
-        variableType,
-        initializer
-      );
-      let localReference = factory.createPropertyAccessExpression(
-        rangeFacts & 32 /* InStaticRegion */ ? factory.createIdentifier(scope.name.getText()) : factory.createThis(),
-        factory.createIdentifier(localNameText)
-      );
-      if (isInJSXContent(node)) {
-        localReference = factory.createJsxExpression(
-          /*dotDotDotToken*/
-          void 0,
-          localReference
-        );
-      }
-      const maxInsertionPos = node.pos;
-      const nodeToInsertBefore = getNodeToInsertPropertyBefore(maxInsertionPos, scope);
-      changeTracker.insertNodeBefore(
-        context.file,
-        nodeToInsertBefore,
-        newVariable,
-        /*blankLineBetween*/
-        true
-      );
-      changeTracker.replaceNode(context.file, node, localReference);
-    } else {
-      const newVariableDeclaration = factory.createVariableDeclaration(
-        localNameText,
-        /*exclamationToken*/
-        void 0,
-        variableType,
-        initializer
-      );
-      const oldVariableDeclaration = getContainingVariableDeclarationIfInList(node, scope);
-      if (oldVariableDeclaration) {
-        changeTracker.insertNodeBefore(context.file, oldVariableDeclaration, newVariableDeclaration);
-        const localReference = factory.createIdentifier(localNameText);
-        changeTracker.replaceNode(context.file, node, localReference);
-      } else if (node.parent.kind === 243 /* ExpressionStatement */ && scope === findAncestor(node, isScope)) {
-        const newVariableStatement = factory.createVariableStatement(
-          /*modifiers*/
-          void 0,
-          factory.createVariableDeclarationList([newVariableDeclaration], 2 /* Const */)
-        );
-        changeTracker.replaceNode(context.file, node.parent, newVariableStatement);
-      } else {
-        const newVariableStatement = factory.createVariableStatement(
-          /*modifiers*/
-          void 0,
-          factory.createVariableDeclarationList([newVariableDeclaration], 2 /* Const */)
-        );
-        const nodeToInsertBefore = getNodeToInsertConstantBefore(node, scope);
-        if (nodeToInsertBefore.pos === 0) {
-          changeTracker.insertNodeAtTopOfFile(
-            context.file,
-            newVariableStatement,
-            /*blankLineBetween*/
-            false
-          );
-        } else {
-          changeTracker.insertNodeBefore(
-            context.file,
-            nodeToInsertBefore,
-            newVariableStatement,
-            /*blankLineBetween*/
-            false
-          );
-        }
-        if (node.parent.kind === 243 /* ExpressionStatement */) {
-          changeTracker.delete(context.file, node.parent);
-        } else {
-          let localReference = factory.createIdentifier(localNameText);
-          if (isInJSXContent(node)) {
-            localReference = factory.createJsxExpression(
-              /*dotDotDotToken*/
-              void 0,
-              localReference
-            );
-          }
-          changeTracker.replaceNode(context.file, node, localReference);
-        }
-      }
-    }
-    const edits = changeTracker.getChanges();
-    const renameFilename = node.getSourceFile().fileName;
-    const renameLocation = getRenameLocation(
-      edits,
-      renameFilename,
-      localNameText,
-      /*preferLastLocation*/
-      true
-    );
-    return { renameFilename, renameLocation, edits };
-    function transformFunctionInitializerAndType(variableType2, initializer2) {
-      if (variableType2 === void 0)
-        return { variableType: variableType2, initializer: initializer2 };
-      if (!isFunctionExpression(initializer2) && !isArrowFunction(initializer2) || !!initializer2.typeParameters)
-        return { variableType: variableType2, initializer: initializer2 };
-      const functionType = checker.getTypeAtLocation(node);
-      const functionSignature = singleOrUndefined(checker.getSignaturesOfType(functionType, 0 /* Call */));
-      if (!functionSignature)
-        return { variableType: variableType2, initializer: initializer2 };
-      if (!!functionSignature.getTypeParameters())
-        return { variableType: variableType2, initializer: initializer2 };
-      const parameters = [];
-      let hasAny = false;
-      for (const p of initializer2.parameters) {
-        if (p.type) {
-          parameters.push(p);
-        } else {
-          const paramType = checker.getTypeAtLocation(p);
-          if (paramType === checker.getAnyType())
-            hasAny = true;
-          parameters.push(factory.updateParameterDeclaration(
-            p,
-            p.modifiers,
-            p.dotDotDotToken,
-            p.name,
-            p.questionToken,
-            p.type || checker.typeToTypeNode(paramType, scope, 1 /* NoTruncation */),
-            p.initializer
-          ));
-        }
-      }
-      if (hasAny)
-        return { variableType: variableType2, initializer: initializer2 };
-      variableType2 = void 0;
-      if (isArrowFunction(initializer2)) {
-        initializer2 = factory.updateArrowFunction(
-          initializer2,
-          canHaveModifiers(node) ? getModifiers(node) : void 0,
-          initializer2.typeParameters,
-          parameters,
-          initializer2.type || checker.typeToTypeNode(functionSignature.getReturnType(), scope, 1 /* NoTruncation */),
-          initializer2.equalsGreaterThanToken,
-          initializer2.body
-        );
-      } else {
-        if (functionSignature && !!functionSignature.thisParameter) {
-          const firstParameter = firstOrUndefined(parameters);
-          if (!firstParameter || isIdentifier(firstParameter.name) && firstParameter.name.escapedText !== "this") {
-            const thisType = checker.getTypeOfSymbolAtLocation(functionSignature.thisParameter, node);
-            parameters.splice(0, 0, factory.createParameterDeclaration(
-              /*modifiers*/
-              void 0,
-              /*dotDotDotToken*/
-              void 0,
-              "this",
-              /*questionToken*/
-              void 0,
-              checker.typeToTypeNode(thisType, scope, 1 /* NoTruncation */)
-            ));
-          }
-        }
-        initializer2 = factory.updateFunctionExpression(
-          initializer2,
-          canHaveModifiers(node) ? getModifiers(node) : void 0,
-          initializer2.asteriskToken,
-          initializer2.name,
-          initializer2.typeParameters,
-          parameters,
-          initializer2.type || checker.typeToTypeNode(functionSignature.getReturnType(), scope, 1 /* NoTruncation */),
-          initializer2.body
-        );
-      }
-      return { variableType: variableType2, initializer: initializer2 };
-    }
-  }
-  function getContainingVariableDeclarationIfInList(node, scope) {
-    let prevNode;
-    while (node !== void 0 && node !== scope) {
-      if (isVariableDeclaration(node) && node.initializer === prevNode && isVariableDeclarationList(node.parent) && node.parent.declarations.length > 1) {
-        return node;
-      }
-      prevNode = node;
-      node = node.parent;
-    }
-  }
-  function getFirstDeclarationBeforePosition(type, position) {
-    let firstDeclaration;
-    const symbol = type.symbol;
-    if (symbol && symbol.declarations) {
-      for (const declaration of symbol.declarations) {
-        if ((firstDeclaration === void 0 || declaration.pos < firstDeclaration.pos) && declaration.pos < position) {
-          firstDeclaration = declaration;
-        }
-      }
-    }
-    return firstDeclaration;
-  }
-  function compareTypesByDeclarationOrder({ type: type1, declaration: declaration1 }, { type: type2, declaration: declaration2 }) {
-    return compareProperties(declaration1, declaration2, "pos", compareValues) || compareStringsCaseSensitive(
-      type1.symbol ? type1.symbol.getName() : "",
-      type2.symbol ? type2.symbol.getName() : ""
-    ) || compareValues(type1.id, type2.id);
-  }
-  function getCalledExpression(scope, range, functionNameText) {
-    const functionReference = factory.createIdentifier(functionNameText);
-    if (isClassLike(scope)) {
-      const lhs = range.facts & 32 /* InStaticRegion */ ? factory.createIdentifier(scope.name.text) : factory.createThis();
-      return factory.createPropertyAccessExpression(lhs, functionReference);
-    } else {
-      return functionReference;
-    }
-  }
-  function transformFunctionBody(body, exposedVariableDeclarations, writes, substitutions, hasReturn2) {
-    const hasWritesOrVariableDeclarations = writes !== void 0 || exposedVariableDeclarations.length > 0;
-    if (isBlock(body) && !hasWritesOrVariableDeclarations && substitutions.size === 0) {
-      return { body: factory.createBlock(
-        body.statements,
-        /*multiLine*/
-        true
-      ), returnValueProperty: void 0 };
-    }
-    let returnValueProperty;
-    let ignoreReturns = false;
-    const statements = factory.createNodeArray(isBlock(body) ? body.statements.slice(0) : [isStatement(body) ? body : factory.createReturnStatement(skipParentheses(body))]);
-    if (hasWritesOrVariableDeclarations || substitutions.size) {
-      const rewrittenStatements = visitNodes2(statements, visitor, isStatement).slice();
-      if (hasWritesOrVariableDeclarations && !hasReturn2 && isStatement(body)) {
-        const assignments = getPropertyAssignmentsForWritesAndVariableDeclarations(exposedVariableDeclarations, writes);
-        if (assignments.length === 1) {
-          rewrittenStatements.push(factory.createReturnStatement(assignments[0].name));
-        } else {
-          rewrittenStatements.push(factory.createReturnStatement(factory.createObjectLiteralExpression(assignments)));
-        }
-      }
-      return { body: factory.createBlock(
-        rewrittenStatements,
-        /*multiLine*/
-        true
-      ), returnValueProperty };
-    } else {
-      return { body: factory.createBlock(
-        statements,
-        /*multiLine*/
-        true
-      ), returnValueProperty: void 0 };
-    }
-    function visitor(node) {
-      if (!ignoreReturns && isReturnStatement(node) && hasWritesOrVariableDeclarations) {
-        const assignments = getPropertyAssignmentsForWritesAndVariableDeclarations(exposedVariableDeclarations, writes);
-        if (node.expression) {
-          if (!returnValueProperty) {
-            returnValueProperty = "__return";
-          }
-          assignments.unshift(factory.createPropertyAssignment(returnValueProperty, visitNode(node.expression, visitor, isExpression)));
-        }
-        if (assignments.length === 1) {
-          return factory.createReturnStatement(assignments[0].name);
-        } else {
-          return factory.createReturnStatement(factory.createObjectLiteralExpression(assignments));
-        }
-      } else {
-        const oldIgnoreReturns = ignoreReturns;
-        ignoreReturns = ignoreReturns || isFunctionLikeDeclaration(node) || isClassLike(node);
-        const substitution = substitutions.get(getNodeId(node).toString());
-        const result = substitution ? getSynthesizedDeepClone(substitution) : visitEachChild(node, visitor, nullTransformationContext);
-        ignoreReturns = oldIgnoreReturns;
-        return result;
-      }
-    }
-  }
-  function transformConstantInitializer(initializer, substitutions) {
-    return substitutions.size ? visitor(initializer) : initializer;
-    function visitor(node) {
-      const substitution = substitutions.get(getNodeId(node).toString());
-      return substitution ? getSynthesizedDeepClone(substitution) : visitEachChild(node, visitor, nullTransformationContext);
-    }
-  }
-  function getStatementsOrClassElements(scope) {
-    if (isFunctionLikeDeclaration(scope)) {
-      const body = scope.body;
-      if (isBlock(body)) {
-        return body.statements;
-      }
-    } else if (isModuleBlock(scope) || isSourceFile(scope)) {
-      return scope.statements;
-    } else if (isClassLike(scope)) {
-      return scope.members;
-    } else {
-      assertType(scope);
-    }
-    return emptyArray;
-  }
-  function getNodeToInsertFunctionBefore(minPos, scope) {
-    return find(getStatementsOrClassElements(scope), (child) => child.pos >= minPos && isFunctionLikeDeclaration(child) && !isConstructorDeclaration(child));
-  }
-  function getNodeToInsertPropertyBefore(maxPos, scope) {
-    const members = scope.members;
-    Debug.assert(members.length > 0, "Found no members");
-    let prevMember;
-    let allProperties = true;
-    for (const member of members) {
-      if (member.pos > maxPos) {
-        return prevMember || members[0];
-      }
-      if (allProperties && !isPropertyDeclaration(member)) {
-        if (prevMember !== void 0) {
-          return member;
-        }
-        allProperties = false;
-      }
-      prevMember = member;
-    }
-    if (prevMember === void 0)
-      return Debug.fail();
-    return prevMember;
-  }
-  function getNodeToInsertConstantBefore(node, scope) {
-    Debug.assert(!isClassLike(scope));
-    let prevScope;
-    for (let curr = node; curr !== scope; curr = curr.parent) {
-      if (isScope(curr)) {
-        prevScope = curr;
-      }
-    }
-    for (let curr = (prevScope || node).parent; ; curr = curr.parent) {
-      if (isBlockLike(curr)) {
-        let prevStatement;
-        for (const statement of curr.statements) {
-          if (statement.pos > node.pos) {
-            break;
-          }
-          prevStatement = statement;
-        }
-        if (!prevStatement && isCaseClause(curr)) {
-          Debug.assert(isSwitchStatement(curr.parent.parent), "Grandparent isn't a switch statement");
-          return curr.parent.parent;
-        }
-        return Debug.checkDefined(prevStatement, "prevStatement failed to get set");
-      }
-      Debug.assert(curr !== scope, "Didn't encounter a block-like before encountering scope");
-    }
-  }
-  function getPropertyAssignmentsForWritesAndVariableDeclarations(exposedVariableDeclarations, writes) {
-    const variableAssignments = map(exposedVariableDeclarations, (v) => factory.createShorthandPropertyAssignment(v.symbol.name));
-    const writeAssignments = map(writes, (w) => factory.createShorthandPropertyAssignment(w.symbol.name));
-    return variableAssignments === void 0 ? writeAssignments : writeAssignments === void 0 ? variableAssignments : variableAssignments.concat(writeAssignments);
-  }
-  function isReadonlyArray(v) {
-    return isArray(v);
-  }
-  function getEnclosingTextRange(targetRange, sourceFile) {
-    return isReadonlyArray(targetRange.range) ? { pos: first(targetRange.range).getStart(sourceFile), end: last(targetRange.range).getEnd() } : targetRange.range;
-  }
-  function collectReadsAndWrites(targetRange, scopes, enclosingTextRange, sourceFile, checker, cancellationToken) {
-    const allTypeParameterUsages = /* @__PURE__ */ new Map();
-    const usagesPerScope = [];
-    const substitutionsPerScope = [];
-    const functionErrorsPerScope = [];
-    const constantErrorsPerScope = [];
-    const visibleDeclarationsInExtractedRange = [];
-    const exposedVariableSymbolSet = /* @__PURE__ */ new Map();
-    const exposedVariableDeclarations = [];
-    let firstExposedNonVariableDeclaration;
-    const expression = !isReadonlyArray(targetRange.range) ? targetRange.range : targetRange.range.length === 1 && isExpressionStatement(targetRange.range[0]) ? targetRange.range[0].expression : void 0;
-    let expressionDiagnostic;
-    if (expression === void 0) {
-      const statements = targetRange.range;
-      const start = first(statements).getStart();
-      const end = last(statements).end;
-      expressionDiagnostic = createFileDiagnostic(sourceFile, start, end - start, Messages.expressionExpected);
-    } else if (checker.getTypeAtLocation(expression).flags & (16384 /* Void */ | 131072 /* Never */)) {
-      expressionDiagnostic = createDiagnosticForNode(expression, Messages.uselessConstantType);
-    }
-    for (const scope of scopes) {
-      usagesPerScope.push({ usages: /* @__PURE__ */ new Map(), typeParameterUsages: /* @__PURE__ */ new Map(), substitutions: /* @__PURE__ */ new Map() });
-      substitutionsPerScope.push(/* @__PURE__ */ new Map());
-      functionErrorsPerScope.push([]);
-      const constantErrors = [];
-      if (expressionDiagnostic) {
-        constantErrors.push(expressionDiagnostic);
-      }
-      if (isClassLike(scope) && isInJSFile(scope)) {
-        constantErrors.push(createDiagnosticForNode(scope, Messages.cannotExtractToJSClass));
-      }
-      if (isArrowFunction(scope) && !isBlock(scope.body)) {
-        constantErrors.push(createDiagnosticForNode(scope, Messages.cannotExtractToExpressionArrowFunction));
-      }
-      constantErrorsPerScope.push(constantErrors);
-    }
-    const seenUsages = /* @__PURE__ */ new Map();
-    const target = isReadonlyArray(targetRange.range) ? factory.createBlock(targetRange.range) : targetRange.range;
-    const unmodifiedNode = isReadonlyArray(targetRange.range) ? first(targetRange.range) : targetRange.range;
-    const inGenericContext = isInGenericContext(unmodifiedNode);
-    collectUsages(target);
-    if (inGenericContext && !isReadonlyArray(targetRange.range) && !isJsxAttribute(targetRange.range)) {
-      const contextualType = checker.getContextualType(targetRange.range);
-      recordTypeParameterUsages(contextualType);
-    }
-    if (allTypeParameterUsages.size > 0) {
-      const seenTypeParameterUsages = /* @__PURE__ */ new Map();
-      let i = 0;
-      for (let curr = unmodifiedNode; curr !== void 0 && i < scopes.length; curr = curr.parent) {
-        if (curr === scopes[i]) {
-          seenTypeParameterUsages.forEach((typeParameter, id) => {
-            usagesPerScope[i].typeParameterUsages.set(id, typeParameter);
-          });
-          i++;
-        }
-        if (isDeclarationWithTypeParameters(curr)) {
-          for (const typeParameterDecl of getEffectiveTypeParameterDeclarations(curr)) {
-            const typeParameter = checker.getTypeAtLocation(typeParameterDecl);
-            if (allTypeParameterUsages.has(typeParameter.id.toString())) {
-              seenTypeParameterUsages.set(typeParameter.id.toString(), typeParameter);
-            }
-          }
-        }
-      }
-      Debug.assert(i === scopes.length, "Should have iterated all scopes");
-    }
-    if (visibleDeclarationsInExtractedRange.length) {
-      const containingLexicalScopeOfExtraction = isBlockScope(scopes[0], scopes[0].parent) ? scopes[0] : getEnclosingBlockScopeContainer(scopes[0]);
-      forEachChild(containingLexicalScopeOfExtraction, checkForUsedDeclarations);
-    }
-    for (let i = 0; i < scopes.length; i++) {
-      const scopeUsages = usagesPerScope[i];
-      if (i > 0 && (scopeUsages.usages.size > 0 || scopeUsages.typeParameterUsages.size > 0)) {
-        const errorNode = isReadonlyArray(targetRange.range) ? targetRange.range[0] : targetRange.range;
-        constantErrorsPerScope[i].push(createDiagnosticForNode(errorNode, Messages.cannotAccessVariablesFromNestedScopes));
-      }
-      if (targetRange.facts & 16 /* UsesThisInFunction */ && isClassLike(scopes[i])) {
-        functionErrorsPerScope[i].push(createDiagnosticForNode(targetRange.thisNode, Messages.cannotExtractFunctionsContainingThisToMethod));
-      }
-      let hasWrite = false;
-      let readonlyClassPropertyWrite;
-      usagesPerScope[i].usages.forEach((value) => {
-        if (value.usage === 2 /* Write */) {
-          hasWrite = true;
-          if (value.symbol.flags & 106500 /* ClassMember */ && value.symbol.valueDeclaration && hasEffectiveModifier(value.symbol.valueDeclaration, 64 /* Readonly */)) {
-            readonlyClassPropertyWrite = value.symbol.valueDeclaration;
-          }
-        }
-      });
-      Debug.assert(isReadonlyArray(targetRange.range) || exposedVariableDeclarations.length === 0, "No variable declarations expected if something was extracted");
-      if (hasWrite && !isReadonlyArray(targetRange.range)) {
-        const diag2 = createDiagnosticForNode(targetRange.range, Messages.cannotWriteInExpression);
-        functionErrorsPerScope[i].push(diag2);
-        constantErrorsPerScope[i].push(diag2);
-      } else if (readonlyClassPropertyWrite && i > 0) {
-        const diag2 = createDiagnosticForNode(readonlyClassPropertyWrite, Messages.cannotExtractReadonlyPropertyInitializerOutsideConstructor);
-        functionErrorsPerScope[i].push(diag2);
-        constantErrorsPerScope[i].push(diag2);
-      } else if (firstExposedNonVariableDeclaration) {
-        const diag2 = createDiagnosticForNode(firstExposedNonVariableDeclaration, Messages.cannotExtractExportedEntity);
-        functionErrorsPerScope[i].push(diag2);
-        constantErrorsPerScope[i].push(diag2);
-      }
-    }
-    return { target, usagesPerScope, functionErrorsPerScope, constantErrorsPerScope, exposedVariableDeclarations };
-    function isInGenericContext(node) {
-      return !!findAncestor(node, (n) => isDeclarationWithTypeParameters(n) && getEffectiveTypeParameterDeclarations(n).length !== 0);
-    }
-    function recordTypeParameterUsages(type) {
-      const symbolWalker = checker.getSymbolWalker(() => (cancellationToken.throwIfCancellationRequested(), true));
-      const { visitedTypes } = symbolWalker.walkType(type);
-      for (const visitedType of visitedTypes) {
-        if (visitedType.isTypeParameter()) {
-          allTypeParameterUsages.set(visitedType.id.toString(), visitedType);
-        }
-      }
-    }
-    function collectUsages(node, valueUsage = 1 /* Read */) {
-      if (inGenericContext) {
-        const type = checker.getTypeAtLocation(node);
-        recordTypeParameterUsages(type);
-      }
-      if (isDeclaration(node) && node.symbol) {
-        visibleDeclarationsInExtractedRange.push(node);
-      }
-      if (isAssignmentExpression(node)) {
-        collectUsages(node.left, 2 /* Write */);
-        collectUsages(node.right);
-      } else if (isUnaryExpressionWithWrite(node)) {
-        collectUsages(node.operand, 2 /* Write */);
-      } else if (isPropertyAccessExpression(node) || isElementAccessExpression(node)) {
-        forEachChild(node, collectUsages);
-      } else if (isIdentifier(node)) {
-        if (!node.parent) {
-          return;
-        }
-        if (isQualifiedName(node.parent) && node !== node.parent.left) {
-          return;
-        }
-        if (isPropertyAccessExpression(node.parent) && node !== node.parent.expression) {
-          return;
-        }
-        recordUsage(
-          node,
-          valueUsage,
-          /*isTypeNode*/
-          isPartOfTypeNode(node)
-        );
-      } else {
-        forEachChild(node, collectUsages);
-      }
-    }
-    function recordUsage(n, usage, isTypeNode2) {
-      const symbolId = recordUsagebySymbol(n, usage, isTypeNode2);
-      if (symbolId) {
-        for (let i = 0; i < scopes.length; i++) {
-          const substitution = substitutionsPerScope[i].get(symbolId);
-          if (substitution) {
-            usagesPerScope[i].substitutions.set(getNodeId(n).toString(), substitution);
-          }
-        }
-      }
-    }
-    function recordUsagebySymbol(identifier, usage, isTypeName) {
-      const symbol = getSymbolReferencedByIdentifier(identifier);
-      if (!symbol) {
-        return void 0;
-      }
-      const symbolId = getSymbolId(symbol).toString();
-      const lastUsage = seenUsages.get(symbolId);
-      if (lastUsage && lastUsage >= usage) {
-        return symbolId;
-      }
-      seenUsages.set(symbolId, usage);
-      if (lastUsage) {
-        for (const perScope of usagesPerScope) {
-          const prevEntry = perScope.usages.get(identifier.text);
-          if (prevEntry) {
-            perScope.usages.set(identifier.text, { usage, symbol, node: identifier });
-          }
-        }
-        return symbolId;
-      }
-      const decls = symbol.getDeclarations();
-      const declInFile = decls && find(decls, (d) => d.getSourceFile() === sourceFile);
-      if (!declInFile) {
-        return void 0;
-      }
-      if (rangeContainsStartEnd(enclosingTextRange, declInFile.getStart(), declInFile.end)) {
-        return void 0;
-      }
-      if (targetRange.facts & 2 /* IsGenerator */ && usage === 2 /* Write */) {
-        const diag2 = createDiagnosticForNode(identifier, Messages.cannotExtractRangeThatContainsWritesToReferencesLocatedOutsideOfTheTargetRangeInGenerators);
-        for (const errors of functionErrorsPerScope) {
-          errors.push(diag2);
-        }
-        for (const errors of constantErrorsPerScope) {
-          errors.push(diag2);
-        }
-      }
-      for (let i = 0; i < scopes.length; i++) {
-        const scope = scopes[i];
-        const resolvedSymbol = checker.resolveName(
-          symbol.name,
-          scope,
-          symbol.flags,
-          /*excludeGlobals*/
-          false
-        );
-        if (resolvedSymbol === symbol) {
-          continue;
-        }
-        if (!substitutionsPerScope[i].has(symbolId)) {
-          const substitution = tryReplaceWithQualifiedNameOrPropertyAccess(symbol.exportSymbol || symbol, scope, isTypeName);
-          if (substitution) {
-            substitutionsPerScope[i].set(symbolId, substitution);
-          } else if (isTypeName) {
-            if (!(symbol.flags & 262144 /* TypeParameter */)) {
-              const diag2 = createDiagnosticForNode(identifier, Messages.typeWillNotBeVisibleInTheNewScope);
-              functionErrorsPerScope[i].push(diag2);
-              constantErrorsPerScope[i].push(diag2);
-            }
-          } else {
-            usagesPerScope[i].usages.set(identifier.text, { usage, symbol, node: identifier });
-          }
-        }
-      }
-      return symbolId;
-    }
-    function checkForUsedDeclarations(node) {
-      if (node === targetRange.range || isReadonlyArray(targetRange.range) && targetRange.range.indexOf(node) >= 0) {
-        return;
-      }
-      const sym = isIdentifier(node) ? getSymbolReferencedByIdentifier(node) : checker.getSymbolAtLocation(node);
-      if (sym) {
-        const decl = find(visibleDeclarationsInExtractedRange, (d) => d.symbol === sym);
-        if (decl) {
-          if (isVariableDeclaration(decl)) {
-            const idString = decl.symbol.id.toString();
-            if (!exposedVariableSymbolSet.has(idString)) {
-              exposedVariableDeclarations.push(decl);
-              exposedVariableSymbolSet.set(idString, true);
-            }
-          } else {
-            firstExposedNonVariableDeclaration = firstExposedNonVariableDeclaration || decl;
-          }
-        }
-      }
-      forEachChild(node, checkForUsedDeclarations);
-    }
-    function getSymbolReferencedByIdentifier(identifier) {
-      return identifier.parent && isShorthandPropertyAssignment(identifier.parent) && identifier.parent.name === identifier ? checker.getShorthandAssignmentValueSymbol(identifier.parent) : checker.getSymbolAtLocation(identifier);
-    }
-    function tryReplaceWithQualifiedNameOrPropertyAccess(symbol, scopeDecl, isTypeNode2) {
-      if (!symbol) {
-        return void 0;
-      }
-      const decls = symbol.getDeclarations();
-      if (decls && decls.some((d) => d.parent === scopeDecl)) {
-        return factory.createIdentifier(symbol.name);
-      }
-      const prefix = tryReplaceWithQualifiedNameOrPropertyAccess(symbol.parent, scopeDecl, isTypeNode2);
-      if (prefix === void 0) {
-        return void 0;
-      }
-      return isTypeNode2 ? factory.createQualifiedName(prefix, factory.createIdentifier(symbol.name)) : factory.createPropertyAccessExpression(prefix, symbol.name);
-    }
-  }
-  function getExtractableParent(node) {
-    return findAncestor(node, (node2) => node2.parent && isExtractableExpression(node2) && !isBinaryExpression(node2.parent));
-  }
-  function isExtractableExpression(node) {
-    const { parent: parent2 } = node;
-    switch (parent2.kind) {
-      case 305 /* EnumMember */:
-        return false;
-    }
-    switch (node.kind) {
-      case 11 /* StringLiteral */:
-        return parent2.kind !== 271 /* ImportDeclaration */ && parent2.kind !== 275 /* ImportSpecifier */;
-      case 229 /* SpreadElement */:
-      case 205 /* ObjectBindingPattern */:
-      case 207 /* BindingElement */:
-        return false;
-      case 80 /* Identifier */:
-        return parent2.kind !== 207 /* BindingElement */ && parent2.kind !== 275 /* ImportSpecifier */ && parent2.kind !== 280 /* ExportSpecifier */;
-    }
-    return true;
-  }
-  function isBlockLike(node) {
-    switch (node.kind) {
-      case 240 /* Block */:
-      case 311 /* SourceFile */:
-      case 267 /* ModuleBlock */:
-      case 295 /* CaseClause */:
-        return true;
-      default:
-        return false;
-    }
-  }
-  function isInJSXContent(node) {
-    return isStringLiteralJsxAttribute(node) || (isJsxElement(node) || isJsxSelfClosingElement(node) || isJsxFragment(node)) && (isJsxElement(node.parent) || isJsxFragment(node.parent));
-  }
-  function isStringLiteralJsxAttribute(node) {
-    return isStringLiteral(node) && node.parent && isJsxAttribute(node.parent);
-  }
-  var refactorName11, extractConstantAction, extractFunctionAction, Messages, RangeFacts;
-  var init_extractSymbol = __esm({
-    "src/services/refactors/extractSymbol.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_refactor();
-      refactorName11 = "Extract Symbol";
-      extractConstantAction = {
-        name: "Extract Constant",
-        description: getLocaleSpecificMessage(Diagnostics.Extract_constant),
-        kind: "refactor.extract.constant"
-      };
-      extractFunctionAction = {
-        name: "Extract Function",
-        description: getLocaleSpecificMessage(Diagnostics.Extract_function),
-        kind: "refactor.extract.function"
-      };
-      registerRefactor(refactorName11, {
-        kinds: [
-          extractConstantAction.kind,
-          extractFunctionAction.kind
-        ],
-        getEditsForAction: getRefactorEditsToExtractSymbol,
-        getAvailableActions: getRefactorActionsToExtractSymbol
-      });
-      ((Messages2) => {
-        function createMessage(message) {
-          return { message, code: 0, category: 3 /* Message */, key: message };
-        }
-        Messages2.cannotExtractRange = createMessage("Cannot extract range.");
-        Messages2.cannotExtractImport = createMessage("Cannot extract import statement.");
-        Messages2.cannotExtractSuper = createMessage("Cannot extract super call.");
-        Messages2.cannotExtractJSDoc = createMessage("Cannot extract JSDoc.");
-        Messages2.cannotExtractEmpty = createMessage("Cannot extract empty range.");
-        Messages2.expressionExpected = createMessage("expression expected.");
-        Messages2.uselessConstantType = createMessage("No reason to extract constant of type.");
-        Messages2.statementOrExpressionExpected = createMessage("Statement or expression expected.");
-        Messages2.cannotExtractRangeContainingConditionalBreakOrContinueStatements = createMessage("Cannot extract range containing conditional break or continue statements.");
-        Messages2.cannotExtractRangeContainingConditionalReturnStatement = createMessage("Cannot extract range containing conditional return statement.");
-        Messages2.cannotExtractRangeContainingLabeledBreakOrContinueStatementWithTargetOutsideOfTheRange = createMessage("Cannot extract range containing labeled break or continue with target outside of the range.");
-        Messages2.cannotExtractRangeThatContainsWritesToReferencesLocatedOutsideOfTheTargetRangeInGenerators = createMessage("Cannot extract range containing writes to references located outside of the target range in generators.");
-        Messages2.typeWillNotBeVisibleInTheNewScope = createMessage("Type will not visible in the new scope.");
-        Messages2.functionWillNotBeVisibleInTheNewScope = createMessage("Function will not visible in the new scope.");
-        Messages2.cannotExtractIdentifier = createMessage("Select more than a single identifier.");
-        Messages2.cannotExtractExportedEntity = createMessage("Cannot extract exported declaration");
-        Messages2.cannotWriteInExpression = createMessage("Cannot write back side-effects when extracting an expression");
-        Messages2.cannotExtractReadonlyPropertyInitializerOutsideConstructor = createMessage("Cannot move initialization of read-only class property outside of the constructor");
-        Messages2.cannotExtractAmbientBlock = createMessage("Cannot extract code from ambient contexts");
-        Messages2.cannotAccessVariablesFromNestedScopes = createMessage("Cannot access variables from nested scopes");
-        Messages2.cannotExtractToJSClass = createMessage("Cannot extract constant to a class scope in JS");
-        Messages2.cannotExtractToExpressionArrowFunction = createMessage("Cannot extract constant to an arrow function without a block");
-        Messages2.cannotExtractFunctionsContainingThisToMethod = createMessage("Cannot extract functions containing this to method");
-      })(Messages || (Messages = {}));
-      RangeFacts = /* @__PURE__ */ ((RangeFacts2) => {
-        RangeFacts2[RangeFacts2["None"] = 0] = "None";
-        RangeFacts2[RangeFacts2["HasReturn"] = 1] = "HasReturn";
-        RangeFacts2[RangeFacts2["IsGenerator"] = 2] = "IsGenerator";
-        RangeFacts2[RangeFacts2["IsAsyncFunction"] = 4] = "IsAsyncFunction";
-        RangeFacts2[RangeFacts2["UsesThis"] = 8] = "UsesThis";
-        RangeFacts2[RangeFacts2["UsesThisInFunction"] = 16] = "UsesThisInFunction";
-        RangeFacts2[RangeFacts2["InStaticRegion"] = 32] = "InStaticRegion";
-        return RangeFacts2;
-      })(RangeFacts || {});
-    }
-  });
-
-  // src/services/_namespaces/ts.refactor.extractSymbol.ts
-  var ts_refactor_extractSymbol_exports = {};
-  __export(ts_refactor_extractSymbol_exports, {
-    Messages: () => Messages,
-    RangeFacts: () => RangeFacts,
-    getRangeToExtract: () => getRangeToExtract2,
-    getRefactorActionsToExtractSymbol: () => getRefactorActionsToExtractSymbol,
-    getRefactorEditsToExtractSymbol: () => getRefactorEditsToExtractSymbol
-  });
-  var init_ts_refactor_extractSymbol = __esm({
-    "src/services/_namespaces/ts.refactor.extractSymbol.ts"() {
-      "use strict";
-      init_extractSymbol();
-    }
-  });
-
-  // src/services/refactors/generateGetAccessorAndSetAccessor.ts
-  var actionName, actionDescription, generateGetSetAction;
-  var init_generateGetAccessorAndSetAccessor = __esm({
-    "src/services/refactors/generateGetAccessorAndSetAccessor.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_refactor();
-      actionName = "Generate 'get' and 'set' accessors";
-      actionDescription = Diagnostics.Generate_get_and_set_accessors.message;
-      generateGetSetAction = {
-        name: actionName,
-        description: actionDescription,
-        kind: "refactor.rewrite.property.generateAccessors"
-      };
-      registerRefactor(actionName, {
-        kinds: [generateGetSetAction.kind],
-        getEditsForAction: function getRefactorActionsToGenerateGetAndSetAccessors(context, actionName2) {
-          if (!context.endPosition)
-            return void 0;
-          const info = ts_codefix_exports.getAccessorConvertiblePropertyAtPosition(context.file, context.program, context.startPosition, context.endPosition);
-          Debug.assert(info && !isRefactorErrorInfo(info), "Expected applicable refactor info");
-          const edits = ts_codefix_exports.generateAccessorFromProperty(context.file, context.program, context.startPosition, context.endPosition, context, actionName2);
-          if (!edits)
-            return void 0;
-          const renameFilename = context.file.fileName;
-          const nameNeedRename = info.renameAccessor ? info.accessorName : info.fieldName;
-          const renameLocationOffset = isIdentifier(nameNeedRename) ? 0 : -1;
-          const renameLocation = renameLocationOffset + getRenameLocation(
-            edits,
-            renameFilename,
-            nameNeedRename.text,
-            /*preferLastLocation*/
-            isParameter(info.declaration)
-          );
-          return { renameFilename, renameLocation, edits };
-        },
-        getAvailableActions(context) {
-          if (!context.endPosition)
-            return emptyArray;
-          const info = ts_codefix_exports.getAccessorConvertiblePropertyAtPosition(context.file, context.program, context.startPosition, context.endPosition, context.triggerReason === "invoked");
-          if (!info)
-            return emptyArray;
-          if (!isRefactorErrorInfo(info)) {
-            return [{
-              name: actionName,
-              description: actionDescription,
-              actions: [generateGetSetAction]
-            }];
-          }
-          if (context.preferences.provideRefactorNotApplicableReason) {
-            return [{
-              name: actionName,
-              description: actionDescription,
-              actions: [{ ...generateGetSetAction, notApplicableReason: info.error }]
-            }];
-          }
-          return emptyArray;
-        }
-      });
-    }
-  });
-
-  // src/services/_namespaces/ts.refactor.generateGetAccessorAndSetAccessor.ts
-  var ts_refactor_generateGetAccessorAndSetAccessor_exports = {};
-  var init_ts_refactor_generateGetAccessorAndSetAccessor = __esm({
-    "src/services/_namespaces/ts.refactor.generateGetAccessorAndSetAccessor.ts"() {
-      "use strict";
-      init_generateGetAccessorAndSetAccessor();
-    }
-  });
-
-  // src/services/refactors/inferFunctionReturnType.ts
-  function getRefactorEditsToInferReturnType(context) {
-    const info = getInfo4(context);
-    if (info && !isRefactorErrorInfo(info)) {
-      const edits = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange7(context.file, t, info.declaration, info.returnTypeNode));
-      return { renameFilename: void 0, renameLocation: void 0, edits };
-    }
-    return void 0;
-  }
-  function getRefactorActionsToInferReturnType(context) {
-    const info = getInfo4(context);
-    if (!info)
-      return emptyArray;
-    if (!isRefactorErrorInfo(info)) {
-      return [{
-        name: refactorName12,
-        description: refactorDescription6,
-        actions: [inferReturnTypeAction]
-      }];
-    }
-    if (context.preferences.provideRefactorNotApplicableReason) {
-      return [{
-        name: refactorName12,
-        description: refactorDescription6,
-        actions: [{ ...inferReturnTypeAction, notApplicableReason: info.error }]
-      }];
-    }
-    return emptyArray;
-  }
-  function doChange7(sourceFile, changes, declaration, typeNode) {
-    const closeParen = findChildOfKind(declaration, 22 /* CloseParenToken */, sourceFile);
-    const needParens = isArrowFunction(declaration) && closeParen === void 0;
-    const endNode2 = needParens ? first(declaration.parameters) : closeParen;
-    if (endNode2) {
-      if (needParens) {
-        changes.insertNodeBefore(sourceFile, endNode2, factory.createToken(21 /* OpenParenToken */));
-        changes.insertNodeAfter(sourceFile, endNode2, factory.createToken(22 /* CloseParenToken */));
-      }
-      changes.insertNodeAt(sourceFile, endNode2.end, typeNode, { prefix: ": " });
-    }
-  }
-  function getInfo4(context) {
-    if (isInJSFile(context.file) || !refactorKindBeginsWith(inferReturnTypeAction.kind, context.kind))
-      return;
-    const token = getTokenAtPosition(context.file, context.startPosition);
-    const declaration = findAncestor(token, (n) => isBlock(n) || n.parent && isArrowFunction(n.parent) && (n.kind === 39 /* EqualsGreaterThanToken */ || n.parent.body === n) ? "quit" : isConvertibleDeclaration(n));
-    if (!declaration || !declaration.body || declaration.type) {
-      return { error: getLocaleSpecificMessage(Diagnostics.Return_type_must_be_inferred_from_a_function) };
-    }
-    const typeChecker = context.program.getTypeChecker();
-    const returnType = tryGetReturnType(typeChecker, declaration);
-    if (!returnType) {
-      return { error: getLocaleSpecificMessage(Diagnostics.Could_not_determine_function_return_type) };
-    }
-    const returnTypeNode = typeChecker.typeToTypeNode(returnType, declaration, 1 /* NoTruncation */);
-    if (returnTypeNode) {
-      return { declaration, returnTypeNode };
-    }
-  }
-  function isConvertibleDeclaration(node) {
-    switch (node.kind) {
-      case 261 /* FunctionDeclaration */:
-      case 217 /* FunctionExpression */:
-      case 218 /* ArrowFunction */:
-      case 173 /* MethodDeclaration */:
-        return true;
-      default:
-        return false;
-    }
-  }
-  function tryGetReturnType(typeChecker, node) {
-    if (typeChecker.isImplementationOfOverload(node)) {
-      const signatures = typeChecker.getTypeAtLocation(node).getCallSignatures();
-      if (signatures.length > 1) {
-        return typeChecker.getUnionType(mapDefined(signatures, (s) => s.getReturnType()));
-      }
-    }
-    const signature = typeChecker.getSignatureFromDeclaration(node);
-    if (signature) {
-      return typeChecker.getReturnTypeOfSignature(signature);
-    }
-  }
-  var refactorName12, refactorDescription6, inferReturnTypeAction;
-  var init_inferFunctionReturnType = __esm({
-    "src/services/refactors/inferFunctionReturnType.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_refactor();
-      refactorName12 = "Infer function return type";
-      refactorDescription6 = Diagnostics.Infer_function_return_type.message;
-      inferReturnTypeAction = {
-        name: refactorName12,
-        description: refactorDescription6,
-        kind: "refactor.rewrite.function.returnType"
-      };
-      registerRefactor(refactorName12, {
-        kinds: [inferReturnTypeAction.kind],
-        getEditsForAction: getRefactorEditsToInferReturnType,
-        getAvailableActions: getRefactorActionsToInferReturnType
-      });
-    }
-  });
-
-  // src/services/_namespaces/ts.refactor.inferFunctionReturnType.ts
-  var ts_refactor_inferFunctionReturnType_exports = {};
-  var init_ts_refactor_inferFunctionReturnType = __esm({
-    "src/services/_namespaces/ts.refactor.inferFunctionReturnType.ts"() {
-      "use strict";
-      init_inferFunctionReturnType();
-    }
-  });
-
-  // src/services/_namespaces/ts.refactor.ts
-  var ts_refactor_exports = {};
-  __export(ts_refactor_exports, {
-    addExportToChanges: () => addExportToChanges,
-    addExports: () => addExports,
-    addNewFileToTsconfig: () => addNewFileToTsconfig,
-    addOrRemoveBracesToArrowFunction: () => ts_refactor_addOrRemoveBracesToArrowFunction_exports,
-    convertArrowFunctionOrFunctionExpression: () => ts_refactor_convertArrowFunctionOrFunctionExpression_exports,
-    convertParamsToDestructuredObject: () => ts_refactor_convertParamsToDestructuredObject_exports,
-    convertStringOrTemplateLiteral: () => ts_refactor_convertStringOrTemplateLiteral_exports,
-    convertToOptionalChainExpression: () => ts_refactor_convertToOptionalChainExpression_exports,
-    createNewFileName: () => createNewFileName,
-    createOldFileImportsFromTargetFile: () => createOldFileImportsFromTargetFile,
-    deleteMovedStatements: () => deleteMovedStatements,
-    deleteUnusedImports: () => deleteUnusedImports,
-    deleteUnusedOldImports: () => deleteUnusedOldImports,
-    doChangeNamedToNamespaceOrDefault: () => doChangeNamedToNamespaceOrDefault,
-    extractSymbol: () => ts_refactor_extractSymbol_exports,
-    filterImport: () => filterImport,
-    forEachImportInStatement: () => forEachImportInStatement,
-    generateGetAccessorAndSetAccessor: () => ts_refactor_generateGetAccessorAndSetAccessor_exports,
-    getApplicableRefactors: () => getApplicableRefactors,
-    getEditsForRefactor: () => getEditsForRefactor,
-    getStatementsToMove: () => getStatementsToMove,
-    getTopLevelDeclarationStatement: () => getTopLevelDeclarationStatement,
-    getUsageInfo: () => getUsageInfo,
-    inferFunctionReturnType: () => ts_refactor_inferFunctionReturnType_exports,
-    isRefactorErrorInfo: () => isRefactorErrorInfo,
-    isTopLevelDeclaration: () => isTopLevelDeclaration,
-    makeImportOrRequire: () => makeImportOrRequire,
-    moduleSpecifierFromImport: () => moduleSpecifierFromImport,
-    nameOfTopLevelDeclaration: () => nameOfTopLevelDeclaration,
-    refactorKindBeginsWith: () => refactorKindBeginsWith,
-    registerRefactor: () => registerRefactor,
-    updateImportsInOtherFiles: () => updateImportsInOtherFiles
-  });
-  var init_ts_refactor = __esm({
-    "src/services/_namespaces/ts.refactor.ts"() {
-      "use strict";
-      init_refactorProvider();
-      init_convertExport();
-      init_convertImport();
-      init_extractType();
-      init_helpers();
-      init_moveToNewFile();
-      init_moveToFile();
-      init_ts_refactor_addOrRemoveBracesToArrowFunction();
-      init_ts_refactor_convertArrowFunctionOrFunctionExpression();
-      init_ts_refactor_convertParamsToDestructuredObject();
-      init_ts_refactor_convertStringOrTemplateLiteral();
-      init_ts_refactor_convertToOptionalChainExpression();
-      init_ts_refactor_extractSymbol();
-      init_ts_refactor_generateGetAccessorAndSetAccessor();
-      init_ts_refactor_inferFunctionReturnType();
-    }
-  });
-
-  // src/services/classifier2020.ts
-  function getSemanticClassifications2(program, cancellationToken, sourceFile, span) {
-    const classifications = getEncodedSemanticClassifications2(program, cancellationToken, sourceFile, span);
-    Debug.assert(classifications.spans.length % 3 === 0);
-    const dense = classifications.spans;
-    const result = [];
-    for (let i = 0; i < dense.length; i += 3) {
-      result.push({
-        textSpan: createTextSpan(dense[i], dense[i + 1]),
-        classificationType: dense[i + 2]
-      });
-    }
-    return result;
-  }
-  function getEncodedSemanticClassifications2(program, cancellationToken, sourceFile, span) {
-    return {
-      spans: getSemanticTokens(program, sourceFile, span, cancellationToken),
-      endOfLineState: 0 /* None */
-    };
-  }
-  function getSemanticTokens(program, sourceFile, span, cancellationToken) {
-    const resultTokens = [];
-    const collector = (node, typeIdx, modifierSet) => {
-      resultTokens.push(node.getStart(sourceFile), node.getWidth(sourceFile), (typeIdx + 1 << 8 /* typeOffset */) + modifierSet);
-    };
-    if (program && sourceFile) {
-      collectTokens(program, sourceFile, span, collector, cancellationToken);
-    }
-    return resultTokens;
-  }
-  function collectTokens(program, sourceFile, span, collector, cancellationToken) {
-    const typeChecker = program.getTypeChecker();
-    let inJSXElement = false;
-    function visit(node) {
-      switch (node.kind) {
-        case 266 /* ModuleDeclaration */:
-        case 262 /* ClassDeclaration */:
-        case 263 /* InterfaceDeclaration */:
-        case 261 /* FunctionDeclaration */:
-        case 230 /* ClassExpression */:
-        case 217 /* FunctionExpression */:
-        case 218 /* ArrowFunction */:
-          cancellationToken.throwIfCancellationRequested();
-      }
-      if (!node || !textSpanIntersectsWith(span, node.pos, node.getFullWidth()) || node.getFullWidth() === 0) {
-        return;
-      }
-      const prevInJSXElement = inJSXElement;
-      if (isJsxElement(node) || isJsxSelfClosingElement(node)) {
-        inJSXElement = true;
-      }
-      if (isJsxExpression(node)) {
-        inJSXElement = false;
-      }
-      if (isIdentifier(node) && !inJSXElement && !inImportClause(node) && !isInfinityOrNaNString(node.escapedText)) {
-        let symbol = typeChecker.getSymbolAtLocation(node);
-        if (symbol) {
-          if (symbol.flags & 2097152 /* Alias */) {
-            symbol = typeChecker.getAliasedSymbol(symbol);
-          }
-          let typeIdx = classifySymbol2(symbol, getMeaningFromLocation(node));
-          if (typeIdx !== void 0) {
-            let modifierSet = 0;
-            if (node.parent) {
-              const parentIsDeclaration = isBindingElement(node.parent) || tokenFromDeclarationMapping.get(node.parent.kind) === typeIdx;
-              if (parentIsDeclaration && node.parent.name === node) {
-                modifierSet = 1 << 0 /* declaration */;
-              }
-            }
-            if (typeIdx === 6 /* parameter */ && isRightSideOfQualifiedNameOrPropertyAccess2(node)) {
-              typeIdx = 9 /* property */;
-            }
-            typeIdx = reclassifyByType(typeChecker, node, typeIdx);
-            const decl = symbol.valueDeclaration;
-            if (decl) {
-              const modifiers = getCombinedModifierFlags(decl);
-              const nodeFlags = getCombinedNodeFlags(decl);
-              if (modifiers & 32 /* Static */) {
-                modifierSet |= 1 << 1 /* static */;
-              }
-              if (modifiers & 512 /* Async */) {
-                modifierSet |= 1 << 2 /* async */;
-              }
-              if (typeIdx !== 0 /* class */ && typeIdx !== 2 /* interface */) {
-                if (modifiers & 64 /* Readonly */ || nodeFlags & 2 /* Const */ || symbol.getFlags() & 8 /* EnumMember */) {
-                  modifierSet |= 1 << 3 /* readonly */;
-                }
-              }
-              if ((typeIdx === 7 /* variable */ || typeIdx === 10 /* function */) && isLocalDeclaration(decl, sourceFile)) {
-                modifierSet |= 1 << 5 /* local */;
-              }
-              if (program.isSourceFileDefaultLibrary(decl.getSourceFile())) {
-                modifierSet |= 1 << 4 /* defaultLibrary */;
-              }
-            } else if (symbol.declarations && symbol.declarations.some((d) => program.isSourceFileDefaultLibrary(d.getSourceFile()))) {
-              modifierSet |= 1 << 4 /* defaultLibrary */;
-            }
-            collector(node, typeIdx, modifierSet);
-          }
-        }
-      }
-      forEachChild(node, visit);
-      inJSXElement = prevInJSXElement;
-    }
-    visit(sourceFile);
-  }
-  function classifySymbol2(symbol, meaning) {
-    const flags = symbol.getFlags();
-    if (flags & 32 /* Class */) {
-      return 0 /* class */;
-    } else if (flags & 384 /* Enum */) {
-      return 1 /* enum */;
-    } else if (flags & 524288 /* TypeAlias */) {
-      return 5 /* type */;
-    } else if (flags & 64 /* Interface */) {
-      if (meaning & 2 /* Type */) {
-        return 2 /* interface */;
-      }
-    } else if (flags & 262144 /* TypeParameter */) {
-      return 4 /* typeParameter */;
-    }
-    let decl = symbol.valueDeclaration || symbol.declarations && symbol.declarations[0];
-    if (decl && isBindingElement(decl)) {
-      decl = getDeclarationForBindingElement(decl);
-    }
-    return decl && tokenFromDeclarationMapping.get(decl.kind);
-  }
-  function reclassifyByType(typeChecker, node, typeIdx) {
-    if (typeIdx === 7 /* variable */ || typeIdx === 9 /* property */ || typeIdx === 6 /* parameter */) {
-      const type = typeChecker.getTypeAtLocation(node);
-      if (type) {
-        const test = (condition) => {
-          return condition(type) || type.isUnion() && type.types.some(condition);
-        };
-        if (typeIdx !== 6 /* parameter */ && test((t) => t.getConstructSignatures().length > 0)) {
-          return 0 /* class */;
-        }
-        if (test((t) => t.getCallSignatures().length > 0) && !test((t) => t.getProperties().length > 0) || isExpressionInCallExpression(node)) {
-          return typeIdx === 9 /* property */ ? 11 /* member */ : 10 /* function */;
-        }
-      }
-    }
-    return typeIdx;
-  }
-  function isLocalDeclaration(decl, sourceFile) {
-    if (isBindingElement(decl)) {
-      decl = getDeclarationForBindingElement(decl);
-    }
-    if (isVariableDeclaration(decl)) {
-      return (!isSourceFile(decl.parent.parent.parent) || isCatchClause(decl.parent)) && decl.getSourceFile() === sourceFile;
-    } else if (isFunctionDeclaration(decl)) {
-      return !isSourceFile(decl.parent) && decl.getSourceFile() === sourceFile;
-    }
-    return false;
-  }
-  function getDeclarationForBindingElement(element) {
-    while (true) {
-      if (isBindingElement(element.parent.parent)) {
-        element = element.parent.parent;
-      } else {
-        return element.parent.parent;
-      }
-    }
-  }
-  function inImportClause(node) {
-    const parent2 = node.parent;
-    return parent2 && (isImportClause(parent2) || isImportSpecifier(parent2) || isNamespaceImport(parent2));
-  }
-  function isExpressionInCallExpression(node) {
-    while (isRightSideOfQualifiedNameOrPropertyAccess2(node)) {
-      node = node.parent;
-    }
-    return isCallExpression(node.parent) && node.parent.expression === node;
-  }
-  function isRightSideOfQualifiedNameOrPropertyAccess2(node) {
-    return isQualifiedName(node.parent) && node.parent.right === node || isPropertyAccessExpression(node.parent) && node.parent.name === node;
-  }
-  var TokenEncodingConsts, TokenType, TokenModifier, tokenFromDeclarationMapping;
-  var init_classifier2020 = __esm({
-    "src/services/classifier2020.ts"() {
-      "use strict";
-      init_ts4();
-      TokenEncodingConsts = /* @__PURE__ */ ((TokenEncodingConsts2) => {
-        TokenEncodingConsts2[TokenEncodingConsts2["typeOffset"] = 8] = "typeOffset";
-        TokenEncodingConsts2[TokenEncodingConsts2["modifierMask"] = 255] = "modifierMask";
-        return TokenEncodingConsts2;
-      })(TokenEncodingConsts || {});
-      TokenType = /* @__PURE__ */ ((TokenType2) => {
-        TokenType2[TokenType2["class"] = 0] = "class";
-        TokenType2[TokenType2["enum"] = 1] = "enum";
-        TokenType2[TokenType2["interface"] = 2] = "interface";
-        TokenType2[TokenType2["namespace"] = 3] = "namespace";
-        TokenType2[TokenType2["typeParameter"] = 4] = "typeParameter";
-        TokenType2[TokenType2["type"] = 5] = "type";
-        TokenType2[TokenType2["parameter"] = 6] = "parameter";
-        TokenType2[TokenType2["variable"] = 7] = "variable";
-        TokenType2[TokenType2["enumMember"] = 8] = "enumMember";
-        TokenType2[TokenType2["property"] = 9] = "property";
-        TokenType2[TokenType2["function"] = 10] = "function";
-        TokenType2[TokenType2["member"] = 11] = "member";
-        return TokenType2;
-      })(TokenType || {});
-      TokenModifier = /* @__PURE__ */ ((TokenModifier2) => {
-        TokenModifier2[TokenModifier2["declaration"] = 0] = "declaration";
-        TokenModifier2[TokenModifier2["static"] = 1] = "static";
-        TokenModifier2[TokenModifier2["async"] = 2] = "async";
-        TokenModifier2[TokenModifier2["readonly"] = 3] = "readonly";
-        TokenModifier2[TokenModifier2["defaultLibrary"] = 4] = "defaultLibrary";
-        TokenModifier2[TokenModifier2["local"] = 5] = "local";
-        return TokenModifier2;
-      })(TokenModifier || {});
-      tokenFromDeclarationMapping = /* @__PURE__ */ new Map([
-        [259 /* VariableDeclaration */, 7 /* variable */],
-        [168 /* Parameter */, 6 /* parameter */],
-        [171 /* PropertyDeclaration */, 9 /* property */],
-        [266 /* ModuleDeclaration */, 3 /* namespace */],
-        [265 /* EnumDeclaration */, 1 /* enum */],
-        [305 /* EnumMember */, 8 /* enumMember */],
-        [262 /* ClassDeclaration */, 0 /* class */],
-        [173 /* MethodDeclaration */, 11 /* member */],
-        [261 /* FunctionDeclaration */, 10 /* function */],
-        [217 /* FunctionExpression */, 10 /* function */],
-        [172 /* MethodSignature */, 11 /* member */],
-        [176 /* GetAccessor */, 9 /* property */],
-        [177 /* SetAccessor */, 9 /* property */],
-        [170 /* PropertySignature */, 9 /* property */],
-        [263 /* InterfaceDeclaration */, 2 /* interface */],
-        [264 /* TypeAliasDeclaration */, 5 /* type */],
-        [167 /* TypeParameter */, 4 /* typeParameter */],
-        [302 /* PropertyAssignment */, 9 /* property */],
-        [303 /* ShorthandPropertyAssignment */, 9 /* property */]
-      ]);
-    }
-  });
-
-  // src/services/services.ts
-  function createNode(kind, pos, end, parent2) {
-    const node = isNodeKind(kind) ? new NodeObject(kind, pos, end) : kind === 80 /* Identifier */ ? new IdentifierObject(80 /* Identifier */, pos, end) : kind === 81 /* PrivateIdentifier */ ? new PrivateIdentifierObject(81 /* PrivateIdentifier */, pos, end) : new TokenObject(kind, pos, end);
-    node.parent = parent2;
-    node.flags = parent2.flags & 50720768 /* ContextFlags */;
-    return node;
-  }
-  function createChildren(node, sourceFile) {
-    if (!isNodeKind(node.kind)) {
-      return emptyArray;
-    }
-    const children = [];
-    if (isJSDocCommentContainingNode(node)) {
-      node.forEachChild((child) => {
-        children.push(child);
-      });
-      return children;
-    }
-    scanner.setText((sourceFile || node.getSourceFile()).text);
-    let pos = node.pos;
-    const processNode = (child) => {
-      addSyntheticNodes(children, pos, child.pos, node);
-      children.push(child);
-      pos = child.end;
-    };
-    const processNodes = (nodes) => {
-      addSyntheticNodes(children, pos, nodes.pos, node);
-      children.push(createSyntaxList(nodes, node));
-      pos = nodes.end;
-    };
-    forEach(node.jsDoc, processNode);
-    pos = node.pos;
-    node.forEachChild(processNode, processNodes);
-    addSyntheticNodes(children, pos, node.end, node);
-    scanner.setText(void 0);
-    return children;
-  }
-  function addSyntheticNodes(nodes, pos, end, parent2) {
-    scanner.resetTokenState(pos);
-    while (pos < end) {
-      const token = scanner.scan();
-      const textPos = scanner.getTokenEnd();
-      if (textPos <= end) {
-        if (token === 80 /* Identifier */) {
-          if (hasTabstop(parent2)) {
-            continue;
-          }
-          Debug.fail(`Did not expect ${Debug.formatSyntaxKind(parent2.kind)} to have an Identifier in its trivia`);
-        }
-        nodes.push(createNode(token, pos, textPos, parent2));
-      }
-      pos = textPos;
-      if (token === 1 /* EndOfFileToken */) {
-        break;
-      }
-    }
-  }
-  function createSyntaxList(nodes, parent2) {
-    const list = createNode(357 /* SyntaxList */, nodes.pos, nodes.end, parent2);
-    list._children = [];
-    let pos = nodes.pos;
-    for (const node of nodes) {
-      addSyntheticNodes(list._children, pos, node.pos, parent2);
-      list._children.push(node);
-      pos = node.end;
-    }
-    addSyntheticNodes(list._children, pos, nodes.end, parent2);
-    return list;
-  }
-  function hasJSDocInheritDocTag(node) {
-    return getJSDocTags(node).some((tag) => tag.tagName.text === "inheritDoc" || tag.tagName.text === "inheritdoc");
-  }
-  function getJsDocTagsOfDeclarations(declarations, checker) {
-    if (!declarations)
-      return emptyArray;
-    let tags = ts_JsDoc_exports.getJsDocTagsFromDeclarations(declarations, checker);
-    if (checker && (tags.length === 0 || declarations.some(hasJSDocInheritDocTag))) {
-      const seenSymbols = /* @__PURE__ */ new Set();
-      for (const declaration of declarations) {
-        const inheritedTags = findBaseOfDeclaration(checker, declaration, (symbol) => {
-          var _a;
-          if (!seenSymbols.has(symbol)) {
-            seenSymbols.add(symbol);
-            if (declaration.kind === 176 /* GetAccessor */ || declaration.kind === 177 /* SetAccessor */) {
-              return symbol.getContextualJsDocTags(declaration, checker);
-            }
-            return ((_a = symbol.declarations) == null ? void 0 : _a.length) === 1 ? symbol.getJsDocTags() : void 0;
-          }
-        });
-        if (inheritedTags) {
-          tags = [...inheritedTags, ...tags];
-        }
-      }
-    }
-    return tags;
-  }
-  function getDocumentationComment(declarations, checker) {
-    if (!declarations)
-      return emptyArray;
-    let doc = ts_JsDoc_exports.getJsDocCommentsFromDeclarations(declarations, checker);
-    if (checker && (doc.length === 0 || declarations.some(hasJSDocInheritDocTag))) {
-      const seenSymbols = /* @__PURE__ */ new Set();
-      for (const declaration of declarations) {
-        const inheritedDocs = findBaseOfDeclaration(checker, declaration, (symbol) => {
-          if (!seenSymbols.has(symbol)) {
-            seenSymbols.add(symbol);
-            if (declaration.kind === 176 /* GetAccessor */ || declaration.kind === 177 /* SetAccessor */) {
-              return symbol.getContextualDocumentationComment(declaration, checker);
-            }
-            return symbol.getDocumentationComment(checker);
-          }
-        });
-        if (inheritedDocs)
-          doc = doc.length === 0 ? inheritedDocs.slice() : inheritedDocs.concat(lineBreakPart(), doc);
-      }
-    }
-    return doc;
-  }
-  function findBaseOfDeclaration(checker, declaration, cb) {
-    var _a;
-    const classOrInterfaceDeclaration = ((_a = declaration.parent) == null ? void 0 : _a.kind) === 175 /* Constructor */ ? declaration.parent.parent : declaration.parent;
-    if (!classOrInterfaceDeclaration)
-      return;
-    const isStaticMember = hasStaticModifier(declaration);
-    return firstDefined(getAllSuperTypeNodes(classOrInterfaceDeclaration), (superTypeNode) => {
-      const baseType = checker.getTypeAtLocation(superTypeNode);
-      const type = isStaticMember && baseType.symbol ? checker.getTypeOfSymbol(baseType.symbol) : baseType;
-      const symbol = checker.getPropertyOfType(type, declaration.symbol.name);
-      return symbol ? cb(symbol) : void 0;
-    });
-  }
-  function getServicesObjectAllocator() {
-    return {
-      getNodeConstructor: () => NodeObject,
-      getTokenConstructor: () => TokenObject,
-      getIdentifierConstructor: () => IdentifierObject,
-      getPrivateIdentifierConstructor: () => PrivateIdentifierObject,
-      getSourceFileConstructor: () => SourceFileObject,
-      getSymbolConstructor: () => SymbolObject,
-      getTypeConstructor: () => TypeObject,
-      getSignatureConstructor: () => SignatureObject,
-      getSourceMapSourceConstructor: () => SourceMapSourceObject
-    };
-  }
-  function toEditorSettings(optionsAsMap) {
-    let allPropertiesAreCamelCased = true;
-    for (const key in optionsAsMap) {
-      if (hasProperty(optionsAsMap, key) && !isCamelCase(key)) {
-        allPropertiesAreCamelCased = false;
-        break;
-      }
-    }
-    if (allPropertiesAreCamelCased) {
-      return optionsAsMap;
-    }
-    const settings = {};
-    for (const key in optionsAsMap) {
-      if (hasProperty(optionsAsMap, key)) {
-        const newKey = isCamelCase(key) ? key : key.charAt(0).toLowerCase() + key.substr(1);
-        settings[newKey] = optionsAsMap[key];
-      }
-    }
-    return settings;
-  }
-  function isCamelCase(s) {
-    return !s.length || s.charAt(0) === s.charAt(0).toLowerCase();
-  }
-  function displayPartsToString(displayParts) {
-    if (displayParts) {
-      return map(displayParts, (displayPart2) => displayPart2.text).join("");
-    }
-    return "";
-  }
-  function getDefaultCompilerOptions2() {
-    return {
-      target: 1 /* ES5 */,
-      jsx: 1 /* Preserve */
-    };
-  }
-  function getSupportedCodeFixes() {
-    return ts_codefix_exports.getSupportedErrorCodes();
-  }
-  function setSourceFileFields(sourceFile, scriptSnapshot, version2) {
-    sourceFile.version = version2;
-    sourceFile.scriptSnapshot = scriptSnapshot;
-  }
-  function createLanguageServiceSourceFile(fileName, scriptSnapshot, scriptTargetOrOptions, version2, setNodeParents, scriptKind) {
-    const sourceFile = createSourceFile(fileName, getSnapshotText(scriptSnapshot), scriptTargetOrOptions, setNodeParents, scriptKind);
-    setSourceFileFields(sourceFile, scriptSnapshot, version2);
-    return sourceFile;
-  }
-  function updateLanguageServiceSourceFile(sourceFile, scriptSnapshot, version2, textChangeRange, aggressiveChecks) {
-    if (textChangeRange) {
-      if (version2 !== sourceFile.version) {
-        let newText;
-        const prefix = textChangeRange.span.start !== 0 ? sourceFile.text.substr(0, textChangeRange.span.start) : "";
-        const suffix = textSpanEnd(textChangeRange.span) !== sourceFile.text.length ? sourceFile.text.substr(textSpanEnd(textChangeRange.span)) : "";
-        if (textChangeRange.newLength === 0) {
-          newText = prefix && suffix ? prefix + suffix : prefix || suffix;
-        } else {
-          const changedText = scriptSnapshot.getText(textChangeRange.span.start, textChangeRange.span.start + textChangeRange.newLength);
-          newText = prefix && suffix ? prefix + changedText + suffix : prefix ? prefix + changedText : changedText + suffix;
-        }
-        const newSourceFile = updateSourceFile(sourceFile, newText, textChangeRange, aggressiveChecks);
-        setSourceFileFields(newSourceFile, scriptSnapshot, version2);
-        newSourceFile.nameTable = void 0;
-        if (sourceFile !== newSourceFile && sourceFile.scriptSnapshot) {
-          if (sourceFile.scriptSnapshot.dispose) {
-            sourceFile.scriptSnapshot.dispose();
-          }
-          sourceFile.scriptSnapshot = void 0;
-        }
-        return newSourceFile;
-      }
-    }
-    const options = {
-      languageVersion: sourceFile.languageVersion,
-      impliedNodeFormat: sourceFile.impliedNodeFormat,
-      setExternalModuleIndicator: sourceFile.setExternalModuleIndicator
-    };
-    return createLanguageServiceSourceFile(
-      sourceFile.fileName,
-      scriptSnapshot,
-      options,
-      version2,
-      /*setNodeParents*/
-      true,
-      sourceFile.scriptKind
-    );
-  }
-  function createLanguageService(host, documentRegistry = createDocumentRegistry(host.useCaseSensitiveFileNames && host.useCaseSensitiveFileNames(), host.getCurrentDirectory()), syntaxOnlyOrLanguageServiceMode) {
-    var _a;
-    let languageServiceMode;
-    if (syntaxOnlyOrLanguageServiceMode === void 0) {
-      languageServiceMode = 0 /* Semantic */;
-    } else if (typeof syntaxOnlyOrLanguageServiceMode === "boolean") {
-      languageServiceMode = syntaxOnlyOrLanguageServiceMode ? 2 /* Syntactic */ : 0 /* Semantic */;
-    } else {
-      languageServiceMode = syntaxOnlyOrLanguageServiceMode;
-    }
-    const syntaxTreeCache = new SyntaxTreeCache(host);
-    let program;
-    let lastProjectVersion;
-    let lastTypesRootVersion = 0;
-    const cancellationToken = host.getCancellationToken ? new CancellationTokenObject(host.getCancellationToken()) : NoopCancellationToken;
-    const currentDirectory = host.getCurrentDirectory();
-    maybeSetLocalizedDiagnosticMessages((_a = host.getLocalizedDiagnosticMessages) == null ? void 0 : _a.bind(host));
-    function log(message) {
-      if (host.log) {
-        host.log(message);
-      }
-    }
-    const useCaseSensitiveFileNames = hostUsesCaseSensitiveFileNames(host);
-    const getCanonicalFileName = createGetCanonicalFileName(useCaseSensitiveFileNames);
-    const sourceMapper = getSourceMapper({
-      useCaseSensitiveFileNames: () => useCaseSensitiveFileNames,
-      getCurrentDirectory: () => currentDirectory,
-      getProgram,
-      fileExists: maybeBind(host, host.fileExists),
-      readFile: maybeBind(host, host.readFile),
-      getDocumentPositionMapper: maybeBind(host, host.getDocumentPositionMapper),
-      getSourceFileLike: maybeBind(host, host.getSourceFileLike),
-      log
-    });
-    function getValidSourceFile(fileName) {
-      const sourceFile = program.getSourceFile(fileName);
-      if (!sourceFile) {
-        const error = new Error(`Could not find source file: '${fileName}'.`);
-        error.ProgramFiles = program.getSourceFiles().map((f) => f.fileName);
-        throw error;
-      }
-      return sourceFile;
-    }
-    function synchronizeHostData() {
-      var _a2, _b, _c;
-      Debug.assert(languageServiceMode !== 2 /* Syntactic */);
-      if (host.getProjectVersion) {
-        const hostProjectVersion = host.getProjectVersion();
-        if (hostProjectVersion) {
-          if (lastProjectVersion === hostProjectVersion && !((_a2 = host.hasChangedAutomaticTypeDirectiveNames) == null ? void 0 : _a2.call(host))) {
-            return;
-          }
-          lastProjectVersion = hostProjectVersion;
-        }
-      }
-      const typeRootsVersion = host.getTypeRootsVersion ? host.getTypeRootsVersion() : 0;
-      if (lastTypesRootVersion !== typeRootsVersion) {
-        log("TypeRoots version has changed; provide new program");
-        program = void 0;
-        lastTypesRootVersion = typeRootsVersion;
-      }
-      const rootFileNames = host.getScriptFileNames().slice();
-      const newSettings = host.getCompilationSettings() || getDefaultCompilerOptions2();
-      const hasInvalidatedResolutions = host.hasInvalidatedResolutions || returnFalse;
-      const hasInvalidatedLibResolutions = maybeBind(host, host.hasInvalidatedLibResolutions) || returnFalse;
-      const hasChangedAutomaticTypeDirectiveNames = maybeBind(host, host.hasChangedAutomaticTypeDirectiveNames);
-      const projectReferences = (_b = host.getProjectReferences) == null ? void 0 : _b.call(host);
-      let parsedCommandLines;
-      let compilerHost = {
-        getSourceFile: getOrCreateSourceFile,
-        getSourceFileByPath: getOrCreateSourceFileByPath,
-        getCancellationToken: () => cancellationToken,
-        getCanonicalFileName,
-        useCaseSensitiveFileNames: () => useCaseSensitiveFileNames,
-        getNewLine: () => getNewLineCharacter(newSettings),
-        getDefaultLibFileName: (options2) => host.getDefaultLibFileName(options2),
-        writeFile: noop,
-        getCurrentDirectory: () => currentDirectory,
-        fileExists: (fileName) => host.fileExists(fileName),
-        readFile: (fileName) => host.readFile && host.readFile(fileName),
-        getSymlinkCache: maybeBind(host, host.getSymlinkCache),
-        realpath: maybeBind(host, host.realpath),
-        directoryExists: (directoryName) => {
-          return directoryProbablyExists(directoryName, host);
-        },
-        getDirectories: (path) => {
-          return host.getDirectories ? host.getDirectories(path) : [];
-        },
-        readDirectory: (path, extensions, exclude, include, depth) => {
-          Debug.checkDefined(host.readDirectory, "'LanguageServiceHost.readDirectory' must be implemented to correctly process 'projectReferences'");
-          return host.readDirectory(path, extensions, exclude, include, depth);
-        },
-        onReleaseOldSourceFile,
-        onReleaseParsedCommandLine,
-        hasInvalidatedResolutions,
-        hasInvalidatedLibResolutions,
-        hasChangedAutomaticTypeDirectiveNames,
-        trace: maybeBind(host, host.trace),
-        resolveModuleNames: maybeBind(host, host.resolveModuleNames),
-        getModuleResolutionCache: maybeBind(host, host.getModuleResolutionCache),
-        createHash: maybeBind(host, host.createHash),
-        resolveTypeReferenceDirectives: maybeBind(host, host.resolveTypeReferenceDirectives),
-        resolveModuleNameLiterals: maybeBind(host, host.resolveModuleNameLiterals),
-        resolveTypeReferenceDirectiveReferences: maybeBind(host, host.resolveTypeReferenceDirectiveReferences),
-        resolveLibrary: maybeBind(host, host.resolveLibrary),
-        useSourceOfProjectReferenceRedirect: maybeBind(host, host.useSourceOfProjectReferenceRedirect),
-        getParsedCommandLine
-      };
-      const originalGetSourceFile = compilerHost.getSourceFile;
-      const { getSourceFileWithCache } = changeCompilerHostLikeToUseCache(
-        compilerHost,
-        (fileName) => toPath(fileName, currentDirectory, getCanonicalFileName),
-        (...args) => originalGetSourceFile.call(compilerHost, ...args)
-      );
-      compilerHost.getSourceFile = getSourceFileWithCache;
-      (_c = host.setCompilerHost) == null ? void 0 : _c.call(host, compilerHost);
-      const parseConfigHost = {
-        useCaseSensitiveFileNames,
-        fileExists: (fileName) => compilerHost.fileExists(fileName),
-        readFile: (fileName) => compilerHost.readFile(fileName),
-        readDirectory: (...args) => compilerHost.readDirectory(...args),
-        trace: compilerHost.trace,
-        getCurrentDirectory: compilerHost.getCurrentDirectory,
-        onUnRecoverableConfigFileDiagnostic: noop
-      };
-      const documentRegistryBucketKey = documentRegistry.getKeyForCompilationSettings(newSettings);
-      let releasedScriptKinds = /* @__PURE__ */ new Set();
-      if (isProgramUptoDate(program, rootFileNames, newSettings, (_path, fileName) => host.getScriptVersion(fileName), (fileName) => compilerHost.fileExists(fileName), hasInvalidatedResolutions, hasInvalidatedLibResolutions, hasChangedAutomaticTypeDirectiveNames, getParsedCommandLine, projectReferences)) {
-        compilerHost = void 0;
-        parsedCommandLines = void 0;
-        releasedScriptKinds = void 0;
-        return;
-      }
-      const options = {
-        rootNames: rootFileNames,
-        options: newSettings,
-        host: compilerHost,
-        oldProgram: program,
-        projectReferences
-      };
-      program = createProgram(options);
-      compilerHost = void 0;
-      parsedCommandLines = void 0;
-      releasedScriptKinds = void 0;
-      sourceMapper.clearCache();
-      program.getTypeChecker();
-      return;
-      function getParsedCommandLine(fileName) {
-        const path = toPath(fileName, currentDirectory, getCanonicalFileName);
-        const existing = parsedCommandLines == null ? void 0 : parsedCommandLines.get(path);
-        if (existing !== void 0)
-          return existing || void 0;
-        const result = host.getParsedCommandLine ? host.getParsedCommandLine(fileName) : getParsedCommandLineOfConfigFileUsingSourceFile(fileName);
-        (parsedCommandLines || (parsedCommandLines = /* @__PURE__ */ new Map())).set(path, result || false);
-        return result;
-      }
-      function getParsedCommandLineOfConfigFileUsingSourceFile(configFileName) {
-        const result = getOrCreateSourceFile(configFileName, 100 /* JSON */);
-        if (!result)
-          return void 0;
-        result.path = toPath(configFileName, currentDirectory, getCanonicalFileName);
-        result.resolvedPath = result.path;
-        result.originalFileName = result.fileName;
-        return parseJsonSourceFileConfigFileContent(
-          result,
-          parseConfigHost,
-          getNormalizedAbsolutePath(getDirectoryPath(configFileName), currentDirectory),
-          /*existingOptions*/
-          void 0,
-          getNormalizedAbsolutePath(configFileName, currentDirectory)
-        );
-      }
-      function onReleaseParsedCommandLine(configFileName, oldResolvedRef, oldOptions) {
-        var _a3;
-        if (host.getParsedCommandLine) {
-          (_a3 = host.onReleaseParsedCommandLine) == null ? void 0 : _a3.call(host, configFileName, oldResolvedRef, oldOptions);
-        } else if (oldResolvedRef) {
-          onReleaseOldSourceFile(oldResolvedRef.sourceFile, oldOptions);
-        }
-      }
-      function onReleaseOldSourceFile(oldSourceFile, oldOptions) {
-        const oldSettingsKey = documentRegistry.getKeyForCompilationSettings(oldOptions);
-        documentRegistry.releaseDocumentWithKey(oldSourceFile.resolvedPath, oldSettingsKey, oldSourceFile.scriptKind, oldSourceFile.impliedNodeFormat);
-      }
-      function getOrCreateSourceFile(fileName, languageVersionOrOptions, onError, shouldCreateNewSourceFile) {
-        return getOrCreateSourceFileByPath(fileName, toPath(fileName, currentDirectory, getCanonicalFileName), languageVersionOrOptions, onError, shouldCreateNewSourceFile);
-      }
-      function getOrCreateSourceFileByPath(fileName, path, languageVersionOrOptions, _onError, shouldCreateNewSourceFile) {
-        Debug.assert(compilerHost, "getOrCreateSourceFileByPath called after typical CompilerHost lifetime, check the callstack something with a reference to an old host.");
-        const scriptSnapshot = host.getScriptSnapshot(fileName);
-        if (!scriptSnapshot) {
-          return void 0;
-        }
-        const scriptKind = getScriptKind(fileName, host);
-        const scriptVersion = host.getScriptVersion(fileName);
-        if (!shouldCreateNewSourceFile) {
-          const oldSourceFile = program && program.getSourceFileByPath(path);
-          if (oldSourceFile) {
-            if (scriptKind === oldSourceFile.scriptKind || releasedScriptKinds.has(oldSourceFile.resolvedPath)) {
-              return documentRegistry.updateDocumentWithKey(fileName, path, host, documentRegistryBucketKey, scriptSnapshot, scriptVersion, scriptKind, languageVersionOrOptions);
-            } else {
-              documentRegistry.releaseDocumentWithKey(oldSourceFile.resolvedPath, documentRegistry.getKeyForCompilationSettings(program.getCompilerOptions()), oldSourceFile.scriptKind, oldSourceFile.impliedNodeFormat);
-              releasedScriptKinds.add(oldSourceFile.resolvedPath);
-            }
-          }
-        }
-        return documentRegistry.acquireDocumentWithKey(fileName, path, host, documentRegistryBucketKey, scriptSnapshot, scriptVersion, scriptKind, languageVersionOrOptions);
-      }
-    }
-    function getProgram() {
-      if (languageServiceMode === 2 /* Syntactic */) {
-        Debug.assert(program === void 0);
-        return void 0;
-      }
-      synchronizeHostData();
-      return program;
-    }
-    function getAutoImportProvider() {
-      var _a2;
-      return (_a2 = host.getPackageJsonAutoImportProvider) == null ? void 0 : _a2.call(host);
-    }
-    function updateIsDefinitionOfReferencedSymbols(referencedSymbols, knownSymbolSpans) {
-      const checker = program.getTypeChecker();
-      const symbol = getSymbolForProgram();
-      if (!symbol)
-        return false;
-      for (const referencedSymbol of referencedSymbols) {
-        for (const ref of referencedSymbol.references) {
-          const refNode = getNodeForSpan(ref);
-          Debug.assertIsDefined(refNode);
-          if (knownSymbolSpans.has(ref) || ts_FindAllReferences_exports.isDeclarationOfSymbol(refNode, symbol)) {
-            knownSymbolSpans.add(ref);
-            ref.isDefinition = true;
-            const mappedSpan = getMappedDocumentSpan(ref, sourceMapper, maybeBind(host, host.fileExists));
-            if (mappedSpan) {
-              knownSymbolSpans.add(mappedSpan);
-            }
-          } else {
-            ref.isDefinition = false;
-          }
-        }
-      }
-      return true;
-      function getSymbolForProgram() {
-        for (const referencedSymbol of referencedSymbols) {
-          for (const ref of referencedSymbol.references) {
-            if (knownSymbolSpans.has(ref)) {
-              const refNode = getNodeForSpan(ref);
-              Debug.assertIsDefined(refNode);
-              return checker.getSymbolAtLocation(refNode);
-            }
-            const mappedSpan = getMappedDocumentSpan(ref, sourceMapper, maybeBind(host, host.fileExists));
-            if (mappedSpan && knownSymbolSpans.has(mappedSpan)) {
-              const refNode = getNodeForSpan(mappedSpan);
-              if (refNode) {
-                return checker.getSymbolAtLocation(refNode);
-              }
-            }
-          }
-        }
-        return void 0;
-      }
-      function getNodeForSpan(docSpan) {
-        const sourceFile = program.getSourceFile(docSpan.fileName);
-        if (!sourceFile)
-          return void 0;
-        const rawNode = getTouchingPropertyName(sourceFile, docSpan.textSpan.start);
-        const adjustedNode = ts_FindAllReferences_exports.Core.getAdjustedNode(rawNode, { use: ts_FindAllReferences_exports.FindReferencesUse.References });
-        return adjustedNode;
-      }
-    }
-    function cleanupSemanticCache() {
-      program = void 0;
-    }
-    function dispose() {
-      if (program) {
-        const key = documentRegistry.getKeyForCompilationSettings(program.getCompilerOptions());
-        forEach(program.getSourceFiles(), (f) => documentRegistry.releaseDocumentWithKey(f.resolvedPath, key, f.scriptKind, f.impliedNodeFormat));
-        program = void 0;
-      }
-      host = void 0;
-    }
-    function getSyntacticDiagnostics(fileName) {
-      synchronizeHostData();
-      return program.getSyntacticDiagnostics(getValidSourceFile(fileName), cancellationToken).slice();
-    }
-    function getSemanticDiagnostics(fileName) {
-      synchronizeHostData();
-      const targetSourceFile = getValidSourceFile(fileName);
-      const semanticDiagnostics = program.getSemanticDiagnostics(targetSourceFile, cancellationToken);
-      if (!getEmitDeclarations(program.getCompilerOptions())) {
-        return semanticDiagnostics.slice();
-      }
-      const declarationDiagnostics = program.getDeclarationDiagnostics(targetSourceFile, cancellationToken);
-      return [...semanticDiagnostics, ...declarationDiagnostics];
-    }
-    function getSuggestionDiagnostics(fileName) {
-      synchronizeHostData();
-      return computeSuggestionDiagnostics(getValidSourceFile(fileName), program, cancellationToken);
-    }
-    function getCompilerOptionsDiagnostics() {
-      synchronizeHostData();
-      return [...program.getOptionsDiagnostics(cancellationToken), ...program.getGlobalDiagnostics(cancellationToken)];
-    }
-    function getCompletionsAtPosition2(fileName, position, options = emptyOptions, formattingSettings) {
-      const fullPreferences = {
-        ...identity(options),
-        // avoid excess property check
-        includeCompletionsForModuleExports: options.includeCompletionsForModuleExports || options.includeExternalModuleExports,
-        includeCompletionsWithInsertText: options.includeCompletionsWithInsertText || options.includeInsertTextCompletions
-      };
-      synchronizeHostData();
-      return ts_Completions_exports.getCompletionsAtPosition(
-        host,
-        program,
-        log,
-        getValidSourceFile(fileName),
-        position,
-        fullPreferences,
-        options.triggerCharacter,
-        options.triggerKind,
-        cancellationToken,
-        formattingSettings && ts_formatting_exports.getFormatContext(formattingSettings, host),
-        options.includeSymbol
-      );
-    }
-    function getCompletionEntryDetails2(fileName, position, name, formattingOptions, source, preferences = emptyOptions, data) {
-      synchronizeHostData();
-      return ts_Completions_exports.getCompletionEntryDetails(
-        program,
-        log,
-        getValidSourceFile(fileName),
-        position,
-        { name, source, data },
-        host,
-        formattingOptions && ts_formatting_exports.getFormatContext(formattingOptions, host),
-        // TODO: GH#18217
-        preferences,
-        cancellationToken
-      );
-    }
-    function getCompletionEntrySymbol2(fileName, position, name, source, preferences = emptyOptions) {
-      synchronizeHostData();
-      return ts_Completions_exports.getCompletionEntrySymbol(program, log, getValidSourceFile(fileName), position, { name, source }, host, preferences);
-    }
-    function getQuickInfoAtPosition(fileName, position) {
-      synchronizeHostData();
-      const sourceFile = getValidSourceFile(fileName);
-      const node = getTouchingPropertyName(sourceFile, position);
-      if (node === sourceFile) {
-        return void 0;
-      }
-      const typeChecker = program.getTypeChecker();
-      const nodeForQuickInfo = getNodeForQuickInfo(node);
-      const symbol = getSymbolAtLocationForQuickInfo(nodeForQuickInfo, typeChecker);
-      if (!symbol || typeChecker.isUnknownSymbol(symbol)) {
-        const type = shouldGetType(sourceFile, nodeForQuickInfo, position) ? typeChecker.getTypeAtLocation(nodeForQuickInfo) : void 0;
-        return type && {
-          kind: "" /* unknown */,
-          kindModifiers: "" /* none */,
-          textSpan: createTextSpanFromNode(nodeForQuickInfo, sourceFile),
-          displayParts: typeChecker.runWithCancellationToken(cancellationToken, (typeChecker2) => typeToDisplayParts(typeChecker2, type, getContainerNode(nodeForQuickInfo))),
-          documentation: type.symbol ? type.symbol.getDocumentationComment(typeChecker) : void 0,
-          tags: type.symbol ? type.symbol.getJsDocTags(typeChecker) : void 0
-        };
-      }
-      const { symbolKind, displayParts, documentation, tags } = typeChecker.runWithCancellationToken(
-        cancellationToken,
-        (typeChecker2) => ts_SymbolDisplay_exports.getSymbolDisplayPartsDocumentationAndSymbolKind(typeChecker2, symbol, sourceFile, getContainerNode(nodeForQuickInfo), nodeForQuickInfo)
-      );
-      return {
-        kind: symbolKind,
-        kindModifiers: ts_SymbolDisplay_exports.getSymbolModifiers(typeChecker, symbol),
-        textSpan: createTextSpanFromNode(nodeForQuickInfo, sourceFile),
-        displayParts,
-        documentation,
-        tags
-      };
-    }
-    function getNodeForQuickInfo(node) {
-      if (isNewExpression(node.parent) && node.pos === node.parent.pos) {
-        return node.parent.expression;
-      }
-      if (isNamedTupleMember(node.parent) && node.pos === node.parent.pos) {
-        return node.parent;
-      }
-      if (isImportMeta(node.parent) && node.parent.name === node) {
-        return node.parent;
-      }
-      if (isJsxNamespacedName(node.parent)) {
-        return node.parent;
-      }
-      return node;
-    }
-    function shouldGetType(sourceFile, node, position) {
-      switch (node.kind) {
-        case 80 /* Identifier */:
-          return !isLabelName(node) && !isTagName(node) && !isConstTypeReference(node.parent);
-        case 210 /* PropertyAccessExpression */:
-        case 165 /* QualifiedName */:
-          return !isInComment(sourceFile, position);
-        case 110 /* ThisKeyword */:
-        case 196 /* ThisType */:
-        case 108 /* SuperKeyword */:
-        case 201 /* NamedTupleMember */:
-          return true;
-        case 235 /* MetaProperty */:
-          return isImportMeta(node);
-        default:
-          return false;
-      }
-    }
-    function getDefinitionAtPosition2(fileName, position, searchOtherFilesOnly, stopAtAlias) {
-      synchronizeHostData();
-      return ts_GoToDefinition_exports.getDefinitionAtPosition(program, getValidSourceFile(fileName), position, searchOtherFilesOnly, stopAtAlias);
-    }
-    function getDefinitionAndBoundSpan2(fileName, position) {
-      synchronizeHostData();
-      return ts_GoToDefinition_exports.getDefinitionAndBoundSpan(program, getValidSourceFile(fileName), position);
-    }
-    function getTypeDefinitionAtPosition2(fileName, position) {
-      synchronizeHostData();
-      return ts_GoToDefinition_exports.getTypeDefinitionAtPosition(program.getTypeChecker(), getValidSourceFile(fileName), position);
-    }
-    function getImplementationAtPosition(fileName, position) {
-      synchronizeHostData();
-      return ts_FindAllReferences_exports.getImplementationsAtPosition(program, cancellationToken, program.getSourceFiles(), getValidSourceFile(fileName), position);
-    }
-    function getDocumentHighlights(fileName, position, filesToSearch) {
-      const normalizedFileName = normalizePath(fileName);
-      Debug.assert(filesToSearch.some((f) => normalizePath(f) === normalizedFileName));
-      synchronizeHostData();
-      const sourceFilesToSearch = mapDefined(filesToSearch, (fileName2) => program.getSourceFile(fileName2));
-      const sourceFile = getValidSourceFile(fileName);
-      return DocumentHighlights.getDocumentHighlights(program, cancellationToken, sourceFile, position, sourceFilesToSearch);
-    }
-    function findRenameLocations(fileName, position, findInStrings, findInComments, preferences) {
-      synchronizeHostData();
-      const sourceFile = getValidSourceFile(fileName);
-      const node = getAdjustedRenameLocation(getTouchingPropertyName(sourceFile, position));
-      if (!ts_Rename_exports.nodeIsEligibleForRename(node))
-        return void 0;
-      if (isIdentifier(node) && (isJsxOpeningElement(node.parent) || isJsxClosingElement(node.parent)) && isIntrinsicJsxName(node.escapedText)) {
-        const { openingElement, closingElement } = node.parent.parent;
-        return [openingElement, closingElement].map((node2) => {
-          const textSpan = createTextSpanFromNode(node2.tagName, sourceFile);
-          return {
-            fileName: sourceFile.fileName,
-            textSpan,
-            ...ts_FindAllReferences_exports.toContextSpan(textSpan, sourceFile, node2.parent)
-          };
-        });
-      } else {
-        const quotePreference = getQuotePreference(sourceFile, preferences ?? emptyOptions);
-        const providePrefixAndSuffixTextForRename = typeof preferences === "boolean" ? preferences : preferences == null ? void 0 : preferences.providePrefixAndSuffixTextForRename;
-        return getReferencesWorker(
-          node,
-          position,
-          { findInStrings, findInComments, providePrefixAndSuffixTextForRename, use: ts_FindAllReferences_exports.FindReferencesUse.Rename },
-          (entry, originalNode, checker) => ts_FindAllReferences_exports.toRenameLocation(entry, originalNode, checker, providePrefixAndSuffixTextForRename || false, quotePreference)
-        );
-      }
-    }
-    function getReferencesAtPosition(fileName, position) {
-      synchronizeHostData();
-      return getReferencesWorker(getTouchingPropertyName(getValidSourceFile(fileName), position), position, { use: ts_FindAllReferences_exports.FindReferencesUse.References }, ts_FindAllReferences_exports.toReferenceEntry);
-    }
-    function getReferencesWorker(node, position, options, cb) {
-      synchronizeHostData();
-      const sourceFiles = options && options.use === ts_FindAllReferences_exports.FindReferencesUse.Rename ? program.getSourceFiles().filter((sourceFile) => !program.isSourceFileDefaultLibrary(sourceFile)) : program.getSourceFiles();
-      return ts_FindAllReferences_exports.findReferenceOrRenameEntries(program, cancellationToken, sourceFiles, node, position, options, cb);
-    }
-    function findReferences(fileName, position) {
-      synchronizeHostData();
-      return ts_FindAllReferences_exports.findReferencedSymbols(program, cancellationToken, program.getSourceFiles(), getValidSourceFile(fileName), position);
-    }
-    function getFileReferences(fileName) {
-      synchronizeHostData();
-      return ts_FindAllReferences_exports.Core.getReferencesForFileName(fileName, program, program.getSourceFiles()).map(ts_FindAllReferences_exports.toReferenceEntry);
-    }
-    function getNavigateToItems2(searchValue, maxResultCount, fileName, excludeDtsFiles = false) {
-      synchronizeHostData();
-      const sourceFiles = fileName ? [getValidSourceFile(fileName)] : program.getSourceFiles();
-      return getNavigateToItems(sourceFiles, program.getTypeChecker(), cancellationToken, searchValue, maxResultCount, excludeDtsFiles);
-    }
-    function getEmitOutput(fileName, emitOnlyDtsFiles, forceDtsEmit) {
-      synchronizeHostData();
-      const sourceFile = getValidSourceFile(fileName);
-      const customTransformers = host.getCustomTransformers && host.getCustomTransformers();
-      return getFileEmitOutput(program, sourceFile, !!emitOnlyDtsFiles, cancellationToken, customTransformers, forceDtsEmit);
-    }
-    function getSignatureHelpItems2(fileName, position, { triggerReason } = emptyOptions) {
-      synchronizeHostData();
-      const sourceFile = getValidSourceFile(fileName);
-      return ts_SignatureHelp_exports.getSignatureHelpItems(program, sourceFile, position, triggerReason, cancellationToken);
-    }
-    function getNonBoundSourceFile(fileName) {
-      return syntaxTreeCache.getCurrentSourceFile(fileName);
-    }
-    function getNameOrDottedNameSpan(fileName, startPos, _endPos) {
-      const sourceFile = syntaxTreeCache.getCurrentSourceFile(fileName);
-      const node = getTouchingPropertyName(sourceFile, startPos);
-      if (node === sourceFile) {
-        return void 0;
-      }
-      switch (node.kind) {
-        case 210 /* PropertyAccessExpression */:
-        case 165 /* QualifiedName */:
-        case 11 /* StringLiteral */:
-        case 97 /* FalseKeyword */:
-        case 112 /* TrueKeyword */:
-        case 106 /* NullKeyword */:
-        case 108 /* SuperKeyword */:
-        case 110 /* ThisKeyword */:
-        case 196 /* ThisType */:
-        case 80 /* Identifier */:
-          break;
-        default:
-          return void 0;
-      }
-      let nodeForStartPos = node;
-      while (true) {
-        if (isRightSideOfPropertyAccess(nodeForStartPos) || isRightSideOfQualifiedName(nodeForStartPos)) {
-          nodeForStartPos = nodeForStartPos.parent;
-        } else if (isNameOfModuleDeclaration(nodeForStartPos)) {
-          if (nodeForStartPos.parent.parent.kind === 266 /* ModuleDeclaration */ && nodeForStartPos.parent.parent.body === nodeForStartPos.parent) {
-            nodeForStartPos = nodeForStartPos.parent.parent.name;
-          } else {
-            break;
-          }
-        } else {
-          break;
-        }
-      }
-      return createTextSpanFromBounds(nodeForStartPos.getStart(), node.getEnd());
-    }
-    function getBreakpointStatementAtPosition(fileName, position) {
-      const sourceFile = syntaxTreeCache.getCurrentSourceFile(fileName);
-      return ts_BreakpointResolver_exports.spanInSourceFileAtLocation(sourceFile, position);
-    }
-    function getNavigationBarItems2(fileName) {
-      return getNavigationBarItems(syntaxTreeCache.getCurrentSourceFile(fileName), cancellationToken);
-    }
-    function getNavigationTree2(fileName) {
-      return getNavigationTree(syntaxTreeCache.getCurrentSourceFile(fileName), cancellationToken);
-    }
-    function getSemanticClassifications3(fileName, span, format) {
-      synchronizeHostData();
-      const responseFormat = format || "original" /* Original */;
-      if (responseFormat === "2020" /* TwentyTwenty */) {
-        return getSemanticClassifications2(program, cancellationToken, getValidSourceFile(fileName), span);
-      } else {
-        return getSemanticClassifications(program.getTypeChecker(), cancellationToken, getValidSourceFile(fileName), program.getClassifiableNames(), span);
-      }
-    }
-    function getEncodedSemanticClassifications3(fileName, span, format) {
-      synchronizeHostData();
-      const responseFormat = format || "original" /* Original */;
-      if (responseFormat === "original" /* Original */) {
-        return getEncodedSemanticClassifications(program.getTypeChecker(), cancellationToken, getValidSourceFile(fileName), program.getClassifiableNames(), span);
-      } else {
-        return getEncodedSemanticClassifications2(program, cancellationToken, getValidSourceFile(fileName), span);
-      }
-    }
-    function getSyntacticClassifications2(fileName, span) {
-      return getSyntacticClassifications(cancellationToken, syntaxTreeCache.getCurrentSourceFile(fileName), span);
-    }
-    function getEncodedSyntacticClassifications2(fileName, span) {
-      return getEncodedSyntacticClassifications(cancellationToken, syntaxTreeCache.getCurrentSourceFile(fileName), span);
-    }
-    function getOutliningSpans(fileName) {
-      const sourceFile = syntaxTreeCache.getCurrentSourceFile(fileName);
-      return ts_OutliningElementsCollector_exports.collectElements(sourceFile, cancellationToken);
-    }
-    const braceMatching = new Map(Object.entries({
-      [19 /* OpenBraceToken */]: 20 /* CloseBraceToken */,
-      [21 /* OpenParenToken */]: 22 /* CloseParenToken */,
-      [23 /* OpenBracketToken */]: 24 /* CloseBracketToken */,
-      [32 /* GreaterThanToken */]: 30 /* LessThanToken */
-    }));
-    braceMatching.forEach((value, key) => braceMatching.set(value.toString(), Number(key)));
-    function getBraceMatchingAtPosition(fileName, position) {
-      const sourceFile = syntaxTreeCache.getCurrentSourceFile(fileName);
-      const token = getTouchingToken(sourceFile, position);
-      const matchKind = token.getStart(sourceFile) === position ? braceMatching.get(token.kind.toString()) : void 0;
-      const match = matchKind && findChildOfKind(token.parent, matchKind, sourceFile);
-      return match ? [createTextSpanFromNode(token, sourceFile), createTextSpanFromNode(match, sourceFile)].sort((a, b) => a.start - b.start) : emptyArray;
-    }
-    function getIndentationAtPosition(fileName, position, editorOptions) {
-      let start = timestamp();
-      const settings = toEditorSettings(editorOptions);
-      const sourceFile = syntaxTreeCache.getCurrentSourceFile(fileName);
-      log("getIndentationAtPosition: getCurrentSourceFile: " + (timestamp() - start));
-      start = timestamp();
-      const result = ts_formatting_exports.SmartIndenter.getIndentation(position, sourceFile, settings);
-      log("getIndentationAtPosition: computeIndentation  : " + (timestamp() - start));
-      return result;
-    }
-    function getFormattingEditsForRange(fileName, start, end, options) {
-      const sourceFile = syntaxTreeCache.getCurrentSourceFile(fileName);
-      return ts_formatting_exports.formatSelection(start, end, sourceFile, ts_formatting_exports.getFormatContext(toEditorSettings(options), host));
-    }
-    function getFormattingEditsForDocument(fileName, options) {
-      return ts_formatting_exports.formatDocument(syntaxTreeCache.getCurrentSourceFile(fileName), ts_formatting_exports.getFormatContext(toEditorSettings(options), host));
-    }
-    function getFormattingEditsAfterKeystroke(fileName, position, key, options) {
-      const sourceFile = syntaxTreeCache.getCurrentSourceFile(fileName);
-      const formatContext = ts_formatting_exports.getFormatContext(toEditorSettings(options), host);
-      if (!isInComment(sourceFile, position)) {
-        switch (key) {
-          case "{":
-            return ts_formatting_exports.formatOnOpeningCurly(position, sourceFile, formatContext);
-          case "}":
-            return ts_formatting_exports.formatOnClosingCurly(position, sourceFile, formatContext);
-          case ";":
-            return ts_formatting_exports.formatOnSemicolon(position, sourceFile, formatContext);
-          case "\n":
-            return ts_formatting_exports.formatOnEnter(position, sourceFile, formatContext);
-        }
-      }
-      return [];
-    }
-    function getCodeFixesAtPosition(fileName, start, end, errorCodes64, formatOptions, preferences = emptyOptions) {
-      synchronizeHostData();
-      const sourceFile = getValidSourceFile(fileName);
-      const span = createTextSpanFromBounds(start, end);
-      const formatContext = ts_formatting_exports.getFormatContext(formatOptions, host);
-      return flatMap(deduplicate(errorCodes64, equateValues, compareValues), (errorCode) => {
-        cancellationToken.throwIfCancellationRequested();
-        return ts_codefix_exports.getFixes({ errorCode, sourceFile, span, program, host, cancellationToken, formatContext, preferences });
-      });
-    }
-    function getCombinedCodeFix(scope, fixId52, formatOptions, preferences = emptyOptions) {
-      synchronizeHostData();
-      Debug.assert(scope.type === "file");
-      const sourceFile = getValidSourceFile(scope.fileName);
-      const formatContext = ts_formatting_exports.getFormatContext(formatOptions, host);
-      return ts_codefix_exports.getAllFixes({ fixId: fixId52, sourceFile, program, host, cancellationToken, formatContext, preferences });
-    }
-    function organizeImports2(args, formatOptions, preferences = emptyOptions) {
-      synchronizeHostData();
-      Debug.assert(args.type === "file");
-      const sourceFile = getValidSourceFile(args.fileName);
-      const formatContext = ts_formatting_exports.getFormatContext(formatOptions, host);
-      const mode = args.mode ?? (args.skipDestructiveCodeActions ? "SortAndCombine" /* SortAndCombine */ : "All" /* All */);
-      return ts_OrganizeImports_exports.organizeImports(sourceFile, formatContext, host, program, preferences, mode);
-    }
-    function getEditsForFileRename2(oldFilePath, newFilePath, formatOptions, preferences = emptyOptions) {
-      return getEditsForFileRename(getProgram(), oldFilePath, newFilePath, host, ts_formatting_exports.getFormatContext(formatOptions, host), preferences, sourceMapper);
-    }
-    function applyCodeActionCommand(fileName, actionOrFormatSettingsOrUndefined) {
-      const action = typeof fileName === "string" ? actionOrFormatSettingsOrUndefined : fileName;
-      return isArray(action) ? Promise.all(action.map((a) => applySingleCodeActionCommand(a))) : applySingleCodeActionCommand(action);
-    }
-    function applySingleCodeActionCommand(action) {
-      const getPath = (path) => toPath(path, currentDirectory, getCanonicalFileName);
-      Debug.assertEqual(action.type, "install package");
-      return host.installPackage ? host.installPackage({ fileName: getPath(action.file), packageName: action.packageName }) : Promise.reject("Host does not implement `installPackage`");
-    }
-    function getDocCommentTemplateAtPosition2(fileName, position, options, formatOptions) {
-      const formatSettings = formatOptions ? ts_formatting_exports.getFormatContext(formatOptions, host).options : void 0;
-      return ts_JsDoc_exports.getDocCommentTemplateAtPosition(getNewLineOrDefaultFromHost(host, formatSettings), syntaxTreeCache.getCurrentSourceFile(fileName), position, options);
-    }
-    function isValidBraceCompletionAtPosition(fileName, position, openingBrace) {
-      if (openingBrace === 60 /* lessThan */) {
-        return false;
-      }
-      const sourceFile = syntaxTreeCache.getCurrentSourceFile(fileName);
-      if (isInString(sourceFile, position)) {
-        return false;
-      }
-      if (isInsideJsxElementOrAttribute(sourceFile, position)) {
-        return openingBrace === 123 /* openBrace */;
-      }
-      if (isInTemplateString(sourceFile, position)) {
-        return false;
-      }
-      switch (openingBrace) {
-        case 39 /* singleQuote */:
-        case 34 /* doubleQuote */:
-        case 96 /* backtick */:
-          return !isInComment(sourceFile, position);
-      }
-      return true;
-    }
-    function getJsxClosingTagAtPosition(fileName, position) {
-      const sourceFile = syntaxTreeCache.getCurrentSourceFile(fileName);
-      const token = findPrecedingToken(position, sourceFile);
-      if (!token)
-        return void 0;
-      const element = token.kind === 32 /* GreaterThanToken */ && isJsxOpeningElement(token.parent) ? token.parent.parent : isJsxText(token) && isJsxElement(token.parent) ? token.parent : void 0;
-      if (element && isUnclosedTag(element)) {
-        return { newText: `` };
-      }
-      const fragment = token.kind === 32 /* GreaterThanToken */ && isJsxOpeningFragment(token.parent) ? token.parent.parent : isJsxText(token) && isJsxFragment(token.parent) ? token.parent : void 0;
-      if (fragment && isUnclosedFragment(fragment)) {
-        return { newText: "" };
-      }
-    }
-    function getLinkedEditingRangeAtPosition(fileName, position) {
-      const sourceFile = syntaxTreeCache.getCurrentSourceFile(fileName);
-      const token = findPrecedingToken(position, sourceFile);
-      if (!token || token.parent.kind === 311 /* SourceFile */)
-        return void 0;
-      const jsxTagWordPattern = "[a-zA-Z0-9:\\-\\._$]*";
-      if (isJsxFragment(token.parent.parent)) {
-        const openFragment = token.parent.parent.openingFragment;
-        const closeFragment = token.parent.parent.closingFragment;
-        if (containsParseError(openFragment) || containsParseError(closeFragment))
-          return void 0;
-        const openPos = openFragment.getStart(sourceFile) + 1;
-        const closePos = closeFragment.getStart(sourceFile) + 2;
-        if (position !== openPos && position !== closePos)
-          return void 0;
-        return {
-          ranges: [{ start: openPos, length: 0 }, { start: closePos, length: 0 }],
-          wordPattern: jsxTagWordPattern
-        };
-      } else {
-        const tag = findAncestor(
-          token.parent,
-          (n) => {
-            if (isJsxOpeningElement(n) || isJsxClosingElement(n)) {
-              return true;
-            }
-            return false;
-          }
-        );
-        if (!tag)
-          return void 0;
-        Debug.assert(isJsxOpeningElement(tag) || isJsxClosingElement(tag), "tag should be opening or closing element");
-        const openTag = tag.parent.openingElement;
-        const closeTag = tag.parent.closingElement;
-        const openTagStart = openTag.tagName.getStart(sourceFile);
-        const openTagEnd = openTag.tagName.end;
-        const closeTagStart = closeTag.tagName.getStart(sourceFile);
-        const closeTagEnd = closeTag.tagName.end;
-        if (!(openTagStart <= position && position <= openTagEnd || closeTagStart <= position && position <= closeTagEnd))
-          return void 0;
-        const openingTagText = openTag.tagName.getText(sourceFile);
-        if (openingTagText !== closeTag.tagName.getText(sourceFile))
-          return void 0;
-        return {
-          ranges: [{ start: openTagStart, length: openTagEnd - openTagStart }, { start: closeTagStart, length: closeTagEnd - closeTagStart }],
-          wordPattern: jsxTagWordPattern
-        };
-      }
-    }
-    function getLinesForRange(sourceFile, textRange) {
-      return {
-        lineStarts: sourceFile.getLineStarts(),
-        firstLine: sourceFile.getLineAndCharacterOfPosition(textRange.pos).line,
-        lastLine: sourceFile.getLineAndCharacterOfPosition(textRange.end).line
-      };
-    }
-    function toggleLineComment(fileName, textRange, insertComment) {
-      const sourceFile = syntaxTreeCache.getCurrentSourceFile(fileName);
-      const textChanges2 = [];
-      const { lineStarts, firstLine, lastLine } = getLinesForRange(sourceFile, textRange);
-      let isCommenting = insertComment || false;
-      let leftMostPosition = Number.MAX_VALUE;
-      const lineTextStarts = /* @__PURE__ */ new Map();
-      const firstNonWhitespaceCharacterRegex = new RegExp(/\S/);
-      const isJsx = isInsideJsxElement(sourceFile, lineStarts[firstLine]);
-      const openComment = isJsx ? "{/*" : "//";
-      for (let i = firstLine; i <= lastLine; i++) {
-        const lineText = sourceFile.text.substring(lineStarts[i], sourceFile.getLineEndOfPosition(lineStarts[i]));
-        const regExec = firstNonWhitespaceCharacterRegex.exec(lineText);
-        if (regExec) {
-          leftMostPosition = Math.min(leftMostPosition, regExec.index);
-          lineTextStarts.set(i.toString(), regExec.index);
-          if (lineText.substr(regExec.index, openComment.length) !== openComment) {
-            isCommenting = insertComment === void 0 || insertComment;
-          }
-        }
-      }
-      for (let i = firstLine; i <= lastLine; i++) {
-        if (firstLine !== lastLine && lineStarts[i] === textRange.end) {
-          continue;
-        }
-        const lineTextStart = lineTextStarts.get(i.toString());
-        if (lineTextStart !== void 0) {
-          if (isJsx) {
-            textChanges2.push.apply(textChanges2, toggleMultilineComment(fileName, { pos: lineStarts[i] + leftMostPosition, end: sourceFile.getLineEndOfPosition(lineStarts[i]) }, isCommenting, isJsx));
-          } else if (isCommenting) {
-            textChanges2.push({
-              newText: openComment,
-              span: {
-                length: 0,
-                start: lineStarts[i] + leftMostPosition
-              }
-            });
-          } else if (sourceFile.text.substr(lineStarts[i] + lineTextStart, openComment.length) === openComment) {
-            textChanges2.push({
-              newText: "",
-              span: {
-                length: openComment.length,
-                start: lineStarts[i] + lineTextStart
-              }
-            });
-          }
-        }
-      }
-      return textChanges2;
-    }
-    function toggleMultilineComment(fileName, textRange, insertComment, isInsideJsx) {
-      var _a2;
-      const sourceFile = syntaxTreeCache.getCurrentSourceFile(fileName);
-      const textChanges2 = [];
-      const { text } = sourceFile;
-      let hasComment = false;
-      let isCommenting = insertComment || false;
-      const positions = [];
-      let { pos } = textRange;
-      const isJsx = isInsideJsx !== void 0 ? isInsideJsx : isInsideJsxElement(sourceFile, pos);
-      const openMultiline = isJsx ? "{/*" : "/*";
-      const closeMultiline = isJsx ? "*/}" : "*/";
-      const openMultilineRegex = isJsx ? "\\{\\/\\*" : "\\/\\*";
-      const closeMultilineRegex = isJsx ? "\\*\\/\\}" : "\\*\\/";
-      while (pos <= textRange.end) {
-        const offset = text.substr(pos, openMultiline.length) === openMultiline ? openMultiline.length : 0;
-        const commentRange = isInComment(sourceFile, pos + offset);
-        if (commentRange) {
-          if (isJsx) {
-            commentRange.pos--;
-            commentRange.end++;
-          }
-          positions.push(commentRange.pos);
-          if (commentRange.kind === 3 /* MultiLineCommentTrivia */) {
-            positions.push(commentRange.end);
-          }
-          hasComment = true;
-          pos = commentRange.end + 1;
-        } else {
-          const newPos = text.substring(pos, textRange.end).search(`(${openMultilineRegex})|(${closeMultilineRegex})`);
-          isCommenting = insertComment !== void 0 ? insertComment : isCommenting || !isTextWhiteSpaceLike(text, pos, newPos === -1 ? textRange.end : pos + newPos);
-          pos = newPos === -1 ? textRange.end + 1 : pos + newPos + closeMultiline.length;
-        }
-      }
-      if (isCommenting || !hasComment) {
-        if (((_a2 = isInComment(sourceFile, textRange.pos)) == null ? void 0 : _a2.kind) !== 2 /* SingleLineCommentTrivia */) {
-          insertSorted(positions, textRange.pos, compareValues);
-        }
-        insertSorted(positions, textRange.end, compareValues);
-        const firstPos = positions[0];
-        if (text.substr(firstPos, openMultiline.length) !== openMultiline) {
-          textChanges2.push({
-            newText: openMultiline,
-            span: {
-              length: 0,
-              start: firstPos
-            }
-          });
-        }
-        for (let i = 1; i < positions.length - 1; i++) {
-          if (text.substr(positions[i] - closeMultiline.length, closeMultiline.length) !== closeMultiline) {
-            textChanges2.push({
-              newText: closeMultiline,
-              span: {
-                length: 0,
-                start: positions[i]
-              }
-            });
-          }
-          if (text.substr(positions[i], openMultiline.length) !== openMultiline) {
-            textChanges2.push({
-              newText: openMultiline,
-              span: {
-                length: 0,
-                start: positions[i]
-              }
-            });
-          }
-        }
-        if (textChanges2.length % 2 !== 0) {
-          textChanges2.push({
-            newText: closeMultiline,
-            span: {
-              length: 0,
-              start: positions[positions.length - 1]
-            }
-          });
-        }
-      } else {
-        for (const pos2 of positions) {
-          const from = pos2 - closeMultiline.length > 0 ? pos2 - closeMultiline.length : 0;
-          const offset = text.substr(from, closeMultiline.length) === closeMultiline ? closeMultiline.length : 0;
-          textChanges2.push({
-            newText: "",
-            span: {
-              length: openMultiline.length,
-              start: pos2 - offset
-            }
-          });
-        }
-      }
-      return textChanges2;
-    }
-    function commentSelection(fileName, textRange) {
-      const sourceFile = syntaxTreeCache.getCurrentSourceFile(fileName);
-      const { firstLine, lastLine } = getLinesForRange(sourceFile, textRange);
-      return firstLine === lastLine && textRange.pos !== textRange.end ? toggleMultilineComment(
-        fileName,
-        textRange,
-        /*insertComment*/
-        true
-      ) : toggleLineComment(
-        fileName,
-        textRange,
-        /*insertComment*/
-        true
-      );
-    }
-    function uncommentSelection(fileName, textRange) {
-      const sourceFile = syntaxTreeCache.getCurrentSourceFile(fileName);
-      const textChanges2 = [];
-      const { pos } = textRange;
-      let { end } = textRange;
-      if (pos === end) {
-        end += isInsideJsxElement(sourceFile, pos) ? 2 : 1;
-      }
-      for (let i = pos; i <= end; i++) {
-        const commentRange = isInComment(sourceFile, i);
-        if (commentRange) {
-          switch (commentRange.kind) {
-            case 2 /* SingleLineCommentTrivia */:
-              textChanges2.push.apply(textChanges2, toggleLineComment(
-                fileName,
-                { end: commentRange.end, pos: commentRange.pos + 1 },
-                /*insertComment*/
-                false
-              ));
-              break;
-            case 3 /* MultiLineCommentTrivia */:
-              textChanges2.push.apply(textChanges2, toggleMultilineComment(
-                fileName,
-                { end: commentRange.end, pos: commentRange.pos + 1 },
-                /*insertComment*/
-                false
-              ));
-          }
-          i = commentRange.end + 1;
-        }
-      }
-      return textChanges2;
-    }
-    function isUnclosedTag({ openingElement, closingElement, parent: parent2 }) {
-      return !tagNamesAreEquivalent(openingElement.tagName, closingElement.tagName) || isJsxElement(parent2) && tagNamesAreEquivalent(openingElement.tagName, parent2.openingElement.tagName) && isUnclosedTag(parent2);
-    }
-    function isUnclosedFragment({ closingFragment, parent: parent2 }) {
-      return !!(closingFragment.flags & 131072 /* ThisNodeHasError */) || isJsxFragment(parent2) && isUnclosedFragment(parent2);
-    }
-    function getSpanOfEnclosingComment(fileName, position, onlyMultiLine) {
-      const sourceFile = syntaxTreeCache.getCurrentSourceFile(fileName);
-      const range = ts_formatting_exports.getRangeOfEnclosingComment(sourceFile, position);
-      return range && (!onlyMultiLine || range.kind === 3 /* MultiLineCommentTrivia */) ? createTextSpanFromRange(range) : void 0;
-    }
-    function getTodoComments(fileName, descriptors) {
-      synchronizeHostData();
-      const sourceFile = getValidSourceFile(fileName);
-      cancellationToken.throwIfCancellationRequested();
-      const fileContents = sourceFile.text;
-      const result = [];
-      if (descriptors.length > 0 && !isNodeModulesFile(sourceFile.fileName)) {
-        const regExp = getTodoCommentsRegExp();
-        let matchArray;
-        while (matchArray = regExp.exec(fileContents)) {
-          cancellationToken.throwIfCancellationRequested();
-          const firstDescriptorCaptureIndex = 3;
-          Debug.assert(matchArray.length === descriptors.length + firstDescriptorCaptureIndex);
-          const preamble = matchArray[1];
-          const matchPosition = matchArray.index + preamble.length;
-          if (!isInComment(sourceFile, matchPosition)) {
-            continue;
-          }
-          let descriptor;
-          for (let i = 0; i < descriptors.length; i++) {
-            if (matchArray[i + firstDescriptorCaptureIndex]) {
-              descriptor = descriptors[i];
-            }
-          }
-          if (descriptor === void 0)
-            return Debug.fail();
-          if (isLetterOrDigit(fileContents.charCodeAt(matchPosition + descriptor.text.length))) {
-            continue;
-          }
-          const message = matchArray[2];
-          result.push({ descriptor, message, position: matchPosition });
-        }
-      }
-      return result;
-      function escapeRegExp(str) {
-        return str.replace(/[\-\[\]\/\{\}\(\)\*\+\?\.\\\^\$\|]/g, "\\$&");
-      }
-      function getTodoCommentsRegExp() {
-        const singleLineCommentStart = /(?:\/\/+\s*)/.source;
-        const multiLineCommentStart = /(?:\/\*+\s*)/.source;
-        const anyNumberOfSpacesAndAsterisksAtStartOfLine = /(?:^(?:\s|\*)*)/.source;
-        const preamble = "(" + anyNumberOfSpacesAndAsterisksAtStartOfLine + "|" + singleLineCommentStart + "|" + multiLineCommentStart + ")";
-        const literals = "(?:" + map(descriptors, (d) => "(" + escapeRegExp(d.text) + ")").join("|") + ")";
-        const endOfLineOrEndOfComment = /(?:$|\*\/)/.source;
-        const messageRemainder = /(?:.*?)/.source;
-        const messagePortion = "(" + literals + messageRemainder + ")";
-        const regExpString = preamble + messagePortion + endOfLineOrEndOfComment;
-        return new RegExp(regExpString, "gim");
-      }
-      function isLetterOrDigit(char) {
-        return char >= 97 /* a */ && char <= 122 /* z */ || char >= 65 /* A */ && char <= 90 /* Z */ || char >= 48 /* _0 */ && char <= 57 /* _9 */;
-      }
-      function isNodeModulesFile(path) {
-        return stringContains(path, "/node_modules/");
-      }
-    }
-    function getRenameInfo2(fileName, position, preferences) {
-      synchronizeHostData();
-      return ts_Rename_exports.getRenameInfo(program, getValidSourceFile(fileName), position, preferences || {});
-    }
-    function getRefactorContext(file, positionOrRange, preferences, formatOptions, triggerReason, kind) {
-      const [startPosition, endPosition] = typeof positionOrRange === "number" ? [positionOrRange, void 0] : [positionOrRange.pos, positionOrRange.end];
-      return {
-        file,
-        startPosition,
-        endPosition,
-        program: getProgram(),
-        host,
-        formatContext: ts_formatting_exports.getFormatContext(formatOptions, host),
-        // TODO: GH#18217
-        cancellationToken,
-        preferences,
-        triggerReason,
-        kind
-      };
-    }
-    function getInlayHintsContext(file, span, preferences) {
-      return {
-        file,
-        program: getProgram(),
-        host,
-        span,
-        preferences,
-        cancellationToken
-      };
-    }
-    function getSmartSelectionRange2(fileName, position) {
-      return ts_SmartSelectionRange_exports.getSmartSelectionRange(position, syntaxTreeCache.getCurrentSourceFile(fileName));
-    }
-    function getApplicableRefactors2(fileName, positionOrRange, preferences = emptyOptions, triggerReason, kind, includeInteractiveActions) {
-      synchronizeHostData();
-      const file = getValidSourceFile(fileName);
-      return ts_refactor_exports.getApplicableRefactors(getRefactorContext(file, positionOrRange, preferences, emptyOptions, triggerReason, kind), includeInteractiveActions);
-    }
-    function getMoveToRefactoringFileSuggestions(fileName, positionOrRange, preferences = emptyOptions) {
-      synchronizeHostData();
-      const sourceFile = getValidSourceFile(fileName);
-      const allFiles = Debug.checkDefined(program.getSourceFiles());
-      const extension = extensionFromPath(fileName);
-      const files = mapDefined(allFiles, (file) => !(program == null ? void 0 : program.isSourceFileFromExternalLibrary(sourceFile)) && !(sourceFile === getValidSourceFile(file.fileName) || extension === ".ts" /* Ts */ && extensionFromPath(file.fileName) === ".d.ts" /* Dts */ || extension === ".d.ts" /* Dts */ && startsWith(getBaseFileName(file.fileName), "lib.") && extensionFromPath(file.fileName) === ".d.ts" /* Dts */) && extension === extensionFromPath(file.fileName) ? file.fileName : void 0);
-      const newFileName = createNewFileName(sourceFile, program, getRefactorContext(sourceFile, positionOrRange, preferences, emptyOptions), host);
-      return { newFileName, files };
-    }
-    function getEditsForRefactor2(fileName, formatOptions, positionOrRange, refactorName13, actionName2, preferences = emptyOptions, interactiveRefactorArguments) {
-      synchronizeHostData();
-      const file = getValidSourceFile(fileName);
-      return ts_refactor_exports.getEditsForRefactor(getRefactorContext(file, positionOrRange, preferences, formatOptions), refactorName13, actionName2, interactiveRefactorArguments);
-    }
-    function toLineColumnOffset(fileName, position) {
-      if (position === 0) {
-        return { line: 0, character: 0 };
-      }
-      return sourceMapper.toLineColumnOffset(fileName, position);
-    }
-    function prepareCallHierarchy(fileName, position) {
-      synchronizeHostData();
-      const declarations = ts_CallHierarchy_exports.resolveCallHierarchyDeclaration(program, getTouchingPropertyName(getValidSourceFile(fileName), position));
-      return declarations && mapOneOrMany(declarations, (declaration) => ts_CallHierarchy_exports.createCallHierarchyItem(program, declaration));
-    }
-    function provideCallHierarchyIncomingCalls(fileName, position) {
-      synchronizeHostData();
-      const sourceFile = getValidSourceFile(fileName);
-      const declaration = firstOrOnly(ts_CallHierarchy_exports.resolveCallHierarchyDeclaration(program, position === 0 ? sourceFile : getTouchingPropertyName(sourceFile, position)));
-      return declaration ? ts_CallHierarchy_exports.getIncomingCalls(program, declaration, cancellationToken) : [];
-    }
-    function provideCallHierarchyOutgoingCalls(fileName, position) {
-      synchronizeHostData();
-      const sourceFile = getValidSourceFile(fileName);
-      const declaration = firstOrOnly(ts_CallHierarchy_exports.resolveCallHierarchyDeclaration(program, position === 0 ? sourceFile : getTouchingPropertyName(sourceFile, position)));
-      return declaration ? ts_CallHierarchy_exports.getOutgoingCalls(program, declaration) : [];
-    }
-    function provideInlayHints2(fileName, span, preferences = emptyOptions) {
-      synchronizeHostData();
-      const sourceFile = getValidSourceFile(fileName);
-      return ts_InlayHints_exports.provideInlayHints(getInlayHintsContext(sourceFile, span, preferences));
-    }
-    const ls = {
-      dispose,
-      cleanupSemanticCache,
-      getSyntacticDiagnostics,
-      getSemanticDiagnostics,
-      getSuggestionDiagnostics,
-      getCompilerOptionsDiagnostics,
-      getSyntacticClassifications: getSyntacticClassifications2,
-      getSemanticClassifications: getSemanticClassifications3,
-      getEncodedSyntacticClassifications: getEncodedSyntacticClassifications2,
-      getEncodedSemanticClassifications: getEncodedSemanticClassifications3,
-      getCompletionsAtPosition: getCompletionsAtPosition2,
-      getCompletionEntryDetails: getCompletionEntryDetails2,
-      getCompletionEntrySymbol: getCompletionEntrySymbol2,
-      getSignatureHelpItems: getSignatureHelpItems2,
-      getQuickInfoAtPosition,
-      getDefinitionAtPosition: getDefinitionAtPosition2,
-      getDefinitionAndBoundSpan: getDefinitionAndBoundSpan2,
-      getImplementationAtPosition,
-      getTypeDefinitionAtPosition: getTypeDefinitionAtPosition2,
-      getReferencesAtPosition,
-      findReferences,
-      getFileReferences,
-      getDocumentHighlights,
-      getNameOrDottedNameSpan,
-      getBreakpointStatementAtPosition,
-      getNavigateToItems: getNavigateToItems2,
-      getRenameInfo: getRenameInfo2,
-      getSmartSelectionRange: getSmartSelectionRange2,
-      findRenameLocations,
-      getNavigationBarItems: getNavigationBarItems2,
-      getNavigationTree: getNavigationTree2,
-      getOutliningSpans,
-      getTodoComments,
-      getBraceMatchingAtPosition,
-      getIndentationAtPosition,
-      getFormattingEditsForRange,
-      getFormattingEditsForDocument,
-      getFormattingEditsAfterKeystroke,
-      getDocCommentTemplateAtPosition: getDocCommentTemplateAtPosition2,
-      isValidBraceCompletionAtPosition,
-      getJsxClosingTagAtPosition,
-      getLinkedEditingRangeAtPosition,
-      getSpanOfEnclosingComment,
-      getCodeFixesAtPosition,
-      getCombinedCodeFix,
-      applyCodeActionCommand,
-      organizeImports: organizeImports2,
-      getEditsForFileRename: getEditsForFileRename2,
-      getEmitOutput,
-      getNonBoundSourceFile,
-      getProgram,
-      getCurrentProgram: () => program,
-      getAutoImportProvider,
-      updateIsDefinitionOfReferencedSymbols,
-      getApplicableRefactors: getApplicableRefactors2,
-      getEditsForRefactor: getEditsForRefactor2,
-      getMoveToRefactoringFileSuggestions,
-      toLineColumnOffset,
-      getSourceMapper: () => sourceMapper,
-      clearSourceMapperCache: () => sourceMapper.clearCache(),
-      prepareCallHierarchy,
-      provideCallHierarchyIncomingCalls,
-      provideCallHierarchyOutgoingCalls,
-      toggleLineComment,
-      toggleMultilineComment,
-      commentSelection,
-      uncommentSelection,
-      provideInlayHints: provideInlayHints2,
-      getSupportedCodeFixes
-    };
-    switch (languageServiceMode) {
-      case 0 /* Semantic */:
-        break;
-      case 1 /* PartialSemantic */:
-        invalidOperationsInPartialSemanticMode.forEach(
-          (key) => ls[key] = () => {
-            throw new Error(`LanguageService Operation: ${key} not allowed in LanguageServiceMode.PartialSemantic`);
-          }
-        );
-        break;
-      case 2 /* Syntactic */:
-        invalidOperationsInSyntacticMode.forEach(
-          (key) => ls[key] = () => {
-            throw new Error(`LanguageService Operation: ${key} not allowed in LanguageServiceMode.Syntactic`);
-          }
-        );
-        break;
-      default:
-        Debug.assertNever(languageServiceMode);
-    }
-    return ls;
-  }
-  function getNameTable(sourceFile) {
-    if (!sourceFile.nameTable) {
-      initializeNameTable(sourceFile);
-    }
-    return sourceFile.nameTable;
-  }
-  function initializeNameTable(sourceFile) {
-    const nameTable = sourceFile.nameTable = /* @__PURE__ */ new Map();
-    sourceFile.forEachChild(function walk(node) {
-      if (isIdentifier(node) && !isTagName(node) && node.escapedText || isStringOrNumericLiteralLike(node) && literalIsName(node)) {
-        const text = getEscapedTextOfIdentifierOrLiteral(node);
-        nameTable.set(text, nameTable.get(text) === void 0 ? node.pos : -1);
-      } else if (isPrivateIdentifier(node)) {
-        const text = node.escapedText;
-        nameTable.set(text, nameTable.get(text) === void 0 ? node.pos : -1);
-      }
-      forEachChild(node, walk);
-      if (hasJSDocNodes(node)) {
-        for (const jsDoc of node.jsDoc) {
-          forEachChild(jsDoc, walk);
-        }
-      }
-    });
-  }
-  function literalIsName(node) {
-    return isDeclarationName(node) || node.parent.kind === 282 /* ExternalModuleReference */ || isArgumentOfElementAccessExpression(node) || isLiteralComputedPropertyDeclarationName(node);
-  }
-  function getContainingObjectLiteralElement(node) {
-    const element = getContainingObjectLiteralElementWorker(node);
-    return element && (isObjectLiteralExpression(element.parent) || isJsxAttributes(element.parent)) ? element : void 0;
-  }
-  function getContainingObjectLiteralElementWorker(node) {
-    switch (node.kind) {
-      case 11 /* StringLiteral */:
-      case 15 /* NoSubstitutionTemplateLiteral */:
-      case 9 /* NumericLiteral */:
-        if (node.parent.kind === 166 /* ComputedPropertyName */) {
-          return isObjectLiteralElement(node.parent.parent) ? node.parent.parent : void 0;
-        }
-      case 80 /* Identifier */:
-        return isObjectLiteralElement(node.parent) && (node.parent.parent.kind === 209 /* ObjectLiteralExpression */ || node.parent.parent.kind === 291 /* JsxAttributes */) && node.parent.name === node ? node.parent : void 0;
-    }
-    return void 0;
-  }
-  function getSymbolAtLocationForQuickInfo(node, checker) {
-    const object = getContainingObjectLiteralElement(node);
-    if (object) {
-      const contextualType = checker.getContextualType(object.parent);
-      const properties = contextualType && getPropertySymbolsFromContextualType(
-        object,
-        checker,
-        contextualType,
-        /*unionSymbolOk*/
-        false
-      );
-      if (properties && properties.length === 1) {
-        return first(properties);
-      }
-    }
-    return checker.getSymbolAtLocation(node);
-  }
-  function getPropertySymbolsFromContextualType(node, checker, contextualType, unionSymbolOk) {
-    const name = getNameFromPropertyName(node.name);
-    if (!name)
-      return emptyArray;
-    if (!contextualType.isUnion()) {
-      const symbol = contextualType.getProperty(name);
-      return symbol ? [symbol] : emptyArray;
-    }
-    const discriminatedPropertySymbols = mapDefined(contextualType.types, (t) => (isObjectLiteralExpression(node.parent) || isJsxAttributes(node.parent)) && checker.isTypeInvalidDueToUnionDiscriminant(t, node.parent) ? void 0 : t.getProperty(name));
-    if (unionSymbolOk && (discriminatedPropertySymbols.length === 0 || discriminatedPropertySymbols.length === contextualType.types.length)) {
-      const symbol = contextualType.getProperty(name);
-      if (symbol)
-        return [symbol];
-    }
-    if (discriminatedPropertySymbols.length === 0) {
-      return mapDefined(contextualType.types, (t) => t.getProperty(name));
-    }
-    return discriminatedPropertySymbols;
-  }
-  function isArgumentOfElementAccessExpression(node) {
-    return node && node.parent && node.parent.kind === 211 /* ElementAccessExpression */ && node.parent.argumentExpression === node;
-  }
-  function getDefaultLibFilePath(options) {
-    if (sys) {
-      return combinePaths(getDirectoryPath(normalizePath(sys.getExecutingFilePath())), getDefaultLibFileName(options));
-    }
-    throw new Error("getDefaultLibFilePath is only supported when consumed as a node module. ");
-  }
-  var servicesVersion, NodeObject, TokenOrIdentifierObject, SymbolObject, TokenObject, IdentifierObject, PrivateIdentifierObject, TypeObject, SignatureObject, SourceFileObject, SourceMapSourceObject, SyntaxTreeCache, NoopCancellationToken, CancellationTokenObject, ThrottledCancellationToken, invalidOperationsInPartialSemanticMode, invalidOperationsInSyntacticMode;
-  var init_services = __esm({
-    "src/services/services.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_NavigateTo();
-      init_ts_NavigationBar();
-      init_ts_refactor();
-      init_classifier();
-      init_classifier2020();
-      servicesVersion = "0.8";
-      NodeObject = class {
-        constructor(kind, pos, end) {
-          this.pos = pos;
-          this.end = end;
-          this.flags = 0 /* None */;
-          this.modifierFlagsCache = 0 /* None */;
-          this.transformFlags = 0 /* None */;
-          this.parent = void 0;
-          this.kind = kind;
-        }
-        assertHasRealPosition(message) {
-          Debug.assert(!positionIsSynthesized(this.pos) && !positionIsSynthesized(this.end), message || "Node must have a real position for this operation");
-        }
-        getSourceFile() {
-          return getSourceFileOfNode(this);
-        }
-        getStart(sourceFile, includeJsDocComment) {
-          this.assertHasRealPosition();
-          return getTokenPosOfNode(this, sourceFile, includeJsDocComment);
-        }
-        getFullStart() {
-          this.assertHasRealPosition();
-          return this.pos;
-        }
-        getEnd() {
-          this.assertHasRealPosition();
-          return this.end;
-        }
-        getWidth(sourceFile) {
-          this.assertHasRealPosition();
-          return this.getEnd() - this.getStart(sourceFile);
-        }
-        getFullWidth() {
-          this.assertHasRealPosition();
-          return this.end - this.pos;
-        }
-        getLeadingTriviaWidth(sourceFile) {
-          this.assertHasRealPosition();
-          return this.getStart(sourceFile) - this.pos;
-        }
-        getFullText(sourceFile) {
-          this.assertHasRealPosition();
-          return (sourceFile || this.getSourceFile()).text.substring(this.pos, this.end);
-        }
-        getText(sourceFile) {
-          this.assertHasRealPosition();
-          if (!sourceFile) {
-            sourceFile = this.getSourceFile();
-          }
-          return sourceFile.text.substring(this.getStart(sourceFile), this.getEnd());
-        }
-        getChildCount(sourceFile) {
-          return this.getChildren(sourceFile).length;
-        }
-        getChildAt(index, sourceFile) {
-          return this.getChildren(sourceFile)[index];
-        }
-        getChildren(sourceFile) {
-          this.assertHasRealPosition("Node without a real position cannot be scanned and thus has no token nodes - use forEachChild and collect the result if that's fine");
-          return this._children || (this._children = createChildren(this, sourceFile));
-        }
-        getFirstToken(sourceFile) {
-          this.assertHasRealPosition();
-          const children = this.getChildren(sourceFile);
-          if (!children.length) {
-            return void 0;
-          }
-          const child = find(children, (kid) => kid.kind < 315 /* FirstJSDocNode */ || kid.kind > 356 /* LastJSDocNode */);
-          return child.kind < 165 /* FirstNode */ ? child : child.getFirstToken(sourceFile);
-        }
-        getLastToken(sourceFile) {
-          this.assertHasRealPosition();
-          const children = this.getChildren(sourceFile);
-          const child = lastOrUndefined(children);
-          if (!child) {
-            return void 0;
-          }
-          return child.kind < 165 /* FirstNode */ ? child : child.getLastToken(sourceFile);
-        }
-        forEachChild(cbNode, cbNodeArray) {
-          return forEachChild(this, cbNode, cbNodeArray);
-        }
-      };
-      TokenOrIdentifierObject = class {
-        constructor(pos, end) {
-          this.pos = pos;
-          this.end = end;
-          this.flags = 0 /* None */;
-          this.modifierFlagsCache = 0 /* None */;
-          this.transformFlags = 0 /* None */;
-          this.parent = void 0;
-        }
-        getSourceFile() {
-          return getSourceFileOfNode(this);
-        }
-        getStart(sourceFile, includeJsDocComment) {
-          return getTokenPosOfNode(this, sourceFile, includeJsDocComment);
-        }
-        getFullStart() {
-          return this.pos;
-        }
-        getEnd() {
-          return this.end;
-        }
-        getWidth(sourceFile) {
-          return this.getEnd() - this.getStart(sourceFile);
-        }
-        getFullWidth() {
-          return this.end - this.pos;
-        }
-        getLeadingTriviaWidth(sourceFile) {
-          return this.getStart(sourceFile) - this.pos;
-        }
-        getFullText(sourceFile) {
-          return (sourceFile || this.getSourceFile()).text.substring(this.pos, this.end);
-        }
-        getText(sourceFile) {
-          if (!sourceFile) {
-            sourceFile = this.getSourceFile();
-          }
-          return sourceFile.text.substring(this.getStart(sourceFile), this.getEnd());
-        }
-        getChildCount() {
-          return this.getChildren().length;
-        }
-        getChildAt(index) {
-          return this.getChildren()[index];
-        }
-        getChildren() {
-          return this.kind === 1 /* EndOfFileToken */ ? this.jsDoc || emptyArray : emptyArray;
-        }
-        getFirstToken() {
-          return void 0;
-        }
-        getLastToken() {
-          return void 0;
-        }
-        forEachChild() {
-          return void 0;
-        }
-      };
-      SymbolObject = class {
-        constructor(flags, name) {
-          this.id = 0;
-          this.mergeId = 0;
-          this.flags = flags;
-          this.escapedName = name;
-        }
-        getFlags() {
-          return this.flags;
-        }
-        get name() {
-          return symbolName(this);
-        }
-        getEscapedName() {
-          return this.escapedName;
-        }
-        getName() {
-          return this.name;
-        }
-        getDeclarations() {
-          return this.declarations;
-        }
-        getDocumentationComment(checker) {
-          if (!this.documentationComment) {
-            this.documentationComment = emptyArray;
-            if (!this.declarations && isTransientSymbol(this) && this.links.target && isTransientSymbol(this.links.target) && this.links.target.links.tupleLabelDeclaration) {
-              const labelDecl = this.links.target.links.tupleLabelDeclaration;
-              this.documentationComment = getDocumentationComment([labelDecl], checker);
-            } else {
-              this.documentationComment = getDocumentationComment(this.declarations, checker);
-            }
-          }
-          return this.documentationComment;
-        }
-        getContextualDocumentationComment(context, checker) {
-          if (context) {
-            if (isGetAccessor(context)) {
-              if (!this.contextualGetAccessorDocumentationComment) {
-                this.contextualGetAccessorDocumentationComment = getDocumentationComment(filter(this.declarations, isGetAccessor), checker);
-              }
-              if (length(this.contextualGetAccessorDocumentationComment)) {
-                return this.contextualGetAccessorDocumentationComment;
-              }
-            }
-            if (isSetAccessor(context)) {
-              if (!this.contextualSetAccessorDocumentationComment) {
-                this.contextualSetAccessorDocumentationComment = getDocumentationComment(filter(this.declarations, isSetAccessor), checker);
-              }
-              if (length(this.contextualSetAccessorDocumentationComment)) {
-                return this.contextualSetAccessorDocumentationComment;
-              }
-            }
-          }
-          return this.getDocumentationComment(checker);
-        }
-        getJsDocTags(checker) {
-          if (this.tags === void 0) {
-            this.tags = getJsDocTagsOfDeclarations(this.declarations, checker);
-          }
-          return this.tags;
-        }
-        getContextualJsDocTags(context, checker) {
-          if (context) {
-            if (isGetAccessor(context)) {
-              if (!this.contextualGetAccessorTags) {
-                this.contextualGetAccessorTags = getJsDocTagsOfDeclarations(filter(this.declarations, isGetAccessor), checker);
-              }
-              if (length(this.contextualGetAccessorTags)) {
-                return this.contextualGetAccessorTags;
-              }
-            }
-            if (isSetAccessor(context)) {
-              if (!this.contextualSetAccessorTags) {
-                this.contextualSetAccessorTags = getJsDocTagsOfDeclarations(filter(this.declarations, isSetAccessor), checker);
-              }
-              if (length(this.contextualSetAccessorTags)) {
-                return this.contextualSetAccessorTags;
-              }
-            }
-          }
-          return this.getJsDocTags(checker);
-        }
-      };
-      TokenObject = class extends TokenOrIdentifierObject {
-        constructor(kind, pos, end) {
-          super(pos, end);
-          this.kind = kind;
-        }
-      };
-      IdentifierObject = class extends TokenOrIdentifierObject {
-        constructor(_kind, pos, end) {
-          super(pos, end);
-          this.kind = 80 /* Identifier */;
-        }
-        get text() {
-          return idText(this);
-        }
-      };
-      IdentifierObject.prototype.kind = 80 /* Identifier */;
-      PrivateIdentifierObject = class extends TokenOrIdentifierObject {
-        constructor(_kind, pos, end) {
-          super(pos, end);
-          this.kind = 81 /* PrivateIdentifier */;
-        }
-        get text() {
-          return idText(this);
-        }
-      };
-      PrivateIdentifierObject.prototype.kind = 81 /* PrivateIdentifier */;
-      TypeObject = class {
-        constructor(checker, flags) {
-          this.checker = checker;
-          this.flags = flags;
-        }
-        getFlags() {
-          return this.flags;
-        }
-        getSymbol() {
-          return this.symbol;
-        }
-        getProperties() {
-          return this.checker.getPropertiesOfType(this);
-        }
-        getProperty(propertyName) {
-          return this.checker.getPropertyOfType(this, propertyName);
-        }
-        getApparentProperties() {
-          return this.checker.getAugmentedPropertiesOfType(this);
-        }
-        getCallSignatures() {
-          return this.checker.getSignaturesOfType(this, 0 /* Call */);
-        }
-        getConstructSignatures() {
-          return this.checker.getSignaturesOfType(this, 1 /* Construct */);
-        }
-        getStringIndexType() {
-          return this.checker.getIndexTypeOfType(this, 0 /* String */);
-        }
-        getNumberIndexType() {
-          return this.checker.getIndexTypeOfType(this, 1 /* Number */);
-        }
-        getBaseTypes() {
-          return this.isClassOrInterface() ? this.checker.getBaseTypes(this) : void 0;
-        }
-        isNullableType() {
-          return this.checker.isNullableType(this);
-        }
-        getNonNullableType() {
-          return this.checker.getNonNullableType(this);
-        }
-        getNonOptionalType() {
-          return this.checker.getNonOptionalType(this);
-        }
-        getConstraint() {
-          return this.checker.getBaseConstraintOfType(this);
-        }
-        getDefault() {
-          return this.checker.getDefaultFromTypeParameter(this);
-        }
-        isUnion() {
-          return !!(this.flags & 1048576 /* Union */);
-        }
-        isIntersection() {
-          return !!(this.flags & 2097152 /* Intersection */);
-        }
-        isUnionOrIntersection() {
-          return !!(this.flags & 3145728 /* UnionOrIntersection */);
-        }
-        isLiteral() {
-          return !!(this.flags & (128 /* StringLiteral */ | 256 /* NumberLiteral */ | 2048 /* BigIntLiteral */));
-        }
-        isStringLiteral() {
-          return !!(this.flags & 128 /* StringLiteral */);
-        }
-        isNumberLiteral() {
-          return !!(this.flags & 256 /* NumberLiteral */);
-        }
-        isTypeParameter() {
-          return !!(this.flags & 262144 /* TypeParameter */);
-        }
-        isClassOrInterface() {
-          return !!(getObjectFlags(this) & 3 /* ClassOrInterface */);
-        }
-        isClass() {
-          return !!(getObjectFlags(this) & 1 /* Class */);
-        }
-        isIndexType() {
-          return !!(this.flags & 4194304 /* Index */);
-        }
-        /**
-         * This polyfills `referenceType.typeArguments` for API consumers
-         */
-        get typeArguments() {
-          if (getObjectFlags(this) & 4 /* Reference */) {
-            return this.checker.getTypeArguments(this);
-          }
-          return void 0;
-        }
-      };
-      SignatureObject = class {
-        // same
-        constructor(checker, flags) {
-          this.checker = checker;
-          this.flags = flags;
-        }
-        getDeclaration() {
-          return this.declaration;
-        }
-        getTypeParameters() {
-          return this.typeParameters;
-        }
-        getParameters() {
-          return this.parameters;
-        }
-        getReturnType() {
-          return this.checker.getReturnTypeOfSignature(this);
-        }
-        getTypeParameterAtPosition(pos) {
-          const type = this.checker.getParameterType(this, pos);
-          if (type.isIndexType() && isThisTypeParameter(type.type)) {
-            const constraint = type.type.getConstraint();
-            if (constraint) {
-              return this.checker.getIndexType(constraint);
-            }
-          }
-          return type;
-        }
-        getDocumentationComment() {
-          return this.documentationComment || (this.documentationComment = getDocumentationComment(singleElementArray(this.declaration), this.checker));
-        }
-        getJsDocTags() {
-          return this.jsDocTags || (this.jsDocTags = getJsDocTagsOfDeclarations(singleElementArray(this.declaration), this.checker));
-        }
-      };
-      SourceFileObject = class extends NodeObject {
-        constructor(kind, pos, end) {
-          super(kind, pos, end);
-          this.kind = 311 /* SourceFile */;
-        }
-        update(newText, textChangeRange) {
-          return updateSourceFile(this, newText, textChangeRange);
-        }
-        getLineAndCharacterOfPosition(position) {
-          return getLineAndCharacterOfPosition(this, position);
-        }
-        getLineStarts() {
-          return getLineStarts(this);
-        }
-        getPositionOfLineAndCharacter(line, character, allowEdits) {
-          return computePositionOfLineAndCharacter(getLineStarts(this), line, character, this.text, allowEdits);
-        }
-        getLineEndOfPosition(pos) {
-          const { line } = this.getLineAndCharacterOfPosition(pos);
-          const lineStarts = this.getLineStarts();
-          let lastCharPos;
-          if (line + 1 >= lineStarts.length) {
-            lastCharPos = this.getEnd();
-          }
-          if (!lastCharPos) {
-            lastCharPos = lineStarts[line + 1] - 1;
-          }
-          const fullText = this.getFullText();
-          return fullText[lastCharPos] === "\n" && fullText[lastCharPos - 1] === "\r" ? lastCharPos - 1 : lastCharPos;
-        }
-        getNamedDeclarations() {
-          if (!this.namedDeclarations) {
-            this.namedDeclarations = this.computeNamedDeclarations();
-          }
-          return this.namedDeclarations;
-        }
-        computeNamedDeclarations() {
-          const result = createMultiMap();
-          this.forEachChild(visit);
-          return result;
-          function addDeclaration(declaration) {
-            const name = getDeclarationName(declaration);
-            if (name) {
-              result.add(name, declaration);
-            }
-          }
-          function getDeclarations(name) {
-            let declarations = result.get(name);
-            if (!declarations) {
-              result.set(name, declarations = []);
-            }
-            return declarations;
-          }
-          function getDeclarationName(declaration) {
-            const name = getNonAssignedNameOfDeclaration(declaration);
-            return name && (isComputedPropertyName(name) && isPropertyAccessExpression(name.expression) ? name.expression.name.text : isPropertyName(name) ? getNameFromPropertyName(name) : void 0);
-          }
-          function visit(node) {
-            switch (node.kind) {
-              case 261 /* FunctionDeclaration */:
-              case 217 /* FunctionExpression */:
-              case 173 /* MethodDeclaration */:
-              case 172 /* MethodSignature */:
-                const functionDeclaration = node;
-                const declarationName = getDeclarationName(functionDeclaration);
-                if (declarationName) {
-                  const declarations = getDeclarations(declarationName);
-                  const lastDeclaration = lastOrUndefined(declarations);
-                  if (lastDeclaration && functionDeclaration.parent === lastDeclaration.parent && functionDeclaration.symbol === lastDeclaration.symbol) {
-                    if (functionDeclaration.body && !lastDeclaration.body) {
-                      declarations[declarations.length - 1] = functionDeclaration;
-                    }
-                  } else {
-                    declarations.push(functionDeclaration);
-                  }
-                }
-                forEachChild(node, visit);
-                break;
-              case 262 /* ClassDeclaration */:
-              case 230 /* ClassExpression */:
-              case 263 /* InterfaceDeclaration */:
-              case 264 /* TypeAliasDeclaration */:
-              case 265 /* EnumDeclaration */:
-              case 266 /* ModuleDeclaration */:
-              case 270 /* ImportEqualsDeclaration */:
-              case 280 /* ExportSpecifier */:
-              case 275 /* ImportSpecifier */:
-              case 272 /* ImportClause */:
-              case 273 /* NamespaceImport */:
-              case 176 /* GetAccessor */:
-              case 177 /* SetAccessor */:
-              case 186 /* TypeLiteral */:
-                addDeclaration(node);
-                forEachChild(node, visit);
-                break;
-              case 168 /* Parameter */:
-                if (!hasSyntacticModifier(node, 16476 /* ParameterPropertyModifier */)) {
-                  break;
-                }
-              case 259 /* VariableDeclaration */:
-              case 207 /* BindingElement */: {
-                const decl = node;
-                if (isBindingPattern(decl.name)) {
-                  forEachChild(decl.name, visit);
-                  break;
-                }
-                if (decl.initializer) {
-                  visit(decl.initializer);
-                }
-              }
-              case 305 /* EnumMember */:
-              case 171 /* PropertyDeclaration */:
-              case 170 /* PropertySignature */:
-                addDeclaration(node);
-                break;
-              case 277 /* ExportDeclaration */:
-                const exportDeclaration = node;
-                if (exportDeclaration.exportClause) {
-                  if (isNamedExports(exportDeclaration.exportClause)) {
-                    forEach(exportDeclaration.exportClause.elements, visit);
-                  } else {
-                    visit(exportDeclaration.exportClause.name);
-                  }
-                }
-                break;
-              case 271 /* ImportDeclaration */:
-                const importClause = node.importClause;
-                if (importClause) {
-                  if (importClause.name) {
-                    addDeclaration(importClause.name);
-                  }
-                  if (importClause.namedBindings) {
-                    if (importClause.namedBindings.kind === 273 /* NamespaceImport */) {
-                      addDeclaration(importClause.namedBindings);
-                    } else {
-                      forEach(importClause.namedBindings.elements, visit);
-                    }
-                  }
-                }
-                break;
-              case 225 /* BinaryExpression */:
-                if (getAssignmentDeclarationKind(node) !== 0 /* None */) {
-                  addDeclaration(node);
-                }
-              default:
-                forEachChild(node, visit);
-            }
-          }
-        }
-      };
-      SourceMapSourceObject = class {
-        constructor(fileName, text, skipTrivia2) {
-          this.fileName = fileName;
-          this.text = text;
-          this.skipTrivia = skipTrivia2;
-        }
-        getLineAndCharacterOfPosition(pos) {
-          return getLineAndCharacterOfPosition(this, pos);
-        }
-      };
-      SyntaxTreeCache = class {
-        constructor(host) {
-          this.host = host;
-        }
-        getCurrentSourceFile(fileName) {
-          var _a, _b, _c, _d, _e, _f, _g, _h;
-          const scriptSnapshot = this.host.getScriptSnapshot(fileName);
-          if (!scriptSnapshot) {
-            throw new Error("Could not find file: '" + fileName + "'.");
-          }
-          const scriptKind = getScriptKind(fileName, this.host);
-          const version2 = this.host.getScriptVersion(fileName);
-          let sourceFile;
-          if (this.currentFileName !== fileName) {
-            const options = {
-              languageVersion: 99 /* Latest */,
-              impliedNodeFormat: getImpliedNodeFormatForFile(
-                toPath(fileName, this.host.getCurrentDirectory(), ((_c = (_b = (_a = this.host).getCompilerHost) == null ? void 0 : _b.call(_a)) == null ? void 0 : _c.getCanonicalFileName) || hostGetCanonicalFileName(this.host)),
-                (_h = (_g = (_f = (_e = (_d = this.host).getCompilerHost) == null ? void 0 : _e.call(_d)) == null ? void 0 : _f.getModuleResolutionCache) == null ? void 0 : _g.call(_f)) == null ? void 0 : _h.getPackageJsonInfoCache(),
-                this.host,
-                this.host.getCompilationSettings()
-              ),
-              setExternalModuleIndicator: getSetExternalModuleIndicator(this.host.getCompilationSettings())
-            };
-            sourceFile = createLanguageServiceSourceFile(
-              fileName,
-              scriptSnapshot,
-              options,
-              version2,
-              /*setNodeParents*/
-              true,
-              scriptKind
-            );
-          } else if (this.currentFileVersion !== version2) {
-            const editRange = scriptSnapshot.getChangeRange(this.currentFileScriptSnapshot);
-            sourceFile = updateLanguageServiceSourceFile(this.currentSourceFile, scriptSnapshot, version2, editRange);
-          }
-          if (sourceFile) {
-            this.currentFileVersion = version2;
-            this.currentFileName = fileName;
-            this.currentFileScriptSnapshot = scriptSnapshot;
-            this.currentSourceFile = sourceFile;
-          }
-          return this.currentSourceFile;
-        }
-      };
-      NoopCancellationToken = {
-        isCancellationRequested: returnFalse,
-        throwIfCancellationRequested: noop
-      };
-      CancellationTokenObject = class {
-        constructor(cancellationToken) {
-          this.cancellationToken = cancellationToken;
-        }
-        isCancellationRequested() {
-          return this.cancellationToken.isCancellationRequested();
-        }
-        throwIfCancellationRequested() {
-          var _a;
-          if (this.isCancellationRequested()) {
-            (_a = tracing) == null ? void 0 : _a.instant(tracing.Phase.Session, "cancellationThrown", { kind: "CancellationTokenObject" });
-            throw new OperationCanceledException();
-          }
-        }
-      };
-      ThrottledCancellationToken = class {
-        constructor(hostCancellationToken, throttleWaitMilliseconds = 20) {
-          this.hostCancellationToken = hostCancellationToken;
-          this.throttleWaitMilliseconds = throttleWaitMilliseconds;
-          // Store when we last tried to cancel.  Checking cancellation can be expensive (as we have
-          // to marshall over to the host layer).  So we only bother actually checking once enough
-          // time has passed.
-          this.lastCancellationCheckTime = 0;
-        }
-        isCancellationRequested() {
-          const time = timestamp();
-          const duration = Math.abs(time - this.lastCancellationCheckTime);
-          if (duration >= this.throttleWaitMilliseconds) {
-            this.lastCancellationCheckTime = time;
-            return this.hostCancellationToken.isCancellationRequested();
-          }
-          return false;
-        }
-        throwIfCancellationRequested() {
-          var _a;
-          if (this.isCancellationRequested()) {
-            (_a = tracing) == null ? void 0 : _a.instant(tracing.Phase.Session, "cancellationThrown", { kind: "ThrottledCancellationToken" });
-            throw new OperationCanceledException();
-          }
-        }
-      };
-      invalidOperationsInPartialSemanticMode = [
-        "getSemanticDiagnostics",
-        "getSuggestionDiagnostics",
-        "getCompilerOptionsDiagnostics",
-        "getSemanticClassifications",
-        "getEncodedSemanticClassifications",
-        "getCodeFixesAtPosition",
-        "getCombinedCodeFix",
-        "applyCodeActionCommand",
-        "organizeImports",
-        "getEditsForFileRename",
-        "getEmitOutput",
-        "getApplicableRefactors",
-        "getEditsForRefactor",
-        "prepareCallHierarchy",
-        "provideCallHierarchyIncomingCalls",
-        "provideCallHierarchyOutgoingCalls",
-        "provideInlayHints",
-        "getSupportedCodeFixes"
-      ];
-      invalidOperationsInSyntacticMode = [
-        ...invalidOperationsInPartialSemanticMode,
-        "getCompletionsAtPosition",
-        "getCompletionEntryDetails",
-        "getCompletionEntrySymbol",
-        "getSignatureHelpItems",
-        "getQuickInfoAtPosition",
-        "getDefinitionAtPosition",
-        "getDefinitionAndBoundSpan",
-        "getImplementationAtPosition",
-        "getTypeDefinitionAtPosition",
-        "getReferencesAtPosition",
-        "findReferences",
-        "getDocumentHighlights",
-        "getNavigateToItems",
-        "getRenameInfo",
-        "findRenameLocations",
-        "getApplicableRefactors"
-      ];
-      setObjectAllocator(getServicesObjectAllocator());
-    }
-  });
-
-  // src/services/transform.ts
-  function transform(source, transformers, compilerOptions) {
-    const diagnostics = [];
-    compilerOptions = fixupCompilerOptions(compilerOptions, diagnostics);
-    const nodes = isArray(source) ? source : [source];
-    const result = transformNodes(
-      /*resolver*/
-      void 0,
-      /*host*/
-      void 0,
-      factory,
-      compilerOptions,
-      nodes,
-      transformers,
-      /*allowDtsFiles*/
-      true
-    );
-    result.diagnostics = concatenate(result.diagnostics, diagnostics);
-    return result;
-  }
-  var init_transform = __esm({
-    "src/services/transform.ts"() {
-      "use strict";
-      init_ts4();
-    }
-  });
-
-  // src/services/shims.ts
-  function logInternalError(logger, err) {
-    if (logger) {
-      logger.log("*INTERNAL ERROR* - Exception in typescript services: " + err.message);
-    }
-  }
-  function simpleForwardCall(logger, actionDescription2, action, logPerformance) {
-    let start;
-    if (logPerformance) {
-      logger.log(actionDescription2);
-      start = timestamp();
-    }
-    const result = action();
-    if (logPerformance) {
-      const end = timestamp();
-      logger.log(`${actionDescription2} completed in ${end - start} msec`);
-      if (isString(result)) {
-        let str = result;
-        if (str.length > 128) {
-          str = str.substring(0, 128) + "...";
-        }
-        logger.log(`  result.length=${str.length}, result='${JSON.stringify(str)}'`);
-      }
-    }
-    return result;
-  }
-  function forwardJSONCall(logger, actionDescription2, action, logPerformance) {
-    return forwardCall(
-      logger,
-      actionDescription2,
-      /*returnJson*/
-      true,
-      action,
-      logPerformance
-    );
-  }
-  function forwardCall(logger, actionDescription2, returnJson, action, logPerformance) {
-    try {
-      const result = simpleForwardCall(logger, actionDescription2, action, logPerformance);
-      return returnJson ? JSON.stringify({ result }) : result;
-    } catch (err) {
-      if (err instanceof OperationCanceledException) {
-        return JSON.stringify({ canceled: true });
-      }
-      logInternalError(logger, err);
-      err.description = actionDescription2;
-      return JSON.stringify({ error: err });
-    }
-  }
-  function realizeDiagnostics(diagnostics, newLine) {
-    return diagnostics.map((d) => realizeDiagnostic(d, newLine));
-  }
-  function realizeDiagnostic(diagnostic, newLine) {
-    return {
-      message: flattenDiagnosticMessageText(diagnostic.messageText, newLine),
-      start: diagnostic.start,
-      // TODO: GH#18217
-      length: diagnostic.length,
-      // TODO: GH#18217
-      category: diagnosticCategoryName(diagnostic),
-      code: diagnostic.code,
-      reportsUnnecessary: diagnostic.reportsUnnecessary,
-      reportsDeprecated: diagnostic.reportsDeprecated
-    };
-  }
-  function convertClassifications(classifications) {
-    return { spans: classifications.spans.join(","), endOfLineState: classifications.endOfLineState };
-  }
-  var debugObjectHost, ScriptSnapshotShimAdapter, LanguageServiceShimHostAdapter, CoreServicesShimHostAdapter, ShimBase, LanguageServiceShimObject, ClassifierShimObject, CoreServicesShimObject, TypeScriptServicesFactory;
-  var init_shims = __esm({
-    "src/services/shims.ts"() {
-      "use strict";
-      init_ts4();
-      debugObjectHost = function() {
-        return this;
-      }();
-      ScriptSnapshotShimAdapter = class {
-        constructor(scriptSnapshotShim) {
-          this.scriptSnapshotShim = scriptSnapshotShim;
-        }
-        getText(start, end) {
-          return this.scriptSnapshotShim.getText(start, end);
-        }
-        getLength() {
-          return this.scriptSnapshotShim.getLength();
-        }
-        getChangeRange(oldSnapshot) {
-          const oldSnapshotShim = oldSnapshot;
-          const encoded = this.scriptSnapshotShim.getChangeRange(oldSnapshotShim.scriptSnapshotShim);
-          if (encoded === null) {
-            return null;
-          }
-          const decoded = JSON.parse(encoded);
-          return createTextChangeRange(
-            createTextSpan(decoded.span.start, decoded.span.length),
-            decoded.newLength
-          );
-        }
-        dispose() {
-          if ("dispose" in this.scriptSnapshotShim) {
-            this.scriptSnapshotShim.dispose();
-          }
-        }
-      };
-      LanguageServiceShimHostAdapter = class {
-        constructor(shimHost) {
-          this.shimHost = shimHost;
-          this.loggingEnabled = false;
-          this.tracingEnabled = false;
-          if ("getModuleResolutionsForFile" in this.shimHost) {
-            this.resolveModuleNames = (moduleNames, containingFile) => {
-              const resolutionsInFile = JSON.parse(this.shimHost.getModuleResolutionsForFile(containingFile));
-              return map(moduleNames, (name) => {
-                const result = getProperty(resolutionsInFile, name);
-                return result ? { resolvedFileName: result, extension: extensionFromPath(result), isExternalLibraryImport: false } : void 0;
-              });
-            };
-          }
-          if ("directoryExists" in this.shimHost) {
-            this.directoryExists = (directoryName) => this.shimHost.directoryExists(directoryName);
-          }
-          if ("getTypeReferenceDirectiveResolutionsForFile" in this.shimHost) {
-            this.resolveTypeReferenceDirectives = (typeDirectiveNames, containingFile) => {
-              const typeDirectivesForFile = JSON.parse(this.shimHost.getTypeReferenceDirectiveResolutionsForFile(containingFile));
-              return map(typeDirectiveNames, (name) => getProperty(typeDirectivesForFile, isString(name) ? name : toFileNameLowerCase(name.fileName)));
-            };
-          }
-        }
-        log(s) {
-          if (this.loggingEnabled) {
-            this.shimHost.log(s);
-          }
-        }
-        trace(s) {
-          if (this.tracingEnabled) {
-            this.shimHost.trace(s);
-          }
-        }
-        error(s) {
-          this.shimHost.error(s);
-        }
-        getProjectVersion() {
-          if (!this.shimHost.getProjectVersion) {
-            return void 0;
-          }
-          return this.shimHost.getProjectVersion();
-        }
-        getTypeRootsVersion() {
-          if (!this.shimHost.getTypeRootsVersion) {
-            return 0;
-          }
-          return this.shimHost.getTypeRootsVersion();
-        }
-        useCaseSensitiveFileNames() {
-          return this.shimHost.useCaseSensitiveFileNames ? this.shimHost.useCaseSensitiveFileNames() : false;
-        }
-        getCompilationSettings() {
-          const settingsJson = this.shimHost.getCompilationSettings();
-          if (settingsJson === null || settingsJson === "") {
-            throw Error("LanguageServiceShimHostAdapter.getCompilationSettings: empty compilationSettings");
-          }
-          const compilerOptions = JSON.parse(settingsJson);
-          compilerOptions.allowNonTsExtensions = true;
-          return compilerOptions;
-        }
-        getScriptFileNames() {
-          const encoded = this.shimHost.getScriptFileNames();
-          return JSON.parse(encoded);
-        }
-        getScriptSnapshot(fileName) {
-          const scriptSnapshot = this.shimHost.getScriptSnapshot(fileName);
-          return scriptSnapshot && new ScriptSnapshotShimAdapter(scriptSnapshot);
-        }
-        getScriptKind(fileName) {
-          if ("getScriptKind" in this.shimHost) {
-            return this.shimHost.getScriptKind(fileName);
-          } else {
-            return 0 /* Unknown */;
-          }
-        }
-        getScriptVersion(fileName) {
-          return this.shimHost.getScriptVersion(fileName);
-        }
-        getLocalizedDiagnosticMessages() {
-          const diagnosticMessagesJson = this.shimHost.getLocalizedDiagnosticMessages();
-          if (diagnosticMessagesJson === null || diagnosticMessagesJson === "") {
-            return null;
-          }
-          try {
-            return JSON.parse(diagnosticMessagesJson);
-          } catch (e) {
-            this.log(e.description || "diagnosticMessages.generated.json has invalid JSON format");
-            return null;
-          }
-        }
-        getCancellationToken() {
-          const hostCancellationToken = this.shimHost.getCancellationToken();
-          return new ThrottledCancellationToken(hostCancellationToken);
-        }
-        getCurrentDirectory() {
-          return this.shimHost.getCurrentDirectory();
-        }
-        getDirectories(path) {
-          return JSON.parse(this.shimHost.getDirectories(path));
-        }
-        getDefaultLibFileName(options) {
-          return this.shimHost.getDefaultLibFileName(JSON.stringify(options));
-        }
-        readDirectory(path, extensions, exclude, include, depth) {
-          const pattern = getFileMatcherPatterns(
-            path,
-            exclude,
-            include,
-            this.shimHost.useCaseSensitiveFileNames(),
-            this.shimHost.getCurrentDirectory()
-          );
-          return JSON.parse(this.shimHost.readDirectory(
-            path,
-            JSON.stringify(extensions),
-            JSON.stringify(pattern.basePaths),
-            pattern.excludePattern,
-            pattern.includeFilePattern,
-            pattern.includeDirectoryPattern,
-            depth
-          ));
-        }
-        readFile(path, encoding) {
-          return this.shimHost.readFile(path, encoding);
-        }
-        fileExists(path) {
-          return this.shimHost.fileExists(path);
-        }
-      };
-      CoreServicesShimHostAdapter = class {
-        constructor(shimHost) {
-          this.shimHost = shimHost;
-          this.useCaseSensitiveFileNames = this.shimHost.useCaseSensitiveFileNames ? this.shimHost.useCaseSensitiveFileNames() : false;
-          if ("directoryExists" in this.shimHost) {
-            this.directoryExists = (directoryName) => this.shimHost.directoryExists(directoryName);
-          } else {
-            this.directoryExists = void 0;
-          }
-          if ("realpath" in this.shimHost) {
-            this.realpath = (path) => this.shimHost.realpath(path);
-          } else {
-            this.realpath = void 0;
-          }
-        }
-        readDirectory(rootDir, extensions, exclude, include, depth) {
-          const pattern = getFileMatcherPatterns(
-            rootDir,
-            exclude,
-            include,
-            this.shimHost.useCaseSensitiveFileNames(),
-            this.shimHost.getCurrentDirectory()
-          );
-          return JSON.parse(this.shimHost.readDirectory(
-            rootDir,
-            JSON.stringify(extensions),
-            JSON.stringify(pattern.basePaths),
-            pattern.excludePattern,
-            pattern.includeFilePattern,
-            pattern.includeDirectoryPattern,
-            depth
-          ));
-        }
-        fileExists(fileName) {
-          return this.shimHost.fileExists(fileName);
-        }
-        readFile(fileName) {
-          return this.shimHost.readFile(fileName);
-        }
-        getDirectories(path) {
-          return JSON.parse(this.shimHost.getDirectories(path));
-        }
-      };
-      ShimBase = class {
-        constructor(factory2) {
-          this.factory = factory2;
-          factory2.registerShim(this);
-        }
-        dispose(_dummy) {
-          this.factory.unregisterShim(this);
-        }
-      };
-      LanguageServiceShimObject = class extends ShimBase {
-        constructor(factory2, host, languageService) {
-          super(factory2);
-          this.host = host;
-          this.languageService = languageService;
-          this.logPerformance = false;
-          this.logger = this.host;
-        }
-        forwardJSONCall(actionDescription2, action) {
-          return forwardJSONCall(this.logger, actionDescription2, action, this.logPerformance);
-        }
-        /// DISPOSE
-        /**
-         * Ensure (almost) deterministic release of internal Javascript resources when
-         * some external native objects holds onto us (e.g. Com/Interop).
-         */
-        dispose(dummy) {
-          this.logger.log("dispose()");
-          this.languageService.dispose();
-          this.languageService = null;
-          if (debugObjectHost && debugObjectHost.CollectGarbage) {
-            debugObjectHost.CollectGarbage();
-            this.logger.log("CollectGarbage()");
-          }
-          this.logger = null;
-          super.dispose(dummy);
-        }
-        /// REFRESH
-        /**
-         * Update the list of scripts known to the compiler
-         */
-        refresh(throwOnError) {
-          this.forwardJSONCall(
-            `refresh(${throwOnError})`,
-            () => null
-            // eslint-disable-line no-null/no-null
-          );
-        }
-        cleanupSemanticCache() {
-          this.forwardJSONCall(
-            "cleanupSemanticCache()",
-            () => {
-              this.languageService.cleanupSemanticCache();
-              return null;
-            }
-          );
-        }
-        realizeDiagnostics(diagnostics) {
-          const newLine = getNewLineOrDefaultFromHost(
-            this.host,
-            /*formatSettings*/
-            void 0
-          );
-          return realizeDiagnostics(diagnostics, newLine);
-        }
-        getSyntacticClassifications(fileName, start, length2) {
-          return this.forwardJSONCall(
-            `getSyntacticClassifications('${fileName}', ${start}, ${length2})`,
-            () => this.languageService.getSyntacticClassifications(fileName, createTextSpan(start, length2))
-          );
-        }
-        getSemanticClassifications(fileName, start, length2) {
-          return this.forwardJSONCall(
-            `getSemanticClassifications('${fileName}', ${start}, ${length2})`,
-            () => this.languageService.getSemanticClassifications(fileName, createTextSpan(start, length2))
-          );
-        }
-        getEncodedSyntacticClassifications(fileName, start, length2) {
-          return this.forwardJSONCall(
-            `getEncodedSyntacticClassifications('${fileName}', ${start}, ${length2})`,
-            // directly serialize the spans out to a string.  This is much faster to decode
-            // on the managed side versus a full JSON array.
-            () => convertClassifications(this.languageService.getEncodedSyntacticClassifications(fileName, createTextSpan(start, length2)))
-          );
-        }
-        getEncodedSemanticClassifications(fileName, start, length2) {
-          return this.forwardJSONCall(
-            `getEncodedSemanticClassifications('${fileName}', ${start}, ${length2})`,
-            // directly serialize the spans out to a string.  This is much faster to decode
-            // on the managed side versus a full JSON array.
-            () => convertClassifications(this.languageService.getEncodedSemanticClassifications(fileName, createTextSpan(start, length2)))
-          );
-        }
-        getSyntacticDiagnostics(fileName) {
-          return this.forwardJSONCall(
-            `getSyntacticDiagnostics('${fileName}')`,
-            () => {
-              const diagnostics = this.languageService.getSyntacticDiagnostics(fileName);
-              return this.realizeDiagnostics(diagnostics);
-            }
-          );
-        }
-        getSemanticDiagnostics(fileName) {
-          return this.forwardJSONCall(
-            `getSemanticDiagnostics('${fileName}')`,
-            () => {
-              const diagnostics = this.languageService.getSemanticDiagnostics(fileName);
-              return this.realizeDiagnostics(diagnostics);
-            }
-          );
-        }
-        getSuggestionDiagnostics(fileName) {
-          return this.forwardJSONCall(`getSuggestionDiagnostics('${fileName}')`, () => this.realizeDiagnostics(this.languageService.getSuggestionDiagnostics(fileName)));
-        }
-        getCompilerOptionsDiagnostics() {
-          return this.forwardJSONCall(
-            "getCompilerOptionsDiagnostics()",
-            () => {
-              const diagnostics = this.languageService.getCompilerOptionsDiagnostics();
-              return this.realizeDiagnostics(diagnostics);
-            }
-          );
-        }
-        /// QUICKINFO
-        /**
-         * Computes a string representation of the type at the requested position
-         * in the active file.
-         */
-        getQuickInfoAtPosition(fileName, position) {
-          return this.forwardJSONCall(
-            `getQuickInfoAtPosition('${fileName}', ${position})`,
-            () => this.languageService.getQuickInfoAtPosition(fileName, position)
-          );
-        }
-        /// NAMEORDOTTEDNAMESPAN
-        /**
-         * Computes span information of the name or dotted name at the requested position
-         * in the active file.
-         */
-        getNameOrDottedNameSpan(fileName, startPos, endPos) {
-          return this.forwardJSONCall(
-            `getNameOrDottedNameSpan('${fileName}', ${startPos}, ${endPos})`,
-            () => this.languageService.getNameOrDottedNameSpan(fileName, startPos, endPos)
-          );
-        }
-        /**
-         * STATEMENTSPAN
-         * Computes span information of statement at the requested position in the active file.
-         */
-        getBreakpointStatementAtPosition(fileName, position) {
-          return this.forwardJSONCall(
-            `getBreakpointStatementAtPosition('${fileName}', ${position})`,
-            () => this.languageService.getBreakpointStatementAtPosition(fileName, position)
-          );
-        }
-        /// SIGNATUREHELP
-        getSignatureHelpItems(fileName, position, options) {
-          return this.forwardJSONCall(
-            `getSignatureHelpItems('${fileName}', ${position})`,
-            () => this.languageService.getSignatureHelpItems(fileName, position, options)
-          );
-        }
-        /// GOTO DEFINITION
-        /**
-         * Computes the definition location and file for the symbol
-         * at the requested position.
-         */
-        getDefinitionAtPosition(fileName, position) {
-          return this.forwardJSONCall(
-            `getDefinitionAtPosition('${fileName}', ${position})`,
-            () => this.languageService.getDefinitionAtPosition(fileName, position)
-          );
-        }
-        /**
-         * Computes the definition location and file for the symbol
-         * at the requested position.
-         */
-        getDefinitionAndBoundSpan(fileName, position) {
-          return this.forwardJSONCall(
-            `getDefinitionAndBoundSpan('${fileName}', ${position})`,
-            () => this.languageService.getDefinitionAndBoundSpan(fileName, position)
-          );
-        }
-        /// GOTO Type
-        /**
-         * Computes the definition location of the type of the symbol
-         * at the requested position.
-         */
-        getTypeDefinitionAtPosition(fileName, position) {
-          return this.forwardJSONCall(
-            `getTypeDefinitionAtPosition('${fileName}', ${position})`,
-            () => this.languageService.getTypeDefinitionAtPosition(fileName, position)
-          );
-        }
-        /// GOTO Implementation
-        /**
-         * Computes the implementation location of the symbol
-         * at the requested position.
-         */
-        getImplementationAtPosition(fileName, position) {
-          return this.forwardJSONCall(
-            `getImplementationAtPosition('${fileName}', ${position})`,
-            () => this.languageService.getImplementationAtPosition(fileName, position)
-          );
-        }
-        getRenameInfo(fileName, position, preferences) {
-          return this.forwardJSONCall(
-            `getRenameInfo('${fileName}', ${position})`,
-            () => this.languageService.getRenameInfo(fileName, position, preferences)
-          );
-        }
-        getSmartSelectionRange(fileName, position) {
-          return this.forwardJSONCall(
-            `getSmartSelectionRange('${fileName}', ${position})`,
-            () => this.languageService.getSmartSelectionRange(fileName, position)
-          );
-        }
-        findRenameLocations(fileName, position, findInStrings, findInComments, preferences) {
-          return this.forwardJSONCall(
-            `findRenameLocations('${fileName}', ${position}, ${findInStrings}, ${findInComments})`,
-            () => this.languageService.findRenameLocations(fileName, position, findInStrings, findInComments, preferences)
-          );
-        }
-        /// GET BRACE MATCHING
-        getBraceMatchingAtPosition(fileName, position) {
-          return this.forwardJSONCall(
-            `getBraceMatchingAtPosition('${fileName}', ${position})`,
-            () => this.languageService.getBraceMatchingAtPosition(fileName, position)
-          );
-        }
-        isValidBraceCompletionAtPosition(fileName, position, openingBrace) {
-          return this.forwardJSONCall(
-            `isValidBraceCompletionAtPosition('${fileName}', ${position}, ${openingBrace})`,
-            () => this.languageService.isValidBraceCompletionAtPosition(fileName, position, openingBrace)
-          );
-        }
-        getSpanOfEnclosingComment(fileName, position, onlyMultiLine) {
-          return this.forwardJSONCall(
-            `getSpanOfEnclosingComment('${fileName}', ${position})`,
-            () => this.languageService.getSpanOfEnclosingComment(fileName, position, onlyMultiLine)
-          );
-        }
-        /// GET SMART INDENT
-        getIndentationAtPosition(fileName, position, options) {
-          return this.forwardJSONCall(
-            `getIndentationAtPosition('${fileName}', ${position})`,
-            () => {
-              const localOptions = JSON.parse(options);
-              return this.languageService.getIndentationAtPosition(fileName, position, localOptions);
-            }
-          );
-        }
-        /// GET REFERENCES
-        getReferencesAtPosition(fileName, position) {
-          return this.forwardJSONCall(
-            `getReferencesAtPosition('${fileName}', ${position})`,
-            () => this.languageService.getReferencesAtPosition(fileName, position)
-          );
-        }
-        findReferences(fileName, position) {
-          return this.forwardJSONCall(
-            `findReferences('${fileName}', ${position})`,
-            () => this.languageService.findReferences(fileName, position)
-          );
-        }
-        getFileReferences(fileName) {
-          return this.forwardJSONCall(
-            `getFileReferences('${fileName})`,
-            () => this.languageService.getFileReferences(fileName)
-          );
-        }
-        getDocumentHighlights(fileName, position, filesToSearch) {
-          return this.forwardJSONCall(
-            `getDocumentHighlights('${fileName}', ${position})`,
-            () => {
-              const results = this.languageService.getDocumentHighlights(fileName, position, JSON.parse(filesToSearch));
-              const normalizedName = toFileNameLowerCase(normalizeSlashes(fileName));
-              return filter(results, (r) => toFileNameLowerCase(normalizeSlashes(r.fileName)) === normalizedName);
-            }
-          );
-        }
-        /// COMPLETION LISTS
-        /**
-         * Get a string based representation of the completions
-         * to provide at the given source position and providing a member completion
-         * list if requested.
-         */
-        getCompletionsAtPosition(fileName, position, preferences, formattingSettings) {
-          return this.forwardJSONCall(
-            `getCompletionsAtPosition('${fileName}', ${position}, ${preferences}, ${formattingSettings})`,
-            () => this.languageService.getCompletionsAtPosition(fileName, position, preferences, formattingSettings)
-          );
-        }
-        /** Get a string based representation of a completion list entry details */
-        getCompletionEntryDetails(fileName, position, entryName, formatOptions, source, preferences, data) {
-          return this.forwardJSONCall(
-            `getCompletionEntryDetails('${fileName}', ${position}, '${entryName}')`,
-            () => {
-              const localOptions = formatOptions === void 0 ? void 0 : JSON.parse(formatOptions);
-              return this.languageService.getCompletionEntryDetails(fileName, position, entryName, localOptions, source, preferences, data);
-            }
-          );
-        }
-        getFormattingEditsForRange(fileName, start, end, options) {
-          return this.forwardJSONCall(
-            `getFormattingEditsForRange('${fileName}', ${start}, ${end})`,
-            () => {
-              const localOptions = JSON.parse(options);
-              return this.languageService.getFormattingEditsForRange(fileName, start, end, localOptions);
-            }
-          );
-        }
-        getFormattingEditsForDocument(fileName, options) {
-          return this.forwardJSONCall(
-            `getFormattingEditsForDocument('${fileName}')`,
-            () => {
-              const localOptions = JSON.parse(options);
-              return this.languageService.getFormattingEditsForDocument(fileName, localOptions);
-            }
-          );
-        }
-        getFormattingEditsAfterKeystroke(fileName, position, key, options) {
-          return this.forwardJSONCall(
-            `getFormattingEditsAfterKeystroke('${fileName}', ${position}, '${key}')`,
-            () => {
-              const localOptions = JSON.parse(options);
-              return this.languageService.getFormattingEditsAfterKeystroke(fileName, position, key, localOptions);
-            }
-          );
-        }
-        getDocCommentTemplateAtPosition(fileName, position, options, formatOptions) {
-          return this.forwardJSONCall(
-            `getDocCommentTemplateAtPosition('${fileName}', ${position})`,
-            () => this.languageService.getDocCommentTemplateAtPosition(fileName, position, options, formatOptions)
-          );
-        }
-        /// NAVIGATE TO
-        /** Return a list of symbols that are interesting to navigate to */
-        getNavigateToItems(searchValue, maxResultCount, fileName) {
-          return this.forwardJSONCall(
-            `getNavigateToItems('${searchValue}', ${maxResultCount}, ${fileName})`,
-            () => this.languageService.getNavigateToItems(searchValue, maxResultCount, fileName)
-          );
-        }
-        getNavigationBarItems(fileName) {
-          return this.forwardJSONCall(
-            `getNavigationBarItems('${fileName}')`,
-            () => this.languageService.getNavigationBarItems(fileName)
-          );
-        }
-        getNavigationTree(fileName) {
-          return this.forwardJSONCall(
-            `getNavigationTree('${fileName}')`,
-            () => this.languageService.getNavigationTree(fileName)
-          );
-        }
-        getOutliningSpans(fileName) {
-          return this.forwardJSONCall(
-            `getOutliningSpans('${fileName}')`,
-            () => this.languageService.getOutliningSpans(fileName)
-          );
-        }
-        getTodoComments(fileName, descriptors) {
-          return this.forwardJSONCall(
-            `getTodoComments('${fileName}')`,
-            () => this.languageService.getTodoComments(fileName, JSON.parse(descriptors))
-          );
-        }
-        /// CALL HIERARCHY
-        prepareCallHierarchy(fileName, position) {
-          return this.forwardJSONCall(
-            `prepareCallHierarchy('${fileName}', ${position})`,
-            () => this.languageService.prepareCallHierarchy(fileName, position)
-          );
-        }
-        provideCallHierarchyIncomingCalls(fileName, position) {
-          return this.forwardJSONCall(
-            `provideCallHierarchyIncomingCalls('${fileName}', ${position})`,
-            () => this.languageService.provideCallHierarchyIncomingCalls(fileName, position)
-          );
-        }
-        provideCallHierarchyOutgoingCalls(fileName, position) {
-          return this.forwardJSONCall(
-            `provideCallHierarchyOutgoingCalls('${fileName}', ${position})`,
-            () => this.languageService.provideCallHierarchyOutgoingCalls(fileName, position)
-          );
-        }
-        provideInlayHints(fileName, span, preference) {
-          return this.forwardJSONCall(
-            `provideInlayHints('${fileName}', '${JSON.stringify(span)}', ${JSON.stringify(preference)})`,
-            () => this.languageService.provideInlayHints(fileName, span, preference)
-          );
-        }
-        /// Emit
-        getEmitOutput(fileName) {
-          return this.forwardJSONCall(
-            `getEmitOutput('${fileName}')`,
-            () => {
-              const { diagnostics, ...rest } = this.languageService.getEmitOutput(fileName);
-              return { ...rest, diagnostics: this.realizeDiagnostics(diagnostics) };
-            }
-          );
-        }
-        getEmitOutputObject(fileName) {
-          return forwardCall(
-            this.logger,
-            `getEmitOutput('${fileName}')`,
-            /*returnJson*/
-            false,
-            () => this.languageService.getEmitOutput(fileName),
-            this.logPerformance
-          );
-        }
-        toggleLineComment(fileName, textRange) {
-          return this.forwardJSONCall(
-            `toggleLineComment('${fileName}', '${JSON.stringify(textRange)}')`,
-            () => this.languageService.toggleLineComment(fileName, textRange)
-          );
-        }
-        toggleMultilineComment(fileName, textRange) {
-          return this.forwardJSONCall(
-            `toggleMultilineComment('${fileName}', '${JSON.stringify(textRange)}')`,
-            () => this.languageService.toggleMultilineComment(fileName, textRange)
-          );
-        }
-        commentSelection(fileName, textRange) {
-          return this.forwardJSONCall(
-            `commentSelection('${fileName}', '${JSON.stringify(textRange)}')`,
-            () => this.languageService.commentSelection(fileName, textRange)
-          );
-        }
-        uncommentSelection(fileName, textRange) {
-          return this.forwardJSONCall(
-            `uncommentSelection('${fileName}', '${JSON.stringify(textRange)}')`,
-            () => this.languageService.uncommentSelection(fileName, textRange)
-          );
-        }
-      };
-      ClassifierShimObject = class extends ShimBase {
-        constructor(factory2, logger) {
-          super(factory2);
-          this.logger = logger;
-          this.logPerformance = false;
-          this.classifier = createClassifier();
-        }
-        getEncodedLexicalClassifications(text, lexState, syntacticClassifierAbsent = false) {
-          return forwardJSONCall(
-            this.logger,
-            "getEncodedLexicalClassifications",
-            () => convertClassifications(this.classifier.getEncodedLexicalClassifications(text, lexState, syntacticClassifierAbsent)),
-            this.logPerformance
-          );
-        }
-        /// COLORIZATION
-        getClassificationsForLine(text, lexState, classifyKeywordsInGenerics = false) {
-          const classification = this.classifier.getClassificationsForLine(text, lexState, classifyKeywordsInGenerics);
-          let result = "";
-          for (const item of classification.entries) {
-            result += item.length + "\n";
-            result += item.classification + "\n";
-          }
-          result += classification.finalLexState;
-          return result;
-        }
-      };
-      CoreServicesShimObject = class extends ShimBase {
-        constructor(factory2, logger, host) {
-          super(factory2);
-          this.logger = logger;
-          this.host = host;
-          this.logPerformance = false;
-        }
-        forwardJSONCall(actionDescription2, action) {
-          return forwardJSONCall(this.logger, actionDescription2, action, this.logPerformance);
-        }
-        resolveModuleName(fileName, moduleName, compilerOptionsJson) {
-          return this.forwardJSONCall(`resolveModuleName('${fileName}')`, () => {
-            const compilerOptions = JSON.parse(compilerOptionsJson);
-            const result = resolveModuleName(moduleName, normalizeSlashes(fileName), compilerOptions, this.host);
-            let resolvedFileName = result.resolvedModule ? result.resolvedModule.resolvedFileName : void 0;
-            if (result.resolvedModule && result.resolvedModule.extension !== ".ts" /* Ts */ && result.resolvedModule.extension !== ".tsx" /* Tsx */ && result.resolvedModule.extension !== ".d.ts" /* Dts */) {
-              resolvedFileName = void 0;
-            }
-            return {
-              resolvedFileName,
-              failedLookupLocations: result.failedLookupLocations,
-              affectingLocations: result.affectingLocations
-            };
-          });
-        }
-        resolveTypeReferenceDirective(fileName, typeReferenceDirective, compilerOptionsJson) {
-          return this.forwardJSONCall(`resolveTypeReferenceDirective(${fileName})`, () => {
-            const compilerOptions = JSON.parse(compilerOptionsJson);
-            const result = resolveTypeReferenceDirective(typeReferenceDirective, normalizeSlashes(fileName), compilerOptions, this.host);
-            return {
-              resolvedFileName: result.resolvedTypeReferenceDirective ? result.resolvedTypeReferenceDirective.resolvedFileName : void 0,
-              primary: result.resolvedTypeReferenceDirective ? result.resolvedTypeReferenceDirective.primary : true,
-              failedLookupLocations: result.failedLookupLocations
-            };
-          });
-        }
-        getPreProcessedFileInfo(fileName, sourceTextSnapshot) {
-          return this.forwardJSONCall(
-            `getPreProcessedFileInfo('${fileName}')`,
-            () => {
-              const result = preProcessFile(
-                getSnapshotText(sourceTextSnapshot),
-                /*readImportFiles*/
-                true,
-                /*detectJavaScriptImports*/
-                true
-              );
-              return {
-                referencedFiles: this.convertFileReferences(result.referencedFiles),
-                importedFiles: this.convertFileReferences(result.importedFiles),
-                ambientExternalModules: result.ambientExternalModules,
-                isLibFile: result.isLibFile,
-                typeReferenceDirectives: this.convertFileReferences(result.typeReferenceDirectives),
-                libReferenceDirectives: this.convertFileReferences(result.libReferenceDirectives)
-              };
-            }
-          );
-        }
-        getAutomaticTypeDirectiveNames(compilerOptionsJson) {
-          return this.forwardJSONCall(
-            `getAutomaticTypeDirectiveNames('${compilerOptionsJson}')`,
-            () => {
-              const compilerOptions = JSON.parse(compilerOptionsJson);
-              return getAutomaticTypeDirectiveNames(compilerOptions, this.host);
-            }
-          );
-        }
-        convertFileReferences(refs) {
-          if (!refs) {
-            return void 0;
-          }
-          const result = [];
-          for (const ref of refs) {
-            result.push({
-              path: normalizeSlashes(ref.fileName),
-              position: ref.pos,
-              length: ref.end - ref.pos
-            });
-          }
-          return result;
-        }
-        getTSConfigFileInfo(fileName, sourceTextSnapshot) {
-          return this.forwardJSONCall(
-            `getTSConfigFileInfo('${fileName}')`,
-            () => {
-              const result = parseJsonText(fileName, getSnapshotText(sourceTextSnapshot));
-              const normalizedFileName = normalizeSlashes(fileName);
-              const configFile = parseJsonSourceFileConfigFileContent(
-                result,
-                this.host,
-                getDirectoryPath(normalizedFileName),
-                /*existingOptions*/
-                {},
-                normalizedFileName
-              );
-              return {
-                options: configFile.options,
-                typeAcquisition: configFile.typeAcquisition,
-                files: configFile.fileNames,
-                raw: configFile.raw,
-                errors: realizeDiagnostics([...result.parseDiagnostics, ...configFile.errors], "\r\n")
-              };
-            }
-          );
-        }
-        getDefaultCompilationSettings() {
-          return this.forwardJSONCall(
-            "getDefaultCompilationSettings()",
-            () => getDefaultCompilerOptions2()
-          );
-        }
-        discoverTypings(discoverTypingsJson) {
-          const getCanonicalFileName = createGetCanonicalFileName(
-            /*useCaseSensitiveFileNames*/
-            false
-          );
-          return this.forwardJSONCall("discoverTypings()", () => {
-            const info = JSON.parse(discoverTypingsJson);
-            if (this.safeList === void 0) {
-              this.safeList = ts_JsTyping_exports.loadSafeList(this.host, toPath(info.safeListPath, info.safeListPath, getCanonicalFileName));
-            }
-            return ts_JsTyping_exports.discoverTypings(
-              this.host,
-              (msg) => this.logger.log(msg),
-              info.fileNames,
-              toPath(info.projectRootPath, info.projectRootPath, getCanonicalFileName),
-              this.safeList,
-              info.packageNameToTypingLocation,
-              info.typeAcquisition,
-              info.unresolvedImports,
-              info.typesRegistry,
-              emptyOptions
-            );
-          });
-        }
-      };
-      TypeScriptServicesFactory = class {
-        constructor() {
-          this._shims = [];
-        }
-        /*
-         * Returns script API version.
-         */
-        getServicesVersion() {
-          return servicesVersion;
-        }
-        createLanguageServiceShim(host) {
-          try {
-            if (this.documentRegistry === void 0) {
-              this.documentRegistry = createDocumentRegistry(host.useCaseSensitiveFileNames && host.useCaseSensitiveFileNames(), host.getCurrentDirectory());
-            }
-            const hostAdapter = new LanguageServiceShimHostAdapter(host);
-            const languageService = createLanguageService(
-              hostAdapter,
-              this.documentRegistry,
-              /*syntaxOnlyOrLanguageServiceMode*/
-              false
-            );
-            return new LanguageServiceShimObject(this, host, languageService);
-          } catch (err) {
-            logInternalError(host, err);
-            throw err;
-          }
-        }
-        createClassifierShim(logger) {
-          try {
-            return new ClassifierShimObject(this, logger);
-          } catch (err) {
-            logInternalError(logger, err);
-            throw err;
-          }
-        }
-        createCoreServicesShim(host) {
-          try {
-            const adapter = new CoreServicesShimHostAdapter(host);
-            return new CoreServicesShimObject(this, host, adapter);
-          } catch (err) {
-            logInternalError(host, err);
-            throw err;
-          }
-        }
-        close() {
-          clear(this._shims);
-          this.documentRegistry = void 0;
-        }
-        registerShim(shim) {
-          this._shims.push(shim);
-        }
-        unregisterShim(shim) {
-          for (let i = 0; i < this._shims.length; i++) {
-            if (this._shims[i] === shim) {
-              delete this._shims[i];
-              return;
-            }
-          }
-          throw new Error("Invalid operation");
-        }
-      };
-    }
-  });
-
-  // src/services/breakpoints.ts
-  function spanInSourceFileAtLocation(sourceFile, position) {
-    if (sourceFile.isDeclarationFile) {
-      return void 0;
-    }
-    let tokenAtLocation = getTokenAtPosition(sourceFile, position);
-    const lineOfPosition = sourceFile.getLineAndCharacterOfPosition(position).line;
-    if (sourceFile.getLineAndCharacterOfPosition(tokenAtLocation.getStart(sourceFile)).line > lineOfPosition) {
-      const preceding = findPrecedingToken(tokenAtLocation.pos, sourceFile);
-      if (!preceding || sourceFile.getLineAndCharacterOfPosition(preceding.getEnd()).line !== lineOfPosition) {
-        return void 0;
-      }
-      tokenAtLocation = preceding;
-    }
-    if (tokenAtLocation.flags & 16777216 /* Ambient */) {
-      return void 0;
-    }
-    return spanInNode(tokenAtLocation);
-    function textSpan(startNode2, endNode2) {
-      const lastDecorator = canHaveDecorators(startNode2) ? findLast(startNode2.modifiers, isDecorator) : void 0;
-      const start = lastDecorator ? skipTrivia(sourceFile.text, lastDecorator.end) : startNode2.getStart(sourceFile);
-      return createTextSpanFromBounds(start, (endNode2 || startNode2).getEnd());
-    }
-    function textSpanEndingAtNextToken(startNode2, previousTokenToFindNextEndToken) {
-      return textSpan(startNode2, findNextToken(previousTokenToFindNextEndToken, previousTokenToFindNextEndToken.parent, sourceFile));
-    }
-    function spanInNodeIfStartsOnSameLine(node, otherwiseOnNode) {
-      if (node && lineOfPosition === sourceFile.getLineAndCharacterOfPosition(node.getStart(sourceFile)).line) {
-        return spanInNode(node);
-      }
-      return spanInNode(otherwiseOnNode);
-    }
-    function spanInNodeArray(nodeArray, node, match) {
-      if (nodeArray) {
-        const index = nodeArray.indexOf(node);
-        if (index >= 0) {
-          let start = index;
-          let end = index + 1;
-          while (start > 0 && match(nodeArray[start - 1]))
-            start--;
-          while (end < nodeArray.length && match(nodeArray[end]))
-            end++;
-          return createTextSpanFromBounds(skipTrivia(sourceFile.text, nodeArray[start].pos), nodeArray[end - 1].end);
-        }
-      }
-      return textSpan(node);
-    }
-    function spanInPreviousNode(node) {
-      return spanInNode(findPrecedingToken(node.pos, sourceFile));
-    }
-    function spanInNextNode(node) {
-      return spanInNode(findNextToken(node, node.parent, sourceFile));
-    }
-    function spanInNode(node) {
-      if (node) {
-        const { parent: parent2 } = node;
-        switch (node.kind) {
-          case 242 /* VariableStatement */:
-            return spanInVariableDeclaration(node.declarationList.declarations[0]);
-          case 259 /* VariableDeclaration */:
-          case 171 /* PropertyDeclaration */:
-          case 170 /* PropertySignature */:
-            return spanInVariableDeclaration(node);
-          case 168 /* Parameter */:
-            return spanInParameterDeclaration(node);
-          case 261 /* FunctionDeclaration */:
-          case 173 /* MethodDeclaration */:
-          case 172 /* MethodSignature */:
-          case 176 /* GetAccessor */:
-          case 177 /* SetAccessor */:
-          case 175 /* Constructor */:
-          case 217 /* FunctionExpression */:
-          case 218 /* ArrowFunction */:
-            return spanInFunctionDeclaration(node);
-          case 240 /* Block */:
-            if (isFunctionBlock(node)) {
-              return spanInFunctionBlock(node);
-            }
-          case 267 /* ModuleBlock */:
-            return spanInBlock(node);
-          case 298 /* CatchClause */:
-            return spanInBlock(node.block);
-          case 243 /* ExpressionStatement */:
-            return textSpan(node.expression);
-          case 252 /* ReturnStatement */:
-            return textSpan(node.getChildAt(0), node.expression);
-          case 246 /* WhileStatement */:
-            return textSpanEndingAtNextToken(node, node.expression);
-          case 245 /* DoStatement */:
-            return spanInNode(node.statement);
-          case 258 /* DebuggerStatement */:
-            return textSpan(node.getChildAt(0));
-          case 244 /* IfStatement */:
-            return textSpanEndingAtNextToken(node, node.expression);
-          case 255 /* LabeledStatement */:
-            return spanInNode(node.statement);
-          case 251 /* BreakStatement */:
-          case 250 /* ContinueStatement */:
-            return textSpan(node.getChildAt(0), node.label);
-          case 247 /* ForStatement */:
-            return spanInForStatement(node);
-          case 248 /* ForInStatement */:
-            return textSpanEndingAtNextToken(node, node.expression);
-          case 249 /* ForOfStatement */:
-            return spanInInitializerOfForLike(node);
-          case 254 /* SwitchStatement */:
-            return textSpanEndingAtNextToken(node, node.expression);
-          case 295 /* CaseClause */:
-          case 296 /* DefaultClause */:
-            return spanInNode(node.statements[0]);
-          case 257 /* TryStatement */:
-            return spanInBlock(node.tryBlock);
-          case 256 /* ThrowStatement */:
-            return textSpan(node, node.expression);
-          case 276 /* ExportAssignment */:
-            return textSpan(node, node.expression);
-          case 270 /* ImportEqualsDeclaration */:
-            return textSpan(node, node.moduleReference);
-          case 271 /* ImportDeclaration */:
-            return textSpan(node, node.moduleSpecifier);
-          case 277 /* ExportDeclaration */:
-            return textSpan(node, node.moduleSpecifier);
-          case 266 /* ModuleDeclaration */:
-            if (getModuleInstanceState(node) !== 1 /* Instantiated */) {
-              return void 0;
-            }
-          case 262 /* ClassDeclaration */:
-          case 265 /* EnumDeclaration */:
-          case 305 /* EnumMember */:
-          case 207 /* BindingElement */:
-            return textSpan(node);
-          case 253 /* WithStatement */:
-            return spanInNode(node.statement);
-          case 169 /* Decorator */:
-            return spanInNodeArray(parent2.modifiers, node, isDecorator);
-          case 205 /* ObjectBindingPattern */:
-          case 206 /* ArrayBindingPattern */:
-            return spanInBindingPattern(node);
-          case 263 /* InterfaceDeclaration */:
-          case 264 /* TypeAliasDeclaration */:
-            return void 0;
-          case 27 /* SemicolonToken */:
-          case 1 /* EndOfFileToken */:
-            return spanInNodeIfStartsOnSameLine(findPrecedingToken(node.pos, sourceFile));
-          case 28 /* CommaToken */:
-            return spanInPreviousNode(node);
-          case 19 /* OpenBraceToken */:
-            return spanInOpenBraceToken(node);
-          case 20 /* CloseBraceToken */:
-            return spanInCloseBraceToken(node);
-          case 24 /* CloseBracketToken */:
-            return spanInCloseBracketToken(node);
-          case 21 /* OpenParenToken */:
-            return spanInOpenParenToken(node);
-          case 22 /* CloseParenToken */:
-            return spanInCloseParenToken(node);
-          case 59 /* ColonToken */:
-            return spanInColonToken(node);
-          case 32 /* GreaterThanToken */:
-          case 30 /* LessThanToken */:
-            return spanInGreaterThanOrLessThanToken(node);
-          case 117 /* WhileKeyword */:
-            return spanInWhileKeyword(node);
-          case 93 /* ElseKeyword */:
-          case 85 /* CatchKeyword */:
-          case 98 /* FinallyKeyword */:
-            return spanInNextNode(node);
-          case 164 /* OfKeyword */:
-            return spanInOfKeyword(node);
-          default:
-            if (isArrayLiteralOrObjectLiteralDestructuringPattern(node)) {
-              return spanInArrayLiteralOrObjectLiteralDestructuringPattern(node);
-            }
-            if ((node.kind === 80 /* Identifier */ || node.kind === 229 /* SpreadElement */ || node.kind === 302 /* PropertyAssignment */ || node.kind === 303 /* ShorthandPropertyAssignment */) && isArrayLiteralOrObjectLiteralDestructuringPattern(parent2)) {
-              return textSpan(node);
-            }
-            if (node.kind === 225 /* BinaryExpression */) {
-              const { left, operatorToken } = node;
-              if (isArrayLiteralOrObjectLiteralDestructuringPattern(left)) {
-                return spanInArrayLiteralOrObjectLiteralDestructuringPattern(
-                  left
-                );
-              }
-              if (operatorToken.kind === 64 /* EqualsToken */ && isArrayLiteralOrObjectLiteralDestructuringPattern(node.parent)) {
-                return textSpan(node);
-              }
-              if (operatorToken.kind === 28 /* CommaToken */) {
-                return spanInNode(left);
-              }
-            }
-            if (isExpressionNode(node)) {
-              switch (parent2.kind) {
-                case 245 /* DoStatement */:
-                  return spanInPreviousNode(node);
-                case 169 /* Decorator */:
-                  return spanInNode(node.parent);
-                case 247 /* ForStatement */:
-                case 249 /* ForOfStatement */:
-                  return textSpan(node);
-                case 225 /* BinaryExpression */:
-                  if (node.parent.operatorToken.kind === 28 /* CommaToken */) {
-                    return textSpan(node);
-                  }
-                  break;
-                case 218 /* ArrowFunction */:
-                  if (node.parent.body === node) {
-                    return textSpan(node);
-                  }
-                  break;
-              }
-            }
-            switch (node.parent.kind) {
-              case 302 /* PropertyAssignment */:
-                if (node.parent.name === node && !isArrayLiteralOrObjectLiteralDestructuringPattern(node.parent.parent)) {
-                  return spanInNode(node.parent.initializer);
-                }
-                break;
-              case 215 /* TypeAssertionExpression */:
-                if (node.parent.type === node) {
-                  return spanInNextNode(node.parent.type);
-                }
-                break;
-              case 259 /* VariableDeclaration */:
-              case 168 /* Parameter */: {
-                const { initializer, type } = node.parent;
-                if (initializer === node || type === node || isAssignmentOperator(node.kind)) {
-                  return spanInPreviousNode(node);
-                }
-                break;
-              }
-              case 225 /* BinaryExpression */: {
-                const { left } = node.parent;
-                if (isArrayLiteralOrObjectLiteralDestructuringPattern(left) && node !== left) {
-                  return spanInPreviousNode(node);
-                }
-                break;
-              }
-              default:
-                if (isFunctionLike(node.parent) && node.parent.type === node) {
-                  return spanInPreviousNode(node);
-                }
-            }
-            return spanInNode(node.parent);
-        }
-      }
-      function textSpanFromVariableDeclaration(variableDeclaration) {
-        if (isVariableDeclarationList(variableDeclaration.parent) && variableDeclaration.parent.declarations[0] === variableDeclaration) {
-          return textSpan(findPrecedingToken(variableDeclaration.pos, sourceFile, variableDeclaration.parent), variableDeclaration);
-        } else {
-          return textSpan(variableDeclaration);
-        }
-      }
-      function spanInVariableDeclaration(variableDeclaration) {
-        if (variableDeclaration.parent.parent.kind === 248 /* ForInStatement */) {
-          return spanInNode(variableDeclaration.parent.parent);
-        }
-        const parent2 = variableDeclaration.parent;
-        if (isBindingPattern(variableDeclaration.name)) {
-          return spanInBindingPattern(variableDeclaration.name);
-        }
-        if (hasOnlyExpressionInitializer(variableDeclaration) && variableDeclaration.initializer || hasSyntacticModifier(variableDeclaration, 1 /* Export */) || parent2.parent.kind === 249 /* ForOfStatement */) {
-          return textSpanFromVariableDeclaration(variableDeclaration);
-        }
-        if (isVariableDeclarationList(variableDeclaration.parent) && variableDeclaration.parent.declarations[0] !== variableDeclaration) {
-          return spanInNode(findPrecedingToken(variableDeclaration.pos, sourceFile, variableDeclaration.parent));
-        }
-      }
-      function canHaveSpanInParameterDeclaration(parameter) {
-        return !!parameter.initializer || parameter.dotDotDotToken !== void 0 || hasSyntacticModifier(parameter, 4 /* Public */ | 8 /* Private */);
-      }
-      function spanInParameterDeclaration(parameter) {
-        if (isBindingPattern(parameter.name)) {
-          return spanInBindingPattern(parameter.name);
-        } else if (canHaveSpanInParameterDeclaration(parameter)) {
-          return textSpan(parameter);
-        } else {
-          const functionDeclaration = parameter.parent;
-          const indexOfParameter = functionDeclaration.parameters.indexOf(parameter);
-          Debug.assert(indexOfParameter !== -1);
-          if (indexOfParameter !== 0) {
-            return spanInParameterDeclaration(functionDeclaration.parameters[indexOfParameter - 1]);
-          } else {
-            return spanInNode(functionDeclaration.body);
-          }
-        }
-      }
-      function canFunctionHaveSpanInWholeDeclaration(functionDeclaration) {
-        return hasSyntacticModifier(functionDeclaration, 1 /* Export */) || functionDeclaration.parent.kind === 262 /* ClassDeclaration */ && functionDeclaration.kind !== 175 /* Constructor */;
-      }
-      function spanInFunctionDeclaration(functionDeclaration) {
-        if (!functionDeclaration.body) {
-          return void 0;
-        }
-        if (canFunctionHaveSpanInWholeDeclaration(functionDeclaration)) {
-          return textSpan(functionDeclaration);
-        }
-        return spanInNode(functionDeclaration.body);
-      }
-      function spanInFunctionBlock(block) {
-        const nodeForSpanInBlock = block.statements.length ? block.statements[0] : block.getLastToken();
-        if (canFunctionHaveSpanInWholeDeclaration(block.parent)) {
-          return spanInNodeIfStartsOnSameLine(block.parent, nodeForSpanInBlock);
-        }
-        return spanInNode(nodeForSpanInBlock);
-      }
-      function spanInBlock(block) {
-        switch (block.parent.kind) {
-          case 266 /* ModuleDeclaration */:
-            if (getModuleInstanceState(block.parent) !== 1 /* Instantiated */) {
-              return void 0;
-            }
-          case 246 /* WhileStatement */:
-          case 244 /* IfStatement */:
-          case 248 /* ForInStatement */:
-            return spanInNodeIfStartsOnSameLine(block.parent, block.statements[0]);
-          case 247 /* ForStatement */:
-          case 249 /* ForOfStatement */:
-            return spanInNodeIfStartsOnSameLine(findPrecedingToken(block.pos, sourceFile, block.parent), block.statements[0]);
-        }
-        return spanInNode(block.statements[0]);
-      }
-      function spanInInitializerOfForLike(forLikeStatement) {
-        if (forLikeStatement.initializer.kind === 260 /* VariableDeclarationList */) {
-          const variableDeclarationList = forLikeStatement.initializer;
-          if (variableDeclarationList.declarations.length > 0) {
-            return spanInNode(variableDeclarationList.declarations[0]);
-          }
-        } else {
-          return spanInNode(forLikeStatement.initializer);
-        }
-      }
-      function spanInForStatement(forStatement) {
-        if (forStatement.initializer) {
-          return spanInInitializerOfForLike(forStatement);
-        }
-        if (forStatement.condition) {
-          return textSpan(forStatement.condition);
-        }
-        if (forStatement.incrementor) {
-          return textSpan(forStatement.incrementor);
-        }
-      }
-      function spanInBindingPattern(bindingPattern) {
-        const firstBindingElement = forEach(
-          bindingPattern.elements,
-          (element) => element.kind !== 231 /* OmittedExpression */ ? element : void 0
-        );
-        if (firstBindingElement) {
-          return spanInNode(firstBindingElement);
-        }
-        if (bindingPattern.parent.kind === 207 /* BindingElement */) {
-          return textSpan(bindingPattern.parent);
-        }
-        return textSpanFromVariableDeclaration(bindingPattern.parent);
-      }
-      function spanInArrayLiteralOrObjectLiteralDestructuringPattern(node2) {
-        Debug.assert(node2.kind !== 206 /* ArrayBindingPattern */ && node2.kind !== 205 /* ObjectBindingPattern */);
-        const elements = node2.kind === 208 /* ArrayLiteralExpression */ ? node2.elements : node2.properties;
-        const firstBindingElement = forEach(
-          elements,
-          (element) => element.kind !== 231 /* OmittedExpression */ ? element : void 0
-        );
-        if (firstBindingElement) {
-          return spanInNode(firstBindingElement);
-        }
-        return textSpan(node2.parent.kind === 225 /* BinaryExpression */ ? node2.parent : node2);
-      }
-      function spanInOpenBraceToken(node2) {
-        switch (node2.parent.kind) {
-          case 265 /* EnumDeclaration */:
-            const enumDeclaration = node2.parent;
-            return spanInNodeIfStartsOnSameLine(findPrecedingToken(node2.pos, sourceFile, node2.parent), enumDeclaration.members.length ? enumDeclaration.members[0] : enumDeclaration.getLastToken(sourceFile));
-          case 262 /* ClassDeclaration */:
-            const classDeclaration = node2.parent;
-            return spanInNodeIfStartsOnSameLine(findPrecedingToken(node2.pos, sourceFile, node2.parent), classDeclaration.members.length ? classDeclaration.members[0] : classDeclaration.getLastToken(sourceFile));
-          case 268 /* CaseBlock */:
-            return spanInNodeIfStartsOnSameLine(node2.parent.parent, node2.parent.clauses[0]);
-        }
-        return spanInNode(node2.parent);
-      }
-      function spanInCloseBraceToken(node2) {
-        switch (node2.parent.kind) {
-          case 267 /* ModuleBlock */:
-            if (getModuleInstanceState(node2.parent.parent) !== 1 /* Instantiated */) {
-              return void 0;
-            }
-          case 265 /* EnumDeclaration */:
-          case 262 /* ClassDeclaration */:
-            return textSpan(node2);
-          case 240 /* Block */:
-            if (isFunctionBlock(node2.parent)) {
-              return textSpan(node2);
-            }
-          case 298 /* CatchClause */:
-            return spanInNode(lastOrUndefined(node2.parent.statements));
-          case 268 /* CaseBlock */:
-            const caseBlock = node2.parent;
-            const lastClause = lastOrUndefined(caseBlock.clauses);
-            if (lastClause) {
-              return spanInNode(lastOrUndefined(lastClause.statements));
-            }
-            return void 0;
-          case 205 /* ObjectBindingPattern */:
-            const bindingPattern = node2.parent;
-            return spanInNode(lastOrUndefined(bindingPattern.elements) || bindingPattern);
-          default:
-            if (isArrayLiteralOrObjectLiteralDestructuringPattern(node2.parent)) {
-              const objectLiteral = node2.parent;
-              return textSpan(lastOrUndefined(objectLiteral.properties) || objectLiteral);
-            }
-            return spanInNode(node2.parent);
-        }
-      }
-      function spanInCloseBracketToken(node2) {
-        switch (node2.parent.kind) {
-          case 206 /* ArrayBindingPattern */:
-            const bindingPattern = node2.parent;
-            return textSpan(lastOrUndefined(bindingPattern.elements) || bindingPattern);
-          default:
-            if (isArrayLiteralOrObjectLiteralDestructuringPattern(node2.parent)) {
-              const arrayLiteral = node2.parent;
-              return textSpan(lastOrUndefined(arrayLiteral.elements) || arrayLiteral);
-            }
-            return spanInNode(node2.parent);
-        }
-      }
-      function spanInOpenParenToken(node2) {
-        if (node2.parent.kind === 245 /* DoStatement */ || // Go to while keyword and do action instead
-        node2.parent.kind === 212 /* CallExpression */ || node2.parent.kind === 213 /* NewExpression */) {
-          return spanInPreviousNode(node2);
-        }
-        if (node2.parent.kind === 216 /* ParenthesizedExpression */) {
-          return spanInNextNode(node2);
-        }
-        return spanInNode(node2.parent);
-      }
-      function spanInCloseParenToken(node2) {
-        switch (node2.parent.kind) {
-          case 217 /* FunctionExpression */:
-          case 261 /* FunctionDeclaration */:
-          case 218 /* ArrowFunction */:
-          case 173 /* MethodDeclaration */:
-          case 172 /* MethodSignature */:
-          case 176 /* GetAccessor */:
-          case 177 /* SetAccessor */:
-          case 175 /* Constructor */:
-          case 246 /* WhileStatement */:
-          case 245 /* DoStatement */:
-          case 247 /* ForStatement */:
-          case 249 /* ForOfStatement */:
-          case 212 /* CallExpression */:
-          case 213 /* NewExpression */:
-          case 216 /* ParenthesizedExpression */:
-            return spanInPreviousNode(node2);
-          default:
-            return spanInNode(node2.parent);
-        }
-      }
-      function spanInColonToken(node2) {
-        if (isFunctionLike(node2.parent) || node2.parent.kind === 302 /* PropertyAssignment */ || node2.parent.kind === 168 /* Parameter */) {
-          return spanInPreviousNode(node2);
-        }
-        return spanInNode(node2.parent);
-      }
-      function spanInGreaterThanOrLessThanToken(node2) {
-        if (node2.parent.kind === 215 /* TypeAssertionExpression */) {
-          return spanInNextNode(node2);
-        }
-        return spanInNode(node2.parent);
-      }
-      function spanInWhileKeyword(node2) {
-        if (node2.parent.kind === 245 /* DoStatement */) {
-          return textSpanEndingAtNextToken(node2, node2.parent.expression);
-        }
-        return spanInNode(node2.parent);
-      }
-      function spanInOfKeyword(node2) {
-        if (node2.parent.kind === 249 /* ForOfStatement */) {
-          return spanInNextNode(node2);
-        }
-        return spanInNode(node2.parent);
-      }
-    }
-  }
-  var init_breakpoints = __esm({
-    "src/services/breakpoints.ts"() {
-      "use strict";
-      init_ts4();
-    }
-  });
-
-  // src/services/_namespaces/ts.BreakpointResolver.ts
-  var ts_BreakpointResolver_exports = {};
-  __export(ts_BreakpointResolver_exports, {
-    spanInSourceFileAtLocation: () => spanInSourceFileAtLocation
-  });
-  var init_ts_BreakpointResolver = __esm({
-    "src/services/_namespaces/ts.BreakpointResolver.ts"() {
-      "use strict";
-      init_breakpoints();
-    }
-  });
-
-  // src/services/callHierarchy.ts
-  function isNamedExpression(node) {
-    return (isFunctionExpression(node) || isClassExpression(node)) && isNamedDeclaration(node);
-  }
-  function isConstNamedExpression(node) {
-    return (isFunctionExpression(node) || isArrowFunction(node) || isClassExpression(node)) && isVariableDeclaration(node.parent) && node === node.parent.initializer && isIdentifier(node.parent.name) && !!(getCombinedNodeFlags(node.parent) & 2 /* Const */);
-  }
-  function isPossibleCallHierarchyDeclaration(node) {
-    return isSourceFile(node) || isModuleDeclaration(node) || isFunctionDeclaration(node) || isFunctionExpression(node) || isClassDeclaration(node) || isClassExpression(node) || isClassStaticBlockDeclaration(node) || isMethodDeclaration(node) || isMethodSignature(node) || isGetAccessorDeclaration(node) || isSetAccessorDeclaration(node);
-  }
-  function isValidCallHierarchyDeclaration(node) {
-    return isSourceFile(node) || isModuleDeclaration(node) && isIdentifier(node.name) || isFunctionDeclaration(node) || isClassDeclaration(node) || isClassStaticBlockDeclaration(node) || isMethodDeclaration(node) || isMethodSignature(node) || isGetAccessorDeclaration(node) || isSetAccessorDeclaration(node) || isNamedExpression(node) || isConstNamedExpression(node);
-  }
-  function getCallHierarchyDeclarationReferenceNode(node) {
-    if (isSourceFile(node))
-      return node;
-    if (isNamedDeclaration(node))
-      return node.name;
-    if (isConstNamedExpression(node))
-      return node.parent.name;
-    return Debug.checkDefined(node.modifiers && find(node.modifiers, isDefaultModifier3));
-  }
-  function isDefaultModifier3(node) {
-    return node.kind === 90 /* DefaultKeyword */;
-  }
-  function getSymbolOfCallHierarchyDeclaration(typeChecker, node) {
-    const location = getCallHierarchyDeclarationReferenceNode(node);
-    return location && typeChecker.getSymbolAtLocation(location);
-  }
-  function getCallHierarchyItemName(program, node) {
-    if (isSourceFile(node)) {
-      return { text: node.fileName, pos: 0, end: 0 };
-    }
-    if ((isFunctionDeclaration(node) || isClassDeclaration(node)) && !isNamedDeclaration(node)) {
-      const defaultModifier = node.modifiers && find(node.modifiers, isDefaultModifier3);
-      if (defaultModifier) {
-        return { text: "default", pos: defaultModifier.getStart(), end: defaultModifier.getEnd() };
-      }
-    }
-    if (isClassStaticBlockDeclaration(node)) {
-      const sourceFile = node.getSourceFile();
-      const pos = skipTrivia(sourceFile.text, moveRangePastModifiers(node).pos);
-      const end = pos + 6;
-      const typeChecker = program.getTypeChecker();
-      const symbol = typeChecker.getSymbolAtLocation(node.parent);
-      const prefix = symbol ? `${typeChecker.symbolToString(symbol, node.parent)} ` : "";
-      return { text: `${prefix}static {}`, pos, end };
-    }
-    const declName = isConstNamedExpression(node) ? node.parent.name : Debug.checkDefined(getNameOfDeclaration(node), "Expected call hierarchy item to have a name");
-    let text = isIdentifier(declName) ? idText(declName) : isStringOrNumericLiteralLike(declName) ? declName.text : isComputedPropertyName(declName) ? isStringOrNumericLiteralLike(declName.expression) ? declName.expression.text : void 0 : void 0;
-    if (text === void 0) {
-      const typeChecker = program.getTypeChecker();
-      const symbol = typeChecker.getSymbolAtLocation(declName);
-      if (symbol) {
-        text = typeChecker.symbolToString(symbol, node);
-      }
-    }
-    if (text === void 0) {
-      const printer = createPrinterWithRemoveCommentsOmitTrailingSemicolon();
-      text = usingSingleLineStringWriter((writer) => printer.writeNode(4 /* Unspecified */, node, node.getSourceFile(), writer));
-    }
-    return { text, pos: declName.getStart(), end: declName.getEnd() };
-  }
-  function getCallHierarchItemContainerName(node) {
-    var _a, _b;
-    if (isConstNamedExpression(node)) {
-      if (isModuleBlock(node.parent.parent.parent.parent) && isIdentifier(node.parent.parent.parent.parent.parent.name)) {
-        return node.parent.parent.parent.parent.parent.name.getText();
-      }
-      return;
-    }
-    switch (node.kind) {
-      case 176 /* GetAccessor */:
-      case 177 /* SetAccessor */:
-      case 173 /* MethodDeclaration */:
-        if (node.parent.kind === 209 /* ObjectLiteralExpression */) {
-          return (_a = getAssignedName(node.parent)) == null ? void 0 : _a.getText();
-        }
-        return (_b = getNameOfDeclaration(node.parent)) == null ? void 0 : _b.getText();
-      case 261 /* FunctionDeclaration */:
-      case 262 /* ClassDeclaration */:
-      case 266 /* ModuleDeclaration */:
-        if (isModuleBlock(node.parent) && isIdentifier(node.parent.parent.name)) {
-          return node.parent.parent.name.getText();
-        }
-    }
-  }
-  function findImplementation(typeChecker, node) {
-    if (node.body) {
-      return node;
-    }
-    if (isConstructorDeclaration(node)) {
-      return getFirstConstructorWithBody(node.parent);
-    }
-    if (isFunctionDeclaration(node) || isMethodDeclaration(node)) {
-      const symbol = getSymbolOfCallHierarchyDeclaration(typeChecker, node);
-      if (symbol && symbol.valueDeclaration && isFunctionLikeDeclaration(symbol.valueDeclaration) && symbol.valueDeclaration.body) {
-        return symbol.valueDeclaration;
-      }
-      return void 0;
-    }
-    return node;
-  }
-  function findAllInitialDeclarations(typeChecker, node) {
-    const symbol = getSymbolOfCallHierarchyDeclaration(typeChecker, node);
-    let declarations;
-    if (symbol && symbol.declarations) {
-      const indices = indicesOf(symbol.declarations);
-      const keys = map(symbol.declarations, (decl) => ({ file: decl.getSourceFile().fileName, pos: decl.pos }));
-      indices.sort((a, b) => compareStringsCaseSensitive(keys[a].file, keys[b].file) || keys[a].pos - keys[b].pos);
-      const sortedDeclarations = map(indices, (i) => symbol.declarations[i]);
-      let lastDecl;
-      for (const decl of sortedDeclarations) {
-        if (isValidCallHierarchyDeclaration(decl)) {
-          if (!lastDecl || lastDecl.parent !== decl.parent || lastDecl.end !== decl.pos) {
-            declarations = append(declarations, decl);
-          }
-          lastDecl = decl;
-        }
-      }
-    }
-    return declarations;
-  }
-  function findImplementationOrAllInitialDeclarations(typeChecker, node) {
-    if (isClassStaticBlockDeclaration(node)) {
-      return node;
-    }
-    if (isFunctionLikeDeclaration(node)) {
-      return findImplementation(typeChecker, node) ?? findAllInitialDeclarations(typeChecker, node) ?? node;
-    }
-    return findAllInitialDeclarations(typeChecker, node) ?? node;
-  }
-  function resolveCallHierarchyDeclaration(program, location) {
-    const typeChecker = program.getTypeChecker();
-    let followingSymbol = false;
-    while (true) {
-      if (isValidCallHierarchyDeclaration(location)) {
-        return findImplementationOrAllInitialDeclarations(typeChecker, location);
-      }
-      if (isPossibleCallHierarchyDeclaration(location)) {
-        const ancestor = findAncestor(location, isValidCallHierarchyDeclaration);
-        return ancestor && findImplementationOrAllInitialDeclarations(typeChecker, ancestor);
-      }
-      if (isDeclarationName(location)) {
-        if (isValidCallHierarchyDeclaration(location.parent)) {
-          return findImplementationOrAllInitialDeclarations(typeChecker, location.parent);
-        }
-        if (isPossibleCallHierarchyDeclaration(location.parent)) {
-          const ancestor = findAncestor(location.parent, isValidCallHierarchyDeclaration);
-          return ancestor && findImplementationOrAllInitialDeclarations(typeChecker, ancestor);
-        }
-        if (isVariableDeclaration(location.parent) && location.parent.initializer && isConstNamedExpression(location.parent.initializer)) {
-          return location.parent.initializer;
-        }
-        return void 0;
-      }
-      if (isConstructorDeclaration(location)) {
-        if (isValidCallHierarchyDeclaration(location.parent)) {
-          return location.parent;
-        }
-        return void 0;
-      }
-      if (location.kind === 126 /* StaticKeyword */ && isClassStaticBlockDeclaration(location.parent)) {
-        location = location.parent;
-        continue;
-      }
-      if (isVariableDeclaration(location) && location.initializer && isConstNamedExpression(location.initializer)) {
-        return location.initializer;
-      }
-      if (!followingSymbol) {
-        let symbol = typeChecker.getSymbolAtLocation(location);
-        if (symbol) {
-          if (symbol.flags & 2097152 /* Alias */) {
-            symbol = typeChecker.getAliasedSymbol(symbol);
-          }
-          if (symbol.valueDeclaration) {
-            followingSymbol = true;
-            location = symbol.valueDeclaration;
-            continue;
-          }
-        }
-      }
-      return void 0;
-    }
-  }
-  function createCallHierarchyItem(program, node) {
-    const sourceFile = node.getSourceFile();
-    const name = getCallHierarchyItemName(program, node);
-    const containerName = getCallHierarchItemContainerName(node);
-    const kind = getNodeKind(node);
-    const kindModifiers = getNodeModifiers(node);
-    const span = createTextSpanFromBounds(skipTrivia(
-      sourceFile.text,
-      node.getFullStart(),
-      /*stopAfterLineBreak*/
-      false,
-      /*stopAtComments*/
-      true
-    ), node.getEnd());
-    const selectionSpan = createTextSpanFromBounds(name.pos, name.end);
-    return { file: sourceFile.fileName, kind, kindModifiers, name: name.text, containerName, span, selectionSpan };
-  }
-  function isDefined(x) {
-    return x !== void 0;
-  }
-  function convertEntryToCallSite(entry) {
-    if (entry.kind === ts_FindAllReferences_exports.EntryKind.Node) {
-      const { node } = entry;
-      if (isCallOrNewExpressionTarget(
-        node,
-        /*includeElementAccess*/
-        true,
-        /*skipPastOuterExpressions*/
-        true
-      ) || isTaggedTemplateTag(
-        node,
-        /*includeElementAccess*/
-        true,
-        /*skipPastOuterExpressions*/
-        true
-      ) || isDecoratorTarget(
-        node,
-        /*includeElementAccess*/
-        true,
-        /*skipPastOuterExpressions*/
-        true
-      ) || isJsxOpeningLikeElementTagName(
-        node,
-        /*includeElementAccess*/
-        true,
-        /*skipPastOuterExpressions*/
-        true
-      ) || isRightSideOfPropertyAccess(node) || isArgumentExpressionOfElementAccess(node)) {
-        const sourceFile = node.getSourceFile();
-        const ancestor = findAncestor(node, isValidCallHierarchyDeclaration) || sourceFile;
-        return { declaration: ancestor, range: createTextRangeFromNode(node, sourceFile) };
-      }
-    }
-  }
-  function getCallSiteGroupKey(entry) {
-    return getNodeId(entry.declaration);
-  }
-  function createCallHierarchyIncomingCall(from, fromSpans) {
-    return { from, fromSpans };
-  }
-  function convertCallSiteGroupToIncomingCall(program, entries) {
-    return createCallHierarchyIncomingCall(createCallHierarchyItem(program, entries[0].declaration), map(entries, (entry) => createTextSpanFromRange(entry.range)));
-  }
-  function getIncomingCalls(program, declaration, cancellationToken) {
-    if (isSourceFile(declaration) || isModuleDeclaration(declaration) || isClassStaticBlockDeclaration(declaration)) {
-      return [];
-    }
-    const location = getCallHierarchyDeclarationReferenceNode(declaration);
-    const calls = filter(ts_FindAllReferences_exports.findReferenceOrRenameEntries(
-      program,
-      cancellationToken,
-      program.getSourceFiles(),
-      location,
-      /*position*/
-      0,
-      { use: ts_FindAllReferences_exports.FindReferencesUse.References },
-      convertEntryToCallSite
-    ), isDefined);
-    return calls ? group(calls, getCallSiteGroupKey, (entries) => convertCallSiteGroupToIncomingCall(program, entries)) : [];
-  }
-  function createCallSiteCollector(program, callSites) {
-    function recordCallSite(node) {
-      const target = isTaggedTemplateExpression(node) ? node.tag : isJsxOpeningLikeElement(node) ? node.tagName : isAccessExpression(node) ? node : isClassStaticBlockDeclaration(node) ? node : node.expression;
-      const declaration = resolveCallHierarchyDeclaration(program, target);
-      if (declaration) {
-        const range = createTextRangeFromNode(target, node.getSourceFile());
-        if (isArray(declaration)) {
-          for (const decl of declaration) {
-            callSites.push({ declaration: decl, range });
-          }
-        } else {
-          callSites.push({ declaration, range });
-        }
-      }
-    }
-    function collect(node) {
-      if (!node)
-        return;
-      if (node.flags & 16777216 /* Ambient */) {
-        return;
-      }
-      if (isValidCallHierarchyDeclaration(node)) {
-        if (isClassLike(node)) {
-          for (const member of node.members) {
-            if (member.name && isComputedPropertyName(member.name)) {
-              collect(member.name.expression);
-            }
-          }
-        }
-        return;
-      }
-      switch (node.kind) {
-        case 80 /* Identifier */:
-        case 270 /* ImportEqualsDeclaration */:
-        case 271 /* ImportDeclaration */:
-        case 277 /* ExportDeclaration */:
-        case 263 /* InterfaceDeclaration */:
-        case 264 /* TypeAliasDeclaration */:
-          return;
-        case 174 /* ClassStaticBlockDeclaration */:
-          recordCallSite(node);
-          return;
-        case 215 /* TypeAssertionExpression */:
-        case 233 /* AsExpression */:
-          collect(node.expression);
-          return;
-        case 259 /* VariableDeclaration */:
-        case 168 /* Parameter */:
-          collect(node.name);
-          collect(node.initializer);
-          return;
-        case 212 /* CallExpression */:
-          recordCallSite(node);
-          collect(node.expression);
-          forEach(node.arguments, collect);
-          return;
-        case 213 /* NewExpression */:
-          recordCallSite(node);
-          collect(node.expression);
-          forEach(node.arguments, collect);
-          return;
-        case 214 /* TaggedTemplateExpression */:
-          recordCallSite(node);
-          collect(node.tag);
-          collect(node.template);
-          return;
-        case 285 /* JsxOpeningElement */:
-        case 284 /* JsxSelfClosingElement */:
-          recordCallSite(node);
-          collect(node.tagName);
-          collect(node.attributes);
-          return;
-        case 169 /* Decorator */:
-          recordCallSite(node);
-          collect(node.expression);
-          return;
-        case 210 /* PropertyAccessExpression */:
-        case 211 /* ElementAccessExpression */:
-          recordCallSite(node);
-          forEachChild(node, collect);
-          break;
-        case 237 /* SatisfiesExpression */:
-          collect(node.expression);
-          return;
-      }
-      if (isPartOfTypeNode(node)) {
-        return;
-      }
-      forEachChild(node, collect);
-    }
-    return collect;
-  }
-  function collectCallSitesOfSourceFile(node, collect) {
-    forEach(node.statements, collect);
-  }
-  function collectCallSitesOfModuleDeclaration(node, collect) {
-    if (!hasSyntacticModifier(node, 2 /* Ambient */) && node.body && isModuleBlock(node.body)) {
-      forEach(node.body.statements, collect);
-    }
-  }
-  function collectCallSitesOfFunctionLikeDeclaration(typeChecker, node, collect) {
-    const implementation = findImplementation(typeChecker, node);
-    if (implementation) {
-      forEach(implementation.parameters, collect);
-      collect(implementation.body);
-    }
-  }
-  function collectCallSitesOfClassStaticBlockDeclaration(node, collect) {
-    collect(node.body);
-  }
-  function collectCallSitesOfClassLikeDeclaration(node, collect) {
-    forEach(node.modifiers, collect);
-    const heritage = getClassExtendsHeritageElement(node);
-    if (heritage) {
-      collect(heritage.expression);
-    }
-    for (const member of node.members) {
-      if (canHaveModifiers(member)) {
-        forEach(member.modifiers, collect);
-      }
-      if (isPropertyDeclaration(member)) {
-        collect(member.initializer);
-      } else if (isConstructorDeclaration(member) && member.body) {
-        forEach(member.parameters, collect);
-        collect(member.body);
-      } else if (isClassStaticBlockDeclaration(member)) {
-        collect(member);
-      }
-    }
-  }
-  function collectCallSites(program, node) {
-    const callSites = [];
-    const collect = createCallSiteCollector(program, callSites);
-    switch (node.kind) {
-      case 311 /* SourceFile */:
-        collectCallSitesOfSourceFile(node, collect);
-        break;
-      case 266 /* ModuleDeclaration */:
-        collectCallSitesOfModuleDeclaration(node, collect);
-        break;
-      case 261 /* FunctionDeclaration */:
-      case 217 /* FunctionExpression */:
-      case 218 /* ArrowFunction */:
-      case 173 /* MethodDeclaration */:
-      case 176 /* GetAccessor */:
-      case 177 /* SetAccessor */:
-        collectCallSitesOfFunctionLikeDeclaration(program.getTypeChecker(), node, collect);
-        break;
-      case 262 /* ClassDeclaration */:
-      case 230 /* ClassExpression */:
-        collectCallSitesOfClassLikeDeclaration(node, collect);
-        break;
-      case 174 /* ClassStaticBlockDeclaration */:
-        collectCallSitesOfClassStaticBlockDeclaration(node, collect);
-        break;
-      default:
-        Debug.assertNever(node);
-    }
-    return callSites;
-  }
-  function createCallHierarchyOutgoingCall(to, fromSpans) {
-    return { to, fromSpans };
-  }
-  function convertCallSiteGroupToOutgoingCall(program, entries) {
-    return createCallHierarchyOutgoingCall(createCallHierarchyItem(program, entries[0].declaration), map(entries, (entry) => createTextSpanFromRange(entry.range)));
-  }
-  function getOutgoingCalls(program, declaration) {
-    if (declaration.flags & 16777216 /* Ambient */ || isMethodSignature(declaration)) {
-      return [];
-    }
-    return group(collectCallSites(program, declaration), getCallSiteGroupKey, (entries) => convertCallSiteGroupToOutgoingCall(program, entries));
-  }
-  var init_callHierarchy = __esm({
-    "src/services/callHierarchy.ts"() {
-      "use strict";
-      init_ts4();
-    }
-  });
-
-  // src/services/_namespaces/ts.CallHierarchy.ts
-  var ts_CallHierarchy_exports = {};
-  __export(ts_CallHierarchy_exports, {
-    createCallHierarchyItem: () => createCallHierarchyItem,
-    getIncomingCalls: () => getIncomingCalls,
-    getOutgoingCalls: () => getOutgoingCalls,
-    resolveCallHierarchyDeclaration: () => resolveCallHierarchyDeclaration
-  });
-  var init_ts_CallHierarchy = __esm({
-    "src/services/_namespaces/ts.CallHierarchy.ts"() {
-      "use strict";
-      init_callHierarchy();
-    }
-  });
-
-  // src/services/_namespaces/ts.classifier.v2020.ts
-  var ts_classifier_v2020_exports = {};
-  __export(ts_classifier_v2020_exports, {
-    TokenEncodingConsts: () => TokenEncodingConsts,
-    TokenModifier: () => TokenModifier,
-    TokenType: () => TokenType,
-    getEncodedSemanticClassifications: () => getEncodedSemanticClassifications2,
-    getSemanticClassifications: () => getSemanticClassifications2
-  });
-  var init_ts_classifier_v2020 = __esm({
-    "src/services/_namespaces/ts.classifier.v2020.ts"() {
-      "use strict";
-      init_classifier2020();
-    }
-  });
-
-  // src/services/_namespaces/ts.classifier.ts
-  var ts_classifier_exports = {};
-  __export(ts_classifier_exports, {
-    v2020: () => ts_classifier_v2020_exports
-  });
-  var init_ts_classifier = __esm({
-    "src/services/_namespaces/ts.classifier.ts"() {
-      "use strict";
-      init_ts_classifier_v2020();
-    }
-  });
-
-  // src/services/codeFixProvider.ts
-  function createCodeFixActionWithoutFixAll(fixName8, changes, description3) {
-    return createCodeFixActionWorker(
-      fixName8,
-      diagnosticToString(description3),
-      changes,
-      /*fixId*/
-      void 0,
-      /*fixAllDescription*/
-      void 0
-    );
-  }
-  function createCodeFixAction(fixName8, changes, description3, fixId52, fixAllDescription, command) {
-    return createCodeFixActionWorker(fixName8, diagnosticToString(description3), changes, fixId52, diagnosticToString(fixAllDescription), command);
-  }
-  function createCodeFixActionMaybeFixAll(fixName8, changes, description3, fixId52, fixAllDescription, command) {
-    return createCodeFixActionWorker(fixName8, diagnosticToString(description3), changes, fixId52, fixAllDescription && diagnosticToString(fixAllDescription), command);
-  }
-  function createCodeFixActionWorker(fixName8, description3, changes, fixId52, fixAllDescription, command) {
-    return { fixName: fixName8, description: description3, changes, fixId: fixId52, fixAllDescription, commands: command ? [command] : void 0 };
-  }
-  function registerCodeFix(reg) {
-    for (const error of reg.errorCodes) {
-      errorCodeToFixesArray = void 0;
-      errorCodeToFixes.add(String(error), reg);
-    }
-    if (reg.fixIds) {
-      for (const fixId52 of reg.fixIds) {
-        Debug.assert(!fixIdToRegistration.has(fixId52));
-        fixIdToRegistration.set(fixId52, reg);
-      }
-    }
-  }
-  function getSupportedErrorCodes() {
-    return errorCodeToFixesArray ?? (errorCodeToFixesArray = arrayFrom(errorCodeToFixes.keys()));
-  }
-  function removeFixIdIfFixAllUnavailable(registration, diagnostics) {
-    const { errorCodes: errorCodes64 } = registration;
-    let maybeFixableDiagnostics = 0;
-    for (const diag2 of diagnostics) {
-      if (contains(errorCodes64, diag2.code))
-        maybeFixableDiagnostics++;
-      if (maybeFixableDiagnostics > 1)
-        break;
-    }
-    const fixAllUnavailable = maybeFixableDiagnostics < 2;
-    return ({ fixId: fixId52, fixAllDescription, ...action }) => {
-      return fixAllUnavailable ? action : { ...action, fixId: fixId52, fixAllDescription };
-    };
-  }
-  function getFixes(context) {
-    const diagnostics = getDiagnostics(context);
-    const registrations = errorCodeToFixes.get(String(context.errorCode));
-    return flatMap(registrations, (f) => map(f.getCodeActions(context), removeFixIdIfFixAllUnavailable(f, diagnostics)));
-  }
-  function getAllFixes(context) {
-    return fixIdToRegistration.get(cast(context.fixId, isString)).getAllCodeActions(context);
-  }
-  function createCombinedCodeActions(changes, commands) {
-    return { changes, commands };
-  }
-  function createFileTextChanges(fileName, textChanges2) {
-    return { fileName, textChanges: textChanges2 };
-  }
-  function codeFixAll(context, errorCodes64, use) {
-    const commands = [];
-    const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => eachDiagnostic(context, errorCodes64, (diag2) => use(t, diag2, commands)));
-    return createCombinedCodeActions(changes, commands.length === 0 ? void 0 : commands);
-  }
-  function eachDiagnostic(context, errorCodes64, cb) {
-    for (const diag2 of getDiagnostics(context)) {
-      if (contains(errorCodes64, diag2.code)) {
-        cb(diag2);
-      }
-    }
-  }
-  function getDiagnostics({ program, sourceFile, cancellationToken }) {
-    return [
-      ...program.getSemanticDiagnostics(sourceFile, cancellationToken),
-      ...program.getSyntacticDiagnostics(sourceFile, cancellationToken),
-      ...computeSuggestionDiagnostics(sourceFile, program, cancellationToken)
-    ];
-  }
-  var errorCodeToFixes, fixIdToRegistration, errorCodeToFixesArray;
-  var init_codeFixProvider = __esm({
-    "src/services/codeFixProvider.ts"() {
-      "use strict";
-      init_ts4();
-      errorCodeToFixes = createMultiMap();
-      fixIdToRegistration = /* @__PURE__ */ new Map();
-    }
-  });
-
-  // src/services/codefixes/addConvertToUnknownForNonOverlappingTypes.ts
-  function makeChange(changeTracker, sourceFile, assertion) {
-    const replacement = isAsExpression(assertion) ? factory.createAsExpression(assertion.expression, factory.createKeywordTypeNode(159 /* UnknownKeyword */)) : factory.createTypeAssertion(factory.createKeywordTypeNode(159 /* UnknownKeyword */), assertion.expression);
-    changeTracker.replaceNode(sourceFile, assertion.expression, replacement);
-  }
-  function getAssertion(sourceFile, pos) {
-    if (isInJSFile(sourceFile))
-      return void 0;
-    return findAncestor(getTokenAtPosition(sourceFile, pos), (n) => isAsExpression(n) || isTypeAssertionExpression(n));
-  }
-  var fixId, errorCodes;
-  var init_addConvertToUnknownForNonOverlappingTypes = __esm({
-    "src/services/codefixes/addConvertToUnknownForNonOverlappingTypes.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_codefix();
-      fixId = "addConvertToUnknownForNonOverlappingTypes";
-      errorCodes = [Diagnostics.Conversion_of_type_0_to_type_1_may_be_a_mistake_because_neither_type_sufficiently_overlaps_with_the_other_If_this_was_intentional_convert_the_expression_to_unknown_first.code];
-      registerCodeFix({
-        errorCodes,
-        getCodeActions: function getCodeActionsToAddConvertToUnknownForNonOverlappingTypes(context) {
-          const assertion = getAssertion(context.sourceFile, context.span.start);
-          if (assertion === void 0)
-            return void 0;
-          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => makeChange(t, context.sourceFile, assertion));
-          return [createCodeFixAction(fixId, changes, Diagnostics.Add_unknown_conversion_for_non_overlapping_types, fixId, Diagnostics.Add_unknown_to_all_conversions_of_non_overlapping_types)];
-        },
-        fixIds: [fixId],
-        getAllCodeActions: (context) => codeFixAll(context, errorCodes, (changes, diag2) => {
-          const assertion = getAssertion(diag2.file, diag2.start);
-          if (assertion) {
-            makeChange(changes, diag2.file, assertion);
-          }
-        })
-      });
-    }
-  });
-
-  // src/services/codefixes/addEmptyExportDeclaration.ts
-  var init_addEmptyExportDeclaration = __esm({
-    "src/services/codefixes/addEmptyExportDeclaration.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_codefix();
-      registerCodeFix({
-        errorCodes: [
-          Diagnostics.await_expressions_are_only_allowed_at_the_top_level_of_a_file_when_that_file_is_a_module_but_this_file_has_no_imports_or_exports_Consider_adding_an_empty_export_to_make_this_file_a_module.code,
-          Diagnostics.for_await_loops_are_only_allowed_at_the_top_level_of_a_file_when_that_file_is_a_module_but_this_file_has_no_imports_or_exports_Consider_adding_an_empty_export_to_make_this_file_a_module.code
-        ],
-        getCodeActions: function getCodeActionsToAddEmptyExportDeclaration(context) {
-          const { sourceFile } = context;
-          const changes = ts_textChanges_exports.ChangeTracker.with(context, (changes2) => {
-            const exportDeclaration = factory.createExportDeclaration(
-              /*modifiers*/
-              void 0,
-              /*isTypeOnly*/
-              false,
-              factory.createNamedExports([]),
-              /*moduleSpecifier*/
-              void 0
-            );
-            changes2.insertNodeAtEndOfScope(sourceFile, sourceFile, exportDeclaration);
-          });
-          return [createCodeFixActionWithoutFixAll("addEmptyExportDeclaration", changes, Diagnostics.Add_export_to_make_this_file_into_a_module)];
-        }
-      });
-    }
-  });
-
-  // src/services/codefixes/addMissingAsync.ts
-  function getFix(context, decl, trackChanges, fixedDeclarations) {
-    const changes = trackChanges((t) => makeChange2(t, context.sourceFile, decl, fixedDeclarations));
-    return createCodeFixAction(fixId2, changes, Diagnostics.Add_async_modifier_to_containing_function, fixId2, Diagnostics.Add_all_missing_async_modifiers);
-  }
-  function makeChange2(changeTracker, sourceFile, insertionSite, fixedDeclarations) {
-    if (fixedDeclarations) {
-      if (fixedDeclarations.has(getNodeId(insertionSite))) {
-        return;
-      }
-    }
-    fixedDeclarations == null ? void 0 : fixedDeclarations.add(getNodeId(insertionSite));
-    const cloneWithModifier = factory.updateModifiers(
-      getSynthesizedDeepClone(
-        insertionSite,
-        /*includeTrivia*/
-        true
-      ),
-      factory.createNodeArray(factory.createModifiersFromModifierFlags(getSyntacticModifierFlags(insertionSite) | 512 /* Async */))
-    );
-    changeTracker.replaceNode(
-      sourceFile,
-      insertionSite,
-      cloneWithModifier
-    );
-  }
-  function getFixableErrorSpanDeclaration(sourceFile, span) {
-    if (!span)
-      return void 0;
-    const token = getTokenAtPosition(sourceFile, span.start);
-    const decl = findAncestor(token, (node) => {
-      if (node.getStart(sourceFile) < span.start || node.getEnd() > textSpanEnd(span)) {
-        return "quit";
-      }
-      return (isArrowFunction(node) || isMethodDeclaration(node) || isFunctionExpression(node) || isFunctionDeclaration(node)) && textSpansEqual(span, createTextSpanFromNode(node, sourceFile));
-    });
-    return decl;
-  }
-  function getIsMatchingAsyncError(span, errorCode) {
-    return ({ start, length: length2, relatedInformation, code }) => isNumber(start) && isNumber(length2) && textSpansEqual({ start, length: length2 }, span) && code === errorCode && !!relatedInformation && some(relatedInformation, (related) => related.code === Diagnostics.Did_you_mean_to_mark_this_function_as_async.code);
-  }
-  var fixId2, errorCodes2;
-  var init_addMissingAsync = __esm({
-    "src/services/codefixes/addMissingAsync.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_codefix();
-      fixId2 = "addMissingAsync";
-      errorCodes2 = [
-        Diagnostics.Argument_of_type_0_is_not_assignable_to_parameter_of_type_1.code,
-        Diagnostics.Type_0_is_not_assignable_to_type_1.code,
-        Diagnostics.Type_0_is_not_comparable_to_type_1.code
-      ];
-      registerCodeFix({
-        fixIds: [fixId2],
-        errorCodes: errorCodes2,
-        getCodeActions: function getCodeActionsToAddMissingAsync(context) {
-          const { sourceFile, errorCode, cancellationToken, program, span } = context;
-          const diagnostic = find(program.getTypeChecker().getDiagnostics(sourceFile, cancellationToken), getIsMatchingAsyncError(span, errorCode));
-          const directSpan = diagnostic && diagnostic.relatedInformation && find(diagnostic.relatedInformation, (r) => r.code === Diagnostics.Did_you_mean_to_mark_this_function_as_async.code);
-          const decl = getFixableErrorSpanDeclaration(sourceFile, directSpan);
-          if (!decl) {
-            return;
-          }
-          const trackChanges = (cb) => ts_textChanges_exports.ChangeTracker.with(context, cb);
-          return [getFix(context, decl, trackChanges)];
-        },
-        getAllCodeActions: (context) => {
-          const { sourceFile } = context;
-          const fixedDeclarations = /* @__PURE__ */ new Set();
-          return codeFixAll(context, errorCodes2, (t, diagnostic) => {
-            const span = diagnostic.relatedInformation && find(diagnostic.relatedInformation, (r) => r.code === Diagnostics.Did_you_mean_to_mark_this_function_as_async.code);
-            const decl = getFixableErrorSpanDeclaration(sourceFile, span);
-            if (!decl) {
-              return;
-            }
-            const trackChanges = (cb) => (cb(t), []);
-            return getFix(context, decl, trackChanges, fixedDeclarations);
-          });
-        }
-      });
-    }
-  });
-
-  // src/services/codefixes/addMissingAwait.ts
-  function getAwaitErrorSpanExpression(sourceFile, errorCode, span, cancellationToken, program) {
-    const expression = getFixableErrorSpanExpression(sourceFile, span);
-    return expression && isMissingAwaitError(sourceFile, errorCode, span, cancellationToken, program) && isInsideAwaitableBody(expression) ? expression : void 0;
-  }
-  function getDeclarationSiteFix(context, expression, errorCode, checker, trackChanges, fixedDeclarations) {
-    const { sourceFile, program, cancellationToken } = context;
-    const awaitableInitializers = findAwaitableInitializers(expression, sourceFile, cancellationToken, program, checker);
-    if (awaitableInitializers) {
-      const initializerChanges = trackChanges((t) => {
-        forEach(awaitableInitializers.initializers, ({ expression: expression2 }) => makeChange3(t, errorCode, sourceFile, checker, expression2, fixedDeclarations));
-        if (fixedDeclarations && awaitableInitializers.needsSecondPassForFixAll) {
-          makeChange3(t, errorCode, sourceFile, checker, expression, fixedDeclarations);
-        }
-      });
-      return createCodeFixActionWithoutFixAll(
-        "addMissingAwaitToInitializer",
-        initializerChanges,
-        awaitableInitializers.initializers.length === 1 ? [Diagnostics.Add_await_to_initializer_for_0, awaitableInitializers.initializers[0].declarationSymbol.name] : Diagnostics.Add_await_to_initializers
-      );
-    }
-  }
-  function getUseSiteFix(context, expression, errorCode, checker, trackChanges, fixedDeclarations) {
-    const changes = trackChanges((t) => makeChange3(t, errorCode, context.sourceFile, checker, expression, fixedDeclarations));
-    return createCodeFixAction(fixId3, changes, Diagnostics.Add_await, fixId3, Diagnostics.Fix_all_expressions_possibly_missing_await);
-  }
-  function isMissingAwaitError(sourceFile, errorCode, span, cancellationToken, program) {
-    const checker = program.getTypeChecker();
-    const diagnostics = checker.getDiagnostics(sourceFile, cancellationToken);
-    return some(diagnostics, ({ start, length: length2, relatedInformation, code }) => isNumber(start) && isNumber(length2) && textSpansEqual({ start, length: length2 }, span) && code === errorCode && !!relatedInformation && some(relatedInformation, (related) => related.code === Diagnostics.Did_you_forget_to_use_await.code));
-  }
-  function findAwaitableInitializers(expression, sourceFile, cancellationToken, program, checker) {
-    const identifiers = getIdentifiersFromErrorSpanExpression(expression, checker);
-    if (!identifiers) {
-      return;
-    }
-    let isCompleteFix = identifiers.isCompleteFix;
-    let initializers;
-    for (const identifier of identifiers.identifiers) {
-      const symbol = checker.getSymbolAtLocation(identifier);
-      if (!symbol) {
-        continue;
-      }
-      const declaration = tryCast(symbol.valueDeclaration, isVariableDeclaration);
-      const variableName = declaration && tryCast(declaration.name, isIdentifier);
-      const variableStatement = getAncestor(declaration, 242 /* VariableStatement */);
-      if (!declaration || !variableStatement || declaration.type || !declaration.initializer || variableStatement.getSourceFile() !== sourceFile || hasSyntacticModifier(variableStatement, 1 /* Export */) || !variableName || !isInsideAwaitableBody(declaration.initializer)) {
-        isCompleteFix = false;
-        continue;
-      }
-      const diagnostics = program.getSemanticDiagnostics(sourceFile, cancellationToken);
-      const isUsedElsewhere = ts_FindAllReferences_exports.Core.eachSymbolReferenceInFile(variableName, checker, sourceFile, (reference) => {
-        return identifier !== reference && !symbolReferenceIsAlsoMissingAwait(reference, diagnostics, sourceFile, checker);
-      });
-      if (isUsedElsewhere) {
-        isCompleteFix = false;
-        continue;
-      }
-      (initializers || (initializers = [])).push({
-        expression: declaration.initializer,
-        declarationSymbol: symbol
-      });
-    }
-    return initializers && {
-      initializers,
-      needsSecondPassForFixAll: !isCompleteFix
-    };
-  }
-  function getIdentifiersFromErrorSpanExpression(expression, checker) {
-    if (isPropertyAccessExpression(expression.parent) && isIdentifier(expression.parent.expression)) {
-      return { identifiers: [expression.parent.expression], isCompleteFix: true };
-    }
-    if (isIdentifier(expression)) {
-      return { identifiers: [expression], isCompleteFix: true };
-    }
-    if (isBinaryExpression(expression)) {
-      let sides;
-      let isCompleteFix = true;
-      for (const side of [expression.left, expression.right]) {
-        const type = checker.getTypeAtLocation(side);
-        if (checker.getPromisedTypeOfPromise(type)) {
-          if (!isIdentifier(side)) {
-            isCompleteFix = false;
-            continue;
-          }
-          (sides || (sides = [])).push(side);
-        }
-      }
-      return sides && { identifiers: sides, isCompleteFix };
-    }
-  }
-  function symbolReferenceIsAlsoMissingAwait(reference, diagnostics, sourceFile, checker) {
-    const errorNode = isPropertyAccessExpression(reference.parent) ? reference.parent.name : isBinaryExpression(reference.parent) ? reference.parent : reference;
-    const diagnostic = find(diagnostics, (diagnostic2) => diagnostic2.start === errorNode.getStart(sourceFile) && diagnostic2.start + diagnostic2.length === errorNode.getEnd());
-    return diagnostic && contains(errorCodes3, diagnostic.code) || // A Promise is usually not correct in a binary expression (it's not valid
-    // in an arithmetic expression and an equality comparison seems unusual),
-    // but if the other side of the binary expression has an error, the side
-    // is typed `any` which will squash the error that would identify this
-    // Promise as an invalid operand. So if the whole binary expression is
-    // typed `any` as a result, there is a strong likelihood that this Promise
-    // is accidentally missing `await`.
-    checker.getTypeAtLocation(errorNode).flags & 1 /* Any */;
-  }
-  function isInsideAwaitableBody(node) {
-    return node.kind & 32768 /* AwaitContext */ || !!findAncestor(node, (ancestor) => ancestor.parent && isArrowFunction(ancestor.parent) && ancestor.parent.body === ancestor || isBlock(ancestor) && (ancestor.parent.kind === 261 /* FunctionDeclaration */ || ancestor.parent.kind === 217 /* FunctionExpression */ || ancestor.parent.kind === 218 /* ArrowFunction */ || ancestor.parent.kind === 173 /* MethodDeclaration */));
-  }
-  function makeChange3(changeTracker, errorCode, sourceFile, checker, insertionSite, fixedDeclarations) {
-    if (isForOfStatement(insertionSite.parent) && !insertionSite.parent.awaitModifier) {
-      const exprType = checker.getTypeAtLocation(insertionSite);
-      const asyncIter = checker.getAsyncIterableType();
-      if (asyncIter && checker.isTypeAssignableTo(exprType, asyncIter)) {
-        const forOf = insertionSite.parent;
-        changeTracker.replaceNode(sourceFile, forOf, factory.updateForOfStatement(forOf, factory.createToken(135 /* AwaitKeyword */), forOf.initializer, forOf.expression, forOf.statement));
-        return;
-      }
-    }
-    if (isBinaryExpression(insertionSite)) {
-      for (const side of [insertionSite.left, insertionSite.right]) {
-        if (fixedDeclarations && isIdentifier(side)) {
-          const symbol = checker.getSymbolAtLocation(side);
-          if (symbol && fixedDeclarations.has(getSymbolId(symbol))) {
-            continue;
-          }
-        }
-        const type = checker.getTypeAtLocation(side);
-        const newNode = checker.getPromisedTypeOfPromise(type) ? factory.createAwaitExpression(side) : side;
-        changeTracker.replaceNode(sourceFile, side, newNode);
-      }
-    } else if (errorCode === propertyAccessCode && isPropertyAccessExpression(insertionSite.parent)) {
-      if (fixedDeclarations && isIdentifier(insertionSite.parent.expression)) {
-        const symbol = checker.getSymbolAtLocation(insertionSite.parent.expression);
-        if (symbol && fixedDeclarations.has(getSymbolId(symbol))) {
-          return;
-        }
-      }
-      changeTracker.replaceNode(
-        sourceFile,
-        insertionSite.parent.expression,
-        factory.createParenthesizedExpression(factory.createAwaitExpression(insertionSite.parent.expression))
-      );
-      insertLeadingSemicolonIfNeeded(changeTracker, insertionSite.parent.expression, sourceFile);
-    } else if (contains(callableConstructableErrorCodes, errorCode) && isCallOrNewExpression(insertionSite.parent)) {
-      if (fixedDeclarations && isIdentifier(insertionSite)) {
-        const symbol = checker.getSymbolAtLocation(insertionSite);
-        if (symbol && fixedDeclarations.has(getSymbolId(symbol))) {
-          return;
-        }
-      }
-      changeTracker.replaceNode(sourceFile, insertionSite, factory.createParenthesizedExpression(factory.createAwaitExpression(insertionSite)));
-      insertLeadingSemicolonIfNeeded(changeTracker, insertionSite, sourceFile);
-    } else {
-      if (fixedDeclarations && isVariableDeclaration(insertionSite.parent) && isIdentifier(insertionSite.parent.name)) {
-        const symbol = checker.getSymbolAtLocation(insertionSite.parent.name);
-        if (symbol && !tryAddToSet(fixedDeclarations, getSymbolId(symbol))) {
-          return;
-        }
-      }
-      changeTracker.replaceNode(sourceFile, insertionSite, factory.createAwaitExpression(insertionSite));
-    }
-  }
-  function insertLeadingSemicolonIfNeeded(changeTracker, beforeNode, sourceFile) {
-    const precedingToken = findPrecedingToken(beforeNode.pos, sourceFile);
-    if (precedingToken && positionIsASICandidate(precedingToken.end, precedingToken.parent, sourceFile)) {
-      changeTracker.insertText(sourceFile, beforeNode.getStart(sourceFile), ";");
-    }
-  }
-  var fixId3, propertyAccessCode, callableConstructableErrorCodes, errorCodes3;
-  var init_addMissingAwait = __esm({
-    "src/services/codefixes/addMissingAwait.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_codefix();
-      fixId3 = "addMissingAwait";
-      propertyAccessCode = Diagnostics.Property_0_does_not_exist_on_type_1.code;
-      callableConstructableErrorCodes = [
-        Diagnostics.This_expression_is_not_callable.code,
-        Diagnostics.This_expression_is_not_constructable.code
-      ];
-      errorCodes3 = [
-        Diagnostics.An_arithmetic_operand_must_be_of_type_any_number_bigint_or_an_enum_type.code,
-        Diagnostics.The_left_hand_side_of_an_arithmetic_operation_must_be_of_type_any_number_bigint_or_an_enum_type.code,
-        Diagnostics.The_right_hand_side_of_an_arithmetic_operation_must_be_of_type_any_number_bigint_or_an_enum_type.code,
-        Diagnostics.Operator_0_cannot_be_applied_to_type_1.code,
-        Diagnostics.Operator_0_cannot_be_applied_to_types_1_and_2.code,
-        Diagnostics.This_comparison_appears_to_be_unintentional_because_the_types_0_and_1_have_no_overlap.code,
-        Diagnostics.This_condition_will_always_return_true_since_this_0_is_always_defined.code,
-        Diagnostics.Type_0_is_not_an_array_type.code,
-        Diagnostics.Type_0_is_not_an_array_type_or_a_string_type.code,
-        Diagnostics.Type_0_can_only_be_iterated_through_when_using_the_downlevelIteration_flag_or_with_a_target_of_es2015_or_higher.code,
-        Diagnostics.Type_0_is_not_an_array_type_or_a_string_type_or_does_not_have_a_Symbol_iterator_method_that_returns_an_iterator.code,
-        Diagnostics.Type_0_is_not_an_array_type_or_does_not_have_a_Symbol_iterator_method_that_returns_an_iterator.code,
-        Diagnostics.Type_0_must_have_a_Symbol_iterator_method_that_returns_an_iterator.code,
-        Diagnostics.Type_0_must_have_a_Symbol_asyncIterator_method_that_returns_an_async_iterator.code,
-        Diagnostics.Argument_of_type_0_is_not_assignable_to_parameter_of_type_1.code,
-        propertyAccessCode,
-        ...callableConstructableErrorCodes
-      ];
-      registerCodeFix({
-        fixIds: [fixId3],
-        errorCodes: errorCodes3,
-        getCodeActions: function getCodeActionsToAddMissingAwait(context) {
-          const { sourceFile, errorCode, span, cancellationToken, program } = context;
-          const expression = getAwaitErrorSpanExpression(sourceFile, errorCode, span, cancellationToken, program);
-          if (!expression) {
-            return;
-          }
-          const checker = context.program.getTypeChecker();
-          const trackChanges = (cb) => ts_textChanges_exports.ChangeTracker.with(context, cb);
-          return compact([
-            getDeclarationSiteFix(context, expression, errorCode, checker, trackChanges),
-            getUseSiteFix(context, expression, errorCode, checker, trackChanges)
-          ]);
-        },
-        getAllCodeActions: (context) => {
-          const { sourceFile, program, cancellationToken } = context;
-          const checker = context.program.getTypeChecker();
-          const fixedDeclarations = /* @__PURE__ */ new Set();
-          return codeFixAll(context, errorCodes3, (t, diagnostic) => {
-            const expression = getAwaitErrorSpanExpression(sourceFile, diagnostic.code, diagnostic, cancellationToken, program);
-            if (!expression) {
-              return;
-            }
-            const trackChanges = (cb) => (cb(t), []);
-            return getDeclarationSiteFix(context, expression, diagnostic.code, checker, trackChanges, fixedDeclarations) || getUseSiteFix(context, expression, diagnostic.code, checker, trackChanges, fixedDeclarations);
-          });
-        }
-      });
-    }
-  });
-
-  // src/services/codefixes/addMissingConst.ts
-  function makeChange4(changeTracker, sourceFile, pos, program, fixedNodes) {
-    const token = getTokenAtPosition(sourceFile, pos);
-    const forInitializer = findAncestor(
-      token,
-      (node) => isForInOrOfStatement(node.parent) ? node.parent.initializer === node : isPossiblyPartOfDestructuring(node) ? false : "quit"
-    );
-    if (forInitializer)
-      return applyChange(changeTracker, forInitializer, sourceFile, fixedNodes);
-    const parent2 = token.parent;
-    if (isBinaryExpression(parent2) && parent2.operatorToken.kind === 64 /* EqualsToken */ && isExpressionStatement(parent2.parent)) {
-      return applyChange(changeTracker, token, sourceFile, fixedNodes);
-    }
-    if (isArrayLiteralExpression(parent2)) {
-      const checker = program.getTypeChecker();
-      if (!every(parent2.elements, (element) => arrayElementCouldBeVariableDeclaration(element, checker))) {
-        return;
-      }
-      return applyChange(changeTracker, parent2, sourceFile, fixedNodes);
-    }
-    const commaExpression = findAncestor(
-      token,
-      (node) => isExpressionStatement(node.parent) ? true : isPossiblyPartOfCommaSeperatedInitializer(node) ? false : "quit"
-    );
-    if (commaExpression) {
-      const checker = program.getTypeChecker();
-      if (!expressionCouldBeVariableDeclaration(commaExpression, checker)) {
-        return;
-      }
-      return applyChange(changeTracker, commaExpression, sourceFile, fixedNodes);
-    }
-  }
-  function applyChange(changeTracker, initializer, sourceFile, fixedNodes) {
-    if (!fixedNodes || tryAddToSet(fixedNodes, initializer)) {
-      changeTracker.insertModifierBefore(sourceFile, 87 /* ConstKeyword */, initializer);
-    }
-  }
-  function isPossiblyPartOfDestructuring(node) {
-    switch (node.kind) {
-      case 80 /* Identifier */:
-      case 208 /* ArrayLiteralExpression */:
-      case 209 /* ObjectLiteralExpression */:
-      case 302 /* PropertyAssignment */:
-      case 303 /* ShorthandPropertyAssignment */:
-        return true;
-      default:
-        return false;
-    }
-  }
-  function arrayElementCouldBeVariableDeclaration(expression, checker) {
-    const identifier = isIdentifier(expression) ? expression : isAssignmentExpression(
-      expression,
-      /*excludeCompoundAssignment*/
-      true
-    ) && isIdentifier(expression.left) ? expression.left : void 0;
-    return !!identifier && !checker.getSymbolAtLocation(identifier);
-  }
-  function isPossiblyPartOfCommaSeperatedInitializer(node) {
-    switch (node.kind) {
-      case 80 /* Identifier */:
-      case 225 /* BinaryExpression */:
-      case 28 /* CommaToken */:
-        return true;
-      default:
-        return false;
-    }
-  }
-  function expressionCouldBeVariableDeclaration(expression, checker) {
-    if (!isBinaryExpression(expression)) {
-      return false;
-    }
-    if (expression.operatorToken.kind === 28 /* CommaToken */) {
-      return every([expression.left, expression.right], (expression2) => expressionCouldBeVariableDeclaration(expression2, checker));
-    }
-    return expression.operatorToken.kind === 64 /* EqualsToken */ && isIdentifier(expression.left) && !checker.getSymbolAtLocation(expression.left);
-  }
-  var fixId4, errorCodes4;
-  var init_addMissingConst = __esm({
-    "src/services/codefixes/addMissingConst.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_codefix();
-      fixId4 = "addMissingConst";
-      errorCodes4 = [
-        Diagnostics.Cannot_find_name_0.code,
-        Diagnostics.No_value_exists_in_scope_for_the_shorthand_property_0_Either_declare_one_or_provide_an_initializer.code
-      ];
-      registerCodeFix({
-        errorCodes: errorCodes4,
-        getCodeActions: function getCodeActionsToAddMissingConst(context) {
-          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => makeChange4(t, context.sourceFile, context.span.start, context.program));
-          if (changes.length > 0) {
-            return [createCodeFixAction(fixId4, changes, Diagnostics.Add_const_to_unresolved_variable, fixId4, Diagnostics.Add_const_to_all_unresolved_variables)];
-          }
-        },
-        fixIds: [fixId4],
-        getAllCodeActions: (context) => {
-          const fixedNodes = /* @__PURE__ */ new Set();
-          return codeFixAll(context, errorCodes4, (changes, diag2) => makeChange4(changes, diag2.file, diag2.start, context.program, fixedNodes));
-        }
-      });
-    }
-  });
-
-  // src/services/codefixes/addMissingDeclareProperty.ts
-  function makeChange5(changeTracker, sourceFile, pos, fixedNodes) {
-    const token = getTokenAtPosition(sourceFile, pos);
-    if (!isIdentifier(token)) {
-      return;
-    }
-    const declaration = token.parent;
-    if (declaration.kind === 171 /* PropertyDeclaration */ && (!fixedNodes || tryAddToSet(fixedNodes, declaration))) {
-      changeTracker.insertModifierBefore(sourceFile, 138 /* DeclareKeyword */, declaration);
-    }
-  }
-  var fixId5, errorCodes5;
-  var init_addMissingDeclareProperty = __esm({
-    "src/services/codefixes/addMissingDeclareProperty.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_codefix();
-      fixId5 = "addMissingDeclareProperty";
-      errorCodes5 = [
-        Diagnostics.Property_0_will_overwrite_the_base_property_in_1_If_this_is_intentional_add_an_initializer_Otherwise_add_a_declare_modifier_or_remove_the_redundant_declaration.code
-      ];
-      registerCodeFix({
-        errorCodes: errorCodes5,
-        getCodeActions: function getCodeActionsToAddMissingDeclareOnProperty(context) {
-          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => makeChange5(t, context.sourceFile, context.span.start));
-          if (changes.length > 0) {
-            return [createCodeFixAction(fixId5, changes, Diagnostics.Prefix_with_declare, fixId5, Diagnostics.Prefix_all_incorrect_property_declarations_with_declare)];
-          }
-        },
-        fixIds: [fixId5],
-        getAllCodeActions: (context) => {
-          const fixedNodes = /* @__PURE__ */ new Set();
-          return codeFixAll(context, errorCodes5, (changes, diag2) => makeChange5(changes, diag2.file, diag2.start, fixedNodes));
-        }
-      });
-    }
-  });
-
-  // src/services/codefixes/addMissingInvocationForDecorator.ts
-  function makeChange6(changeTracker, sourceFile, pos) {
-    const token = getTokenAtPosition(sourceFile, pos);
-    const decorator = findAncestor(token, isDecorator);
-    Debug.assert(!!decorator, "Expected position to be owned by a decorator.");
-    const replacement = factory.createCallExpression(
-      decorator.expression,
-      /*typeArguments*/
-      void 0,
-      /*argumentsArray*/
-      void 0
-    );
-    changeTracker.replaceNode(sourceFile, decorator.expression, replacement);
-  }
-  var fixId6, errorCodes6;
-  var init_addMissingInvocationForDecorator = __esm({
-    "src/services/codefixes/addMissingInvocationForDecorator.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_codefix();
-      fixId6 = "addMissingInvocationForDecorator";
-      errorCodes6 = [Diagnostics._0_accepts_too_few_arguments_to_be_used_as_a_decorator_here_Did_you_mean_to_call_it_first_and_write_0.code];
-      registerCodeFix({
-        errorCodes: errorCodes6,
-        getCodeActions: function getCodeActionsToAddMissingInvocationForDecorator(context) {
-          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => makeChange6(t, context.sourceFile, context.span.start));
-          return [createCodeFixAction(fixId6, changes, Diagnostics.Call_decorator_expression, fixId6, Diagnostics.Add_to_all_uncalled_decorators)];
-        },
-        fixIds: [fixId6],
-        getAllCodeActions: (context) => codeFixAll(context, errorCodes6, (changes, diag2) => makeChange6(changes, diag2.file, diag2.start))
-      });
-    }
-  });
-
-  // src/services/codefixes/addNameToNamelessParameter.ts
-  function makeChange7(changeTracker, sourceFile, pos) {
-    const token = getTokenAtPosition(sourceFile, pos);
-    const param = token.parent;
-    if (!isParameter(param)) {
-      return Debug.fail("Tried to add a parameter name to a non-parameter: " + Debug.formatSyntaxKind(token.kind));
-    }
-    const i = param.parent.parameters.indexOf(param);
-    Debug.assert(!param.type, "Tried to add a parameter name to a parameter that already had one.");
-    Debug.assert(i > -1, "Parameter not found in parent parameter list.");
-    const typeNode = factory.createTypeReferenceNode(
-      param.name,
-      /*typeArguments*/
-      void 0
-    );
-    const replacement = factory.createParameterDeclaration(
-      param.modifiers,
-      param.dotDotDotToken,
-      "arg" + i,
-      param.questionToken,
-      param.dotDotDotToken ? factory.createArrayTypeNode(typeNode) : typeNode,
-      param.initializer
-    );
-    changeTracker.replaceNode(sourceFile, param, replacement);
-  }
-  var fixId7, errorCodes7;
-  var init_addNameToNamelessParameter = __esm({
-    "src/services/codefixes/addNameToNamelessParameter.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_codefix();
-      fixId7 = "addNameToNamelessParameter";
-      errorCodes7 = [Diagnostics.Parameter_has_a_name_but_no_type_Did_you_mean_0_Colon_1.code];
-      registerCodeFix({
-        errorCodes: errorCodes7,
-        getCodeActions: function getCodeActionsToAddNameToNamelessParameter(context) {
-          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => makeChange7(t, context.sourceFile, context.span.start));
-          return [createCodeFixAction(fixId7, changes, Diagnostics.Add_parameter_name, fixId7, Diagnostics.Add_names_to_all_parameters_without_names)];
-        },
-        fixIds: [fixId7],
-        getAllCodeActions: (context) => codeFixAll(context, errorCodes7, (changes, diag2) => makeChange7(changes, diag2.file, diag2.start))
-      });
-    }
-  });
-
-  // src/services/codefixes/addOptionalPropertyUndefined.ts
-  function getPropertiesToAdd(file, span, checker) {
-    var _a, _b;
-    const sourceTarget = getSourceTarget(getFixableErrorSpanExpression(file, span), checker);
-    if (!sourceTarget) {
-      return emptyArray;
-    }
-    const { source: sourceNode, target: targetNode } = sourceTarget;
-    const target = shouldUseParentTypeOfProperty(sourceNode, targetNode, checker) ? checker.getTypeAtLocation(targetNode.expression) : checker.getTypeAtLocation(targetNode);
-    if ((_b = (_a = target.symbol) == null ? void 0 : _a.declarations) == null ? void 0 : _b.some((d) => getSourceFileOfNode(d).fileName.match(/\.d\.ts$/))) {
-      return emptyArray;
-    }
-    return checker.getExactOptionalProperties(target);
-  }
-  function shouldUseParentTypeOfProperty(sourceNode, targetNode, checker) {
-    return isPropertyAccessExpression(targetNode) && !!checker.getExactOptionalProperties(checker.getTypeAtLocation(targetNode.expression)).length && checker.getTypeAtLocation(sourceNode) === checker.getUndefinedType();
-  }
-  function getSourceTarget(errorNode, checker) {
-    var _a;
-    if (!errorNode) {
-      return void 0;
-    } else if (isBinaryExpression(errorNode.parent) && errorNode.parent.operatorToken.kind === 64 /* EqualsToken */) {
-      return { source: errorNode.parent.right, target: errorNode.parent.left };
-    } else if (isVariableDeclaration(errorNode.parent) && errorNode.parent.initializer) {
-      return { source: errorNode.parent.initializer, target: errorNode.parent.name };
-    } else if (isCallExpression(errorNode.parent)) {
-      const n = checker.getSymbolAtLocation(errorNode.parent.expression);
-      if (!(n == null ? void 0 : n.valueDeclaration) || !isFunctionLikeKind(n.valueDeclaration.kind))
-        return void 0;
-      if (!isExpression(errorNode))
-        return void 0;
-      const i = errorNode.parent.arguments.indexOf(errorNode);
-      if (i === -1)
-        return void 0;
-      const name = n.valueDeclaration.parameters[i].name;
-      if (isIdentifier(name))
-        return { source: errorNode, target: name };
-    } else if (isPropertyAssignment(errorNode.parent) && isIdentifier(errorNode.parent.name) || isShorthandPropertyAssignment(errorNode.parent)) {
-      const parentTarget = getSourceTarget(errorNode.parent.parent, checker);
-      if (!parentTarget)
-        return void 0;
-      const prop = checker.getPropertyOfType(checker.getTypeAtLocation(parentTarget.target), errorNode.parent.name.text);
-      const declaration = (_a = prop == null ? void 0 : prop.declarations) == null ? void 0 : _a[0];
-      if (!declaration)
-        return void 0;
-      return {
-        source: isPropertyAssignment(errorNode.parent) ? errorNode.parent.initializer : errorNode.parent.name,
-        target: declaration
-      };
-    }
-    return void 0;
-  }
-  function addUndefinedToOptionalProperty(changes, toAdd) {
-    for (const add of toAdd) {
-      const d = add.valueDeclaration;
-      if (d && (isPropertySignature(d) || isPropertyDeclaration(d)) && d.type) {
-        const t = factory.createUnionTypeNode([
-          ...d.type.kind === 191 /* UnionType */ ? d.type.types : [d.type],
-          factory.createTypeReferenceNode("undefined")
-        ]);
-        changes.replaceNode(d.getSourceFile(), d.type, t);
-      }
-    }
-  }
-  var addOptionalPropertyUndefined, errorCodes8;
-  var init_addOptionalPropertyUndefined = __esm({
-    "src/services/codefixes/addOptionalPropertyUndefined.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_codefix();
-      addOptionalPropertyUndefined = "addOptionalPropertyUndefined";
-      errorCodes8 = [
-        Diagnostics.Type_0_is_not_assignable_to_type_1_with_exactOptionalPropertyTypes_Colon_true_Consider_adding_undefined_to_the_type_of_the_target.code,
-        Diagnostics.Type_0_is_not_assignable_to_type_1_with_exactOptionalPropertyTypes_Colon_true_Consider_adding_undefined_to_the_types_of_the_target_s_properties.code,
-        Diagnostics.Argument_of_type_0_is_not_assignable_to_parameter_of_type_1_with_exactOptionalPropertyTypes_Colon_true_Consider_adding_undefined_to_the_types_of_the_target_s_properties.code
-      ];
-      registerCodeFix({
-        errorCodes: errorCodes8,
-        getCodeActions(context) {
-          const typeChecker = context.program.getTypeChecker();
-          const toAdd = getPropertiesToAdd(context.sourceFile, context.span, typeChecker);
-          if (!toAdd.length) {
-            return void 0;
-          }
-          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => addUndefinedToOptionalProperty(t, toAdd));
-          return [createCodeFixActionWithoutFixAll(addOptionalPropertyUndefined, changes, Diagnostics.Add_undefined_to_optional_property_type)];
-        },
-        fixIds: [addOptionalPropertyUndefined]
-      });
-    }
-  });
-
-  // src/services/codefixes/annotateWithTypeFromJSDoc.ts
-  function getDeclaration(file, pos) {
-    const name = getTokenAtPosition(file, pos);
-    return tryCast(isParameter(name.parent) ? name.parent.parent : name.parent, parameterShouldGetTypeFromJSDoc);
-  }
-  function parameterShouldGetTypeFromJSDoc(node) {
-    return isDeclarationWithType(node) && hasUsableJSDoc(node);
-  }
-  function hasUsableJSDoc(decl) {
-    return isFunctionLikeDeclaration(decl) ? decl.parameters.some(hasUsableJSDoc) || !decl.type && !!getJSDocReturnType(decl) : !decl.type && !!getJSDocType(decl);
-  }
-  function doChange8(changes, sourceFile, decl) {
-    if (isFunctionLikeDeclaration(decl) && (getJSDocReturnType(decl) || decl.parameters.some((p) => !!getJSDocType(p)))) {
-      if (!decl.typeParameters) {
-        const typeParameters = getJSDocTypeParameterDeclarations(decl);
-        if (typeParameters.length)
-          changes.insertTypeParameters(sourceFile, decl, typeParameters);
-      }
-      const needParens = isArrowFunction(decl) && !findChildOfKind(decl, 21 /* OpenParenToken */, sourceFile);
-      if (needParens)
-        changes.insertNodeBefore(sourceFile, first(decl.parameters), factory.createToken(21 /* OpenParenToken */));
-      for (const param of decl.parameters) {
-        if (!param.type) {
-          const paramType = getJSDocType(param);
-          if (paramType)
-            changes.tryInsertTypeAnnotation(sourceFile, param, visitNode(paramType, transformJSDocType, isTypeNode));
-        }
-      }
-      if (needParens)
-        changes.insertNodeAfter(sourceFile, last(decl.parameters), factory.createToken(22 /* CloseParenToken */));
-      if (!decl.type) {
-        const returnType = getJSDocReturnType(decl);
-        if (returnType)
-          changes.tryInsertTypeAnnotation(sourceFile, decl, visitNode(returnType, transformJSDocType, isTypeNode));
-      }
-    } else {
-      const jsdocType = Debug.checkDefined(getJSDocType(decl), "A JSDocType for this declaration should exist");
-      Debug.assert(!decl.type, "The JSDocType decl should have a type");
-      changes.tryInsertTypeAnnotation(sourceFile, decl, visitNode(jsdocType, transformJSDocType, isTypeNode));
-    }
-  }
-  function isDeclarationWithType(node) {
-    return isFunctionLikeDeclaration(node) || node.kind === 259 /* VariableDeclaration */ || node.kind === 170 /* PropertySignature */ || node.kind === 171 /* PropertyDeclaration */;
-  }
-  function transformJSDocType(node) {
-    switch (node.kind) {
-      case 318 /* JSDocAllType */:
-      case 319 /* JSDocUnknownType */:
-        return factory.createTypeReferenceNode("any", emptyArray);
-      case 322 /* JSDocOptionalType */:
-        return transformJSDocOptionalType(node);
-      case 321 /* JSDocNonNullableType */:
-        return transformJSDocType(node.type);
-      case 320 /* JSDocNullableType */:
-        return transformJSDocNullableType(node);
-      case 324 /* JSDocVariadicType */:
-        return transformJSDocVariadicType(node);
-      case 323 /* JSDocFunctionType */:
-        return transformJSDocFunctionType(node);
-      case 182 /* TypeReference */:
-        return transformJSDocTypeReference(node);
-      case 328 /* JSDocTypeLiteral */:
-        return transformJSDocTypeLiteral(node);
-      default:
-        const visited = visitEachChild(node, transformJSDocType, nullTransformationContext);
-        setEmitFlags(visited, 1 /* SingleLine */);
-        return visited;
-    }
-  }
-  function transformJSDocTypeLiteral(node) {
-    const typeNode = factory.createTypeLiteralNode(map(node.jsDocPropertyTags, (tag) => factory.createPropertySignature(
-      /*modifiers*/
-      void 0,
-      isIdentifier(tag.name) ? tag.name : tag.name.right,
-      isOptionalJSDocPropertyLikeTag(tag) ? factory.createToken(58 /* QuestionToken */) : void 0,
-      tag.typeExpression && visitNode(tag.typeExpression.type, transformJSDocType, isTypeNode) || factory.createKeywordTypeNode(133 /* AnyKeyword */)
-    )));
-    setEmitFlags(typeNode, 1 /* SingleLine */);
-    return typeNode;
-  }
-  function transformJSDocOptionalType(node) {
-    return factory.createUnionTypeNode([visitNode(node.type, transformJSDocType, isTypeNode), factory.createTypeReferenceNode("undefined", emptyArray)]);
-  }
-  function transformJSDocNullableType(node) {
-    return factory.createUnionTypeNode([visitNode(node.type, transformJSDocType, isTypeNode), factory.createTypeReferenceNode("null", emptyArray)]);
-  }
-  function transformJSDocVariadicType(node) {
-    return factory.createArrayTypeNode(visitNode(node.type, transformJSDocType, isTypeNode));
-  }
-  function transformJSDocFunctionType(node) {
-    return factory.createFunctionTypeNode(emptyArray, node.parameters.map(transformJSDocParameter), node.type ?? factory.createKeywordTypeNode(133 /* AnyKeyword */));
-  }
-  function transformJSDocParameter(node) {
-    const index = node.parent.parameters.indexOf(node);
-    const isRest = node.type.kind === 324 /* JSDocVariadicType */ && index === node.parent.parameters.length - 1;
-    const name = node.name || (isRest ? "rest" : "arg" + index);
-    const dotdotdot = isRest ? factory.createToken(26 /* DotDotDotToken */) : node.dotDotDotToken;
-    return factory.createParameterDeclaration(node.modifiers, dotdotdot, name, node.questionToken, visitNode(node.type, transformJSDocType, isTypeNode), node.initializer);
-  }
-  function transformJSDocTypeReference(node) {
-    let name = node.typeName;
-    let args = node.typeArguments;
-    if (isIdentifier(node.typeName)) {
-      if (isJSDocIndexSignature(node)) {
-        return transformJSDocIndexSignature(node);
-      }
-      let text = node.typeName.text;
-      switch (node.typeName.text) {
-        case "String":
-        case "Boolean":
-        case "Object":
-        case "Number":
-          text = text.toLowerCase();
-          break;
-        case "array":
-        case "date":
-        case "promise":
-          text = text[0].toUpperCase() + text.slice(1);
-          break;
-      }
-      name = factory.createIdentifier(text);
-      if ((text === "Array" || text === "Promise") && !node.typeArguments) {
-        args = factory.createNodeArray([factory.createTypeReferenceNode("any", emptyArray)]);
-      } else {
-        args = visitNodes2(node.typeArguments, transformJSDocType, isTypeNode);
-      }
-    }
-    return factory.createTypeReferenceNode(name, args);
-  }
-  function transformJSDocIndexSignature(node) {
-    const index = factory.createParameterDeclaration(
-      /*modifiers*/
-      void 0,
-      /*dotDotDotToken*/
-      void 0,
-      node.typeArguments[0].kind === 150 /* NumberKeyword */ ? "n" : "s",
-      /*questionToken*/
-      void 0,
-      factory.createTypeReferenceNode(node.typeArguments[0].kind === 150 /* NumberKeyword */ ? "number" : "string", []),
-      /*initializer*/
-      void 0
-    );
-    const indexSignature = factory.createTypeLiteralNode([factory.createIndexSignature(
-      /*modifiers*/
-      void 0,
-      [index],
-      node.typeArguments[1]
-    )]);
-    setEmitFlags(indexSignature, 1 /* SingleLine */);
-    return indexSignature;
-  }
-  var fixId8, errorCodes9;
-  var init_annotateWithTypeFromJSDoc = __esm({
-    "src/services/codefixes/annotateWithTypeFromJSDoc.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_codefix();
-      fixId8 = "annotateWithTypeFromJSDoc";
-      errorCodes9 = [Diagnostics.JSDoc_types_may_be_moved_to_TypeScript_types.code];
-      registerCodeFix({
-        errorCodes: errorCodes9,
-        getCodeActions(context) {
-          const decl = getDeclaration(context.sourceFile, context.span.start);
-          if (!decl)
-            return;
-          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange8(t, context.sourceFile, decl));
-          return [createCodeFixAction(fixId8, changes, Diagnostics.Annotate_with_type_from_JSDoc, fixId8, Diagnostics.Annotate_everything_with_types_from_JSDoc)];
-        },
-        fixIds: [fixId8],
-        getAllCodeActions: (context) => codeFixAll(context, errorCodes9, (changes, diag2) => {
-          const decl = getDeclaration(diag2.file, diag2.start);
-          if (decl)
-            doChange8(changes, diag2.file, decl);
-        })
-      });
-    }
-  });
-
-  // src/services/codefixes/convertFunctionToEs6Class.ts
-  function doChange9(changes, sourceFile, position, checker, preferences, compilerOptions) {
-    const ctorSymbol = checker.getSymbolAtLocation(getTokenAtPosition(sourceFile, position));
-    if (!ctorSymbol || !ctorSymbol.valueDeclaration || !(ctorSymbol.flags & (16 /* Function */ | 3 /* Variable */))) {
-      return void 0;
-    }
-    const ctorDeclaration = ctorSymbol.valueDeclaration;
-    if (isFunctionDeclaration(ctorDeclaration) || isFunctionExpression(ctorDeclaration)) {
-      changes.replaceNode(sourceFile, ctorDeclaration, createClassFromFunction(ctorDeclaration));
-    } else if (isVariableDeclaration(ctorDeclaration)) {
-      const classDeclaration = createClassFromVariableDeclaration(ctorDeclaration);
-      if (!classDeclaration) {
-        return void 0;
-      }
-      const ancestor = ctorDeclaration.parent.parent;
-      if (isVariableDeclarationList(ctorDeclaration.parent) && ctorDeclaration.parent.declarations.length > 1) {
-        changes.delete(sourceFile, ctorDeclaration);
-        changes.insertNodeAfter(sourceFile, ancestor, classDeclaration);
-      } else {
-        changes.replaceNode(sourceFile, ancestor, classDeclaration);
-      }
-    }
-    function createClassElementsFromSymbol(symbol) {
-      const memberElements = [];
-      if (symbol.exports) {
-        symbol.exports.forEach((member) => {
-          if (member.name === "prototype" && member.declarations) {
-            const firstDeclaration = member.declarations[0];
-            if (member.declarations.length === 1 && isPropertyAccessExpression(firstDeclaration) && isBinaryExpression(firstDeclaration.parent) && firstDeclaration.parent.operatorToken.kind === 64 /* EqualsToken */ && isObjectLiteralExpression(firstDeclaration.parent.right)) {
-              const prototypes = firstDeclaration.parent.right;
-              createClassElement(
-                prototypes.symbol,
-                /*modifiers*/
-                void 0,
-                memberElements
-              );
-            }
-          } else {
-            createClassElement(member, [factory.createToken(126 /* StaticKeyword */)], memberElements);
-          }
-        });
-      }
-      if (symbol.members) {
-        symbol.members.forEach((member, key) => {
-          var _a, _b, _c, _d;
-          if (key === "constructor" && member.valueDeclaration) {
-            const prototypeAssignment = (_d = (_c = (_b = (_a = symbol.exports) == null ? void 0 : _a.get("prototype")) == null ? void 0 : _b.declarations) == null ? void 0 : _c[0]) == null ? void 0 : _d.parent;
-            if (prototypeAssignment && isBinaryExpression(prototypeAssignment) && isObjectLiteralExpression(prototypeAssignment.right) && some(prototypeAssignment.right.properties, isConstructorAssignment)) {
-            } else {
-              changes.delete(sourceFile, member.valueDeclaration.parent);
-            }
-            return;
-          }
-          createClassElement(
-            member,
-            /*modifiers*/
-            void 0,
-            memberElements
-          );
-        });
-      }
-      return memberElements;
-      function shouldConvertDeclaration(_target, source) {
-        if (isAccessExpression(_target)) {
-          if (isPropertyAccessExpression(_target) && isConstructorAssignment(_target))
-            return true;
-          return isFunctionLike(source);
-        } else {
-          return every(_target.properties, (property) => {
-            if (isMethodDeclaration(property) || isGetOrSetAccessorDeclaration(property))
-              return true;
-            if (isPropertyAssignment(property) && isFunctionExpression(property.initializer) && !!property.name)
-              return true;
-            if (isConstructorAssignment(property))
-              return true;
-            return false;
-          });
-        }
-      }
-      function createClassElement(symbol2, modifiers, members) {
-        if (!(symbol2.flags & 8192 /* Method */) && !(symbol2.flags & 4096 /* ObjectLiteral */)) {
-          return;
-        }
-        const memberDeclaration = symbol2.valueDeclaration;
-        const assignmentBinaryExpression = memberDeclaration.parent;
-        const assignmentExpr = assignmentBinaryExpression.right;
-        if (!shouldConvertDeclaration(memberDeclaration, assignmentExpr)) {
-          return;
-        }
-        if (some(members, (m) => {
-          const name = getNameOfDeclaration(m);
-          if (name && isIdentifier(name) && idText(name) === symbolName(symbol2)) {
-            return true;
-          }
-          return false;
-        })) {
-          return;
-        }
-        const nodeToDelete = assignmentBinaryExpression.parent && assignmentBinaryExpression.parent.kind === 243 /* ExpressionStatement */ ? assignmentBinaryExpression.parent : assignmentBinaryExpression;
-        changes.delete(sourceFile, nodeToDelete);
-        if (!assignmentExpr) {
-          members.push(factory.createPropertyDeclaration(
-            modifiers,
-            symbol2.name,
-            /*questionOrExclamationToken*/
-            void 0,
-            /*type*/
-            void 0,
-            /*initializer*/
-            void 0
-          ));
-          return;
-        }
-        if (isAccessExpression(memberDeclaration) && (isFunctionExpression(assignmentExpr) || isArrowFunction(assignmentExpr))) {
-          const quotePreference = getQuotePreference(sourceFile, preferences);
-          const name = tryGetPropertyName(memberDeclaration, compilerOptions, quotePreference);
-          if (name) {
-            createFunctionLikeExpressionMember(members, assignmentExpr, name);
-          }
-          return;
-        } else if (isObjectLiteralExpression(assignmentExpr)) {
-          forEach(
-            assignmentExpr.properties,
-            (property) => {
-              if (isMethodDeclaration(property) || isGetOrSetAccessorDeclaration(property)) {
-                members.push(property);
-              }
-              if (isPropertyAssignment(property) && isFunctionExpression(property.initializer)) {
-                createFunctionLikeExpressionMember(members, property.initializer, property.name);
-              }
-              if (isConstructorAssignment(property))
-                return;
-              return;
-            }
-          );
-          return;
-        } else {
-          if (isSourceFileJS(sourceFile))
-            return;
-          if (!isPropertyAccessExpression(memberDeclaration))
-            return;
-          const prop = factory.createPropertyDeclaration(
-            modifiers,
-            memberDeclaration.name,
-            /*questionOrExclamationToken*/
-            void 0,
-            /*type*/
-            void 0,
-            assignmentExpr
-          );
-          copyLeadingComments(assignmentBinaryExpression.parent, prop, sourceFile);
-          members.push(prop);
-          return;
-        }
-        function createFunctionLikeExpressionMember(members2, expression, name) {
-          if (isFunctionExpression(expression))
-            return createFunctionExpressionMember(members2, expression, name);
-          else
-            return createArrowFunctionExpressionMember(members2, expression, name);
-        }
-        function createFunctionExpressionMember(members2, functionExpression, name) {
-          const fullModifiers = concatenate(modifiers, getModifierKindFromSource(functionExpression, 134 /* AsyncKeyword */));
-          const method = factory.createMethodDeclaration(
-            fullModifiers,
-            /*asteriskToken*/
-            void 0,
-            name,
-            /*questionToken*/
-            void 0,
-            /*typeParameters*/
-            void 0,
-            functionExpression.parameters,
-            /*type*/
-            void 0,
-            functionExpression.body
-          );
-          copyLeadingComments(assignmentBinaryExpression, method, sourceFile);
-          members2.push(method);
-          return;
-        }
-        function createArrowFunctionExpressionMember(members2, arrowFunction, name) {
-          const arrowFunctionBody = arrowFunction.body;
-          let bodyBlock;
-          if (arrowFunctionBody.kind === 240 /* Block */) {
-            bodyBlock = arrowFunctionBody;
-          } else {
-            bodyBlock = factory.createBlock([factory.createReturnStatement(arrowFunctionBody)]);
-          }
-          const fullModifiers = concatenate(modifiers, getModifierKindFromSource(arrowFunction, 134 /* AsyncKeyword */));
-          const method = factory.createMethodDeclaration(
-            fullModifiers,
-            /*asteriskToken*/
-            void 0,
-            name,
-            /*questionToken*/
-            void 0,
-            /*typeParameters*/
-            void 0,
-            arrowFunction.parameters,
-            /*type*/
-            void 0,
-            bodyBlock
-          );
-          copyLeadingComments(assignmentBinaryExpression, method, sourceFile);
-          members2.push(method);
-        }
-      }
-    }
-    function createClassFromVariableDeclaration(node) {
-      const initializer = node.initializer;
-      if (!initializer || !isFunctionExpression(initializer) || !isIdentifier(node.name)) {
-        return void 0;
-      }
-      const memberElements = createClassElementsFromSymbol(node.symbol);
-      if (initializer.body) {
-        memberElements.unshift(factory.createConstructorDeclaration(
-          /*modifiers*/
-          void 0,
-          initializer.parameters,
-          initializer.body
-        ));
-      }
-      const modifiers = getModifierKindFromSource(node.parent.parent, 95 /* ExportKeyword */);
-      const cls = factory.createClassDeclaration(
-        modifiers,
-        node.name,
-        /*typeParameters*/
-        void 0,
-        /*heritageClauses*/
-        void 0,
-        memberElements
-      );
-      return cls;
-    }
-    function createClassFromFunction(node) {
-      const memberElements = createClassElementsFromSymbol(ctorSymbol);
-      if (node.body) {
-        memberElements.unshift(factory.createConstructorDeclaration(
-          /*modifiers*/
-          void 0,
-          node.parameters,
-          node.body
-        ));
-      }
-      const modifiers = getModifierKindFromSource(node, 95 /* ExportKeyword */);
-      const cls = factory.createClassDeclaration(
-        modifiers,
-        node.name,
-        /*typeParameters*/
-        void 0,
-        /*heritageClauses*/
-        void 0,
-        memberElements
-      );
-      return cls;
-    }
-  }
-  function getModifierKindFromSource(source, kind) {
-    return canHaveModifiers(source) ? filter(source.modifiers, (modifier) => modifier.kind === kind) : void 0;
-  }
-  function isConstructorAssignment(x) {
-    if (!x.name)
-      return false;
-    if (isIdentifier(x.name) && x.name.text === "constructor")
-      return true;
-    return false;
-  }
-  function tryGetPropertyName(node, compilerOptions, quotePreference) {
-    if (isPropertyAccessExpression(node)) {
-      return node.name;
-    }
-    const propName = node.argumentExpression;
-    if (isNumericLiteral(propName)) {
-      return propName;
-    }
-    if (isStringLiteralLike(propName)) {
-      return isIdentifierText(propName.text, getEmitScriptTarget(compilerOptions)) ? factory.createIdentifier(propName.text) : isNoSubstitutionTemplateLiteral(propName) ? factory.createStringLiteral(propName.text, quotePreference === 0 /* Single */) : propName;
-    }
-    return void 0;
-  }
-  var fixId9, errorCodes10;
-  var init_convertFunctionToEs6Class = __esm({
-    "src/services/codefixes/convertFunctionToEs6Class.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_codefix();
-      fixId9 = "convertFunctionToEs6Class";
-      errorCodes10 = [Diagnostics.This_constructor_function_may_be_converted_to_a_class_declaration.code];
-      registerCodeFix({
-        errorCodes: errorCodes10,
-        getCodeActions(context) {
-          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange9(t, context.sourceFile, context.span.start, context.program.getTypeChecker(), context.preferences, context.program.getCompilerOptions()));
-          return [createCodeFixAction(fixId9, changes, Diagnostics.Convert_function_to_an_ES2015_class, fixId9, Diagnostics.Convert_all_constructor_functions_to_classes)];
-        },
-        fixIds: [fixId9],
-        getAllCodeActions: (context) => codeFixAll(context, errorCodes10, (changes, err) => doChange9(changes, err.file, err.start, context.program.getTypeChecker(), context.preferences, context.program.getCompilerOptions()))
-      });
-    }
-  });
-
-  // src/services/codefixes/convertToAsyncFunction.ts
-  function convertToAsyncFunction(changes, sourceFile, position, checker) {
-    const tokenAtPosition = getTokenAtPosition(sourceFile, position);
-    let functionToConvert;
-    if (isIdentifier(tokenAtPosition) && isVariableDeclaration(tokenAtPosition.parent) && tokenAtPosition.parent.initializer && isFunctionLikeDeclaration(tokenAtPosition.parent.initializer)) {
-      functionToConvert = tokenAtPosition.parent.initializer;
-    } else {
-      functionToConvert = tryCast(getContainingFunction(getTokenAtPosition(sourceFile, position)), canBeConvertedToAsync);
-    }
-    if (!functionToConvert) {
-      return;
-    }
-    const synthNamesMap = /* @__PURE__ */ new Map();
-    const isInJavascript = isInJSFile(functionToConvert);
-    const setOfExpressionsToReturn = getAllPromiseExpressionsToReturn(functionToConvert, checker);
-    const functionToConvertRenamed = renameCollidingVarNames(functionToConvert, checker, synthNamesMap);
-    if (!returnsPromise(functionToConvertRenamed, checker)) {
-      return;
-    }
-    const returnStatements = functionToConvertRenamed.body && isBlock(functionToConvertRenamed.body) ? getReturnStatementsWithPromiseHandlers(functionToConvertRenamed.body, checker) : emptyArray;
-    const transformer = { checker, synthNamesMap, setOfExpressionsToReturn, isInJSFile: isInJavascript };
-    if (!returnStatements.length) {
-      return;
-    }
-    const pos = skipTrivia(sourceFile.text, moveRangePastModifiers(functionToConvert).pos);
-    changes.insertModifierAt(sourceFile, pos, 134 /* AsyncKeyword */, { suffix: " " });
-    for (const returnStatement of returnStatements) {
-      forEachChild(returnStatement, function visit(node) {
-        if (isCallExpression(node)) {
-          const newNodes = transformExpression(
-            node,
-            node,
-            transformer,
-            /*hasContinuation*/
-            false
-          );
-          if (hasFailed()) {
-            return true;
-          }
-          changes.replaceNodeWithNodes(sourceFile, returnStatement, newNodes);
-        } else if (!isFunctionLike(node)) {
-          forEachChild(node, visit);
-          if (hasFailed()) {
-            return true;
-          }
-        }
-      });
-      if (hasFailed()) {
-        return;
-      }
-    }
-  }
-  function getReturnStatementsWithPromiseHandlers(body, checker) {
-    const res = [];
-    forEachReturnStatement(body, (ret) => {
-      if (isReturnStatementWithFixablePromiseHandler(ret, checker))
-        res.push(ret);
-    });
-    return res;
-  }
-  function getAllPromiseExpressionsToReturn(func, checker) {
-    if (!func.body) {
-      return /* @__PURE__ */ new Set();
-    }
-    const setOfExpressionsToReturn = /* @__PURE__ */ new Set();
-    forEachChild(func.body, function visit(node) {
-      if (isPromiseReturningCallExpression(node, checker, "then")) {
-        setOfExpressionsToReturn.add(getNodeId(node));
-        forEach(node.arguments, visit);
-      } else if (isPromiseReturningCallExpression(node, checker, "catch") || isPromiseReturningCallExpression(node, checker, "finally")) {
-        setOfExpressionsToReturn.add(getNodeId(node));
-        forEachChild(node, visit);
-      } else if (isPromiseTypedExpression(node, checker)) {
-        setOfExpressionsToReturn.add(getNodeId(node));
-      } else {
-        forEachChild(node, visit);
-      }
-    });
-    return setOfExpressionsToReturn;
-  }
-  function isPromiseReturningCallExpression(node, checker, name) {
-    if (!isCallExpression(node))
-      return false;
-    const isExpressionOfName = hasPropertyAccessExpressionWithName(node, name);
-    const nodeType = isExpressionOfName && checker.getTypeAtLocation(node);
-    return !!(nodeType && checker.getPromisedTypeOfPromise(nodeType));
-  }
-  function isReferenceToType(type, target) {
-    return (getObjectFlags(type) & 4 /* Reference */) !== 0 && type.target === target;
-  }
-  function getExplicitPromisedTypeOfPromiseReturningCallExpression(node, callback, checker) {
-    if (node.expression.name.escapedText === "finally") {
-      return void 0;
-    }
-    const promiseType = checker.getTypeAtLocation(node.expression.expression);
-    if (isReferenceToType(promiseType, checker.getPromiseType()) || isReferenceToType(promiseType, checker.getPromiseLikeType())) {
-      if (node.expression.name.escapedText === "then") {
-        if (callback === elementAt(node.arguments, 0)) {
-          return elementAt(node.typeArguments, 0);
-        } else if (callback === elementAt(node.arguments, 1)) {
-          return elementAt(node.typeArguments, 1);
-        }
-      } else {
-        return elementAt(node.typeArguments, 0);
-      }
-    }
-  }
-  function isPromiseTypedExpression(node, checker) {
-    if (!isExpression(node))
-      return false;
-    return !!checker.getPromisedTypeOfPromise(checker.getTypeAtLocation(node));
-  }
-  function renameCollidingVarNames(nodeToRename, checker, synthNamesMap) {
-    const identsToRenameMap = /* @__PURE__ */ new Map();
-    const collidingSymbolMap = createMultiMap();
-    forEachChild(nodeToRename, function visit(node) {
-      if (!isIdentifier(node)) {
-        forEachChild(node, visit);
-        return;
-      }
-      const symbol = checker.getSymbolAtLocation(node);
-      if (symbol) {
-        const type = checker.getTypeAtLocation(node);
-        const lastCallSignature = getLastCallSignature(type, checker);
-        const symbolIdString = getSymbolId(symbol).toString();
-        if (lastCallSignature && !isParameter(node.parent) && !isFunctionLikeDeclaration(node.parent) && !synthNamesMap.has(symbolIdString)) {
-          const firstParameter = firstOrUndefined(lastCallSignature.parameters);
-          const ident = (firstParameter == null ? void 0 : firstParameter.valueDeclaration) && isParameter(firstParameter.valueDeclaration) && tryCast(firstParameter.valueDeclaration.name, isIdentifier) || factory.createUniqueName("result", 16 /* Optimistic */);
-          const synthName = getNewNameIfConflict(ident, collidingSymbolMap);
-          synthNamesMap.set(symbolIdString, synthName);
-          collidingSymbolMap.add(ident.text, symbol);
-        } else if (node.parent && (isParameter(node.parent) || isVariableDeclaration(node.parent) || isBindingElement(node.parent))) {
-          const originalName = node.text;
-          const collidingSymbols = collidingSymbolMap.get(originalName);
-          if (collidingSymbols && collidingSymbols.some((prevSymbol) => prevSymbol !== symbol)) {
-            const newName = getNewNameIfConflict(node, collidingSymbolMap);
-            identsToRenameMap.set(symbolIdString, newName.identifier);
-            synthNamesMap.set(symbolIdString, newName);
-            collidingSymbolMap.add(originalName, symbol);
-          } else {
-            const identifier = getSynthesizedDeepClone(node);
-            synthNamesMap.set(symbolIdString, createSynthIdentifier(identifier));
-            collidingSymbolMap.add(originalName, symbol);
-          }
-        }
-      }
-    });
-    return getSynthesizedDeepCloneWithReplacements(
-      nodeToRename,
-      /*includeTrivia*/
-      true,
-      (original) => {
-        if (isBindingElement(original) && isIdentifier(original.name) && isObjectBindingPattern(original.parent)) {
-          const symbol = checker.getSymbolAtLocation(original.name);
-          const renameInfo = symbol && identsToRenameMap.get(String(getSymbolId(symbol)));
-          if (renameInfo && renameInfo.text !== (original.name || original.propertyName).getText()) {
-            return factory.createBindingElement(
-              original.dotDotDotToken,
-              original.propertyName || original.name,
-              renameInfo,
-              original.initializer
-            );
-          }
-        } else if (isIdentifier(original)) {
-          const symbol = checker.getSymbolAtLocation(original);
-          const renameInfo = symbol && identsToRenameMap.get(String(getSymbolId(symbol)));
-          if (renameInfo) {
-            return factory.createIdentifier(renameInfo.text);
-          }
-        }
-      }
-    );
-  }
-  function getNewNameIfConflict(name, originalNames) {
-    const numVarsSameName = (originalNames.get(name.text) || emptyArray).length;
-    const identifier = numVarsSameName === 0 ? name : factory.createIdentifier(name.text + "_" + numVarsSameName);
-    return createSynthIdentifier(identifier);
-  }
-  function hasFailed() {
-    return !codeActionSucceeded;
-  }
-  function silentFail() {
-    codeActionSucceeded = false;
-    return emptyArray;
-  }
-  function transformExpression(returnContextNode, node, transformer, hasContinuation, continuationArgName) {
-    if (isPromiseReturningCallExpression(node, transformer.checker, "then")) {
-      return transformThen(node, elementAt(node.arguments, 0), elementAt(node.arguments, 1), transformer, hasContinuation, continuationArgName);
-    }
-    if (isPromiseReturningCallExpression(node, transformer.checker, "catch")) {
-      return transformCatch(node, elementAt(node.arguments, 0), transformer, hasContinuation, continuationArgName);
-    }
-    if (isPromiseReturningCallExpression(node, transformer.checker, "finally")) {
-      return transformFinally(node, elementAt(node.arguments, 0), transformer, hasContinuation, continuationArgName);
-    }
-    if (isPropertyAccessExpression(node)) {
-      return transformExpression(returnContextNode, node.expression, transformer, hasContinuation, continuationArgName);
-    }
-    const nodeType = transformer.checker.getTypeAtLocation(node);
-    if (nodeType && transformer.checker.getPromisedTypeOfPromise(nodeType)) {
-      Debug.assertNode(getOriginalNode(node).parent, isPropertyAccessExpression);
-      return transformPromiseExpressionOfPropertyAccess(returnContextNode, node, transformer, hasContinuation, continuationArgName);
-    }
-    return silentFail();
-  }
-  function isNullOrUndefined2({ checker }, node) {
-    if (node.kind === 106 /* NullKeyword */)
-      return true;
-    if (isIdentifier(node) && !isGeneratedIdentifier(node) && idText(node) === "undefined") {
-      const symbol = checker.getSymbolAtLocation(node);
-      return !symbol || checker.isUndefinedSymbol(symbol);
-    }
-    return false;
-  }
-  function createUniqueSynthName(prevArgName) {
-    const renamedPrevArg = factory.createUniqueName(prevArgName.identifier.text, 16 /* Optimistic */);
-    return createSynthIdentifier(renamedPrevArg);
-  }
-  function getPossibleNameForVarDecl(node, transformer, continuationArgName) {
-    let possibleNameForVarDecl;
-    if (continuationArgName && !shouldReturn(node, transformer)) {
-      if (isSynthIdentifier(continuationArgName)) {
-        possibleNameForVarDecl = continuationArgName;
-        transformer.synthNamesMap.forEach((val, key) => {
-          if (val.identifier.text === continuationArgName.identifier.text) {
-            const newSynthName = createUniqueSynthName(continuationArgName);
-            transformer.synthNamesMap.set(key, newSynthName);
-          }
-        });
-      } else {
-        possibleNameForVarDecl = createSynthIdentifier(factory.createUniqueName("result", 16 /* Optimistic */), continuationArgName.types);
-      }
-      declareSynthIdentifier(possibleNameForVarDecl);
-    }
-    return possibleNameForVarDecl;
-  }
-  function finishCatchOrFinallyTransform(node, transformer, tryStatement, possibleNameForVarDecl, continuationArgName) {
-    const statements = [];
-    let varDeclIdentifier;
-    if (possibleNameForVarDecl && !shouldReturn(node, transformer)) {
-      varDeclIdentifier = getSynthesizedDeepClone(declareSynthIdentifier(possibleNameForVarDecl));
-      const typeArray = possibleNameForVarDecl.types;
-      const unionType = transformer.checker.getUnionType(typeArray, 2 /* Subtype */);
-      const unionTypeNode = transformer.isInJSFile ? void 0 : transformer.checker.typeToTypeNode(
-        unionType,
-        /*enclosingDeclaration*/
-        void 0,
-        /*flags*/
-        void 0
-      );
-      const varDecl = [factory.createVariableDeclaration(
-        varDeclIdentifier,
-        /*exclamationToken*/
-        void 0,
-        unionTypeNode
-      )];
-      const varDeclList = factory.createVariableStatement(
-        /*modifiers*/
-        void 0,
-        factory.createVariableDeclarationList(varDecl, 1 /* Let */)
-      );
-      statements.push(varDeclList);
-    }
-    statements.push(tryStatement);
-    if (continuationArgName && varDeclIdentifier && isSynthBindingPattern(continuationArgName)) {
-      statements.push(factory.createVariableStatement(
-        /*modifiers*/
-        void 0,
-        factory.createVariableDeclarationList(
-          [
-            factory.createVariableDeclaration(
-              getSynthesizedDeepClone(declareSynthBindingPattern(continuationArgName)),
-              /*exclamationToken*/
-              void 0,
-              /*type*/
-              void 0,
-              varDeclIdentifier
-            )
-          ],
-          2 /* Const */
-        )
-      ));
-    }
-    return statements;
-  }
-  function transformFinally(node, onFinally, transformer, hasContinuation, continuationArgName) {
-    if (!onFinally || isNullOrUndefined2(transformer, onFinally)) {
-      return transformExpression(
-        /* returnContextNode */
-        node,
-        node.expression.expression,
-        transformer,
-        hasContinuation,
-        continuationArgName
-      );
-    }
-    const possibleNameForVarDecl = getPossibleNameForVarDecl(node, transformer, continuationArgName);
-    const inlinedLeftHandSide = transformExpression(
-      /*returnContextNode*/
-      node,
-      node.expression.expression,
-      transformer,
-      /*hasContinuation*/
-      true,
-      possibleNameForVarDecl
-    );
-    if (hasFailed())
-      return silentFail();
-    const inlinedCallback = transformCallbackArgument(
-      onFinally,
-      hasContinuation,
-      /*continuationArgName*/
-      void 0,
-      /*inputArgName*/
-      void 0,
-      node,
-      transformer
-    );
-    if (hasFailed())
-      return silentFail();
-    const tryBlock = factory.createBlock(inlinedLeftHandSide);
-    const finallyBlock = factory.createBlock(inlinedCallback);
-    const tryStatement = factory.createTryStatement(
-      tryBlock,
-      /*catchClause*/
-      void 0,
-      finallyBlock
-    );
-    return finishCatchOrFinallyTransform(node, transformer, tryStatement, possibleNameForVarDecl, continuationArgName);
-  }
-  function transformCatch(node, onRejected, transformer, hasContinuation, continuationArgName) {
-    if (!onRejected || isNullOrUndefined2(transformer, onRejected)) {
-      return transformExpression(
-        /* returnContextNode */
-        node,
-        node.expression.expression,
-        transformer,
-        hasContinuation,
-        continuationArgName
-      );
-    }
-    const inputArgName = getArgBindingName(onRejected, transformer);
-    const possibleNameForVarDecl = getPossibleNameForVarDecl(node, transformer, continuationArgName);
-    const inlinedLeftHandSide = transformExpression(
-      /*returnContextNode*/
-      node,
-      node.expression.expression,
-      transformer,
-      /*hasContinuation*/
-      true,
-      possibleNameForVarDecl
-    );
-    if (hasFailed())
-      return silentFail();
-    const inlinedCallback = transformCallbackArgument(onRejected, hasContinuation, possibleNameForVarDecl, inputArgName, node, transformer);
-    if (hasFailed())
-      return silentFail();
-    const tryBlock = factory.createBlock(inlinedLeftHandSide);
-    const catchClause = factory.createCatchClause(inputArgName && getSynthesizedDeepClone(declareSynthBindingName(inputArgName)), factory.createBlock(inlinedCallback));
-    const tryStatement = factory.createTryStatement(
-      tryBlock,
-      catchClause,
-      /*finallyBlock*/
-      void 0
-    );
-    return finishCatchOrFinallyTransform(node, transformer, tryStatement, possibleNameForVarDecl, continuationArgName);
-  }
-  function transformThen(node, onFulfilled, onRejected, transformer, hasContinuation, continuationArgName) {
-    if (!onFulfilled || isNullOrUndefined2(transformer, onFulfilled)) {
-      return transformCatch(node, onRejected, transformer, hasContinuation, continuationArgName);
-    }
-    if (onRejected && !isNullOrUndefined2(transformer, onRejected)) {
-      return silentFail();
-    }
-    const inputArgName = getArgBindingName(onFulfilled, transformer);
-    const inlinedLeftHandSide = transformExpression(
-      node.expression.expression,
-      node.expression.expression,
-      transformer,
-      /*hasContinuation*/
-      true,
-      inputArgName
-    );
-    if (hasFailed())
-      return silentFail();
-    const inlinedCallback = transformCallbackArgument(onFulfilled, hasContinuation, continuationArgName, inputArgName, node, transformer);
-    if (hasFailed())
-      return silentFail();
-    return concatenate(inlinedLeftHandSide, inlinedCallback);
-  }
-  function transformPromiseExpressionOfPropertyAccess(returnContextNode, node, transformer, hasContinuation, continuationArgName) {
-    if (shouldReturn(returnContextNode, transformer)) {
-      let returnValue = getSynthesizedDeepClone(node);
-      if (hasContinuation) {
-        returnValue = factory.createAwaitExpression(returnValue);
-      }
-      return [factory.createReturnStatement(returnValue)];
-    }
-    return createVariableOrAssignmentOrExpressionStatement(
-      continuationArgName,
-      factory.createAwaitExpression(node),
-      /*typeAnnotation*/
-      void 0
-    );
-  }
-  function createVariableOrAssignmentOrExpressionStatement(variableName, rightHandSide, typeAnnotation) {
-    if (!variableName || isEmptyBindingName(variableName)) {
-      return [factory.createExpressionStatement(rightHandSide)];
-    }
-    if (isSynthIdentifier(variableName) && variableName.hasBeenDeclared) {
-      return [factory.createExpressionStatement(factory.createAssignment(getSynthesizedDeepClone(referenceSynthIdentifier(variableName)), rightHandSide))];
-    }
-    return [
-      factory.createVariableStatement(
-        /*modifiers*/
-        void 0,
-        factory.createVariableDeclarationList(
-          [
-            factory.createVariableDeclaration(
-              getSynthesizedDeepClone(declareSynthBindingName(variableName)),
-              /*exclamationToken*/
-              void 0,
-              typeAnnotation,
-              rightHandSide
-            )
-          ],
-          2 /* Const */
-        )
-      )
-    ];
-  }
-  function maybeAnnotateAndReturn(expressionToReturn, typeAnnotation) {
-    if (typeAnnotation && expressionToReturn) {
-      const name = factory.createUniqueName("result", 16 /* Optimistic */);
-      return [
-        ...createVariableOrAssignmentOrExpressionStatement(createSynthIdentifier(name), expressionToReturn, typeAnnotation),
-        factory.createReturnStatement(name)
-      ];
-    }
-    return [factory.createReturnStatement(expressionToReturn)];
-  }
-  function transformCallbackArgument(func, hasContinuation, continuationArgName, inputArgName, parent2, transformer) {
-    var _a;
-    switch (func.kind) {
-      case 106 /* NullKeyword */:
-        break;
-      case 210 /* PropertyAccessExpression */:
-      case 80 /* Identifier */:
-        if (!inputArgName) {
-          break;
-        }
-        const synthCall = factory.createCallExpression(
-          getSynthesizedDeepClone(func),
-          /*typeArguments*/
-          void 0,
-          isSynthIdentifier(inputArgName) ? [referenceSynthIdentifier(inputArgName)] : []
-        );
-        if (shouldReturn(parent2, transformer)) {
-          return maybeAnnotateAndReturn(synthCall, getExplicitPromisedTypeOfPromiseReturningCallExpression(parent2, func, transformer.checker));
-        }
-        const type = transformer.checker.getTypeAtLocation(func);
-        const callSignatures = transformer.checker.getSignaturesOfType(type, 0 /* Call */);
-        if (!callSignatures.length) {
-          return silentFail();
-        }
-        const returnType = callSignatures[0].getReturnType();
-        const varDeclOrAssignment = createVariableOrAssignmentOrExpressionStatement(continuationArgName, factory.createAwaitExpression(synthCall), getExplicitPromisedTypeOfPromiseReturningCallExpression(parent2, func, transformer.checker));
-        if (continuationArgName) {
-          continuationArgName.types.push(transformer.checker.getAwaitedType(returnType) || returnType);
-        }
-        return varDeclOrAssignment;
-      case 217 /* FunctionExpression */:
-      case 218 /* ArrowFunction */: {
-        const funcBody = func.body;
-        const returnType2 = (_a = getLastCallSignature(transformer.checker.getTypeAtLocation(func), transformer.checker)) == null ? void 0 : _a.getReturnType();
-        if (isBlock(funcBody)) {
-          let refactoredStmts = [];
-          let seenReturnStatement = false;
-          for (const statement of funcBody.statements) {
-            if (isReturnStatement(statement)) {
-              seenReturnStatement = true;
-              if (isReturnStatementWithFixablePromiseHandler(statement, transformer.checker)) {
-                refactoredStmts = refactoredStmts.concat(transformReturnStatementWithFixablePromiseHandler(transformer, statement, hasContinuation, continuationArgName));
-              } else {
-                const possiblyAwaitedRightHandSide = returnType2 && statement.expression ? getPossiblyAwaitedRightHandSide(transformer.checker, returnType2, statement.expression) : statement.expression;
-                refactoredStmts.push(...maybeAnnotateAndReturn(possiblyAwaitedRightHandSide, getExplicitPromisedTypeOfPromiseReturningCallExpression(parent2, func, transformer.checker)));
-              }
-            } else if (hasContinuation && forEachReturnStatement(statement, returnTrue)) {
-              return silentFail();
-            } else {
-              refactoredStmts.push(statement);
-            }
-          }
-          return shouldReturn(parent2, transformer) ? refactoredStmts.map((s) => getSynthesizedDeepClone(s)) : removeReturns(
-            refactoredStmts,
-            continuationArgName,
-            transformer,
-            seenReturnStatement
-          );
-        } else {
-          const inlinedStatements = isFixablePromiseHandler(funcBody, transformer.checker) ? transformReturnStatementWithFixablePromiseHandler(transformer, factory.createReturnStatement(funcBody), hasContinuation, continuationArgName) : emptyArray;
-          if (inlinedStatements.length > 0) {
-            return inlinedStatements;
-          }
-          if (returnType2) {
-            const possiblyAwaitedRightHandSide = getPossiblyAwaitedRightHandSide(transformer.checker, returnType2, funcBody);
-            if (!shouldReturn(parent2, transformer)) {
-              const transformedStatement = createVariableOrAssignmentOrExpressionStatement(
-                continuationArgName,
-                possiblyAwaitedRightHandSide,
-                /*typeAnnotation*/
-                void 0
-              );
-              if (continuationArgName) {
-                continuationArgName.types.push(transformer.checker.getAwaitedType(returnType2) || returnType2);
-              }
-              return transformedStatement;
-            } else {
-              return maybeAnnotateAndReturn(possiblyAwaitedRightHandSide, getExplicitPromisedTypeOfPromiseReturningCallExpression(parent2, func, transformer.checker));
-            }
-          } else {
-            return silentFail();
-          }
-        }
-      }
-      default:
-        return silentFail();
-    }
-    return emptyArray;
-  }
-  function getPossiblyAwaitedRightHandSide(checker, type, expr) {
-    const rightHandSide = getSynthesizedDeepClone(expr);
-    return !!checker.getPromisedTypeOfPromise(type) ? factory.createAwaitExpression(rightHandSide) : rightHandSide;
-  }
-  function getLastCallSignature(type, checker) {
-    const callSignatures = checker.getSignaturesOfType(type, 0 /* Call */);
-    return lastOrUndefined(callSignatures);
-  }
-  function removeReturns(stmts, prevArgName, transformer, seenReturnStatement) {
-    const ret = [];
-    for (const stmt of stmts) {
-      if (isReturnStatement(stmt)) {
-        if (stmt.expression) {
-          const possiblyAwaitedExpression = isPromiseTypedExpression(stmt.expression, transformer.checker) ? factory.createAwaitExpression(stmt.expression) : stmt.expression;
-          if (prevArgName === void 0) {
-            ret.push(factory.createExpressionStatement(possiblyAwaitedExpression));
-          } else if (isSynthIdentifier(prevArgName) && prevArgName.hasBeenDeclared) {
-            ret.push(factory.createExpressionStatement(factory.createAssignment(referenceSynthIdentifier(prevArgName), possiblyAwaitedExpression)));
-          } else {
-            ret.push(factory.createVariableStatement(
-              /*modifiers*/
-              void 0,
-              factory.createVariableDeclarationList([factory.createVariableDeclaration(
-                declareSynthBindingName(prevArgName),
-                /*exclamationToken*/
-                void 0,
-                /*type*/
-                void 0,
-                possiblyAwaitedExpression
-              )], 2 /* Const */)
-            ));
-          }
-        }
-      } else {
-        ret.push(getSynthesizedDeepClone(stmt));
-      }
-    }
-    if (!seenReturnStatement && prevArgName !== void 0) {
-      ret.push(factory.createVariableStatement(
-        /*modifiers*/
-        void 0,
-        factory.createVariableDeclarationList([factory.createVariableDeclaration(
-          declareSynthBindingName(prevArgName),
-          /*exclamationToken*/
-          void 0,
-          /*type*/
-          void 0,
-          factory.createIdentifier("undefined")
-        )], 2 /* Const */)
-      ));
-    }
-    return ret;
-  }
-  function transformReturnStatementWithFixablePromiseHandler(transformer, innerRetStmt, hasContinuation, continuationArgName) {
-    let innerCbBody = [];
-    forEachChild(innerRetStmt, function visit(node) {
-      if (isCallExpression(node)) {
-        const temp = transformExpression(node, node, transformer, hasContinuation, continuationArgName);
-        innerCbBody = innerCbBody.concat(temp);
-        if (innerCbBody.length > 0) {
-          return;
-        }
-      } else if (!isFunctionLike(node)) {
-        forEachChild(node, visit);
-      }
-    });
-    return innerCbBody;
-  }
-  function getArgBindingName(funcNode, transformer) {
-    const types = [];
-    let name;
-    if (isFunctionLikeDeclaration(funcNode)) {
-      if (funcNode.parameters.length > 0) {
-        const param = funcNode.parameters[0].name;
-        name = getMappedBindingNameOrDefault(param);
-      }
-    } else if (isIdentifier(funcNode)) {
-      name = getMapEntryOrDefault(funcNode);
-    } else if (isPropertyAccessExpression(funcNode) && isIdentifier(funcNode.name)) {
-      name = getMapEntryOrDefault(funcNode.name);
-    }
-    if (!name || "identifier" in name && name.identifier.text === "undefined") {
-      return void 0;
-    }
-    return name;
-    function getMappedBindingNameOrDefault(bindingName) {
-      if (isIdentifier(bindingName))
-        return getMapEntryOrDefault(bindingName);
-      const elements = flatMap(bindingName.elements, (element) => {
-        if (isOmittedExpression(element))
-          return [];
-        return [getMappedBindingNameOrDefault(element.name)];
-      });
-      return createSynthBindingPattern(bindingName, elements);
-    }
-    function getMapEntryOrDefault(identifier) {
-      const originalNode = getOriginalNode2(identifier);
-      const symbol = getSymbol2(originalNode);
-      if (!symbol) {
-        return createSynthIdentifier(identifier, types);
-      }
-      const mapEntry = transformer.synthNamesMap.get(getSymbolId(symbol).toString());
-      return mapEntry || createSynthIdentifier(identifier, types);
-    }
-    function getSymbol2(node) {
-      var _a;
-      return ((_a = tryCast(node, canHaveSymbol)) == null ? void 0 : _a.symbol) ?? transformer.checker.getSymbolAtLocation(node);
-    }
-    function getOriginalNode2(node) {
-      return node.original ? node.original : node;
-    }
-  }
-  function isEmptyBindingName(bindingName) {
-    if (!bindingName) {
-      return true;
-    }
-    if (isSynthIdentifier(bindingName)) {
-      return !bindingName.identifier.text;
-    }
-    return every(bindingName.elements, isEmptyBindingName);
-  }
-  function createSynthIdentifier(identifier, types = []) {
-    return { kind: 0 /* Identifier */, identifier, types, hasBeenDeclared: false, hasBeenReferenced: false };
-  }
-  function createSynthBindingPattern(bindingPattern, elements = emptyArray, types = []) {
-    return { kind: 1 /* BindingPattern */, bindingPattern, elements, types };
-  }
-  function referenceSynthIdentifier(synthId) {
-    synthId.hasBeenReferenced = true;
-    return synthId.identifier;
-  }
-  function declareSynthBindingName(synthName) {
-    return isSynthIdentifier(synthName) ? declareSynthIdentifier(synthName) : declareSynthBindingPattern(synthName);
-  }
-  function declareSynthBindingPattern(synthPattern) {
-    for (const element of synthPattern.elements) {
-      declareSynthBindingName(element);
-    }
-    return synthPattern.bindingPattern;
-  }
-  function declareSynthIdentifier(synthId) {
-    synthId.hasBeenDeclared = true;
-    return synthId.identifier;
-  }
-  function isSynthIdentifier(bindingName) {
-    return bindingName.kind === 0 /* Identifier */;
-  }
-  function isSynthBindingPattern(bindingName) {
-    return bindingName.kind === 1 /* BindingPattern */;
-  }
-  function shouldReturn(expression, transformer) {
-    return !!expression.original && transformer.setOfExpressionsToReturn.has(getNodeId(expression.original));
-  }
-  var fixId10, errorCodes11, codeActionSucceeded;
-  var init_convertToAsyncFunction = __esm({
-    "src/services/codefixes/convertToAsyncFunction.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_codefix();
-      fixId10 = "convertToAsyncFunction";
-      errorCodes11 = [Diagnostics.This_may_be_converted_to_an_async_function.code];
-      codeActionSucceeded = true;
-      registerCodeFix({
-        errorCodes: errorCodes11,
-        getCodeActions(context) {
-          codeActionSucceeded = true;
-          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => convertToAsyncFunction(t, context.sourceFile, context.span.start, context.program.getTypeChecker()));
-          return codeActionSucceeded ? [createCodeFixAction(fixId10, changes, Diagnostics.Convert_to_async_function, fixId10, Diagnostics.Convert_all_to_async_functions)] : [];
-        },
-        fixIds: [fixId10],
-        getAllCodeActions: (context) => codeFixAll(context, errorCodes11, (changes, err) => convertToAsyncFunction(changes, err.file, err.start, context.program.getTypeChecker()))
-      });
-    }
-  });
-
-  // src/services/codefixes/convertToEsModule.ts
-  function fixImportOfModuleExports(importingFile, exportingFile, changes, quotePreference) {
-    for (const moduleSpecifier of importingFile.imports) {
-      const imported = getResolvedModule(importingFile, moduleSpecifier.text, getModeForUsageLocation(importingFile, moduleSpecifier));
-      if (!imported || imported.resolvedFileName !== exportingFile.fileName) {
-        continue;
-      }
-      const importNode = importFromModuleSpecifier(moduleSpecifier);
-      switch (importNode.kind) {
-        case 270 /* ImportEqualsDeclaration */:
-          changes.replaceNode(importingFile, importNode, makeImport(
-            importNode.name,
-            /*namedImports*/
-            void 0,
-            moduleSpecifier,
-            quotePreference
-          ));
-          break;
-        case 212 /* CallExpression */:
-          if (isRequireCall(
-            importNode,
-            /*requireStringLiteralLikeArgument*/
-            false
-          )) {
-            changes.replaceNode(importingFile, importNode, factory.createPropertyAccessExpression(getSynthesizedDeepClone(importNode), "default"));
-          }
-          break;
-      }
-    }
-  }
-  function convertFileToEsModule(sourceFile, checker, changes, target, quotePreference) {
-    const identifiers = { original: collectFreeIdentifiers(sourceFile), additional: /* @__PURE__ */ new Set() };
-    const exports = collectExportRenames(sourceFile, checker, identifiers);
-    convertExportsAccesses(sourceFile, exports, changes);
-    let moduleExportsChangedToDefault = false;
-    let useSitesToUnqualify;
-    for (const statement of filter(sourceFile.statements, isVariableStatement)) {
-      const newUseSites = convertVariableStatement(sourceFile, statement, changes, checker, identifiers, target, quotePreference);
-      if (newUseSites) {
-        copyEntries(newUseSites, useSitesToUnqualify ?? (useSitesToUnqualify = /* @__PURE__ */ new Map()));
-      }
-    }
-    for (const statement of filter(sourceFile.statements, (s) => !isVariableStatement(s))) {
-      const moduleExportsChanged = convertStatement(sourceFile, statement, checker, changes, identifiers, target, exports, useSitesToUnqualify, quotePreference);
-      moduleExportsChangedToDefault = moduleExportsChangedToDefault || moduleExportsChanged;
-    }
-    useSitesToUnqualify == null ? void 0 : useSitesToUnqualify.forEach((replacement, original) => {
-      changes.replaceNode(sourceFile, original, replacement);
-    });
-    return moduleExportsChangedToDefault;
-  }
-  function collectExportRenames(sourceFile, checker, identifiers) {
-    const res = /* @__PURE__ */ new Map();
-    forEachExportReference(sourceFile, (node) => {
-      const { text } = node.name;
-      if (!res.has(text) && (isIdentifierANonContextualKeyword(node.name) || checker.resolveName(
-        text,
-        node,
-        111551 /* Value */,
-        /*excludeGlobals*/
-        true
-      ))) {
-        res.set(text, makeUniqueName(`_${text}`, identifiers));
-      }
-    });
-    return res;
-  }
-  function convertExportsAccesses(sourceFile, exports, changes) {
-    forEachExportReference(sourceFile, (node, isAssignmentLhs) => {
-      if (isAssignmentLhs) {
-        return;
-      }
-      const { text } = node.name;
-      changes.replaceNode(sourceFile, node, factory.createIdentifier(exports.get(text) || text));
-    });
-  }
-  function forEachExportReference(sourceFile, cb) {
-    sourceFile.forEachChild(function recur(node) {
-      if (isPropertyAccessExpression(node) && isExportsOrModuleExportsOrAlias(sourceFile, node.expression) && isIdentifier(node.name)) {
-        const { parent: parent2 } = node;
-        cb(node, isBinaryExpression(parent2) && parent2.left === node && parent2.operatorToken.kind === 64 /* EqualsToken */);
-      }
-      node.forEachChild(recur);
-    });
-  }
-  function convertStatement(sourceFile, statement, checker, changes, identifiers, target, exports, useSitesToUnqualify, quotePreference) {
-    switch (statement.kind) {
-      case 242 /* VariableStatement */:
-        convertVariableStatement(sourceFile, statement, changes, checker, identifiers, target, quotePreference);
-        return false;
-      case 243 /* ExpressionStatement */: {
-        const { expression } = statement;
-        switch (expression.kind) {
-          case 212 /* CallExpression */: {
-            if (isRequireCall(
-              expression,
-              /*requireStringLiteralLikeArgument*/
-              true
-            )) {
-              changes.replaceNode(sourceFile, statement, makeImport(
-                /*defaultImport*/
-                void 0,
-                /*namedImports*/
-                void 0,
-                expression.arguments[0],
-                quotePreference
-              ));
-            }
-            return false;
-          }
-          case 225 /* BinaryExpression */: {
-            const { operatorToken } = expression;
-            return operatorToken.kind === 64 /* EqualsToken */ && convertAssignment(sourceFile, checker, expression, changes, exports, useSitesToUnqualify);
-          }
-        }
-      }
-      default:
-        return false;
-    }
-  }
-  function convertVariableStatement(sourceFile, statement, changes, checker, identifiers, target, quotePreference) {
-    const { declarationList } = statement;
-    let foundImport = false;
-    const converted = map(declarationList.declarations, (decl) => {
-      const { name, initializer } = decl;
-      if (initializer) {
-        if (isExportsOrModuleExportsOrAlias(sourceFile, initializer)) {
-          foundImport = true;
-          return convertedImports([]);
-        } else if (isRequireCall(
-          initializer,
-          /*requireStringLiteralLikeArgument*/
-          true
-        )) {
-          foundImport = true;
-          return convertSingleImport(name, initializer.arguments[0], checker, identifiers, target, quotePreference);
-        } else if (isPropertyAccessExpression(initializer) && isRequireCall(
-          initializer.expression,
-          /*requireStringLiteralLikeArgument*/
-          true
-        )) {
-          foundImport = true;
-          return convertPropertyAccessImport(name, initializer.name.text, initializer.expression.arguments[0], identifiers, quotePreference);
-        }
-      }
-      return convertedImports([factory.createVariableStatement(
-        /*modifiers*/
-        void 0,
-        factory.createVariableDeclarationList([decl], declarationList.flags)
-      )]);
-    });
-    if (foundImport) {
-      changes.replaceNodeWithNodes(sourceFile, statement, flatMap(converted, (c) => c.newImports));
-      let combinedUseSites;
-      forEach(converted, (c) => {
-        if (c.useSitesToUnqualify) {
-          copyEntries(c.useSitesToUnqualify, combinedUseSites ?? (combinedUseSites = /* @__PURE__ */ new Map()));
-        }
-      });
-      return combinedUseSites;
-    }
-  }
-  function convertPropertyAccessImport(name, propertyName, moduleSpecifier, identifiers, quotePreference) {
-    switch (name.kind) {
-      case 205 /* ObjectBindingPattern */:
-      case 206 /* ArrayBindingPattern */: {
-        const tmp = makeUniqueName(propertyName, identifiers);
-        return convertedImports([
-          makeSingleImport(tmp, propertyName, moduleSpecifier, quotePreference),
-          makeConst(
-            /*modifiers*/
-            void 0,
-            name,
-            factory.createIdentifier(tmp)
-          )
-        ]);
-      }
-      case 80 /* Identifier */:
-        return convertedImports([makeSingleImport(name.text, propertyName, moduleSpecifier, quotePreference)]);
-      default:
-        return Debug.assertNever(name, `Convert to ES module got invalid syntax form ${name.kind}`);
-    }
-  }
-  function convertAssignment(sourceFile, checker, assignment, changes, exports, useSitesToUnqualify) {
-    const { left, right } = assignment;
-    if (!isPropertyAccessExpression(left)) {
-      return false;
-    }
-    if (isExportsOrModuleExportsOrAlias(sourceFile, left)) {
-      if (isExportsOrModuleExportsOrAlias(sourceFile, right)) {
-        changes.delete(sourceFile, assignment.parent);
-      } else {
-        const replacement = isObjectLiteralExpression(right) ? tryChangeModuleExportsObject(right, useSitesToUnqualify) : isRequireCall(
-          right,
-          /*requireStringLiteralLikeArgument*/
-          true
-        ) ? convertReExportAll(right.arguments[0], checker) : void 0;
-        if (replacement) {
-          changes.replaceNodeWithNodes(sourceFile, assignment.parent, replacement[0]);
-          return replacement[1];
-        } else {
-          changes.replaceRangeWithText(sourceFile, createRange(left.getStart(sourceFile), right.pos), "export default");
-          return true;
-        }
-      }
-    } else if (isExportsOrModuleExportsOrAlias(sourceFile, left.expression)) {
-      convertNamedExport(sourceFile, assignment, changes, exports);
-    }
-    return false;
-  }
-  function tryChangeModuleExportsObject(object, useSitesToUnqualify) {
-    const statements = mapAllOrFail(object.properties, (prop) => {
-      switch (prop.kind) {
-        case 176 /* GetAccessor */:
-        case 177 /* SetAccessor */:
-        case 303 /* ShorthandPropertyAssignment */:
-        case 304 /* SpreadAssignment */:
-          return void 0;
-        case 302 /* PropertyAssignment */:
-          return !isIdentifier(prop.name) ? void 0 : convertExportsDotXEquals_replaceNode(prop.name.text, prop.initializer, useSitesToUnqualify);
-        case 173 /* MethodDeclaration */:
-          return !isIdentifier(prop.name) ? void 0 : functionExpressionToDeclaration(prop.name.text, [factory.createToken(95 /* ExportKeyword */)], prop, useSitesToUnqualify);
-        default:
-          Debug.assertNever(prop, `Convert to ES6 got invalid prop kind ${prop.kind}`);
-      }
-    });
-    return statements && [statements, false];
-  }
-  function convertNamedExport(sourceFile, assignment, changes, exports) {
-    const { text } = assignment.left.name;
-    const rename = exports.get(text);
-    if (rename !== void 0) {
-      const newNodes = [
-        makeConst(
-          /*modifiers*/
-          void 0,
-          rename,
-          assignment.right
-        ),
-        makeExportDeclaration([factory.createExportSpecifier(
-          /*isTypeOnly*/
-          false,
-          rename,
-          text
-        )])
-      ];
-      changes.replaceNodeWithNodes(sourceFile, assignment.parent, newNodes);
-    } else {
-      convertExportsPropertyAssignment(assignment, sourceFile, changes);
-    }
-  }
-  function convertReExportAll(reExported, checker) {
-    const moduleSpecifier = reExported.text;
-    const moduleSymbol = checker.getSymbolAtLocation(reExported);
-    const exports = moduleSymbol ? moduleSymbol.exports : emptyMap;
-    return exports.has("export=" /* ExportEquals */) ? [[reExportDefault(moduleSpecifier)], true] : !exports.has("default" /* Default */) ? [[reExportStar(moduleSpecifier)], false] : (
-      // If there's some non-default export, must include both `export *` and `export default`.
-      exports.size > 1 ? [[reExportStar(moduleSpecifier), reExportDefault(moduleSpecifier)], true] : [[reExportDefault(moduleSpecifier)], true]
-    );
-  }
-  function reExportStar(moduleSpecifier) {
-    return makeExportDeclaration(
-      /*exportSpecifiers*/
-      void 0,
-      moduleSpecifier
-    );
-  }
-  function reExportDefault(moduleSpecifier) {
-    return makeExportDeclaration([factory.createExportSpecifier(
-      /*isTypeOnly*/
-      false,
-      /*propertyName*/
-      void 0,
-      "default"
-    )], moduleSpecifier);
-  }
-  function convertExportsPropertyAssignment({ left, right, parent: parent2 }, sourceFile, changes) {
-    const name = left.name.text;
-    if ((isFunctionExpression(right) || isArrowFunction(right) || isClassExpression(right)) && (!right.name || right.name.text === name)) {
-      changes.replaceRange(sourceFile, { pos: left.getStart(sourceFile), end: right.getStart(sourceFile) }, factory.createToken(95 /* ExportKeyword */), { suffix: " " });
-      if (!right.name)
-        changes.insertName(sourceFile, right, name);
-      const semi = findChildOfKind(parent2, 27 /* SemicolonToken */, sourceFile);
-      if (semi)
-        changes.delete(sourceFile, semi);
-    } else {
-      changes.replaceNodeRangeWithNodes(
-        sourceFile,
-        left.expression,
-        findChildOfKind(left, 25 /* DotToken */, sourceFile),
-        [factory.createToken(95 /* ExportKeyword */), factory.createToken(87 /* ConstKeyword */)],
-        { joiner: " ", suffix: " " }
-      );
-    }
-  }
-  function convertExportsDotXEquals_replaceNode(name, exported, useSitesToUnqualify) {
-    const modifiers = [factory.createToken(95 /* ExportKeyword */)];
-    switch (exported.kind) {
-      case 217 /* FunctionExpression */: {
-        const { name: expressionName } = exported;
-        if (expressionName && expressionName.text !== name) {
-          return exportConst();
-        }
-      }
-      case 218 /* ArrowFunction */:
-        return functionExpressionToDeclaration(name, modifiers, exported, useSitesToUnqualify);
-      case 230 /* ClassExpression */:
-        return classExpressionToDeclaration(name, modifiers, exported, useSitesToUnqualify);
-      default:
-        return exportConst();
-    }
-    function exportConst() {
-      return makeConst(modifiers, factory.createIdentifier(name), replaceImportUseSites(exported, useSitesToUnqualify));
-    }
-  }
-  function replaceImportUseSites(nodeOrNodes, useSitesToUnqualify) {
-    if (!useSitesToUnqualify || !some(arrayFrom(useSitesToUnqualify.keys()), (original) => rangeContainsRange(nodeOrNodes, original))) {
-      return nodeOrNodes;
-    }
-    return isArray(nodeOrNodes) ? getSynthesizedDeepClonesWithReplacements(
-      nodeOrNodes,
-      /*includeTrivia*/
-      true,
-      replaceNode
-    ) : getSynthesizedDeepCloneWithReplacements(
-      nodeOrNodes,
-      /*includeTrivia*/
-      true,
-      replaceNode
-    );
-    function replaceNode(original) {
-      if (original.kind === 210 /* PropertyAccessExpression */) {
-        const replacement = useSitesToUnqualify.get(original);
-        useSitesToUnqualify.delete(original);
-        return replacement;
-      }
-    }
-  }
-  function convertSingleImport(name, moduleSpecifier, checker, identifiers, target, quotePreference) {
-    switch (name.kind) {
-      case 205 /* ObjectBindingPattern */: {
-        const importSpecifiers = mapAllOrFail(name.elements, (e) => e.dotDotDotToken || e.initializer || e.propertyName && !isIdentifier(e.propertyName) || !isIdentifier(e.name) ? void 0 : makeImportSpecifier2(e.propertyName && e.propertyName.text, e.name.text));
-        if (importSpecifiers) {
-          return convertedImports([makeImport(
-            /*defaultImport*/
-            void 0,
-            importSpecifiers,
-            moduleSpecifier,
-            quotePreference
-          )]);
-        }
-      }
-      case 206 /* ArrayBindingPattern */: {
-        const tmp = makeUniqueName(moduleSpecifierToValidIdentifier(moduleSpecifier.text, target), identifiers);
-        return convertedImports([
-          makeImport(
-            factory.createIdentifier(tmp),
-            /*namedImports*/
-            void 0,
-            moduleSpecifier,
-            quotePreference
-          ),
-          makeConst(
-            /*modifiers*/
-            void 0,
-            getSynthesizedDeepClone(name),
-            factory.createIdentifier(tmp)
-          )
-        ]);
-      }
-      case 80 /* Identifier */:
-        return convertSingleIdentifierImport(name, moduleSpecifier, checker, identifiers, quotePreference);
-      default:
-        return Debug.assertNever(name, `Convert to ES module got invalid name kind ${name.kind}`);
-    }
-  }
-  function convertSingleIdentifierImport(name, moduleSpecifier, checker, identifiers, quotePreference) {
-    const nameSymbol = checker.getSymbolAtLocation(name);
-    const namedBindingsNames = /* @__PURE__ */ new Map();
-    let needDefaultImport = false;
-    let useSitesToUnqualify;
-    for (const use of identifiers.original.get(name.text)) {
-      if (checker.getSymbolAtLocation(use) !== nameSymbol || use === name) {
-        continue;
-      }
-      const { parent: parent2 } = use;
-      if (isPropertyAccessExpression(parent2)) {
-        const { name: { text: propertyName } } = parent2;
-        if (propertyName === "default") {
-          needDefaultImport = true;
-          const importDefaultName = use.getText();
-          (useSitesToUnqualify ?? (useSitesToUnqualify = /* @__PURE__ */ new Map())).set(parent2, factory.createIdentifier(importDefaultName));
-        } else {
-          Debug.assert(parent2.expression === use, "Didn't expect expression === use");
-          let idName = namedBindingsNames.get(propertyName);
-          if (idName === void 0) {
-            idName = makeUniqueName(propertyName, identifiers);
-            namedBindingsNames.set(propertyName, idName);
-          }
-          (useSitesToUnqualify ?? (useSitesToUnqualify = /* @__PURE__ */ new Map())).set(parent2, factory.createIdentifier(idName));
-        }
-      } else {
-        needDefaultImport = true;
-      }
-    }
-    const namedBindings = namedBindingsNames.size === 0 ? void 0 : arrayFrom(mapIterator(namedBindingsNames.entries(), ([propertyName, idName]) => factory.createImportSpecifier(
-      /*isTypeOnly*/
-      false,
-      propertyName === idName ? void 0 : factory.createIdentifier(propertyName),
-      factory.createIdentifier(idName)
-    )));
-    if (!namedBindings) {
-      needDefaultImport = true;
-    }
-    return convertedImports(
-      [makeImport(needDefaultImport ? getSynthesizedDeepClone(name) : void 0, namedBindings, moduleSpecifier, quotePreference)],
-      useSitesToUnqualify
-    );
-  }
-  function makeUniqueName(name, identifiers) {
-    while (identifiers.original.has(name) || identifiers.additional.has(name)) {
-      name = `_${name}`;
-    }
-    identifiers.additional.add(name);
-    return name;
-  }
-  function collectFreeIdentifiers(file) {
-    const map2 = createMultiMap();
-    forEachFreeIdentifier(file, (id) => map2.add(id.text, id));
-    return map2;
-  }
-  function forEachFreeIdentifier(node, cb) {
-    if (isIdentifier(node) && isFreeIdentifier(node))
-      cb(node);
-    node.forEachChild((child) => forEachFreeIdentifier(child, cb));
-  }
-  function isFreeIdentifier(node) {
-    const { parent: parent2 } = node;
-    switch (parent2.kind) {
-      case 210 /* PropertyAccessExpression */:
-        return parent2.name !== node;
-      case 207 /* BindingElement */:
-        return parent2.propertyName !== node;
-      case 275 /* ImportSpecifier */:
-        return parent2.propertyName !== node;
-      default:
-        return true;
-    }
-  }
-  function functionExpressionToDeclaration(name, additionalModifiers, fn, useSitesToUnqualify) {
-    return factory.createFunctionDeclaration(
-      concatenate(additionalModifiers, getSynthesizedDeepClones(fn.modifiers)),
-      getSynthesizedDeepClone(fn.asteriskToken),
-      name,
-      getSynthesizedDeepClones(fn.typeParameters),
-      getSynthesizedDeepClones(fn.parameters),
-      getSynthesizedDeepClone(fn.type),
-      factory.converters.convertToFunctionBlock(replaceImportUseSites(fn.body, useSitesToUnqualify))
-    );
-  }
-  function classExpressionToDeclaration(name, additionalModifiers, cls, useSitesToUnqualify) {
-    return factory.createClassDeclaration(
-      concatenate(additionalModifiers, getSynthesizedDeepClones(cls.modifiers)),
-      name,
-      getSynthesizedDeepClones(cls.typeParameters),
-      getSynthesizedDeepClones(cls.heritageClauses),
-      replaceImportUseSites(cls.members, useSitesToUnqualify)
-    );
-  }
-  function makeSingleImport(localName, propertyName, moduleSpecifier, quotePreference) {
-    return propertyName === "default" ? makeImport(
-      factory.createIdentifier(localName),
-      /*namedImports*/
-      void 0,
-      moduleSpecifier,
-      quotePreference
-    ) : makeImport(
-      /*defaultImport*/
-      void 0,
-      [makeImportSpecifier2(propertyName, localName)],
-      moduleSpecifier,
-      quotePreference
-    );
-  }
-  function makeImportSpecifier2(propertyName, name) {
-    return factory.createImportSpecifier(
-      /*isTypeOnly*/
-      false,
-      propertyName !== void 0 && propertyName !== name ? factory.createIdentifier(propertyName) : void 0,
-      factory.createIdentifier(name)
-    );
-  }
-  function makeConst(modifiers, name, init) {
-    return factory.createVariableStatement(
-      modifiers,
-      factory.createVariableDeclarationList(
-        [factory.createVariableDeclaration(
-          name,
-          /*exclamationToken*/
-          void 0,
-          /*type*/
-          void 0,
-          init
-        )],
-        2 /* Const */
-      )
-    );
-  }
-  function makeExportDeclaration(exportSpecifiers, moduleSpecifier) {
-    return factory.createExportDeclaration(
-      /*modifiers*/
-      void 0,
-      /*isTypeOnly*/
-      false,
-      exportSpecifiers && factory.createNamedExports(exportSpecifiers),
-      moduleSpecifier === void 0 ? void 0 : factory.createStringLiteral(moduleSpecifier)
-    );
-  }
-  function convertedImports(newImports, useSitesToUnqualify) {
-    return {
-      newImports,
-      useSitesToUnqualify
-    };
-  }
-  var init_convertToEsModule = __esm({
-    "src/services/codefixes/convertToEsModule.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_codefix();
-      registerCodeFix({
-        errorCodes: [Diagnostics.File_is_a_CommonJS_module_it_may_be_converted_to_an_ES_module.code],
-        getCodeActions(context) {
-          const { sourceFile, program, preferences } = context;
-          const changes = ts_textChanges_exports.ChangeTracker.with(context, (changes2) => {
-            const moduleExportsChangedToDefault = convertFileToEsModule(sourceFile, program.getTypeChecker(), changes2, getEmitScriptTarget(program.getCompilerOptions()), getQuotePreference(sourceFile, preferences));
-            if (moduleExportsChangedToDefault) {
-              for (const importingFile of program.getSourceFiles()) {
-                fixImportOfModuleExports(importingFile, sourceFile, changes2, getQuotePreference(importingFile, preferences));
-              }
-            }
-          });
-          return [createCodeFixActionWithoutFixAll("convertToEsModule", changes, Diagnostics.Convert_to_ES_module)];
-        }
-      });
-    }
-  });
-
-  // src/services/codefixes/correctQualifiedNameToIndexedAccessType.ts
-  function getQualifiedName(sourceFile, pos) {
-    const qualifiedName = findAncestor(getTokenAtPosition(sourceFile, pos), isQualifiedName);
-    Debug.assert(!!qualifiedName, "Expected position to be owned by a qualified name.");
-    return isIdentifier(qualifiedName.left) ? qualifiedName : void 0;
-  }
-  function doChange10(changeTracker, sourceFile, qualifiedName) {
-    const rightText = qualifiedName.right.text;
-    const replacement = factory.createIndexedAccessTypeNode(
-      factory.createTypeReferenceNode(
-        qualifiedName.left,
-        /*typeArguments*/
-        void 0
-      ),
-      factory.createLiteralTypeNode(factory.createStringLiteral(rightText))
-    );
-    changeTracker.replaceNode(sourceFile, qualifiedName, replacement);
-  }
-  var fixId11, errorCodes12;
-  var init_correctQualifiedNameToIndexedAccessType = __esm({
-    "src/services/codefixes/correctQualifiedNameToIndexedAccessType.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_codefix();
-      fixId11 = "correctQualifiedNameToIndexedAccessType";
-      errorCodes12 = [Diagnostics.Cannot_access_0_1_because_0_is_a_type_but_not_a_namespace_Did_you_mean_to_retrieve_the_type_of_the_property_1_in_0_with_0_1.code];
-      registerCodeFix({
-        errorCodes: errorCodes12,
-        getCodeActions(context) {
-          const qualifiedName = getQualifiedName(context.sourceFile, context.span.start);
-          if (!qualifiedName)
-            return void 0;
-          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange10(t, context.sourceFile, qualifiedName));
-          const newText = `${qualifiedName.left.text}["${qualifiedName.right.text}"]`;
-          return [createCodeFixAction(fixId11, changes, [Diagnostics.Rewrite_as_the_indexed_access_type_0, newText], fixId11, Diagnostics.Rewrite_all_as_indexed_access_types)];
-        },
-        fixIds: [fixId11],
-        getAllCodeActions: (context) => codeFixAll(context, errorCodes12, (changes, diag2) => {
-          const q = getQualifiedName(diag2.file, diag2.start);
-          if (q) {
-            doChange10(changes, diag2.file, q);
-          }
-        })
-      });
-    }
-  });
-
-  // src/services/codefixes/convertToTypeOnlyExport.ts
-  function getExportSpecifierForDiagnosticSpan(span, sourceFile) {
-    return tryCast(getTokenAtPosition(sourceFile, span.start).parent, isExportSpecifier);
-  }
-  function fixSingleExportDeclaration(changes, exportSpecifier, context) {
-    if (!exportSpecifier) {
-      return;
-    }
-    const exportClause = exportSpecifier.parent;
-    const exportDeclaration = exportClause.parent;
-    const typeExportSpecifiers = getTypeExportSpecifiers(exportSpecifier, context);
-    if (typeExportSpecifiers.length === exportClause.elements.length) {
-      changes.insertModifierBefore(context.sourceFile, 156 /* TypeKeyword */, exportClause);
-    } else {
-      const valueExportDeclaration = factory.updateExportDeclaration(
-        exportDeclaration,
-        exportDeclaration.modifiers,
-        /*isTypeOnly*/
-        false,
-        factory.updateNamedExports(exportClause, filter(exportClause.elements, (e) => !contains(typeExportSpecifiers, e))),
-        exportDeclaration.moduleSpecifier,
-        /*assertClause*/
-        void 0
-      );
-      const typeExportDeclaration = factory.createExportDeclaration(
-        /*modifiers*/
-        void 0,
-        /*isTypeOnly*/
-        true,
-        factory.createNamedExports(typeExportSpecifiers),
-        exportDeclaration.moduleSpecifier,
-        /*assertClause*/
-        void 0
-      );
-      changes.replaceNode(context.sourceFile, exportDeclaration, valueExportDeclaration, {
-        leadingTriviaOption: ts_textChanges_exports.LeadingTriviaOption.IncludeAll,
-        trailingTriviaOption: ts_textChanges_exports.TrailingTriviaOption.Exclude
-      });
-      changes.insertNodeAfter(context.sourceFile, exportDeclaration, typeExportDeclaration);
-    }
-  }
-  function getTypeExportSpecifiers(originExportSpecifier, context) {
-    const exportClause = originExportSpecifier.parent;
-    if (exportClause.elements.length === 1) {
-      return exportClause.elements;
-    }
-    const diagnostics = getDiagnosticsWithinSpan(
-      createTextSpanFromNode(exportClause),
-      context.program.getSemanticDiagnostics(context.sourceFile, context.cancellationToken)
-    );
-    return filter(exportClause.elements, (element) => {
-      var _a;
-      return element === originExportSpecifier || ((_a = findDiagnosticForNode(element, diagnostics)) == null ? void 0 : _a.code) === errorCodes13[0];
-    });
-  }
-  var errorCodes13, fixId12;
-  var init_convertToTypeOnlyExport = __esm({
-    "src/services/codefixes/convertToTypeOnlyExport.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_codefix();
-      errorCodes13 = [Diagnostics.Re_exporting_a_type_when_0_is_enabled_requires_using_export_type.code];
-      fixId12 = "convertToTypeOnlyExport";
-      registerCodeFix({
-        errorCodes: errorCodes13,
-        getCodeActions: function getCodeActionsToConvertToTypeOnlyExport(context) {
-          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => fixSingleExportDeclaration(t, getExportSpecifierForDiagnosticSpan(context.span, context.sourceFile), context));
-          if (changes.length) {
-            return [createCodeFixAction(fixId12, changes, Diagnostics.Convert_to_type_only_export, fixId12, Diagnostics.Convert_all_re_exported_types_to_type_only_exports)];
-          }
-        },
-        fixIds: [fixId12],
-        getAllCodeActions: function getAllCodeActionsToConvertToTypeOnlyExport(context) {
-          const fixedExportDeclarations = /* @__PURE__ */ new Map();
-          return codeFixAll(context, errorCodes13, (changes, diag2) => {
-            const exportSpecifier = getExportSpecifierForDiagnosticSpan(diag2, context.sourceFile);
-            if (exportSpecifier && addToSeen(fixedExportDeclarations, getNodeId(exportSpecifier.parent.parent))) {
-              fixSingleExportDeclaration(changes, exportSpecifier, context);
-            }
-          });
-        }
-      });
-    }
-  });
-
-  // src/services/codefixes/convertToTypeOnlyImport.ts
-  function getDeclaration2(sourceFile, pos) {
-    const { parent: parent2 } = getTokenAtPosition(sourceFile, pos);
-    return isImportSpecifier(parent2) || isImportDeclaration(parent2) && parent2.importClause ? parent2 : void 0;
-  }
-  function doChange11(changes, sourceFile, declaration) {
-    if (isImportSpecifier(declaration)) {
-      changes.replaceNode(sourceFile, declaration, factory.updateImportSpecifier(
-        declaration,
-        /*isTypeOnly*/
-        true,
-        declaration.propertyName,
-        declaration.name
-      ));
-    } else {
-      const importClause = declaration.importClause;
-      if (importClause.name && importClause.namedBindings) {
-        changes.replaceNodeWithNodes(sourceFile, declaration, [
-          factory.createImportDeclaration(
-            getSynthesizedDeepClones(
-              declaration.modifiers,
-              /*includeTrivia*/
-              true
-            ),
-            factory.createImportClause(
-              /*isTypeOnly*/
-              true,
-              getSynthesizedDeepClone(
-                importClause.name,
-                /*includeTrivia*/
-                true
-              ),
-              /*namedBindings*/
-              void 0
-            ),
-            getSynthesizedDeepClone(
-              declaration.moduleSpecifier,
-              /*includeTrivia*/
-              true
-            ),
-            getSynthesizedDeepClone(
-              declaration.assertClause,
-              /*includeTrivia*/
-              true
-            )
-          ),
-          factory.createImportDeclaration(
-            getSynthesizedDeepClones(
-              declaration.modifiers,
-              /*includeTrivia*/
-              true
-            ),
-            factory.createImportClause(
-              /*isTypeOnly*/
-              true,
-              /*name*/
-              void 0,
-              getSynthesizedDeepClone(
-                importClause.namedBindings,
-                /*includeTrivia*/
-                true
-              )
-            ),
-            getSynthesizedDeepClone(
-              declaration.moduleSpecifier,
-              /*includeTrivia*/
-              true
-            ),
-            getSynthesizedDeepClone(
-              declaration.assertClause,
-              /*includeTrivia*/
-              true
-            )
-          )
-        ]);
-      } else {
-        const importDeclaration = factory.updateImportDeclaration(
-          declaration,
-          declaration.modifiers,
-          factory.updateImportClause(
-            importClause,
-            /*isTypeOnly*/
-            true,
-            importClause.name,
-            importClause.namedBindings
-          ),
-          declaration.moduleSpecifier,
-          declaration.assertClause
-        );
-        changes.replaceNode(sourceFile, declaration, importDeclaration);
-      }
-    }
-  }
-  var errorCodes14, fixId13;
-  var init_convertToTypeOnlyImport = __esm({
-    "src/services/codefixes/convertToTypeOnlyImport.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_codefix();
-      errorCodes14 = [
-        Diagnostics.This_import_is_never_used_as_a_value_and_must_use_import_type_because_importsNotUsedAsValues_is_set_to_error.code,
-        Diagnostics._0_is_a_type_and_must_be_imported_using_a_type_only_import_when_verbatimModuleSyntax_is_enabled.code
-      ];
-      fixId13 = "convertToTypeOnlyImport";
-      registerCodeFix({
-        errorCodes: errorCodes14,
-        getCodeActions: function getCodeActionsToConvertToTypeOnlyImport(context) {
-          const declaration = getDeclaration2(context.sourceFile, context.span.start);
-          if (declaration) {
-            const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange11(t, context.sourceFile, declaration));
-            return [createCodeFixAction(fixId13, changes, Diagnostics.Convert_to_type_only_import, fixId13, Diagnostics.Convert_all_imports_not_used_as_a_value_to_type_only_imports)];
-          }
-          return void 0;
-        },
-        fixIds: [fixId13],
-        getAllCodeActions: function getAllCodeActionsToConvertToTypeOnlyImport(context) {
-          return codeFixAll(context, errorCodes14, (changes, diag2) => {
-            const declaration = getDeclaration2(diag2.file, diag2.start);
-            if (declaration) {
-              doChange11(changes, diag2.file, declaration);
-            }
-          });
-        }
-      });
-    }
-  });
-
-  // src/services/codefixes/convertTypedefToType.ts
-  function doChange12(changes, node, sourceFile) {
-    if (isJSDocTypedefTag(node)) {
-      fixSingleTypeDef(changes, node, sourceFile);
-    }
-  }
-  function fixSingleTypeDef(changes, typeDefNode, sourceFile) {
-    if (!typeDefNode)
-      return;
-    const declaration = createDeclaration(typeDefNode);
-    if (!declaration)
-      return;
-    const comment = typeDefNode.parent;
-    changes.replaceNode(
-      sourceFile,
-      comment,
-      declaration
-    );
-  }
-  function createDeclaration(tag) {
-    var _a;
-    const { typeExpression } = tag;
-    if (!typeExpression)
-      return;
-    const typeName = (_a = tag.name) == null ? void 0 : _a.getText();
-    if (!typeName)
-      return;
-    if (typeExpression.kind === 328 /* JSDocTypeLiteral */) {
-      return createInterfaceForTypeLiteral(typeName, typeExpression);
-    }
-    if (typeExpression.kind === 315 /* JSDocTypeExpression */) {
-      return createTypeAliasForTypeExpression(typeName, typeExpression);
-    }
-  }
-  function createInterfaceForTypeLiteral(typeName, typeLiteral) {
-    const propertySignatures = createSignatureFromTypeLiteral(typeLiteral);
-    if (!some(propertySignatures))
-      return;
-    const interfaceDeclaration = factory.createInterfaceDeclaration(
-      /*modifiers*/
-      void 0,
-      typeName,
-      /*typeParameters*/
-      void 0,
-      /*heritageClauses*/
-      void 0,
-      propertySignatures
-    );
-    return interfaceDeclaration;
-  }
-  function createTypeAliasForTypeExpression(typeName, typeExpression) {
-    const typeReference = getSynthesizedDeepClone(typeExpression.type);
-    if (!typeReference)
-      return;
-    const declaration = factory.createTypeAliasDeclaration(
-      /*modifiers*/
-      void 0,
-      factory.createIdentifier(typeName),
-      /*typeParameters*/
-      void 0,
-      typeReference
-    );
-    return declaration;
-  }
-  function createSignatureFromTypeLiteral(typeLiteral) {
-    const propertyTags = typeLiteral.jsDocPropertyTags;
-    if (!some(propertyTags))
-      return;
-    const getSignature = (tag) => {
-      var _a;
-      const name = getPropertyName(tag);
-      const type = (_a = tag.typeExpression) == null ? void 0 : _a.type;
-      const isOptional = tag.isBracketed;
-      let typeReference;
-      if (type && isJSDocTypeLiteral(type)) {
-        const signatures = createSignatureFromTypeLiteral(type);
-        typeReference = factory.createTypeLiteralNode(signatures);
-      } else if (type) {
-        typeReference = getSynthesizedDeepClone(type);
-      }
-      if (typeReference && name) {
-        const questionToken = isOptional ? factory.createToken(58 /* QuestionToken */) : void 0;
-        const prop = factory.createPropertySignature(
-          /*modifiers*/
-          void 0,
-          name,
-          questionToken,
-          typeReference
-        );
-        return prop;
-      }
-    };
-    const props = mapDefined(propertyTags, getSignature);
-    return props;
-  }
-  function getPropertyName(tag) {
-    return tag.name.kind === 80 /* Identifier */ ? tag.name.text : tag.name.right.text;
-  }
-  function getJSDocTypedefNode(node) {
-    if (hasJSDocNodes(node)) {
-      return forEach(node.jsDoc, (node2) => {
-        var _a;
-        return (_a = node2.tags) == null ? void 0 : _a.find(isJSDocTypedefTag);
-      });
-    }
-    return void 0;
-  }
-  var fixId14, errorCodes15;
-  var init_convertTypedefToType = __esm({
-    "src/services/codefixes/convertTypedefToType.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_codefix();
-      fixId14 = "convertTypedefToType";
-      errorCodes15 = [Diagnostics.JSDoc_typedef_may_be_converted_to_TypeScript_type.code];
-      registerCodeFix({
-        fixIds: [fixId14],
-        errorCodes: errorCodes15,
-        getCodeActions(context) {
-          const node = getTokenAtPosition(
-            context.sourceFile,
-            context.span.start
-          );
-          if (!node)
-            return;
-          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange12(t, node, context.sourceFile));
-          if (changes.length > 0) {
-            return [
-              createCodeFixAction(
-                fixId14,
-                changes,
-                Diagnostics.Convert_typedef_to_TypeScript_type,
-                fixId14,
-                Diagnostics.Convert_all_typedef_to_TypeScript_types
-              )
-            ];
-          }
-        },
-        getAllCodeActions: (context) => codeFixAll(context, errorCodes15, (changes, diag2) => {
-          const node = getTokenAtPosition(diag2.file, diag2.start);
-          if (node)
-            doChange12(changes, node, diag2.file);
-        })
-      });
-    }
-  });
-
-  // src/services/codefixes/convertLiteralTypeToMappedType.ts
-  function getInfo5(sourceFile, pos) {
-    const token = getTokenAtPosition(sourceFile, pos);
-    if (isIdentifier(token)) {
-      const propertySignature = cast(token.parent.parent, isPropertySignature);
-      const propertyName = token.getText(sourceFile);
-      return {
-        container: cast(propertySignature.parent, isTypeLiteralNode),
-        typeNode: propertySignature.type,
-        constraint: propertyName,
-        name: propertyName === "K" ? "P" : "K"
-      };
-    }
-    return void 0;
-  }
-  function doChange13(changes, sourceFile, { container, typeNode, constraint, name }) {
-    changes.replaceNode(sourceFile, container, factory.createMappedTypeNode(
-      /*readonlyToken*/
-      void 0,
-      factory.createTypeParameterDeclaration(
-        /*modifiers*/
-        void 0,
-        name,
-        factory.createTypeReferenceNode(constraint)
-      ),
-      /*nameType*/
-      void 0,
-      /*questionToken*/
-      void 0,
-      typeNode,
-      /*members*/
-      void 0
-    ));
-  }
-  var fixId15, errorCodes16;
-  var init_convertLiteralTypeToMappedType = __esm({
-    "src/services/codefixes/convertLiteralTypeToMappedType.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_codefix();
-      fixId15 = "convertLiteralTypeToMappedType";
-      errorCodes16 = [Diagnostics._0_only_refers_to_a_type_but_is_being_used_as_a_value_here_Did_you_mean_to_use_1_in_0.code];
-      registerCodeFix({
-        errorCodes: errorCodes16,
-        getCodeActions: function getCodeActionsToConvertLiteralTypeToMappedType(context) {
-          const { sourceFile, span } = context;
-          const info = getInfo5(sourceFile, span.start);
-          if (!info) {
-            return void 0;
-          }
-          const { name, constraint } = info;
-          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange13(t, sourceFile, info));
-          return [createCodeFixAction(fixId15, changes, [Diagnostics.Convert_0_to_1_in_0, constraint, name], fixId15, Diagnostics.Convert_all_type_literals_to_mapped_type)];
-        },
-        fixIds: [fixId15],
-        getAllCodeActions: (context) => codeFixAll(context, errorCodes16, (changes, diag2) => {
-          const info = getInfo5(diag2.file, diag2.start);
-          if (info) {
-            doChange13(changes, diag2.file, info);
-          }
-        })
-      });
-    }
-  });
-
-  // src/services/codefixes/fixClassIncorrectlyImplementsInterface.ts
-  function getClass(sourceFile, pos) {
-    return Debug.checkDefined(getContainingClass(getTokenAtPosition(sourceFile, pos)), "There should be a containing class");
-  }
-  function symbolPointsToNonPrivateMember(symbol) {
-    return !symbol.valueDeclaration || !(getEffectiveModifierFlags(symbol.valueDeclaration) & 8 /* Private */);
-  }
-  function addMissingDeclarations(context, implementedTypeNode, sourceFile, classDeclaration, changeTracker, preferences) {
-    const checker = context.program.getTypeChecker();
-    const maybeHeritageClauseSymbol = getHeritageClauseSymbolTable(classDeclaration, checker);
-    const implementedType = checker.getTypeAtLocation(implementedTypeNode);
-    const implementedTypeSymbols = checker.getPropertiesOfType(implementedType);
-    const nonPrivateAndNotExistedInHeritageClauseMembers = implementedTypeSymbols.filter(and(symbolPointsToNonPrivateMember, (symbol) => !maybeHeritageClauseSymbol.has(symbol.escapedName)));
-    const classType = checker.getTypeAtLocation(classDeclaration);
-    const constructor = find(classDeclaration.members, (m) => isConstructorDeclaration(m));
-    if (!classType.getNumberIndexType()) {
-      createMissingIndexSignatureDeclaration(implementedType, 1 /* Number */);
-    }
-    if (!classType.getStringIndexType()) {
-      createMissingIndexSignatureDeclaration(implementedType, 0 /* String */);
-    }
-    const importAdder = createImportAdder(sourceFile, context.program, preferences, context.host);
-    createMissingMemberNodes(classDeclaration, nonPrivateAndNotExistedInHeritageClauseMembers, sourceFile, context, preferences, importAdder, (member) => insertInterfaceMemberNode(sourceFile, classDeclaration, member));
-    importAdder.writeFixes(changeTracker);
-    function createMissingIndexSignatureDeclaration(type, kind) {
-      const indexInfoOfKind = checker.getIndexInfoOfType(type, kind);
-      if (indexInfoOfKind) {
-        insertInterfaceMemberNode(sourceFile, classDeclaration, checker.indexInfoToIndexSignatureDeclaration(
-          indexInfoOfKind,
-          classDeclaration,
-          /*flags*/
-          void 0,
-          getNoopSymbolTrackerWithResolver(context)
-        ));
-      }
-    }
-    function insertInterfaceMemberNode(sourceFile2, cls, newElement) {
-      if (constructor) {
-        changeTracker.insertNodeAfter(sourceFile2, constructor, newElement);
-      } else {
-        changeTracker.insertMemberAtStart(sourceFile2, cls, newElement);
-      }
-    }
-  }
-  function getHeritageClauseSymbolTable(classDeclaration, checker) {
-    const heritageClauseNode = getEffectiveBaseTypeNode(classDeclaration);
-    if (!heritageClauseNode)
-      return createSymbolTable();
-    const heritageClauseType = checker.getTypeAtLocation(heritageClauseNode);
-    const heritageClauseTypeSymbols = checker.getPropertiesOfType(heritageClauseType);
-    return createSymbolTable(heritageClauseTypeSymbols.filter(symbolPointsToNonPrivateMember));
-  }
-  var errorCodes17, fixId16;
-  var init_fixClassIncorrectlyImplementsInterface = __esm({
-    "src/services/codefixes/fixClassIncorrectlyImplementsInterface.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_codefix();
-      errorCodes17 = [
-        Diagnostics.Class_0_incorrectly_implements_interface_1.code,
-        Diagnostics.Class_0_incorrectly_implements_class_1_Did_you_mean_to_extend_1_and_inherit_its_members_as_a_subclass.code
-      ];
-      fixId16 = "fixClassIncorrectlyImplementsInterface";
-      registerCodeFix({
-        errorCodes: errorCodes17,
-        getCodeActions(context) {
-          const { sourceFile, span } = context;
-          const classDeclaration = getClass(sourceFile, span.start);
-          return mapDefined(getEffectiveImplementsTypeNodes(classDeclaration), (implementedTypeNode) => {
-            const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => addMissingDeclarations(context, implementedTypeNode, sourceFile, classDeclaration, t, context.preferences));
-            return changes.length === 0 ? void 0 : createCodeFixAction(fixId16, changes, [Diagnostics.Implement_interface_0, implementedTypeNode.getText(sourceFile)], fixId16, Diagnostics.Implement_all_unimplemented_interfaces);
-          });
-        },
-        fixIds: [fixId16],
-        getAllCodeActions(context) {
-          const seenClassDeclarations = /* @__PURE__ */ new Map();
-          return codeFixAll(context, errorCodes17, (changes, diag2) => {
-            const classDeclaration = getClass(diag2.file, diag2.start);
-            if (addToSeen(seenClassDeclarations, getNodeId(classDeclaration))) {
-              for (const implementedTypeNode of getEffectiveImplementsTypeNodes(classDeclaration)) {
-                addMissingDeclarations(context, implementedTypeNode, diag2.file, classDeclaration, changes, context.preferences);
-              }
-            }
-          });
-        }
-      });
-    }
-  });
-
-  // src/services/codefixes/importFixes.ts
-  function createImportAdder(sourceFile, program, preferences, host, cancellationToken) {
-    return createImportAdderWorker(
-      sourceFile,
-      program,
-      /*useAutoImportProvider*/
-      false,
-      preferences,
-      host,
-      cancellationToken
-    );
-  }
-  function createImportAdderWorker(sourceFile, program, useAutoImportProvider, preferences, host, cancellationToken) {
-    const compilerOptions = program.getCompilerOptions();
-    const addToNamespace = [];
-    const importType = [];
-    const addToExisting = /* @__PURE__ */ new Map();
-    const newImports = /* @__PURE__ */ new Map();
-    return { addImportFromDiagnostic, addImportFromExportedSymbol, writeFixes, hasFixes };
-    function addImportFromDiagnostic(diagnostic, context) {
-      const info = getFixInfos(context, diagnostic.code, diagnostic.start, useAutoImportProvider);
-      if (!info || !info.length)
-        return;
-      addImport(first(info));
-    }
-    function addImportFromExportedSymbol(exportedSymbol, isValidTypeOnlyUseSite) {
-      const moduleSymbol = Debug.checkDefined(exportedSymbol.parent);
-      const symbolName2 = getNameForExportedSymbol(exportedSymbol, getEmitScriptTarget(compilerOptions));
-      const checker = program.getTypeChecker();
-      const symbol = checker.getMergedSymbol(skipAlias(exportedSymbol, checker));
-      const exportInfo = getAllExportInfoForSymbol(
-        sourceFile,
-        symbol,
-        symbolName2,
-        moduleSymbol,
-        /*preferCapitalized*/
-        false,
-        program,
-        host,
-        preferences,
-        cancellationToken
-      );
-      const useRequire = shouldUseRequire(sourceFile, program);
-      const fix = getImportFixForSymbol(
-        sourceFile,
-        Debug.checkDefined(exportInfo),
-        program,
-        /*position*/
-        void 0,
-        !!isValidTypeOnlyUseSite,
-        useRequire,
-        host,
-        preferences
-      );
-      if (fix) {
-        addImport({ fix, symbolName: symbolName2, errorIdentifierText: void 0 });
-      }
-    }
-    function addImport(info) {
-      var _a, _b;
-      const { fix, symbolName: symbolName2 } = info;
-      switch (fix.kind) {
-        case 0 /* UseNamespace */:
-          addToNamespace.push(fix);
-          break;
-        case 1 /* JsdocTypeImport */:
-          importType.push(fix);
-          break;
-        case 2 /* AddToExisting */: {
-          const { importClauseOrBindingPattern, importKind, addAsTypeOnly } = fix;
-          const key = String(getNodeId(importClauseOrBindingPattern));
-          let entry = addToExisting.get(key);
-          if (!entry) {
-            addToExisting.set(key, entry = { importClauseOrBindingPattern, defaultImport: void 0, namedImports: /* @__PURE__ */ new Map() });
-          }
-          if (importKind === 0 /* Named */) {
-            const prevValue = entry == null ? void 0 : entry.namedImports.get(symbolName2);
-            entry.namedImports.set(symbolName2, reduceAddAsTypeOnlyValues(prevValue, addAsTypeOnly));
-          } else {
-            Debug.assert(entry.defaultImport === void 0 || entry.defaultImport.name === symbolName2, "(Add to Existing) Default import should be missing or match symbolName");
-            entry.defaultImport = {
-              name: symbolName2,
-              addAsTypeOnly: reduceAddAsTypeOnlyValues((_a = entry.defaultImport) == null ? void 0 : _a.addAsTypeOnly, addAsTypeOnly)
-            };
-          }
-          break;
-        }
-        case 3 /* AddNew */: {
-          const { moduleSpecifier, importKind, useRequire, addAsTypeOnly } = fix;
-          const entry = getNewImportEntry(moduleSpecifier, importKind, useRequire, addAsTypeOnly);
-          Debug.assert(entry.useRequire === useRequire, "(Add new) Tried to add an `import` and a `require` for the same module");
-          switch (importKind) {
-            case 1 /* Default */:
-              Debug.assert(entry.defaultImport === void 0 || entry.defaultImport.name === symbolName2, "(Add new) Default import should be missing or match symbolName");
-              entry.defaultImport = { name: symbolName2, addAsTypeOnly: reduceAddAsTypeOnlyValues((_b = entry.defaultImport) == null ? void 0 : _b.addAsTypeOnly, addAsTypeOnly) };
-              break;
-            case 0 /* Named */:
-              const prevValue = (entry.namedImports || (entry.namedImports = /* @__PURE__ */ new Map())).get(symbolName2);
-              entry.namedImports.set(symbolName2, reduceAddAsTypeOnlyValues(prevValue, addAsTypeOnly));
-              break;
-            case 3 /* CommonJS */:
-            case 2 /* Namespace */:
-              Debug.assert(entry.namespaceLikeImport === void 0 || entry.namespaceLikeImport.name === symbolName2, "Namespacelike import shoudl be missing or match symbolName");
-              entry.namespaceLikeImport = { importKind, name: symbolName2, addAsTypeOnly };
-              break;
-          }
-          break;
-        }
-        case 4 /* PromoteTypeOnly */:
-          break;
-        default:
-          Debug.assertNever(fix, `fix wasn't never - got kind ${fix.kind}`);
-      }
-      function reduceAddAsTypeOnlyValues(prevValue, newValue) {
-        return Math.max(prevValue ?? 0, newValue);
-      }
-      function getNewImportEntry(moduleSpecifier, importKind, useRequire, addAsTypeOnly) {
-        const typeOnlyKey = newImportsKey(
-          moduleSpecifier,
-          /*topLevelTypeOnly*/
-          true
-        );
-        const nonTypeOnlyKey = newImportsKey(
-          moduleSpecifier,
-          /*topLevelTypeOnly*/
-          false
-        );
-        const typeOnlyEntry = newImports.get(typeOnlyKey);
-        const nonTypeOnlyEntry = newImports.get(nonTypeOnlyKey);
-        const newEntry = {
-          defaultImport: void 0,
-          namedImports: void 0,
-          namespaceLikeImport: void 0,
-          useRequire
-        };
-        if (importKind === 1 /* Default */ && addAsTypeOnly === 2 /* Required */) {
-          if (typeOnlyEntry)
-            return typeOnlyEntry;
-          newImports.set(typeOnlyKey, newEntry);
-          return newEntry;
-        }
-        if (addAsTypeOnly === 1 /* Allowed */ && (typeOnlyEntry || nonTypeOnlyEntry)) {
-          return typeOnlyEntry || nonTypeOnlyEntry;
-        }
-        if (nonTypeOnlyEntry) {
-          return nonTypeOnlyEntry;
-        }
-        newImports.set(nonTypeOnlyKey, newEntry);
-        return newEntry;
-      }
-      function newImportsKey(moduleSpecifier, topLevelTypeOnly) {
-        return `${topLevelTypeOnly ? 1 : 0}|${moduleSpecifier}`;
-      }
-    }
-    function writeFixes(changeTracker) {
-      const quotePreference = getQuotePreference(sourceFile, preferences);
-      for (const fix of addToNamespace) {
-        addNamespaceQualifier(changeTracker, sourceFile, fix);
-      }
-      for (const fix of importType) {
-        addImportType(changeTracker, sourceFile, fix, quotePreference);
-      }
-      addToExisting.forEach(({ importClauseOrBindingPattern, defaultImport, namedImports }) => {
-        doAddExistingFix(
-          changeTracker,
-          sourceFile,
-          importClauseOrBindingPattern,
-          defaultImport,
-          arrayFrom(namedImports.entries(), ([name, addAsTypeOnly]) => ({ addAsTypeOnly, name })),
-          preferences
-        );
-      });
-      let newDeclarations;
-      newImports.forEach(({ useRequire, defaultImport, namedImports, namespaceLikeImport }, key) => {
-        const moduleSpecifier = key.slice(2);
-        const getDeclarations = useRequire ? getNewRequires : getNewImports;
-        const declarations = getDeclarations(
-          moduleSpecifier,
-          quotePreference,
-          defaultImport,
-          namedImports && arrayFrom(namedImports.entries(), ([name, addAsTypeOnly]) => ({ addAsTypeOnly, name })),
-          namespaceLikeImport,
-          compilerOptions
-        );
-        newDeclarations = combine(newDeclarations, declarations);
-      });
-      if (newDeclarations) {
-        insertImports(
-          changeTracker,
-          sourceFile,
-          newDeclarations,
-          /*blankLineBetween*/
-          true,
-          preferences
-        );
-      }
-    }
-    function hasFixes() {
-      return addToNamespace.length > 0 || importType.length > 0 || addToExisting.size > 0 || newImports.size > 0;
-    }
-  }
-  function createImportSpecifierResolver(importingFile, program, host, preferences) {
-    const packageJsonImportFilter = createPackageJsonImportFilter(importingFile, preferences, host);
-    const importMap = createExistingImportMap(program.getTypeChecker(), importingFile, program.getCompilerOptions());
-    return { getModuleSpecifierForBestExportInfo };
-    function getModuleSpecifierForBestExportInfo(exportInfo, position, isValidTypeOnlyUseSite, fromCacheOnly) {
-      const { fixes, computedWithoutCacheCount } = getImportFixes(
-        exportInfo,
-        position,
-        isValidTypeOnlyUseSite,
-        /*useRequire*/
-        false,
-        program,
-        importingFile,
-        host,
-        preferences,
-        importMap,
-        fromCacheOnly
-      );
-      const result = getBestFix(fixes, importingFile, program, packageJsonImportFilter, host);
-      return result && { ...result, computedWithoutCacheCount };
-    }
-  }
-  function getImportCompletionAction(targetSymbol, moduleSymbol, exportMapKey, sourceFile, symbolName2, isJsxTagName, host, program, formatContext, position, preferences, cancellationToken) {
-    const compilerOptions = program.getCompilerOptions();
-    let exportInfos;
-    if (exportMapKey) {
-      exportInfos = getExportInfoMap(sourceFile, host, program, preferences, cancellationToken).get(sourceFile.path, exportMapKey);
-      Debug.assertIsDefined(exportInfos, "Some exportInfo should match the specified exportMapKey");
-    } else {
-      exportInfos = pathIsBareSpecifier(stripQuotes(moduleSymbol.name)) ? [getSingleExportInfoForSymbol(targetSymbol, symbolName2, moduleSymbol, program, host)] : getAllExportInfoForSymbol(sourceFile, targetSymbol, symbolName2, moduleSymbol, isJsxTagName, program, host, preferences, cancellationToken);
-      Debug.assertIsDefined(exportInfos, "Some exportInfo should match the specified symbol / moduleSymbol");
-    }
-    const useRequire = shouldUseRequire(sourceFile, program);
-    const isValidTypeOnlyUseSite = isValidTypeOnlyAliasUseSite(getTokenAtPosition(sourceFile, position));
-    const fix = Debug.checkDefined(getImportFixForSymbol(sourceFile, exportInfos, program, position, isValidTypeOnlyUseSite, useRequire, host, preferences));
-    return {
-      moduleSpecifier: fix.moduleSpecifier,
-      codeAction: codeFixActionToCodeAction(codeActionForFix(
-        { host, formatContext, preferences },
-        sourceFile,
-        symbolName2,
-        fix,
-        /*includeSymbolNameInDescription*/
-        false,
-        compilerOptions,
-        preferences
-      ))
-    };
-  }
-  function getPromoteTypeOnlyCompletionAction(sourceFile, symbolToken, program, host, formatContext, preferences) {
-    const compilerOptions = program.getCompilerOptions();
-    const symbolName2 = single(getSymbolNamesToImport(sourceFile, program.getTypeChecker(), symbolToken, compilerOptions));
-    const fix = getTypeOnlyPromotionFix(sourceFile, symbolToken, symbolName2, program);
-    const includeSymbolNameInDescription = symbolName2 !== symbolToken.text;
-    return fix && codeFixActionToCodeAction(codeActionForFix({ host, formatContext, preferences }, sourceFile, symbolName2, fix, includeSymbolNameInDescription, compilerOptions, preferences));
-  }
-  function getImportFixForSymbol(sourceFile, exportInfos, program, position, isValidTypeOnlyUseSite, useRequire, host, preferences) {
-    const packageJsonImportFilter = createPackageJsonImportFilter(sourceFile, preferences, host);
-    return getBestFix(getImportFixes(exportInfos, position, isValidTypeOnlyUseSite, useRequire, program, sourceFile, host, preferences).fixes, sourceFile, program, packageJsonImportFilter, host);
-  }
-  function codeFixActionToCodeAction({ description: description3, changes, commands }) {
-    return { description: description3, changes, commands };
-  }
-  function getAllExportInfoForSymbol(importingFile, symbol, symbolName2, moduleSymbol, preferCapitalized, program, host, preferences, cancellationToken) {
-    const getChecker = createGetChecker(program, host);
-    return getExportInfoMap(importingFile, host, program, preferences, cancellationToken).search(importingFile.path, preferCapitalized, (name) => name === symbolName2, (info) => {
-      if (skipAlias(info[0].symbol, getChecker(info[0].isFromPackageJson)) === symbol && info.some((i) => i.moduleSymbol === moduleSymbol || i.symbol.parent === moduleSymbol)) {
-        return info;
-      }
-    });
-  }
-  function getSingleExportInfoForSymbol(symbol, symbolName2, moduleSymbol, program, host) {
-    var _a, _b;
-    const compilerOptions = program.getCompilerOptions();
-    const mainProgramInfo = getInfoWithChecker(
-      program.getTypeChecker(),
-      /*isFromPackageJson*/
-      false
-    );
-    if (mainProgramInfo) {
-      return mainProgramInfo;
-    }
-    const autoImportProvider = (_b = (_a = host.getPackageJsonAutoImportProvider) == null ? void 0 : _a.call(host)) == null ? void 0 : _b.getTypeChecker();
-    return Debug.checkDefined(autoImportProvider && getInfoWithChecker(
-      autoImportProvider,
-      /*isFromPackageJson*/
-      true
-    ), `Could not find symbol in specified module for code actions`);
-    function getInfoWithChecker(checker, isFromPackageJson) {
-      const defaultInfo = getDefaultLikeExportInfo(moduleSymbol, checker, compilerOptions);
-      if (defaultInfo && skipAlias(defaultInfo.symbol, checker) === symbol) {
-        return { symbol: defaultInfo.symbol, moduleSymbol, moduleFileName: void 0, exportKind: defaultInfo.exportKind, targetFlags: skipAlias(symbol, checker).flags, isFromPackageJson };
-      }
-      const named = checker.tryGetMemberInModuleExportsAndProperties(symbolName2, moduleSymbol);
-      if (named && skipAlias(named, checker) === symbol) {
-        return { symbol: named, moduleSymbol, moduleFileName: void 0, exportKind: 0 /* Named */, targetFlags: skipAlias(symbol, checker).flags, isFromPackageJson };
-      }
-    }
-  }
-  function getImportFixes(exportInfos, usagePosition, isValidTypeOnlyUseSite, useRequire, program, sourceFile, host, preferences, importMap = createExistingImportMap(program.getTypeChecker(), sourceFile, program.getCompilerOptions()), fromCacheOnly) {
-    const checker = program.getTypeChecker();
-    const existingImports = flatMap(exportInfos, importMap.getImportsForExportInfo);
-    const useNamespace = usagePosition !== void 0 && tryUseExistingNamespaceImport(existingImports, usagePosition);
-    const addToExisting = tryAddToExistingImport(existingImports, isValidTypeOnlyUseSite, checker, program.getCompilerOptions());
-    if (addToExisting) {
-      return {
-        computedWithoutCacheCount: 0,
-        fixes: [...useNamespace ? [useNamespace] : emptyArray, addToExisting]
-      };
-    }
-    const { fixes, computedWithoutCacheCount = 0 } = getFixesForAddImport(
-      exportInfos,
-      existingImports,
-      program,
-      sourceFile,
-      usagePosition,
-      isValidTypeOnlyUseSite,
-      useRequire,
-      host,
-      preferences,
-      fromCacheOnly
-    );
-    return {
-      computedWithoutCacheCount,
-      fixes: [...useNamespace ? [useNamespace] : emptyArray, ...fixes]
-    };
-  }
-  function tryUseExistingNamespaceImport(existingImports, position) {
-    return firstDefined(existingImports, ({ declaration, importKind }) => {
-      var _a;
-      if (importKind !== 0 /* Named */)
-        return void 0;
-      const namespacePrefix = getNamespaceLikeImportText(declaration);
-      const moduleSpecifier = namespacePrefix && ((_a = tryGetModuleSpecifierFromDeclaration(declaration)) == null ? void 0 : _a.text);
-      if (moduleSpecifier) {
-        return { kind: 0 /* UseNamespace */, namespacePrefix, usagePosition: position, moduleSpecifier };
-      }
-    });
-  }
-  function getNamespaceLikeImportText(declaration) {
-    var _a, _b, _c;
-    switch (declaration.kind) {
-      case 259 /* VariableDeclaration */:
-        return (_a = tryCast(declaration.name, isIdentifier)) == null ? void 0 : _a.text;
-      case 270 /* ImportEqualsDeclaration */:
-        return declaration.name.text;
-      case 271 /* ImportDeclaration */:
-        return (_c = tryCast((_b = declaration.importClause) == null ? void 0 : _b.namedBindings, isNamespaceImport)) == null ? void 0 : _c.name.text;
-      default:
-        return Debug.assertNever(declaration);
-    }
-  }
-  function getAddAsTypeOnly(isValidTypeOnlyUseSite, isForNewImportDeclaration, symbol, targetFlags, checker, compilerOptions) {
-    if (!isValidTypeOnlyUseSite) {
-      return 4 /* NotAllowed */;
-    }
-    if (isForNewImportDeclaration && compilerOptions.importsNotUsedAsValues === 2 /* Error */) {
-      return 2 /* Required */;
-    }
-    if (importNameElisionDisabled(compilerOptions) && (!(targetFlags & 111551 /* Value */) || !!checker.getTypeOnlyAliasDeclaration(symbol))) {
-      return 2 /* Required */;
-    }
-    return 1 /* Allowed */;
-  }
-  function tryAddToExistingImport(existingImports, isValidTypeOnlyUseSite, checker, compilerOptions) {
-    let best;
-    for (const existingImport of existingImports) {
-      const fix = getAddToExistingImportFix(existingImport);
-      if (!fix)
-        continue;
-      const isTypeOnly = isTypeOnlyImportDeclaration(fix.importClauseOrBindingPattern);
-      if (fix.addAsTypeOnly !== 4 /* NotAllowed */ && isTypeOnly || fix.addAsTypeOnly === 4 /* NotAllowed */ && !isTypeOnly) {
-        return fix;
-      }
-      best ?? (best = fix);
-    }
-    return best;
-    function getAddToExistingImportFix({ declaration, importKind, symbol, targetFlags }) {
-      if (importKind === 3 /* CommonJS */ || importKind === 2 /* Namespace */ || declaration.kind === 270 /* ImportEqualsDeclaration */) {
-        return void 0;
-      }
-      if (declaration.kind === 259 /* VariableDeclaration */) {
-        return (importKind === 0 /* Named */ || importKind === 1 /* Default */) && declaration.name.kind === 205 /* ObjectBindingPattern */ ? { kind: 2 /* AddToExisting */, importClauseOrBindingPattern: declaration.name, importKind, moduleSpecifier: declaration.initializer.arguments[0].text, addAsTypeOnly: 4 /* NotAllowed */ } : void 0;
-      }
-      const { importClause } = declaration;
-      if (!importClause || !isStringLiteralLike(declaration.moduleSpecifier)) {
-        return void 0;
-      }
-      const { name, namedBindings } = importClause;
-      if (importClause.isTypeOnly && !(importKind === 0 /* Named */ && namedBindings)) {
-        return void 0;
-      }
-      const addAsTypeOnly = getAddAsTypeOnly(
-        isValidTypeOnlyUseSite,
-        /*isForNewImportDeclaration*/
-        false,
-        symbol,
-        targetFlags,
-        checker,
-        compilerOptions
-      );
-      if (importKind === 1 /* Default */ && (name || // Cannot add a default import to a declaration that already has one
-      addAsTypeOnly === 2 /* Required */ && namedBindings)) {
-        return void 0;
-      }
-      if (importKind === 0 /* Named */ && (namedBindings == null ? void 0 : namedBindings.kind) === 273 /* NamespaceImport */) {
-        return void 0;
-      }
-      return {
-        kind: 2 /* AddToExisting */,
-        importClauseOrBindingPattern: importClause,
-        importKind,
-        moduleSpecifier: declaration.moduleSpecifier.text,
-        addAsTypeOnly
-      };
-    }
-  }
-  function createExistingImportMap(checker, importingFile, compilerOptions) {
-    let importMap;
-    for (const moduleSpecifier of importingFile.imports) {
-      const i = importFromModuleSpecifier(moduleSpecifier);
-      if (isVariableDeclarationInitializedToRequire(i.parent)) {
-        const moduleSymbol = checker.resolveExternalModuleName(moduleSpecifier);
-        if (moduleSymbol) {
-          (importMap || (importMap = createMultiMap())).add(getSymbolId(moduleSymbol), i.parent);
-        }
-      } else if (i.kind === 271 /* ImportDeclaration */ || i.kind === 270 /* ImportEqualsDeclaration */) {
-        const moduleSymbol = checker.getSymbolAtLocation(moduleSpecifier);
-        if (moduleSymbol) {
-          (importMap || (importMap = createMultiMap())).add(getSymbolId(moduleSymbol), i);
-        }
-      }
-    }
-    return {
-      getImportsForExportInfo: ({ moduleSymbol, exportKind, targetFlags, symbol }) => {
-        if (!(targetFlags & 111551 /* Value */) && isSourceFileJS(importingFile))
-          return emptyArray;
-        const matchingDeclarations = importMap == null ? void 0 : importMap.get(getSymbolId(moduleSymbol));
-        if (!matchingDeclarations)
-          return emptyArray;
-        const importKind = getImportKind(importingFile, exportKind, compilerOptions);
-        return matchingDeclarations.map((declaration) => ({ declaration, importKind, symbol, targetFlags }));
-      }
-    };
-  }
-  function shouldUseRequire(sourceFile, program) {
-    if (!isSourceFileJS(sourceFile)) {
-      return false;
-    }
-    if (sourceFile.commonJsModuleIndicator && !sourceFile.externalModuleIndicator)
-      return true;
-    if (sourceFile.externalModuleIndicator && !sourceFile.commonJsModuleIndicator)
-      return false;
-    const compilerOptions = program.getCompilerOptions();
-    if (compilerOptions.configFile) {
-      return getEmitModuleKind(compilerOptions) < 5 /* ES2015 */;
-    }
-    for (const otherFile of program.getSourceFiles()) {
-      if (otherFile === sourceFile || !isSourceFileJS(otherFile) || program.isSourceFileFromExternalLibrary(otherFile))
-        continue;
-      if (otherFile.commonJsModuleIndicator && !otherFile.externalModuleIndicator)
-        return true;
-      if (otherFile.externalModuleIndicator && !otherFile.commonJsModuleIndicator)
-        return false;
-    }
-    return true;
-  }
-  function createGetChecker(program, host) {
-    return memoizeOne((isFromPackageJson) => isFromPackageJson ? host.getPackageJsonAutoImportProvider().getTypeChecker() : program.getTypeChecker());
-  }
-  function getNewImportFixes(program, sourceFile, usagePosition, isValidTypeOnlyUseSite, useRequire, exportInfo, host, preferences, fromCacheOnly) {
-    const isJs = isSourceFileJS(sourceFile);
-    const compilerOptions = program.getCompilerOptions();
-    const moduleSpecifierResolutionHost = createModuleSpecifierResolutionHost(program, host);
-    const getChecker = createGetChecker(program, host);
-    const moduleResolution = getEmitModuleResolutionKind(compilerOptions);
-    const rejectNodeModulesRelativePaths = moduleResolutionUsesNodeModules(moduleResolution);
-    const getModuleSpecifiers2 = fromCacheOnly ? (moduleSymbol) => ({ moduleSpecifiers: ts_moduleSpecifiers_exports.tryGetModuleSpecifiersFromCache(moduleSymbol, sourceFile, moduleSpecifierResolutionHost, preferences), computedWithoutCache: false }) : (moduleSymbol, checker) => ts_moduleSpecifiers_exports.getModuleSpecifiersWithCacheInfo(moduleSymbol, checker, compilerOptions, sourceFile, moduleSpecifierResolutionHost, preferences);
-    let computedWithoutCacheCount = 0;
-    const fixes = flatMap(exportInfo, (exportInfo2, i) => {
-      const checker = getChecker(exportInfo2.isFromPackageJson);
-      const { computedWithoutCache, moduleSpecifiers } = getModuleSpecifiers2(exportInfo2.moduleSymbol, checker);
-      const importedSymbolHasValueMeaning = !!(exportInfo2.targetFlags & 111551 /* Value */);
-      const addAsTypeOnly = getAddAsTypeOnly(
-        isValidTypeOnlyUseSite,
-        /*isForNewImportDeclaration*/
-        true,
-        exportInfo2.symbol,
-        exportInfo2.targetFlags,
-        checker,
-        compilerOptions
-      );
-      computedWithoutCacheCount += computedWithoutCache ? 1 : 0;
-      return mapDefined(moduleSpecifiers, (moduleSpecifier) => {
-        var _a;
-        if (rejectNodeModulesRelativePaths && pathContainsNodeModules(moduleSpecifier)) {
-          return void 0;
-        }
-        if (!importedSymbolHasValueMeaning && isJs && usagePosition !== void 0) {
-          return { kind: 1 /* JsdocTypeImport */, moduleSpecifier, usagePosition, exportInfo: exportInfo2, isReExport: i > 0 };
-        }
-        const importKind = getImportKind(sourceFile, exportInfo2.exportKind, compilerOptions);
-        let qualification;
-        if (usagePosition !== void 0 && importKind === 3 /* CommonJS */ && exportInfo2.exportKind === 0 /* Named */) {
-          const exportEquals = checker.resolveExternalModuleSymbol(exportInfo2.moduleSymbol);
-          let namespacePrefix;
-          if (exportEquals !== exportInfo2.moduleSymbol) {
-            namespacePrefix = (_a = getDefaultExportInfoWorker(exportEquals, checker, compilerOptions)) == null ? void 0 : _a.name;
-          }
-          namespacePrefix || (namespacePrefix = moduleSymbolToValidIdentifier(
-            exportInfo2.moduleSymbol,
-            getEmitScriptTarget(compilerOptions),
-            /*forceCapitalize*/
-            false
-          ));
-          qualification = { namespacePrefix, usagePosition };
-        }
-        return {
-          kind: 3 /* AddNew */,
-          moduleSpecifier,
-          importKind,
-          useRequire,
-          addAsTypeOnly,
-          exportInfo: exportInfo2,
-          isReExport: i > 0,
-          qualification
-        };
-      });
-    });
-    return { computedWithoutCacheCount, fixes };
-  }
-  function getFixesForAddImport(exportInfos, existingImports, program, sourceFile, usagePosition, isValidTypeOnlyUseSite, useRequire, host, preferences, fromCacheOnly) {
-    const existingDeclaration = firstDefined(existingImports, (info) => newImportInfoFromExistingSpecifier(info, isValidTypeOnlyUseSite, useRequire, program.getTypeChecker(), program.getCompilerOptions()));
-    return existingDeclaration ? { fixes: [existingDeclaration] } : getNewImportFixes(program, sourceFile, usagePosition, isValidTypeOnlyUseSite, useRequire, exportInfos, host, preferences, fromCacheOnly);
-  }
-  function newImportInfoFromExistingSpecifier({ declaration, importKind, symbol, targetFlags }, isValidTypeOnlyUseSite, useRequire, checker, compilerOptions) {
-    var _a;
-    const moduleSpecifier = (_a = tryGetModuleSpecifierFromDeclaration(declaration)) == null ? void 0 : _a.text;
-    if (moduleSpecifier) {
-      const addAsTypeOnly = useRequire ? 4 /* NotAllowed */ : getAddAsTypeOnly(
-        isValidTypeOnlyUseSite,
-        /*isForNewImportDeclaration*/
-        true,
-        symbol,
-        targetFlags,
-        checker,
-        compilerOptions
-      );
-      return { kind: 3 /* AddNew */, moduleSpecifier, importKind, addAsTypeOnly, useRequire };
-    }
-  }
-  function getFixInfos(context, errorCode, pos, useAutoImportProvider) {
-    const symbolToken = getTokenAtPosition(context.sourceFile, pos);
-    let info;
-    if (errorCode === Diagnostics._0_refers_to_a_UMD_global_but_the_current_file_is_a_module_Consider_adding_an_import_instead.code) {
-      info = getFixesInfoForUMDImport(context, symbolToken);
-    } else if (!isIdentifier(symbolToken)) {
-      return void 0;
-    } else if (errorCode === Diagnostics._0_cannot_be_used_as_a_value_because_it_was_imported_using_import_type.code) {
-      const symbolName2 = single(getSymbolNamesToImport(context.sourceFile, context.program.getTypeChecker(), symbolToken, context.program.getCompilerOptions()));
-      const fix = getTypeOnlyPromotionFix(context.sourceFile, symbolToken, symbolName2, context.program);
-      return fix && [{ fix, symbolName: symbolName2, errorIdentifierText: symbolToken.text }];
-    } else {
-      info = getFixesInfoForNonUMDImport(context, symbolToken, useAutoImportProvider);
-    }
-    const packageJsonImportFilter = createPackageJsonImportFilter(context.sourceFile, context.preferences, context.host);
-    return info && sortFixInfo(info, context.sourceFile, context.program, packageJsonImportFilter, context.host);
-  }
-  function sortFixInfo(fixes, sourceFile, program, packageJsonImportFilter, host) {
-    const _toPath = (fileName) => toPath(fileName, host.getCurrentDirectory(), hostGetCanonicalFileName(host));
-    return sort(fixes, (a, b) => compareBooleans(!!a.isJsxNamespaceFix, !!b.isJsxNamespaceFix) || compareValues(a.fix.kind, b.fix.kind) || compareModuleSpecifiers(a.fix, b.fix, sourceFile, program, packageJsonImportFilter.allowsImportingSpecifier, _toPath));
-  }
-  function getBestFix(fixes, sourceFile, program, packageJsonImportFilter, host) {
-    if (!some(fixes))
-      return;
-    if (fixes[0].kind === 0 /* UseNamespace */ || fixes[0].kind === 2 /* AddToExisting */) {
-      return fixes[0];
-    }
-    return fixes.reduce(
-      (best, fix) => (
-        // Takes true branch of conditional if `fix` is better than `best`
-        compareModuleSpecifiers(
-          fix,
-          best,
-          sourceFile,
-          program,
-          packageJsonImportFilter.allowsImportingSpecifier,
-          (fileName) => toPath(fileName, host.getCurrentDirectory(), hostGetCanonicalFileName(host))
-        ) === -1 /* LessThan */ ? fix : best
-      )
-    );
-  }
-  function compareModuleSpecifiers(a, b, importingFile, program, allowsImportingSpecifier, toPath3) {
-    if (a.kind !== 0 /* UseNamespace */ && b.kind !== 0 /* UseNamespace */) {
-      return compareBooleans(allowsImportingSpecifier(b.moduleSpecifier), allowsImportingSpecifier(a.moduleSpecifier)) || compareNodeCoreModuleSpecifiers(a.moduleSpecifier, b.moduleSpecifier, importingFile, program) || compareBooleans(
-        isFixPossiblyReExportingImportingFile(a, importingFile, program.getCompilerOptions(), toPath3),
-        isFixPossiblyReExportingImportingFile(b, importingFile, program.getCompilerOptions(), toPath3)
-      ) || compareNumberOfDirectorySeparators(a.moduleSpecifier, b.moduleSpecifier);
-    }
-    return 0 /* EqualTo */;
-  }
-  function isFixPossiblyReExportingImportingFile(fix, importingFile, compilerOptions, toPath3) {
-    var _a;
-    if (fix.isReExport && ((_a = fix.exportInfo) == null ? void 0 : _a.moduleFileName) && getEmitModuleResolutionKind(compilerOptions) === 2 /* Node10 */ && isIndexFileName(fix.exportInfo.moduleFileName)) {
-      const reExportDir = toPath3(getDirectoryPath(fix.exportInfo.moduleFileName));
-      return startsWith(importingFile.path, reExportDir);
-    }
-    return false;
-  }
-  function isIndexFileName(fileName) {
-    return getBaseFileName(
-      fileName,
-      [".js", ".jsx", ".d.ts", ".ts", ".tsx"],
-      /*ignoreCase*/
-      true
-    ) === "index";
-  }
-  function compareNodeCoreModuleSpecifiers(a, b, importingFile, program) {
-    if (startsWith(a, "node:") && !startsWith(b, "node:"))
-      return shouldUseUriStyleNodeCoreModules(importingFile, program) ? -1 /* LessThan */ : 1 /* GreaterThan */;
-    if (startsWith(b, "node:") && !startsWith(a, "node:"))
-      return shouldUseUriStyleNodeCoreModules(importingFile, program) ? 1 /* GreaterThan */ : -1 /* LessThan */;
-    return 0 /* EqualTo */;
-  }
-  function getFixesInfoForUMDImport({ sourceFile, program, host, preferences }, token) {
-    const checker = program.getTypeChecker();
-    const umdSymbol = getUmdSymbol(token, checker);
-    if (!umdSymbol)
-      return void 0;
-    const symbol = checker.getAliasedSymbol(umdSymbol);
-    const symbolName2 = umdSymbol.name;
-    const exportInfo = [{ symbol: umdSymbol, moduleSymbol: symbol, moduleFileName: void 0, exportKind: 3 /* UMD */, targetFlags: symbol.flags, isFromPackageJson: false }];
-    const useRequire = shouldUseRequire(sourceFile, program);
-    const fixes = getImportFixes(
-      exportInfo,
-      /*usagePosition*/
-      void 0,
-      /*isValidTypeOnlyUseSite*/
-      false,
-      useRequire,
-      program,
-      sourceFile,
-      host,
-      preferences
-    ).fixes;
-    return fixes.map((fix) => {
-      var _a;
-      return { fix, symbolName: symbolName2, errorIdentifierText: (_a = tryCast(token, isIdentifier)) == null ? void 0 : _a.text };
-    });
-  }
-  function getUmdSymbol(token, checker) {
-    const umdSymbol = isIdentifier(token) ? checker.getSymbolAtLocation(token) : void 0;
-    if (isUMDExportSymbol(umdSymbol))
-      return umdSymbol;
-    const { parent: parent2 } = token;
-    if (isJsxOpeningLikeElement(parent2) && parent2.tagName === token || isJsxOpeningFragment(parent2)) {
-      const parentSymbol = checker.resolveName(
-        checker.getJsxNamespace(parent2),
-        isJsxOpeningLikeElement(parent2) ? token : parent2,
-        111551 /* Value */,
-        /*excludeGlobals*/
-        false
-      );
-      if (isUMDExportSymbol(parentSymbol)) {
-        return parentSymbol;
-      }
-    }
-    return void 0;
-  }
-  function getImportKind(importingFile, exportKind, compilerOptions, forceImportKeyword) {
-    if (compilerOptions.verbatimModuleSyntax && (getEmitModuleKind(compilerOptions) === 1 /* CommonJS */ || importingFile.impliedNodeFormat === 1 /* CommonJS */)) {
-      return 3 /* CommonJS */;
-    }
-    switch (exportKind) {
-      case 0 /* Named */:
-        return 0 /* Named */;
-      case 1 /* Default */:
-        return 1 /* Default */;
-      case 2 /* ExportEquals */:
-        return getExportEqualsImportKind(importingFile, compilerOptions, !!forceImportKeyword);
-      case 3 /* UMD */:
-        return getUmdImportKind(importingFile, compilerOptions, !!forceImportKeyword);
-      default:
-        return Debug.assertNever(exportKind);
-    }
-  }
-  function getUmdImportKind(importingFile, compilerOptions, forceImportKeyword) {
-    if (getAllowSyntheticDefaultImports(compilerOptions)) {
-      return 1 /* Default */;
-    }
-    const moduleKind = getEmitModuleKind(compilerOptions);
-    switch (moduleKind) {
-      case 2 /* AMD */:
-      case 1 /* CommonJS */:
-      case 3 /* UMD */:
-        if (isInJSFile(importingFile)) {
-          return isExternalModule(importingFile) || forceImportKeyword ? 2 /* Namespace */ : 3 /* CommonJS */;
-        }
-        return 3 /* CommonJS */;
-      case 4 /* System */:
-      case 5 /* ES2015 */:
-      case 6 /* ES2020 */:
-      case 7 /* ES2022 */:
-      case 99 /* ESNext */:
-      case 0 /* None */:
-        return 2 /* Namespace */;
-      case 100 /* Node16 */:
-      case 199 /* NodeNext */:
-        return importingFile.impliedNodeFormat === 99 /* ESNext */ ? 2 /* Namespace */ : 3 /* CommonJS */;
-      default:
-        return Debug.assertNever(moduleKind, `Unexpected moduleKind ${moduleKind}`);
-    }
-  }
-  function getFixesInfoForNonUMDImport({ sourceFile, program, cancellationToken, host, preferences }, symbolToken, useAutoImportProvider) {
-    const checker = program.getTypeChecker();
-    const compilerOptions = program.getCompilerOptions();
-    return flatMap(getSymbolNamesToImport(sourceFile, checker, symbolToken, compilerOptions), (symbolName2) => {
-      if (symbolName2 === "default" /* Default */) {
-        return void 0;
-      }
-      const isValidTypeOnlyUseSite = isValidTypeOnlyAliasUseSite(symbolToken);
-      const useRequire = shouldUseRequire(sourceFile, program);
-      const exportInfo = getExportInfos(symbolName2, isJSXTagName(symbolToken), getMeaningFromLocation(symbolToken), cancellationToken, sourceFile, program, useAutoImportProvider, host, preferences);
-      return arrayFrom(
-        flatMapIterator(exportInfo.values(), (exportInfos) => getImportFixes(exportInfos, symbolToken.getStart(sourceFile), isValidTypeOnlyUseSite, useRequire, program, sourceFile, host, preferences).fixes),
-        (fix) => ({ fix, symbolName: symbolName2, errorIdentifierText: symbolToken.text, isJsxNamespaceFix: symbolName2 !== symbolToken.text })
-      );
-    });
-  }
-  function getTypeOnlyPromotionFix(sourceFile, symbolToken, symbolName2, program) {
-    const checker = program.getTypeChecker();
-    const symbol = checker.resolveName(
-      symbolName2,
-      symbolToken,
-      111551 /* Value */,
-      /*excludeGlobals*/
-      true
-    );
-    if (!symbol)
-      return void 0;
-    const typeOnlyAliasDeclaration = checker.getTypeOnlyAliasDeclaration(symbol);
-    if (!typeOnlyAliasDeclaration || getSourceFileOfNode(typeOnlyAliasDeclaration) !== sourceFile)
-      return void 0;
-    return { kind: 4 /* PromoteTypeOnly */, typeOnlyAliasDeclaration };
-  }
-  function getSymbolNamesToImport(sourceFile, checker, symbolToken, compilerOptions) {
-    const parent2 = symbolToken.parent;
-    if ((isJsxOpeningLikeElement(parent2) || isJsxClosingElement(parent2)) && parent2.tagName === symbolToken && jsxModeNeedsExplicitImport(compilerOptions.jsx)) {
-      const jsxNamespace = checker.getJsxNamespace(sourceFile);
-      if (needsJsxNamespaceFix(jsxNamespace, symbolToken, checker)) {
-        const needsComponentNameFix = !isIntrinsicJsxName(symbolToken.text) && !checker.resolveName(
-          symbolToken.text,
-          symbolToken,
-          111551 /* Value */,
-          /*excludeGlobals*/
-          false
-        );
-        return needsComponentNameFix ? [symbolToken.text, jsxNamespace] : [jsxNamespace];
-      }
-    }
-    return [symbolToken.text];
-  }
-  function needsJsxNamespaceFix(jsxNamespace, symbolToken, checker) {
-    if (isIntrinsicJsxName(symbolToken.text))
-      return true;
-    const namespaceSymbol = checker.resolveName(
-      jsxNamespace,
-      symbolToken,
-      111551 /* Value */,
-      /*excludeGlobals*/
-      true
-    );
-    return !namespaceSymbol || some(namespaceSymbol.declarations, isTypeOnlyImportOrExportDeclaration) && !(namespaceSymbol.flags & 111551 /* Value */);
-  }
-  function getExportInfos(symbolName2, isJsxTagName, currentTokenMeaning, cancellationToken, fromFile, program, useAutoImportProvider, host, preferences) {
-    var _a;
-    const originalSymbolToExportInfos = createMultiMap();
-    const packageJsonFilter = createPackageJsonImportFilter(fromFile, preferences, host);
-    const moduleSpecifierCache = (_a = host.getModuleSpecifierCache) == null ? void 0 : _a.call(host);
-    const getModuleSpecifierResolutionHost = memoizeOne((isFromPackageJson) => {
-      return createModuleSpecifierResolutionHost(isFromPackageJson ? host.getPackageJsonAutoImportProvider() : program, host);
-    });
-    function addSymbol(moduleSymbol, toFile, exportedSymbol, exportKind, program2, isFromPackageJson) {
-      const moduleSpecifierResolutionHost = getModuleSpecifierResolutionHost(isFromPackageJson);
-      if (toFile && isImportableFile(program2, fromFile, toFile, preferences, packageJsonFilter, moduleSpecifierResolutionHost, moduleSpecifierCache) || !toFile && packageJsonFilter.allowsImportingAmbientModule(moduleSymbol, moduleSpecifierResolutionHost)) {
-        const checker = program2.getTypeChecker();
-        originalSymbolToExportInfos.add(getUniqueSymbolId(exportedSymbol, checker).toString(), { symbol: exportedSymbol, moduleSymbol, moduleFileName: toFile == null ? void 0 : toFile.fileName, exportKind, targetFlags: skipAlias(exportedSymbol, checker).flags, isFromPackageJson });
-      }
-    }
-    forEachExternalModuleToImportFrom(program, host, preferences, useAutoImportProvider, (moduleSymbol, sourceFile, program2, isFromPackageJson) => {
-      const checker = program2.getTypeChecker();
-      cancellationToken.throwIfCancellationRequested();
-      const compilerOptions = program2.getCompilerOptions();
-      const defaultInfo = getDefaultLikeExportInfo(moduleSymbol, checker, compilerOptions);
-      if (defaultInfo && (defaultInfo.name === symbolName2 || moduleSymbolToValidIdentifier(moduleSymbol, getEmitScriptTarget(compilerOptions), isJsxTagName) === symbolName2) && symbolHasMeaning(defaultInfo.resolvedSymbol, currentTokenMeaning)) {
-        addSymbol(moduleSymbol, sourceFile, defaultInfo.symbol, defaultInfo.exportKind, program2, isFromPackageJson);
-      }
-      const exportSymbolWithIdenticalName = checker.tryGetMemberInModuleExportsAndProperties(symbolName2, moduleSymbol);
-      if (exportSymbolWithIdenticalName && symbolHasMeaning(exportSymbolWithIdenticalName, currentTokenMeaning)) {
-        addSymbol(moduleSymbol, sourceFile, exportSymbolWithIdenticalName, 0 /* Named */, program2, isFromPackageJson);
-      }
-    });
-    return originalSymbolToExportInfos;
-  }
-  function getExportEqualsImportKind(importingFile, compilerOptions, forceImportKeyword) {
-    const allowSyntheticDefaults = getAllowSyntheticDefaultImports(compilerOptions);
-    const isJS = isInJSFile(importingFile);
-    if (!isJS && getEmitModuleKind(compilerOptions) >= 5 /* ES2015 */) {
-      return allowSyntheticDefaults ? 1 /* Default */ : 2 /* Namespace */;
-    }
-    if (isJS) {
-      return isExternalModule(importingFile) || forceImportKeyword ? allowSyntheticDefaults ? 1 /* Default */ : 2 /* Namespace */ : 3 /* CommonJS */;
-    }
-    for (const statement of importingFile.statements) {
-      if (isImportEqualsDeclaration(statement) && !nodeIsMissing(statement.moduleReference)) {
-        return 3 /* CommonJS */;
-      }
-    }
-    return allowSyntheticDefaults ? 1 /* Default */ : 3 /* CommonJS */;
-  }
-  function codeActionForFix(context, sourceFile, symbolName2, fix, includeSymbolNameInDescription, compilerOptions, preferences) {
-    let diag2;
-    const changes = ts_textChanges_exports.ChangeTracker.with(context, (tracker) => {
-      diag2 = codeActionForFixWorker(tracker, sourceFile, symbolName2, fix, includeSymbolNameInDescription, compilerOptions, preferences);
-    });
-    return createCodeFixAction(importFixName, changes, diag2, importFixId, Diagnostics.Add_all_missing_imports);
-  }
-  function codeActionForFixWorker(changes, sourceFile, symbolName2, fix, includeSymbolNameInDescription, compilerOptions, preferences) {
-    const quotePreference = getQuotePreference(sourceFile, preferences);
-    switch (fix.kind) {
-      case 0 /* UseNamespace */:
-        addNamespaceQualifier(changes, sourceFile, fix);
-        return [Diagnostics.Change_0_to_1, symbolName2, `${fix.namespacePrefix}.${symbolName2}`];
-      case 1 /* JsdocTypeImport */:
-        addImportType(changes, sourceFile, fix, quotePreference);
-        return [Diagnostics.Change_0_to_1, symbolName2, getImportTypePrefix(fix.moduleSpecifier, quotePreference) + symbolName2];
-      case 2 /* AddToExisting */: {
-        const { importClauseOrBindingPattern, importKind, addAsTypeOnly, moduleSpecifier } = fix;
-        doAddExistingFix(
-          changes,
-          sourceFile,
-          importClauseOrBindingPattern,
-          importKind === 1 /* Default */ ? { name: symbolName2, addAsTypeOnly } : void 0,
-          importKind === 0 /* Named */ ? [{ name: symbolName2, addAsTypeOnly }] : emptyArray,
-          preferences
-        );
-        const moduleSpecifierWithoutQuotes = stripQuotes(moduleSpecifier);
-        return includeSymbolNameInDescription ? [Diagnostics.Import_0_from_1, symbolName2, moduleSpecifierWithoutQuotes] : [Diagnostics.Update_import_from_0, moduleSpecifierWithoutQuotes];
-      }
-      case 3 /* AddNew */: {
-        const { importKind, moduleSpecifier, addAsTypeOnly, useRequire, qualification } = fix;
-        const getDeclarations = useRequire ? getNewRequires : getNewImports;
-        const defaultImport = importKind === 1 /* Default */ ? { name: symbolName2, addAsTypeOnly } : void 0;
-        const namedImports = importKind === 0 /* Named */ ? [{ name: symbolName2, addAsTypeOnly }] : void 0;
-        const namespaceLikeImport = importKind === 2 /* Namespace */ || importKind === 3 /* CommonJS */ ? { importKind, name: (qualification == null ? void 0 : qualification.namespacePrefix) || symbolName2, addAsTypeOnly } : void 0;
-        insertImports(
-          changes,
-          sourceFile,
-          getDeclarations(
-            moduleSpecifier,
-            quotePreference,
-            defaultImport,
-            namedImports,
-            namespaceLikeImport,
-            compilerOptions
-          ),
-          /*blankLineBetween*/
-          true,
-          preferences
-        );
-        if (qualification) {
-          addNamespaceQualifier(changes, sourceFile, qualification);
-        }
-        return includeSymbolNameInDescription ? [Diagnostics.Import_0_from_1, symbolName2, moduleSpecifier] : [Diagnostics.Add_import_from_0, moduleSpecifier];
-      }
-      case 4 /* PromoteTypeOnly */: {
-        const { typeOnlyAliasDeclaration } = fix;
-        const promotedDeclaration = promoteFromTypeOnly(changes, typeOnlyAliasDeclaration, compilerOptions, sourceFile, preferences);
-        return promotedDeclaration.kind === 275 /* ImportSpecifier */ ? [Diagnostics.Remove_type_from_import_of_0_from_1, symbolName2, getModuleSpecifierText(promotedDeclaration.parent.parent)] : [Diagnostics.Remove_type_from_import_declaration_from_0, getModuleSpecifierText(promotedDeclaration)];
-      }
-      default:
-        return Debug.assertNever(fix, `Unexpected fix kind ${fix.kind}`);
-    }
-  }
-  function getModuleSpecifierText(promotedDeclaration) {
-    var _a, _b;
-    return promotedDeclaration.kind === 270 /* ImportEqualsDeclaration */ ? ((_b = tryCast((_a = tryCast(promotedDeclaration.moduleReference, isExternalModuleReference)) == null ? void 0 : _a.expression, isStringLiteralLike)) == null ? void 0 : _b.text) || promotedDeclaration.moduleReference.getText() : cast(promotedDeclaration.parent.moduleSpecifier, isStringLiteral).text;
-  }
-  function promoteFromTypeOnly(changes, aliasDeclaration, compilerOptions, sourceFile, preferences) {
-    const convertExistingToTypeOnly = importNameElisionDisabled(compilerOptions);
-    switch (aliasDeclaration.kind) {
-      case 275 /* ImportSpecifier */:
-        if (aliasDeclaration.isTypeOnly) {
-          const sortKind = ts_OrganizeImports_exports.detectImportSpecifierSorting(aliasDeclaration.parent.elements, preferences);
-          if (aliasDeclaration.parent.elements.length > 1 && sortKind) {
-            changes.delete(sourceFile, aliasDeclaration);
-            const newSpecifier = factory.updateImportSpecifier(
-              aliasDeclaration,
-              /*isTypeOnly*/
-              false,
-              aliasDeclaration.propertyName,
-              aliasDeclaration.name
-            );
-            const comparer = ts_OrganizeImports_exports.getOrganizeImportsComparer(preferences, sortKind === 2 /* CaseInsensitive */);
-            const insertionIndex = ts_OrganizeImports_exports.getImportSpecifierInsertionIndex(aliasDeclaration.parent.elements, newSpecifier, comparer);
-            changes.insertImportSpecifierAtIndex(sourceFile, newSpecifier, aliasDeclaration.parent, insertionIndex);
-          } else {
-            changes.deleteRange(sourceFile, aliasDeclaration.getFirstToken());
-          }
-          return aliasDeclaration;
-        } else {
-          Debug.assert(aliasDeclaration.parent.parent.isTypeOnly);
-          promoteImportClause(aliasDeclaration.parent.parent);
-          return aliasDeclaration.parent.parent;
-        }
-      case 272 /* ImportClause */:
-        promoteImportClause(aliasDeclaration);
-        return aliasDeclaration;
-      case 273 /* NamespaceImport */:
-        promoteImportClause(aliasDeclaration.parent);
-        return aliasDeclaration.parent;
-      case 270 /* ImportEqualsDeclaration */:
-        changes.deleteRange(sourceFile, aliasDeclaration.getChildAt(1));
-        return aliasDeclaration;
-      default:
-        Debug.failBadSyntaxKind(aliasDeclaration);
-    }
-    function promoteImportClause(importClause) {
-      changes.delete(sourceFile, getTypeKeywordOfTypeOnlyImport(importClause, sourceFile));
-      if (convertExistingToTypeOnly) {
-        const namedImports = tryCast(importClause.namedBindings, isNamedImports);
-        if (namedImports && namedImports.elements.length > 1) {
-          if (ts_OrganizeImports_exports.detectImportSpecifierSorting(namedImports.elements, preferences) && aliasDeclaration.kind === 275 /* ImportSpecifier */ && namedImports.elements.indexOf(aliasDeclaration) !== 0) {
-            changes.delete(sourceFile, aliasDeclaration);
-            changes.insertImportSpecifierAtIndex(sourceFile, aliasDeclaration, namedImports, 0);
-          }
-          for (const element of namedImports.elements) {
-            if (element !== aliasDeclaration && !element.isTypeOnly) {
-              changes.insertModifierBefore(sourceFile, 156 /* TypeKeyword */, element);
-            }
-          }
-        }
-      }
-    }
-  }
-  function doAddExistingFix(changes, sourceFile, clause, defaultImport, namedImports, preferences) {
-    var _a;
-    if (clause.kind === 205 /* ObjectBindingPattern */) {
-      if (defaultImport) {
-        addElementToBindingPattern(clause, defaultImport.name, "default");
-      }
-      for (const specifier of namedImports) {
-        addElementToBindingPattern(
-          clause,
-          specifier.name,
-          /*propertyName*/
-          void 0
-        );
-      }
-      return;
-    }
-    const promoteFromTypeOnly2 = clause.isTypeOnly && some([defaultImport, ...namedImports], (i) => (i == null ? void 0 : i.addAsTypeOnly) === 4 /* NotAllowed */);
-    const existingSpecifiers = clause.namedBindings && ((_a = tryCast(clause.namedBindings, isNamedImports)) == null ? void 0 : _a.elements);
-    if (defaultImport) {
-      Debug.assert(!clause.name, "Cannot add a default import to an import clause that already has one");
-      changes.insertNodeAt(sourceFile, clause.getStart(sourceFile), factory.createIdentifier(defaultImport.name), { suffix: ", " });
-    }
-    if (namedImports.length) {
-      let ignoreCaseForSorting;
-      if (typeof preferences.organizeImportsIgnoreCase === "boolean") {
-        ignoreCaseForSorting = preferences.organizeImportsIgnoreCase;
-      } else if (existingSpecifiers) {
-        const targetImportSorting = ts_OrganizeImports_exports.detectImportSpecifierSorting(existingSpecifiers, preferences);
-        if (targetImportSorting !== 3 /* Both */) {
-          ignoreCaseForSorting = targetImportSorting === 2 /* CaseInsensitive */;
-        }
-      }
-      if (ignoreCaseForSorting === void 0) {
-        ignoreCaseForSorting = ts_OrganizeImports_exports.detectSorting(sourceFile, preferences) === 2 /* CaseInsensitive */;
-      }
-      const comparer = ts_OrganizeImports_exports.getOrganizeImportsComparer(preferences, ignoreCaseForSorting);
-      const newSpecifiers = stableSort(
-        namedImports.map((namedImport) => factory.createImportSpecifier(
-          (!clause.isTypeOnly || promoteFromTypeOnly2) && needsTypeOnly(namedImport),
-          /*propertyName*/
-          void 0,
-          factory.createIdentifier(namedImport.name)
-        )),
-        (s1, s2) => ts_OrganizeImports_exports.compareImportOrExportSpecifiers(s1, s2, comparer)
-      );
-      const specifierSort = (existingSpecifiers == null ? void 0 : existingSpecifiers.length) && ts_OrganizeImports_exports.detectImportSpecifierSorting(existingSpecifiers, preferences);
-      if (specifierSort && !(ignoreCaseForSorting && specifierSort === 1 /* CaseSensitive */)) {
-        for (const spec of newSpecifiers) {
-          const insertionIndex = promoteFromTypeOnly2 && !spec.isTypeOnly ? 0 : ts_OrganizeImports_exports.getImportSpecifierInsertionIndex(existingSpecifiers, spec, comparer);
-          changes.insertImportSpecifierAtIndex(sourceFile, spec, clause.namedBindings, insertionIndex);
-        }
-      } else if (existingSpecifiers == null ? void 0 : existingSpecifiers.length) {
-        for (const spec of newSpecifiers) {
-          changes.insertNodeInListAfter(sourceFile, last(existingSpecifiers), spec, existingSpecifiers);
-        }
-      } else {
-        if (newSpecifiers.length) {
-          const namedImports2 = factory.createNamedImports(newSpecifiers);
-          if (clause.namedBindings) {
-            changes.replaceNode(sourceFile, clause.namedBindings, namedImports2);
-          } else {
-            changes.insertNodeAfter(sourceFile, Debug.checkDefined(clause.name, "Import clause must have either named imports or a default import"), namedImports2);
-          }
-        }
-      }
-    }
-    if (promoteFromTypeOnly2) {
-      changes.delete(sourceFile, getTypeKeywordOfTypeOnlyImport(clause, sourceFile));
-      if (existingSpecifiers) {
-        for (const specifier of existingSpecifiers) {
-          changes.insertModifierBefore(sourceFile, 156 /* TypeKeyword */, specifier);
-        }
-      }
-    }
-    function addElementToBindingPattern(bindingPattern, name, propertyName) {
-      const element = factory.createBindingElement(
-        /*dotDotDotToken*/
-        void 0,
-        propertyName,
-        name
-      );
-      if (bindingPattern.elements.length) {
-        changes.insertNodeInListAfter(sourceFile, last(bindingPattern.elements), element);
-      } else {
-        changes.replaceNode(sourceFile, bindingPattern, factory.createObjectBindingPattern([element]));
-      }
-    }
-  }
-  function addNamespaceQualifier(changes, sourceFile, { namespacePrefix, usagePosition }) {
-    changes.insertText(sourceFile, usagePosition, namespacePrefix + ".");
-  }
-  function addImportType(changes, sourceFile, { moduleSpecifier, usagePosition: position }, quotePreference) {
-    changes.insertText(sourceFile, position, getImportTypePrefix(moduleSpecifier, quotePreference));
-  }
-  function getImportTypePrefix(moduleSpecifier, quotePreference) {
-    const quote2 = getQuoteFromPreference(quotePreference);
-    return `import(${quote2}${moduleSpecifier}${quote2}).`;
-  }
-  function needsTypeOnly({ addAsTypeOnly }) {
-    return addAsTypeOnly === 2 /* Required */;
-  }
-  function getNewImports(moduleSpecifier, quotePreference, defaultImport, namedImports, namespaceLikeImport, compilerOptions) {
-    const quotedModuleSpecifier = makeStringLiteral(moduleSpecifier, quotePreference);
-    let statements;
-    if (defaultImport !== void 0 || (namedImports == null ? void 0 : namedImports.length)) {
-      const topLevelTypeOnly = (!defaultImport || needsTypeOnly(defaultImport)) && every(namedImports, needsTypeOnly) || compilerOptions.verbatimModuleSyntax && (defaultImport == null ? void 0 : defaultImport.addAsTypeOnly) !== 4 /* NotAllowed */ && !some(namedImports, (i) => i.addAsTypeOnly === 4 /* NotAllowed */);
-      statements = combine(statements, makeImport(
-        defaultImport && factory.createIdentifier(defaultImport.name),
-        namedImports == null ? void 0 : namedImports.map(({ addAsTypeOnly, name }) => factory.createImportSpecifier(
-          !topLevelTypeOnly && addAsTypeOnly === 2 /* Required */,
-          /*propertyName*/
-          void 0,
-          factory.createIdentifier(name)
-        )),
-        moduleSpecifier,
-        quotePreference,
-        topLevelTypeOnly
-      ));
-    }
-    if (namespaceLikeImport) {
-      const declaration = namespaceLikeImport.importKind === 3 /* CommonJS */ ? factory.createImportEqualsDeclaration(
-        /*modifiers*/
-        void 0,
-        needsTypeOnly(namespaceLikeImport),
-        factory.createIdentifier(namespaceLikeImport.name),
-        factory.createExternalModuleReference(quotedModuleSpecifier)
-      ) : factory.createImportDeclaration(
-        /*modifiers*/
-        void 0,
-        factory.createImportClause(
-          needsTypeOnly(namespaceLikeImport),
-          /*name*/
-          void 0,
-          factory.createNamespaceImport(factory.createIdentifier(namespaceLikeImport.name))
-        ),
-        quotedModuleSpecifier,
-        /*assertClause*/
-        void 0
-      );
-      statements = combine(statements, declaration);
-    }
-    return Debug.checkDefined(statements);
-  }
-  function getNewRequires(moduleSpecifier, quotePreference, defaultImport, namedImports, namespaceLikeImport) {
-    const quotedModuleSpecifier = makeStringLiteral(moduleSpecifier, quotePreference);
-    let statements;
-    if (defaultImport || (namedImports == null ? void 0 : namedImports.length)) {
-      const bindingElements = (namedImports == null ? void 0 : namedImports.map(({ name }) => factory.createBindingElement(
-        /*dotDotDotToken*/
-        void 0,
-        /*propertyName*/
-        void 0,
-        name
-      ))) || [];
-      if (defaultImport) {
-        bindingElements.unshift(factory.createBindingElement(
-          /*dotDotDotToken*/
-          void 0,
-          "default",
-          defaultImport.name
-        ));
-      }
-      const declaration = createConstEqualsRequireDeclaration(factory.createObjectBindingPattern(bindingElements), quotedModuleSpecifier);
-      statements = combine(statements, declaration);
-    }
-    if (namespaceLikeImport) {
-      const declaration = createConstEqualsRequireDeclaration(namespaceLikeImport.name, quotedModuleSpecifier);
-      statements = combine(statements, declaration);
-    }
-    return Debug.checkDefined(statements);
-  }
-  function createConstEqualsRequireDeclaration(name, quotedModuleSpecifier) {
-    return factory.createVariableStatement(
-      /*modifiers*/
-      void 0,
-      factory.createVariableDeclarationList(
-        [
-          factory.createVariableDeclaration(
-            typeof name === "string" ? factory.createIdentifier(name) : name,
-            /*exclamationToken*/
-            void 0,
-            /*type*/
-            void 0,
-            factory.createCallExpression(
-              factory.createIdentifier("require"),
-              /*typeArguments*/
-              void 0,
-              [quotedModuleSpecifier]
-            )
-          )
-        ],
-        2 /* Const */
-      )
-    );
-  }
-  function symbolHasMeaning({ declarations }, meaning) {
-    return some(declarations, (decl) => !!(getMeaningFromDeclaration(decl) & meaning));
-  }
-  function moduleSymbolToValidIdentifier(moduleSymbol, target, forceCapitalize) {
-    return moduleSpecifierToValidIdentifier(removeFileExtension(stripQuotes(moduleSymbol.name)), target, forceCapitalize);
-  }
-  function moduleSpecifierToValidIdentifier(moduleSpecifier, target, forceCapitalize) {
-    const baseName = getBaseFileName(removeSuffix(moduleSpecifier, "/index"));
-    let res = "";
-    let lastCharWasValid = true;
-    const firstCharCode = baseName.charCodeAt(0);
-    if (isIdentifierStart(firstCharCode, target)) {
-      res += String.fromCharCode(firstCharCode);
-      if (forceCapitalize) {
-        res = res.toUpperCase();
-      }
-    } else {
-      lastCharWasValid = false;
-    }
-    for (let i = 1; i < baseName.length; i++) {
-      const ch = baseName.charCodeAt(i);
-      const isValid = isIdentifierPart(ch, target);
-      if (isValid) {
-        let char = String.fromCharCode(ch);
-        if (!lastCharWasValid) {
-          char = char.toUpperCase();
-        }
-        res += char;
-      }
-      lastCharWasValid = isValid;
-    }
-    return !isStringANonContextualKeyword(res) ? res || "_" : `_${res}`;
-  }
-  var importFixName, importFixId, errorCodes18;
-  var init_importFixes = __esm({
-    "src/services/codefixes/importFixes.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_codefix();
-      importFixName = "import";
-      importFixId = "fixMissingImport";
-      errorCodes18 = [
-        Diagnostics.Cannot_find_name_0.code,
-        Diagnostics.Cannot_find_name_0_Did_you_mean_1.code,
-        Diagnostics.Cannot_find_name_0_Did_you_mean_the_instance_member_this_0.code,
-        Diagnostics.Cannot_find_name_0_Did_you_mean_the_static_member_1_0.code,
-        Diagnostics.Cannot_find_namespace_0.code,
-        Diagnostics._0_refers_to_a_UMD_global_but_the_current_file_is_a_module_Consider_adding_an_import_instead.code,
-        Diagnostics._0_only_refers_to_a_type_but_is_being_used_as_a_value_here.code,
-        Diagnostics.No_value_exists_in_scope_for_the_shorthand_property_0_Either_declare_one_or_provide_an_initializer.code,
-        Diagnostics._0_cannot_be_used_as_a_value_because_it_was_imported_using_import_type.code
-      ];
-      registerCodeFix({
-        errorCodes: errorCodes18,
-        getCodeActions(context) {
-          const { errorCode, preferences, sourceFile, span, program } = context;
-          const info = getFixInfos(
-            context,
-            errorCode,
-            span.start,
-            /*useAutoImportProvider*/
-            true
-          );
-          if (!info)
-            return void 0;
-          return info.map(({ fix, symbolName: symbolName2, errorIdentifierText }) => codeActionForFix(
-            context,
-            sourceFile,
-            symbolName2,
-            fix,
-            /*includeSymbolNameInDescription*/
-            symbolName2 !== errorIdentifierText,
-            program.getCompilerOptions(),
-            preferences
-          ));
-        },
-        fixIds: [importFixId],
-        getAllCodeActions: (context) => {
-          const { sourceFile, program, preferences, host, cancellationToken } = context;
-          const importAdder = createImportAdderWorker(
-            sourceFile,
-            program,
-            /*useAutoImportProvider*/
-            true,
-            preferences,
-            host,
-            cancellationToken
-          );
-          eachDiagnostic(context, errorCodes18, (diag2) => importAdder.addImportFromDiagnostic(diag2, context));
-          return createCombinedCodeActions(ts_textChanges_exports.ChangeTracker.with(context, importAdder.writeFixes));
-        }
-      });
-    }
-  });
-
-  // src/services/codefixes/fixAddMissingConstraint.ts
-  function getInfo6(program, sourceFile, span) {
-    const diag2 = find(program.getSemanticDiagnostics(sourceFile), (diag3) => diag3.start === span.start && diag3.length === span.length);
-    if (diag2 === void 0 || diag2.relatedInformation === void 0)
-      return;
-    const related = find(diag2.relatedInformation, (related2) => related2.code === Diagnostics.This_type_parameter_might_need_an_extends_0_constraint.code);
-    if (related === void 0 || related.file === void 0 || related.start === void 0 || related.length === void 0)
-      return;
-    let declaration = findAncestorMatchingSpan(related.file, createTextSpan(related.start, related.length));
-    if (declaration === void 0)
-      return;
-    if (isIdentifier(declaration) && isTypeParameterDeclaration(declaration.parent)) {
-      declaration = declaration.parent;
-    }
-    if (isTypeParameterDeclaration(declaration)) {
-      if (isMappedTypeNode(declaration.parent))
-        return;
-      const token = getTokenAtPosition(sourceFile, span.start);
-      const checker = program.getTypeChecker();
-      const constraint = tryGetConstraintType(checker, token) || tryGetConstraintFromDiagnosticMessage(related.messageText);
-      return { constraint, declaration, token };
-    }
-    return void 0;
-  }
-  function addMissingConstraint(changes, program, preferences, host, sourceFile, info) {
-    const { declaration, constraint } = info;
-    const checker = program.getTypeChecker();
-    if (isString(constraint)) {
-      changes.insertText(sourceFile, declaration.name.end, ` extends ${constraint}`);
-    } else {
-      const scriptTarget = getEmitScriptTarget(program.getCompilerOptions());
-      const tracker = getNoopSymbolTrackerWithResolver({ program, host });
-      const importAdder = createImportAdder(sourceFile, program, preferences, host);
-      const typeNode = typeToAutoImportableTypeNode(
-        checker,
-        importAdder,
-        constraint,
-        /*contextNode*/
-        void 0,
-        scriptTarget,
-        /*flags*/
-        void 0,
-        tracker
-      );
-      if (typeNode) {
-        changes.replaceNode(sourceFile, declaration, factory.updateTypeParameterDeclaration(
-          declaration,
-          /*modifiers*/
-          void 0,
-          declaration.name,
-          typeNode,
-          declaration.default
-        ));
-        importAdder.writeFixes(changes);
-      }
-    }
-  }
-  function tryGetConstraintFromDiagnosticMessage(messageText) {
-    const [_, constraint] = flattenDiagnosticMessageText(messageText, "\n", 0).match(/`extends (.*)`/) || [];
-    return constraint;
-  }
-  function tryGetConstraintType(checker, node) {
-    if (isTypeNode(node.parent)) {
-      return checker.getTypeArgumentConstraint(node.parent);
-    }
-    const contextualType = isExpression(node) ? checker.getContextualType(node) : void 0;
-    return contextualType || checker.getTypeAtLocation(node);
-  }
-  var fixId17, errorCodes19;
-  var init_fixAddMissingConstraint = __esm({
-    "src/services/codefixes/fixAddMissingConstraint.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_codefix();
-      fixId17 = "addMissingConstraint";
-      errorCodes19 = [
-        // We want errors this could be attached to:
-        // Diagnostics.This_type_parameter_probably_needs_an_extends_0_constraint
-        Diagnostics.Type_0_is_not_comparable_to_type_1.code,
-        Diagnostics.Type_0_is_not_assignable_to_type_1_Two_different_types_with_this_name_exist_but_they_are_unrelated.code,
-        Diagnostics.Type_0_is_not_assignable_to_type_1_with_exactOptionalPropertyTypes_Colon_true_Consider_adding_undefined_to_the_types_of_the_target_s_properties.code,
-        Diagnostics.Type_0_is_not_assignable_to_type_1.code,
-        Diagnostics.Argument_of_type_0_is_not_assignable_to_parameter_of_type_1_with_exactOptionalPropertyTypes_Colon_true_Consider_adding_undefined_to_the_types_of_the_target_s_properties.code,
-        Diagnostics.Property_0_is_incompatible_with_index_signature.code,
-        Diagnostics.Property_0_in_type_1_is_not_assignable_to_type_2.code,
-        Diagnostics.Type_0_does_not_satisfy_the_constraint_1.code
-      ];
-      registerCodeFix({
-        errorCodes: errorCodes19,
-        getCodeActions(context) {
-          const { sourceFile, span, program, preferences, host } = context;
-          const info = getInfo6(program, sourceFile, span);
-          if (info === void 0)
-            return;
-          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => addMissingConstraint(t, program, preferences, host, sourceFile, info));
-          return [createCodeFixAction(fixId17, changes, Diagnostics.Add_extends_constraint, fixId17, Diagnostics.Add_extends_constraint_to_all_type_parameters)];
-        },
-        fixIds: [fixId17],
-        getAllCodeActions: (context) => {
-          const { program, preferences, host } = context;
-          const seen = /* @__PURE__ */ new Map();
-          return createCombinedCodeActions(ts_textChanges_exports.ChangeTracker.with(context, (changes) => {
-            eachDiagnostic(context, errorCodes19, (diag2) => {
-              const info = getInfo6(program, diag2.file, createTextSpan(diag2.start, diag2.length));
-              if (info) {
-                if (addToSeen(seen, getNodeId(info.declaration))) {
-                  return addMissingConstraint(changes, program, preferences, host, diag2.file, info);
-                }
-              }
-              return void 0;
-            });
-          }));
-        }
-      });
-    }
-  });
-
-  // src/services/codefixes/fixOverrideModifier.ts
-  function dispatchChanges(changeTracker, context, errorCode, pos) {
-    switch (errorCode) {
-      case Diagnostics.This_member_must_have_an_override_modifier_because_it_overrides_a_member_in_the_base_class_0.code:
-      case Diagnostics.This_member_must_have_a_JSDoc_comment_with_an_override_tag_because_it_overrides_a_member_in_the_base_class_0.code:
-      case Diagnostics.This_member_must_have_an_override_modifier_because_it_overrides_an_abstract_method_that_is_declared_in_the_base_class_0.code:
-      case Diagnostics.This_parameter_property_must_have_an_override_modifier_because_it_overrides_a_member_in_base_class_0.code:
-      case Diagnostics.This_parameter_property_must_have_a_JSDoc_comment_with_an_override_tag_because_it_overrides_a_member_in_the_base_class_0.code:
-        return doAddOverrideModifierChange(changeTracker, context.sourceFile, pos);
-      case Diagnostics.This_member_cannot_have_an_override_modifier_because_it_is_not_declared_in_the_base_class_0.code:
-      case Diagnostics.This_member_cannot_have_a_JSDoc_comment_with_an_override_tag_because_it_is_not_declared_in_the_base_class_0.code:
-      case Diagnostics.This_member_cannot_have_an_override_modifier_because_its_containing_class_0_does_not_extend_another_class.code:
-      case Diagnostics.This_member_cannot_have_a_JSDoc_comment_with_an_override_tag_because_its_containing_class_0_does_not_extend_another_class.code:
-        return doRemoveOverrideModifierChange(changeTracker, context.sourceFile, pos);
-      default:
-        Debug.fail("Unexpected error code: " + errorCode);
-    }
-  }
-  function doAddOverrideModifierChange(changeTracker, sourceFile, pos) {
-    const classElement = findContainerClassElementLike(sourceFile, pos);
-    if (isSourceFileJS(sourceFile)) {
-      changeTracker.addJSDocTags(sourceFile, classElement, [factory.createJSDocOverrideTag(factory.createIdentifier("override"))]);
-      return;
-    }
-    const modifiers = classElement.modifiers || emptyArray;
-    const staticModifier = find(modifiers, isStaticModifier);
-    const abstractModifier = find(modifiers, isAbstractModifier);
-    const accessibilityModifier = find(modifiers, (m) => isAccessibilityModifier(m.kind));
-    const lastDecorator = findLast(modifiers, isDecorator);
-    const modifierPos = abstractModifier ? abstractModifier.end : staticModifier ? staticModifier.end : accessibilityModifier ? accessibilityModifier.end : lastDecorator ? skipTrivia(sourceFile.text, lastDecorator.end) : classElement.getStart(sourceFile);
-    const options = accessibilityModifier || staticModifier || abstractModifier ? { prefix: " " } : { suffix: " " };
-    changeTracker.insertModifierAt(sourceFile, modifierPos, 163 /* OverrideKeyword */, options);
-  }
-  function doRemoveOverrideModifierChange(changeTracker, sourceFile, pos) {
-    const classElement = findContainerClassElementLike(sourceFile, pos);
-    if (isSourceFileJS(sourceFile)) {
-      changeTracker.filterJSDocTags(sourceFile, classElement, not(isJSDocOverrideTag));
-      return;
-    }
-    const overrideModifier = find(classElement.modifiers, isOverrideModifier);
-    Debug.assertIsDefined(overrideModifier);
-    changeTracker.deleteModifier(sourceFile, overrideModifier);
-  }
-  function isClassElementLikeHasJSDoc(node) {
-    switch (node.kind) {
-      case 175 /* Constructor */:
-      case 171 /* PropertyDeclaration */:
-      case 173 /* MethodDeclaration */:
-      case 176 /* GetAccessor */:
-      case 177 /* SetAccessor */:
-        return true;
-      case 168 /* Parameter */:
-        return isParameterPropertyDeclaration(node, node.parent);
-      default:
-        return false;
-    }
-  }
-  function findContainerClassElementLike(sourceFile, pos) {
-    const token = getTokenAtPosition(sourceFile, pos);
-    const classElement = findAncestor(token, (node) => {
-      if (isClassLike(node))
-        return "quit";
-      return isClassElementLikeHasJSDoc(node);
-    });
-    Debug.assert(classElement && isClassElementLikeHasJSDoc(classElement));
-    return classElement;
-  }
-  var fixName, fixAddOverrideId, fixRemoveOverrideId, errorCodes20, errorCodeFixIdMap;
-  var init_fixOverrideModifier = __esm({
-    "src/services/codefixes/fixOverrideModifier.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_codefix();
-      fixName = "fixOverrideModifier";
-      fixAddOverrideId = "fixAddOverrideModifier";
-      fixRemoveOverrideId = "fixRemoveOverrideModifier";
-      errorCodes20 = [
-        Diagnostics.This_member_cannot_have_an_override_modifier_because_it_is_not_declared_in_the_base_class_0.code,
-        Diagnostics.This_member_cannot_have_an_override_modifier_because_its_containing_class_0_does_not_extend_another_class.code,
-        Diagnostics.This_member_must_have_an_override_modifier_because_it_overrides_an_abstract_method_that_is_declared_in_the_base_class_0.code,
-        Diagnostics.This_member_must_have_an_override_modifier_because_it_overrides_a_member_in_the_base_class_0.code,
-        Diagnostics.This_parameter_property_must_have_an_override_modifier_because_it_overrides_a_member_in_base_class_0.code,
-        Diagnostics.This_member_must_have_a_JSDoc_comment_with_an_override_tag_because_it_overrides_a_member_in_the_base_class_0.code,
-        Diagnostics.This_member_cannot_have_a_JSDoc_comment_with_an_override_tag_because_its_containing_class_0_does_not_extend_another_class.code,
-        Diagnostics.This_parameter_property_must_have_a_JSDoc_comment_with_an_override_tag_because_it_overrides_a_member_in_the_base_class_0.code,
-        Diagnostics.This_member_cannot_have_a_JSDoc_comment_with_an_override_tag_because_it_is_not_declared_in_the_base_class_0.code
-      ];
-      errorCodeFixIdMap = {
-        // case #1:
-        [Diagnostics.This_member_must_have_an_override_modifier_because_it_overrides_a_member_in_the_base_class_0.code]: {
-          descriptions: Diagnostics.Add_override_modifier,
-          fixId: fixAddOverrideId,
-          fixAllDescriptions: Diagnostics.Add_all_missing_override_modifiers
-        },
-        [Diagnostics.This_member_must_have_a_JSDoc_comment_with_an_override_tag_because_it_overrides_a_member_in_the_base_class_0.code]: {
-          descriptions: Diagnostics.Add_override_modifier,
-          fixId: fixAddOverrideId,
-          fixAllDescriptions: Diagnostics.Add_all_missing_override_modifiers
-        },
-        // case #2:
-        [Diagnostics.This_member_cannot_have_an_override_modifier_because_its_containing_class_0_does_not_extend_another_class.code]: {
-          descriptions: Diagnostics.Remove_override_modifier,
-          fixId: fixRemoveOverrideId,
-          fixAllDescriptions: Diagnostics.Remove_all_unnecessary_override_modifiers
-        },
-        [Diagnostics.This_member_cannot_have_a_JSDoc_comment_with_an_override_tag_because_its_containing_class_0_does_not_extend_another_class.code]: {
-          descriptions: Diagnostics.Remove_override_modifier,
-          fixId: fixRemoveOverrideId,
-          fixAllDescriptions: Diagnostics.Remove_override_modifier
-        },
-        // case #3:
-        [Diagnostics.This_parameter_property_must_have_an_override_modifier_because_it_overrides_a_member_in_base_class_0.code]: {
-          descriptions: Diagnostics.Add_override_modifier,
-          fixId: fixAddOverrideId,
-          fixAllDescriptions: Diagnostics.Add_all_missing_override_modifiers
-        },
-        [Diagnostics.This_parameter_property_must_have_a_JSDoc_comment_with_an_override_tag_because_it_overrides_a_member_in_the_base_class_0.code]: {
-          descriptions: Diagnostics.Add_override_modifier,
-          fixId: fixAddOverrideId,
-          fixAllDescriptions: Diagnostics.Add_all_missing_override_modifiers
-        },
-        // case #4:
-        [Diagnostics.This_member_must_have_an_override_modifier_because_it_overrides_an_abstract_method_that_is_declared_in_the_base_class_0.code]: {
-          descriptions: Diagnostics.Add_override_modifier,
-          fixId: fixAddOverrideId,
-          fixAllDescriptions: Diagnostics.Remove_all_unnecessary_override_modifiers
-        },
-        // case #5:
-        [Diagnostics.This_member_cannot_have_an_override_modifier_because_it_is_not_declared_in_the_base_class_0.code]: {
-          descriptions: Diagnostics.Remove_override_modifier,
-          fixId: fixRemoveOverrideId,
-          fixAllDescriptions: Diagnostics.Remove_all_unnecessary_override_modifiers
-        },
-        [Diagnostics.This_member_cannot_have_a_JSDoc_comment_with_an_override_tag_because_it_is_not_declared_in_the_base_class_0.code]: {
-          descriptions: Diagnostics.Remove_override_modifier,
-          fixId: fixRemoveOverrideId,
-          fixAllDescriptions: Diagnostics.Remove_all_unnecessary_override_modifiers
-        }
-      };
-      registerCodeFix({
-        errorCodes: errorCodes20,
-        getCodeActions: function getCodeActionsToFixOverrideModifierIssues(context) {
-          const { errorCode, span } = context;
-          const info = errorCodeFixIdMap[errorCode];
-          if (!info)
-            return emptyArray;
-          const { descriptions, fixId: fixId52, fixAllDescriptions } = info;
-          const changes = ts_textChanges_exports.ChangeTracker.with(context, (changes2) => dispatchChanges(changes2, context, errorCode, span.start));
-          return [
-            createCodeFixActionMaybeFixAll(fixName, changes, descriptions, fixId52, fixAllDescriptions)
-          ];
-        },
-        fixIds: [fixName, fixAddOverrideId, fixRemoveOverrideId],
-        getAllCodeActions: (context) => codeFixAll(context, errorCodes20, (changes, diag2) => {
-          const { code, start } = diag2;
-          const info = errorCodeFixIdMap[code];
-          if (!info || info.fixId !== context.fixId) {
-            return;
-          }
-          dispatchChanges(changes, context, code, start);
-        })
-      });
-    }
-  });
-
-  // src/services/codefixes/fixNoPropertyAccessFromIndexSignature.ts
-  function doChange14(changes, sourceFile, node, preferences) {
-    const quotePreference = getQuotePreference(sourceFile, preferences);
-    const argumentsExpression = factory.createStringLiteral(node.name.text, quotePreference === 0 /* Single */);
-    changes.replaceNode(
-      sourceFile,
-      node,
-      isPropertyAccessChain(node) ? factory.createElementAccessChain(node.expression, node.questionDotToken, argumentsExpression) : factory.createElementAccessExpression(node.expression, argumentsExpression)
-    );
-  }
-  function getPropertyAccessExpression(sourceFile, pos) {
-    return cast(getTokenAtPosition(sourceFile, pos).parent, isPropertyAccessExpression);
-  }
-  var fixId18, errorCodes21;
-  var init_fixNoPropertyAccessFromIndexSignature = __esm({
-    "src/services/codefixes/fixNoPropertyAccessFromIndexSignature.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_codefix();
-      fixId18 = "fixNoPropertyAccessFromIndexSignature";
-      errorCodes21 = [
-        Diagnostics.Property_0_comes_from_an_index_signature_so_it_must_be_accessed_with_0.code
-      ];
-      registerCodeFix({
-        errorCodes: errorCodes21,
-        fixIds: [fixId18],
-        getCodeActions(context) {
-          const { sourceFile, span, preferences } = context;
-          const property = getPropertyAccessExpression(sourceFile, span.start);
-          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange14(t, context.sourceFile, property, preferences));
-          return [createCodeFixAction(fixId18, changes, [Diagnostics.Use_element_access_for_0, property.name.text], fixId18, Diagnostics.Use_element_access_for_all_undeclared_properties)];
-        },
-        getAllCodeActions: (context) => codeFixAll(context, errorCodes21, (changes, diag2) => doChange14(changes, diag2.file, getPropertyAccessExpression(diag2.file, diag2.start), context.preferences))
-      });
-    }
-  });
-
-  // src/services/codefixes/fixImplicitThis.ts
-  function doChange15(changes, sourceFile, pos, checker) {
-    const token = getTokenAtPosition(sourceFile, pos);
-    if (!isThis(token))
-      return void 0;
-    const fn = getThisContainer(
-      token,
-      /*includeArrowFunctions*/
-      false,
-      /*includeClassComputedPropertyName*/
-      false
-    );
-    if (!isFunctionDeclaration(fn) && !isFunctionExpression(fn))
-      return void 0;
-    if (!isSourceFile(getThisContainer(
-      fn,
-      /*includeArrowFunctions*/
-      false,
-      /*includeClassComputedPropertyName*/
-      false
-    ))) {
-      const fnKeyword = Debug.checkDefined(findChildOfKind(fn, 100 /* FunctionKeyword */, sourceFile));
-      const { name } = fn;
-      const body = Debug.checkDefined(fn.body);
-      if (isFunctionExpression(fn)) {
-        if (name && ts_FindAllReferences_exports.Core.isSymbolReferencedInFile(name, checker, sourceFile, body)) {
-          return void 0;
-        }
-        changes.delete(sourceFile, fnKeyword);
-        if (name) {
-          changes.delete(sourceFile, name);
-        }
-        changes.insertText(sourceFile, body.pos, " =>");
-        return [Diagnostics.Convert_function_expression_0_to_arrow_function, name ? name.text : ANONYMOUS];
-      } else {
-        changes.replaceNode(sourceFile, fnKeyword, factory.createToken(87 /* ConstKeyword */));
-        changes.insertText(sourceFile, name.end, " = ");
-        changes.insertText(sourceFile, body.pos, " =>");
-        return [Diagnostics.Convert_function_declaration_0_to_arrow_function, name.text];
-      }
-    }
-  }
-  var fixId19, errorCodes22;
-  var init_fixImplicitThis = __esm({
-    "src/services/codefixes/fixImplicitThis.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_codefix();
-      fixId19 = "fixImplicitThis";
-      errorCodes22 = [Diagnostics.this_implicitly_has_type_any_because_it_does_not_have_a_type_annotation.code];
-      registerCodeFix({
-        errorCodes: errorCodes22,
-        getCodeActions: function getCodeActionsToFixImplicitThis(context) {
-          const { sourceFile, program, span } = context;
-          let diagnostic;
-          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => {
-            diagnostic = doChange15(t, sourceFile, span.start, program.getTypeChecker());
-          });
-          return diagnostic ? [createCodeFixAction(fixId19, changes, diagnostic, fixId19, Diagnostics.Fix_all_implicit_this_errors)] : emptyArray;
-        },
-        fixIds: [fixId19],
-        getAllCodeActions: (context) => codeFixAll(context, errorCodes22, (changes, diag2) => {
-          doChange15(changes, diag2.file, diag2.start, context.program.getTypeChecker());
-        })
-      });
-    }
-  });
-
-  // src/services/codefixes/fixImportNonExportedMember.ts
-  function getInfo7(sourceFile, pos, program) {
-    var _a;
-    const token = getTokenAtPosition(sourceFile, pos);
-    if (isIdentifier(token)) {
-      const importDeclaration = findAncestor(token, isImportDeclaration);
-      if (importDeclaration === void 0)
-        return void 0;
-      const moduleSpecifier = isStringLiteral(importDeclaration.moduleSpecifier) ? importDeclaration.moduleSpecifier.text : void 0;
-      if (moduleSpecifier === void 0)
-        return void 0;
-      const resolvedModule = getResolvedModule(
-        sourceFile,
-        moduleSpecifier,
-        /*mode*/
-        void 0
-      );
-      if (resolvedModule === void 0)
-        return void 0;
-      const moduleSourceFile = program.getSourceFile(resolvedModule.resolvedFileName);
-      if (moduleSourceFile === void 0 || isSourceFileFromLibrary(program, moduleSourceFile))
-        return void 0;
-      const moduleSymbol = moduleSourceFile.symbol;
-      const locals = (_a = tryCast(moduleSymbol.valueDeclaration, canHaveLocals)) == null ? void 0 : _a.locals;
-      if (locals === void 0)
-        return void 0;
-      const localSymbol = locals.get(token.escapedText);
-      if (localSymbol === void 0)
-        return void 0;
-      const node = getNodeOfSymbol(localSymbol);
-      if (node === void 0)
-        return void 0;
-      const exportName = { node: token, isTypeOnly: isTypeDeclaration(node) };
-      return { exportName, node, moduleSourceFile, moduleSpecifier };
-    }
-    return void 0;
-  }
-  function doChange16(changes, program, { exportName, node, moduleSourceFile }) {
-    const exportDeclaration = tryGetExportDeclaration(moduleSourceFile, exportName.isTypeOnly);
-    if (exportDeclaration) {
-      updateExport(changes, program, moduleSourceFile, exportDeclaration, [exportName]);
-    } else if (canHaveExportModifier(node)) {
-      changes.insertExportModifier(moduleSourceFile, node);
-    } else {
-      createExport(changes, program, moduleSourceFile, [exportName]);
-    }
-  }
-  function doChanges(changes, program, sourceFile, moduleExports, node) {
-    if (length(moduleExports)) {
-      if (node) {
-        updateExport(changes, program, sourceFile, node, moduleExports);
-      } else {
-        createExport(changes, program, sourceFile, moduleExports);
-      }
-    }
-  }
-  function tryGetExportDeclaration(sourceFile, isTypeOnly) {
-    const predicate = (node) => isExportDeclaration(node) && (isTypeOnly && node.isTypeOnly || !node.isTypeOnly);
-    return findLast(sourceFile.statements, predicate);
-  }
-  function updateExport(changes, program, sourceFile, node, names) {
-    const namedExports = node.exportClause && isNamedExports(node.exportClause) ? node.exportClause.elements : factory.createNodeArray([]);
-    const allowTypeModifier = !node.isTypeOnly && !!(getIsolatedModules(program.getCompilerOptions()) || find(namedExports, (e) => e.isTypeOnly));
-    changes.replaceNode(
-      sourceFile,
-      node,
-      factory.updateExportDeclaration(
-        node,
-        node.modifiers,
-        node.isTypeOnly,
-        factory.createNamedExports(
-          factory.createNodeArray(
-            [...namedExports, ...createExportSpecifiers(names, allowTypeModifier)],
-            /*hasTrailingComma*/
-            namedExports.hasTrailingComma
-          )
-        ),
-        node.moduleSpecifier,
-        node.assertClause
-      )
-    );
-  }
-  function createExport(changes, program, sourceFile, names) {
-    changes.insertNodeAtEndOfScope(
-      sourceFile,
-      sourceFile,
-      factory.createExportDeclaration(
-        /*modifiers*/
-        void 0,
-        /*isTypeOnly*/
-        false,
-        factory.createNamedExports(createExportSpecifiers(
-          names,
-          /*allowTypeModifier*/
-          getIsolatedModules(program.getCompilerOptions())
-        )),
-        /*moduleSpecifier*/
-        void 0,
-        /*assertClause*/
-        void 0
-      )
-    );
-  }
-  function createExportSpecifiers(names, allowTypeModifier) {
-    return factory.createNodeArray(map(names, (n) => factory.createExportSpecifier(
-      allowTypeModifier && n.isTypeOnly,
-      /*propertyName*/
-      void 0,
-      n.node
-    )));
-  }
-  function getNodeOfSymbol(symbol) {
-    if (symbol.valueDeclaration === void 0) {
-      return firstOrUndefined(symbol.declarations);
-    }
-    const declaration = symbol.valueDeclaration;
-    const variableStatement = isVariableDeclaration(declaration) ? tryCast(declaration.parent.parent, isVariableStatement) : void 0;
-    return variableStatement && length(variableStatement.declarationList.declarations) === 1 ? variableStatement : declaration;
-  }
-  var fixId20, errorCodes23;
-  var init_fixImportNonExportedMember = __esm({
-    "src/services/codefixes/fixImportNonExportedMember.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_codefix();
-      fixId20 = "fixImportNonExportedMember";
-      errorCodes23 = [
-        Diagnostics.Module_0_declares_1_locally_but_it_is_not_exported.code
-      ];
-      registerCodeFix({
-        errorCodes: errorCodes23,
-        fixIds: [fixId20],
-        getCodeActions(context) {
-          const { sourceFile, span, program } = context;
-          const info = getInfo7(sourceFile, span.start, program);
-          if (info === void 0)
-            return void 0;
-          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange16(t, program, info));
-          return [createCodeFixAction(fixId20, changes, [Diagnostics.Export_0_from_module_1, info.exportName.node.text, info.moduleSpecifier], fixId20, Diagnostics.Export_all_referenced_locals)];
-        },
-        getAllCodeActions(context) {
-          const { program } = context;
-          return createCombinedCodeActions(ts_textChanges_exports.ChangeTracker.with(context, (changes) => {
-            const exports = /* @__PURE__ */ new Map();
-            eachDiagnostic(context, errorCodes23, (diag2) => {
-              const info = getInfo7(diag2.file, diag2.start, program);
-              if (info === void 0)
-                return void 0;
-              const { exportName, node, moduleSourceFile } = info;
-              if (tryGetExportDeclaration(moduleSourceFile, exportName.isTypeOnly) === void 0 && canHaveExportModifier(node)) {
-                changes.insertExportModifier(moduleSourceFile, node);
-              } else {
-                const moduleExports = exports.get(moduleSourceFile) || { typeOnlyExports: [], exports: [] };
-                if (exportName.isTypeOnly) {
-                  moduleExports.typeOnlyExports.push(exportName);
-                } else {
-                  moduleExports.exports.push(exportName);
-                }
-                exports.set(moduleSourceFile, moduleExports);
-              }
-            });
-            exports.forEach((moduleExports, moduleSourceFile) => {
-              const exportDeclaration = tryGetExportDeclaration(
-                moduleSourceFile,
-                /*isTypeOnly*/
-                true
-              );
-              if (exportDeclaration && exportDeclaration.isTypeOnly) {
-                doChanges(changes, program, moduleSourceFile, moduleExports.typeOnlyExports, exportDeclaration);
-                doChanges(changes, program, moduleSourceFile, moduleExports.exports, tryGetExportDeclaration(
-                  moduleSourceFile,
-                  /*isTypeOnly*/
-                  false
-                ));
-              } else {
-                doChanges(changes, program, moduleSourceFile, [...moduleExports.exports, ...moduleExports.typeOnlyExports], exportDeclaration);
-              }
-            });
-          }));
-        }
-      });
-    }
-  });
-
-  // src/services/codefixes/fixIncorrectNamedTupleSyntax.ts
-  function getNamedTupleMember(sourceFile, pos) {
-    const token = getTokenAtPosition(sourceFile, pos);
-    return findAncestor(token, (t) => t.kind === 201 /* NamedTupleMember */);
-  }
-  function doChange17(changes, sourceFile, namedTupleMember) {
-    if (!namedTupleMember) {
-      return;
-    }
-    let unwrappedType = namedTupleMember.type;
-    let sawOptional = false;
-    let sawRest = false;
-    while (unwrappedType.kind === 189 /* OptionalType */ || unwrappedType.kind === 190 /* RestType */ || unwrappedType.kind === 195 /* ParenthesizedType */) {
-      if (unwrappedType.kind === 189 /* OptionalType */) {
-        sawOptional = true;
-      } else if (unwrappedType.kind === 190 /* RestType */) {
-        sawRest = true;
-      }
-      unwrappedType = unwrappedType.type;
-    }
-    const updated = factory.updateNamedTupleMember(
-      namedTupleMember,
-      namedTupleMember.dotDotDotToken || (sawRest ? factory.createToken(26 /* DotDotDotToken */) : void 0),
-      namedTupleMember.name,
-      namedTupleMember.questionToken || (sawOptional ? factory.createToken(58 /* QuestionToken */) : void 0),
-      unwrappedType
-    );
-    if (updated === namedTupleMember) {
-      return;
-    }
-    changes.replaceNode(sourceFile, namedTupleMember, updated);
-  }
-  var fixId21, errorCodes24;
-  var init_fixIncorrectNamedTupleSyntax = __esm({
-    "src/services/codefixes/fixIncorrectNamedTupleSyntax.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_codefix();
-      fixId21 = "fixIncorrectNamedTupleSyntax";
-      errorCodes24 = [
-        Diagnostics.A_labeled_tuple_element_is_declared_as_optional_with_a_question_mark_after_the_name_and_before_the_colon_rather_than_after_the_type.code,
-        Diagnostics.A_labeled_tuple_element_is_declared_as_rest_with_a_before_the_name_rather_than_before_the_type.code
-      ];
-      registerCodeFix({
-        errorCodes: errorCodes24,
-        getCodeActions: function getCodeActionsToFixIncorrectNamedTupleSyntax(context) {
-          const { sourceFile, span } = context;
-          const namedTupleMember = getNamedTupleMember(sourceFile, span.start);
-          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange17(t, sourceFile, namedTupleMember));
-          return [createCodeFixAction(fixId21, changes, Diagnostics.Move_labeled_tuple_element_modifiers_to_labels, fixId21, Diagnostics.Move_labeled_tuple_element_modifiers_to_labels)];
-        },
-        fixIds: [fixId21]
-      });
-    }
-  });
-
-  // src/services/codefixes/fixSpelling.ts
-  function getInfo8(sourceFile, pos, context, errorCode) {
-    const node = getTokenAtPosition(sourceFile, pos);
-    const parent2 = node.parent;
-    if ((errorCode === Diagnostics.No_overload_matches_this_call.code || errorCode === Diagnostics.Type_0_is_not_assignable_to_type_1.code) && !isJsxAttribute(parent2))
-      return void 0;
-    const checker = context.program.getTypeChecker();
-    let suggestedSymbol;
-    if (isPropertyAccessExpression(parent2) && parent2.name === node) {
-      Debug.assert(isMemberName(node), "Expected an identifier for spelling (property access)");
-      let containingType = checker.getTypeAtLocation(parent2.expression);
-      if (parent2.flags & 32 /* OptionalChain */) {
-        containingType = checker.getNonNullableType(containingType);
-      }
-      suggestedSymbol = checker.getSuggestedSymbolForNonexistentProperty(node, containingType);
-    } else if (isBinaryExpression(parent2) && parent2.operatorToken.kind === 103 /* InKeyword */ && parent2.left === node && isPrivateIdentifier(node)) {
-      const receiverType = checker.getTypeAtLocation(parent2.right);
-      suggestedSymbol = checker.getSuggestedSymbolForNonexistentProperty(node, receiverType);
-    } else if (isQualifiedName(parent2) && parent2.right === node) {
-      const symbol = checker.getSymbolAtLocation(parent2.left);
-      if (symbol && symbol.flags & 1536 /* Module */) {
-        suggestedSymbol = checker.getSuggestedSymbolForNonexistentModule(parent2.right, symbol);
-      }
-    } else if (isImportSpecifier(parent2) && parent2.name === node) {
-      Debug.assertNode(node, isIdentifier, "Expected an identifier for spelling (import)");
-      const importDeclaration = findAncestor(node, isImportDeclaration);
-      const resolvedSourceFile = getResolvedSourceFileFromImportDeclaration(sourceFile, context, importDeclaration);
-      if (resolvedSourceFile && resolvedSourceFile.symbol) {
-        suggestedSymbol = checker.getSuggestedSymbolForNonexistentModule(node, resolvedSourceFile.symbol);
-      }
-    } else if (isJsxAttribute(parent2) && parent2.name === node) {
-      Debug.assertNode(node, isIdentifier, "Expected an identifier for JSX attribute");
-      const tag = findAncestor(node, isJsxOpeningLikeElement);
-      const props = checker.getContextualTypeForArgumentAtIndex(tag, 0);
-      suggestedSymbol = checker.getSuggestedSymbolForNonexistentJSXAttribute(node, props);
-    } else if (hasSyntacticModifier(parent2, 16384 /* Override */) && isClassElement(parent2) && parent2.name === node) {
-      const baseDeclaration = findAncestor(node, isClassLike);
-      const baseTypeNode = baseDeclaration ? getEffectiveBaseTypeNode(baseDeclaration) : void 0;
-      const baseType = baseTypeNode ? checker.getTypeAtLocation(baseTypeNode) : void 0;
-      if (baseType) {
-        suggestedSymbol = checker.getSuggestedSymbolForNonexistentClassMember(getTextOfNode(node), baseType);
-      }
-    } else {
-      const meaning = getMeaningFromLocation(node);
-      const name = getTextOfNode(node);
-      Debug.assert(name !== void 0, "name should be defined");
-      suggestedSymbol = checker.getSuggestedSymbolForNonexistentSymbol(node, name, convertSemanticMeaningToSymbolFlags(meaning));
-    }
-    return suggestedSymbol === void 0 ? void 0 : { node, suggestedSymbol };
-  }
-  function doChange18(changes, sourceFile, node, suggestedSymbol, target) {
-    const suggestion = symbolName(suggestedSymbol);
-    if (!isIdentifierText(suggestion, target) && isPropertyAccessExpression(node.parent)) {
-      const valDecl = suggestedSymbol.valueDeclaration;
-      if (valDecl && isNamedDeclaration(valDecl) && isPrivateIdentifier(valDecl.name)) {
-        changes.replaceNode(sourceFile, node, factory.createIdentifier(suggestion));
-      } else {
-        changes.replaceNode(sourceFile, node.parent, factory.createElementAccessExpression(node.parent.expression, factory.createStringLiteral(suggestion)));
-      }
-    } else {
-      changes.replaceNode(sourceFile, node, factory.createIdentifier(suggestion));
-    }
-  }
-  function convertSemanticMeaningToSymbolFlags(meaning) {
-    let flags = 0;
-    if (meaning & 4 /* Namespace */) {
-      flags |= 1920 /* Namespace */;
-    }
-    if (meaning & 2 /* Type */) {
-      flags |= 788968 /* Type */;
-    }
-    if (meaning & 1 /* Value */) {
-      flags |= 111551 /* Value */;
-    }
-    return flags;
-  }
-  function getResolvedSourceFileFromImportDeclaration(sourceFile, context, importDeclaration) {
-    if (!importDeclaration || !isStringLiteralLike(importDeclaration.moduleSpecifier))
-      return void 0;
-    const resolvedModule = getResolvedModule(sourceFile, importDeclaration.moduleSpecifier.text, getModeForUsageLocation(sourceFile, importDeclaration.moduleSpecifier));
-    if (!resolvedModule)
-      return void 0;
-    return context.program.getSourceFile(resolvedModule.resolvedFileName);
-  }
-  var fixId22, errorCodes25;
-  var init_fixSpelling = __esm({
-    "src/services/codefixes/fixSpelling.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_codefix();
-      fixId22 = "fixSpelling";
-      errorCodes25 = [
-        Diagnostics.Property_0_does_not_exist_on_type_1_Did_you_mean_2.code,
-        Diagnostics.Property_0_may_not_exist_on_type_1_Did_you_mean_2.code,
-        Diagnostics.Cannot_find_name_0_Did_you_mean_1.code,
-        Diagnostics.Could_not_find_name_0_Did_you_mean_1.code,
-        Diagnostics.Cannot_find_namespace_0_Did_you_mean_1.code,
-        Diagnostics.Cannot_find_name_0_Did_you_mean_the_instance_member_this_0.code,
-        Diagnostics.Cannot_find_name_0_Did_you_mean_the_static_member_1_0.code,
-        Diagnostics._0_has_no_exported_member_named_1_Did_you_mean_2.code,
-        Diagnostics.This_member_cannot_have_an_override_modifier_because_it_is_not_declared_in_the_base_class_0_Did_you_mean_1.code,
-        Diagnostics.This_member_cannot_have_a_JSDoc_comment_with_an_override_tag_because_it_is_not_declared_in_the_base_class_0_Did_you_mean_1.code,
-        // for JSX class components
-        Diagnostics.No_overload_matches_this_call.code,
-        // for JSX FC
-        Diagnostics.Type_0_is_not_assignable_to_type_1.code
-      ];
-      registerCodeFix({
-        errorCodes: errorCodes25,
-        getCodeActions(context) {
-          const { sourceFile, errorCode } = context;
-          const info = getInfo8(sourceFile, context.span.start, context, errorCode);
-          if (!info)
-            return void 0;
-          const { node, suggestedSymbol } = info;
-          const target = getEmitScriptTarget(context.host.getCompilationSettings());
-          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange18(t, sourceFile, node, suggestedSymbol, target));
-          return [createCodeFixAction("spelling", changes, [Diagnostics.Change_spelling_to_0, symbolName(suggestedSymbol)], fixId22, Diagnostics.Fix_all_detected_spelling_errors)];
-        },
-        fixIds: [fixId22],
-        getAllCodeActions: (context) => codeFixAll(context, errorCodes25, (changes, diag2) => {
-          const info = getInfo8(diag2.file, diag2.start, context, diag2.code);
-          const target = getEmitScriptTarget(context.host.getCompilationSettings());
-          if (info)
-            doChange18(changes, context.sourceFile, info.node, info.suggestedSymbol, target);
-        })
-      });
-    }
-  });
-
-  // src/services/codefixes/returnValueCorrect.ts
-  function createObjectTypeFromLabeledExpression(checker, label, expression) {
-    const member = checker.createSymbol(4 /* Property */, label.escapedText);
-    member.links.type = checker.getTypeAtLocation(expression);
-    const members = createSymbolTable([member]);
-    return checker.createAnonymousType(
-      /*symbol*/
-      void 0,
-      members,
-      [],
-      [],
-      []
-    );
-  }
-  function getFixInfo(checker, declaration, expectType, isFunctionType) {
-    if (!declaration.body || !isBlock(declaration.body) || length(declaration.body.statements) !== 1)
-      return void 0;
-    const firstStatement = first(declaration.body.statements);
-    if (isExpressionStatement(firstStatement) && checkFixedAssignableTo(checker, declaration, checker.getTypeAtLocation(firstStatement.expression), expectType, isFunctionType)) {
-      return {
-        declaration,
-        kind: 0 /* MissingReturnStatement */,
-        expression: firstStatement.expression,
-        statement: firstStatement,
-        commentSource: firstStatement.expression
-      };
-    } else if (isLabeledStatement(firstStatement) && isExpressionStatement(firstStatement.statement)) {
-      const node = factory.createObjectLiteralExpression([factory.createPropertyAssignment(firstStatement.label, firstStatement.statement.expression)]);
-      const nodeType = createObjectTypeFromLabeledExpression(checker, firstStatement.label, firstStatement.statement.expression);
-      if (checkFixedAssignableTo(checker, declaration, nodeType, expectType, isFunctionType)) {
-        return isArrowFunction(declaration) ? {
-          declaration,
-          kind: 1 /* MissingParentheses */,
-          expression: node,
-          statement: firstStatement,
-          commentSource: firstStatement.statement.expression
-        } : {
-          declaration,
-          kind: 0 /* MissingReturnStatement */,
-          expression: node,
-          statement: firstStatement,
-          commentSource: firstStatement.statement.expression
-        };
-      }
-    } else if (isBlock(firstStatement) && length(firstStatement.statements) === 1) {
-      const firstBlockStatement = first(firstStatement.statements);
-      if (isLabeledStatement(firstBlockStatement) && isExpressionStatement(firstBlockStatement.statement)) {
-        const node = factory.createObjectLiteralExpression([factory.createPropertyAssignment(firstBlockStatement.label, firstBlockStatement.statement.expression)]);
-        const nodeType = createObjectTypeFromLabeledExpression(checker, firstBlockStatement.label, firstBlockStatement.statement.expression);
-        if (checkFixedAssignableTo(checker, declaration, nodeType, expectType, isFunctionType)) {
-          return {
-            declaration,
-            kind: 0 /* MissingReturnStatement */,
-            expression: node,
-            statement: firstStatement,
-            commentSource: firstBlockStatement
-          };
-        }
-      }
-    }
-    return void 0;
-  }
-  function checkFixedAssignableTo(checker, declaration, exprType, type, isFunctionType) {
-    if (isFunctionType) {
-      const sig = checker.getSignatureFromDeclaration(declaration);
-      if (sig) {
-        if (hasSyntacticModifier(declaration, 512 /* Async */)) {
-          exprType = checker.createPromiseType(exprType);
-        }
-        const newSig = checker.createSignature(
-          declaration,
-          sig.typeParameters,
-          sig.thisParameter,
-          sig.parameters,
-          exprType,
-          /*typePredicate*/
-          void 0,
-          sig.minArgumentCount,
-          sig.flags
-        );
-        exprType = checker.createAnonymousType(
-          /*symbol*/
-          void 0,
-          createSymbolTable(),
-          [newSig],
-          [],
-          []
-        );
-      } else {
-        exprType = checker.getAnyType();
-      }
-    }
-    return checker.isTypeAssignableTo(exprType, type);
-  }
-  function getInfo9(checker, sourceFile, position, errorCode) {
-    const node = getTokenAtPosition(sourceFile, position);
-    if (!node.parent)
-      return void 0;
-    const declaration = findAncestor(node.parent, isFunctionLikeDeclaration);
-    switch (errorCode) {
-      case Diagnostics.A_function_whose_declared_type_is_neither_undefined_void_nor_any_must_return_a_value.code:
-        if (!declaration || !declaration.body || !declaration.type || !rangeContainsRange(declaration.type, node))
-          return void 0;
-        return getFixInfo(
-          checker,
-          declaration,
-          checker.getTypeFromTypeNode(declaration.type),
-          /*isFunctionType*/
-          false
-        );
-      case Diagnostics.Argument_of_type_0_is_not_assignable_to_parameter_of_type_1.code:
-        if (!declaration || !isCallExpression(declaration.parent) || !declaration.body)
-          return void 0;
-        const pos = declaration.parent.arguments.indexOf(declaration);
-        const type = checker.getContextualTypeForArgumentAtIndex(declaration.parent, pos);
-        if (!type)
-          return void 0;
-        return getFixInfo(
-          checker,
-          declaration,
-          type,
-          /*isFunctionType*/
-          true
-        );
-      case Diagnostics.Type_0_is_not_assignable_to_type_1.code:
-        if (!isDeclarationName(node) || !isVariableLike(node.parent) && !isJsxAttribute(node.parent))
-          return void 0;
-        const initializer = getVariableLikeInitializer(node.parent);
-        if (!initializer || !isFunctionLikeDeclaration(initializer) || !initializer.body)
-          return void 0;
-        return getFixInfo(
-          checker,
-          initializer,
-          checker.getTypeAtLocation(node.parent),
-          /*isFunctionType*/
-          true
-        );
-    }
-    return void 0;
-  }
-  function getVariableLikeInitializer(declaration) {
-    switch (declaration.kind) {
-      case 259 /* VariableDeclaration */:
-      case 168 /* Parameter */:
-      case 207 /* BindingElement */:
-      case 171 /* PropertyDeclaration */:
-      case 302 /* PropertyAssignment */:
-        return declaration.initializer;
-      case 290 /* JsxAttribute */:
-        return declaration.initializer && (isJsxExpression(declaration.initializer) ? declaration.initializer.expression : void 0);
-      case 303 /* ShorthandPropertyAssignment */:
-      case 170 /* PropertySignature */:
-      case 305 /* EnumMember */:
-      case 354 /* JSDocPropertyTag */:
-      case 347 /* JSDocParameterTag */:
-        return void 0;
-    }
-  }
-  function addReturnStatement(changes, sourceFile, expression, statement) {
-    suppressLeadingAndTrailingTrivia(expression);
-    const probablyNeedSemi = probablyUsesSemicolons(sourceFile);
-    changes.replaceNode(sourceFile, statement, factory.createReturnStatement(expression), {
-      leadingTriviaOption: ts_textChanges_exports.LeadingTriviaOption.Exclude,
-      trailingTriviaOption: ts_textChanges_exports.TrailingTriviaOption.Exclude,
-      suffix: probablyNeedSemi ? ";" : void 0
-    });
-  }
-  function removeBlockBodyBrace(changes, sourceFile, declaration, expression, commentSource, withParen) {
-    const newBody = withParen || needsParentheses(expression) ? factory.createParenthesizedExpression(expression) : expression;
-    suppressLeadingAndTrailingTrivia(commentSource);
-    copyComments(commentSource, newBody);
-    changes.replaceNode(sourceFile, declaration.body, newBody);
-  }
-  function wrapBlockWithParen(changes, sourceFile, declaration, expression) {
-    changes.replaceNode(sourceFile, declaration.body, factory.createParenthesizedExpression(expression));
-  }
-  function getActionForfixAddReturnStatement(context, expression, statement) {
-    const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => addReturnStatement(t, context.sourceFile, expression, statement));
-    return createCodeFixAction(fixId23, changes, Diagnostics.Add_a_return_statement, fixIdAddReturnStatement, Diagnostics.Add_all_missing_return_statement);
-  }
-  function getActionForFixRemoveBracesFromArrowFunctionBody(context, declaration, expression, commentSource) {
-    const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => removeBlockBodyBrace(
-      t,
-      context.sourceFile,
-      declaration,
-      expression,
-      commentSource,
-      /*withParen*/
-      false
-    ));
-    return createCodeFixAction(fixId23, changes, Diagnostics.Remove_braces_from_arrow_function_body, fixRemoveBracesFromArrowFunctionBody, Diagnostics.Remove_braces_from_all_arrow_function_bodies_with_relevant_issues);
-  }
-  function getActionForfixWrapTheBlockWithParen(context, declaration, expression) {
-    const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => wrapBlockWithParen(t, context.sourceFile, declaration, expression));
-    return createCodeFixAction(fixId23, changes, Diagnostics.Wrap_the_following_body_with_parentheses_which_should_be_an_object_literal, fixIdWrapTheBlockWithParen, Diagnostics.Wrap_all_object_literal_with_parentheses);
-  }
-  var fixId23, fixIdAddReturnStatement, fixRemoveBracesFromArrowFunctionBody, fixIdWrapTheBlockWithParen, errorCodes26;
-  var init_returnValueCorrect = __esm({
-    "src/services/codefixes/returnValueCorrect.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_codefix();
-      fixId23 = "returnValueCorrect";
-      fixIdAddReturnStatement = "fixAddReturnStatement";
-      fixRemoveBracesFromArrowFunctionBody = "fixRemoveBracesFromArrowFunctionBody";
-      fixIdWrapTheBlockWithParen = "fixWrapTheBlockWithParen";
-      errorCodes26 = [
-        Diagnostics.A_function_whose_declared_type_is_neither_undefined_void_nor_any_must_return_a_value.code,
-        Diagnostics.Type_0_is_not_assignable_to_type_1.code,
-        Diagnostics.Argument_of_type_0_is_not_assignable_to_parameter_of_type_1.code
-      ];
-      registerCodeFix({
-        errorCodes: errorCodes26,
-        fixIds: [fixIdAddReturnStatement, fixRemoveBracesFromArrowFunctionBody, fixIdWrapTheBlockWithParen],
-        getCodeActions: function getCodeActionsToCorrectReturnValue(context) {
-          const { program, sourceFile, span: { start }, errorCode } = context;
-          const info = getInfo9(program.getTypeChecker(), sourceFile, start, errorCode);
-          if (!info)
-            return void 0;
-          if (info.kind === 0 /* MissingReturnStatement */) {
-            return append(
-              [getActionForfixAddReturnStatement(context, info.expression, info.statement)],
-              isArrowFunction(info.declaration) ? getActionForFixRemoveBracesFromArrowFunctionBody(context, info.declaration, info.expression, info.commentSource) : void 0
-            );
-          } else {
-            return [getActionForfixWrapTheBlockWithParen(context, info.declaration, info.expression)];
-          }
-        },
-        getAllCodeActions: (context) => codeFixAll(context, errorCodes26, (changes, diag2) => {
-          const info = getInfo9(context.program.getTypeChecker(), diag2.file, diag2.start, diag2.code);
-          if (!info)
-            return void 0;
-          switch (context.fixId) {
-            case fixIdAddReturnStatement:
-              addReturnStatement(changes, diag2.file, info.expression, info.statement);
-              break;
-            case fixRemoveBracesFromArrowFunctionBody:
-              if (!isArrowFunction(info.declaration))
-                return void 0;
-              removeBlockBodyBrace(
-                changes,
-                diag2.file,
-                info.declaration,
-                info.expression,
-                info.commentSource,
-                /*withParen*/
-                false
-              );
-              break;
-            case fixIdWrapTheBlockWithParen:
-              if (!isArrowFunction(info.declaration))
-                return void 0;
-              wrapBlockWithParen(changes, diag2.file, info.declaration, info.expression);
-              break;
-            default:
-              Debug.fail(JSON.stringify(context.fixId));
-          }
-        })
-      });
-    }
-  });
-
-  // src/services/codefixes/fixAddMissingMember.ts
-  function getInfo10(sourceFile, tokenPos, errorCode, checker, program) {
-    var _a;
-    const token = getTokenAtPosition(sourceFile, tokenPos);
-    const parent2 = token.parent;
-    if (errorCode === Diagnostics.Argument_of_type_0_is_not_assignable_to_parameter_of_type_1.code) {
-      if (!(token.kind === 19 /* OpenBraceToken */ && isObjectLiteralExpression(parent2) && isCallExpression(parent2.parent)))
-        return void 0;
-      const argIndex = findIndex(parent2.parent.arguments, (arg) => arg === parent2);
-      if (argIndex < 0)
-        return void 0;
-      const signature = checker.getResolvedSignature(parent2.parent);
-      if (!(signature && signature.declaration && signature.parameters[argIndex]))
-        return void 0;
-      const param = signature.parameters[argIndex].valueDeclaration;
-      if (!(param && isParameter(param) && isIdentifier(param.name)))
-        return void 0;
-      const properties = arrayFrom(checker.getUnmatchedProperties(
-        checker.getTypeAtLocation(parent2),
-        checker.getParameterType(signature, argIndex),
-        /*requireOptionalProperties*/
-        false,
-        /*matchDiscriminantProperties*/
-        false
-      ));
-      if (!length(properties))
-        return void 0;
-      return { kind: 3 /* ObjectLiteral */, token: param.name, properties, parentDeclaration: parent2 };
-    }
-    if (!isMemberName(token))
-      return void 0;
-    if (isIdentifier(token) && hasInitializer(parent2) && parent2.initializer && isObjectLiteralExpression(parent2.initializer)) {
-      const targetType = checker.getContextualType(token) || checker.getTypeAtLocation(token);
-      const properties = arrayFrom(checker.getUnmatchedProperties(
-        checker.getTypeAtLocation(parent2.initializer),
-        targetType,
-        /*requireOptionalProperties*/
-        false,
-        /*matchDiscriminantProperties*/
-        false
-      ));
-      if (!length(properties))
-        return void 0;
-      return { kind: 3 /* ObjectLiteral */, token, properties, parentDeclaration: parent2.initializer };
-    }
-    if (isIdentifier(token) && isJsxOpeningLikeElement(token.parent)) {
-      const target = getEmitScriptTarget(program.getCompilerOptions());
-      const attributes = getUnmatchedAttributes(checker, target, token.parent);
-      if (!length(attributes))
-        return void 0;
-      return { kind: 4 /* JsxAttributes */, token, attributes, parentDeclaration: token.parent };
-    }
-    if (isIdentifier(token)) {
-      const type = (_a = checker.getContextualType(token)) == null ? void 0 : _a.getNonNullableType();
-      if (type && getObjectFlags(type) & 16 /* Anonymous */) {
-        const signature = firstOrUndefined(checker.getSignaturesOfType(type, 0 /* Call */));
-        if (signature === void 0)
-          return void 0;
-        return { kind: 5 /* Signature */, token, signature, sourceFile, parentDeclaration: findScope(token) };
-      }
-      if (isCallExpression(parent2) && parent2.expression === token) {
-        return { kind: 2 /* Function */, token, call: parent2, sourceFile, modifierFlags: 0 /* None */, parentDeclaration: findScope(token) };
-      }
-    }
-    if (!isPropertyAccessExpression(parent2))
-      return void 0;
-    const leftExpressionType = skipConstraint(checker.getTypeAtLocation(parent2.expression));
-    const symbol = leftExpressionType.symbol;
-    if (!symbol || !symbol.declarations)
-      return void 0;
-    if (isIdentifier(token) && isCallExpression(parent2.parent)) {
-      const moduleDeclaration = find(symbol.declarations, isModuleDeclaration);
-      const moduleDeclarationSourceFile = moduleDeclaration == null ? void 0 : moduleDeclaration.getSourceFile();
-      if (moduleDeclaration && moduleDeclarationSourceFile && !isSourceFileFromLibrary(program, moduleDeclarationSourceFile)) {
-        return { kind: 2 /* Function */, token, call: parent2.parent, sourceFile, modifierFlags: 1 /* Export */, parentDeclaration: moduleDeclaration };
-      }
-      const moduleSourceFile = find(symbol.declarations, isSourceFile);
-      if (sourceFile.commonJsModuleIndicator)
-        return void 0;
-      if (moduleSourceFile && !isSourceFileFromLibrary(program, moduleSourceFile)) {
-        return { kind: 2 /* Function */, token, call: parent2.parent, sourceFile: moduleSourceFile, modifierFlags: 1 /* Export */, parentDeclaration: moduleSourceFile };
-      }
-    }
-    const classDeclaration = find(symbol.declarations, isClassLike);
-    if (!classDeclaration && isPrivateIdentifier(token))
-      return void 0;
-    const declaration = classDeclaration || find(symbol.declarations, (d) => isInterfaceDeclaration(d) || isTypeLiteralNode(d));
-    if (declaration && !isSourceFileFromLibrary(program, declaration.getSourceFile())) {
-      const makeStatic = !isTypeLiteralNode(declaration) && (leftExpressionType.target || leftExpressionType) !== checker.getDeclaredTypeOfSymbol(symbol);
-      if (makeStatic && (isPrivateIdentifier(token) || isInterfaceDeclaration(declaration)))
-        return void 0;
-      const declSourceFile = declaration.getSourceFile();
-      const modifierFlags = isTypeLiteralNode(declaration) ? 0 /* None */ : (makeStatic ? 32 /* Static */ : 0 /* None */) | (startsWithUnderscore(token.text) ? 8 /* Private */ : 0 /* None */);
-      const isJSFile = isSourceFileJS(declSourceFile);
-      const call = tryCast(parent2.parent, isCallExpression);
-      return { kind: 0 /* TypeLikeDeclaration */, token, call, modifierFlags, parentDeclaration: declaration, declSourceFile, isJSFile };
-    }
-    const enumDeclaration = find(symbol.declarations, isEnumDeclaration);
-    if (enumDeclaration && !(leftExpressionType.flags & 1056 /* EnumLike */) && !isPrivateIdentifier(token) && !isSourceFileFromLibrary(program, enumDeclaration.getSourceFile())) {
-      return { kind: 1 /* Enum */, token, parentDeclaration: enumDeclaration };
-    }
-    return void 0;
-  }
-  function getActionsForMissingMemberDeclaration(context, info) {
-    return info.isJSFile ? singleElementArray(createActionForAddMissingMemberInJavascriptFile(context, info)) : createActionsForAddMissingMemberInTypeScriptFile(context, info);
-  }
-  function createActionForAddMissingMemberInJavascriptFile(context, { parentDeclaration, declSourceFile, modifierFlags, token }) {
-    if (isInterfaceDeclaration(parentDeclaration) || isTypeLiteralNode(parentDeclaration)) {
-      return void 0;
-    }
-    const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => addMissingMemberInJs(t, declSourceFile, parentDeclaration, token, !!(modifierFlags & 32 /* Static */)));
-    if (changes.length === 0) {
-      return void 0;
-    }
-    const diagnostic = modifierFlags & 32 /* Static */ ? Diagnostics.Initialize_static_property_0 : isPrivateIdentifier(token) ? Diagnostics.Declare_a_private_field_named_0 : Diagnostics.Initialize_property_0_in_the_constructor;
-    return createCodeFixAction(fixMissingMember, changes, [diagnostic, token.text], fixMissingMember, Diagnostics.Add_all_missing_members);
-  }
-  function addMissingMemberInJs(changeTracker, sourceFile, classDeclaration, token, makeStatic) {
-    const tokenName = token.text;
-    if (makeStatic) {
-      if (classDeclaration.kind === 230 /* ClassExpression */) {
-        return;
-      }
-      const className = classDeclaration.name.getText();
-      const staticInitialization = initializePropertyToUndefined(factory.createIdentifier(className), tokenName);
-      changeTracker.insertNodeAfter(sourceFile, classDeclaration, staticInitialization);
-    } else if (isPrivateIdentifier(token)) {
-      const property = factory.createPropertyDeclaration(
-        /*modifiers*/
-        void 0,
-        tokenName,
-        /*questionOrExclamationToken*/
-        void 0,
-        /*type*/
-        void 0,
-        /*initializer*/
-        void 0
-      );
-      const lastProp = getNodeToInsertPropertyAfter(classDeclaration);
-      if (lastProp) {
-        changeTracker.insertNodeAfter(sourceFile, lastProp, property);
-      } else {
-        changeTracker.insertMemberAtStart(sourceFile, classDeclaration, property);
-      }
-    } else {
-      const classConstructor = getFirstConstructorWithBody(classDeclaration);
-      if (!classConstructor) {
-        return;
-      }
-      const propertyInitialization = initializePropertyToUndefined(factory.createThis(), tokenName);
-      changeTracker.insertNodeAtConstructorEnd(sourceFile, classConstructor, propertyInitialization);
-    }
-  }
-  function initializePropertyToUndefined(obj, propertyName) {
-    return factory.createExpressionStatement(factory.createAssignment(factory.createPropertyAccessExpression(obj, propertyName), createUndefined()));
-  }
-  function createActionsForAddMissingMemberInTypeScriptFile(context, { parentDeclaration, declSourceFile, modifierFlags, token }) {
-    const memberName = token.text;
-    const isStatic2 = modifierFlags & 32 /* Static */;
-    const typeNode = getTypeNode2(context.program.getTypeChecker(), parentDeclaration, token);
-    const addPropertyDeclarationChanges = (modifierFlags2) => ts_textChanges_exports.ChangeTracker.with(context, (t) => addPropertyDeclaration(t, declSourceFile, parentDeclaration, memberName, typeNode, modifierFlags2));
-    const actions2 = [createCodeFixAction(fixMissingMember, addPropertyDeclarationChanges(modifierFlags & 32 /* Static */), [isStatic2 ? Diagnostics.Declare_static_property_0 : Diagnostics.Declare_property_0, memberName], fixMissingMember, Diagnostics.Add_all_missing_members)];
-    if (isStatic2 || isPrivateIdentifier(token)) {
-      return actions2;
-    }
-    if (modifierFlags & 8 /* Private */) {
-      actions2.unshift(createCodeFixActionWithoutFixAll(fixMissingMember, addPropertyDeclarationChanges(8 /* Private */), [Diagnostics.Declare_private_property_0, memberName]));
-    }
-    actions2.push(createAddIndexSignatureAction(context, declSourceFile, parentDeclaration, token.text, typeNode));
-    return actions2;
-  }
-  function getTypeNode2(checker, node, token) {
-    let typeNode;
-    if (token.parent.parent.kind === 225 /* BinaryExpression */) {
-      const binaryExpression = token.parent.parent;
-      const otherExpression = token.parent === binaryExpression.left ? binaryExpression.right : binaryExpression.left;
-      const widenedType = checker.getWidenedType(checker.getBaseTypeOfLiteralType(checker.getTypeAtLocation(otherExpression)));
-      typeNode = checker.typeToTypeNode(widenedType, node, 1 /* NoTruncation */);
-    } else {
-      const contextualType = checker.getContextualType(token.parent);
-      typeNode = contextualType ? checker.typeToTypeNode(
-        contextualType,
-        /*enclosingDeclaration*/
-        void 0,
-        1 /* NoTruncation */
-      ) : void 0;
-    }
-    return typeNode || factory.createKeywordTypeNode(133 /* AnyKeyword */);
-  }
-  function addPropertyDeclaration(changeTracker, sourceFile, node, tokenName, typeNode, modifierFlags) {
-    const modifiers = modifierFlags ? factory.createNodeArray(factory.createModifiersFromModifierFlags(modifierFlags)) : void 0;
-    const property = isClassLike(node) ? factory.createPropertyDeclaration(
-      modifiers,
-      tokenName,
-      /*questionOrExclamationToken*/
-      void 0,
-      typeNode,
-      /*initializer*/
-      void 0
-    ) : factory.createPropertySignature(
-      /*modifiers*/
-      void 0,
-      tokenName,
-      /*questionToken*/
-      void 0,
-      typeNode
-    );
-    const lastProp = getNodeToInsertPropertyAfter(node);
-    if (lastProp) {
-      changeTracker.insertNodeAfter(sourceFile, lastProp, property);
-    } else {
-      changeTracker.insertMemberAtStart(sourceFile, node, property);
-    }
-  }
-  function getNodeToInsertPropertyAfter(node) {
-    let res;
-    for (const member of node.members) {
-      if (!isPropertyDeclaration(member))
-        break;
-      res = member;
-    }
-    return res;
-  }
-  function createAddIndexSignatureAction(context, sourceFile, node, tokenName, typeNode) {
-    const stringTypeNode = factory.createKeywordTypeNode(154 /* StringKeyword */);
-    const indexingParameter = factory.createParameterDeclaration(
-      /*modifiers*/
-      void 0,
-      /*dotDotDotToken*/
-      void 0,
-      "x",
-      /*questionToken*/
-      void 0,
-      stringTypeNode,
-      /*initializer*/
-      void 0
-    );
-    const indexSignature = factory.createIndexSignature(
-      /*modifiers*/
-      void 0,
-      [indexingParameter],
-      typeNode
-    );
-    const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => t.insertMemberAtStart(sourceFile, node, indexSignature));
-    return createCodeFixActionWithoutFixAll(fixMissingMember, changes, [Diagnostics.Add_index_signature_for_property_0, tokenName]);
-  }
-  function getActionsForMissingMethodDeclaration(context, info) {
-    const { parentDeclaration, declSourceFile, modifierFlags, token, call } = info;
-    if (call === void 0) {
-      return void 0;
-    }
-    if (isPrivateIdentifier(token)) {
-      return void 0;
-    }
-    const methodName = token.text;
-    const addMethodDeclarationChanges = (modifierFlags2) => ts_textChanges_exports.ChangeTracker.with(context, (t) => addMethodDeclaration(context, t, call, token, modifierFlags2, parentDeclaration, declSourceFile));
-    const actions2 = [createCodeFixAction(fixMissingMember, addMethodDeclarationChanges(modifierFlags & 32 /* Static */), [modifierFlags & 32 /* Static */ ? Diagnostics.Declare_static_method_0 : Diagnostics.Declare_method_0, methodName], fixMissingMember, Diagnostics.Add_all_missing_members)];
-    if (modifierFlags & 8 /* Private */) {
-      actions2.unshift(createCodeFixActionWithoutFixAll(fixMissingMember, addMethodDeclarationChanges(8 /* Private */), [Diagnostics.Declare_private_method_0, methodName]));
-    }
-    return actions2;
-  }
-  function addMethodDeclaration(context, changes, callExpression, name, modifierFlags, parentDeclaration, sourceFile) {
-    const importAdder = createImportAdder(sourceFile, context.program, context.preferences, context.host);
-    const kind = isClassLike(parentDeclaration) ? 173 /* MethodDeclaration */ : 172 /* MethodSignature */;
-    const signatureDeclaration = createSignatureDeclarationFromCallExpression(kind, context, importAdder, callExpression, name, modifierFlags, parentDeclaration);
-    const containingMethodDeclaration = tryGetContainingMethodDeclaration(parentDeclaration, callExpression);
-    if (containingMethodDeclaration) {
-      changes.insertNodeAfter(sourceFile, containingMethodDeclaration, signatureDeclaration);
-    } else {
-      changes.insertMemberAtStart(sourceFile, parentDeclaration, signatureDeclaration);
-    }
-    importAdder.writeFixes(changes);
-  }
-  function addEnumMemberDeclaration(changes, checker, { token, parentDeclaration }) {
-    const hasStringInitializer = some(parentDeclaration.members, (member) => {
-      const type = checker.getTypeAtLocation(member);
-      return !!(type && type.flags & 402653316 /* StringLike */);
-    });
-    const enumMember = factory.createEnumMember(token, hasStringInitializer ? factory.createStringLiteral(token.text) : void 0);
-    changes.replaceNode(parentDeclaration.getSourceFile(), parentDeclaration, factory.updateEnumDeclaration(
-      parentDeclaration,
-      parentDeclaration.modifiers,
-      parentDeclaration.name,
-      concatenate(parentDeclaration.members, singleElementArray(enumMember))
-    ), {
-      leadingTriviaOption: ts_textChanges_exports.LeadingTriviaOption.IncludeAll,
-      trailingTriviaOption: ts_textChanges_exports.TrailingTriviaOption.Exclude
-    });
-  }
-  function addFunctionDeclaration(changes, context, info) {
-    const quotePreference = getQuotePreference(context.sourceFile, context.preferences);
-    const importAdder = createImportAdder(context.sourceFile, context.program, context.preferences, context.host);
-    const functionDeclaration = info.kind === 2 /* Function */ ? createSignatureDeclarationFromCallExpression(261 /* FunctionDeclaration */, context, importAdder, info.call, idText(info.token), info.modifierFlags, info.parentDeclaration) : createSignatureDeclarationFromSignature(
-      261 /* FunctionDeclaration */,
-      context,
-      quotePreference,
-      info.signature,
-      createStubbedBody(Diagnostics.Function_not_implemented.message, quotePreference),
-      info.token,
-      /*modifiers*/
-      void 0,
-      /*optional*/
-      void 0,
-      /*enclosingDeclaration*/
-      void 0,
-      importAdder
-    );
-    if (functionDeclaration === void 0) {
-      Debug.fail("fixMissingFunctionDeclaration codefix got unexpected error.");
-    }
-    isReturnStatement(info.parentDeclaration) ? changes.insertNodeBefore(
-      info.sourceFile,
-      info.parentDeclaration,
-      functionDeclaration,
-      /*blankLineBetween*/
-      true
-    ) : changes.insertNodeAtEndOfScope(info.sourceFile, info.parentDeclaration, functionDeclaration);
-    importAdder.writeFixes(changes);
-  }
-  function addJsxAttributes(changes, context, info) {
-    const importAdder = createImportAdder(context.sourceFile, context.program, context.preferences, context.host);
-    const quotePreference = getQuotePreference(context.sourceFile, context.preferences);
-    const checker = context.program.getTypeChecker();
-    const jsxAttributesNode = info.parentDeclaration.attributes;
-    const hasSpreadAttribute = some(jsxAttributesNode.properties, isJsxSpreadAttribute);
-    const attrs = map(info.attributes, (attr) => {
-      const value = tryGetValueFromType(context, checker, importAdder, quotePreference, checker.getTypeOfSymbol(attr), info.parentDeclaration);
-      const name = factory.createIdentifier(attr.name);
-      const jsxAttribute = factory.createJsxAttribute(name, factory.createJsxExpression(
-        /*dotDotDotToken*/
-        void 0,
-        value
-      ));
-      setParent(name, jsxAttribute);
-      return jsxAttribute;
-    });
-    const jsxAttributes = factory.createJsxAttributes(hasSpreadAttribute ? [...attrs, ...jsxAttributesNode.properties] : [...jsxAttributesNode.properties, ...attrs]);
-    const options = { prefix: jsxAttributesNode.pos === jsxAttributesNode.end ? " " : void 0 };
-    changes.replaceNode(context.sourceFile, jsxAttributesNode, jsxAttributes, options);
-    importAdder.writeFixes(changes);
-  }
-  function addObjectLiteralProperties(changes, context, info) {
-    const importAdder = createImportAdder(context.sourceFile, context.program, context.preferences, context.host);
-    const quotePreference = getQuotePreference(context.sourceFile, context.preferences);
-    const target = getEmitScriptTarget(context.program.getCompilerOptions());
-    const checker = context.program.getTypeChecker();
-    const props = map(info.properties, (prop) => {
-      const initializer = tryGetValueFromType(context, checker, importAdder, quotePreference, checker.getTypeOfSymbol(prop), info.parentDeclaration);
-      return factory.createPropertyAssignment(createPropertyNameFromSymbol(prop, target, quotePreference, checker), initializer);
-    });
-    const options = {
-      leadingTriviaOption: ts_textChanges_exports.LeadingTriviaOption.Exclude,
-      trailingTriviaOption: ts_textChanges_exports.TrailingTriviaOption.Exclude,
-      indentation: info.indentation
-    };
-    changes.replaceNode(context.sourceFile, info.parentDeclaration, factory.createObjectLiteralExpression(
-      [...info.parentDeclaration.properties, ...props],
-      /*multiLine*/
-      true
-    ), options);
-    importAdder.writeFixes(changes);
-  }
-  function tryGetValueFromType(context, checker, importAdder, quotePreference, type, enclosingDeclaration) {
-    if (type.flags & 3 /* AnyOrUnknown */) {
-      return createUndefined();
-    }
-    if (type.flags & (4 /* String */ | 134217728 /* TemplateLiteral */)) {
-      return factory.createStringLiteral(
-        "",
-        /* isSingleQuote */
-        quotePreference === 0 /* Single */
-      );
-    }
-    if (type.flags & 8 /* Number */) {
-      return factory.createNumericLiteral(0);
-    }
-    if (type.flags & 64 /* BigInt */) {
-      return factory.createBigIntLiteral("0n");
-    }
-    if (type.flags & 16 /* Boolean */) {
-      return factory.createFalse();
-    }
-    if (type.flags & 1056 /* EnumLike */) {
-      const enumMember = type.symbol.exports ? firstOrUndefinedIterator(type.symbol.exports.values()) : type.symbol;
-      const name = checker.symbolToExpression(
-        type.symbol.parent ? type.symbol.parent : type.symbol,
-        111551 /* Value */,
-        /*enclosingDeclaration*/
-        void 0,
-        /*flags*/
-        void 0
-      );
-      return enumMember === void 0 || name === void 0 ? factory.createNumericLiteral(0) : factory.createPropertyAccessExpression(name, checker.symbolToString(enumMember));
-    }
-    if (type.flags & 256 /* NumberLiteral */) {
-      return factory.createNumericLiteral(type.value);
-    }
-    if (type.flags & 2048 /* BigIntLiteral */) {
-      return factory.createBigIntLiteral(type.value);
-    }
-    if (type.flags & 128 /* StringLiteral */) {
-      return factory.createStringLiteral(
-        type.value,
-        /* isSingleQuote */
-        quotePreference === 0 /* Single */
-      );
-    }
-    if (type.flags & 512 /* BooleanLiteral */) {
-      return type === checker.getFalseType() || type === checker.getFalseType(
-        /*fresh*/
-        true
-      ) ? factory.createFalse() : factory.createTrue();
-    }
-    if (type.flags & 65536 /* Null */) {
-      return factory.createNull();
-    }
-    if (type.flags & 1048576 /* Union */) {
-      const expression = firstDefined(type.types, (t) => tryGetValueFromType(context, checker, importAdder, quotePreference, t, enclosingDeclaration));
-      return expression ?? createUndefined();
-    }
-    if (checker.isArrayLikeType(type)) {
-      return factory.createArrayLiteralExpression();
-    }
-    if (isObjectLiteralType(type)) {
-      const props = map(checker.getPropertiesOfType(type), (prop) => {
-        const initializer = tryGetValueFromType(context, checker, importAdder, quotePreference, checker.getTypeOfSymbol(prop), enclosingDeclaration);
-        return factory.createPropertyAssignment(prop.name, initializer);
-      });
-      return factory.createObjectLiteralExpression(
-        props,
-        /*multiLine*/
-        true
-      );
-    }
-    if (getObjectFlags(type) & 16 /* Anonymous */) {
-      const decl = find(type.symbol.declarations || emptyArray, or(isFunctionTypeNode, isMethodSignature, isMethodDeclaration));
-      if (decl === void 0)
-        return createUndefined();
-      const signature = checker.getSignaturesOfType(type, 0 /* Call */);
-      if (signature === void 0)
-        return createUndefined();
-      const func = createSignatureDeclarationFromSignature(
-        217 /* FunctionExpression */,
-        context,
-        quotePreference,
-        signature[0],
-        createStubbedBody(Diagnostics.Function_not_implemented.message, quotePreference),
-        /*name*/
-        void 0,
-        /*modifiers*/
-        void 0,
-        /*optional*/
-        void 0,
-        /*enclosingDeclaration*/
-        enclosingDeclaration,
-        importAdder
-      );
-      return func ?? createUndefined();
-    }
-    if (getObjectFlags(type) & 1 /* Class */) {
-      const classDeclaration = getClassLikeDeclarationOfSymbol(type.symbol);
-      if (classDeclaration === void 0 || hasAbstractModifier(classDeclaration))
-        return createUndefined();
-      const constructorDeclaration = getFirstConstructorWithBody(classDeclaration);
-      if (constructorDeclaration && length(constructorDeclaration.parameters))
-        return createUndefined();
-      return factory.createNewExpression(
-        factory.createIdentifier(type.symbol.name),
-        /*typeArguments*/
-        void 0,
-        /*argumentsArray*/
-        void 0
-      );
-    }
-    return createUndefined();
-  }
-  function createUndefined() {
-    return factory.createIdentifier("undefined");
-  }
-  function isObjectLiteralType(type) {
-    return type.flags & 524288 /* Object */ && (getObjectFlags(type) & 128 /* ObjectLiteral */ || type.symbol && tryCast(singleOrUndefined(type.symbol.declarations), isTypeLiteralNode));
-  }
-  function getUnmatchedAttributes(checker, target, source) {
-    const attrsType = checker.getContextualType(source.attributes);
-    if (attrsType === void 0)
-      return emptyArray;
-    const targetProps = attrsType.getProperties();
-    if (!length(targetProps))
-      return emptyArray;
-    const seenNames = /* @__PURE__ */ new Set();
-    for (const sourceProp of source.attributes.properties) {
-      if (isJsxAttribute(sourceProp)) {
-        seenNames.add(getEscapedTextOfJsxAttributeName(sourceProp.name));
-      }
-      if (isJsxSpreadAttribute(sourceProp)) {
-        const type = checker.getTypeAtLocation(sourceProp.expression);
-        for (const prop of type.getProperties()) {
-          seenNames.add(prop.escapedName);
-        }
-      }
-    }
-    return filter(targetProps, (targetProp) => isIdentifierText(targetProp.name, target, 1 /* JSX */) && !(targetProp.flags & 16777216 /* Optional */ || getCheckFlags(targetProp) & 48 /* Partial */ || seenNames.has(targetProp.escapedName)));
-  }
-  function tryGetContainingMethodDeclaration(node, callExpression) {
-    if (isTypeLiteralNode(node)) {
-      return void 0;
-    }
-    const declaration = findAncestor(callExpression, (n) => isMethodDeclaration(n) || isConstructorDeclaration(n));
-    return declaration && declaration.parent === node ? declaration : void 0;
-  }
-  function createPropertyNameFromSymbol(symbol, target, quotePreference, checker) {
-    if (isTransientSymbol(symbol)) {
-      const prop = checker.symbolToNode(
-        symbol,
-        111551 /* Value */,
-        /*enclosingDeclaration*/
-        void 0,
-        1073741824 /* WriteComputedProps */
-      );
-      if (prop && isComputedPropertyName(prop))
-        return prop;
-    }
-    return createPropertyNameNodeForIdentifierOrLiteral(symbol.name, target, quotePreference === 0 /* Single */);
-  }
-  function findScope(node) {
-    if (findAncestor(node, isJsxExpression)) {
-      const returnStatement = findAncestor(node.parent, isReturnStatement);
-      if (returnStatement)
-        return returnStatement;
-    }
-    return getSourceFileOfNode(node);
-  }
-  var fixMissingMember, fixMissingProperties, fixMissingAttributes, fixMissingFunctionDeclaration, errorCodes27;
-  var init_fixAddMissingMember = __esm({
-    "src/services/codefixes/fixAddMissingMember.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_codefix();
-      fixMissingMember = "fixMissingMember";
-      fixMissingProperties = "fixMissingProperties";
-      fixMissingAttributes = "fixMissingAttributes";
-      fixMissingFunctionDeclaration = "fixMissingFunctionDeclaration";
-      errorCodes27 = [
-        Diagnostics.Property_0_does_not_exist_on_type_1.code,
-        Diagnostics.Property_0_does_not_exist_on_type_1_Did_you_mean_2.code,
-        Diagnostics.Property_0_is_missing_in_type_1_but_required_in_type_2.code,
-        Diagnostics.Type_0_is_missing_the_following_properties_from_type_1_Colon_2.code,
-        Diagnostics.Type_0_is_missing_the_following_properties_from_type_1_Colon_2_and_3_more.code,
-        Diagnostics.Argument_of_type_0_is_not_assignable_to_parameter_of_type_1.code,
-        Diagnostics.Cannot_find_name_0.code
-      ];
-      registerCodeFix({
-        errorCodes: errorCodes27,
-        getCodeActions(context) {
-          const typeChecker = context.program.getTypeChecker();
-          const info = getInfo10(context.sourceFile, context.span.start, context.errorCode, typeChecker, context.program);
-          if (!info) {
-            return void 0;
-          }
-          if (info.kind === 3 /* ObjectLiteral */) {
-            const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => addObjectLiteralProperties(t, context, info));
-            return [createCodeFixAction(fixMissingProperties, changes, Diagnostics.Add_missing_properties, fixMissingProperties, Diagnostics.Add_all_missing_properties)];
-          }
-          if (info.kind === 4 /* JsxAttributes */) {
-            const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => addJsxAttributes(t, context, info));
-            return [createCodeFixAction(fixMissingAttributes, changes, Diagnostics.Add_missing_attributes, fixMissingAttributes, Diagnostics.Add_all_missing_attributes)];
-          }
-          if (info.kind === 2 /* Function */ || info.kind === 5 /* Signature */) {
-            const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => addFunctionDeclaration(t, context, info));
-            return [createCodeFixAction(fixMissingFunctionDeclaration, changes, [Diagnostics.Add_missing_function_declaration_0, info.token.text], fixMissingFunctionDeclaration, Diagnostics.Add_all_missing_function_declarations)];
-          }
-          if (info.kind === 1 /* Enum */) {
-            const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => addEnumMemberDeclaration(t, context.program.getTypeChecker(), info));
-            return [createCodeFixAction(fixMissingMember, changes, [Diagnostics.Add_missing_enum_member_0, info.token.text], fixMissingMember, Diagnostics.Add_all_missing_members)];
-          }
-          return concatenate(getActionsForMissingMethodDeclaration(context, info), getActionsForMissingMemberDeclaration(context, info));
-        },
-        fixIds: [fixMissingMember, fixMissingFunctionDeclaration, fixMissingProperties, fixMissingAttributes],
-        getAllCodeActions: (context) => {
-          const { program, fixId: fixId52 } = context;
-          const checker = program.getTypeChecker();
-          const seen = /* @__PURE__ */ new Map();
-          const typeDeclToMembers = /* @__PURE__ */ new Map();
-          return createCombinedCodeActions(ts_textChanges_exports.ChangeTracker.with(context, (changes) => {
-            eachDiagnostic(context, errorCodes27, (diag2) => {
-              const info = getInfo10(diag2.file, diag2.start, diag2.code, checker, context.program);
-              if (!info || !addToSeen(seen, getNodeId(info.parentDeclaration) + "#" + info.token.text)) {
-                return;
-              }
-              if (fixId52 === fixMissingFunctionDeclaration && (info.kind === 2 /* Function */ || info.kind === 5 /* Signature */)) {
-                addFunctionDeclaration(changes, context, info);
-              } else if (fixId52 === fixMissingProperties && info.kind === 3 /* ObjectLiteral */) {
-                addObjectLiteralProperties(changes, context, info);
-              } else if (fixId52 === fixMissingAttributes && info.kind === 4 /* JsxAttributes */) {
-                addJsxAttributes(changes, context, info);
-              } else {
-                if (info.kind === 1 /* Enum */) {
-                  addEnumMemberDeclaration(changes, checker, info);
-                }
-                if (info.kind === 0 /* TypeLikeDeclaration */) {
-                  const { parentDeclaration, token } = info;
-                  const infos = getOrUpdate(typeDeclToMembers, parentDeclaration, () => []);
-                  if (!infos.some((i) => i.token.text === token.text)) {
-                    infos.push(info);
-                  }
-                }
-              }
-            });
-            typeDeclToMembers.forEach((infos, declaration) => {
-              const supers = isTypeLiteralNode(declaration) ? void 0 : getAllSupers(declaration, checker);
-              for (const info of infos) {
-                if (supers == null ? void 0 : supers.some((superClassOrInterface) => {
-                  const superInfos = typeDeclToMembers.get(superClassOrInterface);
-                  return !!superInfos && superInfos.some(({ token: token2 }) => token2.text === info.token.text);
-                }))
-                  continue;
-                const { parentDeclaration, declSourceFile, modifierFlags, token, call, isJSFile } = info;
-                if (call && !isPrivateIdentifier(token)) {
-                  addMethodDeclaration(context, changes, call, token, modifierFlags & 32 /* Static */, parentDeclaration, declSourceFile);
-                } else {
-                  if (isJSFile && !isInterfaceDeclaration(parentDeclaration) && !isTypeLiteralNode(parentDeclaration)) {
-                    addMissingMemberInJs(changes, declSourceFile, parentDeclaration, token, !!(modifierFlags & 32 /* Static */));
-                  } else {
-                    const typeNode = getTypeNode2(checker, parentDeclaration, token);
-                    addPropertyDeclaration(changes, declSourceFile, parentDeclaration, token.text, typeNode, modifierFlags & 32 /* Static */);
-                  }
-                }
-              }
-            });
-          }));
-        }
-      });
-    }
-  });
-
-  // src/services/codefixes/fixAddMissingNewOperator.ts
-  function addMissingNewOperator(changes, sourceFile, span) {
-    const call = cast(findAncestorMatchingSpan2(sourceFile, span), isCallExpression);
-    const newExpression = factory.createNewExpression(call.expression, call.typeArguments, call.arguments);
-    changes.replaceNode(sourceFile, call, newExpression);
-  }
-  function findAncestorMatchingSpan2(sourceFile, span) {
-    let token = getTokenAtPosition(sourceFile, span.start);
-    const end = textSpanEnd(span);
-    while (token.end < end) {
-      token = token.parent;
-    }
-    return token;
-  }
-  var fixId24, errorCodes28;
-  var init_fixAddMissingNewOperator = __esm({
-    "src/services/codefixes/fixAddMissingNewOperator.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_codefix();
-      fixId24 = "addMissingNewOperator";
-      errorCodes28 = [Diagnostics.Value_of_type_0_is_not_callable_Did_you_mean_to_include_new.code];
-      registerCodeFix({
-        errorCodes: errorCodes28,
-        getCodeActions(context) {
-          const { sourceFile, span } = context;
-          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => addMissingNewOperator(t, sourceFile, span));
-          return [createCodeFixAction(fixId24, changes, Diagnostics.Add_missing_new_operator_to_call, fixId24, Diagnostics.Add_missing_new_operator_to_all_calls)];
-        },
-        fixIds: [fixId24],
-        getAllCodeActions: (context) => codeFixAll(context, errorCodes28, (changes, diag2) => addMissingNewOperator(changes, context.sourceFile, diag2))
-      });
-    }
-  });
-
-  // src/services/codefixes/fixCannotFindModule.ts
-  function getInstallCommand(fileName, packageName) {
-    return { type: "install package", file: fileName, packageName };
-  }
-  function tryGetImportedPackageName(sourceFile, pos) {
-    const moduleSpecifierText = tryCast(getTokenAtPosition(sourceFile, pos), isStringLiteral);
-    if (!moduleSpecifierText)
-      return void 0;
-    const moduleName = moduleSpecifierText.text;
-    const { packageName } = parsePackageName(moduleName);
-    return isExternalModuleNameRelative(packageName) ? void 0 : packageName;
-  }
-  function getTypesPackageNameToInstall(packageName, host, diagCode) {
-    var _a;
-    return diagCode === errorCodeCannotFindModule ? ts_JsTyping_exports.nodeCoreModules.has(packageName) ? "@types/node" : void 0 : ((_a = host.isKnownTypesPackageName) == null ? void 0 : _a.call(host, packageName)) ? getTypesPackageName(packageName) : void 0;
-  }
-  var fixName2, fixIdInstallTypesPackage, errorCodeCannotFindModule, errorCodes29;
-  var init_fixCannotFindModule = __esm({
-    "src/services/codefixes/fixCannotFindModule.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_codefix();
-      fixName2 = "fixCannotFindModule";
-      fixIdInstallTypesPackage = "installTypesPackage";
-      errorCodeCannotFindModule = Diagnostics.Cannot_find_module_0_or_its_corresponding_type_declarations.code;
-      errorCodes29 = [
-        errorCodeCannotFindModule,
-        Diagnostics.Could_not_find_a_declaration_file_for_module_0_1_implicitly_has_an_any_type.code
-      ];
-      registerCodeFix({
-        errorCodes: errorCodes29,
-        getCodeActions: function getCodeActionsToFixNotFoundModule(context) {
-          const { host, sourceFile, span: { start } } = context;
-          const packageName = tryGetImportedPackageName(sourceFile, start);
-          if (packageName === void 0)
-            return void 0;
-          const typesPackageName = getTypesPackageNameToInstall(packageName, host, context.errorCode);
-          return typesPackageName === void 0 ? [] : [createCodeFixAction(
-            fixName2,
-            /*changes*/
-            [],
-            [Diagnostics.Install_0, typesPackageName],
-            fixIdInstallTypesPackage,
-            Diagnostics.Install_all_missing_types_packages,
-            getInstallCommand(sourceFile.fileName, typesPackageName)
-          )];
-        },
-        fixIds: [fixIdInstallTypesPackage],
-        getAllCodeActions: (context) => {
-          return codeFixAll(context, errorCodes29, (_changes, diag2, commands) => {
-            const packageName = tryGetImportedPackageName(diag2.file, diag2.start);
-            if (packageName === void 0)
-              return void 0;
-            switch (context.fixId) {
-              case fixIdInstallTypesPackage: {
-                const pkg = getTypesPackageNameToInstall(packageName, context.host, diag2.code);
-                if (pkg) {
-                  commands.push(getInstallCommand(diag2.file.fileName, pkg));
-                }
-                break;
-              }
-              default:
-                Debug.fail(`Bad fixId: ${context.fixId}`);
-            }
-          });
-        }
-      });
-    }
-  });
-
-  // src/services/codefixes/fixClassDoesntImplementInheritedAbstractMember.ts
-  function getClass2(sourceFile, pos) {
-    const token = getTokenAtPosition(sourceFile, pos);
-    return cast(token.parent, isClassLike);
-  }
-  function addMissingMembers(classDeclaration, sourceFile, context, changeTracker, preferences) {
-    const extendsNode = getEffectiveBaseTypeNode(classDeclaration);
-    const checker = context.program.getTypeChecker();
-    const instantiatedExtendsType = checker.getTypeAtLocation(extendsNode);
-    const abstractAndNonPrivateExtendsSymbols = checker.getPropertiesOfType(instantiatedExtendsType).filter(symbolPointsToNonPrivateAndAbstractMember);
-    const importAdder = createImportAdder(sourceFile, context.program, preferences, context.host);
-    createMissingMemberNodes(classDeclaration, abstractAndNonPrivateExtendsSymbols, sourceFile, context, preferences, importAdder, (member) => changeTracker.insertMemberAtStart(sourceFile, classDeclaration, member));
-    importAdder.writeFixes(changeTracker);
-  }
-  function symbolPointsToNonPrivateAndAbstractMember(symbol) {
-    const flags = getSyntacticModifierFlags(first(symbol.getDeclarations()));
-    return !(flags & 8 /* Private */) && !!(flags & 256 /* Abstract */);
-  }
-  var errorCodes30, fixId25;
-  var init_fixClassDoesntImplementInheritedAbstractMember = __esm({
-    "src/services/codefixes/fixClassDoesntImplementInheritedAbstractMember.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_codefix();
-      errorCodes30 = [
-        Diagnostics.Non_abstract_class_0_does_not_implement_all_abstract_members_of_1.code
-      ];
-      fixId25 = "fixClassDoesntImplementInheritedAbstractMember";
-      registerCodeFix({
-        errorCodes: errorCodes30,
-        getCodeActions: function getCodeActionsToFixClassNotImplementingInheritedMembers(context) {
-          const { sourceFile, span } = context;
-          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => addMissingMembers(getClass2(sourceFile, span.start), sourceFile, context, t, context.preferences));
-          return changes.length === 0 ? void 0 : [createCodeFixAction(fixId25, changes, Diagnostics.Implement_inherited_abstract_class, fixId25, Diagnostics.Implement_all_inherited_abstract_classes)];
-        },
-        fixIds: [fixId25],
-        getAllCodeActions: function getAllCodeActionsToFixClassDoesntImplementInheritedAbstractMember(context) {
-          const seenClassDeclarations = /* @__PURE__ */ new Map();
-          return codeFixAll(context, errorCodes30, (changes, diag2) => {
-            const classDeclaration = getClass2(diag2.file, diag2.start);
-            if (addToSeen(seenClassDeclarations, getNodeId(classDeclaration))) {
-              addMissingMembers(classDeclaration, context.sourceFile, context, changes, context.preferences);
-            }
-          });
-        }
-      });
-    }
-  });
-
-  // src/services/codefixes/fixClassSuperMustPrecedeThisAccess.ts
-  function doChange19(changes, sourceFile, constructor, superCall) {
-    changes.insertNodeAtConstructorStart(sourceFile, constructor, superCall);
-    changes.delete(sourceFile, superCall);
-  }
-  function getNodes(sourceFile, pos) {
-    const token = getTokenAtPosition(sourceFile, pos);
-    if (token.kind !== 110 /* ThisKeyword */)
-      return void 0;
-    const constructor = getContainingFunction(token);
-    const superCall = findSuperCall(constructor.body);
-    return superCall && !superCall.expression.arguments.some((arg) => isPropertyAccessExpression(arg) && arg.expression === token) ? { constructor, superCall } : void 0;
-  }
-  function findSuperCall(n) {
-    return isExpressionStatement(n) && isSuperCall(n.expression) ? n : isFunctionLike(n) ? void 0 : forEachChild(n, findSuperCall);
-  }
-  var fixId26, errorCodes31;
-  var init_fixClassSuperMustPrecedeThisAccess = __esm({
-    "src/services/codefixes/fixClassSuperMustPrecedeThisAccess.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_codefix();
-      fixId26 = "classSuperMustPrecedeThisAccess";
-      errorCodes31 = [Diagnostics.super_must_be_called_before_accessing_this_in_the_constructor_of_a_derived_class.code];
-      registerCodeFix({
-        errorCodes: errorCodes31,
-        getCodeActions(context) {
-          const { sourceFile, span } = context;
-          const nodes = getNodes(sourceFile, span.start);
-          if (!nodes)
-            return void 0;
-          const { constructor, superCall } = nodes;
-          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange19(t, sourceFile, constructor, superCall));
-          return [createCodeFixAction(fixId26, changes, Diagnostics.Make_super_call_the_first_statement_in_the_constructor, fixId26, Diagnostics.Make_all_super_calls_the_first_statement_in_their_constructor)];
-        },
-        fixIds: [fixId26],
-        getAllCodeActions(context) {
-          const { sourceFile } = context;
-          const seenClasses = /* @__PURE__ */ new Map();
-          return codeFixAll(context, errorCodes31, (changes, diag2) => {
-            const nodes = getNodes(diag2.file, diag2.start);
-            if (!nodes)
-              return;
-            const { constructor, superCall } = nodes;
-            if (addToSeen(seenClasses, getNodeId(constructor.parent))) {
-              doChange19(changes, sourceFile, constructor, superCall);
-            }
-          });
-        }
-      });
-    }
-  });
-
-  // src/services/codefixes/fixConstructorForDerivedNeedSuperCall.ts
-  function getNode(sourceFile, pos) {
-    const token = getTokenAtPosition(sourceFile, pos);
-    Debug.assert(isConstructorDeclaration(token.parent), "token should be at the constructor declaration");
-    return token.parent;
-  }
-  function doChange20(changes, sourceFile, ctr) {
-    const superCall = factory.createExpressionStatement(factory.createCallExpression(
-      factory.createSuper(),
-      /*typeArguments*/
-      void 0,
-      /*argumentsArray*/
-      emptyArray
-    ));
-    changes.insertNodeAtConstructorStart(sourceFile, ctr, superCall);
-  }
-  var fixId27, errorCodes32;
-  var init_fixConstructorForDerivedNeedSuperCall = __esm({
-    "src/services/codefixes/fixConstructorForDerivedNeedSuperCall.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_codefix();
-      fixId27 = "constructorForDerivedNeedSuperCall";
-      errorCodes32 = [Diagnostics.Constructors_for_derived_classes_must_contain_a_super_call.code];
-      registerCodeFix({
-        errorCodes: errorCodes32,
-        getCodeActions(context) {
-          const { sourceFile, span } = context;
-          const ctr = getNode(sourceFile, span.start);
-          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange20(t, sourceFile, ctr));
-          return [createCodeFixAction(fixId27, changes, Diagnostics.Add_missing_super_call, fixId27, Diagnostics.Add_all_missing_super_calls)];
-        },
-        fixIds: [fixId27],
-        getAllCodeActions: (context) => codeFixAll(context, errorCodes32, (changes, diag2) => doChange20(changes, context.sourceFile, getNode(diag2.file, diag2.start)))
-      });
-    }
-  });
-
-  // src/services/codefixes/fixEnableJsxFlag.ts
-  function doChange21(changeTracker, configFile) {
-    setJsonCompilerOptionValue(changeTracker, configFile, "jsx", factory.createStringLiteral("react"));
-  }
-  var fixID, errorCodes33;
-  var init_fixEnableJsxFlag = __esm({
-    "src/services/codefixes/fixEnableJsxFlag.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_codefix();
-      fixID = "fixEnableJsxFlag";
-      errorCodes33 = [Diagnostics.Cannot_use_JSX_unless_the_jsx_flag_is_provided.code];
-      registerCodeFix({
-        errorCodes: errorCodes33,
-        getCodeActions: function getCodeActionsToFixEnableJsxFlag(context) {
-          const { configFile } = context.program.getCompilerOptions();
-          if (configFile === void 0) {
-            return void 0;
-          }
-          const changes = ts_textChanges_exports.ChangeTracker.with(
-            context,
-            (changeTracker) => doChange21(changeTracker, configFile)
-          );
-          return [
-            createCodeFixActionWithoutFixAll(fixID, changes, Diagnostics.Enable_the_jsx_flag_in_your_configuration_file)
-          ];
-        },
-        fixIds: [fixID],
-        getAllCodeActions: (context) => codeFixAll(context, errorCodes33, (changes) => {
-          const { configFile } = context.program.getCompilerOptions();
-          if (configFile === void 0) {
-            return void 0;
-          }
-          doChange21(changes, configFile);
-        })
-      });
-    }
-  });
-
-  // src/services/codefixes/fixNaNEquality.ts
-  function getInfo11(program, sourceFile, span) {
-    const diag2 = find(program.getSemanticDiagnostics(sourceFile), (diag3) => diag3.start === span.start && diag3.length === span.length);
-    if (diag2 === void 0 || diag2.relatedInformation === void 0)
-      return;
-    const related = find(diag2.relatedInformation, (related2) => related2.code === Diagnostics.Did_you_mean_0.code);
-    if (related === void 0 || related.file === void 0 || related.start === void 0 || related.length === void 0)
-      return;
-    const token = findAncestorMatchingSpan(related.file, createTextSpan(related.start, related.length));
-    if (token === void 0)
-      return;
-    if (isExpression(token) && isBinaryExpression(token.parent)) {
-      return { suggestion: getSuggestion(related.messageText), expression: token.parent, arg: token };
-    }
-    return void 0;
-  }
-  function doChange22(changes, sourceFile, arg, expression) {
-    const callExpression = factory.createCallExpression(
-      factory.createPropertyAccessExpression(factory.createIdentifier("Number"), factory.createIdentifier("isNaN")),
-      /*typeArguments*/
-      void 0,
-      [arg]
-    );
-    const operator = expression.operatorToken.kind;
-    changes.replaceNode(
-      sourceFile,
-      expression,
-      operator === 38 /* ExclamationEqualsEqualsToken */ || operator === 36 /* ExclamationEqualsToken */ ? factory.createPrefixUnaryExpression(54 /* ExclamationToken */, callExpression) : callExpression
-    );
-  }
-  function getSuggestion(messageText) {
-    const [_, suggestion] = flattenDiagnosticMessageText(messageText, "\n", 0).match(/\'(.*)\'/) || [];
-    return suggestion;
-  }
-  var fixId28, errorCodes34;
-  var init_fixNaNEquality = __esm({
-    "src/services/codefixes/fixNaNEquality.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_codefix();
-      fixId28 = "fixNaNEquality";
-      errorCodes34 = [
-        Diagnostics.This_condition_will_always_return_0.code
-      ];
-      registerCodeFix({
-        errorCodes: errorCodes34,
-        getCodeActions(context) {
-          const { sourceFile, span, program } = context;
-          const info = getInfo11(program, sourceFile, span);
-          if (info === void 0)
-            return;
-          const { suggestion, expression, arg } = info;
-          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange22(t, sourceFile, arg, expression));
-          return [createCodeFixAction(fixId28, changes, [Diagnostics.Use_0, suggestion], fixId28, Diagnostics.Use_Number_isNaN_in_all_conditions)];
-        },
-        fixIds: [fixId28],
-        getAllCodeActions: (context) => {
-          return codeFixAll(context, errorCodes34, (changes, diag2) => {
-            const info = getInfo11(context.program, diag2.file, createTextSpan(diag2.start, diag2.length));
-            if (info) {
-              doChange22(changes, diag2.file, info.arg, info.expression);
-            }
-          });
-        }
-      });
-    }
-  });
-
-  // src/services/codefixes/fixModuleAndTargetOptions.ts
-  var init_fixModuleAndTargetOptions = __esm({
-    "src/services/codefixes/fixModuleAndTargetOptions.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_codefix();
-      registerCodeFix({
-        errorCodes: [
-          Diagnostics.Top_level_await_expressions_are_only_allowed_when_the_module_option_is_set_to_es2022_esnext_system_node16_or_nodenext_and_the_target_option_is_set_to_es2017_or_higher.code,
-          Diagnostics.Top_level_for_await_loops_are_only_allowed_when_the_module_option_is_set_to_es2022_esnext_system_node16_or_nodenext_and_the_target_option_is_set_to_es2017_or_higher.code
-        ],
-        getCodeActions: function getCodeActionsToFixModuleAndTarget(context) {
-          const compilerOptions = context.program.getCompilerOptions();
-          const { configFile } = compilerOptions;
-          if (configFile === void 0) {
-            return void 0;
-          }
-          const codeFixes = [];
-          const moduleKind = getEmitModuleKind(compilerOptions);
-          const moduleOutOfRange = moduleKind >= 5 /* ES2015 */ && moduleKind < 99 /* ESNext */;
-          if (moduleOutOfRange) {
-            const changes = ts_textChanges_exports.ChangeTracker.with(context, (changes2) => {
-              setJsonCompilerOptionValue(changes2, configFile, "module", factory.createStringLiteral("esnext"));
-            });
-            codeFixes.push(createCodeFixActionWithoutFixAll("fixModuleOption", changes, [Diagnostics.Set_the_module_option_in_your_configuration_file_to_0, "esnext"]));
-          }
-          const target = getEmitScriptTarget(compilerOptions);
-          const targetOutOfRange = target < 4 /* ES2017 */ || target > 99 /* ESNext */;
-          if (targetOutOfRange) {
-            const changes = ts_textChanges_exports.ChangeTracker.with(context, (tracker) => {
-              const configObject = getTsConfigObjectLiteralExpression(configFile);
-              if (!configObject)
-                return;
-              const options = [["target", factory.createStringLiteral("es2017")]];
-              if (moduleKind === 1 /* CommonJS */) {
-                options.push(["module", factory.createStringLiteral("commonjs")]);
-              }
-              setJsonCompilerOptionValues(tracker, configFile, options);
-            });
-            codeFixes.push(createCodeFixActionWithoutFixAll("fixTargetOption", changes, [Diagnostics.Set_the_target_option_in_your_configuration_file_to_0, "es2017"]));
-          }
-          return codeFixes.length ? codeFixes : void 0;
-        }
-      });
-    }
-  });
-
-  // src/services/codefixes/fixPropertyAssignment.ts
-  function doChange23(changes, sourceFile, node) {
-    changes.replaceNode(sourceFile, node, factory.createPropertyAssignment(node.name, node.objectAssignmentInitializer));
-  }
-  function getProperty2(sourceFile, pos) {
-    return cast(getTokenAtPosition(sourceFile, pos).parent, isShorthandPropertyAssignment);
-  }
-  var fixId29, errorCodes35;
-  var init_fixPropertyAssignment = __esm({
-    "src/services/codefixes/fixPropertyAssignment.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_codefix();
-      fixId29 = "fixPropertyAssignment";
-      errorCodes35 = [
-        Diagnostics.Did_you_mean_to_use_a_Colon_An_can_only_follow_a_property_name_when_the_containing_object_literal_is_part_of_a_destructuring_pattern.code
-      ];
-      registerCodeFix({
-        errorCodes: errorCodes35,
-        fixIds: [fixId29],
-        getCodeActions(context) {
-          const { sourceFile, span } = context;
-          const property = getProperty2(sourceFile, span.start);
-          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange23(t, context.sourceFile, property));
-          return [createCodeFixAction(fixId29, changes, [Diagnostics.Change_0_to_1, "=", ":"], fixId29, [Diagnostics.Switch_each_misused_0_to_1, "=", ":"])];
-        },
-        getAllCodeActions: (context) => codeFixAll(context, errorCodes35, (changes, diag2) => doChange23(changes, diag2.file, getProperty2(diag2.file, diag2.start)))
-      });
-    }
-  });
-
-  // src/services/codefixes/fixExtendsInterfaceBecomesImplements.ts
-  function getNodes2(sourceFile, pos) {
-    const token = getTokenAtPosition(sourceFile, pos);
-    const heritageClauses = getContainingClass(token).heritageClauses;
-    const extendsToken = heritageClauses[0].getFirstToken();
-    return extendsToken.kind === 96 /* ExtendsKeyword */ ? { extendsToken, heritageClauses } : void 0;
-  }
-  function doChanges2(changes, sourceFile, extendsToken, heritageClauses) {
-    changes.replaceNode(sourceFile, extendsToken, factory.createToken(119 /* ImplementsKeyword */));
-    if (heritageClauses.length === 2 && heritageClauses[0].token === 96 /* ExtendsKeyword */ && heritageClauses[1].token === 119 /* ImplementsKeyword */) {
-      const implementsToken = heritageClauses[1].getFirstToken();
-      const implementsFullStart = implementsToken.getFullStart();
-      changes.replaceRange(sourceFile, { pos: implementsFullStart, end: implementsFullStart }, factory.createToken(28 /* CommaToken */));
-      const text = sourceFile.text;
-      let end = implementsToken.end;
-      while (end < text.length && isWhiteSpaceSingleLine(text.charCodeAt(end))) {
-        end++;
-      }
-      changes.deleteRange(sourceFile, { pos: implementsToken.getStart(), end });
-    }
-  }
-  var fixId30, errorCodes36;
-  var init_fixExtendsInterfaceBecomesImplements = __esm({
-    "src/services/codefixes/fixExtendsInterfaceBecomesImplements.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_codefix();
-      fixId30 = "extendsInterfaceBecomesImplements";
-      errorCodes36 = [Diagnostics.Cannot_extend_an_interface_0_Did_you_mean_implements.code];
-      registerCodeFix({
-        errorCodes: errorCodes36,
-        getCodeActions(context) {
-          const { sourceFile } = context;
-          const nodes = getNodes2(sourceFile, context.span.start);
-          if (!nodes)
-            return void 0;
-          const { extendsToken, heritageClauses } = nodes;
-          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChanges2(t, sourceFile, extendsToken, heritageClauses));
-          return [createCodeFixAction(fixId30, changes, Diagnostics.Change_extends_to_implements, fixId30, Diagnostics.Change_all_extended_interfaces_to_implements)];
-        },
-        fixIds: [fixId30],
-        getAllCodeActions: (context) => codeFixAll(context, errorCodes36, (changes, diag2) => {
-          const nodes = getNodes2(diag2.file, diag2.start);
-          if (nodes)
-            doChanges2(changes, diag2.file, nodes.extendsToken, nodes.heritageClauses);
-        })
-      });
-    }
-  });
-
-  // src/services/codefixes/fixForgottenThisPropertyAccess.ts
-  function getInfo12(sourceFile, pos, diagCode) {
-    const node = getTokenAtPosition(sourceFile, pos);
-    if (isIdentifier(node) || isPrivateIdentifier(node)) {
-      return { node, className: diagCode === didYouMeanStaticMemberCode ? getContainingClass(node).name.text : void 0 };
-    }
-  }
-  function doChange24(changes, sourceFile, { node, className }) {
-    suppressLeadingAndTrailingTrivia(node);
-    changes.replaceNode(sourceFile, node, factory.createPropertyAccessExpression(className ? factory.createIdentifier(className) : factory.createThis(), node));
-  }
-  var fixId31, didYouMeanStaticMemberCode, errorCodes37;
-  var init_fixForgottenThisPropertyAccess = __esm({
-    "src/services/codefixes/fixForgottenThisPropertyAccess.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_codefix();
-      fixId31 = "forgottenThisPropertyAccess";
-      didYouMeanStaticMemberCode = Diagnostics.Cannot_find_name_0_Did_you_mean_the_static_member_1_0.code;
-      errorCodes37 = [
-        Diagnostics.Cannot_find_name_0_Did_you_mean_the_instance_member_this_0.code,
-        Diagnostics.Private_identifiers_are_only_allowed_in_class_bodies_and_may_only_be_used_as_part_of_a_class_member_declaration_property_access_or_on_the_left_hand_side_of_an_in_expression.code,
-        didYouMeanStaticMemberCode
-      ];
-      registerCodeFix({
-        errorCodes: errorCodes37,
-        getCodeActions(context) {
-          const { sourceFile } = context;
-          const info = getInfo12(sourceFile, context.span.start, context.errorCode);
-          if (!info) {
-            return void 0;
-          }
-          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange24(t, sourceFile, info));
-          return [createCodeFixAction(fixId31, changes, [Diagnostics.Add_0_to_unresolved_variable, info.className || "this"], fixId31, Diagnostics.Add_qualifier_to_all_unresolved_variables_matching_a_member_name)];
-        },
-        fixIds: [fixId31],
-        getAllCodeActions: (context) => codeFixAll(context, errorCodes37, (changes, diag2) => {
-          const info = getInfo12(diag2.file, diag2.start, diag2.code);
-          if (info)
-            doChange24(changes, context.sourceFile, info);
-        })
-      });
-    }
-  });
-
-  // src/services/codefixes/fixInvalidJsxCharacters.ts
-  function isValidCharacter(character) {
-    return hasProperty(htmlEntity, character);
-  }
-  function doChange25(changes, preferences, sourceFile, start, useHtmlEntity) {
-    const character = sourceFile.getText()[start];
-    if (!isValidCharacter(character)) {
-      return;
-    }
-    const replacement = useHtmlEntity ? htmlEntity[character] : `{${quote(sourceFile, preferences, character)}}`;
-    changes.replaceRangeWithText(sourceFile, { pos: start, end: start + 1 }, replacement);
-  }
-  var fixIdExpression, fixIdHtmlEntity, errorCodes38, htmlEntity;
-  var init_fixInvalidJsxCharacters = __esm({
-    "src/services/codefixes/fixInvalidJsxCharacters.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_codefix();
-      fixIdExpression = "fixInvalidJsxCharacters_expression";
-      fixIdHtmlEntity = "fixInvalidJsxCharacters_htmlEntity";
-      errorCodes38 = [
-        Diagnostics.Unexpected_token_Did_you_mean_or_gt.code,
-        Diagnostics.Unexpected_token_Did_you_mean_or_rbrace.code
-      ];
-      registerCodeFix({
-        errorCodes: errorCodes38,
-        fixIds: [fixIdExpression, fixIdHtmlEntity],
-        getCodeActions(context) {
-          const { sourceFile, preferences, span } = context;
-          const changeToExpression = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange25(
-            t,
-            preferences,
-            sourceFile,
-            span.start,
-            /*useHtmlEntity*/
-            false
-          ));
-          const changeToHtmlEntity = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange25(
-            t,
-            preferences,
-            sourceFile,
-            span.start,
-            /*useHtmlEntity*/
-            true
-          ));
-          return [
-            createCodeFixAction(fixIdExpression, changeToExpression, Diagnostics.Wrap_invalid_character_in_an_expression_container, fixIdExpression, Diagnostics.Wrap_all_invalid_characters_in_an_expression_container),
-            createCodeFixAction(fixIdHtmlEntity, changeToHtmlEntity, Diagnostics.Convert_invalid_character_to_its_html_entity_code, fixIdHtmlEntity, Diagnostics.Convert_all_invalid_characters_to_HTML_entity_code)
-          ];
-        },
-        getAllCodeActions(context) {
-          return codeFixAll(context, errorCodes38, (changes, diagnostic) => doChange25(changes, context.preferences, diagnostic.file, diagnostic.start, context.fixId === fixIdHtmlEntity));
-        }
-      });
-      htmlEntity = {
-        ">": ">",
-        "}": "}"
-      };
-    }
-  });
-
-  // src/services/codefixes/fixUnmatchedParameter.ts
-  function getDeleteAction(context, { name, jsDocHost, jsDocParameterTag }) {
-    const changes = ts_textChanges_exports.ChangeTracker.with(context, (changeTracker) => changeTracker.filterJSDocTags(context.sourceFile, jsDocHost, (t) => t !== jsDocParameterTag));
-    return createCodeFixAction(
-      deleteUnmatchedParameter,
-      changes,
-      [Diagnostics.Delete_unused_param_tag_0, name.getText(context.sourceFile)],
-      deleteUnmatchedParameter,
-      Diagnostics.Delete_all_unused_param_tags
-    );
-  }
-  function getRenameAction(context, { name, jsDocHost, signature, jsDocParameterTag }) {
-    if (!length(signature.parameters))
-      return void 0;
-    const sourceFile = context.sourceFile;
-    const tags = getJSDocTags(signature);
-    const names = /* @__PURE__ */ new Set();
-    for (const tag of tags) {
-      if (isJSDocParameterTag(tag) && isIdentifier(tag.name)) {
-        names.add(tag.name.escapedText);
-      }
-    }
-    const parameterName = firstDefined(signature.parameters, (p) => isIdentifier(p.name) && !names.has(p.name.escapedText) ? p.name.getText(sourceFile) : void 0);
-    if (parameterName === void 0)
-      return void 0;
-    const newJSDocParameterTag = factory.updateJSDocParameterTag(
-      jsDocParameterTag,
-      jsDocParameterTag.tagName,
-      factory.createIdentifier(parameterName),
-      jsDocParameterTag.isBracketed,
-      jsDocParameterTag.typeExpression,
-      jsDocParameterTag.isNameFirst,
-      jsDocParameterTag.comment
-    );
-    const changes = ts_textChanges_exports.ChangeTracker.with(context, (changeTracker) => changeTracker.replaceJSDocComment(sourceFile, jsDocHost, map(tags, (t) => t === jsDocParameterTag ? newJSDocParameterTag : t)));
-    return createCodeFixActionWithoutFixAll(renameUnmatchedParameter, changes, [Diagnostics.Rename_param_tag_name_0_to_1, name.getText(sourceFile), parameterName]);
-  }
-  function getInfo13(sourceFile, pos) {
-    const token = getTokenAtPosition(sourceFile, pos);
-    if (token.parent && isJSDocParameterTag(token.parent) && isIdentifier(token.parent.name)) {
-      const jsDocParameterTag = token.parent;
-      const jsDocHost = getJSDocHost(jsDocParameterTag);
-      const signature = getHostSignatureFromJSDoc(jsDocParameterTag);
-      if (jsDocHost && signature) {
-        return { jsDocHost, signature, name: token.parent.name, jsDocParameterTag };
-      }
-    }
-    return void 0;
-  }
-  var deleteUnmatchedParameter, renameUnmatchedParameter, errorCodes39;
-  var init_fixUnmatchedParameter = __esm({
-    "src/services/codefixes/fixUnmatchedParameter.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_codefix();
-      deleteUnmatchedParameter = "deleteUnmatchedParameter";
-      renameUnmatchedParameter = "renameUnmatchedParameter";
-      errorCodes39 = [
-        Diagnostics.JSDoc_param_tag_has_name_0_but_there_is_no_parameter_with_that_name.code
-      ];
-      registerCodeFix({
-        fixIds: [deleteUnmatchedParameter, renameUnmatchedParameter],
-        errorCodes: errorCodes39,
-        getCodeActions: function getCodeActionsToFixUnmatchedParameter(context) {
-          const { sourceFile, span } = context;
-          const actions2 = [];
-          const info = getInfo13(sourceFile, span.start);
-          if (info) {
-            append(actions2, getDeleteAction(context, info));
-            append(actions2, getRenameAction(context, info));
-            return actions2;
-          }
-          return void 0;
-        },
-        getAllCodeActions: function getAllCodeActionsToFixUnmatchedParameter(context) {
-          const tagsToSignature = /* @__PURE__ */ new Map();
-          return createCombinedCodeActions(ts_textChanges_exports.ChangeTracker.with(context, (changes) => {
-            eachDiagnostic(context, errorCodes39, ({ file, start }) => {
-              const info = getInfo13(file, start);
-              if (info) {
-                tagsToSignature.set(info.signature, append(tagsToSignature.get(info.signature), info.jsDocParameterTag));
-              }
-            });
-            tagsToSignature.forEach((tags, signature) => {
-              if (context.fixId === deleteUnmatchedParameter) {
-                const tagsSet = new Set(tags);
-                changes.filterJSDocTags(signature.getSourceFile(), signature, (t) => !tagsSet.has(t));
-              }
-            });
-          }));
-        }
-      });
-    }
-  });
-
-  // src/services/codefixes/fixUnreferenceableDecoratorMetadata.ts
-  function getImportDeclaration(sourceFile, program, start) {
-    const identifier = tryCast(getTokenAtPosition(sourceFile, start), isIdentifier);
-    if (!identifier || identifier.parent.kind !== 182 /* TypeReference */)
-      return;
-    const checker = program.getTypeChecker();
-    const symbol = checker.getSymbolAtLocation(identifier);
-    return find((symbol == null ? void 0 : symbol.declarations) || emptyArray, or(isImportClause, isImportSpecifier, isImportEqualsDeclaration));
-  }
-  function doTypeOnlyImportChange(changes, sourceFile, importDeclaration, program) {
-    if (importDeclaration.kind === 270 /* ImportEqualsDeclaration */) {
-      changes.insertModifierBefore(sourceFile, 156 /* TypeKeyword */, importDeclaration.name);
-      return;
-    }
-    const importClause = importDeclaration.kind === 272 /* ImportClause */ ? importDeclaration : importDeclaration.parent.parent;
-    if (importClause.name && importClause.namedBindings) {
-      return;
-    }
-    const checker = program.getTypeChecker();
-    const importsValue = !!forEachImportClauseDeclaration(importClause, (decl) => {
-      if (skipAlias(decl.symbol, checker).flags & 111551 /* Value */)
-        return true;
-    });
-    if (importsValue) {
-      return;
-    }
-    changes.insertModifierBefore(sourceFile, 156 /* TypeKeyword */, importClause);
-  }
-  function doNamespaceImportChange(changes, sourceFile, importDeclaration, program) {
-    ts_refactor_exports.doChangeNamedToNamespaceOrDefault(sourceFile, program, changes, importDeclaration.parent);
-  }
-  var fixId32, errorCodes40;
-  var init_fixUnreferenceableDecoratorMetadata = __esm({
-    "src/services/codefixes/fixUnreferenceableDecoratorMetadata.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_codefix();
-      fixId32 = "fixUnreferenceableDecoratorMetadata";
-      errorCodes40 = [Diagnostics.A_type_referenced_in_a_decorated_signature_must_be_imported_with_import_type_or_a_namespace_import_when_isolatedModules_and_emitDecoratorMetadata_are_enabled.code];
-      registerCodeFix({
-        errorCodes: errorCodes40,
-        getCodeActions: (context) => {
-          const importDeclaration = getImportDeclaration(context.sourceFile, context.program, context.span.start);
-          if (!importDeclaration)
-            return;
-          const namespaceChanges = ts_textChanges_exports.ChangeTracker.with(context, (t) => importDeclaration.kind === 275 /* ImportSpecifier */ && doNamespaceImportChange(t, context.sourceFile, importDeclaration, context.program));
-          const typeOnlyChanges = ts_textChanges_exports.ChangeTracker.with(context, (t) => doTypeOnlyImportChange(t, context.sourceFile, importDeclaration, context.program));
-          let actions2;
-          if (namespaceChanges.length) {
-            actions2 = append(actions2, createCodeFixActionWithoutFixAll(fixId32, namespaceChanges, Diagnostics.Convert_named_imports_to_namespace_import));
-          }
-          if (typeOnlyChanges.length) {
-            actions2 = append(actions2, createCodeFixActionWithoutFixAll(fixId32, typeOnlyChanges, Diagnostics.Convert_to_type_only_import));
-          }
-          return actions2;
-        },
-        fixIds: [fixId32]
-      });
-    }
-  });
-
-  // src/services/codefixes/fixUnusedIdentifier.ts
-  function changeInferToUnknown(changes, sourceFile, token) {
-    changes.replaceNode(sourceFile, token.parent, factory.createKeywordTypeNode(159 /* UnknownKeyword */));
-  }
-  function createDeleteFix(changes, diag2) {
-    return createCodeFixAction(fixName3, changes, diag2, fixIdDelete, Diagnostics.Delete_all_unused_declarations);
-  }
-  function deleteTypeParameters(changes, sourceFile, token) {
-    changes.delete(sourceFile, Debug.checkDefined(cast(token.parent, isDeclarationWithTypeParameterChildren).typeParameters, "The type parameter to delete should exist"));
-  }
-  function isImport(token) {
-    return token.kind === 102 /* ImportKeyword */ || token.kind === 80 /* Identifier */ && (token.parent.kind === 275 /* ImportSpecifier */ || token.parent.kind === 272 /* ImportClause */);
-  }
-  function tryGetFullImport(token) {
-    return token.kind === 102 /* ImportKeyword */ ? tryCast(token.parent, isImportDeclaration) : void 0;
-  }
-  function canDeleteEntireVariableStatement(sourceFile, token) {
-    return isVariableDeclarationList(token.parent) && first(token.parent.getChildren(sourceFile)) === token;
-  }
-  function deleteEntireVariableStatement(changes, sourceFile, node) {
-    changes.delete(sourceFile, node.parent.kind === 242 /* VariableStatement */ ? node.parent : node);
-  }
-  function deleteDestructuringElements(changes, sourceFile, node) {
-    forEach(node.elements, (n) => changes.delete(sourceFile, n));
-  }
-  function deleteDestructuring(context, changes, sourceFile, { parent: parent2 }) {
-    if (isVariableDeclaration(parent2) && parent2.initializer && isCallLikeExpression(parent2.initializer)) {
-      if (isVariableDeclarationList(parent2.parent) && length(parent2.parent.declarations) > 1) {
-        const varStatement = parent2.parent.parent;
-        const pos = varStatement.getStart(sourceFile);
-        const end = varStatement.end;
-        changes.delete(sourceFile, parent2);
-        changes.insertNodeAt(sourceFile, end, parent2.initializer, {
-          prefix: getNewLineOrDefaultFromHost(context.host, context.formatContext.options) + sourceFile.text.slice(getPrecedingNonSpaceCharacterPosition(sourceFile.text, pos - 1), pos),
-          suffix: probablyUsesSemicolons(sourceFile) ? ";" : ""
-        });
-      } else {
-        changes.replaceNode(sourceFile, parent2.parent, parent2.initializer);
-      }
-    } else {
-      changes.delete(sourceFile, parent2);
-    }
-  }
-  function tryPrefixDeclaration(changes, errorCode, sourceFile, token) {
-    if (errorCode === Diagnostics.Property_0_is_declared_but_its_value_is_never_read.code)
-      return;
-    if (token.kind === 140 /* InferKeyword */) {
-      token = cast(token.parent, isInferTypeNode).typeParameter.name;
-    }
-    if (isIdentifier(token) && canPrefix(token)) {
-      changes.replaceNode(sourceFile, token, factory.createIdentifier(`_${token.text}`));
-      if (isParameter(token.parent)) {
-        getJSDocParameterTags(token.parent).forEach((tag) => {
-          if (isIdentifier(tag.name)) {
-            changes.replaceNode(sourceFile, tag.name, factory.createIdentifier(`_${tag.name.text}`));
-          }
-        });
-      }
-    }
-  }
-  function canPrefix(token) {
-    switch (token.parent.kind) {
-      case 168 /* Parameter */:
-      case 167 /* TypeParameter */:
-        return true;
-      case 259 /* VariableDeclaration */: {
-        const varDecl = token.parent;
-        switch (varDecl.parent.parent.kind) {
-          case 249 /* ForOfStatement */:
-          case 248 /* ForInStatement */:
-            return true;
-        }
-      }
-    }
-    return false;
-  }
-  function tryDeleteDeclaration(sourceFile, token, changes, checker, sourceFiles, program, cancellationToken, isFixAll) {
-    tryDeleteDeclarationWorker(token, changes, sourceFile, checker, sourceFiles, program, cancellationToken, isFixAll);
-    if (isIdentifier(token)) {
-      ts_FindAllReferences_exports.Core.eachSymbolReferenceInFile(token, checker, sourceFile, (ref) => {
-        if (isPropertyAccessExpression(ref.parent) && ref.parent.name === ref)
-          ref = ref.parent;
-        if (!isFixAll && mayDeleteExpression(ref)) {
-          changes.delete(sourceFile, ref.parent.parent);
-        }
-      });
-    }
-  }
-  function tryDeleteDeclarationWorker(token, changes, sourceFile, checker, sourceFiles, program, cancellationToken, isFixAll) {
-    const { parent: parent2 } = token;
-    if (isParameter(parent2)) {
-      tryDeleteParameter(changes, sourceFile, parent2, checker, sourceFiles, program, cancellationToken, isFixAll);
-    } else if (!(isFixAll && isIdentifier(token) && ts_FindAllReferences_exports.Core.isSymbolReferencedInFile(token, checker, sourceFile))) {
-      const node = isImportClause(parent2) ? token : isComputedPropertyName(parent2) ? parent2.parent : parent2;
-      Debug.assert(node !== sourceFile, "should not delete whole source file");
-      changes.delete(sourceFile, node);
-    }
-  }
-  function tryDeleteParameter(changes, sourceFile, parameter, checker, sourceFiles, program, cancellationToken, isFixAll = false) {
-    if (mayDeleteParameter(checker, sourceFile, parameter, sourceFiles, program, cancellationToken, isFixAll)) {
-      if (parameter.modifiers && parameter.modifiers.length > 0 && (!isIdentifier(parameter.name) || ts_FindAllReferences_exports.Core.isSymbolReferencedInFile(parameter.name, checker, sourceFile))) {
-        for (const modifier of parameter.modifiers) {
-          if (isModifier(modifier)) {
-            changes.deleteModifier(sourceFile, modifier);
-          }
-        }
-      } else if (!parameter.initializer && isNotProvidedArguments(parameter, checker, sourceFiles)) {
-        changes.delete(sourceFile, parameter);
-      }
-    }
-  }
-  function isNotProvidedArguments(parameter, checker, sourceFiles) {
-    const index = parameter.parent.parameters.indexOf(parameter);
-    return !ts_FindAllReferences_exports.Core.someSignatureUsage(parameter.parent, sourceFiles, checker, (_, call) => !call || call.arguments.length > index);
-  }
-  function mayDeleteParameter(checker, sourceFile, parameter, sourceFiles, program, cancellationToken, isFixAll) {
-    const { parent: parent2 } = parameter;
-    switch (parent2.kind) {
-      case 173 /* MethodDeclaration */:
-      case 175 /* Constructor */:
-        const index = parent2.parameters.indexOf(parameter);
-        const referent = isMethodDeclaration(parent2) ? parent2.name : parent2;
-        const entries = ts_FindAllReferences_exports.Core.getReferencedSymbolsForNode(parent2.pos, referent, program, sourceFiles, cancellationToken);
-        if (entries) {
-          for (const entry of entries) {
-            for (const reference of entry.references) {
-              if (reference.kind === ts_FindAllReferences_exports.EntryKind.Node) {
-                const isSuperCall2 = isSuperKeyword(reference.node) && isCallExpression(reference.node.parent) && reference.node.parent.arguments.length > index;
-                const isSuperMethodCall = isPropertyAccessExpression(reference.node.parent) && isSuperKeyword(reference.node.parent.expression) && isCallExpression(reference.node.parent.parent) && reference.node.parent.parent.arguments.length > index;
-                const isOverriddenMethod = (isMethodDeclaration(reference.node.parent) || isMethodSignature(reference.node.parent)) && reference.node.parent !== parameter.parent && reference.node.parent.parameters.length > index;
-                if (isSuperCall2 || isSuperMethodCall || isOverriddenMethod)
-                  return false;
-              }
-            }
-          }
-        }
-        return true;
-      case 261 /* FunctionDeclaration */: {
-        if (parent2.name && isCallbackLike(checker, sourceFile, parent2.name)) {
-          return isLastParameter(parent2, parameter, isFixAll);
-        }
-        return true;
-      }
-      case 217 /* FunctionExpression */:
-      case 218 /* ArrowFunction */:
-        return isLastParameter(parent2, parameter, isFixAll);
-      case 177 /* SetAccessor */:
-        return false;
-      case 176 /* GetAccessor */:
-        return true;
-      default:
-        return Debug.failBadSyntaxKind(parent2);
-    }
-  }
-  function isCallbackLike(checker, sourceFile, name) {
-    return !!ts_FindAllReferences_exports.Core.eachSymbolReferenceInFile(name, checker, sourceFile, (reference) => isIdentifier(reference) && isCallExpression(reference.parent) && reference.parent.arguments.indexOf(reference) >= 0);
-  }
-  function isLastParameter(func, parameter, isFixAll) {
-    const parameters = func.parameters;
-    const index = parameters.indexOf(parameter);
-    Debug.assert(index !== -1, "The parameter should already be in the list");
-    return isFixAll ? parameters.slice(index + 1).every((p) => isIdentifier(p.name) && !p.symbol.isReferenced) : index === parameters.length - 1;
-  }
-  function mayDeleteExpression(node) {
-    return (isBinaryExpression(node.parent) && node.parent.left === node || (isPostfixUnaryExpression(node.parent) || isPrefixUnaryExpression(node.parent)) && node.parent.operand === node) && isExpressionStatement(node.parent.parent);
-  }
-  var fixName3, fixIdPrefix, fixIdDelete, fixIdDeleteImports, fixIdInfer, errorCodes41;
-  var init_fixUnusedIdentifier = __esm({
-    "src/services/codefixes/fixUnusedIdentifier.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_codefix();
-      fixName3 = "unusedIdentifier";
-      fixIdPrefix = "unusedIdentifier_prefix";
-      fixIdDelete = "unusedIdentifier_delete";
-      fixIdDeleteImports = "unusedIdentifier_deleteImports";
-      fixIdInfer = "unusedIdentifier_infer";
-      errorCodes41 = [
-        Diagnostics._0_is_declared_but_its_value_is_never_read.code,
-        Diagnostics._0_is_declared_but_never_used.code,
-        Diagnostics.Property_0_is_declared_but_its_value_is_never_read.code,
-        Diagnostics.All_imports_in_import_declaration_are_unused.code,
-        Diagnostics.All_destructured_elements_are_unused.code,
-        Diagnostics.All_variables_are_unused.code,
-        Diagnostics.All_type_parameters_are_unused.code
-      ];
-      registerCodeFix({
-        errorCodes: errorCodes41,
-        getCodeActions(context) {
-          const { errorCode, sourceFile, program, cancellationToken } = context;
-          const checker = program.getTypeChecker();
-          const sourceFiles = program.getSourceFiles();
-          const token = getTokenAtPosition(sourceFile, context.span.start);
-          if (isJSDocTemplateTag(token)) {
-            return [createDeleteFix(ts_textChanges_exports.ChangeTracker.with(context, (t) => t.delete(sourceFile, token)), Diagnostics.Remove_template_tag)];
-          }
-          if (token.kind === 30 /* LessThanToken */) {
-            const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => deleteTypeParameters(t, sourceFile, token));
-            return [createDeleteFix(changes, Diagnostics.Remove_type_parameters)];
-          }
-          const importDecl = tryGetFullImport(token);
-          if (importDecl) {
-            const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => t.delete(sourceFile, importDecl));
-            return [createCodeFixAction(fixName3, changes, [Diagnostics.Remove_import_from_0, showModuleSpecifier(importDecl)], fixIdDeleteImports, Diagnostics.Delete_all_unused_imports)];
-          } else if (isImport(token)) {
-            const deletion = ts_textChanges_exports.ChangeTracker.with(context, (t) => tryDeleteDeclaration(
-              sourceFile,
-              token,
-              t,
-              checker,
-              sourceFiles,
-              program,
-              cancellationToken,
-              /*isFixAll*/
-              false
-            ));
-            if (deletion.length) {
-              return [createCodeFixAction(fixName3, deletion, [Diagnostics.Remove_unused_declaration_for_Colon_0, token.getText(sourceFile)], fixIdDeleteImports, Diagnostics.Delete_all_unused_imports)];
-            }
-          }
-          if (isObjectBindingPattern(token.parent) || isArrayBindingPattern(token.parent)) {
-            if (isParameter(token.parent.parent)) {
-              const elements = token.parent.elements;
-              const diagnostic = [
-                elements.length > 1 ? Diagnostics.Remove_unused_declarations_for_Colon_0 : Diagnostics.Remove_unused_declaration_for_Colon_0,
-                map(elements, (e) => e.getText(sourceFile)).join(", ")
-              ];
-              return [
-                createDeleteFix(ts_textChanges_exports.ChangeTracker.with(context, (t) => deleteDestructuringElements(t, sourceFile, token.parent)), diagnostic)
-              ];
-            }
-            return [
-              createDeleteFix(ts_textChanges_exports.ChangeTracker.with(context, (t) => deleteDestructuring(context, t, sourceFile, token.parent)), Diagnostics.Remove_unused_destructuring_declaration)
-            ];
-          }
-          if (canDeleteEntireVariableStatement(sourceFile, token)) {
-            return [
-              createDeleteFix(ts_textChanges_exports.ChangeTracker.with(context, (t) => deleteEntireVariableStatement(t, sourceFile, token.parent)), Diagnostics.Remove_variable_statement)
-            ];
-          }
-          const result = [];
-          if (token.kind === 140 /* InferKeyword */) {
-            const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => changeInferToUnknown(t, sourceFile, token));
-            const name = cast(token.parent, isInferTypeNode).typeParameter.name.text;
-            result.push(createCodeFixAction(fixName3, changes, [Diagnostics.Replace_infer_0_with_unknown, name], fixIdInfer, Diagnostics.Replace_all_unused_infer_with_unknown));
-          } else {
-            const deletion = ts_textChanges_exports.ChangeTracker.with(context, (t) => tryDeleteDeclaration(
-              sourceFile,
-              token,
-              t,
-              checker,
-              sourceFiles,
-              program,
-              cancellationToken,
-              /*isFixAll*/
-              false
-            ));
-            if (deletion.length) {
-              const name = isComputedPropertyName(token.parent) ? token.parent : token;
-              result.push(createDeleteFix(deletion, [Diagnostics.Remove_unused_declaration_for_Colon_0, name.getText(sourceFile)]));
-            }
-          }
-          const prefix = ts_textChanges_exports.ChangeTracker.with(context, (t) => tryPrefixDeclaration(t, errorCode, sourceFile, token));
-          if (prefix.length) {
-            result.push(createCodeFixAction(fixName3, prefix, [Diagnostics.Prefix_0_with_an_underscore, token.getText(sourceFile)], fixIdPrefix, Diagnostics.Prefix_all_unused_declarations_with_where_possible));
-          }
-          return result;
-        },
-        fixIds: [fixIdPrefix, fixIdDelete, fixIdDeleteImports, fixIdInfer],
-        getAllCodeActions: (context) => {
-          const { sourceFile, program, cancellationToken } = context;
-          const checker = program.getTypeChecker();
-          const sourceFiles = program.getSourceFiles();
-          return codeFixAll(context, errorCodes41, (changes, diag2) => {
-            const token = getTokenAtPosition(sourceFile, diag2.start);
-            switch (context.fixId) {
-              case fixIdPrefix:
-                tryPrefixDeclaration(changes, diag2.code, sourceFile, token);
-                break;
-              case fixIdDeleteImports: {
-                const importDecl = tryGetFullImport(token);
-                if (importDecl) {
-                  changes.delete(sourceFile, importDecl);
-                } else if (isImport(token)) {
-                  tryDeleteDeclaration(
-                    sourceFile,
-                    token,
-                    changes,
-                    checker,
-                    sourceFiles,
-                    program,
-                    cancellationToken,
-                    /*isFixAll*/
-                    true
-                  );
-                }
-                break;
-              }
-              case fixIdDelete: {
-                if (token.kind === 140 /* InferKeyword */ || isImport(token)) {
-                  break;
-                } else if (isJSDocTemplateTag(token)) {
-                  changes.delete(sourceFile, token);
-                } else if (token.kind === 30 /* LessThanToken */) {
-                  deleteTypeParameters(changes, sourceFile, token);
-                } else if (isObjectBindingPattern(token.parent)) {
-                  if (token.parent.parent.initializer) {
-                    break;
-                  } else if (!isParameter(token.parent.parent) || isNotProvidedArguments(token.parent.parent, checker, sourceFiles)) {
-                    changes.delete(sourceFile, token.parent.parent);
-                  }
-                } else if (isArrayBindingPattern(token.parent.parent) && token.parent.parent.parent.initializer) {
-                  break;
-                } else if (canDeleteEntireVariableStatement(sourceFile, token)) {
-                  deleteEntireVariableStatement(changes, sourceFile, token.parent);
-                } else {
-                  tryDeleteDeclaration(
-                    sourceFile,
-                    token,
-                    changes,
-                    checker,
-                    sourceFiles,
-                    program,
-                    cancellationToken,
-                    /*isFixAll*/
-                    true
-                  );
-                }
-                break;
-              }
-              case fixIdInfer:
-                if (token.kind === 140 /* InferKeyword */) {
-                  changeInferToUnknown(changes, sourceFile, token);
-                }
-                break;
-              default:
-                Debug.fail(JSON.stringify(context.fixId));
-            }
-          });
-        }
-      });
-    }
-  });
-
-  // src/services/codefixes/fixUnreachableCode.ts
-  function doChange26(changes, sourceFile, start, length2, errorCode) {
-    const token = getTokenAtPosition(sourceFile, start);
-    const statement = findAncestor(token, isStatement);
-    if (statement.getStart(sourceFile) !== token.getStart(sourceFile)) {
-      const logData = JSON.stringify({
-        statementKind: Debug.formatSyntaxKind(statement.kind),
-        tokenKind: Debug.formatSyntaxKind(token.kind),
-        errorCode,
-        start,
-        length: length2
-      });
-      Debug.fail("Token and statement should start at the same point. " + logData);
-    }
-    const container = (isBlock(statement.parent) ? statement.parent : statement).parent;
-    if (!isBlock(statement.parent) || statement === first(statement.parent.statements)) {
-      switch (container.kind) {
-        case 244 /* IfStatement */:
-          if (container.elseStatement) {
-            if (isBlock(statement.parent)) {
-              break;
-            } else {
-              changes.replaceNode(sourceFile, statement, factory.createBlock(emptyArray));
-            }
-            return;
-          }
-        case 246 /* WhileStatement */:
-        case 247 /* ForStatement */:
-          changes.delete(sourceFile, container);
-          return;
-      }
-    }
-    if (isBlock(statement.parent)) {
-      const end = start + length2;
-      const lastStatement = Debug.checkDefined(lastWhere(sliceAfter(statement.parent.statements, statement), (s) => s.pos < end), "Some statement should be last");
-      changes.deleteNodeRange(sourceFile, statement, lastStatement);
-    } else {
-      changes.delete(sourceFile, statement);
-    }
-  }
-  function lastWhere(a, pred) {
-    let last2;
-    for (const value of a) {
-      if (!pred(value))
-        break;
-      last2 = value;
-    }
-    return last2;
-  }
-  var fixId33, errorCodes42;
-  var init_fixUnreachableCode = __esm({
-    "src/services/codefixes/fixUnreachableCode.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_codefix();
-      fixId33 = "fixUnreachableCode";
-      errorCodes42 = [Diagnostics.Unreachable_code_detected.code];
-      registerCodeFix({
-        errorCodes: errorCodes42,
-        getCodeActions(context) {
-          const syntacticDiagnostics = context.program.getSyntacticDiagnostics(context.sourceFile, context.cancellationToken);
-          if (syntacticDiagnostics.length)
-            return;
-          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange26(t, context.sourceFile, context.span.start, context.span.length, context.errorCode));
-          return [createCodeFixAction(fixId33, changes, Diagnostics.Remove_unreachable_code, fixId33, Diagnostics.Remove_all_unreachable_code)];
-        },
-        fixIds: [fixId33],
-        getAllCodeActions: (context) => codeFixAll(context, errorCodes42, (changes, diag2) => doChange26(changes, diag2.file, diag2.start, diag2.length, diag2.code))
-      });
-    }
-  });
-
-  // src/services/codefixes/fixUnusedLabel.ts
-  function doChange27(changes, sourceFile, start) {
-    const token = getTokenAtPosition(sourceFile, start);
-    const labeledStatement = cast(token.parent, isLabeledStatement);
-    const pos = token.getStart(sourceFile);
-    const statementPos = labeledStatement.statement.getStart(sourceFile);
-    const end = positionsAreOnSameLine(pos, statementPos, sourceFile) ? statementPos : skipTrivia(
-      sourceFile.text,
-      findChildOfKind(labeledStatement, 59 /* ColonToken */, sourceFile).end,
-      /*stopAfterLineBreak*/
-      true
-    );
-    changes.deleteRange(sourceFile, { pos, end });
-  }
-  var fixId34, errorCodes43;
-  var init_fixUnusedLabel = __esm({
-    "src/services/codefixes/fixUnusedLabel.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_codefix();
-      fixId34 = "fixUnusedLabel";
-      errorCodes43 = [Diagnostics.Unused_label.code];
-      registerCodeFix({
-        errorCodes: errorCodes43,
-        getCodeActions(context) {
-          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange27(t, context.sourceFile, context.span.start));
-          return [createCodeFixAction(fixId34, changes, Diagnostics.Remove_unused_label, fixId34, Diagnostics.Remove_all_unused_labels)];
-        },
-        fixIds: [fixId34],
-        getAllCodeActions: (context) => codeFixAll(context, errorCodes43, (changes, diag2) => doChange27(changes, diag2.file, diag2.start))
-      });
-    }
-  });
-
-  // src/services/codefixes/fixJSDocTypes.ts
-  function doChange28(changes, sourceFile, oldTypeNode, newType, checker) {
-    changes.replaceNode(sourceFile, oldTypeNode, checker.typeToTypeNode(
-      newType,
-      /*enclosingDeclaration*/
-      oldTypeNode,
-      /*flags*/
-      void 0
-    ));
-  }
-  function getInfo14(sourceFile, pos, checker) {
-    const decl = findAncestor(getTokenAtPosition(sourceFile, pos), isTypeContainer);
-    const typeNode = decl && decl.type;
-    return typeNode && { typeNode, type: getType(checker, typeNode) };
-  }
-  function isTypeContainer(node) {
-    switch (node.kind) {
-      case 233 /* AsExpression */:
-      case 178 /* CallSignature */:
-      case 179 /* ConstructSignature */:
-      case 261 /* FunctionDeclaration */:
-      case 176 /* GetAccessor */:
-      case 180 /* IndexSignature */:
-      case 199 /* MappedType */:
-      case 173 /* MethodDeclaration */:
-      case 172 /* MethodSignature */:
-      case 168 /* Parameter */:
-      case 171 /* PropertyDeclaration */:
-      case 170 /* PropertySignature */:
-      case 177 /* SetAccessor */:
-      case 264 /* TypeAliasDeclaration */:
-      case 215 /* TypeAssertionExpression */:
-      case 259 /* VariableDeclaration */:
-        return true;
-      default:
-        return false;
-    }
-  }
-  function getType(checker, node) {
-    if (isJSDocNullableType(node)) {
-      const type = checker.getTypeFromTypeNode(node.type);
-      if (type === checker.getNeverType() || type === checker.getVoidType()) {
-        return type;
-      }
-      return checker.getUnionType(
-        append([type, checker.getUndefinedType()], node.postfix ? void 0 : checker.getNullType())
-      );
-    }
-    return checker.getTypeFromTypeNode(node);
-  }
-  var fixIdPlain, fixIdNullable, errorCodes44;
-  var init_fixJSDocTypes = __esm({
-    "src/services/codefixes/fixJSDocTypes.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_codefix();
-      fixIdPlain = "fixJSDocTypes_plain";
-      fixIdNullable = "fixJSDocTypes_nullable";
-      errorCodes44 = [
-        Diagnostics.JSDoc_types_can_only_be_used_inside_documentation_comments.code,
-        Diagnostics._0_at_the_end_of_a_type_is_not_valid_TypeScript_syntax_Did_you_mean_to_write_1.code,
-        Diagnostics._0_at_the_start_of_a_type_is_not_valid_TypeScript_syntax_Did_you_mean_to_write_1.code
-      ];
-      registerCodeFix({
-        errorCodes: errorCodes44,
-        getCodeActions(context) {
-          const { sourceFile } = context;
-          const checker = context.program.getTypeChecker();
-          const info = getInfo14(sourceFile, context.span.start, checker);
-          if (!info)
-            return void 0;
-          const { typeNode, type } = info;
-          const original = typeNode.getText(sourceFile);
-          const actions2 = [fix(type, fixIdPlain, Diagnostics.Change_all_jsdoc_style_types_to_TypeScript)];
-          if (typeNode.kind === 320 /* JSDocNullableType */) {
-            actions2.push(fix(type, fixIdNullable, Diagnostics.Change_all_jsdoc_style_types_to_TypeScript_and_add_undefined_to_nullable_types));
-          }
-          return actions2;
-          function fix(type2, fixId52, fixAllDescription) {
-            const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange28(t, sourceFile, typeNode, type2, checker));
-            return createCodeFixAction("jdocTypes", changes, [Diagnostics.Change_0_to_1, original, checker.typeToString(type2)], fixId52, fixAllDescription);
-          }
-        },
-        fixIds: [fixIdPlain, fixIdNullable],
-        getAllCodeActions(context) {
-          const { fixId: fixId52, program, sourceFile } = context;
-          const checker = program.getTypeChecker();
-          return codeFixAll(context, errorCodes44, (changes, err) => {
-            const info = getInfo14(err.file, err.start, checker);
-            if (!info)
-              return;
-            const { typeNode, type } = info;
-            const fixedType = typeNode.kind === 320 /* JSDocNullableType */ && fixId52 === fixIdNullable ? checker.getNullableType(type, 32768 /* Undefined */) : type;
-            doChange28(changes, sourceFile, typeNode, fixedType, checker);
-          });
-        }
-      });
-    }
-  });
-
-  // src/services/codefixes/fixMissingCallParentheses.ts
-  function doChange29(changes, sourceFile, name) {
-    changes.replaceNodeWithText(sourceFile, name, `${name.text}()`);
-  }
-  function getCallName(sourceFile, start) {
-    const token = getTokenAtPosition(sourceFile, start);
-    if (isPropertyAccessExpression(token.parent)) {
-      let current = token.parent;
-      while (isPropertyAccessExpression(current.parent)) {
-        current = current.parent;
-      }
-      return current.name;
-    }
-    if (isIdentifier(token)) {
-      return token;
-    }
-    return void 0;
-  }
-  var fixId35, errorCodes45;
-  var init_fixMissingCallParentheses = __esm({
-    "src/services/codefixes/fixMissingCallParentheses.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_codefix();
-      fixId35 = "fixMissingCallParentheses";
-      errorCodes45 = [
-        Diagnostics.This_condition_will_always_return_true_since_this_function_is_always_defined_Did_you_mean_to_call_it_instead.code
-      ];
-      registerCodeFix({
-        errorCodes: errorCodes45,
-        fixIds: [fixId35],
-        getCodeActions(context) {
-          const { sourceFile, span } = context;
-          const callName = getCallName(sourceFile, span.start);
-          if (!callName)
-            return;
-          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange29(t, context.sourceFile, callName));
-          return [createCodeFixAction(fixId35, changes, Diagnostics.Add_missing_call_parentheses, fixId35, Diagnostics.Add_all_missing_call_parentheses)];
-        },
-        getAllCodeActions: (context) => codeFixAll(context, errorCodes45, (changes, diag2) => {
-          const callName = getCallName(diag2.file, diag2.start);
-          if (callName)
-            doChange29(changes, diag2.file, callName);
-        })
-      });
-    }
-  });
-
-  // src/services/codefixes/fixAwaitInSyncFunction.ts
-  function getReturnType(expr) {
-    if (expr.type) {
-      return expr.type;
-    }
-    if (isVariableDeclaration(expr.parent) && expr.parent.type && isFunctionTypeNode(expr.parent.type)) {
-      return expr.parent.type.type;
-    }
-  }
-  function getNodes3(sourceFile, start) {
-    const token = getTokenAtPosition(sourceFile, start);
-    const containingFunction = getContainingFunction(token);
-    if (!containingFunction) {
-      return;
-    }
-    let insertBefore;
-    switch (containingFunction.kind) {
-      case 173 /* MethodDeclaration */:
-        insertBefore = containingFunction.name;
-        break;
-      case 261 /* FunctionDeclaration */:
-      case 217 /* FunctionExpression */:
-        insertBefore = findChildOfKind(containingFunction, 100 /* FunctionKeyword */, sourceFile);
-        break;
-      case 218 /* ArrowFunction */:
-        const kind = containingFunction.typeParameters ? 30 /* LessThanToken */ : 21 /* OpenParenToken */;
-        insertBefore = findChildOfKind(containingFunction, kind, sourceFile) || first(containingFunction.parameters);
-        break;
-      default:
-        return;
-    }
-    return insertBefore && {
-      insertBefore,
-      returnType: getReturnType(containingFunction)
-    };
-  }
-  function doChange30(changes, sourceFile, { insertBefore, returnType }) {
-    if (returnType) {
-      const entityName = getEntityNameFromTypeNode(returnType);
-      if (!entityName || entityName.kind !== 80 /* Identifier */ || entityName.text !== "Promise") {
-        changes.replaceNode(sourceFile, returnType, factory.createTypeReferenceNode("Promise", factory.createNodeArray([returnType])));
-      }
-    }
-    changes.insertModifierBefore(sourceFile, 134 /* AsyncKeyword */, insertBefore);
-  }
-  var fixId36, errorCodes46;
-  var init_fixAwaitInSyncFunction = __esm({
-    "src/services/codefixes/fixAwaitInSyncFunction.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_codefix();
-      fixId36 = "fixAwaitInSyncFunction";
-      errorCodes46 = [
-        Diagnostics.await_expressions_are_only_allowed_within_async_functions_and_at_the_top_levels_of_modules.code,
-        Diagnostics.for_await_loops_are_only_allowed_within_async_functions_and_at_the_top_levels_of_modules.code,
-        Diagnostics.Cannot_find_name_0_Did_you_mean_to_write_this_in_an_async_function.code
-      ];
-      registerCodeFix({
-        errorCodes: errorCodes46,
-        getCodeActions(context) {
-          const { sourceFile, span } = context;
-          const nodes = getNodes3(sourceFile, span.start);
-          if (!nodes)
-            return void 0;
-          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange30(t, sourceFile, nodes));
-          return [createCodeFixAction(fixId36, changes, Diagnostics.Add_async_modifier_to_containing_function, fixId36, Diagnostics.Add_all_missing_async_modifiers)];
-        },
-        fixIds: [fixId36],
-        getAllCodeActions: function getAllCodeActionsToFixAwaitInSyncFunction(context) {
-          const seen = /* @__PURE__ */ new Map();
-          return codeFixAll(context, errorCodes46, (changes, diag2) => {
-            const nodes = getNodes3(diag2.file, diag2.start);
-            if (!nodes || !addToSeen(seen, getNodeId(nodes.insertBefore)))
-              return;
-            doChange30(changes, context.sourceFile, nodes);
-          });
-        }
-      });
-    }
-  });
-
-  // src/services/codefixes/fixPropertyOverrideAccessor.ts
-  function doChange31(file, start, length2, code, context) {
-    let startPosition;
-    let endPosition;
-    if (code === Diagnostics._0_is_defined_as_an_accessor_in_class_1_but_is_overridden_here_in_2_as_an_instance_property.code) {
-      startPosition = start;
-      endPosition = start + length2;
-    } else if (code === Diagnostics._0_is_defined_as_a_property_in_class_1_but_is_overridden_here_in_2_as_an_accessor.code) {
-      const checker = context.program.getTypeChecker();
-      const node = getTokenAtPosition(file, start).parent;
-      Debug.assert(isAccessor(node), "error span of fixPropertyOverrideAccessor should only be on an accessor");
-      const containingClass = node.parent;
-      Debug.assert(isClassLike(containingClass), "erroneous accessors should only be inside classes");
-      const base = singleOrUndefined(getAllSupers(containingClass, checker));
-      if (!base)
-        return [];
-      const name = unescapeLeadingUnderscores(getTextOfPropertyName(node.name));
-      const baseProp = checker.getPropertyOfType(checker.getTypeAtLocation(base), name);
-      if (!baseProp || !baseProp.valueDeclaration)
-        return [];
-      startPosition = baseProp.valueDeclaration.pos;
-      endPosition = baseProp.valueDeclaration.end;
-      file = getSourceFileOfNode(baseProp.valueDeclaration);
-    } else {
-      Debug.fail("fixPropertyOverrideAccessor codefix got unexpected error code " + code);
-    }
-    return generateAccessorFromProperty(file, context.program, startPosition, endPosition, context, Diagnostics.Generate_get_and_set_accessors.message);
-  }
-  var errorCodes47, fixId37;
-  var init_fixPropertyOverrideAccessor = __esm({
-    "src/services/codefixes/fixPropertyOverrideAccessor.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_codefix();
-      errorCodes47 = [
-        Diagnostics._0_is_defined_as_an_accessor_in_class_1_but_is_overridden_here_in_2_as_an_instance_property.code,
-        Diagnostics._0_is_defined_as_a_property_in_class_1_but_is_overridden_here_in_2_as_an_accessor.code
-      ];
-      fixId37 = "fixPropertyOverrideAccessor";
-      registerCodeFix({
-        errorCodes: errorCodes47,
-        getCodeActions(context) {
-          const edits = doChange31(context.sourceFile, context.span.start, context.span.length, context.errorCode, context);
-          if (edits) {
-            return [createCodeFixAction(fixId37, edits, Diagnostics.Generate_get_and_set_accessors, fixId37, Diagnostics.Generate_get_and_set_accessors_for_all_overriding_properties)];
-          }
-        },
-        fixIds: [fixId37],
-        getAllCodeActions: (context) => codeFixAll(context, errorCodes47, (changes, diag2) => {
-          const edits = doChange31(diag2.file, diag2.start, diag2.length, diag2.code, context);
-          if (edits) {
-            for (const edit of edits) {
-              changes.pushRaw(context.sourceFile, edit);
-            }
-          }
-        })
-      });
-    }
-  });
-
-  // src/services/codefixes/inferFromUsage.ts
-  function getDiagnostic(errorCode, token) {
-    switch (errorCode) {
-      case Diagnostics.Parameter_0_implicitly_has_an_1_type.code:
-      case Diagnostics.Parameter_0_implicitly_has_an_1_type_but_a_better_type_may_be_inferred_from_usage.code:
-        return isSetAccessorDeclaration(getContainingFunction(token)) ? Diagnostics.Infer_type_of_0_from_usage : Diagnostics.Infer_parameter_types_from_usage;
-      case Diagnostics.Rest_parameter_0_implicitly_has_an_any_type.code:
-      case Diagnostics.Rest_parameter_0_implicitly_has_an_any_type_but_a_better_type_may_be_inferred_from_usage.code:
-        return Diagnostics.Infer_parameter_types_from_usage;
-      case Diagnostics.this_implicitly_has_type_any_because_it_does_not_have_a_type_annotation.code:
-        return Diagnostics.Infer_this_type_of_0_from_usage;
-      default:
-        return Diagnostics.Infer_type_of_0_from_usage;
-    }
-  }
-  function mapSuggestionDiagnostic(errorCode) {
-    switch (errorCode) {
-      case Diagnostics.Variable_0_implicitly_has_type_1_in_some_locations_but_a_better_type_may_be_inferred_from_usage.code:
-        return Diagnostics.Variable_0_implicitly_has_type_1_in_some_locations_where_its_type_cannot_be_determined.code;
-      case Diagnostics.Variable_0_implicitly_has_an_1_type_but_a_better_type_may_be_inferred_from_usage.code:
-        return Diagnostics.Variable_0_implicitly_has_an_1_type.code;
-      case Diagnostics.Parameter_0_implicitly_has_an_1_type_but_a_better_type_may_be_inferred_from_usage.code:
-        return Diagnostics.Parameter_0_implicitly_has_an_1_type.code;
-      case Diagnostics.Rest_parameter_0_implicitly_has_an_any_type_but_a_better_type_may_be_inferred_from_usage.code:
-        return Diagnostics.Rest_parameter_0_implicitly_has_an_any_type.code;
-      case Diagnostics.Property_0_implicitly_has_type_any_but_a_better_type_for_its_get_accessor_may_be_inferred_from_usage.code:
-        return Diagnostics.Property_0_implicitly_has_type_any_because_its_get_accessor_lacks_a_return_type_annotation.code;
-      case Diagnostics._0_implicitly_has_an_1_return_type_but_a_better_type_may_be_inferred_from_usage.code:
-        return Diagnostics._0_which_lacks_return_type_annotation_implicitly_has_an_1_return_type.code;
-      case Diagnostics.Property_0_implicitly_has_type_any_but_a_better_type_for_its_set_accessor_may_be_inferred_from_usage.code:
-        return Diagnostics.Property_0_implicitly_has_type_any_because_its_set_accessor_lacks_a_parameter_type_annotation.code;
-      case Diagnostics.Member_0_implicitly_has_an_1_type_but_a_better_type_may_be_inferred_from_usage.code:
-        return Diagnostics.Member_0_implicitly_has_an_1_type.code;
-    }
-    return errorCode;
-  }
-  function doChange32(changes, sourceFile, token, errorCode, program, cancellationToken, markSeen, host, preferences) {
-    if (!isParameterPropertyModifier(token.kind) && token.kind !== 80 /* Identifier */ && token.kind !== 26 /* DotDotDotToken */ && token.kind !== 110 /* ThisKeyword */) {
-      return void 0;
-    }
-    const { parent: parent2 } = token;
-    const importAdder = createImportAdder(sourceFile, program, preferences, host);
-    errorCode = mapSuggestionDiagnostic(errorCode);
-    switch (errorCode) {
-      case Diagnostics.Member_0_implicitly_has_an_1_type.code:
-      case Diagnostics.Variable_0_implicitly_has_type_1_in_some_locations_where_its_type_cannot_be_determined.code:
-        if (isVariableDeclaration(parent2) && markSeen(parent2) || isPropertyDeclaration(parent2) || isPropertySignature(parent2)) {
-          annotateVariableDeclaration(changes, importAdder, sourceFile, parent2, program, host, cancellationToken);
-          importAdder.writeFixes(changes);
-          return parent2;
-        }
-        if (isPropertyAccessExpression(parent2)) {
-          const type = inferTypeForVariableFromUsage(parent2.name, program, cancellationToken);
-          const typeNode = getTypeNodeIfAccessible(type, parent2, program, host);
-          if (typeNode) {
-            const typeTag = factory.createJSDocTypeTag(
-              /*tagName*/
-              void 0,
-              factory.createJSDocTypeExpression(typeNode),
-              /*comment*/
-              void 0
-            );
-            changes.addJSDocTags(sourceFile, cast(parent2.parent.parent, isExpressionStatement), [typeTag]);
-          }
-          importAdder.writeFixes(changes);
-          return parent2;
-        }
-        return void 0;
-      case Diagnostics.Variable_0_implicitly_has_an_1_type.code: {
-        const symbol = program.getTypeChecker().getSymbolAtLocation(token);
-        if (symbol && symbol.valueDeclaration && isVariableDeclaration(symbol.valueDeclaration) && markSeen(symbol.valueDeclaration)) {
-          annotateVariableDeclaration(changes, importAdder, getSourceFileOfNode(symbol.valueDeclaration), symbol.valueDeclaration, program, host, cancellationToken);
-          importAdder.writeFixes(changes);
-          return symbol.valueDeclaration;
-        }
-        return void 0;
-      }
-    }
-    const containingFunction = getContainingFunction(token);
-    if (containingFunction === void 0) {
-      return void 0;
-    }
-    let declaration;
-    switch (errorCode) {
-      case Diagnostics.Parameter_0_implicitly_has_an_1_type.code:
-        if (isSetAccessorDeclaration(containingFunction)) {
-          annotateSetAccessor(changes, importAdder, sourceFile, containingFunction, program, host, cancellationToken);
-          declaration = containingFunction;
-          break;
-        }
-      case Diagnostics.Rest_parameter_0_implicitly_has_an_any_type.code:
-        if (markSeen(containingFunction)) {
-          const param = cast(parent2, isParameter);
-          annotateParameters(changes, importAdder, sourceFile, param, containingFunction, program, host, cancellationToken);
-          declaration = param;
-        }
-        break;
-      case Diagnostics.Property_0_implicitly_has_type_any_because_its_get_accessor_lacks_a_return_type_annotation.code:
-      case Diagnostics._0_which_lacks_return_type_annotation_implicitly_has_an_1_return_type.code:
-        if (isGetAccessorDeclaration(containingFunction) && isIdentifier(containingFunction.name)) {
-          annotate(changes, importAdder, sourceFile, containingFunction, inferTypeForVariableFromUsage(containingFunction.name, program, cancellationToken), program, host);
-          declaration = containingFunction;
-        }
-        break;
-      case Diagnostics.Property_0_implicitly_has_type_any_because_its_set_accessor_lacks_a_parameter_type_annotation.code:
-        if (isSetAccessorDeclaration(containingFunction)) {
-          annotateSetAccessor(changes, importAdder, sourceFile, containingFunction, program, host, cancellationToken);
-          declaration = containingFunction;
-        }
-        break;
-      case Diagnostics.this_implicitly_has_type_any_because_it_does_not_have_a_type_annotation.code:
-        if (ts_textChanges_exports.isThisTypeAnnotatable(containingFunction) && markSeen(containingFunction)) {
-          annotateThis(changes, sourceFile, containingFunction, program, host, cancellationToken);
-          declaration = containingFunction;
-        }
-        break;
-      default:
-        return Debug.fail(String(errorCode));
-    }
-    importAdder.writeFixes(changes);
-    return declaration;
-  }
-  function annotateVariableDeclaration(changes, importAdder, sourceFile, declaration, program, host, cancellationToken) {
-    if (isIdentifier(declaration.name)) {
-      annotate(changes, importAdder, sourceFile, declaration, inferTypeForVariableFromUsage(declaration.name, program, cancellationToken), program, host);
-    }
-  }
-  function annotateParameters(changes, importAdder, sourceFile, parameterDeclaration, containingFunction, program, host, cancellationToken) {
-    if (!isIdentifier(parameterDeclaration.name)) {
-      return;
-    }
-    const parameterInferences = inferTypeForParametersFromUsage(containingFunction, sourceFile, program, cancellationToken);
-    Debug.assert(containingFunction.parameters.length === parameterInferences.length, "Parameter count and inference count should match");
-    if (isInJSFile(containingFunction)) {
-      annotateJSDocParameters(changes, sourceFile, parameterInferences, program, host);
-    } else {
-      const needParens = isArrowFunction(containingFunction) && !findChildOfKind(containingFunction, 21 /* OpenParenToken */, sourceFile);
-      if (needParens)
-        changes.insertNodeBefore(sourceFile, first(containingFunction.parameters), factory.createToken(21 /* OpenParenToken */));
-      for (const { declaration, type } of parameterInferences) {
-        if (declaration && !declaration.type && !declaration.initializer) {
-          annotate(changes, importAdder, sourceFile, declaration, type, program, host);
-        }
-      }
-      if (needParens)
-        changes.insertNodeAfter(sourceFile, last(containingFunction.parameters), factory.createToken(22 /* CloseParenToken */));
-    }
-  }
-  function annotateThis(changes, sourceFile, containingFunction, program, host, cancellationToken) {
-    const references = getFunctionReferences(containingFunction, sourceFile, program, cancellationToken);
-    if (!references || !references.length) {
-      return;
-    }
-    const thisInference = inferTypeFromReferences(program, references, cancellationToken).thisParameter();
-    const typeNode = getTypeNodeIfAccessible(thisInference, containingFunction, program, host);
-    if (!typeNode) {
-      return;
-    }
-    if (isInJSFile(containingFunction)) {
-      annotateJSDocThis(changes, sourceFile, containingFunction, typeNode);
-    } else {
-      changes.tryInsertThisTypeAnnotation(sourceFile, containingFunction, typeNode);
-    }
-  }
-  function annotateJSDocThis(changes, sourceFile, containingFunction, typeNode) {
-    changes.addJSDocTags(sourceFile, containingFunction, [
-      factory.createJSDocThisTag(
-        /*tagName*/
-        void 0,
-        factory.createJSDocTypeExpression(typeNode)
-      )
-    ]);
-  }
-  function annotateSetAccessor(changes, importAdder, sourceFile, setAccessorDeclaration, program, host, cancellationToken) {
-    const param = firstOrUndefined(setAccessorDeclaration.parameters);
-    if (param && isIdentifier(setAccessorDeclaration.name) && isIdentifier(param.name)) {
-      let type = inferTypeForVariableFromUsage(setAccessorDeclaration.name, program, cancellationToken);
-      if (type === program.getTypeChecker().getAnyType()) {
-        type = inferTypeForVariableFromUsage(param.name, program, cancellationToken);
-      }
-      if (isInJSFile(setAccessorDeclaration)) {
-        annotateJSDocParameters(changes, sourceFile, [{ declaration: param, type }], program, host);
-      } else {
-        annotate(changes, importAdder, sourceFile, param, type, program, host);
-      }
-    }
-  }
-  function annotate(changes, importAdder, sourceFile, declaration, type, program, host) {
-    const typeNode = getTypeNodeIfAccessible(type, declaration, program, host);
-    if (typeNode) {
-      if (isInJSFile(sourceFile) && declaration.kind !== 170 /* PropertySignature */) {
-        const parent2 = isVariableDeclaration(declaration) ? tryCast(declaration.parent.parent, isVariableStatement) : declaration;
-        if (!parent2) {
-          return;
-        }
-        const typeExpression = factory.createJSDocTypeExpression(typeNode);
-        const typeTag = isGetAccessorDeclaration(declaration) ? factory.createJSDocReturnTag(
-          /*tagName*/
-          void 0,
-          typeExpression,
-          /*comment*/
-          void 0
-        ) : factory.createJSDocTypeTag(
-          /*tagName*/
-          void 0,
-          typeExpression,
-          /*comment*/
-          void 0
-        );
-        changes.addJSDocTags(sourceFile, parent2, [typeTag]);
-      } else if (!tryReplaceImportTypeNodeWithAutoImport(typeNode, declaration, sourceFile, changes, importAdder, getEmitScriptTarget(program.getCompilerOptions()))) {
-        changes.tryInsertTypeAnnotation(sourceFile, declaration, typeNode);
-      }
-    }
-  }
-  function tryReplaceImportTypeNodeWithAutoImport(typeNode, declaration, sourceFile, changes, importAdder, scriptTarget) {
-    const importableReference = tryGetAutoImportableReferenceFromTypeNode(typeNode, scriptTarget);
-    if (importableReference && changes.tryInsertTypeAnnotation(sourceFile, declaration, importableReference.typeNode)) {
-      forEach(importableReference.symbols, (s) => importAdder.addImportFromExportedSymbol(
-        s,
-        /*isValidTypeOnlyUseSite*/
-        true
-      ));
-      return true;
-    }
-    return false;
-  }
-  function annotateJSDocParameters(changes, sourceFile, parameterInferences, program, host) {
-    const signature = parameterInferences.length && parameterInferences[0].declaration.parent;
-    if (!signature) {
-      return;
-    }
-    const inferences = mapDefined(parameterInferences, (inference) => {
-      const param = inference.declaration;
-      if (param.initializer || getJSDocType(param) || !isIdentifier(param.name)) {
-        return;
-      }
-      const typeNode = inference.type && getTypeNodeIfAccessible(inference.type, param, program, host);
-      if (typeNode) {
-        const name = factory.cloneNode(param.name);
-        setEmitFlags(name, 3072 /* NoComments */ | 4096 /* NoNestedComments */);
-        return { name: factory.cloneNode(param.name), param, isOptional: !!inference.isOptional, typeNode };
-      }
-    });
-    if (!inferences.length) {
-      return;
-    }
-    if (isArrowFunction(signature) || isFunctionExpression(signature)) {
-      const needParens = isArrowFunction(signature) && !findChildOfKind(signature, 21 /* OpenParenToken */, sourceFile);
-      if (needParens) {
-        changes.insertNodeBefore(sourceFile, first(signature.parameters), factory.createToken(21 /* OpenParenToken */));
-      }
-      forEach(inferences, ({ typeNode, param }) => {
-        const typeTag = factory.createJSDocTypeTag(
-          /*tagName*/
-          void 0,
-          factory.createJSDocTypeExpression(typeNode)
-        );
-        const jsDoc = factory.createJSDocComment(
-          /*comment*/
-          void 0,
-          [typeTag]
-        );
-        changes.insertNodeAt(sourceFile, param.getStart(sourceFile), jsDoc, { suffix: " " });
-      });
-      if (needParens) {
-        changes.insertNodeAfter(sourceFile, last(signature.parameters), factory.createToken(22 /* CloseParenToken */));
-      }
-    } else {
-      const paramTags = map(inferences, ({ name, typeNode, isOptional }) => factory.createJSDocParameterTag(
-        /*tagName*/
-        void 0,
-        name,
-        /*isBracketed*/
-        !!isOptional,
-        factory.createJSDocTypeExpression(typeNode),
-        /*isNameFirst*/
-        false,
-        /*comment*/
-        void 0
-      ));
-      changes.addJSDocTags(sourceFile, signature, paramTags);
-    }
-  }
-  function getReferences(token, program, cancellationToken) {
-    return mapDefined(ts_FindAllReferences_exports.getReferenceEntriesForNode(-1, token, program, program.getSourceFiles(), cancellationToken), (entry) => entry.kind !== ts_FindAllReferences_exports.EntryKind.Span ? tryCast(entry.node, isIdentifier) : void 0);
-  }
-  function inferTypeForVariableFromUsage(token, program, cancellationToken) {
-    const references = getReferences(token, program, cancellationToken);
-    return inferTypeFromReferences(program, references, cancellationToken).single();
-  }
-  function inferTypeForParametersFromUsage(func, sourceFile, program, cancellationToken) {
-    const references = getFunctionReferences(func, sourceFile, program, cancellationToken);
-    return references && inferTypeFromReferences(program, references, cancellationToken).parameters(func) || func.parameters.map((p) => ({
-      declaration: p,
-      type: isIdentifier(p.name) ? inferTypeForVariableFromUsage(p.name, program, cancellationToken) : program.getTypeChecker().getAnyType()
-    }));
-  }
-  function getFunctionReferences(containingFunction, sourceFile, program, cancellationToken) {
-    let searchToken;
-    switch (containingFunction.kind) {
-      case 175 /* Constructor */:
-        searchToken = findChildOfKind(containingFunction, 137 /* ConstructorKeyword */, sourceFile);
-        break;
-      case 218 /* ArrowFunction */:
-      case 217 /* FunctionExpression */:
-        const parent2 = containingFunction.parent;
-        searchToken = (isVariableDeclaration(parent2) || isPropertyDeclaration(parent2)) && isIdentifier(parent2.name) ? parent2.name : containingFunction.name;
-        break;
-      case 261 /* FunctionDeclaration */:
-      case 173 /* MethodDeclaration */:
-      case 172 /* MethodSignature */:
-        searchToken = containingFunction.name;
-        break;
-    }
-    if (!searchToken) {
-      return void 0;
-    }
-    return getReferences(searchToken, program, cancellationToken);
-  }
-  function inferTypeFromReferences(program, references, cancellationToken) {
-    const checker = program.getTypeChecker();
-    const builtinConstructors = {
-      string: () => checker.getStringType(),
-      number: () => checker.getNumberType(),
-      Array: (t) => checker.createArrayType(t),
-      Promise: (t) => checker.createPromiseType(t)
-    };
-    const builtins = [
-      checker.getStringType(),
-      checker.getNumberType(),
-      checker.createArrayType(checker.getAnyType()),
-      checker.createPromiseType(checker.getAnyType())
-    ];
-    return {
-      single: single2,
-      parameters,
-      thisParameter
-    };
-    function createEmptyUsage() {
-      return {
-        isNumber: void 0,
-        isString: void 0,
-        isNumberOrString: void 0,
-        candidateTypes: void 0,
-        properties: void 0,
-        calls: void 0,
-        constructs: void 0,
-        numberIndex: void 0,
-        stringIndex: void 0,
-        candidateThisTypes: void 0,
-        inferredTypes: void 0
-      };
-    }
-    function combineUsages(usages) {
-      const combinedProperties = /* @__PURE__ */ new Map();
-      for (const u of usages) {
-        if (u.properties) {
-          u.properties.forEach((p, name) => {
-            if (!combinedProperties.has(name)) {
-              combinedProperties.set(name, []);
-            }
-            combinedProperties.get(name).push(p);
-          });
-        }
-      }
-      const properties = /* @__PURE__ */ new Map();
-      combinedProperties.forEach((ps, name) => {
-        properties.set(name, combineUsages(ps));
-      });
-      return {
-        isNumber: usages.some((u) => u.isNumber),
-        isString: usages.some((u) => u.isString),
-        isNumberOrString: usages.some((u) => u.isNumberOrString),
-        candidateTypes: flatMap(usages, (u) => u.candidateTypes),
-        properties,
-        calls: flatMap(usages, (u) => u.calls),
-        constructs: flatMap(usages, (u) => u.constructs),
-        numberIndex: forEach(usages, (u) => u.numberIndex),
-        stringIndex: forEach(usages, (u) => u.stringIndex),
-        candidateThisTypes: flatMap(usages, (u) => u.candidateThisTypes),
-        inferredTypes: void 0
-        // clear type cache
-      };
-    }
-    function single2() {
-      return combineTypes(inferTypesFromReferencesSingle(references));
-    }
-    function parameters(declaration) {
-      if (references.length === 0 || !declaration.parameters) {
-        return void 0;
-      }
-      const usage = createEmptyUsage();
-      for (const reference of references) {
-        cancellationToken.throwIfCancellationRequested();
-        calculateUsageOfNode(reference, usage);
-      }
-      const calls = [...usage.constructs || [], ...usage.calls || []];
-      return declaration.parameters.map((parameter, parameterIndex) => {
-        const types = [];
-        const isRest = isRestParameter(parameter);
-        let isOptional = false;
-        for (const call of calls) {
-          if (call.argumentTypes.length <= parameterIndex) {
-            isOptional = isInJSFile(declaration);
-            types.push(checker.getUndefinedType());
-          } else if (isRest) {
-            for (let i = parameterIndex; i < call.argumentTypes.length; i++) {
-              types.push(checker.getBaseTypeOfLiteralType(call.argumentTypes[i]));
-            }
-          } else {
-            types.push(checker.getBaseTypeOfLiteralType(call.argumentTypes[parameterIndex]));
-          }
-        }
-        if (isIdentifier(parameter.name)) {
-          const inferred = inferTypesFromReferencesSingle(getReferences(parameter.name, program, cancellationToken));
-          types.push(...isRest ? mapDefined(inferred, checker.getElementTypeOfArrayType) : inferred);
-        }
-        const type = combineTypes(types);
-        return {
-          type: isRest ? checker.createArrayType(type) : type,
-          isOptional: isOptional && !isRest,
-          declaration: parameter
-        };
-      });
-    }
-    function thisParameter() {
-      const usage = createEmptyUsage();
-      for (const reference of references) {
-        cancellationToken.throwIfCancellationRequested();
-        calculateUsageOfNode(reference, usage);
-      }
-      return combineTypes(usage.candidateThisTypes || emptyArray);
-    }
-    function inferTypesFromReferencesSingle(references2) {
-      const usage = createEmptyUsage();
-      for (const reference of references2) {
-        cancellationToken.throwIfCancellationRequested();
-        calculateUsageOfNode(reference, usage);
-      }
-      return inferTypes(usage);
-    }
-    function calculateUsageOfNode(node, usage) {
-      while (isRightSideOfQualifiedNameOrPropertyAccess(node)) {
-        node = node.parent;
-      }
-      switch (node.parent.kind) {
-        case 243 /* ExpressionStatement */:
-          inferTypeFromExpressionStatement(node, usage);
-          break;
-        case 224 /* PostfixUnaryExpression */:
-          usage.isNumber = true;
-          break;
-        case 223 /* PrefixUnaryExpression */:
-          inferTypeFromPrefixUnaryExpression(node.parent, usage);
-          break;
-        case 225 /* BinaryExpression */:
-          inferTypeFromBinaryExpression(node, node.parent, usage);
-          break;
-        case 295 /* CaseClause */:
-        case 296 /* DefaultClause */:
-          inferTypeFromSwitchStatementLabel(node.parent, usage);
-          break;
-        case 212 /* CallExpression */:
-        case 213 /* NewExpression */:
-          if (node.parent.expression === node) {
-            inferTypeFromCallExpression(node.parent, usage);
-          } else {
-            inferTypeFromContextualType(node, usage);
-          }
-          break;
-        case 210 /* PropertyAccessExpression */:
-          inferTypeFromPropertyAccessExpression(node.parent, usage);
-          break;
-        case 211 /* ElementAccessExpression */:
-          inferTypeFromPropertyElementExpression(node.parent, node, usage);
-          break;
-        case 302 /* PropertyAssignment */:
-        case 303 /* ShorthandPropertyAssignment */:
-          inferTypeFromPropertyAssignment(node.parent, usage);
-          break;
-        case 171 /* PropertyDeclaration */:
-          inferTypeFromPropertyDeclaration(node.parent, usage);
-          break;
-        case 259 /* VariableDeclaration */: {
-          const { name, initializer } = node.parent;
-          if (node === name) {
-            if (initializer) {
-              addCandidateType(usage, checker.getTypeAtLocation(initializer));
-            }
-            break;
-          }
-        }
-        default:
-          return inferTypeFromContextualType(node, usage);
-      }
-    }
-    function inferTypeFromContextualType(node, usage) {
-      if (isExpressionNode(node)) {
-        addCandidateType(usage, checker.getContextualType(node));
-      }
-    }
-    function inferTypeFromExpressionStatement(node, usage) {
-      addCandidateType(usage, isCallExpression(node) ? checker.getVoidType() : checker.getAnyType());
-    }
-    function inferTypeFromPrefixUnaryExpression(node, usage) {
-      switch (node.operator) {
-        case 46 /* PlusPlusToken */:
-        case 47 /* MinusMinusToken */:
-        case 41 /* MinusToken */:
-        case 55 /* TildeToken */:
-          usage.isNumber = true;
-          break;
-        case 40 /* PlusToken */:
-          usage.isNumberOrString = true;
-          break;
-      }
-    }
-    function inferTypeFromBinaryExpression(node, parent2, usage) {
-      switch (parent2.operatorToken.kind) {
-        case 43 /* AsteriskAsteriskToken */:
-        case 42 /* AsteriskToken */:
-        case 44 /* SlashToken */:
-        case 45 /* PercentToken */:
-        case 48 /* LessThanLessThanToken */:
-        case 49 /* GreaterThanGreaterThanToken */:
-        case 50 /* GreaterThanGreaterThanGreaterThanToken */:
-        case 51 /* AmpersandToken */:
-        case 52 /* BarToken */:
-        case 53 /* CaretToken */:
-        case 66 /* MinusEqualsToken */:
-        case 68 /* AsteriskAsteriskEqualsToken */:
-        case 67 /* AsteriskEqualsToken */:
-        case 69 /* SlashEqualsToken */:
-        case 70 /* PercentEqualsToken */:
-        case 74 /* AmpersandEqualsToken */:
-        case 75 /* BarEqualsToken */:
-        case 79 /* CaretEqualsToken */:
-        case 71 /* LessThanLessThanEqualsToken */:
-        case 73 /* GreaterThanGreaterThanGreaterThanEqualsToken */:
-        case 72 /* GreaterThanGreaterThanEqualsToken */:
-        case 41 /* MinusToken */:
-        case 30 /* LessThanToken */:
-        case 33 /* LessThanEqualsToken */:
-        case 32 /* GreaterThanToken */:
-        case 34 /* GreaterThanEqualsToken */:
-          const operandType = checker.getTypeAtLocation(parent2.left === node ? parent2.right : parent2.left);
-          if (operandType.flags & 1056 /* EnumLike */) {
-            addCandidateType(usage, operandType);
-          } else {
-            usage.isNumber = true;
-          }
-          break;
-        case 65 /* PlusEqualsToken */:
-        case 40 /* PlusToken */:
-          const otherOperandType = checker.getTypeAtLocation(parent2.left === node ? parent2.right : parent2.left);
-          if (otherOperandType.flags & 1056 /* EnumLike */) {
-            addCandidateType(usage, otherOperandType);
-          } else if (otherOperandType.flags & 296 /* NumberLike */) {
-            usage.isNumber = true;
-          } else if (otherOperandType.flags & 402653316 /* StringLike */) {
-            usage.isString = true;
-          } else if (otherOperandType.flags & 1 /* Any */) {
-          } else {
-            usage.isNumberOrString = true;
-          }
-          break;
-        case 64 /* EqualsToken */:
-        case 35 /* EqualsEqualsToken */:
-        case 37 /* EqualsEqualsEqualsToken */:
-        case 38 /* ExclamationEqualsEqualsToken */:
-        case 36 /* ExclamationEqualsToken */:
-        case 77 /* AmpersandAmpersandEqualsToken */:
-        case 78 /* QuestionQuestionEqualsToken */:
-        case 76 /* BarBarEqualsToken */:
-          addCandidateType(usage, checker.getTypeAtLocation(parent2.left === node ? parent2.right : parent2.left));
-          break;
-        case 103 /* InKeyword */:
-          if (node === parent2.left) {
-            usage.isString = true;
-          }
-          break;
-        case 57 /* BarBarToken */:
-        case 61 /* QuestionQuestionToken */:
-          if (node === parent2.left && (node.parent.parent.kind === 259 /* VariableDeclaration */ || isAssignmentExpression(
-            node.parent.parent,
-            /*excludeCompoundAssignment*/
-            true
-          ))) {
-            addCandidateType(usage, checker.getTypeAtLocation(parent2.right));
-          }
-          break;
-        case 56 /* AmpersandAmpersandToken */:
-        case 28 /* CommaToken */:
-        case 104 /* InstanceOfKeyword */:
-          break;
-      }
-    }
-    function inferTypeFromSwitchStatementLabel(parent2, usage) {
-      addCandidateType(usage, checker.getTypeAtLocation(parent2.parent.parent.expression));
-    }
-    function inferTypeFromCallExpression(parent2, usage) {
-      const call = {
-        argumentTypes: [],
-        return_: createEmptyUsage()
-      };
-      if (parent2.arguments) {
-        for (const argument of parent2.arguments) {
-          call.argumentTypes.push(checker.getTypeAtLocation(argument));
-        }
-      }
-      calculateUsageOfNode(parent2, call.return_);
-      if (parent2.kind === 212 /* CallExpression */) {
-        (usage.calls || (usage.calls = [])).push(call);
-      } else {
-        (usage.constructs || (usage.constructs = [])).push(call);
-      }
-    }
-    function inferTypeFromPropertyAccessExpression(parent2, usage) {
-      const name = escapeLeadingUnderscores(parent2.name.text);
-      if (!usage.properties) {
-        usage.properties = /* @__PURE__ */ new Map();
-      }
-      const propertyUsage = usage.properties.get(name) || createEmptyUsage();
-      calculateUsageOfNode(parent2, propertyUsage);
-      usage.properties.set(name, propertyUsage);
-    }
-    function inferTypeFromPropertyElementExpression(parent2, node, usage) {
-      if (node === parent2.argumentExpression) {
-        usage.isNumberOrString = true;
-        return;
-      } else {
-        const indexType = checker.getTypeAtLocation(parent2.argumentExpression);
-        const indexUsage = createEmptyUsage();
-        calculateUsageOfNode(parent2, indexUsage);
-        if (indexType.flags & 296 /* NumberLike */) {
-          usage.numberIndex = indexUsage;
-        } else {
-          usage.stringIndex = indexUsage;
-        }
-      }
-    }
-    function inferTypeFromPropertyAssignment(assignment, usage) {
-      const nodeWithRealType = isVariableDeclaration(assignment.parent.parent) ? assignment.parent.parent : assignment.parent;
-      addCandidateThisType(usage, checker.getTypeAtLocation(nodeWithRealType));
-    }
-    function inferTypeFromPropertyDeclaration(declaration, usage) {
-      addCandidateThisType(usage, checker.getTypeAtLocation(declaration.parent));
-    }
-    function removeLowPriorityInferences(inferences, priorities) {
-      const toRemove = [];
-      for (const i of inferences) {
-        for (const { high, low } of priorities) {
-          if (high(i)) {
-            Debug.assert(!low(i), "Priority can't have both low and high");
-            toRemove.push(low);
-          }
-        }
-      }
-      return inferences.filter((i) => toRemove.every((f) => !f(i)));
-    }
-    function combineFromUsage(usage) {
-      return combineTypes(inferTypes(usage));
-    }
-    function combineTypes(inferences) {
-      if (!inferences.length)
-        return checker.getAnyType();
-      const stringNumber = checker.getUnionType([checker.getStringType(), checker.getNumberType()]);
-      const priorities = [
-        {
-          high: (t) => t === checker.getStringType() || t === checker.getNumberType(),
-          low: (t) => t === stringNumber
-        },
-        {
-          high: (t) => !(t.flags & (1 /* Any */ | 16384 /* Void */)),
-          low: (t) => !!(t.flags & (1 /* Any */ | 16384 /* Void */))
-        },
-        {
-          high: (t) => !(t.flags & (98304 /* Nullable */ | 1 /* Any */ | 16384 /* Void */)) && !(getObjectFlags(t) & 16 /* Anonymous */),
-          low: (t) => !!(getObjectFlags(t) & 16 /* Anonymous */)
-        }
-      ];
-      let good = removeLowPriorityInferences(inferences, priorities);
-      const anons = good.filter((i) => getObjectFlags(i) & 16 /* Anonymous */);
-      if (anons.length) {
-        good = good.filter((i) => !(getObjectFlags(i) & 16 /* Anonymous */));
-        good.push(combineAnonymousTypes(anons));
-      }
-      return checker.getWidenedType(checker.getUnionType(good.map(checker.getBaseTypeOfLiteralType), 2 /* Subtype */));
-    }
-    function combineAnonymousTypes(anons) {
-      if (anons.length === 1) {
-        return anons[0];
-      }
-      const calls = [];
-      const constructs = [];
-      const stringIndices = [];
-      const numberIndices = [];
-      let stringIndexReadonly = false;
-      let numberIndexReadonly = false;
-      const props = createMultiMap();
-      for (const anon2 of anons) {
-        for (const p of checker.getPropertiesOfType(anon2)) {
-          props.add(p.escapedName, p.valueDeclaration ? checker.getTypeOfSymbolAtLocation(p, p.valueDeclaration) : checker.getAnyType());
-        }
-        calls.push(...checker.getSignaturesOfType(anon2, 0 /* Call */));
-        constructs.push(...checker.getSignaturesOfType(anon2, 1 /* Construct */));
-        const stringIndexInfo = checker.getIndexInfoOfType(anon2, 0 /* String */);
-        if (stringIndexInfo) {
-          stringIndices.push(stringIndexInfo.type);
-          stringIndexReadonly = stringIndexReadonly || stringIndexInfo.isReadonly;
-        }
-        const numberIndexInfo = checker.getIndexInfoOfType(anon2, 1 /* Number */);
-        if (numberIndexInfo) {
-          numberIndices.push(numberIndexInfo.type);
-          numberIndexReadonly = numberIndexReadonly || numberIndexInfo.isReadonly;
-        }
-      }
-      const members = mapEntries(props, (name, types) => {
-        const isOptional = types.length < anons.length ? 16777216 /* Optional */ : 0;
-        const s = checker.createSymbol(4 /* Property */ | isOptional, name);
-        s.links.type = checker.getUnionType(types);
-        return [name, s];
-      });
-      const indexInfos = [];
-      if (stringIndices.length)
-        indexInfos.push(checker.createIndexInfo(checker.getStringType(), checker.getUnionType(stringIndices), stringIndexReadonly));
-      if (numberIndices.length)
-        indexInfos.push(checker.createIndexInfo(checker.getNumberType(), checker.getUnionType(numberIndices), numberIndexReadonly));
-      return checker.createAnonymousType(
-        anons[0].symbol,
-        members,
-        calls,
-        constructs,
-        indexInfos
-      );
-    }
-    function inferTypes(usage) {
-      var _a, _b, _c;
-      const types = [];
-      if (usage.isNumber) {
-        types.push(checker.getNumberType());
-      }
-      if (usage.isString) {
-        types.push(checker.getStringType());
-      }
-      if (usage.isNumberOrString) {
-        types.push(checker.getUnionType([checker.getStringType(), checker.getNumberType()]));
-      }
-      if (usage.numberIndex) {
-        types.push(checker.createArrayType(combineFromUsage(usage.numberIndex)));
-      }
-      if (((_a = usage.properties) == null ? void 0 : _a.size) || ((_b = usage.constructs) == null ? void 0 : _b.length) || usage.stringIndex) {
-        types.push(inferStructuralType(usage));
-      }
-      const candidateTypes = (usage.candidateTypes || []).map((t) => checker.getBaseTypeOfLiteralType(t));
-      const callsType = ((_c = usage.calls) == null ? void 0 : _c.length) ? inferStructuralType(usage) : void 0;
-      if (callsType && candidateTypes) {
-        types.push(checker.getUnionType([callsType, ...candidateTypes], 2 /* Subtype */));
-      } else {
-        if (callsType) {
-          types.push(callsType);
-        }
-        if (length(candidateTypes)) {
-          types.push(...candidateTypes);
-        }
-      }
-      types.push(...inferNamedTypesFromProperties(usage));
-      return types;
-    }
-    function inferStructuralType(usage) {
-      const members = /* @__PURE__ */ new Map();
-      if (usage.properties) {
-        usage.properties.forEach((u, name) => {
-          const symbol = checker.createSymbol(4 /* Property */, name);
-          symbol.links.type = combineFromUsage(u);
-          members.set(name, symbol);
-        });
-      }
-      const callSignatures = usage.calls ? [getSignatureFromCalls(usage.calls)] : [];
-      const constructSignatures = usage.constructs ? [getSignatureFromCalls(usage.constructs)] : [];
-      const indexInfos = usage.stringIndex ? [checker.createIndexInfo(
-        checker.getStringType(),
-        combineFromUsage(usage.stringIndex),
-        /*isReadonly*/
-        false
-      )] : [];
-      return checker.createAnonymousType(
-        /*symbol*/
-        void 0,
-        members,
-        callSignatures,
-        constructSignatures,
-        indexInfos
-      );
-    }
-    function inferNamedTypesFromProperties(usage) {
-      if (!usage.properties || !usage.properties.size)
-        return [];
-      const types = builtins.filter((t) => allPropertiesAreAssignableToUsage(t, usage));
-      if (0 < types.length && types.length < 3) {
-        return types.map((t) => inferInstantiationFromUsage(t, usage));
-      }
-      return [];
-    }
-    function allPropertiesAreAssignableToUsage(type, usage) {
-      if (!usage.properties)
-        return false;
-      return !forEachEntry(usage.properties, (propUsage, name) => {
-        const source = checker.getTypeOfPropertyOfType(type, name);
-        if (!source) {
-          return true;
-        }
-        if (propUsage.calls) {
-          const sigs = checker.getSignaturesOfType(source, 0 /* Call */);
-          return !sigs.length || !checker.isTypeAssignableTo(source, getFunctionFromCalls(propUsage.calls));
-        } else {
-          return !checker.isTypeAssignableTo(source, combineFromUsage(propUsage));
-        }
-      });
-    }
-    function inferInstantiationFromUsage(type, usage) {
-      if (!(getObjectFlags(type) & 4 /* Reference */) || !usage.properties) {
-        return type;
-      }
-      const generic = type.target;
-      const singleTypeParameter = singleOrUndefined(generic.typeParameters);
-      if (!singleTypeParameter)
-        return type;
-      const types = [];
-      usage.properties.forEach((propUsage, name) => {
-        const genericPropertyType = checker.getTypeOfPropertyOfType(generic, name);
-        Debug.assert(!!genericPropertyType, "generic should have all the properties of its reference.");
-        types.push(...inferTypeParameters(genericPropertyType, combineFromUsage(propUsage), singleTypeParameter));
-      });
-      return builtinConstructors[type.symbol.escapedName](combineTypes(types));
-    }
-    function inferTypeParameters(genericType, usageType, typeParameter) {
-      if (genericType === typeParameter) {
-        return [usageType];
-      } else if (genericType.flags & 3145728 /* UnionOrIntersection */) {
-        return flatMap(genericType.types, (t) => inferTypeParameters(t, usageType, typeParameter));
-      } else if (getObjectFlags(genericType) & 4 /* Reference */ && getObjectFlags(usageType) & 4 /* Reference */) {
-        const genericArgs = checker.getTypeArguments(genericType);
-        const usageArgs = checker.getTypeArguments(usageType);
-        const types = [];
-        if (genericArgs && usageArgs) {
-          for (let i = 0; i < genericArgs.length; i++) {
-            if (usageArgs[i]) {
-              types.push(...inferTypeParameters(genericArgs[i], usageArgs[i], typeParameter));
-            }
-          }
-        }
-        return types;
-      }
-      const genericSigs = checker.getSignaturesOfType(genericType, 0 /* Call */);
-      const usageSigs = checker.getSignaturesOfType(usageType, 0 /* Call */);
-      if (genericSigs.length === 1 && usageSigs.length === 1) {
-        return inferFromSignatures(genericSigs[0], usageSigs[0], typeParameter);
-      }
-      return [];
-    }
-    function inferFromSignatures(genericSig, usageSig, typeParameter) {
-      var _a;
-      const types = [];
-      for (let i = 0; i < genericSig.parameters.length; i++) {
-        const genericParam = genericSig.parameters[i];
-        const usageParam = usageSig.parameters[i];
-        const isRest = genericSig.declaration && isRestParameter(genericSig.declaration.parameters[i]);
-        if (!usageParam) {
-          break;
-        }
-        let genericParamType = genericParam.valueDeclaration ? checker.getTypeOfSymbolAtLocation(genericParam, genericParam.valueDeclaration) : checker.getAnyType();
-        const elementType = isRest && checker.getElementTypeOfArrayType(genericParamType);
-        if (elementType) {
-          genericParamType = elementType;
-        }
-        const targetType = ((_a = tryCast(usageParam, isTransientSymbol)) == null ? void 0 : _a.links.type) || (usageParam.valueDeclaration ? checker.getTypeOfSymbolAtLocation(usageParam, usageParam.valueDeclaration) : checker.getAnyType());
-        types.push(...inferTypeParameters(genericParamType, targetType, typeParameter));
-      }
-      const genericReturn = checker.getReturnTypeOfSignature(genericSig);
-      const usageReturn = checker.getReturnTypeOfSignature(usageSig);
-      types.push(...inferTypeParameters(genericReturn, usageReturn, typeParameter));
-      return types;
-    }
-    function getFunctionFromCalls(calls) {
-      return checker.createAnonymousType(
-        /*symbol*/
-        void 0,
-        createSymbolTable(),
-        [getSignatureFromCalls(calls)],
-        emptyArray,
-        emptyArray
-      );
-    }
-    function getSignatureFromCalls(calls) {
-      const parameters2 = [];
-      const length2 = Math.max(...calls.map((c) => c.argumentTypes.length));
-      for (let i = 0; i < length2; i++) {
-        const symbol = checker.createSymbol(1 /* FunctionScopedVariable */, escapeLeadingUnderscores(`arg${i}`));
-        symbol.links.type = combineTypes(calls.map((call) => call.argumentTypes[i] || checker.getUndefinedType()));
-        if (calls.some((call) => call.argumentTypes[i] === void 0)) {
-          symbol.flags |= 16777216 /* Optional */;
-        }
-        parameters2.push(symbol);
-      }
-      const returnType = combineFromUsage(combineUsages(calls.map((call) => call.return_)));
-      return checker.createSignature(
-        /*declaration*/
-        void 0,
-        /*typeParameters*/
-        void 0,
-        /*thisParameter*/
-        void 0,
-        parameters2,
-        returnType,
-        /*typePredicate*/
-        void 0,
-        length2,
-        0 /* None */
-      );
-    }
-    function addCandidateType(usage, type) {
-      if (type && !(type.flags & 1 /* Any */) && !(type.flags & 131072 /* Never */)) {
-        (usage.candidateTypes || (usage.candidateTypes = [])).push(type);
-      }
-    }
-    function addCandidateThisType(usage, type) {
-      if (type && !(type.flags & 1 /* Any */) && !(type.flags & 131072 /* Never */)) {
-        (usage.candidateThisTypes || (usage.candidateThisTypes = [])).push(type);
-      }
-    }
-  }
-  var fixId38, errorCodes48;
-  var init_inferFromUsage = __esm({
-    "src/services/codefixes/inferFromUsage.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_codefix();
-      fixId38 = "inferFromUsage";
-      errorCodes48 = [
-        // Variable declarations
-        Diagnostics.Variable_0_implicitly_has_type_1_in_some_locations_where_its_type_cannot_be_determined.code,
-        // Variable uses
-        Diagnostics.Variable_0_implicitly_has_an_1_type.code,
-        // Parameter declarations
-        Diagnostics.Parameter_0_implicitly_has_an_1_type.code,
-        Diagnostics.Rest_parameter_0_implicitly_has_an_any_type.code,
-        // Get Accessor declarations
-        Diagnostics.Property_0_implicitly_has_type_any_because_its_get_accessor_lacks_a_return_type_annotation.code,
-        Diagnostics._0_which_lacks_return_type_annotation_implicitly_has_an_1_return_type.code,
-        // Set Accessor declarations
-        Diagnostics.Property_0_implicitly_has_type_any_because_its_set_accessor_lacks_a_parameter_type_annotation.code,
-        // Property declarations
-        Diagnostics.Member_0_implicitly_has_an_1_type.code,
-        //// Suggestions
-        // Variable declarations
-        Diagnostics.Variable_0_implicitly_has_type_1_in_some_locations_but_a_better_type_may_be_inferred_from_usage.code,
-        // Variable uses
-        Diagnostics.Variable_0_implicitly_has_an_1_type_but_a_better_type_may_be_inferred_from_usage.code,
-        // Parameter declarations
-        Diagnostics.Parameter_0_implicitly_has_an_1_type_but_a_better_type_may_be_inferred_from_usage.code,
-        Diagnostics.Rest_parameter_0_implicitly_has_an_any_type_but_a_better_type_may_be_inferred_from_usage.code,
-        // Get Accessor declarations
-        Diagnostics.Property_0_implicitly_has_type_any_but_a_better_type_for_its_get_accessor_may_be_inferred_from_usage.code,
-        Diagnostics._0_implicitly_has_an_1_return_type_but_a_better_type_may_be_inferred_from_usage.code,
-        // Set Accessor declarations
-        Diagnostics.Property_0_implicitly_has_type_any_but_a_better_type_for_its_set_accessor_may_be_inferred_from_usage.code,
-        // Property declarations
-        Diagnostics.Member_0_implicitly_has_an_1_type_but_a_better_type_may_be_inferred_from_usage.code,
-        // Function expressions and declarations
-        Diagnostics.this_implicitly_has_type_any_because_it_does_not_have_a_type_annotation.code
-      ];
-      registerCodeFix({
-        errorCodes: errorCodes48,
-        getCodeActions(context) {
-          const { sourceFile, program, span: { start }, errorCode, cancellationToken, host, preferences } = context;
-          const token = getTokenAtPosition(sourceFile, start);
-          let declaration;
-          const changes = ts_textChanges_exports.ChangeTracker.with(context, (changes2) => {
-            declaration = doChange32(
-              changes2,
-              sourceFile,
-              token,
-              errorCode,
-              program,
-              cancellationToken,
-              /*markSeen*/
-              returnTrue,
-              host,
-              preferences
-            );
-          });
-          const name = declaration && getNameOfDeclaration(declaration);
-          return !name || changes.length === 0 ? void 0 : [createCodeFixAction(fixId38, changes, [getDiagnostic(errorCode, token), getTextOfNode(name)], fixId38, Diagnostics.Infer_all_types_from_usage)];
-        },
-        fixIds: [fixId38],
-        getAllCodeActions(context) {
-          const { sourceFile, program, cancellationToken, host, preferences } = context;
-          const markSeen = nodeSeenTracker();
-          return codeFixAll(context, errorCodes48, (changes, err) => {
-            doChange32(changes, sourceFile, getTokenAtPosition(err.file, err.start), err.code, program, cancellationToken, markSeen, host, preferences);
-          });
-        }
-      });
-    }
-  });
-
-  // src/services/codefixes/fixReturnTypeInAsyncFunction.ts
-  function getInfo15(sourceFile, checker, pos) {
-    if (isInJSFile(sourceFile)) {
-      return void 0;
-    }
-    const token = getTokenAtPosition(sourceFile, pos);
-    const func = findAncestor(token, isFunctionLikeDeclaration);
-    const returnTypeNode = func == null ? void 0 : func.type;
-    if (!returnTypeNode) {
-      return void 0;
-    }
-    const returnType = checker.getTypeFromTypeNode(returnTypeNode);
-    const promisedType = checker.getAwaitedType(returnType) || checker.getVoidType();
-    const promisedTypeNode = checker.typeToTypeNode(
-      promisedType,
-      /*enclosingDeclaration*/
-      returnTypeNode,
-      /*flags*/
-      void 0
-    );
-    if (promisedTypeNode) {
-      return { returnTypeNode, returnType, promisedTypeNode, promisedType };
-    }
-  }
-  function doChange33(changes, sourceFile, returnTypeNode, promisedTypeNode) {
-    changes.replaceNode(sourceFile, returnTypeNode, factory.createTypeReferenceNode("Promise", [promisedTypeNode]));
-  }
-  var fixId39, errorCodes49;
-  var init_fixReturnTypeInAsyncFunction = __esm({
-    "src/services/codefixes/fixReturnTypeInAsyncFunction.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_codefix();
-      fixId39 = "fixReturnTypeInAsyncFunction";
-      errorCodes49 = [
-        Diagnostics.The_return_type_of_an_async_function_or_method_must_be_the_global_Promise_T_type_Did_you_mean_to_write_Promise_0.code
-      ];
-      registerCodeFix({
-        errorCodes: errorCodes49,
-        fixIds: [fixId39],
-        getCodeActions: function getCodeActionsToFixReturnTypeInAsyncFunction(context) {
-          const { sourceFile, program, span } = context;
-          const checker = program.getTypeChecker();
-          const info = getInfo15(sourceFile, program.getTypeChecker(), span.start);
-          if (!info) {
-            return void 0;
-          }
-          const { returnTypeNode, returnType, promisedTypeNode, promisedType } = info;
-          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange33(t, sourceFile, returnTypeNode, promisedTypeNode));
-          return [createCodeFixAction(
-            fixId39,
-            changes,
-            [
-              Diagnostics.Replace_0_with_Promise_1,
-              checker.typeToString(returnType),
-              checker.typeToString(promisedType)
-            ],
-            fixId39,
-            Diagnostics.Fix_all_incorrect_return_type_of_an_async_functions
-          )];
-        },
-        getAllCodeActions: (context) => codeFixAll(context, errorCodes49, (changes, diag2) => {
-          const info = getInfo15(diag2.file, context.program.getTypeChecker(), diag2.start);
-          if (info) {
-            doChange33(changes, diag2.file, info.returnTypeNode, info.promisedTypeNode);
-          }
-        })
-      });
-    }
-  });
-
-  // src/services/codefixes/disableJsDiagnostics.ts
-  function makeChange8(changes, sourceFile, position, seenLines) {
-    const { line: lineNumber } = getLineAndCharacterOfPosition(sourceFile, position);
-    if (!seenLines || tryAddToSet(seenLines, lineNumber)) {
-      changes.insertCommentBeforeLine(sourceFile, lineNumber, position, " @ts-ignore");
-    }
-  }
-  var fixName4, fixId40, errorCodes50;
-  var init_disableJsDiagnostics = __esm({
-    "src/services/codefixes/disableJsDiagnostics.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_codefix();
-      fixName4 = "disableJsDiagnostics";
-      fixId40 = "disableJsDiagnostics";
-      errorCodes50 = mapDefined(Object.keys(Diagnostics), (key) => {
-        const diag2 = Diagnostics[key];
-        return diag2.category === 1 /* Error */ ? diag2.code : void 0;
-      });
-      registerCodeFix({
-        errorCodes: errorCodes50,
-        getCodeActions: function getCodeActionsToDisableJsDiagnostics(context) {
-          const { sourceFile, program, span, host, formatContext } = context;
-          if (!isInJSFile(sourceFile) || !isCheckJsEnabledForFile(sourceFile, program.getCompilerOptions())) {
-            return void 0;
-          }
-          const newLineCharacter = sourceFile.checkJsDirective ? "" : getNewLineOrDefaultFromHost(host, formatContext.options);
-          const fixes = [
-            // fixId unnecessary because adding `// @ts-nocheck` even once will ignore every error in the file.
-            createCodeFixActionWithoutFixAll(
-              fixName4,
-              [createFileTextChanges(sourceFile.fileName, [
-                createTextChange(sourceFile.checkJsDirective ? createTextSpanFromBounds(sourceFile.checkJsDirective.pos, sourceFile.checkJsDirective.end) : createTextSpan(0, 0), `// @ts-nocheck${newLineCharacter}`)
-              ])],
-              Diagnostics.Disable_checking_for_this_file
-            )
-          ];
-          if (ts_textChanges_exports.isValidLocationToAddComment(sourceFile, span.start)) {
-            fixes.unshift(createCodeFixAction(fixName4, ts_textChanges_exports.ChangeTracker.with(context, (t) => makeChange8(t, sourceFile, span.start)), Diagnostics.Ignore_this_error_message, fixId40, Diagnostics.Add_ts_ignore_to_all_error_messages));
-          }
-          return fixes;
-        },
-        fixIds: [fixId40],
-        getAllCodeActions: (context) => {
-          const seenLines = /* @__PURE__ */ new Set();
-          return codeFixAll(context, errorCodes50, (changes, diag2) => {
-            if (ts_textChanges_exports.isValidLocationToAddComment(diag2.file, diag2.start)) {
-              makeChange8(changes, diag2.file, diag2.start, seenLines);
-            }
-          });
-        }
-      });
-    }
-  });
-
-  // src/services/codefixes/helpers.ts
-  function createMissingMemberNodes(classDeclaration, possiblyMissingSymbols, sourceFile, context, preferences, importAdder, addClassElement) {
-    const classMembers = classDeclaration.symbol.members;
-    for (const symbol of possiblyMissingSymbols) {
-      if (!classMembers.has(symbol.escapedName)) {
-        addNewNodeForMemberSymbol(
-          symbol,
-          classDeclaration,
-          sourceFile,
-          context,
-          preferences,
-          importAdder,
-          addClassElement,
-          /*body*/
-          void 0
-        );
-      }
-    }
-  }
-  function getNoopSymbolTrackerWithResolver(context) {
-    return {
-      trackSymbol: () => false,
-      moduleResolverHost: getModuleSpecifierResolverHost(context.program, context.host)
-    };
-  }
-  function addNewNodeForMemberSymbol(symbol, enclosingDeclaration, sourceFile, context, preferences, importAdder, addClassElement, body, preserveOptional = 3 /* All */, isAmbient = false) {
-    const declarations = symbol.getDeclarations();
-    const declaration = declarations == null ? void 0 : declarations[0];
-    const checker = context.program.getTypeChecker();
-    const scriptTarget = getEmitScriptTarget(context.program.getCompilerOptions());
-    const kind = (declaration == null ? void 0 : declaration.kind) ?? 170 /* PropertySignature */;
-    const declarationName = getSynthesizedDeepClone(
-      getNameOfDeclaration(declaration),
-      /*includeTrivia*/
-      false
-    );
-    const effectiveModifierFlags = declaration ? getEffectiveModifierFlags(declaration) : 0 /* None */;
-    let modifierFlags = effectiveModifierFlags & 4 /* Public */ ? 4 /* Public */ : effectiveModifierFlags & 16 /* Protected */ ? 16 /* Protected */ : 0 /* None */;
-    if (declaration && isAutoAccessorPropertyDeclaration(declaration)) {
-      modifierFlags |= 128 /* Accessor */;
-    }
-    const modifiers = createModifiers();
-    const type = checker.getWidenedType(checker.getTypeOfSymbolAtLocation(symbol, enclosingDeclaration));
-    const optional = !!(symbol.flags & 16777216 /* Optional */);
-    const ambient = !!(enclosingDeclaration.flags & 16777216 /* Ambient */) || isAmbient;
-    const quotePreference = getQuotePreference(sourceFile, preferences);
-    switch (kind) {
-      case 170 /* PropertySignature */:
-      case 171 /* PropertyDeclaration */:
-        const flags = quotePreference === 0 /* Single */ ? 268435456 /* UseSingleQuotesForStringLiteralType */ : void 0;
-        let typeNode = checker.typeToTypeNode(type, enclosingDeclaration, flags, getNoopSymbolTrackerWithResolver(context));
-        if (importAdder) {
-          const importableReference = tryGetAutoImportableReferenceFromTypeNode(typeNode, scriptTarget);
-          if (importableReference) {
-            typeNode = importableReference.typeNode;
-            importSymbols(importAdder, importableReference.symbols);
-          }
-        }
-        addClassElement(factory.createPropertyDeclaration(
-          modifiers,
-          declaration ? createName(declarationName) : symbol.getName(),
-          optional && preserveOptional & 2 /* Property */ ? factory.createToken(58 /* QuestionToken */) : void 0,
-          typeNode,
-          /*initializer*/
-          void 0
-        ));
-        break;
-      case 176 /* GetAccessor */:
-      case 177 /* SetAccessor */: {
-        Debug.assertIsDefined(declarations);
-        let typeNode2 = checker.typeToTypeNode(
-          type,
-          enclosingDeclaration,
-          /*flags*/
-          void 0,
-          getNoopSymbolTrackerWithResolver(context)
-        );
-        const allAccessors = getAllAccessorDeclarations(declarations, declaration);
-        const orderedAccessors = allAccessors.secondAccessor ? [allAccessors.firstAccessor, allAccessors.secondAccessor] : [allAccessors.firstAccessor];
-        if (importAdder) {
-          const importableReference = tryGetAutoImportableReferenceFromTypeNode(typeNode2, scriptTarget);
-          if (importableReference) {
-            typeNode2 = importableReference.typeNode;
-            importSymbols(importAdder, importableReference.symbols);
-          }
-        }
-        for (const accessor of orderedAccessors) {
-          if (isGetAccessorDeclaration(accessor)) {
-            addClassElement(factory.createGetAccessorDeclaration(
-              modifiers,
-              createName(declarationName),
-              emptyArray,
-              createTypeNode(typeNode2),
-              createBody(body, quotePreference, ambient)
-            ));
-          } else {
-            Debug.assertNode(accessor, isSetAccessorDeclaration, "The counterpart to a getter should be a setter");
-            const parameter = getSetAccessorValueParameter(accessor);
-            const parameterName = parameter && isIdentifier(parameter.name) ? idText(parameter.name) : void 0;
-            addClassElement(factory.createSetAccessorDeclaration(
-              modifiers,
-              createName(declarationName),
-              createDummyParameters(
-                1,
-                [parameterName],
-                [createTypeNode(typeNode2)],
-                1,
-                /*inJs*/
-                false
-              ),
-              createBody(body, quotePreference, ambient)
-            ));
-          }
-        }
-        break;
-      }
-      case 172 /* MethodSignature */:
-      case 173 /* MethodDeclaration */:
-        Debug.assertIsDefined(declarations);
-        const signatures = type.isUnion() ? flatMap(type.types, (t) => t.getCallSignatures()) : type.getCallSignatures();
-        if (!some(signatures)) {
-          break;
-        }
-        if (declarations.length === 1) {
-          Debug.assert(signatures.length === 1, "One declaration implies one signature");
-          const signature = signatures[0];
-          outputMethod(quotePreference, signature, modifiers, createName(declarationName), createBody(body, quotePreference, ambient));
-          break;
-        }
-        for (const signature of signatures) {
-          outputMethod(quotePreference, signature, modifiers, createName(declarationName));
-        }
-        if (!ambient) {
-          if (declarations.length > signatures.length) {
-            const signature = checker.getSignatureFromDeclaration(declarations[declarations.length - 1]);
-            outputMethod(quotePreference, signature, modifiers, createName(declarationName), createBody(body, quotePreference));
-          } else {
-            Debug.assert(declarations.length === signatures.length, "Declarations and signatures should match count");
-            addClassElement(createMethodImplementingSignatures(checker, context, enclosingDeclaration, signatures, createName(declarationName), optional && !!(preserveOptional & 1 /* Method */), modifiers, quotePreference, body));
-          }
-        }
-        break;
-    }
-    function outputMethod(quotePreference2, signature, modifiers2, name, body2) {
-      const method = createSignatureDeclarationFromSignature(173 /* MethodDeclaration */, context, quotePreference2, signature, body2, name, modifiers2, optional && !!(preserveOptional & 1 /* Method */), enclosingDeclaration, importAdder);
-      if (method)
-        addClassElement(method);
-    }
-    function createModifiers() {
-      let modifiers2;
-      if (modifierFlags) {
-        modifiers2 = combine(modifiers2, factory.createModifiersFromModifierFlags(modifierFlags));
-      }
-      if (shouldAddOverrideKeyword()) {
-        modifiers2 = append(modifiers2, factory.createToken(163 /* OverrideKeyword */));
-      }
-      return modifiers2 && factory.createNodeArray(modifiers2);
-    }
-    function shouldAddOverrideKeyword() {
-      return !!(context.program.getCompilerOptions().noImplicitOverride && declaration && hasAbstractModifier(declaration));
-    }
-    function createName(node) {
-      if (isIdentifier(node) && node.escapedText === "constructor") {
-        return factory.createComputedPropertyName(factory.createStringLiteral(idText(node), quotePreference === 0 /* Single */));
-      }
-      return getSynthesizedDeepClone(
-        node,
-        /*includeTrivia*/
-        false
-      );
-    }
-    function createBody(block, quotePreference2, ambient2) {
-      return ambient2 ? void 0 : getSynthesizedDeepClone(
-        block,
-        /*includeTrivia*/
-        false
-      ) || createStubbedMethodBody(quotePreference2);
-    }
-    function createTypeNode(typeNode) {
-      return getSynthesizedDeepClone(
-        typeNode,
-        /*includeTrivia*/
-        false
-      );
-    }
-  }
-  function createSignatureDeclarationFromSignature(kind, context, quotePreference, signature, body, name, modifiers, optional, enclosingDeclaration, importAdder) {
-    const program = context.program;
-    const checker = program.getTypeChecker();
-    const scriptTarget = getEmitScriptTarget(program.getCompilerOptions());
-    const isJs = isInJSFile(enclosingDeclaration);
-    const flags = 1 /* NoTruncation */ | 256 /* SuppressAnyReturnType */ | 524288 /* AllowEmptyTuple */ | (quotePreference === 0 /* Single */ ? 268435456 /* UseSingleQuotesForStringLiteralType */ : 0 /* None */);
-    const signatureDeclaration = checker.signatureToSignatureDeclaration(signature, kind, enclosingDeclaration, flags, getNoopSymbolTrackerWithResolver(context));
-    if (!signatureDeclaration) {
-      return void 0;
-    }
-    let typeParameters = isJs ? void 0 : signatureDeclaration.typeParameters;
-    let parameters = signatureDeclaration.parameters;
-    let type = isJs ? void 0 : signatureDeclaration.type;
-    if (importAdder) {
-      if (typeParameters) {
-        const newTypeParameters = sameMap(typeParameters, (typeParameterDecl) => {
-          let constraint = typeParameterDecl.constraint;
-          let defaultType = typeParameterDecl.default;
-          if (constraint) {
-            const importableReference = tryGetAutoImportableReferenceFromTypeNode(constraint, scriptTarget);
-            if (importableReference) {
-              constraint = importableReference.typeNode;
-              importSymbols(importAdder, importableReference.symbols);
-            }
-          }
-          if (defaultType) {
-            const importableReference = tryGetAutoImportableReferenceFromTypeNode(defaultType, scriptTarget);
-            if (importableReference) {
-              defaultType = importableReference.typeNode;
-              importSymbols(importAdder, importableReference.symbols);
-            }
-          }
-          return factory.updateTypeParameterDeclaration(
-            typeParameterDecl,
-            typeParameterDecl.modifiers,
-            typeParameterDecl.name,
-            constraint,
-            defaultType
-          );
-        });
-        if (typeParameters !== newTypeParameters) {
-          typeParameters = setTextRange(factory.createNodeArray(newTypeParameters, typeParameters.hasTrailingComma), typeParameters);
-        }
-      }
-      const newParameters = sameMap(parameters, (parameterDecl) => {
-        let type2 = isJs ? void 0 : parameterDecl.type;
-        if (type2) {
-          const importableReference = tryGetAutoImportableReferenceFromTypeNode(type2, scriptTarget);
-          if (importableReference) {
-            type2 = importableReference.typeNode;
-            importSymbols(importAdder, importableReference.symbols);
-          }
-        }
-        return factory.updateParameterDeclaration(
-          parameterDecl,
-          parameterDecl.modifiers,
-          parameterDecl.dotDotDotToken,
-          parameterDecl.name,
-          isJs ? void 0 : parameterDecl.questionToken,
-          type2,
-          parameterDecl.initializer
-        );
-      });
-      if (parameters !== newParameters) {
-        parameters = setTextRange(factory.createNodeArray(newParameters, parameters.hasTrailingComma), parameters);
-      }
-      if (type) {
-        const importableReference = tryGetAutoImportableReferenceFromTypeNode(type, scriptTarget);
-        if (importableReference) {
-          type = importableReference.typeNode;
-          importSymbols(importAdder, importableReference.symbols);
-        }
-      }
-    }
-    const questionToken = optional ? factory.createToken(58 /* QuestionToken */) : void 0;
-    const asteriskToken = signatureDeclaration.asteriskToken;
-    if (isFunctionExpression(signatureDeclaration)) {
-      return factory.updateFunctionExpression(signatureDeclaration, modifiers, signatureDeclaration.asteriskToken, tryCast(name, isIdentifier), typeParameters, parameters, type, body ?? signatureDeclaration.body);
-    }
-    if (isArrowFunction(signatureDeclaration)) {
-      return factory.updateArrowFunction(signatureDeclaration, modifiers, typeParameters, parameters, type, signatureDeclaration.equalsGreaterThanToken, body ?? signatureDeclaration.body);
-    }
-    if (isMethodDeclaration(signatureDeclaration)) {
-      return factory.updateMethodDeclaration(signatureDeclaration, modifiers, asteriskToken, name ?? factory.createIdentifier(""), questionToken, typeParameters, parameters, type, body);
-    }
-    if (isFunctionDeclaration(signatureDeclaration)) {
-      return factory.updateFunctionDeclaration(signatureDeclaration, modifiers, signatureDeclaration.asteriskToken, tryCast(name, isIdentifier), typeParameters, parameters, type, body ?? signatureDeclaration.body);
-    }
-    return void 0;
-  }
-  function createSignatureDeclarationFromCallExpression(kind, context, importAdder, call, name, modifierFlags, contextNode) {
-    const quotePreference = getQuotePreference(context.sourceFile, context.preferences);
-    const scriptTarget = getEmitScriptTarget(context.program.getCompilerOptions());
-    const tracker = getNoopSymbolTrackerWithResolver(context);
-    const checker = context.program.getTypeChecker();
-    const isJs = isInJSFile(contextNode);
-    const { typeArguments, arguments: args, parent: parent2 } = call;
-    const contextualType = isJs ? void 0 : checker.getContextualType(call);
-    const names = map(args, (arg) => isIdentifier(arg) ? arg.text : isPropertyAccessExpression(arg) && isIdentifier(arg.name) ? arg.name.text : void 0);
-    const instanceTypes = isJs ? [] : map(args, (arg) => checker.getTypeAtLocation(arg));
-    const { argumentTypeNodes, argumentTypeParameters } = getArgumentTypesAndTypeParameters(
-      checker,
-      importAdder,
-      instanceTypes,
-      contextNode,
-      scriptTarget,
-      /*flags*/
-      void 0,
-      tracker
-    );
-    const modifiers = modifierFlags ? factory.createNodeArray(factory.createModifiersFromModifierFlags(modifierFlags)) : void 0;
-    const asteriskToken = isYieldExpression(parent2) ? factory.createToken(42 /* AsteriskToken */) : void 0;
-    const typeParameters = isJs ? void 0 : createTypeParametersForArguments(checker, argumentTypeParameters, typeArguments);
-    const parameters = createDummyParameters(
-      args.length,
-      names,
-      argumentTypeNodes,
-      /*minArgumentCount*/
-      void 0,
-      isJs
-    );
-    const type = isJs || contextualType === void 0 ? void 0 : checker.typeToTypeNode(
-      contextualType,
-      contextNode,
-      /*flags*/
-      void 0,
-      tracker
-    );
-    switch (kind) {
-      case 173 /* MethodDeclaration */:
-        return factory.createMethodDeclaration(
-          modifiers,
-          asteriskToken,
-          name,
-          /*questionToken*/
-          void 0,
-          typeParameters,
-          parameters,
-          type,
-          createStubbedMethodBody(quotePreference)
-        );
-      case 172 /* MethodSignature */:
-        return factory.createMethodSignature(
-          modifiers,
-          name,
-          /*questionToken*/
-          void 0,
-          typeParameters,
-          parameters,
-          type === void 0 ? factory.createKeywordTypeNode(159 /* UnknownKeyword */) : type
-        );
-      case 261 /* FunctionDeclaration */:
-        return factory.createFunctionDeclaration(
-          modifiers,
-          asteriskToken,
-          name,
-          typeParameters,
-          parameters,
-          type,
-          createStubbedBody(Diagnostics.Function_not_implemented.message, quotePreference)
-        );
-      default:
-        Debug.fail("Unexpected kind");
-    }
-  }
-  function createTypeParametersForArguments(checker, argumentTypeParameters, typeArguments) {
-    const usedNames = new Set(argumentTypeParameters.map((pair) => pair[0]));
-    const constraintsByName = new Map(argumentTypeParameters);
-    if (typeArguments) {
-      const typeArgumentsWithNewTypes = typeArguments.filter((typeArgument) => !argumentTypeParameters.some((pair) => {
-        var _a;
-        return checker.getTypeAtLocation(typeArgument) === ((_a = pair[1]) == null ? void 0 : _a.argumentType);
-      }));
-      const targetSize = usedNames.size + typeArgumentsWithNewTypes.length;
-      for (let i = 0; usedNames.size < targetSize; i += 1) {
-        usedNames.add(createTypeParameterName(i));
-      }
-    }
-    return arrayFrom(
-      usedNames.values(),
-      (usedName) => {
-        var _a;
-        return factory.createTypeParameterDeclaration(
-          /*modifiers*/
-          void 0,
-          usedName,
-          (_a = constraintsByName.get(usedName)) == null ? void 0 : _a.constraint
-        );
-      }
-    );
-  }
-  function createTypeParameterName(index) {
-    return 84 /* T */ + index <= 90 /* Z */ ? String.fromCharCode(84 /* T */ + index) : `T${index}`;
-  }
-  function typeToAutoImportableTypeNode(checker, importAdder, type, contextNode, scriptTarget, flags, tracker) {
-    let typeNode = checker.typeToTypeNode(type, contextNode, flags, tracker);
-    if (typeNode && isImportTypeNode(typeNode)) {
-      const importableReference = tryGetAutoImportableReferenceFromTypeNode(typeNode, scriptTarget);
-      if (importableReference) {
-        importSymbols(importAdder, importableReference.symbols);
-        typeNode = importableReference.typeNode;
-      }
-    }
-    return getSynthesizedDeepClone(typeNode);
-  }
-  function typeContainsTypeParameter(type) {
-    if (type.isUnionOrIntersection()) {
-      return type.types.some(typeContainsTypeParameter);
-    }
-    return type.flags & 262144 /* TypeParameter */;
-  }
-  function getArgumentTypesAndTypeParameters(checker, importAdder, instanceTypes, contextNode, scriptTarget, flags, tracker) {
-    const argumentTypeNodes = [];
-    const argumentTypeParameters = /* @__PURE__ */ new Map();
-    for (let i = 0; i < instanceTypes.length; i += 1) {
-      const instanceType = instanceTypes[i];
-      if (instanceType.isUnionOrIntersection() && instanceType.types.some(typeContainsTypeParameter)) {
-        const synthesizedTypeParameterName = createTypeParameterName(i);
-        argumentTypeNodes.push(factory.createTypeReferenceNode(synthesizedTypeParameterName));
-        argumentTypeParameters.set(synthesizedTypeParameterName, void 0);
-        continue;
-      }
-      const widenedInstanceType = checker.getBaseTypeOfLiteralType(instanceType);
-      const argumentTypeNode = typeToAutoImportableTypeNode(checker, importAdder, widenedInstanceType, contextNode, scriptTarget, flags, tracker);
-      if (!argumentTypeNode) {
-        continue;
-      }
-      argumentTypeNodes.push(argumentTypeNode);
-      const argumentTypeParameter = getFirstTypeParameterName(instanceType);
-      const instanceTypeConstraint = instanceType.isTypeParameter() && instanceType.constraint && !isAnonymousObjectConstraintType(instanceType.constraint) ? typeToAutoImportableTypeNode(checker, importAdder, instanceType.constraint, contextNode, scriptTarget, flags, tracker) : void 0;
-      if (argumentTypeParameter) {
-        argumentTypeParameters.set(argumentTypeParameter, { argumentType: instanceType, constraint: instanceTypeConstraint });
-      }
-    }
-    return { argumentTypeNodes, argumentTypeParameters: arrayFrom(argumentTypeParameters.entries()) };
-  }
-  function isAnonymousObjectConstraintType(type) {
-    return type.flags & 524288 /* Object */ && type.objectFlags === 16 /* Anonymous */;
-  }
-  function getFirstTypeParameterName(type) {
-    var _a;
-    if (type.flags & (1048576 /* Union */ | 2097152 /* Intersection */)) {
-      for (const subType of type.types) {
-        const subTypeName = getFirstTypeParameterName(subType);
-        if (subTypeName) {
-          return subTypeName;
-        }
-      }
-    }
-    return type.flags & 262144 /* TypeParameter */ ? (_a = type.getSymbol()) == null ? void 0 : _a.getName() : void 0;
-  }
-  function createDummyParameters(argCount, names, types, minArgumentCount, inJs) {
-    const parameters = [];
-    const parameterNameCounts = /* @__PURE__ */ new Map();
-    for (let i = 0; i < argCount; i++) {
-      const parameterName = (names == null ? void 0 : names[i]) || `arg${i}`;
-      const parameterNameCount = parameterNameCounts.get(parameterName);
-      parameterNameCounts.set(parameterName, (parameterNameCount || 0) + 1);
-      const newParameter = factory.createParameterDeclaration(
-        /*modifiers*/
-        void 0,
-        /*dotDotDotToken*/
-        void 0,
-        /*name*/
-        parameterName + (parameterNameCount || ""),
-        /*questionToken*/
-        minArgumentCount !== void 0 && i >= minArgumentCount ? factory.createToken(58 /* QuestionToken */) : void 0,
-        /*type*/
-        inJs ? void 0 : (types == null ? void 0 : types[i]) || factory.createKeywordTypeNode(159 /* UnknownKeyword */),
-        /*initializer*/
-        void 0
-      );
-      parameters.push(newParameter);
-    }
-    return parameters;
-  }
-  function createMethodImplementingSignatures(checker, context, enclosingDeclaration, signatures, name, optional, modifiers, quotePreference, body) {
-    let maxArgsSignature = signatures[0];
-    let minArgumentCount = signatures[0].minArgumentCount;
-    let someSigHasRestParameter = false;
-    for (const sig of signatures) {
-      minArgumentCount = Math.min(sig.minArgumentCount, minArgumentCount);
-      if (signatureHasRestParameter(sig)) {
-        someSigHasRestParameter = true;
-      }
-      if (sig.parameters.length >= maxArgsSignature.parameters.length && (!signatureHasRestParameter(sig) || signatureHasRestParameter(maxArgsSignature))) {
-        maxArgsSignature = sig;
-      }
-    }
-    const maxNonRestArgs = maxArgsSignature.parameters.length - (signatureHasRestParameter(maxArgsSignature) ? 1 : 0);
-    const maxArgsParameterSymbolNames = maxArgsSignature.parameters.map((symbol) => symbol.name);
-    const parameters = createDummyParameters(
-      maxNonRestArgs,
-      maxArgsParameterSymbolNames,
-      /*types*/
-      void 0,
-      minArgumentCount,
-      /*inJs*/
-      false
-    );
-    if (someSigHasRestParameter) {
-      const restParameter = factory.createParameterDeclaration(
-        /*modifiers*/
-        void 0,
-        factory.createToken(26 /* DotDotDotToken */),
-        maxArgsParameterSymbolNames[maxNonRestArgs] || "rest",
-        /*questionToken*/
-        maxNonRestArgs >= minArgumentCount ? factory.createToken(58 /* QuestionToken */) : void 0,
-        factory.createArrayTypeNode(factory.createKeywordTypeNode(159 /* UnknownKeyword */)),
-        /*initializer*/
-        void 0
-      );
-      parameters.push(restParameter);
-    }
-    return createStubbedMethod(
-      modifiers,
-      name,
-      optional,
-      /*typeParameters*/
-      void 0,
-      parameters,
-      getReturnTypeFromSignatures(signatures, checker, context, enclosingDeclaration),
-      quotePreference,
-      body
-    );
-  }
-  function getReturnTypeFromSignatures(signatures, checker, context, enclosingDeclaration) {
-    if (length(signatures)) {
-      const type = checker.getUnionType(map(signatures, checker.getReturnTypeOfSignature));
-      return checker.typeToTypeNode(type, enclosingDeclaration, 1 /* NoTruncation */, getNoopSymbolTrackerWithResolver(context));
-    }
-  }
-  function createStubbedMethod(modifiers, name, optional, typeParameters, parameters, returnType, quotePreference, body) {
-    return factory.createMethodDeclaration(
-      modifiers,
-      /*asteriskToken*/
-      void 0,
-      name,
-      optional ? factory.createToken(58 /* QuestionToken */) : void 0,
-      typeParameters,
-      parameters,
-      returnType,
-      body || createStubbedMethodBody(quotePreference)
-    );
-  }
-  function createStubbedMethodBody(quotePreference) {
-    return createStubbedBody(Diagnostics.Method_not_implemented.message, quotePreference);
-  }
-  function createStubbedBody(text, quotePreference) {
-    return factory.createBlock(
-      [factory.createThrowStatement(
-        factory.createNewExpression(
-          factory.createIdentifier("Error"),
-          /*typeArguments*/
-          void 0,
-          // TODO Handle auto quote preference.
-          [factory.createStringLiteral(
-            text,
-            /*isSingleQuote*/
-            quotePreference === 0 /* Single */
-          )]
-        )
-      )],
-      /*multiLine*/
-      true
-    );
-  }
-  function setJsonCompilerOptionValues(changeTracker, configFile, options) {
-    const tsconfigObjectLiteral = getTsConfigObjectLiteralExpression(configFile);
-    if (!tsconfigObjectLiteral)
-      return void 0;
-    const compilerOptionsProperty = findJsonProperty(tsconfigObjectLiteral, "compilerOptions");
-    if (compilerOptionsProperty === void 0) {
-      changeTracker.insertNodeAtObjectStart(configFile, tsconfigObjectLiteral, createJsonPropertyAssignment(
-        "compilerOptions",
-        factory.createObjectLiteralExpression(
-          options.map(([optionName, optionValue]) => createJsonPropertyAssignment(optionName, optionValue)),
-          /*multiLine*/
-          true
-        )
-      ));
-      return;
-    }
-    const compilerOptions = compilerOptionsProperty.initializer;
-    if (!isObjectLiteralExpression(compilerOptions)) {
-      return;
-    }
-    for (const [optionName, optionValue] of options) {
-      const optionProperty = findJsonProperty(compilerOptions, optionName);
-      if (optionProperty === void 0) {
-        changeTracker.insertNodeAtObjectStart(configFile, compilerOptions, createJsonPropertyAssignment(optionName, optionValue));
-      } else {
-        changeTracker.replaceNode(configFile, optionProperty.initializer, optionValue);
-      }
-    }
-  }
-  function setJsonCompilerOptionValue(changeTracker, configFile, optionName, optionValue) {
-    setJsonCompilerOptionValues(changeTracker, configFile, [[optionName, optionValue]]);
-  }
-  function createJsonPropertyAssignment(name, initializer) {
-    return factory.createPropertyAssignment(factory.createStringLiteral(name), initializer);
-  }
-  function findJsonProperty(obj, name) {
-    return find(obj.properties, (p) => isPropertyAssignment(p) && !!p.name && isStringLiteral(p.name) && p.name.text === name);
-  }
-  function tryGetAutoImportableReferenceFromTypeNode(importTypeNode, scriptTarget) {
-    let symbols;
-    const typeNode = visitNode(importTypeNode, visit, isTypeNode);
-    if (symbols && typeNode) {
-      return { typeNode, symbols };
-    }
-    function visit(node) {
-      if (isLiteralImportTypeNode(node) && node.qualifier) {
-        const firstIdentifier = getFirstIdentifier(node.qualifier);
-        const name = getNameForExportedSymbol(firstIdentifier.symbol, scriptTarget);
-        const qualifier = name !== firstIdentifier.text ? replaceFirstIdentifierOfEntityName(node.qualifier, factory.createIdentifier(name)) : node.qualifier;
-        symbols = append(symbols, firstIdentifier.symbol);
-        const typeArguments = visitNodes2(node.typeArguments, visit, isTypeNode);
-        return factory.createTypeReferenceNode(qualifier, typeArguments);
-      }
-      return visitEachChild(node, visit, nullTransformationContext);
-    }
-  }
-  function replaceFirstIdentifierOfEntityName(name, newIdentifier) {
-    if (name.kind === 80 /* Identifier */) {
-      return newIdentifier;
-    }
-    return factory.createQualifiedName(replaceFirstIdentifierOfEntityName(name.left, newIdentifier), name.right);
-  }
-  function importSymbols(importAdder, symbols) {
-    symbols.forEach((s) => importAdder.addImportFromExportedSymbol(
-      s,
-      /*isValidTypeOnlyUseSite*/
-      true
-    ));
-  }
-  function findAncestorMatchingSpan(sourceFile, span) {
-    const end = textSpanEnd(span);
-    let token = getTokenAtPosition(sourceFile, span.start);
-    while (token.end < end) {
-      token = token.parent;
-    }
-    return token;
-  }
-  var PreserveOptionalFlags;
-  var init_helpers2 = __esm({
-    "src/services/codefixes/helpers.ts"() {
-      "use strict";
-      init_ts4();
-      PreserveOptionalFlags = /* @__PURE__ */ ((PreserveOptionalFlags2) => {
-        PreserveOptionalFlags2[PreserveOptionalFlags2["Method"] = 1] = "Method";
-        PreserveOptionalFlags2[PreserveOptionalFlags2["Property"] = 2] = "Property";
-        PreserveOptionalFlags2[PreserveOptionalFlags2["All"] = 3] = "All";
-        return PreserveOptionalFlags2;
-      })(PreserveOptionalFlags || {});
-    }
-  });
-
-  // src/services/codefixes/generateAccessors.ts
-  function generateAccessorFromProperty(file, program, start, end, context, _actionName) {
-    const fieldInfo = getAccessorConvertiblePropertyAtPosition(file, program, start, end);
-    if (!fieldInfo || ts_refactor_exports.isRefactorErrorInfo(fieldInfo))
-      return void 0;
-    const changeTracker = ts_textChanges_exports.ChangeTracker.fromContext(context);
-    const { isStatic: isStatic2, isReadonly, fieldName, accessorName, originalName, type, container, declaration } = fieldInfo;
-    suppressLeadingAndTrailingTrivia(fieldName);
-    suppressLeadingAndTrailingTrivia(accessorName);
-    suppressLeadingAndTrailingTrivia(declaration);
-    suppressLeadingAndTrailingTrivia(container);
-    let accessorModifiers;
-    let fieldModifiers;
-    if (isClassLike(container)) {
-      const modifierFlags = getEffectiveModifierFlags(declaration);
-      if (isSourceFileJS(file)) {
-        const modifiers = factory.createModifiersFromModifierFlags(modifierFlags);
-        accessorModifiers = modifiers;
-        fieldModifiers = modifiers;
-      } else {
-        accessorModifiers = factory.createModifiersFromModifierFlags(prepareModifierFlagsForAccessor(modifierFlags));
-        fieldModifiers = factory.createModifiersFromModifierFlags(prepareModifierFlagsForField(modifierFlags));
-      }
-      if (canHaveDecorators(declaration)) {
-        fieldModifiers = concatenate(getDecorators(declaration), fieldModifiers);
-      }
-    }
-    updateFieldDeclaration(changeTracker, file, declaration, type, fieldName, fieldModifiers);
-    const getAccessor = generateGetAccessor(fieldName, accessorName, type, accessorModifiers, isStatic2, container);
-    suppressLeadingAndTrailingTrivia(getAccessor);
-    insertAccessor(changeTracker, file, getAccessor, declaration, container);
-    if (isReadonly) {
-      const constructor = getFirstConstructorWithBody(container);
-      if (constructor) {
-        updateReadonlyPropertyInitializerStatementConstructor(changeTracker, file, constructor, fieldName.text, originalName);
-      }
-    } else {
-      const setAccessor = generateSetAccessor(fieldName, accessorName, type, accessorModifiers, isStatic2, container);
-      suppressLeadingAndTrailingTrivia(setAccessor);
-      insertAccessor(changeTracker, file, setAccessor, declaration, container);
-    }
-    return changeTracker.getChanges();
-  }
-  function isConvertibleName(name) {
-    return isIdentifier(name) || isStringLiteral(name);
-  }
-  function isAcceptedDeclaration(node) {
-    return isParameterPropertyDeclaration(node, node.parent) || isPropertyDeclaration(node) || isPropertyAssignment(node);
-  }
-  function createPropertyName(name, originalName) {
-    return isIdentifier(originalName) ? factory.createIdentifier(name) : factory.createStringLiteral(name);
-  }
-  function createAccessorAccessExpression(fieldName, isStatic2, container) {
-    const leftHead = isStatic2 ? container.name : factory.createThis();
-    return isIdentifier(fieldName) ? factory.createPropertyAccessExpression(leftHead, fieldName) : factory.createElementAccessExpression(leftHead, factory.createStringLiteralFromNode(fieldName));
-  }
-  function prepareModifierFlagsForAccessor(modifierFlags) {
-    modifierFlags &= ~64 /* Readonly */;
-    modifierFlags &= ~8 /* Private */;
-    if (!(modifierFlags & 16 /* Protected */)) {
-      modifierFlags |= 4 /* Public */;
-    }
-    return modifierFlags;
-  }
-  function prepareModifierFlagsForField(modifierFlags) {
-    modifierFlags &= ~4 /* Public */;
-    modifierFlags &= ~16 /* Protected */;
-    modifierFlags |= 8 /* Private */;
-    return modifierFlags;
-  }
-  function getAccessorConvertiblePropertyAtPosition(file, program, start, end, considerEmptySpans = true) {
-    const node = getTokenAtPosition(file, start);
-    const cursorRequest = start === end && considerEmptySpans;
-    const declaration = findAncestor(node.parent, isAcceptedDeclaration);
-    const meaning = 28 /* AccessibilityModifier */ | 32 /* Static */ | 64 /* Readonly */;
-    if (!declaration || !(nodeOverlapsWithStartEnd(declaration.name, file, start, end) || cursorRequest)) {
-      return {
-        error: getLocaleSpecificMessage(Diagnostics.Could_not_find_property_for_which_to_generate_accessor)
-      };
-    }
-    if (!isConvertibleName(declaration.name)) {
-      return {
-        error: getLocaleSpecificMessage(Diagnostics.Name_is_not_valid)
-      };
-    }
-    if ((getEffectiveModifierFlags(declaration) & 126975 /* Modifier */ | meaning) !== meaning) {
-      return {
-        error: getLocaleSpecificMessage(Diagnostics.Can_only_convert_property_with_modifier)
-      };
-    }
-    const name = declaration.name.text;
-    const startWithUnderscore = startsWithUnderscore(name);
-    const fieldName = createPropertyName(startWithUnderscore ? name : getUniqueName(`_${name}`, file), declaration.name);
-    const accessorName = createPropertyName(startWithUnderscore ? getUniqueName(name.substring(1), file) : name, declaration.name);
-    return {
-      isStatic: hasStaticModifier(declaration),
-      isReadonly: hasEffectiveReadonlyModifier(declaration),
-      type: getDeclarationType(declaration, program),
-      container: declaration.kind === 168 /* Parameter */ ? declaration.parent.parent : declaration.parent,
-      originalName: declaration.name.text,
-      declaration,
-      fieldName,
-      accessorName,
-      renameAccessor: startWithUnderscore
-    };
-  }
-  function generateGetAccessor(fieldName, accessorName, type, modifiers, isStatic2, container) {
-    return factory.createGetAccessorDeclaration(
-      modifiers,
-      accessorName,
-      [],
-      type,
-      factory.createBlock(
-        [
-          factory.createReturnStatement(
-            createAccessorAccessExpression(fieldName, isStatic2, container)
-          )
-        ],
-        /*multiLine*/
-        true
-      )
-    );
-  }
-  function generateSetAccessor(fieldName, accessorName, type, modifiers, isStatic2, container) {
-    return factory.createSetAccessorDeclaration(
-      modifiers,
-      accessorName,
-      [factory.createParameterDeclaration(
-        /*modifiers*/
-        void 0,
-        /*dotDotDotToken*/
-        void 0,
-        factory.createIdentifier("value"),
-        /*questionToken*/
-        void 0,
-        type
-      )],
-      factory.createBlock(
-        [
-          factory.createExpressionStatement(
-            factory.createAssignment(
-              createAccessorAccessExpression(fieldName, isStatic2, container),
-              factory.createIdentifier("value")
-            )
-          )
-        ],
-        /*multiLine*/
-        true
-      )
-    );
-  }
-  function updatePropertyDeclaration(changeTracker, file, declaration, type, fieldName, modifiers) {
-    const property = factory.updatePropertyDeclaration(
-      declaration,
-      modifiers,
-      fieldName,
-      declaration.questionToken || declaration.exclamationToken,
-      type,
-      declaration.initializer
-    );
-    changeTracker.replaceNode(file, declaration, property);
-  }
-  function updatePropertyAssignmentDeclaration(changeTracker, file, declaration, fieldName) {
-    let assignment = factory.updatePropertyAssignment(declaration, fieldName, declaration.initializer);
-    if (assignment.modifiers || assignment.questionToken || assignment.exclamationToken) {
-      if (assignment === declaration)
-        assignment = factory.cloneNode(assignment);
-      assignment.modifiers = void 0;
-      assignment.questionToken = void 0;
-      assignment.exclamationToken = void 0;
-    }
-    changeTracker.replacePropertyAssignment(file, declaration, assignment);
-  }
-  function updateFieldDeclaration(changeTracker, file, declaration, type, fieldName, modifiers) {
-    if (isPropertyDeclaration(declaration)) {
-      updatePropertyDeclaration(changeTracker, file, declaration, type, fieldName, modifiers);
-    } else if (isPropertyAssignment(declaration)) {
-      updatePropertyAssignmentDeclaration(changeTracker, file, declaration, fieldName);
-    } else {
-      changeTracker.replaceNode(
-        file,
-        declaration,
-        factory.updateParameterDeclaration(declaration, modifiers, declaration.dotDotDotToken, cast(fieldName, isIdentifier), declaration.questionToken, declaration.type, declaration.initializer)
-      );
-    }
-  }
-  function insertAccessor(changeTracker, file, accessor, declaration, container) {
-    isParameterPropertyDeclaration(declaration, declaration.parent) ? changeTracker.insertMemberAtStart(file, container, accessor) : isPropertyAssignment(declaration) ? changeTracker.insertNodeAfterComma(file, declaration, accessor) : changeTracker.insertNodeAfter(file, declaration, accessor);
-  }
-  function updateReadonlyPropertyInitializerStatementConstructor(changeTracker, file, constructor, fieldName, originalName) {
-    if (!constructor.body)
-      return;
-    constructor.body.forEachChild(function recur(node) {
-      if (isElementAccessExpression(node) && node.expression.kind === 110 /* ThisKeyword */ && isStringLiteral(node.argumentExpression) && node.argumentExpression.text === originalName && isWriteAccess(node)) {
-        changeTracker.replaceNode(file, node.argumentExpression, factory.createStringLiteral(fieldName));
-      }
-      if (isPropertyAccessExpression(node) && node.expression.kind === 110 /* ThisKeyword */ && node.name.text === originalName && isWriteAccess(node)) {
-        changeTracker.replaceNode(file, node.name, factory.createIdentifier(fieldName));
-      }
-      if (!isFunctionLike(node) && !isClassLike(node)) {
-        node.forEachChild(recur);
-      }
-    });
-  }
-  function getDeclarationType(declaration, program) {
-    const typeNode = getTypeAnnotationNode(declaration);
-    if (isPropertyDeclaration(declaration) && typeNode && declaration.questionToken) {
-      const typeChecker = program.getTypeChecker();
-      const type = typeChecker.getTypeFromTypeNode(typeNode);
-      if (!typeChecker.isTypeAssignableTo(typeChecker.getUndefinedType(), type)) {
-        const types = isUnionTypeNode(typeNode) ? typeNode.types : [typeNode];
-        return factory.createUnionTypeNode([...types, factory.createKeywordTypeNode(157 /* UndefinedKeyword */)]);
-      }
-    }
-    return typeNode;
-  }
-  function getAllSupers(decl, checker) {
-    const res = [];
-    while (decl) {
-      const superElement = getClassExtendsHeritageElement(decl);
-      const superSymbol = superElement && checker.getSymbolAtLocation(superElement.expression);
-      if (!superSymbol)
-        break;
-      const symbol = superSymbol.flags & 2097152 /* Alias */ ? checker.getAliasedSymbol(superSymbol) : superSymbol;
-      const superDecl = symbol.declarations && find(symbol.declarations, isClassLike);
-      if (!superDecl)
-        break;
-      res.push(superDecl);
-      decl = superDecl;
-    }
-    return res;
-  }
-  var init_generateAccessors = __esm({
-    "src/services/codefixes/generateAccessors.ts"() {
-      "use strict";
-      init_ts4();
-    }
-  });
-
-  // src/services/codefixes/fixInvalidImportSyntax.ts
-  function getCodeFixesForImportDeclaration(context, node) {
-    const sourceFile = getSourceFileOfNode(node);
-    const namespace = getNamespaceDeclarationNode(node);
-    const opts = context.program.getCompilerOptions();
-    const variations = [];
-    variations.push(createAction(context, sourceFile, node, makeImport(
-      namespace.name,
-      /*namedImports*/
-      void 0,
-      node.moduleSpecifier,
-      getQuotePreference(sourceFile, context.preferences)
-    )));
-    if (getEmitModuleKind(opts) === 1 /* CommonJS */) {
-      variations.push(createAction(context, sourceFile, node, factory.createImportEqualsDeclaration(
-        /*modifiers*/
-        void 0,
-        /*isTypeOnly*/
-        false,
-        namespace.name,
-        factory.createExternalModuleReference(node.moduleSpecifier)
-      )));
-    }
-    return variations;
-  }
-  function createAction(context, sourceFile, node, replacement) {
-    const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => t.replaceNode(sourceFile, node, replacement));
-    return createCodeFixActionWithoutFixAll(fixName5, changes, [Diagnostics.Replace_import_with_0, changes[0].textChanges[0].newText]);
-  }
-  function getActionsForUsageOfInvalidImport(context) {
-    const sourceFile = context.sourceFile;
-    const targetKind = Diagnostics.This_expression_is_not_callable.code === context.errorCode ? 212 /* CallExpression */ : 213 /* NewExpression */;
-    const node = findAncestor(getTokenAtPosition(sourceFile, context.span.start), (a) => a.kind === targetKind);
-    if (!node) {
-      return [];
-    }
-    const expr = node.expression;
-    return getImportCodeFixesForExpression(context, expr);
-  }
-  function getActionsForInvalidImportLocation(context) {
-    const sourceFile = context.sourceFile;
-    const node = findAncestor(getTokenAtPosition(sourceFile, context.span.start), (a) => a.getStart() === context.span.start && a.getEnd() === context.span.start + context.span.length);
-    if (!node) {
-      return [];
-    }
-    return getImportCodeFixesForExpression(context, node);
-  }
-  function getImportCodeFixesForExpression(context, expr) {
-    const type = context.program.getTypeChecker().getTypeAtLocation(expr);
-    if (!(type.symbol && isTransientSymbol(type.symbol) && type.symbol.links.originatingImport)) {
-      return [];
-    }
-    const fixes = [];
-    const relatedImport = type.symbol.links.originatingImport;
-    if (!isImportCall(relatedImport)) {
-      addRange(fixes, getCodeFixesForImportDeclaration(context, relatedImport));
-    }
-    if (isExpression(expr) && !(isNamedDeclaration(expr.parent) && expr.parent.name === expr)) {
-      const sourceFile = context.sourceFile;
-      const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => t.replaceNode(sourceFile, expr, factory.createPropertyAccessExpression(expr, "default"), {}));
-      fixes.push(createCodeFixActionWithoutFixAll(fixName5, changes, Diagnostics.Use_synthetic_default_member));
-    }
-    return fixes;
-  }
-  var fixName5;
-  var init_fixInvalidImportSyntax = __esm({
-    "src/services/codefixes/fixInvalidImportSyntax.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_codefix();
-      fixName5 = "invalidImportSyntax";
-      registerCodeFix({
-        errorCodes: [
-          Diagnostics.This_expression_is_not_callable.code,
-          Diagnostics.This_expression_is_not_constructable.code
-        ],
-        getCodeActions: getActionsForUsageOfInvalidImport
-      });
-      registerCodeFix({
-        errorCodes: [
-          // The following error codes cover pretty much all assignability errors that could involve an expression
-          Diagnostics.Argument_of_type_0_is_not_assignable_to_parameter_of_type_1.code,
-          Diagnostics.Type_0_does_not_satisfy_the_constraint_1.code,
-          Diagnostics.Type_0_is_not_assignable_to_type_1.code,
-          Diagnostics.Type_0_is_not_assignable_to_type_1_Two_different_types_with_this_name_exist_but_they_are_unrelated.code,
-          Diagnostics.Type_predicate_0_is_not_assignable_to_1.code,
-          Diagnostics.Property_0_of_type_1_is_not_assignable_to_2_index_type_3.code,
-          Diagnostics._0_index_type_1_is_not_assignable_to_2_index_type_3.code,
-          Diagnostics.Property_0_in_type_1_is_not_assignable_to_the_same_property_in_base_type_2.code,
-          Diagnostics.Property_0_in_type_1_is_not_assignable_to_type_2.code,
-          Diagnostics.Property_0_of_JSX_spread_attribute_is_not_assignable_to_target_property.code,
-          Diagnostics.The_this_context_of_type_0_is_not_assignable_to_method_s_this_of_type_1.code
-        ],
-        getCodeActions: getActionsForInvalidImportLocation
-      });
-    }
-  });
-
-  // src/services/codefixes/fixStrictClassInitialization.ts
-  function getInfo16(sourceFile, pos) {
-    const token = getTokenAtPosition(sourceFile, pos);
-    if (isIdentifier(token) && isPropertyDeclaration(token.parent)) {
-      const type = getEffectiveTypeAnnotationNode(token.parent);
-      if (type) {
-        return { type, prop: token.parent, isJs: isInJSFile(token.parent) };
-      }
-    }
-    return void 0;
-  }
-  function getActionForAddMissingDefiniteAssignmentAssertion(context, info) {
-    if (info.isJs)
-      return void 0;
-    const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => addDefiniteAssignmentAssertion(t, context.sourceFile, info.prop));
-    return createCodeFixAction(fixName6, changes, [Diagnostics.Add_definite_assignment_assertion_to_property_0, info.prop.getText()], fixIdAddDefiniteAssignmentAssertions, Diagnostics.Add_definite_assignment_assertions_to_all_uninitialized_properties);
-  }
-  function addDefiniteAssignmentAssertion(changeTracker, propertyDeclarationSourceFile, propertyDeclaration) {
-    suppressLeadingAndTrailingTrivia(propertyDeclaration);
-    const property = factory.updatePropertyDeclaration(
-      propertyDeclaration,
-      propertyDeclaration.modifiers,
-      propertyDeclaration.name,
-      factory.createToken(54 /* ExclamationToken */),
-      propertyDeclaration.type,
-      propertyDeclaration.initializer
-    );
-    changeTracker.replaceNode(propertyDeclarationSourceFile, propertyDeclaration, property);
-  }
-  function getActionForAddMissingUndefinedType(context, info) {
-    const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => addUndefinedType(t, context.sourceFile, info));
-    return createCodeFixAction(fixName6, changes, [Diagnostics.Add_undefined_type_to_property_0, info.prop.name.getText()], fixIdAddUndefinedType, Diagnostics.Add_undefined_type_to_all_uninitialized_properties);
-  }
-  function addUndefinedType(changeTracker, sourceFile, info) {
-    const undefinedTypeNode = factory.createKeywordTypeNode(157 /* UndefinedKeyword */);
-    const types = isUnionTypeNode(info.type) ? info.type.types.concat(undefinedTypeNode) : [info.type, undefinedTypeNode];
-    const unionTypeNode = factory.createUnionTypeNode(types);
-    if (info.isJs) {
-      changeTracker.addJSDocTags(sourceFile, info.prop, [factory.createJSDocTypeTag(
-        /*tagName*/
-        void 0,
-        factory.createJSDocTypeExpression(unionTypeNode)
-      )]);
-    } else {
-      changeTracker.replaceNode(sourceFile, info.type, unionTypeNode);
-    }
-  }
-  function getActionForAddMissingInitializer(context, info) {
-    if (info.isJs)
-      return void 0;
-    const checker = context.program.getTypeChecker();
-    const initializer = getInitializer(checker, info.prop);
-    if (!initializer)
-      return void 0;
-    const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => addInitializer(t, context.sourceFile, info.prop, initializer));
-    return createCodeFixAction(fixName6, changes, [Diagnostics.Add_initializer_to_property_0, info.prop.name.getText()], fixIdAddInitializer, Diagnostics.Add_initializers_to_all_uninitialized_properties);
-  }
-  function addInitializer(changeTracker, propertyDeclarationSourceFile, propertyDeclaration, initializer) {
-    suppressLeadingAndTrailingTrivia(propertyDeclaration);
-    const property = factory.updatePropertyDeclaration(
-      propertyDeclaration,
-      propertyDeclaration.modifiers,
-      propertyDeclaration.name,
-      propertyDeclaration.questionToken,
-      propertyDeclaration.type,
-      initializer
-    );
-    changeTracker.replaceNode(propertyDeclarationSourceFile, propertyDeclaration, property);
-  }
-  function getInitializer(checker, propertyDeclaration) {
-    return getDefaultValueFromType(checker, checker.getTypeFromTypeNode(propertyDeclaration.type));
-  }
-  function getDefaultValueFromType(checker, type) {
-    if (type.flags & 512 /* BooleanLiteral */) {
-      return type === checker.getFalseType() || type === checker.getFalseType(
-        /*fresh*/
-        true
-      ) ? factory.createFalse() : factory.createTrue();
-    } else if (type.isStringLiteral()) {
-      return factory.createStringLiteral(type.value);
-    } else if (type.isNumberLiteral()) {
-      return factory.createNumericLiteral(type.value);
-    } else if (type.flags & 2048 /* BigIntLiteral */) {
-      return factory.createBigIntLiteral(type.value);
-    } else if (type.isUnion()) {
-      return firstDefined(type.types, (t) => getDefaultValueFromType(checker, t));
-    } else if (type.isClass()) {
-      const classDeclaration = getClassLikeDeclarationOfSymbol(type.symbol);
-      if (!classDeclaration || hasSyntacticModifier(classDeclaration, 256 /* Abstract */))
-        return void 0;
-      const constructorDeclaration = getFirstConstructorWithBody(classDeclaration);
-      if (constructorDeclaration && constructorDeclaration.parameters.length)
-        return void 0;
-      return factory.createNewExpression(
-        factory.createIdentifier(type.symbol.name),
-        /*typeArguments*/
-        void 0,
-        /*argumentsArray*/
-        void 0
-      );
-    } else if (checker.isArrayLikeType(type)) {
-      return factory.createArrayLiteralExpression();
-    }
-    return void 0;
-  }
-  var fixName6, fixIdAddDefiniteAssignmentAssertions, fixIdAddUndefinedType, fixIdAddInitializer, errorCodes51;
-  var init_fixStrictClassInitialization = __esm({
-    "src/services/codefixes/fixStrictClassInitialization.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_codefix();
-      fixName6 = "strictClassInitialization";
-      fixIdAddDefiniteAssignmentAssertions = "addMissingPropertyDefiniteAssignmentAssertions";
-      fixIdAddUndefinedType = "addMissingPropertyUndefinedType";
-      fixIdAddInitializer = "addMissingPropertyInitializer";
-      errorCodes51 = [Diagnostics.Property_0_has_no_initializer_and_is_not_definitely_assigned_in_the_constructor.code];
-      registerCodeFix({
-        errorCodes: errorCodes51,
-        getCodeActions: function getCodeActionsForStrictClassInitializationErrors(context) {
-          const info = getInfo16(context.sourceFile, context.span.start);
-          if (!info)
-            return;
-          const result = [];
-          append(result, getActionForAddMissingUndefinedType(context, info));
-          append(result, getActionForAddMissingDefiniteAssignmentAssertion(context, info));
-          append(result, getActionForAddMissingInitializer(context, info));
-          return result;
-        },
-        fixIds: [fixIdAddDefiniteAssignmentAssertions, fixIdAddUndefinedType, fixIdAddInitializer],
-        getAllCodeActions: (context) => {
-          return codeFixAll(context, errorCodes51, (changes, diag2) => {
-            const info = getInfo16(diag2.file, diag2.start);
-            if (!info)
-              return;
-            switch (context.fixId) {
-              case fixIdAddDefiniteAssignmentAssertions:
-                addDefiniteAssignmentAssertion(changes, diag2.file, info.prop);
-                break;
-              case fixIdAddUndefinedType:
-                addUndefinedType(changes, diag2.file, info);
-                break;
-              case fixIdAddInitializer:
-                const checker = context.program.getTypeChecker();
-                const initializer = getInitializer(checker, info.prop);
-                if (!initializer)
-                  return;
-                addInitializer(changes, diag2.file, info.prop, initializer);
-                break;
-              default:
-                Debug.fail(JSON.stringify(context.fixId));
-            }
-          });
-        }
-      });
-    }
-  });
-
-  // src/services/codefixes/requireInTs.ts
-  function doChange34(changes, sourceFile, info) {
-    const { allowSyntheticDefaults, defaultImportName, namedImports, statement, required } = info;
-    changes.replaceNode(sourceFile, statement, defaultImportName && !allowSyntheticDefaults ? factory.createImportEqualsDeclaration(
-      /*modifiers*/
-      void 0,
-      /*isTypeOnly*/
-      false,
-      defaultImportName,
-      factory.createExternalModuleReference(required)
-    ) : factory.createImportDeclaration(
-      /*modifiers*/
-      void 0,
-      factory.createImportClause(
-        /*isTypeOnly*/
-        false,
-        defaultImportName,
-        namedImports
-      ),
-      required,
-      /*assertClause*/
-      void 0
-    ));
-  }
-  function getInfo17(sourceFile, program, pos) {
-    const { parent: parent2 } = getTokenAtPosition(sourceFile, pos);
-    if (!isRequireCall(
-      parent2,
-      /*requireStringLiteralLikeArgument*/
-      true
-    )) {
-      Debug.failBadSyntaxKind(parent2);
-    }
-    const decl = cast(parent2.parent, isVariableDeclaration);
-    const defaultImportName = tryCast(decl.name, isIdentifier);
-    const namedImports = isObjectBindingPattern(decl.name) ? tryCreateNamedImportsFromObjectBindingPattern(decl.name) : void 0;
-    if (defaultImportName || namedImports) {
-      return {
-        allowSyntheticDefaults: getAllowSyntheticDefaultImports(program.getCompilerOptions()),
-        defaultImportName,
-        namedImports,
-        statement: cast(decl.parent.parent, isVariableStatement),
-        required: first(parent2.arguments)
-      };
-    }
-  }
-  function tryCreateNamedImportsFromObjectBindingPattern(node) {
-    const importSpecifiers = [];
-    for (const element of node.elements) {
-      if (!isIdentifier(element.name) || element.initializer) {
-        return void 0;
-      }
-      importSpecifiers.push(factory.createImportSpecifier(
-        /*isTypeOnly*/
-        false,
-        tryCast(element.propertyName, isIdentifier),
-        element.name
-      ));
-    }
-    if (importSpecifiers.length) {
-      return factory.createNamedImports(importSpecifiers);
-    }
-  }
-  var fixId41, errorCodes52;
-  var init_requireInTs = __esm({
-    "src/services/codefixes/requireInTs.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_codefix();
-      fixId41 = "requireInTs";
-      errorCodes52 = [Diagnostics.require_call_may_be_converted_to_an_import.code];
-      registerCodeFix({
-        errorCodes: errorCodes52,
-        getCodeActions(context) {
-          const info = getInfo17(context.sourceFile, context.program, context.span.start);
-          if (!info) {
-            return void 0;
-          }
-          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange34(t, context.sourceFile, info));
-          return [createCodeFixAction(fixId41, changes, Diagnostics.Convert_require_to_import, fixId41, Diagnostics.Convert_all_require_to_import)];
-        },
-        fixIds: [fixId41],
-        getAllCodeActions: (context) => codeFixAll(context, errorCodes52, (changes, diag2) => {
-          const info = getInfo17(diag2.file, context.program, diag2.start);
-          if (info) {
-            doChange34(changes, context.sourceFile, info);
-          }
-        })
-      });
-    }
-  });
-
-  // src/services/codefixes/useDefaultImport.ts
-  function getInfo18(sourceFile, pos) {
-    const name = getTokenAtPosition(sourceFile, pos);
-    if (!isIdentifier(name))
-      return void 0;
-    const { parent: parent2 } = name;
-    if (isImportEqualsDeclaration(parent2) && isExternalModuleReference(parent2.moduleReference)) {
-      return { importNode: parent2, name, moduleSpecifier: parent2.moduleReference.expression };
-    } else if (isNamespaceImport(parent2)) {
-      const importNode = parent2.parent.parent;
-      return { importNode, name, moduleSpecifier: importNode.moduleSpecifier };
-    }
-  }
-  function doChange35(changes, sourceFile, info, preferences) {
-    changes.replaceNode(sourceFile, info.importNode, makeImport(
-      info.name,
-      /*namedImports*/
-      void 0,
-      info.moduleSpecifier,
-      getQuotePreference(sourceFile, preferences)
-    ));
-  }
-  var fixId42, errorCodes53;
-  var init_useDefaultImport = __esm({
-    "src/services/codefixes/useDefaultImport.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_codefix();
-      fixId42 = "useDefaultImport";
-      errorCodes53 = [Diagnostics.Import_may_be_converted_to_a_default_import.code];
-      registerCodeFix({
-        errorCodes: errorCodes53,
-        getCodeActions(context) {
-          const { sourceFile, span: { start } } = context;
-          const info = getInfo18(sourceFile, start);
-          if (!info)
-            return void 0;
-          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange35(t, sourceFile, info, context.preferences));
-          return [createCodeFixAction(fixId42, changes, Diagnostics.Convert_to_default_import, fixId42, Diagnostics.Convert_all_to_default_imports)];
-        },
-        fixIds: [fixId42],
-        getAllCodeActions: (context) => codeFixAll(context, errorCodes53, (changes, diag2) => {
-          const info = getInfo18(diag2.file, diag2.start);
-          if (info)
-            doChange35(changes, diag2.file, info, context.preferences);
-        })
-      });
-    }
-  });
-
-  // src/services/codefixes/useBigintLiteral.ts
-  function makeChange9(changeTracker, sourceFile, span) {
-    const numericLiteral = tryCast(getTokenAtPosition(sourceFile, span.start), isNumericLiteral);
-    if (!numericLiteral) {
-      return;
-    }
-    const newText = numericLiteral.getText(sourceFile) + "n";
-    changeTracker.replaceNode(sourceFile, numericLiteral, factory.createBigIntLiteral(newText));
-  }
-  var fixId43, errorCodes54;
-  var init_useBigintLiteral = __esm({
-    "src/services/codefixes/useBigintLiteral.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_codefix();
-      fixId43 = "useBigintLiteral";
-      errorCodes54 = [
-        Diagnostics.Numeric_literals_with_absolute_values_equal_to_2_53_or_greater_are_too_large_to_be_represented_accurately_as_integers.code
-      ];
-      registerCodeFix({
-        errorCodes: errorCodes54,
-        getCodeActions: function getCodeActionsToUseBigintLiteral(context) {
-          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => makeChange9(t, context.sourceFile, context.span));
-          if (changes.length > 0) {
-            return [createCodeFixAction(fixId43, changes, Diagnostics.Convert_to_a_bigint_numeric_literal, fixId43, Diagnostics.Convert_all_to_bigint_numeric_literals)];
-          }
-        },
-        fixIds: [fixId43],
-        getAllCodeActions: (context) => {
-          return codeFixAll(context, errorCodes54, (changes, diag2) => makeChange9(changes, diag2.file, diag2));
-        }
-      });
-    }
-  });
-
-  // src/services/codefixes/fixAddModuleReferTypeMissingTypeof.ts
-  function getImportTypeNode(sourceFile, pos) {
-    const token = getTokenAtPosition(sourceFile, pos);
-    Debug.assert(token.kind === 102 /* ImportKeyword */, "This token should be an ImportKeyword");
-    Debug.assert(token.parent.kind === 204 /* ImportType */, "Token parent should be an ImportType");
-    return token.parent;
-  }
-  function doChange36(changes, sourceFile, importType) {
-    const newTypeNode = factory.updateImportTypeNode(
-      importType,
-      importType.argument,
-      importType.assertions,
-      importType.qualifier,
-      importType.typeArguments,
-      /*isTypeOf*/
-      true
-    );
-    changes.replaceNode(sourceFile, importType, newTypeNode);
-  }
-  var fixIdAddMissingTypeof, fixId44, errorCodes55;
-  var init_fixAddModuleReferTypeMissingTypeof = __esm({
-    "src/services/codefixes/fixAddModuleReferTypeMissingTypeof.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_codefix();
-      fixIdAddMissingTypeof = "fixAddModuleReferTypeMissingTypeof";
-      fixId44 = fixIdAddMissingTypeof;
-      errorCodes55 = [Diagnostics.Module_0_does_not_refer_to_a_type_but_is_used_as_a_type_here_Did_you_mean_typeof_import_0.code];
-      registerCodeFix({
-        errorCodes: errorCodes55,
-        getCodeActions: function getCodeActionsToAddMissingTypeof(context) {
-          const { sourceFile, span } = context;
-          const importType = getImportTypeNode(sourceFile, span.start);
-          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange36(t, sourceFile, importType));
-          return [createCodeFixAction(fixId44, changes, Diagnostics.Add_missing_typeof, fixId44, Diagnostics.Add_missing_typeof)];
-        },
-        fixIds: [fixId44],
-        getAllCodeActions: (context) => codeFixAll(context, errorCodes55, (changes, diag2) => doChange36(changes, context.sourceFile, getImportTypeNode(diag2.file, diag2.start)))
-      });
-    }
-  });
-
-  // src/services/codefixes/wrapJsxInFragment.ts
-  function findNodeToFix(sourceFile, pos) {
-    const lessThanToken = getTokenAtPosition(sourceFile, pos);
-    const firstJsxElementOrOpenElement = lessThanToken.parent;
-    let binaryExpr = firstJsxElementOrOpenElement.parent;
-    if (!isBinaryExpression(binaryExpr)) {
-      binaryExpr = binaryExpr.parent;
-      if (!isBinaryExpression(binaryExpr))
-        return void 0;
-    }
-    if (!nodeIsMissing(binaryExpr.operatorToken))
-      return void 0;
-    return binaryExpr;
-  }
-  function doChange37(changeTracker, sf, node) {
-    const jsx = flattenInvalidBinaryExpr(node);
-    if (jsx)
-      changeTracker.replaceNode(sf, node, factory.createJsxFragment(factory.createJsxOpeningFragment(), jsx, factory.createJsxJsxClosingFragment()));
-  }
-  function flattenInvalidBinaryExpr(node) {
-    const children = [];
-    let current = node;
-    while (true) {
-      if (isBinaryExpression(current) && nodeIsMissing(current.operatorToken) && current.operatorToken.kind === 28 /* CommaToken */) {
-        children.push(current.left);
-        if (isJsxChild(current.right)) {
-          children.push(current.right);
-          return children;
-        } else if (isBinaryExpression(current.right)) {
-          current = current.right;
-          continue;
-        } else
-          return void 0;
-      } else
-        return void 0;
-    }
-  }
-  var fixID2, errorCodes56;
-  var init_wrapJsxInFragment = __esm({
-    "src/services/codefixes/wrapJsxInFragment.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_codefix();
-      fixID2 = "wrapJsxInFragment";
-      errorCodes56 = [Diagnostics.JSX_expressions_must_have_one_parent_element.code];
-      registerCodeFix({
-        errorCodes: errorCodes56,
-        getCodeActions: function getCodeActionsToWrapJsxInFragment(context) {
-          const { sourceFile, span } = context;
-          const node = findNodeToFix(sourceFile, span.start);
-          if (!node)
-            return void 0;
-          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange37(t, sourceFile, node));
-          return [createCodeFixAction(fixID2, changes, Diagnostics.Wrap_in_JSX_fragment, fixID2, Diagnostics.Wrap_all_unparented_JSX_in_JSX_fragment)];
-        },
-        fixIds: [fixID2],
-        getAllCodeActions: (context) => codeFixAll(context, errorCodes56, (changes, diag2) => {
-          const node = findNodeToFix(context.sourceFile, diag2.start);
-          if (!node)
-            return void 0;
-          doChange37(changes, context.sourceFile, node);
-        })
-      });
-    }
-  });
-
-  // src/services/codefixes/convertToMappedObjectType.ts
-  function getInfo19(sourceFile, pos) {
-    const token = getTokenAtPosition(sourceFile, pos);
-    const indexSignature = tryCast(token.parent.parent, isIndexSignatureDeclaration);
-    if (!indexSignature)
-      return void 0;
-    const container = isInterfaceDeclaration(indexSignature.parent) ? indexSignature.parent : tryCast(indexSignature.parent.parent, isTypeAliasDeclaration);
-    if (!container)
-      return void 0;
-    return { indexSignature, container };
-  }
-  function createTypeAliasFromInterface(declaration, type) {
-    return factory.createTypeAliasDeclaration(declaration.modifiers, declaration.name, declaration.typeParameters, type);
-  }
-  function doChange38(changes, sourceFile, { indexSignature, container }) {
-    const members = isInterfaceDeclaration(container) ? container.members : container.type.members;
-    const otherMembers = members.filter((member) => !isIndexSignatureDeclaration(member));
-    const parameter = first(indexSignature.parameters);
-    const mappedTypeParameter = factory.createTypeParameterDeclaration(
-      /*modifiers*/
-      void 0,
-      cast(parameter.name, isIdentifier),
-      parameter.type
-    );
-    const mappedIntersectionType = factory.createMappedTypeNode(
-      hasEffectiveReadonlyModifier(indexSignature) ? factory.createModifier(148 /* ReadonlyKeyword */) : void 0,
-      mappedTypeParameter,
-      /*nameType*/
-      void 0,
-      indexSignature.questionToken,
-      indexSignature.type,
-      /*members*/
-      void 0
-    );
-    const intersectionType = factory.createIntersectionTypeNode([
-      ...getAllSuperTypeNodes(container),
-      mappedIntersectionType,
-      ...otherMembers.length ? [factory.createTypeLiteralNode(otherMembers)] : emptyArray
-    ]);
-    changes.replaceNode(sourceFile, container, createTypeAliasFromInterface(container, intersectionType));
-  }
-  var fixId45, errorCodes57;
-  var init_convertToMappedObjectType = __esm({
-    "src/services/codefixes/convertToMappedObjectType.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_codefix();
-      fixId45 = "fixConvertToMappedObjectType";
-      errorCodes57 = [Diagnostics.An_index_signature_parameter_type_cannot_be_a_literal_type_or_generic_type_Consider_using_a_mapped_object_type_instead.code];
-      registerCodeFix({
-        errorCodes: errorCodes57,
-        getCodeActions: function getCodeActionsToConvertToMappedTypeObject(context) {
-          const { sourceFile, span } = context;
-          const info = getInfo19(sourceFile, span.start);
-          if (!info)
-            return void 0;
-          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange38(t, sourceFile, info));
-          const name = idText(info.container.name);
-          return [createCodeFixAction(fixId45, changes, [Diagnostics.Convert_0_to_mapped_object_type, name], fixId45, [Diagnostics.Convert_0_to_mapped_object_type, name])];
-        },
-        fixIds: [fixId45],
-        getAllCodeActions: (context) => codeFixAll(context, errorCodes57, (changes, diag2) => {
-          const info = getInfo19(diag2.file, diag2.start);
-          if (info)
-            doChange38(changes, diag2.file, info);
-        })
-      });
-    }
-  });
-
-  // src/services/codefixes/removeAccidentalCallParentheses.ts
-  var fixId46, errorCodes58;
-  var init_removeAccidentalCallParentheses = __esm({
-    "src/services/codefixes/removeAccidentalCallParentheses.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_codefix();
-      fixId46 = "removeAccidentalCallParentheses";
-      errorCodes58 = [
-        Diagnostics.This_expression_is_not_callable_because_it_is_a_get_accessor_Did_you_mean_to_use_it_without.code
-      ];
-      registerCodeFix({
-        errorCodes: errorCodes58,
-        getCodeActions(context) {
-          const callExpression = findAncestor(getTokenAtPosition(context.sourceFile, context.span.start), isCallExpression);
-          if (!callExpression) {
-            return void 0;
-          }
-          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => {
-            t.deleteRange(context.sourceFile, { pos: callExpression.expression.end, end: callExpression.end });
-          });
-          return [createCodeFixActionWithoutFixAll(fixId46, changes, Diagnostics.Remove_parentheses)];
-        },
-        fixIds: [fixId46]
-      });
-    }
-  });
-
-  // src/services/codefixes/removeUnnecessaryAwait.ts
-  function makeChange10(changeTracker, sourceFile, span) {
-    const awaitKeyword = tryCast(getTokenAtPosition(sourceFile, span.start), (node) => node.kind === 135 /* AwaitKeyword */);
-    const awaitExpression = awaitKeyword && tryCast(awaitKeyword.parent, isAwaitExpression);
-    if (!awaitExpression) {
-      return;
-    }
-    let expressionToReplace = awaitExpression;
-    const hasSurroundingParens = isParenthesizedExpression(awaitExpression.parent);
-    if (hasSurroundingParens) {
-      const leftMostExpression = getLeftmostExpression(
-        awaitExpression.expression,
-        /*stopAtCallExpressions*/
-        false
-      );
-      if (isIdentifier(leftMostExpression)) {
-        const precedingToken = findPrecedingToken(awaitExpression.parent.pos, sourceFile);
-        if (precedingToken && precedingToken.kind !== 105 /* NewKeyword */) {
-          expressionToReplace = awaitExpression.parent;
-        }
-      }
-    }
-    changeTracker.replaceNode(sourceFile, expressionToReplace, awaitExpression.expression);
-  }
-  var fixId47, errorCodes59;
-  var init_removeUnnecessaryAwait = __esm({
-    "src/services/codefixes/removeUnnecessaryAwait.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_codefix();
-      fixId47 = "removeUnnecessaryAwait";
-      errorCodes59 = [
-        Diagnostics.await_has_no_effect_on_the_type_of_this_expression.code
-      ];
-      registerCodeFix({
-        errorCodes: errorCodes59,
-        getCodeActions: function getCodeActionsToRemoveUnnecessaryAwait(context) {
-          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => makeChange10(t, context.sourceFile, context.span));
-          if (changes.length > 0) {
-            return [createCodeFixAction(fixId47, changes, Diagnostics.Remove_unnecessary_await, fixId47, Diagnostics.Remove_all_unnecessary_uses_of_await)];
-          }
-        },
-        fixIds: [fixId47],
-        getAllCodeActions: (context) => {
-          return codeFixAll(context, errorCodes59, (changes, diag2) => makeChange10(changes, diag2.file, diag2));
-        }
-      });
-    }
-  });
-
-  // src/services/codefixes/splitTypeOnlyImport.ts
-  function getImportDeclaration2(sourceFile, span) {
-    return findAncestor(getTokenAtPosition(sourceFile, span.start), isImportDeclaration);
-  }
-  function splitTypeOnlyImport(changes, importDeclaration, context) {
-    if (!importDeclaration) {
-      return;
-    }
-    const importClause = Debug.checkDefined(importDeclaration.importClause);
-    changes.replaceNode(context.sourceFile, importDeclaration, factory.updateImportDeclaration(
-      importDeclaration,
-      importDeclaration.modifiers,
-      factory.updateImportClause(
-        importClause,
-        importClause.isTypeOnly,
-        importClause.name,
-        /*namedBindings*/
-        void 0
-      ),
-      importDeclaration.moduleSpecifier,
-      importDeclaration.assertClause
-    ));
-    changes.insertNodeAfter(context.sourceFile, importDeclaration, factory.createImportDeclaration(
-      /*modifiers*/
-      void 0,
-      factory.updateImportClause(
-        importClause,
-        importClause.isTypeOnly,
-        /*name*/
-        void 0,
-        importClause.namedBindings
-      ),
-      importDeclaration.moduleSpecifier,
-      importDeclaration.assertClause
-    ));
-  }
-  var errorCodes60, fixId48;
-  var init_splitTypeOnlyImport = __esm({
-    "src/services/codefixes/splitTypeOnlyImport.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_codefix();
-      errorCodes60 = [Diagnostics.A_type_only_import_can_specify_a_default_import_or_named_bindings_but_not_both.code];
-      fixId48 = "splitTypeOnlyImport";
-      registerCodeFix({
-        errorCodes: errorCodes60,
-        fixIds: [fixId48],
-        getCodeActions: function getCodeActionsToSplitTypeOnlyImport(context) {
-          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => {
-            return splitTypeOnlyImport(t, getImportDeclaration2(context.sourceFile, context.span), context);
-          });
-          if (changes.length) {
-            return [createCodeFixAction(fixId48, changes, Diagnostics.Split_into_two_separate_import_declarations, fixId48, Diagnostics.Split_all_invalid_type_only_imports)];
-          }
-        },
-        getAllCodeActions: (context) => codeFixAll(context, errorCodes60, (changes, error) => {
-          splitTypeOnlyImport(changes, getImportDeclaration2(context.sourceFile, error), context);
-        })
-      });
-    }
-  });
-
-  // src/services/codefixes/convertConstToLet.ts
-  function getInfo20(sourceFile, pos, program) {
-    var _a;
-    const checker = program.getTypeChecker();
-    const symbol = checker.getSymbolAtLocation(getTokenAtPosition(sourceFile, pos));
-    if (symbol === void 0)
-      return;
-    const declaration = tryCast((_a = symbol == null ? void 0 : symbol.valueDeclaration) == null ? void 0 : _a.parent, isVariableDeclarationList);
-    if (declaration === void 0)
-      return;
-    const constToken = findChildOfKind(declaration, 87 /* ConstKeyword */, sourceFile);
-    if (constToken === void 0)
-      return;
-    return { symbol, token: constToken };
-  }
-  function doChange39(changes, sourceFile, token) {
-    changes.replaceNode(sourceFile, token, factory.createToken(121 /* LetKeyword */));
-  }
-  var fixId49, errorCodes61;
-  var init_convertConstToLet = __esm({
-    "src/services/codefixes/convertConstToLet.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_codefix();
-      fixId49 = "fixConvertConstToLet";
-      errorCodes61 = [Diagnostics.Cannot_assign_to_0_because_it_is_a_constant.code];
-      registerCodeFix({
-        errorCodes: errorCodes61,
-        getCodeActions: function getCodeActionsToConvertConstToLet(context) {
-          const { sourceFile, span, program } = context;
-          const info = getInfo20(sourceFile, span.start, program);
-          if (info === void 0)
-            return;
-          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange39(t, sourceFile, info.token));
-          return [createCodeFixActionMaybeFixAll(fixId49, changes, Diagnostics.Convert_const_to_let, fixId49, Diagnostics.Convert_all_const_to_let)];
-        },
-        getAllCodeActions: (context) => {
-          const { program } = context;
-          const seen = /* @__PURE__ */ new Map();
-          return createCombinedCodeActions(ts_textChanges_exports.ChangeTracker.with(context, (changes) => {
-            eachDiagnostic(context, errorCodes61, (diag2) => {
-              const info = getInfo20(diag2.file, diag2.start, program);
-              if (info) {
-                if (addToSeen(seen, getSymbolId(info.symbol))) {
-                  return doChange39(changes, diag2.file, info.token);
-                }
-              }
-              return void 0;
-            });
-          }));
-        },
-        fixIds: [fixId49]
-      });
-    }
-  });
-
-  // src/services/codefixes/fixExpectedComma.ts
-  function getInfo21(sourceFile, pos, _) {
-    const node = getTokenAtPosition(sourceFile, pos);
-    return node.kind === 27 /* SemicolonToken */ && node.parent && (isObjectLiteralExpression(node.parent) || isArrayLiteralExpression(node.parent)) ? { node } : void 0;
-  }
-  function doChange40(changes, sourceFile, { node }) {
-    const newNode = factory.createToken(28 /* CommaToken */);
-    changes.replaceNode(sourceFile, node, newNode);
-  }
-  var fixId50, expectedErrorCode, errorCodes62;
-  var init_fixExpectedComma = __esm({
-    "src/services/codefixes/fixExpectedComma.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_codefix();
-      fixId50 = "fixExpectedComma";
-      expectedErrorCode = Diagnostics._0_expected.code;
-      errorCodes62 = [expectedErrorCode];
-      registerCodeFix({
-        errorCodes: errorCodes62,
-        getCodeActions(context) {
-          const { sourceFile } = context;
-          const info = getInfo21(sourceFile, context.span.start, context.errorCode);
-          if (!info)
-            return void 0;
-          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange40(t, sourceFile, info));
-          return [createCodeFixAction(
-            fixId50,
-            changes,
-            [Diagnostics.Change_0_to_1, ";", ","],
-            fixId50,
-            [Diagnostics.Change_0_to_1, ";", ","]
-          )];
-        },
-        fixIds: [fixId50],
-        getAllCodeActions: (context) => codeFixAll(context, errorCodes62, (changes, diag2) => {
-          const info = getInfo21(diag2.file, diag2.start, diag2.code);
-          if (info)
-            doChange40(changes, context.sourceFile, info);
-        })
-      });
-    }
-  });
-
-  // src/services/codefixes/fixAddVoidToPromise.ts
-  function makeChange11(changes, sourceFile, span, program, seen) {
-    const node = getTokenAtPosition(sourceFile, span.start);
-    if (!isIdentifier(node) || !isCallExpression(node.parent) || node.parent.expression !== node || node.parent.arguments.length !== 0)
-      return;
-    const checker = program.getTypeChecker();
-    const symbol = checker.getSymbolAtLocation(node);
-    const decl = symbol == null ? void 0 : symbol.valueDeclaration;
-    if (!decl || !isParameter(decl) || !isNewExpression(decl.parent.parent))
-      return;
-    if (seen == null ? void 0 : seen.has(decl))
-      return;
-    seen == null ? void 0 : seen.add(decl);
-    const typeArguments = getEffectiveTypeArguments(decl.parent.parent);
-    if (some(typeArguments)) {
-      const typeArgument = typeArguments[0];
-      const needsParens = !isUnionTypeNode(typeArgument) && !isParenthesizedTypeNode(typeArgument) && isParenthesizedTypeNode(factory.createUnionTypeNode([typeArgument, factory.createKeywordTypeNode(116 /* VoidKeyword */)]).types[0]);
-      if (needsParens) {
-        changes.insertText(sourceFile, typeArgument.pos, "(");
-      }
-      changes.insertText(sourceFile, typeArgument.end, needsParens ? ") | void" : " | void");
-    } else {
-      const signature = checker.getResolvedSignature(node.parent);
-      const parameter = signature == null ? void 0 : signature.parameters[0];
-      const parameterType = parameter && checker.getTypeOfSymbolAtLocation(parameter, decl.parent.parent);
-      if (isInJSFile(decl)) {
-        if (!parameterType || parameterType.flags & 3 /* AnyOrUnknown */) {
-          changes.insertText(sourceFile, decl.parent.parent.end, `)`);
-          changes.insertText(sourceFile, skipTrivia(sourceFile.text, decl.parent.parent.pos), `/** @type {Promise} */(`);
-        }
-      } else {
-        if (!parameterType || parameterType.flags & 2 /* Unknown */) {
-          changes.insertText(sourceFile, decl.parent.parent.expression.end, "");
-        }
-      }
-    }
-  }
-  function getEffectiveTypeArguments(node) {
-    var _a;
-    if (isInJSFile(node)) {
-      if (isParenthesizedExpression(node.parent)) {
-        const jsDocType = (_a = getJSDocTypeTag(node.parent)) == null ? void 0 : _a.typeExpression.type;
-        if (jsDocType && isTypeReferenceNode(jsDocType) && isIdentifier(jsDocType.typeName) && idText(jsDocType.typeName) === "Promise") {
-          return jsDocType.typeArguments;
-        }
-      }
-    } else {
-      return node.typeArguments;
-    }
-  }
-  var fixName7, fixId51, errorCodes63;
-  var init_fixAddVoidToPromise = __esm({
-    "src/services/codefixes/fixAddVoidToPromise.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_codefix();
-      fixName7 = "addVoidToPromise";
-      fixId51 = "addVoidToPromise";
-      errorCodes63 = [
-        Diagnostics.Expected_1_argument_but_got_0_new_Promise_needs_a_JSDoc_hint_to_produce_a_resolve_that_can_be_called_without_arguments.code,
-        Diagnostics.Expected_0_arguments_but_got_1_Did_you_forget_to_include_void_in_your_type_argument_to_Promise.code
-      ];
-      registerCodeFix({
-        errorCodes: errorCodes63,
-        fixIds: [fixId51],
-        getCodeActions(context) {
-          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => makeChange11(t, context.sourceFile, context.span, context.program));
-          if (changes.length > 0) {
-            return [createCodeFixAction(fixName7, changes, Diagnostics.Add_void_to_Promise_resolved_without_a_value, fixId51, Diagnostics.Add_void_to_all_Promises_resolved_without_a_value)];
-          }
-        },
-        getAllCodeActions(context) {
-          return codeFixAll(context, errorCodes63, (changes, diag2) => makeChange11(changes, diag2.file, diag2, context.program, /* @__PURE__ */ new Set()));
-        }
-      });
-    }
-  });
-
-  // src/services/_namespaces/ts.codefix.ts
-  var ts_codefix_exports = {};
-  __export(ts_codefix_exports, {
-    PreserveOptionalFlags: () => PreserveOptionalFlags,
-    addNewNodeForMemberSymbol: () => addNewNodeForMemberSymbol,
-    codeFixAll: () => codeFixAll,
-    createCodeFixAction: () => createCodeFixAction,
-    createCodeFixActionMaybeFixAll: () => createCodeFixActionMaybeFixAll,
-    createCodeFixActionWithoutFixAll: () => createCodeFixActionWithoutFixAll,
-    createCombinedCodeActions: () => createCombinedCodeActions,
-    createFileTextChanges: () => createFileTextChanges,
-    createImportAdder: () => createImportAdder,
-    createImportSpecifierResolver: () => createImportSpecifierResolver,
-    createJsonPropertyAssignment: () => createJsonPropertyAssignment,
-    createMissingMemberNodes: () => createMissingMemberNodes,
-    createSignatureDeclarationFromCallExpression: () => createSignatureDeclarationFromCallExpression,
-    createSignatureDeclarationFromSignature: () => createSignatureDeclarationFromSignature,
-    createStubbedBody: () => createStubbedBody,
-    eachDiagnostic: () => eachDiagnostic,
-    findAncestorMatchingSpan: () => findAncestorMatchingSpan,
-    findJsonProperty: () => findJsonProperty,
-    generateAccessorFromProperty: () => generateAccessorFromProperty,
-    getAccessorConvertiblePropertyAtPosition: () => getAccessorConvertiblePropertyAtPosition,
-    getAllFixes: () => getAllFixes,
-    getAllSupers: () => getAllSupers,
-    getArgumentTypesAndTypeParameters: () => getArgumentTypesAndTypeParameters,
-    getFixes: () => getFixes,
-    getImportCompletionAction: () => getImportCompletionAction,
-    getImportKind: () => getImportKind,
-    getJSDocTypedefNode: () => getJSDocTypedefNode,
-    getNoopSymbolTrackerWithResolver: () => getNoopSymbolTrackerWithResolver,
-    getPromoteTypeOnlyCompletionAction: () => getPromoteTypeOnlyCompletionAction,
-    getSupportedErrorCodes: () => getSupportedErrorCodes,
-    importFixName: () => importFixName,
-    importSymbols: () => importSymbols,
-    moduleSpecifierToValidIdentifier: () => moduleSpecifierToValidIdentifier,
-    moduleSymbolToValidIdentifier: () => moduleSymbolToValidIdentifier,
-    parameterShouldGetTypeFromJSDoc: () => parameterShouldGetTypeFromJSDoc,
-    registerCodeFix: () => registerCodeFix,
-    setJsonCompilerOptionValue: () => setJsonCompilerOptionValue,
-    setJsonCompilerOptionValues: () => setJsonCompilerOptionValues,
-    tryGetAutoImportableReferenceFromTypeNode: () => tryGetAutoImportableReferenceFromTypeNode,
-    typeToAutoImportableTypeNode: () => typeToAutoImportableTypeNode
-  });
-  var init_ts_codefix = __esm({
-    "src/services/_namespaces/ts.codefix.ts"() {
-      "use strict";
-      init_codeFixProvider();
-      init_addConvertToUnknownForNonOverlappingTypes();
-      init_addEmptyExportDeclaration();
-      init_addMissingAsync();
-      init_addMissingAwait();
-      init_addMissingConst();
-      init_addMissingDeclareProperty();
-      init_addMissingInvocationForDecorator();
-      init_addNameToNamelessParameter();
-      init_addOptionalPropertyUndefined();
-      init_annotateWithTypeFromJSDoc();
-      init_convertFunctionToEs6Class();
-      init_convertToAsyncFunction();
-      init_convertToEsModule();
-      init_correctQualifiedNameToIndexedAccessType();
-      init_convertToTypeOnlyExport();
-      init_convertToTypeOnlyImport();
-      init_convertTypedefToType();
-      init_convertLiteralTypeToMappedType();
-      init_fixClassIncorrectlyImplementsInterface();
-      init_importFixes();
-      init_fixAddMissingConstraint();
-      init_fixOverrideModifier();
-      init_fixNoPropertyAccessFromIndexSignature();
-      init_fixImplicitThis();
-      init_fixImportNonExportedMember();
-      init_fixIncorrectNamedTupleSyntax();
-      init_fixSpelling();
-      init_returnValueCorrect();
-      init_fixAddMissingMember();
-      init_fixAddMissingNewOperator();
-      init_fixCannotFindModule();
-      init_fixClassDoesntImplementInheritedAbstractMember();
-      init_fixClassSuperMustPrecedeThisAccess();
-      init_fixConstructorForDerivedNeedSuperCall();
-      init_fixEnableJsxFlag();
-      init_fixNaNEquality();
-      init_fixModuleAndTargetOptions();
-      init_fixPropertyAssignment();
-      init_fixExtendsInterfaceBecomesImplements();
-      init_fixForgottenThisPropertyAccess();
-      init_fixInvalidJsxCharacters();
-      init_fixUnmatchedParameter();
-      init_fixUnreferenceableDecoratorMetadata();
-      init_fixUnusedIdentifier();
-      init_fixUnreachableCode();
-      init_fixUnusedLabel();
-      init_fixJSDocTypes();
-      init_fixMissingCallParentheses();
-      init_fixAwaitInSyncFunction();
-      init_fixPropertyOverrideAccessor();
-      init_inferFromUsage();
-      init_fixReturnTypeInAsyncFunction();
-      init_disableJsDiagnostics();
-      init_helpers2();
-      init_generateAccessors();
-      init_fixInvalidImportSyntax();
-      init_fixStrictClassInitialization();
-      init_requireInTs();
-      init_useDefaultImport();
-      init_useBigintLiteral();
-      init_fixAddModuleReferTypeMissingTypeof();
-      init_wrapJsxInFragment();
-      init_convertToMappedObjectType();
-      init_removeAccidentalCallParentheses();
-      init_removeUnnecessaryAwait();
-      init_splitTypeOnlyImport();
-      init_convertConstToLet();
-      init_fixExpectedComma();
-      init_fixAddVoidToPromise();
-    }
-  });
-
-  // src/services/completions.ts
-  function originIsThisType(origin) {
-    return !!(origin.kind & 1 /* ThisType */);
-  }
-  function originIsSymbolMember(origin) {
-    return !!(origin.kind & 2 /* SymbolMember */);
-  }
-  function originIsExport(origin) {
-    return !!(origin && origin.kind & 4 /* Export */);
-  }
-  function originIsResolvedExport(origin) {
-    return !!(origin && origin.kind === 32 /* ResolvedExport */);
-  }
-  function originIncludesSymbolName(origin) {
-    return originIsExport(origin) || originIsResolvedExport(origin) || originIsComputedPropertyName(origin);
-  }
-  function originIsPackageJsonImport(origin) {
-    return (originIsExport(origin) || originIsResolvedExport(origin)) && !!origin.isFromPackageJson;
-  }
-  function originIsPromise(origin) {
-    return !!(origin.kind & 8 /* Promise */);
-  }
-  function originIsNullableMember(origin) {
-    return !!(origin.kind & 16 /* Nullable */);
-  }
-  function originIsTypeOnlyAlias(origin) {
-    return !!(origin && origin.kind & 64 /* TypeOnlyAlias */);
-  }
-  function originIsObjectLiteralMethod(origin) {
-    return !!(origin && origin.kind & 128 /* ObjectLiteralMethod */);
-  }
-  function originIsIgnore(origin) {
-    return !!(origin && origin.kind & 256 /* Ignore */);
-  }
-  function originIsComputedPropertyName(origin) {
-    return !!(origin && origin.kind & 512 /* ComputedPropertyName */);
-  }
-  function resolvingModuleSpecifiers(logPrefix, host, resolver, program, position, preferences, isForImportStatementCompletion, isValidTypeOnlyUseSite, cb) {
-    var _a, _b, _c;
-    const start = timestamp();
-    const needsFullResolution = isForImportStatementCompletion || moduleResolutionSupportsPackageJsonExportsAndImports(getEmitModuleResolutionKind(program.getCompilerOptions()));
-    let skippedAny = false;
-    let ambientCount = 0;
-    let resolvedCount = 0;
-    let resolvedFromCacheCount = 0;
-    let cacheAttemptCount = 0;
-    const result = cb({
-      tryResolve,
-      skippedAny: () => skippedAny,
-      resolvedAny: () => resolvedCount > 0,
-      resolvedBeyondLimit: () => resolvedCount > moduleSpecifierResolutionLimit
-    });
-    const hitRateMessage = cacheAttemptCount ? ` (${(resolvedFromCacheCount / cacheAttemptCount * 100).toFixed(1)}% hit rate)` : "";
-    (_a = host.log) == null ? void 0 : _a.call(host, `${logPrefix}: resolved ${resolvedCount} module specifiers, plus ${ambientCount} ambient and ${resolvedFromCacheCount} from cache${hitRateMessage}`);
-    (_b = host.log) == null ? void 0 : _b.call(host, `${logPrefix}: response is ${skippedAny ? "incomplete" : "complete"}`);
-    (_c = host.log) == null ? void 0 : _c.call(host, `${logPrefix}: ${timestamp() - start}`);
-    return result;
-    function tryResolve(exportInfo, isFromAmbientModule) {
-      if (isFromAmbientModule) {
-        const result3 = resolver.getModuleSpecifierForBestExportInfo(exportInfo, position, isValidTypeOnlyUseSite);
-        if (result3) {
-          ambientCount++;
-        }
-        return result3 || "failed";
-      }
-      const shouldResolveModuleSpecifier = needsFullResolution || preferences.allowIncompleteCompletions && resolvedCount < moduleSpecifierResolutionLimit;
-      const shouldGetModuleSpecifierFromCache = !shouldResolveModuleSpecifier && preferences.allowIncompleteCompletions && cacheAttemptCount < moduleSpecifierResolutionCacheAttemptLimit;
-      const result2 = shouldResolveModuleSpecifier || shouldGetModuleSpecifierFromCache ? resolver.getModuleSpecifierForBestExportInfo(exportInfo, position, isValidTypeOnlyUseSite, shouldGetModuleSpecifierFromCache) : void 0;
-      if (!shouldResolveModuleSpecifier && !shouldGetModuleSpecifierFromCache || shouldGetModuleSpecifierFromCache && !result2) {
-        skippedAny = true;
-      }
-      resolvedCount += (result2 == null ? void 0 : result2.computedWithoutCacheCount) || 0;
-      resolvedFromCacheCount += exportInfo.length - ((result2 == null ? void 0 : result2.computedWithoutCacheCount) || 0);
-      if (shouldGetModuleSpecifierFromCache) {
-        cacheAttemptCount++;
-      }
-      return result2 || (needsFullResolution ? "failed" : "skipped");
-    }
-  }
-  function getCompletionsAtPosition(host, program, log, sourceFile, position, preferences, triggerCharacter, completionKind, cancellationToken, formatContext, includeSymbol = false) {
-    var _a;
-    const { previousToken } = getRelevantTokens(position, sourceFile);
-    if (triggerCharacter && !isInString(sourceFile, position, previousToken) && !isValidTrigger(sourceFile, triggerCharacter, previousToken, position)) {
-      return void 0;
-    }
-    if (triggerCharacter === " ") {
-      if (preferences.includeCompletionsForImportStatements && preferences.includeCompletionsWithInsertText) {
-        return { isGlobalCompletion: true, isMemberCompletion: false, isNewIdentifierLocation: true, isIncomplete: true, entries: [] };
-      }
-      return void 0;
-    }
-    const compilerOptions = program.getCompilerOptions();
-    const checker = program.getTypeChecker();
-    const incompleteCompletionsCache = preferences.allowIncompleteCompletions ? (_a = host.getIncompleteCompletionsCache) == null ? void 0 : _a.call(host) : void 0;
-    if (incompleteCompletionsCache && completionKind === 3 /* TriggerForIncompleteCompletions */ && previousToken && isIdentifier(previousToken)) {
-      const incompleteContinuation = continuePreviousIncompleteResponse(incompleteCompletionsCache, sourceFile, previousToken, program, host, preferences, cancellationToken, position);
-      if (incompleteContinuation) {
-        return incompleteContinuation;
-      }
-    } else {
-      incompleteCompletionsCache == null ? void 0 : incompleteCompletionsCache.clear();
-    }
-    const stringCompletions = ts_Completions_StringCompletions_exports.getStringLiteralCompletions(sourceFile, position, previousToken, compilerOptions, host, program, log, preferences, includeSymbol);
-    if (stringCompletions) {
-      return stringCompletions;
-    }
-    if (previousToken && isBreakOrContinueStatement(previousToken.parent) && (previousToken.kind === 83 /* BreakKeyword */ || previousToken.kind === 88 /* ContinueKeyword */ || previousToken.kind === 80 /* Identifier */)) {
-      return getLabelCompletionAtPosition(previousToken.parent);
-    }
-    const completionData = getCompletionData(
-      program,
-      log,
-      sourceFile,
-      compilerOptions,
-      position,
-      preferences,
-      /*detailsEntryId*/
-      void 0,
-      host,
-      formatContext,
-      cancellationToken
-    );
-    if (!completionData) {
-      return void 0;
-    }
-    switch (completionData.kind) {
-      case 0 /* Data */:
-        const response = completionInfoFromData(sourceFile, host, program, compilerOptions, log, completionData, preferences, formatContext, position, includeSymbol);
-        if (response == null ? void 0 : response.isIncomplete) {
-          incompleteCompletionsCache == null ? void 0 : incompleteCompletionsCache.set(response);
-        }
-        return response;
-      case 1 /* JsDocTagName */:
-        return jsdocCompletionInfo([
-          ...ts_JsDoc_exports.getJSDocTagNameCompletions(),
-          ...getJSDocParameterCompletions(
-            sourceFile,
-            position,
-            checker,
-            compilerOptions,
-            preferences,
-            /*tagNameOnly*/
-            true
-          )
-        ]);
-      case 2 /* JsDocTag */:
-        return jsdocCompletionInfo([
-          ...ts_JsDoc_exports.getJSDocTagCompletions(),
-          ...getJSDocParameterCompletions(
-            sourceFile,
-            position,
-            checker,
-            compilerOptions,
-            preferences,
-            /*tagNameOnly*/
-            false
-          )
-        ]);
-      case 3 /* JsDocParameterName */:
-        return jsdocCompletionInfo(ts_JsDoc_exports.getJSDocParameterNameCompletions(completionData.tag));
-      case 4 /* Keywords */:
-        return specificKeywordCompletionInfo(completionData.keywordCompletions, completionData.isNewIdentifierLocation);
-      default:
-        return Debug.assertNever(completionData);
-    }
-  }
-  function compareCompletionEntries(entryInArray, entryToInsert) {
-    var _a, _b;
-    let result = compareStringsCaseSensitiveUI(entryInArray.sortText, entryToInsert.sortText);
-    if (result === 0 /* EqualTo */) {
-      result = compareStringsCaseSensitiveUI(entryInArray.name, entryToInsert.name);
-    }
-    if (result === 0 /* EqualTo */ && ((_a = entryInArray.data) == null ? void 0 : _a.moduleSpecifier) && ((_b = entryToInsert.data) == null ? void 0 : _b.moduleSpecifier)) {
-      result = compareNumberOfDirectorySeparators(
-        entryInArray.data.moduleSpecifier,
-        entryToInsert.data.moduleSpecifier
-      );
-    }
-    if (result === 0 /* EqualTo */) {
-      return -1 /* LessThan */;
-    }
-    return result;
-  }
-  function completionEntryDataIsResolved(data) {
-    return !!(data == null ? void 0 : data.moduleSpecifier);
-  }
-  function continuePreviousIncompleteResponse(cache, file, location, program, host, preferences, cancellationToken, position) {
-    const previousResponse = cache.get();
-    if (!previousResponse)
-      return void 0;
-    const touchNode = getTouchingPropertyName(file, position);
-    const lowerCaseTokenText = location.text.toLowerCase();
-    const exportMap = getExportInfoMap(file, host, program, preferences, cancellationToken);
-    const newEntries = resolvingModuleSpecifiers(
-      "continuePreviousIncompleteResponse",
-      host,
-      ts_codefix_exports.createImportSpecifierResolver(file, program, host, preferences),
-      program,
-      location.getStart(),
-      preferences,
-      /*isForImportStatementCompletion*/
-      false,
-      isValidTypeOnlyAliasUseSite(location),
-      (context) => {
-        const entries = mapDefined(previousResponse.entries, (entry) => {
-          var _a;
-          if (!entry.hasAction || !entry.source || !entry.data || completionEntryDataIsResolved(entry.data)) {
-            return entry;
-          }
-          if (!charactersFuzzyMatchInString(entry.name, lowerCaseTokenText)) {
-            return void 0;
-          }
-          const { origin } = Debug.checkDefined(getAutoImportSymbolFromCompletionEntryData(entry.name, entry.data, program, host));
-          const info = exportMap.get(file.path, entry.data.exportMapKey);
-          const result = info && context.tryResolve(info, !isExternalModuleNameRelative(stripQuotes(origin.moduleSymbol.name)));
-          if (result === "skipped")
-            return entry;
-          if (!result || result === "failed") {
-            (_a = host.log) == null ? void 0 : _a.call(host, `Unexpected failure resolving auto import for '${entry.name}' from '${entry.source}'`);
-            return void 0;
-          }
-          const newOrigin = {
-            ...origin,
-            kind: 32 /* ResolvedExport */,
-            moduleSpecifier: result.moduleSpecifier
-          };
-          entry.data = originToCompletionEntryData(newOrigin);
-          entry.source = getSourceFromOrigin(newOrigin);
-          entry.sourceDisplay = [textPart(newOrigin.moduleSpecifier)];
-          return entry;
-        });
-        if (!context.skippedAny()) {
-          previousResponse.isIncomplete = void 0;
-        }
-        return entries;
-      }
-    );
-    previousResponse.entries = newEntries;
-    previousResponse.flags = (previousResponse.flags || 0) | 4 /* IsContinuation */;
-    previousResponse.optionalReplacementSpan = getOptionalReplacementSpan(touchNode);
-    return previousResponse;
-  }
-  function jsdocCompletionInfo(entries) {
-    return { isGlobalCompletion: false, isMemberCompletion: false, isNewIdentifierLocation: false, entries };
-  }
-  function getJSDocParameterCompletions(sourceFile, position, checker, options, preferences, tagNameOnly) {
-    const currentToken = getTokenAtPosition(sourceFile, position);
-    if (!isJSDocTag(currentToken) && !isJSDoc(currentToken)) {
-      return [];
-    }
-    const jsDoc = isJSDoc(currentToken) ? currentToken : currentToken.parent;
-    if (!isJSDoc(jsDoc)) {
-      return [];
-    }
-    const func = jsDoc.parent;
-    if (!isFunctionLike(func)) {
-      return [];
-    }
-    const isJs = isSourceFileJS(sourceFile);
-    const isSnippet = preferences.includeCompletionsWithSnippetText || void 0;
-    const paramTagCount = countWhere(jsDoc.tags, (tag) => isJSDocParameterTag(tag) && tag.getEnd() <= position);
-    return mapDefined(func.parameters, (param) => {
-      if (getJSDocParameterTags(param).length) {
-        return void 0;
-      }
-      if (isIdentifier(param.name)) {
-        const tabstopCounter = { tabstop: 1 };
-        const paramName = param.name.text;
-        let displayText = getJSDocParamAnnotation(
-          paramName,
-          param.initializer,
-          param.dotDotDotToken,
-          isJs,
-          /*isObject*/
-          false,
-          /*isSnippet*/
-          false,
-          checker,
-          options,
-          preferences
-        );
-        let snippetText = isSnippet ? getJSDocParamAnnotation(
-          paramName,
-          param.initializer,
-          param.dotDotDotToken,
-          isJs,
-          /*isObject*/
-          false,
-          /*isSnippet*/
-          true,
-          checker,
-          options,
-          preferences,
-          tabstopCounter
-        ) : void 0;
-        if (tagNameOnly) {
-          displayText = displayText.slice(1);
-          if (snippetText)
-            snippetText = snippetText.slice(1);
-        }
-        return {
-          name: displayText,
-          kind: "parameter" /* parameterElement */,
-          sortText: SortText.LocationPriority,
-          insertText: isSnippet ? snippetText : void 0,
-          isSnippet
-        };
-      } else if (param.parent.parameters.indexOf(param) === paramTagCount) {
-        const paramPath = `param${paramTagCount}`;
-        const displayTextResult = generateJSDocParamTagsForDestructuring(
-          paramPath,
-          param.name,
-          param.initializer,
-          param.dotDotDotToken,
-          isJs,
-          /*isSnippet*/
-          false,
-          checker,
-          options,
-          preferences
-        );
-        const snippetTextResult = isSnippet ? generateJSDocParamTagsForDestructuring(
-          paramPath,
-          param.name,
-          param.initializer,
-          param.dotDotDotToken,
-          isJs,
-          /*isSnippet*/
-          true,
-          checker,
-          options,
-          preferences
-        ) : void 0;
-        let displayText = displayTextResult.join(getNewLineCharacter(options) + "* ");
-        let snippetText = snippetTextResult == null ? void 0 : snippetTextResult.join(getNewLineCharacter(options) + "* ");
-        if (tagNameOnly) {
-          displayText = displayText.slice(1);
-          if (snippetText)
-            snippetText = snippetText.slice(1);
-        }
-        return {
-          name: displayText,
-          kind: "parameter" /* parameterElement */,
-          sortText: SortText.LocationPriority,
-          insertText: isSnippet ? snippetText : void 0,
-          isSnippet
-        };
-      }
-    });
-  }
-  function generateJSDocParamTagsForDestructuring(path, pattern, initializer, dotDotDotToken, isJs, isSnippet, checker, options, preferences) {
-    if (!isJs) {
-      return [
-        getJSDocParamAnnotation(
-          path,
-          initializer,
-          dotDotDotToken,
-          isJs,
-          /*isObject*/
-          false,
-          isSnippet,
-          checker,
-          options,
-          preferences,
-          { tabstop: 1 }
-        )
-      ];
-    }
-    return patternWorker(path, pattern, initializer, dotDotDotToken, { tabstop: 1 });
-    function patternWorker(path2, pattern2, initializer2, dotDotDotToken2, counter) {
-      if (isObjectBindingPattern(pattern2) && !dotDotDotToken2) {
-        const oldTabstop = counter.tabstop;
-        const childCounter = { tabstop: oldTabstop };
-        const rootParam = getJSDocParamAnnotation(
-          path2,
-          initializer2,
-          dotDotDotToken2,
-          isJs,
-          /*isObject*/
-          true,
-          isSnippet,
-          checker,
-          options,
-          preferences,
-          childCounter
-        );
-        let childTags = [];
-        for (const element of pattern2.elements) {
-          const elementTags = elementWorker(path2, element, childCounter);
-          if (!elementTags) {
-            childTags = void 0;
-            break;
-          } else {
-            childTags.push(...elementTags);
-          }
-        }
-        if (childTags) {
-          counter.tabstop = childCounter.tabstop;
-          return [rootParam, ...childTags];
-        }
-      }
-      return [
-        getJSDocParamAnnotation(
-          path2,
-          initializer2,
-          dotDotDotToken2,
-          isJs,
-          /*isObject*/
-          false,
-          isSnippet,
-          checker,
-          options,
-          preferences,
-          counter
-        )
-      ];
-    }
-    function elementWorker(path2, element, counter) {
-      if (!element.propertyName && isIdentifier(element.name) || isIdentifier(element.name)) {
-        const propertyName = element.propertyName ? tryGetTextOfPropertyName(element.propertyName) : element.name.text;
-        if (!propertyName) {
-          return void 0;
-        }
-        const paramName = `${path2}.${propertyName}`;
-        return [
-          getJSDocParamAnnotation(
-            paramName,
-            element.initializer,
-            element.dotDotDotToken,
-            isJs,
-            /*isObject*/
-            false,
-            isSnippet,
-            checker,
-            options,
-            preferences,
-            counter
-          )
-        ];
-      } else if (element.propertyName) {
-        const propertyName = tryGetTextOfPropertyName(element.propertyName);
-        return propertyName && patternWorker(`${path2}.${propertyName}`, element.name, element.initializer, element.dotDotDotToken, counter);
-      }
-      return void 0;
-    }
-  }
-  function getJSDocParamAnnotation(paramName, initializer, dotDotDotToken, isJs, isObject, isSnippet, checker, options, preferences, tabstopCounter) {
-    if (isSnippet) {
-      Debug.assertIsDefined(tabstopCounter);
-    }
-    if (initializer) {
-      paramName = getJSDocParamNameWithInitializer(paramName, initializer);
-    }
-    if (isSnippet) {
-      paramName = escapeSnippetText(paramName);
-    }
-    if (isJs) {
-      let type = "*";
-      if (isObject) {
-        Debug.assert(!dotDotDotToken, `Cannot annotate a rest parameter with type 'Object'.`);
-        type = "Object";
-      } else {
-        if (initializer) {
-          const inferredType = checker.getTypeAtLocation(initializer.parent);
-          if (!(inferredType.flags & (1 /* Any */ | 16384 /* Void */))) {
-            const sourceFile = initializer.getSourceFile();
-            const quotePreference = getQuotePreference(sourceFile, preferences);
-            const builderFlags = quotePreference === 0 /* Single */ ? 268435456 /* UseSingleQuotesForStringLiteralType */ : 0 /* None */;
-            const typeNode = checker.typeToTypeNode(inferredType, findAncestor(initializer, isFunctionLike), builderFlags);
-            if (typeNode) {
-              const printer = isSnippet ? createSnippetPrinter({
-                removeComments: true,
-                module: options.module,
-                target: options.target
-              }) : createPrinter({
-                removeComments: true,
-                module: options.module,
-                target: options.target
-              });
-              setEmitFlags(typeNode, 1 /* SingleLine */);
-              type = printer.printNode(4 /* Unspecified */, typeNode, sourceFile);
-            }
-          }
-        }
-        if (isSnippet && type === "*") {
-          type = `\${${tabstopCounter.tabstop++}:${type}}`;
-        }
-      }
-      const dotDotDot = !isObject && dotDotDotToken ? "..." : "";
-      const description3 = isSnippet ? `\${${tabstopCounter.tabstop++}}` : "";
-      return `@param {${dotDotDot}${type}} ${paramName} ${description3}`;
-    } else {
-      const description3 = isSnippet ? `\${${tabstopCounter.tabstop++}}` : "";
-      return `@param ${paramName} ${description3}`;
-    }
-  }
-  function getJSDocParamNameWithInitializer(paramName, initializer) {
-    const initializerText = initializer.getText().trim();
-    if (initializerText.includes("\n") || initializerText.length > 80) {
-      return `[${paramName}]`;
-    }
-    return `[${paramName}=${initializerText}]`;
-  }
-  function keywordToCompletionEntry(keyword) {
-    return {
-      name: tokenToString(keyword),
-      kind: "keyword" /* keyword */,
-      kindModifiers: "" /* none */,
-      sortText: SortText.GlobalsOrKeywords
-    };
-  }
-  function specificKeywordCompletionInfo(entries, isNewIdentifierLocation) {
-    return {
-      isGlobalCompletion: false,
-      isMemberCompletion: false,
-      isNewIdentifierLocation,
-      entries: entries.slice()
-    };
-  }
-  function keywordCompletionData(keywordFilters, filterOutTsOnlyKeywords, isNewIdentifierLocation) {
-    return {
-      kind: 4 /* Keywords */,
-      keywordCompletions: getKeywordCompletions(keywordFilters, filterOutTsOnlyKeywords),
-      isNewIdentifierLocation
-    };
-  }
-  function keywordFiltersFromSyntaxKind(keywordCompletion) {
-    switch (keywordCompletion) {
-      case 156 /* TypeKeyword */:
-        return 8 /* TypeKeyword */;
-      default:
-        Debug.fail("Unknown mapping from SyntaxKind to KeywordCompletionFilters");
-    }
-  }
-  function getOptionalReplacementSpan(location) {
-    return (location == null ? void 0 : location.kind) === 80 /* Identifier */ ? createTextSpanFromNode(location) : void 0;
-  }
-  function completionInfoFromData(sourceFile, host, program, compilerOptions, log, completionData, preferences, formatContext, position, includeSymbol) {
-    const {
-      symbols,
-      contextToken,
-      completionKind,
-      isInSnippetScope,
-      isNewIdentifierLocation,
-      location,
-      propertyAccessToConvert,
-      keywordFilters,
-      symbolToOriginInfoMap,
-      recommendedCompletion,
-      isJsxInitializer,
-      isTypeOnlyLocation,
-      isJsxIdentifierExpected,
-      isRightOfOpenTag,
-      isRightOfDotOrQuestionDot,
-      importStatementCompletion,
-      insideJsDocTagTypeExpression,
-      symbolToSortTextMap,
-      hasUnresolvedAutoImports
-    } = completionData;
-    let literals = completionData.literals;
-    const checker = program.getTypeChecker();
-    if (getLanguageVariant(sourceFile.scriptKind) === 1 /* JSX */) {
-      const completionInfo = getJsxClosingTagCompletion(location, sourceFile);
-      if (completionInfo) {
-        return completionInfo;
-      }
-    }
-    const caseClause = findAncestor(contextToken, isCaseClause);
-    if (caseClause && (isCaseKeyword(contextToken) || isNodeDescendantOf(contextToken, caseClause.expression))) {
-      const tracker = newCaseClauseTracker(checker, caseClause.parent.clauses);
-      literals = literals.filter((literal) => !tracker.hasValue(literal));
-      symbols.forEach((symbol, i) => {
-        if (symbol.valueDeclaration && isEnumMember(symbol.valueDeclaration)) {
-          const value = checker.getConstantValue(symbol.valueDeclaration);
-          if (value !== void 0 && tracker.hasValue(value)) {
-            symbolToOriginInfoMap[i] = { kind: 256 /* Ignore */ };
-          }
-        }
-      });
-    }
-    const entries = createSortedArray();
-    const isChecked = isCheckedFile(sourceFile, compilerOptions);
-    if (isChecked && !isNewIdentifierLocation && (!symbols || symbols.length === 0) && keywordFilters === 0 /* None */) {
-      return void 0;
-    }
-    const uniqueNames = getCompletionEntriesFromSymbols(
-      symbols,
-      entries,
-      /*replacementToken*/
-      void 0,
-      contextToken,
-      location,
-      position,
-      sourceFile,
-      host,
-      program,
-      getEmitScriptTarget(compilerOptions),
-      log,
-      completionKind,
-      preferences,
-      compilerOptions,
-      formatContext,
-      isTypeOnlyLocation,
-      propertyAccessToConvert,
-      isJsxIdentifierExpected,
-      isJsxInitializer,
-      importStatementCompletion,
-      recommendedCompletion,
-      symbolToOriginInfoMap,
-      symbolToSortTextMap,
-      isJsxIdentifierExpected,
-      isRightOfOpenTag,
-      includeSymbol
-    );
-    if (keywordFilters !== 0 /* None */) {
-      for (const keywordEntry of getKeywordCompletions(keywordFilters, !insideJsDocTagTypeExpression && isSourceFileJS(sourceFile))) {
-        if (isTypeOnlyLocation && isTypeKeyword(stringToToken(keywordEntry.name)) || !uniqueNames.has(keywordEntry.name)) {
-          uniqueNames.add(keywordEntry.name);
-          insertSorted(
-            entries,
-            keywordEntry,
-            compareCompletionEntries,
-            /*allowDuplicates*/
-            true
-          );
-        }
-      }
-    }
-    for (const keywordEntry of getContextualKeywords(contextToken, position)) {
-      if (!uniqueNames.has(keywordEntry.name)) {
-        uniqueNames.add(keywordEntry.name);
-        insertSorted(
-          entries,
-          keywordEntry,
-          compareCompletionEntries,
-          /*allowDuplicates*/
-          true
-        );
-      }
-    }
-    for (const literal of literals) {
-      const literalEntry = createCompletionEntryForLiteral(sourceFile, preferences, literal);
-      uniqueNames.add(literalEntry.name);
-      insertSorted(
-        entries,
-        literalEntry,
-        compareCompletionEntries,
-        /*allowDuplicates*/
-        true
-      );
-    }
-    if (!isChecked) {
-      getJSCompletionEntries(sourceFile, location.pos, uniqueNames, getEmitScriptTarget(compilerOptions), entries);
-    }
-    let caseBlock;
-    if (preferences.includeCompletionsWithInsertText && contextToken && !isRightOfOpenTag && !isRightOfDotOrQuestionDot && (caseBlock = findAncestor(contextToken, isCaseBlock))) {
-      const cases = getExhaustiveCaseSnippets(caseBlock, sourceFile, preferences, compilerOptions, host, program, formatContext);
-      if (cases) {
-        entries.push(cases.entry);
-      }
-    }
-    return {
-      flags: completionData.flags,
-      isGlobalCompletion: isInSnippetScope,
-      isIncomplete: preferences.allowIncompleteCompletions && hasUnresolvedAutoImports ? true : void 0,
-      isMemberCompletion: isMemberCompletionKind(completionKind),
-      isNewIdentifierLocation,
-      optionalReplacementSpan: getOptionalReplacementSpan(location),
-      entries
-    };
-  }
-  function isCheckedFile(sourceFile, compilerOptions) {
-    return !isSourceFileJS(sourceFile) || !!isCheckJsEnabledForFile(sourceFile, compilerOptions);
-  }
-  function getExhaustiveCaseSnippets(caseBlock, sourceFile, preferences, options, host, program, formatContext) {
-    const clauses = caseBlock.clauses;
-    const checker = program.getTypeChecker();
-    const switchType = checker.getTypeAtLocation(caseBlock.parent.expression);
-    if (switchType && switchType.isUnion() && every(switchType.types, (type) => type.isLiteral())) {
-      const tracker = newCaseClauseTracker(checker, clauses);
-      const target = getEmitScriptTarget(options);
-      const quotePreference = getQuotePreference(sourceFile, preferences);
-      const importAdder = ts_codefix_exports.createImportAdder(sourceFile, program, preferences, host);
-      const elements = [];
-      for (const type of switchType.types) {
-        if (type.flags & 1024 /* EnumLiteral */) {
-          Debug.assert(type.symbol, "An enum member type should have a symbol");
-          Debug.assert(type.symbol.parent, "An enum member type should have a parent symbol (the enum symbol)");
-          const enumValue = type.symbol.valueDeclaration && checker.getConstantValue(type.symbol.valueDeclaration);
-          if (enumValue !== void 0) {
-            if (tracker.hasValue(enumValue)) {
-              continue;
-            }
-            tracker.addValue(enumValue);
-          }
-          const typeNode = ts_codefix_exports.typeToAutoImportableTypeNode(checker, importAdder, type, caseBlock, target);
-          if (!typeNode) {
-            return void 0;
-          }
-          const expr = typeNodeToExpression(typeNode, target, quotePreference);
-          if (!expr) {
-            return void 0;
-          }
-          elements.push(expr);
-        } else if (!tracker.hasValue(type.value)) {
-          switch (typeof type.value) {
-            case "object":
-              elements.push(type.value.negative ? factory.createPrefixUnaryExpression(41 /* MinusToken */, factory.createBigIntLiteral({ negative: false, base10Value: type.value.base10Value })) : factory.createBigIntLiteral(type.value));
-              break;
-            case "number":
-              elements.push(type.value < 0 ? factory.createPrefixUnaryExpression(41 /* MinusToken */, factory.createNumericLiteral(-type.value)) : factory.createNumericLiteral(type.value));
-              break;
-            case "string":
-              elements.push(factory.createStringLiteral(type.value, quotePreference === 0 /* Single */));
-              break;
-          }
-        }
-      }
-      if (elements.length === 0) {
-        return void 0;
-      }
-      const newClauses = map(elements, (element) => factory.createCaseClause(element, []));
-      const newLineChar = getNewLineOrDefaultFromHost(host, formatContext == null ? void 0 : formatContext.options);
-      const printer = createSnippetPrinter({
-        removeComments: true,
-        module: options.module,
-        target: options.target,
-        newLine: getNewLineKind(newLineChar)
-      });
-      const printNode = formatContext ? (node) => printer.printAndFormatNode(4 /* Unspecified */, node, sourceFile, formatContext) : (node) => printer.printNode(4 /* Unspecified */, node, sourceFile);
-      const insertText = map(newClauses, (clause, i) => {
-        if (preferences.includeCompletionsWithSnippetText) {
-          return `${printNode(clause)}$${i + 1}`;
-        }
-        return `${printNode(clause)}`;
-      }).join(newLineChar);
-      const firstClause = printer.printNode(4 /* Unspecified */, newClauses[0], sourceFile);
-      return {
-        entry: {
-          name: `${firstClause} ...`,
-          kind: "" /* unknown */,
-          sortText: SortText.GlobalsOrKeywords,
-          insertText,
-          hasAction: importAdder.hasFixes() || void 0,
-          source: "SwitchCases/" /* SwitchCases */,
-          isSnippet: preferences.includeCompletionsWithSnippetText ? true : void 0
-        },
-        importAdder
-      };
-    }
-    return void 0;
-  }
-  function typeNodeToExpression(typeNode, languageVersion, quotePreference) {
-    switch (typeNode.kind) {
-      case 182 /* TypeReference */:
-        const typeName = typeNode.typeName;
-        return entityNameToExpression(typeName, languageVersion, quotePreference);
-      case 198 /* IndexedAccessType */:
-        const objectExpression = typeNodeToExpression(typeNode.objectType, languageVersion, quotePreference);
-        const indexExpression = typeNodeToExpression(typeNode.indexType, languageVersion, quotePreference);
-        return objectExpression && indexExpression && factory.createElementAccessExpression(objectExpression, indexExpression);
-      case 200 /* LiteralType */:
-        const literal = typeNode.literal;
-        switch (literal.kind) {
-          case 11 /* StringLiteral */:
-            return factory.createStringLiteral(literal.text, quotePreference === 0 /* Single */);
-          case 9 /* NumericLiteral */:
-            return factory.createNumericLiteral(literal.text, literal.numericLiteralFlags);
-        }
-        return void 0;
-      case 195 /* ParenthesizedType */:
-        const exp = typeNodeToExpression(typeNode.type, languageVersion, quotePreference);
-        return exp && (isIdentifier(exp) ? exp : factory.createParenthesizedExpression(exp));
-      case 185 /* TypeQuery */:
-        return entityNameToExpression(typeNode.exprName, languageVersion, quotePreference);
-      case 204 /* ImportType */:
-        Debug.fail(`We should not get an import type after calling 'codefix.typeToAutoImportableTypeNode'.`);
-    }
-    return void 0;
-  }
-  function entityNameToExpression(entityName, languageVersion, quotePreference) {
-    if (isIdentifier(entityName)) {
-      return entityName;
-    }
-    const unescapedName = unescapeLeadingUnderscores(entityName.right.escapedText);
-    if (canUsePropertyAccess(unescapedName, languageVersion)) {
-      return factory.createPropertyAccessExpression(
-        entityNameToExpression(entityName.left, languageVersion, quotePreference),
-        unescapedName
-      );
-    } else {
-      return factory.createElementAccessExpression(
-        entityNameToExpression(entityName.left, languageVersion, quotePreference),
-        factory.createStringLiteral(unescapedName, quotePreference === 0 /* Single */)
-      );
-    }
-  }
-  function isMemberCompletionKind(kind) {
-    switch (kind) {
-      case 0 /* ObjectPropertyDeclaration */:
-      case 3 /* MemberLike */:
-      case 2 /* PropertyAccess */:
-        return true;
-      default:
-        return false;
-    }
-  }
-  function getJsxClosingTagCompletion(location, sourceFile) {
-    const jsxClosingElement = findAncestor(location, (node) => {
-      switch (node.kind) {
-        case 286 /* JsxClosingElement */:
-          return true;
-        case 44 /* SlashToken */:
-        case 32 /* GreaterThanToken */:
-        case 80 /* Identifier */:
-        case 210 /* PropertyAccessExpression */:
-          return false;
-        default:
-          return "quit";
-      }
-    });
-    if (jsxClosingElement) {
-      const hasClosingAngleBracket = !!findChildOfKind(jsxClosingElement, 32 /* GreaterThanToken */, sourceFile);
-      const tagName = jsxClosingElement.parent.openingElement.tagName;
-      const closingTag = tagName.getText(sourceFile);
-      const fullClosingTag = closingTag + (hasClosingAngleBracket ? "" : ">");
-      const replacementSpan = createTextSpanFromNode(jsxClosingElement.tagName);
-      const entry = {
-        name: fullClosingTag,
-        kind: "class" /* classElement */,
-        kindModifiers: void 0,
-        sortText: SortText.LocationPriority
-      };
-      return { isGlobalCompletion: false, isMemberCompletion: true, isNewIdentifierLocation: false, optionalReplacementSpan: replacementSpan, entries: [entry] };
-    }
-    return;
-  }
-  function getJSCompletionEntries(sourceFile, position, uniqueNames, target, entries) {
-    getNameTable(sourceFile).forEach((pos, name) => {
-      if (pos === position) {
-        return;
-      }
-      const realName = unescapeLeadingUnderscores(name);
-      if (!uniqueNames.has(realName) && isIdentifierText(realName, target)) {
-        uniqueNames.add(realName);
-        insertSorted(entries, {
-          name: realName,
-          kind: "warning" /* warning */,
-          kindModifiers: "",
-          sortText: SortText.JavascriptIdentifiers,
-          isFromUncheckedFile: true
-        }, compareCompletionEntries);
-      }
-    });
-  }
-  function completionNameForLiteral(sourceFile, preferences, literal) {
-    return typeof literal === "object" ? pseudoBigIntToString(literal) + "n" : isString(literal) ? quote(sourceFile, preferences, literal) : JSON.stringify(literal);
-  }
-  function createCompletionEntryForLiteral(sourceFile, preferences, literal) {
-    return { name: completionNameForLiteral(sourceFile, preferences, literal), kind: "string" /* string */, kindModifiers: "" /* none */, sortText: SortText.LocationPriority };
-  }
-  function createCompletionEntry(symbol, sortText, replacementToken, contextToken, location, position, sourceFile, host, program, name, needsConvertPropertyAccess, origin, recommendedCompletion, propertyAccessToConvert, isJsxInitializer, importStatementCompletion, useSemicolons, options, preferences, completionKind, formatContext, isJsxIdentifierExpected, isRightOfOpenTag, includeSymbol) {
-    let insertText;
-    let replacementSpan = getReplacementSpanForContextToken(replacementToken);
-    let data;
-    let isSnippet;
-    let source = getSourceFromOrigin(origin);
-    let sourceDisplay;
-    let hasAction;
-    let labelDetails;
-    const typeChecker = program.getTypeChecker();
-    const insertQuestionDot = origin && originIsNullableMember(origin);
-    const useBraces = origin && originIsSymbolMember(origin) || needsConvertPropertyAccess;
-    if (origin && originIsThisType(origin)) {
-      insertText = needsConvertPropertyAccess ? `this${insertQuestionDot ? "?." : ""}[${quotePropertyName(sourceFile, preferences, name)}]` : `this${insertQuestionDot ? "?." : "."}${name}`;
-    } else if ((useBraces || insertQuestionDot) && propertyAccessToConvert) {
-      insertText = useBraces ? needsConvertPropertyAccess ? `[${quotePropertyName(sourceFile, preferences, name)}]` : `[${name}]` : name;
-      if (insertQuestionDot || propertyAccessToConvert.questionDotToken) {
-        insertText = `?.${insertText}`;
-      }
-      const dot = findChildOfKind(propertyAccessToConvert, 25 /* DotToken */, sourceFile) || findChildOfKind(propertyAccessToConvert, 29 /* QuestionDotToken */, sourceFile);
-      if (!dot) {
-        return void 0;
-      }
-      const end = startsWith(name, propertyAccessToConvert.name.text) ? propertyAccessToConvert.name.end : dot.end;
-      replacementSpan = createTextSpanFromBounds(dot.getStart(sourceFile), end);
-    }
-    if (isJsxInitializer) {
-      if (insertText === void 0)
-        insertText = name;
-      insertText = `{${insertText}}`;
-      if (typeof isJsxInitializer !== "boolean") {
-        replacementSpan = createTextSpanFromNode(isJsxInitializer, sourceFile);
-      }
-    }
-    if (origin && originIsPromise(origin) && propertyAccessToConvert) {
-      if (insertText === void 0)
-        insertText = name;
-      const precedingToken = findPrecedingToken(propertyAccessToConvert.pos, sourceFile);
-      let awaitText = "";
-      if (precedingToken && positionIsASICandidate(precedingToken.end, precedingToken.parent, sourceFile)) {
-        awaitText = ";";
-      }
-      awaitText += `(await ${propertyAccessToConvert.expression.getText()})`;
-      insertText = needsConvertPropertyAccess ? `${awaitText}${insertText}` : `${awaitText}${insertQuestionDot ? "?." : "."}${insertText}`;
-      const isInAwaitExpression = tryCast(propertyAccessToConvert.parent, isAwaitExpression);
-      const wrapNode = isInAwaitExpression ? propertyAccessToConvert.parent : propertyAccessToConvert.expression;
-      replacementSpan = createTextSpanFromBounds(wrapNode.getStart(sourceFile), propertyAccessToConvert.end);
-    }
-    if (originIsResolvedExport(origin)) {
-      sourceDisplay = [textPart(origin.moduleSpecifier)];
-      if (importStatementCompletion) {
-        ({ insertText, replacementSpan } = getInsertTextAndReplacementSpanForImportCompletion(name, importStatementCompletion, origin, useSemicolons, sourceFile, options, preferences));
-        isSnippet = preferences.includeCompletionsWithSnippetText ? true : void 0;
-      }
-    }
-    if ((origin == null ? void 0 : origin.kind) === 64 /* TypeOnlyAlias */) {
-      hasAction = true;
-    }
-    if (preferences.includeCompletionsWithClassMemberSnippets && preferences.includeCompletionsWithInsertText && completionKind === 3 /* MemberLike */ && isClassLikeMemberCompletion(symbol, location, sourceFile)) {
-      let importAdder;
-      ({ insertText, isSnippet, importAdder, replacementSpan } = getEntryForMemberCompletion(host, program, options, preferences, name, symbol, location, position, contextToken, formatContext));
-      sortText = SortText.ClassMemberSnippets;
-      if (importAdder == null ? void 0 : importAdder.hasFixes()) {
-        hasAction = true;
-        source = "ClassMemberSnippet/" /* ClassMemberSnippet */;
-      }
-    }
-    if (origin && originIsObjectLiteralMethod(origin)) {
-      ({ insertText, isSnippet, labelDetails } = origin);
-      if (!preferences.useLabelDetailsInCompletionEntries) {
-        name = name + labelDetails.detail;
-        labelDetails = void 0;
-      }
-      source = "ObjectLiteralMethodSnippet/" /* ObjectLiteralMethodSnippet */;
-      sortText = SortText.SortBelow(sortText);
-    }
-    if (isJsxIdentifierExpected && !isRightOfOpenTag && preferences.includeCompletionsWithSnippetText && preferences.jsxAttributeCompletionStyle && preferences.jsxAttributeCompletionStyle !== "none" && !(isJsxAttribute(location.parent) && location.parent.initializer)) {
-      let useBraces2 = preferences.jsxAttributeCompletionStyle === "braces";
-      const type = typeChecker.getTypeOfSymbolAtLocation(symbol, location);
-      if (preferences.jsxAttributeCompletionStyle === "auto" && !(type.flags & 528 /* BooleanLike */) && !(type.flags & 1048576 /* Union */ && find(type.types, (type2) => !!(type2.flags & 528 /* BooleanLike */)))) {
-        if (type.flags & 402653316 /* StringLike */ || type.flags & 1048576 /* Union */ && every(type.types, (type2) => !!(type2.flags & (402653316 /* StringLike */ | 32768 /* Undefined */) || isStringAndEmptyAnonymousObjectIntersection(type2)))) {
-          insertText = `${escapeSnippetText(name)}=${quote(sourceFile, preferences, "$1")}`;
-          isSnippet = true;
-        } else {
-          useBraces2 = true;
-        }
-      }
-      if (useBraces2) {
-        insertText = `${escapeSnippetText(name)}={$1}`;
-        isSnippet = true;
-      }
-    }
-    if (insertText !== void 0 && !preferences.includeCompletionsWithInsertText) {
-      return void 0;
-    }
-    if (originIsExport(origin) || originIsResolvedExport(origin)) {
-      data = originToCompletionEntryData(origin);
-      hasAction = !importStatementCompletion;
-    }
-    return {
-      name,
-      kind: ts_SymbolDisplay_exports.getSymbolKind(typeChecker, symbol, location),
-      kindModifiers: ts_SymbolDisplay_exports.getSymbolModifiers(typeChecker, symbol),
-      sortText,
-      source,
-      hasAction: hasAction ? true : void 0,
-      isRecommended: isRecommendedCompletionMatch(symbol, recommendedCompletion, typeChecker) || void 0,
-      insertText,
-      replacementSpan,
-      sourceDisplay,
-      labelDetails,
-      isSnippet,
-      isPackageJsonImport: originIsPackageJsonImport(origin) || void 0,
-      isImportStatementCompletion: !!importStatementCompletion || void 0,
-      data,
-      ...includeSymbol ? { symbol } : void 0
-    };
-  }
-  function isClassLikeMemberCompletion(symbol, location, sourceFile) {
-    if (isInJSFile(location)) {
-      return false;
-    }
-    const memberFlags = 106500 /* ClassMember */ & 900095 /* EnumMemberExcludes */;
-    return !!(symbol.flags & memberFlags) && (isClassLike(location) || location.parent && location.parent.parent && isClassElement(location.parent) && location === location.parent.name && location.parent.getLastToken(sourceFile) === location.parent.name && isClassLike(location.parent.parent) || location.parent && isSyntaxList(location) && isClassLike(location.parent));
-  }
-  function getEntryForMemberCompletion(host, program, options, preferences, name, symbol, location, position, contextToken, formatContext) {
-    const classLikeDeclaration = findAncestor(location, isClassLike);
-    if (!classLikeDeclaration) {
-      return { insertText: name };
-    }
-    let isSnippet;
-    let replacementSpan;
-    let insertText = name;
-    const checker = program.getTypeChecker();
-    const sourceFile = location.getSourceFile();
-    const printer = createSnippetPrinter({
-      removeComments: true,
-      module: options.module,
-      target: options.target,
-      omitTrailingSemicolon: false,
-      newLine: getNewLineKind(getNewLineOrDefaultFromHost(host, formatContext == null ? void 0 : formatContext.options))
-    });
-    const importAdder = ts_codefix_exports.createImportAdder(sourceFile, program, preferences, host);
-    let body;
-    if (preferences.includeCompletionsWithSnippetText) {
-      isSnippet = true;
-      const emptyStmt = factory.createEmptyStatement();
-      body = factory.createBlock(
-        [emptyStmt],
-        /*multiLine*/
-        true
-      );
-      setSnippetElement(emptyStmt, { kind: 0 /* TabStop */, order: 0 });
-    } else {
-      body = factory.createBlock(
-        [],
-        /*multiLine*/
-        true
-      );
-    }
-    let modifiers = 0 /* None */;
-    const { modifiers: presentModifiers, span: modifiersSpan } = getPresentModifiers(contextToken, sourceFile, position);
-    const isAbstract = !!(presentModifiers & 256 /* Abstract */);
-    const completionNodes = [];
-    ts_codefix_exports.addNewNodeForMemberSymbol(
-      symbol,
-      classLikeDeclaration,
-      sourceFile,
-      { program, host },
-      preferences,
-      importAdder,
-      // `addNewNodeForMemberSymbol` calls this callback function for each new member node
-      // it adds for the given member symbol.
-      // We store these member nodes in the `completionNodes` array.
-      // Note: there might be:
-      //  - No nodes if `addNewNodeForMemberSymbol` cannot figure out a node for the member;
-      //  - One node;
-      //  - More than one node if the member is overloaded (e.g. a method with overload signatures).
-      (node) => {
-        let requiredModifiers = 0 /* None */;
-        if (isAbstract) {
-          requiredModifiers |= 256 /* Abstract */;
-        }
-        if (isClassElement(node) && checker.getMemberOverrideModifierStatus(classLikeDeclaration, node, symbol) === 1 /* NeedsOverride */) {
-          requiredModifiers |= 16384 /* Override */;
-        }
-        if (!completionNodes.length) {
-          modifiers = node.modifierFlagsCache | requiredModifiers | presentModifiers;
-        }
-        node = factory.updateModifiers(node, modifiers);
-        completionNodes.push(node);
-      },
-      body,
-      ts_codefix_exports.PreserveOptionalFlags.Property,
-      isAbstract
-    );
-    if (completionNodes.length) {
-      const format = 1 /* MultiLine */ | 131072 /* NoTrailingNewLine */;
-      replacementSpan = modifiersSpan;
-      if (formatContext) {
-        insertText = printer.printAndFormatSnippetList(
-          format,
-          factory.createNodeArray(completionNodes),
-          sourceFile,
-          formatContext
-        );
-      } else {
-        insertText = printer.printSnippetList(
-          format,
-          factory.createNodeArray(completionNodes),
-          sourceFile
-        );
-      }
-    }
-    return { insertText, isSnippet, importAdder, replacementSpan };
-  }
-  function getPresentModifiers(contextToken, sourceFile, position) {
-    if (!contextToken || getLineAndCharacterOfPosition(sourceFile, position).line > getLineAndCharacterOfPosition(sourceFile, contextToken.getEnd()).line) {
-      return { modifiers: 0 /* None */ };
-    }
-    let modifiers = 0 /* None */;
-    let span;
-    let contextMod;
-    if (contextMod = isModifierLike2(contextToken)) {
-      modifiers |= modifierToFlag(contextMod);
-      span = createTextSpanFromNode(contextToken);
-    }
-    if (isPropertyDeclaration(contextToken.parent)) {
-      modifiers |= modifiersToFlags(contextToken.parent.modifiers) & 126975 /* Modifier */;
-      span = createTextSpanFromNode(contextToken.parent);
-    }
-    return { modifiers, span };
-  }
-  function isModifierLike2(node) {
-    if (isModifier(node)) {
-      return node.kind;
-    }
-    if (isIdentifier(node)) {
-      const originalKeywordKind = identifierToKeywordKind(node);
-      if (originalKeywordKind && isModifierKind(originalKeywordKind)) {
-        return originalKeywordKind;
-      }
-    }
-    return void 0;
-  }
-  function getEntryForObjectLiteralMethodCompletion(symbol, name, enclosingDeclaration, program, host, options, preferences, formatContext) {
-    const isSnippet = preferences.includeCompletionsWithSnippetText || void 0;
-    let insertText = name;
-    const sourceFile = enclosingDeclaration.getSourceFile();
-    const method = createObjectLiteralMethod(symbol, enclosingDeclaration, sourceFile, program, host, preferences);
-    if (!method) {
-      return void 0;
-    }
-    const printer = createSnippetPrinter({
-      removeComments: true,
-      module: options.module,
-      target: options.target,
-      omitTrailingSemicolon: false,
-      newLine: getNewLineKind(getNewLineOrDefaultFromHost(host, formatContext == null ? void 0 : formatContext.options))
-    });
-    if (formatContext) {
-      insertText = printer.printAndFormatSnippetList(16 /* CommaDelimited */ | 64 /* AllowTrailingComma */, factory.createNodeArray(
-        [method],
-        /*hasTrailingComma*/
-        true
-      ), sourceFile, formatContext);
-    } else {
-      insertText = printer.printSnippetList(16 /* CommaDelimited */ | 64 /* AllowTrailingComma */, factory.createNodeArray(
-        [method],
-        /*hasTrailingComma*/
-        true
-      ), sourceFile);
-    }
-    const signaturePrinter = createPrinter({
-      removeComments: true,
-      module: options.module,
-      target: options.target,
-      omitTrailingSemicolon: true
-    });
-    const methodSignature = factory.createMethodSignature(
-      /*modifiers*/
-      void 0,
-      /*name*/
-      "",
-      method.questionToken,
-      method.typeParameters,
-      method.parameters,
-      method.type
-    );
-    const labelDetails = { detail: signaturePrinter.printNode(4 /* Unspecified */, methodSignature, sourceFile) };
-    return { isSnippet, insertText, labelDetails };
-  }
-  function createObjectLiteralMethod(symbol, enclosingDeclaration, sourceFile, program, host, preferences) {
-    const declarations = symbol.getDeclarations();
-    if (!(declarations && declarations.length)) {
-      return void 0;
-    }
-    const checker = program.getTypeChecker();
-    const declaration = declarations[0];
-    const name = getSynthesizedDeepClone(
-      getNameOfDeclaration(declaration),
-      /*includeTrivia*/
-      false
-    );
-    const type = checker.getWidenedType(checker.getTypeOfSymbolAtLocation(symbol, enclosingDeclaration));
-    const quotePreference = getQuotePreference(sourceFile, preferences);
-    const builderFlags = 33554432 /* OmitThisParameter */ | (quotePreference === 0 /* Single */ ? 268435456 /* UseSingleQuotesForStringLiteralType */ : 0 /* None */);
-    switch (declaration.kind) {
-      case 170 /* PropertySignature */:
-      case 171 /* PropertyDeclaration */:
-      case 172 /* MethodSignature */:
-      case 173 /* MethodDeclaration */: {
-        let effectiveType = type.flags & 1048576 /* Union */ && type.types.length < 10 ? checker.getUnionType(type.types, 2 /* Subtype */) : type;
-        if (effectiveType.flags & 1048576 /* Union */) {
-          const functionTypes = filter(effectiveType.types, (type2) => checker.getSignaturesOfType(type2, 0 /* Call */).length > 0);
-          if (functionTypes.length === 1) {
-            effectiveType = functionTypes[0];
-          } else {
-            return void 0;
-          }
-        }
-        const signatures = checker.getSignaturesOfType(effectiveType, 0 /* Call */);
-        if (signatures.length !== 1) {
-          return void 0;
-        }
-        const typeNode = checker.typeToTypeNode(effectiveType, enclosingDeclaration, builderFlags, ts_codefix_exports.getNoopSymbolTrackerWithResolver({ program, host }));
-        if (!typeNode || !isFunctionTypeNode(typeNode)) {
-          return void 0;
-        }
-        let body;
-        if (preferences.includeCompletionsWithSnippetText) {
-          const emptyStmt = factory.createEmptyStatement();
-          body = factory.createBlock(
-            [emptyStmt],
-            /*multiLine*/
-            true
-          );
-          setSnippetElement(emptyStmt, { kind: 0 /* TabStop */, order: 0 });
-        } else {
-          body = factory.createBlock(
-            [],
-            /*multiLine*/
-            true
-          );
-        }
-        const parameters = typeNode.parameters.map((typedParam) => factory.createParameterDeclaration(
-          /*modifiers*/
-          void 0,
-          typedParam.dotDotDotToken,
-          typedParam.name,
-          /*questionToken*/
-          void 0,
-          /*type*/
-          void 0,
-          typedParam.initializer
-        ));
-        return factory.createMethodDeclaration(
-          /*modifiers*/
-          void 0,
-          /*asteriskToken*/
-          void 0,
-          name,
-          /*questionToken*/
-          void 0,
-          /*typeParameters*/
-          void 0,
-          parameters,
-          /*type*/
-          void 0,
-          body
-        );
-      }
-      default:
-        return void 0;
-    }
-  }
-  function createSnippetPrinter(printerOptions) {
-    let escapes;
-    const baseWriter = ts_textChanges_exports.createWriter(getNewLineCharacter(printerOptions));
-    const printer = createPrinter(printerOptions, baseWriter);
-    const writer = {
-      ...baseWriter,
-      write: (s) => escapingWrite(s, () => baseWriter.write(s)),
-      nonEscapingWrite: baseWriter.write,
-      writeLiteral: (s) => escapingWrite(s, () => baseWriter.writeLiteral(s)),
-      writeStringLiteral: (s) => escapingWrite(s, () => baseWriter.writeStringLiteral(s)),
-      writeSymbol: (s, symbol) => escapingWrite(s, () => baseWriter.writeSymbol(s, symbol)),
-      writeParameter: (s) => escapingWrite(s, () => baseWriter.writeParameter(s)),
-      writeComment: (s) => escapingWrite(s, () => baseWriter.writeComment(s)),
-      writeProperty: (s) => escapingWrite(s, () => baseWriter.writeProperty(s))
-    };
-    return {
-      printSnippetList,
-      printAndFormatSnippetList,
-      printNode,
-      printAndFormatNode
-    };
-    function escapingWrite(s, write) {
-      const escaped = escapeSnippetText(s);
-      if (escaped !== s) {
-        const start = baseWriter.getTextPos();
-        write();
-        const end = baseWriter.getTextPos();
-        escapes = append(escapes || (escapes = []), { newText: escaped, span: { start, length: end - start } });
-      } else {
-        write();
-      }
-    }
-    function printSnippetList(format, list, sourceFile) {
-      const unescaped = printUnescapedSnippetList(format, list, sourceFile);
-      return escapes ? ts_textChanges_exports.applyChanges(unescaped, escapes) : unescaped;
-    }
-    function printUnescapedSnippetList(format, list, sourceFile) {
-      escapes = void 0;
-      writer.clear();
-      printer.writeList(format, list, sourceFile, writer);
-      return writer.getText();
-    }
-    function printAndFormatSnippetList(format, list, sourceFile, formatContext) {
-      const syntheticFile = {
-        text: printUnescapedSnippetList(
-          format,
-          list,
-          sourceFile
-        ),
-        getLineAndCharacterOfPosition(pos) {
-          return getLineAndCharacterOfPosition(this, pos);
-        }
-      };
-      const formatOptions = getFormatCodeSettingsForWriting(formatContext, sourceFile);
-      const changes = flatMap(list, (node) => {
-        const nodeWithPos = ts_textChanges_exports.assignPositionsToNode(node);
-        return ts_formatting_exports.formatNodeGivenIndentation(
-          nodeWithPos,
-          syntheticFile,
-          sourceFile.languageVariant,
-          /* indentation */
-          0,
-          /* delta */
-          0,
-          { ...formatContext, options: formatOptions }
-        );
-      });
-      const allChanges = escapes ? stableSort(concatenate(changes, escapes), (a, b) => compareTextSpans(a.span, b.span)) : changes;
-      return ts_textChanges_exports.applyChanges(syntheticFile.text, allChanges);
-    }
-    function printNode(hint, node, sourceFile) {
-      const unescaped = printUnescapedNode(hint, node, sourceFile);
-      return escapes ? ts_textChanges_exports.applyChanges(unescaped, escapes) : unescaped;
-    }
-    function printUnescapedNode(hint, node, sourceFile) {
-      escapes = void 0;
-      writer.clear();
-      printer.writeNode(hint, node, sourceFile, writer);
-      return writer.getText();
-    }
-    function printAndFormatNode(hint, node, sourceFile, formatContext) {
-      const syntheticFile = {
-        text: printUnescapedNode(
-          hint,
-          node,
-          sourceFile
-        ),
-        getLineAndCharacterOfPosition(pos) {
-          return getLineAndCharacterOfPosition(this, pos);
-        }
-      };
-      const formatOptions = getFormatCodeSettingsForWriting(formatContext, sourceFile);
-      const nodeWithPos = ts_textChanges_exports.assignPositionsToNode(node);
-      const changes = ts_formatting_exports.formatNodeGivenIndentation(
-        nodeWithPos,
-        syntheticFile,
-        sourceFile.languageVariant,
-        /* indentation */
-        0,
-        /* delta */
-        0,
-        { ...formatContext, options: formatOptions }
-      );
-      const allChanges = escapes ? stableSort(concatenate(changes, escapes), (a, b) => compareTextSpans(a.span, b.span)) : changes;
-      return ts_textChanges_exports.applyChanges(syntheticFile.text, allChanges);
-    }
-  }
-  function originToCompletionEntryData(origin) {
-    const ambientModuleName = origin.fileName ? void 0 : stripQuotes(origin.moduleSymbol.name);
-    const isPackageJsonImport = origin.isFromPackageJson ? true : void 0;
-    if (originIsResolvedExport(origin)) {
-      const resolvedData = {
-        exportName: origin.exportName,
-        exportMapKey: origin.exportMapKey,
-        moduleSpecifier: origin.moduleSpecifier,
-        ambientModuleName,
-        fileName: origin.fileName,
-        isPackageJsonImport
-      };
-      return resolvedData;
-    }
-    const unresolvedData = {
-      exportName: origin.exportName,
-      exportMapKey: origin.exportMapKey,
-      fileName: origin.fileName,
-      ambientModuleName: origin.fileName ? void 0 : stripQuotes(origin.moduleSymbol.name),
-      isPackageJsonImport: origin.isFromPackageJson ? true : void 0
-    };
-    return unresolvedData;
-  }
-  function completionEntryDataToSymbolOriginInfo(data, completionName, moduleSymbol) {
-    const isDefaultExport = data.exportName === "default" /* Default */;
-    const isFromPackageJson = !!data.isPackageJsonImport;
-    if (completionEntryDataIsResolved(data)) {
-      const resolvedOrigin = {
-        kind: 32 /* ResolvedExport */,
-        exportName: data.exportName,
-        exportMapKey: data.exportMapKey,
-        moduleSpecifier: data.moduleSpecifier,
-        symbolName: completionName,
-        fileName: data.fileName,
-        moduleSymbol,
-        isDefaultExport,
-        isFromPackageJson
-      };
-      return resolvedOrigin;
-    }
-    const unresolvedOrigin = {
-      kind: 4 /* Export */,
-      exportName: data.exportName,
-      exportMapKey: data.exportMapKey,
-      symbolName: completionName,
-      fileName: data.fileName,
-      moduleSymbol,
-      isDefaultExport,
-      isFromPackageJson
-    };
-    return unresolvedOrigin;
-  }
-  function getInsertTextAndReplacementSpanForImportCompletion(name, importStatementCompletion, origin, useSemicolons, sourceFile, options, preferences) {
-    const replacementSpan = importStatementCompletion.replacementSpan;
-    const quotedModuleSpecifier = escapeSnippetText(quote(sourceFile, preferences, origin.moduleSpecifier));
-    const exportKind = origin.isDefaultExport ? 1 /* Default */ : origin.exportName === "export=" /* ExportEquals */ ? 2 /* ExportEquals */ : 0 /* Named */;
-    const tabStop = preferences.includeCompletionsWithSnippetText ? "$1" : "";
-    const importKind = ts_codefix_exports.getImportKind(
-      sourceFile,
-      exportKind,
-      options,
-      /*forceImportKeyword*/
-      true
-    );
-    const isImportSpecifierTypeOnly = importStatementCompletion.couldBeTypeOnlyImportSpecifier;
-    const topLevelTypeOnlyText = importStatementCompletion.isTopLevelTypeOnly ? ` ${tokenToString(156 /* TypeKeyword */)} ` : " ";
-    const importSpecifierTypeOnlyText = isImportSpecifierTypeOnly ? `${tokenToString(156 /* TypeKeyword */)} ` : "";
-    const suffix = useSemicolons ? ";" : "";
-    switch (importKind) {
-      case 3 /* CommonJS */:
-        return { replacementSpan, insertText: `import${topLevelTypeOnlyText}${escapeSnippetText(name)}${tabStop} = require(${quotedModuleSpecifier})${suffix}` };
-      case 1 /* Default */:
-        return { replacementSpan, insertText: `import${topLevelTypeOnlyText}${escapeSnippetText(name)}${tabStop} from ${quotedModuleSpecifier}${suffix}` };
-      case 2 /* Namespace */:
-        return { replacementSpan, insertText: `import${topLevelTypeOnlyText}* as ${escapeSnippetText(name)} from ${quotedModuleSpecifier}${suffix}` };
-      case 0 /* Named */:
-        return { replacementSpan, insertText: `import${topLevelTypeOnlyText}{ ${importSpecifierTypeOnlyText}${escapeSnippetText(name)}${tabStop} } from ${quotedModuleSpecifier}${suffix}` };
-    }
-  }
-  function quotePropertyName(sourceFile, preferences, name) {
-    if (/^\d+$/.test(name)) {
-      return name;
-    }
-    return quote(sourceFile, preferences, name);
-  }
-  function isRecommendedCompletionMatch(localSymbol, recommendedCompletion, checker) {
-    return localSymbol === recommendedCompletion || !!(localSymbol.flags & 1048576 /* ExportValue */) && checker.getExportSymbolOfSymbol(localSymbol) === recommendedCompletion;
-  }
-  function getSourceFromOrigin(origin) {
-    if (originIsExport(origin)) {
-      return stripQuotes(origin.moduleSymbol.name);
-    }
-    if (originIsResolvedExport(origin)) {
-      return origin.moduleSpecifier;
-    }
-    if ((origin == null ? void 0 : origin.kind) === 1 /* ThisType */) {
-      return "ThisProperty/" /* ThisProperty */;
-    }
-    if ((origin == null ? void 0 : origin.kind) === 64 /* TypeOnlyAlias */) {
-      return "TypeOnlyAlias/" /* TypeOnlyAlias */;
-    }
-  }
-  function getCompletionEntriesFromSymbols(symbols, entries, replacementToken, contextToken, location, position, sourceFile, host, program, target, log, kind, preferences, compilerOptions, formatContext, isTypeOnlyLocation, propertyAccessToConvert, jsxIdentifierExpected, isJsxInitializer, importStatementCompletion, recommendedCompletion, symbolToOriginInfoMap, symbolToSortTextMap, isJsxIdentifierExpected, isRightOfOpenTag, includeSymbol = false) {
-    const start = timestamp();
-    const variableOrParameterDeclaration = getVariableOrParameterDeclaration(contextToken, location);
-    const useSemicolons = probablyUsesSemicolons(sourceFile);
-    const typeChecker = program.getTypeChecker();
-    const uniques = /* @__PURE__ */ new Map();
-    for (let i = 0; i < symbols.length; i++) {
-      const symbol = symbols[i];
-      const origin = symbolToOriginInfoMap == null ? void 0 : symbolToOriginInfoMap[i];
-      const info = getCompletionEntryDisplayNameForSymbol(symbol, target, origin, kind, !!jsxIdentifierExpected);
-      if (!info || uniques.get(info.name) && (!origin || !originIsObjectLiteralMethod(origin)) || kind === 1 /* Global */ && symbolToSortTextMap && !shouldIncludeSymbol(symbol, symbolToSortTextMap)) {
-        continue;
-      }
-      const { name, needsConvertPropertyAccess } = info;
-      const originalSortText = (symbolToSortTextMap == null ? void 0 : symbolToSortTextMap[getSymbolId(symbol)]) ?? SortText.LocationPriority;
-      const sortText = isDeprecated(symbol, typeChecker) ? SortText.Deprecated(originalSortText) : originalSortText;
-      const entry = createCompletionEntry(
-        symbol,
-        sortText,
-        replacementToken,
-        contextToken,
-        location,
-        position,
-        sourceFile,
-        host,
-        program,
-        name,
-        needsConvertPropertyAccess,
-        origin,
-        recommendedCompletion,
-        propertyAccessToConvert,
-        isJsxInitializer,
-        importStatementCompletion,
-        useSemicolons,
-        compilerOptions,
-        preferences,
-        kind,
-        formatContext,
-        isJsxIdentifierExpected,
-        isRightOfOpenTag,
-        includeSymbol
-      );
-      if (!entry) {
-        continue;
-      }
-      const shouldShadowLaterSymbols = (!origin || originIsTypeOnlyAlias(origin)) && !(symbol.parent === void 0 && !some(symbol.declarations, (d) => d.getSourceFile() === location.getSourceFile()));
-      uniques.set(name, shouldShadowLaterSymbols);
-      insertSorted(
-        entries,
-        entry,
-        compareCompletionEntries,
-        /*allowDuplicates*/
-        true
-      );
-    }
-    log("getCompletionsAtPosition: getCompletionEntriesFromSymbols: " + (timestamp() - start));
-    return {
-      has: (name) => uniques.has(name),
-      add: (name) => uniques.set(name, true)
-    };
-    function shouldIncludeSymbol(symbol, symbolToSortTextMap2) {
-      var _a;
-      let allFlags = symbol.flags;
-      if (!isSourceFile(location)) {
-        if (isExportAssignment(location.parent)) {
-          return true;
-        }
-        if (tryCast(variableOrParameterDeclaration, isVariableDeclaration) && symbol.valueDeclaration === variableOrParameterDeclaration) {
-          return false;
-        }
-        const symbolDeclaration = symbol.valueDeclaration ?? ((_a = symbol.declarations) == null ? void 0 : _a[0]);
-        if (variableOrParameterDeclaration && symbolDeclaration && (isTypeParameterDeclaration(variableOrParameterDeclaration) && isTypeParameterDeclaration(symbolDeclaration) || isParameter(variableOrParameterDeclaration) && isParameter(symbolDeclaration))) {
-          const symbolDeclarationPos = symbolDeclaration.pos;
-          const parameters = isParameter(variableOrParameterDeclaration) ? variableOrParameterDeclaration.parent.parameters : isInferTypeNode(variableOrParameterDeclaration.parent) ? void 0 : variableOrParameterDeclaration.parent.typeParameters;
-          if (symbolDeclarationPos >= variableOrParameterDeclaration.pos && parameters && symbolDeclarationPos < parameters.end) {
-            return false;
-          }
-        }
-        const symbolOrigin = skipAlias(symbol, typeChecker);
-        if (!!sourceFile.externalModuleIndicator && !compilerOptions.allowUmdGlobalAccess && symbolToSortTextMap2[getSymbolId(symbol)] === SortText.GlobalsOrKeywords && (symbolToSortTextMap2[getSymbolId(symbolOrigin)] === SortText.AutoImportSuggestions || symbolToSortTextMap2[getSymbolId(symbolOrigin)] === SortText.LocationPriority)) {
-          return false;
-        }
-        allFlags |= getCombinedLocalAndExportSymbolFlags(symbolOrigin);
-        if (isInRightSideOfInternalImportEqualsDeclaration(location)) {
-          return !!(allFlags & 1920 /* Namespace */);
-        }
-        if (isTypeOnlyLocation) {
-          return symbolCanBeReferencedAtTypeLocation(symbol, typeChecker);
-        }
-      }
-      return !!(allFlags & 111551 /* Value */);
-    }
-  }
-  function getLabelCompletionAtPosition(node) {
-    const entries = getLabelStatementCompletions(node);
-    if (entries.length) {
-      return { isGlobalCompletion: false, isMemberCompletion: false, isNewIdentifierLocation: false, entries };
-    }
-  }
-  function getLabelStatementCompletions(node) {
-    const entries = [];
-    const uniques = /* @__PURE__ */ new Map();
-    let current = node;
-    while (current) {
-      if (isFunctionLike(current)) {
-        break;
-      }
-      if (isLabeledStatement(current)) {
-        const name = current.label.text;
-        if (!uniques.has(name)) {
-          uniques.set(name, true);
-          entries.push({
-            name,
-            kindModifiers: "" /* none */,
-            kind: "label" /* label */,
-            sortText: SortText.LocationPriority
-          });
-        }
-      }
-      current = current.parent;
-    }
-    return entries;
-  }
-  function getSymbolCompletionFromEntryId(program, log, sourceFile, position, entryId, host, preferences) {
-    if (entryId.source === "SwitchCases/" /* SwitchCases */) {
-      return { type: "cases" };
-    }
-    if (entryId.data) {
-      const autoImport = getAutoImportSymbolFromCompletionEntryData(entryId.name, entryId.data, program, host);
-      if (autoImport) {
-        const { contextToken: contextToken2, previousToken: previousToken2 } = getRelevantTokens(position, sourceFile);
-        return {
-          type: "symbol",
-          symbol: autoImport.symbol,
-          location: getTouchingPropertyName(sourceFile, position),
-          previousToken: previousToken2,
-          contextToken: contextToken2,
-          isJsxInitializer: false,
-          isTypeOnlyLocation: false,
-          origin: autoImport.origin
-        };
-      }
-    }
-    const compilerOptions = program.getCompilerOptions();
-    const completionData = getCompletionData(
-      program,
-      log,
-      sourceFile,
-      compilerOptions,
-      position,
-      { includeCompletionsForModuleExports: true, includeCompletionsWithInsertText: true },
-      entryId,
-      host,
-      /*formatContext*/
-      void 0
-    );
-    if (!completionData) {
-      return { type: "none" };
-    }
-    if (completionData.kind !== 0 /* Data */) {
-      return { type: "request", request: completionData };
-    }
-    const { symbols, literals, location, completionKind, symbolToOriginInfoMap, contextToken, previousToken, isJsxInitializer, isTypeOnlyLocation } = completionData;
-    const literal = find(literals, (l) => completionNameForLiteral(sourceFile, preferences, l) === entryId.name);
-    if (literal !== void 0)
-      return { type: "literal", literal };
-    return firstDefined(symbols, (symbol, index) => {
-      const origin = symbolToOriginInfoMap[index];
-      const info = getCompletionEntryDisplayNameForSymbol(symbol, getEmitScriptTarget(compilerOptions), origin, completionKind, completionData.isJsxIdentifierExpected);
-      return info && info.name === entryId.name && (entryId.source === "ClassMemberSnippet/" /* ClassMemberSnippet */ && symbol.flags & 106500 /* ClassMember */ || entryId.source === "ObjectLiteralMethodSnippet/" /* ObjectLiteralMethodSnippet */ && symbol.flags & (4 /* Property */ | 8192 /* Method */) || getSourceFromOrigin(origin) === entryId.source) ? { type: "symbol", symbol, location, origin, contextToken, previousToken, isJsxInitializer, isTypeOnlyLocation } : void 0;
-    }) || { type: "none" };
-  }
-  function getCompletionEntryDetails(program, log, sourceFile, position, entryId, host, formatContext, preferences, cancellationToken) {
-    const typeChecker = program.getTypeChecker();
-    const compilerOptions = program.getCompilerOptions();
-    const { name, source, data } = entryId;
-    const { previousToken, contextToken } = getRelevantTokens(position, sourceFile);
-    if (isInString(sourceFile, position, previousToken)) {
-      return ts_Completions_StringCompletions_exports.getStringLiteralCompletionDetails(name, sourceFile, position, previousToken, typeChecker, compilerOptions, host, cancellationToken, preferences);
-    }
-    const symbolCompletion = getSymbolCompletionFromEntryId(program, log, sourceFile, position, entryId, host, preferences);
-    switch (symbolCompletion.type) {
-      case "request": {
-        const { request } = symbolCompletion;
-        switch (request.kind) {
-          case 1 /* JsDocTagName */:
-            return ts_JsDoc_exports.getJSDocTagNameCompletionDetails(name);
-          case 2 /* JsDocTag */:
-            return ts_JsDoc_exports.getJSDocTagCompletionDetails(name);
-          case 3 /* JsDocParameterName */:
-            return ts_JsDoc_exports.getJSDocParameterNameCompletionDetails(name);
-          case 4 /* Keywords */:
-            return some(request.keywordCompletions, (c) => c.name === name) ? createSimpleDetails(name, "keyword" /* keyword */, 5 /* keyword */) : void 0;
-          default:
-            return Debug.assertNever(request);
-        }
-      }
-      case "symbol": {
-        const { symbol, location, contextToken: contextToken2, origin, previousToken: previousToken2 } = symbolCompletion;
-        const { codeActions, sourceDisplay } = getCompletionEntryCodeActionsAndSourceDisplay(name, location, contextToken2, origin, symbol, program, host, compilerOptions, sourceFile, position, previousToken2, formatContext, preferences, data, source, cancellationToken);
-        const symbolName2 = originIsComputedPropertyName(origin) ? origin.symbolName : symbol.name;
-        return createCompletionDetailsForSymbol(symbol, symbolName2, typeChecker, sourceFile, location, cancellationToken, codeActions, sourceDisplay);
-      }
-      case "literal": {
-        const { literal } = symbolCompletion;
-        return createSimpleDetails(completionNameForLiteral(sourceFile, preferences, literal), "string" /* string */, typeof literal === "string" ? 8 /* stringLiteral */ : 7 /* numericLiteral */);
-      }
-      case "cases": {
-        const { entry, importAdder } = getExhaustiveCaseSnippets(
-          contextToken.parent,
-          sourceFile,
-          preferences,
-          program.getCompilerOptions(),
-          host,
-          program,
-          /*formatContext*/
-          void 0
-        );
-        if (importAdder.hasFixes()) {
-          const changes = ts_textChanges_exports.ChangeTracker.with(
-            { host, formatContext, preferences },
-            importAdder.writeFixes
-          );
-          return {
-            name: entry.name,
-            kind: "" /* unknown */,
-            kindModifiers: "",
-            displayParts: [],
-            sourceDisplay: void 0,
-            codeActions: [{
-              changes,
-              description: diagnosticToString([Diagnostics.Includes_imports_of_types_referenced_by_0, name])
-            }]
-          };
-        }
-        return {
-          name: entry.name,
-          kind: "" /* unknown */,
-          kindModifiers: "",
-          displayParts: [],
-          sourceDisplay: void 0
-        };
-      }
-      case "none":
-        return allKeywordsCompletions().some((c) => c.name === name) ? createSimpleDetails(name, "keyword" /* keyword */, 5 /* keyword */) : void 0;
-      default:
-        Debug.assertNever(symbolCompletion);
-    }
-  }
-  function createSimpleDetails(name, kind, kind2) {
-    return createCompletionDetails(name, "" /* none */, kind, [displayPart(name, kind2)]);
-  }
-  function createCompletionDetailsForSymbol(symbol, name, checker, sourceFile, location, cancellationToken, codeActions, sourceDisplay) {
-    const { displayParts, documentation, symbolKind, tags } = checker.runWithCancellationToken(
-      cancellationToken,
-      (checker2) => ts_SymbolDisplay_exports.getSymbolDisplayPartsDocumentationAndSymbolKind(checker2, symbol, sourceFile, location, location, 7 /* All */)
-    );
-    return createCompletionDetails(name, ts_SymbolDisplay_exports.getSymbolModifiers(checker, symbol), symbolKind, displayParts, documentation, tags, codeActions, sourceDisplay);
-  }
-  function createCompletionDetails(name, kindModifiers, kind, displayParts, documentation, tags, codeActions, source) {
-    return { name, kindModifiers, kind, displayParts, documentation, tags, codeActions, source, sourceDisplay: source };
-  }
-  function getCompletionEntryCodeActionsAndSourceDisplay(name, location, contextToken, origin, symbol, program, host, compilerOptions, sourceFile, position, previousToken, formatContext, preferences, data, source, cancellationToken) {
-    if (data == null ? void 0 : data.moduleSpecifier) {
-      if (previousToken && getImportStatementCompletionInfo(contextToken || previousToken).replacementSpan) {
-        return { codeActions: void 0, sourceDisplay: [textPart(data.moduleSpecifier)] };
-      }
-    }
-    if (source === "ClassMemberSnippet/" /* ClassMemberSnippet */) {
-      const { importAdder } = getEntryForMemberCompletion(
-        host,
-        program,
-        compilerOptions,
-        preferences,
-        name,
-        symbol,
-        location,
-        position,
-        contextToken,
-        formatContext
-      );
-      if (importAdder) {
-        const changes = ts_textChanges_exports.ChangeTracker.with(
-          { host, formatContext, preferences },
-          importAdder.writeFixes
-        );
-        return {
-          sourceDisplay: void 0,
-          codeActions: [{
-            changes,
-            description: diagnosticToString([Diagnostics.Includes_imports_of_types_referenced_by_0, name])
-          }]
-        };
-      }
-    }
-    if (originIsTypeOnlyAlias(origin)) {
-      const codeAction2 = ts_codefix_exports.getPromoteTypeOnlyCompletionAction(
-        sourceFile,
-        origin.declaration.name,
-        program,
-        host,
-        formatContext,
-        preferences
-      );
-      Debug.assertIsDefined(codeAction2, "Expected to have a code action for promoting type-only alias");
-      return { codeActions: [codeAction2], sourceDisplay: void 0 };
-    }
-    if (!origin || !(originIsExport(origin) || originIsResolvedExport(origin))) {
-      return { codeActions: void 0, sourceDisplay: void 0 };
-    }
-    const checker = origin.isFromPackageJson ? host.getPackageJsonAutoImportProvider().getTypeChecker() : program.getTypeChecker();
-    const { moduleSymbol } = origin;
-    const targetSymbol = checker.getMergedSymbol(skipAlias(symbol.exportSymbol || symbol, checker));
-    const isJsxOpeningTagName = (contextToken == null ? void 0 : contextToken.kind) === 30 /* LessThanToken */ && isJsxOpeningLikeElement(contextToken.parent);
-    const { moduleSpecifier, codeAction } = ts_codefix_exports.getImportCompletionAction(
-      targetSymbol,
-      moduleSymbol,
-      data == null ? void 0 : data.exportMapKey,
-      sourceFile,
-      name,
-      isJsxOpeningTagName,
-      host,
-      program,
-      formatContext,
-      previousToken && isIdentifier(previousToken) ? previousToken.getStart(sourceFile) : position,
-      preferences,
-      cancellationToken
-    );
-    Debug.assert(!(data == null ? void 0 : data.moduleSpecifier) || moduleSpecifier === data.moduleSpecifier);
-    return { sourceDisplay: [textPart(moduleSpecifier)], codeActions: [codeAction] };
-  }
-  function getCompletionEntrySymbol(program, log, sourceFile, position, entryId, host, preferences) {
-    const completion = getSymbolCompletionFromEntryId(program, log, sourceFile, position, entryId, host, preferences);
-    return completion.type === "symbol" ? completion.symbol : void 0;
-  }
-  function getRecommendedCompletion(previousToken, contextualType, checker) {
-    return firstDefined(contextualType && (contextualType.isUnion() ? contextualType.types : [contextualType]), (type) => {
-      const symbol = type && type.symbol;
-      return symbol && (symbol.flags & (8 /* EnumMember */ | 384 /* Enum */ | 32 /* Class */) && !isAbstractConstructorSymbol(symbol)) ? getFirstSymbolInChain(symbol, previousToken, checker) : void 0;
-    });
-  }
-  function getContextualType(previousToken, position, sourceFile, checker) {
-    const { parent: parent2 } = previousToken;
-    switch (previousToken.kind) {
-      case 80 /* Identifier */:
-        return getContextualTypeFromParent(previousToken, checker);
-      case 64 /* EqualsToken */:
-        switch (parent2.kind) {
-          case 259 /* VariableDeclaration */:
-            return checker.getContextualType(parent2.initializer);
-          case 225 /* BinaryExpression */:
-            return checker.getTypeAtLocation(parent2.left);
-          case 290 /* JsxAttribute */:
-            return checker.getContextualTypeForJsxAttribute(parent2);
-          default:
-            return void 0;
-        }
-      case 105 /* NewKeyword */:
-        return checker.getContextualType(parent2);
-      case 84 /* CaseKeyword */:
-        const caseClause = tryCast(parent2, isCaseClause);
-        return caseClause ? getSwitchedType(caseClause, checker) : void 0;
-      case 19 /* OpenBraceToken */:
-        return isJsxExpression(parent2) && !isJsxElement(parent2.parent) && !isJsxFragment(parent2.parent) ? checker.getContextualTypeForJsxAttribute(parent2.parent) : void 0;
-      default:
-        const argInfo = ts_SignatureHelp_exports.getArgumentInfoForCompletions(previousToken, position, sourceFile);
-        return argInfo ? (
-          // At `,`, treat this as the next argument after the comma.
-          checker.getContextualTypeForArgumentAtIndex(argInfo.invocation, argInfo.argumentIndex + (previousToken.kind === 28 /* CommaToken */ ? 1 : 0))
-        ) : isEqualityOperatorKind(previousToken.kind) && isBinaryExpression(parent2) && isEqualityOperatorKind(parent2.operatorToken.kind) ? (
-          // completion at `x ===/**/` should be for the right side
-          checker.getTypeAtLocation(parent2.left)
-        ) : checker.getContextualType(previousToken, 4 /* Completions */) || checker.getContextualType(previousToken);
-    }
-  }
-  function getFirstSymbolInChain(symbol, enclosingDeclaration, checker) {
-    const chain = checker.getAccessibleSymbolChain(
-      symbol,
-      enclosingDeclaration,
-      /*meaning*/
-      67108863 /* All */,
-      /*useOnlyExternalAliasing*/
-      false
-    );
-    if (chain)
-      return first(chain);
-    return symbol.parent && (isModuleSymbol(symbol.parent) ? symbol : getFirstSymbolInChain(symbol.parent, enclosingDeclaration, checker));
-  }
-  function isModuleSymbol(symbol) {
-    var _a;
-    return !!((_a = symbol.declarations) == null ? void 0 : _a.some((d) => d.kind === 311 /* SourceFile */));
-  }
-  function getCompletionData(program, log, sourceFile, compilerOptions, position, preferences, detailsEntryId, host, formatContext, cancellationToken) {
-    const typeChecker = program.getTypeChecker();
-    const inCheckedFile = isCheckedFile(sourceFile, compilerOptions);
-    let start = timestamp();
-    let currentToken = getTokenAtPosition(sourceFile, position);
-    log("getCompletionData: Get current token: " + (timestamp() - start));
-    start = timestamp();
-    const insideComment = isInComment(sourceFile, position, currentToken);
-    log("getCompletionData: Is inside comment: " + (timestamp() - start));
-    let insideJsDocTagTypeExpression = false;
-    let isInSnippetScope = false;
-    if (insideComment) {
-      if (hasDocComment(sourceFile, position)) {
-        if (sourceFile.text.charCodeAt(position - 1) === 64 /* at */) {
-          return { kind: 1 /* JsDocTagName */ };
-        } else {
-          const lineStart = getLineStartPositionForPosition(position, sourceFile);
-          if (!/[^\*|\s(/)]/.test(sourceFile.text.substring(lineStart, position))) {
-            return { kind: 2 /* JsDocTag */ };
-          }
-        }
-      }
-      const tag = getJsDocTagAtPosition(currentToken, position);
-      if (tag) {
-        if (tag.tagName.pos <= position && position <= tag.tagName.end) {
-          return { kind: 1 /* JsDocTagName */ };
-        }
-        const typeExpression = tryGetTypeExpressionFromTag(tag);
-        if (typeExpression) {
-          currentToken = getTokenAtPosition(sourceFile, position);
-          if (!currentToken || !isDeclarationName(currentToken) && (currentToken.parent.kind !== 354 /* JSDocPropertyTag */ || currentToken.parent.name !== currentToken)) {
-            insideJsDocTagTypeExpression = isCurrentlyEditingNode(typeExpression);
-          }
-        }
-        if (!insideJsDocTagTypeExpression && isJSDocParameterTag(tag) && (nodeIsMissing(tag.name) || tag.name.pos <= position && position <= tag.name.end)) {
-          return { kind: 3 /* JsDocParameterName */, tag };
-        }
-      }
-      if (!insideJsDocTagTypeExpression) {
-        log("Returning an empty list because completion was inside a regular comment or plain text part of a JsDoc comment.");
-        return void 0;
-      }
-    }
-    start = timestamp();
-    const isJsOnlyLocation = !insideJsDocTagTypeExpression && isSourceFileJS(sourceFile);
-    const tokens = getRelevantTokens(position, sourceFile);
-    const previousToken = tokens.previousToken;
-    let contextToken = tokens.contextToken;
-    log("getCompletionData: Get previous token: " + (timestamp() - start));
-    let node = currentToken;
-    let propertyAccessToConvert;
-    let isRightOfDot = false;
-    let isRightOfQuestionDot = false;
-    let isRightOfOpenTag = false;
-    let isStartingCloseTag = false;
-    let isJsxInitializer = false;
-    let isJsxIdentifierExpected = false;
-    let importStatementCompletion;
-    let location = getTouchingPropertyName(sourceFile, position);
-    let keywordFilters = 0 /* None */;
-    let isNewIdentifierLocation = false;
-    let flags = 0 /* None */;
-    if (contextToken) {
-      const importStatementCompletionInfo = getImportStatementCompletionInfo(contextToken);
-      if (importStatementCompletionInfo.keywordCompletion) {
-        if (importStatementCompletionInfo.isKeywordOnlyCompletion) {
-          return {
-            kind: 4 /* Keywords */,
-            keywordCompletions: [keywordToCompletionEntry(importStatementCompletionInfo.keywordCompletion)],
-            isNewIdentifierLocation: importStatementCompletionInfo.isNewIdentifierLocation
-          };
-        }
-        keywordFilters = keywordFiltersFromSyntaxKind(importStatementCompletionInfo.keywordCompletion);
-      }
-      if (importStatementCompletionInfo.replacementSpan && preferences.includeCompletionsForImportStatements && preferences.includeCompletionsWithInsertText) {
-        flags |= 2 /* IsImportStatementCompletion */;
-        importStatementCompletion = importStatementCompletionInfo;
-        isNewIdentifierLocation = importStatementCompletionInfo.isNewIdentifierLocation;
-      }
-      if (!importStatementCompletionInfo.replacementSpan && isCompletionListBlocker(contextToken)) {
-        log("Returning an empty list because completion was requested in an invalid position.");
-        return keywordFilters ? keywordCompletionData(keywordFilters, isJsOnlyLocation, isNewIdentifierDefinitionLocation()) : void 0;
-      }
-      let parent2 = contextToken.parent;
-      if (contextToken.kind === 25 /* DotToken */ || contextToken.kind === 29 /* QuestionDotToken */) {
-        isRightOfDot = contextToken.kind === 25 /* DotToken */;
-        isRightOfQuestionDot = contextToken.kind === 29 /* QuestionDotToken */;
-        switch (parent2.kind) {
-          case 210 /* PropertyAccessExpression */:
-            propertyAccessToConvert = parent2;
-            node = propertyAccessToConvert.expression;
-            const leftmostAccessExpression = getLeftmostAccessExpression(propertyAccessToConvert);
-            if (nodeIsMissing(leftmostAccessExpression) || (isCallExpression(node) || isFunctionLike(node)) && node.end === contextToken.pos && node.getChildCount(sourceFile) && last(node.getChildren(sourceFile)).kind !== 22 /* CloseParenToken */) {
-              return void 0;
-            }
-            break;
-          case 165 /* QualifiedName */:
-            node = parent2.left;
-            break;
-          case 266 /* ModuleDeclaration */:
-            node = parent2.name;
-            break;
-          case 204 /* ImportType */:
-            node = parent2;
-            break;
-          case 235 /* MetaProperty */:
-            node = parent2.getFirstToken(sourceFile);
-            Debug.assert(node.kind === 102 /* ImportKeyword */ || node.kind === 105 /* NewKeyword */);
-            break;
-          default:
-            return void 0;
-        }
-      } else if (!importStatementCompletion) {
-        if (parent2 && parent2.kind === 210 /* PropertyAccessExpression */) {
-          contextToken = parent2;
-          parent2 = parent2.parent;
-        }
-        if (currentToken.parent === location) {
-          switch (currentToken.kind) {
-            case 32 /* GreaterThanToken */:
-              if (currentToken.parent.kind === 283 /* JsxElement */ || currentToken.parent.kind === 285 /* JsxOpeningElement */) {
-                location = currentToken;
-              }
-              break;
-            case 44 /* SlashToken */:
-              if (currentToken.parent.kind === 284 /* JsxSelfClosingElement */) {
-                location = currentToken;
-              }
-              break;
-          }
-        }
-        switch (parent2.kind) {
-          case 286 /* JsxClosingElement */:
-            if (contextToken.kind === 44 /* SlashToken */) {
-              isStartingCloseTag = true;
-              location = contextToken;
-            }
-            break;
-          case 225 /* BinaryExpression */:
-            if (!binaryExpressionMayBeOpenTag(parent2)) {
-              break;
-            }
-          case 284 /* JsxSelfClosingElement */:
-          case 283 /* JsxElement */:
-          case 285 /* JsxOpeningElement */:
-            isJsxIdentifierExpected = true;
-            if (contextToken.kind === 30 /* LessThanToken */) {
-              isRightOfOpenTag = true;
-              location = contextToken;
-            }
-            break;
-          case 293 /* JsxExpression */:
-          case 292 /* JsxSpreadAttribute */:
-            if (previousToken.kind === 20 /* CloseBraceToken */ || previousToken.kind === 80 /* Identifier */ && previousToken.parent.kind === 290 /* JsxAttribute */) {
-              isJsxIdentifierExpected = true;
-            }
-            break;
-          case 290 /* JsxAttribute */:
-            if (parent2.initializer === previousToken && previousToken.end < position) {
-              isJsxIdentifierExpected = true;
-              break;
-            }
-            switch (previousToken.kind) {
-              case 64 /* EqualsToken */:
-                isJsxInitializer = true;
-                break;
-              case 80 /* Identifier */:
-                isJsxIdentifierExpected = true;
-                if (parent2 !== previousToken.parent && !parent2.initializer && findChildOfKind(parent2, 64 /* EqualsToken */, sourceFile)) {
-                  isJsxInitializer = previousToken;
-                }
-            }
-            break;
-        }
-      }
-    }
-    const semanticStart = timestamp();
-    let completionKind = 5 /* None */;
-    let isNonContextualObjectLiteral = false;
-    let hasUnresolvedAutoImports = false;
-    let symbols = [];
-    let importSpecifierResolver;
-    const symbolToOriginInfoMap = [];
-    const symbolToSortTextMap = [];
-    const seenPropertySymbols = /* @__PURE__ */ new Map();
-    const isTypeOnlyLocation = isTypeOnlyCompletion();
-    const getModuleSpecifierResolutionHost = memoizeOne((isFromPackageJson) => {
-      return createModuleSpecifierResolutionHost(isFromPackageJson ? host.getPackageJsonAutoImportProvider() : program, host);
-    });
-    if (isRightOfDot || isRightOfQuestionDot) {
-      getTypeScriptMemberSymbols();
-    } else if (isRightOfOpenTag) {
-      symbols = typeChecker.getJsxIntrinsicTagNamesAt(location);
-      Debug.assertEachIsDefined(symbols, "getJsxIntrinsicTagNames() should all be defined");
-      tryGetGlobalSymbols();
-      completionKind = 1 /* Global */;
-      keywordFilters = 0 /* None */;
-    } else if (isStartingCloseTag) {
-      const tagName = contextToken.parent.parent.openingElement.tagName;
-      const tagSymbol = typeChecker.getSymbolAtLocation(tagName);
-      if (tagSymbol) {
-        symbols = [tagSymbol];
-      }
-      completionKind = 1 /* Global */;
-      keywordFilters = 0 /* None */;
-    } else {
-      if (!tryGetGlobalSymbols()) {
-        return keywordFilters ? keywordCompletionData(keywordFilters, isJsOnlyLocation, isNewIdentifierLocation) : void 0;
-      }
-    }
-    log("getCompletionData: Semantic work: " + (timestamp() - semanticStart));
-    const contextualType = previousToken && getContextualType(previousToken, position, sourceFile, typeChecker);
-    const isLiteralExpected = !tryCast(previousToken, isStringLiteralLike) && !isJsxIdentifierExpected;
-    const literals = !isLiteralExpected ? [] : mapDefined(
-      contextualType && (contextualType.isUnion() ? contextualType.types : [contextualType]),
-      (t) => t.isLiteral() && !(t.flags & 1024 /* EnumLiteral */) ? t.value : void 0
-    );
-    const recommendedCompletion = previousToken && contextualType && getRecommendedCompletion(previousToken, contextualType, typeChecker);
-    return {
-      kind: 0 /* Data */,
-      symbols,
-      completionKind,
-      isInSnippetScope,
-      propertyAccessToConvert,
-      isNewIdentifierLocation,
-      location,
-      keywordFilters,
-      literals,
-      symbolToOriginInfoMap,
-      recommendedCompletion,
-      previousToken,
-      contextToken,
-      isJsxInitializer,
-      insideJsDocTagTypeExpression,
-      symbolToSortTextMap,
-      isTypeOnlyLocation,
-      isJsxIdentifierExpected,
-      isRightOfOpenTag,
-      isRightOfDotOrQuestionDot: isRightOfDot || isRightOfQuestionDot,
-      importStatementCompletion,
-      hasUnresolvedAutoImports,
-      flags
-    };
-    function isTagWithTypeExpression(tag) {
-      switch (tag.kind) {
-        case 347 /* JSDocParameterTag */:
-        case 354 /* JSDocPropertyTag */:
-        case 348 /* JSDocReturnTag */:
-        case 350 /* JSDocTypeTag */:
-        case 352 /* JSDocTypedefTag */:
-        case 355 /* JSDocThrowsTag */:
-        case 356 /* JSDocSatisfiesTag */:
-          return true;
-        case 351 /* JSDocTemplateTag */:
-          return !!tag.constraint;
-        default:
-          return false;
-      }
-    }
-    function tryGetTypeExpressionFromTag(tag) {
-      if (isTagWithTypeExpression(tag)) {
-        const typeExpression = isJSDocTemplateTag(tag) ? tag.constraint : tag.typeExpression;
-        return typeExpression && typeExpression.kind === 315 /* JSDocTypeExpression */ ? typeExpression : void 0;
-      }
-      if (isJSDocAugmentsTag(tag) || isJSDocImplementsTag(tag)) {
-        return tag.class;
-      }
-      return void 0;
-    }
-    function getTypeScriptMemberSymbols() {
-      completionKind = 2 /* PropertyAccess */;
-      const isImportType = isLiteralImportTypeNode(node);
-      const isTypeLocation = isImportType && !node.isTypeOf || isPartOfTypeNode(node.parent) || isPossiblyTypeArgumentPosition(contextToken, sourceFile, typeChecker);
-      const isRhsOfImportDeclaration = isInRightSideOfInternalImportEqualsDeclaration(node);
-      if (isEntityName(node) || isImportType || isPropertyAccessExpression(node)) {
-        const isNamespaceName = isModuleDeclaration(node.parent);
-        if (isNamespaceName)
-          isNewIdentifierLocation = true;
-        let symbol = typeChecker.getSymbolAtLocation(node);
-        if (symbol) {
-          symbol = skipAlias(symbol, typeChecker);
-          if (symbol.flags & (1536 /* Module */ | 384 /* Enum */)) {
-            const exportedSymbols = typeChecker.getExportsOfModule(symbol);
-            Debug.assertEachIsDefined(exportedSymbols, "getExportsOfModule() should all be defined");
-            const isValidValueAccess = (symbol2) => typeChecker.isValidPropertyAccess(isImportType ? node : node.parent, symbol2.name);
-            const isValidTypeAccess = (symbol2) => symbolCanBeReferencedAtTypeLocation(symbol2, typeChecker);
-            const isValidAccess = isNamespaceName ? (symbol2) => {
-              var _a;
-              return !!(symbol2.flags & 1920 /* Namespace */) && !((_a = symbol2.declarations) == null ? void 0 : _a.every((d) => d.parent === node.parent));
-            } : isRhsOfImportDeclaration ? (
-              // Any kind is allowed when dotting off namespace in internal import equals declaration
-              (symbol2) => isValidTypeAccess(symbol2) || isValidValueAccess(symbol2)
-            ) : isTypeLocation || insideJsDocTagTypeExpression ? isValidTypeAccess : isValidValueAccess;
-            for (const exportedSymbol of exportedSymbols) {
-              if (isValidAccess(exportedSymbol)) {
-                symbols.push(exportedSymbol);
-              }
-            }
-            if (!isTypeLocation && !insideJsDocTagTypeExpression && symbol.declarations && symbol.declarations.some((d) => d.kind !== 311 /* SourceFile */ && d.kind !== 266 /* ModuleDeclaration */ && d.kind !== 265 /* EnumDeclaration */)) {
-              let type = typeChecker.getTypeOfSymbolAtLocation(symbol, node).getNonOptionalType();
-              let insertQuestionDot = false;
-              if (type.isNullableType()) {
-                const canCorrectToQuestionDot = isRightOfDot && !isRightOfQuestionDot && preferences.includeAutomaticOptionalChainCompletions !== false;
-                if (canCorrectToQuestionDot || isRightOfQuestionDot) {
-                  type = type.getNonNullableType();
-                  if (canCorrectToQuestionDot) {
-                    insertQuestionDot = true;
-                  }
-                }
-              }
-              addTypeProperties(type, !!(node.flags & 32768 /* AwaitContext */), insertQuestionDot);
-            }
-            return;
-          }
-        }
-      }
-      if (!isTypeLocation) {
-        typeChecker.tryGetThisTypeAt(
-          node,
-          /*includeGlobalThis*/
-          false
-        );
-        let type = typeChecker.getTypeAtLocation(node).getNonOptionalType();
-        let insertQuestionDot = false;
-        if (type.isNullableType()) {
-          const canCorrectToQuestionDot = isRightOfDot && !isRightOfQuestionDot && preferences.includeAutomaticOptionalChainCompletions !== false;
-          if (canCorrectToQuestionDot || isRightOfQuestionDot) {
-            type = type.getNonNullableType();
-            if (canCorrectToQuestionDot) {
-              insertQuestionDot = true;
-            }
-          }
-        }
-        addTypeProperties(type, !!(node.flags & 32768 /* AwaitContext */), insertQuestionDot);
-      }
-    }
-    function addTypeProperties(type, insertAwait, insertQuestionDot) {
-      isNewIdentifierLocation = !!type.getStringIndexType();
-      if (isRightOfQuestionDot && some(type.getCallSignatures())) {
-        isNewIdentifierLocation = true;
-      }
-      const propertyAccess = node.kind === 204 /* ImportType */ ? node : node.parent;
-      if (inCheckedFile) {
-        for (const symbol of type.getApparentProperties()) {
-          if (typeChecker.isValidPropertyAccessForCompletions(propertyAccess, type, symbol)) {
-            addPropertySymbol(
-              symbol,
-              /*insertAwait*/
-              false,
-              insertQuestionDot
-            );
-          }
-        }
-      } else {
-        symbols.push(...filter(getPropertiesForCompletion(type, typeChecker), (s) => typeChecker.isValidPropertyAccessForCompletions(propertyAccess, type, s)));
-      }
-      if (insertAwait && preferences.includeCompletionsWithInsertText) {
-        const promiseType = typeChecker.getPromisedTypeOfPromise(type);
-        if (promiseType) {
-          for (const symbol of promiseType.getApparentProperties()) {
-            if (typeChecker.isValidPropertyAccessForCompletions(propertyAccess, promiseType, symbol)) {
-              addPropertySymbol(
-                symbol,
-                /*insertAwait*/
-                true,
-                insertQuestionDot
-              );
-            }
-          }
-        }
-      }
-    }
-    function addPropertySymbol(symbol, insertAwait, insertQuestionDot) {
-      var _a;
-      const computedPropertyName = firstDefined(symbol.declarations, (decl) => tryCast(getNameOfDeclaration(decl), isComputedPropertyName));
-      if (computedPropertyName) {
-        const leftMostName = getLeftMostName(computedPropertyName.expression);
-        const nameSymbol = leftMostName && typeChecker.getSymbolAtLocation(leftMostName);
-        const firstAccessibleSymbol = nameSymbol && getFirstSymbolInChain(nameSymbol, contextToken, typeChecker);
-        if (firstAccessibleSymbol && addToSeen(seenPropertySymbols, getSymbolId(firstAccessibleSymbol))) {
-          const index = symbols.length;
-          symbols.push(firstAccessibleSymbol);
-          const moduleSymbol = firstAccessibleSymbol.parent;
-          if (!moduleSymbol || !isExternalModuleSymbol(moduleSymbol) || typeChecker.tryGetMemberInModuleExportsAndProperties(firstAccessibleSymbol.name, moduleSymbol) !== firstAccessibleSymbol) {
-            symbolToOriginInfoMap[index] = { kind: getNullableSymbolOriginInfoKind(2 /* SymbolMemberNoExport */) };
-          } else {
-            const fileName = isExternalModuleNameRelative(stripQuotes(moduleSymbol.name)) ? (_a = getSourceFileOfModule(moduleSymbol)) == null ? void 0 : _a.fileName : void 0;
-            const { moduleSpecifier } = (importSpecifierResolver || (importSpecifierResolver = ts_codefix_exports.createImportSpecifierResolver(sourceFile, program, host, preferences))).getModuleSpecifierForBestExportInfo([{
-              exportKind: 0 /* Named */,
-              moduleFileName: fileName,
-              isFromPackageJson: false,
-              moduleSymbol,
-              symbol: firstAccessibleSymbol,
-              targetFlags: skipAlias(firstAccessibleSymbol, typeChecker).flags
-            }], position, isValidTypeOnlyAliasUseSite(location)) || {};
-            if (moduleSpecifier) {
-              const origin = {
-                kind: getNullableSymbolOriginInfoKind(6 /* SymbolMemberExport */),
-                moduleSymbol,
-                isDefaultExport: false,
-                symbolName: firstAccessibleSymbol.name,
-                exportName: firstAccessibleSymbol.name,
-                fileName,
-                moduleSpecifier
-              };
-              symbolToOriginInfoMap[index] = origin;
-            }
-          }
-        } else if (preferences.includeCompletionsWithInsertText) {
-          addSymbolOriginInfo(symbol);
-          addSymbolSortInfo(symbol);
-          symbols.push(symbol);
-        }
-      } else {
-        addSymbolOriginInfo(symbol);
-        addSymbolSortInfo(symbol);
-        symbols.push(symbol);
-      }
-      function addSymbolSortInfo(symbol2) {
-        if (isStaticProperty(symbol2)) {
-          symbolToSortTextMap[getSymbolId(symbol2)] = SortText.LocalDeclarationPriority;
-        }
-      }
-      function addSymbolOriginInfo(symbol2) {
-        if (preferences.includeCompletionsWithInsertText) {
-          if (insertAwait && addToSeen(seenPropertySymbols, getSymbolId(symbol2))) {
-            symbolToOriginInfoMap[symbols.length] = { kind: getNullableSymbolOriginInfoKind(8 /* Promise */) };
-          } else if (insertQuestionDot) {
-            symbolToOriginInfoMap[symbols.length] = { kind: 16 /* Nullable */ };
-          }
-        }
-      }
-      function getNullableSymbolOriginInfoKind(kind) {
-        return insertQuestionDot ? kind | 16 /* Nullable */ : kind;
-      }
-    }
-    function getLeftMostName(e) {
-      return isIdentifier(e) ? e : isPropertyAccessExpression(e) ? getLeftMostName(e.expression) : void 0;
-    }
-    function tryGetGlobalSymbols() {
-      const result = tryGetObjectTypeLiteralInTypeArgumentCompletionSymbols() || tryGetObjectLikeCompletionSymbols() || tryGetImportCompletionSymbols() || tryGetImportOrExportClauseCompletionSymbols() || tryGetLocalNamedExportCompletionSymbols() || tryGetConstructorCompletion() || tryGetClassLikeCompletionSymbols() || tryGetJsxCompletionSymbols() || (getGlobalCompletions(), 1 /* Success */);
-      return result === 1 /* Success */;
-    }
-    function tryGetConstructorCompletion() {
-      if (!tryGetConstructorLikeCompletionContainer(contextToken))
-        return 0 /* Continue */;
-      completionKind = 5 /* None */;
-      isNewIdentifierLocation = true;
-      keywordFilters = 4 /* ConstructorParameterKeywords */;
-      return 1 /* Success */;
-    }
-    function tryGetJsxCompletionSymbols() {
-      const jsxContainer = tryGetContainingJsxElement(contextToken);
-      const attrsType = jsxContainer && typeChecker.getContextualType(jsxContainer.attributes);
-      if (!attrsType)
-        return 0 /* Continue */;
-      const completionsType = jsxContainer && typeChecker.getContextualType(jsxContainer.attributes, 4 /* Completions */);
-      symbols = concatenate(symbols, filterJsxAttributes(getPropertiesForObjectExpression(attrsType, completionsType, jsxContainer.attributes, typeChecker), jsxContainer.attributes.properties));
-      setSortTextToOptionalMember();
-      completionKind = 3 /* MemberLike */;
-      isNewIdentifierLocation = false;
-      return 1 /* Success */;
-    }
-    function tryGetImportCompletionSymbols() {
-      if (!importStatementCompletion)
-        return 0 /* Continue */;
-      isNewIdentifierLocation = true;
-      collectAutoImports();
-      return 1 /* Success */;
-    }
-    function getGlobalCompletions() {
-      keywordFilters = tryGetFunctionLikeBodyCompletionContainer(contextToken) ? 5 /* FunctionLikeBodyKeywords */ : 1 /* All */;
-      completionKind = 1 /* Global */;
-      isNewIdentifierLocation = isNewIdentifierDefinitionLocation();
-      if (previousToken !== contextToken) {
-        Debug.assert(!!previousToken, "Expected 'contextToken' to be defined when different from 'previousToken'.");
-      }
-      const adjustedPosition = previousToken !== contextToken ? previousToken.getStart() : position;
-      const scopeNode = getScopeNode(contextToken, adjustedPosition, sourceFile) || sourceFile;
-      isInSnippetScope = isSnippetScope(scopeNode);
-      const symbolMeanings = (isTypeOnlyLocation ? 0 /* None */ : 111551 /* Value */) | 788968 /* Type */ | 1920 /* Namespace */ | 2097152 /* Alias */;
-      const typeOnlyAliasNeedsPromotion = previousToken && !isValidTypeOnlyAliasUseSite(previousToken);
-      symbols = concatenate(symbols, typeChecker.getSymbolsInScope(scopeNode, symbolMeanings));
-      Debug.assertEachIsDefined(symbols, "getSymbolsInScope() should all be defined");
-      for (let i = 0; i < symbols.length; i++) {
-        const symbol = symbols[i];
-        if (!typeChecker.isArgumentsSymbol(symbol) && !some(symbol.declarations, (d) => d.getSourceFile() === sourceFile)) {
-          symbolToSortTextMap[getSymbolId(symbol)] = SortText.GlobalsOrKeywords;
-        }
-        if (typeOnlyAliasNeedsPromotion && !(symbol.flags & 111551 /* Value */)) {
-          const typeOnlyAliasDeclaration = symbol.declarations && find(symbol.declarations, isTypeOnlyImportDeclaration);
-          if (typeOnlyAliasDeclaration) {
-            const origin = { kind: 64 /* TypeOnlyAlias */, declaration: typeOnlyAliasDeclaration };
-            symbolToOriginInfoMap[i] = origin;
-          }
-        }
-      }
-      if (preferences.includeCompletionsWithInsertText && scopeNode.kind !== 311 /* SourceFile */) {
-        const thisType = typeChecker.tryGetThisTypeAt(
-          scopeNode,
-          /*includeGlobalThis*/
-          false,
-          isClassLike(scopeNode.parent) ? scopeNode : void 0
-        );
-        if (thisType && !isProbablyGlobalType(thisType, sourceFile, typeChecker)) {
-          for (const symbol of getPropertiesForCompletion(thisType, typeChecker)) {
-            symbolToOriginInfoMap[symbols.length] = { kind: 1 /* ThisType */ };
-            symbols.push(symbol);
-            symbolToSortTextMap[getSymbolId(symbol)] = SortText.SuggestedClassMembers;
-          }
-        }
-      }
-      collectAutoImports();
-      if (isTypeOnlyLocation) {
-        keywordFilters = contextToken && isAssertionExpression(contextToken.parent) ? 6 /* TypeAssertionKeywords */ : 7 /* TypeKeywords */;
-      }
-    }
-    function shouldOfferImportCompletions() {
-      if (importStatementCompletion)
-        return true;
-      if (isNonContextualObjectLiteral)
-        return false;
-      if (!preferences.includeCompletionsForModuleExports)
-        return false;
-      if (sourceFile.externalModuleIndicator || sourceFile.commonJsModuleIndicator)
-        return true;
-      if (compilerOptionsIndicateEsModules(program.getCompilerOptions()))
-        return true;
-      return programContainsModules(program);
-    }
-    function isSnippetScope(scopeNode) {
-      switch (scopeNode.kind) {
-        case 311 /* SourceFile */:
-        case 227 /* TemplateExpression */:
-        case 293 /* JsxExpression */:
-        case 240 /* Block */:
-          return true;
-        default:
-          return isStatement(scopeNode);
-      }
-    }
-    function isTypeOnlyCompletion() {
-      return insideJsDocTagTypeExpression || !!importStatementCompletion && isTypeOnlyImportOrExportDeclaration(location.parent) || !isContextTokenValueLocation(contextToken) && (isPossiblyTypeArgumentPosition(contextToken, sourceFile, typeChecker) || isPartOfTypeNode(location) || isContextTokenTypeLocation(contextToken));
-    }
-    function isContextTokenValueLocation(contextToken2) {
-      return contextToken2 && (contextToken2.kind === 114 /* TypeOfKeyword */ && (contextToken2.parent.kind === 185 /* TypeQuery */ || isTypeOfExpression(contextToken2.parent)) || contextToken2.kind === 131 /* AssertsKeyword */ && contextToken2.parent.kind === 181 /* TypePredicate */);
-    }
-    function isContextTokenTypeLocation(contextToken2) {
-      if (contextToken2) {
-        const parentKind = contextToken2.parent.kind;
-        switch (contextToken2.kind) {
-          case 59 /* ColonToken */:
-            return parentKind === 171 /* PropertyDeclaration */ || parentKind === 170 /* PropertySignature */ || parentKind === 168 /* Parameter */ || parentKind === 259 /* VariableDeclaration */ || isFunctionLikeKind(parentKind);
-          case 64 /* EqualsToken */:
-            return parentKind === 264 /* TypeAliasDeclaration */;
-          case 130 /* AsKeyword */:
-            return parentKind === 233 /* AsExpression */;
-          case 30 /* LessThanToken */:
-            return parentKind === 182 /* TypeReference */ || parentKind === 215 /* TypeAssertionExpression */;
-          case 96 /* ExtendsKeyword */:
-            return parentKind === 167 /* TypeParameter */;
-          case 152 /* SatisfiesKeyword */:
-            return parentKind === 237 /* SatisfiesExpression */;
-        }
-      }
-      return false;
-    }
-    function collectAutoImports() {
-      var _a, _b;
-      if (!shouldOfferImportCompletions())
-        return;
-      Debug.assert(!(detailsEntryId == null ? void 0 : detailsEntryId.data), "Should not run 'collectAutoImports' when faster path is available via `data`");
-      if (detailsEntryId && !detailsEntryId.source) {
-        return;
-      }
-      flags |= 1 /* MayIncludeAutoImports */;
-      const isAfterTypeOnlyImportSpecifierModifier = previousToken === contextToken && importStatementCompletion;
-      const lowerCaseTokenText = isAfterTypeOnlyImportSpecifierModifier ? "" : previousToken && isIdentifier(previousToken) ? previousToken.text.toLowerCase() : "";
-      const moduleSpecifierCache = (_a = host.getModuleSpecifierCache) == null ? void 0 : _a.call(host);
-      const exportInfo = getExportInfoMap(sourceFile, host, program, preferences, cancellationToken);
-      const packageJsonAutoImportProvider = (_b = host.getPackageJsonAutoImportProvider) == null ? void 0 : _b.call(host);
-      const packageJsonFilter = detailsEntryId ? void 0 : createPackageJsonImportFilter(sourceFile, preferences, host);
-      resolvingModuleSpecifiers(
-        "collectAutoImports",
-        host,
-        importSpecifierResolver || (importSpecifierResolver = ts_codefix_exports.createImportSpecifierResolver(sourceFile, program, host, preferences)),
-        program,
-        position,
-        preferences,
-        !!importStatementCompletion,
-        isValidTypeOnlyAliasUseSite(location),
-        (context) => {
-          exportInfo.search(
-            sourceFile.path,
-            /*preferCapitalized*/
-            isRightOfOpenTag,
-            (symbolName2, targetFlags) => {
-              if (!isIdentifierText(symbolName2, getEmitScriptTarget(host.getCompilationSettings())))
-                return false;
-              if (!detailsEntryId && isStringANonContextualKeyword(symbolName2))
-                return false;
-              if (!isTypeOnlyLocation && !importStatementCompletion && !(targetFlags & 111551 /* Value */))
-                return false;
-              if (isTypeOnlyLocation && !(targetFlags & (1536 /* Module */ | 788968 /* Type */)))
-                return false;
-              const firstChar = symbolName2.charCodeAt(0);
-              if (isRightOfOpenTag && (firstChar < 65 /* A */ || firstChar > 90 /* Z */))
-                return false;
-              if (detailsEntryId)
-                return true;
-              return charactersFuzzyMatchInString(symbolName2, lowerCaseTokenText);
-            },
-            (info, symbolName2, isFromAmbientModule, exportMapKey) => {
-              if (detailsEntryId && !some(info, (i) => detailsEntryId.source === stripQuotes(i.moduleSymbol.name))) {
-                return;
-              }
-              info = filter(info, isImportableExportInfo);
-              if (!info.length) {
-                return;
-              }
-              const result = context.tryResolve(info, isFromAmbientModule) || {};
-              if (result === "failed")
-                return;
-              let exportInfo2 = info[0], moduleSpecifier;
-              if (result !== "skipped") {
-                ({ exportInfo: exportInfo2 = info[0], moduleSpecifier } = result);
-              }
-              const isDefaultExport = exportInfo2.exportKind === 1 /* Default */;
-              const symbol = isDefaultExport && getLocalSymbolForExportDefault(exportInfo2.symbol) || exportInfo2.symbol;
-              pushAutoImportSymbol(symbol, {
-                kind: moduleSpecifier ? 32 /* ResolvedExport */ : 4 /* Export */,
-                moduleSpecifier,
-                symbolName: symbolName2,
-                exportMapKey,
-                exportName: exportInfo2.exportKind === 2 /* ExportEquals */ ? "export=" /* ExportEquals */ : exportInfo2.symbol.name,
-                fileName: exportInfo2.moduleFileName,
-                isDefaultExport,
-                moduleSymbol: exportInfo2.moduleSymbol,
-                isFromPackageJson: exportInfo2.isFromPackageJson
-              });
-            }
-          );
-          hasUnresolvedAutoImports = context.skippedAny();
-          flags |= context.resolvedAny() ? 8 /* ResolvedModuleSpecifiers */ : 0;
-          flags |= context.resolvedBeyondLimit() ? 16 /* ResolvedModuleSpecifiersBeyondLimit */ : 0;
-        }
-      );
-      function isImportableExportInfo(info) {
-        const moduleFile = tryCast(info.moduleSymbol.valueDeclaration, isSourceFile);
-        if (!moduleFile) {
-          const moduleName = stripQuotes(info.moduleSymbol.name);
-          if (ts_JsTyping_exports.nodeCoreModules.has(moduleName) && startsWith(moduleName, "node:") !== shouldUseUriStyleNodeCoreModules(sourceFile, program)) {
-            return false;
-          }
-          return packageJsonFilter ? packageJsonFilter.allowsImportingAmbientModule(info.moduleSymbol, getModuleSpecifierResolutionHost(info.isFromPackageJson)) : true;
-        }
-        return isImportableFile(
-          info.isFromPackageJson ? packageJsonAutoImportProvider : program,
-          sourceFile,
-          moduleFile,
-          preferences,
-          packageJsonFilter,
-          getModuleSpecifierResolutionHost(info.isFromPackageJson),
-          moduleSpecifierCache
-        );
-      }
-    }
-    function pushAutoImportSymbol(symbol, origin) {
-      const symbolId = getSymbolId(symbol);
-      if (symbolToSortTextMap[symbolId] === SortText.GlobalsOrKeywords) {
-        return;
-      }
-      symbolToOriginInfoMap[symbols.length] = origin;
-      symbolToSortTextMap[symbolId] = importStatementCompletion ? SortText.LocationPriority : SortText.AutoImportSuggestions;
-      symbols.push(symbol);
-    }
-    function collectObjectLiteralMethodSymbols(members, enclosingDeclaration) {
-      if (isInJSFile(location)) {
-        return;
-      }
-      members.forEach((member) => {
-        if (!isObjectLiteralMethodSymbol(member)) {
-          return;
-        }
-        const displayName = getCompletionEntryDisplayNameForSymbol(
-          member,
-          getEmitScriptTarget(compilerOptions),
-          /*origin*/
-          void 0,
-          0 /* ObjectPropertyDeclaration */,
-          /*jsxIdentifierExpected*/
-          false
-        );
-        if (!displayName) {
-          return;
-        }
-        const { name } = displayName;
-        const entryProps = getEntryForObjectLiteralMethodCompletion(
-          member,
-          name,
-          enclosingDeclaration,
-          program,
-          host,
-          compilerOptions,
-          preferences,
-          formatContext
-        );
-        if (!entryProps) {
-          return;
-        }
-        const origin = { kind: 128 /* ObjectLiteralMethod */, ...entryProps };
-        flags |= 32 /* MayIncludeMethodSnippets */;
-        symbolToOriginInfoMap[symbols.length] = origin;
-        symbols.push(member);
-      });
-    }
-    function isObjectLiteralMethodSymbol(symbol) {
-      if (!(symbol.flags & (4 /* Property */ | 8192 /* Method */))) {
-        return false;
-      }
-      return true;
-    }
-    function getScopeNode(initialToken, position2, sourceFile2) {
-      let scope = initialToken;
-      while (scope && !positionBelongsToNode(scope, position2, sourceFile2)) {
-        scope = scope.parent;
-      }
-      return scope;
-    }
-    function isCompletionListBlocker(contextToken2) {
-      const start2 = timestamp();
-      const result = isInStringOrRegularExpressionOrTemplateLiteral(contextToken2) || isSolelyIdentifierDefinitionLocation(contextToken2) || isDotOfNumericLiteral(contextToken2) || isInJsxText(contextToken2) || isBigIntLiteral(contextToken2);
-      log("getCompletionsAtPosition: isCompletionListBlocker: " + (timestamp() - start2));
-      return result;
-    }
-    function isInJsxText(contextToken2) {
-      if (contextToken2.kind === 12 /* JsxText */) {
-        return true;
-      }
-      if (contextToken2.kind === 32 /* GreaterThanToken */ && contextToken2.parent) {
-        if (location === contextToken2.parent && (location.kind === 285 /* JsxOpeningElement */ || location.kind === 284 /* JsxSelfClosingElement */)) {
-          return false;
-        }
-        if (contextToken2.parent.kind === 285 /* JsxOpeningElement */) {
-          return location.parent.kind !== 285 /* JsxOpeningElement */;
-        }
-        if (contextToken2.parent.kind === 286 /* JsxClosingElement */ || contextToken2.parent.kind === 284 /* JsxSelfClosingElement */) {
-          return !!contextToken2.parent.parent && contextToken2.parent.parent.kind === 283 /* JsxElement */;
-        }
-      }
-      return false;
-    }
-    function isNewIdentifierDefinitionLocation() {
-      if (contextToken) {
-        const containingNodeKind = contextToken.parent.kind;
-        const tokenKind = keywordForNode(contextToken);
-        switch (tokenKind) {
-          case 28 /* CommaToken */:
-            return containingNodeKind === 212 /* CallExpression */ || containingNodeKind === 175 /* Constructor */ || containingNodeKind === 213 /* NewExpression */ || containingNodeKind === 208 /* ArrayLiteralExpression */ || containingNodeKind === 225 /* BinaryExpression */ || containingNodeKind === 183 /* FunctionType */ || containingNodeKind === 209 /* ObjectLiteralExpression */;
-          case 21 /* OpenParenToken */:
-            return containingNodeKind === 212 /* CallExpression */ || containingNodeKind === 175 /* Constructor */ || containingNodeKind === 213 /* NewExpression */ || containingNodeKind === 216 /* ParenthesizedExpression */ || containingNodeKind === 195 /* ParenthesizedType */;
-          case 23 /* OpenBracketToken */:
-            return containingNodeKind === 208 /* ArrayLiteralExpression */ || containingNodeKind === 180 /* IndexSignature */ || containingNodeKind === 166 /* ComputedPropertyName */;
-          case 144 /* ModuleKeyword */:
-          case 145 /* NamespaceKeyword */:
-          case 102 /* ImportKeyword */:
-            return true;
-          case 25 /* DotToken */:
-            return containingNodeKind === 266 /* ModuleDeclaration */;
-          case 19 /* OpenBraceToken */:
-            return containingNodeKind === 262 /* ClassDeclaration */ || containingNodeKind === 209 /* ObjectLiteralExpression */;
-          case 64 /* EqualsToken */:
-            return containingNodeKind === 259 /* VariableDeclaration */ || containingNodeKind === 225 /* BinaryExpression */;
-          case 16 /* TemplateHead */:
-            return containingNodeKind === 227 /* TemplateExpression */;
-          case 17 /* TemplateMiddle */:
-            return containingNodeKind === 238 /* TemplateSpan */;
-          case 134 /* AsyncKeyword */:
-            return containingNodeKind === 173 /* MethodDeclaration */ || containingNodeKind === 303 /* ShorthandPropertyAssignment */;
-          case 42 /* AsteriskToken */:
-            return containingNodeKind === 173 /* MethodDeclaration */;
-        }
-        if (isClassMemberCompletionKeyword(tokenKind)) {
-          return true;
-        }
-      }
-      return false;
-    }
-    function isInStringOrRegularExpressionOrTemplateLiteral(contextToken2) {
-      return (isRegularExpressionLiteral(contextToken2) || isStringTextContainingNode(contextToken2)) && (rangeContainsPositionExclusive(contextToken2, position) || position === contextToken2.end && (!!contextToken2.isUnterminated || isRegularExpressionLiteral(contextToken2)));
-    }
-    function tryGetObjectTypeLiteralInTypeArgumentCompletionSymbols() {
-      const typeLiteralNode = tryGetTypeLiteralNode(contextToken);
-      if (!typeLiteralNode)
-        return 0 /* Continue */;
-      const intersectionTypeNode = isIntersectionTypeNode(typeLiteralNode.parent) ? typeLiteralNode.parent : void 0;
-      const containerTypeNode = intersectionTypeNode || typeLiteralNode;
-      const containerExpectedType = getConstraintOfTypeArgumentProperty(containerTypeNode, typeChecker);
-      if (!containerExpectedType)
-        return 0 /* Continue */;
-      const containerActualType = typeChecker.getTypeFromTypeNode(containerTypeNode);
-      const members = getPropertiesForCompletion(containerExpectedType, typeChecker);
-      const existingMembers = getPropertiesForCompletion(containerActualType, typeChecker);
-      const existingMemberEscapedNames = /* @__PURE__ */ new Set();
-      existingMembers.forEach((s) => existingMemberEscapedNames.add(s.escapedName));
-      symbols = concatenate(symbols, filter(members, (s) => !existingMemberEscapedNames.has(s.escapedName)));
-      completionKind = 0 /* ObjectPropertyDeclaration */;
-      isNewIdentifierLocation = true;
-      return 1 /* Success */;
-    }
-    function tryGetObjectLikeCompletionSymbols() {
-      const symbolsStartIndex = symbols.length;
-      const objectLikeContainer = tryGetObjectLikeCompletionContainer(contextToken);
-      if (!objectLikeContainer)
-        return 0 /* Continue */;
-      completionKind = 0 /* ObjectPropertyDeclaration */;
-      let typeMembers;
-      let existingMembers;
-      if (objectLikeContainer.kind === 209 /* ObjectLiteralExpression */) {
-        const instantiatedType = tryGetObjectLiteralContextualType(objectLikeContainer, typeChecker);
-        if (instantiatedType === void 0) {
-          if (objectLikeContainer.flags & 33554432 /* InWithStatement */) {
-            return 2 /* Fail */;
-          }
-          isNonContextualObjectLiteral = true;
-          return 0 /* Continue */;
-        }
-        const completionsType = typeChecker.getContextualType(objectLikeContainer, 4 /* Completions */);
-        const hasStringIndexType = (completionsType || instantiatedType).getStringIndexType();
-        const hasNumberIndextype = (completionsType || instantiatedType).getNumberIndexType();
-        isNewIdentifierLocation = !!hasStringIndexType || !!hasNumberIndextype;
-        typeMembers = getPropertiesForObjectExpression(instantiatedType, completionsType, objectLikeContainer, typeChecker);
-        existingMembers = objectLikeContainer.properties;
-        if (typeMembers.length === 0) {
-          if (!hasNumberIndextype) {
-            isNonContextualObjectLiteral = true;
-            return 0 /* Continue */;
-          }
-        }
-      } else {
-        Debug.assert(objectLikeContainer.kind === 205 /* ObjectBindingPattern */);
-        isNewIdentifierLocation = false;
-        const rootDeclaration = getRootDeclaration(objectLikeContainer.parent);
-        if (!isVariableLike(rootDeclaration))
-          return Debug.fail("Root declaration is not variable-like.");
-        let canGetType = hasInitializer(rootDeclaration) || !!getEffectiveTypeAnnotationNode(rootDeclaration) || rootDeclaration.parent.parent.kind === 249 /* ForOfStatement */;
-        if (!canGetType && rootDeclaration.kind === 168 /* Parameter */) {
-          if (isExpression(rootDeclaration.parent)) {
-            canGetType = !!typeChecker.getContextualType(rootDeclaration.parent);
-          } else if (rootDeclaration.parent.kind === 173 /* MethodDeclaration */ || rootDeclaration.parent.kind === 177 /* SetAccessor */) {
-            canGetType = isExpression(rootDeclaration.parent.parent) && !!typeChecker.getContextualType(rootDeclaration.parent.parent);
-          }
-        }
-        if (canGetType) {
-          const typeForObject = typeChecker.getTypeAtLocation(objectLikeContainer);
-          if (!typeForObject)
-            return 2 /* Fail */;
-          typeMembers = typeChecker.getPropertiesOfType(typeForObject).filter((propertySymbol) => {
-            return typeChecker.isPropertyAccessible(
-              objectLikeContainer,
-              /*isSuper*/
-              false,
-              /*isWrite*/
-              false,
-              typeForObject,
-              propertySymbol
-            );
-          });
-          existingMembers = objectLikeContainer.elements;
-        }
-      }
-      if (typeMembers && typeMembers.length > 0) {
-        const filteredMembers = filterObjectMembersList(typeMembers, Debug.checkDefined(existingMembers));
-        symbols = concatenate(symbols, filteredMembers);
-        setSortTextToOptionalMember();
-        if (objectLikeContainer.kind === 209 /* ObjectLiteralExpression */ && preferences.includeCompletionsWithObjectLiteralMethodSnippets && preferences.includeCompletionsWithInsertText) {
-          transformObjectLiteralMembersSortText(symbolsStartIndex);
-          collectObjectLiteralMethodSymbols(filteredMembers, objectLikeContainer);
-        }
-      }
-      return 1 /* Success */;
-    }
-    function tryGetImportOrExportClauseCompletionSymbols() {
-      if (!contextToken)
-        return 0 /* Continue */;
-      const namedImportsOrExports = contextToken.kind === 19 /* OpenBraceToken */ || contextToken.kind === 28 /* CommaToken */ ? tryCast(contextToken.parent, isNamedImportsOrExports) : isTypeKeywordTokenOrIdentifier(contextToken) ? tryCast(contextToken.parent.parent, isNamedImportsOrExports) : void 0;
-      if (!namedImportsOrExports)
-        return 0 /* Continue */;
-      if (!isTypeKeywordTokenOrIdentifier(contextToken)) {
-        keywordFilters = 8 /* TypeKeyword */;
-      }
-      const { moduleSpecifier } = namedImportsOrExports.kind === 274 /* NamedImports */ ? namedImportsOrExports.parent.parent : namedImportsOrExports.parent;
-      if (!moduleSpecifier) {
-        isNewIdentifierLocation = true;
-        return namedImportsOrExports.kind === 274 /* NamedImports */ ? 2 /* Fail */ : 0 /* Continue */;
-      }
-      const moduleSpecifierSymbol = typeChecker.getSymbolAtLocation(moduleSpecifier);
-      if (!moduleSpecifierSymbol) {
-        isNewIdentifierLocation = true;
-        return 2 /* Fail */;
-      }
-      completionKind = 3 /* MemberLike */;
-      isNewIdentifierLocation = false;
-      const exports = typeChecker.getExportsAndPropertiesOfModule(moduleSpecifierSymbol);
-      const existing = new Set(namedImportsOrExports.elements.filter((n) => !isCurrentlyEditingNode(n)).map((n) => (n.propertyName || n.name).escapedText));
-      const uniques = exports.filter((e) => e.escapedName !== "default" /* Default */ && !existing.has(e.escapedName));
-      symbols = concatenate(symbols, uniques);
-      if (!uniques.length) {
-        keywordFilters = 0 /* None */;
-      }
-      return 1 /* Success */;
-    }
-    function tryGetLocalNamedExportCompletionSymbols() {
-      var _a;
-      const namedExports = contextToken && (contextToken.kind === 19 /* OpenBraceToken */ || contextToken.kind === 28 /* CommaToken */) ? tryCast(contextToken.parent, isNamedExports) : void 0;
-      if (!namedExports) {
-        return 0 /* Continue */;
-      }
-      const localsContainer = findAncestor(namedExports, or(isSourceFile, isModuleDeclaration));
-      completionKind = 5 /* None */;
-      isNewIdentifierLocation = false;
-      (_a = localsContainer.locals) == null ? void 0 : _a.forEach((symbol, name) => {
-        var _a2, _b;
-        symbols.push(symbol);
-        if ((_b = (_a2 = localsContainer.symbol) == null ? void 0 : _a2.exports) == null ? void 0 : _b.has(name)) {
-          symbolToSortTextMap[getSymbolId(symbol)] = SortText.OptionalMember;
-        }
-      });
-      return 1 /* Success */;
-    }
-    function tryGetClassLikeCompletionSymbols() {
-      const decl = tryGetObjectTypeDeclarationCompletionContainer(sourceFile, contextToken, location, position);
-      if (!decl)
-        return 0 /* Continue */;
-      completionKind = 3 /* MemberLike */;
-      isNewIdentifierLocation = true;
-      keywordFilters = contextToken.kind === 42 /* AsteriskToken */ ? 0 /* None */ : isClassLike(decl) ? 2 /* ClassElementKeywords */ : 3 /* InterfaceElementKeywords */;
-      if (!isClassLike(decl))
-        return 1 /* Success */;
-      const classElement = contextToken.kind === 27 /* SemicolonToken */ ? contextToken.parent.parent : contextToken.parent;
-      let classElementModifierFlags = isClassElement(classElement) ? getEffectiveModifierFlags(classElement) : 0 /* None */;
-      if (contextToken.kind === 80 /* Identifier */ && !isCurrentlyEditingNode(contextToken)) {
-        switch (contextToken.getText()) {
-          case "private":
-            classElementModifierFlags = classElementModifierFlags | 8 /* Private */;
-            break;
-          case "static":
-            classElementModifierFlags = classElementModifierFlags | 32 /* Static */;
-            break;
-          case "override":
-            classElementModifierFlags = classElementModifierFlags | 16384 /* Override */;
-            break;
-        }
-      }
-      if (isClassStaticBlockDeclaration(classElement)) {
-        classElementModifierFlags |= 32 /* Static */;
-      }
-      if (!(classElementModifierFlags & 8 /* Private */)) {
-        const baseTypeNodes = isClassLike(decl) && classElementModifierFlags & 16384 /* Override */ ? singleElementArray(getEffectiveBaseTypeNode(decl)) : getAllSuperTypeNodes(decl);
-        const baseSymbols = flatMap(baseTypeNodes, (baseTypeNode) => {
-          const type = typeChecker.getTypeAtLocation(baseTypeNode);
-          return classElementModifierFlags & 32 /* Static */ ? (type == null ? void 0 : type.symbol) && typeChecker.getPropertiesOfType(typeChecker.getTypeOfSymbolAtLocation(type.symbol, decl)) : type && typeChecker.getPropertiesOfType(type);
-        });
-        symbols = concatenate(symbols, filterClassMembersList(baseSymbols, decl.members, classElementModifierFlags));
-        forEach(symbols, (symbol, index) => {
-          const declaration = symbol == null ? void 0 : symbol.valueDeclaration;
-          if (declaration && isClassElement(declaration) && declaration.name && isComputedPropertyName(declaration.name)) {
-            const origin = {
-              kind: 512 /* ComputedPropertyName */,
-              symbolName: typeChecker.symbolToString(symbol)
-            };
-            symbolToOriginInfoMap[index] = origin;
-          }
-        });
-      }
-      return 1 /* Success */;
-    }
-    function isConstructorParameterCompletion(node2) {
-      return !!node2.parent && isParameter(node2.parent) && isConstructorDeclaration(node2.parent.parent) && (isParameterPropertyModifier(node2.kind) || isDeclarationName(node2));
-    }
-    function tryGetConstructorLikeCompletionContainer(contextToken2) {
-      if (contextToken2) {
-        const parent2 = contextToken2.parent;
-        switch (contextToken2.kind) {
-          case 21 /* OpenParenToken */:
-          case 28 /* CommaToken */:
-            return isConstructorDeclaration(contextToken2.parent) ? contextToken2.parent : void 0;
-          default:
-            if (isConstructorParameterCompletion(contextToken2)) {
-              return parent2.parent;
-            }
-        }
-      }
-      return void 0;
-    }
-    function tryGetFunctionLikeBodyCompletionContainer(contextToken2) {
-      if (contextToken2) {
-        let prev;
-        const container = findAncestor(contextToken2.parent, (node2) => {
-          if (isClassLike(node2)) {
-            return "quit";
-          }
-          if (isFunctionLikeDeclaration(node2) && prev === node2.body) {
-            return true;
-          }
-          prev = node2;
-          return false;
-        });
-        return container && container;
-      }
-    }
-    function tryGetContainingJsxElement(contextToken2) {
-      if (contextToken2) {
-        const parent2 = contextToken2.parent;
-        switch (contextToken2.kind) {
-          case 32 /* GreaterThanToken */:
-          case 31 /* LessThanSlashToken */:
-          case 44 /* SlashToken */:
-          case 80 /* Identifier */:
-          case 210 /* PropertyAccessExpression */:
-          case 291 /* JsxAttributes */:
-          case 290 /* JsxAttribute */:
-          case 292 /* JsxSpreadAttribute */:
-            if (parent2 && (parent2.kind === 284 /* JsxSelfClosingElement */ || parent2.kind === 285 /* JsxOpeningElement */)) {
-              if (contextToken2.kind === 32 /* GreaterThanToken */) {
-                const precedingToken = findPrecedingToken(
-                  contextToken2.pos,
-                  sourceFile,
-                  /*startNode*/
-                  void 0
-                );
-                if (!parent2.typeArguments || precedingToken && precedingToken.kind === 44 /* SlashToken */)
-                  break;
-              }
-              return parent2;
-            } else if (parent2.kind === 290 /* JsxAttribute */) {
-              return parent2.parent.parent;
-            }
-            break;
-          case 11 /* StringLiteral */:
-            if (parent2 && (parent2.kind === 290 /* JsxAttribute */ || parent2.kind === 292 /* JsxSpreadAttribute */)) {
-              return parent2.parent.parent;
-            }
-            break;
-          case 20 /* CloseBraceToken */:
-            if (parent2 && parent2.kind === 293 /* JsxExpression */ && parent2.parent && parent2.parent.kind === 290 /* JsxAttribute */) {
-              return parent2.parent.parent.parent;
-            }
-            if (parent2 && parent2.kind === 292 /* JsxSpreadAttribute */) {
-              return parent2.parent.parent;
-            }
-            break;
-        }
-      }
-      return void 0;
-    }
-    function isSolelyIdentifierDefinitionLocation(contextToken2) {
-      const parent2 = contextToken2.parent;
-      const containingNodeKind = parent2.kind;
-      switch (contextToken2.kind) {
-        case 28 /* CommaToken */:
-          return containingNodeKind === 259 /* VariableDeclaration */ || isVariableDeclarationListButNotTypeArgument(contextToken2) || containingNodeKind === 242 /* VariableStatement */ || containingNodeKind === 265 /* EnumDeclaration */ || // enum a { foo, |
-          isFunctionLikeButNotConstructor(containingNodeKind) || containingNodeKind === 263 /* InterfaceDeclaration */ || // interface A= contextToken2.pos;
-        case 25 /* DotToken */:
-          return containingNodeKind === 206 /* ArrayBindingPattern */;
-        case 59 /* ColonToken */:
-          return containingNodeKind === 207 /* BindingElement */;
-        case 23 /* OpenBracketToken */:
-          return containingNodeKind === 206 /* ArrayBindingPattern */;
-        case 21 /* OpenParenToken */:
-          return containingNodeKind === 298 /* CatchClause */ || isFunctionLikeButNotConstructor(containingNodeKind);
-        case 19 /* OpenBraceToken */:
-          return containingNodeKind === 265 /* EnumDeclaration */;
-        case 30 /* LessThanToken */:
-          return containingNodeKind === 262 /* ClassDeclaration */ || // class A< |
-          containingNodeKind === 230 /* ClassExpression */ || // var C = class D< |
-          containingNodeKind === 263 /* InterfaceDeclaration */ || // interface A< |
-          containingNodeKind === 264 /* TypeAliasDeclaration */ || // type List< |
-          isFunctionLikeKind(containingNodeKind);
-        case 126 /* StaticKeyword */:
-          return containingNodeKind === 171 /* PropertyDeclaration */ && !isClassLike(parent2.parent);
-        case 26 /* DotDotDotToken */:
-          return containingNodeKind === 168 /* Parameter */ || !!parent2.parent && parent2.parent.kind === 206 /* ArrayBindingPattern */;
-        case 125 /* PublicKeyword */:
-        case 123 /* PrivateKeyword */:
-        case 124 /* ProtectedKeyword */:
-          return containingNodeKind === 168 /* Parameter */ && !isConstructorDeclaration(parent2.parent);
-        case 130 /* AsKeyword */:
-          return containingNodeKind === 275 /* ImportSpecifier */ || containingNodeKind === 280 /* ExportSpecifier */ || containingNodeKind === 273 /* NamespaceImport */;
-        case 139 /* GetKeyword */:
-        case 153 /* SetKeyword */:
-          return !isFromObjectTypeDeclaration(contextToken2);
-        case 80 /* Identifier */:
-          if (containingNodeKind === 275 /* ImportSpecifier */ && contextToken2 === parent2.name && contextToken2.text === "type") {
-            return false;
-          }
-          break;
-        case 86 /* ClassKeyword */:
-        case 94 /* EnumKeyword */:
-        case 120 /* InterfaceKeyword */:
-        case 100 /* FunctionKeyword */:
-        case 115 /* VarKeyword */:
-        case 102 /* ImportKeyword */:
-        case 121 /* LetKeyword */:
-        case 87 /* ConstKeyword */:
-        case 140 /* InferKeyword */:
-          return true;
-        case 156 /* TypeKeyword */:
-          return containingNodeKind !== 275 /* ImportSpecifier */;
-        case 42 /* AsteriskToken */:
-          return isFunctionLike(contextToken2.parent) && !isMethodDeclaration(contextToken2.parent);
-      }
-      if (isClassMemberCompletionKeyword(keywordForNode(contextToken2)) && isFromObjectTypeDeclaration(contextToken2)) {
-        return false;
-      }
-      if (isConstructorParameterCompletion(contextToken2)) {
-        if (!isIdentifier(contextToken2) || isParameterPropertyModifier(keywordForNode(contextToken2)) || isCurrentlyEditingNode(contextToken2)) {
-          return false;
-        }
-      }
-      switch (keywordForNode(contextToken2)) {
-        case 128 /* AbstractKeyword */:
-        case 86 /* ClassKeyword */:
-        case 87 /* ConstKeyword */:
-        case 138 /* DeclareKeyword */:
-        case 94 /* EnumKeyword */:
-        case 100 /* FunctionKeyword */:
-        case 120 /* InterfaceKeyword */:
-        case 121 /* LetKeyword */:
-        case 123 /* PrivateKeyword */:
-        case 124 /* ProtectedKeyword */:
-        case 125 /* PublicKeyword */:
-        case 126 /* StaticKeyword */:
-        case 115 /* VarKeyword */:
-          return true;
-        case 134 /* AsyncKeyword */:
-          return isPropertyDeclaration(contextToken2.parent);
-      }
-      const ancestorClassLike = findAncestor(contextToken2.parent, isClassLike);
-      if (ancestorClassLike && contextToken2 === previousToken && isPreviousPropertyDeclarationTerminated(contextToken2, position)) {
-        return false;
-      }
-      const ancestorPropertyDeclaraion = getAncestor(contextToken2.parent, 171 /* PropertyDeclaration */);
-      if (ancestorPropertyDeclaraion && contextToken2 !== previousToken && isClassLike(previousToken.parent.parent) && position <= previousToken.end) {
-        if (isPreviousPropertyDeclarationTerminated(contextToken2, previousToken.end)) {
-          return false;
-        } else if (contextToken2.kind !== 64 /* EqualsToken */ && (isInitializedProperty(ancestorPropertyDeclaraion) || hasType(ancestorPropertyDeclaraion))) {
-          return true;
-        }
-      }
-      return isDeclarationName(contextToken2) && !isShorthandPropertyAssignment(contextToken2.parent) && !isJsxAttribute(contextToken2.parent) && !((isClassLike(contextToken2.parent) || isInterfaceDeclaration(contextToken2.parent) || isTypeParameterDeclaration(contextToken2.parent)) && (contextToken2 !== previousToken || position > previousToken.end));
-    }
-    function isPreviousPropertyDeclarationTerminated(contextToken2, position2) {
-      return contextToken2.kind !== 64 /* EqualsToken */ && (contextToken2.kind === 27 /* SemicolonToken */ || !positionsAreOnSameLine(contextToken2.end, position2, sourceFile));
-    }
-    function isFunctionLikeButNotConstructor(kind) {
-      return isFunctionLikeKind(kind) && kind !== 175 /* Constructor */;
-    }
-    function isDotOfNumericLiteral(contextToken2) {
-      if (contextToken2.kind === 9 /* NumericLiteral */) {
-        const text = contextToken2.getFullText();
-        return text.charAt(text.length - 1) === ".";
-      }
-      return false;
-    }
-    function isVariableDeclarationListButNotTypeArgument(node2) {
-      return node2.parent.kind === 260 /* VariableDeclarationList */ && !isPossiblyTypeArgumentPosition(node2, sourceFile, typeChecker);
-    }
-    function filterObjectMembersList(contextualMemberSymbols, existingMembers) {
-      if (existingMembers.length === 0) {
-        return contextualMemberSymbols;
-      }
-      const membersDeclaredBySpreadAssignment = /* @__PURE__ */ new Set();
-      const existingMemberNames = /* @__PURE__ */ new Set();
-      for (const m of existingMembers) {
-        if (m.kind !== 302 /* PropertyAssignment */ && m.kind !== 303 /* ShorthandPropertyAssignment */ && m.kind !== 207 /* BindingElement */ && m.kind !== 173 /* MethodDeclaration */ && m.kind !== 176 /* GetAccessor */ && m.kind !== 177 /* SetAccessor */ && m.kind !== 304 /* SpreadAssignment */) {
-          continue;
-        }
-        if (isCurrentlyEditingNode(m)) {
-          continue;
-        }
-        let existingName;
-        if (isSpreadAssignment(m)) {
-          setMembersDeclaredBySpreadAssignment(m, membersDeclaredBySpreadAssignment);
-        } else if (isBindingElement(m) && m.propertyName) {
-          if (m.propertyName.kind === 80 /* Identifier */) {
-            existingName = m.propertyName.escapedText;
-          }
-        } else {
-          const name = getNameOfDeclaration(m);
-          existingName = name && isPropertyNameLiteral(name) ? getEscapedTextOfIdentifierOrLiteral(name) : void 0;
-        }
-        if (existingName !== void 0) {
-          existingMemberNames.add(existingName);
-        }
-      }
-      const filteredSymbols = contextualMemberSymbols.filter((m) => !existingMemberNames.has(m.escapedName));
-      setSortTextToMemberDeclaredBySpreadAssignment(membersDeclaredBySpreadAssignment, filteredSymbols);
-      return filteredSymbols;
-    }
-    function setMembersDeclaredBySpreadAssignment(declaration, membersDeclaredBySpreadAssignment) {
-      const expression = declaration.expression;
-      const symbol = typeChecker.getSymbolAtLocation(expression);
-      const type = symbol && typeChecker.getTypeOfSymbolAtLocation(symbol, expression);
-      const properties = type && type.properties;
-      if (properties) {
-        properties.forEach((property) => {
-          membersDeclaredBySpreadAssignment.add(property.name);
-        });
-      }
-    }
-    function setSortTextToOptionalMember() {
-      symbols.forEach((m) => {
-        if (m.flags & 16777216 /* Optional */) {
-          const symbolId = getSymbolId(m);
-          symbolToSortTextMap[symbolId] = symbolToSortTextMap[symbolId] ?? SortText.OptionalMember;
-        }
-      });
-    }
-    function setSortTextToMemberDeclaredBySpreadAssignment(membersDeclaredBySpreadAssignment, contextualMemberSymbols) {
-      if (membersDeclaredBySpreadAssignment.size === 0) {
-        return;
-      }
-      for (const contextualMemberSymbol of contextualMemberSymbols) {
-        if (membersDeclaredBySpreadAssignment.has(contextualMemberSymbol.name)) {
-          symbolToSortTextMap[getSymbolId(contextualMemberSymbol)] = SortText.MemberDeclaredBySpreadAssignment;
-        }
-      }
-    }
-    function transformObjectLiteralMembersSortText(start2) {
-      for (let i = start2; i < symbols.length; i++) {
-        const symbol = symbols[i];
-        const symbolId = getSymbolId(symbol);
-        const origin = symbolToOriginInfoMap == null ? void 0 : symbolToOriginInfoMap[i];
-        const target = getEmitScriptTarget(compilerOptions);
-        const displayName = getCompletionEntryDisplayNameForSymbol(
-          symbol,
-          target,
-          origin,
-          0 /* ObjectPropertyDeclaration */,
-          /*jsxIdentifierExpected*/
-          false
-        );
-        if (displayName) {
-          const originalSortText = symbolToSortTextMap[symbolId] ?? SortText.LocationPriority;
-          const { name } = displayName;
-          symbolToSortTextMap[symbolId] = SortText.ObjectLiteralProperty(originalSortText, name);
-        }
-      }
-    }
-    function filterClassMembersList(baseSymbols, existingMembers, currentClassElementModifierFlags) {
-      const existingMemberNames = /* @__PURE__ */ new Set();
-      for (const m of existingMembers) {
-        if (m.kind !== 171 /* PropertyDeclaration */ && m.kind !== 173 /* MethodDeclaration */ && m.kind !== 176 /* GetAccessor */ && m.kind !== 177 /* SetAccessor */) {
-          continue;
-        }
-        if (isCurrentlyEditingNode(m)) {
-          continue;
-        }
-        if (hasEffectiveModifier(m, 8 /* Private */)) {
-          continue;
-        }
-        if (isStatic(m) !== !!(currentClassElementModifierFlags & 32 /* Static */)) {
-          continue;
-        }
-        const existingName = getPropertyNameForPropertyNameNode(m.name);
-        if (existingName) {
-          existingMemberNames.add(existingName);
-        }
-      }
-      return baseSymbols.filter((propertySymbol) => !existingMemberNames.has(propertySymbol.escapedName) && !!propertySymbol.declarations && !(getDeclarationModifierFlagsFromSymbol(propertySymbol) & 8 /* Private */) && !(propertySymbol.valueDeclaration && isPrivateIdentifierClassElementDeclaration(propertySymbol.valueDeclaration)));
-    }
-    function filterJsxAttributes(symbols2, attributes) {
-      const seenNames = /* @__PURE__ */ new Set();
-      const membersDeclaredBySpreadAssignment = /* @__PURE__ */ new Set();
-      for (const attr of attributes) {
-        if (isCurrentlyEditingNode(attr)) {
-          continue;
-        }
-        if (attr.kind === 290 /* JsxAttribute */) {
-          seenNames.add(getEscapedTextOfJsxAttributeName(attr.name));
-        } else if (isJsxSpreadAttribute(attr)) {
-          setMembersDeclaredBySpreadAssignment(attr, membersDeclaredBySpreadAssignment);
-        }
-      }
-      const filteredSymbols = symbols2.filter((a) => !seenNames.has(a.escapedName));
-      setSortTextToMemberDeclaredBySpreadAssignment(membersDeclaredBySpreadAssignment, filteredSymbols);
-      return filteredSymbols;
-    }
-    function isCurrentlyEditingNode(node2) {
-      return node2.getStart(sourceFile) <= position && position <= node2.getEnd();
-    }
-  }
-  function tryGetObjectLikeCompletionContainer(contextToken) {
-    if (contextToken) {
-      const { parent: parent2 } = contextToken;
-      switch (contextToken.kind) {
-        case 19 /* OpenBraceToken */:
-        case 28 /* CommaToken */:
-          if (isObjectLiteralExpression(parent2) || isObjectBindingPattern(parent2)) {
-            return parent2;
-          }
-          break;
-        case 42 /* AsteriskToken */:
-          return isMethodDeclaration(parent2) ? tryCast(parent2.parent, isObjectLiteralExpression) : void 0;
-        case 134 /* AsyncKeyword */:
-          return tryCast(parent2.parent, isObjectLiteralExpression);
-        case 80 /* Identifier */:
-          return contextToken.text === "async" && isShorthandPropertyAssignment(contextToken.parent) ? contextToken.parent.parent : void 0;
-      }
-    }
-    return void 0;
-  }
-  function getRelevantTokens(position, sourceFile) {
-    const previousToken = findPrecedingToken(position, sourceFile);
-    if (previousToken && position <= previousToken.end && (isMemberName(previousToken) || isKeyword(previousToken.kind))) {
-      const contextToken = findPrecedingToken(
-        previousToken.getFullStart(),
-        sourceFile,
-        /*startNode*/
-        void 0
-      );
-      return { contextToken, previousToken };
-    }
-    return { contextToken: previousToken, previousToken };
-  }
-  function getAutoImportSymbolFromCompletionEntryData(name, data, program, host) {
-    const containingProgram = data.isPackageJsonImport ? host.getPackageJsonAutoImportProvider() : program;
-    const checker = containingProgram.getTypeChecker();
-    const moduleSymbol = data.ambientModuleName ? checker.tryFindAmbientModule(data.ambientModuleName) : data.fileName ? checker.getMergedSymbol(Debug.checkDefined(containingProgram.getSourceFile(data.fileName)).symbol) : void 0;
-    if (!moduleSymbol)
-      return void 0;
-    let symbol = data.exportName === "export=" /* ExportEquals */ ? checker.resolveExternalModuleSymbol(moduleSymbol) : checker.tryGetMemberInModuleExportsAndProperties(data.exportName, moduleSymbol);
-    if (!symbol)
-      return void 0;
-    const isDefaultExport = data.exportName === "default" /* Default */;
-    symbol = isDefaultExport && getLocalSymbolForExportDefault(symbol) || symbol;
-    return { symbol, origin: completionEntryDataToSymbolOriginInfo(data, name, moduleSymbol) };
-  }
-  function getCompletionEntryDisplayNameForSymbol(symbol, target, origin, kind, jsxIdentifierExpected) {
-    if (originIsIgnore(origin)) {
-      return void 0;
-    }
-    const name = originIncludesSymbolName(origin) ? origin.symbolName : symbol.name;
-    if (name === void 0 || symbol.flags & 1536 /* Module */ && isSingleOrDoubleQuote(name.charCodeAt(0)) || isKnownSymbol(symbol)) {
-      return void 0;
-    }
-    const validNameResult = { name, needsConvertPropertyAccess: false };
-    if (isIdentifierText(name, target, jsxIdentifierExpected ? 1 /* JSX */ : 0 /* Standard */) || symbol.valueDeclaration && isPrivateIdentifierClassElementDeclaration(symbol.valueDeclaration)) {
-      return validNameResult;
-    }
-    switch (kind) {
-      case 3 /* MemberLike */:
-        return originIsComputedPropertyName(origin) ? { name: origin.symbolName, needsConvertPropertyAccess: false } : void 0;
-      case 0 /* ObjectPropertyDeclaration */:
-        return { name: JSON.stringify(name), needsConvertPropertyAccess: false };
-      case 2 /* PropertyAccess */:
-      case 1 /* Global */:
-        return name.charCodeAt(0) === 32 /* space */ ? void 0 : { name, needsConvertPropertyAccess: true };
-      case 5 /* None */:
-      case 4 /* String */:
-        return validNameResult;
-      default:
-        Debug.assertNever(kind);
-    }
-  }
-  function getKeywordCompletions(keywordFilter, filterOutTsOnlyKeywords) {
-    if (!filterOutTsOnlyKeywords)
-      return getTypescriptKeywordCompletions(keywordFilter);
-    const index = keywordFilter + 8 /* Last */ + 1;
-    return _keywordCompletions[index] || (_keywordCompletions[index] = getTypescriptKeywordCompletions(keywordFilter).filter((entry) => !isTypeScriptOnlyKeyword(stringToToken(entry.name))));
-  }
-  function getTypescriptKeywordCompletions(keywordFilter) {
-    return _keywordCompletions[keywordFilter] || (_keywordCompletions[keywordFilter] = allKeywordsCompletions().filter((entry) => {
-      const kind = stringToToken(entry.name);
-      switch (keywordFilter) {
-        case 0 /* None */:
-          return false;
-        case 1 /* All */:
-          return isFunctionLikeBodyKeyword(kind) || kind === 138 /* DeclareKeyword */ || kind === 144 /* ModuleKeyword */ || kind === 156 /* TypeKeyword */ || kind === 145 /* NamespaceKeyword */ || kind === 128 /* AbstractKeyword */ || isTypeKeyword(kind) && kind !== 157 /* UndefinedKeyword */;
-        case 5 /* FunctionLikeBodyKeywords */:
-          return isFunctionLikeBodyKeyword(kind);
-        case 2 /* ClassElementKeywords */:
-          return isClassMemberCompletionKeyword(kind);
-        case 3 /* InterfaceElementKeywords */:
-          return isInterfaceOrTypeLiteralCompletionKeyword(kind);
-        case 4 /* ConstructorParameterKeywords */:
-          return isParameterPropertyModifier(kind);
-        case 6 /* TypeAssertionKeywords */:
-          return isTypeKeyword(kind) || kind === 87 /* ConstKeyword */;
-        case 7 /* TypeKeywords */:
-          return isTypeKeyword(kind);
-        case 8 /* TypeKeyword */:
-          return kind === 156 /* TypeKeyword */;
-        default:
-          return Debug.assertNever(keywordFilter);
-      }
-    }));
-  }
-  function isTypeScriptOnlyKeyword(kind) {
-    switch (kind) {
-      case 128 /* AbstractKeyword */:
-      case 133 /* AnyKeyword */:
-      case 162 /* BigIntKeyword */:
-      case 136 /* BooleanKeyword */:
-      case 138 /* DeclareKeyword */:
-      case 94 /* EnumKeyword */:
-      case 161 /* GlobalKeyword */:
-      case 119 /* ImplementsKeyword */:
-      case 140 /* InferKeyword */:
-      case 120 /* InterfaceKeyword */:
-      case 142 /* IsKeyword */:
-      case 143 /* KeyOfKeyword */:
-      case 144 /* ModuleKeyword */:
-      case 145 /* NamespaceKeyword */:
-      case 146 /* NeverKeyword */:
-      case 150 /* NumberKeyword */:
-      case 151 /* ObjectKeyword */:
-      case 163 /* OverrideKeyword */:
-      case 123 /* PrivateKeyword */:
-      case 124 /* ProtectedKeyword */:
-      case 125 /* PublicKeyword */:
-      case 148 /* ReadonlyKeyword */:
-      case 154 /* StringKeyword */:
-      case 155 /* SymbolKeyword */:
-      case 156 /* TypeKeyword */:
-      case 158 /* UniqueKeyword */:
-      case 159 /* UnknownKeyword */:
-        return true;
-      default:
-        return false;
-    }
-  }
-  function isInterfaceOrTypeLiteralCompletionKeyword(kind) {
-    return kind === 148 /* ReadonlyKeyword */;
-  }
-  function isClassMemberCompletionKeyword(kind) {
-    switch (kind) {
-      case 128 /* AbstractKeyword */:
-      case 129 /* AccessorKeyword */:
-      case 137 /* ConstructorKeyword */:
-      case 139 /* GetKeyword */:
-      case 153 /* SetKeyword */:
-      case 134 /* AsyncKeyword */:
-      case 138 /* DeclareKeyword */:
-      case 163 /* OverrideKeyword */:
-        return true;
-      default:
-        return isClassMemberModifier(kind);
-    }
-  }
-  function isFunctionLikeBodyKeyword(kind) {
-    return kind === 134 /* AsyncKeyword */ || kind === 135 /* AwaitKeyword */ || kind === 130 /* AsKeyword */ || kind === 152 /* SatisfiesKeyword */ || kind === 156 /* TypeKeyword */ || !isContextualKeyword(kind) && !isClassMemberCompletionKeyword(kind);
-  }
-  function keywordForNode(node) {
-    return isIdentifier(node) ? identifierToKeywordKind(node) ?? 0 /* Unknown */ : node.kind;
-  }
-  function getContextualKeywords(contextToken, position) {
-    const entries = [];
-    if (contextToken) {
-      const file = contextToken.getSourceFile();
-      const parent2 = contextToken.parent;
-      const tokenLine = file.getLineAndCharacterOfPosition(contextToken.end).line;
-      const currentLine = file.getLineAndCharacterOfPosition(position).line;
-      if ((isImportDeclaration(parent2) || isExportDeclaration(parent2) && parent2.moduleSpecifier) && contextToken === parent2.moduleSpecifier && tokenLine === currentLine) {
-        entries.push({
-          name: tokenToString(132 /* AssertKeyword */),
-          kind: "keyword" /* keyword */,
-          kindModifiers: "" /* none */,
-          sortText: SortText.GlobalsOrKeywords
-        });
-      }
-    }
-    return entries;
-  }
-  function getJsDocTagAtPosition(node, position) {
-    return findAncestor(node, (n) => isJSDocTag(n) && rangeContainsPosition(n, position) ? true : isJSDoc(n) ? "quit" : false);
-  }
-  function getPropertiesForObjectExpression(contextualType, completionsType, obj, checker) {
-    const hasCompletionsType = completionsType && completionsType !== contextualType;
-    const type = hasCompletionsType && !(completionsType.flags & 3 /* AnyOrUnknown */) ? checker.getUnionType([contextualType, completionsType]) : contextualType;
-    const properties = getApparentProperties(type, obj, checker);
-    return type.isClass() && containsNonPublicProperties(properties) ? [] : hasCompletionsType ? filter(properties, hasDeclarationOtherThanSelf) : properties;
-    function hasDeclarationOtherThanSelf(member) {
-      if (!length(member.declarations))
-        return true;
-      return some(member.declarations, (decl) => decl.parent !== obj);
-    }
-  }
-  function getApparentProperties(type, node, checker) {
-    if (!type.isUnion())
-      return type.getApparentProperties();
-    return checker.getAllPossiblePropertiesOfTypes(filter(type.types, (memberType) => !(memberType.flags & 402784252 /* Primitive */ || checker.isArrayLikeType(memberType) || checker.isTypeInvalidDueToUnionDiscriminant(memberType, node) || checker.typeHasCallOrConstructSignatures(memberType) || memberType.isClass() && containsNonPublicProperties(memberType.getApparentProperties()))));
-  }
-  function containsNonPublicProperties(props) {
-    return some(props, (p) => !!(getDeclarationModifierFlagsFromSymbol(p) & 24 /* NonPublicAccessibilityModifier */));
-  }
-  function getPropertiesForCompletion(type, checker) {
-    return type.isUnion() ? Debug.checkEachDefined(checker.getAllPossiblePropertiesOfTypes(type.types), "getAllPossiblePropertiesOfTypes() should all be defined") : Debug.checkEachDefined(type.getApparentProperties(), "getApparentProperties() should all be defined");
-  }
-  function tryGetObjectTypeDeclarationCompletionContainer(sourceFile, contextToken, location, position) {
-    switch (location.kind) {
-      case 357 /* SyntaxList */:
-        return tryCast(location.parent, isObjectTypeDeclaration);
-      case 1 /* EndOfFileToken */:
-        const cls = tryCast(lastOrUndefined(cast(location.parent, isSourceFile).statements), isObjectTypeDeclaration);
-        if (cls && !findChildOfKind(cls, 20 /* CloseBraceToken */, sourceFile)) {
-          return cls;
-        }
-        break;
-      case 80 /* Identifier */: {
-        const originalKeywordKind = identifierToKeywordKind(location);
-        if (originalKeywordKind) {
-          return void 0;
-        }
-        if (isPropertyDeclaration(location.parent) && location.parent.initializer === location) {
-          return void 0;
-        }
-        if (isFromObjectTypeDeclaration(location)) {
-          return findAncestor(location, isObjectTypeDeclaration);
-        }
-      }
-    }
-    if (!contextToken)
-      return void 0;
-    if (location.kind === 137 /* ConstructorKeyword */ || isIdentifier(contextToken) && isPropertyDeclaration(contextToken.parent) && isClassLike(location)) {
-      return findAncestor(contextToken, isClassLike);
-    }
-    switch (contextToken.kind) {
-      case 64 /* EqualsToken */:
-        return void 0;
-      case 27 /* SemicolonToken */:
-      case 20 /* CloseBraceToken */:
-        return isFromObjectTypeDeclaration(location) && location.parent.name === location ? location.parent.parent : tryCast(location, isObjectTypeDeclaration);
-      case 19 /* OpenBraceToken */:
-      case 28 /* CommaToken */:
-        return tryCast(contextToken.parent, isObjectTypeDeclaration);
-      default:
-        if (isObjectTypeDeclaration(location)) {
-          if (getLineAndCharacterOfPosition(sourceFile, contextToken.getEnd()).line !== getLineAndCharacterOfPosition(sourceFile, position).line) {
-            return location;
-          }
-          const isValidKeyword = isClassLike(contextToken.parent.parent) ? isClassMemberCompletionKeyword : isInterfaceOrTypeLiteralCompletionKeyword;
-          return isValidKeyword(contextToken.kind) || contextToken.kind === 42 /* AsteriskToken */ || isIdentifier(contextToken) && isValidKeyword(identifierToKeywordKind(contextToken) ?? 0 /* Unknown */) ? contextToken.parent.parent : void 0;
-        }
-        return void 0;
-    }
-  }
-  function tryGetTypeLiteralNode(node) {
-    if (!node)
-      return void 0;
-    const parent2 = node.parent;
-    switch (node.kind) {
-      case 19 /* OpenBraceToken */:
-        if (isTypeLiteralNode(parent2)) {
-          return parent2;
-        }
-        break;
-      case 27 /* SemicolonToken */:
-      case 28 /* CommaToken */:
-      case 80 /* Identifier */:
-        if (parent2.kind === 170 /* PropertySignature */ && isTypeLiteralNode(parent2.parent)) {
-          return parent2.parent;
-        }
-        break;
-    }
-    return void 0;
-  }
-  function getConstraintOfTypeArgumentProperty(node, checker) {
-    if (!node)
-      return void 0;
-    if (isTypeNode(node) && isTypeReferenceType(node.parent)) {
-      return checker.getTypeArgumentConstraint(node);
-    }
-    const t = getConstraintOfTypeArgumentProperty(node.parent, checker);
-    if (!t)
-      return void 0;
-    switch (node.kind) {
-      case 170 /* PropertySignature */:
-        return checker.getTypeOfPropertyOfContextualType(t, node.symbol.escapedName);
-      case 192 /* IntersectionType */:
-      case 186 /* TypeLiteral */:
-      case 191 /* UnionType */:
-        return t;
-    }
-  }
-  function isFromObjectTypeDeclaration(node) {
-    return node.parent && isClassOrTypeElement(node.parent) && isObjectTypeDeclaration(node.parent.parent);
-  }
-  function isValidTrigger(sourceFile, triggerCharacter, contextToken, position) {
-    switch (triggerCharacter) {
-      case ".":
-      case "@":
-        return true;
-      case '"':
-      case "'":
-      case "`":
-        return !!contextToken && isStringLiteralOrTemplate(contextToken) && position === contextToken.getStart(sourceFile) + 1;
-      case "#":
-        return !!contextToken && isPrivateIdentifier(contextToken) && !!getContainingClass(contextToken);
-      case "<":
-        return !!contextToken && contextToken.kind === 30 /* LessThanToken */ && (!isBinaryExpression(contextToken.parent) || binaryExpressionMayBeOpenTag(contextToken.parent));
-      case "/":
-        return !!contextToken && (isStringLiteralLike(contextToken) ? !!tryGetImportFromModuleSpecifier(contextToken) : contextToken.kind === 44 /* SlashToken */ && isJsxClosingElement(contextToken.parent));
-      case " ":
-        return !!contextToken && isImportKeyword(contextToken) && contextToken.parent.kind === 311 /* SourceFile */;
-      default:
-        return Debug.assertNever(triggerCharacter);
-    }
-  }
-  function binaryExpressionMayBeOpenTag({ left }) {
-    return nodeIsMissing(left);
-  }
-  function isProbablyGlobalType(type, sourceFile, checker) {
-    const selfSymbol = checker.resolveName(
-      "self",
-      /*location*/
-      void 0,
-      111551 /* Value */,
-      /*excludeGlobals*/
-      false
-    );
-    if (selfSymbol && checker.getTypeOfSymbolAtLocation(selfSymbol, sourceFile) === type) {
-      return true;
-    }
-    const globalSymbol = checker.resolveName(
-      "global",
-      /*location*/
-      void 0,
-      111551 /* Value */,
-      /*excludeGlobals*/
-      false
-    );
-    if (globalSymbol && checker.getTypeOfSymbolAtLocation(globalSymbol, sourceFile) === type) {
-      return true;
-    }
-    const globalThisSymbol = checker.resolveName(
-      "globalThis",
-      /*location*/
-      void 0,
-      111551 /* Value */,
-      /*excludeGlobals*/
-      false
-    );
-    if (globalThisSymbol && checker.getTypeOfSymbolAtLocation(globalThisSymbol, sourceFile) === type) {
-      return true;
-    }
-    return false;
-  }
-  function isStaticProperty(symbol) {
-    return !!(symbol.valueDeclaration && getEffectiveModifierFlags(symbol.valueDeclaration) & 32 /* Static */ && isClassLike(symbol.valueDeclaration.parent));
-  }
-  function tryGetObjectLiteralContextualType(node, typeChecker) {
-    const type = typeChecker.getContextualType(node);
-    if (type) {
-      return type;
-    }
-    const parent2 = walkUpParenthesizedExpressions(node.parent);
-    if (isBinaryExpression(parent2) && parent2.operatorToken.kind === 64 /* EqualsToken */ && node === parent2.left) {
-      return typeChecker.getTypeAtLocation(parent2);
-    }
-    if (isExpression(parent2)) {
-      return typeChecker.getContextualType(parent2);
-    }
-    return void 0;
-  }
-  function getImportStatementCompletionInfo(contextToken) {
-    var _a, _b, _c;
-    let keywordCompletion;
-    let isKeywordOnlyCompletion = false;
-    const candidate = getCandidate();
-    return {
-      isKeywordOnlyCompletion,
-      keywordCompletion,
-      isNewIdentifierLocation: !!(candidate || keywordCompletion === 156 /* TypeKeyword */),
-      isTopLevelTypeOnly: !!((_b = (_a = tryCast(candidate, isImportDeclaration)) == null ? void 0 : _a.importClause) == null ? void 0 : _b.isTypeOnly) || !!((_c = tryCast(candidate, isImportEqualsDeclaration)) == null ? void 0 : _c.isTypeOnly),
-      couldBeTypeOnlyImportSpecifier: !!candidate && couldBeTypeOnlyImportSpecifier(candidate, contextToken),
-      replacementSpan: getSingleLineReplacementSpanForImportCompletionNode(candidate)
-    };
-    function getCandidate() {
-      const parent2 = contextToken.parent;
-      if (isImportEqualsDeclaration(parent2)) {
-        keywordCompletion = contextToken.kind === 156 /* TypeKeyword */ ? void 0 : 156 /* TypeKeyword */;
-        return isModuleSpecifierMissingOrEmpty(parent2.moduleReference) ? parent2 : void 0;
-      }
-      if (couldBeTypeOnlyImportSpecifier(parent2, contextToken) && canCompleteFromNamedBindings(parent2.parent)) {
-        return parent2;
-      }
-      if (isNamedImports(parent2) || isNamespaceImport(parent2)) {
-        if (!parent2.parent.isTypeOnly && (contextToken.kind === 19 /* OpenBraceToken */ || contextToken.kind === 102 /* ImportKeyword */ || contextToken.kind === 28 /* CommaToken */)) {
-          keywordCompletion = 156 /* TypeKeyword */;
-        }
-        if (canCompleteFromNamedBindings(parent2)) {
-          if (contextToken.kind === 20 /* CloseBraceToken */ || contextToken.kind === 80 /* Identifier */) {
-            isKeywordOnlyCompletion = true;
-            keywordCompletion = 160 /* FromKeyword */;
-          } else {
-            return parent2.parent.parent;
-          }
-        }
-        return void 0;
-      }
-      if (isImportKeyword(contextToken) && isSourceFile(parent2)) {
-        keywordCompletion = 156 /* TypeKeyword */;
-        return contextToken;
-      }
-      if (isImportKeyword(contextToken) && isImportDeclaration(parent2)) {
-        keywordCompletion = 156 /* TypeKeyword */;
-        return isModuleSpecifierMissingOrEmpty(parent2.moduleSpecifier) ? parent2 : void 0;
-      }
-      return void 0;
-    }
-  }
-  function getSingleLineReplacementSpanForImportCompletionNode(node) {
-    var _a;
-    if (!node)
-      return void 0;
-    const top = findAncestor(node, or(isImportDeclaration, isImportEqualsDeclaration)) ?? node;
-    const sourceFile = top.getSourceFile();
-    if (rangeIsOnSingleLine(top, sourceFile)) {
-      return createTextSpanFromNode(top, sourceFile);
-    }
-    Debug.assert(top.kind !== 102 /* ImportKeyword */ && top.kind !== 275 /* ImportSpecifier */);
-    const potentialSplitPoint = top.kind === 271 /* ImportDeclaration */ ? getPotentiallyInvalidImportSpecifier((_a = top.importClause) == null ? void 0 : _a.namedBindings) ?? top.moduleSpecifier : top.moduleReference;
-    const withoutModuleSpecifier = {
-      pos: top.getFirstToken().getStart(),
-      end: potentialSplitPoint.pos
-    };
-    if (rangeIsOnSingleLine(withoutModuleSpecifier, sourceFile)) {
-      return createTextSpanFromRange(withoutModuleSpecifier);
-    }
-  }
-  function getPotentiallyInvalidImportSpecifier(namedBindings) {
-    var _a;
-    return find(
-      (_a = tryCast(namedBindings, isNamedImports)) == null ? void 0 : _a.elements,
-      (e) => {
-        var _a2;
-        return !e.propertyName && isStringANonContextualKeyword(e.name.text) && ((_a2 = findPrecedingToken(e.name.pos, namedBindings.getSourceFile(), namedBindings)) == null ? void 0 : _a2.kind) !== 28 /* CommaToken */;
-      }
-    );
-  }
-  function couldBeTypeOnlyImportSpecifier(importSpecifier, contextToken) {
-    return isImportSpecifier(importSpecifier) && (importSpecifier.isTypeOnly || contextToken === importSpecifier.name && isTypeKeywordTokenOrIdentifier(contextToken));
-  }
-  function canCompleteFromNamedBindings(namedBindings) {
-    if (!isModuleSpecifierMissingOrEmpty(namedBindings.parent.parent.moduleSpecifier) || namedBindings.parent.name) {
-      return false;
-    }
-    if (isNamedImports(namedBindings)) {
-      const invalidNamedImport = getPotentiallyInvalidImportSpecifier(namedBindings);
-      const validImports = invalidNamedImport ? namedBindings.elements.indexOf(invalidNamedImport) : namedBindings.elements.length;
-      return validImports < 2;
-    }
-    return true;
-  }
-  function isModuleSpecifierMissingOrEmpty(specifier) {
-    var _a;
-    if (nodeIsMissing(specifier))
-      return true;
-    return !((_a = tryCast(isExternalModuleReference(specifier) ? specifier.expression : specifier, isStringLiteralLike)) == null ? void 0 : _a.text);
-  }
-  function getVariableOrParameterDeclaration(contextToken, location) {
-    if (!contextToken)
-      return;
-    const possiblyParameterDeclaration = findAncestor(contextToken, (node) => isFunctionBlock(node) || isArrowFunctionBody(node) || isBindingPattern(node) ? "quit" : (isParameter(node) || isTypeParameterDeclaration(node)) && !isIndexSignatureDeclaration(node.parent));
-    const possiblyVariableDeclaration = findAncestor(location, (node) => isFunctionBlock(node) || isArrowFunctionBody(node) || isBindingPattern(node) ? "quit" : isVariableDeclaration(node));
-    return possiblyParameterDeclaration || possiblyVariableDeclaration;
-  }
-  function isArrowFunctionBody(node) {
-    return node.parent && isArrowFunction(node.parent) && (node.parent.body === node || // const a = () => /**/;
-    node.kind === 39 /* EqualsGreaterThanToken */);
-  }
-  function symbolCanBeReferencedAtTypeLocation(symbol, checker, seenModules = /* @__PURE__ */ new Map()) {
-    return nonAliasCanBeReferencedAtTypeLocation(symbol) || nonAliasCanBeReferencedAtTypeLocation(skipAlias(symbol.exportSymbol || symbol, checker));
-    function nonAliasCanBeReferencedAtTypeLocation(symbol2) {
-      return !!(symbol2.flags & 788968 /* Type */) || checker.isUnknownSymbol(symbol2) || !!(symbol2.flags & 1536 /* Module */) && addToSeen(seenModules, getSymbolId(symbol2)) && checker.getExportsOfModule(symbol2).some((e) => symbolCanBeReferencedAtTypeLocation(e, checker, seenModules));
-    }
-  }
-  function isDeprecated(symbol, checker) {
-    const declarations = skipAlias(symbol, checker).declarations;
-    return !!length(declarations) && every(declarations, isDeprecatedDeclaration);
-  }
-  function charactersFuzzyMatchInString(identifierString, lowercaseCharacters) {
-    if (lowercaseCharacters.length === 0) {
-      return true;
-    }
-    let matchedFirstCharacter = false;
-    let prevChar;
-    let characterIndex = 0;
-    const len = identifierString.length;
-    for (let strIndex = 0; strIndex < len; strIndex++) {
-      const strChar = identifierString.charCodeAt(strIndex);
-      const testChar = lowercaseCharacters.charCodeAt(characterIndex);
-      if (strChar === testChar || strChar === toUpperCharCode(testChar)) {
-        matchedFirstCharacter || (matchedFirstCharacter = prevChar === void 0 || // Beginning of word
-        97 /* a */ <= prevChar && prevChar <= 122 /* z */ && 65 /* A */ <= strChar && strChar <= 90 /* Z */ || // camelCase transition
-        prevChar === 95 /* _ */ && strChar !== 95 /* _ */);
-        if (matchedFirstCharacter) {
-          characterIndex++;
-        }
-        if (characterIndex === lowercaseCharacters.length) {
-          return true;
-        }
-      }
-      prevChar = strChar;
-    }
-    return false;
-  }
-  function toUpperCharCode(charCode) {
-    if (97 /* a */ <= charCode && charCode <= 122 /* z */) {
-      return charCode - 32;
-    }
-    return charCode;
-  }
-  var moduleSpecifierResolutionLimit, moduleSpecifierResolutionCacheAttemptLimit, SortText, CompletionSource, SymbolOriginInfoKind, CompletionKind, _keywordCompletions, allKeywordsCompletions;
-  var init_completions = __esm({
-    "src/services/completions.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_Completions();
-      moduleSpecifierResolutionLimit = 100;
-      moduleSpecifierResolutionCacheAttemptLimit = 1e3;
-      SortText = {
-        // Presets
-        LocalDeclarationPriority: "10",
-        LocationPriority: "11",
-        OptionalMember: "12",
-        MemberDeclaredBySpreadAssignment: "13",
-        SuggestedClassMembers: "14",
-        GlobalsOrKeywords: "15",
-        AutoImportSuggestions: "16",
-        ClassMemberSnippets: "17",
-        JavascriptIdentifiers: "18",
-        // Transformations
-        Deprecated(sortText) {
-          return "z" + sortText;
-        },
-        ObjectLiteralProperty(presetSortText, symbolDisplayName) {
-          return `${presetSortText}\0${symbolDisplayName}\0`;
-        },
-        SortBelow(sortText) {
-          return sortText + "1";
-        }
-      };
-      CompletionSource = /* @__PURE__ */ ((CompletionSource2) => {
-        CompletionSource2["ThisProperty"] = "ThisProperty/";
-        CompletionSource2["ClassMemberSnippet"] = "ClassMemberSnippet/";
-        CompletionSource2["TypeOnlyAlias"] = "TypeOnlyAlias/";
-        CompletionSource2["ObjectLiteralMethodSnippet"] = "ObjectLiteralMethodSnippet/";
-        CompletionSource2["SwitchCases"] = "SwitchCases/";
-        return CompletionSource2;
-      })(CompletionSource || {});
-      SymbolOriginInfoKind = /* @__PURE__ */ ((SymbolOriginInfoKind2) => {
-        SymbolOriginInfoKind2[SymbolOriginInfoKind2["ThisType"] = 1] = "ThisType";
-        SymbolOriginInfoKind2[SymbolOriginInfoKind2["SymbolMember"] = 2] = "SymbolMember";
-        SymbolOriginInfoKind2[SymbolOriginInfoKind2["Export"] = 4] = "Export";
-        SymbolOriginInfoKind2[SymbolOriginInfoKind2["Promise"] = 8] = "Promise";
-        SymbolOriginInfoKind2[SymbolOriginInfoKind2["Nullable"] = 16] = "Nullable";
-        SymbolOriginInfoKind2[SymbolOriginInfoKind2["ResolvedExport"] = 32] = "ResolvedExport";
-        SymbolOriginInfoKind2[SymbolOriginInfoKind2["TypeOnlyAlias"] = 64] = "TypeOnlyAlias";
-        SymbolOriginInfoKind2[SymbolOriginInfoKind2["ObjectLiteralMethod"] = 128] = "ObjectLiteralMethod";
-        SymbolOriginInfoKind2[SymbolOriginInfoKind2["Ignore"] = 256] = "Ignore";
-        SymbolOriginInfoKind2[SymbolOriginInfoKind2["ComputedPropertyName"] = 512] = "ComputedPropertyName";
-        SymbolOriginInfoKind2[SymbolOriginInfoKind2["SymbolMemberNoExport"] = 2 /* SymbolMember */] = "SymbolMemberNoExport";
-        SymbolOriginInfoKind2[SymbolOriginInfoKind2["SymbolMemberExport"] = 6] = "SymbolMemberExport";
-        return SymbolOriginInfoKind2;
-      })(SymbolOriginInfoKind || {});
-      CompletionKind = /* @__PURE__ */ ((CompletionKind2) => {
-        CompletionKind2[CompletionKind2["ObjectPropertyDeclaration"] = 0] = "ObjectPropertyDeclaration";
-        CompletionKind2[CompletionKind2["Global"] = 1] = "Global";
-        CompletionKind2[CompletionKind2["PropertyAccess"] = 2] = "PropertyAccess";
-        CompletionKind2[CompletionKind2["MemberLike"] = 3] = "MemberLike";
-        CompletionKind2[CompletionKind2["String"] = 4] = "String";
-        CompletionKind2[CompletionKind2["None"] = 5] = "None";
-        return CompletionKind2;
-      })(CompletionKind || {});
-      _keywordCompletions = [];
-      allKeywordsCompletions = memoize(() => {
-        const res = [];
-        for (let i = 83 /* FirstKeyword */; i <= 164 /* LastKeyword */; i++) {
-          res.push({
-            name: tokenToString(i),
-            kind: "keyword" /* keyword */,
-            kindModifiers: "" /* none */,
-            sortText: SortText.GlobalsOrKeywords
-          });
-        }
-        return res;
-      });
-    }
-  });
-
-  // src/services/stringCompletions.ts
-  function createNameAndKindSet() {
-    const map2 = /* @__PURE__ */ new Map();
-    function add(value) {
-      const existing = map2.get(value.name);
-      if (!existing || kindPrecedence[existing.kind] < kindPrecedence[value.kind]) {
-        map2.set(value.name, value);
-      }
-    }
-    return {
-      add,
-      has: map2.has.bind(map2),
-      values: map2.values.bind(map2)
-    };
-  }
-  function getStringLiteralCompletions(sourceFile, position, contextToken, options, host, program, log, preferences, includeSymbol) {
-    if (isInReferenceComment(sourceFile, position)) {
-      const entries = getTripleSlashReferenceCompletion(sourceFile, position, options, host);
-      return entries && convertPathCompletions(entries);
-    }
-    if (isInString(sourceFile, position, contextToken)) {
-      if (!contextToken || !isStringLiteralLike(contextToken))
-        return void 0;
-      const entries = getStringLiteralCompletionEntries(sourceFile, contextToken, position, program.getTypeChecker(), options, host, preferences);
-      return convertStringLiteralCompletions(entries, contextToken, sourceFile, host, program, log, options, preferences, position, includeSymbol);
-    }
-  }
-  function convertStringLiteralCompletions(completion, contextToken, sourceFile, host, program, log, options, preferences, position, includeSymbol) {
-    if (completion === void 0) {
-      return void 0;
-    }
-    const optionalReplacementSpan = createTextSpanFromStringLiteralLikeContent(contextToken);
-    switch (completion.kind) {
-      case 0 /* Paths */:
-        return convertPathCompletions(completion.paths);
-      case 1 /* Properties */: {
-        const entries = createSortedArray();
-        getCompletionEntriesFromSymbols(
-          completion.symbols,
-          entries,
-          contextToken,
-          contextToken,
-          sourceFile,
-          position,
-          sourceFile,
-          host,
-          program,
-          99 /* ESNext */,
-          log,
-          4 /* String */,
-          preferences,
-          options,
-          /*formatContext*/
-          void 0,
-          /*isTypeOnlyLocation*/
-          void 0,
-          /*propertyAccessToConvert*/
-          void 0,
-          /*jsxIdentifierExpected*/
-          void 0,
-          /*isJsxInitializer*/
-          void 0,
-          /*importStatementCompletion*/
-          void 0,
-          /*recommendedCompletion*/
-          void 0,
-          /*symbolToOriginInfoMap*/
-          void 0,
-          /*symbolToSortTextMap*/
-          void 0,
-          /*isJsxIdentifierExpected*/
-          void 0,
-          /*isRightOfOpenTag*/
-          void 0,
-          includeSymbol
-        );
-        return { isGlobalCompletion: false, isMemberCompletion: true, isNewIdentifierLocation: completion.hasIndexSignature, optionalReplacementSpan, entries };
-      }
-      case 2 /* Types */: {
-        const entries = completion.types.map((type) => ({
-          name: type.value,
-          kindModifiers: "" /* none */,
-          kind: "string" /* string */,
-          sortText: SortText.LocationPriority,
-          replacementSpan: getReplacementSpanForContextToken(contextToken)
-        }));
-        return { isGlobalCompletion: false, isMemberCompletion: false, isNewIdentifierLocation: completion.isNewIdentifier, optionalReplacementSpan, entries };
-      }
-      default:
-        return Debug.assertNever(completion);
-    }
-  }
-  function getStringLiteralCompletionDetails(name, sourceFile, position, contextToken, checker, options, host, cancellationToken, preferences) {
-    if (!contextToken || !isStringLiteralLike(contextToken))
-      return void 0;
-    const completions = getStringLiteralCompletionEntries(sourceFile, contextToken, position, checker, options, host, preferences);
-    return completions && stringLiteralCompletionDetails(name, contextToken, completions, sourceFile, checker, cancellationToken);
-  }
-  function stringLiteralCompletionDetails(name, location, completion, sourceFile, checker, cancellationToken) {
-    switch (completion.kind) {
-      case 0 /* Paths */: {
-        const match = find(completion.paths, (p) => p.name === name);
-        return match && createCompletionDetails(name, kindModifiersFromExtension(match.extension), match.kind, [textPart(name)]);
-      }
-      case 1 /* Properties */: {
-        const match = find(completion.symbols, (s) => s.name === name);
-        return match && createCompletionDetailsForSymbol(match, match.name, checker, sourceFile, location, cancellationToken);
-      }
-      case 2 /* Types */:
-        return find(completion.types, (t) => t.value === name) ? createCompletionDetails(name, "" /* none */, "string" /* string */, [textPart(name)]) : void 0;
-      default:
-        return Debug.assertNever(completion);
-    }
-  }
-  function convertPathCompletions(pathCompletions) {
-    const isGlobalCompletion = false;
-    const isNewIdentifierLocation = true;
-    const entries = pathCompletions.map(({ name, kind, span, extension }) => ({ name, kind, kindModifiers: kindModifiersFromExtension(extension), sortText: SortText.LocationPriority, replacementSpan: span }));
-    return { isGlobalCompletion, isMemberCompletion: false, isNewIdentifierLocation, entries };
-  }
-  function kindModifiersFromExtension(extension) {
-    switch (extension) {
-      case ".d.ts" /* Dts */:
-        return ".d.ts" /* dtsModifier */;
-      case ".js" /* Js */:
-        return ".js" /* jsModifier */;
-      case ".json" /* Json */:
-        return ".json" /* jsonModifier */;
-      case ".jsx" /* Jsx */:
-        return ".jsx" /* jsxModifier */;
-      case ".ts" /* Ts */:
-        return ".ts" /* tsModifier */;
-      case ".tsx" /* Tsx */:
-        return ".tsx" /* tsxModifier */;
-      case ".d.mts" /* Dmts */:
-        return ".d.mts" /* dmtsModifier */;
-      case ".mjs" /* Mjs */:
-        return ".mjs" /* mjsModifier */;
-      case ".mts" /* Mts */:
-        return ".mts" /* mtsModifier */;
-      case ".d.cts" /* Dcts */:
-        return ".d.cts" /* dctsModifier */;
-      case ".cjs" /* Cjs */:
-        return ".cjs" /* cjsModifier */;
-      case ".cts" /* Cts */:
-        return ".cts" /* ctsModifier */;
-      case ".tsbuildinfo" /* TsBuildInfo */:
-        return Debug.fail(`Extension ${".tsbuildinfo" /* TsBuildInfo */} is unsupported.`);
-      case void 0:
-        return "" /* none */;
-      default:
-        return Debug.assertNever(extension);
-    }
-  }
-  function getStringLiteralCompletionEntries(sourceFile, node, position, typeChecker, compilerOptions, host, preferences) {
-    const parent2 = walkUpParentheses(node.parent);
-    switch (parent2.kind) {
-      case 200 /* LiteralType */: {
-        const grandParent = walkUpParentheses(parent2.parent);
-        if (grandParent.kind === 204 /* ImportType */) {
-          return { kind: 0 /* Paths */, paths: getStringLiteralCompletionsFromModuleNames(sourceFile, node, compilerOptions, host, typeChecker, preferences) };
-        }
-        return fromUnionableLiteralType(grandParent);
-      }
-      case 302 /* PropertyAssignment */:
-        if (isObjectLiteralExpression(parent2.parent) && parent2.name === node) {
-          return stringLiteralCompletionsForObjectLiteral(typeChecker, parent2.parent);
-        }
-        return fromContextualType() || fromContextualType(0 /* None */);
-      case 211 /* ElementAccessExpression */: {
-        const { expression, argumentExpression } = parent2;
-        if (node === skipParentheses(argumentExpression)) {
-          return stringLiteralCompletionsFromProperties(typeChecker.getTypeAtLocation(expression));
-        }
-        return void 0;
-      }
-      case 212 /* CallExpression */:
-      case 213 /* NewExpression */:
-      case 290 /* JsxAttribute */:
-        if (!isRequireCallArgument(node) && !isImportCall(parent2)) {
-          const argumentInfo = ts_SignatureHelp_exports.getArgumentInfoForCompletions(parent2.kind === 290 /* JsxAttribute */ ? parent2.parent : node, position, sourceFile);
-          return argumentInfo && getStringLiteralCompletionsFromSignature(argumentInfo.invocation, node, argumentInfo, typeChecker) || fromContextualType(0 /* None */);
-        }
-      case 271 /* ImportDeclaration */:
-      case 277 /* ExportDeclaration */:
-      case 282 /* ExternalModuleReference */:
-        return { kind: 0 /* Paths */, paths: getStringLiteralCompletionsFromModuleNames(sourceFile, node, compilerOptions, host, typeChecker, preferences) };
-      case 295 /* CaseClause */:
-        const tracker = newCaseClauseTracker(typeChecker, parent2.parent.clauses);
-        const contextualTypes = fromContextualType();
-        if (!contextualTypes) {
-          return;
-        }
-        const literals = contextualTypes.types.filter((literal) => !tracker.hasValue(literal.value));
-        return { kind: 2 /* Types */, types: literals, isNewIdentifier: false };
-      default:
-        return fromContextualType() || fromContextualType(0 /* None */);
-    }
-    function fromUnionableLiteralType(grandParent) {
-      switch (grandParent.kind) {
-        case 232 /* ExpressionWithTypeArguments */:
-        case 182 /* TypeReference */: {
-          const typeArgument = findAncestor(parent2, (n) => n.parent === grandParent);
-          if (typeArgument) {
-            return { kind: 2 /* Types */, types: getStringLiteralTypes(typeChecker.getTypeArgumentConstraint(typeArgument)), isNewIdentifier: false };
-          }
-          return void 0;
-        }
-        case 198 /* IndexedAccessType */:
-          const { indexType, objectType } = grandParent;
-          if (!rangeContainsPosition(indexType, position)) {
-            return void 0;
-          }
-          return stringLiteralCompletionsFromProperties(typeChecker.getTypeFromTypeNode(objectType));
-        case 191 /* UnionType */: {
-          const result = fromUnionableLiteralType(walkUpParentheses(grandParent.parent));
-          if (!result) {
-            return void 0;
-          }
-          const alreadyUsedTypes = getAlreadyUsedTypesInStringLiteralUnion(grandParent, parent2);
-          if (result.kind === 1 /* Properties */) {
-            return { kind: 1 /* Properties */, symbols: result.symbols.filter((sym) => !contains(alreadyUsedTypes, sym.name)), hasIndexSignature: result.hasIndexSignature };
-          }
-          return { kind: 2 /* Types */, types: result.types.filter((t) => !contains(alreadyUsedTypes, t.value)), isNewIdentifier: false };
-        }
-        default:
-          return void 0;
-      }
-    }
-    function fromContextualType(contextFlags = 4 /* Completions */) {
-      const types = getStringLiteralTypes(getContextualTypeFromParent(node, typeChecker, contextFlags));
-      if (!types.length) {
-        return;
-      }
-      return { kind: 2 /* Types */, types, isNewIdentifier: false };
-    }
-  }
-  function walkUpParentheses(node) {
-    switch (node.kind) {
-      case 195 /* ParenthesizedType */:
-        return walkUpParenthesizedTypes(node);
-      case 216 /* ParenthesizedExpression */:
-        return walkUpParenthesizedExpressions(node);
-      default:
-        return node;
-    }
-  }
-  function getAlreadyUsedTypesInStringLiteralUnion(union, current) {
-    return mapDefined(union.types, (type) => type !== current && isLiteralTypeNode(type) && isStringLiteral(type.literal) ? type.literal.text : void 0);
-  }
-  function getStringLiteralCompletionsFromSignature(call, arg, argumentInfo, checker) {
-    let isNewIdentifier = false;
-    const uniques = /* @__PURE__ */ new Map();
-    const candidates = [];
-    const editingArgument = isJsxOpeningLikeElement(call) ? Debug.checkDefined(findAncestor(arg.parent, isJsxAttribute)) : arg;
-    checker.getResolvedSignatureForStringLiteralCompletions(call, editingArgument, candidates);
-    const types = flatMap(candidates, (candidate) => {
-      if (!signatureHasRestParameter(candidate) && argumentInfo.argumentCount > candidate.parameters.length)
-        return;
-      let type = candidate.getTypeParameterAtPosition(argumentInfo.argumentIndex);
-      if (isJsxOpeningLikeElement(call)) {
-        const propType = checker.getTypeOfPropertyOfType(type, getTextOfJsxAttributeName(editingArgument.name));
-        if (propType) {
-          type = propType;
-        }
-      }
-      isNewIdentifier = isNewIdentifier || !!(type.flags & 4 /* String */);
-      return getStringLiteralTypes(type, uniques);
-    });
-    return length(types) ? { kind: 2 /* Types */, types, isNewIdentifier } : void 0;
-  }
-  function stringLiteralCompletionsFromProperties(type) {
-    return type && {
-      kind: 1 /* Properties */,
-      symbols: filter(type.getApparentProperties(), (prop) => !(prop.valueDeclaration && isPrivateIdentifierClassElementDeclaration(prop.valueDeclaration))),
-      hasIndexSignature: hasIndexSignature(type)
-    };
-  }
-  function stringLiteralCompletionsForObjectLiteral(checker, objectLiteralExpression) {
-    const contextualType = checker.getContextualType(objectLiteralExpression);
-    if (!contextualType)
-      return void 0;
-    const completionsType = checker.getContextualType(objectLiteralExpression, 4 /* Completions */);
-    const symbols = getPropertiesForObjectExpression(
-      contextualType,
-      completionsType,
-      objectLiteralExpression,
-      checker
-    );
-    return {
-      kind: 1 /* Properties */,
-      symbols,
-      hasIndexSignature: hasIndexSignature(contextualType)
-    };
-  }
-  function getStringLiteralTypes(type, uniques = /* @__PURE__ */ new Map()) {
-    if (!type)
-      return emptyArray;
-    type = skipConstraint(type);
-    return type.isUnion() ? flatMap(type.types, (t) => getStringLiteralTypes(t, uniques)) : type.isStringLiteral() && !(type.flags & 1024 /* EnumLiteral */) && addToSeen(uniques, type.value) ? [type] : emptyArray;
-  }
-  function nameAndKind(name, kind, extension) {
-    return { name, kind, extension };
-  }
-  function directoryResult(name) {
-    return nameAndKind(
-      name,
-      "directory" /* directory */,
-      /*extension*/
-      void 0
-    );
-  }
-  function addReplacementSpans(text, textStart, names) {
-    const span = getDirectoryFragmentTextSpan(text, textStart);
-    const wholeSpan = text.length === 0 ? void 0 : createTextSpan(textStart, text.length);
-    return names.map(({ name, kind, extension }) => Math.max(name.indexOf(directorySeparator), name.indexOf(altDirectorySeparator)) !== -1 ? { name, kind, extension, span: wholeSpan } : { name, kind, extension, span });
-  }
-  function getStringLiteralCompletionsFromModuleNames(sourceFile, node, compilerOptions, host, typeChecker, preferences) {
-    return addReplacementSpans(node.text, node.getStart(sourceFile) + 1, getStringLiteralCompletionsFromModuleNamesWorker(sourceFile, node, compilerOptions, host, typeChecker, preferences));
-  }
-  function getStringLiteralCompletionsFromModuleNamesWorker(sourceFile, node, compilerOptions, host, typeChecker, preferences) {
-    const literalValue = normalizeSlashes(node.text);
-    const mode = isStringLiteralLike(node) ? getModeForUsageLocation(sourceFile, node) : void 0;
-    const scriptPath = sourceFile.path;
-    const scriptDirectory = getDirectoryPath(scriptPath);
-    const extensionOptions = getExtensionOptions(compilerOptions, 1 /* ModuleSpecifier */, sourceFile, typeChecker, preferences, mode);
-    return isPathRelativeToScript(literalValue) || !compilerOptions.baseUrl && !compilerOptions.paths && (isRootedDiskPath(literalValue) || isUrl(literalValue)) ? getCompletionEntriesForRelativeModules(literalValue, scriptDirectory, compilerOptions, host, scriptPath, extensionOptions) : getCompletionEntriesForNonRelativeModules(literalValue, scriptDirectory, mode, compilerOptions, host, extensionOptions, typeChecker);
-  }
-  function getExtensionOptions(compilerOptions, referenceKind, importingSourceFile, typeChecker, preferences, resolutionMode) {
-    return {
-      extensionsToSearch: flatten(getSupportedExtensionsForModuleResolution(compilerOptions, typeChecker)),
-      referenceKind,
-      importingSourceFile,
-      endingPreference: preferences == null ? void 0 : preferences.importModuleSpecifierEnding,
-      resolutionMode
-    };
-  }
-  function getCompletionEntriesForRelativeModules(literalValue, scriptDirectory, compilerOptions, host, scriptPath, extensionOptions) {
-    if (compilerOptions.rootDirs) {
-      return getCompletionEntriesForDirectoryFragmentWithRootDirs(
-        compilerOptions.rootDirs,
-        literalValue,
-        scriptDirectory,
-        extensionOptions,
-        compilerOptions,
-        host,
-        scriptPath
-      );
-    } else {
-      return arrayFrom(getCompletionEntriesForDirectoryFragment(
-        literalValue,
-        scriptDirectory,
-        extensionOptions,
-        host,
-        /*moduleSpecifierIsRelative*/
-        false,
-        scriptPath
-      ).values());
-    }
-  }
-  function getSupportedExtensionsForModuleResolution(compilerOptions, typeChecker) {
-    const ambientModulesExtensions = !typeChecker ? [] : mapDefined(
-      typeChecker.getAmbientModules(),
-      (module2) => {
-        const name = module2.name.slice(1, -1);
-        if (!name.startsWith("*.") || name.includes("/"))
-          return;
-        return name.slice(1);
-      }
-    );
-    const extensions = [...getSupportedExtensions(compilerOptions), ambientModulesExtensions];
-    const moduleResolution = getEmitModuleResolutionKind(compilerOptions);
-    return moduleResolutionUsesNodeModules(moduleResolution) ? getSupportedExtensionsWithJsonIfResolveJsonModule(compilerOptions, extensions) : extensions;
-  }
-  function getBaseDirectoriesFromRootDirs(rootDirs, basePath, scriptDirectory, ignoreCase) {
-    rootDirs = rootDirs.map((rootDirectory) => normalizePath(isRootedDiskPath(rootDirectory) ? rootDirectory : combinePaths(basePath, rootDirectory)));
-    const relativeDirectory = firstDefined(rootDirs, (rootDirectory) => containsPath(rootDirectory, scriptDirectory, basePath, ignoreCase) ? scriptDirectory.substr(rootDirectory.length) : void 0);
-    return deduplicate(
-      [...rootDirs.map((rootDirectory) => combinePaths(rootDirectory, relativeDirectory)), scriptDirectory],
-      equateStringsCaseSensitive,
-      compareStringsCaseSensitive
-    );
-  }
-  function getCompletionEntriesForDirectoryFragmentWithRootDirs(rootDirs, fragment, scriptDirectory, extensionOptions, compilerOptions, host, exclude) {
-    const basePath = compilerOptions.project || host.getCurrentDirectory();
-    const ignoreCase = !(host.useCaseSensitiveFileNames && host.useCaseSensitiveFileNames());
-    const baseDirectories = getBaseDirectoriesFromRootDirs(rootDirs, basePath, scriptDirectory, ignoreCase);
-    return flatMap(baseDirectories, (baseDirectory) => arrayFrom(getCompletionEntriesForDirectoryFragment(
-      fragment,
-      baseDirectory,
-      extensionOptions,
-      host,
-      /*moduleSpecifierIsRelative*/
-      true,
-      exclude
-    ).values()));
-  }
-  function getCompletionEntriesForDirectoryFragment(fragment, scriptDirectory, extensionOptions, host, moduleSpecifierIsRelative, exclude, result = createNameAndKindSet()) {
-    var _a;
-    if (fragment === void 0) {
-      fragment = "";
-    }
-    fragment = normalizeSlashes(fragment);
-    if (!hasTrailingDirectorySeparator(fragment)) {
-      fragment = getDirectoryPath(fragment);
-    }
-    if (fragment === "") {
-      fragment = "." + directorySeparator;
-    }
-    fragment = ensureTrailingDirectorySeparator(fragment);
-    const absolutePath = resolvePath(scriptDirectory, fragment);
-    const baseDirectory = hasTrailingDirectorySeparator(absolutePath) ? absolutePath : getDirectoryPath(absolutePath);
-    if (!moduleSpecifierIsRelative) {
-      const packageJsonPath = findPackageJson(baseDirectory, host);
-      if (packageJsonPath) {
-        const packageJson = readJson(packageJsonPath, host);
-        const typesVersions = packageJson.typesVersions;
-        if (typeof typesVersions === "object") {
-          const versionPaths = (_a = getPackageJsonTypesVersionsPaths(typesVersions)) == null ? void 0 : _a.paths;
-          if (versionPaths) {
-            const packageDirectory = getDirectoryPath(packageJsonPath);
-            const pathInPackage = absolutePath.slice(ensureTrailingDirectorySeparator(packageDirectory).length);
-            if (addCompletionEntriesFromPaths(result, pathInPackage, packageDirectory, extensionOptions, host, versionPaths)) {
-              return result;
-            }
-          }
-        }
-      }
-    }
-    const ignoreCase = !(host.useCaseSensitiveFileNames && host.useCaseSensitiveFileNames());
-    if (!tryDirectoryExists(host, baseDirectory))
-      return result;
-    const files = tryReadDirectory(
-      host,
-      baseDirectory,
-      extensionOptions.extensionsToSearch,
-      /*exclude*/
-      void 0,
-      /*include*/
-      ["./*"]
-    );
-    if (files) {
-      for (let filePath of files) {
-        filePath = normalizePath(filePath);
-        if (exclude && comparePaths(filePath, exclude, scriptDirectory, ignoreCase) === 0 /* EqualTo */) {
-          continue;
-        }
-        const { name, extension } = getFilenameWithExtensionOption(getBaseFileName(filePath), host.getCompilationSettings(), extensionOptions);
-        result.add(nameAndKind(name, "script" /* scriptElement */, extension));
-      }
-    }
-    const directories = tryGetDirectories(host, baseDirectory);
-    if (directories) {
-      for (const directory of directories) {
-        const directoryName = getBaseFileName(normalizePath(directory));
-        if (directoryName !== "@types") {
-          result.add(directoryResult(directoryName));
-        }
-      }
-    }
-    return result;
-  }
-  function getFilenameWithExtensionOption(name, compilerOptions, extensionOptions) {
-    const nonJsResult = ts_moduleSpecifiers_exports.tryGetRealFileNameForNonJsDeclarationFileName(name);
-    if (nonJsResult) {
-      return { name: nonJsResult, extension: tryGetExtensionFromPath2(nonJsResult) };
-    }
-    if (extensionOptions.referenceKind === 0 /* Filename */) {
-      return { name, extension: tryGetExtensionFromPath2(name) };
-    }
-    const endingPreference = getModuleSpecifierEndingPreference(extensionOptions.endingPreference, extensionOptions.resolutionMode, compilerOptions, extensionOptions.importingSourceFile);
-    if (endingPreference === 3 /* TsExtension */) {
-      if (fileExtensionIsOneOf(name, supportedTSImplementationExtensions)) {
-        return { name, extension: tryGetExtensionFromPath2(name) };
-      }
-      const outputExtension2 = ts_moduleSpecifiers_exports.tryGetJSExtensionForFile(name, compilerOptions);
-      return outputExtension2 ? { name: changeExtension(name, outputExtension2), extension: outputExtension2 } : { name, extension: tryGetExtensionFromPath2(name) };
-    }
-    if ((endingPreference === 0 /* Minimal */ || endingPreference === 1 /* Index */) && fileExtensionIsOneOf(name, [".js" /* Js */, ".jsx" /* Jsx */, ".ts" /* Ts */, ".tsx" /* Tsx */, ".d.ts" /* Dts */])) {
-      return { name: removeFileExtension(name), extension: tryGetExtensionFromPath2(name) };
-    }
-    const outputExtension = ts_moduleSpecifiers_exports.tryGetJSExtensionForFile(name, compilerOptions);
-    return outputExtension ? { name: changeExtension(name, outputExtension), extension: outputExtension } : { name, extension: tryGetExtensionFromPath2(name) };
-  }
-  function addCompletionEntriesFromPaths(result, fragment, baseDirectory, extensionOptions, host, paths) {
-    const getPatternsForKey = (key) => paths[key];
-    const comparePaths2 = (a, b) => {
-      const patternA = tryParsePattern(a);
-      const patternB = tryParsePattern(b);
-      const lengthA = typeof patternA === "object" ? patternA.prefix.length : a.length;
-      const lengthB = typeof patternB === "object" ? patternB.prefix.length : b.length;
-      return compareValues(lengthB, lengthA);
-    };
-    return addCompletionEntriesFromPathsOrExports(result, fragment, baseDirectory, extensionOptions, host, getOwnKeys(paths), getPatternsForKey, comparePaths2);
-  }
-  function addCompletionEntriesFromPathsOrExports(result, fragment, baseDirectory, extensionOptions, host, keys, getPatternsForKey, comparePaths2) {
-    let pathResults = [];
-    let matchedPath;
-    for (const key of keys) {
-      if (key === ".")
-        continue;
-      const keyWithoutLeadingDotSlash = key.replace(/^\.\//, "");
-      const patterns = getPatternsForKey(key);
-      if (patterns) {
-        const pathPattern = tryParsePattern(keyWithoutLeadingDotSlash);
-        if (!pathPattern)
-          continue;
-        const isMatch = typeof pathPattern === "object" && isPatternMatch(pathPattern, fragment);
-        const isLongestMatch = isMatch && (matchedPath === void 0 || comparePaths2(key, matchedPath) === -1 /* LessThan */);
-        if (isLongestMatch) {
-          matchedPath = key;
-          pathResults = pathResults.filter((r) => !r.matchedPattern);
-        }
-        if (typeof pathPattern === "string" || matchedPath === void 0 || comparePaths2(key, matchedPath) !== 1 /* GreaterThan */) {
-          pathResults.push({
-            matchedPattern: isMatch,
-            results: getCompletionsForPathMapping(keyWithoutLeadingDotSlash, patterns, fragment, baseDirectory, extensionOptions, host).map(({ name, kind, extension }) => nameAndKind(name, kind, extension))
-          });
-        }
-      }
-    }
-    pathResults.forEach((pathResult) => pathResult.results.forEach((r) => result.add(r)));
-    return matchedPath !== void 0;
-  }
-  function getCompletionEntriesForNonRelativeModules(fragment, scriptPath, mode, compilerOptions, host, extensionOptions, typeChecker) {
-    const { baseUrl, paths } = compilerOptions;
-    const result = createNameAndKindSet();
-    const moduleResolution = getEmitModuleResolutionKind(compilerOptions);
-    if (baseUrl) {
-      const absolute = normalizePath(combinePaths(host.getCurrentDirectory(), baseUrl));
-      getCompletionEntriesForDirectoryFragment(
-        fragment,
-        absolute,
-        extensionOptions,
-        host,
-        /*moduleSpecifierIsRelative*/
-        false,
-        /*exclude*/
-        void 0,
-        result
-      );
-    }
-    if (paths) {
-      const absolute = getPathsBasePath(compilerOptions, host);
-      addCompletionEntriesFromPaths(result, fragment, absolute, extensionOptions, host, paths);
-    }
-    const fragmentDirectory = getFragmentDirectory(fragment);
-    for (const ambientName of getAmbientModuleCompletions(fragment, fragmentDirectory, typeChecker)) {
-      result.add(nameAndKind(
-        ambientName,
-        "external module name" /* externalModuleName */,
-        /*extension*/
-        void 0
-      ));
-    }
-    getCompletionEntriesFromTypings(host, compilerOptions, scriptPath, fragmentDirectory, extensionOptions, result);
-    if (moduleResolutionUsesNodeModules(moduleResolution)) {
-      let foundGlobal = false;
-      if (fragmentDirectory === void 0) {
-        for (const moduleName of enumerateNodeModulesVisibleToScript(host, scriptPath)) {
-          const moduleResult = nameAndKind(
-            moduleName,
-            "external module name" /* externalModuleName */,
-            /*extension*/
-            void 0
-          );
-          if (!result.has(moduleResult.name)) {
-            foundGlobal = true;
-            result.add(moduleResult);
-          }
-        }
-      }
-      if (!foundGlobal) {
-        let ancestorLookup = (ancestor) => {
-          const nodeModules = combinePaths(ancestor, "node_modules");
-          if (tryDirectoryExists(host, nodeModules)) {
-            getCompletionEntriesForDirectoryFragment(
-              fragment,
-              nodeModules,
-              extensionOptions,
-              host,
-              /*moduleSpecifierIsRelative*/
-              false,
-              /*exclude*/
-              void 0,
-              result
-            );
-          }
-        };
-        if (fragmentDirectory && getResolvePackageJsonExports(compilerOptions)) {
-          const nodeModulesDirectoryLookup = ancestorLookup;
-          ancestorLookup = (ancestor) => {
-            const components = getPathComponents(fragment);
-            components.shift();
-            let packagePath = components.shift();
-            if (!packagePath) {
-              return nodeModulesDirectoryLookup(ancestor);
-            }
-            if (startsWith(packagePath, "@")) {
-              const subName = components.shift();
-              if (!subName) {
-                return nodeModulesDirectoryLookup(ancestor);
-              }
-              packagePath = combinePaths(packagePath, subName);
-            }
-            const packageDirectory = combinePaths(ancestor, "node_modules", packagePath);
-            const packageFile = combinePaths(packageDirectory, "package.json");
-            if (tryFileExists(host, packageFile)) {
-              const packageJson = readJson(packageFile, host);
-              const exports = packageJson.exports;
-              if (exports) {
-                if (typeof exports !== "object" || exports === null) {
-                  return;
-                }
-                const keys = getOwnKeys(exports);
-                const fragmentSubpath = components.join("/") + (components.length && hasTrailingDirectorySeparator(fragment) ? "/" : "");
-                const conditions = mode === 99 /* ESNext */ ? ["node", "import", "types"] : ["node", "require", "types"];
-                addCompletionEntriesFromPathsOrExports(
-                  result,
-                  fragmentSubpath,
-                  packageDirectory,
-                  extensionOptions,
-                  host,
-                  keys,
-                  (key) => singleElementArray(getPatternFromFirstMatchingCondition(exports[key], conditions)),
-                  comparePatternKeys
-                );
-                return;
-              }
-            }
-            return nodeModulesDirectoryLookup(ancestor);
-          };
-        }
-        forEachAncestorDirectory(scriptPath, ancestorLookup);
-      }
-    }
-    return arrayFrom(result.values());
-  }
-  function getPatternFromFirstMatchingCondition(target, conditions) {
-    if (typeof target === "string") {
-      return target;
-    }
-    if (target && typeof target === "object" && !isArray(target)) {
-      for (const condition in target) {
-        if (condition === "default" || conditions.indexOf(condition) > -1 || isApplicableVersionedTypesKey(conditions, condition)) {
-          const pattern = target[condition];
-          return getPatternFromFirstMatchingCondition(pattern, conditions);
-        }
-      }
-    }
-  }
-  function getFragmentDirectory(fragment) {
-    return containsSlash(fragment) ? hasTrailingDirectorySeparator(fragment) ? fragment : getDirectoryPath(fragment) : void 0;
-  }
-  function getCompletionsForPathMapping(path, patterns, fragment, packageDirectory, extensionOptions, host) {
-    if (!endsWith(path, "*")) {
-      return !stringContains(path, "*") ? justPathMappingName(path, "script" /* scriptElement */) : emptyArray;
-    }
-    const pathPrefix = path.slice(0, path.length - 1);
-    const remainingFragment = tryRemovePrefix(fragment, pathPrefix);
-    if (remainingFragment === void 0) {
-      const starIsFullPathComponent = path[path.length - 2] === "/";
-      return starIsFullPathComponent ? justPathMappingName(pathPrefix, "directory" /* directory */) : flatMap(patterns, (pattern) => {
-        var _a;
-        return (_a = getModulesForPathsPattern("", packageDirectory, pattern, extensionOptions, host)) == null ? void 0 : _a.map(({ name, ...rest }) => ({ name: pathPrefix + name, ...rest }));
-      });
-    }
-    return flatMap(patterns, (pattern) => getModulesForPathsPattern(remainingFragment, packageDirectory, pattern, extensionOptions, host));
-    function justPathMappingName(name, kind) {
-      return startsWith(name, fragment) ? [{ name: removeTrailingDirectorySeparator(name), kind, extension: void 0 }] : emptyArray;
-    }
-  }
-  function getModulesForPathsPattern(fragment, packageDirectory, pattern, extensionOptions, host) {
-    if (!host.readDirectory) {
-      return void 0;
-    }
-    const parsed = tryParsePattern(pattern);
-    if (parsed === void 0 || isString(parsed)) {
-      return void 0;
-    }
-    const normalizedPrefix = resolvePath(parsed.prefix);
-    const normalizedPrefixDirectory = hasTrailingDirectorySeparator(parsed.prefix) ? normalizedPrefix : getDirectoryPath(normalizedPrefix);
-    const normalizedPrefixBase = hasTrailingDirectorySeparator(parsed.prefix) ? "" : getBaseFileName(normalizedPrefix);
-    const fragmentHasPath = containsSlash(fragment);
-    const fragmentDirectory = fragmentHasPath ? hasTrailingDirectorySeparator(fragment) ? fragment : getDirectoryPath(fragment) : void 0;
-    const expandedPrefixDirectory = fragmentHasPath ? combinePaths(normalizedPrefixDirectory, normalizedPrefixBase + fragmentDirectory) : normalizedPrefixDirectory;
-    const normalizedSuffix = normalizePath(parsed.suffix);
-    const baseDirectory = normalizePath(combinePaths(packageDirectory, expandedPrefixDirectory));
-    const completePrefix = fragmentHasPath ? baseDirectory : ensureTrailingDirectorySeparator(baseDirectory) + normalizedPrefixBase;
-    const includeGlob = normalizedSuffix ? "**/*" + normalizedSuffix : "./*";
-    const matches = mapDefined(tryReadDirectory(
-      host,
-      baseDirectory,
-      extensionOptions.extensionsToSearch,
-      /*exclude*/
-      void 0,
-      [includeGlob]
-    ), (match) => {
-      const trimmedWithPattern = trimPrefixAndSuffix(match);
-      if (trimmedWithPattern) {
-        if (containsSlash(trimmedWithPattern)) {
-          return directoryResult(getPathComponents(removeLeadingDirectorySeparator(trimmedWithPattern))[1]);
-        }
-        const { name, extension } = getFilenameWithExtensionOption(trimmedWithPattern, host.getCompilationSettings(), extensionOptions);
-        return nameAndKind(name, "script" /* scriptElement */, extension);
-      }
-    });
-    const directories = normalizedSuffix ? emptyArray : mapDefined(tryGetDirectories(host, baseDirectory), (dir) => dir === "node_modules" ? void 0 : directoryResult(dir));
-    return [...matches, ...directories];
-    function trimPrefixAndSuffix(path) {
-      const inner = withoutStartAndEnd(normalizePath(path), completePrefix, normalizedSuffix);
-      return inner === void 0 ? void 0 : removeLeadingDirectorySeparator(inner);
-    }
-  }
-  function withoutStartAndEnd(s, start, end) {
-    return startsWith(s, start) && endsWith(s, end) ? s.slice(start.length, s.length - end.length) : void 0;
-  }
-  function removeLeadingDirectorySeparator(path) {
-    return path[0] === directorySeparator ? path.slice(1) : path;
-  }
-  function getAmbientModuleCompletions(fragment, fragmentDirectory, checker) {
-    const ambientModules = checker.getAmbientModules().map((sym) => stripQuotes(sym.name));
-    const nonRelativeModuleNames = ambientModules.filter((moduleName) => startsWith(moduleName, fragment) && moduleName.indexOf("*") < 0);
-    if (fragmentDirectory !== void 0) {
-      const moduleNameWithSeparator = ensureTrailingDirectorySeparator(fragmentDirectory);
-      return nonRelativeModuleNames.map((nonRelativeModuleName) => removePrefix(nonRelativeModuleName, moduleNameWithSeparator));
-    }
-    return nonRelativeModuleNames;
-  }
-  function getTripleSlashReferenceCompletion(sourceFile, position, compilerOptions, host) {
-    const token = getTokenAtPosition(sourceFile, position);
-    const commentRanges = getLeadingCommentRanges(sourceFile.text, token.pos);
-    const range = commentRanges && find(commentRanges, (commentRange) => position >= commentRange.pos && position <= commentRange.end);
-    if (!range) {
-      return void 0;
-    }
-    const text = sourceFile.text.slice(range.pos, position);
-    const match = tripleSlashDirectiveFragmentRegex.exec(text);
-    if (!match) {
-      return void 0;
-    }
-    const [, prefix, kind, toComplete] = match;
-    const scriptPath = getDirectoryPath(sourceFile.path);
-    const names = kind === "path" ? getCompletionEntriesForDirectoryFragment(
-      toComplete,
-      scriptPath,
-      getExtensionOptions(compilerOptions, 0 /* Filename */, sourceFile),
-      host,
-      /*moduleSpecifierIsRelative*/
-      true,
-      sourceFile.path
-    ) : kind === "types" ? getCompletionEntriesFromTypings(host, compilerOptions, scriptPath, getFragmentDirectory(toComplete), getExtensionOptions(compilerOptions, 1 /* ModuleSpecifier */, sourceFile)) : Debug.fail();
-    return addReplacementSpans(toComplete, range.pos + prefix.length, arrayFrom(names.values()));
-  }
-  function getCompletionEntriesFromTypings(host, options, scriptPath, fragmentDirectory, extensionOptions, result = createNameAndKindSet()) {
-    const seen = /* @__PURE__ */ new Map();
-    const typeRoots = tryAndIgnoreErrors(() => getEffectiveTypeRoots(options, host)) || emptyArray;
-    for (const root of typeRoots) {
-      getCompletionEntriesFromDirectories(root);
-    }
-    for (const packageJson of findPackageJsons(scriptPath, host)) {
-      const typesDir = combinePaths(getDirectoryPath(packageJson), "node_modules/@types");
-      getCompletionEntriesFromDirectories(typesDir);
-    }
-    return result;
-    function getCompletionEntriesFromDirectories(directory) {
-      if (!tryDirectoryExists(host, directory))
-        return;
-      for (const typeDirectoryName of tryGetDirectories(host, directory)) {
-        const packageName = unmangleScopedPackageName(typeDirectoryName);
-        if (options.types && !contains(options.types, packageName))
-          continue;
-        if (fragmentDirectory === void 0) {
-          if (!seen.has(packageName)) {
-            result.add(nameAndKind(
-              packageName,
-              "external module name" /* externalModuleName */,
-              /*extension*/
-              void 0
-            ));
-            seen.set(packageName, true);
-          }
-        } else {
-          const baseDirectory = combinePaths(directory, typeDirectoryName);
-          const remainingFragment = tryRemoveDirectoryPrefix(fragmentDirectory, packageName, hostGetCanonicalFileName(host));
-          if (remainingFragment !== void 0) {
-            getCompletionEntriesForDirectoryFragment(
-              remainingFragment,
-              baseDirectory,
-              extensionOptions,
-              host,
-              /*moduleSpecifierIsRelative*/
-              false,
-              /*exclude*/
-              void 0,
-              result
-            );
-          }
-        }
-      }
-    }
-  }
-  function enumerateNodeModulesVisibleToScript(host, scriptPath) {
-    if (!host.readFile || !host.fileExists)
-      return emptyArray;
-    const result = [];
-    for (const packageJson of findPackageJsons(scriptPath, host)) {
-      const contents = readJson(packageJson, host);
-      for (const key of nodeModulesDependencyKeys) {
-        const dependencies = contents[key];
-        if (!dependencies)
-          continue;
-        for (const dep in dependencies) {
-          if (hasProperty(dependencies, dep) && !startsWith(dep, "@types/")) {
-            result.push(dep);
-          }
-        }
-      }
-    }
-    return result;
-  }
-  function getDirectoryFragmentTextSpan(text, textStart) {
-    const index = Math.max(text.lastIndexOf(directorySeparator), text.lastIndexOf(altDirectorySeparator));
-    const offset = index !== -1 ? index + 1 : 0;
-    const length2 = text.length - offset;
-    return length2 === 0 || isIdentifierText(text.substr(offset, length2), 99 /* ESNext */) ? void 0 : createTextSpan(textStart + offset, length2);
-  }
-  function isPathRelativeToScript(path) {
-    if (path && path.length >= 2 && path.charCodeAt(0) === 46 /* dot */) {
-      const slashIndex = path.length >= 3 && path.charCodeAt(1) === 46 /* dot */ ? 2 : 1;
-      const slashCharCode = path.charCodeAt(slashIndex);
-      return slashCharCode === 47 /* slash */ || slashCharCode === 92 /* backslash */;
-    }
-    return false;
-  }
-  function containsSlash(fragment) {
-    return stringContains(fragment, directorySeparator);
-  }
-  function isRequireCallArgument(node) {
-    return isCallExpression(node.parent) && firstOrUndefined(node.parent.arguments) === node && isIdentifier(node.parent.expression) && node.parent.expression.escapedText === "require";
-  }
-  var kindPrecedence, tripleSlashDirectiveFragmentRegex, nodeModulesDependencyKeys;
-  var init_stringCompletions = __esm({
-    "src/services/stringCompletions.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_Completions();
-      kindPrecedence = {
-        ["directory" /* directory */]: 0,
-        ["script" /* scriptElement */]: 1,
-        ["external module name" /* externalModuleName */]: 2
-      };
-      tripleSlashDirectiveFragmentRegex = /^(\/\/\/\s* getStringLiteralCompletionDetails,
-    getStringLiteralCompletions: () => getStringLiteralCompletions
-  });
-  var init_ts_Completions_StringCompletions = __esm({
-    "src/services/_namespaces/ts.Completions.StringCompletions.ts"() {
-      "use strict";
-      init_stringCompletions();
-    }
-  });
-
-  // src/services/_namespaces/ts.Completions.ts
-  var ts_Completions_exports = {};
-  __export(ts_Completions_exports, {
-    CompletionKind: () => CompletionKind,
-    CompletionSource: () => CompletionSource,
-    SortText: () => SortText,
-    StringCompletions: () => ts_Completions_StringCompletions_exports,
-    SymbolOriginInfoKind: () => SymbolOriginInfoKind,
-    createCompletionDetails: () => createCompletionDetails,
-    createCompletionDetailsForSymbol: () => createCompletionDetailsForSymbol,
-    getCompletionEntriesFromSymbols: () => getCompletionEntriesFromSymbols,
-    getCompletionEntryDetails: () => getCompletionEntryDetails,
-    getCompletionEntrySymbol: () => getCompletionEntrySymbol,
-    getCompletionsAtPosition: () => getCompletionsAtPosition,
-    getPropertiesForObjectExpression: () => getPropertiesForObjectExpression,
-    moduleSpecifierResolutionCacheAttemptLimit: () => moduleSpecifierResolutionCacheAttemptLimit,
-    moduleSpecifierResolutionLimit: () => moduleSpecifierResolutionLimit
-  });
-  var init_ts_Completions = __esm({
-    "src/services/_namespaces/ts.Completions.ts"() {
-      "use strict";
-      init_completions();
-      init_ts_Completions_StringCompletions();
-    }
-  });
-
-  // src/services/importTracker.ts
-  function createImportTracker(sourceFiles, sourceFilesSet, checker, cancellationToken) {
-    const allDirectImports = getDirectImportsMap(sourceFiles, checker, cancellationToken);
-    return (exportSymbol, exportInfo, isForRename) => {
-      const { directImports, indirectUsers } = getImportersForExport(sourceFiles, sourceFilesSet, allDirectImports, exportInfo, checker, cancellationToken);
-      return { indirectUsers, ...getSearchesFromDirectImports(directImports, exportSymbol, exportInfo.exportKind, checker, isForRename) };
-    };
-  }
-  function getImportersForExport(sourceFiles, sourceFilesSet, allDirectImports, { exportingModuleSymbol, exportKind }, checker, cancellationToken) {
-    const markSeenDirectImport = nodeSeenTracker();
-    const markSeenIndirectUser = nodeSeenTracker();
-    const directImports = [];
-    const isAvailableThroughGlobal = !!exportingModuleSymbol.globalExports;
-    const indirectUserDeclarations = isAvailableThroughGlobal ? void 0 : [];
-    handleDirectImports(exportingModuleSymbol);
-    return { directImports, indirectUsers: getIndirectUsers() };
-    function getIndirectUsers() {
-      if (isAvailableThroughGlobal) {
-        return sourceFiles;
-      }
-      if (exportingModuleSymbol.declarations) {
-        for (const decl of exportingModuleSymbol.declarations) {
-          if (isExternalModuleAugmentation(decl) && sourceFilesSet.has(decl.getSourceFile().fileName)) {
-            addIndirectUser(decl);
-          }
-        }
-      }
-      return indirectUserDeclarations.map(getSourceFileOfNode);
-    }
-    function handleDirectImports(exportingModuleSymbol2) {
-      const theseDirectImports = getDirectImports(exportingModuleSymbol2);
-      if (theseDirectImports) {
-        for (const direct of theseDirectImports) {
-          if (!markSeenDirectImport(direct)) {
-            continue;
-          }
-          if (cancellationToken)
-            cancellationToken.throwIfCancellationRequested();
-          switch (direct.kind) {
-            case 212 /* CallExpression */:
-              if (isImportCall(direct)) {
-                handleImportCall(direct);
-                break;
-              }
-              if (!isAvailableThroughGlobal) {
-                const parent2 = direct.parent;
-                if (exportKind === 2 /* ExportEquals */ && parent2.kind === 259 /* VariableDeclaration */) {
-                  const { name } = parent2;
-                  if (name.kind === 80 /* Identifier */) {
-                    directImports.push(name);
-                    break;
-                  }
-                }
-              }
-              break;
-            case 80 /* Identifier */:
-              break;
-            case 270 /* ImportEqualsDeclaration */:
-              handleNamespaceImport(
-                direct,
-                direct.name,
-                hasSyntacticModifier(direct, 1 /* Export */),
-                /*alreadyAddedDirect*/
-                false
-              );
-              break;
-            case 271 /* ImportDeclaration */:
-              directImports.push(direct);
-              const namedBindings = direct.importClause && direct.importClause.namedBindings;
-              if (namedBindings && namedBindings.kind === 273 /* NamespaceImport */) {
-                handleNamespaceImport(
-                  direct,
-                  namedBindings.name,
-                  /*isReExport*/
-                  false,
-                  /*alreadyAddedDirect*/
-                  true
-                );
-              } else if (!isAvailableThroughGlobal && isDefaultImport(direct)) {
-                addIndirectUser(getSourceFileLikeForImportDeclaration(direct));
-              }
-              break;
-            case 277 /* ExportDeclaration */:
-              if (!direct.exportClause) {
-                handleDirectImports(getContainingModuleSymbol(direct, checker));
-              } else if (direct.exportClause.kind === 279 /* NamespaceExport */) {
-                addIndirectUser(
-                  getSourceFileLikeForImportDeclaration(direct),
-                  /*addTransitiveDependencies*/
-                  true
-                );
-              } else {
-                directImports.push(direct);
-              }
-              break;
-            case 204 /* ImportType */:
-              if (!isAvailableThroughGlobal && direct.isTypeOf && !direct.qualifier && isExported2(direct)) {
-                addIndirectUser(
-                  direct.getSourceFile(),
-                  /*addTransitiveDependencies*/
-                  true
-                );
-              }
-              directImports.push(direct);
-              break;
-            default:
-              Debug.failBadSyntaxKind(direct, "Unexpected import kind.");
-          }
-        }
-      }
-    }
-    function handleImportCall(importCall) {
-      const top = findAncestor(importCall, isAmbientModuleDeclaration) || importCall.getSourceFile();
-      addIndirectUser(
-        top,
-        /** addTransitiveDependencies */
-        !!isExported2(
-          importCall,
-          /*stopAtAmbientModule*/
-          true
-        )
-      );
-    }
-    function isExported2(node, stopAtAmbientModule = false) {
-      return findAncestor(node, (node2) => {
-        if (stopAtAmbientModule && isAmbientModuleDeclaration(node2))
-          return "quit";
-        return canHaveModifiers(node2) && some(node2.modifiers, isExportModifier);
-      });
-    }
-    function handleNamespaceImport(importDeclaration, name, isReExport, alreadyAddedDirect) {
-      if (exportKind === 2 /* ExportEquals */) {
-        if (!alreadyAddedDirect)
-          directImports.push(importDeclaration);
-      } else if (!isAvailableThroughGlobal) {
-        const sourceFileLike = getSourceFileLikeForImportDeclaration(importDeclaration);
-        Debug.assert(sourceFileLike.kind === 311 /* SourceFile */ || sourceFileLike.kind === 266 /* ModuleDeclaration */);
-        if (isReExport || findNamespaceReExports(sourceFileLike, name, checker)) {
-          addIndirectUser(
-            sourceFileLike,
-            /*addTransitiveDependencies*/
-            true
-          );
-        } else {
-          addIndirectUser(sourceFileLike);
-        }
-      }
-    }
-    function addIndirectUser(sourceFileLike, addTransitiveDependencies = false) {
-      Debug.assert(!isAvailableThroughGlobal);
-      const isNew = markSeenIndirectUser(sourceFileLike);
-      if (!isNew)
-        return;
-      indirectUserDeclarations.push(sourceFileLike);
-      if (!addTransitiveDependencies)
-        return;
-      const moduleSymbol = checker.getMergedSymbol(sourceFileLike.symbol);
-      if (!moduleSymbol)
-        return;
-      Debug.assert(!!(moduleSymbol.flags & 1536 /* Module */));
-      const directImports2 = getDirectImports(moduleSymbol);
-      if (directImports2) {
-        for (const directImport of directImports2) {
-          if (!isImportTypeNode(directImport)) {
-            addIndirectUser(
-              getSourceFileLikeForImportDeclaration(directImport),
-              /*addTransitiveDependencies*/
-              true
-            );
-          }
-        }
-      }
-    }
-    function getDirectImports(moduleSymbol) {
-      return allDirectImports.get(getSymbolId(moduleSymbol).toString());
-    }
-  }
-  function getSearchesFromDirectImports(directImports, exportSymbol, exportKind, checker, isForRename) {
-    const importSearches = [];
-    const singleReferences = [];
-    function addSearch(location, symbol) {
-      importSearches.push([location, symbol]);
-    }
-    if (directImports) {
-      for (const decl of directImports) {
-        handleImport(decl);
-      }
-    }
-    return { importSearches, singleReferences };
-    function handleImport(decl) {
-      if (decl.kind === 270 /* ImportEqualsDeclaration */) {
-        if (isExternalModuleImportEquals(decl)) {
-          handleNamespaceImportLike(decl.name);
-        }
-        return;
-      }
-      if (decl.kind === 80 /* Identifier */) {
-        handleNamespaceImportLike(decl);
-        return;
-      }
-      if (decl.kind === 204 /* ImportType */) {
-        if (decl.qualifier) {
-          const firstIdentifier = getFirstIdentifier(decl.qualifier);
-          if (firstIdentifier.escapedText === symbolName(exportSymbol)) {
-            singleReferences.push(firstIdentifier);
-          }
-        } else if (exportKind === 2 /* ExportEquals */) {
-          singleReferences.push(decl.argument.literal);
-        }
-        return;
-      }
-      if (decl.moduleSpecifier.kind !== 11 /* StringLiteral */) {
-        return;
-      }
-      if (decl.kind === 277 /* ExportDeclaration */) {
-        if (decl.exportClause && isNamedExports(decl.exportClause)) {
-          searchForNamedImport(decl.exportClause);
-        }
-        return;
-      }
-      const { name, namedBindings } = decl.importClause || { name: void 0, namedBindings: void 0 };
-      if (namedBindings) {
-        switch (namedBindings.kind) {
-          case 273 /* NamespaceImport */:
-            handleNamespaceImportLike(namedBindings.name);
-            break;
-          case 274 /* NamedImports */:
-            if (exportKind === 0 /* Named */ || exportKind === 1 /* Default */) {
-              searchForNamedImport(namedBindings);
-            }
-            break;
-          default:
-            Debug.assertNever(namedBindings);
-        }
-      }
-      if (name && (exportKind === 1 /* Default */ || exportKind === 2 /* ExportEquals */) && (!isForRename || name.escapedText === symbolEscapedNameNoDefault(exportSymbol))) {
-        const defaultImportAlias = checker.getSymbolAtLocation(name);
-        addSearch(name, defaultImportAlias);
-      }
-    }
-    function handleNamespaceImportLike(importName) {
-      if (exportKind === 2 /* ExportEquals */ && (!isForRename || isNameMatch(importName.escapedText))) {
-        addSearch(importName, checker.getSymbolAtLocation(importName));
-      }
-    }
-    function searchForNamedImport(namedBindings) {
-      if (!namedBindings) {
-        return;
-      }
-      for (const element of namedBindings.elements) {
-        const { name, propertyName } = element;
-        if (!isNameMatch((propertyName || name).escapedText)) {
-          continue;
-        }
-        if (propertyName) {
-          singleReferences.push(propertyName);
-          if (!isForRename || name.escapedText === exportSymbol.escapedName) {
-            addSearch(name, checker.getSymbolAtLocation(name));
-          }
-        } else {
-          const localSymbol = element.kind === 280 /* ExportSpecifier */ && element.propertyName ? checker.getExportSpecifierLocalTargetSymbol(element) : checker.getSymbolAtLocation(name);
-          addSearch(name, localSymbol);
-        }
-      }
-    }
-    function isNameMatch(name) {
-      return name === exportSymbol.escapedName || exportKind !== 0 /* Named */ && name === "default" /* Default */;
-    }
-  }
-  function findNamespaceReExports(sourceFileLike, name, checker) {
-    const namespaceImportSymbol = checker.getSymbolAtLocation(name);
-    return !!forEachPossibleImportOrExportStatement(sourceFileLike, (statement) => {
-      if (!isExportDeclaration(statement))
-        return;
-      const { exportClause, moduleSpecifier } = statement;
-      return !moduleSpecifier && exportClause && isNamedExports(exportClause) && exportClause.elements.some((element) => checker.getExportSpecifierLocalTargetSymbol(element) === namespaceImportSymbol);
-    });
-  }
-  function findModuleReferences(program, sourceFiles, searchModuleSymbol) {
-    var _a;
-    const refs = [];
-    const checker = program.getTypeChecker();
-    for (const referencingFile of sourceFiles) {
-      const searchSourceFile = searchModuleSymbol.valueDeclaration;
-      if ((searchSourceFile == null ? void 0 : searchSourceFile.kind) === 311 /* SourceFile */) {
-        for (const ref of referencingFile.referencedFiles) {
-          if (program.getSourceFileFromReference(referencingFile, ref) === searchSourceFile) {
-            refs.push({ kind: "reference", referencingFile, ref });
-          }
-        }
-        for (const ref of referencingFile.typeReferenceDirectives) {
-          const referenced = (_a = program.getResolvedTypeReferenceDirectives().get(ref.fileName, ref.resolutionMode || referencingFile.impliedNodeFormat)) == null ? void 0 : _a.resolvedTypeReferenceDirective;
-          if (referenced !== void 0 && referenced.resolvedFileName === searchSourceFile.fileName) {
-            refs.push({ kind: "reference", referencingFile, ref });
-          }
-        }
-      }
-      forEachImport(referencingFile, (importDecl, moduleSpecifier) => {
-        const moduleSymbol = checker.getSymbolAtLocation(moduleSpecifier);
-        if (moduleSymbol === searchModuleSymbol) {
-          refs.push(nodeIsSynthesized(importDecl) ? { kind: "implicit", literal: moduleSpecifier, referencingFile } : { kind: "import", literal: moduleSpecifier });
-        }
-      });
-    }
-    return refs;
-  }
-  function getDirectImportsMap(sourceFiles, checker, cancellationToken) {
-    const map2 = /* @__PURE__ */ new Map();
-    for (const sourceFile of sourceFiles) {
-      if (cancellationToken)
-        cancellationToken.throwIfCancellationRequested();
-      forEachImport(sourceFile, (importDecl, moduleSpecifier) => {
-        const moduleSymbol = checker.getSymbolAtLocation(moduleSpecifier);
-        if (moduleSymbol) {
-          const id = getSymbolId(moduleSymbol).toString();
-          let imports = map2.get(id);
-          if (!imports) {
-            map2.set(id, imports = []);
-          }
-          imports.push(importDecl);
-        }
-      });
-    }
-    return map2;
-  }
-  function forEachPossibleImportOrExportStatement(sourceFileLike, action) {
-    return forEach(sourceFileLike.kind === 311 /* SourceFile */ ? sourceFileLike.statements : sourceFileLike.body.statements, (statement) => (
-      // TODO: GH#18217
-      action(statement) || isAmbientModuleDeclaration(statement) && forEach(statement.body && statement.body.statements, action)
-    ));
-  }
-  function forEachImport(sourceFile, action) {
-    if (sourceFile.externalModuleIndicator || sourceFile.imports !== void 0) {
-      for (const i of sourceFile.imports) {
-        action(importFromModuleSpecifier(i), i);
-      }
-    } else {
-      forEachPossibleImportOrExportStatement(sourceFile, (statement) => {
-        switch (statement.kind) {
-          case 277 /* ExportDeclaration */:
-          case 271 /* ImportDeclaration */: {
-            const decl = statement;
-            if (decl.moduleSpecifier && isStringLiteral(decl.moduleSpecifier)) {
-              action(decl, decl.moduleSpecifier);
-            }
-            break;
-          }
-          case 270 /* ImportEqualsDeclaration */: {
-            const decl = statement;
-            if (isExternalModuleImportEquals(decl)) {
-              action(decl, decl.moduleReference.expression);
-            }
-            break;
-          }
-        }
-      });
-    }
-  }
-  function getImportOrExportSymbol(node, symbol, checker, comingFromExport) {
-    return comingFromExport ? getExport() : getExport() || getImport();
-    function getExport() {
-      var _a;
-      const { parent: parent2 } = node;
-      const grandparent = parent2.parent;
-      if (symbol.exportSymbol) {
-        if (parent2.kind === 210 /* PropertyAccessExpression */) {
-          return ((_a = symbol.declarations) == null ? void 0 : _a.some((d) => d === parent2)) && isBinaryExpression(grandparent) ? getSpecialPropertyExport(
-            grandparent,
-            /*useLhsSymbol*/
-            false
-          ) : void 0;
-        } else {
-          return exportInfo(symbol.exportSymbol, getExportKindForDeclaration(parent2));
-        }
-      } else {
-        const exportNode = getExportNode(parent2, node);
-        if (exportNode && hasSyntacticModifier(exportNode, 1 /* Export */)) {
-          if (isImportEqualsDeclaration(exportNode) && exportNode.moduleReference === node) {
-            if (comingFromExport) {
-              return void 0;
-            }
-            const lhsSymbol = checker.getSymbolAtLocation(exportNode.name);
-            return { kind: 0 /* Import */, symbol: lhsSymbol };
-          } else {
-            return exportInfo(symbol, getExportKindForDeclaration(exportNode));
-          }
-        } else if (isNamespaceExport(parent2)) {
-          return exportInfo(symbol, 0 /* Named */);
-        } else if (isExportAssignment(parent2)) {
-          return getExportAssignmentExport(parent2);
-        } else if (isExportAssignment(grandparent)) {
-          return getExportAssignmentExport(grandparent);
-        } else if (isBinaryExpression(parent2)) {
-          return getSpecialPropertyExport(
-            parent2,
-            /*useLhsSymbol*/
-            true
-          );
-        } else if (isBinaryExpression(grandparent)) {
-          return getSpecialPropertyExport(
-            grandparent,
-            /*useLhsSymbol*/
-            true
-          );
-        } else if (isJSDocTypedefTag(parent2) || isJSDocCallbackTag(parent2)) {
-          return exportInfo(symbol, 0 /* Named */);
-        }
-      }
-      function getExportAssignmentExport(ex) {
-        if (!ex.symbol.parent)
-          return void 0;
-        const exportKind = ex.isExportEquals ? 2 /* ExportEquals */ : 1 /* Default */;
-        return { kind: 1 /* Export */, symbol, exportInfo: { exportingModuleSymbol: ex.symbol.parent, exportKind } };
-      }
-      function getSpecialPropertyExport(node2, useLhsSymbol) {
-        let kind;
-        switch (getAssignmentDeclarationKind(node2)) {
-          case 1 /* ExportsProperty */:
-            kind = 0 /* Named */;
-            break;
-          case 2 /* ModuleExports */:
-            kind = 2 /* ExportEquals */;
-            break;
-          default:
-            return void 0;
-        }
-        const sym = useLhsSymbol ? checker.getSymbolAtLocation(getNameOfAccessExpression(cast(node2.left, isAccessExpression))) : symbol;
-        return sym && exportInfo(sym, kind);
-      }
-    }
-    function getImport() {
-      const isImport3 = isNodeImport(node);
-      if (!isImport3)
-        return void 0;
-      let importedSymbol = checker.getImmediateAliasedSymbol(symbol);
-      if (!importedSymbol)
-        return void 0;
-      importedSymbol = skipExportSpecifierSymbol(importedSymbol, checker);
-      if (importedSymbol.escapedName === "export=") {
-        importedSymbol = getExportEqualsLocalSymbol(importedSymbol, checker);
-        if (importedSymbol === void 0)
-          return void 0;
-      }
-      const importedName = symbolEscapedNameNoDefault(importedSymbol);
-      if (importedName === void 0 || importedName === "default" /* Default */ || importedName === symbol.escapedName) {
-        return { kind: 0 /* Import */, symbol: importedSymbol };
-      }
-    }
-    function exportInfo(symbol2, kind) {
-      const exportInfo2 = getExportInfo(symbol2, kind, checker);
-      return exportInfo2 && { kind: 1 /* Export */, symbol: symbol2, exportInfo: exportInfo2 };
-    }
-    function getExportKindForDeclaration(node2) {
-      return hasSyntacticModifier(node2, 1024 /* Default */) ? 1 /* Default */ : 0 /* Named */;
-    }
-  }
-  function getExportEqualsLocalSymbol(importedSymbol, checker) {
-    var _a, _b;
-    if (importedSymbol.flags & 2097152 /* Alias */) {
-      return checker.getImmediateAliasedSymbol(importedSymbol);
-    }
-    const decl = Debug.checkDefined(importedSymbol.valueDeclaration);
-    if (isExportAssignment(decl)) {
-      return (_a = tryCast(decl.expression, canHaveSymbol)) == null ? void 0 : _a.symbol;
-    } else if (isBinaryExpression(decl)) {
-      return (_b = tryCast(decl.right, canHaveSymbol)) == null ? void 0 : _b.symbol;
-    } else if (isSourceFile(decl)) {
-      return decl.symbol;
-    }
-    return void 0;
-  }
-  function getExportNode(parent2, node) {
-    const declaration = isVariableDeclaration(parent2) ? parent2 : isBindingElement(parent2) ? walkUpBindingElementsAndPatterns(parent2) : void 0;
-    if (declaration) {
-      return parent2.name !== node ? void 0 : isCatchClause(declaration.parent) ? void 0 : isVariableStatement(declaration.parent.parent) ? declaration.parent.parent : void 0;
-    } else {
-      return parent2;
-    }
-  }
-  function isNodeImport(node) {
-    const { parent: parent2 } = node;
-    switch (parent2.kind) {
-      case 270 /* ImportEqualsDeclaration */:
-        return parent2.name === node && isExternalModuleImportEquals(parent2);
-      case 275 /* ImportSpecifier */:
-        return !parent2.propertyName;
-      case 272 /* ImportClause */:
-      case 273 /* NamespaceImport */:
-        Debug.assert(parent2.name === node);
-        return true;
-      case 207 /* BindingElement */:
-        return isInJSFile(node) && isVariableDeclarationInitializedToBareOrAccessedRequire(parent2.parent.parent);
-      default:
-        return false;
-    }
-  }
-  function getExportInfo(exportSymbol, exportKind, checker) {
-    const moduleSymbol = exportSymbol.parent;
-    if (!moduleSymbol)
-      return void 0;
-    const exportingModuleSymbol = checker.getMergedSymbol(moduleSymbol);
-    return isExternalModuleSymbol(exportingModuleSymbol) ? { exportingModuleSymbol, exportKind } : void 0;
-  }
-  function skipExportSpecifierSymbol(symbol, checker) {
-    if (symbol.declarations) {
-      for (const declaration of symbol.declarations) {
-        if (isExportSpecifier(declaration) && !declaration.propertyName && !declaration.parent.parent.moduleSpecifier) {
-          return checker.getExportSpecifierLocalTargetSymbol(declaration) || symbol;
-        } else if (isPropertyAccessExpression(declaration) && isModuleExportsAccessExpression(declaration.expression) && !isPrivateIdentifier(declaration.name)) {
-          return checker.getSymbolAtLocation(declaration);
-        } else if (isShorthandPropertyAssignment(declaration) && isBinaryExpression(declaration.parent.parent) && getAssignmentDeclarationKind(declaration.parent.parent) === 2 /* ModuleExports */) {
-          return checker.getExportSpecifierLocalTargetSymbol(declaration.name);
-        }
-      }
-    }
-    return symbol;
-  }
-  function getContainingModuleSymbol(importer, checker) {
-    return checker.getMergedSymbol(getSourceFileLikeForImportDeclaration(importer).symbol);
-  }
-  function getSourceFileLikeForImportDeclaration(node) {
-    if (node.kind === 212 /* CallExpression */) {
-      return node.getSourceFile();
-    }
-    const { parent: parent2 } = node;
-    if (parent2.kind === 311 /* SourceFile */) {
-      return parent2;
-    }
-    Debug.assert(parent2.kind === 267 /* ModuleBlock */);
-    return cast(parent2.parent, isAmbientModuleDeclaration);
-  }
-  function isAmbientModuleDeclaration(node) {
-    return node.kind === 266 /* ModuleDeclaration */ && node.name.kind === 11 /* StringLiteral */;
-  }
-  function isExternalModuleImportEquals(eq) {
-    return eq.moduleReference.kind === 282 /* ExternalModuleReference */ && eq.moduleReference.expression.kind === 11 /* StringLiteral */;
-  }
-  var ExportKind2, ImportExport;
-  var init_importTracker = __esm({
-    "src/services/importTracker.ts"() {
-      "use strict";
-      init_ts4();
-      ExportKind2 = /* @__PURE__ */ ((ExportKind3) => {
-        ExportKind3[ExportKind3["Named"] = 0] = "Named";
-        ExportKind3[ExportKind3["Default"] = 1] = "Default";
-        ExportKind3[ExportKind3["ExportEquals"] = 2] = "ExportEquals";
-        return ExportKind3;
-      })(ExportKind2 || {});
-      ImportExport = /* @__PURE__ */ ((ImportExport2) => {
-        ImportExport2[ImportExport2["Import"] = 0] = "Import";
-        ImportExport2[ImportExport2["Export"] = 1] = "Export";
-        return ImportExport2;
-      })(ImportExport || {});
-    }
-  });
-
-  // src/services/findAllReferences.ts
-  function nodeEntry(node, kind = 1 /* Node */) {
-    return {
-      kind,
-      node: node.name || node,
-      context: getContextNodeForNodeEntry(node)
-    };
-  }
-  function isContextWithStartAndEndNode(node) {
-    return node && node.kind === void 0;
-  }
-  function getContextNodeForNodeEntry(node) {
-    if (isDeclaration(node)) {
-      return getContextNode(node);
-    }
-    if (!node.parent)
-      return void 0;
-    if (!isDeclaration(node.parent) && !isExportAssignment(node.parent)) {
-      if (isInJSFile(node)) {
-        const binaryExpression = isBinaryExpression(node.parent) ? node.parent : isAccessExpression(node.parent) && isBinaryExpression(node.parent.parent) && node.parent.parent.left === node.parent ? node.parent.parent : void 0;
-        if (binaryExpression && getAssignmentDeclarationKind(binaryExpression) !== 0 /* None */) {
-          return getContextNode(binaryExpression);
-        }
-      }
-      if (isJsxOpeningElement(node.parent) || isJsxClosingElement(node.parent)) {
-        return node.parent.parent;
-      } else if (isJsxSelfClosingElement(node.parent) || isLabeledStatement(node.parent) || isBreakOrContinueStatement(node.parent)) {
-        return node.parent;
-      } else if (isStringLiteralLike(node)) {
-        const validImport = tryGetImportFromModuleSpecifier(node);
-        if (validImport) {
-          const declOrStatement = findAncestor(
-            validImport,
-            (node2) => isDeclaration(node2) || isStatement(node2) || isJSDocTag(node2)
-          );
-          return isDeclaration(declOrStatement) ? getContextNode(declOrStatement) : declOrStatement;
-        }
-      }
-      const propertyName = findAncestor(node, isComputedPropertyName);
-      return propertyName ? getContextNode(propertyName.parent) : void 0;
-    }
-    if (node.parent.name === node || // node is name of declaration, use parent
-    isConstructorDeclaration(node.parent) || isExportAssignment(node.parent) || // Property name of the import export specifier or binding pattern, use parent
-    (isImportOrExportSpecifier(node.parent) || isBindingElement(node.parent)) && node.parent.propertyName === node || // Is default export
-    node.kind === 90 /* DefaultKeyword */ && hasSyntacticModifier(node.parent, 1025 /* ExportDefault */)) {
-      return getContextNode(node.parent);
-    }
-    return void 0;
-  }
-  function getContextNode(node) {
-    if (!node)
-      return void 0;
-    switch (node.kind) {
-      case 259 /* VariableDeclaration */:
-        return !isVariableDeclarationList(node.parent) || node.parent.declarations.length !== 1 ? node : isVariableStatement(node.parent.parent) ? node.parent.parent : isForInOrOfStatement(node.parent.parent) ? getContextNode(node.parent.parent) : node.parent;
-      case 207 /* BindingElement */:
-        return getContextNode(node.parent.parent);
-      case 275 /* ImportSpecifier */:
-        return node.parent.parent.parent;
-      case 280 /* ExportSpecifier */:
-      case 273 /* NamespaceImport */:
-        return node.parent.parent;
-      case 272 /* ImportClause */:
-      case 279 /* NamespaceExport */:
-        return node.parent;
-      case 225 /* BinaryExpression */:
-        return isExpressionStatement(node.parent) ? node.parent : node;
-      case 249 /* ForOfStatement */:
-      case 248 /* ForInStatement */:
-        return {
-          start: node.initializer,
-          end: node.expression
-        };
-      case 302 /* PropertyAssignment */:
-      case 303 /* ShorthandPropertyAssignment */:
-        return isArrayLiteralOrObjectLiteralDestructuringPattern(node.parent) ? getContextNode(
-          findAncestor(
-            node.parent,
-            (node2) => isBinaryExpression(node2) || isForInOrOfStatement(node2)
-          )
-        ) : node;
-      default:
-        return node;
-    }
-  }
-  function toContextSpan(textSpan, sourceFile, context) {
-    if (!context)
-      return void 0;
-    const contextSpan = isContextWithStartAndEndNode(context) ? getTextSpan(context.start, sourceFile, context.end) : getTextSpan(context, sourceFile);
-    return contextSpan.start !== textSpan.start || contextSpan.length !== textSpan.length ? { contextSpan } : void 0;
-  }
-  function findReferencedSymbols(program, cancellationToken, sourceFiles, sourceFile, position) {
-    const node = getTouchingPropertyName(sourceFile, position);
-    const options = { use: 1 /* References */ };
-    const referencedSymbols = Core.getReferencedSymbolsForNode(position, node, program, sourceFiles, cancellationToken, options);
-    const checker = program.getTypeChecker();
-    const adjustedNode = Core.getAdjustedNode(node, options);
-    const symbol = isDefinitionForReference(adjustedNode) ? checker.getSymbolAtLocation(adjustedNode) : void 0;
-    return !referencedSymbols || !referencedSymbols.length ? void 0 : mapDefined(referencedSymbols, ({ definition, references }) => (
-      // Only include referenced symbols that have a valid definition.
-      definition && {
-        definition: checker.runWithCancellationToken(cancellationToken, (checker2) => definitionToReferencedSymbolDefinitionInfo(definition, checker2, node)),
-        references: references.map((r) => toReferencedSymbolEntry(r, symbol))
-      }
-    ));
-  }
-  function isDefinitionForReference(node) {
-    return node.kind === 90 /* DefaultKeyword */ || !!getDeclarationFromName(node) || isLiteralComputedPropertyDeclarationName(node) || node.kind === 137 /* ConstructorKeyword */ && isConstructorDeclaration(node.parent);
-  }
-  function getImplementationsAtPosition(program, cancellationToken, sourceFiles, sourceFile, position) {
-    const node = getTouchingPropertyName(sourceFile, position);
-    let referenceEntries;
-    const entries = getImplementationReferenceEntries(program, cancellationToken, sourceFiles, node, position);
-    if (node.parent.kind === 210 /* PropertyAccessExpression */ || node.parent.kind === 207 /* BindingElement */ || node.parent.kind === 211 /* ElementAccessExpression */ || node.kind === 108 /* SuperKeyword */) {
-      referenceEntries = entries && [...entries];
-    } else if (entries) {
-      const queue = createQueue(entries);
-      const seenNodes = /* @__PURE__ */ new Map();
-      while (!queue.isEmpty()) {
-        const entry = queue.dequeue();
-        if (!addToSeen(seenNodes, getNodeId(entry.node))) {
-          continue;
-        }
-        referenceEntries = append(referenceEntries, entry);
-        const entries2 = getImplementationReferenceEntries(program, cancellationToken, sourceFiles, entry.node, entry.node.pos);
-        if (entries2) {
-          queue.enqueue(...entries2);
-        }
-      }
-    }
-    const checker = program.getTypeChecker();
-    return map(referenceEntries, (entry) => toImplementationLocation(entry, checker));
-  }
-  function getImplementationReferenceEntries(program, cancellationToken, sourceFiles, node, position) {
-    if (node.kind === 311 /* SourceFile */) {
-      return void 0;
-    }
-    const checker = program.getTypeChecker();
-    if (node.parent.kind === 303 /* ShorthandPropertyAssignment */) {
-      const result = [];
-      Core.getReferenceEntriesForShorthandPropertyAssignment(node, checker, (node2) => result.push(nodeEntry(node2)));
-      return result;
-    } else if (node.kind === 108 /* SuperKeyword */ || isSuperProperty(node.parent)) {
-      const symbol = checker.getSymbolAtLocation(node);
-      return symbol.valueDeclaration && [nodeEntry(symbol.valueDeclaration)];
-    } else {
-      return getReferenceEntriesForNode(position, node, program, sourceFiles, cancellationToken, { implementations: true, use: 1 /* References */ });
-    }
-  }
-  function findReferenceOrRenameEntries(program, cancellationToken, sourceFiles, node, position, options, convertEntry) {
-    return map(flattenEntries(Core.getReferencedSymbolsForNode(position, node, program, sourceFiles, cancellationToken, options)), (entry) => convertEntry(entry, node, program.getTypeChecker()));
-  }
-  function getReferenceEntriesForNode(position, node, program, sourceFiles, cancellationToken, options = {}, sourceFilesSet = new Set(sourceFiles.map((f) => f.fileName))) {
-    return flattenEntries(Core.getReferencedSymbolsForNode(position, node, program, sourceFiles, cancellationToken, options, sourceFilesSet));
-  }
-  function flattenEntries(referenceSymbols) {
-    return referenceSymbols && flatMap(referenceSymbols, (r) => r.references);
-  }
-  function definitionToReferencedSymbolDefinitionInfo(def, checker, originalNode) {
-    const info = (() => {
-      switch (def.type) {
-        case 0 /* Symbol */: {
-          const { symbol } = def;
-          const { displayParts: displayParts2, kind: kind2 } = getDefinitionKindAndDisplayParts(symbol, checker, originalNode);
-          const name2 = displayParts2.map((p) => p.text).join("");
-          const declaration = symbol.declarations && firstOrUndefined(symbol.declarations);
-          const node = declaration ? getNameOfDeclaration(declaration) || declaration : originalNode;
-          return {
-            ...getFileAndTextSpanFromNode(node),
-            name: name2,
-            kind: kind2,
-            displayParts: displayParts2,
-            context: getContextNode(declaration)
-          };
-        }
-        case 1 /* Label */: {
-          const { node } = def;
-          return { ...getFileAndTextSpanFromNode(node), name: node.text, kind: "label" /* label */, displayParts: [displayPart(node.text, 17 /* text */)] };
-        }
-        case 2 /* Keyword */: {
-          const { node } = def;
-          const name2 = tokenToString(node.kind);
-          return { ...getFileAndTextSpanFromNode(node), name: name2, kind: "keyword" /* keyword */, displayParts: [{ text: name2, kind: "keyword" /* keyword */ }] };
-        }
-        case 3 /* This */: {
-          const { node } = def;
-          const symbol = checker.getSymbolAtLocation(node);
-          const displayParts2 = symbol && ts_SymbolDisplay_exports.getSymbolDisplayPartsDocumentationAndSymbolKind(
-            checker,
-            symbol,
-            node.getSourceFile(),
-            getContainerNode(node),
-            node
-          ).displayParts || [textPart("this")];
-          return { ...getFileAndTextSpanFromNode(node), name: "this", kind: "var" /* variableElement */, displayParts: displayParts2 };
-        }
-        case 4 /* String */: {
-          const { node } = def;
-          return {
-            ...getFileAndTextSpanFromNode(node),
-            name: node.text,
-            kind: "var" /* variableElement */,
-            displayParts: [displayPart(getTextOfNode(node), 8 /* stringLiteral */)]
-          };
-        }
-        case 5 /* TripleSlashReference */: {
-          return {
-            textSpan: createTextSpanFromRange(def.reference),
-            sourceFile: def.file,
-            name: def.reference.fileName,
-            kind: "string" /* string */,
-            displayParts: [displayPart(`"${def.reference.fileName}"`, 8 /* stringLiteral */)]
-          };
-        }
-        default:
-          return Debug.assertNever(def);
-      }
-    })();
-    const { sourceFile, textSpan, name, kind, displayParts, context } = info;
-    return {
-      containerKind: "" /* unknown */,
-      containerName: "",
-      fileName: sourceFile.fileName,
-      kind,
-      name,
-      textSpan,
-      displayParts,
-      ...toContextSpan(textSpan, sourceFile, context)
-    };
-  }
-  function getFileAndTextSpanFromNode(node) {
-    const sourceFile = node.getSourceFile();
-    return {
-      sourceFile,
-      textSpan: getTextSpan(isComputedPropertyName(node) ? node.expression : node, sourceFile)
-    };
-  }
-  function getDefinitionKindAndDisplayParts(symbol, checker, node) {
-    const meaning = Core.getIntersectingMeaningFromDeclarations(node, symbol);
-    const enclosingDeclaration = symbol.declarations && firstOrUndefined(symbol.declarations) || node;
-    const { displayParts, symbolKind } = ts_SymbolDisplay_exports.getSymbolDisplayPartsDocumentationAndSymbolKind(checker, symbol, enclosingDeclaration.getSourceFile(), enclosingDeclaration, enclosingDeclaration, meaning);
-    return { displayParts, kind: symbolKind };
-  }
-  function toRenameLocation(entry, originalNode, checker, providePrefixAndSuffixText, quotePreference) {
-    return { ...entryToDocumentSpan(entry), ...providePrefixAndSuffixText && getPrefixAndSuffixText(entry, originalNode, checker, quotePreference) };
-  }
-  function toReferencedSymbolEntry(entry, symbol) {
-    const referenceEntry = toReferenceEntry(entry);
-    if (!symbol)
-      return referenceEntry;
-    return {
-      ...referenceEntry,
-      isDefinition: entry.kind !== 0 /* Span */ && isDeclarationOfSymbol(entry.node, symbol)
-    };
-  }
-  function toReferenceEntry(entry) {
-    const documentSpan = entryToDocumentSpan(entry);
-    if (entry.kind === 0 /* Span */) {
-      return { ...documentSpan, isWriteAccess: false };
-    }
-    const { kind, node } = entry;
-    return {
-      ...documentSpan,
-      isWriteAccess: isWriteAccessForReference(node),
-      isInString: kind === 2 /* StringLiteral */ ? true : void 0
-    };
-  }
-  function entryToDocumentSpan(entry) {
-    if (entry.kind === 0 /* Span */) {
-      return { textSpan: entry.textSpan, fileName: entry.fileName };
-    } else {
-      const sourceFile = entry.node.getSourceFile();
-      const textSpan = getTextSpan(entry.node, sourceFile);
-      return {
-        textSpan,
-        fileName: sourceFile.fileName,
-        ...toContextSpan(textSpan, sourceFile, entry.context)
-      };
-    }
-  }
-  function getPrefixAndSuffixText(entry, originalNode, checker, quotePreference) {
-    if (entry.kind !== 0 /* Span */ && isIdentifier(originalNode)) {
-      const { node, kind } = entry;
-      const parent2 = node.parent;
-      const name = originalNode.text;
-      const isShorthandAssignment = isShorthandPropertyAssignment(parent2);
-      if (isShorthandAssignment || isObjectBindingElementWithoutPropertyName(parent2) && parent2.name === node && parent2.dotDotDotToken === void 0) {
-        const prefixColon = { prefixText: name + ": " };
-        const suffixColon = { suffixText: ": " + name };
-        if (kind === 3 /* SearchedLocalFoundProperty */) {
-          return prefixColon;
-        }
-        if (kind === 4 /* SearchedPropertyFoundLocal */) {
-          return suffixColon;
-        }
-        if (isShorthandAssignment) {
-          const grandParent = parent2.parent;
-          if (isObjectLiteralExpression(grandParent) && isBinaryExpression(grandParent.parent) && isModuleExportsAccessExpression(grandParent.parent.left)) {
-            return prefixColon;
-          }
-          return suffixColon;
-        } else {
-          return prefixColon;
-        }
-      } else if (isImportSpecifier(parent2) && !parent2.propertyName) {
-        const originalSymbol = isExportSpecifier(originalNode.parent) ? checker.getExportSpecifierLocalTargetSymbol(originalNode.parent) : checker.getSymbolAtLocation(originalNode);
-        return contains(originalSymbol.declarations, parent2) ? { prefixText: name + " as " } : emptyOptions;
-      } else if (isExportSpecifier(parent2) && !parent2.propertyName) {
-        return originalNode === entry.node || checker.getSymbolAtLocation(originalNode) === checker.getSymbolAtLocation(entry.node) ? { prefixText: name + " as " } : { suffixText: " as " + name };
-      }
-    }
-    if (entry.kind !== 0 /* Span */ && isNumericLiteral(entry.node) && isAccessExpression(entry.node.parent)) {
-      const quote2 = getQuoteFromPreference(quotePreference);
-      return { prefixText: quote2, suffixText: quote2 };
-    }
-    return emptyOptions;
-  }
-  function toImplementationLocation(entry, checker) {
-    const documentSpan = entryToDocumentSpan(entry);
-    if (entry.kind !== 0 /* Span */) {
-      const { node } = entry;
-      return {
-        ...documentSpan,
-        ...implementationKindDisplayParts(node, checker)
-      };
-    } else {
-      return { ...documentSpan, kind: "" /* unknown */, displayParts: [] };
-    }
-  }
-  function implementationKindDisplayParts(node, checker) {
-    const symbol = checker.getSymbolAtLocation(isDeclaration(node) && node.name ? node.name : node);
-    if (symbol) {
-      return getDefinitionKindAndDisplayParts(symbol, checker, node);
-    } else if (node.kind === 209 /* ObjectLiteralExpression */) {
-      return {
-        kind: "interface" /* interfaceElement */,
-        displayParts: [punctuationPart(21 /* OpenParenToken */), textPart("object literal"), punctuationPart(22 /* CloseParenToken */)]
-      };
-    } else if (node.kind === 230 /* ClassExpression */) {
-      return {
-        kind: "local class" /* localClassElement */,
-        displayParts: [punctuationPart(21 /* OpenParenToken */), textPart("anonymous local class"), punctuationPart(22 /* CloseParenToken */)]
-      };
-    } else {
-      return { kind: getNodeKind(node), displayParts: [] };
-    }
-  }
-  function toHighlightSpan(entry) {
-    const documentSpan = entryToDocumentSpan(entry);
-    if (entry.kind === 0 /* Span */) {
-      return {
-        fileName: documentSpan.fileName,
-        span: {
-          textSpan: documentSpan.textSpan,
-          kind: "reference" /* reference */
-        }
-      };
-    }
-    const writeAccess = isWriteAccessForReference(entry.node);
-    const span = {
-      textSpan: documentSpan.textSpan,
-      kind: writeAccess ? "writtenReference" /* writtenReference */ : "reference" /* reference */,
-      isInString: entry.kind === 2 /* StringLiteral */ ? true : void 0,
-      ...documentSpan.contextSpan && { contextSpan: documentSpan.contextSpan }
-    };
-    return { fileName: documentSpan.fileName, span };
-  }
-  function getTextSpan(node, sourceFile, endNode2) {
-    let start = node.getStart(sourceFile);
-    let end = (endNode2 || node).getEnd();
-    if (isStringLiteralLike(node) && end - start > 2) {
-      Debug.assert(endNode2 === void 0);
-      start += 1;
-      end -= 1;
-    }
-    return createTextSpanFromBounds(start, end);
-  }
-  function getTextSpanOfEntry(entry) {
-    return entry.kind === 0 /* Span */ ? entry.textSpan : getTextSpan(entry.node, entry.node.getSourceFile());
-  }
-  function isWriteAccessForReference(node) {
-    const decl = getDeclarationFromName(node);
-    return !!decl && declarationIsWriteAccess(decl) || node.kind === 90 /* DefaultKeyword */ || isWriteAccess(node);
-  }
-  function isDeclarationOfSymbol(node, target) {
-    var _a;
-    if (!target)
-      return false;
-    const source = getDeclarationFromName(node) || (node.kind === 90 /* DefaultKeyword */ ? node.parent : isLiteralComputedPropertyDeclarationName(node) ? node.parent.parent : node.kind === 137 /* ConstructorKeyword */ && isConstructorDeclaration(node.parent) ? node.parent.parent : void 0);
-    const commonjsSource = source && isBinaryExpression(source) ? source.left : void 0;
-    return !!(source && ((_a = target.declarations) == null ? void 0 : _a.some((d) => d === source || d === commonjsSource)));
-  }
-  function declarationIsWriteAccess(decl) {
-    if (!!(decl.flags & 16777216 /* Ambient */))
-      return true;
-    switch (decl.kind) {
-      case 225 /* BinaryExpression */:
-      case 207 /* BindingElement */:
-      case 262 /* ClassDeclaration */:
-      case 230 /* ClassExpression */:
-      case 90 /* DefaultKeyword */:
-      case 265 /* EnumDeclaration */:
-      case 305 /* EnumMember */:
-      case 280 /* ExportSpecifier */:
-      case 272 /* ImportClause */:
-      case 270 /* ImportEqualsDeclaration */:
-      case 275 /* ImportSpecifier */:
-      case 263 /* InterfaceDeclaration */:
-      case 344 /* JSDocCallbackTag */:
-      case 352 /* JSDocTypedefTag */:
-      case 290 /* JsxAttribute */:
-      case 266 /* ModuleDeclaration */:
-      case 269 /* NamespaceExportDeclaration */:
-      case 273 /* NamespaceImport */:
-      case 279 /* NamespaceExport */:
-      case 168 /* Parameter */:
-      case 303 /* ShorthandPropertyAssignment */:
-      case 264 /* TypeAliasDeclaration */:
-      case 167 /* TypeParameter */:
-        return true;
-      case 302 /* PropertyAssignment */:
-        return !isArrayLiteralOrObjectLiteralDestructuringPattern(decl.parent);
-      case 261 /* FunctionDeclaration */:
-      case 217 /* FunctionExpression */:
-      case 175 /* Constructor */:
-      case 173 /* MethodDeclaration */:
-      case 176 /* GetAccessor */:
-      case 177 /* SetAccessor */:
-        return !!decl.body;
-      case 259 /* VariableDeclaration */:
-      case 171 /* PropertyDeclaration */:
-        return !!decl.initializer || isCatchClause(decl.parent);
-      case 172 /* MethodSignature */:
-      case 170 /* PropertySignature */:
-      case 354 /* JSDocPropertyTag */:
-      case 347 /* JSDocParameterTag */:
-        return false;
-      default:
-        return Debug.failBadSyntaxKind(decl);
-    }
-  }
-  var DefinitionKind, EntryKind, FindReferencesUse, Core;
-  var init_findAllReferences = __esm({
-    "src/services/findAllReferences.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_FindAllReferences();
-      DefinitionKind = /* @__PURE__ */ ((DefinitionKind2) => {
-        DefinitionKind2[DefinitionKind2["Symbol"] = 0] = "Symbol";
-        DefinitionKind2[DefinitionKind2["Label"] = 1] = "Label";
-        DefinitionKind2[DefinitionKind2["Keyword"] = 2] = "Keyword";
-        DefinitionKind2[DefinitionKind2["This"] = 3] = "This";
-        DefinitionKind2[DefinitionKind2["String"] = 4] = "String";
-        DefinitionKind2[DefinitionKind2["TripleSlashReference"] = 5] = "TripleSlashReference";
-        return DefinitionKind2;
-      })(DefinitionKind || {});
-      EntryKind = /* @__PURE__ */ ((EntryKind2) => {
-        EntryKind2[EntryKind2["Span"] = 0] = "Span";
-        EntryKind2[EntryKind2["Node"] = 1] = "Node";
-        EntryKind2[EntryKind2["StringLiteral"] = 2] = "StringLiteral";
-        EntryKind2[EntryKind2["SearchedLocalFoundProperty"] = 3] = "SearchedLocalFoundProperty";
-        EntryKind2[EntryKind2["SearchedPropertyFoundLocal"] = 4] = "SearchedPropertyFoundLocal";
-        return EntryKind2;
-      })(EntryKind || {});
-      FindReferencesUse = /* @__PURE__ */ ((FindReferencesUse2) => {
-        FindReferencesUse2[FindReferencesUse2["Other"] = 0] = "Other";
-        FindReferencesUse2[FindReferencesUse2["References"] = 1] = "References";
-        FindReferencesUse2[FindReferencesUse2["Rename"] = 2] = "Rename";
-        return FindReferencesUse2;
-      })(FindReferencesUse || {});
-      ((Core2) => {
-        function getReferencedSymbolsForNode(position, node, program, sourceFiles, cancellationToken, options = {}, sourceFilesSet = new Set(sourceFiles.map((f) => f.fileName))) {
-          var _a, _b, _c;
-          node = getAdjustedNode2(node, options);
-          if (isSourceFile(node)) {
-            const resolvedRef = ts_GoToDefinition_exports.getReferenceAtPosition(node, position, program);
-            if (!(resolvedRef == null ? void 0 : resolvedRef.file)) {
-              return void 0;
-            }
-            const moduleSymbol = program.getTypeChecker().getMergedSymbol(resolvedRef.file.symbol);
-            if (moduleSymbol) {
-              return getReferencedSymbolsForModule(
-                program,
-                moduleSymbol,
-                /*excludeImportTypeOfExportEquals*/
-                false,
-                sourceFiles,
-                sourceFilesSet
-              );
-            }
-            const fileIncludeReasons = program.getFileIncludeReasons();
-            if (!fileIncludeReasons) {
-              return void 0;
-            }
-            return [{
-              definition: { type: 5 /* TripleSlashReference */, reference: resolvedRef.reference, file: node },
-              references: getReferencesForNonModule(resolvedRef.file, fileIncludeReasons, program) || emptyArray
-            }];
-          }
-          if (!options.implementations) {
-            const special = getReferencedSymbolsSpecial(node, sourceFiles, cancellationToken);
-            if (special) {
-              return special;
-            }
-          }
-          const checker = program.getTypeChecker();
-          const symbol = checker.getSymbolAtLocation(isConstructorDeclaration(node) && node.parent.name || node);
-          if (!symbol) {
-            if (!options.implementations && isStringLiteralLike(node)) {
-              if (isModuleSpecifierLike(node)) {
-                const fileIncludeReasons = program.getFileIncludeReasons();
-                const referencedFileName = (_c = (_b = (_a = node.getSourceFile().resolvedModules) == null ? void 0 : _a.get(node.text, getModeForUsageLocation(node.getSourceFile(), node))) == null ? void 0 : _b.resolvedModule) == null ? void 0 : _c.resolvedFileName;
-                const referencedFile = referencedFileName ? program.getSourceFile(referencedFileName) : void 0;
-                if (referencedFile) {
-                  return [{ definition: { type: 4 /* String */, node }, references: getReferencesForNonModule(referencedFile, fileIncludeReasons, program) || emptyArray }];
-                }
-              }
-              return getReferencesForStringLiteral(node, sourceFiles, checker, cancellationToken);
-            }
-            return void 0;
-          }
-          if (symbol.escapedName === "export=" /* ExportEquals */) {
-            return getReferencedSymbolsForModule(
-              program,
-              symbol.parent,
-              /*excludeImportTypeOfExportEquals*/
-              false,
-              sourceFiles,
-              sourceFilesSet
-            );
-          }
-          const moduleReferences = getReferencedSymbolsForModuleIfDeclaredBySourceFile(symbol, program, sourceFiles, cancellationToken, options, sourceFilesSet);
-          if (moduleReferences && !(symbol.flags & 33554432 /* Transient */)) {
-            return moduleReferences;
-          }
-          const aliasedSymbol = getMergedAliasedSymbolOfNamespaceExportDeclaration(node, symbol, checker);
-          const moduleReferencesOfExportTarget = aliasedSymbol && getReferencedSymbolsForModuleIfDeclaredBySourceFile(aliasedSymbol, program, sourceFiles, cancellationToken, options, sourceFilesSet);
-          const references = getReferencedSymbolsForSymbol(symbol, node, sourceFiles, sourceFilesSet, checker, cancellationToken, options);
-          return mergeReferences(program, moduleReferences, references, moduleReferencesOfExportTarget);
-        }
-        Core2.getReferencedSymbolsForNode = getReferencedSymbolsForNode;
-        function getAdjustedNode2(node, options) {
-          if (options.use === 1 /* References */) {
-            node = getAdjustedReferenceLocation(node);
-          } else if (options.use === 2 /* Rename */) {
-            node = getAdjustedRenameLocation(node);
-          }
-          return node;
-        }
-        Core2.getAdjustedNode = getAdjustedNode2;
-        function getReferencesForFileName(fileName, program, sourceFiles, sourceFilesSet = new Set(sourceFiles.map((f) => f.fileName))) {
-          var _a, _b;
-          const moduleSymbol = (_a = program.getSourceFile(fileName)) == null ? void 0 : _a.symbol;
-          if (moduleSymbol) {
-            return ((_b = getReferencedSymbolsForModule(
-              program,
-              moduleSymbol,
-              /*excludeImportTypeOfExportEquals*/
-              false,
-              sourceFiles,
-              sourceFilesSet
-            )[0]) == null ? void 0 : _b.references) || emptyArray;
-          }
-          const fileIncludeReasons = program.getFileIncludeReasons();
-          const referencedFile = program.getSourceFile(fileName);
-          return referencedFile && fileIncludeReasons && getReferencesForNonModule(referencedFile, fileIncludeReasons, program) || emptyArray;
-        }
-        Core2.getReferencesForFileName = getReferencesForFileName;
-        function getReferencesForNonModule(referencedFile, refFileMap, program) {
-          let entries;
-          const references = refFileMap.get(referencedFile.path) || emptyArray;
-          for (const ref of references) {
-            if (isReferencedFile(ref)) {
-              const referencingFile = program.getSourceFileByPath(ref.file);
-              const location = getReferencedFileLocation(program.getSourceFileByPath, ref);
-              if (isReferenceFileLocation(location)) {
-                entries = append(entries, {
-                  kind: 0 /* Span */,
-                  fileName: referencingFile.fileName,
-                  textSpan: createTextSpanFromRange(location)
-                });
-              }
-            }
-          }
-          return entries;
-        }
-        function getMergedAliasedSymbolOfNamespaceExportDeclaration(node, symbol, checker) {
-          if (node.parent && isNamespaceExportDeclaration(node.parent)) {
-            const aliasedSymbol = checker.getAliasedSymbol(symbol);
-            const targetSymbol = checker.getMergedSymbol(aliasedSymbol);
-            if (aliasedSymbol !== targetSymbol) {
-              return targetSymbol;
-            }
-          }
-          return void 0;
-        }
-        function getReferencedSymbolsForModuleIfDeclaredBySourceFile(symbol, program, sourceFiles, cancellationToken, options, sourceFilesSet) {
-          const moduleSourceFile = symbol.flags & 1536 /* Module */ && symbol.declarations && find(symbol.declarations, isSourceFile);
-          if (!moduleSourceFile)
-            return void 0;
-          const exportEquals = symbol.exports.get("export=" /* ExportEquals */);
-          const moduleReferences = getReferencedSymbolsForModule(program, symbol, !!exportEquals, sourceFiles, sourceFilesSet);
-          if (!exportEquals || !sourceFilesSet.has(moduleSourceFile.fileName))
-            return moduleReferences;
-          const checker = program.getTypeChecker();
-          symbol = skipAlias(exportEquals, checker);
-          return mergeReferences(program, moduleReferences, getReferencedSymbolsForSymbol(
-            symbol,
-            /*node*/
-            void 0,
-            sourceFiles,
-            sourceFilesSet,
-            checker,
-            cancellationToken,
-            options
-          ));
-        }
-        function mergeReferences(program, ...referencesToMerge) {
-          let result;
-          for (const references of referencesToMerge) {
-            if (!references || !references.length)
-              continue;
-            if (!result) {
-              result = references;
-              continue;
-            }
-            for (const entry of references) {
-              if (!entry.definition || entry.definition.type !== 0 /* Symbol */) {
-                result.push(entry);
-                continue;
-              }
-              const symbol = entry.definition.symbol;
-              const refIndex = findIndex(result, (ref) => !!ref.definition && ref.definition.type === 0 /* Symbol */ && ref.definition.symbol === symbol);
-              if (refIndex === -1) {
-                result.push(entry);
-                continue;
-              }
-              const reference = result[refIndex];
-              result[refIndex] = {
-                definition: reference.definition,
-                references: reference.references.concat(entry.references).sort((entry1, entry2) => {
-                  const entry1File = getSourceFileIndexOfEntry(program, entry1);
-                  const entry2File = getSourceFileIndexOfEntry(program, entry2);
-                  if (entry1File !== entry2File) {
-                    return compareValues(entry1File, entry2File);
-                  }
-                  const entry1Span = getTextSpanOfEntry(entry1);
-                  const entry2Span = getTextSpanOfEntry(entry2);
-                  return entry1Span.start !== entry2Span.start ? compareValues(entry1Span.start, entry2Span.start) : compareValues(entry1Span.length, entry2Span.length);
-                })
-              };
-            }
-          }
-          return result;
-        }
-        function getSourceFileIndexOfEntry(program, entry) {
-          const sourceFile = entry.kind === 0 /* Span */ ? program.getSourceFile(entry.fileName) : entry.node.getSourceFile();
-          return program.getSourceFiles().indexOf(sourceFile);
-        }
-        function getReferencedSymbolsForModule(program, symbol, excludeImportTypeOfExportEquals, sourceFiles, sourceFilesSet) {
-          Debug.assert(!!symbol.valueDeclaration);
-          const references = mapDefined(findModuleReferences(program, sourceFiles, symbol), (reference) => {
-            if (reference.kind === "import") {
-              const parent2 = reference.literal.parent;
-              if (isLiteralTypeNode(parent2)) {
-                const importType = cast(parent2.parent, isImportTypeNode);
-                if (excludeImportTypeOfExportEquals && !importType.qualifier) {
-                  return void 0;
-                }
-              }
-              return nodeEntry(reference.literal);
-            } else if (reference.kind === "implicit") {
-              const range = reference.literal.text !== externalHelpersModuleNameText && forEachChildRecursively(
-                reference.referencingFile,
-                (n) => !(n.transformFlags & 2 /* ContainsJsx */) ? "skip" : isJsxElement(n) || isJsxSelfClosingElement(n) || isJsxFragment(n) ? n : void 0
-              ) || reference.referencingFile.statements[0] || reference.referencingFile;
-              return nodeEntry(range);
-            } else {
-              return {
-                kind: 0 /* Span */,
-                fileName: reference.referencingFile.fileName,
-                textSpan: createTextSpanFromRange(reference.ref)
-              };
-            }
-          });
-          if (symbol.declarations) {
-            for (const decl of symbol.declarations) {
-              switch (decl.kind) {
-                case 311 /* SourceFile */:
-                  break;
-                case 266 /* ModuleDeclaration */:
-                  if (sourceFilesSet.has(decl.getSourceFile().fileName)) {
-                    references.push(nodeEntry(decl.name));
-                  }
-                  break;
-                default:
-                  Debug.assert(!!(symbol.flags & 33554432 /* Transient */), "Expected a module symbol to be declared by a SourceFile or ModuleDeclaration.");
-              }
-            }
-          }
-          const exported = symbol.exports.get("export=" /* ExportEquals */);
-          if (exported == null ? void 0 : exported.declarations) {
-            for (const decl of exported.declarations) {
-              const sourceFile = decl.getSourceFile();
-              if (sourceFilesSet.has(sourceFile.fileName)) {
-                const node = isBinaryExpression(decl) && isPropertyAccessExpression(decl.left) ? decl.left.expression : isExportAssignment(decl) ? Debug.checkDefined(findChildOfKind(decl, 95 /* ExportKeyword */, sourceFile)) : getNameOfDeclaration(decl) || decl;
-                references.push(nodeEntry(node));
-              }
-            }
-          }
-          return references.length ? [{ definition: { type: 0 /* Symbol */, symbol }, references }] : emptyArray;
-        }
-        function isReadonlyTypeOperator(node) {
-          return node.kind === 148 /* ReadonlyKeyword */ && isTypeOperatorNode(node.parent) && node.parent.operator === 148 /* ReadonlyKeyword */;
-        }
-        function getReferencedSymbolsSpecial(node, sourceFiles, cancellationToken) {
-          if (isTypeKeyword(node.kind)) {
-            if (node.kind === 116 /* VoidKeyword */ && isVoidExpression(node.parent)) {
-              return void 0;
-            }
-            if (node.kind === 148 /* ReadonlyKeyword */ && !isReadonlyTypeOperator(node)) {
-              return void 0;
-            }
-            return getAllReferencesForKeyword(
-              sourceFiles,
-              node.kind,
-              cancellationToken,
-              node.kind === 148 /* ReadonlyKeyword */ ? isReadonlyTypeOperator : void 0
-            );
-          }
-          if (isImportMeta(node.parent) && node.parent.name === node) {
-            return getAllReferencesForImportMeta(sourceFiles, cancellationToken);
-          }
-          if (isStaticModifier(node) && isClassStaticBlockDeclaration(node.parent)) {
-            return [{ definition: { type: 2 /* Keyword */, node }, references: [nodeEntry(node)] }];
-          }
-          if (isJumpStatementTarget(node)) {
-            const labelDefinition = getTargetLabel(node.parent, node.text);
-            return labelDefinition && getLabelReferencesInNode(labelDefinition.parent, labelDefinition);
-          } else if (isLabelOfLabeledStatement(node)) {
-            return getLabelReferencesInNode(node.parent, node);
-          }
-          if (isThis(node)) {
-            return getReferencesForThisKeyword(node, sourceFiles, cancellationToken);
-          }
-          if (node.kind === 108 /* SuperKeyword */) {
-            return getReferencesForSuperKeyword(node);
-          }
-          return void 0;
-        }
-        function getReferencedSymbolsForSymbol(originalSymbol, node, sourceFiles, sourceFilesSet, checker, cancellationToken, options) {
-          const symbol = node && skipPastExportOrImportSpecifierOrUnion(
-            originalSymbol,
-            node,
-            checker,
-            /*useLocalSymbolForExportSpecifier*/
-            !isForRenameWithPrefixAndSuffixText(options)
-          ) || originalSymbol;
-          const searchMeaning = node ? getIntersectingMeaningFromDeclarations(node, symbol) : 7 /* All */;
-          const result = [];
-          const state = new State(sourceFiles, sourceFilesSet, node ? getSpecialSearchKind(node) : 0 /* None */, checker, cancellationToken, searchMeaning, options, result);
-          const exportSpecifier = !isForRenameWithPrefixAndSuffixText(options) || !symbol.declarations ? void 0 : find(symbol.declarations, isExportSpecifier);
-          if (exportSpecifier) {
-            getReferencesAtExportSpecifier(
-              exportSpecifier.name,
-              symbol,
-              exportSpecifier,
-              state.createSearch(
-                node,
-                originalSymbol,
-                /*comingFrom*/
-                void 0
-              ),
-              state,
-              /*addReferencesHere*/
-              true,
-              /*alwaysGetReferences*/
-              true
-            );
-          } else if (node && node.kind === 90 /* DefaultKeyword */ && symbol.escapedName === "default" /* Default */ && symbol.parent) {
-            addReference(node, symbol, state);
-            searchForImportsOfExport(node, symbol, { exportingModuleSymbol: symbol.parent, exportKind: 1 /* Default */ }, state);
-          } else {
-            const search = state.createSearch(
-              node,
-              symbol,
-              /*comingFrom*/
-              void 0,
-              { allSearchSymbols: node ? populateSearchSymbolSet(symbol, node, checker, options.use === 2 /* Rename */, !!options.providePrefixAndSuffixTextForRename, !!options.implementations) : [symbol] }
-            );
-            getReferencesInContainerOrFiles(symbol, state, search);
-          }
-          return result;
-        }
-        function getReferencesInContainerOrFiles(symbol, state, search) {
-          const scope = getSymbolScope(symbol);
-          if (scope) {
-            getReferencesInContainer(
-              scope,
-              scope.getSourceFile(),
-              search,
-              state,
-              /*addReferencesHere*/
-              !(isSourceFile(scope) && !contains(state.sourceFiles, scope))
-            );
-          } else {
-            for (const sourceFile of state.sourceFiles) {
-              state.cancellationToken.throwIfCancellationRequested();
-              searchForName(sourceFile, search, state);
-            }
-          }
-        }
-        function getSpecialSearchKind(node) {
-          switch (node.kind) {
-            case 175 /* Constructor */:
-            case 137 /* ConstructorKeyword */:
-              return 1 /* Constructor */;
-            case 80 /* Identifier */:
-              if (isClassLike(node.parent)) {
-                Debug.assert(node.parent.name === node);
-                return 2 /* Class */;
-              }
-            default:
-              return 0 /* None */;
-          }
-        }
-        function skipPastExportOrImportSpecifierOrUnion(symbol, node, checker, useLocalSymbolForExportSpecifier) {
-          const { parent: parent2 } = node;
-          if (isExportSpecifier(parent2) && useLocalSymbolForExportSpecifier) {
-            return getLocalSymbolForExportSpecifier(node, symbol, parent2, checker);
-          }
-          return firstDefined(symbol.declarations, (decl) => {
-            if (!decl.parent) {
-              if (symbol.flags & 33554432 /* Transient */)
-                return void 0;
-              Debug.fail(`Unexpected symbol at ${Debug.formatSyntaxKind(node.kind)}: ${Debug.formatSymbol(symbol)}`);
-            }
-            return isTypeLiteralNode(decl.parent) && isUnionTypeNode(decl.parent.parent) ? checker.getPropertyOfType(checker.getTypeFromTypeNode(decl.parent.parent), symbol.name) : void 0;
-          });
-        }
-        let SpecialSearchKind;
-        ((SpecialSearchKind2) => {
-          SpecialSearchKind2[SpecialSearchKind2["None"] = 0] = "None";
-          SpecialSearchKind2[SpecialSearchKind2["Constructor"] = 1] = "Constructor";
-          SpecialSearchKind2[SpecialSearchKind2["Class"] = 2] = "Class";
-        })(SpecialSearchKind || (SpecialSearchKind = {}));
-        function getNonModuleSymbolOfMergedModuleSymbol(symbol) {
-          if (!(symbol.flags & (1536 /* Module */ | 33554432 /* Transient */)))
-            return void 0;
-          const decl = symbol.declarations && find(symbol.declarations, (d) => !isSourceFile(d) && !isModuleDeclaration(d));
-          return decl && decl.symbol;
-        }
-        class State {
-          constructor(sourceFiles, sourceFilesSet, specialSearchKind, checker, cancellationToken, searchMeaning, options, result) {
-            this.sourceFiles = sourceFiles;
-            this.sourceFilesSet = sourceFilesSet;
-            this.specialSearchKind = specialSearchKind;
-            this.checker = checker;
-            this.cancellationToken = cancellationToken;
-            this.searchMeaning = searchMeaning;
-            this.options = options;
-            this.result = result;
-            /** Cache for `explicitlyinheritsFrom`. */
-            this.inheritsFromCache = /* @__PURE__ */ new Map();
-            /**
-             * Type nodes can contain multiple references to the same type. For example:
-             *      let x: Foo & (Foo & Bar) = ...
-             * Because we are returning the implementation locations and not the identifier locations,
-             * duplicate entries would be returned here as each of the type references is part of
-             * the same implementation. For that reason, check before we add a new entry.
-             */
-            this.markSeenContainingTypeReference = nodeSeenTracker();
-            /**
-             * It's possible that we will encounter the right side of `export { foo as bar } from "x";` more than once.
-             * For example:
-             *     // b.ts
-             *     export { foo as bar } from "./a";
-             *     import { bar } from "./b";
-             *
-             * Normally at `foo as bar` we directly add `foo` and do not locally search for it (since it doesn't declare a local).
-             * But another reference to it may appear in the same source file.
-             * See `tests/cases/fourslash/transitiveExportImports3.ts`.
-             */
-            this.markSeenReExportRHS = nodeSeenTracker();
-            this.symbolIdToReferences = [];
-            // Source file ID -> symbol ID -> Whether the symbol has been searched for in the source file.
-            this.sourceFileToSeenSymbols = [];
-          }
-          includesSourceFile(sourceFile) {
-            return this.sourceFilesSet.has(sourceFile.fileName);
-          }
-          /** Gets every place to look for references of an exported symbols. See `ImportsResult` in `importTracker.ts` for more documentation. */
-          getImportSearches(exportSymbol, exportInfo) {
-            if (!this.importTracker)
-              this.importTracker = createImportTracker(this.sourceFiles, this.sourceFilesSet, this.checker, this.cancellationToken);
-            return this.importTracker(exportSymbol, exportInfo, this.options.use === 2 /* Rename */);
-          }
-          /** @param allSearchSymbols set of additional symbols for use by `includes`. */
-          createSearch(location, symbol, comingFrom, searchOptions = {}) {
-            const {
-              text = stripQuotes(symbolName(getLocalSymbolForExportDefault(symbol) || getNonModuleSymbolOfMergedModuleSymbol(symbol) || symbol)),
-              allSearchSymbols = [symbol]
-            } = searchOptions;
-            const escapedText = escapeLeadingUnderscores(text);
-            const parents = this.options.implementations && location ? getParentSymbolsOfPropertyAccess(location, symbol, this.checker) : void 0;
-            return { symbol, comingFrom, text, escapedText, parents, allSearchSymbols, includes: (sym) => contains(allSearchSymbols, sym) };
-          }
-          /**
-           * Callback to add references for a particular searched symbol.
-           * This initializes a reference group, so only call this if you will add at least one reference.
-           */
-          referenceAdder(searchSymbol) {
-            const symbolId = getSymbolId(searchSymbol);
-            let references = this.symbolIdToReferences[symbolId];
-            if (!references) {
-              references = this.symbolIdToReferences[symbolId] = [];
-              this.result.push({ definition: { type: 0 /* Symbol */, symbol: searchSymbol }, references });
-            }
-            return (node, kind) => references.push(nodeEntry(node, kind));
-          }
-          /** Add a reference with no associated definition. */
-          addStringOrCommentReference(fileName, textSpan) {
-            this.result.push({
-              definition: void 0,
-              references: [{ kind: 0 /* Span */, fileName, textSpan }]
-            });
-          }
-          /** Returns `true` the first time we search for a symbol in a file and `false` afterwards. */
-          markSearchedSymbols(sourceFile, symbols) {
-            const sourceId = getNodeId(sourceFile);
-            const seenSymbols = this.sourceFileToSeenSymbols[sourceId] || (this.sourceFileToSeenSymbols[sourceId] = /* @__PURE__ */ new Set());
-            let anyNewSymbols = false;
-            for (const sym of symbols) {
-              anyNewSymbols = tryAddToSet(seenSymbols, getSymbolId(sym)) || anyNewSymbols;
-            }
-            return anyNewSymbols;
-          }
-        }
-        function searchForImportsOfExport(exportLocation, exportSymbol, exportInfo, state) {
-          const { importSearches, singleReferences, indirectUsers } = state.getImportSearches(exportSymbol, exportInfo);
-          if (singleReferences.length) {
-            const addRef = state.referenceAdder(exportSymbol);
-            for (const singleRef of singleReferences) {
-              if (shouldAddSingleReference(singleRef, state))
-                addRef(singleRef);
-            }
-          }
-          for (const [importLocation, importSymbol] of importSearches) {
-            getReferencesInSourceFile(importLocation.getSourceFile(), state.createSearch(importLocation, importSymbol, 1 /* Export */), state);
-          }
-          if (indirectUsers.length) {
-            let indirectSearch;
-            switch (exportInfo.exportKind) {
-              case 0 /* Named */:
-                indirectSearch = state.createSearch(exportLocation, exportSymbol, 1 /* Export */);
-                break;
-              case 1 /* Default */:
-                indirectSearch = state.options.use === 2 /* Rename */ ? void 0 : state.createSearch(exportLocation, exportSymbol, 1 /* Export */, { text: "default" });
-                break;
-              case 2 /* ExportEquals */:
-                break;
-            }
-            if (indirectSearch) {
-              for (const indirectUser of indirectUsers) {
-                searchForName(indirectUser, indirectSearch, state);
-              }
-            }
-          }
-        }
-        function eachExportReference(sourceFiles, checker, cancellationToken, exportSymbol, exportingModuleSymbol, exportName, isDefaultExport, cb) {
-          const importTracker = createImportTracker(sourceFiles, new Set(sourceFiles.map((f) => f.fileName)), checker, cancellationToken);
-          const { importSearches, indirectUsers, singleReferences } = importTracker(
-            exportSymbol,
-            { exportKind: isDefaultExport ? 1 /* Default */ : 0 /* Named */, exportingModuleSymbol },
-            /*isForRename*/
-            false
-          );
-          for (const [importLocation] of importSearches) {
-            cb(importLocation);
-          }
-          for (const singleReference of singleReferences) {
-            if (isIdentifier(singleReference) && isImportTypeNode(singleReference.parent)) {
-              cb(singleReference);
-            }
-          }
-          for (const indirectUser of indirectUsers) {
-            for (const node of getPossibleSymbolReferenceNodes(indirectUser, isDefaultExport ? "default" : exportName)) {
-              const symbol = checker.getSymbolAtLocation(node);
-              const hasExportAssignmentDeclaration = some(symbol == null ? void 0 : symbol.declarations, (d) => tryCast(d, isExportAssignment) ? true : false);
-              if (isIdentifier(node) && !isImportOrExportSpecifier(node.parent) && (symbol === exportSymbol || hasExportAssignmentDeclaration)) {
-                cb(node);
-              }
-            }
-          }
-        }
-        Core2.eachExportReference = eachExportReference;
-        function shouldAddSingleReference(singleRef, state) {
-          if (!hasMatchingMeaning(singleRef, state))
-            return false;
-          if (state.options.use !== 2 /* Rename */)
-            return true;
-          if (!isIdentifier(singleRef))
-            return false;
-          return !(isImportOrExportSpecifier(singleRef.parent) && singleRef.escapedText === "default" /* Default */);
-        }
-        function searchForImportedSymbol(symbol, state) {
-          if (!symbol.declarations)
-            return;
-          for (const declaration of symbol.declarations) {
-            const exportingFile = declaration.getSourceFile();
-            getReferencesInSourceFile(exportingFile, state.createSearch(declaration, symbol, 0 /* Import */), state, state.includesSourceFile(exportingFile));
-          }
-        }
-        function searchForName(sourceFile, search, state) {
-          if (getNameTable(sourceFile).get(search.escapedText) !== void 0) {
-            getReferencesInSourceFile(sourceFile, search, state);
-          }
-        }
-        function getPropertySymbolOfDestructuringAssignment(location, checker) {
-          return isArrayLiteralOrObjectLiteralDestructuringPattern(location.parent.parent) ? checker.getPropertySymbolOfDestructuringAssignment(location) : void 0;
-        }
-        function getSymbolScope(symbol) {
-          const { declarations, flags, parent: parent2, valueDeclaration } = symbol;
-          if (valueDeclaration && (valueDeclaration.kind === 217 /* FunctionExpression */ || valueDeclaration.kind === 230 /* ClassExpression */)) {
-            return valueDeclaration;
-          }
-          if (!declarations) {
-            return void 0;
-          }
-          if (flags & (4 /* Property */ | 8192 /* Method */)) {
-            const privateDeclaration = find(declarations, (d) => hasEffectiveModifier(d, 8 /* Private */) || isPrivateIdentifierClassElementDeclaration(d));
-            if (privateDeclaration) {
-              return getAncestor(privateDeclaration, 262 /* ClassDeclaration */);
-            }
-            return void 0;
-          }
-          if (declarations.some(isObjectBindingElementWithoutPropertyName)) {
-            return void 0;
-          }
-          const exposedByParent = parent2 && !(symbol.flags & 262144 /* TypeParameter */);
-          if (exposedByParent && !(isExternalModuleSymbol(parent2) && !parent2.globalExports)) {
-            return void 0;
-          }
-          let scope;
-          for (const declaration of declarations) {
-            const container = getContainerNode(declaration);
-            if (scope && scope !== container) {
-              return void 0;
-            }
-            if (!container || container.kind === 311 /* SourceFile */ && !isExternalOrCommonJsModule(container)) {
-              return void 0;
-            }
-            scope = container;
-            if (isFunctionExpression(scope)) {
-              let next;
-              while (next = getNextJSDocCommentLocation(scope)) {
-                scope = next;
-              }
-            }
-          }
-          return exposedByParent ? scope.getSourceFile() : scope;
-        }
-        function isSymbolReferencedInFile(definition, checker, sourceFile, searchContainer = sourceFile) {
-          return eachSymbolReferenceInFile(definition, checker, sourceFile, () => true, searchContainer) || false;
-        }
-        Core2.isSymbolReferencedInFile = isSymbolReferencedInFile;
-        function eachSymbolReferenceInFile(definition, checker, sourceFile, cb, searchContainer = sourceFile) {
-          const symbol = isParameterPropertyDeclaration(definition.parent, definition.parent.parent) ? first(checker.getSymbolsOfParameterPropertyDeclaration(definition.parent, definition.text)) : checker.getSymbolAtLocation(definition);
-          if (!symbol)
-            return void 0;
-          for (const token of getPossibleSymbolReferenceNodes(sourceFile, symbol.name, searchContainer)) {
-            if (!isIdentifier(token) || token === definition || token.escapedText !== definition.escapedText)
-              continue;
-            const referenceSymbol = checker.getSymbolAtLocation(token);
-            if (referenceSymbol === symbol || checker.getShorthandAssignmentValueSymbol(token.parent) === symbol || isExportSpecifier(token.parent) && getLocalSymbolForExportSpecifier(token, referenceSymbol, token.parent, checker) === symbol) {
-              const res = cb(token);
-              if (res)
-                return res;
-            }
-          }
-        }
-        Core2.eachSymbolReferenceInFile = eachSymbolReferenceInFile;
-        function getTopMostDeclarationNamesInFile(declarationName, sourceFile) {
-          const candidates = filter(getPossibleSymbolReferenceNodes(sourceFile, declarationName), (name) => !!getDeclarationFromName(name));
-          return candidates.reduce((topMost, decl) => {
-            const depth = getDepth(decl);
-            if (!some(topMost.declarationNames) || depth === topMost.depth) {
-              topMost.declarationNames.push(decl);
-              topMost.depth = depth;
-            } else if (depth < topMost.depth) {
-              topMost.declarationNames = [decl];
-              topMost.depth = depth;
-            }
-            return topMost;
-          }, { depth: Infinity, declarationNames: [] }).declarationNames;
-          function getDepth(declaration) {
-            let depth = 0;
-            while (declaration) {
-              declaration = getContainerNode(declaration);
-              depth++;
-            }
-            return depth;
-          }
-        }
-        Core2.getTopMostDeclarationNamesInFile = getTopMostDeclarationNamesInFile;
-        function someSignatureUsage(signature, sourceFiles, checker, cb) {
-          if (!signature.name || !isIdentifier(signature.name))
-            return false;
-          const symbol = Debug.checkDefined(checker.getSymbolAtLocation(signature.name));
-          for (const sourceFile of sourceFiles) {
-            for (const name of getPossibleSymbolReferenceNodes(sourceFile, symbol.name)) {
-              if (!isIdentifier(name) || name === signature.name || name.escapedText !== signature.name.escapedText)
-                continue;
-              const called = climbPastPropertyAccess(name);
-              const call = isCallExpression(called.parent) && called.parent.expression === called ? called.parent : void 0;
-              const referenceSymbol = checker.getSymbolAtLocation(name);
-              if (referenceSymbol && checker.getRootSymbols(referenceSymbol).some((s) => s === symbol)) {
-                if (cb(name, call)) {
-                  return true;
-                }
-              }
-            }
-          }
-          return false;
-        }
-        Core2.someSignatureUsage = someSignatureUsage;
-        function getPossibleSymbolReferenceNodes(sourceFile, symbolName2, container = sourceFile) {
-          return getPossibleSymbolReferencePositions(sourceFile, symbolName2, container).map((pos) => getTouchingPropertyName(sourceFile, pos));
-        }
-        function getPossibleSymbolReferencePositions(sourceFile, symbolName2, container = sourceFile) {
-          const positions = [];
-          if (!symbolName2 || !symbolName2.length) {
-            return positions;
-          }
-          const text = sourceFile.text;
-          const sourceLength = text.length;
-          const symbolNameLength = symbolName2.length;
-          let position = text.indexOf(symbolName2, container.pos);
-          while (position >= 0) {
-            if (position > container.end)
-              break;
-            const endPosition = position + symbolNameLength;
-            if ((position === 0 || !isIdentifierPart(text.charCodeAt(position - 1), 99 /* Latest */)) && (endPosition === sourceLength || !isIdentifierPart(text.charCodeAt(endPosition), 99 /* Latest */))) {
-              positions.push(position);
-            }
-            position = text.indexOf(symbolName2, position + symbolNameLength + 1);
-          }
-          return positions;
-        }
-        function getLabelReferencesInNode(container, targetLabel) {
-          const sourceFile = container.getSourceFile();
-          const labelName = targetLabel.text;
-          const references = mapDefined(getPossibleSymbolReferenceNodes(sourceFile, labelName, container), (node) => (
-            // Only pick labels that are either the target label, or have a target that is the target label
-            node === targetLabel || isJumpStatementTarget(node) && getTargetLabel(node, labelName) === targetLabel ? nodeEntry(node) : void 0
-          ));
-          return [{ definition: { type: 1 /* Label */, node: targetLabel }, references }];
-        }
-        function isValidReferencePosition(node, searchSymbolName) {
-          switch (node.kind) {
-            case 81 /* PrivateIdentifier */:
-              if (isJSDocMemberName(node.parent)) {
-                return true;
-              }
-            case 80 /* Identifier */:
-              return node.text.length === searchSymbolName.length;
-            case 15 /* NoSubstitutionTemplateLiteral */:
-            case 11 /* StringLiteral */: {
-              const str = node;
-              return (isLiteralNameOfPropertyDeclarationOrIndexAccess(str) || isNameOfModuleDeclaration(node) || isExpressionOfExternalModuleImportEqualsDeclaration(node) || isCallExpression(node.parent) && isBindableObjectDefinePropertyCall(node.parent) && node.parent.arguments[1] === node) && str.text.length === searchSymbolName.length;
-            }
-            case 9 /* NumericLiteral */:
-              return isLiteralNameOfPropertyDeclarationOrIndexAccess(node) && node.text.length === searchSymbolName.length;
-            case 90 /* DefaultKeyword */:
-              return "default".length === searchSymbolName.length;
-            default:
-              return false;
-          }
-        }
-        function getAllReferencesForImportMeta(sourceFiles, cancellationToken) {
-          const references = flatMap(sourceFiles, (sourceFile) => {
-            cancellationToken.throwIfCancellationRequested();
-            return mapDefined(getPossibleSymbolReferenceNodes(sourceFile, "meta", sourceFile), (node) => {
-              const parent2 = node.parent;
-              if (isImportMeta(parent2)) {
-                return nodeEntry(parent2);
-              }
-            });
-          });
-          return references.length ? [{ definition: { type: 2 /* Keyword */, node: references[0].node }, references }] : void 0;
-        }
-        function getAllReferencesForKeyword(sourceFiles, keywordKind, cancellationToken, filter2) {
-          const references = flatMap(sourceFiles, (sourceFile) => {
-            cancellationToken.throwIfCancellationRequested();
-            return mapDefined(getPossibleSymbolReferenceNodes(sourceFile, tokenToString(keywordKind), sourceFile), (referenceLocation) => {
-              if (referenceLocation.kind === keywordKind && (!filter2 || filter2(referenceLocation))) {
-                return nodeEntry(referenceLocation);
-              }
-            });
-          });
-          return references.length ? [{ definition: { type: 2 /* Keyword */, node: references[0].node }, references }] : void 0;
-        }
-        function getReferencesInSourceFile(sourceFile, search, state, addReferencesHere = true) {
-          state.cancellationToken.throwIfCancellationRequested();
-          return getReferencesInContainer(sourceFile, sourceFile, search, state, addReferencesHere);
-        }
-        function getReferencesInContainer(container, sourceFile, search, state, addReferencesHere) {
-          if (!state.markSearchedSymbols(sourceFile, search.allSearchSymbols)) {
-            return;
-          }
-          for (const position of getPossibleSymbolReferencePositions(sourceFile, search.text, container)) {
-            getReferencesAtLocation(sourceFile, position, search, state, addReferencesHere);
-          }
-        }
-        function hasMatchingMeaning(referenceLocation, state) {
-          return !!(getMeaningFromLocation(referenceLocation) & state.searchMeaning);
-        }
-        function getReferencesAtLocation(sourceFile, position, search, state, addReferencesHere) {
-          const referenceLocation = getTouchingPropertyName(sourceFile, position);
-          if (!isValidReferencePosition(referenceLocation, search.text)) {
-            if (!state.options.implementations && (state.options.findInStrings && isInString(sourceFile, position) || state.options.findInComments && isInNonReferenceComment(sourceFile, position))) {
-              state.addStringOrCommentReference(sourceFile.fileName, createTextSpan(position, search.text.length));
-            }
-            return;
-          }
-          if (!hasMatchingMeaning(referenceLocation, state))
-            return;
-          let referenceSymbol = state.checker.getSymbolAtLocation(referenceLocation);
-          if (!referenceSymbol) {
-            return;
-          }
-          const parent2 = referenceLocation.parent;
-          if (isImportSpecifier(parent2) && parent2.propertyName === referenceLocation) {
-            return;
-          }
-          if (isExportSpecifier(parent2)) {
-            Debug.assert(referenceLocation.kind === 80 /* Identifier */);
-            getReferencesAtExportSpecifier(referenceLocation, referenceSymbol, parent2, search, state, addReferencesHere);
-            return;
-          }
-          const relatedSymbol = getRelatedSymbol(search, referenceSymbol, referenceLocation, state);
-          if (!relatedSymbol) {
-            getReferenceForShorthandProperty(referenceSymbol, search, state);
-            return;
-          }
-          switch (state.specialSearchKind) {
-            case 0 /* None */:
-              if (addReferencesHere)
-                addReference(referenceLocation, relatedSymbol, state);
-              break;
-            case 1 /* Constructor */:
-              addConstructorReferences(referenceLocation, sourceFile, search, state);
-              break;
-            case 2 /* Class */:
-              addClassStaticThisReferences(referenceLocation, search, state);
-              break;
-            default:
-              Debug.assertNever(state.specialSearchKind);
-          }
-          if (isInJSFile(referenceLocation) && isBindingElement(referenceLocation.parent) && isVariableDeclarationInitializedToBareOrAccessedRequire(referenceLocation.parent.parent.parent)) {
-            referenceSymbol = referenceLocation.parent.symbol;
-            if (!referenceSymbol)
-              return;
-          }
-          getImportOrExportReferences(referenceLocation, referenceSymbol, search, state);
-        }
-        function getReferencesAtExportSpecifier(referenceLocation, referenceSymbol, exportSpecifier, search, state, addReferencesHere, alwaysGetReferences) {
-          Debug.assert(!alwaysGetReferences || !!state.options.providePrefixAndSuffixTextForRename, "If alwaysGetReferences is true, then prefix/suffix text must be enabled");
-          const { parent: parent2, propertyName, name } = exportSpecifier;
-          const exportDeclaration = parent2.parent;
-          const localSymbol = getLocalSymbolForExportSpecifier(referenceLocation, referenceSymbol, exportSpecifier, state.checker);
-          if (!alwaysGetReferences && !search.includes(localSymbol)) {
-            return;
-          }
-          if (!propertyName) {
-            if (!(state.options.use === 2 /* Rename */ && name.escapedText === "default" /* Default */)) {
-              addRef();
-            }
-          } else if (referenceLocation === propertyName) {
-            if (!exportDeclaration.moduleSpecifier) {
-              addRef();
-            }
-            if (addReferencesHere && state.options.use !== 2 /* Rename */ && state.markSeenReExportRHS(name)) {
-              addReference(name, Debug.checkDefined(exportSpecifier.symbol), state);
-            }
-          } else {
-            if (state.markSeenReExportRHS(referenceLocation)) {
-              addRef();
-            }
-          }
-          if (!isForRenameWithPrefixAndSuffixText(state.options) || alwaysGetReferences) {
-            const isDefaultExport = referenceLocation.escapedText === "default" || exportSpecifier.name.escapedText === "default";
-            const exportKind = isDefaultExport ? 1 /* Default */ : 0 /* Named */;
-            const exportSymbol = Debug.checkDefined(exportSpecifier.symbol);
-            const exportInfo = getExportInfo(exportSymbol, exportKind, state.checker);
-            if (exportInfo) {
-              searchForImportsOfExport(referenceLocation, exportSymbol, exportInfo, state);
-            }
-          }
-          if (search.comingFrom !== 1 /* Export */ && exportDeclaration.moduleSpecifier && !propertyName && !isForRenameWithPrefixAndSuffixText(state.options)) {
-            const imported = state.checker.getExportSpecifierLocalTargetSymbol(exportSpecifier);
-            if (imported)
-              searchForImportedSymbol(imported, state);
-          }
-          function addRef() {
-            if (addReferencesHere)
-              addReference(referenceLocation, localSymbol, state);
-          }
-        }
-        function getLocalSymbolForExportSpecifier(referenceLocation, referenceSymbol, exportSpecifier, checker) {
-          return isExportSpecifierAlias(referenceLocation, exportSpecifier) && checker.getExportSpecifierLocalTargetSymbol(exportSpecifier) || referenceSymbol;
-        }
-        function isExportSpecifierAlias(referenceLocation, exportSpecifier) {
-          const { parent: parent2, propertyName, name } = exportSpecifier;
-          Debug.assert(propertyName === referenceLocation || name === referenceLocation);
-          if (propertyName) {
-            return propertyName === referenceLocation;
-          } else {
-            return !parent2.parent.moduleSpecifier;
-          }
-        }
-        function getImportOrExportReferences(referenceLocation, referenceSymbol, search, state) {
-          const importOrExport = getImportOrExportSymbol(referenceLocation, referenceSymbol, state.checker, search.comingFrom === 1 /* Export */);
-          if (!importOrExport)
-            return;
-          const { symbol } = importOrExport;
-          if (importOrExport.kind === 0 /* Import */) {
-            if (!isForRenameWithPrefixAndSuffixText(state.options)) {
-              searchForImportedSymbol(symbol, state);
-            }
-          } else {
-            searchForImportsOfExport(referenceLocation, symbol, importOrExport.exportInfo, state);
-          }
-        }
-        function getReferenceForShorthandProperty({ flags, valueDeclaration }, search, state) {
-          const shorthandValueSymbol = state.checker.getShorthandAssignmentValueSymbol(valueDeclaration);
-          const name = valueDeclaration && getNameOfDeclaration(valueDeclaration);
-          if (!(flags & 33554432 /* Transient */) && name && search.includes(shorthandValueSymbol)) {
-            addReference(name, shorthandValueSymbol, state);
-          }
-        }
-        function addReference(referenceLocation, relatedSymbol, state) {
-          const { kind, symbol } = "kind" in relatedSymbol ? relatedSymbol : { kind: void 0, symbol: relatedSymbol };
-          if (state.options.use === 2 /* Rename */ && referenceLocation.kind === 90 /* DefaultKeyword */) {
-            return;
-          }
-          const addRef = state.referenceAdder(symbol);
-          if (state.options.implementations) {
-            addImplementationReferences(referenceLocation, addRef, state);
-          } else {
-            addRef(referenceLocation, kind);
-          }
-        }
-        function addConstructorReferences(referenceLocation, sourceFile, search, state) {
-          if (isNewExpressionTarget(referenceLocation)) {
-            addReference(referenceLocation, search.symbol, state);
-          }
-          const pusher = () => state.referenceAdder(search.symbol);
-          if (isClassLike(referenceLocation.parent)) {
-            Debug.assert(referenceLocation.kind === 90 /* DefaultKeyword */ || referenceLocation.parent.name === referenceLocation);
-            findOwnConstructorReferences(search.symbol, sourceFile, pusher());
-          } else {
-            const classExtending = tryGetClassByExtendingIdentifier(referenceLocation);
-            if (classExtending) {
-              findSuperConstructorAccesses(classExtending, pusher());
-              findInheritedConstructorReferences(classExtending, state);
-            }
-          }
-        }
-        function addClassStaticThisReferences(referenceLocation, search, state) {
-          addReference(referenceLocation, search.symbol, state);
-          const classLike = referenceLocation.parent;
-          if (state.options.use === 2 /* Rename */ || !isClassLike(classLike))
-            return;
-          Debug.assert(classLike.name === referenceLocation);
-          const addRef = state.referenceAdder(search.symbol);
-          for (const member of classLike.members) {
-            if (!(isMethodOrAccessor(member) && isStatic(member))) {
-              continue;
-            }
-            if (member.body) {
-              member.body.forEachChild(function cb(node) {
-                if (node.kind === 110 /* ThisKeyword */) {
-                  addRef(node);
-                } else if (!isFunctionLike(node) && !isClassLike(node)) {
-                  node.forEachChild(cb);
-                }
-              });
-            }
-          }
-        }
-        function findOwnConstructorReferences(classSymbol, sourceFile, addNode) {
-          const constructorSymbol = getClassConstructorSymbol(classSymbol);
-          if (constructorSymbol && constructorSymbol.declarations) {
-            for (const decl of constructorSymbol.declarations) {
-              const ctrKeyword = findChildOfKind(decl, 137 /* ConstructorKeyword */, sourceFile);
-              Debug.assert(decl.kind === 175 /* Constructor */ && !!ctrKeyword);
-              addNode(ctrKeyword);
-            }
-          }
-          if (classSymbol.exports) {
-            classSymbol.exports.forEach((member) => {
-              const decl = member.valueDeclaration;
-              if (decl && decl.kind === 173 /* MethodDeclaration */) {
-                const body = decl.body;
-                if (body) {
-                  forEachDescendantOfKind(body, 110 /* ThisKeyword */, (thisKeyword) => {
-                    if (isNewExpressionTarget(thisKeyword)) {
-                      addNode(thisKeyword);
-                    }
-                  });
-                }
-              }
-            });
-          }
-        }
-        function getClassConstructorSymbol(classSymbol) {
-          return classSymbol.members && classSymbol.members.get("__constructor" /* Constructor */);
-        }
-        function findSuperConstructorAccesses(classDeclaration, addNode) {
-          const constructor = getClassConstructorSymbol(classDeclaration.symbol);
-          if (!(constructor && constructor.declarations)) {
-            return;
-          }
-          for (const decl of constructor.declarations) {
-            Debug.assert(decl.kind === 175 /* Constructor */);
-            const body = decl.body;
-            if (body) {
-              forEachDescendantOfKind(body, 108 /* SuperKeyword */, (node) => {
-                if (isCallExpressionTarget(node)) {
-                  addNode(node);
-                }
-              });
-            }
-          }
-        }
-        function hasOwnConstructor(classDeclaration) {
-          return !!getClassConstructorSymbol(classDeclaration.symbol);
-        }
-        function findInheritedConstructorReferences(classDeclaration, state) {
-          if (hasOwnConstructor(classDeclaration))
-            return;
-          const classSymbol = classDeclaration.symbol;
-          const search = state.createSearch(
-            /*location*/
-            void 0,
-            classSymbol,
-            /*comingFrom*/
-            void 0
-          );
-          getReferencesInContainerOrFiles(classSymbol, state, search);
-        }
-        function addImplementationReferences(refNode, addReference2, state) {
-          if (isDeclarationName(refNode) && isImplementation(refNode.parent)) {
-            addReference2(refNode);
-            return;
-          }
-          if (refNode.kind !== 80 /* Identifier */) {
-            return;
-          }
-          if (refNode.parent.kind === 303 /* ShorthandPropertyAssignment */) {
-            getReferenceEntriesForShorthandPropertyAssignment(refNode, state.checker, addReference2);
-          }
-          const containingClass = getContainingClassIfInHeritageClause(refNode);
-          if (containingClass) {
-            addReference2(containingClass);
-            return;
-          }
-          const typeNode = findAncestor(refNode, (a) => !isQualifiedName(a.parent) && !isTypeNode(a.parent) && !isTypeElement(a.parent));
-          const typeHavingNode = typeNode.parent;
-          if (hasType(typeHavingNode) && typeHavingNode.type === typeNode && state.markSeenContainingTypeReference(typeHavingNode)) {
-            if (hasInitializer(typeHavingNode)) {
-              addIfImplementation(typeHavingNode.initializer);
-            } else if (isFunctionLike(typeHavingNode) && typeHavingNode.body) {
-              const body = typeHavingNode.body;
-              if (body.kind === 240 /* Block */) {
-                forEachReturnStatement(body, (returnStatement) => {
-                  if (returnStatement.expression)
-                    addIfImplementation(returnStatement.expression);
-                });
-              } else {
-                addIfImplementation(body);
-              }
-            } else if (isAssertionExpression(typeHavingNode)) {
-              addIfImplementation(typeHavingNode.expression);
-            }
-          }
-          function addIfImplementation(e) {
-            if (isImplementationExpression(e))
-              addReference2(e);
-          }
-        }
-        function getContainingClassIfInHeritageClause(node) {
-          return isIdentifier(node) || isPropertyAccessExpression(node) ? getContainingClassIfInHeritageClause(node.parent) : isExpressionWithTypeArguments(node) ? tryCast(node.parent.parent, isClassLike) : void 0;
-        }
-        function isImplementationExpression(node) {
-          switch (node.kind) {
-            case 216 /* ParenthesizedExpression */:
-              return isImplementationExpression(node.expression);
-            case 218 /* ArrowFunction */:
-            case 217 /* FunctionExpression */:
-            case 209 /* ObjectLiteralExpression */:
-            case 230 /* ClassExpression */:
-            case 208 /* ArrayLiteralExpression */:
-              return true;
-            default:
-              return false;
-          }
-        }
-        function explicitlyInheritsFrom(symbol, parent2, cachedResults, checker) {
-          if (symbol === parent2) {
-            return true;
-          }
-          const key = getSymbolId(symbol) + "," + getSymbolId(parent2);
-          const cached = cachedResults.get(key);
-          if (cached !== void 0) {
-            return cached;
-          }
-          cachedResults.set(key, false);
-          const inherits = !!symbol.declarations && symbol.declarations.some((declaration) => getAllSuperTypeNodes(declaration).some((typeReference) => {
-            const type = checker.getTypeAtLocation(typeReference);
-            return !!type && !!type.symbol && explicitlyInheritsFrom(type.symbol, parent2, cachedResults, checker);
-          }));
-          cachedResults.set(key, inherits);
-          return inherits;
-        }
-        function getReferencesForSuperKeyword(superKeyword) {
-          let searchSpaceNode = getSuperContainer(
-            superKeyword,
-            /*stopOnFunctions*/
-            false
-          );
-          if (!searchSpaceNode) {
-            return void 0;
-          }
-          let staticFlag = 32 /* Static */;
-          switch (searchSpaceNode.kind) {
-            case 171 /* PropertyDeclaration */:
-            case 170 /* PropertySignature */:
-            case 173 /* MethodDeclaration */:
-            case 172 /* MethodSignature */:
-            case 175 /* Constructor */:
-            case 176 /* GetAccessor */:
-            case 177 /* SetAccessor */:
-              staticFlag &= getSyntacticModifierFlags(searchSpaceNode);
-              searchSpaceNode = searchSpaceNode.parent;
-              break;
-            default:
-              return void 0;
-          }
-          const sourceFile = searchSpaceNode.getSourceFile();
-          const references = mapDefined(getPossibleSymbolReferenceNodes(sourceFile, "super", searchSpaceNode), (node) => {
-            if (node.kind !== 108 /* SuperKeyword */) {
-              return;
-            }
-            const container = getSuperContainer(
-              node,
-              /*stopOnFunctions*/
-              false
-            );
-            return container && isStatic(container) === !!staticFlag && container.parent.symbol === searchSpaceNode.symbol ? nodeEntry(node) : void 0;
-          });
-          return [{ definition: { type: 0 /* Symbol */, symbol: searchSpaceNode.symbol }, references }];
-        }
-        function isParameterName(node) {
-          return node.kind === 80 /* Identifier */ && node.parent.kind === 168 /* Parameter */ && node.parent.name === node;
-        }
-        function getReferencesForThisKeyword(thisOrSuperKeyword, sourceFiles, cancellationToken) {
-          let searchSpaceNode = getThisContainer(
-            thisOrSuperKeyword,
-            /*includeArrowFunctions*/
-            false,
-            /*includeClassComputedPropertyName*/
-            false
-          );
-          let staticFlag = 32 /* Static */;
-          switch (searchSpaceNode.kind) {
-            case 173 /* MethodDeclaration */:
-            case 172 /* MethodSignature */:
-              if (isObjectLiteralMethod(searchSpaceNode)) {
-                staticFlag &= getSyntacticModifierFlags(searchSpaceNode);
-                searchSpaceNode = searchSpaceNode.parent;
-                break;
-              }
-            case 171 /* PropertyDeclaration */:
-            case 170 /* PropertySignature */:
-            case 175 /* Constructor */:
-            case 176 /* GetAccessor */:
-            case 177 /* SetAccessor */:
-              staticFlag &= getSyntacticModifierFlags(searchSpaceNode);
-              searchSpaceNode = searchSpaceNode.parent;
-              break;
-            case 311 /* SourceFile */:
-              if (isExternalModule(searchSpaceNode) || isParameterName(thisOrSuperKeyword)) {
-                return void 0;
-              }
-            case 261 /* FunctionDeclaration */:
-            case 217 /* FunctionExpression */:
-              break;
-            default:
-              return void 0;
-          }
-          const references = flatMap(searchSpaceNode.kind === 311 /* SourceFile */ ? sourceFiles : [searchSpaceNode.getSourceFile()], (sourceFile) => {
-            cancellationToken.throwIfCancellationRequested();
-            return getPossibleSymbolReferenceNodes(sourceFile, "this", isSourceFile(searchSpaceNode) ? sourceFile : searchSpaceNode).filter((node) => {
-              if (!isThis(node)) {
-                return false;
-              }
-              const container = getThisContainer(
-                node,
-                /*includeArrowFunctions*/
-                false,
-                /*includeClassComputedPropertyName*/
-                false
-              );
-              if (!canHaveSymbol(container))
-                return false;
-              switch (searchSpaceNode.kind) {
-                case 217 /* FunctionExpression */:
-                case 261 /* FunctionDeclaration */:
-                  return searchSpaceNode.symbol === container.symbol;
-                case 173 /* MethodDeclaration */:
-                case 172 /* MethodSignature */:
-                  return isObjectLiteralMethod(searchSpaceNode) && searchSpaceNode.symbol === container.symbol;
-                case 230 /* ClassExpression */:
-                case 262 /* ClassDeclaration */:
-                case 209 /* ObjectLiteralExpression */:
-                  return container.parent && canHaveSymbol(container.parent) && searchSpaceNode.symbol === container.parent.symbol && isStatic(container) === !!staticFlag;
-                case 311 /* SourceFile */:
-                  return container.kind === 311 /* SourceFile */ && !isExternalModule(container) && !isParameterName(node);
-              }
-            });
-          }).map((n) => nodeEntry(n));
-          const thisParameter = firstDefined(references, (r) => isParameter(r.node.parent) ? r.node : void 0);
-          return [{
-            definition: { type: 3 /* This */, node: thisParameter || thisOrSuperKeyword },
-            references
-          }];
-        }
-        function getReferencesForStringLiteral(node, sourceFiles, checker, cancellationToken) {
-          const type = getContextualTypeFromParentOrAncestorTypeNode(node, checker);
-          const references = flatMap(sourceFiles, (sourceFile) => {
-            cancellationToken.throwIfCancellationRequested();
-            return mapDefined(getPossibleSymbolReferenceNodes(sourceFile, node.text), (ref) => {
-              if (isStringLiteralLike(ref) && ref.text === node.text) {
-                if (type) {
-                  const refType = getContextualTypeFromParentOrAncestorTypeNode(ref, checker);
-                  if (type !== checker.getStringType() && type === refType) {
-                    return nodeEntry(ref, 2 /* StringLiteral */);
-                  }
-                } else {
-                  return isNoSubstitutionTemplateLiteral(ref) && !rangeIsOnSingleLine(ref, sourceFile) ? void 0 : nodeEntry(ref, 2 /* StringLiteral */);
-                }
-              }
-            });
-          });
-          return [{
-            definition: { type: 4 /* String */, node },
-            references
-          }];
-        }
-        function populateSearchSymbolSet(symbol, location, checker, isForRename, providePrefixAndSuffixText, implementations) {
-          const result = [];
-          forEachRelatedSymbol(
-            symbol,
-            location,
-            checker,
-            isForRename,
-            !(isForRename && providePrefixAndSuffixText),
-            (sym, root, base) => {
-              if (base) {
-                if (isStaticSymbol(symbol) !== isStaticSymbol(base)) {
-                  base = void 0;
-                }
-              }
-              result.push(base || root || sym);
-            },
-            // when try to find implementation, implementations is true, and not allowed to find base class
-            /*allowBaseTypes*/
-            () => !implementations
-          );
-          return result;
-        }
-        function forEachRelatedSymbol(symbol, location, checker, isForRenamePopulateSearchSymbolSet, onlyIncludeBindingElementAtReferenceLocation, cbSymbol, allowBaseTypes) {
-          const containingObjectLiteralElement = getContainingObjectLiteralElement(location);
-          if (containingObjectLiteralElement) {
-            const shorthandValueSymbol = checker.getShorthandAssignmentValueSymbol(location.parent);
-            if (shorthandValueSymbol && isForRenamePopulateSearchSymbolSet) {
-              return cbSymbol(
-                shorthandValueSymbol,
-                /*rootSymbol*/
-                void 0,
-                /*baseSymbol*/
-                void 0,
-                3 /* SearchedLocalFoundProperty */
-              );
-            }
-            const contextualType = checker.getContextualType(containingObjectLiteralElement.parent);
-            const res2 = contextualType && firstDefined(
-              getPropertySymbolsFromContextualType(
-                containingObjectLiteralElement,
-                checker,
-                contextualType,
-                /*unionSymbolOk*/
-                true
-              ),
-              (sym) => fromRoot(sym, 4 /* SearchedPropertyFoundLocal */)
-            );
-            if (res2)
-              return res2;
-            const propertySymbol = getPropertySymbolOfDestructuringAssignment(location, checker);
-            const res1 = propertySymbol && cbSymbol(
-              propertySymbol,
-              /*rootSymbol*/
-              void 0,
-              /*baseSymbol*/
-              void 0,
-              4 /* SearchedPropertyFoundLocal */
-            );
-            if (res1)
-              return res1;
-            const res22 = shorthandValueSymbol && cbSymbol(
-              shorthandValueSymbol,
-              /*rootSymbol*/
-              void 0,
-              /*baseSymbol*/
-              void 0,
-              3 /* SearchedLocalFoundProperty */
-            );
-            if (res22)
-              return res22;
-          }
-          const aliasedSymbol = getMergedAliasedSymbolOfNamespaceExportDeclaration(location, symbol, checker);
-          if (aliasedSymbol) {
-            const res2 = cbSymbol(
-              aliasedSymbol,
-              /*rootSymbol*/
-              void 0,
-              /*baseSymbol*/
-              void 0,
-              1 /* Node */
-            );
-            if (res2)
-              return res2;
-          }
-          const res = fromRoot(symbol);
-          if (res)
-            return res;
-          if (symbol.valueDeclaration && isParameterPropertyDeclaration(symbol.valueDeclaration, symbol.valueDeclaration.parent)) {
-            const paramProps = checker.getSymbolsOfParameterPropertyDeclaration(cast(symbol.valueDeclaration, isParameter), symbol.name);
-            Debug.assert(paramProps.length === 2 && !!(paramProps[0].flags & 1 /* FunctionScopedVariable */) && !!(paramProps[1].flags & 4 /* Property */));
-            return fromRoot(symbol.flags & 1 /* FunctionScopedVariable */ ? paramProps[1] : paramProps[0]);
-          }
-          const exportSpecifier = getDeclarationOfKind(symbol, 280 /* ExportSpecifier */);
-          if (!isForRenamePopulateSearchSymbolSet || exportSpecifier && !exportSpecifier.propertyName) {
-            const localSymbol = exportSpecifier && checker.getExportSpecifierLocalTargetSymbol(exportSpecifier);
-            if (localSymbol) {
-              const res2 = cbSymbol(
-                localSymbol,
-                /*rootSymbol*/
-                void 0,
-                /*baseSymbol*/
-                void 0,
-                1 /* Node */
-              );
-              if (res2)
-                return res2;
-            }
-          }
-          if (!isForRenamePopulateSearchSymbolSet) {
-            let bindingElementPropertySymbol;
-            if (onlyIncludeBindingElementAtReferenceLocation) {
-              bindingElementPropertySymbol = isObjectBindingElementWithoutPropertyName(location.parent) ? getPropertySymbolFromBindingElement(checker, location.parent) : void 0;
-            } else {
-              bindingElementPropertySymbol = getPropertySymbolOfObjectBindingPatternWithoutPropertyName(symbol, checker);
-            }
-            return bindingElementPropertySymbol && fromRoot(bindingElementPropertySymbol, 4 /* SearchedPropertyFoundLocal */);
-          }
-          Debug.assert(isForRenamePopulateSearchSymbolSet);
-          const includeOriginalSymbolOfBindingElement = onlyIncludeBindingElementAtReferenceLocation;
-          if (includeOriginalSymbolOfBindingElement) {
-            const bindingElementPropertySymbol = getPropertySymbolOfObjectBindingPatternWithoutPropertyName(symbol, checker);
-            return bindingElementPropertySymbol && fromRoot(bindingElementPropertySymbol, 4 /* SearchedPropertyFoundLocal */);
-          }
-          function fromRoot(sym, kind) {
-            return firstDefined(checker.getRootSymbols(sym), (rootSymbol) => cbSymbol(
-              sym,
-              rootSymbol,
-              /*baseSymbol*/
-              void 0,
-              kind
-            ) || (rootSymbol.parent && rootSymbol.parent.flags & (32 /* Class */ | 64 /* Interface */) && allowBaseTypes(rootSymbol) ? getPropertySymbolsFromBaseTypes(rootSymbol.parent, rootSymbol.name, checker, (base) => cbSymbol(sym, rootSymbol, base, kind)) : void 0));
-          }
-          function getPropertySymbolOfObjectBindingPatternWithoutPropertyName(symbol2, checker2) {
-            const bindingElement = getDeclarationOfKind(symbol2, 207 /* BindingElement */);
-            if (bindingElement && isObjectBindingElementWithoutPropertyName(bindingElement)) {
-              return getPropertySymbolFromBindingElement(checker2, bindingElement);
-            }
-          }
-        }
-        function getPropertySymbolsFromBaseTypes(symbol, propertyName, checker, cb) {
-          const seen = /* @__PURE__ */ new Map();
-          return recur(symbol);
-          function recur(symbol2) {
-            if (!(symbol2.flags & (32 /* Class */ | 64 /* Interface */)) || !addToSeen(seen, getSymbolId(symbol2)))
-              return;
-            return firstDefined(symbol2.declarations, (declaration) => firstDefined(getAllSuperTypeNodes(declaration), (typeReference) => {
-              const type = checker.getTypeAtLocation(typeReference);
-              const propertySymbol = type && type.symbol && checker.getPropertyOfType(type, propertyName);
-              return type && propertySymbol && (firstDefined(checker.getRootSymbols(propertySymbol), cb) || recur(type.symbol));
-            }));
-          }
-        }
-        function isStaticSymbol(symbol) {
-          if (!symbol.valueDeclaration)
-            return false;
-          const modifierFlags = getEffectiveModifierFlags(symbol.valueDeclaration);
-          return !!(modifierFlags & 32 /* Static */);
-        }
-        function getRelatedSymbol(search, referenceSymbol, referenceLocation, state) {
-          const { checker } = state;
-          return forEachRelatedSymbol(
-            referenceSymbol,
-            referenceLocation,
-            checker,
-            /*isForRenamePopulateSearchSymbolSet*/
-            false,
-            /*onlyIncludeBindingElementAtReferenceLocation*/
-            state.options.use !== 2 /* Rename */ || !!state.options.providePrefixAndSuffixTextForRename,
-            (sym, rootSymbol, baseSymbol, kind) => {
-              if (baseSymbol) {
-                if (isStaticSymbol(referenceSymbol) !== isStaticSymbol(baseSymbol)) {
-                  baseSymbol = void 0;
-                }
-              }
-              return search.includes(baseSymbol || rootSymbol || sym) ? { symbol: rootSymbol && !(getCheckFlags(sym) & 6 /* Synthetic */) ? rootSymbol : sym, kind } : void 0;
-            },
-            /*allowBaseTypes*/
-            (rootSymbol) => !(search.parents && !search.parents.some((parent2) => explicitlyInheritsFrom(rootSymbol.parent, parent2, state.inheritsFromCache, checker)))
-          );
-        }
-        function getIntersectingMeaningFromDeclarations(node, symbol) {
-          let meaning = getMeaningFromLocation(node);
-          const { declarations } = symbol;
-          if (declarations) {
-            let lastIterationMeaning;
-            do {
-              lastIterationMeaning = meaning;
-              for (const declaration of declarations) {
-                const declarationMeaning = getMeaningFromDeclaration(declaration);
-                if (declarationMeaning & meaning) {
-                  meaning |= declarationMeaning;
-                }
-              }
-            } while (meaning !== lastIterationMeaning);
-          }
-          return meaning;
-        }
-        Core2.getIntersectingMeaningFromDeclarations = getIntersectingMeaningFromDeclarations;
-        function isImplementation(node) {
-          return !!(node.flags & 16777216 /* Ambient */) ? !(isInterfaceDeclaration(node) || isTypeAliasDeclaration(node)) : isVariableLike(node) ? hasInitializer(node) : isFunctionLikeDeclaration(node) ? !!node.body : isClassLike(node) || isModuleOrEnumDeclaration(node);
-        }
-        function getReferenceEntriesForShorthandPropertyAssignment(node, checker, addReference2) {
-          const refSymbol = checker.getSymbolAtLocation(node);
-          const shorthandSymbol = checker.getShorthandAssignmentValueSymbol(refSymbol.valueDeclaration);
-          if (shorthandSymbol) {
-            for (const declaration of shorthandSymbol.getDeclarations()) {
-              if (getMeaningFromDeclaration(declaration) & 1 /* Value */) {
-                addReference2(declaration);
-              }
-            }
-          }
-        }
-        Core2.getReferenceEntriesForShorthandPropertyAssignment = getReferenceEntriesForShorthandPropertyAssignment;
-        function forEachDescendantOfKind(node, kind, action) {
-          forEachChild(node, (child) => {
-            if (child.kind === kind) {
-              action(child);
-            }
-            forEachDescendantOfKind(child, kind, action);
-          });
-        }
-        function tryGetClassByExtendingIdentifier(node) {
-          return tryGetClassExtendingExpressionWithTypeArguments(climbPastPropertyAccess(node).parent);
-        }
-        function getParentSymbolsOfPropertyAccess(location, symbol, checker) {
-          const propertyAccessExpression = isRightSideOfPropertyAccess(location) ? location.parent : void 0;
-          const lhsType = propertyAccessExpression && checker.getTypeAtLocation(propertyAccessExpression.expression);
-          const res = mapDefined(lhsType && (lhsType.isUnionOrIntersection() ? lhsType.types : lhsType.symbol === symbol.parent ? void 0 : [lhsType]), (t) => t.symbol && t.symbol.flags & (32 /* Class */ | 64 /* Interface */) ? t.symbol : void 0);
-          return res.length === 0 ? void 0 : res;
-        }
-        function isForRenameWithPrefixAndSuffixText(options) {
-          return options.use === 2 /* Rename */ && options.providePrefixAndSuffixTextForRename;
-        }
-      })(Core || (Core = {}));
-    }
-  });
-
-  // src/services/_namespaces/ts.FindAllReferences.ts
-  var ts_FindAllReferences_exports = {};
-  __export(ts_FindAllReferences_exports, {
-    Core: () => Core,
-    DefinitionKind: () => DefinitionKind,
-    EntryKind: () => EntryKind,
-    ExportKind: () => ExportKind2,
-    FindReferencesUse: () => FindReferencesUse,
-    ImportExport: () => ImportExport,
-    createImportTracker: () => createImportTracker,
-    findModuleReferences: () => findModuleReferences,
-    findReferenceOrRenameEntries: () => findReferenceOrRenameEntries,
-    findReferencedSymbols: () => findReferencedSymbols,
-    getContextNode: () => getContextNode,
-    getExportInfo: () => getExportInfo,
-    getImplementationsAtPosition: () => getImplementationsAtPosition,
-    getImportOrExportSymbol: () => getImportOrExportSymbol,
-    getReferenceEntriesForNode: () => getReferenceEntriesForNode,
-    getTextSpanOfEntry: () => getTextSpanOfEntry,
-    isContextWithStartAndEndNode: () => isContextWithStartAndEndNode,
-    isDeclarationOfSymbol: () => isDeclarationOfSymbol,
-    nodeEntry: () => nodeEntry,
-    toContextSpan: () => toContextSpan,
-    toHighlightSpan: () => toHighlightSpan,
-    toReferenceEntry: () => toReferenceEntry,
-    toRenameLocation: () => toRenameLocation
-  });
-  var init_ts_FindAllReferences = __esm({
-    "src/services/_namespaces/ts.FindAllReferences.ts"() {
-      "use strict";
-      init_importTracker();
-      init_findAllReferences();
-    }
-  });
-
-  // src/services/goToDefinition.ts
-  function getDefinitionAtPosition(program, sourceFile, position, searchOtherFilesOnly, stopAtAlias) {
-    var _a, _b;
-    const resolvedRef = getReferenceAtPosition(sourceFile, position, program);
-    const fileReferenceDefinition = resolvedRef && [getDefinitionInfoForFileReference(resolvedRef.reference.fileName, resolvedRef.fileName, resolvedRef.unverified)] || emptyArray;
-    if (resolvedRef == null ? void 0 : resolvedRef.file) {
-      return fileReferenceDefinition;
-    }
-    const node = getTouchingPropertyName(sourceFile, position);
-    if (node === sourceFile) {
-      return void 0;
-    }
-    const { parent: parent2 } = node;
-    const typeChecker = program.getTypeChecker();
-    if (node.kind === 163 /* OverrideKeyword */ || isIdentifier(node) && isJSDocOverrideTag(parent2) && parent2.tagName === node) {
-      return getDefinitionFromOverriddenMember(typeChecker, node) || emptyArray;
-    }
-    if (isJumpStatementTarget(node)) {
-      const label = getTargetLabel(node.parent, node.text);
-      return label ? [createDefinitionInfoFromName(
-        typeChecker,
-        label,
-        "label" /* label */,
-        node.text,
-        /*containerName*/
-        void 0
-      )] : void 0;
-    }
-    if (node.kind === 107 /* ReturnKeyword */) {
-      const functionDeclaration = findAncestor(node.parent, (n) => isClassStaticBlockDeclaration(n) ? "quit" : isFunctionLikeDeclaration(n));
-      return functionDeclaration ? [createDefinitionFromSignatureDeclaration(typeChecker, functionDeclaration)] : void 0;
-    }
-    if (node.kind === 135 /* AwaitKeyword */) {
-      const functionDeclaration = findAncestor(node, (n) => isFunctionLikeDeclaration(n));
-      const isAsyncFunction2 = functionDeclaration && some(functionDeclaration.modifiers, (node2) => node2.kind === 134 /* AsyncKeyword */);
-      return isAsyncFunction2 ? [createDefinitionFromSignatureDeclaration(typeChecker, functionDeclaration)] : void 0;
-    }
-    if (node.kind === 127 /* YieldKeyword */) {
-      const functionDeclaration = findAncestor(node, (n) => isFunctionLikeDeclaration(n));
-      const isGeneratorFunction = functionDeclaration && functionDeclaration.asteriskToken;
-      return isGeneratorFunction ? [createDefinitionFromSignatureDeclaration(typeChecker, functionDeclaration)] : void 0;
-    }
-    if (isStaticModifier(node) && isClassStaticBlockDeclaration(node.parent)) {
-      const classDecl = node.parent.parent;
-      const { symbol: symbol2, failedAliasResolution: failedAliasResolution2 } = getSymbol(classDecl, typeChecker, stopAtAlias);
-      const staticBlocks = filter(classDecl.members, isClassStaticBlockDeclaration);
-      const containerName = symbol2 ? typeChecker.symbolToString(symbol2, classDecl) : "";
-      const sourceFile2 = node.getSourceFile();
-      return map(staticBlocks, (staticBlock) => {
-        let { pos } = moveRangePastModifiers(staticBlock);
-        pos = skipTrivia(sourceFile2.text, pos);
-        return createDefinitionInfoFromName(
-          typeChecker,
-          staticBlock,
-          "constructor" /* constructorImplementationElement */,
-          "static {}",
-          containerName,
-          /*unverified*/
-          false,
-          failedAliasResolution2,
-          { start: pos, length: "static".length }
-        );
-      });
-    }
-    let { symbol, failedAliasResolution } = getSymbol(node, typeChecker, stopAtAlias);
-    let fallbackNode = node;
-    if (searchOtherFilesOnly && failedAliasResolution) {
-      const importDeclaration = forEach([node, ...(symbol == null ? void 0 : symbol.declarations) || emptyArray], (n) => findAncestor(n, isAnyImportOrBareOrAccessedRequire));
-      const moduleSpecifier = importDeclaration && tryGetModuleSpecifierFromDeclaration(importDeclaration);
-      if (moduleSpecifier) {
-        ({ symbol, failedAliasResolution } = getSymbol(moduleSpecifier, typeChecker, stopAtAlias));
-        fallbackNode = moduleSpecifier;
-      }
-    }
-    if (!symbol && isModuleSpecifierLike(fallbackNode)) {
-      const ref = (_b = (_a = sourceFile.resolvedModules) == null ? void 0 : _a.get(fallbackNode.text, getModeForUsageLocation(sourceFile, fallbackNode))) == null ? void 0 : _b.resolvedModule;
-      if (ref) {
-        return [{
-          name: fallbackNode.text,
-          fileName: ref.resolvedFileName,
-          containerName: void 0,
-          containerKind: void 0,
-          kind: "script" /* scriptElement */,
-          textSpan: createTextSpan(0, 0),
-          failedAliasResolution,
-          isAmbient: isDeclarationFileName(ref.resolvedFileName),
-          unverified: fallbackNode !== node
-        }];
-      }
-    }
-    if (!symbol) {
-      return concatenate(fileReferenceDefinition, getDefinitionInfoForIndexSignatures(node, typeChecker));
-    }
-    if (searchOtherFilesOnly && every(symbol.declarations, (d) => d.getSourceFile().fileName === sourceFile.fileName))
-      return void 0;
-    const calledDeclaration = tryGetSignatureDeclaration(typeChecker, node);
-    if (calledDeclaration && !(isJsxOpeningLikeElement(node.parent) && isConstructorLike(calledDeclaration))) {
-      const sigInfo = createDefinitionFromSignatureDeclaration(typeChecker, calledDeclaration, failedAliasResolution);
-      if (typeChecker.getRootSymbols(symbol).some((s) => symbolMatchesSignature(s, calledDeclaration))) {
-        return [sigInfo];
-      } else {
-        const defs = getDefinitionFromSymbol(typeChecker, symbol, node, failedAliasResolution, calledDeclaration) || emptyArray;
-        return node.kind === 108 /* SuperKeyword */ ? [sigInfo, ...defs] : [...defs, sigInfo];
-      }
-    }
-    if (node.parent.kind === 303 /* ShorthandPropertyAssignment */) {
-      const shorthandSymbol = typeChecker.getShorthandAssignmentValueSymbol(symbol.valueDeclaration);
-      const definitions = (shorthandSymbol == null ? void 0 : shorthandSymbol.declarations) ? shorthandSymbol.declarations.map((decl) => createDefinitionInfo(
-        decl,
-        typeChecker,
-        shorthandSymbol,
-        node,
-        /*unverified*/
-        false,
-        failedAliasResolution
-      )) : emptyArray;
-      return concatenate(definitions, getDefinitionFromObjectLiteralElement(typeChecker, node));
-    }
-    if (isPropertyName(node) && isBindingElement(parent2) && isObjectBindingPattern(parent2.parent) && node === (parent2.propertyName || parent2.name)) {
-      const name = getNameFromPropertyName(node);
-      const type = typeChecker.getTypeAtLocation(parent2.parent);
-      return name === void 0 ? emptyArray : flatMap(type.isUnion() ? type.types : [type], (t) => {
-        const prop = t.getProperty(name);
-        return prop && getDefinitionFromSymbol(typeChecker, prop, node);
-      });
-    }
-    const objectLiteralElementDefinition = getDefinitionFromObjectLiteralElement(typeChecker, node);
-    return concatenate(fileReferenceDefinition, objectLiteralElementDefinition.length ? objectLiteralElementDefinition : getDefinitionFromSymbol(typeChecker, symbol, node, failedAliasResolution));
-  }
-  function symbolMatchesSignature(s, calledDeclaration) {
-    var _a;
-    return s === calledDeclaration.symbol || s === calledDeclaration.symbol.parent || isAssignmentExpression(calledDeclaration.parent) || !isCallLikeExpression(calledDeclaration.parent) && s === ((_a = tryCast(calledDeclaration.parent, canHaveSymbol)) == null ? void 0 : _a.symbol);
-  }
-  function getDefinitionFromObjectLiteralElement(typeChecker, node) {
-    const element = getContainingObjectLiteralElement(node);
-    if (element) {
-      const contextualType = element && typeChecker.getContextualType(element.parent);
-      if (contextualType) {
-        return flatMap(getPropertySymbolsFromContextualType(
-          element,
-          typeChecker,
-          contextualType,
-          /*unionSymbolOk*/
-          false
-        ), (propertySymbol) => getDefinitionFromSymbol(typeChecker, propertySymbol, node));
-      }
-    }
-    return emptyArray;
-  }
-  function getDefinitionFromOverriddenMember(typeChecker, node) {
-    const classElement = findAncestor(node, isClassElement);
-    if (!(classElement && classElement.name))
-      return;
-    const baseDeclaration = findAncestor(classElement, isClassLike);
-    if (!baseDeclaration)
-      return;
-    const baseTypeNode = getEffectiveBaseTypeNode(baseDeclaration);
-    if (!baseTypeNode)
-      return;
-    const expression = skipParentheses(baseTypeNode.expression);
-    const base = isClassExpression(expression) ? expression.symbol : typeChecker.getSymbolAtLocation(expression);
-    if (!base)
-      return;
-    const name = unescapeLeadingUnderscores(getTextOfPropertyName(classElement.name));
-    const symbol = hasStaticModifier(classElement) ? typeChecker.getPropertyOfType(typeChecker.getTypeOfSymbol(base), name) : typeChecker.getPropertyOfType(typeChecker.getDeclaredTypeOfSymbol(base), name);
-    if (!symbol)
-      return;
-    return getDefinitionFromSymbol(typeChecker, symbol, node);
-  }
-  function getReferenceAtPosition(sourceFile, position, program) {
-    var _a, _b, _c, _d;
-    const referencePath = findReferenceInPosition(sourceFile.referencedFiles, position);
-    if (referencePath) {
-      const file = program.getSourceFileFromReference(sourceFile, referencePath);
-      return file && { reference: referencePath, fileName: file.fileName, file, unverified: false };
-    }
-    const typeReferenceDirective = findReferenceInPosition(sourceFile.typeReferenceDirectives, position);
-    if (typeReferenceDirective) {
-      const reference = (_a = program.getResolvedTypeReferenceDirectives().get(typeReferenceDirective.fileName, typeReferenceDirective.resolutionMode || sourceFile.impliedNodeFormat)) == null ? void 0 : _a.resolvedTypeReferenceDirective;
-      const file = reference && program.getSourceFile(reference.resolvedFileName);
-      return file && { reference: typeReferenceDirective, fileName: file.fileName, file, unverified: false };
-    }
-    const libReferenceDirective = findReferenceInPosition(sourceFile.libReferenceDirectives, position);
-    if (libReferenceDirective) {
-      const file = program.getLibFileFromReference(libReferenceDirective);
-      return file && { reference: libReferenceDirective, fileName: file.fileName, file, unverified: false };
-    }
-    if ((_b = sourceFile.resolvedModules) == null ? void 0 : _b.size()) {
-      const node = getTouchingToken(sourceFile, position);
-      if (isModuleSpecifierLike(node) && isExternalModuleNameRelative(node.text) && sourceFile.resolvedModules.has(node.text, getModeForUsageLocation(sourceFile, node))) {
-        const verifiedFileName = (_d = (_c = sourceFile.resolvedModules.get(node.text, getModeForUsageLocation(sourceFile, node))) == null ? void 0 : _c.resolvedModule) == null ? void 0 : _d.resolvedFileName;
-        const fileName = verifiedFileName || resolvePath(getDirectoryPath(sourceFile.fileName), node.text);
-        return {
-          file: program.getSourceFile(fileName),
-          fileName,
-          reference: {
-            pos: node.getStart(),
-            end: node.getEnd(),
-            fileName: node.text
-          },
-          unverified: !verifiedFileName
-        };
-      }
-    }
-    return void 0;
-  }
-  function getTypeDefinitionAtPosition(typeChecker, sourceFile, position) {
-    const node = getTouchingPropertyName(sourceFile, position);
-    if (node === sourceFile) {
-      return void 0;
-    }
-    if (isImportMeta(node.parent) && node.parent.name === node) {
-      return definitionFromType(
-        typeChecker.getTypeAtLocation(node.parent),
-        typeChecker,
-        node.parent,
-        /*failedAliasResolution*/
-        false
-      );
-    }
-    const { symbol, failedAliasResolution } = getSymbol(
-      node,
-      typeChecker,
-      /*stopAtAlias*/
-      false
-    );
-    if (!symbol)
-      return void 0;
-    const typeAtLocation = typeChecker.getTypeOfSymbolAtLocation(symbol, node);
-    const returnType = tryGetReturnTypeOfFunction(symbol, typeAtLocation, typeChecker);
-    const fromReturnType = returnType && definitionFromType(returnType, typeChecker, node, failedAliasResolution);
-    const typeDefinitions = fromReturnType && fromReturnType.length !== 0 ? fromReturnType : definitionFromType(typeAtLocation, typeChecker, node, failedAliasResolution);
-    return typeDefinitions.length ? typeDefinitions : !(symbol.flags & 111551 /* Value */) && symbol.flags & 788968 /* Type */ ? getDefinitionFromSymbol(typeChecker, skipAlias(symbol, typeChecker), node, failedAliasResolution) : void 0;
-  }
-  function definitionFromType(type, checker, node, failedAliasResolution) {
-    return flatMap(type.isUnion() && !(type.flags & 32 /* Enum */) ? type.types : [type], (t) => t.symbol && getDefinitionFromSymbol(checker, t.symbol, node, failedAliasResolution));
-  }
-  function tryGetReturnTypeOfFunction(symbol, type, checker) {
-    if (type.symbol === symbol || // At `const f = () => {}`, the symbol is `f` and the type symbol is at `() => {}`
-    symbol.valueDeclaration && type.symbol && isVariableDeclaration(symbol.valueDeclaration) && symbol.valueDeclaration.initializer === type.symbol.valueDeclaration) {
-      const sigs = type.getCallSignatures();
-      if (sigs.length === 1)
-        return checker.getReturnTypeOfSignature(first(sigs));
-    }
-    return void 0;
-  }
-  function getDefinitionAndBoundSpan(program, sourceFile, position) {
-    const definitions = getDefinitionAtPosition(program, sourceFile, position);
-    if (!definitions || definitions.length === 0) {
-      return void 0;
-    }
-    const comment = findReferenceInPosition(sourceFile.referencedFiles, position) || findReferenceInPosition(sourceFile.typeReferenceDirectives, position) || findReferenceInPosition(sourceFile.libReferenceDirectives, position);
-    if (comment) {
-      return { definitions, textSpan: createTextSpanFromRange(comment) };
-    }
-    const node = getTouchingPropertyName(sourceFile, position);
-    const textSpan = createTextSpan(node.getStart(), node.getWidth());
-    return { definitions, textSpan };
-  }
-  function getDefinitionInfoForIndexSignatures(node, checker) {
-    return mapDefined(checker.getIndexInfosAtLocation(node), (info) => info.declaration && createDefinitionFromSignatureDeclaration(checker, info.declaration));
-  }
-  function getSymbol(node, checker, stopAtAlias) {
-    const symbol = checker.getSymbolAtLocation(node);
-    let failedAliasResolution = false;
-    if ((symbol == null ? void 0 : symbol.declarations) && symbol.flags & 2097152 /* Alias */ && !stopAtAlias && shouldSkipAlias(node, symbol.declarations[0])) {
-      const aliased = checker.getAliasedSymbol(symbol);
-      if (aliased.declarations) {
-        return { symbol: aliased };
-      } else {
-        failedAliasResolution = true;
-      }
-    }
-    return { symbol, failedAliasResolution };
-  }
-  function shouldSkipAlias(node, declaration) {
-    if (node.kind !== 80 /* Identifier */) {
-      return false;
-    }
-    if (node.parent === declaration) {
-      return true;
-    }
-    if (declaration.kind === 273 /* NamespaceImport */) {
-      return false;
-    }
-    return true;
-  }
-  function isExpandoDeclaration(node) {
-    if (!isAssignmentDeclaration(node))
-      return false;
-    const containingAssignment = findAncestor(node, (p) => {
-      if (isAssignmentExpression(p))
-        return true;
-      if (!isAssignmentDeclaration(p))
-        return "quit";
-      return false;
-    });
-    return !!containingAssignment && getAssignmentDeclarationKind(containingAssignment) === 5 /* Property */;
-  }
-  function getDefinitionFromSymbol(typeChecker, symbol, node, failedAliasResolution, excludeDeclaration) {
-    const filteredDeclarations = filter(symbol.declarations, (d) => d !== excludeDeclaration);
-    const withoutExpandos = filter(filteredDeclarations, (d) => !isExpandoDeclaration(d));
-    const results = some(withoutExpandos) ? withoutExpandos : filteredDeclarations;
-    return getConstructSignatureDefinition() || getCallSignatureDefinition() || map(results, (declaration) => createDefinitionInfo(
-      declaration,
-      typeChecker,
-      symbol,
-      node,
-      /*unverified*/
-      false,
-      failedAliasResolution
-    ));
-    function getConstructSignatureDefinition() {
-      if (symbol.flags & 32 /* Class */ && !(symbol.flags & (16 /* Function */ | 3 /* Variable */)) && (isNewExpressionTarget(node) || node.kind === 137 /* ConstructorKeyword */)) {
-        const cls = find(filteredDeclarations, isClassLike) || Debug.fail("Expected declaration to have at least one class-like declaration");
-        return getSignatureDefinition(
-          cls.members,
-          /*selectConstructors*/
-          true
-        );
-      }
-    }
-    function getCallSignatureDefinition() {
-      return isCallOrNewExpressionTarget(node) || isNameOfFunctionDeclaration(node) ? getSignatureDefinition(
-        filteredDeclarations,
-        /*selectConstructors*/
-        false
-      ) : void 0;
-    }
-    function getSignatureDefinition(signatureDeclarations, selectConstructors) {
-      if (!signatureDeclarations) {
-        return void 0;
-      }
-      const declarations = signatureDeclarations.filter(selectConstructors ? isConstructorDeclaration : isFunctionLike);
-      const declarationsWithBody = declarations.filter((d) => !!d.body);
-      return declarations.length ? declarationsWithBody.length !== 0 ? declarationsWithBody.map((x) => createDefinitionInfo(x, typeChecker, symbol, node)) : [createDefinitionInfo(
-        last(declarations),
-        typeChecker,
-        symbol,
-        node,
-        /*unverified*/
-        false,
-        failedAliasResolution
-      )] : void 0;
-    }
-  }
-  function createDefinitionInfo(declaration, checker, symbol, node, unverified, failedAliasResolution) {
-    const symbolName2 = checker.symbolToString(symbol);
-    const symbolKind = ts_SymbolDisplay_exports.getSymbolKind(checker, symbol, node);
-    const containerName = symbol.parent ? checker.symbolToString(symbol.parent, node) : "";
-    return createDefinitionInfoFromName(checker, declaration, symbolKind, symbolName2, containerName, unverified, failedAliasResolution);
-  }
-  function createDefinitionInfoFromName(checker, declaration, symbolKind, symbolName2, containerName, unverified, failedAliasResolution, textSpan) {
-    const sourceFile = declaration.getSourceFile();
-    if (!textSpan) {
-      const name = getNameOfDeclaration(declaration) || declaration;
-      textSpan = createTextSpanFromNode(name, sourceFile);
-    }
-    return {
-      fileName: sourceFile.fileName,
-      textSpan,
-      kind: symbolKind,
-      name: symbolName2,
-      containerKind: void 0,
-      // TODO: GH#18217
-      containerName,
-      ...ts_FindAllReferences_exports.toContextSpan(
-        textSpan,
-        sourceFile,
-        ts_FindAllReferences_exports.getContextNode(declaration)
-      ),
-      isLocal: !isDefinitionVisible(checker, declaration),
-      isAmbient: !!(declaration.flags & 16777216 /* Ambient */),
-      unverified,
-      failedAliasResolution
-    };
-  }
-  function isDefinitionVisible(checker, declaration) {
-    if (checker.isDeclarationVisible(declaration))
-      return true;
-    if (!declaration.parent)
-      return false;
-    if (hasInitializer(declaration.parent) && declaration.parent.initializer === declaration)
-      return isDefinitionVisible(checker, declaration.parent);
-    switch (declaration.kind) {
-      case 171 /* PropertyDeclaration */:
-      case 176 /* GetAccessor */:
-      case 177 /* SetAccessor */:
-      case 173 /* MethodDeclaration */:
-        if (hasEffectiveModifier(declaration, 8 /* Private */))
-          return false;
-      case 175 /* Constructor */:
-      case 302 /* PropertyAssignment */:
-      case 303 /* ShorthandPropertyAssignment */:
-      case 209 /* ObjectLiteralExpression */:
-      case 230 /* ClassExpression */:
-      case 218 /* ArrowFunction */:
-      case 217 /* FunctionExpression */:
-        return isDefinitionVisible(checker, declaration.parent);
-      default:
-        return false;
-    }
-  }
-  function createDefinitionFromSignatureDeclaration(typeChecker, decl, failedAliasResolution) {
-    return createDefinitionInfo(
-      decl,
-      typeChecker,
-      decl.symbol,
-      decl,
-      /*unverified*/
-      false,
-      failedAliasResolution
-    );
-  }
-  function findReferenceInPosition(refs, pos) {
-    return find(refs, (ref) => textRangeContainsPositionInclusive(ref, pos));
-  }
-  function getDefinitionInfoForFileReference(name, targetFileName, unverified) {
-    return {
-      fileName: targetFileName,
-      textSpan: createTextSpanFromBounds(0, 0),
-      kind: "script" /* scriptElement */,
-      name,
-      containerName: void 0,
-      containerKind: void 0,
-      // TODO: GH#18217
-      unverified
-    };
-  }
-  function getAncestorCallLikeExpression(node) {
-    const target = findAncestor(node, (n) => !isRightSideOfPropertyAccess(n));
-    const callLike = target == null ? void 0 : target.parent;
-    return callLike && isCallLikeExpression(callLike) && getInvokedExpression(callLike) === target ? callLike : void 0;
-  }
-  function tryGetSignatureDeclaration(typeChecker, node) {
-    const callLike = getAncestorCallLikeExpression(node);
-    const signature = callLike && typeChecker.getResolvedSignature(callLike);
-    return tryCast(signature && signature.declaration, (d) => isFunctionLike(d) && !isFunctionTypeNode(d));
-  }
-  function isConstructorLike(node) {
-    switch (node.kind) {
-      case 175 /* Constructor */:
-      case 184 /* ConstructorType */:
-      case 179 /* ConstructSignature */:
-        return true;
-      default:
-        return false;
-    }
-  }
-  var init_goToDefinition = __esm({
-    "src/services/goToDefinition.ts"() {
-      "use strict";
-      init_ts4();
-    }
-  });
-
-  // src/services/_namespaces/ts.GoToDefinition.ts
-  var ts_GoToDefinition_exports = {};
-  __export(ts_GoToDefinition_exports, {
-    createDefinitionInfo: () => createDefinitionInfo,
-    findReferenceInPosition: () => findReferenceInPosition,
-    getDefinitionAndBoundSpan: () => getDefinitionAndBoundSpan,
-    getDefinitionAtPosition: () => getDefinitionAtPosition,
-    getReferenceAtPosition: () => getReferenceAtPosition,
-    getTypeDefinitionAtPosition: () => getTypeDefinitionAtPosition
-  });
-  var init_ts_GoToDefinition = __esm({
-    "src/services/_namespaces/ts.GoToDefinition.ts"() {
-      "use strict";
-      init_goToDefinition();
-    }
-  });
-
-  // src/services/inlayHints.ts
-  function shouldShowParameterNameHints(preferences) {
-    return preferences.includeInlayParameterNameHints === "literals" || preferences.includeInlayParameterNameHints === "all";
-  }
-  function shouldShowLiteralParameterNameHintsOnly(preferences) {
-    return preferences.includeInlayParameterNameHints === "literals";
-  }
-  function provideInlayHints(context) {
-    const { file, program, span, cancellationToken, preferences } = context;
-    const sourceFileText = file.text;
-    const compilerOptions = program.getCompilerOptions();
-    const checker = program.getTypeChecker();
-    const result = [];
-    visitor(file);
-    return result;
-    function visitor(node) {
-      if (!node || node.getFullWidth() === 0) {
-        return;
-      }
-      switch (node.kind) {
-        case 266 /* ModuleDeclaration */:
-        case 262 /* ClassDeclaration */:
-        case 263 /* InterfaceDeclaration */:
-        case 261 /* FunctionDeclaration */:
-        case 230 /* ClassExpression */:
-        case 217 /* FunctionExpression */:
-        case 173 /* MethodDeclaration */:
-        case 218 /* ArrowFunction */:
-          cancellationToken.throwIfCancellationRequested();
-      }
-      if (!textSpanIntersectsWith(span, node.pos, node.getFullWidth())) {
-        return;
-      }
-      if (isTypeNode(node) && !isExpressionWithTypeArguments(node)) {
-        return;
-      }
-      if (preferences.includeInlayVariableTypeHints && isVariableDeclaration(node)) {
-        visitVariableLikeDeclaration(node);
-      } else if (preferences.includeInlayPropertyDeclarationTypeHints && isPropertyDeclaration(node)) {
-        visitVariableLikeDeclaration(node);
-      } else if (preferences.includeInlayEnumMemberValueHints && isEnumMember(node)) {
-        visitEnumMember(node);
-      } else if (shouldShowParameterNameHints(preferences) && (isCallExpression(node) || isNewExpression(node))) {
-        visitCallOrNewExpression(node);
-      } else {
-        if (preferences.includeInlayFunctionParameterTypeHints && isFunctionLikeDeclaration(node) && hasContextSensitiveParameters(node)) {
-          visitFunctionLikeForParameterType(node);
-        }
-        if (preferences.includeInlayFunctionLikeReturnTypeHints && isSignatureSupportingReturnAnnotation(node)) {
-          visitFunctionDeclarationLikeForReturnType(node);
-        }
-      }
-      return forEachChild(node, visitor);
-    }
-    function isSignatureSupportingReturnAnnotation(node) {
-      return isArrowFunction(node) || isFunctionExpression(node) || isFunctionDeclaration(node) || isMethodDeclaration(node) || isGetAccessorDeclaration(node);
-    }
-    function addParameterHints(text, position, isFirstVariadicArgument) {
-      result.push({
-        text: `${isFirstVariadicArgument ? "..." : ""}${truncation(text, maxHintsLength)}:`,
-        position,
-        kind: "Parameter" /* Parameter */,
-        whitespaceAfter: true
-      });
-    }
-    function addTypeHints(text, position) {
-      result.push({
-        text: `: ${truncation(text, maxHintsLength)}`,
-        position,
-        kind: "Type" /* Type */,
-        whitespaceBefore: true
-      });
-    }
-    function addEnumMemberValueHints(text, position) {
-      result.push({
-        text: `= ${truncation(text, maxHintsLength)}`,
-        position,
-        kind: "Enum" /* Enum */,
-        whitespaceBefore: true
-      });
-    }
-    function visitEnumMember(member) {
-      if (member.initializer) {
-        return;
-      }
-      const enumValue = checker.getConstantValue(member);
-      if (enumValue !== void 0) {
-        addEnumMemberValueHints(enumValue.toString(), member.end);
-      }
-    }
-    function isModuleReferenceType(type) {
-      return type.symbol && type.symbol.flags & 1536 /* Module */;
-    }
-    function visitVariableLikeDeclaration(decl) {
-      if (!decl.initializer || isBindingPattern(decl.name) || isVariableDeclaration(decl) && !isHintableDeclaration(decl)) {
-        return;
-      }
-      const effectiveTypeAnnotation = getEffectiveTypeAnnotationNode(decl);
-      if (effectiveTypeAnnotation) {
-        return;
-      }
-      const declarationType = checker.getTypeAtLocation(decl);
-      if (isModuleReferenceType(declarationType)) {
-        return;
-      }
-      const typeDisplayString = printTypeInSingleLine(declarationType);
-      if (typeDisplayString) {
-        const isVariableNameMatchesType = preferences.includeInlayVariableTypeHintsWhenTypeMatchesName === false && equateStringsCaseInsensitive(decl.name.getText(), typeDisplayString);
-        if (isVariableNameMatchesType) {
-          return;
-        }
-        addTypeHints(typeDisplayString, decl.name.end);
-      }
-    }
-    function visitCallOrNewExpression(expr) {
-      const args = expr.arguments;
-      if (!args || !args.length) {
-        return;
-      }
-      const candidates = [];
-      const signature = checker.getResolvedSignatureForSignatureHelp(expr, candidates);
-      if (!signature || !candidates.length) {
-        return;
-      }
-      for (let i = 0; i < args.length; ++i) {
-        const originalArg = args[i];
-        const arg = skipParentheses(originalArg);
-        if (shouldShowLiteralParameterNameHintsOnly(preferences) && !isHintableLiteral(arg)) {
-          continue;
-        }
-        const identifierNameInfo = checker.getParameterIdentifierNameAtPosition(signature, i);
-        if (identifierNameInfo) {
-          const [parameterName, isFirstVariadicArgument] = identifierNameInfo;
-          const isParameterNameNotSameAsArgument = preferences.includeInlayParameterNameHintsWhenArgumentMatchesName || !identifierOrAccessExpressionPostfixMatchesParameterName(arg, parameterName);
-          if (!isParameterNameNotSameAsArgument && !isFirstVariadicArgument) {
-            continue;
-          }
-          const name = unescapeLeadingUnderscores(parameterName);
-          if (leadingCommentsContainsParameterName(arg, name)) {
-            continue;
-          }
-          addParameterHints(name, originalArg.getStart(), isFirstVariadicArgument);
-        }
-      }
-    }
-    function identifierOrAccessExpressionPostfixMatchesParameterName(expr, parameterName) {
-      if (isIdentifier(expr)) {
-        return expr.text === parameterName;
-      }
-      if (isPropertyAccessExpression(expr)) {
-        return expr.name.text === parameterName;
-      }
-      return false;
-    }
-    function leadingCommentsContainsParameterName(node, name) {
-      if (!isIdentifierText(name, compilerOptions.target, getLanguageVariant(file.scriptKind))) {
-        return false;
-      }
-      const ranges = getLeadingCommentRanges(sourceFileText, node.pos);
-      if (!(ranges == null ? void 0 : ranges.length)) {
-        return false;
-      }
-      const regex = leadingParameterNameCommentRegexFactory(name);
-      return some(ranges, (range) => regex.test(sourceFileText.substring(range.pos, range.end)));
-    }
-    function isHintableLiteral(node) {
-      switch (node.kind) {
-        case 223 /* PrefixUnaryExpression */: {
-          const operand = node.operand;
-          return isLiteralExpression(operand) || isIdentifier(operand) && isInfinityOrNaNString(operand.escapedText);
-        }
-        case 112 /* TrueKeyword */:
-        case 97 /* FalseKeyword */:
-        case 106 /* NullKeyword */:
-        case 15 /* NoSubstitutionTemplateLiteral */:
-        case 227 /* TemplateExpression */:
-          return true;
-        case 80 /* Identifier */: {
-          const name = node.escapedText;
-          return isUndefined(name) || isInfinityOrNaNString(name);
-        }
-      }
-      return isLiteralExpression(node);
-    }
-    function visitFunctionDeclarationLikeForReturnType(decl) {
-      if (isArrowFunction(decl)) {
-        if (!findChildOfKind(decl, 21 /* OpenParenToken */, file)) {
-          return;
-        }
-      }
-      const effectiveTypeAnnotation = getEffectiveReturnTypeNode(decl);
-      if (effectiveTypeAnnotation || !decl.body) {
-        return;
-      }
-      const signature = checker.getSignatureFromDeclaration(decl);
-      if (!signature) {
-        return;
-      }
-      const returnType = checker.getReturnTypeOfSignature(signature);
-      if (isModuleReferenceType(returnType)) {
-        return;
-      }
-      const typeDisplayString = printTypeInSingleLine(returnType);
-      if (!typeDisplayString) {
-        return;
-      }
-      addTypeHints(typeDisplayString, getTypeAnnotationPosition(decl));
-    }
-    function getTypeAnnotationPosition(decl) {
-      const closeParenToken = findChildOfKind(decl, 22 /* CloseParenToken */, file);
-      if (closeParenToken) {
-        return closeParenToken.end;
-      }
-      return decl.parameters.end;
-    }
-    function visitFunctionLikeForParameterType(node) {
-      const signature = checker.getSignatureFromDeclaration(node);
-      if (!signature) {
-        return;
-      }
-      for (let i = 0; i < node.parameters.length && i < signature.parameters.length; ++i) {
-        const param = node.parameters[i];
-        if (!isHintableDeclaration(param)) {
-          continue;
-        }
-        const effectiveTypeAnnotation = getEffectiveTypeAnnotationNode(param);
-        if (effectiveTypeAnnotation) {
-          continue;
-        }
-        const typeDisplayString = getParameterDeclarationTypeDisplayString(signature.parameters[i]);
-        if (!typeDisplayString) {
-          continue;
-        }
-        addTypeHints(typeDisplayString, param.questionToken ? param.questionToken.end : param.name.end);
-      }
-    }
-    function getParameterDeclarationTypeDisplayString(symbol) {
-      const valueDeclaration = symbol.valueDeclaration;
-      if (!valueDeclaration || !isParameter(valueDeclaration)) {
-        return void 0;
-      }
-      const signatureParamType = checker.getTypeOfSymbolAtLocation(symbol, valueDeclaration);
-      if (isModuleReferenceType(signatureParamType)) {
-        return void 0;
-      }
-      return printTypeInSingleLine(signatureParamType);
-    }
-    function truncation(text, maxLength2) {
-      if (text.length > maxLength2) {
-        return text.substr(0, maxLength2 - "...".length) + "...";
-      }
-      return text;
-    }
-    function printTypeInSingleLine(type) {
-      const flags = 70221824 /* IgnoreErrors */ | 1048576 /* AllowUniqueESSymbolType */ | 16384 /* UseAliasDefinedOutsideCurrentScope */;
-      const printer = createPrinterWithRemoveComments();
-      return usingSingleLineStringWriter((writer) => {
-        const typeNode = checker.typeToTypeNode(
-          type,
-          /*enclosingDeclaration*/
-          void 0,
-          flags
-        );
-        Debug.assertIsDefined(typeNode, "should always get typenode");
-        printer.writeNode(
-          4 /* Unspecified */,
-          typeNode,
-          /*sourceFile*/
-          file,
-          writer
-        );
-      });
-    }
-    function isUndefined(name) {
-      return name === "undefined";
-    }
-    function isHintableDeclaration(node) {
-      if ((isParameterDeclaration(node) || isVariableDeclaration(node) && isVarConst(node)) && node.initializer) {
-        const initializer = skipParentheses(node.initializer);
-        return !(isHintableLiteral(initializer) || isNewExpression(initializer) || isObjectLiteralExpression(initializer) || isAssertionExpression(initializer));
-      }
-      return true;
-    }
-  }
-  var maxHintsLength, leadingParameterNameCommentRegexFactory;
-  var init_inlayHints = __esm({
-    "src/services/inlayHints.ts"() {
-      "use strict";
-      init_ts4();
-      maxHintsLength = 30;
-      leadingParameterNameCommentRegexFactory = (name) => {
-        return new RegExp(`^\\s?/\\*\\*?\\s?${name}\\s?\\*\\/\\s?$`);
-      };
-    }
-  });
-
-  // src/services/_namespaces/ts.InlayHints.ts
-  var ts_InlayHints_exports = {};
-  __export(ts_InlayHints_exports, {
-    provideInlayHints: () => provideInlayHints
-  });
-  var init_ts_InlayHints = __esm({
-    "src/services/_namespaces/ts.InlayHints.ts"() {
-      "use strict";
-      init_inlayHints();
-    }
-  });
-
-  // src/services/jsDoc.ts
-  function getJsDocCommentsFromDeclarations(declarations, checker) {
-    const parts = [];
-    forEachUnique(declarations, (declaration) => {
-      for (const jsdoc of getCommentHavingNodes(declaration)) {
-        const inheritDoc = isJSDoc(jsdoc) && jsdoc.tags && find(jsdoc.tags, (t) => t.kind === 333 /* JSDocTag */ && (t.tagName.escapedText === "inheritDoc" || t.tagName.escapedText === "inheritdoc"));
-        if (jsdoc.comment === void 0 && !inheritDoc || isJSDoc(jsdoc) && declaration.kind !== 352 /* JSDocTypedefTag */ && declaration.kind !== 344 /* JSDocCallbackTag */ && jsdoc.tags && jsdoc.tags.some((t) => t.kind === 352 /* JSDocTypedefTag */ || t.kind === 344 /* JSDocCallbackTag */) && !jsdoc.tags.some((t) => t.kind === 347 /* JSDocParameterTag */ || t.kind === 348 /* JSDocReturnTag */)) {
-          continue;
-        }
-        let newparts = jsdoc.comment ? getDisplayPartsFromComment(jsdoc.comment, checker) : [];
-        if (inheritDoc && inheritDoc.comment) {
-          newparts = newparts.concat(getDisplayPartsFromComment(inheritDoc.comment, checker));
-        }
-        if (!contains(parts, newparts, isIdenticalListOfDisplayParts)) {
-          parts.push(newparts);
-        }
-      }
-    });
-    return flatten(intersperse(parts, [lineBreakPart()]));
-  }
-  function isIdenticalListOfDisplayParts(parts1, parts2) {
-    return arraysEqual(parts1, parts2, (p1, p2) => p1.kind === p2.kind && p1.text === p2.text);
-  }
-  function getCommentHavingNodes(declaration) {
-    switch (declaration.kind) {
-      case 347 /* JSDocParameterTag */:
-      case 354 /* JSDocPropertyTag */:
-        return [declaration];
-      case 344 /* JSDocCallbackTag */:
-      case 352 /* JSDocTypedefTag */:
-        return [declaration, declaration.parent];
-      default:
-        return getJSDocCommentsAndTags(declaration);
-    }
-  }
-  function getJsDocTagsFromDeclarations(declarations, checker) {
-    const infos = [];
-    forEachUnique(declarations, (declaration) => {
-      const tags = getJSDocTags(declaration);
-      if (tags.some((t) => t.kind === 352 /* JSDocTypedefTag */ || t.kind === 344 /* JSDocCallbackTag */) && !tags.some((t) => t.kind === 347 /* JSDocParameterTag */ || t.kind === 348 /* JSDocReturnTag */)) {
-        return;
-      }
-      for (const tag of tags) {
-        infos.push({ name: tag.tagName.text, text: getCommentDisplayParts(tag, checker) });
-      }
-    });
-    return infos;
-  }
-  function getDisplayPartsFromComment(comment, checker) {
-    if (typeof comment === "string") {
-      return [textPart(comment)];
-    }
-    return flatMap(
-      comment,
-      (node) => node.kind === 327 /* JSDocText */ ? [textPart(node.text)] : buildLinkParts(node, checker)
-    );
-  }
-  function getCommentDisplayParts(tag, checker) {
-    const { comment, kind } = tag;
-    const namePart = getTagNameDisplayPart(kind);
-    switch (kind) {
-      case 355 /* JSDocThrowsTag */:
-        const typeExpression = tag.typeExpression;
-        return typeExpression ? withNode(typeExpression) : comment === void 0 ? void 0 : getDisplayPartsFromComment(comment, checker);
-      case 335 /* JSDocImplementsTag */:
-        return withNode(tag.class);
-      case 334 /* JSDocAugmentsTag */:
-        return withNode(tag.class);
-      case 351 /* JSDocTemplateTag */:
-        const templateTag = tag;
-        const displayParts = [];
-        if (templateTag.constraint) {
-          displayParts.push(textPart(templateTag.constraint.getText()));
-        }
-        if (length(templateTag.typeParameters)) {
-          if (length(displayParts)) {
-            displayParts.push(spacePart());
-          }
-          const lastTypeParameter = templateTag.typeParameters[templateTag.typeParameters.length - 1];
-          forEach(templateTag.typeParameters, (tp) => {
-            displayParts.push(namePart(tp.getText()));
-            if (lastTypeParameter !== tp) {
-              displayParts.push(...[punctuationPart(28 /* CommaToken */), spacePart()]);
-            }
-          });
-        }
-        if (comment) {
-          displayParts.push(...[spacePart(), ...getDisplayPartsFromComment(comment, checker)]);
-        }
-        return displayParts;
-      case 350 /* JSDocTypeTag */:
-      case 356 /* JSDocSatisfiesTag */:
-        return withNode(tag.typeExpression);
-      case 352 /* JSDocTypedefTag */:
-      case 344 /* JSDocCallbackTag */:
-      case 354 /* JSDocPropertyTag */:
-      case 347 /* JSDocParameterTag */:
-      case 353 /* JSDocSeeTag */:
-        const { name } = tag;
-        return name ? withNode(name) : comment === void 0 ? void 0 : getDisplayPartsFromComment(comment, checker);
-      default:
-        return comment === void 0 ? void 0 : getDisplayPartsFromComment(comment, checker);
-    }
-    function withNode(node) {
-      return addComment(node.getText());
-    }
-    function addComment(s) {
-      if (comment) {
-        if (s.match(/^https?$/)) {
-          return [textPart(s), ...getDisplayPartsFromComment(comment, checker)];
-        } else {
-          return [namePart(s), spacePart(), ...getDisplayPartsFromComment(comment, checker)];
-        }
-      } else {
-        return [textPart(s)];
-      }
-    }
-  }
-  function getTagNameDisplayPart(kind) {
-    switch (kind) {
-      case 347 /* JSDocParameterTag */:
-        return parameterNamePart;
-      case 354 /* JSDocPropertyTag */:
-        return propertyNamePart;
-      case 351 /* JSDocTemplateTag */:
-        return typeParameterNamePart;
-      case 352 /* JSDocTypedefTag */:
-      case 344 /* JSDocCallbackTag */:
-        return typeAliasNamePart;
-      default:
-        return textPart;
-    }
-  }
-  function getJSDocTagNameCompletions() {
-    return jsDocTagNameCompletionEntries || (jsDocTagNameCompletionEntries = map(jsDocTagNames, (tagName) => {
-      return {
-        name: tagName,
-        kind: "keyword" /* keyword */,
-        kindModifiers: "",
-        sortText: ts_Completions_exports.SortText.LocationPriority
-      };
-    }));
-  }
-  function getJSDocTagCompletions() {
-    return jsDocTagCompletionEntries || (jsDocTagCompletionEntries = map(jsDocTagNames, (tagName) => {
-      return {
-        name: `@${tagName}`,
-        kind: "keyword" /* keyword */,
-        kindModifiers: "",
-        sortText: ts_Completions_exports.SortText.LocationPriority
-      };
-    }));
-  }
-  function getJSDocTagCompletionDetails(name) {
-    return {
-      name,
-      kind: "" /* unknown */,
-      // TODO: should have its own kind?
-      kindModifiers: "",
-      displayParts: [textPart(name)],
-      documentation: emptyArray,
-      tags: void 0,
-      codeActions: void 0
-    };
-  }
-  function getJSDocParameterNameCompletions(tag) {
-    if (!isIdentifier(tag.name)) {
-      return emptyArray;
-    }
-    const nameThusFar = tag.name.text;
-    const jsdoc = tag.parent;
-    const fn = jsdoc.parent;
-    if (!isFunctionLike(fn))
-      return [];
-    return mapDefined(fn.parameters, (param) => {
-      if (!isIdentifier(param.name))
-        return void 0;
-      const name = param.name.text;
-      if (jsdoc.tags.some((t) => t !== tag && isJSDocParameterTag(t) && isIdentifier(t.name) && t.name.escapedText === name) || nameThusFar !== void 0 && !startsWith(name, nameThusFar)) {
-        return void 0;
-      }
-      return { name, kind: "parameter" /* parameterElement */, kindModifiers: "", sortText: ts_Completions_exports.SortText.LocationPriority };
-    });
-  }
-  function getJSDocParameterNameCompletionDetails(name) {
-    return {
-      name,
-      kind: "parameter" /* parameterElement */,
-      kindModifiers: "",
-      displayParts: [textPart(name)],
-      documentation: emptyArray,
-      tags: void 0,
-      codeActions: void 0
-    };
-  }
-  function getDocCommentTemplateAtPosition(newLine, sourceFile, position, options) {
-    const tokenAtPos = getTokenAtPosition(sourceFile, position);
-    const existingDocComment = findAncestor(tokenAtPos, isJSDoc);
-    if (existingDocComment && (existingDocComment.comment !== void 0 || length(existingDocComment.tags))) {
-      return void 0;
-    }
-    const tokenStart = tokenAtPos.getStart(sourceFile);
-    if (!existingDocComment && tokenStart < position) {
-      return void 0;
-    }
-    const commentOwnerInfo = getCommentOwnerInfo(tokenAtPos, options);
-    if (!commentOwnerInfo) {
-      return void 0;
-    }
-    const { commentOwner, parameters, hasReturn: hasReturn2 } = commentOwnerInfo;
-    const commentOwnerJsDoc = hasJSDocNodes(commentOwner) && commentOwner.jsDoc ? commentOwner.jsDoc : void 0;
-    const lastJsDoc = lastOrUndefined(commentOwnerJsDoc);
-    if (commentOwner.getStart(sourceFile) < position || lastJsDoc && existingDocComment && lastJsDoc !== existingDocComment) {
-      return void 0;
-    }
-    const indentationStr = getIndentationStringAtPosition(sourceFile, position);
-    const isJavaScriptFile = hasJSFileExtension(sourceFile.fileName);
-    const tags = (parameters ? parameterDocComments(parameters || [], isJavaScriptFile, indentationStr, newLine) : "") + (hasReturn2 ? returnsDocComment(indentationStr, newLine) : "");
-    const openComment = "/**";
-    const closeComment = " */";
-    const hasTag = (commentOwnerJsDoc || []).some((jsDoc) => !!jsDoc.tags);
-    if (tags && !hasTag) {
-      const preamble = openComment + newLine + indentationStr + " * ";
-      const endLine = tokenStart === position ? newLine + indentationStr : "";
-      const result = preamble + newLine + tags + indentationStr + closeComment + endLine;
-      return { newText: result, caretOffset: preamble.length };
-    }
-    return { newText: openComment + closeComment, caretOffset: 3 };
-  }
-  function getIndentationStringAtPosition(sourceFile, position) {
-    const { text } = sourceFile;
-    const lineStart = getLineStartPositionForPosition(position, sourceFile);
-    let pos = lineStart;
-    for (; pos <= position && isWhiteSpaceSingleLine(text.charCodeAt(pos)); pos++)
-      ;
-    return text.slice(lineStart, pos);
-  }
-  function parameterDocComments(parameters, isJavaScriptFile, indentationStr, newLine) {
-    return parameters.map(({ name, dotDotDotToken }, i) => {
-      const paramName = name.kind === 80 /* Identifier */ ? name.text : "param" + i;
-      const type = isJavaScriptFile ? dotDotDotToken ? "{...any} " : "{any} " : "";
-      return `${indentationStr} * @param ${type}${paramName}${newLine}`;
-    }).join("");
-  }
-  function returnsDocComment(indentationStr, newLine) {
-    return `${indentationStr} * @returns${newLine}`;
-  }
-  function getCommentOwnerInfo(tokenAtPos, options) {
-    return forEachAncestor(tokenAtPos, (n) => getCommentOwnerInfoWorker(n, options));
-  }
-  function getCommentOwnerInfoWorker(commentOwner, options) {
-    switch (commentOwner.kind) {
-      case 261 /* FunctionDeclaration */:
-      case 217 /* FunctionExpression */:
-      case 173 /* MethodDeclaration */:
-      case 175 /* Constructor */:
-      case 172 /* MethodSignature */:
-      case 218 /* ArrowFunction */:
-        const host = commentOwner;
-        return { commentOwner, parameters: host.parameters, hasReturn: hasReturn(host, options) };
-      case 302 /* PropertyAssignment */:
-        return getCommentOwnerInfoWorker(commentOwner.initializer, options);
-      case 262 /* ClassDeclaration */:
-      case 263 /* InterfaceDeclaration */:
-      case 265 /* EnumDeclaration */:
-      case 305 /* EnumMember */:
-      case 264 /* TypeAliasDeclaration */:
-        return { commentOwner };
-      case 170 /* PropertySignature */: {
-        const host2 = commentOwner;
-        return host2.type && isFunctionTypeNode(host2.type) ? { commentOwner, parameters: host2.type.parameters, hasReturn: hasReturn(host2.type, options) } : { commentOwner };
-      }
-      case 242 /* VariableStatement */: {
-        const varStatement = commentOwner;
-        const varDeclarations = varStatement.declarationList.declarations;
-        const host2 = varDeclarations.length === 1 && varDeclarations[0].initializer ? getRightHandSideOfAssignment(varDeclarations[0].initializer) : void 0;
-        return host2 ? { commentOwner, parameters: host2.parameters, hasReturn: hasReturn(host2, options) } : { commentOwner };
-      }
-      case 311 /* SourceFile */:
-        return "quit";
-      case 266 /* ModuleDeclaration */:
-        return commentOwner.parent.kind === 266 /* ModuleDeclaration */ ? void 0 : { commentOwner };
-      case 243 /* ExpressionStatement */:
-        return getCommentOwnerInfoWorker(commentOwner.expression, options);
-      case 225 /* BinaryExpression */: {
-        const be = commentOwner;
-        if (getAssignmentDeclarationKind(be) === 0 /* None */) {
-          return "quit";
-        }
-        return isFunctionLike(be.right) ? { commentOwner, parameters: be.right.parameters, hasReturn: hasReturn(be.right, options) } : { commentOwner };
-      }
-      case 171 /* PropertyDeclaration */:
-        const init = commentOwner.initializer;
-        if (init && (isFunctionExpression(init) || isArrowFunction(init))) {
-          return { commentOwner, parameters: init.parameters, hasReturn: hasReturn(init, options) };
-        }
-    }
-  }
-  function hasReturn(node, options) {
-    return !!(options == null ? void 0 : options.generateReturnInDocTemplate) && (isFunctionTypeNode(node) || isArrowFunction(node) && isExpression(node.body) || isFunctionLikeDeclaration(node) && node.body && isBlock(node.body) && !!forEachReturnStatement(node.body, (n) => n));
-  }
-  function getRightHandSideOfAssignment(rightHandSide) {
-    while (rightHandSide.kind === 216 /* ParenthesizedExpression */) {
-      rightHandSide = rightHandSide.expression;
-    }
-    switch (rightHandSide.kind) {
-      case 217 /* FunctionExpression */:
-      case 218 /* ArrowFunction */:
-        return rightHandSide;
-      case 230 /* ClassExpression */:
-        return find(rightHandSide.members, isConstructorDeclaration);
-    }
-  }
-  var jsDocTagNames, jsDocTagNameCompletionEntries, jsDocTagCompletionEntries, getJSDocTagNameCompletionDetails;
-  var init_jsDoc = __esm({
-    "src/services/jsDoc.ts"() {
-      "use strict";
-      init_ts4();
-      jsDocTagNames = [
-        "abstract",
-        "access",
-        "alias",
-        "argument",
-        "async",
-        "augments",
-        "author",
-        "borrows",
-        "callback",
-        "class",
-        "classdesc",
-        "constant",
-        "constructor",
-        "constructs",
-        "copyright",
-        "default",
-        "deprecated",
-        "description",
-        "emits",
-        "enum",
-        "event",
-        "example",
-        "exports",
-        "extends",
-        "external",
-        "field",
-        "file",
-        "fileoverview",
-        "fires",
-        "function",
-        "generator",
-        "global",
-        "hideconstructor",
-        "host",
-        "ignore",
-        "implements",
-        "inheritdoc",
-        "inner",
-        "instance",
-        "interface",
-        "kind",
-        "lends",
-        "license",
-        "link",
-        "linkcode",
-        "linkplain",
-        "listens",
-        "member",
-        "memberof",
-        "method",
-        "mixes",
-        "module",
-        "name",
-        "namespace",
-        "overload",
-        "override",
-        "package",
-        "param",
-        "private",
-        "prop",
-        "property",
-        "protected",
-        "public",
-        "readonly",
-        "requires",
-        "returns",
-        "satisfies",
-        "see",
-        "since",
-        "static",
-        "summary",
-        "template",
-        "this",
-        "throws",
-        "todo",
-        "tutorial",
-        "type",
-        "typedef",
-        "var",
-        "variation",
-        "version",
-        "virtual",
-        "yields"
-      ];
-      getJSDocTagNameCompletionDetails = getJSDocTagCompletionDetails;
-    }
-  });
-
-  // src/services/_namespaces/ts.JsDoc.ts
-  var ts_JsDoc_exports = {};
-  __export(ts_JsDoc_exports, {
-    getDocCommentTemplateAtPosition: () => getDocCommentTemplateAtPosition,
-    getJSDocParameterNameCompletionDetails: () => getJSDocParameterNameCompletionDetails,
-    getJSDocParameterNameCompletions: () => getJSDocParameterNameCompletions,
-    getJSDocTagCompletionDetails: () => getJSDocTagCompletionDetails,
-    getJSDocTagCompletions: () => getJSDocTagCompletions,
-    getJSDocTagNameCompletionDetails: () => getJSDocTagNameCompletionDetails,
-    getJSDocTagNameCompletions: () => getJSDocTagNameCompletions,
-    getJsDocCommentsFromDeclarations: () => getJsDocCommentsFromDeclarations,
-    getJsDocTagsFromDeclarations: () => getJsDocTagsFromDeclarations
-  });
-  var init_ts_JsDoc = __esm({
-    "src/services/_namespaces/ts.JsDoc.ts"() {
-      "use strict";
-      init_jsDoc();
-    }
-  });
-
-  // src/services/organizeImports.ts
-  function organizeImports(sourceFile, formatContext, host, program, preferences, mode) {
-    const changeTracker = ts_textChanges_exports.ChangeTracker.fromContext({ host, formatContext, preferences });
-    const shouldSort = mode === "SortAndCombine" /* SortAndCombine */ || mode === "All" /* All */;
-    const shouldCombine = shouldSort;
-    const shouldRemove = mode === "RemoveUnused" /* RemoveUnused */ || mode === "All" /* All */;
-    const topLevelImportGroupDecls = groupByNewlineContiguous(sourceFile, sourceFile.statements.filter(isImportDeclaration));
-    const comparer = getOrganizeImportsComparerWithDetection(preferences, shouldSort ? () => detectSortingWorker(topLevelImportGroupDecls, preferences) === 2 /* CaseInsensitive */ : void 0);
-    const processImportsOfSameModuleSpecifier = (importGroup) => {
-      if (shouldRemove)
-        importGroup = removeUnusedImports(importGroup, sourceFile, program);
-      if (shouldCombine)
-        importGroup = coalesceImportsWorker(importGroup, comparer, sourceFile);
-      if (shouldSort)
-        importGroup = stableSort(importGroup, (s1, s2) => compareImportsOrRequireStatements(s1, s2, comparer));
-      return importGroup;
-    };
-    topLevelImportGroupDecls.forEach((importGroupDecl) => organizeImportsWorker(importGroupDecl, processImportsOfSameModuleSpecifier));
-    if (mode !== "RemoveUnused" /* RemoveUnused */) {
-      getTopLevelExportGroups(sourceFile).forEach((exportGroupDecl) => organizeImportsWorker(exportGroupDecl, (group2) => coalesceExportsWorker(group2, comparer)));
-    }
-    for (const ambientModule of sourceFile.statements.filter(isAmbientModule)) {
-      if (!ambientModule.body)
-        continue;
-      const ambientModuleImportGroupDecls = groupByNewlineContiguous(sourceFile, ambientModule.body.statements.filter(isImportDeclaration));
-      ambientModuleImportGroupDecls.forEach((importGroupDecl) => organizeImportsWorker(importGroupDecl, processImportsOfSameModuleSpecifier));
-      if (mode !== "RemoveUnused" /* RemoveUnused */) {
-        const ambientModuleExportDecls = ambientModule.body.statements.filter(isExportDeclaration);
-        organizeImportsWorker(ambientModuleExportDecls, (group2) => coalesceExportsWorker(group2, comparer));
-      }
-    }
-    return changeTracker.getChanges();
-    function organizeImportsWorker(oldImportDecls, coalesce) {
-      if (length(oldImportDecls) === 0) {
-        return;
-      }
-      suppressLeadingTrivia(oldImportDecls[0]);
-      const oldImportGroups = shouldCombine ? group(oldImportDecls, (importDecl) => getExternalModuleName2(importDecl.moduleSpecifier)) : [oldImportDecls];
-      const sortedImportGroups = shouldSort ? stableSort(oldImportGroups, (group1, group2) => compareModuleSpecifiersWorker(group1[0].moduleSpecifier, group2[0].moduleSpecifier, comparer)) : oldImportGroups;
-      const newImportDecls = flatMap(sortedImportGroups, (importGroup) => getExternalModuleName2(importGroup[0].moduleSpecifier) || importGroup[0].moduleSpecifier === void 0 ? coalesce(importGroup) : importGroup);
-      if (newImportDecls.length === 0) {
-        changeTracker.deleteNodes(
-          sourceFile,
-          oldImportDecls,
-          {
-            leadingTriviaOption: ts_textChanges_exports.LeadingTriviaOption.Exclude,
-            trailingTriviaOption: ts_textChanges_exports.TrailingTriviaOption.Include
-          },
-          /*hasTrailingComment*/
-          true
-        );
-      } else {
-        const replaceOptions = {
-          leadingTriviaOption: ts_textChanges_exports.LeadingTriviaOption.Exclude,
-          // Leave header comment in place
-          trailingTriviaOption: ts_textChanges_exports.TrailingTriviaOption.Include,
-          suffix: getNewLineOrDefaultFromHost(host, formatContext.options)
-        };
-        changeTracker.replaceNodeWithNodes(sourceFile, oldImportDecls[0], newImportDecls, replaceOptions);
-        const hasTrailingComment = changeTracker.nodeHasTrailingComment(sourceFile, oldImportDecls[0], replaceOptions);
-        changeTracker.deleteNodes(sourceFile, oldImportDecls.slice(1), {
-          trailingTriviaOption: ts_textChanges_exports.TrailingTriviaOption.Include
-        }, hasTrailingComment);
-      }
-    }
-  }
-  function groupByNewlineContiguous(sourceFile, decls) {
-    const scanner2 = createScanner(
-      sourceFile.languageVersion,
-      /*skipTrivia*/
-      false,
-      sourceFile.languageVariant
-    );
-    const group2 = [];
-    let groupIndex = 0;
-    for (const decl of decls) {
-      if (group2[groupIndex] && isNewGroup(sourceFile, decl, scanner2)) {
-        groupIndex++;
-      }
-      if (!group2[groupIndex]) {
-        group2[groupIndex] = [];
-      }
-      group2[groupIndex].push(decl);
-    }
-    return group2;
-  }
-  function isNewGroup(sourceFile, decl, scanner2) {
-    const startPos = decl.getFullStart();
-    const endPos = decl.getStart();
-    scanner2.setText(sourceFile.text, startPos, endPos - startPos);
-    let numberOfNewLines = 0;
-    while (scanner2.getTokenStart() < endPos) {
-      const tokenKind = scanner2.scan();
-      if (tokenKind === 4 /* NewLineTrivia */) {
-        numberOfNewLines++;
-        if (numberOfNewLines >= 2) {
-          return true;
-        }
-      }
-    }
-    return false;
-  }
-  function removeUnusedImports(oldImports, sourceFile, program) {
-    const typeChecker = program.getTypeChecker();
-    const compilerOptions = program.getCompilerOptions();
-    const jsxNamespace = typeChecker.getJsxNamespace(sourceFile);
-    const jsxFragmentFactory = typeChecker.getJsxFragmentFactory(sourceFile);
-    const jsxElementsPresent = !!(sourceFile.transformFlags & 2 /* ContainsJsx */);
-    const usedImports = [];
-    for (const importDecl of oldImports) {
-      const { importClause, moduleSpecifier } = importDecl;
-      if (!importClause) {
-        usedImports.push(importDecl);
-        continue;
-      }
-      let { name, namedBindings } = importClause;
-      if (name && !isDeclarationUsed(name)) {
-        name = void 0;
-      }
-      if (namedBindings) {
-        if (isNamespaceImport(namedBindings)) {
-          if (!isDeclarationUsed(namedBindings.name)) {
-            namedBindings = void 0;
-          }
-        } else {
-          const newElements = namedBindings.elements.filter((e) => isDeclarationUsed(e.name));
-          if (newElements.length < namedBindings.elements.length) {
-            namedBindings = newElements.length ? factory.updateNamedImports(namedBindings, newElements) : void 0;
-          }
-        }
-      }
-      if (name || namedBindings) {
-        usedImports.push(updateImportDeclarationAndClause(importDecl, name, namedBindings));
-      } else if (hasModuleDeclarationMatchingSpecifier(sourceFile, moduleSpecifier)) {
-        if (sourceFile.isDeclarationFile) {
-          usedImports.push(factory.createImportDeclaration(
-            importDecl.modifiers,
-            /*importClause*/
-            void 0,
-            moduleSpecifier,
-            /*assertClause*/
-            void 0
-          ));
-        } else {
-          usedImports.push(importDecl);
-        }
-      }
-    }
-    return usedImports;
-    function isDeclarationUsed(identifier) {
-      return jsxElementsPresent && (identifier.text === jsxNamespace || jsxFragmentFactory && identifier.text === jsxFragmentFactory) && jsxModeNeedsExplicitImport(compilerOptions.jsx) || ts_FindAllReferences_exports.Core.isSymbolReferencedInFile(identifier, typeChecker, sourceFile);
-    }
-  }
-  function hasModuleDeclarationMatchingSpecifier(sourceFile, moduleSpecifier) {
-    const moduleSpecifierText = isStringLiteral(moduleSpecifier) && moduleSpecifier.text;
-    return isString(moduleSpecifierText) && some(sourceFile.moduleAugmentations, (moduleName) => isStringLiteral(moduleName) && moduleName.text === moduleSpecifierText);
-  }
-  function getExternalModuleName2(specifier) {
-    return specifier !== void 0 && isStringLiteralLike(specifier) ? specifier.text : void 0;
-  }
-  function coalesceImports(importGroup, ignoreCase, sourceFile) {
-    const comparer = getOrganizeImportsOrdinalStringComparer(ignoreCase);
-    return coalesceImportsWorker(importGroup, comparer, sourceFile);
-  }
-  function coalesceImportsWorker(importGroup, comparer, sourceFile) {
-    if (importGroup.length === 0) {
-      return importGroup;
-    }
-    const { importWithoutClause, typeOnlyImports, regularImports } = getCategorizedImports(importGroup);
-    const coalescedImports = [];
-    if (importWithoutClause) {
-      coalescedImports.push(importWithoutClause);
-    }
-    for (const group2 of [regularImports, typeOnlyImports]) {
-      const isTypeOnly = group2 === typeOnlyImports;
-      const { defaultImports, namespaceImports, namedImports } = group2;
-      if (!isTypeOnly && defaultImports.length === 1 && namespaceImports.length === 1 && namedImports.length === 0) {
-        const defaultImport = defaultImports[0];
-        coalescedImports.push(
-          updateImportDeclarationAndClause(defaultImport, defaultImport.importClause.name, namespaceImports[0].importClause.namedBindings)
-        );
-        continue;
-      }
-      const sortedNamespaceImports = stableSort(namespaceImports, (i1, i2) => comparer(i1.importClause.namedBindings.name.text, i2.importClause.namedBindings.name.text));
-      for (const namespaceImport of sortedNamespaceImports) {
-        coalescedImports.push(
-          updateImportDeclarationAndClause(
-            namespaceImport,
-            /*name*/
-            void 0,
-            namespaceImport.importClause.namedBindings
-          )
-        );
-      }
-      const firstDefaultImport = firstOrUndefined(defaultImports);
-      const firstNamedImport = firstOrUndefined(namedImports);
-      const importDecl = firstDefaultImport ?? firstNamedImport;
-      if (!importDecl) {
-        continue;
-      }
-      let newDefaultImport;
-      const newImportSpecifiers = [];
-      if (defaultImports.length === 1) {
-        newDefaultImport = defaultImports[0].importClause.name;
-      } else {
-        for (const defaultImport of defaultImports) {
-          newImportSpecifiers.push(
-            factory.createImportSpecifier(
-              /*isTypeOnly*/
-              false,
-              factory.createIdentifier("default"),
-              defaultImport.importClause.name
-            )
-          );
-        }
-      }
-      newImportSpecifiers.push(...getNewImportSpecifiers(namedImports));
-      const sortedImportSpecifiers = factory.createNodeArray(
-        sortSpecifiers(newImportSpecifiers, comparer),
-        firstNamedImport == null ? void 0 : firstNamedImport.importClause.namedBindings.elements.hasTrailingComma
-      );
-      const newNamedImports = sortedImportSpecifiers.length === 0 ? newDefaultImport ? void 0 : factory.createNamedImports(emptyArray) : firstNamedImport ? factory.updateNamedImports(firstNamedImport.importClause.namedBindings, sortedImportSpecifiers) : factory.createNamedImports(sortedImportSpecifiers);
-      if (sourceFile && newNamedImports && (firstNamedImport == null ? void 0 : firstNamedImport.importClause.namedBindings) && !rangeIsOnSingleLine(firstNamedImport.importClause.namedBindings, sourceFile)) {
-        setEmitFlags(newNamedImports, 2 /* MultiLine */);
-      }
-      if (isTypeOnly && newDefaultImport && newNamedImports) {
-        coalescedImports.push(
-          updateImportDeclarationAndClause(
-            importDecl,
-            newDefaultImport,
-            /*namedBindings*/
-            void 0
-          )
-        );
-        coalescedImports.push(
-          updateImportDeclarationAndClause(
-            firstNamedImport ?? importDecl,
-            /*name*/
-            void 0,
-            newNamedImports
-          )
-        );
-      } else {
-        coalescedImports.push(
-          updateImportDeclarationAndClause(importDecl, newDefaultImport, newNamedImports)
-        );
-      }
-    }
-    return coalescedImports;
-  }
-  function getCategorizedImports(importGroup) {
-    let importWithoutClause;
-    const typeOnlyImports = { defaultImports: [], namespaceImports: [], namedImports: [] };
-    const regularImports = { defaultImports: [], namespaceImports: [], namedImports: [] };
-    for (const importDeclaration of importGroup) {
-      if (importDeclaration.importClause === void 0) {
-        importWithoutClause = importWithoutClause || importDeclaration;
-        continue;
-      }
-      const group2 = importDeclaration.importClause.isTypeOnly ? typeOnlyImports : regularImports;
-      const { name, namedBindings } = importDeclaration.importClause;
-      if (name) {
-        group2.defaultImports.push(importDeclaration);
-      }
-      if (namedBindings) {
-        if (isNamespaceImport(namedBindings)) {
-          group2.namespaceImports.push(importDeclaration);
-        } else {
-          group2.namedImports.push(importDeclaration);
-        }
-      }
-    }
-    return {
-      importWithoutClause,
-      typeOnlyImports,
-      regularImports
-    };
-  }
-  function coalesceExports(exportGroup, ignoreCase) {
-    const comparer = getOrganizeImportsOrdinalStringComparer(ignoreCase);
-    return coalesceExportsWorker(exportGroup, comparer);
-  }
-  function coalesceExportsWorker(exportGroup, comparer) {
-    if (exportGroup.length === 0) {
-      return exportGroup;
-    }
-    const { exportWithoutClause, namedExports, typeOnlyExports } = getCategorizedExports(exportGroup);
-    const coalescedExports = [];
-    if (exportWithoutClause) {
-      coalescedExports.push(exportWithoutClause);
-    }
-    for (const exportGroup2 of [namedExports, typeOnlyExports]) {
-      if (exportGroup2.length === 0) {
-        continue;
-      }
-      const newExportSpecifiers = [];
-      newExportSpecifiers.push(...flatMap(exportGroup2, (i) => i.exportClause && isNamedExports(i.exportClause) ? i.exportClause.elements : emptyArray));
-      const sortedExportSpecifiers = sortSpecifiers(newExportSpecifiers, comparer);
-      const exportDecl = exportGroup2[0];
-      coalescedExports.push(
-        factory.updateExportDeclaration(
-          exportDecl,
-          exportDecl.modifiers,
-          exportDecl.isTypeOnly,
-          exportDecl.exportClause && (isNamedExports(exportDecl.exportClause) ? factory.updateNamedExports(exportDecl.exportClause, sortedExportSpecifiers) : factory.updateNamespaceExport(exportDecl.exportClause, exportDecl.exportClause.name)),
-          exportDecl.moduleSpecifier,
-          exportDecl.assertClause
-        )
-      );
-    }
-    return coalescedExports;
-    function getCategorizedExports(exportGroup2) {
-      let exportWithoutClause2;
-      const namedExports2 = [];
-      const typeOnlyExports2 = [];
-      for (const exportDeclaration of exportGroup2) {
-        if (exportDeclaration.exportClause === void 0) {
-          exportWithoutClause2 = exportWithoutClause2 || exportDeclaration;
-        } else if (exportDeclaration.isTypeOnly) {
-          typeOnlyExports2.push(exportDeclaration);
-        } else {
-          namedExports2.push(exportDeclaration);
-        }
-      }
-      return {
-        exportWithoutClause: exportWithoutClause2,
-        namedExports: namedExports2,
-        typeOnlyExports: typeOnlyExports2
-      };
-    }
-  }
-  function updateImportDeclarationAndClause(importDeclaration, name, namedBindings) {
-    return factory.updateImportDeclaration(
-      importDeclaration,
-      importDeclaration.modifiers,
-      factory.updateImportClause(importDeclaration.importClause, importDeclaration.importClause.isTypeOnly, name, namedBindings),
-      // TODO: GH#18217
-      importDeclaration.moduleSpecifier,
-      importDeclaration.assertClause
-    );
-  }
-  function sortSpecifiers(specifiers, comparer) {
-    return stableSort(specifiers, (s1, s2) => compareImportOrExportSpecifiers(s1, s2, comparer));
-  }
-  function compareImportOrExportSpecifiers(s1, s2, comparer) {
-    return compareBooleans(s1.isTypeOnly, s2.isTypeOnly) || comparer(s1.name.text, s2.name.text);
-  }
-  function compareModuleSpecifiers2(m1, m2, ignoreCase) {
-    const comparer = getOrganizeImportsOrdinalStringComparer(!!ignoreCase);
-    return compareModuleSpecifiersWorker(m1, m2, comparer);
-  }
-  function compareModuleSpecifiersWorker(m1, m2, comparer) {
-    const name1 = m1 === void 0 ? void 0 : getExternalModuleName2(m1);
-    const name2 = m2 === void 0 ? void 0 : getExternalModuleName2(m2);
-    return compareBooleans(name1 === void 0, name2 === void 0) || compareBooleans(isExternalModuleNameRelative(name1), isExternalModuleNameRelative(name2)) || comparer(name1, name2);
-  }
-  function getModuleSpecifierExpression(declaration) {
-    var _a;
-    switch (declaration.kind) {
-      case 270 /* ImportEqualsDeclaration */:
-        return (_a = tryCast(declaration.moduleReference, isExternalModuleReference)) == null ? void 0 : _a.expression;
-      case 271 /* ImportDeclaration */:
-        return declaration.moduleSpecifier;
-      case 242 /* VariableStatement */:
-        return declaration.declarationList.declarations[0].initializer.arguments[0];
-    }
-  }
-  function detectSorting(sourceFile, preferences) {
-    return detectSortingWorker(
-      groupByNewlineContiguous(sourceFile, sourceFile.statements.filter(isImportDeclaration)),
-      preferences
-    );
-  }
-  function detectSortingWorker(importGroups, preferences) {
-    const collateCaseSensitive = getOrganizeImportsComparer(
-      preferences,
-      /*ignoreCase*/
-      false
-    );
-    const collateCaseInsensitive = getOrganizeImportsComparer(
-      preferences,
-      /*ignoreCase*/
-      true
-    );
-    let sortState = 3 /* Both */;
-    let seenUnsortedGroup = false;
-    for (const importGroup of importGroups) {
-      if (importGroup.length > 1) {
-        const moduleSpecifierSort = detectSortCaseSensitivity(
-          importGroup,
-          (i) => {
-            var _a;
-            return ((_a = tryCast(i.moduleSpecifier, isStringLiteral)) == null ? void 0 : _a.text) ?? "";
-          },
-          collateCaseSensitive,
-          collateCaseInsensitive
-        );
-        if (moduleSpecifierSort) {
-          sortState &= moduleSpecifierSort;
-          seenUnsortedGroup = true;
-        }
-        if (!sortState) {
-          return sortState;
-        }
-      }
-      const declarationWithNamedImports = find(
-        importGroup,
-        (i) => {
-          var _a, _b;
-          return ((_b = tryCast((_a = i.importClause) == null ? void 0 : _a.namedBindings, isNamedImports)) == null ? void 0 : _b.elements.length) > 1;
-        }
-      );
-      if (declarationWithNamedImports) {
-        const namedImportSort = detectImportSpecifierSorting(declarationWithNamedImports.importClause.namedBindings.elements, preferences);
-        if (namedImportSort) {
-          sortState &= namedImportSort;
-          seenUnsortedGroup = true;
-        }
-        if (!sortState) {
-          return sortState;
-        }
-      }
-      if (sortState !== 3 /* Both */) {
-        return sortState;
-      }
-    }
-    return seenUnsortedGroup ? 0 /* None */ : sortState;
-  }
-  function detectImportDeclarationSorting(imports, preferences) {
-    const collateCaseSensitive = getOrganizeImportsComparer(
-      preferences,
-      /*ignoreCase*/
-      false
-    );
-    const collateCaseInsensitive = getOrganizeImportsComparer(
-      preferences,
-      /*ignoreCase*/
-      true
-    );
-    return detectSortCaseSensitivity(
-      imports,
-      (s) => getExternalModuleName2(getModuleSpecifierExpression(s)) || "",
-      collateCaseSensitive,
-      collateCaseInsensitive
-    );
-  }
-  function getImportDeclarationInsertionIndex(sortedImports, newImport, comparer) {
-    const index = binarySearch(sortedImports, newImport, identity, (a, b) => compareImportsOrRequireStatements(a, b, comparer));
-    return index < 0 ? ~index : index;
-  }
-  function getImportSpecifierInsertionIndex(sortedImports, newImport, comparer) {
-    const index = binarySearch(sortedImports, newImport, identity, (s1, s2) => compareImportOrExportSpecifiers(s1, s2, comparer));
-    return index < 0 ? ~index : index;
-  }
-  function compareImportsOrRequireStatements(s1, s2, comparer) {
-    return compareModuleSpecifiersWorker(getModuleSpecifierExpression(s1), getModuleSpecifierExpression(s2), comparer) || compareImportKind(s1, s2);
-  }
-  function compareImportKind(s1, s2) {
-    return compareValues(getImportKindOrder(s1), getImportKindOrder(s2));
-  }
-  function getImportKindOrder(s1) {
-    var _a;
-    switch (s1.kind) {
-      case 271 /* ImportDeclaration */:
-        if (!s1.importClause)
-          return 0;
-        if (s1.importClause.isTypeOnly)
-          return 1;
-        if (((_a = s1.importClause.namedBindings) == null ? void 0 : _a.kind) === 273 /* NamespaceImport */)
-          return 2;
-        if (s1.importClause.name)
-          return 3;
-        return 4;
-      case 270 /* ImportEqualsDeclaration */:
-        return 5;
-      case 242 /* VariableStatement */:
-        return 6;
-    }
-  }
-  function getNewImportSpecifiers(namedImports) {
-    return flatMap(
-      namedImports,
-      (namedImport) => map(
-        tryGetNamedBindingElements(namedImport),
-        (importSpecifier) => importSpecifier.name && importSpecifier.propertyName && importSpecifier.name.escapedText === importSpecifier.propertyName.escapedText ? factory.updateImportSpecifier(
-          importSpecifier,
-          importSpecifier.isTypeOnly,
-          /*propertyName*/
-          void 0,
-          importSpecifier.name
-        ) : importSpecifier
-      )
-    );
-  }
-  function tryGetNamedBindingElements(namedImport) {
-    var _a;
-    return ((_a = namedImport.importClause) == null ? void 0 : _a.namedBindings) && isNamedImports(namedImport.importClause.namedBindings) ? namedImport.importClause.namedBindings.elements : void 0;
-  }
-  function getOrganizeImportsOrdinalStringComparer(ignoreCase) {
-    return ignoreCase ? compareStringsCaseInsensitiveEslintCompatible : compareStringsCaseSensitive;
-  }
-  function getOrganizeImportsUnicodeStringComparer(ignoreCase, preferences) {
-    const resolvedLocale = getOrganizeImportsLocale(preferences);
-    const caseFirst = preferences.organizeImportsCaseFirst ?? false;
-    const numeric = preferences.organizeImportsNumericCollation ?? false;
-    const accents = preferences.organizeImportsAccentCollation ?? true;
-    const sensitivity = ignoreCase ? accents ? "accent" : "base" : accents ? "variant" : "case";
-    const collator = new Intl.Collator(resolvedLocale, {
-      usage: "sort",
-      caseFirst: caseFirst || "false",
-      sensitivity,
-      numeric
-    });
-    return collator.compare;
-  }
-  function getOrganizeImportsLocale(preferences) {
-    let locale = preferences.organizeImportsLocale;
-    if (locale === "auto")
-      locale = getUILocale();
-    if (locale === void 0)
-      locale = "en";
-    const supportedLocales = Intl.Collator.supportedLocalesOf(locale);
-    const resolvedLocale = supportedLocales.length ? supportedLocales[0] : "en";
-    return resolvedLocale;
-  }
-  function getOrganizeImportsComparer(preferences, ignoreCase) {
-    const collation = preferences.organizeImportsCollation ?? "ordinal";
-    return collation === "unicode" ? getOrganizeImportsUnicodeStringComparer(ignoreCase, preferences) : getOrganizeImportsOrdinalStringComparer(ignoreCase);
-  }
-  function getOrganizeImportsComparerWithDetection(preferences, detectIgnoreCase) {
-    const ignoreCase = typeof preferences.organizeImportsIgnoreCase === "boolean" ? preferences.organizeImportsIgnoreCase : (detectIgnoreCase == null ? void 0 : detectIgnoreCase()) ?? false;
-    return getOrganizeImportsComparer(preferences, ignoreCase);
-  }
-  function getTopLevelExportGroups(sourceFile) {
-    const topLevelExportGroups = [];
-    const statements = sourceFile.statements;
-    const len = length(statements);
-    let i = 0;
-    let groupIndex = 0;
-    while (i < len) {
-      if (isExportDeclaration(statements[i])) {
-        if (topLevelExportGroups[groupIndex] === void 0) {
-          topLevelExportGroups[groupIndex] = [];
-        }
-        const exportDecl = statements[i];
-        if (exportDecl.moduleSpecifier) {
-          topLevelExportGroups[groupIndex].push(exportDecl);
-          i++;
-        } else {
-          while (i < len && isExportDeclaration(statements[i])) {
-            topLevelExportGroups[groupIndex].push(statements[i++]);
-          }
-          groupIndex++;
-        }
-      } else {
-        i++;
-      }
-    }
-    return flatMap(topLevelExportGroups, (exportGroupDecls) => groupByNewlineContiguous(sourceFile, exportGroupDecls));
-  }
-  var ImportSpecifierSortingCache, detectImportSpecifierSorting;
-  var init_organizeImports = __esm({
-    "src/services/organizeImports.ts"() {
-      "use strict";
-      init_ts4();
-      ImportSpecifierSortingCache = class {
-        has([specifiers, preferences]) {
-          if (this._lastPreferences !== preferences || !this._cache)
-            return false;
-          return this._cache.has(specifiers);
-        }
-        get([specifiers, preferences]) {
-          if (this._lastPreferences !== preferences || !this._cache)
-            return void 0;
-          return this._cache.get(specifiers);
-        }
-        set([specifiers, preferences], value) {
-          if (this._lastPreferences !== preferences) {
-            this._lastPreferences = preferences;
-            this._cache = void 0;
-          }
-          this._cache ?? (this._cache = /* @__PURE__ */ new WeakMap());
-          this._cache.set(specifiers, value);
-        }
-      };
-      detectImportSpecifierSorting = memoizeCached((specifiers, preferences) => {
-        if (!arrayIsSorted(specifiers, (s1, s2) => compareBooleans(s1.isTypeOnly, s2.isTypeOnly))) {
-          return 0 /* None */;
-        }
-        const collateCaseSensitive = getOrganizeImportsComparer(
-          preferences,
-          /*ignoreCase*/
-          false
-        );
-        const collateCaseInsensitive = getOrganizeImportsComparer(
-          preferences,
-          /*ignoreCase*/
-          true
-        );
-        return detectSortCaseSensitivity(specifiers, (specifier) => specifier.name.text, collateCaseSensitive, collateCaseInsensitive);
-      }, new ImportSpecifierSortingCache());
-    }
-  });
-
-  // src/services/_namespaces/ts.OrganizeImports.ts
-  var ts_OrganizeImports_exports = {};
-  __export(ts_OrganizeImports_exports, {
-    coalesceExports: () => coalesceExports,
-    coalesceImports: () => coalesceImports,
-    compareImportOrExportSpecifiers: () => compareImportOrExportSpecifiers,
-    compareImportsOrRequireStatements: () => compareImportsOrRequireStatements,
-    compareModuleSpecifiers: () => compareModuleSpecifiers2,
-    detectImportDeclarationSorting: () => detectImportDeclarationSorting,
-    detectImportSpecifierSorting: () => detectImportSpecifierSorting,
-    detectSorting: () => detectSorting,
-    getImportDeclarationInsertionIndex: () => getImportDeclarationInsertionIndex,
-    getImportSpecifierInsertionIndex: () => getImportSpecifierInsertionIndex,
-    getOrganizeImportsComparer: () => getOrganizeImportsComparer,
-    organizeImports: () => organizeImports
-  });
-  var init_ts_OrganizeImports = __esm({
-    "src/services/_namespaces/ts.OrganizeImports.ts"() {
-      "use strict";
-      init_organizeImports();
-    }
-  });
-
-  // src/services/outliningElementsCollector.ts
-  function collectElements(sourceFile, cancellationToken) {
-    const res = [];
-    addNodeOutliningSpans(sourceFile, cancellationToken, res);
-    addRegionOutliningSpans(sourceFile, res);
-    return res.sort((span1, span2) => span1.textSpan.start - span2.textSpan.start);
-  }
-  function addNodeOutliningSpans(sourceFile, cancellationToken, out) {
-    let depthRemaining = 40;
-    let current = 0;
-    const statements = [...sourceFile.statements, sourceFile.endOfFileToken];
-    const n = statements.length;
-    while (current < n) {
-      while (current < n && !isAnyImportSyntax(statements[current])) {
-        visitNode3(statements[current]);
-        current++;
-      }
-      if (current === n)
-        break;
-      const firstImport = current;
-      while (current < n && isAnyImportSyntax(statements[current])) {
-        visitNode3(statements[current]);
-        current++;
-      }
-      const lastImport = current - 1;
-      if (lastImport !== firstImport) {
-        out.push(createOutliningSpanFromBounds(findChildOfKind(statements[firstImport], 102 /* ImportKeyword */, sourceFile).getStart(sourceFile), statements[lastImport].getEnd(), "imports" /* Imports */));
-      }
-    }
-    function visitNode3(n2) {
-      var _a;
-      if (depthRemaining === 0)
-        return;
-      cancellationToken.throwIfCancellationRequested();
-      if (isDeclaration(n2) || isVariableStatement(n2) || isReturnStatement(n2) || isCallOrNewExpression(n2) || n2.kind === 1 /* EndOfFileToken */) {
-        addOutliningForLeadingCommentsForNode(n2, sourceFile, cancellationToken, out);
-      }
-      if (isFunctionLike(n2) && isBinaryExpression(n2.parent) && isPropertyAccessExpression(n2.parent.left)) {
-        addOutliningForLeadingCommentsForNode(n2.parent.left, sourceFile, cancellationToken, out);
-      }
-      if (isBlock(n2) || isModuleBlock(n2)) {
-        addOutliningForLeadingCommentsForPos(n2.statements.end, sourceFile, cancellationToken, out);
-      }
-      if (isClassLike(n2) || isInterfaceDeclaration(n2)) {
-        addOutliningForLeadingCommentsForPos(n2.members.end, sourceFile, cancellationToken, out);
-      }
-      const span = getOutliningSpanForNode(n2, sourceFile);
-      if (span)
-        out.push(span);
-      depthRemaining--;
-      if (isCallExpression(n2)) {
-        depthRemaining++;
-        visitNode3(n2.expression);
-        depthRemaining--;
-        n2.arguments.forEach(visitNode3);
-        (_a = n2.typeArguments) == null ? void 0 : _a.forEach(visitNode3);
-      } else if (isIfStatement(n2) && n2.elseStatement && isIfStatement(n2.elseStatement)) {
-        visitNode3(n2.expression);
-        visitNode3(n2.thenStatement);
-        depthRemaining++;
-        visitNode3(n2.elseStatement);
-        depthRemaining--;
-      } else {
-        n2.forEachChild(visitNode3);
-      }
-      depthRemaining++;
-    }
-  }
-  function addRegionOutliningSpans(sourceFile, out) {
-    const regions = [];
-    const lineStarts = sourceFile.getLineStarts();
-    for (const currentLineStart of lineStarts) {
-      const lineEnd = sourceFile.getLineEndOfPosition(currentLineStart);
-      const lineText = sourceFile.text.substring(currentLineStart, lineEnd);
-      const result = isRegionDelimiter(lineText);
-      if (!result || isInComment(sourceFile, currentLineStart)) {
-        continue;
-      }
-      if (!result[1]) {
-        const span = createTextSpanFromBounds(sourceFile.text.indexOf("//", currentLineStart), lineEnd);
-        regions.push(createOutliningSpan(
-          span,
-          "region" /* Region */,
-          span,
-          /*autoCollapse*/
-          false,
-          result[2] || "#region"
-        ));
-      } else {
-        const region = regions.pop();
-        if (region) {
-          region.textSpan.length = lineEnd - region.textSpan.start;
-          region.hintSpan.length = lineEnd - region.textSpan.start;
-          out.push(region);
-        }
-      }
-    }
-  }
-  function isRegionDelimiter(lineText) {
-    lineText = trimStringStart(lineText);
-    if (!startsWith(lineText, "//")) {
-      return null;
-    }
-    lineText = trimString(lineText.slice(2));
-    return regionDelimiterRegExp.exec(lineText);
-  }
-  function addOutliningForLeadingCommentsForPos(pos, sourceFile, cancellationToken, out) {
-    const comments = getLeadingCommentRanges(sourceFile.text, pos);
-    if (!comments)
-      return;
-    let firstSingleLineCommentStart = -1;
-    let lastSingleLineCommentEnd = -1;
-    let singleLineCommentCount = 0;
-    const sourceText = sourceFile.getFullText();
-    for (const { kind, pos: pos2, end } of comments) {
-      cancellationToken.throwIfCancellationRequested();
-      switch (kind) {
-        case 2 /* SingleLineCommentTrivia */:
-          const commentText = sourceText.slice(pos2, end);
-          if (isRegionDelimiter(commentText)) {
-            combineAndAddMultipleSingleLineComments();
-            singleLineCommentCount = 0;
-            break;
-          }
-          if (singleLineCommentCount === 0) {
-            firstSingleLineCommentStart = pos2;
-          }
-          lastSingleLineCommentEnd = end;
-          singleLineCommentCount++;
-          break;
-        case 3 /* MultiLineCommentTrivia */:
-          combineAndAddMultipleSingleLineComments();
-          out.push(createOutliningSpanFromBounds(pos2, end, "comment" /* Comment */));
-          singleLineCommentCount = 0;
-          break;
-        default:
-          Debug.assertNever(kind);
-      }
-    }
-    combineAndAddMultipleSingleLineComments();
-    function combineAndAddMultipleSingleLineComments() {
-      if (singleLineCommentCount > 1) {
-        out.push(createOutliningSpanFromBounds(firstSingleLineCommentStart, lastSingleLineCommentEnd, "comment" /* Comment */));
-      }
-    }
-  }
-  function addOutliningForLeadingCommentsForNode(n, sourceFile, cancellationToken, out) {
-    if (isJsxText(n))
-      return;
-    addOutliningForLeadingCommentsForPos(n.pos, sourceFile, cancellationToken, out);
-  }
-  function createOutliningSpanFromBounds(pos, end, kind) {
-    return createOutliningSpan(createTextSpanFromBounds(pos, end), kind);
-  }
-  function getOutliningSpanForNode(n, sourceFile) {
-    switch (n.kind) {
-      case 240 /* Block */:
-        if (isFunctionLike(n.parent)) {
-          return functionSpan(n.parent, n, sourceFile);
-        }
-        switch (n.parent.kind) {
-          case 245 /* DoStatement */:
-          case 248 /* ForInStatement */:
-          case 249 /* ForOfStatement */:
-          case 247 /* ForStatement */:
-          case 244 /* IfStatement */:
-          case 246 /* WhileStatement */:
-          case 253 /* WithStatement */:
-          case 298 /* CatchClause */:
-            return spanForNode(n.parent);
-          case 257 /* TryStatement */:
-            const tryStatement = n.parent;
-            if (tryStatement.tryBlock === n) {
-              return spanForNode(n.parent);
-            } else if (tryStatement.finallyBlock === n) {
-              const node = findChildOfKind(tryStatement, 98 /* FinallyKeyword */, sourceFile);
-              if (node)
-                return spanForNode(node);
-            }
-          default:
-            return createOutliningSpan(createTextSpanFromNode(n, sourceFile), "code" /* Code */);
-        }
-      case 267 /* ModuleBlock */:
-        return spanForNode(n.parent);
-      case 262 /* ClassDeclaration */:
-      case 230 /* ClassExpression */:
-      case 263 /* InterfaceDeclaration */:
-      case 265 /* EnumDeclaration */:
-      case 268 /* CaseBlock */:
-      case 186 /* TypeLiteral */:
-      case 205 /* ObjectBindingPattern */:
-        return spanForNode(n);
-      case 188 /* TupleType */:
-        return spanForNode(
-          n,
-          /*autoCollapse*/
-          false,
-          /*useFullStart*/
-          !isTupleTypeNode(n.parent),
-          23 /* OpenBracketToken */
-        );
-      case 295 /* CaseClause */:
-      case 296 /* DefaultClause */:
-        return spanForNodeArray(n.statements);
-      case 209 /* ObjectLiteralExpression */:
-        return spanForObjectOrArrayLiteral(n);
-      case 208 /* ArrayLiteralExpression */:
-        return spanForObjectOrArrayLiteral(n, 23 /* OpenBracketToken */);
-      case 283 /* JsxElement */:
-        return spanForJSXElement(n);
-      case 287 /* JsxFragment */:
-        return spanForJSXFragment(n);
-      case 284 /* JsxSelfClosingElement */:
-      case 285 /* JsxOpeningElement */:
-        return spanForJSXAttributes(n.attributes);
-      case 227 /* TemplateExpression */:
-      case 15 /* NoSubstitutionTemplateLiteral */:
-        return spanForTemplateLiteral(n);
-      case 206 /* ArrayBindingPattern */:
-        return spanForNode(
-          n,
-          /*autoCollapse*/
-          false,
-          /*useFullStart*/
-          !isBindingElement(n.parent),
-          23 /* OpenBracketToken */
-        );
-      case 218 /* ArrowFunction */:
-        return spanForArrowFunction(n);
-      case 212 /* CallExpression */:
-        return spanForCallExpression(n);
-      case 216 /* ParenthesizedExpression */:
-        return spanForParenthesizedExpression(n);
-      case 274 /* NamedImports */:
-      case 278 /* NamedExports */:
-      case 299 /* AssertClause */:
-        return spanForNamedImportsOrExportsOrAssertClause(n);
-    }
-    function spanForNamedImportsOrExportsOrAssertClause(node) {
-      if (!node.elements.length) {
-        return void 0;
-      }
-      const openToken = findChildOfKind(node, 19 /* OpenBraceToken */, sourceFile);
-      const closeToken = findChildOfKind(node, 20 /* CloseBraceToken */, sourceFile);
-      if (!openToken || !closeToken || positionsAreOnSameLine(openToken.pos, closeToken.pos, sourceFile)) {
-        return void 0;
-      }
-      return spanBetweenTokens(
-        openToken,
-        closeToken,
-        node,
-        sourceFile,
-        /*autoCollapse*/
-        false,
-        /*useFullStart*/
-        false
-      );
-    }
-    function spanForCallExpression(node) {
-      if (!node.arguments.length) {
-        return void 0;
-      }
-      const openToken = findChildOfKind(node, 21 /* OpenParenToken */, sourceFile);
-      const closeToken = findChildOfKind(node, 22 /* CloseParenToken */, sourceFile);
-      if (!openToken || !closeToken || positionsAreOnSameLine(openToken.pos, closeToken.pos, sourceFile)) {
-        return void 0;
-      }
-      return spanBetweenTokens(
-        openToken,
-        closeToken,
-        node,
-        sourceFile,
-        /*autoCollapse*/
-        false,
-        /*useFullStart*/
-        true
-      );
-    }
-    function spanForArrowFunction(node) {
-      if (isBlock(node.body) || isParenthesizedExpression(node.body) || positionsAreOnSameLine(node.body.getFullStart(), node.body.getEnd(), sourceFile)) {
-        return void 0;
-      }
-      const textSpan = createTextSpanFromBounds(node.body.getFullStart(), node.body.getEnd());
-      return createOutliningSpan(textSpan, "code" /* Code */, createTextSpanFromNode(node));
-    }
-    function spanForJSXElement(node) {
-      const textSpan = createTextSpanFromBounds(node.openingElement.getStart(sourceFile), node.closingElement.getEnd());
-      const tagName = node.openingElement.tagName.getText(sourceFile);
-      const bannerText = "<" + tagName + ">...";
-      return createOutliningSpan(
-        textSpan,
-        "code" /* Code */,
-        textSpan,
-        /*autoCollapse*/
-        false,
-        bannerText
-      );
-    }
-    function spanForJSXFragment(node) {
-      const textSpan = createTextSpanFromBounds(node.openingFragment.getStart(sourceFile), node.closingFragment.getEnd());
-      const bannerText = "<>...";
-      return createOutliningSpan(
-        textSpan,
-        "code" /* Code */,
-        textSpan,
-        /*autoCollapse*/
-        false,
-        bannerText
-      );
-    }
-    function spanForJSXAttributes(node) {
-      if (node.properties.length === 0) {
-        return void 0;
-      }
-      return createOutliningSpanFromBounds(node.getStart(sourceFile), node.getEnd(), "code" /* Code */);
-    }
-    function spanForTemplateLiteral(node) {
-      if (node.kind === 15 /* NoSubstitutionTemplateLiteral */ && node.text.length === 0) {
-        return void 0;
-      }
-      return createOutliningSpanFromBounds(node.getStart(sourceFile), node.getEnd(), "code" /* Code */);
-    }
-    function spanForObjectOrArrayLiteral(node, open = 19 /* OpenBraceToken */) {
-      return spanForNode(
-        node,
-        /*autoCollapse*/
-        false,
-        /*useFullStart*/
-        !isArrayLiteralExpression(node.parent) && !isCallExpression(node.parent),
-        open
-      );
-    }
-    function spanForNode(hintSpanNode, autoCollapse = false, useFullStart = true, open = 19 /* OpenBraceToken */, close = open === 19 /* OpenBraceToken */ ? 20 /* CloseBraceToken */ : 24 /* CloseBracketToken */) {
-      const openToken = findChildOfKind(n, open, sourceFile);
-      const closeToken = findChildOfKind(n, close, sourceFile);
-      return openToken && closeToken && spanBetweenTokens(openToken, closeToken, hintSpanNode, sourceFile, autoCollapse, useFullStart);
-    }
-    function spanForNodeArray(nodeArray) {
-      return nodeArray.length ? createOutliningSpan(createTextSpanFromRange(nodeArray), "code" /* Code */) : void 0;
-    }
-    function spanForParenthesizedExpression(node) {
-      if (positionsAreOnSameLine(node.getStart(), node.getEnd(), sourceFile))
-        return void 0;
-      const textSpan = createTextSpanFromBounds(node.getStart(), node.getEnd());
-      return createOutliningSpan(textSpan, "code" /* Code */, createTextSpanFromNode(node));
-    }
-  }
-  function functionSpan(node, body, sourceFile) {
-    const openToken = tryGetFunctionOpenToken(node, body, sourceFile);
-    const closeToken = findChildOfKind(body, 20 /* CloseBraceToken */, sourceFile);
-    return openToken && closeToken && spanBetweenTokens(
-      openToken,
-      closeToken,
-      node,
-      sourceFile,
-      /*autoCollapse*/
-      node.kind !== 218 /* ArrowFunction */
-    );
-  }
-  function spanBetweenTokens(openToken, closeToken, hintSpanNode, sourceFile, autoCollapse = false, useFullStart = true) {
-    const textSpan = createTextSpanFromBounds(useFullStart ? openToken.getFullStart() : openToken.getStart(sourceFile), closeToken.getEnd());
-    return createOutliningSpan(textSpan, "code" /* Code */, createTextSpanFromNode(hintSpanNode, sourceFile), autoCollapse);
-  }
-  function createOutliningSpan(textSpan, kind, hintSpan = textSpan, autoCollapse = false, bannerText = "...") {
-    return { textSpan, kind, hintSpan, bannerText, autoCollapse };
-  }
-  function tryGetFunctionOpenToken(node, body, sourceFile) {
-    if (isNodeArrayMultiLine(node.parameters, sourceFile)) {
-      const openParenToken = findChildOfKind(node, 21 /* OpenParenToken */, sourceFile);
-      if (openParenToken) {
-        return openParenToken;
-      }
-    }
-    return findChildOfKind(body, 19 /* OpenBraceToken */, sourceFile);
-  }
-  var regionDelimiterRegExp;
-  var init_outliningElementsCollector = __esm({
-    "src/services/outliningElementsCollector.ts"() {
-      "use strict";
-      init_ts4();
-      regionDelimiterRegExp = /^#(end)?region(?:\s+(.*))?(?:\r)?$/;
-    }
-  });
-
-  // src/services/_namespaces/ts.OutliningElementsCollector.ts
-  var ts_OutliningElementsCollector_exports = {};
-  __export(ts_OutliningElementsCollector_exports, {
-    collectElements: () => collectElements
-  });
-  var init_ts_OutliningElementsCollector = __esm({
-    "src/services/_namespaces/ts.OutliningElementsCollector.ts"() {
-      "use strict";
-      init_outliningElementsCollector();
-    }
-  });
-
-  // src/services/rename.ts
-  function getRenameInfo(program, sourceFile, position, preferences) {
-    const node = getAdjustedRenameLocation(getTouchingPropertyName(sourceFile, position));
-    if (nodeIsEligibleForRename(node)) {
-      const renameInfo = getRenameInfoForNode(node, program.getTypeChecker(), sourceFile, program, preferences);
-      if (renameInfo) {
-        return renameInfo;
-      }
-    }
-    return getRenameInfoError(Diagnostics.You_cannot_rename_this_element);
-  }
-  function getRenameInfoForNode(node, typeChecker, sourceFile, program, preferences) {
-    const symbol = typeChecker.getSymbolAtLocation(node);
-    if (!symbol) {
-      if (isStringLiteralLike(node)) {
-        const type = getContextualTypeFromParentOrAncestorTypeNode(node, typeChecker);
-        if (type && (type.flags & 128 /* StringLiteral */ || type.flags & 1048576 /* Union */ && every(type.types, (type2) => !!(type2.flags & 128 /* StringLiteral */)))) {
-          return getRenameInfoSuccess(node.text, node.text, "string" /* string */, "", node, sourceFile);
-        }
-      } else if (isLabelName(node)) {
-        const name = getTextOfNode(node);
-        return getRenameInfoSuccess(name, name, "label" /* label */, "" /* none */, node, sourceFile);
-      }
-      return void 0;
-    }
-    const { declarations } = symbol;
-    if (!declarations || declarations.length === 0)
-      return;
-    if (declarations.some((declaration) => isDefinedInLibraryFile(program, declaration))) {
-      return getRenameInfoError(Diagnostics.You_cannot_rename_elements_that_are_defined_in_the_standard_TypeScript_library);
-    }
-    if (isIdentifier(node) && node.escapedText === "default" && symbol.parent && symbol.parent.flags & 1536 /* Module */) {
-      return void 0;
-    }
-    if (isStringLiteralLike(node) && tryGetImportFromModuleSpecifier(node)) {
-      return preferences.allowRenameOfImportPath ? getRenameInfoForModule(node, sourceFile, symbol) : void 0;
-    }
-    const wouldRenameNodeModules = wouldRenameInOtherNodeModules(sourceFile, symbol, typeChecker, preferences);
-    if (wouldRenameNodeModules) {
-      return getRenameInfoError(wouldRenameNodeModules);
-    }
-    const kind = ts_SymbolDisplay_exports.getSymbolKind(typeChecker, symbol, node);
-    const specifierName = isImportOrExportSpecifierName(node) || isStringOrNumericLiteralLike(node) && node.parent.kind === 166 /* ComputedPropertyName */ ? stripQuotes(getTextOfIdentifierOrLiteral(node)) : void 0;
-    const displayName = specifierName || typeChecker.symbolToString(symbol);
-    const fullDisplayName = specifierName || typeChecker.getFullyQualifiedName(symbol);
-    return getRenameInfoSuccess(displayName, fullDisplayName, kind, ts_SymbolDisplay_exports.getSymbolModifiers(typeChecker, symbol), node, sourceFile);
-  }
-  function isDefinedInLibraryFile(program, declaration) {
-    const sourceFile = declaration.getSourceFile();
-    return program.isSourceFileDefaultLibrary(sourceFile) && fileExtensionIs(sourceFile.fileName, ".d.ts" /* Dts */);
-  }
-  function wouldRenameInOtherNodeModules(originalFile, symbol, checker, preferences) {
-    if (!preferences.providePrefixAndSuffixTextForRename && symbol.flags & 2097152 /* Alias */) {
-      const importSpecifier = symbol.declarations && find(symbol.declarations, (decl) => isImportSpecifier(decl));
-      if (importSpecifier && !importSpecifier.propertyName) {
-        symbol = checker.getAliasedSymbol(symbol);
-      }
-    }
-    const { declarations } = symbol;
-    if (!declarations) {
-      return void 0;
-    }
-    const originalPackage = getPackagePathComponents(originalFile.path);
-    if (originalPackage === void 0) {
-      if (some(declarations, (declaration) => isInsideNodeModules(declaration.getSourceFile().path))) {
-        return Diagnostics.You_cannot_rename_elements_that_are_defined_in_a_node_modules_folder;
-      } else {
-        return void 0;
-      }
-    }
-    for (const declaration of declarations) {
-      const declPackage = getPackagePathComponents(declaration.getSourceFile().path);
-      if (declPackage) {
-        const length2 = Math.min(originalPackage.length, declPackage.length);
-        for (let i = 0; i <= length2; i++) {
-          if (compareStringsCaseSensitive(originalPackage[i], declPackage[i]) !== 0 /* EqualTo */) {
-            return Diagnostics.You_cannot_rename_elements_that_are_defined_in_another_node_modules_folder;
-          }
-        }
-      }
-    }
-    return void 0;
-  }
-  function getPackagePathComponents(filePath) {
-    const components = getPathComponents(filePath);
-    const nodeModulesIdx = components.lastIndexOf("node_modules");
-    if (nodeModulesIdx === -1) {
-      return void 0;
-    }
-    return components.slice(0, nodeModulesIdx + 2);
-  }
-  function getRenameInfoForModule(node, sourceFile, moduleSymbol) {
-    if (!isExternalModuleNameRelative(node.text)) {
-      return getRenameInfoError(Diagnostics.You_cannot_rename_a_module_via_a_global_import);
-    }
-    const moduleSourceFile = moduleSymbol.declarations && find(moduleSymbol.declarations, isSourceFile);
-    if (!moduleSourceFile)
-      return void 0;
-    const withoutIndex = endsWith(node.text, "/index") || endsWith(node.text, "/index.js") ? void 0 : tryRemoveSuffix(removeFileExtension(moduleSourceFile.fileName), "/index");
-    const name = withoutIndex === void 0 ? moduleSourceFile.fileName : withoutIndex;
-    const kind = withoutIndex === void 0 ? "module" /* moduleElement */ : "directory" /* directory */;
-    const indexAfterLastSlash = node.text.lastIndexOf("/") + 1;
-    const triggerSpan = createTextSpan(node.getStart(sourceFile) + 1 + indexAfterLastSlash, node.text.length - indexAfterLastSlash);
-    return {
-      canRename: true,
-      fileToRename: name,
-      kind,
-      displayName: name,
-      fullDisplayName: name,
-      kindModifiers: "" /* none */,
-      triggerSpan
-    };
-  }
-  function getRenameInfoSuccess(displayName, fullDisplayName, kind, kindModifiers, node, sourceFile) {
-    return {
-      canRename: true,
-      fileToRename: void 0,
-      kind,
-      displayName,
-      fullDisplayName,
-      kindModifiers,
-      triggerSpan: createTriggerSpanForNode(node, sourceFile)
-    };
-  }
-  function getRenameInfoError(diagnostic) {
-    return { canRename: false, localizedErrorMessage: getLocaleSpecificMessage(diagnostic) };
-  }
-  function createTriggerSpanForNode(node, sourceFile) {
-    let start = node.getStart(sourceFile);
-    let width = node.getWidth(sourceFile);
-    if (isStringLiteralLike(node)) {
-      start += 1;
-      width -= 2;
-    }
-    return createTextSpan(start, width);
-  }
-  function nodeIsEligibleForRename(node) {
-    switch (node.kind) {
-      case 80 /* Identifier */:
-      case 81 /* PrivateIdentifier */:
-      case 11 /* StringLiteral */:
-      case 15 /* NoSubstitutionTemplateLiteral */:
-      case 110 /* ThisKeyword */:
-        return true;
-      case 9 /* NumericLiteral */:
-        return isLiteralNameOfPropertyDeclarationOrIndexAccess(node);
-      default:
-        return false;
-    }
-  }
-  var init_rename = __esm({
-    "src/services/rename.ts"() {
-      "use strict";
-      init_ts4();
-    }
-  });
-
-  // src/services/_namespaces/ts.Rename.ts
-  var ts_Rename_exports = {};
-  __export(ts_Rename_exports, {
-    getRenameInfo: () => getRenameInfo,
-    nodeIsEligibleForRename: () => nodeIsEligibleForRename
-  });
-  var init_ts_Rename = __esm({
-    "src/services/_namespaces/ts.Rename.ts"() {
-      "use strict";
-      init_rename();
-    }
-  });
-
-  // src/services/signatureHelp.ts
-  function getSignatureHelpItems(program, sourceFile, position, triggerReason, cancellationToken) {
-    const typeChecker = program.getTypeChecker();
-    const startingToken = findTokenOnLeftOfPosition(sourceFile, position);
-    if (!startingToken) {
-      return void 0;
-    }
-    const onlyUseSyntacticOwners = !!triggerReason && triggerReason.kind === "characterTyped";
-    if (onlyUseSyntacticOwners && (isInString(sourceFile, position, startingToken) || isInComment(sourceFile, position))) {
-      return void 0;
-    }
-    const isManuallyInvoked = !!triggerReason && triggerReason.kind === "invoked";
-    const argumentInfo = getContainingArgumentInfo(startingToken, position, sourceFile, typeChecker, isManuallyInvoked);
-    if (!argumentInfo)
-      return void 0;
-    cancellationToken.throwIfCancellationRequested();
-    const candidateInfo = getCandidateOrTypeInfo(argumentInfo, typeChecker, sourceFile, startingToken, onlyUseSyntacticOwners);
-    cancellationToken.throwIfCancellationRequested();
-    if (!candidateInfo) {
-      return isSourceFileJS(sourceFile) ? createJSSignatureHelpItems(argumentInfo, program, cancellationToken) : void 0;
-    }
-    return typeChecker.runWithCancellationToken(cancellationToken, (typeChecker2) => candidateInfo.kind === 0 /* Candidate */ ? createSignatureHelpItems(candidateInfo.candidates, candidateInfo.resolvedSignature, argumentInfo, sourceFile, typeChecker2) : createTypeHelpItems(candidateInfo.symbol, argumentInfo, sourceFile, typeChecker2));
-  }
-  function getCandidateOrTypeInfo({ invocation, argumentCount }, checker, sourceFile, startingToken, onlyUseSyntacticOwners) {
-    switch (invocation.kind) {
-      case 0 /* Call */: {
-        if (onlyUseSyntacticOwners && !isSyntacticOwner(startingToken, invocation.node, sourceFile)) {
-          return void 0;
-        }
-        const candidates = [];
-        const resolvedSignature = checker.getResolvedSignatureForSignatureHelp(invocation.node, candidates, argumentCount);
-        return candidates.length === 0 ? void 0 : { kind: 0 /* Candidate */, candidates, resolvedSignature };
-      }
-      case 1 /* TypeArgs */: {
-        const { called } = invocation;
-        if (onlyUseSyntacticOwners && !containsPrecedingToken(startingToken, sourceFile, isIdentifier(called) ? called.parent : called)) {
-          return void 0;
-        }
-        const candidates = getPossibleGenericSignatures(called, argumentCount, checker);
-        if (candidates.length !== 0)
-          return { kind: 0 /* Candidate */, candidates, resolvedSignature: first(candidates) };
-        const symbol = checker.getSymbolAtLocation(called);
-        return symbol && { kind: 1 /* Type */, symbol };
-      }
-      case 2 /* Contextual */:
-        return { kind: 0 /* Candidate */, candidates: [invocation.signature], resolvedSignature: invocation.signature };
-      default:
-        return Debug.assertNever(invocation);
-    }
-  }
-  function isSyntacticOwner(startingToken, node, sourceFile) {
-    if (!isCallOrNewExpression(node))
-      return false;
-    const invocationChildren = node.getChildren(sourceFile);
-    switch (startingToken.kind) {
-      case 21 /* OpenParenToken */:
-        return contains(invocationChildren, startingToken);
-      case 28 /* CommaToken */: {
-        const containingList = findContainingList(startingToken);
-        return !!containingList && contains(invocationChildren, containingList);
-      }
-      case 30 /* LessThanToken */:
-        return containsPrecedingToken(startingToken, sourceFile, node.expression);
-      default:
-        return false;
-    }
-  }
-  function createJSSignatureHelpItems(argumentInfo, program, cancellationToken) {
-    if (argumentInfo.invocation.kind === 2 /* Contextual */)
-      return void 0;
-    const expression = getExpressionFromInvocation(argumentInfo.invocation);
-    const name = isPropertyAccessExpression(expression) ? expression.name.text : void 0;
-    const typeChecker = program.getTypeChecker();
-    return name === void 0 ? void 0 : firstDefined(program.getSourceFiles(), (sourceFile) => firstDefined(sourceFile.getNamedDeclarations().get(name), (declaration) => {
-      const type = declaration.symbol && typeChecker.getTypeOfSymbolAtLocation(declaration.symbol, declaration);
-      const callSignatures = type && type.getCallSignatures();
-      if (callSignatures && callSignatures.length) {
-        return typeChecker.runWithCancellationToken(
-          cancellationToken,
-          (typeChecker2) => createSignatureHelpItems(
-            callSignatures,
-            callSignatures[0],
-            argumentInfo,
-            sourceFile,
-            typeChecker2,
-            /*useFullPrefix*/
-            true
-          )
-        );
-      }
-    }));
-  }
-  function containsPrecedingToken(startingToken, sourceFile, container) {
-    const pos = startingToken.getFullStart();
-    let currentParent = startingToken.parent;
-    while (currentParent) {
-      const precedingToken = findPrecedingToken(
-        pos,
-        sourceFile,
-        currentParent,
-        /*excludeJsdoc*/
-        true
-      );
-      if (precedingToken) {
-        return rangeContainsRange(container, precedingToken);
-      }
-      currentParent = currentParent.parent;
-    }
-    return Debug.fail("Could not find preceding token");
-  }
-  function getArgumentInfoForCompletions(node, position, sourceFile) {
-    const info = getImmediatelyContainingArgumentInfo(node, position, sourceFile);
-    return !info || info.isTypeParameterList || info.invocation.kind !== 0 /* Call */ ? void 0 : { invocation: info.invocation.node, argumentCount: info.argumentCount, argumentIndex: info.argumentIndex };
-  }
-  function getArgumentOrParameterListInfo(node, position, sourceFile) {
-    const info = getArgumentOrParameterListAndIndex(node, sourceFile);
-    if (!info)
-      return void 0;
-    const { list, argumentIndex } = info;
-    const argumentCount = getArgumentCount(
-      list,
-      /*ignoreTrailingComma*/
-      isInString(sourceFile, position, node)
-    );
-    if (argumentIndex !== 0) {
-      Debug.assertLessThan(argumentIndex, argumentCount);
-    }
-    const argumentsSpan = getApplicableSpanForArguments(list, sourceFile);
-    return { list, argumentIndex, argumentCount, argumentsSpan };
-  }
-  function getArgumentOrParameterListAndIndex(node, sourceFile) {
-    if (node.kind === 30 /* LessThanToken */ || node.kind === 21 /* OpenParenToken */) {
-      return { list: getChildListThatStartsWithOpenerToken(node.parent, node, sourceFile), argumentIndex: 0 };
-    } else {
-      const list = findContainingList(node);
-      return list && { list, argumentIndex: getArgumentIndex(list, node) };
-    }
-  }
-  function getImmediatelyContainingArgumentInfo(node, position, sourceFile) {
-    const { parent: parent2 } = node;
-    if (isCallOrNewExpression(parent2)) {
-      const invocation = parent2;
-      const info = getArgumentOrParameterListInfo(node, position, sourceFile);
-      if (!info)
-        return void 0;
-      const { list, argumentIndex, argumentCount, argumentsSpan } = info;
-      const isTypeParameterList = !!parent2.typeArguments && parent2.typeArguments.pos === list.pos;
-      return { isTypeParameterList, invocation: { kind: 0 /* Call */, node: invocation }, argumentsSpan, argumentIndex, argumentCount };
-    } else if (isNoSubstitutionTemplateLiteral(node) && isTaggedTemplateExpression(parent2)) {
-      if (isInsideTemplateLiteral(node, position, sourceFile)) {
-        return getArgumentListInfoForTemplate(
-          parent2,
-          /*argumentIndex*/
-          0,
-          sourceFile
-        );
-      }
-      return void 0;
-    } else if (isTemplateHead(node) && parent2.parent.kind === 214 /* TaggedTemplateExpression */) {
-      const templateExpression = parent2;
-      const tagExpression = templateExpression.parent;
-      Debug.assert(templateExpression.kind === 227 /* TemplateExpression */);
-      const argumentIndex = isInsideTemplateLiteral(node, position, sourceFile) ? 0 : 1;
-      return getArgumentListInfoForTemplate(tagExpression, argumentIndex, sourceFile);
-    } else if (isTemplateSpan(parent2) && isTaggedTemplateExpression(parent2.parent.parent)) {
-      const templateSpan = parent2;
-      const tagExpression = parent2.parent.parent;
-      if (isTemplateTail(node) && !isInsideTemplateLiteral(node, position, sourceFile)) {
-        return void 0;
-      }
-      const spanIndex = templateSpan.parent.templateSpans.indexOf(templateSpan);
-      const argumentIndex = getArgumentIndexForTemplatePiece(spanIndex, node, position, sourceFile);
-      return getArgumentListInfoForTemplate(tagExpression, argumentIndex, sourceFile);
-    } else if (isJsxOpeningLikeElement(parent2)) {
-      const attributeSpanStart = parent2.attributes.pos;
-      const attributeSpanEnd = skipTrivia(
-        sourceFile.text,
-        parent2.attributes.end,
-        /*stopAfterLineBreak*/
-        false
-      );
-      return {
-        isTypeParameterList: false,
-        invocation: { kind: 0 /* Call */, node: parent2 },
-        argumentsSpan: createTextSpan(attributeSpanStart, attributeSpanEnd - attributeSpanStart),
-        argumentIndex: 0,
-        argumentCount: 1
-      };
-    } else {
-      const typeArgInfo = getPossibleTypeArgumentsInfo(node, sourceFile);
-      if (typeArgInfo) {
-        const { called, nTypeArguments } = typeArgInfo;
-        const invocation = { kind: 1 /* TypeArgs */, called };
-        const argumentsSpan = createTextSpanFromBounds(called.getStart(sourceFile), node.end);
-        return { isTypeParameterList: true, invocation, argumentsSpan, argumentIndex: nTypeArguments, argumentCount: nTypeArguments + 1 };
-      }
-      return void 0;
-    }
-  }
-  function getImmediatelyContainingArgumentOrContextualParameterInfo(node, position, sourceFile, checker) {
-    return tryGetParameterInfo(node, position, sourceFile, checker) || getImmediatelyContainingArgumentInfo(node, position, sourceFile);
-  }
-  function getHighestBinary(b) {
-    return isBinaryExpression(b.parent) ? getHighestBinary(b.parent) : b;
-  }
-  function countBinaryExpressionParameters(b) {
-    return isBinaryExpression(b.left) ? countBinaryExpressionParameters(b.left) + 1 : 2;
-  }
-  function tryGetParameterInfo(startingToken, position, sourceFile, checker) {
-    const node = getAdjustedNode(startingToken);
-    if (node === void 0)
-      return void 0;
-    const info = getContextualSignatureLocationInfo(node, sourceFile, position, checker);
-    if (info === void 0)
-      return void 0;
-    const { contextualType, argumentIndex, argumentCount, argumentsSpan } = info;
-    const nonNullableContextualType = contextualType.getNonNullableType();
-    const symbol = nonNullableContextualType.symbol;
-    if (symbol === void 0)
-      return void 0;
-    const signature = lastOrUndefined(nonNullableContextualType.getCallSignatures());
-    if (signature === void 0)
-      return void 0;
-    const invocation = { kind: 2 /* Contextual */, signature, node: startingToken, symbol: chooseBetterSymbol(symbol) };
-    return { isTypeParameterList: false, invocation, argumentsSpan, argumentIndex, argumentCount };
-  }
-  function getAdjustedNode(node) {
-    switch (node.kind) {
-      case 21 /* OpenParenToken */:
-      case 28 /* CommaToken */:
-        return node;
-      default:
-        return findAncestor(node.parent, (n) => isParameter(n) ? true : isBindingElement(n) || isObjectBindingPattern(n) || isArrayBindingPattern(n) ? false : "quit");
-    }
-  }
-  function getContextualSignatureLocationInfo(node, sourceFile, position, checker) {
-    const { parent: parent2 } = node;
-    switch (parent2.kind) {
-      case 216 /* ParenthesizedExpression */:
-      case 173 /* MethodDeclaration */:
-      case 217 /* FunctionExpression */:
-      case 218 /* ArrowFunction */:
-        const info = getArgumentOrParameterListInfo(node, position, sourceFile);
-        if (!info)
-          return void 0;
-        const { argumentIndex, argumentCount, argumentsSpan } = info;
-        const contextualType = isMethodDeclaration(parent2) ? checker.getContextualTypeForObjectLiteralElement(parent2) : checker.getContextualType(parent2);
-        return contextualType && { contextualType, argumentIndex, argumentCount, argumentsSpan };
-      case 225 /* BinaryExpression */: {
-        const highestBinary = getHighestBinary(parent2);
-        const contextualType2 = checker.getContextualType(highestBinary);
-        const argumentIndex2 = node.kind === 21 /* OpenParenToken */ ? 0 : countBinaryExpressionParameters(parent2) - 1;
-        const argumentCount2 = countBinaryExpressionParameters(highestBinary);
-        return contextualType2 && { contextualType: contextualType2, argumentIndex: argumentIndex2, argumentCount: argumentCount2, argumentsSpan: createTextSpanFromNode(parent2) };
-      }
-      default:
-        return void 0;
-    }
-  }
-  function chooseBetterSymbol(s) {
-    return s.name === "__type" /* Type */ ? firstDefined(s.declarations, (d) => {
-      var _a;
-      return isFunctionTypeNode(d) ? (_a = tryCast(d.parent, canHaveSymbol)) == null ? void 0 : _a.symbol : void 0;
-    }) || s : s;
-  }
-  function getArgumentIndex(argumentsList, node) {
-    let argumentIndex = 0;
-    for (const child of argumentsList.getChildren()) {
-      if (child === node) {
-        break;
-      }
-      if (child.kind !== 28 /* CommaToken */) {
-        argumentIndex++;
-      }
-    }
-    return argumentIndex;
-  }
-  function getArgumentCount(argumentsList, ignoreTrailingComma) {
-    const listChildren = argumentsList.getChildren();
-    let argumentCount = countWhere(listChildren, (arg) => arg.kind !== 28 /* CommaToken */);
-    if (!ignoreTrailingComma && listChildren.length > 0 && last(listChildren).kind === 28 /* CommaToken */) {
-      argumentCount++;
-    }
-    return argumentCount;
-  }
-  function getArgumentIndexForTemplatePiece(spanIndex, node, position, sourceFile) {
-    Debug.assert(position >= node.getStart(), "Assumed 'position' could not occur before node.");
-    if (isTemplateLiteralToken(node)) {
-      if (isInsideTemplateLiteral(node, position, sourceFile)) {
-        return 0;
-      }
-      return spanIndex + 2;
-    }
-    return spanIndex + 1;
-  }
-  function getArgumentListInfoForTemplate(tagExpression, argumentIndex, sourceFile) {
-    const argumentCount = isNoSubstitutionTemplateLiteral(tagExpression.template) ? 1 : tagExpression.template.templateSpans.length + 1;
-    if (argumentIndex !== 0) {
-      Debug.assertLessThan(argumentIndex, argumentCount);
-    }
-    return {
-      isTypeParameterList: false,
-      invocation: { kind: 0 /* Call */, node: tagExpression },
-      argumentsSpan: getApplicableSpanForTaggedTemplate(tagExpression, sourceFile),
-      argumentIndex,
-      argumentCount
-    };
-  }
-  function getApplicableSpanForArguments(argumentsList, sourceFile) {
-    const applicableSpanStart = argumentsList.getFullStart();
-    const applicableSpanEnd = skipTrivia(
-      sourceFile.text,
-      argumentsList.getEnd(),
-      /*stopAfterLineBreak*/
-      false
-    );
-    return createTextSpan(applicableSpanStart, applicableSpanEnd - applicableSpanStart);
-  }
-  function getApplicableSpanForTaggedTemplate(taggedTemplate, sourceFile) {
-    const template = taggedTemplate.template;
-    const applicableSpanStart = template.getStart();
-    let applicableSpanEnd = template.getEnd();
-    if (template.kind === 227 /* TemplateExpression */) {
-      const lastSpan = last(template.templateSpans);
-      if (lastSpan.literal.getFullWidth() === 0) {
-        applicableSpanEnd = skipTrivia(
-          sourceFile.text,
-          applicableSpanEnd,
-          /*stopAfterLineBreak*/
-          false
-        );
-      }
-    }
-    return createTextSpan(applicableSpanStart, applicableSpanEnd - applicableSpanStart);
-  }
-  function getContainingArgumentInfo(node, position, sourceFile, checker, isManuallyInvoked) {
-    for (let n = node; !isSourceFile(n) && (isManuallyInvoked || !isBlock(n)); n = n.parent) {
-      Debug.assert(rangeContainsRange(n.parent, n), "Not a subspan", () => `Child: ${Debug.formatSyntaxKind(n.kind)}, parent: ${Debug.formatSyntaxKind(n.parent.kind)}`);
-      const argumentInfo = getImmediatelyContainingArgumentOrContextualParameterInfo(n, position, sourceFile, checker);
-      if (argumentInfo) {
-        return argumentInfo;
-      }
-    }
-    return void 0;
-  }
-  function getChildListThatStartsWithOpenerToken(parent2, openerToken, sourceFile) {
-    const children = parent2.getChildren(sourceFile);
-    const indexOfOpenerToken = children.indexOf(openerToken);
-    Debug.assert(indexOfOpenerToken >= 0 && children.length > indexOfOpenerToken + 1);
-    return children[indexOfOpenerToken + 1];
-  }
-  function getExpressionFromInvocation(invocation) {
-    return invocation.kind === 0 /* Call */ ? getInvokedExpression(invocation.node) : invocation.called;
-  }
-  function getEnclosingDeclarationFromInvocation(invocation) {
-    return invocation.kind === 0 /* Call */ ? invocation.node : invocation.kind === 1 /* TypeArgs */ ? invocation.called : invocation.node;
-  }
-  function createSignatureHelpItems(candidates, resolvedSignature, { isTypeParameterList, argumentCount, argumentsSpan: applicableSpan, invocation, argumentIndex }, sourceFile, typeChecker, useFullPrefix) {
-    var _a;
-    const enclosingDeclaration = getEnclosingDeclarationFromInvocation(invocation);
-    const callTargetSymbol = invocation.kind === 2 /* Contextual */ ? invocation.symbol : typeChecker.getSymbolAtLocation(getExpressionFromInvocation(invocation)) || useFullPrefix && ((_a = resolvedSignature.declaration) == null ? void 0 : _a.symbol);
-    const callTargetDisplayParts = callTargetSymbol ? symbolToDisplayParts(
-      typeChecker,
-      callTargetSymbol,
-      useFullPrefix ? sourceFile : void 0,
-      /*meaning*/
-      void 0
-    ) : emptyArray;
-    const items = map(candidates, (candidateSignature) => getSignatureHelpItem(candidateSignature, callTargetDisplayParts, isTypeParameterList, typeChecker, enclosingDeclaration, sourceFile));
-    if (argumentIndex !== 0) {
-      Debug.assertLessThan(argumentIndex, argumentCount);
-    }
-    let selectedItemIndex = 0;
-    let itemsSeen = 0;
-    for (let i = 0; i < items.length; i++) {
-      const item = items[i];
-      if (candidates[i] === resolvedSignature) {
-        selectedItemIndex = itemsSeen;
-        if (item.length > 1) {
-          let count = 0;
-          for (const i2 of item) {
-            if (i2.isVariadic || i2.parameters.length >= argumentCount) {
-              selectedItemIndex = itemsSeen + count;
-              break;
-            }
-            count++;
-          }
-        }
-      }
-      itemsSeen += item.length;
-    }
-    Debug.assert(selectedItemIndex !== -1);
-    const help = { items: flatMapToMutable(items, identity), applicableSpan, selectedItemIndex, argumentIndex, argumentCount };
-    const selected = help.items[selectedItemIndex];
-    if (selected.isVariadic) {
-      const firstRest = findIndex(selected.parameters, (p) => !!p.isRest);
-      if (-1 < firstRest && firstRest < selected.parameters.length - 1) {
-        help.argumentIndex = selected.parameters.length;
-      } else {
-        help.argumentIndex = Math.min(help.argumentIndex, selected.parameters.length - 1);
-      }
-    }
-    return help;
-  }
-  function createTypeHelpItems(symbol, { argumentCount, argumentsSpan: applicableSpan, invocation, argumentIndex }, sourceFile, checker) {
-    const typeParameters = checker.getLocalTypeParametersOfClassOrInterfaceOrTypeAlias(symbol);
-    if (!typeParameters)
-      return void 0;
-    const items = [getTypeHelpItem(symbol, typeParameters, checker, getEnclosingDeclarationFromInvocation(invocation), sourceFile)];
-    return { items, applicableSpan, selectedItemIndex: 0, argumentIndex, argumentCount };
-  }
-  function getTypeHelpItem(symbol, typeParameters, checker, enclosingDeclaration, sourceFile) {
-    const typeSymbolDisplay = symbolToDisplayParts(checker, symbol);
-    const printer = createPrinterWithRemoveComments();
-    const parameters = typeParameters.map((t) => createSignatureHelpParameterForTypeParameter(t, checker, enclosingDeclaration, sourceFile, printer));
-    const documentation = symbol.getDocumentationComment(checker);
-    const tags = symbol.getJsDocTags(checker);
-    const prefixDisplayParts = [...typeSymbolDisplay, punctuationPart(30 /* LessThanToken */)];
-    return { isVariadic: false, prefixDisplayParts, suffixDisplayParts: [punctuationPart(32 /* GreaterThanToken */)], separatorDisplayParts, parameters, documentation, tags };
-  }
-  function getSignatureHelpItem(candidateSignature, callTargetDisplayParts, isTypeParameterList, checker, enclosingDeclaration, sourceFile) {
-    const infos = (isTypeParameterList ? itemInfoForTypeParameters : itemInfoForParameters)(candidateSignature, checker, enclosingDeclaration, sourceFile);
-    return map(infos, ({ isVariadic, parameters, prefix, suffix }) => {
-      const prefixDisplayParts = [...callTargetDisplayParts, ...prefix];
-      const suffixDisplayParts = [...suffix, ...returnTypeToDisplayParts(candidateSignature, enclosingDeclaration, checker)];
-      const documentation = candidateSignature.getDocumentationComment(checker);
-      const tags = candidateSignature.getJsDocTags();
-      return { isVariadic, prefixDisplayParts, suffixDisplayParts, separatorDisplayParts, parameters, documentation, tags };
-    });
-  }
-  function returnTypeToDisplayParts(candidateSignature, enclosingDeclaration, checker) {
-    return mapToDisplayParts((writer) => {
-      writer.writePunctuation(":");
-      writer.writeSpace(" ");
-      const predicate = checker.getTypePredicateOfSignature(candidateSignature);
-      if (predicate) {
-        checker.writeTypePredicate(
-          predicate,
-          enclosingDeclaration,
-          /*flags*/
-          void 0,
-          writer
-        );
-      } else {
-        checker.writeType(
-          checker.getReturnTypeOfSignature(candidateSignature),
-          enclosingDeclaration,
-          /*flags*/
-          void 0,
-          writer
-        );
-      }
-    });
-  }
-  function itemInfoForTypeParameters(candidateSignature, checker, enclosingDeclaration, sourceFile) {
-    const typeParameters = (candidateSignature.target || candidateSignature).typeParameters;
-    const printer = createPrinterWithRemoveComments();
-    const parameters = (typeParameters || emptyArray).map((t) => createSignatureHelpParameterForTypeParameter(t, checker, enclosingDeclaration, sourceFile, printer));
-    const thisParameter = candidateSignature.thisParameter ? [checker.symbolToParameterDeclaration(candidateSignature.thisParameter, enclosingDeclaration, signatureHelpNodeBuilderFlags)] : [];
-    return checker.getExpandedParameters(candidateSignature).map((paramList) => {
-      const params = factory.createNodeArray([...thisParameter, ...map(paramList, (param) => checker.symbolToParameterDeclaration(param, enclosingDeclaration, signatureHelpNodeBuilderFlags))]);
-      const parameterParts = mapToDisplayParts((writer) => {
-        printer.writeList(2576 /* CallExpressionArguments */, params, sourceFile, writer);
-      });
-      return { isVariadic: false, parameters, prefix: [punctuationPart(30 /* LessThanToken */)], suffix: [punctuationPart(32 /* GreaterThanToken */), ...parameterParts] };
-    });
-  }
-  function itemInfoForParameters(candidateSignature, checker, enclosingDeclaration, sourceFile) {
-    const printer = createPrinterWithRemoveComments();
-    const typeParameterParts = mapToDisplayParts((writer) => {
-      if (candidateSignature.typeParameters && candidateSignature.typeParameters.length) {
-        const args = factory.createNodeArray(candidateSignature.typeParameters.map((p) => checker.typeParameterToDeclaration(p, enclosingDeclaration, signatureHelpNodeBuilderFlags)));
-        printer.writeList(53776 /* TypeParameters */, args, sourceFile, writer);
-      }
-    });
-    const lists = checker.getExpandedParameters(candidateSignature);
-    const isVariadic = !checker.hasEffectiveRestParameter(candidateSignature) ? (_) => false : lists.length === 1 ? (_) => true : (pList) => {
-      var _a;
-      return !!(pList.length && ((_a = tryCast(pList[pList.length - 1], isTransientSymbol)) == null ? void 0 : _a.links.checkFlags) & 32768 /* RestParameter */);
-    };
-    return lists.map((parameterList) => ({
-      isVariadic: isVariadic(parameterList),
-      parameters: parameterList.map((p) => createSignatureHelpParameterForParameter(p, checker, enclosingDeclaration, sourceFile, printer)),
-      prefix: [...typeParameterParts, punctuationPart(21 /* OpenParenToken */)],
-      suffix: [punctuationPart(22 /* CloseParenToken */)]
-    }));
-  }
-  function createSignatureHelpParameterForParameter(parameter, checker, enclosingDeclaration, sourceFile, printer) {
-    const displayParts = mapToDisplayParts((writer) => {
-      const param = checker.symbolToParameterDeclaration(parameter, enclosingDeclaration, signatureHelpNodeBuilderFlags);
-      printer.writeNode(4 /* Unspecified */, param, sourceFile, writer);
-    });
-    const isOptional = checker.isOptionalParameter(parameter.valueDeclaration);
-    const isRest = isTransientSymbol(parameter) && !!(parameter.links.checkFlags & 32768 /* RestParameter */);
-    return { name: parameter.name, documentation: parameter.getDocumentationComment(checker), displayParts, isOptional, isRest };
-  }
-  function createSignatureHelpParameterForTypeParameter(typeParameter, checker, enclosingDeclaration, sourceFile, printer) {
-    const displayParts = mapToDisplayParts((writer) => {
-      const param = checker.typeParameterToDeclaration(typeParameter, enclosingDeclaration, signatureHelpNodeBuilderFlags);
-      printer.writeNode(4 /* Unspecified */, param, sourceFile, writer);
-    });
-    return { name: typeParameter.symbol.name, documentation: typeParameter.symbol.getDocumentationComment(checker), displayParts, isOptional: false, isRest: false };
-  }
-  var signatureHelpNodeBuilderFlags, separatorDisplayParts;
-  var init_signatureHelp = __esm({
-    "src/services/signatureHelp.ts"() {
-      "use strict";
-      init_ts4();
-      signatureHelpNodeBuilderFlags = 8192 /* OmitParameterModifiers */ | 70221824 /* IgnoreErrors */ | 16384 /* UseAliasDefinedOutsideCurrentScope */;
-      separatorDisplayParts = [punctuationPart(28 /* CommaToken */), spacePart()];
-    }
-  });
-
-  // src/services/_namespaces/ts.SignatureHelp.ts
-  var ts_SignatureHelp_exports = {};
-  __export(ts_SignatureHelp_exports, {
-    getArgumentInfoForCompletions: () => getArgumentInfoForCompletions,
-    getSignatureHelpItems: () => getSignatureHelpItems
-  });
-  var init_ts_SignatureHelp = __esm({
-    "src/services/_namespaces/ts.SignatureHelp.ts"() {
-      "use strict";
-      init_signatureHelp();
-    }
-  });
-
-  // src/services/smartSelection.ts
-  function getSmartSelectionRange(pos, sourceFile) {
-    var _a, _b;
-    let selectionRange = {
-      textSpan: createTextSpanFromBounds(sourceFile.getFullStart(), sourceFile.getEnd())
-    };
-    let parentNode = sourceFile;
-    outer:
-      while (true) {
-        const children = getSelectionChildren(parentNode);
-        if (!children.length)
-          break;
-        for (let i = 0; i < children.length; i++) {
-          const prevNode = children[i - 1];
-          const node = children[i];
-          const nextNode = children[i + 1];
-          if (getTokenPosOfNode(
-            node,
-            sourceFile,
-            /*includeJsDoc*/
-            true
-          ) > pos) {
-            break outer;
-          }
-          const comment = singleOrUndefined(getTrailingCommentRanges(sourceFile.text, node.end));
-          if (comment && comment.kind === 2 /* SingleLineCommentTrivia */) {
-            pushSelectionCommentRange(comment.pos, comment.end);
-          }
-          if (positionShouldSnapToNode(sourceFile, pos, node)) {
-            if (isFunctionBody(node) && isFunctionLikeDeclaration(parentNode) && !positionsAreOnSameLine(node.getStart(sourceFile), node.getEnd(), sourceFile)) {
-              pushSelectionRange(node.getStart(sourceFile), node.getEnd());
-            }
-            if (isBlock(node) || isTemplateSpan(node) || isTemplateHead(node) || isTemplateTail(node) || prevNode && isTemplateHead(prevNode) || isVariableDeclarationList(node) && isVariableStatement(parentNode) || isSyntaxList(node) && isVariableDeclarationList(parentNode) || isVariableDeclaration(node) && isSyntaxList(parentNode) && children.length === 1 || isJSDocTypeExpression(node) || isJSDocSignature(node) || isJSDocTypeLiteral(node)) {
-              parentNode = node;
-              break;
-            }
-            if (isTemplateSpan(parentNode) && nextNode && isTemplateMiddleOrTemplateTail(nextNode)) {
-              const start2 = node.getFullStart() - "${".length;
-              const end2 = nextNode.getStart() + "}".length;
-              pushSelectionRange(start2, end2);
-            }
-            const isBetweenMultiLineBookends = isSyntaxList(node) && isListOpener(prevNode) && isListCloser(nextNode) && !positionsAreOnSameLine(prevNode.getStart(), nextNode.getStart(), sourceFile);
-            let start = isBetweenMultiLineBookends ? prevNode.getEnd() : node.getStart();
-            const end = isBetweenMultiLineBookends ? nextNode.getStart() : getEndPos(sourceFile, node);
-            if (hasJSDocNodes(node) && ((_a = node.jsDoc) == null ? void 0 : _a.length)) {
-              pushSelectionRange(first(node.jsDoc).getStart(), end);
-            }
-            if (isSyntaxList(node)) {
-              const firstChild = node.getChildren()[0];
-              if (firstChild && hasJSDocNodes(firstChild) && ((_b = firstChild.jsDoc) == null ? void 0 : _b.length) && firstChild.getStart() !== node.pos) {
-                start = Math.min(start, first(firstChild.jsDoc).getStart());
-              }
-            }
-            pushSelectionRange(start, end);
-            if (isStringLiteral(node) || isTemplateLiteral(node)) {
-              pushSelectionRange(start + 1, end - 1);
-            }
-            parentNode = node;
-            break;
-          }
-          if (i === children.length - 1) {
-            break outer;
-          }
-        }
-      }
-    return selectionRange;
-    function pushSelectionRange(start, end) {
-      if (start !== end) {
-        const textSpan = createTextSpanFromBounds(start, end);
-        if (!selectionRange || // Skip ranges that are identical to the parent
-        !textSpansEqual(textSpan, selectionRange.textSpan) && // Skip ranges that don't contain the original position
-        textSpanIntersectsWithPosition(textSpan, pos)) {
-          selectionRange = { textSpan, ...selectionRange && { parent: selectionRange } };
-        }
-      }
-    }
-    function pushSelectionCommentRange(start, end) {
-      pushSelectionRange(start, end);
-      let pos2 = start;
-      while (sourceFile.text.charCodeAt(pos2) === 47 /* slash */) {
-        pos2++;
-      }
-      pushSelectionRange(pos2, end);
-    }
-  }
-  function positionShouldSnapToNode(sourceFile, pos, node) {
-    Debug.assert(node.pos <= pos);
-    if (pos < node.end) {
-      return true;
-    }
-    const nodeEnd = node.getEnd();
-    if (nodeEnd === pos) {
-      return getTouchingPropertyName(sourceFile, pos).pos < node.end;
-    }
-    return false;
-  }
-  function getSelectionChildren(node) {
-    var _a;
-    if (isSourceFile(node)) {
-      return groupChildren(node.getChildAt(0).getChildren(), isImport2);
-    }
-    if (isMappedTypeNode(node)) {
-      const [openBraceToken, ...children] = node.getChildren();
-      const closeBraceToken = Debug.checkDefined(children.pop());
-      Debug.assertEqual(openBraceToken.kind, 19 /* OpenBraceToken */);
-      Debug.assertEqual(closeBraceToken.kind, 20 /* CloseBraceToken */);
-      const groupedWithPlusMinusTokens = groupChildren(children, (child) => child === node.readonlyToken || child.kind === 148 /* ReadonlyKeyword */ || child === node.questionToken || child.kind === 58 /* QuestionToken */);
-      const groupedWithBrackets = groupChildren(
-        groupedWithPlusMinusTokens,
-        ({ kind }) => kind === 23 /* OpenBracketToken */ || kind === 167 /* TypeParameter */ || kind === 24 /* CloseBracketToken */
-      );
-      return [
-        openBraceToken,
-        // Pivot on `:`
-        createSyntaxList2(splitChildren(groupedWithBrackets, ({ kind }) => kind === 59 /* ColonToken */)),
-        closeBraceToken
-      ];
-    }
-    if (isPropertySignature(node)) {
-      const children = groupChildren(node.getChildren(), (child) => child === node.name || contains(node.modifiers, child));
-      const firstJSDocChild = ((_a = children[0]) == null ? void 0 : _a.kind) === 326 /* JSDoc */ ? children[0] : void 0;
-      const withJSDocSeparated = firstJSDocChild ? children.slice(1) : children;
-      const splittedChildren = splitChildren(withJSDocSeparated, ({ kind }) => kind === 59 /* ColonToken */);
-      return firstJSDocChild ? [firstJSDocChild, createSyntaxList2(splittedChildren)] : splittedChildren;
-    }
-    if (isParameter(node)) {
-      const groupedDotDotDotAndName = groupChildren(node.getChildren(), (child) => child === node.dotDotDotToken || child === node.name);
-      const groupedWithQuestionToken = groupChildren(groupedDotDotDotAndName, (child) => child === groupedDotDotDotAndName[0] || child === node.questionToken);
-      return splitChildren(groupedWithQuestionToken, ({ kind }) => kind === 64 /* EqualsToken */);
-    }
-    if (isBindingElement(node)) {
-      return splitChildren(node.getChildren(), ({ kind }) => kind === 64 /* EqualsToken */);
-    }
-    return node.getChildren();
-  }
-  function groupChildren(children, groupOn) {
-    const result = [];
-    let group2;
-    for (const child of children) {
-      if (groupOn(child)) {
-        group2 = group2 || [];
-        group2.push(child);
-      } else {
-        if (group2) {
-          result.push(createSyntaxList2(group2));
-          group2 = void 0;
-        }
-        result.push(child);
-      }
-    }
-    if (group2) {
-      result.push(createSyntaxList2(group2));
-    }
-    return result;
-  }
-  function splitChildren(children, pivotOn, separateTrailingSemicolon = true) {
-    if (children.length < 2) {
-      return children;
-    }
-    const splitTokenIndex = findIndex(children, pivotOn);
-    if (splitTokenIndex === -1) {
-      return children;
-    }
-    const leftChildren = children.slice(0, splitTokenIndex);
-    const splitToken = children[splitTokenIndex];
-    const lastToken = last(children);
-    const separateLastToken = separateTrailingSemicolon && lastToken.kind === 27 /* SemicolonToken */;
-    const rightChildren = children.slice(splitTokenIndex + 1, separateLastToken ? children.length - 1 : void 0);
-    const result = compact([
-      leftChildren.length ? createSyntaxList2(leftChildren) : void 0,
-      splitToken,
-      rightChildren.length ? createSyntaxList2(rightChildren) : void 0
-    ]);
-    return separateLastToken ? result.concat(lastToken) : result;
-  }
-  function createSyntaxList2(children) {
-    Debug.assertGreaterThanOrEqual(children.length, 1);
-    return setTextRangePosEnd(parseNodeFactory.createSyntaxList(children), children[0].pos, last(children).end);
-  }
-  function isListOpener(token) {
-    const kind = token && token.kind;
-    return kind === 19 /* OpenBraceToken */ || kind === 23 /* OpenBracketToken */ || kind === 21 /* OpenParenToken */ || kind === 285 /* JsxOpeningElement */;
-  }
-  function isListCloser(token) {
-    const kind = token && token.kind;
-    return kind === 20 /* CloseBraceToken */ || kind === 24 /* CloseBracketToken */ || kind === 22 /* CloseParenToken */ || kind === 286 /* JsxClosingElement */;
-  }
-  function getEndPos(sourceFile, node) {
-    switch (node.kind) {
-      case 347 /* JSDocParameterTag */:
-      case 344 /* JSDocCallbackTag */:
-      case 354 /* JSDocPropertyTag */:
-      case 352 /* JSDocTypedefTag */:
-      case 349 /* JSDocThisTag */:
-        return sourceFile.getLineEndOfPosition(node.getStart());
-      default:
-        return node.getEnd();
-    }
-  }
-  var isImport2;
-  var init_smartSelection = __esm({
-    "src/services/smartSelection.ts"() {
-      "use strict";
-      init_ts4();
-      isImport2 = or(isImportDeclaration, isImportEqualsDeclaration);
-    }
-  });
-
-  // src/services/_namespaces/ts.SmartSelectionRange.ts
-  var ts_SmartSelectionRange_exports = {};
-  __export(ts_SmartSelectionRange_exports, {
-    getSmartSelectionRange: () => getSmartSelectionRange
-  });
-  var init_ts_SmartSelectionRange = __esm({
-    "src/services/_namespaces/ts.SmartSelectionRange.ts"() {
-      "use strict";
-      init_smartSelection();
-    }
-  });
-
-  // src/services/symbolDisplay.ts
-  function getSymbolKind(typeChecker, symbol, location) {
-    const result = getSymbolKindOfConstructorPropertyMethodAccessorFunctionOrVar(typeChecker, symbol, location);
-    if (result !== "" /* unknown */) {
-      return result;
-    }
-    const flags = getCombinedLocalAndExportSymbolFlags(symbol);
-    if (flags & 32 /* Class */) {
-      return getDeclarationOfKind(symbol, 230 /* ClassExpression */) ? "local class" /* localClassElement */ : "class" /* classElement */;
-    }
-    if (flags & 384 /* Enum */)
-      return "enum" /* enumElement */;
-    if (flags & 524288 /* TypeAlias */)
-      return "type" /* typeElement */;
-    if (flags & 64 /* Interface */)
-      return "interface" /* interfaceElement */;
-    if (flags & 262144 /* TypeParameter */)
-      return "type parameter" /* typeParameterElement */;
-    if (flags & 8 /* EnumMember */)
-      return "enum member" /* enumMemberElement */;
-    if (flags & 2097152 /* Alias */)
-      return "alias" /* alias */;
-    if (flags & 1536 /* Module */)
-      return "module" /* moduleElement */;
-    return result;
-  }
-  function getSymbolKindOfConstructorPropertyMethodAccessorFunctionOrVar(typeChecker, symbol, location) {
-    const roots = typeChecker.getRootSymbols(symbol);
-    if (roots.length === 1 && first(roots).flags & 8192 /* Method */ && typeChecker.getTypeOfSymbolAtLocation(symbol, location).getNonNullableType().getCallSignatures().length !== 0) {
-      return "method" /* memberFunctionElement */;
-    }
-    if (typeChecker.isUndefinedSymbol(symbol)) {
-      return "var" /* variableElement */;
-    }
-    if (typeChecker.isArgumentsSymbol(symbol)) {
-      return "local var" /* localVariableElement */;
-    }
-    if (location.kind === 110 /* ThisKeyword */ && isExpression(location) || isThisInTypeQuery(location)) {
-      return "parameter" /* parameterElement */;
-    }
-    const flags = getCombinedLocalAndExportSymbolFlags(symbol);
-    if (flags & 3 /* Variable */) {
-      if (isFirstDeclarationOfSymbolParameter(symbol)) {
-        return "parameter" /* parameterElement */;
-      } else if (symbol.valueDeclaration && isVarConst(symbol.valueDeclaration)) {
-        return "const" /* constElement */;
-      } else if (forEach(symbol.declarations, isLet)) {
-        return "let" /* letElement */;
-      }
-      return isLocalVariableOrFunction(symbol) ? "local var" /* localVariableElement */ : "var" /* variableElement */;
-    }
-    if (flags & 16 /* Function */)
-      return isLocalVariableOrFunction(symbol) ? "local function" /* localFunctionElement */ : "function" /* functionElement */;
-    if (flags & 32768 /* GetAccessor */)
-      return "getter" /* memberGetAccessorElement */;
-    if (flags & 65536 /* SetAccessor */)
-      return "setter" /* memberSetAccessorElement */;
-    if (flags & 8192 /* Method */)
-      return "method" /* memberFunctionElement */;
-    if (flags & 16384 /* Constructor */)
-      return "constructor" /* constructorImplementationElement */;
-    if (flags & 131072 /* Signature */)
-      return "index" /* indexSignatureElement */;
-    if (flags & 4 /* Property */) {
-      if (flags & 33554432 /* Transient */ && symbol.links.checkFlags & 6 /* Synthetic */) {
-        const unionPropertyKind = forEach(typeChecker.getRootSymbols(symbol), (rootSymbol) => {
-          const rootSymbolFlags = rootSymbol.getFlags();
-          if (rootSymbolFlags & (98308 /* PropertyOrAccessor */ | 3 /* Variable */)) {
-            return "property" /* memberVariableElement */;
-          }
-        });
-        if (!unionPropertyKind) {
-          const typeOfUnionProperty = typeChecker.getTypeOfSymbolAtLocation(symbol, location);
-          if (typeOfUnionProperty.getCallSignatures().length) {
-            return "method" /* memberFunctionElement */;
-          }
-          return "property" /* memberVariableElement */;
-        }
-        return unionPropertyKind;
-      }
-      return "property" /* memberVariableElement */;
-    }
-    return "" /* unknown */;
-  }
-  function getNormalizedSymbolModifiers(symbol) {
-    if (symbol.declarations && symbol.declarations.length) {
-      const [declaration, ...declarations] = symbol.declarations;
-      const excludeFlags = length(declarations) && isDeprecatedDeclaration(declaration) && some(declarations, (d) => !isDeprecatedDeclaration(d)) ? 8192 /* Deprecated */ : 0 /* None */;
-      const modifiers = getNodeModifiers(declaration, excludeFlags);
-      if (modifiers) {
-        return modifiers.split(",");
-      }
-    }
-    return [];
-  }
-  function getSymbolModifiers(typeChecker, symbol) {
-    if (!symbol) {
-      return "" /* none */;
-    }
-    const modifiers = new Set(getNormalizedSymbolModifiers(symbol));
-    if (symbol.flags & 2097152 /* Alias */) {
-      const resolvedSymbol = typeChecker.getAliasedSymbol(symbol);
-      if (resolvedSymbol !== symbol) {
-        forEach(getNormalizedSymbolModifiers(resolvedSymbol), (modifier) => {
-          modifiers.add(modifier);
-        });
-      }
-    }
-    if (symbol.flags & 16777216 /* Optional */) {
-      modifiers.add("optional" /* optionalModifier */);
-    }
-    return modifiers.size > 0 ? arrayFrom(modifiers.values()).join(",") : "" /* none */;
-  }
-  function getSymbolDisplayPartsDocumentationAndSymbolKind(typeChecker, symbol, sourceFile, enclosingDeclaration, location, semanticMeaning = getMeaningFromLocation(location), alias) {
-    var _a;
-    const displayParts = [];
-    let documentation = [];
-    let tags = [];
-    const symbolFlags = getCombinedLocalAndExportSymbolFlags(symbol);
-    let symbolKind = semanticMeaning & 1 /* Value */ ? getSymbolKindOfConstructorPropertyMethodAccessorFunctionOrVar(typeChecker, symbol, location) : "" /* unknown */;
-    let hasAddedSymbolInfo = false;
-    const isThisExpression = location.kind === 110 /* ThisKeyword */ && isInExpressionContext(location) || isThisInTypeQuery(location);
-    let type;
-    let documentationFromAlias;
-    let tagsFromAlias;
-    let hasMultipleSignatures = false;
-    if (location.kind === 110 /* ThisKeyword */ && !isThisExpression) {
-      return { displayParts: [keywordPart(110 /* ThisKeyword */)], documentation: [], symbolKind: "primitive type" /* primitiveType */, tags: void 0 };
-    }
-    if (symbolKind !== "" /* unknown */ || symbolFlags & 32 /* Class */ || symbolFlags & 2097152 /* Alias */) {
-      if (symbolKind === "getter" /* memberGetAccessorElement */ || symbolKind === "setter" /* memberSetAccessorElement */) {
-        const declaration = find(symbol.declarations, (declaration2) => declaration2.name === location);
-        if (declaration) {
-          switch (declaration.kind) {
-            case 176 /* GetAccessor */:
-              symbolKind = "getter" /* memberGetAccessorElement */;
-              break;
-            case 177 /* SetAccessor */:
-              symbolKind = "setter" /* memberSetAccessorElement */;
-              break;
-            case 171 /* PropertyDeclaration */:
-              symbolKind = "accessor" /* memberAccessorVariableElement */;
-              break;
-            default:
-              Debug.assertNever(declaration);
-          }
-        } else {
-          symbolKind = "property" /* memberVariableElement */;
-        }
-      }
-      let signature;
-      type = isThisExpression ? typeChecker.getTypeAtLocation(location) : typeChecker.getTypeOfSymbolAtLocation(symbol, location);
-      if (location.parent && location.parent.kind === 210 /* PropertyAccessExpression */) {
-        const right = location.parent.name;
-        if (right === location || right && right.getFullWidth() === 0) {
-          location = location.parent;
-        }
-      }
-      let callExpressionLike;
-      if (isCallOrNewExpression(location)) {
-        callExpressionLike = location;
-      } else if (isCallExpressionTarget(location) || isNewExpressionTarget(location)) {
-        callExpressionLike = location.parent;
-      } else if (location.parent && (isJsxOpeningLikeElement(location.parent) || isTaggedTemplateExpression(location.parent)) && isFunctionLike(symbol.valueDeclaration)) {
-        callExpressionLike = location.parent;
-      }
-      if (callExpressionLike) {
-        signature = typeChecker.getResolvedSignature(callExpressionLike);
-        const useConstructSignatures = callExpressionLike.kind === 213 /* NewExpression */ || isCallExpression(callExpressionLike) && callExpressionLike.expression.kind === 108 /* SuperKeyword */;
-        const allSignatures = useConstructSignatures ? type.getConstructSignatures() : type.getCallSignatures();
-        if (signature && !contains(allSignatures, signature.target) && !contains(allSignatures, signature)) {
-          signature = allSignatures.length ? allSignatures[0] : void 0;
-        }
-        if (signature) {
-          if (useConstructSignatures && symbolFlags & 32 /* Class */) {
-            symbolKind = "constructor" /* constructorImplementationElement */;
-            addPrefixForAnyFunctionOrVar(type.symbol, symbolKind);
-          } else if (symbolFlags & 2097152 /* Alias */) {
-            symbolKind = "alias" /* alias */;
-            pushSymbolKind(symbolKind);
-            displayParts.push(spacePart());
-            if (useConstructSignatures) {
-              if (signature.flags & 4 /* Abstract */) {
-                displayParts.push(keywordPart(128 /* AbstractKeyword */));
-                displayParts.push(spacePart());
-              }
-              displayParts.push(keywordPart(105 /* NewKeyword */));
-              displayParts.push(spacePart());
-            }
-            addFullSymbolName(symbol);
-          } else {
-            addPrefixForAnyFunctionOrVar(symbol, symbolKind);
-          }
-          switch (symbolKind) {
-            case "JSX attribute" /* jsxAttribute */:
-            case "property" /* memberVariableElement */:
-            case "var" /* variableElement */:
-            case "const" /* constElement */:
-            case "let" /* letElement */:
-            case "parameter" /* parameterElement */:
-            case "local var" /* localVariableElement */:
-              displayParts.push(punctuationPart(59 /* ColonToken */));
-              displayParts.push(spacePart());
-              if (!(getObjectFlags(type) & 16 /* Anonymous */) && type.symbol) {
-                addRange(displayParts, symbolToDisplayParts(
-                  typeChecker,
-                  type.symbol,
-                  enclosingDeclaration,
-                  /*meaning*/
-                  void 0,
-                  4 /* AllowAnyNodeKind */ | 1 /* WriteTypeParametersOrArguments */
-                ));
-                displayParts.push(lineBreakPart());
-              }
-              if (useConstructSignatures) {
-                if (signature.flags & 4 /* Abstract */) {
-                  displayParts.push(keywordPart(128 /* AbstractKeyword */));
-                  displayParts.push(spacePart());
-                }
-                displayParts.push(keywordPart(105 /* NewKeyword */));
-                displayParts.push(spacePart());
-              }
-              addSignatureDisplayParts(signature, allSignatures, 262144 /* WriteArrowStyleSignature */);
-              break;
-            default:
-              addSignatureDisplayParts(signature, allSignatures);
-          }
-          hasAddedSymbolInfo = true;
-          hasMultipleSignatures = allSignatures.length > 1;
-        }
-      } else if (isNameOfFunctionDeclaration(location) && !(symbolFlags & 98304 /* Accessor */) || // name of function declaration
-      location.kind === 137 /* ConstructorKeyword */ && location.parent.kind === 175 /* Constructor */) {
-        const functionDeclaration = location.parent;
-        const locationIsSymbolDeclaration = symbol.declarations && find(symbol.declarations, (declaration) => declaration === (location.kind === 137 /* ConstructorKeyword */ ? functionDeclaration.parent : functionDeclaration));
-        if (locationIsSymbolDeclaration) {
-          const allSignatures = functionDeclaration.kind === 175 /* Constructor */ ? type.getNonNullableType().getConstructSignatures() : type.getNonNullableType().getCallSignatures();
-          if (!typeChecker.isImplementationOfOverload(functionDeclaration)) {
-            signature = typeChecker.getSignatureFromDeclaration(functionDeclaration);
-          } else {
-            signature = allSignatures[0];
-          }
-          if (functionDeclaration.kind === 175 /* Constructor */) {
-            symbolKind = "constructor" /* constructorImplementationElement */;
-            addPrefixForAnyFunctionOrVar(type.symbol, symbolKind);
-          } else {
-            addPrefixForAnyFunctionOrVar(functionDeclaration.kind === 178 /* CallSignature */ && !(type.symbol.flags & 2048 /* TypeLiteral */ || type.symbol.flags & 4096 /* ObjectLiteral */) ? type.symbol : symbol, symbolKind);
-          }
-          if (signature) {
-            addSignatureDisplayParts(signature, allSignatures);
-          }
-          hasAddedSymbolInfo = true;
-          hasMultipleSignatures = allSignatures.length > 1;
-        }
-      }
-    }
-    if (symbolFlags & 32 /* Class */ && !hasAddedSymbolInfo && !isThisExpression) {
-      addAliasPrefixIfNecessary();
-      if (getDeclarationOfKind(symbol, 230 /* ClassExpression */)) {
-        pushSymbolKind("local class" /* localClassElement */);
-      } else {
-        displayParts.push(keywordPart(86 /* ClassKeyword */));
-      }
-      displayParts.push(spacePart());
-      addFullSymbolName(symbol);
-      writeTypeParametersOfSymbol(symbol, sourceFile);
-    }
-    if (symbolFlags & 64 /* Interface */ && semanticMeaning & 2 /* Type */) {
-      prefixNextMeaning();
-      displayParts.push(keywordPart(120 /* InterfaceKeyword */));
-      displayParts.push(spacePart());
-      addFullSymbolName(symbol);
-      writeTypeParametersOfSymbol(symbol, sourceFile);
-    }
-    if (symbolFlags & 524288 /* TypeAlias */ && semanticMeaning & 2 /* Type */) {
-      prefixNextMeaning();
-      displayParts.push(keywordPart(156 /* TypeKeyword */));
-      displayParts.push(spacePart());
-      addFullSymbolName(symbol);
-      writeTypeParametersOfSymbol(symbol, sourceFile);
-      displayParts.push(spacePart());
-      displayParts.push(operatorPart(64 /* EqualsToken */));
-      displayParts.push(spacePart());
-      addRange(displayParts, typeToDisplayParts(typeChecker, location.parent && isConstTypeReference(location.parent) ? typeChecker.getTypeAtLocation(location.parent) : typeChecker.getDeclaredTypeOfSymbol(symbol), enclosingDeclaration, 8388608 /* InTypeAlias */));
-    }
-    if (symbolFlags & 384 /* Enum */) {
-      prefixNextMeaning();
-      if (some(symbol.declarations, (d) => isEnumDeclaration(d) && isEnumConst(d))) {
-        displayParts.push(keywordPart(87 /* ConstKeyword */));
-        displayParts.push(spacePart());
-      }
-      displayParts.push(keywordPart(94 /* EnumKeyword */));
-      displayParts.push(spacePart());
-      addFullSymbolName(symbol);
-    }
-    if (symbolFlags & 1536 /* Module */ && !isThisExpression) {
-      prefixNextMeaning();
-      const declaration = getDeclarationOfKind(symbol, 266 /* ModuleDeclaration */);
-      const isNamespace = declaration && declaration.name && declaration.name.kind === 80 /* Identifier */;
-      displayParts.push(keywordPart(isNamespace ? 145 /* NamespaceKeyword */ : 144 /* ModuleKeyword */));
-      displayParts.push(spacePart());
-      addFullSymbolName(symbol);
-    }
-    if (symbolFlags & 262144 /* TypeParameter */ && semanticMeaning & 2 /* Type */) {
-      prefixNextMeaning();
-      displayParts.push(punctuationPart(21 /* OpenParenToken */));
-      displayParts.push(textPart("type parameter"));
-      displayParts.push(punctuationPart(22 /* CloseParenToken */));
-      displayParts.push(spacePart());
-      addFullSymbolName(symbol);
-      if (symbol.parent) {
-        addInPrefix();
-        addFullSymbolName(symbol.parent, enclosingDeclaration);
-        writeTypeParametersOfSymbol(symbol.parent, enclosingDeclaration);
-      } else {
-        const decl = getDeclarationOfKind(symbol, 167 /* TypeParameter */);
-        if (decl === void 0)
-          return Debug.fail();
-        const declaration = decl.parent;
-        if (declaration) {
-          if (isFunctionLike(declaration)) {
-            addInPrefix();
-            const signature = typeChecker.getSignatureFromDeclaration(declaration);
-            if (declaration.kind === 179 /* ConstructSignature */) {
-              displayParts.push(keywordPart(105 /* NewKeyword */));
-              displayParts.push(spacePart());
-            } else if (declaration.kind !== 178 /* CallSignature */ && declaration.name) {
-              addFullSymbolName(declaration.symbol);
-            }
-            addRange(displayParts, signatureToDisplayParts(typeChecker, signature, sourceFile, 32 /* WriteTypeArgumentsOfSignature */));
-          } else if (isTypeAliasDeclaration(declaration)) {
-            addInPrefix();
-            displayParts.push(keywordPart(156 /* TypeKeyword */));
-            displayParts.push(spacePart());
-            addFullSymbolName(declaration.symbol);
-            writeTypeParametersOfSymbol(declaration.symbol, sourceFile);
-          }
-        }
-      }
-    }
-    if (symbolFlags & 8 /* EnumMember */) {
-      symbolKind = "enum member" /* enumMemberElement */;
-      addPrefixForAnyFunctionOrVar(symbol, "enum member");
-      const declaration = (_a = symbol.declarations) == null ? void 0 : _a[0];
-      if ((declaration == null ? void 0 : declaration.kind) === 305 /* EnumMember */) {
-        const constantValue = typeChecker.getConstantValue(declaration);
-        if (constantValue !== void 0) {
-          displayParts.push(spacePart());
-          displayParts.push(operatorPart(64 /* EqualsToken */));
-          displayParts.push(spacePart());
-          displayParts.push(displayPart(
-            getTextOfConstantValue(constantValue),
-            typeof constantValue === "number" ? 7 /* numericLiteral */ : 8 /* stringLiteral */
-          ));
-        }
-      }
-    }
-    if (symbol.flags & 2097152 /* Alias */) {
-      prefixNextMeaning();
-      if (!hasAddedSymbolInfo || documentation.length === 0 && tags.length === 0) {
-        const resolvedSymbol = typeChecker.getAliasedSymbol(symbol);
-        if (resolvedSymbol !== symbol && resolvedSymbol.declarations && resolvedSymbol.declarations.length > 0) {
-          const resolvedNode = resolvedSymbol.declarations[0];
-          const declarationName = getNameOfDeclaration(resolvedNode);
-          if (declarationName && !hasAddedSymbolInfo) {
-            const isExternalModuleDeclaration = isModuleWithStringLiteralName(resolvedNode) && hasSyntacticModifier(resolvedNode, 2 /* Ambient */);
-            const shouldUseAliasName = symbol.name !== "default" && !isExternalModuleDeclaration;
-            const resolvedInfo = getSymbolDisplayPartsDocumentationAndSymbolKind(
-              typeChecker,
-              resolvedSymbol,
-              getSourceFileOfNode(resolvedNode),
-              resolvedNode,
-              declarationName,
-              semanticMeaning,
-              shouldUseAliasName ? symbol : resolvedSymbol
-            );
-            displayParts.push(...resolvedInfo.displayParts);
-            displayParts.push(lineBreakPart());
-            documentationFromAlias = resolvedInfo.documentation;
-            tagsFromAlias = resolvedInfo.tags;
-          } else {
-            documentationFromAlias = resolvedSymbol.getContextualDocumentationComment(resolvedNode, typeChecker);
-            tagsFromAlias = resolvedSymbol.getJsDocTags(typeChecker);
-          }
-        }
-      }
-      if (symbol.declarations) {
-        switch (symbol.declarations[0].kind) {
-          case 269 /* NamespaceExportDeclaration */:
-            displayParts.push(keywordPart(95 /* ExportKeyword */));
-            displayParts.push(spacePart());
-            displayParts.push(keywordPart(145 /* NamespaceKeyword */));
-            break;
-          case 276 /* ExportAssignment */:
-            displayParts.push(keywordPart(95 /* ExportKeyword */));
-            displayParts.push(spacePart());
-            displayParts.push(keywordPart(symbol.declarations[0].isExportEquals ? 64 /* EqualsToken */ : 90 /* DefaultKeyword */));
-            break;
-          case 280 /* ExportSpecifier */:
-            displayParts.push(keywordPart(95 /* ExportKeyword */));
-            break;
-          default:
-            displayParts.push(keywordPart(102 /* ImportKeyword */));
-        }
-      }
-      displayParts.push(spacePart());
-      addFullSymbolName(symbol);
-      forEach(symbol.declarations, (declaration) => {
-        if (declaration.kind === 270 /* ImportEqualsDeclaration */) {
-          const importEqualsDeclaration = declaration;
-          if (isExternalModuleImportEqualsDeclaration(importEqualsDeclaration)) {
-            displayParts.push(spacePart());
-            displayParts.push(operatorPart(64 /* EqualsToken */));
-            displayParts.push(spacePart());
-            displayParts.push(keywordPart(149 /* RequireKeyword */));
-            displayParts.push(punctuationPart(21 /* OpenParenToken */));
-            displayParts.push(displayPart(getTextOfNode(getExternalModuleImportEqualsDeclarationExpression(importEqualsDeclaration)), 8 /* stringLiteral */));
-            displayParts.push(punctuationPart(22 /* CloseParenToken */));
-          } else {
-            const internalAliasSymbol = typeChecker.getSymbolAtLocation(importEqualsDeclaration.moduleReference);
-            if (internalAliasSymbol) {
-              displayParts.push(spacePart());
-              displayParts.push(operatorPart(64 /* EqualsToken */));
-              displayParts.push(spacePart());
-              addFullSymbolName(internalAliasSymbol, enclosingDeclaration);
-            }
-          }
-          return true;
-        }
-      });
-    }
-    if (!hasAddedSymbolInfo) {
-      if (symbolKind !== "" /* unknown */) {
-        if (type) {
-          if (isThisExpression) {
-            prefixNextMeaning();
-            displayParts.push(keywordPart(110 /* ThisKeyword */));
-          } else {
-            addPrefixForAnyFunctionOrVar(symbol, symbolKind);
-          }
-          if (symbolKind === "property" /* memberVariableElement */ || symbolKind === "accessor" /* memberAccessorVariableElement */ || symbolKind === "getter" /* memberGetAccessorElement */ || symbolKind === "setter" /* memberSetAccessorElement */ || symbolKind === "JSX attribute" /* jsxAttribute */ || symbolFlags & 3 /* Variable */ || symbolKind === "local var" /* localVariableElement */ || symbolKind === "index" /* indexSignatureElement */ || isThisExpression) {
-            displayParts.push(punctuationPart(59 /* ColonToken */));
-            displayParts.push(spacePart());
-            if (type.symbol && type.symbol.flags & 262144 /* TypeParameter */ && symbolKind !== "index" /* indexSignatureElement */) {
-              const typeParameterParts = mapToDisplayParts((writer) => {
-                const param = typeChecker.typeParameterToDeclaration(type, enclosingDeclaration, symbolDisplayNodeBuilderFlags);
-                getPrinter().writeNode(4 /* Unspecified */, param, getSourceFileOfNode(getParseTreeNode(enclosingDeclaration)), writer);
-              });
-              addRange(displayParts, typeParameterParts);
-            } else {
-              addRange(displayParts, typeToDisplayParts(typeChecker, type, enclosingDeclaration));
-            }
-            if (isTransientSymbol(symbol) && symbol.links.target && isTransientSymbol(symbol.links.target) && symbol.links.target.links.tupleLabelDeclaration) {
-              const labelDecl = symbol.links.target.links.tupleLabelDeclaration;
-              Debug.assertNode(labelDecl.name, isIdentifier);
-              displayParts.push(spacePart());
-              displayParts.push(punctuationPart(21 /* OpenParenToken */));
-              displayParts.push(textPart(idText(labelDecl.name)));
-              displayParts.push(punctuationPart(22 /* CloseParenToken */));
-            }
-          } else if (symbolFlags & 16 /* Function */ || symbolFlags & 8192 /* Method */ || symbolFlags & 16384 /* Constructor */ || symbolFlags & 131072 /* Signature */ || symbolFlags & 98304 /* Accessor */ || symbolKind === "method" /* memberFunctionElement */) {
-            const allSignatures = type.getNonNullableType().getCallSignatures();
-            if (allSignatures.length) {
-              addSignatureDisplayParts(allSignatures[0], allSignatures);
-              hasMultipleSignatures = allSignatures.length > 1;
-            }
-          }
-        }
-      } else {
-        symbolKind = getSymbolKind(typeChecker, symbol, location);
-      }
-    }
-    if (documentation.length === 0 && !hasMultipleSignatures) {
-      documentation = symbol.getContextualDocumentationComment(enclosingDeclaration, typeChecker);
-    }
-    if (documentation.length === 0 && symbolFlags & 4 /* Property */) {
-      if (symbol.parent && symbol.declarations && forEach(symbol.parent.declarations, (declaration) => declaration.kind === 311 /* SourceFile */)) {
-        for (const declaration of symbol.declarations) {
-          if (!declaration.parent || declaration.parent.kind !== 225 /* BinaryExpression */) {
-            continue;
-          }
-          const rhsSymbol = typeChecker.getSymbolAtLocation(declaration.parent.right);
-          if (!rhsSymbol) {
-            continue;
-          }
-          documentation = rhsSymbol.getDocumentationComment(typeChecker);
-          tags = rhsSymbol.getJsDocTags(typeChecker);
-          if (documentation.length > 0) {
-            break;
-          }
-        }
-      }
-    }
-    if (documentation.length === 0 && isIdentifier(location) && symbol.valueDeclaration && isBindingElement(symbol.valueDeclaration)) {
-      const declaration = symbol.valueDeclaration;
-      const parent2 = declaration.parent;
-      if (isIdentifier(declaration.name) && isObjectBindingPattern(parent2)) {
-        const name = getTextOfIdentifierOrLiteral(declaration.name);
-        const objectType = typeChecker.getTypeAtLocation(parent2);
-        documentation = firstDefined(objectType.isUnion() ? objectType.types : [objectType], (t) => {
-          const prop = t.getProperty(name);
-          return prop ? prop.getDocumentationComment(typeChecker) : void 0;
-        }) || emptyArray;
-      }
-    }
-    if (tags.length === 0 && !hasMultipleSignatures) {
-      tags = symbol.getContextualJsDocTags(enclosingDeclaration, typeChecker);
-    }
-    if (documentation.length === 0 && documentationFromAlias) {
-      documentation = documentationFromAlias;
-    }
-    if (tags.length === 0 && tagsFromAlias) {
-      tags = tagsFromAlias;
-    }
-    return { displayParts, documentation, symbolKind, tags: tags.length === 0 ? void 0 : tags };
-    function getPrinter() {
-      return createPrinterWithRemoveComments();
-    }
-    function prefixNextMeaning() {
-      if (displayParts.length) {
-        displayParts.push(lineBreakPart());
-      }
-      addAliasPrefixIfNecessary();
-    }
-    function addAliasPrefixIfNecessary() {
-      if (alias) {
-        pushSymbolKind("alias" /* alias */);
-        displayParts.push(spacePart());
-      }
-    }
-    function addInPrefix() {
-      displayParts.push(spacePart());
-      displayParts.push(keywordPart(103 /* InKeyword */));
-      displayParts.push(spacePart());
-    }
-    function addFullSymbolName(symbolToDisplay, enclosingDeclaration2) {
-      let indexInfos;
-      if (alias && symbolToDisplay === symbol) {
-        symbolToDisplay = alias;
-      }
-      if (symbolKind === "index" /* indexSignatureElement */) {
-        indexInfos = typeChecker.getIndexInfosOfIndexSymbol(symbolToDisplay);
-      }
-      let fullSymbolDisplayParts = [];
-      if (symbolToDisplay.flags & 131072 /* Signature */ && indexInfos) {
-        if (symbolToDisplay.parent) {
-          fullSymbolDisplayParts = symbolToDisplayParts(typeChecker, symbolToDisplay.parent);
-        }
-        fullSymbolDisplayParts.push(punctuationPart(23 /* OpenBracketToken */));
-        indexInfos.forEach((info, i) => {
-          fullSymbolDisplayParts.push(...typeToDisplayParts(typeChecker, info.keyType));
-          if (i !== indexInfos.length - 1) {
-            fullSymbolDisplayParts.push(spacePart());
-            fullSymbolDisplayParts.push(punctuationPart(52 /* BarToken */));
-            fullSymbolDisplayParts.push(spacePart());
-          }
-        });
-        fullSymbolDisplayParts.push(punctuationPart(24 /* CloseBracketToken */));
-      } else {
-        fullSymbolDisplayParts = symbolToDisplayParts(
-          typeChecker,
-          symbolToDisplay,
-          enclosingDeclaration2 || sourceFile,
-          /*meaning*/
-          void 0,
-          1 /* WriteTypeParametersOrArguments */ | 2 /* UseOnlyExternalAliasing */ | 4 /* AllowAnyNodeKind */
-        );
-      }
-      addRange(displayParts, fullSymbolDisplayParts);
-      if (symbol.flags & 16777216 /* Optional */) {
-        displayParts.push(punctuationPart(58 /* QuestionToken */));
-      }
-    }
-    function addPrefixForAnyFunctionOrVar(symbol2, symbolKind2) {
-      prefixNextMeaning();
-      if (symbolKind2) {
-        pushSymbolKind(symbolKind2);
-        if (symbol2 && !some(symbol2.declarations, (d) => isArrowFunction(d) || (isFunctionExpression(d) || isClassExpression(d)) && !d.name)) {
-          displayParts.push(spacePart());
-          addFullSymbolName(symbol2);
-        }
-      }
-    }
-    function pushSymbolKind(symbolKind2) {
-      switch (symbolKind2) {
-        case "var" /* variableElement */:
-        case "function" /* functionElement */:
-        case "let" /* letElement */:
-        case "const" /* constElement */:
-        case "constructor" /* constructorImplementationElement */:
-          displayParts.push(textOrKeywordPart(symbolKind2));
-          return;
-        default:
-          displayParts.push(punctuationPart(21 /* OpenParenToken */));
-          displayParts.push(textOrKeywordPart(symbolKind2));
-          displayParts.push(punctuationPart(22 /* CloseParenToken */));
-          return;
-      }
-    }
-    function addSignatureDisplayParts(signature, allSignatures, flags = 0 /* None */) {
-      addRange(displayParts, signatureToDisplayParts(typeChecker, signature, enclosingDeclaration, flags | 32 /* WriteTypeArgumentsOfSignature */));
-      if (allSignatures.length > 1) {
-        displayParts.push(spacePart());
-        displayParts.push(punctuationPart(21 /* OpenParenToken */));
-        displayParts.push(operatorPart(40 /* PlusToken */));
-        displayParts.push(displayPart((allSignatures.length - 1).toString(), 7 /* numericLiteral */));
-        displayParts.push(spacePart());
-        displayParts.push(textPart(allSignatures.length === 2 ? "overload" : "overloads"));
-        displayParts.push(punctuationPart(22 /* CloseParenToken */));
-      }
-      documentation = signature.getDocumentationComment(typeChecker);
-      tags = signature.getJsDocTags();
-      if (allSignatures.length > 1 && documentation.length === 0 && tags.length === 0) {
-        documentation = allSignatures[0].getDocumentationComment(typeChecker);
-        tags = allSignatures[0].getJsDocTags().filter((tag) => tag.name !== "deprecated");
-      }
-    }
-    function writeTypeParametersOfSymbol(symbol2, enclosingDeclaration2) {
-      const typeParameterParts = mapToDisplayParts((writer) => {
-        const params = typeChecker.symbolToTypeParameterDeclarations(symbol2, enclosingDeclaration2, symbolDisplayNodeBuilderFlags);
-        getPrinter().writeList(53776 /* TypeParameters */, params, getSourceFileOfNode(getParseTreeNode(enclosingDeclaration2)), writer);
-      });
-      addRange(displayParts, typeParameterParts);
-    }
-  }
-  function isLocalVariableOrFunction(symbol) {
-    if (symbol.parent) {
-      return false;
-    }
-    return forEach(symbol.declarations, (declaration) => {
-      if (declaration.kind === 217 /* FunctionExpression */) {
-        return true;
-      }
-      if (declaration.kind !== 259 /* VariableDeclaration */ && declaration.kind !== 261 /* FunctionDeclaration */) {
-        return false;
-      }
-      for (let parent2 = declaration.parent; !isFunctionBlock(parent2); parent2 = parent2.parent) {
-        if (parent2.kind === 311 /* SourceFile */ || parent2.kind === 267 /* ModuleBlock */) {
-          return false;
-        }
-      }
-      return true;
-    });
-  }
-  var symbolDisplayNodeBuilderFlags;
-  var init_symbolDisplay = __esm({
-    "src/services/symbolDisplay.ts"() {
-      "use strict";
-      init_ts4();
-      symbolDisplayNodeBuilderFlags = 8192 /* OmitParameterModifiers */ | 70221824 /* IgnoreErrors */ | 16384 /* UseAliasDefinedOutsideCurrentScope */;
-    }
-  });
-
-  // src/services/_namespaces/ts.SymbolDisplay.ts
-  var ts_SymbolDisplay_exports = {};
-  __export(ts_SymbolDisplay_exports, {
-    getSymbolDisplayPartsDocumentationAndSymbolKind: () => getSymbolDisplayPartsDocumentationAndSymbolKind,
-    getSymbolKind: () => getSymbolKind,
-    getSymbolModifiers: () => getSymbolModifiers
-  });
-  var init_ts_SymbolDisplay = __esm({
-    "src/services/_namespaces/ts.SymbolDisplay.ts"() {
-      "use strict";
-      init_symbolDisplay();
-    }
-  });
-
-  // src/services/textChanges.ts
-  function getPos2(n) {
-    const result = n.__pos;
-    Debug.assert(typeof result === "number");
-    return result;
-  }
-  function setPos(n, pos) {
-    Debug.assert(typeof pos === "number");
-    n.__pos = pos;
-  }
-  function getEnd(n) {
-    const result = n.__end;
-    Debug.assert(typeof result === "number");
-    return result;
-  }
-  function setEnd(n, end) {
-    Debug.assert(typeof end === "number");
-    n.__end = end;
-  }
-  function skipWhitespacesAndLineBreaks(text, start) {
-    return skipTrivia(
-      text,
-      start,
-      /*stopAfterLineBreak*/
-      false,
-      /*stopAtComments*/
-      true
-    );
-  }
-  function hasCommentsBeforeLineBreak(text, start) {
-    let i = start;
-    while (i < text.length) {
-      const ch = text.charCodeAt(i);
-      if (isWhiteSpaceSingleLine(ch)) {
-        i++;
-        continue;
-      }
-      return ch === 47 /* slash */;
-    }
-    return false;
-  }
-  function getAdjustedRange(sourceFile, startNode2, endNode2, options) {
-    return { pos: getAdjustedStartPosition(sourceFile, startNode2, options), end: getAdjustedEndPosition(sourceFile, endNode2, options) };
-  }
-  function getAdjustedStartPosition(sourceFile, node, options, hasTrailingComment = false) {
-    var _a, _b;
-    const { leadingTriviaOption } = options;
-    if (leadingTriviaOption === 0 /* Exclude */) {
-      return node.getStart(sourceFile);
-    }
-    if (leadingTriviaOption === 3 /* StartLine */) {
-      const startPos = node.getStart(sourceFile);
-      const pos = getLineStartPositionForPosition(startPos, sourceFile);
-      return rangeContainsPosition(node, pos) ? pos : startPos;
-    }
-    if (leadingTriviaOption === 2 /* JSDoc */) {
-      const JSDocComments = getJSDocCommentRanges(node, sourceFile.text);
-      if (JSDocComments == null ? void 0 : JSDocComments.length) {
-        return getLineStartPositionForPosition(JSDocComments[0].pos, sourceFile);
-      }
-    }
-    const fullStart = node.getFullStart();
-    const start = node.getStart(sourceFile);
-    if (fullStart === start) {
-      return start;
-    }
-    const fullStartLine = getLineStartPositionForPosition(fullStart, sourceFile);
-    const startLine = getLineStartPositionForPosition(start, sourceFile);
-    if (startLine === fullStartLine) {
-      return leadingTriviaOption === 1 /* IncludeAll */ ? fullStart : start;
-    }
-    if (hasTrailingComment) {
-      const comment = ((_a = getLeadingCommentRanges(sourceFile.text, fullStart)) == null ? void 0 : _a[0]) || ((_b = getTrailingCommentRanges(sourceFile.text, fullStart)) == null ? void 0 : _b[0]);
-      if (comment) {
-        return skipTrivia(
-          sourceFile.text,
-          comment.end,
-          /*stopAfterLineBreak*/
-          true,
-          /*stopAtComments*/
-          true
-        );
-      }
-    }
-    const nextLineStart = fullStart > 0 ? 1 : 0;
-    let adjustedStartPosition = getStartPositionOfLine(getLineOfLocalPosition(sourceFile, fullStartLine) + nextLineStart, sourceFile);
-    adjustedStartPosition = skipWhitespacesAndLineBreaks(sourceFile.text, adjustedStartPosition);
-    return getStartPositionOfLine(getLineOfLocalPosition(sourceFile, adjustedStartPosition), sourceFile);
-  }
-  function getEndPositionOfMultilineTrailingComment(sourceFile, node, options) {
-    const { end } = node;
-    const { trailingTriviaOption } = options;
-    if (trailingTriviaOption === 2 /* Include */) {
-      const comments = getTrailingCommentRanges(sourceFile.text, end);
-      if (comments) {
-        const nodeEndLine = getLineOfLocalPosition(sourceFile, node.end);
-        for (const comment of comments) {
-          if (comment.kind === 2 /* SingleLineCommentTrivia */ || getLineOfLocalPosition(sourceFile, comment.pos) > nodeEndLine) {
-            break;
-          }
-          const commentEndLine = getLineOfLocalPosition(sourceFile, comment.end);
-          if (commentEndLine > nodeEndLine) {
-            return skipTrivia(
-              sourceFile.text,
-              comment.end,
-              /*stopAfterLineBreak*/
-              true,
-              /*stopAtComments*/
-              true
-            );
-          }
-        }
-      }
-    }
-    return void 0;
-  }
-  function getAdjustedEndPosition(sourceFile, node, options) {
-    var _a;
-    const { end } = node;
-    const { trailingTriviaOption } = options;
-    if (trailingTriviaOption === 0 /* Exclude */) {
-      return end;
-    }
-    if (trailingTriviaOption === 1 /* ExcludeWhitespace */) {
-      const comments = concatenate(getTrailingCommentRanges(sourceFile.text, end), getLeadingCommentRanges(sourceFile.text, end));
-      const realEnd = (_a = comments == null ? void 0 : comments[comments.length - 1]) == null ? void 0 : _a.end;
-      if (realEnd) {
-        return realEnd;
-      }
-      return end;
-    }
-    const multilineEndPosition = getEndPositionOfMultilineTrailingComment(sourceFile, node, options);
-    if (multilineEndPosition) {
-      return multilineEndPosition;
-    }
-    const newEnd = skipTrivia(
-      sourceFile.text,
-      end,
-      /*stopAfterLineBreak*/
-      true
-    );
-    return newEnd !== end && (trailingTriviaOption === 2 /* Include */ || isLineBreak(sourceFile.text.charCodeAt(newEnd - 1))) ? newEnd : end;
-  }
-  function isSeparator(node, candidate) {
-    return !!candidate && !!node.parent && (candidate.kind === 28 /* CommaToken */ || candidate.kind === 27 /* SemicolonToken */ && node.parent.kind === 209 /* ObjectLiteralExpression */);
-  }
-  function isThisTypeAnnotatable(containingFunction) {
-    return isFunctionExpression(containingFunction) || isFunctionDeclaration(containingFunction);
-  }
-  function updateJSDocHost(parent2) {
-    if (parent2.kind !== 218 /* ArrowFunction */) {
-      return parent2;
-    }
-    const jsDocNode = parent2.parent.kind === 171 /* PropertyDeclaration */ ? parent2.parent : parent2.parent.parent;
-    jsDocNode.jsDoc = parent2.jsDoc;
-    return jsDocNode;
-  }
-  function tryMergeJsdocTags(oldTag, newTag) {
-    if (oldTag.kind !== newTag.kind) {
-      return void 0;
-    }
-    switch (oldTag.kind) {
-      case 347 /* JSDocParameterTag */: {
-        const oldParam = oldTag;
-        const newParam = newTag;
-        return isIdentifier(oldParam.name) && isIdentifier(newParam.name) && oldParam.name.escapedText === newParam.name.escapedText ? factory.createJSDocParameterTag(
-          /*tagName*/
-          void 0,
-          newParam.name,
-          /*isBracketed*/
-          false,
-          newParam.typeExpression,
-          newParam.isNameFirst,
-          oldParam.comment
-        ) : void 0;
-      }
-      case 348 /* JSDocReturnTag */:
-        return factory.createJSDocReturnTag(
-          /*tagName*/
-          void 0,
-          newTag.typeExpression,
-          oldTag.comment
-        );
-      case 350 /* JSDocTypeTag */:
-        return factory.createJSDocTypeTag(
-          /*tagName*/
-          void 0,
-          newTag.typeExpression,
-          oldTag.comment
-        );
-    }
-  }
-  function startPositionToDeleteNodeInList(sourceFile, node) {
-    return skipTrivia(
-      sourceFile.text,
-      getAdjustedStartPosition(sourceFile, node, { leadingTriviaOption: 1 /* IncludeAll */ }),
-      /*stopAfterLineBreak*/
-      false,
-      /*stopAtComments*/
-      true
-    );
-  }
-  function endPositionToDeleteNodeInList(sourceFile, node, prevNode, nextNode) {
-    const end = startPositionToDeleteNodeInList(sourceFile, nextNode);
-    if (prevNode === void 0 || positionsAreOnSameLine(getAdjustedEndPosition(sourceFile, node, {}), end, sourceFile)) {
-      return end;
-    }
-    const token = findPrecedingToken(nextNode.getStart(sourceFile), sourceFile);
-    if (isSeparator(node, token)) {
-      const prevToken = findPrecedingToken(node.getStart(sourceFile), sourceFile);
-      if (isSeparator(prevNode, prevToken)) {
-        const pos = skipTrivia(
-          sourceFile.text,
-          token.getEnd(),
-          /*stopAfterLineBreak*/
-          true,
-          /*stopAtComments*/
-          true
-        );
-        if (positionsAreOnSameLine(prevToken.getStart(sourceFile), token.getStart(sourceFile), sourceFile)) {
-          return isLineBreak(sourceFile.text.charCodeAt(pos - 1)) ? pos - 1 : pos;
-        }
-        if (isLineBreak(sourceFile.text.charCodeAt(pos))) {
-          return pos;
-        }
-      }
-    }
-    return end;
-  }
-  function getClassOrObjectBraceEnds(cls, sourceFile) {
-    const open = findChildOfKind(cls, 19 /* OpenBraceToken */, sourceFile);
-    const close = findChildOfKind(cls, 20 /* CloseBraceToken */, sourceFile);
-    return [open == null ? void 0 : open.end, close == null ? void 0 : close.end];
-  }
-  function getMembersOrProperties(node) {
-    return isObjectLiteralExpression(node) ? node.properties : node.members;
-  }
-  function applyChanges(text, changes) {
-    for (let i = changes.length - 1; i >= 0; i--) {
-      const { span, newText } = changes[i];
-      text = `${text.substring(0, span.start)}${newText}${text.substring(textSpanEnd(span))}`;
-    }
-    return text;
-  }
-  function isTrivia2(s) {
-    return skipTrivia(s, 0) === s.length;
-  }
-  function assignPositionsToNode(node) {
-    const visited = visitEachChild(node, assignPositionsToNode, textChangesTransformationContext, assignPositionsToNodeArray, assignPositionsToNode);
-    const newNode = nodeIsSynthesized(visited) ? visited : Object.create(visited);
-    setTextRangePosEnd(newNode, getPos2(node), getEnd(node));
-    return newNode;
-  }
-  function assignPositionsToNodeArray(nodes, visitor, test, start, count) {
-    const visited = visitNodes2(nodes, visitor, test, start, count);
-    if (!visited) {
-      return visited;
-    }
-    Debug.assert(nodes);
-    const nodeArray = visited === nodes ? factory.createNodeArray(visited.slice(0)) : visited;
-    setTextRangePosEnd(nodeArray, getPos2(nodes), getEnd(nodes));
-    return nodeArray;
-  }
-  function createWriter(newLine) {
-    let lastNonTriviaPosition = 0;
-    const writer = createTextWriter(newLine);
-    const onBeforeEmitNode = (node) => {
-      if (node) {
-        setPos(node, lastNonTriviaPosition);
-      }
-    };
-    const onAfterEmitNode = (node) => {
-      if (node) {
-        setEnd(node, lastNonTriviaPosition);
-      }
-    };
-    const onBeforeEmitNodeArray = (nodes) => {
-      if (nodes) {
-        setPos(nodes, lastNonTriviaPosition);
-      }
-    };
-    const onAfterEmitNodeArray = (nodes) => {
-      if (nodes) {
-        setEnd(nodes, lastNonTriviaPosition);
-      }
-    };
-    const onBeforeEmitToken = (node) => {
-      if (node) {
-        setPos(node, lastNonTriviaPosition);
-      }
-    };
-    const onAfterEmitToken = (node) => {
-      if (node) {
-        setEnd(node, lastNonTriviaPosition);
-      }
-    };
-    function setLastNonTriviaPosition(s, force) {
-      if (force || !isTrivia2(s)) {
-        lastNonTriviaPosition = writer.getTextPos();
-        let i = 0;
-        while (isWhiteSpaceLike(s.charCodeAt(s.length - i - 1))) {
-          i++;
-        }
-        lastNonTriviaPosition -= i;
-      }
-    }
-    function write(s) {
-      writer.write(s);
-      setLastNonTriviaPosition(
-        s,
-        /*force*/
-        false
-      );
-    }
-    function writeComment(s) {
-      writer.writeComment(s);
-    }
-    function writeKeyword(s) {
-      writer.writeKeyword(s);
-      setLastNonTriviaPosition(
-        s,
-        /*force*/
-        false
-      );
-    }
-    function writeOperator(s) {
-      writer.writeOperator(s);
-      setLastNonTriviaPosition(
-        s,
-        /*force*/
-        false
-      );
-    }
-    function writePunctuation(s) {
-      writer.writePunctuation(s);
-      setLastNonTriviaPosition(
-        s,
-        /*force*/
-        false
-      );
-    }
-    function writeTrailingSemicolon(s) {
-      writer.writeTrailingSemicolon(s);
-      setLastNonTriviaPosition(
-        s,
-        /*force*/
-        false
-      );
-    }
-    function writeParameter(s) {
-      writer.writeParameter(s);
-      setLastNonTriviaPosition(
-        s,
-        /*force*/
-        false
-      );
-    }
-    function writeProperty(s) {
-      writer.writeProperty(s);
-      setLastNonTriviaPosition(
-        s,
-        /*force*/
-        false
-      );
-    }
-    function writeSpace(s) {
-      writer.writeSpace(s);
-      setLastNonTriviaPosition(
-        s,
-        /*force*/
-        false
-      );
-    }
-    function writeStringLiteral(s) {
-      writer.writeStringLiteral(s);
-      setLastNonTriviaPosition(
-        s,
-        /*force*/
-        false
-      );
-    }
-    function writeSymbol(s, sym) {
-      writer.writeSymbol(s, sym);
-      setLastNonTriviaPosition(
-        s,
-        /*force*/
-        false
-      );
-    }
-    function writeLine(force) {
-      writer.writeLine(force);
-    }
-    function increaseIndent() {
-      writer.increaseIndent();
-    }
-    function decreaseIndent() {
-      writer.decreaseIndent();
-    }
-    function getText() {
-      return writer.getText();
-    }
-    function rawWrite(s) {
-      writer.rawWrite(s);
-      setLastNonTriviaPosition(
-        s,
-        /*force*/
-        false
-      );
-    }
-    function writeLiteral(s) {
-      writer.writeLiteral(s);
-      setLastNonTriviaPosition(
-        s,
-        /*force*/
-        true
-      );
-    }
-    function getTextPos() {
-      return writer.getTextPos();
-    }
-    function getLine() {
-      return writer.getLine();
-    }
-    function getColumn() {
-      return writer.getColumn();
-    }
-    function getIndent() {
-      return writer.getIndent();
-    }
-    function isAtStartOfLine() {
-      return writer.isAtStartOfLine();
-    }
-    function clear2() {
-      writer.clear();
-      lastNonTriviaPosition = 0;
-    }
-    return {
-      onBeforeEmitNode,
-      onAfterEmitNode,
-      onBeforeEmitNodeArray,
-      onAfterEmitNodeArray,
-      onBeforeEmitToken,
-      onAfterEmitToken,
-      write,
-      writeComment,
-      writeKeyword,
-      writeOperator,
-      writePunctuation,
-      writeTrailingSemicolon,
-      writeParameter,
-      writeProperty,
-      writeSpace,
-      writeStringLiteral,
-      writeSymbol,
-      writeLine,
-      increaseIndent,
-      decreaseIndent,
-      getText,
-      rawWrite,
-      writeLiteral,
-      getTextPos,
-      getLine,
-      getColumn,
-      getIndent,
-      isAtStartOfLine,
-      hasTrailingComment: () => writer.hasTrailingComment(),
-      hasTrailingWhitespace: () => writer.hasTrailingWhitespace(),
-      clear: clear2
-    };
-  }
-  function getInsertionPositionAtSourceFileTop(sourceFile) {
-    let lastPrologue;
-    for (const node of sourceFile.statements) {
-      if (isPrologueDirective(node)) {
-        lastPrologue = node;
-      } else {
-        break;
-      }
-    }
-    let position = 0;
-    const text = sourceFile.text;
-    if (lastPrologue) {
-      position = lastPrologue.end;
-      advancePastLineBreak();
-      return position;
-    }
-    const shebang = getShebang(text);
-    if (shebang !== void 0) {
-      position = shebang.length;
-      advancePastLineBreak();
-    }
-    const ranges = getLeadingCommentRanges(text, position);
-    if (!ranges)
-      return position;
-    let lastComment;
-    let firstNodeLine;
-    for (const range of ranges) {
-      if (range.kind === 3 /* MultiLineCommentTrivia */) {
-        if (isPinnedComment(text, range.pos)) {
-          lastComment = { range, pinnedOrTripleSlash: true };
-          continue;
-        }
-      } else if (isRecognizedTripleSlashComment(text, range.pos, range.end)) {
-        lastComment = { range, pinnedOrTripleSlash: true };
-        continue;
-      }
-      if (lastComment) {
-        if (lastComment.pinnedOrTripleSlash)
-          break;
-        const commentLine = sourceFile.getLineAndCharacterOfPosition(range.pos).line;
-        const lastCommentEndLine = sourceFile.getLineAndCharacterOfPosition(lastComment.range.end).line;
-        if (commentLine >= lastCommentEndLine + 2)
-          break;
-      }
-      if (sourceFile.statements.length) {
-        if (firstNodeLine === void 0)
-          firstNodeLine = sourceFile.getLineAndCharacterOfPosition(sourceFile.statements[0].getStart()).line;
-        const commentEndLine = sourceFile.getLineAndCharacterOfPosition(range.end).line;
-        if (firstNodeLine < commentEndLine + 2)
-          break;
-      }
-      lastComment = { range, pinnedOrTripleSlash: false };
-    }
-    if (lastComment) {
-      position = lastComment.range.end;
-      advancePastLineBreak();
-    }
-    return position;
-    function advancePastLineBreak() {
-      if (position < text.length) {
-        const charCode = text.charCodeAt(position);
-        if (isLineBreak(charCode)) {
-          position++;
-          if (position < text.length && charCode === 13 /* carriageReturn */ && text.charCodeAt(position) === 10 /* lineFeed */) {
-            position++;
-          }
-        }
-      }
-    }
-  }
-  function isValidLocationToAddComment(sourceFile, position) {
-    return !isInComment(sourceFile, position) && !isInString(sourceFile, position) && !isInTemplateString(sourceFile, position) && !isInJSXText(sourceFile, position);
-  }
-  function needSemicolonBetween(a, b) {
-    return (isPropertySignature(a) || isPropertyDeclaration(a)) && isClassOrTypeElement(b) && b.name.kind === 166 /* ComputedPropertyName */ || isStatementButNotDeclaration(a) && isStatementButNotDeclaration(b);
-  }
-  function deleteNode(changes, sourceFile, node, options = { leadingTriviaOption: 1 /* IncludeAll */ }) {
-    const startPosition = getAdjustedStartPosition(sourceFile, node, options);
-    const endPosition = getAdjustedEndPosition(sourceFile, node, options);
-    changes.deleteRange(sourceFile, { pos: startPosition, end: endPosition });
-  }
-  function deleteNodeInList(changes, deletedNodesInLists, sourceFile, node) {
-    const containingList = Debug.checkDefined(ts_formatting_exports.SmartIndenter.getContainingList(node, sourceFile));
-    const index = indexOfNode(containingList, node);
-    Debug.assert(index !== -1);
-    if (containingList.length === 1) {
-      deleteNode(changes, sourceFile, node);
-      return;
-    }
-    Debug.assert(!deletedNodesInLists.has(node), "Deleting a node twice");
-    deletedNodesInLists.add(node);
-    changes.deleteRange(sourceFile, {
-      pos: startPositionToDeleteNodeInList(sourceFile, node),
-      end: index === containingList.length - 1 ? getAdjustedEndPosition(sourceFile, node, {}) : endPositionToDeleteNodeInList(sourceFile, node, containingList[index - 1], containingList[index + 1])
-    });
-  }
-  var LeadingTriviaOption, TrailingTriviaOption, useNonAdjustedPositions, ChangeTracker, changesToText, textChangesTransformationContext, deleteDeclaration;
-  var init_textChanges = __esm({
-    "src/services/textChanges.ts"() {
-      "use strict";
-      init_ts4();
-      LeadingTriviaOption = /* @__PURE__ */ ((LeadingTriviaOption2) => {
-        LeadingTriviaOption2[LeadingTriviaOption2["Exclude"] = 0] = "Exclude";
-        LeadingTriviaOption2[LeadingTriviaOption2["IncludeAll"] = 1] = "IncludeAll";
-        LeadingTriviaOption2[LeadingTriviaOption2["JSDoc"] = 2] = "JSDoc";
-        LeadingTriviaOption2[LeadingTriviaOption2["StartLine"] = 3] = "StartLine";
-        return LeadingTriviaOption2;
-      })(LeadingTriviaOption || {});
-      TrailingTriviaOption = /* @__PURE__ */ ((TrailingTriviaOption2) => {
-        TrailingTriviaOption2[TrailingTriviaOption2["Exclude"] = 0] = "Exclude";
-        TrailingTriviaOption2[TrailingTriviaOption2["ExcludeWhitespace"] = 1] = "ExcludeWhitespace";
-        TrailingTriviaOption2[TrailingTriviaOption2["Include"] = 2] = "Include";
-        return TrailingTriviaOption2;
-      })(TrailingTriviaOption || {});
-      useNonAdjustedPositions = {
-        leadingTriviaOption: 0 /* Exclude */,
-        trailingTriviaOption: 0 /* Exclude */
-      };
-      ChangeTracker = class {
-        /** Public for tests only. Other callers should use `ChangeTracker.with`. */
-        constructor(newLineCharacter, formatContext) {
-          this.newLineCharacter = newLineCharacter;
-          this.formatContext = formatContext;
-          this.changes = [];
-          this.classesWithNodesInsertedAtStart = /* @__PURE__ */ new Map();
-          // Set implemented as Map
-          this.deletedNodes = [];
-        }
-        static fromContext(context) {
-          return new ChangeTracker(getNewLineOrDefaultFromHost(context.host, context.formatContext.options), context.formatContext);
-        }
-        static with(context, cb) {
-          const tracker = ChangeTracker.fromContext(context);
-          cb(tracker);
-          return tracker.getChanges();
-        }
-        pushRaw(sourceFile, change) {
-          Debug.assertEqual(sourceFile.fileName, change.fileName);
-          for (const c of change.textChanges) {
-            this.changes.push({
-              kind: 3 /* Text */,
-              sourceFile,
-              text: c.newText,
-              range: createTextRangeFromSpan(c.span)
-            });
-          }
-        }
-        deleteRange(sourceFile, range) {
-          this.changes.push({ kind: 0 /* Remove */, sourceFile, range });
-        }
-        delete(sourceFile, node) {
-          this.deletedNodes.push({ sourceFile, node });
-        }
-        /** Stop! Consider using `delete` instead, which has logic for deleting nodes from delimited lists. */
-        deleteNode(sourceFile, node, options = { leadingTriviaOption: 1 /* IncludeAll */ }) {
-          this.deleteRange(sourceFile, getAdjustedRange(sourceFile, node, node, options));
-        }
-        deleteNodes(sourceFile, nodes, options = { leadingTriviaOption: 1 /* IncludeAll */ }, hasTrailingComment) {
-          for (const node of nodes) {
-            const pos = getAdjustedStartPosition(sourceFile, node, options, hasTrailingComment);
-            const end = getAdjustedEndPosition(sourceFile, node, options);
-            this.deleteRange(sourceFile, { pos, end });
-            hasTrailingComment = !!getEndPositionOfMultilineTrailingComment(sourceFile, node, options);
-          }
-        }
-        deleteModifier(sourceFile, modifier) {
-          this.deleteRange(sourceFile, { pos: modifier.getStart(sourceFile), end: skipTrivia(
-            sourceFile.text,
-            modifier.end,
-            /*stopAfterLineBreak*/
-            true
-          ) });
-        }
-        deleteNodeRange(sourceFile, startNode2, endNode2, options = { leadingTriviaOption: 1 /* IncludeAll */ }) {
-          const startPosition = getAdjustedStartPosition(sourceFile, startNode2, options);
-          const endPosition = getAdjustedEndPosition(sourceFile, endNode2, options);
-          this.deleteRange(sourceFile, { pos: startPosition, end: endPosition });
-        }
-        deleteNodeRangeExcludingEnd(sourceFile, startNode2, afterEndNode, options = { leadingTriviaOption: 1 /* IncludeAll */ }) {
-          const startPosition = getAdjustedStartPosition(sourceFile, startNode2, options);
-          const endPosition = afterEndNode === void 0 ? sourceFile.text.length : getAdjustedStartPosition(sourceFile, afterEndNode, options);
-          this.deleteRange(sourceFile, { pos: startPosition, end: endPosition });
-        }
-        replaceRange(sourceFile, range, newNode, options = {}) {
-          this.changes.push({ kind: 1 /* ReplaceWithSingleNode */, sourceFile, range, options, node: newNode });
-        }
-        replaceNode(sourceFile, oldNode, newNode, options = useNonAdjustedPositions) {
-          this.replaceRange(sourceFile, getAdjustedRange(sourceFile, oldNode, oldNode, options), newNode, options);
-        }
-        replaceNodeRange(sourceFile, startNode2, endNode2, newNode, options = useNonAdjustedPositions) {
-          this.replaceRange(sourceFile, getAdjustedRange(sourceFile, startNode2, endNode2, options), newNode, options);
-        }
-        replaceRangeWithNodes(sourceFile, range, newNodes, options = {}) {
-          this.changes.push({ kind: 2 /* ReplaceWithMultipleNodes */, sourceFile, range, options, nodes: newNodes });
-        }
-        replaceNodeWithNodes(sourceFile, oldNode, newNodes, options = useNonAdjustedPositions) {
-          this.replaceRangeWithNodes(sourceFile, getAdjustedRange(sourceFile, oldNode, oldNode, options), newNodes, options);
-        }
-        replaceNodeWithText(sourceFile, oldNode, text) {
-          this.replaceRangeWithText(sourceFile, getAdjustedRange(sourceFile, oldNode, oldNode, useNonAdjustedPositions), text);
-        }
-        replaceNodeRangeWithNodes(sourceFile, startNode2, endNode2, newNodes, options = useNonAdjustedPositions) {
-          this.replaceRangeWithNodes(sourceFile, getAdjustedRange(sourceFile, startNode2, endNode2, options), newNodes, options);
-        }
-        nodeHasTrailingComment(sourceFile, oldNode, configurableEnd = useNonAdjustedPositions) {
-          return !!getEndPositionOfMultilineTrailingComment(sourceFile, oldNode, configurableEnd);
-        }
-        nextCommaToken(sourceFile, node) {
-          const next = findNextToken(node, node.parent, sourceFile);
-          return next && next.kind === 28 /* CommaToken */ ? next : void 0;
-        }
-        replacePropertyAssignment(sourceFile, oldNode, newNode) {
-          const suffix = this.nextCommaToken(sourceFile, oldNode) ? "" : "," + this.newLineCharacter;
-          this.replaceNode(sourceFile, oldNode, newNode, { suffix });
-        }
-        insertNodeAt(sourceFile, pos, newNode, options = {}) {
-          this.replaceRange(sourceFile, createRange(pos), newNode, options);
-        }
-        insertNodesAt(sourceFile, pos, newNodes, options = {}) {
-          this.replaceRangeWithNodes(sourceFile, createRange(pos), newNodes, options);
-        }
-        insertNodeAtTopOfFile(sourceFile, newNode, blankLineBetween) {
-          this.insertAtTopOfFile(sourceFile, newNode, blankLineBetween);
-        }
-        insertNodesAtTopOfFile(sourceFile, newNodes, blankLineBetween) {
-          this.insertAtTopOfFile(sourceFile, newNodes, blankLineBetween);
-        }
-        insertAtTopOfFile(sourceFile, insert, blankLineBetween) {
-          const pos = getInsertionPositionAtSourceFileTop(sourceFile);
-          const options = {
-            prefix: pos === 0 ? void 0 : this.newLineCharacter,
-            suffix: (isLineBreak(sourceFile.text.charCodeAt(pos)) ? "" : this.newLineCharacter) + (blankLineBetween ? this.newLineCharacter : "")
-          };
-          if (isArray(insert)) {
-            this.insertNodesAt(sourceFile, pos, insert, options);
-          } else {
-            this.insertNodeAt(sourceFile, pos, insert, options);
-          }
-        }
-        insertNodesAtEndOfFile(sourceFile, newNodes, blankLineBetween) {
-          this.insertAtEndOfFile(sourceFile, newNodes, blankLineBetween);
-        }
-        insertAtEndOfFile(sourceFile, insert, blankLineBetween) {
-          const pos = sourceFile.end + 1;
-          const options = {
-            prefix: this.newLineCharacter,
-            suffix: this.newLineCharacter + (blankLineBetween ? this.newLineCharacter : "")
-          };
-          this.insertNodesAt(sourceFile, pos, insert, options);
-        }
-        insertStatementsInNewFile(fileName, statements, oldFile) {
-          if (!this.newFileChanges) {
-            this.newFileChanges = createMultiMap();
-          }
-          this.newFileChanges.add(fileName, { oldFile, statements });
-        }
-        insertFirstParameter(sourceFile, parameters, newParam) {
-          const p0 = firstOrUndefined(parameters);
-          if (p0) {
-            this.insertNodeBefore(sourceFile, p0, newParam);
-          } else {
-            this.insertNodeAt(sourceFile, parameters.pos, newParam);
-          }
-        }
-        insertNodeBefore(sourceFile, before, newNode, blankLineBetween = false, options = {}) {
-          this.insertNodeAt(sourceFile, getAdjustedStartPosition(sourceFile, before, options), newNode, this.getOptionsForInsertNodeBefore(before, newNode, blankLineBetween));
-        }
-        insertModifierAt(sourceFile, pos, modifier, options = {}) {
-          this.insertNodeAt(sourceFile, pos, factory.createToken(modifier), options);
-        }
-        insertModifierBefore(sourceFile, modifier, before) {
-          return this.insertModifierAt(sourceFile, before.getStart(sourceFile), modifier, { suffix: " " });
-        }
-        insertCommentBeforeLine(sourceFile, lineNumber, position, commentText) {
-          const lineStartPosition = getStartPositionOfLine(lineNumber, sourceFile);
-          const startPosition = getFirstNonSpaceCharacterPosition(sourceFile.text, lineStartPosition);
-          const insertAtLineStart = isValidLocationToAddComment(sourceFile, startPosition);
-          const token = getTouchingToken(sourceFile, insertAtLineStart ? startPosition : position);
-          const indent2 = sourceFile.text.slice(lineStartPosition, startPosition);
-          const text = `${insertAtLineStart ? "" : this.newLineCharacter}//${commentText}${this.newLineCharacter}${indent2}`;
-          this.insertText(sourceFile, token.getStart(sourceFile), text);
-        }
-        insertJsdocCommentBefore(sourceFile, node, tag) {
-          const fnStart = node.getStart(sourceFile);
-          if (node.jsDoc) {
-            for (const jsdoc of node.jsDoc) {
-              this.deleteRange(sourceFile, {
-                pos: getLineStartPositionForPosition(jsdoc.getStart(sourceFile), sourceFile),
-                end: getAdjustedEndPosition(
-                  sourceFile,
-                  jsdoc,
-                  /*options*/
-                  {}
-                )
-              });
-            }
-          }
-          const startPosition = getPrecedingNonSpaceCharacterPosition(sourceFile.text, fnStart - 1);
-          const indent2 = sourceFile.text.slice(startPosition, fnStart);
-          this.insertNodeAt(sourceFile, fnStart, tag, { suffix: this.newLineCharacter + indent2 });
-        }
-        createJSDocText(sourceFile, node) {
-          const comments = flatMap(node.jsDoc, (jsDoc2) => isString(jsDoc2.comment) ? factory.createJSDocText(jsDoc2.comment) : jsDoc2.comment);
-          const jsDoc = singleOrUndefined(node.jsDoc);
-          return jsDoc && positionsAreOnSameLine(jsDoc.pos, jsDoc.end, sourceFile) && length(comments) === 0 ? void 0 : factory.createNodeArray(intersperse(comments, factory.createJSDocText("\n")));
-        }
-        replaceJSDocComment(sourceFile, node, tags) {
-          this.insertJsdocCommentBefore(sourceFile, updateJSDocHost(node), factory.createJSDocComment(this.createJSDocText(sourceFile, node), factory.createNodeArray(tags)));
-        }
-        addJSDocTags(sourceFile, parent2, newTags) {
-          const oldTags = flatMapToMutable(parent2.jsDoc, (j) => j.tags);
-          const unmergedNewTags = newTags.filter((newTag) => !oldTags.some((tag, i) => {
-            const merged = tryMergeJsdocTags(tag, newTag);
-            if (merged)
-              oldTags[i] = merged;
-            return !!merged;
-          }));
-          this.replaceJSDocComment(sourceFile, parent2, [...oldTags, ...unmergedNewTags]);
-        }
-        filterJSDocTags(sourceFile, parent2, predicate) {
-          this.replaceJSDocComment(sourceFile, parent2, filter(flatMapToMutable(parent2.jsDoc, (j) => j.tags), predicate));
-        }
-        replaceRangeWithText(sourceFile, range, text) {
-          this.changes.push({ kind: 3 /* Text */, sourceFile, range, text });
-        }
-        insertText(sourceFile, pos, text) {
-          this.replaceRangeWithText(sourceFile, createRange(pos), text);
-        }
-        /** Prefer this over replacing a node with another that has a type annotation, as it avoids reformatting the other parts of the node. */
-        tryInsertTypeAnnotation(sourceFile, node, type) {
-          let endNode2;
-          if (isFunctionLike(node)) {
-            endNode2 = findChildOfKind(node, 22 /* CloseParenToken */, sourceFile);
-            if (!endNode2) {
-              if (!isArrowFunction(node))
-                return false;
-              endNode2 = first(node.parameters);
-            }
-          } else {
-            endNode2 = (node.kind === 259 /* VariableDeclaration */ ? node.exclamationToken : node.questionToken) ?? node.name;
-          }
-          this.insertNodeAt(sourceFile, endNode2.end, type, { prefix: ": " });
-          return true;
-        }
-        tryInsertThisTypeAnnotation(sourceFile, node, type) {
-          const start = findChildOfKind(node, 21 /* OpenParenToken */, sourceFile).getStart(sourceFile) + 1;
-          const suffix = node.parameters.length ? ", " : "";
-          this.insertNodeAt(sourceFile, start, type, { prefix: "this: ", suffix });
-        }
-        insertTypeParameters(sourceFile, node, typeParameters) {
-          const start = (findChildOfKind(node, 21 /* OpenParenToken */, sourceFile) || first(node.parameters)).getStart(sourceFile);
-          this.insertNodesAt(sourceFile, start, typeParameters, { prefix: "<", suffix: ">", joiner: ", " });
-        }
-        getOptionsForInsertNodeBefore(before, inserted, blankLineBetween) {
-          if (isStatement(before) || isClassElement(before)) {
-            return { suffix: blankLineBetween ? this.newLineCharacter + this.newLineCharacter : this.newLineCharacter };
-          } else if (isVariableDeclaration(before)) {
-            return { suffix: ", " };
-          } else if (isParameter(before)) {
-            return isParameter(inserted) ? { suffix: ", " } : {};
-          } else if (isStringLiteral(before) && isImportDeclaration(before.parent) || isNamedImports(before)) {
-            return { suffix: ", " };
-          } else if (isImportSpecifier(before)) {
-            return { suffix: "," + (blankLineBetween ? this.newLineCharacter : " ") };
-          }
-          return Debug.failBadSyntaxKind(before);
-        }
-        insertNodeAtConstructorStart(sourceFile, ctr, newStatement) {
-          const firstStatement = firstOrUndefined(ctr.body.statements);
-          if (!firstStatement || !ctr.body.multiLine) {
-            this.replaceConstructorBody(sourceFile, ctr, [newStatement, ...ctr.body.statements]);
-          } else {
-            this.insertNodeBefore(sourceFile, firstStatement, newStatement);
-          }
-        }
-        insertNodeAtConstructorStartAfterSuperCall(sourceFile, ctr, newStatement) {
-          const superCallStatement = find(ctr.body.statements, (stmt) => isExpressionStatement(stmt) && isSuperCall(stmt.expression));
-          if (!superCallStatement || !ctr.body.multiLine) {
-            this.replaceConstructorBody(sourceFile, ctr, [...ctr.body.statements, newStatement]);
-          } else {
-            this.insertNodeAfter(sourceFile, superCallStatement, newStatement);
-          }
-        }
-        insertNodeAtConstructorEnd(sourceFile, ctr, newStatement) {
-          const lastStatement = lastOrUndefined(ctr.body.statements);
-          if (!lastStatement || !ctr.body.multiLine) {
-            this.replaceConstructorBody(sourceFile, ctr, [...ctr.body.statements, newStatement]);
-          } else {
-            this.insertNodeAfter(sourceFile, lastStatement, newStatement);
-          }
-        }
-        replaceConstructorBody(sourceFile, ctr, statements) {
-          this.replaceNode(sourceFile, ctr.body, factory.createBlock(
-            statements,
-            /*multiLine*/
-            true
-          ));
-        }
-        insertNodeAtEndOfScope(sourceFile, scope, newNode) {
-          const pos = getAdjustedStartPosition(sourceFile, scope.getLastToken(), {});
-          this.insertNodeAt(sourceFile, pos, newNode, {
-            prefix: isLineBreak(sourceFile.text.charCodeAt(scope.getLastToken().pos)) ? this.newLineCharacter : this.newLineCharacter + this.newLineCharacter,
-            suffix: this.newLineCharacter
-          });
-        }
-        insertMemberAtStart(sourceFile, node, newElement) {
-          this.insertNodeAtStartWorker(sourceFile, node, newElement);
-        }
-        insertNodeAtObjectStart(sourceFile, obj, newElement) {
-          this.insertNodeAtStartWorker(sourceFile, obj, newElement);
-        }
-        insertNodeAtStartWorker(sourceFile, node, newElement) {
-          const indentation = this.guessIndentationFromExistingMembers(sourceFile, node) ?? this.computeIndentationForNewMember(sourceFile, node);
-          this.insertNodeAt(sourceFile, getMembersOrProperties(node).pos, newElement, this.getInsertNodeAtStartInsertOptions(sourceFile, node, indentation));
-        }
-        /**
-         * Tries to guess the indentation from the existing members of a class/interface/object. All members must be on
-         * new lines and must share the same indentation.
-         */
-        guessIndentationFromExistingMembers(sourceFile, node) {
-          let indentation;
-          let lastRange = node;
-          for (const member of getMembersOrProperties(node)) {
-            if (rangeStartPositionsAreOnSameLine(lastRange, member, sourceFile)) {
-              return void 0;
-            }
-            const memberStart = member.getStart(sourceFile);
-            const memberIndentation = ts_formatting_exports.SmartIndenter.findFirstNonWhitespaceColumn(getLineStartPositionForPosition(memberStart, sourceFile), memberStart, sourceFile, this.formatContext.options);
-            if (indentation === void 0) {
-              indentation = memberIndentation;
-            } else if (memberIndentation !== indentation) {
-              return void 0;
-            }
-            lastRange = member;
-          }
-          return indentation;
-        }
-        computeIndentationForNewMember(sourceFile, node) {
-          const nodeStart = node.getStart(sourceFile);
-          return ts_formatting_exports.SmartIndenter.findFirstNonWhitespaceColumn(getLineStartPositionForPosition(nodeStart, sourceFile), nodeStart, sourceFile, this.formatContext.options) + (this.formatContext.options.indentSize ?? 4);
-        }
-        getInsertNodeAtStartInsertOptions(sourceFile, node, indentation) {
-          const members = getMembersOrProperties(node);
-          const isEmpty = members.length === 0;
-          const isFirstInsertion = addToSeen(this.classesWithNodesInsertedAtStart, getNodeId(node), { node, sourceFile });
-          const insertTrailingComma = isObjectLiteralExpression(node) && (!isJsonSourceFile(sourceFile) || !isEmpty);
-          const insertLeadingComma = isObjectLiteralExpression(node) && isJsonSourceFile(sourceFile) && isEmpty && !isFirstInsertion;
-          return {
-            indentation,
-            prefix: (insertLeadingComma ? "," : "") + this.newLineCharacter,
-            suffix: insertTrailingComma ? "," : isInterfaceDeclaration(node) && isEmpty ? ";" : ""
-          };
-        }
-        insertNodeAfterComma(sourceFile, after, newNode) {
-          const endPosition = this.insertNodeAfterWorker(sourceFile, this.nextCommaToken(sourceFile, after) || after, newNode);
-          this.insertNodeAt(sourceFile, endPosition, newNode, this.getInsertNodeAfterOptions(sourceFile, after));
-        }
-        insertNodeAfter(sourceFile, after, newNode) {
-          const endPosition = this.insertNodeAfterWorker(sourceFile, after, newNode);
-          this.insertNodeAt(sourceFile, endPosition, newNode, this.getInsertNodeAfterOptions(sourceFile, after));
-        }
-        insertNodeAtEndOfList(sourceFile, list, newNode) {
-          this.insertNodeAt(sourceFile, list.end, newNode, { prefix: ", " });
-        }
-        insertNodesAfter(sourceFile, after, newNodes) {
-          const endPosition = this.insertNodeAfterWorker(sourceFile, after, first(newNodes));
-          this.insertNodesAt(sourceFile, endPosition, newNodes, this.getInsertNodeAfterOptions(sourceFile, after));
-        }
-        insertNodeAfterWorker(sourceFile, after, newNode) {
-          if (needSemicolonBetween(after, newNode)) {
-            if (sourceFile.text.charCodeAt(after.end - 1) !== 59 /* semicolon */) {
-              this.replaceRange(sourceFile, createRange(after.end), factory.createToken(27 /* SemicolonToken */));
-            }
-          }
-          const endPosition = getAdjustedEndPosition(sourceFile, after, {});
-          return endPosition;
-        }
-        getInsertNodeAfterOptions(sourceFile, after) {
-          const options = this.getInsertNodeAfterOptionsWorker(after);
-          return {
-            ...options,
-            prefix: after.end === sourceFile.end && isStatement(after) ? options.prefix ? `
-${options.prefix}` : "\n" : options.prefix
-          };
-        }
-        getInsertNodeAfterOptionsWorker(node) {
-          switch (node.kind) {
-            case 262 /* ClassDeclaration */:
-            case 266 /* ModuleDeclaration */:
-              return { prefix: this.newLineCharacter, suffix: this.newLineCharacter };
-            case 259 /* VariableDeclaration */:
-            case 11 /* StringLiteral */:
-            case 80 /* Identifier */:
-              return { prefix: ", " };
-            case 302 /* PropertyAssignment */:
-              return { suffix: "," + this.newLineCharacter };
-            case 95 /* ExportKeyword */:
-              return { prefix: " " };
-            case 168 /* Parameter */:
-              return {};
-            default:
-              Debug.assert(isStatement(node) || isClassOrTypeElement(node));
-              return { suffix: this.newLineCharacter };
-          }
-        }
-        insertName(sourceFile, node, name) {
-          Debug.assert(!node.name);
-          if (node.kind === 218 /* ArrowFunction */) {
-            const arrow = findChildOfKind(node, 39 /* EqualsGreaterThanToken */, sourceFile);
-            const lparen = findChildOfKind(node, 21 /* OpenParenToken */, sourceFile);
-            if (lparen) {
-              this.insertNodesAt(sourceFile, lparen.getStart(sourceFile), [factory.createToken(100 /* FunctionKeyword */), factory.createIdentifier(name)], { joiner: " " });
-              deleteNode(this, sourceFile, arrow);
-            } else {
-              this.insertText(sourceFile, first(node.parameters).getStart(sourceFile), `function ${name}(`);
-              this.replaceRange(sourceFile, arrow, factory.createToken(22 /* CloseParenToken */));
-            }
-            if (node.body.kind !== 240 /* Block */) {
-              this.insertNodesAt(sourceFile, node.body.getStart(sourceFile), [factory.createToken(19 /* OpenBraceToken */), factory.createToken(107 /* ReturnKeyword */)], { joiner: " ", suffix: " " });
-              this.insertNodesAt(sourceFile, node.body.end, [factory.createToken(27 /* SemicolonToken */), factory.createToken(20 /* CloseBraceToken */)], { joiner: " " });
-            }
-          } else {
-            const pos = findChildOfKind(node, node.kind === 217 /* FunctionExpression */ ? 100 /* FunctionKeyword */ : 86 /* ClassKeyword */, sourceFile).end;
-            this.insertNodeAt(sourceFile, pos, factory.createIdentifier(name), { prefix: " " });
-          }
-        }
-        insertExportModifier(sourceFile, node) {
-          this.insertText(sourceFile, node.getStart(sourceFile), "export ");
-        }
-        insertImportSpecifierAtIndex(sourceFile, importSpecifier, namedImports, index) {
-          const prevSpecifier = namedImports.elements[index - 1];
-          if (prevSpecifier) {
-            this.insertNodeInListAfter(sourceFile, prevSpecifier, importSpecifier);
-          } else {
-            this.insertNodeBefore(
-              sourceFile,
-              namedImports.elements[0],
-              importSpecifier,
-              !positionsAreOnSameLine(namedImports.elements[0].getStart(), namedImports.parent.parent.getStart(), sourceFile)
-            );
-          }
-        }
-        /**
-         * This function should be used to insert nodes in lists when nodes don't carry separators as the part of the node range,
-         * i.e. arguments in arguments lists, parameters in parameter lists etc.
-         * Note that separators are part of the node in statements and class elements.
-         */
-        insertNodeInListAfter(sourceFile, after, newNode, containingList = ts_formatting_exports.SmartIndenter.getContainingList(after, sourceFile)) {
-          if (!containingList) {
-            Debug.fail("node is not a list element");
-            return;
-          }
-          const index = indexOfNode(containingList, after);
-          if (index < 0) {
-            return;
-          }
-          const end = after.getEnd();
-          if (index !== containingList.length - 1) {
-            const nextToken = getTokenAtPosition(sourceFile, after.end);
-            if (nextToken && isSeparator(after, nextToken)) {
-              const nextNode = containingList[index + 1];
-              const startPos = skipWhitespacesAndLineBreaks(sourceFile.text, nextNode.getFullStart());
-              const suffix = `${tokenToString(nextToken.kind)}${sourceFile.text.substring(nextToken.end, startPos)}`;
-              this.insertNodesAt(sourceFile, startPos, [newNode], { suffix });
-            }
-          } else {
-            const afterStart = after.getStart(sourceFile);
-            const afterStartLinePosition = getLineStartPositionForPosition(afterStart, sourceFile);
-            let separator;
-            let multilineList = false;
-            if (containingList.length === 1) {
-              separator = 28 /* CommaToken */;
-            } else {
-              const tokenBeforeInsertPosition = findPrecedingToken(after.pos, sourceFile);
-              separator = isSeparator(after, tokenBeforeInsertPosition) ? tokenBeforeInsertPosition.kind : 28 /* CommaToken */;
-              const afterMinusOneStartLinePosition = getLineStartPositionForPosition(containingList[index - 1].getStart(sourceFile), sourceFile);
-              multilineList = afterMinusOneStartLinePosition !== afterStartLinePosition;
-            }
-            if (hasCommentsBeforeLineBreak(sourceFile.text, after.end)) {
-              multilineList = true;
-            }
-            if (multilineList) {
-              this.replaceRange(sourceFile, createRange(end), factory.createToken(separator));
-              const indentation = ts_formatting_exports.SmartIndenter.findFirstNonWhitespaceColumn(afterStartLinePosition, afterStart, sourceFile, this.formatContext.options);
-              let insertPos = skipTrivia(
-                sourceFile.text,
-                end,
-                /*stopAfterLineBreak*/
-                true,
-                /*stopAtComments*/
-                false
-              );
-              while (insertPos !== end && isLineBreak(sourceFile.text.charCodeAt(insertPos - 1))) {
-                insertPos--;
-              }
-              this.replaceRange(sourceFile, createRange(insertPos), newNode, { indentation, prefix: this.newLineCharacter });
-            } else {
-              this.replaceRange(sourceFile, createRange(end), newNode, { prefix: `${tokenToString(separator)} ` });
-            }
-          }
-        }
-        parenthesizeExpression(sourceFile, expression) {
-          this.replaceRange(sourceFile, rangeOfNode(expression), factory.createParenthesizedExpression(expression));
-        }
-        finishClassesWithNodesInsertedAtStart() {
-          this.classesWithNodesInsertedAtStart.forEach(({ node, sourceFile }) => {
-            const [openBraceEnd, closeBraceEnd] = getClassOrObjectBraceEnds(node, sourceFile);
-            if (openBraceEnd !== void 0 && closeBraceEnd !== void 0) {
-              const isEmpty = getMembersOrProperties(node).length === 0;
-              const isSingleLine = positionsAreOnSameLine(openBraceEnd, closeBraceEnd, sourceFile);
-              if (isEmpty && isSingleLine && openBraceEnd !== closeBraceEnd - 1) {
-                this.deleteRange(sourceFile, createRange(openBraceEnd, closeBraceEnd - 1));
-              }
-              if (isSingleLine) {
-                this.insertText(sourceFile, closeBraceEnd - 1, this.newLineCharacter);
-              }
-            }
-          });
-        }
-        finishDeleteDeclarations() {
-          const deletedNodesInLists = /* @__PURE__ */ new Set();
-          for (const { sourceFile, node } of this.deletedNodes) {
-            if (!this.deletedNodes.some((d) => d.sourceFile === sourceFile && rangeContainsRangeExclusive(d.node, node))) {
-              if (isArray(node)) {
-                this.deleteRange(sourceFile, rangeOfTypeParameters(sourceFile, node));
-              } else {
-                deleteDeclaration.deleteDeclaration(this, deletedNodesInLists, sourceFile, node);
-              }
-            }
-          }
-          deletedNodesInLists.forEach((node) => {
-            const sourceFile = node.getSourceFile();
-            const list = ts_formatting_exports.SmartIndenter.getContainingList(node, sourceFile);
-            if (node !== last(list))
-              return;
-            const lastNonDeletedIndex = findLastIndex(list, (n) => !deletedNodesInLists.has(n), list.length - 2);
-            if (lastNonDeletedIndex !== -1) {
-              this.deleteRange(sourceFile, { pos: list[lastNonDeletedIndex].end, end: startPositionToDeleteNodeInList(sourceFile, list[lastNonDeletedIndex + 1]) });
-            }
-          });
-        }
-        /**
-         * Note: after calling this, the TextChanges object must be discarded!
-         * @param validate only for tests
-         *    The reason we must validate as part of this method is that `getNonFormattedText` changes the node's positions,
-         *    so we can only call this once and can't get the non-formatted text separately.
-         */
-        getChanges(validate) {
-          this.finishDeleteDeclarations();
-          this.finishClassesWithNodesInsertedAtStart();
-          const changes = changesToText.getTextChangesFromChanges(this.changes, this.newLineCharacter, this.formatContext, validate);
-          if (this.newFileChanges) {
-            this.newFileChanges.forEach((insertions, fileName) => {
-              changes.push(changesToText.newFileChanges(fileName, insertions, this.newLineCharacter, this.formatContext));
-            });
-          }
-          return changes;
-        }
-        createNewFile(oldFile, fileName, statements) {
-          this.insertStatementsInNewFile(fileName, statements, oldFile);
-        }
-      };
-      ((changesToText2) => {
-        function getTextChangesFromChanges(changes, newLineCharacter, formatContext, validate) {
-          return mapDefined(group(changes, (c) => c.sourceFile.path), (changesInFile) => {
-            const sourceFile = changesInFile[0].sourceFile;
-            const normalized = stableSort(changesInFile, (a, b) => a.range.pos - b.range.pos || a.range.end - b.range.end);
-            for (let i = 0; i < normalized.length - 1; i++) {
-              Debug.assert(normalized[i].range.end <= normalized[i + 1].range.pos, "Changes overlap", () => `${JSON.stringify(normalized[i].range)} and ${JSON.stringify(normalized[i + 1].range)}`);
-            }
-            const textChanges2 = mapDefined(normalized, (c) => {
-              const span = createTextSpanFromRange(c.range);
-              const targetSourceFile = c.kind === 1 /* ReplaceWithSingleNode */ ? getSourceFileOfNode(getOriginalNode(c.node)) ?? c.sourceFile : c.kind === 2 /* ReplaceWithMultipleNodes */ ? getSourceFileOfNode(getOriginalNode(c.nodes[0])) ?? c.sourceFile : c.sourceFile;
-              const newText = computeNewText(c, targetSourceFile, sourceFile, newLineCharacter, formatContext, validate);
-              if (span.length === newText.length && stringContainsAt(targetSourceFile.text, newText, span.start)) {
-                return void 0;
-              }
-              return createTextChange(span, newText);
-            });
-            return textChanges2.length > 0 ? { fileName: sourceFile.fileName, textChanges: textChanges2 } : void 0;
-          });
-        }
-        changesToText2.getTextChangesFromChanges = getTextChangesFromChanges;
-        function newFileChanges(fileName, insertions, newLineCharacter, formatContext) {
-          const text = newFileChangesWorker(getScriptKindFromFileName(fileName), insertions, newLineCharacter, formatContext);
-          return { fileName, textChanges: [createTextChange(createTextSpan(0, 0), text)], isNewFile: true };
-        }
-        changesToText2.newFileChanges = newFileChanges;
-        function newFileChangesWorker(scriptKind, insertions, newLineCharacter, formatContext) {
-          const nonFormattedText = flatMap(insertions, (insertion) => insertion.statements.map((s) => s === 4 /* NewLineTrivia */ ? "" : getNonformattedText(s, insertion.oldFile, newLineCharacter).text)).join(newLineCharacter);
-          const sourceFile = createSourceFile(
-            "any file name",
-            nonFormattedText,
-            99 /* ESNext */,
-            /*setParentNodes*/
-            true,
-            scriptKind
-          );
-          const changes = ts_formatting_exports.formatDocument(sourceFile, formatContext);
-          return applyChanges(nonFormattedText, changes) + newLineCharacter;
-        }
-        changesToText2.newFileChangesWorker = newFileChangesWorker;
-        function computeNewText(change, targetSourceFile, sourceFile, newLineCharacter, formatContext, validate) {
-          var _a;
-          if (change.kind === 0 /* Remove */) {
-            return "";
-          }
-          if (change.kind === 3 /* Text */) {
-            return change.text;
-          }
-          const { options = {}, range: { pos } } = change;
-          const format = (n) => getFormattedTextOfNode(n, targetSourceFile, sourceFile, pos, options, newLineCharacter, formatContext, validate);
-          const text = change.kind === 2 /* ReplaceWithMultipleNodes */ ? change.nodes.map((n) => removeSuffix(format(n), newLineCharacter)).join(((_a = change.options) == null ? void 0 : _a.joiner) || newLineCharacter) : format(change.node);
-          const noIndent = options.indentation !== void 0 || getLineStartPositionForPosition(pos, targetSourceFile) === pos ? text : text.replace(/^\s+/, "");
-          return (options.prefix || "") + noIndent + (!options.suffix || endsWith(noIndent, options.suffix) ? "" : options.suffix);
-        }
-        function getFormattedTextOfNode(nodeIn, targetSourceFile, sourceFile, pos, { indentation, prefix, delta }, newLineCharacter, formatContext, validate) {
-          const { node, text } = getNonformattedText(nodeIn, targetSourceFile, newLineCharacter);
-          if (validate)
-            validate(node, text);
-          const formatOptions = getFormatCodeSettingsForWriting(formatContext, targetSourceFile);
-          const initialIndentation = indentation !== void 0 ? indentation : ts_formatting_exports.SmartIndenter.getIndentation(pos, sourceFile, formatOptions, prefix === newLineCharacter || getLineStartPositionForPosition(pos, targetSourceFile) === pos);
-          if (delta === void 0) {
-            delta = ts_formatting_exports.SmartIndenter.shouldIndentChildNode(formatOptions, nodeIn) ? formatOptions.indentSize || 0 : 0;
-          }
-          const file = {
-            text,
-            getLineAndCharacterOfPosition(pos2) {
-              return getLineAndCharacterOfPosition(this, pos2);
-            }
-          };
-          const changes = ts_formatting_exports.formatNodeGivenIndentation(node, file, targetSourceFile.languageVariant, initialIndentation, delta, { ...formatContext, options: formatOptions });
-          return applyChanges(text, changes);
-        }
-        function getNonformattedText(node, sourceFile, newLineCharacter) {
-          const writer = createWriter(newLineCharacter);
-          const newLine = getNewLineKind(newLineCharacter);
-          createPrinter({
-            newLine,
-            neverAsciiEscape: true,
-            preserveSourceNewlines: true,
-            terminateUnterminatedLiterals: true
-          }, writer).writeNode(4 /* Unspecified */, node, sourceFile, writer);
-          return { text: writer.getText(), node: assignPositionsToNode(node) };
-        }
-        changesToText2.getNonformattedText = getNonformattedText;
-      })(changesToText || (changesToText = {}));
-      textChangesTransformationContext = {
-        ...nullTransformationContext,
-        factory: createNodeFactory(
-          nullTransformationContext.factory.flags | 1 /* NoParenthesizerRules */,
-          nullTransformationContext.factory.baseFactory
-        )
-      };
-      ((_deleteDeclaration) => {
-        function deleteDeclaration2(changes, deletedNodesInLists, sourceFile, node) {
-          switch (node.kind) {
-            case 168 /* Parameter */: {
-              const oldFunction = node.parent;
-              if (isArrowFunction(oldFunction) && oldFunction.parameters.length === 1 && !findChildOfKind(oldFunction, 21 /* OpenParenToken */, sourceFile)) {
-                changes.replaceNodeWithText(sourceFile, node, "()");
-              } else {
-                deleteNodeInList(changes, deletedNodesInLists, sourceFile, node);
-              }
-              break;
-            }
-            case 271 /* ImportDeclaration */:
-            case 270 /* ImportEqualsDeclaration */:
-              const isFirstImport = sourceFile.imports.length && node === first(sourceFile.imports).parent || node === find(sourceFile.statements, isAnyImportSyntax);
-              deleteNode(changes, sourceFile, node, {
-                leadingTriviaOption: isFirstImport ? 0 /* Exclude */ : hasJSDocNodes(node) ? 2 /* JSDoc */ : 3 /* StartLine */
-              });
-              break;
-            case 207 /* BindingElement */:
-              const pattern = node.parent;
-              const preserveComma = pattern.kind === 206 /* ArrayBindingPattern */ && node !== last(pattern.elements);
-              if (preserveComma) {
-                deleteNode(changes, sourceFile, node);
-              } else {
-                deleteNodeInList(changes, deletedNodesInLists, sourceFile, node);
-              }
-              break;
-            case 259 /* VariableDeclaration */:
-              deleteVariableDeclaration(changes, deletedNodesInLists, sourceFile, node);
-              break;
-            case 167 /* TypeParameter */:
-              deleteNodeInList(changes, deletedNodesInLists, sourceFile, node);
-              break;
-            case 275 /* ImportSpecifier */:
-              const namedImports = node.parent;
-              if (namedImports.elements.length === 1) {
-                deleteImportBinding(changes, sourceFile, namedImports);
-              } else {
-                deleteNodeInList(changes, deletedNodesInLists, sourceFile, node);
-              }
-              break;
-            case 273 /* NamespaceImport */:
-              deleteImportBinding(changes, sourceFile, node);
-              break;
-            case 27 /* SemicolonToken */:
-              deleteNode(changes, sourceFile, node, { trailingTriviaOption: 0 /* Exclude */ });
-              break;
-            case 100 /* FunctionKeyword */:
-              deleteNode(changes, sourceFile, node, { leadingTriviaOption: 0 /* Exclude */ });
-              break;
-            case 262 /* ClassDeclaration */:
-            case 261 /* FunctionDeclaration */:
-              deleteNode(changes, sourceFile, node, { leadingTriviaOption: hasJSDocNodes(node) ? 2 /* JSDoc */ : 3 /* StartLine */ });
-              break;
-            default:
-              if (!node.parent) {
-                deleteNode(changes, sourceFile, node);
-              } else if (isImportClause(node.parent) && node.parent.name === node) {
-                deleteDefaultImport(changes, sourceFile, node.parent);
-              } else if (isCallExpression(node.parent) && contains(node.parent.arguments, node)) {
-                deleteNodeInList(changes, deletedNodesInLists, sourceFile, node);
-              } else {
-                deleteNode(changes, sourceFile, node);
-              }
-          }
-        }
-        _deleteDeclaration.deleteDeclaration = deleteDeclaration2;
-        function deleteDefaultImport(changes, sourceFile, importClause) {
-          if (!importClause.namedBindings) {
-            deleteNode(changes, sourceFile, importClause.parent);
-          } else {
-            const start = importClause.name.getStart(sourceFile);
-            const nextToken = getTokenAtPosition(sourceFile, importClause.name.end);
-            if (nextToken && nextToken.kind === 28 /* CommaToken */) {
-              const end = skipTrivia(
-                sourceFile.text,
-                nextToken.end,
-                /*stopAfterLineBreak*/
-                false,
-                /*stopAtComments*/
-                true
-              );
-              changes.deleteRange(sourceFile, { pos: start, end });
-            } else {
-              deleteNode(changes, sourceFile, importClause.name);
-            }
-          }
-        }
-        function deleteImportBinding(changes, sourceFile, node) {
-          if (node.parent.name) {
-            const previousToken = Debug.checkDefined(getTokenAtPosition(sourceFile, node.pos - 1));
-            changes.deleteRange(sourceFile, { pos: previousToken.getStart(sourceFile), end: node.end });
-          } else {
-            const importDecl = getAncestor(node, 271 /* ImportDeclaration */);
-            deleteNode(changes, sourceFile, importDecl);
-          }
-        }
-        function deleteVariableDeclaration(changes, deletedNodesInLists, sourceFile, node) {
-          const { parent: parent2 } = node;
-          if (parent2.kind === 298 /* CatchClause */) {
-            changes.deleteNodeRange(sourceFile, findChildOfKind(parent2, 21 /* OpenParenToken */, sourceFile), findChildOfKind(parent2, 22 /* CloseParenToken */, sourceFile));
-            return;
-          }
-          if (parent2.declarations.length !== 1) {
-            deleteNodeInList(changes, deletedNodesInLists, sourceFile, node);
-            return;
-          }
-          const gp = parent2.parent;
-          switch (gp.kind) {
-            case 249 /* ForOfStatement */:
-            case 248 /* ForInStatement */:
-              changes.replaceNode(sourceFile, node, factory.createObjectLiteralExpression());
-              break;
-            case 247 /* ForStatement */:
-              deleteNode(changes, sourceFile, parent2);
-              break;
-            case 242 /* VariableStatement */:
-              deleteNode(changes, sourceFile, gp, { leadingTriviaOption: hasJSDocNodes(gp) ? 2 /* JSDoc */ : 3 /* StartLine */ });
-              break;
-            default:
-              Debug.assertNever(gp);
-          }
-        }
-      })(deleteDeclaration || (deleteDeclaration = {}));
-    }
-  });
-
-  // src/services/_namespaces/ts.textChanges.ts
-  var ts_textChanges_exports = {};
-  __export(ts_textChanges_exports, {
-    ChangeTracker: () => ChangeTracker,
-    LeadingTriviaOption: () => LeadingTriviaOption,
-    TrailingTriviaOption: () => TrailingTriviaOption,
-    applyChanges: () => applyChanges,
-    assignPositionsToNode: () => assignPositionsToNode,
-    createWriter: () => createWriter,
-    deleteNode: () => deleteNode,
-    isThisTypeAnnotatable: () => isThisTypeAnnotatable,
-    isValidLocationToAddComment: () => isValidLocationToAddComment
-  });
-  var init_ts_textChanges = __esm({
-    "src/services/_namespaces/ts.textChanges.ts"() {
-      "use strict";
-      init_textChanges();
-    }
-  });
-
-  // src/services/formatting/formattingContext.ts
-  var FormattingRequestKind, FormattingContext;
-  var init_formattingContext = __esm({
-    "src/services/formatting/formattingContext.ts"() {
-      "use strict";
-      init_ts4();
-      FormattingRequestKind = /* @__PURE__ */ ((FormattingRequestKind2) => {
-        FormattingRequestKind2[FormattingRequestKind2["FormatDocument"] = 0] = "FormatDocument";
-        FormattingRequestKind2[FormattingRequestKind2["FormatSelection"] = 1] = "FormatSelection";
-        FormattingRequestKind2[FormattingRequestKind2["FormatOnEnter"] = 2] = "FormatOnEnter";
-        FormattingRequestKind2[FormattingRequestKind2["FormatOnSemicolon"] = 3] = "FormatOnSemicolon";
-        FormattingRequestKind2[FormattingRequestKind2["FormatOnOpeningCurlyBrace"] = 4] = "FormatOnOpeningCurlyBrace";
-        FormattingRequestKind2[FormattingRequestKind2["FormatOnClosingCurlyBrace"] = 5] = "FormatOnClosingCurlyBrace";
-        return FormattingRequestKind2;
-      })(FormattingRequestKind || {});
-      FormattingContext = class {
-        constructor(sourceFile, formattingRequestKind, options) {
-          this.sourceFile = sourceFile;
-          this.formattingRequestKind = formattingRequestKind;
-          this.options = options;
-        }
-        updateContext(currentRange, currentTokenParent, nextRange, nextTokenParent, commonParent) {
-          this.currentTokenSpan = Debug.checkDefined(currentRange);
-          this.currentTokenParent = Debug.checkDefined(currentTokenParent);
-          this.nextTokenSpan = Debug.checkDefined(nextRange);
-          this.nextTokenParent = Debug.checkDefined(nextTokenParent);
-          this.contextNode = Debug.checkDefined(commonParent);
-          this.contextNodeAllOnSameLine = void 0;
-          this.nextNodeAllOnSameLine = void 0;
-          this.tokensAreOnSameLine = void 0;
-          this.contextNodeBlockIsOnOneLine = void 0;
-          this.nextNodeBlockIsOnOneLine = void 0;
-        }
-        ContextNodeAllOnSameLine() {
-          if (this.contextNodeAllOnSameLine === void 0) {
-            this.contextNodeAllOnSameLine = this.NodeIsOnOneLine(this.contextNode);
-          }
-          return this.contextNodeAllOnSameLine;
-        }
-        NextNodeAllOnSameLine() {
-          if (this.nextNodeAllOnSameLine === void 0) {
-            this.nextNodeAllOnSameLine = this.NodeIsOnOneLine(this.nextTokenParent);
-          }
-          return this.nextNodeAllOnSameLine;
-        }
-        TokensAreOnSameLine() {
-          if (this.tokensAreOnSameLine === void 0) {
-            const startLine = this.sourceFile.getLineAndCharacterOfPosition(this.currentTokenSpan.pos).line;
-            const endLine = this.sourceFile.getLineAndCharacterOfPosition(this.nextTokenSpan.pos).line;
-            this.tokensAreOnSameLine = startLine === endLine;
-          }
-          return this.tokensAreOnSameLine;
-        }
-        ContextNodeBlockIsOnOneLine() {
-          if (this.contextNodeBlockIsOnOneLine === void 0) {
-            this.contextNodeBlockIsOnOneLine = this.BlockIsOnOneLine(this.contextNode);
-          }
-          return this.contextNodeBlockIsOnOneLine;
-        }
-        NextNodeBlockIsOnOneLine() {
-          if (this.nextNodeBlockIsOnOneLine === void 0) {
-            this.nextNodeBlockIsOnOneLine = this.BlockIsOnOneLine(this.nextTokenParent);
-          }
-          return this.nextNodeBlockIsOnOneLine;
-        }
-        NodeIsOnOneLine(node) {
-          const startLine = this.sourceFile.getLineAndCharacterOfPosition(node.getStart(this.sourceFile)).line;
-          const endLine = this.sourceFile.getLineAndCharacterOfPosition(node.getEnd()).line;
-          return startLine === endLine;
-        }
-        BlockIsOnOneLine(node) {
-          const openBrace = findChildOfKind(node, 19 /* OpenBraceToken */, this.sourceFile);
-          const closeBrace = findChildOfKind(node, 20 /* CloseBraceToken */, this.sourceFile);
-          if (openBrace && closeBrace) {
-            const startLine = this.sourceFile.getLineAndCharacterOfPosition(openBrace.getEnd()).line;
-            const endLine = this.sourceFile.getLineAndCharacterOfPosition(closeBrace.getStart(this.sourceFile)).line;
-            return startLine === endLine;
-          }
-          return false;
-        }
-      };
-    }
-  });
-
-  // src/services/formatting/formattingScanner.ts
-  function getFormattingScanner(text, languageVariant, startPos, endPos, cb) {
-    const scanner2 = languageVariant === 1 /* JSX */ ? jsxScanner : standardScanner;
-    scanner2.setText(text);
-    scanner2.resetTokenState(startPos);
-    let wasNewLine = true;
-    let leadingTrivia;
-    let trailingTrivia;
-    let savedPos;
-    let lastScanAction;
-    let lastTokenInfo;
-    const res = cb({
-      advance,
-      readTokenInfo,
-      readEOFTokenRange,
-      isOnToken,
-      isOnEOF,
-      getCurrentLeadingTrivia: () => leadingTrivia,
-      lastTrailingTriviaWasNewLine: () => wasNewLine,
-      skipToEndOf,
-      skipToStartOf,
-      getTokenFullStart: () => (lastTokenInfo == null ? void 0 : lastTokenInfo.token.pos) ?? scanner2.getTokenStart(),
-      getStartPos: () => (lastTokenInfo == null ? void 0 : lastTokenInfo.token.pos) ?? scanner2.getTokenStart()
-    });
-    lastTokenInfo = void 0;
-    scanner2.setText(void 0);
-    return res;
-    function advance() {
-      lastTokenInfo = void 0;
-      const isStarted = scanner2.getTokenFullStart() !== startPos;
-      if (isStarted) {
-        wasNewLine = !!trailingTrivia && last(trailingTrivia).kind === 4 /* NewLineTrivia */;
-      } else {
-        scanner2.scan();
-      }
-      leadingTrivia = void 0;
-      trailingTrivia = void 0;
-      let pos = scanner2.getTokenFullStart();
-      while (pos < endPos) {
-        const t = scanner2.getToken();
-        if (!isTrivia(t)) {
-          break;
-        }
-        scanner2.scan();
-        const item = {
-          pos,
-          end: scanner2.getTokenFullStart(),
-          kind: t
-        };
-        pos = scanner2.getTokenFullStart();
-        leadingTrivia = append(leadingTrivia, item);
-      }
-      savedPos = scanner2.getTokenFullStart();
-    }
-    function shouldRescanGreaterThanToken(node) {
-      switch (node.kind) {
-        case 34 /* GreaterThanEqualsToken */:
-        case 72 /* GreaterThanGreaterThanEqualsToken */:
-        case 73 /* GreaterThanGreaterThanGreaterThanEqualsToken */:
-        case 50 /* GreaterThanGreaterThanGreaterThanToken */:
-        case 49 /* GreaterThanGreaterThanToken */:
-          return true;
-      }
-      return false;
-    }
-    function shouldRescanJsxIdentifier(node) {
-      if (node.parent) {
-        switch (node.parent.kind) {
-          case 290 /* JsxAttribute */:
-          case 285 /* JsxOpeningElement */:
-          case 286 /* JsxClosingElement */:
-          case 284 /* JsxSelfClosingElement */:
-            return isKeyword(node.kind) || node.kind === 80 /* Identifier */;
-        }
-      }
-      return false;
-    }
-    function shouldRescanJsxText(node) {
-      return isJsxText(node) || isJsxElement(node) && (lastTokenInfo == null ? void 0 : lastTokenInfo.token.kind) === 12 /* JsxText */;
-    }
-    function shouldRescanSlashToken(container) {
-      return container.kind === 14 /* RegularExpressionLiteral */;
-    }
-    function shouldRescanTemplateToken(container) {
-      return container.kind === 17 /* TemplateMiddle */ || container.kind === 18 /* TemplateTail */;
-    }
-    function shouldRescanJsxAttributeValue(node) {
-      return node.parent && isJsxAttribute(node.parent) && node.parent.initializer === node;
-    }
-    function startsWithSlashToken(t) {
-      return t === 44 /* SlashToken */ || t === 69 /* SlashEqualsToken */;
-    }
-    function readTokenInfo(n) {
-      Debug.assert(isOnToken());
-      const expectedScanAction = shouldRescanGreaterThanToken(n) ? 1 /* RescanGreaterThanToken */ : shouldRescanSlashToken(n) ? 2 /* RescanSlashToken */ : shouldRescanTemplateToken(n) ? 3 /* RescanTemplateToken */ : shouldRescanJsxIdentifier(n) ? 4 /* RescanJsxIdentifier */ : shouldRescanJsxText(n) ? 5 /* RescanJsxText */ : shouldRescanJsxAttributeValue(n) ? 6 /* RescanJsxAttributeValue */ : 0 /* Scan */;
-      if (lastTokenInfo && expectedScanAction === lastScanAction) {
-        return fixTokenKind(lastTokenInfo, n);
-      }
-      if (scanner2.getTokenFullStart() !== savedPos) {
-        Debug.assert(lastTokenInfo !== void 0);
-        scanner2.resetTokenState(savedPos);
-        scanner2.scan();
-      }
-      let currentToken = getNextToken(n, expectedScanAction);
-      const token = createTextRangeWithKind(
-        scanner2.getTokenFullStart(),
-        scanner2.getTokenEnd(),
-        currentToken
-      );
-      if (trailingTrivia) {
-        trailingTrivia = void 0;
-      }
-      while (scanner2.getTokenFullStart() < endPos) {
-        currentToken = scanner2.scan();
-        if (!isTrivia(currentToken)) {
-          break;
-        }
-        const trivia = createTextRangeWithKind(
-          scanner2.getTokenFullStart(),
-          scanner2.getTokenEnd(),
-          currentToken
-        );
-        if (!trailingTrivia) {
-          trailingTrivia = [];
-        }
-        trailingTrivia.push(trivia);
-        if (currentToken === 4 /* NewLineTrivia */) {
-          scanner2.scan();
-          break;
-        }
-      }
-      lastTokenInfo = { leadingTrivia, trailingTrivia, token };
-      return fixTokenKind(lastTokenInfo, n);
-    }
-    function getNextToken(n, expectedScanAction) {
-      const token = scanner2.getToken();
-      lastScanAction = 0 /* Scan */;
-      switch (expectedScanAction) {
-        case 1 /* RescanGreaterThanToken */:
-          if (token === 32 /* GreaterThanToken */) {
-            lastScanAction = 1 /* RescanGreaterThanToken */;
-            const newToken = scanner2.reScanGreaterToken();
-            Debug.assert(n.kind === newToken);
-            return newToken;
-          }
-          break;
-        case 2 /* RescanSlashToken */:
-          if (startsWithSlashToken(token)) {
-            lastScanAction = 2 /* RescanSlashToken */;
-            const newToken = scanner2.reScanSlashToken();
-            Debug.assert(n.kind === newToken);
-            return newToken;
-          }
-          break;
-        case 3 /* RescanTemplateToken */:
-          if (token === 20 /* CloseBraceToken */) {
-            lastScanAction = 3 /* RescanTemplateToken */;
-            return scanner2.reScanTemplateToken(
-              /*isTaggedTemplate*/
-              false
-            );
-          }
-          break;
-        case 4 /* RescanJsxIdentifier */:
-          lastScanAction = 4 /* RescanJsxIdentifier */;
-          return scanner2.scanJsxIdentifier();
-        case 5 /* RescanJsxText */:
-          lastScanAction = 5 /* RescanJsxText */;
-          return scanner2.reScanJsxToken(
-            /*allowMultilineJsxText*/
-            false
-          );
-        case 6 /* RescanJsxAttributeValue */:
-          lastScanAction = 6 /* RescanJsxAttributeValue */;
-          return scanner2.reScanJsxAttributeValue();
-        case 0 /* Scan */:
-          break;
-        default:
-          Debug.assertNever(expectedScanAction);
-      }
-      return token;
-    }
-    function readEOFTokenRange() {
-      Debug.assert(isOnEOF());
-      return createTextRangeWithKind(scanner2.getTokenFullStart(), scanner2.getTokenEnd(), 1 /* EndOfFileToken */);
-    }
-    function isOnToken() {
-      const current = lastTokenInfo ? lastTokenInfo.token.kind : scanner2.getToken();
-      return current !== 1 /* EndOfFileToken */ && !isTrivia(current);
-    }
-    function isOnEOF() {
-      const current = lastTokenInfo ? lastTokenInfo.token.kind : scanner2.getToken();
-      return current === 1 /* EndOfFileToken */;
-    }
-    function fixTokenKind(tokenInfo, container) {
-      if (isToken(container) && tokenInfo.token.kind !== container.kind) {
-        tokenInfo.token.kind = container.kind;
-      }
-      return tokenInfo;
-    }
-    function skipToEndOf(node) {
-      scanner2.resetTokenState(node.end);
-      savedPos = scanner2.getTokenFullStart();
-      lastScanAction = void 0;
-      lastTokenInfo = void 0;
-      wasNewLine = false;
-      leadingTrivia = void 0;
-      trailingTrivia = void 0;
-    }
-    function skipToStartOf(node) {
-      scanner2.resetTokenState(node.pos);
-      savedPos = scanner2.getTokenFullStart();
-      lastScanAction = void 0;
-      lastTokenInfo = void 0;
-      wasNewLine = false;
-      leadingTrivia = void 0;
-      trailingTrivia = void 0;
-    }
-  }
-  var standardScanner, jsxScanner;
-  var init_formattingScanner = __esm({
-    "src/services/formatting/formattingScanner.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_formatting();
-      standardScanner = createScanner(
-        99 /* Latest */,
-        /*skipTrivia*/
-        false,
-        0 /* Standard */
-      );
-      jsxScanner = createScanner(
-        99 /* Latest */,
-        /*skipTrivia*/
-        false,
-        1 /* JSX */
-      );
-    }
-  });
-
-  // src/services/formatting/rule.ts
-  var anyContext, RuleAction, RuleFlags;
-  var init_rule = __esm({
-    "src/services/formatting/rule.ts"() {
-      "use strict";
-      init_ts4();
-      anyContext = emptyArray;
-      RuleAction = /* @__PURE__ */ ((RuleAction2) => {
-        RuleAction2[RuleAction2["None"] = 0] = "None";
-        RuleAction2[RuleAction2["StopProcessingSpaceActions"] = 1] = "StopProcessingSpaceActions";
-        RuleAction2[RuleAction2["StopProcessingTokenActions"] = 2] = "StopProcessingTokenActions";
-        RuleAction2[RuleAction2["InsertSpace"] = 4] = "InsertSpace";
-        RuleAction2[RuleAction2["InsertNewLine"] = 8] = "InsertNewLine";
-        RuleAction2[RuleAction2["DeleteSpace"] = 16] = "DeleteSpace";
-        RuleAction2[RuleAction2["DeleteToken"] = 32] = "DeleteToken";
-        RuleAction2[RuleAction2["InsertTrailingSemicolon"] = 64] = "InsertTrailingSemicolon";
-        RuleAction2[RuleAction2["StopAction"] = 3] = "StopAction";
-        RuleAction2[RuleAction2["ModifySpaceAction"] = 28] = "ModifySpaceAction";
-        RuleAction2[RuleAction2["ModifyTokenAction"] = 96] = "ModifyTokenAction";
-        return RuleAction2;
-      })(RuleAction || {});
-      RuleFlags = /* @__PURE__ */ ((RuleFlags2) => {
-        RuleFlags2[RuleFlags2["None"] = 0] = "None";
-        RuleFlags2[RuleFlags2["CanDeleteNewLines"] = 1] = "CanDeleteNewLines";
-        return RuleFlags2;
-      })(RuleFlags || {});
-    }
-  });
-
-  // src/services/formatting/rules.ts
-  function getAllRules() {
-    const allTokens = [];
-    for (let token = 0 /* FirstToken */; token <= 164 /* LastToken */; token++) {
-      if (token !== 1 /* EndOfFileToken */) {
-        allTokens.push(token);
-      }
-    }
-    function anyTokenExcept(...tokens) {
-      return { tokens: allTokens.filter((t) => !tokens.some((t2) => t2 === t)), isSpecific: false };
-    }
-    const anyToken = { tokens: allTokens, isSpecific: false };
-    const anyTokenIncludingMultilineComments = tokenRangeFrom([...allTokens, 3 /* MultiLineCommentTrivia */]);
-    const anyTokenIncludingEOF = tokenRangeFrom([...allTokens, 1 /* EndOfFileToken */]);
-    const keywords = tokenRangeFromRange(83 /* FirstKeyword */, 164 /* LastKeyword */);
-    const binaryOperators = tokenRangeFromRange(30 /* FirstBinaryOperator */, 79 /* LastBinaryOperator */);
-    const binaryKeywordOperators = [
-      103 /* InKeyword */,
-      104 /* InstanceOfKeyword */,
-      164 /* OfKeyword */,
-      130 /* AsKeyword */,
-      142 /* IsKeyword */,
-      152 /* SatisfiesKeyword */
-    ];
-    const unaryPrefixOperators = [46 /* PlusPlusToken */, 47 /* MinusMinusToken */, 55 /* TildeToken */, 54 /* ExclamationToken */];
-    const unaryPrefixExpressions = [
-      9 /* NumericLiteral */,
-      10 /* BigIntLiteral */,
-      80 /* Identifier */,
-      21 /* OpenParenToken */,
-      23 /* OpenBracketToken */,
-      19 /* OpenBraceToken */,
-      110 /* ThisKeyword */,
-      105 /* NewKeyword */
-    ];
-    const unaryPreincrementExpressions = [80 /* Identifier */, 21 /* OpenParenToken */, 110 /* ThisKeyword */, 105 /* NewKeyword */];
-    const unaryPostincrementExpressions = [80 /* Identifier */, 22 /* CloseParenToken */, 24 /* CloseBracketToken */, 105 /* NewKeyword */];
-    const unaryPredecrementExpressions = [80 /* Identifier */, 21 /* OpenParenToken */, 110 /* ThisKeyword */, 105 /* NewKeyword */];
-    const unaryPostdecrementExpressions = [80 /* Identifier */, 22 /* CloseParenToken */, 24 /* CloseBracketToken */, 105 /* NewKeyword */];
-    const comments = [2 /* SingleLineCommentTrivia */, 3 /* MultiLineCommentTrivia */];
-    const typeNames = [80 /* Identifier */, ...typeKeywords];
-    const functionOpenBraceLeftTokenRange = anyTokenIncludingMultilineComments;
-    const typeScriptOpenBraceLeftTokenRange = tokenRangeFrom([80 /* Identifier */, 3 /* MultiLineCommentTrivia */, 86 /* ClassKeyword */, 95 /* ExportKeyword */, 102 /* ImportKeyword */]);
-    const controlOpenBraceLeftTokenRange = tokenRangeFrom([22 /* CloseParenToken */, 3 /* MultiLineCommentTrivia */, 92 /* DoKeyword */, 113 /* TryKeyword */, 98 /* FinallyKeyword */, 93 /* ElseKeyword */]);
-    const highPriorityCommonRules = [
-      // Leave comments alone
-      rule("IgnoreBeforeComment", anyToken, comments, anyContext, 1 /* StopProcessingSpaceActions */),
-      rule("IgnoreAfterLineComment", 2 /* SingleLineCommentTrivia */, anyToken, anyContext, 1 /* StopProcessingSpaceActions */),
-      rule("NotSpaceBeforeColon", anyToken, 59 /* ColonToken */, [isNonJsxSameLineTokenContext, isNotBinaryOpContext, isNotTypeAnnotationContext], 16 /* DeleteSpace */),
-      rule("SpaceAfterColon", 59 /* ColonToken */, anyToken, [isNonJsxSameLineTokenContext, isNotBinaryOpContext], 4 /* InsertSpace */),
-      rule("NoSpaceBeforeQuestionMark", anyToken, 58 /* QuestionToken */, [isNonJsxSameLineTokenContext, isNotBinaryOpContext, isNotTypeAnnotationContext], 16 /* DeleteSpace */),
-      // insert space after '?' only when it is used in conditional operator
-      rule("SpaceAfterQuestionMarkInConditionalOperator", 58 /* QuestionToken */, anyToken, [isNonJsxSameLineTokenContext, isConditionalOperatorContext], 4 /* InsertSpace */),
-      // in other cases there should be no space between '?' and next token
-      rule("NoSpaceAfterQuestionMark", 58 /* QuestionToken */, anyToken, [isNonJsxSameLineTokenContext], 16 /* DeleteSpace */),
-      rule("NoSpaceBeforeDot", anyToken, [25 /* DotToken */, 29 /* QuestionDotToken */], [isNonJsxSameLineTokenContext, isNotPropertyAccessOnIntegerLiteral], 16 /* DeleteSpace */),
-      rule("NoSpaceAfterDot", [25 /* DotToken */, 29 /* QuestionDotToken */], anyToken, [isNonJsxSameLineTokenContext], 16 /* DeleteSpace */),
-      rule("NoSpaceBetweenImportParenInImportType", 102 /* ImportKeyword */, 21 /* OpenParenToken */, [isNonJsxSameLineTokenContext, isImportTypeContext], 16 /* DeleteSpace */),
-      // Special handling of unary operators.
-      // Prefix operators generally shouldn't have a space between
-      // them and their target unary expression.
-      rule("NoSpaceAfterUnaryPrefixOperator", unaryPrefixOperators, unaryPrefixExpressions, [isNonJsxSameLineTokenContext, isNotBinaryOpContext], 16 /* DeleteSpace */),
-      rule("NoSpaceAfterUnaryPreincrementOperator", 46 /* PlusPlusToken */, unaryPreincrementExpressions, [isNonJsxSameLineTokenContext], 16 /* DeleteSpace */),
-      rule("NoSpaceAfterUnaryPredecrementOperator", 47 /* MinusMinusToken */, unaryPredecrementExpressions, [isNonJsxSameLineTokenContext], 16 /* DeleteSpace */),
-      rule("NoSpaceBeforeUnaryPostincrementOperator", unaryPostincrementExpressions, 46 /* PlusPlusToken */, [isNonJsxSameLineTokenContext, isNotStatementConditionContext], 16 /* DeleteSpace */),
-      rule("NoSpaceBeforeUnaryPostdecrementOperator", unaryPostdecrementExpressions, 47 /* MinusMinusToken */, [isNonJsxSameLineTokenContext, isNotStatementConditionContext], 16 /* DeleteSpace */),
-      // More unary operator special-casing.
-      // DevDiv 181814: Be careful when removing leading whitespace
-      // around unary operators.  Examples:
-      //      1 - -2  --X--> 1--2
-      //      a + ++b --X--> a+++b
-      rule("SpaceAfterPostincrementWhenFollowedByAdd", 46 /* PlusPlusToken */, 40 /* PlusToken */, [isNonJsxSameLineTokenContext, isBinaryOpContext], 4 /* InsertSpace */),
-      rule("SpaceAfterAddWhenFollowedByUnaryPlus", 40 /* PlusToken */, 40 /* PlusToken */, [isNonJsxSameLineTokenContext, isBinaryOpContext], 4 /* InsertSpace */),
-      rule("SpaceAfterAddWhenFollowedByPreincrement", 40 /* PlusToken */, 46 /* PlusPlusToken */, [isNonJsxSameLineTokenContext, isBinaryOpContext], 4 /* InsertSpace */),
-      rule("SpaceAfterPostdecrementWhenFollowedBySubtract", 47 /* MinusMinusToken */, 41 /* MinusToken */, [isNonJsxSameLineTokenContext, isBinaryOpContext], 4 /* InsertSpace */),
-      rule("SpaceAfterSubtractWhenFollowedByUnaryMinus", 41 /* MinusToken */, 41 /* MinusToken */, [isNonJsxSameLineTokenContext, isBinaryOpContext], 4 /* InsertSpace */),
-      rule("SpaceAfterSubtractWhenFollowedByPredecrement", 41 /* MinusToken */, 47 /* MinusMinusToken */, [isNonJsxSameLineTokenContext, isBinaryOpContext], 4 /* InsertSpace */),
-      rule("NoSpaceAfterCloseBrace", 20 /* CloseBraceToken */, [28 /* CommaToken */, 27 /* SemicolonToken */], [isNonJsxSameLineTokenContext], 16 /* DeleteSpace */),
-      // For functions and control block place } on a new line [multi-line rule]
-      rule("NewLineBeforeCloseBraceInBlockContext", anyTokenIncludingMultilineComments, 20 /* CloseBraceToken */, [isMultilineBlockContext], 8 /* InsertNewLine */),
-      // Space/new line after }.
-      rule("SpaceAfterCloseBrace", 20 /* CloseBraceToken */, anyTokenExcept(22 /* CloseParenToken */), [isNonJsxSameLineTokenContext, isAfterCodeBlockContext], 4 /* InsertSpace */),
-      // Special case for (}, else) and (}, while) since else & while tokens are not part of the tree which makes SpaceAfterCloseBrace rule not applied
-      // Also should not apply to })
-      rule("SpaceBetweenCloseBraceAndElse", 20 /* CloseBraceToken */, 93 /* ElseKeyword */, [isNonJsxSameLineTokenContext], 4 /* InsertSpace */),
-      rule("SpaceBetweenCloseBraceAndWhile", 20 /* CloseBraceToken */, 117 /* WhileKeyword */, [isNonJsxSameLineTokenContext], 4 /* InsertSpace */),
-      rule("NoSpaceBetweenEmptyBraceBrackets", 19 /* OpenBraceToken */, 20 /* CloseBraceToken */, [isNonJsxSameLineTokenContext, isObjectContext], 16 /* DeleteSpace */),
-      // Add a space after control dec context if the next character is an open bracket ex: 'if (false)[a, b] = [1, 2];' -> 'if (false) [a, b] = [1, 2];'
-      rule("SpaceAfterConditionalClosingParen", 22 /* CloseParenToken */, 23 /* OpenBracketToken */, [isControlDeclContext], 4 /* InsertSpace */),
-      rule("NoSpaceBetweenFunctionKeywordAndStar", 100 /* FunctionKeyword */, 42 /* AsteriskToken */, [isFunctionDeclarationOrFunctionExpressionContext], 16 /* DeleteSpace */),
-      rule("SpaceAfterStarInGeneratorDeclaration", 42 /* AsteriskToken */, 80 /* Identifier */, [isFunctionDeclarationOrFunctionExpressionContext], 4 /* InsertSpace */),
-      rule("SpaceAfterFunctionInFuncDecl", 100 /* FunctionKeyword */, anyToken, [isFunctionDeclContext], 4 /* InsertSpace */),
-      // Insert new line after { and before } in multi-line contexts.
-      rule("NewLineAfterOpenBraceInBlockContext", 19 /* OpenBraceToken */, anyToken, [isMultilineBlockContext], 8 /* InsertNewLine */),
-      // For get/set members, we check for (identifier,identifier) since get/set don't have tokens and they are represented as just an identifier token.
-      // Though, we do extra check on the context to make sure we are dealing with get/set node. Example:
-      //      get x() {}
-      //      set x(val) {}
-      rule("SpaceAfterGetSetInMember", [139 /* GetKeyword */, 153 /* SetKeyword */], 80 /* Identifier */, [isFunctionDeclContext], 4 /* InsertSpace */),
-      rule("NoSpaceBetweenYieldKeywordAndStar", 127 /* YieldKeyword */, 42 /* AsteriskToken */, [isNonJsxSameLineTokenContext, isYieldOrYieldStarWithOperand], 16 /* DeleteSpace */),
-      rule("SpaceBetweenYieldOrYieldStarAndOperand", [127 /* YieldKeyword */, 42 /* AsteriskToken */], anyToken, [isNonJsxSameLineTokenContext, isYieldOrYieldStarWithOperand], 4 /* InsertSpace */),
-      rule("NoSpaceBetweenReturnAndSemicolon", 107 /* ReturnKeyword */, 27 /* SemicolonToken */, [isNonJsxSameLineTokenContext], 16 /* DeleteSpace */),
-      rule("SpaceAfterCertainKeywords", [115 /* VarKeyword */, 111 /* ThrowKeyword */, 105 /* NewKeyword */, 91 /* DeleteKeyword */, 107 /* ReturnKeyword */, 114 /* TypeOfKeyword */, 135 /* AwaitKeyword */], anyToken, [isNonJsxSameLineTokenContext], 4 /* InsertSpace */),
-      rule("SpaceAfterLetConstInVariableDeclaration", [121 /* LetKeyword */, 87 /* ConstKeyword */], anyToken, [isNonJsxSameLineTokenContext, isStartOfVariableDeclarationList], 4 /* InsertSpace */),
-      rule("NoSpaceBeforeOpenParenInFuncCall", anyToken, 21 /* OpenParenToken */, [isNonJsxSameLineTokenContext, isFunctionCallOrNewContext, isPreviousTokenNotComma], 16 /* DeleteSpace */),
-      // Special case for binary operators (that are keywords). For these we have to add a space and shouldn't follow any user options.
-      rule("SpaceBeforeBinaryKeywordOperator", anyToken, binaryKeywordOperators, [isNonJsxSameLineTokenContext, isBinaryOpContext], 4 /* InsertSpace */),
-      rule("SpaceAfterBinaryKeywordOperator", binaryKeywordOperators, anyToken, [isNonJsxSameLineTokenContext, isBinaryOpContext], 4 /* InsertSpace */),
-      rule("SpaceAfterVoidOperator", 116 /* VoidKeyword */, anyToken, [isNonJsxSameLineTokenContext, isVoidOpContext], 4 /* InsertSpace */),
-      // Async-await
-      rule("SpaceBetweenAsyncAndOpenParen", 134 /* AsyncKeyword */, 21 /* OpenParenToken */, [isArrowFunctionContext, isNonJsxSameLineTokenContext], 4 /* InsertSpace */),
-      rule("SpaceBetweenAsyncAndFunctionKeyword", 134 /* AsyncKeyword */, [100 /* FunctionKeyword */, 80 /* Identifier */], [isNonJsxSameLineTokenContext], 4 /* InsertSpace */),
-      // Template string
-      rule("NoSpaceBetweenTagAndTemplateString", [80 /* Identifier */, 22 /* CloseParenToken */], [15 /* NoSubstitutionTemplateLiteral */, 16 /* TemplateHead */], [isNonJsxSameLineTokenContext], 16 /* DeleteSpace */),
-      // JSX opening elements
-      rule("SpaceBeforeJsxAttribute", anyToken, 80 /* Identifier */, [isNextTokenParentJsxAttribute, isNonJsxSameLineTokenContext], 4 /* InsertSpace */),
-      rule("SpaceBeforeSlashInJsxOpeningElement", anyToken, 44 /* SlashToken */, [isJsxSelfClosingElementContext, isNonJsxSameLineTokenContext], 4 /* InsertSpace */),
-      rule("NoSpaceBeforeGreaterThanTokenInJsxOpeningElement", 44 /* SlashToken */, 32 /* GreaterThanToken */, [isJsxSelfClosingElementContext, isNonJsxSameLineTokenContext], 16 /* DeleteSpace */),
-      rule("NoSpaceBeforeEqualInJsxAttribute", anyToken, 64 /* EqualsToken */, [isJsxAttributeContext, isNonJsxSameLineTokenContext], 16 /* DeleteSpace */),
-      rule("NoSpaceAfterEqualInJsxAttribute", 64 /* EqualsToken */, anyToken, [isJsxAttributeContext, isNonJsxSameLineTokenContext], 16 /* DeleteSpace */),
-      // TypeScript-specific rules
-      // Use of module as a function call. e.g.: import m2 = module("m2");
-      rule("NoSpaceAfterModuleImport", [144 /* ModuleKeyword */, 149 /* RequireKeyword */], 21 /* OpenParenToken */, [isNonJsxSameLineTokenContext], 16 /* DeleteSpace */),
-      // Add a space around certain TypeScript keywords
-      rule(
-        "SpaceAfterCertainTypeScriptKeywords",
-        [
-          128 /* AbstractKeyword */,
-          129 /* AccessorKeyword */,
-          86 /* ClassKeyword */,
-          138 /* DeclareKeyword */,
-          90 /* DefaultKeyword */,
-          94 /* EnumKeyword */,
-          95 /* ExportKeyword */,
-          96 /* ExtendsKeyword */,
-          139 /* GetKeyword */,
-          119 /* ImplementsKeyword */,
-          102 /* ImportKeyword */,
-          120 /* InterfaceKeyword */,
-          144 /* ModuleKeyword */,
-          145 /* NamespaceKeyword */,
-          123 /* PrivateKeyword */,
-          125 /* PublicKeyword */,
-          124 /* ProtectedKeyword */,
-          148 /* ReadonlyKeyword */,
-          153 /* SetKeyword */,
-          126 /* StaticKeyword */,
-          156 /* TypeKeyword */,
-          160 /* FromKeyword */,
-          143 /* KeyOfKeyword */,
-          140 /* InferKeyword */
-        ],
-        anyToken,
-        [isNonJsxSameLineTokenContext],
-        4 /* InsertSpace */
-      ),
-      rule(
-        "SpaceBeforeCertainTypeScriptKeywords",
-        anyToken,
-        [96 /* ExtendsKeyword */, 119 /* ImplementsKeyword */, 160 /* FromKeyword */],
-        [isNonJsxSameLineTokenContext],
-        4 /* InsertSpace */
-      ),
-      // Treat string literals in module names as identifiers, and add a space between the literal and the opening Brace braces, e.g.: module "m2" {
-      rule("SpaceAfterModuleName", 11 /* StringLiteral */, 19 /* OpenBraceToken */, [isModuleDeclContext], 4 /* InsertSpace */),
-      // Lambda expressions
-      rule("SpaceBeforeArrow", anyToken, 39 /* EqualsGreaterThanToken */, [isNonJsxSameLineTokenContext], 4 /* InsertSpace */),
-      rule("SpaceAfterArrow", 39 /* EqualsGreaterThanToken */, anyToken, [isNonJsxSameLineTokenContext], 4 /* InsertSpace */),
-      // Optional parameters and let args
-      rule("NoSpaceAfterEllipsis", 26 /* DotDotDotToken */, 80 /* Identifier */, [isNonJsxSameLineTokenContext], 16 /* DeleteSpace */),
-      rule("NoSpaceAfterOptionalParameters", 58 /* QuestionToken */, [22 /* CloseParenToken */, 28 /* CommaToken */], [isNonJsxSameLineTokenContext, isNotBinaryOpContext], 16 /* DeleteSpace */),
-      // Remove spaces in empty interface literals. e.g.: x: {}
-      rule("NoSpaceBetweenEmptyInterfaceBraceBrackets", 19 /* OpenBraceToken */, 20 /* CloseBraceToken */, [isNonJsxSameLineTokenContext, isObjectTypeContext], 16 /* DeleteSpace */),
-      // generics and type assertions
-      rule("NoSpaceBeforeOpenAngularBracket", typeNames, 30 /* LessThanToken */, [isNonJsxSameLineTokenContext, isTypeArgumentOrParameterOrAssertionContext], 16 /* DeleteSpace */),
-      rule("NoSpaceBetweenCloseParenAndAngularBracket", 22 /* CloseParenToken */, 30 /* LessThanToken */, [isNonJsxSameLineTokenContext, isTypeArgumentOrParameterOrAssertionContext], 16 /* DeleteSpace */),
-      rule("NoSpaceAfterOpenAngularBracket", 30 /* LessThanToken */, anyToken, [isNonJsxSameLineTokenContext, isTypeArgumentOrParameterOrAssertionContext], 16 /* DeleteSpace */),
-      rule("NoSpaceBeforeCloseAngularBracket", anyToken, 32 /* GreaterThanToken */, [isNonJsxSameLineTokenContext, isTypeArgumentOrParameterOrAssertionContext], 16 /* DeleteSpace */),
-      rule("NoSpaceAfterCloseAngularBracket", 32 /* GreaterThanToken */, [21 /* OpenParenToken */, 23 /* OpenBracketToken */, 32 /* GreaterThanToken */, 28 /* CommaToken */], [
-        isNonJsxSameLineTokenContext,
-        isTypeArgumentOrParameterOrAssertionContext,
-        isNotFunctionDeclContext,
-        isNonTypeAssertionContext
-      ], 16 /* DeleteSpace */),
-      // decorators
-      rule("SpaceBeforeAt", [22 /* CloseParenToken */, 80 /* Identifier */], 60 /* AtToken */, [isNonJsxSameLineTokenContext], 4 /* InsertSpace */),
-      rule("NoSpaceAfterAt", 60 /* AtToken */, anyToken, [isNonJsxSameLineTokenContext], 16 /* DeleteSpace */),
-      // Insert space after @ in decorator
-      rule(
-        "SpaceAfterDecorator",
-        anyToken,
-        [
-          128 /* AbstractKeyword */,
-          80 /* Identifier */,
-          95 /* ExportKeyword */,
-          90 /* DefaultKeyword */,
-          86 /* ClassKeyword */,
-          126 /* StaticKeyword */,
-          125 /* PublicKeyword */,
-          123 /* PrivateKeyword */,
-          124 /* ProtectedKeyword */,
-          139 /* GetKeyword */,
-          153 /* SetKeyword */,
-          23 /* OpenBracketToken */,
-          42 /* AsteriskToken */
-        ],
-        [isEndOfDecoratorContextOnSameLine],
-        4 /* InsertSpace */
-      ),
-      rule("NoSpaceBeforeNonNullAssertionOperator", anyToken, 54 /* ExclamationToken */, [isNonJsxSameLineTokenContext, isNonNullAssertionContext], 16 /* DeleteSpace */),
-      rule("NoSpaceAfterNewKeywordOnConstructorSignature", 105 /* NewKeyword */, 21 /* OpenParenToken */, [isNonJsxSameLineTokenContext, isConstructorSignatureContext], 16 /* DeleteSpace */),
-      rule("SpaceLessThanAndNonJSXTypeAnnotation", 30 /* LessThanToken */, 30 /* LessThanToken */, [isNonJsxSameLineTokenContext], 4 /* InsertSpace */)
-    ];
-    const userConfigurableRules = [
-      // Treat constructor as an identifier in a function declaration, and remove spaces between constructor and following left parentheses
-      rule("SpaceAfterConstructor", 137 /* ConstructorKeyword */, 21 /* OpenParenToken */, [isOptionEnabled("insertSpaceAfterConstructor"), isNonJsxSameLineTokenContext], 4 /* InsertSpace */),
-      rule("NoSpaceAfterConstructor", 137 /* ConstructorKeyword */, 21 /* OpenParenToken */, [isOptionDisabledOrUndefined("insertSpaceAfterConstructor"), isNonJsxSameLineTokenContext], 16 /* DeleteSpace */),
-      rule("SpaceAfterComma", 28 /* CommaToken */, anyToken, [isOptionEnabled("insertSpaceAfterCommaDelimiter"), isNonJsxSameLineTokenContext, isNonJsxElementOrFragmentContext, isNextTokenNotCloseBracket, isNextTokenNotCloseParen], 4 /* InsertSpace */),
-      rule("NoSpaceAfterComma", 28 /* CommaToken */, anyToken, [isOptionDisabledOrUndefined("insertSpaceAfterCommaDelimiter"), isNonJsxSameLineTokenContext, isNonJsxElementOrFragmentContext], 16 /* DeleteSpace */),
-      // Insert space after function keyword for anonymous functions
-      rule("SpaceAfterAnonymousFunctionKeyword", [100 /* FunctionKeyword */, 42 /* AsteriskToken */], 21 /* OpenParenToken */, [isOptionEnabled("insertSpaceAfterFunctionKeywordForAnonymousFunctions"), isFunctionDeclContext], 4 /* InsertSpace */),
-      rule("NoSpaceAfterAnonymousFunctionKeyword", [100 /* FunctionKeyword */, 42 /* AsteriskToken */], 21 /* OpenParenToken */, [isOptionDisabledOrUndefined("insertSpaceAfterFunctionKeywordForAnonymousFunctions"), isFunctionDeclContext], 16 /* DeleteSpace */),
-      // Insert space after keywords in control flow statements
-      rule("SpaceAfterKeywordInControl", keywords, 21 /* OpenParenToken */, [isOptionEnabled("insertSpaceAfterKeywordsInControlFlowStatements"), isControlDeclContext], 4 /* InsertSpace */),
-      rule("NoSpaceAfterKeywordInControl", keywords, 21 /* OpenParenToken */, [isOptionDisabledOrUndefined("insertSpaceAfterKeywordsInControlFlowStatements"), isControlDeclContext], 16 /* DeleteSpace */),
-      // Insert space after opening and before closing nonempty parenthesis
-      rule("SpaceAfterOpenParen", 21 /* OpenParenToken */, anyToken, [isOptionEnabled("insertSpaceAfterOpeningAndBeforeClosingNonemptyParenthesis"), isNonJsxSameLineTokenContext], 4 /* InsertSpace */),
-      rule("SpaceBeforeCloseParen", anyToken, 22 /* CloseParenToken */, [isOptionEnabled("insertSpaceAfterOpeningAndBeforeClosingNonemptyParenthesis"), isNonJsxSameLineTokenContext], 4 /* InsertSpace */),
-      rule("SpaceBetweenOpenParens", 21 /* OpenParenToken */, 21 /* OpenParenToken */, [isOptionEnabled("insertSpaceAfterOpeningAndBeforeClosingNonemptyParenthesis"), isNonJsxSameLineTokenContext], 4 /* InsertSpace */),
-      rule("NoSpaceBetweenParens", 21 /* OpenParenToken */, 22 /* CloseParenToken */, [isNonJsxSameLineTokenContext], 16 /* DeleteSpace */),
-      rule("NoSpaceAfterOpenParen", 21 /* OpenParenToken */, anyToken, [isOptionDisabledOrUndefined("insertSpaceAfterOpeningAndBeforeClosingNonemptyParenthesis"), isNonJsxSameLineTokenContext], 16 /* DeleteSpace */),
-      rule("NoSpaceBeforeCloseParen", anyToken, 22 /* CloseParenToken */, [isOptionDisabledOrUndefined("insertSpaceAfterOpeningAndBeforeClosingNonemptyParenthesis"), isNonJsxSameLineTokenContext], 16 /* DeleteSpace */),
-      // Insert space after opening and before closing nonempty brackets
-      rule("SpaceAfterOpenBracket", 23 /* OpenBracketToken */, anyToken, [isOptionEnabled("insertSpaceAfterOpeningAndBeforeClosingNonemptyBrackets"), isNonJsxSameLineTokenContext], 4 /* InsertSpace */),
-      rule("SpaceBeforeCloseBracket", anyToken, 24 /* CloseBracketToken */, [isOptionEnabled("insertSpaceAfterOpeningAndBeforeClosingNonemptyBrackets"), isNonJsxSameLineTokenContext], 4 /* InsertSpace */),
-      rule("NoSpaceBetweenBrackets", 23 /* OpenBracketToken */, 24 /* CloseBracketToken */, [isNonJsxSameLineTokenContext], 16 /* DeleteSpace */),
-      rule("NoSpaceAfterOpenBracket", 23 /* OpenBracketToken */, anyToken, [isOptionDisabledOrUndefined("insertSpaceAfterOpeningAndBeforeClosingNonemptyBrackets"), isNonJsxSameLineTokenContext], 16 /* DeleteSpace */),
-      rule("NoSpaceBeforeCloseBracket", anyToken, 24 /* CloseBracketToken */, [isOptionDisabledOrUndefined("insertSpaceAfterOpeningAndBeforeClosingNonemptyBrackets"), isNonJsxSameLineTokenContext], 16 /* DeleteSpace */),
-      // Insert a space after { and before } in single-line contexts, but remove space from empty object literals {}.
-      rule("SpaceAfterOpenBrace", 19 /* OpenBraceToken */, anyToken, [isOptionEnabledOrUndefined("insertSpaceAfterOpeningAndBeforeClosingNonemptyBraces"), isBraceWrappedContext], 4 /* InsertSpace */),
-      rule("SpaceBeforeCloseBrace", anyToken, 20 /* CloseBraceToken */, [isOptionEnabledOrUndefined("insertSpaceAfterOpeningAndBeforeClosingNonemptyBraces"), isBraceWrappedContext], 4 /* InsertSpace */),
-      rule("NoSpaceBetweenEmptyBraceBrackets", 19 /* OpenBraceToken */, 20 /* CloseBraceToken */, [isNonJsxSameLineTokenContext, isObjectContext], 16 /* DeleteSpace */),
-      rule("NoSpaceAfterOpenBrace", 19 /* OpenBraceToken */, anyToken, [isOptionDisabled("insertSpaceAfterOpeningAndBeforeClosingNonemptyBraces"), isNonJsxSameLineTokenContext], 16 /* DeleteSpace */),
-      rule("NoSpaceBeforeCloseBrace", anyToken, 20 /* CloseBraceToken */, [isOptionDisabled("insertSpaceAfterOpeningAndBeforeClosingNonemptyBraces"), isNonJsxSameLineTokenContext], 16 /* DeleteSpace */),
-      // Insert a space after opening and before closing empty brace brackets
-      rule("SpaceBetweenEmptyBraceBrackets", 19 /* OpenBraceToken */, 20 /* CloseBraceToken */, [isOptionEnabled("insertSpaceAfterOpeningAndBeforeClosingEmptyBraces")], 4 /* InsertSpace */),
-      rule("NoSpaceBetweenEmptyBraceBrackets", 19 /* OpenBraceToken */, 20 /* CloseBraceToken */, [isOptionDisabled("insertSpaceAfterOpeningAndBeforeClosingEmptyBraces"), isNonJsxSameLineTokenContext], 16 /* DeleteSpace */),
-      // Insert space after opening and before closing template string braces
-      rule("SpaceAfterTemplateHeadAndMiddle", [16 /* TemplateHead */, 17 /* TemplateMiddle */], anyToken, [isOptionEnabled("insertSpaceAfterOpeningAndBeforeClosingTemplateStringBraces"), isNonJsxTextContext], 4 /* InsertSpace */, 1 /* CanDeleteNewLines */),
-      rule("SpaceBeforeTemplateMiddleAndTail", anyToken, [17 /* TemplateMiddle */, 18 /* TemplateTail */], [isOptionEnabled("insertSpaceAfterOpeningAndBeforeClosingTemplateStringBraces"), isNonJsxSameLineTokenContext], 4 /* InsertSpace */),
-      rule("NoSpaceAfterTemplateHeadAndMiddle", [16 /* TemplateHead */, 17 /* TemplateMiddle */], anyToken, [isOptionDisabledOrUndefined("insertSpaceAfterOpeningAndBeforeClosingTemplateStringBraces"), isNonJsxTextContext], 16 /* DeleteSpace */, 1 /* CanDeleteNewLines */),
-      rule("NoSpaceBeforeTemplateMiddleAndTail", anyToken, [17 /* TemplateMiddle */, 18 /* TemplateTail */], [isOptionDisabledOrUndefined("insertSpaceAfterOpeningAndBeforeClosingTemplateStringBraces"), isNonJsxSameLineTokenContext], 16 /* DeleteSpace */),
-      // No space after { and before } in JSX expression
-      rule("SpaceAfterOpenBraceInJsxExpression", 19 /* OpenBraceToken */, anyToken, [isOptionEnabled("insertSpaceAfterOpeningAndBeforeClosingJsxExpressionBraces"), isNonJsxSameLineTokenContext, isJsxExpressionContext], 4 /* InsertSpace */),
-      rule("SpaceBeforeCloseBraceInJsxExpression", anyToken, 20 /* CloseBraceToken */, [isOptionEnabled("insertSpaceAfterOpeningAndBeforeClosingJsxExpressionBraces"), isNonJsxSameLineTokenContext, isJsxExpressionContext], 4 /* InsertSpace */),
-      rule("NoSpaceAfterOpenBraceInJsxExpression", 19 /* OpenBraceToken */, anyToken, [isOptionDisabledOrUndefined("insertSpaceAfterOpeningAndBeforeClosingJsxExpressionBraces"), isNonJsxSameLineTokenContext, isJsxExpressionContext], 16 /* DeleteSpace */),
-      rule("NoSpaceBeforeCloseBraceInJsxExpression", anyToken, 20 /* CloseBraceToken */, [isOptionDisabledOrUndefined("insertSpaceAfterOpeningAndBeforeClosingJsxExpressionBraces"), isNonJsxSameLineTokenContext, isJsxExpressionContext], 16 /* DeleteSpace */),
-      // Insert space after semicolon in for statement
-      rule("SpaceAfterSemicolonInFor", 27 /* SemicolonToken */, anyToken, [isOptionEnabled("insertSpaceAfterSemicolonInForStatements"), isNonJsxSameLineTokenContext, isForContext], 4 /* InsertSpace */),
-      rule("NoSpaceAfterSemicolonInFor", 27 /* SemicolonToken */, anyToken, [isOptionDisabledOrUndefined("insertSpaceAfterSemicolonInForStatements"), isNonJsxSameLineTokenContext, isForContext], 16 /* DeleteSpace */),
-      // Insert space before and after binary operators
-      rule("SpaceBeforeBinaryOperator", anyToken, binaryOperators, [isOptionEnabled("insertSpaceBeforeAndAfterBinaryOperators"), isNonJsxSameLineTokenContext, isBinaryOpContext], 4 /* InsertSpace */),
-      rule("SpaceAfterBinaryOperator", binaryOperators, anyToken, [isOptionEnabled("insertSpaceBeforeAndAfterBinaryOperators"), isNonJsxSameLineTokenContext, isBinaryOpContext], 4 /* InsertSpace */),
-      rule("NoSpaceBeforeBinaryOperator", anyToken, binaryOperators, [isOptionDisabledOrUndefined("insertSpaceBeforeAndAfterBinaryOperators"), isNonJsxSameLineTokenContext, isBinaryOpContext], 16 /* DeleteSpace */),
-      rule("NoSpaceAfterBinaryOperator", binaryOperators, anyToken, [isOptionDisabledOrUndefined("insertSpaceBeforeAndAfterBinaryOperators"), isNonJsxSameLineTokenContext, isBinaryOpContext], 16 /* DeleteSpace */),
-      rule("SpaceBeforeOpenParenInFuncDecl", anyToken, 21 /* OpenParenToken */, [isOptionEnabled("insertSpaceBeforeFunctionParenthesis"), isNonJsxSameLineTokenContext, isFunctionDeclContext], 4 /* InsertSpace */),
-      rule("NoSpaceBeforeOpenParenInFuncDecl", anyToken, 21 /* OpenParenToken */, [isOptionDisabledOrUndefined("insertSpaceBeforeFunctionParenthesis"), isNonJsxSameLineTokenContext, isFunctionDeclContext], 16 /* DeleteSpace */),
-      // Open Brace braces after control block
-      rule("NewLineBeforeOpenBraceInControl", controlOpenBraceLeftTokenRange, 19 /* OpenBraceToken */, [isOptionEnabled("placeOpenBraceOnNewLineForControlBlocks"), isControlDeclContext, isBeforeMultilineBlockContext], 8 /* InsertNewLine */, 1 /* CanDeleteNewLines */),
-      // Open Brace braces after function
-      // TypeScript: Function can have return types, which can be made of tons of different token kinds
-      rule("NewLineBeforeOpenBraceInFunction", functionOpenBraceLeftTokenRange, 19 /* OpenBraceToken */, [isOptionEnabled("placeOpenBraceOnNewLineForFunctions"), isFunctionDeclContext, isBeforeMultilineBlockContext], 8 /* InsertNewLine */, 1 /* CanDeleteNewLines */),
-      // Open Brace braces after TypeScript module/class/interface
-      rule("NewLineBeforeOpenBraceInTypeScriptDeclWithBlock", typeScriptOpenBraceLeftTokenRange, 19 /* OpenBraceToken */, [isOptionEnabled("placeOpenBraceOnNewLineForFunctions"), isTypeScriptDeclWithBlockContext, isBeforeMultilineBlockContext], 8 /* InsertNewLine */, 1 /* CanDeleteNewLines */),
-      rule("SpaceAfterTypeAssertion", 32 /* GreaterThanToken */, anyToken, [isOptionEnabled("insertSpaceAfterTypeAssertion"), isNonJsxSameLineTokenContext, isTypeAssertionContext], 4 /* InsertSpace */),
-      rule("NoSpaceAfterTypeAssertion", 32 /* GreaterThanToken */, anyToken, [isOptionDisabledOrUndefined("insertSpaceAfterTypeAssertion"), isNonJsxSameLineTokenContext, isTypeAssertionContext], 16 /* DeleteSpace */),
-      rule("SpaceBeforeTypeAnnotation", anyToken, [58 /* QuestionToken */, 59 /* ColonToken */], [isOptionEnabled("insertSpaceBeforeTypeAnnotation"), isNonJsxSameLineTokenContext, isTypeAnnotationContext], 4 /* InsertSpace */),
-      rule("NoSpaceBeforeTypeAnnotation", anyToken, [58 /* QuestionToken */, 59 /* ColonToken */], [isOptionDisabledOrUndefined("insertSpaceBeforeTypeAnnotation"), isNonJsxSameLineTokenContext, isTypeAnnotationContext], 16 /* DeleteSpace */),
-      rule("NoOptionalSemicolon", 27 /* SemicolonToken */, anyTokenIncludingEOF, [optionEquals("semicolons", "remove" /* Remove */), isSemicolonDeletionContext], 32 /* DeleteToken */),
-      rule("OptionalSemicolon", anyToken, anyTokenIncludingEOF, [optionEquals("semicolons", "insert" /* Insert */), isSemicolonInsertionContext], 64 /* InsertTrailingSemicolon */)
-    ];
-    const lowPriorityCommonRules = [
-      // Space after keyword but not before ; or : or ?
-      rule("NoSpaceBeforeSemicolon", anyToken, 27 /* SemicolonToken */, [isNonJsxSameLineTokenContext], 16 /* DeleteSpace */),
-      rule("SpaceBeforeOpenBraceInControl", controlOpenBraceLeftTokenRange, 19 /* OpenBraceToken */, [isOptionDisabledOrUndefinedOrTokensOnSameLine("placeOpenBraceOnNewLineForControlBlocks"), isControlDeclContext, isNotFormatOnEnter, isSameLineTokenOrBeforeBlockContext], 4 /* InsertSpace */, 1 /* CanDeleteNewLines */),
-      rule("SpaceBeforeOpenBraceInFunction", functionOpenBraceLeftTokenRange, 19 /* OpenBraceToken */, [isOptionDisabledOrUndefinedOrTokensOnSameLine("placeOpenBraceOnNewLineForFunctions"), isFunctionDeclContext, isBeforeBlockContext, isNotFormatOnEnter, isSameLineTokenOrBeforeBlockContext], 4 /* InsertSpace */, 1 /* CanDeleteNewLines */),
-      rule("SpaceBeforeOpenBraceInTypeScriptDeclWithBlock", typeScriptOpenBraceLeftTokenRange, 19 /* OpenBraceToken */, [isOptionDisabledOrUndefinedOrTokensOnSameLine("placeOpenBraceOnNewLineForFunctions"), isTypeScriptDeclWithBlockContext, isNotFormatOnEnter, isSameLineTokenOrBeforeBlockContext], 4 /* InsertSpace */, 1 /* CanDeleteNewLines */),
-      rule("NoSpaceBeforeComma", anyToken, 28 /* CommaToken */, [isNonJsxSameLineTokenContext], 16 /* DeleteSpace */),
-      // No space before and after indexer `x[]`
-      rule("NoSpaceBeforeOpenBracket", anyTokenExcept(134 /* AsyncKeyword */, 84 /* CaseKeyword */), 23 /* OpenBracketToken */, [isNonJsxSameLineTokenContext], 16 /* DeleteSpace */),
-      rule("NoSpaceAfterCloseBracket", 24 /* CloseBracketToken */, anyToken, [isNonJsxSameLineTokenContext, isNotBeforeBlockInFunctionDeclarationContext], 16 /* DeleteSpace */),
-      rule("SpaceAfterSemicolon", 27 /* SemicolonToken */, anyToken, [isNonJsxSameLineTokenContext], 4 /* InsertSpace */),
-      // Remove extra space between for and await
-      rule("SpaceBetweenForAndAwaitKeyword", 99 /* ForKeyword */, 135 /* AwaitKeyword */, [isNonJsxSameLineTokenContext], 4 /* InsertSpace */),
-      // Add a space between statements. All keywords except (do,else,case) has open/close parens after them.
-      // So, we have a rule to add a space for [),Any], [do,Any], [else,Any], and [case,Any]
-      rule(
-        "SpaceBetweenStatements",
-        [22 /* CloseParenToken */, 92 /* DoKeyword */, 93 /* ElseKeyword */, 84 /* CaseKeyword */],
-        anyToken,
-        [isNonJsxSameLineTokenContext, isNonJsxElementOrFragmentContext, isNotForContext],
-        4 /* InsertSpace */
-      ),
-      // This low-pri rule takes care of "try {", "catch {" and "finally {" in case the rule SpaceBeforeOpenBraceInControl didn't execute on FormatOnEnter.
-      rule("SpaceAfterTryCatchFinally", [113 /* TryKeyword */, 85 /* CatchKeyword */, 98 /* FinallyKeyword */], 19 /* OpenBraceToken */, [isNonJsxSameLineTokenContext], 4 /* InsertSpace */)
-    ];
-    return [
-      ...highPriorityCommonRules,
-      ...userConfigurableRules,
-      ...lowPriorityCommonRules
-    ];
-  }
-  function rule(debugName, left, right, context, action, flags = 0 /* None */) {
-    return { leftTokenRange: toTokenRange(left), rightTokenRange: toTokenRange(right), rule: { debugName, context, action, flags } };
-  }
-  function tokenRangeFrom(tokens) {
-    return { tokens, isSpecific: true };
-  }
-  function toTokenRange(arg) {
-    return typeof arg === "number" ? tokenRangeFrom([arg]) : isArray(arg) ? tokenRangeFrom(arg) : arg;
-  }
-  function tokenRangeFromRange(from, to, except = []) {
-    const tokens = [];
-    for (let token = from; token <= to; token++) {
-      if (!contains(except, token)) {
-        tokens.push(token);
-      }
-    }
-    return tokenRangeFrom(tokens);
-  }
-  function optionEquals(optionName, optionValue) {
-    return (context) => context.options && context.options[optionName] === optionValue;
-  }
-  function isOptionEnabled(optionName) {
-    return (context) => context.options && hasProperty(context.options, optionName) && !!context.options[optionName];
-  }
-  function isOptionDisabled(optionName) {
-    return (context) => context.options && hasProperty(context.options, optionName) && !context.options[optionName];
-  }
-  function isOptionDisabledOrUndefined(optionName) {
-    return (context) => !context.options || !hasProperty(context.options, optionName) || !context.options[optionName];
-  }
-  function isOptionDisabledOrUndefinedOrTokensOnSameLine(optionName) {
-    return (context) => !context.options || !hasProperty(context.options, optionName) || !context.options[optionName] || context.TokensAreOnSameLine();
-  }
-  function isOptionEnabledOrUndefined(optionName) {
-    return (context) => !context.options || !hasProperty(context.options, optionName) || !!context.options[optionName];
-  }
-  function isForContext(context) {
-    return context.contextNode.kind === 247 /* ForStatement */;
-  }
-  function isNotForContext(context) {
-    return !isForContext(context);
-  }
-  function isBinaryOpContext(context) {
-    switch (context.contextNode.kind) {
-      case 225 /* BinaryExpression */:
-        return context.contextNode.operatorToken.kind !== 28 /* CommaToken */;
-      case 226 /* ConditionalExpression */:
-      case 193 /* ConditionalType */:
-      case 233 /* AsExpression */:
-      case 280 /* ExportSpecifier */:
-      case 275 /* ImportSpecifier */:
-      case 181 /* TypePredicate */:
-      case 191 /* UnionType */:
-      case 192 /* IntersectionType */:
-      case 237 /* SatisfiesExpression */:
-        return true;
-      case 207 /* BindingElement */:
-      case 264 /* TypeAliasDeclaration */:
-      case 270 /* ImportEqualsDeclaration */:
-      case 276 /* ExportAssignment */:
-      case 259 /* VariableDeclaration */:
-      case 168 /* Parameter */:
-      case 305 /* EnumMember */:
-      case 171 /* PropertyDeclaration */:
-      case 170 /* PropertySignature */:
-        return context.currentTokenSpan.kind === 64 /* EqualsToken */ || context.nextTokenSpan.kind === 64 /* EqualsToken */;
-      case 248 /* ForInStatement */:
-      case 167 /* TypeParameter */:
-        return context.currentTokenSpan.kind === 103 /* InKeyword */ || context.nextTokenSpan.kind === 103 /* InKeyword */ || context.currentTokenSpan.kind === 64 /* EqualsToken */ || context.nextTokenSpan.kind === 64 /* EqualsToken */;
-      case 249 /* ForOfStatement */:
-        return context.currentTokenSpan.kind === 164 /* OfKeyword */ || context.nextTokenSpan.kind === 164 /* OfKeyword */;
-    }
-    return false;
-  }
-  function isNotBinaryOpContext(context) {
-    return !isBinaryOpContext(context);
-  }
-  function isNotTypeAnnotationContext(context) {
-    return !isTypeAnnotationContext(context);
-  }
-  function isTypeAnnotationContext(context) {
-    const contextKind = context.contextNode.kind;
-    return contextKind === 171 /* PropertyDeclaration */ || contextKind === 170 /* PropertySignature */ || contextKind === 168 /* Parameter */ || contextKind === 259 /* VariableDeclaration */ || isFunctionLikeKind(contextKind);
-  }
-  function isConditionalOperatorContext(context) {
-    return context.contextNode.kind === 226 /* ConditionalExpression */ || context.contextNode.kind === 193 /* ConditionalType */;
-  }
-  function isSameLineTokenOrBeforeBlockContext(context) {
-    return context.TokensAreOnSameLine() || isBeforeBlockContext(context);
-  }
-  function isBraceWrappedContext(context) {
-    return context.contextNode.kind === 205 /* ObjectBindingPattern */ || context.contextNode.kind === 199 /* MappedType */ || isSingleLineBlockContext(context);
-  }
-  function isBeforeMultilineBlockContext(context) {
-    return isBeforeBlockContext(context) && !(context.NextNodeAllOnSameLine() || context.NextNodeBlockIsOnOneLine());
-  }
-  function isMultilineBlockContext(context) {
-    return isBlockContext(context) && !(context.ContextNodeAllOnSameLine() || context.ContextNodeBlockIsOnOneLine());
-  }
-  function isSingleLineBlockContext(context) {
-    return isBlockContext(context) && (context.ContextNodeAllOnSameLine() || context.ContextNodeBlockIsOnOneLine());
-  }
-  function isBlockContext(context) {
-    return nodeIsBlockContext(context.contextNode);
-  }
-  function isBeforeBlockContext(context) {
-    return nodeIsBlockContext(context.nextTokenParent);
-  }
-  function nodeIsBlockContext(node) {
-    if (nodeIsTypeScriptDeclWithBlockContext(node)) {
-      return true;
-    }
-    switch (node.kind) {
-      case 240 /* Block */:
-      case 268 /* CaseBlock */:
-      case 209 /* ObjectLiteralExpression */:
-      case 267 /* ModuleBlock */:
-        return true;
-    }
-    return false;
-  }
-  function isFunctionDeclContext(context) {
-    switch (context.contextNode.kind) {
-      case 261 /* FunctionDeclaration */:
-      case 173 /* MethodDeclaration */:
-      case 172 /* MethodSignature */:
-      case 176 /* GetAccessor */:
-      case 177 /* SetAccessor */:
-      case 178 /* CallSignature */:
-      case 217 /* FunctionExpression */:
-      case 175 /* Constructor */:
-      case 218 /* ArrowFunction */:
-      case 263 /* InterfaceDeclaration */:
-        return true;
-    }
-    return false;
-  }
-  function isNotFunctionDeclContext(context) {
-    return !isFunctionDeclContext(context);
-  }
-  function isFunctionDeclarationOrFunctionExpressionContext(context) {
-    return context.contextNode.kind === 261 /* FunctionDeclaration */ || context.contextNode.kind === 217 /* FunctionExpression */;
-  }
-  function isTypeScriptDeclWithBlockContext(context) {
-    return nodeIsTypeScriptDeclWithBlockContext(context.contextNode);
-  }
-  function nodeIsTypeScriptDeclWithBlockContext(node) {
-    switch (node.kind) {
-      case 262 /* ClassDeclaration */:
-      case 230 /* ClassExpression */:
-      case 263 /* InterfaceDeclaration */:
-      case 265 /* EnumDeclaration */:
-      case 186 /* TypeLiteral */:
-      case 266 /* ModuleDeclaration */:
-      case 277 /* ExportDeclaration */:
-      case 278 /* NamedExports */:
-      case 271 /* ImportDeclaration */:
-      case 274 /* NamedImports */:
-        return true;
-    }
-    return false;
-  }
-  function isAfterCodeBlockContext(context) {
-    switch (context.currentTokenParent.kind) {
-      case 262 /* ClassDeclaration */:
-      case 266 /* ModuleDeclaration */:
-      case 265 /* EnumDeclaration */:
-      case 298 /* CatchClause */:
-      case 267 /* ModuleBlock */:
-      case 254 /* SwitchStatement */:
-        return true;
-      case 240 /* Block */: {
-        const blockParent = context.currentTokenParent.parent;
-        if (!blockParent || blockParent.kind !== 218 /* ArrowFunction */ && blockParent.kind !== 217 /* FunctionExpression */) {
-          return true;
-        }
-      }
-    }
-    return false;
-  }
-  function isControlDeclContext(context) {
-    switch (context.contextNode.kind) {
-      case 244 /* IfStatement */:
-      case 254 /* SwitchStatement */:
-      case 247 /* ForStatement */:
-      case 248 /* ForInStatement */:
-      case 249 /* ForOfStatement */:
-      case 246 /* WhileStatement */:
-      case 257 /* TryStatement */:
-      case 245 /* DoStatement */:
-      case 253 /* WithStatement */:
-      case 298 /* CatchClause */:
-        return true;
-      default:
-        return false;
-    }
-  }
-  function isObjectContext(context) {
-    return context.contextNode.kind === 209 /* ObjectLiteralExpression */;
-  }
-  function isFunctionCallContext(context) {
-    return context.contextNode.kind === 212 /* CallExpression */;
-  }
-  function isNewContext(context) {
-    return context.contextNode.kind === 213 /* NewExpression */;
-  }
-  function isFunctionCallOrNewContext(context) {
-    return isFunctionCallContext(context) || isNewContext(context);
-  }
-  function isPreviousTokenNotComma(context) {
-    return context.currentTokenSpan.kind !== 28 /* CommaToken */;
-  }
-  function isNextTokenNotCloseBracket(context) {
-    return context.nextTokenSpan.kind !== 24 /* CloseBracketToken */;
-  }
-  function isNextTokenNotCloseParen(context) {
-    return context.nextTokenSpan.kind !== 22 /* CloseParenToken */;
-  }
-  function isArrowFunctionContext(context) {
-    return context.contextNode.kind === 218 /* ArrowFunction */;
-  }
-  function isImportTypeContext(context) {
-    return context.contextNode.kind === 204 /* ImportType */;
-  }
-  function isNonJsxSameLineTokenContext(context) {
-    return context.TokensAreOnSameLine() && context.contextNode.kind !== 12 /* JsxText */;
-  }
-  function isNonJsxTextContext(context) {
-    return context.contextNode.kind !== 12 /* JsxText */;
-  }
-  function isNonJsxElementOrFragmentContext(context) {
-    return context.contextNode.kind !== 283 /* JsxElement */ && context.contextNode.kind !== 287 /* JsxFragment */;
-  }
-  function isJsxExpressionContext(context) {
-    return context.contextNode.kind === 293 /* JsxExpression */ || context.contextNode.kind === 292 /* JsxSpreadAttribute */;
-  }
-  function isNextTokenParentJsxAttribute(context) {
-    return context.nextTokenParent.kind === 290 /* JsxAttribute */;
-  }
-  function isJsxAttributeContext(context) {
-    return context.contextNode.kind === 290 /* JsxAttribute */;
-  }
-  function isJsxSelfClosingElementContext(context) {
-    return context.contextNode.kind === 284 /* JsxSelfClosingElement */;
-  }
-  function isNotBeforeBlockInFunctionDeclarationContext(context) {
-    return !isFunctionDeclContext(context) && !isBeforeBlockContext(context);
-  }
-  function isEndOfDecoratorContextOnSameLine(context) {
-    return context.TokensAreOnSameLine() && hasDecorators(context.contextNode) && nodeIsInDecoratorContext(context.currentTokenParent) && !nodeIsInDecoratorContext(context.nextTokenParent);
-  }
-  function nodeIsInDecoratorContext(node) {
-    while (node && isExpression(node)) {
-      node = node.parent;
-    }
-    return node && node.kind === 169 /* Decorator */;
-  }
-  function isStartOfVariableDeclarationList(context) {
-    return context.currentTokenParent.kind === 260 /* VariableDeclarationList */ && context.currentTokenParent.getStart(context.sourceFile) === context.currentTokenSpan.pos;
-  }
-  function isNotFormatOnEnter(context) {
-    return context.formattingRequestKind !== 2 /* FormatOnEnter */;
-  }
-  function isModuleDeclContext(context) {
-    return context.contextNode.kind === 266 /* ModuleDeclaration */;
-  }
-  function isObjectTypeContext(context) {
-    return context.contextNode.kind === 186 /* TypeLiteral */;
-  }
-  function isConstructorSignatureContext(context) {
-    return context.contextNode.kind === 179 /* ConstructSignature */;
-  }
-  function isTypeArgumentOrParameterOrAssertion(token, parent2) {
-    if (token.kind !== 30 /* LessThanToken */ && token.kind !== 32 /* GreaterThanToken */) {
-      return false;
-    }
-    switch (parent2.kind) {
-      case 182 /* TypeReference */:
-      case 215 /* TypeAssertionExpression */:
-      case 264 /* TypeAliasDeclaration */:
-      case 262 /* ClassDeclaration */:
-      case 230 /* ClassExpression */:
-      case 263 /* InterfaceDeclaration */:
-      case 261 /* FunctionDeclaration */:
-      case 217 /* FunctionExpression */:
-      case 218 /* ArrowFunction */:
-      case 173 /* MethodDeclaration */:
-      case 172 /* MethodSignature */:
-      case 178 /* CallSignature */:
-      case 179 /* ConstructSignature */:
-      case 212 /* CallExpression */:
-      case 213 /* NewExpression */:
-      case 232 /* ExpressionWithTypeArguments */:
-        return true;
-      default:
-        return false;
-    }
-  }
-  function isTypeArgumentOrParameterOrAssertionContext(context) {
-    return isTypeArgumentOrParameterOrAssertion(context.currentTokenSpan, context.currentTokenParent) || isTypeArgumentOrParameterOrAssertion(context.nextTokenSpan, context.nextTokenParent);
-  }
-  function isTypeAssertionContext(context) {
-    return context.contextNode.kind === 215 /* TypeAssertionExpression */;
-  }
-  function isNonTypeAssertionContext(context) {
-    return !isTypeAssertionContext(context);
-  }
-  function isVoidOpContext(context) {
-    return context.currentTokenSpan.kind === 116 /* VoidKeyword */ && context.currentTokenParent.kind === 221 /* VoidExpression */;
-  }
-  function isYieldOrYieldStarWithOperand(context) {
-    return context.contextNode.kind === 228 /* YieldExpression */ && context.contextNode.expression !== void 0;
-  }
-  function isNonNullAssertionContext(context) {
-    return context.contextNode.kind === 234 /* NonNullExpression */;
-  }
-  function isNotStatementConditionContext(context) {
-    return !isStatementConditionContext(context);
-  }
-  function isStatementConditionContext(context) {
-    switch (context.contextNode.kind) {
-      case 244 /* IfStatement */:
-      case 247 /* ForStatement */:
-      case 248 /* ForInStatement */:
-      case 249 /* ForOfStatement */:
-      case 245 /* DoStatement */:
-      case 246 /* WhileStatement */:
-        return true;
-      default:
-        return false;
-    }
-  }
-  function isSemicolonDeletionContext(context) {
-    let nextTokenKind = context.nextTokenSpan.kind;
-    let nextTokenStart = context.nextTokenSpan.pos;
-    if (isTrivia(nextTokenKind)) {
-      const nextRealToken = context.nextTokenParent === context.currentTokenParent ? findNextToken(
-        context.currentTokenParent,
-        findAncestor(context.currentTokenParent, (a) => !a.parent),
-        context.sourceFile
-      ) : context.nextTokenParent.getFirstToken(context.sourceFile);
-      if (!nextRealToken) {
-        return true;
-      }
-      nextTokenKind = nextRealToken.kind;
-      nextTokenStart = nextRealToken.getStart(context.sourceFile);
-    }
-    const startLine = context.sourceFile.getLineAndCharacterOfPosition(context.currentTokenSpan.pos).line;
-    const endLine = context.sourceFile.getLineAndCharacterOfPosition(nextTokenStart).line;
-    if (startLine === endLine) {
-      return nextTokenKind === 20 /* CloseBraceToken */ || nextTokenKind === 1 /* EndOfFileToken */;
-    }
-    if (nextTokenKind === 239 /* SemicolonClassElement */ || nextTokenKind === 27 /* SemicolonToken */) {
-      return false;
-    }
-    if (context.contextNode.kind === 263 /* InterfaceDeclaration */ || context.contextNode.kind === 264 /* TypeAliasDeclaration */) {
-      return !isPropertySignature(context.currentTokenParent) || !!context.currentTokenParent.type || nextTokenKind !== 21 /* OpenParenToken */;
-    }
-    if (isPropertyDeclaration(context.currentTokenParent)) {
-      return !context.currentTokenParent.initializer;
-    }
-    return context.currentTokenParent.kind !== 247 /* ForStatement */ && context.currentTokenParent.kind !== 241 /* EmptyStatement */ && context.currentTokenParent.kind !== 239 /* SemicolonClassElement */ && nextTokenKind !== 23 /* OpenBracketToken */ && nextTokenKind !== 21 /* OpenParenToken */ && nextTokenKind !== 40 /* PlusToken */ && nextTokenKind !== 41 /* MinusToken */ && nextTokenKind !== 44 /* SlashToken */ && nextTokenKind !== 14 /* RegularExpressionLiteral */ && nextTokenKind !== 28 /* CommaToken */ && nextTokenKind !== 227 /* TemplateExpression */ && nextTokenKind !== 16 /* TemplateHead */ && nextTokenKind !== 15 /* NoSubstitutionTemplateLiteral */ && nextTokenKind !== 25 /* DotToken */;
-  }
-  function isSemicolonInsertionContext(context) {
-    return positionIsASICandidate(context.currentTokenSpan.end, context.currentTokenParent, context.sourceFile);
-  }
-  function isNotPropertyAccessOnIntegerLiteral(context) {
-    return !isPropertyAccessExpression(context.contextNode) || !isNumericLiteral(context.contextNode.expression) || context.contextNode.expression.getText().indexOf(".") !== -1;
-  }
-  var init_rules = __esm({
-    "src/services/formatting/rules.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_formatting();
-    }
-  });
-
-  // src/services/formatting/rulesMap.ts
-  function getFormatContext(options, host) {
-    return { options, getRules: getRulesMap(), host };
-  }
-  function getRulesMap() {
-    if (rulesMapCache === void 0) {
-      rulesMapCache = createRulesMap(getAllRules());
-    }
-    return rulesMapCache;
-  }
-  function getRuleActionExclusion(ruleAction) {
-    let mask2 = 0 /* None */;
-    if (ruleAction & 1 /* StopProcessingSpaceActions */) {
-      mask2 |= 28 /* ModifySpaceAction */;
-    }
-    if (ruleAction & 2 /* StopProcessingTokenActions */) {
-      mask2 |= 96 /* ModifyTokenAction */;
-    }
-    if (ruleAction & 28 /* ModifySpaceAction */) {
-      mask2 |= 28 /* ModifySpaceAction */;
-    }
-    if (ruleAction & 96 /* ModifyTokenAction */) {
-      mask2 |= 96 /* ModifyTokenAction */;
-    }
-    return mask2;
-  }
-  function createRulesMap(rules) {
-    const map2 = buildMap(rules);
-    return (context) => {
-      const bucket = map2[getRuleBucketIndex(context.currentTokenSpan.kind, context.nextTokenSpan.kind)];
-      if (bucket) {
-        const rules2 = [];
-        let ruleActionMask = 0;
-        for (const rule2 of bucket) {
-          const acceptRuleActions = ~getRuleActionExclusion(ruleActionMask);
-          if (rule2.action & acceptRuleActions && every(rule2.context, (c) => c(context))) {
-            rules2.push(rule2);
-            ruleActionMask |= rule2.action;
-          }
-        }
-        if (rules2.length) {
-          return rules2;
-        }
-      }
-    };
-  }
-  function buildMap(rules) {
-    const map2 = new Array(mapRowLength * mapRowLength);
-    const rulesBucketConstructionStateList = new Array(map2.length);
-    for (const rule2 of rules) {
-      const specificRule = rule2.leftTokenRange.isSpecific && rule2.rightTokenRange.isSpecific;
-      for (const left of rule2.leftTokenRange.tokens) {
-        for (const right of rule2.rightTokenRange.tokens) {
-          const index = getRuleBucketIndex(left, right);
-          let rulesBucket = map2[index];
-          if (rulesBucket === void 0) {
-            rulesBucket = map2[index] = [];
-          }
-          addRule(rulesBucket, rule2.rule, specificRule, rulesBucketConstructionStateList, index);
-        }
-      }
-    }
-    return map2;
-  }
-  function getRuleBucketIndex(row, column) {
-    Debug.assert(row <= 164 /* LastKeyword */ && column <= 164 /* LastKeyword */, "Must compute formatting context from tokens");
-    return row * mapRowLength + column;
-  }
-  function addRule(rules, rule2, specificTokens, constructionState, rulesBucketIndex) {
-    const position = rule2.action & 3 /* StopAction */ ? specificTokens ? 0 /* StopRulesSpecific */ : RulesPosition.StopRulesAny : rule2.context !== anyContext ? specificTokens ? RulesPosition.ContextRulesSpecific : RulesPosition.ContextRulesAny : specificTokens ? RulesPosition.NoContextRulesSpecific : RulesPosition.NoContextRulesAny;
-    const state = constructionState[rulesBucketIndex] || 0;
-    rules.splice(getInsertionIndex(state, position), 0, rule2);
-    constructionState[rulesBucketIndex] = increaseInsertionIndex(state, position);
-  }
-  function getInsertionIndex(indexBitmap, maskPosition) {
-    let index = 0;
-    for (let pos = 0; pos <= maskPosition; pos += maskBitSize) {
-      index += indexBitmap & mask;
-      indexBitmap >>= maskBitSize;
-    }
-    return index;
-  }
-  function increaseInsertionIndex(indexBitmap, maskPosition) {
-    const value = (indexBitmap >> maskPosition & mask) + 1;
-    Debug.assert((value & mask) === value, "Adding more rules into the sub-bucket than allowed. Maximum allowed is 32 rules.");
-    return indexBitmap & ~(mask << maskPosition) | value << maskPosition;
-  }
-  var rulesMapCache, maskBitSize, mask, mapRowLength, RulesPosition;
-  var init_rulesMap = __esm({
-    "src/services/formatting/rulesMap.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_formatting();
-      maskBitSize = 5;
-      mask = 31;
-      mapRowLength = 164 /* LastToken */ + 1;
-      RulesPosition = ((RulesPosition2) => {
-        RulesPosition2[RulesPosition2["StopRulesSpecific"] = 0] = "StopRulesSpecific";
-        RulesPosition2[RulesPosition2["StopRulesAny"] = maskBitSize * 1] = "StopRulesAny";
-        RulesPosition2[RulesPosition2["ContextRulesSpecific"] = maskBitSize * 2] = "ContextRulesSpecific";
-        RulesPosition2[RulesPosition2["ContextRulesAny"] = maskBitSize * 3] = "ContextRulesAny";
-        RulesPosition2[RulesPosition2["NoContextRulesSpecific"] = maskBitSize * 4] = "NoContextRulesSpecific";
-        RulesPosition2[RulesPosition2["NoContextRulesAny"] = maskBitSize * 5] = "NoContextRulesAny";
-        return RulesPosition2;
-      })(RulesPosition || {});
-    }
-  });
-
-  // src/services/formatting/formatting.ts
-  function createTextRangeWithKind(pos, end, kind) {
-    const textRangeWithKind = { pos, end, kind };
-    if (Debug.isDebugging) {
-      Object.defineProperty(textRangeWithKind, "__debugKind", {
-        get: () => Debug.formatSyntaxKind(kind)
-      });
-    }
-    return textRangeWithKind;
-  }
-  function formatOnEnter(position, sourceFile, formatContext) {
-    const line = sourceFile.getLineAndCharacterOfPosition(position).line;
-    if (line === 0) {
-      return [];
-    }
-    let endOfFormatSpan = getEndLinePosition(line, sourceFile);
-    while (isWhiteSpaceSingleLine(sourceFile.text.charCodeAt(endOfFormatSpan))) {
-      endOfFormatSpan--;
-    }
-    if (isLineBreak(sourceFile.text.charCodeAt(endOfFormatSpan))) {
-      endOfFormatSpan--;
-    }
-    const span = {
-      // get start position for the previous line
-      pos: getStartPositionOfLine(line - 1, sourceFile),
-      // end value is exclusive so add 1 to the result
-      end: endOfFormatSpan + 1
-    };
-    return formatSpan(span, sourceFile, formatContext, 2 /* FormatOnEnter */);
-  }
-  function formatOnSemicolon(position, sourceFile, formatContext) {
-    const semicolon = findImmediatelyPrecedingTokenOfKind(position, 27 /* SemicolonToken */, sourceFile);
-    return formatNodeLines(findOutermostNodeWithinListLevel(semicolon), sourceFile, formatContext, 3 /* FormatOnSemicolon */);
-  }
-  function formatOnOpeningCurly(position, sourceFile, formatContext) {
-    const openingCurly = findImmediatelyPrecedingTokenOfKind(position, 19 /* OpenBraceToken */, sourceFile);
-    if (!openingCurly) {
-      return [];
-    }
-    const curlyBraceRange = openingCurly.parent;
-    const outermostNode = findOutermostNodeWithinListLevel(curlyBraceRange);
-    const textRange = {
-      pos: getLineStartPositionForPosition(outermostNode.getStart(sourceFile), sourceFile),
-      // TODO: GH#18217
-      end: position
-    };
-    return formatSpan(textRange, sourceFile, formatContext, 4 /* FormatOnOpeningCurlyBrace */);
-  }
-  function formatOnClosingCurly(position, sourceFile, formatContext) {
-    const precedingToken = findImmediatelyPrecedingTokenOfKind(position, 20 /* CloseBraceToken */, sourceFile);
-    return formatNodeLines(findOutermostNodeWithinListLevel(precedingToken), sourceFile, formatContext, 5 /* FormatOnClosingCurlyBrace */);
-  }
-  function formatDocument(sourceFile, formatContext) {
-    const span = {
-      pos: 0,
-      end: sourceFile.text.length
-    };
-    return formatSpan(span, sourceFile, formatContext, 0 /* FormatDocument */);
-  }
-  function formatSelection(start, end, sourceFile, formatContext) {
-    const span = {
-      pos: getLineStartPositionForPosition(start, sourceFile),
-      end
-    };
-    return formatSpan(span, sourceFile, formatContext, 1 /* FormatSelection */);
-  }
-  function findImmediatelyPrecedingTokenOfKind(end, expectedTokenKind, sourceFile) {
-    const precedingToken = findPrecedingToken(end, sourceFile);
-    return precedingToken && precedingToken.kind === expectedTokenKind && end === precedingToken.getEnd() ? precedingToken : void 0;
-  }
-  function findOutermostNodeWithinListLevel(node) {
-    let current = node;
-    while (current && current.parent && current.parent.end === node.end && !isListElement(current.parent, current)) {
-      current = current.parent;
-    }
-    return current;
-  }
-  function isListElement(parent2, node) {
-    switch (parent2.kind) {
-      case 262 /* ClassDeclaration */:
-      case 263 /* InterfaceDeclaration */:
-        return rangeContainsRange(parent2.members, node);
-      case 266 /* ModuleDeclaration */:
-        const body = parent2.body;
-        return !!body && body.kind === 267 /* ModuleBlock */ && rangeContainsRange(body.statements, node);
-      case 311 /* SourceFile */:
-      case 240 /* Block */:
-      case 267 /* ModuleBlock */:
-        return rangeContainsRange(parent2.statements, node);
-      case 298 /* CatchClause */:
-        return rangeContainsRange(parent2.block.statements, node);
-    }
-    return false;
-  }
-  function findEnclosingNode(range, sourceFile) {
-    return find2(sourceFile);
-    function find2(n) {
-      const candidate = forEachChild(n, (c) => startEndContainsRange(c.getStart(sourceFile), c.end, range) && c);
-      if (candidate) {
-        const result = find2(candidate);
-        if (result) {
-          return result;
-        }
-      }
-      return n;
-    }
-  }
-  function prepareRangeContainsErrorFunction(errors, originalRange) {
-    if (!errors.length) {
-      return rangeHasNoErrors;
-    }
-    const sorted = errors.filter((d) => rangeOverlapsWithStartEnd(originalRange, d.start, d.start + d.length)).sort((e1, e2) => e1.start - e2.start);
-    if (!sorted.length) {
-      return rangeHasNoErrors;
-    }
-    let index = 0;
-    return (r) => {
-      while (true) {
-        if (index >= sorted.length) {
-          return false;
-        }
-        const error = sorted[index];
-        if (r.end <= error.start) {
-          return false;
-        }
-        if (startEndOverlapsWithStartEnd(r.pos, r.end, error.start, error.start + error.length)) {
-          return true;
-        }
-        index++;
-      }
-    };
-    function rangeHasNoErrors() {
-      return false;
-    }
-  }
-  function getScanStartPosition(enclosingNode, originalRange, sourceFile) {
-    const start = enclosingNode.getStart(sourceFile);
-    if (start === originalRange.pos && enclosingNode.end === originalRange.end) {
-      return start;
-    }
-    const precedingToken = findPrecedingToken(originalRange.pos, sourceFile);
-    if (!precedingToken) {
-      return enclosingNode.pos;
-    }
-    if (precedingToken.end >= originalRange.pos) {
-      return enclosingNode.pos;
-    }
-    return precedingToken.end;
-  }
-  function getOwnOrInheritedDelta(n, options, sourceFile) {
-    let previousLine = -1 /* Unknown */;
-    let child;
-    while (n) {
-      const line = sourceFile.getLineAndCharacterOfPosition(n.getStart(sourceFile)).line;
-      if (previousLine !== -1 /* Unknown */ && line !== previousLine) {
-        break;
-      }
-      if (SmartIndenter.shouldIndentChildNode(options, n, child, sourceFile)) {
-        return options.indentSize;
-      }
-      previousLine = line;
-      child = n;
-      n = n.parent;
-    }
-    return 0;
-  }
-  function formatNodeGivenIndentation(node, sourceFileLike, languageVariant, initialIndentation, delta, formatContext) {
-    const range = { pos: node.pos, end: node.end };
-    return getFormattingScanner(sourceFileLike.text, languageVariant, range.pos, range.end, (scanner2) => formatSpanWorker(
-      range,
-      node,
-      initialIndentation,
-      delta,
-      scanner2,
-      formatContext,
-      1 /* FormatSelection */,
-      (_) => false,
-      // assume that node does not have any errors
-      sourceFileLike
-    ));
-  }
-  function formatNodeLines(node, sourceFile, formatContext, requestKind) {
-    if (!node) {
-      return [];
-    }
-    const span = {
-      pos: getLineStartPositionForPosition(node.getStart(sourceFile), sourceFile),
-      end: node.end
-    };
-    return formatSpan(span, sourceFile, formatContext, requestKind);
-  }
-  function formatSpan(originalRange, sourceFile, formatContext, requestKind) {
-    const enclosingNode = findEnclosingNode(originalRange, sourceFile);
-    return getFormattingScanner(
-      sourceFile.text,
-      sourceFile.languageVariant,
-      getScanStartPosition(enclosingNode, originalRange, sourceFile),
-      originalRange.end,
-      (scanner2) => formatSpanWorker(
-        originalRange,
-        enclosingNode,
-        SmartIndenter.getIndentationForNode(enclosingNode, originalRange, sourceFile, formatContext.options),
-        getOwnOrInheritedDelta(enclosingNode, formatContext.options, sourceFile),
-        scanner2,
-        formatContext,
-        requestKind,
-        prepareRangeContainsErrorFunction(sourceFile.parseDiagnostics, originalRange),
-        sourceFile
-      )
-    );
-  }
-  function formatSpanWorker(originalRange, enclosingNode, initialIndentation, delta, formattingScanner, { options, getRules, host }, requestKind, rangeContainsError, sourceFile) {
-    var _a;
-    const formattingContext = new FormattingContext(sourceFile, requestKind, options);
-    let previousRangeTriviaEnd;
-    let previousRange;
-    let previousParent;
-    let previousRangeStartLine;
-    let lastIndentedLine;
-    let indentationOnLastIndentedLine = -1 /* Unknown */;
-    const edits = [];
-    formattingScanner.advance();
-    if (formattingScanner.isOnToken()) {
-      const startLine = sourceFile.getLineAndCharacterOfPosition(enclosingNode.getStart(sourceFile)).line;
-      let undecoratedStartLine = startLine;
-      if (hasDecorators(enclosingNode)) {
-        undecoratedStartLine = sourceFile.getLineAndCharacterOfPosition(getNonDecoratorTokenPosOfNode(enclosingNode, sourceFile)).line;
-      }
-      processNode(enclosingNode, enclosingNode, startLine, undecoratedStartLine, initialIndentation, delta);
-    }
-    if (!formattingScanner.isOnToken()) {
-      const indentation = SmartIndenter.nodeWillIndentChild(
-        options,
-        enclosingNode,
-        /*child*/
-        void 0,
-        sourceFile,
-        /*indentByDefault*/
-        false
-      ) ? initialIndentation + options.indentSize : initialIndentation;
-      const leadingTrivia = formattingScanner.getCurrentLeadingTrivia();
-      if (leadingTrivia) {
-        indentTriviaItems(
-          leadingTrivia,
-          indentation,
-          /*indentNextTokenOrTrivia*/
-          false,
-          (item) => processRange(
-            item,
-            sourceFile.getLineAndCharacterOfPosition(item.pos),
-            enclosingNode,
-            enclosingNode,
-            /*dynamicIndentation*/
-            void 0
-          )
-        );
-        if (options.trimTrailingWhitespace !== false) {
-          trimTrailingWhitespacesForRemainingRange(leadingTrivia);
-        }
-      }
-    }
-    if (previousRange && formattingScanner.getTokenFullStart() >= originalRange.end) {
-      const tokenInfo = formattingScanner.isOnEOF() ? formattingScanner.readEOFTokenRange() : formattingScanner.isOnToken() ? formattingScanner.readTokenInfo(enclosingNode).token : void 0;
-      if (tokenInfo && tokenInfo.pos === previousRangeTriviaEnd) {
-        const parent2 = ((_a = findPrecedingToken(tokenInfo.end, sourceFile, enclosingNode)) == null ? void 0 : _a.parent) || previousParent;
-        processPair(
-          tokenInfo,
-          sourceFile.getLineAndCharacterOfPosition(tokenInfo.pos).line,
-          parent2,
-          previousRange,
-          previousRangeStartLine,
-          previousParent,
-          parent2,
-          /*dynamicIndentation*/
-          void 0
-        );
-      }
-    }
-    return edits;
-    function tryComputeIndentationForListItem(startPos, endPos, parentStartLine, range, inheritedIndentation) {
-      if (rangeOverlapsWithStartEnd(range, startPos, endPos) || rangeContainsStartEnd(range, startPos, endPos)) {
-        if (inheritedIndentation !== -1 /* Unknown */) {
-          return inheritedIndentation;
-        }
-      } else {
-        const startLine = sourceFile.getLineAndCharacterOfPosition(startPos).line;
-        const startLinePosition = getLineStartPositionForPosition(startPos, sourceFile);
-        const column = SmartIndenter.findFirstNonWhitespaceColumn(startLinePosition, startPos, sourceFile, options);
-        if (startLine !== parentStartLine || startPos === column) {
-          const baseIndentSize = SmartIndenter.getBaseIndentation(options);
-          return baseIndentSize > column ? baseIndentSize : column;
-        }
-      }
-      return -1 /* Unknown */;
-    }
-    function computeIndentation(node, startLine, inheritedIndentation, parent2, parentDynamicIndentation, effectiveParentStartLine) {
-      const delta2 = SmartIndenter.shouldIndentChildNode(options, node) ? options.indentSize : 0;
-      if (effectiveParentStartLine === startLine) {
-        return {
-          indentation: startLine === lastIndentedLine ? indentationOnLastIndentedLine : parentDynamicIndentation.getIndentation(),
-          delta: Math.min(options.indentSize, parentDynamicIndentation.getDelta(node) + delta2)
-        };
-      } else if (inheritedIndentation === -1 /* Unknown */) {
-        if (node.kind === 21 /* OpenParenToken */ && startLine === lastIndentedLine) {
-          return { indentation: indentationOnLastIndentedLine, delta: parentDynamicIndentation.getDelta(node) };
-        } else if (SmartIndenter.childStartsOnTheSameLineWithElseInIfStatement(parent2, node, startLine, sourceFile) || SmartIndenter.childIsUnindentedBranchOfConditionalExpression(parent2, node, startLine, sourceFile) || SmartIndenter.argumentStartsOnSameLineAsPreviousArgument(parent2, node, startLine, sourceFile)) {
-          return { indentation: parentDynamicIndentation.getIndentation(), delta: delta2 };
-        } else {
-          return { indentation: parentDynamicIndentation.getIndentation() + parentDynamicIndentation.getDelta(node), delta: delta2 };
-        }
-      } else {
-        return { indentation: inheritedIndentation, delta: delta2 };
-      }
-    }
-    function getFirstNonDecoratorTokenOfNode(node) {
-      if (canHaveModifiers(node)) {
-        const modifier = find(node.modifiers, isModifier, findIndex(node.modifiers, isDecorator));
-        if (modifier)
-          return modifier.kind;
-      }
-      switch (node.kind) {
-        case 262 /* ClassDeclaration */:
-          return 86 /* ClassKeyword */;
-        case 263 /* InterfaceDeclaration */:
-          return 120 /* InterfaceKeyword */;
-        case 261 /* FunctionDeclaration */:
-          return 100 /* FunctionKeyword */;
-        case 265 /* EnumDeclaration */:
-          return 265 /* EnumDeclaration */;
-        case 176 /* GetAccessor */:
-          return 139 /* GetKeyword */;
-        case 177 /* SetAccessor */:
-          return 153 /* SetKeyword */;
-        case 173 /* MethodDeclaration */:
-          if (node.asteriskToken) {
-            return 42 /* AsteriskToken */;
-          }
-        case 171 /* PropertyDeclaration */:
-        case 168 /* Parameter */:
-          const name = getNameOfDeclaration(node);
-          if (name) {
-            return name.kind;
-          }
-      }
-    }
-    function getDynamicIndentation(node, nodeStartLine, indentation, delta2) {
-      return {
-        getIndentationForComment: (kind, tokenIndentation, container) => {
-          switch (kind) {
-            case 20 /* CloseBraceToken */:
-            case 24 /* CloseBracketToken */:
-            case 22 /* CloseParenToken */:
-              return indentation + getDelta(container);
-          }
-          return tokenIndentation !== -1 /* Unknown */ ? tokenIndentation : indentation;
-        },
-        // if list end token is LessThanToken '>' then its delta should be explicitly suppressed
-        // so that LessThanToken as a binary operator can still be indented.
-        // foo.then
-        //     <
-        //         number,
-        //         string,
-        //     >();
-        // vs
-        // var a = xValue
-        //     > yValue;
-        getIndentationForToken: (line, kind, container, suppressDelta) => !suppressDelta && shouldAddDelta(line, kind, container) ? indentation + getDelta(container) : indentation,
-        getIndentation: () => indentation,
-        getDelta,
-        recomputeIndentation: (lineAdded, parent2) => {
-          if (SmartIndenter.shouldIndentChildNode(options, parent2, node, sourceFile)) {
-            indentation += lineAdded ? options.indentSize : -options.indentSize;
-            delta2 = SmartIndenter.shouldIndentChildNode(options, node) ? options.indentSize : 0;
-          }
-        }
-      };
-      function shouldAddDelta(line, kind, container) {
-        switch (kind) {
-          case 19 /* OpenBraceToken */:
-          case 20 /* CloseBraceToken */:
-          case 22 /* CloseParenToken */:
-          case 93 /* ElseKeyword */:
-          case 117 /* WhileKeyword */:
-          case 60 /* AtToken */:
-            return false;
-          case 44 /* SlashToken */:
-          case 32 /* GreaterThanToken */:
-            switch (container.kind) {
-              case 285 /* JsxOpeningElement */:
-              case 286 /* JsxClosingElement */:
-              case 284 /* JsxSelfClosingElement */:
-                return false;
-            }
-            break;
-          case 23 /* OpenBracketToken */:
-          case 24 /* CloseBracketToken */:
-            if (container.kind !== 199 /* MappedType */) {
-              return false;
-            }
-            break;
-        }
-        return nodeStartLine !== line && !(hasDecorators(node) && kind === getFirstNonDecoratorTokenOfNode(node));
-      }
-      function getDelta(child) {
-        return SmartIndenter.nodeWillIndentChild(
-          options,
-          node,
-          child,
-          sourceFile,
-          /*indentByDefault*/
-          true
-        ) ? delta2 : 0;
-      }
-    }
-    function processNode(node, contextNode, nodeStartLine, undecoratedNodeStartLine, indentation, delta2) {
-      if (!rangeOverlapsWithStartEnd(originalRange, node.getStart(sourceFile), node.getEnd())) {
-        return;
-      }
-      const nodeDynamicIndentation = getDynamicIndentation(node, nodeStartLine, indentation, delta2);
-      let childContextNode = contextNode;
-      forEachChild(
-        node,
-        (child) => {
-          processChildNode(
-            child,
-            /*inheritedIndentation*/
-            -1 /* Unknown */,
-            node,
-            nodeDynamicIndentation,
-            nodeStartLine,
-            undecoratedNodeStartLine,
-            /*isListItem*/
-            false
-          );
-        },
-        (nodes) => {
-          processChildNodes(nodes, node, nodeStartLine, nodeDynamicIndentation);
-        }
-      );
-      while (formattingScanner.isOnToken() && formattingScanner.getTokenFullStart() < originalRange.end) {
-        const tokenInfo = formattingScanner.readTokenInfo(node);
-        if (tokenInfo.token.end > Math.min(node.end, originalRange.end)) {
-          break;
-        }
-        consumeTokenAndAdvanceScanner(tokenInfo, node, nodeDynamicIndentation, node);
-      }
-      function processChildNode(child, inheritedIndentation, parent2, parentDynamicIndentation, parentStartLine, undecoratedParentStartLine, isListItem, isFirstListItem) {
-        Debug.assert(!nodeIsSynthesized(child));
-        if (nodeIsMissing(child) || isGrammarError(parent2, child)) {
-          return inheritedIndentation;
-        }
-        const childStartPos = child.getStart(sourceFile);
-        const childStartLine = sourceFile.getLineAndCharacterOfPosition(childStartPos).line;
-        let undecoratedChildStartLine = childStartLine;
-        if (hasDecorators(child)) {
-          undecoratedChildStartLine = sourceFile.getLineAndCharacterOfPosition(getNonDecoratorTokenPosOfNode(child, sourceFile)).line;
-        }
-        let childIndentationAmount = -1 /* Unknown */;
-        if (isListItem && rangeContainsRange(originalRange, parent2)) {
-          childIndentationAmount = tryComputeIndentationForListItem(childStartPos, child.end, parentStartLine, originalRange, inheritedIndentation);
-          if (childIndentationAmount !== -1 /* Unknown */) {
-            inheritedIndentation = childIndentationAmount;
-          }
-        }
-        if (!rangeOverlapsWithStartEnd(originalRange, child.pos, child.end)) {
-          if (child.end < originalRange.pos) {
-            formattingScanner.skipToEndOf(child);
-          }
-          return inheritedIndentation;
-        }
-        if (child.getFullWidth() === 0) {
-          return inheritedIndentation;
-        }
-        while (formattingScanner.isOnToken() && formattingScanner.getTokenFullStart() < originalRange.end) {
-          const tokenInfo = formattingScanner.readTokenInfo(node);
-          if (tokenInfo.token.end > originalRange.end) {
-            return inheritedIndentation;
-          }
-          if (tokenInfo.token.end > childStartPos) {
-            if (tokenInfo.token.pos > childStartPos) {
-              formattingScanner.skipToStartOf(child);
-            }
-            break;
-          }
-          consumeTokenAndAdvanceScanner(tokenInfo, node, parentDynamicIndentation, node);
-        }
-        if (!formattingScanner.isOnToken() || formattingScanner.getTokenFullStart() >= originalRange.end) {
-          return inheritedIndentation;
-        }
-        if (isToken(child)) {
-          const tokenInfo = formattingScanner.readTokenInfo(child);
-          if (child.kind !== 12 /* JsxText */) {
-            Debug.assert(tokenInfo.token.end === child.end, "Token end is child end");
-            consumeTokenAndAdvanceScanner(tokenInfo, node, parentDynamicIndentation, child);
-            return inheritedIndentation;
-          }
-        }
-        const effectiveParentStartLine = child.kind === 169 /* Decorator */ ? childStartLine : undecoratedParentStartLine;
-        const childIndentation = computeIndentation(child, childStartLine, childIndentationAmount, node, parentDynamicIndentation, effectiveParentStartLine);
-        processNode(child, childContextNode, childStartLine, undecoratedChildStartLine, childIndentation.indentation, childIndentation.delta);
-        childContextNode = node;
-        if (isFirstListItem && parent2.kind === 208 /* ArrayLiteralExpression */ && inheritedIndentation === -1 /* Unknown */) {
-          inheritedIndentation = childIndentation.indentation;
-        }
-        return inheritedIndentation;
-      }
-      function processChildNodes(nodes, parent2, parentStartLine, parentDynamicIndentation) {
-        Debug.assert(isNodeArray(nodes));
-        Debug.assert(!nodeIsSynthesized(nodes));
-        const listStartToken = getOpenTokenForList(parent2, nodes);
-        let listDynamicIndentation = parentDynamicIndentation;
-        let startLine = parentStartLine;
-        if (!rangeOverlapsWithStartEnd(originalRange, nodes.pos, nodes.end)) {
-          if (nodes.end < originalRange.pos) {
-            formattingScanner.skipToEndOf(nodes);
-          }
-          return;
-        }
-        if (listStartToken !== 0 /* Unknown */) {
-          while (formattingScanner.isOnToken() && formattingScanner.getTokenFullStart() < originalRange.end) {
-            const tokenInfo = formattingScanner.readTokenInfo(parent2);
-            if (tokenInfo.token.end > nodes.pos) {
-              break;
-            } else if (tokenInfo.token.kind === listStartToken) {
-              startLine = sourceFile.getLineAndCharacterOfPosition(tokenInfo.token.pos).line;
-              consumeTokenAndAdvanceScanner(tokenInfo, parent2, parentDynamicIndentation, parent2);
-              let indentationOnListStartToken;
-              if (indentationOnLastIndentedLine !== -1 /* Unknown */) {
-                indentationOnListStartToken = indentationOnLastIndentedLine;
-              } else {
-                const startLinePosition = getLineStartPositionForPosition(tokenInfo.token.pos, sourceFile);
-                indentationOnListStartToken = SmartIndenter.findFirstNonWhitespaceColumn(startLinePosition, tokenInfo.token.pos, sourceFile, options);
-              }
-              listDynamicIndentation = getDynamicIndentation(parent2, parentStartLine, indentationOnListStartToken, options.indentSize);
-            } else {
-              consumeTokenAndAdvanceScanner(tokenInfo, parent2, parentDynamicIndentation, parent2);
-            }
-          }
-        }
-        let inheritedIndentation = -1 /* Unknown */;
-        for (let i = 0; i < nodes.length; i++) {
-          const child = nodes[i];
-          inheritedIndentation = processChildNode(
-            child,
-            inheritedIndentation,
-            node,
-            listDynamicIndentation,
-            startLine,
-            startLine,
-            /*isListItem*/
-            true,
-            /*isFirstListItem*/
-            i === 0
-          );
-        }
-        const listEndToken = getCloseTokenForOpenToken(listStartToken);
-        if (listEndToken !== 0 /* Unknown */ && formattingScanner.isOnToken() && formattingScanner.getTokenFullStart() < originalRange.end) {
-          let tokenInfo = formattingScanner.readTokenInfo(parent2);
-          if (tokenInfo.token.kind === 28 /* CommaToken */) {
-            consumeTokenAndAdvanceScanner(tokenInfo, parent2, listDynamicIndentation, parent2);
-            tokenInfo = formattingScanner.isOnToken() ? formattingScanner.readTokenInfo(parent2) : void 0;
-          }
-          if (tokenInfo && tokenInfo.token.kind === listEndToken && rangeContainsRange(parent2, tokenInfo.token)) {
-            consumeTokenAndAdvanceScanner(
-              tokenInfo,
-              parent2,
-              listDynamicIndentation,
-              parent2,
-              /*isListEndToken*/
-              true
-            );
-          }
-        }
-      }
-      function consumeTokenAndAdvanceScanner(currentTokenInfo, parent2, dynamicIndentation, container, isListEndToken) {
-        Debug.assert(rangeContainsRange(parent2, currentTokenInfo.token));
-        const lastTriviaWasNewLine = formattingScanner.lastTrailingTriviaWasNewLine();
-        let indentToken = false;
-        if (currentTokenInfo.leadingTrivia) {
-          processTrivia(currentTokenInfo.leadingTrivia, parent2, childContextNode, dynamicIndentation);
-        }
-        let lineAction = 0 /* None */;
-        const isTokenInRange = rangeContainsRange(originalRange, currentTokenInfo.token);
-        const tokenStart = sourceFile.getLineAndCharacterOfPosition(currentTokenInfo.token.pos);
-        if (isTokenInRange) {
-          const rangeHasError = rangeContainsError(currentTokenInfo.token);
-          const savePreviousRange = previousRange;
-          lineAction = processRange(currentTokenInfo.token, tokenStart, parent2, childContextNode, dynamicIndentation);
-          if (!rangeHasError) {
-            if (lineAction === 0 /* None */) {
-              const prevEndLine = savePreviousRange && sourceFile.getLineAndCharacterOfPosition(savePreviousRange.end).line;
-              indentToken = lastTriviaWasNewLine && tokenStart.line !== prevEndLine;
-            } else {
-              indentToken = lineAction === 1 /* LineAdded */;
-            }
-          }
-        }
-        if (currentTokenInfo.trailingTrivia) {
-          previousRangeTriviaEnd = last(currentTokenInfo.trailingTrivia).end;
-          processTrivia(currentTokenInfo.trailingTrivia, parent2, childContextNode, dynamicIndentation);
-        }
-        if (indentToken) {
-          const tokenIndentation = isTokenInRange && !rangeContainsError(currentTokenInfo.token) ? dynamicIndentation.getIndentationForToken(tokenStart.line, currentTokenInfo.token.kind, container, !!isListEndToken) : -1 /* Unknown */;
-          let indentNextTokenOrTrivia = true;
-          if (currentTokenInfo.leadingTrivia) {
-            const commentIndentation = dynamicIndentation.getIndentationForComment(currentTokenInfo.token.kind, tokenIndentation, container);
-            indentNextTokenOrTrivia = indentTriviaItems(
-              currentTokenInfo.leadingTrivia,
-              commentIndentation,
-              indentNextTokenOrTrivia,
-              (item) => insertIndentation(
-                item.pos,
-                commentIndentation,
-                /*lineAdded*/
-                false
-              )
-            );
-          }
-          if (tokenIndentation !== -1 /* Unknown */ && indentNextTokenOrTrivia) {
-            insertIndentation(currentTokenInfo.token.pos, tokenIndentation, lineAction === 1 /* LineAdded */);
-            lastIndentedLine = tokenStart.line;
-            indentationOnLastIndentedLine = tokenIndentation;
-          }
-        }
-        formattingScanner.advance();
-        childContextNode = parent2;
-      }
-    }
-    function indentTriviaItems(trivia, commentIndentation, indentNextTokenOrTrivia, indentSingleLine) {
-      for (const triviaItem of trivia) {
-        const triviaInRange = rangeContainsRange(originalRange, triviaItem);
-        switch (triviaItem.kind) {
-          case 3 /* MultiLineCommentTrivia */:
-            if (triviaInRange) {
-              indentMultilineComment(
-                triviaItem,
-                commentIndentation,
-                /*firstLineIsIndented*/
-                !indentNextTokenOrTrivia
-              );
-            }
-            indentNextTokenOrTrivia = false;
-            break;
-          case 2 /* SingleLineCommentTrivia */:
-            if (indentNextTokenOrTrivia && triviaInRange) {
-              indentSingleLine(triviaItem);
-            }
-            indentNextTokenOrTrivia = false;
-            break;
-          case 4 /* NewLineTrivia */:
-            indentNextTokenOrTrivia = true;
-            break;
-        }
-      }
-      return indentNextTokenOrTrivia;
-    }
-    function processTrivia(trivia, parent2, contextNode, dynamicIndentation) {
-      for (const triviaItem of trivia) {
-        if (isComment(triviaItem.kind) && rangeContainsRange(originalRange, triviaItem)) {
-          const triviaItemStart = sourceFile.getLineAndCharacterOfPosition(triviaItem.pos);
-          processRange(triviaItem, triviaItemStart, parent2, contextNode, dynamicIndentation);
-        }
-      }
-    }
-    function processRange(range, rangeStart, parent2, contextNode, dynamicIndentation) {
-      const rangeHasError = rangeContainsError(range);
-      let lineAction = 0 /* None */;
-      if (!rangeHasError) {
-        if (!previousRange) {
-          const originalStart = sourceFile.getLineAndCharacterOfPosition(originalRange.pos);
-          trimTrailingWhitespacesForLines(originalStart.line, rangeStart.line);
-        } else {
-          lineAction = processPair(range, rangeStart.line, parent2, previousRange, previousRangeStartLine, previousParent, contextNode, dynamicIndentation);
-        }
-      }
-      previousRange = range;
-      previousRangeTriviaEnd = range.end;
-      previousParent = parent2;
-      previousRangeStartLine = rangeStart.line;
-      return lineAction;
-    }
-    function processPair(currentItem, currentStartLine, currentParent, previousItem, previousStartLine, previousParent2, contextNode, dynamicIndentation) {
-      formattingContext.updateContext(previousItem, previousParent2, currentItem, currentParent, contextNode);
-      const rules = getRules(formattingContext);
-      let trimTrailingWhitespaces = formattingContext.options.trimTrailingWhitespace !== false;
-      let lineAction = 0 /* None */;
-      if (rules) {
-        forEachRight(rules, (rule2) => {
-          lineAction = applyRuleEdits(rule2, previousItem, previousStartLine, currentItem, currentStartLine);
-          if (dynamicIndentation) {
-            switch (lineAction) {
-              case 2 /* LineRemoved */:
-                if (currentParent.getStart(sourceFile) === currentItem.pos) {
-                  dynamicIndentation.recomputeIndentation(
-                    /*lineAddedByFormatting*/
-                    false,
-                    contextNode
-                  );
-                }
-                break;
-              case 1 /* LineAdded */:
-                if (currentParent.getStart(sourceFile) === currentItem.pos) {
-                  dynamicIndentation.recomputeIndentation(
-                    /*lineAddedByFormatting*/
-                    true,
-                    contextNode
-                  );
-                }
-                break;
-              default:
-                Debug.assert(lineAction === 0 /* None */);
-            }
-          }
-          trimTrailingWhitespaces = trimTrailingWhitespaces && !(rule2.action & 16 /* DeleteSpace */) && rule2.flags !== 1 /* CanDeleteNewLines */;
-        });
-      } else {
-        trimTrailingWhitespaces = trimTrailingWhitespaces && currentItem.kind !== 1 /* EndOfFileToken */;
-      }
-      if (currentStartLine !== previousStartLine && trimTrailingWhitespaces) {
-        trimTrailingWhitespacesForLines(previousStartLine, currentStartLine, previousItem);
-      }
-      return lineAction;
-    }
-    function insertIndentation(pos, indentation, lineAdded) {
-      const indentationString = getIndentationString(indentation, options);
-      if (lineAdded) {
-        recordReplace(pos, 0, indentationString);
-      } else {
-        const tokenStart = sourceFile.getLineAndCharacterOfPosition(pos);
-        const startLinePosition = getStartPositionOfLine(tokenStart.line, sourceFile);
-        if (indentation !== characterToColumn(startLinePosition, tokenStart.character) || indentationIsDifferent(indentationString, startLinePosition)) {
-          recordReplace(startLinePosition, tokenStart.character, indentationString);
-        }
-      }
-    }
-    function characterToColumn(startLinePosition, characterInLine) {
-      let column = 0;
-      for (let i = 0; i < characterInLine; i++) {
-        if (sourceFile.text.charCodeAt(startLinePosition + i) === 9 /* tab */) {
-          column += options.tabSize - column % options.tabSize;
-        } else {
-          column++;
-        }
-      }
-      return column;
-    }
-    function indentationIsDifferent(indentationString, startLinePosition) {
-      return indentationString !== sourceFile.text.substr(startLinePosition, indentationString.length);
-    }
-    function indentMultilineComment(commentRange, indentation, firstLineIsIndented, indentFinalLine = true) {
-      let startLine = sourceFile.getLineAndCharacterOfPosition(commentRange.pos).line;
-      const endLine = sourceFile.getLineAndCharacterOfPosition(commentRange.end).line;
-      if (startLine === endLine) {
-        if (!firstLineIsIndented) {
-          insertIndentation(
-            commentRange.pos,
-            indentation,
-            /*lineAdded*/
-            false
-          );
-        }
-        return;
-      }
-      const parts = [];
-      let startPos = commentRange.pos;
-      for (let line = startLine; line < endLine; line++) {
-        const endOfLine = getEndLinePosition(line, sourceFile);
-        parts.push({ pos: startPos, end: endOfLine });
-        startPos = getStartPositionOfLine(line + 1, sourceFile);
-      }
-      if (indentFinalLine) {
-        parts.push({ pos: startPos, end: commentRange.end });
-      }
-      if (parts.length === 0)
-        return;
-      const startLinePos = getStartPositionOfLine(startLine, sourceFile);
-      const nonWhitespaceColumnInFirstPart = SmartIndenter.findFirstNonWhitespaceCharacterAndColumn(startLinePos, parts[0].pos, sourceFile, options);
-      let startIndex = 0;
-      if (firstLineIsIndented) {
-        startIndex = 1;
-        startLine++;
-      }
-      const delta2 = indentation - nonWhitespaceColumnInFirstPart.column;
-      for (let i = startIndex; i < parts.length; i++, startLine++) {
-        const startLinePos2 = getStartPositionOfLine(startLine, sourceFile);
-        const nonWhitespaceCharacterAndColumn = i === 0 ? nonWhitespaceColumnInFirstPart : SmartIndenter.findFirstNonWhitespaceCharacterAndColumn(parts[i].pos, parts[i].end, sourceFile, options);
-        const newIndentation = nonWhitespaceCharacterAndColumn.column + delta2;
-        if (newIndentation > 0) {
-          const indentationString = getIndentationString(newIndentation, options);
-          recordReplace(startLinePos2, nonWhitespaceCharacterAndColumn.character, indentationString);
-        } else {
-          recordDelete(startLinePos2, nonWhitespaceCharacterAndColumn.character);
-        }
-      }
-    }
-    function trimTrailingWhitespacesForLines(line1, line2, range) {
-      for (let line = line1; line < line2; line++) {
-        const lineStartPosition = getStartPositionOfLine(line, sourceFile);
-        const lineEndPosition = getEndLinePosition(line, sourceFile);
-        if (range && (isComment(range.kind) || isStringOrRegularExpressionOrTemplateLiteral(range.kind)) && range.pos <= lineEndPosition && range.end > lineEndPosition) {
-          continue;
-        }
-        const whitespaceStart = getTrailingWhitespaceStartPosition(lineStartPosition, lineEndPosition);
-        if (whitespaceStart !== -1) {
-          Debug.assert(whitespaceStart === lineStartPosition || !isWhiteSpaceSingleLine(sourceFile.text.charCodeAt(whitespaceStart - 1)));
-          recordDelete(whitespaceStart, lineEndPosition + 1 - whitespaceStart);
-        }
-      }
-    }
-    function getTrailingWhitespaceStartPosition(start, end) {
-      let pos = end;
-      while (pos >= start && isWhiteSpaceSingleLine(sourceFile.text.charCodeAt(pos))) {
-        pos--;
-      }
-      if (pos !== end) {
-        return pos + 1;
-      }
-      return -1;
-    }
-    function trimTrailingWhitespacesForRemainingRange(trivias) {
-      let startPos = previousRange ? previousRange.end : originalRange.pos;
-      for (const trivia of trivias) {
-        if (isComment(trivia.kind)) {
-          if (startPos < trivia.pos) {
-            trimTrailingWitespacesForPositions(startPos, trivia.pos - 1, previousRange);
-          }
-          startPos = trivia.end + 1;
-        }
-      }
-      if (startPos < originalRange.end) {
-        trimTrailingWitespacesForPositions(startPos, originalRange.end, previousRange);
-      }
-    }
-    function trimTrailingWitespacesForPositions(startPos, endPos, previousRange2) {
-      const startLine = sourceFile.getLineAndCharacterOfPosition(startPos).line;
-      const endLine = sourceFile.getLineAndCharacterOfPosition(endPos).line;
-      trimTrailingWhitespacesForLines(startLine, endLine + 1, previousRange2);
-    }
-    function recordDelete(start, len) {
-      if (len) {
-        edits.push(createTextChangeFromStartLength(start, len, ""));
-      }
-    }
-    function recordReplace(start, len, newText) {
-      if (len || newText) {
-        edits.push(createTextChangeFromStartLength(start, len, newText));
-      }
-    }
-    function recordInsert(start, text) {
-      if (text) {
-        edits.push(createTextChangeFromStartLength(start, 0, text));
-      }
-    }
-    function applyRuleEdits(rule2, previousRange2, previousStartLine, currentRange, currentStartLine) {
-      const onLaterLine = currentStartLine !== previousStartLine;
-      switch (rule2.action) {
-        case 1 /* StopProcessingSpaceActions */:
-          return 0 /* None */;
-        case 16 /* DeleteSpace */:
-          if (previousRange2.end !== currentRange.pos) {
-            recordDelete(previousRange2.end, currentRange.pos - previousRange2.end);
-            return onLaterLine ? 2 /* LineRemoved */ : 0 /* None */;
-          }
-          break;
-        case 32 /* DeleteToken */:
-          recordDelete(previousRange2.pos, previousRange2.end - previousRange2.pos);
-          break;
-        case 8 /* InsertNewLine */:
-          if (rule2.flags !== 1 /* CanDeleteNewLines */ && previousStartLine !== currentStartLine) {
-            return 0 /* None */;
-          }
-          const lineDelta = currentStartLine - previousStartLine;
-          if (lineDelta !== 1) {
-            recordReplace(previousRange2.end, currentRange.pos - previousRange2.end, getNewLineOrDefaultFromHost(host, options));
-            return onLaterLine ? 0 /* None */ : 1 /* LineAdded */;
-          }
-          break;
-        case 4 /* InsertSpace */:
-          if (rule2.flags !== 1 /* CanDeleteNewLines */ && previousStartLine !== currentStartLine) {
-            return 0 /* None */;
-          }
-          const posDelta = currentRange.pos - previousRange2.end;
-          if (posDelta !== 1 || sourceFile.text.charCodeAt(previousRange2.end) !== 32 /* space */) {
-            recordReplace(previousRange2.end, currentRange.pos - previousRange2.end, " ");
-            return onLaterLine ? 2 /* LineRemoved */ : 0 /* None */;
-          }
-          break;
-        case 64 /* InsertTrailingSemicolon */:
-          recordInsert(previousRange2.end, ";");
-      }
-      return 0 /* None */;
-    }
-  }
-  function getRangeOfEnclosingComment(sourceFile, position, precedingToken, tokenAtPosition = getTokenAtPosition(sourceFile, position)) {
-    const jsdoc = findAncestor(tokenAtPosition, isJSDoc);
-    if (jsdoc)
-      tokenAtPosition = jsdoc.parent;
-    const tokenStart = tokenAtPosition.getStart(sourceFile);
-    if (tokenStart <= position && position < tokenAtPosition.getEnd()) {
-      return void 0;
-    }
-    precedingToken = precedingToken === null ? void 0 : precedingToken === void 0 ? findPrecedingToken(position, sourceFile) : precedingToken;
-    const trailingRangesOfPreviousToken = precedingToken && getTrailingCommentRanges(sourceFile.text, precedingToken.end);
-    const leadingCommentRangesOfNextToken = getLeadingCommentRangesOfNode(tokenAtPosition, sourceFile);
-    const commentRanges = concatenate(trailingRangesOfPreviousToken, leadingCommentRangesOfNextToken);
-    return commentRanges && find(commentRanges, (range) => rangeContainsPositionExclusive(range, position) || // The end marker of a single-line comment does not include the newline character.
-    // With caret at `^`, in the following case, we are inside a comment (^ denotes the cursor position):
-    //
-    //    // asdf   ^\n
-    //
-    // But for closed multi-line comments, we don't want to be inside the comment in the following case:
-    //
-    //    /* asdf */^
-    //
-    // However, unterminated multi-line comments *do* contain their end.
-    //
-    // Internally, we represent the end of the comment at the newline and closing '/', respectively.
-    //
-    position === range.end && (range.kind === 2 /* SingleLineCommentTrivia */ || position === sourceFile.getFullWidth()));
-  }
-  function getOpenTokenForList(node, list) {
-    switch (node.kind) {
-      case 175 /* Constructor */:
-      case 261 /* FunctionDeclaration */:
-      case 217 /* FunctionExpression */:
-      case 173 /* MethodDeclaration */:
-      case 172 /* MethodSignature */:
-      case 218 /* ArrowFunction */:
-      case 178 /* CallSignature */:
-      case 179 /* ConstructSignature */:
-      case 183 /* FunctionType */:
-      case 184 /* ConstructorType */:
-      case 176 /* GetAccessor */:
-      case 177 /* SetAccessor */:
-        if (node.typeParameters === list) {
-          return 30 /* LessThanToken */;
-        } else if (node.parameters === list) {
-          return 21 /* OpenParenToken */;
-        }
-        break;
-      case 212 /* CallExpression */:
-      case 213 /* NewExpression */:
-        if (node.typeArguments === list) {
-          return 30 /* LessThanToken */;
-        } else if (node.arguments === list) {
-          return 21 /* OpenParenToken */;
-        }
-        break;
-      case 262 /* ClassDeclaration */:
-      case 230 /* ClassExpression */:
-      case 263 /* InterfaceDeclaration */:
-      case 264 /* TypeAliasDeclaration */:
-        if (node.typeParameters === list) {
-          return 30 /* LessThanToken */;
-        }
-        break;
-      case 182 /* TypeReference */:
-      case 214 /* TaggedTemplateExpression */:
-      case 185 /* TypeQuery */:
-      case 232 /* ExpressionWithTypeArguments */:
-      case 204 /* ImportType */:
-        if (node.typeArguments === list) {
-          return 30 /* LessThanToken */;
-        }
-        break;
-      case 186 /* TypeLiteral */:
-        return 19 /* OpenBraceToken */;
-    }
-    return 0 /* Unknown */;
-  }
-  function getCloseTokenForOpenToken(kind) {
-    switch (kind) {
-      case 21 /* OpenParenToken */:
-        return 22 /* CloseParenToken */;
-      case 30 /* LessThanToken */:
-        return 32 /* GreaterThanToken */;
-      case 19 /* OpenBraceToken */:
-        return 20 /* CloseBraceToken */;
-    }
-    return 0 /* Unknown */;
-  }
-  function getIndentationString(indentation, options) {
-    const resetInternedStrings = !internedSizes || (internedSizes.tabSize !== options.tabSize || internedSizes.indentSize !== options.indentSize);
-    if (resetInternedStrings) {
-      internedSizes = { tabSize: options.tabSize, indentSize: options.indentSize };
-      internedTabsIndentation = internedSpacesIndentation = void 0;
-    }
-    if (!options.convertTabsToSpaces) {
-      const tabs = Math.floor(indentation / options.tabSize);
-      const spaces = indentation - tabs * options.tabSize;
-      let tabString;
-      if (!internedTabsIndentation) {
-        internedTabsIndentation = [];
-      }
-      if (internedTabsIndentation[tabs] === void 0) {
-        internedTabsIndentation[tabs] = tabString = repeatString("	", tabs);
-      } else {
-        tabString = internedTabsIndentation[tabs];
-      }
-      return spaces ? tabString + repeatString(" ", spaces) : tabString;
-    } else {
-      let spacesString;
-      const quotient = Math.floor(indentation / options.indentSize);
-      const remainder = indentation % options.indentSize;
-      if (!internedSpacesIndentation) {
-        internedSpacesIndentation = [];
-      }
-      if (internedSpacesIndentation[quotient] === void 0) {
-        spacesString = repeatString(" ", options.indentSize * quotient);
-        internedSpacesIndentation[quotient] = spacesString;
-      } else {
-        spacesString = internedSpacesIndentation[quotient];
-      }
-      return remainder ? spacesString + repeatString(" ", remainder) : spacesString;
-    }
-  }
-  var internedSizes, internedTabsIndentation, internedSpacesIndentation;
-  var init_formatting = __esm({
-    "src/services/formatting/formatting.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_formatting();
-    }
-  });
-
-  // src/services/formatting/smartIndenter.ts
-  var SmartIndenter;
-  var init_smartIndenter = __esm({
-    "src/services/formatting/smartIndenter.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_formatting();
-      ((SmartIndenter2) => {
-        let Value;
-        ((Value2) => {
-          Value2[Value2["Unknown"] = -1] = "Unknown";
-        })(Value || (Value = {}));
-        function getIndentation(position, sourceFile, options, assumeNewLineBeforeCloseBrace = false) {
-          if (position > sourceFile.text.length) {
-            return getBaseIndentation(options);
-          }
-          if (options.indentStyle === 0 /* None */) {
-            return 0;
-          }
-          const precedingToken = findPrecedingToken(
-            position,
-            sourceFile,
-            /*startNode*/
-            void 0,
-            /*excludeJsdoc*/
-            true
-          );
-          const enclosingCommentRange = getRangeOfEnclosingComment(sourceFile, position, precedingToken || null);
-          if (enclosingCommentRange && enclosingCommentRange.kind === 3 /* MultiLineCommentTrivia */) {
-            return getCommentIndent(sourceFile, position, options, enclosingCommentRange);
-          }
-          if (!precedingToken) {
-            return getBaseIndentation(options);
-          }
-          const precedingTokenIsLiteral = isStringOrRegularExpressionOrTemplateLiteral(precedingToken.kind);
-          if (precedingTokenIsLiteral && precedingToken.getStart(sourceFile) <= position && position < precedingToken.end) {
-            return 0;
-          }
-          const lineAtPosition = sourceFile.getLineAndCharacterOfPosition(position).line;
-          const currentToken = getTokenAtPosition(sourceFile, position);
-          const isObjectLiteral = currentToken.kind === 19 /* OpenBraceToken */ && currentToken.parent.kind === 209 /* ObjectLiteralExpression */;
-          if (options.indentStyle === 1 /* Block */ || isObjectLiteral) {
-            return getBlockIndent(sourceFile, position, options);
-          }
-          if (precedingToken.kind === 28 /* CommaToken */ && precedingToken.parent.kind !== 225 /* BinaryExpression */) {
-            const actualIndentation = getActualIndentationForListItemBeforeComma(precedingToken, sourceFile, options);
-            if (actualIndentation !== -1 /* Unknown */) {
-              return actualIndentation;
-            }
-          }
-          const containerList = getListByPosition(position, precedingToken.parent, sourceFile);
-          if (containerList && !rangeContainsRange(containerList, precedingToken)) {
-            const useTheSameBaseIndentation = [217 /* FunctionExpression */, 218 /* ArrowFunction */].indexOf(currentToken.parent.kind) !== -1;
-            const indentSize = useTheSameBaseIndentation ? 0 : options.indentSize;
-            return getActualIndentationForListStartLine(containerList, sourceFile, options) + indentSize;
-          }
-          return getSmartIndent(sourceFile, position, precedingToken, lineAtPosition, assumeNewLineBeforeCloseBrace, options);
-        }
-        SmartIndenter2.getIndentation = getIndentation;
-        function getCommentIndent(sourceFile, position, options, enclosingCommentRange) {
-          const previousLine = getLineAndCharacterOfPosition(sourceFile, position).line - 1;
-          const commentStartLine = getLineAndCharacterOfPosition(sourceFile, enclosingCommentRange.pos).line;
-          Debug.assert(commentStartLine >= 0);
-          if (previousLine <= commentStartLine) {
-            return findFirstNonWhitespaceColumn(getStartPositionOfLine(commentStartLine, sourceFile), position, sourceFile, options);
-          }
-          const startPositionOfLine = getStartPositionOfLine(previousLine, sourceFile);
-          const { column, character } = findFirstNonWhitespaceCharacterAndColumn(startPositionOfLine, position, sourceFile, options);
-          if (column === 0) {
-            return column;
-          }
-          const firstNonWhitespaceCharacterCode = sourceFile.text.charCodeAt(startPositionOfLine + character);
-          return firstNonWhitespaceCharacterCode === 42 /* asterisk */ ? column - 1 : column;
-        }
-        function getBlockIndent(sourceFile, position, options) {
-          let current = position;
-          while (current > 0) {
-            const char = sourceFile.text.charCodeAt(current);
-            if (!isWhiteSpaceLike(char)) {
-              break;
-            }
-            current--;
-          }
-          const lineStart = getLineStartPositionForPosition(current, sourceFile);
-          return findFirstNonWhitespaceColumn(lineStart, current, sourceFile, options);
-        }
-        function getSmartIndent(sourceFile, position, precedingToken, lineAtPosition, assumeNewLineBeforeCloseBrace, options) {
-          let previous;
-          let current = precedingToken;
-          while (current) {
-            if (positionBelongsToNode(current, position, sourceFile) && shouldIndentChildNode(
-              options,
-              current,
-              previous,
-              sourceFile,
-              /*isNextChild*/
-              true
-            )) {
-              const currentStart = getStartLineAndCharacterForNode(current, sourceFile);
-              const nextTokenKind = nextTokenIsCurlyBraceOnSameLineAsCursor(precedingToken, current, lineAtPosition, sourceFile);
-              const indentationDelta = nextTokenKind !== 0 /* Unknown */ ? assumeNewLineBeforeCloseBrace && nextTokenKind === 2 /* CloseBrace */ ? options.indentSize : 0 : lineAtPosition !== currentStart.line ? options.indentSize : 0;
-              return getIndentationForNodeWorker(
-                current,
-                currentStart,
-                /*ignoreActualIndentationRange*/
-                void 0,
-                indentationDelta,
-                sourceFile,
-                /*isNextChild*/
-                true,
-                options
-              );
-            }
-            const actualIndentation = getActualIndentationForListItem(
-              current,
-              sourceFile,
-              options,
-              /*listIndentsChild*/
-              true
-            );
-            if (actualIndentation !== -1 /* Unknown */) {
-              return actualIndentation;
-            }
-            previous = current;
-            current = current.parent;
-          }
-          return getBaseIndentation(options);
-        }
-        function getIndentationForNode(n, ignoreActualIndentationRange, sourceFile, options) {
-          const start = sourceFile.getLineAndCharacterOfPosition(n.getStart(sourceFile));
-          return getIndentationForNodeWorker(
-            n,
-            start,
-            ignoreActualIndentationRange,
-            /*indentationDelta*/
-            0,
-            sourceFile,
-            /*isNextChild*/
-            false,
-            options
-          );
-        }
-        SmartIndenter2.getIndentationForNode = getIndentationForNode;
-        function getBaseIndentation(options) {
-          return options.baseIndentSize || 0;
-        }
-        SmartIndenter2.getBaseIndentation = getBaseIndentation;
-        function getIndentationForNodeWorker(current, currentStart, ignoreActualIndentationRange, indentationDelta, sourceFile, isNextChild, options) {
-          var _a;
-          let parent2 = current.parent;
-          while (parent2) {
-            let useActualIndentation = true;
-            if (ignoreActualIndentationRange) {
-              const start = current.getStart(sourceFile);
-              useActualIndentation = start < ignoreActualIndentationRange.pos || start > ignoreActualIndentationRange.end;
-            }
-            const containingListOrParentStart = getContainingListOrParentStart(parent2, current, sourceFile);
-            const parentAndChildShareLine = containingListOrParentStart.line === currentStart.line || childStartsOnTheSameLineWithElseInIfStatement(parent2, current, currentStart.line, sourceFile);
-            if (useActualIndentation) {
-              const firstListChild = (_a = getContainingList(current, sourceFile)) == null ? void 0 : _a[0];
-              const listIndentsChild = !!firstListChild && getStartLineAndCharacterForNode(firstListChild, sourceFile).line > containingListOrParentStart.line;
-              let actualIndentation = getActualIndentationForListItem(current, sourceFile, options, listIndentsChild);
-              if (actualIndentation !== -1 /* Unknown */) {
-                return actualIndentation + indentationDelta;
-              }
-              actualIndentation = getActualIndentationForNode(current, parent2, currentStart, parentAndChildShareLine, sourceFile, options);
-              if (actualIndentation !== -1 /* Unknown */) {
-                return actualIndentation + indentationDelta;
-              }
-            }
-            if (shouldIndentChildNode(options, parent2, current, sourceFile, isNextChild) && !parentAndChildShareLine) {
-              indentationDelta += options.indentSize;
-            }
-            const useTrueStart = isArgumentAndStartLineOverlapsExpressionBeingCalled(parent2, current, currentStart.line, sourceFile);
-            current = parent2;
-            parent2 = current.parent;
-            currentStart = useTrueStart ? sourceFile.getLineAndCharacterOfPosition(current.getStart(sourceFile)) : containingListOrParentStart;
-          }
-          return indentationDelta + getBaseIndentation(options);
-        }
-        function getContainingListOrParentStart(parent2, child, sourceFile) {
-          const containingList = getContainingList(child, sourceFile);
-          const startPos = containingList ? containingList.pos : parent2.getStart(sourceFile);
-          return sourceFile.getLineAndCharacterOfPosition(startPos);
-        }
-        function getActualIndentationForListItemBeforeComma(commaToken, sourceFile, options) {
-          const commaItemInfo = findListItemInfo(commaToken);
-          if (commaItemInfo && commaItemInfo.listItemIndex > 0) {
-            return deriveActualIndentationFromList(commaItemInfo.list.getChildren(), commaItemInfo.listItemIndex - 1, sourceFile, options);
-          } else {
-            return -1 /* Unknown */;
-          }
-        }
-        function getActualIndentationForNode(current, parent2, currentLineAndChar, parentAndChildShareLine, sourceFile, options) {
-          const useActualIndentation = (isDeclaration(current) || isStatementButNotDeclaration(current)) && (parent2.kind === 311 /* SourceFile */ || !parentAndChildShareLine);
-          if (!useActualIndentation) {
-            return -1 /* Unknown */;
-          }
-          return findColumnForFirstNonWhitespaceCharacterInLine(currentLineAndChar, sourceFile, options);
-        }
-        let NextTokenKind;
-        ((NextTokenKind2) => {
-          NextTokenKind2[NextTokenKind2["Unknown"] = 0] = "Unknown";
-          NextTokenKind2[NextTokenKind2["OpenBrace"] = 1] = "OpenBrace";
-          NextTokenKind2[NextTokenKind2["CloseBrace"] = 2] = "CloseBrace";
-        })(NextTokenKind || (NextTokenKind = {}));
-        function nextTokenIsCurlyBraceOnSameLineAsCursor(precedingToken, current, lineAtPosition, sourceFile) {
-          const nextToken = findNextToken(precedingToken, current, sourceFile);
-          if (!nextToken) {
-            return 0 /* Unknown */;
-          }
-          if (nextToken.kind === 19 /* OpenBraceToken */) {
-            return 1 /* OpenBrace */;
-          } else if (nextToken.kind === 20 /* CloseBraceToken */) {
-            const nextTokenStartLine = getStartLineAndCharacterForNode(nextToken, sourceFile).line;
-            return lineAtPosition === nextTokenStartLine ? 2 /* CloseBrace */ : 0 /* Unknown */;
-          }
-          return 0 /* Unknown */;
-        }
-        function getStartLineAndCharacterForNode(n, sourceFile) {
-          return sourceFile.getLineAndCharacterOfPosition(n.getStart(sourceFile));
-        }
-        function isArgumentAndStartLineOverlapsExpressionBeingCalled(parent2, child, childStartLine, sourceFile) {
-          if (!(isCallExpression(parent2) && contains(parent2.arguments, child))) {
-            return false;
-          }
-          const expressionOfCallExpressionEnd = parent2.expression.getEnd();
-          const expressionOfCallExpressionEndLine = getLineAndCharacterOfPosition(sourceFile, expressionOfCallExpressionEnd).line;
-          return expressionOfCallExpressionEndLine === childStartLine;
-        }
-        SmartIndenter2.isArgumentAndStartLineOverlapsExpressionBeingCalled = isArgumentAndStartLineOverlapsExpressionBeingCalled;
-        function childStartsOnTheSameLineWithElseInIfStatement(parent2, child, childStartLine, sourceFile) {
-          if (parent2.kind === 244 /* IfStatement */ && parent2.elseStatement === child) {
-            const elseKeyword = findChildOfKind(parent2, 93 /* ElseKeyword */, sourceFile);
-            Debug.assert(elseKeyword !== void 0);
-            const elseKeywordStartLine = getStartLineAndCharacterForNode(elseKeyword, sourceFile).line;
-            return elseKeywordStartLine === childStartLine;
-          }
-          return false;
-        }
-        SmartIndenter2.childStartsOnTheSameLineWithElseInIfStatement = childStartsOnTheSameLineWithElseInIfStatement;
-        function childIsUnindentedBranchOfConditionalExpression(parent2, child, childStartLine, sourceFile) {
-          if (isConditionalExpression(parent2) && (child === parent2.whenTrue || child === parent2.whenFalse)) {
-            const conditionEndLine = getLineAndCharacterOfPosition(sourceFile, parent2.condition.end).line;
-            if (child === parent2.whenTrue) {
-              return childStartLine === conditionEndLine;
-            } else {
-              const trueStartLine = getStartLineAndCharacterForNode(parent2.whenTrue, sourceFile).line;
-              const trueEndLine = getLineAndCharacterOfPosition(sourceFile, parent2.whenTrue.end).line;
-              return conditionEndLine === trueStartLine && trueEndLine === childStartLine;
-            }
-          }
-          return false;
-        }
-        SmartIndenter2.childIsUnindentedBranchOfConditionalExpression = childIsUnindentedBranchOfConditionalExpression;
-        function argumentStartsOnSameLineAsPreviousArgument(parent2, child, childStartLine, sourceFile) {
-          if (isCallOrNewExpression(parent2)) {
-            if (!parent2.arguments)
-              return false;
-            const currentNode = find(parent2.arguments, (arg) => arg.pos === child.pos);
-            if (!currentNode)
-              return false;
-            const currentIndex = parent2.arguments.indexOf(currentNode);
-            if (currentIndex === 0)
-              return false;
-            const previousNode = parent2.arguments[currentIndex - 1];
-            const lineOfPreviousNode = getLineAndCharacterOfPosition(sourceFile, previousNode.getEnd()).line;
-            if (childStartLine === lineOfPreviousNode) {
-              return true;
-            }
-          }
-          return false;
-        }
-        SmartIndenter2.argumentStartsOnSameLineAsPreviousArgument = argumentStartsOnSameLineAsPreviousArgument;
-        function getContainingList(node, sourceFile) {
-          return node.parent && getListByRange(node.getStart(sourceFile), node.getEnd(), node.parent, sourceFile);
-        }
-        SmartIndenter2.getContainingList = getContainingList;
-        function getListByPosition(pos, node, sourceFile) {
-          return node && getListByRange(pos, pos, node, sourceFile);
-        }
-        function getListByRange(start, end, node, sourceFile) {
-          switch (node.kind) {
-            case 182 /* TypeReference */:
-              return getList(node.typeArguments);
-            case 209 /* ObjectLiteralExpression */:
-              return getList(node.properties);
-            case 208 /* ArrayLiteralExpression */:
-              return getList(node.elements);
-            case 186 /* TypeLiteral */:
-              return getList(node.members);
-            case 261 /* FunctionDeclaration */:
-            case 217 /* FunctionExpression */:
-            case 218 /* ArrowFunction */:
-            case 173 /* MethodDeclaration */:
-            case 172 /* MethodSignature */:
-            case 178 /* CallSignature */:
-            case 175 /* Constructor */:
-            case 184 /* ConstructorType */:
-            case 179 /* ConstructSignature */:
-              return getList(node.typeParameters) || getList(node.parameters);
-            case 176 /* GetAccessor */:
-              return getList(node.parameters);
-            case 262 /* ClassDeclaration */:
-            case 230 /* ClassExpression */:
-            case 263 /* InterfaceDeclaration */:
-            case 264 /* TypeAliasDeclaration */:
-            case 351 /* JSDocTemplateTag */:
-              return getList(node.typeParameters);
-            case 213 /* NewExpression */:
-            case 212 /* CallExpression */:
-              return getList(node.typeArguments) || getList(node.arguments);
-            case 260 /* VariableDeclarationList */:
-              return getList(node.declarations);
-            case 274 /* NamedImports */:
-            case 278 /* NamedExports */:
-              return getList(node.elements);
-            case 205 /* ObjectBindingPattern */:
-            case 206 /* ArrayBindingPattern */:
-              return getList(node.elements);
-          }
-          function getList(list) {
-            return list && rangeContainsStartEnd(getVisualListRange(node, list, sourceFile), start, end) ? list : void 0;
-          }
-        }
-        function getVisualListRange(node, list, sourceFile) {
-          const children = node.getChildren(sourceFile);
-          for (let i = 1; i < children.length - 1; i++) {
-            if (children[i].pos === list.pos && children[i].end === list.end) {
-              return { pos: children[i - 1].end, end: children[i + 1].getStart(sourceFile) };
-            }
-          }
-          return list;
-        }
-        function getActualIndentationForListStartLine(list, sourceFile, options) {
-          if (!list) {
-            return -1 /* Unknown */;
-          }
-          return findColumnForFirstNonWhitespaceCharacterInLine(sourceFile.getLineAndCharacterOfPosition(list.pos), sourceFile, options);
-        }
-        function getActualIndentationForListItem(node, sourceFile, options, listIndentsChild) {
-          if (node.parent && node.parent.kind === 260 /* VariableDeclarationList */) {
-            return -1 /* Unknown */;
-          }
-          const containingList = getContainingList(node, sourceFile);
-          if (containingList) {
-            const index = containingList.indexOf(node);
-            if (index !== -1) {
-              const result = deriveActualIndentationFromList(containingList, index, sourceFile, options);
-              if (result !== -1 /* Unknown */) {
-                return result;
-              }
-            }
-            return getActualIndentationForListStartLine(containingList, sourceFile, options) + (listIndentsChild ? options.indentSize : 0);
-          }
-          return -1 /* Unknown */;
-        }
-        function deriveActualIndentationFromList(list, index, sourceFile, options) {
-          Debug.assert(index >= 0 && index < list.length);
-          const node = list[index];
-          let lineAndCharacter = getStartLineAndCharacterForNode(node, sourceFile);
-          for (let i = index - 1; i >= 0; i--) {
-            if (list[i].kind === 28 /* CommaToken */) {
-              continue;
-            }
-            const prevEndLine = sourceFile.getLineAndCharacterOfPosition(list[i].end).line;
-            if (prevEndLine !== lineAndCharacter.line) {
-              return findColumnForFirstNonWhitespaceCharacterInLine(lineAndCharacter, sourceFile, options);
-            }
-            lineAndCharacter = getStartLineAndCharacterForNode(list[i], sourceFile);
-          }
-          return -1 /* Unknown */;
-        }
-        function findColumnForFirstNonWhitespaceCharacterInLine(lineAndCharacter, sourceFile, options) {
-          const lineStart = sourceFile.getPositionOfLineAndCharacter(lineAndCharacter.line, 0);
-          return findFirstNonWhitespaceColumn(lineStart, lineStart + lineAndCharacter.character, sourceFile, options);
-        }
-        function findFirstNonWhitespaceCharacterAndColumn(startPos, endPos, sourceFile, options) {
-          let character = 0;
-          let column = 0;
-          for (let pos = startPos; pos < endPos; pos++) {
-            const ch = sourceFile.text.charCodeAt(pos);
-            if (!isWhiteSpaceSingleLine(ch)) {
-              break;
-            }
-            if (ch === 9 /* tab */) {
-              column += options.tabSize + column % options.tabSize;
-            } else {
-              column++;
-            }
-            character++;
-          }
-          return { column, character };
-        }
-        SmartIndenter2.findFirstNonWhitespaceCharacterAndColumn = findFirstNonWhitespaceCharacterAndColumn;
-        function findFirstNonWhitespaceColumn(startPos, endPos, sourceFile, options) {
-          return findFirstNonWhitespaceCharacterAndColumn(startPos, endPos, sourceFile, options).column;
-        }
-        SmartIndenter2.findFirstNonWhitespaceColumn = findFirstNonWhitespaceColumn;
-        function nodeWillIndentChild(settings, parent2, child, sourceFile, indentByDefault) {
-          const childKind = child ? child.kind : 0 /* Unknown */;
-          switch (parent2.kind) {
-            case 243 /* ExpressionStatement */:
-            case 262 /* ClassDeclaration */:
-            case 230 /* ClassExpression */:
-            case 263 /* InterfaceDeclaration */:
-            case 265 /* EnumDeclaration */:
-            case 264 /* TypeAliasDeclaration */:
-            case 208 /* ArrayLiteralExpression */:
-            case 240 /* Block */:
-            case 267 /* ModuleBlock */:
-            case 209 /* ObjectLiteralExpression */:
-            case 186 /* TypeLiteral */:
-            case 199 /* MappedType */:
-            case 188 /* TupleType */:
-            case 216 /* ParenthesizedExpression */:
-            case 210 /* PropertyAccessExpression */:
-            case 212 /* CallExpression */:
-            case 213 /* NewExpression */:
-            case 242 /* VariableStatement */:
-            case 276 /* ExportAssignment */:
-            case 252 /* ReturnStatement */:
-            case 226 /* ConditionalExpression */:
-            case 206 /* ArrayBindingPattern */:
-            case 205 /* ObjectBindingPattern */:
-            case 285 /* JsxOpeningElement */:
-            case 288 /* JsxOpeningFragment */:
-            case 284 /* JsxSelfClosingElement */:
-            case 293 /* JsxExpression */:
-            case 172 /* MethodSignature */:
-            case 178 /* CallSignature */:
-            case 179 /* ConstructSignature */:
-            case 168 /* Parameter */:
-            case 183 /* FunctionType */:
-            case 184 /* ConstructorType */:
-            case 195 /* ParenthesizedType */:
-            case 214 /* TaggedTemplateExpression */:
-            case 222 /* AwaitExpression */:
-            case 278 /* NamedExports */:
-            case 274 /* NamedImports */:
-            case 280 /* ExportSpecifier */:
-            case 275 /* ImportSpecifier */:
-            case 171 /* PropertyDeclaration */:
-            case 295 /* CaseClause */:
-            case 296 /* DefaultClause */:
-              return true;
-            case 268 /* CaseBlock */:
-              return settings.indentSwitchCase ?? true;
-            case 259 /* VariableDeclaration */:
-            case 302 /* PropertyAssignment */:
-            case 225 /* BinaryExpression */:
-              if (!settings.indentMultiLineObjectLiteralBeginningOnBlankLine && sourceFile && childKind === 209 /* ObjectLiteralExpression */) {
-                return rangeIsOnOneLine(sourceFile, child);
-              }
-              if (parent2.kind === 225 /* BinaryExpression */ && sourceFile && child && childKind === 283 /* JsxElement */) {
-                const parentStartLine = sourceFile.getLineAndCharacterOfPosition(skipTrivia(sourceFile.text, parent2.pos)).line;
-                const childStartLine = sourceFile.getLineAndCharacterOfPosition(skipTrivia(sourceFile.text, child.pos)).line;
-                return parentStartLine !== childStartLine;
-              }
-              if (parent2.kind !== 225 /* BinaryExpression */) {
-                return true;
-              }
-              break;
-            case 245 /* DoStatement */:
-            case 246 /* WhileStatement */:
-            case 248 /* ForInStatement */:
-            case 249 /* ForOfStatement */:
-            case 247 /* ForStatement */:
-            case 244 /* IfStatement */:
-            case 261 /* FunctionDeclaration */:
-            case 217 /* FunctionExpression */:
-            case 173 /* MethodDeclaration */:
-            case 175 /* Constructor */:
-            case 176 /* GetAccessor */:
-            case 177 /* SetAccessor */:
-              return childKind !== 240 /* Block */;
-            case 218 /* ArrowFunction */:
-              if (sourceFile && childKind === 216 /* ParenthesizedExpression */) {
-                return rangeIsOnOneLine(sourceFile, child);
-              }
-              return childKind !== 240 /* Block */;
-            case 277 /* ExportDeclaration */:
-              return childKind !== 278 /* NamedExports */;
-            case 271 /* ImportDeclaration */:
-              return childKind !== 272 /* ImportClause */ || !!child.namedBindings && child.namedBindings.kind !== 274 /* NamedImports */;
-            case 283 /* JsxElement */:
-              return childKind !== 286 /* JsxClosingElement */;
-            case 287 /* JsxFragment */:
-              return childKind !== 289 /* JsxClosingFragment */;
-            case 192 /* IntersectionType */:
-            case 191 /* UnionType */:
-              if (childKind === 186 /* TypeLiteral */ || childKind === 188 /* TupleType */) {
-                return false;
-              }
-              break;
-          }
-          return indentByDefault;
-        }
-        SmartIndenter2.nodeWillIndentChild = nodeWillIndentChild;
-        function isControlFlowEndingStatement(kind, parent2) {
-          switch (kind) {
-            case 252 /* ReturnStatement */:
-            case 256 /* ThrowStatement */:
-            case 250 /* ContinueStatement */:
-            case 251 /* BreakStatement */:
-              return parent2.kind !== 240 /* Block */;
-            default:
-              return false;
-          }
-        }
-        function shouldIndentChildNode(settings, parent2, child, sourceFile, isNextChild = false) {
-          return nodeWillIndentChild(
-            settings,
-            parent2,
-            child,
-            sourceFile,
-            /*indentByDefault*/
-            false
-          ) && !(isNextChild && child && isControlFlowEndingStatement(child.kind, parent2));
-        }
-        SmartIndenter2.shouldIndentChildNode = shouldIndentChildNode;
-        function rangeIsOnOneLine(sourceFile, range) {
-          const rangeStart = skipTrivia(sourceFile.text, range.pos);
-          const startLine = sourceFile.getLineAndCharacterOfPosition(rangeStart).line;
-          const endLine = sourceFile.getLineAndCharacterOfPosition(range.end).line;
-          return startLine === endLine;
-        }
-      })(SmartIndenter || (SmartIndenter = {}));
-    }
-  });
-
-  // src/services/_namespaces/ts.formatting.ts
-  var ts_formatting_exports = {};
-  __export(ts_formatting_exports, {
-    FormattingContext: () => FormattingContext,
-    FormattingRequestKind: () => FormattingRequestKind,
-    RuleAction: () => RuleAction,
-    RuleFlags: () => RuleFlags,
-    SmartIndenter: () => SmartIndenter,
-    anyContext: () => anyContext,
-    createTextRangeWithKind: () => createTextRangeWithKind,
-    formatDocument: () => formatDocument,
-    formatNodeGivenIndentation: () => formatNodeGivenIndentation,
-    formatOnClosingCurly: () => formatOnClosingCurly,
-    formatOnEnter: () => formatOnEnter,
-    formatOnOpeningCurly: () => formatOnOpeningCurly,
-    formatOnSemicolon: () => formatOnSemicolon,
-    formatSelection: () => formatSelection,
-    getAllRules: () => getAllRules,
-    getFormatContext: () => getFormatContext,
-    getFormattingScanner: () => getFormattingScanner,
-    getIndentationString: () => getIndentationString,
-    getRangeOfEnclosingComment: () => getRangeOfEnclosingComment
-  });
-  var init_ts_formatting = __esm({
-    "src/services/_namespaces/ts.formatting.ts"() {
-      "use strict";
-      init_formattingContext();
-      init_formattingScanner();
-      init_rule();
-      init_rules();
-      init_rulesMap();
-      init_formatting();
-      init_smartIndenter();
-    }
-  });
-
-  // src/services/_namespaces/ts.ts
-  var init_ts4 = __esm({
-    "src/services/_namespaces/ts.ts"() {
-      "use strict";
-      init_ts2();
-      init_ts3();
-      init_types3();
-      init_utilities4();
-      init_exportInfoMap();
-      init_classifier();
-      init_documentHighlights();
-      init_documentRegistry();
-      init_getEditsForFileRename();
-      init_patternMatcher();
-      init_preProcess();
-      init_sourcemaps();
-      init_suggestionDiagnostics();
-      init_transpile();
-      init_services();
-      init_transform();
-      init_shims();
-      init_ts_BreakpointResolver();
-      init_ts_CallHierarchy();
-      init_ts_classifier();
-      init_ts_codefix();
-      init_ts_Completions();
-      init_ts_FindAllReferences();
-      init_ts_GoToDefinition();
-      init_ts_InlayHints();
-      init_ts_JsDoc();
-      init_ts_NavigateTo();
-      init_ts_NavigationBar();
-      init_ts_OrganizeImports();
-      init_ts_OutliningElementsCollector();
-      init_ts_refactor();
-      init_ts_Rename();
-      init_ts_SignatureHelp();
-      init_ts_SmartSelectionRange();
-      init_ts_SymbolDisplay();
-      init_ts_textChanges();
-      init_ts_formatting();
-    }
-  });
-
-  // src/deprecatedCompat/deprecate.ts
-  function getTypeScriptVersion() {
-    return typeScriptVersion2 ?? (typeScriptVersion2 = new Version(version));
-  }
-  function formatDeprecationMessage(name, error, errorAfter, since, message) {
-    let deprecationMessage = error ? "DeprecationError: " : "DeprecationWarning: ";
-    deprecationMessage += `'${name}' `;
-    deprecationMessage += since ? `has been deprecated since v${since}` : "is deprecated";
-    deprecationMessage += error ? " and can no longer be used." : errorAfter ? ` and will no longer be usable after v${errorAfter}.` : ".";
-    deprecationMessage += message ? ` ${formatStringFromArgs(message, [name], 0)}` : "";
-    return deprecationMessage;
-  }
-  function createErrorDeprecation(name, errorAfter, since, message) {
-    const deprecationMessage = formatDeprecationMessage(
-      name,
-      /*error*/
-      true,
-      errorAfter,
-      since,
-      message
-    );
-    return () => {
-      throw new TypeError(deprecationMessage);
-    };
-  }
-  function createWarningDeprecation(name, errorAfter, since, message) {
-    let hasWrittenDeprecation = false;
-    return () => {
-      if (enableDeprecationWarnings && !hasWrittenDeprecation) {
-        Debug.log.warn(formatDeprecationMessage(
-          name,
-          /*error*/
-          false,
-          errorAfter,
-          since,
-          message
-        ));
-        hasWrittenDeprecation = true;
-      }
-    };
-  }
-  function createDeprecation(name, options = {}) {
-    const version2 = typeof options.typeScriptVersion === "string" ? new Version(options.typeScriptVersion) : options.typeScriptVersion ?? getTypeScriptVersion();
-    const errorAfter = typeof options.errorAfter === "string" ? new Version(options.errorAfter) : options.errorAfter;
-    const warnAfter = typeof options.warnAfter === "string" ? new Version(options.warnAfter) : options.warnAfter;
-    const since = typeof options.since === "string" ? new Version(options.since) : options.since ?? warnAfter;
-    const error = options.error || errorAfter && version2.compareTo(errorAfter) >= 0;
-    const warn = !warnAfter || version2.compareTo(warnAfter) >= 0;
-    return error ? createErrorDeprecation(name, errorAfter, since, options.message) : warn ? createWarningDeprecation(name, errorAfter, since, options.message) : noop;
-  }
-  function wrapFunction(deprecation, func) {
-    return function() {
-      deprecation();
-      return func.apply(this, arguments);
-    };
-  }
-  function deprecate(func, options) {
-    const deprecation = createDeprecation((options == null ? void 0 : options.name) ?? Debug.getFunctionName(func), options);
-    return wrapFunction(deprecation, func);
-  }
-  var enableDeprecationWarnings, typeScriptVersion2;
-  var init_deprecate = __esm({
-    "src/deprecatedCompat/deprecate.ts"() {
-      "use strict";
-      init_ts5();
-      enableDeprecationWarnings = true;
-    }
-  });
-
-  // src/deprecatedCompat/deprecations.ts
-  function createOverload(name, overloads, binder2, deprecations) {
-    Object.defineProperty(call, "name", { ...Object.getOwnPropertyDescriptor(call, "name"), value: name });
-    if (deprecations) {
-      for (const key of Object.keys(deprecations)) {
-        const index = +key;
-        if (!isNaN(index) && hasProperty(overloads, `${index}`)) {
-          overloads[index] = deprecate(overloads[index], { ...deprecations[index], name });
-        }
-      }
-    }
-    const bind = createBinder2(overloads, binder2);
-    return call;
-    function call(...args) {
-      const index = bind(args);
-      const fn = index !== void 0 ? overloads[index] : void 0;
-      if (typeof fn === "function") {
-        return fn(...args);
-      }
-      throw new TypeError("Invalid arguments");
-    }
-  }
-  function createBinder2(overloads, binder2) {
-    return (args) => {
-      for (let i = 0; hasProperty(overloads, `${i}`) && hasProperty(binder2, `${i}`); i++) {
-        const fn = binder2[i];
-        if (fn(args)) {
-          return i;
-        }
-      }
-    };
-  }
-  function buildOverload(name) {
-    return {
-      overload: (overloads) => ({
-        bind: (binder2) => ({
-          finish: () => createOverload(name, overloads, binder2),
-          deprecate: (deprecations) => ({
-            finish: () => createOverload(name, overloads, binder2, deprecations)
-          })
-        })
-      })
-    };
-  }
-  var init_deprecations = __esm({
-    "src/deprecatedCompat/deprecations.ts"() {
-      "use strict";
-      init_ts5();
-      init_deprecate();
-    }
-  });
-
-  // src/deprecatedCompat/5.0/identifierProperties.ts
-  var init_identifierProperties = __esm({
-    "src/deprecatedCompat/5.0/identifierProperties.ts"() {
-      "use strict";
-      init_ts5();
-      init_deprecate();
-      addObjectAllocatorPatcher((objectAllocator2) => {
-        const Identifier74 = objectAllocator2.getIdentifierConstructor();
-        if (!hasProperty(Identifier74.prototype, "originalKeywordKind")) {
-          Object.defineProperty(Identifier74.prototype, "originalKeywordKind", {
-            get: deprecate(function() {
-              return identifierToKeywordKind(this);
-            }, {
-              name: "originalKeywordKind",
-              since: "5.0",
-              warnAfter: "5.1",
-              errorAfter: "5.2",
-              message: "Use 'identifierToKeywordKind(identifier)' instead."
-            })
-          });
-        }
-        if (!hasProperty(Identifier74.prototype, "isInJSDocNamespace")) {
-          Object.defineProperty(Identifier74.prototype, "isInJSDocNamespace", {
-            get: deprecate(function() {
-              return this.flags & 2048 /* IdentifierIsInJSDocNamespace */ ? true : void 0;
-            }, {
-              name: "isInJSDocNamespace",
-              since: "5.0",
-              warnAfter: "5.1",
-              errorAfter: "5.2",
-              message: "Use '.parent' or the surrounding context to determine this instead."
-            })
-          });
-        }
-      });
-    }
-  });
-
-  // src/deprecatedCompat/_namespaces/ts.ts
-  var init_ts5 = __esm({
-    "src/deprecatedCompat/_namespaces/ts.ts"() {
-      "use strict";
-      init_ts2();
-      init_deprecations();
-      init_identifierProperties();
-    }
-  });
-
-  // src/typescript/_namespaces/ts.ts
-  var ts_exports2 = {};
-  __export(ts_exports2, {
-    ANONYMOUS: () => ANONYMOUS,
-    AccessFlags: () => AccessFlags,
-    AssertionLevel: () => AssertionLevel,
-    AssignmentDeclarationKind: () => AssignmentDeclarationKind,
-    AssignmentKind: () => AssignmentKind,
-    Associativity: () => Associativity,
-    BreakpointResolver: () => ts_BreakpointResolver_exports,
-    BuilderFileEmit: () => BuilderFileEmit,
-    BuilderProgramKind: () => BuilderProgramKind,
-    BuilderState: () => BuilderState,
-    BundleFileSectionKind: () => BundleFileSectionKind,
-    CallHierarchy: () => ts_CallHierarchy_exports,
-    CharacterCodes: () => CharacterCodes,
-    CheckFlags: () => CheckFlags,
-    CheckMode: () => CheckMode,
-    ClassificationType: () => ClassificationType,
-    ClassificationTypeNames: () => ClassificationTypeNames,
-    CommentDirectiveType: () => CommentDirectiveType,
-    Comparison: () => Comparison,
-    CompletionInfoFlags: () => CompletionInfoFlags,
-    CompletionTriggerKind: () => CompletionTriggerKind,
-    Completions: () => ts_Completions_exports,
-    ConfigFileProgramReloadLevel: () => ConfigFileProgramReloadLevel,
-    ContextFlags: () => ContextFlags,
-    CoreServicesShimHostAdapter: () => CoreServicesShimHostAdapter,
-    Debug: () => Debug,
-    DiagnosticCategory: () => DiagnosticCategory,
-    Diagnostics: () => Diagnostics,
-    DocumentHighlights: () => DocumentHighlights,
-    ElementFlags: () => ElementFlags,
-    EmitFlags: () => EmitFlags,
-    EmitHint: () => EmitHint,
-    EmitOnly: () => EmitOnly,
-    EndOfLineState: () => EndOfLineState,
-    EnumKind: () => EnumKind,
-    ExitStatus: () => ExitStatus,
-    ExportKind: () => ExportKind,
-    Extension: () => Extension,
-    ExternalEmitHelpers: () => ExternalEmitHelpers,
-    FileIncludeKind: () => FileIncludeKind,
-    FilePreprocessingDiagnosticsKind: () => FilePreprocessingDiagnosticsKind,
-    FileSystemEntryKind: () => FileSystemEntryKind,
-    FileWatcherEventKind: () => FileWatcherEventKind,
-    FindAllReferences: () => ts_FindAllReferences_exports,
-    FlattenLevel: () => FlattenLevel,
-    FlowFlags: () => FlowFlags,
-    ForegroundColorEscapeSequences: () => ForegroundColorEscapeSequences,
-    FunctionFlags: () => FunctionFlags,
-    GeneratedIdentifierFlags: () => GeneratedIdentifierFlags,
-    GetLiteralTextFlags: () => GetLiteralTextFlags,
-    GoToDefinition: () => ts_GoToDefinition_exports,
-    HighlightSpanKind: () => HighlightSpanKind,
-    ImportKind: () => ImportKind,
-    ImportsNotUsedAsValues: () => ImportsNotUsedAsValues,
-    IndentStyle: () => IndentStyle,
-    IndexFlags: () => IndexFlags,
-    IndexKind: () => IndexKind,
-    InferenceFlags: () => InferenceFlags,
-    InferencePriority: () => InferencePriority,
-    InlayHintKind: () => InlayHintKind,
-    InlayHints: () => ts_InlayHints_exports,
-    InternalEmitFlags: () => InternalEmitFlags,
-    InternalSymbolName: () => InternalSymbolName,
-    InvalidatedProjectKind: () => InvalidatedProjectKind,
-    JsDoc: () => ts_JsDoc_exports,
-    JsTyping: () => ts_JsTyping_exports,
-    JsxEmit: () => JsxEmit,
-    JsxFlags: () => JsxFlags,
-    JsxReferenceKind: () => JsxReferenceKind,
-    LanguageServiceMode: () => LanguageServiceMode,
-    LanguageServiceShimHostAdapter: () => LanguageServiceShimHostAdapter,
-    LanguageVariant: () => LanguageVariant,
-    LexicalEnvironmentFlags: () => LexicalEnvironmentFlags,
-    ListFormat: () => ListFormat,
-    LogLevel: () => LogLevel,
-    MemberOverrideStatus: () => MemberOverrideStatus,
-    ModifierFlags: () => ModifierFlags,
-    ModuleDetectionKind: () => ModuleDetectionKind,
-    ModuleInstanceState: () => ModuleInstanceState,
-    ModuleKind: () => ModuleKind,
-    ModuleResolutionKind: () => ModuleResolutionKind,
-    ModuleSpecifierEnding: () => ModuleSpecifierEnding,
-    NavigateTo: () => ts_NavigateTo_exports,
-    NavigationBar: () => ts_NavigationBar_exports,
-    NewLineKind: () => NewLineKind,
-    NodeBuilderFlags: () => NodeBuilderFlags,
-    NodeCheckFlags: () => NodeCheckFlags,
-    NodeFactoryFlags: () => NodeFactoryFlags,
-    NodeFlags: () => NodeFlags,
-    NodeResolutionFeatures: () => NodeResolutionFeatures,
-    ObjectFlags: () => ObjectFlags,
-    OperationCanceledException: () => OperationCanceledException,
-    OperatorPrecedence: () => OperatorPrecedence,
-    OrganizeImports: () => ts_OrganizeImports_exports,
-    OrganizeImportsMode: () => OrganizeImportsMode,
-    OuterExpressionKinds: () => OuterExpressionKinds,
-    OutliningElementsCollector: () => ts_OutliningElementsCollector_exports,
-    OutliningSpanKind: () => OutliningSpanKind,
-    OutputFileType: () => OutputFileType,
-    PackageJsonAutoImportPreference: () => PackageJsonAutoImportPreference,
-    PackageJsonDependencyGroup: () => PackageJsonDependencyGroup,
-    PatternMatchKind: () => PatternMatchKind,
-    PollingInterval: () => PollingInterval,
-    PollingWatchKind: () => PollingWatchKind,
-    PragmaKindFlags: () => PragmaKindFlags,
-    PrivateIdentifierKind: () => PrivateIdentifierKind,
-    ProcessLevel: () => ProcessLevel,
-    QuotePreference: () => QuotePreference,
-    RelationComparisonResult: () => RelationComparisonResult,
-    Rename: () => ts_Rename_exports,
-    ScriptElementKind: () => ScriptElementKind,
-    ScriptElementKindModifier: () => ScriptElementKindModifier,
-    ScriptKind: () => ScriptKind,
-    ScriptSnapshot: () => ScriptSnapshot,
-    ScriptTarget: () => ScriptTarget,
-    SemanticClassificationFormat: () => SemanticClassificationFormat,
-    SemanticMeaning: () => SemanticMeaning,
-    SemicolonPreference: () => SemicolonPreference,
-    SignatureCheckMode: () => SignatureCheckMode,
-    SignatureFlags: () => SignatureFlags,
-    SignatureHelp: () => ts_SignatureHelp_exports,
-    SignatureKind: () => SignatureKind,
-    SmartSelectionRange: () => ts_SmartSelectionRange_exports,
-    SnippetKind: () => SnippetKind,
-    SortKind: () => SortKind,
-    StructureIsReused: () => StructureIsReused,
-    SymbolAccessibility: () => SymbolAccessibility,
-    SymbolDisplay: () => ts_SymbolDisplay_exports,
-    SymbolDisplayPartKind: () => SymbolDisplayPartKind,
-    SymbolFlags: () => SymbolFlags,
-    SymbolFormatFlags: () => SymbolFormatFlags,
-    SyntaxKind: () => SyntaxKind,
-    SyntheticSymbolKind: () => SyntheticSymbolKind,
-    Ternary: () => Ternary,
-    ThrottledCancellationToken: () => ThrottledCancellationToken,
-    TokenClass: () => TokenClass,
-    TokenFlags: () => TokenFlags,
-    TransformFlags: () => TransformFlags,
-    TypeFacts: () => TypeFacts,
-    TypeFlags: () => TypeFlags,
-    TypeFormatFlags: () => TypeFormatFlags,
-    TypeMapKind: () => TypeMapKind,
-    TypePredicateKind: () => TypePredicateKind,
-    TypeReferenceSerializationKind: () => TypeReferenceSerializationKind,
-    TypeScriptServicesFactory: () => TypeScriptServicesFactory,
-    UnionReduction: () => UnionReduction,
-    UpToDateStatusType: () => UpToDateStatusType,
-    VarianceFlags: () => VarianceFlags,
-    Version: () => Version,
-    VersionRange: () => VersionRange,
-    WatchDirectoryFlags: () => WatchDirectoryFlags,
-    WatchDirectoryKind: () => WatchDirectoryKind,
-    WatchFileKind: () => WatchFileKind,
-    WatchLogLevel: () => WatchLogLevel,
-    WatchType: () => WatchType,
-    accessPrivateIdentifier: () => accessPrivateIdentifier,
-    addEmitFlags: () => addEmitFlags,
-    addEmitHelper: () => addEmitHelper,
-    addEmitHelpers: () => addEmitHelpers,
-    addInternalEmitFlags: () => addInternalEmitFlags,
-    addNodeFactoryPatcher: () => addNodeFactoryPatcher,
-    addObjectAllocatorPatcher: () => addObjectAllocatorPatcher,
-    addRange: () => addRange,
-    addRelatedInfo: () => addRelatedInfo,
-    addSyntheticLeadingComment: () => addSyntheticLeadingComment,
-    addSyntheticTrailingComment: () => addSyntheticTrailingComment,
-    addToSeen: () => addToSeen,
-    advancedAsyncSuperHelper: () => advancedAsyncSuperHelper,
-    affectsDeclarationPathOptionDeclarations: () => affectsDeclarationPathOptionDeclarations,
-    affectsEmitOptionDeclarations: () => affectsEmitOptionDeclarations,
-    allKeysStartWithDot: () => allKeysStartWithDot,
-    altDirectorySeparator: () => altDirectorySeparator,
-    and: () => and,
-    append: () => append,
-    appendIfUnique: () => appendIfUnique,
-    arrayFrom: () => arrayFrom,
-    arrayIsEqualTo: () => arrayIsEqualTo,
-    arrayIsHomogeneous: () => arrayIsHomogeneous,
-    arrayIsSorted: () => arrayIsSorted,
-    arrayOf: () => arrayOf,
-    arrayReverseIterator: () => arrayReverseIterator,
-    arrayToMap: () => arrayToMap,
-    arrayToMultiMap: () => arrayToMultiMap,
-    arrayToNumericMap: () => arrayToNumericMap,
-    arraysEqual: () => arraysEqual,
-    assertType: () => assertType,
-    assign: () => assign,
-    assignHelper: () => assignHelper,
-    asyncDelegator: () => asyncDelegator,
-    asyncGeneratorHelper: () => asyncGeneratorHelper,
-    asyncSuperHelper: () => asyncSuperHelper,
-    asyncValues: () => asyncValues,
-    attachFileToDiagnostics: () => attachFileToDiagnostics,
-    awaitHelper: () => awaitHelper,
-    awaiterHelper: () => awaiterHelper,
-    base64decode: () => base64decode,
-    base64encode: () => base64encode,
-    binarySearch: () => binarySearch,
-    binarySearchKey: () => binarySearchKey,
-    bindSourceFile: () => bindSourceFile,
-    breakIntoCharacterSpans: () => breakIntoCharacterSpans,
-    breakIntoWordSpans: () => breakIntoWordSpans,
-    buildLinkParts: () => buildLinkParts,
-    buildOpts: () => buildOpts,
-    buildOverload: () => buildOverload,
-    bundlerModuleNameResolver: () => bundlerModuleNameResolver,
-    canBeConvertedToAsync: () => canBeConvertedToAsync,
-    canHaveDecorators: () => canHaveDecorators,
-    canHaveExportModifier: () => canHaveExportModifier,
-    canHaveFlowNode: () => canHaveFlowNode,
-    canHaveIllegalDecorators: () => canHaveIllegalDecorators,
-    canHaveIllegalModifiers: () => canHaveIllegalModifiers,
-    canHaveIllegalType: () => canHaveIllegalType,
-    canHaveIllegalTypeParameters: () => canHaveIllegalTypeParameters,
-    canHaveJSDoc: () => canHaveJSDoc,
-    canHaveLocals: () => canHaveLocals,
-    canHaveModifiers: () => canHaveModifiers,
-    canHaveSymbol: () => canHaveSymbol,
-    canJsonReportNoInputFiles: () => canJsonReportNoInputFiles,
-    canProduceDiagnostics: () => canProduceDiagnostics,
-    canUsePropertyAccess: () => canUsePropertyAccess,
-    canWatchAffectingLocation: () => canWatchAffectingLocation,
-    canWatchAtTypes: () => canWatchAtTypes,
-    canWatchDirectoryOrFile: () => canWatchDirectoryOrFile,
-    cartesianProduct: () => cartesianProduct,
-    cast: () => cast,
-    chainBundle: () => chainBundle,
-    chainDiagnosticMessages: () => chainDiagnosticMessages,
-    changeAnyExtension: () => changeAnyExtension,
-    changeCompilerHostLikeToUseCache: () => changeCompilerHostLikeToUseCache,
-    changeExtension: () => changeExtension,
-    changesAffectModuleResolution: () => changesAffectModuleResolution,
-    changesAffectingProgramStructure: () => changesAffectingProgramStructure,
-    childIsDecorated: () => childIsDecorated,
-    classElementOrClassElementParameterIsDecorated: () => classElementOrClassElementParameterIsDecorated,
-    classOrConstructorParameterIsDecorated: () => classOrConstructorParameterIsDecorated,
-    classPrivateFieldGetHelper: () => classPrivateFieldGetHelper,
-    classPrivateFieldInHelper: () => classPrivateFieldInHelper,
-    classPrivateFieldSetHelper: () => classPrivateFieldSetHelper,
-    classicNameResolver: () => classicNameResolver,
-    classifier: () => ts_classifier_exports,
-    cleanExtendedConfigCache: () => cleanExtendedConfigCache,
-    clear: () => clear,
-    clearMap: () => clearMap,
-    clearSharedExtendedConfigFileWatcher: () => clearSharedExtendedConfigFileWatcher,
-    climbPastPropertyAccess: () => climbPastPropertyAccess,
-    climbPastPropertyOrElementAccess: () => climbPastPropertyOrElementAccess,
-    clone: () => clone,
-    cloneCompilerOptions: () => cloneCompilerOptions,
-    closeFileWatcher: () => closeFileWatcher,
-    closeFileWatcherOf: () => closeFileWatcherOf,
-    codefix: () => ts_codefix_exports,
-    collapseTextChangeRangesAcrossMultipleVersions: () => collapseTextChangeRangesAcrossMultipleVersions,
-    collectExternalModuleInfo: () => collectExternalModuleInfo,
-    combine: () => combine,
-    combinePaths: () => combinePaths,
-    commentPragmas: () => commentPragmas,
-    commonOptionsWithBuild: () => commonOptionsWithBuild,
-    commonPackageFolders: () => commonPackageFolders,
-    compact: () => compact,
-    compareBooleans: () => compareBooleans,
-    compareDataObjects: () => compareDataObjects,
-    compareDiagnostics: () => compareDiagnostics,
-    compareDiagnosticsSkipRelatedInformation: () => compareDiagnosticsSkipRelatedInformation,
-    compareEmitHelpers: () => compareEmitHelpers,
-    compareNumberOfDirectorySeparators: () => compareNumberOfDirectorySeparators,
-    comparePaths: () => comparePaths,
-    comparePathsCaseInsensitive: () => comparePathsCaseInsensitive,
-    comparePathsCaseSensitive: () => comparePathsCaseSensitive,
-    comparePatternKeys: () => comparePatternKeys,
-    compareProperties: () => compareProperties,
-    compareStringsCaseInsensitive: () => compareStringsCaseInsensitive,
-    compareStringsCaseInsensitiveEslintCompatible: () => compareStringsCaseInsensitiveEslintCompatible,
-    compareStringsCaseSensitive: () => compareStringsCaseSensitive,
-    compareStringsCaseSensitiveUI: () => compareStringsCaseSensitiveUI,
-    compareTextSpans: () => compareTextSpans,
-    compareValues: () => compareValues,
-    compileOnSaveCommandLineOption: () => compileOnSaveCommandLineOption,
-    compilerOptionsAffectDeclarationPath: () => compilerOptionsAffectDeclarationPath,
-    compilerOptionsAffectEmit: () => compilerOptionsAffectEmit,
-    compilerOptionsAffectSemanticDiagnostics: () => compilerOptionsAffectSemanticDiagnostics,
-    compilerOptionsDidYouMeanDiagnostics: () => compilerOptionsDidYouMeanDiagnostics,
-    compilerOptionsIndicateEsModules: () => compilerOptionsIndicateEsModules,
-    compose: () => compose,
-    computeCommonSourceDirectoryOfFilenames: () => computeCommonSourceDirectoryOfFilenames,
-    computeLineAndCharacterOfPosition: () => computeLineAndCharacterOfPosition,
-    computeLineOfPosition: () => computeLineOfPosition,
-    computeLineStarts: () => computeLineStarts,
-    computePositionOfLineAndCharacter: () => computePositionOfLineAndCharacter,
-    computeSignature: () => computeSignature,
-    computeSignatureWithDiagnostics: () => computeSignatureWithDiagnostics,
-    computeSuggestionDiagnostics: () => computeSuggestionDiagnostics,
-    concatenate: () => concatenate,
-    concatenateDiagnosticMessageChains: () => concatenateDiagnosticMessageChains,
-    consumesNodeCoreModules: () => consumesNodeCoreModules,
-    contains: () => contains,
-    containsIgnoredPath: () => containsIgnoredPath,
-    containsObjectRestOrSpread: () => containsObjectRestOrSpread,
-    containsParseError: () => containsParseError,
-    containsPath: () => containsPath,
-    convertCompilerOptionsForTelemetry: () => convertCompilerOptionsForTelemetry,
-    convertCompilerOptionsFromJson: () => convertCompilerOptionsFromJson,
-    convertJsonOption: () => convertJsonOption,
-    convertToBase64: () => convertToBase64,
-    convertToJson: () => convertToJson,
-    convertToObject: () => convertToObject,
-    convertToOptionsWithAbsolutePaths: () => convertToOptionsWithAbsolutePaths,
-    convertToRelativePath: () => convertToRelativePath,
-    convertToTSConfig: () => convertToTSConfig,
-    convertTypeAcquisitionFromJson: () => convertTypeAcquisitionFromJson,
-    copyComments: () => copyComments,
-    copyEntries: () => copyEntries,
-    copyLeadingComments: () => copyLeadingComments,
-    copyProperties: () => copyProperties,
-    copyTrailingAsLeadingComments: () => copyTrailingAsLeadingComments,
-    copyTrailingComments: () => copyTrailingComments,
-    couldStartTrivia: () => couldStartTrivia,
-    countWhere: () => countWhere,
-    createAbstractBuilder: () => createAbstractBuilder,
-    createAccessorPropertyBackingField: () => createAccessorPropertyBackingField,
-    createAccessorPropertyGetRedirector: () => createAccessorPropertyGetRedirector,
-    createAccessorPropertySetRedirector: () => createAccessorPropertySetRedirector,
-    createBaseNodeFactory: () => createBaseNodeFactory,
-    createBinaryExpressionTrampoline: () => createBinaryExpressionTrampoline,
-    createBindingHelper: () => createBindingHelper,
-    createBuildInfo: () => createBuildInfo,
-    createBuilderProgram: () => createBuilderProgram,
-    createBuilderProgramUsingProgramBuildInfo: () => createBuilderProgramUsingProgramBuildInfo,
-    createBuilderStatusReporter: () => createBuilderStatusReporter,
-    createCacheWithRedirects: () => createCacheWithRedirects,
-    createCacheableExportInfoMap: () => createCacheableExportInfoMap,
-    createCachedDirectoryStructureHost: () => createCachedDirectoryStructureHost,
-    createClassifier: () => createClassifier,
-    createCommentDirectivesMap: () => createCommentDirectivesMap,
-    createCompilerDiagnostic: () => createCompilerDiagnostic,
-    createCompilerDiagnosticForInvalidCustomType: () => createCompilerDiagnosticForInvalidCustomType,
-    createCompilerDiagnosticFromMessageChain: () => createCompilerDiagnosticFromMessageChain,
-    createCompilerHost: () => createCompilerHost,
-    createCompilerHostFromProgramHost: () => createCompilerHostFromProgramHost,
-    createCompilerHostWorker: () => createCompilerHostWorker,
-    createDetachedDiagnostic: () => createDetachedDiagnostic,
-    createDiagnosticCollection: () => createDiagnosticCollection,
-    createDiagnosticForFileFromMessageChain: () => createDiagnosticForFileFromMessageChain,
-    createDiagnosticForNode: () => createDiagnosticForNode,
-    createDiagnosticForNodeArray: () => createDiagnosticForNodeArray,
-    createDiagnosticForNodeArrayFromMessageChain: () => createDiagnosticForNodeArrayFromMessageChain,
-    createDiagnosticForNodeFromMessageChain: () => createDiagnosticForNodeFromMessageChain,
-    createDiagnosticForNodeInSourceFile: () => createDiagnosticForNodeInSourceFile,
-    createDiagnosticForRange: () => createDiagnosticForRange,
-    createDiagnosticMessageChainFromDiagnostic: () => createDiagnosticMessageChainFromDiagnostic,
-    createDiagnosticReporter: () => createDiagnosticReporter,
-    createDocumentPositionMapper: () => createDocumentPositionMapper,
-    createDocumentRegistry: () => createDocumentRegistry,
-    createDocumentRegistryInternal: () => createDocumentRegistryInternal,
-    createEmitAndSemanticDiagnosticsBuilderProgram: () => createEmitAndSemanticDiagnosticsBuilderProgram,
-    createEmitHelperFactory: () => createEmitHelperFactory,
-    createEmptyExports: () => createEmptyExports,
-    createExpressionForJsxElement: () => createExpressionForJsxElement,
-    createExpressionForJsxFragment: () => createExpressionForJsxFragment,
-    createExpressionForObjectLiteralElementLike: () => createExpressionForObjectLiteralElementLike,
-    createExpressionForPropertyName: () => createExpressionForPropertyName,
-    createExpressionFromEntityName: () => createExpressionFromEntityName,
-    createExternalHelpersImportDeclarationIfNeeded: () => createExternalHelpersImportDeclarationIfNeeded,
-    createFileDiagnostic: () => createFileDiagnostic,
-    createFileDiagnosticFromMessageChain: () => createFileDiagnosticFromMessageChain,
-    createForOfBindingStatement: () => createForOfBindingStatement,
-    createGetCanonicalFileName: () => createGetCanonicalFileName,
-    createGetSourceFile: () => createGetSourceFile,
-    createGetSymbolAccessibilityDiagnosticForNode: () => createGetSymbolAccessibilityDiagnosticForNode,
-    createGetSymbolAccessibilityDiagnosticForNodeName: () => createGetSymbolAccessibilityDiagnosticForNodeName,
-    createGetSymbolWalker: () => createGetSymbolWalker,
-    createIncrementalCompilerHost: () => createIncrementalCompilerHost,
-    createIncrementalProgram: () => createIncrementalProgram,
-    createInputFiles: () => createInputFiles,
-    createInputFilesWithFilePaths: () => createInputFilesWithFilePaths,
-    createInputFilesWithFileTexts: () => createInputFilesWithFileTexts,
-    createJsxFactoryExpression: () => createJsxFactoryExpression,
-    createLanguageService: () => createLanguageService,
-    createLanguageServiceSourceFile: () => createLanguageServiceSourceFile,
-    createMemberAccessForPropertyName: () => createMemberAccessForPropertyName,
-    createModeAwareCache: () => createModeAwareCache,
-    createModeAwareCacheKey: () => createModeAwareCacheKey,
-    createModuleNotFoundChain: () => createModuleNotFoundChain,
-    createModuleResolutionCache: () => createModuleResolutionCache,
-    createModuleResolutionLoader: () => createModuleResolutionLoader,
-    createModuleSpecifierResolutionHost: () => createModuleSpecifierResolutionHost,
-    createMultiMap: () => createMultiMap,
-    createNodeConverters: () => createNodeConverters,
-    createNodeFactory: () => createNodeFactory,
-    createOptionNameMap: () => createOptionNameMap,
-    createOverload: () => createOverload,
-    createPackageJsonImportFilter: () => createPackageJsonImportFilter,
-    createPackageJsonInfo: () => createPackageJsonInfo,
-    createParenthesizerRules: () => createParenthesizerRules,
-    createPatternMatcher: () => createPatternMatcher,
-    createPrependNodes: () => createPrependNodes,
-    createPrinter: () => createPrinter,
-    createPrinterWithDefaults: () => createPrinterWithDefaults,
-    createPrinterWithRemoveComments: () => createPrinterWithRemoveComments,
-    createPrinterWithRemoveCommentsNeverAsciiEscape: () => createPrinterWithRemoveCommentsNeverAsciiEscape,
-    createPrinterWithRemoveCommentsOmitTrailingSemicolon: () => createPrinterWithRemoveCommentsOmitTrailingSemicolon,
-    createProgram: () => createProgram,
-    createProgramHost: () => createProgramHost,
-    createPropertyNameNodeForIdentifierOrLiteral: () => createPropertyNameNodeForIdentifierOrLiteral,
-    createQueue: () => createQueue,
-    createRange: () => createRange,
-    createRedirectedBuilderProgram: () => createRedirectedBuilderProgram,
-    createResolutionCache: () => createResolutionCache,
-    createRuntimeTypeSerializer: () => createRuntimeTypeSerializer,
-    createScanner: () => createScanner,
-    createSemanticDiagnosticsBuilderProgram: () => createSemanticDiagnosticsBuilderProgram,
-    createSet: () => createSet,
-    createSolutionBuilder: () => createSolutionBuilder,
-    createSolutionBuilderHost: () => createSolutionBuilderHost,
-    createSolutionBuilderWithWatch: () => createSolutionBuilderWithWatch,
-    createSolutionBuilderWithWatchHost: () => createSolutionBuilderWithWatchHost,
-    createSortedArray: () => createSortedArray,
-    createSourceFile: () => createSourceFile,
-    createSourceMapGenerator: () => createSourceMapGenerator,
-    createSourceMapSource: () => createSourceMapSource,
-    createSuperAccessVariableStatement: () => createSuperAccessVariableStatement,
-    createSymbolTable: () => createSymbolTable,
-    createSymlinkCache: () => createSymlinkCache,
-    createSystemWatchFunctions: () => createSystemWatchFunctions,
-    createTextChange: () => createTextChange,
-    createTextChangeFromStartLength: () => createTextChangeFromStartLength,
-    createTextChangeRange: () => createTextChangeRange,
-    createTextRangeFromNode: () => createTextRangeFromNode,
-    createTextRangeFromSpan: () => createTextRangeFromSpan,
-    createTextSpan: () => createTextSpan,
-    createTextSpanFromBounds: () => createTextSpanFromBounds,
-    createTextSpanFromNode: () => createTextSpanFromNode,
-    createTextSpanFromRange: () => createTextSpanFromRange,
-    createTextSpanFromStringLiteralLikeContent: () => createTextSpanFromStringLiteralLikeContent,
-    createTextWriter: () => createTextWriter,
-    createTokenRange: () => createTokenRange,
-    createTypeChecker: () => createTypeChecker,
-    createTypeReferenceDirectiveResolutionCache: () => createTypeReferenceDirectiveResolutionCache,
-    createTypeReferenceResolutionLoader: () => createTypeReferenceResolutionLoader,
-    createUnparsedSourceFile: () => createUnparsedSourceFile,
-    createWatchCompilerHost: () => createWatchCompilerHost2,
-    createWatchCompilerHostOfConfigFile: () => createWatchCompilerHostOfConfigFile,
-    createWatchCompilerHostOfFilesAndCompilerOptions: () => createWatchCompilerHostOfFilesAndCompilerOptions,
-    createWatchFactory: () => createWatchFactory,
-    createWatchHost: () => createWatchHost,
-    createWatchProgram: () => createWatchProgram,
-    createWatchStatusReporter: () => createWatchStatusReporter,
-    createWriteFileMeasuringIO: () => createWriteFileMeasuringIO,
-    declarationNameToString: () => declarationNameToString,
-    decodeMappings: () => decodeMappings,
-    decodedTextSpanIntersectsWith: () => decodedTextSpanIntersectsWith,
-    decorateHelper: () => decorateHelper,
-    deduplicate: () => deduplicate,
-    defaultIncludeSpec: () => defaultIncludeSpec,
-    defaultInitCompilerOptions: () => defaultInitCompilerOptions,
-    defaultMaximumTruncationLength: () => defaultMaximumTruncationLength,
-    detectSortCaseSensitivity: () => detectSortCaseSensitivity,
-    diagnosticCategoryName: () => diagnosticCategoryName,
-    diagnosticToString: () => diagnosticToString,
-    directoryProbablyExists: () => directoryProbablyExists,
-    directorySeparator: () => directorySeparator,
-    displayPart: () => displayPart,
-    displayPartsToString: () => displayPartsToString,
-    disposeEmitNodes: () => disposeEmitNodes,
-    documentSpansEqual: () => documentSpansEqual,
-    dumpTracingLegend: () => dumpTracingLegend,
-    elementAt: () => elementAt,
-    elideNodes: () => elideNodes,
-    emitComments: () => emitComments,
-    emitDetachedComments: () => emitDetachedComments,
-    emitFiles: () => emitFiles,
-    emitFilesAndReportErrors: () => emitFilesAndReportErrors,
-    emitFilesAndReportErrorsAndGetExitStatus: () => emitFilesAndReportErrorsAndGetExitStatus,
-    emitModuleKindIsNonNodeESM: () => emitModuleKindIsNonNodeESM,
-    emitNewLineBeforeLeadingCommentOfPosition: () => emitNewLineBeforeLeadingCommentOfPosition,
-    emitNewLineBeforeLeadingComments: () => emitNewLineBeforeLeadingComments,
-    emitNewLineBeforeLeadingCommentsOfPosition: () => emitNewLineBeforeLeadingCommentsOfPosition,
-    emitSkippedWithNoDiagnostics: () => emitSkippedWithNoDiagnostics,
-    emitUsingBuildInfo: () => emitUsingBuildInfo,
-    emptyArray: () => emptyArray,
-    emptyFileSystemEntries: () => emptyFileSystemEntries,
-    emptyMap: () => emptyMap,
-    emptyOptions: () => emptyOptions,
-    emptySet: () => emptySet,
-    endsWith: () => endsWith,
-    ensurePathIsNonModuleName: () => ensurePathIsNonModuleName,
-    ensureScriptKind: () => ensureScriptKind,
-    ensureTrailingDirectorySeparator: () => ensureTrailingDirectorySeparator,
-    entityNameToString: () => entityNameToString,
-    enumerateInsertsAndDeletes: () => enumerateInsertsAndDeletes,
-    equalOwnProperties: () => equalOwnProperties,
-    equateStringsCaseInsensitive: () => equateStringsCaseInsensitive,
-    equateStringsCaseSensitive: () => equateStringsCaseSensitive,
-    equateValues: () => equateValues,
-    esDecorateHelper: () => esDecorateHelper,
-    escapeJsxAttributeString: () => escapeJsxAttributeString,
-    escapeLeadingUnderscores: () => escapeLeadingUnderscores,
-    escapeNonAsciiString: () => escapeNonAsciiString,
-    escapeSnippetText: () => escapeSnippetText,
-    escapeString: () => escapeString,
-    every: () => every,
-    expandPreOrPostfixIncrementOrDecrementExpression: () => expandPreOrPostfixIncrementOrDecrementExpression,
-    explainFiles: () => explainFiles,
-    explainIfFileIsRedirectAndImpliedFormat: () => explainIfFileIsRedirectAndImpliedFormat,
-    exportAssignmentIsAlias: () => exportAssignmentIsAlias,
-    exportStarHelper: () => exportStarHelper,
-    expressionResultIsUnused: () => expressionResultIsUnused,
-    extend: () => extend,
-    extendsHelper: () => extendsHelper,
-    extensionFromPath: () => extensionFromPath,
-    extensionIsTS: () => extensionIsTS,
-    extensionsNotSupportingExtensionlessResolution: () => extensionsNotSupportingExtensionlessResolution,
-    externalHelpersModuleNameText: () => externalHelpersModuleNameText,
-    factory: () => factory,
-    fileExtensionIs: () => fileExtensionIs,
-    fileExtensionIsOneOf: () => fileExtensionIsOneOf,
-    fileIncludeReasonToDiagnostics: () => fileIncludeReasonToDiagnostics,
-    fileShouldUseJavaScriptRequire: () => fileShouldUseJavaScriptRequire,
-    filter: () => filter,
-    filterMutate: () => filterMutate,
-    filterSemanticDiagnostics: () => filterSemanticDiagnostics,
-    find: () => find,
-    findAncestor: () => findAncestor,
-    findBestPatternMatch: () => findBestPatternMatch,
-    findChildOfKind: () => findChildOfKind,
-    findComputedPropertyNameCacheAssignment: () => findComputedPropertyNameCacheAssignment,
-    findConfigFile: () => findConfigFile,
-    findContainingList: () => findContainingList,
-    findDiagnosticForNode: () => findDiagnosticForNode,
-    findFirstNonJsxWhitespaceToken: () => findFirstNonJsxWhitespaceToken,
-    findIndex: () => findIndex,
-    findLast: () => findLast,
-    findLastIndex: () => findLastIndex,
-    findListItemInfo: () => findListItemInfo,
-    findMap: () => findMap,
-    findModifier: () => findModifier,
-    findNextToken: () => findNextToken,
-    findPackageJson: () => findPackageJson,
-    findPackageJsons: () => findPackageJsons,
-    findPrecedingMatchingToken: () => findPrecedingMatchingToken,
-    findPrecedingToken: () => findPrecedingToken,
-    findSuperStatementIndex: () => findSuperStatementIndex,
-    findTokenOnLeftOfPosition: () => findTokenOnLeftOfPosition,
-    findUseStrictPrologue: () => findUseStrictPrologue,
-    first: () => first,
-    firstDefined: () => firstDefined,
-    firstDefinedIterator: () => firstDefinedIterator,
-    firstIterator: () => firstIterator,
-    firstOrOnly: () => firstOrOnly,
-    firstOrUndefined: () => firstOrUndefined,
-    firstOrUndefinedIterator: () => firstOrUndefinedIterator,
-    fixupCompilerOptions: () => fixupCompilerOptions,
-    flatMap: () => flatMap,
-    flatMapIterator: () => flatMapIterator,
-    flatMapToMutable: () => flatMapToMutable,
-    flatten: () => flatten,
-    flattenCommaList: () => flattenCommaList,
-    flattenDestructuringAssignment: () => flattenDestructuringAssignment,
-    flattenDestructuringBinding: () => flattenDestructuringBinding,
-    flattenDiagnosticMessageText: () => flattenDiagnosticMessageText,
-    forEach: () => forEach,
-    forEachAncestor: () => forEachAncestor,
-    forEachAncestorDirectory: () => forEachAncestorDirectory,
-    forEachChild: () => forEachChild,
-    forEachChildRecursively: () => forEachChildRecursively,
-    forEachEmittedFile: () => forEachEmittedFile,
-    forEachEnclosingBlockScopeContainer: () => forEachEnclosingBlockScopeContainer,
-    forEachEntry: () => forEachEntry,
-    forEachExternalModuleToImportFrom: () => forEachExternalModuleToImportFrom,
-    forEachImportClauseDeclaration: () => forEachImportClauseDeclaration,
-    forEachKey: () => forEachKey,
-    forEachLeadingCommentRange: () => forEachLeadingCommentRange,
-    forEachNameInAccessChainWalkingLeft: () => forEachNameInAccessChainWalkingLeft,
-    forEachPropertyAssignment: () => forEachPropertyAssignment,
-    forEachResolvedProjectReference: () => forEachResolvedProjectReference,
-    forEachReturnStatement: () => forEachReturnStatement,
-    forEachRight: () => forEachRight,
-    forEachTrailingCommentRange: () => forEachTrailingCommentRange,
-    forEachTsConfigPropArray: () => forEachTsConfigPropArray,
-    forEachUnique: () => forEachUnique,
-    forEachYieldExpression: () => forEachYieldExpression,
-    forSomeAncestorDirectory: () => forSomeAncestorDirectory,
-    formatColorAndReset: () => formatColorAndReset,
-    formatDiagnostic: () => formatDiagnostic,
-    formatDiagnostics: () => formatDiagnostics,
-    formatDiagnosticsWithColorAndContext: () => formatDiagnosticsWithColorAndContext,
-    formatGeneratedName: () => formatGeneratedName,
-    formatGeneratedNamePart: () => formatGeneratedNamePart,
-    formatLocation: () => formatLocation,
-    formatMessage: () => formatMessage,
-    formatStringFromArgs: () => formatStringFromArgs,
-    formatting: () => ts_formatting_exports,
-    fullTripleSlashAMDReferencePathRegEx: () => fullTripleSlashAMDReferencePathRegEx,
-    fullTripleSlashReferencePathRegEx: () => fullTripleSlashReferencePathRegEx,
-    generateDjb2Hash: () => generateDjb2Hash,
-    generateTSConfig: () => generateTSConfig,
-    generatorHelper: () => generatorHelper,
-    getAdjustedReferenceLocation: () => getAdjustedReferenceLocation,
-    getAdjustedRenameLocation: () => getAdjustedRenameLocation,
-    getAliasDeclarationFromName: () => getAliasDeclarationFromName,
-    getAllAccessorDeclarations: () => getAllAccessorDeclarations,
-    getAllDecoratorsOfClass: () => getAllDecoratorsOfClass,
-    getAllDecoratorsOfClassElement: () => getAllDecoratorsOfClassElement,
-    getAllJSDocTags: () => getAllJSDocTags,
-    getAllJSDocTagsOfKind: () => getAllJSDocTagsOfKind,
-    getAllKeys: () => getAllKeys,
-    getAllProjectOutputs: () => getAllProjectOutputs,
-    getAllSuperTypeNodes: () => getAllSuperTypeNodes,
-    getAllUnscopedEmitHelpers: () => getAllUnscopedEmitHelpers,
-    getAllowJSCompilerOption: () => getAllowJSCompilerOption,
-    getAllowSyntheticDefaultImports: () => getAllowSyntheticDefaultImports,
-    getAncestor: () => getAncestor,
-    getAnyExtensionFromPath: () => getAnyExtensionFromPath,
-    getAreDeclarationMapsEnabled: () => getAreDeclarationMapsEnabled,
-    getAssignedExpandoInitializer: () => getAssignedExpandoInitializer,
-    getAssignedName: () => getAssignedName,
-    getAssignmentDeclarationKind: () => getAssignmentDeclarationKind,
-    getAssignmentDeclarationPropertyAccessKind: () => getAssignmentDeclarationPropertyAccessKind,
-    getAssignmentTargetKind: () => getAssignmentTargetKind,
-    getAutomaticTypeDirectiveNames: () => getAutomaticTypeDirectiveNames,
-    getBaseFileName: () => getBaseFileName,
-    getBinaryOperatorPrecedence: () => getBinaryOperatorPrecedence,
-    getBuildInfo: () => getBuildInfo,
-    getBuildInfoFileVersionMap: () => getBuildInfoFileVersionMap,
-    getBuildInfoText: () => getBuildInfoText,
-    getBuildOrderFromAnyBuildOrder: () => getBuildOrderFromAnyBuildOrder,
-    getBuilderCreationParameters: () => getBuilderCreationParameters,
-    getBuilderFileEmit: () => getBuilderFileEmit,
-    getCheckFlags: () => getCheckFlags,
-    getClassExtendsHeritageElement: () => getClassExtendsHeritageElement,
-    getClassLikeDeclarationOfSymbol: () => getClassLikeDeclarationOfSymbol,
-    getCombinedLocalAndExportSymbolFlags: () => getCombinedLocalAndExportSymbolFlags,
-    getCombinedModifierFlags: () => getCombinedModifierFlags,
-    getCombinedNodeFlags: () => getCombinedNodeFlags,
-    getCombinedNodeFlagsAlwaysIncludeJSDoc: () => getCombinedNodeFlagsAlwaysIncludeJSDoc,
-    getCommentRange: () => getCommentRange,
-    getCommonSourceDirectory: () => getCommonSourceDirectory,
-    getCommonSourceDirectoryOfConfig: () => getCommonSourceDirectoryOfConfig,
-    getCompilerOptionValue: () => getCompilerOptionValue,
-    getCompilerOptionsDiffValue: () => getCompilerOptionsDiffValue,
-    getConditions: () => getConditions,
-    getConfigFileParsingDiagnostics: () => getConfigFileParsingDiagnostics,
-    getConstantValue: () => getConstantValue,
-    getContainerNode: () => getContainerNode,
-    getContainingClass: () => getContainingClass,
-    getContainingClassStaticBlock: () => getContainingClassStaticBlock,
-    getContainingFunction: () => getContainingFunction,
-    getContainingFunctionDeclaration: () => getContainingFunctionDeclaration,
-    getContainingFunctionOrClassStaticBlock: () => getContainingFunctionOrClassStaticBlock,
-    getContainingNodeArray: () => getContainingNodeArray,
-    getContainingObjectLiteralElement: () => getContainingObjectLiteralElement,
-    getContextualTypeFromParent: () => getContextualTypeFromParent,
-    getContextualTypeFromParentOrAncestorTypeNode: () => getContextualTypeFromParentOrAncestorTypeNode,
-    getCurrentTime: () => getCurrentTime,
-    getDeclarationDiagnostics: () => getDeclarationDiagnostics,
-    getDeclarationEmitExtensionForPath: () => getDeclarationEmitExtensionForPath,
-    getDeclarationEmitOutputFilePath: () => getDeclarationEmitOutputFilePath,
-    getDeclarationEmitOutputFilePathWorker: () => getDeclarationEmitOutputFilePathWorker,
-    getDeclarationFromName: () => getDeclarationFromName,
-    getDeclarationModifierFlagsFromSymbol: () => getDeclarationModifierFlagsFromSymbol,
-    getDeclarationOfKind: () => getDeclarationOfKind,
-    getDeclarationsOfKind: () => getDeclarationsOfKind,
-    getDeclaredExpandoInitializer: () => getDeclaredExpandoInitializer,
-    getDecorators: () => getDecorators,
-    getDefaultCompilerOptions: () => getDefaultCompilerOptions2,
-    getDefaultExportInfoWorker: () => getDefaultExportInfoWorker,
-    getDefaultFormatCodeSettings: () => getDefaultFormatCodeSettings,
-    getDefaultLibFileName: () => getDefaultLibFileName,
-    getDefaultLibFilePath: () => getDefaultLibFilePath,
-    getDefaultLikeExportInfo: () => getDefaultLikeExportInfo,
-    getDiagnosticText: () => getDiagnosticText,
-    getDiagnosticsWithinSpan: () => getDiagnosticsWithinSpan,
-    getDirectoryPath: () => getDirectoryPath,
-    getDirectoryToWatchFailedLookupLocation: () => getDirectoryToWatchFailedLookupLocation,
-    getDirectoryToWatchFailedLookupLocationFromTypeRoot: () => getDirectoryToWatchFailedLookupLocationFromTypeRoot,
-    getDocumentPositionMapper: () => getDocumentPositionMapper,
-    getESModuleInterop: () => getESModuleInterop,
-    getEditsForFileRename: () => getEditsForFileRename,
-    getEffectiveBaseTypeNode: () => getEffectiveBaseTypeNode,
-    getEffectiveConstraintOfTypeParameter: () => getEffectiveConstraintOfTypeParameter,
-    getEffectiveContainerForJSDocTemplateTag: () => getEffectiveContainerForJSDocTemplateTag,
-    getEffectiveImplementsTypeNodes: () => getEffectiveImplementsTypeNodes,
-    getEffectiveInitializer: () => getEffectiveInitializer,
-    getEffectiveJSDocHost: () => getEffectiveJSDocHost,
-    getEffectiveModifierFlags: () => getEffectiveModifierFlags,
-    getEffectiveModifierFlagsAlwaysIncludeJSDoc: () => getEffectiveModifierFlagsAlwaysIncludeJSDoc,
-    getEffectiveModifierFlagsNoCache: () => getEffectiveModifierFlagsNoCache,
-    getEffectiveReturnTypeNode: () => getEffectiveReturnTypeNode,
-    getEffectiveSetAccessorTypeAnnotationNode: () => getEffectiveSetAccessorTypeAnnotationNode,
-    getEffectiveTypeAnnotationNode: () => getEffectiveTypeAnnotationNode,
-    getEffectiveTypeParameterDeclarations: () => getEffectiveTypeParameterDeclarations,
-    getEffectiveTypeRoots: () => getEffectiveTypeRoots,
-    getElementOrPropertyAccessArgumentExpressionOrName: () => getElementOrPropertyAccessArgumentExpressionOrName,
-    getElementOrPropertyAccessName: () => getElementOrPropertyAccessName,
-    getElementsOfBindingOrAssignmentPattern: () => getElementsOfBindingOrAssignmentPattern,
-    getEmitDeclarations: () => getEmitDeclarations,
-    getEmitFlags: () => getEmitFlags,
-    getEmitHelpers: () => getEmitHelpers,
-    getEmitModuleDetectionKind: () => getEmitModuleDetectionKind,
-    getEmitModuleKind: () => getEmitModuleKind,
-    getEmitModuleResolutionKind: () => getEmitModuleResolutionKind,
-    getEmitScriptTarget: () => getEmitScriptTarget,
-    getEnclosingBlockScopeContainer: () => getEnclosingBlockScopeContainer,
-    getEncodedSemanticClassifications: () => getEncodedSemanticClassifications,
-    getEncodedSyntacticClassifications: () => getEncodedSyntacticClassifications,
-    getEndLinePosition: () => getEndLinePosition,
-    getEntityNameFromTypeNode: () => getEntityNameFromTypeNode,
-    getEntrypointsFromPackageJsonInfo: () => getEntrypointsFromPackageJsonInfo,
-    getErrorCountForSummary: () => getErrorCountForSummary,
-    getErrorSpanForNode: () => getErrorSpanForNode,
-    getErrorSummaryText: () => getErrorSummaryText,
-    getEscapedTextOfIdentifierOrLiteral: () => getEscapedTextOfIdentifierOrLiteral,
-    getEscapedTextOfJsxAttributeName: () => getEscapedTextOfJsxAttributeName,
-    getEscapedTextOfJsxNamespacedName: () => getEscapedTextOfJsxNamespacedName,
-    getExpandoInitializer: () => getExpandoInitializer,
-    getExportAssignmentExpression: () => getExportAssignmentExpression,
-    getExportInfoMap: () => getExportInfoMap,
-    getExportNeedsImportStarHelper: () => getExportNeedsImportStarHelper,
-    getExpressionAssociativity: () => getExpressionAssociativity,
-    getExpressionPrecedence: () => getExpressionPrecedence,
-    getExternalHelpersModuleName: () => getExternalHelpersModuleName,
-    getExternalModuleImportEqualsDeclarationExpression: () => getExternalModuleImportEqualsDeclarationExpression,
-    getExternalModuleName: () => getExternalModuleName,
-    getExternalModuleNameFromDeclaration: () => getExternalModuleNameFromDeclaration,
-    getExternalModuleNameFromPath: () => getExternalModuleNameFromPath,
-    getExternalModuleNameLiteral: () => getExternalModuleNameLiteral,
-    getExternalModuleRequireArgument: () => getExternalModuleRequireArgument,
-    getFallbackOptions: () => getFallbackOptions,
-    getFileEmitOutput: () => getFileEmitOutput,
-    getFileMatcherPatterns: () => getFileMatcherPatterns,
-    getFileNamesFromConfigSpecs: () => getFileNamesFromConfigSpecs,
-    getFileWatcherEventKind: () => getFileWatcherEventKind,
-    getFilesInErrorForSummary: () => getFilesInErrorForSummary,
-    getFirstConstructorWithBody: () => getFirstConstructorWithBody,
-    getFirstIdentifier: () => getFirstIdentifier,
-    getFirstNonSpaceCharacterPosition: () => getFirstNonSpaceCharacterPosition,
-    getFirstProjectOutput: () => getFirstProjectOutput,
-    getFixableErrorSpanExpression: () => getFixableErrorSpanExpression,
-    getFormatCodeSettingsForWriting: () => getFormatCodeSettingsForWriting,
-    getFullWidth: () => getFullWidth,
-    getFunctionFlags: () => getFunctionFlags,
-    getHeritageClause: () => getHeritageClause,
-    getHostSignatureFromJSDoc: () => getHostSignatureFromJSDoc,
-    getIdentifierAutoGenerate: () => getIdentifierAutoGenerate,
-    getIdentifierGeneratedImportReference: () => getIdentifierGeneratedImportReference,
-    getIdentifierTypeArguments: () => getIdentifierTypeArguments,
-    getImmediatelyInvokedFunctionExpression: () => getImmediatelyInvokedFunctionExpression,
-    getImpliedNodeFormatForFile: () => getImpliedNodeFormatForFile,
-    getImpliedNodeFormatForFileWorker: () => getImpliedNodeFormatForFileWorker,
-    getImportNeedsImportDefaultHelper: () => getImportNeedsImportDefaultHelper,
-    getImportNeedsImportStarHelper: () => getImportNeedsImportStarHelper,
-    getIndentSize: () => getIndentSize,
-    getIndentString: () => getIndentString,
-    getInferredLibraryNameResolveFrom: () => getInferredLibraryNameResolveFrom,
-    getInitializedVariables: () => getInitializedVariables,
-    getInitializerOfBinaryExpression: () => getInitializerOfBinaryExpression,
-    getInitializerOfBindingOrAssignmentElement: () => getInitializerOfBindingOrAssignmentElement,
-    getInterfaceBaseTypeNodes: () => getInterfaceBaseTypeNodes,
-    getInternalEmitFlags: () => getInternalEmitFlags,
-    getInvokedExpression: () => getInvokedExpression,
-    getIsolatedModules: () => getIsolatedModules,
-    getJSDocAugmentsTag: () => getJSDocAugmentsTag,
-    getJSDocClassTag: () => getJSDocClassTag,
-    getJSDocCommentRanges: () => getJSDocCommentRanges,
-    getJSDocCommentsAndTags: () => getJSDocCommentsAndTags,
-    getJSDocDeprecatedTag: () => getJSDocDeprecatedTag,
-    getJSDocDeprecatedTagNoCache: () => getJSDocDeprecatedTagNoCache,
-    getJSDocEnumTag: () => getJSDocEnumTag,
-    getJSDocHost: () => getJSDocHost,
-    getJSDocImplementsTags: () => getJSDocImplementsTags,
-    getJSDocOverrideTagNoCache: () => getJSDocOverrideTagNoCache,
-    getJSDocParameterTags: () => getJSDocParameterTags,
-    getJSDocParameterTagsNoCache: () => getJSDocParameterTagsNoCache,
-    getJSDocPrivateTag: () => getJSDocPrivateTag,
-    getJSDocPrivateTagNoCache: () => getJSDocPrivateTagNoCache,
-    getJSDocProtectedTag: () => getJSDocProtectedTag,
-    getJSDocProtectedTagNoCache: () => getJSDocProtectedTagNoCache,
-    getJSDocPublicTag: () => getJSDocPublicTag,
-    getJSDocPublicTagNoCache: () => getJSDocPublicTagNoCache,
-    getJSDocReadonlyTag: () => getJSDocReadonlyTag,
-    getJSDocReadonlyTagNoCache: () => getJSDocReadonlyTagNoCache,
-    getJSDocReturnTag: () => getJSDocReturnTag,
-    getJSDocReturnType: () => getJSDocReturnType,
-    getJSDocRoot: () => getJSDocRoot,
-    getJSDocSatisfiesExpressionType: () => getJSDocSatisfiesExpressionType,
-    getJSDocSatisfiesTag: () => getJSDocSatisfiesTag,
-    getJSDocTags: () => getJSDocTags,
-    getJSDocTagsNoCache: () => getJSDocTagsNoCache,
-    getJSDocTemplateTag: () => getJSDocTemplateTag,
-    getJSDocThisTag: () => getJSDocThisTag,
-    getJSDocType: () => getJSDocType,
-    getJSDocTypeAliasName: () => getJSDocTypeAliasName,
-    getJSDocTypeAssertionType: () => getJSDocTypeAssertionType,
-    getJSDocTypeParameterDeclarations: () => getJSDocTypeParameterDeclarations,
-    getJSDocTypeParameterTags: () => getJSDocTypeParameterTags,
-    getJSDocTypeParameterTagsNoCache: () => getJSDocTypeParameterTagsNoCache,
-    getJSDocTypeTag: () => getJSDocTypeTag,
-    getJSXImplicitImportBase: () => getJSXImplicitImportBase,
-    getJSXRuntimeImport: () => getJSXRuntimeImport,
-    getJSXTransformEnabled: () => getJSXTransformEnabled,
-    getKeyForCompilerOptions: () => getKeyForCompilerOptions,
-    getLanguageVariant: () => getLanguageVariant,
-    getLastChild: () => getLastChild,
-    getLeadingCommentRanges: () => getLeadingCommentRanges,
-    getLeadingCommentRangesOfNode: () => getLeadingCommentRangesOfNode,
-    getLeftmostAccessExpression: () => getLeftmostAccessExpression,
-    getLeftmostExpression: () => getLeftmostExpression,
-    getLineAndCharacterOfPosition: () => getLineAndCharacterOfPosition,
-    getLineInfo: () => getLineInfo,
-    getLineOfLocalPosition: () => getLineOfLocalPosition,
-    getLineOfLocalPositionFromLineMap: () => getLineOfLocalPositionFromLineMap,
-    getLineStartPositionForPosition: () => getLineStartPositionForPosition,
-    getLineStarts: () => getLineStarts,
-    getLinesBetweenPositionAndNextNonWhitespaceCharacter: () => getLinesBetweenPositionAndNextNonWhitespaceCharacter,
-    getLinesBetweenPositionAndPrecedingNonWhitespaceCharacter: () => getLinesBetweenPositionAndPrecedingNonWhitespaceCharacter,
-    getLinesBetweenPositions: () => getLinesBetweenPositions,
-    getLinesBetweenRangeEndAndRangeStart: () => getLinesBetweenRangeEndAndRangeStart,
-    getLinesBetweenRangeEndPositions: () => getLinesBetweenRangeEndPositions,
-    getLiteralText: () => getLiteralText,
-    getLocalNameForExternalImport: () => getLocalNameForExternalImport,
-    getLocalSymbolForExportDefault: () => getLocalSymbolForExportDefault,
-    getLocaleSpecificMessage: () => getLocaleSpecificMessage,
-    getLocaleTimeString: () => getLocaleTimeString,
-    getMappedContextSpan: () => getMappedContextSpan,
-    getMappedDocumentSpan: () => getMappedDocumentSpan,
-    getMappedLocation: () => getMappedLocation,
-    getMatchedFileSpec: () => getMatchedFileSpec,
-    getMatchedIncludeSpec: () => getMatchedIncludeSpec,
-    getMeaningFromDeclaration: () => getMeaningFromDeclaration,
-    getMeaningFromLocation: () => getMeaningFromLocation,
-    getMembersOfDeclaration: () => getMembersOfDeclaration,
-    getModeForFileReference: () => getModeForFileReference,
-    getModeForResolutionAtIndex: () => getModeForResolutionAtIndex,
-    getModeForUsageLocation: () => getModeForUsageLocation,
-    getModifiedTime: () => getModifiedTime,
-    getModifiers: () => getModifiers,
-    getModuleInstanceState: () => getModuleInstanceState,
-    getModuleNameStringLiteralAt: () => getModuleNameStringLiteralAt,
-    getModuleSpecifierEndingPreference: () => getModuleSpecifierEndingPreference,
-    getModuleSpecifierResolverHost: () => getModuleSpecifierResolverHost,
-    getNameForExportedSymbol: () => getNameForExportedSymbol,
-    getNameFromIndexInfo: () => getNameFromIndexInfo,
-    getNameFromPropertyName: () => getNameFromPropertyName,
-    getNameOfAccessExpression: () => getNameOfAccessExpression,
-    getNameOfCompilerOptionValue: () => getNameOfCompilerOptionValue,
-    getNameOfDeclaration: () => getNameOfDeclaration,
-    getNameOfExpando: () => getNameOfExpando,
-    getNameOfJSDocTypedef: () => getNameOfJSDocTypedef,
-    getNameOrArgument: () => getNameOrArgument,
-    getNameTable: () => getNameTable,
-    getNamesForExportedSymbol: () => getNamesForExportedSymbol,
-    getNamespaceDeclarationNode: () => getNamespaceDeclarationNode,
-    getNewLineCharacter: () => getNewLineCharacter,
-    getNewLineKind: () => getNewLineKind,
-    getNewLineOrDefaultFromHost: () => getNewLineOrDefaultFromHost,
-    getNewTargetContainer: () => getNewTargetContainer,
-    getNextJSDocCommentLocation: () => getNextJSDocCommentLocation,
-    getNodeForGeneratedName: () => getNodeForGeneratedName,
-    getNodeId: () => getNodeId,
-    getNodeKind: () => getNodeKind,
-    getNodeModifiers: () => getNodeModifiers,
-    getNodeModulePathParts: () => getNodeModulePathParts,
-    getNonAssignedNameOfDeclaration: () => getNonAssignedNameOfDeclaration,
-    getNonAssignmentOperatorForCompoundAssignment: () => getNonAssignmentOperatorForCompoundAssignment,
-    getNonAugmentationDeclaration: () => getNonAugmentationDeclaration,
-    getNonDecoratorTokenPosOfNode: () => getNonDecoratorTokenPosOfNode,
-    getNormalizedAbsolutePath: () => getNormalizedAbsolutePath,
-    getNormalizedAbsolutePathWithoutRoot: () => getNormalizedAbsolutePathWithoutRoot,
-    getNormalizedPathComponents: () => getNormalizedPathComponents,
-    getObjectFlags: () => getObjectFlags,
-    getOperator: () => getOperator,
-    getOperatorAssociativity: () => getOperatorAssociativity,
-    getOperatorPrecedence: () => getOperatorPrecedence,
-    getOptionFromName: () => getOptionFromName,
-    getOptionsForLibraryResolution: () => getOptionsForLibraryResolution,
-    getOptionsNameMap: () => getOptionsNameMap,
-    getOrCreateEmitNode: () => getOrCreateEmitNode,
-    getOrCreateExternalHelpersModuleNameIfNeeded: () => getOrCreateExternalHelpersModuleNameIfNeeded,
-    getOrUpdate: () => getOrUpdate,
-    getOriginalNode: () => getOriginalNode,
-    getOriginalNodeId: () => getOriginalNodeId,
-    getOriginalSourceFile: () => getOriginalSourceFile,
-    getOutputDeclarationFileName: () => getOutputDeclarationFileName,
-    getOutputExtension: () => getOutputExtension,
-    getOutputFileNames: () => getOutputFileNames,
-    getOutputPathsFor: () => getOutputPathsFor,
-    getOutputPathsForBundle: () => getOutputPathsForBundle,
-    getOwnEmitOutputFilePath: () => getOwnEmitOutputFilePath,
-    getOwnKeys: () => getOwnKeys,
-    getOwnValues: () => getOwnValues,
-    getPackageJsonInfo: () => getPackageJsonInfo,
-    getPackageJsonTypesVersionsPaths: () => getPackageJsonTypesVersionsPaths,
-    getPackageJsonsVisibleToFile: () => getPackageJsonsVisibleToFile,
-    getPackageNameFromTypesPackageName: () => getPackageNameFromTypesPackageName,
-    getPackageScopeForPath: () => getPackageScopeForPath,
-    getParameterSymbolFromJSDoc: () => getParameterSymbolFromJSDoc,
-    getParameterTypeNode: () => getParameterTypeNode,
-    getParentNodeInSpan: () => getParentNodeInSpan,
-    getParseTreeNode: () => getParseTreeNode,
-    getParsedCommandLineOfConfigFile: () => getParsedCommandLineOfConfigFile,
-    getPathComponents: () => getPathComponents,
-    getPathComponentsRelativeTo: () => getPathComponentsRelativeTo,
-    getPathFromPathComponents: () => getPathFromPathComponents,
-    getPathUpdater: () => getPathUpdater,
-    getPathsBasePath: () => getPathsBasePath,
-    getPatternFromSpec: () => getPatternFromSpec,
-    getPendingEmitKind: () => getPendingEmitKind,
-    getPositionOfLineAndCharacter: () => getPositionOfLineAndCharacter,
-    getPossibleGenericSignatures: () => getPossibleGenericSignatures,
-    getPossibleOriginalInputExtensionForExtension: () => getPossibleOriginalInputExtensionForExtension,
-    getPossibleTypeArgumentsInfo: () => getPossibleTypeArgumentsInfo,
-    getPreEmitDiagnostics: () => getPreEmitDiagnostics,
-    getPrecedingNonSpaceCharacterPosition: () => getPrecedingNonSpaceCharacterPosition,
-    getPrivateIdentifier: () => getPrivateIdentifier,
-    getProperties: () => getProperties,
-    getProperty: () => getProperty,
-    getPropertyArrayElementValue: () => getPropertyArrayElementValue,
-    getPropertyAssignmentAliasLikeExpression: () => getPropertyAssignmentAliasLikeExpression,
-    getPropertyNameForPropertyNameNode: () => getPropertyNameForPropertyNameNode,
-    getPropertyNameForUniqueESSymbol: () => getPropertyNameForUniqueESSymbol,
-    getPropertyNameOfBindingOrAssignmentElement: () => getPropertyNameOfBindingOrAssignmentElement,
-    getPropertySymbolFromBindingElement: () => getPropertySymbolFromBindingElement,
-    getPropertySymbolsFromContextualType: () => getPropertySymbolsFromContextualType,
-    getQuoteFromPreference: () => getQuoteFromPreference,
-    getQuotePreference: () => getQuotePreference,
-    getRangesWhere: () => getRangesWhere,
-    getRefactorContextSpan: () => getRefactorContextSpan,
-    getReferencedFileLocation: () => getReferencedFileLocation,
-    getRegexFromPattern: () => getRegexFromPattern,
-    getRegularExpressionForWildcard: () => getRegularExpressionForWildcard,
-    getRegularExpressionsForWildcards: () => getRegularExpressionsForWildcards,
-    getRelativePathFromDirectory: () => getRelativePathFromDirectory,
-    getRelativePathFromFile: () => getRelativePathFromFile,
-    getRelativePathToDirectoryOrUrl: () => getRelativePathToDirectoryOrUrl,
-    getRenameLocation: () => getRenameLocation,
-    getReplacementSpanForContextToken: () => getReplacementSpanForContextToken,
-    getResolutionDiagnostic: () => getResolutionDiagnostic,
-    getResolutionModeOverrideForClause: () => getResolutionModeOverrideForClause,
-    getResolveJsonModule: () => getResolveJsonModule,
-    getResolvePackageJsonExports: () => getResolvePackageJsonExports,
-    getResolvePackageJsonImports: () => getResolvePackageJsonImports,
-    getResolvedExternalModuleName: () => getResolvedExternalModuleName,
-    getResolvedModule: () => getResolvedModule,
-    getResolvedTypeReferenceDirective: () => getResolvedTypeReferenceDirective,
-    getRestIndicatorOfBindingOrAssignmentElement: () => getRestIndicatorOfBindingOrAssignmentElement,
-    getRestParameterElementType: () => getRestParameterElementType,
-    getRightMostAssignedExpression: () => getRightMostAssignedExpression,
-    getRootDeclaration: () => getRootDeclaration,
-    getRootDirectoryOfResolutionCache: () => getRootDirectoryOfResolutionCache,
-    getRootLength: () => getRootLength,
-    getRootPathSplitLength: () => getRootPathSplitLength,
-    getScriptKind: () => getScriptKind,
-    getScriptKindFromFileName: () => getScriptKindFromFileName,
-    getScriptTargetFeatures: () => getScriptTargetFeatures,
-    getSelectedEffectiveModifierFlags: () => getSelectedEffectiveModifierFlags,
-    getSelectedSyntacticModifierFlags: () => getSelectedSyntacticModifierFlags,
-    getSemanticClassifications: () => getSemanticClassifications,
-    getSemanticJsxChildren: () => getSemanticJsxChildren,
-    getSetAccessorTypeAnnotationNode: () => getSetAccessorTypeAnnotationNode,
-    getSetAccessorValueParameter: () => getSetAccessorValueParameter,
-    getSetExternalModuleIndicator: () => getSetExternalModuleIndicator,
-    getShebang: () => getShebang,
-    getSingleInitializerOfVariableStatementOrPropertyDeclaration: () => getSingleInitializerOfVariableStatementOrPropertyDeclaration,
-    getSingleVariableOfVariableStatement: () => getSingleVariableOfVariableStatement,
-    getSnapshotText: () => getSnapshotText,
-    getSnippetElement: () => getSnippetElement,
-    getSourceFileOfModule: () => getSourceFileOfModule,
-    getSourceFileOfNode: () => getSourceFileOfNode,
-    getSourceFilePathInNewDir: () => getSourceFilePathInNewDir,
-    getSourceFilePathInNewDirWorker: () => getSourceFilePathInNewDirWorker,
-    getSourceFileVersionAsHashFromText: () => getSourceFileVersionAsHashFromText,
-    getSourceFilesToEmit: () => getSourceFilesToEmit,
-    getSourceMapRange: () => getSourceMapRange,
-    getSourceMapper: () => getSourceMapper,
-    getSourceTextOfNodeFromSourceFile: () => getSourceTextOfNodeFromSourceFile,
-    getSpanOfTokenAtPosition: () => getSpanOfTokenAtPosition,
-    getSpellingSuggestion: () => getSpellingSuggestion,
-    getStartPositionOfLine: () => getStartPositionOfLine,
-    getStartPositionOfRange: () => getStartPositionOfRange,
-    getStartsOnNewLine: () => getStartsOnNewLine,
-    getStaticPropertiesAndClassStaticBlock: () => getStaticPropertiesAndClassStaticBlock,
-    getStrictOptionValue: () => getStrictOptionValue,
-    getStringComparer: () => getStringComparer,
-    getSuperCallFromStatement: () => getSuperCallFromStatement,
-    getSuperContainer: () => getSuperContainer,
-    getSupportedCodeFixes: () => getSupportedCodeFixes,
-    getSupportedExtensions: () => getSupportedExtensions,
-    getSupportedExtensionsWithJsonIfResolveJsonModule: () => getSupportedExtensionsWithJsonIfResolveJsonModule,
-    getSwitchedType: () => getSwitchedType,
-    getSymbolId: () => getSymbolId,
-    getSymbolNameForPrivateIdentifier: () => getSymbolNameForPrivateIdentifier,
-    getSymbolTarget: () => getSymbolTarget,
-    getSyntacticClassifications: () => getSyntacticClassifications,
-    getSyntacticModifierFlags: () => getSyntacticModifierFlags,
-    getSyntacticModifierFlagsNoCache: () => getSyntacticModifierFlagsNoCache,
-    getSynthesizedDeepClone: () => getSynthesizedDeepClone,
-    getSynthesizedDeepCloneWithReplacements: () => getSynthesizedDeepCloneWithReplacements,
-    getSynthesizedDeepClones: () => getSynthesizedDeepClones,
-    getSynthesizedDeepClonesWithReplacements: () => getSynthesizedDeepClonesWithReplacements,
-    getSyntheticLeadingComments: () => getSyntheticLeadingComments,
-    getSyntheticTrailingComments: () => getSyntheticTrailingComments,
-    getTargetLabel: () => getTargetLabel,
-    getTargetOfBindingOrAssignmentElement: () => getTargetOfBindingOrAssignmentElement,
-    getTemporaryModuleResolutionState: () => getTemporaryModuleResolutionState,
-    getTextOfConstantValue: () => getTextOfConstantValue,
-    getTextOfIdentifierOrLiteral: () => getTextOfIdentifierOrLiteral,
-    getTextOfJSDocComment: () => getTextOfJSDocComment,
-    getTextOfJsxAttributeName: () => getTextOfJsxAttributeName,
-    getTextOfJsxNamespacedName: () => getTextOfJsxNamespacedName,
-    getTextOfNode: () => getTextOfNode,
-    getTextOfNodeFromSourceText: () => getTextOfNodeFromSourceText,
-    getTextOfPropertyName: () => getTextOfPropertyName,
-    getThisContainer: () => getThisContainer,
-    getThisParameter: () => getThisParameter,
-    getTokenAtPosition: () => getTokenAtPosition,
-    getTokenPosOfNode: () => getTokenPosOfNode,
-    getTokenSourceMapRange: () => getTokenSourceMapRange,
-    getTouchingPropertyName: () => getTouchingPropertyName,
-    getTouchingToken: () => getTouchingToken,
-    getTrailingCommentRanges: () => getTrailingCommentRanges,
-    getTrailingSemicolonDeferringWriter: () => getTrailingSemicolonDeferringWriter,
-    getTransformFlagsSubtreeExclusions: () => getTransformFlagsSubtreeExclusions,
-    getTransformers: () => getTransformers,
-    getTsBuildInfoEmitOutputFilePath: () => getTsBuildInfoEmitOutputFilePath,
-    getTsConfigObjectLiteralExpression: () => getTsConfigObjectLiteralExpression,
-    getTsConfigPropArrayElementValue: () => getTsConfigPropArrayElementValue,
-    getTypeAnnotationNode: () => getTypeAnnotationNode,
-    getTypeArgumentOrTypeParameterList: () => getTypeArgumentOrTypeParameterList,
-    getTypeKeywordOfTypeOnlyImport: () => getTypeKeywordOfTypeOnlyImport,
-    getTypeNode: () => getTypeNode,
-    getTypeNodeIfAccessible: () => getTypeNodeIfAccessible,
-    getTypeParameterFromJsDoc: () => getTypeParameterFromJsDoc,
-    getTypeParameterOwner: () => getTypeParameterOwner,
-    getTypesPackageName: () => getTypesPackageName,
-    getUILocale: () => getUILocale,
-    getUniqueName: () => getUniqueName,
-    getUniqueSymbolId: () => getUniqueSymbolId,
-    getUseDefineForClassFields: () => getUseDefineForClassFields,
-    getWatchErrorSummaryDiagnosticMessage: () => getWatchErrorSummaryDiagnosticMessage,
-    getWatchFactory: () => getWatchFactory,
-    group: () => group,
-    groupBy: () => groupBy,
-    guessIndentation: () => guessIndentation,
-    handleNoEmitOptions: () => handleNoEmitOptions,
-    hasAbstractModifier: () => hasAbstractModifier,
-    hasAccessorModifier: () => hasAccessorModifier,
-    hasAmbientModifier: () => hasAmbientModifier,
-    hasChangesInResolutions: () => hasChangesInResolutions,
-    hasChildOfKind: () => hasChildOfKind,
-    hasContextSensitiveParameters: () => hasContextSensitiveParameters,
-    hasDecorators: () => hasDecorators,
-    hasDocComment: () => hasDocComment,
-    hasDynamicName: () => hasDynamicName,
-    hasEffectiveModifier: () => hasEffectiveModifier,
-    hasEffectiveModifiers: () => hasEffectiveModifiers,
-    hasEffectiveReadonlyModifier: () => hasEffectiveReadonlyModifier,
-    hasExtension: () => hasExtension,
-    hasIndexSignature: () => hasIndexSignature,
-    hasInitializer: () => hasInitializer,
-    hasInvalidEscape: () => hasInvalidEscape,
-    hasJSDocNodes: () => hasJSDocNodes,
-    hasJSDocParameterTags: () => hasJSDocParameterTags,
-    hasJSFileExtension: () => hasJSFileExtension,
-    hasJsonModuleEmitEnabled: () => hasJsonModuleEmitEnabled,
-    hasOnlyExpressionInitializer: () => hasOnlyExpressionInitializer,
-    hasOverrideModifier: () => hasOverrideModifier,
-    hasPossibleExternalModuleReference: () => hasPossibleExternalModuleReference,
-    hasProperty: () => hasProperty,
-    hasPropertyAccessExpressionWithName: () => hasPropertyAccessExpressionWithName,
-    hasQuestionToken: () => hasQuestionToken,
-    hasRecordedExternalHelpers: () => hasRecordedExternalHelpers,
-    hasRestParameter: () => hasRestParameter,
-    hasScopeMarker: () => hasScopeMarker,
-    hasStaticModifier: () => hasStaticModifier,
-    hasSyntacticModifier: () => hasSyntacticModifier,
-    hasSyntacticModifiers: () => hasSyntacticModifiers,
-    hasTSFileExtension: () => hasTSFileExtension,
-    hasTabstop: () => hasTabstop,
-    hasTrailingDirectorySeparator: () => hasTrailingDirectorySeparator,
-    hasType: () => hasType,
-    hasTypeArguments: () => hasTypeArguments,
-    hasZeroOrOneAsteriskCharacter: () => hasZeroOrOneAsteriskCharacter,
-    helperString: () => helperString,
-    hostGetCanonicalFileName: () => hostGetCanonicalFileName,
-    hostUsesCaseSensitiveFileNames: () => hostUsesCaseSensitiveFileNames,
-    idText: () => idText,
-    identifierIsThisKeyword: () => identifierIsThisKeyword,
-    identifierToKeywordKind: () => identifierToKeywordKind,
-    identity: () => identity,
-    identitySourceMapConsumer: () => identitySourceMapConsumer,
-    ignoreSourceNewlines: () => ignoreSourceNewlines,
-    ignoredPaths: () => ignoredPaths,
-    importDefaultHelper: () => importDefaultHelper,
-    importFromModuleSpecifier: () => importFromModuleSpecifier,
-    importNameElisionDisabled: () => importNameElisionDisabled,
-    importStarHelper: () => importStarHelper,
-    indexOfAnyCharCode: () => indexOfAnyCharCode,
-    indexOfNode: () => indexOfNode,
-    indicesOf: () => indicesOf,
-    inferredTypesContainingFile: () => inferredTypesContainingFile,
-    insertImports: () => insertImports,
-    insertLeadingStatement: () => insertLeadingStatement,
-    insertSorted: () => insertSorted,
-    insertStatementAfterCustomPrologue: () => insertStatementAfterCustomPrologue,
-    insertStatementAfterStandardPrologue: () => insertStatementAfterStandardPrologue,
-    insertStatementsAfterCustomPrologue: () => insertStatementsAfterCustomPrologue,
-    insertStatementsAfterStandardPrologue: () => insertStatementsAfterStandardPrologue,
-    intersperse: () => intersperse,
-    intrinsicTagNameToString: () => intrinsicTagNameToString,
-    introducesArgumentsExoticObject: () => introducesArgumentsExoticObject,
-    inverseJsxOptionMap: () => inverseJsxOptionMap,
-    isAbstractConstructorSymbol: () => isAbstractConstructorSymbol,
-    isAbstractModifier: () => isAbstractModifier,
-    isAccessExpression: () => isAccessExpression,
-    isAccessibilityModifier: () => isAccessibilityModifier,
-    isAccessor: () => isAccessor,
-    isAccessorModifier: () => isAccessorModifier,
-    isAliasSymbolDeclaration: () => isAliasSymbolDeclaration,
-    isAliasableExpression: () => isAliasableExpression,
-    isAmbientModule: () => isAmbientModule,
-    isAmbientPropertyDeclaration: () => isAmbientPropertyDeclaration,
-    isAnonymousFunctionDefinition: () => isAnonymousFunctionDefinition,
-    isAnyDirectorySeparator: () => isAnyDirectorySeparator,
-    isAnyImportOrBareOrAccessedRequire: () => isAnyImportOrBareOrAccessedRequire,
-    isAnyImportOrReExport: () => isAnyImportOrReExport,
-    isAnyImportSyntax: () => isAnyImportSyntax,
-    isAnySupportedFileExtension: () => isAnySupportedFileExtension,
-    isApplicableVersionedTypesKey: () => isApplicableVersionedTypesKey,
-    isArgumentExpressionOfElementAccess: () => isArgumentExpressionOfElementAccess,
-    isArray: () => isArray,
-    isArrayBindingElement: () => isArrayBindingElement,
-    isArrayBindingOrAssignmentElement: () => isArrayBindingOrAssignmentElement,
-    isArrayBindingOrAssignmentPattern: () => isArrayBindingOrAssignmentPattern,
-    isArrayBindingPattern: () => isArrayBindingPattern,
-    isArrayLiteralExpression: () => isArrayLiteralExpression,
-    isArrayLiteralOrObjectLiteralDestructuringPattern: () => isArrayLiteralOrObjectLiteralDestructuringPattern,
-    isArrayTypeNode: () => isArrayTypeNode,
-    isArrowFunction: () => isArrowFunction,
-    isAsExpression: () => isAsExpression,
-    isAssertClause: () => isAssertClause,
-    isAssertEntry: () => isAssertEntry,
-    isAssertionExpression: () => isAssertionExpression,
-    isAssertionKey: () => isAssertionKey,
-    isAssertsKeyword: () => isAssertsKeyword,
-    isAssignmentDeclaration: () => isAssignmentDeclaration,
-    isAssignmentExpression: () => isAssignmentExpression,
-    isAssignmentOperator: () => isAssignmentOperator,
-    isAssignmentPattern: () => isAssignmentPattern,
-    isAssignmentTarget: () => isAssignmentTarget,
-    isAsteriskToken: () => isAsteriskToken,
-    isAsyncFunction: () => isAsyncFunction,
-    isAsyncModifier: () => isAsyncModifier,
-    isAutoAccessorPropertyDeclaration: () => isAutoAccessorPropertyDeclaration,
-    isAwaitExpression: () => isAwaitExpression,
-    isAwaitKeyword: () => isAwaitKeyword,
-    isBigIntLiteral: () => isBigIntLiteral,
-    isBinaryExpression: () => isBinaryExpression,
-    isBinaryOperatorToken: () => isBinaryOperatorToken,
-    isBindableObjectDefinePropertyCall: () => isBindableObjectDefinePropertyCall,
-    isBindableStaticAccessExpression: () => isBindableStaticAccessExpression,
-    isBindableStaticElementAccessExpression: () => isBindableStaticElementAccessExpression,
-    isBindableStaticNameExpression: () => isBindableStaticNameExpression,
-    isBindingElement: () => isBindingElement,
-    isBindingElementOfBareOrAccessedRequire: () => isBindingElementOfBareOrAccessedRequire,
-    isBindingName: () => isBindingName,
-    isBindingOrAssignmentElement: () => isBindingOrAssignmentElement,
-    isBindingOrAssignmentPattern: () => isBindingOrAssignmentPattern,
-    isBindingPattern: () => isBindingPattern,
-    isBlock: () => isBlock,
-    isBlockOrCatchScoped: () => isBlockOrCatchScoped,
-    isBlockScope: () => isBlockScope,
-    isBlockScopedContainerTopLevel: () => isBlockScopedContainerTopLevel,
-    isBooleanLiteral: () => isBooleanLiteral,
-    isBreakOrContinueStatement: () => isBreakOrContinueStatement,
-    isBreakStatement: () => isBreakStatement,
-    isBuildInfoFile: () => isBuildInfoFile,
-    isBuilderProgram: () => isBuilderProgram2,
-    isBundle: () => isBundle,
-    isBundleFileTextLike: () => isBundleFileTextLike,
-    isCallChain: () => isCallChain,
-    isCallExpression: () => isCallExpression,
-    isCallExpressionTarget: () => isCallExpressionTarget,
-    isCallLikeExpression: () => isCallLikeExpression,
-    isCallOrNewExpression: () => isCallOrNewExpression,
-    isCallOrNewExpressionTarget: () => isCallOrNewExpressionTarget,
-    isCallSignatureDeclaration: () => isCallSignatureDeclaration,
-    isCallToHelper: () => isCallToHelper,
-    isCaseBlock: () => isCaseBlock,
-    isCaseClause: () => isCaseClause,
-    isCaseKeyword: () => isCaseKeyword,
-    isCaseOrDefaultClause: () => isCaseOrDefaultClause,
-    isCatchClause: () => isCatchClause,
-    isCatchClauseVariableDeclaration: () => isCatchClauseVariableDeclaration,
-    isCatchClauseVariableDeclarationOrBindingElement: () => isCatchClauseVariableDeclarationOrBindingElement,
-    isCheckJsEnabledForFile: () => isCheckJsEnabledForFile,
-    isChildOfNodeWithKind: () => isChildOfNodeWithKind,
-    isCircularBuildOrder: () => isCircularBuildOrder,
-    isClassDeclaration: () => isClassDeclaration,
-    isClassElement: () => isClassElement,
-    isClassExpression: () => isClassExpression,
-    isClassLike: () => isClassLike,
-    isClassMemberModifier: () => isClassMemberModifier,
-    isClassOrTypeElement: () => isClassOrTypeElement,
-    isClassStaticBlockDeclaration: () => isClassStaticBlockDeclaration,
-    isCollapsedRange: () => isCollapsedRange,
-    isColonToken: () => isColonToken,
-    isCommaExpression: () => isCommaExpression,
-    isCommaListExpression: () => isCommaListExpression,
-    isCommaSequence: () => isCommaSequence,
-    isCommaToken: () => isCommaToken,
-    isComment: () => isComment,
-    isCommonJsExportPropertyAssignment: () => isCommonJsExportPropertyAssignment,
-    isCommonJsExportedExpression: () => isCommonJsExportedExpression,
-    isCompoundAssignment: () => isCompoundAssignment,
-    isComputedNonLiteralName: () => isComputedNonLiteralName,
-    isComputedPropertyName: () => isComputedPropertyName,
-    isConciseBody: () => isConciseBody,
-    isConditionalExpression: () => isConditionalExpression,
-    isConditionalTypeNode: () => isConditionalTypeNode,
-    isConstTypeReference: () => isConstTypeReference,
-    isConstructSignatureDeclaration: () => isConstructSignatureDeclaration,
-    isConstructorDeclaration: () => isConstructorDeclaration,
-    isConstructorTypeNode: () => isConstructorTypeNode,
-    isContextualKeyword: () => isContextualKeyword,
-    isContinueStatement: () => isContinueStatement,
-    isCustomPrologue: () => isCustomPrologue,
-    isDebuggerStatement: () => isDebuggerStatement,
-    isDeclaration: () => isDeclaration,
-    isDeclarationBindingElement: () => isDeclarationBindingElement,
-    isDeclarationFileName: () => isDeclarationFileName,
-    isDeclarationName: () => isDeclarationName,
-    isDeclarationNameOfEnumOrNamespace: () => isDeclarationNameOfEnumOrNamespace,
-    isDeclarationReadonly: () => isDeclarationReadonly,
-    isDeclarationStatement: () => isDeclarationStatement,
-    isDeclarationWithTypeParameterChildren: () => isDeclarationWithTypeParameterChildren,
-    isDeclarationWithTypeParameters: () => isDeclarationWithTypeParameters,
-    isDecorator: () => isDecorator,
-    isDecoratorTarget: () => isDecoratorTarget,
-    isDefaultClause: () => isDefaultClause,
-    isDefaultImport: () => isDefaultImport,
-    isDefaultModifier: () => isDefaultModifier,
-    isDefaultedExpandoInitializer: () => isDefaultedExpandoInitializer,
-    isDeleteExpression: () => isDeleteExpression,
-    isDeleteTarget: () => isDeleteTarget,
-    isDeprecatedDeclaration: () => isDeprecatedDeclaration,
-    isDestructuringAssignment: () => isDestructuringAssignment,
-    isDiagnosticWithLocation: () => isDiagnosticWithLocation,
-    isDiskPathRoot: () => isDiskPathRoot,
-    isDoStatement: () => isDoStatement,
-    isDotDotDotToken: () => isDotDotDotToken,
-    isDottedName: () => isDottedName,
-    isDynamicName: () => isDynamicName,
-    isESSymbolIdentifier: () => isESSymbolIdentifier,
-    isEffectiveExternalModule: () => isEffectiveExternalModule,
-    isEffectiveModuleDeclaration: () => isEffectiveModuleDeclaration,
-    isEffectiveStrictModeSourceFile: () => isEffectiveStrictModeSourceFile,
-    isElementAccessChain: () => isElementAccessChain,
-    isElementAccessExpression: () => isElementAccessExpression,
-    isEmittedFileOfProgram: () => isEmittedFileOfProgram,
-    isEmptyArrayLiteral: () => isEmptyArrayLiteral,
-    isEmptyBindingElement: () => isEmptyBindingElement,
-    isEmptyBindingPattern: () => isEmptyBindingPattern,
-    isEmptyObjectLiteral: () => isEmptyObjectLiteral,
-    isEmptyStatement: () => isEmptyStatement,
-    isEmptyStringLiteral: () => isEmptyStringLiteral,
-    isEntityName: () => isEntityName,
-    isEntityNameExpression: () => isEntityNameExpression,
-    isEnumConst: () => isEnumConst,
-    isEnumDeclaration: () => isEnumDeclaration,
-    isEnumMember: () => isEnumMember,
-    isEqualityOperatorKind: () => isEqualityOperatorKind,
-    isEqualsGreaterThanToken: () => isEqualsGreaterThanToken,
-    isExclamationToken: () => isExclamationToken,
-    isExcludedFile: () => isExcludedFile,
-    isExclusivelyTypeOnlyImportOrExport: () => isExclusivelyTypeOnlyImportOrExport,
-    isExportAssignment: () => isExportAssignment,
-    isExportDeclaration: () => isExportDeclaration,
-    isExportModifier: () => isExportModifier,
-    isExportName: () => isExportName,
-    isExportNamespaceAsDefaultDeclaration: () => isExportNamespaceAsDefaultDeclaration,
-    isExportOrDefaultModifier: () => isExportOrDefaultModifier,
-    isExportSpecifier: () => isExportSpecifier,
-    isExportsIdentifier: () => isExportsIdentifier,
-    isExportsOrModuleExportsOrAlias: () => isExportsOrModuleExportsOrAlias,
-    isExpression: () => isExpression,
-    isExpressionNode: () => isExpressionNode,
-    isExpressionOfExternalModuleImportEqualsDeclaration: () => isExpressionOfExternalModuleImportEqualsDeclaration,
-    isExpressionOfOptionalChainRoot: () => isExpressionOfOptionalChainRoot,
-    isExpressionStatement: () => isExpressionStatement,
-    isExpressionWithTypeArguments: () => isExpressionWithTypeArguments,
-    isExpressionWithTypeArgumentsInClassExtendsClause: () => isExpressionWithTypeArgumentsInClassExtendsClause,
-    isExternalModule: () => isExternalModule,
-    isExternalModuleAugmentation: () => isExternalModuleAugmentation,
-    isExternalModuleImportEqualsDeclaration: () => isExternalModuleImportEqualsDeclaration,
-    isExternalModuleIndicator: () => isExternalModuleIndicator,
-    isExternalModuleNameRelative: () => isExternalModuleNameRelative,
-    isExternalModuleReference: () => isExternalModuleReference,
-    isExternalModuleSymbol: () => isExternalModuleSymbol,
-    isExternalOrCommonJsModule: () => isExternalOrCommonJsModule,
-    isFileLevelUniqueName: () => isFileLevelUniqueName,
-    isFileProbablyExternalModule: () => isFileProbablyExternalModule,
-    isFirstDeclarationOfSymbolParameter: () => isFirstDeclarationOfSymbolParameter,
-    isFixablePromiseHandler: () => isFixablePromiseHandler,
-    isForInOrOfStatement: () => isForInOrOfStatement,
-    isForInStatement: () => isForInStatement,
-    isForInitializer: () => isForInitializer,
-    isForOfStatement: () => isForOfStatement,
-    isForStatement: () => isForStatement,
-    isFunctionBlock: () => isFunctionBlock,
-    isFunctionBody: () => isFunctionBody,
-    isFunctionDeclaration: () => isFunctionDeclaration,
-    isFunctionExpression: () => isFunctionExpression,
-    isFunctionExpressionOrArrowFunction: () => isFunctionExpressionOrArrowFunction,
-    isFunctionLike: () => isFunctionLike,
-    isFunctionLikeDeclaration: () => isFunctionLikeDeclaration,
-    isFunctionLikeKind: () => isFunctionLikeKind,
-    isFunctionLikeOrClassStaticBlockDeclaration: () => isFunctionLikeOrClassStaticBlockDeclaration,
-    isFunctionOrConstructorTypeNode: () => isFunctionOrConstructorTypeNode,
-    isFunctionOrModuleBlock: () => isFunctionOrModuleBlock,
-    isFunctionSymbol: () => isFunctionSymbol,
-    isFunctionTypeNode: () => isFunctionTypeNode,
-    isFutureReservedKeyword: () => isFutureReservedKeyword,
-    isGeneratedIdentifier: () => isGeneratedIdentifier,
-    isGeneratedPrivateIdentifier: () => isGeneratedPrivateIdentifier,
-    isGetAccessor: () => isGetAccessor,
-    isGetAccessorDeclaration: () => isGetAccessorDeclaration,
-    isGetOrSetAccessorDeclaration: () => isGetOrSetAccessorDeclaration,
-    isGlobalDeclaration: () => isGlobalDeclaration,
-    isGlobalScopeAugmentation: () => isGlobalScopeAugmentation,
-    isGrammarError: () => isGrammarError,
-    isHeritageClause: () => isHeritageClause,
-    isHoistedFunction: () => isHoistedFunction,
-    isHoistedVariableStatement: () => isHoistedVariableStatement,
-    isIdentifier: () => isIdentifier,
-    isIdentifierANonContextualKeyword: () => isIdentifierANonContextualKeyword,
-    isIdentifierName: () => isIdentifierName,
-    isIdentifierOrThisTypeNode: () => isIdentifierOrThisTypeNode,
-    isIdentifierPart: () => isIdentifierPart,
-    isIdentifierStart: () => isIdentifierStart,
-    isIdentifierText: () => isIdentifierText,
-    isIdentifierTypePredicate: () => isIdentifierTypePredicate,
-    isIdentifierTypeReference: () => isIdentifierTypeReference,
-    isIfStatement: () => isIfStatement,
-    isIgnoredFileFromWildCardWatching: () => isIgnoredFileFromWildCardWatching,
-    isImplicitGlob: () => isImplicitGlob,
-    isImportCall: () => isImportCall,
-    isImportClause: () => isImportClause,
-    isImportDeclaration: () => isImportDeclaration,
-    isImportEqualsDeclaration: () => isImportEqualsDeclaration,
-    isImportKeyword: () => isImportKeyword,
-    isImportMeta: () => isImportMeta,
-    isImportOrExportSpecifier: () => isImportOrExportSpecifier,
-    isImportOrExportSpecifierName: () => isImportOrExportSpecifierName,
-    isImportSpecifier: () => isImportSpecifier,
-    isImportTypeAssertionContainer: () => isImportTypeAssertionContainer,
-    isImportTypeNode: () => isImportTypeNode,
-    isImportableFile: () => isImportableFile,
-    isInComment: () => isInComment,
-    isInExpressionContext: () => isInExpressionContext,
-    isInJSDoc: () => isInJSDoc,
-    isInJSFile: () => isInJSFile,
-    isInJSXText: () => isInJSXText,
-    isInJsonFile: () => isInJsonFile,
-    isInNonReferenceComment: () => isInNonReferenceComment,
-    isInReferenceComment: () => isInReferenceComment,
-    isInRightSideOfInternalImportEqualsDeclaration: () => isInRightSideOfInternalImportEqualsDeclaration,
-    isInString: () => isInString,
-    isInTemplateString: () => isInTemplateString,
-    isInTopLevelContext: () => isInTopLevelContext,
-    isIncrementalCompilation: () => isIncrementalCompilation,
-    isIndexSignatureDeclaration: () => isIndexSignatureDeclaration,
-    isIndexedAccessTypeNode: () => isIndexedAccessTypeNode,
-    isInferTypeNode: () => isInferTypeNode,
-    isInfinityOrNaNString: () => isInfinityOrNaNString,
-    isInitializedProperty: () => isInitializedProperty,
-    isInitializedVariable: () => isInitializedVariable,
-    isInsideJsxElement: () => isInsideJsxElement,
-    isInsideJsxElementOrAttribute: () => isInsideJsxElementOrAttribute,
-    isInsideNodeModules: () => isInsideNodeModules,
-    isInsideTemplateLiteral: () => isInsideTemplateLiteral,
-    isInstantiatedModule: () => isInstantiatedModule,
-    isInterfaceDeclaration: () => isInterfaceDeclaration,
-    isInternalDeclaration: () => isInternalDeclaration,
-    isInternalModuleImportEqualsDeclaration: () => isInternalModuleImportEqualsDeclaration,
-    isInternalName: () => isInternalName,
-    isIntersectionTypeNode: () => isIntersectionTypeNode,
-    isIntrinsicJsxName: () => isIntrinsicJsxName,
-    isIterationStatement: () => isIterationStatement,
-    isJSDoc: () => isJSDoc,
-    isJSDocAllType: () => isJSDocAllType,
-    isJSDocAugmentsTag: () => isJSDocAugmentsTag,
-    isJSDocAuthorTag: () => isJSDocAuthorTag,
-    isJSDocCallbackTag: () => isJSDocCallbackTag,
-    isJSDocClassTag: () => isJSDocClassTag,
-    isJSDocCommentContainingNode: () => isJSDocCommentContainingNode,
-    isJSDocConstructSignature: () => isJSDocConstructSignature,
-    isJSDocDeprecatedTag: () => isJSDocDeprecatedTag,
-    isJSDocEnumTag: () => isJSDocEnumTag,
-    isJSDocFunctionType: () => isJSDocFunctionType,
-    isJSDocImplementsTag: () => isJSDocImplementsTag,
-    isJSDocIndexSignature: () => isJSDocIndexSignature,
-    isJSDocLikeText: () => isJSDocLikeText,
-    isJSDocLink: () => isJSDocLink,
-    isJSDocLinkCode: () => isJSDocLinkCode,
-    isJSDocLinkLike: () => isJSDocLinkLike,
-    isJSDocLinkPlain: () => isJSDocLinkPlain,
-    isJSDocMemberName: () => isJSDocMemberName,
-    isJSDocNameReference: () => isJSDocNameReference,
-    isJSDocNamepathType: () => isJSDocNamepathType,
-    isJSDocNamespaceBody: () => isJSDocNamespaceBody,
-    isJSDocNode: () => isJSDocNode,
-    isJSDocNonNullableType: () => isJSDocNonNullableType,
-    isJSDocNullableType: () => isJSDocNullableType,
-    isJSDocOptionalParameter: () => isJSDocOptionalParameter,
-    isJSDocOptionalType: () => isJSDocOptionalType,
-    isJSDocOverloadTag: () => isJSDocOverloadTag,
-    isJSDocOverrideTag: () => isJSDocOverrideTag,
-    isJSDocParameterTag: () => isJSDocParameterTag,
-    isJSDocPrivateTag: () => isJSDocPrivateTag,
-    isJSDocPropertyLikeTag: () => isJSDocPropertyLikeTag,
-    isJSDocPropertyTag: () => isJSDocPropertyTag,
-    isJSDocProtectedTag: () => isJSDocProtectedTag,
-    isJSDocPublicTag: () => isJSDocPublicTag,
-    isJSDocReadonlyTag: () => isJSDocReadonlyTag,
-    isJSDocReturnTag: () => isJSDocReturnTag,
-    isJSDocSatisfiesExpression: () => isJSDocSatisfiesExpression,
-    isJSDocSatisfiesTag: () => isJSDocSatisfiesTag,
-    isJSDocSeeTag: () => isJSDocSeeTag,
-    isJSDocSignature: () => isJSDocSignature,
-    isJSDocTag: () => isJSDocTag,
-    isJSDocTemplateTag: () => isJSDocTemplateTag,
-    isJSDocThisTag: () => isJSDocThisTag,
-    isJSDocThrowsTag: () => isJSDocThrowsTag,
-    isJSDocTypeAlias: () => isJSDocTypeAlias,
-    isJSDocTypeAssertion: () => isJSDocTypeAssertion,
-    isJSDocTypeExpression: () => isJSDocTypeExpression,
-    isJSDocTypeLiteral: () => isJSDocTypeLiteral,
-    isJSDocTypeTag: () => isJSDocTypeTag,
-    isJSDocTypedefTag: () => isJSDocTypedefTag,
-    isJSDocUnknownTag: () => isJSDocUnknownTag,
-    isJSDocUnknownType: () => isJSDocUnknownType,
-    isJSDocVariadicType: () => isJSDocVariadicType,
-    isJSXTagName: () => isJSXTagName,
-    isJsonEqual: () => isJsonEqual,
-    isJsonSourceFile: () => isJsonSourceFile,
-    isJsxAttribute: () => isJsxAttribute,
-    isJsxAttributeLike: () => isJsxAttributeLike,
-    isJsxAttributeName: () => isJsxAttributeName,
-    isJsxAttributes: () => isJsxAttributes,
-    isJsxChild: () => isJsxChild,
-    isJsxClosingElement: () => isJsxClosingElement,
-    isJsxClosingFragment: () => isJsxClosingFragment,
-    isJsxElement: () => isJsxElement,
-    isJsxExpression: () => isJsxExpression,
-    isJsxFragment: () => isJsxFragment,
-    isJsxNamespacedName: () => isJsxNamespacedName,
-    isJsxOpeningElement: () => isJsxOpeningElement,
-    isJsxOpeningFragment: () => isJsxOpeningFragment,
-    isJsxOpeningLikeElement: () => isJsxOpeningLikeElement,
-    isJsxOpeningLikeElementTagName: () => isJsxOpeningLikeElementTagName,
-    isJsxSelfClosingElement: () => isJsxSelfClosingElement,
-    isJsxSpreadAttribute: () => isJsxSpreadAttribute,
-    isJsxTagNameExpression: () => isJsxTagNameExpression,
-    isJsxText: () => isJsxText,
-    isJumpStatementTarget: () => isJumpStatementTarget,
-    isKeyword: () => isKeyword,
-    isKeywordOrPunctuation: () => isKeywordOrPunctuation,
-    isKnownSymbol: () => isKnownSymbol,
-    isLabelName: () => isLabelName,
-    isLabelOfLabeledStatement: () => isLabelOfLabeledStatement,
-    isLabeledStatement: () => isLabeledStatement,
-    isLateVisibilityPaintedStatement: () => isLateVisibilityPaintedStatement,
-    isLeftHandSideExpression: () => isLeftHandSideExpression,
-    isLeftHandSideOfAssignment: () => isLeftHandSideOfAssignment,
-    isLet: () => isLet,
-    isLineBreak: () => isLineBreak,
-    isLiteralComputedPropertyDeclarationName: () => isLiteralComputedPropertyDeclarationName,
-    isLiteralExpression: () => isLiteralExpression,
-    isLiteralExpressionOfObject: () => isLiteralExpressionOfObject,
-    isLiteralImportTypeNode: () => isLiteralImportTypeNode,
-    isLiteralKind: () => isLiteralKind,
-    isLiteralLikeAccess: () => isLiteralLikeAccess,
-    isLiteralLikeElementAccess: () => isLiteralLikeElementAccess,
-    isLiteralNameOfPropertyDeclarationOrIndexAccess: () => isLiteralNameOfPropertyDeclarationOrIndexAccess,
-    isLiteralTypeLikeExpression: () => isLiteralTypeLikeExpression,
-    isLiteralTypeLiteral: () => isLiteralTypeLiteral,
-    isLiteralTypeNode: () => isLiteralTypeNode,
-    isLocalName: () => isLocalName,
-    isLogicalOperator: () => isLogicalOperator,
-    isLogicalOrCoalescingAssignmentExpression: () => isLogicalOrCoalescingAssignmentExpression,
-    isLogicalOrCoalescingAssignmentOperator: () => isLogicalOrCoalescingAssignmentOperator,
-    isLogicalOrCoalescingBinaryExpression: () => isLogicalOrCoalescingBinaryExpression,
-    isLogicalOrCoalescingBinaryOperator: () => isLogicalOrCoalescingBinaryOperator,
-    isMappedTypeNode: () => isMappedTypeNode,
-    isMemberName: () => isMemberName,
-    isMetaProperty: () => isMetaProperty,
-    isMethodDeclaration: () => isMethodDeclaration,
-    isMethodOrAccessor: () => isMethodOrAccessor,
-    isMethodSignature: () => isMethodSignature,
-    isMinusToken: () => isMinusToken,
-    isMissingDeclaration: () => isMissingDeclaration,
-    isModifier: () => isModifier,
-    isModifierKind: () => isModifierKind,
-    isModifierLike: () => isModifierLike,
-    isModuleAugmentationExternal: () => isModuleAugmentationExternal,
-    isModuleBlock: () => isModuleBlock,
-    isModuleBody: () => isModuleBody,
-    isModuleDeclaration: () => isModuleDeclaration,
-    isModuleExportsAccessExpression: () => isModuleExportsAccessExpression,
-    isModuleIdentifier: () => isModuleIdentifier,
-    isModuleName: () => isModuleName,
-    isModuleOrEnumDeclaration: () => isModuleOrEnumDeclaration,
-    isModuleReference: () => isModuleReference,
-    isModuleSpecifierLike: () => isModuleSpecifierLike,
-    isModuleWithStringLiteralName: () => isModuleWithStringLiteralName,
-    isNameOfFunctionDeclaration: () => isNameOfFunctionDeclaration,
-    isNameOfModuleDeclaration: () => isNameOfModuleDeclaration,
-    isNamedClassElement: () => isNamedClassElement,
-    isNamedDeclaration: () => isNamedDeclaration,
-    isNamedEvaluation: () => isNamedEvaluation,
-    isNamedEvaluationSource: () => isNamedEvaluationSource,
-    isNamedExportBindings: () => isNamedExportBindings,
-    isNamedExports: () => isNamedExports,
-    isNamedImportBindings: () => isNamedImportBindings,
-    isNamedImports: () => isNamedImports,
-    isNamedImportsOrExports: () => isNamedImportsOrExports,
-    isNamedTupleMember: () => isNamedTupleMember,
-    isNamespaceBody: () => isNamespaceBody,
-    isNamespaceExport: () => isNamespaceExport,
-    isNamespaceExportDeclaration: () => isNamespaceExportDeclaration,
-    isNamespaceImport: () => isNamespaceImport,
-    isNamespaceReexportDeclaration: () => isNamespaceReexportDeclaration,
-    isNewExpression: () => isNewExpression,
-    isNewExpressionTarget: () => isNewExpressionTarget,
-    isNightly: () => isNightly,
-    isNoSubstitutionTemplateLiteral: () => isNoSubstitutionTemplateLiteral,
-    isNode: () => isNode,
-    isNodeArray: () => isNodeArray,
-    isNodeArrayMultiLine: () => isNodeArrayMultiLine,
-    isNodeDescendantOf: () => isNodeDescendantOf,
-    isNodeKind: () => isNodeKind,
-    isNodeLikeSystem: () => isNodeLikeSystem,
-    isNodeModulesDirectory: () => isNodeModulesDirectory,
-    isNodeWithPossibleHoistedDeclaration: () => isNodeWithPossibleHoistedDeclaration,
-    isNonContextualKeyword: () => isNonContextualKeyword,
-    isNonExportDefaultModifier: () => isNonExportDefaultModifier,
-    isNonGlobalAmbientModule: () => isNonGlobalAmbientModule,
-    isNonGlobalDeclaration: () => isNonGlobalDeclaration,
-    isNonNullAccess: () => isNonNullAccess,
-    isNonNullChain: () => isNonNullChain,
-    isNonNullExpression: () => isNonNullExpression,
-    isNonStaticMethodOrAccessorWithPrivateName: () => isNonStaticMethodOrAccessorWithPrivateName,
-    isNotEmittedOrPartiallyEmittedNode: () => isNotEmittedOrPartiallyEmittedNode,
-    isNotEmittedStatement: () => isNotEmittedStatement,
-    isNullishCoalesce: () => isNullishCoalesce,
-    isNumber: () => isNumber,
-    isNumericLiteral: () => isNumericLiteral,
-    isNumericLiteralName: () => isNumericLiteralName,
-    isObjectBindingElementWithoutPropertyName: () => isObjectBindingElementWithoutPropertyName,
-    isObjectBindingOrAssignmentElement: () => isObjectBindingOrAssignmentElement,
-    isObjectBindingOrAssignmentPattern: () => isObjectBindingOrAssignmentPattern,
-    isObjectBindingPattern: () => isObjectBindingPattern,
-    isObjectLiteralElement: () => isObjectLiteralElement,
-    isObjectLiteralElementLike: () => isObjectLiteralElementLike,
-    isObjectLiteralExpression: () => isObjectLiteralExpression,
-    isObjectLiteralMethod: () => isObjectLiteralMethod,
-    isObjectLiteralOrClassExpressionMethodOrAccessor: () => isObjectLiteralOrClassExpressionMethodOrAccessor,
-    isObjectTypeDeclaration: () => isObjectTypeDeclaration,
-    isOctalDigit: () => isOctalDigit,
-    isOmittedExpression: () => isOmittedExpression,
-    isOptionalChain: () => isOptionalChain,
-    isOptionalChainRoot: () => isOptionalChainRoot,
-    isOptionalDeclaration: () => isOptionalDeclaration,
-    isOptionalJSDocPropertyLikeTag: () => isOptionalJSDocPropertyLikeTag,
-    isOptionalTypeNode: () => isOptionalTypeNode,
-    isOuterExpression: () => isOuterExpression,
-    isOutermostOptionalChain: () => isOutermostOptionalChain,
-    isOverrideModifier: () => isOverrideModifier,
-    isPackedArrayLiteral: () => isPackedArrayLiteral,
-    isParameter: () => isParameter,
-    isParameterDeclaration: () => isParameterDeclaration,
-    isParameterOrCatchClauseVariable: () => isParameterOrCatchClauseVariable,
-    isParameterPropertyDeclaration: () => isParameterPropertyDeclaration,
-    isParameterPropertyModifier: () => isParameterPropertyModifier,
-    isParenthesizedExpression: () => isParenthesizedExpression,
-    isParenthesizedTypeNode: () => isParenthesizedTypeNode,
-    isParseTreeNode: () => isParseTreeNode,
-    isPartOfTypeNode: () => isPartOfTypeNode,
-    isPartOfTypeQuery: () => isPartOfTypeQuery,
-    isPartiallyEmittedExpression: () => isPartiallyEmittedExpression,
-    isPatternMatch: () => isPatternMatch,
-    isPinnedComment: () => isPinnedComment,
-    isPlainJsFile: () => isPlainJsFile,
-    isPlusToken: () => isPlusToken,
-    isPossiblyTypeArgumentPosition: () => isPossiblyTypeArgumentPosition,
-    isPostfixUnaryExpression: () => isPostfixUnaryExpression,
-    isPrefixUnaryExpression: () => isPrefixUnaryExpression,
-    isPrivateIdentifier: () => isPrivateIdentifier,
-    isPrivateIdentifierClassElementDeclaration: () => isPrivateIdentifierClassElementDeclaration,
-    isPrivateIdentifierPropertyAccessExpression: () => isPrivateIdentifierPropertyAccessExpression,
-    isPrivateIdentifierSymbol: () => isPrivateIdentifierSymbol,
-    isProgramBundleEmitBuildInfo: () => isProgramBundleEmitBuildInfo,
-    isProgramUptoDate: () => isProgramUptoDate,
-    isPrologueDirective: () => isPrologueDirective,
-    isPropertyAccessChain: () => isPropertyAccessChain,
-    isPropertyAccessEntityNameExpression: () => isPropertyAccessEntityNameExpression,
-    isPropertyAccessExpression: () => isPropertyAccessExpression,
-    isPropertyAccessOrQualifiedName: () => isPropertyAccessOrQualifiedName,
-    isPropertyAccessOrQualifiedNameOrImportTypeNode: () => isPropertyAccessOrQualifiedNameOrImportTypeNode,
-    isPropertyAssignment: () => isPropertyAssignment,
-    isPropertyDeclaration: () => isPropertyDeclaration,
-    isPropertyName: () => isPropertyName,
-    isPropertyNameLiteral: () => isPropertyNameLiteral,
-    isPropertySignature: () => isPropertySignature,
-    isProtoSetter: () => isProtoSetter,
-    isPrototypeAccess: () => isPrototypeAccess,
-    isPrototypePropertyAssignment: () => isPrototypePropertyAssignment,
-    isPunctuation: () => isPunctuation,
-    isPushOrUnshiftIdentifier: () => isPushOrUnshiftIdentifier,
-    isQualifiedName: () => isQualifiedName,
-    isQuestionDotToken: () => isQuestionDotToken,
-    isQuestionOrExclamationToken: () => isQuestionOrExclamationToken,
-    isQuestionOrPlusOrMinusToken: () => isQuestionOrPlusOrMinusToken,
-    isQuestionToken: () => isQuestionToken,
-    isRawSourceMap: () => isRawSourceMap,
-    isReadonlyKeyword: () => isReadonlyKeyword,
-    isReadonlyKeywordOrPlusOrMinusToken: () => isReadonlyKeywordOrPlusOrMinusToken,
-    isRecognizedTripleSlashComment: () => isRecognizedTripleSlashComment,
-    isReferenceFileLocation: () => isReferenceFileLocation,
-    isReferencedFile: () => isReferencedFile,
-    isRegularExpressionLiteral: () => isRegularExpressionLiteral,
-    isRequireCall: () => isRequireCall,
-    isRequireVariableStatement: () => isRequireVariableStatement,
-    isRestParameter: () => isRestParameter,
-    isRestTypeNode: () => isRestTypeNode,
-    isReturnStatement: () => isReturnStatement,
-    isReturnStatementWithFixablePromiseHandler: () => isReturnStatementWithFixablePromiseHandler,
-    isRightSideOfAccessExpression: () => isRightSideOfAccessExpression,
-    isRightSideOfPropertyAccess: () => isRightSideOfPropertyAccess,
-    isRightSideOfQualifiedName: () => isRightSideOfQualifiedName,
-    isRightSideOfQualifiedNameOrPropertyAccess: () => isRightSideOfQualifiedNameOrPropertyAccess,
-    isRightSideOfQualifiedNameOrPropertyAccessOrJSDocMemberName: () => isRightSideOfQualifiedNameOrPropertyAccessOrJSDocMemberName,
-    isRootedDiskPath: () => isRootedDiskPath,
-    isSameEntityName: () => isSameEntityName,
-    isSatisfiesExpression: () => isSatisfiesExpression,
-    isScopeMarker: () => isScopeMarker,
-    isSemicolonClassElement: () => isSemicolonClassElement,
-    isSetAccessor: () => isSetAccessor,
-    isSetAccessorDeclaration: () => isSetAccessorDeclaration,
-    isShebangTrivia: () => isShebangTrivia,
-    isShorthandAmbientModuleSymbol: () => isShorthandAmbientModuleSymbol,
-    isShorthandPropertyAssignment: () => isShorthandPropertyAssignment,
-    isSignedNumericLiteral: () => isSignedNumericLiteral,
-    isSimpleCopiableExpression: () => isSimpleCopiableExpression,
-    isSimpleInlineableExpression: () => isSimpleInlineableExpression,
-    isSingleOrDoubleQuote: () => isSingleOrDoubleQuote,
-    isSourceFile: () => isSourceFile,
-    isSourceFileFromLibrary: () => isSourceFileFromLibrary,
-    isSourceFileJS: () => isSourceFileJS,
-    isSourceFileNotJS: () => isSourceFileNotJS,
-    isSourceFileNotJson: () => isSourceFileNotJson,
-    isSourceMapping: () => isSourceMapping,
-    isSpecialPropertyDeclaration: () => isSpecialPropertyDeclaration,
-    isSpreadAssignment: () => isSpreadAssignment,
-    isSpreadElement: () => isSpreadElement,
-    isStatement: () => isStatement,
-    isStatementButNotDeclaration: () => isStatementButNotDeclaration,
-    isStatementOrBlock: () => isStatementOrBlock,
-    isStatementWithLocals: () => isStatementWithLocals,
-    isStatic: () => isStatic,
-    isStaticModifier: () => isStaticModifier,
-    isString: () => isString,
-    isStringAKeyword: () => isStringAKeyword,
-    isStringANonContextualKeyword: () => isStringANonContextualKeyword,
-    isStringAndEmptyAnonymousObjectIntersection: () => isStringAndEmptyAnonymousObjectIntersection,
-    isStringDoubleQuoted: () => isStringDoubleQuoted,
-    isStringLiteral: () => isStringLiteral,
-    isStringLiteralLike: () => isStringLiteralLike,
-    isStringLiteralOrJsxExpression: () => isStringLiteralOrJsxExpression,
-    isStringLiteralOrTemplate: () => isStringLiteralOrTemplate,
-    isStringOrNumericLiteralLike: () => isStringOrNumericLiteralLike,
-    isStringOrRegularExpressionOrTemplateLiteral: () => isStringOrRegularExpressionOrTemplateLiteral,
-    isStringTextContainingNode: () => isStringTextContainingNode,
-    isSuperCall: () => isSuperCall,
-    isSuperKeyword: () => isSuperKeyword,
-    isSuperOrSuperProperty: () => isSuperOrSuperProperty,
-    isSuperProperty: () => isSuperProperty,
-    isSupportedSourceFileName: () => isSupportedSourceFileName,
-    isSwitchStatement: () => isSwitchStatement,
-    isSyntaxList: () => isSyntaxList,
-    isSyntheticExpression: () => isSyntheticExpression,
-    isSyntheticReference: () => isSyntheticReference,
-    isTagName: () => isTagName,
-    isTaggedTemplateExpression: () => isTaggedTemplateExpression,
-    isTaggedTemplateTag: () => isTaggedTemplateTag,
-    isTemplateExpression: () => isTemplateExpression,
-    isTemplateHead: () => isTemplateHead,
-    isTemplateLiteral: () => isTemplateLiteral,
-    isTemplateLiteralKind: () => isTemplateLiteralKind,
-    isTemplateLiteralToken: () => isTemplateLiteralToken,
-    isTemplateLiteralTypeNode: () => isTemplateLiteralTypeNode,
-    isTemplateLiteralTypeSpan: () => isTemplateLiteralTypeSpan,
-    isTemplateMiddle: () => isTemplateMiddle,
-    isTemplateMiddleOrTemplateTail: () => isTemplateMiddleOrTemplateTail,
-    isTemplateSpan: () => isTemplateSpan,
-    isTemplateTail: () => isTemplateTail,
-    isTextWhiteSpaceLike: () => isTextWhiteSpaceLike,
-    isThis: () => isThis,
-    isThisContainerOrFunctionBlock: () => isThisContainerOrFunctionBlock,
-    isThisIdentifier: () => isThisIdentifier,
-    isThisInTypeQuery: () => isThisInTypeQuery,
-    isThisInitializedDeclaration: () => isThisInitializedDeclaration,
-    isThisInitializedObjectBindingExpression: () => isThisInitializedObjectBindingExpression,
-    isThisProperty: () => isThisProperty,
-    isThisTypeNode: () => isThisTypeNode,
-    isThisTypeParameter: () => isThisTypeParameter,
-    isThisTypePredicate: () => isThisTypePredicate,
-    isThrowStatement: () => isThrowStatement,
-    isToken: () => isToken,
-    isTokenKind: () => isTokenKind,
-    isTraceEnabled: () => isTraceEnabled,
-    isTransientSymbol: () => isTransientSymbol,
-    isTrivia: () => isTrivia,
-    isTryStatement: () => isTryStatement,
-    isTupleTypeNode: () => isTupleTypeNode,
-    isTypeAlias: () => isTypeAlias,
-    isTypeAliasDeclaration: () => isTypeAliasDeclaration,
-    isTypeAssertionExpression: () => isTypeAssertionExpression,
-    isTypeDeclaration: () => isTypeDeclaration,
-    isTypeElement: () => isTypeElement,
-    isTypeKeyword: () => isTypeKeyword,
-    isTypeKeywordToken: () => isTypeKeywordToken,
-    isTypeKeywordTokenOrIdentifier: () => isTypeKeywordTokenOrIdentifier,
-    isTypeLiteralNode: () => isTypeLiteralNode,
-    isTypeNode: () => isTypeNode,
-    isTypeNodeKind: () => isTypeNodeKind,
-    isTypeOfExpression: () => isTypeOfExpression,
-    isTypeOnlyExportDeclaration: () => isTypeOnlyExportDeclaration,
-    isTypeOnlyImportDeclaration: () => isTypeOnlyImportDeclaration,
-    isTypeOnlyImportOrExportDeclaration: () => isTypeOnlyImportOrExportDeclaration,
-    isTypeOperatorNode: () => isTypeOperatorNode,
-    isTypeParameterDeclaration: () => isTypeParameterDeclaration,
-    isTypePredicateNode: () => isTypePredicateNode,
-    isTypeQueryNode: () => isTypeQueryNode,
-    isTypeReferenceNode: () => isTypeReferenceNode,
-    isTypeReferenceType: () => isTypeReferenceType,
-    isUMDExportSymbol: () => isUMDExportSymbol,
-    isUnaryExpression: () => isUnaryExpression,
-    isUnaryExpressionWithWrite: () => isUnaryExpressionWithWrite,
-    isUnicodeIdentifierStart: () => isUnicodeIdentifierStart,
-    isUnionTypeNode: () => isUnionTypeNode,
-    isUnparsedNode: () => isUnparsedNode,
-    isUnparsedPrepend: () => isUnparsedPrepend,
-    isUnparsedSource: () => isUnparsedSource,
-    isUnparsedTextLike: () => isUnparsedTextLike,
-    isUrl: () => isUrl,
-    isValidBigIntString: () => isValidBigIntString,
-    isValidESSymbolDeclaration: () => isValidESSymbolDeclaration,
-    isValidTypeOnlyAliasUseSite: () => isValidTypeOnlyAliasUseSite,
-    isValueSignatureDeclaration: () => isValueSignatureDeclaration,
-    isVarConst: () => isVarConst,
-    isVariableDeclaration: () => isVariableDeclaration,
-    isVariableDeclarationInVariableStatement: () => isVariableDeclarationInVariableStatement,
-    isVariableDeclarationInitializedToBareOrAccessedRequire: () => isVariableDeclarationInitializedToBareOrAccessedRequire,
-    isVariableDeclarationInitializedToRequire: () => isVariableDeclarationInitializedToRequire,
-    isVariableDeclarationList: () => isVariableDeclarationList,
-    isVariableLike: () => isVariableLike,
-    isVariableLikeOrAccessor: () => isVariableLikeOrAccessor,
-    isVariableStatement: () => isVariableStatement,
-    isVoidExpression: () => isVoidExpression,
-    isWatchSet: () => isWatchSet,
-    isWhileStatement: () => isWhileStatement,
-    isWhiteSpaceLike: () => isWhiteSpaceLike,
-    isWhiteSpaceSingleLine: () => isWhiteSpaceSingleLine,
-    isWithStatement: () => isWithStatement,
-    isWriteAccess: () => isWriteAccess,
-    isWriteOnlyAccess: () => isWriteOnlyAccess,
-    isYieldExpression: () => isYieldExpression,
-    jsxModeNeedsExplicitImport: () => jsxModeNeedsExplicitImport,
-    keywordPart: () => keywordPart,
-    last: () => last,
-    lastOrUndefined: () => lastOrUndefined,
-    length: () => length,
-    libMap: () => libMap,
-    libs: () => libs,
-    lineBreakPart: () => lineBreakPart,
-    linkNamePart: () => linkNamePart,
-    linkPart: () => linkPart,
-    linkTextPart: () => linkTextPart,
-    listFiles: () => listFiles,
-    loadModuleFromGlobalCache: () => loadModuleFromGlobalCache,
-    loadWithModeAwareCache: () => loadWithModeAwareCache,
-    makeIdentifierFromModuleName: () => makeIdentifierFromModuleName,
-    makeImport: () => makeImport,
-    makeImportIfNecessary: () => makeImportIfNecessary,
-    makeStringLiteral: () => makeStringLiteral,
-    mangleScopedPackageName: () => mangleScopedPackageName,
-    map: () => map,
-    mapAllOrFail: () => mapAllOrFail,
-    mapDefined: () => mapDefined,
-    mapDefinedEntries: () => mapDefinedEntries,
-    mapDefinedIterator: () => mapDefinedIterator,
-    mapEntries: () => mapEntries,
-    mapIterator: () => mapIterator,
-    mapOneOrMany: () => mapOneOrMany,
-    mapToDisplayParts: () => mapToDisplayParts,
-    matchFiles: () => matchFiles,
-    matchPatternOrExact: () => matchPatternOrExact,
-    matchedText: () => matchedText,
-    matchesExclude: () => matchesExclude,
-    maybeBind: () => maybeBind,
-    maybeSetLocalizedDiagnosticMessages: () => maybeSetLocalizedDiagnosticMessages,
-    memoize: () => memoize,
-    memoizeCached: () => memoizeCached,
-    memoizeOne: () => memoizeOne,
-    memoizeWeak: () => memoizeWeak,
-    metadataHelper: () => metadataHelper,
-    min: () => min,
-    minAndMax: () => minAndMax,
-    missingFileModifiedTime: () => missingFileModifiedTime,
-    modifierToFlag: () => modifierToFlag,
-    modifiersToFlags: () => modifiersToFlags,
-    moduleOptionDeclaration: () => moduleOptionDeclaration,
-    moduleResolutionIsEqualTo: () => moduleResolutionIsEqualTo,
-    moduleResolutionNameAndModeGetter: () => moduleResolutionNameAndModeGetter,
-    moduleResolutionOptionDeclarations: () => moduleResolutionOptionDeclarations,
-    moduleResolutionSupportsPackageJsonExportsAndImports: () => moduleResolutionSupportsPackageJsonExportsAndImports,
-    moduleResolutionUsesNodeModules: () => moduleResolutionUsesNodeModules,
-    moduleSpecifiers: () => ts_moduleSpecifiers_exports,
-    moveEmitHelpers: () => moveEmitHelpers,
-    moveRangeEnd: () => moveRangeEnd,
-    moveRangePastDecorators: () => moveRangePastDecorators,
-    moveRangePastModifiers: () => moveRangePastModifiers,
-    moveRangePos: () => moveRangePos,
-    moveSyntheticComments: () => moveSyntheticComments,
-    mutateMap: () => mutateMap,
-    mutateMapSkippingNewValues: () => mutateMapSkippingNewValues,
-    needsParentheses: () => needsParentheses,
-    needsScopeMarker: () => needsScopeMarker,
-    newCaseClauseTracker: () => newCaseClauseTracker,
-    newPrivateEnvironment: () => newPrivateEnvironment,
-    noEmitNotification: () => noEmitNotification,
-    noEmitSubstitution: () => noEmitSubstitution,
-    noTransformers: () => noTransformers,
-    noTruncationMaximumTruncationLength: () => noTruncationMaximumTruncationLength,
-    nodeCanBeDecorated: () => nodeCanBeDecorated,
-    nodeHasName: () => nodeHasName,
-    nodeIsDecorated: () => nodeIsDecorated,
-    nodeIsMissing: () => nodeIsMissing,
-    nodeIsPresent: () => nodeIsPresent,
-    nodeIsSynthesized: () => nodeIsSynthesized,
-    nodeModuleNameResolver: () => nodeModuleNameResolver,
-    nodeModulesPathPart: () => nodeModulesPathPart,
-    nodeNextJsonConfigResolver: () => nodeNextJsonConfigResolver,
-    nodeOrChildIsDecorated: () => nodeOrChildIsDecorated,
-    nodeOverlapsWithStartEnd: () => nodeOverlapsWithStartEnd,
-    nodePosToString: () => nodePosToString,
-    nodeSeenTracker: () => nodeSeenTracker,
-    nodeStartsNewLexicalEnvironment: () => nodeStartsNewLexicalEnvironment,
-    nodeToDisplayParts: () => nodeToDisplayParts,
-    noop: () => noop,
-    noopFileWatcher: () => noopFileWatcher,
-    normalizePath: () => normalizePath,
-    normalizeSlashes: () => normalizeSlashes,
-    not: () => not,
-    notImplemented: () => notImplemented,
-    notImplementedResolver: () => notImplementedResolver,
-    nullNodeConverters: () => nullNodeConverters,
-    nullParenthesizerRules: () => nullParenthesizerRules,
-    nullTransformationContext: () => nullTransformationContext,
-    objectAllocator: () => objectAllocator,
-    operatorPart: () => operatorPart,
-    optionDeclarations: () => optionDeclarations,
-    optionMapToObject: () => optionMapToObject,
-    optionsAffectingProgramStructure: () => optionsAffectingProgramStructure,
-    optionsForBuild: () => optionsForBuild,
-    optionsForWatch: () => optionsForWatch,
-    optionsHaveChanges: () => optionsHaveChanges,
-    optionsHaveModuleResolutionChanges: () => optionsHaveModuleResolutionChanges,
-    or: () => or,
-    orderedRemoveItem: () => orderedRemoveItem,
-    orderedRemoveItemAt: () => orderedRemoveItemAt,
-    outFile: () => outFile,
-    packageIdToPackageName: () => packageIdToPackageName,
-    packageIdToString: () => packageIdToString,
-    padLeft: () => padLeft,
-    padRight: () => padRight,
-    paramHelper: () => paramHelper,
-    parameterIsThisKeyword: () => parameterIsThisKeyword,
-    parameterNamePart: () => parameterNamePart,
-    parseBaseNodeFactory: () => parseBaseNodeFactory,
-    parseBigInt: () => parseBigInt,
-    parseBuildCommand: () => parseBuildCommand,
-    parseCommandLine: () => parseCommandLine,
-    parseCommandLineWorker: () => parseCommandLineWorker,
-    parseConfigFileTextToJson: () => parseConfigFileTextToJson,
-    parseConfigFileWithSystem: () => parseConfigFileWithSystem,
-    parseConfigHostFromCompilerHostLike: () => parseConfigHostFromCompilerHostLike,
-    parseCustomTypeOption: () => parseCustomTypeOption,
-    parseIsolatedEntityName: () => parseIsolatedEntityName,
-    parseIsolatedJSDocComment: () => parseIsolatedJSDocComment,
-    parseJSDocTypeExpressionForTests: () => parseJSDocTypeExpressionForTests,
-    parseJsonConfigFileContent: () => parseJsonConfigFileContent,
-    parseJsonSourceFileConfigFileContent: () => parseJsonSourceFileConfigFileContent,
-    parseJsonText: () => parseJsonText,
-    parseListTypeOption: () => parseListTypeOption,
-    parseNodeFactory: () => parseNodeFactory,
-    parseNodeModuleFromPath: () => parseNodeModuleFromPath,
-    parsePackageName: () => parsePackageName,
-    parsePseudoBigInt: () => parsePseudoBigInt,
-    parseValidBigInt: () => parseValidBigInt,
-    patchWriteFileEnsuringDirectory: () => patchWriteFileEnsuringDirectory,
-    pathContainsNodeModules: () => pathContainsNodeModules,
-    pathIsAbsolute: () => pathIsAbsolute,
-    pathIsBareSpecifier: () => pathIsBareSpecifier,
-    pathIsRelative: () => pathIsRelative,
-    patternText: () => patternText,
-    perfLogger: () => perfLogger,
-    performIncrementalCompilation: () => performIncrementalCompilation,
-    performance: () => ts_performance_exports,
-    plainJSErrors: () => plainJSErrors,
-    positionBelongsToNode: () => positionBelongsToNode,
-    positionIsASICandidate: () => positionIsASICandidate,
-    positionIsSynthesized: () => positionIsSynthesized,
-    positionsAreOnSameLine: () => positionsAreOnSameLine,
-    preProcessFile: () => preProcessFile,
-    probablyUsesSemicolons: () => probablyUsesSemicolons,
-    processCommentPragmas: () => processCommentPragmas,
-    processPragmasIntoFields: () => processPragmasIntoFields,
-    processTaggedTemplateExpression: () => processTaggedTemplateExpression,
-    programContainsEsModules: () => programContainsEsModules,
-    programContainsModules: () => programContainsModules,
-    projectReferenceIsEqualTo: () => projectReferenceIsEqualTo,
-    propKeyHelper: () => propKeyHelper,
-    propertyNamePart: () => propertyNamePart,
-    pseudoBigIntToString: () => pseudoBigIntToString,
-    punctuationPart: () => punctuationPart,
-    pushIfUnique: () => pushIfUnique,
-    quote: () => quote,
-    quotePreferenceFromString: () => quotePreferenceFromString,
-    rangeContainsPosition: () => rangeContainsPosition,
-    rangeContainsPositionExclusive: () => rangeContainsPositionExclusive,
-    rangeContainsRange: () => rangeContainsRange,
-    rangeContainsRangeExclusive: () => rangeContainsRangeExclusive,
-    rangeContainsStartEnd: () => rangeContainsStartEnd,
-    rangeEndIsOnSameLineAsRangeStart: () => rangeEndIsOnSameLineAsRangeStart,
-    rangeEndPositionsAreOnSameLine: () => rangeEndPositionsAreOnSameLine,
-    rangeEquals: () => rangeEquals,
-    rangeIsOnSingleLine: () => rangeIsOnSingleLine,
-    rangeOfNode: () => rangeOfNode,
-    rangeOfTypeParameters: () => rangeOfTypeParameters,
-    rangeOverlapsWithStartEnd: () => rangeOverlapsWithStartEnd,
-    rangeStartIsOnSameLineAsRangeEnd: () => rangeStartIsOnSameLineAsRangeEnd,
-    rangeStartPositionsAreOnSameLine: () => rangeStartPositionsAreOnSameLine,
-    readBuilderProgram: () => readBuilderProgram,
-    readConfigFile: () => readConfigFile,
-    readHelper: () => readHelper,
-    readJson: () => readJson,
-    readJsonConfigFile: () => readJsonConfigFile,
-    readJsonOrUndefined: () => readJsonOrUndefined,
-    realizeDiagnostics: () => realizeDiagnostics,
-    reduceEachLeadingCommentRange: () => reduceEachLeadingCommentRange,
-    reduceEachTrailingCommentRange: () => reduceEachTrailingCommentRange,
-    reduceLeft: () => reduceLeft,
-    reduceLeftIterator: () => reduceLeftIterator,
-    reducePathComponents: () => reducePathComponents,
-    refactor: () => ts_refactor_exports,
-    regExpEscape: () => regExpEscape,
-    relativeComplement: () => relativeComplement,
-    removeAllComments: () => removeAllComments,
-    removeEmitHelper: () => removeEmitHelper,
-    removeExtension: () => removeExtension,
-    removeFileExtension: () => removeFileExtension,
-    removeIgnoredPath: () => removeIgnoredPath,
-    removeMinAndVersionNumbers: () => removeMinAndVersionNumbers,
-    removeOptionality: () => removeOptionality,
-    removePrefix: () => removePrefix,
-    removeSuffix: () => removeSuffix,
-    removeTrailingDirectorySeparator: () => removeTrailingDirectorySeparator,
-    repeatString: () => repeatString,
-    replaceElement: () => replaceElement,
-    resolutionExtensionIsTSOrJson: () => resolutionExtensionIsTSOrJson,
-    resolveConfigFileProjectName: () => resolveConfigFileProjectName,
-    resolveJSModule: () => resolveJSModule,
-    resolveLibrary: () => resolveLibrary,
-    resolveModuleName: () => resolveModuleName,
-    resolveModuleNameFromCache: () => resolveModuleNameFromCache,
-    resolvePackageNameToPackageJson: () => resolvePackageNameToPackageJson,
-    resolvePath: () => resolvePath,
-    resolveProjectReferencePath: () => resolveProjectReferencePath,
-    resolveTripleslashReference: () => resolveTripleslashReference,
-    resolveTypeReferenceDirective: () => resolveTypeReferenceDirective,
-    resolvingEmptyArray: () => resolvingEmptyArray,
-    restHelper: () => restHelper,
-    returnFalse: () => returnFalse,
-    returnNoopFileWatcher: () => returnNoopFileWatcher,
-    returnTrue: () => returnTrue,
-    returnUndefined: () => returnUndefined,
-    returnsPromise: () => returnsPromise,
-    runInitializersHelper: () => runInitializersHelper,
-    sameFlatMap: () => sameFlatMap,
-    sameMap: () => sameMap,
-    sameMapping: () => sameMapping,
-    scanShebangTrivia: () => scanShebangTrivia,
-    scanTokenAtPosition: () => scanTokenAtPosition,
-    scanner: () => scanner,
-    screenStartingMessageCodes: () => screenStartingMessageCodes,
-    semanticDiagnosticsOptionDeclarations: () => semanticDiagnosticsOptionDeclarations,
-    serializeCompilerOptions: () => serializeCompilerOptions,
-    server: () => ts_server_exports,
-    servicesVersion: () => servicesVersion,
-    setCommentRange: () => setCommentRange,
-    setConfigFileInOptions: () => setConfigFileInOptions,
-    setConstantValue: () => setConstantValue,
-    setEachParent: () => setEachParent,
-    setEmitFlags: () => setEmitFlags,
-    setFunctionNameHelper: () => setFunctionNameHelper,
-    setGetSourceFileAsHashVersioned: () => setGetSourceFileAsHashVersioned,
-    setIdentifierAutoGenerate: () => setIdentifierAutoGenerate,
-    setIdentifierGeneratedImportReference: () => setIdentifierGeneratedImportReference,
-    setIdentifierTypeArguments: () => setIdentifierTypeArguments,
-    setInternalEmitFlags: () => setInternalEmitFlags,
-    setLocalizedDiagnosticMessages: () => setLocalizedDiagnosticMessages,
-    setModuleDefaultHelper: () => setModuleDefaultHelper,
-    setNodeFlags: () => setNodeFlags,
-    setObjectAllocator: () => setObjectAllocator,
-    setOriginalNode: () => setOriginalNode,
-    setParent: () => setParent,
-    setParentRecursive: () => setParentRecursive,
-    setPrivateIdentifier: () => setPrivateIdentifier,
-    setResolvedModule: () => setResolvedModule,
-    setResolvedTypeReferenceDirective: () => setResolvedTypeReferenceDirective,
-    setSnippetElement: () => setSnippetElement,
-    setSourceMapRange: () => setSourceMapRange,
-    setStackTraceLimit: () => setStackTraceLimit,
-    setStartsOnNewLine: () => setStartsOnNewLine,
-    setSyntheticLeadingComments: () => setSyntheticLeadingComments,
-    setSyntheticTrailingComments: () => setSyntheticTrailingComments,
-    setSys: () => setSys,
-    setSysLog: () => setSysLog,
-    setTextRange: () => setTextRange,
-    setTextRangeEnd: () => setTextRangeEnd,
-    setTextRangePos: () => setTextRangePos,
-    setTextRangePosEnd: () => setTextRangePosEnd,
-    setTextRangePosWidth: () => setTextRangePosWidth,
-    setTokenSourceMapRange: () => setTokenSourceMapRange,
-    setTypeNode: () => setTypeNode,
-    setUILocale: () => setUILocale,
-    setValueDeclaration: () => setValueDeclaration,
-    shouldAllowImportingTsExtension: () => shouldAllowImportingTsExtension,
-    shouldPreserveConstEnums: () => shouldPreserveConstEnums,
-    shouldResolveJsRequire: () => shouldResolveJsRequire,
-    shouldUseUriStyleNodeCoreModules: () => shouldUseUriStyleNodeCoreModules,
-    showModuleSpecifier: () => showModuleSpecifier,
-    signatureHasLiteralTypes: () => signatureHasLiteralTypes,
-    signatureHasRestParameter: () => signatureHasRestParameter,
-    signatureToDisplayParts: () => signatureToDisplayParts,
-    single: () => single,
-    singleElementArray: () => singleElementArray,
-    singleIterator: () => singleIterator,
-    singleOrMany: () => singleOrMany,
-    singleOrUndefined: () => singleOrUndefined,
-    skipAlias: () => skipAlias,
-    skipAssertions: () => skipAssertions,
-    skipConstraint: () => skipConstraint,
-    skipOuterExpressions: () => skipOuterExpressions,
-    skipParentheses: () => skipParentheses,
-    skipPartiallyEmittedExpressions: () => skipPartiallyEmittedExpressions,
-    skipTrivia: () => skipTrivia,
-    skipTypeChecking: () => skipTypeChecking,
-    skipTypeParentheses: () => skipTypeParentheses,
-    skipWhile: () => skipWhile,
-    sliceAfter: () => sliceAfter,
-    some: () => some,
-    sort: () => sort,
-    sortAndDeduplicate: () => sortAndDeduplicate,
-    sortAndDeduplicateDiagnostics: () => sortAndDeduplicateDiagnostics,
-    sourceFileAffectingCompilerOptions: () => sourceFileAffectingCompilerOptions,
-    sourceFileMayBeEmitted: () => sourceFileMayBeEmitted,
-    sourceMapCommentRegExp: () => sourceMapCommentRegExp,
-    sourceMapCommentRegExpDontCareLineStart: () => sourceMapCommentRegExpDontCareLineStart,
-    spacePart: () => spacePart,
-    spanMap: () => spanMap,
-    spreadArrayHelper: () => spreadArrayHelper,
-    stableSort: () => stableSort,
-    startEndContainsRange: () => startEndContainsRange,
-    startEndOverlapsWithStartEnd: () => startEndOverlapsWithStartEnd,
-    startOnNewLine: () => startOnNewLine,
-    startTracing: () => startTracing,
-    startsWith: () => startsWith,
-    startsWithDirectory: () => startsWithDirectory,
-    startsWithUnderscore: () => startsWithUnderscore,
-    startsWithUseStrict: () => startsWithUseStrict,
-    stringContains: () => stringContains,
-    stringContainsAt: () => stringContainsAt,
-    stringToToken: () => stringToToken,
-    stripQuotes: () => stripQuotes,
-    supportedDeclarationExtensions: () => supportedDeclarationExtensions,
-    supportedJSExtensions: () => supportedJSExtensions,
-    supportedJSExtensionsFlat: () => supportedJSExtensionsFlat,
-    supportedLocaleDirectories: () => supportedLocaleDirectories,
-    supportedTSExtensions: () => supportedTSExtensions,
-    supportedTSExtensionsFlat: () => supportedTSExtensionsFlat,
-    supportedTSImplementationExtensions: () => supportedTSImplementationExtensions,
-    suppressLeadingAndTrailingTrivia: () => suppressLeadingAndTrailingTrivia,
-    suppressLeadingTrivia: () => suppressLeadingTrivia,
-    suppressTrailingTrivia: () => suppressTrailingTrivia,
-    symbolEscapedNameNoDefault: () => symbolEscapedNameNoDefault,
-    symbolName: () => symbolName,
-    symbolNameNoDefault: () => symbolNameNoDefault,
-    symbolPart: () => symbolPart,
-    symbolToDisplayParts: () => symbolToDisplayParts,
-    syntaxMayBeASICandidate: () => syntaxMayBeASICandidate,
-    syntaxRequiresTrailingSemicolonOrASI: () => syntaxRequiresTrailingSemicolonOrASI,
-    sys: () => sys,
-    sysLog: () => sysLog,
-    tagNamesAreEquivalent: () => tagNamesAreEquivalent,
-    takeWhile: () => takeWhile,
-    targetOptionDeclaration: () => targetOptionDeclaration,
-    templateObjectHelper: () => templateObjectHelper,
-    testFormatSettings: () => testFormatSettings,
-    textChangeRangeIsUnchanged: () => textChangeRangeIsUnchanged,
-    textChangeRangeNewSpan: () => textChangeRangeNewSpan,
-    textChanges: () => ts_textChanges_exports,
-    textOrKeywordPart: () => textOrKeywordPart,
-    textPart: () => textPart,
-    textRangeContainsPositionInclusive: () => textRangeContainsPositionInclusive,
-    textSpanContainsPosition: () => textSpanContainsPosition,
-    textSpanContainsTextSpan: () => textSpanContainsTextSpan,
-    textSpanEnd: () => textSpanEnd,
-    textSpanIntersection: () => textSpanIntersection,
-    textSpanIntersectsWith: () => textSpanIntersectsWith,
-    textSpanIntersectsWithPosition: () => textSpanIntersectsWithPosition,
-    textSpanIntersectsWithTextSpan: () => textSpanIntersectsWithTextSpan,
-    textSpanIsEmpty: () => textSpanIsEmpty,
-    textSpanOverlap: () => textSpanOverlap,
-    textSpanOverlapsWith: () => textSpanOverlapsWith,
-    textSpansEqual: () => textSpansEqual,
-    textToKeywordObj: () => textToKeywordObj,
-    timestamp: () => timestamp,
-    toArray: () => toArray,
-    toBuilderFileEmit: () => toBuilderFileEmit,
-    toBuilderStateFileInfoForMultiEmit: () => toBuilderStateFileInfoForMultiEmit,
-    toEditorSettings: () => toEditorSettings,
-    toFileNameLowerCase: () => toFileNameLowerCase,
-    toLowerCase: () => toLowerCase,
-    toPath: () => toPath,
-    toProgramEmitPending: () => toProgramEmitPending,
-    tokenIsIdentifierOrKeyword: () => tokenIsIdentifierOrKeyword,
-    tokenIsIdentifierOrKeywordOrGreaterThan: () => tokenIsIdentifierOrKeywordOrGreaterThan,
-    tokenToString: () => tokenToString,
-    trace: () => trace,
-    tracing: () => tracing,
-    tracingEnabled: () => tracingEnabled,
-    transform: () => transform,
-    transformClassFields: () => transformClassFields,
-    transformDeclarations: () => transformDeclarations,
-    transformECMAScriptModule: () => transformECMAScriptModule,
-    transformES2015: () => transformES2015,
-    transformES2016: () => transformES2016,
-    transformES2017: () => transformES2017,
-    transformES2018: () => transformES2018,
-    transformES2019: () => transformES2019,
-    transformES2020: () => transformES2020,
-    transformES2021: () => transformES2021,
-    transformES5: () => transformES5,
-    transformESDecorators: () => transformESDecorators,
-    transformESNext: () => transformESNext,
-    transformGenerators: () => transformGenerators,
-    transformJsx: () => transformJsx,
-    transformLegacyDecorators: () => transformLegacyDecorators,
-    transformModule: () => transformModule,
-    transformNodeModule: () => transformNodeModule,
-    transformNodes: () => transformNodes,
-    transformSystemModule: () => transformSystemModule,
-    transformTypeScript: () => transformTypeScript,
-    transpile: () => transpile,
-    transpileModule: () => transpileModule,
-    transpileOptionValueCompilerOptions: () => transpileOptionValueCompilerOptions,
-    trimString: () => trimString,
-    trimStringEnd: () => trimStringEnd,
-    trimStringStart: () => trimStringStart,
-    tryAddToSet: () => tryAddToSet,
-    tryAndIgnoreErrors: () => tryAndIgnoreErrors,
-    tryCast: () => tryCast,
-    tryDirectoryExists: () => tryDirectoryExists,
-    tryExtractTSExtension: () => tryExtractTSExtension,
-    tryFileExists: () => tryFileExists,
-    tryGetClassExtendingExpressionWithTypeArguments: () => tryGetClassExtendingExpressionWithTypeArguments,
-    tryGetClassImplementingOrExtendingExpressionWithTypeArguments: () => tryGetClassImplementingOrExtendingExpressionWithTypeArguments,
-    tryGetDirectories: () => tryGetDirectories,
-    tryGetExtensionFromPath: () => tryGetExtensionFromPath2,
-    tryGetImportFromModuleSpecifier: () => tryGetImportFromModuleSpecifier,
-    tryGetJSDocSatisfiesTypeNode: () => tryGetJSDocSatisfiesTypeNode,
-    tryGetModuleNameFromFile: () => tryGetModuleNameFromFile,
-    tryGetModuleSpecifierFromDeclaration: () => tryGetModuleSpecifierFromDeclaration,
-    tryGetNativePerformanceHooks: () => tryGetNativePerformanceHooks,
-    tryGetPropertyAccessOrIdentifierToString: () => tryGetPropertyAccessOrIdentifierToString,
-    tryGetPropertyNameOfBindingOrAssignmentElement: () => tryGetPropertyNameOfBindingOrAssignmentElement,
-    tryGetSourceMappingURL: () => tryGetSourceMappingURL,
-    tryGetTextOfPropertyName: () => tryGetTextOfPropertyName,
-    tryIOAndConsumeErrors: () => tryIOAndConsumeErrors,
-    tryParsePattern: () => tryParsePattern,
-    tryParsePatterns: () => tryParsePatterns,
-    tryParseRawSourceMap: () => tryParseRawSourceMap,
-    tryReadDirectory: () => tryReadDirectory,
-    tryReadFile: () => tryReadFile,
-    tryRemoveDirectoryPrefix: () => tryRemoveDirectoryPrefix,
-    tryRemoveExtension: () => tryRemoveExtension,
-    tryRemovePrefix: () => tryRemovePrefix,
-    tryRemoveSuffix: () => tryRemoveSuffix,
-    typeAcquisitionDeclarations: () => typeAcquisitionDeclarations,
-    typeAliasNamePart: () => typeAliasNamePart,
-    typeDirectiveIsEqualTo: () => typeDirectiveIsEqualTo,
-    typeKeywords: () => typeKeywords,
-    typeParameterNamePart: () => typeParameterNamePart,
-    typeReferenceResolutionNameAndModeGetter: () => typeReferenceResolutionNameAndModeGetter,
-    typeToDisplayParts: () => typeToDisplayParts,
-    unchangedPollThresholds: () => unchangedPollThresholds,
-    unchangedTextChangeRange: () => unchangedTextChangeRange,
-    unescapeLeadingUnderscores: () => unescapeLeadingUnderscores,
-    unmangleScopedPackageName: () => unmangleScopedPackageName,
-    unorderedRemoveItem: () => unorderedRemoveItem,
-    unorderedRemoveItemAt: () => unorderedRemoveItemAt,
-    unreachableCodeIsError: () => unreachableCodeIsError,
-    unusedLabelIsError: () => unusedLabelIsError,
-    unwrapInnermostStatementOfLabel: () => unwrapInnermostStatementOfLabel,
-    updateErrorForNoInputFiles: () => updateErrorForNoInputFiles,
-    updateLanguageServiceSourceFile: () => updateLanguageServiceSourceFile,
-    updateMissingFilePathsWatch: () => updateMissingFilePathsWatch,
-    updatePackageJsonWatch: () => updatePackageJsonWatch,
-    updateResolutionField: () => updateResolutionField,
-    updateSharedExtendedConfigFileWatcher: () => updateSharedExtendedConfigFileWatcher,
-    updateSourceFile: () => updateSourceFile,
-    updateWatchingWildcardDirectories: () => updateWatchingWildcardDirectories,
-    usesExtensionsOnImports: () => usesExtensionsOnImports,
-    usingSingleLineStringWriter: () => usingSingleLineStringWriter,
-    utf16EncodeAsString: () => utf16EncodeAsString,
-    validateLocaleAndSetLanguage: () => validateLocaleAndSetLanguage,
-    valuesHelper: () => valuesHelper,
-    version: () => version,
-    versionMajorMinor: () => versionMajorMinor,
-    visitArray: () => visitArray,
-    visitCommaListElements: () => visitCommaListElements,
-    visitEachChild: () => visitEachChild,
-    visitFunctionBody: () => visitFunctionBody,
-    visitIterationBody: () => visitIterationBody,
-    visitLexicalEnvironment: () => visitLexicalEnvironment,
-    visitNode: () => visitNode,
-    visitNodes: () => visitNodes2,
-    visitParameterList: () => visitParameterList,
-    walkUpBindingElementsAndPatterns: () => walkUpBindingElementsAndPatterns,
-    walkUpLexicalEnvironments: () => walkUpLexicalEnvironments,
-    walkUpOuterExpressions: () => walkUpOuterExpressions,
-    walkUpParenthesizedExpressions: () => walkUpParenthesizedExpressions,
-    walkUpParenthesizedTypes: () => walkUpParenthesizedTypes,
-    walkUpParenthesizedTypesAndGetParentAndChild: () => walkUpParenthesizedTypesAndGetParentAndChild,
-    whitespaceOrMapCommentRegExp: () => whitespaceOrMapCommentRegExp,
-    writeCommentRange: () => writeCommentRange,
-    writeFile: () => writeFile,
-    writeFileEnsuringDirectories: () => writeFileEnsuringDirectories,
-    zipToModeAwareCache: () => zipToModeAwareCache,
-    zipWith: () => zipWith
-  });
-  var init_ts6 = __esm({
-    "src/typescript/_namespaces/ts.ts"() {
-      "use strict";
-      init_ts2();
-      init_ts3();
-      init_ts4();
-      init_ts5();
-    }
-  });
-
-  // src/typescript/typescript.ts
-  var require_typescript = __commonJS({
-    "src/typescript/typescript.ts"(exports, module2) {
-      init_ts6();
-      init_ts6();
-      if (typeof console !== "undefined") {
-        Debug.loggingHost = {
-          log(level, s) {
-            switch (level) {
-              case 1 /* Error */:
-                return console.error(s);
-              case 2 /* Warning */:
-                return console.warn(s);
-              case 3 /* Info */:
-                return console.log(s);
-              case 4 /* Verbose */:
-                return console.log(s);
-            }
-          }
-        };
-      }
-      module2.exports = ts_exports2;
-    }
-  });
-  return require_typescript();
-})();
-
-if (typeof module !== "undefined" && module.exports) { module.exports = ts; }
-//# sourceMappingURL=typescript.js.map
diff --git a/actions/run-many/dist/index.js b/actions/run-many/dist/index.js
index 8d20b47c..bb623fb9 100644
--- a/actions/run-many/dist/index.js
+++ b/actions/run-many/dist/index.js
@@ -1,7 +1,7 @@
 /******/ (() => { // webpackBootstrap
 /******/ 	var __webpack_modules__ = ({
 
-/***/ 7513:
+/***/ 11071:
 /***/ (function(__unused_webpack_module, exports, __nccwpck_require__) {
 
 "use strict";
@@ -28,7 +28,7 @@ var __importStar = (this && this.__importStar) || function (mod) {
 Object.defineProperty(exports, "__esModule", ({ value: true }));
 exports.issue = exports.issueCommand = void 0;
 const os = __importStar(__nccwpck_require__(22037));
-const utils_1 = __nccwpck_require__(77401);
+const utils_1 = __nccwpck_require__(46023);
 /**
  * Commands
  *
@@ -100,7 +100,7 @@ function escapeProperty(s) {
 
 /***/ }),
 
-/***/ 57896:
+/***/ 44712:
 /***/ (function(__unused_webpack_module, exports, __nccwpck_require__) {
 
 "use strict";
@@ -135,12 +135,12 @@ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, ge
 };
 Object.defineProperty(exports, "__esModule", ({ value: true }));
 exports.getIDToken = exports.getState = exports.saveState = exports.group = exports.endGroup = exports.startGroup = exports.info = exports.notice = exports.warning = exports.error = exports.debug = exports.isDebug = exports.setFailed = exports.setCommandEcho = exports.setOutput = exports.getBooleanInput = exports.getMultilineInput = exports.getInput = exports.addPath = exports.setSecret = exports.exportVariable = exports.ExitCode = void 0;
-const command_1 = __nccwpck_require__(7513);
-const file_command_1 = __nccwpck_require__(36802);
-const utils_1 = __nccwpck_require__(77401);
+const command_1 = __nccwpck_require__(11071);
+const file_command_1 = __nccwpck_require__(99034);
+const utils_1 = __nccwpck_require__(46023);
 const os = __importStar(__nccwpck_require__(22037));
 const path = __importStar(__nccwpck_require__(71017));
-const oidc_utils_1 = __nccwpck_require__(64852);
+const oidc_utils_1 = __nccwpck_require__(6963);
 /**
  * The code to exit an action
  */
@@ -425,17 +425,17 @@ exports.getIDToken = getIDToken;
 /**
  * Summary exports
  */
-var summary_1 = __nccwpck_require__(67259);
+var summary_1 = __nccwpck_require__(29140);
 Object.defineProperty(exports, "summary", ({ enumerable: true, get: function () { return summary_1.summary; } }));
 /**
  * @deprecated use core.summary
  */
-var summary_2 = __nccwpck_require__(67259);
+var summary_2 = __nccwpck_require__(29140);
 Object.defineProperty(exports, "markdownSummary", ({ enumerable: true, get: function () { return summary_2.markdownSummary; } }));
 /**
  * Path exports
  */
-var path_utils_1 = __nccwpck_require__(29442);
+var path_utils_1 = __nccwpck_require__(54531);
 Object.defineProperty(exports, "toPosixPath", ({ enumerable: true, get: function () { return path_utils_1.toPosixPath; } }));
 Object.defineProperty(exports, "toWin32Path", ({ enumerable: true, get: function () { return path_utils_1.toWin32Path; } }));
 Object.defineProperty(exports, "toPlatformPath", ({ enumerable: true, get: function () { return path_utils_1.toPlatformPath; } }));
@@ -443,7 +443,7 @@ Object.defineProperty(exports, "toPlatformPath", ({ enumerable: true, get: funct
 
 /***/ }),
 
-/***/ 36802:
+/***/ 99034:
 /***/ (function(__unused_webpack_module, exports, __nccwpck_require__) {
 
 "use strict";
@@ -474,8 +474,8 @@ exports.prepareKeyValueMessage = exports.issueFileCommand = void 0;
 /* eslint-disable @typescript-eslint/no-explicit-any */
 const fs = __importStar(__nccwpck_require__(57147));
 const os = __importStar(__nccwpck_require__(22037));
-const uuid_1 = __nccwpck_require__(10580);
-const utils_1 = __nccwpck_require__(77401);
+const uuid_1 = __nccwpck_require__(37515);
+const utils_1 = __nccwpck_require__(46023);
 function issueFileCommand(command, message) {
     const filePath = process.env[`GITHUB_${command}`];
     if (!filePath) {
@@ -508,7 +508,7 @@ exports.prepareKeyValueMessage = prepareKeyValueMessage;
 
 /***/ }),
 
-/***/ 64852:
+/***/ 6963:
 /***/ (function(__unused_webpack_module, exports, __nccwpck_require__) {
 
 "use strict";
@@ -524,9 +524,9 @@ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, ge
 };
 Object.defineProperty(exports, "__esModule", ({ value: true }));
 exports.OidcClient = void 0;
-const http_client_1 = __nccwpck_require__(57281);
-const auth_1 = __nccwpck_require__(62669);
-const core_1 = __nccwpck_require__(57896);
+const http_client_1 = __nccwpck_require__(18158);
+const auth_1 = __nccwpck_require__(42601);
+const core_1 = __nccwpck_require__(44712);
 class OidcClient {
     static createHttpClient(allowRetry = true, maxRetry = 10) {
         const requestOptions = {
@@ -558,7 +558,7 @@ class OidcClient {
                 .catch(error => {
                 throw new Error(`Failed to get ID Token. \n 
         Error Code : ${error.statusCode}\n 
-        Error Message: ${error.result.message}`);
+        Error Message: ${error.message}`);
             });
             const id_token = (_a = res.result) === null || _a === void 0 ? void 0 : _a.value;
             if (!id_token) {
@@ -592,7 +592,7 @@ exports.OidcClient = OidcClient;
 
 /***/ }),
 
-/***/ 29442:
+/***/ 54531:
 /***/ (function(__unused_webpack_module, exports, __nccwpck_require__) {
 
 "use strict";
@@ -657,7 +657,7 @@ exports.toPlatformPath = toPlatformPath;
 
 /***/ }),
 
-/***/ 67259:
+/***/ 29140:
 /***/ (function(__unused_webpack_module, exports, __nccwpck_require__) {
 
 "use strict";
@@ -947,7 +947,7 @@ exports.summary = _summary;
 
 /***/ }),
 
-/***/ 77401:
+/***/ 46023:
 /***/ ((__unused_webpack_module, exports) => {
 
 "use strict";
@@ -994,7 +994,7 @@ exports.toCommandProperties = toCommandProperties;
 
 /***/ }),
 
-/***/ 62669:
+/***/ 42601:
 /***/ (function(__unused_webpack_module, exports) {
 
 "use strict";
@@ -1082,7 +1082,7 @@ exports.PersonalAccessTokenCredentialHandler = PersonalAccessTokenCredentialHand
 
 /***/ }),
 
-/***/ 57281:
+/***/ 18158:
 /***/ (function(__unused_webpack_module, exports, __nccwpck_require__) {
 
 "use strict";
@@ -1120,8 +1120,8 @@ Object.defineProperty(exports, "__esModule", ({ value: true }));
 exports.HttpClient = exports.isHttps = exports.HttpClientResponse = exports.HttpClientError = exports.getProxyUrl = exports.MediaTypes = exports.Headers = exports.HttpCodes = void 0;
 const http = __importStar(__nccwpck_require__(13685));
 const https = __importStar(__nccwpck_require__(95687));
-const pm = __importStar(__nccwpck_require__(32871));
-const tunnel = __importStar(__nccwpck_require__(57383));
+const pm = __importStar(__nccwpck_require__(34321));
+const tunnel = __importStar(__nccwpck_require__(2932));
 var HttpCodes;
 (function (HttpCodes) {
     HttpCodes[HttpCodes["OK"] = 200] = "OK";
@@ -1694,7 +1694,7 @@ const lowercaseKeys = (obj) => Object.keys(obj).reduce((c, k) => ((c[k.toLowerCa
 
 /***/ }),
 
-/***/ 32871:
+/***/ 34321:
 /***/ ((__unused_webpack_module, exports) => {
 
 "use strict";
@@ -1777,267 +1777,11 @@ function isLoopbackAddress(host) {
 
 /***/ }),
 
-/***/ 97127:
-/***/ (function(module) {
-
-(function (global, factory) {
-     true ? module.exports = factory() :
-    0;
-})(this, (function () { 'use strict';
-
-    // Matches the scheme of a URL, eg "http://"
-    const schemeRegex = /^[\w+.-]+:\/\//;
-    /**
-     * Matches the parts of a URL:
-     * 1. Scheme, including ":", guaranteed.
-     * 2. User/password, including "@", optional.
-     * 3. Host, guaranteed.
-     * 4. Port, including ":", optional.
-     * 5. Path, including "/", optional.
-     * 6. Query, including "?", optional.
-     * 7. Hash, including "#", optional.
-     */
-    const urlRegex = /^([\w+.-]+:)\/\/([^@/#?]*@)?([^:/#?]*)(:\d+)?(\/[^#?]*)?(\?[^#]*)?(#.*)?/;
-    /**
-     * File URLs are weird. They dont' need the regular `//` in the scheme, they may or may not start
-     * with a leading `/`, they can have a domain (but only if they don't start with a Windows drive).
-     *
-     * 1. Host, optional.
-     * 2. Path, which may include "/", guaranteed.
-     * 3. Query, including "?", optional.
-     * 4. Hash, including "#", optional.
-     */
-    const fileRegex = /^file:(?:\/\/((?![a-z]:)[^/#?]*)?)?(\/?[^#?]*)(\?[^#]*)?(#.*)?/i;
-    var UrlType;
-    (function (UrlType) {
-        UrlType[UrlType["Empty"] = 1] = "Empty";
-        UrlType[UrlType["Hash"] = 2] = "Hash";
-        UrlType[UrlType["Query"] = 3] = "Query";
-        UrlType[UrlType["RelativePath"] = 4] = "RelativePath";
-        UrlType[UrlType["AbsolutePath"] = 5] = "AbsolutePath";
-        UrlType[UrlType["SchemeRelative"] = 6] = "SchemeRelative";
-        UrlType[UrlType["Absolute"] = 7] = "Absolute";
-    })(UrlType || (UrlType = {}));
-    function isAbsoluteUrl(input) {
-        return schemeRegex.test(input);
-    }
-    function isSchemeRelativeUrl(input) {
-        return input.startsWith('//');
-    }
-    function isAbsolutePath(input) {
-        return input.startsWith('/');
-    }
-    function isFileUrl(input) {
-        return input.startsWith('file:');
-    }
-    function isRelative(input) {
-        return /^[.?#]/.test(input);
-    }
-    function parseAbsoluteUrl(input) {
-        const match = urlRegex.exec(input);
-        return makeUrl(match[1], match[2] || '', match[3], match[4] || '', match[5] || '/', match[6] || '', match[7] || '');
-    }
-    function parseFileUrl(input) {
-        const match = fileRegex.exec(input);
-        const path = match[2];
-        return makeUrl('file:', '', match[1] || '', '', isAbsolutePath(path) ? path : '/' + path, match[3] || '', match[4] || '');
-    }
-    function makeUrl(scheme, user, host, port, path, query, hash) {
-        return {
-            scheme,
-            user,
-            host,
-            port,
-            path,
-            query,
-            hash,
-            type: UrlType.Absolute,
-        };
-    }
-    function parseUrl(input) {
-        if (isSchemeRelativeUrl(input)) {
-            const url = parseAbsoluteUrl('http:' + input);
-            url.scheme = '';
-            url.type = UrlType.SchemeRelative;
-            return url;
-        }
-        if (isAbsolutePath(input)) {
-            const url = parseAbsoluteUrl('http://foo.com' + input);
-            url.scheme = '';
-            url.host = '';
-            url.type = UrlType.AbsolutePath;
-            return url;
-        }
-        if (isFileUrl(input))
-            return parseFileUrl(input);
-        if (isAbsoluteUrl(input))
-            return parseAbsoluteUrl(input);
-        const url = parseAbsoluteUrl('http://foo.com/' + input);
-        url.scheme = '';
-        url.host = '';
-        url.type = input
-            ? input.startsWith('?')
-                ? UrlType.Query
-                : input.startsWith('#')
-                    ? UrlType.Hash
-                    : UrlType.RelativePath
-            : UrlType.Empty;
-        return url;
-    }
-    function stripPathFilename(path) {
-        // If a path ends with a parent directory "..", then it's a relative path with excess parent
-        // paths. It's not a file, so we can't strip it.
-        if (path.endsWith('/..'))
-            return path;
-        const index = path.lastIndexOf('/');
-        return path.slice(0, index + 1);
-    }
-    function mergePaths(url, base) {
-        normalizePath(base, base.type);
-        // If the path is just a "/", then it was an empty path to begin with (remember, we're a relative
-        // path).
-        if (url.path === '/') {
-            url.path = base.path;
-        }
-        else {
-            // Resolution happens relative to the base path's directory, not the file.
-            url.path = stripPathFilename(base.path) + url.path;
-        }
-    }
-    /**
-     * The path can have empty directories "//", unneeded parents "foo/..", or current directory
-     * "foo/.". We need to normalize to a standard representation.
-     */
-    function normalizePath(url, type) {
-        const rel = type <= UrlType.RelativePath;
-        const pieces = url.path.split('/');
-        // We need to preserve the first piece always, so that we output a leading slash. The item at
-        // pieces[0] is an empty string.
-        let pointer = 1;
-        // Positive is the number of real directories we've output, used for popping a parent directory.
-        // Eg, "foo/bar/.." will have a positive 2, and we can decrement to be left with just "foo".
-        let positive = 0;
-        // We need to keep a trailing slash if we encounter an empty directory (eg, splitting "foo/" will
-        // generate `["foo", ""]` pieces). And, if we pop a parent directory. But once we encounter a
-        // real directory, we won't need to append, unless the other conditions happen again.
-        let addTrailingSlash = false;
-        for (let i = 1; i < pieces.length; i++) {
-            const piece = pieces[i];
-            // An empty directory, could be a trailing slash, or just a double "//" in the path.
-            if (!piece) {
-                addTrailingSlash = true;
-                continue;
-            }
-            // If we encounter a real directory, then we don't need to append anymore.
-            addTrailingSlash = false;
-            // A current directory, which we can always drop.
-            if (piece === '.')
-                continue;
-            // A parent directory, we need to see if there are any real directories we can pop. Else, we
-            // have an excess of parents, and we'll need to keep the "..".
-            if (piece === '..') {
-                if (positive) {
-                    addTrailingSlash = true;
-                    positive--;
-                    pointer--;
-                }
-                else if (rel) {
-                    // If we're in a relativePath, then we need to keep the excess parents. Else, in an absolute
-                    // URL, protocol relative URL, or an absolute path, we don't need to keep excess.
-                    pieces[pointer++] = piece;
-                }
-                continue;
-            }
-            // We've encountered a real directory. Move it to the next insertion pointer, which accounts for
-            // any popped or dropped directories.
-            pieces[pointer++] = piece;
-            positive++;
-        }
-        let path = '';
-        for (let i = 1; i < pointer; i++) {
-            path += '/' + pieces[i];
-        }
-        if (!path || (addTrailingSlash && !path.endsWith('/..'))) {
-            path += '/';
-        }
-        url.path = path;
-    }
-    /**
-     * Attempts to resolve `input` URL/path relative to `base`.
-     */
-    function resolve(input, base) {
-        if (!input && !base)
-            return '';
-        const url = parseUrl(input);
-        let inputType = url.type;
-        if (base && inputType !== UrlType.Absolute) {
-            const baseUrl = parseUrl(base);
-            const baseType = baseUrl.type;
-            switch (inputType) {
-                case UrlType.Empty:
-                    url.hash = baseUrl.hash;
-                // fall through
-                case UrlType.Hash:
-                    url.query = baseUrl.query;
-                // fall through
-                case UrlType.Query:
-                case UrlType.RelativePath:
-                    mergePaths(url, baseUrl);
-                // fall through
-                case UrlType.AbsolutePath:
-                    // The host, user, and port are joined, you can't copy one without the others.
-                    url.user = baseUrl.user;
-                    url.host = baseUrl.host;
-                    url.port = baseUrl.port;
-                // fall through
-                case UrlType.SchemeRelative:
-                    // The input doesn't have a schema at least, so we need to copy at least that over.
-                    url.scheme = baseUrl.scheme;
-            }
-            if (baseType > inputType)
-                inputType = baseType;
-        }
-        normalizePath(url, inputType);
-        const queryHash = url.query + url.hash;
-        switch (inputType) {
-            // This is impossible, because of the empty checks at the start of the function.
-            // case UrlType.Empty:
-            case UrlType.Hash:
-            case UrlType.Query:
-                return queryHash;
-            case UrlType.RelativePath: {
-                // The first char is always a "/", and we need it to be relative.
-                const path = url.path.slice(1);
-                if (!path)
-                    return queryHash || '.';
-                if (isRelative(base || input) && !isRelative(path)) {
-                    // If base started with a leading ".", or there is no base and input started with a ".",
-                    // then we need to ensure that the relative path starts with a ".". We don't know if
-                    // relative starts with a "..", though, so check before prepending.
-                    return './' + path + queryHash;
-                }
-                return path + queryHash;
-            }
-            case UrlType.AbsolutePath:
-                return url.path + queryHash;
-            default:
-                return url.scheme + '//' + url.user + url.host + url.port + url.path + queryHash;
-        }
-    }
-
-    return resolve;
-
-}));
-//# sourceMappingURL=resolve-uri.umd.js.map
-
-
-/***/ }),
-
-/***/ 66980:
+/***/ 88686:
 /***/ (function(__unused_webpack_module, exports, __nccwpck_require__) {
 
 (function (global, factory) {
-     true ? factory(exports, __nccwpck_require__(8205), __nccwpck_require__(97127)) :
+     true ? factory(exports, __nccwpck_require__(22447), __nccwpck_require__(45192)) :
     0;
 })(this, (function (exports, sourcemapCodec, resolveUri) { 'use strict';
 
@@ -2567,11 +2311,11 @@ function isLoopbackAddress(host) {
 
 /***/ }),
 
-/***/ 62090:
+/***/ 89254:
 /***/ ((module, exports, __nccwpck_require__) => {
 
 /* module decorator */ module = __nccwpck_require__.nmd(module);
-const { TraceMap, originalPositionFor, AnyMap } = __nccwpck_require__(66980);
+const { TraceMap, originalPositionFor, AnyMap } = __nccwpck_require__(88686);
 var path = __nccwpck_require__(71017);
 const { fileURLToPath, pathToFileURL } = __nccwpck_require__(57310);
 var util = __nccwpck_require__(73837);
@@ -3513,7 +3257,263 @@ exports.resetRetrieveHandlers = function() {
 
 /***/ }),
 
-/***/ 8205:
+/***/ 45192:
+/***/ (function(module) {
+
+(function (global, factory) {
+     true ? module.exports = factory() :
+    0;
+})(this, (function () { 'use strict';
+
+    // Matches the scheme of a URL, eg "http://"
+    const schemeRegex = /^[\w+.-]+:\/\//;
+    /**
+     * Matches the parts of a URL:
+     * 1. Scheme, including ":", guaranteed.
+     * 2. User/password, including "@", optional.
+     * 3. Host, guaranteed.
+     * 4. Port, including ":", optional.
+     * 5. Path, including "/", optional.
+     * 6. Query, including "?", optional.
+     * 7. Hash, including "#", optional.
+     */
+    const urlRegex = /^([\w+.-]+:)\/\/([^@/#?]*@)?([^:/#?]*)(:\d+)?(\/[^#?]*)?(\?[^#]*)?(#.*)?/;
+    /**
+     * File URLs are weird. They dont' need the regular `//` in the scheme, they may or may not start
+     * with a leading `/`, they can have a domain (but only if they don't start with a Windows drive).
+     *
+     * 1. Host, optional.
+     * 2. Path, which may include "/", guaranteed.
+     * 3. Query, including "?", optional.
+     * 4. Hash, including "#", optional.
+     */
+    const fileRegex = /^file:(?:\/\/((?![a-z]:)[^/#?]*)?)?(\/?[^#?]*)(\?[^#]*)?(#.*)?/i;
+    var UrlType;
+    (function (UrlType) {
+        UrlType[UrlType["Empty"] = 1] = "Empty";
+        UrlType[UrlType["Hash"] = 2] = "Hash";
+        UrlType[UrlType["Query"] = 3] = "Query";
+        UrlType[UrlType["RelativePath"] = 4] = "RelativePath";
+        UrlType[UrlType["AbsolutePath"] = 5] = "AbsolutePath";
+        UrlType[UrlType["SchemeRelative"] = 6] = "SchemeRelative";
+        UrlType[UrlType["Absolute"] = 7] = "Absolute";
+    })(UrlType || (UrlType = {}));
+    function isAbsoluteUrl(input) {
+        return schemeRegex.test(input);
+    }
+    function isSchemeRelativeUrl(input) {
+        return input.startsWith('//');
+    }
+    function isAbsolutePath(input) {
+        return input.startsWith('/');
+    }
+    function isFileUrl(input) {
+        return input.startsWith('file:');
+    }
+    function isRelative(input) {
+        return /^[.?#]/.test(input);
+    }
+    function parseAbsoluteUrl(input) {
+        const match = urlRegex.exec(input);
+        return makeUrl(match[1], match[2] || '', match[3], match[4] || '', match[5] || '/', match[6] || '', match[7] || '');
+    }
+    function parseFileUrl(input) {
+        const match = fileRegex.exec(input);
+        const path = match[2];
+        return makeUrl('file:', '', match[1] || '', '', isAbsolutePath(path) ? path : '/' + path, match[3] || '', match[4] || '');
+    }
+    function makeUrl(scheme, user, host, port, path, query, hash) {
+        return {
+            scheme,
+            user,
+            host,
+            port,
+            path,
+            query,
+            hash,
+            type: UrlType.Absolute,
+        };
+    }
+    function parseUrl(input) {
+        if (isSchemeRelativeUrl(input)) {
+            const url = parseAbsoluteUrl('http:' + input);
+            url.scheme = '';
+            url.type = UrlType.SchemeRelative;
+            return url;
+        }
+        if (isAbsolutePath(input)) {
+            const url = parseAbsoluteUrl('http://foo.com' + input);
+            url.scheme = '';
+            url.host = '';
+            url.type = UrlType.AbsolutePath;
+            return url;
+        }
+        if (isFileUrl(input))
+            return parseFileUrl(input);
+        if (isAbsoluteUrl(input))
+            return parseAbsoluteUrl(input);
+        const url = parseAbsoluteUrl('http://foo.com/' + input);
+        url.scheme = '';
+        url.host = '';
+        url.type = input
+            ? input.startsWith('?')
+                ? UrlType.Query
+                : input.startsWith('#')
+                    ? UrlType.Hash
+                    : UrlType.RelativePath
+            : UrlType.Empty;
+        return url;
+    }
+    function stripPathFilename(path) {
+        // If a path ends with a parent directory "..", then it's a relative path with excess parent
+        // paths. It's not a file, so we can't strip it.
+        if (path.endsWith('/..'))
+            return path;
+        const index = path.lastIndexOf('/');
+        return path.slice(0, index + 1);
+    }
+    function mergePaths(url, base) {
+        normalizePath(base, base.type);
+        // If the path is just a "/", then it was an empty path to begin with (remember, we're a relative
+        // path).
+        if (url.path === '/') {
+            url.path = base.path;
+        }
+        else {
+            // Resolution happens relative to the base path's directory, not the file.
+            url.path = stripPathFilename(base.path) + url.path;
+        }
+    }
+    /**
+     * The path can have empty directories "//", unneeded parents "foo/..", or current directory
+     * "foo/.". We need to normalize to a standard representation.
+     */
+    function normalizePath(url, type) {
+        const rel = type <= UrlType.RelativePath;
+        const pieces = url.path.split('/');
+        // We need to preserve the first piece always, so that we output a leading slash. The item at
+        // pieces[0] is an empty string.
+        let pointer = 1;
+        // Positive is the number of real directories we've output, used for popping a parent directory.
+        // Eg, "foo/bar/.." will have a positive 2, and we can decrement to be left with just "foo".
+        let positive = 0;
+        // We need to keep a trailing slash if we encounter an empty directory (eg, splitting "foo/" will
+        // generate `["foo", ""]` pieces). And, if we pop a parent directory. But once we encounter a
+        // real directory, we won't need to append, unless the other conditions happen again.
+        let addTrailingSlash = false;
+        for (let i = 1; i < pieces.length; i++) {
+            const piece = pieces[i];
+            // An empty directory, could be a trailing slash, or just a double "//" in the path.
+            if (!piece) {
+                addTrailingSlash = true;
+                continue;
+            }
+            // If we encounter a real directory, then we don't need to append anymore.
+            addTrailingSlash = false;
+            // A current directory, which we can always drop.
+            if (piece === '.')
+                continue;
+            // A parent directory, we need to see if there are any real directories we can pop. Else, we
+            // have an excess of parents, and we'll need to keep the "..".
+            if (piece === '..') {
+                if (positive) {
+                    addTrailingSlash = true;
+                    positive--;
+                    pointer--;
+                }
+                else if (rel) {
+                    // If we're in a relativePath, then we need to keep the excess parents. Else, in an absolute
+                    // URL, protocol relative URL, or an absolute path, we don't need to keep excess.
+                    pieces[pointer++] = piece;
+                }
+                continue;
+            }
+            // We've encountered a real directory. Move it to the next insertion pointer, which accounts for
+            // any popped or dropped directories.
+            pieces[pointer++] = piece;
+            positive++;
+        }
+        let path = '';
+        for (let i = 1; i < pointer; i++) {
+            path += '/' + pieces[i];
+        }
+        if (!path || (addTrailingSlash && !path.endsWith('/..'))) {
+            path += '/';
+        }
+        url.path = path;
+    }
+    /**
+     * Attempts to resolve `input` URL/path relative to `base`.
+     */
+    function resolve(input, base) {
+        if (!input && !base)
+            return '';
+        const url = parseUrl(input);
+        let inputType = url.type;
+        if (base && inputType !== UrlType.Absolute) {
+            const baseUrl = parseUrl(base);
+            const baseType = baseUrl.type;
+            switch (inputType) {
+                case UrlType.Empty:
+                    url.hash = baseUrl.hash;
+                // fall through
+                case UrlType.Hash:
+                    url.query = baseUrl.query;
+                // fall through
+                case UrlType.Query:
+                case UrlType.RelativePath:
+                    mergePaths(url, baseUrl);
+                // fall through
+                case UrlType.AbsolutePath:
+                    // The host, user, and port are joined, you can't copy one without the others.
+                    url.user = baseUrl.user;
+                    url.host = baseUrl.host;
+                    url.port = baseUrl.port;
+                // fall through
+                case UrlType.SchemeRelative:
+                    // The input doesn't have a schema at least, so we need to copy at least that over.
+                    url.scheme = baseUrl.scheme;
+            }
+            if (baseType > inputType)
+                inputType = baseType;
+        }
+        normalizePath(url, inputType);
+        const queryHash = url.query + url.hash;
+        switch (inputType) {
+            // This is impossible, because of the empty checks at the start of the function.
+            // case UrlType.Empty:
+            case UrlType.Hash:
+            case UrlType.Query:
+                return queryHash;
+            case UrlType.RelativePath: {
+                // The first char is always a "/", and we need it to be relative.
+                const path = url.path.slice(1);
+                if (!path)
+                    return queryHash || '.';
+                if (isRelative(base || input) && !isRelative(path)) {
+                    // If base started with a leading ".", or there is no base and input started with a ".",
+                    // then we need to ensure that the relative path starts with a ".". We don't know if
+                    // relative starts with a "..", though, so check before prepending.
+                    return './' + path + queryHash;
+                }
+                return path + queryHash;
+            }
+            case UrlType.AbsolutePath:
+                return url.path + queryHash;
+            default:
+                return url.scheme + '//' + url.user + url.host + url.port + url.path + queryHash;
+        }
+    }
+
+    return resolve;
+
+}));
+//# sourceMappingURL=resolve-uri.umd.js.map
+
+
+/***/ }),
+
+/***/ 22447:
 /***/ (function(__unused_webpack_module, exports) {
 
 (function (global, factory) {
@@ -3694,945 +3694,27 @@ exports.resetRetrieveHandlers = function() {
 
 /***/ }),
 
-/***/ 50183:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
-
-"use strict";
-
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.createFileSystemAdapter = exports.FILE_SYSTEM_ADAPTER = void 0;
-const fs = __nccwpck_require__(57147);
-exports.FILE_SYSTEM_ADAPTER = {
-    lstat: fs.lstat,
-    stat: fs.stat,
-    lstatSync: fs.lstatSync,
-    statSync: fs.statSync,
-    readdir: fs.readdir,
-    readdirSync: fs.readdirSync
-};
-function createFileSystemAdapter(fsMethods) {
-    if (fsMethods === undefined) {
-        return exports.FILE_SYSTEM_ADAPTER;
-    }
-    return Object.assign(Object.assign({}, exports.FILE_SYSTEM_ADAPTER), fsMethods);
-}
-exports.createFileSystemAdapter = createFileSystemAdapter;
-
-
-/***/ }),
-
-/***/ 68809:
-/***/ ((__unused_webpack_module, exports) => {
-
-"use strict";
-
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.IS_SUPPORT_READDIR_WITH_FILE_TYPES = void 0;
-const NODE_PROCESS_VERSION_PARTS = process.versions.node.split('.');
-if (NODE_PROCESS_VERSION_PARTS[0] === undefined || NODE_PROCESS_VERSION_PARTS[1] === undefined) {
-    throw new Error(`Unexpected behavior. The 'process.versions.node' variable has invalid value: ${process.versions.node}`);
-}
-const MAJOR_VERSION = Number.parseInt(NODE_PROCESS_VERSION_PARTS[0], 10);
-const MINOR_VERSION = Number.parseInt(NODE_PROCESS_VERSION_PARTS[1], 10);
-const SUPPORTED_MAJOR_VERSION = 10;
-const SUPPORTED_MINOR_VERSION = 10;
-const IS_MATCHED_BY_MAJOR = MAJOR_VERSION > SUPPORTED_MAJOR_VERSION;
-const IS_MATCHED_BY_MAJOR_AND_MINOR = MAJOR_VERSION === SUPPORTED_MAJOR_VERSION && MINOR_VERSION >= SUPPORTED_MINOR_VERSION;
-/**
- * IS `true` for Node.js 10.10 and greater.
- */
-exports.IS_SUPPORT_READDIR_WITH_FILE_TYPES = IS_MATCHED_BY_MAJOR || IS_MATCHED_BY_MAJOR_AND_MINOR;
-
-
-/***/ }),
-
-/***/ 56595:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
-
-"use strict";
-
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.Settings = exports.scandirSync = exports.scandir = void 0;
-const async = __nccwpck_require__(46975);
-const sync = __nccwpck_require__(7805);
-const settings_1 = __nccwpck_require__(59549);
-exports.Settings = settings_1.default;
-function scandir(path, optionsOrSettingsOrCallback, callback) {
-    if (typeof optionsOrSettingsOrCallback === 'function') {
-        async.read(path, getSettings(), optionsOrSettingsOrCallback);
-        return;
-    }
-    async.read(path, getSettings(optionsOrSettingsOrCallback), callback);
-}
-exports.scandir = scandir;
-function scandirSync(path, optionsOrSettings) {
-    const settings = getSettings(optionsOrSettings);
-    return sync.read(path, settings);
-}
-exports.scandirSync = scandirSync;
-function getSettings(settingsOrOptions = {}) {
-    if (settingsOrOptions instanceof settings_1.default) {
-        return settingsOrOptions;
-    }
-    return new settings_1.default(settingsOrOptions);
-}
-
-
-/***/ }),
-
-/***/ 46975:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
-
-"use strict";
-
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.readdir = exports.readdirWithFileTypes = exports.read = void 0;
-const fsStat = __nccwpck_require__(25925);
-const rpl = __nccwpck_require__(87851);
-const constants_1 = __nccwpck_require__(68809);
-const utils = __nccwpck_require__(65973);
-const common = __nccwpck_require__(83292);
-function read(directory, settings, callback) {
-    if (!settings.stats && constants_1.IS_SUPPORT_READDIR_WITH_FILE_TYPES) {
-        readdirWithFileTypes(directory, settings, callback);
-        return;
-    }
-    readdir(directory, settings, callback);
-}
-exports.read = read;
-function readdirWithFileTypes(directory, settings, callback) {
-    settings.fs.readdir(directory, { withFileTypes: true }, (readdirError, dirents) => {
-        if (readdirError !== null) {
-            callFailureCallback(callback, readdirError);
-            return;
-        }
-        const entries = dirents.map((dirent) => ({
-            dirent,
-            name: dirent.name,
-            path: common.joinPathSegments(directory, dirent.name, settings.pathSegmentSeparator)
-        }));
-        if (!settings.followSymbolicLinks) {
-            callSuccessCallback(callback, entries);
-            return;
-        }
-        const tasks = entries.map((entry) => makeRplTaskEntry(entry, settings));
-        rpl(tasks, (rplError, rplEntries) => {
-            if (rplError !== null) {
-                callFailureCallback(callback, rplError);
-                return;
-            }
-            callSuccessCallback(callback, rplEntries);
-        });
-    });
-}
-exports.readdirWithFileTypes = readdirWithFileTypes;
-function makeRplTaskEntry(entry, settings) {
-    return (done) => {
-        if (!entry.dirent.isSymbolicLink()) {
-            done(null, entry);
-            return;
-        }
-        settings.fs.stat(entry.path, (statError, stats) => {
-            if (statError !== null) {
-                if (settings.throwErrorOnBrokenSymbolicLink) {
-                    done(statError);
-                    return;
-                }
-                done(null, entry);
-                return;
-            }
-            entry.dirent = utils.fs.createDirentFromStats(entry.name, stats);
-            done(null, entry);
-        });
-    };
-}
-function readdir(directory, settings, callback) {
-    settings.fs.readdir(directory, (readdirError, names) => {
-        if (readdirError !== null) {
-            callFailureCallback(callback, readdirError);
-            return;
-        }
-        const tasks = names.map((name) => {
-            const path = common.joinPathSegments(directory, name, settings.pathSegmentSeparator);
-            return (done) => {
-                fsStat.stat(path, settings.fsStatSettings, (error, stats) => {
-                    if (error !== null) {
-                        done(error);
-                        return;
-                    }
-                    const entry = {
-                        name,
-                        path,
-                        dirent: utils.fs.createDirentFromStats(name, stats)
-                    };
-                    if (settings.stats) {
-                        entry.stats = stats;
-                    }
-                    done(null, entry);
-                });
-            };
-        });
-        rpl(tasks, (rplError, entries) => {
-            if (rplError !== null) {
-                callFailureCallback(callback, rplError);
-                return;
-            }
-            callSuccessCallback(callback, entries);
-        });
-    });
-}
-exports.readdir = readdir;
-function callFailureCallback(callback, error) {
-    callback(error);
-}
-function callSuccessCallback(callback, result) {
-    callback(null, result);
-}
-
-
-/***/ }),
-
-/***/ 83292:
-/***/ ((__unused_webpack_module, exports) => {
-
-"use strict";
-
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.joinPathSegments = void 0;
-function joinPathSegments(a, b, separator) {
-    /**
-     * The correct handling of cases when the first segment is a root (`/`, `C:/`) or UNC path (`//?/C:/`).
-     */
-    if (a.endsWith(separator)) {
-        return a + b;
-    }
-    return a + separator + b;
-}
-exports.joinPathSegments = joinPathSegments;
-
-
-/***/ }),
-
-/***/ 7805:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
-
-"use strict";
-
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.readdir = exports.readdirWithFileTypes = exports.read = void 0;
-const fsStat = __nccwpck_require__(25925);
-const constants_1 = __nccwpck_require__(68809);
-const utils = __nccwpck_require__(65973);
-const common = __nccwpck_require__(83292);
-function read(directory, settings) {
-    if (!settings.stats && constants_1.IS_SUPPORT_READDIR_WITH_FILE_TYPES) {
-        return readdirWithFileTypes(directory, settings);
-    }
-    return readdir(directory, settings);
-}
-exports.read = read;
-function readdirWithFileTypes(directory, settings) {
-    const dirents = settings.fs.readdirSync(directory, { withFileTypes: true });
-    return dirents.map((dirent) => {
-        const entry = {
-            dirent,
-            name: dirent.name,
-            path: common.joinPathSegments(directory, dirent.name, settings.pathSegmentSeparator)
-        };
-        if (entry.dirent.isSymbolicLink() && settings.followSymbolicLinks) {
-            try {
-                const stats = settings.fs.statSync(entry.path);
-                entry.dirent = utils.fs.createDirentFromStats(entry.name, stats);
-            }
-            catch (error) {
-                if (settings.throwErrorOnBrokenSymbolicLink) {
-                    throw error;
-                }
-            }
-        }
-        return entry;
-    });
-}
-exports.readdirWithFileTypes = readdirWithFileTypes;
-function readdir(directory, settings) {
-    const names = settings.fs.readdirSync(directory);
-    return names.map((name) => {
-        const entryPath = common.joinPathSegments(directory, name, settings.pathSegmentSeparator);
-        const stats = fsStat.statSync(entryPath, settings.fsStatSettings);
-        const entry = {
-            name,
-            path: entryPath,
-            dirent: utils.fs.createDirentFromStats(name, stats)
-        };
-        if (settings.stats) {
-            entry.stats = stats;
-        }
-        return entry;
-    });
-}
-exports.readdir = readdir;
-
-
-/***/ }),
-
-/***/ 59549:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
-
-"use strict";
-
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-const path = __nccwpck_require__(71017);
-const fsStat = __nccwpck_require__(25925);
-const fs = __nccwpck_require__(50183);
-class Settings {
-    constructor(_options = {}) {
-        this._options = _options;
-        this.followSymbolicLinks = this._getValue(this._options.followSymbolicLinks, false);
-        this.fs = fs.createFileSystemAdapter(this._options.fs);
-        this.pathSegmentSeparator = this._getValue(this._options.pathSegmentSeparator, path.sep);
-        this.stats = this._getValue(this._options.stats, false);
-        this.throwErrorOnBrokenSymbolicLink = this._getValue(this._options.throwErrorOnBrokenSymbolicLink, true);
-        this.fsStatSettings = new fsStat.Settings({
-            followSymbolicLink: this.followSymbolicLinks,
-            fs: this.fs,
-            throwErrorOnBrokenSymbolicLink: this.throwErrorOnBrokenSymbolicLink
-        });
-    }
-    _getValue(option, value) {
-        return option !== null && option !== void 0 ? option : value;
-    }
-}
-exports["default"] = Settings;
-
-
-/***/ }),
-
-/***/ 60421:
-/***/ ((__unused_webpack_module, exports) => {
-
-"use strict";
-
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.createDirentFromStats = void 0;
-class DirentFromStats {
-    constructor(name, stats) {
-        this.name = name;
-        this.isBlockDevice = stats.isBlockDevice.bind(stats);
-        this.isCharacterDevice = stats.isCharacterDevice.bind(stats);
-        this.isDirectory = stats.isDirectory.bind(stats);
-        this.isFIFO = stats.isFIFO.bind(stats);
-        this.isFile = stats.isFile.bind(stats);
-        this.isSocket = stats.isSocket.bind(stats);
-        this.isSymbolicLink = stats.isSymbolicLink.bind(stats);
-    }
-}
-function createDirentFromStats(name, stats) {
-    return new DirentFromStats(name, stats);
-}
-exports.createDirentFromStats = createDirentFromStats;
-
-
-/***/ }),
-
-/***/ 65973:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
-
-"use strict";
-
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.fs = void 0;
-const fs = __nccwpck_require__(60421);
-exports.fs = fs;
-
-
-/***/ }),
-
-/***/ 91892:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
-
-"use strict";
-
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.createFileSystemAdapter = exports.FILE_SYSTEM_ADAPTER = void 0;
-const fs = __nccwpck_require__(57147);
-exports.FILE_SYSTEM_ADAPTER = {
-    lstat: fs.lstat,
-    stat: fs.stat,
-    lstatSync: fs.lstatSync,
-    statSync: fs.statSync
-};
-function createFileSystemAdapter(fsMethods) {
-    if (fsMethods === undefined) {
-        return exports.FILE_SYSTEM_ADAPTER;
-    }
-    return Object.assign(Object.assign({}, exports.FILE_SYSTEM_ADAPTER), fsMethods);
-}
-exports.createFileSystemAdapter = createFileSystemAdapter;
-
-
-/***/ }),
-
-/***/ 25925:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
-
-"use strict";
-
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.statSync = exports.stat = exports.Settings = void 0;
-const async = __nccwpck_require__(97178);
-const sync = __nccwpck_require__(79804);
-const settings_1 = __nccwpck_require__(5237);
-exports.Settings = settings_1.default;
-function stat(path, optionsOrSettingsOrCallback, callback) {
-    if (typeof optionsOrSettingsOrCallback === 'function') {
-        async.read(path, getSettings(), optionsOrSettingsOrCallback);
-        return;
-    }
-    async.read(path, getSettings(optionsOrSettingsOrCallback), callback);
-}
-exports.stat = stat;
-function statSync(path, optionsOrSettings) {
-    const settings = getSettings(optionsOrSettings);
-    return sync.read(path, settings);
-}
-exports.statSync = statSync;
-function getSettings(settingsOrOptions = {}) {
-    if (settingsOrOptions instanceof settings_1.default) {
-        return settingsOrOptions;
-    }
-    return new settings_1.default(settingsOrOptions);
-}
-
-
-/***/ }),
-
-/***/ 97178:
-/***/ ((__unused_webpack_module, exports) => {
-
-"use strict";
-
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.read = void 0;
-function read(path, settings, callback) {
-    settings.fs.lstat(path, (lstatError, lstat) => {
-        if (lstatError !== null) {
-            callFailureCallback(callback, lstatError);
-            return;
-        }
-        if (!lstat.isSymbolicLink() || !settings.followSymbolicLink) {
-            callSuccessCallback(callback, lstat);
-            return;
-        }
-        settings.fs.stat(path, (statError, stat) => {
-            if (statError !== null) {
-                if (settings.throwErrorOnBrokenSymbolicLink) {
-                    callFailureCallback(callback, statError);
-                    return;
-                }
-                callSuccessCallback(callback, lstat);
-                return;
-            }
-            if (settings.markSymbolicLink) {
-                stat.isSymbolicLink = () => true;
-            }
-            callSuccessCallback(callback, stat);
-        });
-    });
-}
-exports.read = read;
-function callFailureCallback(callback, error) {
-    callback(error);
-}
-function callSuccessCallback(callback, result) {
-    callback(null, result);
-}
-
-
-/***/ }),
-
-/***/ 79804:
-/***/ ((__unused_webpack_module, exports) => {
-
-"use strict";
-
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.read = void 0;
-function read(path, settings) {
-    const lstat = settings.fs.lstatSync(path);
-    if (!lstat.isSymbolicLink() || !settings.followSymbolicLink) {
-        return lstat;
-    }
-    try {
-        const stat = settings.fs.statSync(path);
-        if (settings.markSymbolicLink) {
-            stat.isSymbolicLink = () => true;
-        }
-        return stat;
-    }
-    catch (error) {
-        if (!settings.throwErrorOnBrokenSymbolicLink) {
-            return lstat;
-        }
-        throw error;
-    }
-}
-exports.read = read;
-
-
-/***/ }),
-
-/***/ 5237:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
-
-"use strict";
-
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-const fs = __nccwpck_require__(91892);
-class Settings {
-    constructor(_options = {}) {
-        this._options = _options;
-        this.followSymbolicLink = this._getValue(this._options.followSymbolicLink, true);
-        this.fs = fs.createFileSystemAdapter(this._options.fs);
-        this.markSymbolicLink = this._getValue(this._options.markSymbolicLink, false);
-        this.throwErrorOnBrokenSymbolicLink = this._getValue(this._options.throwErrorOnBrokenSymbolicLink, true);
-    }
-    _getValue(option, value) {
-        return option !== null && option !== void 0 ? option : value;
-    }
-}
-exports["default"] = Settings;
-
-
-/***/ }),
-
-/***/ 99155:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
-
-"use strict";
-
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.Settings = exports.walkStream = exports.walkSync = exports.walk = void 0;
-const async_1 = __nccwpck_require__(40315);
-const stream_1 = __nccwpck_require__(77809);
-const sync_1 = __nccwpck_require__(45863);
-const settings_1 = __nccwpck_require__(45854);
-exports.Settings = settings_1.default;
-function walk(directory, optionsOrSettingsOrCallback, callback) {
-    if (typeof optionsOrSettingsOrCallback === 'function') {
-        new async_1.default(directory, getSettings()).read(optionsOrSettingsOrCallback);
-        return;
-    }
-    new async_1.default(directory, getSettings(optionsOrSettingsOrCallback)).read(callback);
-}
-exports.walk = walk;
-function walkSync(directory, optionsOrSettings) {
-    const settings = getSettings(optionsOrSettings);
-    const provider = new sync_1.default(directory, settings);
-    return provider.read();
-}
-exports.walkSync = walkSync;
-function walkStream(directory, optionsOrSettings) {
-    const settings = getSettings(optionsOrSettings);
-    const provider = new stream_1.default(directory, settings);
-    return provider.read();
-}
-exports.walkStream = walkStream;
-function getSettings(settingsOrOptions = {}) {
-    if (settingsOrOptions instanceof settings_1.default) {
-        return settingsOrOptions;
-    }
-    return new settings_1.default(settingsOrOptions);
-}
-
-
-/***/ }),
-
-/***/ 40315:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
-
-"use strict";
-
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-const async_1 = __nccwpck_require__(34615);
-class AsyncProvider {
-    constructor(_root, _settings) {
-        this._root = _root;
-        this._settings = _settings;
-        this._reader = new async_1.default(this._root, this._settings);
-        this._storage = [];
-    }
-    read(callback) {
-        this._reader.onError((error) => {
-            callFailureCallback(callback, error);
-        });
-        this._reader.onEntry((entry) => {
-            this._storage.push(entry);
-        });
-        this._reader.onEnd(() => {
-            callSuccessCallback(callback, this._storage);
-        });
-        this._reader.read();
-    }
-}
-exports["default"] = AsyncProvider;
-function callFailureCallback(callback, error) {
-    callback(error);
-}
-function callSuccessCallback(callback, entries) {
-    callback(null, entries);
-}
-
-
-/***/ }),
-
-/***/ 77809:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
-
-"use strict";
-
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-const stream_1 = __nccwpck_require__(12781);
-const async_1 = __nccwpck_require__(34615);
-class StreamProvider {
-    constructor(_root, _settings) {
-        this._root = _root;
-        this._settings = _settings;
-        this._reader = new async_1.default(this._root, this._settings);
-        this._stream = new stream_1.Readable({
-            objectMode: true,
-            read: () => { },
-            destroy: () => {
-                if (!this._reader.isDestroyed) {
-                    this._reader.destroy();
-                }
-            }
-        });
-    }
-    read() {
-        this._reader.onError((error) => {
-            this._stream.emit('error', error);
-        });
-        this._reader.onEntry((entry) => {
-            this._stream.push(entry);
-        });
-        this._reader.onEnd(() => {
-            this._stream.push(null);
-        });
-        this._reader.read();
-        return this._stream;
-    }
-}
-exports["default"] = StreamProvider;
-
-
-/***/ }),
-
-/***/ 45863:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
-
-"use strict";
-
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-const sync_1 = __nccwpck_require__(47751);
-class SyncProvider {
-    constructor(_root, _settings) {
-        this._root = _root;
-        this._settings = _settings;
-        this._reader = new sync_1.default(this._root, this._settings);
-    }
-    read() {
-        return this._reader.read();
-    }
-}
-exports["default"] = SyncProvider;
-
-
-/***/ }),
-
-/***/ 34615:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
-
-"use strict";
-
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-const events_1 = __nccwpck_require__(82361);
-const fsScandir = __nccwpck_require__(56595);
-const fastq = __nccwpck_require__(32027);
-const common = __nccwpck_require__(55892);
-const reader_1 = __nccwpck_require__(80707);
-class AsyncReader extends reader_1.default {
-    constructor(_root, _settings) {
-        super(_root, _settings);
-        this._settings = _settings;
-        this._scandir = fsScandir.scandir;
-        this._emitter = new events_1.EventEmitter();
-        this._queue = fastq(this._worker.bind(this), this._settings.concurrency);
-        this._isFatalError = false;
-        this._isDestroyed = false;
-        this._queue.drain = () => {
-            if (!this._isFatalError) {
-                this._emitter.emit('end');
-            }
-        };
-    }
-    read() {
-        this._isFatalError = false;
-        this._isDestroyed = false;
-        setImmediate(() => {
-            this._pushToQueue(this._root, this._settings.basePath);
-        });
-        return this._emitter;
-    }
-    get isDestroyed() {
-        return this._isDestroyed;
-    }
-    destroy() {
-        if (this._isDestroyed) {
-            throw new Error('The reader is already destroyed');
-        }
-        this._isDestroyed = true;
-        this._queue.killAndDrain();
-    }
-    onEntry(callback) {
-        this._emitter.on('entry', callback);
-    }
-    onError(callback) {
-        this._emitter.once('error', callback);
-    }
-    onEnd(callback) {
-        this._emitter.once('end', callback);
-    }
-    _pushToQueue(directory, base) {
-        const queueItem = { directory, base };
-        this._queue.push(queueItem, (error) => {
-            if (error !== null) {
-                this._handleError(error);
-            }
-        });
-    }
-    _worker(item, done) {
-        this._scandir(item.directory, this._settings.fsScandirSettings, (error, entries) => {
-            if (error !== null) {
-                done(error, undefined);
-                return;
-            }
-            for (const entry of entries) {
-                this._handleEntry(entry, item.base);
-            }
-            done(null, undefined);
-        });
-    }
-    _handleError(error) {
-        if (this._isDestroyed || !common.isFatalError(this._settings, error)) {
-            return;
-        }
-        this._isFatalError = true;
-        this._isDestroyed = true;
-        this._emitter.emit('error', error);
-    }
-    _handleEntry(entry, base) {
-        if (this._isDestroyed || this._isFatalError) {
-            return;
-        }
-        const fullpath = entry.path;
-        if (base !== undefined) {
-            entry.path = common.joinPathSegments(base, entry.name, this._settings.pathSegmentSeparator);
-        }
-        if (common.isAppliedFilter(this._settings.entryFilter, entry)) {
-            this._emitEntry(entry);
-        }
-        if (entry.dirent.isDirectory() && common.isAppliedFilter(this._settings.deepFilter, entry)) {
-            this._pushToQueue(fullpath, base === undefined ? undefined : entry.path);
-        }
-    }
-    _emitEntry(entry) {
-        this._emitter.emit('entry', entry);
-    }
-}
-exports["default"] = AsyncReader;
-
-
-/***/ }),
-
-/***/ 55892:
-/***/ ((__unused_webpack_module, exports) => {
-
-"use strict";
-
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.joinPathSegments = exports.replacePathSegmentSeparator = exports.isAppliedFilter = exports.isFatalError = void 0;
-function isFatalError(settings, error) {
-    if (settings.errorFilter === null) {
-        return true;
-    }
-    return !settings.errorFilter(error);
-}
-exports.isFatalError = isFatalError;
-function isAppliedFilter(filter, value) {
-    return filter === null || filter(value);
-}
-exports.isAppliedFilter = isAppliedFilter;
-function replacePathSegmentSeparator(filepath, separator) {
-    return filepath.split(/[/\\]/).join(separator);
-}
-exports.replacePathSegmentSeparator = replacePathSegmentSeparator;
-function joinPathSegments(a, b, separator) {
-    if (a === '') {
-        return b;
-    }
-    /**
-     * The correct handling of cases when the first segment is a root (`/`, `C:/`) or UNC path (`//?/C:/`).
-     */
-    if (a.endsWith(separator)) {
-        return a + b;
-    }
-    return a + separator + b;
-}
-exports.joinPathSegments = joinPathSegments;
-
-
-/***/ }),
-
-/***/ 80707:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
-
-"use strict";
-
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-const common = __nccwpck_require__(55892);
-class Reader {
-    constructor(_root, _settings) {
-        this._root = _root;
-        this._settings = _settings;
-        this._root = common.replacePathSegmentSeparator(_root, _settings.pathSegmentSeparator);
-    }
-}
-exports["default"] = Reader;
-
-
-/***/ }),
-
-/***/ 47751:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
-
-"use strict";
-
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-const fsScandir = __nccwpck_require__(56595);
-const common = __nccwpck_require__(55892);
-const reader_1 = __nccwpck_require__(80707);
-class SyncReader extends reader_1.default {
-    constructor() {
-        super(...arguments);
-        this._scandir = fsScandir.scandirSync;
-        this._storage = [];
-        this._queue = new Set();
-    }
-    read() {
-        this._pushToQueue(this._root, this._settings.basePath);
-        this._handleQueue();
-        return this._storage;
-    }
-    _pushToQueue(directory, base) {
-        this._queue.add({ directory, base });
-    }
-    _handleQueue() {
-        for (const item of this._queue.values()) {
-            this._handleDirectory(item.directory, item.base);
-        }
-    }
-    _handleDirectory(directory, base) {
-        try {
-            const entries = this._scandir(directory, this._settings.fsScandirSettings);
-            for (const entry of entries) {
-                this._handleEntry(entry, base);
-            }
-        }
-        catch (error) {
-            this._handleError(error);
-        }
-    }
-    _handleError(error) {
-        if (!common.isFatalError(this._settings, error)) {
-            return;
-        }
-        throw error;
-    }
-    _handleEntry(entry, base) {
-        const fullpath = entry.path;
-        if (base !== undefined) {
-            entry.path = common.joinPathSegments(base, entry.name, this._settings.pathSegmentSeparator);
-        }
-        if (common.isAppliedFilter(this._settings.entryFilter, entry)) {
-            this._pushToStorage(entry);
-        }
-        if (entry.dirent.isDirectory() && common.isAppliedFilter(this._settings.deepFilter, entry)) {
-            this._pushToQueue(fullpath, base === undefined ? undefined : entry.path);
-        }
-    }
-    _pushToStorage(entry) {
-        this._storage.push(entry);
-    }
-}
-exports["default"] = SyncReader;
-
-
-/***/ }),
-
-/***/ 45854:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
-
-"use strict";
-
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-const path = __nccwpck_require__(71017);
-const fsScandir = __nccwpck_require__(56595);
-class Settings {
-    constructor(_options = {}) {
-        this._options = _options;
-        this.basePath = this._getValue(this._options.basePath, undefined);
-        this.concurrency = this._getValue(this._options.concurrency, Number.POSITIVE_INFINITY);
-        this.deepFilter = this._getValue(this._options.deepFilter, null);
-        this.entryFilter = this._getValue(this._options.entryFilter, null);
-        this.errorFilter = this._getValue(this._options.errorFilter, null);
-        this.pathSegmentSeparator = this._getValue(this._options.pathSegmentSeparator, path.sep);
-        this.fsScandirSettings = new fsScandir.Settings({
-            followSymbolicLinks: this._options.followSymbolicLinks,
-            fs: this._options.fs,
-            pathSegmentSeparator: this._options.pathSegmentSeparator,
-            stats: this._options.stats,
-            throwErrorOnBrokenSymbolicLink: this._options.throwErrorOnBrokenSymbolicLink
-        });
-    }
-    _getValue(option, value) {
-        return option !== null && option !== void 0 ? option : value;
-    }
-}
-exports["default"] = Settings;
-
-
-/***/ }),
-
-/***/ 10763:
+/***/ 47885:
 /***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
 "use strict";
 
 Object.defineProperty(exports, "__esModule", ({ value: true }));
 exports.transform = exports.transformJest = exports.transformSync = void 0;
-const core_1 = __nccwpck_require__(76237);
+const core_1 = __nccwpck_require__(65142);
 // Oldest LTS Node.js supported target
 const DEFAULT_ES_TARGET = 'es2018';
 function transformOption(path, options, jest = false) {
-    var _a, _b, _c, _d, _e;
-    const opts = options == null ? {} : options;
+    var _a, _b, _c, _d, _e, _f, _g;
+    const opts = options !== null && options !== void 0 ? options : {};
     opts.esModuleInterop = (_a = opts.esModuleInterop) !== null && _a !== void 0 ? _a : true;
+    const moduleType = (_b = options === null || options === void 0 ? void 0 : options.module) !== null && _b !== void 0 ? _b : 'commonjs';
     return {
         filename: path,
-        jsc: ((_b = options === null || options === void 0 ? void 0 : options.swc) === null || _b === void 0 ? void 0 : _b.swcrc)
+        jsc: ((_c = options === null || options === void 0 ? void 0 : options.swc) === null || _c === void 0 ? void 0 : _c.swcrc)
             ? undefined
             : {
-                target: (_c = opts.target) !== null && _c !== void 0 ? _c : DEFAULT_ES_TARGET,
+                target: (_d = opts.target) !== null && _d !== void 0 ? _d : DEFAULT_ES_TARGET,
                 externalHelpers: jest ? true : Boolean(opts.externalHelpers),
                 parser: {
                     syntax: 'typescript',
@@ -4643,6 +3725,7 @@ function transformOption(path, options, jest = false) {
                 transform: {
                     legacyDecorator: Boolean(opts.experimentalDecorators),
                     decoratorMetadata: Boolean(opts.emitDecoratorMetadata),
+                    useDefineForClassFields: Boolean(opts.useDefineForClassFields),
                     react: options === null || options === void 0 ? void 0 : options.react,
                     // @ts-expect-error
                     hidden: {
@@ -4651,17 +3734,29 @@ function transformOption(path, options, jest = false) {
                 },
                 keepClassNames: opts.keepClassNames,
                 paths: opts.paths,
+                baseUrl: opts.baseUrl,
             },
         minify: false,
         isModule: true,
-        module: {
-            type: (_d = options === null || options === void 0 ? void 0 : options.module) !== null && _d !== void 0 ? _d : 'commonjs',
-            noInterop: !opts.esModuleInterop,
-        },
-        sourceMaps: jest || typeof opts.sourcemap === 'undefined' ? 'inline' : opts.sourcemap,
+        module: ((_e = options === null || options === void 0 ? void 0 : options.swc) === null || _e === void 0 ? void 0 : _e.swcrc)
+            ? undefined
+            : {
+                type: moduleType,
+                ...(moduleType === 'commonjs' || moduleType === 'umd' || moduleType === 'amd'
+                    ? {
+                        noInterop: !opts.esModuleInterop,
+                        ignoreDynamic: opts.ignoreDynamic,
+                    }
+                    : undefined),
+            },
+        sourceMaps: ((_f = options === null || options === void 0 ? void 0 : options.swc) === null || _f === void 0 ? void 0 : _f.swcrc)
+            ? undefined
+            : jest || typeof opts.sourcemap === 'undefined'
+                ? 'inline'
+                : opts.sourcemap,
         inlineSourcesContent: true,
         swcrc: false,
-        ...((_e = options === null || options === void 0 ? void 0 : options.swc) !== null && _e !== void 0 ? _e : {}),
+        ...((_g = options === null || options === void 0 ? void 0 : options.swc) !== null && _g !== void 0 ? _g : {}),
     };
 }
 function transformSync(source, path, options) {
@@ -4680,7 +3775,7 @@ exports.transform = transform;
 
 /***/ }),
 
-/***/ 11642:
+/***/ 66357:
 /***/ (function(__unused_webpack_module, exports, __nccwpck_require__) {
 
 "use strict";
@@ -4715,9 +3810,9 @@ Object.defineProperty(exports, "__esModule", ({ value: true }));
 exports.tsCompilerOptionsToSwcConfig = exports.readDefaultTsConfig = void 0;
 const fs_1 = __nccwpck_require__(57147);
 const path_1 = __nccwpck_require__(71017);
-const colorette_1 = __nccwpck_require__(90583);
-const debug_1 = __importDefault(__nccwpck_require__(44126));
-const ts = __importStar(__nccwpck_require__(70048));
+const colorette_1 = __nccwpck_require__(6613);
+const debug_1 = __importDefault(__nccwpck_require__(93118));
+const ts = __importStar(__nccwpck_require__(81151));
 const debug = (0, debug_1.default)('@swc-node');
 function readDefaultTsConfig(tsConfigPath) {
     var _a, _b;
@@ -4802,36 +3897,48 @@ function toModule(moduleKind) {
             throw new TypeError('Do not support system kind module');
     }
 }
+/**
+ * The default value for useDefineForClassFields depends on the emit target
+ * @see https://www.typescriptlang.org/tsconfig#useDefineForClassFields
+ */
+function getUseDefineForClassFields(compilerOptions, target) {
+    var _a;
+    return (_a = compilerOptions.useDefineForClassFields) !== null && _a !== void 0 ? _a : target >= ts.ScriptTarget.ES2022;
+}
 function tsCompilerOptionsToSwcConfig(options, filename) {
-    var _a, _b, _c, _d, _e, _f, _g, _h;
+    var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m;
     const isJsx = filename.endsWith('.tsx') || filename.endsWith('.jsx') || Boolean(options.jsx);
+    const target = (_a = options.target) !== null && _a !== void 0 ? _a : ts.ScriptTarget.ES2018;
     return {
-        module: toModule((_a = options.module) !== null && _a !== void 0 ? _a : ts.ModuleKind.ES2015),
-        target: toTsTarget((_b = options.target) !== null && _b !== void 0 ? _b : ts.ScriptTarget.ES2018),
+        module: toModule((_b = options.module) !== null && _b !== void 0 ? _b : ts.ModuleKind.ES2015),
+        target: toTsTarget(target),
         jsx: isJsx,
         sourcemap: options.sourceMap && options.inlineSourceMap ? 'inline' : Boolean(options.sourceMap),
         experimentalDecorators: (_c = options.experimentalDecorators) !== null && _c !== void 0 ? _c : false,
         emitDecoratorMetadata: (_d = options.emitDecoratorMetadata) !== null && _d !== void 0 ? _d : false,
+        useDefineForClassFields: getUseDefineForClassFields(options, target),
         esModuleInterop: (_e = options.esModuleInterop) !== null && _e !== void 0 ? _e : false,
         dynamicImport: true,
         keepClassNames: true,
         externalHelpers: Boolean(options.importHelpers),
-        react: options.jsxFactory || options.jsxFragmentFactory || options.jsx || options.jsxImportSource
+        react: ((_h = (_g = (_f = options.jsxFactory) !== null && _f !== void 0 ? _f : options.jsxFragmentFactory) !== null && _g !== void 0 ? _g : options.jsx) !== null && _h !== void 0 ? _h : options.jsxImportSource)
             ? {
                 pragma: options.jsxFactory,
                 pragmaFrag: options.jsxFragmentFactory,
-                importSource: (_f = options.jsxImportSource) !== null && _f !== void 0 ? _f : 'react',
-                runtime: ((_g = options.jsx) !== null && _g !== void 0 ? _g : 0) >= ts.JsxEmit.ReactJSX ? 'automatic' : 'classic',
+                importSource: (_j = options.jsxImportSource) !== null && _j !== void 0 ? _j : 'react',
+                runtime: ((_k = options.jsx) !== null && _k !== void 0 ? _k : 0) >= ts.JsxEmit.ReactJSX ? 'automatic' : 'classic',
                 useBuiltins: true,
             }
             : undefined,
-        paths: Object.fromEntries(Object.entries((_h = options.paths) !== null && _h !== void 0 ? _h : {}).map(([aliasKey, aliasPaths]) => {
+        baseUrl: (0, path_1.resolve)((_l = options.baseUrl) !== null && _l !== void 0 ? _l : './'),
+        paths: Object.fromEntries(Object.entries((_m = options.paths) !== null && _m !== void 0 ? _m : {}).map(([aliasKey, aliasPaths]) => {
             var _a;
             return [
                 aliasKey,
                 ((_a = aliasPaths) !== null && _a !== void 0 ? _a : []).map((path) => { var _a; return (0, path_1.resolve)((_a = options.baseUrl) !== null && _a !== void 0 ? _a : './', path); }),
             ];
         })),
+        ignoreDynamic: Boolean(process.env.SWC_NODE_IGNORE_DYNAMIC),
         swc: {
             sourceRoot: options.sourceRoot,
             inputSourceMap: options.inlineSourceMap,
@@ -4843,7 +3950,7 @@ exports.tsCompilerOptionsToSwcConfig = tsCompilerOptionsToSwcConfig;
 
 /***/ }),
 
-/***/ 61856:
+/***/ 55204:
 /***/ (function(__unused_webpack_module, exports, __nccwpck_require__) {
 
 "use strict";
@@ -4875,11 +3982,11 @@ Object.defineProperty(exports, "__esModule", ({ value: true }));
 exports.register = exports.compile = void 0;
 const os_1 = __nccwpck_require__(22037);
 const path_1 = __nccwpck_require__(71017);
-const core_1 = __nccwpck_require__(10763);
-const sourcemap_support_1 = __nccwpck_require__(13756);
-const pirates_1 = __nccwpck_require__(115);
-const ts = __importStar(__nccwpck_require__(70048));
-const read_default_tsconfig_1 = __nccwpck_require__(11642);
+const core_1 = __nccwpck_require__(47885);
+const sourcemap_support_1 = __nccwpck_require__(80758);
+const pirates_1 = __nccwpck_require__(16135);
+const ts = __importStar(__nccwpck_require__(81151));
+const read_default_tsconfig_1 = __nccwpck_require__(66357);
 const DEFAULT_EXTENSIONS = ['.js', '.jsx', '.es6', '.es', '.mjs', '.ts', '.tsx'];
 const PLATFORM = (0, os_1.platform)();
 const injectInlineSourceMap = ({ filename, code, map, }) => {
@@ -4912,24 +4019,24 @@ function compile(sourcecode, filename, options, async = false) {
         });
         return injectInlineSourceMap({ filename, code: outputText, map: sourceMapText });
     }
-    else if (async) {
-        return (0, core_1.transform)(sourcecode, filename, (0, read_default_tsconfig_1.tsCompilerOptionsToSwcConfig)(options, filename)).then(({ code, map }) => {
+    let swcRegisterConfig;
+    if (process.env.SWCRC) {
+        // when SWCRC environment variable is set to true it will use swcrc file
+        swcRegisterConfig = {
+            swc: {
+                swcrc: true,
+            },
+        };
+    }
+    else {
+        swcRegisterConfig = (0, read_default_tsconfig_1.tsCompilerOptionsToSwcConfig)(options, filename);
+    }
+    if (async) {
+        return (0, core_1.transform)(sourcecode, filename, swcRegisterConfig).then(({ code, map }) => {
             return injectInlineSourceMap({ filename, code, map });
         });
     }
     else {
-        let swcRegisterConfig;
-        if (process.env.SWCRC) {
-            // when SWCRC environment variable is set to true it will use swcrc file
-            swcRegisterConfig = {
-                swc: {
-                    swcrc: true,
-                },
-            };
-        }
-        else {
-            swcRegisterConfig = (0, read_default_tsconfig_1.tsCompilerOptionsToSwcConfig)(options, filename);
-        }
         const { code, map } = (0, core_1.transformSync)(sourcecode, filename, swcRegisterConfig);
         return injectInlineSourceMap({ filename, code, map });
     }
@@ -4937,7 +4044,7 @@ function compile(sourcecode, filename, options, async = false) {
 exports.compile = compile;
 function register(options = {}, hookOpts = {}) {
     if (!process.env.SWCRC) {
-        options = (0, read_default_tsconfig_1.readDefaultTsConfig)();
+        options = Object.keys(options).length ? options : (0, read_default_tsconfig_1.readDefaultTsConfig)();
     }
     options.module = ts.ModuleKind.CommonJS;
     (0, sourcemap_support_1.installSourceMapSupport)();
@@ -4951,7 +4058,7 @@ exports.register = register;
 
 /***/ }),
 
-/***/ 13756:
+/***/ 80758:
 /***/ (function(__unused_webpack_module, exports, __nccwpck_require__) {
 
 "use strict";
@@ -4961,7 +4068,7 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
 };
 Object.defineProperty(exports, "__esModule", ({ value: true }));
 exports.installSourceMapSupport = exports.SourcemapMap = void 0;
-const source_map_support_1 = __importDefault(__nccwpck_require__(95953));
+const source_map_support_1 = __importDefault(__nccwpck_require__(98841));
 exports.SourcemapMap = new Map();
 function installSourceMapSupport() {
     source_map_support_1.default.install({
@@ -4983,1001 +4090,445 @@ exports.installSourceMapSupport = installSourceMapSupport;
 
 /***/ }),
 
-/***/ 95953:
-/***/ ((module, exports, __nccwpck_require__) => {
-
-/* module decorator */ module = __nccwpck_require__.nmd(module);
-var SourceMapConsumer = (__nccwpck_require__(36096).SourceMapConsumer);
-var path = __nccwpck_require__(71017);
-
-var fs;
-try {
-  fs = __nccwpck_require__(57147);
-  if (!fs.existsSync || !fs.readFileSync) {
-    // fs doesn't have all methods we need
-    fs = null;
-  }
-} catch (err) {
-  /* nop */
-}
-
-var bufferFrom = __nccwpck_require__(82415);
-
-/**
- * Requires a module which is protected against bundler minification.
- *
- * @param {NodeModule} mod
- * @param {string} request
- */
-function dynamicRequire(mod, request) {
-  return mod.require(request);
-}
-
-// Only install once if called multiple times
-var errorFormatterInstalled = false;
-var uncaughtShimInstalled = false;
-
-// If true, the caches are reset before a stack trace formatting operation
-var emptyCacheBetweenOperations = false;
-
-// Supports {browser, node, auto}
-var environment = "auto";
-
-// Maps a file path to a string containing the file contents
-var fileContentsCache = {};
-
-// Maps a file path to a source map for that file
-var sourceMapCache = {};
-
-// Regex for detecting source maps
-var reSourceMap = /^data:application\/json[^,]+base64,/;
+/***/ 24279:
+/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
-// Priority list of retrieve handlers
-var retrieveFileHandlers = [];
-var retrieveMapHandlers = [];
+"use strict";
 
-function isInBrowser() {
-  if (environment === "browser")
-    return true;
-  if (environment === "node")
+// prettier-ignore
+/* eslint-disable */
+/* auto-generated by NAPI-RS */
+const { existsSync, readFileSync } = __nccwpck_require__(57147);
+const { join } = __nccwpck_require__(71017);
+const { platform, arch } = process;
+let nativeBinding = null;
+let localFileExisted = false;
+let loadError = null;
+const isMusl = () => {
+    let musl = false;
+    if (process.platform === 'linux') {
+        musl = isMuslFromFilesystem();
+        if (musl === null) {
+            musl = isMuslFromReport();
+        }
+        if (musl === null) {
+            musl = isMuslFromChildProcess();
+        }
+    }
+    return musl;
+};
+const isFileMusl = (f) => f.includes('libc.musl-') || f.includes('ld-musl-');
+const isMuslFromFilesystem = () => {
+    try {
+        return readFileSync('/usr/bin/ldd', 'utf-8').includes('musl');
+    }
+    catch (_a) {
+        return null;
+    }
+};
+const isMuslFromReport = () => {
+    const report = typeof process.report.getReport === 'function' ? process.report.getReport() : null;
+    if (!report) {
+        return null;
+    }
+    if (report.header && report.header.glibcVersionRuntime) {
+        return false;
+    }
+    if (Array.isArray(report.sharedObjects)) {
+        if (report.sharedObjects.some(isFileMusl)) {
+            return true;
+        }
+    }
     return false;
-  return ((typeof window !== 'undefined') && (typeof XMLHttpRequest === 'function') && !(window.require && window.module && window.process && window.process.type === "renderer"));
-}
-
-function hasGlobalProcessEventEmitter() {
-  return ((typeof process === 'object') && (process !== null) && (typeof process.on === 'function'));
-}
-
-function globalProcessVersion() {
-  if ((typeof process === 'object') && (process !== null)) {
-    return process.version;
-  } else {
-    return '';
-  }
-}
-
-function globalProcessStderr() {
-  if ((typeof process === 'object') && (process !== null)) {
-    return process.stderr;
-  }
-}
-
-function globalProcessExit(code) {
-  if ((typeof process === 'object') && (process !== null) && (typeof process.exit === 'function')) {
-    return process.exit(code);
-  }
-}
-
-function handlerExec(list) {
-  return function(arg) {
-    for (var i = 0; i < list.length; i++) {
-      var ret = list[i](arg);
-      if (ret) {
-        return ret;
-      }
+};
+const isMuslFromChildProcess = () => {
+    try {
+        return (__nccwpck_require__(32081).execSync)('ldd --version', { encoding: 'utf8' }).includes('musl');
     }
-    return null;
-  };
+    catch (e) {
+        // If we reach this case, we don't know if the system is musl or not, so is better to just fallback to false
+        return false;
+    }
+};
+switch (platform) {
+    case 'android':
+        switch (arch) {
+            case 'arm64':
+                localFileExisted = existsSync(join(__dirname, 'swc.android-arm64.node'));
+                try {
+                    if (localFileExisted) {
+                        nativeBinding = __nccwpck_require__(27607);
+                    }
+                    else {
+                        nativeBinding = __nccwpck_require__(73543);
+                    }
+                }
+                catch (e) {
+                    loadError = e;
+                }
+                break;
+            case 'arm':
+                localFileExisted = existsSync(join(__dirname, 'swc.android-arm-eabi.node'));
+                try {
+                    if (localFileExisted) {
+                        nativeBinding = __nccwpck_require__(84384);
+                    }
+                    else {
+                        nativeBinding = __nccwpck_require__(86670);
+                    }
+                }
+                catch (e) {
+                    loadError = e;
+                }
+                break;
+            default:
+                throw new Error(`Unsupported architecture on Android ${arch}`);
+        }
+        break;
+    case 'win32':
+        switch (arch) {
+            case 'x64':
+                localFileExisted = existsSync(join(__dirname, 'swc.win32-x64-msvc.node'));
+                try {
+                    if (localFileExisted) {
+                        nativeBinding = __nccwpck_require__(48865);
+                    }
+                    else {
+                        nativeBinding = __nccwpck_require__(66995);
+                    }
+                }
+                catch (e) {
+                    loadError = e;
+                }
+                break;
+            case 'ia32':
+                localFileExisted = existsSync(join(__dirname, 'swc.win32-ia32-msvc.node'));
+                try {
+                    if (localFileExisted) {
+                        nativeBinding = __nccwpck_require__(56637);
+                    }
+                    else {
+                        nativeBinding = __nccwpck_require__(46924);
+                    }
+                }
+                catch (e) {
+                    loadError = e;
+                }
+                break;
+            case 'arm64':
+                localFileExisted = existsSync(join(__dirname, 'swc.win32-arm64-msvc.node'));
+                try {
+                    if (localFileExisted) {
+                        nativeBinding = __nccwpck_require__(42395);
+                    }
+                    else {
+                        nativeBinding = __nccwpck_require__(7470);
+                    }
+                }
+                catch (e) {
+                    loadError = e;
+                }
+                break;
+            default:
+                throw new Error(`Unsupported architecture on Windows: ${arch}`);
+        }
+        break;
+    case 'darwin':
+        localFileExisted = existsSync(join(__dirname, 'swc.darwin-universal.node'));
+        try {
+            if (localFileExisted) {
+                nativeBinding = __nccwpck_require__(29232);
+            }
+            else {
+                nativeBinding = __nccwpck_require__(66749);
+            }
+            break;
+        }
+        catch (_a) { }
+        switch (arch) {
+            case 'x64':
+                localFileExisted = existsSync(join(__dirname, 'swc.darwin-x64.node'));
+                try {
+                    if (localFileExisted) {
+                        nativeBinding = __nccwpck_require__(71110);
+                    }
+                    else {
+                        nativeBinding = __nccwpck_require__(62659);
+                    }
+                }
+                catch (e) {
+                    loadError = e;
+                }
+                break;
+            case 'arm64':
+                localFileExisted = existsSync(join(__dirname, 'swc.darwin-arm64.node'));
+                try {
+                    if (localFileExisted) {
+                        nativeBinding = __nccwpck_require__(23827);
+                    }
+                    else {
+                        nativeBinding = __nccwpck_require__(67754);
+                    }
+                }
+                catch (e) {
+                    loadError = e;
+                }
+                break;
+            default:
+                throw new Error(`Unsupported architecture on macOS: ${arch}`);
+        }
+        break;
+    case 'freebsd':
+        if (arch !== 'x64') {
+            throw new Error(`Unsupported architecture on FreeBSD: ${arch}`);
+        }
+        localFileExisted = existsSync(join(__dirname, 'swc.freebsd-x64.node'));
+        try {
+            if (localFileExisted) {
+                nativeBinding = __nccwpck_require__(96182);
+            }
+            else {
+                nativeBinding = __nccwpck_require__(26640);
+            }
+        }
+        catch (e) {
+            loadError = e;
+        }
+        break;
+    case 'linux':
+        switch (arch) {
+            case 'x64':
+                if (isMusl()) {
+                    localFileExisted = existsSync(join(__dirname, 'swc.linux-x64-musl.node'));
+                    try {
+                        if (localFileExisted) {
+                            nativeBinding = __nccwpck_require__(76885);
+                        }
+                        else {
+                            nativeBinding = __nccwpck_require__(27110);
+                        }
+                    }
+                    catch (e) {
+                        loadError = e;
+                    }
+                }
+                else {
+                    localFileExisted = existsSync(join(__dirname, 'swc.linux-x64-gnu.node'));
+                    try {
+                        if (localFileExisted) {
+                            nativeBinding = __nccwpck_require__(93305);
+                        }
+                        else {
+                            nativeBinding = __nccwpck_require__(69653);
+                        }
+                    }
+                    catch (e) {
+                        loadError = e;
+                    }
+                }
+                break;
+            case 'arm64':
+                if (isMusl()) {
+                    localFileExisted = existsSync(join(__dirname, 'swc.linux-arm64-musl.node'));
+                    try {
+                        if (localFileExisted) {
+                            nativeBinding = __nccwpck_require__(52614);
+                        }
+                        else {
+                            nativeBinding = __nccwpck_require__(93346);
+                        }
+                    }
+                    catch (e) {
+                        loadError = e;
+                    }
+                }
+                else {
+                    localFileExisted = existsSync(join(__dirname, 'swc.linux-arm64-gnu.node'));
+                    try {
+                        if (localFileExisted) {
+                            nativeBinding = __nccwpck_require__(7458);
+                        }
+                        else {
+                            nativeBinding = __nccwpck_require__(13520);
+                        }
+                    }
+                    catch (e) {
+                        loadError = e;
+                    }
+                }
+                break;
+            case 'arm':
+                localFileExisted = existsSync(join(__dirname, 'swc.linux-arm-gnueabihf.node'));
+                try {
+                    if (localFileExisted) {
+                        nativeBinding = __nccwpck_require__(10645);
+                    }
+                    else {
+                        nativeBinding = __nccwpck_require__(19505);
+                    }
+                }
+                catch (e) {
+                    loadError = e;
+                }
+                break;
+            case 'riscv64':
+                if (isMusl()) {
+                    localFileExisted = existsSync(join(__dirname, 'swc.linux-riscv64-musl.node'));
+                    try {
+                        if (localFileExisted) {
+                            nativeBinding = __nccwpck_require__(899);
+                        }
+                        else {
+                            nativeBinding = __nccwpck_require__(81873);
+                        }
+                    }
+                    catch (e) {
+                        loadError = e;
+                    }
+                }
+                else {
+                    localFileExisted = existsSync(join(__dirname, 'swc.linux-riscv64-gnu.node'));
+                    try {
+                        if (localFileExisted) {
+                            nativeBinding = __nccwpck_require__(79306);
+                        }
+                        else {
+                            nativeBinding = __nccwpck_require__(32636);
+                        }
+                    }
+                    catch (e) {
+                        loadError = e;
+                    }
+                }
+                break;
+            default:
+                throw new Error(`Unsupported architecture on Linux: ${arch}`);
+        }
+        break;
+    default:
+        throw new Error(`Unsupported OS: ${platform}, architecture: ${arch}`);
 }
-
-var retrieveFile = handlerExec(retrieveFileHandlers);
-
-retrieveFileHandlers.push(function(path) {
-  // Trim the path to make sure there is no extra whitespace.
-  path = path.trim();
-  if (/^file:/.test(path)) {
-    // existsSync/readFileSync can't handle file protocol, but once stripped, it works
-    path = path.replace(/file:\/\/\/(\w:)?/, function(protocol, drive) {
-      return drive ?
-        '' : // file:///C:/dir/file -> C:/dir/file
-        '/'; // file:///root-dir/file -> /root-dir/file
-    });
-  }
-  if (path in fileContentsCache) {
-    return fileContentsCache[path];
-  }
-
-  var contents = '';
-  try {
-    if (!fs) {
-      // Use SJAX if we are in the browser
-      var xhr = new XMLHttpRequest();
-      xhr.open('GET', path, /** async */ false);
-      xhr.send(null);
-      if (xhr.readyState === 4 && xhr.status === 200) {
-        contents = xhr.responseText;
-      }
-    } else if (fs.existsSync(path)) {
-      // Otherwise, use the filesystem
-      contents = fs.readFileSync(path, 'utf8');
+if (!nativeBinding) {
+    if (loadError) {
+        throw loadError;
     }
-  } catch (er) {
-    /* ignore any errors */
-  }
-
-  return fileContentsCache[path] = contents;
-});
-
-// Support URLs relative to a directory, but be careful about a protocol prefix
-// in case we are in the browser (i.e. directories may start with "http://" or "file:///")
-function supportRelativeURL(file, url) {
-  if (!file) return url;
-  var dir = path.dirname(file);
-  var match = /^\w+:\/\/[^\/]*/.exec(dir);
-  var protocol = match ? match[0] : '';
-  var startPath = dir.slice(protocol.length);
-  if (protocol && /^\/\w\:/.test(startPath)) {
-    // handle file:///C:/ paths
-    protocol += '/';
-    return protocol + path.resolve(dir.slice(protocol.length), url).replace(/\\/g, '/');
-  }
-  return protocol + path.resolve(dir.slice(protocol.length), url);
+    throw new Error(`Failed to load native binding`);
 }
+module.exports.Compiler = nativeBinding.Compiler;
+module.exports.JsCompiler = nativeBinding.JsCompiler;
+module.exports.bundle = nativeBinding.bundle;
+module.exports.getTargetTriple = nativeBinding.getTargetTriple;
+module.exports.initCustomTraceSubscriber = nativeBinding.initCustomTraceSubscriber;
+module.exports.minify = nativeBinding.minify;
+module.exports.minifySync = nativeBinding.minifySync;
+module.exports.parse = nativeBinding.parse;
+module.exports.parseFile = nativeBinding.parseFile;
+module.exports.parseFileSync = nativeBinding.parseFileSync;
+module.exports.parseSync = nativeBinding.parseSync;
+module.exports.print = nativeBinding.print;
+module.exports.printSync = nativeBinding.printSync;
+module.exports.transform = nativeBinding.transform;
+module.exports.transformFile = nativeBinding.transformFile;
+module.exports.transformFileSync = nativeBinding.transformFileSync;
+module.exports.transformSync = nativeBinding.transformSync;
 
-function retrieveSourceMapURL(source) {
-  var fileData;
-
-  if (isInBrowser()) {
-     try {
-       var xhr = new XMLHttpRequest();
-       xhr.open('GET', source, false);
-       xhr.send(null);
-       fileData = xhr.readyState === 4 ? xhr.responseText : null;
-
-       // Support providing a sourceMappingURL via the SourceMap header
-       var sourceMapHeader = xhr.getResponseHeader("SourceMap") ||
-                             xhr.getResponseHeader("X-SourceMap");
-       if (sourceMapHeader) {
-         return sourceMapHeader;
-       }
-     } catch (e) {
-     }
-  }
-
-  // Get the URL of the source map
-  fileData = retrieveFile(source);
-  var re = /(?:\/\/[@#][\s]*sourceMappingURL=([^\s'"]+)[\s]*$)|(?:\/\*[@#][\s]*sourceMappingURL=([^\s*'"]+)[\s]*(?:\*\/)[\s]*$)/mg;
-  // Keep executing the search to find the *last* sourceMappingURL to avoid
-  // picking up sourceMappingURLs from comments, strings, etc.
-  var lastMatch, match;
-  while (match = re.exec(fileData)) lastMatch = match;
-  if (!lastMatch) return null;
-  return lastMatch[1];
-};
 
-// Can be overridden by the retrieveSourceMap option to install. Takes a
-// generated source filename; returns a {map, optional url} object, or null if
-// there is no source map.  The map field may be either a string or the parsed
-// JSON object (ie, it must be a valid argument to the SourceMapConsumer
-// constructor).
-var retrieveSourceMap = handlerExec(retrieveMapHandlers);
-retrieveMapHandlers.push(function(source) {
-  var sourceMappingURL = retrieveSourceMapURL(source);
-  if (!sourceMappingURL) return null;
+/***/ }),
 
-  // Read the contents of the source map
-  var sourceMapData;
-  if (reSourceMap.test(sourceMappingURL)) {
-    // Support source map URL as a data url
-    var rawData = sourceMappingURL.slice(sourceMappingURL.indexOf(',') + 1);
-    sourceMapData = bufferFrom(rawData, "base64").toString();
-    sourceMappingURL = source;
-  } else {
-    // Support source map URLs relative to the source URL
-    sourceMappingURL = supportRelativeURL(source, sourceMappingURL);
-    sourceMapData = retrieveFile(sourceMappingURL);
-  }
+/***/ 65142:
+/***/ (function(__unused_webpack_module, exports, __nccwpck_require__) {
 
-  if (!sourceMapData) {
-    return null;
-  }
+"use strict";
 
-  return {
-    url: sourceMappingURL,
-    map: sourceMapData
-  };
+var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
+    if (k2 === undefined) k2 = k;
+    var desc = Object.getOwnPropertyDescriptor(m, k);
+    if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
+      desc = { enumerable: true, get: function() { return m[k]; } };
+    }
+    Object.defineProperty(o, k2, desc);
+}) : (function(o, m, k, k2) {
+    if (k2 === undefined) k2 = k;
+    o[k2] = m[k];
+}));
+var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
+    Object.defineProperty(o, "default", { enumerable: true, value: v });
+}) : function(o, v) {
+    o["default"] = v;
 });
-
-function mapSourcePosition(position) {
-  var sourceMap = sourceMapCache[position.source];
-  if (!sourceMap) {
-    // Call the (overrideable) retrieveSourceMap function to get the source map.
-    var urlAndMap = retrieveSourceMap(position.source);
-    if (urlAndMap) {
-      sourceMap = sourceMapCache[position.source] = {
-        url: urlAndMap.url,
-        map: new SourceMapConsumer(urlAndMap.map)
-      };
-
-      // Load all sources stored inline with the source map into the file cache
-      // to pretend like they are already loaded. They may not exist on disk.
-      if (sourceMap.map.sourcesContent) {
-        sourceMap.map.sources.forEach(function(source, i) {
-          var contents = sourceMap.map.sourcesContent[i];
-          if (contents) {
-            var url = supportRelativeURL(sourceMap.url, source);
-            fileContentsCache[url] = contents;
-          }
-        });
-      }
-    } else {
-      sourceMap = sourceMapCache[position.source] = {
-        url: null,
-        map: null
-      };
+var __exportStar = (this && this.__exportStar) || function(m, exports) {
+    for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
+};
+var __importStar = (this && this.__importStar) || function (mod) {
+    if (mod && mod.__esModule) return mod;
+    var result = {};
+    if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
+    __setModuleDefault(result, mod);
+    return result;
+};
+var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
+    function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
+    return new (P || (P = Promise))(function (resolve, reject) {
+        function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
+        function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
+        function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
+        step((generator = generator.apply(thisArg, _arguments || [])).next());
+    });
+};
+var __rest = (this && this.__rest) || function (s, e) {
+    var t = {};
+    for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
+        t[p] = s[p];
+    if (s != null && typeof Object.getOwnPropertySymbols === "function")
+        for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
+            if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
+                t[p[i]] = s[p[i]];
+        }
+    return t;
+};
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.DEFAULT_EXTENSIONS = exports.getBinaryMetadata = exports.__experimental_registerGlobalTraceConfig = exports.minifySync = exports.minify = exports.bundle = exports.transformFileSync = exports.transformFile = exports.transformSync = exports.transform = exports.printSync = exports.print = exports.parseFileSync = exports.parseFile = exports.parseSync = exports.parse = exports.Compiler = exports.plugins = exports.version = void 0;
+const path_1 = __nccwpck_require__(71017);
+__exportStar(__nccwpck_require__(71992), exports);
+const spack_1 = __nccwpck_require__(82357);
+const assert = __importStar(__nccwpck_require__(39491));
+// Allow overrides to the location of the .node binding file
+const bindingsOverride = process.env["SWC_BINARY_PATH"];
+// `@swc/core` includes d.ts for the `@swc/wasm` to provide typed fallback bindings
+// todo: fix package.json scripts
+let fallbackBindings;
+const bindings = (() => {
+    let binding;
+    try {
+        binding = !!bindingsOverride ? require((0, path_1.resolve)(bindingsOverride)) : __nccwpck_require__(24279);
+        // If native binding loaded successfully, it should return proper target triple constant.
+        const triple = binding.getTargetTriple();
+        assert.ok(triple, 'Failed to read target triple from native binary.');
+        return binding;
     }
-  }
-
-  // Resolve the source URL relative to the URL of the source map
-  if (sourceMap && sourceMap.map && typeof sourceMap.map.originalPositionFor === 'function') {
-    var originalPosition = sourceMap.map.originalPositionFor(position);
-
-    // Only return the original position if a matching line was found. If no
-    // matching line is found then we return position instead, which will cause
-    // the stack trace to print the path and line for the compiled file. It is
-    // better to give a precise location in the compiled file than a vague
-    // location in the original file.
-    if (originalPosition.source !== null) {
-      originalPosition.source = supportRelativeURL(
-        sourceMap.url, originalPosition.source);
-      return originalPosition;
+    catch (_) {
+        // postinstall supposed to install `@swc/wasm` already
+        fallbackBindings = __nccwpck_require__(7343);
     }
-  }
-
-  return position;
-}
-
-// Parses code generated by FormatEvalOrigin(), a function inside V8:
-// https://code.google.com/p/v8/source/browse/trunk/src/messages.js
-function mapEvalOrigin(origin) {
-  // Most eval() calls are in this format
-  var match = /^eval at ([^(]+) \((.+):(\d+):(\d+)\)$/.exec(origin);
-  if (match) {
-    var position = mapSourcePosition({
-      source: match[2],
-      line: +match[3],
-      column: match[4] - 1
-    });
-    return 'eval at ' + match[1] + ' (' + position.source + ':' +
-      position.line + ':' + (position.column + 1) + ')';
-  }
-
-  // Parse nested eval() calls using recursion
-  match = /^eval at ([^(]+) \((.+)\)$/.exec(origin);
-  if (match) {
-    return 'eval at ' + match[1] + ' (' + mapEvalOrigin(match[2]) + ')';
-  }
-
-  // Make sure we still return useful information if we didn't find anything
-  return origin;
-}
-
-// This is copied almost verbatim from the V8 source code at
-// https://code.google.com/p/v8/source/browse/trunk/src/messages.js. The
-// implementation of wrapCallSite() used to just forward to the actual source
-// code of CallSite.prototype.toString but unfortunately a new release of V8
-// did something to the prototype chain and broke the shim. The only fix I
-// could find was copy/paste.
-function CallSiteToString() {
-  var fileName;
-  var fileLocation = "";
-  if (this.isNative()) {
-    fileLocation = "native";
-  } else {
-    fileName = this.getScriptNameOrSourceURL();
-    if (!fileName && this.isEval()) {
-      fileLocation = this.getEvalOrigin();
-      fileLocation += ", ";  // Expecting source position to follow.
-    }
-
-    if (fileName) {
-      fileLocation += fileName;
-    } else {
-      // Source code does not originate from a file and is not native, but we
-      // can still get the source position inside the source string, e.g. in
-      // an eval string.
-      fileLocation += "";
-    }
-    var lineNumber = this.getLineNumber();
-    if (lineNumber != null) {
-      fileLocation += ":" + lineNumber;
-      var columnNumber = this.getColumnNumber();
-      if (columnNumber) {
-        fileLocation += ":" + columnNumber;
-      }
-    }
-  }
-
-  var line = "";
-  var functionName = this.getFunctionName();
-  var addSuffix = true;
-  var isConstructor = this.isConstructor();
-  var isMethodCall = !(this.isToplevel() || isConstructor);
-  if (isMethodCall) {
-    var typeName = this.getTypeName();
-    // Fixes shim to be backward compatable with Node v0 to v4
-    if (typeName === "[object Object]") {
-      typeName = "null";
-    }
-    var methodName = this.getMethodName();
-    if (functionName) {
-      if (typeName && functionName.indexOf(typeName) != 0) {
-        line += typeName + ".";
-      }
-      line += functionName;
-      if (methodName && functionName.indexOf("." + methodName) != functionName.length - methodName.length - 1) {
-        line += " [as " + methodName + "]";
-      }
-    } else {
-      line += typeName + "." + (methodName || "");
-    }
-  } else if (isConstructor) {
-    line += "new " + (functionName || "");
-  } else if (functionName) {
-    line += functionName;
-  } else {
-    line += fileLocation;
-    addSuffix = false;
-  }
-  if (addSuffix) {
-    line += " (" + fileLocation + ")";
-  }
-  return line;
-}
-
-function cloneCallSite(frame) {
-  var object = {};
-  Object.getOwnPropertyNames(Object.getPrototypeOf(frame)).forEach(function(name) {
-    object[name] = /^(?:is|get)/.test(name) ? function() { return frame[name].call(frame); } : frame[name];
-  });
-  object.toString = CallSiteToString;
-  return object;
-}
-
-function wrapCallSite(frame, state) {
-  // provides interface backward compatibility
-  if (state === undefined) {
-    state = { nextPosition: null, curPosition: null }
-  }
-  if(frame.isNative()) {
-    state.curPosition = null;
-    return frame;
-  }
-
-  // Most call sites will return the source file from getFileName(), but code
-  // passed to eval() ending in "//# sourceURL=..." will return the source file
-  // from getScriptNameOrSourceURL() instead
-  var source = frame.getFileName() || frame.getScriptNameOrSourceURL();
-  if (source) {
-    var line = frame.getLineNumber();
-    var column = frame.getColumnNumber() - 1;
-
-    // Fix position in Node where some (internal) code is prepended.
-    // See https://github.com/evanw/node-source-map-support/issues/36
-    // Header removed in node at ^10.16 || >=11.11.0
-    // v11 is not an LTS candidate, we can just test the one version with it.
-    // Test node versions for: 10.16-19, 10.20+, 12-19, 20-99, 100+, or 11.11
-    var noHeader = /^v(10\.1[6-9]|10\.[2-9][0-9]|10\.[0-9]{3,}|1[2-9]\d*|[2-9]\d|\d{3,}|11\.11)/;
-    var headerLength = noHeader.test(globalProcessVersion()) ? 0 : 62;
-    if (line === 1 && column > headerLength && !isInBrowser() && !frame.isEval()) {
-      column -= headerLength;
-    }
-
-    var position = mapSourcePosition({
-      source: source,
-      line: line,
-      column: column
-    });
-    state.curPosition = position;
-    frame = cloneCallSite(frame);
-    var originalFunctionName = frame.getFunctionName;
-    frame.getFunctionName = function() {
-      if (state.nextPosition == null) {
-        return originalFunctionName();
-      }
-      return state.nextPosition.name || originalFunctionName();
-    };
-    frame.getFileName = function() { return position.source; };
-    frame.getLineNumber = function() { return position.line; };
-    frame.getColumnNumber = function() { return position.column + 1; };
-    frame.getScriptNameOrSourceURL = function() { return position.source; };
-    return frame;
-  }
-
-  // Code called using eval() needs special handling
-  var origin = frame.isEval() && frame.getEvalOrigin();
-  if (origin) {
-    origin = mapEvalOrigin(origin);
-    frame = cloneCallSite(frame);
-    frame.getEvalOrigin = function() { return origin; };
-    return frame;
-  }
-
-  // If we get here then we were unable to change the source position
-  return frame;
-}
-
-// This function is part of the V8 stack trace API, for more info see:
-// https://v8.dev/docs/stack-trace-api
-function prepareStackTrace(error, stack) {
-  if (emptyCacheBetweenOperations) {
-    fileContentsCache = {};
-    sourceMapCache = {};
-  }
-
-  var name = error.name || 'Error';
-  var message = error.message || '';
-  var errorString = name + ": " + message;
-
-  var state = { nextPosition: null, curPosition: null };
-  var processedStack = [];
-  for (var i = stack.length - 1; i >= 0; i--) {
-    processedStack.push('\n    at ' + wrapCallSite(stack[i], state));
-    state.nextPosition = state.curPosition;
-  }
-  state.curPosition = state.nextPosition = null;
-  return errorString + processedStack.reverse().join('');
-}
-
-// Generate position and snippet of original source with pointer
-function getErrorSource(error) {
-  var match = /\n    at [^(]+ \((.*):(\d+):(\d+)\)/.exec(error.stack);
-  if (match) {
-    var source = match[1];
-    var line = +match[2];
-    var column = +match[3];
-
-    // Support the inline sourceContents inside the source map
-    var contents = fileContentsCache[source];
-
-    // Support files on disk
-    if (!contents && fs && fs.existsSync(source)) {
-      try {
-        contents = fs.readFileSync(source, 'utf8');
-      } catch (er) {
-        contents = '';
-      }
-    }
-
-    // Format the line from the original source code like node does
-    if (contents) {
-      var code = contents.split(/(?:\r\n|\r|\n)/)[line - 1];
-      if (code) {
-        return source + ':' + line + '\n' + code + '\n' +
-          new Array(column).join(' ') + '^';
-      }
-    }
-  }
-  return null;
-}
-
-function printErrorAndExit (error) {
-  var source = getErrorSource(error);
-
-  // Ensure error is printed synchronously and not truncated
-  var stderr = globalProcessStderr();
-  if (stderr && stderr._handle && stderr._handle.setBlocking) {
-    stderr._handle.setBlocking(true);
-  }
-
-  if (source) {
-    console.error();
-    console.error(source);
-  }
-
-  console.error(error.stack);
-  globalProcessExit(1);
-}
-
-function shimEmitUncaughtException () {
-  var origEmit = process.emit;
-
-  process.emit = function (type) {
-    if (type === 'uncaughtException') {
-      var hasStack = (arguments[1] && arguments[1].stack);
-      var hasListeners = (this.listeners(type).length > 0);
-
-      if (hasStack && !hasListeners) {
-        return printErrorAndExit(arguments[1]);
-      }
-    }
-
-    return origEmit.apply(this, arguments);
-  };
-}
-
-var originalRetrieveFileHandlers = retrieveFileHandlers.slice(0);
-var originalRetrieveMapHandlers = retrieveMapHandlers.slice(0);
-
-exports.wrapCallSite = wrapCallSite;
-exports.getErrorSource = getErrorSource;
-exports.mapSourcePosition = mapSourcePosition;
-exports.retrieveSourceMap = retrieveSourceMap;
-
-exports.install = function(options) {
-  options = options || {};
-
-  if (options.environment) {
-    environment = options.environment;
-    if (["node", "browser", "auto"].indexOf(environment) === -1) {
-      throw new Error("environment " + environment + " was unknown. Available options are {auto, browser, node}")
-    }
-  }
-
-  // Allow sources to be found by methods other than reading the files
-  // directly from disk.
-  if (options.retrieveFile) {
-    if (options.overrideRetrieveFile) {
-      retrieveFileHandlers.length = 0;
-    }
-
-    retrieveFileHandlers.unshift(options.retrieveFile);
-  }
-
-  // Allow source maps to be found by methods other than reading the files
-  // directly from disk.
-  if (options.retrieveSourceMap) {
-    if (options.overrideRetrieveSourceMap) {
-      retrieveMapHandlers.length = 0;
-    }
-
-    retrieveMapHandlers.unshift(options.retrieveSourceMap);
-  }
-
-  // Support runtime transpilers that include inline source maps
-  if (options.hookRequire && !isInBrowser()) {
-    // Use dynamicRequire to avoid including in browser bundles
-    var Module = dynamicRequire(module, 'module');
-    var $compile = Module.prototype._compile;
-
-    if (!$compile.__sourceMapSupport) {
-      Module.prototype._compile = function(content, filename) {
-        fileContentsCache[filename] = content;
-        sourceMapCache[filename] = undefined;
-        return $compile.call(this, content, filename);
-      };
-
-      Module.prototype._compile.__sourceMapSupport = true;
-    }
-  }
-
-  // Configure options
-  if (!emptyCacheBetweenOperations) {
-    emptyCacheBetweenOperations = 'emptyCacheBetweenOperations' in options ?
-      options.emptyCacheBetweenOperations : false;
-  }
-
-  // Install the error reformatter
-  if (!errorFormatterInstalled) {
-    errorFormatterInstalled = true;
-    Error.prepareStackTrace = prepareStackTrace;
-  }
-
-  if (!uncaughtShimInstalled) {
-    var installHandler = 'handleUncaughtExceptions' in options ?
-      options.handleUncaughtExceptions : true;
-
-    // Do not override 'uncaughtException' with our own handler in Node.js
-    // Worker threads. Workers pass the error to the main thread as an event,
-    // rather than printing something to stderr and exiting.
-    try {
-      // We need to use `dynamicRequire` because `require` on it's own will be optimized by WebPack/Browserify.
-      var worker_threads = dynamicRequire(module, 'worker_threads');
-      if (worker_threads.isMainThread === false) {
-        installHandler = false;
-      }
-    } catch(e) {}
-
-    // Provide the option to not install the uncaught exception handler. This is
-    // to support other uncaught exception handlers (in test frameworks, for
-    // example). If this handler is not installed and there are no other uncaught
-    // exception handlers, uncaught exceptions will be caught by node's built-in
-    // exception handler and the process will still be terminated. However, the
-    // generated JavaScript code will be shown above the stack trace instead of
-    // the original source code.
-    if (installHandler && hasGlobalProcessEventEmitter()) {
-      uncaughtShimInstalled = true;
-      shimEmitUncaughtException();
-    }
-  }
-};
-
-exports.resetRetrieveHandlers = function() {
-  retrieveFileHandlers.length = 0;
-  retrieveMapHandlers.length = 0;
-
-  retrieveFileHandlers = originalRetrieveFileHandlers.slice(0);
-  retrieveMapHandlers = originalRetrieveMapHandlers.slice(0);
-
-  retrieveSourceMap = handlerExec(retrieveMapHandlers);
-  retrieveFile = handlerExec(retrieveFileHandlers);
-}
-
-
-/***/ }),
-
-/***/ 89484:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
-
-"use strict";
-
-const { existsSync, readFileSync } = __nccwpck_require__(57147);
-const { join } = __nccwpck_require__(71017);
-const { platform, arch } = process;
-let nativeBinding = null;
-let localFileExisted = false;
-let loadError = null;
-function isMusl() {
-    // For Node 10
-    if (!process.report || typeof process.report.getReport !== 'function') {
-        try {
-            const lddPath = (__nccwpck_require__(32081).execSync)('which ldd').toString().trim();
-            return readFileSync(lddPath, 'utf8').includes('musl');
-        }
-        catch (e) {
-            return true;
-        }
-    }
-    else {
-        const { glibcVersionRuntime } = process.report.getReport().header;
-        return !glibcVersionRuntime;
-    }
-}
-switch (platform) {
-    case 'android':
-        switch (arch) {
-            case 'arm64':
-                localFileExisted = existsSync(join(__dirname, 'swc.android-arm64.node'));
-                try {
-                    if (localFileExisted) {
-                        nativeBinding = __nccwpck_require__(10849);
-                    }
-                    else {
-                        nativeBinding = __nccwpck_require__(95833);
-                    }
-                }
-                catch (e) {
-                    loadError = e;
-                }
-                break;
-            case 'arm':
-                localFileExisted = existsSync(join(__dirname, 'swc.android-arm-eabi.node'));
-                try {
-                    if (localFileExisted) {
-                        nativeBinding = __nccwpck_require__(70243);
-                    }
-                    else {
-                        nativeBinding = __nccwpck_require__(39423);
-                    }
-                }
-                catch (e) {
-                    loadError = e;
-                }
-                break;
-            default:
-                throw new Error(`Unsupported architecture on Android ${arch}`);
-        }
-        break;
-    case 'win32':
-        switch (arch) {
-            case 'x64':
-                localFileExisted = existsSync(join(__dirname, 'swc.win32-x64-msvc.node'));
-                try {
-                    if (localFileExisted) {
-                        nativeBinding = __nccwpck_require__(1779);
-                    }
-                    else {
-                        nativeBinding = __nccwpck_require__(20250);
-                    }
-                }
-                catch (e) {
-                    loadError = e;
-                }
-                break;
-            case 'ia32':
-                localFileExisted = existsSync(join(__dirname, 'swc.win32-ia32-msvc.node'));
-                try {
-                    if (localFileExisted) {
-                        nativeBinding = __nccwpck_require__(12445);
-                    }
-                    else {
-                        nativeBinding = __nccwpck_require__(48333);
-                    }
-                }
-                catch (e) {
-                    loadError = e;
-                }
-                break;
-            case 'arm64':
-                localFileExisted = existsSync(join(__dirname, 'swc.win32-arm64-msvc.node'));
-                try {
-                    if (localFileExisted) {
-                        nativeBinding = __nccwpck_require__(91156);
-                    }
-                    else {
-                        nativeBinding = __nccwpck_require__(89962);
-                    }
-                }
-                catch (e) {
-                    loadError = e;
-                }
-                break;
-            default:
-                throw new Error(`Unsupported architecture on Windows: ${arch}`);
-        }
-        break;
-    case 'darwin':
-        switch (arch) {
-            case 'x64':
-                localFileExisted = existsSync(join(__dirname, 'swc.darwin-x64.node'));
-                try {
-                    if (localFileExisted) {
-                        nativeBinding = __nccwpck_require__(9172);
-                    }
-                    else {
-                        nativeBinding = __nccwpck_require__(5829);
-                    }
-                }
-                catch (e) {
-                    loadError = e;
-                }
-                break;
-            case 'arm64':
-                localFileExisted = existsSync(join(__dirname, 'swc.darwin-arm64.node'));
-                try {
-                    if (localFileExisted) {
-                        nativeBinding = __nccwpck_require__(37969);
-                    }
-                    else {
-                        nativeBinding = __nccwpck_require__(40679);
-                    }
-                }
-                catch (e) {
-                    loadError = e;
-                }
-                break;
-            default:
-                throw new Error(`Unsupported architecture on macOS: ${arch}`);
-        }
-        break;
-    case 'freebsd':
-        if (arch !== 'x64') {
-            throw new Error(`Unsupported architecture on FreeBSD: ${arch}`);
-        }
-        localFileExisted = existsSync(join(__dirname, 'swc.freebsd-x64.node'));
-        try {
-            if (localFileExisted) {
-                nativeBinding = __nccwpck_require__(71487);
-            }
-            else {
-                nativeBinding = __nccwpck_require__(95212);
-            }
-        }
-        catch (e) {
-            loadError = e;
-        }
-        break;
-    case 'linux':
-        switch (arch) {
-            case 'x64':
-                if (isMusl()) {
-                    localFileExisted = existsSync(join(__dirname, 'swc.linux-x64-musl.node'));
-                    try {
-                        if (localFileExisted) {
-                            nativeBinding = __nccwpck_require__(3394);
-                        }
-                        else {
-                            nativeBinding = __nccwpck_require__(35887);
-                        }
-                    }
-                    catch (e) {
-                        loadError = e;
-                    }
-                }
-                else {
-                    localFileExisted = existsSync(join(__dirname, 'swc.linux-x64-gnu.node'));
-                    try {
-                        if (localFileExisted) {
-                            nativeBinding = __nccwpck_require__(13546);
-                        }
-                        else {
-                            nativeBinding = __nccwpck_require__(47663);
-                        }
-                    }
-                    catch (e) {
-                        loadError = e;
-                    }
-                }
-                break;
-            case 'arm64':
-                if (isMusl()) {
-                    localFileExisted = existsSync(join(__dirname, 'swc.linux-arm64-musl.node'));
-                    try {
-                        if (localFileExisted) {
-                            nativeBinding = __nccwpck_require__(2168);
-                        }
-                        else {
-                            nativeBinding = __nccwpck_require__(79914);
-                        }
-                    }
-                    catch (e) {
-                        loadError = e;
-                    }
-                }
-                else {
-                    localFileExisted = existsSync(join(__dirname, 'swc.linux-arm64-gnu.node'));
-                    try {
-                        if (localFileExisted) {
-                            nativeBinding = __nccwpck_require__(37857);
-                        }
-                        else {
-                            nativeBinding = __nccwpck_require__(25670);
-                        }
-                    }
-                    catch (e) {
-                        loadError = e;
-                    }
-                }
-                break;
-            case 'arm':
-                localFileExisted = existsSync(join(__dirname, 'swc.linux-arm-gnueabihf.node'));
-                try {
-                    if (localFileExisted) {
-                        nativeBinding = __nccwpck_require__(21651);
-                    }
-                    else {
-                        nativeBinding = __nccwpck_require__(70593);
-                    }
-                }
-                catch (e) {
-                    loadError = e;
-                }
-                break;
-            default:
-                throw new Error(`Unsupported architecture on Linux: ${arch}`);
-        }
-        break;
-    default:
-        throw new Error(`Unsupported OS: ${platform}, architecture: ${arch}`);
-}
-if (!nativeBinding) {
-    if (loadError) {
-        throw loadError;
-    }
-    throw new Error(`Failed to load native binding`);
-}
-const { bundle, minify, minifySync, parse, parseSync, parseFileSync, parseFile, print, printSync, transform, transformSync, transformFile, transformFileSync, getTargetTriple, initCustomTraceSubscriber, Compiler } = nativeBinding;
-module.exports.bundle = bundle;
-module.exports.minify = minify;
-module.exports.minifySync = minifySync;
-module.exports.parse = parse;
-module.exports.parseSync = parseSync;
-module.exports.parseFileSync = parseFileSync;
-module.exports.parseFile = parseFile;
-module.exports.print = print;
-module.exports.printSync = printSync;
-module.exports.transform = transform;
-module.exports.transformSync = transformSync;
-module.exports.transformFile = transformFile;
-module.exports.transformFileSync = transformFileSync;
-module.exports.getTargetTriple = getTargetTriple;
-module.exports.initCustomTraceSubscriber = initCustomTraceSubscriber;
-module.exports.Compiler = Compiler;
-
-
-/***/ }),
-
-/***/ 76237:
-/***/ (function(__unused_webpack_module, exports, __nccwpck_require__) {
-
-"use strict";
-
-var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
-    if (k2 === undefined) k2 = k;
-    var desc = Object.getOwnPropertyDescriptor(m, k);
-    if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
-      desc = { enumerable: true, get: function() { return m[k]; } };
-    }
-    Object.defineProperty(o, k2, desc);
-}) : (function(o, m, k, k2) {
-    if (k2 === undefined) k2 = k;
-    o[k2] = m[k];
-}));
-var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
-    Object.defineProperty(o, "default", { enumerable: true, value: v });
-}) : function(o, v) {
-    o["default"] = v;
-});
-var __exportStar = (this && this.__exportStar) || function(m, exports) {
-    for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
-};
-var __importStar = (this && this.__importStar) || function (mod) {
-    if (mod && mod.__esModule) return mod;
-    var result = {};
-    if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
-    __setModuleDefault(result, mod);
-    return result;
-};
-var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
-    function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
-    return new (P || (P = Promise))(function (resolve, reject) {
-        function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
-        function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
-        function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
-        step((generator = generator.apply(thisArg, _arguments || [])).next());
-    });
-};
-var __rest = (this && this.__rest) || function (s, e) {
-    var t = {};
-    for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
-        t[p] = s[p];
-    if (s != null && typeof Object.getOwnPropertySymbols === "function")
-        for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
-            if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
-                t[p[i]] = s[p[i]];
-        }
-    return t;
-};
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.DEFAULT_EXTENSIONS = exports.getBinaryMetadata = exports.__experimental_registerGlobalTraceConfig = exports.minifySync = exports.minify = exports.bundle = exports.transformFileSync = exports.transformFile = exports.transformSync = exports.transform = exports.printSync = exports.print = exports.parseFileSync = exports.parseFile = exports.parseSync = exports.parse = exports.Compiler = exports.plugins = exports.version = void 0;
-const path_1 = __nccwpck_require__(71017);
-__exportStar(__nccwpck_require__(34222), exports);
-const spack_1 = __nccwpck_require__(58986);
-const assert = __importStar(__nccwpck_require__(39491));
-// Allow overrides to the location of the .node binding file
-const bindingsOverride = process.env["SWC_BINARY_PATH"];
-// `@swc/core` includes d.ts for the `@swc/wasm` to provide typed fallback bindings
-// todo: fix package.json scripts
-let fallbackBindings;
-const bindings = (() => {
-    let binding;
-    try {
-        binding = !!bindingsOverride ? require((0, path_1.resolve)(bindingsOverride)) : __nccwpck_require__(89484);
-        // If native binding loaded successfully, it should return proper target triple constant.
-        const triple = binding.getTargetTriple();
-        assert.ok(triple, 'Failed to read target triple from native binary.');
-        return binding;
-    }
-    catch (_) {
-        // postinstall supposed to install `@swc/wasm` already
-        fallbackBindings = __nccwpck_require__(80083);
-    }
-    finally {
-        return binding;
-    }
-})();
-/**
- * Version of the swc binding.
- */
-exports.version = __nccwpck_require__(21841).version;
-function plugins(ps) {
-    return mod => {
-        let m = mod;
-        for (const p of ps) {
-            m = p(m);
-        }
-        return m;
-    };
+    finally {
+        return binding;
+    }
+})();
+/**
+ * Version of the swc binding.
+ */
+exports.version = __nccwpck_require__(21841).version;
+/**
+ * @deprecated JavaScript API is deprecated. Please use Wasm plugin instead.
+ */
+function plugins(ps) {
+    return mod => {
+        let m = mod;
+        for (const p of ps) {
+            m = p(m);
+        }
+        return m;
+    };
 }
 exports.plugins = plugins;
 class Compiler {
@@ -6323,7 +4874,7 @@ function toBuffer(t) {
 
 /***/ }),
 
-/***/ 58986:
+/***/ 82357:
 /***/ (function(__unused_webpack_module, exports, __nccwpck_require__) {
 
 "use strict";
@@ -6416,7 +4967,7 @@ exports.config = config;
 
 /***/ }),
 
-/***/ 34222:
+/***/ 71992:
 /***/ ((__unused_webpack_module, exports) => {
 
 "use strict";
@@ -6426,7 +4977,7 @@ Object.defineProperty(exports, "__esModule", ({ value: true }));
 
 /***/ }),
 
-/***/ 82035:
+/***/ 4694:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 module.exports =
@@ -16705,7 +15256,7 @@ module.exports = process && support(supportLevel);
 
 /***/ }),
 
-/***/ 92378:
+/***/ 44301:
 /***/ ((module) => {
 
 "use strict";
@@ -17243,7 +15794,7 @@ module.exports = {
 
 /***/ }),
 
-/***/ 30505:
+/***/ 25704:
 /***/ ((module) => {
 
 "use strict";
@@ -20904,7 +19455,7 @@ module.exports = {
 
 /***/ }),
 
-/***/ 15748:
+/***/ 28111:
 /***/ ((module) => {
 
 "use strict";
@@ -22823,14 +21374,14 @@ module.exports = {
 
 /***/ }),
 
-/***/ 98006:
+/***/ 2877:
 /***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
 "use strict";
 
 Object.defineProperty(exports, "__esModule", ({ value: true }));
 exports.stringifySyml = exports.parseSyml = exports.stringifyResolution = exports.parseResolution = exports.stringifyValueArgument = exports.stringifyShellLine = exports.stringifyRedirectArgument = exports.stringifyEnvSegment = exports.stringifyCommandLineThen = exports.stringifyCommandLine = exports.stringifyCommandChainThen = exports.stringifyCommandChain = exports.stringifyCommand = exports.stringifyArithmeticExpression = exports.stringifyArgumentSegment = exports.stringifyArgument = exports.stringifyShell = exports.parseShell = void 0;
-var shell_1 = __nccwpck_require__(72216);
+var shell_1 = __nccwpck_require__(86546);
 Object.defineProperty(exports, "parseShell", ({ enumerable: true, get: function () { return shell_1.parseShell; } }));
 Object.defineProperty(exports, "stringifyShell", ({ enumerable: true, get: function () { return shell_1.stringifyShell; } }));
 Object.defineProperty(exports, "stringifyArgument", ({ enumerable: true, get: function () { return shell_1.stringifyArgument; } }));
@@ -22845,24 +21396,24 @@ Object.defineProperty(exports, "stringifyEnvSegment", ({ enumerable: true, get:
 Object.defineProperty(exports, "stringifyRedirectArgument", ({ enumerable: true, get: function () { return shell_1.stringifyRedirectArgument; } }));
 Object.defineProperty(exports, "stringifyShellLine", ({ enumerable: true, get: function () { return shell_1.stringifyShellLine; } }));
 Object.defineProperty(exports, "stringifyValueArgument", ({ enumerable: true, get: function () { return shell_1.stringifyValueArgument; } }));
-var resolution_1 = __nccwpck_require__(79591);
+var resolution_1 = __nccwpck_require__(31642);
 Object.defineProperty(exports, "parseResolution", ({ enumerable: true, get: function () { return resolution_1.parseResolution; } }));
 Object.defineProperty(exports, "stringifyResolution", ({ enumerable: true, get: function () { return resolution_1.stringifyResolution; } }));
-var syml_1 = __nccwpck_require__(42481);
+var syml_1 = __nccwpck_require__(2419);
 Object.defineProperty(exports, "parseSyml", ({ enumerable: true, get: function () { return syml_1.parseSyml; } }));
 Object.defineProperty(exports, "stringifySyml", ({ enumerable: true, get: function () { return syml_1.stringifySyml; } }));
 
 
 /***/ }),
 
-/***/ 79591:
+/***/ 31642:
 /***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
 "use strict";
 
 Object.defineProperty(exports, "__esModule", ({ value: true }));
 exports.stringifyResolution = exports.parseResolution = void 0;
-const resolution_1 = __nccwpck_require__(92378);
+const resolution_1 = __nccwpck_require__(44301);
 function parseResolution(source) {
     const legacyResolution = source.match(/^\*{1,2}\/(.*)/);
     if (legacyResolution)
@@ -22895,14 +21446,14 @@ exports.stringifyResolution = stringifyResolution;
 
 /***/ }),
 
-/***/ 72216:
+/***/ 86546:
 /***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
 "use strict";
 
 Object.defineProperty(exports, "__esModule", ({ value: true }));
 exports.stringifyShell = exports.stringifyArithmeticExpression = exports.stringifyArgumentSegment = exports.stringifyValueArgument = exports.stringifyRedirectArgument = exports.stringifyArgument = exports.stringifyEnvSegment = exports.stringifyCommand = exports.stringifyCommandChainThen = exports.stringifyCommandChain = exports.stringifyCommandLineThen = exports.stringifyCommandLine = exports.stringifyShellLine = exports.parseShell = void 0;
-const shell_1 = __nccwpck_require__(30505);
+const shell_1 = __nccwpck_require__(25704);
 function parseShell(source, options = { isGlobPattern: () => false }) {
     try {
         return (0, shell_1.parse)(source, options);
@@ -23051,15 +21602,15 @@ exports.stringifyArithmeticExpression = stringifyArithmeticExpression;
 
 /***/ }),
 
-/***/ 42481:
+/***/ 2419:
 /***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
 "use strict";
 
 Object.defineProperty(exports, "__esModule", ({ value: true }));
 exports.parseSyml = exports.stringifySyml = exports.PreserveOrdering = void 0;
-const js_yaml_1 = __nccwpck_require__(13469);
-const syml_1 = __nccwpck_require__(15748);
+const js_yaml_1 = __nccwpck_require__(49685);
+const syml_1 = __nccwpck_require__(28111);
 const simpleStringPattern = /^(?![-?:,\][{}#&*!|>'"%@` \t\r\n]).([ \t]*(?![,\][{}:# \t\r\n]).)*$/;
 // The following keys will always be stored at the top of the object, in the
 // specified order. It's not fair but life isn't fair either.
@@ -23191,14 +21742,14 @@ exports.parseSyml = parseSyml;
 
 /***/ }),
 
-/***/ 13469:
+/***/ 49685:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
 
 
 
-var yaml = __nccwpck_require__(87497);
+var yaml = __nccwpck_require__(87329);
 
 
 module.exports = yaml;
@@ -23206,15 +21757,15 @@ module.exports = yaml;
 
 /***/ }),
 
-/***/ 87497:
+/***/ 87329:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
 
 
 
-var loader = __nccwpck_require__(39463);
-var dumper = __nccwpck_require__(5500);
+var loader = __nccwpck_require__(88527);
+var dumper = __nccwpck_require__(21175);
 
 
 function deprecated(name) {
@@ -23224,25 +21775,25 @@ function deprecated(name) {
 }
 
 
-module.exports.Type = __nccwpck_require__(34592);
-module.exports.Schema = __nccwpck_require__(27731);
-module.exports.FAILSAFE_SCHEMA = __nccwpck_require__(45576);
-module.exports.JSON_SCHEMA = __nccwpck_require__(99482);
-module.exports.CORE_SCHEMA = __nccwpck_require__(89554);
-module.exports.DEFAULT_SAFE_SCHEMA = __nccwpck_require__(3012);
-module.exports.DEFAULT_FULL_SCHEMA = __nccwpck_require__(2726);
+module.exports.Type = __nccwpck_require__(58153);
+module.exports.Schema = __nccwpck_require__(76658);
+module.exports.FAILSAFE_SCHEMA = __nccwpck_require__(13589);
+module.exports.JSON_SCHEMA = __nccwpck_require__(67464);
+module.exports.CORE_SCHEMA = __nccwpck_require__(75447);
+module.exports.DEFAULT_SAFE_SCHEMA = __nccwpck_require__(30537);
+module.exports.DEFAULT_FULL_SCHEMA = __nccwpck_require__(88227);
 module.exports.load                = loader.load;
 module.exports.loadAll             = loader.loadAll;
 module.exports.safeLoad            = loader.safeLoad;
 module.exports.safeLoadAll         = loader.safeLoadAll;
 module.exports.dump                = dumper.dump;
 module.exports.safeDump            = dumper.safeDump;
-module.exports.YAMLException = __nccwpck_require__(28743);
+module.exports.YAMLException = __nccwpck_require__(12406);
 
 // Deprecated schema names from JS-YAML 2.0.x
-module.exports.MINIMAL_SCHEMA = __nccwpck_require__(45576);
-module.exports.SAFE_SCHEMA = __nccwpck_require__(3012);
-module.exports.DEFAULT_SCHEMA = __nccwpck_require__(2726);
+module.exports.MINIMAL_SCHEMA = __nccwpck_require__(13589);
+module.exports.SAFE_SCHEMA = __nccwpck_require__(30537);
+module.exports.DEFAULT_SCHEMA = __nccwpck_require__(88227);
 
 // Deprecated functions from JS-YAML 1.x.x
 module.exports.scan           = deprecated('scan');
@@ -23253,7 +21804,7 @@ module.exports.addConstructor = deprecated('addConstructor');
 
 /***/ }),
 
-/***/ 81108:
+/***/ 50062:
 /***/ ((module) => {
 
 "use strict";
@@ -23320,7 +21871,7 @@ module.exports.extend         = extend;
 
 /***/ }),
 
-/***/ 5500:
+/***/ 21175:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
@@ -23328,10 +21879,10 @@ module.exports.extend         = extend;
 
 /*eslint-disable no-use-before-define*/
 
-var common              = __nccwpck_require__(81108);
-var YAMLException       = __nccwpck_require__(28743);
-var DEFAULT_FULL_SCHEMA = __nccwpck_require__(2726);
-var DEFAULT_SAFE_SCHEMA = __nccwpck_require__(3012);
+var common              = __nccwpck_require__(50062);
+var YAMLException       = __nccwpck_require__(12406);
+var DEFAULT_FULL_SCHEMA = __nccwpck_require__(88227);
+var DEFAULT_SAFE_SCHEMA = __nccwpck_require__(30537);
 
 var _toString       = Object.prototype.toString;
 var _hasOwnProperty = Object.prototype.hasOwnProperty;
@@ -24178,7 +22729,7 @@ module.exports.safeDump = safeDump;
 
 /***/ }),
 
-/***/ 28743:
+/***/ 12406:
 /***/ ((module) => {
 
 "use strict";
@@ -24229,7 +22780,7 @@ module.exports = YAMLException;
 
 /***/ }),
 
-/***/ 39463:
+/***/ 88527:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
@@ -24237,11 +22788,11 @@ module.exports = YAMLException;
 
 /*eslint-disable max-len,no-use-before-define*/
 
-var common              = __nccwpck_require__(81108);
-var YAMLException       = __nccwpck_require__(28743);
-var Mark                = __nccwpck_require__(49656);
-var DEFAULT_SAFE_SCHEMA = __nccwpck_require__(3012);
-var DEFAULT_FULL_SCHEMA = __nccwpck_require__(2726);
+var common              = __nccwpck_require__(50062);
+var YAMLException       = __nccwpck_require__(12406);
+var Mark                = __nccwpck_require__(54710);
+var DEFAULT_SAFE_SCHEMA = __nccwpck_require__(30537);
+var DEFAULT_FULL_SCHEMA = __nccwpck_require__(88227);
 
 
 var _hasOwnProperty = Object.prototype.hasOwnProperty;
@@ -25881,14 +24432,14 @@ module.exports.safeLoad    = safeLoad;
 
 /***/ }),
 
-/***/ 49656:
+/***/ 54710:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
 
 
 
-var common = __nccwpck_require__(81108);
+var common = __nccwpck_require__(50062);
 
 
 function Mark(name, buffer, position, line, column) {
@@ -25965,7 +24516,7 @@ module.exports = Mark;
 
 /***/ }),
 
-/***/ 27731:
+/***/ 76658:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
@@ -25973,9 +24524,9 @@ module.exports = Mark;
 
 /*eslint-disable max-len*/
 
-var common        = __nccwpck_require__(81108);
-var YAMLException = __nccwpck_require__(28743);
-var Type          = __nccwpck_require__(34592);
+var common        = __nccwpck_require__(50062);
+var YAMLException = __nccwpck_require__(12406);
+var Type          = __nccwpck_require__(58153);
 
 
 function compileList(schema, name, result) {
@@ -26081,7 +24632,7 @@ module.exports = Schema;
 
 /***/ }),
 
-/***/ 89554:
+/***/ 75447:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
@@ -26095,19 +24646,19 @@ module.exports = Schema;
 
 
 
-var Schema = __nccwpck_require__(27731);
+var Schema = __nccwpck_require__(76658);
 
 
 module.exports = new Schema({
   include: [
-    __nccwpck_require__(99482)
+    __nccwpck_require__(67464)
   ]
 });
 
 
 /***/ }),
 
-/***/ 2726:
+/***/ 88227:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
@@ -26123,24 +24674,24 @@ module.exports = new Schema({
 
 
 
-var Schema = __nccwpck_require__(27731);
+var Schema = __nccwpck_require__(76658);
 
 
 module.exports = Schema.DEFAULT = new Schema({
   include: [
-    __nccwpck_require__(3012)
+    __nccwpck_require__(30537)
   ],
   explicit: [
-    __nccwpck_require__(73828),
-    __nccwpck_require__(94234),
-    __nccwpck_require__(15552)
+    __nccwpck_require__(58947),
+    __nccwpck_require__(99716),
+    __nccwpck_require__(71654)
   ]
 });
 
 
 /***/ }),
 
-/***/ 3012:
+/***/ 30537:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
@@ -26154,29 +24705,29 @@ module.exports = Schema.DEFAULT = new Schema({
 
 
 
-var Schema = __nccwpck_require__(27731);
+var Schema = __nccwpck_require__(76658);
 
 
 module.exports = new Schema({
   include: [
-    __nccwpck_require__(89554)
+    __nccwpck_require__(75447)
   ],
   implicit: [
-    __nccwpck_require__(91278),
-    __nccwpck_require__(18363)
+    __nccwpck_require__(42711),
+    __nccwpck_require__(52332)
   ],
   explicit: [
-    __nccwpck_require__(47650),
-    __nccwpck_require__(98516),
-    __nccwpck_require__(77376),
-    __nccwpck_require__(15169)
+    __nccwpck_require__(67866),
+    __nccwpck_require__(82807),
+    __nccwpck_require__(56026),
+    __nccwpck_require__(9605)
   ]
 });
 
 
 /***/ }),
 
-/***/ 45576:
+/***/ 13589:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
@@ -26187,21 +24738,21 @@ module.exports = new Schema({
 
 
 
-var Schema = __nccwpck_require__(27731);
+var Schema = __nccwpck_require__(76658);
 
 
 module.exports = new Schema({
   explicit: [
-    __nccwpck_require__(43337),
-    __nccwpck_require__(82627),
-    __nccwpck_require__(79411)
+    __nccwpck_require__(45477),
+    __nccwpck_require__(78800),
+    __nccwpck_require__(55135)
   ]
 });
 
 
 /***/ }),
 
-/***/ 99482:
+/***/ 67464:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
@@ -26216,31 +24767,31 @@ module.exports = new Schema({
 
 
 
-var Schema = __nccwpck_require__(27731);
+var Schema = __nccwpck_require__(76658);
 
 
 module.exports = new Schema({
   include: [
-    __nccwpck_require__(45576)
+    __nccwpck_require__(13589)
   ],
   implicit: [
-    __nccwpck_require__(1195),
-    __nccwpck_require__(87975),
-    __nccwpck_require__(50231),
-    __nccwpck_require__(92067)
+    __nccwpck_require__(99432),
+    __nccwpck_require__(61131),
+    __nccwpck_require__(63357),
+    __nccwpck_require__(92026)
   ]
 });
 
 
 /***/ }),
 
-/***/ 34592:
+/***/ 58153:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
 
 
-var YAMLException = __nccwpck_require__(28743);
+var YAMLException = __nccwpck_require__(12406);
 
 var TYPE_CONSTRUCTOR_OPTIONS = [
   'kind',
@@ -26303,7 +24854,7 @@ module.exports = Type;
 
 /***/ }),
 
-/***/ 47650:
+/***/ 67866:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
@@ -26319,7 +24870,7 @@ try {
   NodeBuffer = _require('buffer').Buffer;
 } catch (__) {}
 
-var Type       = __nccwpck_require__(34592);
+var Type       = __nccwpck_require__(58153);
 
 
 // [ 64, 65, 66 ] -> [ padding, CR, LF ]
@@ -26449,13 +25000,13 @@ module.exports = new Type('tag:yaml.org,2002:binary', {
 
 /***/ }),
 
-/***/ 87975:
+/***/ 61131:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
 
 
-var Type = __nccwpck_require__(34592);
+var Type = __nccwpck_require__(58153);
 
 function resolveYamlBoolean(data) {
   if (data === null) return false;
@@ -26492,14 +25043,14 @@ module.exports = new Type('tag:yaml.org,2002:bool', {
 
 /***/ }),
 
-/***/ 92067:
+/***/ 92026:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
 
 
-var common = __nccwpck_require__(81108);
-var Type   = __nccwpck_require__(34592);
+var common = __nccwpck_require__(50062);
+var Type   = __nccwpck_require__(58153);
 
 var YAML_FLOAT_PATTERN = new RegExp(
   // 2.5e4, 2.5 and integers
@@ -26616,14 +25167,14 @@ module.exports = new Type('tag:yaml.org,2002:float', {
 
 /***/ }),
 
-/***/ 50231:
+/***/ 63357:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
 
 
-var common = __nccwpck_require__(81108);
-var Type   = __nccwpck_require__(34592);
+var common = __nccwpck_require__(50062);
+var Type   = __nccwpck_require__(58153);
 
 function isHexCode(c) {
   return ((0x30/* 0 */ <= c) && (c <= 0x39/* 9 */)) ||
@@ -26797,7 +25348,7 @@ module.exports = new Type('tag:yaml.org,2002:int', {
 
 /***/ }),
 
-/***/ 15552:
+/***/ 71654:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
@@ -26822,7 +25373,7 @@ try {
   if (typeof window !== 'undefined') esprima = window.esprima;
 }
 
-var Type = __nccwpck_require__(34592);
+var Type = __nccwpck_require__(58153);
 
 function resolveJavascriptFunction(data) {
   if (data === null) return false;
@@ -26898,13 +25449,13 @@ module.exports = new Type('tag:yaml.org,2002:js/function', {
 
 /***/ }),
 
-/***/ 94234:
+/***/ 99716:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
 
 
-var Type = __nccwpck_require__(34592);
+var Type = __nccwpck_require__(58153);
 
 function resolveJavascriptRegExp(data) {
   if (data === null) return false;
@@ -26966,13 +25517,13 @@ module.exports = new Type('tag:yaml.org,2002:js/regexp', {
 
 /***/ }),
 
-/***/ 73828:
+/***/ 58947:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
 
 
-var Type = __nccwpck_require__(34592);
+var Type = __nccwpck_require__(58153);
 
 function resolveJavascriptUndefined() {
   return true;
@@ -27002,13 +25553,13 @@ module.exports = new Type('tag:yaml.org,2002:js/undefined', {
 
 /***/ }),
 
-/***/ 79411:
+/***/ 55135:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
 
 
-var Type = __nccwpck_require__(34592);
+var Type = __nccwpck_require__(58153);
 
 module.exports = new Type('tag:yaml.org,2002:map', {
   kind: 'mapping',
@@ -27018,13 +25569,13 @@ module.exports = new Type('tag:yaml.org,2002:map', {
 
 /***/ }),
 
-/***/ 18363:
+/***/ 52332:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
 
 
-var Type = __nccwpck_require__(34592);
+var Type = __nccwpck_require__(58153);
 
 function resolveYamlMerge(data) {
   return data === '<<' || data === null;
@@ -27038,13 +25589,13 @@ module.exports = new Type('tag:yaml.org,2002:merge', {
 
 /***/ }),
 
-/***/ 1195:
+/***/ 99432:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
 
 
-var Type = __nccwpck_require__(34592);
+var Type = __nccwpck_require__(58153);
 
 function resolveYamlNull(data) {
   if (data === null) return true;
@@ -27080,13 +25631,13 @@ module.exports = new Type('tag:yaml.org,2002:null', {
 
 /***/ }),
 
-/***/ 98516:
+/***/ 82807:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
 
 
-var Type = __nccwpck_require__(34592);
+var Type = __nccwpck_require__(58153);
 
 var _hasOwnProperty = Object.prototype.hasOwnProperty;
 var _toString       = Object.prototype.toString;
@@ -27132,13 +25683,13 @@ module.exports = new Type('tag:yaml.org,2002:omap', {
 
 /***/ }),
 
-/***/ 77376:
+/***/ 56026:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
 
 
-var Type = __nccwpck_require__(34592);
+var Type = __nccwpck_require__(58153);
 
 var _toString = Object.prototype.toString;
 
@@ -27193,13 +25744,13 @@ module.exports = new Type('tag:yaml.org,2002:pairs', {
 
 /***/ }),
 
-/***/ 82627:
+/***/ 78800:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
 
 
-var Type = __nccwpck_require__(34592);
+var Type = __nccwpck_require__(58153);
 
 module.exports = new Type('tag:yaml.org,2002:seq', {
   kind: 'sequence',
@@ -27209,13 +25760,13 @@ module.exports = new Type('tag:yaml.org,2002:seq', {
 
 /***/ }),
 
-/***/ 15169:
+/***/ 9605:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
 
 
-var Type = __nccwpck_require__(34592);
+var Type = __nccwpck_require__(58153);
 
 var _hasOwnProperty = Object.prototype.hasOwnProperty;
 
@@ -27246,13 +25797,13 @@ module.exports = new Type('tag:yaml.org,2002:set', {
 
 /***/ }),
 
-/***/ 43337:
+/***/ 45477:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
 
 
-var Type = __nccwpck_require__(34592);
+var Type = __nccwpck_require__(58153);
 
 module.exports = new Type('tag:yaml.org,2002:str', {
   kind: 'scalar',
@@ -27262,13 +25813,13 @@ module.exports = new Type('tag:yaml.org,2002:str', {
 
 /***/ }),
 
-/***/ 91278:
+/***/ 42711:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
 
 
-var Type = __nccwpck_require__(34592);
+var Type = __nccwpck_require__(58153);
 
 var YAML_DATE_REGEXP = new RegExp(
   '^([0-9][0-9][0-9][0-9])'          + // [1] year
@@ -27358,15 +25909,15 @@ module.exports = new Type('tag:yaml.org,2002:timestamp', {
 
 /***/ }),
 
-/***/ 89777:
+/***/ 74529:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
 
 
 
-var loader = __nccwpck_require__(75421);
-var dumper = __nccwpck_require__(14908);
+var loader = __nccwpck_require__(16871);
+var dumper = __nccwpck_require__(74169);
 
 
 function renamed(from, to) {
@@ -27377,16 +25928,16 @@ function renamed(from, to) {
 }
 
 
-module.exports.Type = __nccwpck_require__(33872);
-module.exports.Schema = __nccwpck_require__(81043);
-module.exports.FAILSAFE_SCHEMA = __nccwpck_require__(40167);
-module.exports.JSON_SCHEMA = __nccwpck_require__(17223);
-module.exports.CORE_SCHEMA = __nccwpck_require__(36141);
-module.exports.DEFAULT_SCHEMA = __nccwpck_require__(19097);
+module.exports.Type = __nccwpck_require__(92889);
+module.exports.Schema = __nccwpck_require__(80554);
+module.exports.FAILSAFE_SCHEMA = __nccwpck_require__(49625);
+module.exports.JSON_SCHEMA = __nccwpck_require__(23775);
+module.exports.CORE_SCHEMA = __nccwpck_require__(95385);
+module.exports.DEFAULT_SCHEMA = __nccwpck_require__(11972);
 module.exports.load                = loader.load;
 module.exports.loadAll             = loader.loadAll;
 module.exports.dump                = dumper.dump;
-module.exports.YAMLException = __nccwpck_require__(85003);
+module.exports.YAMLException = __nccwpck_require__(70730);
 
 // Removed functions from JS-YAML 3.0.x
 module.exports.safeLoad            = renamed('safeLoad', 'load');
@@ -27396,7 +25947,7 @@ module.exports.safeDump            = renamed('safeDump', 'dump');
 
 /***/ }),
 
-/***/ 52152:
+/***/ 19827:
 /***/ ((module) => {
 
 "use strict";
@@ -27463,7 +26014,7 @@ module.exports.extend         = extend;
 
 /***/ }),
 
-/***/ 14908:
+/***/ 74169:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
@@ -27471,9 +26022,9 @@ module.exports.extend         = extend;
 
 /*eslint-disable no-use-before-define*/
 
-var common              = __nccwpck_require__(52152);
-var YAMLException       = __nccwpck_require__(85003);
-var DEFAULT_SCHEMA      = __nccwpck_require__(19097);
+var common              = __nccwpck_require__(19827);
+var YAMLException       = __nccwpck_require__(70730);
+var DEFAULT_SCHEMA      = __nccwpck_require__(11972);
 
 var _toString       = Object.prototype.toString;
 var _hasOwnProperty = Object.prototype.hasOwnProperty;
@@ -28449,7 +27000,7 @@ module.exports.dump = dump;
 
 /***/ }),
 
-/***/ 85003:
+/***/ 70730:
 /***/ ((module) => {
 
 "use strict";
@@ -28512,7 +27063,7 @@ module.exports = YAMLException;
 
 /***/ }),
 
-/***/ 75421:
+/***/ 16871:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
@@ -28520,10 +27071,10 @@ module.exports = YAMLException;
 
 /*eslint-disable max-len,no-use-before-define*/
 
-var common              = __nccwpck_require__(52152);
-var YAMLException       = __nccwpck_require__(85003);
-var makeSnippet         = __nccwpck_require__(89420);
-var DEFAULT_SCHEMA      = __nccwpck_require__(19097);
+var common              = __nccwpck_require__(19827);
+var YAMLException       = __nccwpck_require__(70730);
+var makeSnippet         = __nccwpck_require__(45649);
+var DEFAULT_SCHEMA      = __nccwpck_require__(11972);
 
 
 var _hasOwnProperty = Object.prototype.hasOwnProperty;
@@ -30247,7 +28798,7 @@ module.exports.load    = load;
 
 /***/ }),
 
-/***/ 81043:
+/***/ 80554:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
@@ -30255,8 +28806,8 @@ module.exports.load    = load;
 
 /*eslint-disable max-len*/
 
-var YAMLException = __nccwpck_require__(85003);
-var Type          = __nccwpck_require__(33872);
+var YAMLException = __nccwpck_require__(70730);
+var Type          = __nccwpck_require__(92889);
 
 
 function compileList(schema, name, result) {
@@ -30376,7 +28927,7 @@ module.exports = Schema;
 
 /***/ }),
 
-/***/ 36141:
+/***/ 95385:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
@@ -30390,12 +28941,12 @@ module.exports = Schema;
 
 
 
-module.exports = __nccwpck_require__(17223);
+module.exports = __nccwpck_require__(23775);
 
 
 /***/ }),
 
-/***/ 19097:
+/***/ 11972:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
@@ -30409,23 +28960,23 @@ module.exports = __nccwpck_require__(17223);
 
 
 
-module.exports = (__nccwpck_require__(36141).extend)({
+module.exports = (__nccwpck_require__(95385).extend)({
   implicit: [
-    __nccwpck_require__(86559),
-    __nccwpck_require__(93159)
+    __nccwpck_require__(26202),
+    __nccwpck_require__(94533)
   ],
   explicit: [
-    __nccwpck_require__(29937),
-    __nccwpck_require__(6924),
-    __nccwpck_require__(48915),
-    __nccwpck_require__(20726)
+    __nccwpck_require__(75140),
+    __nccwpck_require__(36992),
+    __nccwpck_require__(86681),
+    __nccwpck_require__(13760)
   ]
 });
 
 
 /***/ }),
 
-/***/ 40167:
+/***/ 49625:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
@@ -30436,21 +28987,21 @@ module.exports = (__nccwpck_require__(36141).extend)({
 
 
 
-var Schema = __nccwpck_require__(81043);
+var Schema = __nccwpck_require__(80554);
 
 
 module.exports = new Schema({
   explicit: [
-    __nccwpck_require__(68647),
-    __nccwpck_require__(23208),
-    __nccwpck_require__(39172)
+    __nccwpck_require__(20819),
+    __nccwpck_require__(48021),
+    __nccwpck_require__(47070)
   ]
 });
 
 
 /***/ }),
 
-/***/ 17223:
+/***/ 23775:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
@@ -30465,26 +29016,26 @@ module.exports = new Schema({
 
 
 
-module.exports = (__nccwpck_require__(40167).extend)({
+module.exports = (__nccwpck_require__(49625).extend)({
   implicit: [
-    __nccwpck_require__(80783),
-    __nccwpck_require__(80791),
-    __nccwpck_require__(62053),
-    __nccwpck_require__(83142)
+    __nccwpck_require__(10618),
+    __nccwpck_require__(67358),
+    __nccwpck_require__(44734),
+    __nccwpck_require__(75609)
   ]
 });
 
 
 /***/ }),
 
-/***/ 89420:
+/***/ 45649:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
 
 
 
-var common = __nccwpck_require__(52152);
+var common = __nccwpck_require__(19827);
 
 
 // get snippet for a single line, respecting maxLength
@@ -30586,13 +29137,13 @@ module.exports = makeSnippet;
 
 /***/ }),
 
-/***/ 33872:
+/***/ 92889:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
 
 
-var YAMLException = __nccwpck_require__(85003);
+var YAMLException = __nccwpck_require__(70730);
 
 var TYPE_CONSTRUCTOR_OPTIONS = [
   'kind',
@@ -30659,7 +29210,7 @@ module.exports = Type;
 
 /***/ }),
 
-/***/ 29937:
+/***/ 75140:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
@@ -30668,7 +29219,7 @@ module.exports = Type;
 /*eslint-disable no-bitwise*/
 
 
-var Type = __nccwpck_require__(33872);
+var Type = __nccwpck_require__(92889);
 
 
 // [ 64, 65, 66 ] -> [ padding, CR, LF ]
@@ -30792,13 +29343,13 @@ module.exports = new Type('tag:yaml.org,2002:binary', {
 
 /***/ }),
 
-/***/ 80791:
+/***/ 67358:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
 
 
-var Type = __nccwpck_require__(33872);
+var Type = __nccwpck_require__(92889);
 
 function resolveYamlBoolean(data) {
   if (data === null) return false;
@@ -30835,14 +29386,14 @@ module.exports = new Type('tag:yaml.org,2002:bool', {
 
 /***/ }),
 
-/***/ 83142:
+/***/ 75609:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
 
 
-var common = __nccwpck_require__(52152);
-var Type   = __nccwpck_require__(33872);
+var common = __nccwpck_require__(19827);
+var Type   = __nccwpck_require__(92889);
 
 var YAML_FLOAT_PATTERN = new RegExp(
   // 2.5e4, 2.5 and integers
@@ -30940,14 +29491,14 @@ module.exports = new Type('tag:yaml.org,2002:float', {
 
 /***/ }),
 
-/***/ 62053:
+/***/ 44734:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
 
 
-var common = __nccwpck_require__(52152);
-var Type   = __nccwpck_require__(33872);
+var common = __nccwpck_require__(19827);
+var Type   = __nccwpck_require__(92889);
 
 function isHexCode(c) {
   return ((0x30/* 0 */ <= c) && (c <= 0x39/* 9 */)) ||
@@ -31104,13 +29655,13 @@ module.exports = new Type('tag:yaml.org,2002:int', {
 
 /***/ }),
 
-/***/ 39172:
+/***/ 47070:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
 
 
-var Type = __nccwpck_require__(33872);
+var Type = __nccwpck_require__(92889);
 
 module.exports = new Type('tag:yaml.org,2002:map', {
   kind: 'mapping',
@@ -31120,13 +29671,13 @@ module.exports = new Type('tag:yaml.org,2002:map', {
 
 /***/ }),
 
-/***/ 93159:
+/***/ 94533:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
 
 
-var Type = __nccwpck_require__(33872);
+var Type = __nccwpck_require__(92889);
 
 function resolveYamlMerge(data) {
   return data === '<<' || data === null;
@@ -31140,13 +29691,13 @@ module.exports = new Type('tag:yaml.org,2002:merge', {
 
 /***/ }),
 
-/***/ 80783:
+/***/ 10618:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
 
 
-var Type = __nccwpck_require__(33872);
+var Type = __nccwpck_require__(92889);
 
 function resolveYamlNull(data) {
   if (data === null) return true;
@@ -31183,13 +29734,13 @@ module.exports = new Type('tag:yaml.org,2002:null', {
 
 /***/ }),
 
-/***/ 6924:
+/***/ 36992:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
 
 
-var Type = __nccwpck_require__(33872);
+var Type = __nccwpck_require__(92889);
 
 var _hasOwnProperty = Object.prototype.hasOwnProperty;
 var _toString       = Object.prototype.toString;
@@ -31235,13 +29786,13 @@ module.exports = new Type('tag:yaml.org,2002:omap', {
 
 /***/ }),
 
-/***/ 48915:
+/***/ 86681:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
 
 
-var Type = __nccwpck_require__(33872);
+var Type = __nccwpck_require__(92889);
 
 var _toString = Object.prototype.toString;
 
@@ -31296,13 +29847,13 @@ module.exports = new Type('tag:yaml.org,2002:pairs', {
 
 /***/ }),
 
-/***/ 23208:
+/***/ 48021:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
 
 
-var Type = __nccwpck_require__(33872);
+var Type = __nccwpck_require__(92889);
 
 module.exports = new Type('tag:yaml.org,2002:seq', {
   kind: 'sequence',
@@ -31312,13 +29863,13 @@ module.exports = new Type('tag:yaml.org,2002:seq', {
 
 /***/ }),
 
-/***/ 20726:
+/***/ 13760:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
 
 
-var Type = __nccwpck_require__(33872);
+var Type = __nccwpck_require__(92889);
 
 var _hasOwnProperty = Object.prototype.hasOwnProperty;
 
@@ -31349,13 +29900,13 @@ module.exports = new Type('tag:yaml.org,2002:set', {
 
 /***/ }),
 
-/***/ 68647:
+/***/ 20819:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
 
 
-var Type = __nccwpck_require__(33872);
+var Type = __nccwpck_require__(92889);
 
 module.exports = new Type('tag:yaml.org,2002:str', {
   kind: 'scalar',
@@ -31365,13 +29916,13 @@ module.exports = new Type('tag:yaml.org,2002:str', {
 
 /***/ }),
 
-/***/ 86559:
+/***/ 26202:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
 
 
-var Type = __nccwpck_require__(33872);
+var Type = __nccwpck_require__(92889);
 
 var YAML_DATE_REGEXP = new RegExp(
   '^([0-9][0-9][0-9][0-9])'          + // [1] year
@@ -31461,7 +30012,7 @@ module.exports = new Type('tag:yaml.org,2002:timestamp', {
 
 /***/ }),
 
-/***/ 51697:
+/***/ 95141:
 /***/ (function(__unused_webpack_module, exports) {
 
 (function (global, factory) {
@@ -31930,7 +30481,7 @@ module.exports = new Type('tag:yaml.org,2002:timestamp', {
 
 /***/ }),
 
-/***/ 89761:
+/***/ 69241:
 /***/ (function(__unused_webpack_module, exports) {
 
 (function (global, factory) {
@@ -37919,7 +36470,7 @@ module.exports = new Type('tag:yaml.org,2002:timestamp', {
 
 /***/ }),
 
-/***/ 3537:
+/***/ 93799:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
@@ -37966,7 +36517,7 @@ const setLazyProperty = (object, property, get) => {
 let colorConvert;
 const makeDynamicStyles = (wrap, targetSpace, identity, isBackground) => {
 	if (colorConvert === undefined) {
-		colorConvert = __nccwpck_require__(69218);
+		colorConvert = __nccwpck_require__(79713);
 	}
 
 	const offset = isBackground ? 10 : 0;
@@ -38091,3197 +36642,2620 @@ Object.defineProperty(module, 'exports', {
 
 /***/ }),
 
-/***/ 62158:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+/***/ 69888:
+/***/ ((module) => {
 
-/* MIT license */
-/* eslint-disable no-mixed-operators */
-const cssKeywords = __nccwpck_require__(58158);
+const flagSymbol = Symbol('arg flag');
 
-// NOTE: conversions should only return primitive values (i.e. arrays, or
-//       values that give correct `typeof` results).
-//       do not use box values types (i.e. Number(), String(), etc.)
+function arg(opts, {argv = process.argv.slice(2), permissive = false, stopAtPositional = false} = {}) {
+	if (!opts) {
+		throw new Error('Argument specification object is required');
+	}
 
-const reverseKeywords = {};
-for (const key of Object.keys(cssKeywords)) {
-	reverseKeywords[cssKeywords[key]] = key;
-}
+	const result = {_: []};
 
-const convert = {
-	rgb: {channels: 3, labels: 'rgb'},
-	hsl: {channels: 3, labels: 'hsl'},
-	hsv: {channels: 3, labels: 'hsv'},
-	hwb: {channels: 3, labels: 'hwb'},
-	cmyk: {channels: 4, labels: 'cmyk'},
-	xyz: {channels: 3, labels: 'xyz'},
-	lab: {channels: 3, labels: 'lab'},
-	lch: {channels: 3, labels: 'lch'},
-	hex: {channels: 1, labels: ['hex']},
-	keyword: {channels: 1, labels: ['keyword']},
-	ansi16: {channels: 1, labels: ['ansi16']},
-	ansi256: {channels: 1, labels: ['ansi256']},
-	hcg: {channels: 3, labels: ['h', 'c', 'g']},
-	apple: {channels: 3, labels: ['r16', 'g16', 'b16']},
-	gray: {channels: 1, labels: ['gray']}
-};
+	const aliases = {};
+	const handlers = {};
 
-module.exports = convert;
+	for (const key of Object.keys(opts)) {
+		if (!key) {
+			throw new TypeError('Argument key cannot be an empty string');
+		}
 
-// Hide .channels and .labels properties
-for (const model of Object.keys(convert)) {
-	if (!('channels' in convert[model])) {
-		throw new Error('missing channels property: ' + model);
-	}
+		if (key[0] !== '-') {
+			throw new TypeError(`Argument key must start with '-' but found: '${key}'`);
+		}
 
-	if (!('labels' in convert[model])) {
-		throw new Error('missing channel labels property: ' + model);
-	}
+		if (key.length === 1) {
+			throw new TypeError(`Argument key must have a name; singular '-' keys are not allowed: ${key}`);
+		}
 
-	if (convert[model].labels.length !== convert[model].channels) {
-		throw new Error('channel and label counts mismatch: ' + model);
-	}
+		if (typeof opts[key] === 'string') {
+			aliases[key] = opts[key];
+			continue;
+		}
 
-	const {channels, labels} = convert[model];
-	delete convert[model].channels;
-	delete convert[model].labels;
-	Object.defineProperty(convert[model], 'channels', {value: channels});
-	Object.defineProperty(convert[model], 'labels', {value: labels});
-}
+		let type = opts[key];
+		let isFlag = false;
 
-convert.rgb.hsl = function (rgb) {
-	const r = rgb[0] / 255;
-	const g = rgb[1] / 255;
-	const b = rgb[2] / 255;
-	const min = Math.min(r, g, b);
-	const max = Math.max(r, g, b);
-	const delta = max - min;
-	let h;
-	let s;
+		if (Array.isArray(type) && type.length === 1 && typeof type[0] === 'function') {
+			const [fn] = type;
+			type = (value, name, prev = []) => {
+				prev.push(fn(value, name, prev[prev.length - 1]));
+				return prev;
+			};
+			isFlag = fn === Boolean || fn[flagSymbol] === true;
+		} else if (typeof type === 'function') {
+			isFlag = type === Boolean || type[flagSymbol] === true;
+		} else {
+			throw new TypeError(`Type missing or not a function or valid array type: ${key}`);
+		}
 
-	if (max === min) {
-		h = 0;
-	} else if (r === max) {
-		h = (g - b) / delta;
-	} else if (g === max) {
-		h = 2 + (b - r) / delta;
-	} else if (b === max) {
-		h = 4 + (r - g) / delta;
+		if (key[1] !== '-' && key.length > 2) {
+			throw new TypeError(`Short argument keys (with a single hyphen) must have only one character: ${key}`);
+		}
+
+		handlers[key] = [type, isFlag];
 	}
 
-	h = Math.min(h * 60, 360);
+	for (let i = 0, len = argv.length; i < len; i++) {
+		const wholeArg = argv[i];
 
-	if (h < 0) {
-		h += 360;
-	}
+		if (stopAtPositional && result._.length > 0) {
+			result._ = result._.concat(argv.slice(i));
+			break;
+		}
 
-	const l = (min + max) / 2;
+		if (wholeArg === '--') {
+			result._ = result._.concat(argv.slice(i + 1));
+			break;
+		}
 
-	if (max === min) {
-		s = 0;
-	} else if (l <= 0.5) {
-		s = delta / (max + min);
-	} else {
-		s = delta / (2 - max - min);
-	}
+		if (wholeArg.length > 1 && wholeArg[0] === '-') {
+			/* eslint-disable operator-linebreak */
+			const separatedArguments = (wholeArg[1] === '-' || wholeArg.length === 2)
+				? [wholeArg]
+				: wholeArg.slice(1).split('').map(a => `-${a}`);
+			/* eslint-enable operator-linebreak */
 
-	return [h, s * 100, l * 100];
-};
+			for (let j = 0; j < separatedArguments.length; j++) {
+				const arg = separatedArguments[j];
+				const [originalArgName, argStr] = arg[1] === '-' ? arg.split(/=(.*)/, 2) : [arg, undefined];
 
-convert.rgb.hsv = function (rgb) {
-	let rdif;
-	let gdif;
-	let bdif;
-	let h;
-	let s;
+				let argName = originalArgName;
+				while (argName in aliases) {
+					argName = aliases[argName];
+				}
 
-	const r = rgb[0] / 255;
-	const g = rgb[1] / 255;
-	const b = rgb[2] / 255;
-	const v = Math.max(r, g, b);
-	const diff = v - Math.min(r, g, b);
-	const diffc = function (c) {
-		return (v - c) / 6 / diff + 1 / 2;
-	};
+				if (!(argName in handlers)) {
+					if (permissive) {
+						result._.push(arg);
+						continue;
+					} else {
+						const err = new Error(`Unknown or unexpected option: ${originalArgName}`);
+						err.code = 'ARG_UNKNOWN_OPTION';
+						throw err;
+					}
+				}
 
-	if (diff === 0) {
-		h = 0;
-		s = 0;
-	} else {
-		s = diff / v;
-		rdif = diffc(r);
-		gdif = diffc(g);
-		bdif = diffc(b);
+				const [type, isFlag] = handlers[argName];
 
-		if (r === v) {
-			h = bdif - gdif;
-		} else if (g === v) {
-			h = (1 / 3) + rdif - bdif;
-		} else if (b === v) {
-			h = (2 / 3) + gdif - rdif;
-		}
+				if (!isFlag && ((j + 1) < separatedArguments.length)) {
+					throw new TypeError(`Option requires argument (but was followed by another short argument): ${originalArgName}`);
+				}
 
-		if (h < 0) {
-			h += 1;
-		} else if (h > 1) {
-			h -= 1;
+				if (isFlag) {
+					result[argName] = type(true, argName, result[argName]);
+				} else if (argStr === undefined) {
+					if (
+						argv.length < i + 2 ||
+						(
+							argv[i + 1].length > 1 &&
+							(argv[i + 1][0] === '-') &&
+							!(
+								argv[i + 1].match(/^-?\d*(\.(?=\d))?\d*$/) &&
+								(
+									type === Number ||
+									// eslint-disable-next-line no-undef
+									(typeof BigInt !== 'undefined' && type === BigInt)
+								)
+							)
+						)
+					) {
+						const extended = originalArgName === argName ? '' : ` (alias for ${argName})`;
+						throw new Error(`Option requires argument: ${originalArgName}${extended}`);
+					}
+
+					result[argName] = type(argv[i + 1], argName, result[argName]);
+					++i;
+				} else {
+					result[argName] = type(argStr, argName, result[argName]);
+				}
+			}
+		} else {
+			result._.push(wholeArg);
 		}
 	}
 
-	return [
-		h * 360,
-		s * 100,
-		v * 100
-	];
+	return result;
+}
+
+arg.flag = fn => {
+	fn[flagSymbol] = true;
+	return fn;
 };
 
-convert.rgb.hwb = function (rgb) {
-	const r = rgb[0];
-	const g = rgb[1];
-	let b = rgb[2];
-	const h = convert.rgb.hsl(rgb)[0];
-	const w = 1 / 255 * Math.min(r, Math.min(g, b));
+// Utility types
+arg.COUNT = arg.flag((v, name, existingCount) => (existingCount || 0) + 1);
 
-	b = 1 - 1 / 255 * Math.max(r, Math.max(g, b));
+module.exports = arg;
 
-	return [h, w * 100, b * 100];
-};
 
-convert.rgb.cmyk = function (rgb) {
-	const r = rgb[0] / 255;
-	const g = rgb[1] / 255;
-	const b = rgb[2] / 255;
+/***/ }),
 
-	const k = Math.min(1 - r, 1 - g, 1 - b);
-	const c = (1 - r - k) / (1 - k) || 0;
-	const m = (1 - g - k) / (1 - k) || 0;
-	const y = (1 - b - k) / (1 - k) || 0;
+/***/ 77524:
+/***/ ((module) => {
 
-	return [c * 100, m * 100, y * 100, k * 100];
-};
+"use strict";
 
-function comparativeDistance(x, y) {
-	/*
-		See https://en.m.wikipedia.org/wiki/Euclidean_distance#Squared_Euclidean_distance
-	*/
-	return (
-		((x[0] - y[0]) ** 2) +
-		((x[1] - y[1]) ** 2) +
-		((x[2] - y[2]) ** 2)
-	);
-}
+module.exports = balanced;
+function balanced(a, b, str) {
+  if (a instanceof RegExp) a = maybeMatch(a, str);
+  if (b instanceof RegExp) b = maybeMatch(b, str);
 
-convert.rgb.keyword = function (rgb) {
-	const reversed = reverseKeywords[rgb];
-	if (reversed) {
-		return reversed;
-	}
+  var r = range(a, b, str);
 
-	let currentClosestDistance = Infinity;
-	let currentClosestKeyword;
+  return r && {
+    start: r[0],
+    end: r[1],
+    pre: str.slice(0, r[0]),
+    body: str.slice(r[0] + a.length, r[1]),
+    post: str.slice(r[1] + b.length)
+  };
+}
 
-	for (const keyword of Object.keys(cssKeywords)) {
-		const value = cssKeywords[keyword];
+function maybeMatch(reg, str) {
+  var m = str.match(reg);
+  return m ? m[0] : null;
+}
 
-		// Compute comparative distance
-		const distance = comparativeDistance(rgb, value);
+balanced.range = range;
+function range(a, b, str) {
+  var begs, beg, left, right, result;
+  var ai = str.indexOf(a);
+  var bi = str.indexOf(b, ai + 1);
+  var i = ai;
 
-		// Check if its less, if so set as closest
-		if (distance < currentClosestDistance) {
-			currentClosestDistance = distance;
-			currentClosestKeyword = keyword;
-		}
-	}
+  if (ai >= 0 && bi > 0) {
+    if(a===b) {
+      return [ai, bi];
+    }
+    begs = [];
+    left = str.length;
 
-	return currentClosestKeyword;
-};
+    while (i >= 0 && !result) {
+      if (i == ai) {
+        begs.push(i);
+        ai = str.indexOf(a, i + 1);
+      } else if (begs.length == 1) {
+        result = [ begs.pop(), bi ];
+      } else {
+        beg = begs.pop();
+        if (beg < left) {
+          left = beg;
+          right = bi;
+        }
 
-convert.keyword.rgb = function (keyword) {
-	return cssKeywords[keyword];
-};
+        bi = str.indexOf(b, i + 1);
+      }
 
-convert.rgb.xyz = function (rgb) {
-	let r = rgb[0] / 255;
-	let g = rgb[1] / 255;
-	let b = rgb[2] / 255;
+      i = ai < bi && ai >= 0 ? ai : bi;
+    }
 
-	// Assume sRGB
-	r = r > 0.04045 ? (((r + 0.055) / 1.055) ** 2.4) : (r / 12.92);
-	g = g > 0.04045 ? (((g + 0.055) / 1.055) ** 2.4) : (g / 12.92);
-	b = b > 0.04045 ? (((b + 0.055) / 1.055) ** 2.4) : (b / 12.92);
+    if (begs.length) {
+      result = [ left, right ];
+    }
+  }
 
-	const x = (r * 0.4124) + (g * 0.3576) + (b * 0.1805);
-	const y = (r * 0.2126) + (g * 0.7152) + (b * 0.0722);
-	const z = (r * 0.0193) + (g * 0.1192) + (b * 0.9505);
+  return result;
+}
 
-	return [x * 100, y * 100, z * 100];
-};
 
-convert.rgb.lab = function (rgb) {
-	const xyz = convert.rgb.xyz(rgb);
-	let x = xyz[0];
-	let y = xyz[1];
-	let z = xyz[2];
+/***/ }),
 
-	x /= 95.047;
-	y /= 100;
-	z /= 108.883;
+/***/ 43858:
+/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
-	x = x > 0.008856 ? (x ** (1 / 3)) : (7.787 * x) + (16 / 116);
-	y = y > 0.008856 ? (y ** (1 / 3)) : (7.787 * y) + (16 / 116);
-	z = z > 0.008856 ? (z ** (1 / 3)) : (7.787 * z) + (16 / 116);
+"use strict";
 
-	const l = (116 * y) - 16;
-	const a = 500 * (x - y);
-	const b = 200 * (y - z);
 
-	return [l, a, b];
-};
+const { Buffer } = __nccwpck_require__(14300)
+const symbol = Symbol.for('BufferList')
 
-convert.hsl.rgb = function (hsl) {
-	const h = hsl[0] / 360;
-	const s = hsl[1] / 100;
-	const l = hsl[2] / 100;
-	let t2;
-	let t3;
-	let val;
+function BufferList (buf) {
+  if (!(this instanceof BufferList)) {
+    return new BufferList(buf)
+  }
 
-	if (s === 0) {
-		val = l * 255;
-		return [val, val, val];
-	}
+  BufferList._init.call(this, buf)
+}
 
-	if (l < 0.5) {
-		t2 = l * (1 + s);
-	} else {
-		t2 = l + s - l * s;
-	}
+BufferList._init = function _init (buf) {
+  Object.defineProperty(this, symbol, { value: true })
 
-	const t1 = 2 * l - t2;
+  this._bufs = []
+  this.length = 0
 
-	const rgb = [0, 0, 0];
-	for (let i = 0; i < 3; i++) {
-		t3 = h + 1 / 3 * -(i - 1);
-		if (t3 < 0) {
-			t3++;
-		}
+  if (buf) {
+    this.append(buf)
+  }
+}
 
-		if (t3 > 1) {
-			t3--;
-		}
+BufferList.prototype._new = function _new (buf) {
+  return new BufferList(buf)
+}
 
-		if (6 * t3 < 1) {
-			val = t1 + (t2 - t1) * 6 * t3;
-		} else if (2 * t3 < 1) {
-			val = t2;
-		} else if (3 * t3 < 2) {
-			val = t1 + (t2 - t1) * (2 / 3 - t3) * 6;
-		} else {
-			val = t1;
-		}
+BufferList.prototype._offset = function _offset (offset) {
+  if (offset === 0) {
+    return [0, 0]
+  }
 
-		rgb[i] = val * 255;
-	}
+  let tot = 0
 
-	return rgb;
-};
+  for (let i = 0; i < this._bufs.length; i++) {
+    const _t = tot + this._bufs[i].length
+    if (offset < _t || i === this._bufs.length - 1) {
+      return [i, offset - tot]
+    }
+    tot = _t
+  }
+}
 
-convert.hsl.hsv = function (hsl) {
-	const h = hsl[0];
-	let s = hsl[1] / 100;
-	let l = hsl[2] / 100;
-	let smin = s;
-	const lmin = Math.max(l, 0.01);
+BufferList.prototype._reverseOffset = function (blOffset) {
+  const bufferId = blOffset[0]
+  let offset = blOffset[1]
 
-	l *= 2;
-	s *= (l <= 1) ? l : 2 - l;
-	smin *= lmin <= 1 ? lmin : 2 - lmin;
-	const v = (l + s) / 2;
-	const sv = l === 0 ? (2 * smin) / (lmin + smin) : (2 * s) / (l + s);
+  for (let i = 0; i < bufferId; i++) {
+    offset += this._bufs[i].length
+  }
 
-	return [h, sv * 100, v * 100];
-};
+  return offset
+}
 
-convert.hsv.rgb = function (hsv) {
-	const h = hsv[0] / 60;
-	const s = hsv[1] / 100;
-	let v = hsv[2] / 100;
-	const hi = Math.floor(h) % 6;
+BufferList.prototype.get = function get (index) {
+  if (index > this.length || index < 0) {
+    return undefined
+  }
 
-	const f = h - Math.floor(h);
-	const p = 255 * v * (1 - s);
-	const q = 255 * v * (1 - (s * f));
-	const t = 255 * v * (1 - (s * (1 - f)));
-	v *= 255;
+  const offset = this._offset(index)
 
-	switch (hi) {
-		case 0:
-			return [v, t, p];
-		case 1:
-			return [q, v, p];
-		case 2:
-			return [p, v, t];
-		case 3:
-			return [p, q, v];
-		case 4:
-			return [t, p, v];
-		case 5:
-			return [v, p, q];
-	}
-};
+  return this._bufs[offset[0]][offset[1]]
+}
 
-convert.hsv.hsl = function (hsv) {
-	const h = hsv[0];
-	const s = hsv[1] / 100;
-	const v = hsv[2] / 100;
-	const vmin = Math.max(v, 0.01);
-	let sl;
-	let l;
+BufferList.prototype.slice = function slice (start, end) {
+  if (typeof start === 'number' && start < 0) {
+    start += this.length
+  }
 
-	l = (2 - s) * v;
-	const lmin = (2 - s) * vmin;
-	sl = s * vmin;
-	sl /= (lmin <= 1) ? lmin : 2 - lmin;
-	sl = sl || 0;
-	l /= 2;
+  if (typeof end === 'number' && end < 0) {
+    end += this.length
+  }
 
-	return [h, sl * 100, l * 100];
-};
+  return this.copy(null, 0, start, end)
+}
 
-// http://dev.w3.org/csswg/css-color/#hwb-to-rgb
-convert.hwb.rgb = function (hwb) {
-	const h = hwb[0] / 360;
-	let wh = hwb[1] / 100;
-	let bl = hwb[2] / 100;
-	const ratio = wh + bl;
-	let f;
+BufferList.prototype.copy = function copy (dst, dstStart, srcStart, srcEnd) {
+  if (typeof srcStart !== 'number' || srcStart < 0) {
+    srcStart = 0
+  }
 
-	// Wh + bl cant be > 1
-	if (ratio > 1) {
-		wh /= ratio;
-		bl /= ratio;
-	}
+  if (typeof srcEnd !== 'number' || srcEnd > this.length) {
+    srcEnd = this.length
+  }
 
-	const i = Math.floor(6 * h);
-	const v = 1 - bl;
-	f = 6 * h - i;
+  if (srcStart >= this.length) {
+    return dst || Buffer.alloc(0)
+  }
 
-	if ((i & 0x01) !== 0) {
-		f = 1 - f;
-	}
+  if (srcEnd <= 0) {
+    return dst || Buffer.alloc(0)
+  }
 
-	const n = wh + f * (v - wh); // Linear interpolation
+  const copy = !!dst
+  const off = this._offset(srcStart)
+  const len = srcEnd - srcStart
+  let bytes = len
+  let bufoff = (copy && dstStart) || 0
+  let start = off[1]
 
-	let r;
-	let g;
-	let b;
-	/* eslint-disable max-statements-per-line,no-multi-spaces */
-	switch (i) {
-		default:
-		case 6:
-		case 0: r = v;  g = n;  b = wh; break;
-		case 1: r = n;  g = v;  b = wh; break;
-		case 2: r = wh; g = v;  b = n; break;
-		case 3: r = wh; g = n;  b = v; break;
-		case 4: r = n;  g = wh; b = v; break;
-		case 5: r = v;  g = wh; b = n; break;
-	}
-	/* eslint-enable max-statements-per-line,no-multi-spaces */
+  // copy/slice everything
+  if (srcStart === 0 && srcEnd === this.length) {
+    if (!copy) {
+      // slice, but full concat if multiple buffers
+      return this._bufs.length === 1
+        ? this._bufs[0]
+        : Buffer.concat(this._bufs, this.length)
+    }
 
-	return [r * 255, g * 255, b * 255];
-};
+    // copy, need to copy individual buffers
+    for (let i = 0; i < this._bufs.length; i++) {
+      this._bufs[i].copy(dst, bufoff)
+      bufoff += this._bufs[i].length
+    }
 
-convert.cmyk.rgb = function (cmyk) {
-	const c = cmyk[0] / 100;
-	const m = cmyk[1] / 100;
-	const y = cmyk[2] / 100;
-	const k = cmyk[3] / 100;
+    return dst
+  }
 
-	const r = 1 - Math.min(1, c * (1 - k) + k);
-	const g = 1 - Math.min(1, m * (1 - k) + k);
-	const b = 1 - Math.min(1, y * (1 - k) + k);
+  // easy, cheap case where it's a subset of one of the buffers
+  if (bytes <= this._bufs[off[0]].length - start) {
+    return copy
+      ? this._bufs[off[0]].copy(dst, dstStart, start, start + bytes)
+      : this._bufs[off[0]].slice(start, start + bytes)
+  }
 
-	return [r * 255, g * 255, b * 255];
-};
+  if (!copy) {
+    // a slice, we need something to copy in to
+    dst = Buffer.allocUnsafe(len)
+  }
 
-convert.xyz.rgb = function (xyz) {
-	const x = xyz[0] / 100;
-	const y = xyz[1] / 100;
-	const z = xyz[2] / 100;
-	let r;
-	let g;
-	let b;
+  for (let i = off[0]; i < this._bufs.length; i++) {
+    const l = this._bufs[i].length - start
 
-	r = (x * 3.2406) + (y * -1.5372) + (z * -0.4986);
-	g = (x * -0.9689) + (y * 1.8758) + (z * 0.0415);
-	b = (x * 0.0557) + (y * -0.2040) + (z * 1.0570);
+    if (bytes > l) {
+      this._bufs[i].copy(dst, bufoff, start)
+      bufoff += l
+    } else {
+      this._bufs[i].copy(dst, bufoff, start, start + bytes)
+      bufoff += l
+      break
+    }
 
-	// Assume sRGB
-	r = r > 0.0031308
-		? ((1.055 * (r ** (1.0 / 2.4))) - 0.055)
-		: r * 12.92;
+    bytes -= l
 
-	g = g > 0.0031308
-		? ((1.055 * (g ** (1.0 / 2.4))) - 0.055)
-		: g * 12.92;
+    if (start) {
+      start = 0
+    }
+  }
 
-	b = b > 0.0031308
-		? ((1.055 * (b ** (1.0 / 2.4))) - 0.055)
-		: b * 12.92;
+  // safeguard so that we don't return uninitialized memory
+  if (dst.length > bufoff) return dst.slice(0, bufoff)
 
-	r = Math.min(Math.max(0, r), 1);
-	g = Math.min(Math.max(0, g), 1);
-	b = Math.min(Math.max(0, b), 1);
+  return dst
+}
 
-	return [r * 255, g * 255, b * 255];
-};
+BufferList.prototype.shallowSlice = function shallowSlice (start, end) {
+  start = start || 0
+  end = typeof end !== 'number' ? this.length : end
 
-convert.xyz.lab = function (xyz) {
-	let x = xyz[0];
-	let y = xyz[1];
-	let z = xyz[2];
+  if (start < 0) {
+    start += this.length
+  }
 
-	x /= 95.047;
-	y /= 100;
-	z /= 108.883;
+  if (end < 0) {
+    end += this.length
+  }
 
-	x = x > 0.008856 ? (x ** (1 / 3)) : (7.787 * x) + (16 / 116);
-	y = y > 0.008856 ? (y ** (1 / 3)) : (7.787 * y) + (16 / 116);
-	z = z > 0.008856 ? (z ** (1 / 3)) : (7.787 * z) + (16 / 116);
+  if (start === end) {
+    return this._new()
+  }
 
-	const l = (116 * y) - 16;
-	const a = 500 * (x - y);
-	const b = 200 * (y - z);
+  const startOffset = this._offset(start)
+  const endOffset = this._offset(end)
+  const buffers = this._bufs.slice(startOffset[0], endOffset[0] + 1)
 
-	return [l, a, b];
-};
+  if (endOffset[1] === 0) {
+    buffers.pop()
+  } else {
+    buffers[buffers.length - 1] = buffers[buffers.length - 1].slice(0, endOffset[1])
+  }
 
-convert.lab.xyz = function (lab) {
-	const l = lab[0];
-	const a = lab[1];
-	const b = lab[2];
-	let x;
-	let y;
-	let z;
+  if (startOffset[1] !== 0) {
+    buffers[0] = buffers[0].slice(startOffset[1])
+  }
 
-	y = (l + 16) / 116;
-	x = a / 500 + y;
-	z = y - b / 200;
+  return this._new(buffers)
+}
 
-	const y2 = y ** 3;
-	const x2 = x ** 3;
-	const z2 = z ** 3;
-	y = y2 > 0.008856 ? y2 : (y - 16 / 116) / 7.787;
-	x = x2 > 0.008856 ? x2 : (x - 16 / 116) / 7.787;
-	z = z2 > 0.008856 ? z2 : (z - 16 / 116) / 7.787;
+BufferList.prototype.toString = function toString (encoding, start, end) {
+  return this.slice(start, end).toString(encoding)
+}
 
-	x *= 95.047;
-	y *= 100;
-	z *= 108.883;
+BufferList.prototype.consume = function consume (bytes) {
+  // first, normalize the argument, in accordance with how Buffer does it
+  bytes = Math.trunc(bytes)
+  // do nothing if not a positive number
+  if (Number.isNaN(bytes) || bytes <= 0) return this
 
-	return [x, y, z];
-};
+  while (this._bufs.length) {
+    if (bytes >= this._bufs[0].length) {
+      bytes -= this._bufs[0].length
+      this.length -= this._bufs[0].length
+      this._bufs.shift()
+    } else {
+      this._bufs[0] = this._bufs[0].slice(bytes)
+      this.length -= bytes
+      break
+    }
+  }
 
-convert.lab.lch = function (lab) {
-	const l = lab[0];
-	const a = lab[1];
-	const b = lab[2];
-	let h;
+  return this
+}
 
-	const hr = Math.atan2(b, a);
-	h = hr * 360 / 2 / Math.PI;
+BufferList.prototype.duplicate = function duplicate () {
+  const copy = this._new()
 
-	if (h < 0) {
-		h += 360;
-	}
+  for (let i = 0; i < this._bufs.length; i++) {
+    copy.append(this._bufs[i])
+  }
 
-	const c = Math.sqrt(a * a + b * b);
+  return copy
+}
 
-	return [l, c, h];
-};
+BufferList.prototype.append = function append (buf) {
+  if (buf == null) {
+    return this
+  }
 
-convert.lch.lab = function (lch) {
-	const l = lch[0];
-	const c = lch[1];
-	const h = lch[2];
+  if (buf.buffer) {
+    // append a view of the underlying ArrayBuffer
+    this._appendBuffer(Buffer.from(buf.buffer, buf.byteOffset, buf.byteLength))
+  } else if (Array.isArray(buf)) {
+    for (let i = 0; i < buf.length; i++) {
+      this.append(buf[i])
+    }
+  } else if (this._isBufferList(buf)) {
+    // unwrap argument into individual BufferLists
+    for (let i = 0; i < buf._bufs.length; i++) {
+      this.append(buf._bufs[i])
+    }
+  } else {
+    // coerce number arguments to strings, since Buffer(number) does
+    // uninitialized memory allocation
+    if (typeof buf === 'number') {
+      buf = buf.toString()
+    }
 
-	const hr = h / 360 * 2 * Math.PI;
-	const a = c * Math.cos(hr);
-	const b = c * Math.sin(hr);
+    this._appendBuffer(Buffer.from(buf))
+  }
 
-	return [l, a, b];
-};
+  return this
+}
 
-convert.rgb.ansi16 = function (args, saturation = null) {
-	const [r, g, b] = args;
-	let value = saturation === null ? convert.rgb.hsv(args)[2] : saturation; // Hsv -> ansi16 optimization
+BufferList.prototype._appendBuffer = function appendBuffer (buf) {
+  this._bufs.push(buf)
+  this.length += buf.length
+}
 
-	value = Math.round(value / 50);
+BufferList.prototype.indexOf = function (search, offset, encoding) {
+  if (encoding === undefined && typeof offset === 'string') {
+    encoding = offset
+    offset = undefined
+  }
 
-	if (value === 0) {
-		return 30;
-	}
+  if (typeof search === 'function' || Array.isArray(search)) {
+    throw new TypeError('The "value" argument must be one of type string, Buffer, BufferList, or Uint8Array.')
+  } else if (typeof search === 'number') {
+    search = Buffer.from([search])
+  } else if (typeof search === 'string') {
+    search = Buffer.from(search, encoding)
+  } else if (this._isBufferList(search)) {
+    search = search.slice()
+  } else if (Array.isArray(search.buffer)) {
+    search = Buffer.from(search.buffer, search.byteOffset, search.byteLength)
+  } else if (!Buffer.isBuffer(search)) {
+    search = Buffer.from(search)
+  }
 
-	let ansi = 30
-		+ ((Math.round(b / 255) << 2)
-		| (Math.round(g / 255) << 1)
-		| Math.round(r / 255));
+  offset = Number(offset || 0)
 
-	if (value === 2) {
-		ansi += 60;
-	}
+  if (isNaN(offset)) {
+    offset = 0
+  }
 
-	return ansi;
-};
+  if (offset < 0) {
+    offset = this.length + offset
+  }
 
-convert.hsv.ansi16 = function (args) {
-	// Optimization here; we already know the value and don't need to get
-	// it converted for us.
-	return convert.rgb.ansi16(convert.hsv.rgb(args), args[2]);
-};
+  if (offset < 0) {
+    offset = 0
+  }
 
-convert.rgb.ansi256 = function (args) {
-	const r = args[0];
-	const g = args[1];
-	const b = args[2];
+  if (search.length === 0) {
+    return offset > this.length ? this.length : offset
+  }
 
-	// We use the extended greyscale palette here, with the exception of
-	// black and white. normal palette only has 4 greyscale shades.
-	if (r === g && g === b) {
-		if (r < 8) {
-			return 16;
-		}
+  const blOffset = this._offset(offset)
+  let blIndex = blOffset[0] // index of which internal buffer we're working on
+  let buffOffset = blOffset[1] // offset of the internal buffer we're working on
 
-		if (r > 248) {
-			return 231;
-		}
+  // scan over each buffer
+  for (; blIndex < this._bufs.length; blIndex++) {
+    const buff = this._bufs[blIndex]
 
-		return Math.round(((r - 8) / 247) * 24) + 232;
-	}
+    while (buffOffset < buff.length) {
+      const availableWindow = buff.length - buffOffset
 
-	const ansi = 16
-		+ (36 * Math.round(r / 255 * 5))
-		+ (6 * Math.round(g / 255 * 5))
-		+ Math.round(b / 255 * 5);
+      if (availableWindow >= search.length) {
+        const nativeSearchResult = buff.indexOf(search, buffOffset)
 
-	return ansi;
-};
+        if (nativeSearchResult !== -1) {
+          return this._reverseOffset([blIndex, nativeSearchResult])
+        }
 
-convert.ansi16.rgb = function (args) {
-	let color = args % 10;
+        buffOffset = buff.length - search.length + 1 // end of native search window
+      } else {
+        const revOffset = this._reverseOffset([blIndex, buffOffset])
 
-	// Handle greyscale
-	if (color === 0 || color === 7) {
-		if (args > 50) {
-			color += 3.5;
-		}
+        if (this._match(revOffset, search)) {
+          return revOffset
+        }
 
-		color = color / 10.5 * 255;
+        buffOffset++
+      }
+    }
 
-		return [color, color, color];
-	}
+    buffOffset = 0
+  }
 
-	const mult = (~~(args > 50) + 1) * 0.5;
-	const r = ((color & 1) * mult) * 255;
-	const g = (((color >> 1) & 1) * mult) * 255;
-	const b = (((color >> 2) & 1) * mult) * 255;
+  return -1
+}
 
-	return [r, g, b];
-};
+BufferList.prototype._match = function (offset, search) {
+  if (this.length - offset < search.length) {
+    return false
+  }
 
-convert.ansi256.rgb = function (args) {
-	// Handle greyscale
-	if (args >= 232) {
-		const c = (args - 232) * 10 + 8;
-		return [c, c, c];
-	}
+  for (let searchOffset = 0; searchOffset < search.length; searchOffset++) {
+    if (this.get(offset + searchOffset) !== search[searchOffset]) {
+      return false
+    }
+  }
+  return true
+}
 
-	args -= 16;
+;(function () {
+  const methods = {
+    readDoubleBE: 8,
+    readDoubleLE: 8,
+    readFloatBE: 4,
+    readFloatLE: 4,
+    readInt32BE: 4,
+    readInt32LE: 4,
+    readUInt32BE: 4,
+    readUInt32LE: 4,
+    readInt16BE: 2,
+    readInt16LE: 2,
+    readUInt16BE: 2,
+    readUInt16LE: 2,
+    readInt8: 1,
+    readUInt8: 1,
+    readIntBE: null,
+    readIntLE: null,
+    readUIntBE: null,
+    readUIntLE: null
+  }
 
-	let rem;
-	const r = Math.floor(args / 36) / 5 * 255;
-	const g = Math.floor((rem = args % 36) / 6) / 5 * 255;
-	const b = (rem % 6) / 5 * 255;
+  for (const m in methods) {
+    (function (m) {
+      if (methods[m] === null) {
+        BufferList.prototype[m] = function (offset, byteLength) {
+          return this.slice(offset, offset + byteLength)[m](0, byteLength)
+        }
+      } else {
+        BufferList.prototype[m] = function (offset = 0) {
+          return this.slice(offset, offset + methods[m])[m](0)
+        }
+      }
+    }(m))
+  }
+}())
 
-	return [r, g, b];
-};
+// Used internally by the class and also as an indicator of this object being
+// a `BufferList`. It's not possible to use `instanceof BufferList` in a browser
+// environment because there could be multiple different copies of the
+// BufferList class and some `BufferList`s might be `BufferList`s.
+BufferList.prototype._isBufferList = function _isBufferList (b) {
+  return b instanceof BufferList || BufferList.isBufferList(b)
+}
 
-convert.rgb.hex = function (args) {
-	const integer = ((Math.round(args[0]) & 0xFF) << 16)
-		+ ((Math.round(args[1]) & 0xFF) << 8)
-		+ (Math.round(args[2]) & 0xFF);
+BufferList.isBufferList = function isBufferList (b) {
+  return b != null && b[symbol]
+}
 
-	const string = integer.toString(16).toUpperCase();
-	return '000000'.substring(string.length) + string;
-};
+module.exports = BufferList
 
-convert.hex.rgb = function (args) {
-	const match = args.toString(16).match(/[a-f0-9]{6}|[a-f0-9]{3}/i);
-	if (!match) {
-		return [0, 0, 0];
-	}
 
-	let colorString = match[0];
+/***/ }),
 
-	if (match[0].length === 3) {
-		colorString = colorString.split('').map(char => {
-			return char + char;
-		}).join('');
-	}
+/***/ 82489:
+/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
-	const integer = parseInt(colorString, 16);
-	const r = (integer >> 16) & 0xFF;
-	const g = (integer >> 8) & 0xFF;
-	const b = integer & 0xFF;
+"use strict";
 
-	return [r, g, b];
-};
 
-convert.rgb.hcg = function (rgb) {
-	const r = rgb[0] / 255;
-	const g = rgb[1] / 255;
-	const b = rgb[2] / 255;
-	const max = Math.max(Math.max(r, g), b);
-	const min = Math.min(Math.min(r, g), b);
-	const chroma = (max - min);
-	let grayscale;
-	let hue;
+const DuplexStream = (__nccwpck_require__(17067).Duplex)
+const inherits = __nccwpck_require__(76401)
+const BufferList = __nccwpck_require__(43858)
 
-	if (chroma < 1) {
-		grayscale = min / (1 - chroma);
-	} else {
-		grayscale = 0;
-	}
+function BufferListStream (callback) {
+  if (!(this instanceof BufferListStream)) {
+    return new BufferListStream(callback)
+  }
 
-	if (chroma <= 0) {
-		hue = 0;
-	} else
-	if (max === r) {
-		hue = ((g - b) / chroma) % 6;
-	} else
-	if (max === g) {
-		hue = 2 + (b - r) / chroma;
-	} else {
-		hue = 4 + (r - g) / chroma;
-	}
-
-	hue /= 6;
-	hue %= 1;
+  if (typeof callback === 'function') {
+    this._callback = callback
 
-	return [hue * 360, chroma * 100, grayscale * 100];
-};
+    const piper = function piper (err) {
+      if (this._callback) {
+        this._callback(err)
+        this._callback = null
+      }
+    }.bind(this)
 
-convert.hsl.hcg = function (hsl) {
-	const s = hsl[1] / 100;
-	const l = hsl[2] / 100;
+    this.on('pipe', function onPipe (src) {
+      src.on('error', piper)
+    })
+    this.on('unpipe', function onUnpipe (src) {
+      src.removeListener('error', piper)
+    })
 
-	const c = l < 0.5 ? (2.0 * s * l) : (2.0 * s * (1.0 - l));
+    callback = null
+  }
 
-	let f = 0;
-	if (c < 1.0) {
-		f = (l - 0.5 * c) / (1.0 - c);
-	}
+  BufferList._init.call(this, callback)
+  DuplexStream.call(this)
+}
 
-	return [hsl[0], c * 100, f * 100];
-};
+inherits(BufferListStream, DuplexStream)
+Object.assign(BufferListStream.prototype, BufferList.prototype)
 
-convert.hsv.hcg = function (hsv) {
-	const s = hsv[1] / 100;
-	const v = hsv[2] / 100;
+BufferListStream.prototype._new = function _new (callback) {
+  return new BufferListStream(callback)
+}
 
-	const c = s * v;
-	let f = 0;
+BufferListStream.prototype._write = function _write (buf, encoding, callback) {
+  this._appendBuffer(buf)
 
-	if (c < 1.0) {
-		f = (v - c) / (1 - c);
-	}
+  if (typeof callback === 'function') {
+    callback()
+  }
+}
 
-	return [hsv[0], c * 100, f * 100];
-};
+BufferListStream.prototype._read = function _read (size) {
+  if (!this.length) {
+    return this.push(null)
+  }
 
-convert.hcg.rgb = function (hcg) {
-	const h = hcg[0] / 360;
-	const c = hcg[1] / 100;
-	const g = hcg[2] / 100;
+  size = Math.min(size, this.length)
+  this.push(this.slice(0, size))
+  this.consume(size)
+}
 
-	if (c === 0.0) {
-		return [g * 255, g * 255, g * 255];
-	}
+BufferListStream.prototype.end = function end (chunk) {
+  DuplexStream.prototype.end.call(this, chunk)
 
-	const pure = [0, 0, 0];
-	const hi = (h % 1) * 6;
-	const v = hi % 1;
-	const w = 1 - v;
-	let mg = 0;
+  if (this._callback) {
+    this._callback(null, this.slice())
+    this._callback = null
+  }
+}
 
-	/* eslint-disable max-statements-per-line */
-	switch (Math.floor(hi)) {
-		case 0:
-			pure[0] = 1; pure[1] = v; pure[2] = 0; break;
-		case 1:
-			pure[0] = w; pure[1] = 1; pure[2] = 0; break;
-		case 2:
-			pure[0] = 0; pure[1] = 1; pure[2] = v; break;
-		case 3:
-			pure[0] = 0; pure[1] = w; pure[2] = 1; break;
-		case 4:
-			pure[0] = v; pure[1] = 0; pure[2] = 1; break;
-		default:
-			pure[0] = 1; pure[1] = 0; pure[2] = w;
-	}
-	/* eslint-enable max-statements-per-line */
+BufferListStream.prototype._destroy = function _destroy (err, cb) {
+  this._bufs.length = 0
+  this.length = 0
+  cb(err)
+}
 
-	mg = (1.0 - c) * g;
+BufferListStream.prototype._isBufferList = function _isBufferList (b) {
+  return b instanceof BufferListStream || b instanceof BufferList || BufferListStream.isBufferList(b)
+}
 
-	return [
-		(c * pure[0] + mg) * 255,
-		(c * pure[1] + mg) * 255,
-		(c * pure[2] + mg) * 255
-	];
-};
+BufferListStream.isBufferList = BufferList.isBufferList
 
-convert.hcg.hsv = function (hcg) {
-	const c = hcg[1] / 100;
-	const g = hcg[2] / 100;
+module.exports = BufferListStream
+module.exports.BufferListStream = BufferListStream
+module.exports.BufferList = BufferList
 
-	const v = c + g * (1.0 - c);
-	let f = 0;
 
-	if (v > 0.0) {
-		f = c / v;
-	}
+/***/ }),
 
-	return [hcg[0], f * 100, v * 100];
-};
+/***/ 82548:
+/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
-convert.hcg.hsl = function (hcg) {
-	const c = hcg[1] / 100;
-	const g = hcg[2] / 100;
+var balanced = __nccwpck_require__(77524);
 
-	const l = g * (1.0 - c) + 0.5 * c;
-	let s = 0;
+module.exports = expandTop;
 
-	if (l > 0.0 && l < 0.5) {
-		s = c / (2 * l);
-	} else
-	if (l >= 0.5 && l < 1.0) {
-		s = c / (2 * (1 - l));
-	}
+var escSlash = '\0SLASH'+Math.random()+'\0';
+var escOpen = '\0OPEN'+Math.random()+'\0';
+var escClose = '\0CLOSE'+Math.random()+'\0';
+var escComma = '\0COMMA'+Math.random()+'\0';
+var escPeriod = '\0PERIOD'+Math.random()+'\0';
 
-	return [hcg[0], s * 100, l * 100];
-};
+function numeric(str) {
+  return parseInt(str, 10) == str
+    ? parseInt(str, 10)
+    : str.charCodeAt(0);
+}
 
-convert.hcg.hwb = function (hcg) {
-	const c = hcg[1] / 100;
-	const g = hcg[2] / 100;
-	const v = c + g * (1.0 - c);
-	return [hcg[0], (v - c) * 100, (1 - v) * 100];
-};
+function escapeBraces(str) {
+  return str.split('\\\\').join(escSlash)
+            .split('\\{').join(escOpen)
+            .split('\\}').join(escClose)
+            .split('\\,').join(escComma)
+            .split('\\.').join(escPeriod);
+}
 
-convert.hwb.hcg = function (hwb) {
-	const w = hwb[1] / 100;
-	const b = hwb[2] / 100;
-	const v = 1 - b;
-	const c = v - w;
-	let g = 0;
+function unescapeBraces(str) {
+  return str.split(escSlash).join('\\')
+            .split(escOpen).join('{')
+            .split(escClose).join('}')
+            .split(escComma).join(',')
+            .split(escPeriod).join('.');
+}
 
-	if (c < 1) {
-		g = (v - c) / (1 - c);
-	}
 
-	return [hwb[0], c * 100, g * 100];
-};
+// Basically just str.split(","), but handling cases
+// where we have nested braced sections, which should be
+// treated as individual members, like {a,{b,c},d}
+function parseCommaParts(str) {
+  if (!str)
+    return [''];
 
-convert.apple.rgb = function (apple) {
-	return [(apple[0] / 65535) * 255, (apple[1] / 65535) * 255, (apple[2] / 65535) * 255];
-};
+  var parts = [];
+  var m = balanced('{', '}', str);
 
-convert.rgb.apple = function (rgb) {
-	return [(rgb[0] / 255) * 65535, (rgb[1] / 255) * 65535, (rgb[2] / 255) * 65535];
-};
+  if (!m)
+    return str.split(',');
 
-convert.gray.rgb = function (args) {
-	return [args[0] / 100 * 255, args[0] / 100 * 255, args[0] / 100 * 255];
-};
+  var pre = m.pre;
+  var body = m.body;
+  var post = m.post;
+  var p = pre.split(',');
 
-convert.gray.hsl = function (args) {
-	return [0, 0, args[0]];
-};
+  p[p.length-1] += '{' + body + '}';
+  var postParts = parseCommaParts(post);
+  if (post.length) {
+    p[p.length-1] += postParts.shift();
+    p.push.apply(p, postParts);
+  }
 
-convert.gray.hsv = convert.gray.hsl;
+  parts.push.apply(parts, p);
 
-convert.gray.hwb = function (gray) {
-	return [0, 100, gray[0]];
-};
+  return parts;
+}
 
-convert.gray.cmyk = function (gray) {
-	return [0, 0, 0, gray[0]];
-};
+function expandTop(str) {
+  if (!str)
+    return [];
 
-convert.gray.lab = function (gray) {
-	return [gray[0], 0, 0];
-};
+  // I don't know why Bash 4.3 does this, but it does.
+  // Anything starting with {} will have the first two bytes preserved
+  // but *only* at the top level, so {},a}b will not expand to anything,
+  // but a{},b}c will be expanded to [a}c,abc].
+  // One could argue that this is a bug in Bash, but since the goal of
+  // this module is to match Bash's rules, we escape a leading {}
+  if (str.substr(0, 2) === '{}') {
+    str = '\\{\\}' + str.substr(2);
+  }
 
-convert.gray.hex = function (gray) {
-	const val = Math.round(gray[0] / 100 * 255) & 0xFF;
-	const integer = (val << 16) + (val << 8) + val;
+  return expand(escapeBraces(str), true).map(unescapeBraces);
+}
 
-	const string = integer.toString(16).toUpperCase();
-	return '000000'.substring(string.length) + string;
-};
+function embrace(str) {
+  return '{' + str + '}';
+}
+function isPadded(el) {
+  return /^-?0\d/.test(el);
+}
 
-convert.rgb.gray = function (rgb) {
-	const val = (rgb[0] + rgb[1] + rgb[2]) / 3;
-	return [val / 255 * 100];
-};
+function lte(i, y) {
+  return i <= y;
+}
+function gte(i, y) {
+  return i >= y;
+}
 
+function expand(str, isTop) {
+  var expansions = [];
 
-/***/ }),
+  var m = balanced('{', '}', str);
+  if (!m) return [str];
 
-/***/ 69218:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+  // no need to expand pre, since it is guaranteed to be free of brace-sets
+  var pre = m.pre;
+  var post = m.post.length
+    ? expand(m.post, false)
+    : [''];
 
-const conversions = __nccwpck_require__(62158);
-const route = __nccwpck_require__(20694);
+  if (/\$$/.test(m.pre)) {    
+    for (var k = 0; k < post.length; k++) {
+      var expansion = pre+ '{' + m.body + '}' + post[k];
+      expansions.push(expansion);
+    }
+  } else {
+    var isNumericSequence = /^-?\d+\.\.-?\d+(?:\.\.-?\d+)?$/.test(m.body);
+    var isAlphaSequence = /^[a-zA-Z]\.\.[a-zA-Z](?:\.\.-?\d+)?$/.test(m.body);
+    var isSequence = isNumericSequence || isAlphaSequence;
+    var isOptions = m.body.indexOf(',') >= 0;
+    if (!isSequence && !isOptions) {
+      // {a},b}
+      if (m.post.match(/,.*\}/)) {
+        str = m.pre + '{' + m.body + escClose + m.post;
+        return expand(str);
+      }
+      return [str];
+    }
+
+    var n;
+    if (isSequence) {
+      n = m.body.split(/\.\./);
+    } else {
+      n = parseCommaParts(m.body);
+      if (n.length === 1) {
+        // x{{a,b}}y ==> x{a}y x{b}y
+        n = expand(n[0], false).map(embrace);
+        if (n.length === 1) {
+          return post.map(function(p) {
+            return m.pre + n[0] + p;
+          });
+        }
+      }
+    }
 
-const convert = {};
+    // at this point, n is the parts, and we know it's not a comma set
+    // with a single entry.
+    var N;
 
-const models = Object.keys(conversions);
+    if (isSequence) {
+      var x = numeric(n[0]);
+      var y = numeric(n[1]);
+      var width = Math.max(n[0].length, n[1].length)
+      var incr = n.length == 3
+        ? Math.abs(numeric(n[2]))
+        : 1;
+      var test = lte;
+      var reverse = y < x;
+      if (reverse) {
+        incr *= -1;
+        test = gte;
+      }
+      var pad = n.some(isPadded);
 
-function wrapRaw(fn) {
-	const wrappedFn = function (...args) {
-		const arg0 = args[0];
-		if (arg0 === undefined || arg0 === null) {
-			return arg0;
-		}
+      N = [];
 
-		if (arg0.length > 1) {
-			args = arg0;
-		}
+      for (var i = x; test(i, y); i += incr) {
+        var c;
+        if (isAlphaSequence) {
+          c = String.fromCharCode(i);
+          if (c === '\\')
+            c = '';
+        } else {
+          c = String(i);
+          if (pad) {
+            var need = width - c.length;
+            if (need > 0) {
+              var z = new Array(need + 1).join('0');
+              if (i < 0)
+                c = '-' + z + c.slice(1);
+              else
+                c = z + c;
+            }
+          }
+        }
+        N.push(c);
+      }
+    } else {
+      N = [];
 
-		return fn(args);
-	};
+      for (var j = 0; j < n.length; j++) {
+        N.push.apply(N, expand(n[j], false));
+      }
+    }
 
-	// Preserve .conversion property if there is one
-	if ('conversion' in fn) {
-		wrappedFn.conversion = fn.conversion;
-	}
+    for (var j = 0; j < N.length; j++) {
+      for (var k = 0; k < post.length; k++) {
+        var expansion = pre + N[j] + post[k];
+        if (!isTop || isSequence || expansion)
+          expansions.push(expansion);
+      }
+    }
+  }
 
-	return wrappedFn;
+  return expansions;
 }
 
-function wrapRounded(fn) {
-	const wrappedFn = function (...args) {
-		const arg0 = args[0];
 
-		if (arg0 === undefined || arg0 === null) {
-			return arg0;
-		}
 
-		if (arg0.length > 1) {
-			args = arg0;
-		}
+/***/ }),
 
-		const result = fn(args);
+/***/ 11720:
+/***/ ((module) => {
 
-		// We're assuming the result is an array here.
-		// see notice in conversions.js; don't use box types
-		// in conversion functions.
-		if (typeof result === 'object') {
-			for (let len = result.length, i = 0; i < len; i++) {
-				result[i] = Math.round(result[i]);
-			}
-		}
+/* eslint-disable node/no-deprecated-api */
 
-		return result;
-	};
+var toString = Object.prototype.toString
 
-	// Preserve .conversion property if there is one
-	if ('conversion' in fn) {
-		wrappedFn.conversion = fn.conversion;
-	}
+var isModern = (
+  typeof Buffer !== 'undefined' &&
+  typeof Buffer.alloc === 'function' &&
+  typeof Buffer.allocUnsafe === 'function' &&
+  typeof Buffer.from === 'function'
+)
 
-	return wrappedFn;
+function isArrayBuffer (input) {
+  return toString.call(input).slice(8, -1) === 'ArrayBuffer'
 }
 
-models.forEach(fromModel => {
-	convert[fromModel] = {};
-
-	Object.defineProperty(convert[fromModel], 'channels', {value: conversions[fromModel].channels});
-	Object.defineProperty(convert[fromModel], 'labels', {value: conversions[fromModel].labels});
+function fromArrayBuffer (obj, byteOffset, length) {
+  byteOffset >>>= 0
 
-	const routes = route(fromModel);
-	const routeModels = Object.keys(routes);
+  var maxLength = obj.byteLength - byteOffset
 
-	routeModels.forEach(toModel => {
-		const fn = routes[toModel];
+  if (maxLength < 0) {
+    throw new RangeError("'offset' is out of bounds")
+  }
 
-		convert[fromModel][toModel] = wrapRounded(fn);
-		convert[fromModel][toModel].raw = wrapRaw(fn);
-	});
-});
+  if (length === undefined) {
+    length = maxLength
+  } else {
+    length >>>= 0
 
-module.exports = convert;
+    if (length > maxLength) {
+      throw new RangeError("'length' is out of bounds")
+    }
+  }
 
+  return isModern
+    ? Buffer.from(obj.slice(byteOffset, byteOffset + length))
+    : new Buffer(new Uint8Array(obj.slice(byteOffset, byteOffset + length)))
+}
 
-/***/ }),
+function fromString (string, encoding) {
+  if (typeof encoding !== 'string' || encoding === '') {
+    encoding = 'utf8'
+  }
 
-/***/ 20694:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+  if (!Buffer.isEncoding(encoding)) {
+    throw new TypeError('"encoding" must be a valid string encoding')
+  }
 
-const conversions = __nccwpck_require__(62158);
+  return isModern
+    ? Buffer.from(string, encoding)
+    : new Buffer(string, encoding)
+}
 
-/*
-	This function routes a model to all other models.
+function bufferFrom (value, encodingOrOffset, length) {
+  if (typeof value === 'number') {
+    throw new TypeError('"value" argument must not be a number')
+  }
 
-	all functions that are routed have a property `.conversion` attached
-	to the returned synthetic function. This property is an array
-	of strings, each with the steps in between the 'from' and 'to'
-	color models (inclusive).
+  if (isArrayBuffer(value)) {
+    return fromArrayBuffer(value, encodingOrOffset, length)
+  }
 
-	conversions that are not possible simply are not included.
-*/
+  if (typeof value === 'string') {
+    return fromString(value, encodingOrOffset)
+  }
 
-function buildGraph() {
-	const graph = {};
-	// https://jsperf.com/object-keys-vs-for-in-with-closure/3
-	const models = Object.keys(conversions);
+  return isModern
+    ? Buffer.from(value)
+    : new Buffer(value)
+}
 
-	for (let len = models.length, i = 0; i < len; i++) {
-		graph[models[i]] = {
-			// http://jsperf.com/1-vs-infinity
-			// micro-opt, but this is simple.
-			distance: -1,
-			parent: null
-		};
-	}
+module.exports = bufferFrom
 
-	return graph;
-}
 
-// https://en.wikipedia.org/wiki/Breadth-first_search
-function deriveBFS(fromModel) {
-	const graph = buildGraph();
-	const queue = [fromModel]; // Unshift -> queue -> pop
+/***/ }),
 
-	graph[fromModel].distance = 0;
+/***/ 66573:
+/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
-	while (queue.length) {
-		const current = queue.pop();
-		const adjacents = Object.keys(conversions[current]);
+"use strict";
 
-		for (let len = adjacents.length, i = 0; i < len; i++) {
-			const adjacent = adjacents[i];
-			const node = graph[adjacent];
+const os = __nccwpck_require__(22037);
+const tty = __nccwpck_require__(76224);
+const hasFlag = __nccwpck_require__(87583);
 
-			if (node.distance === -1) {
-				node.distance = graph[current].distance + 1;
-				node.parent = current;
-				queue.unshift(adjacent);
-			}
-		}
-	}
+const {env} = process;
 
-	return graph;
+let forceColor;
+if (hasFlag('no-color') ||
+	hasFlag('no-colors') ||
+	hasFlag('color=false') ||
+	hasFlag('color=never')) {
+	forceColor = 0;
+} else if (hasFlag('color') ||
+	hasFlag('colors') ||
+	hasFlag('color=true') ||
+	hasFlag('color=always')) {
+	forceColor = 1;
 }
 
-function link(from, to) {
-	return function (args) {
-		return to(from(args));
-	};
+if ('FORCE_COLOR' in env) {
+	if (env.FORCE_COLOR === 'true') {
+		forceColor = 1;
+	} else if (env.FORCE_COLOR === 'false') {
+		forceColor = 0;
+	} else {
+		forceColor = env.FORCE_COLOR.length === 0 ? 1 : Math.min(parseInt(env.FORCE_COLOR, 10), 3);
+	}
 }
 
-function wrapConversion(toModel, graph) {
-	const path = [graph[toModel].parent, toModel];
-	let fn = conversions[graph[toModel].parent][toModel];
-
-	let cur = graph[toModel].parent;
-	while (graph[cur].parent) {
-		path.unshift(graph[cur].parent);
-		fn = link(conversions[graph[cur].parent][cur], fn);
-		cur = graph[cur].parent;
+function translateLevel(level) {
+	if (level === 0) {
+		return false;
 	}
 
-	fn.conversion = path;
-	return fn;
+	return {
+		level,
+		hasBasic: true,
+		has256: level >= 2,
+		has16m: level >= 3
+	};
 }
 
-module.exports = function (fromModel) {
-	const graph = deriveBFS(fromModel);
-	const conversion = {};
-
-	const models = Object.keys(graph);
-	for (let len = models.length, i = 0; i < len; i++) {
-		const toModel = models[i];
-		const node = graph[toModel];
-
-		if (node.parent === null) {
-			// No possible conversion, or this node is the source model.
-			continue;
-		}
-
-		conversion[toModel] = wrapConversion(toModel, graph);
+function supportsColor(haveStream, streamIsTTY) {
+	if (forceColor === 0) {
+		return 0;
 	}
 
-	return conversion;
-};
-
-
+	if (hasFlag('color=16m') ||
+		hasFlag('color=full') ||
+		hasFlag('color=truecolor')) {
+		return 3;
+	}
 
-/***/ }),
+	if (hasFlag('color=256')) {
+		return 2;
+	}
 
-/***/ 13474:
-/***/ ((module) => {
+	if (haveStream && !streamIsTTY && forceColor === undefined) {
+		return 0;
+	}
 
-const flagSymbol = Symbol('arg flag');
+	const min = forceColor || 0;
 
-function arg(opts, {argv = process.argv.slice(2), permissive = false, stopAtPositional = false} = {}) {
-	if (!opts) {
-		throw new Error('Argument specification object is required');
+	if (env.TERM === 'dumb') {
+		return min;
 	}
 
-	const result = {_: []};
+	if (process.platform === 'win32') {
+		// Windows 10 build 10586 is the first Windows release that supports 256 colors.
+		// Windows 10 build 14931 is the first release that supports 16m/TrueColor.
+		const osRelease = os.release().split('.');
+		if (
+			Number(osRelease[0]) >= 10 &&
+			Number(osRelease[2]) >= 10586
+		) {
+			return Number(osRelease[2]) >= 14931 ? 3 : 2;
+		}
 
-	const aliases = {};
-	const handlers = {};
+		return 1;
+	}
 
-	for (const key of Object.keys(opts)) {
-		if (!key) {
-			throw new TypeError('Argument key cannot be an empty string');
+	if ('CI' in env) {
+		if (['TRAVIS', 'CIRCLECI', 'APPVEYOR', 'GITLAB_CI', 'GITHUB_ACTIONS', 'BUILDKITE'].some(sign => sign in env) || env.CI_NAME === 'codeship') {
+			return 1;
 		}
 
-		if (key[0] !== '-') {
-			throw new TypeError(`Argument key must start with '-' but found: '${key}'`);
-		}
+		return min;
+	}
 
-		if (key.length === 1) {
-			throw new TypeError(`Argument key must have a name; singular '-' keys are not allowed: ${key}`);
-		}
+	if ('TEAMCITY_VERSION' in env) {
+		return /^(9\.(0*[1-9]\d*)\.|\d{2,}\.)/.test(env.TEAMCITY_VERSION) ? 1 : 0;
+	}
 
-		if (typeof opts[key] === 'string') {
-			aliases[key] = opts[key];
-			continue;
-		}
+	if (env.COLORTERM === 'truecolor') {
+		return 3;
+	}
 
-		let type = opts[key];
-		let isFlag = false;
+	if ('TERM_PROGRAM' in env) {
+		const version = parseInt((env.TERM_PROGRAM_VERSION || '').split('.')[0], 10);
 
-		if (Array.isArray(type) && type.length === 1 && typeof type[0] === 'function') {
-			const [fn] = type;
-			type = (value, name, prev = []) => {
-				prev.push(fn(value, name, prev[prev.length - 1]));
-				return prev;
-			};
-			isFlag = fn === Boolean || fn[flagSymbol] === true;
-		} else if (typeof type === 'function') {
-			isFlag = type === Boolean || type[flagSymbol] === true;
-		} else {
-			throw new TypeError(`Type missing or not a function or valid array type: ${key}`);
+		switch (env.TERM_PROGRAM) {
+			case 'iTerm.app':
+				return version >= 3 ? 3 : 2;
+			case 'Apple_Terminal':
+				return 2;
+			// No default
 		}
+	}
 
-		if (key[1] !== '-' && key.length > 2) {
-			throw new TypeError(`Short argument keys (with a single hyphen) must have only one character: ${key}`);
-		}
+	if (/-256(color)?$/i.test(env.TERM)) {
+		return 2;
+	}
 
-		handlers[key] = [type, isFlag];
+	if (/^screen|^xterm|^vt100|^vt220|^rxvt|color|ansi|cygwin|linux/i.test(env.TERM)) {
+		return 1;
 	}
 
-	for (let i = 0, len = argv.length; i < len; i++) {
-		const wholeArg = argv[i];
+	if ('COLORTERM' in env) {
+		return 1;
+	}
 
-		if (stopAtPositional && result._.length > 0) {
-			result._ = result._.concat(argv.slice(i));
-			break;
-		}
+	return min;
+}
 
-		if (wholeArg === '--') {
-			result._ = result._.concat(argv.slice(i + 1));
-			break;
-		}
+function getSupportLevel(stream) {
+	const level = supportsColor(stream, stream && stream.isTTY);
+	return translateLevel(level);
+}
 
-		if (wholeArg.length > 1 && wholeArg[0] === '-') {
-			/* eslint-disable operator-linebreak */
-			const separatedArguments = (wholeArg[1] === '-' || wholeArg.length === 2)
-				? [wholeArg]
-				: wholeArg.slice(1).split('').map(a => `-${a}`);
-			/* eslint-enable operator-linebreak */
+module.exports = {
+	supportsColor: getSupportLevel,
+	stdout: translateLevel(supportsColor(true, tty.isatty(1))),
+	stderr: translateLevel(supportsColor(true, tty.isatty(2)))
+};
 
-			for (let j = 0; j < separatedArguments.length; j++) {
-				const arg = separatedArguments[j];
-				const [originalArgName, argStr] = arg[1] === '-' ? arg.split(/=(.*)/, 2) : [arg, undefined];
 
-				let argName = originalArgName;
-				while (argName in aliases) {
-					argName = aliases[argName];
-				}
+/***/ }),
 
-				if (!(argName in handlers)) {
-					if (permissive) {
-						result._.push(arg);
-						continue;
-					} else {
-						const err = new Error(`Unknown or unexpected option: ${originalArgName}`);
-						err.code = 'ARG_UNKNOWN_OPTION';
-						throw err;
-					}
-				}
+/***/ 36662:
+/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
-				const [type, isFlag] = handlers[argName];
+"use strict";
 
-				if (!isFlag && ((j + 1) < separatedArguments.length)) {
-					throw new TypeError(`Option requires argument (but was followed by another short argument): ${originalArgName}`);
-				}
+const ansiStyles = __nccwpck_require__(93799);
+const {stdout: stdoutColor, stderr: stderrColor} = __nccwpck_require__(66573);
+const {
+	stringReplaceAll,
+	stringEncaseCRLFWithFirstIndex
+} = __nccwpck_require__(59207);
 
-				if (isFlag) {
-					result[argName] = type(true, argName, result[argName]);
-				} else if (argStr === undefined) {
-					if (
-						argv.length < i + 2 ||
-						(
-							argv[i + 1].length > 1 &&
-							(argv[i + 1][0] === '-') &&
-							!(
-								argv[i + 1].match(/^-?\d*(\.(?=\d))?\d*$/) &&
-								(
-									type === Number ||
-									// eslint-disable-next-line no-undef
-									(typeof BigInt !== 'undefined' && type === BigInt)
-								)
-							)
-						)
-					) {
-						const extended = originalArgName === argName ? '' : ` (alias for ${argName})`;
-						throw new Error(`Option requires argument: ${originalArgName}${extended}`);
-					}
+const {isArray} = Array;
 
-					result[argName] = type(argv[i + 1], argName, result[argName]);
-					++i;
-				} else {
-					result[argName] = type(argStr, argName, result[argName]);
-				}
-			}
-		} else {
-			result._.push(wholeArg);
-		}
-	}
+// `supportsColor.level` → `ansiStyles.color[name]` mapping
+const levelMapping = [
+	'ansi',
+	'ansi',
+	'ansi256',
+	'ansi16m'
+];
 
-	return result;
-}
+const styles = Object.create(null);
 
-arg.flag = fn => {
-	fn[flagSymbol] = true;
-	return fn;
-};
+const applyOptions = (object, options = {}) => {
+	if (options.level && !(Number.isInteger(options.level) && options.level >= 0 && options.level <= 3)) {
+		throw new Error('The `level` option should be an integer from 0 to 3');
+	}
 
-// Utility types
-arg.COUNT = arg.flag((v, name, existingCount) => (existingCount || 0) + 1);
+	// Detect level if not set manually
+	const colorLevel = stdoutColor ? stdoutColor.level : 0;
+	object.level = options.level === undefined ? colorLevel : options.level;
+};
 
-module.exports = arg;
+class ChalkClass {
+	constructor(options) {
+		// eslint-disable-next-line no-constructor-return
+		return chalkFactory(options);
+	}
+}
 
+const chalkFactory = options => {
+	const chalk = {};
+	applyOptions(chalk, options);
 
-/***/ }),
+	chalk.template = (...arguments_) => chalkTag(chalk.template, ...arguments_);
 
-/***/ 94015:
-/***/ ((module) => {
+	Object.setPrototypeOf(chalk, Chalk.prototype);
+	Object.setPrototypeOf(chalk.template, chalk);
 
-"use strict";
+	chalk.template.constructor = () => {
+		throw new Error('`chalk.constructor()` is deprecated. Use `new chalk.Instance()` instead.');
+	};
 
-module.exports = balanced;
-function balanced(a, b, str) {
-  if (a instanceof RegExp) a = maybeMatch(a, str);
-  if (b instanceof RegExp) b = maybeMatch(b, str);
+	chalk.template.Instance = ChalkClass;
 
-  var r = range(a, b, str);
+	return chalk.template;
+};
 
-  return r && {
-    start: r[0],
-    end: r[1],
-    pre: str.slice(0, r[0]),
-    body: str.slice(r[0] + a.length, r[1]),
-    post: str.slice(r[1] + b.length)
-  };
+function Chalk(options) {
+	return chalkFactory(options);
 }
 
-function maybeMatch(reg, str) {
-  var m = str.match(reg);
-  return m ? m[0] : null;
+for (const [styleName, style] of Object.entries(ansiStyles)) {
+	styles[styleName] = {
+		get() {
+			const builder = createBuilder(this, createStyler(style.open, style.close, this._styler), this._isEmpty);
+			Object.defineProperty(this, styleName, {value: builder});
+			return builder;
+		}
+	};
 }
 
-balanced.range = range;
-function range(a, b, str) {
-  var begs, beg, left, right, result;
-  var ai = str.indexOf(a);
-  var bi = str.indexOf(b, ai + 1);
-  var i = ai;
+styles.visible = {
+	get() {
+		const builder = createBuilder(this, this._styler, true);
+		Object.defineProperty(this, 'visible', {value: builder});
+		return builder;
+	}
+};
 
-  if (ai >= 0 && bi > 0) {
-    if(a===b) {
-      return [ai, bi];
-    }
-    begs = [];
-    left = str.length;
+const usedModels = ['rgb', 'hex', 'keyword', 'hsl', 'hsv', 'hwb', 'ansi', 'ansi256'];
 
-    while (i >= 0 && !result) {
-      if (i == ai) {
-        begs.push(i);
-        ai = str.indexOf(a, i + 1);
-      } else if (begs.length == 1) {
-        result = [ begs.pop(), bi ];
-      } else {
-        beg = begs.pop();
-        if (beg < left) {
-          left = beg;
-          right = bi;
-        }
+for (const model of usedModels) {
+	styles[model] = {
+		get() {
+			const {level} = this;
+			return function (...arguments_) {
+				const styler = createStyler(ansiStyles.color[levelMapping[level]][model](...arguments_), ansiStyles.color.close, this._styler);
+				return createBuilder(this, styler, this._isEmpty);
+			};
+		}
+	};
+}
 
-        bi = str.indexOf(b, i + 1);
-      }
+for (const model of usedModels) {
+	const bgModel = 'bg' + model[0].toUpperCase() + model.slice(1);
+	styles[bgModel] = {
+		get() {
+			const {level} = this;
+			return function (...arguments_) {
+				const styler = createStyler(ansiStyles.bgColor[levelMapping[level]][model](...arguments_), ansiStyles.bgColor.close, this._styler);
+				return createBuilder(this, styler, this._isEmpty);
+			};
+		}
+	};
+}
 
-      i = ai < bi && ai >= 0 ? ai : bi;
-    }
+const proto = Object.defineProperties(() => {}, {
+	...styles,
+	level: {
+		enumerable: true,
+		get() {
+			return this._generator.level;
+		},
+		set(level) {
+			this._generator.level = level;
+		}
+	}
+});
 
-    if (begs.length) {
-      result = [ left, right ];
-    }
-  }
+const createStyler = (open, close, parent) => {
+	let openAll;
+	let closeAll;
+	if (parent === undefined) {
+		openAll = open;
+		closeAll = close;
+	} else {
+		openAll = parent.openAll + open;
+		closeAll = close + parent.closeAll;
+	}
 
-  return result;
-}
+	return {
+		open,
+		close,
+		openAll,
+		closeAll,
+		parent
+	};
+};
 
+const createBuilder = (self, _styler, _isEmpty) => {
+	const builder = (...arguments_) => {
+		if (isArray(arguments_[0]) && isArray(arguments_[0].raw)) {
+			// Called as a template literal, for example: chalk.red`2 + 3 = {bold ${2+3}}`
+			return applyStyle(builder, chalkTag(builder, ...arguments_));
+		}
 
-/***/ }),
+		// Single argument is hot path, implicit coercion is faster than anything
+		// eslint-disable-next-line no-implicit-coercion
+		return applyStyle(builder, (arguments_.length === 1) ? ('' + arguments_[0]) : arguments_.join(' '));
+	};
 
-/***/ 74286:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+	// We alter the prototype because we must return a function, but there is
+	// no way to create a function with a different prototype
+	Object.setPrototypeOf(builder, proto);
 
-"use strict";
+	builder._generator = self;
+	builder._styler = _styler;
+	builder._isEmpty = _isEmpty;
 
+	return builder;
+};
 
-const { Buffer } = __nccwpck_require__(14300)
-const symbol = Symbol.for('BufferList')
+const applyStyle = (self, string) => {
+	if (self.level <= 0 || !string) {
+		return self._isEmpty ? '' : string;
+	}
 
-function BufferList (buf) {
-  if (!(this instanceof BufferList)) {
-    return new BufferList(buf)
-  }
+	let styler = self._styler;
 
-  BufferList._init.call(this, buf)
-}
+	if (styler === undefined) {
+		return string;
+	}
 
-BufferList._init = function _init (buf) {
-  Object.defineProperty(this, symbol, { value: true })
+	const {openAll, closeAll} = styler;
+	if (string.indexOf('\u001B') !== -1) {
+		while (styler !== undefined) {
+			// Replace any instances already present with a re-opening code
+			// otherwise only the part of the string until said closing code
+			// will be colored, and the rest will simply be 'plain'.
+			string = stringReplaceAll(string, styler.close, styler.open);
 
-  this._bufs = []
-  this.length = 0
+			styler = styler.parent;
+		}
+	}
 
-  if (buf) {
-    this.append(buf)
-  }
-}
+	// We can move both next actions out of loop, because remaining actions in loop won't have
+	// any/visible effect on parts we add here. Close the styling before a linebreak and reopen
+	// after next line to fix a bleed issue on macOS: https://github.com/chalk/chalk/pull/92
+	const lfIndex = string.indexOf('\n');
+	if (lfIndex !== -1) {
+		string = stringEncaseCRLFWithFirstIndex(string, closeAll, openAll, lfIndex);
+	}
 
-BufferList.prototype._new = function _new (buf) {
-  return new BufferList(buf)
-}
+	return openAll + string + closeAll;
+};
 
-BufferList.prototype._offset = function _offset (offset) {
-  if (offset === 0) {
-    return [0, 0]
-  }
+let template;
+const chalkTag = (chalk, ...strings) => {
+	const [firstString] = strings;
 
-  let tot = 0
+	if (!isArray(firstString) || !isArray(firstString.raw)) {
+		// If chalk() was called by itself or with a string,
+		// return the string itself as a string.
+		return strings.join(' ');
+	}
 
-  for (let i = 0; i < this._bufs.length; i++) {
-    const _t = tot + this._bufs[i].length
-    if (offset < _t || i === this._bufs.length - 1) {
-      return [i, offset - tot]
-    }
-    tot = _t
-  }
-}
+	const arguments_ = strings.slice(1);
+	const parts = [firstString.raw[0]];
 
-BufferList.prototype._reverseOffset = function (blOffset) {
-  const bufferId = blOffset[0]
-  let offset = blOffset[1]
+	for (let i = 1; i < firstString.length; i++) {
+		parts.push(
+			String(arguments_[i - 1]).replace(/[{}\\]/g, '\\$&'),
+			String(firstString.raw[i])
+		);
+	}
 
-  for (let i = 0; i < bufferId; i++) {
-    offset += this._bufs[i].length
-  }
+	if (template === undefined) {
+		template = __nccwpck_require__(4081);
+	}
 
-  return offset
-}
+	return template(chalk, parts.join(''));
+};
 
-BufferList.prototype.get = function get (index) {
-  if (index > this.length || index < 0) {
-    return undefined
-  }
+Object.defineProperties(Chalk.prototype, styles);
 
-  const offset = this._offset(index)
+const chalk = Chalk(); // eslint-disable-line new-cap
+chalk.supportsColor = stdoutColor;
+chalk.stderr = Chalk({level: stderrColor ? stderrColor.level : 0}); // eslint-disable-line new-cap
+chalk.stderr.supportsColor = stderrColor;
 
-  return this._bufs[offset[0]][offset[1]]
-}
+module.exports = chalk;
 
-BufferList.prototype.slice = function slice (start, end) {
-  if (typeof start === 'number' && start < 0) {
-    start += this.length
-  }
 
-  if (typeof end === 'number' && end < 0) {
-    end += this.length
-  }
+/***/ }),
 
-  return this.copy(null, 0, start, end)
-}
+/***/ 4081:
+/***/ ((module) => {
 
-BufferList.prototype.copy = function copy (dst, dstStart, srcStart, srcEnd) {
-  if (typeof srcStart !== 'number' || srcStart < 0) {
-    srcStart = 0
-  }
+"use strict";
 
-  if (typeof srcEnd !== 'number' || srcEnd > this.length) {
-    srcEnd = this.length
-  }
+const TEMPLATE_REGEX = /(?:\\(u(?:[a-f\d]{4}|\{[a-f\d]{1,6}\})|x[a-f\d]{2}|.))|(?:\{(~)?(\w+(?:\([^)]*\))?(?:\.\w+(?:\([^)]*\))?)*)(?:[ \t]|(?=\r?\n)))|(\})|((?:.|[\r\n\f])+?)/gi;
+const STYLE_REGEX = /(?:^|\.)(\w+)(?:\(([^)]*)\))?/g;
+const STRING_REGEX = /^(['"])((?:\\.|(?!\1)[^\\])*)\1$/;
+const ESCAPE_REGEX = /\\(u(?:[a-f\d]{4}|{[a-f\d]{1,6}})|x[a-f\d]{2}|.)|([^\\])/gi;
 
-  if (srcStart >= this.length) {
-    return dst || Buffer.alloc(0)
-  }
-
-  if (srcEnd <= 0) {
-    return dst || Buffer.alloc(0)
-  }
+const ESCAPES = new Map([
+	['n', '\n'],
+	['r', '\r'],
+	['t', '\t'],
+	['b', '\b'],
+	['f', '\f'],
+	['v', '\v'],
+	['0', '\0'],
+	['\\', '\\'],
+	['e', '\u001B'],
+	['a', '\u0007']
+]);
 
-  const copy = !!dst
-  const off = this._offset(srcStart)
-  const len = srcEnd - srcStart
-  let bytes = len
-  let bufoff = (copy && dstStart) || 0
-  let start = off[1]
+function unescape(c) {
+	const u = c[0] === 'u';
+	const bracket = c[1] === '{';
 
-  // copy/slice everything
-  if (srcStart === 0 && srcEnd === this.length) {
-    if (!copy) {
-      // slice, but full concat if multiple buffers
-      return this._bufs.length === 1
-        ? this._bufs[0]
-        : Buffer.concat(this._bufs, this.length)
-    }
+	if ((u && !bracket && c.length === 5) || (c[0] === 'x' && c.length === 3)) {
+		return String.fromCharCode(parseInt(c.slice(1), 16));
+	}
 
-    // copy, need to copy individual buffers
-    for (let i = 0; i < this._bufs.length; i++) {
-      this._bufs[i].copy(dst, bufoff)
-      bufoff += this._bufs[i].length
-    }
+	if (u && bracket) {
+		return String.fromCodePoint(parseInt(c.slice(2, -1), 16));
+	}
 
-    return dst
-  }
+	return ESCAPES.get(c) || c;
+}
 
-  // easy, cheap case where it's a subset of one of the buffers
-  if (bytes <= this._bufs[off[0]].length - start) {
-    return copy
-      ? this._bufs[off[0]].copy(dst, dstStart, start, start + bytes)
-      : this._bufs[off[0]].slice(start, start + bytes)
-  }
+function parseArguments(name, arguments_) {
+	const results = [];
+	const chunks = arguments_.trim().split(/\s*,\s*/g);
+	let matches;
 
-  if (!copy) {
-    // a slice, we need something to copy in to
-    dst = Buffer.allocUnsafe(len)
-  }
+	for (const chunk of chunks) {
+		const number = Number(chunk);
+		if (!Number.isNaN(number)) {
+			results.push(number);
+		} else if ((matches = chunk.match(STRING_REGEX))) {
+			results.push(matches[2].replace(ESCAPE_REGEX, (m, escape, character) => escape ? unescape(escape) : character));
+		} else {
+			throw new Error(`Invalid Chalk template style argument: ${chunk} (in style '${name}')`);
+		}
+	}
 
-  for (let i = off[0]; i < this._bufs.length; i++) {
-    const l = this._bufs[i].length - start
+	return results;
+}
 
-    if (bytes > l) {
-      this._bufs[i].copy(dst, bufoff, start)
-      bufoff += l
-    } else {
-      this._bufs[i].copy(dst, bufoff, start, start + bytes)
-      bufoff += l
-      break
-    }
+function parseStyle(style) {
+	STYLE_REGEX.lastIndex = 0;
 
-    bytes -= l
+	const results = [];
+	let matches;
 
-    if (start) {
-      start = 0
-    }
-  }
+	while ((matches = STYLE_REGEX.exec(style)) !== null) {
+		const name = matches[1];
 
-  // safeguard so that we don't return uninitialized memory
-  if (dst.length > bufoff) return dst.slice(0, bufoff)
+		if (matches[2]) {
+			const args = parseArguments(name, matches[2]);
+			results.push([name].concat(args));
+		} else {
+			results.push([name]);
+		}
+	}
 
-  return dst
+	return results;
 }
 
-BufferList.prototype.shallowSlice = function shallowSlice (start, end) {
-  start = start || 0
-  end = typeof end !== 'number' ? this.length : end
-
-  if (start < 0) {
-    start += this.length
-  }
-
-  if (end < 0) {
-    end += this.length
-  }
+function buildStyle(chalk, styles) {
+	const enabled = {};
 
-  if (start === end) {
-    return this._new()
-  }
+	for (const layer of styles) {
+		for (const style of layer.styles) {
+			enabled[style[0]] = layer.inverse ? null : style.slice(1);
+		}
+	}
 
-  const startOffset = this._offset(start)
-  const endOffset = this._offset(end)
-  const buffers = this._bufs.slice(startOffset[0], endOffset[0] + 1)
+	let current = chalk;
+	for (const [styleName, styles] of Object.entries(enabled)) {
+		if (!Array.isArray(styles)) {
+			continue;
+		}
 
-  if (endOffset[1] === 0) {
-    buffers.pop()
-  } else {
-    buffers[buffers.length - 1] = buffers[buffers.length - 1].slice(0, endOffset[1])
-  }
+		if (!(styleName in current)) {
+			throw new Error(`Unknown Chalk style: ${styleName}`);
+		}
 
-  if (startOffset[1] !== 0) {
-    buffers[0] = buffers[0].slice(startOffset[1])
-  }
+		current = styles.length > 0 ? current[styleName](...styles) : current[styleName];
+	}
 
-  return this._new(buffers)
+	return current;
 }
 
-BufferList.prototype.toString = function toString (encoding, start, end) {
-  return this.slice(start, end).toString(encoding)
-}
+module.exports = (chalk, temporary) => {
+	const styles = [];
+	const chunks = [];
+	let chunk = [];
 
-BufferList.prototype.consume = function consume (bytes) {
-  // first, normalize the argument, in accordance with how Buffer does it
-  bytes = Math.trunc(bytes)
-  // do nothing if not a positive number
-  if (Number.isNaN(bytes) || bytes <= 0) return this
+	// eslint-disable-next-line max-params
+	temporary.replace(TEMPLATE_REGEX, (m, escapeCharacter, inverse, style, close, character) => {
+		if (escapeCharacter) {
+			chunk.push(unescape(escapeCharacter));
+		} else if (style) {
+			const string = chunk.join('');
+			chunk = [];
+			chunks.push(styles.length === 0 ? string : buildStyle(chalk, styles)(string));
+			styles.push({inverse, styles: parseStyle(style)});
+		} else if (close) {
+			if (styles.length === 0) {
+				throw new Error('Found extraneous } in Chalk template literal');
+			}
 
-  while (this._bufs.length) {
-    if (bytes >= this._bufs[0].length) {
-      bytes -= this._bufs[0].length
-      this.length -= this._bufs[0].length
-      this._bufs.shift()
-    } else {
-      this._bufs[0] = this._bufs[0].slice(bytes)
-      this.length -= bytes
-      break
-    }
-  }
+			chunks.push(buildStyle(chalk, styles)(chunk.join('')));
+			chunk = [];
+			styles.pop();
+		} else {
+			chunk.push(character);
+		}
+	});
 
-  return this
-}
+	chunks.push(chunk.join(''));
 
-BufferList.prototype.duplicate = function duplicate () {
-  const copy = this._new()
+	if (styles.length > 0) {
+		const errMessage = `Chalk template literal is missing ${styles.length} closing bracket${styles.length === 1 ? '' : 's'} (\`}\`)`;
+		throw new Error(errMessage);
+	}
 
-  for (let i = 0; i < this._bufs.length; i++) {
-    copy.append(this._bufs[i])
-  }
+	return chunks.join('');
+};
 
-  return copy
-}
 
-BufferList.prototype.append = function append (buf) {
-  if (buf == null) {
-    return this
-  }
+/***/ }),
 
-  if (buf.buffer) {
-    // append a view of the underlying ArrayBuffer
-    this._appendBuffer(Buffer.from(buf.buffer, buf.byteOffset, buf.byteLength))
-  } else if (Array.isArray(buf)) {
-    for (let i = 0; i < buf.length; i++) {
-      this.append(buf[i])
-    }
-  } else if (this._isBufferList(buf)) {
-    // unwrap argument into individual BufferLists
-    for (let i = 0; i < buf._bufs.length; i++) {
-      this.append(buf._bufs[i])
-    }
-  } else {
-    // coerce number arguments to strings, since Buffer(number) does
-    // uninitialized memory allocation
-    if (typeof buf === 'number') {
-      buf = buf.toString()
-    }
+/***/ 59207:
+/***/ ((module) => {
 
-    this._appendBuffer(Buffer.from(buf))
-  }
+"use strict";
 
-  return this
-}
 
-BufferList.prototype._appendBuffer = function appendBuffer (buf) {
-  this._bufs.push(buf)
-  this.length += buf.length
-}
+const stringReplaceAll = (string, substring, replacer) => {
+	let index = string.indexOf(substring);
+	if (index === -1) {
+		return string;
+	}
 
-BufferList.prototype.indexOf = function (search, offset, encoding) {
-  if (encoding === undefined && typeof offset === 'string') {
-    encoding = offset
-    offset = undefined
-  }
+	const substringLength = substring.length;
+	let endIndex = 0;
+	let returnValue = '';
+	do {
+		returnValue += string.substr(endIndex, index - endIndex) + substring + replacer;
+		endIndex = index + substringLength;
+		index = string.indexOf(substring, endIndex);
+	} while (index !== -1);
 
-  if (typeof search === 'function' || Array.isArray(search)) {
-    throw new TypeError('The "value" argument must be one of type string, Buffer, BufferList, or Uint8Array.')
-  } else if (typeof search === 'number') {
-    search = Buffer.from([search])
-  } else if (typeof search === 'string') {
-    search = Buffer.from(search, encoding)
-  } else if (this._isBufferList(search)) {
-    search = search.slice()
-  } else if (Array.isArray(search.buffer)) {
-    search = Buffer.from(search.buffer, search.byteOffset, search.byteLength)
-  } else if (!Buffer.isBuffer(search)) {
-    search = Buffer.from(search)
-  }
+	returnValue += string.substr(endIndex);
+	return returnValue;
+};
 
-  offset = Number(offset || 0)
+const stringEncaseCRLFWithFirstIndex = (string, prefix, postfix, index) => {
+	let endIndex = 0;
+	let returnValue = '';
+	do {
+		const gotCR = string[index - 1] === '\r';
+		returnValue += string.substr(endIndex, (gotCR ? index - 1 : index) - endIndex) + prefix + (gotCR ? '\r\n' : '\n') + postfix;
+		endIndex = index + 1;
+		index = string.indexOf('\n', endIndex);
+	} while (index !== -1);
 
-  if (isNaN(offset)) {
-    offset = 0
-  }
+	returnValue += string.substr(endIndex);
+	return returnValue;
+};
 
-  if (offset < 0) {
-    offset = this.length + offset
-  }
+module.exports = {
+	stringReplaceAll,
+	stringEncaseCRLFWithFirstIndex
+};
 
-  if (offset < 0) {
-    offset = 0
-  }
 
-  if (search.length === 0) {
-    return offset > this.length ? this.length : offset
-  }
+/***/ }),
 
-  const blOffset = this._offset(offset)
-  let blIndex = blOffset[0] // index of which internal buffer we're working on
-  let buffOffset = blOffset[1] // offset of the internal buffer we're working on
+/***/ 78567:
+/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
-  // scan over each buffer
-  for (; blIndex < this._bufs.length; blIndex++) {
-    const buff = this._bufs[blIndex]
+/* MIT license */
+/* eslint-disable no-mixed-operators */
+const cssKeywords = __nccwpck_require__(22365);
 
-    while (buffOffset < buff.length) {
-      const availableWindow = buff.length - buffOffset
+// NOTE: conversions should only return primitive values (i.e. arrays, or
+//       values that give correct `typeof` results).
+//       do not use box values types (i.e. Number(), String(), etc.)
 
-      if (availableWindow >= search.length) {
-        const nativeSearchResult = buff.indexOf(search, buffOffset)
+const reverseKeywords = {};
+for (const key of Object.keys(cssKeywords)) {
+	reverseKeywords[cssKeywords[key]] = key;
+}
 
-        if (nativeSearchResult !== -1) {
-          return this._reverseOffset([blIndex, nativeSearchResult])
-        }
+const convert = {
+	rgb: {channels: 3, labels: 'rgb'},
+	hsl: {channels: 3, labels: 'hsl'},
+	hsv: {channels: 3, labels: 'hsv'},
+	hwb: {channels: 3, labels: 'hwb'},
+	cmyk: {channels: 4, labels: 'cmyk'},
+	xyz: {channels: 3, labels: 'xyz'},
+	lab: {channels: 3, labels: 'lab'},
+	lch: {channels: 3, labels: 'lch'},
+	hex: {channels: 1, labels: ['hex']},
+	keyword: {channels: 1, labels: ['keyword']},
+	ansi16: {channels: 1, labels: ['ansi16']},
+	ansi256: {channels: 1, labels: ['ansi256']},
+	hcg: {channels: 3, labels: ['h', 'c', 'g']},
+	apple: {channels: 3, labels: ['r16', 'g16', 'b16']},
+	gray: {channels: 1, labels: ['gray']}
+};
 
-        buffOffset = buff.length - search.length + 1 // end of native search window
-      } else {
-        const revOffset = this._reverseOffset([blIndex, buffOffset])
+module.exports = convert;
 
-        if (this._match(revOffset, search)) {
-          return revOffset
-        }
+// Hide .channels and .labels properties
+for (const model of Object.keys(convert)) {
+	if (!('channels' in convert[model])) {
+		throw new Error('missing channels property: ' + model);
+	}
 
-        buffOffset++
-      }
-    }
+	if (!('labels' in convert[model])) {
+		throw new Error('missing channel labels property: ' + model);
+	}
 
-    buffOffset = 0
-  }
+	if (convert[model].labels.length !== convert[model].channels) {
+		throw new Error('channel and label counts mismatch: ' + model);
+	}
 
-  return -1
+	const {channels, labels} = convert[model];
+	delete convert[model].channels;
+	delete convert[model].labels;
+	Object.defineProperty(convert[model], 'channels', {value: channels});
+	Object.defineProperty(convert[model], 'labels', {value: labels});
 }
 
-BufferList.prototype._match = function (offset, search) {
-  if (this.length - offset < search.length) {
-    return false
-  }
-
-  for (let searchOffset = 0; searchOffset < search.length; searchOffset++) {
-    if (this.get(offset + searchOffset) !== search[searchOffset]) {
-      return false
-    }
-  }
-  return true
-}
+convert.rgb.hsl = function (rgb) {
+	const r = rgb[0] / 255;
+	const g = rgb[1] / 255;
+	const b = rgb[2] / 255;
+	const min = Math.min(r, g, b);
+	const max = Math.max(r, g, b);
+	const delta = max - min;
+	let h;
+	let s;
 
-;(function () {
-  const methods = {
-    readDoubleBE: 8,
-    readDoubleLE: 8,
-    readFloatBE: 4,
-    readFloatLE: 4,
-    readInt32BE: 4,
-    readInt32LE: 4,
-    readUInt32BE: 4,
-    readUInt32LE: 4,
-    readInt16BE: 2,
-    readInt16LE: 2,
-    readUInt16BE: 2,
-    readUInt16LE: 2,
-    readInt8: 1,
-    readUInt8: 1,
-    readIntBE: null,
-    readIntLE: null,
-    readUIntBE: null,
-    readUIntLE: null
-  }
+	if (max === min) {
+		h = 0;
+	} else if (r === max) {
+		h = (g - b) / delta;
+	} else if (g === max) {
+		h = 2 + (b - r) / delta;
+	} else if (b === max) {
+		h = 4 + (r - g) / delta;
+	}
 
-  for (const m in methods) {
-    (function (m) {
-      if (methods[m] === null) {
-        BufferList.prototype[m] = function (offset, byteLength) {
-          return this.slice(offset, offset + byteLength)[m](0, byteLength)
-        }
-      } else {
-        BufferList.prototype[m] = function (offset = 0) {
-          return this.slice(offset, offset + methods[m])[m](0)
-        }
-      }
-    }(m))
-  }
-}())
+	h = Math.min(h * 60, 360);
 
-// Used internally by the class and also as an indicator of this object being
-// a `BufferList`. It's not possible to use `instanceof BufferList` in a browser
-// environment because there could be multiple different copies of the
-// BufferList class and some `BufferList`s might be `BufferList`s.
-BufferList.prototype._isBufferList = function _isBufferList (b) {
-  return b instanceof BufferList || BufferList.isBufferList(b)
-}
+	if (h < 0) {
+		h += 360;
+	}
 
-BufferList.isBufferList = function isBufferList (b) {
-  return b != null && b[symbol]
-}
+	const l = (min + max) / 2;
 
-module.exports = BufferList
+	if (max === min) {
+		s = 0;
+	} else if (l <= 0.5) {
+		s = delta / (max + min);
+	} else {
+		s = delta / (2 - max - min);
+	}
 
+	return [h, s * 100, l * 100];
+};
 
-/***/ }),
+convert.rgb.hsv = function (rgb) {
+	let rdif;
+	let gdif;
+	let bdif;
+	let h;
+	let s;
 
-/***/ 1236:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+	const r = rgb[0] / 255;
+	const g = rgb[1] / 255;
+	const b = rgb[2] / 255;
+	const v = Math.max(r, g, b);
+	const diff = v - Math.min(r, g, b);
+	const diffc = function (c) {
+		return (v - c) / 6 / diff + 1 / 2;
+	};
 
-"use strict";
+	if (diff === 0) {
+		h = 0;
+		s = 0;
+	} else {
+		s = diff / v;
+		rdif = diffc(r);
+		gdif = diffc(g);
+		bdif = diffc(b);
 
+		if (r === v) {
+			h = bdif - gdif;
+		} else if (g === v) {
+			h = (1 / 3) + rdif - bdif;
+		} else if (b === v) {
+			h = (2 / 3) + gdif - rdif;
+		}
 
-const DuplexStream = (__nccwpck_require__(88550).Duplex)
-const inherits = __nccwpck_require__(2868)
-const BufferList = __nccwpck_require__(74286)
+		if (h < 0) {
+			h += 1;
+		} else if (h > 1) {
+			h -= 1;
+		}
+	}
 
-function BufferListStream (callback) {
-  if (!(this instanceof BufferListStream)) {
-    return new BufferListStream(callback)
-  }
+	return [
+		h * 360,
+		s * 100,
+		v * 100
+	];
+};
 
-  if (typeof callback === 'function') {
-    this._callback = callback
+convert.rgb.hwb = function (rgb) {
+	const r = rgb[0];
+	const g = rgb[1];
+	let b = rgb[2];
+	const h = convert.rgb.hsl(rgb)[0];
+	const w = 1 / 255 * Math.min(r, Math.min(g, b));
 
-    const piper = function piper (err) {
-      if (this._callback) {
-        this._callback(err)
-        this._callback = null
-      }
-    }.bind(this)
+	b = 1 - 1 / 255 * Math.max(r, Math.max(g, b));
 
-    this.on('pipe', function onPipe (src) {
-      src.on('error', piper)
-    })
-    this.on('unpipe', function onUnpipe (src) {
-      src.removeListener('error', piper)
-    })
+	return [h, w * 100, b * 100];
+};
 
-    callback = null
-  }
+convert.rgb.cmyk = function (rgb) {
+	const r = rgb[0] / 255;
+	const g = rgb[1] / 255;
+	const b = rgb[2] / 255;
 
-  BufferList._init.call(this, callback)
-  DuplexStream.call(this)
-}
+	const k = Math.min(1 - r, 1 - g, 1 - b);
+	const c = (1 - r - k) / (1 - k) || 0;
+	const m = (1 - g - k) / (1 - k) || 0;
+	const y = (1 - b - k) / (1 - k) || 0;
 
-inherits(BufferListStream, DuplexStream)
-Object.assign(BufferListStream.prototype, BufferList.prototype)
+	return [c * 100, m * 100, y * 100, k * 100];
+};
 
-BufferListStream.prototype._new = function _new (callback) {
-  return new BufferListStream(callback)
+function comparativeDistance(x, y) {
+	/*
+		See https://en.m.wikipedia.org/wiki/Euclidean_distance#Squared_Euclidean_distance
+	*/
+	return (
+		((x[0] - y[0]) ** 2) +
+		((x[1] - y[1]) ** 2) +
+		((x[2] - y[2]) ** 2)
+	);
 }
 
-BufferListStream.prototype._write = function _write (buf, encoding, callback) {
-  this._appendBuffer(buf)
-
-  if (typeof callback === 'function') {
-    callback()
-  }
-}
+convert.rgb.keyword = function (rgb) {
+	const reversed = reverseKeywords[rgb];
+	if (reversed) {
+		return reversed;
+	}
 
-BufferListStream.prototype._read = function _read (size) {
-  if (!this.length) {
-    return this.push(null)
-  }
+	let currentClosestDistance = Infinity;
+	let currentClosestKeyword;
 
-  size = Math.min(size, this.length)
-  this.push(this.slice(0, size))
-  this.consume(size)
-}
+	for (const keyword of Object.keys(cssKeywords)) {
+		const value = cssKeywords[keyword];
 
-BufferListStream.prototype.end = function end (chunk) {
-  DuplexStream.prototype.end.call(this, chunk)
+		// Compute comparative distance
+		const distance = comparativeDistance(rgb, value);
 
-  if (this._callback) {
-    this._callback(null, this.slice())
-    this._callback = null
-  }
-}
+		// Check if its less, if so set as closest
+		if (distance < currentClosestDistance) {
+			currentClosestDistance = distance;
+			currentClosestKeyword = keyword;
+		}
+	}
 
-BufferListStream.prototype._destroy = function _destroy (err, cb) {
-  this._bufs.length = 0
-  this.length = 0
-  cb(err)
-}
+	return currentClosestKeyword;
+};
 
-BufferListStream.prototype._isBufferList = function _isBufferList (b) {
-  return b instanceof BufferListStream || b instanceof BufferList || BufferListStream.isBufferList(b)
-}
+convert.keyword.rgb = function (keyword) {
+	return cssKeywords[keyword];
+};
 
-BufferListStream.isBufferList = BufferList.isBufferList
+convert.rgb.xyz = function (rgb) {
+	let r = rgb[0] / 255;
+	let g = rgb[1] / 255;
+	let b = rgb[2] / 255;
 
-module.exports = BufferListStream
-module.exports.BufferListStream = BufferListStream
-module.exports.BufferList = BufferList
+	// Assume sRGB
+	r = r > 0.04045 ? (((r + 0.055) / 1.055) ** 2.4) : (r / 12.92);
+	g = g > 0.04045 ? (((g + 0.055) / 1.055) ** 2.4) : (g / 12.92);
+	b = b > 0.04045 ? (((b + 0.055) / 1.055) ** 2.4) : (b / 12.92);
 
+	const x = (r * 0.4124) + (g * 0.3576) + (b * 0.1805);
+	const y = (r * 0.2126) + (g * 0.7152) + (b * 0.0722);
+	const z = (r * 0.0193) + (g * 0.1192) + (b * 0.9505);
 
-/***/ }),
+	return [x * 100, y * 100, z * 100];
+};
 
-/***/ 2473:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+convert.rgb.lab = function (rgb) {
+	const xyz = convert.rgb.xyz(rgb);
+	let x = xyz[0];
+	let y = xyz[1];
+	let z = xyz[2];
 
-"use strict";
+	x /= 95.047;
+	y /= 100;
+	z /= 108.883;
 
+	x = x > 0.008856 ? (x ** (1 / 3)) : (7.787 * x) + (16 / 116);
+	y = y > 0.008856 ? (y ** (1 / 3)) : (7.787 * y) + (16 / 116);
+	z = z > 0.008856 ? (z ** (1 / 3)) : (7.787 * z) + (16 / 116);
 
-const stringify = __nccwpck_require__(50947);
-const compile = __nccwpck_require__(41802);
-const expand = __nccwpck_require__(59727);
-const parse = __nccwpck_require__(89479);
+	const l = (116 * y) - 16;
+	const a = 500 * (x - y);
+	const b = 200 * (y - z);
 
-/**
- * Expand the given pattern or create a regex-compatible string.
- *
- * ```js
- * const braces = require('braces');
- * console.log(braces('{a,b,c}', { compile: true })); //=> ['(a|b|c)']
- * console.log(braces('{a,b,c}')); //=> ['a', 'b', 'c']
- * ```
- * @param {String} `str`
- * @param {Object} `options`
- * @return {String}
- * @api public
- */
+	return [l, a, b];
+};
 
-const braces = (input, options = {}) => {
-  let output = [];
+convert.hsl.rgb = function (hsl) {
+	const h = hsl[0] / 360;
+	const s = hsl[1] / 100;
+	const l = hsl[2] / 100;
+	let t2;
+	let t3;
+	let val;
 
-  if (Array.isArray(input)) {
-    for (let pattern of input) {
-      let result = braces.create(pattern, options);
-      if (Array.isArray(result)) {
-        output.push(...result);
-      } else {
-        output.push(result);
-      }
-    }
-  } else {
-    output = [].concat(braces.create(input, options));
-  }
+	if (s === 0) {
+		val = l * 255;
+		return [val, val, val];
+	}
 
-  if (options && options.expand === true && options.nodupes === true) {
-    output = [...new Set(output)];
-  }
-  return output;
-};
+	if (l < 0.5) {
+		t2 = l * (1 + s);
+	} else {
+		t2 = l + s - l * s;
+	}
 
-/**
- * Parse the given `str` with the given `options`.
- *
- * ```js
- * // braces.parse(pattern, [, options]);
- * const ast = braces.parse('a/{b,c}/d');
- * console.log(ast);
- * ```
- * @param {String} pattern Brace pattern to parse
- * @param {Object} options
- * @return {Object} Returns an AST
- * @api public
- */
+	const t1 = 2 * l - t2;
 
-braces.parse = (input, options = {}) => parse(input, options);
+	const rgb = [0, 0, 0];
+	for (let i = 0; i < 3; i++) {
+		t3 = h + 1 / 3 * -(i - 1);
+		if (t3 < 0) {
+			t3++;
+		}
 
-/**
- * Creates a braces string from an AST, or an AST node.
- *
- * ```js
- * const braces = require('braces');
- * let ast = braces.parse('foo/{a,b}/bar');
- * console.log(stringify(ast.nodes[2])); //=> '{a,b}'
- * ```
- * @param {String} `input` Brace pattern or AST.
- * @param {Object} `options`
- * @return {Array} Returns an array of expanded values.
- * @api public
- */
+		if (t3 > 1) {
+			t3--;
+		}
 
-braces.stringify = (input, options = {}) => {
-  if (typeof input === 'string') {
-    return stringify(braces.parse(input, options), options);
-  }
-  return stringify(input, options);
-};
+		if (6 * t3 < 1) {
+			val = t1 + (t2 - t1) * 6 * t3;
+		} else if (2 * t3 < 1) {
+			val = t2;
+		} else if (3 * t3 < 2) {
+			val = t1 + (t2 - t1) * (2 / 3 - t3) * 6;
+		} else {
+			val = t1;
+		}
 
-/**
- * Compiles a brace pattern into a regex-compatible, optimized string.
- * This method is called by the main [braces](#braces) function by default.
- *
- * ```js
- * const braces = require('braces');
- * console.log(braces.compile('a/{b,c}/d'));
- * //=> ['a/(b|c)/d']
- * ```
- * @param {String} `input` Brace pattern or AST.
- * @param {Object} `options`
- * @return {Array} Returns an array of expanded values.
- * @api public
- */
+		rgb[i] = val * 255;
+	}
 
-braces.compile = (input, options = {}) => {
-  if (typeof input === 'string') {
-    input = braces.parse(input, options);
-  }
-  return compile(input, options);
+	return rgb;
 };
 
-/**
- * Expands a brace pattern into an array. This method is called by the
- * main [braces](#braces) function when `options.expand` is true. Before
- * using this method it's recommended that you read the [performance notes](#performance))
- * and advantages of using [.compile](#compile) instead.
- *
- * ```js
- * const braces = require('braces');
- * console.log(braces.expand('a/{b,c}/d'));
- * //=> ['a/b/d', 'a/c/d'];
- * ```
- * @param {String} `pattern` Brace pattern
- * @param {Object} `options`
- * @return {Array} Returns an array of expanded values.
- * @api public
- */
+convert.hsl.hsv = function (hsl) {
+	const h = hsl[0];
+	let s = hsl[1] / 100;
+	let l = hsl[2] / 100;
+	let smin = s;
+	const lmin = Math.max(l, 0.01);
 
-braces.expand = (input, options = {}) => {
-  if (typeof input === 'string') {
-    input = braces.parse(input, options);
-  }
+	l *= 2;
+	s *= (l <= 1) ? l : 2 - l;
+	smin *= lmin <= 1 ? lmin : 2 - lmin;
+	const v = (l + s) / 2;
+	const sv = l === 0 ? (2 * smin) / (lmin + smin) : (2 * s) / (l + s);
 
-  let result = expand(input, options);
+	return [h, sv * 100, v * 100];
+};
 
-  // filter out empty strings if specified
-  if (options.noempty === true) {
-    result = result.filter(Boolean);
-  }
+convert.hsv.rgb = function (hsv) {
+	const h = hsv[0] / 60;
+	const s = hsv[1] / 100;
+	let v = hsv[2] / 100;
+	const hi = Math.floor(h) % 6;
 
-  // filter out duplicates if specified
-  if (options.nodupes === true) {
-    result = [...new Set(result)];
-  }
+	const f = h - Math.floor(h);
+	const p = 255 * v * (1 - s);
+	const q = 255 * v * (1 - (s * f));
+	const t = 255 * v * (1 - (s * (1 - f)));
+	v *= 255;
 
-  return result;
+	switch (hi) {
+		case 0:
+			return [v, t, p];
+		case 1:
+			return [q, v, p];
+		case 2:
+			return [p, v, t];
+		case 3:
+			return [p, q, v];
+		case 4:
+			return [t, p, v];
+		case 5:
+			return [v, p, q];
+	}
 };
 
-/**
- * Processes a brace pattern and returns either an expanded array
- * (if `options.expand` is true), a highly optimized regex-compatible string.
- * This method is called by the main [braces](#braces) function.
- *
- * ```js
- * const braces = require('braces');
- * console.log(braces.create('user-{200..300}/project-{a,b,c}-{1..10}'))
- * //=> 'user-(20[0-9]|2[1-9][0-9]|300)/project-(a|b|c)-([1-9]|10)'
- * ```
- * @param {String} `pattern` Brace pattern
- * @param {Object} `options`
- * @return {Array} Returns an array of expanded values.
- * @api public
- */
+convert.hsv.hsl = function (hsv) {
+	const h = hsv[0];
+	const s = hsv[1] / 100;
+	const v = hsv[2] / 100;
+	const vmin = Math.max(v, 0.01);
+	let sl;
+	let l;
 
-braces.create = (input, options = {}) => {
-  if (input === '' || input.length < 3) {
-    return [input];
-  }
+	l = (2 - s) * v;
+	const lmin = (2 - s) * vmin;
+	sl = s * vmin;
+	sl /= (lmin <= 1) ? lmin : 2 - lmin;
+	sl = sl || 0;
+	l /= 2;
 
- return options.expand !== true
-    ? braces.compile(input, options)
-    : braces.expand(input, options);
+	return [h, sl * 100, l * 100];
 };
 
-/**
- * Expose "braces"
- */
-
-module.exports = braces;
+// http://dev.w3.org/csswg/css-color/#hwb-to-rgb
+convert.hwb.rgb = function (hwb) {
+	const h = hwb[0] / 360;
+	let wh = hwb[1] / 100;
+	let bl = hwb[2] / 100;
+	const ratio = wh + bl;
+	let f;
 
+	// Wh + bl cant be > 1
+	if (ratio > 1) {
+		wh /= ratio;
+		bl /= ratio;
+	}
 
-/***/ }),
+	const i = Math.floor(6 * h);
+	const v = 1 - bl;
+	f = 6 * h - i;
 
-/***/ 41802:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+	if ((i & 0x01) !== 0) {
+		f = 1 - f;
+	}
 
-"use strict";
+	const n = wh + f * (v - wh); // Linear interpolation
 
+	let r;
+	let g;
+	let b;
+	/* eslint-disable max-statements-per-line,no-multi-spaces */
+	switch (i) {
+		default:
+		case 6:
+		case 0: r = v;  g = n;  b = wh; break;
+		case 1: r = n;  g = v;  b = wh; break;
+		case 2: r = wh; g = v;  b = n; break;
+		case 3: r = wh; g = n;  b = v; break;
+		case 4: r = n;  g = wh; b = v; break;
+		case 5: r = v;  g = wh; b = n; break;
+	}
+	/* eslint-enable max-statements-per-line,no-multi-spaces */
 
-const fill = __nccwpck_require__(12619);
-const utils = __nccwpck_require__(25078);
+	return [r * 255, g * 255, b * 255];
+};
 
-const compile = (ast, options = {}) => {
-  let walk = (node, parent = {}) => {
-    let invalidBlock = utils.isInvalidBrace(parent);
-    let invalidNode = node.invalid === true && options.escapeInvalid === true;
-    let invalid = invalidBlock === true || invalidNode === true;
-    let prefix = options.escapeInvalid === true ? '\\' : '';
-    let output = '';
+convert.cmyk.rgb = function (cmyk) {
+	const c = cmyk[0] / 100;
+	const m = cmyk[1] / 100;
+	const y = cmyk[2] / 100;
+	const k = cmyk[3] / 100;
 
-    if (node.isOpen === true) {
-      return prefix + node.value;
-    }
-    if (node.isClose === true) {
-      return prefix + node.value;
-    }
+	const r = 1 - Math.min(1, c * (1 - k) + k);
+	const g = 1 - Math.min(1, m * (1 - k) + k);
+	const b = 1 - Math.min(1, y * (1 - k) + k);
 
-    if (node.type === 'open') {
-      return invalid ? (prefix + node.value) : '(';
-    }
+	return [r * 255, g * 255, b * 255];
+};
 
-    if (node.type === 'close') {
-      return invalid ? (prefix + node.value) : ')';
-    }
+convert.xyz.rgb = function (xyz) {
+	const x = xyz[0] / 100;
+	const y = xyz[1] / 100;
+	const z = xyz[2] / 100;
+	let r;
+	let g;
+	let b;
 
-    if (node.type === 'comma') {
-      return node.prev.type === 'comma' ? '' : (invalid ? node.value : '|');
-    }
+	r = (x * 3.2406) + (y * -1.5372) + (z * -0.4986);
+	g = (x * -0.9689) + (y * 1.8758) + (z * 0.0415);
+	b = (x * 0.0557) + (y * -0.2040) + (z * 1.0570);
 
-    if (node.value) {
-      return node.value;
-    }
+	// Assume sRGB
+	r = r > 0.0031308
+		? ((1.055 * (r ** (1.0 / 2.4))) - 0.055)
+		: r * 12.92;
 
-    if (node.nodes && node.ranges > 0) {
-      let args = utils.reduce(node.nodes);
-      let range = fill(...args, { ...options, wrap: false, toRegex: true });
+	g = g > 0.0031308
+		? ((1.055 * (g ** (1.0 / 2.4))) - 0.055)
+		: g * 12.92;
 
-      if (range.length !== 0) {
-        return args.length > 1 && range.length > 1 ? `(${range})` : range;
-      }
-    }
+	b = b > 0.0031308
+		? ((1.055 * (b ** (1.0 / 2.4))) - 0.055)
+		: b * 12.92;
 
-    if (node.nodes) {
-      for (let child of node.nodes) {
-        output += walk(child, node);
-      }
-    }
-    return output;
-  };
+	r = Math.min(Math.max(0, r), 1);
+	g = Math.min(Math.max(0, g), 1);
+	b = Math.min(Math.max(0, b), 1);
 
-  return walk(ast);
+	return [r * 255, g * 255, b * 255];
 };
 
-module.exports = compile;
-
-
-/***/ }),
+convert.xyz.lab = function (xyz) {
+	let x = xyz[0];
+	let y = xyz[1];
+	let z = xyz[2];
 
-/***/ 46867:
-/***/ ((module) => {
+	x /= 95.047;
+	y /= 100;
+	z /= 108.883;
 
-"use strict";
+	x = x > 0.008856 ? (x ** (1 / 3)) : (7.787 * x) + (16 / 116);
+	y = y > 0.008856 ? (y ** (1 / 3)) : (7.787 * y) + (16 / 116);
+	z = z > 0.008856 ? (z ** (1 / 3)) : (7.787 * z) + (16 / 116);
 
+	const l = (116 * y) - 16;
+	const a = 500 * (x - y);
+	const b = 200 * (y - z);
 
-module.exports = {
-  MAX_LENGTH: 1024 * 64,
-
-  // Digits
-  CHAR_0: '0', /* 0 */
-  CHAR_9: '9', /* 9 */
-
-  // Alphabet chars.
-  CHAR_UPPERCASE_A: 'A', /* A */
-  CHAR_LOWERCASE_A: 'a', /* a */
-  CHAR_UPPERCASE_Z: 'Z', /* Z */
-  CHAR_LOWERCASE_Z: 'z', /* z */
-
-  CHAR_LEFT_PARENTHESES: '(', /* ( */
-  CHAR_RIGHT_PARENTHESES: ')', /* ) */
-
-  CHAR_ASTERISK: '*', /* * */
-
-  // Non-alphabetic chars.
-  CHAR_AMPERSAND: '&', /* & */
-  CHAR_AT: '@', /* @ */
-  CHAR_BACKSLASH: '\\', /* \ */
-  CHAR_BACKTICK: '`', /* ` */
-  CHAR_CARRIAGE_RETURN: '\r', /* \r */
-  CHAR_CIRCUMFLEX_ACCENT: '^', /* ^ */
-  CHAR_COLON: ':', /* : */
-  CHAR_COMMA: ',', /* , */
-  CHAR_DOLLAR: '$', /* . */
-  CHAR_DOT: '.', /* . */
-  CHAR_DOUBLE_QUOTE: '"', /* " */
-  CHAR_EQUAL: '=', /* = */
-  CHAR_EXCLAMATION_MARK: '!', /* ! */
-  CHAR_FORM_FEED: '\f', /* \f */
-  CHAR_FORWARD_SLASH: '/', /* / */
-  CHAR_HASH: '#', /* # */
-  CHAR_HYPHEN_MINUS: '-', /* - */
-  CHAR_LEFT_ANGLE_BRACKET: '<', /* < */
-  CHAR_LEFT_CURLY_BRACE: '{', /* { */
-  CHAR_LEFT_SQUARE_BRACKET: '[', /* [ */
-  CHAR_LINE_FEED: '\n', /* \n */
-  CHAR_NO_BREAK_SPACE: '\u00A0', /* \u00A0 */
-  CHAR_PERCENT: '%', /* % */
-  CHAR_PLUS: '+', /* + */
-  CHAR_QUESTION_MARK: '?', /* ? */
-  CHAR_RIGHT_ANGLE_BRACKET: '>', /* > */
-  CHAR_RIGHT_CURLY_BRACE: '}', /* } */
-  CHAR_RIGHT_SQUARE_BRACKET: ']', /* ] */
-  CHAR_SEMICOLON: ';', /* ; */
-  CHAR_SINGLE_QUOTE: '\'', /* ' */
-  CHAR_SPACE: ' ', /*   */
-  CHAR_TAB: '\t', /* \t */
-  CHAR_UNDERSCORE: '_', /* _ */
-  CHAR_VERTICAL_LINE: '|', /* | */
-  CHAR_ZERO_WIDTH_NOBREAK_SPACE: '\uFEFF' /* \uFEFF */
+	return [l, a, b];
 };
 
+convert.lab.xyz = function (lab) {
+	const l = lab[0];
+	const a = lab[1];
+	const b = lab[2];
+	let x;
+	let y;
+	let z;
 
-/***/ }),
+	y = (l + 16) / 116;
+	x = a / 500 + y;
+	z = y - b / 200;
 
-/***/ 59727:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+	const y2 = y ** 3;
+	const x2 = x ** 3;
+	const z2 = z ** 3;
+	y = y2 > 0.008856 ? y2 : (y - 16 / 116) / 7.787;
+	x = x2 > 0.008856 ? x2 : (x - 16 / 116) / 7.787;
+	z = z2 > 0.008856 ? z2 : (z - 16 / 116) / 7.787;
 
-"use strict";
+	x *= 95.047;
+	y *= 100;
+	z *= 108.883;
 
+	return [x, y, z];
+};
 
-const fill = __nccwpck_require__(12619);
-const stringify = __nccwpck_require__(50947);
-const utils = __nccwpck_require__(25078);
+convert.lab.lch = function (lab) {
+	const l = lab[0];
+	const a = lab[1];
+	const b = lab[2];
+	let h;
 
-const append = (queue = '', stash = '', enclose = false) => {
-  let result = [];
+	const hr = Math.atan2(b, a);
+	h = hr * 360 / 2 / Math.PI;
 
-  queue = [].concat(queue);
-  stash = [].concat(stash);
+	if (h < 0) {
+		h += 360;
+	}
 
-  if (!stash.length) return queue;
-  if (!queue.length) {
-    return enclose ? utils.flatten(stash).map(ele => `{${ele}}`) : stash;
-  }
+	const c = Math.sqrt(a * a + b * b);
 
-  for (let item of queue) {
-    if (Array.isArray(item)) {
-      for (let value of item) {
-        result.push(append(value, stash, enclose));
-      }
-    } else {
-      for (let ele of stash) {
-        if (enclose === true && typeof ele === 'string') ele = `{${ele}}`;
-        result.push(Array.isArray(ele) ? append(item, ele, enclose) : (item + ele));
-      }
-    }
-  }
-  return utils.flatten(result);
+	return [l, c, h];
 };
 
-const expand = (ast, options = {}) => {
-  let rangeLimit = options.rangeLimit === void 0 ? 1000 : options.rangeLimit;
-
-  let walk = (node, parent = {}) => {
-    node.queue = [];
-
-    let p = parent;
-    let q = parent.queue;
-
-    while (p.type !== 'brace' && p.type !== 'root' && p.parent) {
-      p = p.parent;
-      q = p.queue;
-    }
+convert.lch.lab = function (lch) {
+	const l = lch[0];
+	const c = lch[1];
+	const h = lch[2];
 
-    if (node.invalid || node.dollar) {
-      q.push(append(q.pop(), stringify(node, options)));
-      return;
-    }
+	const hr = h / 360 * 2 * Math.PI;
+	const a = c * Math.cos(hr);
+	const b = c * Math.sin(hr);
 
-    if (node.type === 'brace' && node.invalid !== true && node.nodes.length === 2) {
-      q.push(append(q.pop(), ['{}']));
-      return;
-    }
+	return [l, a, b];
+};
 
-    if (node.nodes && node.ranges > 0) {
-      let args = utils.reduce(node.nodes);
+convert.rgb.ansi16 = function (args, saturation = null) {
+	const [r, g, b] = args;
+	let value = saturation === null ? convert.rgb.hsv(args)[2] : saturation; // Hsv -> ansi16 optimization
 
-      if (utils.exceedsLimit(...args, options.step, rangeLimit)) {
-        throw new RangeError('expanded array length exceeds range limit. Use options.rangeLimit to increase or disable the limit.');
-      }
+	value = Math.round(value / 50);
 
-      let range = fill(...args, options);
-      if (range.length === 0) {
-        range = stringify(node, options);
-      }
+	if (value === 0) {
+		return 30;
+	}
 
-      q.push(append(q.pop(), range));
-      node.nodes = [];
-      return;
-    }
+	let ansi = 30
+		+ ((Math.round(b / 255) << 2)
+		| (Math.round(g / 255) << 1)
+		| Math.round(r / 255));
 
-    let enclose = utils.encloseBrace(node);
-    let queue = node.queue;
-    let block = node;
+	if (value === 2) {
+		ansi += 60;
+	}
 
-    while (block.type !== 'brace' && block.type !== 'root' && block.parent) {
-      block = block.parent;
-      queue = block.queue;
-    }
+	return ansi;
+};
 
-    for (let i = 0; i < node.nodes.length; i++) {
-      let child = node.nodes[i];
+convert.hsv.ansi16 = function (args) {
+	// Optimization here; we already know the value and don't need to get
+	// it converted for us.
+	return convert.rgb.ansi16(convert.hsv.rgb(args), args[2]);
+};
 
-      if (child.type === 'comma' && node.type === 'brace') {
-        if (i === 1) queue.push('');
-        queue.push('');
-        continue;
-      }
+convert.rgb.ansi256 = function (args) {
+	const r = args[0];
+	const g = args[1];
+	const b = args[2];
 
-      if (child.type === 'close') {
-        q.push(append(q.pop(), queue, enclose));
-        continue;
-      }
+	// We use the extended greyscale palette here, with the exception of
+	// black and white. normal palette only has 4 greyscale shades.
+	if (r === g && g === b) {
+		if (r < 8) {
+			return 16;
+		}
 
-      if (child.value && child.type !== 'open') {
-        queue.push(append(queue.pop(), child.value));
-        continue;
-      }
+		if (r > 248) {
+			return 231;
+		}
 
-      if (child.nodes) {
-        walk(child, node);
-      }
-    }
+		return Math.round(((r - 8) / 247) * 24) + 232;
+	}
 
-    return queue;
-  };
+	const ansi = 16
+		+ (36 * Math.round(r / 255 * 5))
+		+ (6 * Math.round(g / 255 * 5))
+		+ Math.round(b / 255 * 5);
 
-  return utils.flatten(walk(ast));
+	return ansi;
 };
 
-module.exports = expand;
+convert.ansi16.rgb = function (args) {
+	let color = args % 10;
 
+	// Handle greyscale
+	if (color === 0 || color === 7) {
+		if (args > 50) {
+			color += 3.5;
+		}
 
-/***/ }),
+		color = color / 10.5 * 255;
 
-/***/ 89479:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
-
-"use strict";
-
-
-const stringify = __nccwpck_require__(50947);
-
-/**
- * Constants
- */
-
-const {
-  MAX_LENGTH,
-  CHAR_BACKSLASH, /* \ */
-  CHAR_BACKTICK, /* ` */
-  CHAR_COMMA, /* , */
-  CHAR_DOT, /* . */
-  CHAR_LEFT_PARENTHESES, /* ( */
-  CHAR_RIGHT_PARENTHESES, /* ) */
-  CHAR_LEFT_CURLY_BRACE, /* { */
-  CHAR_RIGHT_CURLY_BRACE, /* } */
-  CHAR_LEFT_SQUARE_BRACKET, /* [ */
-  CHAR_RIGHT_SQUARE_BRACKET, /* ] */
-  CHAR_DOUBLE_QUOTE, /* " */
-  CHAR_SINGLE_QUOTE, /* ' */
-  CHAR_NO_BREAK_SPACE,
-  CHAR_ZERO_WIDTH_NOBREAK_SPACE
-} = __nccwpck_require__(46867);
-
-/**
- * parse
- */
-
-const parse = (input, options = {}) => {
-  if (typeof input !== 'string') {
-    throw new TypeError('Expected a string');
-  }
-
-  let opts = options || {};
-  let max = typeof opts.maxLength === 'number' ? Math.min(MAX_LENGTH, opts.maxLength) : MAX_LENGTH;
-  if (input.length > max) {
-    throw new SyntaxError(`Input length (${input.length}), exceeds max characters (${max})`);
-  }
-
-  let ast = { type: 'root', input, nodes: [] };
-  let stack = [ast];
-  let block = ast;
-  let prev = ast;
-  let brackets = 0;
-  let length = input.length;
-  let index = 0;
-  let depth = 0;
-  let value;
-  let memo = {};
-
-  /**
-   * Helpers
-   */
-
-  const advance = () => input[index++];
-  const push = node => {
-    if (node.type === 'text' && prev.type === 'dot') {
-      prev.type = 'text';
-    }
-
-    if (prev && prev.type === 'text' && node.type === 'text') {
-      prev.value += node.value;
-      return;
-    }
-
-    block.nodes.push(node);
-    node.parent = block;
-    node.prev = prev;
-    prev = node;
-    return node;
-  };
-
-  push({ type: 'bos' });
-
-  while (index < length) {
-    block = stack[stack.length - 1];
-    value = advance();
-
-    /**
-     * Invalid chars
-     */
-
-    if (value === CHAR_ZERO_WIDTH_NOBREAK_SPACE || value === CHAR_NO_BREAK_SPACE) {
-      continue;
-    }
-
-    /**
-     * Escaped chars
-     */
-
-    if (value === CHAR_BACKSLASH) {
-      push({ type: 'text', value: (options.keepEscaping ? value : '') + advance() });
-      continue;
-    }
-
-    /**
-     * Right square bracket (literal): ']'
-     */
-
-    if (value === CHAR_RIGHT_SQUARE_BRACKET) {
-      push({ type: 'text', value: '\\' + value });
-      continue;
-    }
-
-    /**
-     * Left square bracket: '['
-     */
-
-    if (value === CHAR_LEFT_SQUARE_BRACKET) {
-      brackets++;
-
-      let closed = true;
-      let next;
-
-      while (index < length && (next = advance())) {
-        value += next;
-
-        if (next === CHAR_LEFT_SQUARE_BRACKET) {
-          brackets++;
-          continue;
-        }
-
-        if (next === CHAR_BACKSLASH) {
-          value += advance();
-          continue;
-        }
-
-        if (next === CHAR_RIGHT_SQUARE_BRACKET) {
-          brackets--;
-
-          if (brackets === 0) {
-            break;
-          }
-        }
-      }
-
-      push({ type: 'text', value });
-      continue;
-    }
-
-    /**
-     * Parentheses
-     */
-
-    if (value === CHAR_LEFT_PARENTHESES) {
-      block = push({ type: 'paren', nodes: [] });
-      stack.push(block);
-      push({ type: 'text', value });
-      continue;
-    }
-
-    if (value === CHAR_RIGHT_PARENTHESES) {
-      if (block.type !== 'paren') {
-        push({ type: 'text', value });
-        continue;
-      }
-      block = stack.pop();
-      push({ type: 'text', value });
-      block = stack[stack.length - 1];
-      continue;
-    }
-
-    /**
-     * Quotes: '|"|`
-     */
-
-    if (value === CHAR_DOUBLE_QUOTE || value === CHAR_SINGLE_QUOTE || value === CHAR_BACKTICK) {
-      let open = value;
-      let next;
-
-      if (options.keepQuotes !== true) {
-        value = '';
-      }
-
-      while (index < length && (next = advance())) {
-        if (next === CHAR_BACKSLASH) {
-          value += next + advance();
-          continue;
-        }
-
-        if (next === open) {
-          if (options.keepQuotes === true) value += next;
-          break;
-        }
-
-        value += next;
-      }
-
-      push({ type: 'text', value });
-      continue;
-    }
+		return [color, color, color];
+	}
 
-    /**
-     * Left curly brace: '{'
-     */
+	const mult = (~~(args > 50) + 1) * 0.5;
+	const r = ((color & 1) * mult) * 255;
+	const g = (((color >> 1) & 1) * mult) * 255;
+	const b = (((color >> 2) & 1) * mult) * 255;
 
-    if (value === CHAR_LEFT_CURLY_BRACE) {
-      depth++;
-
-      let dollar = prev.value && prev.value.slice(-1) === '$' || block.dollar === true;
-      let brace = {
-        type: 'brace',
-        open: true,
-        close: false,
-        dollar,
-        depth,
-        commas: 0,
-        ranges: 0,
-        nodes: []
-      };
+	return [r, g, b];
+};
 
-      block = push(brace);
-      stack.push(block);
-      push({ type: 'open', value });
-      continue;
-    }
+convert.ansi256.rgb = function (args) {
+	// Handle greyscale
+	if (args >= 232) {
+		const c = (args - 232) * 10 + 8;
+		return [c, c, c];
+	}
 
-    /**
-     * Right curly brace: '}'
-     */
+	args -= 16;
 
-    if (value === CHAR_RIGHT_CURLY_BRACE) {
-      if (block.type !== 'brace') {
-        push({ type: 'text', value });
-        continue;
-      }
+	let rem;
+	const r = Math.floor(args / 36) / 5 * 255;
+	const g = Math.floor((rem = args % 36) / 6) / 5 * 255;
+	const b = (rem % 6) / 5 * 255;
 
-      let type = 'close';
-      block = stack.pop();
-      block.close = true;
+	return [r, g, b];
+};
 
-      push({ type, value });
-      depth--;
+convert.rgb.hex = function (args) {
+	const integer = ((Math.round(args[0]) & 0xFF) << 16)
+		+ ((Math.round(args[1]) & 0xFF) << 8)
+		+ (Math.round(args[2]) & 0xFF);
 
-      block = stack[stack.length - 1];
-      continue;
-    }
+	const string = integer.toString(16).toUpperCase();
+	return '000000'.substring(string.length) + string;
+};
 
-    /**
-     * Comma: ','
-     */
+convert.hex.rgb = function (args) {
+	const match = args.toString(16).match(/[a-f0-9]{6}|[a-f0-9]{3}/i);
+	if (!match) {
+		return [0, 0, 0];
+	}
 
-    if (value === CHAR_COMMA && depth > 0) {
-      if (block.ranges > 0) {
-        block.ranges = 0;
-        let open = block.nodes.shift();
-        block.nodes = [open, { type: 'text', value: stringify(block) }];
-      }
+	let colorString = match[0];
 
-      push({ type: 'comma', value });
-      block.commas++;
-      continue;
-    }
+	if (match[0].length === 3) {
+		colorString = colorString.split('').map(char => {
+			return char + char;
+		}).join('');
+	}
 
-    /**
-     * Dot: '.'
-     */
+	const integer = parseInt(colorString, 16);
+	const r = (integer >> 16) & 0xFF;
+	const g = (integer >> 8) & 0xFF;
+	const b = integer & 0xFF;
 
-    if (value === CHAR_DOT && depth > 0 && block.commas === 0) {
-      let siblings = block.nodes;
+	return [r, g, b];
+};
 
-      if (depth === 0 || siblings.length === 0) {
-        push({ type: 'text', value });
-        continue;
-      }
+convert.rgb.hcg = function (rgb) {
+	const r = rgb[0] / 255;
+	const g = rgb[1] / 255;
+	const b = rgb[2] / 255;
+	const max = Math.max(Math.max(r, g), b);
+	const min = Math.min(Math.min(r, g), b);
+	const chroma = (max - min);
+	let grayscale;
+	let hue;
 
-      if (prev.type === 'dot') {
-        block.range = [];
-        prev.value += value;
-        prev.type = 'range';
+	if (chroma < 1) {
+		grayscale = min / (1 - chroma);
+	} else {
+		grayscale = 0;
+	}
 
-        if (block.nodes.length !== 3 && block.nodes.length !== 5) {
-          block.invalid = true;
-          block.ranges = 0;
-          prev.type = 'text';
-          continue;
-        }
+	if (chroma <= 0) {
+		hue = 0;
+	} else
+	if (max === r) {
+		hue = ((g - b) / chroma) % 6;
+	} else
+	if (max === g) {
+		hue = 2 + (b - r) / chroma;
+	} else {
+		hue = 4 + (r - g) / chroma;
+	}
 
-        block.ranges++;
-        block.args = [];
-        continue;
-      }
+	hue /= 6;
+	hue %= 1;
 
-      if (prev.type === 'range') {
-        siblings.pop();
+	return [hue * 360, chroma * 100, grayscale * 100];
+};
 
-        let before = siblings[siblings.length - 1];
-        before.value += prev.value + value;
-        prev = before;
-        block.ranges--;
-        continue;
-      }
+convert.hsl.hcg = function (hsl) {
+	const s = hsl[1] / 100;
+	const l = hsl[2] / 100;
 
-      push({ type: 'dot', value });
-      continue;
-    }
+	const c = l < 0.5 ? (2.0 * s * l) : (2.0 * s * (1.0 - l));
 
-    /**
-     * Text
-     */
+	let f = 0;
+	if (c < 1.0) {
+		f = (l - 0.5 * c) / (1.0 - c);
+	}
 
-    push({ type: 'text', value });
-  }
+	return [hsl[0], c * 100, f * 100];
+};
 
-  // Mark imbalanced braces and brackets as invalid
-  do {
-    block = stack.pop();
+convert.hsv.hcg = function (hsv) {
+	const s = hsv[1] / 100;
+	const v = hsv[2] / 100;
 
-    if (block.type !== 'root') {
-      block.nodes.forEach(node => {
-        if (!node.nodes) {
-          if (node.type === 'open') node.isOpen = true;
-          if (node.type === 'close') node.isClose = true;
-          if (!node.nodes) node.type = 'text';
-          node.invalid = true;
-        }
-      });
+	const c = s * v;
+	let f = 0;
 
-      // get the location of the block on parent.nodes (block's siblings)
-      let parent = stack[stack.length - 1];
-      let index = parent.nodes.indexOf(block);
-      // replace the (invalid) block with it's nodes
-      parent.nodes.splice(index, 1, ...block.nodes);
-    }
-  } while (stack.length > 0);
+	if (c < 1.0) {
+		f = (v - c) / (1 - c);
+	}
 
-  push({ type: 'eos' });
-  return ast;
+	return [hsv[0], c * 100, f * 100];
 };
 
-module.exports = parse;
-
-
-/***/ }),
+convert.hcg.rgb = function (hcg) {
+	const h = hcg[0] / 360;
+	const c = hcg[1] / 100;
+	const g = hcg[2] / 100;
 
-/***/ 50947:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+	if (c === 0.0) {
+		return [g * 255, g * 255, g * 255];
+	}
 
-"use strict";
+	const pure = [0, 0, 0];
+	const hi = (h % 1) * 6;
+	const v = hi % 1;
+	const w = 1 - v;
+	let mg = 0;
 
+	/* eslint-disable max-statements-per-line */
+	switch (Math.floor(hi)) {
+		case 0:
+			pure[0] = 1; pure[1] = v; pure[2] = 0; break;
+		case 1:
+			pure[0] = w; pure[1] = 1; pure[2] = 0; break;
+		case 2:
+			pure[0] = 0; pure[1] = 1; pure[2] = v; break;
+		case 3:
+			pure[0] = 0; pure[1] = w; pure[2] = 1; break;
+		case 4:
+			pure[0] = v; pure[1] = 0; pure[2] = 1; break;
+		default:
+			pure[0] = 1; pure[1] = 0; pure[2] = w;
+	}
+	/* eslint-enable max-statements-per-line */
 
-const utils = __nccwpck_require__(25078);
+	mg = (1.0 - c) * g;
 
-module.exports = (ast, options = {}) => {
-  let stringify = (node, parent = {}) => {
-    let invalidBlock = options.escapeInvalid && utils.isInvalidBrace(parent);
-    let invalidNode = node.invalid === true && options.escapeInvalid === true;
-    let output = '';
+	return [
+		(c * pure[0] + mg) * 255,
+		(c * pure[1] + mg) * 255,
+		(c * pure[2] + mg) * 255
+	];
+};
 
-    if (node.value) {
-      if ((invalidBlock || invalidNode) && utils.isOpenOrClose(node)) {
-        return '\\' + node.value;
-      }
-      return node.value;
-    }
+convert.hcg.hsv = function (hcg) {
+	const c = hcg[1] / 100;
+	const g = hcg[2] / 100;
 
-    if (node.value) {
-      return node.value;
-    }
+	const v = c + g * (1.0 - c);
+	let f = 0;
 
-    if (node.nodes) {
-      for (let child of node.nodes) {
-        output += stringify(child);
-      }
-    }
-    return output;
-  };
+	if (v > 0.0) {
+		f = c / v;
+	}
 
-  return stringify(ast);
+	return [hcg[0], f * 100, v * 100];
 };
 
+convert.hcg.hsl = function (hcg) {
+	const c = hcg[1] / 100;
+	const g = hcg[2] / 100;
 
+	const l = g * (1.0 - c) + 0.5 * c;
+	let s = 0;
 
-/***/ }),
-
-/***/ 25078:
-/***/ ((__unused_webpack_module, exports) => {
-
-"use strict";
-
+	if (l > 0.0 && l < 0.5) {
+		s = c / (2 * l);
+	} else
+	if (l >= 0.5 && l < 1.0) {
+		s = c / (2 * (1 - l));
+	}
 
-exports.isInteger = num => {
-  if (typeof num === 'number') {
-    return Number.isInteger(num);
-  }
-  if (typeof num === 'string' && num.trim() !== '') {
-    return Number.isInteger(Number(num));
-  }
-  return false;
+	return [hcg[0], s * 100, l * 100];
 };
 
-/**
- * Find a node of the given type
- */
-
-exports.find = (node, type) => node.nodes.find(node => node.type === type);
-
-/**
- * Find a node of the given type
- */
-
-exports.exceedsLimit = (min, max, step = 1, limit) => {
-  if (limit === false) return false;
-  if (!exports.isInteger(min) || !exports.isInteger(max)) return false;
-  return ((Number(max) - Number(min)) / Number(step)) >= limit;
+convert.hcg.hwb = function (hcg) {
+	const c = hcg[1] / 100;
+	const g = hcg[2] / 100;
+	const v = c + g * (1.0 - c);
+	return [hcg[0], (v - c) * 100, (1 - v) * 100];
 };
 
-/**
- * Escape the given node with '\\' before node.value
- */
+convert.hwb.hcg = function (hwb) {
+	const w = hwb[1] / 100;
+	const b = hwb[2] / 100;
+	const v = 1 - b;
+	const c = v - w;
+	let g = 0;
 
-exports.escapeNode = (block, n = 0, type) => {
-  let node = block.nodes[n];
-  if (!node) return;
+	if (c < 1) {
+		g = (v - c) / (1 - c);
+	}
 
-  if ((type && node.type === type) || node.type === 'open' || node.type === 'close') {
-    if (node.escaped !== true) {
-      node.value = '\\' + node.value;
-      node.escaped = true;
-    }
-  }
+	return [hwb[0], c * 100, g * 100];
 };
 
-/**
- * Returns true if the given brace node should be enclosed in literal braces
- */
-
-exports.encloseBrace = node => {
-  if (node.type !== 'brace') return false;
-  if ((node.commas >> 0 + node.ranges >> 0) === 0) {
-    node.invalid = true;
-    return true;
-  }
-  return false;
+convert.apple.rgb = function (apple) {
+	return [(apple[0] / 65535) * 255, (apple[1] / 65535) * 255, (apple[2] / 65535) * 255];
 };
 
-/**
- * Returns true if a brace node is invalid.
- */
-
-exports.isInvalidBrace = block => {
-  if (block.type !== 'brace') return false;
-  if (block.invalid === true || block.dollar) return true;
-  if ((block.commas >> 0 + block.ranges >> 0) === 0) {
-    block.invalid = true;
-    return true;
-  }
-  if (block.open !== true || block.close !== true) {
-    block.invalid = true;
-    return true;
-  }
-  return false;
+convert.rgb.apple = function (rgb) {
+	return [(rgb[0] / 255) * 65535, (rgb[1] / 255) * 65535, (rgb[2] / 255) * 65535];
 };
 
-/**
- * Returns true if a node is an open or close node
- */
-
-exports.isOpenOrClose = node => {
-  if (node.type === 'open' || node.type === 'close') {
-    return true;
-  }
-  return node.open === true || node.close === true;
+convert.gray.rgb = function (args) {
+	return [args[0] / 100 * 255, args[0] / 100 * 255, args[0] / 100 * 255];
 };
 
-/**
- * Reduce an array of text nodes.
- */
-
-exports.reduce = nodes => nodes.reduce((acc, node) => {
-  if (node.type === 'text') acc.push(node.value);
-  if (node.type === 'range') node.type = 'text';
-  return acc;
-}, []);
-
-/**
- * Flatten an array
- */
-
-exports.flatten = (...args) => {
-  const result = [];
-  const flat = arr => {
-    for (let i = 0; i < arr.length; i++) {
-      let ele = arr[i];
-      Array.isArray(ele) ? flat(ele, result) : ele !== void 0 && result.push(ele);
-    }
-    return result;
-  };
-  flat(args);
-  return result;
+convert.gray.hsl = function (args) {
+	return [0, 0, args[0]];
 };
 
+convert.gray.hsv = convert.gray.hsl;
 
-/***/ }),
-
-/***/ 82415:
-/***/ ((module) => {
-
-/* eslint-disable node/no-deprecated-api */
-
-var toString = Object.prototype.toString
-
-var isModern = (
-  typeof Buffer !== 'undefined' &&
-  typeof Buffer.alloc === 'function' &&
-  typeof Buffer.allocUnsafe === 'function' &&
-  typeof Buffer.from === 'function'
-)
-
-function isArrayBuffer (input) {
-  return toString.call(input).slice(8, -1) === 'ArrayBuffer'
-}
-
-function fromArrayBuffer (obj, byteOffset, length) {
-  byteOffset >>>= 0
-
-  var maxLength = obj.byteLength - byteOffset
-
-  if (maxLength < 0) {
-    throw new RangeError("'offset' is out of bounds")
-  }
-
-  if (length === undefined) {
-    length = maxLength
-  } else {
-    length >>>= 0
-
-    if (length > maxLength) {
-      throw new RangeError("'length' is out of bounds")
-    }
-  }
-
-  return isModern
-    ? Buffer.from(obj.slice(byteOffset, byteOffset + length))
-    : new Buffer(new Uint8Array(obj.slice(byteOffset, byteOffset + length)))
-}
-
-function fromString (string, encoding) {
-  if (typeof encoding !== 'string' || encoding === '') {
-    encoding = 'utf8'
-  }
-
-  if (!Buffer.isEncoding(encoding)) {
-    throw new TypeError('"encoding" must be a valid string encoding')
-  }
-
-  return isModern
-    ? Buffer.from(string, encoding)
-    : new Buffer(string, encoding)
-}
+convert.gray.hwb = function (gray) {
+	return [0, 100, gray[0]];
+};
 
-function bufferFrom (value, encodingOrOffset, length) {
-  if (typeof value === 'number') {
-    throw new TypeError('"value" argument must not be a number')
-  }
+convert.gray.cmyk = function (gray) {
+	return [0, 0, 0, gray[0]];
+};
 
-  if (isArrayBuffer(value)) {
-    return fromArrayBuffer(value, encodingOrOffset, length)
-  }
+convert.gray.lab = function (gray) {
+	return [gray[0], 0, 0];
+};
 
-  if (typeof value === 'string') {
-    return fromString(value, encodingOrOffset)
-  }
+convert.gray.hex = function (gray) {
+	const val = Math.round(gray[0] / 100 * 255) & 0xFF;
+	const integer = (val << 16) + (val << 8) + val;
 
-  return isModern
-    ? Buffer.from(value)
-    : new Buffer(value)
-}
+	const string = integer.toString(16).toUpperCase();
+	return '000000'.substring(string.length) + string;
+};
 
-module.exports = bufferFrom
+convert.rgb.gray = function (rgb) {
+	const val = (rgb[0] + rgb[1] + rgb[2]) / 3;
+	return [val / 255 * 100];
+};
 
 
 /***/ }),
 
-/***/ 29541:
+/***/ 79713:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
-"use strict";
+const conversions = __nccwpck_require__(78567);
+const route = __nccwpck_require__(8411);
 
-const ansiStyles = __nccwpck_require__(3537);
-const {stdout: stdoutColor, stderr: stderrColor} = __nccwpck_require__(9679);
-const {
-	stringReplaceAll,
-	stringEncaseCRLFWithFirstIndex
-} = __nccwpck_require__(94187);
-
-const {isArray} = Array;
-
-// `supportsColor.level` → `ansiStyles.color[name]` mapping
-const levelMapping = [
-	'ansi',
-	'ansi',
-	'ansi256',
-	'ansi16m'
-];
-
-const styles = Object.create(null);
-
-const applyOptions = (object, options = {}) => {
-	if (options.level && !(Number.isInteger(options.level) && options.level >= 0 && options.level <= 3)) {
-		throw new Error('The `level` option should be an integer from 0 to 3');
-	}
-
-	// Detect level if not set manually
-	const colorLevel = stdoutColor ? stdoutColor.level : 0;
-	object.level = options.level === undefined ? colorLevel : options.level;
-};
-
-class ChalkClass {
-	constructor(options) {
-		// eslint-disable-next-line no-constructor-return
-		return chalkFactory(options);
-	}
-}
-
-const chalkFactory = options => {
-	const chalk = {};
-	applyOptions(chalk, options);
-
-	chalk.template = (...arguments_) => chalkTag(chalk.template, ...arguments_);
-
-	Object.setPrototypeOf(chalk, Chalk.prototype);
-	Object.setPrototypeOf(chalk.template, chalk);
-
-	chalk.template.constructor = () => {
-		throw new Error('`chalk.constructor()` is deprecated. Use `new chalk.Instance()` instead.');
-	};
-
-	chalk.template.Instance = ChalkClass;
-
-	return chalk.template;
-};
+const convert = {};
 
-function Chalk(options) {
-	return chalkFactory(options);
-}
+const models = Object.keys(conversions);
 
-for (const [styleName, style] of Object.entries(ansiStyles)) {
-	styles[styleName] = {
-		get() {
-			const builder = createBuilder(this, createStyler(style.open, style.close, this._styler), this._isEmpty);
-			Object.defineProperty(this, styleName, {value: builder});
-			return builder;
+function wrapRaw(fn) {
+	const wrappedFn = function (...args) {
+		const arg0 = args[0];
+		if (arg0 === undefined || arg0 === null) {
+			return arg0;
 		}
-	};
-}
 
-styles.visible = {
-	get() {
-		const builder = createBuilder(this, this._styler, true);
-		Object.defineProperty(this, 'visible', {value: builder});
-		return builder;
-	}
-};
-
-const usedModels = ['rgb', 'hex', 'keyword', 'hsl', 'hsv', 'hwb', 'ansi', 'ansi256'];
-
-for (const model of usedModels) {
-	styles[model] = {
-		get() {
-			const {level} = this;
-			return function (...arguments_) {
-				const styler = createStyler(ansiStyles.color[levelMapping[level]][model](...arguments_), ansiStyles.color.close, this._styler);
-				return createBuilder(this, styler, this._isEmpty);
-			};
+		if (arg0.length > 1) {
+			args = arg0;
 		}
-	};
-}
 
-for (const model of usedModels) {
-	const bgModel = 'bg' + model[0].toUpperCase() + model.slice(1);
-	styles[bgModel] = {
-		get() {
-			const {level} = this;
-			return function (...arguments_) {
-				const styler = createStyler(ansiStyles.bgColor[levelMapping[level]][model](...arguments_), ansiStyles.bgColor.close, this._styler);
-				return createBuilder(this, styler, this._isEmpty);
-			};
-		}
+		return fn(args);
 	};
-}
 
-const proto = Object.defineProperties(() => {}, {
-	...styles,
-	level: {
-		enumerable: true,
-		get() {
-			return this._generator.level;
-		},
-		set(level) {
-			this._generator.level = level;
-		}
+	// Preserve .conversion property if there is one
+	if ('conversion' in fn) {
+		wrappedFn.conversion = fn.conversion;
 	}
-});
 
-const createStyler = (open, close, parent) => {
-	let openAll;
-	let closeAll;
-	if (parent === undefined) {
-		openAll = open;
-		closeAll = close;
-	} else {
-		openAll = parent.openAll + open;
-		closeAll = close + parent.closeAll;
-	}
+	return wrappedFn;
+}
 
-	return {
-		open,
-		close,
-		openAll,
-		closeAll,
-		parent
-	};
-};
+function wrapRounded(fn) {
+	const wrappedFn = function (...args) {
+		const arg0 = args[0];
 
-const createBuilder = (self, _styler, _isEmpty) => {
-	const builder = (...arguments_) => {
-		if (isArray(arguments_[0]) && isArray(arguments_[0].raw)) {
-			// Called as a template literal, for example: chalk.red`2 + 3 = {bold ${2+3}}`
-			return applyStyle(builder, chalkTag(builder, ...arguments_));
+		if (arg0 === undefined || arg0 === null) {
+			return arg0;
 		}
 
-		// Single argument is hot path, implicit coercion is faster than anything
-		// eslint-disable-next-line no-implicit-coercion
-		return applyStyle(builder, (arguments_.length === 1) ? ('' + arguments_[0]) : arguments_.join(' '));
-	};
-
-	// We alter the prototype because we must return a function, but there is
-	// no way to create a function with a different prototype
-	Object.setPrototypeOf(builder, proto);
-
-	builder._generator = self;
-	builder._styler = _styler;
-	builder._isEmpty = _isEmpty;
-
-	return builder;
-};
-
-const applyStyle = (self, string) => {
-	if (self.level <= 0 || !string) {
-		return self._isEmpty ? '' : string;
-	}
-
-	let styler = self._styler;
-
-	if (styler === undefined) {
-		return string;
-	}
-
-	const {openAll, closeAll} = styler;
-	if (string.indexOf('\u001B') !== -1) {
-		while (styler !== undefined) {
-			// Replace any instances already present with a re-opening code
-			// otherwise only the part of the string until said closing code
-			// will be colored, and the rest will simply be 'plain'.
-			string = stringReplaceAll(string, styler.close, styler.open);
-
-			styler = styler.parent;
+		if (arg0.length > 1) {
+			args = arg0;
 		}
-	}
 
-	// We can move both next actions out of loop, because remaining actions in loop won't have
-	// any/visible effect on parts we add here. Close the styling before a linebreak and reopen
-	// after next line to fix a bleed issue on macOS: https://github.com/chalk/chalk/pull/92
-	const lfIndex = string.indexOf('\n');
-	if (lfIndex !== -1) {
-		string = stringEncaseCRLFWithFirstIndex(string, closeAll, openAll, lfIndex);
-	}
+		const result = fn(args);
 
-	return openAll + string + closeAll;
-};
+		// We're assuming the result is an array here.
+		// see notice in conversions.js; don't use box types
+		// in conversion functions.
+		if (typeof result === 'object') {
+			for (let len = result.length, i = 0; i < len; i++) {
+				result[i] = Math.round(result[i]);
+			}
+		}
 
-let template;
-const chalkTag = (chalk, ...strings) => {
-	const [firstString] = strings;
+		return result;
+	};
 
-	if (!isArray(firstString) || !isArray(firstString.raw)) {
-		// If chalk() was called by itself or with a string,
-		// return the string itself as a string.
-		return strings.join(' ');
+	// Preserve .conversion property if there is one
+	if ('conversion' in fn) {
+		wrappedFn.conversion = fn.conversion;
 	}
 
-	const arguments_ = strings.slice(1);
-	const parts = [firstString.raw[0]];
+	return wrappedFn;
+}
 
-	for (let i = 1; i < firstString.length; i++) {
-		parts.push(
-			String(arguments_[i - 1]).replace(/[{}\\]/g, '\\$&'),
-			String(firstString.raw[i])
-		);
-	}
+models.forEach(fromModel => {
+	convert[fromModel] = {};
 
-	if (template === undefined) {
-		template = __nccwpck_require__(17353);
-	}
+	Object.defineProperty(convert[fromModel], 'channels', {value: conversions[fromModel].channels});
+	Object.defineProperty(convert[fromModel], 'labels', {value: conversions[fromModel].labels});
 
-	return template(chalk, parts.join(''));
-};
+	const routes = route(fromModel);
+	const routeModels = Object.keys(routes);
 
-Object.defineProperties(Chalk.prototype, styles);
+	routeModels.forEach(toModel => {
+		const fn = routes[toModel];
 
-const chalk = Chalk(); // eslint-disable-line new-cap
-chalk.supportsColor = stdoutColor;
-chalk.stderr = Chalk({level: stderrColor ? stderrColor.level : 0}); // eslint-disable-line new-cap
-chalk.stderr.supportsColor = stderrColor;
+		convert[fromModel][toModel] = wrapRounded(fn);
+		convert[fromModel][toModel].raw = wrapRaw(fn);
+	});
+});
 
-module.exports = chalk;
+module.exports = convert;
 
 
 /***/ }),
 
-/***/ 17353:
-/***/ ((module) => {
+/***/ 8411:
+/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
-"use strict";
+const conversions = __nccwpck_require__(78567);
 
-const TEMPLATE_REGEX = /(?:\\(u(?:[a-f\d]{4}|\{[a-f\d]{1,6}\})|x[a-f\d]{2}|.))|(?:\{(~)?(\w+(?:\([^)]*\))?(?:\.\w+(?:\([^)]*\))?)*)(?:[ \t]|(?=\r?\n)))|(\})|((?:.|[\r\n\f])+?)/gi;
-const STYLE_REGEX = /(?:^|\.)(\w+)(?:\(([^)]*)\))?/g;
-const STRING_REGEX = /^(['"])((?:\\.|(?!\1)[^\\])*)\1$/;
-const ESCAPE_REGEX = /\\(u(?:[a-f\d]{4}|{[a-f\d]{1,6}})|x[a-f\d]{2}|.)|([^\\])/gi;
+/*
+	This function routes a model to all other models.
 
-const ESCAPES = new Map([
-	['n', '\n'],
-	['r', '\r'],
-	['t', '\t'],
-	['b', '\b'],
-	['f', '\f'],
-	['v', '\v'],
-	['0', '\0'],
-	['\\', '\\'],
-	['e', '\u001B'],
-	['a', '\u0007']
-]);
+	all functions that are routed have a property `.conversion` attached
+	to the returned synthetic function. This property is an array
+	of strings, each with the steps in between the 'from' and 'to'
+	color models (inclusive).
 
-function unescape(c) {
-	const u = c[0] === 'u';
-	const bracket = c[1] === '{';
+	conversions that are not possible simply are not included.
+*/
 
-	if ((u && !bracket && c.length === 5) || (c[0] === 'x' && c.length === 3)) {
-		return String.fromCharCode(parseInt(c.slice(1), 16));
-	}
+function buildGraph() {
+	const graph = {};
+	// https://jsperf.com/object-keys-vs-for-in-with-closure/3
+	const models = Object.keys(conversions);
 
-	if (u && bracket) {
-		return String.fromCodePoint(parseInt(c.slice(2, -1), 16));
+	for (let len = models.length, i = 0; i < len; i++) {
+		graph[models[i]] = {
+			// http://jsperf.com/1-vs-infinity
+			// micro-opt, but this is simple.
+			distance: -1,
+			parent: null
+		};
 	}
 
-	return ESCAPES.get(c) || c;
+	return graph;
 }
 
-function parseArguments(name, arguments_) {
-	const results = [];
-	const chunks = arguments_.trim().split(/\s*,\s*/g);
-	let matches;
-
-	for (const chunk of chunks) {
-		const number = Number(chunk);
-		if (!Number.isNaN(number)) {
-			results.push(number);
-		} else if ((matches = chunk.match(STRING_REGEX))) {
-			results.push(matches[2].replace(ESCAPE_REGEX, (m, escape, character) => escape ? unescape(escape) : character));
-		} else {
-			throw new Error(`Invalid Chalk template style argument: ${chunk} (in style '${name}')`);
-		}
-	}
-
-	return results;
-}
+// https://en.wikipedia.org/wiki/Breadth-first_search
+function deriveBFS(fromModel) {
+	const graph = buildGraph();
+	const queue = [fromModel]; // Unshift -> queue -> pop
 
-function parseStyle(style) {
-	STYLE_REGEX.lastIndex = 0;
+	graph[fromModel].distance = 0;
 
-	const results = [];
-	let matches;
+	while (queue.length) {
+		const current = queue.pop();
+		const adjacents = Object.keys(conversions[current]);
 
-	while ((matches = STYLE_REGEX.exec(style)) !== null) {
-		const name = matches[1];
+		for (let len = adjacents.length, i = 0; i < len; i++) {
+			const adjacent = adjacents[i];
+			const node = graph[adjacent];
 
-		if (matches[2]) {
-			const args = parseArguments(name, matches[2]);
-			results.push([name].concat(args));
-		} else {
-			results.push([name]);
+			if (node.distance === -1) {
+				node.distance = graph[current].distance + 1;
+				node.parent = current;
+				queue.unshift(adjacent);
+			}
 		}
 	}
 
-	return results;
+	return graph;
 }
 
-function buildStyle(chalk, styles) {
-	const enabled = {};
-
-	for (const layer of styles) {
-		for (const style of layer.styles) {
-			enabled[style[0]] = layer.inverse ? null : style.slice(1);
-		}
-	}
-
-	let current = chalk;
-	for (const [styleName, styles] of Object.entries(enabled)) {
-		if (!Array.isArray(styles)) {
-			continue;
-		}
+function link(from, to) {
+	return function (args) {
+		return to(from(args));
+	};
+}
 
-		if (!(styleName in current)) {
-			throw new Error(`Unknown Chalk style: ${styleName}`);
-		}
+function wrapConversion(toModel, graph) {
+	const path = [graph[toModel].parent, toModel];
+	let fn = conversions[graph[toModel].parent][toModel];
 
-		current = styles.length > 0 ? current[styleName](...styles) : current[styleName];
+	let cur = graph[toModel].parent;
+	while (graph[cur].parent) {
+		path.unshift(graph[cur].parent);
+		fn = link(conversions[graph[cur].parent][cur], fn);
+		cur = graph[cur].parent;
 	}
 
-	return current;
+	fn.conversion = path;
+	return fn;
 }
 
-module.exports = (chalk, temporary) => {
-	const styles = [];
-	const chunks = [];
-	let chunk = [];
+module.exports = function (fromModel) {
+	const graph = deriveBFS(fromModel);
+	const conversion = {};
 
-	// eslint-disable-next-line max-params
-	temporary.replace(TEMPLATE_REGEX, (m, escapeCharacter, inverse, style, close, character) => {
-		if (escapeCharacter) {
-			chunk.push(unescape(escapeCharacter));
-		} else if (style) {
-			const string = chunk.join('');
-			chunk = [];
-			chunks.push(styles.length === 0 ? string : buildStyle(chalk, styles)(string));
-			styles.push({inverse, styles: parseStyle(style)});
-		} else if (close) {
-			if (styles.length === 0) {
-				throw new Error('Found extraneous } in Chalk template literal');
-			}
+	const models = Object.keys(graph);
+	for (let len = models.length, i = 0; i < len; i++) {
+		const toModel = models[i];
+		const node = graph[toModel];
 
-			chunks.push(buildStyle(chalk, styles)(chunk.join('')));
-			chunk = [];
-			styles.pop();
-		} else {
-			chunk.push(character);
+		if (node.parent === null) {
+			// No possible conversion, or this node is the source model.
+			continue;
 		}
-	});
-
-	chunks.push(chunk.join(''));
-
-	if (styles.length > 0) {
-		const errMessage = `Chalk template literal is missing ${styles.length} closing bracket${styles.length === 1 ? '' : 's'} (\`}\`)`;
-		throw new Error(errMessage);
-	}
-
-	return chunks.join('');
-};
-
 
-/***/ }),
-
-/***/ 94187:
-/***/ ((module) => {
-
-"use strict";
-
-
-const stringReplaceAll = (string, substring, replacer) => {
-	let index = string.indexOf(substring);
-	if (index === -1) {
-		return string;
+		conversion[toModel] = wrapConversion(toModel, graph);
 	}
 
-	const substringLength = substring.length;
-	let endIndex = 0;
-	let returnValue = '';
-	do {
-		returnValue += string.substr(endIndex, index - endIndex) + substring + replacer;
-		endIndex = index + substringLength;
-		index = string.indexOf(substring, endIndex);
-	} while (index !== -1);
-
-	returnValue += string.substr(endIndex);
-	return returnValue;
-};
-
-const stringEncaseCRLFWithFirstIndex = (string, prefix, postfix, index) => {
-	let endIndex = 0;
-	let returnValue = '';
-	do {
-		const gotCR = string[index - 1] === '\r';
-		returnValue += string.substr(endIndex, (gotCR ? index - 1 : index) - endIndex) + prefix + (gotCR ? '\r\n' : '\n') + postfix;
-		endIndex = index + 1;
-		index = string.indexOf('\n', endIndex);
-	} while (index !== -1);
-
-	returnValue += string.substr(endIndex);
-	return returnValue;
+	return conversion;
 };
 
-module.exports = {
-	stringReplaceAll,
-	stringEncaseCRLFWithFirstIndex
-};
 
 
 /***/ }),
 
-/***/ 58158:
+/***/ 22365:
 /***/ ((module) => {
 
 "use strict";
@@ -41441,7 +39415,7 @@ module.exports = {
 
 /***/ }),
 
-/***/ 50819:
+/***/ 90353:
 /***/ ((module) => {
 
 module.exports = function (xs, fn) {
@@ -41461,7 +39435,7 @@ var isArray = Array.isArray || function (xs) {
 
 /***/ }),
 
-/***/ 6691:
+/***/ 14838:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 const nativeModule = __nccwpck_require__(98188)
@@ -41517,7 +39491,7 @@ module.exports = createRequire
 
 /***/ }),
 
-/***/ 69617:
+/***/ 7398:
 /***/ ((module) => {
 
 /**
@@ -41686,7 +39660,7 @@ function plural(ms, msAbs, n, name) {
 
 /***/ }),
 
-/***/ 38617:
+/***/ 76674:
 /***/ ((module, exports, __nccwpck_require__) => {
 
 /* eslint-env browser */
@@ -41943,7 +39917,7 @@ function localstorage() {
 	}
 }
 
-module.exports = __nccwpck_require__(50885)(exports);
+module.exports = __nccwpck_require__(50923)(exports);
 
 const {formatters} = module.exports;
 
@@ -41962,7 +39936,7 @@ formatters.j = function (v) {
 
 /***/ }),
 
-/***/ 50885:
+/***/ 50923:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 
@@ -41978,7 +39952,7 @@ function setup(env) {
 	createDebug.disable = disable;
 	createDebug.enable = enable;
 	createDebug.enabled = enabled;
-	createDebug.humanize = __nccwpck_require__(69617);
+	createDebug.humanize = __nccwpck_require__(7398);
 	createDebug.destroy = destroy;
 
 	Object.keys(env).forEach(key => {
@@ -42243,7 +40217,7 @@ module.exports = setup;
 
 /***/ }),
 
-/***/ 44126:
+/***/ 93118:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 /**
@@ -42252,15 +40226,15 @@ module.exports = setup;
  */
 
 if (typeof process === 'undefined' || process.type === 'renderer' || process.browser === true || process.__nwjs) {
-	module.exports = __nccwpck_require__(38617);
+	module.exports = __nccwpck_require__(76674);
 } else {
-	module.exports = __nccwpck_require__(2202);
+	module.exports = __nccwpck_require__(37847);
 }
 
 
 /***/ }),
 
-/***/ 2202:
+/***/ 37847:
 /***/ ((module, exports, __nccwpck_require__) => {
 
 /**
@@ -42294,7 +40268,7 @@ exports.colors = [6, 2, 3, 4, 5, 1];
 try {
 	// Optional dependency (as in, doesn't need to be installed, NOT like optionalDependencies in package.json)
 	// eslint-disable-next-line import/no-extraneous-dependencies
-	const supportsColor = __nccwpck_require__(9679);
+	const supportsColor = __nccwpck_require__(26080);
 
 	if (supportsColor && (supportsColor.stderr || supportsColor).level >= 2) {
 		exports.colors = [
@@ -42502,7 +40476,7 @@ function init(debug) {
 	}
 }
 
-module.exports = __nccwpck_require__(50885)(exports);
+module.exports = __nccwpck_require__(50923)(exports);
 
 const {formatters} = module.exports;
 
@@ -42530,7 +40504,7 @@ formatters.O = function (v) {
 
 /***/ }),
 
-/***/ 47375:
+/***/ 9474:
 /***/ ((__unused_webpack_module, exports) => {
 
 "use strict";
@@ -42570,7 +40544,7 @@ function convertChangesToDMP(changes) {
 
 /***/ }),
 
-/***/ 81828:
+/***/ 67132:
 /***/ ((__unused_webpack_module, exports) => {
 
 "use strict";
@@ -42620,7 +40594,7 @@ function escapeHTML(s) {
 
 /***/ }),
 
-/***/ 512:
+/***/ 37475:
 /***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
 "use strict";
@@ -42636,7 +40610,7 @@ exports.arrayDiff = void 0;
 /*istanbul ignore end*/
 var
 /*istanbul ignore start*/
-_base = _interopRequireDefault(__nccwpck_require__(33385))
+_base = _interopRequireDefault(__nccwpck_require__(31095))
 /*istanbul ignore end*/
 ;
 
@@ -42673,7 +40647,7 @@ function diffArrays(oldArr, newArr, callback) {
 
 /***/ }),
 
-/***/ 33385:
+/***/ 31095:
 /***/ ((__unused_webpack_module, exports) => {
 
 "use strict";
@@ -42985,7 +40959,7 @@ function clonePath(path) {
 
 /***/ }),
 
-/***/ 58381:
+/***/ 31045:
 /***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
 "use strict";
@@ -43001,7 +40975,7 @@ exports.characterDiff = void 0;
 /*istanbul ignore end*/
 var
 /*istanbul ignore start*/
-_base = _interopRequireDefault(__nccwpck_require__(33385))
+_base = _interopRequireDefault(__nccwpck_require__(31095))
 /*istanbul ignore end*/
 ;
 
@@ -43030,7 +41004,7 @@ function diffChars(oldStr, newStr, options) {
 
 /***/ }),
 
-/***/ 48802:
+/***/ 56400:
 /***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
 "use strict";
@@ -43046,7 +41020,7 @@ exports.cssDiff = void 0;
 /*istanbul ignore end*/
 var
 /*istanbul ignore start*/
-_base = _interopRequireDefault(__nccwpck_require__(33385))
+_base = _interopRequireDefault(__nccwpck_require__(31095))
 /*istanbul ignore end*/
 ;
 
@@ -43079,7 +41053,7 @@ function diffCss(oldStr, newStr, callback) {
 
 /***/ }),
 
-/***/ 93818:
+/***/ 75672:
 /***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
 "use strict";
@@ -43096,13 +41070,13 @@ exports.jsonDiff = void 0;
 /*istanbul ignore end*/
 var
 /*istanbul ignore start*/
-_base = _interopRequireDefault(__nccwpck_require__(33385))
+_base = _interopRequireDefault(__nccwpck_require__(31095))
 /*istanbul ignore end*/
 ;
 
 var
 /*istanbul ignore start*/
-_line = __nccwpck_require__(87234)
+_line = __nccwpck_require__(60410)
 /*istanbul ignore end*/
 ;
 
@@ -43250,7 +41224,7 @@ function canonicalize(obj, stack, replacementStack, replacer, key) {
 
 /***/ }),
 
-/***/ 87234:
+/***/ 60410:
 /***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
 "use strict";
@@ -43267,13 +41241,13 @@ exports.lineDiff = void 0;
 /*istanbul ignore end*/
 var
 /*istanbul ignore start*/
-_base = _interopRequireDefault(__nccwpck_require__(33385))
+_base = _interopRequireDefault(__nccwpck_require__(31095))
 /*istanbul ignore end*/
 ;
 
 var
 /*istanbul ignore start*/
-_params = __nccwpck_require__(42308)
+_params = __nccwpck_require__(35239)
 /*istanbul ignore end*/
 ;
 
@@ -43347,7 +41321,7 @@ function diffTrimmedLines(oldStr, newStr, callback) {
 
 /***/ }),
 
-/***/ 47080:
+/***/ 10320:
 /***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
 "use strict";
@@ -43363,7 +41337,7 @@ exports.sentenceDiff = void 0;
 /*istanbul ignore end*/
 var
 /*istanbul ignore start*/
-_base = _interopRequireDefault(__nccwpck_require__(33385))
+_base = _interopRequireDefault(__nccwpck_require__(31095))
 /*istanbul ignore end*/
 ;
 
@@ -43396,7 +41370,7 @@ function diffSentences(oldStr, newStr, callback) {
 
 /***/ }),
 
-/***/ 75496:
+/***/ 74677:
 /***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
 "use strict";
@@ -43413,13 +41387,13 @@ exports.wordDiff = void 0;
 /*istanbul ignore end*/
 var
 /*istanbul ignore start*/
-_base = _interopRequireDefault(__nccwpck_require__(33385))
+_base = _interopRequireDefault(__nccwpck_require__(31095))
 /*istanbul ignore end*/
 ;
 
 var
 /*istanbul ignore start*/
-_params = __nccwpck_require__(42308)
+_params = __nccwpck_require__(35239)
 /*istanbul ignore end*/
 ;
 
@@ -43511,7 +41485,7 @@ function diffWordsWithSpace(oldStr, newStr, options) {
 
 /***/ }),
 
-/***/ 45604:
+/***/ 95214:
 /***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
 "use strict";
@@ -43645,85 +41619,85 @@ Object.defineProperty(exports, "convertChangesToXML", ({
 /*istanbul ignore end*/
 var
 /*istanbul ignore start*/
-_base = _interopRequireDefault(__nccwpck_require__(33385))
+_base = _interopRequireDefault(__nccwpck_require__(31095))
 /*istanbul ignore end*/
 ;
 
 var
 /*istanbul ignore start*/
-_character = __nccwpck_require__(58381)
+_character = __nccwpck_require__(31045)
 /*istanbul ignore end*/
 ;
 
 var
 /*istanbul ignore start*/
-_word = __nccwpck_require__(75496)
+_word = __nccwpck_require__(74677)
 /*istanbul ignore end*/
 ;
 
 var
 /*istanbul ignore start*/
-_line = __nccwpck_require__(87234)
+_line = __nccwpck_require__(60410)
 /*istanbul ignore end*/
 ;
 
 var
 /*istanbul ignore start*/
-_sentence = __nccwpck_require__(47080)
+_sentence = __nccwpck_require__(10320)
 /*istanbul ignore end*/
 ;
 
 var
 /*istanbul ignore start*/
-_css = __nccwpck_require__(48802)
+_css = __nccwpck_require__(56400)
 /*istanbul ignore end*/
 ;
 
 var
 /*istanbul ignore start*/
-_json = __nccwpck_require__(93818)
+_json = __nccwpck_require__(75672)
 /*istanbul ignore end*/
 ;
 
 var
 /*istanbul ignore start*/
-_array = __nccwpck_require__(512)
+_array = __nccwpck_require__(37475)
 /*istanbul ignore end*/
 ;
 
 var
 /*istanbul ignore start*/
-_apply = __nccwpck_require__(99960)
+_apply = __nccwpck_require__(97505)
 /*istanbul ignore end*/
 ;
 
 var
 /*istanbul ignore start*/
-_parse = __nccwpck_require__(99002)
+_parse = __nccwpck_require__(4341)
 /*istanbul ignore end*/
 ;
 
 var
 /*istanbul ignore start*/
-_merge = __nccwpck_require__(24545)
+_merge = __nccwpck_require__(508)
 /*istanbul ignore end*/
 ;
 
 var
 /*istanbul ignore start*/
-_create = __nccwpck_require__(12963)
+_create = __nccwpck_require__(67450)
 /*istanbul ignore end*/
 ;
 
 var
 /*istanbul ignore start*/
-_dmp = __nccwpck_require__(47375)
+_dmp = __nccwpck_require__(9474)
 /*istanbul ignore end*/
 ;
 
 var
 /*istanbul ignore start*/
-_xml = __nccwpck_require__(81828)
+_xml = __nccwpck_require__(67132)
 /*istanbul ignore end*/
 ;
 
@@ -43735,7 +41709,7 @@ _xml = __nccwpck_require__(81828)
 
 /***/ }),
 
-/***/ 99960:
+/***/ 97505:
 /***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
 "use strict";
@@ -43751,13 +41725,13 @@ exports.applyPatches = applyPatches;
 /*istanbul ignore end*/
 var
 /*istanbul ignore start*/
-_parse = __nccwpck_require__(99002)
+_parse = __nccwpck_require__(4341)
 /*istanbul ignore end*/
 ;
 
 var
 /*istanbul ignore start*/
-_distanceIterator = _interopRequireDefault(__nccwpck_require__(89616))
+_distanceIterator = _interopRequireDefault(__nccwpck_require__(72368))
 /*istanbul ignore end*/
 ;
 
@@ -43986,7 +41960,7 @@ function applyPatches(uniDiff, options) {
 
 /***/ }),
 
-/***/ 12963:
+/***/ 67450:
 /***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
 "use strict";
@@ -44003,7 +41977,7 @@ exports.createPatch = createPatch;
 /*istanbul ignore end*/
 var
 /*istanbul ignore start*/
-_line = __nccwpck_require__(87234)
+_line = __nccwpck_require__(60410)
 /*istanbul ignore end*/
 ;
 
@@ -44241,7 +42215,7 @@ function createPatch(fileName, oldStr, newStr, oldHeader, newHeader, options) {
 
 /***/ }),
 
-/***/ 24545:
+/***/ 508:
 /***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
 "use strict";
@@ -44257,19 +42231,19 @@ exports.merge = merge;
 /*istanbul ignore end*/
 var
 /*istanbul ignore start*/
-_create = __nccwpck_require__(12963)
+_create = __nccwpck_require__(67450)
 /*istanbul ignore end*/
 ;
 
 var
 /*istanbul ignore start*/
-_parse = __nccwpck_require__(99002)
+_parse = __nccwpck_require__(4341)
 /*istanbul ignore end*/
 ;
 
 var
 /*istanbul ignore start*/
-_array = __nccwpck_require__(29773)
+_array = __nccwpck_require__(39380)
 /*istanbul ignore end*/
 ;
 
@@ -44858,7 +42832,7 @@ function calcOldNewLineCount(lines) {
 
 /***/ }),
 
-/***/ 99002:
+/***/ 4341:
 /***/ ((__unused_webpack_module, exports) => {
 
 "use strict";
@@ -45022,7 +42996,7 @@ function parsePatch(uniDiff) {
 
 /***/ }),
 
-/***/ 29773:
+/***/ 39380:
 /***/ ((__unused_webpack_module, exports) => {
 
 "use strict";
@@ -45062,7 +43036,7 @@ function arrayStartsWith(array, start) {
 
 /***/ }),
 
-/***/ 89616:
+/***/ 72368:
 /***/ ((__unused_webpack_module, exports) => {
 
 "use strict";
@@ -45127,7 +43101,7 @@ _default
 
 /***/ }),
 
-/***/ 42308:
+/***/ 35239:
 /***/ ((__unused_webpack_module, exports) => {
 
 "use strict";
@@ -45159,7 +43133,7 @@ function generateOptions(options, defaults) {
 
 /***/ }),
 
-/***/ 77510:
+/***/ 37896:
 /***/ ((module) => {
 
 "use strict";
@@ -45173,10 +43147,10 @@ module.exports = function () {
 
 /***/ }),
 
-/***/ 69867:
+/***/ 44790:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
-var once = __nccwpck_require__(37909);
+var once = __nccwpck_require__(63767);
 
 var noop = function() {};
 
@@ -45274,7 +43248,7 @@ module.exports = eos;
 
 /***/ }),
 
-/***/ 34959:
+/***/ 11149:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 const { dirname, resolve } = __nccwpck_require__(71017);
@@ -45299,561 +43273,7 @@ module.exports = function (start, callback) {
 
 /***/ }),
 
-/***/ 32027:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
-
-"use strict";
-
-
-/* eslint-disable no-var */
-
-var reusify = __nccwpck_require__(36873)
-
-function fastqueue (context, worker, concurrency) {
-  if (typeof context === 'function') {
-    concurrency = worker
-    worker = context
-    context = null
-  }
-
-  if (concurrency < 1) {
-    throw new Error('fastqueue concurrency must be greater than 1')
-  }
-
-  var cache = reusify(Task)
-  var queueHead = null
-  var queueTail = null
-  var _running = 0
-  var errorHandler = null
-
-  var self = {
-    push: push,
-    drain: noop,
-    saturated: noop,
-    pause: pause,
-    paused: false,
-    concurrency: concurrency,
-    running: running,
-    resume: resume,
-    idle: idle,
-    length: length,
-    getQueue: getQueue,
-    unshift: unshift,
-    empty: noop,
-    kill: kill,
-    killAndDrain: killAndDrain,
-    error: error
-  }
-
-  return self
-
-  function running () {
-    return _running
-  }
-
-  function pause () {
-    self.paused = true
-  }
-
-  function length () {
-    var current = queueHead
-    var counter = 0
-
-    while (current) {
-      current = current.next
-      counter++
-    }
-
-    return counter
-  }
-
-  function getQueue () {
-    var current = queueHead
-    var tasks = []
-
-    while (current) {
-      tasks.push(current.value)
-      current = current.next
-    }
-
-    return tasks
-  }
-
-  function resume () {
-    if (!self.paused) return
-    self.paused = false
-    for (var i = 0; i < self.concurrency; i++) {
-      _running++
-      release()
-    }
-  }
-
-  function idle () {
-    return _running === 0 && self.length() === 0
-  }
-
-  function push (value, done) {
-    var current = cache.get()
-
-    current.context = context
-    current.release = release
-    current.value = value
-    current.callback = done || noop
-    current.errorHandler = errorHandler
-
-    if (_running === self.concurrency || self.paused) {
-      if (queueTail) {
-        queueTail.next = current
-        queueTail = current
-      } else {
-        queueHead = current
-        queueTail = current
-        self.saturated()
-      }
-    } else {
-      _running++
-      worker.call(context, current.value, current.worked)
-    }
-  }
-
-  function unshift (value, done) {
-    var current = cache.get()
-
-    current.context = context
-    current.release = release
-    current.value = value
-    current.callback = done || noop
-
-    if (_running === self.concurrency || self.paused) {
-      if (queueHead) {
-        current.next = queueHead
-        queueHead = current
-      } else {
-        queueHead = current
-        queueTail = current
-        self.saturated()
-      }
-    } else {
-      _running++
-      worker.call(context, current.value, current.worked)
-    }
-  }
-
-  function release (holder) {
-    if (holder) {
-      cache.release(holder)
-    }
-    var next = queueHead
-    if (next) {
-      if (!self.paused) {
-        if (queueTail === queueHead) {
-          queueTail = null
-        }
-        queueHead = next.next
-        next.next = null
-        worker.call(context, next.value, next.worked)
-        if (queueTail === null) {
-          self.empty()
-        }
-      } else {
-        _running--
-      }
-    } else if (--_running === 0) {
-      self.drain()
-    }
-  }
-
-  function kill () {
-    queueHead = null
-    queueTail = null
-    self.drain = noop
-  }
-
-  function killAndDrain () {
-    queueHead = null
-    queueTail = null
-    self.drain()
-    self.drain = noop
-  }
-
-  function error (handler) {
-    errorHandler = handler
-  }
-}
-
-function noop () {}
-
-function Task () {
-  this.value = null
-  this.callback = noop
-  this.next = null
-  this.release = noop
-  this.context = null
-  this.errorHandler = null
-
-  var self = this
-
-  this.worked = function worked (err, result) {
-    var callback = self.callback
-    var errorHandler = self.errorHandler
-    var val = self.value
-    self.value = null
-    self.callback = noop
-    if (self.errorHandler) {
-      errorHandler(err, val)
-    }
-    callback.call(self.context, err, result)
-    self.release(self)
-  }
-}
-
-function queueAsPromised (context, worker, concurrency) {
-  if (typeof context === 'function') {
-    concurrency = worker
-    worker = context
-    context = null
-  }
-
-  function asyncWrapper (arg, cb) {
-    worker.call(this, arg)
-      .then(function (res) {
-        cb(null, res)
-      }, cb)
-  }
-
-  var queue = fastqueue(context, asyncWrapper, concurrency)
-
-  var pushCb = queue.push
-  var unshiftCb = queue.unshift
-
-  queue.push = push
-  queue.unshift = unshift
-  queue.drained = drained
-
-  return queue
-
-  function push (value) {
-    var p = new Promise(function (resolve, reject) {
-      pushCb(value, function (err, result) {
-        if (err) {
-          reject(err)
-          return
-        }
-        resolve(result)
-      })
-    })
-
-    // Let's fork the promise chain to
-    // make the error bubble up to the user but
-    // not lead to a unhandledRejection
-    p.catch(noop)
-
-    return p
-  }
-
-  function unshift (value) {
-    var p = new Promise(function (resolve, reject) {
-      unshiftCb(value, function (err, result) {
-        if (err) {
-          reject(err)
-          return
-        }
-        resolve(result)
-      })
-    })
-
-    // Let's fork the promise chain to
-    // make the error bubble up to the user but
-    // not lead to a unhandledRejection
-    p.catch(noop)
-
-    return p
-  }
-
-  function drained () {
-    if (queue.idle()) {
-      return new Promise(function (resolve) {
-        resolve()
-      })
-    }
-
-    var previousDrain = queue.drain
-
-    var p = new Promise(function (resolve) {
-      queue.drain = function () {
-        previousDrain()
-        resolve()
-      }
-    })
-
-    return p
-  }
-}
-
-module.exports = fastqueue
-module.exports.promise = queueAsPromised
-
-
-/***/ }),
-
-/***/ 12619:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
-
-"use strict";
-/*!
- * fill-range 
- *
- * Copyright (c) 2014-present, Jon Schlinkert.
- * Licensed under the MIT License.
- */
-
-
-
-const util = __nccwpck_require__(73837);
-const toRegexRange = __nccwpck_require__(12085);
-
-const isObject = val => val !== null && typeof val === 'object' && !Array.isArray(val);
-
-const transform = toNumber => {
-  return value => toNumber === true ? Number(value) : String(value);
-};
-
-const isValidValue = value => {
-  return typeof value === 'number' || (typeof value === 'string' && value !== '');
-};
-
-const isNumber = num => Number.isInteger(+num);
-
-const zeros = input => {
-  let value = `${input}`;
-  let index = -1;
-  if (value[0] === '-') value = value.slice(1);
-  if (value === '0') return false;
-  while (value[++index] === '0');
-  return index > 0;
-};
-
-const stringify = (start, end, options) => {
-  if (typeof start === 'string' || typeof end === 'string') {
-    return true;
-  }
-  return options.stringify === true;
-};
-
-const pad = (input, maxLength, toNumber) => {
-  if (maxLength > 0) {
-    let dash = input[0] === '-' ? '-' : '';
-    if (dash) input = input.slice(1);
-    input = (dash + input.padStart(dash ? maxLength - 1 : maxLength, '0'));
-  }
-  if (toNumber === false) {
-    return String(input);
-  }
-  return input;
-};
-
-const toMaxLen = (input, maxLength) => {
-  let negative = input[0] === '-' ? '-' : '';
-  if (negative) {
-    input = input.slice(1);
-    maxLength--;
-  }
-  while (input.length < maxLength) input = '0' + input;
-  return negative ? ('-' + input) : input;
-};
-
-const toSequence = (parts, options) => {
-  parts.negatives.sort((a, b) => a < b ? -1 : a > b ? 1 : 0);
-  parts.positives.sort((a, b) => a < b ? -1 : a > b ? 1 : 0);
-
-  let prefix = options.capture ? '' : '?:';
-  let positives = '';
-  let negatives = '';
-  let result;
-
-  if (parts.positives.length) {
-    positives = parts.positives.join('|');
-  }
-
-  if (parts.negatives.length) {
-    negatives = `-(${prefix}${parts.negatives.join('|')})`;
-  }
-
-  if (positives && negatives) {
-    result = `${positives}|${negatives}`;
-  } else {
-    result = positives || negatives;
-  }
-
-  if (options.wrap) {
-    return `(${prefix}${result})`;
-  }
-
-  return result;
-};
-
-const toRange = (a, b, isNumbers, options) => {
-  if (isNumbers) {
-    return toRegexRange(a, b, { wrap: false, ...options });
-  }
-
-  let start = String.fromCharCode(a);
-  if (a === b) return start;
-
-  let stop = String.fromCharCode(b);
-  return `[${start}-${stop}]`;
-};
-
-const toRegex = (start, end, options) => {
-  if (Array.isArray(start)) {
-    let wrap = options.wrap === true;
-    let prefix = options.capture ? '' : '?:';
-    return wrap ? `(${prefix}${start.join('|')})` : start.join('|');
-  }
-  return toRegexRange(start, end, options);
-};
-
-const rangeError = (...args) => {
-  return new RangeError('Invalid range arguments: ' + util.inspect(...args));
-};
-
-const invalidRange = (start, end, options) => {
-  if (options.strictRanges === true) throw rangeError([start, end]);
-  return [];
-};
-
-const invalidStep = (step, options) => {
-  if (options.strictRanges === true) {
-    throw new TypeError(`Expected step "${step}" to be a number`);
-  }
-  return [];
-};
-
-const fillNumbers = (start, end, step = 1, options = {}) => {
-  let a = Number(start);
-  let b = Number(end);
-
-  if (!Number.isInteger(a) || !Number.isInteger(b)) {
-    if (options.strictRanges === true) throw rangeError([start, end]);
-    return [];
-  }
-
-  // fix negative zero
-  if (a === 0) a = 0;
-  if (b === 0) b = 0;
-
-  let descending = a > b;
-  let startString = String(start);
-  let endString = String(end);
-  let stepString = String(step);
-  step = Math.max(Math.abs(step), 1);
-
-  let padded = zeros(startString) || zeros(endString) || zeros(stepString);
-  let maxLen = padded ? Math.max(startString.length, endString.length, stepString.length) : 0;
-  let toNumber = padded === false && stringify(start, end, options) === false;
-  let format = options.transform || transform(toNumber);
-
-  if (options.toRegex && step === 1) {
-    return toRange(toMaxLen(start, maxLen), toMaxLen(end, maxLen), true, options);
-  }
-
-  let parts = { negatives: [], positives: [] };
-  let push = num => parts[num < 0 ? 'negatives' : 'positives'].push(Math.abs(num));
-  let range = [];
-  let index = 0;
-
-  while (descending ? a >= b : a <= b) {
-    if (options.toRegex === true && step > 1) {
-      push(a);
-    } else {
-      range.push(pad(format(a, index), maxLen, toNumber));
-    }
-    a = descending ? a - step : a + step;
-    index++;
-  }
-
-  if (options.toRegex === true) {
-    return step > 1
-      ? toSequence(parts, options)
-      : toRegex(range, null, { wrap: false, ...options });
-  }
-
-  return range;
-};
-
-const fillLetters = (start, end, step = 1, options = {}) => {
-  if ((!isNumber(start) && start.length > 1) || (!isNumber(end) && end.length > 1)) {
-    return invalidRange(start, end, options);
-  }
-
-
-  let format = options.transform || (val => String.fromCharCode(val));
-  let a = `${start}`.charCodeAt(0);
-  let b = `${end}`.charCodeAt(0);
-
-  let descending = a > b;
-  let min = Math.min(a, b);
-  let max = Math.max(a, b);
-
-  if (options.toRegex && step === 1) {
-    return toRange(min, max, false, options);
-  }
-
-  let range = [];
-  let index = 0;
-
-  while (descending ? a >= b : a <= b) {
-    range.push(format(a, index));
-    a = descending ? a - step : a + step;
-    index++;
-  }
-
-  if (options.toRegex === true) {
-    return toRegex(range, null, { wrap: false, options });
-  }
-
-  return range;
-};
-
-const fill = (start, end, step, options = {}) => {
-  if (end == null && isValidValue(start)) {
-    return [start];
-  }
-
-  if (!isValidValue(start) || !isValidValue(end)) {
-    return invalidRange(start, end, options);
-  }
-
-  if (typeof step === 'function') {
-    return fill(start, end, 1, { transform: step });
-  }
-
-  if (isObject(step)) {
-    return fill(start, end, 0, step);
-  }
-
-  let opts = { ...options };
-  if (opts.capture === true) opts.wrap = true;
-  step = step || opts.step || 1;
-
-  if (!isNumber(step)) {
-    if (step != null && !isObject(step)) return invalidStep(step, opts);
-    return fill(start, end, 1, step);
-  }
-
-  if (isNumber(start) && isNumber(end)) {
-    return fillNumbers(start, end, step, opts);
-  }
-
-  return fillLetters(start, end, Math.max(Math.abs(step), 1), opts);
-};
-
-module.exports = fill;
-
-
-/***/ }),
-
-/***/ 21978:
+/***/ 69026:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 module.exports = (__nccwpck_require__(57147).constants) || __nccwpck_require__(22057)
@@ -45861,7 +43281,7 @@ module.exports = (__nccwpck_require__(57147).constants) || __nccwpck_require__(2
 
 /***/ }),
 
-/***/ 45074:
+/***/ 56318:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 module.exports = realpath
@@ -45877,7 +43297,7 @@ var origRealpathSync = fs.realpathSync
 
 var version = process.version
 var ok = /^v[0-5]\./.test(version)
-var old = __nccwpck_require__(11830)
+var old = __nccwpck_require__(95086)
 
 function newError (er) {
   return er && er.syscall === 'realpath' && (
@@ -45934,7 +43354,7 @@ function unmonkeypatch () {
 
 /***/ }),
 
-/***/ 11830:
+/***/ 95086:
 /***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
 // Copyright Joyent, Inc. and other Node contributors.
@@ -46244,7 +43664,7 @@ exports.realpath = function realpath(p, cache, cb) {
 
 /***/ }),
 
-/***/ 59466:
+/***/ 455:
 /***/ ((module) => {
 
 "use strict";
@@ -46273,57 +43693,7 @@ module.exports = function getCallerFile(position) {
 
 /***/ }),
 
-/***/ 86420:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
-
-"use strict";
-
-
-var isGlob = __nccwpck_require__(35411);
-var pathPosixDirname = (__nccwpck_require__(71017).posix.dirname);
-var isWin32 = (__nccwpck_require__(22037).platform)() === 'win32';
-
-var slash = '/';
-var backslash = /\\/g;
-var enclosure = /[\{\[].*[\}\]]$/;
-var globby = /(^|[^\\])([\{\[]|\([^\)]+$)/;
-var escaped = /\\([\!\*\?\|\[\]\(\)\{\}])/g;
-
-/**
- * @param {string} str
- * @param {Object} opts
- * @param {boolean} [opts.flipBackslashes=true]
- * @returns {string}
- */
-module.exports = function globParent(str, opts) {
-  var options = Object.assign({ flipBackslashes: true }, opts);
-
-  // flip windows path separators
-  if (options.flipBackslashes && isWin32 && str.indexOf(slash) < 0) {
-    str = str.replace(backslash, slash);
-  }
-
-  // special case for strings ending in enclosure containing path separator
-  if (enclosure.test(str)) {
-    str += slash;
-  }
-
-  // preserves full path in case of trailing path separator
-  str += 'a';
-
-  // remove path parts that are globby
-  do {
-    str = pathPosixDirname(str);
-  } while (isGlob(str) || globby.test(str));
-
-  // remove escape chars and return result
-  return str.replace(escaped, '$1');
-};
-
-
-/***/ }),
-
-/***/ 53434:
+/***/ 94860:
 /***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
 exports.setopts = setopts
@@ -46340,8 +43710,8 @@ function ownProp (obj, field) {
 
 var fs = __nccwpck_require__(57147)
 var path = __nccwpck_require__(71017)
-var minimatch = __nccwpck_require__(84546)
-var isAbsolute = __nccwpck_require__(50124)
+var minimatch = __nccwpck_require__(491)
+var isAbsolute = __nccwpck_require__(76384)
 var Minimatch = minimatch.Minimatch
 
 function alphasort (a, b) {
@@ -46568,7 +43938,7 @@ function childrenIgnored (self, path) {
 
 /***/ }),
 
-/***/ 20557:
+/***/ 69959:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 // Approach:
@@ -46613,24 +43983,24 @@ function childrenIgnored (self, path) {
 
 module.exports = glob
 
-var rp = __nccwpck_require__(45074)
-var minimatch = __nccwpck_require__(84546)
+var rp = __nccwpck_require__(56318)
+var minimatch = __nccwpck_require__(491)
 var Minimatch = minimatch.Minimatch
-var inherits = __nccwpck_require__(2868)
+var inherits = __nccwpck_require__(76401)
 var EE = (__nccwpck_require__(82361).EventEmitter)
 var path = __nccwpck_require__(71017)
 var assert = __nccwpck_require__(39491)
-var isAbsolute = __nccwpck_require__(50124)
-var globSync = __nccwpck_require__(99278)
-var common = __nccwpck_require__(53434)
+var isAbsolute = __nccwpck_require__(76384)
+var globSync = __nccwpck_require__(21498)
+var common = __nccwpck_require__(94860)
 var setopts = common.setopts
 var ownProp = common.ownProp
-var inflight = __nccwpck_require__(60629)
+var inflight = __nccwpck_require__(88107)
 var util = __nccwpck_require__(73837)
 var childrenIgnored = common.childrenIgnored
 var isIgnored = common.isIgnored
 
-var once = __nccwpck_require__(37909)
+var once = __nccwpck_require__(63767)
 
 function glob (pattern, options, cb) {
   if (typeof options === 'function') cb = options, options = {}
@@ -47365,21 +44735,21 @@ Glob.prototype._stat2 = function (f, abs, er, stat, cb) {
 
 /***/ }),
 
-/***/ 99278:
+/***/ 21498:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 module.exports = globSync
 globSync.GlobSync = GlobSync
 
-var rp = __nccwpck_require__(45074)
-var minimatch = __nccwpck_require__(84546)
+var rp = __nccwpck_require__(56318)
+var minimatch = __nccwpck_require__(491)
 var Minimatch = minimatch.Minimatch
-var Glob = (__nccwpck_require__(20557).Glob)
+var Glob = (__nccwpck_require__(69959).Glob)
 var util = __nccwpck_require__(73837)
 var path = __nccwpck_require__(71017)
 var assert = __nccwpck_require__(39491)
-var isAbsolute = __nccwpck_require__(50124)
-var common = __nccwpck_require__(53434)
+var isAbsolute = __nccwpck_require__(76384)
+var common = __nccwpck_require__(94860)
 var setopts = common.setopts
 var ownProp = common.ownProp
 var childrenIgnored = common.childrenIgnored
@@ -47858,7 +45228,7 @@ GlobSync.prototype._makeAbs = function (f) {
 
 /***/ }),
 
-/***/ 71316:
+/***/ 83647:
 /***/ ((module) => {
 
 "use strict";
@@ -47889,13 +45259,13 @@ function clone (obj) {
 
 /***/ }),
 
-/***/ 88285:
+/***/ 59866:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 var fs = __nccwpck_require__(57147)
-var polyfills = __nccwpck_require__(50142)
-var legacy = __nccwpck_require__(66752)
-var clone = __nccwpck_require__(71316)
+var polyfills = __nccwpck_require__(71011)
+var legacy = __nccwpck_require__(64356)
+var clone = __nccwpck_require__(83647)
 
 var util = __nccwpck_require__(73837)
 
@@ -48344,7 +45714,7 @@ function retry () {
 
 /***/ }),
 
-/***/ 66752:
+/***/ 64356:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 var Stream = (__nccwpck_require__(12781).Stream)
@@ -48469,7 +45839,7 @@ function legacy (fs) {
 
 /***/ }),
 
-/***/ 50142:
+/***/ 71011:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 var constants = __nccwpck_require__(22057)
@@ -48831,7 +46201,7 @@ function patch (fs) {
 
 /***/ }),
 
-/***/ 97:
+/***/ 87583:
 /***/ ((module) => {
 
 "use strict";
@@ -48847,7 +46217,7 @@ module.exports = (flag, argv = process.argv) => {
 
 /***/ }),
 
-/***/ 98337:
+/***/ 56508:
 /***/ ((module) => {
 
 // A simple implementation of make-array
@@ -49472,12 +46842,12 @@ if (
 
 /***/ }),
 
-/***/ 60629:
+/***/ 88107:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
-var wrappy = __nccwpck_require__(63180)
+var wrappy = __nccwpck_require__(65173)
 var reqs = Object.create(null)
-var once = __nccwpck_require__(37909)
+var once = __nccwpck_require__(63767)
 
 module.exports = wrappy(inflight)
 
@@ -49533,7 +46903,7 @@ function slice (args) {
 
 /***/ }),
 
-/***/ 2868:
+/***/ 76401:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 try {
@@ -49543,13 +46913,13 @@ try {
   module.exports = util.inherits;
 } catch (e) {
   /* istanbul ignore next */
-  module.exports = __nccwpck_require__(34278);
+  module.exports = __nccwpck_require__(15195);
 }
 
 
 /***/ }),
 
-/***/ 34278:
+/***/ 15195:
 /***/ ((module) => {
 
 if (typeof Object.create === 'function') {
@@ -49583,34 +46953,7 @@ if (typeof Object.create === 'function') {
 
 /***/ }),
 
-/***/ 10890:
-/***/ ((module) => {
-
-/*!
- * is-extglob 
- *
- * Copyright (c) 2014-2016, Jon Schlinkert.
- * Licensed under the MIT License.
- */
-
-module.exports = function isExtglob(str) {
-  if (typeof str !== 'string' || str === '') {
-    return false;
-  }
-
-  var match;
-  while ((match = /(\\).|([@?!+*]\(.*\))/g.exec(str))) {
-    if (match[2]) return true;
-    str = str.slice(match.index + match[0].length);
-  }
-
-  return false;
-};
-
-
-/***/ }),
-
-/***/ 46766:
+/***/ 3221:
 /***/ ((module) => {
 
 "use strict";
@@ -49668,172 +47011,15 @@ module.exports["default"] = isFullwidthCodePoint;
 
 /***/ }),
 
-/***/ 35411:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
-
-/*!
- * is-glob 
- *
- * Copyright (c) 2014-2017, Jon Schlinkert.
- * Released under the MIT License.
- */
-
-var isExtglob = __nccwpck_require__(10890);
-var chars = { '{': '}', '(': ')', '[': ']'};
-var strictCheck = function(str) {
-  if (str[0] === '!') {
-    return true;
-  }
-  var index = 0;
-  var pipeIndex = -2;
-  var closeSquareIndex = -2;
-  var closeCurlyIndex = -2;
-  var closeParenIndex = -2;
-  var backSlashIndex = -2;
-  while (index < str.length) {
-    if (str[index] === '*') {
-      return true;
-    }
-
-    if (str[index + 1] === '?' && /[\].+)]/.test(str[index])) {
-      return true;
-    }
-
-    if (closeSquareIndex !== -1 && str[index] === '[' && str[index + 1] !== ']') {
-      if (closeSquareIndex < index) {
-        closeSquareIndex = str.indexOf(']', index);
-      }
-      if (closeSquareIndex > index) {
-        if (backSlashIndex === -1 || backSlashIndex > closeSquareIndex) {
-          return true;
-        }
-        backSlashIndex = str.indexOf('\\', index);
-        if (backSlashIndex === -1 || backSlashIndex > closeSquareIndex) {
-          return true;
-        }
-      }
-    }
-
-    if (closeCurlyIndex !== -1 && str[index] === '{' && str[index + 1] !== '}') {
-      closeCurlyIndex = str.indexOf('}', index);
-      if (closeCurlyIndex > index) {
-        backSlashIndex = str.indexOf('\\', index);
-        if (backSlashIndex === -1 || backSlashIndex > closeCurlyIndex) {
-          return true;
-        }
-      }
-    }
-
-    if (closeParenIndex !== -1 && str[index] === '(' && str[index + 1] === '?' && /[:!=]/.test(str[index + 2]) && str[index + 3] !== ')') {
-      closeParenIndex = str.indexOf(')', index);
-      if (closeParenIndex > index) {
-        backSlashIndex = str.indexOf('\\', index);
-        if (backSlashIndex === -1 || backSlashIndex > closeParenIndex) {
-          return true;
-        }
-      }
-    }
-
-    if (pipeIndex !== -1 && str[index] === '(' && str[index + 1] !== '|') {
-      if (pipeIndex < index) {
-        pipeIndex = str.indexOf('|', index);
-      }
-      if (pipeIndex !== -1 && str[pipeIndex + 1] !== ')') {
-        closeParenIndex = str.indexOf(')', pipeIndex);
-        if (closeParenIndex > pipeIndex) {
-          backSlashIndex = str.indexOf('\\', pipeIndex);
-          if (backSlashIndex === -1 || backSlashIndex > closeParenIndex) {
-            return true;
-          }
-        }
-      }
-    }
-
-    if (str[index] === '\\') {
-      var open = str[index + 1];
-      index += 2;
-      var close = chars[open];
-
-      if (close) {
-        var n = str.indexOf(close, index);
-        if (n !== -1) {
-          index = n + 1;
-        }
-      }
-
-      if (str[index] === '!') {
-        return true;
-      }
-    } else {
-      index++;
-    }
-  }
-  return false;
-};
-
-var relaxedCheck = function(str) {
-  if (str[0] === '!') {
-    return true;
-  }
-  var index = 0;
-  while (index < str.length) {
-    if (/[*?{}()[\]]/.test(str[index])) {
-      return true;
-    }
-
-    if (str[index] === '\\') {
-      var open = str[index + 1];
-      index += 2;
-      var close = chars[open];
-
-      if (close) {
-        var n = str.indexOf(close, index);
-        if (n !== -1) {
-          index = n + 1;
-        }
-      }
-
-      if (str[index] === '!') {
-        return true;
-      }
-    } else {
-      index++;
-    }
-  }
-  return false;
-};
-
-module.exports = function isGlob(str, options) {
-  if (typeof str !== 'string' || str === '') {
-    return false;
-  }
-
-  if (isExtglob(str)) {
-    return true;
-  }
-
-  var check = strictCheck;
-
-  // optionally relax check
-  if (options && options.strict === false) {
-    check = relaxedCheck;
-  }
-
-  return check(str);
-};
-
-
-/***/ }),
-
-/***/ 92595:
+/***/ 45126:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
 
 
 
-var loader = __nccwpck_require__(61652);
-var dumper = __nccwpck_require__(71136);
+var loader = __nccwpck_require__(84199);
+var dumper = __nccwpck_require__(78945);
 
 
 function renamed(from, to) {
@@ -49844,32 +47030,32 @@ function renamed(from, to) {
 }
 
 
-module.exports.Type = __nccwpck_require__(29957);
-module.exports.Schema = __nccwpck_require__(28694);
-module.exports.FAILSAFE_SCHEMA = __nccwpck_require__(85392);
-module.exports.JSON_SCHEMA = __nccwpck_require__(75257);
-module.exports.CORE_SCHEMA = __nccwpck_require__(15329);
-module.exports.DEFAULT_SCHEMA = __nccwpck_require__(40142);
+module.exports.Type = __nccwpck_require__(41646);
+module.exports.Schema = __nccwpck_require__(58362);
+module.exports.FAILSAFE_SCHEMA = __nccwpck_require__(5433);
+module.exports.JSON_SCHEMA = __nccwpck_require__(49110);
+module.exports.CORE_SCHEMA = __nccwpck_require__(66208);
+module.exports.DEFAULT_SCHEMA = __nccwpck_require__(26625);
 module.exports.load                = loader.load;
 module.exports.loadAll             = loader.loadAll;
 module.exports.dump                = dumper.dump;
-module.exports.YAMLException = __nccwpck_require__(40674);
+module.exports.YAMLException = __nccwpck_require__(61855);
 
 // Re-export all types in case user wants to create custom schema
 module.exports.types = {
-  binary:    __nccwpck_require__(74451),
-  float:     __nccwpck_require__(17137),
-  map:       __nccwpck_require__(52978),
-  null:      __nccwpck_require__(17743),
-  pairs:     __nccwpck_require__(66592),
-  set:       __nccwpck_require__(28060),
-  timestamp: __nccwpck_require__(10951),
-  bool:      __nccwpck_require__(63548),
-  int:       __nccwpck_require__(88461),
-  merge:     __nccwpck_require__(85446),
-  omap:      __nccwpck_require__(3461),
-  seq:       __nccwpck_require__(69796),
-  str:       __nccwpck_require__(47118)
+  binary:    __nccwpck_require__(23647),
+  float:     __nccwpck_require__(5258),
+  map:       __nccwpck_require__(68765),
+  null:      __nccwpck_require__(43016),
+  pairs:     __nccwpck_require__(71369),
+  set:       __nccwpck_require__(80346),
+  timestamp: __nccwpck_require__(81787),
+  bool:      __nccwpck_require__(15767),
+  int:       __nccwpck_require__(43225),
+  merge:     __nccwpck_require__(61551),
+  omap:      __nccwpck_require__(25111),
+  seq:       __nccwpck_require__(18498),
+  str:       __nccwpck_require__(64145)
 };
 
 // Removed functions from JS-YAML 3.0.x
@@ -49880,7 +47066,7 @@ module.exports.safeDump            = renamed('safeDump', 'dump');
 
 /***/ }),
 
-/***/ 49647:
+/***/ 6731:
 /***/ ((module) => {
 
 "use strict";
@@ -49947,7 +47133,7 @@ module.exports.extend         = extend;
 
 /***/ }),
 
-/***/ 71136:
+/***/ 78945:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
@@ -49955,9 +47141,9 @@ module.exports.extend         = extend;
 
 /*eslint-disable no-use-before-define*/
 
-var common              = __nccwpck_require__(49647);
-var YAMLException       = __nccwpck_require__(40674);
-var DEFAULT_SCHEMA      = __nccwpck_require__(40142);
+var common              = __nccwpck_require__(6731);
+var YAMLException       = __nccwpck_require__(61855);
+var DEFAULT_SCHEMA      = __nccwpck_require__(26625);
 
 var _toString       = Object.prototype.toString;
 var _hasOwnProperty = Object.prototype.hasOwnProperty;
@@ -50920,7 +48106,7 @@ module.exports.dump = dump;
 
 /***/ }),
 
-/***/ 40674:
+/***/ 61855:
 /***/ ((module) => {
 
 "use strict";
@@ -50983,7 +48169,7 @@ module.exports = YAMLException;
 
 /***/ }),
 
-/***/ 61652:
+/***/ 84199:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
@@ -50991,10 +48177,10 @@ module.exports = YAMLException;
 
 /*eslint-disable max-len,no-use-before-define*/
 
-var common              = __nccwpck_require__(49647);
-var YAMLException       = __nccwpck_require__(40674);
-var makeSnippet         = __nccwpck_require__(65229);
-var DEFAULT_SCHEMA      = __nccwpck_require__(40142);
+var common              = __nccwpck_require__(6731);
+var YAMLException       = __nccwpck_require__(61855);
+var makeSnippet         = __nccwpck_require__(90324);
+var DEFAULT_SCHEMA      = __nccwpck_require__(26625);
 
 
 var _hasOwnProperty = Object.prototype.hasOwnProperty;
@@ -52718,7 +49904,7 @@ module.exports.load    = load;
 
 /***/ }),
 
-/***/ 28694:
+/***/ 58362:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
@@ -52726,8 +49912,8 @@ module.exports.load    = load;
 
 /*eslint-disable max-len*/
 
-var YAMLException = __nccwpck_require__(40674);
-var Type          = __nccwpck_require__(29957);
+var YAMLException = __nccwpck_require__(61855);
+var Type          = __nccwpck_require__(41646);
 
 
 function compileList(schema, name) {
@@ -52847,7 +50033,7 @@ module.exports = Schema;
 
 /***/ }),
 
-/***/ 15329:
+/***/ 66208:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
@@ -52861,12 +50047,12 @@ module.exports = Schema;
 
 
 
-module.exports = __nccwpck_require__(75257);
+module.exports = __nccwpck_require__(49110);
 
 
 /***/ }),
 
-/***/ 40142:
+/***/ 26625:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
@@ -52880,23 +50066,23 @@ module.exports = __nccwpck_require__(75257);
 
 
 
-module.exports = (__nccwpck_require__(15329).extend)({
+module.exports = (__nccwpck_require__(66208).extend)({
   implicit: [
-    __nccwpck_require__(10951),
-    __nccwpck_require__(85446)
+    __nccwpck_require__(81787),
+    __nccwpck_require__(61551)
   ],
   explicit: [
-    __nccwpck_require__(74451),
-    __nccwpck_require__(3461),
-    __nccwpck_require__(66592),
-    __nccwpck_require__(28060)
+    __nccwpck_require__(23647),
+    __nccwpck_require__(25111),
+    __nccwpck_require__(71369),
+    __nccwpck_require__(80346)
   ]
 });
 
 
 /***/ }),
 
-/***/ 85392:
+/***/ 5433:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
@@ -52907,21 +50093,21 @@ module.exports = (__nccwpck_require__(15329).extend)({
 
 
 
-var Schema = __nccwpck_require__(28694);
+var Schema = __nccwpck_require__(58362);
 
 
 module.exports = new Schema({
   explicit: [
-    __nccwpck_require__(47118),
-    __nccwpck_require__(69796),
-    __nccwpck_require__(52978)
+    __nccwpck_require__(64145),
+    __nccwpck_require__(18498),
+    __nccwpck_require__(68765)
   ]
 });
 
 
 /***/ }),
 
-/***/ 75257:
+/***/ 49110:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
@@ -52936,26 +50122,26 @@ module.exports = new Schema({
 
 
 
-module.exports = (__nccwpck_require__(85392).extend)({
+module.exports = (__nccwpck_require__(5433).extend)({
   implicit: [
-    __nccwpck_require__(17743),
-    __nccwpck_require__(63548),
-    __nccwpck_require__(88461),
-    __nccwpck_require__(17137)
+    __nccwpck_require__(43016),
+    __nccwpck_require__(15767),
+    __nccwpck_require__(43225),
+    __nccwpck_require__(5258)
   ]
 });
 
 
 /***/ }),
 
-/***/ 65229:
+/***/ 90324:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
 
 
 
-var common = __nccwpck_require__(49647);
+var common = __nccwpck_require__(6731);
 
 
 // get snippet for a single line, respecting maxLength
@@ -53057,13 +50243,13 @@ module.exports = makeSnippet;
 
 /***/ }),
 
-/***/ 29957:
+/***/ 41646:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
 
 
-var YAMLException = __nccwpck_require__(40674);
+var YAMLException = __nccwpck_require__(61855);
 
 var TYPE_CONSTRUCTOR_OPTIONS = [
   'kind',
@@ -53131,7 +50317,7 @@ module.exports = Type;
 
 /***/ }),
 
-/***/ 74451:
+/***/ 23647:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
@@ -53140,7 +50326,7 @@ module.exports = Type;
 /*eslint-disable no-bitwise*/
 
 
-var Type = __nccwpck_require__(29957);
+var Type = __nccwpck_require__(41646);
 
 
 // [ 64, 65, 66 ] -> [ padding, CR, LF ]
@@ -53264,13 +50450,13 @@ module.exports = new Type('tag:yaml.org,2002:binary', {
 
 /***/ }),
 
-/***/ 63548:
+/***/ 15767:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
 
 
-var Type = __nccwpck_require__(29957);
+var Type = __nccwpck_require__(41646);
 
 function resolveYamlBoolean(data) {
   if (data === null) return false;
@@ -53307,14 +50493,14 @@ module.exports = new Type('tag:yaml.org,2002:bool', {
 
 /***/ }),
 
-/***/ 17137:
+/***/ 5258:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
 
 
-var common = __nccwpck_require__(49647);
-var Type   = __nccwpck_require__(29957);
+var common = __nccwpck_require__(6731);
+var Type   = __nccwpck_require__(41646);
 
 var YAML_FLOAT_PATTERN = new RegExp(
   // 2.5e4, 2.5 and integers
@@ -53412,14 +50598,14 @@ module.exports = new Type('tag:yaml.org,2002:float', {
 
 /***/ }),
 
-/***/ 88461:
+/***/ 43225:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
 
 
-var common = __nccwpck_require__(49647);
-var Type   = __nccwpck_require__(29957);
+var common = __nccwpck_require__(6731);
+var Type   = __nccwpck_require__(41646);
 
 function isHexCode(c) {
   return ((0x30/* 0 */ <= c) && (c <= 0x39/* 9 */)) ||
@@ -53576,13 +50762,13 @@ module.exports = new Type('tag:yaml.org,2002:int', {
 
 /***/ }),
 
-/***/ 52978:
+/***/ 68765:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
 
 
-var Type = __nccwpck_require__(29957);
+var Type = __nccwpck_require__(41646);
 
 module.exports = new Type('tag:yaml.org,2002:map', {
   kind: 'mapping',
@@ -53592,13 +50778,13 @@ module.exports = new Type('tag:yaml.org,2002:map', {
 
 /***/ }),
 
-/***/ 85446:
+/***/ 61551:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
 
 
-var Type = __nccwpck_require__(29957);
+var Type = __nccwpck_require__(41646);
 
 function resolveYamlMerge(data) {
   return data === '<<' || data === null;
@@ -53612,13 +50798,13 @@ module.exports = new Type('tag:yaml.org,2002:merge', {
 
 /***/ }),
 
-/***/ 17743:
+/***/ 43016:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
 
 
-var Type = __nccwpck_require__(29957);
+var Type = __nccwpck_require__(41646);
 
 function resolveYamlNull(data) {
   if (data === null) return true;
@@ -53655,13 +50841,13 @@ module.exports = new Type('tag:yaml.org,2002:null', {
 
 /***/ }),
 
-/***/ 3461:
+/***/ 25111:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
 
 
-var Type = __nccwpck_require__(29957);
+var Type = __nccwpck_require__(41646);
 
 var _hasOwnProperty = Object.prototype.hasOwnProperty;
 var _toString       = Object.prototype.toString;
@@ -53707,13 +50893,13 @@ module.exports = new Type('tag:yaml.org,2002:omap', {
 
 /***/ }),
 
-/***/ 66592:
+/***/ 71369:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
 
 
-var Type = __nccwpck_require__(29957);
+var Type = __nccwpck_require__(41646);
 
 var _toString = Object.prototype.toString;
 
@@ -53768,13 +50954,13 @@ module.exports = new Type('tag:yaml.org,2002:pairs', {
 
 /***/ }),
 
-/***/ 69796:
+/***/ 18498:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
 
 
-var Type = __nccwpck_require__(29957);
+var Type = __nccwpck_require__(41646);
 
 module.exports = new Type('tag:yaml.org,2002:seq', {
   kind: 'sequence',
@@ -53784,13 +50970,13 @@ module.exports = new Type('tag:yaml.org,2002:seq', {
 
 /***/ }),
 
-/***/ 28060:
+/***/ 80346:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
 
 
-var Type = __nccwpck_require__(29957);
+var Type = __nccwpck_require__(41646);
 
 var _hasOwnProperty = Object.prototype.hasOwnProperty;
 
@@ -53821,13 +51007,13 @@ module.exports = new Type('tag:yaml.org,2002:set', {
 
 /***/ }),
 
-/***/ 47118:
+/***/ 64145:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
 
 
-var Type = __nccwpck_require__(29957);
+var Type = __nccwpck_require__(41646);
 
 module.exports = new Type('tag:yaml.org,2002:str', {
   kind: 'scalar',
@@ -53837,13 +51023,13 @@ module.exports = new Type('tag:yaml.org,2002:str', {
 
 /***/ }),
 
-/***/ 10951:
+/***/ 81787:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
 
 
-var Type = __nccwpck_require__(29957);
+var Type = __nccwpck_require__(41646);
 
 var YAML_DATE_REGEXP = new RegExp(
   '^([0-9][0-9][0-9][0-9])'          + // [1] year
@@ -53933,11 +51119,11 @@ module.exports = new Type('tag:yaml.org,2002:timestamp', {
 
 /***/ }),
 
-/***/ 89501:
+/***/ 29941:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
-const parse = __nccwpck_require__(94362)
-const stringify = __nccwpck_require__(11686)
+const parse = __nccwpck_require__(84575)
+const stringify = __nccwpck_require__(38193)
 
 const JSON5 = {
     parse,
@@ -53949,10 +51135,10 @@ module.exports = JSON5
 
 /***/ }),
 
-/***/ 94362:
+/***/ 84575:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
-const util = __nccwpck_require__(46400)
+const util = __nccwpck_require__(70040)
 
 let source
 let parseState
@@ -55070,10 +52256,10 @@ function syntaxError (message) {
 
 /***/ }),
 
-/***/ 11686:
+/***/ 38193:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
-const util = __nccwpck_require__(46400)
+const util = __nccwpck_require__(70040)
 
 module.exports = function stringify (value, replacer, space) {
     const stack = []
@@ -55338,7 +52524,7 @@ module.exports = function stringify (value, replacer, space) {
 
 /***/ }),
 
-/***/ 43366:
+/***/ 90424:
 /***/ ((module) => {
 
 // This is a generated file. Do not edit.
@@ -55349,10 +52535,10 @@ module.exports.ID_Continue = /[\xAA\xB5\xBA\xC0-\xD6\xD8-\xF6\xF8-\u02C1\u02C6-\
 
 /***/ }),
 
-/***/ 46400:
+/***/ 70040:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
-const unicode = __nccwpck_require__(43366)
+const unicode = __nccwpck_require__(90424)
 
 module.exports = {
     isSpaceSeparator (c) {
@@ -55391,7 +52577,7 @@ module.exports = {
 
 /***/ }),
 
-/***/ 99810:
+/***/ 25515:
 /***/ ((module, exports, __nccwpck_require__) => {
 
 (function (factory) {
@@ -55410,8 +52596,8 @@ module.exports = {
     'use strict';
     Object.defineProperty(exports, "__esModule", ({ value: true }));
     exports.isWS = exports.applyEdit = exports.setProperty = exports.removeProperty = void 0;
-    const format_1 = __nccwpck_require__(22018);
-    const parser_1 = __nccwpck_require__(22622);
+    const format_1 = __nccwpck_require__(37985);
+    const parser_1 = __nccwpck_require__(21169);
     function removeProperty(text, path, options) {
         return setProperty(text, path, void 0, options);
     }
@@ -55599,7 +52785,7 @@ module.exports = {
 
 /***/ }),
 
-/***/ 22018:
+/***/ 37985:
 /***/ ((module, exports, __nccwpck_require__) => {
 
 (function (factory) {
@@ -55618,7 +52804,7 @@ module.exports = {
     'use strict';
     Object.defineProperty(exports, "__esModule", ({ value: true }));
     exports.isEOL = exports.format = void 0;
-    const scanner_1 = __nccwpck_require__(78859);
+    const scanner_1 = __nccwpck_require__(16044);
     function format(documentText, range, options) {
         let initialIndentLevel;
         let formatText;
@@ -55871,7 +53057,7 @@ module.exports = {
 
 /***/ }),
 
-/***/ 22622:
+/***/ 21169:
 /***/ ((module, exports, __nccwpck_require__) => {
 
 (function (factory) {
@@ -55890,7 +53076,7 @@ module.exports = {
     'use strict';
     Object.defineProperty(exports, "__esModule", ({ value: true }));
     exports.getNodeType = exports.stripComments = exports.visit = exports.findNodeAtOffset = exports.contains = exports.getNodeValue = exports.getNodePath = exports.findNodeAtLocation = exports.parseTree = exports.parse = exports.getLocation = void 0;
-    const scanner_1 = __nccwpck_require__(78859);
+    const scanner_1 = __nccwpck_require__(16044);
     var ParseOptions;
     (function (ParseOptions) {
         ParseOptions.DEFAULT = {
@@ -56533,7 +53719,7 @@ module.exports = {
 
 /***/ }),
 
-/***/ 78859:
+/***/ 16044:
 /***/ ((module, exports) => {
 
 (function (factory) {
@@ -56996,7 +54182,7 @@ module.exports = {
 
 /***/ }),
 
-/***/ 56416:
+/***/ 18875:
 /***/ ((module, exports, __nccwpck_require__) => {
 
 (function (factory) {
@@ -57015,10 +54201,10 @@ module.exports = {
     'use strict';
     Object.defineProperty(exports, "__esModule", ({ value: true }));
     exports.applyEdits = exports.modify = exports.format = exports.printParseErrorCode = exports.ParseErrorCode = exports.stripComments = exports.visit = exports.getNodeValue = exports.getNodePath = exports.findNodeAtOffset = exports.findNodeAtLocation = exports.parseTree = exports.parse = exports.getLocation = exports.SyntaxKind = exports.ScanError = exports.createScanner = void 0;
-    const formatter = __nccwpck_require__(22018);
-    const edit = __nccwpck_require__(99810);
-    const scanner = __nccwpck_require__(78859);
-    const parser = __nccwpck_require__(22622);
+    const formatter = __nccwpck_require__(37985);
+    const edit = __nccwpck_require__(25515);
+    const scanner = __nccwpck_require__(16044);
+    const parser = __nccwpck_require__(21169);
     /**
      * Creates a JSON scanner on the given text.
      * If ignoreTrivia is set, whitespaces or comments are ignored.
@@ -57197,17 +54383,17 @@ module.exports = {
 
 /***/ }),
 
-/***/ 77681:
+/***/ 3653:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 let _fs
 try {
-  _fs = __nccwpck_require__(88285)
+  _fs = __nccwpck_require__(59866)
 } catch (_) {
   _fs = __nccwpck_require__(57147)
 }
-const universalify = __nccwpck_require__(82787)
-const { stringify, stripBom } = __nccwpck_require__(47667)
+const universalify = __nccwpck_require__(63931)
+const { stringify, stripBom } = __nccwpck_require__(13379)
 
 async function _readFile (file, options = {}) {
   if (typeof options === 'string') {
@@ -57292,7 +54478,7 @@ module.exports = jsonfile
 
 /***/ }),
 
-/***/ 47667:
+/***/ 13379:
 /***/ ((module) => {
 
 function stringify (obj, { EOL = '\n', finalEOL = true, replacer = null, spaces } = {}) {
@@ -57313,14 +54499,14 @@ module.exports = { stringify, stripBom }
 
 /***/ }),
 
-/***/ 83617:
+/***/ 17963:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
 
 
 // A linked list to keep track of recently-used-ness
-const Yallist = __nccwpck_require__(19385)
+const Yallist = __nccwpck_require__(83278)
 
 const MAX = Symbol('max')
 const LENGTH = Symbol('length')
@@ -57655,7 +54841,7 @@ module.exports = LRUCache
 
 /***/ }),
 
-/***/ 80976:
+/***/ 46419:
 /***/ ((module, exports) => {
 
 "use strict";
@@ -57814,634 +55000,7 @@ exports.BaseError = BaseError;
 
 /***/ }),
 
-/***/ 30268:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
-
-"use strict";
-
-/*
- * merge2
- * https://github.com/teambition/merge2
- *
- * Copyright (c) 2014-2020 Teambition
- * Licensed under the MIT license.
- */
-const Stream = __nccwpck_require__(12781)
-const PassThrough = Stream.PassThrough
-const slice = Array.prototype.slice
-
-module.exports = merge2
-
-function merge2 () {
-  const streamsQueue = []
-  const args = slice.call(arguments)
-  let merging = false
-  let options = args[args.length - 1]
-
-  if (options && !Array.isArray(options) && options.pipe == null) {
-    args.pop()
-  } else {
-    options = {}
-  }
-
-  const doEnd = options.end !== false
-  const doPipeError = options.pipeError === true
-  if (options.objectMode == null) {
-    options.objectMode = true
-  }
-  if (options.highWaterMark == null) {
-    options.highWaterMark = 64 * 1024
-  }
-  const mergedStream = PassThrough(options)
-
-  function addStream () {
-    for (let i = 0, len = arguments.length; i < len; i++) {
-      streamsQueue.push(pauseStreams(arguments[i], options))
-    }
-    mergeStream()
-    return this
-  }
-
-  function mergeStream () {
-    if (merging) {
-      return
-    }
-    merging = true
-
-    let streams = streamsQueue.shift()
-    if (!streams) {
-      process.nextTick(endStream)
-      return
-    }
-    if (!Array.isArray(streams)) {
-      streams = [streams]
-    }
-
-    let pipesCount = streams.length + 1
-
-    function next () {
-      if (--pipesCount > 0) {
-        return
-      }
-      merging = false
-      mergeStream()
-    }
-
-    function pipe (stream) {
-      function onend () {
-        stream.removeListener('merge2UnpipeEnd', onend)
-        stream.removeListener('end', onend)
-        if (doPipeError) {
-          stream.removeListener('error', onerror)
-        }
-        next()
-      }
-      function onerror (err) {
-        mergedStream.emit('error', err)
-      }
-      // skip ended stream
-      if (stream._readableState.endEmitted) {
-        return next()
-      }
-
-      stream.on('merge2UnpipeEnd', onend)
-      stream.on('end', onend)
-
-      if (doPipeError) {
-        stream.on('error', onerror)
-      }
-
-      stream.pipe(mergedStream, { end: false })
-      // compatible for old stream
-      stream.resume()
-    }
-
-    for (let i = 0; i < streams.length; i++) {
-      pipe(streams[i])
-    }
-
-    next()
-  }
-
-  function endStream () {
-    merging = false
-    // emit 'queueDrain' when all streams merged.
-    mergedStream.emit('queueDrain')
-    if (doEnd) {
-      mergedStream.end()
-    }
-  }
-
-  mergedStream.setMaxListeners(0)
-  mergedStream.add = addStream
-  mergedStream.on('unpipe', function (stream) {
-    stream.emit('merge2UnpipeEnd')
-  })
-
-  if (args.length) {
-    addStream.apply(null, args)
-  }
-  return mergedStream
-}
-
-// check and pause streams for pipe.
-function pauseStreams (streams, options) {
-  if (!Array.isArray(streams)) {
-    // Backwards-compat with old-style streams
-    if (!streams._readableState && streams.pipe) {
-      streams = streams.pipe(PassThrough(options))
-    }
-    if (!streams._readableState || !streams.pause || !streams.pipe) {
-      throw new Error('Only readable stream can be merged.')
-    }
-    streams.pause()
-  } else {
-    for (let i = 0, len = streams.length; i < len; i++) {
-      streams[i] = pauseStreams(streams[i], options)
-    }
-  }
-  return streams
-}
-
-
-/***/ }),
-
-/***/ 99573:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
-
-"use strict";
-
-
-const util = __nccwpck_require__(73837);
-const braces = __nccwpck_require__(2473);
-const picomatch = __nccwpck_require__(21224);
-const utils = __nccwpck_require__(76088);
-const isEmptyString = val => val === '' || val === './';
-
-/**
- * Returns an array of strings that match one or more glob patterns.
- *
- * ```js
- * const mm = require('micromatch');
- * // mm(list, patterns[, options]);
- *
- * console.log(mm(['a.js', 'a.txt'], ['*.js']));
- * //=> [ 'a.js' ]
- * ```
- * @param {String|Array} `list` List of strings to match.
- * @param {String|Array} `patterns` One or more glob patterns to use for matching.
- * @param {Object} `options` See available [options](#options)
- * @return {Array} Returns an array of matches
- * @summary false
- * @api public
- */
-
-const micromatch = (list, patterns, options) => {
-  patterns = [].concat(patterns);
-  list = [].concat(list);
-
-  let omit = new Set();
-  let keep = new Set();
-  let items = new Set();
-  let negatives = 0;
-
-  let onResult = state => {
-    items.add(state.output);
-    if (options && options.onResult) {
-      options.onResult(state);
-    }
-  };
-
-  for (let i = 0; i < patterns.length; i++) {
-    let isMatch = picomatch(String(patterns[i]), { ...options, onResult }, true);
-    let negated = isMatch.state.negated || isMatch.state.negatedExtglob;
-    if (negated) negatives++;
-
-    for (let item of list) {
-      let matched = isMatch(item, true);
-
-      let match = negated ? !matched.isMatch : matched.isMatch;
-      if (!match) continue;
-
-      if (negated) {
-        omit.add(matched.output);
-      } else {
-        omit.delete(matched.output);
-        keep.add(matched.output);
-      }
-    }
-  }
-
-  let result = negatives === patterns.length ? [...items] : [...keep];
-  let matches = result.filter(item => !omit.has(item));
-
-  if (options && matches.length === 0) {
-    if (options.failglob === true) {
-      throw new Error(`No matches found for "${patterns.join(', ')}"`);
-    }
-
-    if (options.nonull === true || options.nullglob === true) {
-      return options.unescape ? patterns.map(p => p.replace(/\\/g, '')) : patterns;
-    }
-  }
-
-  return matches;
-};
-
-/**
- * Backwards compatibility
- */
-
-micromatch.match = micromatch;
-
-/**
- * Returns a matcher function from the given glob `pattern` and `options`.
- * The returned function takes a string to match as its only argument and returns
- * true if the string is a match.
- *
- * ```js
- * const mm = require('micromatch');
- * // mm.matcher(pattern[, options]);
- *
- * const isMatch = mm.matcher('*.!(*a)');
- * console.log(isMatch('a.a')); //=> false
- * console.log(isMatch('a.b')); //=> true
- * ```
- * @param {String} `pattern` Glob pattern
- * @param {Object} `options`
- * @return {Function} Returns a matcher function.
- * @api public
- */
-
-micromatch.matcher = (pattern, options) => picomatch(pattern, options);
-
-/**
- * Returns true if **any** of the given glob `patterns` match the specified `string`.
- *
- * ```js
- * const mm = require('micromatch');
- * // mm.isMatch(string, patterns[, options]);
- *
- * console.log(mm.isMatch('a.a', ['b.*', '*.a'])); //=> true
- * console.log(mm.isMatch('a.a', 'b.*')); //=> false
- * ```
- * @param {String} `str` The string to test.
- * @param {String|Array} `patterns` One or more glob patterns to use for matching.
- * @param {Object} `[options]` See available [options](#options).
- * @return {Boolean} Returns true if any patterns match `str`
- * @api public
- */
-
-micromatch.isMatch = (str, patterns, options) => picomatch(patterns, options)(str);
-
-/**
- * Backwards compatibility
- */
-
-micromatch.any = micromatch.isMatch;
-
-/**
- * Returns a list of strings that _**do not match any**_ of the given `patterns`.
- *
- * ```js
- * const mm = require('micromatch');
- * // mm.not(list, patterns[, options]);
- *
- * console.log(mm.not(['a.a', 'b.b', 'c.c'], '*.a'));
- * //=> ['b.b', 'c.c']
- * ```
- * @param {Array} `list` Array of strings to match.
- * @param {String|Array} `patterns` One or more glob pattern to use for matching.
- * @param {Object} `options` See available [options](#options) for changing how matches are performed
- * @return {Array} Returns an array of strings that **do not match** the given patterns.
- * @api public
- */
-
-micromatch.not = (list, patterns, options = {}) => {
-  patterns = [].concat(patterns).map(String);
-  let result = new Set();
-  let items = [];
-
-  let onResult = state => {
-    if (options.onResult) options.onResult(state);
-    items.push(state.output);
-  };
-
-  let matches = new Set(micromatch(list, patterns, { ...options, onResult }));
-
-  for (let item of items) {
-    if (!matches.has(item)) {
-      result.add(item);
-    }
-  }
-  return [...result];
-};
-
-/**
- * Returns true if the given `string` contains the given pattern. Similar
- * to [.isMatch](#isMatch) but the pattern can match any part of the string.
- *
- * ```js
- * var mm = require('micromatch');
- * // mm.contains(string, pattern[, options]);
- *
- * console.log(mm.contains('aa/bb/cc', '*b'));
- * //=> true
- * console.log(mm.contains('aa/bb/cc', '*d'));
- * //=> false
- * ```
- * @param {String} `str` The string to match.
- * @param {String|Array} `patterns` Glob pattern to use for matching.
- * @param {Object} `options` See available [options](#options) for changing how matches are performed
- * @return {Boolean} Returns true if any of the patterns matches any part of `str`.
- * @api public
- */
-
-micromatch.contains = (str, pattern, options) => {
-  if (typeof str !== 'string') {
-    throw new TypeError(`Expected a string: "${util.inspect(str)}"`);
-  }
-
-  if (Array.isArray(pattern)) {
-    return pattern.some(p => micromatch.contains(str, p, options));
-  }
-
-  if (typeof pattern === 'string') {
-    if (isEmptyString(str) || isEmptyString(pattern)) {
-      return false;
-    }
-
-    if (str.includes(pattern) || (str.startsWith('./') && str.slice(2).includes(pattern))) {
-      return true;
-    }
-  }
-
-  return micromatch.isMatch(str, pattern, { ...options, contains: true });
-};
-
-/**
- * Filter the keys of the given object with the given `glob` pattern
- * and `options`. Does not attempt to match nested keys. If you need this feature,
- * use [glob-object][] instead.
- *
- * ```js
- * const mm = require('micromatch');
- * // mm.matchKeys(object, patterns[, options]);
- *
- * const obj = { aa: 'a', ab: 'b', ac: 'c' };
- * console.log(mm.matchKeys(obj, '*b'));
- * //=> { ab: 'b' }
- * ```
- * @param {Object} `object` The object with keys to filter.
- * @param {String|Array} `patterns` One or more glob patterns to use for matching.
- * @param {Object} `options` See available [options](#options) for changing how matches are performed
- * @return {Object} Returns an object with only keys that match the given patterns.
- * @api public
- */
-
-micromatch.matchKeys = (obj, patterns, options) => {
-  if (!utils.isObject(obj)) {
-    throw new TypeError('Expected the first argument to be an object');
-  }
-  let keys = micromatch(Object.keys(obj), patterns, options);
-  let res = {};
-  for (let key of keys) res[key] = obj[key];
-  return res;
-};
-
-/**
- * Returns true if some of the strings in the given `list` match any of the given glob `patterns`.
- *
- * ```js
- * const mm = require('micromatch');
- * // mm.some(list, patterns[, options]);
- *
- * console.log(mm.some(['foo.js', 'bar.js'], ['*.js', '!foo.js']));
- * // true
- * console.log(mm.some(['foo.js'], ['*.js', '!foo.js']));
- * // false
- * ```
- * @param {String|Array} `list` The string or array of strings to test. Returns as soon as the first match is found.
- * @param {String|Array} `patterns` One or more glob patterns to use for matching.
- * @param {Object} `options` See available [options](#options) for changing how matches are performed
- * @return {Boolean} Returns true if any `patterns` matches any of the strings in `list`
- * @api public
- */
-
-micromatch.some = (list, patterns, options) => {
-  let items = [].concat(list);
-
-  for (let pattern of [].concat(patterns)) {
-    let isMatch = picomatch(String(pattern), options);
-    if (items.some(item => isMatch(item))) {
-      return true;
-    }
-  }
-  return false;
-};
-
-/**
- * Returns true if every string in the given `list` matches
- * any of the given glob `patterns`.
- *
- * ```js
- * const mm = require('micromatch');
- * // mm.every(list, patterns[, options]);
- *
- * console.log(mm.every('foo.js', ['foo.js']));
- * // true
- * console.log(mm.every(['foo.js', 'bar.js'], ['*.js']));
- * // true
- * console.log(mm.every(['foo.js', 'bar.js'], ['*.js', '!foo.js']));
- * // false
- * console.log(mm.every(['foo.js'], ['*.js', '!foo.js']));
- * // false
- * ```
- * @param {String|Array} `list` The string or array of strings to test.
- * @param {String|Array} `patterns` One or more glob patterns to use for matching.
- * @param {Object} `options` See available [options](#options) for changing how matches are performed
- * @return {Boolean} Returns true if all `patterns` matches all of the strings in `list`
- * @api public
- */
-
-micromatch.every = (list, patterns, options) => {
-  let items = [].concat(list);
-
-  for (let pattern of [].concat(patterns)) {
-    let isMatch = picomatch(String(pattern), options);
-    if (!items.every(item => isMatch(item))) {
-      return false;
-    }
-  }
-  return true;
-};
-
-/**
- * Returns true if **all** of the given `patterns` match
- * the specified string.
- *
- * ```js
- * const mm = require('micromatch');
- * // mm.all(string, patterns[, options]);
- *
- * console.log(mm.all('foo.js', ['foo.js']));
- * // true
- *
- * console.log(mm.all('foo.js', ['*.js', '!foo.js']));
- * // false
- *
- * console.log(mm.all('foo.js', ['*.js', 'foo.js']));
- * // true
- *
- * console.log(mm.all('foo.js', ['*.js', 'f*', '*o*', '*o.js']));
- * // true
- * ```
- * @param {String|Array} `str` The string to test.
- * @param {String|Array} `patterns` One or more glob patterns to use for matching.
- * @param {Object} `options` See available [options](#options) for changing how matches are performed
- * @return {Boolean} Returns true if any patterns match `str`
- * @api public
- */
-
-micromatch.all = (str, patterns, options) => {
-  if (typeof str !== 'string') {
-    throw new TypeError(`Expected a string: "${util.inspect(str)}"`);
-  }
-
-  return [].concat(patterns).every(p => picomatch(p, options)(str));
-};
-
-/**
- * Returns an array of matches captured by `pattern` in `string, or `null` if the pattern did not match.
- *
- * ```js
- * const mm = require('micromatch');
- * // mm.capture(pattern, string[, options]);
- *
- * console.log(mm.capture('test/*.js', 'test/foo.js'));
- * //=> ['foo']
- * console.log(mm.capture('test/*.js', 'foo/bar.css'));
- * //=> null
- * ```
- * @param {String} `glob` Glob pattern to use for matching.
- * @param {String} `input` String to match
- * @param {Object} `options` See available [options](#options) for changing how matches are performed
- * @return {Array|null} Returns an array of captures if the input matches the glob pattern, otherwise `null`.
- * @api public
- */
-
-micromatch.capture = (glob, input, options) => {
-  let posix = utils.isWindows(options);
-  let regex = picomatch.makeRe(String(glob), { ...options, capture: true });
-  let match = regex.exec(posix ? utils.toPosixSlashes(input) : input);
-
-  if (match) {
-    return match.slice(1).map(v => v === void 0 ? '' : v);
-  }
-};
-
-/**
- * Create a regular expression from the given glob `pattern`.
- *
- * ```js
- * const mm = require('micromatch');
- * // mm.makeRe(pattern[, options]);
- *
- * console.log(mm.makeRe('*.js'));
- * //=> /^(?:(\.[\\\/])?(?!\.)(?=.)[^\/]*?\.js)$/
- * ```
- * @param {String} `pattern` A glob pattern to convert to regex.
- * @param {Object} `options`
- * @return {RegExp} Returns a regex created from the given pattern.
- * @api public
- */
-
-micromatch.makeRe = (...args) => picomatch.makeRe(...args);
-
-/**
- * Scan a glob pattern to separate the pattern into segments. Used
- * by the [split](#split) method.
- *
- * ```js
- * const mm = require('micromatch');
- * const state = mm.scan(pattern[, options]);
- * ```
- * @param {String} `pattern`
- * @param {Object} `options`
- * @return {Object} Returns an object with
- * @api public
- */
-
-micromatch.scan = (...args) => picomatch.scan(...args);
-
-/**
- * Parse a glob pattern to create the source string for a regular
- * expression.
- *
- * ```js
- * const mm = require('micromatch');
- * const state = mm.parse(pattern[, options]);
- * ```
- * @param {String} `glob`
- * @param {Object} `options`
- * @return {Object} Returns an object with useful properties and output to be used as regex source string.
- * @api public
- */
-
-micromatch.parse = (patterns, options) => {
-  let res = [];
-  for (let pattern of [].concat(patterns || [])) {
-    for (let str of braces(String(pattern), options)) {
-      res.push(picomatch.parse(str, options));
-    }
-  }
-  return res;
-};
-
-/**
- * Process the given brace `pattern`.
- *
- * ```js
- * const { braces } = require('micromatch');
- * console.log(braces('foo/{a,b,c}/bar'));
- * //=> [ 'foo/(a|b|c)/bar' ]
- *
- * console.log(braces('foo/{a,b,c}/bar', { expand: true }));
- * //=> [ 'foo/a/bar', 'foo/b/bar', 'foo/c/bar' ]
- * ```
- * @param {String} `pattern` String with brace pattern to process.
- * @param {Object} `options` Any [options](#options) to change how expansion is performed. See the [braces][] library for all available options.
- * @return {Array}
- * @api public
- */
-
-micromatch.braces = (pattern, options) => {
-  if (typeof pattern !== 'string') throw new TypeError('Expected a string');
-  if ((options && options.nobrace === true) || !/\{.*\}/.test(pattern)) {
-    return [pattern];
-  }
-  return braces(pattern, options);
-};
-
-/**
- * Expand braces
- */
-
-micromatch.braceExpand = (pattern, options) => {
-  if (typeof pattern !== 'string') throw new TypeError('Expected a string');
-  return micromatch.braces(pattern, { ...options, expand: true });
-};
-
-/**
- * Expose micromatch
- */
-
-module.exports = micromatch;
-
-
-/***/ }),
-
-/***/ 84546:
+/***/ 491:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 module.exports = minimatch
@@ -58453,7 +55012,7 @@ var path = (function () { try { return __nccwpck_require__(71017) } catch (e) {}
 minimatch.sep = path.sep
 
 var GLOBSTAR = minimatch.GLOBSTAR = Minimatch.GLOBSTAR = {}
-var expand = __nccwpck_require__(6265)
+var expand = __nccwpck_require__(34792)
 
 var plTypes = {
   '!': { open: '(?:(?!(?:', close: '))[^/]*?)'},
@@ -59395,11 +55954,11 @@ function regExpEscape (s) {
 
 /***/ }),
 
-/***/ 6265:
+/***/ 34792:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
-var concatMap = __nccwpck_require__(50819);
-var balanced = __nccwpck_require__(94015);
+var concatMap = __nccwpck_require__(90353);
+var balanced = __nccwpck_require__(77524);
 
 module.exports = expandTop;
 
@@ -59603,7 +56162,7 @@ function expand(str, isTop) {
 
 /***/ }),
 
-/***/ 11474:
+/***/ 40311:
 /***/ ((module) => {
 
 "use strict";
@@ -59874,1412 +56433,17 @@ module.exports = function (args, opts) {
 
 /***/ }),
 
-/***/ 88149:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
-
-var concatMap = __nccwpck_require__(50819);
-var balanced = __nccwpck_require__(94015);
-
-module.exports = expandTop;
-
-var escSlash = '\0SLASH'+Math.random()+'\0';
-var escOpen = '\0OPEN'+Math.random()+'\0';
-var escClose = '\0CLOSE'+Math.random()+'\0';
-var escComma = '\0COMMA'+Math.random()+'\0';
-var escPeriod = '\0PERIOD'+Math.random()+'\0';
-
-function numeric(str) {
-  return parseInt(str, 10) == str
-    ? parseInt(str, 10)
-    : str.charCodeAt(0);
-}
-
-function escapeBraces(str) {
-  return str.split('\\\\').join(escSlash)
-            .split('\\{').join(escOpen)
-            .split('\\}').join(escClose)
-            .split('\\,').join(escComma)
-            .split('\\.').join(escPeriod);
-}
-
-function unescapeBraces(str) {
-  return str.split(escSlash).join('\\')
-            .split(escOpen).join('{')
-            .split(escClose).join('}')
-            .split(escComma).join(',')
-            .split(escPeriod).join('.');
-}
-
-
-// Basically just str.split(","), but handling cases
-// where we have nested braced sections, which should be
-// treated as individual members, like {a,{b,c},d}
-function parseCommaParts(str) {
-  if (!str)
-    return [''];
-
-  var parts = [];
-  var m = balanced('{', '}', str);
-
-  if (!m)
-    return str.split(',');
-
-  var pre = m.pre;
-  var body = m.body;
-  var post = m.post;
-  var p = pre.split(',');
-
-  p[p.length-1] += '{' + body + '}';
-  var postParts = parseCommaParts(post);
-  if (post.length) {
-    p[p.length-1] += postParts.shift();
-    p.push.apply(p, postParts);
-  }
-
-  parts.push.apply(parts, p);
-
-  return parts;
-}
-
-function expandTop(str) {
-  if (!str)
-    return [];
-
-  // I don't know why Bash 4.3 does this, but it does.
-  // Anything starting with {} will have the first two bytes preserved
-  // but *only* at the top level, so {},a}b will not expand to anything,
-  // but a{},b}c will be expanded to [a}c,abc].
-  // One could argue that this is a bug in Bash, but since the goal of
-  // this module is to match Bash's rules, we escape a leading {}
-  if (str.substr(0, 2) === '{}') {
-    str = '\\{\\}' + str.substr(2);
-  }
-
-  return expand(escapeBraces(str), true).map(unescapeBraces);
-}
-
-function identity(e) {
-  return e;
-}
-
-function embrace(str) {
-  return '{' + str + '}';
-}
-function isPadded(el) {
-  return /^-?0\d/.test(el);
-}
-
-function lte(i, y) {
-  return i <= y;
-}
-function gte(i, y) {
-  return i >= y;
-}
-
-function expand(str, isTop) {
-  var expansions = [];
-
-  var m = balanced('{', '}', str);
-  if (!m || /\$$/.test(m.pre)) return [str];
-
-  var isNumericSequence = /^-?\d+\.\.-?\d+(?:\.\.-?\d+)?$/.test(m.body);
-  var isAlphaSequence = /^[a-zA-Z]\.\.[a-zA-Z](?:\.\.-?\d+)?$/.test(m.body);
-  var isSequence = isNumericSequence || isAlphaSequence;
-  var isOptions = m.body.indexOf(',') >= 0;
-  if (!isSequence && !isOptions) {
-    // {a},b}
-    if (m.post.match(/,.*\}/)) {
-      str = m.pre + '{' + m.body + escClose + m.post;
-      return expand(str);
-    }
-    return [str];
-  }
-
-  var n;
-  if (isSequence) {
-    n = m.body.split(/\.\./);
-  } else {
-    n = parseCommaParts(m.body);
-    if (n.length === 1) {
-      // x{{a,b}}y ==> x{a}y x{b}y
-      n = expand(n[0], false).map(embrace);
-      if (n.length === 1) {
-        var post = m.post.length
-          ? expand(m.post, false)
-          : [''];
-        return post.map(function(p) {
-          return m.pre + n[0] + p;
-        });
-      }
-    }
-  }
-
-  // at this point, n is the parts, and we know it's not a comma set
-  // with a single entry.
-
-  // no need to expand pre, since it is guaranteed to be free of brace-sets
-  var pre = m.pre;
-  var post = m.post.length
-    ? expand(m.post, false)
-    : [''];
-
-  var N;
-
-  if (isSequence) {
-    var x = numeric(n[0]);
-    var y = numeric(n[1]);
-    var width = Math.max(n[0].length, n[1].length)
-    var incr = n.length == 3
-      ? Math.abs(numeric(n[2]))
-      : 1;
-    var test = lte;
-    var reverse = y < x;
-    if (reverse) {
-      incr *= -1;
-      test = gte;
-    }
-    var pad = n.some(isPadded);
-
-    N = [];
-
-    for (var i = x; test(i, y); i += incr) {
-      var c;
-      if (isAlphaSequence) {
-        c = String.fromCharCode(i);
-        if (c === '\\')
-          c = '';
-      } else {
-        c = String(i);
-        if (pad) {
-          var need = width - c.length;
-          if (need > 0) {
-            var z = new Array(need + 1).join('0');
-            if (i < 0)
-              c = '-' + z + c.slice(1);
-            else
-              c = z + c;
-          }
-        }
-      }
-      N.push(c);
-    }
-  } else {
-    N = concatMap(n, function(el) { return expand(el, false) });
-  }
-
-  for (var j = 0; j < N.length; j++) {
-    for (var k = 0; k < post.length; k++) {
-      var expansion = pre + N[j] + post[k];
-      if (!isTop || isSequence || expansion)
-        expansions.push(expansion);
-    }
-  }
-
-  return expansions;
-}
-
-
-
-/***/ }),
-
-/***/ 19131:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
-
-"use strict";
-
-const taskManager = __nccwpck_require__(82845);
-const async_1 = __nccwpck_require__(48123);
-const stream_1 = __nccwpck_require__(36672);
-const sync_1 = __nccwpck_require__(48463);
-const settings_1 = __nccwpck_require__(67938);
-const utils = __nccwpck_require__(74219);
-async function FastGlob(source, options) {
-    assertPatternsInput(source);
-    const works = getWorks(source, async_1.default, options);
-    const result = await Promise.all(works);
-    return utils.array.flatten(result);
-}
-// https://github.com/typescript-eslint/typescript-eslint/issues/60
-// eslint-disable-next-line no-redeclare
-(function (FastGlob) {
-    function sync(source, options) {
-        assertPatternsInput(source);
-        const works = getWorks(source, sync_1.default, options);
-        return utils.array.flatten(works);
-    }
-    FastGlob.sync = sync;
-    function stream(source, options) {
-        assertPatternsInput(source);
-        const works = getWorks(source, stream_1.default, options);
-        /**
-         * The stream returned by the provider cannot work with an asynchronous iterator.
-         * To support asynchronous iterators, regardless of the number of tasks, we always multiplex streams.
-         * This affects performance (+25%). I don't see best solution right now.
-         */
-        return utils.stream.merge(works);
-    }
-    FastGlob.stream = stream;
-    function generateTasks(source, options) {
-        assertPatternsInput(source);
-        const patterns = [].concat(source);
-        const settings = new settings_1.default(options);
-        return taskManager.generate(patterns, settings);
-    }
-    FastGlob.generateTasks = generateTasks;
-    function isDynamicPattern(source, options) {
-        assertPatternsInput(source);
-        const settings = new settings_1.default(options);
-        return utils.pattern.isDynamicPattern(source, settings);
-    }
-    FastGlob.isDynamicPattern = isDynamicPattern;
-    function escapePath(source) {
-        assertPatternsInput(source);
-        return utils.path.escape(source);
-    }
-    FastGlob.escapePath = escapePath;
-})(FastGlob || (FastGlob = {}));
-function getWorks(source, _Provider, options) {
-    const patterns = [].concat(source);
-    const settings = new settings_1.default(options);
-    const tasks = taskManager.generate(patterns, settings);
-    const provider = new _Provider(settings);
-    return tasks.map(provider.read, provider);
-}
-function assertPatternsInput(input) {
-    const source = [].concat(input);
-    const isValidSource = source.every((item) => utils.string.isString(item) && !utils.string.isEmpty(item));
-    if (!isValidSource) {
-        throw new TypeError('Patterns must be a string (non empty) or an array of strings');
-    }
-}
-module.exports = FastGlob;
-
-
-/***/ }),
-
-/***/ 82845:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
-
-"use strict";
-
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.convertPatternGroupToTask = exports.convertPatternGroupsToTasks = exports.groupPatternsByBaseDirectory = exports.getNegativePatternsAsPositive = exports.getPositivePatterns = exports.convertPatternsToTasks = exports.generate = void 0;
-const utils = __nccwpck_require__(74219);
-function generate(patterns, settings) {
-    const positivePatterns = getPositivePatterns(patterns);
-    const negativePatterns = getNegativePatternsAsPositive(patterns, settings.ignore);
-    const staticPatterns = positivePatterns.filter((pattern) => utils.pattern.isStaticPattern(pattern, settings));
-    const dynamicPatterns = positivePatterns.filter((pattern) => utils.pattern.isDynamicPattern(pattern, settings));
-    const staticTasks = convertPatternsToTasks(staticPatterns, negativePatterns, /* dynamic */ false);
-    const dynamicTasks = convertPatternsToTasks(dynamicPatterns, negativePatterns, /* dynamic */ true);
-    return staticTasks.concat(dynamicTasks);
-}
-exports.generate = generate;
-/**
- * Returns tasks grouped by basic pattern directories.
- *
- * Patterns that can be found inside (`./`) and outside (`../`) the current directory are handled separately.
- * This is necessary because directory traversal starts at the base directory and goes deeper.
- */
-function convertPatternsToTasks(positive, negative, dynamic) {
-    const tasks = [];
-    const patternsOutsideCurrentDirectory = utils.pattern.getPatternsOutsideCurrentDirectory(positive);
-    const patternsInsideCurrentDirectory = utils.pattern.getPatternsInsideCurrentDirectory(positive);
-    const outsideCurrentDirectoryGroup = groupPatternsByBaseDirectory(patternsOutsideCurrentDirectory);
-    const insideCurrentDirectoryGroup = groupPatternsByBaseDirectory(patternsInsideCurrentDirectory);
-    tasks.push(...convertPatternGroupsToTasks(outsideCurrentDirectoryGroup, negative, dynamic));
-    /*
-     * For the sake of reducing future accesses to the file system, we merge all tasks within the current directory
-     * into a global task, if at least one pattern refers to the root (`.`). In this case, the global task covers the rest.
-     */
-    if ('.' in insideCurrentDirectoryGroup) {
-        tasks.push(convertPatternGroupToTask('.', patternsInsideCurrentDirectory, negative, dynamic));
-    }
-    else {
-        tasks.push(...convertPatternGroupsToTasks(insideCurrentDirectoryGroup, negative, dynamic));
-    }
-    return tasks;
-}
-exports.convertPatternsToTasks = convertPatternsToTasks;
-function getPositivePatterns(patterns) {
-    return utils.pattern.getPositivePatterns(patterns);
-}
-exports.getPositivePatterns = getPositivePatterns;
-function getNegativePatternsAsPositive(patterns, ignore) {
-    const negative = utils.pattern.getNegativePatterns(patterns).concat(ignore);
-    const positive = negative.map(utils.pattern.convertToPositivePattern);
-    return positive;
-}
-exports.getNegativePatternsAsPositive = getNegativePatternsAsPositive;
-function groupPatternsByBaseDirectory(patterns) {
-    const group = {};
-    return patterns.reduce((collection, pattern) => {
-        const base = utils.pattern.getBaseDirectory(pattern);
-        if (base in collection) {
-            collection[base].push(pattern);
-        }
-        else {
-            collection[base] = [pattern];
-        }
-        return collection;
-    }, group);
-}
-exports.groupPatternsByBaseDirectory = groupPatternsByBaseDirectory;
-function convertPatternGroupsToTasks(positive, negative, dynamic) {
-    return Object.keys(positive).map((base) => {
-        return convertPatternGroupToTask(base, positive[base], negative, dynamic);
-    });
-}
-exports.convertPatternGroupsToTasks = convertPatternGroupsToTasks;
-function convertPatternGroupToTask(base, positive, negative, dynamic) {
-    return {
-        dynamic,
-        positive,
-        negative,
-        base,
-        patterns: [].concat(positive, negative.map(utils.pattern.convertToNegativePattern))
-    };
-}
-exports.convertPatternGroupToTask = convertPatternGroupToTask;
-
-
-/***/ }),
-
-/***/ 48123:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
-
-"use strict";
-
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-const stream_1 = __nccwpck_require__(67763);
-const provider_1 = __nccwpck_require__(64746);
-class ProviderAsync extends provider_1.default {
-    constructor() {
-        super(...arguments);
-        this._reader = new stream_1.default(this._settings);
-    }
-    read(task) {
-        const root = this._getRootDirectory(task);
-        const options = this._getReaderOptions(task);
-        const entries = [];
-        return new Promise((resolve, reject) => {
-            const stream = this.api(root, task, options);
-            stream.once('error', reject);
-            stream.on('data', (entry) => entries.push(options.transform(entry)));
-            stream.once('end', () => resolve(entries));
-        });
-    }
-    api(root, task, options) {
-        if (task.dynamic) {
-            return this._reader.dynamic(root, options);
-        }
-        return this._reader.static(task.patterns, options);
-    }
-}
-exports["default"] = ProviderAsync;
-
-
-/***/ }),
-
-/***/ 60429:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
-
-"use strict";
-
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-const utils = __nccwpck_require__(74219);
-const partial_1 = __nccwpck_require__(70221);
-class DeepFilter {
-    constructor(_settings, _micromatchOptions) {
-        this._settings = _settings;
-        this._micromatchOptions = _micromatchOptions;
-    }
-    getFilter(basePath, positive, negative) {
-        const matcher = this._getMatcher(positive);
-        const negativeRe = this._getNegativePatternsRe(negative);
-        return (entry) => this._filter(basePath, entry, matcher, negativeRe);
-    }
-    _getMatcher(patterns) {
-        return new partial_1.default(patterns, this._settings, this._micromatchOptions);
-    }
-    _getNegativePatternsRe(patterns) {
-        const affectDepthOfReadingPatterns = patterns.filter(utils.pattern.isAffectDepthOfReadingPattern);
-        return utils.pattern.convertPatternsToRe(affectDepthOfReadingPatterns, this._micromatchOptions);
-    }
-    _filter(basePath, entry, matcher, negativeRe) {
-        if (this._isSkippedByDeep(basePath, entry.path)) {
-            return false;
-        }
-        if (this._isSkippedSymbolicLink(entry)) {
-            return false;
-        }
-        const filepath = utils.path.removeLeadingDotSegment(entry.path);
-        if (this._isSkippedByPositivePatterns(filepath, matcher)) {
-            return false;
-        }
-        return this._isSkippedByNegativePatterns(filepath, negativeRe);
-    }
-    _isSkippedByDeep(basePath, entryPath) {
-        /**
-         * Avoid unnecessary depth calculations when it doesn't matter.
-         */
-        if (this._settings.deep === Infinity) {
-            return false;
-        }
-        return this._getEntryLevel(basePath, entryPath) >= this._settings.deep;
-    }
-    _getEntryLevel(basePath, entryPath) {
-        const entryPathDepth = entryPath.split('/').length;
-        if (basePath === '') {
-            return entryPathDepth;
-        }
-        const basePathDepth = basePath.split('/').length;
-        return entryPathDepth - basePathDepth;
-    }
-    _isSkippedSymbolicLink(entry) {
-        return !this._settings.followSymbolicLinks && entry.dirent.isSymbolicLink();
-    }
-    _isSkippedByPositivePatterns(entryPath, matcher) {
-        return !this._settings.baseNameMatch && !matcher.match(entryPath);
-    }
-    _isSkippedByNegativePatterns(entryPath, patternsRe) {
-        return !utils.pattern.matchAny(entryPath, patternsRe);
-    }
-}
-exports["default"] = DeepFilter;
-
-
-/***/ }),
-
-/***/ 26658:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
-
-"use strict";
-
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-const utils = __nccwpck_require__(74219);
-class EntryFilter {
-    constructor(_settings, _micromatchOptions) {
-        this._settings = _settings;
-        this._micromatchOptions = _micromatchOptions;
-        this.index = new Map();
-    }
-    getFilter(positive, negative) {
-        const positiveRe = utils.pattern.convertPatternsToRe(positive, this._micromatchOptions);
-        const negativeRe = utils.pattern.convertPatternsToRe(negative, this._micromatchOptions);
-        return (entry) => this._filter(entry, positiveRe, negativeRe);
-    }
-    _filter(entry, positiveRe, negativeRe) {
-        if (this._settings.unique && this._isDuplicateEntry(entry)) {
-            return false;
-        }
-        if (this._onlyFileFilter(entry) || this._onlyDirectoryFilter(entry)) {
-            return false;
-        }
-        if (this._isSkippedByAbsoluteNegativePatterns(entry.path, negativeRe)) {
-            return false;
-        }
-        const filepath = this._settings.baseNameMatch ? entry.name : entry.path;
-        const isMatched = this._isMatchToPatterns(filepath, positiveRe) && !this._isMatchToPatterns(entry.path, negativeRe);
-        if (this._settings.unique && isMatched) {
-            this._createIndexRecord(entry);
-        }
-        return isMatched;
-    }
-    _isDuplicateEntry(entry) {
-        return this.index.has(entry.path);
-    }
-    _createIndexRecord(entry) {
-        this.index.set(entry.path, undefined);
-    }
-    _onlyFileFilter(entry) {
-        return this._settings.onlyFiles && !entry.dirent.isFile();
-    }
-    _onlyDirectoryFilter(entry) {
-        return this._settings.onlyDirectories && !entry.dirent.isDirectory();
-    }
-    _isSkippedByAbsoluteNegativePatterns(entryPath, patternsRe) {
-        if (!this._settings.absolute) {
-            return false;
-        }
-        const fullpath = utils.path.makeAbsolute(this._settings.cwd, entryPath);
-        return utils.pattern.matchAny(fullpath, patternsRe);
-    }
-    _isMatchToPatterns(entryPath, patternsRe) {
-        const filepath = utils.path.removeLeadingDotSegment(entryPath);
-        return utils.pattern.matchAny(filepath, patternsRe);
-    }
-}
-exports["default"] = EntryFilter;
-
-
-/***/ }),
-
-/***/ 52968:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
-
-"use strict";
-
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-const utils = __nccwpck_require__(74219);
-class ErrorFilter {
-    constructor(_settings) {
-        this._settings = _settings;
-    }
-    getFilter() {
-        return (error) => this._isNonFatalError(error);
-    }
-    _isNonFatalError(error) {
-        return utils.errno.isEnoentCodeError(error) || this._settings.suppressErrors;
-    }
-}
-exports["default"] = ErrorFilter;
-
-
-/***/ }),
-
-/***/ 84063:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
-
-"use strict";
-
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-const utils = __nccwpck_require__(74219);
-class Matcher {
-    constructor(_patterns, _settings, _micromatchOptions) {
-        this._patterns = _patterns;
-        this._settings = _settings;
-        this._micromatchOptions = _micromatchOptions;
-        this._storage = [];
-        this._fillStorage();
-    }
-    _fillStorage() {
-        /**
-         * The original pattern may include `{,*,**,a/*}`, which will lead to problems with matching (unresolved level).
-         * So, before expand patterns with brace expansion into separated patterns.
-         */
-        const patterns = utils.pattern.expandPatternsWithBraceExpansion(this._patterns);
-        for (const pattern of patterns) {
-            const segments = this._getPatternSegments(pattern);
-            const sections = this._splitSegmentsIntoSections(segments);
-            this._storage.push({
-                complete: sections.length <= 1,
-                pattern,
-                segments,
-                sections
-            });
-        }
-    }
-    _getPatternSegments(pattern) {
-        const parts = utils.pattern.getPatternParts(pattern, this._micromatchOptions);
-        return parts.map((part) => {
-            const dynamic = utils.pattern.isDynamicPattern(part, this._settings);
-            if (!dynamic) {
-                return {
-                    dynamic: false,
-                    pattern: part
-                };
-            }
-            return {
-                dynamic: true,
-                pattern: part,
-                patternRe: utils.pattern.makeRe(part, this._micromatchOptions)
-            };
-        });
-    }
-    _splitSegmentsIntoSections(segments) {
-        return utils.array.splitWhen(segments, (segment) => segment.dynamic && utils.pattern.hasGlobStar(segment.pattern));
-    }
-}
-exports["default"] = Matcher;
-
-
-/***/ }),
-
-/***/ 70221:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
-
-"use strict";
-
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-const matcher_1 = __nccwpck_require__(84063);
-class PartialMatcher extends matcher_1.default {
-    match(filepath) {
-        const parts = filepath.split('/');
-        const levels = parts.length;
-        const patterns = this._storage.filter((info) => !info.complete || info.segments.length > levels);
-        for (const pattern of patterns) {
-            const section = pattern.sections[0];
-            /**
-             * In this case, the pattern has a globstar and we must read all directories unconditionally,
-             * but only if the level has reached the end of the first group.
-             *
-             * fixtures/{a,b}/**
-             *  ^ true/false  ^ always true
-            */
-            if (!pattern.complete && levels > section.length) {
-                return true;
-            }
-            const match = parts.every((part, index) => {
-                const segment = pattern.segments[index];
-                if (segment.dynamic && segment.patternRe.test(part)) {
-                    return true;
-                }
-                if (!segment.dynamic && segment.pattern === part) {
-                    return true;
-                }
-                return false;
-            });
-            if (match) {
-                return true;
-            }
-        }
-        return false;
-    }
-}
-exports["default"] = PartialMatcher;
-
-
-/***/ }),
-
-/***/ 64746:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
-
-"use strict";
-
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-const path = __nccwpck_require__(71017);
-const deep_1 = __nccwpck_require__(60429);
-const entry_1 = __nccwpck_require__(26658);
-const error_1 = __nccwpck_require__(52968);
-const entry_2 = __nccwpck_require__(58684);
-class Provider {
-    constructor(_settings) {
-        this._settings = _settings;
-        this.errorFilter = new error_1.default(this._settings);
-        this.entryFilter = new entry_1.default(this._settings, this._getMicromatchOptions());
-        this.deepFilter = new deep_1.default(this._settings, this._getMicromatchOptions());
-        this.entryTransformer = new entry_2.default(this._settings);
-    }
-    _getRootDirectory(task) {
-        return path.resolve(this._settings.cwd, task.base);
-    }
-    _getReaderOptions(task) {
-        const basePath = task.base === '.' ? '' : task.base;
-        return {
-            basePath,
-            pathSegmentSeparator: '/',
-            concurrency: this._settings.concurrency,
-            deepFilter: this.deepFilter.getFilter(basePath, task.positive, task.negative),
-            entryFilter: this.entryFilter.getFilter(task.positive, task.negative),
-            errorFilter: this.errorFilter.getFilter(),
-            followSymbolicLinks: this._settings.followSymbolicLinks,
-            fs: this._settings.fs,
-            stats: this._settings.stats,
-            throwErrorOnBrokenSymbolicLink: this._settings.throwErrorOnBrokenSymbolicLink,
-            transform: this.entryTransformer.getTransformer()
-        };
-    }
-    _getMicromatchOptions() {
-        return {
-            dot: this._settings.dot,
-            matchBase: this._settings.baseNameMatch,
-            nobrace: !this._settings.braceExpansion,
-            nocase: !this._settings.caseSensitiveMatch,
-            noext: !this._settings.extglob,
-            noglobstar: !this._settings.globstar,
-            posix: true,
-            strictSlashes: false
-        };
-    }
-}
-exports["default"] = Provider;
-
-
-/***/ }),
-
-/***/ 36672:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
-
-"use strict";
-
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-const stream_1 = __nccwpck_require__(12781);
-const stream_2 = __nccwpck_require__(67763);
-const provider_1 = __nccwpck_require__(64746);
-class ProviderStream extends provider_1.default {
-    constructor() {
-        super(...arguments);
-        this._reader = new stream_2.default(this._settings);
-    }
-    read(task) {
-        const root = this._getRootDirectory(task);
-        const options = this._getReaderOptions(task);
-        const source = this.api(root, task, options);
-        const destination = new stream_1.Readable({ objectMode: true, read: () => { } });
-        source
-            .once('error', (error) => destination.emit('error', error))
-            .on('data', (entry) => destination.emit('data', options.transform(entry)))
-            .once('end', () => destination.emit('end'));
-        destination
-            .once('close', () => source.destroy());
-        return destination;
-    }
-    api(root, task, options) {
-        if (task.dynamic) {
-            return this._reader.dynamic(root, options);
-        }
-        return this._reader.static(task.patterns, options);
-    }
-}
-exports["default"] = ProviderStream;
-
-
-/***/ }),
-
-/***/ 48463:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
-
-"use strict";
-
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-const sync_1 = __nccwpck_require__(58162);
-const provider_1 = __nccwpck_require__(64746);
-class ProviderSync extends provider_1.default {
-    constructor() {
-        super(...arguments);
-        this._reader = new sync_1.default(this._settings);
-    }
-    read(task) {
-        const root = this._getRootDirectory(task);
-        const options = this._getReaderOptions(task);
-        const entries = this.api(root, task, options);
-        return entries.map(options.transform);
-    }
-    api(root, task, options) {
-        if (task.dynamic) {
-            return this._reader.dynamic(root, options);
-        }
-        return this._reader.static(task.patterns, options);
-    }
-}
-exports["default"] = ProviderSync;
-
-
-/***/ }),
-
-/***/ 58684:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
-
-"use strict";
-
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-const utils = __nccwpck_require__(74219);
-class EntryTransformer {
-    constructor(_settings) {
-        this._settings = _settings;
-    }
-    getTransformer() {
-        return (entry) => this._transform(entry);
-    }
-    _transform(entry) {
-        let filepath = entry.path;
-        if (this._settings.absolute) {
-            filepath = utils.path.makeAbsolute(this._settings.cwd, filepath);
-            filepath = utils.path.unixify(filepath);
-        }
-        if (this._settings.markDirectories && entry.dirent.isDirectory()) {
-            filepath += '/';
-        }
-        if (!this._settings.objectMode) {
-            return filepath;
-        }
-        return Object.assign(Object.assign({}, entry), { path: filepath });
-    }
-}
-exports["default"] = EntryTransformer;
-
-
-/***/ }),
-
-/***/ 86255:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
-
-"use strict";
-
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-const path = __nccwpck_require__(71017);
-const fsStat = __nccwpck_require__(25925);
-const utils = __nccwpck_require__(74219);
-class Reader {
-    constructor(_settings) {
-        this._settings = _settings;
-        this._fsStatSettings = new fsStat.Settings({
-            followSymbolicLink: this._settings.followSymbolicLinks,
-            fs: this._settings.fs,
-            throwErrorOnBrokenSymbolicLink: this._settings.followSymbolicLinks
-        });
-    }
-    _getFullEntryPath(filepath) {
-        return path.resolve(this._settings.cwd, filepath);
-    }
-    _makeEntry(stats, pattern) {
-        const entry = {
-            name: pattern,
-            path: pattern,
-            dirent: utils.fs.createDirentFromStats(pattern, stats)
-        };
-        if (this._settings.stats) {
-            entry.stats = stats;
-        }
-        return entry;
-    }
-    _isFatalError(error) {
-        return !utils.errno.isEnoentCodeError(error) && !this._settings.suppressErrors;
-    }
-}
-exports["default"] = Reader;
-
-
-/***/ }),
-
-/***/ 67763:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
-
-"use strict";
-
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-const stream_1 = __nccwpck_require__(12781);
-const fsStat = __nccwpck_require__(25925);
-const fsWalk = __nccwpck_require__(99155);
-const reader_1 = __nccwpck_require__(86255);
-class ReaderStream extends reader_1.default {
-    constructor() {
-        super(...arguments);
-        this._walkStream = fsWalk.walkStream;
-        this._stat = fsStat.stat;
-    }
-    dynamic(root, options) {
-        return this._walkStream(root, options);
-    }
-    static(patterns, options) {
-        const filepaths = patterns.map(this._getFullEntryPath, this);
-        const stream = new stream_1.PassThrough({ objectMode: true });
-        stream._write = (index, _enc, done) => {
-            return this._getEntry(filepaths[index], patterns[index], options)
-                .then((entry) => {
-                if (entry !== null && options.entryFilter(entry)) {
-                    stream.push(entry);
-                }
-                if (index === filepaths.length - 1) {
-                    stream.end();
-                }
-                done();
-            })
-                .catch(done);
-        };
-        for (let i = 0; i < filepaths.length; i++) {
-            stream.write(i);
-        }
-        return stream;
-    }
-    _getEntry(filepath, pattern, options) {
-        return this._getStat(filepath)
-            .then((stats) => this._makeEntry(stats, pattern))
-            .catch((error) => {
-            if (options.errorFilter(error)) {
-                return null;
-            }
-            throw error;
-        });
-    }
-    _getStat(filepath) {
-        return new Promise((resolve, reject) => {
-            this._stat(filepath, this._fsStatSettings, (error, stats) => {
-                return error === null ? resolve(stats) : reject(error);
-            });
-        });
-    }
-}
-exports["default"] = ReaderStream;
-
-
-/***/ }),
-
-/***/ 58162:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
-
-"use strict";
-
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-const fsStat = __nccwpck_require__(25925);
-const fsWalk = __nccwpck_require__(99155);
-const reader_1 = __nccwpck_require__(86255);
-class ReaderSync extends reader_1.default {
-    constructor() {
-        super(...arguments);
-        this._walkSync = fsWalk.walkSync;
-        this._statSync = fsStat.statSync;
-    }
-    dynamic(root, options) {
-        return this._walkSync(root, options);
-    }
-    static(patterns, options) {
-        const entries = [];
-        for (const pattern of patterns) {
-            const filepath = this._getFullEntryPath(pattern);
-            const entry = this._getEntry(filepath, pattern, options);
-            if (entry === null || !options.entryFilter(entry)) {
-                continue;
-            }
-            entries.push(entry);
-        }
-        return entries;
-    }
-    _getEntry(filepath, pattern, options) {
-        try {
-            const stats = this._getStat(filepath);
-            return this._makeEntry(stats, pattern);
-        }
-        catch (error) {
-            if (options.errorFilter(error)) {
-                return null;
-            }
-            throw error;
-        }
-    }
-    _getStat(filepath) {
-        return this._statSync(filepath, this._fsStatSettings);
-    }
-}
-exports["default"] = ReaderSync;
-
-
-/***/ }),
-
-/***/ 67938:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
-
-"use strict";
-
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.DEFAULT_FILE_SYSTEM_ADAPTER = void 0;
-const fs = __nccwpck_require__(57147);
-const os = __nccwpck_require__(22037);
-/**
- * The `os.cpus` method can return zero. We expect the number of cores to be greater than zero.
- * https://github.com/nodejs/node/blob/7faeddf23a98c53896f8b574a6e66589e8fb1eb8/lib/os.js#L106-L107
- */
-const CPU_COUNT = Math.max(os.cpus().length, 1);
-exports.DEFAULT_FILE_SYSTEM_ADAPTER = {
-    lstat: fs.lstat,
-    lstatSync: fs.lstatSync,
-    stat: fs.stat,
-    statSync: fs.statSync,
-    readdir: fs.readdir,
-    readdirSync: fs.readdirSync
-};
-class Settings {
-    constructor(_options = {}) {
-        this._options = _options;
-        this.absolute = this._getValue(this._options.absolute, false);
-        this.baseNameMatch = this._getValue(this._options.baseNameMatch, false);
-        this.braceExpansion = this._getValue(this._options.braceExpansion, true);
-        this.caseSensitiveMatch = this._getValue(this._options.caseSensitiveMatch, true);
-        this.concurrency = this._getValue(this._options.concurrency, CPU_COUNT);
-        this.cwd = this._getValue(this._options.cwd, process.cwd());
-        this.deep = this._getValue(this._options.deep, Infinity);
-        this.dot = this._getValue(this._options.dot, false);
-        this.extglob = this._getValue(this._options.extglob, true);
-        this.followSymbolicLinks = this._getValue(this._options.followSymbolicLinks, true);
-        this.fs = this._getFileSystemMethods(this._options.fs);
-        this.globstar = this._getValue(this._options.globstar, true);
-        this.ignore = this._getValue(this._options.ignore, []);
-        this.markDirectories = this._getValue(this._options.markDirectories, false);
-        this.objectMode = this._getValue(this._options.objectMode, false);
-        this.onlyDirectories = this._getValue(this._options.onlyDirectories, false);
-        this.onlyFiles = this._getValue(this._options.onlyFiles, true);
-        this.stats = this._getValue(this._options.stats, false);
-        this.suppressErrors = this._getValue(this._options.suppressErrors, false);
-        this.throwErrorOnBrokenSymbolicLink = this._getValue(this._options.throwErrorOnBrokenSymbolicLink, false);
-        this.unique = this._getValue(this._options.unique, true);
-        if (this.onlyDirectories) {
-            this.onlyFiles = false;
-        }
-        if (this.stats) {
-            this.objectMode = true;
-        }
-    }
-    _getValue(option, value) {
-        return option === undefined ? value : option;
-    }
-    _getFileSystemMethods(methods = {}) {
-        return Object.assign(Object.assign({}, exports.DEFAULT_FILE_SYSTEM_ADAPTER), methods);
-    }
-}
-exports["default"] = Settings;
-
-
-/***/ }),
-
-/***/ 1966:
-/***/ ((__unused_webpack_module, exports) => {
-
-"use strict";
-
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.splitWhen = exports.flatten = void 0;
-function flatten(items) {
-    return items.reduce((collection, item) => [].concat(collection, item), []);
-}
-exports.flatten = flatten;
-function splitWhen(items, predicate) {
-    const result = [[]];
-    let groupIndex = 0;
-    for (const item of items) {
-        if (predicate(item)) {
-            groupIndex++;
-            result[groupIndex] = [];
-        }
-        else {
-            result[groupIndex].push(item);
-        }
-    }
-    return result;
-}
-exports.splitWhen = splitWhen;
-
-
-/***/ }),
-
-/***/ 30821:
-/***/ ((__unused_webpack_module, exports) => {
-
-"use strict";
-
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.isEnoentCodeError = void 0;
-function isEnoentCodeError(error) {
-    return error.code === 'ENOENT';
-}
-exports.isEnoentCodeError = isEnoentCodeError;
-
-
-/***/ }),
-
-/***/ 70274:
-/***/ ((__unused_webpack_module, exports) => {
-
-"use strict";
-
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.createDirentFromStats = void 0;
-class DirentFromStats {
-    constructor(name, stats) {
-        this.name = name;
-        this.isBlockDevice = stats.isBlockDevice.bind(stats);
-        this.isCharacterDevice = stats.isCharacterDevice.bind(stats);
-        this.isDirectory = stats.isDirectory.bind(stats);
-        this.isFIFO = stats.isFIFO.bind(stats);
-        this.isFile = stats.isFile.bind(stats);
-        this.isSocket = stats.isSocket.bind(stats);
-        this.isSymbolicLink = stats.isSymbolicLink.bind(stats);
-    }
-}
-function createDirentFromStats(name, stats) {
-    return new DirentFromStats(name, stats);
-}
-exports.createDirentFromStats = createDirentFromStats;
-
-
-/***/ }),
-
-/***/ 74219:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
-
-"use strict";
-
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.string = exports.stream = exports.pattern = exports.path = exports.fs = exports.errno = exports.array = void 0;
-const array = __nccwpck_require__(1966);
-exports.array = array;
-const errno = __nccwpck_require__(30821);
-exports.errno = errno;
-const fs = __nccwpck_require__(70274);
-exports.fs = fs;
-const path = __nccwpck_require__(98478);
-exports.path = path;
-const pattern = __nccwpck_require__(48517);
-exports.pattern = pattern;
-const stream = __nccwpck_require__(2914);
-exports.stream = stream;
-const string = __nccwpck_require__(25039);
-exports.string = string;
-
-
-/***/ }),
-
-/***/ 98478:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
-
-"use strict";
-
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.removeLeadingDotSegment = exports.escape = exports.makeAbsolute = exports.unixify = void 0;
-const path = __nccwpck_require__(71017);
-const LEADING_DOT_SEGMENT_CHARACTERS_COUNT = 2; // ./ or .\\
-const UNESCAPED_GLOB_SYMBOLS_RE = /(\\?)([()*?[\]{|}]|^!|[!+@](?=\())/g;
-/**
- * Designed to work only with simple paths: `dir\\file`.
- */
-function unixify(filepath) {
-    return filepath.replace(/\\/g, '/');
-}
-exports.unixify = unixify;
-function makeAbsolute(cwd, filepath) {
-    return path.resolve(cwd, filepath);
-}
-exports.makeAbsolute = makeAbsolute;
-function escape(pattern) {
-    return pattern.replace(UNESCAPED_GLOB_SYMBOLS_RE, '\\$2');
-}
-exports.escape = escape;
-function removeLeadingDotSegment(entry) {
-    // We do not use `startsWith` because this is 10x slower than current implementation for some cases.
-    // eslint-disable-next-line @typescript-eslint/prefer-string-starts-ends-with
-    if (entry.charAt(0) === '.') {
-        const secondCharactery = entry.charAt(1);
-        if (secondCharactery === '/' || secondCharactery === '\\') {
-            return entry.slice(LEADING_DOT_SEGMENT_CHARACTERS_COUNT);
-        }
-    }
-    return entry;
-}
-exports.removeLeadingDotSegment = removeLeadingDotSegment;
-
-
-/***/ }),
-
-/***/ 48517:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
-
-"use strict";
-
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.matchAny = exports.convertPatternsToRe = exports.makeRe = exports.getPatternParts = exports.expandBraceExpansion = exports.expandPatternsWithBraceExpansion = exports.isAffectDepthOfReadingPattern = exports.endsWithSlashGlobStar = exports.hasGlobStar = exports.getBaseDirectory = exports.isPatternRelatedToParentDirectory = exports.getPatternsOutsideCurrentDirectory = exports.getPatternsInsideCurrentDirectory = exports.getPositivePatterns = exports.getNegativePatterns = exports.isPositivePattern = exports.isNegativePattern = exports.convertToNegativePattern = exports.convertToPositivePattern = exports.isDynamicPattern = exports.isStaticPattern = void 0;
-const path = __nccwpck_require__(71017);
-const globParent = __nccwpck_require__(86420);
-const micromatch = __nccwpck_require__(99573);
-const GLOBSTAR = '**';
-const ESCAPE_SYMBOL = '\\';
-const COMMON_GLOB_SYMBOLS_RE = /[*?]|^!/;
-const REGEX_CHARACTER_CLASS_SYMBOLS_RE = /\[.*]/;
-const REGEX_GROUP_SYMBOLS_RE = /(?:^|[^!*+?@])\(.*\|.*\)/;
-const GLOB_EXTENSION_SYMBOLS_RE = /[!*+?@]\(.*\)/;
-const BRACE_EXPANSIONS_SYMBOLS_RE = /{.*(?:,|\.\.).*}/;
-function isStaticPattern(pattern, options = {}) {
-    return !isDynamicPattern(pattern, options);
-}
-exports.isStaticPattern = isStaticPattern;
-function isDynamicPattern(pattern, options = {}) {
-    /**
-     * A special case with an empty string is necessary for matching patterns that start with a forward slash.
-     * An empty string cannot be a dynamic pattern.
-     * For example, the pattern `/lib/*` will be spread into parts: '', 'lib', '*'.
-     */
-    if (pattern === '') {
-        return false;
-    }
-    /**
-     * When the `caseSensitiveMatch` option is disabled, all patterns must be marked as dynamic, because we cannot check
-     * filepath directly (without read directory).
-     */
-    if (options.caseSensitiveMatch === false || pattern.includes(ESCAPE_SYMBOL)) {
-        return true;
-    }
-    if (COMMON_GLOB_SYMBOLS_RE.test(pattern) || REGEX_CHARACTER_CLASS_SYMBOLS_RE.test(pattern) || REGEX_GROUP_SYMBOLS_RE.test(pattern)) {
-        return true;
-    }
-    if (options.extglob !== false && GLOB_EXTENSION_SYMBOLS_RE.test(pattern)) {
-        return true;
-    }
-    if (options.braceExpansion !== false && BRACE_EXPANSIONS_SYMBOLS_RE.test(pattern)) {
-        return true;
-    }
-    return false;
-}
-exports.isDynamicPattern = isDynamicPattern;
-function convertToPositivePattern(pattern) {
-    return isNegativePattern(pattern) ? pattern.slice(1) : pattern;
-}
-exports.convertToPositivePattern = convertToPositivePattern;
-function convertToNegativePattern(pattern) {
-    return '!' + pattern;
-}
-exports.convertToNegativePattern = convertToNegativePattern;
-function isNegativePattern(pattern) {
-    return pattern.startsWith('!') && pattern[1] !== '(';
-}
-exports.isNegativePattern = isNegativePattern;
-function isPositivePattern(pattern) {
-    return !isNegativePattern(pattern);
-}
-exports.isPositivePattern = isPositivePattern;
-function getNegativePatterns(patterns) {
-    return patterns.filter(isNegativePattern);
-}
-exports.getNegativePatterns = getNegativePatterns;
-function getPositivePatterns(patterns) {
-    return patterns.filter(isPositivePattern);
-}
-exports.getPositivePatterns = getPositivePatterns;
-/**
- * Returns patterns that can be applied inside the current directory.
- *
- * @example
- * // ['./*', '*', 'a/*']
- * getPatternsInsideCurrentDirectory(['./*', '*', 'a/*', '../*', './../*'])
- */
-function getPatternsInsideCurrentDirectory(patterns) {
-    return patterns.filter((pattern) => !isPatternRelatedToParentDirectory(pattern));
-}
-exports.getPatternsInsideCurrentDirectory = getPatternsInsideCurrentDirectory;
-/**
- * Returns patterns to be expanded relative to (outside) the current directory.
- *
- * @example
- * // ['../*', './../*']
- * getPatternsInsideCurrentDirectory(['./*', '*', 'a/*', '../*', './../*'])
- */
-function getPatternsOutsideCurrentDirectory(patterns) {
-    return patterns.filter(isPatternRelatedToParentDirectory);
-}
-exports.getPatternsOutsideCurrentDirectory = getPatternsOutsideCurrentDirectory;
-function isPatternRelatedToParentDirectory(pattern) {
-    return pattern.startsWith('..') || pattern.startsWith('./..');
-}
-exports.isPatternRelatedToParentDirectory = isPatternRelatedToParentDirectory;
-function getBaseDirectory(pattern) {
-    return globParent(pattern, { flipBackslashes: false });
-}
-exports.getBaseDirectory = getBaseDirectory;
-function hasGlobStar(pattern) {
-    return pattern.includes(GLOBSTAR);
-}
-exports.hasGlobStar = hasGlobStar;
-function endsWithSlashGlobStar(pattern) {
-    return pattern.endsWith('/' + GLOBSTAR);
-}
-exports.endsWithSlashGlobStar = endsWithSlashGlobStar;
-function isAffectDepthOfReadingPattern(pattern) {
-    const basename = path.basename(pattern);
-    return endsWithSlashGlobStar(pattern) || isStaticPattern(basename);
-}
-exports.isAffectDepthOfReadingPattern = isAffectDepthOfReadingPattern;
-function expandPatternsWithBraceExpansion(patterns) {
-    return patterns.reduce((collection, pattern) => {
-        return collection.concat(expandBraceExpansion(pattern));
-    }, []);
-}
-exports.expandPatternsWithBraceExpansion = expandPatternsWithBraceExpansion;
-function expandBraceExpansion(pattern) {
-    return micromatch.braces(pattern, {
-        expand: true,
-        nodupes: true
-    });
-}
-exports.expandBraceExpansion = expandBraceExpansion;
-function getPatternParts(pattern, options) {
-    let { parts } = micromatch.scan(pattern, Object.assign(Object.assign({}, options), { parts: true }));
-    /**
-     * The scan method returns an empty array in some cases.
-     * See micromatch/picomatch#58 for more details.
-     */
-    if (parts.length === 0) {
-        parts = [pattern];
-    }
-    /**
-     * The scan method does not return an empty part for the pattern with a forward slash.
-     * This is another part of micromatch/picomatch#58.
-     */
-    if (parts[0].startsWith('/')) {
-        parts[0] = parts[0].slice(1);
-        parts.unshift('');
-    }
-    return parts;
-}
-exports.getPatternParts = getPatternParts;
-function makeRe(pattern, options) {
-    return micromatch.makeRe(pattern, options);
-}
-exports.makeRe = makeRe;
-function convertPatternsToRe(patterns, options) {
-    return patterns.map((pattern) => makeRe(pattern, options));
-}
-exports.convertPatternsToRe = convertPatternsToRe;
-function matchAny(entry, patternsRe) {
-    return patternsRe.some((patternRe) => patternRe.test(entry));
-}
-exports.matchAny = matchAny;
-
-
-/***/ }),
-
-/***/ 2914:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
-
-"use strict";
-
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.merge = void 0;
-const merge2 = __nccwpck_require__(30268);
-function merge(streams) {
-    const mergedStream = merge2(streams);
-    streams.forEach((stream) => {
-        stream.once('error', (error) => mergedStream.emit('error', error));
-    });
-    mergedStream.once('close', () => propagateCloseEventToSources(streams));
-    mergedStream.once('end', () => propagateCloseEventToSources(streams));
-    return mergedStream;
-}
-exports.merge = merge;
-function propagateCloseEventToSources(streams) {
-    streams.forEach((stream) => stream.emit('close'));
-}
-
-
-/***/ }),
-
-/***/ 25039:
-/***/ ((__unused_webpack_module, exports) => {
-
-"use strict";
-
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.isEmpty = exports.isString = void 0;
-function isString(input) {
-    return typeof input === 'string';
-}
-exports.isString = isString;
-function isEmpty(input) {
-    return input === '';
-}
-exports.isEmpty = isEmpty;
-
-
-/***/ }),
-
-/***/ 26920:
+/***/ 38281:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
 
 
-const fs = __nccwpck_require__(88285)
+const fs = __nccwpck_require__(59866)
 const path = __nccwpck_require__(71017)
-const mkdirsSync = (__nccwpck_require__(68761).mkdirsSync)
-const utimesMillisSync = (__nccwpck_require__(51144).utimesMillisSync)
-const stat = __nccwpck_require__(27931)
+const mkdirsSync = (__nccwpck_require__(52897).mkdirsSync)
+const utimesMillisSync = (__nccwpck_require__(67670).utimesMillisSync)
+const stat = __nccwpck_require__(15466)
 
 function copySync (src, dest, opts) {
   if (typeof opts === 'function') {
@@ -61438,18 +56602,18 @@ module.exports = copySync
 
 /***/ }),
 
-/***/ 40671:
+/***/ 61745:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
 
 
-const fs = __nccwpck_require__(88285)
+const fs = __nccwpck_require__(59866)
 const path = __nccwpck_require__(71017)
-const mkdirs = (__nccwpck_require__(68761).mkdirs)
-const pathExists = (__nccwpck_require__(29414).pathExists)
-const utimesMillis = (__nccwpck_require__(51144).utimesMillis)
-const stat = __nccwpck_require__(27931)
+const mkdirs = (__nccwpck_require__(52897).mkdirs)
+const pathExists = (__nccwpck_require__(84485).pathExists)
+const utimesMillis = (__nccwpck_require__(67670).utimesMillis)
+const stat = __nccwpck_require__(15466)
 
 function copy (src, dest, opts, cb) {
   if (typeof opts === 'function' && !cb) {
@@ -61684,32 +56848,32 @@ module.exports = copy
 
 /***/ }),
 
-/***/ 94109:
+/***/ 20133:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
 
 
-const u = (__nccwpck_require__(82787).fromCallback)
+const u = (__nccwpck_require__(63931).fromCallback)
 module.exports = {
-  copy: u(__nccwpck_require__(40671)),
-  copySync: __nccwpck_require__(26920)
+  copy: u(__nccwpck_require__(61745)),
+  copySync: __nccwpck_require__(38281)
 }
 
 
 /***/ }),
 
-/***/ 6331:
+/***/ 81168:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
 
 
-const u = (__nccwpck_require__(82787).fromPromise)
-const fs = __nccwpck_require__(5944)
+const u = (__nccwpck_require__(63931).fromPromise)
+const fs = __nccwpck_require__(98397)
 const path = __nccwpck_require__(71017)
-const mkdir = __nccwpck_require__(68761)
-const remove = __nccwpck_require__(59954)
+const mkdir = __nccwpck_require__(52897)
+const remove = __nccwpck_require__(12039)
 
 const emptyDir = u(async function emptyDir (dir) {
   let items
@@ -61746,16 +56910,16 @@ module.exports = {
 
 /***/ }),
 
-/***/ 37453:
+/***/ 9353:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
 
 
-const u = (__nccwpck_require__(82787).fromCallback)
+const u = (__nccwpck_require__(63931).fromCallback)
 const path = __nccwpck_require__(71017)
-const fs = __nccwpck_require__(88285)
-const mkdir = __nccwpck_require__(68761)
+const fs = __nccwpck_require__(59866)
+const mkdir = __nccwpck_require__(52897)
 
 function createFile (file, callback) {
   function makeFile () {
@@ -61823,15 +56987,15 @@ module.exports = {
 
 /***/ }),
 
-/***/ 13406:
+/***/ 53707:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
 
 
-const { createFile, createFileSync } = __nccwpck_require__(37453)
-const { createLink, createLinkSync } = __nccwpck_require__(67603)
-const { createSymlink, createSymlinkSync } = __nccwpck_require__(85385)
+const { createFile, createFileSync } = __nccwpck_require__(9353)
+const { createLink, createLinkSync } = __nccwpck_require__(75318)
+const { createSymlink, createSymlinkSync } = __nccwpck_require__(8384)
 
 module.exports = {
   // file
@@ -61854,18 +57018,18 @@ module.exports = {
 
 /***/ }),
 
-/***/ 67603:
+/***/ 75318:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
 
 
-const u = (__nccwpck_require__(82787).fromCallback)
+const u = (__nccwpck_require__(63931).fromCallback)
 const path = __nccwpck_require__(71017)
-const fs = __nccwpck_require__(88285)
-const mkdir = __nccwpck_require__(68761)
-const pathExists = (__nccwpck_require__(29414).pathExists)
-const { areIdentical } = __nccwpck_require__(27931)
+const fs = __nccwpck_require__(59866)
+const mkdir = __nccwpck_require__(52897)
+const pathExists = (__nccwpck_require__(84485).pathExists)
+const { areIdentical } = __nccwpck_require__(15466)
 
 function createLink (srcpath, dstpath, callback) {
   function makeLink (srcpath, dstpath) {
@@ -61926,15 +57090,15 @@ module.exports = {
 
 /***/ }),
 
-/***/ 8537:
+/***/ 88272:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
 
 
 const path = __nccwpck_require__(71017)
-const fs = __nccwpck_require__(88285)
-const pathExists = (__nccwpck_require__(29414).pathExists)
+const fs = __nccwpck_require__(59866)
+const pathExists = (__nccwpck_require__(84485).pathExists)
 
 /**
  * Function that returns two types of paths, one relative to symlink, and one
@@ -62033,13 +57197,13 @@ module.exports = {
 
 /***/ }),
 
-/***/ 38909:
+/***/ 12310:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
 
 
-const fs = __nccwpck_require__(88285)
+const fs = __nccwpck_require__(59866)
 
 function symlinkType (srcpath, type, callback) {
   callback = (typeof type === 'function') ? type : callback
@@ -62072,30 +57236,30 @@ module.exports = {
 
 /***/ }),
 
-/***/ 85385:
+/***/ 8384:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
 
 
-const u = (__nccwpck_require__(82787).fromCallback)
+const u = (__nccwpck_require__(63931).fromCallback)
 const path = __nccwpck_require__(71017)
-const fs = __nccwpck_require__(5944)
-const _mkdirs = __nccwpck_require__(68761)
+const fs = __nccwpck_require__(98397)
+const _mkdirs = __nccwpck_require__(52897)
 const mkdirs = _mkdirs.mkdirs
 const mkdirsSync = _mkdirs.mkdirsSync
 
-const _symlinkPaths = __nccwpck_require__(8537)
+const _symlinkPaths = __nccwpck_require__(88272)
 const symlinkPaths = _symlinkPaths.symlinkPaths
 const symlinkPathsSync = _symlinkPaths.symlinkPathsSync
 
-const _symlinkType = __nccwpck_require__(38909)
+const _symlinkType = __nccwpck_require__(12310)
 const symlinkType = _symlinkType.symlinkType
 const symlinkTypeSync = _symlinkType.symlinkTypeSync
 
-const pathExists = (__nccwpck_require__(29414).pathExists)
+const pathExists = (__nccwpck_require__(84485).pathExists)
 
-const { areIdentical } = __nccwpck_require__(27931)
+const { areIdentical } = __nccwpck_require__(15466)
 
 function createSymlink (srcpath, dstpath, type, callback) {
   callback = (typeof type === 'function') ? type : callback
@@ -62162,15 +57326,15 @@ module.exports = {
 
 /***/ }),
 
-/***/ 5944:
+/***/ 98397:
 /***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
 "use strict";
 
 // This is adapted from https://github.com/normalize/mz
 // Copyright (c) 2014-2016 Jonathan Ong me@jongleberry.com and Contributors
-const u = (__nccwpck_require__(82787).fromCallback)
-const fs = __nccwpck_require__(88285)
+const u = (__nccwpck_require__(63931).fromCallback)
+const fs = __nccwpck_require__(59866)
 
 const api = [
   'access',
@@ -62310,7 +57474,7 @@ if (typeof fs.realpath.native === 'function') {
 
 /***/ }),
 
-/***/ 59511:
+/***/ 27475:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
@@ -62318,33 +57482,33 @@ if (typeof fs.realpath.native === 'function') {
 
 module.exports = {
   // Export promiseified graceful-fs:
-  ...__nccwpck_require__(5944),
+  ...__nccwpck_require__(98397),
   // Export extra methods:
-  ...__nccwpck_require__(94109),
-  ...__nccwpck_require__(6331),
-  ...__nccwpck_require__(13406),
-  ...__nccwpck_require__(87834),
-  ...__nccwpck_require__(68761),
-  ...__nccwpck_require__(66412),
-  ...__nccwpck_require__(16298),
-  ...__nccwpck_require__(29414),
-  ...__nccwpck_require__(59954)
+  ...__nccwpck_require__(20133),
+  ...__nccwpck_require__(81168),
+  ...__nccwpck_require__(53707),
+  ...__nccwpck_require__(32877),
+  ...__nccwpck_require__(52897),
+  ...__nccwpck_require__(94696),
+  ...__nccwpck_require__(73354),
+  ...__nccwpck_require__(84485),
+  ...__nccwpck_require__(12039)
 }
 
 
 /***/ }),
 
-/***/ 87834:
+/***/ 32877:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
 
 
-const u = (__nccwpck_require__(82787).fromPromise)
-const jsonFile = __nccwpck_require__(38911)
+const u = (__nccwpck_require__(63931).fromPromise)
+const jsonFile = __nccwpck_require__(14314)
 
-jsonFile.outputJson = u(__nccwpck_require__(94530))
-jsonFile.outputJsonSync = __nccwpck_require__(41266)
+jsonFile.outputJson = u(__nccwpck_require__(19946))
+jsonFile.outputJsonSync = __nccwpck_require__(35938)
 // aliases
 jsonFile.outputJSON = jsonFile.outputJson
 jsonFile.outputJSONSync = jsonFile.outputJsonSync
@@ -62358,13 +57522,13 @@ module.exports = jsonFile
 
 /***/ }),
 
-/***/ 38911:
+/***/ 14314:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
 
 
-const jsonFile = __nccwpck_require__(77681)
+const jsonFile = __nccwpck_require__(3653)
 
 module.exports = {
   // jsonfile exports
@@ -62377,14 +57541,14 @@ module.exports = {
 
 /***/ }),
 
-/***/ 41266:
+/***/ 35938:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
 
 
-const { stringify } = __nccwpck_require__(47667)
-const { outputFileSync } = __nccwpck_require__(16298)
+const { stringify } = __nccwpck_require__(13379)
+const { outputFileSync } = __nccwpck_require__(73354)
 
 function outputJsonSync (file, data, options) {
   const str = stringify(data, options)
@@ -62397,14 +57561,14 @@ module.exports = outputJsonSync
 
 /***/ }),
 
-/***/ 94530:
+/***/ 19946:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
 
 
-const { stringify } = __nccwpck_require__(47667)
-const { outputFile } = __nccwpck_require__(16298)
+const { stringify } = __nccwpck_require__(13379)
+const { outputFile } = __nccwpck_require__(73354)
 
 async function outputJson (file, data, options = {}) {
   const str = stringify(data, options)
@@ -62417,13 +57581,13 @@ module.exports = outputJson
 
 /***/ }),
 
-/***/ 68761:
+/***/ 52897:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
 
-const u = (__nccwpck_require__(82787).fromPromise)
-const { makeDir: _makeDir, makeDirSync } = __nccwpck_require__(48701)
+const u = (__nccwpck_require__(63931).fromPromise)
+const { makeDir: _makeDir, makeDirSync } = __nccwpck_require__(58307)
 const makeDir = u(_makeDir)
 
 module.exports = {
@@ -62439,13 +57603,13 @@ module.exports = {
 
 /***/ }),
 
-/***/ 48701:
+/***/ 58307:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
 
-const fs = __nccwpck_require__(5944)
-const { checkPath } = __nccwpck_require__(34522)
+const fs = __nccwpck_require__(98397)
+const { checkPath } = __nccwpck_require__(78834)
 
 const getMode = options => {
   const defaults = { mode: 0o777 }
@@ -62474,7 +57638,7 @@ module.exports.makeDirSync = (dir, options) => {
 
 /***/ }),
 
-/***/ 34522:
+/***/ 78834:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
@@ -62503,33 +57667,33 @@ module.exports.checkPath = function checkPath (pth) {
 
 /***/ }),
 
-/***/ 66412:
+/***/ 94696:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
 
 
-const u = (__nccwpck_require__(82787).fromCallback)
+const u = (__nccwpck_require__(63931).fromCallback)
 module.exports = {
-  move: u(__nccwpck_require__(27230)),
-  moveSync: __nccwpck_require__(33080)
+  move: u(__nccwpck_require__(16984)),
+  moveSync: __nccwpck_require__(29562)
 }
 
 
 /***/ }),
 
-/***/ 33080:
+/***/ 29562:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
 
 
-const fs = __nccwpck_require__(88285)
+const fs = __nccwpck_require__(59866)
 const path = __nccwpck_require__(71017)
-const copySync = (__nccwpck_require__(94109).copySync)
-const removeSync = (__nccwpck_require__(59954).removeSync)
-const mkdirpSync = (__nccwpck_require__(68761).mkdirpSync)
-const stat = __nccwpck_require__(27931)
+const copySync = (__nccwpck_require__(20133).copySync)
+const removeSync = (__nccwpck_require__(12039).removeSync)
+const mkdirpSync = (__nccwpck_require__(52897).mkdirpSync)
+const stat = __nccwpck_require__(15466)
 
 function moveSync (src, dest, opts) {
   opts = opts || {}
@@ -62569,7 +57733,8 @@ function rename (src, dest, overwrite) {
 function moveAcrossDevice (src, dest, overwrite) {
   const opts = {
     overwrite,
-    errorOnExist: true
+    errorOnExist: true,
+    preserveTimestamps: true
   }
   copySync(src, dest, opts)
   return removeSync(src)
@@ -62580,19 +57745,19 @@ module.exports = moveSync
 
 /***/ }),
 
-/***/ 27230:
+/***/ 16984:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
 
 
-const fs = __nccwpck_require__(88285)
+const fs = __nccwpck_require__(59866)
 const path = __nccwpck_require__(71017)
-const copy = (__nccwpck_require__(94109).copy)
-const remove = (__nccwpck_require__(59954).remove)
-const mkdirp = (__nccwpck_require__(68761).mkdirp)
-const pathExists = (__nccwpck_require__(29414).pathExists)
-const stat = __nccwpck_require__(27931)
+const copy = (__nccwpck_require__(20133).copy)
+const remove = (__nccwpck_require__(12039).remove)
+const mkdirp = (__nccwpck_require__(52897).mkdirp)
+const pathExists = (__nccwpck_require__(84485).pathExists)
+const stat = __nccwpck_require__(15466)
 
 function move (src, dest, opts, cb) {
   if (typeof opts === 'function') {
@@ -62650,7 +57815,8 @@ function rename (src, dest, overwrite, cb) {
 function moveAcrossDevice (src, dest, overwrite, cb) {
   const opts = {
     overwrite,
-    errorOnExist: true
+    errorOnExist: true,
+    preserveTimestamps: true
   }
   copy(src, dest, opts, err => {
     if (err) return cb(err)
@@ -62663,17 +57829,17 @@ module.exports = move
 
 /***/ }),
 
-/***/ 16298:
+/***/ 73354:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
 
 
-const u = (__nccwpck_require__(82787).fromCallback)
-const fs = __nccwpck_require__(88285)
+const u = (__nccwpck_require__(63931).fromCallback)
+const fs = __nccwpck_require__(59866)
 const path = __nccwpck_require__(71017)
-const mkdir = __nccwpck_require__(68761)
-const pathExists = (__nccwpck_require__(29414).pathExists)
+const mkdir = __nccwpck_require__(52897)
+const pathExists = (__nccwpck_require__(84485).pathExists)
 
 function outputFile (file, data, encoding, callback) {
   if (typeof encoding === 'function') {
@@ -62711,13 +57877,13 @@ module.exports = {
 
 /***/ }),
 
-/***/ 29414:
+/***/ 84485:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
 
-const u = (__nccwpck_require__(82787).fromPromise)
-const fs = __nccwpck_require__(5944)
+const u = (__nccwpck_require__(63931).fromPromise)
+const fs = __nccwpck_require__(98397)
 
 function pathExists (path) {
   return fs.access(path).then(() => true).catch(() => false)
@@ -62731,14 +57897,14 @@ module.exports = {
 
 /***/ }),
 
-/***/ 59954:
+/***/ 12039:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
 
 
-const fs = __nccwpck_require__(88285)
-const u = (__nccwpck_require__(82787).fromCallback)
+const fs = __nccwpck_require__(59866)
+const u = (__nccwpck_require__(63931).fromCallback)
 
 function remove (path, callback) {
   fs.rm(path, { recursive: true, force: true }, callback)
@@ -62756,13 +57922,13 @@ module.exports = {
 
 /***/ }),
 
-/***/ 27931:
+/***/ 15466:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
 
 
-const fs = __nccwpck_require__(5944)
+const fs = __nccwpck_require__(98397)
 const path = __nccwpck_require__(71017)
 const util = __nccwpck_require__(73837)
 
@@ -62918,13 +58084,13 @@ module.exports = {
 
 /***/ }),
 
-/***/ 51144:
+/***/ 67670:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
 
 
-const fs = __nccwpck_require__(88285)
+const fs = __nccwpck_require__(59866)
 
 function utimesMillis (path, atime, mtime, callback) {
   // if (!HAS_MILLIS_RES) return fs.utimes(path, atime, mtime, callback)
@@ -62952,39935 +58118,27363 @@ module.exports = {
 
 /***/ }),
 
-/***/ 72755:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+/***/ 57265:
+/***/ ((module) => {
 
-module.exports = minimatch
-minimatch.Minimatch = Minimatch
+/******************************************************************************
+Copyright (c) Microsoft Corporation.
 
-const path = (() => { try { return __nccwpck_require__(71017) } catch (e) {}})() || {
-  sep: '/'
-}
-minimatch.sep = path.sep
+Permission to use, copy, modify, and/or distribute this software for any
+purpose with or without fee is hereby granted.
 
-const GLOBSTAR = minimatch.GLOBSTAR = Minimatch.GLOBSTAR = {}
-const expand = __nccwpck_require__(88149)
+THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH
+REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY
+AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,
+INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM
+LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR
+OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
+PERFORMANCE OF THIS SOFTWARE.
+***************************************************************************** */
+/* global global, define, System, Reflect, Promise */
+var __extends;
+var __assign;
+var __rest;
+var __decorate;
+var __param;
+var __esDecorate;
+var __runInitializers;
+var __propKey;
+var __setFunctionName;
+var __metadata;
+var __awaiter;
+var __generator;
+var __exportStar;
+var __values;
+var __read;
+var __spread;
+var __spreadArrays;
+var __spreadArray;
+var __await;
+var __asyncGenerator;
+var __asyncDelegator;
+var __asyncValues;
+var __makeTemplateObject;
+var __importStar;
+var __importDefault;
+var __classPrivateFieldGet;
+var __classPrivateFieldSet;
+var __classPrivateFieldIn;
+var __createBinding;
+(function (factory) {
+    var root = typeof global === "object" ? global : typeof self === "object" ? self : typeof this === "object" ? this : {};
+    if (typeof define === "function" && define.amd) {
+        define("tslib", ["exports"], function (exports) { factory(createExporter(root, createExporter(exports))); });
+    }
+    else if ( true && typeof module.exports === "object") {
+        factory(createExporter(root, createExporter(module.exports)));
+    }
+    else {
+        factory(createExporter(root));
+    }
+    function createExporter(exports, previous) {
+        if (exports !== root) {
+            if (typeof Object.create === "function") {
+                Object.defineProperty(exports, "__esModule", { value: true });
+            }
+            else {
+                exports.__esModule = true;
+            }
+        }
+        return function (id, v) { return exports[id] = previous ? previous(id, v) : v; };
+    }
+})
+(function (exporter) {
+    var extendStatics = Object.setPrototypeOf ||
+        ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
+        function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };
 
-const plTypes = {
-  '!': { open: '(?:(?!(?:', close: '))[^/]*?)'},
-  '?': { open: '(?:', close: ')?' },
-  '+': { open: '(?:', close: ')+' },
-  '*': { open: '(?:', close: ')*' },
-  '@': { open: '(?:', close: ')' }
-}
+    __extends = function (d, b) {
+        if (typeof b !== "function" && b !== null)
+            throw new TypeError("Class extends value " + String(b) + " is not a constructor or null");
+        extendStatics(d, b);
+        function __() { this.constructor = d; }
+        d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
+    };
 
-// any single thing other than /
-// don't need to escape / when using new RegExp()
-const qmark = '[^/]'
+    __assign = Object.assign || function (t) {
+        for (var s, i = 1, n = arguments.length; i < n; i++) {
+            s = arguments[i];
+            for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];
+        }
+        return t;
+    };
 
-// * => any number of characters
-const star = qmark + '*?'
+    __rest = function (s, e) {
+        var t = {};
+        for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
+            t[p] = s[p];
+        if (s != null && typeof Object.getOwnPropertySymbols === "function")
+            for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
+                if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
+                    t[p[i]] = s[p[i]];
+            }
+        return t;
+    };
 
-// ** when dots are allowed.  Anything goes, except .. and .
-// not (^ or / followed by one or two dots followed by $ or /),
-// followed by anything, any number of times.
-const twoStarDot = '(?:(?!(?:\\\/|^)(?:\\.{1,2})($|\\\/)).)*?'
+    __decorate = function (decorators, target, key, desc) {
+        var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
+        if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
+        else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
+        return c > 3 && r && Object.defineProperty(target, key, r), r;
+    };
 
-// not a ^ or / followed by a dot,
-// followed by anything, any number of times.
-const twoStarNoDot = '(?:(?!(?:\\\/|^)\\.).)*?'
+    __param = function (paramIndex, decorator) {
+        return function (target, key) { decorator(target, key, paramIndex); }
+    };
 
-// characters that need to be escaped in RegExp.
-const reSpecials = charSet('().*{}+?[]^$\\!')
+    __esDecorate = function (ctor, descriptorIn, decorators, contextIn, initializers, extraInitializers) {
+        function accept(f) { if (f !== void 0 && typeof f !== "function") throw new TypeError("Function expected"); return f; }
+        var kind = contextIn.kind, key = kind === "getter" ? "get" : kind === "setter" ? "set" : "value";
+        var target = !descriptorIn && ctor ? contextIn["static"] ? ctor : ctor.prototype : null;
+        var descriptor = descriptorIn || (target ? Object.getOwnPropertyDescriptor(target, contextIn.name) : {});
+        var _, done = false;
+        for (var i = decorators.length - 1; i >= 0; i--) {
+            var context = {};
+            for (var p in contextIn) context[p] = p === "access" ? {} : contextIn[p];
+            for (var p in contextIn.access) context.access[p] = contextIn.access[p];
+            context.addInitializer = function (f) { if (done) throw new TypeError("Cannot add initializers after decoration has completed"); extraInitializers.push(accept(f || null)); };
+            var result = (0, decorators[i])(kind === "accessor" ? { get: descriptor.get, set: descriptor.set } : descriptor[key], context);
+            if (kind === "accessor") {
+                if (result === void 0) continue;
+                if (result === null || typeof result !== "object") throw new TypeError("Object expected");
+                if (_ = accept(result.get)) descriptor.get = _;
+                if (_ = accept(result.set)) descriptor.set = _;
+                if (_ = accept(result.init)) initializers.unshift(_);
+            }
+            else if (_ = accept(result)) {
+                if (kind === "field") initializers.unshift(_);
+                else descriptor[key] = _;
+            }
+        }
+        if (target) Object.defineProperty(target, contextIn.name, descriptor);
+        done = true;
+    };
 
-// "abc" -> { a:true, b:true, c:true }
-function charSet (s) {
-  return s.split('').reduce(function (set, c) {
-    set[c] = true
-    return set
-  }, {})
-}
+    __runInitializers = function (thisArg, initializers, value) {
+        var useValue = arguments.length > 2;
+        for (var i = 0; i < initializers.length; i++) {
+            value = useValue ? initializers[i].call(thisArg, value) : initializers[i].call(thisArg);
+        }
+        return useValue ? value : void 0;
+    };
 
-// normalizes slashes.
-const slashSplit = /\/+/
+    __propKey = function (x) {
+        return typeof x === "symbol" ? x : "".concat(x);
+    };
 
-minimatch.filter = filter
-function filter (pattern, options) {
-  options = options || {}
-  return function (p, i, list) {
-    return minimatch(p, pattern, options)
-  }
-}
+    __setFunctionName = function (f, name, prefix) {
+        if (typeof name === "symbol") name = name.description ? "[".concat(name.description, "]") : "";
+        return Object.defineProperty(f, "name", { configurable: true, value: prefix ? "".concat(prefix, " ", name) : name });
+    };
 
-function ext (a, b) {
-  a = a || {}
-  b = b || {}
-  const t = {}
-  Object.keys(a).forEach(function (k) {
-    t[k] = a[k]
-  })
-  Object.keys(b).forEach(function (k) {
-    t[k] = b[k]
-  })
-  return t
-}
+    __metadata = function (metadataKey, metadataValue) {
+        if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(metadataKey, metadataValue);
+    };
 
-minimatch.defaults = function (def) {
-  if (!def || typeof def !== 'object' || !Object.keys(def).length) {
-    return minimatch
-  }
+    __awaiter = function (thisArg, _arguments, P, generator) {
+        function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
+        return new (P || (P = Promise))(function (resolve, reject) {
+            function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
+            function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
+            function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
+            step((generator = generator.apply(thisArg, _arguments || [])).next());
+        });
+    };
 
-  const orig = minimatch
+    __generator = function (thisArg, body) {
+        var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;
+        return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
+        function verb(n) { return function (v) { return step([n, v]); }; }
+        function step(op) {
+            if (f) throw new TypeError("Generator is already executing.");
+            while (g && (g = 0, op[0] && (_ = 0)), _) try {
+                if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
+                if (y = 0, t) op = [op[0] & 2, t.value];
+                switch (op[0]) {
+                    case 0: case 1: t = op; break;
+                    case 4: _.label++; return { value: op[1], done: false };
+                    case 5: _.label++; y = op[1]; op = [0]; continue;
+                    case 7: op = _.ops.pop(); _.trys.pop(); continue;
+                    default:
+                        if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
+                        if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
+                        if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
+                        if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
+                        if (t[2]) _.ops.pop();
+                        _.trys.pop(); continue;
+                }
+                op = body.call(thisArg, _);
+            } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
+            if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
+        }
+    };
 
-  const m = function minimatch (p, pattern, options) {
-    return orig(p, pattern, ext(def, options))
-  }
+    __exportStar = function(m, o) {
+        for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(o, p)) __createBinding(o, m, p);
+    };
 
-  m.Minimatch = function Minimatch (pattern, options) {
-    return new orig.Minimatch(pattern, ext(def, options))
-  }
-  m.Minimatch.defaults = options => {
-    return orig.defaults(ext(def, options)).Minimatch
-  }
+    __createBinding = Object.create ? (function(o, m, k, k2) {
+        if (k2 === undefined) k2 = k;
+        var desc = Object.getOwnPropertyDescriptor(m, k);
+        if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
+            desc = { enumerable: true, get: function() { return m[k]; } };
+        }
+        Object.defineProperty(o, k2, desc);
+    }) : (function(o, m, k, k2) {
+        if (k2 === undefined) k2 = k;
+        o[k2] = m[k];
+    });
 
-  m.filter = function filter (pattern, options) {
-    return orig.filter(pattern, ext(def, options))
-  }
+    __values = function (o) {
+        var s = typeof Symbol === "function" && Symbol.iterator, m = s && o[s], i = 0;
+        if (m) return m.call(o);
+        if (o && typeof o.length === "number") return {
+            next: function () {
+                if (o && i >= o.length) o = void 0;
+                return { value: o && o[i++], done: !o };
+            }
+        };
+        throw new TypeError(s ? "Object is not iterable." : "Symbol.iterator is not defined.");
+    };
 
-  m.defaults = function defaults (options) {
-    return orig.defaults(ext(def, options))
-  }
+    __read = function (o, n) {
+        var m = typeof Symbol === "function" && o[Symbol.iterator];
+        if (!m) return o;
+        var i = m.call(o), r, ar = [], e;
+        try {
+            while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);
+        }
+        catch (error) { e = { error: error }; }
+        finally {
+            try {
+                if (r && !r.done && (m = i["return"])) m.call(i);
+            }
+            finally { if (e) throw e.error; }
+        }
+        return ar;
+    };
 
-  m.makeRe = function makeRe (pattern, options) {
-    return orig.makeRe(pattern, ext(def, options))
-  }
+    /** @deprecated */
+    __spread = function () {
+        for (var ar = [], i = 0; i < arguments.length; i++)
+            ar = ar.concat(__read(arguments[i]));
+        return ar;
+    };
 
-  m.braceExpand = function braceExpand (pattern, options) {
-    return orig.braceExpand(pattern, ext(def, options))
-  }
+    /** @deprecated */
+    __spreadArrays = function () {
+        for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;
+        for (var r = Array(s), k = 0, i = 0; i < il; i++)
+            for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)
+                r[k] = a[j];
+        return r;
+    };
 
-  m.match = function (list, pattern, options) {
-    return orig.match(list, pattern, ext(def, options))
-  }
+    __spreadArray = function (to, from, pack) {
+        if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {
+            if (ar || !(i in from)) {
+                if (!ar) ar = Array.prototype.slice.call(from, 0, i);
+                ar[i] = from[i];
+            }
+        }
+        return to.concat(ar || Array.prototype.slice.call(from));
+    };
 
-  return m
-}
+    __await = function (v) {
+        return this instanceof __await ? (this.v = v, this) : new __await(v);
+    };
 
-Minimatch.defaults = function (def) {
-  return minimatch.defaults(def).Minimatch
-}
+    __asyncGenerator = function (thisArg, _arguments, generator) {
+        if (!Symbol.asyncIterator) throw new TypeError("Symbol.asyncIterator is not defined.");
+        var g = generator.apply(thisArg, _arguments || []), i, q = [];
+        return i = {}, verb("next"), verb("throw"), verb("return"), i[Symbol.asyncIterator] = function () { return this; }, i;
+        function verb(n) { if (g[n]) i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; }
+        function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } }
+        function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r);  }
+        function fulfill(value) { resume("next", value); }
+        function reject(value) { resume("throw", value); }
+        function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); }
+    };
 
-function minimatch (p, pattern, options) {
-  assertValidPattern(pattern)
+    __asyncDelegator = function (o) {
+        var i, p;
+        return i = {}, verb("next"), verb("throw", function (e) { throw e; }), verb("return"), i[Symbol.iterator] = function () { return this; }, i;
+        function verb(n, f) { i[n] = o[n] ? function (v) { return (p = !p) ? { value: __await(o[n](v)), done: false } : f ? f(v) : v; } : f; }
+    };
 
-  if (!options) options = {}
+    __asyncValues = function (o) {
+        if (!Symbol.asyncIterator) throw new TypeError("Symbol.asyncIterator is not defined.");
+        var m = o[Symbol.asyncIterator], i;
+        return m ? m.call(o) : (o = typeof __values === "function" ? __values(o) : o[Symbol.iterator](), i = {}, verb("next"), verb("throw"), verb("return"), i[Symbol.asyncIterator] = function () { return this; }, i);
+        function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; }
+        function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); }
+    };
 
-  // shortcut: comments match nothing.
-  if (!options.nocomment && pattern.charAt(0) === '#') {
-    return false
-  }
+    __makeTemplateObject = function (cooked, raw) {
+        if (Object.defineProperty) { Object.defineProperty(cooked, "raw", { value: raw }); } else { cooked.raw = raw; }
+        return cooked;
+    };
 
-  // "" only matches ""
-  if (pattern.trim() === '') return p === ''
+    var __setModuleDefault = Object.create ? (function(o, v) {
+        Object.defineProperty(o, "default", { enumerable: true, value: v });
+    }) : function(o, v) {
+        o["default"] = v;
+    };
 
-  return new Minimatch(pattern, options).match(p)
-}
+    __importStar = function (mod) {
+        if (mod && mod.__esModule) return mod;
+        var result = {};
+        if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
+        __setModuleDefault(result, mod);
+        return result;
+    };
 
-function Minimatch (pattern, options) {
-  if (!(this instanceof Minimatch)) {
-    return new Minimatch(pattern, options)
-  }
+    __importDefault = function (mod) {
+        return (mod && mod.__esModule) ? mod : { "default": mod };
+    };
 
-  assertValidPattern(pattern)
+    __classPrivateFieldGet = function (receiver, state, kind, f) {
+        if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a getter");
+        if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot read private member from an object whose class did not declare it");
+        return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
+    };
 
-  if (!options) options = {}
-  pattern = pattern.trim()
+    __classPrivateFieldSet = function (receiver, state, value, kind, f) {
+        if (kind === "m") throw new TypeError("Private method is not writable");
+        if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a setter");
+        if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot write private member to an object whose class did not declare it");
+        return (kind === "a" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;
+    };
 
-  // windows support: need to use /, not \
-  if (path.sep !== '/') {
-    pattern = pattern.split(path.sep).join('/')
-  }
+    __classPrivateFieldIn = function (state, receiver) {
+        if (receiver === null || (typeof receiver !== "object" && typeof receiver !== "function")) throw new TypeError("Cannot use 'in' operator on non-object");
+        return typeof state === "function" ? receiver === state : state.has(receiver);
+    };
 
-  this.options = options
-  this.set = []
-  this.pattern = pattern
-  this.regexp = null
-  this.negate = false
-  this.comment = false
-  this.empty = false
+    exporter("__extends", __extends);
+    exporter("__assign", __assign);
+    exporter("__rest", __rest);
+    exporter("__decorate", __decorate);
+    exporter("__param", __param);
+    exporter("__esDecorate", __esDecorate);
+    exporter("__runInitializers", __runInitializers);
+    exporter("__propKey", __propKey);
+    exporter("__setFunctionName", __setFunctionName);
+    exporter("__metadata", __metadata);
+    exporter("__awaiter", __awaiter);
+    exporter("__generator", __generator);
+    exporter("__exportStar", __exportStar);
+    exporter("__createBinding", __createBinding);
+    exporter("__values", __values);
+    exporter("__read", __read);
+    exporter("__spread", __spread);
+    exporter("__spreadArrays", __spreadArrays);
+    exporter("__spreadArray", __spreadArray);
+    exporter("__await", __await);
+    exporter("__asyncGenerator", __asyncGenerator);
+    exporter("__asyncDelegator", __asyncDelegator);
+    exporter("__asyncValues", __asyncValues);
+    exporter("__makeTemplateObject", __makeTemplateObject);
+    exporter("__importStar", __importStar);
+    exporter("__importDefault", __importDefault);
+    exporter("__classPrivateFieldGet", __classPrivateFieldGet);
+    exporter("__classPrivateFieldSet", __classPrivateFieldSet);
+    exporter("__classPrivateFieldIn", __classPrivateFieldIn);
+});
 
-  // make the set of regexps etc.
-  this.make()
-}
 
-Minimatch.prototype.debug = function () {}
+/***/ }),
 
-Minimatch.prototype.make = make
-function make () {
-  // don't do it more than once.
-  if (this._made) return
+/***/ 63767:
+/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
-  var pattern = this.pattern
-  var options = this.options
+var wrappy = __nccwpck_require__(65173)
+module.exports = wrappy(once)
+module.exports.strict = wrappy(onceStrict)
 
-  // empty patterns and comments match nothing.
-  if (!options.nocomment && pattern.charAt(0) === '#') {
-    this.comment = true
-    return
+once.proto = once(function () {
+  Object.defineProperty(Function.prototype, 'once', {
+    value: function () {
+      return once(this)
+    },
+    configurable: true
+  })
+
+  Object.defineProperty(Function.prototype, 'onceStrict', {
+    value: function () {
+      return onceStrict(this)
+    },
+    configurable: true
+  })
+})
+
+function once (fn) {
+  var f = function () {
+    if (f.called) return f.value
+    f.called = true
+    return f.value = fn.apply(this, arguments)
   }
-  if (!pattern) {
-    this.empty = true
-    return
+  f.called = false
+  return f
+}
+
+function onceStrict (fn) {
+  var f = function () {
+    if (f.called)
+      throw new Error(f.onceError)
+    f.called = true
+    return f.value = fn.apply(this, arguments)
   }
+  var name = fn.name || 'Function wrapped with `once`'
+  f.onceError = name + " shouldn't be called more than once"
+  f.called = false
+  return f
+}
 
-  // step 1: figure out negation, etc.
-  this.parseNegate()
 
-  // step 2: expand braces
-  var set = this.globSet = this.braceExpand()
+/***/ }),
 
-  if (options.debug) this.debug = console.error
+/***/ 76384:
+/***/ ((module) => {
 
-  this.debug(this.pattern, set)
+"use strict";
 
-  // step 3: now we have a set, so turn each one into a series of path-portion
-  // matching patterns.
-  // These will be regexps, except in the case of "**", which is
-  // set to the GLOBSTAR object for globstar behavior,
-  // and will not contain any / characters
-  set = this.globParts = set.map(function (s) {
-    return s.split(slashSplit)
-  })
 
-  this.debug(this.pattern, set)
+function posix(path) {
+	return path.charAt(0) === '/';
+}
 
-  // glob --> regexps
-  set = set.map(function (s, si, set) {
-    return s.map(this.parse, this)
-  }, this)
+function win32(path) {
+	// https://github.com/nodejs/node/blob/b3fcc245fb25539909ef1d5eaa01dbf92e168633/lib/path.js#L56
+	var splitDeviceRe = /^([a-zA-Z]:|[\\\/]{2}[^\\\/]+[\\\/]+[^\\\/]+)?([\\\/])?([\s\S]*?)$/;
+	var result = splitDeviceRe.exec(path);
+	var device = result[1] || '';
+	var isUnc = Boolean(device && device.charAt(1) !== ':');
 
-  this.debug(this.pattern, set)
+	// UNC paths are always absolute
+	return Boolean(result[2] || isUnc);
+}
 
-  // filter out everything that didn't compile properly.
-  set = set.filter(function (s) {
-    return s.indexOf(false) === -1
-  })
+module.exports = process.platform === 'win32' ? win32 : posix;
+module.exports.posix = posix;
+module.exports.win32 = win32;
 
-  this.debug(this.pattern, set)
 
-  this.set = set
-}
+/***/ }),
 
-Minimatch.prototype.parseNegate = parseNegate
-function parseNegate () {
-  var pattern = this.pattern
-  var negate = false
-  var options = this.options
-  var negateOffset = 0
+/***/ 16135:
+/***/ ((module, exports, __nccwpck_require__) => {
 
-  if (options.nonegate) return
+"use strict";
+/* module decorator */ module = __nccwpck_require__.nmd(module);
 
-  for (var i = 0, l = pattern.length
-    ; i < l && pattern.charAt(i) === '!'
-    ; i++) {
-    negate = !negate
-    negateOffset++
-  }
 
-  if (negateOffset) this.pattern = pattern.substr(negateOffset)
-  this.negate = negate
+Object.defineProperty(exports, "__esModule", ({
+  value: true
+}));
+exports.addHook = addHook;
+var _module = _interopRequireDefault(__nccwpck_require__(98188));
+var _path = _interopRequireDefault(__nccwpck_require__(71017));
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+/* (c) 2015 Ari Porad (@ariporad) . License: ariporad.mit-license.org */
+
+const nodeModulesRegex = /^(?:.*[\\/])?node_modules(?:[\\/].*)?$/;
+// Guard against poorly mocked module constructors.
+const Module = module.constructor.length > 1 ? module.constructor : _module.default;
+const HOOK_RETURNED_NOTHING_ERROR_MESSAGE = '[Pirates] A hook returned a non-string, or nothing at all! This is a' + ' violation of intergalactic law!\n' + '--------------------\n' + 'If you have no idea what this means or what Pirates is, let me explain: ' + 'Pirates is a module that makes is easy to implement require hooks. One of' + " the require hooks you're using uses it. One of these require hooks" + " didn't return anything from it's handler, so we don't know what to" + ' do. You might want to debug this.';
+
+/**
+ * @param {string} filename The filename to check.
+ * @param {string[]} exts The extensions to hook. Should start with '.' (ex. ['.js']).
+ * @param {Matcher|null} matcher A matcher function, will be called with path to a file. Should return truthy if the file should be hooked, falsy otherwise.
+ * @param {boolean} ignoreNodeModules Auto-ignore node_modules. Independent of any matcher.
+ */
+function shouldCompile(filename, exts, matcher, ignoreNodeModules) {
+  if (typeof filename !== 'string') {
+    return false;
+  }
+  if (exts.indexOf(_path.default.extname(filename)) === -1) {
+    return false;
+  }
+  const resolvedFilename = _path.default.resolve(filename);
+  if (ignoreNodeModules && nodeModulesRegex.test(resolvedFilename)) {
+    return false;
+  }
+  if (matcher && typeof matcher === 'function') {
+    return !!matcher(resolvedFilename);
+  }
+  return true;
 }
 
-// Brace expansion:
-// a{b,c}d -> abd acd
-// a{b,}c -> abc ac
-// a{0..3}d -> a0d a1d a2d a3d
-// a{b,c{d,e}f}g -> abg acdfg acefg
-// a{b,c}d{e,f}g -> abdeg acdeg abdeg abdfg
-//
-// Invalid sets are not expanded.
-// a{2..}b -> a{2..}b
-// a{b}c -> a{b}c
-minimatch.braceExpand = function (pattern, options) {
-  return braceExpand(pattern, options)
+/**
+ * @callback Hook The hook. Accepts the code of the module and the filename.
+ * @param {string} code
+ * @param {string} filename
+ * @returns {string}
+ */
+/**
+ * @callback Matcher A matcher function, will be called with path to a file.
+ *
+ * Should return truthy if the file should be hooked, falsy otherwise.
+ * @param {string} path
+ * @returns {boolean}
+ */
+/**
+ * @callback RevertFunction Reverts the hook when called.
+ * @returns {void}
+ */
+/**
+ * @typedef {object} Options
+ * @property {Matcher|null} [matcher=null] A matcher function, will be called with path to a file.
+ *
+ * Should return truthy if the file should be hooked, falsy otherwise.
+ *
+ * @property {string[]} [extensions=['.js']] The extensions to hook. Should start with '.' (ex. ['.js']).
+ * @property {string[]} [exts=['.js']] The extensions to hook. Should start with '.' (ex. ['.js']).
+ *
+ * @property {string[]} [extension=['.js']] The extensions to hook. Should start with '.' (ex. ['.js']).
+ * @property {string[]} [ext=['.js']] The extensions to hook. Should start with '.' (ex. ['.js']).
+ *
+ * @property {boolean} [ignoreNodeModules=true] Auto-ignore node_modules. Independent of any matcher.
+ */
+
+/**
+ * Add a require hook.
+ *
+ * @param {Hook} hook The hook. Accepts the code of the module and the filename. Required.
+ * @param {Options} [opts] Options
+ * @returns {RevertFunction} The `revert` function. Reverts the hook when called.
+ */
+function addHook(hook, opts = {}) {
+  let reverted = false;
+  const loaders = [];
+  const oldLoaders = [];
+  let exts;
+
+  // We need to do this to fix #15. Basically, if you use a non-standard extension (ie. .jsx), then
+  // We modify the .js loader, then use the modified .js loader for as the base for .jsx.
+  // This prevents that.
+  const originalJSLoader = Module._extensions['.js'];
+  const matcher = opts.matcher || null;
+  const ignoreNodeModules = opts.ignoreNodeModules !== false;
+  exts = opts.extensions || opts.exts || opts.extension || opts.ext || ['.js'];
+  if (!Array.isArray(exts)) {
+    exts = [exts];
+  }
+  exts.forEach(ext => {
+    if (typeof ext !== 'string') {
+      throw new TypeError(`Invalid Extension: ${ext}`);
+    }
+    const oldLoader = Module._extensions[ext] || originalJSLoader;
+    oldLoaders[ext] = Module._extensions[ext];
+    loaders[ext] = Module._extensions[ext] = function newLoader(mod, filename) {
+      let compile;
+      if (!reverted) {
+        if (shouldCompile(filename, exts, matcher, ignoreNodeModules)) {
+          compile = mod._compile;
+          mod._compile = function _compile(code) {
+            // reset the compile immediately as otherwise we end up having the
+            // compile function being changed even though this loader might be reverted
+            // Not reverting it here leads to long useless compile chains when doing
+            // addHook -> revert -> addHook -> revert -> ...
+            // The compile function is also anyway created new when the loader is called a second time.
+            mod._compile = compile;
+            const newCode = hook(code, filename);
+            if (typeof newCode !== 'string') {
+              throw new Error(HOOK_RETURNED_NOTHING_ERROR_MESSAGE);
+            }
+            return mod._compile(newCode, filename);
+          };
+        }
+      }
+      oldLoader(mod, filename);
+    };
+  });
+  return function revert() {
+    if (reverted) return;
+    reverted = true;
+    exts.forEach(ext => {
+      // if the current loader for the extension is our loader then unregister it and set the oldLoader again
+      // if not we can not do anything as we cannot remove a loader from within the loader-chain
+      if (Module._extensions[ext] === loaders[ext]) {
+        if (!oldLoaders[ext]) {
+          delete Module._extensions[ext];
+        } else {
+          Module._extensions[ext] = oldLoaders[ext];
+        }
+      }
+    });
+  };
 }
 
-Minimatch.prototype.braceExpand = braceExpand
+/***/ }),
 
-function braceExpand (pattern, options) {
-  if (!options) {
-    if (this instanceof Minimatch) {
-      options = this.options
+/***/ 90646:
+/***/ ((module) => {
+
+"use strict";
+
+
+const codes = {};
+
+function createErrorType(code, message, Base) {
+  if (!Base) {
+    Base = Error
+  }
+
+  function getMessage (arg1, arg2, arg3) {
+    if (typeof message === 'string') {
+      return message
     } else {
-      options = {}
+      return message(arg1, arg2, arg3)
     }
   }
 
-  pattern = typeof pattern === 'undefined'
-    ? this.pattern : pattern
+  class NodeError extends Base {
+    constructor (arg1, arg2, arg3) {
+      super(getMessage(arg1, arg2, arg3));
+    }
+  }
 
-  assertValidPattern(pattern)
+  NodeError.prototype.name = Base.name;
+  NodeError.prototype.code = code;
 
-  if (options.nobrace || !/\{(?:(?!\{).)*\}/.test(pattern)) {
-    // shortcut. no need to expand.
-    return [pattern]
+  codes[code] = NodeError;
+}
+
+// https://github.com/nodejs/node/blob/v10.8.0/lib/internal/errors.js
+function oneOf(expected, thing) {
+  if (Array.isArray(expected)) {
+    const len = expected.length;
+    expected = expected.map((i) => String(i));
+    if (len > 2) {
+      return `one of ${thing} ${expected.slice(0, len - 1).join(', ')}, or ` +
+             expected[len - 1];
+    } else if (len === 2) {
+      return `one of ${thing} ${expected[0]} or ${expected[1]}`;
+    } else {
+      return `of ${thing} ${expected[0]}`;
+    }
+  } else {
+    return `of ${thing} ${String(expected)}`;
   }
+}
 
-  return expand(pattern)
+// https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/startsWith
+function startsWith(str, search, pos) {
+	return str.substr(!pos || pos < 0 ? 0 : +pos, search.length) === search;
 }
 
-const MAX_PATTERN_LENGTH = 1024 * 64
-const assertValidPattern = pattern => {
-  if (typeof pattern !== 'string') {
-    throw new TypeError('invalid pattern')
+// https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/endsWith
+function endsWith(str, search, this_len) {
+	if (this_len === undefined || this_len > str.length) {
+		this_len = str.length;
+	}
+	return str.substring(this_len - search.length, this_len) === search;
+}
+
+// https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/includes
+function includes(str, search, start) {
+  if (typeof start !== 'number') {
+    start = 0;
   }
 
-  if (pattern.length > MAX_PATTERN_LENGTH) {
-    throw new TypeError('pattern is too long')
+  if (start + search.length > str.length) {
+    return false;
+  } else {
+    return str.indexOf(search, start) !== -1;
   }
 }
 
-// parse a component of the expanded set.
-// At this point, no pattern may contain "/" in it
-// so we're going to return a 2d array, where each entry is the full
-// pattern, split on '/', and then turned into a regular expression.
-// A regexp is made at the end which joins each array with an
-// escaped /, and another full one which joins each regexp with |.
-//
-// Following the lead of Bash 4.1, note that "**" only has special meaning
-// when it is the *only* thing in a path portion.  Otherwise, any series
-// of * is equivalent to a single *.  Globstar behavior is enabled by
-// default, and can be disabled by setting options.noglobstar.
-Minimatch.prototype.parse = parse
-const SUBPARSE = {}
-function parse (pattern, isSub) {
-  assertValidPattern(pattern)
+createErrorType('ERR_INVALID_OPT_VALUE', function (name, value) {
+  return 'The value "' + value + '" is invalid for option "' + name + '"'
+}, TypeError);
+createErrorType('ERR_INVALID_ARG_TYPE', function (name, expected, actual) {
+  // determiner: 'must be' or 'must not be'
+  let determiner;
+  if (typeof expected === 'string' && startsWith(expected, 'not ')) {
+    determiner = 'must not be';
+    expected = expected.replace(/^not /, '');
+  } else {
+    determiner = 'must be';
+  }
 
-  var options = this.options
+  let msg;
+  if (endsWith(name, ' argument')) {
+    // For cases like 'first argument'
+    msg = `The ${name} ${determiner} ${oneOf(expected, 'type')}`;
+  } else {
+    const type = includes(name, '.') ? 'property' : 'argument';
+    msg = `The "${name}" ${type} ${determiner} ${oneOf(expected, 'type')}`;
+  }
 
-  // shortcuts
-  if (!options.noglobstar && pattern === '**') return GLOBSTAR
-  if (pattern === '') return ''
+  msg += `. Received type ${typeof actual}`;
+  return msg;
+}, TypeError);
+createErrorType('ERR_STREAM_PUSH_AFTER_EOF', 'stream.push() after EOF');
+createErrorType('ERR_METHOD_NOT_IMPLEMENTED', function (name) {
+  return 'The ' + name + ' method is not implemented'
+});
+createErrorType('ERR_STREAM_PREMATURE_CLOSE', 'Premature close');
+createErrorType('ERR_STREAM_DESTROYED', function (name) {
+  return 'Cannot call ' + name + ' after a stream was destroyed';
+});
+createErrorType('ERR_MULTIPLE_CALLBACK', 'Callback called multiple times');
+createErrorType('ERR_STREAM_CANNOT_PIPE', 'Cannot pipe, not readable');
+createErrorType('ERR_STREAM_WRITE_AFTER_END', 'write after end');
+createErrorType('ERR_STREAM_NULL_VALUES', 'May not write null values to stream', TypeError);
+createErrorType('ERR_UNKNOWN_ENCODING', function (arg) {
+  return 'Unknown encoding: ' + arg
+}, TypeError);
+createErrorType('ERR_STREAM_UNSHIFT_AFTER_END_EVENT', 'stream.unshift() after end event');
 
-  var re = ''
-  var hasMagic = false
-  var escaping = false
-  // ? => one single character
-  var patternListStack = []
-  var negativeLists = []
-  var stateChar
-  var inClass = false
-  var reClassStart = -1
-  var classStart = -1
-  // . and .. never match anything that doesn't start with .,
-  // even when options.dot is set.
-  var patternStart = pattern.charAt(0) === '.' ? '' // anything
-  // not (start or / followed by . or .. followed by / or end)
-  : options.dot ? '(?!(?:^|\\\/)\\.{1,2}(?:$|\\\/))'
-  : '(?!\\.)'
-  var self = this
+module.exports.q = codes;
 
-  function clearStateChar () {
-    if (stateChar) {
-      // we had some state-tracking character
-      // that wasn't consumed by this pass.
-      switch (stateChar) {
-        case '*':
-          re += star
-          hasMagic = true
-        break
-        case '?':
-          re += qmark
-          hasMagic = true
-        break
-        default:
-          re += '\\' + stateChar
-        break
-      }
-      self.debug('clearStateChar %j %j', stateChar, re)
-      stateChar = false
-    }
-  }
 
-  for (var i = 0, len = pattern.length, c
-    ; (i < len) && (c = pattern.charAt(i))
-    ; i++) {
-    this.debug('%s\t%s %s %j', pattern, i, re, c)
+/***/ }),
 
-    // skip over any that are escaped.
-    if (escaping && reSpecials[c]) {
-      re += '\\' + c
-      escaping = false
-      continue
-    }
+/***/ 97256:
+/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
-    switch (c) {
-      case '/': /* istanbul ignore next */ {
-        // completely not allowed, even escaped.
-        // Should already be path-split by now.
-        return false
-      }
+"use strict";
+// Copyright Joyent, Inc. and other Node contributors.
+//
+// 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.
+// a duplex stream is just a stream that is both readable and writable.
+// Since JS doesn't have multiple prototypal inheritance, this class
+// prototypally inherits from Readable, and then parasitically from
+// Writable.
 
-      case '\\':
-        clearStateChar()
-        escaping = true
-      continue
+/**/
 
-      // the various stateChar values
-      // for the "extglob" stuff.
-      case '?':
-      case '*':
-      case '+':
-      case '@':
-      case '!':
-        this.debug('%s\t%s %s %j <-- stateChar', pattern, i, re, c)
+var objectKeys = Object.keys || function (obj) {
+  var keys = [];
 
-        // all of those are literals inside a class, except that
-        // the glob [!a] means [^a] in regexp
-        if (inClass) {
-          this.debug('  in class')
-          if (c === '!' && i === classStart + 1) c = '^'
-          re += c
-          continue
-        }
+  for (var key in obj) {
+    keys.push(key);
+  }
 
-        // if we already have a stateChar, then it means
-        // that there was something like ** or +? in there.
-        // Handle the stateChar, then proceed with this one.
-        self.debug('call clearStateChar %j', stateChar)
-        clearStateChar()
-        stateChar = c
-        // if extglob is disabled, then +(asdf|foo) isn't a thing.
-        // just clear the statechar *now*, rather than even diving into
-        // the patternList stuff.
-        if (options.noext) clearStateChar()
-      continue
+  return keys;
+};
+/**/
 
-      case '(':
-        if (inClass) {
-          re += '('
-          continue
-        }
 
-        if (!stateChar) {
-          re += '\\('
-          continue
-        }
+module.exports = Duplex;
 
-        patternListStack.push({
-          type: stateChar,
-          start: i - 1,
-          reStart: re.length,
-          open: plTypes[stateChar].open,
-          close: plTypes[stateChar].close
-        })
-        // negation is (?:(?!js)[^/]*)
-        re += stateChar === '!' ? '(?:(?!(?:' : '(?:'
-        this.debug('plType %j %j', stateChar, re)
-        stateChar = false
-      continue
+var Readable = __nccwpck_require__(90960);
 
-      case ')':
-        if (inClass || !patternListStack.length) {
-          re += '\\)'
-          continue
-        }
+var Writable = __nccwpck_require__(23388);
 
-        clearStateChar()
-        hasMagic = true
-        var pl = patternListStack.pop()
-        // negation is (?:(?!js)[^/]*)
-        // The others are (?:)
-        re += pl.close
-        if (pl.type === '!') {
-          negativeLists.push(pl)
-        }
-        pl.reEnd = re.length
-      continue
+__nccwpck_require__(76401)(Duplex, Readable);
 
-      case '|':
-        if (inClass || !patternListStack.length || escaping) {
-          re += '\\|'
-          escaping = false
-          continue
-        }
+{
+  // Allow the keys array to be GC'ed.
+  var keys = objectKeys(Writable.prototype);
 
-        clearStateChar()
-        re += '|'
-      continue
+  for (var v = 0; v < keys.length; v++) {
+    var method = keys[v];
+    if (!Duplex.prototype[method]) Duplex.prototype[method] = Writable.prototype[method];
+  }
+}
 
-      // these are mostly the same in regexp and glob
-      case '[':
-        // swallow any state-tracking char before the [
-        clearStateChar()
+function Duplex(options) {
+  if (!(this instanceof Duplex)) return new Duplex(options);
+  Readable.call(this, options);
+  Writable.call(this, options);
+  this.allowHalfOpen = true;
 
-        if (inClass) {
-          re += '\\' + c
-          continue
-        }
+  if (options) {
+    if (options.readable === false) this.readable = false;
+    if (options.writable === false) this.writable = false;
 
-        inClass = true
-        classStart = i
-        reClassStart = re.length
-        re += c
-      continue
+    if (options.allowHalfOpen === false) {
+      this.allowHalfOpen = false;
+      this.once('end', onend);
+    }
+  }
+}
 
-      case ']':
-        //  a right bracket shall lose its special
-        //  meaning and represent itself in
-        //  a bracket expression if it occurs
-        //  first in the list.  -- POSIX.2 2.8.3.2
-        if (i === classStart + 1 || !inClass) {
-          re += '\\' + c
-          escaping = false
-          continue
-        }
+Object.defineProperty(Duplex.prototype, 'writableHighWaterMark', {
+  // making it explicit this property is not enumerable
+  // because otherwise some prototype manipulation in
+  // userland will fail
+  enumerable: false,
+  get: function get() {
+    return this._writableState.highWaterMark;
+  }
+});
+Object.defineProperty(Duplex.prototype, 'writableBuffer', {
+  // making it explicit this property is not enumerable
+  // because otherwise some prototype manipulation in
+  // userland will fail
+  enumerable: false,
+  get: function get() {
+    return this._writableState && this._writableState.getBuffer();
+  }
+});
+Object.defineProperty(Duplex.prototype, 'writableLength', {
+  // making it explicit this property is not enumerable
+  // because otherwise some prototype manipulation in
+  // userland will fail
+  enumerable: false,
+  get: function get() {
+    return this._writableState.length;
+  }
+}); // the no-half-open enforcer
 
-        // handle the case where we left a class open.
-        // "[z-a]" is valid, equivalent to "\[z-a\]"
-        if (inClass) {
-          // split where the last [ was, make sure we don't have
-          // an invalid re. if so, re-walk the contents of the
-          // would-be class to re-translate any characters that
-          // were passed through as-is
-          // TODO: It would probably be faster to determine this
-          // without a try/catch and a new RegExp, but it's tricky
-          // to do safely.  For now, this is safe and works.
-          var cs = pattern.substring(classStart + 1, i)
-          try {
-            RegExp('[' + cs + ']')
-          } catch (er) {
-            // not a valid class!
-            var sp = this.parse(cs, SUBPARSE)
-            re = re.substr(0, reClassStart) + '\\[' + sp[0] + '\\]'
-            hasMagic = hasMagic || sp[1]
-            inClass = false
-            continue
-          }
-        }
+function onend() {
+  // If the writable side ended, then we're ok.
+  if (this._writableState.ended) return; // no more data can be written.
+  // But allow more writes to happen in this tick.
 
-        // finish up the class.
-        hasMagic = true
-        inClass = false
-        re += c
-      continue
+  process.nextTick(onEndNT, this);
+}
 
-      default:
-        // swallow any state char that wasn't consumed
-        clearStateChar()
+function onEndNT(self) {
+  self.end();
+}
 
-        if (escaping) {
-          // no need
-          escaping = false
-        } else if (reSpecials[c]
-          && !(c === '^' && inClass)) {
-          re += '\\'
-        }
+Object.defineProperty(Duplex.prototype, 'destroyed', {
+  // making it explicit this property is not enumerable
+  // because otherwise some prototype manipulation in
+  // userland will fail
+  enumerable: false,
+  get: function get() {
+    if (this._readableState === undefined || this._writableState === undefined) {
+      return false;
+    }
 
-        re += c
+    return this._readableState.destroyed && this._writableState.destroyed;
+  },
+  set: function set(value) {
+    // we ignore the value if the stream
+    // has not been initialized yet
+    if (this._readableState === undefined || this._writableState === undefined) {
+      return;
+    } // backward compatibility, the user is explicitly
+    // managing destroyed
 
-    } // switch
-  } // for
 
-  // handle the case where we left a class open.
-  // "[abc" is valid, equivalent to "\[abc"
-  if (inClass) {
-    // split where the last [ was, and escape it
-    // this is a huge pita.  We now have to re-walk
-    // the contents of the would-be class to re-translate
-    // any characters that were passed through as-is
-    cs = pattern.substr(classStart + 1)
-    sp = this.parse(cs, SUBPARSE)
-    re = re.substr(0, reClassStart) + '\\[' + sp[0]
-    hasMagic = hasMagic || sp[1]
+    this._readableState.destroyed = value;
+    this._writableState.destroyed = value;
   }
+});
 
-  // handle the case where we had a +( thing at the *end*
-  // of the pattern.
-  // each pattern list stack adds 3 chars, and we need to go through
-  // and escape any | chars that were passed through as-is for the regexp.
-  // Go through and escape them, taking care not to double-escape any
-  // | chars that were already escaped.
-  for (pl = patternListStack.pop(); pl; pl = patternListStack.pop()) {
-    var tail = re.slice(pl.reStart + pl.open.length)
-    this.debug('setting tail', re, pl)
-    // maybe some even number of \, then maybe 1 \, followed by a |
-    tail = tail.replace(/((?:\\{2}){0,64})(\\?)\|/g, function (_, $1, $2) {
-      if (!$2) {
-        // the | isn't already escaped, so escape it.
-        $2 = '\\'
-      }
-
-      // need to escape all those slashes *again*, without escaping the
-      // one that we need for escaping the | character.  As it works out,
-      // escaping an even number of slashes can be done by simply repeating
-      // it exactly after itself.  That's why this trick works.
-      //
-      // I am sorry that you have to see this.
-      return $1 + $1 + $2 + '|'
-    })
-
-    this.debug('tail=%j\n   %s', tail, tail, pl, re)
-    var t = pl.type === '*' ? star
-      : pl.type === '?' ? qmark
-      : '\\' + pl.type
+/***/ }),
 
-    hasMagic = true
-    re = re.slice(0, pl.reStart) + t + '\\(' + tail
-  }
+/***/ 17940:
+/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
-  // handle trailing things that only matter at the very end.
-  clearStateChar()
-  if (escaping) {
-    // trailing \\
-    re += '\\\\'
-  }
+"use strict";
+// Copyright Joyent, Inc. and other Node contributors.
+//
+// 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.
+// a passthrough stream.
+// basically just the most minimal sort of Transform stream.
+// Every written chunk gets output as-is.
 
-  // only need to apply the nodot start if the re starts with
-  // something that could conceivably capture a dot
-  var addPatternStart = false
-  switch (re.charAt(0)) {
-    case '.':
-    case '[':
-    case '(': addPatternStart = true
-  }
 
-  // Hack to work around lack of negative lookbehind in JS
-  // A pattern like: *.!(x).!(y|z) needs to ensure that a name
-  // like 'a.xyz.yz' doesn't match.  So, the first negative
-  // lookahead, has to look ALL the way ahead, to the end of
-  // the pattern.
-  for (var n = negativeLists.length - 1; n > -1; n--) {
-    var nl = negativeLists[n]
+module.exports = PassThrough;
 
-    var nlBefore = re.slice(0, nl.reStart)
-    var nlFirst = re.slice(nl.reStart, nl.reEnd - 8)
-    var nlLast = re.slice(nl.reEnd - 8, nl.reEnd)
-    var nlAfter = re.slice(nl.reEnd)
+var Transform = __nccwpck_require__(56765);
 
-    nlLast += nlAfter
+__nccwpck_require__(76401)(PassThrough, Transform);
 
-    // Handle nested stuff like *(*.js|!(*.json)), where open parens
-    // mean that we should *not* include the ) in the bit that is considered
-    // "after" the negated section.
-    var openParensBefore = nlBefore.split('(').length - 1
-    var cleanAfter = nlAfter
-    for (i = 0; i < openParensBefore; i++) {
-      cleanAfter = cleanAfter.replace(/\)[+*?]?/, '')
-    }
-    nlAfter = cleanAfter
+function PassThrough(options) {
+  if (!(this instanceof PassThrough)) return new PassThrough(options);
+  Transform.call(this, options);
+}
 
-    var dollar = ''
-    if (nlAfter === '' && isSub !== SUBPARSE) {
-      dollar = '$'
-    }
-    var newRe = nlBefore + nlFirst + nlAfter + dollar + nlLast
-    re = newRe
-  }
+PassThrough.prototype._transform = function (chunk, encoding, cb) {
+  cb(null, chunk);
+};
 
-  // if the re is not "" at this point, then we need to make sure
-  // it doesn't match against an empty path part.
-  // Otherwise a/* will match a/, which it should not.
-  if (re !== '' && hasMagic) {
-    re = '(?=.)' + re
-  }
+/***/ }),
 
-  if (addPatternStart) {
-    re = patternStart + re
-  }
+/***/ 90960:
+/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
-  // parsing just a piece of a larger pattern.
-  if (isSub === SUBPARSE) {
-    return [re, hasMagic]
-  }
+"use strict";
+// Copyright Joyent, Inc. and other Node contributors.
+//
+// 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.
 
-  // skip the regexp for non-magical patterns
-  // unescape anything in it, though, so that it'll be
-  // an exact match against a file etc.
-  if (!hasMagic) {
-    return globUnescape(pattern)
-  }
 
-  var flags = options.nocase ? 'i' : ''
-  try {
-    var regExp = new RegExp('^' + re + '$', flags)
-  } catch (er) /* istanbul ignore next - should be impossible */ {
-    // If it was an invalid regular expression, then it can't match
-    // anything.  This trick looks for a character after the end of
-    // the string, which is of course impossible, except in multi-line
-    // mode, but it's not a /m regex.
-    return new RegExp('$.')
-  }
+module.exports = Readable;
+/**/
 
-  regExp._glob = pattern
-  regExp._src = re
+var Duplex;
+/**/
 
-  return regExp
-}
+Readable.ReadableState = ReadableState;
+/**/
 
-minimatch.makeRe = function (pattern, options) {
-  return new Minimatch(pattern, options || {}).makeRe()
-}
+var EE = (__nccwpck_require__(82361).EventEmitter);
 
-Minimatch.prototype.makeRe = makeRe
-function makeRe () {
-  if (this.regexp || this.regexp === false) return this.regexp
+var EElistenerCount = function EElistenerCount(emitter, type) {
+  return emitter.listeners(type).length;
+};
+/**/
 
-  // at this point, this.set is a 2d array of partial
-  // pattern strings, or "**".
-  //
-  // It's better to use .match().  This function shouldn't
-  // be used, really, but it's pretty convenient sometimes,
-  // when you just want to work with a regex.
-  var set = this.set
+/**/
 
-  if (!set.length) {
-    this.regexp = false
-    return this.regexp
-  }
-  var options = this.options
 
-  var twoStar = options.noglobstar ? star
-    : options.dot ? twoStarDot
-    : twoStarNoDot
-  var flags = options.nocase ? 'i' : ''
+var Stream = __nccwpck_require__(99004);
+/**/
 
-  var re = set.map(function (pattern) {
-    return pattern.map(function (p) {
-      return (p === GLOBSTAR) ? twoStar
-      : (typeof p === 'string') ? regExpEscape(p)
-      : p._src
-    }).join('\\\/')
-  }).join('|')
 
-  // must match entire pattern
-  // ending in a * or ** will make it less strict.
-  re = '^(?:' + re + ')$'
+var Buffer = (__nccwpck_require__(14300).Buffer);
 
-  // can match anything, as long as it's not this.
-  if (this.negate) re = '^(?!' + re + ').*$'
+var OurUint8Array = global.Uint8Array || function () {};
 
-  try {
-    this.regexp = new RegExp(re, flags)
-  } catch (ex) /* istanbul ignore next - should be impossible */ {
-    this.regexp = false
-  }
-  return this.regexp
+function _uint8ArrayToBuffer(chunk) {
+  return Buffer.from(chunk);
 }
 
-minimatch.match = function (list, pattern, options) {
-  options = options || {}
-  const mm = new Minimatch(pattern, options)
-  list = list.filter(function (f) {
-    return mm.match(f)
-  })
-  if (mm.options.nonull && !list.length) {
-    list.push(pattern)
-  }
-  return list
+function _isUint8Array(obj) {
+  return Buffer.isBuffer(obj) || obj instanceof OurUint8Array;
 }
+/**/
 
-Minimatch.prototype.match = match
-function match (f, partial) {
-  this.debug('match', f, this.pattern)
-  // short-circuit in the case of busted things.
-  // comments, etc.
-  if (this.comment) return false
-  if (this.empty) return f === ''
-
-  if (f === '/' && partial) return true
 
-  var options = this.options
+var debugUtil = __nccwpck_require__(73837);
 
-  // windows: need to use /, not \
-  if (path.sep !== '/') {
-    f = f.split(path.sep).join('/')
-  }
+var debug;
 
-  // treat the test path as a set of pathparts.
-  f = f.split(slashSplit)
-  this.debug(this.pattern, 'split', f)
+if (debugUtil && debugUtil.debuglog) {
+  debug = debugUtil.debuglog('stream');
+} else {
+  debug = function debug() {};
+}
+/**/
 
-  // just ONE of the pattern sets in this.set needs to match
-  // in order for it to be valid.  If negating, then just one
-  // match means that we have failed.
-  // Either way, return on the first hit.
 
-  var set = this.set
-  this.debug(this.pattern, 'set', set)
+var BufferList = __nccwpck_require__(75920);
 
-  // Find the basename of the path by looking for the last non-empty segment
-  var filename
-  var i
-  for (i = f.length - 1; i >= 0; i--) {
-    filename = f[i]
-    if (filename) break
-  }
+var destroyImpl = __nccwpck_require__(33148);
 
-  for (i = 0; i < set.length; i++) {
-    var pattern = set[i]
-    var file = f
-    if (options.matchBase && pattern.length === 1) {
-      file = [filename]
-    }
-    var hit = this.matchOne(file, pattern, partial)
-    if (hit) {
-      if (options.flipNegate) return true
-      return !this.negate
-    }
-  }
+var _require = __nccwpck_require__(12138),
+    getHighWaterMark = _require.getHighWaterMark;
 
-  // didn't get any hits.  this is success if it's a negative
-  // pattern, failure otherwise.
-  if (options.flipNegate) return false
-  return this.negate
-}
+var _require$codes = (__nccwpck_require__(90646)/* .codes */ .q),
+    ERR_INVALID_ARG_TYPE = _require$codes.ERR_INVALID_ARG_TYPE,
+    ERR_STREAM_PUSH_AFTER_EOF = _require$codes.ERR_STREAM_PUSH_AFTER_EOF,
+    ERR_METHOD_NOT_IMPLEMENTED = _require$codes.ERR_METHOD_NOT_IMPLEMENTED,
+    ERR_STREAM_UNSHIFT_AFTER_END_EVENT = _require$codes.ERR_STREAM_UNSHIFT_AFTER_END_EVENT; // Lazy loaded to improve the startup performance.
 
-// set partial to true to test if, for example,
-// "/a/b" matches the start of "/*/b/*/d"
-// Partial means, if you run out of file before you run
-// out of pattern, then that's fine, as long as all
-// the parts match.
-Minimatch.prototype.matchOne = function (file, pattern, partial) {
-  var options = this.options
 
-  this.debug('matchOne',
-    { 'this': this, file: file, pattern: pattern })
+var StringDecoder;
+var createReadableStreamAsyncIterator;
+var from;
 
-  this.debug('matchOne', file.length, pattern.length)
+__nccwpck_require__(76401)(Readable, Stream);
 
-  for (var fi = 0,
-      pi = 0,
-      fl = file.length,
-      pl = pattern.length
-      ; (fi < fl) && (pi < pl)
-      ; fi++, pi++) {
-    this.debug('matchOne loop')
-    var p = pattern[pi]
-    var f = file[fi]
+var errorOrDestroy = destroyImpl.errorOrDestroy;
+var kProxyEvents = ['error', 'close', 'destroy', 'pause', 'resume'];
 
-    this.debug(pattern, p, f)
+function prependListener(emitter, event, fn) {
+  // Sadly this is not cacheable as some libraries bundle their own
+  // event emitter implementation with them.
+  if (typeof emitter.prependListener === 'function') return emitter.prependListener(event, fn); // This is a hack to make sure that our error handler is attached before any
+  // userland ones.  NEVER DO THIS. This is here only because this code needs
+  // to continue to work with older versions of Node.js that do not include
+  // the prependListener() method. The goal is to eventually remove this hack.
 
-    // should be impossible.
-    // some invalid regexp stuff in the set.
-    /* istanbul ignore if */
-    if (p === false) return false
+  if (!emitter._events || !emitter._events[event]) emitter.on(event, fn);else if (Array.isArray(emitter._events[event])) emitter._events[event].unshift(fn);else emitter._events[event] = [fn, emitter._events[event]];
+}
 
-    if (p === GLOBSTAR) {
-      this.debug('GLOBSTAR', [pattern, p, f])
+function ReadableState(options, stream, isDuplex) {
+  Duplex = Duplex || __nccwpck_require__(97256);
+  options = options || {}; // Duplex streams are both readable and writable, but share
+  // the same options object.
+  // However, some cases require setting options to different
+  // values for the readable and the writable sides of the duplex stream.
+  // These options can be provided separately as readableXXX and writableXXX.
 
-      // "**"
-      // a/**/b/**/c would match the following:
-      // a/b/x/y/z/c
-      // a/x/y/z/b/c
-      // a/b/x/b/x/c
-      // a/b/c
-      // To do this, take the rest of the pattern after
-      // the **, and see if it would match the file remainder.
-      // If so, return success.
-      // If not, the ** "swallows" a segment, and try again.
-      // This is recursively awful.
-      //
-      // a/**/b/**/c matching a/b/x/y/z/c
-      // - a matches a
-      // - doublestar
-      //   - matchOne(b/x/y/z/c, b/**/c)
-      //     - b matches b
-      //     - doublestar
-      //       - matchOne(x/y/z/c, c) -> no
-      //       - matchOne(y/z/c, c) -> no
-      //       - matchOne(z/c, c) -> no
-      //       - matchOne(c, c) yes, hit
-      var fr = fi
-      var pr = pi + 1
-      if (pr === pl) {
-        this.debug('** at the end')
-        // a ** at the end will just swallow the rest.
-        // We have found a match.
-        // however, it will not swallow /.x, unless
-        // options.dot is set.
-        // . and .. are *never* matched by **, for explosively
-        // exponential reasons.
-        for (; fi < fl; fi++) {
-          if (file[fi] === '.' || file[fi] === '..' ||
-            (!options.dot && file[fi].charAt(0) === '.')) return false
-        }
-        return true
-      }
+  if (typeof isDuplex !== 'boolean') isDuplex = stream instanceof Duplex; // object stream flag. Used to make read(n) ignore n and to
+  // make all the buffer merging and length checks go away
 
-      // ok, let's see if we can swallow whatever we can.
-      while (fr < fl) {
-        var swallowee = file[fr]
+  this.objectMode = !!options.objectMode;
+  if (isDuplex) this.objectMode = this.objectMode || !!options.readableObjectMode; // the point at which it stops calling _read() to fill the buffer
+  // Note: 0 is a valid value, means "don't call _read preemptively ever"
 
-        this.debug('\nglobstar while', file, fr, pattern, pr, swallowee)
+  this.highWaterMark = getHighWaterMark(this, options, 'readableHighWaterMark', isDuplex); // A linked list is used to store data chunks instead of an array because the
+  // linked list can remove elements from the beginning faster than
+  // array.shift()
 
-        // XXX remove this slice.  Just pass the start index.
-        if (this.matchOne(file.slice(fr), pattern.slice(pr), partial)) {
-          this.debug('globstar found match!', fr, fl, swallowee)
-          // found a match.
-          return true
-        } else {
-          // can't swallow "." or ".." ever.
-          // can only swallow ".foo" when explicitly asked.
-          if (swallowee === '.' || swallowee === '..' ||
-            (!options.dot && swallowee.charAt(0) === '.')) {
-            this.debug('dot detected!', file, fr, pattern, pr)
-            break
-          }
+  this.buffer = new BufferList();
+  this.length = 0;
+  this.pipes = null;
+  this.pipesCount = 0;
+  this.flowing = null;
+  this.ended = false;
+  this.endEmitted = false;
+  this.reading = false; // a flag to be able to tell if the event 'readable'/'data' is emitted
+  // immediately, or on a later tick.  We set this to true at first, because
+  // any actions that shouldn't happen until "later" should generally also
+  // not happen before the first read call.
 
-          // ** swallows a segment, and continue.
-          this.debug('globstar swallow a segment, and continue')
-          fr++
-        }
-      }
+  this.sync = true; // whenever we return null, then we set a flag to say
+  // that we're awaiting a 'readable' event emission.
 
-      // no match was found.
-      // However, in partial mode, we can't say this is necessarily over.
-      // If there's more *pattern* left, then
-      /* istanbul ignore if */
-      if (partial) {
-        // ran out of file
-        this.debug('\n>>> no match, partial?', file, fr, pattern, pr)
-        if (fr === fl) return true
-      }
-      return false
-    }
+  this.needReadable = false;
+  this.emittedReadable = false;
+  this.readableListening = false;
+  this.resumeScheduled = false;
+  this.paused = true; // Should close be emitted on destroy. Defaults to true.
 
-    // something other than **
-    // non-magic patterns just have to match exactly
-    // patterns with magic have been turned into regexps.
-    var hit
-    if (typeof p === 'string') {
-      if (options.nocase) {
-        hit = f.toLowerCase() === p.toLowerCase()
-      } else {
-        hit = f === p
-      }
-      this.debug('string match', p, f, hit)
-    } else {
-      hit = f.match(p)
-      this.debug('pattern match', p, f, hit)
-    }
+  this.emitClose = options.emitClose !== false; // Should .destroy() be called after 'end' (and potentially 'finish')
 
-    if (!hit) return false
-  }
+  this.autoDestroy = !!options.autoDestroy; // has it been destroyed
 
-  // Note: ending in / means that we'll get a final ""
-  // at the end of the pattern.  This can only match a
-  // corresponding "" at the end of the file.
-  // If the file ends in /, then it can only match a
-  // a pattern that ends in /, unless the pattern just
-  // doesn't have any more for it. But, a/b/ should *not*
-  // match "a/b/*", even though "" matches against the
-  // [^/]*? pattern, except in partial mode, where it might
-  // simply not be reached yet.
-  // However, a/b/ should still satisfy a/*
+  this.destroyed = false; // Crypto is kind of old and crusty.  Historically, its default string
+  // encoding is 'binary' so we have to make this configurable.
+  // Everything else in the universe uses 'utf8', though.
 
-  // now either we fell off the end of the pattern, or we're done.
-  if (fi === fl && pi === pl) {
-    // ran out of pattern and filename at the same time.
-    // an exact hit!
-    return true
-  } else if (fi === fl) {
-    // ran out of file, but still had pattern left.
-    // this is ok if we're doing the match as part of
-    // a glob fs traversal.
-    return partial
-  } else /* istanbul ignore else */ if (pi === pl) {
-    // ran out of pattern, still have file left.
-    // this is only acceptable if we're on the very last
-    // empty segment of a file with a trailing slash.
-    // a/* should match a/b/
-    return (fi === fl - 1) && (file[fi] === '')
-  }
+  this.defaultEncoding = options.defaultEncoding || 'utf8'; // the number of writers that are awaiting a drain event in .pipe()s
 
-  // should be unreachable.
-  /* istanbul ignore next */
-  throw new Error('wtf?')
-}
+  this.awaitDrain = 0; // if true, a maybeReadMore has been scheduled
 
-// replace stuff like \* with *
-function globUnescape (s) {
-  return s.replace(/\\(.)/g, '$1')
-}
+  this.readingMore = false;
+  this.decoder = null;
+  this.encoding = null;
 
-function regExpEscape (s) {
-  return s.replace(/[-[\]{}()*+?.,\\^$|#\s]/g, '\\$&')
+  if (options.encoding) {
+    if (!StringDecoder) StringDecoder = (__nccwpck_require__(59868)/* .StringDecoder */ .s);
+    this.decoder = new StringDecoder(options.encoding);
+    this.encoding = options.encoding;
+  }
 }
 
+function Readable(options) {
+  Duplex = Duplex || __nccwpck_require__(97256);
+  if (!(this instanceof Readable)) return new Readable(options); // Checking for a Stream.Duplex instance is faster here instead of inside
+  // the ReadableState constructor, at least with V8 6.5
 
-/***/ }),
+  var isDuplex = this instanceof Duplex;
+  this._readableState = new ReadableState(options, this, isDuplex); // legacy
 
-/***/ 32272:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+  this.readable = true;
 
-const ANY = Symbol('SemVer ANY')
-// hoisted class for cyclic dependency
-class Comparator {
-  static get ANY () {
-    return ANY
+  if (options) {
+    if (typeof options.read === 'function') this._read = options.read;
+    if (typeof options.destroy === 'function') this._destroy = options.destroy;
   }
-  constructor (comp, options) {
-    options = parseOptions(options)
 
-    if (comp instanceof Comparator) {
-      if (comp.loose === !!options.loose) {
-        return comp
-      } else {
-        comp = comp.value
-      }
+  Stream.call(this);
+}
+
+Object.defineProperty(Readable.prototype, 'destroyed', {
+  // making it explicit this property is not enumerable
+  // because otherwise some prototype manipulation in
+  // userland will fail
+  enumerable: false,
+  get: function get() {
+    if (this._readableState === undefined) {
+      return false;
     }
 
-    debug('comparator', comp, options)
-    this.options = options
-    this.loose = !!options.loose
-    this.parse(comp)
+    return this._readableState.destroyed;
+  },
+  set: function set(value) {
+    // we ignore the value if the stream
+    // has not been initialized yet
+    if (!this._readableState) {
+      return;
+    } // backward compatibility, the user is explicitly
+    // managing destroyed
 
-    if (this.semver === ANY) {
-      this.value = ''
-    } else {
-      this.value = this.operator + this.semver.version
-    }
 
-    debug('comp', this)
+    this._readableState.destroyed = value;
   }
+});
+Readable.prototype.destroy = destroyImpl.destroy;
+Readable.prototype._undestroy = destroyImpl.undestroy;
 
-  parse (comp) {
-    const r = this.options.loose ? re[t.COMPARATORLOOSE] : re[t.COMPARATOR]
-    const m = comp.match(r)
+Readable.prototype._destroy = function (err, cb) {
+  cb(err);
+}; // Manually shove something into the read() buffer.
+// This returns true if the highWaterMark has not been hit yet,
+// similar to how Writable.write() returns true if you should
+// write() some more.
 
-    if (!m) {
-      throw new TypeError(`Invalid comparator: ${comp}`)
-    }
 
-    this.operator = m[1] !== undefined ? m[1] : ''
-    if (this.operator === '=') {
-      this.operator = ''
-    }
+Readable.prototype.push = function (chunk, encoding) {
+  var state = this._readableState;
+  var skipChunkCheck;
 
-    // if it literally is just '>' or '' then allow anything.
-    if (!m[2]) {
-      this.semver = ANY
-    } else {
-      this.semver = new SemVer(m[2], this.options.loose)
-    }
-  }
+  if (!state.objectMode) {
+    if (typeof chunk === 'string') {
+      encoding = encoding || state.defaultEncoding;
 
-  toString () {
-    return this.value
+      if (encoding !== state.encoding) {
+        chunk = Buffer.from(chunk, encoding);
+        encoding = '';
+      }
+
+      skipChunkCheck = true;
+    }
+  } else {
+    skipChunkCheck = true;
   }
 
-  test (version) {
-    debug('Comparator.test', version, this.options.loose)
+  return readableAddChunk(this, chunk, encoding, false, skipChunkCheck);
+}; // Unshift should *always* be something directly out of read()
 
-    if (this.semver === ANY || version === ANY) {
-      return true
-    }
 
-    if (typeof version === 'string') {
-      try {
-        version = new SemVer(version, this.options)
-      } catch (er) {
-        return false
-      }
-    }
+Readable.prototype.unshift = function (chunk) {
+  return readableAddChunk(this, chunk, null, true, false);
+};
 
-    return cmp(version, this.operator, this.semver, this.options)
-  }
+function readableAddChunk(stream, chunk, encoding, addToFront, skipChunkCheck) {
+  debug('readableAddChunk', chunk);
+  var state = stream._readableState;
 
-  intersects (comp, options) {
-    if (!(comp instanceof Comparator)) {
-      throw new TypeError('a Comparator is required')
-    }
+  if (chunk === null) {
+    state.reading = false;
+    onEofChunk(stream, state);
+  } else {
+    var er;
+    if (!skipChunkCheck) er = chunkInvalid(state, chunk);
 
-    if (!options || typeof options !== 'object') {
-      options = {
-        loose: !!options,
-        includePrerelease: false
+    if (er) {
+      errorOrDestroy(stream, er);
+    } else if (state.objectMode || chunk && chunk.length > 0) {
+      if (typeof chunk !== 'string' && !state.objectMode && Object.getPrototypeOf(chunk) !== Buffer.prototype) {
+        chunk = _uint8ArrayToBuffer(chunk);
       }
-    }
 
-    if (this.operator === '') {
-      if (this.value === '') {
-        return true
-      }
-      return new Range(comp.value, options).test(this.value)
-    } else if (comp.operator === '') {
-      if (comp.value === '') {
-        return true
+      if (addToFront) {
+        if (state.endEmitted) errorOrDestroy(stream, new ERR_STREAM_UNSHIFT_AFTER_END_EVENT());else addChunk(stream, state, chunk, true);
+      } else if (state.ended) {
+        errorOrDestroy(stream, new ERR_STREAM_PUSH_AFTER_EOF());
+      } else if (state.destroyed) {
+        return false;
+      } else {
+        state.reading = false;
+
+        if (state.decoder && !encoding) {
+          chunk = state.decoder.write(chunk);
+          if (state.objectMode || chunk.length !== 0) addChunk(stream, state, chunk, false);else maybeReadMore(stream, state);
+        } else {
+          addChunk(stream, state, chunk, false);
+        }
       }
-      return new Range(this.value, options).test(comp.semver)
+    } else if (!addToFront) {
+      state.reading = false;
+      maybeReadMore(stream, state);
     }
+  } // We can push more data if we are below the highWaterMark.
+  // Also, if we have no data yet, we can stand some more bytes.
+  // This is to work around cases where hwm=0, such as the repl.
 
-    const sameDirectionIncreasing =
-      (this.operator === '>=' || this.operator === '>') &&
-      (comp.operator === '>=' || comp.operator === '>')
-    const sameDirectionDecreasing =
-      (this.operator === '<=' || this.operator === '<') &&
-      (comp.operator === '<=' || comp.operator === '<')
-    const sameSemVer = this.semver.version === comp.semver.version
-    const differentDirectionsInclusive =
-      (this.operator === '>=' || this.operator === '<=') &&
-      (comp.operator === '>=' || comp.operator === '<=')
-    const oppositeDirectionsLessThan =
-      cmp(this.semver, '<', comp.semver, options) &&
-      (this.operator === '>=' || this.operator === '>') &&
-        (comp.operator === '<=' || comp.operator === '<')
-    const oppositeDirectionsGreaterThan =
-      cmp(this.semver, '>', comp.semver, options) &&
-      (this.operator === '<=' || this.operator === '<') &&
-        (comp.operator === '>=' || comp.operator === '>')
 
-    return (
-      sameDirectionIncreasing ||
-      sameDirectionDecreasing ||
-      (sameSemVer && differentDirectionsInclusive) ||
-      oppositeDirectionsLessThan ||
-      oppositeDirectionsGreaterThan
-    )
+  return !state.ended && (state.length < state.highWaterMark || state.length === 0);
+}
+
+function addChunk(stream, state, chunk, addToFront) {
+  if (state.flowing && state.length === 0 && !state.sync) {
+    state.awaitDrain = 0;
+    stream.emit('data', chunk);
+  } else {
+    // update the buffer info.
+    state.length += state.objectMode ? 1 : chunk.length;
+    if (addToFront) state.buffer.unshift(chunk);else state.buffer.push(chunk);
+    if (state.needReadable) emitReadable(stream);
   }
+
+  maybeReadMore(stream, state);
 }
 
-module.exports = Comparator
+function chunkInvalid(state, chunk) {
+  var er;
 
-const parseOptions = __nccwpck_require__(84615)
-const {re, t} = __nccwpck_require__(69493)
-const cmp = __nccwpck_require__(21292)
-const debug = __nccwpck_require__(96839)
-const SemVer = __nccwpck_require__(21098)
-const Range = __nccwpck_require__(39378)
+  if (!_isUint8Array(chunk) && typeof chunk !== 'string' && chunk !== undefined && !state.objectMode) {
+    er = new ERR_INVALID_ARG_TYPE('chunk', ['string', 'Buffer', 'Uint8Array'], chunk);
+  }
 
+  return er;
+}
 
-/***/ }),
+Readable.prototype.isPaused = function () {
+  return this._readableState.flowing === false;
+}; // backwards compatibility.
 
-/***/ 39378:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
-// hoisted class for cyclic dependency
-class Range {
-  constructor (range, options) {
-    options = parseOptions(options)
+Readable.prototype.setEncoding = function (enc) {
+  if (!StringDecoder) StringDecoder = (__nccwpck_require__(59868)/* .StringDecoder */ .s);
+  var decoder = new StringDecoder(enc);
+  this._readableState.decoder = decoder; // If setEncoding(null), decoder.encoding equals utf8
 
-    if (range instanceof Range) {
-      if (
-        range.loose === !!options.loose &&
-        range.includePrerelease === !!options.includePrerelease
-      ) {
-        return range
-      } else {
-        return new Range(range.raw, options)
-      }
-    }
+  this._readableState.encoding = this._readableState.decoder.encoding; // Iterate over current buffer to convert already stored Buffers:
 
-    if (range instanceof Comparator) {
-      // just put it in the set and return
-      this.raw = range.value
-      this.set = [[range]]
-      this.format()
-      return this
-    }
+  var p = this._readableState.buffer.head;
+  var content = '';
 
-    this.options = options
-    this.loose = !!options.loose
-    this.includePrerelease = !!options.includePrerelease
+  while (p !== null) {
+    content += decoder.write(p.data);
+    p = p.next;
+  }
 
-    // First, split based on boolean or ||
-    this.raw = range
-    this.set = range
-      .split(/\s*\|\|\s*/)
-      // map the range to a 2d array of comparators
-      .map(range => this.parseRange(range.trim()))
-      // throw out any comparator lists that are empty
-      // this generally means that it was not a valid range, which is allowed
-      // in loose mode, but will still throw if the WHOLE range is invalid.
-      .filter(c => c.length)
+  this._readableState.buffer.clear();
 
-    if (!this.set.length) {
-      throw new TypeError(`Invalid SemVer Range: ${range}`)
-    }
+  if (content !== '') this._readableState.buffer.push(content);
+  this._readableState.length = content.length;
+  return this;
+}; // Don't raise the hwm > 1GB
 
-    // if we have any that are not the null set, throw out null sets.
-    if (this.set.length > 1) {
-      // keep the first one, in case they're all null sets
-      const first = this.set[0]
-      this.set = this.set.filter(c => !isNullSet(c[0]))
-      if (this.set.length === 0)
-        this.set = [first]
-      else if (this.set.length > 1) {
-        // if we have any that are *, then the range is just *
-        for (const c of this.set) {
-          if (c.length === 1 && isAny(c[0])) {
-            this.set = [c]
-            break
-          }
-        }
-      }
-    }
 
-    this.format()
-  }
+var MAX_HWM = 0x40000000;
 
-  format () {
-    this.range = this.set
-      .map((comps) => {
-        return comps.join(' ').trim()
-      })
-      .join('||')
-      .trim()
-    return this.range
+function computeNewHighWaterMark(n) {
+  if (n >= MAX_HWM) {
+    // TODO(ronag): Throw ERR_VALUE_OUT_OF_RANGE.
+    n = MAX_HWM;
+  } else {
+    // Get the next highest power of 2 to prevent increasing hwm excessively in
+    // tiny amounts
+    n--;
+    n |= n >>> 1;
+    n |= n >>> 2;
+    n |= n >>> 4;
+    n |= n >>> 8;
+    n |= n >>> 16;
+    n++;
   }
 
-  toString () {
-    return this.range
-  }
+  return n;
+} // This function is designed to be inlinable, so please take care when making
+// changes to the function body.
 
-  parseRange (range) {
-    range = range.trim()
 
-    // memoize range parsing for performance.
-    // this is a very hot path, and fully deterministic.
-    const memoOpts = Object.keys(this.options).join(',')
-    const memoKey = `parseRange:${memoOpts}:${range}`
-    const cached = cache.get(memoKey)
-    if (cached)
-      return cached
+function howMuchToRead(n, state) {
+  if (n <= 0 || state.length === 0 && state.ended) return 0;
+  if (state.objectMode) return 1;
 
-    const loose = this.options.loose
-    // `1.2.3 - 1.2.4` => `>=1.2.3 <=1.2.4`
-    const hr = loose ? re[t.HYPHENRANGELOOSE] : re[t.HYPHENRANGE]
-    range = range.replace(hr, hyphenReplace(this.options.includePrerelease))
-    debug('hyphen replace', range)
-    // `> 1.2.3 < 1.2.5` => `>1.2.3 <1.2.5`
-    range = range.replace(re[t.COMPARATORTRIM], comparatorTrimReplace)
-    debug('comparator trim', range, re[t.COMPARATORTRIM])
+  if (n !== n) {
+    // Only flow one buffer at a time
+    if (state.flowing && state.length) return state.buffer.head.data.length;else return state.length;
+  } // If we're asking for more than the current hwm, then raise the hwm.
 
-    // `~ 1.2.3` => `~1.2.3`
-    range = range.replace(re[t.TILDETRIM], tildeTrimReplace)
 
-    // `^ 1.2.3` => `^1.2.3`
-    range = range.replace(re[t.CARETTRIM], caretTrimReplace)
+  if (n > state.highWaterMark) state.highWaterMark = computeNewHighWaterMark(n);
+  if (n <= state.length) return n; // Don't have enough
 
-    // normalize spaces
-    range = range.split(/\s+/).join(' ')
+  if (!state.ended) {
+    state.needReadable = true;
+    return 0;
+  }
 
-    // At this point, the range is completely trimmed and
-    // ready to be split into comparators.
+  return state.length;
+} // you can override either this method, or the async _read(n) below.
 
-    const compRe = loose ? re[t.COMPARATORLOOSE] : re[t.COMPARATOR]
-    const rangeList = range
-      .split(' ')
-      .map(comp => parseComparator(comp, this.options))
-      .join(' ')
-      .split(/\s+/)
-      // >=0.0.0 is equivalent to *
-      .map(comp => replaceGTE0(comp, this.options))
-      // in loose mode, throw out any that are not valid comparators
-      .filter(this.options.loose ? comp => !!comp.match(compRe) : () => true)
-      .map(comp => new Comparator(comp, this.options))
 
-    // if any comparators are the null set, then replace with JUST null set
-    // if more than one comparator, remove any * comparators
-    // also, don't include the same comparator more than once
-    const l = rangeList.length
-    const rangeMap = new Map()
-    for (const comp of rangeList) {
-      if (isNullSet(comp))
-        return [comp]
-      rangeMap.set(comp.value, comp)
-    }
-    if (rangeMap.size > 1 && rangeMap.has(''))
-      rangeMap.delete('')
+Readable.prototype.read = function (n) {
+  debug('read', n);
+  n = parseInt(n, 10);
+  var state = this._readableState;
+  var nOrig = n;
+  if (n !== 0) state.emittedReadable = false; // if we're doing read(0) to trigger a readable event, but we
+  // already have a bunch of data in the buffer, then just trigger
+  // the 'readable' event and move on.
 
-    const result = [...rangeMap.values()]
-    cache.set(memoKey, result)
-    return result
+  if (n === 0 && state.needReadable && ((state.highWaterMark !== 0 ? state.length >= state.highWaterMark : state.length > 0) || state.ended)) {
+    debug('read: emitReadable', state.length, state.ended);
+    if (state.length === 0 && state.ended) endReadable(this);else emitReadable(this);
+    return null;
   }
 
-  intersects (range, options) {
-    if (!(range instanceof Range)) {
-      throw new TypeError('a Range is required')
-    }
-
-    return this.set.some((thisComparators) => {
-      return (
-        isSatisfiable(thisComparators, options) &&
-        range.set.some((rangeComparators) => {
-          return (
-            isSatisfiable(rangeComparators, options) &&
-            thisComparators.every((thisComparator) => {
-              return rangeComparators.every((rangeComparator) => {
-                return thisComparator.intersects(rangeComparator, options)
-              })
-            })
-          )
-        })
-      )
-    })
-  }
+  n = howMuchToRead(n, state); // if we've ended, and we're now clear, then finish it up.
 
-  // if ANY of the sets match ALL of its comparators, then pass
-  test (version) {
-    if (!version) {
-      return false
-    }
-
-    if (typeof version === 'string') {
-      try {
-        version = new SemVer(version, this.options)
-      } catch (er) {
-        return false
-      }
-    }
+  if (n === 0 && state.ended) {
+    if (state.length === 0) endReadable(this);
+    return null;
+  } // All the actual chunk generation logic needs to be
+  // *below* the call to _read.  The reason is that in certain
+  // synthetic stream cases, such as passthrough streams, _read
+  // may be a completely synchronous operation which may change
+  // the state of the read buffer, providing enough data when
+  // before there was *not* enough.
+  //
+  // So, the steps are:
+  // 1. Figure out what the state of things will be after we do
+  // a read from the buffer.
+  //
+  // 2. If that resulting state will trigger a _read, then call _read.
+  // Note that this may be asynchronous, or synchronous.  Yes, it is
+  // deeply ugly to write APIs this way, but that still doesn't mean
+  // that the Readable class should behave improperly, as streams are
+  // designed to be sync/async agnostic.
+  // Take note if the _read call is sync or async (ie, if the read call
+  // has returned yet), so that we know whether or not it's safe to emit
+  // 'readable' etc.
+  //
+  // 3. Actually pull the requested chunks out of the buffer and return.
+  // if we need a readable event, then we need to do some reading.
 
-    for (let i = 0; i < this.set.length; i++) {
-      if (testSet(this.set[i], version, this.options)) {
-        return true
-      }
-    }
-    return false
-  }
-}
-module.exports = Range
 
-const LRU = __nccwpck_require__(83617)
-const cache = new LRU({ max: 1000 })
+  var doRead = state.needReadable;
+  debug('need readable', doRead); // if we currently have less than the highWaterMark, then also read some
 
-const parseOptions = __nccwpck_require__(84615)
-const Comparator = __nccwpck_require__(32272)
-const debug = __nccwpck_require__(96839)
-const SemVer = __nccwpck_require__(21098)
-const {
-  re,
-  t,
-  comparatorTrimReplace,
-  tildeTrimReplace,
-  caretTrimReplace
-} = __nccwpck_require__(69493)
+  if (state.length === 0 || state.length - n < state.highWaterMark) {
+    doRead = true;
+    debug('length less than watermark', doRead);
+  } // however, if we've ended, then there's no point, and if we're already
+  // reading, then it's unnecessary.
 
-const isNullSet = c => c.value === '<0.0.0-0'
-const isAny = c => c.value === ''
 
-// take a set of comparators and determine whether there
-// exists a version which can satisfy it
-const isSatisfiable = (comparators, options) => {
-  let result = true
-  const remainingComparators = comparators.slice()
-  let testComparator = remainingComparators.pop()
+  if (state.ended || state.reading) {
+    doRead = false;
+    debug('reading or ended', doRead);
+  } else if (doRead) {
+    debug('do read');
+    state.reading = true;
+    state.sync = true; // if the length is currently zero, then we *need* a readable event.
 
-  while (result && remainingComparators.length) {
-    result = remainingComparators.every((otherComparator) => {
-      return testComparator.intersects(otherComparator, options)
-    })
+    if (state.length === 0) state.needReadable = true; // call internal read method
 
-    testComparator = remainingComparators.pop()
-  }
+    this._read(state.highWaterMark);
 
-  return result
-}
+    state.sync = false; // If _read pushed data synchronously, then `reading` will be false,
+    // and we need to re-evaluate how much data we can return to the user.
 
-// comprised of xranges, tildes, stars, and gtlt's at this point.
-// already replaced the hyphen ranges
-// turn into a set of JUST comparators.
-const parseComparator = (comp, options) => {
-  debug('comp', comp, options)
-  comp = replaceCarets(comp, options)
-  debug('caret', comp)
-  comp = replaceTildes(comp, options)
-  debug('tildes', comp)
-  comp = replaceXRanges(comp, options)
-  debug('xrange', comp)
-  comp = replaceStars(comp, options)
-  debug('stars', comp)
-  return comp
-}
+    if (!state.reading) n = howMuchToRead(nOrig, state);
+  }
 
-const isX = id => !id || id.toLowerCase() === 'x' || id === '*'
+  var ret;
+  if (n > 0) ret = fromList(n, state);else ret = null;
 
-// ~, ~> --> * (any, kinda silly)
-// ~2, ~2.x, ~2.x.x, ~>2, ~>2.x ~>2.x.x --> >=2.0.0 <3.0.0-0
-// ~2.0, ~2.0.x, ~>2.0, ~>2.0.x --> >=2.0.0 <2.1.0-0
-// ~1.2, ~1.2.x, ~>1.2, ~>1.2.x --> >=1.2.0 <1.3.0-0
-// ~1.2.3, ~>1.2.3 --> >=1.2.3 <1.3.0-0
-// ~1.2.0, ~>1.2.0 --> >=1.2.0 <1.3.0-0
-const replaceTildes = (comp, options) =>
-  comp.trim().split(/\s+/).map((comp) => {
-    return replaceTilde(comp, options)
-  }).join(' ')
+  if (ret === null) {
+    state.needReadable = state.length <= state.highWaterMark;
+    n = 0;
+  } else {
+    state.length -= n;
+    state.awaitDrain = 0;
+  }
 
-const replaceTilde = (comp, options) => {
-  const r = options.loose ? re[t.TILDELOOSE] : re[t.TILDE]
-  return comp.replace(r, (_, M, m, p, pr) => {
-    debug('tilde', comp, _, M, m, p, pr)
-    let ret
+  if (state.length === 0) {
+    // If we have nothing in the buffer, then we want to know
+    // as soon as we *do* get something into the buffer.
+    if (!state.ended) state.needReadable = true; // If we tried to read() past the EOF, then emit end on the next tick.
 
-    if (isX(M)) {
-      ret = ''
-    } else if (isX(m)) {
-      ret = `>=${M}.0.0 <${+M + 1}.0.0-0`
-    } else if (isX(p)) {
-      // ~1.2 == >=1.2.0 <1.3.0-0
-      ret = `>=${M}.${m}.0 <${M}.${+m + 1}.0-0`
-    } else if (pr) {
-      debug('replaceTilde pr', pr)
-      ret = `>=${M}.${m}.${p}-${pr
-      } <${M}.${+m + 1}.0-0`
-    } else {
-      // ~1.2.3 == >=1.2.3 <1.3.0-0
-      ret = `>=${M}.${m}.${p
-      } <${M}.${+m + 1}.0-0`
-    }
+    if (nOrig !== n && state.ended) endReadable(this);
+  }
 
-    debug('tilde return', ret)
-    return ret
-  })
-}
+  if (ret !== null) this.emit('data', ret);
+  return ret;
+};
 
-// ^ --> * (any, kinda silly)
-// ^2, ^2.x, ^2.x.x --> >=2.0.0 <3.0.0-0
-// ^2.0, ^2.0.x --> >=2.0.0 <3.0.0-0
-// ^1.2, ^1.2.x --> >=1.2.0 <2.0.0-0
-// ^1.2.3 --> >=1.2.3 <2.0.0-0
-// ^1.2.0 --> >=1.2.0 <2.0.0-0
-const replaceCarets = (comp, options) =>
-  comp.trim().split(/\s+/).map((comp) => {
-    return replaceCaret(comp, options)
-  }).join(' ')
+function onEofChunk(stream, state) {
+  debug('onEofChunk');
+  if (state.ended) return;
 
-const replaceCaret = (comp, options) => {
-  debug('caret', comp, options)
-  const r = options.loose ? re[t.CARETLOOSE] : re[t.CARET]
-  const z = options.includePrerelease ? '-0' : ''
-  return comp.replace(r, (_, M, m, p, pr) => {
-    debug('caret', comp, _, M, m, p, pr)
-    let ret
+  if (state.decoder) {
+    var chunk = state.decoder.end();
 
-    if (isX(M)) {
-      ret = ''
-    } else if (isX(m)) {
-      ret = `>=${M}.0.0${z} <${+M + 1}.0.0-0`
-    } else if (isX(p)) {
-      if (M === '0') {
-        ret = `>=${M}.${m}.0${z} <${M}.${+m + 1}.0-0`
-      } else {
-        ret = `>=${M}.${m}.0${z} <${+M + 1}.0.0-0`
-      }
-    } else if (pr) {
-      debug('replaceCaret pr', pr)
-      if (M === '0') {
-        if (m === '0') {
-          ret = `>=${M}.${m}.${p}-${pr
-          } <${M}.${m}.${+p + 1}-0`
-        } else {
-          ret = `>=${M}.${m}.${p}-${pr
-          } <${M}.${+m + 1}.0-0`
-        }
-      } else {
-        ret = `>=${M}.${m}.${p}-${pr
-        } <${+M + 1}.0.0-0`
-      }
-    } else {
-      debug('no pr')
-      if (M === '0') {
-        if (m === '0') {
-          ret = `>=${M}.${m}.${p
-          }${z} <${M}.${m}.${+p + 1}-0`
-        } else {
-          ret = `>=${M}.${m}.${p
-          }${z} <${M}.${+m + 1}.0-0`
-        }
-      } else {
-        ret = `>=${M}.${m}.${p
-        } <${+M + 1}.0.0-0`
-      }
+    if (chunk && chunk.length) {
+      state.buffer.push(chunk);
+      state.length += state.objectMode ? 1 : chunk.length;
     }
+  }
 
-    debug('caret return', ret)
-    return ret
-  })
-}
-
-const replaceXRanges = (comp, options) => {
-  debug('replaceXRanges', comp, options)
-  return comp.split(/\s+/).map((comp) => {
-    return replaceXRange(comp, options)
-  }).join(' ')
-}
+  state.ended = true;
 
-const replaceXRange = (comp, options) => {
-  comp = comp.trim()
-  const r = options.loose ? re[t.XRANGELOOSE] : re[t.XRANGE]
-  return comp.replace(r, (ret, gtlt, M, m, p, pr) => {
-    debug('xRange', comp, ret, gtlt, M, m, p, pr)
-    const xM = isX(M)
-    const xm = xM || isX(m)
-    const xp = xm || isX(p)
-    const anyX = xp
+  if (state.sync) {
+    // if we are sync, wait until next tick to emit the data.
+    // Otherwise we risk emitting data in the flow()
+    // the readable code triggers during a read() call
+    emitReadable(stream);
+  } else {
+    // emit 'readable' now to make sure it gets picked up.
+    state.needReadable = false;
 
-    if (gtlt === '=' && anyX) {
-      gtlt = ''
+    if (!state.emittedReadable) {
+      state.emittedReadable = true;
+      emitReadable_(stream);
     }
+  }
+} // Don't emit readable right away in sync mode, because this can trigger
+// another read() call => stack overflow.  This way, it might trigger
+// a nextTick recursion warning, but that's not so bad.
 
-    // if we're including prereleases in the match, then we need
-    // to fix this to -0, the lowest possible prerelease value
-    pr = options.includePrerelease ? '-0' : ''
-
-    if (xM) {
-      if (gtlt === '>' || gtlt === '<') {
-        // nothing is allowed
-        ret = '<0.0.0-0'
-      } else {
-        // nothing is forbidden
-        ret = '*'
-      }
-    } else if (gtlt && anyX) {
-      // we know patch is an x, because we have any x at all.
-      // replace X with 0
-      if (xm) {
-        m = 0
-      }
-      p = 0
-
-      if (gtlt === '>') {
-        // >1 => >=2.0.0
-        // >1.2 => >=1.3.0
-        gtlt = '>='
-        if (xm) {
-          M = +M + 1
-          m = 0
-          p = 0
-        } else {
-          m = +m + 1
-          p = 0
-        }
-      } else if (gtlt === '<=') {
-        // <=0.7.x is actually <0.8.0, since any 0.7.x should
-        // pass.  Similarly, <=7.x is actually <8.0.0, etc.
-        gtlt = '<'
-        if (xm) {
-          M = +M + 1
-        } else {
-          m = +m + 1
-        }
-      }
 
-      if (gtlt === '<')
-        pr = '-0'
+function emitReadable(stream) {
+  var state = stream._readableState;
+  debug('emitReadable', state.needReadable, state.emittedReadable);
+  state.needReadable = false;
 
-      ret = `${gtlt + M}.${m}.${p}${pr}`
-    } else if (xm) {
-      ret = `>=${M}.0.0${pr} <${+M + 1}.0.0-0`
-    } else if (xp) {
-      ret = `>=${M}.${m}.0${pr
-      } <${M}.${+m + 1}.0-0`
-    }
+  if (!state.emittedReadable) {
+    debug('emitReadable', state.flowing);
+    state.emittedReadable = true;
+    process.nextTick(emitReadable_, stream);
+  }
+}
 
-    debug('xRange return', ret)
+function emitReadable_(stream) {
+  var state = stream._readableState;
+  debug('emitReadable_', state.destroyed, state.length, state.ended);
 
-    return ret
-  })
-}
+  if (!state.destroyed && (state.length || state.ended)) {
+    stream.emit('readable');
+    state.emittedReadable = false;
+  } // The stream needs another readable event if
+  // 1. It is not flowing, as the flow mechanism will take
+  //    care of it.
+  // 2. It is not ended.
+  // 3. It is below the highWaterMark, so we can schedule
+  //    another readable later.
 
-// Because * is AND-ed with everything else in the comparator,
-// and '' means "any version", just remove the *s entirely.
-const replaceStars = (comp, options) => {
-  debug('replaceStars', comp, options)
-  // Looseness is ignored here.  star is always as loose as it gets!
-  return comp.trim().replace(re[t.STAR], '')
-}
 
-const replaceGTE0 = (comp, options) => {
-  debug('replaceGTE0', comp, options)
-  return comp.trim()
-    .replace(re[options.includePrerelease ? t.GTE0PRE : t.GTE0], '')
-}
+  state.needReadable = !state.flowing && !state.ended && state.length <= state.highWaterMark;
+  flow(stream);
+} // at this point, the user has presumably seen the 'readable' event,
+// and called read() to consume some data.  that may have triggered
+// in turn another _read(n) call, in which case reading = true if
+// it's in progress.
+// However, if we're not ended, or reading, and the length < hwm,
+// then go ahead and try to read some more preemptively.
 
-// This function is passed to string.replace(re[t.HYPHENRANGE])
-// M, m, patch, prerelease, build
-// 1.2 - 3.4.5 => >=1.2.0 <=3.4.5
-// 1.2.3 - 3.4 => >=1.2.0 <3.5.0-0 Any 3.4.x will do
-// 1.2 - 3.4 => >=1.2.0 <3.5.0-0
-const hyphenReplace = incPr => ($0,
-  from, fM, fm, fp, fpr, fb,
-  to, tM, tm, tp, tpr, tb) => {
-  if (isX(fM)) {
-    from = ''
-  } else if (isX(fm)) {
-    from = `>=${fM}.0.0${incPr ? '-0' : ''}`
-  } else if (isX(fp)) {
-    from = `>=${fM}.${fm}.0${incPr ? '-0' : ''}`
-  } else if (fpr) {
-    from = `>=${from}`
-  } else {
-    from = `>=${from}${incPr ? '-0' : ''}`
-  }
 
-  if (isX(tM)) {
-    to = ''
-  } else if (isX(tm)) {
-    to = `<${+tM + 1}.0.0-0`
-  } else if (isX(tp)) {
-    to = `<${tM}.${+tm + 1}.0-0`
-  } else if (tpr) {
-    to = `<=${tM}.${tm}.${tp}-${tpr}`
-  } else if (incPr) {
-    to = `<${tM}.${tm}.${+tp + 1}-0`
-  } else {
-    to = `<=${to}`
+function maybeReadMore(stream, state) {
+  if (!state.readingMore) {
+    state.readingMore = true;
+    process.nextTick(maybeReadMore_, stream, state);
   }
-
-  return (`${from} ${to}`).trim()
 }
 
-const testSet = (set, version, options) => {
-  for (let i = 0; i < set.length; i++) {
-    if (!set[i].test(version)) {
-      return false
-    }
+function maybeReadMore_(stream, state) {
+  // Attempt to read more data if we should.
+  //
+  // The conditions for reading more data are (one of):
+  // - Not enough data buffered (state.length < state.highWaterMark). The loop
+  //   is responsible for filling the buffer with enough data if such data
+  //   is available. If highWaterMark is 0 and we are not in the flowing mode
+  //   we should _not_ attempt to buffer any extra data. We'll get more data
+  //   when the stream consumer calls read() instead.
+  // - No data in the buffer, and the stream is in flowing mode. In this mode
+  //   the loop below is responsible for ensuring read() is called. Failing to
+  //   call read here would abort the flow and there's no other mechanism for
+  //   continuing the flow if the stream consumer has just subscribed to the
+  //   'data' event.
+  //
+  // In addition to the above conditions to keep reading data, the following
+  // conditions prevent the data from being read:
+  // - The stream has ended (state.ended).
+  // - There is already a pending 'read' operation (state.reading). This is a
+  //   case where the the stream has called the implementation defined _read()
+  //   method, but they are processing the call asynchronously and have _not_
+  //   called push() with new data. In this case we skip performing more
+  //   read()s. The execution ends in this method again after the _read() ends
+  //   up calling push() with more data.
+  while (!state.reading && !state.ended && (state.length < state.highWaterMark || state.flowing && state.length === 0)) {
+    var len = state.length;
+    debug('maybeReadMore read 0');
+    stream.read(0);
+    if (len === state.length) // didn't get any data, stop spinning.
+      break;
   }
 
-  if (version.prerelease.length && !options.includePrerelease) {
-    // Find the set of versions that are allowed to have prereleases
-    // For example, ^1.2.3-pr.1 desugars to >=1.2.3-pr.1 <2.0.0
-    // That should allow `1.2.3-pr.2` to pass.
-    // However, `1.2.4-alpha.notready` should NOT be allowed,
-    // even though it's within the range set by the comparators.
-    for (let i = 0; i < set.length; i++) {
-      debug(set[i].semver)
-      if (set[i].semver === Comparator.ANY) {
-        continue
-      }
+  state.readingMore = false;
+} // abstract method.  to be overridden in specific implementation classes.
+// call cb(er, data) where data is <= n in length.
+// for virtual (non-string, non-buffer) streams, "length" is somewhat
+// arbitrary, and perhaps not very meaningful.
 
-      if (set[i].semver.prerelease.length > 0) {
-        const allowed = set[i].semver
-        if (allowed.major === version.major &&
-            allowed.minor === version.minor &&
-            allowed.patch === version.patch) {
-          return true
-        }
-      }
-    }
 
-    // Version has a -pre, but it's not one of the ones we like.
-    return false
-  }
+Readable.prototype._read = function (n) {
+  errorOrDestroy(this, new ERR_METHOD_NOT_IMPLEMENTED('_read()'));
+};
 
-  return true
-}
+Readable.prototype.pipe = function (dest, pipeOpts) {
+  var src = this;
+  var state = this._readableState;
 
+  switch (state.pipesCount) {
+    case 0:
+      state.pipes = dest;
+      break;
 
-/***/ }),
+    case 1:
+      state.pipes = [state.pipes, dest];
+      break;
 
-/***/ 21098:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+    default:
+      state.pipes.push(dest);
+      break;
+  }
 
-const debug = __nccwpck_require__(96839)
-const { MAX_LENGTH, MAX_SAFE_INTEGER } = __nccwpck_require__(76930)
-const { re, t } = __nccwpck_require__(69493)
+  state.pipesCount += 1;
+  debug('pipe count=%d opts=%j', state.pipesCount, pipeOpts);
+  var doEnd = (!pipeOpts || pipeOpts.end !== false) && dest !== process.stdout && dest !== process.stderr;
+  var endFn = doEnd ? onend : unpipe;
+  if (state.endEmitted) process.nextTick(endFn);else src.once('end', endFn);
+  dest.on('unpipe', onunpipe);
 
-const parseOptions = __nccwpck_require__(84615)
-const { compareIdentifiers } = __nccwpck_require__(17665)
-class SemVer {
-  constructor (version, options) {
-    options = parseOptions(options)
+  function onunpipe(readable, unpipeInfo) {
+    debug('onunpipe');
 
-    if (version instanceof SemVer) {
-      if (version.loose === !!options.loose &&
-          version.includePrerelease === !!options.includePrerelease) {
-        return version
-      } else {
-        version = version.version
+    if (readable === src) {
+      if (unpipeInfo && unpipeInfo.hasUnpiped === false) {
+        unpipeInfo.hasUnpiped = true;
+        cleanup();
       }
-    } else if (typeof version !== 'string') {
-      throw new TypeError(`Invalid Version: ${version}`)
     }
+  }
 
-    if (version.length > MAX_LENGTH) {
-      throw new TypeError(
-        `version is longer than ${MAX_LENGTH} characters`
-      )
-    }
+  function onend() {
+    debug('onend');
+    dest.end();
+  } // when the dest drains, it reduces the awaitDrain counter
+  // on the source.  This would be more elegant with a .once()
+  // handler in flow(), but adding and removing repeatedly is
+  // too slow.
 
-    debug('SemVer', version, options)
-    this.options = options
-    this.loose = !!options.loose
-    // this isn't actually relevant for versions, but keep it so that we
-    // don't run into trouble passing this.options around.
-    this.includePrerelease = !!options.includePrerelease
 
-    const m = version.trim().match(options.loose ? re[t.LOOSE] : re[t.FULL])
+  var ondrain = pipeOnDrain(src);
+  dest.on('drain', ondrain);
+  var cleanedUp = false;
 
-    if (!m) {
-      throw new TypeError(`Invalid Version: ${version}`)
-    }
+  function cleanup() {
+    debug('cleanup'); // cleanup event handlers once the pipe is broken
 
-    this.raw = version
+    dest.removeListener('close', onclose);
+    dest.removeListener('finish', onfinish);
+    dest.removeListener('drain', ondrain);
+    dest.removeListener('error', onerror);
+    dest.removeListener('unpipe', onunpipe);
+    src.removeListener('end', onend);
+    src.removeListener('end', unpipe);
+    src.removeListener('data', ondata);
+    cleanedUp = true; // if the reader is waiting for a drain event from this
+    // specific writer, then it would cause it to never start
+    // flowing again.
+    // So, if this is awaiting a drain, then we just call it now.
+    // If we don't know, then assume that we are waiting for one.
 
-    // these are actually numbers
-    this.major = +m[1]
-    this.minor = +m[2]
-    this.patch = +m[3]
+    if (state.awaitDrain && (!dest._writableState || dest._writableState.needDrain)) ondrain();
+  }
 
-    if (this.major > MAX_SAFE_INTEGER || this.major < 0) {
-      throw new TypeError('Invalid major version')
-    }
+  src.on('data', ondata);
 
-    if (this.minor > MAX_SAFE_INTEGER || this.minor < 0) {
-      throw new TypeError('Invalid minor version')
-    }
+  function ondata(chunk) {
+    debug('ondata');
+    var ret = dest.write(chunk);
+    debug('dest.write', ret);
 
-    if (this.patch > MAX_SAFE_INTEGER || this.patch < 0) {
-      throw new TypeError('Invalid patch version')
-    }
+    if (ret === false) {
+      // If the user unpiped during `dest.write()`, it is possible
+      // to get stuck in a permanently paused state if that write
+      // also returned false.
+      // => Check whether `dest` is still a piping destination.
+      if ((state.pipesCount === 1 && state.pipes === dest || state.pipesCount > 1 && indexOf(state.pipes, dest) !== -1) && !cleanedUp) {
+        debug('false write response, pause', state.awaitDrain);
+        state.awaitDrain++;
+      }
 
-    // numberify any prerelease numeric ids
-    if (!m[4]) {
-      this.prerelease = []
-    } else {
-      this.prerelease = m[4].split('.').map((id) => {
-        if (/^[0-9]+$/.test(id)) {
-          const num = +id
-          if (num >= 0 && num < MAX_SAFE_INTEGER) {
-            return num
-          }
-        }
-        return id
-      })
+      src.pause();
     }
+  } // if the dest has an error, then stop piping into it.
+  // however, don't suppress the throwing behavior for this.
 
-    this.build = m[5] ? m[5].split('.') : []
-    this.format()
-  }
-
-  format () {
-    this.version = `${this.major}.${this.minor}.${this.patch}`
-    if (this.prerelease.length) {
-      this.version += `-${this.prerelease.join('.')}`
-    }
-    return this.version
-  }
 
-  toString () {
-    return this.version
-  }
+  function onerror(er) {
+    debug('onerror', er);
+    unpipe();
+    dest.removeListener('error', onerror);
+    if (EElistenerCount(dest, 'error') === 0) errorOrDestroy(dest, er);
+  } // Make sure our error handler is attached before userland ones.
 
-  compare (other) {
-    debug('SemVer.compare', this.version, this.options, other)
-    if (!(other instanceof SemVer)) {
-      if (typeof other === 'string' && other === this.version) {
-        return 0
-      }
-      other = new SemVer(other, this.options)
-    }
 
-    if (other.version === this.version) {
-      return 0
-    }
+  prependListener(dest, 'error', onerror); // Both close and finish should trigger unpipe, but only once.
 
-    return this.compareMain(other) || this.comparePre(other)
+  function onclose() {
+    dest.removeListener('finish', onfinish);
+    unpipe();
   }
 
-  compareMain (other) {
-    if (!(other instanceof SemVer)) {
-      other = new SemVer(other, this.options)
-    }
+  dest.once('close', onclose);
 
-    return (
-      compareIdentifiers(this.major, other.major) ||
-      compareIdentifiers(this.minor, other.minor) ||
-      compareIdentifiers(this.patch, other.patch)
-    )
+  function onfinish() {
+    debug('onfinish');
+    dest.removeListener('close', onclose);
+    unpipe();
   }
 
-  comparePre (other) {
-    if (!(other instanceof SemVer)) {
-      other = new SemVer(other, this.options)
-    }
+  dest.once('finish', onfinish);
 
-    // NOT having a prerelease is > having one
-    if (this.prerelease.length && !other.prerelease.length) {
-      return -1
-    } else if (!this.prerelease.length && other.prerelease.length) {
-      return 1
-    } else if (!this.prerelease.length && !other.prerelease.length) {
-      return 0
-    }
+  function unpipe() {
+    debug('unpipe');
+    src.unpipe(dest);
+  } // tell the dest that it's being piped to
 
-    let i = 0
-    do {
-      const a = this.prerelease[i]
-      const b = other.prerelease[i]
-      debug('prerelease compare', i, a, b)
-      if (a === undefined && b === undefined) {
-        return 0
-      } else if (b === undefined) {
-        return 1
-      } else if (a === undefined) {
-        return -1
-      } else if (a === b) {
-        continue
-      } else {
-        return compareIdentifiers(a, b)
-      }
-    } while (++i)
-  }
 
-  compareBuild (other) {
-    if (!(other instanceof SemVer)) {
-      other = new SemVer(other, this.options)
-    }
+  dest.emit('pipe', src); // start the flow if it hasn't been started already.
 
-    let i = 0
-    do {
-      const a = this.build[i]
-      const b = other.build[i]
-      debug('prerelease compare', i, a, b)
-      if (a === undefined && b === undefined) {
-        return 0
-      } else if (b === undefined) {
-        return 1
-      } else if (a === undefined) {
-        return -1
-      } else if (a === b) {
-        continue
-      } else {
-        return compareIdentifiers(a, b)
-      }
-    } while (++i)
+  if (!state.flowing) {
+    debug('pipe resume');
+    src.resume();
   }
 
-  // preminor will bump the version up to the next minor release, and immediately
-  // down to pre-release. premajor and prepatch work the same way.
-  inc (release, identifier) {
-    switch (release) {
-      case 'premajor':
-        this.prerelease.length = 0
-        this.patch = 0
-        this.minor = 0
-        this.major++
-        this.inc('pre', identifier)
-        break
-      case 'preminor':
-        this.prerelease.length = 0
-        this.patch = 0
-        this.minor++
-        this.inc('pre', identifier)
-        break
-      case 'prepatch':
-        // If this is already a prerelease, it will bump to the next version
-        // drop any prereleases that might already exist, since they are not
-        // relevant at this point.
-        this.prerelease.length = 0
-        this.inc('patch', identifier)
-        this.inc('pre', identifier)
-        break
-      // If the input is a non-prerelease version, this acts the same as
-      // prepatch.
-      case 'prerelease':
-        if (this.prerelease.length === 0) {
-          this.inc('patch', identifier)
-        }
-        this.inc('pre', identifier)
-        break
+  return dest;
+};
 
-      case 'major':
-        // If this is a pre-major version, bump up to the same major version.
-        // Otherwise increment major.
-        // 1.0.0-5 bumps to 1.0.0
-        // 1.1.0 bumps to 2.0.0
-        if (
-          this.minor !== 0 ||
-          this.patch !== 0 ||
-          this.prerelease.length === 0
-        ) {
-          this.major++
-        }
-        this.minor = 0
-        this.patch = 0
-        this.prerelease = []
-        break
-      case 'minor':
-        // If this is a pre-minor version, bump up to the same minor version.
-        // Otherwise increment minor.
-        // 1.2.0-5 bumps to 1.2.0
-        // 1.2.1 bumps to 1.3.0
-        if (this.patch !== 0 || this.prerelease.length === 0) {
-          this.minor++
-        }
-        this.patch = 0
-        this.prerelease = []
-        break
-      case 'patch':
-        // If this is not a pre-release version, it will increment the patch.
-        // If it is a pre-release it will bump up to the same patch version.
-        // 1.2.0-5 patches to 1.2.0
-        // 1.2.0 patches to 1.2.1
-        if (this.prerelease.length === 0) {
-          this.patch++
-        }
-        this.prerelease = []
-        break
-      // This probably shouldn't be used publicly.
-      // 1.0.0 'pre' would become 1.0.0-0 which is the wrong direction.
-      case 'pre':
-        if (this.prerelease.length === 0) {
-          this.prerelease = [0]
-        } else {
-          let i = this.prerelease.length
-          while (--i >= 0) {
-            if (typeof this.prerelease[i] === 'number') {
-              this.prerelease[i]++
-              i = -2
-            }
-          }
-          if (i === -1) {
-            // didn't increment anything
-            this.prerelease.push(0)
-          }
-        }
-        if (identifier) {
-          // 1.2.0-beta.1 bumps to 1.2.0-beta.2,
-          // 1.2.0-beta.fooblz or 1.2.0-beta bumps to 1.2.0-beta.0
-          if (this.prerelease[0] === identifier) {
-            if (isNaN(this.prerelease[1])) {
-              this.prerelease = [identifier, 0]
-            }
-          } else {
-            this.prerelease = [identifier, 0]
-          }
-        }
-        break
+function pipeOnDrain(src) {
+  return function pipeOnDrainFunctionResult() {
+    var state = src._readableState;
+    debug('pipeOnDrain', state.awaitDrain);
+    if (state.awaitDrain) state.awaitDrain--;
 
-      default:
-        throw new Error(`invalid increment argument: ${release}`)
+    if (state.awaitDrain === 0 && EElistenerCount(src, 'data')) {
+      state.flowing = true;
+      flow(src);
     }
-    this.format()
-    this.raw = this.version
-    return this
-  }
+  };
 }
 
-module.exports = SemVer
+Readable.prototype.unpipe = function (dest) {
+  var state = this._readableState;
+  var unpipeInfo = {
+    hasUnpiped: false
+  }; // if we're not piping anywhere, then do nothing.
 
+  if (state.pipesCount === 0) return this; // just one destination.  most common case.
 
-/***/ }),
+  if (state.pipesCount === 1) {
+    // passed in one, but it's not the right one.
+    if (dest && dest !== state.pipes) return this;
+    if (!dest) dest = state.pipes; // got a match.
 
-/***/ 87225:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+    state.pipes = null;
+    state.pipesCount = 0;
+    state.flowing = false;
+    if (dest) dest.emit('unpipe', this, unpipeInfo);
+    return this;
+  } // slow case. multiple pipe destinations.
 
-const parse = __nccwpck_require__(93863)
-const clean = (version, options) => {
-  const s = parse(version.trim().replace(/^[=v]+/, ''), options)
-  return s ? s.version : null
-}
-module.exports = clean
 
+  if (!dest) {
+    // remove all.
+    var dests = state.pipes;
+    var len = state.pipesCount;
+    state.pipes = null;
+    state.pipesCount = 0;
+    state.flowing = false;
 
-/***/ }),
+    for (var i = 0; i < len; i++) {
+      dests[i].emit('unpipe', this, {
+        hasUnpiped: false
+      });
+    }
 
-/***/ 21292:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+    return this;
+  } // try to find the right one.
 
-const eq = __nccwpck_require__(77477)
-const neq = __nccwpck_require__(18094)
-const gt = __nccwpck_require__(10609)
-const gte = __nccwpck_require__(52469)
-const lt = __nccwpck_require__(67703)
-const lte = __nccwpck_require__(84015)
 
-const cmp = (a, op, b, loose) => {
-  switch (op) {
-    case '===':
-      if (typeof a === 'object')
-        a = a.version
-      if (typeof b === 'object')
-        b = b.version
-      return a === b
+  var index = indexOf(state.pipes, dest);
+  if (index === -1) return this;
+  state.pipes.splice(index, 1);
+  state.pipesCount -= 1;
+  if (state.pipesCount === 1) state.pipes = state.pipes[0];
+  dest.emit('unpipe', this, unpipeInfo);
+  return this;
+}; // set up data events if they are asked for
+// Ensure readable listeners eventually get something
 
-    case '!==':
-      if (typeof a === 'object')
-        a = a.version
-      if (typeof b === 'object')
-        b = b.version
-      return a !== b
 
-    case '':
-    case '=':
-    case '==':
-      return eq(a, b, loose)
+Readable.prototype.on = function (ev, fn) {
+  var res = Stream.prototype.on.call(this, ev, fn);
+  var state = this._readableState;
 
-    case '!=':
-      return neq(a, b, loose)
+  if (ev === 'data') {
+    // update readableListening so that resume() may be a no-op
+    // a few lines down. This is needed to support once('readable').
+    state.readableListening = this.listenerCount('readable') > 0; // Try start flowing on next tick if stream isn't explicitly paused
 
-    case '>':
-      return gt(a, b, loose)
+    if (state.flowing !== false) this.resume();
+  } else if (ev === 'readable') {
+    if (!state.endEmitted && !state.readableListening) {
+      state.readableListening = state.needReadable = true;
+      state.flowing = false;
+      state.emittedReadable = false;
+      debug('on readable', state.length, state.reading);
 
-    case '>=':
-      return gte(a, b, loose)
+      if (state.length) {
+        emitReadable(this);
+      } else if (!state.reading) {
+        process.nextTick(nReadingNextTick, this);
+      }
+    }
+  }
 
-    case '<':
-      return lt(a, b, loose)
+  return res;
+};
 
-    case '<=':
-      return lte(a, b, loose)
+Readable.prototype.addListener = Readable.prototype.on;
 
-    default:
-      throw new TypeError(`Invalid operator: ${op}`)
+Readable.prototype.removeListener = function (ev, fn) {
+  var res = Stream.prototype.removeListener.call(this, ev, fn);
+
+  if (ev === 'readable') {
+    // We need to check if there is someone still listening to
+    // readable and reset the state. However this needs to happen
+    // after readable has been emitted but before I/O (nextTick) to
+    // support once('readable', fn) cycles. This means that calling
+    // resume within the same tick will have no
+    // effect.
+    process.nextTick(updateReadableListening, this);
   }
-}
-module.exports = cmp
 
+  return res;
+};
 
-/***/ }),
+Readable.prototype.removeAllListeners = function (ev) {
+  var res = Stream.prototype.removeAllListeners.apply(this, arguments);
 
-/***/ 77548:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+  if (ev === 'readable' || ev === undefined) {
+    // We need to check if there is someone still listening to
+    // readable and reset the state. However this needs to happen
+    // after readable has been emitted but before I/O (nextTick) to
+    // support once('readable', fn) cycles. This means that calling
+    // resume within the same tick will have no
+    // effect.
+    process.nextTick(updateReadableListening, this);
+  }
 
-const SemVer = __nccwpck_require__(21098)
-const parse = __nccwpck_require__(93863)
-const {re, t} = __nccwpck_require__(69493)
+  return res;
+};
 
-const coerce = (version, options) => {
-  if (version instanceof SemVer) {
-    return version
-  }
+function updateReadableListening(self) {
+  var state = self._readableState;
+  state.readableListening = self.listenerCount('readable') > 0;
 
-  if (typeof version === 'number') {
-    version = String(version)
+  if (state.resumeScheduled && !state.paused) {
+    // flowing needs to be set to true now, otherwise
+    // the upcoming resume will not flow.
+    state.flowing = true; // crude way to check if we should resume
+  } else if (self.listenerCount('data') > 0) {
+    self.resume();
   }
+}
 
-  if (typeof version !== 'string') {
-    return null
-  }
+function nReadingNextTick(self) {
+  debug('readable nexttick read 0');
+  self.read(0);
+} // pause() and resume() are remnants of the legacy readable stream API
+// If the user uses them, then switch into old mode.
 
-  options = options || {}
 
-  let match = null
-  if (!options.rtl) {
-    match = version.match(re[t.COERCE])
-  } else {
-    // Find the right-most coercible string that does not share
-    // a terminus with a more left-ward coercible string.
-    // Eg, '1.2.3.4' wants to coerce '2.3.4', not '3.4' or '4'
-    //
-    // Walk through the string checking with a /g regexp
-    // Manually set the index so as to pick up overlapping matches.
-    // Stop when we get a match that ends at the string end, since no
-    // coercible string can be more right-ward without the same terminus.
-    let next
-    while ((next = re[t.COERCERTL].exec(version)) &&
-        (!match || match.index + match[0].length !== version.length)
-    ) {
-      if (!match ||
-            next.index + next[0].length !== match.index + match[0].length) {
-        match = next
-      }
-      re[t.COERCERTL].lastIndex = next.index + next[1].length + next[2].length
-    }
-    // leave it in a clean state
-    re[t.COERCERTL].lastIndex = -1
+Readable.prototype.resume = function () {
+  var state = this._readableState;
+
+  if (!state.flowing) {
+    debug('resume'); // we flow only if there is no one listening
+    // for readable, but we still have to call
+    // resume()
+
+    state.flowing = !state.readableListening;
+    resume(this, state);
   }
 
-  if (match === null)
-    return null
+  state.paused = false;
+  return this;
+};
 
-  return parse(`${match[2]}.${match[3] || '0'}.${match[4] || '0'}`, options)
+function resume(stream, state) {
+  if (!state.resumeScheduled) {
+    state.resumeScheduled = true;
+    process.nextTick(resume_, stream, state);
+  }
 }
-module.exports = coerce
-
 
-/***/ }),
+function resume_(stream, state) {
+  debug('resume', state.reading);
 
-/***/ 17349:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+  if (!state.reading) {
+    stream.read(0);
+  }
 
-const SemVer = __nccwpck_require__(21098)
-const compareBuild = (a, b, loose) => {
-  const versionA = new SemVer(a, loose)
-  const versionB = new SemVer(b, loose)
-  return versionA.compare(versionB) || versionA.compareBuild(versionB)
+  state.resumeScheduled = false;
+  stream.emit('resume');
+  flow(stream);
+  if (state.flowing && !state.reading) stream.read(0);
 }
-module.exports = compareBuild
 
+Readable.prototype.pause = function () {
+  debug('call pause flowing=%j', this._readableState.flowing);
 
-/***/ }),
+  if (this._readableState.flowing !== false) {
+    debug('pause');
+    this._readableState.flowing = false;
+    this.emit('pause');
+  }
 
-/***/ 70310:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+  this._readableState.paused = true;
+  return this;
+};
 
-const compare = __nccwpck_require__(43234)
-const compareLoose = (a, b) => compare(a, b, true)
-module.exports = compareLoose
+function flow(stream) {
+  var state = stream._readableState;
+  debug('flow', state.flowing);
 
+  while (state.flowing && stream.read() !== null) {
+    ;
+  }
+} // wrap an old-style stream as the async data source.
+// This is *not* part of the readable stream interface.
+// It is an ugly unfortunate mess of history.
 
-/***/ }),
 
-/***/ 43234:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+Readable.prototype.wrap = function (stream) {
+  var _this = this;
 
-const SemVer = __nccwpck_require__(21098)
-const compare = (a, b, loose) =>
-  new SemVer(a, loose).compare(new SemVer(b, loose))
-
-module.exports = compare
+  var state = this._readableState;
+  var paused = false;
+  stream.on('end', function () {
+    debug('wrapped end');
 
+    if (state.decoder && !state.ended) {
+      var chunk = state.decoder.end();
+      if (chunk && chunk.length) _this.push(chunk);
+    }
 
-/***/ }),
+    _this.push(null);
+  });
+  stream.on('data', function (chunk) {
+    debug('wrapped data');
+    if (state.decoder) chunk = state.decoder.write(chunk); // don't skip over falsy values in objectMode
 
-/***/ 89313:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+    if (state.objectMode && (chunk === null || chunk === undefined)) return;else if (!state.objectMode && (!chunk || !chunk.length)) return;
 
-const parse = __nccwpck_require__(93863)
-const eq = __nccwpck_require__(77477)
+    var ret = _this.push(chunk);
 
-const diff = (version1, version2) => {
-  if (eq(version1, version2)) {
-    return null
-  } else {
-    const v1 = parse(version1)
-    const v2 = parse(version2)
-    const hasPre = v1.prerelease.length || v2.prerelease.length
-    const prefix = hasPre ? 'pre' : ''
-    const defaultResult = hasPre ? 'prerelease' : ''
-    for (const key in v1) {
-      if (key === 'major' || key === 'minor' || key === 'patch') {
-        if (v1[key] !== v2[key]) {
-          return prefix + key
-        }
-      }
+    if (!ret) {
+      paused = true;
+      stream.pause();
     }
-    return defaultResult // may be undefined
-  }
-}
-module.exports = diff
+  }); // proxy all the other methods.
+  // important when wrapping filters and duplexes.
 
+  for (var i in stream) {
+    if (this[i] === undefined && typeof stream[i] === 'function') {
+      this[i] = function methodWrap(method) {
+        return function methodWrapReturnFunction() {
+          return stream[method].apply(stream, arguments);
+        };
+      }(i);
+    }
+  } // proxy certain important events.
 
-/***/ }),
 
-/***/ 77477:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+  for (var n = 0; n < kProxyEvents.length; n++) {
+    stream.on(kProxyEvents[n], this.emit.bind(this, kProxyEvents[n]));
+  } // when we try to consume some more bytes, simply unpause the
+  // underlying stream.
 
-const compare = __nccwpck_require__(43234)
-const eq = (a, b, loose) => compare(a, b, loose) === 0
-module.exports = eq
 
+  this._read = function (n) {
+    debug('wrapped _read', n);
 
-/***/ }),
+    if (paused) {
+      paused = false;
+      stream.resume();
+    }
+  };
 
-/***/ 10609:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+  return this;
+};
 
-const compare = __nccwpck_require__(43234)
-const gt = (a, b, loose) => compare(a, b, loose) > 0
-module.exports = gt
+if (typeof Symbol === 'function') {
+  Readable.prototype[Symbol.asyncIterator] = function () {
+    if (createReadableStreamAsyncIterator === undefined) {
+      createReadableStreamAsyncIterator = __nccwpck_require__(51780);
+    }
 
+    return createReadableStreamAsyncIterator(this);
+  };
+}
 
-/***/ }),
+Object.defineProperty(Readable.prototype, 'readableHighWaterMark', {
+  // making it explicit this property is not enumerable
+  // because otherwise some prototype manipulation in
+  // userland will fail
+  enumerable: false,
+  get: function get() {
+    return this._readableState.highWaterMark;
+  }
+});
+Object.defineProperty(Readable.prototype, 'readableBuffer', {
+  // making it explicit this property is not enumerable
+  // because otherwise some prototype manipulation in
+  // userland will fail
+  enumerable: false,
+  get: function get() {
+    return this._readableState && this._readableState.buffer;
+  }
+});
+Object.defineProperty(Readable.prototype, 'readableFlowing', {
+  // making it explicit this property is not enumerable
+  // because otherwise some prototype manipulation in
+  // userland will fail
+  enumerable: false,
+  get: function get() {
+    return this._readableState.flowing;
+  },
+  set: function set(state) {
+    if (this._readableState) {
+      this._readableState.flowing = state;
+    }
+  }
+}); // exposed for testing purposes only.
 
-/***/ 52469:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+Readable._fromList = fromList;
+Object.defineProperty(Readable.prototype, 'readableLength', {
+  // making it explicit this property is not enumerable
+  // because otherwise some prototype manipulation in
+  // userland will fail
+  enumerable: false,
+  get: function get() {
+    return this._readableState.length;
+  }
+}); // Pluck off n bytes from an array of buffers.
+// Length is the combined lengths of all the buffers in the list.
+// This function is designed to be inlinable, so please take care when making
+// changes to the function body.
 
-const compare = __nccwpck_require__(43234)
-const gte = (a, b, loose) => compare(a, b, loose) >= 0
-module.exports = gte
+function fromList(n, state) {
+  // nothing buffered
+  if (state.length === 0) return null;
+  var ret;
+  if (state.objectMode) ret = state.buffer.shift();else if (!n || n >= state.length) {
+    // read it all, truncate the list
+    if (state.decoder) ret = state.buffer.join('');else if (state.buffer.length === 1) ret = state.buffer.first();else ret = state.buffer.concat(state.length);
+    state.buffer.clear();
+  } else {
+    // read part of list
+    ret = state.buffer.consume(n, state.decoder);
+  }
+  return ret;
+}
 
+function endReadable(stream) {
+  var state = stream._readableState;
+  debug('endReadable', state.endEmitted);
 
-/***/ }),
+  if (!state.endEmitted) {
+    state.ended = true;
+    process.nextTick(endReadableNT, state, stream);
+  }
+}
 
-/***/ 10243:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+function endReadableNT(state, stream) {
+  debug('endReadableNT', state.endEmitted, state.length); // Check that we didn't get one last unshift.
 
-const SemVer = __nccwpck_require__(21098)
+  if (!state.endEmitted && state.length === 0) {
+    state.endEmitted = true;
+    stream.readable = false;
+    stream.emit('end');
 
-const inc = (version, release, options, identifier) => {
-  if (typeof (options) === 'string') {
-    identifier = options
-    options = undefined
-  }
+    if (state.autoDestroy) {
+      // In case of duplex streams we need a way to detect
+      // if the writable side is ready for autoDestroy as well
+      var wState = stream._writableState;
 
-  try {
-    return new SemVer(version, options).inc(release, identifier).version
-  } catch (er) {
-    return null
+      if (!wState || wState.autoDestroy && wState.finished) {
+        stream.destroy();
+      }
+    }
   }
 }
-module.exports = inc
 
+if (typeof Symbol === 'function') {
+  Readable.from = function (iterable, opts) {
+    if (from === undefined) {
+      from = __nccwpck_require__(42881);
+    }
 
-/***/ }),
-
-/***/ 67703:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+    return from(Readable, iterable, opts);
+  };
+}
 
-const compare = __nccwpck_require__(43234)
-const lt = (a, b, loose) => compare(a, b, loose) < 0
-module.exports = lt
+function indexOf(xs, x) {
+  for (var i = 0, l = xs.length; i < l; i++) {
+    if (xs[i] === x) return i;
+  }
 
+  return -1;
+}
 
 /***/ }),
 
-/***/ 84015:
+/***/ 56765:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
-const compare = __nccwpck_require__(43234)
-const lte = (a, b, loose) => compare(a, b, loose) <= 0
-module.exports = lte
-
-
-/***/ }),
+"use strict";
+// Copyright Joyent, Inc. and other Node contributors.
+//
+// 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.
+// a transform stream is a readable/writable stream where you do
+// something with the data.  Sometimes it's called a "filter",
+// but that's not a great name for it, since that implies a thing where
+// some bits pass through, and others are simply ignored.  (That would
+// be a valid example of a transform, of course.)
+//
+// While the output is causally related to the input, it's not a
+// necessarily symmetric or synchronous transformation.  For example,
+// a zlib stream might take multiple plain-text writes(), and then
+// emit a single compressed chunk some time in the future.
+//
+// Here's how this works:
+//
+// The Transform stream has all the aspects of the readable and writable
+// stream classes.  When you write(chunk), that calls _write(chunk,cb)
+// internally, and returns false if there's a lot of pending writes
+// buffered up.  When you call read(), that calls _read(n) until
+// there's enough pending readable data buffered up.
+//
+// In a transform stream, the written data is placed in a buffer.  When
+// _read(n) is called, it transforms the queued up data, calling the
+// buffered _write cb's as it consumes chunks.  If consuming a single
+// written chunk would result in multiple output chunks, then the first
+// outputted bit calls the readcb, and subsequent chunks just go into
+// the read buffer, and will cause it to emit 'readable' if necessary.
+//
+// This way, back-pressure is actually determined by the reading side,
+// since _read has to be called to start processing a new chunk.  However,
+// a pathological inflate type of transform can cause excessive buffering
+// here.  For example, imagine a stream where every byte of input is
+// interpreted as an integer from 0-255, and then results in that many
+// bytes of output.  Writing the 4 bytes {ff,ff,ff,ff} would result in
+// 1kb of data being output.  In this case, you could write a very small
+// amount of input, and end up with a very large amount of output.  In
+// such a pathological inflating mechanism, there'd be no way to tell
+// the system to stop doing the transform.  A single 4MB write could
+// cause the system to run out of memory.
+//
+// However, even in such a pathological case, only a single written chunk
+// would be consumed, and then the rest would wait (un-transformed) until
+// the results of the previous transformed chunk were consumed.
 
-/***/ 8222:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
-const SemVer = __nccwpck_require__(21098)
-const major = (a, loose) => new SemVer(a, loose).major
-module.exports = major
+module.exports = Transform;
 
+var _require$codes = (__nccwpck_require__(90646)/* .codes */ .q),
+    ERR_METHOD_NOT_IMPLEMENTED = _require$codes.ERR_METHOD_NOT_IMPLEMENTED,
+    ERR_MULTIPLE_CALLBACK = _require$codes.ERR_MULTIPLE_CALLBACK,
+    ERR_TRANSFORM_ALREADY_TRANSFORMING = _require$codes.ERR_TRANSFORM_ALREADY_TRANSFORMING,
+    ERR_TRANSFORM_WITH_LENGTH_0 = _require$codes.ERR_TRANSFORM_WITH_LENGTH_0;
 
-/***/ }),
+var Duplex = __nccwpck_require__(97256);
 
-/***/ 8940:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+__nccwpck_require__(76401)(Transform, Duplex);
 
-const SemVer = __nccwpck_require__(21098)
-const minor = (a, loose) => new SemVer(a, loose).minor
-module.exports = minor
+function afterTransform(er, data) {
+  var ts = this._transformState;
+  ts.transforming = false;
+  var cb = ts.writecb;
 
+  if (cb === null) {
+    return this.emit('error', new ERR_MULTIPLE_CALLBACK());
+  }
 
-/***/ }),
+  ts.writechunk = null;
+  ts.writecb = null;
+  if (data != null) // single equals check for both `null` and `undefined`
+    this.push(data);
+  cb(er);
+  var rs = this._readableState;
+  rs.reading = false;
 
-/***/ 18094:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+  if (rs.needReadable || rs.length < rs.highWaterMark) {
+    this._read(rs.highWaterMark);
+  }
+}
 
-const compare = __nccwpck_require__(43234)
-const neq = (a, b, loose) => compare(a, b, loose) !== 0
-module.exports = neq
+function Transform(options) {
+  if (!(this instanceof Transform)) return new Transform(options);
+  Duplex.call(this, options);
+  this._transformState = {
+    afterTransform: afterTransform.bind(this),
+    needTransform: false,
+    transforming: false,
+    writecb: null,
+    writechunk: null,
+    writeencoding: null
+  }; // start out asking for a readable event once data is transformed.
 
+  this._readableState.needReadable = true; // we have implemented the _read method, and done the other things
+  // that Readable wants before the first _read call, so unset the
+  // sync guard flag.
 
-/***/ }),
+  this._readableState.sync = false;
 
-/***/ 93863:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+  if (options) {
+    if (typeof options.transform === 'function') this._transform = options.transform;
+    if (typeof options.flush === 'function') this._flush = options.flush;
+  } // When the writable side finishes, then flush out anything remaining.
 
-const {MAX_LENGTH} = __nccwpck_require__(76930)
-const { re, t } = __nccwpck_require__(69493)
-const SemVer = __nccwpck_require__(21098)
 
-const parseOptions = __nccwpck_require__(84615)
-const parse = (version, options) => {
-  options = parseOptions(options)
+  this.on('prefinish', prefinish);
+}
 
-  if (version instanceof SemVer) {
-    return version
-  }
+function prefinish() {
+  var _this = this;
 
-  if (typeof version !== 'string') {
-    return null
+  if (typeof this._flush === 'function' && !this._readableState.destroyed) {
+    this._flush(function (er, data) {
+      done(_this, er, data);
+    });
+  } else {
+    done(this, null, null);
   }
+}
 
-  if (version.length > MAX_LENGTH) {
-    return null
-  }
+Transform.prototype.push = function (chunk, encoding) {
+  this._transformState.needTransform = false;
+  return Duplex.prototype.push.call(this, chunk, encoding);
+}; // This is the part where you do stuff!
+// override this function in implementation classes.
+// 'chunk' is an input chunk.
+//
+// Call `push(newChunk)` to pass along transformed output
+// to the readable side.  You may call 'push' zero or more times.
+//
+// Call `cb(err)` when you are done with this chunk.  If you pass
+// an error, then that'll put the hurt on the whole operation.  If you
+// never call cb(), then you'll never get another chunk.
 
-  const r = options.loose ? re[t.LOOSE] : re[t.FULL]
-  if (!r.test(version)) {
-    return null
-  }
 
-  try {
-    return new SemVer(version, options)
-  } catch (er) {
-    return null
-  }
-}
+Transform.prototype._transform = function (chunk, encoding, cb) {
+  cb(new ERR_METHOD_NOT_IMPLEMENTED('_transform()'));
+};
 
-module.exports = parse
+Transform.prototype._write = function (chunk, encoding, cb) {
+  var ts = this._transformState;
+  ts.writecb = cb;
+  ts.writechunk = chunk;
+  ts.writeencoding = encoding;
 
+  if (!ts.transforming) {
+    var rs = this._readableState;
+    if (ts.needTransform || rs.needReadable || rs.length < rs.highWaterMark) this._read(rs.highWaterMark);
+  }
+}; // Doesn't matter what the args are here.
+// _transform does all the work.
+// That we got here means that the readable side wants more data.
 
-/***/ }),
 
-/***/ 74620:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+Transform.prototype._read = function (n) {
+  var ts = this._transformState;
 
-const SemVer = __nccwpck_require__(21098)
-const patch = (a, loose) => new SemVer(a, loose).patch
-module.exports = patch
+  if (ts.writechunk !== null && !ts.transforming) {
+    ts.transforming = true;
 
+    this._transform(ts.writechunk, ts.writeencoding, ts.afterTransform);
+  } else {
+    // mark that we need a transform, so that any data that comes in
+    // will get processed, now that we've asked for it.
+    ts.needTransform = true;
+  }
+};
 
-/***/ }),
+Transform.prototype._destroy = function (err, cb) {
+  Duplex.prototype._destroy.call(this, err, function (err2) {
+    cb(err2);
+  });
+};
 
-/***/ 53811:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+function done(stream, er, data) {
+  if (er) return stream.emit('error', er);
+  if (data != null) // single equals check for both `null` and `undefined`
+    stream.push(data); // TODO(BridgeAR): Write a test for these two error cases
+  // if there's nothing in the write buffer, then that means
+  // that nothing more will ever be provided
 
-const parse = __nccwpck_require__(93863)
-const prerelease = (version, options) => {
-  const parsed = parse(version, options)
-  return (parsed && parsed.prerelease.length) ? parsed.prerelease : null
+  if (stream._writableState.length) throw new ERR_TRANSFORM_WITH_LENGTH_0();
+  if (stream._transformState.transforming) throw new ERR_TRANSFORM_ALREADY_TRANSFORMING();
+  return stream.push(null);
 }
-module.exports = prerelease
-
 
 /***/ }),
 
-/***/ 80370:
+/***/ 23388:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
-const compare = __nccwpck_require__(43234)
-const rcompare = (a, b, loose) => compare(b, a, loose)
-module.exports = rcompare
-
+"use strict";
+// Copyright Joyent, Inc. and other Node contributors.
+//
+// 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.
+// A bit simpler than readable streams.
+// Implement an async ._write(chunk, encoding, cb), and it'll handle all
+// the drain event emission and buffering.
 
-/***/ }),
 
-/***/ 46526:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+module.exports = Writable;
+/*  */
 
-const compareBuild = __nccwpck_require__(17349)
-const rsort = (list, loose) => list.sort((a, b) => compareBuild(b, a, loose))
-module.exports = rsort
+function WriteReq(chunk, encoding, cb) {
+  this.chunk = chunk;
+  this.encoding = encoding;
+  this.callback = cb;
+  this.next = null;
+} // It seems a linked list but it is not
+// there will be only 2 of these for each stream
 
 
-/***/ }),
+function CorkedRequest(state) {
+  var _this = this;
 
-/***/ 19847:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+  this.next = null;
+  this.entry = null;
 
-const Range = __nccwpck_require__(39378)
-const satisfies = (version, range, options) => {
-  try {
-    range = new Range(range, options)
-  } catch (er) {
-    return false
-  }
-  return range.test(version)
+  this.finish = function () {
+    onCorkedFinish(_this, state);
+  };
 }
-module.exports = satisfies
-
+/*  */
 
-/***/ }),
+/**/
 
-/***/ 59008:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
-const compareBuild = __nccwpck_require__(17349)
-const sort = (list, loose) => list.sort((a, b) => compareBuild(a, b, loose))
-module.exports = sort
+var Duplex;
+/**/
 
+Writable.WritableState = WritableState;
+/**/
 
-/***/ }),
+var internalUtil = {
+  deprecate: __nccwpck_require__(96083)
+};
+/**/
 
-/***/ 13742:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+/**/
 
-const parse = __nccwpck_require__(93863)
-const valid = (version, options) => {
-  const v = parse(version, options)
-  return v ? v.version : null
-}
-module.exports = valid
+var Stream = __nccwpck_require__(99004);
+/**/
 
 
-/***/ }),
+var Buffer = (__nccwpck_require__(14300).Buffer);
 
-/***/ 56192:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+var OurUint8Array = global.Uint8Array || function () {};
 
-// just pre-load all the stuff that index.js lazily exports
-const internalRe = __nccwpck_require__(69493)
-module.exports = {
-  re: internalRe.re,
-  src: internalRe.src,
-  tokens: internalRe.t,
-  SEMVER_SPEC_VERSION: (__nccwpck_require__(76930).SEMVER_SPEC_VERSION),
-  SemVer: __nccwpck_require__(21098),
-  compareIdentifiers: (__nccwpck_require__(17665).compareIdentifiers),
-  rcompareIdentifiers: (__nccwpck_require__(17665).rcompareIdentifiers),
-  parse: __nccwpck_require__(93863),
-  valid: __nccwpck_require__(13742),
-  clean: __nccwpck_require__(87225),
-  inc: __nccwpck_require__(10243),
-  diff: __nccwpck_require__(89313),
-  major: __nccwpck_require__(8222),
-  minor: __nccwpck_require__(8940),
-  patch: __nccwpck_require__(74620),
-  prerelease: __nccwpck_require__(53811),
-  compare: __nccwpck_require__(43234),
-  rcompare: __nccwpck_require__(80370),
-  compareLoose: __nccwpck_require__(70310),
-  compareBuild: __nccwpck_require__(17349),
-  sort: __nccwpck_require__(59008),
-  rsort: __nccwpck_require__(46526),
-  gt: __nccwpck_require__(10609),
-  lt: __nccwpck_require__(67703),
-  eq: __nccwpck_require__(77477),
-  neq: __nccwpck_require__(18094),
-  gte: __nccwpck_require__(52469),
-  lte: __nccwpck_require__(84015),
-  cmp: __nccwpck_require__(21292),
-  coerce: __nccwpck_require__(77548),
-  Comparator: __nccwpck_require__(32272),
-  Range: __nccwpck_require__(39378),
-  satisfies: __nccwpck_require__(19847),
-  toComparators: __nccwpck_require__(9005),
-  maxSatisfying: __nccwpck_require__(89518),
-  minSatisfying: __nccwpck_require__(27542),
-  minVersion: __nccwpck_require__(89296),
-  validRange: __nccwpck_require__(35569),
-  outside: __nccwpck_require__(3170),
-  gtr: __nccwpck_require__(5302),
-  ltr: __nccwpck_require__(68457),
-  intersects: __nccwpck_require__(53188),
-  simplifyRange: __nccwpck_require__(75830),
-  subset: __nccwpck_require__(54774),
+function _uint8ArrayToBuffer(chunk) {
+  return Buffer.from(chunk);
 }
 
+function _isUint8Array(obj) {
+  return Buffer.isBuffer(obj) || obj instanceof OurUint8Array;
+}
 
-/***/ }),
-
-/***/ 76930:
-/***/ ((module) => {
-
-// Note: this is the semver.org version of the spec that it implements
-// Not necessarily the package version of this code.
-const SEMVER_SPEC_VERSION = '2.0.0'
+var destroyImpl = __nccwpck_require__(33148);
 
-const MAX_LENGTH = 256
-const MAX_SAFE_INTEGER = Number.MAX_SAFE_INTEGER ||
-  /* istanbul ignore next */ 9007199254740991
+var _require = __nccwpck_require__(12138),
+    getHighWaterMark = _require.getHighWaterMark;
 
-// Max safe segment length for coercion.
-const MAX_SAFE_COMPONENT_LENGTH = 16
+var _require$codes = (__nccwpck_require__(90646)/* .codes */ .q),
+    ERR_INVALID_ARG_TYPE = _require$codes.ERR_INVALID_ARG_TYPE,
+    ERR_METHOD_NOT_IMPLEMENTED = _require$codes.ERR_METHOD_NOT_IMPLEMENTED,
+    ERR_MULTIPLE_CALLBACK = _require$codes.ERR_MULTIPLE_CALLBACK,
+    ERR_STREAM_CANNOT_PIPE = _require$codes.ERR_STREAM_CANNOT_PIPE,
+    ERR_STREAM_DESTROYED = _require$codes.ERR_STREAM_DESTROYED,
+    ERR_STREAM_NULL_VALUES = _require$codes.ERR_STREAM_NULL_VALUES,
+    ERR_STREAM_WRITE_AFTER_END = _require$codes.ERR_STREAM_WRITE_AFTER_END,
+    ERR_UNKNOWN_ENCODING = _require$codes.ERR_UNKNOWN_ENCODING;
 
-module.exports = {
-  SEMVER_SPEC_VERSION,
-  MAX_LENGTH,
-  MAX_SAFE_INTEGER,
-  MAX_SAFE_COMPONENT_LENGTH
-}
+var errorOrDestroy = destroyImpl.errorOrDestroy;
 
+__nccwpck_require__(76401)(Writable, Stream);
 
-/***/ }),
+function nop() {}
 
-/***/ 96839:
-/***/ ((module) => {
+function WritableState(options, stream, isDuplex) {
+  Duplex = Duplex || __nccwpck_require__(97256);
+  options = options || {}; // Duplex streams are both readable and writable, but share
+  // the same options object.
+  // However, some cases require setting options to different
+  // values for the readable and the writable sides of the duplex stream,
+  // e.g. options.readableObjectMode vs. options.writableObjectMode, etc.
 
-const debug = (
-  typeof process === 'object' &&
-  process.env &&
-  process.env.NODE_DEBUG &&
-  /\bsemver\b/i.test(process.env.NODE_DEBUG)
-) ? (...args) => console.error('SEMVER', ...args)
-  : () => {}
+  if (typeof isDuplex !== 'boolean') isDuplex = stream instanceof Duplex; // object stream flag to indicate whether or not this stream
+  // contains buffers or objects.
 
-module.exports = debug
+  this.objectMode = !!options.objectMode;
+  if (isDuplex) this.objectMode = this.objectMode || !!options.writableObjectMode; // the point at which write() starts returning false
+  // Note: 0 is a valid value, means that we always return false if
+  // the entire buffer is not flushed immediately on write()
 
+  this.highWaterMark = getHighWaterMark(this, options, 'writableHighWaterMark', isDuplex); // if _final has been called
 
-/***/ }),
+  this.finalCalled = false; // drain event flag.
 
-/***/ 17665:
-/***/ ((module) => {
+  this.needDrain = false; // at the start of calling end()
 
-const numeric = /^[0-9]+$/
-const compareIdentifiers = (a, b) => {
-  const anum = numeric.test(a)
-  const bnum = numeric.test(b)
+  this.ending = false; // when end() has been called, and returned
 
-  if (anum && bnum) {
-    a = +a
-    b = +b
-  }
+  this.ended = false; // when 'finish' is emitted
 
-  return a === b ? 0
-    : (anum && !bnum) ? -1
-    : (bnum && !anum) ? 1
-    : a < b ? -1
-    : 1
-}
+  this.finished = false; // has it been destroyed
 
-const rcompareIdentifiers = (a, b) => compareIdentifiers(b, a)
+  this.destroyed = false; // should we decode strings into buffers before passing to _write?
+  // this is here so that some node-core streams can optimize string
+  // handling at a lower level.
 
-module.exports = {
-  compareIdentifiers,
-  rcompareIdentifiers
-}
+  var noDecode = options.decodeStrings === false;
+  this.decodeStrings = !noDecode; // Crypto is kind of old and crusty.  Historically, its default string
+  // encoding is 'binary' so we have to make this configurable.
+  // Everything else in the universe uses 'utf8', though.
 
+  this.defaultEncoding = options.defaultEncoding || 'utf8'; // not an actual buffer we keep track of, but a measurement
+  // of how much we're waiting to get pushed to some underlying
+  // socket or file.
 
-/***/ }),
+  this.length = 0; // a flag to see when we're in the middle of a write.
 
-/***/ 84615:
-/***/ ((module) => {
+  this.writing = false; // when true all writes will be buffered until .uncork() call
 
-// parse out just the options we care about so we always get a consistent
-// obj with keys in a consistent order.
-const opts = ['includePrerelease', 'loose', 'rtl']
-const parseOptions = options =>
-  !options ? {}
-  : typeof options !== 'object' ? { loose: true }
-  : opts.filter(k => options[k]).reduce((options, k) => {
-    options[k] = true
-    return options
-  }, {})
-module.exports = parseOptions
+  this.corked = 0; // a flag to be able to tell if the onwrite cb is called immediately,
+  // or on a later tick.  We set this to true at first, because any
+  // actions that shouldn't happen until "later" should generally also
+  // not happen before the first write call.
 
+  this.sync = true; // a flag to know if we're processing previously buffered items, which
+  // may call the _write() callback in the same tick, so that we don't
+  // end up in an overlapped onwrite situation.
 
-/***/ }),
+  this.bufferProcessing = false; // the callback that's passed to _write(chunk,cb)
 
-/***/ 69493:
-/***/ ((module, exports, __nccwpck_require__) => {
+  this.onwrite = function (er) {
+    onwrite(stream, er);
+  }; // the callback that the user supplies to write(chunk,encoding,cb)
 
-const { MAX_SAFE_COMPONENT_LENGTH } = __nccwpck_require__(76930)
-const debug = __nccwpck_require__(96839)
-exports = module.exports = {}
 
-// The actual regexps go on exports.re
-const re = exports.re = []
-const src = exports.src = []
-const t = exports.t = {}
-let R = 0
+  this.writecb = null; // the amount that is being written when _write is called.
 
-const createToken = (name, value, isGlobal) => {
-  const index = R++
-  debug(index, value)
-  t[name] = index
-  src[index] = value
-  re[index] = new RegExp(value, isGlobal ? 'g' : undefined)
-}
+  this.writelen = 0;
+  this.bufferedRequest = null;
+  this.lastBufferedRequest = null; // number of pending user-supplied write callbacks
+  // this must be 0 before 'finish' can be emitted
 
-// The following Regular Expressions can be used for tokenizing,
-// validating, and parsing SemVer version strings.
+  this.pendingcb = 0; // emit prefinish if the only thing we're waiting for is _write cbs
+  // This is relevant for synchronous Transform streams
 
-// ## Numeric Identifier
-// A single `0`, or a non-zero digit followed by zero or more digits.
+  this.prefinished = false; // True if the error was already emitted and should not be thrown again
 
-createToken('NUMERICIDENTIFIER', '0|[1-9]\\d*')
-createToken('NUMERICIDENTIFIERLOOSE', '[0-9]+')
+  this.errorEmitted = false; // Should close be emitted on destroy. Defaults to true.
 
-// ## Non-numeric Identifier
-// Zero or more digits, followed by a letter or hyphen, and then zero or
-// more letters, digits, or hyphens.
+  this.emitClose = options.emitClose !== false; // Should .destroy() be called after 'finish' (and potentially 'end')
 
-createToken('NONNUMERICIDENTIFIER', '\\d*[a-zA-Z-][a-zA-Z0-9-]*')
+  this.autoDestroy = !!options.autoDestroy; // count buffered requests
 
-// ## Main Version
-// Three dot-separated numeric identifiers.
+  this.bufferedRequestCount = 0; // allocate the first CorkedRequest, there is always
+  // one allocated and free to use, and we maintain at most two
 
-createToken('MAINVERSION', `(${src[t.NUMERICIDENTIFIER]})\\.` +
-                   `(${src[t.NUMERICIDENTIFIER]})\\.` +
-                   `(${src[t.NUMERICIDENTIFIER]})`)
+  this.corkedRequestsFree = new CorkedRequest(this);
+}
 
-createToken('MAINVERSIONLOOSE', `(${src[t.NUMERICIDENTIFIERLOOSE]})\\.` +
-                        `(${src[t.NUMERICIDENTIFIERLOOSE]})\\.` +
-                        `(${src[t.NUMERICIDENTIFIERLOOSE]})`)
+WritableState.prototype.getBuffer = function getBuffer() {
+  var current = this.bufferedRequest;
+  var out = [];
 
-// ## Pre-release Version Identifier
-// A numeric identifier, or a non-numeric identifier.
+  while (current) {
+    out.push(current);
+    current = current.next;
+  }
 
-createToken('PRERELEASEIDENTIFIER', `(?:${src[t.NUMERICIDENTIFIER]
-}|${src[t.NONNUMERICIDENTIFIER]})`)
+  return out;
+};
 
-createToken('PRERELEASEIDENTIFIERLOOSE', `(?:${src[t.NUMERICIDENTIFIERLOOSE]
-}|${src[t.NONNUMERICIDENTIFIER]})`)
+(function () {
+  try {
+    Object.defineProperty(WritableState.prototype, 'buffer', {
+      get: internalUtil.deprecate(function writableStateBufferGetter() {
+        return this.getBuffer();
+      }, '_writableState.buffer is deprecated. Use _writableState.getBuffer ' + 'instead.', 'DEP0003')
+    });
+  } catch (_) {}
+})(); // Test _writableState for inheritance to account for Duplex streams,
+// whose prototype chain only points to Readable.
 
-// ## Pre-release Version
-// Hyphen, followed by one or more dot-separated pre-release version
-// identifiers.
 
-createToken('PRERELEASE', `(?:-(${src[t.PRERELEASEIDENTIFIER]
-}(?:\\.${src[t.PRERELEASEIDENTIFIER]})*))`)
+var realHasInstance;
 
-createToken('PRERELEASELOOSE', `(?:-?(${src[t.PRERELEASEIDENTIFIERLOOSE]
-}(?:\\.${src[t.PRERELEASEIDENTIFIERLOOSE]})*))`)
+if (typeof Symbol === 'function' && Symbol.hasInstance && typeof Function.prototype[Symbol.hasInstance] === 'function') {
+  realHasInstance = Function.prototype[Symbol.hasInstance];
+  Object.defineProperty(Writable, Symbol.hasInstance, {
+    value: function value(object) {
+      if (realHasInstance.call(this, object)) return true;
+      if (this !== Writable) return false;
+      return object && object._writableState instanceof WritableState;
+    }
+  });
+} else {
+  realHasInstance = function realHasInstance(object) {
+    return object instanceof this;
+  };
+}
 
-// ## Build Metadata Identifier
-// Any combination of digits, letters, or hyphens.
+function Writable(options) {
+  Duplex = Duplex || __nccwpck_require__(97256); // Writable ctor is applied to Duplexes, too.
+  // `realHasInstance` is necessary because using plain `instanceof`
+  // would return false, as no `_writableState` property is attached.
+  // Trying to use the custom `instanceof` for Writable here will also break the
+  // Node.js LazyTransform implementation, which has a non-trivial getter for
+  // `_writableState` that would lead to infinite recursion.
+  // Checking for a Stream.Duplex instance is faster here instead of inside
+  // the WritableState constructor, at least with V8 6.5
 
-createToken('BUILDIDENTIFIER', '[0-9A-Za-z-]+')
+  var isDuplex = this instanceof Duplex;
+  if (!isDuplex && !realHasInstance.call(Writable, this)) return new Writable(options);
+  this._writableState = new WritableState(options, this, isDuplex); // legacy.
 
-// ## Build Metadata
-// Plus sign, followed by one or more period-separated build metadata
-// identifiers.
+  this.writable = true;
 
-createToken('BUILD', `(?:\\+(${src[t.BUILDIDENTIFIER]
-}(?:\\.${src[t.BUILDIDENTIFIER]})*))`)
+  if (options) {
+    if (typeof options.write === 'function') this._write = options.write;
+    if (typeof options.writev === 'function') this._writev = options.writev;
+    if (typeof options.destroy === 'function') this._destroy = options.destroy;
+    if (typeof options.final === 'function') this._final = options.final;
+  }
 
-// ## Full Version String
-// A main version, followed optionally by a pre-release version and
-// build metadata.
+  Stream.call(this);
+} // Otherwise people can pipe Writable streams, which is just wrong.
 
-// Note that the only major, minor, patch, and pre-release sections of
-// the version string are capturing groups.  The build metadata is not a
-// capturing group, because it should not ever be used in version
-// comparison.
 
-createToken('FULLPLAIN', `v?${src[t.MAINVERSION]
-}${src[t.PRERELEASE]}?${
-  src[t.BUILD]}?`)
+Writable.prototype.pipe = function () {
+  errorOrDestroy(this, new ERR_STREAM_CANNOT_PIPE());
+};
 
-createToken('FULL', `^${src[t.FULLPLAIN]}$`)
+function writeAfterEnd(stream, cb) {
+  var er = new ERR_STREAM_WRITE_AFTER_END(); // TODO: defer error events consistently everywhere, not just the cb
 
-// like full, but allows v1.2.3 and =1.2.3, which people do sometimes.
-// also, 1.0.0alpha1 (prerelease without the hyphen) which is pretty
-// common in the npm registry.
-createToken('LOOSEPLAIN', `[v=\\s]*${src[t.MAINVERSIONLOOSE]
-}${src[t.PRERELEASELOOSE]}?${
-  src[t.BUILD]}?`)
+  errorOrDestroy(stream, er);
+  process.nextTick(cb, er);
+} // Checks that a user-supplied chunk is valid, especially for the particular
+// mode the stream is in. Currently this means that `null` is never accepted
+// and undefined/non-string values are only allowed in object mode.
 
-createToken('LOOSE', `^${src[t.LOOSEPLAIN]}$`)
 
-createToken('GTLT', '((?:<|>)?=?)')
+function validChunk(stream, state, chunk, cb) {
+  var er;
 
-// Something like "2.*" or "1.2.x".
-// Note that "x.x" is a valid xRange identifer, meaning "any version"
-// Only the first item is strictly required.
-createToken('XRANGEIDENTIFIERLOOSE', `${src[t.NUMERICIDENTIFIERLOOSE]}|x|X|\\*`)
-createToken('XRANGEIDENTIFIER', `${src[t.NUMERICIDENTIFIER]}|x|X|\\*`)
+  if (chunk === null) {
+    er = new ERR_STREAM_NULL_VALUES();
+  } else if (typeof chunk !== 'string' && !state.objectMode) {
+    er = new ERR_INVALID_ARG_TYPE('chunk', ['string', 'Buffer'], chunk);
+  }
 
-createToken('XRANGEPLAIN', `[v=\\s]*(${src[t.XRANGEIDENTIFIER]})` +
-                   `(?:\\.(${src[t.XRANGEIDENTIFIER]})` +
-                   `(?:\\.(${src[t.XRANGEIDENTIFIER]})` +
-                   `(?:${src[t.PRERELEASE]})?${
-                     src[t.BUILD]}?` +
-                   `)?)?`)
+  if (er) {
+    errorOrDestroy(stream, er);
+    process.nextTick(cb, er);
+    return false;
+  }
 
-createToken('XRANGEPLAINLOOSE', `[v=\\s]*(${src[t.XRANGEIDENTIFIERLOOSE]})` +
-                        `(?:\\.(${src[t.XRANGEIDENTIFIERLOOSE]})` +
-                        `(?:\\.(${src[t.XRANGEIDENTIFIERLOOSE]})` +
-                        `(?:${src[t.PRERELEASELOOSE]})?${
-                          src[t.BUILD]}?` +
-                        `)?)?`)
+  return true;
+}
 
-createToken('XRANGE', `^${src[t.GTLT]}\\s*${src[t.XRANGEPLAIN]}$`)
-createToken('XRANGELOOSE', `^${src[t.GTLT]}\\s*${src[t.XRANGEPLAINLOOSE]}$`)
+Writable.prototype.write = function (chunk, encoding, cb) {
+  var state = this._writableState;
+  var ret = false;
 
-// Coercion.
-// Extract anything that could conceivably be a part of a valid semver
-createToken('COERCE', `${'(^|[^\\d])' +
-              '(\\d{1,'}${MAX_SAFE_COMPONENT_LENGTH}})` +
-              `(?:\\.(\\d{1,${MAX_SAFE_COMPONENT_LENGTH}}))?` +
-              `(?:\\.(\\d{1,${MAX_SAFE_COMPONENT_LENGTH}}))?` +
-              `(?:$|[^\\d])`)
-createToken('COERCERTL', src[t.COERCE], true)
+  var isBuf = !state.objectMode && _isUint8Array(chunk);
 
-// Tilde ranges.
-// Meaning is "reasonably at or greater than"
-createToken('LONETILDE', '(?:~>?)')
+  if (isBuf && !Buffer.isBuffer(chunk)) {
+    chunk = _uint8ArrayToBuffer(chunk);
+  }
 
-createToken('TILDETRIM', `(\\s*)${src[t.LONETILDE]}\\s+`, true)
-exports.tildeTrimReplace = '$1~'
+  if (typeof encoding === 'function') {
+    cb = encoding;
+    encoding = null;
+  }
 
-createToken('TILDE', `^${src[t.LONETILDE]}${src[t.XRANGEPLAIN]}$`)
-createToken('TILDELOOSE', `^${src[t.LONETILDE]}${src[t.XRANGEPLAINLOOSE]}$`)
+  if (isBuf) encoding = 'buffer';else if (!encoding) encoding = state.defaultEncoding;
+  if (typeof cb !== 'function') cb = nop;
+  if (state.ending) writeAfterEnd(this, cb);else if (isBuf || validChunk(this, state, chunk, cb)) {
+    state.pendingcb++;
+    ret = writeOrBuffer(this, state, isBuf, chunk, encoding, cb);
+  }
+  return ret;
+};
 
-// Caret ranges.
-// Meaning is "at least and backwards compatible with"
-createToken('LONECARET', '(?:\\^)')
+Writable.prototype.cork = function () {
+  this._writableState.corked++;
+};
 
-createToken('CARETTRIM', `(\\s*)${src[t.LONECARET]}\\s+`, true)
-exports.caretTrimReplace = '$1^'
+Writable.prototype.uncork = function () {
+  var state = this._writableState;
 
-createToken('CARET', `^${src[t.LONECARET]}${src[t.XRANGEPLAIN]}$`)
-createToken('CARETLOOSE', `^${src[t.LONECARET]}${src[t.XRANGEPLAINLOOSE]}$`)
+  if (state.corked) {
+    state.corked--;
+    if (!state.writing && !state.corked && !state.bufferProcessing && state.bufferedRequest) clearBuffer(this, state);
+  }
+};
 
-// A simple gt/lt/eq thing, or just "" to indicate "any version"
-createToken('COMPARATORLOOSE', `^${src[t.GTLT]}\\s*(${src[t.LOOSEPLAIN]})$|^$`)
-createToken('COMPARATOR', `^${src[t.GTLT]}\\s*(${src[t.FULLPLAIN]})$|^$`)
+Writable.prototype.setDefaultEncoding = function setDefaultEncoding(encoding) {
+  // node::ParseEncoding() requires lower case.
+  if (typeof encoding === 'string') encoding = encoding.toLowerCase();
+  if (!(['hex', 'utf8', 'utf-8', 'ascii', 'binary', 'base64', 'ucs2', 'ucs-2', 'utf16le', 'utf-16le', 'raw'].indexOf((encoding + '').toLowerCase()) > -1)) throw new ERR_UNKNOWN_ENCODING(encoding);
+  this._writableState.defaultEncoding = encoding;
+  return this;
+};
 
-// An expression to strip any whitespace between the gtlt and the thing
-// it modifies, so that `> 1.2.3` ==> `>1.2.3`
-createToken('COMPARATORTRIM', `(\\s*)${src[t.GTLT]
-}\\s*(${src[t.LOOSEPLAIN]}|${src[t.XRANGEPLAIN]})`, true)
-exports.comparatorTrimReplace = '$1$2$3'
+Object.defineProperty(Writable.prototype, 'writableBuffer', {
+  // making it explicit this property is not enumerable
+  // because otherwise some prototype manipulation in
+  // userland will fail
+  enumerable: false,
+  get: function get() {
+    return this._writableState && this._writableState.getBuffer();
+  }
+});
 
-// Something like `1.2.3 - 1.2.4`
-// Note that these all use the loose form, because they'll be
-// checked against either the strict or loose comparator form
-// later.
-createToken('HYPHENRANGE', `^\\s*(${src[t.XRANGEPLAIN]})` +
-                   `\\s+-\\s+` +
-                   `(${src[t.XRANGEPLAIN]})` +
-                   `\\s*$`)
+function decodeChunk(state, chunk, encoding) {
+  if (!state.objectMode && state.decodeStrings !== false && typeof chunk === 'string') {
+    chunk = Buffer.from(chunk, encoding);
+  }
 
-createToken('HYPHENRANGELOOSE', `^\\s*(${src[t.XRANGEPLAINLOOSE]})` +
-                        `\\s+-\\s+` +
-                        `(${src[t.XRANGEPLAINLOOSE]})` +
-                        `\\s*$`)
+  return chunk;
+}
 
-// Star ranges basically just allow anything at all.
-createToken('STAR', '(<|>)?=?\\s*\\*')
-// >=0.0.0 is like a star
-createToken('GTE0', '^\\s*>=\\s*0\.0\.0\\s*$')
-createToken('GTE0PRE', '^\\s*>=\\s*0\.0\.0-0\\s*$')
+Object.defineProperty(Writable.prototype, 'writableHighWaterMark', {
+  // making it explicit this property is not enumerable
+  // because otherwise some prototype manipulation in
+  // userland will fail
+  enumerable: false,
+  get: function get() {
+    return this._writableState.highWaterMark;
+  }
+}); // if we're already writing something, then just put this
+// in the queue, and wait our turn.  Otherwise, call _write
+// If we return false, then we need a drain event, so set that flag.
 
+function writeOrBuffer(stream, state, isBuf, chunk, encoding, cb) {
+  if (!isBuf) {
+    var newChunk = decodeChunk(state, chunk, encoding);
 
-/***/ }),
+    if (chunk !== newChunk) {
+      isBuf = true;
+      encoding = 'buffer';
+      chunk = newChunk;
+    }
+  }
 
-/***/ 5302:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+  var len = state.objectMode ? 1 : chunk.length;
+  state.length += len;
+  var ret = state.length < state.highWaterMark; // we must ensure that previous needDrain will not be reset to false.
 
-// Determine if version is greater than all the versions possible in the range.
-const outside = __nccwpck_require__(3170)
-const gtr = (version, range, options) => outside(version, range, '>', options)
-module.exports = gtr
+  if (!ret) state.needDrain = true;
 
+  if (state.writing || state.corked) {
+    var last = state.lastBufferedRequest;
+    state.lastBufferedRequest = {
+      chunk: chunk,
+      encoding: encoding,
+      isBuf: isBuf,
+      callback: cb,
+      next: null
+    };
 
-/***/ }),
+    if (last) {
+      last.next = state.lastBufferedRequest;
+    } else {
+      state.bufferedRequest = state.lastBufferedRequest;
+    }
 
-/***/ 53188:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+    state.bufferedRequestCount += 1;
+  } else {
+    doWrite(stream, state, false, len, chunk, encoding, cb);
+  }
 
-const Range = __nccwpck_require__(39378)
-const intersects = (r1, r2, options) => {
-  r1 = new Range(r1, options)
-  r2 = new Range(r2, options)
-  return r1.intersects(r2)
+  return ret;
 }
-module.exports = intersects
 
+function doWrite(stream, state, writev, len, chunk, encoding, cb) {
+  state.writelen = len;
+  state.writecb = cb;
+  state.writing = true;
+  state.sync = true;
+  if (state.destroyed) state.onwrite(new ERR_STREAM_DESTROYED('write'));else if (writev) stream._writev(chunk, state.onwrite);else stream._write(chunk, encoding, state.onwrite);
+  state.sync = false;
+}
 
-/***/ }),
+function onwriteError(stream, state, sync, er, cb) {
+  --state.pendingcb;
 
-/***/ 68457:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+  if (sync) {
+    // defer the callback if we are being called synchronously
+    // to avoid piling up things on the stack
+    process.nextTick(cb, er); // this can emit finish, and it will always happen
+    // after error
 
-const outside = __nccwpck_require__(3170)
-// Determine if version is less than all the versions possible in the range
-const ltr = (version, range, options) => outside(version, range, '<', options)
-module.exports = ltr
+    process.nextTick(finishMaybe, stream, state);
+    stream._writableState.errorEmitted = true;
+    errorOrDestroy(stream, er);
+  } else {
+    // the caller expect this to happen before if
+    // it is async
+    cb(er);
+    stream._writableState.errorEmitted = true;
+    errorOrDestroy(stream, er); // this can emit finish, but finish must
+    // always follow error
 
+    finishMaybe(stream, state);
+  }
+}
 
-/***/ }),
+function onwriteStateUpdate(state) {
+  state.writing = false;
+  state.writecb = null;
+  state.length -= state.writelen;
+  state.writelen = 0;
+}
 
-/***/ 89518:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+function onwrite(stream, er) {
+  var state = stream._writableState;
+  var sync = state.sync;
+  var cb = state.writecb;
+  if (typeof cb !== 'function') throw new ERR_MULTIPLE_CALLBACK();
+  onwriteStateUpdate(state);
+  if (er) onwriteError(stream, state, sync, er, cb);else {
+    // Check if we're actually ready to finish, but don't emit yet
+    var finished = needFinish(state) || stream.destroyed;
 
-const SemVer = __nccwpck_require__(21098)
-const Range = __nccwpck_require__(39378)
+    if (!finished && !state.corked && !state.bufferProcessing && state.bufferedRequest) {
+      clearBuffer(stream, state);
+    }
 
-const maxSatisfying = (versions, range, options) => {
-  let max = null
-  let maxSV = null
-  let rangeObj = null
-  try {
-    rangeObj = new Range(range, options)
-  } catch (er) {
-    return null
-  }
-  versions.forEach((v) => {
-    if (rangeObj.test(v)) {
-      // satisfies(v, range, options)
-      if (!max || maxSV.compare(v) === -1) {
-        // compare(max, v, true)
-        max = v
-        maxSV = new SemVer(max, options)
-      }
+    if (sync) {
+      process.nextTick(afterWrite, stream, state, finished, cb);
+    } else {
+      afterWrite(stream, state, finished, cb);
     }
-  })
-  return max
+  }
 }
-module.exports = maxSatisfying
 
+function afterWrite(stream, state, finished, cb) {
+  if (!finished) onwriteDrain(stream, state);
+  state.pendingcb--;
+  cb();
+  finishMaybe(stream, state);
+} // Must force callback to be called on nextTick, so that we don't
+// emit 'drain' before the write() consumer gets the 'false' return
+// value, and has a chance to attach a 'drain' listener.
 
-/***/ }),
 
-/***/ 27542:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
-
-const SemVer = __nccwpck_require__(21098)
-const Range = __nccwpck_require__(39378)
-const minSatisfying = (versions, range, options) => {
-  let min = null
-  let minSV = null
-  let rangeObj = null
-  try {
-    rangeObj = new Range(range, options)
-  } catch (er) {
-    return null
-  }
-  versions.forEach((v) => {
-    if (rangeObj.test(v)) {
-      // satisfies(v, range, options)
-      if (!min || minSV.compare(v) === 1) {
-        // compare(min, v, true)
-        min = v
-        minSV = new SemVer(min, options)
-      }
-    }
-  })
-  return min
-}
-module.exports = minSatisfying
+function onwriteDrain(stream, state) {
+  if (state.length === 0 && state.needDrain) {
+    state.needDrain = false;
+    stream.emit('drain');
+  }
+} // if there's something in the buffer waiting, then process it
 
 
-/***/ }),
+function clearBuffer(stream, state) {
+  state.bufferProcessing = true;
+  var entry = state.bufferedRequest;
 
-/***/ 89296:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+  if (stream._writev && entry && entry.next) {
+    // Fast case, write everything using _writev()
+    var l = state.bufferedRequestCount;
+    var buffer = new Array(l);
+    var holder = state.corkedRequestsFree;
+    holder.entry = entry;
+    var count = 0;
+    var allBuffers = true;
 
-const SemVer = __nccwpck_require__(21098)
-const Range = __nccwpck_require__(39378)
-const gt = __nccwpck_require__(10609)
+    while (entry) {
+      buffer[count] = entry;
+      if (!entry.isBuf) allBuffers = false;
+      entry = entry.next;
+      count += 1;
+    }
 
-const minVersion = (range, loose) => {
-  range = new Range(range, loose)
+    buffer.allBuffers = allBuffers;
+    doWrite(stream, state, true, state.length, buffer, '', holder.finish); // doWrite is almost always async, defer these to save a bit of time
+    // as the hot path ends with doWrite
 
-  let minver = new SemVer('0.0.0')
-  if (range.test(minver)) {
-    return minver
-  }
+    state.pendingcb++;
+    state.lastBufferedRequest = null;
 
-  minver = new SemVer('0.0.0-0')
-  if (range.test(minver)) {
-    return minver
-  }
+    if (holder.next) {
+      state.corkedRequestsFree = holder.next;
+      holder.next = null;
+    } else {
+      state.corkedRequestsFree = new CorkedRequest(state);
+    }
 
-  minver = null
-  for (let i = 0; i < range.set.length; ++i) {
-    const comparators = range.set[i]
+    state.bufferedRequestCount = 0;
+  } else {
+    // Slow case, write chunks one-by-one
+    while (entry) {
+      var chunk = entry.chunk;
+      var encoding = entry.encoding;
+      var cb = entry.callback;
+      var len = state.objectMode ? 1 : chunk.length;
+      doWrite(stream, state, false, len, chunk, encoding, cb);
+      entry = entry.next;
+      state.bufferedRequestCount--; // if we didn't call the onwrite immediately, then
+      // it means that we need to wait until it does.
+      // also, that means that the chunk and cb are currently
+      // being processed, so move the buffer counter past them.
 
-    let setMin = null
-    comparators.forEach((comparator) => {
-      // Clone to avoid manipulating the comparator's semver object.
-      const compver = new SemVer(comparator.semver.version)
-      switch (comparator.operator) {
-        case '>':
-          if (compver.prerelease.length === 0) {
-            compver.patch++
-          } else {
-            compver.prerelease.push(0)
-          }
-          compver.raw = compver.format()
-          /* fallthrough */
-        case '':
-        case '>=':
-          if (!setMin || gt(compver, setMin)) {
-            setMin = compver
-          }
-          break
-        case '<':
-        case '<=':
-          /* Ignore maximum versions */
-          break
-        /* istanbul ignore next */
-        default:
-          throw new Error(`Unexpected operation: ${comparator.operator}`)
+      if (state.writing) {
+        break;
       }
-    })
-    if (setMin && (!minver || gt(minver, setMin)))
-      minver = setMin
-  }
+    }
 
-  if (minver && range.test(minver)) {
-    return minver
+    if (entry === null) state.lastBufferedRequest = null;
   }
 
-  return null
+  state.bufferedRequest = entry;
+  state.bufferProcessing = false;
 }
-module.exports = minVersion
 
+Writable.prototype._write = function (chunk, encoding, cb) {
+  cb(new ERR_METHOD_NOT_IMPLEMENTED('_write()'));
+};
 
-/***/ }),
+Writable.prototype._writev = null;
 
-/***/ 3170:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+Writable.prototype.end = function (chunk, encoding, cb) {
+  var state = this._writableState;
 
-const SemVer = __nccwpck_require__(21098)
-const Comparator = __nccwpck_require__(32272)
-const {ANY} = Comparator
-const Range = __nccwpck_require__(39378)
-const satisfies = __nccwpck_require__(19847)
-const gt = __nccwpck_require__(10609)
-const lt = __nccwpck_require__(67703)
-const lte = __nccwpck_require__(84015)
-const gte = __nccwpck_require__(52469)
+  if (typeof chunk === 'function') {
+    cb = chunk;
+    chunk = null;
+    encoding = null;
+  } else if (typeof encoding === 'function') {
+    cb = encoding;
+    encoding = null;
+  }
 
-const outside = (version, range, hilo, options) => {
-  version = new SemVer(version, options)
-  range = new Range(range, options)
+  if (chunk !== null && chunk !== undefined) this.write(chunk, encoding); // .end() fully uncorks
 
-  let gtfn, ltefn, ltfn, comp, ecomp
-  switch (hilo) {
-    case '>':
-      gtfn = gt
-      ltefn = lte
-      ltfn = lt
-      comp = '>'
-      ecomp = '>='
-      break
-    case '<':
-      gtfn = lt
-      ltefn = gte
-      ltfn = gt
-      comp = '<'
-      ecomp = '<='
-      break
-    default:
-      throw new TypeError('Must provide a hilo val of "<" or ">"')
-  }
+  if (state.corked) {
+    state.corked = 1;
+    this.uncork();
+  } // ignore unnecessary end() calls.
 
-  // If it satisfies the range it is not outside
-  if (satisfies(version, range, options)) {
-    return false
-  }
 
-  // From now on, variable terms are as if we're in "gtr" mode.
-  // but note that everything is flipped for the "ltr" function.
+  if (!state.ending) endWritable(this, state, cb);
+  return this;
+};
 
-  for (let i = 0; i < range.set.length; ++i) {
-    const comparators = range.set[i]
+Object.defineProperty(Writable.prototype, 'writableLength', {
+  // making it explicit this property is not enumerable
+  // because otherwise some prototype manipulation in
+  // userland will fail
+  enumerable: false,
+  get: function get() {
+    return this._writableState.length;
+  }
+});
 
-    let high = null
-    let low = null
+function needFinish(state) {
+  return state.ending && state.length === 0 && state.bufferedRequest === null && !state.finished && !state.writing;
+}
 
-    comparators.forEach((comparator) => {
-      if (comparator.semver === ANY) {
-        comparator = new Comparator('>=0.0.0')
-      }
-      high = high || comparator
-      low = low || comparator
-      if (gtfn(comparator.semver, high.semver, options)) {
-        high = comparator
-      } else if (ltfn(comparator.semver, low.semver, options)) {
-        low = comparator
-      }
-    })
+function callFinal(stream, state) {
+  stream._final(function (err) {
+    state.pendingcb--;
 
-    // If the edge version comparator has a operator then our version
-    // isn't outside it
-    if (high.operator === comp || high.operator === ecomp) {
-      return false
+    if (err) {
+      errorOrDestroy(stream, err);
     }
 
-    // If the lowest version comparator has an operator and our version
-    // is less than it then it isn't higher than the range
-    if ((!low.operator || low.operator === comp) &&
-        ltefn(version, low.semver)) {
-      return false
-    } else if (low.operator === ecomp && ltfn(version, low.semver)) {
-      return false
+    state.prefinished = true;
+    stream.emit('prefinish');
+    finishMaybe(stream, state);
+  });
+}
+
+function prefinish(stream, state) {
+  if (!state.prefinished && !state.finalCalled) {
+    if (typeof stream._final === 'function' && !state.destroyed) {
+      state.pendingcb++;
+      state.finalCalled = true;
+      process.nextTick(callFinal, stream, state);
+    } else {
+      state.prefinished = true;
+      stream.emit('prefinish');
     }
   }
-  return true
 }
 
-module.exports = outside
+function finishMaybe(stream, state) {
+  var need = needFinish(state);
 
+  if (need) {
+    prefinish(stream, state);
 
-/***/ }),
+    if (state.pendingcb === 0) {
+      state.finished = true;
+      stream.emit('finish');
 
-/***/ 75830:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+      if (state.autoDestroy) {
+        // In case of duplex streams we need a way to detect
+        // if the readable side is ready for autoDestroy as well
+        var rState = stream._readableState;
 
-// given a set of versions and a range, create a "simplified" range
-// that includes the same versions that the original range does
-// If the original range is shorter than the simplified one, return that.
-const satisfies = __nccwpck_require__(19847)
-const compare = __nccwpck_require__(43234)
-module.exports = (versions, range, options) => {
-  const set = []
-  let min = null
-  let prev = null
-  const v = versions.sort((a, b) => compare(a, b, options))
-  for (const version of v) {
-    const included = satisfies(version, range, options)
-    if (included) {
-      prev = version
-      if (!min)
-        min = version
-    } else {
-      if (prev) {
-        set.push([min, prev])
+        if (!rState || rState.autoDestroy && rState.endEmitted) {
+          stream.destroy();
+        }
       }
-      prev = null
-      min = null
     }
   }
-  if (min)
-    set.push([min, null])
 
-  const ranges = []
-  for (const [min, max] of set) {
-    if (min === max)
-      ranges.push(min)
-    else if (!max && min === v[0])
-      ranges.push('*')
-    else if (!max)
-      ranges.push(`>=${min}`)
-    else if (min === v[0])
-      ranges.push(`<=${max}`)
-    else
-      ranges.push(`${min} - ${max}`)
-  }
-  const simplified = ranges.join(' || ')
-  const original = typeof range.raw === 'string' ? range.raw : String(range)
-  return simplified.length < original.length ? simplified : range
+  return need;
 }
 
+function endWritable(stream, state, cb) {
+  state.ending = true;
+  finishMaybe(stream, state);
 
-/***/ }),
+  if (cb) {
+    if (state.finished) process.nextTick(cb);else stream.once('finish', cb);
+  }
 
-/***/ 54774:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+  state.ended = true;
+  stream.writable = false;
+}
 
-const Range = __nccwpck_require__(39378)
-const { ANY } = __nccwpck_require__(32272)
-const satisfies = __nccwpck_require__(19847)
-const compare = __nccwpck_require__(43234)
+function onCorkedFinish(corkReq, state, err) {
+  var entry = corkReq.entry;
+  corkReq.entry = null;
 
-// Complex range `r1 || r2 || ...` is a subset of `R1 || R2 || ...` iff:
-// - Every simple range `r1, r2, ...` is a subset of some `R1, R2, ...`
-//
-// Simple range `c1 c2 ...` is a subset of simple range `C1 C2 ...` iff:
-// - If c is only the ANY comparator
-//   - If C is only the ANY comparator, return true
-//   - Else return false
-// - Let EQ be the set of = comparators in c
-// - If EQ is more than one, return true (null set)
-// - Let GT be the highest > or >= comparator in c
-// - Let LT be the lowest < or <= comparator in c
-// - If GT and LT, and GT.semver > LT.semver, return true (null set)
-// - If EQ
-//   - If GT, and EQ does not satisfy GT, return true (null set)
-//   - If LT, and EQ does not satisfy LT, return true (null set)
-//   - If EQ satisfies every C, return true
-//   - Else return false
-// - If GT
-//   - If GT.semver is lower than any > or >= comp in C, return false
-//   - If GT is >=, and GT.semver does not satisfy every C, return false
-// - If LT
-//   - If LT.semver is greater than any < or <= comp in C, return false
-//   - If LT is <=, and LT.semver does not satisfy every C, return false
-// - If any C is a = range, and GT or LT are set, return false
-// - Else return true
+  while (entry) {
+    var cb = entry.callback;
+    state.pendingcb--;
+    cb(err);
+    entry = entry.next;
+  } // reuse the free corkReq.
 
-const subset = (sub, dom, options) => {
-  if (sub === dom)
-    return true
 
-  sub = new Range(sub, options)
-  dom = new Range(dom, options)
-  let sawNonNull = false
+  state.corkedRequestsFree.next = corkReq;
+}
 
-  OUTER: for (const simpleSub of sub.set) {
-    for (const simpleDom of dom.set) {
-      const isSub = simpleSubset(simpleSub, simpleDom, options)
-      sawNonNull = sawNonNull || isSub !== null
-      if (isSub)
-        continue OUTER
+Object.defineProperty(Writable.prototype, 'destroyed', {
+  // making it explicit this property is not enumerable
+  // because otherwise some prototype manipulation in
+  // userland will fail
+  enumerable: false,
+  get: function get() {
+    if (this._writableState === undefined) {
+      return false;
     }
-    // the null set is a subset of everything, but null simple ranges in
-    // a complex range should be ignored.  so if we saw a non-null range,
-    // then we know this isn't a subset, but if EVERY simple range was null,
-    // then it is a subset.
-    if (sawNonNull)
-      return false
-  }
-  return true
-}
 
-const simpleSubset = (sub, dom, options) => {
-  if (sub === dom)
-    return true
+    return this._writableState.destroyed;
+  },
+  set: function set(value) {
+    // we ignore the value if the stream
+    // has not been initialized yet
+    if (!this._writableState) {
+      return;
+    } // backward compatibility, the user is explicitly
+    // managing destroyed
 
-  if (sub.length === 1 && sub[0].semver === ANY)
-    return dom.length === 1 && dom[0].semver === ANY
 
-  const eqSet = new Set()
-  let gt, lt
-  for (const c of sub) {
-    if (c.operator === '>' || c.operator === '>=')
-      gt = higherGT(gt, c, options)
-    else if (c.operator === '<' || c.operator === '<=')
-      lt = lowerLT(lt, c, options)
-    else
-      eqSet.add(c.semver)
+    this._writableState.destroyed = value;
   }
+});
+Writable.prototype.destroy = destroyImpl.destroy;
+Writable.prototype._undestroy = destroyImpl.undestroy;
 
-  if (eqSet.size > 1)
-    return null
+Writable.prototype._destroy = function (err, cb) {
+  cb(err);
+};
 
-  let gtltComp
-  if (gt && lt) {
-    gtltComp = compare(gt.semver, lt.semver, options)
-    if (gtltComp > 0)
-      return null
-    else if (gtltComp === 0 && (gt.operator !== '>=' || lt.operator !== '<='))
-      return null
-  }
+/***/ }),
 
-  // will iterate one or zero times
-  for (const eq of eqSet) {
-    if (gt && !satisfies(eq, String(gt), options))
-      return null
+/***/ 51780:
+/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
-    if (lt && !satisfies(eq, String(lt), options))
-      return null
+"use strict";
 
-    for (const c of dom) {
-      if (!satisfies(eq, String(c), options))
-        return false
-    }
 
-    return true
-  }
+var _Object$setPrototypeO;
 
-  let higher, lower
-  let hasDomLT, hasDomGT
-  for (const c of dom) {
-    hasDomGT = hasDomGT || c.operator === '>' || c.operator === '>='
-    hasDomLT = hasDomLT || c.operator === '<' || c.operator === '<='
-    if (gt) {
-      if (c.operator === '>' || c.operator === '>=') {
-        higher = higherGT(gt, c, options)
-        if (higher === c && higher !== gt)
-          return false
-      } else if (gt.operator === '>=' && !satisfies(gt.semver, String(c), options))
-        return false
-    }
-    if (lt) {
-      if (c.operator === '<' || c.operator === '<=') {
-        lower = lowerLT(lt, c, options)
-        if (lower === c && lower !== lt)
-          return false
-      } else if (lt.operator === '<=' && !satisfies(lt.semver, String(c), options))
-        return false
-    }
-    if (!c.operator && (lt || gt) && gtltComp !== 0)
-      return false
-  }
+function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
 
-  // if there was a < or >, and nothing in the dom, then must be false
-  // UNLESS it was limited by another range in the other direction.
-  // Eg, >1.0.0 <1.0.1 is still a subset of <2.0.0
-  if (gt && hasDomLT && !lt && gtltComp !== 0)
-    return false
+var finished = __nccwpck_require__(75628);
 
-  if (lt && hasDomGT && !gt && gtltComp !== 0)
-    return false
+var kLastResolve = Symbol('lastResolve');
+var kLastReject = Symbol('lastReject');
+var kError = Symbol('error');
+var kEnded = Symbol('ended');
+var kLastPromise = Symbol('lastPromise');
+var kHandlePromise = Symbol('handlePromise');
+var kStream = Symbol('stream');
 
-  return true
+function createIterResult(value, done) {
+  return {
+    value: value,
+    done: done
+  };
 }
 
-// >=1.2.3 is lower than >1.2.3
-const higherGT = (a, b, options) => {
-  if (!a)
-    return b
-  const comp = compare(a.semver, b.semver, options)
-  return comp > 0 ? a
-    : comp < 0 ? b
-    : b.operator === '>' && a.operator === '>=' ? b
-    : a
+function readAndResolve(iter) {
+  var resolve = iter[kLastResolve];
+
+  if (resolve !== null) {
+    var data = iter[kStream].read(); // we defer if data is null
+    // we can be expecting either 'end' or
+    // 'error'
+
+    if (data !== null) {
+      iter[kLastPromise] = null;
+      iter[kLastResolve] = null;
+      iter[kLastReject] = null;
+      resolve(createIterResult(data, false));
+    }
+  }
 }
 
-// <=1.2.3 is higher than <1.2.3
-const lowerLT = (a, b, options) => {
-  if (!a)
-    return b
-  const comp = compare(a.semver, b.semver, options)
-  return comp < 0 ? a
-    : comp > 0 ? b
-    : b.operator === '<' && a.operator === '<=' ? b
-    : a
+function onReadable(iter) {
+  // we wait for the next tick, because it might
+  // emit an error with process.nextTick
+  process.nextTick(readAndResolve, iter);
 }
 
-module.exports = subset
+function wrapForNext(lastPromise, iter) {
+  return function (resolve, reject) {
+    lastPromise.then(function () {
+      if (iter[kEnded]) {
+        resolve(createIterResult(undefined, true));
+        return;
+      }
 
+      iter[kHandlePromise](resolve, reject);
+    }, reject);
+  };
+}
 
-/***/ }),
+var AsyncIteratorPrototype = Object.getPrototypeOf(function () {});
+var ReadableStreamAsyncIteratorPrototype = Object.setPrototypeOf((_Object$setPrototypeO = {
+  get stream() {
+    return this[kStream];
+  },
 
-/***/ 9005:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+  next: function next() {
+    var _this = this;
 
-const Range = __nccwpck_require__(39378)
+    // if we have detected an error in the meanwhile
+    // reject straight away
+    var error = this[kError];
 
-// Mostly just for testing and legacy API reasons
-const toComparators = (range, options) =>
-  new Range(range, options).set
-    .map(comp => comp.map(c => c.value).join(' ').trim().split(' '))
+    if (error !== null) {
+      return Promise.reject(error);
+    }
 
-module.exports = toComparators
+    if (this[kEnded]) {
+      return Promise.resolve(createIterResult(undefined, true));
+    }
 
+    if (this[kStream].destroyed) {
+      // We need to defer via nextTick because if .destroy(err) is
+      // called, the error will be emitted via nextTick, and
+      // we cannot guarantee that there is no error lingering around
+      // waiting to be emitted.
+      return new Promise(function (resolve, reject) {
+        process.nextTick(function () {
+          if (_this[kError]) {
+            reject(_this[kError]);
+          } else {
+            resolve(createIterResult(undefined, true));
+          }
+        });
+      });
+    } // if we have multiple next() calls
+    // we will wait for the previous Promise to finish
+    // this logic is optimized to support for await loops,
+    // where next() is only called once at a time
 
-/***/ }),
 
-/***/ 35569:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+    var lastPromise = this[kLastPromise];
+    var promise;
 
-const Range = __nccwpck_require__(39378)
-const validRange = (range, options) => {
-  try {
-    // Return '*' instead of '' so that truthiness works.
-    // This will throw if it's invalid anyway
-    return new Range(range, options).range || '*'
-  } catch (er) {
-    return null
-  }
-}
-module.exports = validRange
+    if (lastPromise) {
+      promise = new Promise(wrapForNext(lastPromise, this));
+    } else {
+      // fast path needed to support multiple this.push()
+      // without triggering the next() queue
+      var data = this[kStream].read();
 
+      if (data !== null) {
+        return Promise.resolve(createIterResult(data, false));
+      }
 
-/***/ }),
+      promise = new Promise(this[kHandlePromise]);
+    }
 
-/***/ 51796:
-/***/ ((module) => {
+    this[kLastPromise] = promise;
+    return promise;
+  }
+}, _defineProperty(_Object$setPrototypeO, Symbol.asyncIterator, function () {
+  return this;
+}), _defineProperty(_Object$setPrototypeO, "return", function _return() {
+  var _this2 = this;
 
-/******************************************************************************
-Copyright (c) Microsoft Corporation.
+  // destroy(err, cb) is a private API
+  // we can guarantee we have that here, because we control the
+  // Readable class this is attached to
+  return new Promise(function (resolve, reject) {
+    _this2[kStream].destroy(null, function (err) {
+      if (err) {
+        reject(err);
+        return;
+      }
 
-Permission to use, copy, modify, and/or distribute this software for any
-purpose with or without fee is hereby granted.
+      resolve(createIterResult(undefined, true));
+    });
+  });
+}), _Object$setPrototypeO), AsyncIteratorPrototype);
 
-THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH
-REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY
-AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,
-INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM
-LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR
-OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
-PERFORMANCE OF THIS SOFTWARE.
-***************************************************************************** */
-/* global global, define, System, Reflect, Promise */
-var __extends;
-var __assign;
-var __rest;
-var __decorate;
-var __param;
-var __esDecorate;
-var __runInitializers;
-var __propKey;
-var __setFunctionName;
-var __metadata;
-var __awaiter;
-var __generator;
-var __exportStar;
-var __values;
-var __read;
-var __spread;
-var __spreadArrays;
-var __spreadArray;
-var __await;
-var __asyncGenerator;
-var __asyncDelegator;
-var __asyncValues;
-var __makeTemplateObject;
-var __importStar;
-var __importDefault;
-var __classPrivateFieldGet;
-var __classPrivateFieldSet;
-var __classPrivateFieldIn;
-var __createBinding;
-(function (factory) {
-    var root = typeof global === "object" ? global : typeof self === "object" ? self : typeof this === "object" ? this : {};
-    if (typeof define === "function" && define.amd) {
-        define("tslib", ["exports"], function (exports) { factory(createExporter(root, createExporter(exports))); });
-    }
-    else if ( true && typeof module.exports === "object") {
-        factory(createExporter(root, createExporter(module.exports)));
-    }
-    else {
-        factory(createExporter(root));
-    }
-    function createExporter(exports, previous) {
-        if (exports !== root) {
-            if (typeof Object.create === "function") {
-                Object.defineProperty(exports, "__esModule", { value: true });
-            }
-            else {
-                exports.__esModule = true;
-            }
-        }
-        return function (id, v) { return exports[id] = previous ? previous(id, v) : v; };
-    }
-})
-(function (exporter) {
-    var extendStatics = Object.setPrototypeOf ||
-        ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
-        function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };
+var createReadableStreamAsyncIterator = function createReadableStreamAsyncIterator(stream) {
+  var _Object$create;
 
-    __extends = function (d, b) {
-        if (typeof b !== "function" && b !== null)
-            throw new TypeError("Class extends value " + String(b) + " is not a constructor or null");
-        extendStatics(d, b);
-        function __() { this.constructor = d; }
-        d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
-    };
+  var iterator = Object.create(ReadableStreamAsyncIteratorPrototype, (_Object$create = {}, _defineProperty(_Object$create, kStream, {
+    value: stream,
+    writable: true
+  }), _defineProperty(_Object$create, kLastResolve, {
+    value: null,
+    writable: true
+  }), _defineProperty(_Object$create, kLastReject, {
+    value: null,
+    writable: true
+  }), _defineProperty(_Object$create, kError, {
+    value: null,
+    writable: true
+  }), _defineProperty(_Object$create, kEnded, {
+    value: stream._readableState.endEmitted,
+    writable: true
+  }), _defineProperty(_Object$create, kHandlePromise, {
+    value: function value(resolve, reject) {
+      var data = iterator[kStream].read();
 
-    __assign = Object.assign || function (t) {
-        for (var s, i = 1, n = arguments.length; i < n; i++) {
-            s = arguments[i];
-            for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];
-        }
-        return t;
-    };
+      if (data) {
+        iterator[kLastPromise] = null;
+        iterator[kLastResolve] = null;
+        iterator[kLastReject] = null;
+        resolve(createIterResult(data, false));
+      } else {
+        iterator[kLastResolve] = resolve;
+        iterator[kLastReject] = reject;
+      }
+    },
+    writable: true
+  }), _Object$create));
+  iterator[kLastPromise] = null;
+  finished(stream, function (err) {
+    if (err && err.code !== 'ERR_STREAM_PREMATURE_CLOSE') {
+      var reject = iterator[kLastReject]; // reject if we are waiting for data in the Promise
+      // returned by next() and store the error
 
-    __rest = function (s, e) {
-        var t = {};
-        for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
-            t[p] = s[p];
-        if (s != null && typeof Object.getOwnPropertySymbols === "function")
-            for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
-                if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
-                    t[p[i]] = s[p[i]];
-            }
-        return t;
-    };
+      if (reject !== null) {
+        iterator[kLastPromise] = null;
+        iterator[kLastResolve] = null;
+        iterator[kLastReject] = null;
+        reject(err);
+      }
 
-    __decorate = function (decorators, target, key, desc) {
-        var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
-        if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
-        else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
-        return c > 3 && r && Object.defineProperty(target, key, r), r;
-    };
+      iterator[kError] = err;
+      return;
+    }
 
-    __param = function (paramIndex, decorator) {
-        return function (target, key) { decorator(target, key, paramIndex); }
-    };
+    var resolve = iterator[kLastResolve];
 
-    __esDecorate = function (ctor, descriptorIn, decorators, contextIn, initializers, extraInitializers) {
-        function accept(f) { if (f !== void 0 && typeof f !== "function") throw new TypeError("Function expected"); return f; }
-        var kind = contextIn.kind, key = kind === "getter" ? "get" : kind === "setter" ? "set" : "value";
-        var target = !descriptorIn && ctor ? contextIn["static"] ? ctor : ctor.prototype : null;
-        var descriptor = descriptorIn || (target ? Object.getOwnPropertyDescriptor(target, contextIn.name) : {});
-        var _, done = false;
-        for (var i = decorators.length - 1; i >= 0; i--) {
-            var context = {};
-            for (var p in contextIn) context[p] = p === "access" ? {} : contextIn[p];
-            for (var p in contextIn.access) context.access[p] = contextIn.access[p];
-            context.addInitializer = function (f) { if (done) throw new TypeError("Cannot add initializers after decoration has completed"); extraInitializers.push(accept(f || null)); };
-            var result = (0, decorators[i])(kind === "accessor" ? { get: descriptor.get, set: descriptor.set } : descriptor[key], context);
-            if (kind === "accessor") {
-                if (result === void 0) continue;
-                if (result === null || typeof result !== "object") throw new TypeError("Object expected");
-                if (_ = accept(result.get)) descriptor.get = _;
-                if (_ = accept(result.set)) descriptor.set = _;
-                if (_ = accept(result.init)) initializers.unshift(_);
-            }
-            else if (_ = accept(result)) {
-                if (kind === "field") initializers.unshift(_);
-                else descriptor[key] = _;
-            }
-        }
-        if (target) Object.defineProperty(target, contextIn.name, descriptor);
-        done = true;
-    };
+    if (resolve !== null) {
+      iterator[kLastPromise] = null;
+      iterator[kLastResolve] = null;
+      iterator[kLastReject] = null;
+      resolve(createIterResult(undefined, true));
+    }
 
-    __runInitializers = function (thisArg, initializers, value) {
-        var useValue = arguments.length > 2;
-        for (var i = 0; i < initializers.length; i++) {
-            value = useValue ? initializers[i].call(thisArg, value) : initializers[i].call(thisArg);
-        }
-        return useValue ? value : void 0;
-    };
+    iterator[kEnded] = true;
+  });
+  stream.on('readable', onReadable.bind(null, iterator));
+  return iterator;
+};
 
-    __propKey = function (x) {
-        return typeof x === "symbol" ? x : "".concat(x);
-    };
+module.exports = createReadableStreamAsyncIterator;
 
-    __setFunctionName = function (f, name, prefix) {
-        if (typeof name === "symbol") name = name.description ? "[".concat(name.description, "]") : "";
-        return Object.defineProperty(f, "name", { configurable: true, value: prefix ? "".concat(prefix, " ", name) : name });
-    };
+/***/ }),
 
-    __metadata = function (metadataKey, metadataValue) {
-        if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(metadataKey, metadataValue);
-    };
+/***/ 75920:
+/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
-    __awaiter = function (thisArg, _arguments, P, generator) {
-        function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
-        return new (P || (P = Promise))(function (resolve, reject) {
-            function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
-            function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
-            function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
-            step((generator = generator.apply(thisArg, _arguments || [])).next());
-        });
-    };
+"use strict";
 
-    __generator = function (thisArg, body) {
-        var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;
-        return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
-        function verb(n) { return function (v) { return step([n, v]); }; }
-        function step(op) {
-            if (f) throw new TypeError("Generator is already executing.");
-            while (g && (g = 0, op[0] && (_ = 0)), _) try {
-                if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
-                if (y = 0, t) op = [op[0] & 2, t.value];
-                switch (op[0]) {
-                    case 0: case 1: t = op; break;
-                    case 4: _.label++; return { value: op[1], done: false };
-                    case 5: _.label++; y = op[1]; op = [0]; continue;
-                    case 7: op = _.ops.pop(); _.trys.pop(); continue;
-                    default:
-                        if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
-                        if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
-                        if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
-                        if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
-                        if (t[2]) _.ops.pop();
-                        _.trys.pop(); continue;
-                }
-                op = body.call(thisArg, _);
-            } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
-            if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
-        }
-    };
 
-    __exportStar = function(m, o) {
-        for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(o, p)) __createBinding(o, m, p);
-    };
+function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }
 
-    __createBinding = Object.create ? (function(o, m, k, k2) {
-        if (k2 === undefined) k2 = k;
-        var desc = Object.getOwnPropertyDescriptor(m, k);
-        if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
-            desc = { enumerable: true, get: function() { return m[k]; } };
-        }
-        Object.defineProperty(o, k2, desc);
-    }) : (function(o, m, k, k2) {
-        if (k2 === undefined) k2 = k;
-        o[k2] = m[k];
-    });
+function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
 
-    __values = function (o) {
-        var s = typeof Symbol === "function" && Symbol.iterator, m = s && o[s], i = 0;
-        if (m) return m.call(o);
-        if (o && typeof o.length === "number") return {
-            next: function () {
-                if (o && i >= o.length) o = void 0;
-                return { value: o && o[i++], done: !o };
-            }
-        };
-        throw new TypeError(s ? "Object is not iterable." : "Symbol.iterator is not defined.");
-    };
+function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
 
-    __read = function (o, n) {
-        var m = typeof Symbol === "function" && o[Symbol.iterator];
-        if (!m) return o;
-        var i = m.call(o), r, ar = [], e;
-        try {
-            while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);
-        }
-        catch (error) { e = { error: error }; }
-        finally {
-            try {
-                if (r && !r.done && (m = i["return"])) m.call(i);
-            }
-            finally { if (e) throw e.error; }
-        }
-        return ar;
-    };
+function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
 
-    /** @deprecated */
-    __spread = function () {
-        for (var ar = [], i = 0; i < arguments.length; i++)
-            ar = ar.concat(__read(arguments[i]));
-        return ar;
-    };
+function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }
 
-    /** @deprecated */
-    __spreadArrays = function () {
-        for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;
-        for (var r = Array(s), k = 0, i = 0; i < il; i++)
-            for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)
-                r[k] = a[j];
-        return r;
-    };
+function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }
 
-    __spreadArray = function (to, from, pack) {
-        if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {
-            if (ar || !(i in from)) {
-                if (!ar) ar = Array.prototype.slice.call(from, 0, i);
-                ar[i] = from[i];
-            }
-        }
-        return to.concat(ar || Array.prototype.slice.call(from));
-    };
+var _require = __nccwpck_require__(14300),
+    Buffer = _require.Buffer;
 
-    __await = function (v) {
-        return this instanceof __await ? (this.v = v, this) : new __await(v);
-    };
+var _require2 = __nccwpck_require__(73837),
+    inspect = _require2.inspect;
 
-    __asyncGenerator = function (thisArg, _arguments, generator) {
-        if (!Symbol.asyncIterator) throw new TypeError("Symbol.asyncIterator is not defined.");
-        var g = generator.apply(thisArg, _arguments || []), i, q = [];
-        return i = {}, verb("next"), verb("throw"), verb("return"), i[Symbol.asyncIterator] = function () { return this; }, i;
-        function verb(n) { if (g[n]) i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; }
-        function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } }
-        function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r);  }
-        function fulfill(value) { resume("next", value); }
-        function reject(value) { resume("throw", value); }
-        function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); }
-    };
+var custom = inspect && inspect.custom || 'inspect';
 
-    __asyncDelegator = function (o) {
-        var i, p;
-        return i = {}, verb("next"), verb("throw", function (e) { throw e; }), verb("return"), i[Symbol.iterator] = function () { return this; }, i;
-        function verb(n, f) { i[n] = o[n] ? function (v) { return (p = !p) ? { value: __await(o[n](v)), done: false } : f ? f(v) : v; } : f; }
-    };
+function copyBuffer(src, target, offset) {
+  Buffer.prototype.copy.call(src, target, offset);
+}
 
-    __asyncValues = function (o) {
-        if (!Symbol.asyncIterator) throw new TypeError("Symbol.asyncIterator is not defined.");
-        var m = o[Symbol.asyncIterator], i;
-        return m ? m.call(o) : (o = typeof __values === "function" ? __values(o) : o[Symbol.iterator](), i = {}, verb("next"), verb("throw"), verb("return"), i[Symbol.asyncIterator] = function () { return this; }, i);
-        function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; }
-        function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); }
-    };
+module.exports =
+/*#__PURE__*/
+function () {
+  function BufferList() {
+    _classCallCheck(this, BufferList);
 
-    __makeTemplateObject = function (cooked, raw) {
-        if (Object.defineProperty) { Object.defineProperty(cooked, "raw", { value: raw }); } else { cooked.raw = raw; }
-        return cooked;
-    };
+    this.head = null;
+    this.tail = null;
+    this.length = 0;
+  }
 
-    var __setModuleDefault = Object.create ? (function(o, v) {
-        Object.defineProperty(o, "default", { enumerable: true, value: v });
-    }) : function(o, v) {
-        o["default"] = v;
-    };
+  _createClass(BufferList, [{
+    key: "push",
+    value: function push(v) {
+      var entry = {
+        data: v,
+        next: null
+      };
+      if (this.length > 0) this.tail.next = entry;else this.head = entry;
+      this.tail = entry;
+      ++this.length;
+    }
+  }, {
+    key: "unshift",
+    value: function unshift(v) {
+      var entry = {
+        data: v,
+        next: this.head
+      };
+      if (this.length === 0) this.tail = entry;
+      this.head = entry;
+      ++this.length;
+    }
+  }, {
+    key: "shift",
+    value: function shift() {
+      if (this.length === 0) return;
+      var ret = this.head.data;
+      if (this.length === 1) this.head = this.tail = null;else this.head = this.head.next;
+      --this.length;
+      return ret;
+    }
+  }, {
+    key: "clear",
+    value: function clear() {
+      this.head = this.tail = null;
+      this.length = 0;
+    }
+  }, {
+    key: "join",
+    value: function join(s) {
+      if (this.length === 0) return '';
+      var p = this.head;
+      var ret = '' + p.data;
 
-    __importStar = function (mod) {
-        if (mod && mod.__esModule) return mod;
-        var result = {};
-        if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
-        __setModuleDefault(result, mod);
-        return result;
-    };
+      while (p = p.next) {
+        ret += s + p.data;
+      }
 
-    __importDefault = function (mod) {
-        return (mod && mod.__esModule) ? mod : { "default": mod };
-    };
+      return ret;
+    }
+  }, {
+    key: "concat",
+    value: function concat(n) {
+      if (this.length === 0) return Buffer.alloc(0);
+      var ret = Buffer.allocUnsafe(n >>> 0);
+      var p = this.head;
+      var i = 0;
 
-    __classPrivateFieldGet = function (receiver, state, kind, f) {
-        if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a getter");
-        if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot read private member from an object whose class did not declare it");
-        return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
-    };
+      while (p) {
+        copyBuffer(p.data, ret, i);
+        i += p.data.length;
+        p = p.next;
+      }
 
-    __classPrivateFieldSet = function (receiver, state, value, kind, f) {
-        if (kind === "m") throw new TypeError("Private method is not writable");
-        if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a setter");
-        if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot write private member to an object whose class did not declare it");
-        return (kind === "a" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;
-    };
+      return ret;
+    } // Consumes a specified amount of bytes or characters from the buffered data.
 
-    __classPrivateFieldIn = function (state, receiver) {
-        if (receiver === null || (typeof receiver !== "object" && typeof receiver !== "function")) throw new TypeError("Cannot use 'in' operator on non-object");
-        return typeof state === "function" ? receiver === state : state.has(receiver);
-    };
+  }, {
+    key: "consume",
+    value: function consume(n, hasStrings) {
+      var ret;
 
-    exporter("__extends", __extends);
-    exporter("__assign", __assign);
-    exporter("__rest", __rest);
-    exporter("__decorate", __decorate);
-    exporter("__param", __param);
-    exporter("__esDecorate", __esDecorate);
-    exporter("__runInitializers", __runInitializers);
-    exporter("__propKey", __propKey);
-    exporter("__setFunctionName", __setFunctionName);
-    exporter("__metadata", __metadata);
-    exporter("__awaiter", __awaiter);
-    exporter("__generator", __generator);
-    exporter("__exportStar", __exportStar);
-    exporter("__createBinding", __createBinding);
-    exporter("__values", __values);
-    exporter("__read", __read);
-    exporter("__spread", __spread);
-    exporter("__spreadArrays", __spreadArrays);
-    exporter("__spreadArray", __spreadArray);
-    exporter("__await", __await);
-    exporter("__asyncGenerator", __asyncGenerator);
-    exporter("__asyncDelegator", __asyncDelegator);
-    exporter("__asyncValues", __asyncValues);
-    exporter("__makeTemplateObject", __makeTemplateObject);
-    exporter("__importStar", __importStar);
-    exporter("__importDefault", __importDefault);
-    exporter("__classPrivateFieldGet", __classPrivateFieldGet);
-    exporter("__classPrivateFieldSet", __classPrivateFieldSet);
-    exporter("__classPrivateFieldIn", __classPrivateFieldIn);
-});
+      if (n < this.head.data.length) {
+        // `slice` is the same for buffers and strings.
+        ret = this.head.data.slice(0, n);
+        this.head.data = this.head.data.slice(n);
+      } else if (n === this.head.data.length) {
+        // First chunk is a perfect match.
+        ret = this.shift();
+      } else {
+        // Result spans more than one buffer.
+        ret = hasStrings ? this._getString(n) : this._getBuffer(n);
+      }
+
+      return ret;
+    }
+  }, {
+    key: "first",
+    value: function first() {
+      return this.head.data;
+    } // Consumes a specified amount of characters from the buffered data.
+
+  }, {
+    key: "_getString",
+    value: function _getString(n) {
+      var p = this.head;
+      var c = 1;
+      var ret = p.data;
+      n -= ret.length;
+
+      while (p = p.next) {
+        var str = p.data;
+        var nb = n > str.length ? str.length : n;
+        if (nb === str.length) ret += str;else ret += str.slice(0, n);
+        n -= nb;
+
+        if (n === 0) {
+          if (nb === str.length) {
+            ++c;
+            if (p.next) this.head = p.next;else this.head = this.tail = null;
+          } else {
+            this.head = p;
+            p.data = str.slice(nb);
+          }
+
+          break;
+        }
+
+        ++c;
+      }
+
+      this.length -= c;
+      return ret;
+    } // Consumes a specified amount of bytes from the buffered data.
+
+  }, {
+    key: "_getBuffer",
+    value: function _getBuffer(n) {
+      var ret = Buffer.allocUnsafe(n);
+      var p = this.head;
+      var c = 1;
+      p.data.copy(ret);
+      n -= p.data.length;
+
+      while (p = p.next) {
+        var buf = p.data;
+        var nb = n > buf.length ? buf.length : n;
+        buf.copy(ret, ret.length - n, 0, nb);
+        n -= nb;
+
+        if (n === 0) {
+          if (nb === buf.length) {
+            ++c;
+            if (p.next) this.head = p.next;else this.head = this.tail = null;
+          } else {
+            this.head = p;
+            p.data = buf.slice(nb);
+          }
+
+          break;
+        }
+
+        ++c;
+      }
+
+      this.length -= c;
+      return ret;
+    } // Make sure the linked list only shows the minimal necessary information.
+
+  }, {
+    key: custom,
+    value: function value(_, options) {
+      return inspect(this, _objectSpread({}, options, {
+        // Only inspect one level.
+        depth: 0,
+        // It should not recurse.
+        customInspect: false
+      }));
+    }
+  }]);
 
+  return BufferList;
+}();
 
 /***/ }),
 
-/***/ 36803:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
+/***/ 33148:
+/***/ ((module) => {
 
 "use strict";
+ // undocumented cb() API, needed for core, not for public API
 
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.toOldFormat = exports.toNewFormat = exports.mergeAngularJsonAndGlobProjects = exports.isAngularPluginInstalled = exports.shouldMergeAngularProjects = void 0;
-const fs_1 = __nccwpck_require__(57147);
-const path = __nccwpck_require__(71017);
-const fileutils_1 = __nccwpck_require__(47930);
-const workspaces_1 = __nccwpck_require__(98715);
-function shouldMergeAngularProjects(root, includeProjectsFromAngularJson) {
-    if ((0, fs_1.existsSync)(path.join(root, 'angular.json')) &&
-        // Include projects from angular.json if explicitly required.
-        // e.g. when invoked from `packages/devkit/src/utils/convert-nx-executor.ts`
-        (includeProjectsFromAngularJson ||
-            // Or if a workspace has `@nrwl/angular`/`@nx/angular` installed then projects from `angular.json` to be considered by Nx.
-            isAngularPluginInstalled())) {
-        return true;
+function destroy(err, cb) {
+  var _this = this;
+
+  var readableDestroyed = this._readableState && this._readableState.destroyed;
+  var writableDestroyed = this._writableState && this._writableState.destroyed;
+
+  if (readableDestroyed || writableDestroyed) {
+    if (cb) {
+      cb(err);
+    } else if (err) {
+      if (!this._writableState) {
+        process.nextTick(emitErrorNT, this, err);
+      } else if (!this._writableState.errorEmitted) {
+        this._writableState.errorEmitted = true;
+        process.nextTick(emitErrorNT, this, err);
+      }
     }
-    else {
-        return false;
+
+    return this;
+  } // we set destroyed to true before firing error callbacks in order
+  // to make it re-entrance safe in case destroy() is called within callbacks
+
+
+  if (this._readableState) {
+    this._readableState.destroyed = true;
+  } // if this is a duplex stream mark the writable part as destroyed as well
+
+
+  if (this._writableState) {
+    this._writableState.destroyed = true;
+  }
+
+  this._destroy(err || null, function (err) {
+    if (!cb && err) {
+      if (!_this._writableState) {
+        process.nextTick(emitErrorAndCloseNT, _this, err);
+      } else if (!_this._writableState.errorEmitted) {
+        _this._writableState.errorEmitted = true;
+        process.nextTick(emitErrorAndCloseNT, _this, err);
+      } else {
+        process.nextTick(emitCloseNT, _this);
+      }
+    } else if (cb) {
+      process.nextTick(emitCloseNT, _this);
+      cb(err);
+    } else {
+      process.nextTick(emitCloseNT, _this);
     }
+  });
+
+  return this;
 }
-exports.shouldMergeAngularProjects = shouldMergeAngularProjects;
-function isAngularPluginInstalled() {
-    try {
-        require.resolve('@nx/angular');
-        return true;
-    }
-    catch (_a) {
-        try {
-            require.resolve('@nrwl/angular');
-            return true;
-        }
-        catch (_b) {
-            return false;
-        }
-    }
+
+function emitErrorAndCloseNT(self, err) {
+  emitErrorNT(self, err);
+  emitCloseNT(self);
 }
-exports.isAngularPluginInstalled = isAngularPluginInstalled;
-function readAngularJson(angularCliWorkspaceRoot) {
-    return toNewFormat((0, fileutils_1.readJsonFile)(path.join(angularCliWorkspaceRoot, 'angular.json'))).projects;
+
+function emitCloseNT(self) {
+  if (self._writableState && !self._writableState.emitClose) return;
+  if (self._readableState && !self._readableState.emitClose) return;
+  self.emit('close');
 }
-function mergeAngularJsonAndGlobProjects(globProjects, angularCliWorkspaceRoot) {
-    const res = readAngularJson(angularCliWorkspaceRoot);
-    const folders = new Set();
-    for (let k of Object.keys(res)) {
-        folders.add(res[k].root);
-    }
-    for (let k of Object.keys(globProjects)) {
-        if (!folders.has(globProjects[k].root)) {
-            res[k] = globProjects[k];
-        }
-    }
-    return res;
+
+function undestroy() {
+  if (this._readableState) {
+    this._readableState.destroyed = false;
+    this._readableState.reading = false;
+    this._readableState.ended = false;
+    this._readableState.endEmitted = false;
+  }
+
+  if (this._writableState) {
+    this._writableState.destroyed = false;
+    this._writableState.ended = false;
+    this._writableState.ending = false;
+    this._writableState.finalCalled = false;
+    this._writableState.prefinished = false;
+    this._writableState.finished = false;
+    this._writableState.errorEmitted = false;
+  }
 }
-exports.mergeAngularJsonAndGlobProjects = mergeAngularJsonAndGlobProjects;
-function toNewFormat(w) {
-    Object.values(w.projects || {}).forEach((projectConfig) => {
-        if (projectConfig.architect) {
-            (0, workspaces_1.renamePropertyWithStableKeys)(projectConfig, 'architect', 'targets');
-        }
-        if (projectConfig.schematics) {
-            (0, workspaces_1.renamePropertyWithStableKeys)(projectConfig, 'schematics', 'generators');
-        }
-        Object.values(projectConfig.targets || {}).forEach((target) => {
-            if (target.builder !== undefined) {
-                (0, workspaces_1.renamePropertyWithStableKeys)(target, 'builder', 'executor');
-            }
-        });
-    });
-    if (w.schematics) {
-        (0, workspaces_1.renamePropertyWithStableKeys)(w, 'schematics', 'generators');
-    }
-    if (w.version !== 2) {
-        w.version = 2;
-    }
-    return w;
+
+function emitErrorNT(self, err) {
+  self.emit('error', err);
 }
-exports.toNewFormat = toNewFormat;
-function toOldFormat(w) {
-    Object.values(w.projects || {}).forEach((projectConfig) => {
-        if (typeof projectConfig === 'string') {
-            throw new Error("'project.json' files are incompatible with version 1 workspace schemas.");
-        }
-        if (projectConfig.targets) {
-            (0, workspaces_1.renamePropertyWithStableKeys)(projectConfig, 'targets', 'architect');
-        }
-        if (projectConfig.generators) {
-            (0, workspaces_1.renamePropertyWithStableKeys)(projectConfig, 'generators', 'schematics');
-        }
-        delete projectConfig.name;
-        Object.values(projectConfig.architect || {}).forEach((target) => {
-            if (target.executor !== undefined) {
-                (0, workspaces_1.renamePropertyWithStableKeys)(target, 'executor', 'builder');
-            }
-        });
-    });
-    if (w.generators) {
-        (0, workspaces_1.renamePropertyWithStableKeys)(w, 'generators', 'schematics');
-    }
-    if (w.version !== 1) {
-        w.version = 1;
-    }
-    return w;
+
+function errorOrDestroy(stream, err) {
+  // We have tests that rely on errors being emitted
+  // in the same tick, so changing this is semver major.
+  // For now when you opt-in to autoDestroy we allow
+  // the error to be emitted nextTick. In a future
+  // semver major update we should change the default to this.
+  var rState = stream._readableState;
+  var wState = stream._writableState;
+  if (rState && rState.autoDestroy || wState && wState.autoDestroy) stream.destroy(err);else stream.emit('error', err);
 }
-exports.toOldFormat = toOldFormat;
 
+module.exports = {
+  destroy: destroy,
+  undestroy: undestroy,
+  errorOrDestroy: errorOrDestroy
+};
 
 /***/ }),
 
-/***/ 65459:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
+/***/ 75628:
+/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
+// Ported from https://github.com/mafintosh/end-of-stream with
+// permission from the author, Mathias Buus (@mafintosh).
 
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.workspaceLayout = exports.readAllWorkspaceConfiguration = exports.readNxJson = void 0;
-const workspaces_1 = __nccwpck_require__(98715);
-const workspace_root_1 = __nccwpck_require__(65766);
-function readNxJson() {
-    return new workspaces_1.Workspaces(workspace_root_1.workspaceRoot).readNxJson();
-}
-exports.readNxJson = readNxJson;
-// TODO(vsavkin): Remove after Nx 16 is out
-/**
- * @deprecated Use readProjectsConfigurationFromProjectGraph(await createProjectGraphAsync())
- */
-function readAllWorkspaceConfiguration() {
-    return new workspaces_1.Workspaces(workspace_root_1.workspaceRoot).readProjectsConfigurations();
+
+var ERR_STREAM_PREMATURE_CLOSE = (__nccwpck_require__(90646)/* .codes.ERR_STREAM_PREMATURE_CLOSE */ .q.ERR_STREAM_PREMATURE_CLOSE);
+
+function once(callback) {
+  var called = false;
+  return function () {
+    if (called) return;
+    called = true;
+
+    for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
+      args[_key] = arguments[_key];
+    }
+
+    callback.apply(this, args);
+  };
 }
-exports.readAllWorkspaceConfiguration = readAllWorkspaceConfiguration;
-/**
- * Returns information about where apps and libs will be created.
- */
-function workspaceLayout() {
-    var _a, _b, _c, _d;
-    const nxJson = readNxJson();
-    return {
-        appsDir: (_b = (_a = nxJson.workspaceLayout) === null || _a === void 0 ? void 0 : _a.appsDir) !== null && _b !== void 0 ? _b : 'apps',
-        libsDir: (_d = (_c = nxJson.workspaceLayout) === null || _c === void 0 ? void 0 : _c.libsDir) !== null && _d !== void 0 ? _d : 'libs',
-    };
+
+function noop() {}
+
+function isRequest(stream) {
+  return stream.setHeader && typeof stream.abort === 'function';
 }
-exports.workspaceLayout = workspaceLayout;
 
+function eos(stream, opts, callback) {
+  if (typeof opts === 'function') return eos(stream, null, opts);
+  if (!opts) opts = {};
+  callback = once(callback || noop);
+  var readable = opts.readable || opts.readable !== false && stream.readable;
+  var writable = opts.writable || opts.writable !== false && stream.writable;
 
-/***/ }),
+  var onlegacyfinish = function onlegacyfinish() {
+    if (!stream.writable) onfinish();
+  };
 
-/***/ 49899:
-/***/ ((__unused_webpack_module, exports) => {
+  var writableEnded = stream._writableState && stream._writableState.finished;
 
-"use strict";
+  var onfinish = function onfinish() {
+    writable = false;
+    writableEnded = true;
+    if (!readable) callback.call(stream);
+  };
 
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.DependencyType = exports.fileDataDepType = exports.fileDataDepTarget = void 0;
-function fileDataDepTarget(dep) {
-    return typeof dep === 'string' ? dep : dep[0];
-}
-exports.fileDataDepTarget = fileDataDepTarget;
-function fileDataDepType(dep) {
-    return typeof dep === 'string' ? 'static' : dep[1];
+  var readableEnded = stream._readableState && stream._readableState.endEmitted;
+
+  var onend = function onend() {
+    readable = false;
+    readableEnded = true;
+    if (!writable) callback.call(stream);
+  };
+
+  var onerror = function onerror(err) {
+    callback.call(stream, err);
+  };
+
+  var onclose = function onclose() {
+    var err;
+
+    if (readable && !readableEnded) {
+      if (!stream._readableState || !stream._readableState.ended) err = new ERR_STREAM_PREMATURE_CLOSE();
+      return callback.call(stream, err);
+    }
+
+    if (writable && !writableEnded) {
+      if (!stream._writableState || !stream._writableState.ended) err = new ERR_STREAM_PREMATURE_CLOSE();
+      return callback.call(stream, err);
+    }
+  };
+
+  var onrequest = function onrequest() {
+    stream.req.on('finish', onfinish);
+  };
+
+  if (isRequest(stream)) {
+    stream.on('complete', onfinish);
+    stream.on('abort', onclose);
+    if (stream.req) onrequest();else stream.on('request', onrequest);
+  } else if (writable && !stream._writableState) {
+    // legacy streams
+    stream.on('end', onlegacyfinish);
+    stream.on('close', onlegacyfinish);
+  }
+
+  stream.on('end', onend);
+  stream.on('finish', onfinish);
+  if (opts.error !== false) stream.on('error', onerror);
+  stream.on('close', onclose);
+  return function () {
+    stream.removeListener('complete', onfinish);
+    stream.removeListener('abort', onclose);
+    stream.removeListener('request', onrequest);
+    if (stream.req) stream.req.removeListener('finish', onfinish);
+    stream.removeListener('end', onlegacyfinish);
+    stream.removeListener('close', onlegacyfinish);
+    stream.removeListener('finish', onfinish);
+    stream.removeListener('end', onend);
+    stream.removeListener('error', onerror);
+    stream.removeListener('close', onclose);
+  };
 }
-exports.fileDataDepType = fileDataDepType;
-/**
- * Type of dependency between projects
- */
-var DependencyType;
-(function (DependencyType) {
-    /**
-     * Static dependencies are tied to the loading of the module
-     */
-    DependencyType["static"] = "static";
-    /**
-     * Dynamic dependencies are brought in by the module at run time
-     */
-    DependencyType["dynamic"] = "dynamic";
-    /**
-     * Implicit dependencies are inferred
-     */
-    DependencyType["implicit"] = "implicit";
-})(DependencyType = exports.DependencyType || (exports.DependencyType = {}));
 
+module.exports = eos;
 
 /***/ }),
 
-/***/ 98715:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
+/***/ 42881:
+/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
 
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.renamePropertyWithStableKeys = exports.readTargetDefaultsForTarget = exports.mergeTargetConfigurations = exports.buildProjectsConfigurationsFromGlobs = exports.inferProjectFromNonStandardFile = exports.deduplicateProjectFiles = exports.globForProjectFiles = exports.getGlobPatternsFromPackageManagerWorkspaces = exports.getGlobPatternsFromPluginsAsync = exports.getGlobPatternsFromPlugins = exports.toProjectName = exports.normalizeExecutorSchema = exports.Workspaces = void 0;
-const tslib_1 = __nccwpck_require__(51796);
-const fast_glob_1 = __nccwpck_require__(19131);
-const fs_1 = __nccwpck_require__(57147);
-const path = __nccwpck_require__(71017);
-const path_1 = __nccwpck_require__(71017);
-const perf_hooks_1 = __nccwpck_require__(4074);
-const workspace_root_1 = __nccwpck_require__(65766);
-const fileutils_1 = __nccwpck_require__(47930);
-const logger_1 = __nccwpck_require__(95324);
-const nx_plugin_1 = __nccwpck_require__(86740);
-const output_1 = __nccwpck_require__(34548);
-const path_2 = __nccwpck_require__(75878);
-const angular_json_1 = __nccwpck_require__(36803);
-const installation_directory_1 = __nccwpck_require__(35075);
-const ignore_1 = __nccwpck_require__(98845);
-const find_project_for_path_1 = __nccwpck_require__(36265);
-class Workspaces {
-    constructor(root) {
-        this.root = root;
-    }
-    relativeCwd(cwd) {
-        return path.relative(this.root, cwd).replace(/\\/g, '/') || null;
-    }
-    calculateDefaultProjectName(cwd, { projects }, nxJson) {
-        var _a;
-        const relativeCwd = this.relativeCwd(cwd);
-        if (relativeCwd) {
-            const matchingProject = findMatchingProjectInCwd(projects, relativeCwd);
-            // We have found a project
-            if (matchingProject) {
-                // That is not at the root
-                if (projects[matchingProject].root !== '.' &&
-                    projects[matchingProject].root !== '') {
-                    return matchingProject;
-                    // But its at the root, and NX_DEFAULT_PROJECT is set
-                }
-                else if (process.env.NX_DEFAULT_PROJECT) {
-                    return process.env.NX_DEFAULT_PROJECT;
-                    // Its root, and NX_DEFAULT_PROJECT is not set
-                }
-                else {
-                    return matchingProject;
-                }
-            }
-        }
-        // There was no matching project in cwd.
-        return (_a = process.env.NX_DEFAULT_PROJECT) !== null && _a !== void 0 ? _a : nxJson === null || nxJson === void 0 ? void 0 : nxJson.defaultProject;
-    }
-    /**
-     * @deprecated
-     */
-    readProjectsConfigurations(opts) {
-        if (this.cachedProjectsConfig &&
-            process.env.NX_CACHE_PROJECTS_CONFIG !== 'false') {
-            return this.cachedProjectsConfig;
-        }
-        const nxJson = this.readNxJson();
-        const projectsConfigurations = buildProjectsConfigurationsFromGlobs(nxJson, globForProjectFiles(this.root, (opts === null || opts === void 0 ? void 0 : opts._ignorePluginInference)
-            ? []
-            : getGlobPatternsFromPlugins(nxJson, (0, installation_directory_1.getNxRequirePaths)(this.root), this.root), nxJson), (path) => (0, fileutils_1.readJsonFile)((0, path_1.join)(this.root, path)));
-        if ((0, angular_json_1.shouldMergeAngularProjects)(this.root, opts === null || opts === void 0 ? void 0 : opts._includeProjectsFromAngularJson)) {
-            projectsConfigurations.projects = (0, angular_json_1.mergeAngularJsonAndGlobProjects)(projectsConfigurations.projects, this.root);
-        }
-        this.cachedProjectsConfig = this.mergeTargetDefaultsIntoProjectDescriptions(projectsConfigurations, nxJson);
-        return this.cachedProjectsConfig;
-    }
-    /**
-     * Deprecated. Use readProjectsConfigurations
-     */
-    readWorkspaceConfiguration(opts) {
-        const nxJson = this.readNxJson();
-        return Object.assign(Object.assign({}, this.readProjectsConfigurations(opts)), nxJson);
-    }
-    mergeTargetDefaultsIntoProjectDescriptions(config, nxJson) {
-        for (const proj of Object.values(config.projects)) {
-            if (proj.targets) {
-                for (const targetName of Object.keys(proj.targets)) {
-                    const projectTargetDefinition = proj.targets[targetName];
-                    const defaults = readTargetDefaultsForTarget(targetName, nxJson.targetDefaults, projectTargetDefinition.executor);
-                    if (defaults) {
-                        proj.targets[targetName] = mergeTargetConfigurations(proj, targetName, defaults);
-                    }
-                }
-            }
-        }
-        return config;
-    }
-    isNxExecutor(nodeModule, executor) {
-        return !this.readExecutor(nodeModule, executor).isNgCompat;
-    }
-    isNxGenerator(collectionName, generatorName) {
-        return !this.readGenerator(collectionName, generatorName).isNgCompat;
-    }
-    readExecutor(nodeModule, executor) {
-        try {
-            const { executorsFilePath, executorConfig, isNgCompat } = this.readExecutorsJson(nodeModule, executor);
-            const executorsDir = path.dirname(executorsFilePath);
-            const schemaPath = this.resolveSchema(executorConfig.schema, executorsDir);
-            const schema = normalizeExecutorSchema((0, fileutils_1.readJsonFile)(schemaPath));
-            const implementationFactory = this.getImplementationFactory(executorConfig.implementation, executorsDir);
-            const batchImplementationFactory = executorConfig.batchImplementation
-                ? this.getImplementationFactory(executorConfig.batchImplementation, executorsDir)
-                : null;
-            const hasherFactory = executorConfig.hasher
-                ? this.getImplementationFactory(executorConfig.hasher, executorsDir)
-                : null;
-            return {
-                schema,
-                implementationFactory,
-                batchImplementationFactory,
-                hasherFactory,
-                isNgCompat,
-            };
-        }
-        catch (e) {
-            throw new Error(`Unable to resolve ${nodeModule}:${executor}.\n${e.message}`);
-        }
-    }
-    readGenerator(collectionName, generatorName) {
-        var _a, _b, _c, _d;
-        try {
-            const { generatorsFilePath, generatorsJson, resolvedCollectionName, normalizedGeneratorName, } = this.readGeneratorsJson(collectionName, generatorName);
-            const generatorsDir = path.dirname(generatorsFilePath);
-            const generatorConfig = ((_a = generatorsJson.generators) === null || _a === void 0 ? void 0 : _a[normalizedGeneratorName]) ||
-                ((_b = generatorsJson.schematics) === null || _b === void 0 ? void 0 : _b[normalizedGeneratorName]);
-            const isNgCompat = !((_c = generatorsJson.generators) === null || _c === void 0 ? void 0 : _c[normalizedGeneratorName]);
-            const schemaPath = this.resolveSchema(generatorConfig.schema, generatorsDir);
-            const schema = (0, fileutils_1.readJsonFile)(schemaPath);
-            if (!schema.properties || typeof schema.properties !== 'object') {
-                schema.properties = {};
-            }
-            generatorConfig.implementation =
-                generatorConfig.implementation || generatorConfig.factory;
-            const implementationFactory = this.getImplementationFactory(generatorConfig.implementation, generatorsDir);
-            const normalizedGeneratorConfiguration = Object.assign(Object.assign({}, generatorConfig), { aliases: (_d = generatorConfig.aliases) !== null && _d !== void 0 ? _d : [], hidden: !!generatorConfig.hidden });
-            return {
-                resolvedCollectionName,
-                normalizedGeneratorName,
-                schema,
-                implementationFactory,
-                isNgCompat,
-                aliases: generatorConfig.aliases || [],
-                generatorConfiguration: normalizedGeneratorConfiguration,
-            };
-        }
-        catch (e) {
-            throw new Error(`Unable to resolve ${collectionName}:${generatorName}.\n${e.message}`);
-        }
-    }
-    hasNxJson() {
-        const nxJson = path.join(this.root, 'nx.json');
-        return (0, fs_1.existsSync)(nxJson);
-    }
-    readNxJson() {
-        const nxJson = path.join(this.root, 'nx.json');
-        if ((0, fs_1.existsSync)(nxJson)) {
-            const nxJsonConfiguration = (0, fileutils_1.readJsonFile)(nxJson);
-            if (nxJsonConfiguration.extends) {
-                const extendedNxJsonPath = require.resolve(nxJsonConfiguration.extends, {
-                    paths: [(0, path_1.dirname)(nxJson)],
-                });
-                const baseNxJson = (0, fileutils_1.readJsonFile)(extendedNxJsonPath);
-                return Object.assign(Object.assign({}, baseNxJson), nxJsonConfiguration);
-            }
-            else {
-                return nxJsonConfiguration;
-            }
-        }
-        else {
-            try {
-                return (0, fileutils_1.readJsonFile)((0, path_1.join)(__dirname, '..', '..', 'presets', 'core.json'));
-            }
-            catch (e) {
-                return {};
-            }
-        }
-    }
-    getImplementationFactory(implementation, directory) {
-        const [implementationModulePath, implementationExportName] = implementation.split('#');
-        return () => {
-            var _a;
-            const modulePath = this.resolveImplementation(implementationModulePath, directory);
-            if ((0, path_1.extname)(modulePath) === '.ts') {
-                (0, nx_plugin_1.registerPluginTSTranspiler)();
-            }
-            const module = require(modulePath);
-            return implementationExportName
-                ? module[implementationExportName]
-                : (_a = module.default) !== null && _a !== void 0 ? _a : module;
-        };
-    }
-    resolveSchema(schemaPath, directory) {
-        const maybeSchemaPath = (0, path_1.join)(directory, schemaPath);
-        if ((0, fs_1.existsSync)(maybeSchemaPath)) {
-            return maybeSchemaPath;
-        }
-        return require.resolve(schemaPath, {
-            paths: [directory],
-        });
-    }
-    resolveImplementation(implementationModulePath, directory) {
-        const validImplementations = ['', '.js', '.ts'].map((x) => implementationModulePath + x);
-        for (const maybeImplementation of validImplementations) {
-            const maybeImplementationPath = (0, path_1.join)(directory, maybeImplementation);
-            if ((0, fs_1.existsSync)(maybeImplementationPath)) {
-                return maybeImplementationPath;
-            }
-            try {
-                return require.resolve(maybeImplementation, {
-                    paths: [directory],
-                });
-            }
-            catch (_a) { }
-        }
-        throw new Error(`Could not resolve "${implementationModulePath}" from "${directory}".`);
-    }
-    readExecutorsJson(nodeModule, executor) {
-        var _a, _b, _c, _d;
-        const { json: packageJson, path: packageJsonPath } = (0, nx_plugin_1.readPluginPackageJson)(nodeModule, this.resolvePaths());
-        const executorsFile = (_a = packageJson.executors) !== null && _a !== void 0 ? _a : packageJson.builders;
-        if (!executorsFile) {
-            throw new Error(`The "${nodeModule}" package does not support Nx executors.`);
-        }
-        const executorsFilePath = require.resolve(path.join(path.dirname(packageJsonPath), executorsFile));
-        const executorsJson = (0, fileutils_1.readJsonFile)(executorsFilePath);
-        const executorConfig = ((_b = executorsJson.executors) === null || _b === void 0 ? void 0 : _b[executor]) || ((_c = executorsJson.builders) === null || _c === void 0 ? void 0 : _c[executor]);
-        if (!executorConfig) {
-            throw new Error(`Cannot find executor '${executor}' in ${executorsFilePath}.`);
-        }
-        const isNgCompat = !((_d = executorsJson.executors) === null || _d === void 0 ? void 0 : _d[executor]);
-        return { executorsFilePath, executorConfig, isNgCompat };
-    }
-    readGeneratorsJson(collectionName, generator) {
-        var _a;
-        let generatorsFilePath;
-        if (collectionName.endsWith('.json')) {
-            generatorsFilePath = require.resolve(collectionName, {
-                paths: this.resolvePaths(),
-            });
-        }
-        else {
-            const { json: packageJson, path: packageJsonPath } = (0, nx_plugin_1.readPluginPackageJson)(collectionName, this.resolvePaths());
-            const generatorsFile = (_a = packageJson.generators) !== null && _a !== void 0 ? _a : packageJson.schematics;
-            if (!generatorsFile) {
-                throw new Error(`The "${collectionName}" package does not support Nx generators.`);
-            }
-            generatorsFilePath = require.resolve(path.join(path.dirname(packageJsonPath), generatorsFile));
-        }
-        const generatorsJson = (0, fileutils_1.readJsonFile)(generatorsFilePath);
-        let normalizedGeneratorName = findFullGeneratorName(generator, generatorsJson.generators) ||
-            findFullGeneratorName(generator, generatorsJson.schematics);
-        if (!normalizedGeneratorName) {
-            for (let parent of generatorsJson.extends || []) {
-                try {
-                    return this.readGeneratorsJson(parent, generator);
-                }
-                catch (e) { }
-            }
-            throw new Error(`Cannot find generator '${generator}' in ${generatorsFilePath}.`);
-        }
-        return {
-            generatorsFilePath,
-            generatorsJson,
-            normalizedGeneratorName,
-            resolvedCollectionName: collectionName,
-        };
-    }
-    resolvePaths() {
-        return this.root ? [this.root, __dirname] : [__dirname];
-    }
-}
-exports.Workspaces = Workspaces;
-function findMatchingProjectInCwd(projects, relativeCwd) {
-    const projectRootMappings = new Map();
-    for (const projectName of Object.keys(projects)) {
-        const { root } = projects[projectName];
-        projectRootMappings.set((0, find_project_for_path_1.normalizeProjectRoot)(root), projectName);
-    }
-    const matchingProject = (0, find_project_for_path_1.findProjectForPath)(relativeCwd, projectRootMappings);
-    return matchingProject;
-}
-function normalizeExecutorSchema(schema) {
-    var _a, _b;
-    const version = ((_a = schema.version) !== null && _a !== void 0 ? _a : (schema.version = 1));
-    return Object.assign({ version, outputCapture: ((_b = schema.outputCapture) !== null && _b !== void 0 ? _b : version < 2) ? 'direct-nodejs' : 'pipe', properties: !schema.properties || typeof schema.properties !== 'object'
-            ? {}
-            : schema.properties }, schema);
-}
-exports.normalizeExecutorSchema = normalizeExecutorSchema;
-function findFullGeneratorName(name, generators) {
-    if (generators) {
-        for (let [key, data] of Object.entries(generators)) {
-            if (key === name ||
-                (data.aliases && data.aliases.includes(name))) {
-                return key;
-            }
-        }
-    }
-}
-/**
- * Pulled from toFileName in names from @nx/devkit.
- * Todo: Should refactor, not duplicate.
- */
-function toProjectName(fileName) {
-    const parts = (0, path_1.dirname)(fileName).split(/[\/\\]/g);
-    return parts[parts.length - 1].toLowerCase();
-}
-exports.toProjectName = toProjectName;
-let projectGlobCache;
-let projectGlobCacheKey;
-/**
- * @deprecated Use getGlobPatternsFromPluginsAsync instead.
- */
-function getGlobPatternsFromPlugins(nxJson, paths, root = workspace_root_1.workspaceRoot) {
-    const plugins = (0, nx_plugin_1.loadNxPluginsSync)(nxJson === null || nxJson === void 0 ? void 0 : nxJson.plugins, paths, root);
-    const patterns = [];
-    for (const plugin of plugins) {
-        if (!plugin.projectFilePatterns) {
-            continue;
-        }
-        for (const filePattern of plugin.projectFilePatterns) {
-            patterns.push('**/' + filePattern);
-        }
+
+function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) { try { var info = gen[key](arg); var value = info.value; } catch (error) { reject(error); return; } if (info.done) { resolve(value); } else { Promise.resolve(value).then(_next, _throw); } }
+
+function _asyncToGenerator(fn) { return function () { var self = this, args = arguments; return new Promise(function (resolve, reject) { var gen = fn.apply(self, args); function _next(value) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, "next", value); } function _throw(err) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, "throw", err); } _next(undefined); }); }; }
+
+function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }
+
+function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
+
+function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
+
+var ERR_INVALID_ARG_TYPE = (__nccwpck_require__(90646)/* .codes.ERR_INVALID_ARG_TYPE */ .q.ERR_INVALID_ARG_TYPE);
+
+function from(Readable, iterable, opts) {
+  var iterator;
+
+  if (iterable && typeof iterable.next === 'function') {
+    iterator = iterable;
+  } else if (iterable && iterable[Symbol.asyncIterator]) iterator = iterable[Symbol.asyncIterator]();else if (iterable && iterable[Symbol.iterator]) iterator = iterable[Symbol.iterator]();else throw new ERR_INVALID_ARG_TYPE('iterable', ['Iterable'], iterable);
+
+  var readable = new Readable(_objectSpread({
+    objectMode: true
+  }, opts)); // Reading boolean to protect against _read
+  // being called before last iteration completion.
+
+  var reading = false;
+
+  readable._read = function () {
+    if (!reading) {
+      reading = true;
+      next();
     }
-    return patterns;
-}
-exports.getGlobPatternsFromPlugins = getGlobPatternsFromPlugins;
-function getGlobPatternsFromPluginsAsync(nxJson, paths, root = workspace_root_1.workspaceRoot) {
-    return tslib_1.__awaiter(this, void 0, void 0, function* () {
-        const plugins = yield (0, nx_plugin_1.loadNxPlugins)(nxJson === null || nxJson === void 0 ? void 0 : nxJson.plugins, paths, root);
-        const patterns = [];
-        for (const plugin of plugins) {
-            if (!plugin.projectFilePatterns) {
-                continue;
-            }
-            for (const filePattern of plugin.projectFilePatterns) {
-                patterns.push('**/' + filePattern);
-            }
-        }
-        return patterns;
-    });
-}
-exports.getGlobPatternsFromPluginsAsync = getGlobPatternsFromPluginsAsync;
-/**
- * Get the package.json globs from package manager workspaces
- */
-function getGlobPatternsFromPackageManagerWorkspaces(root) {
-    var _a, _b;
-    try {
-        const patterns = [];
-        const packageJson = (0, fileutils_1.readJsonFile)((0, path_1.join)(root, 'package.json'));
-        patterns.push(...normalizePatterns(Array.isArray(packageJson.workspaces)
-            ? packageJson.workspaces
-            : (_b = (_a = packageJson.workspaces) === null || _a === void 0 ? void 0 : _a.packages) !== null && _b !== void 0 ? _b : []));
-        if ((0, fs_1.existsSync)((0, path_1.join)(root, 'pnpm-workspace.yaml'))) {
-            try {
-                const { packages } = (0, fileutils_1.readYamlFile)((0, path_1.join)(root, 'pnpm-workspace.yaml'));
-                patterns.push(...normalizePatterns(packages || []));
-            }
-            catch (e) {
-                output_1.output.warn({
-                    title: `${logger_1.NX_PREFIX} Unable to parse pnpm-workspace.yaml`,
-                    bodyLines: [e.toString()],
-                });
-            }
-        }
-        if ((0, fs_1.existsSync)((0, path_1.join)(root, 'lerna.json'))) {
-            try {
-                const { packages } = (0, fileutils_1.readJsonFile)((0, path_1.join)(root, 'lerna.json'));
-                patterns.push(...normalizePatterns((packages === null || packages === void 0 ? void 0 : packages.length) > 0 ? packages : ['packages/*']));
-            }
-            catch (e) {
-                output_1.output.warn({
-                    title: `${logger_1.NX_PREFIX} Unable to parse lerna.json`,
-                    bodyLines: [e.toString()],
-                });
-            }
+  };
+
+  function next() {
+    return _next2.apply(this, arguments);
+  }
+
+  function _next2() {
+    _next2 = _asyncToGenerator(function* () {
+      try {
+        var _ref = yield iterator.next(),
+            value = _ref.value,
+            done = _ref.done;
+
+        if (done) {
+          readable.push(null);
+        } else if (readable.push((yield value))) {
+          next();
+        } else {
+          reading = false;
         }
-        // Merge patterns from workspaces definitions
-        // TODO(@AgentEnder): update logic after better way to determine root project inclusion
-        // Include the root project
-        return packageJson.nx ? patterns.concat('package.json') : patterns;
-    }
-    catch (_c) { }
-}
-exports.getGlobPatternsFromPackageManagerWorkspaces = getGlobPatternsFromPackageManagerWorkspaces;
-function normalizePatterns(patterns) {
-    return patterns.map((pattern) => removeRelativePath(pattern.endsWith('/package.json')
-        ? pattern
-        : (0, path_2.joinPathFragments)(pattern, 'package.json')));
-}
-function removeRelativePath(pattern) {
-    return pattern.startsWith('./') ? pattern.substring(2) : pattern;
-}
-function globForProjectFiles(root, pluginsGlobPatterns, nxJson) {
-    // Deal w/ Caching
-    const cacheKey = [root, ...pluginsGlobPatterns].join(',');
-    if (process.env.NX_PROJECT_GLOB_CACHE !== 'false' &&
-        projectGlobCache &&
-        cacheKey === projectGlobCacheKey) {
-        return projectGlobCache;
-    }
-    projectGlobCacheKey = cacheKey;
-    const _globPatternsFromPackageManagerWorkspaces = getGlobPatternsFromPackageManagerWorkspaces(root);
-    const globPatternsFromPackageManagerWorkspaces = _globPatternsFromPackageManagerWorkspaces !== null && _globPatternsFromPackageManagerWorkspaces !== void 0 ? _globPatternsFromPackageManagerWorkspaces : [];
-    const globsToInclude = globPatternsFromPackageManagerWorkspaces.filter((glob) => !glob.startsWith('!'));
-    const globsToExclude = globPatternsFromPackageManagerWorkspaces
-        .filter((glob) => glob.startsWith('!'))
-        .map((glob) => glob.substring(1))
-        .map((glob) => (glob.startsWith('/') ? glob.substring(1) : glob));
-    const projectGlobPatterns = [
-        'project.json',
-        '**/project.json',
-        ...globsToInclude,
-    ];
-    projectGlobPatterns.push(...pluginsGlobPatterns);
-    const combinedProjectGlobPattern = '{' + projectGlobPatterns.join(',') + '}';
-    perf_hooks_1.performance.mark('start-glob-for-projects');
-    /**
-     * This configures the files and directories which we always want to ignore as part of file watching
-     * and which we know the location of statically (meaning irrespective of user configuration files).
-     * This has the advantage of being ignored directly within globSync
-     *
-     * Other ignored entries will need to be determined dynamically by reading and evaluating the user's
-     * .gitignore and .nxignore files below.
-     */
-    const staticIgnores = [
-        'node_modules',
-        '**/node_modules',
-        'dist',
-        '.git',
-        ...globsToExclude,
-        ...(0, ignore_1.getIgnoredGlobs)(root, false),
-    ];
-    /**
-     * TODO: This utility has been implemented multiple times across the Nx codebase,
-     * discuss whether it should be moved to a shared location.
-     */
-    const opts = {
-        ignore: staticIgnores,
-        absolute: false,
-        cwd: root,
-        dot: true,
-        suppressErrors: true,
-    };
-    const globResults = (0, fast_glob_1.sync)(combinedProjectGlobPattern, opts);
-    projectGlobCache = deduplicateProjectFiles(globResults);
-    // TODO @vsavkin remove after Nx 16
-    if (projectGlobCache.length === 0 &&
-        _globPatternsFromPackageManagerWorkspaces === undefined &&
-        (nxJson === null || nxJson === void 0 ? void 0 : nxJson.extends) === 'nx/presets/npm.json') {
-        output_1.output.warn({
-            title: 'Nx could not find any projects. Check if you need to configure workspaces in package.json or pnpm-workspace.yaml',
-        });
-    }
-    perf_hooks_1.performance.mark('finish-glob-for-projects');
-    perf_hooks_1.performance.measure('glob-for-project-files', 'start-glob-for-projects', 'finish-glob-for-projects');
-    return projectGlobCache;
-}
-exports.globForProjectFiles = globForProjectFiles;
-/**
- * @description Loops through files and reduces them to 1 file per project.
- * @param files Array of files that may represent projects
- */
-function deduplicateProjectFiles(files) {
-    const filtered = new Map();
-    files.forEach((file) => {
-        const projectFolder = (0, path_1.dirname)(file);
-        const projectFile = (0, path_1.basename)(file);
-        if (filtered.has(projectFolder) && projectFile !== 'project.json')
-            return;
-        filtered.set(projectFolder, projectFile);
+      } catch (err) {
+        readable.destroy(err);
+      }
     });
-    return Array.from(filtered.entries()).map(([folder, file]) => (0, path_1.join)(folder, file));
-}
-exports.deduplicateProjectFiles = deduplicateProjectFiles;
-function buildProjectConfigurationFromPackageJson(path, packageJson, nxJson) {
-    var _a, _b, _c, _d;
-    const normalizedPath = path.split('\\').join('/');
-    const directory = (0, path_1.dirname)(normalizedPath);
-    if (!packageJson.name && directory === '.') {
-        throw new Error('Nx requires the root package.json to specify a name if it is being used as an Nx project.');
-    }
-    let name = (_a = packageJson.name) !== null && _a !== void 0 ? _a : toProjectName(normalizedPath);
-    if (nxJson === null || nxJson === void 0 ? void 0 : nxJson.npmScope) {
-        const npmPrefix = `@${nxJson.npmScope}/`;
-        if (name.startsWith(npmPrefix)) {
-            name = name.replace(npmPrefix, '');
-        }
-    }
-    const projectType = ((_b = nxJson === null || nxJson === void 0 ? void 0 : nxJson.workspaceLayout) === null || _b === void 0 ? void 0 : _b.appsDir) != ((_c = nxJson === null || nxJson === void 0 ? void 0 : nxJson.workspaceLayout) === null || _c === void 0 ? void 0 : _c.libsDir) &&
-        ((_d = nxJson === null || nxJson === void 0 ? void 0 : nxJson.workspaceLayout) === null || _d === void 0 ? void 0 : _d.appsDir) &&
-        directory.startsWith(nxJson.workspaceLayout.appsDir)
-        ? 'application'
-        : 'library';
-    return {
-        root: directory,
-        sourceRoot: directory,
-        name,
-        projectType,
-    };
+    return _next2.apply(this, arguments);
+  }
+
+  return readable;
 }
-function inferProjectFromNonStandardFile(file) {
-    const directory = (0, path_1.dirname)(file).split('\\').join('/');
-    return {
-        name: toProjectName(file),
-        root: directory,
-    };
+
+module.exports = from;
+
+/***/ }),
+
+/***/ 21451:
+/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+
+"use strict";
+// Ported from https://github.com/mafintosh/pump with
+// permission from the author, Mathias Buus (@mafintosh).
+
+
+var eos;
+
+function once(callback) {
+  var called = false;
+  return function () {
+    if (called) return;
+    called = true;
+    callback.apply(void 0, arguments);
+  };
 }
-exports.inferProjectFromNonStandardFile = inferProjectFromNonStandardFile;
-function buildProjectsConfigurationsFromGlobs(nxJson, projectFiles, // making this parameter allows devkit to pick up newly created projects
-readJson = (string) => (0, fileutils_1.readJsonFile)(string) // making this an arg allows us to reuse in devkit
-) {
-    const projects = {};
-    for (const file of projectFiles) {
-        const directory = (0, path_1.dirname)(file).split('\\').join('/');
-        const fileName = (0, path_1.basename)(file);
-        if (fileName === 'project.json') {
-            //  Nx specific project configuration (`project.json` files) in the same
-            // directory as a package.json should overwrite the inferred package.json
-            // project configuration.
-            const configuration = readJson(file);
-            configuration.root = directory;
-            let name = configuration.name;
-            if (!configuration.name) {
-                name = toProjectName(file);
-            }
-            if (!projects[name]) {
-                projects[name] = configuration;
-            }
-            else {
-                logger_1.logger.warn(`Skipping project found at ${directory} since project ${name} already exists at ${projects[name].root}! Specify a unique name for the project to allow Nx to differentiate between the two projects.`);
-            }
-        }
-        else {
-            // We can infer projects from package.json files,
-            // if a package.json file is in a directory w/o a `project.json` file.
-            // this results in targets being inferred by Nx from package scripts,
-            // and the root / sourceRoot both being the directory.
-            if (fileName === 'package.json') {
-                const projectPackageJson = readJson(file);
-                const _a = buildProjectConfigurationFromPackageJson(file, projectPackageJson, nxJson), { name } = _a, config = tslib_1.__rest(_a, ["name"]);
-                if (!projects[name]) {
-                    projects[name] = config;
-                }
-                else {
-                    logger_1.logger.warn(`Skipping project found at ${directory} since project ${name} already exists at ${projects[name].root}! Specify a unique name for the project to allow Nx to differentiate between the two projects.`);
-                }
-            }
-            else {
-                // This project was created from an nx plugin.
-                // The only thing we know about the file is its location
-                const _b = inferProjectFromNonStandardFile(file), { name } = _b, config = tslib_1.__rest(_b, ["name"]);
-                if (!projects[name]) {
-                    projects[name] = config;
-                }
-                else {
-                    logger_1.logger.error(`Skipping project inferred from ${file} since project ${name} already exists.`);
-                    throw new Error();
-                }
-            }
-        }
-    }
-    return {
-        version: 2,
-        projects: projects,
-    };
+
+var _require$codes = (__nccwpck_require__(90646)/* .codes */ .q),
+    ERR_MISSING_ARGS = _require$codes.ERR_MISSING_ARGS,
+    ERR_STREAM_DESTROYED = _require$codes.ERR_STREAM_DESTROYED;
+
+function noop(err) {
+  // Rethrow the error if it exists to avoid swallowing it
+  if (err) throw err;
 }
-exports.buildProjectsConfigurationsFromGlobs = buildProjectsConfigurationsFromGlobs;
-function mergeTargetConfigurations(projectConfiguration, target, targetDefaults) {
-    var _a, _b;
-    const targetConfiguration = (_a = projectConfiguration.targets) === null || _a === void 0 ? void 0 : _a[target];
-    if (!targetConfiguration) {
-        throw new Error(`Attempted to merge targetDefaults for ${projectConfiguration.name}.${target}, which doesn't exist.`);
-    }
-    const { configurations: defaultConfigurations, options: defaultOptions } = targetDefaults, defaults = tslib_1.__rest(targetDefaults, ["configurations", "options"]);
-    const result = Object.assign(Object.assign({}, defaults), targetConfiguration);
-    // Target is "compatible", e.g. executor is defined only once or is the same
-    // in both places. This means that it is likely safe to merge options
-    if (!targetDefaults.executor ||
-        !targetConfiguration.executor ||
-        targetDefaults.executor === targetConfiguration.executor) {
-        result.options = mergeOptions(defaultOptions, (_b = targetConfiguration.options) !== null && _b !== void 0 ? _b : {}, projectConfiguration, target);
-        result.configurations = mergeConfigurations(defaultConfigurations, targetConfiguration.configurations, projectConfiguration, target);
-    }
-    return result;
+
+function isRequest(stream) {
+  return stream.setHeader && typeof stream.abort === 'function';
 }
-exports.mergeTargetConfigurations = mergeTargetConfigurations;
-function mergeOptions(defaults, options, project, key) {
-    return Object.assign(Object.assign({}, resolvePathTokensInOptions(defaults, project, key)), options);
+
+function destroyer(stream, reading, writing, callback) {
+  callback = once(callback);
+  var closed = false;
+  stream.on('close', function () {
+    closed = true;
+  });
+  if (eos === undefined) eos = __nccwpck_require__(75628);
+  eos(stream, {
+    readable: reading,
+    writable: writing
+  }, function (err) {
+    if (err) return callback(err);
+    closed = true;
+    callback();
+  });
+  var destroyed = false;
+  return function (err) {
+    if (closed) return;
+    if (destroyed) return;
+    destroyed = true; // request.destroy just do .end - .abort is what we want
+
+    if (isRequest(stream)) return stream.abort();
+    if (typeof stream.destroy === 'function') return stream.destroy();
+    callback(err || new ERR_STREAM_DESTROYED('pipe'));
+  };
 }
-function mergeConfigurations(defaultConfigurations, projectDefinedConfigurations, project, targetName) {
-    const configurations = Object.assign({}, projectDefinedConfigurations);
-    for (const configuration in defaultConfigurations) {
-        configurations[configuration] = mergeOptions(defaultConfigurations[configuration], configurations[configuration], project, `${targetName}.${configuration}`);
-    }
-    return configurations;
+
+function call(fn) {
+  fn();
 }
-function resolvePathTokensInOptions(object, project, key) {
-    const result = Array.isArray(object) ? [...object] : Object.assign({}, object);
-    for (let [opt, value] of Object.entries(object !== null && object !== void 0 ? object : {})) {
-        if (typeof value === 'string') {
-            if (value.startsWith('{workspaceRoot}/')) {
-                value = value.replace(/^\{workspaceRoot\}\//, '');
-            }
-            if (value.includes('{workspaceRoot}')) {
-                throw new Error(`${logger_1.NX_PREFIX} The {workspaceRoot} token is only valid at the beginning of an option. (${key})`);
-            }
-            value = value.replace(/\{projectRoot\}/g, project.root);
-            result[opt] = value.replace(/\{projectName\}/g, project.name);
-        }
-        else if (typeof value === 'object' && value) {
-            result[opt] = resolvePathTokensInOptions(value, project, [key, opt].join('.'));
-        }
-    }
-    return result;
+
+function pipe(from, to) {
+  return from.pipe(to);
 }
-function readTargetDefaultsForTarget(targetName, targetDefaults, executor) {
-    if (executor) {
-        // If an executor is defined in project.json, defaults should be read
-        // from the most specific key that matches that executor.
-        // e.g. If executor === run-commands, and the target is named build:
-        // Use, use nx:run-commands if it is present
-        // If not, use build if it is present.
-        const key = [executor, targetName].find((x) => targetDefaults === null || targetDefaults === void 0 ? void 0 : targetDefaults[x]);
-        return key ? targetDefaults === null || targetDefaults === void 0 ? void 0 : targetDefaults[key] : null;
-    }
-    else {
-        // If the executor is not defined, the only key we have is the target name.
-        return targetDefaults === null || targetDefaults === void 0 ? void 0 : targetDefaults[targetName];
-    }
+
+function popCallback(streams) {
+  if (!streams.length) return noop;
+  if (typeof streams[streams.length - 1] !== 'function') return noop;
+  return streams.pop();
 }
-exports.readTargetDefaultsForTarget = readTargetDefaultsForTarget;
-// we have to do it this way to preserve the order of properties
-// not to screw up the formatting
-function renamePropertyWithStableKeys(obj, from, to) {
-    const copy = Object.assign({}, obj);
-    Object.keys(obj).forEach((k) => {
-        delete obj[k];
-    });
-    Object.keys(copy).forEach((k) => {
-        if (k === from) {
-            obj[to] = copy[k];
-        }
-        else {
-            obj[k] = copy[k];
-        }
+
+function pipeline() {
+  for (var _len = arguments.length, streams = new Array(_len), _key = 0; _key < _len; _key++) {
+    streams[_key] = arguments[_key];
+  }
+
+  var callback = popCallback(streams);
+  if (Array.isArray(streams[0])) streams = streams[0];
+
+  if (streams.length < 2) {
+    throw new ERR_MISSING_ARGS('streams');
+  }
+
+  var error;
+  var destroys = streams.map(function (stream, i) {
+    var reading = i < streams.length - 1;
+    var writing = i > 0;
+    return destroyer(stream, reading, writing, function (err) {
+      if (!error) error = err;
+      if (err) destroys.forEach(call);
+      if (reading) return;
+      destroys.forEach(call);
+      callback(error);
     });
+  });
+  return streams.reduce(pipe);
 }
-exports.renamePropertyWithStableKeys = renamePropertyWithStableKeys;
 
+module.exports = pipeline;
 
 /***/ }),
 
-/***/ 15015:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
+/***/ 12138:
+/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
 
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.getDaemonProcessIdSync = exports.safelyCleanUpExistingProcess = exports.writeDaemonJsonProcessCache = exports.deleteDaemonJsonProcessCache = exports.readDaemonProcessJsonCache = exports.serverProcessJsonPath = void 0;
-const tslib_1 = __nccwpck_require__(51796);
-const fs_extra_1 = __nccwpck_require__(59511);
-const path_1 = __nccwpck_require__(71017);
-const tmp_dir_1 = __nccwpck_require__(87196);
-exports.serverProcessJsonPath = (0, path_1.join)(tmp_dir_1.DAEMON_DIR_FOR_CURRENT_WORKSPACE, 'server-process.json');
-function readDaemonProcessJsonCache() {
-    return tslib_1.__awaiter(this, void 0, void 0, function* () {
-        if (!(0, fs_extra_1.existsSync)(exports.serverProcessJsonPath)) {
-            return null;
-        }
-        return yield (0, fs_extra_1.readJson)(exports.serverProcessJsonPath);
-    });
+
+var ERR_INVALID_OPT_VALUE = (__nccwpck_require__(90646)/* .codes.ERR_INVALID_OPT_VALUE */ .q.ERR_INVALID_OPT_VALUE);
+
+function highWaterMarkFrom(options, isDuplex, duplexKey) {
+  return options.highWaterMark != null ? options.highWaterMark : isDuplex ? options[duplexKey] : null;
 }
-exports.readDaemonProcessJsonCache = readDaemonProcessJsonCache;
-function deleteDaemonJsonProcessCache() {
-    try {
-        if (getDaemonProcessIdSync() === process.pid) {
-            (0, fs_extra_1.unlinkSync)(exports.serverProcessJsonPath);
-        }
+
+function getHighWaterMark(state, options, duplexKey, isDuplex) {
+  var hwm = highWaterMarkFrom(options, isDuplex, duplexKey);
+
+  if (hwm != null) {
+    if (!(isFinite(hwm) && Math.floor(hwm) === hwm) || hwm < 0) {
+      var name = isDuplex ? duplexKey : 'highWaterMark';
+      throw new ERR_INVALID_OPT_VALUE(name, hwm);
     }
-    catch (_a) { }
-}
-exports.deleteDaemonJsonProcessCache = deleteDaemonJsonProcessCache;
-function writeDaemonJsonProcessCache(daemonJson) {
-    return tslib_1.__awaiter(this, void 0, void 0, function* () {
-        yield (0, fs_extra_1.writeJson)(exports.serverProcessJsonPath, daemonJson);
-    });
+
+    return Math.floor(hwm);
+  } // Default value
+
+
+  return state.objectMode ? 16 : 16 * 1024;
 }
-exports.writeDaemonJsonProcessCache = writeDaemonJsonProcessCache;
-function safelyCleanUpExistingProcess() {
-    return tslib_1.__awaiter(this, void 0, void 0, function* () {
-        const daemonProcessJson = yield readDaemonProcessJsonCache();
-        if (daemonProcessJson && daemonProcessJson.processId) {
-            try {
-                process.kill(daemonProcessJson.processId);
-            }
-            catch (_a) { }
-        }
-        deleteDaemonJsonProcessCache();
-    });
+
+module.exports = {
+  getHighWaterMark: getHighWaterMark
+};
+
+/***/ }),
+
+/***/ 99004:
+/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+
+module.exports = __nccwpck_require__(12781);
+
+
+/***/ }),
+
+/***/ 17067:
+/***/ ((module, exports, __nccwpck_require__) => {
+
+var Stream = __nccwpck_require__(12781);
+if (process.env.READABLE_STREAM === 'disable' && Stream) {
+  module.exports = Stream.Readable;
+  Object.assign(module.exports, Stream);
+  module.exports.Stream = Stream;
+} else {
+  exports = module.exports = __nccwpck_require__(90960);
+  exports.Stream = Stream || exports;
+  exports.Readable = exports;
+  exports.Writable = __nccwpck_require__(23388);
+  exports.Duplex = __nccwpck_require__(97256);
+  exports.Transform = __nccwpck_require__(56765);
+  exports.PassThrough = __nccwpck_require__(17940);
+  exports.finished = __nccwpck_require__(75628);
+  exports.pipeline = __nccwpck_require__(21451);
 }
-exports.safelyCleanUpExistingProcess = safelyCleanUpExistingProcess;
-// Must be sync for the help output use case
-function getDaemonProcessIdSync() {
-    if (!(0, fs_extra_1.existsSync)(exports.serverProcessJsonPath)) {
-        return null;
+
+
+/***/ }),
+
+/***/ 30761:
+/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+
+"use strict";
+
+
+var fs = __nccwpck_require__(57147),
+  join = (__nccwpck_require__(71017).join),
+  resolve = (__nccwpck_require__(71017).resolve),
+  dirname = (__nccwpck_require__(71017).dirname),
+  defaultOptions = {
+    extensions: ['js', 'json', 'coffee'],
+    recurse: true,
+    rename: function (name) {
+      return name;
+    },
+    visit: function (obj) {
+      return obj;
     }
-    try {
-        const daemonProcessJson = (0, fs_extra_1.readJsonSync)(exports.serverProcessJsonPath);
-        return daemonProcessJson.processId;
+  };
+
+function checkFileInclusion(path, filename, options) {
+  return (
+    // verify file has valid extension
+    (new RegExp('\\.(' + options.extensions.join('|') + ')$', 'i').test(filename)) &&
+
+    // if options.include is a RegExp, evaluate it and make sure the path passes
+    !(options.include && options.include instanceof RegExp && !options.include.test(path)) &&
+
+    // if options.include is a function, evaluate it and make sure the path passes
+    !(options.include && typeof options.include === 'function' && !options.include(path, filename)) &&
+
+    // if options.exclude is a RegExp, evaluate it and make sure the path doesn't pass
+    !(options.exclude && options.exclude instanceof RegExp && options.exclude.test(path)) &&
+
+    // if options.exclude is a function, evaluate it and make sure the path doesn't pass
+    !(options.exclude && typeof options.exclude === 'function' && options.exclude(path, filename))
+  );
+}
+
+function requireDirectory(m, path, options) {
+  var retval = {};
+
+  // path is optional
+  if (path && !options && typeof path !== 'string') {
+    options = path;
+    path = null;
+  }
+
+  // default options
+  options = options || {};
+  for (var prop in defaultOptions) {
+    if (typeof options[prop] === 'undefined') {
+      options[prop] = defaultOptions[prop];
     }
-    catch (_a) {
-        return null;
+  }
+
+  // if no path was passed in, assume the equivelant of __dirname from caller
+  // otherwise, resolve path relative to the equivalent of __dirname
+  path = !path ? dirname(m.filename) : resolve(dirname(m.filename), path);
+
+  // get the path of each file in specified directory, append to current tree node, recurse
+  fs.readdirSync(path).forEach(function (filename) {
+    var joined = join(path, filename),
+      files,
+      key,
+      obj;
+
+    if (fs.statSync(joined).isDirectory() && options.recurse) {
+      // this node is a directory; recurse
+      files = requireDirectory(m, joined, options);
+      // exclude empty directories
+      if (Object.keys(files).length) {
+        retval[options.rename(filename, joined, filename)] = files;
+      }
+    } else {
+      if (joined !== m.filename && checkFileInclusion(joined, filename, options)) {
+        // hash node key shouldn't include file extension
+        key = filename.substring(0, filename.lastIndexOf('.'));
+        obj = m.require(joined);
+        retval[options.rename(key, joined, filename)] = options.visit(obj, joined, filename) || obj;
+      }
     }
+  });
+
+  return retval;
 }
-exports.getDaemonProcessIdSync = getDaemonProcessIdSync;
+
+module.exports = requireDirectory;
+module.exports.defaults = defaultOptions;
 
 
 /***/ }),
 
-/***/ 55942:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
+/***/ 88624:
+/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
-"use strict";
+const assert = __nccwpck_require__(39491)
+const path = __nccwpck_require__(71017)
+const fs = __nccwpck_require__(57147)
+let glob = undefined
+try {
+  glob = __nccwpck_require__(69959)
+} catch (_err) {
+  // treat glob as optional.
+}
 
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.daemonClient = exports.DaemonClient = void 0;
-const tslib_1 = __nccwpck_require__(51796);
-const workspace_root_1 = __nccwpck_require__(65766);
-const child_process_1 = __nccwpck_require__(32081);
-const fs_1 = __nccwpck_require__(57147);
-const promises_1 = __nccwpck_require__(73292);
-const fs_extra_1 = __nccwpck_require__(59511);
-const net_1 = __nccwpck_require__(41808);
-const path_1 = __nccwpck_require__(71017);
-const perf_hooks_1 = __nccwpck_require__(4074);
-const output_1 = __nccwpck_require__(34548);
-const socket_utils_1 = __nccwpck_require__(3497);
-const tmp_dir_1 = __nccwpck_require__(87196);
-const is_ci_1 = __nccwpck_require__(28839);
-const configuration_1 = __nccwpck_require__(65459);
-const promised_based_queue_1 = __nccwpck_require__(45208);
-const workspaces_1 = __nccwpck_require__(98715);
-const socket_messenger_1 = __nccwpck_require__(4850);
-const cache_1 = __nccwpck_require__(15015);
-const DAEMON_ENV_SETTINGS = Object.assign(Object.assign({}, process.env), { NX_PROJECT_GLOB_CACHE: 'false', NX_CACHE_PROJECTS_CONFIG: 'false' });
-class DaemonClient {
-    constructor(nxJson) {
-        this.nxJson = nxJson;
-        this._out = null;
-        this._err = null;
-        this.reset();
-    }
-    enabled() {
-        var _a, _b, _c;
-        if (this._enabled === undefined) {
-            const useDaemonProcessOption = (_c = (_b = (_a = this.nxJson.tasksRunnerOptions) === null || _a === void 0 ? void 0 : _a['default']) === null || _b === void 0 ? void 0 : _b.options) === null || _c === void 0 ? void 0 : _c.useDaemonProcess;
-            const env = process.env.NX_DAEMON;
-            // env takes precedence
-            // option=true,env=false => no daemon
-            // option=false,env=undefined => no daemon
-            // option=false,env=false => no daemon
-            // option=undefined,env=undefined => daemon
-            // option=true,env=true => daemon
-            // option=false,env=true => daemon
-            // CI=true,env=undefined => no daemon
-            // CI=true,env=false => no daemon
-            // CI=true,env=true => daemon
-            if (((0, is_ci_1.isCI)() && env !== 'true') ||
-                isDocker() ||
-                (0, tmp_dir_1.isDaemonDisabled)() ||
-                nxJsonIsNotPresent() ||
-                (useDaemonProcessOption === undefined && env === 'false') ||
-                (useDaemonProcessOption === true && env === 'false') ||
-                (useDaemonProcessOption === false && env === undefined) ||
-                (useDaemonProcessOption === false && env === 'false')) {
-                this._enabled = false;
-            }
-            else {
-                this._enabled = true;
-            }
+const defaultGlobOpts = {
+  nosort: true,
+  silent: true
+}
+
+// for EMFILE handling
+let timeout = 0
+
+const isWindows = (process.platform === "win32")
+
+const defaults = options => {
+  const methods = [
+    'unlink',
+    'chmod',
+    'stat',
+    'lstat',
+    'rmdir',
+    'readdir'
+  ]
+  methods.forEach(m => {
+    options[m] = options[m] || fs[m]
+    m = m + 'Sync'
+    options[m] = options[m] || fs[m]
+  })
+
+  options.maxBusyTries = options.maxBusyTries || 3
+  options.emfileWait = options.emfileWait || 1000
+  if (options.glob === false) {
+    options.disableGlob = true
+  }
+  if (options.disableGlob !== true && glob === undefined) {
+    throw Error('glob dependency not found, set `options.disableGlob = true` if intentional')
+  }
+  options.disableGlob = options.disableGlob || false
+  options.glob = options.glob || defaultGlobOpts
+}
+
+const rimraf = (p, options, cb) => {
+  if (typeof options === 'function') {
+    cb = options
+    options = {}
+  }
+
+  assert(p, 'rimraf: missing path')
+  assert.equal(typeof p, 'string', 'rimraf: path should be a string')
+  assert.equal(typeof cb, 'function', 'rimraf: callback function required')
+  assert(options, 'rimraf: invalid options argument provided')
+  assert.equal(typeof options, 'object', 'rimraf: options should be object')
+
+  defaults(options)
+
+  let busyTries = 0
+  let errState = null
+  let n = 0
+
+  const next = (er) => {
+    errState = errState || er
+    if (--n === 0)
+      cb(errState)
+  }
+
+  const afterGlob = (er, results) => {
+    if (er)
+      return cb(er)
+
+    n = results.length
+    if (n === 0)
+      return cb()
+
+    results.forEach(p => {
+      const CB = (er) => {
+        if (er) {
+          if ((er.code === "EBUSY" || er.code === "ENOTEMPTY" || er.code === "EPERM") &&
+              busyTries < options.maxBusyTries) {
+            busyTries ++
+            // try again, with the same exact callback as this one.
+            return setTimeout(() => rimraf_(p, options, CB), busyTries * 100)
+          }
+
+          // this one won't happen if graceful-fs is used.
+          if (er.code === "EMFILE" && timeout < options.emfileWait) {
+            return setTimeout(() => rimraf_(p, options, CB), timeout ++)
+          }
+
+          // already gone
+          if (er.code === "ENOENT") er = null
         }
-        return this._enabled;
+
+        timeout = 0
+        next(er)
+      }
+      rimraf_(p, options, CB)
+    })
+  }
+
+  if (options.disableGlob || !glob.hasMagic(p))
+    return afterGlob(null, [p])
+
+  options.lstat(p, (er, stat) => {
+    if (!er)
+      return afterGlob(null, [p])
+
+    glob(p, options.glob, afterGlob)
+  })
+
+}
+
+// Two possible strategies.
+// 1. Assume it's a file.  unlink it, then do the dir stuff on EPERM or EISDIR
+// 2. Assume it's a directory.  readdir, then do the file stuff on ENOTDIR
+//
+// Both result in an extra syscall when you guess wrong.  However, there
+// are likely far more normal files in the world than directories.  This
+// is based on the assumption that a the average number of files per
+// directory is >= 1.
+//
+// If anyone ever complains about this, then I guess the strategy could
+// be made configurable somehow.  But until then, YAGNI.
+const rimraf_ = (p, options, cb) => {
+  assert(p)
+  assert(options)
+  assert(typeof cb === 'function')
+
+  // sunos lets the root user unlink directories, which is... weird.
+  // so we have to lstat here and make sure it's not a dir.
+  options.lstat(p, (er, st) => {
+    if (er && er.code === "ENOENT")
+      return cb(null)
+
+    // Windows can EPERM on stat.  Life is suffering.
+    if (er && er.code === "EPERM" && isWindows)
+      fixWinEPERM(p, options, er, cb)
+
+    if (st && st.isDirectory())
+      return rmdir(p, options, er, cb)
+
+    options.unlink(p, er => {
+      if (er) {
+        if (er.code === "ENOENT")
+          return cb(null)
+        if (er.code === "EPERM")
+          return (isWindows)
+            ? fixWinEPERM(p, options, er, cb)
+            : rmdir(p, options, er, cb)
+        if (er.code === "EISDIR")
+          return rmdir(p, options, er, cb)
+      }
+      return cb(er)
+    })
+  })
+}
+
+const fixWinEPERM = (p, options, er, cb) => {
+  assert(p)
+  assert(options)
+  assert(typeof cb === 'function')
+
+  options.chmod(p, 0o666, er2 => {
+    if (er2)
+      cb(er2.code === "ENOENT" ? null : er)
+    else
+      options.stat(p, (er3, stats) => {
+        if (er3)
+          cb(er3.code === "ENOENT" ? null : er)
+        else if (stats.isDirectory())
+          rmdir(p, options, er, cb)
+        else
+          options.unlink(p, cb)
+      })
+  })
+}
+
+const fixWinEPERMSync = (p, options, er) => {
+  assert(p)
+  assert(options)
+
+  try {
+    options.chmodSync(p, 0o666)
+  } catch (er2) {
+    if (er2.code === "ENOENT")
+      return
+    else
+      throw er
+  }
+
+  let stats
+  try {
+    stats = options.statSync(p)
+  } catch (er3) {
+    if (er3.code === "ENOENT")
+      return
+    else
+      throw er
+  }
+
+  if (stats.isDirectory())
+    rmdirSync(p, options, er)
+  else
+    options.unlinkSync(p)
+}
+
+const rmdir = (p, options, originalEr, cb) => {
+  assert(p)
+  assert(options)
+  assert(typeof cb === 'function')
+
+  // try to rmdir first, and only readdir on ENOTEMPTY or EEXIST (SunOS)
+  // if we guessed wrong, and it's not a directory, then
+  // raise the original error.
+  options.rmdir(p, er => {
+    if (er && (er.code === "ENOTEMPTY" || er.code === "EEXIST" || er.code === "EPERM"))
+      rmkids(p, options, cb)
+    else if (er && er.code === "ENOTDIR")
+      cb(originalEr)
+    else
+      cb(er)
+  })
+}
+
+const rmkids = (p, options, cb) => {
+  assert(p)
+  assert(options)
+  assert(typeof cb === 'function')
+
+  options.readdir(p, (er, files) => {
+    if (er)
+      return cb(er)
+    let n = files.length
+    if (n === 0)
+      return options.rmdir(p, cb)
+    let errState
+    files.forEach(f => {
+      rimraf(path.join(p, f), options, er => {
+        if (errState)
+          return
+        if (er)
+          return cb(errState = er)
+        if (--n === 0)
+          options.rmdir(p, cb)
+      })
+    })
+  })
+}
+
+// this looks simpler, and is strictly *faster*, but will
+// tie up the JavaScript thread and fail on excessively
+// deep directory trees.
+const rimrafSync = (p, options) => {
+  options = options || {}
+  defaults(options)
+
+  assert(p, 'rimraf: missing path')
+  assert.equal(typeof p, 'string', 'rimraf: path should be a string')
+  assert(options, 'rimraf: missing options')
+  assert.equal(typeof options, 'object', 'rimraf: options should be object')
+
+  let results
+
+  if (options.disableGlob || !glob.hasMagic(p)) {
+    results = [p]
+  } else {
+    try {
+      options.lstatSync(p)
+      results = [p]
+    } catch (er) {
+      results = glob.sync(p, options.glob)
     }
-    reset() {
-        var _a, _b, _c;
-        (_a = this.socketMessenger) === null || _a === void 0 ? void 0 : _a.close();
-        this.socketMessenger = null;
-        this.queue = new promised_based_queue_1.PromisedBasedQueue();
-        this.currentMessage = null;
-        this.currentResolve = null;
-        this.currentReject = null;
-        this._enabled = undefined;
-        (_b = this._out) === null || _b === void 0 ? void 0 : _b.close();
-        (_c = this._err) === null || _c === void 0 ? void 0 : _c.close();
-        this._out = null;
-        this._err = null;
-        this._connected = false;
+  }
+
+  if (!results.length)
+    return
+
+  for (let i = 0; i < results.length; i++) {
+    const p = results[i]
+
+    let st
+    try {
+      st = options.lstatSync(p)
+    } catch (er) {
+      if (er.code === "ENOENT")
+        return
+
+      // Windows can EPERM on stat.  Life is suffering.
+      if (er.code === "EPERM" && isWindows)
+        fixWinEPERMSync(p, options, er)
     }
-    requestShutdown() {
-        return tslib_1.__awaiter(this, void 0, void 0, function* () {
-            return this.sendToDaemonViaQueue({ type: 'REQUEST_SHUTDOWN' });
-        });
+
+    try {
+      // sunos lets the root user unlink directories, which is... weird.
+      if (st && st.isDirectory())
+        rmdirSync(p, options, null)
+      else
+        options.unlinkSync(p)
+    } catch (er) {
+      if (er.code === "ENOENT")
+        return
+      if (er.code === "EPERM")
+        return isWindows ? fixWinEPERMSync(p, options, er) : rmdirSync(p, options, er)
+      if (er.code !== "EISDIR")
+        throw er
+
+      rmdirSync(p, options, er)
     }
-    getProjectGraph() {
-        return tslib_1.__awaiter(this, void 0, void 0, function* () {
-            return (yield this.sendToDaemonViaQueue({ type: 'REQUEST_PROJECT_GRAPH' }))
-                .projectGraph;
-        });
+  }
+}
+
+const rmdirSync = (p, options, originalEr) => {
+  assert(p)
+  assert(options)
+
+  try {
+    options.rmdirSync(p)
+  } catch (er) {
+    if (er.code === "ENOENT")
+      return
+    if (er.code === "ENOTDIR")
+      throw originalEr
+    if (er.code === "ENOTEMPTY" || er.code === "EEXIST" || er.code === "EPERM")
+      rmkidsSync(p, options)
+  }
+}
+
+const rmkidsSync = (p, options) => {
+  assert(p)
+  assert(options)
+  options.readdirSync(p).forEach(f => rimrafSync(path.join(p, f), options))
+
+  // We only end up here once we got ENOTEMPTY at least once, and
+  // at this point, we are guaranteed to have removed all the kids.
+  // So, we know that it won't be ENOENT or ENOTDIR or anything else.
+  // try really hard to delete stuff on windows, because it has a
+  // PROFOUNDLY annoying habit of not closing handles promptly when
+  // files are deleted, resulting in spurious ENOTEMPTY errors.
+  const retries = isWindows ? 100 : 1
+  let i = 0
+  do {
+    let threw = true
+    try {
+      const ret = options.rmdirSync(p, options)
+      threw = false
+      return ret
+    } finally {
+      if (++i < retries && threw)
+        continue
     }
-    getAllFileData() {
-        return tslib_1.__awaiter(this, void 0, void 0, function* () {
-            return yield this.sendToDaemonViaQueue({ type: 'REQUEST_FILE_DATA' });
-        });
+  } while (true)
+}
+
+module.exports = rimraf
+rimraf.sync = rimrafSync
+
+
+/***/ }),
+
+/***/ 54184:
+/***/ ((module, exports, __nccwpck_require__) => {
+
+/*! safe-buffer. MIT License. Feross Aboukhadijeh  */
+/* eslint-disable node/no-deprecated-api */
+var buffer = __nccwpck_require__(14300)
+var Buffer = buffer.Buffer
+
+// alternative to using Object.keys for old browsers
+function copyProps (src, dst) {
+  for (var key in src) {
+    dst[key] = src[key]
+  }
+}
+if (Buffer.from && Buffer.alloc && Buffer.allocUnsafe && Buffer.allocUnsafeSlow) {
+  module.exports = buffer
+} else {
+  // Copy properties from require('buffer')
+  copyProps(buffer, exports)
+  exports.Buffer = SafeBuffer
+}
+
+function SafeBuffer (arg, encodingOrOffset, length) {
+  return Buffer(arg, encodingOrOffset, length)
+}
+
+SafeBuffer.prototype = Object.create(Buffer.prototype)
+
+// Copy static methods from Buffer
+copyProps(Buffer, SafeBuffer)
+
+SafeBuffer.from = function (arg, encodingOrOffset, length) {
+  if (typeof arg === 'number') {
+    throw new TypeError('Argument must not be a number')
+  }
+  return Buffer(arg, encodingOrOffset, length)
+}
+
+SafeBuffer.alloc = function (size, fill, encoding) {
+  if (typeof size !== 'number') {
+    throw new TypeError('Argument must be a number')
+  }
+  var buf = Buffer(size)
+  if (fill !== undefined) {
+    if (typeof encoding === 'string') {
+      buf.fill(fill, encoding)
+    } else {
+      buf.fill(fill)
     }
-    hashTasks(runnerOptions, tasks) {
-        return this.sendToDaemonViaQueue({
-            type: 'HASH_TASKS',
-            runnerOptions,
-            tasks,
-        });
+  } else {
+    buf.fill(0)
+  }
+  return buf
+}
+
+SafeBuffer.allocUnsafe = function (size) {
+  if (typeof size !== 'number') {
+    throw new TypeError('Argument must be a number')
+  }
+  return Buffer(size)
+}
+
+SafeBuffer.allocUnsafeSlow = function (size) {
+  if (typeof size !== 'number') {
+    throw new TypeError('Argument must be a number')
+  }
+  return buffer.SlowBuffer(size)
+}
+
+
+/***/ }),
+
+/***/ 14658:
+/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+
+const ANY = Symbol('SemVer ANY')
+// hoisted class for cyclic dependency
+class Comparator {
+  static get ANY () {
+    return ANY
+  }
+
+  constructor (comp, options) {
+    options = parseOptions(options)
+
+    if (comp instanceof Comparator) {
+      if (comp.loose === !!options.loose) {
+        return comp
+      } else {
+        comp = comp.value
+      }
     }
-    registerFileWatcher(config, callback) {
-        return tslib_1.__awaiter(this, void 0, void 0, function* () {
-            yield this.getProjectGraph();
-            const messenger = new socket_messenger_1.SocketMessenger((0, net_1.connect)(socket_utils_1.FULL_OS_SOCKET_PATH)).listen((message) => {
-                try {
-                    const parsedMessage = JSON.parse(message);
-                    callback(null, parsedMessage);
-                }
-                catch (e) {
-                    callback(e, null);
-                }
-            }, () => {
-                callback('closed', null);
-            }, (err) => callback(err, null));
-            yield this.queue.sendToQueue(() => messenger.sendMessage({ type: 'REGISTER_FILE_WATCHER', config }));
-            return () => {
-                messenger.close();
-            };
-        });
+
+    comp = comp.trim().split(/\s+/).join(' ')
+    debug('comparator', comp, options)
+    this.options = options
+    this.loose = !!options.loose
+    this.parse(comp)
+
+    if (this.semver === ANY) {
+      this.value = ''
+    } else {
+      this.value = this.operator + this.semver.version
     }
-    processInBackground(requirePath, data) {
-        return this.sendToDaemonViaQueue({
-            type: 'PROCESS_IN_BACKGROUND',
-            requirePath,
-            data,
-        });
+
+    debug('comp', this)
+  }
+
+  parse (comp) {
+    const r = this.options.loose ? re[t.COMPARATORLOOSE] : re[t.COMPARATOR]
+    const m = comp.match(r)
+
+    if (!m) {
+      throw new TypeError(`Invalid comparator: ${comp}`)
     }
-    recordOutputsHash(outputs, hash) {
-        return this.sendToDaemonViaQueue({
-            type: 'RECORD_OUTPUTS_HASH',
-            data: {
-                outputs,
-                hash,
-            },
-        });
+
+    this.operator = m[1] !== undefined ? m[1] : ''
+    if (this.operator === '=') {
+      this.operator = ''
     }
-    outputsHashesMatch(outputs, hash) {
-        return this.sendToDaemonViaQueue({
-            type: 'OUTPUTS_HASHES_MATCH',
-            data: {
-                outputs,
-                hash,
-            },
-        });
+
+    // if it literally is just '>' or '' then allow anything.
+    if (!m[2]) {
+      this.semver = ANY
+    } else {
+      this.semver = new SemVer(m[2], this.options.loose)
     }
-    isServerAvailable() {
-        return tslib_1.__awaiter(this, void 0, void 0, function* () {
-            return new Promise((resolve) => {
-                try {
-                    const socket = (0, net_1.connect)(socket_utils_1.FULL_OS_SOCKET_PATH, () => {
-                        socket.destroy();
-                        resolve(true);
-                    });
-                    socket.once('error', () => {
-                        resolve(false);
-                    });
-                }
-                catch (err) {
-                    resolve(false);
-                }
-            });
-        });
+  }
+
+  toString () {
+    return this.value
+  }
+
+  test (version) {
+    debug('Comparator.test', version, this.options.loose)
+
+    if (this.semver === ANY || version === ANY) {
+      return true
     }
-    sendToDaemonViaQueue(messageToDaemon) {
-        return tslib_1.__awaiter(this, void 0, void 0, function* () {
-            return this.queue.sendToQueue(() => this.sendMessageToDaemon(messageToDaemon));
-        });
+
+    if (typeof version === 'string') {
+      try {
+        version = new SemVer(version, this.options)
+      } catch (er) {
+        return false
+      }
     }
-    setUpConnection() {
-        this.socketMessenger = new socket_messenger_1.SocketMessenger((0, net_1.connect)(socket_utils_1.FULL_OS_SOCKET_PATH)).listen((message) => this.handleMessage(message), () => {
-            // it's ok for the daemon to terminate if the client doesn't wait on
-            // any messages from the daemon
-            if (this.queue.isEmpty()) {
-                this._connected = false;
-            }
-            else {
-                output_1.output.error({
-                    title: 'Daemon process terminated and closed the connection',
-                    bodyLines: [
-                        'Please rerun the command, which will restart the daemon.',
-                    ],
-                });
-                process.exit(1);
-            }
-        }, (err) => {
-            if (!err.message) {
-                return this.currentReject(daemonProcessException(err.toString()));
-            }
-            if (err.message.startsWith('LOCK-FILES-CHANGED')) {
-                // retry the current message
-                // we cannot send it via the queue because we are in the middle of processing
-                // a message from the queue
-                return this.sendMessageToDaemon(this.currentMessage).then(this.currentResolve, this.currentReject);
-            }
-            let error;
-            if (err.message.startsWith('connect ENOENT')) {
-                error = daemonProcessException('The Daemon Server is not running');
-            }
-            else if (err.message.startsWith('connect ECONNREFUSED')) {
-                error = daemonProcessException(`A server instance had not been fully shut down. Please try running the command again.`);
-                (0, socket_utils_1.killSocketOrPath)();
-            }
-            else if (err.message.startsWith('read ECONNRESET')) {
-                error = daemonProcessException(`Unable to connect to the daemon process.`);
-            }
-            else {
-                error = daemonProcessException(err.toString());
-            }
-            return this.currentReject(error);
-        });
+
+    return cmp(version, this.operator, this.semver, this.options)
+  }
+
+  intersects (comp, options) {
+    if (!(comp instanceof Comparator)) {
+      throw new TypeError('a Comparator is required')
     }
-    sendMessageToDaemon(message) {
-        return tslib_1.__awaiter(this, void 0, void 0, function* () {
-            if (!this._connected) {
-                this._connected = true;
-                if (!(yield this.isServerAvailable())) {
-                    yield this.startInBackground();
-                }
-                this.setUpConnection();
-            }
-            return new Promise((resolve, reject) => {
-                perf_hooks_1.performance.mark('sendMessageToDaemon-start');
-                this.currentMessage = message;
-                this.currentResolve = resolve;
-                this.currentReject = reject;
-                this.socketMessenger.sendMessage(message);
-            });
-        });
+
+    if (this.operator === '') {
+      if (this.value === '') {
+        return true
+      }
+      return new Range(comp.value, options).test(this.value)
+    } else if (comp.operator === '') {
+      if (comp.value === '') {
+        return true
+      }
+      return new Range(this.value, options).test(comp.semver)
     }
-    handleMessage(serializedResult) {
-        try {
-            perf_hooks_1.performance.mark('json-parse-start');
-            const parsedResult = JSON.parse(serializedResult);
-            perf_hooks_1.performance.mark('json-parse-end');
-            perf_hooks_1.performance.measure('deserialize daemon response', 'json-parse-start', 'json-parse-end');
-            if (parsedResult.error) {
-                this.currentReject(parsedResult.error);
-            }
-            else {
-                perf_hooks_1.performance.measure('total for sendMessageToDaemon()', 'sendMessageToDaemon-start', 'json-parse-end');
-                return this.currentResolve(parsedResult);
-            }
-        }
-        catch (e) {
-            const endOfResponse = serializedResult.length > 300
-                ? serializedResult.substring(serializedResult.length - 300)
-                : serializedResult;
-            this.currentReject(daemonProcessException([
-                'Could not deserialize response from Nx daemon.',
-                `Message: ${e.message}`,
-                '\n',
-                `Received:`,
-                endOfResponse,
-                '\n',
-            ].join('\n')));
-        }
+
+    options = parseOptions(options)
+
+    // Special cases where nothing can possibly be lower
+    if (options.includePrerelease &&
+      (this.value === '<0.0.0-0' || comp.value === '<0.0.0-0')) {
+      return false
     }
-    startInBackground() {
-        return tslib_1.__awaiter(this, void 0, void 0, function* () {
-            (0, fs_extra_1.ensureDirSync)(tmp_dir_1.DAEMON_DIR_FOR_CURRENT_WORKSPACE);
-            (0, fs_extra_1.ensureFileSync)(tmp_dir_1.DAEMON_OUTPUT_LOG_FILE);
-            this._out = yield (0, promises_1.open)(tmp_dir_1.DAEMON_OUTPUT_LOG_FILE, 'a');
-            this._err = yield (0, promises_1.open)(tmp_dir_1.DAEMON_OUTPUT_LOG_FILE, 'a');
-            const backgroundProcess = (0, child_process_1.spawn)(process.execPath, [(0, path_1.join)(__dirname, '../server/start.js')], {
-                cwd: workspace_root_1.workspaceRoot,
-                stdio: ['ignore', this._out.fd, this._err.fd],
-                detached: true,
-                windowsHide: true,
-                shell: false,
-                env: DAEMON_ENV_SETTINGS,
-            });
-            backgroundProcess.unref();
-            //
-            /**
-             * Ensure the server is actually available to connect to via IPC before resolving
-             */
-            let attempts = 0;
-            return new Promise((resolve, reject) => {
-                const id = setInterval(() => tslib_1.__awaiter(this, void 0, void 0, function* () {
-                    if (yield this.isServerAvailable()) {
-                        clearInterval(id);
-                        resolve(backgroundProcess.pid);
-                    }
-                    else if (attempts > 1000) {
-                        // daemon fails to start, the process probably exited
-                        // we print the logs and exit the client
-                        reject(daemonProcessException('Failed to start or connect to the Nx Daemon process.'));
-                    }
-                    else {
-                        attempts++;
-                    }
-                }), 10);
-            });
-        });
+    if (!options.includePrerelease &&
+      (this.value.startsWith('<0.0.0') || comp.value.startsWith('<0.0.0'))) {
+      return false
     }
-    stop() {
-        return tslib_1.__awaiter(this, void 0, void 0, function* () {
-            try {
-                yield (0, cache_1.safelyCleanUpExistingProcess)();
-            }
-            catch (err) {
-                output_1.output.error({
-                    title: (err === null || err === void 0 ? void 0 : err.message) ||
-                        'Something unexpected went wrong when stopping the server',
-                });
-            }
-            (0, tmp_dir_1.removeSocketDir)();
-        });
+
+    // Same direction increasing (> or >=)
+    if (this.operator.startsWith('>') && comp.operator.startsWith('>')) {
+      return true
     }
-}
-exports.DaemonClient = DaemonClient;
-exports.daemonClient = new DaemonClient((0, configuration_1.readNxJson)());
-function isDocker() {
-    var _a;
-    try {
-        (0, fs_1.statSync)('/.dockerenv');
-        return true;
+    // Same direction decreasing (< or <=)
+    if (this.operator.startsWith('<') && comp.operator.startsWith('<')) {
+      return true
     }
-    catch (_b) {
-        try {
-            return (_a = (0, fs_1.readFileSync)('/proc/self/cgroup', 'utf8')) === null || _a === void 0 ? void 0 : _a.includes('docker');
-        }
-        catch (_c) { }
-        return false;
+    // same SemVer and both sides are inclusive (<= or >=)
+    if (
+      (this.semver.version === comp.semver.version) &&
+      this.operator.includes('=') && comp.operator.includes('=')) {
+      return true
     }
-}
-function nxJsonIsNotPresent() {
-    return !new workspaces_1.Workspaces(workspace_root_1.workspaceRoot).hasNxJson();
-}
-function daemonProcessException(message) {
-    try {
-        let log = (0, fs_1.readFileSync)(tmp_dir_1.DAEMON_OUTPUT_LOG_FILE).toString().split('\n');
-        if (log.length > 20) {
-            log = log.slice(log.length - 20);
-        }
-        const error = new Error([
-            message,
-            '',
-            'Messages from the log:',
-            ...log,
-            '\n',
-            `More information: ${tmp_dir_1.DAEMON_OUTPUT_LOG_FILE}`,
-        ].join('\n'));
-        error.internalDaemonError = true;
-        return error;
+    // opposite directions less than
+    if (cmp(this.semver, '<', comp.semver, options) &&
+      this.operator.startsWith('>') && comp.operator.startsWith('<')) {
+      return true
     }
-    catch (e) {
-        return new Error(message);
+    // opposite directions greater than
+    if (cmp(this.semver, '>', comp.semver, options) &&
+      this.operator.startsWith('<') && comp.operator.startsWith('>')) {
+      return true
     }
+    return false
+  }
 }
 
+module.exports = Comparator
+
+const parseOptions = __nccwpck_require__(35375)
+const { safeRe: re, t } = __nccwpck_require__(49815)
+const cmp = __nccwpck_require__(97714)
+const debug = __nccwpck_require__(19723)
+const SemVer = __nccwpck_require__(93097)
+const Range = __nccwpck_require__(70434)
+
 
 /***/ }),
 
-/***/ 4850:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
+/***/ 70434:
+/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
-"use strict";
+// hoisted class for cyclic dependency
+class Range {
+  constructor (range, options) {
+    options = parseOptions(options)
 
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.SocketMessenger = void 0;
-const tslib_1 = __nccwpck_require__(51796);
-const consume_messages_from_socket_1 = __nccwpck_require__(81904);
-class SocketMessenger {
-    constructor(socket) {
-        this.socket = socket;
-    }
-    sendMessage(messageToDaemon) {
-        return tslib_1.__awaiter(this, void 0, void 0, function* () {
-            this.socket.write(JSON.stringify(messageToDaemon));
-            // send EOT to indicate that the message has been fully written
-            this.socket.write(String.fromCodePoint(4));
-        });
-    }
-    listen(onData, onClose = () => { }, onError = (err) => { }) {
-        this.socket.on('data', (0, consume_messages_from_socket_1.consumeMessagesFromSocket)((message) => tslib_1.__awaiter(this, void 0, void 0, function* () {
-            onData(message);
-        })));
-        this.socket.on('close', onClose);
-        this.socket.on('error', onError);
-        return this;
+    if (range instanceof Range) {
+      if (
+        range.loose === !!options.loose &&
+        range.includePrerelease === !!options.includePrerelease
+      ) {
+        return range
+      } else {
+        return new Range(range.raw, options)
+      }
     }
-    close() {
-        this.socket.destroy();
+
+    if (range instanceof Comparator) {
+      // just put it in the set and return
+      this.raw = range.value
+      this.set = [[range]]
+      this.format()
+      return this
     }
-}
-exports.SocketMessenger = SocketMessenger;
 
+    this.options = options
+    this.loose = !!options.loose
+    this.includePrerelease = !!options.includePrerelease
 
-/***/ }),
+    // First reduce all whitespace as much as possible so we do not have to rely
+    // on potentially slow regexes like \s*. This is then stored and used for
+    // future error messages as well.
+    this.raw = range
+      .trim()
+      .split(/\s+/)
+      .join(' ')
 
-/***/ 3497:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
+    // First, split on ||
+    this.set = this.raw
+      .split('||')
+      // map the range to a 2d array of comparators
+      .map(r => this.parseRange(r.trim()))
+      // throw out any comparator lists that are empty
+      // this generally means that it was not a valid range, which is allowed
+      // in loose mode, but will still throw if the WHOLE range is invalid.
+      .filter(c => c.length)
 
-"use strict";
+    if (!this.set.length) {
+      throw new TypeError(`Invalid SemVer Range: ${this.raw}`)
+    }
 
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.serializeResult = exports.killSocketOrPath = exports.FULL_OS_SOCKET_PATH = exports.isWindows = void 0;
-const fs_1 = __nccwpck_require__(57147);
-const os_1 = __nccwpck_require__(22037);
-const path_1 = __nccwpck_require__(71017);
-const tmp_dir_1 = __nccwpck_require__(87196);
-exports.isWindows = (0, os_1.platform)() === 'win32';
-/**
- * For IPC with the daemon server we use unix sockets or windows named pipes, depending on the user's operating system.
- *
- * See https://nodejs.org/dist/latest-v14.x/docs/api/net.html#net_identifying_paths_for_ipc_connections for a full breakdown
- * of OS differences between Unix domain sockets and named pipes.
- */
-exports.FULL_OS_SOCKET_PATH = exports.isWindows
-    ? '\\\\.\\pipe\\nx\\' + (0, path_1.resolve)(tmp_dir_1.DAEMON_SOCKET_PATH)
-    : (0, path_1.resolve)(tmp_dir_1.DAEMON_SOCKET_PATH);
-function killSocketOrPath() {
-    try {
-        (0, fs_1.unlinkSync)(exports.FULL_OS_SOCKET_PATH);
+    // if we have any that are not the null set, throw out null sets.
+    if (this.set.length > 1) {
+      // keep the first one, in case they're all null sets
+      const first = this.set[0]
+      this.set = this.set.filter(c => !isNullSet(c[0]))
+      if (this.set.length === 0) {
+        this.set = [first]
+      } else if (this.set.length > 1) {
+        // if we have any that are *, then the range is just *
+        for (const c of this.set) {
+          if (c.length === 1 && isAny(c[0])) {
+            this.set = [c]
+            break
+          }
+        }
+      }
     }
-    catch (_a) { }
-}
-exports.killSocketOrPath = killSocketOrPath;
-// Include the original stack trace within the serialized error so that the client can show it to the user.
-function serializeError(error) {
-    if (!error) {
-        return null;
+
+    this.format()
+  }
+
+  format () {
+    this.range = this.set
+      .map((comps) => comps.join(' ').trim())
+      .join('||')
+      .trim()
+    return this.range
+  }
+
+  toString () {
+    return this.range
+  }
+
+  parseRange (range) {
+    // memoize range parsing for performance.
+    // this is a very hot path, and fully deterministic.
+    const memoOpts =
+      (this.options.includePrerelease && FLAG_INCLUDE_PRERELEASE) |
+      (this.options.loose && FLAG_LOOSE)
+    const memoKey = memoOpts + ':' + range
+    const cached = cache.get(memoKey)
+    if (cached) {
+      return cached
     }
-    return JSON.stringify(error, Object.getOwnPropertyNames(error));
-}
-// Prepare a serialized project graph result for sending over IPC from the server to the client
-function serializeResult(error, serializedProjectGraph) {
-    // We do not want to repeat work `JSON.stringify`ing an object containing the potentially large project graph so merge as strings
-    return `{ "error": ${serializeError(error)}, "projectGraph": ${serializedProjectGraph} }`;
-}
-exports.serializeResult = serializeResult;
 
+    const loose = this.options.loose
+    // `1.2.3 - 1.2.4` => `>=1.2.3 <=1.2.4`
+    const hr = loose ? re[t.HYPHENRANGELOOSE] : re[t.HYPHENRANGE]
+    range = range.replace(hr, hyphenReplace(this.options.includePrerelease))
+    debug('hyphen replace', range)
 
-/***/ }),
+    // `> 1.2.3 < 1.2.5` => `>1.2.3 <1.2.5`
+    range = range.replace(re[t.COMPARATORTRIM], comparatorTrimReplace)
+    debug('comparator trim', range)
 
-/***/ 87196:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
+    // `~ 1.2.3` => `~1.2.3`
+    range = range.replace(re[t.TILDETRIM], tildeTrimReplace)
+    debug('tilde trim', range)
 
-"use strict";
+    // `^ 1.2.3` => `^1.2.3`
+    range = range.replace(re[t.CARETTRIM], caretTrimReplace)
+    debug('caret trim', range)
 
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.removeSocketDir = exports.isDaemonDisabled = exports.markDaemonAsDisabled = exports.writeDaemonLogs = exports.DAEMON_SOCKET_PATH = exports.DAEMON_OUTPUT_LOG_FILE = exports.DAEMON_DIR_FOR_CURRENT_WORKSPACE = void 0;
-/**
- * Per workspace (to avoid subtle differences and issues), we want to have a deterministic
- * location within the OS's tmp directory where we write log files for background processes
- * and where we create the actual unix socket/named pipe for the daemon.
- */
-const fs_1 = __nccwpck_require__(57147);
-const fs_extra_1 = __nccwpck_require__(59511);
-const path_1 = __nccwpck_require__(71017);
-const cache_directory_1 = __nccwpck_require__(20858);
-const crypto_1 = __nccwpck_require__(6113);
-const tmp_1 = __nccwpck_require__(49503);
-const workspace_root_1 = __nccwpck_require__(65766);
-exports.DAEMON_DIR_FOR_CURRENT_WORKSPACE = (0, path_1.join)(cache_directory_1.projectGraphCacheDirectory, 'd');
-exports.DAEMON_OUTPUT_LOG_FILE = (0, path_1.join)(exports.DAEMON_DIR_FOR_CURRENT_WORKSPACE, 'daemon.log');
-const socketDir = createSocketDir();
-exports.DAEMON_SOCKET_PATH = (0, path_1.join)(socketDir, 
-// As per notes above on socket/named pipe length limitations, we keep this intentionally short
-'d.sock');
-function writeDaemonLogs(error) {
-    const file = (0, path_1.join)(exports.DAEMON_DIR_FOR_CURRENT_WORKSPACE, 'daemon-error.log');
-    (0, fs_1.writeFileSync)(file, error);
-    return file;
-}
-exports.writeDaemonLogs = writeDaemonLogs;
-function markDaemonAsDisabled() {
-    (0, fs_1.writeFileSync)((0, path_1.join)(exports.DAEMON_DIR_FOR_CURRENT_WORKSPACE, 'disabled'), 'true');
-}
-exports.markDaemonAsDisabled = markDaemonAsDisabled;
-function isDaemonDisabled() {
-    try {
-        (0, fs_1.statSync)((0, path_1.join)(exports.DAEMON_DIR_FOR_CURRENT_WORKSPACE, 'disabled'));
-        return true;
+    // At this point, the range is completely trimmed and
+    // ready to be split into comparators.
+
+    let rangeList = range
+      .split(' ')
+      .map(comp => parseComparator(comp, this.options))
+      .join(' ')
+      .split(/\s+/)
+      // >=0.0.0 is equivalent to *
+      .map(comp => replaceGTE0(comp, this.options))
+
+    if (loose) {
+      // in loose mode, throw out any that are not valid comparators
+      rangeList = rangeList.filter(comp => {
+        debug('loose invalid filter', comp, this.options)
+        return !!comp.match(re[t.COMPARATORLOOSE])
+      })
     }
-    catch (e) {
-        return false;
+    debug('range list', rangeList)
+
+    // if any comparators are the null set, then replace with JUST null set
+    // if more than one comparator, remove any * comparators
+    // also, don't include the same comparator more than once
+    const rangeMap = new Map()
+    const comparators = rangeList.map(comp => new Comparator(comp, this.options))
+    for (const comp of comparators) {
+      if (isNullSet(comp)) {
+        return [comp]
+      }
+      rangeMap.set(comp.value, comp)
     }
-}
-exports.isDaemonDisabled = isDaemonDisabled;
-function socketDirName() {
-    const hasher = (0, crypto_1.createHash)('sha256');
-    hasher.update(workspace_root_1.workspaceRoot.toLowerCase());
-    const unique = hasher.digest('hex').substring(0, 20);
-    return (0, path_1.join)(tmp_1.tmpdir, unique);
-}
-/**
- * We try to create a socket file in a tmp dir, but if it doesn't work because
- * for instance we don't have permissions, we create it in DAEMON_DIR_FOR_CURRENT_WORKSPACE
- */
-function createSocketDir() {
-    try {
-        const dir = socketDirName();
-        (0, fs_extra_1.ensureDirSync)(dir);
-        return dir;
+    if (rangeMap.size > 1 && rangeMap.has('')) {
+      rangeMap.delete('')
     }
-    catch (e) {
-        return exports.DAEMON_DIR_FOR_CURRENT_WORKSPACE;
+
+    const result = [...rangeMap.values()]
+    cache.set(memoKey, result)
+    return result
+  }
+
+  intersects (range, options) {
+    if (!(range instanceof Range)) {
+      throw new TypeError('a Range is required')
     }
-}
-function removeSocketDir() {
-    try {
-        (0, fs_extra_1.rmdirSync)(socketDir);
+
+    return this.set.some((thisComparators) => {
+      return (
+        isSatisfiable(thisComparators, options) &&
+        range.set.some((rangeComparators) => {
+          return (
+            isSatisfiable(rangeComparators, options) &&
+            thisComparators.every((thisComparator) => {
+              return rangeComparators.every((rangeComparator) => {
+                return thisComparator.intersects(rangeComparator, options)
+              })
+            })
+          )
+        })
+      )
+    })
+  }
+
+  // if ANY of the sets match ALL of its comparators, then pass
+  test (version) {
+    if (!version) {
+      return false
     }
-    catch (e) { }
+
+    if (typeof version === 'string') {
+      try {
+        version = new SemVer(version, this.options)
+      } catch (er) {
+        return false
+      }
+    }
+
+    for (let i = 0; i < this.set.length; i++) {
+      if (testSet(this.set[i], version, this.options)) {
+        return true
+      }
+    }
+    return false
+  }
 }
-exports.removeSocketDir = removeSocketDir;
 
+module.exports = Range
 
-/***/ }),
+const LRU = __nccwpck_require__(17963)
+const cache = new LRU({ max: 1000 })
 
-/***/ 75138:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
+const parseOptions = __nccwpck_require__(35375)
+const Comparator = __nccwpck_require__(14658)
+const debug = __nccwpck_require__(19723)
+const SemVer = __nccwpck_require__(93097)
+const {
+  safeRe: re,
+  t,
+  comparatorTrimReplace,
+  tildeTrimReplace,
+  caretTrimReplace,
+} = __nccwpck_require__(49815)
+const { FLAG_INCLUDE_PRERELEASE, FLAG_LOOSE } = __nccwpck_require__(96730)
 
-"use strict";
+const isNullSet = c => c.value === '<0.0.0-0'
+const isAny = c => c.value === ''
 
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.printChanges = exports.flushChanges = exports.FsTree = void 0;
-const fs_extra_1 = __nccwpck_require__(59511);
-const logger_1 = __nccwpck_require__(95324);
-const output_1 = __nccwpck_require__(34548);
-const path_1 = __nccwpck_require__(71017);
-const chalk = __nccwpck_require__(29541);
-class FsTree {
-    constructor(root, isVerbose, logOperationId) {
-        this.root = root;
-        this.isVerbose = isVerbose;
-        this.logOperationId = logOperationId;
-        this.recordedChanges = {};
-        /**
-         * Signifies if operations on the tree instance
-         * are allowed. Set to false after changes are written
-         * to disk, to prevent someone trying to use the tree to update
-         * files when the tree is no longer effective.
-         */
-        this.locked = false;
-    }
-    read(filePath, encoding) {
-        filePath = this.normalize(filePath);
-        try {
-            let content;
-            if (this.recordedChanges[this.rp(filePath)]) {
-                content = this.recordedChanges[this.rp(filePath)].content;
-            }
-            else {
-                content = this.fsReadFile(filePath);
-            }
-            return encoding ? content.toString(encoding) : content;
-        }
-        catch (e) {
-            if (this.isVerbose) {
-                logger_1.logger.error(e);
-            }
-            return null;
-        }
-    }
-    write(filePath, content, options) {
-        var _a;
-        this.assertUnlocked();
-        filePath = this.normalize(filePath);
-        // Remove any recorded changes where a parent directory has been
-        // deleted when writing a new file within the directory.
-        let parent = (0, path_1.dirname)(this.rp(filePath));
-        while (parent !== '.') {
-            if ((_a = this.recordedChanges[parent]) === null || _a === void 0 ? void 0 : _a.isDeleted) {
-                delete this.recordedChanges[parent];
-            }
-            parent = (0, path_1.dirname)(parent);
-        }
-        if (this.fsExists(this.rp(filePath)) &&
-            Buffer.from(content).equals(this.fsReadFile(filePath))) {
-            // Remove recorded change because the file has been restored to it's original contents
-            delete this.recordedChanges[this.rp(filePath)];
-            return;
-        }
-        try {
-            this.recordedChanges[this.rp(filePath)] = {
-                content: Buffer.from(content),
-                isDeleted: false,
-                options,
-            };
-        }
-        catch (e) {
-            if (this.isVerbose) {
-                logger_1.logger.error(e);
-            }
-        }
-    }
-    overwrite(filePath, content, options) {
-        filePath = this.normalize(filePath);
-        this.write(filePath, content, options);
-    }
-    delete(filePath) {
-        this.assertUnlocked();
-        filePath = this.normalize(filePath);
-        if (this.filesForDir(this.rp(filePath)).length > 0) {
-            this.filesForDir(this.rp(filePath)).forEach((f) => (this.recordedChanges[f] = { content: null, isDeleted: true }));
-        }
-        this.recordedChanges[this.rp(filePath)] = {
-            content: null,
-            isDeleted: true,
-        };
-        // Delete directory when is not root and there are no children
-        if (filePath !== '' &&
-            this.children((0, path_1.dirname)(this.rp(filePath))).length < 1) {
-            this.delete((0, path_1.dirname)(this.rp(filePath)));
-        }
-    }
-    exists(filePath) {
-        filePath = this.normalize(filePath);
-        try {
-            if (this.recordedChanges[this.rp(filePath)]) {
-                return !this.recordedChanges[this.rp(filePath)].isDeleted;
-            }
-            else if (this.filesForDir(this.rp(filePath)).length > 0) {
-                return true;
-            }
-            else {
-                return this.fsExists(filePath);
-            }
-        }
-        catch (_a) {
-            return false;
-        }
-    }
-    rename(from, to) {
-        this.assertUnlocked();
-        from = this.normalize(from);
-        to = this.normalize(to);
-        if (from === to) {
-            return;
-        }
-        if (this.isFile(from)) {
-            const content = this.read(this.rp(from));
-            this.write(this.rp(to), content);
-            this.delete(this.rp(from));
-        }
-        else {
-            for (const child of this.children(from)) {
-                this.rename((0, path_1.join)(from, child), (0, path_1.join)(to, child));
-            }
-        }
-    }
-    isFile(filePath) {
-        filePath = this.normalize(filePath);
-        try {
-            if (this.recordedChanges[this.rp(filePath)]) {
-                return !this.recordedChanges[this.rp(filePath)].isDeleted;
-            }
-            else {
-                return this.fsIsFile(filePath);
-            }
-        }
-        catch (_a) {
-            return false;
-        }
-    }
-    children(dirPath) {
-        dirPath = this.normalize(dirPath);
-        let res = this.fsReadDir(dirPath);
-        res = [...res, ...this.directChildrenOfDir(this.rp(dirPath))];
-        res = res.filter((q) => {
-            const r = this.recordedChanges[this.normalize((0, path_1.join)(this.rp(dirPath), q))];
-            return !(r === null || r === void 0 ? void 0 : r.isDeleted);
-        });
-        // Dedupe
-        return Array.from(new Set(res));
-    }
-    listChanges() {
-        const res = [];
-        Object.keys(this.recordedChanges).forEach((f) => {
-            if (this.recordedChanges[f].isDeleted) {
-                if (this.fsExists(f)) {
-                    res.push({ path: f, type: 'DELETE', content: null });
-                }
-            }
-            else {
-                if (this.fsExists(f)) {
-                    res.push({
-                        path: f,
-                        type: 'UPDATE',
-                        content: this.recordedChanges[f].content,
-                        options: this.recordedChanges[f].options,
-                    });
-                }
-                else {
-                    res.push({
-                        path: f,
-                        type: 'CREATE',
-                        content: this.recordedChanges[f].content,
-                        options: this.recordedChanges[f].options,
-                    });
-                }
-            }
-        });
-        return res;
-    }
-    changePermissions(filePath, mode) {
-        this.assertUnlocked();
-        filePath = this.normalize(filePath);
-        const filePathChangeKey = this.rp(filePath);
-        if (this.recordedChanges[filePathChangeKey]) {
-            if (this.recordedChanges[filePathChangeKey].isDeleted) {
-                throw new Error(`Cannot change permissions of deleted file ${filePath}.`);
-            }
-            this.recordedChanges[filePathChangeKey].options = { mode };
-        }
-        else if (!this.fsExists(filePath)) {
-            throw new Error(`Cannot change permissions of non-existing file ${filePath}.`);
-        }
-        else if (!this.fsIsFile(filePath)) {
-            // To fully support directories we'd need to change how we store
-            // changes to keep a record of directories so we can associate
-            // permissions to them.
-            throw new Error(`Cannot change permissions of non-file ${filePath}.`);
-        }
-        else {
-            this.recordedChanges[filePathChangeKey] = {
-                content: this.fsReadFile(filePath),
-                isDeleted: false,
-                options: { mode },
-            };
-        }
-    }
-    // Marks FsTree as final.
-    lock() {
-        this.locked = true;
-    }
-    assertUnlocked() {
-        if (this.locked) {
-            output_1.output.error({
-                title: `File changes have already been written to disk. Further changes were attempted ${this.logOperationId ? ` while running ${this.logOperationId}.` : '.'}`,
-                bodyLines: [
-                    'The file system can no longer be modified. This commonly happens when a generator attempts to make further changes in its callback, or an asynchronous operation is still running after the generator completes.',
-                ],
-            });
-            throw new Error('Tree changed after commit to disk.');
-        }
-    }
-    normalize(path) {
-        return (0, path_1.relative)(this.root, (0, path_1.join)(this.root, path)).split(path_1.sep).join('/');
-    }
-    fsReadDir(dirPath) {
-        try {
-            return (0, fs_extra_1.readdirSync)((0, path_1.join)(this.root, dirPath));
-        }
-        catch (_a) {
-            return [];
-        }
-    }
-    fsIsFile(filePath) {
-        const stat = (0, fs_extra_1.statSync)((0, path_1.join)(this.root, filePath));
-        return stat.isFile();
-    }
-    fsReadFile(filePath) {
-        return (0, fs_extra_1.readFileSync)((0, path_1.join)(this.root, filePath));
-    }
-    fsExists(filePath) {
-        try {
-            const stat = (0, fs_extra_1.statSync)((0, path_1.join)(this.root, filePath));
-            return stat.isFile() || stat.isDirectory();
-        }
-        catch (_a) {
-            return false;
-        }
-    }
-    filesForDir(path) {
-        return Object.keys(this.recordedChanges).filter((f) => f.startsWith(`${path}/`) && !this.recordedChanges[f].isDeleted);
-    }
-    directChildrenOfDir(path) {
-        const res = {};
-        if (path === '') {
-            return Object.keys(this.recordedChanges).map((file) => file.split('/')[0]);
-        }
-        Object.keys(this.recordedChanges).forEach((f) => {
-            if (f.startsWith(`${path}/`)) {
-                // Remove the current folder's path from the directory
-                const file = f.substring(path.length + 1);
-                // Split the path on segments, and take the first one
-                const basePath = file.split('/')[0];
-                // Mark it as a child of the current directory
-                res[basePath] = true;
-            }
-        });
-        return Object.keys(res);
-    }
-    rp(pp) {
-        return pp.startsWith('/') ? pp.substring(1) : pp;
-    }
-}
-exports.FsTree = FsTree;
-function flushChanges(root, fileChanges) {
-    fileChanges.forEach((f) => {
-        var _a, _b;
-        const fpath = (0, path_1.join)(root, f.path);
-        if (f.type === 'CREATE') {
-            (0, fs_extra_1.ensureDirSync)((0, path_1.dirname)(fpath));
-            (0, fs_extra_1.writeFileSync)(fpath, f.content);
-            if ((_a = f.options) === null || _a === void 0 ? void 0 : _a.mode)
-                (0, fs_extra_1.chmodSync)(fpath, f.options.mode);
-        }
-        else if (f.type === 'UPDATE') {
-            (0, fs_extra_1.writeFileSync)(fpath, f.content);
-            if ((_b = f.options) === null || _b === void 0 ? void 0 : _b.mode)
-                (0, fs_extra_1.chmodSync)(fpath, f.options.mode);
-        }
-        else if (f.type === 'DELETE') {
-            (0, fs_extra_1.removeSync)(fpath);
-        }
-    });
-}
-exports.flushChanges = flushChanges;
-function printChanges(fileChanges, indent = '') {
-    fileChanges.forEach((f) => {
-        if (f.type === 'CREATE') {
-            console.log(`${indent}${chalk.green('CREATE')} ${f.path}`);
-        }
-        else if (f.type === 'UPDATE') {
-            console.log(`${indent}${chalk.white('UPDATE')} ${f.path}`);
-        }
-        else if (f.type === 'DELETE') {
-            console.log(`${indent}${chalk.yellow('DELETE')} ${f.path}`);
-        }
-    });
-}
-exports.printChanges = printChanges;
-
-
-/***/ }),
+// take a set of comparators and determine whether there
+// exists a version which can satisfy it
+const isSatisfiable = (comparators, options) => {
+  let result = true
+  const remainingComparators = comparators.slice()
+  let testComparator = remainingComparators.pop()
 
-/***/ 55060:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
+  while (result && remainingComparators.length) {
+    result = remainingComparators.every((otherComparator) => {
+      return testComparator.intersects(otherComparator, options)
+    })
 
-"use strict";
+    testComparator = remainingComparators.pop()
+  }
 
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.getWorkspacePath = exports.readWorkspaceConfiguration = exports.isStandaloneProject = exports.updateWorkspaceConfiguration = void 0;
-const nx_json_1 = __nccwpck_require__(29931);
-// TODO(v16): Remove this
-/**
- * Update general workspace configuration such as the default project or cli settings.
- *
- * This does _not_ update projects configuration, use {@link updateProjectConfiguration} or {@link addProjectConfiguration} instead.
- *
- * @deprecated use updateNxJson
- */
-function updateWorkspaceConfiguration(tree, workspaceConfig) {
-    const { 
-    // Nx Json Properties
-    cli, defaultProject, generators, implicitDependencies, plugins, pluginsConfig, npmScope, namedInputs, targetDefaults, workspaceLayout, tasksRunnerOptions, affected, extends: ext, installation, } = workspaceConfig;
-    const nxJson = {
-        implicitDependencies,
-        plugins,
-        pluginsConfig,
-        npmScope,
-        namedInputs,
-        targetDefaults,
-        workspaceLayout,
-        tasksRunnerOptions,
-        affected,
-        cli,
-        generators,
-        defaultProject,
-        extends: ext,
-        installation,
-    };
-    (0, nx_json_1.updateNxJson)(tree, nxJson);
-}
-exports.updateWorkspaceConfiguration = updateWorkspaceConfiguration;
-// TODO(v16): Remove this
-/**
- * Returns if a project has a standalone configuration (project.json).
- *
- * @param tree - the file system tree
- * @param project - the project name
- *
- * @deprecated non-standalone projects were deprecated
- */
-function isStandaloneProject(tree, project) {
-    return true;
-}
-exports.isStandaloneProject = isStandaloneProject;
-// TODO(v16): Remove this
-/**
- * Read general workspace configuration such as the default project or cli settings
- *
- * This does _not_ provide projects configuration, use {@link readProjectConfiguration} instead.
- * @deprecated use readNxJson
- */
-function readWorkspaceConfiguration(tree) {
-    return (0, nx_json_1.readNxJson)(tree);
-}
-exports.readWorkspaceConfiguration = readWorkspaceConfiguration;
-// TODO(v16): Remove this
-/**
- * @deprecated all projects are configured using project.json
- */
-function getWorkspacePath(tree) {
-    if (tree.exists('workspace.json'))
-        return 'workspace.json';
-    if (tree.exists('angular.json'))
-        return 'angular.json';
-    return null;
+  return result
 }
-exports.getWorkspacePath = getWorkspacePath;
 
+// comprised of xranges, tildes, stars, and gtlt's at this point.
+// already replaced the hyphen ranges
+// turn into a set of JUST comparators.
+const parseComparator = (comp, options) => {
+  debug('comp', comp, options)
+  comp = replaceCarets(comp, options)
+  debug('caret', comp)
+  comp = replaceTildes(comp, options)
+  debug('tildes', comp)
+  comp = replaceXRanges(comp, options)
+  debug('xrange', comp)
+  comp = replaceStars(comp, options)
+  debug('stars', comp)
+  return comp
+}
 
-/***/ }),
+const isX = id => !id || id.toLowerCase() === 'x' || id === '*'
 
-/***/ 57038:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
+// ~, ~> --> * (any, kinda silly)
+// ~2, ~2.x, ~2.x.x, ~>2, ~>2.x ~>2.x.x --> >=2.0.0 <3.0.0-0
+// ~2.0, ~2.0.x, ~>2.0, ~>2.0.x --> >=2.0.0 <2.1.0-0
+// ~1.2, ~1.2.x, ~>1.2, ~>1.2.x --> >=1.2.0 <1.3.0-0
+// ~1.2.3, ~>1.2.3 --> >=1.2.3 <1.3.0-0
+// ~1.2.0, ~>1.2.0 --> >=1.2.0 <1.3.0-0
+// ~0.0.1 --> >=0.0.1 <0.1.0-0
+const replaceTildes = (comp, options) => {
+  return comp
+    .trim()
+    .split(/\s+/)
+    .map((c) => replaceTilde(c, options))
+    .join(' ')
+}
 
-"use strict";
+const replaceTilde = (comp, options) => {
+  const r = options.loose ? re[t.TILDELOOSE] : re[t.TILDE]
+  return comp.replace(r, (_, M, m, p, pr) => {
+    debug('tilde', comp, _, M, m, p, pr)
+    let ret
 
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.updateJson = exports.writeJson = exports.readJson = void 0;
-const json_1 = __nccwpck_require__(43684);
-/**
- * Reads a json file, removes all comments and parses JSON.
- *
- * @param tree - file system tree
- * @param path - file path
- * @param options - Optional JSON Parse Options
- */
-function readJson(tree, path, options) {
-    if (!tree.exists(path)) {
-        throw new Error(`Cannot find ${path}`);
-    }
-    try {
-        return (0, json_1.parseJson)(tree.read(path, 'utf-8'), options);
-    }
-    catch (e) {
-        throw new Error(`Cannot parse ${path}: ${e.message}`);
+    if (isX(M)) {
+      ret = ''
+    } else if (isX(m)) {
+      ret = `>=${M}.0.0 <${+M + 1}.0.0-0`
+    } else if (isX(p)) {
+      // ~1.2 == >=1.2.0 <1.3.0-0
+      ret = `>=${M}.${m}.0 <${M}.${+m + 1}.0-0`
+    } else if (pr) {
+      debug('replaceTilde pr', pr)
+      ret = `>=${M}.${m}.${p}-${pr
+      } <${M}.${+m + 1}.0-0`
+    } else {
+      // ~1.2.3 == >=1.2.3 <1.3.0-0
+      ret = `>=${M}.${m}.${p
+      } <${M}.${+m + 1}.0-0`
     }
-}
-exports.readJson = readJson;
-/**
- * Writes a JSON value to the file system tree
 
- * @param tree File system tree
- * @param path Path of JSON file in the Tree
- * @param value Serializable value to write
- * @param options Optional JSON Serialize Options
- */
-function writeJson(tree, path, value, options) {
-    tree.write(path, (0, json_1.serializeJson)(value, options));
-}
-exports.writeJson = writeJson;
-/**
- * Updates a JSON value to the file system tree
- *
- * @param tree File system tree
- * @param path Path of JSON file in the Tree
- * @param updater Function that maps the current value of a JSON document to a new value to be written to the document
- * @param options Optional JSON Parse and Serialize Options
- */
-function updateJson(tree, path, updater, options) {
-    const updatedValue = updater(readJson(tree, path, options));
-    writeJson(tree, path, updatedValue, options);
+    debug('tilde return', ret)
+    return ret
+  })
 }
-exports.updateJson = updateJson;
-
-
-/***/ }),
 
-/***/ 29931:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
+// ^ --> * (any, kinda silly)
+// ^2, ^2.x, ^2.x.x --> >=2.0.0 <3.0.0-0
+// ^2.0, ^2.0.x --> >=2.0.0 <3.0.0-0
+// ^1.2, ^1.2.x --> >=1.2.0 <2.0.0-0
+// ^1.2.3 --> >=1.2.3 <2.0.0-0
+// ^1.2.0 --> >=1.2.0 <2.0.0-0
+// ^0.0.1 --> >=0.0.1 <0.0.2-0
+// ^0.1.0 --> >=0.1.0 <0.2.0-0
+const replaceCarets = (comp, options) => {
+  return comp
+    .trim()
+    .split(/\s+/)
+    .map((c) => replaceCaret(c, options))
+    .join(' ')
+}
 
-"use strict";
+const replaceCaret = (comp, options) => {
+  debug('caret', comp, options)
+  const r = options.loose ? re[t.CARETLOOSE] : re[t.CARET]
+  const z = options.includePrerelease ? '-0' : ''
+  return comp.replace(r, (_, M, m, p, pr) => {
+    debug('caret', comp, _, M, m, p, pr)
+    let ret
 
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.updateNxJson = exports.readNxJson = void 0;
-const path_1 = __nccwpck_require__(71017);
-const json_1 = __nccwpck_require__(57038);
-const file_utils_1 = __nccwpck_require__(93155);
-/**
- * Reads nx.json
- */
-function readNxJson(tree) {
-    if (tree) {
-        if (!tree.exists('nx.json')) {
-            return null;
+    if (isX(M)) {
+      ret = ''
+    } else if (isX(m)) {
+      ret = `>=${M}.0.0${z} <${+M + 1}.0.0-0`
+    } else if (isX(p)) {
+      if (M === '0') {
+        ret = `>=${M}.${m}.0${z} <${M}.${+m + 1}.0-0`
+      } else {
+        ret = `>=${M}.${m}.0${z} <${+M + 1}.0.0-0`
+      }
+    } else if (pr) {
+      debug('replaceCaret pr', pr)
+      if (M === '0') {
+        if (m === '0') {
+          ret = `>=${M}.${m}.${p}-${pr
+          } <${M}.${m}.${+p + 1}-0`
+        } else {
+          ret = `>=${M}.${m}.${p}-${pr
+          } <${M}.${+m + 1}.0-0`
         }
-        let nxJson = (0, json_1.readJson)(tree, 'nx.json');
-        if (nxJson.extends) {
-            nxJson = Object.assign(Object.assign({}, readNxJsonExtends(tree, nxJson.extends)), nxJson);
+      } else {
+        ret = `>=${M}.${m}.${p}-${pr
+        } <${+M + 1}.0.0-0`
+      }
+    } else {
+      debug('no pr')
+      if (M === '0') {
+        if (m === '0') {
+          ret = `>=${M}.${m}.${p
+          }${z} <${M}.${m}.${+p + 1}-0`
+        } else {
+          ret = `>=${M}.${m}.${p
+          }${z} <${M}.${+m + 1}.0-0`
         }
-        return nxJson;
-    }
-    else {
-        return (0, file_utils_1.readNxJson)();
-    }
-}
-exports.readNxJson = readNxJson;
-/**
- * Update nx.json
- */
-function updateNxJson(tree, nxJson) {
-    if (tree.exists('nx.json')) {
-        (0, json_1.updateJson)(tree, 'nx.json', (json) => {
-            if (json.extends) {
-                const nxJsonExtends = readNxJsonExtends(tree, json.extends);
-                const changedPropsOfNxJson = {};
-                Object.keys(nxJson).forEach((prop) => {
-                    if (JSON.stringify(nxJson[prop], null, 2) !=
-                        JSON.stringify(nxJsonExtends[prop], null, 2)) {
-                        changedPropsOfNxJson[prop] = nxJson[prop];
-                    }
-                });
-                return changedPropsOfNxJson;
-            }
-            else {
-                return nxJson;
-            }
-        });
+      } else {
+        ret = `>=${M}.${m}.${p
+        } <${+M + 1}.0.0-0`
+      }
     }
+
+    debug('caret return', ret)
+    return ret
+  })
 }
-exports.updateNxJson = updateNxJson;
-function readNxJsonExtends(tree, extendsPath) {
-    try {
-        return (0, json_1.readJson)(tree, (0, path_1.relative)(tree.root, require.resolve(extendsPath, {
-            paths: [tree.root],
-        })));
-    }
-    catch (e) {
-        throw new Error(`Unable to resolve nx.json extends. Error: ${e.message}`);
-    }
+
+const replaceXRanges = (comp, options) => {
+  debug('replaceXRanges', comp, options)
+  return comp
+    .split(/\s+/)
+    .map((c) => replaceXRange(c, options))
+    .join(' ')
 }
 
+const replaceXRange = (comp, options) => {
+  comp = comp.trim()
+  const r = options.loose ? re[t.XRANGELOOSE] : re[t.XRANGE]
+  return comp.replace(r, (ret, gtlt, M, m, p, pr) => {
+    debug('xRange', comp, ret, gtlt, M, m, p, pr)
+    const xM = isX(M)
+    const xm = xM || isX(m)
+    const xp = xm || isX(p)
+    const anyX = xp
 
-/***/ }),
+    if (gtlt === '=' && anyX) {
+      gtlt = ''
+    }
 
-/***/ 41172:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
+    // if we're including prereleases in the match, then we need
+    // to fix this to -0, the lowest possible prerelease value
+    pr = options.includePrerelease ? '-0' : ''
 
-"use strict";
+    if (xM) {
+      if (gtlt === '>' || gtlt === '<') {
+        // nothing is allowed
+        ret = '<0.0.0-0'
+      } else {
+        // nothing is forbidden
+        ret = '*'
+      }
+    } else if (gtlt && anyX) {
+      // we know patch is an x, because we have any x at all.
+      // replace X with 0
+      if (xm) {
+        m = 0
+      }
+      p = 0
 
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.getRelativeProjectJsonSchemaPath = exports.getProjects = exports.readProjectConfiguration = exports.removeProjectConfiguration = exports.updateProjectConfiguration = exports.addProjectConfiguration = exports.getWorkspacePath = exports.isStandaloneProject = exports.updateWorkspaceConfiguration = exports.readWorkspaceConfiguration = exports.updateNxJson = exports.readNxJson = void 0;
-const path_1 = __nccwpck_require__(71017);
-const workspaces_1 = __nccwpck_require__(98715);
-const path_2 = __nccwpck_require__(75878);
-const json_1 = __nccwpck_require__(57038);
-const nx_json_1 = __nccwpck_require__(29931);
-const output_1 = __nccwpck_require__(34548);
-const installation_directory_1 = __nccwpck_require__(35075);
-var nx_json_2 = __nccwpck_require__(29931);
-Object.defineProperty(exports, "readNxJson", ({ enumerable: true, get: function () { return nx_json_2.readNxJson; } }));
-Object.defineProperty(exports, "updateNxJson", ({ enumerable: true, get: function () { return nx_json_2.updateNxJson; } }));
-var deprecated_1 = __nccwpck_require__(55060);
-Object.defineProperty(exports, "readWorkspaceConfiguration", ({ enumerable: true, get: function () { return deprecated_1.readWorkspaceConfiguration; } }));
-Object.defineProperty(exports, "updateWorkspaceConfiguration", ({ enumerable: true, get: function () { return deprecated_1.updateWorkspaceConfiguration; } }));
-Object.defineProperty(exports, "isStandaloneProject", ({ enumerable: true, get: function () { return deprecated_1.isStandaloneProject; } }));
-Object.defineProperty(exports, "getWorkspacePath", ({ enumerable: true, get: function () { return deprecated_1.getWorkspacePath; } }));
-/**
- * Adds project configuration to the Nx workspace.
- *
- * @param tree - the file system tree
- * @param projectName - unique name. Often directories are part of the name (e.g., mydir-mylib)
- * @param projectConfiguration - project configuration
- * @param standalone - whether the project is configured in workspace.json or not
- */
-function addProjectConfiguration(tree, projectName, projectConfiguration, standalone = true) {
-    const projectConfigFile = (0, path_2.joinPathFragments)(projectConfiguration.root, 'project.json');
-    if (!standalone) {
-        output_1.output.warn({
-            title: 'Nx only supports standalone projects. Setting standalone to false is ignored.',
-        });
-    }
-    if (tree.exists(projectConfigFile)) {
-        throw new Error(`Cannot create a new project ${projectName} at ${projectConfiguration.root}. It already exists.`);
-    }
-    delete projectConfiguration.$schema;
-    (0, json_1.writeJson)(tree, projectConfigFile, Object.assign(Object.assign({ name: projectName, $schema: getRelativeProjectJsonSchemaPath(tree, projectConfiguration) }, projectConfiguration), { root: undefined }));
-}
-exports.addProjectConfiguration = addProjectConfiguration;
-/**
- * Updates the configuration of an existing project.
- *
- * @param tree - the file system tree
- * @param projectName - unique name. Often directories are part of the name (e.g., mydir-mylib)
- * @param projectConfiguration - project configuration
- */
-function updateProjectConfiguration(tree, projectName, projectConfiguration) {
-    var _a;
-    const projectConfigFile = (0, path_2.joinPathFragments)(projectConfiguration.root, 'project.json');
-    if (!tree.exists(projectConfigFile)) {
-        throw new Error(`Cannot update Project ${projectName} at ${projectConfiguration.root}. It doesn't exist or uses package.json configuration.`);
-    }
-    (0, json_1.writeJson)(tree, projectConfigFile, Object.assign(Object.assign({ name: (_a = projectConfiguration.name) !== null && _a !== void 0 ? _a : projectName, $schema: getRelativeProjectJsonSchemaPath(tree, projectConfiguration) }, projectConfiguration), { root: undefined }));
-}
-exports.updateProjectConfiguration = updateProjectConfiguration;
-/**
- * Removes the configuration of an existing project.
- *
- * @param tree - the file system tree
- * @param projectName - unique name. Often directories are part of the name (e.g., mydir-mylib)
- */
-function removeProjectConfiguration(tree, projectName) {
-    const projectConfiguration = readProjectConfiguration(tree, projectName);
-    if (!projectConfiguration) {
-        throw new Error(`Cannot delete Project ${projectName}`);
-    }
-    const projectConfigFile = (0, path_2.joinPathFragments)(projectConfiguration.root, 'project.json');
-    if (tree.exists(projectConfigFile)) {
-        tree.delete(projectConfigFile);
-    }
-}
-exports.removeProjectConfiguration = removeProjectConfiguration;
-/**
- * Reads a project configuration.
- *
- * @param tree - the file system tree
- * @param projectName - unique name. Often directories are part of the name (e.g., mydir-mylib)
- * @throws If supplied projectName cannot be found
- */
-function readProjectConfiguration(tree, projectName) {
-    const allProjects = readAndCombineAllProjectConfigurations(tree);
-    if (!allProjects[projectName]) {
-        // temporary polyfill to make sure our generators work for existing angularcli workspaces
-        if (tree.exists('angular.json')) {
-            const angularJson = toNewFormat((0, json_1.readJson)(tree, 'angular.json'));
-            if (angularJson.projects[projectName])
-                return angularJson.projects[projectName];
+      if (gtlt === '>') {
+        // >1 => >=2.0.0
+        // >1.2 => >=1.3.0
+        gtlt = '>='
+        if (xm) {
+          M = +M + 1
+          m = 0
+          p = 0
+        } else {
+          m = +m + 1
+          p = 0
         }
-        throw new Error(`Cannot find configuration for '${projectName}'`);
-    }
-    return allProjects[projectName];
-}
-exports.readProjectConfiguration = readProjectConfiguration;
-/**
- * Get a map of all projects in a workspace.
- *
- * Use {@link readProjectConfiguration} if only one project is needed.
- */
-function getProjects(tree) {
-    let allProjects = readAndCombineAllProjectConfigurations(tree);
-    // temporary polyfill to make sure our generators work for existing angularcli workspaces
-    if (tree.exists('angular.json')) {
-        const angularJson = toNewFormat((0, json_1.readJson)(tree, 'angular.json'));
-        allProjects = Object.assign(Object.assign({}, allProjects), angularJson.projects);
-    }
-    return new Map(Object.keys(allProjects || {}).map((projectName) => {
-        return [projectName, allProjects[projectName]];
-    }));
-}
-exports.getProjects = getProjects;
-function getRelativeProjectJsonSchemaPath(tree, project) {
-    return (0, path_2.normalizePath)((0, path_1.relative)((0, path_1.join)(tree.root, project.root), (0, path_1.join)(tree.root, 'node_modules/nx/schemas/project-schema.json')));
-}
-exports.getRelativeProjectJsonSchemaPath = getRelativeProjectJsonSchemaPath;
-function readAndCombineAllProjectConfigurations(tree) {
-    const nxJson = (0, nx_json_1.readNxJson)(tree);
-    const globbedFiles = (0, workspaces_1.globForProjectFiles)(tree.root, (0, workspaces_1.getGlobPatternsFromPlugins)(nxJson, (0, installation_directory_1.getNxRequirePaths)(tree.root), tree.root), nxJson).map(path_2.normalizePath);
-    const createdFiles = findCreatedProjectFiles(tree);
-    const deletedFiles = findDeletedProjectFiles(tree);
-    const projectFiles = [...globbedFiles, ...createdFiles].filter((r) => deletedFiles.indexOf(r) === -1);
-    return (0, workspaces_1.buildProjectsConfigurationsFromGlobs)(nxJson, projectFiles, (file) => (0, json_1.readJson)(tree, file)).projects;
-}
-/**
- * Used to ensure that projects created during
- * the same devkit generator run show up when
- * there is no project.json file, as `glob`
- * cannot find them.
- *
- * We exclude the root `package.json` from this list unless
- * considered a project during workspace generation
- */
-function findCreatedProjectFiles(tree) {
-    const createdProjectFiles = [];
-    for (const change of tree.listChanges()) {
-        if (change.type === 'CREATE') {
-            const fileName = (0, path_1.basename)(change.path);
-            // all created project json files are created projects
-            if (fileName === 'project.json') {
-                createdProjectFiles.push(change.path);
-            }
-            else if (fileName === 'package.json') {
-                try {
-                    const contents = JSON.parse(change.content.toString());
-                    if (contents.nx) {
-                        createdProjectFiles.push(change.path);
-                    }
-                }
-                catch (_a) { }
-            }
+      } else if (gtlt === '<=') {
+        // <=0.7.x is actually <0.8.0, since any 0.7.x should
+        // pass.  Similarly, <=7.x is actually <8.0.0, etc.
+        gtlt = '<'
+        if (xm) {
+          M = +M + 1
+        } else {
+          m = +m + 1
         }
+      }
+
+      if (gtlt === '<') {
+        pr = '-0'
+      }
+
+      ret = `${gtlt + M}.${m}.${p}${pr}`
+    } else if (xm) {
+      ret = `>=${M}.0.0${pr} <${+M + 1}.0.0-0`
+    } else if (xp) {
+      ret = `>=${M}.${m}.0${pr
+      } <${M}.${+m + 1}.0-0`
     }
-    return (0, workspaces_1.deduplicateProjectFiles)(createdProjectFiles).map(path_2.normalizePath);
-}
-/**
- * Used to ensure that projects created during
- * the same devkit generator run show up when
- * there is no project.json file, as `glob`
- * cannot find them.
- */
-function findDeletedProjectFiles(tree) {
-    return tree
-        .listChanges()
-        .filter((f) => {
-        const fileName = (0, path_1.basename)(f.path);
-        return (f.type === 'DELETE' &&
-            (fileName === 'project.json' || fileName === 'package.json'));
-    })
-        .map((r) => r.path);
+
+    debug('xRange return', ret)
+
+    return ret
+  })
 }
-function toNewFormat(w) {
-    const projects = {};
-    Object.keys(w.projects || {}).forEach((name) => {
-        if (typeof w.projects[name] === 'string')
-            return;
-        const projectConfig = w.projects[name];
-        if (projectConfig.architect) {
-            (0, workspaces_1.renamePropertyWithStableKeys)(projectConfig, 'architect', 'targets');
-        }
-        if (projectConfig.schematics) {
-            (0, workspaces_1.renamePropertyWithStableKeys)(projectConfig, 'schematics', 'generators');
-        }
-        Object.values(projectConfig.targets || {}).forEach((target) => {
-            if (target.builder !== undefined) {
-                (0, workspaces_1.renamePropertyWithStableKeys)(target, 'builder', 'executor');
-            }
-        });
-        projects[name] = projectConfig;
-    });
-    w.projects = projects;
-    if (w.schematics) {
-        (0, workspaces_1.renamePropertyWithStableKeys)(w, 'schematics', 'generators');
-    }
-    if (w.version !== 2) {
-        w.version = 2;
-    }
-    return w;
+
+// Because * is AND-ed with everything else in the comparator,
+// and '' means "any version", just remove the *s entirely.
+const replaceStars = (comp, options) => {
+  debug('replaceStars', comp, options)
+  // Looseness is ignored here.  star is always as loose as it gets!
+  return comp
+    .trim()
+    .replace(re[t.STAR], '')
 }
 
+const replaceGTE0 = (comp, options) => {
+  debug('replaceGTE0', comp, options)
+  return comp
+    .trim()
+    .replace(re[options.includePrerelease ? t.GTE0PRE : t.GTE0], '')
+}
 
-/***/ }),
+// This function is passed to string.replace(re[t.HYPHENRANGE])
+// M, m, patch, prerelease, build
+// 1.2 - 3.4.5 => >=1.2.0 <=3.4.5
+// 1.2.3 - 3.4 => >=1.2.0 <3.5.0-0 Any 3.4.x will do
+// 1.2 - 3.4 => >=1.2.0 <3.5.0-0
+const hyphenReplace = incPr => ($0,
+  from, fM, fm, fp, fpr, fb,
+  to, tM, tm, tp, tpr, tb) => {
+  if (isX(fM)) {
+    from = ''
+  } else if (isX(fm)) {
+    from = `>=${fM}.0.0${incPr ? '-0' : ''}`
+  } else if (isX(fp)) {
+    from = `>=${fM}.${fm}.0${incPr ? '-0' : ''}`
+  } else if (fpr) {
+    from = `>=${from}`
+  } else {
+    from = `>=${from}${incPr ? '-0' : ''}`
+  }
 
-/***/ 94076:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
+  if (isX(tM)) {
+    to = ''
+  } else if (isX(tm)) {
+    to = `<${+tM + 1}.0.0-0`
+  } else if (isX(tp)) {
+    to = `<${tM}.${+tm + 1}.0-0`
+  } else if (tpr) {
+    to = `<=${tM}.${tm}.${tp}-${tpr}`
+  } else if (incPr) {
+    to = `<${tM}.${tm}.${+tp + 1}-0`
+  } else {
+    to = `<=${to}`
+  }
 
-"use strict";
+  return `${from} ${to}`.trim()
+}
 
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.FileHasherBase = void 0;
-const tslib_1 = __nccwpck_require__(51796);
-const perf_hooks_1 = __nccwpck_require__(4074);
-class FileHasherBase {
-    constructor() {
-        this.isInitialized = false;
-    }
-    clear() {
-        this.fileHashes = new Map();
-        this.isInitialized = false;
-    }
-    ensureInitialized() {
-        return tslib_1.__awaiter(this, void 0, void 0, function* () {
-            if (!this.isInitialized) {
-                yield this.init();
-            }
-        });
-    }
-    hashFiles(files) {
-        return tslib_1.__awaiter(this, void 0, void 0, function* () {
-            const r = new Map();
-            for (let f of files) {
-                r.set(f, this.hashFile(f));
-            }
-            return r;
-        });
-    }
-    allFileData() {
-        const res = [];
-        this.fileHashes.forEach((hash, file) => {
-            res.push({
-                file,
-                hash,
-            });
-        });
-        res.sort((x, y) => x.file.localeCompare(y.file));
-        return res;
+const testSet = (set, version, options) => {
+  for (let i = 0; i < set.length; i++) {
+    if (!set[i].test(version)) {
+      return false
     }
-    incrementalUpdate(updatedFiles, deletedFiles = []) {
-        perf_hooks_1.performance.mark('incremental hashing:start');
-        updatedFiles.forEach((hash, filename) => {
-            this.fileHashes.set(filename, hash);
-        });
-        for (const deletedFile of deletedFiles) {
-            this.fileHashes.delete(deletedFile);
+  }
+
+  if (version.prerelease.length && !options.includePrerelease) {
+    // Find the set of versions that are allowed to have prereleases
+    // For example, ^1.2.3-pr.1 desugars to >=1.2.3-pr.1 <2.0.0
+    // That should allow `1.2.3-pr.2` to pass.
+    // However, `1.2.4-alpha.notready` should NOT be allowed,
+    // even though it's within the range set by the comparators.
+    for (let i = 0; i < set.length; i++) {
+      debug(set[i].semver)
+      if (set[i].semver === Comparator.ANY) {
+        continue
+      }
+
+      if (set[i].semver.prerelease.length > 0) {
+        const allowed = set[i].semver
+        if (allowed.major === version.major &&
+            allowed.minor === version.minor &&
+            allowed.patch === version.patch) {
+          return true
         }
-        perf_hooks_1.performance.mark('incremental hashing:end');
-        perf_hooks_1.performance.measure('incremental hashing', 'incremental hashing:start', 'incremental hashing:end');
+      }
     }
+
+    // Version has a -pre, but it's not one of the ones we like.
+    return false
+  }
+
+  return true
 }
-exports.FileHasherBase = FileHasherBase;
 
 
 /***/ }),
 
-/***/ 43265:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
+/***/ 93097:
+/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
-"use strict";
+const debug = __nccwpck_require__(19723)
+const { MAX_LENGTH, MAX_SAFE_INTEGER } = __nccwpck_require__(96730)
+const { safeRe: re, t } = __nccwpck_require__(49815)
 
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.hashArray = exports.fileHasher = exports.getHashingImplementation = exports.HasherImplementation = void 0;
-const node_file_hasher_1 = __nccwpck_require__(18638);
-const native_file_hasher_1 = __nccwpck_require__(34419);
-var HasherImplementation;
-(function (HasherImplementation) {
-    HasherImplementation["Native"] = "Native";
-    HasherImplementation["Node"] = "Node";
-})(HasherImplementation = exports.HasherImplementation || (exports.HasherImplementation = {}));
-function getHashingImplementation() {
-    try {
-        if ((!process.env.NX_NON_NATIVE_HASHER ||
-            process.env.NX_NON_NATIVE_HASHER != 'true') &&
-            native_file_hasher_1.NativeFileHasher.available()) {
-            return HasherImplementation.Native;
-        }
-        return HasherImplementation.Node;
-    }
-    catch (_a) {
-        return HasherImplementation.Node;
-    }
-}
-exports.getHashingImplementation = getHashingImplementation;
-function createFileHasher() {
-    switch (getHashingImplementation()) {
-        case HasherImplementation.Native:
-            return new native_file_hasher_1.NativeFileHasher();
-        case HasherImplementation.Node:
-            return new node_file_hasher_1.NodeFileHasher();
-    }
-}
-function createHashArray() {
-    switch (getHashingImplementation()) {
-        case HasherImplementation.Native:
-            return native_file_hasher_1.nativeHashArray;
-        case HasherImplementation.Node:
-            return node_file_hasher_1.nodeHashArray;
-    }
-}
-exports.fileHasher = createFileHasher();
-exports.hashArray = createHashArray();
+const parseOptions = __nccwpck_require__(35375)
+const { compareIdentifiers } = __nccwpck_require__(67701)
+class SemVer {
+  constructor (version, options) {
+    options = parseOptions(options)
 
+    if (version instanceof SemVer) {
+      if (version.loose === !!options.loose &&
+          version.includePrerelease === !!options.includePrerelease) {
+        return version
+      } else {
+        version = version.version
+      }
+    } else if (typeof version !== 'string') {
+      throw new TypeError(`Invalid version. Must be a string. Got type "${typeof version}".`)
+    }
 
-/***/ }),
+    if (version.length > MAX_LENGTH) {
+      throw new TypeError(
+        `version is longer than ${MAX_LENGTH} characters`
+      )
+    }
 
-/***/ 34419:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
+    debug('SemVer', version, options)
+    this.options = options
+    this.loose = !!options.loose
+    // this isn't actually relevant for versions, but keep it so that we
+    // don't run into trouble passing this.options around.
+    this.includePrerelease = !!options.includePrerelease
 
-"use strict";
+    const m = version.trim().match(options.loose ? re[t.LOOSE] : re[t.FULL])
 
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.nativeHashArray = exports.NativeFileHasher = void 0;
-const tslib_1 = __nccwpck_require__(51796);
-const file_hasher_base_1 = __nccwpck_require__(94076);
-const perf_hooks_1 = __nccwpck_require__(4074);
-const workspace_root_1 = __nccwpck_require__(65766);
-class NativeFileHasher extends file_hasher_base_1.FileHasherBase {
-    static available() {
-        try {
-            __nccwpck_require__(78176);
-            return true;
-        }
-        catch (_a) {
-            return false;
-        }
-    }
-    init() {
-        return tslib_1.__awaiter(this, void 0, void 0, function* () {
-            perf_hooks_1.performance.mark('init hashing:start');
-            // Import as needed. There is also an issue running unit tests in Nx repo if this is a top-level import.
-            const { hashFiles } = __nccwpck_require__(78176);
-            this.clear();
-            const filesObject = hashFiles(workspace_root_1.workspaceRoot);
-            this.fileHashes = new Map(Object.entries(filesObject));
-            perf_hooks_1.performance.mark('init hashing:end');
-            perf_hooks_1.performance.measure('init hashing', 'init hashing:start', 'init hashing:end');
-        });
-    }
-    hashFile(path) {
-        // Import as needed. There is also an issue running unit tests in Nx repo if this is a top-level import.
-        const { hashFile } = __nccwpck_require__(78176);
-        return hashFile(path).hash;
+    if (!m) {
+      throw new TypeError(`Invalid Version: ${version}`)
     }
-}
-exports.NativeFileHasher = NativeFileHasher;
-function nativeHashArray(input) {
-    // Import as needed. There is also an issue running unit tests in Nx repo if this is a top-level import.
-    const { hashArray } = __nccwpck_require__(78176);
-    return hashArray(input);
-}
-exports.nativeHashArray = nativeHashArray;
-
 
-/***/ }),
+    this.raw = version
 
-/***/ 18638:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
+    // these are actually numbers
+    this.major = +m[1]
+    this.minor = +m[2]
+    this.patch = +m[3]
 
-"use strict";
+    if (this.major > MAX_SAFE_INTEGER || this.major < 0) {
+      throw new TypeError('Invalid major version')
+    }
 
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.nodeHashArray = exports.NodeFileHasher = void 0;
-const tslib_1 = __nccwpck_require__(51796);
-const workspace_root_1 = __nccwpck_require__(65766);
-const perf_hooks_1 = __nccwpck_require__(4074);
-const path_1 = __nccwpck_require__(71017);
-const fs_1 = __nccwpck_require__(57147);
-const file_hasher_base_1 = __nccwpck_require__(94076);
-const strip_indents_1 = __nccwpck_require__(4477);
-const path_2 = __nccwpck_require__(75878);
-const ignore_1 = __nccwpck_require__(98845);
-const path_3 = __nccwpck_require__(75878);
-const crypto_1 = __nccwpck_require__(6113);
-class NodeFileHasher extends file_hasher_base_1.FileHasherBase {
-    constructor() {
-        super(...arguments);
-        this.ignoredGlobs = getIgnoredGlobs();
-    }
-    init() {
-        return tslib_1.__awaiter(this, void 0, void 0, function* () {
-            perf_hooks_1.performance.mark('init hashing:start');
-            this.clear();
-            this.allFilesInDir(workspace_root_1.workspaceRoot, true);
-            perf_hooks_1.performance.mark('init hashing:end');
-            perf_hooks_1.performance.measure('init hashing', 'init hashing:start', 'init hashing:end');
-        });
+    if (this.minor > MAX_SAFE_INTEGER || this.minor < 0) {
+      throw new TypeError('Invalid minor version')
     }
-    allFilesInDir(absoluteDirName, recurse = true) {
-        const relDirName = (0, path_1.relative)(workspace_root_1.workspaceRoot, absoluteDirName);
-        if (relDirName && this.ignoredGlobs.ignores(relDirName)) {
-            return;
-        }
-        try {
-            (0, fs_1.readdirSync)(absoluteDirName).forEach((c) => {
-                const absoluteChild = (0, path_1.join)(absoluteDirName, c);
-                const relChild = (0, path_1.relative)(workspace_root_1.workspaceRoot, absoluteChild);
-                if (this.ignoredGlobs.ignores(relChild)) {
-                    return;
-                }
-                try {
-                    const s = (0, fs_1.statSync)(absoluteChild);
-                    if (s.isFile()) {
-                        this.fileHashes.set((0, path_2.normalizePath)(relChild), this.hashFile(relChild));
-                    }
-                    else if (s.isDirectory() && recurse) {
-                        this.allFilesInDir(absoluteChild, true);
-                    }
-                }
-                catch (_a) { }
-            });
-        }
-        catch (_a) { }
+
+    if (this.patch > MAX_SAFE_INTEGER || this.patch < 0) {
+      throw new TypeError('Invalid patch version')
     }
-    hashFile(path) {
-        if (!this.fileHashes) {
-            throw new Error('FileHasher is invoked before being initialized');
-        }
-        const relativePath = (0, path_2.normalizePath)(path.startsWith(workspace_root_1.workspaceRoot)
-            ? path.slice(workspace_root_1.workspaceRoot.length + 1)
-            : path);
-        try {
-            // this has to be absolute to avoid issues with cwd
-            return this.hashContent((0, fs_1.readFileSync)((0, path_3.joinPathFragments)(workspace_root_1.workspaceRoot, relativePath)));
-        }
-        catch (_a) {
-            return '';
+
+    // numberify any prerelease numeric ids
+    if (!m[4]) {
+      this.prerelease = []
+    } else {
+      this.prerelease = m[4].split('.').map((id) => {
+        if (/^[0-9]+$/.test(id)) {
+          const num = +id
+          if (num >= 0 && num < MAX_SAFE_INTEGER) {
+            return num
+          }
         }
+        return id
+      })
     }
-    hashContent(content) {
-        const hasher = (0, crypto_1.createHash)('sha256');
-        hasher.update(content);
-        return hasher.digest('hex');
-    }
-}
-exports.NodeFileHasher = NodeFileHasher;
-function nodeHashArray(input) {
-    const hasher = (0, crypto_1.createHash)('sha256');
-    for (const part of input) {
-        // intentional single equals to check for null and undefined
-        if (part != undefined) {
-            hasher.update(part);
-        }
-    }
-    return hasher.digest('hex');
-}
-exports.nodeHashArray = nodeHashArray;
-function getIgnoredGlobs() {
-    const ig = (0, ignore_1.getIgnoreObject)();
-    ig.add((0, strip_indents_1.stripIndents) `
-      node_modules
-      tmp
-      dist
-      build
-    `);
-    return ig;
-}
 
+    this.build = m[5] ? m[5].split('.') : []
+    this.format()
+  }
 
-/***/ }),
+  format () {
+    this.version = `${this.major}.${this.minor}.${this.patch}`
+    if (this.prerelease.length) {
+      this.version += `-${this.prerelease.join('.')}`
+    }
+    return this.version
+  }
 
-/***/ 78176:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+  toString () {
+    return this.version
+  }
 
-const { existsSync, readFileSync } = __nccwpck_require__(57147)
-const { join } = __nccwpck_require__(71017)
+  compare (other) {
+    debug('SemVer.compare', this.version, this.options, other)
+    if (!(other instanceof SemVer)) {
+      if (typeof other === 'string' && other === this.version) {
+        return 0
+      }
+      other = new SemVer(other, this.options)
+    }
 
-const { platform, arch } = process
+    if (other.version === this.version) {
+      return 0
+    }
 
-let nativeBinding = null
-let localFileExisted = false
-let loadError = null
+    return this.compareMain(other) || this.comparePre(other)
+  }
 
-function isMusl() {
-  // For Node 10
-  if (!process.report || typeof process.report.getReport !== 'function') {
-    try {
-      const lddPath = (__nccwpck_require__(32081).execSync)('which ldd').toString().trim();
-      return readFileSync(lddPath, 'utf8').includes('musl')
-    } catch (e) {
-      return true
+  compareMain (other) {
+    if (!(other instanceof SemVer)) {
+      other = new SemVer(other, this.options)
     }
-  } else {
-    const { glibcVersionRuntime } = process.report.getReport().header
-    return !glibcVersionRuntime
+
+    return (
+      compareIdentifiers(this.major, other.major) ||
+      compareIdentifiers(this.minor, other.minor) ||
+      compareIdentifiers(this.patch, other.patch)
+    )
   }
-}
 
-switch (platform) {
-  case 'android':
-    switch (arch) {
-      case 'arm64':
-        localFileExisted = existsSync(join(__dirname, 'nx.android-arm64.node'))
-        try {
-          if (localFileExisted) {
-            nativeBinding = __nccwpck_require__(68615)
-          } else {
-            nativeBinding = __nccwpck_require__(96024)
-          }
-        } catch (e) {
-          loadError = e
-        }
+  comparePre (other) {
+    if (!(other instanceof SemVer)) {
+      other = new SemVer(other, this.options)
+    }
+
+    // NOT having a prerelease is > having one
+    if (this.prerelease.length && !other.prerelease.length) {
+      return -1
+    } else if (!this.prerelease.length && other.prerelease.length) {
+      return 1
+    } else if (!this.prerelease.length && !other.prerelease.length) {
+      return 0
+    }
+
+    let i = 0
+    do {
+      const a = this.prerelease[i]
+      const b = other.prerelease[i]
+      debug('prerelease compare', i, a, b)
+      if (a === undefined && b === undefined) {
+        return 0
+      } else if (b === undefined) {
+        return 1
+      } else if (a === undefined) {
+        return -1
+      } else if (a === b) {
+        continue
+      } else {
+        return compareIdentifiers(a, b)
+      }
+    } while (++i)
+  }
+
+  compareBuild (other) {
+    if (!(other instanceof SemVer)) {
+      other = new SemVer(other, this.options)
+    }
+
+    let i = 0
+    do {
+      const a = this.build[i]
+      const b = other.build[i]
+      debug('prerelease compare', i, a, b)
+      if (a === undefined && b === undefined) {
+        return 0
+      } else if (b === undefined) {
+        return 1
+      } else if (a === undefined) {
+        return -1
+      } else if (a === b) {
+        continue
+      } else {
+        return compareIdentifiers(a, b)
+      }
+    } while (++i)
+  }
+
+  // preminor will bump the version up to the next minor release, and immediately
+  // down to pre-release. premajor and prepatch work the same way.
+  inc (release, identifier, identifierBase) {
+    switch (release) {
+      case 'premajor':
+        this.prerelease.length = 0
+        this.patch = 0
+        this.minor = 0
+        this.major++
+        this.inc('pre', identifier, identifierBase)
         break
-      case 'arm':
-        localFileExisted = existsSync(join(__dirname, 'nx.android-arm-eabi.node'))
-        try {
-          if (localFileExisted) {
-            nativeBinding = __nccwpck_require__(3479)
-          } else {
-            nativeBinding = __nccwpck_require__(63182)
-          }
-        } catch (e) {
-          loadError = e
-        }
+      case 'preminor':
+        this.prerelease.length = 0
+        this.patch = 0
+        this.minor++
+        this.inc('pre', identifier, identifierBase)
         break
-      default:
-        throw new Error(`Unsupported architecture on Android ${arch}`)
-    }
-    break
-  case 'win32':
-    switch (arch) {
-      case 'x64':
-        localFileExisted = existsSync(
-          join(__dirname, 'nx.win32-x64-msvc.node')
-        )
-        try {
-          if (localFileExisted) {
-            nativeBinding = __nccwpck_require__(23186)
-          } else {
-            nativeBinding = __nccwpck_require__(37840)
-          }
-        } catch (e) {
-          loadError = e
-        }
+      case 'prepatch':
+        // If this is already a prerelease, it will bump to the next version
+        // drop any prereleases that might already exist, since they are not
+        // relevant at this point.
+        this.prerelease.length = 0
+        this.inc('patch', identifier, identifierBase)
+        this.inc('pre', identifier, identifierBase)
         break
-      case 'ia32':
-        localFileExisted = existsSync(
-          join(__dirname, 'nx.win32-ia32-msvc.node')
-        )
-        try {
-          if (localFileExisted) {
-            nativeBinding = __nccwpck_require__(75836)
-          } else {
-            nativeBinding = __nccwpck_require__(75323)
-          }
-        } catch (e) {
-          loadError = e
+      // If the input is a non-prerelease version, this acts the same as
+      // prepatch.
+      case 'prerelease':
+        if (this.prerelease.length === 0) {
+          this.inc('patch', identifier, identifierBase)
         }
+        this.inc('pre', identifier, identifierBase)
         break
-      case 'arm64':
-        localFileExisted = existsSync(
-          join(__dirname, 'nx.win32-arm64-msvc.node')
-        )
-        try {
-          if (localFileExisted) {
-            nativeBinding = __nccwpck_require__(80491)
-          } else {
-            nativeBinding = __nccwpck_require__(48358)
-          }
-        } catch (e) {
-          loadError = e
+
+      case 'major':
+        // If this is a pre-major version, bump up to the same major version.
+        // Otherwise increment major.
+        // 1.0.0-5 bumps to 1.0.0
+        // 1.1.0 bumps to 2.0.0
+        if (
+          this.minor !== 0 ||
+          this.patch !== 0 ||
+          this.prerelease.length === 0
+        ) {
+          this.major++
         }
+        this.minor = 0
+        this.patch = 0
+        this.prerelease = []
         break
-      default:
-        throw new Error(`Unsupported architecture on Windows: ${arch}`)
-    }
-    break
-  case 'darwin':
-    localFileExisted = existsSync(join(__dirname, 'nx.darwin-universal.node'))
-    try {
-      if (localFileExisted) {
-        nativeBinding = __nccwpck_require__(99829)
-      } else {
-        nativeBinding = __nccwpck_require__(51641)
-      }
-      break
-    } catch {}
-    switch (arch) {
-      case 'x64':
-        localFileExisted = existsSync(join(__dirname, 'nx.darwin-x64.node'))
-        try {
-          if (localFileExisted) {
-            nativeBinding = __nccwpck_require__(79412)
-          } else {
-            nativeBinding = __nccwpck_require__(85775)
-          }
-        } catch (e) {
-          loadError = e
+      case 'minor':
+        // If this is a pre-minor version, bump up to the same minor version.
+        // Otherwise increment minor.
+        // 1.2.0-5 bumps to 1.2.0
+        // 1.2.1 bumps to 1.3.0
+        if (this.patch !== 0 || this.prerelease.length === 0) {
+          this.minor++
         }
+        this.patch = 0
+        this.prerelease = []
         break
-      case 'arm64':
-        localFileExisted = existsSync(
-          join(__dirname, 'nx.darwin-arm64.node')
-        )
-        try {
-          if (localFileExisted) {
-            nativeBinding = __nccwpck_require__(64639)
-          } else {
-            nativeBinding = __nccwpck_require__(10498)
-          }
-        } catch (e) {
-          loadError = e
+      case 'patch':
+        // If this is not a pre-release version, it will increment the patch.
+        // If it is a pre-release it will bump up to the same patch version.
+        // 1.2.0-5 patches to 1.2.0
+        // 1.2.0 patches to 1.2.1
+        if (this.prerelease.length === 0) {
+          this.patch++
         }
+        this.prerelease = []
         break
-      default:
-        throw new Error(`Unsupported architecture on macOS: ${arch}`)
-    }
-    break
-  case 'freebsd':
-    if (arch !== 'x64') {
-      throw new Error(`Unsupported architecture on FreeBSD: ${arch}`)
-    }
-    localFileExisted = existsSync(join(__dirname, 'nx.freebsd-x64.node'))
-    try {
-      if (localFileExisted) {
-        nativeBinding = __nccwpck_require__(7678)
-      } else {
-        nativeBinding = __nccwpck_require__(64160)
-      }
-    } catch (e) {
-      loadError = e
-    }
-    break
-  case 'linux':
-    switch (arch) {
-      case 'x64':
-        if (isMusl()) {
-          localFileExisted = existsSync(
-            join(__dirname, 'nx.linux-x64-musl.node')
-          )
-          try {
-            if (localFileExisted) {
-              nativeBinding = __nccwpck_require__(67479)
-            } else {
-              nativeBinding = __nccwpck_require__(93490)
+      // This probably shouldn't be used publicly.
+      // 1.0.0 'pre' would become 1.0.0-0 which is the wrong direction.
+      case 'pre': {
+        const base = Number(identifierBase) ? 1 : 0
+
+        if (!identifier && identifierBase === false) {
+          throw new Error('invalid increment argument: identifier is empty')
+        }
+
+        if (this.prerelease.length === 0) {
+          this.prerelease = [base]
+        } else {
+          let i = this.prerelease.length
+          while (--i >= 0) {
+            if (typeof this.prerelease[i] === 'number') {
+              this.prerelease[i]++
+              i = -2
             }
-          } catch (e) {
-            loadError = e
           }
-        } else {
-          localFileExisted = existsSync(
-            join(__dirname, 'nx.linux-x64-gnu.node')
-          )
-          try {
-            if (localFileExisted) {
-              nativeBinding = __nccwpck_require__(46888)
-            } else {
-              nativeBinding = __nccwpck_require__(94444)
+          if (i === -1) {
+            // didn't increment anything
+            if (identifier === this.prerelease.join('.') && identifierBase === false) {
+              throw new Error('invalid increment argument: identifier already exists')
             }
-          } catch (e) {
-            loadError = e
+            this.prerelease.push(base)
           }
         }
-        break
-      case 'arm64':
-        if (isMusl()) {
-          localFileExisted = existsSync(
-            join(__dirname, 'nx.linux-arm64-musl.node')
-          )
-          try {
-            if (localFileExisted) {
-              nativeBinding = __nccwpck_require__(32938)
-            } else {
-              nativeBinding = __nccwpck_require__(67311)
-            }
-          } catch (e) {
-            loadError = e
+        if (identifier) {
+          // 1.2.0-beta.1 bumps to 1.2.0-beta.2,
+          // 1.2.0-beta.fooblz or 1.2.0-beta bumps to 1.2.0-beta.0
+          let prerelease = [identifier, base]
+          if (identifierBase === false) {
+            prerelease = [identifier]
           }
-        } else {
-          localFileExisted = existsSync(
-            join(__dirname, 'nx.linux-arm64-gnu.node')
-          )
-          try {
-            if (localFileExisted) {
-              nativeBinding = __nccwpck_require__(90179)
-            } else {
-              nativeBinding = __nccwpck_require__(36708)
+          if (compareIdentifiers(this.prerelease[0], identifier) === 0) {
+            if (isNaN(this.prerelease[1])) {
+              this.prerelease = prerelease
             }
-          } catch (e) {
-            loadError = e
-          }
-        }
-        break
-      case 'arm':
-        localFileExisted = existsSync(
-          join(__dirname, 'nx.linux-arm-gnueabihf.node')
-        )
-        try {
-          if (localFileExisted) {
-            nativeBinding = __nccwpck_require__(50050)
           } else {
-            nativeBinding = __nccwpck_require__(8429)
+            this.prerelease = prerelease
           }
-        } catch (e) {
-          loadError = e
         }
         break
+      }
       default:
-        throw new Error(`Unsupported architecture on Linux: ${arch}`)
+        throw new Error(`invalid increment argument: ${release}`)
     }
-    break
-  default:
-    throw new Error(`Unsupported OS: ${platform}, architecture: ${arch}`)
+    this.raw = this.format()
+    if (this.build.length) {
+      this.raw += `+${this.build.join('.')}`
+    }
+    return this
+  }
 }
 
-if (!nativeBinding) {
-  if (loadError) {
-    throw loadError
-  }
-  throw new Error(`Failed to load native binding`)
+module.exports = SemVer
+
+
+/***/ }),
+
+/***/ 30262:
+/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+
+const parse = __nccwpck_require__(13857)
+const clean = (version, options) => {
+  const s = parse(version.trim().replace(/^[=v]+/, ''), options)
+  return s ? s.version : null
 }
+module.exports = clean
 
-const { hashArray, hashFile, hashFiles } = nativeBinding
 
-module.exports.hashArray = hashArray
-module.exports.hashFile = hashFile
-module.exports.hashFiles = hashFiles
+/***/ }),
+
+/***/ 97714:
+/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+
+const eq = __nccwpck_require__(68537)
+const neq = __nccwpck_require__(89176)
+const gt = __nccwpck_require__(71381)
+const gte = __nccwpck_require__(52498)
+const lt = __nccwpck_require__(75330)
+const lte = __nccwpck_require__(84698)
+
+const cmp = (a, op, b, loose) => {
+  switch (op) {
+    case '===':
+      if (typeof a === 'object') {
+        a = a.version
+      }
+      if (typeof b === 'object') {
+        b = b.version
+      }
+      return a === b
+
+    case '!==':
+      if (typeof a === 'object') {
+        a = a.version
+      }
+      if (typeof b === 'object') {
+        b = b.version
+      }
+      return a !== b
+
+    case '':
+    case '=':
+    case '==':
+      return eq(a, b, loose)
+
+    case '!=':
+      return neq(a, b, loose)
+
+    case '>':
+      return gt(a, b, loose)
+
+    case '>=':
+      return gte(a, b, loose)
+
+    case '<':
+      return lt(a, b, loose)
+
+    case '<=':
+      return lte(a, b, loose)
+
+    default:
+      throw new TypeError(`Invalid operator: ${op}`)
+  }
+}
+module.exports = cmp
 
 
 /***/ }),
 
-/***/ 71777:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
+/***/ 93292:
+/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
-"use strict";
+const SemVer = __nccwpck_require__(93097)
+const parse = __nccwpck_require__(13857)
+const { safeRe: re, t } = __nccwpck_require__(49815)
 
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.processProjectGraph = void 0;
-const tslib_1 = __nccwpck_require__(51796);
-const project_graph_builder_1 = __nccwpck_require__(14812);
-const build_dependencies_1 = __nccwpck_require__(89977);
-const configuration_1 = __nccwpck_require__(65459);
-const fileutils_1 = __nccwpck_require__(47930);
-const lock_file_1 = __nccwpck_require__(88740);
-const path_1 = __nccwpck_require__(71017);
-const cache_directory_1 = __nccwpck_require__(20858);
-const fs_1 = __nccwpck_require__(57147);
-const workspace_root_1 = __nccwpck_require__(65766);
-const fs_extra_1 = __nccwpck_require__(59511);
-const processProjectGraph = (graph, context) => tslib_1.__awaiter(void 0, void 0, void 0, function* () {
-    const builder = new project_graph_builder_1.ProjectGraphBuilder(graph, context.fileMap);
-    const pluginConfig = jsPluginConfig((0, configuration_1.readNxJson)());
-    if (pluginConfig.analyzePackageJson) {
-        // during the create-nx-workspace lock file might not exists yet
-        if ((0, lock_file_1.lockFileExists)()) {
-            const lockHash = (0, lock_file_1.lockFileHash)();
-            let parsedLockFile;
-            if (lockFileNeedsReprocessing(lockHash)) {
-                parsedLockFile = (0, lock_file_1.parseLockFile)();
-                writeLastProcessedLockfileHash(lockHash, parsedLockFile);
-            }
-            else {
-                parsedLockFile = readParsedLockFile();
-            }
-            builder.mergeProjectGraph(parsedLockFile);
-        }
-    }
-    yield (0, build_dependencies_1.buildExplicitDependencies)(pluginConfig, context, builder);
-    return builder.getUpdatedProjectGraph();
-});
-exports.processProjectGraph = processProjectGraph;
-const lockFileHashFile = (0, path_1.join)(cache_directory_1.projectGraphCacheDirectory, 'lockfile.hash');
-const parsedLockFile = (0, path_1.join)(cache_directory_1.projectGraphCacheDirectory, 'parsed-lock-file.json');
-function lockFileNeedsReprocessing(lockHash) {
-    try {
-        return (0, fs_1.readFileSync)(lockFileHashFile).toString() !== lockHash;
-    }
-    catch (_a) {
-        return true;
+const coerce = (version, options) => {
+  if (version instanceof SemVer) {
+    return version
+  }
+
+  if (typeof version === 'number') {
+    version = String(version)
+  }
+
+  if (typeof version !== 'string') {
+    return null
+  }
+
+  options = options || {}
+
+  let match = null
+  if (!options.rtl) {
+    match = version.match(re[t.COERCE])
+  } else {
+    // Find the right-most coercible string that does not share
+    // a terminus with a more left-ward coercible string.
+    // Eg, '1.2.3.4' wants to coerce '2.3.4', not '3.4' or '4'
+    //
+    // Walk through the string checking with a /g regexp
+    // Manually set the index so as to pick up overlapping matches.
+    // Stop when we get a match that ends at the string end, since no
+    // coercible string can be more right-ward without the same terminus.
+    let next
+    while ((next = re[t.COERCERTL].exec(version)) &&
+        (!match || match.index + match[0].length !== version.length)
+    ) {
+      if (!match ||
+            next.index + next[0].length !== match.index + match[0].length) {
+        match = next
+      }
+      re[t.COERCERTL].lastIndex = next.index + next[1].length + next[2].length
     }
+    // leave it in a clean state
+    re[t.COERCERTL].lastIndex = -1
+  }
+
+  if (match === null) {
+    return null
+  }
+
+  return parse(`${match[2]}.${match[3] || '0'}.${match[4] || '0'}`, options)
 }
-function writeLastProcessedLockfileHash(hash, lockFile) {
-    (0, fs_extra_1.ensureDirSync)((0, path_1.dirname)(lockFileHashFile));
-    (0, fs_1.writeFileSync)(parsedLockFile, JSON.stringify(lockFile, null, 2));
-    (0, fs_1.writeFileSync)(lockFileHashFile, hash);
-}
-function readParsedLockFile() {
-    return JSON.parse((0, fs_1.readFileSync)(parsedLockFile).toString());
-}
-function jsPluginConfig(nxJson) {
-    var _a, _b, _c;
-    const nxJsonConfig = (_b = (_a = nxJson === null || nxJson === void 0 ? void 0 : nxJson.pluginsConfig) === null || _a === void 0 ? void 0 : _a['@nx/js']) !== null && _b !== void 0 ? _b : (_c = nxJson === null || nxJson === void 0 ? void 0 : nxJson.pluginsConfig) === null || _c === void 0 ? void 0 : _c['@nrwl/js'];
-    if (nxJsonConfig) {
-        return Object.assign({ analyzePackageJson: true, analyzeSourceFiles: true }, nxJsonConfig);
-    }
-    if (!(0, fileutils_1.fileExists)((0, path_1.join)(workspace_root_1.workspaceRoot, 'package.json'))) {
-        return {
-            analyzePackageJson: false,
-            analyzeSourceFiles: false,
-        };
-    }
-    const packageJson = (0, fileutils_1.readJsonFile)((0, path_1.join)(workspace_root_1.workspaceRoot, 'package.json'));
-    const packageJsonDeps = Object.assign(Object.assign({}, packageJson.dependencies), packageJson.devDependencies);
-    if (packageJsonDeps['@nx/workspace'] ||
-        packageJsonDeps['@nx/js'] ||
-        packageJsonDeps['@nx/node'] ||
-        packageJsonDeps['@nx/next'] ||
-        packageJsonDeps['@nx/react'] ||
-        packageJsonDeps['@nx/angular'] ||
-        packageJsonDeps['@nx/web'] ||
-        packageJsonDeps['@nrwl/workspace'] ||
-        packageJsonDeps['@nrwl/js'] ||
-        packageJsonDeps['@nrwl/node'] ||
-        packageJsonDeps['@nrwl/next'] ||
-        packageJsonDeps['@nrwl/react'] ||
-        packageJsonDeps['@nrwl/angular'] ||
-        packageJsonDeps['@nrwl/web']) {
-        return { analyzePackageJson: true, analyzeSourceFiles: true };
-    }
-    else {
-        return { analyzePackageJson: true, analyzeSourceFiles: false };
-    }
+module.exports = coerce
+
+
+/***/ }),
+
+/***/ 73756:
+/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+
+const SemVer = __nccwpck_require__(93097)
+const compareBuild = (a, b, loose) => {
+  const versionA = new SemVer(a, loose)
+  const versionB = new SemVer(b, loose)
+  return versionA.compare(versionB) || versionA.compareBuild(versionB)
 }
+module.exports = compareBuild
 
 
 /***/ }),
 
-/***/ 88740:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
+/***/ 25250:
+/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
-"use strict";
+const compare = __nccwpck_require__(36208)
+const compareLoose = (a, b) => compare(a, b, true)
+module.exports = compareLoose
 
-/**
- * This is the main API for accessing the lock file functionality.
- * It encapsulates the package manager specific logic and implementation details.
- */
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.createLockFile = exports.getLockFileName = exports.parseLockFile = exports.lockFileHash = exports.lockFileExists = void 0;
-const fs_1 = __nccwpck_require__(57147);
-const path_1 = __nccwpck_require__(71017);
-const package_manager_1 = __nccwpck_require__(15425);
-const workspace_root_1 = __nccwpck_require__(65766);
-const project_graph_builder_1 = __nccwpck_require__(14812);
-const impl_1 = __nccwpck_require__(43265);
-const output_1 = __nccwpck_require__(34548);
-const npm_parser_1 = __nccwpck_require__(695);
-const pnpm_parser_1 = __nccwpck_require__(93369);
-const yarn_parser_1 = __nccwpck_require__(33875);
-const project_graph_pruning_1 = __nccwpck_require__(38770);
-const package_json_1 = __nccwpck_require__(6500);
-const YARN_LOCK_FILE = 'yarn.lock';
-const NPM_LOCK_FILE = 'package-lock.json';
-const PNPM_LOCK_FILE = 'pnpm-lock.yaml';
-const YARN_LOCK_PATH = (0, path_1.join)(workspace_root_1.workspaceRoot, YARN_LOCK_FILE);
-const NPM_LOCK_PATH = (0, path_1.join)(workspace_root_1.workspaceRoot, NPM_LOCK_FILE);
-const PNPM_LOCK_PATH = (0, path_1.join)(workspace_root_1.workspaceRoot, PNPM_LOCK_FILE);
-/**
- * Check if lock file exists
- */
-function lockFileExists(packageManager = (0, package_manager_1.detectPackageManager)(workspace_root_1.workspaceRoot)) {
-    if (packageManager === 'yarn') {
-        return (0, fs_1.existsSync)(YARN_LOCK_PATH);
+
+/***/ }),
+
+/***/ 36208:
+/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+
+const SemVer = __nccwpck_require__(93097)
+const compare = (a, b, loose) =>
+  new SemVer(a, loose).compare(new SemVer(b, loose))
+
+module.exports = compare
+
+
+/***/ }),
+
+/***/ 79439:
+/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+
+const parse = __nccwpck_require__(13857)
+
+const diff = (version1, version2) => {
+  const v1 = parse(version1, null, true)
+  const v2 = parse(version2, null, true)
+  const comparison = v1.compare(v2)
+
+  if (comparison === 0) {
+    return null
+  }
+
+  const v1Higher = comparison > 0
+  const highVersion = v1Higher ? v1 : v2
+  const lowVersion = v1Higher ? v2 : v1
+  const highHasPre = !!highVersion.prerelease.length
+  const lowHasPre = !!lowVersion.prerelease.length
+
+  if (lowHasPre && !highHasPre) {
+    // Going from prerelease -> no prerelease requires some special casing
+
+    // If the low version has only a major, then it will always be a major
+    // Some examples:
+    // 1.0.0-1 -> 1.0.0
+    // 1.0.0-1 -> 1.1.1
+    // 1.0.0-1 -> 2.0.0
+    if (!lowVersion.patch && !lowVersion.minor) {
+      return 'major'
     }
-    if (packageManager === 'pnpm') {
-        return (0, fs_1.existsSync)(PNPM_LOCK_PATH);
+
+    // Otherwise it can be determined by checking the high version
+
+    if (highVersion.patch) {
+      // anything higher than a patch bump would result in the wrong version
+      return 'patch'
     }
-    if (packageManager === 'npm') {
-        return (0, fs_1.existsSync)(NPM_LOCK_PATH);
+
+    if (highVersion.minor) {
+      // anything higher than a minor bump would result in the wrong version
+      return 'minor'
     }
-    throw new Error(`Unknown package manager ${packageManager} or lock file missing`);
+
+    // bumping major/minor/patch all have same result
+    return 'major'
+  }
+
+  // add the `pre` prefix if we are going to a prerelease version
+  const prefix = highHasPre ? 'pre' : ''
+
+  if (v1.major !== v2.major) {
+    return prefix + 'major'
+  }
+
+  if (v1.minor !== v2.minor) {
+    return prefix + 'minor'
+  }
+
+  if (v1.patch !== v2.patch) {
+    return prefix + 'patch'
+  }
+
+  // high and low are preleases
+  return 'prerelease'
 }
-exports.lockFileExists = lockFileExists;
-/**
- * Hashes lock file content
- */
-function lockFileHash(packageManager = (0, package_manager_1.detectPackageManager)(workspace_root_1.workspaceRoot)) {
-    let content;
-    if (packageManager === 'yarn') {
-        content = (0, fs_1.readFileSync)(YARN_LOCK_PATH, 'utf8');
-    }
-    if (packageManager === 'pnpm') {
-        content = (0, fs_1.readFileSync)(PNPM_LOCK_PATH, 'utf8');
-    }
-    if (packageManager === 'npm') {
-        content = (0, fs_1.readFileSync)(NPM_LOCK_PATH, 'utf8');
-    }
-    if (content) {
-        return (0, impl_1.hashArray)([content]);
-    }
-    else {
-        throw new Error(`Unknown package manager ${packageManager} or lock file missing`);
-    }
+
+module.exports = diff
+
+
+/***/ }),
+
+/***/ 68537:
+/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+
+const compare = __nccwpck_require__(36208)
+const eq = (a, b, loose) => compare(a, b, loose) === 0
+module.exports = eq
+
+
+/***/ }),
+
+/***/ 71381:
+/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+
+const compare = __nccwpck_require__(36208)
+const gt = (a, b, loose) => compare(a, b, loose) > 0
+module.exports = gt
+
+
+/***/ }),
+
+/***/ 52498:
+/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+
+const compare = __nccwpck_require__(36208)
+const gte = (a, b, loose) => compare(a, b, loose) >= 0
+module.exports = gte
+
+
+/***/ }),
+
+/***/ 7788:
+/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+
+const SemVer = __nccwpck_require__(93097)
+
+const inc = (version, release, options, identifier, identifierBase) => {
+  if (typeof (options) === 'string') {
+    identifierBase = identifier
+    identifier = options
+    options = undefined
+  }
+
+  try {
+    return new SemVer(
+      version instanceof SemVer ? version.version : version,
+      options
+    ).inc(release, identifier, identifierBase).version
+  } catch (er) {
+    return null
+  }
 }
-exports.lockFileHash = lockFileHash;
-/**
- * Parses lock file and maps dependencies and metadata to {@link LockFileGraph}
- */
-function parseLockFile(packageManager = (0, package_manager_1.detectPackageManager)(workspace_root_1.workspaceRoot)) {
-    const builder = new project_graph_builder_1.ProjectGraphBuilder(null, null);
-    try {
-        if (packageManager === 'yarn') {
-            const content = (0, fs_1.readFileSync)(YARN_LOCK_PATH, 'utf8');
-            (0, yarn_parser_1.parseYarnLockfile)(content, builder);
-            return builder.getUpdatedProjectGraph();
-        }
-        if (packageManager === 'pnpm') {
-            const content = (0, fs_1.readFileSync)(PNPM_LOCK_PATH, 'utf8');
-            (0, pnpm_parser_1.parsePnpmLockfile)(content, builder);
-            return builder.getUpdatedProjectGraph();
-        }
-        if (packageManager === 'npm') {
-            const content = (0, fs_1.readFileSync)(NPM_LOCK_PATH, 'utf8');
-            (0, npm_parser_1.parseNpmLockfile)(content, builder);
-            return builder.getUpdatedProjectGraph();
-        }
-    }
-    catch (e) {
-        if (!isPostInstallProcess()) {
-            output_1.output.error({
-                title: `Failed to parse ${packageManager} lockfile`,
-                bodyLines: errorBodyLines(e),
-            });
-        }
-        return;
+module.exports = inc
+
+
+/***/ }),
+
+/***/ 75330:
+/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+
+const compare = __nccwpck_require__(36208)
+const lt = (a, b, loose) => compare(a, b, loose) < 0
+module.exports = lt
+
+
+/***/ }),
+
+/***/ 84698:
+/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+
+const compare = __nccwpck_require__(36208)
+const lte = (a, b, loose) => compare(a, b, loose) <= 0
+module.exports = lte
+
+
+/***/ }),
+
+/***/ 91163:
+/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+
+const SemVer = __nccwpck_require__(93097)
+const major = (a, loose) => new SemVer(a, loose).major
+module.exports = major
+
+
+/***/ }),
+
+/***/ 55612:
+/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+
+const SemVer = __nccwpck_require__(93097)
+const minor = (a, loose) => new SemVer(a, loose).minor
+module.exports = minor
+
+
+/***/ }),
+
+/***/ 89176:
+/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+
+const compare = __nccwpck_require__(36208)
+const neq = (a, b, loose) => compare(a, b, loose) !== 0
+module.exports = neq
+
+
+/***/ }),
+
+/***/ 13857:
+/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+
+const SemVer = __nccwpck_require__(93097)
+const parse = (version, options, throwErrors = false) => {
+  if (version instanceof SemVer) {
+    return version
+  }
+  try {
+    return new SemVer(version, options)
+  } catch (er) {
+    if (!throwErrors) {
+      return null
     }
-    throw new Error(`Unknown package manager: ${packageManager}`);
+    throw er
+  }
 }
-exports.parseLockFile = parseLockFile;
-/**
- * Returns lock file name based on the detected package manager in the root
- * @param packageManager
- * @returns
- */
-function getLockFileName(packageManager = (0, package_manager_1.detectPackageManager)(workspace_root_1.workspaceRoot)) {
-    if (packageManager === 'yarn') {
-        return YARN_LOCK_FILE;
-    }
-    if (packageManager === 'pnpm') {
-        return PNPM_LOCK_FILE;
-    }
-    if (packageManager === 'npm') {
-        return NPM_LOCK_FILE;
-    }
-    throw new Error(`Unknown package manager: ${packageManager}`);
+
+module.exports = parse
+
+
+/***/ }),
+
+/***/ 38899:
+/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+
+const SemVer = __nccwpck_require__(93097)
+const patch = (a, loose) => new SemVer(a, loose).patch
+module.exports = patch
+
+
+/***/ }),
+
+/***/ 7958:
+/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+
+const parse = __nccwpck_require__(13857)
+const prerelease = (version, options) => {
+  const parsed = parse(version, options)
+  return (parsed && parsed.prerelease.length) ? parsed.prerelease : null
 }
-exports.getLockFileName = getLockFileName;
-/**
- * Create lock file based on the root level lock file and (pruned) package.json
- *
- * @param packageJson
- * @param isProduction
- * @param packageManager
- * @returns
- */
-function createLockFile(packageJson, packageManager = (0, package_manager_1.detectPackageManager)(workspace_root_1.workspaceRoot)) {
-    const normalizedPackageJson = (0, package_json_1.normalizePackageJson)(packageJson);
-    const content = (0, fs_1.readFileSync)(getLockFileName(packageManager), 'utf8');
-    const builder = new project_graph_builder_1.ProjectGraphBuilder();
-    try {
-        if (packageManager === 'yarn') {
-            (0, yarn_parser_1.parseYarnLockfile)(content, builder);
-            const graph = builder.getUpdatedProjectGraph();
-            const prunedGraph = (0, project_graph_pruning_1.pruneProjectGraph)(graph, packageJson);
-            return (0, yarn_parser_1.stringifyYarnLockfile)(prunedGraph, content, normalizedPackageJson);
-        }
-        if (packageManager === 'pnpm') {
-            (0, pnpm_parser_1.parsePnpmLockfile)(content, builder);
-            const graph = builder.getUpdatedProjectGraph();
-            const prunedGraph = (0, project_graph_pruning_1.pruneProjectGraph)(graph, packageJson);
-            return (0, pnpm_parser_1.stringifyPnpmLockfile)(prunedGraph, content, normalizedPackageJson);
-        }
-        if (packageManager === 'npm') {
-            (0, npm_parser_1.parseNpmLockfile)(content, builder);
-            const graph = builder.getUpdatedProjectGraph();
-            const prunedGraph = (0, project_graph_pruning_1.pruneProjectGraph)(graph, packageJson);
-            return (0, npm_parser_1.stringifyNpmLockfile)(prunedGraph, content, normalizedPackageJson);
-        }
-    }
-    catch (e) {
-        if (!isPostInstallProcess()) {
-            const additionalInfo = [
-                'To prevent the build from breaking we are returning the root lock file.',
-            ];
-            if (packageManager === 'npm') {
-                additionalInfo.push('If you run `npm install --package-lock-only` in your output folder it will regenerate the correct pruned lockfile.');
-            }
-            if (packageManager === 'pnpm') {
-                additionalInfo.push('If you run `pnpm install --lockfile-only` in your output folder it will regenerate the correct pruned lockfile.');
-            }
-            output_1.output.error({
-                title: 'An error occured while creating pruned lockfile',
-                bodyLines: errorBodyLines(e, additionalInfo),
-            });
-        }
-        return content;
-    }
+module.exports = prerelease
+
+
+/***/ }),
+
+/***/ 3628:
+/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+
+const compare = __nccwpck_require__(36208)
+const rcompare = (a, b, loose) => compare(b, a, loose)
+module.exports = rcompare
+
+
+/***/ }),
+
+/***/ 84358:
+/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+
+const compareBuild = __nccwpck_require__(73756)
+const rsort = (list, loose) => list.sort((a, b) => compareBuild(b, a, loose))
+module.exports = rsort
+
+
+/***/ }),
+
+/***/ 77477:
+/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+
+const Range = __nccwpck_require__(70434)
+const satisfies = (version, range, options) => {
+  try {
+    range = new Range(range, options)
+  } catch (er) {
+    return false
+  }
+  return range.test(version)
 }
-exports.createLockFile = createLockFile;
-// generate body lines for error message
-function errorBodyLines(originalError, additionalInfo = []) {
-    return [
-        'Please open an issue at `https://github.com/nrwl/nx/issues/new?template=1-bug.yml` and provide a reproduction.',
-        ...additionalInfo,
-        `\nOriginal error: ${originalError.message}\n\n`,
-        originalError.stack,
-    ];
+module.exports = satisfies
+
+
+/***/ }),
+
+/***/ 40241:
+/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+
+const compareBuild = __nccwpck_require__(73756)
+const sort = (list, loose) => list.sort((a, b) => compareBuild(a, b, loose))
+module.exports = sort
+
+
+/***/ }),
+
+/***/ 17503:
+/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+
+const parse = __nccwpck_require__(13857)
+const valid = (version, options) => {
+  const v = parse(version, options)
+  return v ? v.version : null
 }
-function isPostInstallProcess() {
-    return (process.env.npm_command === 'install' &&
-        process.env.npm_lifecycle_event === 'postinstall');
+module.exports = valid
+
+
+/***/ }),
+
+/***/ 66195:
+/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+
+// just pre-load all the stuff that index.js lazily exports
+const internalRe = __nccwpck_require__(49815)
+const constants = __nccwpck_require__(96730)
+const SemVer = __nccwpck_require__(93097)
+const identifiers = __nccwpck_require__(67701)
+const parse = __nccwpck_require__(13857)
+const valid = __nccwpck_require__(17503)
+const clean = __nccwpck_require__(30262)
+const inc = __nccwpck_require__(7788)
+const diff = __nccwpck_require__(79439)
+const major = __nccwpck_require__(91163)
+const minor = __nccwpck_require__(55612)
+const patch = __nccwpck_require__(38899)
+const prerelease = __nccwpck_require__(7958)
+const compare = __nccwpck_require__(36208)
+const rcompare = __nccwpck_require__(3628)
+const compareLoose = __nccwpck_require__(25250)
+const compareBuild = __nccwpck_require__(73756)
+const sort = __nccwpck_require__(40241)
+const rsort = __nccwpck_require__(84358)
+const gt = __nccwpck_require__(71381)
+const lt = __nccwpck_require__(75330)
+const eq = __nccwpck_require__(68537)
+const neq = __nccwpck_require__(89176)
+const gte = __nccwpck_require__(52498)
+const lte = __nccwpck_require__(84698)
+const cmp = __nccwpck_require__(97714)
+const coerce = __nccwpck_require__(93292)
+const Comparator = __nccwpck_require__(14658)
+const Range = __nccwpck_require__(70434)
+const satisfies = __nccwpck_require__(77477)
+const toComparators = __nccwpck_require__(45827)
+const maxSatisfying = __nccwpck_require__(59530)
+const minSatisfying = __nccwpck_require__(81539)
+const minVersion = __nccwpck_require__(56296)
+const validRange = __nccwpck_require__(88902)
+const outside = __nccwpck_require__(69808)
+const gtr = __nccwpck_require__(97557)
+const ltr = __nccwpck_require__(64666)
+const intersects = __nccwpck_require__(28658)
+const simplifyRange = __nccwpck_require__(1259)
+const subset = __nccwpck_require__(95865)
+module.exports = {
+  parse,
+  valid,
+  clean,
+  inc,
+  diff,
+  major,
+  minor,
+  patch,
+  prerelease,
+  compare,
+  rcompare,
+  compareLoose,
+  compareBuild,
+  sort,
+  rsort,
+  gt,
+  lt,
+  eq,
+  neq,
+  gte,
+  lte,
+  cmp,
+  coerce,
+  Comparator,
+  Range,
+  satisfies,
+  toComparators,
+  maxSatisfying,
+  minSatisfying,
+  minVersion,
+  validRange,
+  outside,
+  gtr,
+  ltr,
+  intersects,
+  simplifyRange,
+  subset,
+  SemVer,
+  re: internalRe.re,
+  src: internalRe.src,
+  tokens: internalRe.t,
+  SEMVER_SPEC_VERSION: constants.SEMVER_SPEC_VERSION,
+  RELEASE_TYPES: constants.RELEASE_TYPES,
+  compareIdentifiers: identifiers.compareIdentifiers,
+  rcompareIdentifiers: identifiers.rcompareIdentifiers,
 }
 
 
 /***/ }),
 
-/***/ 695:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
+/***/ 96730:
+/***/ ((module) => {
 
-"use strict";
+// Note: this is the semver.org version of the spec that it implements
+// Not necessarily the package version of this code.
+const SEMVER_SPEC_VERSION = '2.0.0'
 
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.stringifyNpmLockfile = exports.parseNpmLockfile = void 0;
-const tslib_1 = __nccwpck_require__(51796);
-const fs_1 = __nccwpck_require__(57147);
-const semver_1 = __nccwpck_require__(56192);
-const workspace_root_1 = __nccwpck_require__(65766);
-const operators_1 = __nccwpck_require__(97607);
-const impl_1 = __nccwpck_require__(43265);
-function parseNpmLockfile(lockFileContent, builder) {
-    const data = JSON.parse(lockFileContent);
-    // we use key => node map to avoid duplicate work when parsing keys
-    const keyMap = new Map();
-    addNodes(data, builder, keyMap);
-    addDependencies(data, builder, keyMap);
+const MAX_LENGTH = 256
+const MAX_SAFE_INTEGER = Number.MAX_SAFE_INTEGER ||
+/* istanbul ignore next */ 9007199254740991
+
+// Max safe segment length for coercion.
+const MAX_SAFE_COMPONENT_LENGTH = 16
+
+// Max safe length for a build identifier. The max length minus 6 characters for
+// the shortest version with a build 0.0.0+BUILD.
+const MAX_SAFE_BUILD_LENGTH = MAX_LENGTH - 6
+
+const RELEASE_TYPES = [
+  'major',
+  'premajor',
+  'minor',
+  'preminor',
+  'patch',
+  'prepatch',
+  'prerelease',
+]
+
+module.exports = {
+  MAX_LENGTH,
+  MAX_SAFE_COMPONENT_LENGTH,
+  MAX_SAFE_BUILD_LENGTH,
+  MAX_SAFE_INTEGER,
+  RELEASE_TYPES,
+  SEMVER_SPEC_VERSION,
+  FLAG_INCLUDE_PRERELEASE: 0b001,
+  FLAG_LOOSE: 0b010,
 }
-exports.parseNpmLockfile = parseNpmLockfile;
-function addNodes(data, builder, keyMap) {
-    const nodes = new Map();
-    if (data.lockfileVersion > 1) {
-        Object.entries(data.packages).forEach(([path, snapshot]) => {
-            // skip workspaces packages
-            if (path === '' || !path.includes('node_modules') || snapshot.link) {
-                return;
-            }
-            const packageName = path.split('node_modules/').pop();
-            const version = findV3Version(snapshot, packageName);
-            createNode(packageName, version, path, nodes, keyMap, snapshot);
-        });
-    }
-    else {
-        Object.entries(data.dependencies).forEach(([packageName, snapshot]) => {
-            var _a;
-            // we only care about dependencies of workspace packages
-            if ((_a = snapshot.version) === null || _a === void 0 ? void 0 : _a.startsWith('file:')) {
-                if (snapshot.dependencies) {
-                    Object.entries(snapshot.dependencies).forEach(([depName, depSnapshot]) => {
-                        addV1Node(depName, depSnapshot, `${snapshot.version.slice(5)}/node_modules/${depName}`, nodes, keyMap, builder);
-                    });
-                }
-            }
-            else {
-                addV1Node(packageName, snapshot, `node_modules/${packageName}`, nodes, keyMap, builder);
-            }
-        });
-    }
-    // some packages can be both hoisted and nested
-    // so we need to run this check once we have all the nodes and paths
-    for (const [packageName, versionMap] of nodes.entries()) {
-        const hoistedNode = keyMap.get(`node_modules/${packageName}`);
-        if (hoistedNode) {
-            hoistedNode.name = `npm:${packageName}`;
-        }
-        versionMap.forEach((node) => {
-            builder.addExternalNode(node);
-        });
-    }
+
+
+/***/ }),
+
+/***/ 19723:
+/***/ ((module) => {
+
+const debug = (
+  typeof process === 'object' &&
+  process.env &&
+  process.env.NODE_DEBUG &&
+  /\bsemver\b/i.test(process.env.NODE_DEBUG)
+) ? (...args) => console.error('SEMVER', ...args)
+  : () => {}
+
+module.exports = debug
+
+
+/***/ }),
+
+/***/ 67701:
+/***/ ((module) => {
+
+const numeric = /^[0-9]+$/
+const compareIdentifiers = (a, b) => {
+  const anum = numeric.test(a)
+  const bnum = numeric.test(b)
+
+  if (anum && bnum) {
+    a = +a
+    b = +b
+  }
+
+  return a === b ? 0
+    : (anum && !bnum) ? -1
+    : (bnum && !anum) ? 1
+    : a < b ? -1
+    : 1
 }
-function addV1Node(packageName, snapshot, path, nodes, keyMap, builder) {
-    createNode(packageName, snapshot.version, path, nodes, keyMap, snapshot);
-    // traverse nested dependencies
-    if (snapshot.dependencies) {
-        Object.entries(snapshot.dependencies).forEach(([depName, depSnapshot]) => {
-            addV1Node(depName, depSnapshot, `${path}/node_modules/${depName}`, nodes, keyMap, builder);
-        });
-    }
+
+const rcompareIdentifiers = (a, b) => compareIdentifiers(b, a)
+
+module.exports = {
+  compareIdentifiers,
+  rcompareIdentifiers,
 }
-function createNode(packageName, version, key, nodes, keyMap, snapshot) {
-    var _a;
-    const existingNode = (_a = nodes.get(packageName)) === null || _a === void 0 ? void 0 : _a.get(version);
-    if (existingNode) {
-        keyMap.set(key, existingNode);
-        return;
-    }
-    const node = {
-        type: 'npm',
-        name: version ? `npm:${packageName}@${version}` : `npm:${packageName}`,
-        data: {
-            version,
-            packageName,
-            hash: snapshot.integrity ||
-                (0, impl_1.hashArray)(snapshot.resolved ? [snapshot.resolved] : [packageName, version]),
-        },
-    };
-    keyMap.set(key, node);
-    if (!nodes.has(packageName)) {
-        nodes.set(packageName, new Map([[version, node]]));
-    }
-    else {
-        nodes.get(packageName).set(version, node);
-    }
+
+
+/***/ }),
+
+/***/ 35375:
+/***/ ((module) => {
+
+// parse out just the options we care about
+const looseOption = Object.freeze({ loose: true })
+const emptyOpts = Object.freeze({ })
+const parseOptions = options => {
+  if (!options) {
+    return emptyOpts
+  }
+
+  if (typeof options !== 'object') {
+    return looseOption
+  }
+
+  return options
 }
-function findV3Version(snapshot, packageName) {
-    let version = snapshot.version;
-    const resolved = snapshot.resolved;
-    // for tarball packages version might not exist or be useless
-    if (!version || (resolved && !resolved.includes(version))) {
-        version = resolved;
-    }
-    // for alias packages name is set
-    if (snapshot.name && snapshot.name !== packageName) {
-        if (version) {
-            version = `npm:${snapshot.name}@${version}`;
-        }
-        else {
-            version = `npm:${snapshot.name}`;
-        }
-    }
-    return version;
+module.exports = parseOptions
+
+
+/***/ }),
+
+/***/ 49815:
+/***/ ((module, exports, __nccwpck_require__) => {
+
+const {
+  MAX_SAFE_COMPONENT_LENGTH,
+  MAX_SAFE_BUILD_LENGTH,
+  MAX_LENGTH,
+} = __nccwpck_require__(96730)
+const debug = __nccwpck_require__(19723)
+exports = module.exports = {}
+
+// The actual regexps go on exports.re
+const re = exports.re = []
+const safeRe = exports.safeRe = []
+const src = exports.src = []
+const t = exports.t = {}
+let R = 0
+
+const LETTERDASHNUMBER = '[a-zA-Z0-9-]'
+
+// Replace some greedy regex tokens to prevent regex dos issues. These regex are
+// used internally via the safeRe object since all inputs in this library get
+// normalized first to trim and collapse all extra whitespace. The original
+// regexes are exported for userland consumption and lower level usage. A
+// future breaking change could export the safer regex only with a note that
+// all input should have extra whitespace removed.
+const safeRegexReplacements = [
+  ['\\s', 1],
+  ['\\d', MAX_LENGTH],
+  [LETTERDASHNUMBER, MAX_SAFE_BUILD_LENGTH],
+]
+
+const makeSafeRegex = (value) => {
+  for (const [token, max] of safeRegexReplacements) {
+    value = value
+      .split(`${token}*`).join(`${token}{0,${max}}`)
+      .split(`${token}+`).join(`${token}{1,${max}}`)
+  }
+  return value
 }
-function addDependencies(data, builder, keyMap) {
-    if (data.lockfileVersion > 1) {
-        Object.entries(data.packages).forEach(([path, snapshot]) => {
-            // we are skipping workspaces packages
-            if (!keyMap.has(path)) {
-                return;
-            }
-            const sourceName = keyMap.get(path).name;
-            [
-                snapshot.peerDependencies,
-                snapshot.dependencies,
-                snapshot.optionalDependencies,
-            ].forEach((section) => {
-                if (section) {
-                    Object.entries(section).forEach(([name, versionRange]) => {
-                        const target = findTarget(path, keyMap, name, versionRange);
-                        if (target) {
-                            builder.addStaticDependency(sourceName, target.name);
-                        }
-                    });
-                }
-            });
-        });
-    }
-    else {
-        Object.entries(data.dependencies).forEach(([packageName, snapshot]) => {
-            addV1NodeDependencies(`node_modules/${packageName}`, snapshot, builder, keyMap);
-        });
-    }
+
+const createToken = (name, value, isGlobal) => {
+  const safe = makeSafeRegex(value)
+  const index = R++
+  debug(name, index, value)
+  t[name] = index
+  src[index] = value
+  re[index] = new RegExp(value, isGlobal ? 'g' : undefined)
+  safeRe[index] = new RegExp(safe, isGlobal ? 'g' : undefined)
 }
-function findTarget(sourcePath, keyMap, targetName, versionRange) {
-    if (sourcePath && !sourcePath.endsWith('/')) {
-        sourcePath = `${sourcePath}/`;
-    }
-    const searchPath = `${sourcePath}node_modules/${targetName}`;
-    if (keyMap.has(searchPath)) {
-        const child = keyMap.get(searchPath);
-        if (child.data.version === versionRange ||
-            (0, semver_1.satisfies)(child.data.version, versionRange)) {
-            return child;
-        }
-    }
-    // the hoisted package did not match, this dependency is missing
-    if (!sourcePath) {
-        return;
-    }
-    return findTarget(sourcePath.split('node_modules/').slice(0, -1).join('node_modules/'), keyMap, targetName, versionRange);
-}
-function addV1NodeDependencies(path, snapshot, builder, keyMap) {
-    if (keyMap.has(path) && snapshot.requires) {
-        const source = keyMap.get(path).name;
-        Object.entries(snapshot.requires).forEach(([name, versionRange]) => {
-            const target = findTarget(path, keyMap, name, versionRange);
-            if (target) {
-                builder.addStaticDependency(source, target.name);
-            }
-        });
-    }
-    if (snapshot.dependencies) {
-        Object.entries(snapshot.dependencies).forEach(([depName, depSnapshot]) => {
-            addV1NodeDependencies(`${path}/node_modules/${depName}`, depSnapshot, builder, keyMap);
-        });
-    }
-    const { peerDependencies } = getPeerDependencies(path);
-    if (peerDependencies) {
-        const node = keyMap.get(path);
-        Object.entries(peerDependencies).forEach(([depName, depSpec]) => {
-            var _a;
-            if (!((_a = builder.graph.dependencies[node.name]) === null || _a === void 0 ? void 0 : _a.find((d) => d.target === depName))) {
-                const target = findTarget(path, keyMap, depName, depSpec);
-                if (target) {
-                    builder.addStaticDependency(node.name, target.name);
-                }
-            }
-        });
-    }
+
+// The following Regular Expressions can be used for tokenizing,
+// validating, and parsing SemVer version strings.
+
+// ## Numeric Identifier
+// A single `0`, or a non-zero digit followed by zero or more digits.
+
+createToken('NUMERICIDENTIFIER', '0|[1-9]\\d*')
+createToken('NUMERICIDENTIFIERLOOSE', '\\d+')
+
+// ## Non-numeric Identifier
+// Zero or more digits, followed by a letter or hyphen, and then zero or
+// more letters, digits, or hyphens.
+
+createToken('NONNUMERICIDENTIFIER', `\\d*[a-zA-Z-]${LETTERDASHNUMBER}*`)
+
+// ## Main Version
+// Three dot-separated numeric identifiers.
+
+createToken('MAINVERSION', `(${src[t.NUMERICIDENTIFIER]})\\.` +
+                   `(${src[t.NUMERICIDENTIFIER]})\\.` +
+                   `(${src[t.NUMERICIDENTIFIER]})`)
+
+createToken('MAINVERSIONLOOSE', `(${src[t.NUMERICIDENTIFIERLOOSE]})\\.` +
+                        `(${src[t.NUMERICIDENTIFIERLOOSE]})\\.` +
+                        `(${src[t.NUMERICIDENTIFIERLOOSE]})`)
+
+// ## Pre-release Version Identifier
+// A numeric identifier, or a non-numeric identifier.
+
+createToken('PRERELEASEIDENTIFIER', `(?:${src[t.NUMERICIDENTIFIER]
+}|${src[t.NONNUMERICIDENTIFIER]})`)
+
+createToken('PRERELEASEIDENTIFIERLOOSE', `(?:${src[t.NUMERICIDENTIFIERLOOSE]
+}|${src[t.NONNUMERICIDENTIFIER]})`)
+
+// ## Pre-release Version
+// Hyphen, followed by one or more dot-separated pre-release version
+// identifiers.
+
+createToken('PRERELEASE', `(?:-(${src[t.PRERELEASEIDENTIFIER]
+}(?:\\.${src[t.PRERELEASEIDENTIFIER]})*))`)
+
+createToken('PRERELEASELOOSE', `(?:-?(${src[t.PRERELEASEIDENTIFIERLOOSE]
+}(?:\\.${src[t.PRERELEASEIDENTIFIERLOOSE]})*))`)
+
+// ## Build Metadata Identifier
+// Any combination of digits, letters, or hyphens.
+
+createToken('BUILDIDENTIFIER', `${LETTERDASHNUMBER}+`)
+
+// ## Build Metadata
+// Plus sign, followed by one or more period-separated build metadata
+// identifiers.
+
+createToken('BUILD', `(?:\\+(${src[t.BUILDIDENTIFIER]
+}(?:\\.${src[t.BUILDIDENTIFIER]})*))`)
+
+// ## Full Version String
+// A main version, followed optionally by a pre-release version and
+// build metadata.
+
+// Note that the only major, minor, patch, and pre-release sections of
+// the version string are capturing groups.  The build metadata is not a
+// capturing group, because it should not ever be used in version
+// comparison.
+
+createToken('FULLPLAIN', `v?${src[t.MAINVERSION]
+}${src[t.PRERELEASE]}?${
+  src[t.BUILD]}?`)
+
+createToken('FULL', `^${src[t.FULLPLAIN]}$`)
+
+// like full, but allows v1.2.3 and =1.2.3, which people do sometimes.
+// also, 1.0.0alpha1 (prerelease without the hyphen) which is pretty
+// common in the npm registry.
+createToken('LOOSEPLAIN', `[v=\\s]*${src[t.MAINVERSIONLOOSE]
+}${src[t.PRERELEASELOOSE]}?${
+  src[t.BUILD]}?`)
+
+createToken('LOOSE', `^${src[t.LOOSEPLAIN]}$`)
+
+createToken('GTLT', '((?:<|>)?=?)')
+
+// Something like "2.*" or "1.2.x".
+// Note that "x.x" is a valid xRange identifer, meaning "any version"
+// Only the first item is strictly required.
+createToken('XRANGEIDENTIFIERLOOSE', `${src[t.NUMERICIDENTIFIERLOOSE]}|x|X|\\*`)
+createToken('XRANGEIDENTIFIER', `${src[t.NUMERICIDENTIFIER]}|x|X|\\*`)
+
+createToken('XRANGEPLAIN', `[v=\\s]*(${src[t.XRANGEIDENTIFIER]})` +
+                   `(?:\\.(${src[t.XRANGEIDENTIFIER]})` +
+                   `(?:\\.(${src[t.XRANGEIDENTIFIER]})` +
+                   `(?:${src[t.PRERELEASE]})?${
+                     src[t.BUILD]}?` +
+                   `)?)?`)
+
+createToken('XRANGEPLAINLOOSE', `[v=\\s]*(${src[t.XRANGEIDENTIFIERLOOSE]})` +
+                        `(?:\\.(${src[t.XRANGEIDENTIFIERLOOSE]})` +
+                        `(?:\\.(${src[t.XRANGEIDENTIFIERLOOSE]})` +
+                        `(?:${src[t.PRERELEASELOOSE]})?${
+                          src[t.BUILD]}?` +
+                        `)?)?`)
+
+createToken('XRANGE', `^${src[t.GTLT]}\\s*${src[t.XRANGEPLAIN]}$`)
+createToken('XRANGELOOSE', `^${src[t.GTLT]}\\s*${src[t.XRANGEPLAINLOOSE]}$`)
+
+// Coercion.
+// Extract anything that could conceivably be a part of a valid semver
+createToken('COERCE', `${'(^|[^\\d])' +
+              '(\\d{1,'}${MAX_SAFE_COMPONENT_LENGTH}})` +
+              `(?:\\.(\\d{1,${MAX_SAFE_COMPONENT_LENGTH}}))?` +
+              `(?:\\.(\\d{1,${MAX_SAFE_COMPONENT_LENGTH}}))?` +
+              `(?:$|[^\\d])`)
+createToken('COERCERTL', src[t.COERCE], true)
+
+// Tilde ranges.
+// Meaning is "reasonably at or greater than"
+createToken('LONETILDE', '(?:~>?)')
+
+createToken('TILDETRIM', `(\\s*)${src[t.LONETILDE]}\\s+`, true)
+exports.tildeTrimReplace = '$1~'
+
+createToken('TILDE', `^${src[t.LONETILDE]}${src[t.XRANGEPLAIN]}$`)
+createToken('TILDELOOSE', `^${src[t.LONETILDE]}${src[t.XRANGEPLAINLOOSE]}$`)
+
+// Caret ranges.
+// Meaning is "at least and backwards compatible with"
+createToken('LONECARET', '(?:\\^)')
+
+createToken('CARETTRIM', `(\\s*)${src[t.LONECARET]}\\s+`, true)
+exports.caretTrimReplace = '$1^'
+
+createToken('CARET', `^${src[t.LONECARET]}${src[t.XRANGEPLAIN]}$`)
+createToken('CARETLOOSE', `^${src[t.LONECARET]}${src[t.XRANGEPLAINLOOSE]}$`)
+
+// A simple gt/lt/eq thing, or just "" to indicate "any version"
+createToken('COMPARATORLOOSE', `^${src[t.GTLT]}\\s*(${src[t.LOOSEPLAIN]})$|^$`)
+createToken('COMPARATOR', `^${src[t.GTLT]}\\s*(${src[t.FULLPLAIN]})$|^$`)
+
+// An expression to strip any whitespace between the gtlt and the thing
+// it modifies, so that `> 1.2.3` ==> `>1.2.3`
+createToken('COMPARATORTRIM', `(\\s*)${src[t.GTLT]
+}\\s*(${src[t.LOOSEPLAIN]}|${src[t.XRANGEPLAIN]})`, true)
+exports.comparatorTrimReplace = '$1$2$3'
+
+// Something like `1.2.3 - 1.2.4`
+// Note that these all use the loose form, because they'll be
+// checked against either the strict or loose comparator form
+// later.
+createToken('HYPHENRANGE', `^\\s*(${src[t.XRANGEPLAIN]})` +
+                   `\\s+-\\s+` +
+                   `(${src[t.XRANGEPLAIN]})` +
+                   `\\s*$`)
+
+createToken('HYPHENRANGELOOSE', `^\\s*(${src[t.XRANGEPLAINLOOSE]})` +
+                        `\\s+-\\s+` +
+                        `(${src[t.XRANGEPLAINLOOSE]})` +
+                        `\\s*$`)
+
+// Star ranges basically just allow anything at all.
+createToken('STAR', '(<|>)?=?\\s*\\*')
+// >=0.0.0 is like a star
+createToken('GTE0', '^\\s*>=\\s*0\\.0\\.0\\s*$')
+createToken('GTE0PRE', '^\\s*>=\\s*0\\.0\\.0-0\\s*$')
+
+
+/***/ }),
+
+/***/ 97557:
+/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+
+// Determine if version is greater than all the versions possible in the range.
+const outside = __nccwpck_require__(69808)
+const gtr = (version, range, options) => outside(version, range, '>', options)
+module.exports = gtr
+
+
+/***/ }),
+
+/***/ 28658:
+/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+
+const Range = __nccwpck_require__(70434)
+const intersects = (r1, r2, options) => {
+  r1 = new Range(r1, options)
+  r2 = new Range(r2, options)
+  return r1.intersects(r2, options)
 }
-function stringifyNpmLockfile(graph, rootLockFileContent, packageJson) {
-    const rootLockFile = JSON.parse(rootLockFileContent);
-    const { lockfileVersion } = JSON.parse(rootLockFileContent);
-    const mappedPackages = mapSnapshots(rootLockFile, graph);
-    const output = {
-        name: packageJson.name || rootLockFile.name,
-        version: packageJson.version || '0.0.1',
-        lockfileVersion: rootLockFile.lockfileVersion,
-    };
-    if (rootLockFile.requires) {
-        output.requires = rootLockFile.requires;
-    }
-    if (lockfileVersion > 1) {
-        output.packages = mapV3Snapshots(mappedPackages, packageJson);
-    }
-    if (lockfileVersion < 3) {
-        output.dependencies = mapV1Snapshots(mappedPackages);
+module.exports = intersects
+
+
+/***/ }),
+
+/***/ 64666:
+/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+
+const outside = __nccwpck_require__(69808)
+// Determine if version is less than all the versions possible in the range
+const ltr = (version, range, options) => outside(version, range, '<', options)
+module.exports = ltr
+
+
+/***/ }),
+
+/***/ 59530:
+/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+
+const SemVer = __nccwpck_require__(93097)
+const Range = __nccwpck_require__(70434)
+
+const maxSatisfying = (versions, range, options) => {
+  let max = null
+  let maxSV = null
+  let rangeObj = null
+  try {
+    rangeObj = new Range(range, options)
+  } catch (er) {
+    return null
+  }
+  versions.forEach((v) => {
+    if (rangeObj.test(v)) {
+      // satisfies(v, range, options)
+      if (!max || maxSV.compare(v) === -1) {
+        // compare(max, v, true)
+        max = v
+        maxSV = new SemVer(max, options)
+      }
     }
-    return JSON.stringify(output, null, 2);
-}
-exports.stringifyNpmLockfile = stringifyNpmLockfile;
-function mapV3Snapshots(mappedPackages, packageJson) {
-    const output = {};
-    output[''] = packageJson;
-    mappedPackages.forEach((p) => {
-        output[p.path] = p.valueV3;
-    });
-    return output;
-}
-function mapV1Snapshots(mappedPackages) {
-    const output = {};
-    mappedPackages.forEach((p) => {
-        getPackageParent(p.path, output)[p.name] = p.valueV1;
-    });
-    return output;
+  })
+  return max
 }
-function getPackageParent(path, packages) {
-    const segments = path.split(/\/?node_modules\//).slice(1, -1);
-    if (!segments.length) {
-        return packages;
-    }
-    let parent = packages[segments.shift()];
-    if (!parent.dependencies) {
-        parent.dependencies = {};
-    }
-    while (segments.length) {
-        parent = parent.dependencies[segments.shift()];
-        if (!parent.dependencies) {
-            parent.dependencies = {};
-        }
+module.exports = maxSatisfying
+
+
+/***/ }),
+
+/***/ 81539:
+/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+
+const SemVer = __nccwpck_require__(93097)
+const Range = __nccwpck_require__(70434)
+const minSatisfying = (versions, range, options) => {
+  let min = null
+  let minSV = null
+  let rangeObj = null
+  try {
+    rangeObj = new Range(range, options)
+  } catch (er) {
+    return null
+  }
+  versions.forEach((v) => {
+    if (rangeObj.test(v)) {
+      // satisfies(v, range, options)
+      if (!min || minSV.compare(v) === 1) {
+        // compare(min, v, true)
+        min = v
+        minSV = new SemVer(min, options)
+      }
     }
-    return parent.dependencies;
+  })
+  return min
 }
-function mapSnapshots(rootLockFile, graph) {
-    const nestedNodes = new Set();
-    const visitedNodes = new Map();
-    const visitedPaths = new Set();
-    const remappedPackages = new Map();
-    // add first level children
-    Object.values(graph.externalNodes).forEach((node) => {
-        if (node.name === `npm:${node.data.packageName}`) {
-            const mappedPackage = mapPackage(rootLockFile, node.data.packageName, node.data.version);
-            remappedPackages.set(mappedPackage.path, mappedPackage);
-            visitedNodes.set(node, new Set([mappedPackage.path]));
-            visitedPaths.add(mappedPackage.path);
-        }
-        else {
-            nestedNodes.add(node);
-        }
-    });
-    let remappedPackagesArray;
-    if (nestedNodes.size) {
-        const invertedGraph = (0, operators_1.reverse)(graph);
-        nestMappedPackages(invertedGraph, remappedPackages, nestedNodes, visitedNodes, visitedPaths, rootLockFile);
-        // initially we naively map package paths to topParent/../parent/child
-        // but some of those should be nested higher up the tree
-        remappedPackagesArray = elevateNestedPaths(remappedPackages);
-    }
-    else {
-        remappedPackagesArray = Array.from(remappedPackages.values());
+module.exports = minSatisfying
+
+
+/***/ }),
+
+/***/ 56296:
+/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+
+const SemVer = __nccwpck_require__(93097)
+const Range = __nccwpck_require__(70434)
+const gt = __nccwpck_require__(71381)
+
+const minVersion = (range, loose) => {
+  range = new Range(range, loose)
+
+  let minver = new SemVer('0.0.0')
+  if (range.test(minver)) {
+    return minver
+  }
+
+  minver = new SemVer('0.0.0-0')
+  if (range.test(minver)) {
+    return minver
+  }
+
+  minver = null
+  for (let i = 0; i < range.set.length; ++i) {
+    const comparators = range.set[i]
+
+    let setMin = null
+    comparators.forEach((comparator) => {
+      // Clone to avoid manipulating the comparator's semver object.
+      const compver = new SemVer(comparator.semver.version)
+      switch (comparator.operator) {
+        case '>':
+          if (compver.prerelease.length === 0) {
+            compver.patch++
+          } else {
+            compver.prerelease.push(0)
+          }
+          compver.raw = compver.format()
+          /* fallthrough */
+        case '':
+        case '>=':
+          if (!setMin || gt(compver, setMin)) {
+            setMin = compver
+          }
+          break
+        case '<':
+        case '<=':
+          /* Ignore maximum versions */
+          break
+        /* istanbul ignore next */
+        default:
+          throw new Error(`Unexpected operation: ${comparator.operator}`)
+      }
+    })
+    if (setMin && (!minver || gt(minver, setMin))) {
+      minver = setMin
     }
-    return remappedPackagesArray.sort((a, b) => a.path.localeCompare(b.path));
+  }
+
+  if (minver && range.test(minver)) {
+    return minver
+  }
+
+  return null
 }
-function mapPackage(rootLockFile, packageName, version, parentPath = '') {
-    const lockfileVersion = rootLockFile.lockfileVersion;
-    let valueV3, valueV1;
-    if (lockfileVersion < 3) {
-        valueV1 = findMatchingPackageV1(rootLockFile.dependencies, packageName, version);
+module.exports = minVersion
+
+
+/***/ }),
+
+/***/ 69808:
+/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+
+const SemVer = __nccwpck_require__(93097)
+const Comparator = __nccwpck_require__(14658)
+const { ANY } = Comparator
+const Range = __nccwpck_require__(70434)
+const satisfies = __nccwpck_require__(77477)
+const gt = __nccwpck_require__(71381)
+const lt = __nccwpck_require__(75330)
+const lte = __nccwpck_require__(84698)
+const gte = __nccwpck_require__(52498)
+
+const outside = (version, range, hilo, options) => {
+  version = new SemVer(version, options)
+  range = new Range(range, options)
+
+  let gtfn, ltefn, ltfn, comp, ecomp
+  switch (hilo) {
+    case '>':
+      gtfn = gt
+      ltefn = lte
+      ltfn = lt
+      comp = '>'
+      ecomp = '>='
+      break
+    case '<':
+      gtfn = lt
+      ltefn = gte
+      ltfn = gt
+      comp = '<'
+      ecomp = '<='
+      break
+    default:
+      throw new TypeError('Must provide a hilo val of "<" or ">"')
+  }
+
+  // If it satisfies the range it is not outside
+  if (satisfies(version, range, options)) {
+    return false
+  }
+
+  // From now on, variable terms are as if we're in "gtr" mode.
+  // but note that everything is flipped for the "ltr" function.
+
+  for (let i = 0; i < range.set.length; ++i) {
+    const comparators = range.set[i]
+
+    let high = null
+    let low = null
+
+    comparators.forEach((comparator) => {
+      if (comparator.semver === ANY) {
+        comparator = new Comparator('>=0.0.0')
+      }
+      high = high || comparator
+      low = low || comparator
+      if (gtfn(comparator.semver, high.semver, options)) {
+        high = comparator
+      } else if (ltfn(comparator.semver, low.semver, options)) {
+        low = comparator
+      }
+    })
+
+    // If the edge version comparator has a operator then our version
+    // isn't outside it
+    if (high.operator === comp || high.operator === ecomp) {
+      return false
     }
-    if (lockfileVersion > 1) {
-        valueV3 = findMatchingPackageV3(rootLockFile.packages, packageName, version);
+
+    // If the lowest version comparator has an operator and our version
+    // is less than it then it isn't higher than the range
+    if ((!low.operator || low.operator === comp) &&
+        ltefn(version, low.semver)) {
+      return false
+    } else if (low.operator === ecomp && ltfn(version, low.semver)) {
+      return false
     }
-    return {
-        path: parentPath + `node_modules/${packageName}`,
-        name: packageName,
-        valueV1,
-        valueV3,
-    };
+  }
+  return true
 }
-function nestMappedPackages(invertedGraph, result, nestedNodes, visitedNodes, visitedPaths, rootLockFile) {
-    const initialSize = nestedNodes.size;
-    if (!initialSize) {
-        return;
-    }
-    nestedNodes.forEach((node) => {
-        let unresolvedParents = invertedGraph.dependencies[node.name].length;
-        invertedGraph.dependencies[node.name].forEach(({ target }) => {
-            const targetNode = invertedGraph.externalNodes[target];
-            if (visitedNodes.has(targetNode)) {
-                visitedNodes.get(targetNode).forEach((path) => {
-                    const mappedPackage = mapPackage(rootLockFile, node.data.packageName, node.data.version, path + '/');
-                    result.set(mappedPackage.path, mappedPackage);
-                    if (visitedNodes.has(node)) {
-                        visitedNodes.get(node).add(mappedPackage.path);
-                    }
-                    else {
-                        visitedNodes.set(node, new Set([mappedPackage.path]));
-                    }
-                    visitedPaths.add(mappedPackage.path);
-                });
-                unresolvedParents--;
-            }
-        });
-        if (!unresolvedParents) {
-            nestedNodes.delete(node);
-        }
-    });
-    if (initialSize === nestedNodes.size) {
-        throw new Error([
-            'Following packages could not be mapped to the NPM lockfile:',
-            ...Array.from(nestedNodes).map((n) => `- ${n.name}`),
-        ].join('\n'));
+
+module.exports = outside
+
+
+/***/ }),
+
+/***/ 1259:
+/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+
+// given a set of versions and a range, create a "simplified" range
+// that includes the same versions that the original range does
+// If the original range is shorter than the simplified one, return that.
+const satisfies = __nccwpck_require__(77477)
+const compare = __nccwpck_require__(36208)
+module.exports = (versions, range, options) => {
+  const set = []
+  let first = null
+  let prev = null
+  const v = versions.sort((a, b) => compare(a, b, options))
+  for (const version of v) {
+    const included = satisfies(version, range, options)
+    if (included) {
+      prev = version
+      if (!first) {
+        first = version
+      }
+    } else {
+      if (prev) {
+        set.push([first, prev])
+      }
+      prev = null
+      first = null
     }
-    else {
-        nestMappedPackages(invertedGraph, result, nestedNodes, visitedNodes, visitedPaths, rootLockFile);
+  }
+  if (first) {
+    set.push([first, null])
+  }
+
+  const ranges = []
+  for (const [min, max] of set) {
+    if (min === max) {
+      ranges.push(min)
+    } else if (!max && min === v[0]) {
+      ranges.push('*')
+    } else if (!max) {
+      ranges.push(`>=${min}`)
+    } else if (min === v[0]) {
+      ranges.push(`<=${max}`)
+    } else {
+      ranges.push(`${min} - ${max}`)
     }
+  }
+  const simplified = ranges.join(' || ')
+  const original = typeof range.raw === 'string' ? range.raw : String(range)
+  return simplified.length < original.length ? simplified : range
 }
-// sort paths by number of segments and then alphabetically
-function sortMappedPackagesPaths(mappedPackages) {
-    return Array.from(mappedPackages.keys()).sort((a, b) => {
-        const aLength = a.split('/node_modules/').length;
-        const bLength = b.split('/node_modules/').length;
-        if (aLength > bLength) {
-            return 1;
-        }
-        if (aLength < bLength) {
-            return -1;
-        }
-        return a.localeCompare(b);
-    });
-}
-function elevateNestedPaths(remappedPackages) {
-    const result = new Map();
-    const sortedPaths = sortMappedPackagesPaths(remappedPackages);
-    sortedPaths.forEach((path) => {
-        const segments = path.split('/node_modules/');
-        const mappedPackage = remappedPackages.get(path);
-        // we keep hoisted packages intact
-        if (segments.length === 1) {
-            result.set(path, mappedPackage);
-            return;
-        }
-        const packageName = segments.pop();
-        const getNewPath = (segs) => `${segs.join('/node_modules/')}/node_modules/${packageName}`;
-        // check if grandparent has the same package
-        const shouldElevate = (segs) => {
-            var _a, _b, _c, _d;
-            const elevatedPath = getNewPath(segs.slice(0, -1));
-            if (result.has(elevatedPath)) {
-                const match = result.get(elevatedPath);
-                return (((_a = match.valueV1) === null || _a === void 0 ? void 0 : _a.version) === ((_b = mappedPackage.valueV1) === null || _b === void 0 ? void 0 : _b.version) &&
-                    ((_c = match.valueV3) === null || _c === void 0 ? void 0 : _c.version) === ((_d = mappedPackage.valueV3) === null || _d === void 0 ? void 0 : _d.version));
-            }
-            return true;
-        };
-        while (segments.length > 1 && shouldElevate(segments)) {
-            segments.pop();
-        }
-        const newPath = getNewPath(segments);
-        if (path !== newPath) {
-            if (!result.has(newPath)) {
-                mappedPackage.path = newPath;
-                result.set(newPath, mappedPackage);
-            }
-        }
-        else {
-            result.set(path, mappedPackage);
-        }
-    });
-    return Array.from(result.values());
-}
-function findMatchingPackageV3(packages, name, version) {
-    for (let _a of Object.entries(packages)) {
-        const [key, _b] = _a, { dev, peer } = _b, snapshot = tslib_1.__rest(_b, ["dev", "peer"]);
-        if (key.endsWith(`node_modules/${name}`)) {
-            if ([
-                snapshot.version,
-                snapshot.resolved,
-                `npm:${snapshot.name}@${snapshot.version}`,
-            ].includes(version)) {
-                return snapshot;
-            }
-        }
+
+
+/***/ }),
+
+/***/ 95865:
+/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+
+const Range = __nccwpck_require__(70434)
+const Comparator = __nccwpck_require__(14658)
+const { ANY } = Comparator
+const satisfies = __nccwpck_require__(77477)
+const compare = __nccwpck_require__(36208)
+
+// Complex range `r1 || r2 || ...` is a subset of `R1 || R2 || ...` iff:
+// - Every simple range `r1, r2, ...` is a null set, OR
+// - Every simple range `r1, r2, ...` which is not a null set is a subset of
+//   some `R1, R2, ...`
+//
+// Simple range `c1 c2 ...` is a subset of simple range `C1 C2 ...` iff:
+// - If c is only the ANY comparator
+//   - If C is only the ANY comparator, return true
+//   - Else if in prerelease mode, return false
+//   - else replace c with `[>=0.0.0]`
+// - If C is only the ANY comparator
+//   - if in prerelease mode, return true
+//   - else replace C with `[>=0.0.0]`
+// - Let EQ be the set of = comparators in c
+// - If EQ is more than one, return true (null set)
+// - Let GT be the highest > or >= comparator in c
+// - Let LT be the lowest < or <= comparator in c
+// - If GT and LT, and GT.semver > LT.semver, return true (null set)
+// - If any C is a = range, and GT or LT are set, return false
+// - If EQ
+//   - If GT, and EQ does not satisfy GT, return true (null set)
+//   - If LT, and EQ does not satisfy LT, return true (null set)
+//   - If EQ satisfies every C, return true
+//   - Else return false
+// - If GT
+//   - If GT.semver is lower than any > or >= comp in C, return false
+//   - If GT is >=, and GT.semver does not satisfy every C, return false
+//   - If GT.semver has a prerelease, and not in prerelease mode
+//     - If no C has a prerelease and the GT.semver tuple, return false
+// - If LT
+//   - If LT.semver is greater than any < or <= comp in C, return false
+//   - If LT is <=, and LT.semver does not satisfy every C, return false
+//   - If GT.semver has a prerelease, and not in prerelease mode
+//     - If no C has a prerelease and the LT.semver tuple, return false
+// - Else return true
+
+const subset = (sub, dom, options = {}) => {
+  if (sub === dom) {
+    return true
+  }
+
+  sub = new Range(sub, options)
+  dom = new Range(dom, options)
+  let sawNonNull = false
+
+  OUTER: for (const simpleSub of sub.set) {
+    for (const simpleDom of dom.set) {
+      const isSub = simpleSubset(simpleSub, simpleDom, options)
+      sawNonNull = sawNonNull || isSub !== null
+      if (isSub) {
+        continue OUTER
+      }
     }
-}
-function findMatchingPackageV1(packages, name, version) {
-    for (let _a of Object.entries(packages)) {
-        const [packageName, _b] = _a, { dev, peer, dependencies } = _b, snapshot = tslib_1.__rest(_b, ["dev", "peer", "dependencies"]);
-        if (packageName === name) {
-            if (snapshot.version === version) {
-                return snapshot;
-            }
-        }
-        if (dependencies) {
-            const found = findMatchingPackageV1(dependencies, name, version);
-            if (found) {
-                return found;
-            }
-        }
+    // the null set is a subset of everything, but null simple ranges in
+    // a complex range should be ignored.  so if we saw a non-null range,
+    // then we know this isn't a subset, but if EVERY simple range was null,
+    // then it is a subset.
+    if (sawNonNull) {
+      return false
     }
+  }
+  return true
 }
-// NPM V1 does not track the peer dependencies in the lock file
-// so we need to parse them directly from the package.json
-function getPeerDependencies(path) {
-    const fullPath = `${workspace_root_1.workspaceRoot}/${path}/package.json`;
-    if ((0, fs_1.existsSync)(fullPath)) {
-        const content = (0, fs_1.readFileSync)(fullPath, 'utf-8');
-        const { peerDependencies, peerDependenciesMeta } = JSON.parse(content);
-        return Object.assign(Object.assign({}, (peerDependencies && { peerDependencies })), (peerDependenciesMeta && { peerDependenciesMeta }));
+
+const minimumVersionWithPreRelease = [new Comparator('>=0.0.0-0')]
+const minimumVersion = [new Comparator('>=0.0.0')]
+
+const simpleSubset = (sub, dom, options) => {
+  if (sub === dom) {
+    return true
+  }
+
+  if (sub.length === 1 && sub[0].semver === ANY) {
+    if (dom.length === 1 && dom[0].semver === ANY) {
+      return true
+    } else if (options.includePrerelease) {
+      sub = minimumVersionWithPreRelease
+    } else {
+      sub = minimumVersion
     }
-    else {
-        if (process.env.NX_VERBOSE_LOGGING === 'true') {
-            console.warn(`Could not find package.json at "${path}"`);
-        }
-        return {};
+  }
+
+  if (dom.length === 1 && dom[0].semver === ANY) {
+    if (options.includePrerelease) {
+      return true
+    } else {
+      dom = minimumVersion
     }
-}
+  }
 
+  const eqSet = new Set()
+  let gt, lt
+  for (const c of sub) {
+    if (c.operator === '>' || c.operator === '>=') {
+      gt = higherGT(gt, c, options)
+    } else if (c.operator === '<' || c.operator === '<=') {
+      lt = lowerLT(lt, c, options)
+    } else {
+      eqSet.add(c.semver)
+    }
+  }
 
-/***/ }),
+  if (eqSet.size > 1) {
+    return null
+  }
 
-/***/ 93369:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
+  let gtltComp
+  if (gt && lt) {
+    gtltComp = compare(gt.semver, lt.semver, options)
+    if (gtltComp > 0) {
+      return null
+    } else if (gtltComp === 0 && (gt.operator !== '>=' || lt.operator !== '<=')) {
+      return null
+    }
+  }
 
-"use strict";
+  // will iterate one or zero times
+  for (const eq of eqSet) {
+    if (gt && !satisfies(eq, String(gt), options)) {
+      return null
+    }
 
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.stringifyPnpmLockfile = exports.parsePnpmLockfile = void 0;
-const pnpm_normalizer_1 = __nccwpck_require__(83463);
-const package_json_1 = __nccwpck_require__(6500);
-const object_sort_1 = __nccwpck_require__(95961);
-const impl_1 = __nccwpck_require__(43265);
-function parsePnpmLockfile(lockFileContent, builder) {
-    const data = (0, pnpm_normalizer_1.parseAndNormalizePnpmLockfile)(lockFileContent);
-    const isV6 = (0, pnpm_normalizer_1.isV6Lockfile)(data);
-    // we use key => node map to avoid duplicate work when parsing keys
-    const keyMap = new Map();
-    addNodes(data, builder, keyMap, isV6);
-    addDependencies(data, builder, keyMap, isV6);
-}
-exports.parsePnpmLockfile = parsePnpmLockfile;
-function addNodes(data, builder, keyMap, isV6) {
-    const nodes = new Map();
-    Object.entries(data.packages).forEach(([key, snapshot]) => {
-        var _a, _b, _c;
-        const packageName = findPackageName(key, snapshot, data);
-        const rawVersion = findVersion(key, packageName);
-        const version = parseBaseVersion(rawVersion, isV6);
-        // we don't need to keep duplicates, we can just track the keys
-        const existingNode = (_a = nodes.get(packageName)) === null || _a === void 0 ? void 0 : _a.get(version);
-        if (existingNode) {
-            keyMap.set(key, existingNode);
-            return;
-        }
-        const node = {
-            type: 'npm',
-            name: version ? `npm:${packageName}@${version}` : `npm:${packageName}`,
-            data: {
-                version,
-                packageName,
-                hash: ((_b = snapshot.resolution) === null || _b === void 0 ? void 0 : _b['integrity']) ||
-                    (0, impl_1.hashArray)(((_c = snapshot.resolution) === null || _c === void 0 ? void 0 : _c['tarball'])
-                        ? [snapshot.resolution['tarball']]
-                        : [packageName, version]),
-            },
-        };
-        keyMap.set(key, node);
-        if (!nodes.has(packageName)) {
-            nodes.set(packageName, new Map([[version, node]]));
-        }
-        else {
-            nodes.get(packageName).set(version, node);
-        }
-    });
-    const hoistedDeps = (0, pnpm_normalizer_1.loadPnpmHoistedDepsDefinition)();
-    for (const [packageName, versionMap] of nodes.entries()) {
-        let hoistedNode;
-        if (versionMap.size === 1) {
-            hoistedNode = versionMap.values().next().value;
-        }
-        else {
-            const hoistedVersion = getHoistedVersion(hoistedDeps, packageName, isV6);
-            hoistedNode = versionMap.get(hoistedVersion);
-        }
-        if (hoistedNode) {
-            hoistedNode.name = `npm:${packageName}`;
-        }
-        versionMap.forEach((node) => {
-            builder.addExternalNode(node);
-        });
+    if (lt && !satisfies(eq, String(lt), options)) {
+      return null
     }
-}
-function getHoistedVersion(hoistedDependencies, packageName, isV6) {
-    let version = (0, package_json_1.getHoistedPackageVersion)(packageName);
-    if (!version) {
-        const key = Object.keys(hoistedDependencies).find((k) => k.startsWith(`/${packageName}/`));
-        if (key) {
-            version = parseBaseVersion(getVersion(key, packageName), isV6);
-        }
-        else {
-            // pnpm might not hoist every package
-            // similarly those packages will not be available to be used via import
-            return;
-        }
+
+    for (const c of dom) {
+      if (!satisfies(eq, String(c), options)) {
+        return false
+      }
     }
-    return version;
-}
-function addDependencies(data, builder, keyMap, isV6) {
-    Object.entries(data.packages).forEach(([key, snapshot]) => {
-        const node = keyMap.get(key);
-        [snapshot.dependencies, snapshot.optionalDependencies].forEach((section) => {
-            if (section) {
-                Object.entries(section).forEach(([name, versionRange]) => {
-                    const version = parseBaseVersion(findVersion(versionRange, name), isV6);
-                    const target = builder.graph.externalNodes[`npm:${name}@${version}`] ||
-                        builder.graph.externalNodes[`npm:${name}`];
-                    if (target) {
-                        builder.addStaticDependency(node.name, target.name);
-                    }
-                });
-            }
-        });
-    });
-}
-function parseBaseVersion(rawVersion, isV6) {
-    return isV6 ? rawVersion.split('(')[0] : rawVersion.split('_')[0];
-}
-function stringifyPnpmLockfile(graph, rootLockFileContent, packageJson) {
-    const data = (0, pnpm_normalizer_1.parseAndNormalizePnpmLockfile)(rootLockFileContent);
-    const { lockfileVersion, packages } = data;
-    const output = {
-        lockfileVersion,
-        importers: {
-            '.': mapRootSnapshot(packageJson, packages, graph.externalNodes),
-        },
-        packages: (0, object_sort_1.sortObjectByKeys)(mapSnapshots(data.packages, graph.externalNodes)),
-    };
-    return (0, pnpm_normalizer_1.stringifyToPnpmYaml)(output);
-}
-exports.stringifyPnpmLockfile = stringifyPnpmLockfile;
-function mapSnapshots(packages, nodes) {
-    const result = {};
-    Object.values(nodes).forEach((node) => {
-        const matchedKeys = findOriginalKeys(packages, node, {
-            returnFullKey: true,
-        });
-        // the package manager doesn't check for types of dependencies
-        // so we can safely set all to prod
-        matchedKeys.forEach(([key, snapshot]) => {
-            snapshot.dev = false;
-            result[key] = snapshot;
-        });
-    });
-    return result;
-}
-function findOriginalKeys(packages, { data: { packageName, version } }, { returnFullKey } = {}) {
-    const matchedKeys = [];
-    for (const key of Object.keys(packages)) {
-        const snapshot = packages[key];
-        // standard package
-        if (key.startsWith(`/${packageName}/${version}`)) {
-            matchedKeys.push([
-                returnFullKey ? key : getVersion(key, packageName),
-                snapshot,
-            ]);
-        }
-        // tarball package
-        if (key === version) {
-            matchedKeys.push([version, snapshot]);
-        }
-        // alias package
-        if (versionIsAlias(key, version)) {
-            matchedKeys.push([key, snapshot]);
+
+    return true
+  }
+
+  let higher, lower
+  let hasDomLT, hasDomGT
+  // if the subset has a prerelease, we need a comparator in the superset
+  // with the same tuple and a prerelease, or it's not a subset
+  let needDomLTPre = lt &&
+    !options.includePrerelease &&
+    lt.semver.prerelease.length ? lt.semver : false
+  let needDomGTPre = gt &&
+    !options.includePrerelease &&
+    gt.semver.prerelease.length ? gt.semver : false
+  // exception: <1.2.3-0 is the same as <1.2.3
+  if (needDomLTPre && needDomLTPre.prerelease.length === 1 &&
+      lt.operator === '<' && needDomLTPre.prerelease[0] === 0) {
+    needDomLTPre = false
+  }
+
+  for (const c of dom) {
+    hasDomGT = hasDomGT || c.operator === '>' || c.operator === '>='
+    hasDomLT = hasDomLT || c.operator === '<' || c.operator === '<='
+    if (gt) {
+      if (needDomGTPre) {
+        if (c.semver.prerelease && c.semver.prerelease.length &&
+            c.semver.major === needDomGTPre.major &&
+            c.semver.minor === needDomGTPre.minor &&
+            c.semver.patch === needDomGTPre.patch) {
+          needDomGTPre = false
         }
-    }
-    return matchedKeys;
-}
-// check if version has a form of npm:packageName@version and
-// key starts with /packageName/version
-function versionIsAlias(key, versionExpr) {
-    const PREFIX = 'npm:';
-    if (!versionExpr.startsWith(PREFIX))
-        return false;
-    const indexOfVersionSeparator = versionExpr.indexOf('@', PREFIX.length + 1);
-    const packageName = versionExpr.slice(PREFIX.length, indexOfVersionSeparator);
-    const version = versionExpr.slice(indexOfVersionSeparator + 1);
-    return key.startsWith(`/${packageName}/${version}`);
-}
-function mapRootSnapshot(packageJson, packages, nodes) {
-    const snapshot = { specifiers: {} };
-    [
-        'dependencies',
-        'optionalDependencies',
-        'devDependencies',
-        'peerDependencies',
-    ].forEach((depType) => {
-        if (packageJson[depType]) {
-            Object.keys(packageJson[depType]).forEach((packageName) => {
-                const version = packageJson[depType][packageName];
-                const node = nodes[`npm:${packageName}@${version}`] || nodes[`npm:${packageName}`];
-                snapshot.specifiers[packageName] = version;
-                // peer dependencies are mapped to dependencies
-                let section = depType === 'peerDependencies' ? 'dependencies' : depType;
-                snapshot[section] = snapshot[section] || {};
-                snapshot[section][packageName] = findOriginalKeys(packages, node)[0][0];
-            });
+      }
+      if (c.operator === '>' || c.operator === '>=') {
+        higher = higherGT(gt, c, options)
+        if (higher === c && higher !== gt) {
+          return false
         }
-    });
-    Object.keys(snapshot).forEach((key) => {
-        snapshot[key] = (0, object_sort_1.sortObjectByKeys)(snapshot[key]);
-    });
-    return snapshot;
-}
-function findVersion(key, packageName) {
-    if (key.startsWith(`/${packageName}/`)) {
-        return getVersion(key, packageName);
-    }
-    // for alias packages prepend with "npm:"
-    if (key.startsWith('/')) {
-        const aliasName = key.slice(1, key.lastIndexOf('/'));
-        const version = getVersion(key, aliasName);
-        return `npm:${aliasName}@${version}`;
+      } else if (gt.operator === '>=' && !satisfies(gt.semver, String(c), options)) {
+        return false
+      }
     }
-    // for tarball package the entire key is the version spec
-    return key;
-}
-function findPackageName(key, snapshot, data) {
-    const matchPropValue = (record) => {
-        if (!record) {
-            return undefined;
+    if (lt) {
+      if (needDomLTPre) {
+        if (c.semver.prerelease && c.semver.prerelease.length &&
+            c.semver.major === needDomLTPre.major &&
+            c.semver.minor === needDomLTPre.minor &&
+            c.semver.patch === needDomLTPre.patch) {
+          needDomLTPre = false
         }
-        const index = Object.values(record).findIndex((version) => version === key);
-        if (index > -1) {
-            return Object.keys(record)[index];
+      }
+      if (c.operator === '<' || c.operator === '<=') {
+        lower = lowerLT(lt, c, options)
+        if (lower === c && lower !== lt) {
+          return false
         }
-    };
-    const matchedDependencyName = (importer) => {
-        return (matchPropValue(importer.dependencies) ||
-            matchPropValue(importer.optionalDependencies) ||
-            matchPropValue(importer.peerDependencies));
-    };
-    // snapshot already has a name
-    if (snapshot.name) {
-        return snapshot.name;
-    }
-    // it'a a root dependency
-    const rootDependencyName = matchedDependencyName(data.importers['.']) ||
-        // only root importers have devDependencies
-        matchPropValue(data.importers['.'].devDependencies);
-    if (rootDependencyName) {
-        return rootDependencyName;
+      } else if (lt.operator === '<=' && !satisfies(lt.semver, String(c), options)) {
+        return false
+      }
     }
-    // find a snapshot that has a dependency that points to this snapshot
-    const snapshots = Object.values(data.packages);
-    for (let i = 0; i < snapshots.length; i++) {
-        const dependencyName = matchedDependencyName(snapshots[i]);
-        if (dependencyName) {
-            return dependencyName;
-        }
+    if (!c.operator && (lt || gt) && gtltComp !== 0) {
+      return false
     }
-    return extractNameFromKey(key);
+  }
+
+  // if there was a < or >, and nothing in the dom, then must be false
+  // UNLESS it was limited by another range in the other direction.
+  // Eg, >1.0.0 <1.0.1 is still a subset of <2.0.0
+  if (gt && hasDomLT && !lt && gtltComp !== 0) {
+    return false
+  }
+
+  if (lt && hasDomGT && !gt && gtltComp !== 0) {
+    return false
+  }
+
+  // we needed a prerelease range in a specific tuple, but didn't get one
+  // then this isn't a subset.  eg >=1.2.3-pre is not a subset of >=1.0.0,
+  // because it includes prereleases in the 1.2.3 tuple
+  if (needDomGTPre || needDomLTPre) {
+    return false
+  }
+
+  return true
 }
-function getVersion(key, packageName) {
-    const KEY_NAME_SEPARATOR_LENGTH = 2; // leading and trailing slash
-    return key.slice(packageName.length + KEY_NAME_SEPARATOR_LENGTH);
+
+// >=1.2.3 is lower than >1.2.3
+const higherGT = (a, b, options) => {
+  if (!a) {
+    return b
+  }
+  const comp = compare(a.semver, b.semver, options)
+  return comp > 0 ? a
+    : comp < 0 ? b
+    : b.operator === '>' && a.operator === '>=' ? b
+    : a
 }
-function extractNameFromKey(key) {
-    // if package name contains org e.g. "/@babel/runtime/7.12.5"
-    // we want slice until the third slash
-    if (key.startsWith('/@')) {
-        // find the position of the '/' after org name
-        const startFrom = key.indexOf('/', 1);
-        return key.slice(1, key.indexOf('/', startFrom + 1));
-    }
-    if (key.startsWith('/')) {
-        // if package has just a name e.g. "/react/7.12.5..."
-        return key.slice(1, key.indexOf('/', 1));
-    }
-    return key;
+
+// <=1.2.3 is higher than <1.2.3
+const lowerLT = (a, b, options) => {
+  if (!a) {
+    return b
+  }
+  const comp = compare(a.semver, b.semver, options)
+  return comp < 0 ? a
+    : comp > 0 ? b
+    : b.operator === '<' && a.operator === '<=' ? b
+    : a
 }
 
+module.exports = subset
+
 
 /***/ }),
 
-/***/ 38770:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
+/***/ 45827:
+/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
-"use strict";
+const Range = __nccwpck_require__(70434)
 
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.pruneProjectGraph = void 0;
-const semver_1 = __nccwpck_require__(56192);
-const project_graph_builder_1 = __nccwpck_require__(14812);
-const operators_1 = __nccwpck_require__(97607);
-/**
- * Prune project graph's external nodes and their dependencies
- * based on the pruned package.json
- */
-function pruneProjectGraph(graph, prunedPackageJson) {
-    const builder = new project_graph_builder_1.ProjectGraphBuilder();
-    const combinedDependencies = normalizeDependencies(prunedPackageJson, graph);
-    addNodesAndDependencies(graph, combinedDependencies, builder);
-    // for NPM (as well as the graph consistency)
-    // we need to distinguish between hoisted and non-hoisted dependencies
-    rehoistNodes(graph, combinedDependencies, builder);
-    return builder.getUpdatedProjectGraph();
-}
-exports.pruneProjectGraph = pruneProjectGraph;
-// ensure that dependency ranges from package.json (e.g. ^1.0.0)
-// are replaced with the actual version based on the available nodes (e.g. 1.0.1)
-function normalizeDependencies(packageJson, graph) {
-    const { dependencies, devDependencies, optionalDependencies, peerDependencies, } = packageJson;
-    const combinedDependencies = Object.assign(Object.assign(Object.assign(Object.assign({}, dependencies), devDependencies), optionalDependencies), peerDependencies);
-    Object.entries(combinedDependencies).forEach(([packageName, versionRange]) => {
-        if (graph.externalNodes[`npm:${packageName}@${versionRange}`]) {
-            return;
-        }
-        if (graph.externalNodes[`npm:${packageName}`] &&
-            graph.externalNodes[`npm:${packageName}`].data.version === versionRange) {
-            return;
-        }
-        // otherwise we need to find the correct version
-        const node = findNodeMatchingVersion(graph, packageName, versionRange);
-        if (node) {
-            combinedDependencies[packageName] = node.data.version;
-        }
-        else {
-            throw new Error(`Pruned lock file creation failed. The following package was not found in the root lock file: ${packageName}@${versionRange}`);
-        }
-    });
-    return combinedDependencies;
+// Mostly just for testing and legacy API reasons
+const toComparators = (range, options) =>
+  new Range(range, options).set
+    .map(comp => comp.map(c => c.value).join(' ').trim().split(' '))
+
+module.exports = toComparators
+
+
+/***/ }),
+
+/***/ 88902:
+/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+
+const Range = __nccwpck_require__(70434)
+const validRange = (range, options) => {
+  try {
+    // Return '*' instead of '' so that truthiness works.
+    // This will throw if it's invalid anyway
+    return new Range(range, options).range || '*'
+  } catch (er) {
+    return null
+  }
 }
-function findNodeMatchingVersion(graph, packageName, versionExpr) {
-    if (versionExpr === '*') {
-        return graph.externalNodes[`npm:${packageName}`];
-    }
-    const nodes = Object.values(graph.externalNodes)
-        .filter((n) => n.data.packageName === packageName)
-        .sort((a, b) => ((0, semver_1.gte)(b.data.version, a.data.version) ? 1 : -1));
-    if (versionExpr === 'latest') {
-        return nodes.sort((a, b) => +(0, semver_1.gte)(b.data.version, a.data.version))[0];
-    }
-    if (graph.externalNodes[`npm:${packageName}`] &&
-        (0, semver_1.satisfies)(graph.externalNodes[`npm:${packageName}`].data.version, versionExpr)) {
-        return graph.externalNodes[`npm:${packageName}`];
+module.exports = validRange
+
+
+/***/ }),
+
+/***/ 65907:
+/***/ ((module) => {
+
+module.exports = [
+  'cat',
+  'cd',
+  'chmod',
+  'cp',
+  'dirs',
+  'echo',
+  'exec',
+  'find',
+  'grep',
+  'head',
+  'ln',
+  'ls',
+  'mkdir',
+  'mv',
+  'pwd',
+  'rm',
+  'sed',
+  'set',
+  'sort',
+  'tail',
+  'tempdir',
+  'test',
+  'to',
+  'toEnd',
+  'touch',
+  'uniq',
+  'which',
+];
+
+
+/***/ }),
+
+/***/ 26877:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
+
+//
+// ShellJS
+// Unix shell commands on top of Node's API
+//
+// Copyright (c) 2012 Artur Adib
+// http://github.com/shelljs/shelljs
+//
+
+function __ncc_wildcard$0 (arg) {
+  if (arg === "cat.js" || arg === "cat") return __nccwpck_require__(87587);
+  else if (arg === "cd.js" || arg === "cd") return __nccwpck_require__(79117);
+  else if (arg === "chmod.js" || arg === "chmod") return __nccwpck_require__(19879);
+  else if (arg === "common.js" || arg === "common") return __nccwpck_require__(60624);
+  else if (arg === "cp.js" || arg === "cp") return __nccwpck_require__(64395);
+  else if (arg === "dirs.js" || arg === "dirs") return __nccwpck_require__(11060);
+  else if (arg === "echo.js" || arg === "echo") return __nccwpck_require__(60607);
+  else if (arg === "error.js" || arg === "error") return __nccwpck_require__(66829);
+  else if (arg === "exec-child.js" || arg === "exec-child") return __nccwpck_require__(148);
+  else if (arg === "exec.js" || arg === "exec") return __nccwpck_require__(25239);
+  else if (arg === "find.js" || arg === "find") return __nccwpck_require__(52388);
+  else if (arg === "grep.js" || arg === "grep") return __nccwpck_require__(47294);
+  else if (arg === "head.js" || arg === "head") return __nccwpck_require__(24902);
+  else if (arg === "ln.js" || arg === "ln") return __nccwpck_require__(68092);
+  else if (arg === "ls.js" || arg === "ls") return __nccwpck_require__(42248);
+  else if (arg === "mkdir.js" || arg === "mkdir") return __nccwpck_require__(27707);
+  else if (arg === "mv.js" || arg === "mv") return __nccwpck_require__(78146);
+  else if (arg === "popd.js" || arg === "popd") return __nccwpck_require__(12425);
+  else if (arg === "pushd.js" || arg === "pushd") return __nccwpck_require__(68943);
+  else if (arg === "pwd.js" || arg === "pwd") return __nccwpck_require__(90909);
+  else if (arg === "rm.js" || arg === "rm") return __nccwpck_require__(54369);
+  else if (arg === "sed.js" || arg === "sed") return __nccwpck_require__(83401);
+  else if (arg === "set.js" || arg === "set") return __nccwpck_require__(62833);
+  else if (arg === "sort.js" || arg === "sort") return __nccwpck_require__(22675);
+  else if (arg === "tail.js" || arg === "tail") return __nccwpck_require__(61434);
+  else if (arg === "tempdir.js" || arg === "tempdir") return __nccwpck_require__(68691);
+  else if (arg === "test.js" || arg === "test") return __nccwpck_require__(22766);
+  else if (arg === "to.js" || arg === "to") return __nccwpck_require__(83181);
+  else if (arg === "toEnd.js" || arg === "toEnd") return __nccwpck_require__(5836);
+  else if (arg === "touch.js" || arg === "touch") return __nccwpck_require__(19811);
+  else if (arg === "uniq.js" || arg === "uniq") return __nccwpck_require__(29095);
+  else if (arg === "which.js" || arg === "which") return __nccwpck_require__(70858);
+}
+var common = __nccwpck_require__(60624);
+
+//@
+//@ All commands run synchronously, unless otherwise stated.
+//@ All commands accept standard bash globbing characters (`*`, `?`, etc.),
+//@ compatible with the [node `glob` module](https://github.com/isaacs/node-glob).
+//@
+//@ For less-commonly used commands and features, please check out our [wiki
+//@ page](https://github.com/shelljs/shelljs/wiki).
+//@
+
+// Include the docs for all the default commands
+//@commands
+
+// Load all default commands
+(__nccwpck_require__(65907).forEach)(function (command) {
+  __ncc_wildcard$0(command);
+});
+
+//@
+//@ ### exit(code)
+//@
+//@ Exits the current process with the given exit `code`.
+exports.exit = process.exit;
+
+//@include ./src/error
+exports.error = __nccwpck_require__(66829);
+
+//@include ./src/common
+exports.ShellString = common.ShellString;
+
+//@
+//@ ### env['VAR_NAME']
+//@
+//@ Object containing environment variables (both getter and setter). Shortcut
+//@ to `process.env`.
+exports.env = process.env;
+
+//@
+//@ ### Pipes
+//@
+//@ Examples:
+//@
+//@ ```javascript
+//@ grep('foo', 'file1.txt', 'file2.txt').sed(/o/g, 'a').to('output.txt');
+//@ echo('files with o\'s in the name:\n' + ls().grep('o'));
+//@ cat('test.js').exec('node'); // pipe to exec() call
+//@ ```
+//@
+//@ Commands can send their output to another command in a pipe-like fashion.
+//@ `sed`, `grep`, `cat`, `exec`, `to`, and `toEnd` can appear on the right-hand
+//@ side of a pipe. Pipes can be chained.
+
+//@
+//@ ## Configuration
+//@
+
+exports.config = common.config;
+
+//@
+//@ ### config.silent
+//@
+//@ Example:
+//@
+//@ ```javascript
+//@ var sh = require('shelljs');
+//@ var silentState = sh.config.silent; // save old silent state
+//@ sh.config.silent = true;
+//@ /* ... */
+//@ sh.config.silent = silentState; // restore old silent state
+//@ ```
+//@
+//@ Suppresses all command output if `true`, except for `echo()` calls.
+//@ Default is `false`.
+
+//@
+//@ ### config.fatal
+//@
+//@ Example:
+//@
+//@ ```javascript
+//@ require('shelljs/global');
+//@ config.fatal = true; // or set('-e');
+//@ cp('this_file_does_not_exist', '/dev/null'); // throws Error here
+//@ /* more commands... */
+//@ ```
+//@
+//@ If `true`, the script will throw a Javascript error when any shell.js
+//@ command encounters an error. Default is `false`. This is analogous to
+//@ Bash's `set -e`.
+
+//@
+//@ ### config.verbose
+//@
+//@ Example:
+//@
+//@ ```javascript
+//@ config.verbose = true; // or set('-v');
+//@ cd('dir/');
+//@ rm('-rf', 'foo.txt', 'bar.txt');
+//@ exec('echo hello');
+//@ ```
+//@
+//@ Will print each command as follows:
+//@
+//@ ```
+//@ cd dir/
+//@ rm -rf foo.txt bar.txt
+//@ exec echo hello
+//@ ```
+
+//@
+//@ ### config.globOptions
+//@
+//@ Example:
+//@
+//@ ```javascript
+//@ config.globOptions = {nodir: true};
+//@ ```
+//@
+//@ Use this value for calls to `glob.sync()` instead of the default options.
+
+//@
+//@ ### config.reset()
+//@
+//@ Example:
+//@
+//@ ```javascript
+//@ var shell = require('shelljs');
+//@ // Make changes to shell.config, and do stuff...
+//@ /* ... */
+//@ shell.config.reset(); // reset to original state
+//@ // Do more stuff, but with original settings
+//@ /* ... */
+//@ ```
+//@
+//@ Reset `shell.config` to the defaults:
+//@
+//@ ```javascript
+//@ {
+//@   fatal: false,
+//@   globOptions: {},
+//@   maxdepth: 255,
+//@   noglob: false,
+//@   silent: false,
+//@   verbose: false,
+//@ }
+//@ ```
+
+
+/***/ }),
+
+/***/ 87587:
+/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+
+var common = __nccwpck_require__(60624);
+var fs = __nccwpck_require__(57147);
+
+common.register('cat', _cat, {
+  canReceivePipe: true,
+  cmdOptions: {
+    'n': 'number',
+  },
+});
+
+//@
+//@ ### cat([options,] file [, file ...])
+//@ ### cat([options,] file_array)
+//@
+//@ Available options:
+//@
+//@ + `-n`: number all output lines
+//@
+//@ Examples:
+//@
+//@ ```javascript
+//@ var str = cat('file*.txt');
+//@ var str = cat('file1', 'file2');
+//@ var str = cat(['file1', 'file2']); // same as above
+//@ ```
+//@
+//@ Returns a string containing the given file, or a concatenated string
+//@ containing the files if more than one file is given (a new line character is
+//@ introduced between each file).
+function _cat(options, files) {
+  var cat = common.readFromPipe();
+
+  if (!files && !cat) common.error('no paths given');
+
+  files = [].slice.call(arguments, 1);
+
+  files.forEach(function (file) {
+    if (!fs.existsSync(file)) {
+      common.error('no such file or directory: ' + file);
+    } else if (common.statFollowLinks(file).isDirectory()) {
+      common.error(file + ': Is a directory');
     }
-    return nodes.find((n) => (0, semver_1.satisfies)(n.data.version, versionExpr));
+
+    cat += fs.readFileSync(file, 'utf8');
+  });
+
+  if (options.number) {
+    cat = addNumbers(cat);
+  }
+
+  return cat;
 }
-function addNodesAndDependencies(graph, packageJsonDeps, builder) {
-    Object.entries(packageJsonDeps).forEach(([name, version]) => {
-        const node = graph.externalNodes[`npm:${name}@${version}`] ||
-            graph.externalNodes[`npm:${name}`];
-        traverseNode(graph, builder, node);
-    });
+module.exports = _cat;
+
+function addNumbers(cat) {
+  var lines = cat.split('\n');
+  var lastLine = lines.pop();
+
+  lines = lines.map(function (line, i) {
+    return numberedLine(i + 1, line);
+  });
+
+  if (lastLine.length) {
+    lastLine = numberedLine(lines.length + 1, lastLine);
+  }
+  lines.push(lastLine);
+
+  return lines.join('\n');
 }
-function traverseNode(graph, builder, node) {
-    var _a;
-    if (builder.graph.externalNodes[node.name]) {
-        return;
+
+function numberedLine(n, line) {
+  // GNU cat use six pad start number + tab. See http://lingrok.org/xref/coreutils/src/cat.c#57
+  // https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/padStart
+  var number = ('     ' + n).slice(-6) + '\t';
+  return number + line;
+}
+
+
+/***/ }),
+
+/***/ 79117:
+/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+
+var os = __nccwpck_require__(22037);
+var common = __nccwpck_require__(60624);
+
+common.register('cd', _cd, {});
+
+//@
+//@ ### cd([dir])
+//@
+//@ Changes to directory `dir` for the duration of the script. Changes to home
+//@ directory if no argument is supplied.
+function _cd(options, dir) {
+  if (!dir) dir = os.homedir();
+
+  if (dir === '-') {
+    if (!process.env.OLDPWD) {
+      common.error('could not find previous directory');
+    } else {
+      dir = process.env.OLDPWD;
     }
-    builder.addExternalNode(node);
-    (_a = graph.dependencies[node.name]) === null || _a === void 0 ? void 0 : _a.forEach((dep) => {
-        const depNode = graph.externalNodes[dep.target];
-        traverseNode(graph, builder, depNode);
-        builder.addStaticDependency(node.name, dep.target);
-    });
+  }
+
+  try {
+    var curDir = process.cwd();
+    process.chdir(dir);
+    process.env.OLDPWD = curDir;
+  } catch (e) {
+    // something went wrong, let's figure out the error
+    var err;
+    try {
+      common.statFollowLinks(dir); // if this succeeds, it must be some sort of file
+      err = 'not a directory: ' + dir;
+    } catch (e2) {
+      err = 'no such file or directory: ' + dir;
+    }
+    if (err) common.error(err);
+  }
+  return '';
 }
-function rehoistNodes(graph, packageJsonDeps, builder) {
-    const packagesToRehoist = new Map();
-    // find all packages that need to be rehoisted
-    Object.values(graph.externalNodes).forEach((node) => {
-        if (node.name === `npm:${node.data.packageName}` &&
-            !builder.graph.externalNodes[node.name]) {
-            const nestedNodes = Object.values(builder.graph.externalNodes).filter((n) => n.data.packageName === node.data.packageName);
-            if (nestedNodes.length > 0) {
-                packagesToRehoist.set(node.data.packageName, nestedNodes);
-            }
-        }
-    });
-    // invert dependencies for easier traversal back
-    const invertedGraph = (0, operators_1.reverse)(builder.graph);
-    const invBuilder = new project_graph_builder_1.ProjectGraphBuilder(invertedGraph, {});
-    // find new hoisted version
-    packagesToRehoist.forEach((nestedNodes) => {
-        if (nestedNodes.length === 1) {
-            switchNodeToHoisted(nestedNodes[0], builder, invBuilder);
-        }
-        else {
-            let minDistance = Infinity;
-            let closest;
-            nestedNodes.forEach((node) => {
-                const distance = pathLengthToIncoming(node, packageJsonDeps, builder, invertedGraph);
-                if (distance < minDistance) {
-                    minDistance = distance;
-                    closest = node;
-                }
-            });
-            switchNodeToHoisted(closest, builder, invBuilder);
+module.exports = _cd;
+
+
+/***/ }),
+
+/***/ 19879:
+/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+
+var common = __nccwpck_require__(60624);
+var fs = __nccwpck_require__(57147);
+var path = __nccwpck_require__(71017);
+
+var PERMS = (function (base) {
+  return {
+    OTHER_EXEC: base.EXEC,
+    OTHER_WRITE: base.WRITE,
+    OTHER_READ: base.READ,
+
+    GROUP_EXEC: base.EXEC << 3,
+    GROUP_WRITE: base.WRITE << 3,
+    GROUP_READ: base.READ << 3,
+
+    OWNER_EXEC: base.EXEC << 6,
+    OWNER_WRITE: base.WRITE << 6,
+    OWNER_READ: base.READ << 6,
+
+    // Literal octal numbers are apparently not allowed in "strict" javascript.
+    STICKY: parseInt('01000', 8),
+    SETGID: parseInt('02000', 8),
+    SETUID: parseInt('04000', 8),
+
+    TYPE_MASK: parseInt('0770000', 8),
+  };
+}({
+  EXEC: 1,
+  WRITE: 2,
+  READ: 4,
+}));
+
+common.register('chmod', _chmod, {
+});
+
+//@
+//@ ### chmod([options,] octal_mode || octal_string, file)
+//@ ### chmod([options,] symbolic_mode, file)
+//@
+//@ Available options:
+//@
+//@ + `-v`: output a diagnostic for every file processed//@
+//@ + `-c`: like verbose, but report only when a change is made//@
+//@ + `-R`: change files and directories recursively//@
+//@
+//@ Examples:
+//@
+//@ ```javascript
+//@ chmod(755, '/Users/brandon');
+//@ chmod('755', '/Users/brandon'); // same as above
+//@ chmod('u+x', '/Users/brandon');
+//@ chmod('-R', 'a-w', '/Users/brandon');
+//@ ```
+//@
+//@ Alters the permissions of a file or directory by either specifying the
+//@ absolute permissions in octal form or expressing the changes in symbols.
+//@ This command tries to mimic the POSIX behavior as much as possible.
+//@ Notable exceptions:
+//@
+//@ + In symbolic modes, `a-r` and `-r` are identical.  No consideration is
+//@   given to the `umask`.
+//@ + There is no "quiet" option, since default behavior is to run silent.
+function _chmod(options, mode, filePattern) {
+  if (!filePattern) {
+    if (options.length > 0 && options.charAt(0) === '-') {
+      // Special case where the specified file permissions started with - to subtract perms, which
+      // get picked up by the option parser as command flags.
+      // If we are down by one argument and options starts with -, shift everything over.
+      [].unshift.call(arguments, '');
+    } else {
+      common.error('You must specify a file.');
+    }
+  }
+
+  options = common.parseOptions(options, {
+    'R': 'recursive',
+    'c': 'changes',
+    'v': 'verbose',
+  });
+
+  filePattern = [].slice.call(arguments, 2);
+
+  var files;
+
+  // TODO: replace this with a call to common.expand()
+  if (options.recursive) {
+    files = [];
+    filePattern.forEach(function addFile(expandedFile) {
+      var stat = common.statNoFollowLinks(expandedFile);
+
+      if (!stat.isSymbolicLink()) {
+        files.push(expandedFile);
+
+        if (stat.isDirectory()) {  // intentionally does not follow symlinks.
+          fs.readdirSync(expandedFile).forEach(function (child) {
+            addFile(expandedFile + '/' + child);
+          });
         }
+      }
     });
-}
-function switchNodeToHoisted(node, builder, invBuilder) {
-    // make a copy of current name, all the dependencies and dependents
-    const previousName = node.name;
-    const targets = (builder.graph.dependencies[node.name] || []).map((d) => d.target);
-    const sources = Object.keys(builder.graph.dependencies).filter((name) => builder.graph.dependencies[name].some((d) => d.target === previousName));
-    builder.removeNode(node.name);
-    invBuilder.removeNode(node.name);
-    // modify the node and re-add it
-    node.name = `npm:${node.data.packageName}`;
-    builder.addExternalNode(node);
-    invBuilder.addExternalNode(node);
-    targets.forEach((target) => {
-        builder.addStaticDependency(node.name, target);
-        invBuilder.addStaticDependency(target, node.name);
-    });
-    sources.forEach((source) => {
-        builder.addStaticDependency(source, node.name);
-        invBuilder.addStaticDependency(node.name, source);
-    });
-}
-// BFS to find the shortest path to a dependency specified in package.json
-// package version with the shortest path is the one that should be hoisted
-function pathLengthToIncoming(node, packageJsonDeps, builder, invertedGraph) {
-    const visited = new Set([node.name]);
-    const queue = [[node, 0]];
-    while (queue.length > 0) {
-        const [current, distance] = queue.shift();
-        if (packageJsonDeps[current.data.packageName] === current.data.version) {
-            return distance;
-        }
-        for (let { target } of invertedGraph.dependencies[current.name] || []) {
-            if (!visited.has(target)) {
-                visited.add(target);
-                queue.push([builder.graph.externalNodes[target], distance + 1]);
+  } else {
+    files = filePattern;
+  }
+
+  files.forEach(function innerChmod(file) {
+    file = path.resolve(file);
+    if (!fs.existsSync(file)) {
+      common.error('File not found: ' + file);
+    }
+
+    // When recursing, don't follow symlinks.
+    if (options.recursive && common.statNoFollowLinks(file).isSymbolicLink()) {
+      return;
+    }
+
+    var stat = common.statFollowLinks(file);
+    var isDir = stat.isDirectory();
+    var perms = stat.mode;
+    var type = perms & PERMS.TYPE_MASK;
+
+    var newPerms = perms;
+
+    if (isNaN(parseInt(mode, 8))) {
+      // parse options
+      mode.split(',').forEach(function (symbolicMode) {
+        var pattern = /([ugoa]*)([=\+-])([rwxXst]*)/i;
+        var matches = pattern.exec(symbolicMode);
+
+        if (matches) {
+          var applyTo = matches[1];
+          var operator = matches[2];
+          var change = matches[3];
+
+          var changeOwner = applyTo.indexOf('u') !== -1 || applyTo === 'a' || applyTo === '';
+          var changeGroup = applyTo.indexOf('g') !== -1 || applyTo === 'a' || applyTo === '';
+          var changeOther = applyTo.indexOf('o') !== -1 || applyTo === 'a' || applyTo === '';
+
+          var changeRead = change.indexOf('r') !== -1;
+          var changeWrite = change.indexOf('w') !== -1;
+          var changeExec = change.indexOf('x') !== -1;
+          var changeExecDir = change.indexOf('X') !== -1;
+          var changeSticky = change.indexOf('t') !== -1;
+          var changeSetuid = change.indexOf('s') !== -1;
+
+          if (changeExecDir && isDir) {
+            changeExec = true;
+          }
+
+          var mask = 0;
+          if (changeOwner) {
+            mask |= (changeRead ? PERMS.OWNER_READ : 0) + (changeWrite ? PERMS.OWNER_WRITE : 0) + (changeExec ? PERMS.OWNER_EXEC : 0) + (changeSetuid ? PERMS.SETUID : 0);
+          }
+          if (changeGroup) {
+            mask |= (changeRead ? PERMS.GROUP_READ : 0) + (changeWrite ? PERMS.GROUP_WRITE : 0) + (changeExec ? PERMS.GROUP_EXEC : 0) + (changeSetuid ? PERMS.SETGID : 0);
+          }
+          if (changeOther) {
+            mask |= (changeRead ? PERMS.OTHER_READ : 0) + (changeWrite ? PERMS.OTHER_WRITE : 0) + (changeExec ? PERMS.OTHER_EXEC : 0);
+          }
+
+          // Sticky bit is special - it's not tied to user, group or other.
+          if (changeSticky) {
+            mask |= PERMS.STICKY;
+          }
+
+          switch (operator) {
+            case '+':
+              newPerms |= mask;
+              break;
+
+            case '-':
+              newPerms &= ~mask;
+              break;
+
+            case '=':
+              newPerms = type + mask;
+
+              // According to POSIX, when using = to explicitly set the
+              // permissions, setuid and setgid can never be cleared.
+              if (common.statFollowLinks(file).isDirectory()) {
+                newPerms |= (PERMS.SETUID + PERMS.SETGID) & perms;
+              }
+              break;
+            default:
+              common.error('Could not recognize operator: `' + operator + '`');
+          }
+
+          if (options.verbose) {
+            console.log(file + ' -> ' + newPerms.toString(8));
+          }
+
+          if (perms !== newPerms) {
+            if (!options.verbose && options.changes) {
+              console.log(file + ' -> ' + newPerms.toString(8));
             }
+            fs.chmodSync(file, newPerms);
+            perms = newPerms; // for the next round of changes!
+          }
+        } else {
+          common.error('Invalid symbolic mode change: ' + symbolicMode);
         }
+      });
+    } else {
+      // they gave us a full number
+      newPerms = type + parseInt(mode, 8);
+
+      // POSIX rules are that setuid and setgid can only be added using numeric
+      // form, but not cleared.
+      if (common.statFollowLinks(file).isDirectory()) {
+        newPerms |= (PERMS.SETUID + PERMS.SETGID) & perms;
+      }
+
+      fs.chmodSync(file, newPerms);
     }
+  });
+  return '';
 }
+module.exports = _chmod;
 
 
 /***/ }),
 
-/***/ 6500:
+/***/ 60624:
 /***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
 "use strict";
+// Ignore warning about 'new String()'
+/* eslint no-new-wrappers: 0 */
 
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.normalizePackageJson = exports.getHoistedPackageVersion = void 0;
-const fs_1 = __nccwpck_require__(57147);
-const workspace_root_1 = __nccwpck_require__(65766);
-/**
- * Get version of hoisted package if available
- */
-function getHoistedPackageVersion(packageName) {
-    var _a;
-    const fullPath = `${workspace_root_1.workspaceRoot}/node_modules/${packageName}/package.json`;
-    if ((0, fs_1.existsSync)(fullPath)) {
-        const content = (0, fs_1.readFileSync)(fullPath, 'utf-8');
-        return (_a = JSON.parse(content)) === null || _a === void 0 ? void 0 : _a.version;
+
+var os = __nccwpck_require__(22037);
+var fs = __nccwpck_require__(57147);
+var glob = __nccwpck_require__(69959);
+var shell = __nccwpck_require__(26877);
+
+var shellMethods = Object.create(shell);
+
+exports.extend = Object.assign;
+
+// Check if we're running under electron
+var isElectron = Boolean(process.versions.electron);
+
+// Module globals (assume no execPath by default)
+var DEFAULT_CONFIG = {
+  fatal: false,
+  globOptions: {},
+  maxdepth: 255,
+  noglob: false,
+  silent: false,
+  verbose: false,
+  execPath: null,
+  bufLength: 64 * 1024, // 64KB
+};
+
+var config = {
+  reset: function () {
+    Object.assign(this, DEFAULT_CONFIG);
+    if (!isElectron) {
+      this.execPath = process.execPath;
     }
-    return;
+  },
+  resetForTesting: function () {
+    this.reset();
+    this.silent = true;
+  },
+};
+
+config.reset();
+exports.config = config;
+
+// Note: commands should generally consider these as read-only values.
+var state = {
+  error: null,
+  errorCode: 0,
+  currentCmd: 'shell.js',
+};
+exports.state = state;
+
+delete process.env.OLDPWD; // initially, there's no previous directory
+
+// Reliably test if something is any sort of javascript object
+function isObject(a) {
+  return typeof a === 'object' && a !== null;
 }
-exports.getHoistedPackageVersion = getHoistedPackageVersion;
-/**
- * Strip off non-pruning related fields from package.json
- */
-function normalizePackageJson(packageJson) {
-    const { name, version, license, dependencies, devDependencies, peerDependencies, peerDependenciesMeta, optionalDependencies, } = packageJson;
-    return {
-        name,
-        version,
-        license,
-        dependencies,
-        devDependencies,
-        peerDependencies,
-        peerDependenciesMeta,
-        optionalDependencies,
-    };
+exports.isObject = isObject;
+
+function log() {
+  /* istanbul ignore next */
+  if (!config.silent) {
+    console.error.apply(console, arguments);
+  }
 }
-exports.normalizePackageJson = normalizePackageJson;
+exports.log = log;
+
+// Converts strings to be equivalent across all platforms. Primarily responsible
+// for making sure we use '/' instead of '\' as path separators, but this may be
+// expanded in the future if necessary
+function convertErrorOutput(msg) {
+  if (typeof msg !== 'string') {
+    throw new TypeError('input must be a string');
+  }
+  return msg.replace(/\\/g, '/');
+}
+exports.convertErrorOutput = convertErrorOutput;
 
+// Shows error message. Throws if config.fatal is true
+function error(msg, _code, options) {
+  // Validate input
+  if (typeof msg !== 'string') throw new Error('msg must be a string');
 
-/***/ }),
+  var DEFAULT_OPTIONS = {
+    continue: false,
+    code: 1,
+    prefix: state.currentCmd + ': ',
+    silent: false,
+  };
 
-/***/ 83463:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
+  if (typeof _code === 'number' && isObject(options)) {
+    options.code = _code;
+  } else if (isObject(_code)) { // no 'code'
+    options = _code;
+  } else if (typeof _code === 'number') { // no 'options'
+    options = { code: _code };
+  } else if (typeof _code !== 'number') { // only 'msg'
+    options = {};
+  }
+  options = Object.assign({}, DEFAULT_OPTIONS, options);
 
-"use strict";
+  if (!state.errorCode) state.errorCode = options.code;
 
-/**
- * This file contains the logic to convert pnpm lockfile to a standard format.
- * It will convert inline specifiers to the separate specifiers format and ensure importers are present.
- */
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.stringifyToPnpmYaml = exports.parseAndNormalizePnpmLockfile = exports.loadPnpmHoistedDepsDefinition = exports.isV6Lockfile = void 0;
-const tslib_1 = __nccwpck_require__(51796);
-const js_yaml_1 = __nccwpck_require__(89777);
-const fs_1 = __nccwpck_require__(57147);
-const workspace_root_1 = __nccwpck_require__(65766);
-const semver_1 = __nccwpck_require__(56192);
-function isV6Lockfile(data) {
-    return data.lockfileVersion.toString().startsWith('6.');
+  var logEntry = convertErrorOutput(options.prefix + msg);
+  state.error = state.error ? state.error + '\n' : '';
+  state.error += logEntry;
+
+  // Throw an error, or log the entry
+  if (config.fatal) throw new Error(logEntry);
+  if (msg.length > 0 && !options.silent) log(logEntry);
+
+  if (!options.continue) {
+    throw {
+      msg: 'earlyExit',
+      retValue: (new ShellString('', state.error, state.errorCode)),
+    };
+  }
 }
-exports.isV6Lockfile = isV6Lockfile;
-function loadPnpmHoistedDepsDefinition() {
-    var _a, _b;
-    const fullPath = `${workspace_root_1.workspaceRoot}/node_modules/.modules.yaml`;
-    if ((0, fs_1.existsSync)(fullPath)) {
-        const content = (0, fs_1.readFileSync)(fullPath, 'utf-8');
-        return (_b = (_a = (0, js_yaml_1.load)(content)) === null || _a === void 0 ? void 0 : _a.hoistedDependencies) !== null && _b !== void 0 ? _b : {};
+exports.error = error;
+
+//@
+//@ ### ShellString(str)
+//@
+//@ Examples:
+//@
+//@ ```javascript
+//@ var foo = ShellString('hello world');
+//@ ```
+//@
+//@ Turns a regular string into a string-like object similar to what each
+//@ command returns. This has special methods, like `.to()` and `.toEnd()`.
+function ShellString(stdout, stderr, code) {
+  var that;
+  if (stdout instanceof Array) {
+    that = stdout;
+    that.stdout = stdout.join('\n');
+    if (stdout.length > 0) that.stdout += '\n';
+  } else {
+    that = new String(stdout);
+    that.stdout = stdout;
+  }
+  that.stderr = stderr;
+  that.code = code;
+  // A list of all commands that can appear on the right-hand side of a pipe
+  // (populated by calls to common.wrap())
+  pipeMethods.forEach(function (cmd) {
+    that[cmd] = shellMethods[cmd].bind(that);
+  });
+  return that;
+}
+
+exports.ShellString = ShellString;
+
+// Returns {'alice': true, 'bob': false} when passed a string and dictionary as follows:
+//   parseOptions('-a', {'a':'alice', 'b':'bob'});
+// Returns {'reference': 'string-value', 'bob': false} when passed two dictionaries of the form:
+//   parseOptions({'-r': 'string-value'}, {'r':'reference', 'b':'bob'});
+// Throws an error when passed a string that does not start with '-':
+//   parseOptions('a', {'a':'alice'}); // throws
+function parseOptions(opt, map, errorOptions) {
+  // Validate input
+  if (typeof opt !== 'string' && !isObject(opt)) {
+    throw new Error('options must be strings or key-value pairs');
+  } else if (!isObject(map)) {
+    throw new Error('parseOptions() internal error: map must be an object');
+  } else if (errorOptions && !isObject(errorOptions)) {
+    throw new Error('parseOptions() internal error: errorOptions must be object');
+  }
+
+  if (opt === '--') {
+    // This means there are no options.
+    return {};
+  }
+
+  // All options are false by default
+  var options = {};
+  Object.keys(map).forEach(function (letter) {
+    var optName = map[letter];
+    if (optName[0] !== '!') {
+      options[optName] = false;
     }
-    else {
-        throw new Error(`Could not find ".modules.yaml" at "${fullPath}"`);
+  });
+
+  if (opt === '') return options; // defaults
+
+  if (typeof opt === 'string') {
+    if (opt[0] !== '-') {
+      throw new Error("Options string must start with a '-'");
     }
+
+    // e.g. chars = ['R', 'f']
+    var chars = opt.slice(1).split('');
+
+    chars.forEach(function (c) {
+      if (c in map) {
+        var optionName = map[c];
+        if (optionName[0] === '!') {
+          options[optionName.slice(1)] = false;
+        } else {
+          options[optionName] = true;
+        }
+      } else {
+        error('option not recognized: ' + c, errorOptions || {});
+      }
+    });
+  } else { // opt is an Object
+    Object.keys(opt).forEach(function (key) {
+      // key is a string of the form '-r', '-d', etc.
+      var c = key[1];
+      if (c in map) {
+        var optionName = map[c];
+        options[optionName] = opt[key]; // assign the given value
+      } else {
+        error('option not recognized: ' + c, errorOptions || {});
+      }
+    });
+  }
+  return options;
 }
-exports.loadPnpmHoistedDepsDefinition = loadPnpmHoistedDepsDefinition;
-/*************************************************************************
- * THE FOLLOWING CODE IS COPIED & simplified FROM @pnpm/lockfile-file for convenience
- *************************************************************************/
-/**
- * Parsing and mapping logic from pnpm lockfile `read` function
- * https://github.com/pnpm/pnpm/blob/af3e5559d377870d4c3d303429b3ed1a4e64fedc/lockfile/lockfile-file/src/read.ts#L91
- */
-function parseAndNormalizePnpmLockfile(content) {
-    const lockFileData = (0, js_yaml_1.load)(content);
-    return revertFromInlineSpecifiersFormatIfNecessary(convertFromLockfileFileMutable(lockFileData));
+exports.parseOptions = parseOptions;
+
+// Expands wildcards with matching (ie. existing) file names.
+// For example:
+//   expand(['file*.js']) = ['file1.js', 'file2.js', ...]
+//   (if the files 'file1.js', 'file2.js', etc, exist in the current dir)
+function expand(list) {
+  if (!Array.isArray(list)) {
+    throw new TypeError('must be an array');
+  }
+  var expanded = [];
+  list.forEach(function (listEl) {
+    // Don't expand non-strings
+    if (typeof listEl !== 'string') {
+      expanded.push(listEl);
+    } else {
+      var ret;
+      try {
+        ret = glob.sync(listEl, config.globOptions);
+        // if nothing matched, interpret the string literally
+        ret = ret.length > 0 ? ret : [listEl];
+      } catch (e) {
+        // if glob fails, interpret the string literally
+        ret = [listEl];
+      }
+      expanded = expanded.concat(ret);
+    }
+  });
+  return expanded;
 }
-exports.parseAndNormalizePnpmLockfile = parseAndNormalizePnpmLockfile;
-/**
- * Reverts changes from the "forceSharedFormat" write option if necessary.
- * https://github.com/pnpm/pnpm/blob/af3e5559d377870d4c3d303429b3ed1a4e64fedc/lockfile/lockfile-file/src/read.ts#L234
- */
-function convertFromLockfileFileMutable(lockfileFile) {
-    var _a;
-    if (typeof (lockfileFile === null || lockfileFile === void 0 ? void 0 : lockfileFile['importers']) === 'undefined') {
-        lockfileFile.importers = {
-            '.': {
-                specifiers: (_a = lockfileFile['specifiers']) !== null && _a !== void 0 ? _a : {},
-                dependenciesMeta: lockfileFile['dependenciesMeta'],
-                publishDirectory: lockfileFile['publishDirectory'],
-            },
-        };
-        delete lockfileFile.specifiers;
-        for (const depType of DEPENDENCIES_FIELDS) {
-            if (lockfileFile[depType] != null) {
-                lockfileFile.importers['.'][depType] = lockfileFile[depType];
-                delete lockfileFile[depType];
-            }
-        }
+exports.expand = expand;
+
+// Normalizes Buffer creation, using Buffer.alloc if possible.
+// Also provides a good default buffer length for most use cases.
+var buffer = typeof Buffer.alloc === 'function' ?
+  function (len) {
+    return Buffer.alloc(len || config.bufLength);
+  } :
+  function (len) {
+    return new Buffer(len || config.bufLength);
+  };
+exports.buffer = buffer;
+
+// Normalizes _unlinkSync() across platforms to match Unix behavior, i.e.
+// file can be unlinked even if it's read-only, see https://github.com/joyent/node/issues/3006
+function unlinkSync(file) {
+  try {
+    fs.unlinkSync(file);
+  } catch (e) {
+    // Try to override file permission
+    /* istanbul ignore next */
+    if (e.code === 'EPERM') {
+      fs.chmodSync(file, '0666');
+      fs.unlinkSync(file);
+    } else {
+      throw e;
     }
-    return lockfileFile;
+  }
 }
-// https://github.com/pnpm/pnpm/blob/af3e5559d377870d4c3d303429b3ed1a4e64fedc/lockfile/lockfile-file/src/write.ts#L27
-const LOCKFILE_YAML_FORMAT = {
-    blankLines: true,
-    lineWidth: 1000,
-    noCompatMode: true,
-    noRefs: true,
-    sortKeys: false,
-};
-/**
- * Mapping and writing logic from pnpm lockfile `write` function
- * https://github.com/pnpm/pnpm/blob/af3e5559d377870d4c3d303429b3ed1a4e64fedc/lockfile/lockfile-file/src/write.ts#L77
- */
-function stringifyToPnpmYaml(lockfile) {
-    const isLockfileV6 = isV6Lockfile(lockfile);
-    const adaptedLockfile = isLockfileV6
-        ? convertToInlineSpecifiersFormat(lockfile)
-        : lockfile;
-    return (0, js_yaml_1.dump)(sortLockfileKeys(normalizeLockfile(adaptedLockfile, isLockfileV6)), LOCKFILE_YAML_FORMAT);
-}
-exports.stringifyToPnpmYaml = stringifyToPnpmYaml;
-// https://github.com/pnpm/pnpm/blob/af3e5559d377870d4c3d303429b3ed1a4e64fedc/lockfile/lockfile-file/src/write.ts#L106
-function normalizeLockfile(lockfile, isLockfileV6) {
-    let lockfileToSave;
-    if (Object.keys(lockfile.importers).length === 1 && lockfile.importers['.']) {
-        lockfileToSave = Object.assign(Object.assign({}, lockfile), lockfile.importers['.']);
-        delete lockfileToSave.importers;
-        for (const depType of DEPENDENCIES_FIELDS) {
-            if (isEmpty(lockfileToSave[depType])) {
-                delete lockfileToSave[depType];
-            }
-        }
-        if (isEmpty(lockfileToSave.packages) || lockfileToSave.packages == null) {
-            delete lockfileToSave.packages;
-        }
-    }
-    else {
-        lockfileToSave = Object.assign(Object.assign({}, lockfile), { importers: mapValues(lockfile.importers, (importer) => {
-                var _a, _b, _c;
-                const normalizedImporter = {};
-                if (!isEmpty((_a = importer.specifiers) !== null && _a !== void 0 ? _a : {}) || !isLockfileV6) {
-                    normalizedImporter['specifiers'] = (_b = importer.specifiers) !== null && _b !== void 0 ? _b : {};
-                }
-                if (importer.dependenciesMeta != null &&
-                    !isEmpty(importer.dependenciesMeta)) {
-                    normalizedImporter['dependenciesMeta'] = importer.dependenciesMeta;
-                }
-                for (const depType of DEPENDENCIES_FIELDS) {
-                    if (!isEmpty((_c = importer[depType]) !== null && _c !== void 0 ? _c : {})) {
-                        normalizedImporter[depType] = importer[depType];
-                    }
-                }
-                if (importer.publishDirectory) {
-                    normalizedImporter.publishDirectory = importer.publishDirectory;
-                }
-                return normalizedImporter;
-            }) });
-        if (isEmpty(lockfileToSave.packages) || lockfileToSave.packages == null) {
-            delete lockfileToSave.packages;
-        }
-    }
-    if (lockfileToSave.time) {
-        lockfileToSave.time = (isLockfileV6 ? pruneTimeInLockfileV6 : pruneTime)(lockfileToSave.time, lockfile.importers);
-    }
-    if (lockfileToSave.overrides != null && isEmpty(lockfileToSave.overrides)) {
-        delete lockfileToSave.overrides;
-    }
-    if (lockfileToSave.patchedDependencies != null &&
-        isEmpty(lockfileToSave.patchedDependencies)) {
-        delete lockfileToSave.patchedDependencies;
-    }
-    if (lockfileToSave.neverBuiltDependencies != null) {
-        if (isEmpty(lockfileToSave.neverBuiltDependencies)) {
-            delete lockfileToSave.neverBuiltDependencies;
-        }
-        else {
-            lockfileToSave.neverBuiltDependencies =
-                lockfileToSave.neverBuiltDependencies.sort();
-        }
-    }
-    if (lockfileToSave.onlyBuiltDependencies != null) {
-        lockfileToSave.onlyBuiltDependencies =
-            lockfileToSave.onlyBuiltDependencies.sort();
-    }
-    if (!lockfileToSave.packageExtensionsChecksum) {
-        delete lockfileToSave.packageExtensionsChecksum;
-    }
-    return lockfileToSave;
+exports.unlinkSync = unlinkSync;
+
+// wrappers around common.statFollowLinks and common.statNoFollowLinks that clarify intent
+// and improve readability
+function statFollowLinks() {
+  return fs.statSync.apply(fs, arguments);
 }
-// https://github.com/pnpm/pnpm/blob/af3e5559d377870d4c3d303429b3ed1a4e64fedc/lockfile/lockfile-file/src/write.ts#L173
-function pruneTimeInLockfileV6(time, importers) {
-    var _a;
-    const rootDepPaths = new Set();
-    for (const importer of Object.values(importers)) {
-        for (const depType of DEPENDENCIES_FIELDS) {
-            for (let [depName, ref] of Object.entries((_a = importer[depType]) !== null && _a !== void 0 ? _a : {})) {
-                let version;
-                if (ref['version']) {
-                    version = ref['version'];
-                }
-                else {
-                    version = ref;
-                }
-                const suffixStart = version.indexOf('(');
-                const refWithoutPeerSuffix = suffixStart === -1 ? version : version.slice(0, suffixStart);
-                const depPath = refToRelative(refWithoutPeerSuffix, depName);
-                if (!depPath)
-                    continue;
-                rootDepPaths.add(depPath);
-            }
-        }
-    }
-    return pickBy((prop) => rootDepPaths.has(prop), time);
+exports.statFollowLinks = statFollowLinks;
+
+function statNoFollowLinks() {
+  return fs.lstatSync.apply(fs, arguments);
 }
-// https://github.com/pnpm/pnpm/blob/af3e5559d377870d4c3d303429b3ed1a4e64fedc/lockfile/lockfile-file/src/write.ts#L191
-function refToRelative(reference, pkgName) {
-    if (reference.startsWith('link:')) {
-        return null;
-    }
-    if (reference.startsWith('file:')) {
-        return reference;
+exports.statNoFollowLinks = statNoFollowLinks;
+
+// e.g. 'shelljs_a5f185d0443ca...'
+function randomFileName() {
+  function randomHash(count) {
+    if (count === 1) {
+      return parseInt(16 * Math.random(), 10).toString(16);
     }
-    if (!reference.includes('/') ||
-        !reference.replace(/(\([^)]+\))+$/, '').includes('/')) {
-        return `/${pkgName}@${reference}`;
+    var hash = '';
+    for (var i = 0; i < count; i++) {
+      hash += randomHash(1);
     }
-    return reference;
+    return hash;
+  }
+
+  return 'shelljs_' + randomHash(20);
 }
-// https://github.com/pnpm/pnpm/blob/af3e5559d377870d4c3d303429b3ed1a4e64fedc/lockfile/lockfile-file/src/write.ts#L207
-function pruneTime(time, importers) {
-    var _a;
-    const rootDepPaths = new Set();
-    for (const importer of Object.values(importers)) {
-        for (const depType of DEPENDENCIES_FIELDS) {
-            for (let [depName, ref] of Object.entries((_a = importer[depType]) !== null && _a !== void 0 ? _a : {})) {
-                let version;
-                if (ref['version']) {
-                    version = ref['version'];
-                }
-                else {
-                    version = ref;
-                }
-                const suffixStart = version.indexOf('_');
-                const refWithoutPeerSuffix = suffixStart === -1 ? version : version.slice(0, suffixStart);
-                const depPath = dpRefToRelative(refWithoutPeerSuffix, depName);
-                if (!depPath)
-                    continue;
-                rootDepPaths.add(depPath);
-            }
+exports.randomFileName = randomFileName;
+
+// Common wrapper for all Unix-like commands that performs glob expansion,
+// command-logging, and other nice things
+function wrap(cmd, fn, options) {
+  options = options || {};
+  return function () {
+    var retValue = null;
+
+    state.currentCmd = cmd;
+    state.error = null;
+    state.errorCode = 0;
+
+    try {
+      var args = [].slice.call(arguments, 0);
+
+      // Log the command to stderr, if appropriate
+      if (config.verbose) {
+        console.error.apply(console, [cmd].concat(args));
+      }
+
+      // If this is coming from a pipe, let's set the pipedValue (otherwise, set
+      // it to the empty string)
+      state.pipedValue = (this && typeof this.stdout === 'string') ? this.stdout : '';
+
+      if (options.unix === false) { // this branch is for exec()
+        retValue = fn.apply(this, args);
+      } else { // and this branch is for everything else
+        if (isObject(args[0]) && args[0].constructor.name === 'Object') {
+          // a no-op, allowing the syntax `touch({'-r': file}, ...)`
+        } else if (args.length === 0 || typeof args[0] !== 'string' || args[0].length <= 1 || args[0][0] !== '-') {
+          args.unshift(''); // only add dummy option if '-option' not already present
         }
-    }
-    return pickBy((depPath) => rootDepPaths.has(depPath), time);
-}
-// https://github.com/pnpm/pnpm/blob/af3e5559d377870d4c3d303429b3ed1a4e64fedc/lockfile/lockfile-file/src/sortLockfileKeys.ts#L34
-const ROOT_KEYS_ORDER = {
-    lockfileVersion: 1,
-    // only and never are conflict options.
-    neverBuiltDependencies: 2,
-    onlyBuiltDependencies: 2,
-    overrides: 3,
-    packageExtensionsChecksum: 4,
-    patchedDependencies: 5,
-    specifiers: 10,
-    dependencies: 11,
-    optionalDependencies: 12,
-    devDependencies: 13,
-    dependenciesMeta: 14,
-    importers: 15,
-    packages: 16,
-};
-// https://github.com/pnpm/pnpm/blob/af3e5559d377870d4c3d303429b3ed1a4e64fedc/lockfile/lockfile-file/src/sortLockfileKeys.ts#L60
-function sortLockfileKeys(lockfile) {
-    let sortedLockfile = {};
-    const sortedKeys = Object.keys(lockfile).sort((a, b) => ROOT_KEYS_ORDER[a] - ROOT_KEYS_ORDER[b]);
-    for (const key of sortedKeys) {
-        sortedLockfile[key] = lockfile[key];
-    }
-    return sortedLockfile;
-}
-/**
- * Types from https://github.com/pnpm/pnpm/blob/af3e5559d377870d4c3d303429b3ed1a4e64fedc/lockfile/lockfile-file/src/experiments/InlineSpecifiersLockfile.ts
- */
-const INLINE_SPECIFIERS_FORMAT_LOCKFILE_VERSION_SUFFIX = '-inlineSpecifiers';
-// https://github.com/pnpm/pnpm/blob/af3e5559d377870d4c3d303429b3ed1a4e64fedc/lockfile/lockfile-file/src/experiments/inlineSpecifiersLockfileConverters.ts#L10
-function isExperimentalInlineSpecifiersFormat(lockfile) {
-    const { lockfileVersion } = lockfile;
-    return (lockfileVersion.toString().startsWith('6.') ||
-        (typeof lockfileVersion === 'string' &&
-            lockfileVersion.endsWith(INLINE_SPECIFIERS_FORMAT_LOCKFILE_VERSION_SUFFIX)));
-}
-// https://github.com/pnpm/pnpm/blob/af3e5559d377870d4c3d303429b3ed1a4e64fedc/lockfile/lockfile-file/src/experiments/inlineSpecifiersLockfileConverters.ts#L17
-function convertToInlineSpecifiersFormat(lockfile) {
-    var _a, _b;
-    let importers = lockfile.importers;
-    let packages = lockfile.packages;
-    if (isV6Lockfile(lockfile)) {
-        importers = Object.fromEntries(Object.entries((_a = lockfile.importers) !== null && _a !== void 0 ? _a : {}).map(([importerId, pkgSnapshot]) => {
-            const newSnapshot = Object.assign({}, pkgSnapshot);
-            if (newSnapshot.dependencies != null) {
-                newSnapshot.dependencies = mapValues(newSnapshot.dependencies, convertOldRefToNewRef);
-            }
-            if (newSnapshot.optionalDependencies != null) {
-                newSnapshot.optionalDependencies = mapValues(newSnapshot.optionalDependencies, convertOldRefToNewRef);
-            }
-            if (newSnapshot.devDependencies != null) {
-                newSnapshot.devDependencies = mapValues(newSnapshot.devDependencies, convertOldRefToNewRef);
-            }
-            return [importerId, newSnapshot];
-        }));
-        packages = Object.fromEntries(Object.entries((_b = lockfile.packages) !== null && _b !== void 0 ? _b : {}).map(([depPath, pkgSnapshot]) => {
-            const newSnapshot = Object.assign({}, pkgSnapshot);
-            if (newSnapshot.dependencies != null) {
-                newSnapshot.dependencies = mapValues(newSnapshot.dependencies, convertOldRefToNewRef);
-            }
-            if (newSnapshot.optionalDependencies != null) {
-                newSnapshot.optionalDependencies = mapValues(newSnapshot.optionalDependencies, convertOldRefToNewRef);
-            }
-            return [convertOldDepPathToNewDepPath(depPath), newSnapshot];
-        }));
-    }
-    const newLockfile = Object.assign(Object.assign({}, lockfile), { packages, lockfileVersion: isV6Lockfile(lockfile)
-            ? lockfile.lockfileVersion.toString()
-            : lockfile.lockfileVersion
-                .toString()
-                .endsWith(INLINE_SPECIFIERS_FORMAT_LOCKFILE_VERSION_SUFFIX)
-                ? lockfile.lockfileVersion.toString()
-                : `${lockfile.lockfileVersion}${INLINE_SPECIFIERS_FORMAT_LOCKFILE_VERSION_SUFFIX}`, importers: mapValues(importers, convertProjectSnapshotToInlineSpecifiersFormat) });
-    if (isV6Lockfile(lockfile) && newLockfile.time) {
-        newLockfile.time = Object.fromEntries(Object.entries(newLockfile.time).map(([depPath, time]) => [
-            convertOldDepPathToNewDepPath(depPath),
-            time,
-        ]));
-    }
-    return newLockfile;
-}
-// https://github.com/pnpm/pnpm/blob/af3e5559d377870d4c3d303429b3ed1a4e64fedc/lockfile/lockfile-file/src/experiments/inlineSpecifiersLockfileConverters.ts#L72
-function convertOldDepPathToNewDepPath(oldDepPath) {
-    const parsedDepPath = dpParse(oldDepPath);
-    if (!parsedDepPath.name || !parsedDepPath.version)
-        return oldDepPath;
-    let newDepPath = `/${parsedDepPath.name}@${parsedDepPath.version}`;
-    if (parsedDepPath.peersSuffix) {
-        if (parsedDepPath.peersSuffix.startsWith('(')) {
-            newDepPath += parsedDepPath.peersSuffix;
+
+        // flatten out arrays that are arguments, to make the syntax:
+        //    `cp([file1, file2, file3], dest);`
+        // equivalent to:
+        //    `cp(file1, file2, file3, dest);`
+        args = args.reduce(function (accum, cur) {
+          if (Array.isArray(cur)) {
+            return accum.concat(cur);
+          }
+          accum.push(cur);
+          return accum;
+        }, []);
+
+        // Convert ShellStrings (basically just String objects) to regular strings
+        args = args.map(function (arg) {
+          if (isObject(arg) && arg.constructor.name === 'String') {
+            return arg.toString();
+          }
+          return arg;
+        });
+
+        // Expand the '~' if appropriate
+        var homeDir = os.homedir();
+        args = args.map(function (arg) {
+          if (typeof arg === 'string' && arg.slice(0, 2) === '~/' || arg === '~') {
+            return arg.replace(/^~/, homeDir);
+          }
+          return arg;
+        });
+
+        // Perform glob-expansion on all arguments after globStart, but preserve
+        // the arguments before it (like regexes for sed and grep)
+        if (!config.noglob && options.allowGlobbing === true) {
+          args = args.slice(0, options.globStart).concat(expand(args.slice(options.globStart)));
         }
-        else {
-            newDepPath += `_${parsedDepPath.peersSuffix}`;
+
+        try {
+          // parse options if options are provided
+          if (isObject(options.cmdOptions)) {
+            args[0] = parseOptions(args[0], options.cmdOptions);
+          }
+
+          retValue = fn.apply(this, args);
+        } catch (e) {
+          /* istanbul ignore else */
+          if (e.msg === 'earlyExit') {
+            retValue = e.retValue;
+          } else {
+            throw e; // this is probably a bug that should be thrown up the call stack
+          }
         }
+      }
+    } catch (e) {
+      /* istanbul ignore next */
+      if (!state.error) {
+        // If state.error hasn't been set it's an error thrown by Node, not us - probably a bug...
+        e.name = 'ShellJSInternalError';
+        throw e;
+      }
+      if (config.fatal) throw e;
     }
-    if (parsedDepPath.host) {
-        newDepPath = `${parsedDepPath.host}${newDepPath}`;
+
+    if (options.wrapOutput &&
+        (typeof retValue === 'string' || Array.isArray(retValue))) {
+      retValue = new ShellString(retValue, state.error, state.errorCode);
     }
-    return newDepPath;
+
+    state.currentCmd = 'shell.js';
+    return retValue;
+  };
+} // wrap
+exports.wrap = wrap;
+
+// This returns all the input that is piped into the current command (or the
+// empty string, if this isn't on the right-hand side of a pipe
+function _readFromPipe() {
+  return state.pipedValue;
 }
-// https://github.com/pnpm/pnpm/blob/af3e5559d377870d4c3d303429b3ed1a4e64fedc/lockfile/lockfile-file/src/experiments/inlineSpecifiersLockfileConverters.ts#L89
-function convertOldRefToNewRef(oldRef) {
-    if (oldRef.startsWith('link:') || oldRef.startsWith('file:')) {
-        return oldRef;
+exports.readFromPipe = _readFromPipe;
+
+var DEFAULT_WRAP_OPTIONS = {
+  allowGlobbing: true,
+  canReceivePipe: false,
+  cmdOptions: null,
+  globStart: 1,
+  pipeOnly: false,
+  wrapOutput: true,
+  unix: true,
+};
+
+// This is populated during plugin registration
+var pipeMethods = [];
+
+// Register a new ShellJS command
+function _register(name, implementation, wrapOptions) {
+  wrapOptions = wrapOptions || {};
+
+  // Validate options
+  Object.keys(wrapOptions).forEach(function (option) {
+    if (!DEFAULT_WRAP_OPTIONS.hasOwnProperty(option)) {
+      throw new Error("Unknown option '" + option + "'");
     }
-    if (oldRef.includes('/')) {
-        return convertOldDepPathToNewDepPath(oldRef);
+    if (typeof wrapOptions[option] !== typeof DEFAULT_WRAP_OPTIONS[option]) {
+      throw new TypeError("Unsupported type '" + typeof wrapOptions[option] +
+        "' for option '" + option + "'");
     }
-    return oldRef;
-}
-// https://github.com/pnpm/pnpm/blob/af3e5559d377870d4c3d303429b3ed1a4e64fedc/lockfile/lockfile-file/src/experiments/inlineSpecifiersLockfileConverters.ts#L99
-function revertFromInlineSpecifiersFormatIfNecessary(lockfile) {
-    return isExperimentalInlineSpecifiersFormat(lockfile)
-        ? revertFromInlineSpecifiersFormat(lockfile)
-        : lockfile;
+  });
+
+  // If an option isn't specified, use the default
+  wrapOptions = Object.assign({}, DEFAULT_WRAP_OPTIONS, wrapOptions);
+
+  if (shell.hasOwnProperty(name)) {
+    throw new Error('Command `' + name + '` already exists');
+  }
+
+  if (wrapOptions.pipeOnly) {
+    wrapOptions.canReceivePipe = true;
+    shellMethods[name] = wrap(name, implementation, wrapOptions);
+  } else {
+    shell[name] = wrap(name, implementation, wrapOptions);
+  }
+
+  if (wrapOptions.canReceivePipe) {
+    pipeMethods.push(name);
+  }
 }
-// https://github.com/pnpm/pnpm/blob/af3e5559d377870d4c3d303429b3ed1a4e64fedc/lockfile/lockfile-file/src/experiments/inlineSpecifiersLockfileConverters.ts#L105
-function revertFromInlineSpecifiersFormat(lockfile) {
-    var _a;
-    const { lockfileVersion, importers } = lockfile, rest = tslib_1.__rest(lockfile, ["lockfileVersion", "importers"]);
-    const originalVersionStr = lockfileVersion.replace(INLINE_SPECIFIERS_FORMAT_LOCKFILE_VERSION_SUFFIX, '');
-    const originalVersion = Number(originalVersionStr);
-    if (isNaN(originalVersion)) {
-        throw new Error(`Unable to revert lockfile from inline specifiers format. Invalid version parsed: ${originalVersionStr}`);
+exports.register = _register;
+
+
+/***/ }),
+
+/***/ 64395:
+/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+
+var fs = __nccwpck_require__(57147);
+var path = __nccwpck_require__(71017);
+var common = __nccwpck_require__(60624);
+
+common.register('cp', _cp, {
+  cmdOptions: {
+    'f': '!no_force',
+    'n': 'no_force',
+    'u': 'update',
+    'R': 'recursive',
+    'r': 'recursive',
+    'L': 'followsymlink',
+    'P': 'noFollowsymlink',
+  },
+  wrapOutput: false,
+});
+
+// Buffered file copy, synchronous
+// (Using readFileSync() + writeFileSync() could easily cause a memory overflow
+//  with large files)
+function copyFileSync(srcFile, destFile, options) {
+  if (!fs.existsSync(srcFile)) {
+    common.error('copyFileSync: no such file or directory: ' + srcFile);
+  }
+
+  var isWindows = process.platform === 'win32';
+
+  // Check the mtimes of the files if the '-u' flag is provided
+  try {
+    if (options.update && common.statFollowLinks(srcFile).mtime < fs.statSync(destFile).mtime) {
+      return;
     }
-    let revertedImporters = mapValues(importers, revertProjectSnapshot);
-    let packages = lockfile.packages;
-    if (originalVersion === 6) {
-        revertedImporters = Object.fromEntries(Object.entries(revertedImporters !== null && revertedImporters !== void 0 ? revertedImporters : {}).map(([importerId, pkgSnapshot]) => {
-            const newSnapshot = Object.assign({}, pkgSnapshot);
-            if (newSnapshot.dependencies != null) {
-                newSnapshot.dependencies = mapValues(newSnapshot.dependencies, convertNewRefToOldRef);
-            }
-            if (newSnapshot.optionalDependencies != null) {
-                newSnapshot.optionalDependencies = mapValues(newSnapshot.optionalDependencies, convertNewRefToOldRef);
-            }
-            if (newSnapshot.devDependencies != null) {
-                newSnapshot.devDependencies = mapValues(newSnapshot.devDependencies, convertNewRefToOldRef);
-            }
-            return [importerId, newSnapshot];
-        }));
-        packages = Object.fromEntries(Object.entries((_a = lockfile.packages) !== null && _a !== void 0 ? _a : {}).map(([depPath, pkgSnapshot]) => {
-            const newSnapshot = Object.assign({}, pkgSnapshot);
-            if (newSnapshot.dependencies != null) {
-                newSnapshot.dependencies = mapValues(newSnapshot.dependencies, convertNewRefToOldRef);
-            }
-            if (newSnapshot.optionalDependencies != null) {
-                newSnapshot.optionalDependencies = mapValues(newSnapshot.optionalDependencies, convertNewRefToOldRef);
-            }
-            return [convertNewDepPathToOldDepPath(depPath), newSnapshot];
-        }));
+  } catch (e) {
+    // If we're here, destFile probably doesn't exist, so just do a normal copy
+  }
+
+  if (common.statNoFollowLinks(srcFile).isSymbolicLink() && !options.followsymlink) {
+    try {
+      common.statNoFollowLinks(destFile);
+      common.unlinkSync(destFile); // re-link it
+    } catch (e) {
+      // it doesn't exist, so no work needs to be done
     }
-    const newLockfile = Object.assign(Object.assign({}, rest), { lockfileVersion: lockfileVersion.endsWith(INLINE_SPECIFIERS_FORMAT_LOCKFILE_VERSION_SUFFIX)
-            ? originalVersion
-            : lockfileVersion, packages, importers: revertedImporters });
-    if (originalVersion === 6 && newLockfile.time) {
-        newLockfile.time = Object.fromEntries(Object.entries(newLockfile.time).map(([depPath, time]) => [
-            convertNewDepPathToOldDepPath(depPath),
-            time,
-        ]));
+
+    var symlinkFull = fs.readlinkSync(srcFile);
+    fs.symlinkSync(symlinkFull, destFile, isWindows ? 'junction' : null);
+  } else {
+    var buf = common.buffer();
+    var bufLength = buf.length;
+    var bytesRead = bufLength;
+    var pos = 0;
+    var fdr = null;
+    var fdw = null;
+
+    try {
+      fdr = fs.openSync(srcFile, 'r');
+    } catch (e) {
+      /* istanbul ignore next */
+      common.error('copyFileSync: could not read src file (' + srcFile + ')');
     }
-    return newLockfile;
-}
-// https://github.com/pnpm/pnpm/blob/af3e5559d377870d4c3d303429b3ed1a4e64fedc/lockfile/lockfile-file/src/experiments/inlineSpecifiersLockfileConverters.ts#L162
-function convertNewDepPathToOldDepPath(oldDepPath) {
-    if (!oldDepPath.includes('@', 2))
-        return oldDepPath;
-    const index = oldDepPath.indexOf('@', oldDepPath.indexOf('/@') + 2);
-    if (oldDepPath.includes('(') && index > oldDepPath.indexOf('('))
-        return oldDepPath;
-    return `${oldDepPath.substring(0, index)}/${oldDepPath.substring(index + 1)}`;
-}
-// https://github.com/pnpm/pnpm/blob/af3e5559d377870d4c3d303429b3ed1a4e64fedc/lockfile/lockfile-file/src/experiments/inlineSpecifiersLockfileConverters.ts#L169
-function convertNewRefToOldRef(oldRef) {
-    if (oldRef.startsWith('link:') || oldRef.startsWith('file:')) {
-        return oldRef;
+
+    try {
+      fdw = fs.openSync(destFile, 'w');
+    } catch (e) {
+      /* istanbul ignore next */
+      common.error('copyFileSync: could not write to dest file (code=' + e.code + '):' + destFile);
     }
-    if (oldRef.includes('@')) {
-        return convertNewDepPathToOldDepPath(oldRef);
+
+    while (bytesRead === bufLength) {
+      bytesRead = fs.readSync(fdr, buf, 0, bufLength, pos);
+      fs.writeSync(fdw, buf, 0, bytesRead);
+      pos += bytesRead;
     }
-    return oldRef;
-}
-// https://github.com/pnpm/pnpm/blob/af3e5559d377870d4c3d303429b3ed1a4e64fedc/lockfile/lockfile-file/src/experiments/inlineSpecifiersLockfileConverters.ts#L179
-function convertProjectSnapshotToInlineSpecifiersFormat(projectSnapshot) {
-    const { specifiers } = projectSnapshot, rest = tslib_1.__rest(projectSnapshot, ["specifiers"]);
-    const convertBlock = (block) => block != null
-        ? convertResolvedDependenciesToInlineSpecifiersFormat(block, {
-            specifiers,
-        })
-        : block;
-    return Object.assign(Object.assign({}, rest), { dependencies: convertBlock(projectSnapshot.dependencies), optionalDependencies: convertBlock(projectSnapshot.optionalDependencies), devDependencies: convertBlock(projectSnapshot.devDependencies) });
-}
-// https://github.com/pnpm/pnpm/blob/af3e5559d377870d4c3d303429b3ed1a4e64fedc/lockfile/lockfile-file/src/experiments/inlineSpecifiersLockfileConverters.ts#L195
-function convertResolvedDependenciesToInlineSpecifiersFormat(resolvedDependencies, { specifiers }) {
-    return mapValues(resolvedDependencies, (version, depName) => ({
-        specifier: specifiers[depName],
-        version,
-    }));
+
+    fs.closeSync(fdr);
+    fs.closeSync(fdw);
+
+    fs.chmodSync(destFile, common.statFollowLinks(srcFile).mode);
+  }
 }
-// https://github.com/pnpm/pnpm/blob/af3e5559d377870d4c3d303429b3ed1a4e64fedc/lockfile/lockfile-file/src/experiments/inlineSpecifiersLockfileConverters.ts#L205
-function revertProjectSnapshot(from) {
-    const specifiers = {};
-    function moveSpecifiers(from) {
-        const resolvedDependencies = {};
-        for (const [depName, { specifier, version }] of Object.entries(from)) {
-            const existingValue = specifiers[depName];
-            if (existingValue != null && existingValue !== specifier) {
-                throw new Error(`Project snapshot lists the same dependency more than once with conflicting versions: ${depName}`);
-            }
-            specifiers[depName] = specifier;
-            resolvedDependencies[depName] = version;
-        }
-        return resolvedDependencies;
+
+// Recursively copies 'sourceDir' into 'destDir'
+// Adapted from https://github.com/ryanmcgrath/wrench-js
+//
+// Copyright (c) 2010 Ryan McGrath
+// Copyright (c) 2012 Artur Adib
+//
+// Licensed under the MIT License
+// http://www.opensource.org/licenses/mit-license.php
+function cpdirSyncRecursive(sourceDir, destDir, currentDepth, opts) {
+  if (!opts) opts = {};
+
+  // Ensure there is not a run away recursive copy
+  if (currentDepth >= common.config.maxdepth) return;
+  currentDepth++;
+
+  var isWindows = process.platform === 'win32';
+
+  // Create the directory where all our junk is moving to; read the mode of the
+  // source directory and mirror it
+  try {
+    fs.mkdirSync(destDir);
+  } catch (e) {
+    // if the directory already exists, that's okay
+    if (e.code !== 'EEXIST') throw e;
+  }
+
+  var files = fs.readdirSync(sourceDir);
+
+  for (var i = 0; i < files.length; i++) {
+    var srcFile = sourceDir + '/' + files[i];
+    var destFile = destDir + '/' + files[i];
+    var srcFileStat = common.statNoFollowLinks(srcFile);
+
+    var symlinkFull;
+    if (opts.followsymlink) {
+      if (cpcheckcycle(sourceDir, srcFile)) {
+        // Cycle link found.
+        console.error('Cycle link found.');
+        symlinkFull = fs.readlinkSync(srcFile);
+        fs.symlinkSync(symlinkFull, destFile, isWindows ? 'junction' : null);
+        continue;
+      }
     }
-    const dependencies = from.dependencies
-        ? moveSpecifiers(from.dependencies)
-        : null;
-    const devDependencies = from.devDependencies
-        ? moveSpecifiers(from.devDependencies)
-        : null;
-    const optionalDependencies = from.optionalDependencies
-        ? moveSpecifiers(from.optionalDependencies)
-        : null;
-    return Object.assign(Object.assign({}, from), { specifiers,
-        dependencies,
-        devDependencies,
-        optionalDependencies });
-}
-// https://github.com/pnpm/pnpm/blob/af3e5559d377870d4c3d303429b3ed1a4e64fedc/lockfile/lockfile-file/src/experiments/inlineSpecifiersLockfileConverters.ts#L241
-function mapValues(obj, mapper) {
-    const result = {};
-    for (const [key, value] of Object.entries(obj)) {
-        result[key] = mapper(value, key);
+    if (srcFileStat.isDirectory()) {
+      /* recursion this thing right on back. */
+      cpdirSyncRecursive(srcFile, destFile, currentDepth, opts);
+    } else if (srcFileStat.isSymbolicLink() && !opts.followsymlink) {
+      symlinkFull = fs.readlinkSync(srcFile);
+      try {
+        common.statNoFollowLinks(destFile);
+        common.unlinkSync(destFile); // re-link it
+      } catch (e) {
+        // it doesn't exist, so no work needs to be done
+      }
+      fs.symlinkSync(symlinkFull, destFile, isWindows ? 'junction' : null);
+    } else if (srcFileStat.isSymbolicLink() && opts.followsymlink) {
+      srcFileStat = common.statFollowLinks(srcFile);
+      if (srcFileStat.isDirectory()) {
+        cpdirSyncRecursive(srcFile, destFile, currentDepth, opts);
+      } else {
+        copyFileSync(srcFile, destFile, opts);
+      }
+    } else {
+      /* At this point, we've hit a file actually worth copying... so copy it on over. */
+      if (fs.existsSync(destFile) && opts.no_force) {
+        common.log('skipping existing file: ' + files[i]);
+      } else {
+        copyFileSync(srcFile, destFile, opts);
+      }
     }
-    return result;
-}
-/*************************************************************************
- * THE FOLLOWING CODE IS COPIED FROM @pnpm/types for convenience
- *************************************************************************/
-// https://github.com/pnpm/pnpm/blob/af3e5559d377870d4c3d303429b3ed1a4e64fedc/packages/types/src/misc.ts#L6
-const DEPENDENCIES_FIELDS = [
-    'optionalDependencies',
-    'dependencies',
-    'devDependencies',
-];
-/*************************************************************************
- * THE FOLLOWING CODE IS COPIED FROM @pnpm/dependency-path for convenience
- *************************************************************************/
-// https://github.com/pnpm/pnpm/blob/af3e5559d377870d4c3d303429b3ed1a4e64fedc/packages/dependency-path/src/index.ts#L6
-function isAbsolute(dependencyPath) {
-    return dependencyPath[0] !== '/';
+  } // for files
+
+  // finally change the mode for the newly created directory (otherwise, we
+  // couldn't add files to a read-only directory).
+  var checkDir = common.statFollowLinks(sourceDir);
+  fs.chmodSync(destDir, checkDir.mode);
+} // cpdirSyncRecursive
+
+// Checks if cureent file was created recently
+function checkRecentCreated(sources, index) {
+  var lookedSource = sources[index];
+  return sources.slice(0, index).some(function (src) {
+    return path.basename(src) === path.basename(lookedSource);
+  });
 }
-// https://github.com/pnpm/pnpm/blob/af3e5559d377870d4c3d303429b3ed1a4e64fedc/packages/dependency-path/src/index.ts#L80
-function dpRefToRelative(reference, pkgName) {
-    if (reference.startsWith('link:')) {
-        return null;
-    }
-    if (reference.startsWith('file:')) {
-        return reference;
-    }
-    if (!reference.includes('/') ||
-        (reference.includes('(') &&
-            reference.lastIndexOf('/', reference.indexOf('(')) === -1)) {
-        return `/${pkgName}/${reference}`;
+
+function cpcheckcycle(sourceDir, srcFile) {
+  var srcFileStat = common.statNoFollowLinks(srcFile);
+  if (srcFileStat.isSymbolicLink()) {
+    // Do cycle check. For example:
+    //   $ mkdir -p 1/2/3/4
+    //   $ cd  1/2/3/4
+    //   $ ln -s ../../3 link
+    //   $ cd ../../../..
+    //   $ cp -RL 1 copy
+    var cyclecheck = common.statFollowLinks(srcFile);
+    if (cyclecheck.isDirectory()) {
+      var sourcerealpath = fs.realpathSync(sourceDir);
+      var symlinkrealpath = fs.realpathSync(srcFile);
+      var re = new RegExp(symlinkrealpath);
+      if (re.test(sourcerealpath)) {
+        return true;
+      }
     }
-    return reference;
+  }
+  return false;
 }
-// https://github.com/pnpm/pnpm/blob/af3e5559d377870d4c3d303429b3ed1a4e64fedc/packages/dependency-path/src/index.ts#L96
-function dpParse(dependencyPath) {
-    // eslint-disable-next-line: strict-type-predicates
-    if (typeof dependencyPath !== 'string') {
-        throw new TypeError(`Expected \`dependencyPath\` to be of type \`string\`, got \`${
-        // eslint-disable-next-line: strict-type-predicates
-        dependencyPath === null ? 'null' : typeof dependencyPath}\``);
+
+//@
+//@ ### cp([options,] source [, source ...], dest)
+//@ ### cp([options,] source_array, dest)
+//@
+//@ Available options:
+//@
+//@ + `-f`: force (default behavior)
+//@ + `-n`: no-clobber
+//@ + `-u`: only copy if `source` is newer than `dest`
+//@ + `-r`, `-R`: recursive
+//@ + `-L`: follow symlinks
+//@ + `-P`: don't follow symlinks
+//@
+//@ Examples:
+//@
+//@ ```javascript
+//@ cp('file1', 'dir1');
+//@ cp('-R', 'path/to/dir/', '~/newCopy/');
+//@ cp('-Rf', '/tmp/*', '/usr/local/*', '/home/tmp');
+//@ cp('-Rf', ['/tmp/*', '/usr/local/*'], '/home/tmp'); // same as above
+//@ ```
+//@
+//@ Copies files.
+function _cp(options, sources, dest) {
+  // If we're missing -R, it actually implies -L (unless -P is explicit)
+  if (options.followsymlink) {
+    options.noFollowsymlink = false;
+  }
+  if (!options.recursive && !options.noFollowsymlink) {
+    options.followsymlink = true;
+  }
+
+  // Get sources, dest
+  if (arguments.length < 3) {
+    common.error('missing  and/or ');
+  } else {
+    sources = [].slice.call(arguments, 1, arguments.length - 1);
+    dest = arguments[arguments.length - 1];
+  }
+
+  var destExists = fs.existsSync(dest);
+  var destStat = destExists && common.statFollowLinks(dest);
+
+  // Dest is not existing dir, but multiple sources given
+  if ((!destExists || !destStat.isDirectory()) && sources.length > 1) {
+    common.error('dest is not a directory (too many sources)');
+  }
+
+  // Dest is an existing file, but -n is given
+  if (destExists && destStat.isFile() && options.no_force) {
+    return new common.ShellString('', '', 0);
+  }
+
+  sources.forEach(function (src, srcIndex) {
+    if (!fs.existsSync(src)) {
+      if (src === '') src = "''"; // if src was empty string, display empty string
+      common.error('no such file or directory: ' + src, { continue: true });
+      return; // skip file
     }
-    const _isAbsolute = isAbsolute(dependencyPath);
-    const parts = dependencyPath.split('/');
-    if (!_isAbsolute)
-        parts.shift();
-    const host = _isAbsolute ? parts.shift() : undefined;
-    if (parts.length === 0)
-        return {
-            host,
-            isAbsolute: _isAbsolute,
-        };
-    const name = parts[0].startsWith('@')
-        ? `${parts.shift()}/${parts.shift()}` // eslint-disable-line @typescript-eslint/restrict-template-expressions
-        : parts.shift();
-    let version = parts.join('/');
-    if (version) {
-        let peerSepIndex;
-        let peersSuffix;
-        if (version.includes('(') && version.endsWith(')')) {
-            peerSepIndex = version.indexOf('(');
-            if (peerSepIndex !== -1) {
-                peersSuffix = version.substring(peerSepIndex);
-                version = version.substring(0, peerSepIndex);
-            }
-        }
-        else {
-            peerSepIndex = version.indexOf('_');
-            if (peerSepIndex !== -1) {
-                peersSuffix = version.substring(peerSepIndex + 1);
-                version = version.substring(0, peerSepIndex);
-            }
-        }
-        if ((0, semver_1.valid)(version)) {
-            return {
-                host,
-                isAbsolute: _isAbsolute,
-                name,
-                peersSuffix,
-                version,
-            };
+    var srcStat = common.statFollowLinks(src);
+    if (!options.noFollowsymlink && srcStat.isDirectory()) {
+      if (!options.recursive) {
+        // Non-Recursive
+        common.error("omitting directory '" + src + "'", { continue: true });
+      } else {
+        // Recursive
+        // 'cp /a/source dest' should create 'source' in 'dest'
+        var newDest = (destStat && destStat.isDirectory()) ?
+            path.join(dest, path.basename(src)) :
+            dest;
+
+        try {
+          common.statFollowLinks(path.dirname(dest));
+          cpdirSyncRecursive(src, newDest, 0, { no_force: options.no_force, followsymlink: options.followsymlink });
+        } catch (e) {
+          /* istanbul ignore next */
+          common.error("cannot create directory '" + dest + "': No such file or directory");
         }
-    }
-    if (!_isAbsolute)
-        throw new Error(`${dependencyPath} is an invalid relative dependency path`);
-    return {
-        host,
-        isAbsolute: _isAbsolute,
-    };
-}
-/********************************************************************************
- * THE FOLLOWING CODE IS COPIED AND SIMPLIFIED FROM @pnpm/ramda for convenience
- *******************************************************************************/
-// https://github.com/pnpm/ramda/blob/50c6b57110b2f3631ed8633141f12012b7768d85/source/pickBy.js#L24
-function pickBy(test, obj) {
-    let result = {};
-    for (const prop in obj) {
-        if (test(obj[prop])) {
-            result[prop] = obj[prop];
+      }
+    } else {
+      // If here, src is a file
+
+      // When copying to '/path/dir':
+      //    thisDest = '/path/dir/file1'
+      var thisDest = dest;
+      if (destStat && destStat.isDirectory()) {
+        thisDest = path.normalize(dest + '/' + path.basename(src));
+      }
+
+      var thisDestExists = fs.existsSync(thisDest);
+      if (thisDestExists && checkRecentCreated(sources, srcIndex)) {
+        // cannot overwrite file created recently in current execution, but we want to continue copying other files
+        if (!options.no_force) {
+          common.error("will not overwrite just-created '" + thisDest + "' with '" + src + "'", { continue: true });
         }
+        return;
+      }
+
+      if (thisDestExists && options.no_force) {
+        return; // skip file
+      }
+
+      if (path.relative(src, thisDest) === '') {
+        // a file cannot be copied to itself, but we want to continue copying other files
+        common.error("'" + thisDest + "' and '" + src + "' are the same file", { continue: true });
+        return;
+      }
+
+      copyFileSync(src, thisDest, options);
     }
-    return result;
-}
-// https://github.com/pnpm/ramda/blob/50c6b57110b2f3631ed8633141f12012b7768d85/source/isEmpty.js#L28
-function isEmpty(obj) {
-    return obj != null && Object.keys(obj).length === 0;
+  }); // forEach(src)
+
+  return new common.ShellString('', common.state.error, common.state.errorCode);
 }
+module.exports = _cp;
 
 
 /***/ }),
 
-/***/ 33875:
+/***/ 11060:
 /***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
-"use strict";
+var common = __nccwpck_require__(60624);
+var _cd = __nccwpck_require__(79117);
+var path = __nccwpck_require__(71017);
 
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.stringifyYarnLockfile = exports.parseYarnLockfile = void 0;
-const tslib_1 = __nccwpck_require__(51796);
-const parsers_1 = __nccwpck_require__(98006);
-const lockfile_1 = __nccwpck_require__(82035);
-const package_json_1 = __nccwpck_require__(6500);
-const semver_1 = __nccwpck_require__(56192);
-const impl_1 = __nccwpck_require__(43265);
-const object_sort_1 = __nccwpck_require__(95961);
-function parseYarnLockfile(lockFileContent, builder) {
-    const data = (0, parsers_1.parseSyml)(lockFileContent);
-    // we use key => node map to avoid duplicate work when parsing keys
-    const keyMap = new Map();
-    addNodes(data, builder, keyMap);
-    addDependencies(data, builder, keyMap);
-}
-exports.parseYarnLockfile = parseYarnLockfile;
-function addNodes(_a, builder, keyMap) {
-    var { __metadata } = _a, dependencies = tslib_1.__rest(_a, ["__metadata"]);
-    const isBerry = !!__metadata;
-    const nodes = new Map();
-    Object.entries(dependencies).forEach(([keys, snapshot]) => {
-        // ignore workspace projects & patches
-        if (snapshot.linkType === 'soft' || keys.includes('@patch:')) {
-            return;
-        }
-        const packageName = keys.slice(0, keys.indexOf('@', 1));
-        const version = findVersion(packageName, keys.split(', ')[0], snapshot, isBerry);
-        keys.split(', ').forEach((key) => {
-            var _a;
-            // we don't need to keep duplicates, we can just track the keys
-            const existingNode = (_a = nodes.get(packageName)) === null || _a === void 0 ? void 0 : _a.get(version);
-            if (existingNode) {
-                keyMap.set(key, existingNode);
-                return;
-            }
-            const node = {
-                type: 'npm',
-                name: version ? `npm:${packageName}@${version}` : `npm:${packageName}`,
-                data: {
-                    version,
-                    packageName,
-                    hash: snapshot.integrity ||
-                        snapshot.checksum ||
-                        (0, impl_1.hashArray)([packageName, version]),
-                },
-            };
-            keyMap.set(key, node);
-            if (!nodes.has(packageName)) {
-                nodes.set(packageName, new Map([[version, node]]));
-            }
-            else {
-                nodes.get(packageName).set(version, node);
-            }
-        });
-    });
-    for (const [packageName, versionMap] of nodes.entries()) {
-        let hoistedNode;
-        if (versionMap.size === 1) {
-            hoistedNode = versionMap.values().next().value;
-        }
-        else {
-            const hoistedVersion = getHoistedVersion(packageName);
-            hoistedNode = versionMap.get(hoistedVersion);
-        }
-        if (hoistedNode) {
-            hoistedNode.name = `npm:${packageName}`;
-        }
-        versionMap.forEach((node) => {
-            builder.addExternalNode(node);
-        });
-    }
-}
-function findVersion(packageName, key, snapshot, isBerry) {
-    const versionRange = key.slice(packageName.length + 1);
-    // check for alias packages
-    const isAlias = isBerry
-        ? snapshot.resolution && !snapshot.resolution.startsWith(`${packageName}@`)
-        : versionRange.startsWith('npm:');
-    if (isAlias) {
-        return versionRange;
-    }
-    // check for berry tarball packages
-    if (isBerry &&
-        snapshot.resolution &&
-        // different registry would yield suffix following '::' which we don't need
-        snapshot.resolution.split('::')[0] !==
-            `${packageName}@npm:${snapshot.version}`) {
-        return snapshot.resolution.slice(packageName.length + 1);
-    }
-    if (!isBerry && snapshot.resolved && !isValidVersionRange(versionRange)) {
-        return snapshot.resolved;
-    }
-    // otherwise it's a standard version
-    return snapshot.version;
-}
-// check if value can be parsed as a semver range
-function isValidVersionRange(versionRange) {
-    try {
-        new semver_1.Range(versionRange);
-        return true;
-    }
-    catch (_a) {
-        return false;
-    }
+common.register('dirs', _dirs, {
+  wrapOutput: false,
+});
+common.register('pushd', _pushd, {
+  wrapOutput: false,
+});
+common.register('popd', _popd, {
+  wrapOutput: false,
+});
+
+// Pushd/popd/dirs internals
+var _dirStack = [];
+
+function _isStackIndex(index) {
+  return (/^[\-+]\d+$/).test(index);
 }
-function getHoistedVersion(packageName) {
-    const version = (0, package_json_1.getHoistedPackageVersion)(packageName);
-    if (version) {
-        return version;
+
+function _parseStackIndex(index) {
+  if (_isStackIndex(index)) {
+    if (Math.abs(index) < _dirStack.length + 1) { // +1 for pwd
+      return (/^-/).test(index) ? Number(index) - 1 : Number(index);
     }
+    common.error(index + ': directory stack index out of range');
+  } else {
+    common.error(index + ': invalid number');
+  }
 }
-function addDependencies(_a, builder, keyMap) {
-    var { __metadata } = _a, dependencies = tslib_1.__rest(_a, ["__metadata"]);
-    Object.keys(dependencies).forEach((keys) => {
-        const snapshot = dependencies[keys];
-        keys.split(', ').forEach((key) => {
-            if (keyMap.has(key)) {
-                const node = keyMap.get(key);
-                [snapshot.dependencies, snapshot.optionalDependencies].forEach((section) => {
-                    if (section) {
-                        Object.entries(section).forEach(([name, versionRange]) => {
-                            const target = keyMap.get(`${name}@npm:${versionRange}`) ||
-                                keyMap.get(`${name}@${versionRange}`);
-                            if (target) {
-                                builder.addStaticDependency(node.name, target.name);
-                            }
-                        });
-                    }
-                });
-            }
-        });
-    });
+
+function _actualDirStack() {
+  return [process.cwd()].concat(_dirStack);
 }
-function stringifyYarnLockfile(graph, rootLockFileContent, packageJson) {
-    const _a = (0, parsers_1.parseSyml)(rootLockFileContent), { __metadata } = _a, dependencies = tslib_1.__rest(_a, ["__metadata"]);
-    const isBerry = !!__metadata;
-    const snapshots = mapSnapshots(dependencies, graph.externalNodes, packageJson, isBerry);
-    if (isBerry) {
-        // add root workspace package
-        const workspacePackage = generateRootWorkspacePackage(packageJson);
-        snapshots[workspacePackage.resolution] = workspacePackage;
-        return (BERRY_LOCK_FILE_DISCLAIMER +
-            (0, parsers_1.stringifySyml)(Object.assign({ __metadata }, (0, object_sort_1.sortObjectByKeys)(snapshots))));
-    }
-    else {
-        return (0, lockfile_1.stringify)((0, object_sort_1.sortObjectByKeys)(snapshots));
-    }
-}
-exports.stringifyYarnLockfile = stringifyYarnLockfile;
-function groupDependencies(dependencies) {
-    let groupedDependencies;
-    const resolutionMap = new Map();
-    const snapshotMap = new Map();
-    Object.entries(dependencies).forEach(([key, snapshot]) => {
-        const resolutionKey = `${snapshot.resolved}${snapshot.integrity}`;
-        if (resolutionMap.has(resolutionKey)) {
-            const existingSnapshot = resolutionMap.get(resolutionKey);
-            snapshotMap.get(existingSnapshot).add(key);
-        }
-        else {
-            resolutionMap.set(resolutionKey, snapshot);
-            snapshotMap.set(snapshot, new Set([key]));
-        }
-    });
-    groupedDependencies = {};
-    snapshotMap.forEach((keys, snapshot) => {
-        groupedDependencies[Array.from(keys).join(', ')] = snapshot;
-    });
-    return groupedDependencies;
-}
-function addPackageVersion(packageName, version, collection, isBerry) {
-    if (!collection.has(packageName)) {
-        collection.set(packageName, new Set());
-    }
-    collection.get(packageName).add(`${packageName}@${version}`);
-    if (isBerry && !version.startsWith('npm:')) {
-        collection.get(packageName).add(`${packageName}@npm:${version}`);
-    }
-}
-function mapSnapshots(dependencies, nodes, packageJson, isBerry) {
-    // map snapshot to set of keys (e.g. `eslint@^7.0.0, eslint@npm:^7.0.0`)
-    const snapshotMap = new Map();
-    // track all existing dependencies's keys
-    const existingKeys = new Map();
-    const combinedDependencies = Object.assign(Object.assign(Object.assign(Object.assign({}, packageJson.dependencies), packageJson.devDependencies), packageJson.optionalDependencies), packageJson.peerDependencies);
-    let groupedDependencies;
-    if (isBerry) {
-        groupedDependencies = dependencies;
-    }
-    else {
-        // yarn classic splits keys when parsing so we need to stich them back together
-        groupedDependencies = groupDependencies(dependencies);
-    }
-    // collect snapshots and their matching keys
-    Object.values(nodes).forEach((node) => {
-        const foundOriginalKeys = findOriginalKeys(groupedDependencies, node);
-        if (!foundOriginalKeys) {
-            throw new Error(`Original key(s) not found for "${node.data.packageName}@${node.data.version}" while pruning yarn.lock.`);
-        }
-        const [matchedKeys, snapshot] = foundOriginalKeys;
-        snapshotMap.set(snapshot, new Set(matchedKeys));
-        // separately save keys that still exist
-        [snapshot.dependencies, snapshot.optionalDependencies].forEach((section) => {
-            Object.entries(section || {}).forEach(([name, versionSpec]) => addPackageVersion(name, versionSpec, existingKeys, isBerry));
-        });
-        // add package.json requested version to keys
-        const requestedVersion = getPackageJsonVersion(combinedDependencies, node);
-        if (requestedVersion) {
-            addPackageVersion(node.data.packageName, requestedVersion, existingKeys, isBerry);
-            const requestedKey = isBerry
-                ? reverseMapBerryKey(node, requestedVersion, snapshot)
-                : `${node.data.packageName}@${requestedVersion}`;
-            if (!snapshotMap.get(snapshot).has(requestedKey)) {
-                snapshotMap.get(snapshot).add(requestedKey);
-            }
-        }
-        if (isBerry) {
-            // look for patched versions
-            const patch = findPatchedKeys(groupedDependencies, node);
-            if (patch) {
-                const [matchedKeys, snapshot] = patch;
-                snapshotMap.set(snapshot, new Set(matchedKeys));
-            }
-        }
-    });
-    // remove keys that match version ranges that have been pruned away
-    snapshotMap.forEach((keysSet) => {
-        for (const key of keysSet.values()) {
-            const packageName = key.slice(0, key.indexOf('@', 1));
-            let normalizedKey = key;
-            if (isBerry && key.includes('@patch:') && key.includes('#')) {
-                normalizedKey = key
-                    .slice(0, key.indexOf('#'))
-                    .replace(`@patch:${packageName}@`, '@npm:');
-            }
-            if (!existingKeys.get(packageName).has(normalizedKey)) {
-                keysSet.delete(key);
-            }
-        }
-    });
-    // join mapped snapshots to lock json file
-    const result = {};
-    snapshotMap.forEach((keysSet, snapshot) => {
-        if (isBerry) {
-            result[Array.from(keysSet).sort().join(', ')] = snapshot;
-        }
-        else {
-            for (const key of keysSet.values()) {
-                result[key] = snapshot;
-            }
-        }
-    });
-    return result;
-}
-function reverseMapBerryKey(node, version, snapshot) {
-    // alias packages already have version
-    if (version.startsWith('npm:')) {
-        `${node.data.packageName}@${version}`;
-    }
-    // check for berry tarball packages
-    if (snapshot.resolution &&
-        snapshot.resolution === `${node.data.packageName}@${version}`) {
-        return snapshot.resolution;
-    }
-    return `${node.data.packageName}@npm:${version}`;
-}
-function getPackageJsonVersion(combinedDependencies, node) {
-    const { packageName, version } = node.data;
-    if (combinedDependencies[packageName]) {
-        if (combinedDependencies[packageName] === version ||
-            (0, semver_1.satisfies)(version, combinedDependencies[packageName])) {
-            return combinedDependencies[packageName];
-        }
-    }
-}
-function findOriginalKeys(dependencies, node) {
-    for (const keyExpr of Object.keys(dependencies)) {
-        const snapshot = dependencies[keyExpr];
-        const keys = keyExpr.split(', ');
-        if (!keys.some((k) => k.startsWith(`${node.data.packageName}@`))) {
-            continue;
-        }
-        // standard package
-        if (snapshot.version === node.data.version) {
-            return [keys, snapshot];
-        }
-        // berry alias package
-        if (snapshot.resolution &&
-            `npm:${snapshot.resolution}` === node.data.version) {
-            return [keys, snapshot];
-        }
-        // classic alias
-        if (node.data.version.startsWith('npm:') &&
-            keys.some((k) => k === `${node.data.packageName}@${node.data.version}`)) {
-            return [keys, snapshot];
-        }
-        // tarball package
-        if (snapshot.resolved === node.data.version ||
-            snapshot.resolution === `${node.data.packageName}@${node.data.version}`) {
-            return [keys, snapshot];
-        }
+
+//@
+//@ ### pushd([options,] [dir | '-N' | '+N'])
+//@
+//@ Available options:
+//@
+//@ + `-n`: Suppresses the normal change of directory when adding directories to the stack, so that only the stack is manipulated.
+//@ + `-q`: Supresses output to the console.
+//@
+//@ Arguments:
+//@
+//@ + `dir`: Sets the current working directory to the top of the stack, then executes the equivalent of `cd dir`.
+//@ + `+N`: Brings the Nth directory (counting from the left of the list printed by dirs, starting with zero) to the top of the list by rotating the stack.
+//@ + `-N`: Brings the Nth directory (counting from the right of the list printed by dirs, starting with zero) to the top of the list by rotating the stack.
+//@
+//@ Examples:
+//@
+//@ ```javascript
+//@ // process.cwd() === '/usr'
+//@ pushd('/etc'); // Returns /etc /usr
+//@ pushd('+1');   // Returns /usr /etc
+//@ ```
+//@
+//@ Save the current directory on the top of the directory stack and then `cd` to `dir`. With no arguments, `pushd` exchanges the top two directories. Returns an array of paths in the stack.
+function _pushd(options, dir) {
+  if (_isStackIndex(options)) {
+    dir = options;
+    options = '';
+  }
+
+  options = common.parseOptions(options, {
+    'n': 'no-cd',
+    'q': 'quiet',
+  });
+
+  var dirs = _actualDirStack();
+
+  if (dir === '+0') {
+    return dirs; // +0 is a noop
+  } else if (!dir) {
+    if (dirs.length > 1) {
+      dirs = dirs.splice(1, 1).concat(dirs);
+    } else {
+      return common.error('no other directory');
     }
-}
-function findPatchedKeys(dependencies, node) {
-    for (const keyExpr of Object.keys(dependencies)) {
-        const snapshot = dependencies[keyExpr];
-        const keys = keyExpr.split(', ');
-        if (!keys[0].startsWith(`${node.data.packageName}@patch:`)) {
-            continue;
-        }
-        if (snapshot.version === node.data.version) {
-            return [keys, snapshot];
-        }
+  } else if (_isStackIndex(dir)) {
+    var n = _parseStackIndex(dir);
+    dirs = dirs.slice(n).concat(dirs.slice(0, n));
+  } else {
+    if (options['no-cd']) {
+      dirs.splice(1, 0, dir);
+    } else {
+      dirs.unshift(dir);
     }
+  }
+
+  if (options['no-cd']) {
+    dirs = dirs.slice(1);
+  } else {
+    dir = path.resolve(dirs.shift());
+    _cd('', dir);
+  }
+
+  _dirStack = dirs;
+  return _dirs(options.quiet ? '-q' : '');
 }
-const BERRY_LOCK_FILE_DISCLAIMER = `# This file is generated by running "yarn install" inside your project.\n# Manual changes might be lost - proceed with caution!\n\n`;
-function generateRootWorkspacePackage(packageJson) {
-    return Object.assign(Object.assign(Object.assign(Object.assign(Object.assign({ version: '0.0.0-use.local', resolution: `${packageJson.name}@workspace:.` }, (packageJson.dependencies && { dependencies: packageJson.dependencies })), (packageJson.peerDependencies && {
-        peerDependencies: packageJson.peerDependencies,
-    })), (packageJson.devDependencies && {
-        devDependencies: packageJson.devDependencies,
-    })), (packageJson.optionalDependencies && {
-        optionalDependencies: packageJson.optionalDependencies,
-    })), { languageName: 'unknown', linkType: 'soft' });
-}
+exports.pushd = _pushd;
+
+//@
+//@
+//@ ### popd([options,] ['-N' | '+N'])
+//@
+//@ Available options:
+//@
+//@ + `-n`: Suppress the normal directory change when removing directories from the stack, so that only the stack is manipulated.
+//@ + `-q`: Supresses output to the console.
+//@
+//@ Arguments:
+//@
+//@ + `+N`: Removes the Nth directory (counting from the left of the list printed by dirs), starting with zero.
+//@ + `-N`: Removes the Nth directory (counting from the right of the list printed by dirs), starting with zero.
+//@
+//@ Examples:
+//@
+//@ ```javascript
+//@ echo(process.cwd()); // '/usr'
+//@ pushd('/etc');       // '/etc /usr'
+//@ echo(process.cwd()); // '/etc'
+//@ popd();              // '/usr'
+//@ echo(process.cwd()); // '/usr'
+//@ ```
+//@
+//@ When no arguments are given, `popd` removes the top directory from the stack and performs a `cd` to the new top directory. The elements are numbered from 0, starting at the first directory listed with dirs (i.e., `popd` is equivalent to `popd +0`). Returns an array of paths in the stack.
+function _popd(options, index) {
+  if (_isStackIndex(options)) {
+    index = options;
+    options = '';
+  }
 
+  options = common.parseOptions(options, {
+    'n': 'no-cd',
+    'q': 'quiet',
+  });
 
-/***/ }),
+  if (!_dirStack.length) {
+    return common.error('directory stack empty');
+  }
 
-/***/ 89977:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
+  index = _parseStackIndex(index || '+0');
 
-"use strict";
+  if (options['no-cd'] || index > 0 || _dirStack.length + index === 0) {
+    index = index > 0 ? index - 1 : index;
+    _dirStack.splice(index, 1);
+  } else {
+    var dir = path.resolve(_dirStack.shift());
+    _cd('', dir);
+  }
 
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.buildExplicitDependencies = void 0;
-const project_graph_1 = __nccwpck_require__(49899);
-const path_1 = __nccwpck_require__(71017);
-const build_explicit_typescript_and_package_json_dependencies_1 = __nccwpck_require__(91714);
-const os = __nccwpck_require__(22037);
-function buildExplicitDependencies(jsPluginConfig, ctx, builder) {
-    let totalNumOfFilesToProcess = totalNumberOfFilesToProcess(ctx);
-    if (totalNumOfFilesToProcess === 0)
-        return;
-    // using workers has an overhead, so we only do it when the number of
-    // files we need to process is >= 100 and there are more than 2 CPUs
-    // to be able to use at least 2 workers (1 worker per CPU and
-    // 1 CPU for the main thread)
-    if (jsPluginConfig.analyzeSourceFiles === false ||
-        totalNumOfFilesToProcess < 100 ||
-        getNumberOfWorkers() <= 2) {
-        return buildExplicitDependenciesWithoutWorkers(jsPluginConfig, ctx, builder);
-    }
-    else {
-        return buildExplicitDependenciesUsingWorkers(jsPluginConfig, ctx, totalNumOfFilesToProcess, builder);
-    }
-}
-exports.buildExplicitDependencies = buildExplicitDependencies;
-function totalNumberOfFilesToProcess(ctx) {
-    let totalNumOfFilesToProcess = 0;
-    Object.values(ctx.filesToProcess).forEach((t) => (totalNumOfFilesToProcess += t.length));
-    return totalNumOfFilesToProcess;
-}
-function splitFilesIntoBins(ctx, totalNumOfFilesToProcess, numberOfWorkers) {
-    // we want to have numberOfWorkers * 5 bins
-    const filesPerBin = Math.round(totalNumOfFilesToProcess / numberOfWorkers / 5) + 1;
-    const bins = [];
-    let currentProjectFileMap = {};
-    let currentNumberOfFiles = 0;
-    for (const source of Object.keys(ctx.filesToProcess)) {
-        for (const f of Object.values(ctx.filesToProcess[source])) {
-            if (!currentProjectFileMap[source])
-                currentProjectFileMap[source] = [];
-            currentProjectFileMap[source].push(f);
-            currentNumberOfFiles++;
-            if (currentNumberOfFiles >= filesPerBin) {
-                bins.push(currentProjectFileMap);
-                currentProjectFileMap = {};
-                currentNumberOfFiles = 0;
-            }
-        }
-    }
-    bins.push(currentProjectFileMap);
-    return bins;
-}
-function createWorkerPool(numberOfWorkers) {
-    const res = [];
-    for (let i = 0; i < numberOfWorkers; ++i) {
-        res.push(new ((__nccwpck_require__(71267).Worker))((0, path_1.join)(__dirname, './project-graph-worker.js'), {
-            env: process.env,
-        }));
-    }
-    return res;
-}
-function buildExplicitDependenciesWithoutWorkers(jsPluginConfig, ctx, builder) {
-    (0, build_explicit_typescript_and_package_json_dependencies_1.buildExplicitTypescriptAndPackageJsonDependencies)(jsPluginConfig, ctx.nxJsonConfiguration, ctx.projectsConfigurations, builder.graph, ctx.filesToProcess).forEach((r) => {
-        if (r.type === project_graph_1.DependencyType.static) {
-            builder.addStaticDependency(r.sourceProjectName, r.targetProjectName, r.sourceProjectFile);
-        }
-        else {
-            builder.addDynamicDependency(r.sourceProjectName, r.targetProjectName, r.sourceProjectFile);
-        }
-    });
-}
-function buildExplicitDependenciesUsingWorkers(jsPluginConfig, ctx, totalNumOfFilesToProcess, builder) {
-    const numberOfWorkers = Math.min(totalNumOfFilesToProcess, getNumberOfWorkers());
-    const bins = splitFilesIntoBins(ctx, totalNumOfFilesToProcess, numberOfWorkers);
-    const workers = createWorkerPool(numberOfWorkers);
-    let numberOfExpectedResponses = bins.length;
-    return new Promise((res, reject) => {
-        for (let w of workers) {
-            w.on('message', (explicitDependencies) => {
-                explicitDependencies.forEach((r) => {
-                    builder.addExplicitDependency(r.sourceProjectName, r.sourceProjectFile, r.targetProjectName);
-                });
-                if (bins.length > 0) {
-                    w.postMessage({ filesToProcess: bins.shift() });
-                }
-                // we processed all the bins
-                if (--numberOfExpectedResponses === 0) {
-                    for (let w of workers) {
-                        w.terminate();
-                    }
-                    res(null);
-                }
-            });
-            w.on('error', reject);
-            w.on('exit', (code) => {
-                if (code !== 0) {
-                    reject(new Error(`Unable to complete project graph creation. Worker stopped with exit code: ${code}`));
-                }
-            });
-            w.postMessage({
-                nxJsonConfiguration: ctx.nxJsonConfiguration,
-                projectsConfigurations: ctx.projectsConfigurations,
-                projectGraph: builder.graph,
-                jsPluginConfig,
-            });
-            w.postMessage({ filesToProcess: bins.shift() });
-        }
-    });
-}
-function getNumberOfWorkers() {
-    return process.env.NX_PROJECT_GRAPH_MAX_WORKERS
-        ? +process.env.NX_PROJECT_GRAPH_MAX_WORKERS
-        : Math.min(os.cpus().length - 1, 8); // This is capped for cases in CI where `os.cpus()` returns way more CPUs than the resources that are allocated
+  return _dirs(options.quiet ? '-q' : '');
 }
+exports.popd = _popd;
+
+//@
+//@
+//@ ### dirs([options | '+N' | '-N'])
+//@
+//@ Available options:
+//@
+//@ + `-c`: Clears the directory stack by deleting all of the elements.
+//@ + `-q`: Supresses output to the console.
+//@
+//@ Arguments:
+//@
+//@ + `+N`: Displays the Nth directory (counting from the left of the list printed by dirs when invoked without options), starting with zero.
+//@ + `-N`: Displays the Nth directory (counting from the right of the list printed by dirs when invoked without options), starting with zero.
+//@
+//@ Display the list of currently remembered directories. Returns an array of paths in the stack, or a single path if `+N` or `-N` was specified.
+//@
+//@ See also: `pushd`, `popd`
+function _dirs(options, index) {
+  if (_isStackIndex(options)) {
+    index = options;
+    options = '';
+  }
 
+  options = common.parseOptions(options, {
+    'c': 'clear',
+    'q': 'quiet',
+  });
 
-/***/ }),
+  if (options.clear) {
+    _dirStack = [];
+    return _dirStack;
+  }
 
-/***/ 91714:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
+  var stack = _actualDirStack();
 
-"use strict";
+  if (index) {
+    index = _parseStackIndex(index);
 
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.buildExplicitTypescriptAndPackageJsonDependencies = void 0;
-const explicit_project_dependencies_1 = __nccwpck_require__(24718);
-const explicit_package_json_dependencies_1 = __nccwpck_require__(21054);
-function buildExplicitTypescriptAndPackageJsonDependencies(jsPluginConfig, nxJsonConfiguration, projectsConfigurations, projectGraph, filesToProcess) {
-    let res = [];
-    if (jsPluginConfig.analyzeSourceFiles === undefined ||
-        jsPluginConfig.analyzeSourceFiles === true) {
-        let tsExists = false;
-        try {
-            __nccwpck_require__.ab + "typescript.js"
-            tsExists = true;
-        }
-        catch (_a) { }
-        if (tsExists) {
-            res = res.concat((0, explicit_project_dependencies_1.buildExplicitTypeScriptDependencies)(projectGraph, filesToProcess));
-        }
+    if (index < 0) {
+      index = stack.length + index;
     }
-    if (jsPluginConfig.analyzePackageJson === undefined ||
-        jsPluginConfig.analyzePackageJson === true) {
-        res = res.concat((0, explicit_package_json_dependencies_1.buildExplicitPackageJsonDependencies)(nxJsonConfiguration, projectsConfigurations, projectGraph, filesToProcess));
+
+    if (!options.quiet) {
+      common.log(stack[index]);
     }
-    return res;
+    return stack[index];
+  }
+
+  if (!options.quiet) {
+    common.log(stack.join(' '));
+  }
+
+  return stack;
 }
-exports.buildExplicitTypescriptAndPackageJsonDependencies = buildExplicitTypescriptAndPackageJsonDependencies;
+exports.dirs = _dirs;
 
 
 /***/ }),
 
-/***/ 21054:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
+/***/ 60607:
+/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
-"use strict";
+var format = (__nccwpck_require__(73837).format);
 
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.buildExplicitPackageJsonDependencies = void 0;
-const file_utils_1 = __nccwpck_require__(93155);
-const path_1 = __nccwpck_require__(71017);
-const project_graph_1 = __nccwpck_require__(49899);
-const json_1 = __nccwpck_require__(43684);
-const path_2 = __nccwpck_require__(75878);
-function buildExplicitPackageJsonDependencies(nxJsonConfiguration, projectsConfigurations, graph, filesToProcess) {
-    const res = [];
-    let packageNameMap = undefined;
-    const nodes = Object.values(graph.nodes);
-    Object.keys(filesToProcess).forEach((source) => {
-        Object.values(filesToProcess[source]).forEach((f) => {
-            if (isPackageJsonAtProjectRoot(nodes, f.file)) {
-                // we only create the package name map once and only if a package.json file changes
-                packageNameMap =
-                    packageNameMap ||
-                        createPackageNameMap(nxJsonConfiguration, projectsConfigurations);
-                processPackageJson(source, f.file, graph, res, packageNameMap);
-            }
-        });
+var common = __nccwpck_require__(60624);
+
+common.register('echo', _echo, {
+  allowGlobbing: false,
+});
+
+//@
+//@ ### echo([options,] string [, string ...])
+//@
+//@ Available options:
+//@
+//@ + `-e`: interpret backslash escapes (default)
+//@ + `-n`: remove trailing newline from output
+//@
+//@ Examples:
+//@
+//@ ```javascript
+//@ echo('hello world');
+//@ var str = echo('hello world');
+//@ echo('-n', 'no newline at end');
+//@ ```
+//@
+//@ Prints `string` to stdout, and returns string with additional utility methods
+//@ like `.to()`.
+function _echo(opts) {
+  // allow strings starting with '-', see issue #20
+  var messages = [].slice.call(arguments, opts ? 0 : 1);
+  var options = {};
+
+  // If the first argument starts with '-', parse it as options string.
+  // If parseOptions throws, it wasn't an options string.
+  try {
+    options = common.parseOptions(messages[0], {
+      'e': 'escapes',
+      'n': 'no_newline',
+    }, {
+      silent: true,
     });
-    return res;
-}
-exports.buildExplicitPackageJsonDependencies = buildExplicitPackageJsonDependencies;
-function createPackageNameMap(nxJsonConfiguration, projectsConfigurations) {
-    var _a;
-    const res = {};
-    for (let projectName of Object.keys(projectsConfigurations.projects)) {
-        try {
-            const packageJson = (0, json_1.parseJson)((0, file_utils_1.defaultFileRead)((0, path_1.join)(projectsConfigurations.projects[projectName].root, 'package.json')));
-            // TODO(v17): Stop reading nx.json for the npmScope
-            const npmScope = nxJsonConfiguration.npmScope;
-            res[(_a = packageJson.name) !== null && _a !== void 0 ? _a : (npmScope
-                ? `${npmScope === '@' ? '' : '@'}${npmScope}/${projectName}`
-                : projectName)] = projectName;
-        }
-        catch (e) { }
-    }
-    return res;
-}
-function isPackageJsonAtProjectRoot(nodes, fileName) {
-    return (fileName.endsWith('package.json') &&
-        nodes.find((projectNode) => (projectNode.type === 'lib' || projectNode.type === 'app') &&
-            (0, path_2.joinPathFragments)(projectNode.data.root, 'package.json') === fileName));
-}
-function processPackageJson(sourceProject, fileName, graph, collectedDeps, packageNameMap) {
-    try {
-        const deps = readDeps((0, json_1.parseJson)((0, file_utils_1.defaultFileRead)(fileName)));
-        // the name matches the import path
-        deps.forEach((d) => {
-            // package.json refers to another project in the monorepo
-            if (packageNameMap[d]) {
-                collectedDeps.push({
-                    sourceProjectName: sourceProject,
-                    targetProjectName: packageNameMap[d],
-                    sourceProjectFile: fileName,
-                    type: project_graph_1.DependencyType.static,
-                });
-            }
-            else if (graph.externalNodes[`npm:${d}`]) {
-                collectedDeps.push({
-                    sourceProjectName: sourceProject,
-                    targetProjectName: `npm:${d}`,
-                    sourceProjectFile: fileName,
-                    type: project_graph_1.DependencyType.static,
-                });
-            }
-        });
-    }
-    catch (e) {
-        if (process.env.NX_VERBOSE_LOGGING === 'true') {
-            console.log(e);
-        }
-    }
-}
-function readDeps(packageJson) {
-    var _a, _b, _c, _d;
-    return [
-        ...Object.keys((_a = packageJson === null || packageJson === void 0 ? void 0 : packageJson.dependencies) !== null && _a !== void 0 ? _a : {}),
-        ...Object.keys((_b = packageJson === null || packageJson === void 0 ? void 0 : packageJson.devDependencies) !== null && _b !== void 0 ? _b : {}),
-        ...Object.keys((_c = packageJson === null || packageJson === void 0 ? void 0 : packageJson.peerDependencies) !== null && _c !== void 0 ? _c : {}),
-        ...Object.keys((_d = packageJson === null || packageJson === void 0 ? void 0 : packageJson.optionalDependencies) !== null && _d !== void 0 ? _d : {}),
-    ];
-}
 
+    // Allow null to be echoed
+    if (messages[0]) {
+      messages.shift();
+    }
+  } catch (_) {
+    // Clear out error if an error occurred
+    common.state.error = null;
+  }
 
-/***/ }),
+  var output = format.apply(null, messages);
 
-/***/ 24718:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
+  // Add newline if -n is not passed.
+  if (!options.no_newline) {
+    output += '\n';
+  }
 
-"use strict";
+  process.stdout.write(output);
 
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.buildExplicitTypeScriptDependencies = void 0;
-const typescript_import_locator_1 = __nccwpck_require__(40234);
-const target_project_locator_1 = __nccwpck_require__(99113);
-function buildExplicitTypeScriptDependencies(graph, filesToProcess) {
-    function isRoot(projectName) {
-        var _a, _b;
-        return ((_b = (_a = graph.nodes[projectName]) === null || _a === void 0 ? void 0 : _a.data) === null || _b === void 0 ? void 0 : _b.root) === '.';
-    }
-    const importLocator = new typescript_import_locator_1.TypeScriptImportLocator();
-    const targetProjectLocator = new target_project_locator_1.TargetProjectLocator(graph.nodes, graph.externalNodes);
-    const res = [];
-    Object.keys(filesToProcess).forEach((source) => {
-        Object.values(filesToProcess[source]).forEach((f) => {
-            importLocator.fromFile(f.file, (importExpr, filePath, type) => {
-                const target = targetProjectLocator.findProjectWithImport(importExpr, f.file);
-                let targetProjectName;
-                if (target) {
-                    if (!isRoot(source) && isRoot(target)) {
-                        // TODO: These edges technically should be allowed but we need to figure out how to separate config files out from root
-                        return;
-                    }
-                    targetProjectName = target;
-                }
-                else {
-                    // treat all unknowns as npm packages, they can be eiher
-                    // - mistyped local import, which has to be fixed manually
-                    // - node internals, which should still be tracked as a dependency
-                    // - npm packages, which are not yet installed but should be tracked
-                    targetProjectName = `npm:${importExpr}`;
-                }
-                res.push({
-                    sourceProjectName: source,
-                    targetProjectName,
-                    sourceProjectFile: f.file,
-                    type,
-                });
-            });
-        });
-    });
-    return res;
+  return output;
 }
-exports.buildExplicitTypeScriptDependencies = buildExplicitTypeScriptDependencies;
+
+module.exports = _echo;
 
 
 /***/ }),
 
-/***/ 84447:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
+/***/ 66829:
+/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
-"use strict";
+var common = __nccwpck_require__(60624);
 
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.stripSourceCode = void 0;
-let SyntaxKind;
-function shouldRescanSlashToken(lastNonTriviaToken) {
-    switch (lastNonTriviaToken) {
-        case SyntaxKind.Identifier:
-        case SyntaxKind.StringLiteral:
-        case SyntaxKind.NumericLiteral:
-        case SyntaxKind.BigIntLiteral:
-        case SyntaxKind.RegularExpressionLiteral:
-        case SyntaxKind.ThisKeyword:
-        case SyntaxKind.PlusPlusToken:
-        case SyntaxKind.MinusMinusToken:
-        case SyntaxKind.CloseParenToken:
-        case SyntaxKind.CloseBracketToken:
-        case SyntaxKind.CloseBraceToken:
-        case SyntaxKind.TrueKeyword:
-        case SyntaxKind.FalseKeyword:
-            return false;
-        default:
-            return true;
-    }
-}
-function stripSourceCode(scanner, contents) {
-    if (!SyntaxKind) {
-        SyntaxKind = (__nccwpck_require__(70048).SyntaxKind);
-    }
-    if (contents.indexOf('loadChildren') > -1) {
-        return contents;
-    }
-    scanner.setText(contents);
-    let token = scanner.scan();
-    let lastNonTriviaToken = SyntaxKind.Unknown;
-    const statements = [];
-    const templateStack = [];
-    let ignoringLine = false;
-    let braceDepth = 0;
-    let start = null;
-    while (token !== SyntaxKind.EndOfFileToken) {
-        const currentToken = token;
-        const potentialStart = scanner.getStartPos();
-        switch (token) {
-            case SyntaxKind.MultiLineCommentTrivia:
-            case SyntaxKind.SingleLineCommentTrivia: {
-                const isMultiLineCommentTrivia = token === SyntaxKind.MultiLineCommentTrivia;
-                const start = potentialStart + 2;
-                token = scanner.scan();
-                const end = scanner.getStartPos() - (isMultiLineCommentTrivia ? 2 : 0);
-                const comment = contents.substring(start, end).trim();
-                if (comment === 'nx-ignore-next-line') {
-                    // reading till the end of the line
-                    while (token === SyntaxKind.WhitespaceTrivia ||
-                        token === SyntaxKind.NewLineTrivia) {
-                        token = scanner.scan();
-                    }
-                    ignoringLine = true;
-                }
-                break;
-            }
-            case SyntaxKind.NewLineTrivia: {
-                ignoringLine = false;
-                token = scanner.scan();
-                break;
-            }
-            case SyntaxKind.RequireKeyword:
-            case SyntaxKind.ImportKeyword: {
-                token = scanner.scan();
-                if (ignoringLine) {
-                    break;
-                }
-                while (token === SyntaxKind.WhitespaceTrivia ||
-                    token === SyntaxKind.NewLineTrivia) {
-                    token = scanner.scan();
-                }
-                start = potentialStart;
-                break;
-            }
-            case SyntaxKind.TemplateHead: {
-                templateStack.push(braceDepth);
-                braceDepth = 0;
-                token = scanner.scan();
-                break;
-            }
-            case SyntaxKind.SlashToken: {
-                if (shouldRescanSlashToken(lastNonTriviaToken)) {
-                    token = scanner.reScanSlashToken();
-                }
-                token = scanner.scan();
-                break;
-            }
-            case SyntaxKind.OpenBraceToken: {
-                ++braceDepth;
-                token = scanner.scan();
-                break;
-            }
-            case SyntaxKind.CloseBraceToken: {
-                if (braceDepth) {
-                    --braceDepth;
-                }
-                else if (templateStack.length) {
-                    token = scanner.reScanTemplateToken(false);
-                    if (token === SyntaxKind.LastTemplateToken) {
-                        braceDepth = templateStack.pop();
-                    }
-                }
-                token = scanner.scan();
-                break;
-            }
-            case SyntaxKind.ExportKeyword: {
-                token = scanner.scan();
-                if (ignoringLine) {
-                    break;
-                }
-                while (token === SyntaxKind.WhitespaceTrivia ||
-                    token === SyntaxKind.NewLineTrivia) {
-                    token = scanner.scan();
-                }
-                if (token === SyntaxKind.OpenBraceToken ||
-                    token === SyntaxKind.AsteriskToken ||
-                    token === SyntaxKind.TypeKeyword) {
-                    start = potentialStart;
-                }
-                break;
-            }
-            case SyntaxKind.StringLiteral: {
-                if (start !== null) {
-                    token = scanner.scan();
-                    if (token === SyntaxKind.CloseParenToken) {
-                        token = scanner.scan();
-                    }
-                    const end = scanner.getStartPos();
-                    statements.push(contents.substring(start, end));
-                    start = null;
-                }
-                else {
-                    token = scanner.scan();
-                }
-                break;
-            }
-            default: {
-                token = scanner.scan();
-            }
-        }
-        if (currentToken > SyntaxKind.LastTriviaToken) {
-            lastNonTriviaToken = currentToken;
-        }
-    }
-    return statements.join('\n');
+//@
+//@ ### error()
+//@
+//@ Tests if error occurred in the last command. Returns a truthy value if an
+//@ error returned, or a falsy value otherwise.
+//@
+//@ **Note**: do not rely on the
+//@ return value to be an error message. If you need the last error message, use
+//@ the `.stderr` attribute from the last command's return value instead.
+function error() {
+  return common.state.error;
 }
-exports.stripSourceCode = stripSourceCode;
+module.exports = error;
 
 
 /***/ }),
 
-/***/ 99113:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
-
-"use strict";
+/***/ 148:
+/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.TargetProjectLocator = void 0;
-const typescript_1 = __nccwpck_require__(62029);
-const fileutils_1 = __nccwpck_require__(47930);
-const path_1 = __nccwpck_require__(71017);
-const workspace_root_1 = __nccwpck_require__(65766);
-const module_1 = __nccwpck_require__(98188);
-const find_project_for_path_1 = __nccwpck_require__(36265);
-const builtInModuleSet = new Set([
-    ...module_1.builtinModules,
-    ...module_1.builtinModules.map((x) => `node:${x}`),
-]);
-class TargetProjectLocator {
-    constructor(nodes, externalNodes) {
-        var _a, _b;
-        this.nodes = nodes;
-        this.externalNodes = externalNodes;
-        this.projectRootMappings = (0, find_project_for_path_1.createProjectRootMappings)(this.nodes);
-        this.npmProjects = filterRootExternalDependencies(this.externalNodes);
-        this.tsConfig = this.getRootTsConfig();
-        this.paths = (_b = (_a = this.tsConfig.config) === null || _a === void 0 ? void 0 : _a.compilerOptions) === null || _b === void 0 ? void 0 : _b.paths;
-        this.typescriptResolutionCache = new Map();
-        this.npmResolutionCache = new Map();
-    }
-    /**
-     * Find a project based on its import
-     *
-     * @param importExpr
-     * @param filePath
-     */
-    findProjectWithImport(importExpr, filePath) {
-        const normalizedImportExpr = importExpr.split('#')[0];
-        if ((0, fileutils_1.isRelativePath)(normalizedImportExpr)) {
-            const resolvedModule = path_1.posix.join((0, path_1.dirname)(filePath), normalizedImportExpr);
-            return this.findProjectOfResolvedModule(resolvedModule);
-        }
-        // find project using tsconfig paths
-        const paths = this.findPaths(normalizedImportExpr);
-        if (paths) {
-            for (let p of paths) {
-                const maybeResolvedProject = this.findProjectOfResolvedModule(p);
-                if (maybeResolvedProject) {
-                    return maybeResolvedProject;
-                }
-            }
-        }
-        // try to find npm package before using expensive typescript resolution
-        const npmProject = this.findNpmPackage(normalizedImportExpr);
-        if (npmProject) {
-            return npmProject;
-        }
-        if (this.tsConfig.config) {
-            // TODO(meeroslav): this block is probably obsolete
-            // and existed only because of the incomplete `paths` matching
-            // if import cannot be matched using tsconfig `paths` the compilation would fail anyway
-            const resolvedProject = this.resolveImportWithTypescript(normalizedImportExpr, filePath);
-            if (resolvedProject) {
-                return resolvedProject;
-            }
-        }
-        if (builtInModuleSet.has(normalizedImportExpr)) {
-            this.npmResolutionCache.set(normalizedImportExpr, null);
-            return null;
-        }
-        try {
-            const resolvedModule = this.resolveImportWithRequire(normalizedImportExpr, filePath);
-            return this.findProjectOfResolvedModule(resolvedModule);
-        }
-        catch (_a) { }
-        // nothing found, cache for later
-        this.npmResolutionCache.set(normalizedImportExpr, null);
-        return null;
-    }
-    /**
-     * Return file paths matching the import relative to the repo root
-     * @param normalizedImportExpr
-     * @returns
-     */
-    findPaths(normalizedImportExpr) {
-        if (!this.paths) {
-            return undefined;
-        }
-        if (this.paths[normalizedImportExpr]) {
-            return this.paths[normalizedImportExpr];
-        }
-        const wildcardPath = Object.keys(this.paths).find((path) => path.endsWith('/*') &&
-            (normalizedImportExpr.startsWith(path.replace(/\*$/, '')) ||
-                normalizedImportExpr === path.replace(/\/\*$/, '')));
-        if (wildcardPath) {
-            return this.paths[wildcardPath];
-        }
-        return undefined;
-    }
-    resolveImportWithTypescript(normalizedImportExpr, filePath) {
-        let resolvedModule;
-        if (this.typescriptResolutionCache.has(normalizedImportExpr)) {
-            resolvedModule = this.typescriptResolutionCache.get(normalizedImportExpr);
-        }
-        else {
-            resolvedModule = (0, typescript_1.resolveModuleByImport)(normalizedImportExpr, filePath, this.tsConfig.absolutePath);
-            this.typescriptResolutionCache.set(normalizedImportExpr, resolvedModule ? resolvedModule : null);
-        }
-        // TODO: vsavkin temporary workaround. Remove it once we reworking handling of npm packages.
-        if (resolvedModule && resolvedModule.indexOf('node_modules/') === -1) {
-            const resolvedProject = this.findProjectOfResolvedModule(resolvedModule);
-            if (resolvedProject) {
-                return resolvedProject;
-            }
-        }
-        return;
-    }
-    resolveImportWithRequire(normalizedImportExpr, filePath) {
-        return path_1.posix.relative(workspace_root_1.workspaceRoot, require.resolve(normalizedImportExpr, {
-            paths: [(0, path_1.dirname)(filePath)],
-        }));
-    }
-    findNpmPackage(npmImport) {
-        if (this.npmResolutionCache.has(npmImport)) {
-            return this.npmResolutionCache.get(npmImport);
-        }
-        else {
-            const pkg = this.npmProjects.find((pkg) => npmImport === pkg.data.packageName ||
-                npmImport.startsWith(`${pkg.data.packageName}/`));
-            if (pkg) {
-                this.npmResolutionCache.set(npmImport, pkg.name);
-                return pkg.name;
-            }
-        }
-    }
-    findProjectOfResolvedModule(resolvedModule) {
-        if (resolvedModule.startsWith('node_modules/'))
-            return undefined;
-        const normalizedResolvedModule = resolvedModule.startsWith('./')
-            ? resolvedModule.substring(2)
-            : resolvedModule;
-        const importedProject = this.findMatchingProjectFiles(normalizedResolvedModule);
-        return importedProject ? importedProject.name : void 0;
-    }
-    getAbsolutePath(path) {
-        return (0, path_1.join)(workspace_root_1.workspaceRoot, path);
-    }
-    getRootTsConfig() {
-        const path = (0, typescript_1.getRootTsConfigFileName)();
-        if (!path) {
-            return {
-                path: null,
-                absolutePath: null,
-                config: null,
-            };
-        }
-        const absolutePath = this.getAbsolutePath(path);
-        return {
-            absolutePath,
-            path,
-            config: (0, fileutils_1.readJsonFile)(absolutePath),
-        };
-    }
-    findMatchingProjectFiles(file) {
-        const project = (0, find_project_for_path_1.findProjectForPath)(file, this.projectRootMappings);
-        return this.nodes[project];
-    }
-}
-exports.TargetProjectLocator = TargetProjectLocator;
-// matches `npm:@scope/name`, `npm:name` but not `npm:@scope/name@version` and `npm:name@version`
-const ROOT_VERSION_PACKAGE_NAME_REGEX = /^npm:(?!.+@.+)/;
-function filterRootExternalDependencies(externalNodes) {
-    if (!externalNodes) {
-        return [];
-    }
-    const keys = Object.keys(externalNodes);
-    const nodes = [];
-    for (let i = 0; i < keys.length; i++) {
-        if (keys[i].match(ROOT_VERSION_PACKAGE_NAME_REGEX)) {
-            nodes.push(externalNodes[keys[i]]);
-        }
-    }
-    return nodes;
+/* module decorator */ module = __nccwpck_require__.nmd(module);
+if (require.main !== module) {
+  throw new Error('This file should not be required');
 }
 
+var childProcess = __nccwpck_require__(32081);
+var fs = __nccwpck_require__(57147);
 
-/***/ }),
+var paramFilePath = process.argv[2];
 
-/***/ 40234:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
+var serializedParams = fs.readFileSync(paramFilePath, 'utf8');
+var params = JSON.parse(serializedParams);
 
-"use strict";
+var cmd = params.command;
+var execOptions = params.execOptions;
+var pipe = params.pipe;
+var stdoutFile = params.stdoutFile;
+var stderrFile = params.stderrFile;
 
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.TypeScriptImportLocator = void 0;
-const path = __nccwpck_require__(71017);
-const strip_source_code_1 = __nccwpck_require__(84447);
-const project_graph_1 = __nccwpck_require__(49899);
-const file_utils_1 = __nccwpck_require__(93155);
-let tsModule;
-class TypeScriptImportLocator {
-    constructor() {
-        tsModule = __nccwpck_require__(70048);
-        this.scanner = tsModule.createScanner(tsModule.ScriptTarget.Latest, false);
-    }
-    fromFile(filePath, visitor) {
-        const extension = path.extname(filePath);
-        if (extension !== '.ts' &&
-            extension !== '.mts' &&
-            extension !== '.tsx' &&
-            extension !== '.js' &&
-            extension !== '.mjs' &&
-            extension !== '.jsx') {
-            return;
-        }
-        const content = (0, file_utils_1.defaultFileRead)(filePath);
-        const strippedContent = (0, strip_source_code_1.stripSourceCode)(this.scanner, content);
-        if (strippedContent !== '') {
-            const tsFile = tsModule.createSourceFile(filePath, strippedContent, tsModule.ScriptTarget.Latest, true);
-            this.fromNode(filePath, tsFile, visitor);
-        }
-    }
-    fromNode(filePath, node, visitor) {
-        if (tsModule.isImportDeclaration(node) ||
-            (tsModule.isExportDeclaration(node) && node.moduleSpecifier)) {
-            if (!this.ignoreStatement(node)) {
-                const imp = this.getStringLiteralValue(node.moduleSpecifier);
-                visitor(imp, filePath, project_graph_1.DependencyType.static);
-            }
-            return; // stop traversing downwards
-        }
-        if (tsModule.isCallExpression(node) &&
-            node.expression.kind === tsModule.SyntaxKind.ImportKeyword &&
-            node.arguments.length === 1 &&
-            tsModule.isStringLiteral(node.arguments[0])) {
-            if (!this.ignoreStatement(node)) {
-                const imp = this.getStringLiteralValue(node.arguments[0]);
-                visitor(imp, filePath, project_graph_1.DependencyType.dynamic);
-            }
-            return;
-        }
-        if (tsModule.isCallExpression(node) &&
-            node.expression.getText() === 'require' &&
-            node.arguments.length === 1 &&
-            tsModule.isStringLiteral(node.arguments[0])) {
-            if (!this.ignoreStatement(node)) {
-                const imp = this.getStringLiteralValue(node.arguments[0]);
-                visitor(imp, filePath, project_graph_1.DependencyType.static);
-            }
-            return;
-        }
-        if (node.kind === tsModule.SyntaxKind.PropertyAssignment) {
-            const name = this.getPropertyAssignmentName(node.name);
-            if (name === 'loadChildren') {
-                const init = node.initializer;
-                if (init.kind === tsModule.SyntaxKind.StringLiteral &&
-                    !this.ignoreLoadChildrenDependency(node.getFullText())) {
-                    const childrenExpr = this.getStringLiteralValue(init);
-                    visitor(childrenExpr, filePath, project_graph_1.DependencyType.dynamic);
-                    return; // stop traversing downwards
-                }
-            }
-        }
-        /**
-         * Continue traversing down the AST from the current node
-         */
-        tsModule.forEachChild(node, (child) => this.fromNode(filePath, child, visitor));
-    }
-    ignoreStatement(node) {
-        return (0, strip_source_code_1.stripSourceCode)(this.scanner, node.getFullText()) === '';
-    }
-    ignoreLoadChildrenDependency(contents) {
-        this.scanner.setText(contents);
-        let token = this.scanner.scan();
-        while (token !== tsModule.SyntaxKind.EndOfFileToken) {
-            if (token === tsModule.SyntaxKind.SingleLineCommentTrivia ||
-                token === tsModule.SyntaxKind.MultiLineCommentTrivia) {
-                const start = this.scanner.getStartPos() + 2;
-                token = this.scanner.scan();
-                const isMultiLineCommentTrivia = token === tsModule.SyntaxKind.MultiLineCommentTrivia;
-                const end = this.scanner.getStartPos() - (isMultiLineCommentTrivia ? 2 : 0);
-                const comment = contents.substring(start, end).trim();
-                if (comment === 'nx-ignore-next-line') {
-                    return true;
-                }
-            }
-            else {
-                token = this.scanner.scan();
-            }
-        }
-        return false;
-    }
-    getPropertyAssignmentName(nameNode) {
-        switch (nameNode.kind) {
-            case tsModule.SyntaxKind.Identifier:
-                return nameNode.getText();
-            case tsModule.SyntaxKind.StringLiteral:
-                return nameNode.text;
-            default:
-                return null;
-        }
-    }
-    getStringLiteralValue(node) {
-        return node.getText().slice(1, -1);
-    }
+var c = childProcess.exec(cmd, execOptions, function (err) {
+  if (!err) {
+    process.exitCode = 0;
+  } else if (err.code === undefined) {
+    process.exitCode = 1;
+  } else {
+    process.exitCode = err.code;
+  }
+});
+
+var stdoutStream = fs.createWriteStream(stdoutFile);
+var stderrStream = fs.createWriteStream(stderrFile);
+
+c.stdout.pipe(stdoutStream);
+c.stderr.pipe(stderrStream);
+c.stdout.pipe(process.stdout);
+c.stderr.pipe(process.stderr);
+
+if (pipe) {
+  c.stdin.end(pipe);
 }
-exports.TypeScriptImportLocator = TypeScriptImportLocator;
 
 
 /***/ }),
 
-/***/ 16354:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
+/***/ 25239:
+/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
-"use strict";
+var common = __nccwpck_require__(60624);
+var _tempDir = (__nccwpck_require__(68691).tempDir);
+var _pwd = __nccwpck_require__(90909);
+var path = __nccwpck_require__(71017);
+var fs = __nccwpck_require__(57147);
+var child = __nccwpck_require__(32081);
 
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.getTsNodeCompilerOptions = exports.registerTsConfigPaths = exports.registerTranspiler = exports.getTranspiler = exports.getTsNodeTranspiler = exports.getSwcTranspiler = exports.registerTsProject = void 0;
-const path_1 = __nccwpck_require__(71017);
-const logger_1 = __nccwpck_require__(95324);
-const swcNodeInstalled = packageIsInstalled('@swc-node/register');
-const tsNodeInstalled = packageIsInstalled('ts-node/register');
-let ts;
-/**
- * Optionally, if swc-node and tsconfig-paths are available in the current workspace, apply the require
- * register hooks so that .ts files can be used for writing custom workspace projects.
- *
- * If ts-node and tsconfig-paths are not available, the user can still provide an index.js file in
- * the root of their project and the fundamentals will still work (but
- * workspace path mapping will not, for example).
- *
- * @returns cleanup function
- */
-const registerTsProject = (path, configFilename = 'tsconfig.json') => {
-    const tsConfigPath = (0, path_1.join)(path, configFilename);
-    const compilerOptions = readCompilerOptions(tsConfigPath);
-    const cleanupFunctions = [
-        registerTsConfigPaths(tsConfigPath),
-        registerTranspiler(compilerOptions),
-    ];
-    return () => {
-        for (const fn of cleanupFunctions) {
-            fn();
-        }
-    };
-};
-exports.registerTsProject = registerTsProject;
-function getSwcTranspiler(compilerOptions) {
-    // These are requires to prevent it from registering when it shouldn't
-    const register = (__nccwpck_require__(61856).register);
-    const cleanupFn = register(compilerOptions);
-    return typeof cleanupFn === 'function' ? cleanupFn : () => { };
-}
-exports.getSwcTranspiler = getSwcTranspiler;
-function getTsNodeTranspiler(compilerOptions) {
-    const { register } = __nccwpck_require__(51351);
-    // ts-node doesn't provide a cleanup method
-    const service = register({
-        transpileOnly: true,
-        compilerOptions: getTsNodeCompilerOptions(compilerOptions),
-    });
-    const { transpiler, swc } = service.options;
-    // Don't warn if a faster transpiler is enabled
-    if (!transpiler && !swc) {
-        warnTsNodeUsage();
-    }
-    return () => { };
-}
-exports.getTsNodeTranspiler = getTsNodeTranspiler;
-function getTranspiler(compilerOptions) {
-    const preferTsNode = process.env.NX_PREFER_TS_NODE === 'true';
-    if (swcNodeInstalled && !preferTsNode) {
-        return () => getSwcTranspiler(compilerOptions);
-    }
-    // We can fall back on ts-node if it's available
-    if (tsNodeInstalled) {
-        return () => getTsNodeTranspiler(compilerOptions);
-    }
-}
-exports.getTranspiler = getTranspiler;
-/**
- * Register ts-node or swc-node given a set of compiler options.
- *
- * Note: Several options require enums from typescript. To avoid importing typescript,
- * use import type + raw values
- *
- * @returns cleanup method
- */
-function registerTranspiler(compilerOptions) {
-    // Function to register transpiler that returns cleanup function
-    const transpiler = getTranspiler(compilerOptions);
-    if (!transpiler) {
-        warnNoTranspiler();
-        return () => { };
-    }
-    return transpiler();
-}
-exports.registerTranspiler = registerTranspiler;
-/**
- * @param tsConfigPath Adds the paths from a tsconfig file into node resolutions
- * @returns cleanup function
- */
-function registerTsConfigPaths(tsConfigPath) {
-    try {
-        /**
-         * Load the ts config from the source project
-         */
-        const tsconfigPaths = __nccwpck_require__(10839);
-        const tsConfigResult = tsconfigPaths.loadConfig(tsConfigPath);
-        /**
-         * Register the custom workspace path mappings with node so that workspace libraries
-         * can be imported and used within project
-         */
-        if (tsConfigResult.resultType === 'success') {
-            return tsconfigPaths.register({
-                baseUrl: tsConfigResult.absoluteBaseUrl,
-                paths: tsConfigResult.paths,
-            });
-        }
-    }
-    catch (err) {
-        warnNoTsconfigPaths();
-    }
-    return () => { };
-}
-exports.registerTsConfigPaths = registerTsConfigPaths;
-function readCompilerOptions(tsConfigPath) {
-    if (swcNodeInstalled) {
-        const { readDefaultTsConfig, } = __nccwpck_require__(11642);
-        return readDefaultTsConfig(tsConfigPath);
-    }
-    else {
-        return readCompilerOptionsWithTypescript(tsConfigPath);
-    }
-}
-function readCompilerOptionsWithTypescript(tsConfigPath) {
-    if (!ts) {
-        ts = __nccwpck_require__(70048);
-    }
-    const { readConfigFile, parseJsonConfigFileContent, sys } = ts;
-    const jsonContent = readConfigFile(tsConfigPath, sys.readFile);
-    const { options } = parseJsonConfigFileContent(jsonContent.config, sys, (0, path_1.dirname)(tsConfigPath));
-    // This property is returned in compiler options for some reason, but not part of the typings.
-    // ts-node fails on unknown props, so we have to remove it.
-    delete options.configFilePath;
-    return options;
-}
-function warnTsNodeUsage() {
-    logger_1.logger.warn((0, logger_1.stripIndent)(`${logger_1.NX_PREFIX} Falling back to ts-node for local typescript execution. This may be a little slower.
-  - To fix this, ensure @swc-node/register and @swc/core have been installed`));
-}
-function warnNoTsconfigPaths() {
-    logger_1.logger.warn((0, logger_1.stripIndent)(`${logger_1.NX_PREFIX} Unable to load tsconfig-paths, workspace libraries may be inaccessible.
-  - To fix this, install tsconfig-paths with npm/yarn/pnpm`));
-}
-function warnNoTranspiler() {
-    logger_1.logger.warn((0, logger_1.stripIndent)(`${logger_1.NX_PREFIX} Unable to locate swc-node or ts-node. Nx will be unable to run local ts files without transpiling.
-  - To fix this, ensure @swc-node/register and @swc/core have been installed`));
-}
-function packageIsInstalled(m) {
-    try {
-        const p = require.resolve(m);
-        return true;
-    }
-    catch (_a) {
-        return false;
-    }
-}
-/**
- * ts-node requires string values for enum based typescript options.
- * `register`'s signature just types the field as `object`, so we
- * unfortunately do not get any kind of type safety on this.
- */
-function getTsNodeCompilerOptions(compilerOptions) {
-    var _a;
-    if (!ts) {
-        ts = __nccwpck_require__(70048);
-    }
-    const flagMap = {
-        module: 'ModuleKind',
-        target: 'ScriptTarget',
-        moduleDetection: 'ModuleDetectionKind',
-        newLine: 'NewLineKind',
-        moduleResolution: 'ModuleResolutionKind',
-        importsNotUsedAsValues: 'ImportsNotUsedAsValues',
-    };
-    const result = Object.assign({}, compilerOptions);
-    for (const flag in flagMap) {
-        if (compilerOptions[flag]) {
-            result[flag] = ts[flagMap[flag]][compilerOptions[flag]];
-        }
-    }
-    delete result.pathsBasePath;
-    delete result.configFilePath;
-    // instead of mapping to enum value we just remove it as it shouldn't ever need to be set for ts-node
-    delete result.jsx;
-    // lib option is in the format `lib.es2022.d.ts`, so we need to remove the leading `lib.` and trailing `.d.ts` to make it valid
-    result.lib = (_a = result.lib) === null || _a === void 0 ? void 0 : _a.map((value) => {
-        return value.replace(/^lib\./, '').replace(/\.d\.ts$/, '');
-    });
-    if (result.moduleResolution) {
-        result.moduleResolution =
-            result.moduleResolution === 'NodeJs'
-                ? 'node'
-                : result.moduleResolution.toLowerCase();
-    }
-    return result;
-}
-exports.getTsNodeCompilerOptions = getTsNodeCompilerOptions;
+var DEFAULT_MAXBUFFER_SIZE = 20 * 1024 * 1024;
+var DEFAULT_ERROR_CODE = 1;
 
+common.register('exec', _exec, {
+  unix: false,
+  canReceivePipe: true,
+  wrapOutput: false,
+});
 
-/***/ }),
+// We use this function to run `exec` synchronously while also providing realtime
+// output.
+function execSync(cmd, opts, pipe) {
+  if (!common.config.execPath) {
+    common.error('Unable to find a path to the node binary. Please manually set config.execPath');
+  }
 
-/***/ 62029:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
+  var tempDir = _tempDir();
+  var paramsFile = path.resolve(tempDir + '/' + common.randomFileName());
+  var stderrFile = path.resolve(tempDir + '/' + common.randomFileName());
+  var stdoutFile = path.resolve(tempDir + '/' + common.randomFileName());
 
-"use strict";
+  opts = common.extend({
+    silent: common.config.silent,
+    cwd: _pwd().toString(),
+    env: process.env,
+    maxBuffer: DEFAULT_MAXBUFFER_SIZE,
+    encoding: 'utf8',
+  }, opts);
 
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.findNodes = exports.getRootTsConfigPath = exports.getRootTsConfigFileName = exports.resolveModuleByImport = exports.readTsConfig = void 0;
-const workspace_root_1 = __nccwpck_require__(65766);
-const fs_1 = __nccwpck_require__(57147);
-const path_1 = __nccwpck_require__(71017);
-const normalizedAppRoot = workspace_root_1.workspaceRoot.replace(/\\/g, '/');
-let tsModule;
-function readTsConfig(tsConfigPath) {
-    if (!tsModule) {
-        tsModule = __nccwpck_require__(70048);
-    }
-    const readResult = tsModule.readConfigFile(tsConfigPath, tsModule.sys.readFile);
-    return tsModule.parseJsonConfigFileContent(readResult.config, tsModule.sys, (0, path_1.dirname)(tsConfigPath));
-}
-exports.readTsConfig = readTsConfig;
-function readTsConfigOptions(tsConfigPath) {
-    if (!tsModule) {
-        tsModule = __nccwpck_require__(70048);
-    }
-    const readResult = tsModule.readConfigFile(tsConfigPath, tsModule.sys.readFile);
-    // we don't need to scan the files, we only care about options
-    const host = {
-        readDirectory: () => [],
-        readFile: () => '',
-        fileExists: tsModule.sys.fileExists,
-    };
-    return tsModule.parseJsonConfigFileContent(readResult.config, host, (0, path_1.dirname)(tsConfigPath)).options;
-}
-let compilerHost;
-/**
- * Find a module based on its import
- *
- * @param importExpr Import used to resolve to a module
- * @param filePath
- * @param tsConfigPath
- */
-function resolveModuleByImport(importExpr, filePath, tsConfigPath) {
-    compilerHost = compilerHost || getCompilerHost(tsConfigPath);
-    const { options, host, moduleResolutionCache } = compilerHost;
-    const { resolvedModule } = tsModule.resolveModuleName(importExpr, filePath, options, host, moduleResolutionCache);
-    if (!resolvedModule) {
-        return;
-    }
-    else {
-        return resolvedModule.resolvedFileName.replace(`${normalizedAppRoot}/`, '');
-    }
-}
-exports.resolveModuleByImport = resolveModuleByImport;
-function getCompilerHost(tsConfigPath) {
-    const options = readTsConfigOptions(tsConfigPath);
-    const host = tsModule.createCompilerHost(options, true);
-    const moduleResolutionCache = tsModule.createModuleResolutionCache(workspace_root_1.workspaceRoot, host.getCanonicalFileName);
-    return { options, host, moduleResolutionCache };
-}
-function getRootTsConfigFileName() {
-    for (const tsConfigName of ['tsconfig.base.json', 'tsconfig.json']) {
-        const tsConfigPath = (0, path_1.join)(workspace_root_1.workspaceRoot, tsConfigName);
-        if ((0, fs_1.existsSync)(tsConfigPath)) {
-            return tsConfigName;
-        }
-    }
-    return null;
-}
-exports.getRootTsConfigFileName = getRootTsConfigFileName;
-function getRootTsConfigPath() {
-    const tsConfigFileName = getRootTsConfigFileName();
-    return tsConfigFileName ? (0, path_1.join)(workspace_root_1.workspaceRoot, tsConfigFileName) : null;
-}
-exports.getRootTsConfigPath = getRootTsConfigPath;
-function findNodes(node, kind, max = Infinity) {
-    if (!node || max == 0) {
-        return [];
-    }
-    const arr = [];
-    const hasMatch = Array.isArray(kind)
-        ? kind.includes(node.kind)
-        : node.kind === kind;
-    if (hasMatch) {
-        arr.push(node);
-        max--;
-    }
-    if (max > 0) {
-        for (const child of node.getChildren()) {
-            findNodes(child, kind, max).forEach((node) => {
-                if (max > 0) {
-                    arr.push(node);
-                }
-                max--;
-            });
-            if (max <= 0) {
-                break;
-            }
-        }
-    }
-    return arr;
-}
-exports.findNodes = findNodes;
+  if (fs.existsSync(paramsFile)) common.unlinkSync(paramsFile);
+  if (fs.existsSync(stderrFile)) common.unlinkSync(stderrFile);
+  if (fs.existsSync(stdoutFile)) common.unlinkSync(stdoutFile);
 
+  opts.cwd = path.resolve(opts.cwd);
 
-/***/ }),
+  var paramsToSerialize = {
+    command: cmd,
+    execOptions: opts,
+    pipe: pipe,
+    stdoutFile: stdoutFile,
+    stderrFile: stderrFile,
+  };
 
-/***/ 84445:
-/***/ ((__unused_webpack_module, exports) => {
+  // Create the files and ensure these are locked down (for read and write) to
+  // the current user. The main concerns here are:
+  //
+  // * If we execute a command which prints sensitive output, then
+  //   stdoutFile/stderrFile must not be readable by other users.
+  // * paramsFile must not be readable by other users, or else they can read it
+  //   to figure out the path for stdoutFile/stderrFile and create these first
+  //   (locked down to their own access), which will crash exec() when it tries
+  //   to write to the files.
+  function writeFileLockedDown(filePath, data) {
+    fs.writeFileSync(filePath, data, {
+      encoding: 'utf8',
+      mode: parseInt('600', 8),
+    });
+  }
+  writeFileLockedDown(stdoutFile, '');
+  writeFileLockedDown(stderrFile, '');
+  writeFileLockedDown(paramsFile, JSON.stringify(paramsToSerialize));
 
-"use strict";
+  var execArgs = [
+    __nccwpck_require__.ab + "exec-child.js",
+    paramsFile,
+  ];
 
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.buildImplicitProjectDependencies = void 0;
-function buildImplicitProjectDependencies(ctx, builder) {
-    Object.keys(ctx.projectsConfigurations.projects).forEach((source) => {
-        const p = ctx.projectsConfigurations.projects[source];
-        if (p.implicitDependencies && p.implicitDependencies.length > 0) {
-            p.implicitDependencies.forEach((target) => {
-                if (target.startsWith('!')) {
-                    builder.removeDependency(source, target.slice(1));
-                }
-                else {
-                    builder.addImplicitDependency(source, target);
-                }
-            });
-        }
-    });
-}
-exports.buildImplicitProjectDependencies = buildImplicitProjectDependencies;
+  /* istanbul ignore else */
+  if (opts.silent) {
+    opts.stdio = 'ignore';
+  } else {
+    opts.stdio = [0, 1, 2];
+  }
 
+  var code = 0;
 
-/***/ }),
+  // Welcome to the future
+  try {
+    // Bad things if we pass in a `shell` option to child_process.execFileSync,
+    // so we need to explicitly remove it here.
+    delete opts.shell;
 
-/***/ 54031:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
+    child.execFileSync(common.config.execPath, execArgs, opts);
+  } catch (e) {
+    // Commands with non-zero exit code raise an exception.
+    code = e.status || DEFAULT_ERROR_CODE;
+  }
 
-"use strict";
+  // fs.readFileSync uses buffer encoding by default, so call
+  // it without the encoding option if the encoding is 'buffer'.
+  // Also, if the exec timeout is too short for node to start up,
+  // the files will not be created, so these calls will throw.
+  var stdout = '';
+  var stderr = '';
+  if (opts.encoding === 'buffer') {
+    stdout = fs.readFileSync(stdoutFile);
+    stderr = fs.readFileSync(stderrFile);
+  } else {
+    stdout = fs.readFileSync(stdoutFile, opts.encoding);
+    stderr = fs.readFileSync(stderrFile, opts.encoding);
+  }
 
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-const tslib_1 = __nccwpck_require__(51796);
-tslib_1.__exportStar(__nccwpck_require__(84445), exports);
+  // No biggie if we can't erase the files now -- they're in a temp dir anyway
+  // and we locked down permissions (see the note above).
+  try { common.unlinkSync(paramsFile); } catch (e) {}
+  try { common.unlinkSync(stderrFile); } catch (e) {}
+  try { common.unlinkSync(stdoutFile); } catch (e) {}
 
+  if (code !== 0) {
+    // Note: `silent` should be unconditionally true to avoid double-printing
+    // the command's stderr, and to avoid printing any stderr when the user has
+    // set `shell.config.silent`.
+    common.error(stderr, code, { continue: true, silent: true });
+  }
+  var obj = common.ShellString(stdout, stderr, code);
+  return obj;
+} // execSync()
 
-/***/ }),
+// Wrapper around exec() to enable echoing output to console in real time
+function execAsync(cmd, opts, pipe, callback) {
+  opts = common.extend({
+    silent: common.config.silent,
+    cwd: _pwd().toString(),
+    env: process.env,
+    maxBuffer: DEFAULT_MAXBUFFER_SIZE,
+    encoding: 'utf8',
+  }, opts);
 
-/***/ 58729:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
+  var c = child.exec(cmd, opts, function (err, stdout, stderr) {
+    if (callback) {
+      if (!err) {
+        callback(0, stdout, stderr);
+      } else if (err.code === undefined) {
+        // See issue #536
+        /* istanbul ignore next */
+        callback(1, stdout, stderr);
+      } else {
+        callback(err.code, stdout, stderr);
+      }
+    }
+  });
 
-"use strict";
+  if (pipe) c.stdin.end(pipe);
 
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-const tslib_1 = __nccwpck_require__(51796);
-tslib_1.__exportStar(__nccwpck_require__(66055), exports);
+  if (!opts.silent) {
+    c.stdout.pipe(process.stdout);
+    c.stderr.pipe(process.stderr);
+  }
 
+  return c;
+}
 
-/***/ }),
+//@
+//@ ### exec(command [, options] [, callback])
+//@
+//@ Available options:
+//@
+//@ + `async`: Asynchronous execution. If a callback is provided, it will be set to
+//@   `true`, regardless of the passed value (default: `false`).
+//@ + `silent`: Do not echo program output to console (default: `false`).
+//@ + `encoding`: Character encoding to use. Affects the values returned to stdout and stderr, and
+//@   what is written to stdout and stderr when not in silent mode (default: `'utf8'`).
+//@ + and any option available to Node.js's
+//@   [`child_process.exec()`](https://nodejs.org/api/child_process.html#child_process_child_process_exec_command_options_callback)
+//@
+//@ Examples:
+//@
+//@ ```javascript
+//@ var version = exec('node --version', {silent:true}).stdout;
+//@
+//@ var child = exec('some_long_running_process', {async:true});
+//@ child.stdout.on('data', function(data) {
+//@   /* ... do something with data ... */
+//@ });
+//@
+//@ exec('some_long_running_process', function(code, stdout, stderr) {
+//@   console.log('Exit code:', code);
+//@   console.log('Program output:', stdout);
+//@   console.log('Program stderr:', stderr);
+//@ });
+//@ ```
+//@
+//@ Executes the given `command` _synchronously_, unless otherwise specified.  When in synchronous
+//@ mode, this returns a `ShellString` (compatible with ShellJS v0.6.x, which returns an object
+//@ of the form `{ code:..., stdout:... , stderr:... }`). Otherwise, this returns the child process
+//@ object, and the `callback` receives the arguments `(code, stdout, stderr)`.
+//@
+//@ Not seeing the behavior you want? `exec()` runs everything through `sh`
+//@ by default (or `cmd.exe` on Windows), which differs from `bash`. If you
+//@ need bash-specific behavior, try out the `{shell: 'path/to/bash'}` option.
+function _exec(command, options, callback) {
+  options = options || {};
+  if (!command) common.error('must specify command');
 
-/***/ 66055:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
+  var pipe = common.readFromPipe();
 
-"use strict";
+  // Callback is defined instead of options.
+  if (typeof options === 'function') {
+    callback = options;
+    options = { async: true };
+  }
 
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.normalizeImplicitDependencies = exports.buildWorkspaceProjectNodes = void 0;
-const tslib_1 = __nccwpck_require__(51796);
-const path_1 = __nccwpck_require__(71017);
-const fs_1 = __nccwpck_require__(57147);
-const workspace_root_1 = __nccwpck_require__(65766);
-const nx_plugin_1 = __nccwpck_require__(86740);
-const project_graph_utils_1 = __nccwpck_require__(27377);
-const fileutils_1 = __nccwpck_require__(47930);
-const find_matching_projects_1 = __nccwpck_require__(56668);
-const logger_1 = __nccwpck_require__(95324);
-const workspaces_1 = __nccwpck_require__(98715);
-function buildWorkspaceProjectNodes(ctx, builder, nxJson) {
-    var _a, _b;
-    return tslib_1.__awaiter(this, void 0, void 0, function* () {
-        const toAdd = [];
-        const projects = Object.keys(ctx.projectsConfigurations.projects);
-        // Used for expanding implicit dependencies (e.g. `@proj/*` or `tag:foo`)
-        const partialProjectGraphNodes = projects.reduce((graph, project) => {
-            const projectConfiguration = ctx.projectsConfigurations.projects[project];
-            graph[project] = {
-                name: project,
-                type: projectConfiguration.projectType === 'library' ? 'lib' : 'app',
-                data: Object.assign({}, projectConfiguration),
-            };
-            return graph;
-        }, {});
-        for (const key of projects) {
-            const p = ctx.projectsConfigurations.projects[key];
-            const projectRoot = (0, path_1.join)(workspace_root_1.workspaceRoot, p.root);
-            if ((0, fs_1.existsSync)((0, path_1.join)(projectRoot, 'package.json'))) {
-                p.targets = (0, project_graph_utils_1.mergeNpmScriptsWithTargets)(projectRoot, p.targets);
-                try {
-                    const { nx } = (0, fileutils_1.readJsonFile)((0, path_1.join)(projectRoot, 'package.json'));
-                    if (nx === null || nx === void 0 ? void 0 : nx.tags) {
-                        p.tags = [...(p.tags || []), ...nx.tags];
-                    }
-                    if (nx === null || nx === void 0 ? void 0 : nx.implicitDependencies) {
-                        p.implicitDependencies = [
-                            ...(p.implicitDependencies || []),
-                            ...nx.implicitDependencies,
-                        ];
-                    }
-                    if (nx === null || nx === void 0 ? void 0 : nx.namedInputs) {
-                        p.namedInputs = Object.assign(Object.assign({}, (p.namedInputs || {})), nx.namedInputs);
-                    }
-                }
-                catch (_c) {
-                    // ignore json parser errors
-                }
-            }
-            p.implicitDependencies = normalizeImplicitDependencies(key, p.implicitDependencies, partialProjectGraphNodes);
-            p.targets = (0, nx_plugin_1.mergePluginTargetsWithNxTargets)(p.root, p.targets, yield (0, nx_plugin_1.loadNxPlugins)(ctx.nxJsonConfiguration.plugins));
-            p.targets = normalizeProjectTargets(p, nxJson.targetDefaults, key);
-            // TODO: remove in v16
-            const projectType = p.projectType === 'application'
-                ? key.endsWith('-e2e') || key === 'e2e'
-                    ? 'e2e'
-                    : 'app'
-                : 'lib';
-            const tags = ((_b = (_a = ctx.projectsConfigurations.projects) === null || _a === void 0 ? void 0 : _a[key]) === null || _b === void 0 ? void 0 : _b.tags) || [];
-            toAdd.push({
-                name: key,
-                type: projectType,
-                data: Object.assign(Object.assign({}, p), { tags }),
-            });
-        }
-        // Sort by root directory length (do we need this?)
-        toAdd.sort((a, b) => {
-            if (!a.data.root)
-                return -1;
-            if (!b.data.root)
-                return -1;
-            return a.data.root.length > b.data.root.length ? -1 : 1;
-        });
-        toAdd.forEach((n) => {
-            builder.addNode({
-                name: n.name,
-                type: n.type,
-                data: n.data,
-            });
-        });
-    });
-}
-exports.buildWorkspaceProjectNodes = buildWorkspaceProjectNodes;
-/**
- * Apply target defaults and normalization
- */
-function normalizeProjectTargets(project, targetDefaults, projectName) {
-    var _a;
-    const targets = project.targets;
-    for (const target in targets) {
-        const executor = ((_a = targets[target].executor) !== null && _a !== void 0 ? _a : targets[target].command)
-            ? 'nx:run-commands'
-            : null;
-        const defaults = (0, workspaces_1.readTargetDefaultsForTarget)(target, targetDefaults, executor);
-        if (defaults) {
-            targets[target] = (0, workspaces_1.mergeTargetConfigurations)(project, target, defaults);
-        }
-        const config = targets[target];
-        if (config.command) {
-            if (config.executor) {
-                throw new Error(`${logger_1.NX_PREFIX} ${projectName}: ${target} should not have executor and command both configured.`);
-            }
-            else {
-                targets[target] = Object.assign(Object.assign({}, targets[target]), { executor, options: Object.assign(Object.assign({}, config.options), { command: config.command }) });
-                delete config.command;
-            }
-        }
-    }
-    return targets;
-}
-function normalizeImplicitDependencies(source, implicitDependencies, projects) {
-    if (!(implicitDependencies === null || implicitDependencies === void 0 ? void 0 : implicitDependencies.length)) {
-        return implicitDependencies !== null && implicitDependencies !== void 0 ? implicitDependencies : [];
-    }
-    const matches = (0, find_matching_projects_1.findMatchingProjects)(implicitDependencies, projects);
-    return (matches
-        .filter((x) => x !== source)
-        // implicit dependencies that start with ! should hang around, to be processed by
-        // implicit-project-dependencies.ts after explicit deps are added to graph.
-        .concat(implicitDependencies.filter((x) => x.startsWith('!'))));
+  // Callback is defined with options.
+  if (typeof options === 'object' && typeof callback === 'function') {
+    options.async = true;
+  }
+
+  options = common.extend({
+    silent: common.config.silent,
+    async: false,
+  }, options);
+
+  if (options.async) {
+    return execAsync(command, options, pipe, callback);
+  } else {
+    return execSync(command, options, pipe);
+  }
 }
-exports.normalizeImplicitDependencies = normalizeImplicitDependencies;
+module.exports = _exec;
 
 
 /***/ }),
 
-/***/ 60214:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
+/***/ 52388:
+/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
-"use strict";
+var path = __nccwpck_require__(71017);
+var common = __nccwpck_require__(60624);
+var _ls = __nccwpck_require__(42248);
 
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.buildProjectGraphUsingProjectFileMap = exports.getProjectFileMap = void 0;
-const tslib_1 = __nccwpck_require__(51796);
-const workspace_root_1 = __nccwpck_require__(65766);
-const path_1 = __nccwpck_require__(71017);
-const perf_hooks_1 = __nccwpck_require__(4074);
-const assert_workspace_validity_1 = __nccwpck_require__(51635);
-const nx_deps_cache_1 = __nccwpck_require__(65959);
-const build_dependencies_1 = __nccwpck_require__(54031);
-const build_nodes_1 = __nccwpck_require__(58729);
-const nx_plugin_1 = __nccwpck_require__(86740);
-const typescript_1 = __nccwpck_require__(62029);
-const fileutils_1 = __nccwpck_require__(47930);
-const project_graph_builder_1 = __nccwpck_require__(14812);
-const configuration_1 = __nccwpck_require__(65459);
-const fs_1 = __nccwpck_require__(57147);
-let storedProjectFileMap = null;
-let storedAllWorkspaceFiles = null;
-function getProjectFileMap() {
-    if (!!storedProjectFileMap) {
-        return {
-            projectFileMap: storedProjectFileMap,
-            allWorkspaceFiles: storedAllWorkspaceFiles,
-        };
-    }
-    else {
-        return { projectFileMap: {}, allWorkspaceFiles: [] };
+common.register('find', _find, {});
+
+//@
+//@ ### find(path [, path ...])
+//@ ### find(path_array)
+//@
+//@ Examples:
+//@
+//@ ```javascript
+//@ find('src', 'lib');
+//@ find(['src', 'lib']); // same as above
+//@ find('.').filter(function(file) { return file.match(/\.js$/); });
+//@ ```
+//@
+//@ Returns array of all files (however deep) in the given paths.
+//@
+//@ The main difference from `ls('-R', path)` is that the resulting file names
+//@ include the base directories (e.g., `lib/resources/file1` instead of just `file1`).
+function _find(options, paths) {
+  if (!paths) {
+    common.error('no path specified');
+  } else if (typeof paths === 'string') {
+    paths = [].slice.call(arguments, 1);
+  }
+
+  var list = [];
+
+  function pushFile(file) {
+    if (process.platform === 'win32') {
+      file = file.replace(/\\/g, '/');
     }
-}
-exports.getProjectFileMap = getProjectFileMap;
-function buildProjectGraphUsingProjectFileMap(projectsConfigurations, projectFileMap, allWorkspaceFiles, fileMap, shouldWriteCache) {
-    return tslib_1.__awaiter(this, void 0, void 0, function* () {
-        storedProjectFileMap = projectFileMap;
-        storedAllWorkspaceFiles = allWorkspaceFiles;
-        const nxJson = (0, configuration_1.readNxJson)();
-        const projectGraphVersion = '6.0';
-        (0, assert_workspace_validity_1.assertWorkspaceValidity)(projectsConfigurations, nxJson);
-        const packageJsonDeps = readCombinedDeps();
-        const rootTsConfig = readRootTsConfig();
-        let filesToProcess;
-        let cachedFileData;
-        const useCacheData = fileMap &&
-            !(0, nx_deps_cache_1.shouldRecomputeWholeGraph)(fileMap, packageJsonDeps, projectsConfigurations, nxJson, rootTsConfig);
-        if (useCacheData) {
-            const fromCache = (0, nx_deps_cache_1.extractCachedFileData)(projectFileMap, fileMap);
-            filesToProcess = fromCache.filesToProcess;
-            cachedFileData = fromCache.cachedFileData;
-        }
-        else {
-            filesToProcess = projectFileMap;
-            cachedFileData = {};
-        }
-        const context = createContext(projectsConfigurations, nxJson, projectFileMap, filesToProcess);
-        let projectGraph = yield buildProjectGraphUsingContext(nxJson, context, cachedFileData, projectGraphVersion);
-        const projectFileMapCache = (0, nx_deps_cache_1.createProjectFileMapCache)(nxJson, packageJsonDeps, projectFileMap, rootTsConfig);
-        if (shouldWriteCache) {
-            (0, nx_deps_cache_1.writeCache)(projectFileMapCache, projectGraph);
-        }
-        return {
-            projectGraph,
-            projectFileMapCache,
-        };
-    });
-}
-exports.buildProjectGraphUsingProjectFileMap = buildProjectGraphUsingProjectFileMap;
-function readCombinedDeps() {
-    const installationPackageJsonPath = (0, path_1.join)(workspace_root_1.workspaceRoot, '.nx', 'installation', 'package.json');
-    const installationPackageJson = (0, fs_1.existsSync)(installationPackageJsonPath)
-        ? (0, fileutils_1.readJsonFile)(installationPackageJsonPath)
-        : {};
-    const rootPackageJsonPath = (0, path_1.join)(workspace_root_1.workspaceRoot, 'package.json');
-    const rootPackageJson = (0, fs_1.existsSync)(rootPackageJsonPath)
-        ? (0, fileutils_1.readJsonFile)(rootPackageJsonPath)
-        : {};
-    return Object.assign(Object.assign(Object.assign(Object.assign({}, rootPackageJson.dependencies), rootPackageJson.devDependencies), installationPackageJson.dependencies), installationPackageJson.devDependencies);
-}
-function buildProjectGraphUsingContext(nxJson, ctx, cachedFileData, projectGraphVersion) {
-    return tslib_1.__awaiter(this, void 0, void 0, function* () {
-        perf_hooks_1.performance.mark('build project graph:start');
-        const builder = new project_graph_builder_1.ProjectGraphBuilder(null, ctx.fileMap);
-        builder.setVersion(projectGraphVersion);
-        yield (0, build_nodes_1.buildWorkspaceProjectNodes)(ctx, builder, nxJson);
-        const initProjectGraph = builder.getUpdatedProjectGraph();
-        const r = yield updateProjectGraphWithPlugins(ctx, initProjectGraph);
-        const updatedBuilder = new project_graph_builder_1.ProjectGraphBuilder(r, ctx.fileMap);
-        for (const proj of Object.keys(cachedFileData)) {
-            for (const f of ctx.fileMap[proj] || []) {
-                const cached = cachedFileData[proj][f.file];
-                if (cached && cached.deps) {
-                    f.deps = [...cached.deps];
-                }
-            }
-        }
-        (0, build_dependencies_1.buildImplicitProjectDependencies)(ctx, updatedBuilder);
-        const finalGraph = updatedBuilder.getUpdatedProjectGraph();
-        perf_hooks_1.performance.mark('build project graph:end');
-        perf_hooks_1.performance.measure('build project graph', 'build project graph:start', 'build project graph:end');
-        return finalGraph;
-    });
-}
-function createContext(projectsConfigurations, nxJson, fileMap, filesToProcess) {
-    const projects = Object.keys(projectsConfigurations.projects).reduce((map, projectName) => {
-        map[projectName] = Object.assign({}, projectsConfigurations.projects[projectName]);
-        return map;
-    }, {});
-    return {
-        nxJsonConfiguration: nxJson,
-        projectsConfigurations,
-        workspace: Object.assign(Object.assign(Object.assign({}, projectsConfigurations), nxJson), { projects }),
-        fileMap,
-        filesToProcess,
-    };
-}
-function updateProjectGraphWithPlugins(context, initProjectGraph) {
-    return tslib_1.__awaiter(this, void 0, void 0, function* () {
-        const plugins = (yield (0, nx_plugin_1.loadNxPlugins)(context.nxJsonConfiguration.plugins)).filter((x) => !!x.processProjectGraph);
-        let graph = initProjectGraph;
-        for (const plugin of plugins) {
-            try {
-                graph = yield plugin.processProjectGraph(graph, context);
-            }
-            catch (e) {
-                let message = `Failed to process the project graph with "${plugin.name}".`;
-                if (e instanceof Error) {
-                    e.message = message + '\n' + e.message;
-                    throw e;
-                }
-                throw new Error(message);
-            }
-        }
-        return graph;
-    });
-}
-function readRootTsConfig() {
+    list.push(file);
+  }
+
+  // why not simply do `ls('-R', paths)`? because the output wouldn't give the base dirs
+  // to get the base dir in the output, we need instead `ls('-R', 'dir/*')` for every directory
+
+  paths.forEach(function (file) {
+    var stat;
     try {
-        const tsConfigPath = (0, typescript_1.getRootTsConfigPath)();
-        if (tsConfigPath) {
-            return (0, fileutils_1.readJsonFile)(tsConfigPath, { expectComments: true });
-        }
+      stat = common.statFollowLinks(file);
+    } catch (e) {
+      common.error('no such file or directory: ' + file);
     }
-    catch (e) {
-        return {};
+
+    pushFile(file);
+
+    if (stat.isDirectory()) {
+      _ls({ recursive: true, all: true }, file).forEach(function (subfile) {
+        pushFile(path.join(file, subfile));
+      });
     }
+  });
+
+  return list;
 }
+module.exports = _find;
 
 
 /***/ }),
 
-/***/ 11223:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
+/***/ 47294:
+/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
-"use strict";
+var common = __nccwpck_require__(60624);
+var fs = __nccwpck_require__(57147);
 
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.updateProjectFileMap = exports.createProjectFileMap = exports.createProjectFileMapUsingProjectGraph = void 0;
-const tslib_1 = __nccwpck_require__(51796);
-const find_project_for_path_1 = __nccwpck_require__(36265);
-const client_1 = __nccwpck_require__(55942);
-const project_graph_1 = __nccwpck_require__(22055);
-const impl_1 = __nccwpck_require__(43265);
-function createProjectFileMapUsingProjectGraph(graph) {
-    return tslib_1.__awaiter(this, void 0, void 0, function* () {
-        const configs = (0, project_graph_1.readProjectsConfigurationFromProjectGraph)(graph);
-        const files = client_1.daemonClient.enabled()
-            ? yield client_1.daemonClient.getAllFileData()
-            : impl_1.fileHasher.allFileData();
-        return createProjectFileMap(configs, files).projectFileMap;
-    });
-}
-exports.createProjectFileMapUsingProjectGraph = createProjectFileMapUsingProjectGraph;
-function createProjectFileMap(projectsConfigurations, allWorkspaceFiles) {
-    var _a;
-    const projectFileMap = {};
-    const projectRootMappings = (0, find_project_for_path_1.createProjectRootMappingsFromProjectConfigurations)(projectsConfigurations.projects);
-    for (const projectName of Object.keys(projectsConfigurations.projects)) {
-        (_a = projectFileMap[projectName]) !== null && _a !== void 0 ? _a : (projectFileMap[projectName] = []);
-    }
-    for (const f of allWorkspaceFiles) {
-        const projectFileMapKey = (0, find_project_for_path_1.findProjectForPath)(f.file, projectRootMappings);
-        const matchingProjectFiles = projectFileMap[projectFileMapKey];
-        if (matchingProjectFiles) {
-            matchingProjectFiles.push(f);
-        }
-    }
-    return { projectFileMap, allWorkspaceFiles };
-}
-exports.createProjectFileMap = createProjectFileMap;
-function updateProjectFileMap(projectsConfigurations, projectFileMap, allWorkspaceFiles, updatedFiles, deletedFiles) {
-    var _a, _b;
-    const projectRootMappings = (0, find_project_for_path_1.createProjectRootMappingsFromProjectConfigurations)(projectsConfigurations.projects);
-    for (const f of updatedFiles.keys()) {
-        const matchingProjectFiles = (_a = projectFileMap[(0, find_project_for_path_1.findProjectForPath)(f, projectRootMappings)]) !== null && _a !== void 0 ? _a : [];
-        if (matchingProjectFiles) {
-            const fileData = matchingProjectFiles.find((t) => t.file === f);
-            if (fileData) {
-                fileData.hash = updatedFiles.get(f);
-            }
-            else {
-                matchingProjectFiles.push({
-                    file: f,
-                    hash: updatedFiles.get(f),
-                });
-            }
-        }
-        const fileData = allWorkspaceFiles.find((t) => t.file === f);
-        if (fileData) {
-            fileData.hash = updatedFiles.get(f);
-        }
-        else {
-            allWorkspaceFiles.push({
-                file: f,
-                hash: updatedFiles.get(f),
-            });
-        }
+common.register('grep', _grep, {
+  globStart: 2, // don't glob-expand the regex
+  canReceivePipe: true,
+  cmdOptions: {
+    'v': 'inverse',
+    'l': 'nameOnly',
+    'i': 'ignoreCase',
+  },
+});
+
+//@
+//@ ### grep([options,] regex_filter, file [, file ...])
+//@ ### grep([options,] regex_filter, file_array)
+//@
+//@ Available options:
+//@
+//@ + `-v`: Invert `regex_filter` (only print non-matching lines).
+//@ + `-l`: Print only filenames of matching files.
+//@ + `-i`: Ignore case.
+//@
+//@ Examples:
+//@
+//@ ```javascript
+//@ grep('-v', 'GLOBAL_VARIABLE', '*.js');
+//@ grep('GLOBAL_VARIABLE', '*.js');
+//@ ```
+//@
+//@ Reads input string from given files and returns a string containing all lines of the
+//@ file that match the given `regex_filter`.
+function _grep(options, regex, files) {
+  // Check if this is coming from a pipe
+  var pipe = common.readFromPipe();
+
+  if (!files && !pipe) common.error('no paths given', 2);
+
+  files = [].slice.call(arguments, 2);
+
+  if (pipe) {
+    files.unshift('-');
+  }
+
+  var grep = [];
+  if (options.ignoreCase) {
+    regex = new RegExp(regex, 'i');
+  }
+  files.forEach(function (file) {
+    if (!fs.existsSync(file) && file !== '-') {
+      common.error('no such file or directory: ' + file, 2, { continue: true });
+      return;
     }
-    for (const f of deletedFiles) {
-        const matchingProjectFiles = (_b = projectFileMap[(0, find_project_for_path_1.findProjectForPath)(f, projectRootMappings)]) !== null && _b !== void 0 ? _b : [];
-        if (matchingProjectFiles) {
-            const index = matchingProjectFiles.findIndex((t) => t.file === f);
-            if (index > -1) {
-                matchingProjectFiles.splice(index, 1);
-            }
-        }
-        const index = allWorkspaceFiles.findIndex((t) => t.file === f);
-        if (index > -1) {
-            allWorkspaceFiles.splice(index, 1);
+
+    var contents = file === '-' ? pipe : fs.readFileSync(file, 'utf8');
+    if (options.nameOnly) {
+      if (contents.match(regex)) {
+        grep.push(file);
+      }
+    } else {
+      var lines = contents.split('\n');
+      lines.forEach(function (line) {
+        var matched = line.match(regex);
+        if ((options.inverse && !matched) || (!options.inverse && matched)) {
+          grep.push(line);
         }
+      });
     }
-    return { projectFileMap, allWorkspaceFiles };
+  });
+
+  return grep.join('\n') + '\n';
 }
-exports.updateProjectFileMap = updateProjectFileMap;
+module.exports = _grep;
 
 
 /***/ }),
 
-/***/ 93155:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
+/***/ 24902:
+/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
-"use strict";
+var common = __nccwpck_require__(60624);
+var fs = __nccwpck_require__(57147);
 
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.workspaceLayout = exports.readAllWorkspaceConfiguration = exports.readNxJson = exports.readPackageJson = exports.defaultFileRead = exports.readWorkspaceConfig = exports.TEN_MEGABYTES = exports.calculateFileChanges = exports.isDeletedFileChange = exports.isWholeFileChange = exports.DeletedFileChange = exports.WholeFileChange = void 0;
-const workspaces_1 = __nccwpck_require__(98715);
-const child_process_1 = __nccwpck_require__(32081);
-const fs_1 = __nccwpck_require__(57147);
-const path_1 = __nccwpck_require__(71017);
-const configuration_1 = __nccwpck_require__(65459);
-const workspace_root_1 = __nccwpck_require__(65766);
-const fileutils_1 = __nccwpck_require__(47930);
-const json_diff_1 = __nccwpck_require__(65058);
-const project_graph_1 = __nccwpck_require__(22055);
-const angular_json_1 = __nccwpck_require__(36803);
-const ignore_1 = __nccwpck_require__(98845);
-class WholeFileChange {
-    constructor() {
-        this.type = 'WholeFileChange';
-    }
-}
-exports.WholeFileChange = WholeFileChange;
-class DeletedFileChange {
-    constructor() {
-        this.type = 'WholeFileDeleted';
-    }
-}
-exports.DeletedFileChange = DeletedFileChange;
-function isWholeFileChange(change) {
-    return change.type === 'WholeFileChange';
-}
-exports.isWholeFileChange = isWholeFileChange;
-function isDeletedFileChange(change) {
-    return change.type === 'WholeFileDeleted';
-}
-exports.isDeletedFileChange = isDeletedFileChange;
-function calculateFileChanges(files, allWorkspaceFiles, nxArgs, readFileAtRevision = defaultReadFileAtRevision, ignore = (0, ignore_1.getIgnoreObject)()) {
-    files = files.filter((f) => !ignore.ignores(f));
-    return files.map((f) => {
-        const ext = (0, path_1.extname)(f);
-        const file = allWorkspaceFiles.find((fileData) => fileData.file == f);
-        const hash = file === null || file === void 0 ? void 0 : file.hash;
-        return {
-            file: f,
-            ext,
-            hash,
-            getChanges: () => {
-                if (!(0, fs_1.existsSync)((0, path_1.join)(workspace_root_1.workspaceRoot, f))) {
-                    return [new DeletedFileChange()];
-                }
-                if (!nxArgs) {
-                    return [new WholeFileChange()];
-                }
-                if (nxArgs.files && nxArgs.files.includes(f)) {
-                    return [new WholeFileChange()];
-                }
-                switch (ext) {
-                    case '.json':
-                        try {
-                            const atBase = readFileAtRevision(f, nxArgs.base);
-                            const atHead = readFileAtRevision(f, nxArgs.head);
-                            return (0, json_diff_1.jsonDiff)(JSON.parse(atBase), JSON.parse(atHead));
-                        }
-                        catch (e) {
-                            return [new WholeFileChange()];
-                        }
-                    default:
-                        return [new WholeFileChange()];
-                }
-            },
-        };
-    });
-}
-exports.calculateFileChanges = calculateFileChanges;
-exports.TEN_MEGABYTES = 1024 * 10000;
-function defaultReadFileAtRevision(file, revision) {
-    try {
-        const fileFullPath = `${workspace_root_1.workspaceRoot}${path_1.sep}${file}`;
-        const gitRepositoryPath = (0, child_process_1.execSync)('git rev-parse --show-toplevel')
-            .toString()
-            .trim();
-        const filePathInGitRepository = (0, path_1.relative)(gitRepositoryPath, fileFullPath)
-            .split(path_1.sep)
-            .join('/');
-        return !revision
-            ? (0, fs_1.readFileSync)(file, 'utf-8')
-            : (0, child_process_1.execSync)(`git show ${revision}:${filePathInGitRepository}`, {
-                maxBuffer: exports.TEN_MEGABYTES,
-                stdio: ['pipe', 'pipe', 'ignore'],
-            })
-                .toString()
-                .trim();
-    }
-    catch (_a) {
-        return '';
-    }
+common.register('head', _head, {
+  canReceivePipe: true,
+  cmdOptions: {
+    'n': 'numLines',
+  },
+});
+
+// Reads |numLines| lines or the entire file, whichever is less.
+function readSomeLines(file, numLines) {
+  var buf = common.buffer();
+  var bufLength = buf.length;
+  var bytesRead = bufLength;
+  var pos = 0;
+
+  var fdr = fs.openSync(file, 'r');
+  var numLinesRead = 0;
+  var ret = '';
+  while (bytesRead === bufLength && numLinesRead < numLines) {
+    bytesRead = fs.readSync(fdr, buf, 0, bufLength, pos);
+    var bufStr = buf.toString('utf8', 0, bytesRead);
+    numLinesRead += bufStr.split('\n').length - 1;
+    ret += bufStr;
+    pos += bytesRead;
+  }
+
+  fs.closeSync(fdr);
+  return ret;
 }
-function readWorkspaceConfig(opts) {
-    let configuration = null;
-    try {
-        const projectGraph = (0, project_graph_1.readCachedProjectGraph)();
-        configuration = Object.assign(Object.assign({}, (0, configuration_1.readNxJson)()), (0, project_graph_1.readProjectsConfigurationFromProjectGraph)(projectGraph));
-    }
-    catch (_a) {
-        const ws = new workspaces_1.Workspaces(opts.path || process.cwd());
-        configuration = ws.readProjectsConfigurations();
-    }
-    if (opts.format === 'angularCli') {
-        return (0, angular_json_1.toOldFormat)(configuration);
-    }
-    else {
-        return configuration;
+
+//@
+//@ ### head([{'-n': \},] file [, file ...])
+//@ ### head([{'-n': \},] file_array)
+//@
+//@ Available options:
+//@
+//@ + `-n `: Show the first `` lines of the files
+//@
+//@ Examples:
+//@
+//@ ```javascript
+//@ var str = head({'-n': 1}, 'file*.txt');
+//@ var str = head('file1', 'file2');
+//@ var str = head(['file1', 'file2']); // same as above
+//@ ```
+//@
+//@ Read the start of a file.
+function _head(options, files) {
+  var head = [];
+  var pipe = common.readFromPipe();
+
+  if (!files && !pipe) common.error('no paths given');
+
+  var idx = 1;
+  if (options.numLines === true) {
+    idx = 2;
+    options.numLines = Number(arguments[1]);
+  } else if (options.numLines === false) {
+    options.numLines = 10;
+  }
+  files = [].slice.call(arguments, idx);
+
+  if (pipe) {
+    files.unshift('-');
+  }
+
+  var shouldAppendNewline = false;
+  files.forEach(function (file) {
+    if (file !== '-') {
+      if (!fs.existsSync(file)) {
+        common.error('no such file or directory: ' + file, { continue: true });
+        return;
+      } else if (common.statFollowLinks(file).isDirectory()) {
+        common.error("error reading '" + file + "': Is a directory", {
+          continue: true,
+        });
+        return;
+      }
     }
-}
-exports.readWorkspaceConfig = readWorkspaceConfig;
-function defaultFileRead(filePath) {
-    return (0, fs_1.readFileSync)((0, path_1.join)(workspace_root_1.workspaceRoot, filePath), 'utf-8');
-}
-exports.defaultFileRead = defaultFileRead;
-function readPackageJson() {
-    try {
-        return (0, fileutils_1.readJsonFile)(`${workspace_root_1.workspaceRoot}/package.json`);
+
+    var contents;
+    if (file === '-') {
+      contents = pipe;
+    } else if (options.numLines < 0) {
+      contents = fs.readFileSync(file, 'utf8');
+    } else {
+      contents = readSomeLines(file, options.numLines);
     }
-    catch (_a) {
-        return {}; // if package.json doesn't exist
+
+    var lines = contents.split('\n');
+    var hasTrailingNewline = (lines[lines.length - 1] === '');
+    if (hasTrailingNewline) {
+      lines.pop();
     }
+    shouldAppendNewline = (hasTrailingNewline || options.numLines < lines.length);
+
+    head = head.concat(lines.slice(0, options.numLines));
+  });
+
+  if (shouldAppendNewline) {
+    head.push(''); // to add a trailing newline once we join
+  }
+  return head.join('\n');
 }
-exports.readPackageJson = readPackageJson;
-// TODO(v16): Remove these exports
-var configuration_2 = __nccwpck_require__(65459);
-Object.defineProperty(exports, "readNxJson", ({ enumerable: true, get: function () { return configuration_2.readNxJson; } }));
-Object.defineProperty(exports, "readAllWorkspaceConfiguration", ({ enumerable: true, get: function () { return configuration_2.readAllWorkspaceConfiguration; } }));
-Object.defineProperty(exports, "workspaceLayout", ({ enumerable: true, get: function () { return configuration_2.workspaceLayout; } }));
+module.exports = _head;
 
 
 /***/ }),
 
-/***/ 65959:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
+/***/ 68092:
+/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
-"use strict";
+var fs = __nccwpck_require__(57147);
+var path = __nccwpck_require__(71017);
+var common = __nccwpck_require__(60624);
 
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.extractCachedFileData = exports.shouldRecomputeWholeGraph = exports.writeCache = exports.createProjectFileMapCache = exports.readProjectGraphCache = exports.readProjectFileMapCache = exports.ensureCacheDirectory = exports.nxFileMap = exports.nxProjectGraph = void 0;
-const fs_1 = __nccwpck_require__(57147);
-const fs_extra_1 = __nccwpck_require__(59511);
-const path_1 = __nccwpck_require__(71017);
-const perf_hooks_1 = __nccwpck_require__(4074);
-const cache_directory_1 = __nccwpck_require__(20858);
-const fileutils_1 = __nccwpck_require__(47930);
-const versions_1 = __nccwpck_require__(39317);
-exports.nxProjectGraph = (0, path_1.join)(cache_directory_1.projectGraphCacheDirectory, 'project-graph.json');
-exports.nxFileMap = (0, path_1.join)(cache_directory_1.projectGraphCacheDirectory, 'file-map.json');
-function ensureCacheDirectory() {
-    try {
-        if (!(0, fs_1.existsSync)(cache_directory_1.projectGraphCacheDirectory)) {
-            (0, fs_extra_1.ensureDirSync)(cache_directory_1.projectGraphCacheDirectory);
-        }
+common.register('ln', _ln, {
+  cmdOptions: {
+    's': 'symlink',
+    'f': 'force',
+  },
+});
+
+//@
+//@ ### ln([options,] source, dest)
+//@
+//@ Available options:
+//@
+//@ + `-s`: symlink
+//@ + `-f`: force
+//@
+//@ Examples:
+//@
+//@ ```javascript
+//@ ln('file', 'newlink');
+//@ ln('-sf', 'file', 'existing');
+//@ ```
+//@
+//@ Links `source` to `dest`. Use `-f` to force the link, should `dest` already exist.
+function _ln(options, source, dest) {
+  if (!source || !dest) {
+    common.error('Missing  and/or ');
+  }
+
+  source = String(source);
+  var sourcePath = path.normalize(source).replace(RegExp(path.sep + '$'), '');
+  var isAbsolute = (path.resolve(source) === sourcePath);
+  dest = path.resolve(process.cwd(), String(dest));
+
+  if (fs.existsSync(dest)) {
+    if (!options.force) {
+      common.error('Destination file exists', { continue: true });
     }
-    catch (e) {
-        /*
-         * @jeffbcross: Node JS docs recommend against checking for existence of directory immediately before creating it.
-         * Instead, just try to create the directory and handle the error.
-         *
-         * We ran into race conditions when running scripts concurrently, where multiple scripts were
-         * arriving here simultaneously, checking for directory existence, then trying to create the directory simultaneously.
-         *
-         * In this case, we're creating the directory. If the operation failed, we ensure that the directory
-         * exists before continuing (or raise an exception).
-         */
-        if (!(0, fileutils_1.directoryExists)(cache_directory_1.projectGraphCacheDirectory)) {
-            throw new Error(`Failed to create directory: ${cache_directory_1.projectGraphCacheDirectory}`);
-        }
+
+    fs.unlinkSync(dest);
+  }
+
+  if (options.symlink) {
+    var isWindows = process.platform === 'win32';
+    var linkType = isWindows ? 'file' : null;
+    var resolvedSourcePath = isAbsolute ? sourcePath : path.resolve(process.cwd(), path.dirname(dest), source);
+    if (!fs.existsSync(resolvedSourcePath)) {
+      common.error('Source file does not exist', { continue: true });
+    } else if (isWindows && common.statFollowLinks(resolvedSourcePath).isDirectory()) {
+      linkType = 'junction';
     }
-}
-exports.ensureCacheDirectory = ensureCacheDirectory;
-function readProjectFileMapCache() {
-    perf_hooks_1.performance.mark('read cache:start');
-    ensureCacheDirectory();
-    let data = null;
+
     try {
-        if ((0, fileutils_1.fileExists)(exports.nxFileMap)) {
-            data = (0, fileutils_1.readJsonFile)(exports.nxFileMap);
-        }
+      fs.symlinkSync(linkType === 'junction' ? resolvedSourcePath : source, dest, linkType);
+    } catch (err) {
+      common.error(err.message);
     }
-    catch (error) {
-        console.log(`Error reading '${exports.nxFileMap}'. Continue the process without the cache.`);
-        console.log(error);
+  } else {
+    if (!fs.existsSync(source)) {
+      common.error('Source file does not exist', { continue: true });
     }
-    perf_hooks_1.performance.mark('read cache:end');
-    perf_hooks_1.performance.measure('read cache', 'read cache:start', 'read cache:end');
-    return data !== null && data !== void 0 ? data : null;
-}
-exports.readProjectFileMapCache = readProjectFileMapCache;
-function readProjectGraphCache() {
-    perf_hooks_1.performance.mark('read project-graph:start');
-    ensureCacheDirectory();
-    let data = null;
     try {
-        if ((0, fileutils_1.fileExists)(exports.nxProjectGraph)) {
-            data = (0, fileutils_1.readJsonFile)(exports.nxProjectGraph);
-        }
-    }
-    catch (error) {
-        console.log(`Error reading '${exports.nxProjectGraph}'. Continue the process without the cache.`);
-        console.log(error);
-    }
-    perf_hooks_1.performance.mark('read project-graph:end');
-    perf_hooks_1.performance.measure('read cache', 'read project-graph:start', 'read project-graph:end');
-    return data !== null && data !== void 0 ? data : null;
-}
-exports.readProjectGraphCache = readProjectGraphCache;
-function createProjectFileMapCache(nxJson, packageJsonDeps, projectFileMap, tsConfig) {
-    var _a;
-    const nxJsonPlugins = (nxJson.plugins || []).map((p) => ({
-        name: p,
-        version: packageJsonDeps[p],
-    }));
-    const newValue = {
-        version: '6.0',
-        nxVersion: versions_1.nxVersion,
-        deps: packageJsonDeps,
-        // compilerOptions may not exist, especially for package-based repos
-        pathMappings: ((_a = tsConfig === null || tsConfig === void 0 ? void 0 : tsConfig.compilerOptions) === null || _a === void 0 ? void 0 : _a.paths) || {},
-        nxJsonPlugins,
-        pluginsConfig: nxJson.pluginsConfig,
-        projectFileMap,
-    };
-    return newValue;
-}
-exports.createProjectFileMapCache = createProjectFileMapCache;
-function writeCache(cache, projectGraph) {
-    perf_hooks_1.performance.mark('write cache:start');
-    let retry = 1;
-    let done = false;
-    do {
-        // write first to a unique temporary filename and then do a
-        // rename of the file to the correct filename
-        // this is to avoid any problems with half-written files
-        // in case of crash and/or partially written files due
-        // to multiple parallel processes reading and writing this file
-        const unique = (Math.random().toString(16) + '0000000').slice(2, 10);
-        const tmpProjectGraphPath = `${exports.nxProjectGraph}~${unique}`;
-        const tmpFileMapPath = `${exports.nxFileMap}~${unique}`;
-        try {
-            (0, fileutils_1.writeJsonFile)(tmpProjectGraphPath, projectGraph);
-            (0, fs_extra_1.renameSync)(tmpProjectGraphPath, exports.nxProjectGraph);
-            (0, fileutils_1.writeJsonFile)(tmpFileMapPath, cache);
-            (0, fs_extra_1.renameSync)(tmpFileMapPath, exports.nxFileMap);
-            done = true;
-        }
-        catch (err) {
-            if (err instanceof Error) {
-                console.log(`ERROR (${retry}) when writing \n${err.message}\n${err.stack}`);
-            }
-            else {
-                console.log(`ERROR  (${retry}) unknown error when writing ${exports.nxProjectGraph} and ${exports.nxFileMap}`);
-            }
-            ++retry;
-        }
-    } while (!done && retry < 5);
-    perf_hooks_1.performance.mark('write cache:end');
-    perf_hooks_1.performance.measure('write cache', 'write cache:start', 'write cache:end');
-}
-exports.writeCache = writeCache;
-function shouldRecomputeWholeGraph(cache, packageJsonDeps, projects, nxJson, tsConfig) {
-    if (cache.version !== '6.0') {
-        return true;
-    }
-    if (cache.nxVersion !== versions_1.nxVersion) {
-        return true;
-    }
-    // we have a cached project that is no longer present
-    const cachedNodes = Object.keys(cache.projectFileMap);
-    if (cachedNodes.some((p) => projects.projects[p] === undefined)) {
-        return true;
-    }
-    // a path mapping for an existing project has changed
-    if (Object.keys(cache.pathMappings).some((t) => {
-        var _a, _b;
-        const cached = cache.pathMappings && cache.pathMappings[t]
-            ? JSON.stringify(cache.pathMappings[t])
-            : undefined;
-        const notCached = ((_a = tsConfig === null || tsConfig === void 0 ? void 0 : tsConfig.compilerOptions) === null || _a === void 0 ? void 0 : _a.paths) && ((_b = tsConfig === null || tsConfig === void 0 ? void 0 : tsConfig.compilerOptions) === null || _b === void 0 ? void 0 : _b.paths[t])
-            ? JSON.stringify(tsConfig.compilerOptions.paths[t])
-            : undefined;
-        return cached !== notCached;
-    })) {
-        return true;
-    }
-    // a new plugin has been added
-    if ((nxJson.plugins || []).length !== cache.nxJsonPlugins.length)
-        return true;
-    // a plugin has changed
-    if ((nxJson.plugins || []).some((t) => {
-        const matchingPlugin = cache.nxJsonPlugins.find((p) => p.name === t);
-        if (!matchingPlugin)
-            return true;
-        return matchingPlugin.version !== packageJsonDeps[t];
-    })) {
-        return true;
-    }
-    if (JSON.stringify(nxJson.pluginsConfig) !== JSON.stringify(cache.pluginsConfig)) {
-        return true;
-    }
-    return false;
-}
-exports.shouldRecomputeWholeGraph = shouldRecomputeWholeGraph;
-/*
-This can only be invoked when the list of projects is either the same
-or new projects have been added, so every project in the cache has a corresponding
-project in fileMap
-*/
-function extractCachedFileData(fileMap, c) {
-    const filesToProcess = {};
-    const cachedFileData = {};
-    const currentProjects = Object.keys(fileMap).filter((name) => fileMap[name].length > 0);
-    currentProjects.forEach((p) => {
-        processProjectNode(p, c.projectFileMap, cachedFileData, filesToProcess, fileMap);
-    });
-    return {
-        filesToProcess,
-        cachedFileData,
-    };
-}
-exports.extractCachedFileData = extractCachedFileData;
-function processProjectNode(projectName, cachedFileMap, cachedFileData, filesToProcess, fileMap) {
-    if (!cachedFileMap[projectName]) {
-        filesToProcess[projectName] = fileMap[projectName];
-        return;
-    }
-    const fileDataFromCache = {};
-    for (let f of cachedFileMap[projectName]) {
-        fileDataFromCache[f.file] = f;
-    }
-    if (!cachedFileData[projectName]) {
-        cachedFileData[projectName] = {};
-    }
-    for (let f of fileMap[projectName]) {
-        const fromCache = fileDataFromCache[f.file];
-        if (fromCache && fromCache.hash == f.hash) {
-            cachedFileData[projectName][f.file] = fromCache;
-        }
-        else {
-            if (!filesToProcess[projectName]) {
-                filesToProcess[projectName] = [];
-            }
-            filesToProcess[projectName].push(f);
-        }
+      fs.linkSync(source, dest);
+    } catch (err) {
+      common.error(err.message);
     }
+  }
+  return '';
 }
+module.exports = _ln;
 
 
 /***/ }),
 
-/***/ 97607:
-/***/ ((__unused_webpack_module, exports) => {
+/***/ 42248:
+/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
-"use strict";
+var path = __nccwpck_require__(71017);
+var fs = __nccwpck_require__(57147);
+var common = __nccwpck_require__(60624);
+var glob = __nccwpck_require__(69959);
 
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.withDeps = exports.pruneExternalNodes = exports.isNpmProject = exports.filterNodes = exports.reverse = void 0;
-const reverseMemo = new Map();
-/**
- * Returns a new project graph where all the edges are reversed.
- *
- * For instance, if project A depends on B, in the reversed graph
- * B will depend on A.
- */
-function reverse(graph) {
-    const resultFromMemo = reverseMemo.get(graph);
-    if (resultFromMemo) {
-        return resultFromMemo;
-    }
-    const result = Object.assign(Object.assign({}, graph), { nodes: Object.assign({}, graph.nodes), externalNodes: Object.assign({}, graph.externalNodes), dependencies: {} });
-    Object.keys(graph.nodes).forEach((n) => (result.dependencies[n] = []));
-    // we need to keep external node's reverse dependencies to trace our route back
-    if (graph.externalNodes) {
-        Object.keys(graph.externalNodes).forEach((n) => (result.dependencies[n] = []));
-    }
-    Object.values(graph.dependencies).forEach((byProject) => {
-        byProject.forEach((dep) => {
-            const dependency = result.dependencies[dep.target];
-            if (dependency) {
-                dependency.push({
-                    type: dep.type,
-                    source: dep.target,
-                    target: dep.source,
-                });
-            }
-        });
-    });
-    reverseMemo.set(graph, result);
-    reverseMemo.set(result, graph);
-    return result;
-}
-exports.reverse = reverse;
-function filterNodes(predicate) {
-    return (original) => {
-        const graph = { nodes: {}, dependencies: {} };
-        const added = new Set();
-        Object.values(original.nodes).forEach((n) => {
-            if (!predicate || predicate(n)) {
-                graph.nodes[n.name] = n;
-                graph.dependencies[n.name] = [];
-                added.add(n.name);
-            }
-        });
-        Object.values(original.dependencies).forEach((ds) => {
-            ds.forEach((d) => {
-                if (added.has(d.source) && added.has(d.target)) {
-                    graph.dependencies[d.source].push(d);
-                }
-            });
-        });
-        return graph;
-    };
-}
-exports.filterNodes = filterNodes;
-function isNpmProject(project) {
-    return (project === null || project === void 0 ? void 0 : project.type) === 'npm';
-}
-exports.isNpmProject = isNpmProject;
-exports.pruneExternalNodes = filterNodes();
-function withDeps(original, subsetNodes) {
-    const res = { nodes: {}, dependencies: {} };
-    const visitedNodes = [];
-    const visitedEdges = [];
-    Object.values(subsetNodes).forEach(recurNodes);
-    Object.values(subsetNodes).forEach(recurEdges);
-    return res;
-    // ---------------------------------------------------------------------------
-    function recurNodes(node) {
-        if (visitedNodes.indexOf(node.name) > -1)
-            return;
-        res.nodes[node.name] = node;
-        if (!res.dependencies[node.name]) {
-            res.dependencies[node.name] = [];
-        }
-        visitedNodes.push(node.name);
-        original.dependencies[node.name].forEach((n) => {
-            if (original.nodes[n.target]) {
-                recurNodes(original.nodes[n.target]);
-            }
-        });
-    }
-    function recurEdges(node) {
-        if (visitedEdges.indexOf(node.name) > -1)
-            return;
-        visitedEdges.push(node.name);
-        const ds = original.dependencies[node.name];
-        ds.forEach((n) => {
-            if (!original.nodes[n.target]) {
-                return;
-            }
-            if (!res.dependencies[n.source]) {
-                res.dependencies[n.source] = [];
-            }
-            res.dependencies[n.source].push(n);
-        });
-        ds.forEach((n) => {
-            if (original.nodes[n.target]) {
-                recurEdges(original.nodes[n.target]);
-            }
-        });
-    }
-}
-exports.withDeps = withDeps;
+var globPatternRecursive = path.sep + '**';
 
+common.register('ls', _ls, {
+  cmdOptions: {
+    'R': 'recursive',
+    'A': 'all',
+    'L': 'link',
+    'a': 'all_deprecated',
+    'd': 'directory',
+    'l': 'long',
+  },
+});
 
-/***/ }),
+//@
+//@ ### ls([options,] [path, ...])
+//@ ### ls([options,] path_array)
+//@
+//@ Available options:
+//@
+//@ + `-R`: recursive
+//@ + `-A`: all files (include files beginning with `.`, except for `.` and `..`)
+//@ + `-L`: follow symlinks
+//@ + `-d`: list directories themselves, not their contents
+//@ + `-l`: list objects representing each file, each with fields containing `ls
+//@         -l` output fields. See
+//@         [`fs.Stats`](https://nodejs.org/api/fs.html#fs_class_fs_stats)
+//@         for more info
+//@
+//@ Examples:
+//@
+//@ ```javascript
+//@ ls('projs/*.js');
+//@ ls('-R', '/users/me', '/tmp');
+//@ ls('-R', ['/users/me', '/tmp']); // same as above
+//@ ls('-l', 'file.txt'); // { name: 'file.txt', mode: 33188, nlink: 1, ...}
+//@ ```
+//@
+//@ Returns array of files in the given `path`, or files in
+//@ the current directory if no `path` is  provided.
+function _ls(options, paths) {
+  if (options.all_deprecated) {
+    // We won't support the -a option as it's hard to image why it's useful
+    // (it includes '.' and '..' in addition to '.*' files)
+    // For backwards compatibility we'll dump a deprecated message and proceed as before
+    common.log('ls: Option -a is deprecated. Use -A instead');
+    options.all = true;
+  }
 
-/***/ 14812:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
+  if (!paths) {
+    paths = ['.'];
+  } else {
+    paths = [].slice.call(arguments, 1);
+  }
 
-"use strict";
+  var list = [];
 
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.ProjectGraphBuilder = void 0;
-/**
- * Builder for adding nodes and dependencies to a {@link ProjectGraph}
- */
-const project_graph_1 = __nccwpck_require__(49899);
-const build_project_graph_1 = __nccwpck_require__(60214);
-class ProjectGraphBuilder {
-    constructor(g, fileMap) {
-        this.removedEdges = {};
-        if (g) {
-            this.graph = g;
-            this.fileMap = fileMap || (0, build_project_graph_1.getProjectFileMap)().projectFileMap;
-        }
-        else {
-            this.graph = {
-                nodes: {},
-                externalNodes: {},
-                dependencies: {},
-            };
-            this.fileMap = fileMap || {};
-        }
-    }
-    /**
-     * Merges the nodes and dependencies of p into the built project graph.
-     */
-    mergeProjectGraph(p) {
-        this.graph.nodes = Object.assign(Object.assign({}, this.graph.nodes), p.nodes);
-        this.graph.externalNodes = Object.assign(Object.assign({}, this.graph.externalNodes), p.externalNodes);
-        this.graph.dependencies = Object.assign(Object.assign({}, this.graph.dependencies), p.dependencies);
-    }
-    /**
-     * Adds a project node to the project graph
-     */
-    addNode(node) {
-        // Check if project with the same name already exists
-        if (this.graph.nodes[node.name]) {
-            // Throw if existing project is of a different type
-            if (this.graph.nodes[node.name].type !== node.type) {
-                throw new Error(`Multiple projects are named "${node.name}". One is of type "${node.type}" and the other is of type "${this.graph.nodes[node.name].type}". Please resolve the conflicting project names.`);
-            }
-        }
-        this.graph.nodes[node.name] = node;
-    }
-    /**
-     * Removes a node and all of its dependency edges from the graph
-     */
-    removeNode(name) {
-        if (!this.graph.nodes[name] && !this.graph.externalNodes[name]) {
-            throw new Error(`There is no node named: "${name}"`);
-        }
-        this.removeDependenciesWithNode(name);
-        if (this.graph.nodes[name]) {
-            delete this.graph.nodes[name];
-        }
-        else {
-            delete this.graph.externalNodes[name];
-        }
-    }
-    /**
-     * Adds a external node to the project graph
-     */
-    addExternalNode(node) {
-        // Check if project with the same name already exists
-        if (this.graph.externalNodes[node.name]) {
-            throw new Error(`Multiple projects are named "${node.name}". One has version "${node.data.version}" and the other has version "${this.graph.externalNodes[node.name].data.version}". Please resolve the conflicting package names.`);
-        }
-        this.graph.externalNodes[node.name] = node;
-    }
-    /**
-     * Adds static dependency from source project to target project
-     */
-    addStaticDependency(sourceProjectName, targetProjectName, sourceProjectFile) {
-        // internal nodes must provide sourceProjectFile when creating static dependency
-        // externalNodes do not have sourceProjectFile
-        if (this.graph.nodes[sourceProjectName] && !sourceProjectFile) {
-            throw new Error(`Source project file is required`);
-        }
-        this.addDependency(sourceProjectName, targetProjectName, project_graph_1.DependencyType.static, sourceProjectFile);
-    }
-    /**
-     * Adds dynamic dependency from source project to target project
-     */
-    addDynamicDependency(sourceProjectName, targetProjectName, sourceProjectFile) {
-        if (this.graph.externalNodes[sourceProjectName]) {
-            throw new Error(`External projects can't have "dynamic" dependencies`);
-        }
-        // dynamic dependency is always bound to a file
-        if (!sourceProjectFile) {
-            throw new Error(`Source project file is required`);
-        }
-        this.addDependency(sourceProjectName, targetProjectName, project_graph_1.DependencyType.dynamic, sourceProjectFile);
-    }
-    /**
-     * Adds implicit dependency from source project to target project
-     */
-    addImplicitDependency(sourceProjectName, targetProjectName) {
-        if (this.graph.externalNodes[sourceProjectName]) {
-            throw new Error(`External projects can't have "implicit" dependencies`);
-        }
-        this.addDependency(sourceProjectName, targetProjectName, project_graph_1.DependencyType.implicit);
-    }
-    /**
-     * Removes a dependency from source project to target project
-     */
-    removeDependency(sourceProjectName, targetProjectName) {
-        if (sourceProjectName === targetProjectName) {
-            return;
-        }
-        if (!this.graph.nodes[sourceProjectName]) {
-            throw new Error(`Source project does not exist: ${sourceProjectName}`);
-        }
-        if (!this.graph.nodes[targetProjectName] &&
-            !this.graph.externalNodes[targetProjectName]) {
-            throw new Error(`Target project does not exist: ${targetProjectName}`);
-        }
-        // this.graph.dependencies[sourceProjectName] = this.graph.dependencies[
-        //   sourceProjectName
-        // ].filter((d) => d.target !== targetProjectName);
-        if (!this.removedEdges[sourceProjectName]) {
-            this.removedEdges[sourceProjectName] = new Set();
-        }
-        this.removedEdges[sourceProjectName].add(targetProjectName);
-    }
-    /**
-     * Add an explicit dependency from a file in source project to target project
-     * @deprecated this method will be removed in v17. Use {@link addStaticDependency} or {@link addDynamicDependency} instead
-     */
-    addExplicitDependency(sourceProjectName, sourceProjectFile, targetProjectName) {
-        this.addStaticDependency(sourceProjectName, targetProjectName, sourceProjectFile);
-    }
-    /**
-     * Set version of the project graph
-     */
-    setVersion(version) {
-        this.graph.version = version;
-    }
-    getUpdatedProjectGraph() {
-        for (const sourceProject of Object.keys(this.graph.nodes)) {
-            const alreadySetTargetProjects = this.calculateAlreadySetTargetDeps(sourceProject);
-            this.graph.dependencies[sourceProject] = [
-                ...alreadySetTargetProjects.values(),
-            ].flatMap((depsMap) => [...depsMap.values()]);
-            const fileDeps = this.calculateTargetDepsFromFiles(sourceProject);
-            for (const [targetProject, types] of fileDeps.entries()) {
-                // only add known nodes
-                if (!this.graph.nodes[targetProject] &&
-                    !this.graph.externalNodes[targetProject]) {
-                    continue;
-                }
-                for (const type of types.values()) {
-                    if (!alreadySetTargetProjects.has(targetProject) ||
-                        !alreadySetTargetProjects.get(targetProject).has(type)) {
-                        if (!this.removedEdges[sourceProject] ||
-                            !this.removedEdges[sourceProject].has(targetProject)) {
-                            this.graph.dependencies[sourceProject].push({
-                                source: sourceProject,
-                                target: targetProject,
-                                type,
-                            });
-                        }
-                    }
-                }
-            }
-        }
-        return this.graph;
-    }
-    addDependency(sourceProjectName, targetProjectName, type, sourceProjectFile) {
-        if (sourceProjectName === targetProjectName) {
-            return;
-        }
-        if (!this.graph.nodes[sourceProjectName] &&
-            !this.graph.externalNodes[sourceProjectName]) {
-            throw new Error(`Source project does not exist: ${sourceProjectName}`);
-        }
-        if (!this.graph.nodes[targetProjectName] &&
-            !this.graph.externalNodes[targetProjectName] &&
-            !sourceProjectFile) {
-            throw new Error(`Target project does not exist: ${targetProjectName}`);
-        }
-        if (this.graph.externalNodes[sourceProjectName] &&
-            this.graph.nodes[targetProjectName]) {
-            throw new Error(`External projects can't depend on internal projects`);
-        }
-        if (!this.graph.dependencies[sourceProjectName]) {
-            this.graph.dependencies[sourceProjectName] = [];
-        }
-        const isDuplicate = !!this.graph.dependencies[sourceProjectName].find((d) => d.target === targetProjectName && d.type === type);
-        if (sourceProjectFile) {
-            const source = this.graph.nodes[sourceProjectName];
-            if (!source) {
-                throw new Error(`Source project is not a project node: ${sourceProjectName}`);
-            }
-            const fileData = (this.fileMap[sourceProjectName] || []).find((f) => f.file === sourceProjectFile);
-            if (!fileData) {
-                throw new Error(`Source project ${sourceProjectName} does not have a file: ${sourceProjectFile}`);
-            }
-            if (!fileData.deps) {
-                fileData.deps = [];
-            }
-            if (!fileData.deps.find((t) => (0, project_graph_1.fileDataDepTarget)(t) === targetProjectName &&
-                (0, project_graph_1.fileDataDepType)(t) === type)) {
-                const dep = type === 'static' ? targetProjectName : [targetProjectName, type];
-                fileData.deps.push(dep);
-            }
-        }
-        else if (!isDuplicate) {
-            // only add to dependencies section if the source file is not specified
-            // and not already added
-            this.graph.dependencies[sourceProjectName].push({
-                source: sourceProjectName,
-                target: targetProjectName,
-                type,
-            });
-        }
+  function pushFile(abs, relName, stat) {
+    if (process.platform === 'win32') {
+      relName = relName.replace(/\\/g, '/');
     }
-    removeDependenciesWithNode(name) {
-        // remove all source dependencies
-        delete this.graph.dependencies[name];
-        // remove all target dependencies
-        for (const dependencies of Object.values(this.graph.dependencies)) {
-            for (const [index, { source, target }] of dependencies.entries()) {
-                if (target === name) {
-                    const deps = this.graph.dependencies[source];
-                    this.graph.dependencies[source] = [
-                        ...deps.slice(0, index),
-                        ...deps.slice(index + 1),
-                    ];
-                    if (this.graph.dependencies[source].length === 0) {
-                        delete this.graph.dependencies[source];
-                    }
-                }
-            }
-        }
+    if (options.long) {
+      stat = stat || (options.link ? common.statFollowLinks(abs) : common.statNoFollowLinks(abs));
+      list.push(addLsAttributes(relName, stat));
+    } else {
+      // list.push(path.relative(rel || '.', file));
+      list.push(relName);
     }
-    calculateTargetDepsFromFiles(sourceProject) {
-        const fileDeps = new Map();
-        const files = this.fileMap[sourceProject] || [];
-        if (!files) {
-            return fileDeps;
-        }
-        for (let f of files) {
-            if (f.deps) {
-                for (let d of f.deps) {
-                    const target = (0, project_graph_1.fileDataDepTarget)(d);
-                    if (!fileDeps.has(target)) {
-                        fileDeps.set(target, new Set([(0, project_graph_1.fileDataDepType)(d)]));
-                    }
-                    else {
-                        fileDeps.get(target).add((0, project_graph_1.fileDataDepType)(d));
-                    }
-                }
-            }
-        }
-        return fileDeps;
+  }
+
+  paths.forEach(function (p) {
+    var stat;
+
+    try {
+      stat = options.link ? common.statFollowLinks(p) : common.statNoFollowLinks(p);
+      // follow links to directories by default
+      if (stat.isSymbolicLink()) {
+        /* istanbul ignore next */
+        // workaround for https://github.com/shelljs/shelljs/issues/795
+        // codecov seems to have a bug that miscalculate this block as uncovered.
+        // but according to nyc report this block does get covered.
+        try {
+          var _stat = common.statFollowLinks(p);
+          if (_stat.isDirectory()) {
+            stat = _stat;
+          }
+        } catch (_) {} // bad symlink, treat it like a file
+      }
+    } catch (e) {
+      common.error('no such file or directory: ' + p, 2, { continue: true });
+      return;
     }
-    calculateAlreadySetTargetDeps(sourceProject) {
-        const alreadySetTargetProjects = new Map();
-        if (this.graph.dependencies[sourceProject]) {
-            const removed = this.removedEdges[sourceProject];
-            for (const d of this.graph.dependencies[sourceProject]) {
-                // static and dynamic dependencies of internal projects
-                // will be rebuilt based on the file dependencies
-                // we only need to keep the implicit dependencies
-                if (d.type === project_graph_1.DependencyType.implicit && !(removed === null || removed === void 0 ? void 0 : removed.has(d.target))) {
-                    if (!alreadySetTargetProjects.has(d.target)) {
-                        alreadySetTargetProjects.set(d.target, new Map([[d.type, d]]));
-                    }
-                    else {
-                        alreadySetTargetProjects.get(d.target).set(d.type, d);
-                    }
-                }
+
+    // If the stat succeeded
+    if (stat.isDirectory() && !options.directory) {
+      if (options.recursive) {
+        // use glob, because it's simple
+        glob.sync(p + globPatternRecursive, { dot: options.all, follow: options.link })
+          .forEach(function (item) {
+            // Glob pattern returns the directory itself and needs to be filtered out.
+            if (path.relative(p, item)) {
+              pushFile(item, path.relative(p, item));
             }
-        }
-        return alreadySetTargetProjects;
+          });
+      } else if (options.all) {
+        // use fs.readdirSync, because it's fast
+        fs.readdirSync(p).forEach(function (item) {
+          pushFile(path.join(p, item), item);
+        });
+      } else {
+        // use fs.readdirSync and then filter out secret files
+        fs.readdirSync(p).forEach(function (item) {
+          if (item[0] !== '.') {
+            pushFile(path.join(p, item), item);
+          }
+        });
+      }
+    } else {
+      pushFile(p, p, stat);
     }
+  });
+
+  // Add methods, to make this more compatible with ShellStrings
+  return list;
 }
-exports.ProjectGraphBuilder = ProjectGraphBuilder;
+
+function addLsAttributes(pathName, stats) {
+  // Note: this object will contain more information than .toString() returns
+  stats.name = pathName;
+  stats.toString = function () {
+    // Return a string resembling unix's `ls -l` format
+    return [this.mode, this.nlink, this.uid, this.gid, this.size, this.mtime, this.name].join(' ');
+  };
+  return stats;
+}
+
+module.exports = _ls;
 
 
 /***/ }),
 
-/***/ 22055:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
+/***/ 27707:
+/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
-"use strict";
+var common = __nccwpck_require__(60624);
+var fs = __nccwpck_require__(57147);
+var path = __nccwpck_require__(71017);
 
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.createProjectGraphAsync = exports.buildProjectGraphWithoutDaemon = exports.readProjectsConfigurationFromProjectGraph = exports.readCachedProjectConfiguration = exports.readCachedProjectGraph = void 0;
-const tslib_1 = __nccwpck_require__(51796);
-const nx_deps_cache_1 = __nccwpck_require__(65959);
-const build_project_graph_1 = __nccwpck_require__(60214);
-const output_1 = __nccwpck_require__(34548);
-const impl_1 = __nccwpck_require__(43265);
-const tmp_dir_1 = __nccwpck_require__(87196);
-const strip_indents_1 = __nccwpck_require__(4477);
-const client_1 = __nccwpck_require__(55942);
-const fileutils_1 = __nccwpck_require__(47930);
-const workspace_root_1 = __nccwpck_require__(65766);
-const workspaces_1 = __nccwpck_require__(98715);
-const file_map_utils_1 = __nccwpck_require__(11223);
-const perf_hooks_1 = __nccwpck_require__(4074);
-/**
- * Synchronously reads the latest cached copy of the workspace's ProjectGraph.
- * @throws {Error} if there is no cached ProjectGraph to read from
- */
-function readCachedProjectGraph() {
-    const projectGraphCache = (0, nx_deps_cache_1.readProjectGraphCache)();
-    const angularSpecificError = (0, fileutils_1.fileExists)(`${workspace_root_1.workspaceRoot}/angular.json`)
-        ? (0, strip_indents_1.stripIndents) `
-      Make sure invoke 'node ./decorate-angular-cli.js' in your postinstall script.
-      The decorated CLI will compute the project graph.
-      'ng --help' should say 'Smart, Fast and Extensible Build System'.
-      `
-        : '';
-    if (!projectGraphCache) {
-        throw new Error((0, strip_indents_1.stripIndents) `
-      [readCachedProjectGraph] ERROR: No cached ProjectGraph is available.
+common.register('mkdir', _mkdir, {
+  cmdOptions: {
+    'p': 'fullpath',
+  },
+});
 
-      If you are leveraging \`readCachedProjectGraph()\` directly then you will need to refactor your usage to first ensure that
-      the ProjectGraph is created by calling \`await createProjectGraphAsync()\` somewhere before attempting to read the data.
+// Recursively creates `dir`
+function mkdirSyncRecursive(dir) {
+  var baseDir = path.dirname(dir);
 
-      If you encounter this error as part of running standard \`nx\` commands then please open an issue on https://github.com/nrwl/nx
+  // Prevents some potential problems arising from malformed UNCs or
+  // insufficient permissions.
+  /* istanbul ignore next */
+  if (baseDir === dir) {
+    common.error('dirname() failed: [' + dir + ']');
+  }
 
-      ${angularSpecificError}
-    `);
-    }
-    return projectGraphCache;
-}
-exports.readCachedProjectGraph = readCachedProjectGraph;
-function readCachedProjectConfiguration(projectName) {
-    const graph = readCachedProjectGraph();
-    const node = graph.nodes[projectName];
-    return node.data;
-}
-exports.readCachedProjectConfiguration = readCachedProjectConfiguration;
-function readProjectsConfigurationFromProjectGraph(projectGraph) {
-    return {
-        projects: Object.fromEntries(Object.entries(projectGraph.nodes).map(([project, { data }]) => [
-            project,
-            data,
-        ])),
-        version: 2,
-    };
-}
-exports.readProjectsConfigurationFromProjectGraph = readProjectsConfigurationFromProjectGraph;
-function buildProjectGraphWithoutDaemon() {
-    return tslib_1.__awaiter(this, void 0, void 0, function* () {
-        yield impl_1.fileHasher.ensureInitialized();
-        const projectConfigurations = new workspaces_1.Workspaces(workspace_root_1.workspaceRoot).readProjectsConfigurations();
-        const { projectFileMap, allWorkspaceFiles } = (0, file_map_utils_1.createProjectFileMap)(projectConfigurations, impl_1.fileHasher.allFileData());
-        const cacheEnabled = process.env.NX_CACHE_PROJECT_GRAPH !== 'false';
-        return (yield (0, build_project_graph_1.buildProjectGraphUsingProjectFileMap)(projectConfigurations, projectFileMap, allWorkspaceFiles, cacheEnabled ? (0, nx_deps_cache_1.readProjectFileMapCache)() : null, cacheEnabled)).projectGraph;
-    });
-}
-exports.buildProjectGraphWithoutDaemon = buildProjectGraphWithoutDaemon;
-function handleProjectGraphError(opts, e) {
-    if (opts.exitOnError) {
-        const lines = e.message.split('\n');
-        output_1.output.error({
-            title: lines[0],
-            bodyLines: lines.slice(1),
-        });
-        if (process.env.NX_VERBOSE_LOGGING === 'true') {
-            console.error(e);
-        }
-        process.exit(1);
-    }
-    else {
-        throw e;
-    }
-}
-/**
- * Computes and returns a ProjectGraph.
- *
- * Nx will compute the graph either in a daemon process or in the current process.
- *
- * Nx will compute it in the current process if:
- * * The process is running in CI (CI env variable is to true or other common variables used by CI providers are set).
- * * It is running in the docker container.
- * * The daemon process is disabled because of the previous error when starting the daemon.
- * * `NX_DAEMON` is set to `false`.
- * * `useDaemon` is set to false in `nx.json`
- *
- * `NX_DAEMON` env variable takes precedence:
- * * If it is set to true, the daemon will always be used.
- * * If it is set to false, the graph will always be computed in the current process.
- *
- * Tip: If you want to debug project graph creation, run your command with NX_DAEMON=false.
- *
- * Nx uses two layers of caching: the information about explicit dependencies stored on the disk and the information
- * stored in the daemon process. To reset both run: `nx reset`.
- */
-function createProjectGraphAsync(opts = {
-    exitOnError: false,
-    resetDaemonClient: false,
-}) {
-    return tslib_1.__awaiter(this, void 0, void 0, function* () {
-        perf_hooks_1.performance.mark('create-project-graph-async:start');
-        if (!client_1.daemonClient.enabled()) {
-            try {
-                const res = yield buildProjectGraphWithoutDaemon();
-                perf_hooks_1.performance.mark('create-project-graph-async:end');
-                perf_hooks_1.performance.measure('create-project-graph-async', 'create-project-graph-async:start', 'create-project-graph-async:end');
-                return res;
-            }
-            catch (e) {
-                handleProjectGraphError(opts, e);
-            }
-        }
-        else {
-            try {
-                const projectGraph = yield client_1.daemonClient.getProjectGraph();
-                if (opts.resetDaemonClient) {
-                    client_1.daemonClient.reset();
-                }
-                perf_hooks_1.performance.mark('create-project-graph-async:end');
-                perf_hooks_1.performance.measure('create-project-graph-async', 'create-project-graph-async:start', 'create-project-graph-async:end');
-                return projectGraph;
-            }
-            catch (e) {
-                if (e.message.indexOf('inotify_add_watch') > -1) {
-                    // common errors with the daemon due to OS settings (cannot watch all the files available)
-                    output_1.output.note({
-                        title: `Unable to start Nx Daemon due to the limited amount of inotify watches, continuing without the daemon.`,
-                        bodyLines: [
-                            'For more information read: https://askubuntu.com/questions/1088272/inotify-add-watch-failed-no-space-left-on-device',
-                            'Nx Daemon is going to be disabled until you run "nx reset".',
-                        ],
-                    });
-                    (0, tmp_dir_1.markDaemonAsDisabled)();
-                    return buildProjectGraphWithoutDaemon();
-                }
-                if (e.internalDaemonError) {
-                    const errorLogFile = (0, tmp_dir_1.writeDaemonLogs)(e.message);
-                    output_1.output.warn({
-                        title: `Nx Daemon was not able to compute the project graph.`,
-                        bodyLines: [
-                            `Log file with the error: ${errorLogFile}`,
-                            `Please file an issue at https://github.com/nrwl/nx`,
-                            'Nx Daemon is going to be disabled until you run "nx reset".',
-                        ],
-                    });
-                    (0, tmp_dir_1.markDaemonAsDisabled)();
-                    return buildProjectGraphWithoutDaemon();
-                }
-                handleProjectGraphError(opts, e);
-            }
-        }
-    });
-}
-exports.createProjectGraphAsync = createProjectGraphAsync;
+  // Base dir exists, no recursion necessary
+  if (fs.existsSync(baseDir)) {
+    fs.mkdirSync(dir, parseInt('0777', 8));
+    return;
+  }
 
+  // Base dir does not exist, go recursive
+  mkdirSyncRecursive(baseDir);
 
-/***/ }),
+  // Base dir created, can create dir
+  fs.mkdirSync(dir, parseInt('0777', 8));
+}
 
-/***/ 36265:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
+//@
+//@ ### mkdir([options,] dir [, dir ...])
+//@ ### mkdir([options,] dir_array)
+//@
+//@ Available options:
+//@
+//@ + `-p`: full path (and create intermediate directories, if necessary)
+//@
+//@ Examples:
+//@
+//@ ```javascript
+//@ mkdir('-p', '/tmp/a/b/c/d', '/tmp/e/f/g');
+//@ mkdir('-p', ['/tmp/a/b/c/d', '/tmp/e/f/g']); // same as above
+//@ ```
+//@
+//@ Creates directories.
+function _mkdir(options, dirs) {
+  if (!dirs) common.error('no paths given');
 
-"use strict";
+  if (typeof dirs === 'string') {
+    dirs = [].slice.call(arguments, 1);
+  }
+  // if it's array leave it as it is
 
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.normalizeProjectRoot = exports.findProjectForPath = exports.createProjectRootMappings = exports.createProjectRootMappingsFromProjectConfigurations = void 0;
-const path_1 = __nccwpck_require__(71017);
-/**
- * This creates a map of project roots to project names to easily look up the project of a file
- * @param projects This is the map of project configurations commonly found in "workspace.json"
- */
-function createProjectRootMappingsFromProjectConfigurations(projects) {
-    const projectRootMappings = new Map();
-    for (const projectName of Object.keys(projects)) {
-        const root = projects[projectName].root;
-        projectRootMappings.set(normalizeProjectRoot(root), projectName);
+  dirs.forEach(function (dir) {
+    try {
+      var stat = common.statNoFollowLinks(dir);
+      if (!options.fullpath) {
+        common.error('path already exists: ' + dir, { continue: true });
+      } else if (stat.isFile()) {
+        common.error('cannot create directory ' + dir + ': File exists', { continue: true });
+      }
+      return; // skip dir
+    } catch (e) {
+      // do nothing
     }
-    return projectRootMappings;
-}
-exports.createProjectRootMappingsFromProjectConfigurations = createProjectRootMappingsFromProjectConfigurations;
-/**
- * This creates a map of project roots to project names to easily look up the project of a file
- * @param nodes This is the nodes from the project graph
- */
-function createProjectRootMappings(nodes) {
-    const projectRootMappings = new Map();
-    for (const projectName of Object.keys(nodes)) {
-        let root = nodes[projectName].data.root;
-        projectRootMappings.set(normalizeProjectRoot(root), projectName);
+
+    // Base dir does not exist, and no -p option given
+    var baseDir = path.dirname(dir);
+    if (!fs.existsSync(baseDir) && !options.fullpath) {
+      common.error('no such file or directory: ' + baseDir, { continue: true });
+      return; // skip dir
     }
-    return projectRootMappings;
-}
-exports.createProjectRootMappings = createProjectRootMappings;
-/**
- * Locates a project in projectRootMap based on a file within it
- * @param filePath path that is inside of projectName. This should be relative from the workspace root
- * @param projectRootMap Map Use {@link createProjectRootMappings} to create this
- */
-function findProjectForPath(filePath, projectRootMap) {
-    let currentPath = filePath;
-    for (; currentPath != (0, path_1.dirname)(currentPath); currentPath = (0, path_1.dirname)(currentPath)) {
-        const p = projectRootMap.get(currentPath);
-        if (p) {
-            return p;
-        }
+
+    try {
+      if (options.fullpath) {
+        mkdirSyncRecursive(path.resolve(dir));
+      } else {
+        fs.mkdirSync(dir, parseInt('0777', 8));
+      }
+    } catch (e) {
+      var reason;
+      if (e.code === 'EACCES') {
+        reason = 'Permission denied';
+      } else if (e.code === 'ENOTDIR' || e.code === 'ENOENT') {
+        reason = 'Not a directory';
+      } else {
+        /* istanbul ignore next */
+        throw e;
+      }
+      common.error('cannot create directory ' + dir + ': ' + reason, { continue: true });
     }
-    return projectRootMap.get(currentPath);
-}
-exports.findProjectForPath = findProjectForPath;
-function normalizeProjectRoot(root) {
-    root = root === '' ? '.' : root;
-    return root && root.endsWith('/') ? root.substring(0, root.length - 1) : root;
-}
-exports.normalizeProjectRoot = normalizeProjectRoot;
+  });
+  return '';
+} // mkdir
+module.exports = _mkdir;
 
 
 /***/ }),
 
-/***/ 51635:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
+/***/ 78146:
+/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
-"use strict";
+var fs = __nccwpck_require__(57147);
+var path = __nccwpck_require__(71017);
+var common = __nccwpck_require__(60624);
+var cp = __nccwpck_require__(64395);
+var rm = __nccwpck_require__(54369);
 
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.assertWorkspaceValidity = void 0;
-const find_matching_projects_1 = __nccwpck_require__(56668);
-const output_1 = __nccwpck_require__(34548);
-function assertWorkspaceValidity(projectsConfigurations, nxJson) {
-    const projectNames = Object.keys(projectsConfigurations.projects);
-    const projectGraphNodes = projectNames.reduce((graph, project) => {
-        const projectConfiguration = projectsConfigurations.projects[project];
-        graph[project] = {
-            name: project,
-            type: projectConfiguration.projectType === 'library' ? 'lib' : 'app',
-            data: Object.assign({}, projectConfiguration),
-        };
-        return graph;
-    }, {});
-    const projects = Object.assign({}, projectsConfigurations.projects);
-    const invalidImplicitDependencies = new Map();
-    if (nxJson.implicitDependencies) {
-        output_1.output.warn({
-            title: 'Using `implicitDependencies` for global implicit dependencies configuration is no longer supported.',
-            bodyLines: [
-                'Use "namedInputs" instead. You can run "nx repair" to automatically migrate your configuration.',
-                'For more information about the usage of "namedInputs" see https://nx.dev/deprecated/global-implicit-dependencies#global-implicit-dependencies',
-            ],
-        });
-    }
-    projectNames
-        .filter((projectName) => {
-        const project = projects[projectName];
-        return !!project.implicitDependencies;
-    })
-        .reduce((map, projectName) => {
-        const project = projects[projectName];
-        detectAndSetInvalidProjectGlobValues(map, projectName, project.implicitDependencies, projects, projectGraphNodes);
-        return map;
-    }, invalidImplicitDependencies);
-    if (invalidImplicitDependencies.size === 0) {
-        return;
-    }
-    let message = `The following implicitDependencies point to non-existent project(s):\n`;
-    message += [...invalidImplicitDependencies.keys()]
-        .map((key) => {
-        const projectNames = invalidImplicitDependencies.get(key);
-        return `  ${key}\n${projectNames
-            .map((projectName) => `    ${projectName}`)
-            .join('\n')}`;
-    })
-        .join('\n\n');
-    throw new Error(`Configuration Error\n${message}`);
-}
-exports.assertWorkspaceValidity = assertWorkspaceValidity;
-function detectAndSetInvalidProjectGlobValues(map, sourceName, desiredImplicitDeps, projectConfigurations, projects) {
-    const invalidProjectsOrGlobs = desiredImplicitDeps.filter((implicit) => {
-        const projectName = implicit.startsWith('!')
-            ? implicit.substring(1)
-            : implicit;
-        return !(projectConfigurations[projectName] ||
-            (0, find_matching_projects_1.findMatchingProjects)([implicit], projects).length);
-    });
-    if (invalidProjectsOrGlobs.length > 0) {
-        map.set(sourceName, invalidProjectsOrGlobs);
-    }
+common.register('mv', _mv, {
+  cmdOptions: {
+    'f': '!no_force',
+    'n': 'no_force',
+  },
+});
+
+// Checks if cureent file was created recently
+function checkRecentCreated(sources, index) {
+  var lookedSource = sources[index];
+  return sources.slice(0, index).some(function (src) {
+    return path.basename(src) === path.basename(lookedSource);
+  });
 }
 
+//@
+//@ ### mv([options ,] source [, source ...], dest')
+//@ ### mv([options ,] source_array, dest')
+//@
+//@ Available options:
+//@
+//@ + `-f`: force (default behavior)
+//@ + `-n`: no-clobber
+//@
+//@ Examples:
+//@
+//@ ```javascript
+//@ mv('-n', 'file', 'dir/');
+//@ mv('file1', 'file2', 'dir/');
+//@ mv(['file1', 'file2'], 'dir/'); // same as above
+//@ ```
+//@
+//@ Moves `source` file(s) to `dest`.
+function _mv(options, sources, dest) {
+  // Get sources, dest
+  if (arguments.length < 3) {
+    common.error('missing  and/or ');
+  } else if (arguments.length > 3) {
+    sources = [].slice.call(arguments, 1, arguments.length - 1);
+    dest = arguments[arguments.length - 1];
+  } else if (typeof sources === 'string') {
+    sources = [sources];
+  } else {
+    // TODO(nate): figure out if we actually need this line
+    common.error('invalid arguments');
+  }
 
-/***/ }),
+  var exists = fs.existsSync(dest);
+  var stats = exists && common.statFollowLinks(dest);
 
-/***/ 20858:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
+  // Dest is not existing dir, but multiple sources given
+  if ((!exists || !stats.isDirectory()) && sources.length > 1) {
+    common.error('dest is not a directory (too many sources)');
+  }
 
-"use strict";
+  // Dest is an existing file, but no -f given
+  if (exists && stats.isFile() && options.no_force) {
+    common.error('dest file already exists: ' + dest);
+  }
 
-var _a;
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.projectGraphCacheDirectory = exports.cacheDir = void 0;
-const fs_1 = __nccwpck_require__(57147);
-const path_1 = __nccwpck_require__(71017);
-const fileutils_1 = __nccwpck_require__(47930);
-const workspace_root_1 = __nccwpck_require__(65766);
-function readCacheDirectoryProperty(root) {
-    try {
-        const nxJson = (0, fileutils_1.readJsonFile)((0, path_1.join)(root, 'nx.json'));
-        return nxJson.tasksRunnerOptions.default.options.cacheDirectory;
-    }
-    catch (_a) {
-        return undefined;
+  sources.forEach(function (src, srcIndex) {
+    if (!fs.existsSync(src)) {
+      common.error('no such file or directory: ' + src, { continue: true });
+      return; // skip file
     }
-}
-function absolutePath(root, path) {
-    if ((0, path_1.isAbsolute)(path)) {
-        return path;
+
+    // If here, src exists
+
+    // When copying to '/path/dir':
+    //    thisDest = '/path/dir/file1'
+    var thisDest = dest;
+    if (fs.existsSync(dest) && common.statFollowLinks(dest).isDirectory()) {
+      thisDest = path.normalize(dest + '/' + path.basename(src));
     }
-    else {
-        return (0, path_1.join)(root, path);
+
+    var thisDestExists = fs.existsSync(thisDest);
+
+    if (thisDestExists && checkRecentCreated(sources, srcIndex)) {
+      // cannot overwrite file created recently in current execution, but we want to continue copying other files
+      if (!options.no_force) {
+        common.error("will not overwrite just-created '" + thisDest + "' with '" + src + "'", { continue: true });
+      }
+      return;
     }
-}
-function cacheDirectory(root, cacheDirectory) {
-    const cacheDirFromEnv = process.env.NX_CACHE_DIRECTORY;
-    if (cacheDirFromEnv) {
-        cacheDirectory = cacheDirFromEnv;
+
+    if (fs.existsSync(thisDest) && options.no_force) {
+      common.error('dest file already exists: ' + thisDest, { continue: true });
+      return; // skip file
     }
-    if (cacheDirectory) {
-        return absolutePath(root, cacheDirectory);
+
+    if (path.resolve(src) === path.dirname(path.resolve(thisDest))) {
+      common.error('cannot move to self: ' + src, { continue: true });
+      return; // skip file
     }
-    else {
-        return defaultCacheDirectory(root);
+
+    try {
+      fs.renameSync(src, thisDest);
+    } catch (e) {
+      /* istanbul ignore next */
+      if (e.code === 'EXDEV') {
+        // If we're trying to `mv` to an external partition, we'll actually need
+        // to perform a copy and then clean up the original file. If either the
+        // copy or the rm fails with an exception, we should allow this
+        // exception to pass up to the top level.
+        cp('-r', src, thisDest);
+        rm('-rf', src);
+      }
     }
-}
-function defaultCacheDirectory(root) {
-    return (0, fs_1.existsSync)((0, path_1.join)(root, '.nx'))
-        ? (0, path_1.join)(root, '.nx', 'cache')
-        : (0, path_1.join)(root, 'node_modules', '.cache', 'nx');
-}
-/**
- * Path to the directory where Nx stores its cache and daemon-related files.
- */
-exports.cacheDir = cacheDirectory(workspace_root_1.workspaceRoot, readCacheDirectoryProperty(workspace_root_1.workspaceRoot));
-exports.projectGraphCacheDirectory = absolutePath(workspace_root_1.workspaceRoot, (_a = process.env.NX_PROJECT_GRAPH_CACHE_DIRECTORY) !== null && _a !== void 0 ? _a : defaultCacheDirectory(workspace_root_1.workspaceRoot));
+  }); // forEach(src)
+  return '';
+} // mv
+module.exports = _mv;
 
 
 /***/ }),
 
-/***/ 73133:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
+/***/ 12425:
+/***/ (() => {
 
-"use strict";
+// see dirs.js
 
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.codeFrameColumns = void 0;
-// Adapted from https://raw.githubusercontent.com/babel/babel/4108524/packages/babel-code-frame/src/index.js
-const chalk = __nccwpck_require__(29541);
-/**
- * Chalk styles for code frame token types.
- */
-function getDefs(chalk) {
-    return {
-        gutter: chalk.grey,
-        marker: chalk.red.bold,
-        message: chalk.red.bold,
-    };
-}
-/**
- * RegExp to test for newlines in terminal.
- */
-const NEWLINE = /\r\n|[\n\r\u2028\u2029]/;
-/**
- * Extract what lines should be marked and highlighted.
- */
-function getMarkerLines(loc, source, opts = {}) {
-    const startLoc = Object.assign({ column: 0, line: -1 }, loc.start);
-    const endLoc = Object.assign(Object.assign({}, startLoc), loc.end);
-    const { linesAbove = 2, linesBelow = 3 } = opts || {};
-    const startLine = startLoc.line;
-    const startColumn = startLoc.column;
-    const endLine = endLoc.line;
-    const endColumn = endLoc.column;
-    let start = Math.max(startLine - (linesAbove + 1), 0);
-    let end = Math.min(source.length, endLine + linesBelow);
-    if (startLine === -1) {
-        start = 0;
-    }
-    if (endLine === -1) {
-        end = source.length;
-    }
-    const lineDiff = endLine - startLine;
-    const markerLines = {};
-    if (lineDiff) {
-        for (let i = 0; i <= lineDiff; i++) {
-            const lineNumber = i + startLine;
-            if (!startColumn) {
-                markerLines[lineNumber] = true;
-            }
-            else if (i === 0) {
-                const sourceLength = source[lineNumber - 1].length;
-                markerLines[lineNumber] = [startColumn, sourceLength - startColumn + 1];
-            }
-            else if (i === lineDiff) {
-                markerLines[lineNumber] = [0, endColumn];
-            }
-            else {
-                const sourceLength = source[lineNumber - i].length;
-                markerLines[lineNumber] = [0, sourceLength];
-            }
-        }
-    }
-    else {
-        if (startColumn === endColumn) {
-            if (startColumn) {
-                markerLines[startLine] = [startColumn, 0];
-            }
-            else {
-                markerLines[startLine] = true;
-            }
-        }
-        else {
-            markerLines[startLine] = [startColumn, endColumn - startColumn];
-        }
-    }
-    return { start, end, markerLines };
-}
-function codeFrameColumns(rawLines, loc, opts = {}) {
-    const defs = getDefs(chalk);
-    const lines = rawLines.split(NEWLINE);
-    const { start, end, markerLines } = getMarkerLines(loc, lines, opts);
-    const numberMaxWidth = String(end).length;
-    const highlightedLines = opts.highlight ? opts.highlight(rawLines) : rawLines;
-    let frame = highlightedLines
-        .split(NEWLINE)
-        .slice(start, end)
-        .map((line, index) => {
-        const number = start + 1 + index;
-        const paddedNumber = ` ${number}`.slice(-numberMaxWidth);
-        const gutter = ` ${paddedNumber} | `;
-        const hasMarker = markerLines[number];
-        if (hasMarker) {
-            let markerLine = '';
-            if (Array.isArray(hasMarker)) {
-                const markerSpacing = line
-                    .slice(0, Math.max(hasMarker[0] - 1, 0))
-                    .replace(/[^\t]/g, ' ');
-                const numberOfMarkers = hasMarker[1] || 1;
-                markerLine = [
-                    '\n ',
-                    defs.gutter(gutter.replace(/\d/g, ' ')),
-                    markerSpacing,
-                    defs.marker('^').repeat(numberOfMarkers),
-                ].join('');
-            }
-            return [defs.marker('>'), defs.gutter(gutter), line, markerLine].join('');
-        }
-        else {
-            return ` ${defs.gutter(gutter)}${line}`;
-        }
-    })
-        .join('\n');
-    return chalk.reset(frame);
-}
-exports.codeFrameColumns = codeFrameColumns;
+
+/***/ }),
+
+/***/ 68943:
+/***/ (() => {
+
+// see dirs.js
 
 
 /***/ }),
 
-/***/ 81904:
-/***/ ((__unused_webpack_module, exports) => {
+/***/ 90909:
+/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
-"use strict";
+var path = __nccwpck_require__(71017);
+var common = __nccwpck_require__(60624);
 
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.consumeMessagesFromSocket = void 0;
-function consumeMessagesFromSocket(callback) {
-    let message = '';
-    return (data) => {
-        const chunk = data.toString();
-        if (chunk.codePointAt(chunk.length - 1) === 4) {
-            message += chunk.substring(0, chunk.length - 1);
-            // Server may send multiple messages in one chunk, so splitting by 0x4
-            const messages = message.split('');
-            for (const splitMessage of messages) {
-                callback(splitMessage);
-            }
-            message = '';
-        }
-        else {
-            message += chunk;
-        }
-    };
+common.register('pwd', _pwd, {
+  allowGlobbing: false,
+});
+
+//@
+//@ ### pwd()
+//@
+//@ Returns the current directory.
+function _pwd() {
+  var pwd = path.resolve(process.cwd());
+  return pwd;
 }
-exports.consumeMessagesFromSocket = consumeMessagesFromSocket;
+module.exports = _pwd;
 
 
 /***/ }),
 
-/***/ 47930:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
+/***/ 54369:
+/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
-"use strict";
-
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.readFileIfExisting = exports.extractFileFromTarball = exports.isRelativePath = exports.createDirectory = exports.fileExists = exports.directoryExists = exports.writeJsonFile = exports.readYamlFile = exports.readJsonFile = void 0;
-const tslib_1 = __nccwpck_require__(51796);
-const json_1 = __nccwpck_require__(43684);
-const fs_1 = __nccwpck_require__(57147);
-const path_1 = __nccwpck_require__(71017);
-const tar = __nccwpck_require__(93983);
-const zlib_1 = __nccwpck_require__(59796);
-/**
- * Reads a JSON file and returns the object the JSON content represents.
- *
- * @param path A path to a file.
- * @param options JSON parse options
- * @returns Object the JSON content of the file represents
- */
-function readJsonFile(path, options) {
-    const content = (0, fs_1.readFileSync)(path, 'utf-8');
-    if (options) {
-        options.endsWithNewline = content.charCodeAt(content.length - 1) === 10;
-    }
-    try {
-        return (0, json_1.parseJson)(content, options);
-    }
-    catch (e) {
-        e.message = e.message.replace('JSON', path);
-        throw e;
-    }
-}
-exports.readJsonFile = readJsonFile;
-/**
- * Reads a YAML file and returns the object the YAML content represents.
- *
- * @param path A path to a file.
- * @returns
- */
-function readYamlFile(path, options) {
-    const content = (0, fs_1.readFileSync)(path, 'utf-8');
-    const { load } = __nccwpck_require__(92595);
-    return load(content, Object.assign(Object.assign({}, options), { filename: path }));
-}
-exports.readYamlFile = readYamlFile;
-/**
- * Serializes the given data to JSON and writes it to a file.
- *
- * @param path A path to a file.
- * @param data data which should be serialized to JSON and written to the file
- * @param options JSON serialize options
- */
-function writeJsonFile(path, data, options) {
-    (0, fs_1.mkdirSync)((0, path_1.dirname)(path), { recursive: true });
-    const serializedJson = (0, json_1.serializeJson)(data, options);
-    const content = (options === null || options === void 0 ? void 0 : options.appendNewLine)
-        ? `${serializedJson}\n`
-        : serializedJson;
-    (0, fs_1.writeFileSync)(path, content, { encoding: 'utf-8' });
-}
-exports.writeJsonFile = writeJsonFile;
-/**
- * Check if a directory exists
- * @param path Path to directory
- */
-function directoryExists(path) {
-    try {
-        return (0, fs_1.statSync)(path).isDirectory();
-    }
-    catch (_a) {
-        return false;
-    }
-}
-exports.directoryExists = directoryExists;
-/**
- * Check if a file exists.
- * @param path Path to file
- */
-function fileExists(path) {
-    try {
-        return (0, fs_1.statSync)(path).isFile();
-    }
-    catch (_a) {
-        return false;
-    }
-}
-exports.fileExists = fileExists;
-function createDirectory(path) {
-    (0, fs_1.mkdirSync)(path, { recursive: true });
-}
-exports.createDirectory = createDirectory;
-function isRelativePath(path) {
-    return (path === '.' ||
-        path === '..' ||
-        path.startsWith('./') ||
-        path.startsWith('../'));
-}
-exports.isRelativePath = isRelativePath;
-/**
- * Extracts a file from a given tarball to the specified destination.
- * @param tarballPath The path to the tarball from where the file should be extracted.
- * @param file The path to the file inside the tarball.
- * @param destinationFilePath The destination file path.
- * @returns True if the file was extracted successfully, false otherwise.
- */
-function extractFileFromTarball(tarballPath, file, destinationFilePath) {
-    return tslib_1.__awaiter(this, void 0, void 0, function* () {
-        return new Promise((resolve, reject) => {
-            (0, fs_1.mkdirSync)((0, path_1.dirname)(destinationFilePath), { recursive: true });
-            var tarExtractStream = tar.extract();
-            const destinationFileStream = (0, fs_1.createWriteStream)(destinationFilePath);
-            let isFileExtracted = false;
-            tarExtractStream.on('entry', function (header, stream, next) {
-                if (header.name === file) {
-                    stream.pipe(destinationFileStream);
-                    stream.on('end', () => {
-                        isFileExtracted = true;
-                    });
-                    destinationFileStream.on('close', () => {
-                        resolve(destinationFilePath);
-                    });
-                }
-                stream.on('end', function () {
-                    next();
-                });
-                stream.resume();
-            });
-            tarExtractStream.on('finish', function () {
-                if (!isFileExtracted) {
-                    reject();
-                }
-            });
-            (0, fs_1.createReadStream)(tarballPath).pipe((0, zlib_1.createGunzip)()).pipe(tarExtractStream);
-        });
-    });
-}
-exports.extractFileFromTarball = extractFileFromTarball;
-function readFileIfExisting(path) {
-    return (0, fs_1.existsSync)(path) ? (0, fs_1.readFileSync)(path, 'utf-8') : '';
-}
-exports.readFileIfExisting = readFileIfExisting;
+var common = __nccwpck_require__(60624);
+var fs = __nccwpck_require__(57147);
 
+common.register('rm', _rm, {
+  cmdOptions: {
+    'f': 'force',
+    'r': 'recursive',
+    'R': 'recursive',
+  },
+});
 
-/***/ }),
+// Recursively removes 'dir'
+// Adapted from https://github.com/ryanmcgrath/wrench-js
+//
+// Copyright (c) 2010 Ryan McGrath
+// Copyright (c) 2012 Artur Adib
+//
+// Licensed under the MIT License
+// http://www.opensource.org/licenses/mit-license.php
+function rmdirSyncRecursive(dir, force, fromSymlink) {
+  var files;
 
-/***/ 56668:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
+  files = fs.readdirSync(dir);
 
-"use strict";
+  // Loop through and delete everything in the sub-tree after checking it
+  for (var i = 0; i < files.length; i++) {
+    var file = dir + '/' + files[i];
+    var currFile = common.statNoFollowLinks(file);
 
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.getMatchingStringsWithCache = exports.findMatchingProjects = void 0;
-const minimatch = __nccwpck_require__(72755);
-const validPatternTypes = [
-    'name',
-    'tag',
-    'directory',
-    'unlabeled', // Pattern was passed without specifying a type
-];
-const globCharacters = ['*', '|', '{', '}', '(', ')'];
-/**
- * Find matching project names given a list of potential project names or globs.
- *
- * @param patterns A list of project names or globs to match against.
- * @param projects A map of {@link ProjectGraphProjectNode} by project name.
- * @returns
- */
-function findMatchingProjects(patterns = [], projects) {
-    if (!patterns.length || patterns.filter((p) => p.length).length === 0) {
-        return []; // Short circuit if called with no patterns
-    }
-    const projectNames = Object.keys(projects);
-    const selectedProjects = new Set();
-    const excludedProjects = new Set();
-    for (const stringPattern of patterns) {
-        if (!stringPattern.length) {
-            continue;
-        }
-        const pattern = parseStringPattern(stringPattern, projects);
-        // Handle wildcard with short-circuit, as its a common case with potentially
-        // large project sets and we can avoid the more expensive glob matching.
-        if (pattern.value === '*') {
-            for (const projectName of projectNames) {
-                if (pattern.exclude) {
-                    excludedProjects.add(projectName);
-                }
-                else {
-                    selectedProjects.add(projectName);
-                }
-            }
-            continue;
-        }
-        switch (pattern.type) {
-            case 'tag': {
-                addMatchingProjectsByTag(projectNames, projects, pattern, excludedProjects, selectedProjects);
-                continue;
-            }
-            case 'name': {
-                addMatchingProjectsByName(projectNames, projects, pattern, excludedProjects, selectedProjects);
-                continue;
-            }
-            case 'directory': {
-                addMatchingProjectsByDirectory(projectNames, projects, pattern, excludedProjects, selectedProjects);
-                continue;
-            }
-            // Same thing as `type:unlabeled`. If no specific type is set,
-            // we can waterfall through the different types until we find a match
-            default: {
-                // The size of the selected and excluded projects set, before we
-                // start updating it with this pattern. If the size changes, we
-                // know we found a match and can skip the other types.
-                const originalSize = selectedProjects.size + excludedProjects.size;
-                addMatchingProjectsByName(projectNames, projects, pattern, excludedProjects, selectedProjects);
-                if (selectedProjects.size + excludedProjects.size > originalSize) {
-                    // There was some match by name, don't check other types
-                    continue;
-                }
-                addMatchingProjectsByDirectory(projectNames, projects, pattern, excludedProjects, selectedProjects);
-                if (selectedProjects.size + excludedProjects.size > originalSize) {
-                    // There was some match by directory, don't check other types
-                    // Note - this doesn't do anything currently, but preps for future
-                    // types
-                    continue;
-                }
-            }
+    if (currFile.isDirectory()) { // Recursive function back to the beginning
+      rmdirSyncRecursive(file, force);
+    } else { // Assume it's a file - perhaps a try/catch belongs here?
+      if (force || isWriteable(file)) {
+        try {
+          common.unlinkSync(file);
+        } catch (e) {
+          /* istanbul ignore next */
+          common.error('could not remove file (code ' + e.code + '): ' + file, {
+            continue: true,
+          });
         }
+      }
     }
-    for (const project of excludedProjects) {
-        selectedProjects.delete(project);
-    }
-    return Array.from(selectedProjects);
-}
-exports.findMatchingProjects = findMatchingProjects;
-function addMatchingProjectsByDirectory(projectNames, projects, pattern, excludedProjects, selectedProjects) {
-    for (const projectName of projectNames) {
-        const root = projects[projectName].data.root;
-        if ((0, exports.getMatchingStringsWithCache)(pattern.value, [root]).length > 0) {
-            (pattern.exclude ? excludedProjects : selectedProjects).add(projectName);
+  }
+
+  // if was directory was referenced through a symbolic link,
+  // the contents should be removed, but not the directory itself
+  if (fromSymlink) return;
+
+  // Now that we know everything in the sub-tree has been deleted, we can delete the main directory.
+  // Huzzah for the shopkeep.
+
+  var result;
+  try {
+    // Retry on windows, sometimes it takes a little time before all the files in the directory are gone
+    var start = Date.now();
+
+    // TODO: replace this with a finite loop
+    for (;;) {
+      try {
+        result = fs.rmdirSync(dir);
+        if (fs.existsSync(dir)) throw { code: 'EAGAIN' };
+        break;
+      } catch (er) {
+        /* istanbul ignore next */
+        // In addition to error codes, also check if the directory still exists and loop again if true
+        if (process.platform === 'win32' && (er.code === 'ENOTEMPTY' || er.code === 'EBUSY' || er.code === 'EPERM' || er.code === 'EAGAIN')) {
+          if (Date.now() - start > 1000) throw er;
+        } else if (er.code === 'ENOENT') {
+          // Directory did not exist, deletion was successful
+          break;
+        } else {
+          throw er;
         }
+      }
     }
+  } catch (e) {
+    common.error('could not remove directory (code ' + e.code + '): ' + dir, { continue: true });
+  }
+
+  return result;
+} // rmdirSyncRecursive
+
+// Hack to determine if file has write permissions for current user
+// Avoids having to check user, group, etc, but it's probably slow
+function isWriteable(file) {
+  var writePermission = true;
+  try {
+    var __fd = fs.openSync(file, 'a');
+    fs.closeSync(__fd);
+  } catch (e) {
+    writePermission = false;
+  }
+
+  return writePermission;
 }
-function addMatchingProjectsByName(projectNames, projects, pattern, excludedProjects, selectedProjects) {
-    if (projects[pattern.value]) {
-        (pattern.exclude ? excludedProjects : selectedProjects).add(pattern.value);
-        return;
-    }
-    if (!globCharacters.some((c) => pattern.value.includes(c))) {
-        return;
-    }
-    const matchedProjectNames = (0, exports.getMatchingStringsWithCache)(pattern.value, projectNames);
-    for (const projectName of matchedProjectNames) {
-        if (pattern.exclude) {
-            excludedProjects.add(projectName);
-        }
-        else {
-            selectedProjects.add(projectName);
-        }
-    }
+
+function handleFile(file, options) {
+  if (options.force || isWriteable(file)) {
+    // -f was passed, or file is writable, so it can be removed
+    common.unlinkSync(file);
+  } else {
+    common.error('permission denied: ' + file, { continue: true });
+  }
 }
-function addMatchingProjectsByTag(projectNames, projects, pattern, excludedProjects, selectedProjects) {
-    for (const projectName of projectNames) {
-        const tags = projects[projectName].data.tags || [];
-        if (tags.includes(pattern.value)) {
-            (pattern.exclude ? excludedProjects : selectedProjects).add(projectName);
-            continue;
-        }
-        if (!globCharacters.some((c) => pattern.value.includes(c))) {
-            continue;
-        }
-        if ((0, exports.getMatchingStringsWithCache)(pattern.value, tags).length) {
-            (pattern.exclude ? excludedProjects : selectedProjects).add(projectName);
-        }
-    }
+
+function handleDirectory(file, options) {
+  if (options.recursive) {
+    // -r was passed, so directory can be removed
+    rmdirSyncRecursive(file, options.force);
+  } else {
+    common.error('path is a directory', { continue: true });
+  }
 }
-function parseStringPattern(pattern, projects) {
-    const isExclude = pattern.startsWith('!');
-    // Support for things like: `!{type}:value`
-    if (isExclude) {
-        pattern = pattern.substring(1);
-    }
-    const indexOfFirstPotentialSeparator = pattern.indexOf(':');
-    // There is a project that matches directly
-    if (projects[pattern]) {
-        return { type: 'name', value: pattern, exclude: isExclude };
-        // The pattern does not contain a label
-    }
-    else if (indexOfFirstPotentialSeparator === -1) {
-        return { type: 'unlabeled', value: pattern, exclude: isExclude };
-        // The pattern may contain a label
-    }
-    else {
-        const potentialType = pattern.substring(0, indexOfFirstPotentialSeparator);
-        return {
-            type: isValidPatternType(potentialType) ? potentialType : 'unlabeled',
-            value: pattern.substring(indexOfFirstPotentialSeparator + 1),
-            exclude: isExclude,
-        };
+
+function handleSymbolicLink(file, options) {
+  var stats;
+  try {
+    stats = common.statFollowLinks(file);
+  } catch (e) {
+    // symlink is broken, so remove the symlink itself
+    common.unlinkSync(file);
+    return;
+  }
+
+  if (stats.isFile()) {
+    common.unlinkSync(file);
+  } else if (stats.isDirectory()) {
+    if (file[file.length - 1] === '/') {
+      // trailing separator, so remove the contents, not the link
+      if (options.recursive) {
+        // -r was passed, so directory can be removed
+        var fromSymlink = true;
+        rmdirSyncRecursive(file, options.force, fromSymlink);
+      } else {
+        common.error('path is a directory', { continue: true });
+      }
+    } else {
+      // no trailing separator, so remove the link
+      common.unlinkSync(file);
     }
+  }
 }
-function isValidPatternType(type) {
-    return validPatternTypes.includes(type);
-}
-exports.getMatchingStringsWithCache = (() => {
-    // Map< Pattern, Map< Item, Result >>
-    const minimatchCache = new Map();
-    const regexCache = new Map();
-    return (pattern, items) => {
-        if (!minimatchCache.has(pattern)) {
-            minimatchCache.set(pattern, new Map());
-        }
-        const patternCache = minimatchCache.get(pattern);
-        if (!regexCache.has(pattern)) {
-            regexCache.set(pattern, minimatch.makeRe(pattern));
-        }
-        const matcher = regexCache.get(pattern);
-        return items.filter((item) => {
-            let entry = patternCache.get(item);
-            if (entry === undefined || entry === null) {
-                entry = item === pattern ? true : matcher.test(item);
-                patternCache.set(item, entry);
-            }
-            return entry;
-        });
-    };
-})();
-
 
-/***/ }),
+function handleFIFO(file) {
+  common.unlinkSync(file);
+}
 
-/***/ 98845:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
+//@
+//@ ### rm([options,] file [, file ...])
+//@ ### rm([options,] file_array)
+//@
+//@ Available options:
+//@
+//@ + `-f`: force
+//@ + `-r, -R`: recursive
+//@
+//@ Examples:
+//@
+//@ ```javascript
+//@ rm('-rf', '/tmp/*');
+//@ rm('some_file.txt', 'another_file.txt');
+//@ rm(['some_file.txt', 'another_file.txt']); // same as above
+//@ ```
+//@
+//@ Removes files.
+function _rm(options, files) {
+  if (!files) common.error('no paths given');
 
-"use strict";
+  // Convert to array
+  files = [].slice.call(arguments, 1);
 
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.getIgnoreObject = exports.getAlwaysIgnore = exports.getIgnoredGlobs = exports.ALWAYS_IGNORE = void 0;
-const fs_extra_1 = __nccwpck_require__(59511);
-const ignore_1 = __nccwpck_require__(98337);
-const fileutils_1 = __nccwpck_require__(47930);
-const path_1 = __nccwpck_require__(75878);
-const workspace_root_1 = __nccwpck_require__(65766);
-/**
- * An array of glob patterns that should always be ignored.
- * Uses path/posix, since fast-glob requires unix paths.
- */
-exports.ALWAYS_IGNORE = getAlwaysIgnore();
-function getIgnoredGlobs(root = workspace_root_1.workspaceRoot, prependRoot = true) {
-    const files = ['.gitignore', '.nxignore'];
-    if (prependRoot) {
-        return [
-            ...getAlwaysIgnore(root),
-            ...files.flatMap((f) => getIgnoredGlobsFromFile((0, path_1.joinPathFragments)(root, f), root)),
-        ];
-    }
-    else {
-        return [
-            ...getAlwaysIgnore(),
-            ...files.flatMap((f) => getIgnoredGlobsFromFile((0, path_1.joinPathFragments)(root, f))),
-        ];
-    }
-}
-exports.getIgnoredGlobs = getIgnoredGlobs;
-function getAlwaysIgnore(root) {
-    const paths = ['node_modules', '**/node_modules', '.git'];
-    return root ? paths.map((x) => (0, path_1.joinPathFragments)(root, x)) : paths;
-}
-exports.getAlwaysIgnore = getAlwaysIgnore;
-function getIgnoreObject(root = workspace_root_1.workspaceRoot) {
-    const ig = (0, ignore_1.default)();
-    ig.add((0, fileutils_1.readFileIfExisting)(`${root}/.gitignore`));
-    ig.add((0, fileutils_1.readFileIfExisting)(`${root}/.nxignore`));
-    return ig;
-}
-exports.getIgnoreObject = getIgnoreObject;
-function getIgnoredGlobsFromFile(file, root) {
+  files.forEach(function (file) {
+    var lstats;
     try {
-        const results = [];
-        const contents = (0, fs_extra_1.readFileSync)(file, 'utf-8');
-        const lines = contents.split('\n');
-        for (const line of lines) {
-            const trimmed = line.trim();
-            if (!trimmed || trimmed.startsWith('#')) {
-                continue;
-            }
-            else if (trimmed.startsWith('/')) {
-                if (root) {
-                    results.push((0, path_1.joinPathFragments)(root, trimmed));
-                }
-                else {
-                    results.push((0, path_1.joinPathFragments)('.', trimmed));
-                }
-            }
-            else {
-                results.push(trimmed);
-            }
-        }
-        return results;
+      var filepath = (file[file.length - 1] === '/')
+        ? file.slice(0, -1) // remove the '/' so lstatSync can detect symlinks
+        : file;
+      lstats = common.statNoFollowLinks(filepath); // test for existence
+    } catch (e) {
+      // Path does not exist, no force flag given
+      if (!options.force) {
+        common.error('no such file or directory: ' + file, { continue: true });
+      }
+      return; // skip file
     }
-    catch (e) {
-        return [];
+
+    // If here, path exists
+    if (lstats.isFile()) {
+      handleFile(file, options);
+    } else if (lstats.isDirectory()) {
+      handleDirectory(file, options);
+    } else if (lstats.isSymbolicLink()) {
+      handleSymbolicLink(file, options);
+    } else if (lstats.isFIFO()) {
+      handleFIFO(file);
     }
-}
+  }); // forEach(file)
+  return '';
+} // rm
+module.exports = _rm;
 
 
 /***/ }),
 
-/***/ 35075:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
+/***/ 83401:
+/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
-"use strict";
+var common = __nccwpck_require__(60624);
+var fs = __nccwpck_require__(57147);
 
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.getNxRequirePaths = exports.getNxInstallationPath = void 0;
-const path_1 = __nccwpck_require__(71017);
-const workspace_root_1 = __nccwpck_require__(65766);
-function getNxInstallationPath(root = workspace_root_1.workspaceRoot) {
-    return (0, path_1.join)(root, '.nx', 'installation');
-}
-exports.getNxInstallationPath = getNxInstallationPath;
-function getNxRequirePaths(root = workspace_root_1.workspaceRoot) {
-    return [root, getNxInstallationPath(root)];
-}
-exports.getNxRequirePaths = getNxRequirePaths;
+common.register('sed', _sed, {
+  globStart: 3, // don't glob-expand regexes
+  canReceivePipe: true,
+  cmdOptions: {
+    'i': 'inplace',
+  },
+});
+
+//@
+//@ ### sed([options,] search_regex, replacement, file [, file ...])
+//@ ### sed([options,] search_regex, replacement, file_array)
+//@
+//@ Available options:
+//@
+//@ + `-i`: Replace contents of `file` in-place. _Note that no backups will be created!_
+//@
+//@ Examples:
+//@
+//@ ```javascript
+//@ sed('-i', 'PROGRAM_VERSION', 'v0.1.3', 'source.js');
+//@ sed(/.*DELETE_THIS_LINE.*\n/, '', 'source.js');
+//@ ```
+//@
+//@ Reads an input string from `file`s, and performs a JavaScript `replace()` on the input
+//@ using the given `search_regex` and `replacement` string or function. Returns the new string after replacement.
+//@
+//@ Note:
+//@
+//@ Like unix `sed`, ShellJS `sed` supports capture groups. Capture groups are specified
+//@ using the `$n` syntax:
+//@
+//@ ```javascript
+//@ sed(/(\w+)\s(\w+)/, '$2, $1', 'file.txt');
+//@ ```
+function _sed(options, regex, replacement, files) {
+  // Check if this is coming from a pipe
+  var pipe = common.readFromPipe();
 
+  if (typeof replacement !== 'string' && typeof replacement !== 'function') {
+    if (typeof replacement === 'number') {
+      replacement = replacement.toString(); // fallback
+    } else {
+      common.error('invalid replacement string');
+    }
+  }
 
-/***/ }),
+  // Convert all search strings to RegExp
+  if (typeof regex === 'string') {
+    regex = RegExp(regex);
+  }
 
-/***/ 28839:
-/***/ ((__unused_webpack_module, exports) => {
+  if (!files && !pipe) {
+    common.error('no files given');
+  }
 
-"use strict";
+  files = [].slice.call(arguments, 3);
 
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.isCI = void 0;
-function isCI() {
-    return (process.env.CI === 'true' ||
-        process.env.TF_BUILD === 'true' ||
-        process.env.GITHUB_ACTIONS === 'true' ||
-        process.env.BUILDKITE === 'true' ||
-        process.env.CIRCLECI === 'true' ||
-        process.env.CIRRUS_CI === 'true' ||
-        process.env.TRAVIS === 'true' ||
-        !!process.env['bamboo.buildKey'] ||
-        !!process.env.CODEBUILD_BUILD_ID ||
-        !!process.env.GITLAB_CI ||
-        !!process.env.HEROKU_TEST_RUN_ID ||
-        !!process.env.BUILD_ID ||
-        !!process.env.BUILD_BUILDID ||
-        !!process.env.TEAMCITY_VERSION);
+  if (pipe) {
+    files.unshift('-');
+  }
+
+  var sed = [];
+  files.forEach(function (file) {
+    if (!fs.existsSync(file) && file !== '-') {
+      common.error('no such file or directory: ' + file, 2, { continue: true });
+      return;
+    }
+
+    var contents = file === '-' ? pipe : fs.readFileSync(file, 'utf8');
+    var lines = contents.split('\n');
+    var result = lines.map(function (line) {
+      return line.replace(regex, replacement);
+    }).join('\n');
+
+    sed.push(result);
+
+    if (options.inplace) {
+      fs.writeFileSync(file, result, 'utf8');
+    }
+  });
+
+  return sed.join('\n');
 }
-exports.isCI = isCI;
+module.exports = _sed;
 
 
 /***/ }),
 
-/***/ 65058:
-/***/ ((__unused_webpack_module, exports) => {
+/***/ 62833:
+/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
-"use strict";
+var common = __nccwpck_require__(60624);
 
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.walkJsonTree = exports.jsonDiff = exports.isJsonChange = exports.JsonDiffType = void 0;
-var JsonDiffType;
-(function (JsonDiffType) {
-    JsonDiffType["Deleted"] = "JsonPropertyDeleted";
-    JsonDiffType["Added"] = "JsonPropertyAdded";
-    JsonDiffType["Modified"] = "JsonPropertyModified";
-})(JsonDiffType = exports.JsonDiffType || (exports.JsonDiffType = {}));
-function isJsonChange(change) {
-    return (change.type === JsonDiffType.Added ||
-        change.type === JsonDiffType.Deleted ||
-        change.type === JsonDiffType.Modified);
-}
-exports.isJsonChange = isJsonChange;
-function jsonDiff(lhs, rhs) {
-    const result = [];
-    const seenInLhs = new Set();
-    walkJsonTree(lhs, [], (path, lhsValue) => {
-        seenInLhs.add(hashArray(path));
-        const rhsValue = getJsonValue(path, rhs);
-        if (rhsValue === undefined) {
-            result.push({
-                type: JsonDiffType.Deleted,
-                path,
-                value: {
-                    lhs: lhsValue,
-                    rhs: undefined,
-                },
-            });
-        }
-        else if (!deepEquals(lhsValue, rhsValue)) {
-            result.push({
-                type: JsonDiffType.Modified,
-                path,
-                value: {
-                    lhs: lhsValue,
-                    rhs: rhsValue,
-                },
-            });
-        }
-        return typeof lhsValue === 'object' || Array.isArray(lhsValue);
-    });
-    walkJsonTree(rhs, [], (path, rhsValue) => {
-        const addedInRhs = !seenInLhs.has(hashArray(path));
-        if (addedInRhs) {
-            result.push({
-                type: JsonDiffType.Added,
-                path,
-                value: {
-                    lhs: undefined,
-                    rhs: rhsValue,
-                },
-            });
-        }
-        return typeof rhsValue === 'object' || Array.isArray(rhsValue);
-    });
-    return result;
-}
-exports.jsonDiff = jsonDiff;
-// Depth-first walk down JSON tree.
-function walkJsonTree(json, currPath, visitor) {
-    if (!json || typeof json !== 'object') {
-        return;
-    }
-    Object.keys(json).forEach((key) => {
-        const path = currPath.concat([key]);
-        const shouldContinue = visitor(path, json[key]);
-        if (shouldContinue) {
-            walkJsonTree(json[key], path, visitor);
-        }
+common.register('set', _set, {
+  allowGlobbing: false,
+  wrapOutput: false,
+});
+
+//@
+//@ ### set(options)
+//@
+//@ Available options:
+//@
+//@ + `+/-e`: exit upon error (`config.fatal`)
+//@ + `+/-v`: verbose: show all commands (`config.verbose`)
+//@ + `+/-f`: disable filename expansion (globbing)
+//@
+//@ Examples:
+//@
+//@ ```javascript
+//@ set('-e'); // exit upon first error
+//@ set('+e'); // this undoes a "set('-e')"
+//@ ```
+//@
+//@ Sets global configuration variables.
+function _set(options) {
+  if (!options) {
+    var args = [].slice.call(arguments, 0);
+    if (args.length < 2) common.error('must provide an argument');
+    options = args[1];
+  }
+  var negate = (options[0] === '+');
+  if (negate) {
+    options = '-' + options.slice(1); // parseOptions needs a '-' prefix
+  }
+  options = common.parseOptions(options, {
+    'e': 'fatal',
+    'v': 'verbose',
+    'f': 'noglob',
+  });
+
+  if (negate) {
+    Object.keys(options).forEach(function (key) {
+      options[key] = !options[key];
     });
-}
-exports.walkJsonTree = walkJsonTree;
-function hashArray(ary) {
-    return JSON.stringify(ary);
-}
-function getJsonValue(path, json) {
-    let curr = json;
-    for (const k of path) {
-        curr = curr[k];
-        if (curr === undefined) {
-            break;
-        }
-    }
-    return curr;
-}
-function deepEquals(a, b) {
-    if (a === b) {
-        return true;
-    }
-    // Values do not need to be checked for deep equality and the above is false
-    if (
-    // Values are different types
-    typeof a !== typeof b ||
-        // Values are the same type but not an object or array
-        (typeof a !== 'object' && !Array.isArray(a)) ||
-        // Objects are the same type, objects or arrays, but do not have the same number of keys
-        Object.keys(a).length !== Object.keys(b).length) {
-        return false;
+  }
+
+  Object.keys(options).forEach(function (key) {
+    // Only change the global config if `negate` is false and the option is true
+    // or if `negate` is true and the option is false (aka negate !== option)
+    if (negate !== options[key]) {
+      common.config[key] = options[key];
     }
-    // Values need to be checked for deep equality
-    return Object.entries(a).reduce((equal, [key, aValue]) => {
-        // Skip other keys if it is already not equal.
-        if (!equal) {
-            return equal;
-        }
-        // Traverse the object
-        return deepEquals(aValue, b[key]);
-    }, true);
+  });
+  return;
 }
+module.exports = _set;
 
 
 /***/ }),
 
-/***/ 43684:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
+/***/ 22675:
+/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
-"use strict";
+var common = __nccwpck_require__(60624);
+var fs = __nccwpck_require__(57147);
 
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.serializeJson = exports.parseJson = exports.stripJsonComments = void 0;
-const jsonc_parser_1 = __nccwpck_require__(56416);
-Object.defineProperty(exports, "stripJsonComments", ({ enumerable: true, get: function () { return jsonc_parser_1.stripComments; } }));
-const lines_and_columns_1 = __nccwpck_require__(74570);
-const code_frames_1 = __nccwpck_require__(73133);
-/**
- * Parses the given JSON string and returns the object the JSON content represents.
- * By default javascript-style comments and trailing commas are allowed.
- *
- * @param input JSON content as string
- * @param options JSON parse options
- * @returns Object the JSON content represents
- */
-function parseJson(input, options) {
-    try {
-        return JSON.parse(input);
-    }
-    catch (_a) { }
-    options = Object.assign({ allowTrailingComma: true }, options);
-    const errors = [];
-    const result = (0, jsonc_parser_1.parse)(input, errors, options);
-    if (errors.length > 0) {
-        throw new Error(formatParseError(input, errors[0]));
-    }
-    return result;
+common.register('sort', _sort, {
+  canReceivePipe: true,
+  cmdOptions: {
+    'r': 'reverse',
+    'n': 'numerical',
+  },
+});
+
+// parse out the number prefix of a line
+function parseNumber(str) {
+  var match = str.match(/^\s*(\d*)\s*(.*)$/);
+  return { num: Number(match[1]), value: match[2] };
 }
-exports.parseJson = parseJson;
-/**
- * Nicely formats a JSON error with context
- *
- * @param input JSON content as string
- * @param parseError jsonc ParseError
- * @returns
- */
-function formatParseError(input, parseError) {
-    const { error, offset, length } = parseError;
-    let { line, column } = new lines_and_columns_1.LinesAndColumns(input).locationForIndex(offset);
-    line++;
-    column++;
-    return (`${(0, jsonc_parser_1.printParseErrorCode)(error)} in JSON at ${line}:${column}\n` +
-        (0, code_frames_1.codeFrameColumns)(input, {
-            start: { line, column },
-            end: { line, column: column + length },
-        }) +
-        '\n');
+
+// compare two strings case-insensitively, but examine case for strings that are
+// case-insensitive equivalent
+function unixCmp(a, b) {
+  var aLower = a.toLowerCase();
+  var bLower = b.toLowerCase();
+  return (aLower === bLower ?
+      -1 * a.localeCompare(b) : // unix sort treats case opposite how javascript does
+      aLower.localeCompare(bLower));
 }
-/**
- * Serializes the given data to a JSON string.
- * By default the JSON string is formatted with a 2 space indentation to be easy readable.
- *
- * @param input Object which should be serialized to JSON
- * @param options JSON serialize options
- * @returns the formatted JSON representation of the object
- */
-function serializeJson(input, options) {
-    var _a;
-    return JSON.stringify(input, null, (_a = options === null || options === void 0 ? void 0 : options.spaces) !== null && _a !== void 0 ? _a : 2) + '\n';
+
+// compare two strings in the fashion that unix sort's -n option works
+function numericalCmp(a, b) {
+  var objA = parseNumber(a);
+  var objB = parseNumber(b);
+  if (objA.hasOwnProperty('num') && objB.hasOwnProperty('num')) {
+    return ((objA.num !== objB.num) ?
+        (objA.num - objB.num) :
+        unixCmp(objA.value, objB.value));
+  } else {
+    return unixCmp(objA.value, objB.value);
+  }
 }
-exports.serializeJson = serializeJson;
 
+//@
+//@ ### sort([options,] file [, file ...])
+//@ ### sort([options,] file_array)
+//@
+//@ Available options:
+//@
+//@ + `-r`: Reverse the results
+//@ + `-n`: Compare according to numerical value
+//@
+//@ Examples:
+//@
+//@ ```javascript
+//@ sort('foo.txt', 'bar.txt');
+//@ sort('-r', 'foo.txt');
+//@ ```
+//@
+//@ Return the contents of the `file`s, sorted line-by-line. Sorting multiple
+//@ files mixes their content (just as unix `sort` does).
+function _sort(options, files) {
+  // Check if this is coming from a pipe
+  var pipe = common.readFromPipe();
 
-/***/ }),
+  if (!files && !pipe) common.error('no files given');
 
-/***/ 95324:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
+  files = [].slice.call(arguments, 1);
 
-"use strict";
+  if (pipe) {
+    files.unshift('-');
+  }
 
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.stripIndent = exports.logger = exports.NX_ERROR = exports.NX_PREFIX = void 0;
-const chalk = __nccwpck_require__(29541);
-exports.NX_PREFIX = `${chalk.cyan('>')} ${chalk.inverse(chalk.bold(chalk.cyan(' NX ')))}`;
-exports.NX_ERROR = chalk.inverse(chalk.bold(chalk.red(' ERROR ')));
-exports.logger = {
-    warn: (s) => console.warn(chalk.bold(chalk.yellow(s))),
-    error: (s) => {
-        if (typeof s === 'string' && s.startsWith('NX ')) {
-            console.error(`\n${exports.NX_ERROR} ${chalk.bold(chalk.red(s.slice(3)))}\n`);
-        }
-        else if (s instanceof Error && s.stack) {
-            console.error(chalk.bold(chalk.red(s.stack)));
-        }
-        else {
-            console.error(chalk.bold(chalk.red(s)));
-        }
-    },
-    info: (s) => {
-        if (typeof s === 'string' && s.startsWith('NX ')) {
-            console.info(`\n${exports.NX_PREFIX} ${chalk.bold(s.slice(3))}\n`);
-        }
-        else {
-            console.info(s);
-        }
-    },
-    log: (...s) => {
-        console.log(...s);
-    },
-    debug: (...s) => {
-        console.debug(...s);
-    },
-    fatal: (...s) => {
-        console.error(...s);
-    },
-};
-function stripIndent(str) {
-    const match = str.match(/^[ \t]*(?=\S)/gm);
-    if (!match) {
-        return str;
+  var lines = files.reduce(function (accum, file) {
+    if (file !== '-') {
+      if (!fs.existsSync(file)) {
+        common.error('no such file or directory: ' + file, { continue: true });
+        return accum;
+      } else if (common.statFollowLinks(file).isDirectory()) {
+        common.error('read failed: ' + file + ': Is a directory', {
+          continue: true,
+        });
+        return accum;
+      }
     }
-    const indent = match.reduce((r, a) => Math.min(r, a.length), Infinity);
-    const regex = new RegExp(`^[ \\t]{${indent}}`, 'gm');
-    return str.replace(regex, '');
+
+    var contents = file === '-' ? pipe : fs.readFileSync(file, 'utf8');
+    return accum.concat(contents.trimRight().split('\n'));
+  }, []);
+
+  var sorted = lines.sort(options.numerical ? numericalCmp : unixCmp);
+
+  if (options.reverse) {
+    sorted = sorted.reverse();
+  }
+
+  return sorted.join('\n') + '\n';
 }
-exports.stripIndent = stripIndent;
+
+module.exports = _sort;
 
 
 /***/ }),
 
-/***/ 86740:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
+/***/ 61434:
+/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
-"use strict";
+var common = __nccwpck_require__(60624);
+var fs = __nccwpck_require__(57147);
 
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.registerPluginTSTranspiler = exports.resolveLocalNxPlugin = exports.readPluginPackageJson = exports.mergePluginTargetsWithNxTargets = exports.loadNxPlugins = exports.loadNxPluginsSync = exports.loadNxPluginAsync = void 0;
-const tslib_1 = __nccwpck_require__(51796);
-const fast_glob_1 = __nccwpck_require__(19131);
-const fs_1 = __nccwpck_require__(57147);
-const path = __nccwpck_require__(71017);
-const workspaces_1 = __nccwpck_require__(98715);
-const workspace_root_1 = __nccwpck_require__(65766);
-const fileutils_1 = __nccwpck_require__(47930);
-const package_json_1 = __nccwpck_require__(14482);
-const register_1 = __nccwpck_require__(16354);
-const logger_1 = __nccwpck_require__(95324);
-const find_project_for_path_1 = __nccwpck_require__(36265);
-const path_1 = __nccwpck_require__(75878);
-const path_2 = __nccwpck_require__(71017);
-const installation_directory_1 = __nccwpck_require__(35075);
-const typescript_1 = __nccwpck_require__(62029);
-// Short lived cache (cleared between cmd runs)
-// holding resolved nx plugin objects.
-// Allows loadNxPlugins to be called multiple times w/o
-// executing resolution mulitple times.
-let nxPluginCache = new Map();
-function getPluginPathAndName(moduleName, paths, root) {
-    let pluginPath;
-    try {
-        pluginPath = require.resolve(moduleName, {
-            paths,
+common.register('tail', _tail, {
+  canReceivePipe: true,
+  cmdOptions: {
+    'n': 'numLines',
+  },
+});
+
+//@
+//@ ### tail([{'-n': \},] file [, file ...])
+//@ ### tail([{'-n': \},] file_array)
+//@
+//@ Available options:
+//@
+//@ + `-n `: Show the last `` lines of `file`s
+//@
+//@ Examples:
+//@
+//@ ```javascript
+//@ var str = tail({'-n': 1}, 'file*.txt');
+//@ var str = tail('file1', 'file2');
+//@ var str = tail(['file1', 'file2']); // same as above
+//@ ```
+//@
+//@ Read the end of a `file`.
+function _tail(options, files) {
+  var tail = [];
+  var pipe = common.readFromPipe();
+
+  if (!files && !pipe) common.error('no paths given');
+
+  var idx = 1;
+  if (options.numLines === true) {
+    idx = 2;
+    options.numLines = Number(arguments[1]);
+  } else if (options.numLines === false) {
+    options.numLines = 10;
+  }
+  options.numLines = -1 * Math.abs(options.numLines);
+  files = [].slice.call(arguments, idx);
+
+  if (pipe) {
+    files.unshift('-');
+  }
+
+  var shouldAppendNewline = false;
+  files.forEach(function (file) {
+    if (file !== '-') {
+      if (!fs.existsSync(file)) {
+        common.error('no such file or directory: ' + file, { continue: true });
+        return;
+      } else if (common.statFollowLinks(file).isDirectory()) {
+        common.error("error reading '" + file + "': Is a directory", {
+          continue: true,
         });
+        return;
+      }
     }
-    catch (e) {
-        if (e.code === 'MODULE_NOT_FOUND') {
-            const plugin = resolveLocalNxPlugin(moduleName, root);
-            if (plugin) {
-                const main = readPluginMainFromProjectConfiguration(plugin.projectConfig);
-                pluginPath = main ? path.join(root, main) : plugin.path;
-            }
-            else {
-                logger_1.logger.error(`Plugin listed in \`nx.json\` not found: ${moduleName}`);
-                throw e;
-            }
-        }
-        else {
-            throw e;
-        }
+
+    var contents = file === '-' ? pipe : fs.readFileSync(file, 'utf8');
+
+    var lines = contents.split('\n');
+    if (lines[lines.length - 1] === '') {
+      lines.pop();
+      shouldAppendNewline = true;
+    } else {
+      shouldAppendNewline = false;
     }
-    const packageJsonPath = path.join(pluginPath, 'package.json');
-    const { name } = !['.ts', '.js'].some((x) => x === path.extname(pluginPath)) && // Not trying to point to a ts or js file
-        (0, fs_1.existsSync)(packageJsonPath) // plugin has a package.json
-        ? (0, fileutils_1.readJsonFile)(packageJsonPath) // read name from package.json
-        : { name: moduleName };
-    return { pluginPath, name };
-}
-function loadNxPluginAsync(moduleName, paths, root) {
-    return tslib_1.__awaiter(this, void 0, void 0, function* () {
-        let pluginModule = nxPluginCache.get(moduleName);
-        if (pluginModule) {
-            return pluginModule;
-        }
-        let { pluginPath, name } = getPluginPathAndName(moduleName, paths, root);
-        const plugin = (yield Promise.resolve(`${pluginPath}`).then(s => require(s)));
-        plugin.name = name;
-        nxPluginCache.set(moduleName, plugin);
-        return plugin;
-    });
-}
-exports.loadNxPluginAsync = loadNxPluginAsync;
-function loadNxPluginSync(moduleName, paths, root) {
-    let pluginModule = nxPluginCache.get(moduleName);
-    if (pluginModule) {
-        return pluginModule;
-    }
-    let { pluginPath, name } = getPluginPathAndName(moduleName, paths, root);
-    const plugin = require(pluginPath);
-    plugin.name = name;
-    nxPluginCache.set(moduleName, plugin);
-    return plugin;
-}
-/**
- * @deprecated Use loadNxPlugins instead.
- */
-function loadNxPluginsSync(plugins, paths = (0, installation_directory_1.getNxRequirePaths)(), root = workspace_root_1.workspaceRoot) {
-    const result = [];
-    // TODO: This should be specified in nx.json
-    // Temporarily load js as if it were a plugin which is built into nx
-    // In the future, this will be optional and need to be specified in nx.json
-    const jsPlugin = __nccwpck_require__(71777);
-    jsPlugin.name = 'nx-js-graph-plugin';
-    result.push(jsPlugin);
-    plugins !== null && plugins !== void 0 ? plugins : (plugins = []);
-    for (const plugin of plugins) {
-        try {
-            result.push(loadNxPluginSync(plugin, paths, root));
-        }
-        catch (e) {
-            if (e.code === 'ERR_REQUIRE_ESM') {
-                throw new Error(`Unable to load "${plugin}". Plugins cannot be ESM modules. They must be CommonJS modules. Follow the issue on github: https://github.com/nrwl/nx/issues/15682`);
-            }
-            throw e;
-        }
-    }
-    return result;
-}
-exports.loadNxPluginsSync = loadNxPluginsSync;
-function loadNxPlugins(plugins, paths = (0, installation_directory_1.getNxRequirePaths)(), root = workspace_root_1.workspaceRoot) {
-    return tslib_1.__awaiter(this, void 0, void 0, function* () {
-        const result = [];
-        // TODO: This should be specified in nx.json
-        // Temporarily load js as if it were a plugin which is built into nx
-        // In the future, this will be optional and need to be specified in nx.json
-        const jsPlugin = yield Promise.resolve().then(() => __nccwpck_require__(71777));
-        jsPlugin.name = 'nx-js-graph-plugin';
-        result.push(jsPlugin);
-        plugins !== null && plugins !== void 0 ? plugins : (plugins = []);
-        for (const plugin of plugins) {
-            result.push(yield loadNxPluginAsync(plugin, paths, root));
-        }
-        return result;
-    });
-}
-exports.loadNxPlugins = loadNxPlugins;
-function mergePluginTargetsWithNxTargets(projectRoot, targets, plugins) {
-    var _a;
-    let newTargets = {};
-    for (const plugin of plugins) {
-        if (!((_a = plugin.projectFilePatterns) === null || _a === void 0 ? void 0 : _a.length) || !plugin.registerProjectTargets) {
-            continue;
-        }
-        const projectFiles = (0, fast_glob_1.sync)(`+(${plugin.projectFilePatterns.join('|')})`, {
-            cwd: path.join(workspace_root_1.workspaceRoot, projectRoot),
-        });
-        for (const projectFile of projectFiles) {
-            newTargets = Object.assign(Object.assign({}, newTargets), plugin.registerProjectTargets(path.join(projectRoot, projectFile)));
-        }
-    }
-    return Object.assign(Object.assign({}, newTargets), targets);
-}
-exports.mergePluginTargetsWithNxTargets = mergePluginTargetsWithNxTargets;
-function readPluginPackageJson(pluginName, paths = (0, installation_directory_1.getNxRequirePaths)()) {
-    try {
-        const result = (0, package_json_1.readModulePackageJsonWithoutFallbacks)(pluginName, paths);
-        return {
-            json: result.packageJson,
-            path: result.path,
-        };
-    }
-    catch (e) {
-        if (e.code === 'MODULE_NOT_FOUND') {
-            const localPluginPath = resolveLocalNxPlugin(pluginName);
-            if (localPluginPath) {
-                const localPluginPackageJson = path.join(localPluginPath.path, 'package.json');
-                return {
-                    path: localPluginPackageJson,
-                    json: (0, fileutils_1.readJsonFile)(localPluginPackageJson),
-                };
-            }
-        }
-        throw e;
-    }
-}
-exports.readPluginPackageJson = readPluginPackageJson;
-/**
- * Builds a plugin package and returns the path to output
- * @param importPath What is the import path that refers to a potential plugin?
- * @returns The path to the built plugin, or null if it doesn't exist
- */
-const localPluginCache = {};
-function resolveLocalNxPlugin(importPath, root = workspace_root_1.workspaceRoot) {
-    var _a;
-    (_a = localPluginCache[importPath]) !== null && _a !== void 0 ? _a : (localPluginCache[importPath] = lookupLocalPlugin(importPath, root));
-    return localPluginCache[importPath];
-}
-exports.resolveLocalNxPlugin = resolveLocalNxPlugin;
-let tsNodeAndPathsRegistered = false;
-/**
- * Register swc-node or ts-node if they are not currently registered
- * with some default settings which work well for Nx plugins.
- */
-function registerPluginTSTranspiler() {
-    if (!tsNodeAndPathsRegistered) {
-        // nx-ignore-next-line
-        const ts = __nccwpck_require__(70048);
-        // Get the first tsconfig that matches the allowed set
-        const tsConfigName = [
-            (0, path_2.join)(workspace_root_1.workspaceRoot, 'tsconfig.base.json'),
-            (0, path_2.join)(workspace_root_1.workspaceRoot, 'tsconfig.json'),
-        ].find((x) => (0, fs_1.existsSync)(x));
-        const tsConfig = tsConfigName
-            ? (0, typescript_1.readTsConfig)(tsConfigName)
-            : {};
-        (0, register_1.registerTsConfigPaths)(tsConfigName);
-        (0, register_1.registerTranspiler)(Object.assign(Object.assign({ experimentalDecorators: true, emitDecoratorMetadata: true }, tsConfig.options), { lib: ['es2021'], module: ts.ModuleKind.CommonJS, target: ts.ScriptTarget.ES2021, inlineSourceMap: true, skipLibCheck: true }));
-    }
-    tsNodeAndPathsRegistered = true;
-}
-exports.registerPluginTSTranspiler = registerPluginTSTranspiler;
-function lookupLocalPlugin(importPath, root = workspace_root_1.workspaceRoot) {
-    const workspace = new workspaces_1.Workspaces(root).readProjectsConfigurations({
-        _ignorePluginInference: true,
-    });
-    const plugin = findNxProjectForImportPath(importPath, workspace, root);
-    if (!plugin) {
-        return null;
-    }
-    if (!tsNodeAndPathsRegistered) {
-        registerPluginTSTranspiler();
-    }
-    const projectConfig = workspace.projects[plugin];
-    return { path: path.join(root, projectConfig.root), projectConfig };
-}
-function findNxProjectForImportPath(importPath, projects, root = workspace_root_1.workspaceRoot) {
-    var _a;
-    const tsConfigPaths = readTsConfigPaths(root);
-    const possiblePaths = (_a = tsConfigPaths[importPath]) === null || _a === void 0 ? void 0 : _a.map((p) => (0, path_1.normalizePath)(path.relative(root, path.join(root, p))));
-    if (possiblePaths === null || possiblePaths === void 0 ? void 0 : possiblePaths.length) {
-        const projectRootMappings = (0, find_project_for_path_1.createProjectRootMappingsFromProjectConfigurations)(projects.projects);
-        for (const tsConfigPath of possiblePaths) {
-            const nxProject = (0, find_project_for_path_1.findProjectForPath)(tsConfigPath, projectRootMappings);
-            if (nxProject) {
-                return nxProject;
-            }
-        }
-        if (process.env.NX_VERBOSE_LOGGING) {
-            console.log('Unable to find local plugin', possiblePaths, projectRootMappings);
-        }
-        throw new Error('Unable to resolve local plugin with import path ' + importPath);
-    }
-}
-let tsconfigPaths;
-function readTsConfigPaths(root = workspace_root_1.workspaceRoot) {
-    if (!tsconfigPaths) {
-        const tsconfigPath = ['tsconfig.base.json', 'tsconfig.json']
-            .map((x) => path.join(root, x))
-            .filter((x) => (0, fs_1.existsSync)(x))[0];
-        if (!tsconfigPath) {
-            throw new Error('unable to find tsconfig.base.json or tsconfig.json');
-        }
-        const { compilerOptions } = (0, fileutils_1.readJsonFile)(tsconfigPath);
-        tsconfigPaths = compilerOptions === null || compilerOptions === void 0 ? void 0 : compilerOptions.paths;
-    }
-    return tsconfigPaths !== null && tsconfigPaths !== void 0 ? tsconfigPaths : {};
-}
-function readPluginMainFromProjectConfiguration(plugin) {
-    var _a, _b, _c;
-    const { main } = ((_a = Object.values(plugin.targets).find((x) => [
-        '@nx/js:tsc',
-        '@nrwl/js:tsc',
-        '@nx/js:swc',
-        '@nrwl/js:swc',
-        '@nx/node:package',
-        '@nrwl/node:package',
-    ].includes(x.executor))) === null || _a === void 0 ? void 0 : _a.options) ||
-        ((_c = (_b = plugin.targets) === null || _b === void 0 ? void 0 : _b.build) === null || _c === void 0 ? void 0 : _c.options) ||
-        {};
-    return main;
+
+    tail = tail.concat(lines.slice(options.numLines));
+  });
+
+  if (shouldAppendNewline) {
+    tail.push(''); // to add a trailing newline once we join
+  }
+  return tail.join('\n');
 }
+module.exports = _tail;
 
 
 /***/ }),
 
-/***/ 95961:
-/***/ ((__unused_webpack_module, exports) => {
+/***/ 68691:
+/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
-"use strict";
+var common = __nccwpck_require__(60624);
+var os = __nccwpck_require__(22037);
+var fs = __nccwpck_require__(57147);
 
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.sortObjectByKeys = void 0;
-function sortObjectByKeys(originalObject) {
-    const keys = Object.keys(originalObject).sort();
-    const sortedObject = {};
-    keys.forEach((key) => (sortedObject[key] = originalObject[key]));
-    return sortedObject;
+common.register('tempdir', _tempDir, {
+  allowGlobbing: false,
+  wrapOutput: false,
+});
+
+// Returns false if 'dir' is not a writeable directory, 'dir' otherwise
+function writeableDir(dir) {
+  if (!dir || !fs.existsSync(dir)) return false;
+
+  if (!common.statFollowLinks(dir).isDirectory()) return false;
+
+  var testFile = dir + '/' + common.randomFileName();
+  try {
+    fs.writeFileSync(testFile, ' ');
+    common.unlinkSync(testFile);
+    return dir;
+  } catch (e) {
+    /* istanbul ignore next */
+    return false;
+  }
 }
-exports.sortObjectByKeys = sortObjectByKeys;
 
+// Variable to cache the tempdir value for successive lookups.
+var cachedTempDir;
 
-/***/ }),
+//@
+//@ ### tempdir()
+//@
+//@ Examples:
+//@
+//@ ```javascript
+//@ var tmp = tempdir(); // "/tmp" for most *nix platforms
+//@ ```
+//@
+//@ Searches and returns string containing a writeable, platform-dependent temporary directory.
+//@ Follows Python's [tempfile algorithm](http://docs.python.org/library/tempfile.html#tempfile.tempdir).
+function _tempDir() {
+  if (cachedTempDir) return cachedTempDir;
 
-/***/ 34548:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
+  cachedTempDir = writeableDir(os.tmpdir()) ||
+                  writeableDir(process.env.TMPDIR) ||
+                  writeableDir(process.env.TEMP) ||
+                  writeableDir(process.env.TMP) ||
+                  writeableDir(process.env.Wimp$ScrapDir) || // RiscOS
+                  writeableDir('C:\\TEMP') || // Windows
+                  writeableDir('C:\\TMP') || // Windows
+                  writeableDir('\\TEMP') || // Windows
+                  writeableDir('\\TMP') || // Windows
+                  writeableDir('/tmp') ||
+                  writeableDir('/var/tmp') ||
+                  writeableDir('/usr/tmp') ||
+                  writeableDir('.'); // last resort
 
-"use strict";
+  return cachedTempDir;
+}
 
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.output = void 0;
-const chalk = __nccwpck_require__(29541);
-const os_1 = __nccwpck_require__(22037);
-const is_ci_1 = __nccwpck_require__(28839);
-/**
- * Automatically disable styling applied by chalk if CI=true
- */
-const forceColor = process.env.FORCE_COLOR === '' || process.env.FORCE_COLOR === 'true';
-if ((0, is_ci_1.isCI)() && !forceColor) {
-    chalk.level = 0;
+// Indicates if the tempdir value is currently cached. This is exposed for tests
+// only. The return value should only be tested for truthiness.
+function isCached() {
+  return cachedTempDir;
 }
-class CLIOutput {
-    constructor() {
-        this.X_PADDING = ' ';
-        this.cliName = 'NX';
-        this.formatCommand = (taskId) => `${chalk.dim('nx run')} ${taskId}`;
-        /**
-         * Expose some color and other utility functions so that other parts of the codebase that need
-         * more fine-grained control of message bodies are still using a centralized
-         * implementation.
-         */
-        this.colors = {
-            gray: chalk.gray,
-            green: chalk.green,
-            red: chalk.red,
-            cyan: chalk.cyan,
-            white: chalk.white,
-        };
-        this.bold = chalk.bold;
-        this.underline = chalk.underline;
-        this.dim = chalk.dim;
-    }
-    /**
-     * Longer dash character which forms more of a continuous line when place side to side
-     * with itself, unlike the standard dash character
-     */
-    get VERTICAL_SEPARATOR() {
-        let divider = '';
-        for (let i = 0; i < process.stdout.columns - this.X_PADDING.length * 2; i++) {
-            divider += '\u2014';
-        }
-        return divider;
-    }
-    writeToStdOut(str) {
-        process.stdout.write(str);
-    }
-    writeOutputTitle({ color, title, }) {
-        this.writeToStdOut(` ${this.applyNxPrefix(color, title)}${os_1.EOL}`);
-    }
-    writeOptionalOutputBody(bodyLines) {
-        if (!bodyLines) {
-            return;
-        }
-        this.addNewline();
-        bodyLines.forEach((bodyLine) => this.writeToStdOut(`   ${bodyLine}${os_1.EOL}`));
-    }
-    applyNxPrefix(color = 'cyan', text) {
-        let nxPrefix = '';
-        if (chalk[color]) {
-            nxPrefix = `${chalk[color]('>')} ${chalk.reset.inverse.bold[color](` ${this.cliName} `)}`;
-        }
-        else {
-            nxPrefix = `${chalk.keyword(color)('>')} ${chalk.reset.inverse.bold.keyword(color)(` ${this.cliName} `)}`;
-        }
-        return `${nxPrefix}  ${text}`;
-    }
-    addNewline() {
-        this.writeToStdOut(os_1.EOL);
-    }
-    addVerticalSeparator(color = 'gray') {
-        this.addNewline();
-        this.addVerticalSeparatorWithoutNewLines(color);
-        this.addNewline();
-    }
-    addVerticalSeparatorWithoutNewLines(color = 'gray') {
-        this.writeToStdOut(`${this.X_PADDING}${chalk.dim[color](this.VERTICAL_SEPARATOR)}${os_1.EOL}`);
-    }
-    error({ title, slug, bodyLines }) {
-        this.addNewline();
-        this.writeOutputTitle({
-            color: 'red',
-            title: chalk.red(title),
-        });
-        this.writeOptionalOutputBody(bodyLines);
-        /**
-         * Optional slug to be used in an Nx error message redirect URL
-         */
-        if (slug && typeof slug === 'string') {
-            this.addNewline();
-            this.writeToStdOut(`${chalk.grey('  Learn more about this error: ')}https://errors.nx.dev/${slug}${os_1.EOL}`);
-        }
-        this.addNewline();
-    }
-    warn({ title, slug, bodyLines }) {
-        this.addNewline();
-        this.writeOutputTitle({
-            color: 'yellow',
-            title: chalk.yellow(title),
-        });
-        this.writeOptionalOutputBody(bodyLines);
-        /**
-         * Optional slug to be used in an Nx warning message redirect URL
-         */
-        if (slug && typeof slug === 'string') {
-            this.addNewline();
-            this.writeToStdOut(`${chalk.grey('  Learn more about this warning: ')}https://errors.nx.dev/${slug}\n`);
-        }
-        this.addNewline();
-    }
-    note({ title, bodyLines }) {
-        this.addNewline();
-        this.writeOutputTitle({
-            color: 'orange',
-            title: chalk.keyword('orange')(title),
-        });
-        this.writeOptionalOutputBody(bodyLines);
-        this.addNewline();
-    }
-    success({ title, bodyLines }) {
-        this.addNewline();
-        this.writeOutputTitle({
-            color: 'green',
-            title: chalk.green(title),
-        });
-        this.writeOptionalOutputBody(bodyLines);
-        this.addNewline();
-    }
-    logSingleLine(message) {
-        this.addNewline();
-        this.writeOutputTitle({
-            color: 'gray',
-            title: message,
-        });
-        this.addNewline();
-    }
-    logCommand(message, taskStatus) {
-        this.addNewline();
-        const commandOutput = chalk.dim('> ') + this.formatCommand(this.normalizeMessage(message));
-        const commandOutputWithStatus = this.addTaskStatus(taskStatus, commandOutput);
-        this.writeToStdOut(commandOutputWithStatus);
-        this.addNewline();
-    }
-    normalizeMessage(message) {
-        if (message.startsWith('nx run ')) {
-            return message.substring('nx run '.length);
-        }
-        else if (message.startsWith('run ')) {
-            return message.substring('run '.length);
-        }
-        else {
-            return message;
-        }
-    }
-    addTaskStatus(taskStatus, commandOutput) {
-        if (taskStatus === 'local-cache') {
-            return `${commandOutput}  ${chalk.dim('[local cache]')}`;
-        }
-        else if (taskStatus === 'remote-cache') {
-            return `${commandOutput}  ${chalk.dim('[remote cache]')}`;
-        }
-        else if (taskStatus === 'local-cache-kept-existing') {
-            return `${commandOutput}  ${chalk.dim('[existing outputs match the cache, left as is]')}`;
-        }
-        else {
-            return commandOutput;
-        }
-    }
-    log({ title, bodyLines, color }) {
-        this.addNewline();
-        this.writeOutputTitle({
-            color: 'cyan',
-            title: color ? chalk[color](title) : title,
-        });
-        this.writeOptionalOutputBody(bodyLines);
-        this.addNewline();
-    }
-    drain() {
-        return new Promise((resolve) => {
-            if (process.stdout.writableNeedDrain) {
-                process.stdout.once('drain', resolve);
-            }
-            else {
-                resolve();
-            }
-        });
-    }
+
+// Clears the cached tempDir value, if one is cached. This is exposed for tests
+// only.
+function clearCache() {
+  cachedTempDir = undefined;
 }
-exports.output = new CLIOutput();
+
+module.exports.tempDir = _tempDir;
+module.exports.isCached = isCached;
+module.exports.clearCache = clearCache;
 
 
 /***/ }),
 
-/***/ 14482:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
+/***/ 22766:
+/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
-"use strict";
+var common = __nccwpck_require__(60624);
+var fs = __nccwpck_require__(57147);
 
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.readModulePackageJson = exports.readModulePackageJsonWithoutFallbacks = exports.buildTargetFromScript = exports.readNxMigrateConfig = exports.normalizePackageGroup = void 0;
-const fs_1 = __nccwpck_require__(57147);
-const path_1 = __nccwpck_require__(71017);
-const fileutils_1 = __nccwpck_require__(47930);
-const installation_directory_1 = __nccwpck_require__(35075);
-function normalizePackageGroup(packageGroup) {
-    return Array.isArray(packageGroup)
-        ? packageGroup.map((x) => typeof x === 'string' ? { package: x, version: '*' } : x)
-        : Object.entries(packageGroup).map(([pkg, version]) => ({
-            package: pkg,
-            version,
-        }));
-}
-exports.normalizePackageGroup = normalizePackageGroup;
-function readNxMigrateConfig(json) {
-    const parseNxMigrationsConfig = (fromJson) => {
-        if (!fromJson) {
-            return {};
-        }
-        if (typeof fromJson === 'string') {
-            return { migrations: fromJson, packageGroup: [] };
-        }
-        return Object.assign(Object.assign({}, (fromJson.migrations ? { migrations: fromJson.migrations } : {})), (fromJson.packageGroup
-            ? { packageGroup: normalizePackageGroup(fromJson.packageGroup) }
-            : {}));
-    };
-    return Object.assign(Object.assign(Object.assign({}, parseNxMigrationsConfig(json['ng-update'])), parseNxMigrationsConfig(json['nx-migrations'])), parseNxMigrationsConfig(json));
-}
-exports.readNxMigrateConfig = readNxMigrateConfig;
-function buildTargetFromScript(script, nx) {
-    var _a;
-    const nxTargetConfiguration = ((_a = nx === null || nx === void 0 ? void 0 : nx.targets) === null || _a === void 0 ? void 0 : _a[script]) || {};
-    return Object.assign(Object.assign({}, nxTargetConfiguration), { executor: 'nx:run-script', options: Object.assign(Object.assign({}, (nxTargetConfiguration.options || {})), { script }) });
-}
-exports.buildTargetFromScript = buildTargetFromScript;
-/**
- * Uses `require.resolve` to read the package.json for a module.
- *
- * This will fail if the module doesn't export package.json
- *
- * @returns package json contents and path
- */
-function readModulePackageJsonWithoutFallbacks(moduleSpecifier, requirePaths = (0, installation_directory_1.getNxRequirePaths)()) {
-    const packageJsonPath = require.resolve(`${moduleSpecifier}/package.json`, {
-        paths: requirePaths,
-    });
-    const packageJson = (0, fileutils_1.readJsonFile)(packageJsonPath);
-    return {
-        path: packageJsonPath,
-        packageJson,
-    };
-}
-exports.readModulePackageJsonWithoutFallbacks = readModulePackageJsonWithoutFallbacks;
-/**
- * Reads the package.json file for a specified module.
- *
- * Includes a fallback that accounts for modules that don't export package.json
- *
- * @param {string} moduleSpecifier The module to look up
- * @param {string[]} requirePaths List of paths look in. Pass `module.paths` to ensure non-hoisted dependencies are found.
- *
- * @example
- * // Use the caller's lookup paths for non-hoisted dependencies
- * readModulePackageJson('http-server', module.paths);
- *
- * @returns package json contents and path
- */
-function readModulePackageJson(moduleSpecifier, requirePaths = (0, installation_directory_1.getNxRequirePaths)()) {
-    let packageJsonPath;
-    let packageJson;
-    try {
-        ({ path: packageJsonPath, packageJson } =
-            readModulePackageJsonWithoutFallbacks(moduleSpecifier, requirePaths));
-    }
-    catch (_a) {
-        const entryPoint = require.resolve(moduleSpecifier, {
-            paths: requirePaths,
-        });
-        let moduleRootPath = (0, path_1.dirname)(entryPoint);
-        packageJsonPath = (0, path_1.join)(moduleRootPath, 'package.json');
-        while (!(0, fs_1.existsSync)(packageJsonPath)) {
-            moduleRootPath = (0, path_1.dirname)(moduleRootPath);
-            packageJsonPath = (0, path_1.join)(moduleRootPath, 'package.json');
-        }
-        packageJson = (0, fileutils_1.readJsonFile)(packageJsonPath);
-        if (packageJson.name && packageJson.name !== moduleSpecifier) {
-            throw new Error(`Found module ${packageJson.name} while trying to locate ${moduleSpecifier}/package.json`);
-        }
-    }
-    return {
-        packageJson,
-        path: packageJsonPath,
-    };
-}
-exports.readModulePackageJson = readModulePackageJson;
+common.register('test', _test, {
+  cmdOptions: {
+    'b': 'block',
+    'c': 'character',
+    'd': 'directory',
+    'e': 'exists',
+    'f': 'file',
+    'L': 'link',
+    'p': 'pipe',
+    'S': 'socket',
+  },
+  wrapOutput: false,
+  allowGlobbing: false,
+});
 
 
-/***/ }),
+//@
+//@ ### test(expression)
+//@
+//@ Available expression primaries:
+//@
+//@ + `'-b', 'path'`: true if path is a block device
+//@ + `'-c', 'path'`: true if path is a character device
+//@ + `'-d', 'path'`: true if path is a directory
+//@ + `'-e', 'path'`: true if path exists
+//@ + `'-f', 'path'`: true if path is a regular file
+//@ + `'-L', 'path'`: true if path is a symbolic link
+//@ + `'-p', 'path'`: true if path is a pipe (FIFO)
+//@ + `'-S', 'path'`: true if path is a socket
+//@
+//@ Examples:
+//@
+//@ ```javascript
+//@ if (test('-d', path)) { /* do something with dir */ };
+//@ if (!test('-f', path)) continue; // skip if it's a regular file
+//@ ```
+//@
+//@ Evaluates `expression` using the available primaries and returns corresponding value.
+function _test(options, path) {
+  if (!path) common.error('no path given');
 
-/***/ 15425:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
+  var canInterpret = false;
+  Object.keys(options).forEach(function (key) {
+    if (options[key] === true) {
+      canInterpret = true;
+    }
+  });
 
-"use strict";
+  if (!canInterpret) common.error('could not interpret expression');
 
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.packageRegistryPack = exports.packageRegistryView = exports.resolvePackageVersionUsingInstallation = exports.resolvePackageVersionUsingRegistry = exports.createTempNpmDirectory = exports.copyPackageManagerConfigurationFiles = exports.modifyYarnRcToFitNewDirectory = exports.modifyYarnRcYmlToFitNewDirectory = exports.findFileInPackageJsonDirectory = exports.getPackageManagerVersion = exports.getPackageManagerCommand = exports.detectPackageManager = void 0;
-const tslib_1 = __nccwpck_require__(51796);
-const child_process_1 = __nccwpck_require__(32081);
-const fs_1 = __nccwpck_require__(57147);
-const fs_extra_1 = __nccwpck_require__(59511);
-const path_1 = __nccwpck_require__(71017);
-const tmp_1 = __nccwpck_require__(49503);
-const util_1 = __nccwpck_require__(73837);
-const fileutils_1 = __nccwpck_require__(47930);
-const package_json_1 = __nccwpck_require__(14482);
-const semver_1 = __nccwpck_require__(56192);
-const workspace_root_1 = __nccwpck_require__(65766);
-const configuration_1 = __nccwpck_require__(65459);
-const execAsync = (0, util_1.promisify)(child_process_1.exec);
-/**
- * Detects which package manager is used in the workspace based on the lock file.
- */
-function detectPackageManager(dir = '') {
-    var _a, _b;
-    const nxJson = (0, configuration_1.readNxJson)();
-    return ((_b = (_a = nxJson.cli) === null || _a === void 0 ? void 0 : _a.packageManager) !== null && _b !== void 0 ? _b : ((0, fs_1.existsSync)((0, path_1.join)(dir, 'yarn.lock'))
-        ? 'yarn'
-        : (0, fs_1.existsSync)((0, path_1.join)(dir, 'pnpm-lock.yaml'))
-            ? 'pnpm'
-            : 'npm'));
-}
-exports.detectPackageManager = detectPackageManager;
-/**
- * Returns commands for the package manager used in the workspace.
- * By default, the package manager is derived based on the lock file,
- * but it can also be passed in explicitly.
- *
- * Example:
- *
- * ```javascript
- * execSync(`${getPackageManagerCommand().addDev} my-dev-package`);
- * ```
- *
- * @param packageManager The package manager to use. If not provided, it will be detected based on the lock file.
- * @param root The directory the commands will be ran inside of. Defaults to the current workspace's root.
- */
-function getPackageManagerCommand(packageManager = detectPackageManager(), root = workspace_root_1.workspaceRoot) {
-    const commands = {
-        yarn: () => {
-            const yarnVersion = getPackageManagerVersion('yarn');
-            const useBerry = (0, semver_1.gte)(yarnVersion, '2.0.0');
-            return {
-                install: 'yarn',
-                ciInstall: useBerry
-                    ? 'yarn install --immutable'
-                    : 'yarn install --frozen-lockfile',
-                add: useBerry ? 'yarn add' : 'yarn add -W',
-                addDev: useBerry ? 'yarn add -D' : 'yarn add -D -W',
-                rm: 'yarn remove',
-                exec: useBerry ? 'yarn exec' : 'yarn',
-                run: (script, args) => `yarn ${script} ${args}`,
-                list: useBerry ? 'yarn info --name-only' : 'yarn list',
-            };
-        },
-        pnpm: () => {
-            const pnpmVersion = getPackageManagerVersion('pnpm');
-            const useExec = (0, semver_1.gte)(pnpmVersion, '6.13.0');
-            const includeDoubleDashBeforeArgs = (0, semver_1.lt)(pnpmVersion, '7.0.0');
-            const isPnpmWorkspace = (0, fs_1.existsSync)((0, path_1.join)(root, 'pnpm-workspace.yaml'));
-            return {
-                install: 'pnpm install --no-frozen-lockfile',
-                ciInstall: 'pnpm install --frozen-lockfile',
-                add: isPnpmWorkspace ? 'pnpm add -w' : 'pnpm add',
-                addDev: isPnpmWorkspace ? 'pnpm add -Dw' : 'pnpm add -D',
-                rm: 'pnpm rm',
-                exec: useExec ? 'pnpm exec' : 'pnpx',
-                run: (script, args) => includeDoubleDashBeforeArgs
-                    ? `pnpm run ${script} -- ${args}`
-                    : `pnpm run ${script} ${args}`,
-                list: 'pnpm ls --depth 100',
-            };
-        },
-        npm: () => {
-            var _a;
-            var _b;
-            // TODO: Remove this
-            (_a = (_b = process.env).npm_config_legacy_peer_deps) !== null && _a !== void 0 ? _a : (_b.npm_config_legacy_peer_deps = 'true');
-            return {
-                install: 'npm install',
-                ciInstall: 'npm ci',
-                add: 'npm install',
-                addDev: 'npm install -D',
-                rm: 'npm rm',
-                exec: 'npx',
-                run: (script, args) => `npm run ${script} -- ${args}`,
-                list: 'npm ls',
-            };
-        },
-    };
-    return commands[packageManager]();
-}
-exports.getPackageManagerCommand = getPackageManagerCommand;
-/**
- * Returns the version of the package manager used in the workspace.
- * By default, the package manager is derived based on the lock file,
- * but it can also be passed in explicitly.
- */
-function getPackageManagerVersion(packageManager = detectPackageManager()) {
-    return (0, child_process_1.execSync)(`${packageManager} --version`).toString('utf-8').trim();
-}
-exports.getPackageManagerVersion = getPackageManagerVersion;
-/**
- * Checks for a project level npmrc file by crawling up the file tree until
- * hitting a package.json file, as this is how npm finds them as well.
- */
-function findFileInPackageJsonDirectory(file, directory = process.cwd()) {
-    while (!(0, fs_1.existsSync)((0, path_1.join)(directory, 'package.json'))) {
-        directory = (0, path_1.dirname)(directory);
-    }
-    const path = (0, path_1.join)(directory, file);
-    return (0, fs_1.existsSync)(path) ? path : null;
-}
-exports.findFileInPackageJsonDirectory = findFileInPackageJsonDirectory;
-/**
- * We copy yarnrc.yml to the temporary directory to ensure things like the specified
- * package registry are still used. However, there are a few relative paths that can
- * cause issues, so we modify them to fit the new directory.
- *
- * Exported for testing - not meant to be used outside of this file.
- *
- * @param contents The string contents of the yarnrc.yml file
- * @returns Updated string contents of the yarnrc.yml file
- */
-function modifyYarnRcYmlToFitNewDirectory(contents) {
-    const { parseSyml, stringifySyml } = __nccwpck_require__(98006);
-    const parsed = parseSyml(contents);
-    if (parsed.yarnPath) {
-        // yarnPath is relative to the workspace root, so we need to make it relative
-        // to the new directory s.t. it still points to the same yarn binary.
-        delete parsed.yarnPath;
-    }
-    if (parsed.plugins) {
-        // Plugins specified by a string are relative paths from workspace root.
-        // ex: https://yarnpkg.com/advanced/plugin-tutorial#writing-our-first-plugin
-        delete parsed.plugins;
-    }
-    return stringifySyml(parsed);
-}
-exports.modifyYarnRcYmlToFitNewDirectory = modifyYarnRcYmlToFitNewDirectory;
-/**
- * We copy .yarnrc to the temporary directory to ensure things like the specified
- * package registry are still used. However, there are a few relative paths that can
- * cause issues, so we modify them to fit the new directory.
- *
- * Exported for testing - not meant to be used outside of this file.
- *
- * @param contents The string contents of the yarnrc.yml file
- * @returns Updated string contents of the yarnrc.yml file
- */
-function modifyYarnRcToFitNewDirectory(contents) {
-    const lines = contents.split('\n');
-    const yarnPathIndex = lines.findIndex((line) => line.startsWith('yarn-path'));
-    if (yarnPathIndex !== -1) {
-        lines.splice(yarnPathIndex, 1);
-    }
-    return lines.join('\n');
-}
-exports.modifyYarnRcToFitNewDirectory = modifyYarnRcToFitNewDirectory;
-function copyPackageManagerConfigurationFiles(root, destination) {
-    for (const packageManagerConfigFile of ['.npmrc', '.yarnrc', '.yarnrc.yml']) {
-        // f is an absolute path, including the {workspaceRoot}.
-        const f = findFileInPackageJsonDirectory(packageManagerConfigFile, root);
-        if (f) {
-            // Destination should be the same relative path from the {workspaceRoot},
-            // but now relative to the destination. `relative` makes `{workspaceRoot}/some/path`
-            // look like `./some/path`, and joining that gets us `{destination}/some/path
-            const destinationPath = (0, path_1.join)(destination, (0, path_1.relative)(root, f));
-            switch (packageManagerConfigFile) {
-                case '.npmrc': {
-                    (0, fs_1.copyFileSync)(f, destinationPath);
-                    break;
-                }
-                case '.yarnrc': {
-                    const updated = modifyYarnRcToFitNewDirectory((0, fileutils_1.readFileIfExisting)(f));
-                    (0, fs_1.writeFileSync)(destinationPath, updated);
-                    break;
-                }
-                case '.yarnrc.yml': {
-                    const updated = modifyYarnRcYmlToFitNewDirectory((0, fileutils_1.readFileIfExisting)(f));
-                    (0, fs_1.writeFileSync)(destinationPath, updated);
-                    break;
-                }
-            }
-        }
+  if (options.link) {
+    try {
+      return common.statNoFollowLinks(path).isSymbolicLink();
+    } catch (e) {
+      return false;
     }
-}
-exports.copyPackageManagerConfigurationFiles = copyPackageManagerConfigurationFiles;
-/**
- * Creates a temporary directory where you can run package manager commands safely.
- *
- * For cases where you'd want to install packages that require an `.npmrc` set up,
- * this function looks up for the nearest `.npmrc` (if exists) and copies it over to the
- * temp directory.
- */
-function createTempNpmDirectory() {
-    const dir = (0, tmp_1.dirSync)().name;
-    // A package.json is needed for pnpm pack and for .npmrc to resolve
-    (0, fileutils_1.writeJsonFile)(`${dir}/package.json`, {});
-    copyPackageManagerConfigurationFiles(workspace_root_1.workspaceRoot, dir);
-    const cleanup = () => tslib_1.__awaiter(this, void 0, void 0, function* () {
-        try {
-            yield (0, fs_extra_1.remove)(dir);
-        }
-        catch (_a) {
-            // It's okay if this fails, the OS will clean it up eventually
-        }
-    });
-    return { dir, cleanup };
-}
-exports.createTempNpmDirectory = createTempNpmDirectory;
-/**
- * Returns the resolved version for a given package and version tag using the
- * NPM registry (when using Yarn it will fall back to NPM to fetch the info).
- */
-function resolvePackageVersionUsingRegistry(packageName, version) {
-    return tslib_1.__awaiter(this, void 0, void 0, function* () {
-        try {
-            const result = yield packageRegistryView(packageName, version, 'version');
-            if (!result) {
-                throw new Error(`Unable to resolve version ${packageName}@${version}.`);
-            }
-            // get the last line of the output, strip the package version and quotes
-            const resolvedVersion = result
-                .split('\n')
-                .pop()
-                .split(' ')
-                .pop()
-                .replace(/'/g, '');
-            return resolvedVersion;
-        }
-        catch (_a) {
-            throw new Error(`Unable to resolve version ${packageName}@${version}.`);
-        }
-    });
-}
-exports.resolvePackageVersionUsingRegistry = resolvePackageVersionUsingRegistry;
-/**
- * Return the resolved version for a given package and version tag using by
- * installing it in a temporary directory and fetching the version from the
- * package.json.
- */
-function resolvePackageVersionUsingInstallation(packageName, version) {
-    return tslib_1.__awaiter(this, void 0, void 0, function* () {
-        const { dir, cleanup } = createTempNpmDirectory();
-        try {
-            const pmc = getPackageManagerCommand();
-            yield execAsync(`${pmc.add} ${packageName}@${version}`, { cwd: dir });
-            const { packageJson } = (0, package_json_1.readModulePackageJson)(packageName, [dir]);
-            return packageJson.version;
-        }
-        finally {
-            yield cleanup();
-        }
-    });
-}
-exports.resolvePackageVersionUsingInstallation = resolvePackageVersionUsingInstallation;
-function packageRegistryView(pkg, version, args) {
-    return tslib_1.__awaiter(this, void 0, void 0, function* () {
-        let pm = detectPackageManager();
-        if (pm === 'yarn') {
-            /**
-             * yarn has `yarn info` but it behaves differently than (p)npm,
-             * which makes it's usage unreliable
-             *
-             * @see https://github.com/nrwl/nx/pull/9667#discussion_r842553994
-             */
-            pm = 'npm';
-        }
-        const { stdout } = yield execAsync(`${pm} view ${pkg}@${version} ${args}`);
-        return stdout.toString().trim();
-    });
-}
-exports.packageRegistryView = packageRegistryView;
-function packageRegistryPack(cwd, pkg, version) {
-    return tslib_1.__awaiter(this, void 0, void 0, function* () {
-        let pm = detectPackageManager();
-        if (pm === 'yarn') {
-            /**
-             * `(p)npm pack` will download a tarball of the specified version,
-             * whereas `yarn` pack creates a tarball of the active workspace, so it
-             * does not work for getting the content of a library.
-             *
-             * @see https://github.com/nrwl/nx/pull/9667#discussion_r842553994
-             */
-            pm = 'npm';
-        }
-        const { stdout } = yield execAsync(`${pm} pack ${pkg}@${version}`, { cwd });
-        const tarballPath = stdout.trim();
-        return { tarballPath };
-    });
-}
-exports.packageRegistryPack = packageRegistryPack;
+  }
 
+  if (!fs.existsSync(path)) return false;
 
-/***/ }),
+  if (options.exists) return true;
 
-/***/ 75878:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
+  var stats = common.statFollowLinks(path);
 
-"use strict";
+  if (options.block) return stats.isBlockDevice();
 
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.joinPathFragments = exports.normalizePath = void 0;
-const path = __nccwpck_require__(71017);
-function removeWindowsDriveLetter(osSpecificPath) {
-    return osSpecificPath.replace(/^[A-Z]:/, '');
-}
-/**
- * Coverts an os specific path to a unix style path
- */
-function normalizePath(osSpecificPath) {
-    return removeWindowsDriveLetter(osSpecificPath).split('\\').join('/');
-}
-exports.normalizePath = normalizePath;
-/**
- * Normalized path fragments and joins them
- */
-function joinPathFragments(...fragments) {
-    return normalizePath(path.join(...fragments));
-}
-exports.joinPathFragments = joinPathFragments;
+  if (options.character) return stats.isCharacterDevice();
 
+  if (options.directory) return stats.isDirectory();
 
-/***/ }),
+  if (options.file) return stats.isFile();
 
-/***/ 27377:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
+  /* istanbul ignore next */
+  if (options.pipe) return stats.isFIFO();
 
-"use strict";
+  /* istanbul ignore next */
+  if (options.socket) return stats.isSocket();
 
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.findAllProjectNodeDependencies = exports.getSourceDirOfDependentProjects = exports.mergeNpmScriptsWithTargets = exports.projectHasTargetAndConfiguration = exports.projectHasTarget = void 0;
-const package_json_1 = __nccwpck_require__(14482);
-const path_1 = __nccwpck_require__(71017);
-const fileutils_1 = __nccwpck_require__(47930);
-const project_graph_1 = __nccwpck_require__(22055);
-function projectHasTarget(project, target) {
-    return !!(project.data &&
-        project.data.targets &&
-        project.data.targets[target]);
-}
-exports.projectHasTarget = projectHasTarget;
-function projectHasTargetAndConfiguration(project, target, configuration) {
-    return (projectHasTarget(project, target) &&
-        project.data.targets[target].configurations &&
-        project.data.targets[target].configurations[configuration]);
-}
-exports.projectHasTargetAndConfiguration = projectHasTargetAndConfiguration;
-function mergeNpmScriptsWithTargets(projectRoot, targets) {
-    try {
-        const { scripts, nx } = (0, fileutils_1.readJsonFile)((0, path_1.join)(projectRoot, 'package.json'));
-        const res = {};
-        // handle no scripts
-        Object.keys(scripts || {}).forEach((script) => {
-            if (!(nx === null || nx === void 0 ? void 0 : nx.includedScripts) || (nx === null || nx === void 0 ? void 0 : nx.includedScripts.includes(script))) {
-                res[script] = (0, package_json_1.buildTargetFromScript)(script, nx);
-            }
-        });
-        return Object.assign(Object.assign({}, res), (targets || {}));
-    }
-    catch (e) {
-        return targets;
-    }
-}
-exports.mergeNpmScriptsWithTargets = mergeNpmScriptsWithTargets;
-function getSourceDirOfDependentProjects(projectName, projectGraph = (0, project_graph_1.readCachedProjectGraph)()) {
-    if (!projectGraph.nodes[projectName]) {
-        throw new Error(`Couldn't find project "${projectName}" in this Nx workspace`);
-    }
-    const nodeNames = findAllProjectNodeDependencies(projectName, projectGraph);
-    return nodeNames.reduce((result, nodeName) => {
-        if (projectGraph.nodes[nodeName].data.sourceRoot) {
-            result[0].push(projectGraph.nodes[nodeName].data.sourceRoot);
-        }
-        else {
-            result[1].push(nodeName);
-        }
-        return result;
-    }, [[], []]);
-}
-exports.getSourceDirOfDependentProjects = getSourceDirOfDependentProjects;
-/**
- * Find all internal project dependencies.
- * All the external (npm) dependencies will be filtered out
- * @param {string} parentNodeName
- * @param {ProjectGraph} projectGraph
- * @returns {string[]}
- */
-function findAllProjectNodeDependencies(parentNodeName, projectGraph = (0, project_graph_1.readCachedProjectGraph)()) {
-    const dependencyNodeNames = new Set();
-    collectDependentProjectNodesNames(projectGraph, dependencyNodeNames, parentNodeName);
-    return Array.from(dependencyNodeNames);
-}
-exports.findAllProjectNodeDependencies = findAllProjectNodeDependencies;
-// Recursively get all the dependencies of the node
-function collectDependentProjectNodesNames(nxDeps, dependencyNodeNames, parentNodeName) {
-    var _a;
-    const dependencies = nxDeps.dependencies[parentNodeName];
-    if (!dependencies) {
-        // no dependencies for the given node, so silently return,
-        // as we probably wouldn't want to throw here
-        return;
-    }
-    for (const dependency of dependencies) {
-        const dependencyName = dependency.target;
-        // we're only interested in internal nodes, not external
-        if ((_a = nxDeps.externalNodes) === null || _a === void 0 ? void 0 : _a[dependencyName]) {
-            continue;
-        }
-        // skip dependencies already added (avoid circular dependencies)
-        if (dependencyNodeNames.has(dependencyName)) {
-            continue;
-        }
-        dependencyNodeNames.add(dependencyName);
-        // Get the dependencies of the dependencies
-        collectDependentProjectNodesNames(nxDeps, dependencyNodeNames, dependencyName);
-    }
-}
+  /* istanbul ignore next */
+  return false; // fallback
+} // test
+module.exports = _test;
 
 
 /***/ }),
 
-/***/ 45208:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
-
-"use strict";
-
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.PromisedBasedQueue = void 0;
-const tslib_1 = __nccwpck_require__(51796);
-class PromisedBasedQueue {
-    constructor() {
-        this.counter = 0;
-        this.promise = Promise.resolve(null);
-    }
-    sendToQueue(fn) {
-        this.counter++;
-        let res, rej;
-        const r = new Promise((_res, _rej) => {
-            res = _res;
-            rej = _rej;
-        });
-        this.promise = this.promise
-            .then(() => tslib_1.__awaiter(this, void 0, void 0, function* () {
-            try {
-                res(yield fn());
-                this.counter--;
-            }
-            catch (e) {
-                rej(e);
-                this.counter--;
-            }
-        }))
-            .catch(() => tslib_1.__awaiter(this, void 0, void 0, function* () {
-            try {
-                res(yield fn());
-                this.counter--;
-            }
-            catch (e) {
-                rej(e);
-                this.counter--;
-            }
-        }));
-        return r;
-    }
-    isEmpty() {
-        return this.counter === 0;
-    }
-}
-exports.PromisedBasedQueue = PromisedBasedQueue;
+/***/ 83181:
+/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
+var common = __nccwpck_require__(60624);
+var fs = __nccwpck_require__(57147);
+var path = __nccwpck_require__(71017);
 
-/***/ }),
+common.register('to', _to, {
+  pipeOnly: true,
+  wrapOutput: false,
+});
 
-/***/ 4477:
-/***/ ((__unused_webpack_module, exports) => {
+//@
+//@ ### ShellString.prototype.to(file)
+//@
+//@ Examples:
+//@
+//@ ```javascript
+//@ cat('input.txt').to('output.txt');
+//@ ```
+//@
+//@ Analogous to the redirection operator `>` in Unix, but works with
+//@ `ShellStrings` (such as those returned by `cat`, `grep`, etc.). _Like Unix
+//@ redirections, `to()` will overwrite any existing file!_
+function _to(options, file) {
+  if (!file) common.error('wrong arguments');
 
-"use strict";
+  if (!fs.existsSync(path.dirname(file))) {
+    common.error('no such file or directory: ' + path.dirname(file));
+  }
 
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.stripIndents = void 0;
-/**
- * Removes indents, which is useful for printing warning and messages.
- *
- * Example:
- *
- * ```typescript
- * stripIndents`
- *  Options:
- *  - option1
- *  - option2
- * `
- * ```
- */
-function stripIndents(strings, ...values) {
-    return String.raw(strings, ...values)
-        .split('\n')
-        .map((line) => line.trim())
-        .join('\n')
-        .trim();
+  try {
+    fs.writeFileSync(file, this.stdout || this.toString(), 'utf8');
+    return this;
+  } catch (e) {
+    /* istanbul ignore next */
+    common.error('could not write to file (code ' + e.code + '): ' + file, { continue: true });
+  }
 }
-exports.stripIndents = stripIndents;
+module.exports = _to;
 
 
 /***/ }),
 
-/***/ 39317:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
-
-"use strict";
-
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.nxVersion = void 0;
-exports.nxVersion = __nccwpck_require__(89617).version;
+/***/ 5836:
+/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
+var common = __nccwpck_require__(60624);
+var fs = __nccwpck_require__(57147);
+var path = __nccwpck_require__(71017);
 
-/***/ }),
+common.register('toEnd', _toEnd, {
+  pipeOnly: true,
+  wrapOutput: false,
+});
 
-/***/ 65766:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
+//@
+//@ ### ShellString.prototype.toEnd(file)
+//@
+//@ Examples:
+//@
+//@ ```javascript
+//@ cat('input.txt').toEnd('output.txt');
+//@ ```
+//@
+//@ Analogous to the redirect-and-append operator `>>` in Unix, but works with
+//@ `ShellStrings` (such as those returned by `cat`, `grep`, etc.).
+function _toEnd(options, file) {
+  if (!file) common.error('wrong arguments');
 
-"use strict";
+  if (!fs.existsSync(path.dirname(file))) {
+    common.error('no such file or directory: ' + path.dirname(file));
+  }
 
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.workspaceRootInner = exports.setWorkspaceRoot = exports.workspaceRoot = void 0;
-const path = __nccwpck_require__(71017);
-const fileutils_1 = __nccwpck_require__(47930);
-/**
- * The root of the workspace
- */
-exports.workspaceRoot = workspaceRootInner(process.cwd(), process.cwd());
-function setWorkspaceRoot(root) {
-    exports.workspaceRoot = root;
-}
-exports.setWorkspaceRoot = setWorkspaceRoot;
-function workspaceRootInner(dir, candidateRoot) {
-    if (process.env.NX_WORKSPACE_ROOT_PATH)
-        return process.env.NX_WORKSPACE_ROOT_PATH;
-    if (path.dirname(dir) === dir)
-        return candidateRoot;
-    const matches = [
-        path.join(dir, 'nx.json'),
-        path.join(dir, 'nx'),
-        path.join(dir, 'nx.bat'),
-    ];
-    if (matches.some((x) => (0, fileutils_1.fileExists)(x))) {
-        return dir;
-        // This handles the case where we have a workspace which uses npm / yarn / pnpm
-        // workspaces, and has a project which contains Nx in its dependency tree.
-        // e.g. packages/my-lib/package.json contains @nx/devkit, which references Nx and is
-        // thus located in //packages/my-lib/node_modules/nx/package.json
-    }
-    else if ((0, fileutils_1.fileExists)(path.join(dir, 'node_modules', 'nx', 'package.json'))) {
-        return workspaceRootInner(path.dirname(dir), dir);
-    }
-    else {
-        return workspaceRootInner(path.dirname(dir), candidateRoot);
-    }
+  try {
+    fs.appendFileSync(file, this.stdout || this.toString(), 'utf8');
+    return this;
+  } catch (e) {
+    /* istanbul ignore next */
+    common.error('could not append to file (code ' + e.code + '): ' + file, { continue: true });
+  }
 }
-exports.workspaceRootInner = workspaceRootInner;
+module.exports = _toEnd;
 
 
 /***/ }),
 
-/***/ 37909:
+/***/ 19811:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
-var wrappy = __nccwpck_require__(63180)
-module.exports = wrappy(once)
-module.exports.strict = wrappy(onceStrict)
+var common = __nccwpck_require__(60624);
+var fs = __nccwpck_require__(57147);
 
-once.proto = once(function () {
-  Object.defineProperty(Function.prototype, 'once', {
-    value: function () {
-      return once(this)
-    },
-    configurable: true
-  })
-
-  Object.defineProperty(Function.prototype, 'onceStrict', {
-    value: function () {
-      return onceStrict(this)
-    },
-    configurable: true
-  })
-})
+common.register('touch', _touch, {
+  cmdOptions: {
+    'a': 'atime_only',
+    'c': 'no_create',
+    'd': 'date',
+    'm': 'mtime_only',
+    'r': 'reference',
+  },
+});
 
-function once (fn) {
-  var f = function () {
-    if (f.called) return f.value
-    f.called = true
-    return f.value = fn.apply(this, arguments)
+//@
+//@ ### touch([options,] file [, file ...])
+//@ ### touch([options,] file_array)
+//@
+//@ Available options:
+//@
+//@ + `-a`: Change only the access time
+//@ + `-c`: Do not create any files
+//@ + `-m`: Change only the modification time
+//@ + `-d DATE`: Parse `DATE` and use it instead of current time
+//@ + `-r FILE`: Use `FILE`'s times instead of current time
+//@
+//@ Examples:
+//@
+//@ ```javascript
+//@ touch('source.js');
+//@ touch('-c', '/path/to/some/dir/source.js');
+//@ touch({ '-r': FILE }, '/path/to/some/dir/source.js');
+//@ ```
+//@
+//@ Update the access and modification times of each `FILE` to the current time.
+//@ A `FILE` argument that does not exist is created empty, unless `-c` is supplied.
+//@ This is a partial implementation of [`touch(1)`](http://linux.die.net/man/1/touch).
+function _touch(opts, files) {
+  if (!files) {
+    common.error('no files given');
+  } else if (typeof files === 'string') {
+    files = [].slice.call(arguments, 1);
+  } else {
+    common.error('file arg should be a string file path or an Array of string file paths');
   }
-  f.called = false
-  return f
+
+  files.forEach(function (f) {
+    touchFile(opts, f);
+  });
+  return '';
 }
 
-function onceStrict (fn) {
-  var f = function () {
-    if (f.called)
-      throw new Error(f.onceError)
-    f.called = true
-    return f.value = fn.apply(this, arguments)
+function touchFile(opts, file) {
+  var stat = tryStatFile(file);
+
+  if (stat && stat.isDirectory()) {
+    // don't error just exit
+    return;
   }
-  var name = fn.name || 'Function wrapped with `once`'
-  f.onceError = name + " shouldn't be called more than once"
-  f.called = false
-  return f
-}
 
+  // if the file doesn't already exist and the user has specified --no-create then
+  // this script is finished
+  if (!stat && opts.no_create) {
+    return;
+  }
 
-/***/ }),
+  // open the file and then close it. this will create it if it doesn't exist but will
+  // not truncate the file
+  fs.closeSync(fs.openSync(file, 'a'));
 
-/***/ 50124:
-/***/ ((module) => {
+  //
+  // Set timestamps
+  //
 
-"use strict";
+  // setup some defaults
+  var now = new Date();
+  var mtime = opts.date || now;
+  var atime = opts.date || now;
 
+  // use reference file
+  if (opts.reference) {
+    var refStat = tryStatFile(opts.reference);
+    if (!refStat) {
+      common.error('failed to get attributess of ' + opts.reference);
+    }
+    mtime = refStat.mtime;
+    atime = refStat.atime;
+  } else if (opts.date) {
+    mtime = opts.date;
+    atime = opts.date;
+  }
 
-function posix(path) {
-	return path.charAt(0) === '/';
+  if (opts.atime_only && opts.mtime_only) {
+    // keep the new values of mtime and atime like GNU
+  } else if (opts.atime_only) {
+    mtime = stat.mtime;
+  } else if (opts.mtime_only) {
+    atime = stat.atime;
+  }
+
+  fs.utimesSync(file, atime, mtime);
 }
 
-function win32(path) {
-	// https://github.com/nodejs/node/blob/b3fcc245fb25539909ef1d5eaa01dbf92e168633/lib/path.js#L56
-	var splitDeviceRe = /^([a-zA-Z]:|[\\\/]{2}[^\\\/]+[\\\/]+[^\\\/]+)?([\\\/])?([\s\S]*?)$/;
-	var result = splitDeviceRe.exec(path);
-	var device = result[1] || '';
-	var isUnc = Boolean(device && device.charAt(1) !== ':');
+module.exports = _touch;
 
-	// UNC paths are always absolute
-	return Boolean(result[2] || isUnc);
+function tryStatFile(filePath) {
+  try {
+    return common.statFollowLinks(filePath);
+  } catch (e) {
+    return null;
+  }
 }
 
-module.exports = process.platform === 'win32' ? win32 : posix;
-module.exports.posix = posix;
-module.exports.win32 = win32;
-
 
 /***/ }),
 
-/***/ 21224:
+/***/ 29095:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
-"use strict";
-
+var common = __nccwpck_require__(60624);
+var fs = __nccwpck_require__(57147);
 
-module.exports = __nccwpck_require__(74070);
+// add c spaces to the left of str
+function lpad(c, str) {
+  var res = '' + str;
+  if (res.length < c) {
+    res = Array((c - res.length) + 1).join(' ') + res;
+  }
+  return res;
+}
 
+common.register('uniq', _uniq, {
+  canReceivePipe: true,
+  cmdOptions: {
+    'i': 'ignoreCase',
+    'c': 'count',
+    'd': 'duplicates',
+  },
+});
 
-/***/ }),
+//@
+//@ ### uniq([options,] [input, [output]])
+//@
+//@ Available options:
+//@
+//@ + `-i`: Ignore case while comparing
+//@ + `-c`: Prefix lines by the number of occurrences
+//@ + `-d`: Only print duplicate lines, one for each group of identical lines
+//@
+//@ Examples:
+//@
+//@ ```javascript
+//@ uniq('foo.txt');
+//@ uniq('-i', 'foo.txt');
+//@ uniq('-cd', 'foo.txt', 'bar.txt');
+//@ ```
+//@
+//@ Filter adjacent matching lines from `input`.
+function _uniq(options, input, output) {
+  // Check if this is coming from a pipe
+  var pipe = common.readFromPipe();
 
-/***/ 67582:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+  if (!pipe) {
+    if (!input) common.error('no input given');
 
-"use strict";
+    if (!fs.existsSync(input)) {
+      common.error(input + ': No such file or directory');
+    } else if (common.statFollowLinks(input).isDirectory()) {
+      common.error("error reading '" + input + "'");
+    }
+  }
+  if (output && fs.existsSync(output) && common.statFollowLinks(output).isDirectory()) {
+    common.error(output + ': Is a directory');
+  }
 
+  var lines = (input ? fs.readFileSync(input, 'utf8') : pipe).
+              trimRight().
+              split('\n');
 
-const path = __nccwpck_require__(71017);
-const WIN_SLASH = '\\\\/';
-const WIN_NO_SLASH = `[^${WIN_SLASH}]`;
+  var compare = function (a, b) {
+    return options.ignoreCase ?
+           a.toLocaleLowerCase().localeCompare(b.toLocaleLowerCase()) :
+           a.localeCompare(b);
+  };
+  var uniqed = lines.reduceRight(function (res, e) {
+    // Perform uniq -c on the input
+    if (res.length === 0) {
+      return [{ count: 1, ln: e }];
+    } else if (compare(res[0].ln, e) === 0) {
+      return [{ count: res[0].count + 1, ln: e }].concat(res.slice(1));
+    } else {
+      return [{ count: 1, ln: e }].concat(res);
+    }
+  }, []).filter(function (obj) {
+                 // Do we want only duplicated objects?
+    return options.duplicates ? obj.count > 1 : true;
+  }).map(function (obj) {
+                 // Are we tracking the counts of each line?
+    return (options.count ? (lpad(7, obj.count) + ' ') : '') + obj.ln;
+  }).join('\n') + '\n';
 
-/**
- * Posix glob regex
- */
+  if (output) {
+    (new common.ShellString(uniqed)).to(output);
+    // if uniq writes to output, nothing is passed to the next command in the pipeline (if any)
+    return '';
+  } else {
+    return uniqed;
+  }
+}
 
-const DOT_LITERAL = '\\.';
-const PLUS_LITERAL = '\\+';
-const QMARK_LITERAL = '\\?';
-const SLASH_LITERAL = '\\/';
-const ONE_CHAR = '(?=.)';
-const QMARK = '[^/]';
-const END_ANCHOR = `(?:${SLASH_LITERAL}|$)`;
-const START_ANCHOR = `(?:^|${SLASH_LITERAL})`;
-const DOTS_SLASH = `${DOT_LITERAL}{1,2}${END_ANCHOR}`;
-const NO_DOT = `(?!${DOT_LITERAL})`;
-const NO_DOTS = `(?!${START_ANCHOR}${DOTS_SLASH})`;
-const NO_DOT_SLASH = `(?!${DOT_LITERAL}{0,1}${END_ANCHOR})`;
-const NO_DOTS_SLASH = `(?!${DOTS_SLASH})`;
-const QMARK_NO_DOT = `[^.${SLASH_LITERAL}]`;
-const STAR = `${QMARK}*?`;
-
-const POSIX_CHARS = {
-  DOT_LITERAL,
-  PLUS_LITERAL,
-  QMARK_LITERAL,
-  SLASH_LITERAL,
-  ONE_CHAR,
-  QMARK,
-  END_ANCHOR,
-  DOTS_SLASH,
-  NO_DOT,
-  NO_DOTS,
-  NO_DOT_SLASH,
-  NO_DOTS_SLASH,
-  QMARK_NO_DOT,
-  STAR,
-  START_ANCHOR
-};
+module.exports = _uniq;
 
-/**
- * Windows glob regex
- */
 
-const WINDOWS_CHARS = {
-  ...POSIX_CHARS,
-
-  SLASH_LITERAL: `[${WIN_SLASH}]`,
-  QMARK: WIN_NO_SLASH,
-  STAR: `${WIN_NO_SLASH}*?`,
-  DOTS_SLASH: `${DOT_LITERAL}{1,2}(?:[${WIN_SLASH}]|$)`,
-  NO_DOT: `(?!${DOT_LITERAL})`,
-  NO_DOTS: `(?!(?:^|[${WIN_SLASH}])${DOT_LITERAL}{1,2}(?:[${WIN_SLASH}]|$))`,
-  NO_DOT_SLASH: `(?!${DOT_LITERAL}{0,1}(?:[${WIN_SLASH}]|$))`,
-  NO_DOTS_SLASH: `(?!${DOT_LITERAL}{1,2}(?:[${WIN_SLASH}]|$))`,
-  QMARK_NO_DOT: `[^.${WIN_SLASH}]`,
-  START_ANCHOR: `(?:^|[${WIN_SLASH}])`,
-  END_ANCHOR: `(?:[${WIN_SLASH}]|$)`
-};
+/***/ }),
 
-/**
- * POSIX Bracket Regex
- */
+/***/ 70858:
+/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
-const POSIX_REGEX_SOURCE = {
-  alnum: 'a-zA-Z0-9',
-  alpha: 'a-zA-Z',
-  ascii: '\\x00-\\x7F',
-  blank: ' \\t',
-  cntrl: '\\x00-\\x1F\\x7F',
-  digit: '0-9',
-  graph: '\\x21-\\x7E',
-  lower: 'a-z',
-  print: '\\x20-\\x7E ',
-  punct: '\\-!"#$%&\'()\\*+,./:;<=>?@[\\]^_`{|}~',
-  space: ' \\t\\r\\n\\v\\f',
-  upper: 'A-Z',
-  word: 'A-Za-z0-9_',
-  xdigit: 'A-Fa-f0-9'
-};
+var common = __nccwpck_require__(60624);
+var fs = __nccwpck_require__(57147);
+var path = __nccwpck_require__(71017);
 
-module.exports = {
-  MAX_LENGTH: 1024 * 64,
-  POSIX_REGEX_SOURCE,
-
-  // regular expressions
-  REGEX_BACKSLASH: /\\(?![*+?^${}(|)[\]])/g,
-  REGEX_NON_SPECIAL_CHARS: /^[^@![\].,$*+?^{}()|\\/]+/,
-  REGEX_SPECIAL_CHARS: /[-*+?.^${}(|)[\]]/,
-  REGEX_SPECIAL_CHARS_BACKREF: /(\\?)((\W)(\3*))/g,
-  REGEX_SPECIAL_CHARS_GLOBAL: /([-*+?.^${}(|)[\]])/g,
-  REGEX_REMOVE_BACKSLASH: /(?:\[.*?[^\\]\]|\\(?=.))/g,
-
-  // Replace globs with equivalent patterns to reduce parsing time.
-  REPLACEMENTS: {
-    '***': '*',
-    '**/**': '**',
-    '**/**/**': '**'
+common.register('which', _which, {
+  allowGlobbing: false,
+  cmdOptions: {
+    'a': 'all',
   },
+});
 
-  // Digits
-  CHAR_0: 48, /* 0 */
-  CHAR_9: 57, /* 9 */
-
-  // Alphabet chars.
-  CHAR_UPPERCASE_A: 65, /* A */
-  CHAR_LOWERCASE_A: 97, /* a */
-  CHAR_UPPERCASE_Z: 90, /* Z */
-  CHAR_LOWERCASE_Z: 122, /* z */
-
-  CHAR_LEFT_PARENTHESES: 40, /* ( */
-  CHAR_RIGHT_PARENTHESES: 41, /* ) */
-
-  CHAR_ASTERISK: 42, /* * */
-
-  // Non-alphabetic chars.
-  CHAR_AMPERSAND: 38, /* & */
-  CHAR_AT: 64, /* @ */
-  CHAR_BACKWARD_SLASH: 92, /* \ */
-  CHAR_CARRIAGE_RETURN: 13, /* \r */
-  CHAR_CIRCUMFLEX_ACCENT: 94, /* ^ */
-  CHAR_COLON: 58, /* : */
-  CHAR_COMMA: 44, /* , */
-  CHAR_DOT: 46, /* . */
-  CHAR_DOUBLE_QUOTE: 34, /* " */
-  CHAR_EQUAL: 61, /* = */
-  CHAR_EXCLAMATION_MARK: 33, /* ! */
-  CHAR_FORM_FEED: 12, /* \f */
-  CHAR_FORWARD_SLASH: 47, /* / */
-  CHAR_GRAVE_ACCENT: 96, /* ` */
-  CHAR_HASH: 35, /* # */
-  CHAR_HYPHEN_MINUS: 45, /* - */
-  CHAR_LEFT_ANGLE_BRACKET: 60, /* < */
-  CHAR_LEFT_CURLY_BRACE: 123, /* { */
-  CHAR_LEFT_SQUARE_BRACKET: 91, /* [ */
-  CHAR_LINE_FEED: 10, /* \n */
-  CHAR_NO_BREAK_SPACE: 160, /* \u00A0 */
-  CHAR_PERCENT: 37, /* % */
-  CHAR_PLUS: 43, /* + */
-  CHAR_QUESTION_MARK: 63, /* ? */
-  CHAR_RIGHT_ANGLE_BRACKET: 62, /* > */
-  CHAR_RIGHT_CURLY_BRACE: 125, /* } */
-  CHAR_RIGHT_SQUARE_BRACKET: 93, /* ] */
-  CHAR_SEMICOLON: 59, /* ; */
-  CHAR_SINGLE_QUOTE: 39, /* ' */
-  CHAR_SPACE: 32, /*   */
-  CHAR_TAB: 9, /* \t */
-  CHAR_UNDERSCORE: 95, /* _ */
-  CHAR_VERTICAL_LINE: 124, /* | */
-  CHAR_ZERO_WIDTH_NOBREAK_SPACE: 65279, /* \uFEFF */
-
-  SEP: path.sep,
+// XP's system default value for `PATHEXT` system variable, just in case it's not
+// set on Windows.
+var XP_DEFAULT_PATHEXT = '.com;.exe;.bat;.cmd;.vbs;.vbe;.js;.jse;.wsf;.wsh';
 
-  /**
-   * Create EXTGLOB_CHARS
-   */
+// For earlier versions of NodeJS that doesn't have a list of constants (< v6)
+var FILE_EXECUTABLE_MODE = 1;
 
-  extglobChars(chars) {
-    return {
-      '!': { type: 'negate', open: '(?:(?!(?:', close: `))${chars.STAR})` },
-      '?': { type: 'qmark', open: '(?:', close: ')?' },
-      '+': { type: 'plus', open: '(?:', close: ')+' },
-      '*': { type: 'star', open: '(?:', close: ')*' },
-      '@': { type: 'at', open: '(?:', close: ')' }
-    };
-  },
+function isWindowsPlatform() {
+  return process.platform === 'win32';
+}
 
-  /**
-   * Create GLOB_CHARS
-   */
+// Cross-platform method for splitting environment `PATH` variables
+function splitPath(p) {
+  return p ? p.split(path.delimiter) : [];
+}
 
-  globChars(win32) {
-    return win32 === true ? WINDOWS_CHARS : POSIX_CHARS;
+// Tests are running all cases for this func but it stays uncovered by codecov due to unknown reason
+/* istanbul ignore next */
+function isExecutable(pathName) {
+  try {
+    // TODO(node-support): replace with fs.constants.X_OK once remove support for node < v6
+    fs.accessSync(pathName, FILE_EXECUTABLE_MODE);
+  } catch (err) {
+    return false;
   }
-};
+  return true;
+}
 
+function checkPath(pathName) {
+  return fs.existsSync(pathName) && !common.statFollowLinks(pathName).isDirectory()
+    && (isWindowsPlatform() || isExecutable(pathName));
+}
 
-/***/ }),
+//@
+//@ ### which(command)
+//@
+//@ Examples:
+//@
+//@ ```javascript
+//@ var nodeExec = which('node');
+//@ ```
+//@
+//@ Searches for `command` in the system's `PATH`. On Windows, this uses the
+//@ `PATHEXT` variable to append the extension if it's not already executable.
+//@ Returns string containing the absolute path to `command`.
+function _which(options, cmd) {
+  if (!cmd) common.error('must specify command');
 
-/***/ 90207:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+  var isWindows = isWindowsPlatform();
+  var pathArray = splitPath(process.env.PATH);
 
-"use strict";
+  var queryMatches = [];
 
+  // No relative/absolute paths provided?
+  if (cmd.indexOf('/') === -1) {
+    // Assume that there are no extensions to append to queries (this is the
+    // case for unix)
+    var pathExtArray = [''];
+    if (isWindows) {
+      // In case the PATHEXT variable is somehow not set (e.g.
+      // child_process.spawn with an empty environment), use the XP default.
+      var pathExtEnv = process.env.PATHEXT || XP_DEFAULT_PATHEXT;
+      pathExtArray = splitPath(pathExtEnv.toUpperCase());
+    }
 
-const constants = __nccwpck_require__(67582);
-const utils = __nccwpck_require__(76088);
+    // Search for command in PATH
+    for (var k = 0; k < pathArray.length; k++) {
+      // already found it
+      if (queryMatches.length > 0 && !options.all) break;
 
-/**
- * Constants
- */
+      var attempt = path.resolve(pathArray[k], cmd);
 
-const {
-  MAX_LENGTH,
-  POSIX_REGEX_SOURCE,
-  REGEX_NON_SPECIAL_CHARS,
-  REGEX_SPECIAL_CHARS_BACKREF,
-  REPLACEMENTS
-} = constants;
+      if (isWindows) {
+        attempt = attempt.toUpperCase();
+      }
 
-/**
- * Helpers
- */
+      var match = attempt.match(/\.[^<>:"/\|?*.]+$/);
+      if (match && pathExtArray.indexOf(match[0]) >= 0) { // this is Windows-only
+        // The user typed a query with the file extension, like
+        // `which('node.exe')`
+        if (checkPath(attempt)) {
+          queryMatches.push(attempt);
+          break;
+        }
+      } else { // All-platforms
+        // Cycle through the PATHEXT array, and check each extension
+        // Note: the array is always [''] on Unix
+        for (var i = 0; i < pathExtArray.length; i++) {
+          var ext = pathExtArray[i];
+          var newAttempt = attempt + ext;
+          if (checkPath(newAttempt)) {
+            queryMatches.push(newAttempt);
+            break;
+          }
+        }
+      }
+    }
+  } else if (checkPath(cmd)) { // a valid absolute or relative path
+    queryMatches.push(path.resolve(cmd));
+  }
 
-const expandRange = (args, options) => {
-  if (typeof options.expandRange === 'function') {
-    return options.expandRange(...args, options);
+  if (queryMatches.length > 0) {
+    return options.all ? queryMatches : queryMatches[0];
   }
+  return options.all ? [] : null;
+}
+module.exports = _which;
 
-  args.sort();
-  const value = `[${args.join('-')}]`;
 
-  try {
-    /* eslint-disable-next-line no-new */
-    new RegExp(value);
-  } catch (ex) {
-    return args.map(v => utils.escapeRegex(v)).join('..');
-  }
+/***/ }),
 
-  return value;
-};
+/***/ 98841:
+/***/ ((module, exports, __nccwpck_require__) => {
 
-/**
- * Create the message for a syntax error
- */
+/* module decorator */ module = __nccwpck_require__.nmd(module);
+var SourceMapConsumer = (__nccwpck_require__(53439).SourceMapConsumer);
+var path = __nccwpck_require__(71017);
 
-const syntaxError = (type, char) => {
-  return `Missing ${type}: "${char}" - use "\\\\${char}" to match literal characters`;
-};
+var fs;
+try {
+  fs = __nccwpck_require__(57147);
+  if (!fs.existsSync || !fs.readFileSync) {
+    // fs doesn't have all methods we need
+    fs = null;
+  }
+} catch (err) {
+  /* nop */
+}
+
+var bufferFrom = __nccwpck_require__(11720);
 
 /**
- * Parse the given input string.
- * @param {String} input
- * @param {Object} options
- * @return {Object}
+ * Requires a module which is protected against bundler minification.
+ *
+ * @param {NodeModule} mod
+ * @param {string} request
  */
+function dynamicRequire(mod, request) {
+  return mod.require(request);
+}
 
-const parse = (input, options) => {
-  if (typeof input !== 'string') {
-    throw new TypeError('Expected a string');
-  }
-
-  input = REPLACEMENTS[input] || input;
+// Only install once if called multiple times
+var errorFormatterInstalled = false;
+var uncaughtShimInstalled = false;
 
-  const opts = { ...options };
-  const max = typeof opts.maxLength === 'number' ? Math.min(MAX_LENGTH, opts.maxLength) : MAX_LENGTH;
+// If true, the caches are reset before a stack trace formatting operation
+var emptyCacheBetweenOperations = false;
 
-  let len = input.length;
-  if (len > max) {
-    throw new SyntaxError(`Input length: ${len}, exceeds maximum allowed length: ${max}`);
-  }
+// Supports {browser, node, auto}
+var environment = "auto";
 
-  const bos = { type: 'bos', value: '', output: opts.prepend || '' };
-  const tokens = [bos];
+// Maps a file path to a string containing the file contents
+var fileContentsCache = {};
 
-  const capture = opts.capture ? '' : '?:';
-  const win32 = utils.isWindows(options);
+// Maps a file path to a source map for that file
+var sourceMapCache = {};
 
-  // create constants based on platform, for windows or posix
-  const PLATFORM_CHARS = constants.globChars(win32);
-  const EXTGLOB_CHARS = constants.extglobChars(PLATFORM_CHARS);
+// Regex for detecting source maps
+var reSourceMap = /^data:application\/json[^,]+base64,/;
 
-  const {
-    DOT_LITERAL,
-    PLUS_LITERAL,
-    SLASH_LITERAL,
-    ONE_CHAR,
-    DOTS_SLASH,
-    NO_DOT,
-    NO_DOT_SLASH,
-    NO_DOTS_SLASH,
-    QMARK,
-    QMARK_NO_DOT,
-    STAR,
-    START_ANCHOR
-  } = PLATFORM_CHARS;
+// Priority list of retrieve handlers
+var retrieveFileHandlers = [];
+var retrieveMapHandlers = [];
 
-  const globstar = opts => {
-    return `(${capture}(?:(?!${START_ANCHOR}${opts.dot ? DOTS_SLASH : DOT_LITERAL}).)*?)`;
-  };
+function isInBrowser() {
+  if (environment === "browser")
+    return true;
+  if (environment === "node")
+    return false;
+  return ((typeof window !== 'undefined') && (typeof XMLHttpRequest === 'function') && !(window.require && window.module && window.process && window.process.type === "renderer"));
+}
 
-  const nodot = opts.dot ? '' : NO_DOT;
-  const qmarkNoDot = opts.dot ? QMARK : QMARK_NO_DOT;
-  let star = opts.bash === true ? globstar(opts) : STAR;
+function hasGlobalProcessEventEmitter() {
+  return ((typeof process === 'object') && (process !== null) && (typeof process.on === 'function'));
+}
 
-  if (opts.capture) {
-    star = `(${star})`;
+function globalProcessVersion() {
+  if ((typeof process === 'object') && (process !== null)) {
+    return process.version;
+  } else {
+    return '';
   }
+}
 
-  // minimatch options support
-  if (typeof opts.noext === 'boolean') {
-    opts.noextglob = opts.noext;
+function globalProcessStderr() {
+  if ((typeof process === 'object') && (process !== null)) {
+    return process.stderr;
   }
+}
 
-  const state = {
-    input,
-    index: -1,
-    start: 0,
-    dot: opts.dot === true,
-    consumed: '',
-    output: '',
-    prefix: '',
-    backtrack: false,
-    negated: false,
-    brackets: 0,
-    braces: 0,
-    parens: 0,
-    quotes: 0,
-    globstar: false,
-    tokens
-  };
-
-  input = utils.removePrefix(input, state);
-  len = input.length;
-
-  const extglobs = [];
-  const braces = [];
-  const stack = [];
-  let prev = bos;
-  let value;
-
-  /**
-   * Tokenizing helpers
-   */
-
-  const eos = () => state.index === len - 1;
-  const peek = state.peek = (n = 1) => input[state.index + n];
-  const advance = state.advance = () => input[++state.index] || '';
-  const remaining = () => input.slice(state.index + 1);
-  const consume = (value = '', num = 0) => {
-    state.consumed += value;
-    state.index += num;
-  };
-
-  const append = token => {
-    state.output += token.output != null ? token.output : token.value;
-    consume(token.value);
-  };
-
-  const negate = () => {
-    let count = 1;
-
-    while (peek() === '!' && (peek(2) !== '(' || peek(3) === '?')) {
-      advance();
-      state.start++;
-      count++;
-    }
+function globalProcessExit(code) {
+  if ((typeof process === 'object') && (process !== null) && (typeof process.exit === 'function')) {
+    return process.exit(code);
+  }
+}
 
-    if (count % 2 === 0) {
-      return false;
+function handlerExec(list) {
+  return function(arg) {
+    for (var i = 0; i < list.length; i++) {
+      var ret = list[i](arg);
+      if (ret) {
+        return ret;
+      }
     }
-
-    state.negated = true;
-    state.start++;
-    return true;
-  };
-
-  const increment = type => {
-    state[type]++;
-    stack.push(type);
-  };
-
-  const decrement = type => {
-    state[type]--;
-    stack.pop();
+    return null;
   };
+}
 
-  /**
-   * Push tokens onto the tokens array. This helper speeds up
-   * tokenizing by 1) helping us avoid backtracking as much as possible,
-   * and 2) helping us avoid creating extra tokens when consecutive
-   * characters are plain text. This improves performance and simplifies
-   * lookbehinds.
-   */
+var retrieveFile = handlerExec(retrieveFileHandlers);
 
-  const push = tok => {
-    if (prev.type === 'globstar') {
-      const isBrace = state.braces > 0 && (tok.type === 'comma' || tok.type === 'brace');
-      const isExtglob = tok.extglob === true || (extglobs.length && (tok.type === 'pipe' || tok.type === 'paren'));
+retrieveFileHandlers.push(function(path) {
+  // Trim the path to make sure there is no extra whitespace.
+  path = path.trim();
+  if (/^file:/.test(path)) {
+    // existsSync/readFileSync can't handle file protocol, but once stripped, it works
+    path = path.replace(/file:\/\/\/(\w:)?/, function(protocol, drive) {
+      return drive ?
+        '' : // file:///C:/dir/file -> C:/dir/file
+        '/'; // file:///root-dir/file -> /root-dir/file
+    });
+  }
+  if (path in fileContentsCache) {
+    return fileContentsCache[path];
+  }
 
-      if (tok.type !== 'slash' && tok.type !== 'paren' && !isBrace && !isExtglob) {
-        state.output = state.output.slice(0, -prev.output.length);
-        prev.type = 'star';
-        prev.value = '*';
-        prev.output = star;
-        state.output += prev.output;
+  var contents = '';
+  try {
+    if (!fs) {
+      // Use SJAX if we are in the browser
+      var xhr = new XMLHttpRequest();
+      xhr.open('GET', path, /** async */ false);
+      xhr.send(null);
+      if (xhr.readyState === 4 && xhr.status === 200) {
+        contents = xhr.responseText;
       }
+    } else if (fs.existsSync(path)) {
+      // Otherwise, use the filesystem
+      contents = fs.readFileSync(path, 'utf8');
     }
+  } catch (er) {
+    /* ignore any errors */
+  }
 
-    if (extglobs.length && tok.type !== 'paren') {
-      extglobs[extglobs.length - 1].inner += tok.value;
-    }
+  return fileContentsCache[path] = contents;
+});
 
-    if (tok.value || tok.output) append(tok);
-    if (prev && prev.type === 'text' && tok.type === 'text') {
-      prev.value += tok.value;
-      prev.output = (prev.output || '') + tok.value;
-      return;
-    }
+// Support URLs relative to a directory, but be careful about a protocol prefix
+// in case we are in the browser (i.e. directories may start with "http://" or "file:///")
+function supportRelativeURL(file, url) {
+  if (!file) return url;
+  var dir = path.dirname(file);
+  var match = /^\w+:\/\/[^\/]*/.exec(dir);
+  var protocol = match ? match[0] : '';
+  var startPath = dir.slice(protocol.length);
+  if (protocol && /^\/\w\:/.test(startPath)) {
+    // handle file:///C:/ paths
+    protocol += '/';
+    return protocol + path.resolve(dir.slice(protocol.length), url).replace(/\\/g, '/');
+  }
+  return protocol + path.resolve(dir.slice(protocol.length), url);
+}
 
-    tok.prev = prev;
-    tokens.push(tok);
-    prev = tok;
-  };
+function retrieveSourceMapURL(source) {
+  var fileData;
 
-  const extglobOpen = (type, value) => {
-    const token = { ...EXTGLOB_CHARS[value], conditions: 1, inner: '' };
+  if (isInBrowser()) {
+     try {
+       var xhr = new XMLHttpRequest();
+       xhr.open('GET', source, false);
+       xhr.send(null);
+       fileData = xhr.readyState === 4 ? xhr.responseText : null;
 
-    token.prev = prev;
-    token.parens = state.parens;
-    token.output = state.output;
-    const output = (opts.capture ? '(' : '') + token.open;
+       // Support providing a sourceMappingURL via the SourceMap header
+       var sourceMapHeader = xhr.getResponseHeader("SourceMap") ||
+                             xhr.getResponseHeader("X-SourceMap");
+       if (sourceMapHeader) {
+         return sourceMapHeader;
+       }
+     } catch (e) {
+     }
+  }
 
-    increment('parens');
-    push({ type, value, output: state.output ? '' : ONE_CHAR });
-    push({ type: 'paren', extglob: true, value: advance(), output });
-    extglobs.push(token);
-  };
+  // Get the URL of the source map
+  fileData = retrieveFile(source);
+  var re = /(?:\/\/[@#][\s]*sourceMappingURL=([^\s'"]+)[\s]*$)|(?:\/\*[@#][\s]*sourceMappingURL=([^\s*'"]+)[\s]*(?:\*\/)[\s]*$)/mg;
+  // Keep executing the search to find the *last* sourceMappingURL to avoid
+  // picking up sourceMappingURLs from comments, strings, etc.
+  var lastMatch, match;
+  while (match = re.exec(fileData)) lastMatch = match;
+  if (!lastMatch) return null;
+  return lastMatch[1];
+};
 
-  const extglobClose = token => {
-    let output = token.close + (opts.capture ? ')' : '');
-    let rest;
+// Can be overridden by the retrieveSourceMap option to install. Takes a
+// generated source filename; returns a {map, optional url} object, or null if
+// there is no source map.  The map field may be either a string or the parsed
+// JSON object (ie, it must be a valid argument to the SourceMapConsumer
+// constructor).
+var retrieveSourceMap = handlerExec(retrieveMapHandlers);
+retrieveMapHandlers.push(function(source) {
+  var sourceMappingURL = retrieveSourceMapURL(source);
+  if (!sourceMappingURL) return null;
 
-    if (token.type === 'negate') {
-      let extglobStar = star;
+  // Read the contents of the source map
+  var sourceMapData;
+  if (reSourceMap.test(sourceMappingURL)) {
+    // Support source map URL as a data url
+    var rawData = sourceMappingURL.slice(sourceMappingURL.indexOf(',') + 1);
+    sourceMapData = bufferFrom(rawData, "base64").toString();
+    sourceMappingURL = source;
+  } else {
+    // Support source map URLs relative to the source URL
+    sourceMappingURL = supportRelativeURL(source, sourceMappingURL);
+    sourceMapData = retrieveFile(sourceMappingURL);
+  }
 
-      if (token.inner && token.inner.length > 1 && token.inner.includes('/')) {
-        extglobStar = globstar(opts);
-      }
+  if (!sourceMapData) {
+    return null;
+  }
 
-      if (extglobStar !== star || eos() || /^\)+$/.test(remaining())) {
-        output = token.close = `)$))${extglobStar}`;
-      }
+  return {
+    url: sourceMappingURL,
+    map: sourceMapData
+  };
+});
 
-      if (token.inner.includes('*') && (rest = remaining()) && /^\.[^\\/.]+$/.test(rest)) {
-        // Any non-magical string (`.ts`) or even nested expression (`.{ts,tsx}`) can follow after the closing parenthesis.
-        // In this case, we need to parse the string and use it in the output of the original pattern.
-        // Suitable patterns: `/!(*.d).ts`, `/!(*.d).{ts,tsx}`, `**/!(*-dbg).@(js)`.
-        //
-        // Disabling the `fastpaths` option due to a problem with parsing strings as `.ts` in the pattern like `**/!(*.d).ts`.
-        const expression = parse(rest, { ...options, fastpaths: false }).output;
+function mapSourcePosition(position) {
+  var sourceMap = sourceMapCache[position.source];
+  if (!sourceMap) {
+    // Call the (overrideable) retrieveSourceMap function to get the source map.
+    var urlAndMap = retrieveSourceMap(position.source);
+    if (urlAndMap) {
+      sourceMap = sourceMapCache[position.source] = {
+        url: urlAndMap.url,
+        map: new SourceMapConsumer(urlAndMap.map)
+      };
 
-        output = token.close = `)${expression})${extglobStar})`;
+      // Load all sources stored inline with the source map into the file cache
+      // to pretend like they are already loaded. They may not exist on disk.
+      if (sourceMap.map.sourcesContent) {
+        sourceMap.map.sources.forEach(function(source, i) {
+          var contents = sourceMap.map.sourcesContent[i];
+          if (contents) {
+            var url = supportRelativeURL(sourceMap.url, source);
+            fileContentsCache[url] = contents;
+          }
+        });
       }
+    } else {
+      sourceMap = sourceMapCache[position.source] = {
+        url: null,
+        map: null
+      };
+    }
+  }
 
-      if (token.prev.type === 'bos') {
-        state.negatedExtglob = true;
-      }
+  // Resolve the source URL relative to the URL of the source map
+  if (sourceMap && sourceMap.map && typeof sourceMap.map.originalPositionFor === 'function') {
+    var originalPosition = sourceMap.map.originalPositionFor(position);
+
+    // Only return the original position if a matching line was found. If no
+    // matching line is found then we return position instead, which will cause
+    // the stack trace to print the path and line for the compiled file. It is
+    // better to give a precise location in the compiled file than a vague
+    // location in the original file.
+    if (originalPosition.source !== null) {
+      originalPosition.source = supportRelativeURL(
+        sourceMap.url, originalPosition.source);
+      return originalPosition;
     }
+  }
 
-    push({ type: 'paren', extglob: true, value, output });
-    decrement('parens');
-  };
+  return position;
+}
 
-  /**
-   * Fast paths
-   */
+// Parses code generated by FormatEvalOrigin(), a function inside V8:
+// https://code.google.com/p/v8/source/browse/trunk/src/messages.js
+function mapEvalOrigin(origin) {
+  // Most eval() calls are in this format
+  var match = /^eval at ([^(]+) \((.+):(\d+):(\d+)\)$/.exec(origin);
+  if (match) {
+    var position = mapSourcePosition({
+      source: match[2],
+      line: +match[3],
+      column: match[4] - 1
+    });
+    return 'eval at ' + match[1] + ' (' + position.source + ':' +
+      position.line + ':' + (position.column + 1) + ')';
+  }
 
-  if (opts.fastpaths !== false && !/(^[*!]|[/()[\]{}"])/.test(input)) {
-    let backslashes = false;
+  // Parse nested eval() calls using recursion
+  match = /^eval at ([^(]+) \((.+)\)$/.exec(origin);
+  if (match) {
+    return 'eval at ' + match[1] + ' (' + mapEvalOrigin(match[2]) + ')';
+  }
 
-    let output = input.replace(REGEX_SPECIAL_CHARS_BACKREF, (m, esc, chars, first, rest, index) => {
-      if (first === '\\') {
-        backslashes = true;
-        return m;
-      }
+  // Make sure we still return useful information if we didn't find anything
+  return origin;
+}
 
-      if (first === '?') {
-        if (esc) {
-          return esc + first + (rest ? QMARK.repeat(rest.length) : '');
-        }
-        if (index === 0) {
-          return qmarkNoDot + (rest ? QMARK.repeat(rest.length) : '');
-        }
-        return QMARK.repeat(chars.length);
-      }
+// This is copied almost verbatim from the V8 source code at
+// https://code.google.com/p/v8/source/browse/trunk/src/messages.js. The
+// implementation of wrapCallSite() used to just forward to the actual source
+// code of CallSite.prototype.toString but unfortunately a new release of V8
+// did something to the prototype chain and broke the shim. The only fix I
+// could find was copy/paste.
+function CallSiteToString() {
+  var fileName;
+  var fileLocation = "";
+  if (this.isNative()) {
+    fileLocation = "native";
+  } else {
+    fileName = this.getScriptNameOrSourceURL();
+    if (!fileName && this.isEval()) {
+      fileLocation = this.getEvalOrigin();
+      fileLocation += ", ";  // Expecting source position to follow.
+    }
 
-      if (first === '.') {
-        return DOT_LITERAL.repeat(chars.length);
+    if (fileName) {
+      fileLocation += fileName;
+    } else {
+      // Source code does not originate from a file and is not native, but we
+      // can still get the source position inside the source string, e.g. in
+      // an eval string.
+      fileLocation += "";
+    }
+    var lineNumber = this.getLineNumber();
+    if (lineNumber != null) {
+      fileLocation += ":" + lineNumber;
+      var columnNumber = this.getColumnNumber();
+      if (columnNumber) {
+        fileLocation += ":" + columnNumber;
       }
+    }
+  }
 
-      if (first === '*') {
-        if (esc) {
-          return esc + first + (rest ? star : '');
-        }
-        return star;
+  var line = "";
+  var functionName = this.getFunctionName();
+  var addSuffix = true;
+  var isConstructor = this.isConstructor();
+  var isMethodCall = !(this.isToplevel() || isConstructor);
+  if (isMethodCall) {
+    var typeName = this.getTypeName();
+    // Fixes shim to be backward compatable with Node v0 to v4
+    if (typeName === "[object Object]") {
+      typeName = "null";
+    }
+    var methodName = this.getMethodName();
+    if (functionName) {
+      if (typeName && functionName.indexOf(typeName) != 0) {
+        line += typeName + ".";
       }
-      return esc ? m : `\\${m}`;
-    });
-
-    if (backslashes === true) {
-      if (opts.unescape === true) {
-        output = output.replace(/\\/g, '');
-      } else {
-        output = output.replace(/\\+/g, m => {
-          return m.length % 2 === 0 ? '\\\\' : (m ? '\\' : '');
-        });
+      line += functionName;
+      if (methodName && functionName.indexOf("." + methodName) != functionName.length - methodName.length - 1) {
+        line += " [as " + methodName + "]";
       }
+    } else {
+      line += typeName + "." + (methodName || "");
     }
+  } else if (isConstructor) {
+    line += "new " + (functionName || "");
+  } else if (functionName) {
+    line += functionName;
+  } else {
+    line += fileLocation;
+    addSuffix = false;
+  }
+  if (addSuffix) {
+    line += " (" + fileLocation + ")";
+  }
+  return line;
+}
 
-    if (output === input && opts.contains === true) {
-      state.output = input;
-      return state;
-    }
+function cloneCallSite(frame) {
+  var object = {};
+  Object.getOwnPropertyNames(Object.getPrototypeOf(frame)).forEach(function(name) {
+    object[name] = /^(?:is|get)/.test(name) ? function() { return frame[name].call(frame); } : frame[name];
+  });
+  object.toString = CallSiteToString;
+  return object;
+}
 
-    state.output = utils.wrapOutput(output, state, options);
-    return state;
+function wrapCallSite(frame, state) {
+  // provides interface backward compatibility
+  if (state === undefined) {
+    state = { nextPosition: null, curPosition: null }
+  }
+  if(frame.isNative()) {
+    state.curPosition = null;
+    return frame;
   }
 
-  /**
-   * Tokenize input until we reach end-of-string
-   */
-
-  while (!eos()) {
-    value = advance();
+  // Most call sites will return the source file from getFileName(), but code
+  // passed to eval() ending in "//# sourceURL=..." will return the source file
+  // from getScriptNameOrSourceURL() instead
+  var source = frame.getFileName() || frame.getScriptNameOrSourceURL();
+  if (source) {
+    var line = frame.getLineNumber();
+    var column = frame.getColumnNumber() - 1;
 
-    if (value === '\u0000') {
-      continue;
+    // Fix position in Node where some (internal) code is prepended.
+    // See https://github.com/evanw/node-source-map-support/issues/36
+    // Header removed in node at ^10.16 || >=11.11.0
+    // v11 is not an LTS candidate, we can just test the one version with it.
+    // Test node versions for: 10.16-19, 10.20+, 12-19, 20-99, 100+, or 11.11
+    var noHeader = /^v(10\.1[6-9]|10\.[2-9][0-9]|10\.[0-9]{3,}|1[2-9]\d*|[2-9]\d|\d{3,}|11\.11)/;
+    var headerLength = noHeader.test(globalProcessVersion()) ? 0 : 62;
+    if (line === 1 && column > headerLength && !isInBrowser() && !frame.isEval()) {
+      column -= headerLength;
     }
 
-    /**
-     * Escaped characters
-     */
-
-    if (value === '\\') {
-      const next = peek();
-
-      if (next === '/' && opts.bash !== true) {
-        continue;
+    var position = mapSourcePosition({
+      source: source,
+      line: line,
+      column: column
+    });
+    state.curPosition = position;
+    frame = cloneCallSite(frame);
+    var originalFunctionName = frame.getFunctionName;
+    frame.getFunctionName = function() {
+      if (state.nextPosition == null) {
+        return originalFunctionName();
       }
+      return state.nextPosition.name || originalFunctionName();
+    };
+    frame.getFileName = function() { return position.source; };
+    frame.getLineNumber = function() { return position.line; };
+    frame.getColumnNumber = function() { return position.column + 1; };
+    frame.getScriptNameOrSourceURL = function() { return position.source; };
+    return frame;
+  }
 
-      if (next === '.' || next === ';') {
-        continue;
-      }
+  // Code called using eval() needs special handling
+  var origin = frame.isEval() && frame.getEvalOrigin();
+  if (origin) {
+    origin = mapEvalOrigin(origin);
+    frame = cloneCallSite(frame);
+    frame.getEvalOrigin = function() { return origin; };
+    return frame;
+  }
 
-      if (!next) {
-        value += '\\';
-        push({ type: 'text', value });
-        continue;
-      }
+  // If we get here then we were unable to change the source position
+  return frame;
+}
 
-      // collapse slashes to reduce potential for exploits
-      const match = /^\\+/.exec(remaining());
-      let slashes = 0;
+// This function is part of the V8 stack trace API, for more info see:
+// https://v8.dev/docs/stack-trace-api
+function prepareStackTrace(error, stack) {
+  if (emptyCacheBetweenOperations) {
+    fileContentsCache = {};
+    sourceMapCache = {};
+  }
 
-      if (match && match[0].length > 2) {
-        slashes = match[0].length;
-        state.index += slashes;
-        if (slashes % 2 !== 0) {
-          value += '\\';
-        }
-      }
+  var name = error.name || 'Error';
+  var message = error.message || '';
+  var errorString = name + ": " + message;
 
-      if (opts.unescape === true) {
-        value = advance();
-      } else {
-        value += advance();
-      }
+  var state = { nextPosition: null, curPosition: null };
+  var processedStack = [];
+  for (var i = stack.length - 1; i >= 0; i--) {
+    processedStack.push('\n    at ' + wrapCallSite(stack[i], state));
+    state.nextPosition = state.curPosition;
+  }
+  state.curPosition = state.nextPosition = null;
+  return errorString + processedStack.reverse().join('');
+}
 
-      if (state.brackets === 0) {
-        push({ type: 'text', value });
-        continue;
-      }
-    }
+// Generate position and snippet of original source with pointer
+function getErrorSource(error) {
+  var match = /\n    at [^(]+ \((.*):(\d+):(\d+)\)/.exec(error.stack);
+  if (match) {
+    var source = match[1];
+    var line = +match[2];
+    var column = +match[3];
 
-    /**
-     * If we're inside a regex character class, continue
-     * until we reach the closing bracket.
-     */
+    // Support the inline sourceContents inside the source map
+    var contents = fileContentsCache[source];
 
-    if (state.brackets > 0 && (value !== ']' || prev.value === '[' || prev.value === '[^')) {
-      if (opts.posix !== false && value === ':') {
-        const inner = prev.value.slice(1);
-        if (inner.includes('[')) {
-          prev.posix = true;
-
-          if (inner.includes(':')) {
-            const idx = prev.value.lastIndexOf('[');
-            const pre = prev.value.slice(0, idx);
-            const rest = prev.value.slice(idx + 2);
-            const posix = POSIX_REGEX_SOURCE[rest];
-            if (posix) {
-              prev.value = pre + posix;
-              state.backtrack = true;
-              advance();
-
-              if (!bos.output && tokens.indexOf(prev) === 1) {
-                bos.output = ONE_CHAR;
-              }
-              continue;
-            }
-          }
-        }
+    // Support files on disk
+    if (!contents && fs && fs.existsSync(source)) {
+      try {
+        contents = fs.readFileSync(source, 'utf8');
+      } catch (er) {
+        contents = '';
       }
+    }
 
-      if ((value === '[' && peek() !== ':') || (value === '-' && peek() === ']')) {
-        value = `\\${value}`;
+    // Format the line from the original source code like node does
+    if (contents) {
+      var code = contents.split(/(?:\r\n|\r|\n)/)[line - 1];
+      if (code) {
+        return source + ':' + line + '\n' + code + '\n' +
+          new Array(column).join(' ') + '^';
       }
+    }
+  }
+  return null;
+}
 
-      if (value === ']' && (prev.value === '[' || prev.value === '[^')) {
-        value = `\\${value}`;
-      }
+function printErrorAndExit (error) {
+  var source = getErrorSource(error);
 
-      if (opts.posix === true && value === '!' && prev.value === '[') {
-        value = '^';
-      }
+  // Ensure error is printed synchronously and not truncated
+  var stderr = globalProcessStderr();
+  if (stderr && stderr._handle && stderr._handle.setBlocking) {
+    stderr._handle.setBlocking(true);
+  }
 
-      prev.value += value;
-      append({ value });
-      continue;
-    }
+  if (source) {
+    console.error();
+    console.error(source);
+  }
 
-    /**
-     * If we're inside a quoted string, continue
-     * until we reach the closing double quote.
-     */
+  console.error(error.stack);
+  globalProcessExit(1);
+}
 
-    if (state.quotes === 1 && value !== '"') {
-      value = utils.escapeRegex(value);
-      prev.value += value;
-      append({ value });
-      continue;
-    }
+function shimEmitUncaughtException () {
+  var origEmit = process.emit;
 
-    /**
-     * Double quotes
-     */
+  process.emit = function (type) {
+    if (type === 'uncaughtException') {
+      var hasStack = (arguments[1] && arguments[1].stack);
+      var hasListeners = (this.listeners(type).length > 0);
 
-    if (value === '"') {
-      state.quotes = state.quotes === 1 ? 0 : 1;
-      if (opts.keepQuotes === true) {
-        push({ type: 'text', value });
+      if (hasStack && !hasListeners) {
+        return printErrorAndExit(arguments[1]);
       }
-      continue;
     }
 
-    /**
-     * Parentheses
-     */
+    return origEmit.apply(this, arguments);
+  };
+}
 
-    if (value === '(') {
-      increment('parens');
-      push({ type: 'paren', value });
-      continue;
-    }
+var originalRetrieveFileHandlers = retrieveFileHandlers.slice(0);
+var originalRetrieveMapHandlers = retrieveMapHandlers.slice(0);
 
-    if (value === ')') {
-      if (state.parens === 0 && opts.strictBrackets === true) {
-        throw new SyntaxError(syntaxError('opening', '('));
-      }
+exports.wrapCallSite = wrapCallSite;
+exports.getErrorSource = getErrorSource;
+exports.mapSourcePosition = mapSourcePosition;
+exports.retrieveSourceMap = retrieveSourceMap;
 
-      const extglob = extglobs[extglobs.length - 1];
-      if (extglob && state.parens === extglob.parens + 1) {
-        extglobClose(extglobs.pop());
-        continue;
-      }
+exports.install = function(options) {
+  options = options || {};
 
-      push({ type: 'paren', value, output: state.parens ? ')' : '\\)' });
-      decrement('parens');
-      continue;
+  if (options.environment) {
+    environment = options.environment;
+    if (["node", "browser", "auto"].indexOf(environment) === -1) {
+      throw new Error("environment " + environment + " was unknown. Available options are {auto, browser, node}")
     }
+  }
 
-    /**
-     * Square brackets
-     */
-
-    if (value === '[') {
-      if (opts.nobracket === true || !remaining().includes(']')) {
-        if (opts.nobracket !== true && opts.strictBrackets === true) {
-          throw new SyntaxError(syntaxError('closing', ']'));
-        }
+  // Allow sources to be found by methods other than reading the files
+  // directly from disk.
+  if (options.retrieveFile) {
+    if (options.overrideRetrieveFile) {
+      retrieveFileHandlers.length = 0;
+    }
 
-        value = `\\${value}`;
-      } else {
-        increment('brackets');
-      }
+    retrieveFileHandlers.unshift(options.retrieveFile);
+  }
 
-      push({ type: 'bracket', value });
-      continue;
+  // Allow source maps to be found by methods other than reading the files
+  // directly from disk.
+  if (options.retrieveSourceMap) {
+    if (options.overrideRetrieveSourceMap) {
+      retrieveMapHandlers.length = 0;
     }
 
-    if (value === ']') {
-      if (opts.nobracket === true || (prev && prev.type === 'bracket' && prev.value.length === 1)) {
-        push({ type: 'text', value, output: `\\${value}` });
-        continue;
-      }
-
-      if (state.brackets === 0) {
-        if (opts.strictBrackets === true) {
-          throw new SyntaxError(syntaxError('opening', '['));
-        }
+    retrieveMapHandlers.unshift(options.retrieveSourceMap);
+  }
 
-        push({ type: 'text', value, output: `\\${value}` });
-        continue;
-      }
+  // Support runtime transpilers that include inline source maps
+  if (options.hookRequire && !isInBrowser()) {
+    // Use dynamicRequire to avoid including in browser bundles
+    var Module = dynamicRequire(module, 'module');
+    var $compile = Module.prototype._compile;
 
-      decrement('brackets');
+    if (!$compile.__sourceMapSupport) {
+      Module.prototype._compile = function(content, filename) {
+        fileContentsCache[filename] = content;
+        sourceMapCache[filename] = undefined;
+        return $compile.call(this, content, filename);
+      };
 
-      const prevValue = prev.value.slice(1);
-      if (prev.posix !== true && prevValue[0] === '^' && !prevValue.includes('/')) {
-        value = `/${value}`;
-      }
+      Module.prototype._compile.__sourceMapSupport = true;
+    }
+  }
 
-      prev.value += value;
-      append({ value });
+  // Configure options
+  if (!emptyCacheBetweenOperations) {
+    emptyCacheBetweenOperations = 'emptyCacheBetweenOperations' in options ?
+      options.emptyCacheBetweenOperations : false;
+  }
 
-      // when literal brackets are explicitly disabled
-      // assume we should match with a regex character class
-      if (opts.literalBrackets === false || utils.hasRegexChars(prevValue)) {
-        continue;
-      }
+  // Install the error reformatter
+  if (!errorFormatterInstalled) {
+    errorFormatterInstalled = true;
+    Error.prepareStackTrace = prepareStackTrace;
+  }
 
-      const escaped = utils.escapeRegex(prev.value);
-      state.output = state.output.slice(0, -prev.value.length);
+  if (!uncaughtShimInstalled) {
+    var installHandler = 'handleUncaughtExceptions' in options ?
+      options.handleUncaughtExceptions : true;
 
-      // when literal brackets are explicitly enabled
-      // assume we should escape the brackets to match literal characters
-      if (opts.literalBrackets === true) {
-        state.output += escaped;
-        prev.value = escaped;
-        continue;
+    // Do not override 'uncaughtException' with our own handler in Node.js
+    // Worker threads. Workers pass the error to the main thread as an event,
+    // rather than printing something to stderr and exiting.
+    try {
+      // We need to use `dynamicRequire` because `require` on it's own will be optimized by WebPack/Browserify.
+      var worker_threads = dynamicRequire(module, 'worker_threads');
+      if (worker_threads.isMainThread === false) {
+        installHandler = false;
       }
+    } catch(e) {}
 
-      // when the user specifies nothing, try to match both
-      prev.value = `(${capture}${escaped}|${prev.value})`;
-      state.output += prev.value;
-      continue;
+    // Provide the option to not install the uncaught exception handler. This is
+    // to support other uncaught exception handlers (in test frameworks, for
+    // example). If this handler is not installed and there are no other uncaught
+    // exception handlers, uncaught exceptions will be caught by node's built-in
+    // exception handler and the process will still be terminated. However, the
+    // generated JavaScript code will be shown above the stack trace instead of
+    // the original source code.
+    if (installHandler && hasGlobalProcessEventEmitter()) {
+      uncaughtShimInstalled = true;
+      shimEmitUncaughtException();
     }
+  }
+};
 
-    /**
-     * Braces
-     */
+exports.resetRetrieveHandlers = function() {
+  retrieveFileHandlers.length = 0;
+  retrieveMapHandlers.length = 0;
 
-    if (value === '{' && opts.nobrace !== true) {
-      increment('braces');
+  retrieveFileHandlers = originalRetrieveFileHandlers.slice(0);
+  retrieveMapHandlers = originalRetrieveMapHandlers.slice(0);
 
-      const open = {
-        type: 'brace',
-        value,
-        output: '(',
-        outputIndex: state.output.length,
-        tokensIndex: state.tokens.length
-      };
+  retrieveSourceMap = handlerExec(retrieveMapHandlers);
+  retrieveFile = handlerExec(retrieveFileHandlers);
+}
 
-      braces.push(open);
-      push(open);
-      continue;
-    }
 
-    if (value === '}') {
-      const brace = braces[braces.length - 1];
+/***/ }),
 
-      if (opts.nobrace === true || !brace) {
-        push({ type: 'text', value, output: value });
-        continue;
-      }
+/***/ 62880:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
-      let output = ')';
+/* -*- Mode: js; js-indent-level: 2; -*- */
+/*
+ * Copyright 2011 Mozilla Foundation and contributors
+ * Licensed under the New BSD license. See LICENSE or:
+ * http://opensource.org/licenses/BSD-3-Clause
+ */
 
-      if (brace.dots === true) {
-        const arr = tokens.slice();
-        const range = [];
+var util = __nccwpck_require__(89479);
+var has = Object.prototype.hasOwnProperty;
+var hasNativeMap = typeof Map !== "undefined";
 
-        for (let i = arr.length - 1; i >= 0; i--) {
-          tokens.pop();
-          if (arr[i].type === 'brace') {
-            break;
-          }
-          if (arr[i].type !== 'dots') {
-            range.unshift(arr[i].value);
-          }
-        }
-
-        output = expandRange(range, opts);
-        state.backtrack = true;
-      }
-
-      if (brace.comma !== true && brace.dots !== true) {
-        const out = state.output.slice(0, brace.outputIndex);
-        const toks = state.tokens.slice(brace.tokensIndex);
-        brace.value = brace.output = '\\{';
-        value = output = '\\}';
-        state.output = out;
-        for (const t of toks) {
-          state.output += (t.output || t.value);
-        }
-      }
-
-      push({ type: 'brace', value, output });
-      decrement('braces');
-      braces.pop();
-      continue;
-    }
-
-    /**
-     * Pipes
-     */
-
-    if (value === '|') {
-      if (extglobs.length > 0) {
-        extglobs[extglobs.length - 1].conditions++;
-      }
-      push({ type: 'text', value });
-      continue;
-    }
-
-    /**
-     * Commas
-     */
-
-    if (value === ',') {
-      let output = value;
-
-      const brace = braces[braces.length - 1];
-      if (brace && stack[stack.length - 1] === 'braces') {
-        brace.comma = true;
-        output = '|';
-      }
-
-      push({ type: 'comma', value, output });
-      continue;
-    }
-
-    /**
-     * Slashes
-     */
-
-    if (value === '/') {
-      // if the beginning of the glob is "./", advance the start
-      // to the current index, and don't add the "./" characters
-      // to the state. This greatly simplifies lookbehinds when
-      // checking for BOS characters like "!" and "." (not "./")
-      if (prev.type === 'dot' && state.index === state.start + 1) {
-        state.start = state.index + 1;
-        state.consumed = '';
-        state.output = '';
-        tokens.pop();
-        prev = bos; // reset "prev" to the first token
-        continue;
-      }
-
-      push({ type: 'slash', value, output: SLASH_LITERAL });
-      continue;
-    }
-
-    /**
-     * Dots
-     */
-
-    if (value === '.') {
-      if (state.braces > 0 && prev.type === 'dot') {
-        if (prev.value === '.') prev.output = DOT_LITERAL;
-        const brace = braces[braces.length - 1];
-        prev.type = 'dots';
-        prev.output += value;
-        prev.value += value;
-        brace.dots = true;
-        continue;
-      }
-
-      if ((state.braces + state.parens) === 0 && prev.type !== 'bos' && prev.type !== 'slash') {
-        push({ type: 'text', value, output: DOT_LITERAL });
-        continue;
-      }
-
-      push({ type: 'dot', value, output: DOT_LITERAL });
-      continue;
-    }
-
-    /**
-     * Question marks
-     */
-
-    if (value === '?') {
-      const isGroup = prev && prev.value === '(';
-      if (!isGroup && opts.noextglob !== true && peek() === '(' && peek(2) !== '?') {
-        extglobOpen('qmark', value);
-        continue;
-      }
-
-      if (prev && prev.type === 'paren') {
-        const next = peek();
-        let output = value;
-
-        if (next === '<' && !utils.supportsLookbehinds()) {
-          throw new Error('Node.js v10 or higher is required for regex lookbehinds');
-        }
-
-        if ((prev.value === '(' && !/[!=<:]/.test(next)) || (next === '<' && !/<([!=]|\w+>)/.test(remaining()))) {
-          output = `\\${value}`;
-        }
-
-        push({ type: 'text', value, output });
-        continue;
-      }
-
-      if (opts.dot !== true && (prev.type === 'slash' || prev.type === 'bos')) {
-        push({ type: 'qmark', value, output: QMARK_NO_DOT });
-        continue;
-      }
-
-      push({ type: 'qmark', value, output: QMARK });
-      continue;
-    }
-
-    /**
-     * Exclamation
-     */
-
-    if (value === '!') {
-      if (opts.noextglob !== true && peek() === '(') {
-        if (peek(2) !== '?' || !/[!=<:]/.test(peek(3))) {
-          extglobOpen('negate', value);
-          continue;
-        }
-      }
-
-      if (opts.nonegate !== true && state.index === 0) {
-        negate();
-        continue;
-      }
-    }
-
-    /**
-     * Plus
-     */
-
-    if (value === '+') {
-      if (opts.noextglob !== true && peek() === '(' && peek(2) !== '?') {
-        extglobOpen('plus', value);
-        continue;
-      }
-
-      if ((prev && prev.value === '(') || opts.regex === false) {
-        push({ type: 'plus', value, output: PLUS_LITERAL });
-        continue;
-      }
-
-      if ((prev && (prev.type === 'bracket' || prev.type === 'paren' || prev.type === 'brace')) || state.parens > 0) {
-        push({ type: 'plus', value });
-        continue;
-      }
-
-      push({ type: 'plus', value: PLUS_LITERAL });
-      continue;
-    }
+/**
+ * A data structure which is a combination of an array and a set. Adding a new
+ * member is O(1), testing for membership is O(1), and finding the index of an
+ * element is O(1). Removing elements from the set is not supported. Only
+ * strings are supported for membership.
+ */
+function ArraySet() {
+  this._array = [];
+  this._set = hasNativeMap ? new Map() : Object.create(null);
+}
 
-    /**
-     * Plain text
-     */
+/**
+ * Static method for creating ArraySet instances from an existing array.
+ */
+ArraySet.fromArray = function ArraySet_fromArray(aArray, aAllowDuplicates) {
+  var set = new ArraySet();
+  for (var i = 0, len = aArray.length; i < len; i++) {
+    set.add(aArray[i], aAllowDuplicates);
+  }
+  return set;
+};
 
-    if (value === '@') {
-      if (opts.noextglob !== true && peek() === '(' && peek(2) !== '?') {
-        push({ type: 'at', extglob: true, value, output: '' });
-        continue;
-      }
+/**
+ * Return how many unique items are in this ArraySet. If duplicates have been
+ * added, than those do not count towards the size.
+ *
+ * @returns Number
+ */
+ArraySet.prototype.size = function ArraySet_size() {
+  return hasNativeMap ? this._set.size : Object.getOwnPropertyNames(this._set).length;
+};
 
-      push({ type: 'text', value });
-      continue;
+/**
+ * Add the given string to this set.
+ *
+ * @param String aStr
+ */
+ArraySet.prototype.add = function ArraySet_add(aStr, aAllowDuplicates) {
+  var sStr = hasNativeMap ? aStr : util.toSetString(aStr);
+  var isDuplicate = hasNativeMap ? this.has(aStr) : has.call(this._set, sStr);
+  var idx = this._array.length;
+  if (!isDuplicate || aAllowDuplicates) {
+    this._array.push(aStr);
+  }
+  if (!isDuplicate) {
+    if (hasNativeMap) {
+      this._set.set(aStr, idx);
+    } else {
+      this._set[sStr] = idx;
     }
+  }
+};
 
-    /**
-     * Plain text
-     */
-
-    if (value !== '*') {
-      if (value === '$' || value === '^') {
-        value = `\\${value}`;
-      }
-
-      const match = REGEX_NON_SPECIAL_CHARS.exec(remaining());
-      if (match) {
-        value += match[0];
-        state.index += match[0].length;
-      }
+/**
+ * Is the given string a member of this set?
+ *
+ * @param String aStr
+ */
+ArraySet.prototype.has = function ArraySet_has(aStr) {
+  if (hasNativeMap) {
+    return this._set.has(aStr);
+  } else {
+    var sStr = util.toSetString(aStr);
+    return has.call(this._set, sStr);
+  }
+};
 
-      push({ type: 'text', value });
-      continue;
+/**
+ * What is the index of the given string in the array?
+ *
+ * @param String aStr
+ */
+ArraySet.prototype.indexOf = function ArraySet_indexOf(aStr) {
+  if (hasNativeMap) {
+    var idx = this._set.get(aStr);
+    if (idx >= 0) {
+        return idx;
     }
-
-    /**
-     * Stars
-     */
-
-    if (prev && (prev.type === 'globstar' || prev.star === true)) {
-      prev.type = 'star';
-      prev.star = true;
-      prev.value += value;
-      prev.output = star;
-      state.backtrack = true;
-      state.globstar = true;
-      consume(value);
-      continue;
+  } else {
+    var sStr = util.toSetString(aStr);
+    if (has.call(this._set, sStr)) {
+      return this._set[sStr];
     }
+  }
 
-    let rest = remaining();
-    if (opts.noextglob !== true && /^\([^?]/.test(rest)) {
-      extglobOpen('star', value);
-      continue;
-    }
+  throw new Error('"' + aStr + '" is not in the set.');
+};
 
-    if (prev.type === 'star') {
-      if (opts.noglobstar === true) {
-        consume(value);
-        continue;
-      }
+/**
+ * What is the element at the given index?
+ *
+ * @param Number aIdx
+ */
+ArraySet.prototype.at = function ArraySet_at(aIdx) {
+  if (aIdx >= 0 && aIdx < this._array.length) {
+    return this._array[aIdx];
+  }
+  throw new Error('No element indexed by ' + aIdx);
+};
 
-      const prior = prev.prev;
-      const before = prior.prev;
-      const isStart = prior.type === 'slash' || prior.type === 'bos';
-      const afterStar = before && (before.type === 'star' || before.type === 'globstar');
+/**
+ * Returns the array representation of this set (which has the proper indices
+ * indicated by indexOf). Note that this is a copy of the internal array used
+ * for storing the members so that no one can mess with internal state.
+ */
+ArraySet.prototype.toArray = function ArraySet_toArray() {
+  return this._array.slice();
+};
 
-      if (opts.bash === true && (!isStart || (rest[0] && rest[0] !== '/'))) {
-        push({ type: 'star', value, output: '' });
-        continue;
-      }
+exports.I = ArraySet;
 
-      const isBrace = state.braces > 0 && (prior.type === 'comma' || prior.type === 'brace');
-      const isExtglob = extglobs.length && (prior.type === 'pipe' || prior.type === 'paren');
-      if (!isStart && prior.type !== 'paren' && !isBrace && !isExtglob) {
-        push({ type: 'star', value, output: '' });
-        continue;
-      }
 
-      // strip consecutive `/**/`
-      while (rest.slice(0, 3) === '/**') {
-        const after = input[state.index + 4];
-        if (after && after !== '/') {
-          break;
-        }
-        rest = rest.slice(3);
-        consume('/**', 3);
-      }
+/***/ }),
 
-      if (prior.type === 'bos' && eos()) {
-        prev.type = 'globstar';
-        prev.value += value;
-        prev.output = globstar(opts);
-        state.output = prev.output;
-        state.globstar = true;
-        consume(value);
-        continue;
-      }
+/***/ 26672:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
-      if (prior.type === 'slash' && prior.prev.type !== 'bos' && !afterStar && eos()) {
-        state.output = state.output.slice(0, -(prior.output + prev.output).length);
-        prior.output = `(?:${prior.output}`;
+/* -*- Mode: js; js-indent-level: 2; -*- */
+/*
+ * Copyright 2011 Mozilla Foundation and contributors
+ * Licensed under the New BSD license. See LICENSE or:
+ * http://opensource.org/licenses/BSD-3-Clause
+ *
+ * Based on the Base 64 VLQ implementation in Closure Compiler:
+ * https://code.google.com/p/closure-compiler/source/browse/trunk/src/com/google/debugging/sourcemap/Base64VLQ.java
+ *
+ * Copyright 2011 The Closure Compiler Authors. All rights reserved.
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions are
+ * met:
+ *
+ *  * Redistributions of source code must retain the above copyright
+ *    notice, this list of conditions and the following disclaimer.
+ *  * Redistributions in binary form must reproduce the above
+ *    copyright notice, this list of conditions and the following
+ *    disclaimer in the documentation and/or other materials provided
+ *    with the distribution.
+ *  * Neither the name of Google Inc. nor the names of its
+ *    contributors may be used to endorse or promote products derived
+ *    from this software without specific prior written permission.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
+ * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
+ * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
+ * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
+ * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
+ * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
+ * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
+ * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
+ * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
+ * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
+ * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+ */
 
-        prev.type = 'globstar';
-        prev.output = globstar(opts) + (opts.strictSlashes ? ')' : '|$)');
-        prev.value += value;
-        state.globstar = true;
-        state.output += prior.output + prev.output;
-        consume(value);
-        continue;
-      }
+var base64 = __nccwpck_require__(35533);
 
-      if (prior.type === 'slash' && prior.prev.type !== 'bos' && rest[0] === '/') {
-        const end = rest[1] !== void 0 ? '|$' : '';
+// A single base 64 digit can contain 6 bits of data. For the base 64 variable
+// length quantities we use in the source map spec, the first bit is the sign,
+// the next four bits are the actual value, and the 6th bit is the
+// continuation bit. The continuation bit tells us whether there are more
+// digits in this value following this digit.
+//
+//   Continuation
+//   |    Sign
+//   |    |
+//   V    V
+//   101011
 
-        state.output = state.output.slice(0, -(prior.output + prev.output).length);
-        prior.output = `(?:${prior.output}`;
+var VLQ_BASE_SHIFT = 5;
 
-        prev.type = 'globstar';
-        prev.output = `${globstar(opts)}${SLASH_LITERAL}|${SLASH_LITERAL}${end})`;
-        prev.value += value;
+// binary: 100000
+var VLQ_BASE = 1 << VLQ_BASE_SHIFT;
 
-        state.output += prior.output + prev.output;
-        state.globstar = true;
+// binary: 011111
+var VLQ_BASE_MASK = VLQ_BASE - 1;
 
-        consume(value + advance());
+// binary: 100000
+var VLQ_CONTINUATION_BIT = VLQ_BASE;
 
-        push({ type: 'slash', value: '/', output: '' });
-        continue;
-      }
+/**
+ * Converts from a two-complement value to a value where the sign bit is
+ * placed in the least significant bit.  For example, as decimals:
+ *   1 becomes 2 (10 binary), -1 becomes 3 (11 binary)
+ *   2 becomes 4 (100 binary), -2 becomes 5 (101 binary)
+ */
+function toVLQSigned(aValue) {
+  return aValue < 0
+    ? ((-aValue) << 1) + 1
+    : (aValue << 1) + 0;
+}
 
-      if (prior.type === 'bos' && rest[0] === '/') {
-        prev.type = 'globstar';
-        prev.value += value;
-        prev.output = `(?:^|${SLASH_LITERAL}|${globstar(opts)}${SLASH_LITERAL})`;
-        state.output = prev.output;
-        state.globstar = true;
-        consume(value + advance());
-        push({ type: 'slash', value: '/', output: '' });
-        continue;
-      }
+/**
+ * Converts to a two-complement value from a value where the sign bit is
+ * placed in the least significant bit.  For example, as decimals:
+ *   2 (10 binary) becomes 1, 3 (11 binary) becomes -1
+ *   4 (100 binary) becomes 2, 5 (101 binary) becomes -2
+ */
+function fromVLQSigned(aValue) {
+  var isNegative = (aValue & 1) === 1;
+  var shifted = aValue >> 1;
+  return isNegative
+    ? -shifted
+    : shifted;
+}
 
-      // remove single star from output
-      state.output = state.output.slice(0, -prev.output.length);
+/**
+ * Returns the base 64 VLQ encoded value.
+ */
+exports.encode = function base64VLQ_encode(aValue) {
+  var encoded = "";
+  var digit;
 
-      // reset previous token to globstar
-      prev.type = 'globstar';
-      prev.output = globstar(opts);
-      prev.value += value;
+  var vlq = toVLQSigned(aValue);
 
-      // reset output with globstar
-      state.output += prev.output;
-      state.globstar = true;
-      consume(value);
-      continue;
+  do {
+    digit = vlq & VLQ_BASE_MASK;
+    vlq >>>= VLQ_BASE_SHIFT;
+    if (vlq > 0) {
+      // There are still more digits in this value, so we must make sure the
+      // continuation bit is marked.
+      digit |= VLQ_CONTINUATION_BIT;
     }
+    encoded += base64.encode(digit);
+  } while (vlq > 0);
 
-    const token = { type: 'star', value, output: star };
+  return encoded;
+};
 
-    if (opts.bash === true) {
-      token.output = '.*?';
-      if (prev.type === 'bos' || prev.type === 'slash') {
-        token.output = nodot + token.output;
-      }
-      push(token);
-      continue;
-    }
+/**
+ * Decodes the next base 64 VLQ value from the given string and returns the
+ * value and the rest of the string via the out parameter.
+ */
+exports.decode = function base64VLQ_decode(aStr, aIndex, aOutParam) {
+  var strLen = aStr.length;
+  var result = 0;
+  var shift = 0;
+  var continuation, digit;
 
-    if (prev && (prev.type === 'bracket' || prev.type === 'paren') && opts.regex === true) {
-      token.output = value;
-      push(token);
-      continue;
+  do {
+    if (aIndex >= strLen) {
+      throw new Error("Expected more digits in base 64 VLQ value.");
     }
 
-    if (state.index === state.start || prev.type === 'slash' || prev.type === 'dot') {
-      if (prev.type === 'dot') {
-        state.output += NO_DOT_SLASH;
-        prev.output += NO_DOT_SLASH;
-
-      } else if (opts.dot === true) {
-        state.output += NO_DOTS_SLASH;
-        prev.output += NO_DOTS_SLASH;
-
-      } else {
-        state.output += nodot;
-        prev.output += nodot;
-      }
-
-      if (peek() !== '*') {
-        state.output += ONE_CHAR;
-        prev.output += ONE_CHAR;
-      }
+    digit = base64.decode(aStr.charCodeAt(aIndex++));
+    if (digit === -1) {
+      throw new Error("Invalid base64 digit: " + aStr.charAt(aIndex - 1));
     }
 
-    push(token);
-  }
+    continuation = !!(digit & VLQ_CONTINUATION_BIT);
+    digit &= VLQ_BASE_MASK;
+    result = result + (digit << shift);
+    shift += VLQ_BASE_SHIFT;
+  } while (continuation);
 
-  while (state.brackets > 0) {
-    if (opts.strictBrackets === true) throw new SyntaxError(syntaxError('closing', ']'));
-    state.output = utils.escapeLast(state.output, '[');
-    decrement('brackets');
-  }
+  aOutParam.value = fromVLQSigned(result);
+  aOutParam.rest = aIndex;
+};
 
-  while (state.parens > 0) {
-    if (opts.strictBrackets === true) throw new SyntaxError(syntaxError('closing', ')'));
-    state.output = utils.escapeLast(state.output, '(');
-    decrement('parens');
-  }
 
-  while (state.braces > 0) {
-    if (opts.strictBrackets === true) throw new SyntaxError(syntaxError('closing', '}'));
-    state.output = utils.escapeLast(state.output, '{');
-    decrement('braces');
-  }
+/***/ }),
 
-  if (opts.strictSlashes !== true && (prev.type === 'star' || prev.type === 'bracket')) {
-    push({ type: 'maybe_slash', value: '', output: `${SLASH_LITERAL}?` });
-  }
+/***/ 35533:
+/***/ ((__unused_webpack_module, exports) => {
 
-  // rebuild the output if we had to backtrack at any point
-  if (state.backtrack === true) {
-    state.output = '';
+/* -*- Mode: js; js-indent-level: 2; -*- */
+/*
+ * Copyright 2011 Mozilla Foundation and contributors
+ * Licensed under the New BSD license. See LICENSE or:
+ * http://opensource.org/licenses/BSD-3-Clause
+ */
 
-    for (const token of state.tokens) {
-      state.output += token.output != null ? token.output : token.value;
+var intToCharMap = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/'.split('');
 
-      if (token.suffix) {
-        state.output += token.suffix;
-      }
-    }
+/**
+ * Encode an integer in the range of 0 to 63 to a single base 64 digit.
+ */
+exports.encode = function (number) {
+  if (0 <= number && number < intToCharMap.length) {
+    return intToCharMap[number];
   }
-
-  return state;
+  throw new TypeError("Must be between 0 and 63: " + number);
 };
 
 /**
- * Fast paths for creating regular expressions for common glob patterns.
- * This can significantly speed up processing and has very little downside
- * impact when none of the fast paths match.
+ * Decode a single base 64 character code digit to an integer. Returns -1 on
+ * failure.
  */
+exports.decode = function (charCode) {
+  var bigA = 65;     // 'A'
+  var bigZ = 90;     // 'Z'
 
-parse.fastpaths = (input, options) => {
-  const opts = { ...options };
-  const max = typeof opts.maxLength === 'number' ? Math.min(MAX_LENGTH, opts.maxLength) : MAX_LENGTH;
-  const len = input.length;
-  if (len > max) {
-    throw new SyntaxError(`Input length: ${len}, exceeds maximum allowed length: ${max}`);
-  }
-
-  input = REPLACEMENTS[input] || input;
-  const win32 = utils.isWindows(options);
-
-  // create constants based on platform, for windows or posix
-  const {
-    DOT_LITERAL,
-    SLASH_LITERAL,
-    ONE_CHAR,
-    DOTS_SLASH,
-    NO_DOT,
-    NO_DOTS,
-    NO_DOTS_SLASH,
-    STAR,
-    START_ANCHOR
-  } = constants.globChars(win32);
-
-  const nodot = opts.dot ? NO_DOTS : NO_DOT;
-  const slashDot = opts.dot ? NO_DOTS_SLASH : NO_DOT;
-  const capture = opts.capture ? '' : '?:';
-  const state = { negated: false, prefix: '' };
-  let star = opts.bash === true ? '.*?' : STAR;
-
-  if (opts.capture) {
-    star = `(${star})`;
-  }
-
-  const globstar = opts => {
-    if (opts.noglobstar === true) return star;
-    return `(${capture}(?:(?!${START_ANCHOR}${opts.dot ? DOTS_SLASH : DOT_LITERAL}).)*?)`;
-  };
-
-  const create = str => {
-    switch (str) {
-      case '*':
-        return `${nodot}${ONE_CHAR}${star}`;
-
-      case '.*':
-        return `${DOT_LITERAL}${ONE_CHAR}${star}`;
-
-      case '*.*':
-        return `${nodot}${star}${DOT_LITERAL}${ONE_CHAR}${star}`;
-
-      case '*/*':
-        return `${nodot}${star}${SLASH_LITERAL}${ONE_CHAR}${slashDot}${star}`;
-
-      case '**':
-        return nodot + globstar(opts);
+  var littleA = 97;  // 'a'
+  var littleZ = 122; // 'z'
 
-      case '**/*':
-        return `(?:${nodot}${globstar(opts)}${SLASH_LITERAL})?${slashDot}${ONE_CHAR}${star}`;
+  var zero = 48;     // '0'
+  var nine = 57;     // '9'
 
-      case '**/*.*':
-        return `(?:${nodot}${globstar(opts)}${SLASH_LITERAL})?${slashDot}${star}${DOT_LITERAL}${ONE_CHAR}${star}`;
+  var plus = 43;     // '+'
+  var slash = 47;    // '/'
 
-      case '**/.*':
-        return `(?:${nodot}${globstar(opts)}${SLASH_LITERAL})?${DOT_LITERAL}${ONE_CHAR}${star}`;
+  var littleOffset = 26;
+  var numberOffset = 52;
 
-      default: {
-        const match = /^(.*?)\.(\w+)$/.exec(str);
-        if (!match) return;
+  // 0 - 25: ABCDEFGHIJKLMNOPQRSTUVWXYZ
+  if (bigA <= charCode && charCode <= bigZ) {
+    return (charCode - bigA);
+  }
 
-        const source = create(match[1]);
-        if (!source) return;
+  // 26 - 51: abcdefghijklmnopqrstuvwxyz
+  if (littleA <= charCode && charCode <= littleZ) {
+    return (charCode - littleA + littleOffset);
+  }
 
-        return source + DOT_LITERAL + match[2];
-      }
-    }
-  };
+  // 52 - 61: 0123456789
+  if (zero <= charCode && charCode <= nine) {
+    return (charCode - zero + numberOffset);
+  }
 
-  const output = utils.removePrefix(input, state);
-  let source = create(output);
+  // 62: +
+  if (charCode == plus) {
+    return 62;
+  }
 
-  if (source && opts.strictSlashes !== true) {
-    source += `${SLASH_LITERAL}?`;
+  // 63: /
+  if (charCode == slash) {
+    return 63;
   }
 
-  return source;
+  // Invalid base64 digit.
+  return -1;
 };
 
-module.exports = parse;
-
 
 /***/ }),
 
-/***/ 74070:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
-
-"use strict";
+/***/ 35039:
+/***/ ((__unused_webpack_module, exports) => {
 
+/* -*- Mode: js; js-indent-level: 2; -*- */
+/*
+ * Copyright 2011 Mozilla Foundation and contributors
+ * Licensed under the New BSD license. See LICENSE or:
+ * http://opensource.org/licenses/BSD-3-Clause
+ */
 
-const path = __nccwpck_require__(71017);
-const scan = __nccwpck_require__(61910);
-const parse = __nccwpck_require__(90207);
-const utils = __nccwpck_require__(76088);
-const constants = __nccwpck_require__(67582);
-const isObject = val => val && typeof val === 'object' && !Array.isArray(val);
+exports.GREATEST_LOWER_BOUND = 1;
+exports.LEAST_UPPER_BOUND = 2;
 
 /**
- * Creates a matcher function from one or more glob patterns. The
- * returned function takes a string to match as its first argument,
- * and returns true if the string is a match. The returned matcher
- * function also takes a boolean as the second argument that, when true,
- * returns an object with additional information.
- *
- * ```js
- * const picomatch = require('picomatch');
- * // picomatch(glob[, options]);
+ * Recursive implementation of binary search.
  *
- * const isMatch = picomatch('*.!(*a)');
- * console.log(isMatch('a.a')); //=> false
- * console.log(isMatch('a.b')); //=> true
- * ```
- * @name picomatch
- * @param {String|Array} `globs` One or more glob patterns.
- * @param {Object=} `options`
- * @return {Function=} Returns a matcher function.
- * @api public
+ * @param aLow Indices here and lower do not contain the needle.
+ * @param aHigh Indices here and higher do not contain the needle.
+ * @param aNeedle The element being searched for.
+ * @param aHaystack The non-empty array being searched.
+ * @param aCompare Function which takes two elements and returns -1, 0, or 1.
+ * @param aBias Either 'binarySearch.GREATEST_LOWER_BOUND' or
+ *     'binarySearch.LEAST_UPPER_BOUND'. Specifies whether to return the
+ *     closest element that is smaller than or greater than the one we are
+ *     searching for, respectively, if the exact element cannot be found.
  */
-
-const picomatch = (glob, options, returnState = false) => {
-  if (Array.isArray(glob)) {
-    const fns = glob.map(input => picomatch(input, options, returnState));
-    const arrayMatcher = str => {
-      for (const isMatch of fns) {
-        const state = isMatch(str);
-        if (state) return state;
-      }
-      return false;
-    };
-    return arrayMatcher;
-  }
-
-  const isState = isObject(glob) && glob.tokens && glob.input;
-
-  if (glob === '' || (typeof glob !== 'string' && !isState)) {
-    throw new TypeError('Expected pattern to be a non-empty string');
-  }
-
-  const opts = options || {};
-  const posix = utils.isWindows(options);
-  const regex = isState
-    ? picomatch.compileRe(glob, options)
-    : picomatch.makeRe(glob, options, false, true);
-
-  const state = regex.state;
-  delete regex.state;
-
-  let isIgnored = () => false;
-  if (opts.ignore) {
-    const ignoreOpts = { ...options, ignore: null, onMatch: null, onResult: null };
-    isIgnored = picomatch(opts.ignore, ignoreOpts, returnState);
+function recursiveSearch(aLow, aHigh, aNeedle, aHaystack, aCompare, aBias) {
+  // This function terminates when one of the following is true:
+  //
+  //   1. We find the exact element we are looking for.
+  //
+  //   2. We did not find the exact element, but we can return the index of
+  //      the next-closest element.
+  //
+  //   3. We did not find the exact element, and there is no next-closest
+  //      element than the one we are searching for, so we return -1.
+  var mid = Math.floor((aHigh - aLow) / 2) + aLow;
+  var cmp = aCompare(aNeedle, aHaystack[mid], true);
+  if (cmp === 0) {
+    // Found the element we are looking for.
+    return mid;
   }
-
-  const matcher = (input, returnObject = false) => {
-    const { isMatch, match, output } = picomatch.test(input, regex, options, { glob, posix });
-    const result = { glob, state, regex, posix, input, output, match, isMatch };
-
-    if (typeof opts.onResult === 'function') {
-      opts.onResult(result);
+  else if (cmp > 0) {
+    // Our needle is greater than aHaystack[mid].
+    if (aHigh - mid > 1) {
+      // The element is in the upper half.
+      return recursiveSearch(mid, aHigh, aNeedle, aHaystack, aCompare, aBias);
     }
 
-    if (isMatch === false) {
-      result.isMatch = false;
-      return returnObject ? result : false;
+    // The exact needle element was not found in this haystack. Determine if
+    // we are in termination case (3) or (2) and return the appropriate thing.
+    if (aBias == exports.LEAST_UPPER_BOUND) {
+      return aHigh < aHaystack.length ? aHigh : -1;
+    } else {
+      return mid;
     }
-
-    if (isIgnored(input)) {
-      if (typeof opts.onIgnore === 'function') {
-        opts.onIgnore(result);
-      }
-      result.isMatch = false;
-      return returnObject ? result : false;
+  }
+  else {
+    // Our needle is less than aHaystack[mid].
+    if (mid - aLow > 1) {
+      // The element is in the lower half.
+      return recursiveSearch(aLow, mid, aNeedle, aHaystack, aCompare, aBias);
     }
 
-    if (typeof opts.onMatch === 'function') {
-      opts.onMatch(result);
+    // we are in termination case (3) or (2) and return the appropriate thing.
+    if (aBias == exports.LEAST_UPPER_BOUND) {
+      return mid;
+    } else {
+      return aLow < 0 ? -1 : aLow;
     }
-    return returnObject ? result : true;
-  };
-
-  if (returnState) {
-    matcher.state = state;
   }
-
-  return matcher;
-};
+}
 
 /**
- * Test `input` with the given `regex`. This is used by the main
- * `picomatch()` function to test the input string.
- *
- * ```js
- * const picomatch = require('picomatch');
- * // picomatch.test(input, regex[, options]);
+ * This is an implementation of binary search which will always try and return
+ * the index of the closest element if there is no exact hit. This is because
+ * mappings between original and generated line/col pairs are single points,
+ * and there is an implicit region between each of them, so a miss just means
+ * that you aren't on the very start of a region.
  *
- * console.log(picomatch.test('foo/bar', /^(?:([^/]*?)\/([^/]*?))$/));
- * // { isMatch: true, match: [ 'foo/', 'foo', 'bar' ], output: 'foo/bar' }
- * ```
- * @param {String} `input` String to test.
- * @param {RegExp} `regex`
- * @return {Object} Returns an object with matching info.
- * @api public
+ * @param aNeedle The element you are looking for.
+ * @param aHaystack The array that is being searched.
+ * @param aCompare A function which takes the needle and an element in the
+ *     array and returns -1, 0, or 1 depending on whether the needle is less
+ *     than, equal to, or greater than the element, respectively.
+ * @param aBias Either 'binarySearch.GREATEST_LOWER_BOUND' or
+ *     'binarySearch.LEAST_UPPER_BOUND'. Specifies whether to return the
+ *     closest element that is smaller than or greater than the one we are
+ *     searching for, respectively, if the exact element cannot be found.
+ *     Defaults to 'binarySearch.GREATEST_LOWER_BOUND'.
  */
-
-picomatch.test = (input, regex, options, { glob, posix } = {}) => {
-  if (typeof input !== 'string') {
-    throw new TypeError('Expected input to be a string');
-  }
-
-  if (input === '') {
-    return { isMatch: false, output: '' };
+exports.search = function search(aNeedle, aHaystack, aCompare, aBias) {
+  if (aHaystack.length === 0) {
+    return -1;
   }
 
-  const opts = options || {};
-  const format = opts.format || (posix ? utils.toPosixSlashes : null);
-  let match = input === glob;
-  let output = (match && format) ? format(input) : input;
-
-  if (match === false) {
-    output = format ? format(input) : input;
-    match = output === glob;
+  var index = recursiveSearch(-1, aHaystack.length, aNeedle, aHaystack,
+                              aCompare, aBias || exports.GREATEST_LOWER_BOUND);
+  if (index < 0) {
+    return -1;
   }
 
-  if (match === false || opts.capture === true) {
-    if (opts.matchBase === true || opts.basename === true) {
-      match = picomatch.matchBase(input, regex, options, posix);
-    } else {
-      match = regex.exec(output);
+  // We have found either the exact element, or the next-closest element than
+  // the one we are searching for. However, there may be more than one such
+  // element. Make sure we always return the smallest of these.
+  while (index - 1 >= 0) {
+    if (aCompare(aHaystack[index], aHaystack[index - 1], true) !== 0) {
+      break;
     }
+    --index;
   }
 
-  return { isMatch: Boolean(match), match, output };
+  return index;
 };
 
-/**
- * Match the basename of a filepath.
- *
- * ```js
- * const picomatch = require('picomatch');
- * // picomatch.matchBase(input, glob[, options]);
- * console.log(picomatch.matchBase('foo/bar.js', '*.js'); // true
- * ```
- * @param {String} `input` String to test.
- * @param {RegExp|String} `glob` Glob pattern or regex created by [.makeRe](#makeRe).
- * @return {Boolean}
- * @api public
- */
 
-picomatch.matchBase = (input, glob, options, posix = utils.isWindows(options)) => {
-  const regex = glob instanceof RegExp ? glob : picomatch.makeRe(glob, options);
-  return regex.test(path.basename(input));
-};
+/***/ }),
 
-/**
- * Returns true if **any** of the given glob `patterns` match the specified `string`.
- *
- * ```js
- * const picomatch = require('picomatch');
- * // picomatch.isMatch(string, patterns[, options]);
- *
- * console.log(picomatch.isMatch('a.a', ['b.*', '*.a'])); //=> true
- * console.log(picomatch.isMatch('a.a', 'b.*')); //=> false
- * ```
- * @param {String|Array} str The string to test.
- * @param {String|Array} patterns One or more glob patterns to use for matching.
- * @param {Object} [options] See available [options](#options).
- * @return {Boolean} Returns true if any patterns match `str`
- * @api public
+/***/ 66439:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
+
+/* -*- Mode: js; js-indent-level: 2; -*- */
+/*
+ * Copyright 2014 Mozilla Foundation and contributors
+ * Licensed under the New BSD license. See LICENSE or:
+ * http://opensource.org/licenses/BSD-3-Clause
  */
 
-picomatch.isMatch = (str, patterns, options) => picomatch(patterns, options)(str);
+var util = __nccwpck_require__(89479);
 
 /**
- * Parse a glob pattern to create the source string for a regular
- * expression.
- *
- * ```js
- * const picomatch = require('picomatch');
- * const result = picomatch.parse(pattern[, options]);
- * ```
- * @param {String} `pattern`
- * @param {Object} `options`
- * @return {Object} Returns an object with useful properties and output to be used as a regex source string.
- * @api public
+ * Determine whether mappingB is after mappingA with respect to generated
+ * position.
  */
+function generatedPositionAfter(mappingA, mappingB) {
+  // Optimized for most common case
+  var lineA = mappingA.generatedLine;
+  var lineB = mappingB.generatedLine;
+  var columnA = mappingA.generatedColumn;
+  var columnB = mappingB.generatedColumn;
+  return lineB > lineA || lineB == lineA && columnB >= columnA ||
+         util.compareByGeneratedPositionsInflated(mappingA, mappingB) <= 0;
+}
 
-picomatch.parse = (pattern, options) => {
-  if (Array.isArray(pattern)) return pattern.map(p => picomatch.parse(p, options));
-  return parse(pattern, { ...options, fastpaths: false });
-};
+/**
+ * A data structure to provide a sorted view of accumulated mappings in a
+ * performance conscious manner. It trades a neglibable overhead in general
+ * case for a large speedup in case of mappings being added in order.
+ */
+function MappingList() {
+  this._array = [];
+  this._sorted = true;
+  // Serves as infimum
+  this._last = {generatedLine: -1, generatedColumn: 0};
+}
 
 /**
- * Scan a glob pattern to separate the pattern into segments.
- *
- * ```js
- * const picomatch = require('picomatch');
- * // picomatch.scan(input[, options]);
+ * Iterate through internal items. This method takes the same arguments that
+ * `Array.prototype.forEach` takes.
  *
- * const result = picomatch.scan('!./foo/*.js');
- * console.log(result);
- * { prefix: '!./',
- *   input: '!./foo/*.js',
- *   start: 3,
- *   base: 'foo',
- *   glob: '*.js',
- *   isBrace: false,
- *   isBracket: false,
- *   isGlob: true,
- *   isExtglob: false,
- *   isGlobstar: false,
- *   negated: true }
- * ```
- * @param {String} `input` Glob pattern to scan.
- * @param {Object} `options`
- * @return {Object} Returns an object with
- * @api public
+ * NOTE: The order of the mappings is NOT guaranteed.
  */
-
-picomatch.scan = (input, options) => scan(input, options);
+MappingList.prototype.unsortedForEach =
+  function MappingList_forEach(aCallback, aThisArg) {
+    this._array.forEach(aCallback, aThisArg);
+  };
 
 /**
- * Compile a regular expression from the `state` object returned by the
- * [parse()](#parse) method.
+ * Add the given source mapping.
  *
- * @param {Object} `state`
- * @param {Object} `options`
- * @param {Boolean} `returnOutput` Intended for implementors, this argument allows you to return the raw output from the parser.
- * @param {Boolean} `returnState` Adds the state to a `state` property on the returned regex. Useful for implementors and debugging.
- * @return {RegExp}
- * @api public
+ * @param Object aMapping
  */
-
-picomatch.compileRe = (state, options, returnOutput = false, returnState = false) => {
-  if (returnOutput === true) {
-    return state.output;
-  }
-
-  const opts = options || {};
-  const prepend = opts.contains ? '' : '^';
-  const append = opts.contains ? '' : '$';
-
-  let source = `${prepend}(?:${state.output})${append}`;
-  if (state && state.negated === true) {
-    source = `^(?!${source}).*$`;
-  }
-
-  const regex = picomatch.toRegex(source, options);
-  if (returnState === true) {
-    regex.state = state;
+MappingList.prototype.add = function MappingList_add(aMapping) {
+  if (generatedPositionAfter(this._last, aMapping)) {
+    this._last = aMapping;
+    this._array.push(aMapping);
+  } else {
+    this._sorted = false;
+    this._array.push(aMapping);
   }
-
-  return regex;
 };
 
 /**
- * Create a regular expression from a parsed glob pattern.
- *
- * ```js
- * const picomatch = require('picomatch');
- * const state = picomatch.parse('*.js');
- * // picomatch.compileRe(state[, options]);
+ * Returns the flat, sorted array of mappings. The mappings are sorted by
+ * generated position.
  *
- * console.log(picomatch.compileRe(state));
- * //=> /^(?:(?!\.)(?=.)[^/]*?\.js)$/
- * ```
- * @param {String} `state` The object returned from the `.parse` method.
- * @param {Object} `options`
- * @param {Boolean} `returnOutput` Implementors may use this argument to return the compiled output, instead of a regular expression. This is not exposed on the options to prevent end-users from mutating the result.
- * @param {Boolean} `returnState` Implementors may use this argument to return the state from the parsed glob with the returned regular expression.
- * @return {RegExp} Returns a regex created from the given pattern.
- * @api public
+ * WARNING: This method returns internal data without copying, for
+ * performance. The return value must NOT be mutated, and should be treated as
+ * an immutable borrow. If you want to take ownership, you must make your own
+ * copy.
  */
-
-picomatch.makeRe = (input, options = {}, returnOutput = false, returnState = false) => {
-  if (!input || typeof input !== 'string') {
-    throw new TypeError('Expected a non-empty string');
+MappingList.prototype.toArray = function MappingList_toArray() {
+  if (!this._sorted) {
+    this._array.sort(util.compareByGeneratedPositionsInflated);
+    this._sorted = true;
   }
+  return this._array;
+};
 
-  let parsed = { negated: false, fastpaths: true };
+exports.H = MappingList;
 
-  if (options.fastpaths !== false && (input[0] === '.' || input[0] === '*')) {
-    parsed.output = parse.fastpaths(input, options);
-  }
 
-  if (!parsed.output) {
-    parsed = parse(input, options);
-  }
+/***/ }),
 
-  return picomatch.compileRe(parsed, options, returnOutput, returnState);
-};
+/***/ 94438:
+/***/ ((__unused_webpack_module, exports) => {
 
-/**
- * Create a regular expression from the given regex source string.
- *
- * ```js
- * const picomatch = require('picomatch');
- * // picomatch.toRegex(source[, options]);
- *
- * const { output } = picomatch.parse('*.js');
- * console.log(picomatch.toRegex(output));
- * //=> /^(?:(?!\.)(?=.)[^/]*?\.js)$/
- * ```
- * @param {String} `source` Regular expression source string.
- * @param {Object} `options`
- * @return {RegExp}
- * @api public
+/* -*- Mode: js; js-indent-level: 2; -*- */
+/*
+ * Copyright 2011 Mozilla Foundation and contributors
+ * Licensed under the New BSD license. See LICENSE or:
+ * http://opensource.org/licenses/BSD-3-Clause
  */
 
-picomatch.toRegex = (source, options) => {
-  try {
-    const opts = options || {};
-    return new RegExp(source, opts.flags || (opts.nocase ? 'i' : ''));
-  } catch (err) {
-    if (options && options.debug === true) throw err;
-    return /$^/;
-  }
-};
+// It turns out that some (most?) JavaScript engines don't self-host
+// `Array.prototype.sort`. This makes sense because C++ will likely remain
+// faster than JS when doing raw CPU-intensive sorting. However, when using a
+// custom comparator function, calling back and forth between the VM's C++ and
+// JIT'd JS is rather slow *and* loses JIT type information, resulting in
+// worse generated code for the comparator function than would be optimal. In
+// fact, when sorting with a comparator, these costs outweigh the benefits of
+// sorting in C++. By using our own JS-implemented Quick Sort (below), we get
+// a ~3500ms mean speed-up in `bench/bench.html`.
 
 /**
- * Picomatch constants.
- * @return {Object}
+ * Swap the elements indexed by `x` and `y` in the array `ary`.
+ *
+ * @param {Array} ary
+ *        The array.
+ * @param {Number} x
+ *        The index of the first item.
+ * @param {Number} y
+ *        The index of the second item.
  */
-
-picomatch.constants = constants;
+function swap(ary, x, y) {
+  var temp = ary[x];
+  ary[x] = ary[y];
+  ary[y] = temp;
+}
 
 /**
- * Expose "picomatch"
+ * Returns a random integer within the range `low .. high` inclusive.
+ *
+ * @param {Number} low
+ *        The lower bound on the range.
+ * @param {Number} high
+ *        The upper bound on the range.
  */
+function randomIntInRange(low, high) {
+  return Math.round(low + (Math.random() * (high - low)));
+}
 
-module.exports = picomatch;
+/**
+ * The Quick Sort algorithm.
+ *
+ * @param {Array} ary
+ *        An array to sort.
+ * @param {function} comparator
+ *        Function to use to compare two items.
+ * @param {Number} p
+ *        Start index of the array
+ * @param {Number} r
+ *        End index of the array
+ */
+function doQuickSort(ary, comparator, p, r) {
+  // If our lower bound is less than our upper bound, we (1) partition the
+  // array into two pieces and (2) recurse on each half. If it is not, this is
+  // the empty array and our base case.
 
+  if (p < r) {
+    // (1) Partitioning.
+    //
+    // The partitioning chooses a pivot between `p` and `r` and moves all
+    // elements that are less than or equal to the pivot to the before it, and
+    // all the elements that are greater than it after it. The effect is that
+    // once partition is done, the pivot is in the exact place it will be when
+    // the array is put in sorted order, and it will not need to be moved
+    // again. This runs in O(n) time.
 
-/***/ }),
+    // Always choose a random pivot so that an input array which is reverse
+    // sorted does not cause O(n^2) running time.
+    var pivotIndex = randomIntInRange(p, r);
+    var i = p - 1;
 
-/***/ 61910:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+    swap(ary, pivotIndex, r);
+    var pivot = ary[r];
 
-"use strict";
+    // Immediately after `j` is incremented in this loop, the following hold
+    // true:
+    //
+    //   * Every element in `ary[p .. i]` is less than or equal to the pivot.
+    //
+    //   * Every element in `ary[i+1 .. j-1]` is greater than the pivot.
+    for (var j = p; j < r; j++) {
+      if (comparator(ary[j], pivot) <= 0) {
+        i += 1;
+        swap(ary, i, j);
+      }
+    }
 
+    swap(ary, i + 1, j);
+    var q = i + 1;
 
-const utils = __nccwpck_require__(76088);
-const {
-  CHAR_ASTERISK,             /* * */
-  CHAR_AT,                   /* @ */
-  CHAR_BACKWARD_SLASH,       /* \ */
-  CHAR_COMMA,                /* , */
-  CHAR_DOT,                  /* . */
-  CHAR_EXCLAMATION_MARK,     /* ! */
-  CHAR_FORWARD_SLASH,        /* / */
-  CHAR_LEFT_CURLY_BRACE,     /* { */
-  CHAR_LEFT_PARENTHESES,     /* ( */
-  CHAR_LEFT_SQUARE_BRACKET,  /* [ */
-  CHAR_PLUS,                 /* + */
-  CHAR_QUESTION_MARK,        /* ? */
-  CHAR_RIGHT_CURLY_BRACE,    /* } */
-  CHAR_RIGHT_PARENTHESES,    /* ) */
-  CHAR_RIGHT_SQUARE_BRACKET  /* ] */
-} = __nccwpck_require__(67582);
-
-const isPathSeparator = code => {
-  return code === CHAR_FORWARD_SLASH || code === CHAR_BACKWARD_SLASH;
-};
+    // (2) Recurse on each half.
 
-const depth = token => {
-  if (token.isPrefix !== true) {
-    token.depth = token.isGlobstar ? Infinity : 1;
+    doQuickSort(ary, comparator, p, q - 1);
+    doQuickSort(ary, comparator, q + 1, r);
   }
-};
+}
 
 /**
- * Quickly scans a glob pattern and returns an object with a handful of
- * useful properties, like `isGlob`, `path` (the leading non-glob, if it exists),
- * `glob` (the actual pattern), `negated` (true if the path starts with `!` but not
- * with `!(`) and `negatedExtglob` (true if the path starts with `!(`).
+ * Sort the given array in-place with the given comparator function.
  *
- * ```js
- * const pm = require('picomatch');
- * console.log(pm.scan('foo/bar/*.js'));
- * { isGlob: true, input: 'foo/bar/*.js', base: 'foo/bar', glob: '*.js' }
- * ```
- * @param {String} `str`
- * @param {Object} `options`
- * @return {Object} Returns an object with tokens and regex source string.
- * @api public
+ * @param {Array} ary
+ *        An array to sort.
+ * @param {function} comparator
+ *        Function to use to compare two items.
  */
+exports.U = function (ary, comparator) {
+  doQuickSort(ary, comparator, 0, ary.length - 1);
+};
 
-const scan = (input, options) => {
-  const opts = options || {};
-
-  const length = input.length - 1;
-  const scanToEnd = opts.parts === true || opts.scanToEnd === true;
-  const slashes = [];
-  const tokens = [];
-  const parts = [];
-
-  let str = input;
-  let index = -1;
-  let start = 0;
-  let lastIndex = 0;
-  let isBrace = false;
-  let isBracket = false;
-  let isGlob = false;
-  let isExtglob = false;
-  let isGlobstar = false;
-  let braceEscaped = false;
-  let backslashes = false;
-  let negated = false;
-  let negatedExtglob = false;
-  let finished = false;
-  let braces = 0;
-  let prev;
-  let code;
-  let token = { value: '', depth: 0, isGlob: false };
-
-  const eos = () => index >= length;
-  const peek = () => str.charCodeAt(index + 1);
-  const advance = () => {
-    prev = code;
-    return str.charCodeAt(++index);
-  };
 
-  while (index < length) {
-    code = advance();
-    let next;
+/***/ }),
 
-    if (code === CHAR_BACKWARD_SLASH) {
-      backslashes = token.backslashes = true;
-      code = advance();
+/***/ 89457:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
-      if (code === CHAR_LEFT_CURLY_BRACE) {
-        braceEscaped = true;
-      }
-      continue;
-    }
+var __webpack_unused_export__;
+/* -*- Mode: js; js-indent-level: 2; -*- */
+/*
+ * Copyright 2011 Mozilla Foundation and contributors
+ * Licensed under the New BSD license. See LICENSE or:
+ * http://opensource.org/licenses/BSD-3-Clause
+ */
 
-    if (braceEscaped === true || code === CHAR_LEFT_CURLY_BRACE) {
-      braces++;
+var util = __nccwpck_require__(89479);
+var binarySearch = __nccwpck_require__(35039);
+var ArraySet = (__nccwpck_require__(62880)/* .ArraySet */ .I);
+var base64VLQ = __nccwpck_require__(26672);
+var quickSort = (__nccwpck_require__(94438)/* .quickSort */ .U);
 
-      while (eos() !== true && (code = advance())) {
-        if (code === CHAR_BACKWARD_SLASH) {
-          backslashes = token.backslashes = true;
-          advance();
-          continue;
-        }
+function SourceMapConsumer(aSourceMap, aSourceMapURL) {
+  var sourceMap = aSourceMap;
+  if (typeof aSourceMap === 'string') {
+    sourceMap = util.parseSourceMapInput(aSourceMap);
+  }
 
-        if (code === CHAR_LEFT_CURLY_BRACE) {
-          braces++;
-          continue;
-        }
+  return sourceMap.sections != null
+    ? new IndexedSourceMapConsumer(sourceMap, aSourceMapURL)
+    : new BasicSourceMapConsumer(sourceMap, aSourceMapURL);
+}
 
-        if (braceEscaped !== true && code === CHAR_DOT && (code = advance()) === CHAR_DOT) {
-          isBrace = token.isBrace = true;
-          isGlob = token.isGlob = true;
-          finished = true;
+SourceMapConsumer.fromSourceMap = function(aSourceMap, aSourceMapURL) {
+  return BasicSourceMapConsumer.fromSourceMap(aSourceMap, aSourceMapURL);
+}
 
-          if (scanToEnd === true) {
-            continue;
-          }
+/**
+ * The version of the source mapping spec that we are consuming.
+ */
+SourceMapConsumer.prototype._version = 3;
 
-          break;
-        }
+// `__generatedMappings` and `__originalMappings` are arrays that hold the
+// parsed mapping coordinates from the source map's "mappings" attribute. They
+// are lazily instantiated, accessed via the `_generatedMappings` and
+// `_originalMappings` getters respectively, and we only parse the mappings
+// and create these arrays once queried for a source location. We jump through
+// these hoops because there can be many thousands of mappings, and parsing
+// them is expensive, so we only want to do it if we must.
+//
+// Each object in the arrays is of the form:
+//
+//     {
+//       generatedLine: The line number in the generated code,
+//       generatedColumn: The column number in the generated code,
+//       source: The path to the original source file that generated this
+//               chunk of code,
+//       originalLine: The line number in the original source that
+//                     corresponds to this chunk of generated code,
+//       originalColumn: The column number in the original source that
+//                       corresponds to this chunk of generated code,
+//       name: The name of the original symbol which generated this chunk of
+//             code.
+//     }
+//
+// All properties except for `generatedLine` and `generatedColumn` can be
+// `null`.
+//
+// `_generatedMappings` is ordered by the generated positions.
+//
+// `_originalMappings` is ordered by the original positions.
 
-        if (braceEscaped !== true && code === CHAR_COMMA) {
-          isBrace = token.isBrace = true;
-          isGlob = token.isGlob = true;
-          finished = true;
+SourceMapConsumer.prototype.__generatedMappings = null;
+Object.defineProperty(SourceMapConsumer.prototype, '_generatedMappings', {
+  configurable: true,
+  enumerable: true,
+  get: function () {
+    if (!this.__generatedMappings) {
+      this._parseMappings(this._mappings, this.sourceRoot);
+    }
 
-          if (scanToEnd === true) {
-            continue;
-          }
+    return this.__generatedMappings;
+  }
+});
 
-          break;
-        }
+SourceMapConsumer.prototype.__originalMappings = null;
+Object.defineProperty(SourceMapConsumer.prototype, '_originalMappings', {
+  configurable: true,
+  enumerable: true,
+  get: function () {
+    if (!this.__originalMappings) {
+      this._parseMappings(this._mappings, this.sourceRoot);
+    }
 
-        if (code === CHAR_RIGHT_CURLY_BRACE) {
-          braces--;
+    return this.__originalMappings;
+  }
+});
 
-          if (braces === 0) {
-            braceEscaped = false;
-            isBrace = token.isBrace = true;
-            finished = true;
-            break;
-          }
-        }
-      }
+SourceMapConsumer.prototype._charIsMappingSeparator =
+  function SourceMapConsumer_charIsMappingSeparator(aStr, index) {
+    var c = aStr.charAt(index);
+    return c === ";" || c === ",";
+  };
 
-      if (scanToEnd === true) {
-        continue;
-      }
+/**
+ * Parse the mappings in a string in to a data structure which we can easily
+ * query (the ordered arrays in the `this.__generatedMappings` and
+ * `this.__originalMappings` properties).
+ */
+SourceMapConsumer.prototype._parseMappings =
+  function SourceMapConsumer_parseMappings(aStr, aSourceRoot) {
+    throw new Error("Subclasses must implement _parseMappings");
+  };
 
-      break;
-    }
+SourceMapConsumer.GENERATED_ORDER = 1;
+SourceMapConsumer.ORIGINAL_ORDER = 2;
 
-    if (code === CHAR_FORWARD_SLASH) {
-      slashes.push(index);
-      tokens.push(token);
-      token = { value: '', depth: 0, isGlob: false };
+SourceMapConsumer.GREATEST_LOWER_BOUND = 1;
+SourceMapConsumer.LEAST_UPPER_BOUND = 2;
 
-      if (finished === true) continue;
-      if (prev === CHAR_DOT && index === (start + 1)) {
-        start += 2;
-        continue;
-      }
+/**
+ * Iterate over each mapping between an original source/line/column and a
+ * generated line/column in this source map.
+ *
+ * @param Function aCallback
+ *        The function that is called with each mapping.
+ * @param Object aContext
+ *        Optional. If specified, this object will be the value of `this` every
+ *        time that `aCallback` is called.
+ * @param aOrder
+ *        Either `SourceMapConsumer.GENERATED_ORDER` or
+ *        `SourceMapConsumer.ORIGINAL_ORDER`. Specifies whether you want to
+ *        iterate over the mappings sorted by the generated file's line/column
+ *        order or the original's source/line/column order, respectively. Defaults to
+ *        `SourceMapConsumer.GENERATED_ORDER`.
+ */
+SourceMapConsumer.prototype.eachMapping =
+  function SourceMapConsumer_eachMapping(aCallback, aContext, aOrder) {
+    var context = aContext || null;
+    var order = aOrder || SourceMapConsumer.GENERATED_ORDER;
 
-      lastIndex = index + 1;
-      continue;
+    var mappings;
+    switch (order) {
+    case SourceMapConsumer.GENERATED_ORDER:
+      mappings = this._generatedMappings;
+      break;
+    case SourceMapConsumer.ORIGINAL_ORDER:
+      mappings = this._originalMappings;
+      break;
+    default:
+      throw new Error("Unknown order of iteration.");
     }
 
-    if (opts.noext !== true) {
-      const isExtglobChar = code === CHAR_PLUS
-        || code === CHAR_AT
-        || code === CHAR_ASTERISK
-        || code === CHAR_QUESTION_MARK
-        || code === CHAR_EXCLAMATION_MARK;
+    var sourceRoot = this.sourceRoot;
+    mappings.map(function (mapping) {
+      var source = mapping.source === null ? null : this._sources.at(mapping.source);
+      source = util.computeSourceURL(sourceRoot, source, this._sourceMapURL);
+      return {
+        source: source,
+        generatedLine: mapping.generatedLine,
+        generatedColumn: mapping.generatedColumn,
+        originalLine: mapping.originalLine,
+        originalColumn: mapping.originalColumn,
+        name: mapping.name === null ? null : this._names.at(mapping.name)
+      };
+    }, this).forEach(aCallback, context);
+  };
 
-      if (isExtglobChar === true && peek() === CHAR_LEFT_PARENTHESES) {
-        isGlob = token.isGlob = true;
-        isExtglob = token.isExtglob = true;
-        finished = true;
-        if (code === CHAR_EXCLAMATION_MARK && index === start) {
-          negatedExtglob = true;
-        }
+/**
+ * Returns all generated line and column information for the original source,
+ * line, and column provided. If no column is provided, returns all mappings
+ * corresponding to a either the line we are searching for or the next
+ * closest line that has any mappings. Otherwise, returns all mappings
+ * corresponding to the given line and either the column we are searching for
+ * or the next closest column that has any offsets.
+ *
+ * The only argument is an object with the following properties:
+ *
+ *   - source: The filename of the original source.
+ *   - line: The line number in the original source.  The line number is 1-based.
+ *   - column: Optional. the column number in the original source.
+ *    The column number is 0-based.
+ *
+ * and an array of objects is returned, each with the following properties:
+ *
+ *   - line: The line number in the generated source, or null.  The
+ *    line number is 1-based.
+ *   - column: The column number in the generated source, or null.
+ *    The column number is 0-based.
+ */
+SourceMapConsumer.prototype.allGeneratedPositionsFor =
+  function SourceMapConsumer_allGeneratedPositionsFor(aArgs) {
+    var line = util.getArg(aArgs, 'line');
 
-        if (scanToEnd === true) {
-          while (eos() !== true && (code = advance())) {
-            if (code === CHAR_BACKWARD_SLASH) {
-              backslashes = token.backslashes = true;
-              code = advance();
-              continue;
-            }
+    // When there is no exact match, BasicSourceMapConsumer.prototype._findMapping
+    // returns the index of the closest mapping less than the needle. By
+    // setting needle.originalColumn to 0, we thus find the last mapping for
+    // the given line, provided such a mapping exists.
+    var needle = {
+      source: util.getArg(aArgs, 'source'),
+      originalLine: line,
+      originalColumn: util.getArg(aArgs, 'column', 0)
+    };
 
-            if (code === CHAR_RIGHT_PARENTHESES) {
-              isGlob = token.isGlob = true;
-              finished = true;
-              break;
-            }
-          }
-          continue;
-        }
-        break;
-      }
+    needle.source = this._findSourceIndex(needle.source);
+    if (needle.source < 0) {
+      return [];
     }
 
-    if (code === CHAR_ASTERISK) {
-      if (prev === CHAR_ASTERISK) isGlobstar = token.isGlobstar = true;
-      isGlob = token.isGlob = true;
-      finished = true;
+    var mappings = [];
 
-      if (scanToEnd === true) {
-        continue;
-      }
-      break;
-    }
+    var index = this._findMapping(needle,
+                                  this._originalMappings,
+                                  "originalLine",
+                                  "originalColumn",
+                                  util.compareByOriginalPositions,
+                                  binarySearch.LEAST_UPPER_BOUND);
+    if (index >= 0) {
+      var mapping = this._originalMappings[index];
 
-    if (code === CHAR_QUESTION_MARK) {
-      isGlob = token.isGlob = true;
-      finished = true;
+      if (aArgs.column === undefined) {
+        var originalLine = mapping.originalLine;
 
-      if (scanToEnd === true) {
-        continue;
-      }
-      break;
-    }
+        // Iterate until either we run out of mappings, or we run into
+        // a mapping for a different line than the one we found. Since
+        // mappings are sorted, this is guaranteed to find all mappings for
+        // the line we found.
+        while (mapping && mapping.originalLine === originalLine) {
+          mappings.push({
+            line: util.getArg(mapping, 'generatedLine', null),
+            column: util.getArg(mapping, 'generatedColumn', null),
+            lastColumn: util.getArg(mapping, 'lastGeneratedColumn', null)
+          });
 
-    if (code === CHAR_LEFT_SQUARE_BRACKET) {
-      while (eos() !== true && (next = advance())) {
-        if (next === CHAR_BACKWARD_SLASH) {
-          backslashes = token.backslashes = true;
-          advance();
-          continue;
+          mapping = this._originalMappings[++index];
         }
+      } else {
+        var originalColumn = mapping.originalColumn;
 
-        if (next === CHAR_RIGHT_SQUARE_BRACKET) {
-          isBracket = token.isBracket = true;
-          isGlob = token.isGlob = true;
-          finished = true;
-          break;
-        }
-      }
+        // Iterate until either we run out of mappings, or we run into
+        // a mapping for a different line than the one we were searching for.
+        // Since mappings are sorted, this is guaranteed to find all mappings for
+        // the line we are searching for.
+        while (mapping &&
+               mapping.originalLine === line &&
+               mapping.originalColumn == originalColumn) {
+          mappings.push({
+            line: util.getArg(mapping, 'generatedLine', null),
+            column: util.getArg(mapping, 'generatedColumn', null),
+            lastColumn: util.getArg(mapping, 'lastGeneratedColumn', null)
+          });
 
-      if (scanToEnd === true) {
-        continue;
+          mapping = this._originalMappings[++index];
+        }
       }
-
-      break;
     }
 
-    if (opts.nonegate !== true && code === CHAR_EXCLAMATION_MARK && index === start) {
-      negated = token.negated = true;
-      start++;
-      continue;
-    }
-
-    if (opts.noparen !== true && code === CHAR_LEFT_PARENTHESES) {
-      isGlob = token.isGlob = true;
-
-      if (scanToEnd === true) {
-        while (eos() !== true && (code = advance())) {
-          if (code === CHAR_LEFT_PARENTHESES) {
-            backslashes = token.backslashes = true;
-            code = advance();
-            continue;
-          }
+    return mappings;
+  };
 
-          if (code === CHAR_RIGHT_PARENTHESES) {
-            finished = true;
-            break;
-          }
-        }
-        continue;
-      }
-      break;
-    }
+exports.SourceMapConsumer = SourceMapConsumer;
 
-    if (isGlob === true) {
-      finished = true;
+/**
+ * A BasicSourceMapConsumer instance represents a parsed source map which we can
+ * query for information about the original file positions by giving it a file
+ * position in the generated source.
+ *
+ * The first parameter is the raw source map (either as a JSON string, or
+ * already parsed to an object). According to the spec, source maps have the
+ * following attributes:
+ *
+ *   - version: Which version of the source map spec this map is following.
+ *   - sources: An array of URLs to the original source files.
+ *   - names: An array of identifiers which can be referrenced by individual mappings.
+ *   - sourceRoot: Optional. The URL root from which all sources are relative.
+ *   - sourcesContent: Optional. An array of contents of the original source files.
+ *   - mappings: A string of base64 VLQs which contain the actual mappings.
+ *   - file: Optional. The generated file this source map is associated with.
+ *
+ * Here is an example source map, taken from the source map spec[0]:
+ *
+ *     {
+ *       version : 3,
+ *       file: "out.js",
+ *       sourceRoot : "",
+ *       sources: ["foo.js", "bar.js"],
+ *       names: ["src", "maps", "are", "fun"],
+ *       mappings: "AA,AB;;ABCDE;"
+ *     }
+ *
+ * The second parameter, if given, is a string whose value is the URL
+ * at which the source map was found.  This URL is used to compute the
+ * sources array.
+ *
+ * [0]: https://docs.google.com/document/d/1U1RGAehQwRypUTovF1KRlpiOFze0b-_2gc6fAH0KY0k/edit?pli=1#
+ */
+function BasicSourceMapConsumer(aSourceMap, aSourceMapURL) {
+  var sourceMap = aSourceMap;
+  if (typeof aSourceMap === 'string') {
+    sourceMap = util.parseSourceMapInput(aSourceMap);
+  }
 
-      if (scanToEnd === true) {
-        continue;
-      }
+  var version = util.getArg(sourceMap, 'version');
+  var sources = util.getArg(sourceMap, 'sources');
+  // Sass 3.3 leaves out the 'names' array, so we deviate from the spec (which
+  // requires the array) to play nice here.
+  var names = util.getArg(sourceMap, 'names', []);
+  var sourceRoot = util.getArg(sourceMap, 'sourceRoot', null);
+  var sourcesContent = util.getArg(sourceMap, 'sourcesContent', null);
+  var mappings = util.getArg(sourceMap, 'mappings');
+  var file = util.getArg(sourceMap, 'file', null);
 
-      break;
-    }
+  // Once again, Sass deviates from the spec and supplies the version as a
+  // string rather than a number, so we use loose equality checking here.
+  if (version != this._version) {
+    throw new Error('Unsupported version: ' + version);
   }
 
-  if (opts.noext === true) {
-    isExtglob = false;
-    isGlob = false;
+  if (sourceRoot) {
+    sourceRoot = util.normalize(sourceRoot);
   }
 
-  let base = str;
-  let prefix = '';
-  let glob = '';
+  sources = sources
+    .map(String)
+    // Some source maps produce relative source paths like "./foo.js" instead of
+    // "foo.js".  Normalize these first so that future comparisons will succeed.
+    // See bugzil.la/1090768.
+    .map(util.normalize)
+    // Always ensure that absolute sources are internally stored relative to
+    // the source root, if the source root is absolute. Not doing this would
+    // be particularly problematic when the source root is a prefix of the
+    // source (valid, but why??). See github issue #199 and bugzil.la/1188982.
+    .map(function (source) {
+      return sourceRoot && util.isAbsolute(sourceRoot) && util.isAbsolute(source)
+        ? util.relative(sourceRoot, source)
+        : source;
+    });
 
-  if (start > 0) {
-    prefix = str.slice(0, start);
-    str = str.slice(start);
-    lastIndex -= start;
-  }
+  // Pass `true` below to allow duplicate names and sources. While source maps
+  // are intended to be compressed and deduplicated, the TypeScript compiler
+  // sometimes generates source maps with duplicates in them. See Github issue
+  // #72 and bugzil.la/889492.
+  this._names = ArraySet.fromArray(names.map(String), true);
+  this._sources = ArraySet.fromArray(sources, true);
 
-  if (base && isGlob === true && lastIndex > 0) {
-    base = str.slice(0, lastIndex);
-    glob = str.slice(lastIndex);
-  } else if (isGlob === true) {
-    base = '';
-    glob = str;
-  } else {
-    base = str;
-  }
+  this._absoluteSources = this._sources.toArray().map(function (s) {
+    return util.computeSourceURL(sourceRoot, s, aSourceMapURL);
+  });
 
-  if (base && base !== '' && base !== '/' && base !== str) {
-    if (isPathSeparator(base.charCodeAt(base.length - 1))) {
-      base = base.slice(0, -1);
-    }
-  }
+  this.sourceRoot = sourceRoot;
+  this.sourcesContent = sourcesContent;
+  this._mappings = mappings;
+  this._sourceMapURL = aSourceMapURL;
+  this.file = file;
+}
 
-  if (opts.unescape === true) {
-    if (glob) glob = utils.removeBackslashes(glob);
+BasicSourceMapConsumer.prototype = Object.create(SourceMapConsumer.prototype);
+BasicSourceMapConsumer.prototype.consumer = SourceMapConsumer;
 
-    if (base && backslashes === true) {
-      base = utils.removeBackslashes(base);
-    }
+/**
+ * Utility function to find the index of a source.  Returns -1 if not
+ * found.
+ */
+BasicSourceMapConsumer.prototype._findSourceIndex = function(aSource) {
+  var relativeSource = aSource;
+  if (this.sourceRoot != null) {
+    relativeSource = util.relative(this.sourceRoot, relativeSource);
   }
 
-  const state = {
-    prefix,
-    input,
-    start,
-    base,
-    glob,
-    isBrace,
-    isBracket,
-    isGlob,
-    isExtglob,
-    isGlobstar,
-    negated,
-    negatedExtglob
-  };
-
-  if (opts.tokens === true) {
-    state.maxDepth = 0;
-    if (!isPathSeparator(code)) {
-      tokens.push(token);
-    }
-    state.tokens = tokens;
+  if (this._sources.has(relativeSource)) {
+    return this._sources.indexOf(relativeSource);
   }
 
-  if (opts.parts === true || opts.tokens === true) {
-    let prevIndex;
-
-    for (let idx = 0; idx < slashes.length; idx++) {
-      const n = prevIndex ? prevIndex + 1 : start;
-      const i = slashes[idx];
-      const value = input.slice(n, i);
-      if (opts.tokens) {
-        if (idx === 0 && start !== 0) {
-          tokens[idx].isPrefix = true;
-          tokens[idx].value = prefix;
-        } else {
-          tokens[idx].value = value;
-        }
-        depth(tokens[idx]);
-        state.maxDepth += tokens[idx].depth;
-      }
-      if (idx !== 0 || value !== '') {
-        parts.push(value);
-      }
-      prevIndex = i;
-    }
-
-    if (prevIndex && prevIndex + 1 < input.length) {
-      const value = input.slice(prevIndex + 1);
-      parts.push(value);
-
-      if (opts.tokens) {
-        tokens[tokens.length - 1].value = value;
-        depth(tokens[tokens.length - 1]);
-        state.maxDepth += tokens[tokens.length - 1].depth;
-      }
+  // Maybe aSource is an absolute URL as returned by |sources|.  In
+  // this case we can't simply undo the transform.
+  var i;
+  for (i = 0; i < this._absoluteSources.length; ++i) {
+    if (this._absoluteSources[i] == aSource) {
+      return i;
     }
-
-    state.slashes = slashes;
-    state.parts = parts;
-  }
-
-  return state;
-};
-
-module.exports = scan;
-
-
-/***/ }),
-
-/***/ 76088:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
-
-"use strict";
-
-
-const path = __nccwpck_require__(71017);
-const win32 = process.platform === 'win32';
-const {
-  REGEX_BACKSLASH,
-  REGEX_REMOVE_BACKSLASH,
-  REGEX_SPECIAL_CHARS,
-  REGEX_SPECIAL_CHARS_GLOBAL
-} = __nccwpck_require__(67582);
-
-exports.isObject = val => val !== null && typeof val === 'object' && !Array.isArray(val);
-exports.hasRegexChars = str => REGEX_SPECIAL_CHARS.test(str);
-exports.isRegexChar = str => str.length === 1 && exports.hasRegexChars(str);
-exports.escapeRegex = str => str.replace(REGEX_SPECIAL_CHARS_GLOBAL, '\\$1');
-exports.toPosixSlashes = str => str.replace(REGEX_BACKSLASH, '/');
-
-exports.removeBackslashes = str => {
-  return str.replace(REGEX_REMOVE_BACKSLASH, match => {
-    return match === '\\' ? '' : match;
-  });
-};
-
-exports.supportsLookbehinds = () => {
-  const segs = process.version.slice(1).split('.').map(Number);
-  if (segs.length === 3 && segs[0] >= 9 || (segs[0] === 8 && segs[1] >= 10)) {
-    return true;
   }
-  return false;
-};
 
-exports.isWindows = options => {
-  if (options && typeof options.windows === 'boolean') {
-    return options.windows;
-  }
-  return win32 === true || path.sep === '\\';
+  return -1;
 };
 
-exports.escapeLast = (input, char, lastIdx) => {
-  const idx = input.lastIndexOf(char, lastIdx);
-  if (idx === -1) return input;
-  if (input[idx - 1] === '\\') return exports.escapeLast(input, char, idx - 1);
-  return `${input.slice(0, idx)}\\${input.slice(idx)}`;
-};
+/**
+ * Create a BasicSourceMapConsumer from a SourceMapGenerator.
+ *
+ * @param SourceMapGenerator aSourceMap
+ *        The source map that will be consumed.
+ * @param String aSourceMapURL
+ *        The URL at which the source map can be found (optional)
+ * @returns BasicSourceMapConsumer
+ */
+BasicSourceMapConsumer.fromSourceMap =
+  function SourceMapConsumer_fromSourceMap(aSourceMap, aSourceMapURL) {
+    var smc = Object.create(BasicSourceMapConsumer.prototype);
 
-exports.removePrefix = (input, state = {}) => {
-  let output = input;
-  if (output.startsWith('./')) {
-    output = output.slice(2);
-    state.prefix = './';
-  }
-  return output;
-};
+    var names = smc._names = ArraySet.fromArray(aSourceMap._names.toArray(), true);
+    var sources = smc._sources = ArraySet.fromArray(aSourceMap._sources.toArray(), true);
+    smc.sourceRoot = aSourceMap._sourceRoot;
+    smc.sourcesContent = aSourceMap._generateSourcesContent(smc._sources.toArray(),
+                                                            smc.sourceRoot);
+    smc.file = aSourceMap._file;
+    smc._sourceMapURL = aSourceMapURL;
+    smc._absoluteSources = smc._sources.toArray().map(function (s) {
+      return util.computeSourceURL(smc.sourceRoot, s, aSourceMapURL);
+    });
 
-exports.wrapOutput = (input, state = {}, options = {}) => {
-  const prepend = options.contains ? '' : '^';
-  const append = options.contains ? '' : '$';
+    // Because we are modifying the entries (by converting string sources and
+    // names to indices into the sources and names ArraySets), we have to make
+    // a copy of the entry or else bad things happen. Shared mutable state
+    // strikes again! See github issue #191.
 
-  let output = `${prepend}(?:${input})${append}`;
-  if (state.negated === true) {
-    output = `(?:^(?!${output}).*$)`;
-  }
-  return output;
-};
+    var generatedMappings = aSourceMap._mappings.toArray().slice();
+    var destGeneratedMappings = smc.__generatedMappings = [];
+    var destOriginalMappings = smc.__originalMappings = [];
 
+    for (var i = 0, length = generatedMappings.length; i < length; i++) {
+      var srcMapping = generatedMappings[i];
+      var destMapping = new Mapping;
+      destMapping.generatedLine = srcMapping.generatedLine;
+      destMapping.generatedColumn = srcMapping.generatedColumn;
 
-/***/ }),
+      if (srcMapping.source) {
+        destMapping.source = sources.indexOf(srcMapping.source);
+        destMapping.originalLine = srcMapping.originalLine;
+        destMapping.originalColumn = srcMapping.originalColumn;
 
-/***/ 115:
-/***/ ((module, exports, __nccwpck_require__) => {
+        if (srcMapping.name) {
+          destMapping.name = names.indexOf(srcMapping.name);
+        }
 
-"use strict";
-/* module decorator */ module = __nccwpck_require__.nmd(module);
+        destOriginalMappings.push(destMapping);
+      }
 
+      destGeneratedMappings.push(destMapping);
+    }
 
-Object.defineProperty(exports, "__esModule", ({
-  value: true
-}));
-exports.addHook = addHook;
-var _module = _interopRequireDefault(__nccwpck_require__(98188));
-var _path = _interopRequireDefault(__nccwpck_require__(71017));
-function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
-/* (c) 2015 Ari Porad (@ariporad) . License: ariporad.mit-license.org */
+    quickSort(smc.__originalMappings, util.compareByOriginalPositions);
 
-const nodeModulesRegex = /^(?:.*[\\/])?node_modules(?:[\\/].*)?$/;
-// Guard against poorly mocked module constructors.
-const Module = module.constructor.length > 1 ? module.constructor : _module.default;
-const HOOK_RETURNED_NOTHING_ERROR_MESSAGE = '[Pirates] A hook returned a non-string, or nothing at all! This is a' + ' violation of intergalactic law!\n' + '--------------------\n' + 'If you have no idea what this means or what Pirates is, let me explain: ' + 'Pirates is a module that makes is easy to implement require hooks. One of' + " the require hooks you're using uses it. One of these require hooks" + " didn't return anything from it's handler, so we don't know what to" + ' do. You might want to debug this.';
+    return smc;
+  };
 
 /**
- * @param {string} filename The filename to check.
- * @param {string[]} exts The extensions to hook. Should start with '.' (ex. ['.js']).
- * @param {Matcher|null} matcher A matcher function, will be called with path to a file. Should return truthy if the file should be hooked, falsy otherwise.
- * @param {boolean} ignoreNodeModules Auto-ignore node_modules. Independent of any matcher.
+ * The version of the source mapping spec that we are consuming.
  */
-function shouldCompile(filename, exts, matcher, ignoreNodeModules) {
-  if (typeof filename !== 'string') {
-    return false;
-  }
-  if (exts.indexOf(_path.default.extname(filename)) === -1) {
-    return false;
-  }
-  const resolvedFilename = _path.default.resolve(filename);
-  if (ignoreNodeModules && nodeModulesRegex.test(resolvedFilename)) {
-    return false;
-  }
-  if (matcher && typeof matcher === 'function') {
-    return !!matcher(resolvedFilename);
-  }
-  return true;
-}
+BasicSourceMapConsumer.prototype._version = 3;
 
 /**
- * @callback Hook The hook. Accepts the code of the module and the filename.
- * @param {string} code
- * @param {string} filename
- * @returns {string}
- */
-/**
- * @callback Matcher A matcher function, will be called with path to a file.
- *
- * Should return truthy if the file should be hooked, falsy otherwise.
- * @param {string} path
- * @returns {boolean}
- */
-/**
- * @callback RevertFunction Reverts the hook when called.
- * @returns {void}
+ * The list of original sources.
  */
+Object.defineProperty(BasicSourceMapConsumer.prototype, 'sources', {
+  get: function () {
+    return this._absoluteSources.slice();
+  }
+});
+
 /**
- * @typedef {object} Options
- * @property {Matcher|null} [matcher=null] A matcher function, will be called with path to a file.
- *
- * Should return truthy if the file should be hooked, falsy otherwise.
- *
- * @property {string[]} [extensions=['.js']] The extensions to hook. Should start with '.' (ex. ['.js']).
- * @property {string[]} [exts=['.js']] The extensions to hook. Should start with '.' (ex. ['.js']).
- *
- * @property {string[]} [extension=['.js']] The extensions to hook. Should start with '.' (ex. ['.js']).
- * @property {string[]} [ext=['.js']] The extensions to hook. Should start with '.' (ex. ['.js']).
- *
- * @property {boolean} [ignoreNodeModules=true] Auto-ignore node_modules. Independent of any matcher.
+ * Provide the JIT with a nice shape / hidden class.
  */
+function Mapping() {
+  this.generatedLine = 0;
+  this.generatedColumn = 0;
+  this.source = null;
+  this.originalLine = null;
+  this.originalColumn = null;
+  this.name = null;
+}
 
 /**
- * Add a require hook.
- *
- * @param {Hook} hook The hook. Accepts the code of the module and the filename. Required.
- * @param {Options} [opts] Options
- * @returns {RevertFunction} The `revert` function. Reverts the hook when called.
+ * Parse the mappings in a string in to a data structure which we can easily
+ * query (the ordered arrays in the `this.__generatedMappings` and
+ * `this.__originalMappings` properties).
  */
-function addHook(hook, opts = {}) {
-  let reverted = false;
-  const loaders = [];
-  const oldLoaders = [];
-  let exts;
+BasicSourceMapConsumer.prototype._parseMappings =
+  function SourceMapConsumer_parseMappings(aStr, aSourceRoot) {
+    var generatedLine = 1;
+    var previousGeneratedColumn = 0;
+    var previousOriginalLine = 0;
+    var previousOriginalColumn = 0;
+    var previousSource = 0;
+    var previousName = 0;
+    var length = aStr.length;
+    var index = 0;
+    var cachedSegments = {};
+    var temp = {};
+    var originalMappings = [];
+    var generatedMappings = [];
+    var mapping, str, segment, end, value;
 
-  // We need to do this to fix #15. Basically, if you use a non-standard extension (ie. .jsx), then
-  // We modify the .js loader, then use the modified .js loader for as the base for .jsx.
-  // This prevents that.
-  const originalJSLoader = Module._extensions['.js'];
-  const matcher = opts.matcher || null;
-  const ignoreNodeModules = opts.ignoreNodeModules !== false;
-  exts = opts.extensions || opts.exts || opts.extension || opts.ext || ['.js'];
-  if (!Array.isArray(exts)) {
-    exts = [exts];
-  }
-  exts.forEach(ext => {
-    if (typeof ext !== 'string') {
-      throw new TypeError(`Invalid Extension: ${ext}`);
-    }
-    const oldLoader = Module._extensions[ext] || originalJSLoader;
-    oldLoaders[ext] = Module._extensions[ext];
-    loaders[ext] = Module._extensions[ext] = function newLoader(mod, filename) {
-      let compile;
-      if (!reverted) {
-        if (shouldCompile(filename, exts, matcher, ignoreNodeModules)) {
-          compile = mod._compile;
-          mod._compile = function _compile(code) {
-            // reset the compile immediately as otherwise we end up having the
-            // compile function being changed even though this loader might be reverted
-            // Not reverting it here leads to long useless compile chains when doing
-            // addHook -> revert -> addHook -> revert -> ...
-            // The compile function is also anyway created new when the loader is called a second time.
-            mod._compile = compile;
-            const newCode = hook(code, filename);
-            if (typeof newCode !== 'string') {
-              throw new Error(HOOK_RETURNED_NOTHING_ERROR_MESSAGE);
-            }
-            return mod._compile(newCode, filename);
-          };
-        }
+    while (index < length) {
+      if (aStr.charAt(index) === ';') {
+        generatedLine++;
+        index++;
+        previousGeneratedColumn = 0;
       }
-      oldLoader(mod, filename);
-    };
-  });
-  return function revert() {
-    if (reverted) return;
-    reverted = true;
-    exts.forEach(ext => {
-      // if the current loader for the extension is our loader then unregister it and set the oldLoader again
-      // if not we can not do anything as we cannot remove a loader from within the loader-chain
-      if (Module._extensions[ext] === loaders[ext]) {
-        if (!oldLoaders[ext]) {
-          delete Module._extensions[ext];
-        } else {
-          Module._extensions[ext] = oldLoaders[ext];
-        }
+      else if (aStr.charAt(index) === ',') {
+        index++;
       }
-    });
-  };
-}
-
-/***/ }),
+      else {
+        mapping = new Mapping();
+        mapping.generatedLine = generatedLine;
 
-/***/ 98431:
-/***/ ((module) => {
+        // Because each offset is encoded relative to the previous one,
+        // many segments often have the same encoding. We can exploit this
+        // fact by caching the parsed variable length fields of each segment,
+        // allowing us to avoid a second parse if we encounter the same
+        // segment again.
+        for (end = index; end < length; end++) {
+          if (this._charIsMappingSeparator(aStr, end)) {
+            break;
+          }
+        }
+        str = aStr.slice(index, end);
 
-/*! queue-microtask. MIT License. Feross Aboukhadijeh  */
-let promise
+        segment = cachedSegments[str];
+        if (segment) {
+          index += str.length;
+        } else {
+          segment = [];
+          while (index < end) {
+            base64VLQ.decode(aStr, index, temp);
+            value = temp.value;
+            index = temp.rest;
+            segment.push(value);
+          }
 
-module.exports = typeof queueMicrotask === 'function'
-  ? queueMicrotask.bind(typeof window !== 'undefined' ? window : global)
-  // reuse resolved promise, and allocate it lazily
-  : cb => (promise || (promise = Promise.resolve()))
-    .then(cb)
-    .catch(err => setTimeout(() => { throw err }, 0))
+          if (segment.length === 2) {
+            throw new Error('Found a source, but no line and column');
+          }
 
+          if (segment.length === 3) {
+            throw new Error('Found a source and line, but no column');
+          }
 
-/***/ }),
+          cachedSegments[str] = segment;
+        }
 
-/***/ 91042:
-/***/ ((module) => {
+        // Generated column.
+        mapping.generatedColumn = previousGeneratedColumn + segment[0];
+        previousGeneratedColumn = mapping.generatedColumn;
 
-"use strict";
+        if (segment.length > 1) {
+          // Original source.
+          mapping.source = previousSource + segment[1];
+          previousSource += segment[1];
 
+          // Original line.
+          mapping.originalLine = previousOriginalLine + segment[2];
+          previousOriginalLine = mapping.originalLine;
+          // Lines are stored 0-based
+          mapping.originalLine += 1;
 
-const codes = {};
+          // Original column.
+          mapping.originalColumn = previousOriginalColumn + segment[3];
+          previousOriginalColumn = mapping.originalColumn;
 
-function createErrorType(code, message, Base) {
-  if (!Base) {
-    Base = Error
-  }
+          if (segment.length > 4) {
+            // Original name.
+            mapping.name = previousName + segment[4];
+            previousName += segment[4];
+          }
+        }
 
-  function getMessage (arg1, arg2, arg3) {
-    if (typeof message === 'string') {
-      return message
-    } else {
-      return message(arg1, arg2, arg3)
+        generatedMappings.push(mapping);
+        if (typeof mapping.originalLine === 'number') {
+          originalMappings.push(mapping);
+        }
+      }
     }
-  }
 
-  class NodeError extends Base {
-    constructor (arg1, arg2, arg3) {
-      super(getMessage(arg1, arg2, arg3));
-    }
-  }
+    quickSort(generatedMappings, util.compareByGeneratedPositionsDeflated);
+    this.__generatedMappings = generatedMappings;
 
-  NodeError.prototype.name = Base.name;
-  NodeError.prototype.code = code;
+    quickSort(originalMappings, util.compareByOriginalPositions);
+    this.__originalMappings = originalMappings;
+  };
 
-  codes[code] = NodeError;
-}
+/**
+ * Find the mapping that best matches the hypothetical "needle" mapping that
+ * we are searching for in the given "haystack" of mappings.
+ */
+BasicSourceMapConsumer.prototype._findMapping =
+  function SourceMapConsumer_findMapping(aNeedle, aMappings, aLineName,
+                                         aColumnName, aComparator, aBias) {
+    // To return the position we are searching for, we must first find the
+    // mapping for the given position and then return the opposite position it
+    // points to. Because the mappings are sorted, we can use binary search to
+    // find the best mapping.
 
-// https://github.com/nodejs/node/blob/v10.8.0/lib/internal/errors.js
-function oneOf(expected, thing) {
-  if (Array.isArray(expected)) {
-    const len = expected.length;
-    expected = expected.map((i) => String(i));
-    if (len > 2) {
-      return `one of ${thing} ${expected.slice(0, len - 1).join(', ')}, or ` +
-             expected[len - 1];
-    } else if (len === 2) {
-      return `one of ${thing} ${expected[0]} or ${expected[1]}`;
-    } else {
-      return `of ${thing} ${expected[0]}`;
+    if (aNeedle[aLineName] <= 0) {
+      throw new TypeError('Line must be greater than or equal to 1, got '
+                          + aNeedle[aLineName]);
+    }
+    if (aNeedle[aColumnName] < 0) {
+      throw new TypeError('Column must be greater than or equal to 0, got '
+                          + aNeedle[aColumnName]);
     }
-  } else {
-    return `of ${thing} ${String(expected)}`;
-  }
-}
-
-// https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/startsWith
-function startsWith(str, search, pos) {
-	return str.substr(!pos || pos < 0 ? 0 : +pos, search.length) === search;
-}
 
-// https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/endsWith
-function endsWith(str, search, this_len) {
-	if (this_len === undefined || this_len > str.length) {
-		this_len = str.length;
-	}
-	return str.substring(this_len - search.length, this_len) === search;
-}
+    return binarySearch.search(aNeedle, aMappings, aComparator, aBias);
+  };
 
-// https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/includes
-function includes(str, search, start) {
-  if (typeof start !== 'number') {
-    start = 0;
-  }
+/**
+ * Compute the last column for each generated mapping. The last column is
+ * inclusive.
+ */
+BasicSourceMapConsumer.prototype.computeColumnSpans =
+  function SourceMapConsumer_computeColumnSpans() {
+    for (var index = 0; index < this._generatedMappings.length; ++index) {
+      var mapping = this._generatedMappings[index];
 
-  if (start + search.length > str.length) {
-    return false;
-  } else {
-    return str.indexOf(search, start) !== -1;
-  }
-}
+      // Mappings do not contain a field for the last generated columnt. We
+      // can come up with an optimistic estimate, however, by assuming that
+      // mappings are contiguous (i.e. given two consecutive mappings, the
+      // first mapping ends where the second one starts).
+      if (index + 1 < this._generatedMappings.length) {
+        var nextMapping = this._generatedMappings[index + 1];
 
-createErrorType('ERR_INVALID_OPT_VALUE', function (name, value) {
-  return 'The value "' + value + '" is invalid for option "' + name + '"'
-}, TypeError);
-createErrorType('ERR_INVALID_ARG_TYPE', function (name, expected, actual) {
-  // determiner: 'must be' or 'must not be'
-  let determiner;
-  if (typeof expected === 'string' && startsWith(expected, 'not ')) {
-    determiner = 'must not be';
-    expected = expected.replace(/^not /, '');
-  } else {
-    determiner = 'must be';
-  }
+        if (mapping.generatedLine === nextMapping.generatedLine) {
+          mapping.lastGeneratedColumn = nextMapping.generatedColumn - 1;
+          continue;
+        }
+      }
 
-  let msg;
-  if (endsWith(name, ' argument')) {
-    // For cases like 'first argument'
-    msg = `The ${name} ${determiner} ${oneOf(expected, 'type')}`;
-  } else {
-    const type = includes(name, '.') ? 'property' : 'argument';
-    msg = `The "${name}" ${type} ${determiner} ${oneOf(expected, 'type')}`;
-  }
+      // The last mapping for each line spans the entire line.
+      mapping.lastGeneratedColumn = Infinity;
+    }
+  };
 
-  msg += `. Received type ${typeof actual}`;
-  return msg;
-}, TypeError);
-createErrorType('ERR_STREAM_PUSH_AFTER_EOF', 'stream.push() after EOF');
-createErrorType('ERR_METHOD_NOT_IMPLEMENTED', function (name) {
-  return 'The ' + name + ' method is not implemented'
-});
-createErrorType('ERR_STREAM_PREMATURE_CLOSE', 'Premature close');
-createErrorType('ERR_STREAM_DESTROYED', function (name) {
-  return 'Cannot call ' + name + ' after a stream was destroyed';
-});
-createErrorType('ERR_MULTIPLE_CALLBACK', 'Callback called multiple times');
-createErrorType('ERR_STREAM_CANNOT_PIPE', 'Cannot pipe, not readable');
-createErrorType('ERR_STREAM_WRITE_AFTER_END', 'write after end');
-createErrorType('ERR_STREAM_NULL_VALUES', 'May not write null values to stream', TypeError);
-createErrorType('ERR_UNKNOWN_ENCODING', function (arg) {
-  return 'Unknown encoding: ' + arg
-}, TypeError);
-createErrorType('ERR_STREAM_UNSHIFT_AFTER_END_EVENT', 'stream.unshift() after end event');
+/**
+ * Returns the original source, line, and column information for the generated
+ * source's line and column positions provided. The only argument is an object
+ * with the following properties:
+ *
+ *   - line: The line number in the generated source.  The line number
+ *     is 1-based.
+ *   - column: The column number in the generated source.  The column
+ *     number is 0-based.
+ *   - bias: Either 'SourceMapConsumer.GREATEST_LOWER_BOUND' or
+ *     'SourceMapConsumer.LEAST_UPPER_BOUND'. Specifies whether to return the
+ *     closest element that is smaller than or greater than the one we are
+ *     searching for, respectively, if the exact element cannot be found.
+ *     Defaults to 'SourceMapConsumer.GREATEST_LOWER_BOUND'.
+ *
+ * and an object is returned with the following properties:
+ *
+ *   - source: The original source file, or null.
+ *   - line: The line number in the original source, or null.  The
+ *     line number is 1-based.
+ *   - column: The column number in the original source, or null.  The
+ *     column number is 0-based.
+ *   - name: The original identifier, or null.
+ */
+BasicSourceMapConsumer.prototype.originalPositionFor =
+  function SourceMapConsumer_originalPositionFor(aArgs) {
+    var needle = {
+      generatedLine: util.getArg(aArgs, 'line'),
+      generatedColumn: util.getArg(aArgs, 'column')
+    };
 
-module.exports.q = codes;
+    var index = this._findMapping(
+      needle,
+      this._generatedMappings,
+      "generatedLine",
+      "generatedColumn",
+      util.compareByGeneratedPositionsDeflated,
+      util.getArg(aArgs, 'bias', SourceMapConsumer.GREATEST_LOWER_BOUND)
+    );
 
+    if (index >= 0) {
+      var mapping = this._generatedMappings[index];
 
-/***/ }),
+      if (mapping.generatedLine === needle.generatedLine) {
+        var source = util.getArg(mapping, 'source', null);
+        if (source !== null) {
+          source = this._sources.at(source);
+          source = util.computeSourceURL(this.sourceRoot, source, this._sourceMapURL);
+        }
+        var name = util.getArg(mapping, 'name', null);
+        if (name !== null) {
+          name = this._names.at(name);
+        }
+        return {
+          source: source,
+          line: util.getArg(mapping, 'originalLine', null),
+          column: util.getArg(mapping, 'originalColumn', null),
+          name: name
+        };
+      }
+    }
 
-/***/ 25408:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+    return {
+      source: null,
+      line: null,
+      column: null,
+      name: null
+    };
+  };
 
-"use strict";
-// Copyright Joyent, Inc. and other Node contributors.
-//
-// 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.
-// a duplex stream is just a stream that is both readable and writable.
-// Since JS doesn't have multiple prototypal inheritance, this class
-// prototypally inherits from Readable, and then parasitically from
-// Writable.
+/**
+ * Return true if we have the source content for every source in the source
+ * map, false otherwise.
+ */
+BasicSourceMapConsumer.prototype.hasContentsOfAllSources =
+  function BasicSourceMapConsumer_hasContentsOfAllSources() {
+    if (!this.sourcesContent) {
+      return false;
+    }
+    return this.sourcesContent.length >= this._sources.size() &&
+      !this.sourcesContent.some(function (sc) { return sc == null; });
+  };
 
-/**/
+/**
+ * Returns the original source content. The only argument is the url of the
+ * original source file. Returns null if no original source content is
+ * available.
+ */
+BasicSourceMapConsumer.prototype.sourceContentFor =
+  function SourceMapConsumer_sourceContentFor(aSource, nullOnMissing) {
+    if (!this.sourcesContent) {
+      return null;
+    }
 
-var objectKeys = Object.keys || function (obj) {
-  var keys = [];
+    var index = this._findSourceIndex(aSource);
+    if (index >= 0) {
+      return this.sourcesContent[index];
+    }
 
-  for (var key in obj) {
-    keys.push(key);
-  }
+    var relativeSource = aSource;
+    if (this.sourceRoot != null) {
+      relativeSource = util.relative(this.sourceRoot, relativeSource);
+    }
 
-  return keys;
-};
-/**/
+    var url;
+    if (this.sourceRoot != null
+        && (url = util.urlParse(this.sourceRoot))) {
+      // XXX: file:// URIs and absolute paths lead to unexpected behavior for
+      // many users. We can help them out when they expect file:// URIs to
+      // behave like it would if they were running a local HTTP server. See
+      // https://bugzilla.mozilla.org/show_bug.cgi?id=885597.
+      var fileUriAbsPath = relativeSource.replace(/^file:\/\//, "");
+      if (url.scheme == "file"
+          && this._sources.has(fileUriAbsPath)) {
+        return this.sourcesContent[this._sources.indexOf(fileUriAbsPath)]
+      }
 
+      if ((!url.path || url.path == "/")
+          && this._sources.has("/" + relativeSource)) {
+        return this.sourcesContent[this._sources.indexOf("/" + relativeSource)];
+      }
+    }
 
-module.exports = Duplex;
+    // This function is used recursively from
+    // IndexedSourceMapConsumer.prototype.sourceContentFor. In that case, we
+    // don't want to throw if we can't find the source - we just want to
+    // return null, so we provide a flag to exit gracefully.
+    if (nullOnMissing) {
+      return null;
+    }
+    else {
+      throw new Error('"' + relativeSource + '" is not in the SourceMap.');
+    }
+  };
 
-var Readable = __nccwpck_require__(17911);
+/**
+ * Returns the generated line and column information for the original source,
+ * line, and column positions provided. The only argument is an object with
+ * the following properties:
+ *
+ *   - source: The filename of the original source.
+ *   - line: The line number in the original source.  The line number
+ *     is 1-based.
+ *   - column: The column number in the original source.  The column
+ *     number is 0-based.
+ *   - bias: Either 'SourceMapConsumer.GREATEST_LOWER_BOUND' or
+ *     'SourceMapConsumer.LEAST_UPPER_BOUND'. Specifies whether to return the
+ *     closest element that is smaller than or greater than the one we are
+ *     searching for, respectively, if the exact element cannot be found.
+ *     Defaults to 'SourceMapConsumer.GREATEST_LOWER_BOUND'.
+ *
+ * and an object is returned with the following properties:
+ *
+ *   - line: The line number in the generated source, or null.  The
+ *     line number is 1-based.
+ *   - column: The column number in the generated source, or null.
+ *     The column number is 0-based.
+ */
+BasicSourceMapConsumer.prototype.generatedPositionFor =
+  function SourceMapConsumer_generatedPositionFor(aArgs) {
+    var source = util.getArg(aArgs, 'source');
+    source = this._findSourceIndex(source);
+    if (source < 0) {
+      return {
+        line: null,
+        column: null,
+        lastColumn: null
+      };
+    }
 
-var Writable = __nccwpck_require__(51898);
+    var needle = {
+      source: source,
+      originalLine: util.getArg(aArgs, 'line'),
+      originalColumn: util.getArg(aArgs, 'column')
+    };
 
-__nccwpck_require__(2868)(Duplex, Readable);
+    var index = this._findMapping(
+      needle,
+      this._originalMappings,
+      "originalLine",
+      "originalColumn",
+      util.compareByOriginalPositions,
+      util.getArg(aArgs, 'bias', SourceMapConsumer.GREATEST_LOWER_BOUND)
+    );
 
-{
-  // Allow the keys array to be GC'ed.
-  var keys = objectKeys(Writable.prototype);
+    if (index >= 0) {
+      var mapping = this._originalMappings[index];
 
-  for (var v = 0; v < keys.length; v++) {
-    var method = keys[v];
-    if (!Duplex.prototype[method]) Duplex.prototype[method] = Writable.prototype[method];
-  }
-}
+      if (mapping.source === needle.source) {
+        return {
+          line: util.getArg(mapping, 'generatedLine', null),
+          column: util.getArg(mapping, 'generatedColumn', null),
+          lastColumn: util.getArg(mapping, 'lastGeneratedColumn', null)
+        };
+      }
+    }
 
-function Duplex(options) {
-  if (!(this instanceof Duplex)) return new Duplex(options);
-  Readable.call(this, options);
-  Writable.call(this, options);
-  this.allowHalfOpen = true;
+    return {
+      line: null,
+      column: null,
+      lastColumn: null
+    };
+  };
 
-  if (options) {
-    if (options.readable === false) this.readable = false;
-    if (options.writable === false) this.writable = false;
+__webpack_unused_export__ = BasicSourceMapConsumer;
 
-    if (options.allowHalfOpen === false) {
-      this.allowHalfOpen = false;
-      this.once('end', onend);
-    }
+/**
+ * An IndexedSourceMapConsumer instance represents a parsed source map which
+ * we can query for information. It differs from BasicSourceMapConsumer in
+ * that it takes "indexed" source maps (i.e. ones with a "sections" field) as
+ * input.
+ *
+ * The first parameter is a raw source map (either as a JSON string, or already
+ * parsed to an object). According to the spec for indexed source maps, they
+ * have the following attributes:
+ *
+ *   - version: Which version of the source map spec this map is following.
+ *   - file: Optional. The generated file this source map is associated with.
+ *   - sections: A list of section definitions.
+ *
+ * Each value under the "sections" field has two fields:
+ *   - offset: The offset into the original specified at which this section
+ *       begins to apply, defined as an object with a "line" and "column"
+ *       field.
+ *   - map: A source map definition. This source map could also be indexed,
+ *       but doesn't have to be.
+ *
+ * Instead of the "map" field, it's also possible to have a "url" field
+ * specifying a URL to retrieve a source map from, but that's currently
+ * unsupported.
+ *
+ * Here's an example source map, taken from the source map spec[0], but
+ * modified to omit a section which uses the "url" field.
+ *
+ *  {
+ *    version : 3,
+ *    file: "app.js",
+ *    sections: [{
+ *      offset: {line:100, column:10},
+ *      map: {
+ *        version : 3,
+ *        file: "section.js",
+ *        sources: ["foo.js", "bar.js"],
+ *        names: ["src", "maps", "are", "fun"],
+ *        mappings: "AAAA,E;;ABCDE;"
+ *      }
+ *    }],
+ *  }
+ *
+ * The second parameter, if given, is a string whose value is the URL
+ * at which the source map was found.  This URL is used to compute the
+ * sources array.
+ *
+ * [0]: https://docs.google.com/document/d/1U1RGAehQwRypUTovF1KRlpiOFze0b-_2gc6fAH0KY0k/edit#heading=h.535es3xeprgt
+ */
+function IndexedSourceMapConsumer(aSourceMap, aSourceMapURL) {
+  var sourceMap = aSourceMap;
+  if (typeof aSourceMap === 'string') {
+    sourceMap = util.parseSourceMapInput(aSourceMap);
   }
-}
 
-Object.defineProperty(Duplex.prototype, 'writableHighWaterMark', {
-  // making it explicit this property is not enumerable
-  // because otherwise some prototype manipulation in
-  // userland will fail
-  enumerable: false,
-  get: function get() {
-    return this._writableState.highWaterMark;
-  }
-});
-Object.defineProperty(Duplex.prototype, 'writableBuffer', {
-  // making it explicit this property is not enumerable
-  // because otherwise some prototype manipulation in
-  // userland will fail
-  enumerable: false,
-  get: function get() {
-    return this._writableState && this._writableState.getBuffer();
-  }
-});
-Object.defineProperty(Duplex.prototype, 'writableLength', {
-  // making it explicit this property is not enumerable
-  // because otherwise some prototype manipulation in
-  // userland will fail
-  enumerable: false,
-  get: function get() {
-    return this._writableState.length;
+  var version = util.getArg(sourceMap, 'version');
+  var sections = util.getArg(sourceMap, 'sections');
+
+  if (version != this._version) {
+    throw new Error('Unsupported version: ' + version);
   }
-}); // the no-half-open enforcer
 
-function onend() {
-  // If the writable side ended, then we're ok.
-  if (this._writableState.ended) return; // no more data can be written.
-  // But allow more writes to happen in this tick.
+  this._sources = new ArraySet();
+  this._names = new ArraySet();
 
-  process.nextTick(onEndNT, this);
-}
+  var lastOffset = {
+    line: -1,
+    column: 0
+  };
+  this._sections = sections.map(function (s) {
+    if (s.url) {
+      // The url field will require support for asynchronicity.
+      // See https://github.com/mozilla/source-map/issues/16
+      throw new Error('Support for url field in sections not implemented.');
+    }
+    var offset = util.getArg(s, 'offset');
+    var offsetLine = util.getArg(offset, 'line');
+    var offsetColumn = util.getArg(offset, 'column');
 
-function onEndNT(self) {
-  self.end();
-}
+    if (offsetLine < lastOffset.line ||
+        (offsetLine === lastOffset.line && offsetColumn < lastOffset.column)) {
+      throw new Error('Section offsets must be ordered and non-overlapping.');
+    }
+    lastOffset = offset;
 
-Object.defineProperty(Duplex.prototype, 'destroyed', {
-  // making it explicit this property is not enumerable
-  // because otherwise some prototype manipulation in
-  // userland will fail
-  enumerable: false,
-  get: function get() {
-    if (this._readableState === undefined || this._writableState === undefined) {
-      return false;
+    return {
+      generatedOffset: {
+        // The offset fields are 0-based, but we use 1-based indices when
+        // encoding/decoding from VLQ.
+        generatedLine: offsetLine + 1,
+        generatedColumn: offsetColumn + 1
+      },
+      consumer: new SourceMapConsumer(util.getArg(s, 'map'), aSourceMapURL)
     }
+  });
+}
 
-    return this._readableState.destroyed && this._writableState.destroyed;
-  },
-  set: function set(value) {
-    // we ignore the value if the stream
-    // has not been initialized yet
-    if (this._readableState === undefined || this._writableState === undefined) {
-      return;
-    } // backward compatibility, the user is explicitly
-    // managing destroyed
+IndexedSourceMapConsumer.prototype = Object.create(SourceMapConsumer.prototype);
+IndexedSourceMapConsumer.prototype.constructor = SourceMapConsumer;
 
+/**
+ * The version of the source mapping spec that we are consuming.
+ */
+IndexedSourceMapConsumer.prototype._version = 3;
 
-    this._readableState.destroyed = value;
-    this._writableState.destroyed = value;
+/**
+ * The list of original sources.
+ */
+Object.defineProperty(IndexedSourceMapConsumer.prototype, 'sources', {
+  get: function () {
+    var sources = [];
+    for (var i = 0; i < this._sections.length; i++) {
+      for (var j = 0; j < this._sections[i].consumer.sources.length; j++) {
+        sources.push(this._sections[i].consumer.sources[j]);
+      }
+    }
+    return sources;
   }
 });
 
-/***/ }),
-
-/***/ 37838:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
-
-"use strict";
-// Copyright Joyent, Inc. and other Node contributors.
-//
-// 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.
-// a passthrough stream.
-// basically just the most minimal sort of Transform stream.
-// Every written chunk gets output as-is.
+/**
+ * Returns the original source, line, and column information for the generated
+ * source's line and column positions provided. The only argument is an object
+ * with the following properties:
+ *
+ *   - line: The line number in the generated source.  The line number
+ *     is 1-based.
+ *   - column: The column number in the generated source.  The column
+ *     number is 0-based.
+ *
+ * and an object is returned with the following properties:
+ *
+ *   - source: The original source file, or null.
+ *   - line: The line number in the original source, or null.  The
+ *     line number is 1-based.
+ *   - column: The column number in the original source, or null.  The
+ *     column number is 0-based.
+ *   - name: The original identifier, or null.
+ */
+IndexedSourceMapConsumer.prototype.originalPositionFor =
+  function IndexedSourceMapConsumer_originalPositionFor(aArgs) {
+    var needle = {
+      generatedLine: util.getArg(aArgs, 'line'),
+      generatedColumn: util.getArg(aArgs, 'column')
+    };
 
+    // Find the section containing the generated position we're trying to map
+    // to an original position.
+    var sectionIndex = binarySearch.search(needle, this._sections,
+      function(needle, section) {
+        var cmp = needle.generatedLine - section.generatedOffset.generatedLine;
+        if (cmp) {
+          return cmp;
+        }
 
-module.exports = PassThrough;
+        return (needle.generatedColumn -
+                section.generatedOffset.generatedColumn);
+      });
+    var section = this._sections[sectionIndex];
 
-var Transform = __nccwpck_require__(660);
+    if (!section) {
+      return {
+        source: null,
+        line: null,
+        column: null,
+        name: null
+      };
+    }
 
-__nccwpck_require__(2868)(PassThrough, Transform);
+    return section.consumer.originalPositionFor({
+      line: needle.generatedLine -
+        (section.generatedOffset.generatedLine - 1),
+      column: needle.generatedColumn -
+        (section.generatedOffset.generatedLine === needle.generatedLine
+         ? section.generatedOffset.generatedColumn - 1
+         : 0),
+      bias: aArgs.bias
+    });
+  };
 
-function PassThrough(options) {
-  if (!(this instanceof PassThrough)) return new PassThrough(options);
-  Transform.call(this, options);
-}
+/**
+ * Return true if we have the source content for every source in the source
+ * map, false otherwise.
+ */
+IndexedSourceMapConsumer.prototype.hasContentsOfAllSources =
+  function IndexedSourceMapConsumer_hasContentsOfAllSources() {
+    return this._sections.every(function (s) {
+      return s.consumer.hasContentsOfAllSources();
+    });
+  };
 
-PassThrough.prototype._transform = function (chunk, encoding, cb) {
-  cb(null, chunk);
-};
+/**
+ * Returns the original source content. The only argument is the url of the
+ * original source file. Returns null if no original source content is
+ * available.
+ */
+IndexedSourceMapConsumer.prototype.sourceContentFor =
+  function IndexedSourceMapConsumer_sourceContentFor(aSource, nullOnMissing) {
+    for (var i = 0; i < this._sections.length; i++) {
+      var section = this._sections[i];
 
-/***/ }),
+      var content = section.consumer.sourceContentFor(aSource, true);
+      if (content) {
+        return content;
+      }
+    }
+    if (nullOnMissing) {
+      return null;
+    }
+    else {
+      throw new Error('"' + aSource + '" is not in the SourceMap.');
+    }
+  };
 
-/***/ 17911:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+/**
+ * Returns the generated line and column information for the original source,
+ * line, and column positions provided. The only argument is an object with
+ * the following properties:
+ *
+ *   - source: The filename of the original source.
+ *   - line: The line number in the original source.  The line number
+ *     is 1-based.
+ *   - column: The column number in the original source.  The column
+ *     number is 0-based.
+ *
+ * and an object is returned with the following properties:
+ *
+ *   - line: The line number in the generated source, or null.  The
+ *     line number is 1-based. 
+ *   - column: The column number in the generated source, or null.
+ *     The column number is 0-based.
+ */
+IndexedSourceMapConsumer.prototype.generatedPositionFor =
+  function IndexedSourceMapConsumer_generatedPositionFor(aArgs) {
+    for (var i = 0; i < this._sections.length; i++) {
+      var section = this._sections[i];
 
-"use strict";
-// Copyright Joyent, Inc. and other Node contributors.
-//
-// 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.
+      // Only consider this section if the requested source is in the list of
+      // sources of the consumer.
+      if (section.consumer._findSourceIndex(util.getArg(aArgs, 'source')) === -1) {
+        continue;
+      }
+      var generatedPosition = section.consumer.generatedPositionFor(aArgs);
+      if (generatedPosition) {
+        var ret = {
+          line: generatedPosition.line +
+            (section.generatedOffset.generatedLine - 1),
+          column: generatedPosition.column +
+            (section.generatedOffset.generatedLine === generatedPosition.line
+             ? section.generatedOffset.generatedColumn - 1
+             : 0)
+        };
+        return ret;
+      }
+    }
 
+    return {
+      line: null,
+      column: null
+    };
+  };
 
-module.exports = Readable;
-/**/
+/**
+ * Parse the mappings in a string in to a data structure which we can easily
+ * query (the ordered arrays in the `this.__generatedMappings` and
+ * `this.__originalMappings` properties).
+ */
+IndexedSourceMapConsumer.prototype._parseMappings =
+  function IndexedSourceMapConsumer_parseMappings(aStr, aSourceRoot) {
+    this.__generatedMappings = [];
+    this.__originalMappings = [];
+    for (var i = 0; i < this._sections.length; i++) {
+      var section = this._sections[i];
+      var sectionMappings = section.consumer._generatedMappings;
+      for (var j = 0; j < sectionMappings.length; j++) {
+        var mapping = sectionMappings[j];
 
-var Duplex;
-/**/
+        var source = section.consumer._sources.at(mapping.source);
+        source = util.computeSourceURL(section.consumer.sourceRoot, source, this._sourceMapURL);
+        this._sources.add(source);
+        source = this._sources.indexOf(source);
 
-Readable.ReadableState = ReadableState;
-/**/
+        var name = null;
+        if (mapping.name) {
+          name = section.consumer._names.at(mapping.name);
+          this._names.add(name);
+          name = this._names.indexOf(name);
+        }
 
-var EE = (__nccwpck_require__(82361).EventEmitter);
+        // The mappings coming from the consumer for the section have
+        // generated positions relative to the start of the section, so we
+        // need to offset them to be relative to the start of the concatenated
+        // generated file.
+        var adjustedMapping = {
+          source: source,
+          generatedLine: mapping.generatedLine +
+            (section.generatedOffset.generatedLine - 1),
+          generatedColumn: mapping.generatedColumn +
+            (section.generatedOffset.generatedLine === mapping.generatedLine
+            ? section.generatedOffset.generatedColumn - 1
+            : 0),
+          originalLine: mapping.originalLine,
+          originalColumn: mapping.originalColumn,
+          name: name
+        };
 
-var EElistenerCount = function EElistenerCount(emitter, type) {
-  return emitter.listeners(type).length;
-};
-/**/
+        this.__generatedMappings.push(adjustedMapping);
+        if (typeof adjustedMapping.originalLine === 'number') {
+          this.__originalMappings.push(adjustedMapping);
+        }
+      }
+    }
 
-/**/
+    quickSort(this.__generatedMappings, util.compareByGeneratedPositionsDeflated);
+    quickSort(this.__originalMappings, util.compareByOriginalPositions);
+  };
 
+__webpack_unused_export__ = IndexedSourceMapConsumer;
 
-var Stream = __nccwpck_require__(4297);
-/**/
 
+/***/ }),
 
-var Buffer = (__nccwpck_require__(14300).Buffer);
+/***/ 22370:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
-var OurUint8Array = global.Uint8Array || function () {};
+/* -*- Mode: js; js-indent-level: 2; -*- */
+/*
+ * Copyright 2011 Mozilla Foundation and contributors
+ * Licensed under the New BSD license. See LICENSE or:
+ * http://opensource.org/licenses/BSD-3-Clause
+ */
 
-function _uint8ArrayToBuffer(chunk) {
-  return Buffer.from(chunk);
-}
+var base64VLQ = __nccwpck_require__(26672);
+var util = __nccwpck_require__(89479);
+var ArraySet = (__nccwpck_require__(62880)/* .ArraySet */ .I);
+var MappingList = (__nccwpck_require__(66439)/* .MappingList */ .H);
 
-function _isUint8Array(obj) {
-  return Buffer.isBuffer(obj) || obj instanceof OurUint8Array;
+/**
+ * An instance of the SourceMapGenerator represents a source map which is
+ * being built incrementally. You may pass an object with the following
+ * properties:
+ *
+ *   - file: The filename of the generated source.
+ *   - sourceRoot: A root for all relative URLs in this source map.
+ */
+function SourceMapGenerator(aArgs) {
+  if (!aArgs) {
+    aArgs = {};
+  }
+  this._file = util.getArg(aArgs, 'file', null);
+  this._sourceRoot = util.getArg(aArgs, 'sourceRoot', null);
+  this._skipValidation = util.getArg(aArgs, 'skipValidation', false);
+  this._sources = new ArraySet();
+  this._names = new ArraySet();
+  this._mappings = new MappingList();
+  this._sourcesContents = null;
 }
-/**/
 
+SourceMapGenerator.prototype._version = 3;
 
-var debugUtil = __nccwpck_require__(73837);
+/**
+ * Creates a new SourceMapGenerator based on a SourceMapConsumer
+ *
+ * @param aSourceMapConsumer The SourceMap.
+ */
+SourceMapGenerator.fromSourceMap =
+  function SourceMapGenerator_fromSourceMap(aSourceMapConsumer) {
+    var sourceRoot = aSourceMapConsumer.sourceRoot;
+    var generator = new SourceMapGenerator({
+      file: aSourceMapConsumer.file,
+      sourceRoot: sourceRoot
+    });
+    aSourceMapConsumer.eachMapping(function (mapping) {
+      var newMapping = {
+        generated: {
+          line: mapping.generatedLine,
+          column: mapping.generatedColumn
+        }
+      };
 
-var debug;
+      if (mapping.source != null) {
+        newMapping.source = mapping.source;
+        if (sourceRoot != null) {
+          newMapping.source = util.relative(sourceRoot, newMapping.source);
+        }
 
-if (debugUtil && debugUtil.debuglog) {
-  debug = debugUtil.debuglog('stream');
-} else {
-  debug = function debug() {};
-}
-/**/
+        newMapping.original = {
+          line: mapping.originalLine,
+          column: mapping.originalColumn
+        };
 
+        if (mapping.name != null) {
+          newMapping.name = mapping.name;
+        }
+      }
 
-var BufferList = __nccwpck_require__(85243);
+      generator.addMapping(newMapping);
+    });
+    aSourceMapConsumer.sources.forEach(function (sourceFile) {
+      var sourceRelative = sourceFile;
+      if (sourceRoot !== null) {
+        sourceRelative = util.relative(sourceRoot, sourceFile);
+      }
 
-var destroyImpl = __nccwpck_require__(70079);
+      if (!generator._sources.has(sourceRelative)) {
+        generator._sources.add(sourceRelative);
+      }
 
-var _require = __nccwpck_require__(97458),
-    getHighWaterMark = _require.getHighWaterMark;
+      var content = aSourceMapConsumer.sourceContentFor(sourceFile);
+      if (content != null) {
+        generator.setSourceContent(sourceFile, content);
+      }
+    });
+    return generator;
+  };
 
-var _require$codes = (__nccwpck_require__(91042)/* .codes */ .q),
-    ERR_INVALID_ARG_TYPE = _require$codes.ERR_INVALID_ARG_TYPE,
-    ERR_STREAM_PUSH_AFTER_EOF = _require$codes.ERR_STREAM_PUSH_AFTER_EOF,
-    ERR_METHOD_NOT_IMPLEMENTED = _require$codes.ERR_METHOD_NOT_IMPLEMENTED,
-    ERR_STREAM_UNSHIFT_AFTER_END_EVENT = _require$codes.ERR_STREAM_UNSHIFT_AFTER_END_EVENT; // Lazy loaded to improve the startup performance.
+/**
+ * Add a single mapping from original source line and column to the generated
+ * source's line and column for this source map being created. The mapping
+ * object should have the following properties:
+ *
+ *   - generated: An object with the generated line and column positions.
+ *   - original: An object with the original line and column positions.
+ *   - source: The original source file (relative to the sourceRoot).
+ *   - name: An optional original token name for this mapping.
+ */
+SourceMapGenerator.prototype.addMapping =
+  function SourceMapGenerator_addMapping(aArgs) {
+    var generated = util.getArg(aArgs, 'generated');
+    var original = util.getArg(aArgs, 'original', null);
+    var source = util.getArg(aArgs, 'source', null);
+    var name = util.getArg(aArgs, 'name', null);
 
+    if (!this._skipValidation) {
+      this._validateMapping(generated, original, source, name);
+    }
 
-var StringDecoder;
-var createReadableStreamAsyncIterator;
-var from;
+    if (source != null) {
+      source = String(source);
+      if (!this._sources.has(source)) {
+        this._sources.add(source);
+      }
+    }
 
-__nccwpck_require__(2868)(Readable, Stream);
+    if (name != null) {
+      name = String(name);
+      if (!this._names.has(name)) {
+        this._names.add(name);
+      }
+    }
 
-var errorOrDestroy = destroyImpl.errorOrDestroy;
-var kProxyEvents = ['error', 'close', 'destroy', 'pause', 'resume'];
+    this._mappings.add({
+      generatedLine: generated.line,
+      generatedColumn: generated.column,
+      originalLine: original != null && original.line,
+      originalColumn: original != null && original.column,
+      source: source,
+      name: name
+    });
+  };
 
-function prependListener(emitter, event, fn) {
-  // Sadly this is not cacheable as some libraries bundle their own
-  // event emitter implementation with them.
-  if (typeof emitter.prependListener === 'function') return emitter.prependListener(event, fn); // This is a hack to make sure that our error handler is attached before any
-  // userland ones.  NEVER DO THIS. This is here only because this code needs
-  // to continue to work with older versions of Node.js that do not include
-  // the prependListener() method. The goal is to eventually remove this hack.
+/**
+ * Set the source content for a source file.
+ */
+SourceMapGenerator.prototype.setSourceContent =
+  function SourceMapGenerator_setSourceContent(aSourceFile, aSourceContent) {
+    var source = aSourceFile;
+    if (this._sourceRoot != null) {
+      source = util.relative(this._sourceRoot, source);
+    }
 
-  if (!emitter._events || !emitter._events[event]) emitter.on(event, fn);else if (Array.isArray(emitter._events[event])) emitter._events[event].unshift(fn);else emitter._events[event] = [fn, emitter._events[event]];
-}
+    if (aSourceContent != null) {
+      // Add the source content to the _sourcesContents map.
+      // Create a new _sourcesContents map if the property is null.
+      if (!this._sourcesContents) {
+        this._sourcesContents = Object.create(null);
+      }
+      this._sourcesContents[util.toSetString(source)] = aSourceContent;
+    } else if (this._sourcesContents) {
+      // Remove the source file from the _sourcesContents map.
+      // If the _sourcesContents map is empty, set the property to null.
+      delete this._sourcesContents[util.toSetString(source)];
+      if (Object.keys(this._sourcesContents).length === 0) {
+        this._sourcesContents = null;
+      }
+    }
+  };
 
-function ReadableState(options, stream, isDuplex) {
-  Duplex = Duplex || __nccwpck_require__(25408);
-  options = options || {}; // Duplex streams are both readable and writable, but share
-  // the same options object.
-  // However, some cases require setting options to different
-  // values for the readable and the writable sides of the duplex stream.
-  // These options can be provided separately as readableXXX and writableXXX.
+/**
+ * Applies the mappings of a sub-source-map for a specific source file to the
+ * source map being generated. Each mapping to the supplied source file is
+ * rewritten using the supplied source map. Note: The resolution for the
+ * resulting mappings is the minimium of this map and the supplied map.
+ *
+ * @param aSourceMapConsumer The source map to be applied.
+ * @param aSourceFile Optional. The filename of the source file.
+ *        If omitted, SourceMapConsumer's file property will be used.
+ * @param aSourceMapPath Optional. The dirname of the path to the source map
+ *        to be applied. If relative, it is relative to the SourceMapConsumer.
+ *        This parameter is needed when the two source maps aren't in the same
+ *        directory, and the source map to be applied contains relative source
+ *        paths. If so, those relative source paths need to be rewritten
+ *        relative to the SourceMapGenerator.
+ */
+SourceMapGenerator.prototype.applySourceMap =
+  function SourceMapGenerator_applySourceMap(aSourceMapConsumer, aSourceFile, aSourceMapPath) {
+    var sourceFile = aSourceFile;
+    // If aSourceFile is omitted, we will use the file property of the SourceMap
+    if (aSourceFile == null) {
+      if (aSourceMapConsumer.file == null) {
+        throw new Error(
+          'SourceMapGenerator.prototype.applySourceMap requires either an explicit source file, ' +
+          'or the source map\'s "file" property. Both were omitted.'
+        );
+      }
+      sourceFile = aSourceMapConsumer.file;
+    }
+    var sourceRoot = this._sourceRoot;
+    // Make "sourceFile" relative if an absolute Url is passed.
+    if (sourceRoot != null) {
+      sourceFile = util.relative(sourceRoot, sourceFile);
+    }
+    // Applying the SourceMap can add and remove items from the sources and
+    // the names array.
+    var newSources = new ArraySet();
+    var newNames = new ArraySet();
 
-  if (typeof isDuplex !== 'boolean') isDuplex = stream instanceof Duplex; // object stream flag. Used to make read(n) ignore n and to
-  // make all the buffer merging and length checks go away
+    // Find mappings for the "sourceFile"
+    this._mappings.unsortedForEach(function (mapping) {
+      if (mapping.source === sourceFile && mapping.originalLine != null) {
+        // Check if it can be mapped by the source map, then update the mapping.
+        var original = aSourceMapConsumer.originalPositionFor({
+          line: mapping.originalLine,
+          column: mapping.originalColumn
+        });
+        if (original.source != null) {
+          // Copy mapping
+          mapping.source = original.source;
+          if (aSourceMapPath != null) {
+            mapping.source = util.join(aSourceMapPath, mapping.source)
+          }
+          if (sourceRoot != null) {
+            mapping.source = util.relative(sourceRoot, mapping.source);
+          }
+          mapping.originalLine = original.line;
+          mapping.originalColumn = original.column;
+          if (original.name != null) {
+            mapping.name = original.name;
+          }
+        }
+      }
 
-  this.objectMode = !!options.objectMode;
-  if (isDuplex) this.objectMode = this.objectMode || !!options.readableObjectMode; // the point at which it stops calling _read() to fill the buffer
-  // Note: 0 is a valid value, means "don't call _read preemptively ever"
+      var source = mapping.source;
+      if (source != null && !newSources.has(source)) {
+        newSources.add(source);
+      }
 
-  this.highWaterMark = getHighWaterMark(this, options, 'readableHighWaterMark', isDuplex); // A linked list is used to store data chunks instead of an array because the
-  // linked list can remove elements from the beginning faster than
-  // array.shift()
+      var name = mapping.name;
+      if (name != null && !newNames.has(name)) {
+        newNames.add(name);
+      }
 
-  this.buffer = new BufferList();
-  this.length = 0;
-  this.pipes = null;
-  this.pipesCount = 0;
-  this.flowing = null;
-  this.ended = false;
-  this.endEmitted = false;
-  this.reading = false; // a flag to be able to tell if the event 'readable'/'data' is emitted
-  // immediately, or on a later tick.  We set this to true at first, because
-  // any actions that shouldn't happen until "later" should generally also
-  // not happen before the first read call.
+    }, this);
+    this._sources = newSources;
+    this._names = newNames;
 
-  this.sync = true; // whenever we return null, then we set a flag to say
-  // that we're awaiting a 'readable' event emission.
+    // Copy sourcesContents of applied map.
+    aSourceMapConsumer.sources.forEach(function (sourceFile) {
+      var content = aSourceMapConsumer.sourceContentFor(sourceFile);
+      if (content != null) {
+        if (aSourceMapPath != null) {
+          sourceFile = util.join(aSourceMapPath, sourceFile);
+        }
+        if (sourceRoot != null) {
+          sourceFile = util.relative(sourceRoot, sourceFile);
+        }
+        this.setSourceContent(sourceFile, content);
+      }
+    }, this);
+  };
 
-  this.needReadable = false;
-  this.emittedReadable = false;
-  this.readableListening = false;
-  this.resumeScheduled = false;
-  this.paused = true; // Should close be emitted on destroy. Defaults to true.
+/**
+ * A mapping can have one of the three levels of data:
+ *
+ *   1. Just the generated position.
+ *   2. The Generated position, original position, and original source.
+ *   3. Generated and original position, original source, as well as a name
+ *      token.
+ *
+ * To maintain consistency, we validate that any new mapping being added falls
+ * in to one of these categories.
+ */
+SourceMapGenerator.prototype._validateMapping =
+  function SourceMapGenerator_validateMapping(aGenerated, aOriginal, aSource,
+                                              aName) {
+    // When aOriginal is truthy but has empty values for .line and .column,
+    // it is most likely a programmer error. In this case we throw a very
+    // specific error message to try to guide them the right way.
+    // For example: https://github.com/Polymer/polymer-bundler/pull/519
+    if (aOriginal && typeof aOriginal.line !== 'number' && typeof aOriginal.column !== 'number') {
+        throw new Error(
+            'original.line and original.column are not numbers -- you probably meant to omit ' +
+            'the original mapping entirely and only map the generated position. If so, pass ' +
+            'null for the original mapping instead of an object with empty or null values.'
+        );
+    }
 
-  this.emitClose = options.emitClose !== false; // Should .destroy() be called after 'end' (and potentially 'finish')
+    if (aGenerated && 'line' in aGenerated && 'column' in aGenerated
+        && aGenerated.line > 0 && aGenerated.column >= 0
+        && !aOriginal && !aSource && !aName) {
+      // Case 1.
+      return;
+    }
+    else if (aGenerated && 'line' in aGenerated && 'column' in aGenerated
+             && aOriginal && 'line' in aOriginal && 'column' in aOriginal
+             && aGenerated.line > 0 && aGenerated.column >= 0
+             && aOriginal.line > 0 && aOriginal.column >= 0
+             && aSource) {
+      // Cases 2 and 3.
+      return;
+    }
+    else {
+      throw new Error('Invalid mapping: ' + JSON.stringify({
+        generated: aGenerated,
+        source: aSource,
+        original: aOriginal,
+        name: aName
+      }));
+    }
+  };
 
-  this.autoDestroy = !!options.autoDestroy; // has it been destroyed
+/**
+ * Serialize the accumulated mappings in to the stream of base 64 VLQs
+ * specified by the source map format.
+ */
+SourceMapGenerator.prototype._serializeMappings =
+  function SourceMapGenerator_serializeMappings() {
+    var previousGeneratedColumn = 0;
+    var previousGeneratedLine = 1;
+    var previousOriginalColumn = 0;
+    var previousOriginalLine = 0;
+    var previousName = 0;
+    var previousSource = 0;
+    var result = '';
+    var next;
+    var mapping;
+    var nameIdx;
+    var sourceIdx;
 
-  this.destroyed = false; // Crypto is kind of old and crusty.  Historically, its default string
-  // encoding is 'binary' so we have to make this configurable.
-  // Everything else in the universe uses 'utf8', though.
+    var mappings = this._mappings.toArray();
+    for (var i = 0, len = mappings.length; i < len; i++) {
+      mapping = mappings[i];
+      next = ''
 
-  this.defaultEncoding = options.defaultEncoding || 'utf8'; // the number of writers that are awaiting a drain event in .pipe()s
+      if (mapping.generatedLine !== previousGeneratedLine) {
+        previousGeneratedColumn = 0;
+        while (mapping.generatedLine !== previousGeneratedLine) {
+          next += ';';
+          previousGeneratedLine++;
+        }
+      }
+      else {
+        if (i > 0) {
+          if (!util.compareByGeneratedPositionsInflated(mapping, mappings[i - 1])) {
+            continue;
+          }
+          next += ',';
+        }
+      }
 
-  this.awaitDrain = 0; // if true, a maybeReadMore has been scheduled
+      next += base64VLQ.encode(mapping.generatedColumn
+                                 - previousGeneratedColumn);
+      previousGeneratedColumn = mapping.generatedColumn;
 
-  this.readingMore = false;
-  this.decoder = null;
-  this.encoding = null;
+      if (mapping.source != null) {
+        sourceIdx = this._sources.indexOf(mapping.source);
+        next += base64VLQ.encode(sourceIdx - previousSource);
+        previousSource = sourceIdx;
 
-  if (options.encoding) {
-    if (!StringDecoder) StringDecoder = (__nccwpck_require__(26590)/* .StringDecoder */ .s);
-    this.decoder = new StringDecoder(options.encoding);
-    this.encoding = options.encoding;
-  }
-}
+        // lines are stored 0-based in SourceMap spec version 3
+        next += base64VLQ.encode(mapping.originalLine - 1
+                                   - previousOriginalLine);
+        previousOriginalLine = mapping.originalLine - 1;
 
-function Readable(options) {
-  Duplex = Duplex || __nccwpck_require__(25408);
-  if (!(this instanceof Readable)) return new Readable(options); // Checking for a Stream.Duplex instance is faster here instead of inside
-  // the ReadableState constructor, at least with V8 6.5
+        next += base64VLQ.encode(mapping.originalColumn
+                                   - previousOriginalColumn);
+        previousOriginalColumn = mapping.originalColumn;
 
-  var isDuplex = this instanceof Duplex;
-  this._readableState = new ReadableState(options, this, isDuplex); // legacy
+        if (mapping.name != null) {
+          nameIdx = this._names.indexOf(mapping.name);
+          next += base64VLQ.encode(nameIdx - previousName);
+          previousName = nameIdx;
+        }
+      }
 
-  this.readable = true;
+      result += next;
+    }
 
-  if (options) {
-    if (typeof options.read === 'function') this._read = options.read;
-    if (typeof options.destroy === 'function') this._destroy = options.destroy;
-  }
+    return result;
+  };
 
-  Stream.call(this);
-}
+SourceMapGenerator.prototype._generateSourcesContent =
+  function SourceMapGenerator_generateSourcesContent(aSources, aSourceRoot) {
+    return aSources.map(function (source) {
+      if (!this._sourcesContents) {
+        return null;
+      }
+      if (aSourceRoot != null) {
+        source = util.relative(aSourceRoot, source);
+      }
+      var key = util.toSetString(source);
+      return Object.prototype.hasOwnProperty.call(this._sourcesContents, key)
+        ? this._sourcesContents[key]
+        : null;
+    }, this);
+  };
 
-Object.defineProperty(Readable.prototype, 'destroyed', {
-  // making it explicit this property is not enumerable
-  // because otherwise some prototype manipulation in
-  // userland will fail
-  enumerable: false,
-  get: function get() {
-    if (this._readableState === undefined) {
-      return false;
+/**
+ * Externalize the source map.
+ */
+SourceMapGenerator.prototype.toJSON =
+  function SourceMapGenerator_toJSON() {
+    var map = {
+      version: this._version,
+      sources: this._sources.toArray(),
+      names: this._names.toArray(),
+      mappings: this._serializeMappings()
+    };
+    if (this._file != null) {
+      map.file = this._file;
+    }
+    if (this._sourceRoot != null) {
+      map.sourceRoot = this._sourceRoot;
+    }
+    if (this._sourcesContents) {
+      map.sourcesContent = this._generateSourcesContent(map.sources, map.sourceRoot);
     }
 
-    return this._readableState.destroyed;
-  },
-  set: function set(value) {
-    // we ignore the value if the stream
-    // has not been initialized yet
-    if (!this._readableState) {
-      return;
-    } // backward compatibility, the user is explicitly
-    // managing destroyed
+    return map;
+  };
 
+/**
+ * Render the source map being generated to a string.
+ */
+SourceMapGenerator.prototype.toString =
+  function SourceMapGenerator_toString() {
+    return JSON.stringify(this.toJSON());
+  };
 
-    this._readableState.destroyed = value;
-  }
-});
-Readable.prototype.destroy = destroyImpl.destroy;
-Readable.prototype._undestroy = destroyImpl.undestroy;
+exports.h = SourceMapGenerator;
 
-Readable.prototype._destroy = function (err, cb) {
-  cb(err);
-}; // Manually shove something into the read() buffer.
-// This returns true if the highWaterMark has not been hit yet,
-// similar to how Writable.write() returns true if you should
-// write() some more.
 
+/***/ }),
 
-Readable.prototype.push = function (chunk, encoding) {
-  var state = this._readableState;
-  var skipChunkCheck;
+/***/ 53146:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
-  if (!state.objectMode) {
-    if (typeof chunk === 'string') {
-      encoding = encoding || state.defaultEncoding;
+var __webpack_unused_export__;
+/* -*- Mode: js; js-indent-level: 2; -*- */
+/*
+ * Copyright 2011 Mozilla Foundation and contributors
+ * Licensed under the New BSD license. See LICENSE or:
+ * http://opensource.org/licenses/BSD-3-Clause
+ */
 
-      if (encoding !== state.encoding) {
-        chunk = Buffer.from(chunk, encoding);
-        encoding = '';
-      }
+var SourceMapGenerator = (__nccwpck_require__(22370)/* .SourceMapGenerator */ .h);
+var util = __nccwpck_require__(89479);
 
-      skipChunkCheck = true;
-    }
-  } else {
-    skipChunkCheck = true;
-  }
+// Matches a Windows-style `\r\n` newline or a `\n` newline used by all other
+// operating systems these days (capturing the result).
+var REGEX_NEWLINE = /(\r?\n)/;
 
-  return readableAddChunk(this, chunk, encoding, false, skipChunkCheck);
-}; // Unshift should *always* be something directly out of read()
+// Newline character code for charCodeAt() comparisons
+var NEWLINE_CODE = 10;
 
+// Private symbol for identifying `SourceNode`s when multiple versions of
+// the source-map library are loaded. This MUST NOT CHANGE across
+// versions!
+var isSourceNode = "$$$isSourceNode$$$";
 
-Readable.prototype.unshift = function (chunk) {
-  return readableAddChunk(this, chunk, null, true, false);
-};
+/**
+ * SourceNodes provide a way to abstract over interpolating/concatenating
+ * snippets of generated JavaScript source code while maintaining the line and
+ * column information associated with the original source code.
+ *
+ * @param aLine The original line number.
+ * @param aColumn The original column number.
+ * @param aSource The original source's filename.
+ * @param aChunks Optional. An array of strings which are snippets of
+ *        generated JS, or other SourceNodes.
+ * @param aName The original identifier.
+ */
+function SourceNode(aLine, aColumn, aSource, aChunks, aName) {
+  this.children = [];
+  this.sourceContents = {};
+  this.line = aLine == null ? null : aLine;
+  this.column = aColumn == null ? null : aColumn;
+  this.source = aSource == null ? null : aSource;
+  this.name = aName == null ? null : aName;
+  this[isSourceNode] = true;
+  if (aChunks != null) this.add(aChunks);
+}
 
-function readableAddChunk(stream, chunk, encoding, addToFront, skipChunkCheck) {
-  debug('readableAddChunk', chunk);
-  var state = stream._readableState;
+/**
+ * Creates a SourceNode from generated code and a SourceMapConsumer.
+ *
+ * @param aGeneratedCode The generated code
+ * @param aSourceMapConsumer The SourceMap for the generated code
+ * @param aRelativePath Optional. The path that relative sources in the
+ *        SourceMapConsumer should be relative to.
+ */
+SourceNode.fromStringWithSourceMap =
+  function SourceNode_fromStringWithSourceMap(aGeneratedCode, aSourceMapConsumer, aRelativePath) {
+    // The SourceNode we want to fill with the generated code
+    // and the SourceMap
+    var node = new SourceNode();
 
-  if (chunk === null) {
-    state.reading = false;
-    onEofChunk(stream, state);
-  } else {
-    var er;
-    if (!skipChunkCheck) er = chunkInvalid(state, chunk);
+    // All even indices of this array are one line of the generated code,
+    // while all odd indices are the newlines between two adjacent lines
+    // (since `REGEX_NEWLINE` captures its match).
+    // Processed fragments are accessed by calling `shiftNextLine`.
+    var remainingLines = aGeneratedCode.split(REGEX_NEWLINE);
+    var remainingLinesIndex = 0;
+    var shiftNextLine = function() {
+      var lineContents = getNextLine();
+      // The last line of a file might not have a newline.
+      var newLine = getNextLine() || "";
+      return lineContents + newLine;
 
-    if (er) {
-      errorOrDestroy(stream, er);
-    } else if (state.objectMode || chunk && chunk.length > 0) {
-      if (typeof chunk !== 'string' && !state.objectMode && Object.getPrototypeOf(chunk) !== Buffer.prototype) {
-        chunk = _uint8ArrayToBuffer(chunk);
+      function getNextLine() {
+        return remainingLinesIndex < remainingLines.length ?
+            remainingLines[remainingLinesIndex++] : undefined;
       }
+    };
 
-      if (addToFront) {
-        if (state.endEmitted) errorOrDestroy(stream, new ERR_STREAM_UNSHIFT_AFTER_END_EVENT());else addChunk(stream, state, chunk, true);
-      } else if (state.ended) {
-        errorOrDestroy(stream, new ERR_STREAM_PUSH_AFTER_EOF());
-      } else if (state.destroyed) {
-        return false;
-      } else {
-        state.reading = false;
+    // We need to remember the position of "remainingLines"
+    var lastGeneratedLine = 1, lastGeneratedColumn = 0;
 
-        if (state.decoder && !encoding) {
-          chunk = state.decoder.write(chunk);
-          if (state.objectMode || chunk.length !== 0) addChunk(stream, state, chunk, false);else maybeReadMore(stream, state);
+    // The generate SourceNodes we need a code range.
+    // To extract it current and last mapping is used.
+    // Here we store the last mapping.
+    var lastMapping = null;
+
+    aSourceMapConsumer.eachMapping(function (mapping) {
+      if (lastMapping !== null) {
+        // We add the code from "lastMapping" to "mapping":
+        // First check if there is a new line in between.
+        if (lastGeneratedLine < mapping.generatedLine) {
+          // Associate first line with "lastMapping"
+          addMappingWithCode(lastMapping, shiftNextLine());
+          lastGeneratedLine++;
+          lastGeneratedColumn = 0;
+          // The remaining code is added without mapping
         } else {
-          addChunk(stream, state, chunk, false);
+          // There is no new line in between.
+          // Associate the code between "lastGeneratedColumn" and
+          // "mapping.generatedColumn" with "lastMapping"
+          var nextLine = remainingLines[remainingLinesIndex] || '';
+          var code = nextLine.substr(0, mapping.generatedColumn -
+                                        lastGeneratedColumn);
+          remainingLines[remainingLinesIndex] = nextLine.substr(mapping.generatedColumn -
+                                              lastGeneratedColumn);
+          lastGeneratedColumn = mapping.generatedColumn;
+          addMappingWithCode(lastMapping, code);
+          // No more remaining code, continue
+          lastMapping = mapping;
+          return;
         }
       }
-    } else if (!addToFront) {
-      state.reading = false;
-      maybeReadMore(stream, state);
+      // We add the generated code until the first mapping
+      // to the SourceNode without any mapping.
+      // Each line is added as separate string.
+      while (lastGeneratedLine < mapping.generatedLine) {
+        node.add(shiftNextLine());
+        lastGeneratedLine++;
+      }
+      if (lastGeneratedColumn < mapping.generatedColumn) {
+        var nextLine = remainingLines[remainingLinesIndex] || '';
+        node.add(nextLine.substr(0, mapping.generatedColumn));
+        remainingLines[remainingLinesIndex] = nextLine.substr(mapping.generatedColumn);
+        lastGeneratedColumn = mapping.generatedColumn;
+      }
+      lastMapping = mapping;
+    }, this);
+    // We have processed all mappings.
+    if (remainingLinesIndex < remainingLines.length) {
+      if (lastMapping) {
+        // Associate the remaining code in the current line with "lastMapping"
+        addMappingWithCode(lastMapping, shiftNextLine());
+      }
+      // and add the remaining lines without any mapping
+      node.add(remainingLines.splice(remainingLinesIndex).join(""));
     }
-  } // We can push more data if we are below the highWaterMark.
-  // Also, if we have no data yet, we can stand some more bytes.
-  // This is to work around cases where hwm=0, such as the repl.
-
-
-  return !state.ended && (state.length < state.highWaterMark || state.length === 0);
-}
 
-function addChunk(stream, state, chunk, addToFront) {
-  if (state.flowing && state.length === 0 && !state.sync) {
-    state.awaitDrain = 0;
-    stream.emit('data', chunk);
-  } else {
-    // update the buffer info.
-    state.length += state.objectMode ? 1 : chunk.length;
-    if (addToFront) state.buffer.unshift(chunk);else state.buffer.push(chunk);
-    if (state.needReadable) emitReadable(stream);
-  }
+    // Copy sourcesContent into SourceNode
+    aSourceMapConsumer.sources.forEach(function (sourceFile) {
+      var content = aSourceMapConsumer.sourceContentFor(sourceFile);
+      if (content != null) {
+        if (aRelativePath != null) {
+          sourceFile = util.join(aRelativePath, sourceFile);
+        }
+        node.setSourceContent(sourceFile, content);
+      }
+    });
 
-  maybeReadMore(stream, state);
-}
+    return node;
 
-function chunkInvalid(state, chunk) {
-  var er;
+    function addMappingWithCode(mapping, code) {
+      if (mapping === null || mapping.source === undefined) {
+        node.add(code);
+      } else {
+        var source = aRelativePath
+          ? util.join(aRelativePath, mapping.source)
+          : mapping.source;
+        node.add(new SourceNode(mapping.originalLine,
+                                mapping.originalColumn,
+                                source,
+                                code,
+                                mapping.name));
+      }
+    }
+  };
 
-  if (!_isUint8Array(chunk) && typeof chunk !== 'string' && chunk !== undefined && !state.objectMode) {
-    er = new ERR_INVALID_ARG_TYPE('chunk', ['string', 'Buffer', 'Uint8Array'], chunk);
+/**
+ * Add a chunk of generated JS to this source node.
+ *
+ * @param aChunk A string snippet of generated JS code, another instance of
+ *        SourceNode, or an array where each member is one of those things.
+ */
+SourceNode.prototype.add = function SourceNode_add(aChunk) {
+  if (Array.isArray(aChunk)) {
+    aChunk.forEach(function (chunk) {
+      this.add(chunk);
+    }, this);
   }
-
-  return er;
-}
-
-Readable.prototype.isPaused = function () {
-  return this._readableState.flowing === false;
-}; // backwards compatibility.
-
-
-Readable.prototype.setEncoding = function (enc) {
-  if (!StringDecoder) StringDecoder = (__nccwpck_require__(26590)/* .StringDecoder */ .s);
-  var decoder = new StringDecoder(enc);
-  this._readableState.decoder = decoder; // If setEncoding(null), decoder.encoding equals utf8
-
-  this._readableState.encoding = this._readableState.decoder.encoding; // Iterate over current buffer to convert already stored Buffers:
-
-  var p = this._readableState.buffer.head;
-  var content = '';
-
-  while (p !== null) {
-    content += decoder.write(p.data);
-    p = p.next;
+  else if (aChunk[isSourceNode] || typeof aChunk === "string") {
+    if (aChunk) {
+      this.children.push(aChunk);
+    }
   }
+  else {
+    throw new TypeError(
+      "Expected a SourceNode, string, or an array of SourceNodes and strings. Got " + aChunk
+    );
+  }
+  return this;
+};
 
-  this._readableState.buffer.clear();
-
-  if (content !== '') this._readableState.buffer.push(content);
-  this._readableState.length = content.length;
+/**
+ * Add a chunk of generated JS to the beginning of this source node.
+ *
+ * @param aChunk A string snippet of generated JS code, another instance of
+ *        SourceNode, or an array where each member is one of those things.
+ */
+SourceNode.prototype.prepend = function SourceNode_prepend(aChunk) {
+  if (Array.isArray(aChunk)) {
+    for (var i = aChunk.length-1; i >= 0; i--) {
+      this.prepend(aChunk[i]);
+    }
+  }
+  else if (aChunk[isSourceNode] || typeof aChunk === "string") {
+    this.children.unshift(aChunk);
+  }
+  else {
+    throw new TypeError(
+      "Expected a SourceNode, string, or an array of SourceNodes and strings. Got " + aChunk
+    );
+  }
   return this;
-}; // Don't raise the hwm > 1GB
+};
 
+/**
+ * Walk over the tree of JS snippets in this node and its children. The
+ * walking function is called once for each snippet of JS and is passed that
+ * snippet and the its original associated source's line/column location.
+ *
+ * @param aFn The traversal function.
+ */
+SourceNode.prototype.walk = function SourceNode_walk(aFn) {
+  var chunk;
+  for (var i = 0, len = this.children.length; i < len; i++) {
+    chunk = this.children[i];
+    if (chunk[isSourceNode]) {
+      chunk.walk(aFn);
+    }
+    else {
+      if (chunk !== '') {
+        aFn(chunk, { source: this.source,
+                     line: this.line,
+                     column: this.column,
+                     name: this.name });
+      }
+    }
+  }
+};
 
-var MAX_HWM = 0x40000000;
+/**
+ * Like `String.prototype.join` except for SourceNodes. Inserts `aStr` between
+ * each of `this.children`.
+ *
+ * @param aSep The separator.
+ */
+SourceNode.prototype.join = function SourceNode_join(aSep) {
+  var newChildren;
+  var i;
+  var len = this.children.length;
+  if (len > 0) {
+    newChildren = [];
+    for (i = 0; i < len-1; i++) {
+      newChildren.push(this.children[i]);
+      newChildren.push(aSep);
+    }
+    newChildren.push(this.children[i]);
+    this.children = newChildren;
+  }
+  return this;
+};
 
-function computeNewHighWaterMark(n) {
-  if (n >= MAX_HWM) {
-    // TODO(ronag): Throw ERR_VALUE_OUT_OF_RANGE.
-    n = MAX_HWM;
-  } else {
-    // Get the next highest power of 2 to prevent increasing hwm excessively in
-    // tiny amounts
-    n--;
-    n |= n >>> 1;
-    n |= n >>> 2;
-    n |= n >>> 4;
-    n |= n >>> 8;
-    n |= n >>> 16;
-    n++;
+/**
+ * Call String.prototype.replace on the very right-most source snippet. Useful
+ * for trimming whitespace from the end of a source node, etc.
+ *
+ * @param aPattern The pattern to replace.
+ * @param aReplacement The thing to replace the pattern with.
+ */
+SourceNode.prototype.replaceRight = function SourceNode_replaceRight(aPattern, aReplacement) {
+  var lastChild = this.children[this.children.length - 1];
+  if (lastChild[isSourceNode]) {
+    lastChild.replaceRight(aPattern, aReplacement);
+  }
+  else if (typeof lastChild === 'string') {
+    this.children[this.children.length - 1] = lastChild.replace(aPattern, aReplacement);
+  }
+  else {
+    this.children.push(''.replace(aPattern, aReplacement));
   }
+  return this;
+};
 
-  return n;
-} // This function is designed to be inlinable, so please take care when making
-// changes to the function body.
+/**
+ * Set the source content for a source file. This will be added to the SourceMapGenerator
+ * in the sourcesContent field.
+ *
+ * @param aSourceFile The filename of the source file
+ * @param aSourceContent The content of the source file
+ */
+SourceNode.prototype.setSourceContent =
+  function SourceNode_setSourceContent(aSourceFile, aSourceContent) {
+    this.sourceContents[util.toSetString(aSourceFile)] = aSourceContent;
+  };
 
+/**
+ * Walk over the tree of SourceNodes. The walking function is called for each
+ * source file content and is passed the filename and source content.
+ *
+ * @param aFn The traversal function.
+ */
+SourceNode.prototype.walkSourceContents =
+  function SourceNode_walkSourceContents(aFn) {
+    for (var i = 0, len = this.children.length; i < len; i++) {
+      if (this.children[i][isSourceNode]) {
+        this.children[i].walkSourceContents(aFn);
+      }
+    }
 
-function howMuchToRead(n, state) {
-  if (n <= 0 || state.length === 0 && state.ended) return 0;
-  if (state.objectMode) return 1;
+    var sources = Object.keys(this.sourceContents);
+    for (var i = 0, len = sources.length; i < len; i++) {
+      aFn(util.fromSetString(sources[i]), this.sourceContents[sources[i]]);
+    }
+  };
 
-  if (n !== n) {
-    // Only flow one buffer at a time
-    if (state.flowing && state.length) return state.buffer.head.data.length;else return state.length;
-  } // If we're asking for more than the current hwm, then raise the hwm.
+/**
+ * Return the string representation of this source node. Walks over the tree
+ * and concatenates all the various snippets together to one string.
+ */
+SourceNode.prototype.toString = function SourceNode_toString() {
+  var str = "";
+  this.walk(function (chunk) {
+    str += chunk;
+  });
+  return str;
+};
+
+/**
+ * Returns the string representation of this source node along with a source
+ * map.
+ */
+SourceNode.prototype.toStringWithSourceMap = function SourceNode_toStringWithSourceMap(aArgs) {
+  var generated = {
+    code: "",
+    line: 1,
+    column: 0
+  };
+  var map = new SourceMapGenerator(aArgs);
+  var sourceMappingActive = false;
+  var lastOriginalSource = null;
+  var lastOriginalLine = null;
+  var lastOriginalColumn = null;
+  var lastOriginalName = null;
+  this.walk(function (chunk, original) {
+    generated.code += chunk;
+    if (original.source !== null
+        && original.line !== null
+        && original.column !== null) {
+      if(lastOriginalSource !== original.source
+         || lastOriginalLine !== original.line
+         || lastOriginalColumn !== original.column
+         || lastOriginalName !== original.name) {
+        map.addMapping({
+          source: original.source,
+          original: {
+            line: original.line,
+            column: original.column
+          },
+          generated: {
+            line: generated.line,
+            column: generated.column
+          },
+          name: original.name
+        });
+      }
+      lastOriginalSource = original.source;
+      lastOriginalLine = original.line;
+      lastOriginalColumn = original.column;
+      lastOriginalName = original.name;
+      sourceMappingActive = true;
+    } else if (sourceMappingActive) {
+      map.addMapping({
+        generated: {
+          line: generated.line,
+          column: generated.column
+        }
+      });
+      lastOriginalSource = null;
+      sourceMappingActive = false;
+    }
+    for (var idx = 0, length = chunk.length; idx < length; idx++) {
+      if (chunk.charCodeAt(idx) === NEWLINE_CODE) {
+        generated.line++;
+        generated.column = 0;
+        // Mappings end at eol
+        if (idx + 1 === length) {
+          lastOriginalSource = null;
+          sourceMappingActive = false;
+        } else if (sourceMappingActive) {
+          map.addMapping({
+            source: original.source,
+            original: {
+              line: original.line,
+              column: original.column
+            },
+            generated: {
+              line: generated.line,
+              column: generated.column
+            },
+            name: original.name
+          });
+        }
+      } else {
+        generated.column++;
+      }
+    }
+  });
+  this.walkSourceContents(function (sourceFile, sourceContent) {
+    map.setSourceContent(sourceFile, sourceContent);
+  });
 
+  return { code: generated.code, map: map };
+};
 
-  if (n > state.highWaterMark) state.highWaterMark = computeNewHighWaterMark(n);
-  if (n <= state.length) return n; // Don't have enough
+__webpack_unused_export__ = SourceNode;
 
-  if (!state.ended) {
-    state.needReadable = true;
-    return 0;
-  }
 
-  return state.length;
-} // you can override either this method, or the async _read(n) below.
+/***/ }),
 
+/***/ 89479:
+/***/ ((__unused_webpack_module, exports) => {
 
-Readable.prototype.read = function (n) {
-  debug('read', n);
-  n = parseInt(n, 10);
-  var state = this._readableState;
-  var nOrig = n;
-  if (n !== 0) state.emittedReadable = false; // if we're doing read(0) to trigger a readable event, but we
-  // already have a bunch of data in the buffer, then just trigger
-  // the 'readable' event and move on.
+/* -*- Mode: js; js-indent-level: 2; -*- */
+/*
+ * Copyright 2011 Mozilla Foundation and contributors
+ * Licensed under the New BSD license. See LICENSE or:
+ * http://opensource.org/licenses/BSD-3-Clause
+ */
 
-  if (n === 0 && state.needReadable && ((state.highWaterMark !== 0 ? state.length >= state.highWaterMark : state.length > 0) || state.ended)) {
-    debug('read: emitReadable', state.length, state.ended);
-    if (state.length === 0 && state.ended) endReadable(this);else emitReadable(this);
-    return null;
+/**
+ * This is a helper function for getting values from parameter/options
+ * objects.
+ *
+ * @param args The object we are extracting values from
+ * @param name The name of the property we are getting.
+ * @param defaultValue An optional value to return if the property is missing
+ * from the object. If this is not specified and the property is missing, an
+ * error will be thrown.
+ */
+function getArg(aArgs, aName, aDefaultValue) {
+  if (aName in aArgs) {
+    return aArgs[aName];
+  } else if (arguments.length === 3) {
+    return aDefaultValue;
+  } else {
+    throw new Error('"' + aName + '" is a required argument.');
   }
+}
+exports.getArg = getArg;
 
-  n = howMuchToRead(n, state); // if we've ended, and we're now clear, then finish it up.
+var urlRegexp = /^(?:([\w+\-.]+):)?\/\/(?:(\w+:\w+)@)?([\w.-]*)(?::(\d+))?(.*)$/;
+var dataUrlRegexp = /^data:.+\,.+$/;
 
-  if (n === 0 && state.ended) {
-    if (state.length === 0) endReadable(this);
+function urlParse(aUrl) {
+  var match = aUrl.match(urlRegexp);
+  if (!match) {
     return null;
-  } // All the actual chunk generation logic needs to be
-  // *below* the call to _read.  The reason is that in certain
-  // synthetic stream cases, such as passthrough streams, _read
-  // may be a completely synchronous operation which may change
-  // the state of the read buffer, providing enough data when
-  // before there was *not* enough.
-  //
-  // So, the steps are:
-  // 1. Figure out what the state of things will be after we do
-  // a read from the buffer.
-  //
-  // 2. If that resulting state will trigger a _read, then call _read.
-  // Note that this may be asynchronous, or synchronous.  Yes, it is
-  // deeply ugly to write APIs this way, but that still doesn't mean
-  // that the Readable class should behave improperly, as streams are
-  // designed to be sync/async agnostic.
-  // Take note if the _read call is sync or async (ie, if the read call
-  // has returned yet), so that we know whether or not it's safe to emit
-  // 'readable' etc.
-  //
-  // 3. Actually pull the requested chunks out of the buffer and return.
-  // if we need a readable event, then we need to do some reading.
-
-
-  var doRead = state.needReadable;
-  debug('need readable', doRead); // if we currently have less than the highWaterMark, then also read some
+  }
+  return {
+    scheme: match[1],
+    auth: match[2],
+    host: match[3],
+    port: match[4],
+    path: match[5]
+  };
+}
+exports.urlParse = urlParse;
 
-  if (state.length === 0 || state.length - n < state.highWaterMark) {
-    doRead = true;
-    debug('length less than watermark', doRead);
-  } // however, if we've ended, then there's no point, and if we're already
-  // reading, then it's unnecessary.
+function urlGenerate(aParsedUrl) {
+  var url = '';
+  if (aParsedUrl.scheme) {
+    url += aParsedUrl.scheme + ':';
+  }
+  url += '//';
+  if (aParsedUrl.auth) {
+    url += aParsedUrl.auth + '@';
+  }
+  if (aParsedUrl.host) {
+    url += aParsedUrl.host;
+  }
+  if (aParsedUrl.port) {
+    url += ":" + aParsedUrl.port
+  }
+  if (aParsedUrl.path) {
+    url += aParsedUrl.path;
+  }
+  return url;
+}
+exports.urlGenerate = urlGenerate;
 
+/**
+ * Normalizes a path, or the path portion of a URL:
+ *
+ * - Replaces consecutive slashes with one slash.
+ * - Removes unnecessary '.' parts.
+ * - Removes unnecessary '/..' parts.
+ *
+ * Based on code in the Node.js 'path' core module.
+ *
+ * @param aPath The path or url to normalize.
+ */
+function normalize(aPath) {
+  var path = aPath;
+  var url = urlParse(aPath);
+  if (url) {
+    if (!url.path) {
+      return aPath;
+    }
+    path = url.path;
+  }
+  var isAbsolute = exports.isAbsolute(path);
 
-  if (state.ended || state.reading) {
-    doRead = false;
-    debug('reading or ended', doRead);
-  } else if (doRead) {
-    debug('do read');
-    state.reading = true;
-    state.sync = true; // if the length is currently zero, then we *need* a readable event.
+  var parts = path.split(/\/+/);
+  for (var part, up = 0, i = parts.length - 1; i >= 0; i--) {
+    part = parts[i];
+    if (part === '.') {
+      parts.splice(i, 1);
+    } else if (part === '..') {
+      up++;
+    } else if (up > 0) {
+      if (part === '') {
+        // The first part is blank if the path is absolute. Trying to go
+        // above the root is a no-op. Therefore we can remove all '..' parts
+        // directly after the root.
+        parts.splice(i + 1, up);
+        up = 0;
+      } else {
+        parts.splice(i, 2);
+        up--;
+      }
+    }
+  }
+  path = parts.join('/');
 
-    if (state.length === 0) state.needReadable = true; // call internal read method
+  if (path === '') {
+    path = isAbsolute ? '/' : '.';
+  }
 
-    this._read(state.highWaterMark);
+  if (url) {
+    url.path = path;
+    return urlGenerate(url);
+  }
+  return path;
+}
+exports.normalize = normalize;
 
-    state.sync = false; // If _read pushed data synchronously, then `reading` will be false,
-    // and we need to re-evaluate how much data we can return to the user.
+/**
+ * Joins two paths/URLs.
+ *
+ * @param aRoot The root path or URL.
+ * @param aPath The path or URL to be joined with the root.
+ *
+ * - If aPath is a URL or a data URI, aPath is returned, unless aPath is a
+ *   scheme-relative URL: Then the scheme of aRoot, if any, is prepended
+ *   first.
+ * - Otherwise aPath is a path. If aRoot is a URL, then its path portion
+ *   is updated with the result and aRoot is returned. Otherwise the result
+ *   is returned.
+ *   - If aPath is absolute, the result is aPath.
+ *   - Otherwise the two paths are joined with a slash.
+ * - Joining for example 'http://' and 'www.example.com' is also supported.
+ */
+function join(aRoot, aPath) {
+  if (aRoot === "") {
+    aRoot = ".";
+  }
+  if (aPath === "") {
+    aPath = ".";
+  }
+  var aPathUrl = urlParse(aPath);
+  var aRootUrl = urlParse(aRoot);
+  if (aRootUrl) {
+    aRoot = aRootUrl.path || '/';
+  }
 
-    if (!state.reading) n = howMuchToRead(nOrig, state);
+  // `join(foo, '//www.example.org')`
+  if (aPathUrl && !aPathUrl.scheme) {
+    if (aRootUrl) {
+      aPathUrl.scheme = aRootUrl.scheme;
+    }
+    return urlGenerate(aPathUrl);
   }
 
-  var ret;
-  if (n > 0) ret = fromList(n, state);else ret = null;
+  if (aPathUrl || aPath.match(dataUrlRegexp)) {
+    return aPath;
+  }
 
-  if (ret === null) {
-    state.needReadable = state.length <= state.highWaterMark;
-    n = 0;
-  } else {
-    state.length -= n;
-    state.awaitDrain = 0;
+  // `join('http://', 'www.example.com')`
+  if (aRootUrl && !aRootUrl.host && !aRootUrl.path) {
+    aRootUrl.host = aPath;
+    return urlGenerate(aRootUrl);
   }
 
-  if (state.length === 0) {
-    // If we have nothing in the buffer, then we want to know
-    // as soon as we *do* get something into the buffer.
-    if (!state.ended) state.needReadable = true; // If we tried to read() past the EOF, then emit end on the next tick.
+  var joined = aPath.charAt(0) === '/'
+    ? aPath
+    : normalize(aRoot.replace(/\/+$/, '') + '/' + aPath);
 
-    if (nOrig !== n && state.ended) endReadable(this);
+  if (aRootUrl) {
+    aRootUrl.path = joined;
+    return urlGenerate(aRootUrl);
   }
+  return joined;
+}
+exports.join = join;
 
-  if (ret !== null) this.emit('data', ret);
-  return ret;
+exports.isAbsolute = function (aPath) {
+  return aPath.charAt(0) === '/' || urlRegexp.test(aPath);
 };
 
-function onEofChunk(stream, state) {
-  debug('onEofChunk');
-  if (state.ended) return;
-
-  if (state.decoder) {
-    var chunk = state.decoder.end();
-
-    if (chunk && chunk.length) {
-      state.buffer.push(chunk);
-      state.length += state.objectMode ? 1 : chunk.length;
-    }
+/**
+ * Make a path relative to a URL or another path.
+ *
+ * @param aRoot The root path or URL.
+ * @param aPath The path or URL to be made relative to aRoot.
+ */
+function relative(aRoot, aPath) {
+  if (aRoot === "") {
+    aRoot = ".";
   }
 
-  state.ended = true;
-
-  if (state.sync) {
-    // if we are sync, wait until next tick to emit the data.
-    // Otherwise we risk emitting data in the flow()
-    // the readable code triggers during a read() call
-    emitReadable(stream);
-  } else {
-    // emit 'readable' now to make sure it gets picked up.
-    state.needReadable = false;
+  aRoot = aRoot.replace(/\/$/, '');
 
-    if (!state.emittedReadable) {
-      state.emittedReadable = true;
-      emitReadable_(stream);
+  // It is possible for the path to be above the root. In this case, simply
+  // checking whether the root is a prefix of the path won't work. Instead, we
+  // need to remove components from the root one by one, until either we find
+  // a prefix that fits, or we run out of components to remove.
+  var level = 0;
+  while (aPath.indexOf(aRoot + '/') !== 0) {
+    var index = aRoot.lastIndexOf("/");
+    if (index < 0) {
+      return aPath;
     }
-  }
-} // Don't emit readable right away in sync mode, because this can trigger
-// another read() call => stack overflow.  This way, it might trigger
-// a nextTick recursion warning, but that's not so bad.
 
+    // If the only part of the root that is left is the scheme (i.e. http://,
+    // file:///, etc.), one or more slashes (/), or simply nothing at all, we
+    // have exhausted all components, so the path is not relative to the root.
+    aRoot = aRoot.slice(0, index);
+    if (aRoot.match(/^([^\/]+:\/)?\/*$/)) {
+      return aPath;
+    }
 
-function emitReadable(stream) {
-  var state = stream._readableState;
-  debug('emitReadable', state.needReadable, state.emittedReadable);
-  state.needReadable = false;
-
-  if (!state.emittedReadable) {
-    debug('emitReadable', state.flowing);
-    state.emittedReadable = true;
-    process.nextTick(emitReadable_, stream);
+    ++level;
   }
-}
 
-function emitReadable_(stream) {
-  var state = stream._readableState;
-  debug('emitReadable_', state.destroyed, state.length, state.ended);
+  // Make sure we add a "../" for each component we removed from the root.
+  return Array(level + 1).join("../") + aPath.substr(aRoot.length + 1);
+}
+exports.relative = relative;
 
-  if (!state.destroyed && (state.length || state.ended)) {
-    stream.emit('readable');
-    state.emittedReadable = false;
-  } // The stream needs another readable event if
-  // 1. It is not flowing, as the flow mechanism will take
-  //    care of it.
-  // 2. It is not ended.
-  // 3. It is below the highWaterMark, so we can schedule
-  //    another readable later.
+var supportsNullProto = (function () {
+  var obj = Object.create(null);
+  return !('__proto__' in obj);
+}());
 
+function identity (s) {
+  return s;
+}
 
-  state.needReadable = !state.flowing && !state.ended && state.length <= state.highWaterMark;
-  flow(stream);
-} // at this point, the user has presumably seen the 'readable' event,
-// and called read() to consume some data.  that may have triggered
-// in turn another _read(n) call, in which case reading = true if
-// it's in progress.
-// However, if we're not ended, or reading, and the length < hwm,
-// then go ahead and try to read some more preemptively.
+/**
+ * Because behavior goes wacky when you set `__proto__` on objects, we
+ * have to prefix all the strings in our set with an arbitrary character.
+ *
+ * See https://github.com/mozilla/source-map/pull/31 and
+ * https://github.com/mozilla/source-map/issues/30
+ *
+ * @param String aStr
+ */
+function toSetString(aStr) {
+  if (isProtoString(aStr)) {
+    return '$' + aStr;
+  }
 
+  return aStr;
+}
+exports.toSetString = supportsNullProto ? identity : toSetString;
 
-function maybeReadMore(stream, state) {
-  if (!state.readingMore) {
-    state.readingMore = true;
-    process.nextTick(maybeReadMore_, stream, state);
+function fromSetString(aStr) {
+  if (isProtoString(aStr)) {
+    return aStr.slice(1);
   }
+
+  return aStr;
 }
+exports.fromSetString = supportsNullProto ? identity : fromSetString;
 
-function maybeReadMore_(stream, state) {
-  // Attempt to read more data if we should.
-  //
-  // The conditions for reading more data are (one of):
-  // - Not enough data buffered (state.length < state.highWaterMark). The loop
-  //   is responsible for filling the buffer with enough data if such data
-  //   is available. If highWaterMark is 0 and we are not in the flowing mode
-  //   we should _not_ attempt to buffer any extra data. We'll get more data
-  //   when the stream consumer calls read() instead.
-  // - No data in the buffer, and the stream is in flowing mode. In this mode
-  //   the loop below is responsible for ensuring read() is called. Failing to
-  //   call read here would abort the flow and there's no other mechanism for
-  //   continuing the flow if the stream consumer has just subscribed to the
-  //   'data' event.
-  //
-  // In addition to the above conditions to keep reading data, the following
-  // conditions prevent the data from being read:
-  // - The stream has ended (state.ended).
-  // - There is already a pending 'read' operation (state.reading). This is a
-  //   case where the the stream has called the implementation defined _read()
-  //   method, but they are processing the call asynchronously and have _not_
-  //   called push() with new data. In this case we skip performing more
-  //   read()s. The execution ends in this method again after the _read() ends
-  //   up calling push() with more data.
-  while (!state.reading && !state.ended && (state.length < state.highWaterMark || state.flowing && state.length === 0)) {
-    var len = state.length;
-    debug('maybeReadMore read 0');
-    stream.read(0);
-    if (len === state.length) // didn't get any data, stop spinning.
-      break;
+function isProtoString(s) {
+  if (!s) {
+    return false;
   }
 
-  state.readingMore = false;
-} // abstract method.  to be overridden in specific implementation classes.
-// call cb(er, data) where data is <= n in length.
-// for virtual (non-string, non-buffer) streams, "length" is somewhat
-// arbitrary, and perhaps not very meaningful.
+  var length = s.length;
 
+  if (length < 9 /* "__proto__".length */) {
+    return false;
+  }
 
-Readable.prototype._read = function (n) {
-  errorOrDestroy(this, new ERR_METHOD_NOT_IMPLEMENTED('_read()'));
-};
+  if (s.charCodeAt(length - 1) !== 95  /* '_' */ ||
+      s.charCodeAt(length - 2) !== 95  /* '_' */ ||
+      s.charCodeAt(length - 3) !== 111 /* 'o' */ ||
+      s.charCodeAt(length - 4) !== 116 /* 't' */ ||
+      s.charCodeAt(length - 5) !== 111 /* 'o' */ ||
+      s.charCodeAt(length - 6) !== 114 /* 'r' */ ||
+      s.charCodeAt(length - 7) !== 112 /* 'p' */ ||
+      s.charCodeAt(length - 8) !== 95  /* '_' */ ||
+      s.charCodeAt(length - 9) !== 95  /* '_' */) {
+    return false;
+  }
 
-Readable.prototype.pipe = function (dest, pipeOpts) {
-  var src = this;
-  var state = this._readableState;
+  for (var i = length - 10; i >= 0; i--) {
+    if (s.charCodeAt(i) !== 36 /* '$' */) {
+      return false;
+    }
+  }
 
-  switch (state.pipesCount) {
-    case 0:
-      state.pipes = dest;
-      break;
+  return true;
+}
 
-    case 1:
-      state.pipes = [state.pipes, dest];
-      break;
+/**
+ * Comparator between two mappings where the original positions are compared.
+ *
+ * Optionally pass in `true` as `onlyCompareGenerated` to consider two
+ * mappings with the same original source/line/column, but different generated
+ * line and column the same. Useful when searching for a mapping with a
+ * stubbed out mapping.
+ */
+function compareByOriginalPositions(mappingA, mappingB, onlyCompareOriginal) {
+  var cmp = strcmp(mappingA.source, mappingB.source);
+  if (cmp !== 0) {
+    return cmp;
+  }
 
-    default:
-      state.pipes.push(dest);
-      break;
+  cmp = mappingA.originalLine - mappingB.originalLine;
+  if (cmp !== 0) {
+    return cmp;
   }
 
-  state.pipesCount += 1;
-  debug('pipe count=%d opts=%j', state.pipesCount, pipeOpts);
-  var doEnd = (!pipeOpts || pipeOpts.end !== false) && dest !== process.stdout && dest !== process.stderr;
-  var endFn = doEnd ? onend : unpipe;
-  if (state.endEmitted) process.nextTick(endFn);else src.once('end', endFn);
-  dest.on('unpipe', onunpipe);
+  cmp = mappingA.originalColumn - mappingB.originalColumn;
+  if (cmp !== 0 || onlyCompareOriginal) {
+    return cmp;
+  }
 
-  function onunpipe(readable, unpipeInfo) {
-    debug('onunpipe');
+  cmp = mappingA.generatedColumn - mappingB.generatedColumn;
+  if (cmp !== 0) {
+    return cmp;
+  }
 
-    if (readable === src) {
-      if (unpipeInfo && unpipeInfo.hasUnpiped === false) {
-        unpipeInfo.hasUnpiped = true;
-        cleanup();
-      }
-    }
+  cmp = mappingA.generatedLine - mappingB.generatedLine;
+  if (cmp !== 0) {
+    return cmp;
   }
 
-  function onend() {
-    debug('onend');
-    dest.end();
-  } // when the dest drains, it reduces the awaitDrain counter
-  // on the source.  This would be more elegant with a .once()
-  // handler in flow(), but adding and removing repeatedly is
-  // too slow.
+  return strcmp(mappingA.name, mappingB.name);
+}
+exports.compareByOriginalPositions = compareByOriginalPositions;
 
+/**
+ * Comparator between two mappings with deflated source and name indices where
+ * the generated positions are compared.
+ *
+ * Optionally pass in `true` as `onlyCompareGenerated` to consider two
+ * mappings with the same generated line and column, but different
+ * source/name/original line and column the same. Useful when searching for a
+ * mapping with a stubbed out mapping.
+ */
+function compareByGeneratedPositionsDeflated(mappingA, mappingB, onlyCompareGenerated) {
+  var cmp = mappingA.generatedLine - mappingB.generatedLine;
+  if (cmp !== 0) {
+    return cmp;
+  }
 
-  var ondrain = pipeOnDrain(src);
-  dest.on('drain', ondrain);
-  var cleanedUp = false;
+  cmp = mappingA.generatedColumn - mappingB.generatedColumn;
+  if (cmp !== 0 || onlyCompareGenerated) {
+    return cmp;
+  }
 
-  function cleanup() {
-    debug('cleanup'); // cleanup event handlers once the pipe is broken
+  cmp = strcmp(mappingA.source, mappingB.source);
+  if (cmp !== 0) {
+    return cmp;
+  }
 
-    dest.removeListener('close', onclose);
-    dest.removeListener('finish', onfinish);
-    dest.removeListener('drain', ondrain);
-    dest.removeListener('error', onerror);
-    dest.removeListener('unpipe', onunpipe);
-    src.removeListener('end', onend);
-    src.removeListener('end', unpipe);
-    src.removeListener('data', ondata);
-    cleanedUp = true; // if the reader is waiting for a drain event from this
-    // specific writer, then it would cause it to never start
-    // flowing again.
-    // So, if this is awaiting a drain, then we just call it now.
-    // If we don't know, then assume that we are waiting for one.
+  cmp = mappingA.originalLine - mappingB.originalLine;
+  if (cmp !== 0) {
+    return cmp;
+  }
 
-    if (state.awaitDrain && (!dest._writableState || dest._writableState.needDrain)) ondrain();
+  cmp = mappingA.originalColumn - mappingB.originalColumn;
+  if (cmp !== 0) {
+    return cmp;
   }
 
-  src.on('data', ondata);
+  return strcmp(mappingA.name, mappingB.name);
+}
+exports.compareByGeneratedPositionsDeflated = compareByGeneratedPositionsDeflated;
 
-  function ondata(chunk) {
-    debug('ondata');
-    var ret = dest.write(chunk);
-    debug('dest.write', ret);
+function strcmp(aStr1, aStr2) {
+  if (aStr1 === aStr2) {
+    return 0;
+  }
 
-    if (ret === false) {
-      // If the user unpiped during `dest.write()`, it is possible
-      // to get stuck in a permanently paused state if that write
-      // also returned false.
-      // => Check whether `dest` is still a piping destination.
-      if ((state.pipesCount === 1 && state.pipes === dest || state.pipesCount > 1 && indexOf(state.pipes, dest) !== -1) && !cleanedUp) {
-        debug('false write response, pause', state.awaitDrain);
-        state.awaitDrain++;
-      }
+  if (aStr1 === null) {
+    return 1; // aStr2 !== null
+  }
 
-      src.pause();
-    }
-  } // if the dest has an error, then stop piping into it.
-  // however, don't suppress the throwing behavior for this.
+  if (aStr2 === null) {
+    return -1; // aStr1 !== null
+  }
 
+  if (aStr1 > aStr2) {
+    return 1;
+  }
 
-  function onerror(er) {
-    debug('onerror', er);
-    unpipe();
-    dest.removeListener('error', onerror);
-    if (EElistenerCount(dest, 'error') === 0) errorOrDestroy(dest, er);
-  } // Make sure our error handler is attached before userland ones.
+  return -1;
+}
 
+/**
+ * Comparator between two mappings with inflated source and name strings where
+ * the generated positions are compared.
+ */
+function compareByGeneratedPositionsInflated(mappingA, mappingB) {
+  var cmp = mappingA.generatedLine - mappingB.generatedLine;
+  if (cmp !== 0) {
+    return cmp;
+  }
 
-  prependListener(dest, 'error', onerror); // Both close and finish should trigger unpipe, but only once.
+  cmp = mappingA.generatedColumn - mappingB.generatedColumn;
+  if (cmp !== 0) {
+    return cmp;
+  }
 
-  function onclose() {
-    dest.removeListener('finish', onfinish);
-    unpipe();
+  cmp = strcmp(mappingA.source, mappingB.source);
+  if (cmp !== 0) {
+    return cmp;
   }
 
-  dest.once('close', onclose);
+  cmp = mappingA.originalLine - mappingB.originalLine;
+  if (cmp !== 0) {
+    return cmp;
+  }
 
-  function onfinish() {
-    debug('onfinish');
-    dest.removeListener('close', onclose);
-    unpipe();
+  cmp = mappingA.originalColumn - mappingB.originalColumn;
+  if (cmp !== 0) {
+    return cmp;
   }
 
-  dest.once('finish', onfinish);
+  return strcmp(mappingA.name, mappingB.name);
+}
+exports.compareByGeneratedPositionsInflated = compareByGeneratedPositionsInflated;
 
-  function unpipe() {
-    debug('unpipe');
-    src.unpipe(dest);
-  } // tell the dest that it's being piped to
+/**
+ * Strip any JSON XSSI avoidance prefix from the string (as documented
+ * in the source maps specification), and then parse the string as
+ * JSON.
+ */
+function parseSourceMapInput(str) {
+  return JSON.parse(str.replace(/^\)]}'[^\n]*\n/, ''));
+}
+exports.parseSourceMapInput = parseSourceMapInput;
 
+/**
+ * Compute the URL of a source given the the source root, the source's
+ * URL, and the source map's URL.
+ */
+function computeSourceURL(sourceRoot, sourceURL, sourceMapURL) {
+  sourceURL = sourceURL || '';
 
-  dest.emit('pipe', src); // start the flow if it hasn't been started already.
+  if (sourceRoot) {
+    // This follows what Chrome does.
+    if (sourceRoot[sourceRoot.length - 1] !== '/' && sourceURL[0] !== '/') {
+      sourceRoot += '/';
+    }
+    // The spec says:
+    //   Line 4: An optional source root, useful for relocating source
+    //   files on a server or removing repeated values in the
+    //   “sources” entry.  This value is prepended to the individual
+    //   entries in the “source” field.
+    sourceURL = sourceRoot + sourceURL;
+  }
 
-  if (!state.flowing) {
-    debug('pipe resume');
-    src.resume();
+  // Historically, SourceMapConsumer did not take the sourceMapURL as
+  // a parameter.  This mode is still somewhat supported, which is why
+  // this code block is conditional.  However, it's preferable to pass
+  // the source map URL to SourceMapConsumer, so that this function
+  // can implement the source URL resolution algorithm as outlined in
+  // the spec.  This block is basically the equivalent of:
+  //    new URL(sourceURL, sourceMapURL).toString()
+  // ... except it avoids using URL, which wasn't available in the
+  // older releases of node still supported by this library.
+  //
+  // The spec says:
+  //   If the sources are not absolute URLs after prepending of the
+  //   “sourceRoot”, the sources are resolved relative to the
+  //   SourceMap (like resolving script src in a html document).
+  if (sourceMapURL) {
+    var parsed = urlParse(sourceMapURL);
+    if (!parsed) {
+      throw new Error("sourceMapURL could not be parsed");
+    }
+    if (parsed.path) {
+      // Strip the last path component, but keep the "/".
+      var index = parsed.path.lastIndexOf('/');
+      if (index >= 0) {
+        parsed.path = parsed.path.substring(0, index + 1);
+      }
+    }
+    sourceURL = join(urlGenerate(parsed), sourceURL);
   }
 
-  return dest;
-};
+  return normalize(sourceURL);
+}
+exports.computeSourceURL = computeSourceURL;
 
-function pipeOnDrain(src) {
-  return function pipeOnDrainFunctionResult() {
-    var state = src._readableState;
-    debug('pipeOnDrain', state.awaitDrain);
-    if (state.awaitDrain) state.awaitDrain--;
 
-    if (state.awaitDrain === 0 && EElistenerCount(src, 'data')) {
-      state.flowing = true;
-      flow(src);
-    }
-  };
-}
+/***/ }),
 
-Readable.prototype.unpipe = function (dest) {
-  var state = this._readableState;
-  var unpipeInfo = {
-    hasUnpiped: false
-  }; // if we're not piping anywhere, then do nothing.
+/***/ 53439:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
-  if (state.pipesCount === 0) return this; // just one destination.  most common case.
+/*
+ * Copyright 2009-2011 Mozilla Foundation and contributors
+ * Licensed under the New BSD license. See LICENSE.txt or:
+ * http://opensource.org/licenses/BSD-3-Clause
+ */
+/* unused reexport */ __nccwpck_require__(22370)/* .SourceMapGenerator */ .h;
+exports.SourceMapConsumer = __nccwpck_require__(89457).SourceMapConsumer;
+/* unused reexport */ __nccwpck_require__(53146);
 
-  if (state.pipesCount === 1) {
-    // passed in one, but it's not the right one.
-    if (dest && dest !== state.pipes) return this;
-    if (!dest) dest = state.pipes; // got a match.
 
-    state.pipes = null;
-    state.pipesCount = 0;
-    state.flowing = false;
-    if (dest) dest.emit('unpipe', this, unpipeInfo);
-    return this;
-  } // slow case. multiple pipe destinations.
+/***/ }),
 
+/***/ 24823:
+/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
-  if (!dest) {
-    // remove all.
-    var dests = state.pipes;
-    var len = state.pipesCount;
-    state.pipes = null;
-    state.pipesCount = 0;
-    state.flowing = false;
+"use strict";
 
-    for (var i = 0; i < len; i++) {
-      dests[i].emit('unpipe', this, {
-        hasUnpiped: false
-      });
-    }
+const stripAnsi = __nccwpck_require__(74817);
+const isFullwidthCodePoint = __nccwpck_require__(3221);
+const emojiRegex = __nccwpck_require__(37896);
 
-    return this;
-  } // try to find the right one.
+const stringWidth = string => {
+	if (typeof string !== 'string' || string.length === 0) {
+		return 0;
+	}
 
+	string = stripAnsi(string);
 
-  var index = indexOf(state.pipes, dest);
-  if (index === -1) return this;
-  state.pipes.splice(index, 1);
-  state.pipesCount -= 1;
-  if (state.pipesCount === 1) state.pipes = state.pipes[0];
-  dest.emit('unpipe', this, unpipeInfo);
-  return this;
-}; // set up data events if they are asked for
-// Ensure readable listeners eventually get something
+	if (string.length === 0) {
+		return 0;
+	}
 
+	string = string.replace(emojiRegex(), '  ');
 
-Readable.prototype.on = function (ev, fn) {
-  var res = Stream.prototype.on.call(this, ev, fn);
-  var state = this._readableState;
+	let width = 0;
 
-  if (ev === 'data') {
-    // update readableListening so that resume() may be a no-op
-    // a few lines down. This is needed to support once('readable').
-    state.readableListening = this.listenerCount('readable') > 0; // Try start flowing on next tick if stream isn't explicitly paused
+	for (let i = 0; i < string.length; i++) {
+		const code = string.codePointAt(i);
 
-    if (state.flowing !== false) this.resume();
-  } else if (ev === 'readable') {
-    if (!state.endEmitted && !state.readableListening) {
-      state.readableListening = state.needReadable = true;
-      state.flowing = false;
-      state.emittedReadable = false;
-      debug('on readable', state.length, state.reading);
+		// Ignore control characters
+		if (code <= 0x1F || (code >= 0x7F && code <= 0x9F)) {
+			continue;
+		}
 
-      if (state.length) {
-        emitReadable(this);
-      } else if (!state.reading) {
-        process.nextTick(nReadingNextTick, this);
-      }
-    }
-  }
+		// Ignore combining characters
+		if (code >= 0x300 && code <= 0x36F) {
+			continue;
+		}
 
-  return res;
+		// Surrogates
+		if (code > 0xFFFF) {
+			i++;
+		}
+
+		width += isFullwidthCodePoint(code) ? 2 : 1;
+	}
+
+	return width;
 };
 
-Readable.prototype.addListener = Readable.prototype.on;
+module.exports = stringWidth;
+// TODO: remove this in the next major version
+module.exports["default"] = stringWidth;
 
-Readable.prototype.removeListener = function (ev, fn) {
-  var res = Stream.prototype.removeListener.call(this, ev, fn);
 
-  if (ev === 'readable') {
-    // We need to check if there is someone still listening to
-    // readable and reset the state. However this needs to happen
-    // after readable has been emitted but before I/O (nextTick) to
-    // support once('readable', fn) cycles. This means that calling
-    // resume within the same tick will have no
-    // effect.
-    process.nextTick(updateReadableListening, this);
-  }
-
-  return res;
-};
-
-Readable.prototype.removeAllListeners = function (ev) {
-  var res = Stream.prototype.removeAllListeners.apply(this, arguments);
-
-  if (ev === 'readable' || ev === undefined) {
-    // We need to check if there is someone still listening to
-    // readable and reset the state. However this needs to happen
-    // after readable has been emitted but before I/O (nextTick) to
-    // support once('readable', fn) cycles. This means that calling
-    // resume within the same tick will have no
-    // effect.
-    process.nextTick(updateReadableListening, this);
-  }
-
-  return res;
-};
+/***/ }),
 
-function updateReadableListening(self) {
-  var state = self._readableState;
-  state.readableListening = self.listenerCount('readable') > 0;
+/***/ 59868:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
-  if (state.resumeScheduled && !state.paused) {
-    // flowing needs to be set to true now, otherwise
-    // the upcoming resume will not flow.
-    state.flowing = true; // crude way to check if we should resume
-  } else if (self.listenerCount('data') > 0) {
-    self.resume();
-  }
-}
+"use strict";
+// Copyright Joyent, Inc. and other Node contributors.
+//
+// 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.
 
-function nReadingNextTick(self) {
-  debug('readable nexttick read 0');
-  self.read(0);
-} // pause() and resume() are remnants of the legacy readable stream API
-// If the user uses them, then switch into old mode.
 
 
-Readable.prototype.resume = function () {
-  var state = this._readableState;
+/**/
 
-  if (!state.flowing) {
-    debug('resume'); // we flow only if there is no one listening
-    // for readable, but we still have to call
-    // resume()
+var Buffer = (__nccwpck_require__(54184).Buffer);
+/**/
 
-    state.flowing = !state.readableListening;
-    resume(this, state);
+var isEncoding = Buffer.isEncoding || function (encoding) {
+  encoding = '' + encoding;
+  switch (encoding && encoding.toLowerCase()) {
+    case 'hex':case 'utf8':case 'utf-8':case 'ascii':case 'binary':case 'base64':case 'ucs2':case 'ucs-2':case 'utf16le':case 'utf-16le':case 'raw':
+      return true;
+    default:
+      return false;
   }
-
-  state.paused = false;
-  return this;
 };
 
-function resume(stream, state) {
-  if (!state.resumeScheduled) {
-    state.resumeScheduled = true;
-    process.nextTick(resume_, stream, state);
+function _normalizeEncoding(enc) {
+  if (!enc) return 'utf8';
+  var retried;
+  while (true) {
+    switch (enc) {
+      case 'utf8':
+      case 'utf-8':
+        return 'utf8';
+      case 'ucs2':
+      case 'ucs-2':
+      case 'utf16le':
+      case 'utf-16le':
+        return 'utf16le';
+      case 'latin1':
+      case 'binary':
+        return 'latin1';
+      case 'base64':
+      case 'ascii':
+      case 'hex':
+        return enc;
+      default:
+        if (retried) return; // undefined
+        enc = ('' + enc).toLowerCase();
+        retried = true;
+    }
   }
-}
+};
 
-function resume_(stream, state) {
-  debug('resume', state.reading);
+// Do not cache `Buffer.isEncoding` when checking encoding names as some
+// modules monkey-patch it to support additional encodings
+function normalizeEncoding(enc) {
+  var nenc = _normalizeEncoding(enc);
+  if (typeof nenc !== 'string' && (Buffer.isEncoding === isEncoding || !isEncoding(enc))) throw new Error('Unknown encoding: ' + enc);
+  return nenc || enc;
+}
 
-  if (!state.reading) {
-    stream.read(0);
+// StringDecoder provides an interface for efficiently splitting a series of
+// buffers into a series of JS strings without breaking apart multi-byte
+// characters.
+exports.s = StringDecoder;
+function StringDecoder(encoding) {
+  this.encoding = normalizeEncoding(encoding);
+  var nb;
+  switch (this.encoding) {
+    case 'utf16le':
+      this.text = utf16Text;
+      this.end = utf16End;
+      nb = 4;
+      break;
+    case 'utf8':
+      this.fillLast = utf8FillLast;
+      nb = 4;
+      break;
+    case 'base64':
+      this.text = base64Text;
+      this.end = base64End;
+      nb = 3;
+      break;
+    default:
+      this.write = simpleWrite;
+      this.end = simpleEnd;
+      return;
   }
-
-  state.resumeScheduled = false;
-  stream.emit('resume');
-  flow(stream);
-  if (state.flowing && !state.reading) stream.read(0);
+  this.lastNeed = 0;
+  this.lastTotal = 0;
+  this.lastChar = Buffer.allocUnsafe(nb);
 }
 
-Readable.prototype.pause = function () {
-  debug('call pause flowing=%j', this._readableState.flowing);
-
-  if (this._readableState.flowing !== false) {
-    debug('pause');
-    this._readableState.flowing = false;
-    this.emit('pause');
+StringDecoder.prototype.write = function (buf) {
+  if (buf.length === 0) return '';
+  var r;
+  var i;
+  if (this.lastNeed) {
+    r = this.fillLast(buf);
+    if (r === undefined) return '';
+    i = this.lastNeed;
+    this.lastNeed = 0;
+  } else {
+    i = 0;
   }
-
-  this._readableState.paused = true;
-  return this;
+  if (i < buf.length) return r ? r + this.text(buf, i) : this.text(buf, i);
+  return r || '';
 };
 
-function flow(stream) {
-  var state = stream._readableState;
-  debug('flow', state.flowing);
-
-  while (state.flowing && stream.read() !== null) {
-    ;
-  }
-} // wrap an old-style stream as the async data source.
-// This is *not* part of the readable stream interface.
-// It is an ugly unfortunate mess of history.
-
-
-Readable.prototype.wrap = function (stream) {
-  var _this = this;
-
-  var state = this._readableState;
-  var paused = false;
-  stream.on('end', function () {
-    debug('wrapped end');
-
-    if (state.decoder && !state.ended) {
-      var chunk = state.decoder.end();
-      if (chunk && chunk.length) _this.push(chunk);
-    }
-
-    _this.push(null);
-  });
-  stream.on('data', function (chunk) {
-    debug('wrapped data');
-    if (state.decoder) chunk = state.decoder.write(chunk); // don't skip over falsy values in objectMode
-
-    if (state.objectMode && (chunk === null || chunk === undefined)) return;else if (!state.objectMode && (!chunk || !chunk.length)) return;
-
-    var ret = _this.push(chunk);
-
-    if (!ret) {
-      paused = true;
-      stream.pause();
-    }
-  }); // proxy all the other methods.
-  // important when wrapping filters and duplexes.
-
-  for (var i in stream) {
-    if (this[i] === undefined && typeof stream[i] === 'function') {
-      this[i] = function methodWrap(method) {
-        return function methodWrapReturnFunction() {
-          return stream[method].apply(stream, arguments);
-        };
-      }(i);
-    }
-  } // proxy certain important events.
-
-
-  for (var n = 0; n < kProxyEvents.length; n++) {
-    stream.on(kProxyEvents[n], this.emit.bind(this, kProxyEvents[n]));
-  } // when we try to consume some more bytes, simply unpause the
-  // underlying stream.
-
-
-  this._read = function (n) {
-    debug('wrapped _read', n);
+StringDecoder.prototype.end = utf8End;
 
-    if (paused) {
-      paused = false;
-      stream.resume();
-    }
-  };
+// Returns only complete characters in a Buffer
+StringDecoder.prototype.text = utf8Text;
 
-  return this;
+// Attempts to complete a partial non-UTF-8 character using bytes from a Buffer
+StringDecoder.prototype.fillLast = function (buf) {
+  if (this.lastNeed <= buf.length) {
+    buf.copy(this.lastChar, this.lastTotal - this.lastNeed, 0, this.lastNeed);
+    return this.lastChar.toString(this.encoding, 0, this.lastTotal);
+  }
+  buf.copy(this.lastChar, this.lastTotal - this.lastNeed, 0, buf.length);
+  this.lastNeed -= buf.length;
 };
 
-if (typeof Symbol === 'function') {
-  Readable.prototype[Symbol.asyncIterator] = function () {
-    if (createReadableStreamAsyncIterator === undefined) {
-      createReadableStreamAsyncIterator = __nccwpck_require__(29634);
-    }
-
-    return createReadableStreamAsyncIterator(this);
-  };
+// Checks the type of a UTF-8 byte, whether it's ASCII, a leading byte, or a
+// continuation byte. If an invalid byte is detected, -2 is returned.
+function utf8CheckByte(byte) {
+  if (byte <= 0x7F) return 0;else if (byte >> 5 === 0x06) return 2;else if (byte >> 4 === 0x0E) return 3;else if (byte >> 3 === 0x1E) return 4;
+  return byte >> 6 === 0x02 ? -1 : -2;
 }
 
-Object.defineProperty(Readable.prototype, 'readableHighWaterMark', {
-  // making it explicit this property is not enumerable
-  // because otherwise some prototype manipulation in
-  // userland will fail
-  enumerable: false,
-  get: function get() {
-    return this._readableState.highWaterMark;
+// Checks at most 3 bytes at the end of a Buffer in order to detect an
+// incomplete multi-byte UTF-8 character. The total number of bytes (2, 3, or 4)
+// needed to complete the UTF-8 character (if applicable) are returned.
+function utf8CheckIncomplete(self, buf, i) {
+  var j = buf.length - 1;
+  if (j < i) return 0;
+  var nb = utf8CheckByte(buf[j]);
+  if (nb >= 0) {
+    if (nb > 0) self.lastNeed = nb - 1;
+    return nb;
   }
-});
-Object.defineProperty(Readable.prototype, 'readableBuffer', {
-  // making it explicit this property is not enumerable
-  // because otherwise some prototype manipulation in
-  // userland will fail
-  enumerable: false,
-  get: function get() {
-    return this._readableState && this._readableState.buffer;
+  if (--j < i || nb === -2) return 0;
+  nb = utf8CheckByte(buf[j]);
+  if (nb >= 0) {
+    if (nb > 0) self.lastNeed = nb - 2;
+    return nb;
   }
-});
-Object.defineProperty(Readable.prototype, 'readableFlowing', {
-  // making it explicit this property is not enumerable
-  // because otherwise some prototype manipulation in
-  // userland will fail
-  enumerable: false,
-  get: function get() {
-    return this._readableState.flowing;
-  },
-  set: function set(state) {
-    if (this._readableState) {
-      this._readableState.flowing = state;
+  if (--j < i || nb === -2) return 0;
+  nb = utf8CheckByte(buf[j]);
+  if (nb >= 0) {
+    if (nb > 0) {
+      if (nb === 2) nb = 0;else self.lastNeed = nb - 3;
     }
+    return nb;
   }
-}); // exposed for testing purposes only.
+  return 0;
+}
 
-Readable._fromList = fromList;
-Object.defineProperty(Readable.prototype, 'readableLength', {
-  // making it explicit this property is not enumerable
-  // because otherwise some prototype manipulation in
-  // userland will fail
-  enumerable: false,
-  get: function get() {
-    return this._readableState.length;
+// Validates as many continuation bytes for a multi-byte UTF-8 character as
+// needed or are available. If we see a non-continuation byte where we expect
+// one, we "replace" the validated continuation bytes we've seen so far with
+// a single UTF-8 replacement character ('\ufffd'), to match v8's UTF-8 decoding
+// behavior. The continuation byte check is included three times in the case
+// where all of the continuation bytes for a character exist in the same buffer.
+// It is also done this way as a slight performance increase instead of using a
+// loop.
+function utf8CheckExtraBytes(self, buf, p) {
+  if ((buf[0] & 0xC0) !== 0x80) {
+    self.lastNeed = 0;
+    return '\ufffd';
   }
-}); // Pluck off n bytes from an array of buffers.
-// Length is the combined lengths of all the buffers in the list.
-// This function is designed to be inlinable, so please take care when making
-// changes to the function body.
-
-function fromList(n, state) {
-  // nothing buffered
-  if (state.length === 0) return null;
-  var ret;
-  if (state.objectMode) ret = state.buffer.shift();else if (!n || n >= state.length) {
-    // read it all, truncate the list
-    if (state.decoder) ret = state.buffer.join('');else if (state.buffer.length === 1) ret = state.buffer.first();else ret = state.buffer.concat(state.length);
-    state.buffer.clear();
-  } else {
-    // read part of list
-    ret = state.buffer.consume(n, state.decoder);
+  if (self.lastNeed > 1 && buf.length > 1) {
+    if ((buf[1] & 0xC0) !== 0x80) {
+      self.lastNeed = 1;
+      return '\ufffd';
+    }
+    if (self.lastNeed > 2 && buf.length > 2) {
+      if ((buf[2] & 0xC0) !== 0x80) {
+        self.lastNeed = 2;
+        return '\ufffd';
+      }
+    }
   }
-  return ret;
 }
 
-function endReadable(stream) {
-  var state = stream._readableState;
-  debug('endReadable', state.endEmitted);
-
-  if (!state.endEmitted) {
-    state.ended = true;
-    process.nextTick(endReadableNT, state, stream);
+// Attempts to complete a multi-byte UTF-8 character using bytes from a Buffer.
+function utf8FillLast(buf) {
+  var p = this.lastTotal - this.lastNeed;
+  var r = utf8CheckExtraBytes(this, buf, p);
+  if (r !== undefined) return r;
+  if (this.lastNeed <= buf.length) {
+    buf.copy(this.lastChar, p, 0, this.lastNeed);
+    return this.lastChar.toString(this.encoding, 0, this.lastTotal);
   }
+  buf.copy(this.lastChar, p, 0, buf.length);
+  this.lastNeed -= buf.length;
 }
 
-function endReadableNT(state, stream) {
-  debug('endReadableNT', state.endEmitted, state.length); // Check that we didn't get one last unshift.
-
-  if (!state.endEmitted && state.length === 0) {
-    state.endEmitted = true;
-    stream.readable = false;
-    stream.emit('end');
+// Returns all complete UTF-8 characters in a Buffer. If the Buffer ended on a
+// partial character, the character's bytes are buffered until the required
+// number of bytes are available.
+function utf8Text(buf, i) {
+  var total = utf8CheckIncomplete(this, buf, i);
+  if (!this.lastNeed) return buf.toString('utf8', i);
+  this.lastTotal = total;
+  var end = buf.length - (total - this.lastNeed);
+  buf.copy(this.lastChar, 0, end);
+  return buf.toString('utf8', i, end);
+}
 
-    if (state.autoDestroy) {
-      // In case of duplex streams we need a way to detect
-      // if the writable side is ready for autoDestroy as well
-      var wState = stream._writableState;
+// For UTF-8, a replacement character is added when ending on a partial
+// character.
+function utf8End(buf) {
+  var r = buf && buf.length ? this.write(buf) : '';
+  if (this.lastNeed) return r + '\ufffd';
+  return r;
+}
 
-      if (!wState || wState.autoDestroy && wState.finished) {
-        stream.destroy();
+// UTF-16LE typically needs two bytes per character, but even if we have an even
+// number of bytes available, we need to check if we end on a leading/high
+// surrogate. In that case, we need to wait for the next two bytes in order to
+// decode the last character properly.
+function utf16Text(buf, i) {
+  if ((buf.length - i) % 2 === 0) {
+    var r = buf.toString('utf16le', i);
+    if (r) {
+      var c = r.charCodeAt(r.length - 1);
+      if (c >= 0xD800 && c <= 0xDBFF) {
+        this.lastNeed = 2;
+        this.lastTotal = 4;
+        this.lastChar[0] = buf[buf.length - 2];
+        this.lastChar[1] = buf[buf.length - 1];
+        return r.slice(0, -1);
       }
     }
+    return r;
   }
+  this.lastNeed = 1;
+  this.lastTotal = 2;
+  this.lastChar[0] = buf[buf.length - 1];
+  return buf.toString('utf16le', i, buf.length - 1);
 }
 
-if (typeof Symbol === 'function') {
-  Readable.from = function (iterable, opts) {
-    if (from === undefined) {
-      from = __nccwpck_require__(23919);
-    }
-
-    return from(Readable, iterable, opts);
-  };
+// For UTF-16LE we do not explicitly append special replacement characters if we
+// end on a partial character, we simply let v8 handle that.
+function utf16End(buf) {
+  var r = buf && buf.length ? this.write(buf) : '';
+  if (this.lastNeed) {
+    var end = this.lastTotal - this.lastNeed;
+    return r + this.lastChar.toString('utf16le', 0, end);
+  }
+  return r;
 }
 
-function indexOf(xs, x) {
-  for (var i = 0, l = xs.length; i < l; i++) {
-    if (xs[i] === x) return i;
+function base64Text(buf, i) {
+  var n = (buf.length - i) % 3;
+  if (n === 0) return buf.toString('base64', i);
+  this.lastNeed = 3 - n;
+  this.lastTotal = 3;
+  if (n === 1) {
+    this.lastChar[0] = buf[buf.length - 1];
+  } else {
+    this.lastChar[0] = buf[buf.length - 2];
+    this.lastChar[1] = buf[buf.length - 1];
   }
+  return buf.toString('base64', i, buf.length - n);
+}
 
-  return -1;
+function base64End(buf) {
+  var r = buf && buf.length ? this.write(buf) : '';
+  if (this.lastNeed) return r + this.lastChar.toString('base64', 0, 3 - this.lastNeed);
+  return r;
+}
+
+// Pass bytes on through for single-byte encodings (e.g. ascii, latin1, hex)
+function simpleWrite(buf) {
+  return buf.toString(this.encoding);
+}
+
+function simpleEnd(buf) {
+  return buf && buf.length ? this.write(buf) : '';
 }
 
 /***/ }),
 
-/***/ 660:
+/***/ 74817:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
-// Copyright Joyent, Inc. and other Node contributors.
-//
-// 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.
-// a transform stream is a readable/writable stream where you do
-// something with the data.  Sometimes it's called a "filter",
-// but that's not a great name for it, since that implies a thing where
-// some bits pass through, and others are simply ignored.  (That would
-// be a valid example of a transform, of course.)
-//
-// While the output is causally related to the input, it's not a
-// necessarily symmetric or synchronous transformation.  For example,
-// a zlib stream might take multiple plain-text writes(), and then
-// emit a single compressed chunk some time in the future.
-//
-// Here's how this works:
-//
-// The Transform stream has all the aspects of the readable and writable
-// stream classes.  When you write(chunk), that calls _write(chunk,cb)
-// internally, and returns false if there's a lot of pending writes
-// buffered up.  When you call read(), that calls _read(n) until
-// there's enough pending readable data buffered up.
-//
-// In a transform stream, the written data is placed in a buffer.  When
-// _read(n) is called, it transforms the queued up data, calling the
-// buffered _write cb's as it consumes chunks.  If consuming a single
-// written chunk would result in multiple output chunks, then the first
-// outputted bit calls the readcb, and subsequent chunks just go into
-// the read buffer, and will cause it to emit 'readable' if necessary.
-//
-// This way, back-pressure is actually determined by the reading side,
-// since _read has to be called to start processing a new chunk.  However,
-// a pathological inflate type of transform can cause excessive buffering
-// here.  For example, imagine a stream where every byte of input is
-// interpreted as an integer from 0-255, and then results in that many
-// bytes of output.  Writing the 4 bytes {ff,ff,ff,ff} would result in
-// 1kb of data being output.  In this case, you could write a very small
-// amount of input, and end up with a very large amount of output.  In
-// such a pathological inflating mechanism, there'd be no way to tell
-// the system to stop doing the transform.  A single 4MB write could
-// cause the system to run out of memory.
-//
-// However, even in such a pathological case, only a single written chunk
-// would be consumed, and then the rest would wait (un-transformed) until
-// the results of the previous transformed chunk were consumed.
 
+const ansiRegex = __nccwpck_require__(3824);
 
-module.exports = Transform;
+module.exports = string => typeof string === 'string' ? string.replace(ansiRegex(), '') : string;
 
-var _require$codes = (__nccwpck_require__(91042)/* .codes */ .q),
-    ERR_METHOD_NOT_IMPLEMENTED = _require$codes.ERR_METHOD_NOT_IMPLEMENTED,
-    ERR_MULTIPLE_CALLBACK = _require$codes.ERR_MULTIPLE_CALLBACK,
-    ERR_TRANSFORM_ALREADY_TRANSFORMING = _require$codes.ERR_TRANSFORM_ALREADY_TRANSFORMING,
-    ERR_TRANSFORM_WITH_LENGTH_0 = _require$codes.ERR_TRANSFORM_WITH_LENGTH_0;
 
-var Duplex = __nccwpck_require__(25408);
+/***/ }),
 
-__nccwpck_require__(2868)(Transform, Duplex);
+/***/ 3824:
+/***/ ((module) => {
 
-function afterTransform(er, data) {
-  var ts = this._transformState;
-  ts.transforming = false;
-  var cb = ts.writecb;
+"use strict";
 
-  if (cb === null) {
-    return this.emit('error', new ERR_MULTIPLE_CALLBACK());
-  }
 
-  ts.writechunk = null;
-  ts.writecb = null;
-  if (data != null) // single equals check for both `null` and `undefined`
-    this.push(data);
-  cb(er);
-  var rs = this._readableState;
-  rs.reading = false;
+module.exports = ({onlyFirst = false} = {}) => {
+	const pattern = [
+		'[\\u001B\\u009B][[\\]()#;?]*(?:(?:(?:(?:;[-a-zA-Z\\d\\/#&.:=?%@~_]+)*|[a-zA-Z\\d]+(?:;[-a-zA-Z\\d\\/#&.:=?%@~_]*)*)?\\u0007)',
+		'(?:(?:\\d{1,4}(?:;\\d{0,4})*)?[\\dA-PR-TZcf-ntqry=><~]))'
+	].join('|');
 
-  if (rs.needReadable || rs.length < rs.highWaterMark) {
-    this._read(rs.highWaterMark);
-  }
-}
+	return new RegExp(pattern, onlyFirst ? undefined : 'g');
+};
 
-function Transform(options) {
-  if (!(this instanceof Transform)) return new Transform(options);
-  Duplex.call(this, options);
-  this._transformState = {
-    afterTransform: afterTransform.bind(this),
-    needTransform: false,
-    transforming: false,
-    writecb: null,
-    writechunk: null,
-    writeencoding: null
-  }; // start out asking for a readable event once data is transformed.
 
-  this._readableState.needReadable = true; // we have implemented the _read method, and done the other things
-  // that Readable wants before the first _read call, so unset the
-  // sync guard flag.
+/***/ }),
 
-  this._readableState.sync = false;
+/***/ 26080:
+/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
-  if (options) {
-    if (typeof options.transform === 'function') this._transform = options.transform;
-    if (typeof options.flush === 'function') this._flush = options.flush;
-  } // When the writable side finishes, then flush out anything remaining.
+"use strict";
+
+const os = __nccwpck_require__(22037);
+const hasFlag = __nccwpck_require__(54402);
 
+const env = process.env;
 
-  this.on('prefinish', prefinish);
+let forceColor;
+if (hasFlag('no-color') ||
+	hasFlag('no-colors') ||
+	hasFlag('color=false')) {
+	forceColor = false;
+} else if (hasFlag('color') ||
+	hasFlag('colors') ||
+	hasFlag('color=true') ||
+	hasFlag('color=always')) {
+	forceColor = true;
+}
+if ('FORCE_COLOR' in env) {
+	forceColor = env.FORCE_COLOR.length === 0 || parseInt(env.FORCE_COLOR, 10) !== 0;
 }
 
-function prefinish() {
-  var _this = this;
+function translateLevel(level) {
+	if (level === 0) {
+		return false;
+	}
 
-  if (typeof this._flush === 'function' && !this._readableState.destroyed) {
-    this._flush(function (er, data) {
-      done(_this, er, data);
-    });
-  } else {
-    done(this, null, null);
-  }
+	return {
+		level,
+		hasBasic: true,
+		has256: level >= 2,
+		has16m: level >= 3
+	};
 }
 
-Transform.prototype.push = function (chunk, encoding) {
-  this._transformState.needTransform = false;
-  return Duplex.prototype.push.call(this, chunk, encoding);
-}; // This is the part where you do stuff!
-// override this function in implementation classes.
-// 'chunk' is an input chunk.
-//
-// Call `push(newChunk)` to pass along transformed output
-// to the readable side.  You may call 'push' zero or more times.
-//
-// Call `cb(err)` when you are done with this chunk.  If you pass
-// an error, then that'll put the hurt on the whole operation.  If you
-// never call cb(), then you'll never get another chunk.
+function supportsColor(stream) {
+	if (forceColor === false) {
+		return 0;
+	}
 
+	if (hasFlag('color=16m') ||
+		hasFlag('color=full') ||
+		hasFlag('color=truecolor')) {
+		return 3;
+	}
 
-Transform.prototype._transform = function (chunk, encoding, cb) {
-  cb(new ERR_METHOD_NOT_IMPLEMENTED('_transform()'));
-};
+	if (hasFlag('color=256')) {
+		return 2;
+	}
 
-Transform.prototype._write = function (chunk, encoding, cb) {
-  var ts = this._transformState;
-  ts.writecb = cb;
-  ts.writechunk = chunk;
-  ts.writeencoding = encoding;
+	if (stream && !stream.isTTY && forceColor !== true) {
+		return 0;
+	}
 
-  if (!ts.transforming) {
-    var rs = this._readableState;
-    if (ts.needTransform || rs.needReadable || rs.length < rs.highWaterMark) this._read(rs.highWaterMark);
-  }
-}; // Doesn't matter what the args are here.
-// _transform does all the work.
-// That we got here means that the readable side wants more data.
+	const min = forceColor ? 1 : 0;
 
+	if (process.platform === 'win32') {
+		// Node.js 7.5.0 is the first version of Node.js to include a patch to
+		// libuv that enables 256 color output on Windows. Anything earlier and it
+		// won't work. However, here we target Node.js 8 at minimum as it is an LTS
+		// release, and Node.js 7 is not. Windows 10 build 10586 is the first Windows
+		// release that supports 256 colors. Windows 10 build 14931 is the first release
+		// that supports 16m/TrueColor.
+		const osRelease = os.release().split('.');
+		if (
+			Number(process.versions.node.split('.')[0]) >= 8 &&
+			Number(osRelease[0]) >= 10 &&
+			Number(osRelease[2]) >= 10586
+		) {
+			return Number(osRelease[2]) >= 14931 ? 3 : 2;
+		}
 
-Transform.prototype._read = function (n) {
-  var ts = this._transformState;
+		return 1;
+	}
 
-  if (ts.writechunk !== null && !ts.transforming) {
-    ts.transforming = true;
+	if ('CI' in env) {
+		if (['TRAVIS', 'CIRCLECI', 'APPVEYOR', 'GITLAB_CI'].some(sign => sign in env) || env.CI_NAME === 'codeship') {
+			return 1;
+		}
 
-    this._transform(ts.writechunk, ts.writeencoding, ts.afterTransform);
-  } else {
-    // mark that we need a transform, so that any data that comes in
-    // will get processed, now that we've asked for it.
-    ts.needTransform = true;
-  }
-};
+		return min;
+	}
 
-Transform.prototype._destroy = function (err, cb) {
-  Duplex.prototype._destroy.call(this, err, function (err2) {
-    cb(err2);
-  });
-};
+	if ('TEAMCITY_VERSION' in env) {
+		return /^(9\.(0*[1-9]\d*)\.|\d{2,}\.)/.test(env.TEAMCITY_VERSION) ? 1 : 0;
+	}
 
-function done(stream, er, data) {
-  if (er) return stream.emit('error', er);
-  if (data != null) // single equals check for both `null` and `undefined`
-    stream.push(data); // TODO(BridgeAR): Write a test for these two error cases
-  // if there's nothing in the write buffer, then that means
-  // that nothing more will ever be provided
+	if (env.COLORTERM === 'truecolor') {
+		return 3;
+	}
 
-  if (stream._writableState.length) throw new ERR_TRANSFORM_WITH_LENGTH_0();
-  if (stream._transformState.transforming) throw new ERR_TRANSFORM_ALREADY_TRANSFORMING();
-  return stream.push(null);
-}
+	if ('TERM_PROGRAM' in env) {
+		const version = parseInt((env.TERM_PROGRAM_VERSION || '').split('.')[0], 10);
 
-/***/ }),
+		switch (env.TERM_PROGRAM) {
+			case 'iTerm.app':
+				return version >= 3 ? 3 : 2;
+			case 'Apple_Terminal':
+				return 2;
+			// No default
+		}
+	}
 
-/***/ 51898:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+	if (/-256(color)?$/i.test(env.TERM)) {
+		return 2;
+	}
 
-"use strict";
-// Copyright Joyent, Inc. and other Node contributors.
-//
-// 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.
-// A bit simpler than readable streams.
-// Implement an async ._write(chunk, encoding, cb), and it'll handle all
-// the drain event emission and buffering.
+	if (/^screen|^xterm|^vt100|^vt220|^rxvt|color|ansi|cygwin|linux/i.test(env.TERM)) {
+		return 1;
+	}
 
+	if ('COLORTERM' in env) {
+		return 1;
+	}
 
-module.exports = Writable;
-/*  */
+	if (env.TERM === 'dumb') {
+		return min;
+	}
 
-function WriteReq(chunk, encoding, cb) {
-  this.chunk = chunk;
-  this.encoding = encoding;
-  this.callback = cb;
-  this.next = null;
-} // It seems a linked list but it is not
-// there will be only 2 of these for each stream
+	return min;
+}
 
+function getSupportLevel(stream) {
+	const level = supportsColor(stream);
+	return translateLevel(level);
+}
 
-function CorkedRequest(state) {
-  var _this = this;
+module.exports = {
+	supportsColor: getSupportLevel,
+	stdout: getSupportLevel(process.stdout),
+	stderr: getSupportLevel(process.stderr)
+};
 
-  this.next = null;
-  this.entry = null;
 
-  this.finish = function () {
-    onCorkedFinish(_this, state);
-  };
-}
-/*  */
+/***/ }),
 
-/**/
+/***/ 54402:
+/***/ ((module) => {
 
+"use strict";
 
-var Duplex;
-/**/
+module.exports = (flag, argv) => {
+	argv = argv || process.argv;
+	const prefix = flag.startsWith('-') ? '' : (flag.length === 1 ? '-' : '--');
+	const pos = argv.indexOf(prefix + flag);
+	const terminatorPos = argv.indexOf('--');
+	return pos !== -1 && (terminatorPos === -1 ? true : pos < terminatorPos);
+};
 
-Writable.WritableState = WritableState;
-/**/
 
-var internalUtil = {
-  deprecate: __nccwpck_require__(40538)
-};
-/**/
+/***/ }),
 
-/**/
+/***/ 91674:
+/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
-var Stream = __nccwpck_require__(4297);
-/**/
+var util = __nccwpck_require__(73837)
+var bl = __nccwpck_require__(82489)
+var headers = __nccwpck_require__(53350)
 
+var Writable = (__nccwpck_require__(17067).Writable)
+var PassThrough = (__nccwpck_require__(17067).PassThrough)
 
-var Buffer = (__nccwpck_require__(14300).Buffer);
+var noop = function () {}
 
-var OurUint8Array = global.Uint8Array || function () {};
+var overflow = function (size) {
+  size &= 511
+  return size && 512 - size
+}
 
-function _uint8ArrayToBuffer(chunk) {
-  return Buffer.from(chunk);
+var emptyStream = function (self, offset) {
+  var s = new Source(self, offset)
+  s.end()
+  return s
 }
 
-function _isUint8Array(obj) {
-  return Buffer.isBuffer(obj) || obj instanceof OurUint8Array;
+var mixinPax = function (header, pax) {
+  if (pax.path) header.name = pax.path
+  if (pax.linkpath) header.linkname = pax.linkpath
+  if (pax.size) header.size = parseInt(pax.size, 10)
+  header.pax = pax
+  return header
 }
 
-var destroyImpl = __nccwpck_require__(70079);
+var Source = function (self, offset) {
+  this._parent = self
+  this.offset = offset
+  PassThrough.call(this, { autoDestroy: false })
+}
 
-var _require = __nccwpck_require__(97458),
-    getHighWaterMark = _require.getHighWaterMark;
+util.inherits(Source, PassThrough)
 
-var _require$codes = (__nccwpck_require__(91042)/* .codes */ .q),
-    ERR_INVALID_ARG_TYPE = _require$codes.ERR_INVALID_ARG_TYPE,
-    ERR_METHOD_NOT_IMPLEMENTED = _require$codes.ERR_METHOD_NOT_IMPLEMENTED,
-    ERR_MULTIPLE_CALLBACK = _require$codes.ERR_MULTIPLE_CALLBACK,
-    ERR_STREAM_CANNOT_PIPE = _require$codes.ERR_STREAM_CANNOT_PIPE,
-    ERR_STREAM_DESTROYED = _require$codes.ERR_STREAM_DESTROYED,
-    ERR_STREAM_NULL_VALUES = _require$codes.ERR_STREAM_NULL_VALUES,
-    ERR_STREAM_WRITE_AFTER_END = _require$codes.ERR_STREAM_WRITE_AFTER_END,
-    ERR_UNKNOWN_ENCODING = _require$codes.ERR_UNKNOWN_ENCODING;
+Source.prototype.destroy = function (err) {
+  this._parent.destroy(err)
+}
 
-var errorOrDestroy = destroyImpl.errorOrDestroy;
+var Extract = function (opts) {
+  if (!(this instanceof Extract)) return new Extract(opts)
+  Writable.call(this, opts)
 
-__nccwpck_require__(2868)(Writable, Stream);
+  opts = opts || {}
 
-function nop() {}
+  this._offset = 0
+  this._buffer = bl()
+  this._missing = 0
+  this._partial = false
+  this._onparse = noop
+  this._header = null
+  this._stream = null
+  this._overflow = null
+  this._cb = null
+  this._locked = false
+  this._destroyed = false
+  this._pax = null
+  this._paxGlobal = null
+  this._gnuLongPath = null
+  this._gnuLongLinkPath = null
 
-function WritableState(options, stream, isDuplex) {
-  Duplex = Duplex || __nccwpck_require__(25408);
-  options = options || {}; // Duplex streams are both readable and writable, but share
-  // the same options object.
-  // However, some cases require setting options to different
-  // values for the readable and the writable sides of the duplex stream,
-  // e.g. options.readableObjectMode vs. options.writableObjectMode, etc.
+  var self = this
+  var b = self._buffer
 
-  if (typeof isDuplex !== 'boolean') isDuplex = stream instanceof Duplex; // object stream flag to indicate whether or not this stream
-  // contains buffers or objects.
+  var oncontinue = function () {
+    self._continue()
+  }
 
-  this.objectMode = !!options.objectMode;
-  if (isDuplex) this.objectMode = this.objectMode || !!options.writableObjectMode; // the point at which write() starts returning false
-  // Note: 0 is a valid value, means that we always return false if
-  // the entire buffer is not flushed immediately on write()
+  var onunlock = function (err) {
+    self._locked = false
+    if (err) return self.destroy(err)
+    if (!self._stream) oncontinue()
+  }
 
-  this.highWaterMark = getHighWaterMark(this, options, 'writableHighWaterMark', isDuplex); // if _final has been called
+  var onstreamend = function () {
+    self._stream = null
+    var drain = overflow(self._header.size)
+    if (drain) self._parse(drain, ondrain)
+    else self._parse(512, onheader)
+    if (!self._locked) oncontinue()
+  }
 
-  this.finalCalled = false; // drain event flag.
+  var ondrain = function () {
+    self._buffer.consume(overflow(self._header.size))
+    self._parse(512, onheader)
+    oncontinue()
+  }
 
-  this.needDrain = false; // at the start of calling end()
+  var onpaxglobalheader = function () {
+    var size = self._header.size
+    self._paxGlobal = headers.decodePax(b.slice(0, size))
+    b.consume(size)
+    onstreamend()
+  }
 
-  this.ending = false; // when end() has been called, and returned
+  var onpaxheader = function () {
+    var size = self._header.size
+    self._pax = headers.decodePax(b.slice(0, size))
+    if (self._paxGlobal) self._pax = Object.assign({}, self._paxGlobal, self._pax)
+    b.consume(size)
+    onstreamend()
+  }
 
-  this.ended = false; // when 'finish' is emitted
+  var ongnulongpath = function () {
+    var size = self._header.size
+    this._gnuLongPath = headers.decodeLongPath(b.slice(0, size), opts.filenameEncoding)
+    b.consume(size)
+    onstreamend()
+  }
 
-  this.finished = false; // has it been destroyed
+  var ongnulonglinkpath = function () {
+    var size = self._header.size
+    this._gnuLongLinkPath = headers.decodeLongPath(b.slice(0, size), opts.filenameEncoding)
+    b.consume(size)
+    onstreamend()
+  }
 
-  this.destroyed = false; // should we decode strings into buffers before passing to _write?
-  // this is here so that some node-core streams can optimize string
-  // handling at a lower level.
+  var onheader = function () {
+    var offset = self._offset
+    var header
+    try {
+      header = self._header = headers.decode(b.slice(0, 512), opts.filenameEncoding, opts.allowUnknownFormat)
+    } catch (err) {
+      self.emit('error', err)
+    }
+    b.consume(512)
 
-  var noDecode = options.decodeStrings === false;
-  this.decodeStrings = !noDecode; // Crypto is kind of old and crusty.  Historically, its default string
-  // encoding is 'binary' so we have to make this configurable.
-  // Everything else in the universe uses 'utf8', though.
+    if (!header) {
+      self._parse(512, onheader)
+      oncontinue()
+      return
+    }
+    if (header.type === 'gnu-long-path') {
+      self._parse(header.size, ongnulongpath)
+      oncontinue()
+      return
+    }
+    if (header.type === 'gnu-long-link-path') {
+      self._parse(header.size, ongnulonglinkpath)
+      oncontinue()
+      return
+    }
+    if (header.type === 'pax-global-header') {
+      self._parse(header.size, onpaxglobalheader)
+      oncontinue()
+      return
+    }
+    if (header.type === 'pax-header') {
+      self._parse(header.size, onpaxheader)
+      oncontinue()
+      return
+    }
 
-  this.defaultEncoding = options.defaultEncoding || 'utf8'; // not an actual buffer we keep track of, but a measurement
-  // of how much we're waiting to get pushed to some underlying
-  // socket or file.
+    if (self._gnuLongPath) {
+      header.name = self._gnuLongPath
+      self._gnuLongPath = null
+    }
 
-  this.length = 0; // a flag to see when we're in the middle of a write.
+    if (self._gnuLongLinkPath) {
+      header.linkname = self._gnuLongLinkPath
+      self._gnuLongLinkPath = null
+    }
 
-  this.writing = false; // when true all writes will be buffered until .uncork() call
+    if (self._pax) {
+      self._header = header = mixinPax(header, self._pax)
+      self._pax = null
+    }
 
-  this.corked = 0; // a flag to be able to tell if the onwrite cb is called immediately,
-  // or on a later tick.  We set this to true at first, because any
-  // actions that shouldn't happen until "later" should generally also
-  // not happen before the first write call.
+    self._locked = true
 
-  this.sync = true; // a flag to know if we're processing previously buffered items, which
-  // may call the _write() callback in the same tick, so that we don't
-  // end up in an overlapped onwrite situation.
+    if (!header.size || header.type === 'directory') {
+      self._parse(512, onheader)
+      self.emit('entry', header, emptyStream(self, offset), onunlock)
+      return
+    }
 
-  this.bufferProcessing = false; // the callback that's passed to _write(chunk,cb)
+    self._stream = new Source(self, offset)
 
-  this.onwrite = function (er) {
-    onwrite(stream, er);
-  }; // the callback that the user supplies to write(chunk,encoding,cb)
+    self.emit('entry', header, self._stream, onunlock)
+    self._parse(header.size, onstreamend)
+    oncontinue()
+  }
 
+  this._onheader = onheader
+  this._parse(512, onheader)
+}
 
-  this.writecb = null; // the amount that is being written when _write is called.
-
-  this.writelen = 0;
-  this.bufferedRequest = null;
-  this.lastBufferedRequest = null; // number of pending user-supplied write callbacks
-  // this must be 0 before 'finish' can be emitted
-
-  this.pendingcb = 0; // emit prefinish if the only thing we're waiting for is _write cbs
-  // This is relevant for synchronous Transform streams
+util.inherits(Extract, Writable)
 
-  this.prefinished = false; // True if the error was already emitted and should not be thrown again
+Extract.prototype.destroy = function (err) {
+  if (this._destroyed) return
+  this._destroyed = true
 
-  this.errorEmitted = false; // Should close be emitted on destroy. Defaults to true.
+  if (err) this.emit('error', err)
+  this.emit('close')
+  if (this._stream) this._stream.emit('close')
+}
 
-  this.emitClose = options.emitClose !== false; // Should .destroy() be called after 'finish' (and potentially 'end')
+Extract.prototype._parse = function (size, onparse) {
+  if (this._destroyed) return
+  this._offset += size
+  this._missing = size
+  if (onparse === this._onheader) this._partial = false
+  this._onparse = onparse
+}
 
-  this.autoDestroy = !!options.autoDestroy; // count buffered requests
+Extract.prototype._continue = function () {
+  if (this._destroyed) return
+  var cb = this._cb
+  this._cb = noop
+  if (this._overflow) this._write(this._overflow, undefined, cb)
+  else cb()
+}
 
-  this.bufferedRequestCount = 0; // allocate the first CorkedRequest, there is always
-  // one allocated and free to use, and we maintain at most two
+Extract.prototype._write = function (data, enc, cb) {
+  if (this._destroyed) return
 
-  this.corkedRequestsFree = new CorkedRequest(this);
-}
+  var s = this._stream
+  var b = this._buffer
+  var missing = this._missing
+  if (data.length) this._partial = true
 
-WritableState.prototype.getBuffer = function getBuffer() {
-  var current = this.bufferedRequest;
-  var out = [];
+  // we do not reach end-of-chunk now. just forward it
 
-  while (current) {
-    out.push(current);
-    current = current.next;
+  if (data.length < missing) {
+    this._missing -= data.length
+    this._overflow = null
+    if (s) return s.write(data, cb)
+    b.append(data)
+    return cb()
   }
 
-  return out;
-};
+  // end-of-chunk. the parser should call cb.
 
-(function () {
-  try {
-    Object.defineProperty(WritableState.prototype, 'buffer', {
-      get: internalUtil.deprecate(function writableStateBufferGetter() {
-        return this.getBuffer();
-      }, '_writableState.buffer is deprecated. Use _writableState.getBuffer ' + 'instead.', 'DEP0003')
-    });
-  } catch (_) {}
-})(); // Test _writableState for inheritance to account for Duplex streams,
-// whose prototype chain only points to Readable.
+  this._cb = cb
+  this._missing = 0
 
+  var overflow = null
+  if (data.length > missing) {
+    overflow = data.slice(missing)
+    data = data.slice(0, missing)
+  }
 
-var realHasInstance;
+  if (s) s.end(data)
+  else b.append(data)
 
-if (typeof Symbol === 'function' && Symbol.hasInstance && typeof Function.prototype[Symbol.hasInstance] === 'function') {
-  realHasInstance = Function.prototype[Symbol.hasInstance];
-  Object.defineProperty(Writable, Symbol.hasInstance, {
-    value: function value(object) {
-      if (realHasInstance.call(this, object)) return true;
-      if (this !== Writable) return false;
-      return object && object._writableState instanceof WritableState;
-    }
-  });
-} else {
-  realHasInstance = function realHasInstance(object) {
-    return object instanceof this;
-  };
+  this._overflow = overflow
+  this._onparse()
 }
 
-function Writable(options) {
-  Duplex = Duplex || __nccwpck_require__(25408); // Writable ctor is applied to Duplexes, too.
-  // `realHasInstance` is necessary because using plain `instanceof`
-  // would return false, as no `_writableState` property is attached.
-  // Trying to use the custom `instanceof` for Writable here will also break the
-  // Node.js LazyTransform implementation, which has a non-trivial getter for
-  // `_writableState` that would lead to infinite recursion.
-  // Checking for a Stream.Duplex instance is faster here instead of inside
-  // the WritableState constructor, at least with V8 6.5
-
-  var isDuplex = this instanceof Duplex;
-  if (!isDuplex && !realHasInstance.call(Writable, this)) return new Writable(options);
-  this._writableState = new WritableState(options, this, isDuplex); // legacy.
+Extract.prototype._final = function (cb) {
+  if (this._partial) return this.destroy(new Error('Unexpected end of data'))
+  cb()
+}
 
-  this.writable = true;
+module.exports = Extract
 
-  if (options) {
-    if (typeof options.write === 'function') this._write = options.write;
-    if (typeof options.writev === 'function') this._writev = options.writev;
-    if (typeof options.destroy === 'function') this._destroy = options.destroy;
-    if (typeof options.final === 'function') this._final = options.final;
-  }
 
-  Stream.call(this);
-} // Otherwise people can pipe Writable streams, which is just wrong.
+/***/ }),
 
+/***/ 53350:
+/***/ ((__unused_webpack_module, exports) => {
 
-Writable.prototype.pipe = function () {
-  errorOrDestroy(this, new ERR_STREAM_CANNOT_PIPE());
-};
+var alloc = Buffer.alloc
 
-function writeAfterEnd(stream, cb) {
-  var er = new ERR_STREAM_WRITE_AFTER_END(); // TODO: defer error events consistently everywhere, not just the cb
+var ZEROS = '0000000000000000000'
+var SEVENS = '7777777777777777777'
+var ZERO_OFFSET = '0'.charCodeAt(0)
+var USTAR_MAGIC = Buffer.from('ustar\x00', 'binary')
+var USTAR_VER = Buffer.from('00', 'binary')
+var GNU_MAGIC = Buffer.from('ustar\x20', 'binary')
+var GNU_VER = Buffer.from('\x20\x00', 'binary')
+var MASK = parseInt('7777', 8)
+var MAGIC_OFFSET = 257
+var VERSION_OFFSET = 263
 
-  errorOrDestroy(stream, er);
-  process.nextTick(cb, er);
-} // Checks that a user-supplied chunk is valid, especially for the particular
-// mode the stream is in. Currently this means that `null` is never accepted
-// and undefined/non-string values are only allowed in object mode.
+var clamp = function (index, len, defaultValue) {
+  if (typeof index !== 'number') return defaultValue
+  index = ~~index // Coerce to integer.
+  if (index >= len) return len
+  if (index >= 0) return index
+  index += len
+  if (index >= 0) return index
+  return 0
+}
 
+var toType = function (flag) {
+  switch (flag) {
+    case 0:
+      return 'file'
+    case 1:
+      return 'link'
+    case 2:
+      return 'symlink'
+    case 3:
+      return 'character-device'
+    case 4:
+      return 'block-device'
+    case 5:
+      return 'directory'
+    case 6:
+      return 'fifo'
+    case 7:
+      return 'contiguous-file'
+    case 72:
+      return 'pax-header'
+    case 55:
+      return 'pax-global-header'
+    case 27:
+      return 'gnu-long-link-path'
+    case 28:
+    case 30:
+      return 'gnu-long-path'
+  }
 
-function validChunk(stream, state, chunk, cb) {
-  var er;
+  return null
+}
 
-  if (chunk === null) {
-    er = new ERR_STREAM_NULL_VALUES();
-  } else if (typeof chunk !== 'string' && !state.objectMode) {
-    er = new ERR_INVALID_ARG_TYPE('chunk', ['string', 'Buffer'], chunk);
+var toTypeflag = function (flag) {
+  switch (flag) {
+    case 'file':
+      return 0
+    case 'link':
+      return 1
+    case 'symlink':
+      return 2
+    case 'character-device':
+      return 3
+    case 'block-device':
+      return 4
+    case 'directory':
+      return 5
+    case 'fifo':
+      return 6
+    case 'contiguous-file':
+      return 7
+    case 'pax-header':
+      return 72
   }
 
-  if (er) {
-    errorOrDestroy(stream, er);
-    process.nextTick(cb, er);
-    return false;
-  }
+  return 0
+}
 
-  return true;
+var indexOf = function (block, num, offset, end) {
+  for (; offset < end; offset++) {
+    if (block[offset] === num) return offset
+  }
+  return end
 }
 
-Writable.prototype.write = function (chunk, encoding, cb) {
-  var state = this._writableState;
-  var ret = false;
+var cksum = function (block) {
+  var sum = 8 * 32
+  for (var i = 0; i < 148; i++) sum += block[i]
+  for (var j = 156; j < 512; j++) sum += block[j]
+  return sum
+}
 
-  var isBuf = !state.objectMode && _isUint8Array(chunk);
+var encodeOct = function (val, n) {
+  val = val.toString(8)
+  if (val.length > n) return SEVENS.slice(0, n) + ' '
+  else return ZEROS.slice(0, n - val.length) + val + ' '
+}
 
-  if (isBuf && !Buffer.isBuffer(chunk)) {
-    chunk = _uint8ArrayToBuffer(chunk);
-  }
+/* Copied from the node-tar repo and modified to meet
+ * tar-stream coding standard.
+ *
+ * Source: https://github.com/npm/node-tar/blob/51b6627a1f357d2eb433e7378e5f05e83b7aa6cd/lib/header.js#L349
+ */
+function parse256 (buf) {
+  // first byte MUST be either 80 or FF
+  // 80 for positive, FF for 2's comp
+  var positive
+  if (buf[0] === 0x80) positive = true
+  else if (buf[0] === 0xFF) positive = false
+  else return null
 
-  if (typeof encoding === 'function') {
-    cb = encoding;
-    encoding = null;
+  // build up a base-256 tuple from the least sig to the highest
+  var tuple = []
+  for (var i = buf.length - 1; i > 0; i--) {
+    var byte = buf[i]
+    if (positive) tuple.push(byte)
+    else tuple.push(0xFF - byte)
   }
 
-  if (isBuf) encoding = 'buffer';else if (!encoding) encoding = state.defaultEncoding;
-  if (typeof cb !== 'function') cb = nop;
-  if (state.ending) writeAfterEnd(this, cb);else if (isBuf || validChunk(this, state, chunk, cb)) {
-    state.pendingcb++;
-    ret = writeOrBuffer(this, state, isBuf, chunk, encoding, cb);
+  var sum = 0
+  var l = tuple.length
+  for (i = 0; i < l; i++) {
+    sum += tuple[i] * Math.pow(256, i)
   }
-  return ret;
-};
 
-Writable.prototype.cork = function () {
-  this._writableState.corked++;
-};
+  return positive ? sum : -1 * sum
+}
 
-Writable.prototype.uncork = function () {
-  var state = this._writableState;
+var decodeOct = function (val, offset, length) {
+  val = val.slice(offset, offset + length)
+  offset = 0
 
-  if (state.corked) {
-    state.corked--;
-    if (!state.writing && !state.corked && !state.bufferProcessing && state.bufferedRequest) clearBuffer(this, state);
+  // If prefixed with 0x80 then parse as a base-256 integer
+  if (val[offset] & 0x80) {
+    return parse256(val)
+  } else {
+    // Older versions of tar can prefix with spaces
+    while (offset < val.length && val[offset] === 32) offset++
+    var end = clamp(indexOf(val, 32, offset, val.length), val.length, val.length)
+    while (offset < end && val[offset] === 0) offset++
+    if (end === offset) return 0
+    return parseInt(val.slice(offset, end).toString(), 8)
   }
-};
+}
 
-Writable.prototype.setDefaultEncoding = function setDefaultEncoding(encoding) {
-  // node::ParseEncoding() requires lower case.
-  if (typeof encoding === 'string') encoding = encoding.toLowerCase();
-  if (!(['hex', 'utf8', 'utf-8', 'ascii', 'binary', 'base64', 'ucs2', 'ucs-2', 'utf16le', 'utf-16le', 'raw'].indexOf((encoding + '').toLowerCase()) > -1)) throw new ERR_UNKNOWN_ENCODING(encoding);
-  this._writableState.defaultEncoding = encoding;
-  return this;
-};
+var decodeStr = function (val, offset, length, encoding) {
+  return val.slice(offset, indexOf(val, 0, offset, offset + length)).toString(encoding)
+}
 
-Object.defineProperty(Writable.prototype, 'writableBuffer', {
-  // making it explicit this property is not enumerable
-  // because otherwise some prototype manipulation in
-  // userland will fail
-  enumerable: false,
-  get: function get() {
-    return this._writableState && this._writableState.getBuffer();
-  }
-});
+var addLength = function (str) {
+  var len = Buffer.byteLength(str)
+  var digits = Math.floor(Math.log(len) / Math.log(10)) + 1
+  if (len + digits >= Math.pow(10, digits)) digits++
 
-function decodeChunk(state, chunk, encoding) {
-  if (!state.objectMode && state.decodeStrings !== false && typeof chunk === 'string') {
-    chunk = Buffer.from(chunk, encoding);
-  }
+  return (len + digits) + str
+}
 
-  return chunk;
+exports.decodeLongPath = function (buf, encoding) {
+  return decodeStr(buf, 0, buf.length, encoding)
 }
 
-Object.defineProperty(Writable.prototype, 'writableHighWaterMark', {
-  // making it explicit this property is not enumerable
-  // because otherwise some prototype manipulation in
-  // userland will fail
-  enumerable: false,
-  get: function get() {
-    return this._writableState.highWaterMark;
+exports.encodePax = function (opts) { // TODO: encode more stuff in pax
+  var result = ''
+  if (opts.name) result += addLength(' path=' + opts.name + '\n')
+  if (opts.linkname) result += addLength(' linkpath=' + opts.linkname + '\n')
+  var pax = opts.pax
+  if (pax) {
+    for (var key in pax) {
+      result += addLength(' ' + key + '=' + pax[key] + '\n')
+    }
   }
-}); // if we're already writing something, then just put this
-// in the queue, and wait our turn.  Otherwise, call _write
-// If we return false, then we need a drain event, so set that flag.
+  return Buffer.from(result)
+}
 
-function writeOrBuffer(stream, state, isBuf, chunk, encoding, cb) {
-  if (!isBuf) {
-    var newChunk = decodeChunk(state, chunk, encoding);
+exports.decodePax = function (buf) {
+  var result = {}
 
-    if (chunk !== newChunk) {
-      isBuf = true;
-      encoding = 'buffer';
-      chunk = newChunk;
-    }
-  }
+  while (buf.length) {
+    var i = 0
+    while (i < buf.length && buf[i] !== 32) i++
+    var len = parseInt(buf.slice(0, i).toString(), 10)
+    if (!len) return result
 
-  var len = state.objectMode ? 1 : chunk.length;
-  state.length += len;
-  var ret = state.length < state.highWaterMark; // we must ensure that previous needDrain will not be reset to false.
+    var b = buf.slice(i + 1, len - 1).toString()
+    var keyIndex = b.indexOf('=')
+    if (keyIndex === -1) return result
+    result[b.slice(0, keyIndex)] = b.slice(keyIndex + 1)
 
-  if (!ret) state.needDrain = true;
+    buf = buf.slice(len)
+  }
 
-  if (state.writing || state.corked) {
-    var last = state.lastBufferedRequest;
-    state.lastBufferedRequest = {
-      chunk: chunk,
-      encoding: encoding,
-      isBuf: isBuf,
-      callback: cb,
-      next: null
-    };
+  return result
+}
 
-    if (last) {
-      last.next = state.lastBufferedRequest;
-    } else {
-      state.bufferedRequest = state.lastBufferedRequest;
-    }
+exports.encode = function (opts) {
+  var buf = alloc(512)
+  var name = opts.name
+  var prefix = ''
 
-    state.bufferedRequestCount += 1;
-  } else {
-    doWrite(stream, state, false, len, chunk, encoding, cb);
+  if (opts.typeflag === 5 && name[name.length - 1] !== '/') name += '/'
+  if (Buffer.byteLength(name) !== name.length) return null // utf-8
+
+  while (Buffer.byteLength(name) > 100) {
+    var i = name.indexOf('/')
+    if (i === -1) return null
+    prefix += prefix ? '/' + name.slice(0, i) : name.slice(0, i)
+    name = name.slice(i + 1)
   }
 
-  return ret;
-}
+  if (Buffer.byteLength(name) > 100 || Buffer.byteLength(prefix) > 155) return null
+  if (opts.linkname && Buffer.byteLength(opts.linkname) > 100) return null
 
-function doWrite(stream, state, writev, len, chunk, encoding, cb) {
-  state.writelen = len;
-  state.writecb = cb;
-  state.writing = true;
-  state.sync = true;
-  if (state.destroyed) state.onwrite(new ERR_STREAM_DESTROYED('write'));else if (writev) stream._writev(chunk, state.onwrite);else stream._write(chunk, encoding, state.onwrite);
-  state.sync = false;
-}
+  buf.write(name)
+  buf.write(encodeOct(opts.mode & MASK, 6), 100)
+  buf.write(encodeOct(opts.uid, 6), 108)
+  buf.write(encodeOct(opts.gid, 6), 116)
+  buf.write(encodeOct(opts.size, 11), 124)
+  buf.write(encodeOct((opts.mtime.getTime() / 1000) | 0, 11), 136)
 
-function onwriteError(stream, state, sync, er, cb) {
-  --state.pendingcb;
+  buf[156] = ZERO_OFFSET + toTypeflag(opts.type)
 
-  if (sync) {
-    // defer the callback if we are being called synchronously
-    // to avoid piling up things on the stack
-    process.nextTick(cb, er); // this can emit finish, and it will always happen
-    // after error
+  if (opts.linkname) buf.write(opts.linkname, 157)
 
-    process.nextTick(finishMaybe, stream, state);
-    stream._writableState.errorEmitted = true;
-    errorOrDestroy(stream, er);
-  } else {
-    // the caller expect this to happen before if
-    // it is async
-    cb(er);
-    stream._writableState.errorEmitted = true;
-    errorOrDestroy(stream, er); // this can emit finish, but finish must
-    // always follow error
+  USTAR_MAGIC.copy(buf, MAGIC_OFFSET)
+  USTAR_VER.copy(buf, VERSION_OFFSET)
+  if (opts.uname) buf.write(opts.uname, 265)
+  if (opts.gname) buf.write(opts.gname, 297)
+  buf.write(encodeOct(opts.devmajor || 0, 6), 329)
+  buf.write(encodeOct(opts.devminor || 0, 6), 337)
 
-    finishMaybe(stream, state);
-  }
-}
+  if (prefix) buf.write(prefix, 345)
 
-function onwriteStateUpdate(state) {
-  state.writing = false;
-  state.writecb = null;
-  state.length -= state.writelen;
-  state.writelen = 0;
+  buf.write(encodeOct(cksum(buf), 6), 148)
+
+  return buf
 }
 
-function onwrite(stream, er) {
-  var state = stream._writableState;
-  var sync = state.sync;
-  var cb = state.writecb;
-  if (typeof cb !== 'function') throw new ERR_MULTIPLE_CALLBACK();
-  onwriteStateUpdate(state);
-  if (er) onwriteError(stream, state, sync, er, cb);else {
-    // Check if we're actually ready to finish, but don't emit yet
-    var finished = needFinish(state) || stream.destroyed;
+exports.decode = function (buf, filenameEncoding, allowUnknownFormat) {
+  var typeflag = buf[156] === 0 ? 0 : buf[156] - ZERO_OFFSET
 
-    if (!finished && !state.corked && !state.bufferProcessing && state.bufferedRequest) {
-      clearBuffer(stream, state);
-    }
+  var name = decodeStr(buf, 0, 100, filenameEncoding)
+  var mode = decodeOct(buf, 100, 8)
+  var uid = decodeOct(buf, 108, 8)
+  var gid = decodeOct(buf, 116, 8)
+  var size = decodeOct(buf, 124, 12)
+  var mtime = decodeOct(buf, 136, 12)
+  var type = toType(typeflag)
+  var linkname = buf[157] === 0 ? null : decodeStr(buf, 157, 100, filenameEncoding)
+  var uname = decodeStr(buf, 265, 32)
+  var gname = decodeStr(buf, 297, 32)
+  var devmajor = decodeOct(buf, 329, 8)
+  var devminor = decodeOct(buf, 337, 8)
 
-    if (sync) {
-      process.nextTick(afterWrite, stream, state, finished, cb);
-    } else {
-      afterWrite(stream, state, finished, cb);
+  var c = cksum(buf)
+
+  // checksum is still initial value if header was null.
+  if (c === 8 * 32) return null
+
+  // valid checksum
+  if (c !== decodeOct(buf, 148, 8)) throw new Error('Invalid tar header. Maybe the tar is corrupted or it needs to be gunzipped?')
+
+  if (USTAR_MAGIC.compare(buf, MAGIC_OFFSET, MAGIC_OFFSET + 6) === 0) {
+    // ustar (posix) format.
+    // prepend prefix, if present.
+    if (buf[345]) name = decodeStr(buf, 345, 155, filenameEncoding) + '/' + name
+  } else if (GNU_MAGIC.compare(buf, MAGIC_OFFSET, MAGIC_OFFSET + 6) === 0 &&
+             GNU_VER.compare(buf, VERSION_OFFSET, VERSION_OFFSET + 2) === 0) {
+    // 'gnu'/'oldgnu' format. Similar to ustar, but has support for incremental and
+    // multi-volume tarballs.
+  } else {
+    if (!allowUnknownFormat) {
+      throw new Error('Invalid tar header: unknown format.')
     }
   }
-}
-
-function afterWrite(stream, state, finished, cb) {
-  if (!finished) onwriteDrain(stream, state);
-  state.pendingcb--;
-  cb();
-  finishMaybe(stream, state);
-} // Must force callback to be called on nextTick, so that we don't
-// emit 'drain' before the write() consumer gets the 'false' return
-// value, and has a chance to attach a 'drain' listener.
 
+  // to support old tar versions that use trailing / to indicate dirs
+  if (typeflag === 0 && name && name[name.length - 1] === '/') typeflag = 5
 
-function onwriteDrain(stream, state) {
-  if (state.length === 0 && state.needDrain) {
-    state.needDrain = false;
-    stream.emit('drain');
+  return {
+    name,
+    mode,
+    uid,
+    gid,
+    size,
+    mtime: new Date(1000 * mtime),
+    type,
+    linkname,
+    uname,
+    gname,
+    devmajor,
+    devminor
   }
-} // if there's something in the buffer waiting, then process it
+}
 
 
-function clearBuffer(stream, state) {
-  state.bufferProcessing = true;
-  var entry = state.bufferedRequest;
+/***/ }),
 
-  if (stream._writev && entry && entry.next) {
-    // Fast case, write everything using _writev()
-    var l = state.bufferedRequestCount;
-    var buffer = new Array(l);
-    var holder = state.corkedRequestsFree;
-    holder.entry = entry;
-    var count = 0;
-    var allBuffers = true;
+/***/ 18571:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
-    while (entry) {
-      buffer[count] = entry;
-      if (!entry.isBuf) allBuffers = false;
-      entry = entry.next;
-      count += 1;
-    }
+exports.extract = __nccwpck_require__(91674)
+exports.pack = __nccwpck_require__(5080)
 
-    buffer.allBuffers = allBuffers;
-    doWrite(stream, state, true, state.length, buffer, '', holder.finish); // doWrite is almost always async, defer these to save a bit of time
-    // as the hot path ends with doWrite
 
-    state.pendingcb++;
-    state.lastBufferedRequest = null;
+/***/ }),
 
-    if (holder.next) {
-      state.corkedRequestsFree = holder.next;
-      holder.next = null;
-    } else {
-      state.corkedRequestsFree = new CorkedRequest(state);
-    }
+/***/ 5080:
+/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
-    state.bufferedRequestCount = 0;
-  } else {
-    // Slow case, write chunks one-by-one
-    while (entry) {
-      var chunk = entry.chunk;
-      var encoding = entry.encoding;
-      var cb = entry.callback;
-      var len = state.objectMode ? 1 : chunk.length;
-      doWrite(stream, state, false, len, chunk, encoding, cb);
-      entry = entry.next;
-      state.bufferedRequestCount--; // if we didn't call the onwrite immediately, then
-      // it means that we need to wait until it does.
-      // also, that means that the chunk and cb are currently
-      // being processed, so move the buffer counter past them.
+var constants = __nccwpck_require__(69026)
+var eos = __nccwpck_require__(44790)
+var inherits = __nccwpck_require__(76401)
+var alloc = Buffer.alloc
 
-      if (state.writing) {
-        break;
-      }
-    }
+var Readable = (__nccwpck_require__(17067).Readable)
+var Writable = (__nccwpck_require__(17067).Writable)
+var StringDecoder = (__nccwpck_require__(71576).StringDecoder)
 
-    if (entry === null) state.lastBufferedRequest = null;
-  }
+var headers = __nccwpck_require__(53350)
 
-  state.bufferedRequest = entry;
-  state.bufferProcessing = false;
-}
+var DMODE = parseInt('755', 8)
+var FMODE = parseInt('644', 8)
 
-Writable.prototype._write = function (chunk, encoding, cb) {
-  cb(new ERR_METHOD_NOT_IMPLEMENTED('_write()'));
-};
+var END_OF_TAR = alloc(1024)
 
-Writable.prototype._writev = null;
+var noop = function () {}
 
-Writable.prototype.end = function (chunk, encoding, cb) {
-  var state = this._writableState;
+var overflow = function (self, size) {
+  size &= 511
+  if (size) self.push(END_OF_TAR.slice(0, 512 - size))
+}
 
-  if (typeof chunk === 'function') {
-    cb = chunk;
-    chunk = null;
-    encoding = null;
-  } else if (typeof encoding === 'function') {
-    cb = encoding;
-    encoding = null;
+function modeToType (mode) {
+  switch (mode & constants.S_IFMT) {
+    case constants.S_IFBLK: return 'block-device'
+    case constants.S_IFCHR: return 'character-device'
+    case constants.S_IFDIR: return 'directory'
+    case constants.S_IFIFO: return 'fifo'
+    case constants.S_IFLNK: return 'symlink'
   }
 
-  if (chunk !== null && chunk !== undefined) this.write(chunk, encoding); // .end() fully uncorks
-
-  if (state.corked) {
-    state.corked = 1;
-    this.uncork();
-  } // ignore unnecessary end() calls.
+  return 'file'
+}
 
+var Sink = function (to) {
+  Writable.call(this)
+  this.written = 0
+  this._to = to
+  this._destroyed = false
+}
 
-  if (!state.ending) endWritable(this, state, cb);
-  return this;
-};
+inherits(Sink, Writable)
 
-Object.defineProperty(Writable.prototype, 'writableLength', {
-  // making it explicit this property is not enumerable
-  // because otherwise some prototype manipulation in
-  // userland will fail
-  enumerable: false,
-  get: function get() {
-    return this._writableState.length;
-  }
-});
+Sink.prototype._write = function (data, enc, cb) {
+  this.written += data.length
+  if (this._to.push(data)) return cb()
+  this._to._drain = cb
+}
 
-function needFinish(state) {
-  return state.ending && state.length === 0 && state.bufferedRequest === null && !state.finished && !state.writing;
+Sink.prototype.destroy = function () {
+  if (this._destroyed) return
+  this._destroyed = true
+  this.emit('close')
 }
 
-function callFinal(stream, state) {
-  stream._final(function (err) {
-    state.pendingcb--;
+var LinkSink = function () {
+  Writable.call(this)
+  this.linkname = ''
+  this._decoder = new StringDecoder('utf-8')
+  this._destroyed = false
+}
 
-    if (err) {
-      errorOrDestroy(stream, err);
-    }
+inherits(LinkSink, Writable)
 
-    state.prefinished = true;
-    stream.emit('prefinish');
-    finishMaybe(stream, state);
-  });
+LinkSink.prototype._write = function (data, enc, cb) {
+  this.linkname += this._decoder.write(data)
+  cb()
 }
 
-function prefinish(stream, state) {
-  if (!state.prefinished && !state.finalCalled) {
-    if (typeof stream._final === 'function' && !state.destroyed) {
-      state.pendingcb++;
-      state.finalCalled = true;
-      process.nextTick(callFinal, stream, state);
-    } else {
-      state.prefinished = true;
-      stream.emit('prefinish');
-    }
-  }
+LinkSink.prototype.destroy = function () {
+  if (this._destroyed) return
+  this._destroyed = true
+  this.emit('close')
 }
 
-function finishMaybe(stream, state) {
-  var need = needFinish(state);
+var Void = function () {
+  Writable.call(this)
+  this._destroyed = false
+}
 
-  if (need) {
-    prefinish(stream, state);
+inherits(Void, Writable)
 
-    if (state.pendingcb === 0) {
-      state.finished = true;
-      stream.emit('finish');
+Void.prototype._write = function (data, enc, cb) {
+  cb(new Error('No body allowed for this entry'))
+}
 
-      if (state.autoDestroy) {
-        // In case of duplex streams we need a way to detect
-        // if the readable side is ready for autoDestroy as well
-        var rState = stream._readableState;
+Void.prototype.destroy = function () {
+  if (this._destroyed) return
+  this._destroyed = true
+  this.emit('close')
+}
 
-        if (!rState || rState.autoDestroy && rState.endEmitted) {
-          stream.destroy();
-        }
-      }
-    }
-  }
+var Pack = function (opts) {
+  if (!(this instanceof Pack)) return new Pack(opts)
+  Readable.call(this, opts)
 
-  return need;
+  this._drain = noop
+  this._finalized = false
+  this._finalizing = false
+  this._destroyed = false
+  this._stream = null
 }
 
-function endWritable(stream, state, cb) {
-  state.ending = true;
-  finishMaybe(stream, state);
+inherits(Pack, Readable)
 
-  if (cb) {
-    if (state.finished) process.nextTick(cb);else stream.once('finish', cb);
+Pack.prototype.entry = function (header, buffer, callback) {
+  if (this._stream) throw new Error('already piping an entry')
+  if (this._finalized || this._destroyed) return
+
+  if (typeof buffer === 'function') {
+    callback = buffer
+    buffer = null
   }
 
-  state.ended = true;
-  stream.writable = false;
-}
+  if (!callback) callback = noop
 
-function onCorkedFinish(corkReq, state, err) {
-  var entry = corkReq.entry;
-  corkReq.entry = null;
+  var self = this
 
-  while (entry) {
-    var cb = entry.callback;
-    state.pendingcb--;
-    cb(err);
-    entry = entry.next;
-  } // reuse the free corkReq.
+  if (!header.size || header.type === 'symlink') header.size = 0
+  if (!header.type) header.type = modeToType(header.mode)
+  if (!header.mode) header.mode = header.type === 'directory' ? DMODE : FMODE
+  if (!header.uid) header.uid = 0
+  if (!header.gid) header.gid = 0
+  if (!header.mtime) header.mtime = new Date()
 
+  if (typeof buffer === 'string') buffer = Buffer.from(buffer)
+  if (Buffer.isBuffer(buffer)) {
+    header.size = buffer.length
+    this._encode(header)
+    var ok = this.push(buffer)
+    overflow(self, header.size)
+    if (ok) process.nextTick(callback)
+    else this._drain = callback
+    return new Void()
+  }
 
-  state.corkedRequestsFree.next = corkReq;
-}
+  if (header.type === 'symlink' && !header.linkname) {
+    var linkSink = new LinkSink()
+    eos(linkSink, function (err) {
+      if (err) { // stream was closed
+        self.destroy()
+        return callback(err)
+      }
 
-Object.defineProperty(Writable.prototype, 'destroyed', {
-  // making it explicit this property is not enumerable
-  // because otherwise some prototype manipulation in
-  // userland will fail
-  enumerable: false,
-  get: function get() {
-    if (this._writableState === undefined) {
-      return false;
-    }
+      header.linkname = linkSink.linkname
+      self._encode(header)
+      callback()
+    })
 
-    return this._writableState.destroyed;
-  },
-  set: function set(value) {
-    // we ignore the value if the stream
-    // has not been initialized yet
-    if (!this._writableState) {
-      return;
-    } // backward compatibility, the user is explicitly
-    // managing destroyed
+    return linkSink
+  }
 
+  this._encode(header)
 
-    this._writableState.destroyed = value;
+  if (header.type !== 'file' && header.type !== 'contiguous-file') {
+    process.nextTick(callback)
+    return new Void()
   }
-});
-Writable.prototype.destroy = destroyImpl.destroy;
-Writable.prototype._undestroy = destroyImpl.undestroy;
 
-Writable.prototype._destroy = function (err, cb) {
-  cb(err);
-};
-
-/***/ }),
+  var sink = new Sink(this)
 
-/***/ 29634:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+  this._stream = sink
 
-"use strict";
+  eos(sink, function (err) {
+    self._stream = null
 
+    if (err) { // stream was closed
+      self.destroy()
+      return callback(err)
+    }
 
-var _Object$setPrototypeO;
+    if (sink.written !== header.size) { // corrupting tar
+      self.destroy()
+      return callback(new Error('size mismatch'))
+    }
 
-function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
+    overflow(self, header.size)
+    if (self._finalizing) self.finalize()
+    callback()
+  })
 
-var finished = __nccwpck_require__(40841);
+  return sink
+}
 
-var kLastResolve = Symbol('lastResolve');
-var kLastReject = Symbol('lastReject');
-var kError = Symbol('error');
-var kEnded = Symbol('ended');
-var kLastPromise = Symbol('lastPromise');
-var kHandlePromise = Symbol('handlePromise');
-var kStream = Symbol('stream');
+Pack.prototype.finalize = function () {
+  if (this._stream) {
+    this._finalizing = true
+    return
+  }
 
-function createIterResult(value, done) {
-  return {
-    value: value,
-    done: done
-  };
+  if (this._finalized) return
+  this._finalized = true
+  this.push(END_OF_TAR)
+  this.push(null)
 }
 
-function readAndResolve(iter) {
-  var resolve = iter[kLastResolve];
+Pack.prototype.destroy = function (err) {
+  if (this._destroyed) return
+  this._destroyed = true
 
-  if (resolve !== null) {
-    var data = iter[kStream].read(); // we defer if data is null
-    // we can be expecting either 'end' or
-    // 'error'
+  if (err) this.emit('error', err)
+  this.emit('close')
+  if (this._stream && this._stream.destroy) this._stream.destroy()
+}
 
-    if (data !== null) {
-      iter[kLastPromise] = null;
-      iter[kLastResolve] = null;
-      iter[kLastReject] = null;
-      resolve(createIterResult(data, false));
+Pack.prototype._encode = function (header) {
+  if (!header.pax) {
+    var buf = headers.encode(header)
+    if (buf) {
+      this.push(buf)
+      return
     }
   }
+  this._encodePax(header)
 }
 
-function onReadable(iter) {
-  // we wait for the next tick, because it might
-  // emit an error with process.nextTick
-  process.nextTick(readAndResolve, iter);
-}
+Pack.prototype._encodePax = function (header) {
+  var paxHeader = headers.encodePax({
+    name: header.name,
+    linkname: header.linkname,
+    pax: header.pax
+  })
 
-function wrapForNext(lastPromise, iter) {
-  return function (resolve, reject) {
-    lastPromise.then(function () {
-      if (iter[kEnded]) {
-        resolve(createIterResult(undefined, true));
-        return;
-      }
+  var newHeader = {
+    name: 'PaxHeader',
+    mode: header.mode,
+    uid: header.uid,
+    gid: header.gid,
+    size: paxHeader.length,
+    mtime: header.mtime,
+    type: 'pax-header',
+    linkname: header.linkname && 'PaxHeader',
+    uname: header.uname,
+    gname: header.gname,
+    devmajor: header.devmajor,
+    devminor: header.devminor
+  }
 
-      iter[kHandlePromise](resolve, reject);
-    }, reject);
-  };
+  this.push(headers.encode(newHeader))
+  this.push(paxHeader)
+  overflow(this, paxHeader.length)
+
+  newHeader.size = header.size
+  newHeader.type = header.type
+  this.push(headers.encode(newHeader))
 }
 
-var AsyncIteratorPrototype = Object.getPrototypeOf(function () {});
-var ReadableStreamAsyncIteratorPrototype = Object.setPrototypeOf((_Object$setPrototypeO = {
-  get stream() {
-    return this[kStream];
-  },
+Pack.prototype._read = function (n) {
+  var drain = this._drain
+  this._drain = noop
+  drain()
+}
 
-  next: function next() {
-    var _this = this;
+module.exports = Pack
 
-    // if we have detected an error in the meanwhile
-    // reject straight away
-    var error = this[kError];
 
-    if (error !== null) {
-      return Promise.reject(error);
-    }
+/***/ }),
 
-    if (this[kEnded]) {
-      return Promise.resolve(createIterResult(undefined, true));
-    }
+/***/ 81866:
+/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
-    if (this[kStream].destroyed) {
-      // We need to defer via nextTick because if .destroy(err) is
-      // called, the error will be emitted via nextTick, and
-      // we cannot guarantee that there is no error lingering around
-      // waiting to be emitted.
-      return new Promise(function (resolve, reject) {
-        process.nextTick(function () {
-          if (_this[kError]) {
-            reject(_this[kError]);
-          } else {
-            resolve(createIterResult(undefined, true));
-          }
-        });
-      });
-    } // if we have multiple next() calls
-    // we will wait for the previous Promise to finish
-    // this logic is optimized to support for await loops,
-    // where next() is only called once at a time
+/*!
+ * Tmp
+ *
+ * Copyright (c) 2011-2017 KARASZI Istvan 
+ *
+ * MIT Licensed
+ */
 
+/*
+ * Module dependencies.
+ */
+const fs = __nccwpck_require__(57147);
+const os = __nccwpck_require__(22037);
+const path = __nccwpck_require__(71017);
+const crypto = __nccwpck_require__(6113);
+const _c = { fs: fs.constants, os: os.constants };
+const rimraf = __nccwpck_require__(88624);
 
-    var lastPromise = this[kLastPromise];
-    var promise;
+/*
+ * The working inner variables.
+ */
+const
+  // the random characters to choose from
+  RANDOM_CHARS = '0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz',
 
-    if (lastPromise) {
-      promise = new Promise(wrapForNext(lastPromise, this));
-    } else {
-      // fast path needed to support multiple this.push()
-      // without triggering the next() queue
-      var data = this[kStream].read();
+  TEMPLATE_PATTERN = /XXXXXX/,
 
-      if (data !== null) {
-        return Promise.resolve(createIterResult(data, false));
-      }
+  DEFAULT_TRIES = 3,
 
-      promise = new Promise(this[kHandlePromise]);
-    }
+  CREATE_FLAGS = (_c.O_CREAT || _c.fs.O_CREAT) | (_c.O_EXCL || _c.fs.O_EXCL) | (_c.O_RDWR || _c.fs.O_RDWR),
 
-    this[kLastPromise] = promise;
-    return promise;
-  }
-}, _defineProperty(_Object$setPrototypeO, Symbol.asyncIterator, function () {
-  return this;
-}), _defineProperty(_Object$setPrototypeO, "return", function _return() {
-  var _this2 = this;
+  // constants are off on the windows platform and will not match the actual errno codes
+  IS_WIN32 = os.platform() === 'win32',
+  EBADF = _c.EBADF || _c.os.errno.EBADF,
+  ENOENT = _c.ENOENT || _c.os.errno.ENOENT,
 
-  // destroy(err, cb) is a private API
-  // we can guarantee we have that here, because we control the
-  // Readable class this is attached to
-  return new Promise(function (resolve, reject) {
-    _this2[kStream].destroy(null, function (err) {
-      if (err) {
-        reject(err);
-        return;
-      }
+  DIR_MODE = 0o700 /* 448 */,
+  FILE_MODE = 0o600 /* 384 */,
 
-      resolve(createIterResult(undefined, true));
-    });
-  });
-}), _Object$setPrototypeO), AsyncIteratorPrototype);
+  EXIT = 'exit',
 
-var createReadableStreamAsyncIterator = function createReadableStreamAsyncIterator(stream) {
-  var _Object$create;
+  // this will hold the objects need to be removed on exit
+  _removeObjects = [],
 
-  var iterator = Object.create(ReadableStreamAsyncIteratorPrototype, (_Object$create = {}, _defineProperty(_Object$create, kStream, {
-    value: stream,
-    writable: true
-  }), _defineProperty(_Object$create, kLastResolve, {
-    value: null,
-    writable: true
-  }), _defineProperty(_Object$create, kLastReject, {
-    value: null,
-    writable: true
-  }), _defineProperty(_Object$create, kError, {
-    value: null,
-    writable: true
-  }), _defineProperty(_Object$create, kEnded, {
-    value: stream._readableState.endEmitted,
-    writable: true
-  }), _defineProperty(_Object$create, kHandlePromise, {
-    value: function value(resolve, reject) {
-      var data = iterator[kStream].read();
+  // API change in fs.rmdirSync leads to error when passing in a second parameter, e.g. the callback
+  FN_RMDIR_SYNC = fs.rmdirSync.bind(fs),
+  FN_RIMRAF_SYNC = rimraf.sync;
 
-      if (data) {
-        iterator[kLastPromise] = null;
-        iterator[kLastResolve] = null;
-        iterator[kLastReject] = null;
-        resolve(createIterResult(data, false));
-      } else {
-        iterator[kLastResolve] = resolve;
-        iterator[kLastReject] = reject;
-      }
-    },
-    writable: true
-  }), _Object$create));
-  iterator[kLastPromise] = null;
-  finished(stream, function (err) {
-    if (err && err.code !== 'ERR_STREAM_PREMATURE_CLOSE') {
-      var reject = iterator[kLastReject]; // reject if we are waiting for data in the Promise
-      // returned by next() and store the error
+let
+  _gracefulCleanup = false;
 
-      if (reject !== null) {
-        iterator[kLastPromise] = null;
-        iterator[kLastResolve] = null;
-        iterator[kLastReject] = null;
-        reject(err);
-      }
+/**
+ * Gets a temporary file name.
+ *
+ * @param {(Options|tmpNameCallback)} options options or callback
+ * @param {?tmpNameCallback} callback the callback function
+ */
+function tmpName(options, callback) {
+  const
+    args = _parseArguments(options, callback),
+    opts = args[0],
+    cb = args[1];
 
-      iterator[kError] = err;
-      return;
-    }
+  try {
+    _assertAndSanitizeOptions(opts);
+  } catch (err) {
+    return cb(err);
+  }
 
-    var resolve = iterator[kLastResolve];
+  let tries = opts.tries;
+  (function _getUniqueName() {
+    try {
+      const name = _generateTmpName(opts);
 
-    if (resolve !== null) {
-      iterator[kLastPromise] = null;
-      iterator[kLastResolve] = null;
-      iterator[kLastReject] = null;
-      resolve(createIterResult(undefined, true));
-    }
+      // check whether the path exists then retry if needed
+      fs.stat(name, function (err) {
+        /* istanbul ignore else */
+        if (!err) {
+          /* istanbul ignore else */
+          if (tries-- > 0) return _getUniqueName();
 
-    iterator[kEnded] = true;
-  });
-  stream.on('readable', onReadable.bind(null, iterator));
-  return iterator;
-};
+          return cb(new Error('Could not get a unique tmp filename, max tries reached ' + name));
+        }
 
-module.exports = createReadableStreamAsyncIterator;
+        cb(null, name);
+      });
+    } catch (err) {
+      cb(err);
+    }
+  }());
+}
 
-/***/ }),
+/**
+ * Synchronous version of tmpName.
+ *
+ * @param {Object} options
+ * @returns {string} the generated random name
+ * @throws {Error} if the options are invalid or could not generate a filename
+ */
+function tmpNameSync(options) {
+  const
+    args = _parseArguments(options),
+    opts = args[0];
 
-/***/ 85243:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+  _assertAndSanitizeOptions(opts);
 
-"use strict";
+  let tries = opts.tries;
+  do {
+    const name = _generateTmpName(opts);
+    try {
+      fs.statSync(name);
+    } catch (e) {
+      return name;
+    }
+  } while (tries-- > 0);
 
+  throw new Error('Could not get a unique tmp filename, max tries reached');
+}
 
-function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }
+/**
+ * Creates and opens a temporary file.
+ *
+ * @param {(Options|null|undefined|fileCallback)} options the config options or the callback function or null or undefined
+ * @param {?fileCallback} callback
+ */
+function file(options, callback) {
+  const
+    args = _parseArguments(options, callback),
+    opts = args[0],
+    cb = args[1];
 
-function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
+  // gets a temporary filename
+  tmpName(opts, function _tmpNameCreated(err, name) {
+    /* istanbul ignore else */
+    if (err) return cb(err);
 
-function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
+    // create and open the file
+    fs.open(name, CREATE_FLAGS, opts.mode || FILE_MODE, function _fileCreated(err, fd) {
+      /* istanbu ignore else */
+      if (err) return cb(err);
 
-function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
+      if (opts.discardDescriptor) {
+        return fs.close(fd, function _discardCallback(possibleErr) {
+          // the chance of getting an error on close here is rather low and might occur in the most edgiest cases only
+          return cb(possibleErr, name, undefined, _prepareTmpFileRemoveCallback(name, -1, opts, false));
+        });
+      } else {
+        // detachDescriptor passes the descriptor whereas discardDescriptor closes it, either way, we no longer care
+        // about the descriptor
+        const discardOrDetachDescriptor = opts.discardDescriptor || opts.detachDescriptor;
+        cb(null, name, fd, _prepareTmpFileRemoveCallback(name, discardOrDetachDescriptor ? -1 : fd, opts, false));
+      }
+    });
+  });
+}
 
-function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }
+/**
+ * Synchronous version of file.
+ *
+ * @param {Options} options
+ * @returns {FileSyncObject} object consists of name, fd and removeCallback
+ * @throws {Error} if cannot create a file
+ */
+function fileSync(options) {
+  const
+    args = _parseArguments(options),
+    opts = args[0];
 
-function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }
+  const discardOrDetachDescriptor = opts.discardDescriptor || opts.detachDescriptor;
+  const name = tmpNameSync(opts);
+  var fd = fs.openSync(name, CREATE_FLAGS, opts.mode || FILE_MODE);
+  /* istanbul ignore else */
+  if (opts.discardDescriptor) {
+    fs.closeSync(fd);
+    fd = undefined;
+  }
 
-var _require = __nccwpck_require__(14300),
-    Buffer = _require.Buffer;
+  return {
+    name: name,
+    fd: fd,
+    removeCallback: _prepareTmpFileRemoveCallback(name, discardOrDetachDescriptor ? -1 : fd, opts, true)
+  };
+}
 
-var _require2 = __nccwpck_require__(73837),
-    inspect = _require2.inspect;
+/**
+ * Creates a temporary directory.
+ *
+ * @param {(Options|dirCallback)} options the options or the callback function
+ * @param {?dirCallback} callback
+ */
+function dir(options, callback) {
+  const
+    args = _parseArguments(options, callback),
+    opts = args[0],
+    cb = args[1];
 
-var custom = inspect && inspect.custom || 'inspect';
+  // gets a temporary filename
+  tmpName(opts, function _tmpNameCreated(err, name) {
+    /* istanbul ignore else */
+    if (err) return cb(err);
 
-function copyBuffer(src, target, offset) {
-  Buffer.prototype.copy.call(src, target, offset);
+    // create the directory
+    fs.mkdir(name, opts.mode || DIR_MODE, function _dirCreated(err) {
+      /* istanbul ignore else */
+      if (err) return cb(err);
+
+      cb(null, name, _prepareTmpDirRemoveCallback(name, opts, false));
+    });
+  });
 }
 
-module.exports =
-/*#__PURE__*/
-function () {
-  function BufferList() {
-    _classCallCheck(this, BufferList);
+/**
+ * Synchronous version of dir.
+ *
+ * @param {Options} options
+ * @returns {DirSyncObject} object consists of name and removeCallback
+ * @throws {Error} if it cannot create a directory
+ */
+function dirSync(options) {
+  const
+    args = _parseArguments(options),
+    opts = args[0];
 
-    this.head = null;
-    this.tail = null;
-    this.length = 0;
-  }
+  const name = tmpNameSync(opts);
+  fs.mkdirSync(name, opts.mode || DIR_MODE);
 
-  _createClass(BufferList, [{
-    key: "push",
-    value: function push(v) {
-      var entry = {
-        data: v,
-        next: null
-      };
-      if (this.length > 0) this.tail.next = entry;else this.head = entry;
-      this.tail = entry;
-      ++this.length;
-    }
-  }, {
-    key: "unshift",
-    value: function unshift(v) {
-      var entry = {
-        data: v,
-        next: this.head
-      };
-      if (this.length === 0) this.tail = entry;
-      this.head = entry;
-      ++this.length;
+  return {
+    name: name,
+    removeCallback: _prepareTmpDirRemoveCallback(name, opts, true)
+  };
+}
+
+/**
+ * Removes files asynchronously.
+ *
+ * @param {Object} fdPath
+ * @param {Function} next
+ * @private
+ */
+function _removeFileAsync(fdPath, next) {
+  const _handler = function (err) {
+    if (err && !_isENOENT(err)) {
+      // reraise any unanticipated error
+      return next(err);
     }
-  }, {
-    key: "shift",
-    value: function shift() {
-      if (this.length === 0) return;
-      var ret = this.head.data;
-      if (this.length === 1) this.head = this.tail = null;else this.head = this.head.next;
-      --this.length;
-      return ret;
+    next();
+  };
+
+  if (0 <= fdPath[0])
+    fs.close(fdPath[0], function () {
+      fs.unlink(fdPath[1], _handler);
+    });
+  else fs.unlink(fdPath[1], _handler);
+}
+
+/**
+ * Removes files synchronously.
+ *
+ * @param {Object} fdPath
+ * @private
+ */
+function _removeFileSync(fdPath) {
+  let rethrownException = null;
+  try {
+    if (0 <= fdPath[0]) fs.closeSync(fdPath[0]);
+  } catch (e) {
+    // reraise any unanticipated error
+    if (!_isEBADF(e) && !_isENOENT(e)) throw e;
+  } finally {
+    try {
+      fs.unlinkSync(fdPath[1]);
     }
-  }, {
-    key: "clear",
-    value: function clear() {
-      this.head = this.tail = null;
-      this.length = 0;
+    catch (e) {
+      // reraise any unanticipated error
+      if (!_isENOENT(e)) rethrownException = e;
     }
-  }, {
-    key: "join",
-    value: function join(s) {
-      if (this.length === 0) return '';
-      var p = this.head;
-      var ret = '' + p.data;
+  }
+  if (rethrownException !== null) {
+    throw rethrownException;
+  }
+}
 
-      while (p = p.next) {
-        ret += s + p.data;
-      }
+/**
+ * Prepares the callback for removal of the temporary file.
+ *
+ * Returns either a sync callback or a async callback depending on whether
+ * fileSync or file was called, which is expressed by the sync parameter.
+ *
+ * @param {string} name the path of the file
+ * @param {number} fd file descriptor
+ * @param {Object} opts
+ * @param {boolean} sync
+ * @returns {fileCallback | fileCallbackSync}
+ * @private
+ */
+function _prepareTmpFileRemoveCallback(name, fd, opts, sync) {
+  const removeCallbackSync = _prepareRemoveCallback(_removeFileSync, [fd, name], sync);
+  const removeCallback = _prepareRemoveCallback(_removeFileAsync, [fd, name], sync, removeCallbackSync);
 
-      return ret;
-    }
-  }, {
-    key: "concat",
-    value: function concat(n) {
-      if (this.length === 0) return Buffer.alloc(0);
-      var ret = Buffer.allocUnsafe(n >>> 0);
-      var p = this.head;
-      var i = 0;
+  if (!opts.keep) _removeObjects.unshift(removeCallbackSync);
 
-      while (p) {
-        copyBuffer(p.data, ret, i);
-        i += p.data.length;
-        p = p.next;
-      }
+  return sync ? removeCallbackSync : removeCallback;
+}
 
-      return ret;
-    } // Consumes a specified amount of bytes or characters from the buffered data.
+/**
+ * Prepares the callback for removal of the temporary directory.
+ *
+ * Returns either a sync callback or a async callback depending on whether
+ * tmpFileSync or tmpFile was called, which is expressed by the sync parameter.
+ *
+ * @param {string} name
+ * @param {Object} opts
+ * @param {boolean} sync
+ * @returns {Function} the callback
+ * @private
+ */
+function _prepareTmpDirRemoveCallback(name, opts, sync) {
+  const removeFunction = opts.unsafeCleanup ? rimraf : fs.rmdir.bind(fs);
+  const removeFunctionSync = opts.unsafeCleanup ? FN_RIMRAF_SYNC : FN_RMDIR_SYNC;
+  const removeCallbackSync = _prepareRemoveCallback(removeFunctionSync, name, sync);
+  const removeCallback = _prepareRemoveCallback(removeFunction, name, sync, removeCallbackSync);
+  if (!opts.keep) _removeObjects.unshift(removeCallbackSync);
 
-  }, {
-    key: "consume",
-    value: function consume(n, hasStrings) {
-      var ret;
+  return sync ? removeCallbackSync : removeCallback;
+}
 
-      if (n < this.head.data.length) {
-        // `slice` is the same for buffers and strings.
-        ret = this.head.data.slice(0, n);
-        this.head.data = this.head.data.slice(n);
-      } else if (n === this.head.data.length) {
-        // First chunk is a perfect match.
-        ret = this.shift();
+/**
+ * Creates a guarded function wrapping the removeFunction call.
+ *
+ * The cleanup callback is save to be called multiple times.
+ * Subsequent invocations will be ignored.
+ *
+ * @param {Function} removeFunction
+ * @param {string} fileOrDirName
+ * @param {boolean} sync
+ * @param {cleanupCallbackSync?} cleanupCallbackSync
+ * @returns {cleanupCallback | cleanupCallbackSync}
+ * @private
+ */
+function _prepareRemoveCallback(removeFunction, fileOrDirName, sync, cleanupCallbackSync) {
+  let called = false;
+
+  // if sync is true, the next parameter will be ignored
+  return function _cleanupCallback(next) {
+
+    /* istanbul ignore else */
+    if (!called) {
+      // remove cleanupCallback from cache
+      const toRemove = cleanupCallbackSync || _cleanupCallback;
+      const index = _removeObjects.indexOf(toRemove);
+      /* istanbul ignore else */
+      if (index >= 0) _removeObjects.splice(index, 1);
+
+      called = true;
+      if (sync || removeFunction === FN_RMDIR_SYNC || removeFunction === FN_RIMRAF_SYNC) {
+        return removeFunction(fileOrDirName);
       } else {
-        // Result spans more than one buffer.
-        ret = hasStrings ? this._getString(n) : this._getBuffer(n);
+        return removeFunction(fileOrDirName, next || function() {});
       }
+    }
+  };
+}
 
-      return ret;
+/**
+ * The garbage collector.
+ *
+ * @private
+ */
+function _garbageCollector() {
+  /* istanbul ignore else */
+  if (!_gracefulCleanup) return;
+
+  // the function being called removes itself from _removeObjects,
+  // loop until _removeObjects is empty
+  while (_removeObjects.length) {
+    try {
+      _removeObjects[0]();
+    } catch (e) {
+      // already removed?
     }
-  }, {
-    key: "first",
-    value: function first() {
-      return this.head.data;
-    } // Consumes a specified amount of characters from the buffered data.
+  }
+}
 
-  }, {
-    key: "_getString",
-    value: function _getString(n) {
-      var p = this.head;
-      var c = 1;
-      var ret = p.data;
-      n -= ret.length;
+/**
+ * Random name generator based on crypto.
+ * Adapted from http://blog.tompawlak.org/how-to-generate-random-values-nodejs-javascript
+ *
+ * @param {number} howMany
+ * @returns {string} the generated random name
+ * @private
+ */
+function _randomChars(howMany) {
+  let
+    value = [],
+    rnd = null;
 
-      while (p = p.next) {
-        var str = p.data;
-        var nb = n > str.length ? str.length : n;
-        if (nb === str.length) ret += str;else ret += str.slice(0, n);
-        n -= nb;
+  // make sure that we do not fail because we ran out of entropy
+  try {
+    rnd = crypto.randomBytes(howMany);
+  } catch (e) {
+    rnd = crypto.pseudoRandomBytes(howMany);
+  }
 
-        if (n === 0) {
-          if (nb === str.length) {
-            ++c;
-            if (p.next) this.head = p.next;else this.head = this.tail = null;
-          } else {
-            this.head = p;
-            p.data = str.slice(nb);
-          }
+  for (var i = 0; i < howMany; i++) {
+    value.push(RANDOM_CHARS[rnd[i] % RANDOM_CHARS.length]);
+  }
 
-          break;
-        }
+  return value.join('');
+}
 
-        ++c;
-      }
+/**
+ * Helper which determines whether a string s is blank, that is undefined, or empty or null.
+ *
+ * @private
+ * @param {string} s
+ * @returns {Boolean} true whether the string s is blank, false otherwise
+ */
+function _isBlank(s) {
+  return s === null || _isUndefined(s) || !s.trim();
+}
 
-      this.length -= c;
-      return ret;
-    } // Consumes a specified amount of bytes from the buffered data.
+/**
+ * Checks whether the `obj` parameter is defined or not.
+ *
+ * @param {Object} obj
+ * @returns {boolean} true if the object is undefined
+ * @private
+ */
+function _isUndefined(obj) {
+  return typeof obj === 'undefined';
+}
 
-  }, {
-    key: "_getBuffer",
-    value: function _getBuffer(n) {
-      var ret = Buffer.allocUnsafe(n);
-      var p = this.head;
-      var c = 1;
-      p.data.copy(ret);
-      n -= p.data.length;
+/**
+ * Parses the function arguments.
+ *
+ * This function helps to have optional arguments.
+ *
+ * @param {(Options|null|undefined|Function)} options
+ * @param {?Function} callback
+ * @returns {Array} parsed arguments
+ * @private
+ */
+function _parseArguments(options, callback) {
+  /* istanbul ignore else */
+  if (typeof options === 'function') {
+    return [{}, options];
+  }
 
-      while (p = p.next) {
-        var buf = p.data;
-        var nb = n > buf.length ? buf.length : n;
-        buf.copy(ret, ret.length - n, 0, nb);
-        n -= nb;
+  /* istanbul ignore else */
+  if (_isUndefined(options)) {
+    return [{}, callback];
+  }
 
-        if (n === 0) {
-          if (nb === buf.length) {
-            ++c;
-            if (p.next) this.head = p.next;else this.head = this.tail = null;
-          } else {
-            this.head = p;
-            p.data = buf.slice(nb);
-          }
+  // copy options so we do not leak the changes we make internally
+  const actualOptions = {};
+  for (const key of Object.getOwnPropertyNames(options)) {
+    actualOptions[key] = options[key];
+  }
 
-          break;
-        }
+  return [actualOptions, callback];
+}
 
-        ++c;
-      }
+/**
+ * Generates a new temporary name.
+ *
+ * @param {Object} opts
+ * @returns {string} the new random name according to opts
+ * @private
+ */
+function _generateTmpName(opts) {
 
-      this.length -= c;
-      return ret;
-    } // Make sure the linked list only shows the minimal necessary information.
+  const tmpDir = opts.tmpdir;
 
-  }, {
-    key: custom,
-    value: function value(_, options) {
-      return inspect(this, _objectSpread({}, options, {
-        // Only inspect one level.
-        depth: 0,
-        // It should not recurse.
-        customInspect: false
-      }));
-    }
-  }]);
+  /* istanbul ignore else */
+  if (!_isUndefined(opts.name))
+    return path.join(tmpDir, opts.dir, opts.name);
 
-  return BufferList;
-}();
+  /* istanbul ignore else */
+  if (!_isUndefined(opts.template))
+    return path.join(tmpDir, opts.dir, opts.template).replace(TEMPLATE_PATTERN, _randomChars(6));
 
-/***/ }),
+  // prefix and postfix
+  const name = [
+    opts.prefix ? opts.prefix : 'tmp',
+    '-',
+    process.pid,
+    '-',
+    _randomChars(12),
+    opts.postfix ? '-' + opts.postfix : ''
+  ].join('');
 
-/***/ 70079:
-/***/ ((module) => {
+  return path.join(tmpDir, opts.dir, name);
+}
 
-"use strict";
- // undocumented cb() API, needed for core, not for public API
+/**
+ * Asserts whether the specified options are valid, also sanitizes options and provides sane defaults for missing
+ * options.
+ *
+ * @param {Options} options
+ * @private
+ */
+function _assertAndSanitizeOptions(options) {
 
-function destroy(err, cb) {
-  var _this = this;
+  options.tmpdir = _getTmpDir(options);
 
-  var readableDestroyed = this._readableState && this._readableState.destroyed;
-  var writableDestroyed = this._writableState && this._writableState.destroyed;
+  const tmpDir = options.tmpdir;
 
-  if (readableDestroyed || writableDestroyed) {
-    if (cb) {
-      cb(err);
-    } else if (err) {
-      if (!this._writableState) {
-        process.nextTick(emitErrorNT, this, err);
-      } else if (!this._writableState.errorEmitted) {
-        this._writableState.errorEmitted = true;
-        process.nextTick(emitErrorNT, this, err);
-      }
-    }
+  /* istanbul ignore else */
+  if (!_isUndefined(options.name))
+    _assertIsRelative(options.name, 'name', tmpDir);
+  /* istanbul ignore else */
+  if (!_isUndefined(options.dir))
+    _assertIsRelative(options.dir, 'dir', tmpDir);
+  /* istanbul ignore else */
+  if (!_isUndefined(options.template)) {
+    _assertIsRelative(options.template, 'template', tmpDir);
+    if (!options.template.match(TEMPLATE_PATTERN))
+      throw new Error(`Invalid template, found "${options.template}".`);
+  }
+  /* istanbul ignore else */
+  if (!_isUndefined(options.tries) && isNaN(options.tries) || options.tries < 0)
+    throw new Error(`Invalid tries, found "${options.tries}".`);
 
-    return this;
-  } // we set destroyed to true before firing error callbacks in order
-  // to make it re-entrance safe in case destroy() is called within callbacks
+  // if a name was specified we will try once
+  options.tries = _isUndefined(options.name) ? options.tries || DEFAULT_TRIES : 1;
+  options.keep = !!options.keep;
+  options.detachDescriptor = !!options.detachDescriptor;
+  options.discardDescriptor = !!options.discardDescriptor;
+  options.unsafeCleanup = !!options.unsafeCleanup;
 
+  // sanitize dir, also keep (multiple) blanks if the user, purportedly sane, requests us to
+  options.dir = _isUndefined(options.dir) ? '' : path.relative(tmpDir, _resolvePath(options.dir, tmpDir));
+  options.template = _isUndefined(options.template) ? undefined : path.relative(tmpDir, _resolvePath(options.template, tmpDir));
+  // sanitize further if template is relative to options.dir
+  options.template = _isBlank(options.template) ? undefined : path.relative(options.dir, options.template);
 
-  if (this._readableState) {
-    this._readableState.destroyed = true;
-  } // if this is a duplex stream mark the writable part as destroyed as well
+  // for completeness' sake only, also keep (multiple) blanks if the user, purportedly sane, requests us to
+  options.name = _isUndefined(options.name) ? undefined : _sanitizeName(options.name);
+  options.prefix = _isUndefined(options.prefix) ? '' : options.prefix;
+  options.postfix = _isUndefined(options.postfix) ? '' : options.postfix;
+}
 
+/**
+ * Resolve the specified path name in respect to tmpDir.
+ *
+ * The specified name might include relative path components, e.g. ../
+ * so we need to resolve in order to be sure that is is located inside tmpDir
+ *
+ * @param name
+ * @param tmpDir
+ * @returns {string}
+ * @private
+ */
+function _resolvePath(name, tmpDir) {
+  const sanitizedName = _sanitizeName(name);
+  if (sanitizedName.startsWith(tmpDir)) {
+    return path.resolve(sanitizedName);
+  } else {
+    return path.resolve(path.join(tmpDir, sanitizedName));
+  }
+}
 
-  if (this._writableState) {
-    this._writableState.destroyed = true;
+/**
+ * Sanitize the specified path name by removing all quote characters.
+ *
+ * @param name
+ * @returns {string}
+ * @private
+ */
+function _sanitizeName(name) {
+  if (_isBlank(name)) {
+    return name;
   }
+  return name.replace(/["']/g, '');
+}
 
-  this._destroy(err || null, function (err) {
-    if (!cb && err) {
-      if (!_this._writableState) {
-        process.nextTick(emitErrorAndCloseNT, _this, err);
-      } else if (!_this._writableState.errorEmitted) {
-        _this._writableState.errorEmitted = true;
-        process.nextTick(emitErrorAndCloseNT, _this, err);
-      } else {
-        process.nextTick(emitCloseNT, _this);
-      }
-    } else if (cb) {
-      process.nextTick(emitCloseNT, _this);
-      cb(err);
-    } else {
-      process.nextTick(emitCloseNT, _this);
+/**
+ * Asserts whether specified name is relative to the specified tmpDir.
+ *
+ * @param {string} name
+ * @param {string} option
+ * @param {string} tmpDir
+ * @throws {Error}
+ * @private
+ */
+function _assertIsRelative(name, option, tmpDir) {
+  if (option === 'name') {
+    // assert that name is not absolute and does not contain a path
+    if (path.isAbsolute(name))
+      throw new Error(`${option} option must not contain an absolute path, found "${name}".`);
+    // must not fail on valid . or .. or similar such constructs
+    let basename = path.basename(name);
+    if (basename === '..' || basename === '.' || basename !== name)
+      throw new Error(`${option} option must not contain a path, found "${name}".`);
+  }
+  else { // if (option === 'dir' || option === 'template') {
+    // assert that dir or template are relative to tmpDir
+    if (path.isAbsolute(name) && !name.startsWith(tmpDir)) {
+      throw new Error(`${option} option must be relative to "${tmpDir}", found "${name}".`);
     }
-  });
-
-  return this;
+    let resolvedPath = _resolvePath(name, tmpDir);
+    if (!resolvedPath.startsWith(tmpDir))
+      throw new Error(`${option} option must be relative to "${tmpDir}", found "${resolvedPath}".`);
+  }
 }
 
-function emitErrorAndCloseNT(self, err) {
-  emitErrorNT(self, err);
-  emitCloseNT(self);
+/**
+ * Helper for testing against EBADF to compensate changes made to Node 7.x under Windows.
+ *
+ * @private
+ */
+function _isEBADF(error) {
+  return _isExpectedError(error, -EBADF, 'EBADF');
 }
 
-function emitCloseNT(self) {
-  if (self._writableState && !self._writableState.emitClose) return;
-  if (self._readableState && !self._readableState.emitClose) return;
-  self.emit('close');
+/**
+ * Helper for testing against ENOENT to compensate changes made to Node 7.x under Windows.
+ *
+ * @private
+ */
+function _isENOENT(error) {
+  return _isExpectedError(error, -ENOENT, 'ENOENT');
 }
 
-function undestroy() {
-  if (this._readableState) {
-    this._readableState.destroyed = false;
-    this._readableState.reading = false;
-    this._readableState.ended = false;
-    this._readableState.endEmitted = false;
-  }
-
-  if (this._writableState) {
-    this._writableState.destroyed = false;
-    this._writableState.ended = false;
-    this._writableState.ending = false;
-    this._writableState.finalCalled = false;
-    this._writableState.prefinished = false;
-    this._writableState.finished = false;
-    this._writableState.errorEmitted = false;
-  }
+/**
+ * Helper to determine whether the expected error code matches the actual code and errno,
+ * which will differ between the supported node versions.
+ *
+ * - Node >= 7.0:
+ *   error.code {string}
+ *   error.errno {number} any numerical value will be negated
+ *
+ * CAVEAT
+ *
+ * On windows, the errno for EBADF is -4083 but os.constants.errno.EBADF is different and we must assume that ENOENT
+ * is no different here.
+ *
+ * @param {SystemError} error
+ * @param {number} errno
+ * @param {string} code
+ * @private
+ */
+function _isExpectedError(error, errno, code) {
+  return IS_WIN32 ? error.code === code : error.code === code && error.errno === errno;
 }
 
-function emitErrorNT(self, err) {
-  self.emit('error', err);
+/**
+ * Sets the graceful cleanup.
+ *
+ * If graceful cleanup is set, tmp will remove all controlled temporary objects on process exit, otherwise the
+ * temporary objects will remain in place, waiting to be cleaned up on system restart or otherwise scheduled temporary
+ * object removals.
+ */
+function setGracefulCleanup() {
+  _gracefulCleanup = true;
 }
 
-function errorOrDestroy(stream, err) {
-  // We have tests that rely on errors being emitted
-  // in the same tick, so changing this is semver major.
-  // For now when you opt-in to autoDestroy we allow
-  // the error to be emitted nextTick. In a future
-  // semver major update we should change the default to this.
-  var rState = stream._readableState;
-  var wState = stream._writableState;
-  if (rState && rState.autoDestroy || wState && wState.autoDestroy) stream.destroy(err);else stream.emit('error', err);
+/**
+ * Returns the currently configured tmp dir from os.tmpdir().
+ *
+ * @private
+ * @param {?Options} options
+ * @returns {string} the currently configured tmp dir
+ */
+function _getTmpDir(options) {
+  return path.resolve(_sanitizeName(options && options.tmpdir || os.tmpdir()));
 }
 
-module.exports = {
-  destroy: destroy,
-  undestroy: undestroy,
-  errorOrDestroy: errorOrDestroy
-};
+// Install process exit listener
+process.addListener(EXIT, _garbageCollector);
 
-/***/ }),
+/**
+ * Configuration options.
+ *
+ * @typedef {Object} Options
+ * @property {?boolean} keep the temporary object (file or dir) will not be garbage collected
+ * @property {?number} tries the number of tries before give up the name generation
+ * @property (?int) mode the access mode, defaults are 0o700 for directories and 0o600 for files
+ * @property {?string} template the "mkstemp" like filename template
+ * @property {?string} name fixed name relative to tmpdir or the specified dir option
+ * @property {?string} dir tmp directory relative to the root tmp directory in use
+ * @property {?string} prefix prefix for the generated name
+ * @property {?string} postfix postfix for the generated name
+ * @property {?string} tmpdir the root tmp directory which overrides the os tmpdir
+ * @property {?boolean} unsafeCleanup recursively removes the created temporary directory, even when it's not empty
+ * @property {?boolean} detachDescriptor detaches the file descriptor, caller is responsible for closing the file, tmp will no longer try closing the file during garbage collection
+ * @property {?boolean} discardDescriptor discards the file descriptor (closes file, fd is -1), tmp will no longer try closing the file during garbage collection
+ */
 
-/***/ 40841:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+/**
+ * @typedef {Object} FileSyncObject
+ * @property {string} name the name of the file
+ * @property {string} fd the file descriptor or -1 if the fd has been discarded
+ * @property {fileCallback} removeCallback the callback function to remove the file
+ */
 
-"use strict";
-// Ported from https://github.com/mafintosh/end-of-stream with
-// permission from the author, Mathias Buus (@mafintosh).
+/**
+ * @typedef {Object} DirSyncObject
+ * @property {string} name the name of the directory
+ * @property {fileCallback} removeCallback the callback function to remove the directory
+ */
 
+/**
+ * @callback tmpNameCallback
+ * @param {?Error} err the error object if anything goes wrong
+ * @param {string} name the temporary file name
+ */
 
-var ERR_STREAM_PREMATURE_CLOSE = (__nccwpck_require__(91042)/* .codes.ERR_STREAM_PREMATURE_CLOSE */ .q.ERR_STREAM_PREMATURE_CLOSE);
+/**
+ * @callback fileCallback
+ * @param {?Error} err the error object if anything goes wrong
+ * @param {string} name the temporary file name
+ * @param {number} fd the file descriptor or -1 if the fd had been discarded
+ * @param {cleanupCallback} fn the cleanup callback function
+ */
 
-function once(callback) {
-  var called = false;
-  return function () {
-    if (called) return;
-    called = true;
+/**
+ * @callback fileCallbackSync
+ * @param {?Error} err the error object if anything goes wrong
+ * @param {string} name the temporary file name
+ * @param {number} fd the file descriptor or -1 if the fd had been discarded
+ * @param {cleanupCallbackSync} fn the cleanup callback function
+ */
 
-    for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
-      args[_key] = arguments[_key];
-    }
+/**
+ * @callback dirCallback
+ * @param {?Error} err the error object if anything goes wrong
+ * @param {string} name the temporary file name
+ * @param {cleanupCallback} fn the cleanup callback function
+ */
 
-    callback.apply(this, args);
-  };
-}
+/**
+ * @callback dirCallbackSync
+ * @param {?Error} err the error object if anything goes wrong
+ * @param {string} name the temporary file name
+ * @param {cleanupCallbackSync} fn the cleanup callback function
+ */
 
-function noop() {}
+/**
+ * Removes the temporary created file or directory.
+ *
+ * @callback cleanupCallback
+ * @param {simpleCallback} [next] function to call whenever the tmp object needs to be removed
+ */
 
-function isRequest(stream) {
-  return stream.setHeader && typeof stream.abort === 'function';
-}
+/**
+ * Removes the temporary created file or directory.
+ *
+ * @callback cleanupCallbackSync
+ */
 
-function eos(stream, opts, callback) {
-  if (typeof opts === 'function') return eos(stream, null, opts);
-  if (!opts) opts = {};
-  callback = once(callback || noop);
-  var readable = opts.readable || opts.readable !== false && stream.readable;
-  var writable = opts.writable || opts.writable !== false && stream.writable;
+/**
+ * Callback function for function composition.
+ * @see {@link https://github.com/raszi/node-tmp/issues/57|raszi/node-tmp#57}
+ *
+ * @callback simpleCallback
+ */
 
-  var onlegacyfinish = function onlegacyfinish() {
-    if (!stream.writable) onfinish();
-  };
+// exporting all the needed methods
 
-  var writableEnded = stream._writableState && stream._writableState.finished;
+// evaluate _getTmpDir() lazily, mainly for simplifying testing but it also will
+// allow users to reconfigure the temporary directory
+Object.defineProperty(module.exports, "tmpdir", ({
+  enumerable: true,
+  configurable: false,
+  get: function () {
+    return _getTmpDir();
+  }
+}));
 
-  var onfinish = function onfinish() {
-    writable = false;
-    writableEnded = true;
-    if (!readable) callback.call(stream);
-  };
+module.exports.dir = dir;
+module.exports.dirSync = dirSync;
 
-  var readableEnded = stream._readableState && stream._readableState.endEmitted;
+module.exports.file = file;
+module.exports.fileSync = fileSync;
 
-  var onend = function onend() {
-    readable = false;
-    readableEnded = true;
-    if (!writable) callback.call(stream);
-  };
+module.exports.tmpName = tmpName;
+module.exports.tmpNameSync = tmpNameSync;
 
-  var onerror = function onerror(err) {
-    callback.call(stream, err);
-  };
+module.exports.setGracefulCleanup = setGracefulCleanup;
 
-  var onclose = function onclose() {
-    var err;
-
-    if (readable && !readableEnded) {
-      if (!stream._readableState || !stream._readableState.ended) err = new ERR_STREAM_PREMATURE_CLOSE();
-      return callback.call(stream, err);
-    }
-
-    if (writable && !writableEnded) {
-      if (!stream._writableState || !stream._writableState.ended) err = new ERR_STREAM_PREMATURE_CLOSE();
-      return callback.call(stream, err);
-    }
-  };
 
-  var onrequest = function onrequest() {
-    stream.req.on('finish', onfinish);
-  };
+/***/ }),
 
-  if (isRequest(stream)) {
-    stream.on('complete', onfinish);
-    stream.on('abort', onclose);
-    if (stream.req) onrequest();else stream.on('request', onrequest);
-  } else if (writable && !stream._writableState) {
-    // legacy streams
-    stream.on('end', onlegacyfinish);
-    stream.on('close', onlegacyfinish);
-  }
+/***/ 19841:
+/***/ ((module) => {
 
-  stream.on('end', onend);
-  stream.on('finish', onfinish);
-  if (opts.error !== false) stream.on('error', onerror);
-  stream.on('close', onclose);
-  return function () {
-    stream.removeListener('complete', onfinish);
-    stream.removeListener('abort', onclose);
-    stream.removeListener('request', onrequest);
-    if (stream.req) stream.req.removeListener('finish', onfinish);
-    stream.removeListener('end', onlegacyfinish);
-    stream.removeListener('close', onlegacyfinish);
-    stream.removeListener('finish', onfinish);
-    stream.removeListener('end', onend);
-    stream.removeListener('error', onerror);
-    stream.removeListener('close', onclose);
-  };
-}
+// Copied from https://github.com/nodejs/node/blob/master/lib/internal/constants.js
+module.exports = {
+  CHAR_FORWARD_SLASH: 47, /* / */
+};
 
-module.exports = eos;
 
 /***/ }),
 
-/***/ 23919:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+/***/ 5604:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
 "use strict";
 
 
-function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) { try { var info = gen[key](arg); var value = info.value; } catch (error) { reject(error); return; } if (info.done) { resolve(value); } else { Promise.resolve(value).then(_next, _throw); } }
-
-function _asyncToGenerator(fn) { return function () { var self = this, args = arguments; return new Promise(function (resolve, reject) { var gen = fn.apply(self, args); function _next(value) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, "next", value); } function _throw(err) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, "throw", err); } _next(undefined); }); }; }
-
-function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }
-
-function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
-
-function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
-
-var ERR_INVALID_ARG_TYPE = (__nccwpck_require__(91042)/* .codes.ERR_INVALID_ARG_TYPE */ .q.ERR_INVALID_ARG_TYPE);
-
-function from(Readable, iterable, opts) {
-  var iterator;
-
-  if (iterable && typeof iterable.next === 'function') {
-    iterator = iterable;
-  } else if (iterable && iterable[Symbol.asyncIterator]) iterator = iterable[Symbol.asyncIterator]();else if (iterable && iterable[Symbol.iterator]) iterator = iterable[Symbol.iterator]();else throw new ERR_INVALID_ARG_TYPE('iterable', ['Iterable'], iterable);
+const path = __nccwpck_require__(71017);
 
-  var readable = new Readable(_objectSpread({
-    objectMode: true
-  }, opts)); // Reading boolean to protect against _read
-  // being called before last iteration completion.
+exports.codes = {
+  ERR_INPUT_TYPE_NOT_ALLOWED: createErrorCtor(joinArgs('ERR_INPUT_TYPE_NOT_ALLOWED')),
+  ERR_INVALID_ARG_VALUE: createErrorCtor(joinArgs('ERR_INVALID_ARG_VALUE')),
+  ERR_INVALID_MODULE_SPECIFIER: createErrorCtor(joinArgs('ERR_INVALID_MODULE_SPECIFIER')),
+  ERR_INVALID_PACKAGE_CONFIG: createErrorCtor(joinArgs('ERR_INVALID_PACKAGE_CONFIG')),
+  ERR_INVALID_PACKAGE_TARGET: createErrorCtor(joinArgs('ERR_INVALID_PACKAGE_TARGET')),
+  ERR_MANIFEST_DEPENDENCY_MISSING: createErrorCtor(joinArgs('ERR_MANIFEST_DEPENDENCY_MISSING')),
+  ERR_MODULE_NOT_FOUND: createErrorCtor((path, base, type = 'package') => {
+    return `Cannot find ${type} '${path}' imported from ${base}`
+  }),
+  ERR_PACKAGE_IMPORT_NOT_DEFINED: createErrorCtor(joinArgs('ERR_PACKAGE_IMPORT_NOT_DEFINED')),
+  ERR_PACKAGE_PATH_NOT_EXPORTED: createErrorCtor(joinArgs('ERR_PACKAGE_PATH_NOT_EXPORTED')),
+  ERR_UNSUPPORTED_DIR_IMPORT: createErrorCtor(joinArgs('ERR_UNSUPPORTED_DIR_IMPORT')),
+  ERR_UNSUPPORTED_ESM_URL_SCHEME: createErrorCtor(joinArgs('ERR_UNSUPPORTED_ESM_URL_SCHEME')),
+  ERR_UNKNOWN_FILE_EXTENSION: createErrorCtor(joinArgs('ERR_UNKNOWN_FILE_EXTENSION')),
+}
 
-  var reading = false;
+function joinArgs(name) {
+  return (...args) => {
+    return [name, ...args].join(' ')
+  }
+}
 
-  readable._read = function () {
-    if (!reading) {
-      reading = true;
-      next();
+function createErrorCtor(errorMessageCreator) {
+  return class CustomError extends Error {
+    constructor(...args) {
+      super(errorMessageCreator(...args))
     }
-  };
-
-  function next() {
-    return _next2.apply(this, arguments);
   }
+}
+exports.createErrRequireEsm = createErrRequireEsm;
 
-  function _next2() {
-    _next2 = _asyncToGenerator(function* () {
-      try {
-        var _ref = yield iterator.next(),
-            value = _ref.value,
-            done = _ref.done;
+// Native ERR_REQUIRE_ESM Error is declared here:
+//   https://github.com/nodejs/node/blob/2d5d77306f6dff9110c1f77fefab25f973415770/lib/internal/errors.js#L1294-L1313
+// Error class factory is implemented here:
+//   function E: https://github.com/nodejs/node/blob/2d5d77306f6dff9110c1f77fefab25f973415770/lib/internal/errors.js#L323-L341
+//   function makeNodeErrorWithCode: https://github.com/nodejs/node/blob/2d5d77306f6dff9110c1f77fefab25f973415770/lib/internal/errors.js#L251-L278
+// The code below should create an error that matches the native error as closely as possible.
+// Third-party libraries which attempt to catch the native ERR_REQUIRE_ESM should recognize our imitation error.
+function createErrRequireEsm(filename, parentPath, packageJsonPath) {
+  const code = 'ERR_REQUIRE_ESM'
+  const err = new Error(getErrRequireEsmMessage(filename, parentPath, packageJsonPath))
+  // Set `name` to be used in stack trace, generate stack trace with that name baked in, then re-declare the `name` field.
+  // This trick is copied from node's source.
+  err.name = `Error [${ code }]`
+  err.stack
+  Object.defineProperty(err, 'name', {
+    value: 'Error',
+    enumerable: false,
+    writable: true,
+    configurable: true
+  })
+  err.code = code
+  return err
+}
 
-        if (done) {
-          readable.push(null);
-        } else if (readable.push((yield value))) {
-          next();
-        } else {
-          reading = false;
-        }
-      } catch (err) {
-        readable.destroy(err);
-      }
-    });
-    return _next2.apply(this, arguments);
+// Copy-pasted from https://github.com/nodejs/node/blob/b533fb3508009e5f567cc776daba8fbf665386a6/lib/internal/errors.js#L1293-L1311
+// so that our error message is identical to the native message.
+function getErrRequireEsmMessage(filename, parentPath = null, packageJsonPath = null) {
+  const ext = path.extname(filename)
+  let msg = `Must use import to load ES Module: ${filename}`;
+  if (parentPath && packageJsonPath) {
+    const path = __nccwpck_require__(71017);
+    const basename = path.basename(filename) === path.basename(parentPath) ?
+      filename : path.basename(filename);
+    msg +=
+      '\nrequire() of ES modules is not supported.\nrequire() of ' +
+      `${filename} ${parentPath ? `from ${parentPath} ` : ''}` +
+      `is an ES module file as it is a ${ext} file whose nearest parent ` +
+      `package.json contains "type": "module" which defines all ${ext} ` +
+      'files in that package scope as ES modules.\nInstead ' +
+      'change the requiring code to use ' +
+      'import(), or remove "type": "module" from ' +
+      `${packageJsonPath}.\n`;
+    return msg;
   }
-
-  return readable;
+  return msg;
 }
 
-module.exports = from;
 
 /***/ }),
 
-/***/ 72928:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+/***/ 2076:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
 "use strict";
-// Ported from https://github.com/mafintosh/pump with
-// permission from the author, Mathias Buus (@mafintosh).
-
-
-var eos;
+// Copied from https://github.com/nodejs/node/blob/v17.0.1/lib/internal/modules/cjs/helpers.js
 
-function once(callback) {
-  var called = false;
-  return function () {
-    if (called) return;
-    called = true;
-    callback.apply(void 0, arguments);
-  };
-}
 
-var _require$codes = (__nccwpck_require__(91042)/* .codes */ .q),
-    ERR_MISSING_ARGS = _require$codes.ERR_MISSING_ARGS,
-    ERR_STREAM_DESTROYED = _require$codes.ERR_STREAM_DESTROYED;
 
-function noop(err) {
-  // Rethrow the error if it exists to avoid swallowing it
-  if (err) throw err;
-}
+const {
+  ArrayPrototypeForEach,
+  ObjectDefineProperty,
+  ObjectPrototypeHasOwnProperty,
+  SafeSet,
+  StringPrototypeIncludes,
+  StringPrototypeStartsWith,
+} = __nccwpck_require__(57523);
 
-function isRequest(stream) {
-  return stream.setHeader && typeof stream.abort === 'function';
-}
+const { getOptionValue } = __nccwpck_require__(92060);
+const userConditions = getOptionValue('--conditions');
 
-function destroyer(stream, reading, writing, callback) {
-  callback = once(callback);
-  var closed = false;
-  stream.on('close', function () {
-    closed = true;
-  });
-  if (eos === undefined) eos = __nccwpck_require__(40841);
-  eos(stream, {
-    readable: reading,
-    writable: writing
-  }, function (err) {
-    if (err) return callback(err);
-    closed = true;
-    callback();
-  });
-  var destroyed = false;
-  return function (err) {
-    if (closed) return;
-    if (destroyed) return;
-    destroyed = true; // request.destroy just do .end - .abort is what we want
+const noAddons = getOptionValue('--no-addons');
+const addonConditions = noAddons ? [] : ['node-addons'];
 
-    if (isRequest(stream)) return stream.abort();
-    if (typeof stream.destroy === 'function') return stream.destroy();
-    callback(err || new ERR_STREAM_DESTROYED('pipe'));
-  };
-}
+// TODO: Use this set when resolving pkg#exports conditions in loader.js.
+const cjsConditions = new SafeSet([
+  'require',
+  'node',
+  ...addonConditions,
+  ...userConditions,
+]);
 
-function call(fn) {
-  fn();
-}
+/**
+ * @param {any} object
+ * @param {string} [dummyModuleName]
+ * @return {void}
+ */
+function addBuiltinLibsToObject(object, dummyModuleName) {
+  // Make built-in modules available directly (loaded lazily).
+  const Module = (__nccwpck_require__(98188).Module);
+  const { builtinModules } = Module;
 
-function pipe(from, to) {
-  return from.pipe(to);
-}
+  // To require built-in modules in user-land and ignore modules whose
+  // `canBeRequiredByUsers` is false. So we create a dummy module object and not
+  // use `require()` directly.
+  const dummyModule = new Module(dummyModuleName);
 
-function popCallback(streams) {
-  if (!streams.length) return noop;
-  if (typeof streams[streams.length - 1] !== 'function') return noop;
-  return streams.pop();
-}
+  ArrayPrototypeForEach(builtinModules, (name) => {
+    // Neither add underscored modules, nor ones that contain slashes (e.g.,
+    // 'fs/promises') or ones that are already defined.
+    if (StringPrototypeStartsWith(name, '_') ||
+        StringPrototypeIncludes(name, '/') ||
+        ObjectPrototypeHasOwnProperty(object, name)) {
+      return;
+    }
+    // Goals of this mechanism are:
+    // - Lazy loading of built-in modules
+    // - Having all built-in modules available as non-enumerable properties
+    // - Allowing the user to re-assign these variables as if there were no
+    //   pre-existing globals with the same name.
 
-function pipeline() {
-  for (var _len = arguments.length, streams = new Array(_len), _key = 0; _key < _len; _key++) {
-    streams[_key] = arguments[_key];
-  }
+    const setReal = (val) => {
+      // Deleting the property before re-assigning it disables the
+      // getter/setter mechanism.
+      delete object[name];
+      object[name] = val;
+    };
 
-  var callback = popCallback(streams);
-  if (Array.isArray(streams[0])) streams = streams[0];
+    ObjectDefineProperty(object, name, {
+      get: () => {
+        // Node 12 hack; remove when we drop node12 support
+        const lib = (dummyModule.require || require)(name);
 
-  if (streams.length < 2) {
-    throw new ERR_MISSING_ARGS('streams');
-  }
+        // Disable the current getter/setter and set up a new
+        // non-enumerable property.
+        delete object[name];
+        ObjectDefineProperty(object, name, {
+          get: () => lib,
+          set: setReal,
+          configurable: true,
+          enumerable: false
+        });
 
-  var error;
-  var destroys = streams.map(function (stream, i) {
-    var reading = i < streams.length - 1;
-    var writing = i > 0;
-    return destroyer(stream, reading, writing, function (err) {
-      if (!error) error = err;
-      if (err) destroys.forEach(call);
-      if (reading) return;
-      destroys.forEach(call);
-      callback(error);
+        return lib;
+      },
+      set: setReal,
+      configurable: true,
+      enumerable: false
     });
   });
-  return streams.reduce(pipe);
 }
 
-module.exports = pipeline;
+exports.addBuiltinLibsToObject = addBuiltinLibsToObject;
+exports.cjsConditions = cjsConditions;
+
 
 /***/ }),
 
-/***/ 97458:
+/***/ 88232:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
+// Copied from several files in node's source code.
+// https://github.com/nodejs/node/blob/2d5d77306f6dff9110c1f77fefab25f973415770/lib/internal/modules/cjs/loader.js
+// Each function and variable below must have a comment linking to the source in node's github repo.
 
 
-var ERR_INVALID_OPT_VALUE = (__nccwpck_require__(91042)/* .codes.ERR_INVALID_OPT_VALUE */ .q.ERR_INVALID_OPT_VALUE);
 
-function highWaterMarkFrom(options, isDuplex, duplexKey) {
-  return options.highWaterMark != null ? options.highWaterMark : isDuplex ? options[duplexKey] : null;
-}
+const {
+  ArrayIsArray,
+  ArrayPrototypeIncludes,
+  ArrayPrototypeJoin,
+  ArrayPrototypePush,
+  JSONParse,
+  ObjectKeys,
+  RegExpPrototypeTest,
+  SafeMap,
+  SafeWeakMap,
+  StringPrototypeCharCodeAt,
+  StringPrototypeEndsWith,
+  StringPrototypeLastIndexOf,
+  StringPrototypeIndexOf,
+  StringPrototypeMatch,
+  StringPrototypeSlice,
+  StringPrototypeStartsWith,
+} = __nccwpck_require__(57523);
+const { NativeModule } = __nccwpck_require__(12061);
+const { pathToFileURL, fileURLToPath } = __nccwpck_require__(57310);
+const fs = __nccwpck_require__(57147);
+const path = __nccwpck_require__(71017);
+const { sep } = path;
+const { internalModuleStat } = __nccwpck_require__(69149);
+const packageJsonReader = __nccwpck_require__(73104);
+const {
+  cjsConditions,
+} = __nccwpck_require__(2076);
+const { getOptionValue } = __nccwpck_require__(92060);
+const preserveSymlinks = getOptionValue('--preserve-symlinks');
+const preserveSymlinksMain = getOptionValue('--preserve-symlinks-main');
+const {normalizeSlashes} = __nccwpck_require__(26239);
+const {createErrRequireEsm} = __nccwpck_require__(5604);
+const {
+  codes: {
+    ERR_INVALID_MODULE_SPECIFIER,
+  },
+} = __nccwpck_require__(5604);
 
-function getHighWaterMark(state, options, duplexKey, isDuplex) {
-  var hwm = highWaterMarkFrom(options, isDuplex, duplexKey);
+const {
+  CHAR_FORWARD_SLASH,
+} = __nccwpck_require__(19841);
 
-  if (hwm != null) {
-    if (!(isFinite(hwm) && Math.floor(hwm) === hwm) || hwm < 0) {
-      var name = isDuplex ? duplexKey : 'highWaterMark';
-      throw new ERR_INVALID_OPT_VALUE(name, hwm);
-    }
+const Module = __nccwpck_require__(98188);
 
-    return Math.floor(hwm);
-  } // Default value
+const isWindows = process.platform === 'win32';
 
+let statCache = null;
 
-  return state.objectMode ? 16 : 16 * 1024;
+function stat(filename) {
+  filename = path.toNamespacedPath(filename);
+  if (statCache !== null) {
+    const result = statCache.get(filename);
+    if (result !== undefined) return result;
+  }
+  const result = internalModuleStat(filename);
+  if (statCache !== null && result >= 0) {
+    // Only set cache when `internalModuleStat(filename)` succeeds.
+    statCache.set(filename, result);
+  }
+  return result;
 }
 
-module.exports = {
-  getHighWaterMark: getHighWaterMark
-};
+// Note:
+// we cannot get access to node's internal cache, which is populated from
+// within node's Module constructor.  So the cache here will always be empty.
+// It's possible we could approximate our own cache by building it up with
+// hacky workarounds, but it's not worth the complexity and flakiness.
+const moduleParentCache = new SafeWeakMap();
 
-/***/ }),
+// Given a module name, and a list of paths to test, returns the first
+// matching file in the following precedence.
+//
+// require("a.")
+//   -> a.
+//
+// require("a")
+//   -> a
+//   -> a.
+//   -> a/index.
 
-/***/ 4297:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+const packageJsonCache = new SafeMap();
 
-module.exports = __nccwpck_require__(12781);
+function readPackage(requestPath) {
+  const jsonPath = path.resolve(requestPath, 'package.json');
 
+  const existing = packageJsonCache.get(jsonPath);
+  if (existing !== undefined) return existing;
 
-/***/ }),
+  const result = packageJsonReader.read(jsonPath);
+  const json = result.containsKeys === false ? '{}' : result.string;
+  if (json === undefined) {
+    packageJsonCache.set(jsonPath, false);
+    return false;
+  }
 
-/***/ 88550:
-/***/ ((module, exports, __nccwpck_require__) => {
+  try {
+    const parsed = JSONParse(json);
+    const filtered = {
+      name: parsed.name,
+      main: parsed.main,
+      exports: parsed.exports,
+      imports: parsed.imports,
+      type: parsed.type
+    };
+    packageJsonCache.set(jsonPath, filtered);
+    return filtered;
+  } catch (e) {
+    e.path = jsonPath;
+    e.message = 'Error parsing ' + jsonPath + ': ' + e.message;
+    throw e;
+  }
+}
 
-var Stream = __nccwpck_require__(12781);
-if (process.env.READABLE_STREAM === 'disable' && Stream) {
-  module.exports = Stream.Readable;
-  Object.assign(module.exports, Stream);
-  module.exports.Stream = Stream;
-} else {
-  exports = module.exports = __nccwpck_require__(17911);
-  exports.Stream = Stream || exports;
-  exports.Readable = exports;
-  exports.Writable = __nccwpck_require__(51898);
-  exports.Duplex = __nccwpck_require__(25408);
-  exports.Transform = __nccwpck_require__(660);
-  exports.PassThrough = __nccwpck_require__(37838);
-  exports.finished = __nccwpck_require__(40841);
-  exports.pipeline = __nccwpck_require__(72928);
+function readPackageScope(checkPath) {
+  const rootSeparatorIndex = StringPrototypeIndexOf(checkPath, sep);
+  let separatorIndex;
+  do {
+    separatorIndex = StringPrototypeLastIndexOf(checkPath, sep);
+    checkPath = StringPrototypeSlice(checkPath, 0, separatorIndex);
+    if (StringPrototypeEndsWith(checkPath, sep + 'node_modules'))
+      return false;
+    const pjson = readPackage(checkPath + sep);
+    if (pjson) return {
+      data: pjson,
+      path: checkPath,
+    };
+  } while (separatorIndex > rootSeparatorIndex);
+  return false;
 }
 
+/**
+ * @param {{
+ *   nodeEsmResolver: ReturnType,
+ *   extensions: import('../src/file-extensions').Extensions,
+ *   preferTsExts
+ * }} opts
+ */
+function createCjsLoader(opts) {
+const {nodeEsmResolver, preferTsExts} = opts;
+const {replacementsForCjs, replacementsForJs, replacementsForMjs, replacementsForJsx} = opts.extensions;
+const {
+  encodedSepRegEx,
+  packageExportsResolve,
+  packageImportsResolve
+} = nodeEsmResolver;
 
-/***/ }),
+function tryPackage(requestPath, exts, isMain, originalPath) {
+  // const pkg = readPackage(requestPath)?.main;
+  const tmp = readPackage(requestPath)
+  const pkg = tmp != null ? tmp.main : undefined;
 
-/***/ 14567:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+  if (!pkg) {
+    return tryExtensions(path.resolve(requestPath, 'index'), exts, isMain);
+  }
 
-"use strict";
+  const filename = path.resolve(requestPath, pkg);
+  let actual = tryReplacementExtensions(filename, isMain) ||
+    tryFile(filename, isMain) ||
+    tryExtensions(filename, exts, isMain) ||
+    tryExtensions(path.resolve(filename, 'index'), exts, isMain);
+  if (actual === false) {
+    actual = tryExtensions(path.resolve(requestPath, 'index'), exts, isMain);
+    if (!actual) {
+      // eslint-disable-next-line no-restricted-syntax
+      const err = new Error(
+        `Cannot find module '${filename}'. ` +
+        'Please verify that the package.json has a valid "main" entry'
+      );
+      err.code = 'MODULE_NOT_FOUND';
+      err.path = path.resolve(requestPath, 'package.json');
+      err.requestPath = originalPath;
+      // TODO(BridgeAR): Add the requireStack as well.
+      throw err;
+    } else {
+      const jsonPath = path.resolve(requestPath, 'package.json');
+      process.emitWarning(
+        `Invalid 'main' field in '${jsonPath}' of '${pkg}'. ` +
+          'Please either fix that or report it to the module author',
+        'DeprecationWarning',
+        'DEP0128'
+      );
+    }
+  }
+  return actual;
+}
 
+// In order to minimize unnecessary lstat() calls,
+// this cache is a list of known-real paths.
+// Set to an empty Map to reset.
+const realpathCache = new SafeMap();
 
-var fs = __nccwpck_require__(57147),
-  join = (__nccwpck_require__(71017).join),
-  resolve = (__nccwpck_require__(71017).resolve),
-  dirname = (__nccwpck_require__(71017).dirname),
-  defaultOptions = {
-    extensions: ['js', 'json', 'coffee'],
-    recurse: true,
-    rename: function (name) {
-      return name;
-    },
-    visit: function (obj) {
-      return obj;
-    }
-  };
+// Check if the file exists and is not a directory
+// if using --preserve-symlinks and isMain is false,
+// keep symlinks intact, otherwise resolve to the
+// absolute realpath.
+function tryFile(requestPath, isMain) {
+  const rc = stat(requestPath);
+  if (rc !== 0) return;
+  if (preserveSymlinks && !isMain) {
+    return path.resolve(requestPath);
+  }
+  return toRealPath(requestPath);
+}
 
-function checkFileInclusion(path, filename, options) {
-  return (
-    // verify file has valid extension
-    (new RegExp('\\.(' + options.extensions.join('|') + ')$', 'i').test(filename)) &&
+function toRealPath(requestPath) {
+  return fs.realpathSync(requestPath, {
+    // [internalFS.realpathCacheKey]: realpathCache
+  });
+}
 
-    // if options.include is a RegExp, evaluate it and make sure the path passes
-    !(options.include && options.include instanceof RegExp && !options.include.test(path)) &&
+function statReplacementExtensions(p) {
+  const lastDotIndex = p.lastIndexOf('.');
+  if(lastDotIndex >= 0) {
+    const ext = p.slice(lastDotIndex);
+    if (ext === '.js' || ext === '.jsx' || ext === '.mjs' || ext === '.cjs') {
+      const pathnameWithoutExtension = p.slice(0, lastDotIndex);
+      const replacementExts =
+        ext === '.js' ? replacementsForJs
+        : ext === '.jsx' ? replacementsForJsx
+        : ext === '.mjs' ? replacementsForMjs
+        : replacementsForCjs;
+      for (let i = 0; i < replacementExts.length; i++) {
+        const filename = pathnameWithoutExtension + replacementExts[i];
+        const rc = stat(filename);
+        if (rc === 0) {
+          return [rc, filename];
+        }
+      }
+    }
+  }
+  return [stat(p), p];
+}
+function tryReplacementExtensions(p, isMain) {
+  const lastDotIndex = p.lastIndexOf('.');
+  if(lastDotIndex >= 0) {
+    const ext = p.slice(lastDotIndex);
+    if (ext === '.js' || ext === '.jsx' || ext === '.mjs' || ext === '.cjs') {
+      const pathnameWithoutExtension = p.slice(0, lastDotIndex);
+      const replacementExts =
+        ext === '.js' ? replacementsForJs
+        : ext === '.jsx' ? replacementsForJsx
+        : ext === '.mjs' ? replacementsForMjs
+        : replacementsForCjs;
+      for (let i = 0; i < replacementExts.length; i++) {
+        const filename = tryFile(pathnameWithoutExtension + replacementExts[i], isMain);
+        if (filename) {
+          return filename;
+        }
+      }
+    }
+  }
+  return false;
+}
 
-    // if options.include is a function, evaluate it and make sure the path passes
-    !(options.include && typeof options.include === 'function' && !options.include(path, filename)) &&
+// Given a path, check if the file exists with any of the set extensions
+function tryExtensions(p, exts, isMain) {
+  for (let i = 0; i < exts.length; i++) {
+    const filename = tryFile(p + exts[i], isMain);
 
-    // if options.exclude is a RegExp, evaluate it and make sure the path doesn't pass
-    !(options.exclude && options.exclude instanceof RegExp && options.exclude.test(path)) &&
+    if (filename) {
+      return filename;
+    }
+  }
+  return false;
+}
 
-    // if options.exclude is a function, evaluate it and make sure the path doesn't pass
-    !(options.exclude && typeof options.exclude === 'function' && options.exclude(path, filename))
-  );
+function trySelfParentPath(parent) {
+  if (!parent) return false;
+
+  if (parent.filename) {
+    return parent.filename;
+  } else if (parent.id === '' || parent.id === 'internal/preload') {
+    try {
+      return process.cwd() + path.sep;
+    } catch {
+      return false;
+    }
+  }
 }
 
-function requireDirectory(m, path, options) {
-  var retval = {};
+function trySelf(parentPath, request) {
+  if (!parentPath) return false;
 
-  // path is optional
-  if (path && !options && typeof path !== 'string') {
-    options = path;
-    path = null;
+  const { data: pkg, path: pkgPath } = readPackageScope(parentPath) || {};
+  if (!pkg || pkg.exports === undefined) return false;
+  if (typeof pkg.name !== 'string') return false;
+
+  let expansion;
+  if (request === pkg.name) {
+    expansion = '.';
+  } else if (StringPrototypeStartsWith(request, `${pkg.name}/`)) {
+    expansion = '.' + StringPrototypeSlice(request, pkg.name.length);
+  } else {
+    return false;
   }
 
-  // default options
-  options = options || {};
-  for (var prop in defaultOptions) {
-    if (typeof options[prop] === 'undefined') {
-      options[prop] = defaultOptions[prop];
+  try {
+    return finalizeEsmResolution(packageExportsResolve(
+      pathToFileURL(pkgPath + '/package.json'), expansion, pkg,
+      pathToFileURL(parentPath), cjsConditions).resolved, parentPath, pkgPath);
+  } catch (e) {
+    if (e.code === 'ERR_MODULE_NOT_FOUND')
+      throw createEsmNotFoundErr(request, pkgPath + '/package.json');
+    throw e;
+  }
+}
+
+// This only applies to requests of a specific form:
+// 1. name/.*
+// 2. @scope/name/.*
+const EXPORTS_PATTERN = /^((?:@[^/\\%]+\/)?[^./\\%][^/\\%]*)(\/.*)?$/;
+function resolveExports(nmPath, request) {
+  // The implementation's behavior is meant to mirror resolution in ESM.
+  const { 1: name, 2: expansion = '' } =
+    StringPrototypeMatch(request, EXPORTS_PATTERN) || [];
+  if (!name)
+    return;
+  const pkgPath = path.resolve(nmPath, name);
+  const pkg = readPackage(pkgPath);
+  // if (pkg?.exports != null) {
+  if (pkg != null && pkg.exports != null) {
+    try {
+      return finalizeEsmResolution(packageExportsResolve(
+        pathToFileURL(pkgPath + '/package.json'), '.' + expansion, pkg, null,
+        cjsConditions).resolved, null, pkgPath);
+    } catch (e) {
+      if (e.code === 'ERR_MODULE_NOT_FOUND')
+        throw createEsmNotFoundErr(request, pkgPath + '/package.json');
+      throw e;
     }
   }
+}
 
-  // if no path was passed in, assume the equivelant of __dirname from caller
-  // otherwise, resolve path relative to the equivalent of __dirname
-  path = !path ? dirname(m.filename) : resolve(dirname(m.filename), path);
+// Backwards compat for old node versions
+const hasModulePathCache = !!(__nccwpck_require__(98188)._pathCache);
+const Module_pathCache = Object.create(null);
+const Module_pathCache_get = hasModulePathCache ? (cacheKey) => Module._pathCache[cacheKey] : (cacheKey) => Module_pathCache[cacheKey];
+const Module_pathCache_set = hasModulePathCache ? (cacheKey, value) => (Module._pathCache[cacheKey] = value) : (cacheKey) => (Module_pathCache[cacheKey] = value);
 
-  // get the path of each file in specified directory, append to current tree node, recurse
-  fs.readdirSync(path).forEach(function (filename) {
-    var joined = join(path, filename),
-      files,
-      key,
-      obj;
+const trailingSlashRegex = /(?:^|\/)\.?\.$/;
+const Module_findPath = function _findPath(request, paths, isMain) {
+  const absoluteRequest = path.isAbsolute(request);
+  if (absoluteRequest) {
+    paths = [''];
+  } else if (!paths || paths.length === 0) {
+    return false;
+  }
 
-    if (fs.statSync(joined).isDirectory() && options.recurse) {
-      // this node is a directory; recurse
-      files = requireDirectory(m, joined, options);
-      // exclude empty directories
-      if (Object.keys(files).length) {
-        retval[options.rename(filename, joined, filename)] = files;
+  const cacheKey = request + '\x00' + ArrayPrototypeJoin(paths, '\x00');
+  const entry = Module_pathCache_get(cacheKey);
+  if (entry)
+    return entry;
+
+  let exts;
+  let trailingSlash = request.length > 0 &&
+    StringPrototypeCharCodeAt(request, request.length - 1) ===
+    CHAR_FORWARD_SLASH;
+  if (!trailingSlash) {
+    trailingSlash = RegExpPrototypeTest(trailingSlashRegex, request);
+  }
+
+  // For each path
+  for (let i = 0; i < paths.length; i++) {
+    // Don't search further if path doesn't exist
+    const curPath = paths[i];
+    if (curPath && stat(curPath) < 1) continue;
+
+    if (!absoluteRequest) {
+      const exportsResolved = resolveExports(curPath, request);
+      if (exportsResolved)
+        return exportsResolved;
+    }
+
+    const _basePath = path.resolve(curPath, request);
+    let filename;
+
+    const [rc, basePath] = statReplacementExtensions(_basePath);
+    if (!trailingSlash) {
+      if (rc === 0) {  // File.
+        if (!isMain) {
+          if (preserveSymlinks) {
+            filename = path.resolve(basePath);
+          } else {
+            filename = toRealPath(basePath);
+          }
+        } else if (preserveSymlinksMain) {
+          // For the main module, we use the preserveSymlinksMain flag instead
+          // mainly for backward compatibility, as the preserveSymlinks flag
+          // historically has not applied to the main module.  Most likely this
+          // was intended to keep .bin/ binaries working, as following those
+          // symlinks is usually required for the imports in the corresponding
+          // files to resolve; that said, in some use cases following symlinks
+          // causes bigger problems which is why the preserveSymlinksMain option
+          // is needed.
+          filename = path.resolve(basePath);
+        } else {
+          filename = toRealPath(basePath);
+        }
       }
-    } else {
-      if (joined !== m.filename && checkFileInclusion(joined, filename, options)) {
-        // hash node key shouldn't include file extension
-        key = filename.substring(0, filename.lastIndexOf('.'));
-        obj = m.require(joined);
-        retval[options.rename(key, joined, filename)] = options.visit(obj, joined, filename) || obj;
+
+      if (!filename) {
+        // Try it with each of the extensions
+        if (exts === undefined)
+          exts = ObjectKeys(Module._extensions);
+        filename = tryExtensions(basePath, exts, isMain);
       }
     }
-  });
 
-  return retval;
-}
+    if (!filename && rc === 1) {  // Directory.
+      // try it with each of the extensions at "index"
+      if (exts === undefined)
+        exts = ObjectKeys(Module._extensions);
+      filename = tryPackage(basePath, exts, isMain, request);
+    }
 
-module.exports = requireDirectory;
-module.exports.defaults = defaultOptions;
+    if (filename) {
+      Module_pathCache_set(cacheKey, filename);
+      return filename;
+    }
+  }
 
+  return false;
+};
 
-/***/ }),
+const Module_resolveFilename = function _resolveFilename(request, parent, isMain, options) {
+  if (StringPrototypeStartsWith(request, 'node:') ||
+      NativeModule.canBeRequiredByUsers(request)) {
+    return request;
+  }
 
-/***/ 36873:
-/***/ ((module) => {
+  let paths;
 
-"use strict";
+  if (typeof options === 'object' && options !== null) {
+    if (ArrayIsArray(options.paths)) {
+      const isRelative = StringPrototypeStartsWith(request, './') ||
+          StringPrototypeStartsWith(request, '../') ||
+          ((isWindows && StringPrototypeStartsWith(request, '.\\')) ||
+          StringPrototypeStartsWith(request, '..\\'));
 
+      if (isRelative) {
+        paths = options.paths;
+      } else {
+        const fakeParent = new Module('', null);
 
-function reusify (Constructor) {
-  var head = new Constructor()
-  var tail = head
+        paths = [];
 
-  function get () {
-    var current = head
+        for (let i = 0; i < options.paths.length; i++) {
+          const path = options.paths[i];
+          fakeParent.paths = Module._nodeModulePaths(path);
+          const lookupPaths = Module._resolveLookupPaths(request, fakeParent);
 
-    if (current.next) {
-      head = current.next
+          for (let j = 0; j < lookupPaths.length; j++) {
+            if (!ArrayPrototypeIncludes(paths, lookupPaths[j]))
+              ArrayPrototypePush(paths, lookupPaths[j]);
+          }
+        }
+      }
+    } else if (options.paths === undefined) {
+      paths = Module._resolveLookupPaths(request, parent);
     } else {
-      head = new Constructor()
-      tail = head
+      throw new ERR_INVALID_ARG_VALUE('options.paths', options.paths);
     }
+  } else {
+    paths = Module._resolveLookupPaths(request, parent);
+  }
 
-    current.next = null
+  // if (parent?.filename) {
+  // node 12 hack
+  if (parent != null && parent.filename) {
+    if (request[0] === '#') {
+      const pkg = readPackageScope(parent.filename) || {};
 
-    return current
+      // if (pkg.data?.imports != null) {
+      // node 12 hack
+      if (pkg.data != null && pkg.data.imports != null) {
+        try {
+          return finalizeEsmResolution(
+            packageImportsResolve(request, pathToFileURL(parent.filename),
+                                  cjsConditions), parent.filename,
+            pkg.path);
+        } catch (e) {
+          if (e.code === 'ERR_MODULE_NOT_FOUND')
+            throw createEsmNotFoundErr(request);
+          throw e;
+        }
+      }
+    }
   }
 
-  function release (obj) {
-    tail.next = obj
-    tail = obj
+  // Try module self resolution first
+  const parentPath = trySelfParentPath(parent);
+  const selfResolved = trySelf(parentPath, request);
+  if (selfResolved) {
+    const cacheKey = request + '\x00' +
+         (paths.length === 1 ? paths[0] : ArrayPrototypeJoin(paths, '\x00'));
+    Module._pathCache[cacheKey] = selfResolved;
+    return selfResolved;
   }
 
-  return {
-    get: get,
-    release: release
+  // Look up the filename first, since that's the cache key.
+  const filename = Module._findPath(request, paths, isMain, false);
+  if (filename) return filename;
+  const requireStack = [];
+  for (let cursor = parent;
+    cursor;
+    cursor = moduleParentCache.get(cursor)) {
+    ArrayPrototypePush(requireStack, cursor.filename || cursor.id);
   }
-}
-
-module.exports = reusify
+  let message = `Cannot find module '${request}'`;
+  if (requireStack.length > 0) {
+    message = message + '\nRequire stack:\n- ' +
+              ArrayPrototypeJoin(requireStack, '\n- ');
+  }
+  // eslint-disable-next-line no-restricted-syntax
+  const err = new Error(message);
+  err.code = 'MODULE_NOT_FOUND';
+  err.requireStack = requireStack;
+  throw err;
+};
 
+function finalizeEsmResolution(resolved, parentPath, pkgPath) {
+  if (RegExpPrototypeTest(encodedSepRegEx, resolved))
+    throw new ERR_INVALID_MODULE_SPECIFIER(
+      resolved, 'must not include encoded "/" or "\\" characters', parentPath);
+  const filename = fileURLToPath(resolved);
+  const actual = tryReplacementExtensions(filename) || tryFile(filename);
+  if (actual)
+    return actual;
+  const err = createEsmNotFoundErr(filename,
+                                   path.resolve(pkgPath, 'package.json'));
+  throw err;
+}
 
-/***/ }),
+function createEsmNotFoundErr(request, path) {
+  // eslint-disable-next-line no-restricted-syntax
+  const err = new Error(`Cannot find module '${request}'`);
+  err.code = 'MODULE_NOT_FOUND';
+  if (path)
+    err.path = path;
+  // TODO(BridgeAR): Add the requireStack as well.
+  return err;
+}
 
-/***/ 8414:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
-const assert = __nccwpck_require__(39491)
-const path = __nccwpck_require__(71017)
-const fs = __nccwpck_require__(57147)
-let glob = undefined
-try {
-  glob = __nccwpck_require__(20557)
-} catch (_err) {
-  // treat glob as optional.
+return {
+  Module_findPath,
+  Module_resolveFilename
 }
 
-const defaultGlobOpts = {
-  nosort: true,
-  silent: true
 }
 
-// for EMFILE handling
-let timeout = 0
+/**
+ * copied from Module._extensions['.js']
+ * https://github.com/nodejs/node/blob/v15.3.0/lib/internal/modules/cjs/loader.js#L1113-L1120
+ * @param {import('../src/index').Service} service
+ * @param {NodeJS.Module} module
+ * @param {string} filename
+ */
+function assertScriptCanLoadAsCJSImpl(service, module, filename) {
+  const pkg = readPackageScope(filename);
 
-const isWindows = (process.platform === "win32")
+  // ts-node modification: allow our configuration to override
+  const tsNodeClassification = service.moduleTypeClassifier.classifyModuleByModuleTypeOverrides(normalizeSlashes(filename));
+  if(tsNodeClassification.moduleType === 'cjs') return;
 
-const defaults = options => {
-  const methods = [
-    'unlink',
-    'chmod',
-    'stat',
-    'lstat',
-    'rmdir',
-    'readdir'
-  ]
-  methods.forEach(m => {
-    options[m] = options[m] || fs[m]
-    m = m + 'Sync'
-    options[m] = options[m] || fs[m]
-  })
+  // ignore package.json when file extension is ESM-only or CJS-only
+  // [MUST_UPDATE_FOR_NEW_FILE_EXTENSIONS]
+  const lastDotIndex = filename.lastIndexOf('.');
+  const ext = lastDotIndex >= 0 ? filename.slice(lastDotIndex) : '';
 
-  options.maxBusyTries = options.maxBusyTries || 3
-  options.emfileWait = options.emfileWait || 1000
-  if (options.glob === false) {
-    options.disableGlob = true
-  }
-  if (options.disableGlob !== true && glob === undefined) {
-    throw Error('glob dependency not found, set `options.disableGlob = true` if intentional')
+  if((ext === '.cts' || ext === '.cjs') && tsNodeClassification.moduleType === 'auto') return;
+
+  // Function require shouldn't be used in ES modules.
+  if (ext === '.mts' || ext === '.mjs' || tsNodeClassification.moduleType === 'esm' || (pkg && pkg.data && pkg.data.type === 'module')) {
+    const parentPath = module.parent && module.parent.filename;
+    const packageJsonPath = pkg ? path.resolve(pkg.path, 'package.json') : null;
+    throw createErrRequireEsm(filename, parentPath, packageJsonPath);
   }
-  options.disableGlob = options.disableGlob || false
-  options.glob = options.glob || defaultGlobOpts
 }
 
-const rimraf = (p, options, cb) => {
-  if (typeof options === 'function') {
-    cb = options
-    options = {}
-  }
 
-  assert(p, 'rimraf: missing path')
-  assert.equal(typeof p, 'string', 'rimraf: path should be a string')
-  assert.equal(typeof cb, 'function', 'rimraf: callback function required')
-  assert(options, 'rimraf: invalid options argument provided')
-  assert.equal(typeof options, 'object', 'rimraf: options should be object')
+module.exports = {
+  createCjsLoader,
+  assertScriptCanLoadAsCJSImpl,
+  readPackageScope
+};
 
-  defaults(options)
 
-  let busyTries = 0
-  let errState = null
-  let n = 0
+/***/ }),
 
-  const next = (er) => {
-    errState = errState || er
-    if (--n === 0)
-      cb(errState)
-  }
+/***/ 17604:
+/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
-  const afterGlob = (er, results) => {
-    if (er)
-      return cb(er)
+"use strict";
+// Copied from https://raw.githubusercontent.com/nodejs/node/v15.3.0/lib/internal/modules/esm/get_format.js
 
-    n = results.length
-    if (n === 0)
-      return cb()
 
-    results.forEach(p => {
-      const CB = (er) => {
-        if (er) {
-          if ((er.code === "EBUSY" || er.code === "ENOTEMPTY" || er.code === "EPERM") &&
-              busyTries < options.maxBusyTries) {
-            busyTries ++
-            // try again, with the same exact callback as this one.
-            return setTimeout(() => rimraf_(p, options, CB), busyTries * 100)
-          }
+const {
+  RegExpPrototypeExec,
+  StringPrototypeStartsWith,
+} = __nccwpck_require__(57523);
+const { extname } = __nccwpck_require__(71017);
+const { getOptionValue } = __nccwpck_require__(92060);
 
-          // this one won't happen if graceful-fs is used.
-          if (er.code === "EMFILE" && timeout < options.emfileWait) {
-            return setTimeout(() => rimraf_(p, options, CB), timeout ++)
-          }
+const [nodeMajor, nodeMinor] = process.versions.node.split('.').map(s => parseInt(s, 10));
+const experimentalJsonModules =
+  nodeMajor > 17
+  || (nodeMajor === 17 && nodeMinor >= 5)
+  || (nodeMajor === 16 && nodeMinor >= 15)
+  || getOptionValue('--experimental-json-modules');
+const experimentalWasmModules = getOptionValue('--experimental-wasm-modules');
+const { URL, fileURLToPath } = __nccwpck_require__(57310);
+const { ERR_UNKNOWN_FILE_EXTENSION } = (__nccwpck_require__(5604).codes);
 
-          // already gone
-          if (er.code === "ENOENT") er = null
-        }
+const extensionFormatMap = {
+  '__proto__': null,
+  '.cjs': 'commonjs',
+  '.js': 'module',
+  '.mjs': 'module'
+};
 
-        timeout = 0
-        next(er)
+const legacyExtensionFormatMap = {
+  '__proto__': null,
+  '.cjs': 'commonjs',
+  '.js': 'commonjs',
+  '.json': 'commonjs',
+  '.mjs': 'module',
+  '.node': 'commonjs'
+};
+
+if (experimentalWasmModules)
+  extensionFormatMap['.wasm'] = legacyExtensionFormatMap['.wasm'] = 'wasm';
+
+if (experimentalJsonModules)
+  extensionFormatMap['.json'] = legacyExtensionFormatMap['.json'] = 'json';
+
+/**
+ *
+ * @param {'node' | 'explicit'} [tsNodeExperimentalSpecifierResolution]
+ * @param {ReturnType<
+ *  typeof import('../dist-raw/node-internal-modules-esm-resolve').createResolve
+ * >} nodeEsmResolver
+ */
+function createGetFormat(tsNodeExperimentalSpecifierResolution, nodeEsmResolver) {
+// const experimentalSpeciferResolution = tsNodeExperimentalSpecifierResolution ?? getOptionValue('--experimental-specifier-resolution');
+let experimentalSpeciferResolution = tsNodeExperimentalSpecifierResolution != null ? tsNodeExperimentalSpecifierResolution : getOptionValue('--experimental-specifier-resolution');
+const { getPackageType } = nodeEsmResolver;
+
+/**
+ * @param {string} url
+ * @param {{}} context
+ * @param {any} defaultGetFormatUnused
+ * @returns {ReturnType}
+ */
+function defaultGetFormat(url, context, defaultGetFormatUnused) {
+  if (StringPrototypeStartsWith(url, 'node:')) {
+    return { format: 'builtin' };
+  }
+  const parsed = new URL(url);
+  if (parsed.protocol === 'data:') {
+    const [ , mime ] = RegExpPrototypeExec(
+      /^([^/]+\/[^;,]+)(?:[^,]*?)(;base64)?,/,
+      parsed.pathname,
+    ) || [ null, null, null ];
+    const format = ({
+      '__proto__': null,
+      'text/javascript': 'module',
+      'application/json': experimentalJsonModules ? 'json' : null,
+      'application/wasm': experimentalWasmModules ? 'wasm' : null
+    })[mime] || null;
+    return { format };
+  } else if (parsed.protocol === 'file:') {
+    const ext = extname(parsed.pathname);
+    let format;
+    if (ext === '.js') {
+      format = getPackageType(parsed.href) === 'module' ? 'module' : 'commonjs';
+    } else {
+      format = extensionFormatMap[ext];
+    }
+    if (!format) {
+      if (experimentalSpeciferResolution === 'node') {
+        process.emitWarning(
+          'The Node.js specifier resolution in ESM is experimental.',
+          'ExperimentalWarning');
+        format = legacyExtensionFormatMap[ext];
+      } else {
+        throw new ERR_UNKNOWN_FILE_EXTENSION(ext, fileURLToPath(url));
       }
-      rimraf_(p, options, CB)
-    })
+    }
+    return { format: format || null };
   }
+  return { format: null };
+}
 
-  if (options.disableGlob || !glob.hasMagic(p))
-    return afterGlob(null, [p])
+return {defaultGetFormat};
+}
 
-  options.lstat(p, (er, stat) => {
-    if (!er)
-      return afterGlob(null, [p])
+module.exports = {
+  createGetFormat
+};
 
-    glob(p, options.glob, afterGlob)
-  })
 
-}
+/***/ }),
 
-// Two possible strategies.
-// 1. Assume it's a file.  unlink it, then do the dir stuff on EPERM or EISDIR
-// 2. Assume it's a directory.  readdir, then do the file stuff on ENOTDIR
-//
-// Both result in an extra syscall when you guess wrong.  However, there
-// are likely far more normal files in the world than directories.  This
-// is based on the assumption that a the average number of files per
-// directory is >= 1.
-//
-// If anyone ever complains about this, then I guess the strategy could
-// be made configurable somehow.  But until then, YAGNI.
-const rimraf_ = (p, options, cb) => {
-  assert(p)
-  assert(options)
-  assert(typeof cb === 'function')
+/***/ 74284:
+/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
-  // sunos lets the root user unlink directories, which is... weird.
-  // so we have to lstat here and make sure it's not a dir.
-  options.lstat(p, (er, st) => {
-    if (er && er.code === "ENOENT")
-      return cb(null)
+"use strict";
+// Copied from https://raw.githubusercontent.com/nodejs/node/v15.3.0/lib/internal/modules/esm/resolve.js
 
-    // Windows can EPERM on stat.  Life is suffering.
-    if (er && er.code === "EPERM" && isWindows)
-      fixWinEPERM(p, options, er, cb)
 
-    if (st && st.isDirectory())
-      return rmdir(p, options, er, cb)
 
-    options.unlink(p, er => {
-      if (er) {
-        if (er.code === "ENOENT")
-          return cb(null)
-        if (er.code === "EPERM")
-          return (isWindows)
-            ? fixWinEPERM(p, options, er, cb)
-            : rmdir(p, options, er, cb)
-        if (er.code === "EISDIR")
-          return rmdir(p, options, er, cb)
-      }
-      return cb(er)
-    })
-  })
-}
+const {versionGteLt} = __nccwpck_require__(26239);
 
-const fixWinEPERM = (p, options, er, cb) => {
-  assert(p)
-  assert(options)
-  assert(typeof cb === 'function')
+// Test for node >14.13.1 || (>=12.20.0 && <13)
+const builtinModuleProtocol =
+  versionGteLt(process.versions.node, '14.13.1') ||
+  versionGteLt(process.versions.node, '12.20.0', '13.0.0')
+    ? 'node:'
+    : 'nodejs:';
 
-  options.chmod(p, 0o666, er2 => {
-    if (er2)
-      cb(er2.code === "ENOENT" ? null : er)
-    else
-      options.stat(p, (er3, stats) => {
-        if (er3)
-          cb(er3.code === "ENOENT" ? null : er)
-        else if (stats.isDirectory())
-          rmdir(p, options, er, cb)
-        else
-          options.unlink(p, cb)
-      })
-  })
-}
+const {
+  ArrayIsArray,
+  ArrayPrototypeJoin,
+  ArrayPrototypeShift,
+  JSONParse,
+  JSONStringify,
+  ObjectFreeze,
+  ObjectGetOwnPropertyNames,
+  ObjectPrototypeHasOwnProperty,
+  RegExpPrototypeTest,
+  SafeMap,
+  SafeSet,
+  StringPrototypeEndsWith,
+  StringPrototypeIndexOf,
+  StringPrototypeLastIndexOf,
+  StringPrototypeReplace,
+  StringPrototypeSlice,
+  StringPrototypeSplit,
+  StringPrototypeStartsWith,
+  StringPrototypeSubstr,
+} = __nccwpck_require__(57523);
 
-const fixWinEPERMSync = (p, options, er) => {
-  assert(p)
-  assert(options)
+// const internalFS = require('internal/fs/utils');
+const Module = __nccwpck_require__(98188);
+const { NativeModule } = __nccwpck_require__(12061);
+const {
+  realpathSync,
+  statSync,
+  Stats,
+} = __nccwpck_require__(57147);
+// const { getOptionValue } = require('internal/options');
+const { getOptionValue } = __nccwpck_require__(92060);
+// // Do not eagerly grab .manifest, it may be in TDZ
+// const policy = getOptionValue('--experimental-policy') ?
+//   require('internal/process/policy') :
+//   null;
+// disabled for now.  I am not sure if/how we should support this
+const policy = null;
+const { sep, relative } = __nccwpck_require__(71017);
+const preserveSymlinks = getOptionValue('--preserve-symlinks');
+const preserveSymlinksMain = getOptionValue('--preserve-symlinks-main');
+const typeFlag = getOptionValue('--input-type');
+// const { URL, pathToFileURL, fileURLToPath } = require('internal/url');
+const { URL, pathToFileURL, fileURLToPath } = __nccwpck_require__(57310);
+const {
+  ERR_INPUT_TYPE_NOT_ALLOWED,
+  ERR_INVALID_ARG_VALUE,
+  ERR_INVALID_MODULE_SPECIFIER,
+  ERR_INVALID_PACKAGE_CONFIG,
+  ERR_INVALID_PACKAGE_TARGET,
+  ERR_MANIFEST_DEPENDENCY_MISSING,
+  ERR_MODULE_NOT_FOUND,
+  ERR_PACKAGE_IMPORT_NOT_DEFINED,
+  ERR_PACKAGE_PATH_NOT_EXPORTED,
+  ERR_UNSUPPORTED_DIR_IMPORT,
+  ERR_UNSUPPORTED_ESM_URL_SCHEME,
+// } = require('internal/errors').codes;
+} = (__nccwpck_require__(5604).codes);
 
-  try {
-    options.chmodSync(p, 0o666)
-  } catch (er2) {
-    if (er2.code === "ENOENT")
-      return
-    else
-      throw er
-  }
+// const { Module: CJSModule } = require('internal/modules/cjs/loader');
+const CJSModule = Module;
 
-  let stats
-  try {
-    stats = options.statSync(p)
-  } catch (er3) {
-    if (er3.code === "ENOENT")
-      return
-    else
-      throw er
-  }
+// const packageJsonReader = require('internal/modules/package_json_reader');
+const packageJsonReader = __nccwpck_require__(73104);
+const userConditions = getOptionValue('--conditions');
+const DEFAULT_CONDITIONS = ObjectFreeze(['node', 'import', ...userConditions]);
+const DEFAULT_CONDITIONS_SET = new SafeSet(DEFAULT_CONDITIONS);
 
-  if (stats.isDirectory())
-    rmdirSync(p, options, er)
-  else
-    options.unlinkSync(p)
-}
+const pendingDeprecation = getOptionValue('--pending-deprecation');
 
-const rmdir = (p, options, originalEr, cb) => {
-  assert(p)
-  assert(options)
-  assert(typeof cb === 'function')
+/**
+ * @param {{
+ *  extensions: import('../src/file-extensions').Extensions,
+ *  preferTsExts: boolean | undefined;
+ *  tsNodeExperimentalSpecifierResolution: import('../src/index').ExperimentalSpecifierResolution | undefined;
+ * }} opts
+ */
+function createResolve(opts) {
+// TODO receive cached fs implementations here
+const {preferTsExts, tsNodeExperimentalSpecifierResolution, extensions} = opts;
+const esrnExtensions = extensions.experimentalSpecifierResolutionAddsIfOmitted;
+const {legacyMainResolveAddsIfOmitted, replacementsForCjs, replacementsForJs, replacementsForMjs, replacementsForJsx} = extensions;
+// const experimentalSpecifierResolution = tsNodeExperimentalSpecifierResolution ?? getOptionValue('--experimental-specifier-resolution');
+const experimentalSpecifierResolution = tsNodeExperimentalSpecifierResolution != null ? tsNodeExperimentalSpecifierResolution : getOptionValue('--experimental-specifier-resolution');
 
-  // try to rmdir first, and only readdir on ENOTEMPTY or EEXIST (SunOS)
-  // if we guessed wrong, and it's not a directory, then
-  // raise the original error.
-  options.rmdir(p, er => {
-    if (er && (er.code === "ENOTEMPTY" || er.code === "EEXIST" || er.code === "EPERM"))
-      rmkids(p, options, cb)
-    else if (er && er.code === "ENOTDIR")
-      cb(originalEr)
-    else
-      cb(er)
-  })
+const emittedPackageWarnings = new SafeSet();
+function emitFolderMapDeprecation(match, pjsonUrl, isExports, base) {
+  const pjsonPath = fileURLToPath(pjsonUrl);
+  if (!pendingDeprecation) {
+    const nodeModulesIndex = StringPrototypeLastIndexOf(pjsonPath,
+                                                        '/node_modules/');
+    if (nodeModulesIndex !== -1) {
+      const afterNodeModulesPath = StringPrototypeSlice(pjsonPath,
+                                                        nodeModulesIndex + 14,
+                                                        -13);
+      try {
+        const { packageSubpath } = parsePackageName(afterNodeModulesPath);
+        if (packageSubpath === '.')
+          return;
+      } catch {}
+    }
+  }
+  if (emittedPackageWarnings.has(pjsonPath + '|' + match))
+    return;
+  emittedPackageWarnings.add(pjsonPath + '|' + match);
+  process.emitWarning(
+    `Use of deprecated folder mapping "${match}" in the ${isExports ?
+      '"exports"' : '"imports"'} field module resolution of the package at ${
+      pjsonPath}${base ? ` imported from ${fileURLToPath(base)}` : ''}.\n` +
+      `Update this package.json to use a subpath pattern like "${match}*".`,
+    'DeprecationWarning',
+    'DEP0148'
+  );
 }
 
-const rmkids = (p, options, cb) => {
-  assert(p)
-  assert(options)
-  assert(typeof cb === 'function')
-
-  options.readdir(p, (er, files) => {
-    if (er)
-      return cb(er)
-    let n = files.length
-    if (n === 0)
-      return options.rmdir(p, cb)
-    let errState
-    files.forEach(f => {
-      rimraf(path.join(p, f), options, er => {
-        if (errState)
-          return
-        if (er)
-          return cb(errState = er)
-        if (--n === 0)
-          options.rmdir(p, cb)
-      })
-    })
-  })
+function getConditionsSet(conditions) {
+  if (conditions !== undefined && conditions !== DEFAULT_CONDITIONS) {
+    if (!ArrayIsArray(conditions)) {
+      throw new ERR_INVALID_ARG_VALUE('conditions', conditions,
+                                      'expected an array');
+    }
+    return new SafeSet(conditions);
+  }
+  return DEFAULT_CONDITIONS_SET;
 }
 
-// this looks simpler, and is strictly *faster*, but will
-// tie up the JavaScript thread and fail on excessively
-// deep directory trees.
-const rimrafSync = (p, options) => {
-  options = options || {}
-  defaults(options)
+const realpathCache = new SafeMap();
+const packageJSONCache = new SafeMap();  /* string -> PackageConfig */
 
-  assert(p, 'rimraf: missing path')
-  assert.equal(typeof p, 'string', 'rimraf: path should be a string')
-  assert(options, 'rimraf: missing options')
-  assert.equal(typeof options, 'object', 'rimraf: options should be object')
+const statSupportsThrowIfNoEntry = versionGteLt(process.versions.node, '15.3.0') ||
+  versionGteLt(process.versions.node, '14.17.0', '15.0.0');
+const tryStatSync = statSupportsThrowIfNoEntry ? tryStatSyncWithoutErrors : tryStatSyncWithErrors;
+const statsIfNotFound = new Stats();
+function tryStatSyncWithoutErrors(path) {
+  const stats = statSync(path, { throwIfNoEntry: false });
+  if(stats != null) return stats;
+  return statsIfNotFound;
+}
+function tryStatSyncWithErrors(path) {
+  try {
+    return statSync(path);
+  } catch {
+    return statsIfNotFound;
+  }
+}
 
-  let results
+function getPackageConfig(path, specifier, base) {
+  const existing = packageJSONCache.get(path);
+  if (existing !== undefined) {
+    return existing;
+  }
+  const source = packageJsonReader.read(path).string;
+  if (source === undefined) {
+    const packageConfig = {
+      pjsonPath: path,
+      exists: false,
+      main: undefined,
+      name: undefined,
+      type: 'none',
+      exports: undefined,
+      imports: undefined,
+    };
+    packageJSONCache.set(path, packageConfig);
+    return packageConfig;
+  }
 
-  if (options.disableGlob || !glob.hasMagic(p)) {
-    results = [p]
-  } else {
-    try {
-      options.lstatSync(p)
-      results = [p]
-    } catch (er) {
-      results = glob.sync(p, options.glob)
-    }
+  let packageJSON;
+  try {
+    packageJSON = JSONParse(source);
+  } catch (error) {
+    throw new ERR_INVALID_PACKAGE_CONFIG(
+      path,
+      (base ? `"${specifier}" from ` : '') + fileURLToPath(base || specifier),
+      error.message
+    );
   }
 
-  if (!results.length)
-    return
+  let { imports, main, name, type } = packageJSON;
+  const { exports } = packageJSON;
+  if (typeof imports !== 'object' || imports === null) imports = undefined;
+  if (typeof main !== 'string') main = undefined;
+  if (typeof name !== 'string') name = undefined;
+  // Ignore unknown types for forwards compatibility
+  if (type !== 'module' && type !== 'commonjs') type = 'none';
 
-  for (let i = 0; i < results.length; i++) {
-    const p = results[i]
+  const packageConfig = {
+    pjsonPath: path,
+    exists: true,
+    main,
+    name,
+    type,
+    exports,
+    imports,
+  };
+  packageJSONCache.set(path, packageConfig);
+  return packageConfig;
+}
 
-    let st
-    try {
-      st = options.lstatSync(p)
-    } catch (er) {
-      if (er.code === "ENOENT")
-        return
+function getPackageScopeConfig(resolved) {
+  let packageJSONUrl = new URL('./package.json', resolved);
+  while (true) {
+    const packageJSONPath = packageJSONUrl.pathname;
+    if (StringPrototypeEndsWith(packageJSONPath, 'node_modules/package.json'))
+      break;
+    const packageConfig = getPackageConfig(fileURLToPath(packageJSONUrl),
+                                           resolved);
+    if (packageConfig.exists) return packageConfig;
 
-      // Windows can EPERM on stat.  Life is suffering.
-      if (er.code === "EPERM" && isWindows)
-        fixWinEPERMSync(p, options, er)
-    }
+    const lastPackageJSONUrl = packageJSONUrl;
+    packageJSONUrl = new URL('../package.json', packageJSONUrl);
 
-    try {
-      // sunos lets the root user unlink directories, which is... weird.
-      if (st && st.isDirectory())
-        rmdirSync(p, options, null)
-      else
-        options.unlinkSync(p)
-    } catch (er) {
-      if (er.code === "ENOENT")
-        return
-      if (er.code === "EPERM")
-        return isWindows ? fixWinEPERMSync(p, options, er) : rmdirSync(p, options, er)
-      if (er.code !== "EISDIR")
-        throw er
+    // Terminates at root where ../package.json equals ../../package.json
+    // (can't just check "/package.json" for Windows support).
+    if (packageJSONUrl.pathname === lastPackageJSONUrl.pathname) break;
+  }
+  const packageJSONPath = fileURLToPath(packageJSONUrl);
+  const packageConfig = {
+    pjsonPath: packageJSONPath,
+    exists: false,
+    main: undefined,
+    name: undefined,
+    type: 'none',
+    exports: undefined,
+    imports: undefined,
+  };
+  packageJSONCache.set(packageJSONPath, packageConfig);
+  return packageConfig;
+}
 
-      rmdirSync(p, options, er)
+/*
+ * Legacy CommonJS main resolution:
+ * 1. let M = pkg_url + (json main field)
+ * 2. TRY(M, M.js, M.json, M.node)
+ * 3. TRY(M/index.js, M/index.json, M/index.node)
+ * 4. TRY(pkg_url/index.js, pkg_url/index.json, pkg_url/index.node)
+ * 5. NOT_FOUND
+ */
+function fileExists(url) {
+  return tryStatSync(fileURLToPath(url)).isFile();
+}
+
+function legacyMainResolve(packageJSONUrl, packageConfig, base) {
+  let guess;
+  if (packageConfig.main !== undefined) {
+    // Note: fs check redundances will be handled by Descriptor cache here.
+    if(guess = resolveReplacementExtensions(new URL(`./${packageConfig.main}`, packageJSONUrl))) {
+      return guess;
+    }
+    if (fileExists(guess = new URL(`./${packageConfig.main}`,
+                                   packageJSONUrl))) {
+      return guess;
+    }
+    for(const extension of legacyMainResolveAddsIfOmitted) {
+      if (fileExists(guess = new URL(`./${packageConfig.main}${extension}`,
+                                    packageJSONUrl))) {
+        return guess;
+      }
+    }
+    for(const extension of legacyMainResolveAddsIfOmitted) {
+      if (fileExists(guess = new URL(`./${packageConfig.main}/index${extension}`,
+                                    packageJSONUrl))) {
+        return guess;
+      }
+    }
+    // Fallthrough.
+  }
+  for(const extension of legacyMainResolveAddsIfOmitted) {
+    if (fileExists(guess = new URL(`./index${extension}`, packageJSONUrl))) {
+      return guess;
     }
   }
+  // Not found.
+  throw new ERR_MODULE_NOT_FOUND(
+    fileURLToPath(new URL('.', packageJSONUrl)), fileURLToPath(base));
 }
 
-const rmdirSync = (p, options, originalEr) => {
-  assert(p)
-  assert(options)
+/** attempts replacement extensions, then tries exact name, then attempts appending extensions */
+function resolveExtensionsWithTryExactName(search) {
+  const resolvedReplacementExtension = resolveReplacementExtensions(search);
+  if(resolvedReplacementExtension) return resolvedReplacementExtension;
+  if (fileExists(search)) return search;
+  return resolveExtensions(search);
+}
 
-  try {
-    options.rmdirSync(p)
-  } catch (er) {
-    if (er.code === "ENOENT")
-      return
-    if (er.code === "ENOTDIR")
-      throw originalEr
-    if (er.code === "ENOTEMPTY" || er.code === "EEXIST" || er.code === "EPERM")
-      rmkidsSync(p, options)
+// This appends missing extensions
+function resolveExtensions(search) {
+  for (let i = 0; i < esrnExtensions.length; i++) {
+    const extension = esrnExtensions[i];
+    const guess = new URL(`${search.pathname}${extension}`, search);
+    if (fileExists(guess)) return guess;
   }
+  return undefined;
 }
 
-const rmkidsSync = (p, options) => {
-  assert(p)
-  assert(options)
-  options.readdirSync(p).forEach(f => rimrafSync(path.join(p, f), options))
-
-  // We only end up here once we got ENOTEMPTY at least once, and
-  // at this point, we are guaranteed to have removed all the kids.
-  // So, we know that it won't be ENOENT or ENOTDIR or anything else.
-  // try really hard to delete stuff on windows, because it has a
-  // PROFOUNDLY annoying habit of not closing handles promptly when
-  // files are deleted, resulting in spurious ENOTEMPTY errors.
-  const retries = isWindows ? 100 : 1
-  let i = 0
-  do {
-    let threw = true
-    try {
-      const ret = options.rmdirSync(p, options)
-      threw = false
-      return ret
-    } finally {
-      if (++i < retries && threw)
-        continue
+/** This replaces JS with TS extensions */
+function resolveReplacementExtensions(search) {
+  const lastDotIndex = search.pathname.lastIndexOf('.');
+  if(lastDotIndex >= 0) {
+    const ext = search.pathname.slice(lastDotIndex);
+    if (ext === '.js' || ext === '.jsx' || ext === '.mjs' || ext === '.cjs') {
+      const pathnameWithoutExtension = search.pathname.slice(0, lastDotIndex);
+      const replacementExts =
+        ext === '.js' ? replacementsForJs
+        : ext === '.jsx' ? replacementsForJsx
+        : ext === '.mjs' ? replacementsForMjs
+        : replacementsForCjs;
+      const guess = new URL(search.toString());
+      for (let i = 0; i < replacementExts.length; i++) {
+        const extension = replacementExts[i];
+        guess.pathname = `${pathnameWithoutExtension}${extension}`;
+        if (fileExists(guess)) return guess;
+      }
     }
-  } while (true)
+  }
+  return undefined;
 }
 
-module.exports = rimraf
-rimraf.sync = rimrafSync
+function resolveIndex(search) {
+  return resolveExtensions(new URL('index', search));
+}
 
+const encodedSepRegEx = /%2F|%2C/i;
+function finalizeResolution(resolved, base) {
+  if (RegExpPrototypeTest(encodedSepRegEx, resolved.pathname))
+    throw new ERR_INVALID_MODULE_SPECIFIER(
+      resolved.pathname, 'must not include encoded "/" or "\\" characters',
+      fileURLToPath(base));
 
-/***/ }),
+  if (experimentalSpecifierResolution === 'node') {
+    const path = fileURLToPath(resolved);
+    let file = resolveExtensionsWithTryExactName(resolved);
+    if (file !== undefined) return file;
+    if (!StringPrototypeEndsWith(path, '/')) {
+      file = resolveIndex(new URL(`${resolved}/`));
+      if (file !== undefined) return file;
+    } else {
+      return resolveIndex(resolved) || resolved;
+    }
+    throw new ERR_MODULE_NOT_FOUND(
+      resolved.pathname, fileURLToPath(base), 'module');
+  }
 
-/***/ 87851:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+  const file = resolveReplacementExtensions(resolved) || resolved;
+  const path = fileURLToPath(file);
+
+  const stats = tryStatSync(StringPrototypeEndsWith(path, '/') ?
+    StringPrototypeSlice(path, -1) : path);
+  if (stats.isDirectory()) {
+    const err = new ERR_UNSUPPORTED_DIR_IMPORT(path, fileURLToPath(base));
+    err.url = String(resolved);
+    throw err;
+  } else if (!stats.isFile()) {
+    throw new ERR_MODULE_NOT_FOUND(
+      path || resolved.pathname, fileURLToPath(base), 'module');
+  }
+
+  return file;
+}
 
-/*! run-parallel. MIT License. Feross Aboukhadijeh  */
-module.exports = runParallel
+function throwImportNotDefined(specifier, packageJSONUrl, base) {
+  throw new ERR_PACKAGE_IMPORT_NOT_DEFINED(
+    specifier, packageJSONUrl && fileURLToPath(new URL('.', packageJSONUrl)),
+    fileURLToPath(base));
+}
 
-const queueMicrotask = __nccwpck_require__(98431)
+function throwExportsNotFound(subpath, packageJSONUrl, base) {
+  throw new ERR_PACKAGE_PATH_NOT_EXPORTED(
+    fileURLToPath(new URL('.', packageJSONUrl)), subpath,
+    base && fileURLToPath(base));
+}
 
-function runParallel (tasks, cb) {
-  let results, pending, keys
-  let isSync = true
+function throwInvalidSubpath(subpath, packageJSONUrl, internal, base) {
+  const reason = `request is not a valid subpath for the "${internal ?
+    'imports' : 'exports'}" resolution of ${fileURLToPath(packageJSONUrl)}`;
+  throw new ERR_INVALID_MODULE_SPECIFIER(subpath, reason,
+                                         base && fileURLToPath(base));
+}
 
-  if (Array.isArray(tasks)) {
-    results = []
-    pending = tasks.length
+function throwInvalidPackageTarget(
+  subpath, target, packageJSONUrl, internal, base) {
+  if (typeof target === 'object' && target !== null) {
+    target = JSONStringify(target, null, '');
   } else {
-    keys = Object.keys(tasks)
-    results = {}
-    pending = keys.length
+    target = `${target}`;
   }
+  throw new ERR_INVALID_PACKAGE_TARGET(
+    fileURLToPath(new URL('.', packageJSONUrl)), subpath, target,
+    internal, base && fileURLToPath(base));
+}
 
-  function done (err) {
-    function end () {
-      if (cb) cb(err, results)
-      cb = null
-    }
-    if (isSync) queueMicrotask(end)
-    else end()
-  }
+const invalidSegmentRegEx = /(^|\\|\/)(\.\.?|node_modules)(\\|\/|$)/;
+const patternRegEx = /\*/g;
 
-  function each (i, err, result) {
-    results[i] = result
-    if (--pending === 0 || err) {
-      done(err)
-    }
-  }
+function resolvePackageTargetString(
+  target, subpath, match, packageJSONUrl, base, pattern, internal, conditions) {
+  if (subpath !== '' && !pattern && target[target.length - 1] !== '/')
+    throwInvalidPackageTarget(match, target, packageJSONUrl, internal, base);
 
-  if (!pending) {
-    // empty
-    done(null)
-  } else if (keys) {
-    // object
-    keys.forEach(function (key) {
-      tasks[key](function (err, result) { each(key, err, result) })
-    })
-  } else {
-    // array
-    tasks.forEach(function (task, i) {
-      task(function (err, result) { each(i, err, result) })
-    })
+  if (!StringPrototypeStartsWith(target, './')) {
+    if (internal && !StringPrototypeStartsWith(target, '../') &&
+        !StringPrototypeStartsWith(target, '/')) {
+      let isURL = false;
+      try {
+        new URL(target);
+        isURL = true;
+      } catch {}
+      if (!isURL) {
+        const exportTarget = pattern ?
+          StringPrototypeReplace(target, patternRegEx, subpath) :
+          target + subpath;
+        return packageResolve(exportTarget, packageJSONUrl, conditions);
+      }
+    }
+    throwInvalidPackageTarget(match, target, packageJSONUrl, internal, base);
   }
 
-  isSync = false
-}
+  if (RegExpPrototypeTest(invalidSegmentRegEx, StringPrototypeSlice(target, 2)))
+    throwInvalidPackageTarget(match, target, packageJSONUrl, internal, base);
 
+  const resolved = new URL(target, packageJSONUrl);
+  const resolvedPath = resolved.pathname;
+  const packagePath = new URL('.', packageJSONUrl).pathname;
 
-/***/ }),
+  if (!StringPrototypeStartsWith(resolvedPath, packagePath))
+    throwInvalidPackageTarget(match, target, packageJSONUrl, internal, base);
 
-/***/ 87128:
-/***/ ((module, exports, __nccwpck_require__) => {
+  if (subpath === '') return resolved;
 
-/*! safe-buffer. MIT License. Feross Aboukhadijeh  */
-/* eslint-disable node/no-deprecated-api */
-var buffer = __nccwpck_require__(14300)
-var Buffer = buffer.Buffer
+  if (RegExpPrototypeTest(invalidSegmentRegEx, subpath))
+    throwInvalidSubpath(match + subpath, packageJSONUrl, internal, base);
 
-// alternative to using Object.keys for old browsers
-function copyProps (src, dst) {
-  for (var key in src) {
-    dst[key] = src[key]
-  }
-}
-if (Buffer.from && Buffer.alloc && Buffer.allocUnsafe && Buffer.allocUnsafeSlow) {
-  module.exports = buffer
-} else {
-  // Copy properties from require('buffer')
-  copyProps(buffer, exports)
-  exports.Buffer = SafeBuffer
+  if (pattern)
+    return new URL(StringPrototypeReplace(resolved.href, patternRegEx,
+                                          subpath));
+  return new URL(subpath, resolved);
 }
 
-function SafeBuffer (arg, encodingOrOffset, length) {
-  return Buffer(arg, encodingOrOffset, length)
+/**
+ * @param {string} key
+ * @returns {boolean}
+ */
+function isArrayIndex(key) {
+  const keyNum = +key;
+  if (`${keyNum}` !== key) return false;
+  return keyNum >= 0 && keyNum < 0xFFFF_FFFF;
 }
 
-SafeBuffer.prototype = Object.create(Buffer.prototype)
-
-// Copy static methods from Buffer
-copyProps(Buffer, SafeBuffer)
+function resolvePackageTarget(packageJSONUrl, target, subpath, packageSubpath,
+                              base, pattern, internal, conditions) {
+  if (typeof target === 'string') {
+    return resolvePackageTargetString(
+      target, subpath, packageSubpath, packageJSONUrl, base, pattern, internal,
+      conditions);
+  } else if (ArrayIsArray(target)) {
+    if (target.length === 0)
+      return null;
 
-SafeBuffer.from = function (arg, encodingOrOffset, length) {
-  if (typeof arg === 'number') {
-    throw new TypeError('Argument must not be a number')
+    let lastException;
+    for (let i = 0; i < target.length; i++) {
+      const targetItem = target[i];
+      let resolved;
+      try {
+        resolved = resolvePackageTarget(
+          packageJSONUrl, targetItem, subpath, packageSubpath, base, pattern,
+          internal, conditions);
+      } catch (e) {
+        lastException = e;
+        if (e.code === 'ERR_INVALID_PACKAGE_TARGET')
+          continue;
+        throw e;
+      }
+      if (resolved === undefined)
+        continue;
+      if (resolved === null) {
+        lastException = null;
+        continue;
+      }
+      return resolved;
+    }
+    if (lastException === undefined || lastException === null)
+      return lastException;
+    throw lastException;
+  } else if (typeof target === 'object' && target !== null) {
+    const keys = ObjectGetOwnPropertyNames(target);
+    for (let i = 0; i < keys.length; i++) {
+      const key = keys[i];
+      if (isArrayIndex(key)) {
+        throw new ERR_INVALID_PACKAGE_CONFIG(
+          fileURLToPath(packageJSONUrl), base,
+          '"exports" cannot contain numeric property keys.');
+      }
+    }
+    for (let i = 0; i < keys.length; i++) {
+      const key = keys[i];
+      if (key === 'default' || conditions.has(key)) {
+        const conditionalTarget = target[key];
+        const resolved = resolvePackageTarget(
+          packageJSONUrl, conditionalTarget, subpath, packageSubpath, base,
+          pattern, internal, conditions);
+        if (resolved === undefined)
+          continue;
+        return resolved;
+      }
+    }
+    return undefined;
+  } else if (target === null) {
+    return null;
   }
-  return Buffer(arg, encodingOrOffset, length)
+  throwInvalidPackageTarget(packageSubpath, target, packageJSONUrl, internal,
+                            base);
 }
 
-SafeBuffer.alloc = function (size, fill, encoding) {
-  if (typeof size !== 'number') {
-    throw new TypeError('Argument must be a number')
-  }
-  var buf = Buffer(size)
-  if (fill !== undefined) {
-    if (typeof encoding === 'string') {
-      buf.fill(fill, encoding)
-    } else {
-      buf.fill(fill)
+function isConditionalExportsMainSugar(exports, packageJSONUrl, base) {
+  if (typeof exports === 'string' || ArrayIsArray(exports)) return true;
+  if (typeof exports !== 'object' || exports === null) return false;
+
+  const keys = ObjectGetOwnPropertyNames(exports);
+  let isConditionalSugar = false;
+  let i = 0;
+  for (let j = 0; j < keys.length; j++) {
+    const key = keys[j];
+    const curIsConditionalSugar = key === '' || key[0] !== '.';
+    if (i++ === 0) {
+      isConditionalSugar = curIsConditionalSugar;
+    } else if (isConditionalSugar !== curIsConditionalSugar) {
+      throw new ERR_INVALID_PACKAGE_CONFIG(
+        fileURLToPath(packageJSONUrl), base,
+        '"exports" cannot contain some keys starting with \'.\' and some not.' +
+        ' The exports object must either be an object of package subpath keys' +
+        ' or an object of main entry condition name keys only.');
     }
-  } else {
-    buf.fill(0)
   }
-  return buf
+  return isConditionalSugar;
 }
 
-SafeBuffer.allocUnsafe = function (size) {
-  if (typeof size !== 'number') {
-    throw new TypeError('Argument must be a number')
+/**
+ * @param {URL} packageJSONUrl
+ * @param {string} packageSubpath
+ * @param {object} packageConfig
+ * @param {string} base
+ * @param {Set} conditions
+ * @returns {{resolved: URL, exact: boolean}}
+ */
+function packageExportsResolve(
+  packageJSONUrl, packageSubpath, packageConfig, base, conditions) {
+  let exports = packageConfig.exports;
+  if (isConditionalExportsMainSugar(exports, packageJSONUrl, base))
+    exports = { '.': exports };
+
+  if (ObjectPrototypeHasOwnProperty(exports, packageSubpath)) {
+    const target = exports[packageSubpath];
+    const resolved = resolvePackageTarget(
+      packageJSONUrl, target, '', packageSubpath, base, false, false, conditions
+    );
+    if (resolved === null || resolved === undefined)
+      throwExportsNotFound(packageSubpath, packageJSONUrl, base);
+    return { resolved, exact: true };
   }
-  return Buffer(size)
-}
 
-SafeBuffer.allocUnsafeSlow = function (size) {
-  if (typeof size !== 'number') {
-    throw new TypeError('Argument must be a number')
+  let bestMatch = '';
+  const keys = ObjectGetOwnPropertyNames(exports);
+  for (let i = 0; i < keys.length; i++) {
+    const key = keys[i];
+    if (key[key.length - 1] === '*' &&
+        StringPrototypeStartsWith(packageSubpath,
+                                  StringPrototypeSlice(key, 0, -1)) &&
+        packageSubpath.length >= key.length &&
+        key.length > bestMatch.length) {
+      bestMatch = key;
+    } else if (key[key.length - 1] === '/' &&
+      StringPrototypeStartsWith(packageSubpath, key) &&
+      key.length > bestMatch.length) {
+      bestMatch = key;
+    }
   }
-  return buffer.SlowBuffer(size)
+
+  if (bestMatch) {
+    const target = exports[bestMatch];
+    const pattern = bestMatch[bestMatch.length - 1] === '*';
+    const subpath = StringPrototypeSubstr(packageSubpath, bestMatch.length -
+      (pattern ? 1 : 0));
+    const resolved = resolvePackageTarget(packageJSONUrl, target, subpath,
+                                          bestMatch, base, pattern, false,
+                                          conditions);
+    if (resolved === null || resolved === undefined)
+      throwExportsNotFound(packageSubpath, packageJSONUrl, base);
+    if (!pattern)
+      emitFolderMapDeprecation(bestMatch, packageJSONUrl, true, base);
+    return { resolved, exact: pattern };
+  }
+
+  throwExportsNotFound(packageSubpath, packageJSONUrl, base);
 }
 
+function packageImportsResolve(name, base, conditions) {
+  if (name === '#' || StringPrototypeStartsWith(name, '#/')) {
+    const reason = 'is not a valid internal imports specifier name';
+    throw new ERR_INVALID_MODULE_SPECIFIER(name, reason, fileURLToPath(base));
+  }
+  let packageJSONUrl;
+  const packageConfig = getPackageScopeConfig(base);
+  if (packageConfig.exists) {
+    packageJSONUrl = pathToFileURL(packageConfig.pjsonPath);
+    const imports = packageConfig.imports;
+    if (imports) {
+      if (ObjectPrototypeHasOwnProperty(imports, name)) {
+        const resolved = resolvePackageTarget(
+          packageJSONUrl, imports[name], '', name, base, false, true, conditions
+        );
+        if (resolved !== null)
+          return { resolved, exact: true };
+      } else {
+        let bestMatch = '';
+        const keys = ObjectGetOwnPropertyNames(imports);
+        for (let i = 0; i < keys.length; i++) {
+          const key = keys[i];
+          if (key[key.length - 1] === '*' &&
+              StringPrototypeStartsWith(name,
+                                        StringPrototypeSlice(key, 0, -1)) &&
+              name.length >= key.length &&
+              key.length > bestMatch.length) {
+            bestMatch = key;
+          } else if (key[key.length - 1] === '/' &&
+            StringPrototypeStartsWith(name, key) &&
+            key.length > bestMatch.length) {
+            bestMatch = key;
+          }
+        }
 
-/***/ }),
+        if (bestMatch) {
+          const target = imports[bestMatch];
+          const pattern = bestMatch[bestMatch.length - 1] === '*';
+          const subpath = StringPrototypeSubstr(name, bestMatch.length -
+            (pattern ? 1 : 0));
+          const resolved = resolvePackageTarget(
+            packageJSONUrl, target, subpath, bestMatch, base, pattern, true,
+            conditions);
+          if (resolved !== null) {
+            if (!pattern)
+              emitFolderMapDeprecation(bestMatch, packageJSONUrl, false, base);
+            return { resolved, exact: pattern };
+          }
+        }
+      }
+    }
+  }
+  throwImportNotDefined(name, packageJSONUrl, base);
+}
 
-/***/ 37270:
-/***/ ((module) => {
+function getPackageType(url) {
+  const packageConfig = getPackageScopeConfig(url);
+  return packageConfig.type;
+}
 
-module.exports = [
-  'cat',
-  'cd',
-  'chmod',
-  'cp',
-  'dirs',
-  'echo',
-  'exec',
-  'find',
-  'grep',
-  'head',
-  'ln',
-  'ls',
-  'mkdir',
-  'mv',
-  'pwd',
-  'rm',
-  'sed',
-  'set',
-  'sort',
-  'tail',
-  'tempdir',
-  'test',
-  'to',
-  'toEnd',
-  'touch',
-  'uniq',
-  'which',
-];
+function parsePackageName(specifier, base) {
+  let separatorIndex = StringPrototypeIndexOf(specifier, '/');
+  let validPackageName = true;
+  let isScoped = false;
+  if (specifier[0] === '@') {
+    isScoped = true;
+    if (separatorIndex === -1 || specifier.length === 0) {
+      validPackageName = false;
+    } else {
+      separatorIndex = StringPrototypeIndexOf(
+        specifier, '/', separatorIndex + 1);
+    }
+  }
 
+  const packageName = separatorIndex === -1 ?
+    specifier : StringPrototypeSlice(specifier, 0, separatorIndex);
 
-/***/ }),
+  // Package name cannot have leading . and cannot have percent-encoding or
+  // separators.
+  for (let i = 0; i < packageName.length; i++) {
+    if (packageName[i] === '%' || packageName[i] === '\\') {
+      validPackageName = false;
+      break;
+    }
+  }
 
-/***/ 54572:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
+  if (!validPackageName) {
+    throw new ERR_INVALID_MODULE_SPECIFIER(
+      specifier, 'is not a valid package name', fileURLToPath(base));
+  }
 
-//
-// ShellJS
-// Unix shell commands on top of Node's API
-//
-// Copyright (c) 2012 Artur Adib
-// http://github.com/shelljs/shelljs
-//
+  const packageSubpath = '.' + (separatorIndex === -1 ? '' :
+    StringPrototypeSlice(specifier, separatorIndex));
 
-function __ncc_wildcard$0 (arg) {
-  if (arg === "cat.js" || arg === "cat") return __nccwpck_require__(95562);
-  else if (arg === "cd.js" || arg === "cd") return __nccwpck_require__(51829);
-  else if (arg === "chmod.js" || arg === "chmod") return __nccwpck_require__(81072);
-  else if (arg === "common.js" || arg === "common") return __nccwpck_require__(17673);
-  else if (arg === "cp.js" || arg === "cp") return __nccwpck_require__(6135);
-  else if (arg === "dirs.js" || arg === "dirs") return __nccwpck_require__(80220);
-  else if (arg === "echo.js" || arg === "echo") return __nccwpck_require__(99534);
-  else if (arg === "error.js" || arg === "error") return __nccwpck_require__(49862);
-  else if (arg === "exec-child.js" || arg === "exec-child") return __nccwpck_require__(24416);
-  else if (arg === "exec.js" || arg === "exec") return __nccwpck_require__(74221);
-  else if (arg === "find.js" || arg === "find") return __nccwpck_require__(49198);
-  else if (arg === "grep.js" || arg === "grep") return __nccwpck_require__(78869);
-  else if (arg === "head.js" || arg === "head") return __nccwpck_require__(41712);
-  else if (arg === "ln.js" || arg === "ln") return __nccwpck_require__(76786);
-  else if (arg === "ls.js" || arg === "ls") return __nccwpck_require__(9644);
-  else if (arg === "mkdir.js" || arg === "mkdir") return __nccwpck_require__(69494);
-  else if (arg === "mv.js" || arg === "mv") return __nccwpck_require__(31285);
-  else if (arg === "popd.js" || arg === "popd") return __nccwpck_require__(42535);
-  else if (arg === "pushd.js" || arg === "pushd") return __nccwpck_require__(47928);
-  else if (arg === "pwd.js" || arg === "pwd") return __nccwpck_require__(24020);
-  else if (arg === "rm.js" || arg === "rm") return __nccwpck_require__(37720);
-  else if (arg === "sed.js" || arg === "sed") return __nccwpck_require__(46926);
-  else if (arg === "set.js" || arg === "set") return __nccwpck_require__(20011);
-  else if (arg === "sort.js" || arg === "sort") return __nccwpck_require__(37472);
-  else if (arg === "tail.js" || arg === "tail") return __nccwpck_require__(18968);
-  else if (arg === "tempdir.js" || arg === "tempdir") return __nccwpck_require__(40591);
-  else if (arg === "test.js" || arg === "test") return __nccwpck_require__(39063);
-  else if (arg === "to.js" || arg === "to") return __nccwpck_require__(94897);
-  else if (arg === "toEnd.js" || arg === "toEnd") return __nccwpck_require__(60228);
-  else if (arg === "touch.js" || arg === "touch") return __nccwpck_require__(28440);
-  else if (arg === "uniq.js" || arg === "uniq") return __nccwpck_require__(55499);
-  else if (arg === "which.js" || arg === "which") return __nccwpck_require__(5405);
-}
-var common = __nccwpck_require__(17673);
+  return { packageName, packageSubpath, isScoped };
+}
 
-//@
-//@ All commands run synchronously, unless otherwise stated.
-//@ All commands accept standard bash globbing characters (`*`, `?`, etc.),
-//@ compatible with the [node `glob` module](https://github.com/isaacs/node-glob).
-//@
-//@ For less-commonly used commands and features, please check out our [wiki
-//@ page](https://github.com/shelljs/shelljs/wiki).
-//@
-
-// Include the docs for all the default commands
-//@commands
-
-// Load all default commands
-(__nccwpck_require__(37270).forEach)(function (command) {
-  __ncc_wildcard$0(command);
-});
-
-//@
-//@ ### exit(code)
-//@
-//@ Exits the current process with the given exit `code`.
-exports.exit = process.exit;
-
-//@include ./src/error
-exports.error = __nccwpck_require__(49862);
-
-//@include ./src/common
-exports.ShellString = common.ShellString;
-
-//@
-//@ ### env['VAR_NAME']
-//@
-//@ Object containing environment variables (both getter and setter). Shortcut
-//@ to `process.env`.
-exports.env = process.env;
-
-//@
-//@ ### Pipes
-//@
-//@ Examples:
-//@
-//@ ```javascript
-//@ grep('foo', 'file1.txt', 'file2.txt').sed(/o/g, 'a').to('output.txt');
-//@ echo('files with o\'s in the name:\n' + ls().grep('o'));
-//@ cat('test.js').exec('node'); // pipe to exec() call
-//@ ```
-//@
-//@ Commands can send their output to another command in a pipe-like fashion.
-//@ `sed`, `grep`, `cat`, `exec`, `to`, and `toEnd` can appear on the right-hand
-//@ side of a pipe. Pipes can be chained.
-
-//@
-//@ ## Configuration
-//@
-
-exports.config = common.config;
-
-//@
-//@ ### config.silent
-//@
-//@ Example:
-//@
-//@ ```javascript
-//@ var sh = require('shelljs');
-//@ var silentState = sh.config.silent; // save old silent state
-//@ sh.config.silent = true;
-//@ /* ... */
-//@ sh.config.silent = silentState; // restore old silent state
-//@ ```
-//@
-//@ Suppresses all command output if `true`, except for `echo()` calls.
-//@ Default is `false`.
-
-//@
-//@ ### config.fatal
-//@
-//@ Example:
-//@
-//@ ```javascript
-//@ require('shelljs/global');
-//@ config.fatal = true; // or set('-e');
-//@ cp('this_file_does_not_exist', '/dev/null'); // throws Error here
-//@ /* more commands... */
-//@ ```
-//@
-//@ If `true`, the script will throw a Javascript error when any shell.js
-//@ command encounters an error. Default is `false`. This is analogous to
-//@ Bash's `set -e`.
-
-//@
-//@ ### config.verbose
-//@
-//@ Example:
-//@
-//@ ```javascript
-//@ config.verbose = true; // or set('-v');
-//@ cd('dir/');
-//@ rm('-rf', 'foo.txt', 'bar.txt');
-//@ exec('echo hello');
-//@ ```
-//@
-//@ Will print each command as follows:
-//@
-//@ ```
-//@ cd dir/
-//@ rm -rf foo.txt bar.txt
-//@ exec echo hello
-//@ ```
+/**
+ * @param {string} specifier
+ * @param {URL} base
+ * @param {Set} conditions
+ * @returns {URL}
+ */
+function packageResolve(specifier, base, conditions) {
+  const { packageName, packageSubpath, isScoped } =
+    parsePackageName(specifier, base);
 
-//@
-//@ ### config.globOptions
-//@
-//@ Example:
-//@
-//@ ```javascript
-//@ config.globOptions = {nodir: true};
-//@ ```
-//@
-//@ Use this value for calls to `glob.sync()` instead of the default options.
+  // ResolveSelf
+  const packageConfig = getPackageScopeConfig(base);
+  if (packageConfig.exists) {
+    const packageJSONUrl = pathToFileURL(packageConfig.pjsonPath);
+    if (packageConfig.name === packageName &&
+        packageConfig.exports !== undefined && packageConfig.exports !== null) {
+      return packageExportsResolve(
+        packageJSONUrl, packageSubpath, packageConfig, base, conditions
+      ).resolved;
+    }
+  }
 
-//@
-//@ ### config.reset()
-//@
-//@ Example:
-//@
-//@ ```javascript
-//@ var shell = require('shelljs');
-//@ // Make changes to shell.config, and do stuff...
-//@ /* ... */
-//@ shell.config.reset(); // reset to original state
-//@ // Do more stuff, but with original settings
-//@ /* ... */
-//@ ```
-//@
-//@ Reset `shell.config` to the defaults:
-//@
-//@ ```javascript
-//@ {
-//@   fatal: false,
-//@   globOptions: {},
-//@   maxdepth: 255,
-//@   noglob: false,
-//@   silent: false,
-//@   verbose: false,
-//@ }
-//@ ```
+  let packageJSONUrl =
+    new URL('./node_modules/' + packageName + '/package.json', base);
+  let packageJSONPath = fileURLToPath(packageJSONUrl);
+  let lastPath;
+  do {
+    const stat = tryStatSync(StringPrototypeSlice(packageJSONPath, 0,
+                                                  packageJSONPath.length - 13));
+    if (!stat.isDirectory()) {
+      lastPath = packageJSONPath;
+      packageJSONUrl = new URL((isScoped ?
+        '../../../../node_modules/' : '../../../node_modules/') +
+        packageName + '/package.json', packageJSONUrl);
+      packageJSONPath = fileURLToPath(packageJSONUrl);
+      continue;
+    }
 
+    // Package match.
+    const packageConfig = getPackageConfig(packageJSONPath, specifier, base);
+    if (packageConfig.exports !== undefined && packageConfig.exports !== null)
+      return packageExportsResolve(
+        packageJSONUrl, packageSubpath, packageConfig, base, conditions
+      ).resolved;
+    if (packageSubpath === '.')
+      return legacyMainResolve(packageJSONUrl, packageConfig, base);
+    return new URL(packageSubpath, packageJSONUrl);
+    // Cross-platform root check.
+  } while (packageJSONPath.length !== lastPath.length);
 
-/***/ }),
+  // eslint can't handle the above code.
+  // eslint-disable-next-line no-unreachable
+  throw new ERR_MODULE_NOT_FOUND(packageName, fileURLToPath(base));
+}
 
-/***/ 95562:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+function isBareSpecifier(specifier) {
+  return specifier[0] && specifier[0] !== '/' && specifier[0] !== '.';
+}
 
-var common = __nccwpck_require__(17673);
-var fs = __nccwpck_require__(57147);
+function isRelativeSpecifier(specifier) {
+  if (specifier[0] === '.') {
+    if (specifier.length === 1 || specifier[1] === '/') return true;
+    if (specifier[1] === '.') {
+      if (specifier.length === 2 || specifier[2] === '/') return true;
+    }
+  }
+  return false;
+}
 
-common.register('cat', _cat, {
-  canReceivePipe: true,
-  cmdOptions: {
-    'n': 'number',
-  },
-});
+function shouldBeTreatedAsRelativeOrAbsolutePath(specifier) {
+  if (specifier === '') return false;
+  if (specifier[0] === '/') return true;
+  return isRelativeSpecifier(specifier);
+}
 
-//@
-//@ ### cat([options,] file [, file ...])
-//@ ### cat([options,] file_array)
-//@
-//@ Available options:
-//@
-//@ + `-n`: number all output lines
-//@
-//@ Examples:
-//@
-//@ ```javascript
-//@ var str = cat('file*.txt');
-//@ var str = cat('file1', 'file2');
-//@ var str = cat(['file1', 'file2']); // same as above
-//@ ```
-//@
-//@ Returns a string containing the given file, or a concatenated string
-//@ containing the files if more than one file is given (a new line character is
-//@ introduced between each file).
-function _cat(options, files) {
-  var cat = common.readFromPipe();
+/**
+ * @param {string} specifier
+ * @param {URL} base
+ * @param {Set} conditions
+ * @returns {URL}
+ */
+function moduleResolve(specifier, base, conditions) {
+  // Order swapped from spec for minor perf gain.
+  // Ok since relative URLs cannot parse as URLs.
+  let resolved;
+  if (shouldBeTreatedAsRelativeOrAbsolutePath(specifier)) {
+    resolved = new URL(specifier, base);
+  } else if (specifier[0] === '#') {
+    ({ resolved } = packageImportsResolve(specifier, base, conditions));
+  } else {
+    try {
+      resolved = new URL(specifier);
+    } catch {
+      resolved = packageResolve(specifier, base, conditions);
+    }
+  }
+  return finalizeResolution(resolved, base);
+}
 
-  if (!files && !cat) common.error('no paths given');
+/**
+ * Try to resolve an import as a CommonJS module
+ * @param {string} specifier
+ * @param {string} parentURL
+ * @returns {boolean|string}
+ */
+function resolveAsCommonJS(specifier, parentURL) {
+  try {
+    const parent = fileURLToPath(parentURL);
+    const tmpModule = new CJSModule(parent, null);
+    tmpModule.paths = CJSModule._nodeModulePaths(parent);
 
-  files = [].slice.call(arguments, 1);
+    let found = CJSModule._resolveFilename(specifier, tmpModule, false);
 
-  files.forEach(function (file) {
-    if (!fs.existsSync(file)) {
-      common.error('no such file or directory: ' + file);
-    } else if (common.statFollowLinks(file).isDirectory()) {
-      common.error(file + ': Is a directory');
+    // If it is a relative specifier return the relative path
+    // to the parent
+    if (isRelativeSpecifier(specifier)) {
+      found = relative(parent, found);
+      // Add '.separator if the path does not start with '..separator'
+      // This should be a safe assumption because when loading
+      // esm modules there should be always a file specified so
+      // there should not be a specifier like '..' or '.'
+      if (!StringPrototypeStartsWith(found, `..${sep}`)) {
+        found = `.${sep}${found}`;
+      }
+    } else if (isBareSpecifier(specifier)) {
+      // If it is a bare specifier return the relative path within the
+      // module
+      const pkg = StringPrototypeSplit(specifier, '/')[0];
+      const index = StringPrototypeIndexOf(found, pkg);
+      if (index !== -1) {
+        found = StringPrototypeSlice(found, index);
+      }
     }
+    // Normalize the path separator to give a valid suggestion
+    // on Windows
+    if (process.platform === 'win32') {
+      found = StringPrototypeReplace(found, new RegExp(`\\${sep}`, 'g'), '/');
+    }
+    return found;
+  } catch {
+    return false;
+  }
+}
 
-    cat += fs.readFileSync(file, 'utf8');
-  });
-
-  if (options.number) {
-    cat = addNumbers(cat);
+function defaultResolve(specifier, context = {}, defaultResolveUnused) {
+  let { parentURL, conditions } = context;
+  if (parentURL && policy != null && policy.manifest) {
+    const redirects = policy.manifest.getDependencyMapper(parentURL);
+    if (redirects) {
+      const { resolve, reaction } = redirects;
+      const destination = resolve(specifier, new SafeSet(conditions));
+      let missing = true;
+      if (destination === true) {
+        missing = false;
+      } else if (destination) {
+        const href = destination.href;
+        return { url: href };
+      }
+      if (missing) {
+        reaction(new ERR_MANIFEST_DEPENDENCY_MISSING(
+          parentURL,
+          specifier,
+          ArrayPrototypeJoin([...conditions], ', '))
+        );
+      }
+    }
+  }
+  let parsed;
+  try {
+    parsed = new URL(specifier);
+    if (parsed.protocol === 'data:') {
+      return {
+        url: specifier
+      };
+    }
+  } catch {}
+  if (parsed && parsed.protocol === builtinModuleProtocol)
+    return { url: specifier };
+  if (parsed && parsed.protocol !== 'file:' && parsed.protocol !== 'data:')
+    throw new ERR_UNSUPPORTED_ESM_URL_SCHEME(parsed);
+  if (NativeModule.canBeRequiredByUsers(specifier)) {
+    return {
+      url: builtinModuleProtocol + specifier
+    };
+  }
+  if (parentURL && StringPrototypeStartsWith(parentURL, 'data:')) {
+    // This is gonna blow up, we want the error
+    new URL(specifier, parentURL);
   }
 
-  return cat;
-}
-module.exports = _cat;
+  const isMain = parentURL === undefined;
+  if (isMain) {
+    parentURL = pathToFileURL(`${process.cwd()}/`).href;
 
-function addNumbers(cat) {
-  var lines = cat.split('\n');
-  var lastLine = lines.pop();
+    // This is the initial entry point to the program, and --input-type has
+    // been passed as an option; but --input-type can only be used with
+    // --eval, --print or STDIN string input. It is not allowed with file
+    // input, to avoid user confusion over how expansive the effect of the
+    // flag should be (i.e. entry point only, package scope surrounding the
+    // entry point, etc.).
+    if (typeFlag)
+      throw new ERR_INPUT_TYPE_NOT_ALLOWED();
+  }
 
-  lines = lines.map(function (line, i) {
-    return numberedLine(i + 1, line);
-  });
+  conditions = getConditionsSet(conditions);
+  let url;
+  try {
+    url = moduleResolve(specifier, parentURL, conditions);
+  } catch (error) {
+    // Try to give the user a hint of what would have been the
+    // resolved CommonJS module
+    if (error.code === 'ERR_MODULE_NOT_FOUND' ||
+        error.code === 'ERR_UNSUPPORTED_DIR_IMPORT') {
+      if (StringPrototypeStartsWith(specifier, 'file://')) {
+        specifier = fileURLToPath(specifier);
+      }
+      const found = resolveAsCommonJS(specifier, parentURL);
+      if (found) {
+        // Modify the stack and message string to include the hint
+        const lines = StringPrototypeSplit(error.stack, '\n');
+        const hint = `Did you mean to import ${found}?`;
+        error.stack =
+          ArrayPrototypeShift(lines) + '\n' +
+          hint + '\n' +
+          ArrayPrototypeJoin(lines, '\n');
+        error.message += `\n${hint}`;
+      }
+    }
+    throw error;
+  }
 
-  if (lastLine.length) {
-    lastLine = numberedLine(lines.length + 1, lastLine);
+  if (isMain ? !preserveSymlinksMain : !preserveSymlinks) {
+    const urlPath = fileURLToPath(url);
+    const real = realpathSync(urlPath, {
+      // [internalFS.realpathCacheKey]: realpathCache
+    });
+    const old = url;
+    url = pathToFileURL(
+      real + (StringPrototypeEndsWith(urlPath, sep) ? '/' : ''));
+    url.search = old.search;
+    url.hash = old.hash;
   }
-  lines.push(lastLine);
 
-  return lines.join('\n');
+  return { url: `${url}` };
 }
 
-function numberedLine(n, line) {
-  // GNU cat use six pad start number + tab. See http://lingrok.org/xref/coreutils/src/cat.c#57
-  // https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/padStart
-  var number = ('     ' + n).slice(-6) + '\t';
-  return number + line;
+return {
+  DEFAULT_CONDITIONS,
+  defaultResolve,
+  encodedSepRegEx,
+  getPackageType,
+  packageExportsResolve,
+  packageImportsResolve
+};
 }
+module.exports = {
+  createResolve
+};
 
 
 /***/ }),
 
-/***/ 51829:
+/***/ 73104:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
-var os = __nccwpck_require__(22037);
-var common = __nccwpck_require__(17673);
+"use strict";
+// copied from https://github.com/nodejs/node/blob/v15.3.0/lib/internal/modules/package_json_reader.js
 
-common.register('cd', _cd, {});
 
-//@
-//@ ### cd([dir])
-//@
-//@ Changes to directory `dir` for the duration of the script. Changes to home
-//@ directory if no argument is supplied.
-function _cd(options, dir) {
-  if (!dir) dir = os.homedir();
+const { SafeMap } = __nccwpck_require__(57523);
+const { internalModuleReadJSON } = __nccwpck_require__(69149);
+const { pathToFileURL } = __nccwpck_require__(57310);
+const { toNamespacedPath } = __nccwpck_require__(71017);
+// const { getOptionValue } = require('./node-options');
 
-  if (dir === '-') {
-    if (!process.env.OLDPWD) {
-      common.error('could not find previous directory');
-    } else {
-      dir = process.env.OLDPWD;
-    }
+const cache = new SafeMap();
+
+let manifest;
+
+/**
+ * @param {string} jsonPath
+ * @return {{string: string, containsKeys: boolean}}
+ */
+function read(jsonPath) {
+  if (cache.has(jsonPath)) {
+    return cache.get(jsonPath);
   }
 
-  try {
-    var curDir = process.cwd();
-    process.chdir(dir);
-    process.env.OLDPWD = curDir;
-  } catch (e) {
-    // something went wrong, let's figure out the error
-    var err;
-    try {
-      common.statFollowLinks(dir); // if this succeeds, it must be some sort of file
-      err = 'not a directory: ' + dir;
-    } catch (e2) {
-      err = 'no such file or directory: ' + dir;
+  const [string, containsKeys] = internalModuleReadJSON(
+    toNamespacedPath(jsonPath)
+  );
+  const result = { string, containsKeys };
+  if (string !== undefined) {
+    if (manifest === undefined) {
+      // manifest = getOptionValue('--experimental-policy') ?
+      //   require('internal/process/policy').manifest :
+      //   null;
+      // disabled for now.  I am not sure if/how we should support this
+      manifest = null;
+    }
+    if (manifest !== null) {
+      const jsonURL = pathToFileURL(jsonPath);
+      manifest.assertIntegrity(jsonURL, string);
     }
-    if (err) common.error(err);
   }
-  return '';
+  cache.set(jsonPath, result);
+  return result;
 }
-module.exports = _cd;
+
+module.exports = { read };
 
 
 /***/ }),
 
-/***/ 81072:
+/***/ 18088:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
-var common = __nccwpck_require__(17673);
-var fs = __nccwpck_require__(57147);
-var path = __nccwpck_require__(71017);
-
-var PERMS = (function (base) {
-  return {
-    OTHER_EXEC: base.EXEC,
-    OTHER_WRITE: base.WRITE,
-    OTHER_READ: base.READ,
-
-    GROUP_EXEC: base.EXEC << 3,
-    GROUP_WRITE: base.WRITE << 3,
-    GROUP_READ: base.READ << 3,
+"use strict";
+// copied from https://github.com/nodejs/node/blob/88799930794045795e8abac874730f9eba7e2300/lib/internal/repl/await.js
 
-    OWNER_EXEC: base.EXEC << 6,
-    OWNER_WRITE: base.WRITE << 6,
-    OWNER_READ: base.READ << 6,
 
-    // Literal octal numbers are apparently not allowed in "strict" javascript.
-    STICKY: parseInt('01000', 8),
-    SETGID: parseInt('02000', 8),
-    SETUID: parseInt('04000', 8),
+const {
+  ArrayFrom,
+  ArrayPrototypeForEach,
+  ArrayPrototypeIncludes,
+  ArrayPrototypeJoin,
+  ArrayPrototypePop,
+  ArrayPrototypePush,
+  FunctionPrototype,
+  ObjectKeys,
+  RegExpPrototypeSymbolReplace,
+  StringPrototypeEndsWith,
+  StringPrototypeIncludes,
+  StringPrototypeIndexOf,
+  StringPrototypeRepeat,
+  StringPrototypeSplit,
+  StringPrototypeStartsWith,
+  SyntaxError,
+} = __nccwpck_require__(57523);
 
-    TYPE_MASK: parseInt('0770000', 8),
-  };
-}({
-  EXEC: 1,
-  WRITE: 2,
-  READ: 4,
-}));
+const parser = (__nccwpck_require__(69241).Parser);
+const walk = __nccwpck_require__(95141);
+const { Recoverable } = __nccwpck_require__(38102);
 
-common.register('chmod', _chmod, {
-});
+function isTopLevelDeclaration(state) {
+  return state.ancestors[state.ancestors.length - 2] === state.body;
+}
 
-//@
-//@ ### chmod([options,] octal_mode || octal_string, file)
-//@ ### chmod([options,] symbolic_mode, file)
-//@
-//@ Available options:
-//@
-//@ + `-v`: output a diagnostic for every file processed//@
-//@ + `-c`: like verbose, but report only when a change is made//@
-//@ + `-R`: change files and directories recursively//@
-//@
-//@ Examples:
-//@
-//@ ```javascript
-//@ chmod(755, '/Users/brandon');
-//@ chmod('755', '/Users/brandon'); // same as above
-//@ chmod('u+x', '/Users/brandon');
-//@ chmod('-R', 'a-w', '/Users/brandon');
-//@ ```
-//@
-//@ Alters the permissions of a file or directory by either specifying the
-//@ absolute permissions in octal form or expressing the changes in symbols.
-//@ This command tries to mimic the POSIX behavior as much as possible.
-//@ Notable exceptions:
-//@
-//@ + In symbolic modes, `a-r` and `-r` are identical.  No consideration is
-//@   given to the `umask`.
-//@ + There is no "quiet" option, since default behavior is to run silent.
-function _chmod(options, mode, filePattern) {
-  if (!filePattern) {
-    if (options.length > 0 && options.charAt(0) === '-') {
-      // Special case where the specified file permissions started with - to subtract perms, which
-      // get picked up by the option parser as command flags.
-      // If we are down by one argument and options starts with -, shift everything over.
-      [].unshift.call(arguments, '');
-    } else {
-      common.error('You must specify a file.');
+const noop = FunctionPrototype;
+const visitorsWithoutAncestors = {
+  ClassDeclaration(node, state, c) {
+    if (isTopLevelDeclaration(state)) {
+      state.prepend(node, `${node.id.name}=`);
+      ArrayPrototypePush(
+        state.hoistedDeclarationStatements,
+        `let ${node.id.name}; `
+      );
     }
-  }
-
-  options = common.parseOptions(options, {
-    'R': 'recursive',
-    'c': 'changes',
-    'v': 'verbose',
-  });
 
-  filePattern = [].slice.call(arguments, 2);
+    walk.base.ClassDeclaration(node, state, c);
+  },
+  ForOfStatement(node, state, c) {
+    if (node.await === true) {
+      state.containsAwait = true;
+    }
+    walk.base.ForOfStatement(node, state, c);
+  },
+  FunctionDeclaration(node, state, c) {
+    state.prepend(node, `${node.id.name}=`);
+    ArrayPrototypePush(
+      state.hoistedDeclarationStatements,
+      `var ${node.id.name}; `
+    );
+  },
+  FunctionExpression: noop,
+  ArrowFunctionExpression: noop,
+  MethodDefinition: noop,
+  AwaitExpression(node, state, c) {
+    state.containsAwait = true;
+    walk.base.AwaitExpression(node, state, c);
+  },
+  ReturnStatement(node, state, c) {
+    state.containsReturn = true;
+    walk.base.ReturnStatement(node, state, c);
+  },
+  VariableDeclaration(node, state, c) {
+    const variableKind = node.kind;
+    const isIterableForDeclaration = ArrayPrototypeIncludes(
+      ['ForOfStatement', 'ForInStatement'],
+      state.ancestors[state.ancestors.length - 2].type
+    );
 
-  var files;
+    if (variableKind === 'var' || isTopLevelDeclaration(state)) {
+      state.replace(
+        node.start,
+        node.start + variableKind.length + (isIterableForDeclaration ? 1 : 0),
+        variableKind === 'var' && isIterableForDeclaration ?
+          '' :
+          'void' + (node.declarations.length === 1 ? '' : ' (')
+      );
 
-  // TODO: replace this with a call to common.expand()
-  if (options.recursive) {
-    files = [];
-    filePattern.forEach(function addFile(expandedFile) {
-      var stat = common.statNoFollowLinks(expandedFile);
+      if (!isIterableForDeclaration) {
+        ArrayPrototypeForEach(node.declarations, (decl) => {
+          state.prepend(decl, '(');
+          state.append(decl, decl.init ? ')' : '=undefined)');
+        });
 
-      if (!stat.isSymbolicLink()) {
-        files.push(expandedFile);
+        if (node.declarations.length !== 1) {
+          state.append(node.declarations[node.declarations.length - 1], ')');
+        }
+      }
 
-        if (stat.isDirectory()) {  // intentionally does not follow symlinks.
-          fs.readdirSync(expandedFile).forEach(function (child) {
-            addFile(expandedFile + '/' + child);
-          });
+      const variableIdentifiersToHoist = [
+        ['var', []],
+        ['let', []],
+      ];
+      function registerVariableDeclarationIdentifiers(node) {
+        switch (node.type) {
+          case 'Identifier':
+            ArrayPrototypePush(
+              variableIdentifiersToHoist[variableKind === 'var' ? 0 : 1][1],
+              node.name
+            );
+            break;
+          case 'ObjectPattern':
+            ArrayPrototypeForEach(node.properties, (property) => {
+              registerVariableDeclarationIdentifiers(property.value);
+            });
+            break;
+          case 'ArrayPattern':
+            ArrayPrototypeForEach(node.elements, (element) => {
+              registerVariableDeclarationIdentifiers(element);
+            });
+            break;
         }
       }
-    });
-  } else {
-    files = filePattern;
-  }
 
-  files.forEach(function innerChmod(file) {
-    file = path.resolve(file);
-    if (!fs.existsSync(file)) {
-      common.error('File not found: ' + file);
-    }
+      ArrayPrototypeForEach(node.declarations, (decl) => {
+        registerVariableDeclarationIdentifiers(decl.id);
+      });
 
-    // When recursing, don't follow symlinks.
-    if (options.recursive && common.statNoFollowLinks(file).isSymbolicLink()) {
-      return;
+      ArrayPrototypeForEach(
+        variableIdentifiersToHoist,
+        ({ 0: kind, 1: identifiers }) => {
+          if (identifiers.length > 0) {
+            ArrayPrototypePush(
+              state.hoistedDeclarationStatements,
+              `${kind} ${ArrayPrototypeJoin(identifiers, ', ')}; `
+            );
+          }
+        }
+      );
     }
 
-    var stat = common.statFollowLinks(file);
-    var isDir = stat.isDirectory();
-    var perms = stat.mode;
-    var type = perms & PERMS.TYPE_MASK;
+    walk.base.VariableDeclaration(node, state, c);
+  }
+};
 
-    var newPerms = perms;
+const visitors = {};
+for (const nodeType of ObjectKeys(walk.base)) {
+  const callback = visitorsWithoutAncestors[nodeType] || walk.base[nodeType];
+  visitors[nodeType] = (node, state, c) => {
+    const isNew = node !== state.ancestors[state.ancestors.length - 1];
+    if (isNew) {
+      ArrayPrototypePush(state.ancestors, node);
+    }
+    callback(node, state, c);
+    if (isNew) {
+      ArrayPrototypePop(state.ancestors);
+    }
+  };
+}
 
-    if (isNaN(parseInt(mode, 8))) {
-      // parse options
-      mode.split(',').forEach(function (symbolicMode) {
-        var pattern = /([ugoa]*)([=\+-])([rwxXst]*)/i;
-        var matches = pattern.exec(symbolicMode);
+function processTopLevelAwait(src) {
+  const wrapPrefix = '(async () => { ';
+  const wrapped = `${wrapPrefix}${src} })()`;
+  const wrappedArray = ArrayFrom(wrapped);
+  let root;
+  try {
+    root = parser.parse(wrapped, { ecmaVersion: 'latest' });
+  } catch (e) {
+    if (StringPrototypeStartsWith(e.message, 'Unterminated '))
+      throw new Recoverable(e);
+    // If the parse error is before the first "await", then use the execution
+    // error. Otherwise we must emit this parse error, making it look like a
+    // proper syntax error.
+    const awaitPos = StringPrototypeIndexOf(src, 'await');
+    const errPos = e.pos - wrapPrefix.length;
+    if (awaitPos > errPos)
+      return null;
+    // Convert keyword parse errors on await into their original errors when
+    // possible.
+    if (errPos === awaitPos + 6 &&
+        StringPrototypeIncludes(e.message, 'Expecting Unicode escape sequence'))
+      return null;
+    if (errPos === awaitPos + 7 &&
+        StringPrototypeIncludes(e.message, 'Unexpected token'))
+      return null;
+    const line = e.loc.line;
+    const column = line === 1 ? e.loc.column - wrapPrefix.length : e.loc.column;
+    let message = '\n' + StringPrototypeSplit(src, '\n')[line - 1] + '\n' +
+        StringPrototypeRepeat(' ', column) +
+        '^\n\n' + RegExpPrototypeSymbolReplace(/ \([^)]+\)/, e.message, '');
+    // V8 unexpected token errors include the token string.
+    if (StringPrototypeEndsWith(message, 'Unexpected token'))
+      message += " '" +
+        // Wrapper end may cause acorn to report error position after the source
+        ((src.length - 1) >= (e.pos - wrapPrefix.length)
+          ? src[e.pos - wrapPrefix.length]
+          : src[src.length - 1]) +
+        "'";
+    // eslint-disable-next-line no-restricted-syntax
+    throw new SyntaxError(message);
+  }
+  const body = root.body[0].expression.callee.body;
+  const state = {
+    body,
+    ancestors: [],
+    hoistedDeclarationStatements: [],
+    replace(from, to, str) {
+      for (let i = from; i < to; i++) {
+        wrappedArray[i] = '';
+      }
+      if (from === to) str += wrappedArray[from];
+      wrappedArray[from] = str;
+    },
+    prepend(node, str) {
+      wrappedArray[node.start] = str + wrappedArray[node.start];
+    },
+    append(node, str) {
+      wrappedArray[node.end - 1] += str;
+    },
+    containsAwait: false,
+    containsReturn: false
+  };
 
-        if (matches) {
-          var applyTo = matches[1];
-          var operator = matches[2];
-          var change = matches[3];
+  walk.recursive(body, state, visitors);
 
-          var changeOwner = applyTo.indexOf('u') !== -1 || applyTo === 'a' || applyTo === '';
-          var changeGroup = applyTo.indexOf('g') !== -1 || applyTo === 'a' || applyTo === '';
-          var changeOther = applyTo.indexOf('o') !== -1 || applyTo === 'a' || applyTo === '';
+  // Do not transform if
+  // 1. False alarm: there isn't actually an await expression.
+  // 2. There is a top-level return, which is not allowed.
+  if (!state.containsAwait || state.containsReturn) {
+    return null;
+  }
 
-          var changeRead = change.indexOf('r') !== -1;
-          var changeWrite = change.indexOf('w') !== -1;
-          var changeExec = change.indexOf('x') !== -1;
-          var changeExecDir = change.indexOf('X') !== -1;
-          var changeSticky = change.indexOf('t') !== -1;
-          var changeSetuid = change.indexOf('s') !== -1;
+  const last = body.body[body.body.length - 1];
+  if (last.type === 'ExpressionStatement') {
+    // For an expression statement of the form
+    // ( expr ) ;
+    // ^^^^^^^^^^   // last
+    //   ^^^^       // last.expression
+    //
+    // We do not want the left parenthesis before the `return` keyword;
+    // therefore we prepend the `return (` to `last`.
+    //
+    // On the other hand, we do not want the right parenthesis after the
+    // semicolon. Since there can only be more right parentheses between
+    // last.expression.end and the semicolon, appending one more to
+    // last.expression should be fine.
+    state.prepend(last, 'return (');
+    state.append(last.expression, ')');
+  }
 
-          if (changeExecDir && isDir) {
-            changeExec = true;
-          }
+  return (
+    ArrayPrototypeJoin(state.hoistedDeclarationStatements, '') +
+    ArrayPrototypeJoin(wrappedArray, '')
+  );
+}
 
-          var mask = 0;
-          if (changeOwner) {
-            mask |= (changeRead ? PERMS.OWNER_READ : 0) + (changeWrite ? PERMS.OWNER_WRITE : 0) + (changeExec ? PERMS.OWNER_EXEC : 0) + (changeSetuid ? PERMS.SETUID : 0);
-          }
-          if (changeGroup) {
-            mask |= (changeRead ? PERMS.GROUP_READ : 0) + (changeWrite ? PERMS.GROUP_WRITE : 0) + (changeExec ? PERMS.GROUP_EXEC : 0) + (changeSetuid ? PERMS.SETGID : 0);
-          }
-          if (changeOther) {
-            mask |= (changeRead ? PERMS.OTHER_READ : 0) + (changeWrite ? PERMS.OTHER_WRITE : 0) + (changeExec ? PERMS.OTHER_EXEC : 0);
-          }
+module.exports = {
+  processTopLevelAwait
+};
 
-          // Sticky bit is special - it's not tied to user, group or other.
-          if (changeSticky) {
-            mask |= PERMS.STICKY;
-          }
 
-          switch (operator) {
-            case '+':
-              newPerms |= mask;
-              break;
+/***/ }),
 
-            case '-':
-              newPerms &= ~mask;
-              break;
+/***/ 69149:
+/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
-            case '=':
-              newPerms = type + mask;
+const fs = __nccwpck_require__(57147);
+const {versionGteLt} = __nccwpck_require__(26239);
 
-              // According to POSIX, when using = to explicitly set the
-              // permissions, setuid and setgid can never be cleared.
-              if (common.statFollowLinks(file).isDirectory()) {
-                newPerms |= (PERMS.SETUID + PERMS.SETGID) & perms;
-              }
-              break;
-            default:
-              common.error('Could not recognize operator: `' + operator + '`');
-          }
+// In node's core, this is implemented in C
+// https://github.com/nodejs/node/blob/v15.3.0/src/node_file.cc#L891-L985
+/**
+ * @param {string} path
+ * @returns {[] | [string, boolean]}
+ */
+function internalModuleReadJSON(path) {
+  let string
+  try {
+    string = fs.readFileSync(path, 'utf8')
+  } catch (e) {
+    if (e.code === 'ENOENT') return []
+    throw e
+  }
+  // Node's implementation checks for the presence of relevant keys: main, name, type, exports, imports
+  // Node does this for performance to skip unnecessary parsing.
+  // This would slow us down and, based on our usage, we can skip it.
+  const containsKeys = true
+  return [string, containsKeys]
+}
 
-          if (options.verbose) {
-            console.log(file + ' -> ' + newPerms.toString(8));
-          }
+// In node's core, this is implemented in C
+// https://github.com/nodejs/node/blob/63e7dc1e5c71b70c80ed9eda230991edb00811e2/src/node_file.cc#L987-L1005
+/**
+ * @param {string} path
+ * @returns {number} 0 = file, 1 = dir, negative = error
+ */
+function internalModuleStat(path) {
+  const stat = fs.statSync(path, { throwIfNoEntry: false });
+  if(!stat) return -1;
+  if(stat.isFile()) return 0;
+  if(stat.isDirectory()) return 1;
+}
 
-          if (perms !== newPerms) {
-            if (!options.verbose && options.changes) {
-              console.log(file + ' -> ' + newPerms.toString(8));
-            }
-            fs.chmodSync(file, newPerms);
-            perms = newPerms; // for the next round of changes!
-          }
-        } else {
-          common.error('Invalid symbolic mode change: ' + symbolicMode);
-        }
-      });
-    } else {
-      // they gave us a full number
-      newPerms = type + parseInt(mode, 8);
+/**
+ * @param {string} path
+ * @returns {number} 0 = file, 1 = dir, negative = error
+ */
+function internalModuleStatInefficient(path) {
+  try {
+    const stat = fs.statSync(path);
+    if(stat.isFile()) return 0;
+    if(stat.isDirectory()) return 1;
+  } catch(e) {
+    return -e.errno || -1;
+  }
+}
 
-      // POSIX rules are that setuid and setgid can only be added using numeric
-      // form, but not cleared.
-      if (common.statFollowLinks(file).isDirectory()) {
-        newPerms |= (PERMS.SETUID + PERMS.SETGID) & perms;
-      }
+const statSupportsThrowIfNoEntry = versionGteLt(process.versions.node, '15.3.0') ||
+  versionGteLt(process.versions.node, '14.17.0', '15.0.0');
 
-      fs.chmodSync(file, newPerms);
-    }
-  });
-  return '';
-}
-module.exports = _chmod;
+module.exports = {
+  internalModuleReadJSON,
+  internalModuleStat: statSupportsThrowIfNoEntry ? internalModuleStat : internalModuleStatInefficient
+};
 
 
 /***/ }),
 
-/***/ 17673:
+/***/ 12061:
 /***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
-"use strict";
-// Ignore warning about 'new String()'
-/* eslint no-new-wrappers: 0 */
 
+// Node imports this from 'internal/bootstrap/loaders'
+const Module = __nccwpck_require__(98188);
+const NativeModule = {
+  canBeRequiredByUsers(specifier) {
+    return Module.builtinModules.includes(specifier)
+  }
+};
+exports.NativeModule = NativeModule;
 
-var os = __nccwpck_require__(22037);
-var fs = __nccwpck_require__(57147);
-var glob = __nccwpck_require__(20557);
-var shell = __nccwpck_require__(54572);
 
-var shellMethods = Object.create(shell);
+/***/ }),
 
-exports.extend = Object.assign;
+/***/ 92060:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
-// Check if we're running under electron
-var isElectron = Boolean(process.versions.electron);
+// Replacement for node's internal 'internal/options' module
 
-// Module globals (assume no execPath by default)
-var DEFAULT_CONFIG = {
-  fatal: false,
-  globOptions: {},
-  maxdepth: 255,
-  noglob: false,
-  silent: false,
-  verbose: false,
-  execPath: null,
-  bufLength: 64 * 1024, // 64KB
-};
+exports.getOptionValue = getOptionValue;
+function getOptionValue(opt) {
+  parseOptions();
+  return options[opt];
+}
 
-var config = {
-  reset: function () {
-    Object.assign(this, DEFAULT_CONFIG);
-    if (!isElectron) {
-      this.execPath = process.execPath;
+let options;
+function parseOptions() {
+  if (!options) {
+    options = {
+      '--preserve-symlinks': false,
+      '--preserve-symlinks-main': false,
+      '--input-type': undefined,
+      '--experimental-specifier-resolution': 'explicit',
+      '--experimental-policy': undefined,
+      '--conditions': [],
+      '--pending-deprecation': false,
+      ...parseArgv(getNodeOptionsEnvArgv()),
+      ...parseArgv(process.execArgv),
+      ...getOptionValuesFromOtherEnvVars()
     }
-  },
-  resetForTesting: function () {
-    this.reset();
-    this.silent = true;
-  },
-};
-
-config.reset();
-exports.config = config;
-
-// Note: commands should generally consider these as read-only values.
-var state = {
-  error: null,
-  errorCode: 0,
-  currentCmd: 'shell.js',
-};
-exports.state = state;
-
-delete process.env.OLDPWD; // initially, there's no previous directory
-
-// Reliably test if something is any sort of javascript object
-function isObject(a) {
-  return typeof a === 'object' && a !== null;
-}
-exports.isObject = isObject;
-
-function log() {
-  /* istanbul ignore next */
-  if (!config.silent) {
-    console.error.apply(console, arguments);
-  }
-}
-exports.log = log;
-
-// Converts strings to be equivalent across all platforms. Primarily responsible
-// for making sure we use '/' instead of '\' as path separators, but this may be
-// expanded in the future if necessary
-function convertErrorOutput(msg) {
-  if (typeof msg !== 'string') {
-    throw new TypeError('input must be a string');
-  }
-  return msg.replace(/\\/g, '/');
-}
-exports.convertErrorOutput = convertErrorOutput;
-
-// Shows error message. Throws if config.fatal is true
-function error(msg, _code, options) {
-  // Validate input
-  if (typeof msg !== 'string') throw new Error('msg must be a string');
-
-  var DEFAULT_OPTIONS = {
-    continue: false,
-    code: 1,
-    prefix: state.currentCmd + ': ',
-    silent: false,
-  };
-
-  if (typeof _code === 'number' && isObject(options)) {
-    options.code = _code;
-  } else if (isObject(_code)) { // no 'code'
-    options = _code;
-  } else if (typeof _code === 'number') { // no 'options'
-    options = { code: _code };
-  } else if (typeof _code !== 'number') { // only 'msg'
-    options = {};
-  }
-  options = Object.assign({}, DEFAULT_OPTIONS, options);
-
-  if (!state.errorCode) state.errorCode = options.code;
-
-  var logEntry = convertErrorOutput(options.prefix + msg);
-  state.error = state.error ? state.error + '\n' : '';
-  state.error += logEntry;
-
-  // Throw an error, or log the entry
-  if (config.fatal) throw new Error(logEntry);
-  if (msg.length > 0 && !options.silent) log(logEntry);
-
-  if (!options.continue) {
-    throw {
-      msg: 'earlyExit',
-      retValue: (new ShellString('', state.error, state.errorCode)),
-    };
   }
 }
-exports.error = error;
 
-//@
-//@ ### ShellString(str)
-//@
-//@ Examples:
-//@
-//@ ```javascript
-//@ var foo = ShellString('hello world');
-//@ ```
-//@
-//@ Turns a regular string into a string-like object similar to what each
-//@ command returns. This has special methods, like `.to()` and `.toEnd()`.
-function ShellString(stdout, stderr, code) {
-  var that;
-  if (stdout instanceof Array) {
-    that = stdout;
-    that.stdout = stdout.join('\n');
-    if (stdout.length > 0) that.stdout += '\n';
-  } else {
-    that = new String(stdout);
-    that.stdout = stdout;
-  }
-  that.stderr = stderr;
-  that.code = code;
-  // A list of all commands that can appear on the right-hand side of a pipe
-  // (populated by calls to common.wrap())
-  pipeMethods.forEach(function (cmd) {
-    that[cmd] = shellMethods[cmd].bind(that);
+function parseArgv(argv) {
+  return __nccwpck_require__(69888)({
+    '--preserve-symlinks': Boolean,
+    '--preserve-symlinks-main': Boolean,
+    '--input-type': String,
+    '--experimental-specifier-resolution': String,
+    // Legacy alias for node versions prior to 12.16
+    '--es-module-specifier-resolution': '--experimental-specifier-resolution',
+    '--experimental-policy': String,
+    '--conditions': [String],
+    '--pending-deprecation': Boolean,
+    '--experimental-json-modules': Boolean,
+    '--experimental-wasm-modules': Boolean,
+  }, {
+    argv,
+    permissive: true
   });
-  return that;
 }
 
-exports.ShellString = ShellString;
-
-// Returns {'alice': true, 'bob': false} when passed a string and dictionary as follows:
-//   parseOptions('-a', {'a':'alice', 'b':'bob'});
-// Returns {'reference': 'string-value', 'bob': false} when passed two dictionaries of the form:
-//   parseOptions({'-r': 'string-value'}, {'r':'reference', 'b':'bob'});
-// Throws an error when passed a string that does not start with '-':
-//   parseOptions('a', {'a':'alice'}); // throws
-function parseOptions(opt, map, errorOptions) {
-  // Validate input
-  if (typeof opt !== 'string' && !isObject(opt)) {
-    throw new Error('options must be strings or key-value pairs');
-  } else if (!isObject(map)) {
-    throw new Error('parseOptions() internal error: map must be an object');
-  } else if (errorOptions && !isObject(errorOptions)) {
-    throw new Error('parseOptions() internal error: errorOptions must be object');
-  }
-
-  if (opt === '--') {
-    // This means there are no options.
-    return {};
+function getNodeOptionsEnvArgv() {
+  const errors = [];
+  const envArgv = ParseNodeOptionsEnvVar(process.env.NODE_OPTIONS || '', errors);
+  if (errors.length !== 0) {
+    // TODO: handle errors somehow
   }
+  return envArgv;
+}
 
-  // All options are false by default
-  var options = {};
-  Object.keys(map).forEach(function (letter) {
-    var optName = map[letter];
-    if (optName[0] !== '!') {
-      options[optName] = false;
-    }
-  });
-
-  if (opt === '') return options; // defaults
-
-  if (typeof opt === 'string') {
-    if (opt[0] !== '-') {
-      throw new Error("Options string must start with a '-'");
-    }
+// Direct JS port of C implementation: https://github.com/nodejs/node/blob/67ba825037b4082d5d16f922fb9ce54516b4a869/src/node_options.cc#L1024-L1063
+function ParseNodeOptionsEnvVar(node_options, errors) {
+  const env_argv = [];
 
-    // e.g. chars = ['R', 'f']
-    var chars = opt.slice(1).split('');
+  let is_in_string = false;
+  let will_start_new_arg = true;
+  for (let index = 0; index < node_options.length; ++index) {
+      let c = node_options[index];
 
-    chars.forEach(function (c) {
-      if (c in map) {
-        var optionName = map[c];
-        if (optionName[0] === '!') {
-          options[optionName.slice(1)] = false;
-        } else {
-          options[optionName] = true;
-        }
-      } else {
-        error('option not recognized: ' + c, errorOptions || {});
+      // Backslashes escape the following character
+      if (c === '\\' && is_in_string) {
+          if (index + 1 === node_options.length) {
+              errors.push("invalid value for NODE_OPTIONS " +
+                  "(invalid escape)\n");
+              return env_argv;
+          } else {
+              c = node_options[++index];
+          }
+      } else if (c === ' ' && !is_in_string) {
+          will_start_new_arg = true;
+          continue;
+      } else if (c === '"') {
+          is_in_string = !is_in_string;
+          continue;
       }
-    });
-  } else { // opt is an Object
-    Object.keys(opt).forEach(function (key) {
-      // key is a string of the form '-r', '-d', etc.
-      var c = key[1];
-      if (c in map) {
-        var optionName = map[c];
-        options[optionName] = opt[key]; // assign the given value
+
+      if (will_start_new_arg) {
+          env_argv.push(c);
+          will_start_new_arg = false;
       } else {
-        error('option not recognized: ' + c, errorOptions || {});
+          env_argv[env_argv.length - 1] += c;
       }
-    });
-  }
-  return options;
-}
-exports.parseOptions = parseOptions;
-
-// Expands wildcards with matching (ie. existing) file names.
-// For example:
-//   expand(['file*.js']) = ['file1.js', 'file2.js', ...]
-//   (if the files 'file1.js', 'file2.js', etc, exist in the current dir)
-function expand(list) {
-  if (!Array.isArray(list)) {
-    throw new TypeError('must be an array');
   }
-  var expanded = [];
-  list.forEach(function (listEl) {
-    // Don't expand non-strings
-    if (typeof listEl !== 'string') {
-      expanded.push(listEl);
-    } else {
-      var ret;
-      try {
-        ret = glob.sync(listEl, config.globOptions);
-        // if nothing matched, interpret the string literally
-        ret = ret.length > 0 ? ret : [listEl];
-      } catch (e) {
-        // if glob fails, interpret the string literally
-        ret = [listEl];
-      }
-      expanded = expanded.concat(ret);
-    }
-  });
-  return expanded;
-}
-exports.expand = expand;
-
-// Normalizes Buffer creation, using Buffer.alloc if possible.
-// Also provides a good default buffer length for most use cases.
-var buffer = typeof Buffer.alloc === 'function' ?
-  function (len) {
-    return Buffer.alloc(len || config.bufLength);
-  } :
-  function (len) {
-    return new Buffer(len || config.bufLength);
-  };
-exports.buffer = buffer;
 
-// Normalizes _unlinkSync() across platforms to match Unix behavior, i.e.
-// file can be unlinked even if it's read-only, see https://github.com/joyent/node/issues/3006
-function unlinkSync(file) {
-  try {
-    fs.unlinkSync(file);
-  } catch (e) {
-    // Try to override file permission
-    /* istanbul ignore next */
-    if (e.code === 'EPERM') {
-      fs.chmodSync(file, '0666');
-      fs.unlinkSync(file);
-    } else {
-      throw e;
-    }
+  if (is_in_string) {
+      errors.push("invalid value for NODE_OPTIONS " +
+          "(unterminated string)\n");
   }
+  return env_argv;
 }
-exports.unlinkSync = unlinkSync;
-
-// wrappers around common.statFollowLinks and common.statNoFollowLinks that clarify intent
-// and improve readability
-function statFollowLinks() {
-  return fs.statSync.apply(fs, arguments);
-}
-exports.statFollowLinks = statFollowLinks;
-
-function statNoFollowLinks() {
-  return fs.lstatSync.apply(fs, arguments);
-}
-exports.statNoFollowLinks = statNoFollowLinks;
 
-// e.g. 'shelljs_a5f185d0443ca...'
-function randomFileName() {
-  function randomHash(count) {
-    if (count === 1) {
-      return parseInt(16 * Math.random(), 10).toString(16);
-    }
-    var hash = '';
-    for (var i = 0; i < count; i++) {
-      hash += randomHash(1);
-    }
-    return hash;
+// Get option values that can be specified via env vars besides NODE_OPTIONS
+function getOptionValuesFromOtherEnvVars() {
+  const options = {};
+  if(process.env.NODE_PENDING_DEPRECATION === '1') {
+    options['--pending-deprecation'] = true;
   }
-
-  return 'shelljs_' + randomHash(20);
+  return options;
 }
-exports.randomFileName = randomFileName;
-
-// Common wrapper for all Unix-like commands that performs glob expansion,
-// command-logging, and other nice things
-function wrap(cmd, fn, options) {
-  options = options || {};
-  return function () {
-    var retValue = null;
 
-    state.currentCmd = cmd;
-    state.error = null;
-    state.errorCode = 0;
 
-    try {
-      var args = [].slice.call(arguments, 0);
+/***/ }),
 
-      // Log the command to stderr, if appropriate
-      if (config.verbose) {
-        console.error.apply(console, [cmd].concat(args));
-      }
+/***/ 57523:
+/***/ ((module) => {
 
-      // If this is coming from a pipe, let's set the pipedValue (otherwise, set
-      // it to the empty string)
-      state.pipedValue = (this && typeof this.stdout === 'string') ? this.stdout : '';
+module.exports = {
+  ArrayFrom: Array.from,
+  ArrayIsArray: Array.isArray,
+  ArrayPrototypeShift: (obj) => Array.prototype.shift.call(obj),
+  ArrayPrototypeForEach: (arr, ...rest) => Array.prototype.forEach.apply(arr, rest),
+  ArrayPrototypeIncludes: (arr, ...rest) => Array.prototype.includes.apply(arr, rest),
+  ArrayPrototypeJoin: (arr, ...rest) => Array.prototype.join.apply(arr, rest),
+  ArrayPrototypePop: (arr, ...rest) => Array.prototype.pop.apply(arr, rest),
+  ArrayPrototypePush: (arr, ...rest) => Array.prototype.push.apply(arr, rest),
+  FunctionPrototype: Function.prototype,
+  JSONParse: JSON.parse,
+  JSONStringify: JSON.stringify,
+  ObjectFreeze: Object.freeze,
+  ObjectKeys: Object.keys,
+  ObjectGetOwnPropertyNames: Object.getOwnPropertyNames,
+  ObjectDefineProperty: Object.defineProperty,
+  ObjectPrototypeHasOwnProperty: (obj, prop) => Object.prototype.hasOwnProperty.call(obj, prop),
+  RegExpPrototypeExec: (obj, string) => RegExp.prototype.exec.call(obj, string),
+  RegExpPrototypeTest: (obj, string) => RegExp.prototype.test.call(obj, string),
+  RegExpPrototypeSymbolReplace: (obj, ...rest) => RegExp.prototype[Symbol.replace].apply(obj, rest),
+  SafeMap: Map,
+  SafeSet: Set,
+  SafeWeakMap: WeakMap,
+  StringPrototypeEndsWith: (str, ...rest) => String.prototype.endsWith.apply(str, rest),
+  StringPrototypeIncludes: (str, ...rest) => String.prototype.includes.apply(str, rest),
+  StringPrototypeLastIndexOf: (str, ...rest) => String.prototype.lastIndexOf.apply(str, rest),
+  StringPrototypeIndexOf: (str, ...rest) => String.prototype.indexOf.apply(str, rest),
+  StringPrototypeRepeat: (str, ...rest) => String.prototype.repeat.apply(str, rest),
+  StringPrototypeReplace: (str, ...rest) => String.prototype.replace.apply(str, rest),
+  StringPrototypeSlice: (str, ...rest) => String.prototype.slice.apply(str, rest),
+  StringPrototypeSplit: (str, ...rest) => String.prototype.split.apply(str, rest),
+  StringPrototypeStartsWith: (str, ...rest) => String.prototype.startsWith.apply(str, rest),
+  StringPrototypeSubstr: (str, ...rest) => String.prototype.substr.apply(str, rest),
+  StringPrototypeCharCodeAt: (str, ...rest) => String.prototype.charCodeAt.apply(str, rest),
+  StringPrototypeMatch: (str, ...rest) => String.prototype.match.apply(str, rest),
+  SyntaxError: SyntaxError
+};
 
-      if (options.unix === false) { // this branch is for exec()
-        retValue = fn.apply(this, args);
-      } else { // and this branch is for everything else
-        if (isObject(args[0]) && args[0].constructor.name === 'Object') {
-          // a no-op, allowing the syntax `touch({'-r': file}, ...)`
-        } else if (args.length === 0 || typeof args[0] !== 'string' || args[0].length <= 1 || args[0][0] !== '-') {
-          args.unshift(''); // only add dummy option if '-option' not already present
-        }
 
-        // flatten out arrays that are arguments, to make the syntax:
-        //    `cp([file1, file2, file3], dest);`
-        // equivalent to:
-        //    `cp(file1, file2, file3, dest);`
-        args = args.reduce(function (accum, cur) {
-          if (Array.isArray(cur)) {
-            return accum.concat(cur);
-          }
-          accum.push(cur);
-          return accum;
-        }, []);
+/***/ }),
 
-        // Convert ShellStrings (basically just String objects) to regular strings
-        args = args.map(function (arg) {
-          if (isObject(arg) && arg.constructor.name === 'String') {
-            return arg.toString();
-          }
-          return arg;
-        });
+/***/ 72501:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
-        // Expand the '~' if appropriate
-        var homeDir = os.homedir();
-        args = args.map(function (arg) {
-          if (typeof arg === 'string' && arg.slice(0, 2) === '~/' || arg === '~') {
-            return arg.replace(/^~/, homeDir);
-          }
-          return arg;
-        });
+"use strict";
 
-        // Perform glob-expansion on all arguments after globStart, but preserve
-        // the arguments before it (like regexes for sed and grep)
-        if (!config.noglob && options.allowGlobbing === true) {
-          args = args.slice(0, options.globStart).concat(expand(args.slice(options.globStart)));
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.installCommonjsResolveHooksIfNecessary = void 0;
+/**
+ * @internal
+ */
+function installCommonjsResolveHooksIfNecessary(tsNodeService) {
+    const Module = __nccwpck_require__(98188);
+    const originalResolveFilename = Module._resolveFilename;
+    const originalFindPath = Module._findPath;
+    const shouldInstallHook = tsNodeService.options.experimentalResolver;
+    if (shouldInstallHook) {
+        const { Module_findPath, Module_resolveFilename } = tsNodeService.getNodeCjsLoader();
+        Module._resolveFilename = _resolveFilename;
+        Module._findPath = _findPath;
+        function _resolveFilename(request, parent, isMain, options, ...rest) {
+            if (!tsNodeService.enabled())
+                return originalResolveFilename.call(this, request, parent, isMain, options, ...rest);
+            return Module_resolveFilename.call(this, request, parent, isMain, options, ...rest);
         }
-
-        try {
-          // parse options if options are provided
-          if (isObject(options.cmdOptions)) {
-            args[0] = parseOptions(args[0], options.cmdOptions);
-          }
-
-          retValue = fn.apply(this, args);
-        } catch (e) {
-          /* istanbul ignore else */
-          if (e.msg === 'earlyExit') {
-            retValue = e.retValue;
-          } else {
-            throw e; // this is probably a bug that should be thrown up the call stack
-          }
+        function _findPath() {
+            if (!tsNodeService.enabled())
+                return originalFindPath.apply(this, arguments);
+            return Module_findPath.apply(this, arguments);
         }
-      }
-    } catch (e) {
-      /* istanbul ignore next */
-      if (!state.error) {
-        // If state.error hasn't been set it's an error thrown by Node, not us - probably a bug...
-        e.name = 'ShellJSInternalError';
-        throw e;
-      }
-      if (config.fatal) throw e;
-    }
-
-    if (options.wrapOutput &&
-        (typeof retValue === 'string' || Array.isArray(retValue))) {
-      retValue = new ShellString(retValue, state.error, state.errorCode);
     }
-
-    state.currentCmd = 'shell.js';
-    return retValue;
-  };
-} // wrap
-exports.wrap = wrap;
-
-// This returns all the input that is piped into the current command (or the
-// empty string, if this isn't on the right-hand side of a pipe
-function _readFromPipe() {
-  return state.pipedValue;
 }
-exports.readFromPipe = _readFromPipe;
+exports.installCommonjsResolveHooksIfNecessary = installCommonjsResolveHooksIfNecessary;
+//# sourceMappingURL=cjs-resolve-hooks.js.map
 
-var DEFAULT_WRAP_OPTIONS = {
-  allowGlobbing: true,
-  canReceivePipe: false,
-  cmdOptions: null,
-  globStart: 1,
-  pipeOnly: false,
-  wrapOutput: true,
-  unix: true,
-};
+/***/ }),
 
-// This is populated during plugin registration
-var pipeMethods = [];
+/***/ 45981:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
-// Register a new ShellJS command
-function _register(name, implementation, wrapOptions) {
-  wrapOptions = wrapOptions || {};
+"use strict";
 
-  // Validate options
-  Object.keys(wrapOptions).forEach(function (option) {
-    if (!DEFAULT_WRAP_OPTIONS.hasOwnProperty(option)) {
-      throw new Error("Unknown option '" + option + "'");
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.getTsConfigDefaults = exports.ComputeAsCommonRootOfFiles = exports.loadCompiler = exports.resolveAndLoadCompiler = exports.readConfig = exports.findAndReadConfig = void 0;
+const path_1 = __nccwpck_require__(71017);
+const index_1 = __nccwpck_require__(94828);
+const ts_internals_1 = __nccwpck_require__(80301);
+const tsconfigs_1 = __nccwpck_require__(88933);
+const util_1 = __nccwpck_require__(26239);
+/**
+ * TypeScript compiler option values required by `ts-node` which cannot be overridden.
+ */
+const TS_NODE_COMPILER_OPTIONS = {
+    sourceMap: true,
+    inlineSourceMap: false,
+    inlineSources: true,
+    declaration: false,
+    noEmit: false,
+    outDir: '.ts-node',
+};
+/*
+ * Do post-processing on config options to support `ts-node`.
+ */
+function fixConfig(ts, config) {
+    // Delete options that *should not* be passed through.
+    delete config.options.out;
+    delete config.options.outFile;
+    delete config.options.composite;
+    delete config.options.declarationDir;
+    delete config.options.declarationMap;
+    delete config.options.emitDeclarationOnly;
+    // Target ES5 output by default (instead of ES3).
+    if (config.options.target === undefined) {
+        config.options.target = ts.ScriptTarget.ES5;
     }
-    if (typeof wrapOptions[option] !== typeof DEFAULT_WRAP_OPTIONS[option]) {
-      throw new TypeError("Unsupported type '" + typeof wrapOptions[option] +
-        "' for option '" + option + "'");
+    // Target CommonJS modules by default (instead of magically switching to ES6 when the target is ES6).
+    if (config.options.module === undefined) {
+        config.options.module = ts.ModuleKind.CommonJS;
     }
-  });
-
-  // If an option isn't specified, use the default
-  wrapOptions = Object.assign({}, DEFAULT_WRAP_OPTIONS, wrapOptions);
-
-  if (shell.hasOwnProperty(name)) {
-    throw new Error('Command `' + name + '` already exists');
-  }
-
-  if (wrapOptions.pipeOnly) {
-    wrapOptions.canReceivePipe = true;
-    shellMethods[name] = wrap(name, implementation, wrapOptions);
-  } else {
-    shell[name] = wrap(name, implementation, wrapOptions);
-  }
-
-  if (wrapOptions.canReceivePipe) {
-    pipeMethods.push(name);
-  }
+    return config;
 }
-exports.register = _register;
-
-
-/***/ }),
-
-/***/ 6135:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
-
-var fs = __nccwpck_require__(57147);
-var path = __nccwpck_require__(71017);
-var common = __nccwpck_require__(17673);
-
-common.register('cp', _cp, {
-  cmdOptions: {
-    'f': '!no_force',
-    'n': 'no_force',
-    'u': 'update',
-    'R': 'recursive',
-    'r': 'recursive',
-    'L': 'followsymlink',
-    'P': 'noFollowsymlink',
-  },
-  wrapOutput: false,
-});
-
-// Buffered file copy, synchronous
-// (Using readFileSync() + writeFileSync() could easily cause a memory overflow
-//  with large files)
-function copyFileSync(srcFile, destFile, options) {
-  if (!fs.existsSync(srcFile)) {
-    common.error('copyFileSync: no such file or directory: ' + srcFile);
-  }
-
-  var isWindows = process.platform === 'win32';
-
-  // Check the mtimes of the files if the '-u' flag is provided
-  try {
-    if (options.update && common.statFollowLinks(srcFile).mtime < fs.statSync(destFile).mtime) {
-      return;
-    }
-  } catch (e) {
-    // If we're here, destFile probably doesn't exist, so just do a normal copy
-  }
-
-  if (common.statNoFollowLinks(srcFile).isSymbolicLink() && !options.followsymlink) {
-    try {
-      common.statNoFollowLinks(destFile);
-      common.unlinkSync(destFile); // re-link it
-    } catch (e) {
-      // it doesn't exist, so no work needs to be done
+/** @internal */
+function findAndReadConfig(rawOptions) {
+    var _a, _b, _c, _d, _e;
+    const cwd = (0, path_1.resolve)((_c = (_b = (_a = rawOptions.cwd) !== null && _a !== void 0 ? _a : rawOptions.dir) !== null && _b !== void 0 ? _b : index_1.DEFAULTS.cwd) !== null && _c !== void 0 ? _c : process.cwd());
+    const compilerName = (_d = rawOptions.compiler) !== null && _d !== void 0 ? _d : index_1.DEFAULTS.compiler;
+    // Compute minimum options to read the config file.
+    let projectLocalResolveDir = (0, util_1.getBasePathForProjectLocalDependencyResolution)(undefined, rawOptions.projectSearchDir, rawOptions.project, cwd);
+    let { compiler, ts } = resolveAndLoadCompiler(compilerName, projectLocalResolveDir);
+    // Read config file and merge new options between env and CLI options.
+    const { configFilePath, config, tsNodeOptionsFromTsconfig, optionBasePaths } = readConfig(cwd, ts, rawOptions);
+    const options = (0, util_1.assign)({}, index_1.DEFAULTS, tsNodeOptionsFromTsconfig || {}, { optionBasePaths }, rawOptions);
+    options.require = [
+        ...(tsNodeOptionsFromTsconfig.require || []),
+        ...(rawOptions.require || []),
+    ];
+    // Re-resolve the compiler in case it has changed.
+    // Compiler is loaded relative to tsconfig.json, so tsconfig discovery may cause us to load a
+    // different compiler than we did above, even if the name has not changed.
+    if (configFilePath) {
+        projectLocalResolveDir = (0, util_1.getBasePathForProjectLocalDependencyResolution)(configFilePath, rawOptions.projectSearchDir, rawOptions.project, cwd);
+        ({ compiler } = resolveCompiler(options.compiler, (_e = optionBasePaths.compiler) !== null && _e !== void 0 ? _e : projectLocalResolveDir));
     }
-
-    var symlinkFull = fs.readlinkSync(srcFile);
-    fs.symlinkSync(symlinkFull, destFile, isWindows ? 'junction' : null);
-  } else {
-    var buf = common.buffer();
-    var bufLength = buf.length;
-    var bytesRead = bufLength;
-    var pos = 0;
-    var fdr = null;
-    var fdw = null;
-
-    try {
-      fdr = fs.openSync(srcFile, 'r');
-    } catch (e) {
-      /* istanbul ignore next */
-      common.error('copyFileSync: could not read src file (' + srcFile + ')');
+    return {
+        options,
+        config,
+        projectLocalResolveDir,
+        optionBasePaths,
+        configFilePath,
+        cwd,
+        compiler,
+    };
+}
+exports.findAndReadConfig = findAndReadConfig;
+/**
+ * Load TypeScript configuration. Returns the parsed TypeScript config and
+ * any `ts-node` options specified in the config file.
+ *
+ * Even when a tsconfig.json is not loaded, this function still handles merging
+ * compilerOptions from various sources: API, environment variables, etc.
+ *
+ * @internal
+ */
+function readConfig(cwd, ts, rawApiOptions) {
+    var _a, _b, _c;
+    // Ordered [a, b, c] where config a extends b extends c
+    const configChain = [];
+    let config = { compilerOptions: {} };
+    let basePath = cwd;
+    let configFilePath = undefined;
+    const projectSearchDir = (0, path_1.resolve)(cwd, (_a = rawApiOptions.projectSearchDir) !== null && _a !== void 0 ? _a : cwd);
+    const { fileExists = ts.sys.fileExists, readFile = ts.sys.readFile, skipProject = index_1.DEFAULTS.skipProject, project = index_1.DEFAULTS.project, tsTrace = index_1.DEFAULTS.tsTrace, } = rawApiOptions;
+    // Read project configuration when available.
+    if (!skipProject) {
+        if (project) {
+            const resolved = (0, path_1.resolve)(cwd, project);
+            const nested = (0, path_1.join)(resolved, 'tsconfig.json');
+            configFilePath = fileExists(nested) ? nested : resolved;
+        }
+        else {
+            configFilePath = ts.findConfigFile(projectSearchDir, fileExists);
+        }
+        if (configFilePath) {
+            let pathToNextConfigInChain = configFilePath;
+            const tsInternals = (0, ts_internals_1.createTsInternals)(ts);
+            const errors = [];
+            // Follow chain of "extends"
+            while (true) {
+                const result = ts.readConfigFile(pathToNextConfigInChain, readFile);
+                // Return diagnostics.
+                if (result.error) {
+                    return {
+                        configFilePath,
+                        config: { errors: [result.error], fileNames: [], options: {} },
+                        tsNodeOptionsFromTsconfig: {},
+                        optionBasePaths: {},
+                    };
+                }
+                const c = result.config;
+                const bp = (0, path_1.dirname)(pathToNextConfigInChain);
+                configChain.push({
+                    config: c,
+                    basePath: bp,
+                    configPath: pathToNextConfigInChain,
+                });
+                if (c.extends == null)
+                    break;
+                const resolvedExtendedConfigPath = tsInternals.getExtendsConfigPath(c.extends, {
+                    fileExists,
+                    readDirectory: ts.sys.readDirectory,
+                    readFile,
+                    useCaseSensitiveFileNames: ts.sys.useCaseSensitiveFileNames,
+                    trace: tsTrace,
+                }, bp, errors, ts.createCompilerDiagnostic);
+                if (errors.length) {
+                    return {
+                        configFilePath,
+                        config: { errors, fileNames: [], options: {} },
+                        tsNodeOptionsFromTsconfig: {},
+                        optionBasePaths: {},
+                    };
+                }
+                if (resolvedExtendedConfigPath == null)
+                    break;
+                pathToNextConfigInChain = resolvedExtendedConfigPath;
+            }
+            ({ config, basePath } = configChain[0]);
+        }
     }
-
-    try {
-      fdw = fs.openSync(destFile, 'w');
-    } catch (e) {
-      /* istanbul ignore next */
-      common.error('copyFileSync: could not write to dest file (code=' + e.code + '):' + destFile);
+    // Merge and fix ts-node options that come from tsconfig.json(s)
+    const tsNodeOptionsFromTsconfig = {};
+    const optionBasePaths = {};
+    for (let i = configChain.length - 1; i >= 0; i--) {
+        const { config, basePath, configPath } = configChain[i];
+        const options = filterRecognizedTsConfigTsNodeOptions(config['ts-node']).recognized;
+        // Some options are relative to the config file, so must be converted to absolute paths here
+        if (options.require) {
+            // Modules are found relative to the tsconfig file, not the `dir` option
+            const tsconfigRelativeResolver = (0, util_1.createProjectLocalResolveHelper)((0, path_1.dirname)(configPath));
+            options.require = options.require.map((path) => tsconfigRelativeResolver(path, false));
+        }
+        if (options.scopeDir) {
+            options.scopeDir = (0, path_1.resolve)(basePath, options.scopeDir);
+        }
+        // Downstream code uses the basePath; we do not do that here.
+        if (options.moduleTypes) {
+            optionBasePaths.moduleTypes = basePath;
+        }
+        if (options.transpiler != null) {
+            optionBasePaths.transpiler = basePath;
+        }
+        if (options.compiler != null) {
+            optionBasePaths.compiler = basePath;
+        }
+        if (options.swc != null) {
+            optionBasePaths.swc = basePath;
+        }
+        (0, util_1.assign)(tsNodeOptionsFromTsconfig, options);
     }
-
-    while (bytesRead === bufLength) {
-      bytesRead = fs.readSync(fdr, buf, 0, bufLength, pos);
-      fs.writeSync(fdw, buf, 0, bytesRead);
-      pos += bytesRead;
+    // Remove resolution of "files".
+    const files = (_c = (_b = rawApiOptions.files) !== null && _b !== void 0 ? _b : tsNodeOptionsFromTsconfig.files) !== null && _c !== void 0 ? _c : index_1.DEFAULTS.files;
+    // Only if a config file is *not* loaded, load an implicit configuration from @tsconfig/bases
+    const skipDefaultCompilerOptions = configFilePath != null;
+    const defaultCompilerOptionsForNodeVersion = skipDefaultCompilerOptions
+        ? undefined
+        : {
+            ...(0, tsconfigs_1.getDefaultTsconfigJsonForNodeVersion)(ts).compilerOptions,
+            types: ['node'],
+        };
+    // Merge compilerOptions from all sources
+    config.compilerOptions = Object.assign({}, 
+    // automatically-applied options from @tsconfig/bases
+    defaultCompilerOptionsForNodeVersion, 
+    // tsconfig.json "compilerOptions"
+    config.compilerOptions, 
+    // from env var
+    index_1.DEFAULTS.compilerOptions, 
+    // tsconfig.json "ts-node": "compilerOptions"
+    tsNodeOptionsFromTsconfig.compilerOptions, 
+    // passed programmatically
+    rawApiOptions.compilerOptions, 
+    // overrides required by ts-node, cannot be changed
+    TS_NODE_COMPILER_OPTIONS);
+    const fixedConfig = fixConfig(ts, ts.parseJsonConfigFileContent(config, {
+        fileExists,
+        readFile,
+        // Only used for globbing "files", "include", "exclude"
+        // When `files` option disabled, we want to avoid the fs calls
+        readDirectory: files ? ts.sys.readDirectory : () => [],
+        useCaseSensitiveFileNames: ts.sys.useCaseSensitiveFileNames,
+    }, basePath, undefined, configFilePath));
+    return {
+        configFilePath,
+        config: fixedConfig,
+        tsNodeOptionsFromTsconfig,
+        optionBasePaths,
+    };
+}
+exports.readConfig = readConfig;
+/**
+ * Load the typescript compiler. It is required to load the tsconfig but might
+ * be changed by the tsconfig, so we have to do this twice.
+ * @internal
+ */
+function resolveAndLoadCompiler(name, relativeToPath) {
+    const { compiler } = resolveCompiler(name, relativeToPath);
+    const ts = loadCompiler(compiler);
+    return { compiler, ts };
+}
+exports.resolveAndLoadCompiler = resolveAndLoadCompiler;
+function resolveCompiler(name, relativeToPath) {
+    const projectLocalResolveHelper = (0, util_1.createProjectLocalResolveHelper)(relativeToPath);
+    const compiler = projectLocalResolveHelper(name || 'typescript', true);
+    return { compiler };
+}
+/** @internal */
+function loadCompiler(compiler) {
+    return (0, util_1.attemptRequireWithV8CompileCache)(require, compiler);
+}
+exports.loadCompiler = loadCompiler;
+/**
+ * Given the raw "ts-node" sub-object from a tsconfig, return an object with only the properties
+ * recognized by "ts-node"
+ */
+function filterRecognizedTsConfigTsNodeOptions(jsonObject) {
+    if (jsonObject == null)
+        return { recognized: {}, unrecognized: {} };
+    const { compiler, compilerHost, compilerOptions, emit, files, ignore, ignoreDiagnostics, logError, preferTsExts, pretty, require, skipIgnore, transpileOnly, typeCheck, transpiler, scope, scopeDir, moduleTypes, experimentalReplAwait, swc, experimentalResolver, esm, experimentalSpecifierResolution, experimentalTsImportSpecifiers, ...unrecognized } = jsonObject;
+    const filteredTsConfigOptions = {
+        compiler,
+        compilerHost,
+        compilerOptions,
+        emit,
+        experimentalReplAwait,
+        files,
+        ignore,
+        ignoreDiagnostics,
+        logError,
+        preferTsExts,
+        pretty,
+        require,
+        skipIgnore,
+        transpileOnly,
+        typeCheck,
+        transpiler,
+        scope,
+        scopeDir,
+        moduleTypes,
+        swc,
+        experimentalResolver,
+        esm,
+        experimentalSpecifierResolution,
+        experimentalTsImportSpecifiers,
+    };
+    // Use the typechecker to make sure this implementation has the correct set of properties
+    const catchExtraneousProps = null;
+    const catchMissingProps = null;
+    return { recognized: filteredTsConfigOptions, unrecognized };
+}
+/** @internal */
+exports.ComputeAsCommonRootOfFiles = Symbol();
+/**
+ * Some TS compiler options have defaults which are not provided by TS's config parsing functions.
+ * This function centralizes the logic for computing those defaults.
+ * @internal
+ */
+function getTsConfigDefaults(config, basePath, _files, _include, _exclude) {
+    const { composite = false } = config.options;
+    let rootDir = config.options.rootDir;
+    if (rootDir == null) {
+        if (composite)
+            rootDir = basePath;
+        // Return this symbol to avoid computing from `files`, which would require fs calls
+        else
+            rootDir = exports.ComputeAsCommonRootOfFiles;
     }
-
-    fs.closeSync(fdr);
-    fs.closeSync(fdw);
-
-    fs.chmodSync(destFile, common.statFollowLinks(srcFile).mode);
-  }
+    const { outDir = rootDir } = config.options;
+    // Docs are wrong: https://www.typescriptlang.org/tsconfig#include
+    // Docs say **, but it's actually **/*; compiler throws error for **
+    const include = _files ? [] : ['**/*'];
+    const files = _files !== null && _files !== void 0 ? _files : [];
+    // Docs are misleading: https://www.typescriptlang.org/tsconfig#exclude
+    // Docs say it excludes node_modules, bower_components, jspm_packages, but actually those are excluded via behavior of "include"
+    const exclude = _exclude !== null && _exclude !== void 0 ? _exclude : [outDir]; // TODO technically, outDir is absolute path, but exclude should be relative glob pattern?
+    // TODO compute baseUrl
+    return { rootDir, outDir, include, files, exclude, composite };
 }
+exports.getTsConfigDefaults = getTsConfigDefaults;
+//# sourceMappingURL=configuration.js.map
 
-// Recursively copies 'sourceDir' into 'destDir'
-// Adapted from https://github.com/ryanmcgrath/wrench-js
-//
-// Copyright (c) 2010 Ryan McGrath
-// Copyright (c) 2012 Artur Adib
-//
-// Licensed under the MIT License
-// http://www.opensource.org/licenses/mit-license.php
-function cpdirSyncRecursive(sourceDir, destDir, currentDepth, opts) {
-  if (!opts) opts = {};
-
-  // Ensure there is not a run away recursive copy
-  if (currentDepth >= common.config.maxdepth) return;
-  currentDepth++;
-
-  var isWindows = process.platform === 'win32';
-
-  // Create the directory where all our junk is moving to; read the mode of the
-  // source directory and mirror it
-  try {
-    fs.mkdirSync(destDir);
-  } catch (e) {
-    // if the directory already exists, that's okay
-    if (e.code !== 'EEXIST') throw e;
-  }
-
-  var files = fs.readdirSync(sourceDir);
-
-  for (var i = 0; i < files.length; i++) {
-    var srcFile = sourceDir + '/' + files[i];
-    var destFile = destDir + '/' + files[i];
-    var srcFileStat = common.statNoFollowLinks(srcFile);
+/***/ }),
 
-    var symlinkFull;
-    if (opts.followsymlink) {
-      if (cpcheckcycle(sourceDir, srcFile)) {
-        // Cycle link found.
-        console.error('Cycle link found.');
-        symlinkFull = fs.readlinkSync(srcFile);
-        fs.symlinkSync(symlinkFull, destFile, isWindows ? 'junction' : null);
-        continue;
-      }
-    }
-    if (srcFileStat.isDirectory()) {
-      /* recursion this thing right on back. */
-      cpdirSyncRecursive(srcFile, destFile, currentDepth, opts);
-    } else if (srcFileStat.isSymbolicLink() && !opts.followsymlink) {
-      symlinkFull = fs.readlinkSync(srcFile);
-      try {
-        common.statNoFollowLinks(destFile);
-        common.unlinkSync(destFile); // re-link it
-      } catch (e) {
-        // it doesn't exist, so no work needs to be done
-      }
-      fs.symlinkSync(symlinkFull, destFile, isWindows ? 'junction' : null);
-    } else if (srcFileStat.isSymbolicLink() && opts.followsymlink) {
-      srcFileStat = common.statFollowLinks(srcFile);
-      if (srcFileStat.isDirectory()) {
-        cpdirSyncRecursive(srcFile, destFile, currentDepth, opts);
-      } else {
-        copyFileSync(srcFile, destFile, opts);
-      }
-    } else {
-      /* At this point, we've hit a file actually worth copying... so copy it on over. */
-      if (fs.existsSync(destFile) && opts.no_force) {
-        common.log('skipping existing file: ' + files[i]);
-      } else {
-        copyFileSync(srcFile, destFile, opts);
-      }
-    }
-  } // for files
+/***/ 36057:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
-  // finally change the mode for the newly created directory (otherwise, we
-  // couldn't add files to a read-only directory).
-  var checkDir = common.statFollowLinks(sourceDir);
-  fs.chmodSync(destDir, checkDir.mode);
-} // cpdirSyncRecursive
+"use strict";
+var __webpack_unused_export__;
 
-// Checks if cureent file was created recently
-function checkRecentCreated(sources, index) {
-  var lookedSource = sources[index];
-  return sources.slice(0, index).some(function (src) {
-    return path.basename(src) === path.basename(lookedSource);
-  });
+__webpack_unused_export__ = ({ value: true });
+exports.lT = __webpack_unused_export__ = __webpack_unused_export__ = void 0;
+const index_1 = __nccwpck_require__(94828);
+const url_1 = __nccwpck_require__(57310);
+const path_1 = __nccwpck_require__(71017);
+const assert = __nccwpck_require__(39491);
+const util_1 = __nccwpck_require__(26239);
+const module_1 = __nccwpck_require__(98188);
+// The hooks API changed in node version X so we need to check for backwards compatibility.
+const newHooksAPI = (0, util_1.versionGteLt)(process.versions.node, '16.12.0');
+/** @internal */
+function filterHooksByAPIVersion(hooks) {
+    const { getFormat, load, resolve, transformSource } = hooks;
+    // Explicit return type to avoid TS's non-ideal inferred type
+    const hooksAPI = newHooksAPI
+        ? { resolve, load, getFormat: undefined, transformSource: undefined }
+        : { resolve, getFormat, transformSource, load: undefined };
+    return hooksAPI;
 }
-
-function cpcheckcycle(sourceDir, srcFile) {
-  var srcFileStat = common.statNoFollowLinks(srcFile);
-  if (srcFileStat.isSymbolicLink()) {
-    // Do cycle check. For example:
-    //   $ mkdir -p 1/2/3/4
-    //   $ cd  1/2/3/4
-    //   $ ln -s ../../3 link
-    //   $ cd ../../../..
-    //   $ cp -RL 1 copy
-    var cyclecheck = common.statFollowLinks(srcFile);
-    if (cyclecheck.isDirectory()) {
-      var sourcerealpath = fs.realpathSync(sourceDir);
-      var symlinkrealpath = fs.realpathSync(srcFile);
-      var re = new RegExp(symlinkrealpath);
-      if (re.test(sourcerealpath)) {
-        return true;
-      }
-    }
-  }
-  return false;
+__webpack_unused_export__ = filterHooksByAPIVersion;
+/** @internal */
+function registerAndCreateEsmHooks(opts) {
+    // Automatically performs registration just like `-r ts-node/register`
+    const tsNodeInstance = (0, index_1.register)(opts);
+    return createEsmHooks(tsNodeInstance);
 }
-
-//@
-//@ ### cp([options,] source [, source ...], dest)
-//@ ### cp([options,] source_array, dest)
-//@
-//@ Available options:
-//@
-//@ + `-f`: force (default behavior)
-//@ + `-n`: no-clobber
-//@ + `-u`: only copy if `source` is newer than `dest`
-//@ + `-r`, `-R`: recursive
-//@ + `-L`: follow symlinks
-//@ + `-P`: don't follow symlinks
-//@
-//@ Examples:
-//@
-//@ ```javascript
-//@ cp('file1', 'dir1');
-//@ cp('-R', 'path/to/dir/', '~/newCopy/');
-//@ cp('-Rf', '/tmp/*', '/usr/local/*', '/home/tmp');
-//@ cp('-Rf', ['/tmp/*', '/usr/local/*'], '/home/tmp'); // same as above
-//@ ```
-//@
-//@ Copies files.
-function _cp(options, sources, dest) {
-  // If we're missing -R, it actually implies -L (unless -P is explicit)
-  if (options.followsymlink) {
-    options.noFollowsymlink = false;
-  }
-  if (!options.recursive && !options.noFollowsymlink) {
-    options.followsymlink = true;
-  }
-
-  // Get sources, dest
-  if (arguments.length < 3) {
-    common.error('missing  and/or ');
-  } else {
-    sources = [].slice.call(arguments, 1, arguments.length - 1);
-    dest = arguments[arguments.length - 1];
-  }
-
-  var destExists = fs.existsSync(dest);
-  var destStat = destExists && common.statFollowLinks(dest);
-
-  // Dest is not existing dir, but multiple sources given
-  if ((!destExists || !destStat.isDirectory()) && sources.length > 1) {
-    common.error('dest is not a directory (too many sources)');
-  }
-
-  // Dest is an existing file, but -n is given
-  if (destExists && destStat.isFile() && options.no_force) {
-    return new common.ShellString('', '', 0);
-  }
-
-  sources.forEach(function (src, srcIndex) {
-    if (!fs.existsSync(src)) {
-      if (src === '') src = "''"; // if src was empty string, display empty string
-      common.error('no such file or directory: ' + src, { continue: true });
-      return; // skip file
+__webpack_unused_export__ = registerAndCreateEsmHooks;
+function createEsmHooks(tsNodeService) {
+    tsNodeService.enableExperimentalEsmLoaderInterop();
+    // Custom implementation that considers additional file extensions and automatically adds file extensions
+    const nodeResolveImplementation = tsNodeService.getNodeEsmResolver();
+    const nodeGetFormatImplementation = tsNodeService.getNodeEsmGetFormat();
+    const extensions = tsNodeService.extensions;
+    const hooksAPI = filterHooksByAPIVersion({
+        resolve,
+        load,
+        getFormat,
+        transformSource,
+    });
+    function isFileUrlOrNodeStyleSpecifier(parsed) {
+        // We only understand file:// URLs, but in node, the specifier can be a node-style `./foo` or `foo`
+        const { protocol } = parsed;
+        return protocol === null || protocol === 'file:';
     }
-    var srcStat = common.statFollowLinks(src);
-    if (!options.noFollowsymlink && srcStat.isDirectory()) {
-      if (!options.recursive) {
-        // Non-Recursive
-        common.error("omitting directory '" + src + "'", { continue: true });
-      } else {
-        // Recursive
-        // 'cp /a/source dest' should create 'source' in 'dest'
-        var newDest = (destStat && destStat.isDirectory()) ?
-            path.join(dest, path.basename(src)) :
-            dest;
-
-        try {
-          common.statFollowLinks(path.dirname(dest));
-          cpdirSyncRecursive(src, newDest, 0, { no_force: options.no_force, followsymlink: options.followsymlink });
-        } catch (e) {
-          /* istanbul ignore next */
-          common.error("cannot create directory '" + dest + "': No such file or directory");
+    /**
+     * Named "probably" as a reminder that this is a guess.
+     * node does not explicitly tell us if we're resolving the entrypoint or not.
+     */
+    function isProbablyEntrypoint(specifier, parentURL) {
+        return parentURL === undefined && specifier.startsWith('file://');
+    }
+    // Side-channel between `resolve()` and `load()` hooks
+    const rememberIsProbablyEntrypoint = new Set();
+    const rememberResolvedViaCommonjsFallback = new Set();
+    async function resolve(specifier, context, defaultResolve) {
+        const defer = async () => {
+            const r = await defaultResolve(specifier, context, defaultResolve);
+            return r;
+        };
+        // See: https://github.com/nodejs/node/discussions/41711
+        // nodejs will likely implement a similar fallback.  Till then, we can do our users a favor and fallback today.
+        async function entrypointFallback(cb) {
+            try {
+                const resolution = await cb();
+                if ((resolution === null || resolution === void 0 ? void 0 : resolution.url) &&
+                    isProbablyEntrypoint(specifier, context.parentURL))
+                    rememberIsProbablyEntrypoint.add(resolution.url);
+                return resolution;
+            }
+            catch (esmResolverError) {
+                if (!isProbablyEntrypoint(specifier, context.parentURL))
+                    throw esmResolverError;
+                try {
+                    let cjsSpecifier = specifier;
+                    // Attempt to convert from ESM file:// to CommonJS path
+                    try {
+                        if (specifier.startsWith('file://'))
+                            cjsSpecifier = (0, url_1.fileURLToPath)(specifier);
+                    }
+                    catch { }
+                    const resolution = (0, url_1.pathToFileURL)((0, module_1.createRequire)(process.cwd()).resolve(cjsSpecifier)).toString();
+                    rememberIsProbablyEntrypoint.add(resolution);
+                    rememberResolvedViaCommonjsFallback.add(resolution);
+                    return { url: resolution, format: 'commonjs' };
+                }
+                catch (commonjsResolverError) {
+                    throw esmResolverError;
+                }
+            }
         }
-      }
-    } else {
-      // If here, src is a file
-
-      // When copying to '/path/dir':
-      //    thisDest = '/path/dir/file1'
-      var thisDest = dest;
-      if (destStat && destStat.isDirectory()) {
-        thisDest = path.normalize(dest + '/' + path.basename(src));
-      }
-
-      var thisDestExists = fs.existsSync(thisDest);
-      if (thisDestExists && checkRecentCreated(sources, srcIndex)) {
-        // cannot overwrite file created recently in current execution, but we want to continue copying other files
-        if (!options.no_force) {
-          common.error("will not overwrite just-created '" + thisDest + "' with '" + src + "'", { continue: true });
+        return addShortCircuitFlag(async () => {
+            const parsed = (0, url_1.parse)(specifier);
+            const { pathname, protocol, hostname } = parsed;
+            if (!isFileUrlOrNodeStyleSpecifier(parsed)) {
+                return entrypointFallback(defer);
+            }
+            if (protocol !== null && protocol !== 'file:') {
+                return entrypointFallback(defer);
+            }
+            // Malformed file:// URL?  We should always see `null` or `''`
+            if (hostname) {
+                // TODO file://./foo sets `hostname` to `'.'`.  Perhaps we should special-case this.
+                return entrypointFallback(defer);
+            }
+            // pathname is the path to be resolved
+            return entrypointFallback(() => nodeResolveImplementation.defaultResolve(specifier, context, defaultResolve));
+        });
+    }
+    // `load` from new loader hook API (See description at the top of this file)
+    async function load(url, context, defaultLoad) {
+        return addShortCircuitFlag(async () => {
+            var _a;
+            // If we get a format hint from resolve() on the context then use it
+            // otherwise call the old getFormat() hook using node's old built-in defaultGetFormat() that ships with ts-node
+            const format = (_a = context.format) !== null && _a !== void 0 ? _a : (await getFormat(url, context, nodeGetFormatImplementation.defaultGetFormat)).format;
+            let source = undefined;
+            if (format !== 'builtin' && format !== 'commonjs') {
+                // Call the new defaultLoad() to get the source
+                const { source: rawSource } = await defaultLoad(url, {
+                    ...context,
+                    format,
+                }, defaultLoad);
+                if (rawSource === undefined || rawSource === null) {
+                    throw new Error(`Failed to load raw source: Format was '${format}' and url was '${url}''.`);
+                }
+                // Emulate node's built-in old defaultTransformSource() so we can re-use the old transformSource() hook
+                const defaultTransformSource = async (source, _context, _defaultTransformSource) => ({ source });
+                // Call the old hook
+                const { source: transformedSource } = await transformSource(rawSource, { url, format }, defaultTransformSource);
+                source = transformedSource;
+            }
+            return { format, source };
+        });
+    }
+    async function getFormat(url, context, defaultGetFormat) {
+        const defer = (overrideUrl = url) => defaultGetFormat(overrideUrl, context, defaultGetFormat);
+        // See: https://github.com/nodejs/node/discussions/41711
+        // nodejs will likely implement a similar fallback.  Till then, we can do our users a favor and fallback today.
+        async function entrypointFallback(cb) {
+            try {
+                return await cb();
+            }
+            catch (getFormatError) {
+                if (!rememberIsProbablyEntrypoint.has(url))
+                    throw getFormatError;
+                return { format: 'commonjs' };
+            }
         }
-        return;
-      }
-
-      if (thisDestExists && options.no_force) {
-        return; // skip file
-      }
-
-      if (path.relative(src, thisDest) === '') {
-        // a file cannot be copied to itself, but we want to continue copying other files
-        common.error("'" + thisDest + "' and '" + src + "' are the same file", { continue: true });
-        return;
-      }
-
-      copyFileSync(src, thisDest, options);
+        const parsed = (0, url_1.parse)(url);
+        if (!isFileUrlOrNodeStyleSpecifier(parsed)) {
+            return entrypointFallback(defer);
+        }
+        const { pathname } = parsed;
+        assert(pathname !== null, 'ESM getFormat() hook: URL should never have null pathname');
+        const nativePath = (0, url_1.fileURLToPath)(url);
+        let nodeSays;
+        // If file has extension not understood by node, then ask node how it would treat the emitted extension.
+        // E.g. .mts compiles to .mjs, so ask node how to classify an .mjs file.
+        const ext = (0, path_1.extname)(nativePath);
+        const tsNodeIgnored = tsNodeService.ignored(nativePath);
+        const nodeEquivalentExt = extensions.nodeEquivalents.get(ext);
+        if (nodeEquivalentExt && !tsNodeIgnored) {
+            nodeSays = await entrypointFallback(() => defer((0, url_1.format)((0, url_1.pathToFileURL)(nativePath + nodeEquivalentExt))));
+        }
+        else {
+            try {
+                nodeSays = await entrypointFallback(defer);
+            }
+            catch (e) {
+                if (e instanceof Error &&
+                    tsNodeIgnored &&
+                    extensions.nodeDoesNotUnderstand.includes(ext)) {
+                    e.message +=
+                        `\n\n` +
+                            `Hint:\n` +
+                            `ts-node is configured to ignore this file.\n` +
+                            `If you want ts-node to handle this file, consider enabling the "skipIgnore" option or adjusting your "ignore" patterns.\n` +
+                            `https://typestrong.org/ts-node/docs/scope\n`;
+                }
+                throw e;
+            }
+        }
+        // For files compiled by ts-node that node believes are either CJS or ESM, check if we should override that classification
+        if (!tsNodeService.ignored(nativePath) &&
+            (nodeSays.format === 'commonjs' || nodeSays.format === 'module')) {
+            const { moduleType } = tsNodeService.moduleTypeClassifier.classifyModuleByModuleTypeOverrides((0, util_1.normalizeSlashes)(nativePath));
+            if (moduleType === 'cjs') {
+                return { format: 'commonjs' };
+            }
+            else if (moduleType === 'esm') {
+                return { format: 'module' };
+            }
+        }
+        return nodeSays;
     }
-  }); // forEach(src)
-
-  return new common.ShellString('', common.state.error, common.state.errorCode);
+    async function transformSource(source, context, defaultTransformSource) {
+        if (source === null || source === undefined) {
+            throw new Error('No source');
+        }
+        const defer = () => defaultTransformSource(source, context, defaultTransformSource);
+        const sourceAsString = typeof source === 'string' ? source : source.toString('utf8');
+        const { url } = context;
+        const parsed = (0, url_1.parse)(url);
+        if (!isFileUrlOrNodeStyleSpecifier(parsed)) {
+            return defer();
+        }
+        const nativePath = (0, url_1.fileURLToPath)(url);
+        if (tsNodeService.ignored(nativePath)) {
+            return defer();
+        }
+        const emittedJs = tsNodeService.compile(sourceAsString, nativePath);
+        return { source: emittedJs };
+    }
+    return hooksAPI;
 }
-module.exports = _cp;
-
+exports.lT = createEsmHooks;
+async function addShortCircuitFlag(fn) {
+    const ret = await fn();
+    // Not sure if this is necessary; being lazy.  Can revisit in the future.
+    if (ret == null)
+        return ret;
+    return {
+        ...ret,
+        shortCircuit: true,
+    };
+}
+//# sourceMappingURL=esm.js.map
 
 /***/ }),
 
-/***/ 80220:
+/***/ 9156:
 /***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
-var common = __nccwpck_require__(17673);
-var _cd = __nccwpck_require__(51829);
-var path = __nccwpck_require__(71017);
-
-common.register('dirs', _dirs, {
-  wrapOutput: false,
-});
-common.register('pushd', _pushd, {
-  wrapOutput: false,
-});
-common.register('popd', _popd, {
-  wrapOutput: false,
-});
-
-// Pushd/popd/dirs internals
-var _dirStack = [];
-
-function _isStackIndex(index) {
-  return (/^[\-+]\d+$/).test(index);
-}
+"use strict";
 
-function _parseStackIndex(index) {
-  if (_isStackIndex(index)) {
-    if (Math.abs(index) < _dirStack.length + 1) { // +1 for pwd
-      return (/^-/).test(index) ? Number(index) - 1 : Number(index);
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.getExtensions = void 0;
+const util_1 = __nccwpck_require__(26239);
+const nodeEquivalents = new Map([
+    ['.ts', '.js'],
+    ['.tsx', '.js'],
+    ['.jsx', '.js'],
+    ['.mts', '.mjs'],
+    ['.cts', '.cjs'],
+]);
+const tsResolverEquivalents = new Map([
+    ['.ts', ['.js']],
+    ['.tsx', ['.js', '.jsx']],
+    ['.mts', ['.mjs']],
+    ['.cts', ['.cjs']],
+]);
+// All extensions understood by vanilla node
+const vanillaNodeExtensions = [
+    '.js',
+    '.json',
+    '.node',
+    '.mjs',
+    '.cjs',
+];
+// Extensions added by vanilla node's require() if you omit them:
+// js, json, node
+// Extensions added by vanilla node if you omit them with --experimental-specifier-resolution=node
+// js, json, node, mjs
+// Extensions added by ESM codepath's legacy package.json "main" resolver
+// js, json, node (not mjs!)
+const nodeDoesNotUnderstand = [
+    '.ts',
+    '.tsx',
+    '.jsx',
+    '.cts',
+    '.mts',
+];
+/**
+ * [MUST_UPDATE_FOR_NEW_FILE_EXTENSIONS]
+ * @internal
+ */
+function getExtensions(config, options, tsVersion) {
+    // TS 4.5 is first version to understand .cts, .mts, .cjs, and .mjs extensions
+    const tsSupportsMtsCtsExts = (0, util_1.versionGteLt)(tsVersion, '4.5.0');
+    const requiresHigherTypescriptVersion = [];
+    if (!tsSupportsMtsCtsExts)
+        requiresHigherTypescriptVersion.push('.cts', '.cjs', '.mts', '.mjs');
+    const allPossibleExtensionsSortedByPreference = Array.from(new Set([
+        ...(options.preferTsExts ? nodeDoesNotUnderstand : []),
+        ...vanillaNodeExtensions,
+        ...nodeDoesNotUnderstand,
+    ]));
+    const compiledJsUnsorted = ['.ts'];
+    const compiledJsxUnsorted = [];
+    if (config.options.jsx)
+        compiledJsxUnsorted.push('.tsx');
+    if (tsSupportsMtsCtsExts)
+        compiledJsUnsorted.push('.mts', '.cts');
+    if (config.options.allowJs) {
+        compiledJsUnsorted.push('.js');
+        if (config.options.jsx)
+            compiledJsxUnsorted.push('.jsx');
+        if (tsSupportsMtsCtsExts)
+            compiledJsUnsorted.push('.mjs', '.cjs');
     }
-    common.error(index + ': directory stack index out of range');
-  } else {
-    common.error(index + ': invalid number');
-  }
-}
-
-function _actualDirStack() {
-  return [process.cwd()].concat(_dirStack);
+    const compiledUnsorted = [...compiledJsUnsorted, ...compiledJsxUnsorted];
+    const compiled = allPossibleExtensionsSortedByPreference.filter((ext) => compiledUnsorted.includes(ext));
+    const compiledNodeDoesNotUnderstand = nodeDoesNotUnderstand.filter((ext) => compiled.includes(ext));
+    /**
+     * TS's resolver can resolve foo.js to foo.ts, by replacing .js extension with several source extensions.
+     * IMPORTANT: Must preserve ordering according to preferTsExts!
+     *            Must include the .js/.mjs/.cjs extension in the array!
+     *            This affects resolution behavior!
+     * [MUST_UPDATE_FOR_NEW_FILE_EXTENSIONS]
+     */
+    const r = allPossibleExtensionsSortedByPreference.filter((ext) => [...compiledUnsorted, '.js', '.mjs', '.cjs', '.mts', '.cts'].includes(ext));
+    const replacementsForJs = r.filter((ext) => ['.js', '.jsx', '.ts', '.tsx'].includes(ext));
+    const replacementsForJsx = r.filter((ext) => ['.jsx', '.tsx'].includes(ext));
+    const replacementsForMjs = r.filter((ext) => ['.mjs', '.mts'].includes(ext));
+    const replacementsForCjs = r.filter((ext) => ['.cjs', '.cts'].includes(ext));
+    const replacementsForJsOrMjs = r.filter((ext) => ['.js', '.jsx', '.ts', '.tsx', '.mjs', '.mts'].includes(ext));
+    // Node allows omitting .js or .mjs extension in certain situations (CJS, ESM w/experimental flag)
+    // So anything that compiles to .js or .mjs can also be omitted.
+    const experimentalSpecifierResolutionAddsIfOmitted = Array.from(new Set([...replacementsForJsOrMjs, '.json', '.node']));
+    // Same as above, except node curiuosly doesn't do .mjs here
+    const legacyMainResolveAddsIfOmitted = Array.from(new Set([...replacementsForJs, '.json', '.node']));
+    return {
+        /** All file extensions we transform, ordered by resolution preference according to preferTsExts */
+        compiled,
+        /** Resolved extensions that vanilla node will not understand; we should handle them */
+        nodeDoesNotUnderstand,
+        /** Like the above, but only the ones we're compiling */
+        compiledNodeDoesNotUnderstand,
+        /**
+         * Mapping from extensions understood by tsc to the equivalent for node,
+         * as far as getFormat is concerned.
+         */
+        nodeEquivalents,
+        /**
+         * Mapping from extensions rejected by TSC in import specifiers, to the
+         * possible alternatives that TS's resolver will accept.
+         *
+         * When we allow users to opt-in to .ts extensions in import specifiers, TS's
+         * resolver requires us to replace the .ts extensions with .js alternatives.
+         * Otherwise, resolution fails.
+         *
+         * Note TS's resolver is only used by, and only required for, typechecking.
+         * This is separate from node's resolver, which we hook separately and which
+         * does not require this mapping.
+         */
+        tsResolverEquivalents,
+        /**
+         * Extensions that we can support if the user upgrades their typescript version.
+         * Used when raising hints.
+         */
+        requiresHigherTypescriptVersion,
+        /**
+         * --experimental-specifier-resolution=node will add these extensions.
+         */
+        experimentalSpecifierResolutionAddsIfOmitted,
+        /**
+         * ESM loader will add these extensions to package.json "main" field
+         */
+        legacyMainResolveAddsIfOmitted,
+        replacementsForMjs,
+        replacementsForCjs,
+        replacementsForJsx,
+        replacementsForJs,
+    };
 }
+exports.getExtensions = getExtensions;
+//# sourceMappingURL=file-extensions.js.map
 
-//@
-//@ ### pushd([options,] [dir | '-N' | '+N'])
-//@
-//@ Available options:
-//@
-//@ + `-n`: Suppresses the normal change of directory when adding directories to the stack, so that only the stack is manipulated.
-//@ + `-q`: Supresses output to the console.
-//@
-//@ Arguments:
-//@
-//@ + `dir`: Sets the current working directory to the top of the stack, then executes the equivalent of `cd dir`.
-//@ + `+N`: Brings the Nth directory (counting from the left of the list printed by dirs, starting with zero) to the top of the list by rotating the stack.
-//@ + `-N`: Brings the Nth directory (counting from the right of the list printed by dirs, starting with zero) to the top of the list by rotating the stack.
-//@
-//@ Examples:
-//@
-//@ ```javascript
-//@ // process.cwd() === '/usr'
-//@ pushd('/etc'); // Returns /etc /usr
-//@ pushd('+1');   // Returns /usr /etc
-//@ ```
-//@
-//@ Save the current directory on the top of the directory stack and then `cd` to `dir`. With no arguments, `pushd` exchanges the top two directories. Returns an array of paths in the stack.
-function _pushd(options, dir) {
-  if (_isStackIndex(options)) {
-    dir = options;
-    options = '';
-  }
+/***/ }),
 
-  options = common.parseOptions(options, {
-    'n': 'no-cd',
-    'q': 'quiet',
-  });
+/***/ 94828:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
-  var dirs = _actualDirStack();
+"use strict";
 
-  if (dir === '+0') {
-    return dirs; // +0 is a noop
-  } else if (!dir) {
-    if (dirs.length > 1) {
-      dirs = dirs.splice(1, 1).concat(dirs);
-    } else {
-      return common.error('no other directory');
-    }
-  } else if (_isStackIndex(dir)) {
-    var n = _parseStackIndex(dir);
-    dirs = dirs.slice(n).concat(dirs.slice(0, n));
-  } else {
-    if (options['no-cd']) {
-      dirs.splice(1, 0, dir);
-    } else {
-      dirs.unshift(dir);
+var _a, _b;
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.createEsmHooks = exports.createFromPreloadedConfig = exports.create = exports.register = exports.TSError = exports.DEFAULTS = exports.VERSION = exports.debug = exports.INSPECT_CUSTOM = exports.env = exports.REGISTER_INSTANCE = exports.createRepl = void 0;
+const path_1 = __nccwpck_require__(71017);
+const module_1 = __nccwpck_require__(98188);
+const util = __nccwpck_require__(73837);
+const url_1 = __nccwpck_require__(57310);
+const make_error_1 = __nccwpck_require__(46419);
+const util_1 = __nccwpck_require__(26239);
+const configuration_1 = __nccwpck_require__(45981);
+const module_type_classifier_1 = __nccwpck_require__(74025);
+const resolver_functions_1 = __nccwpck_require__(83638);
+const cjs_resolve_hooks_1 = __nccwpck_require__(72501);
+const node_module_type_classifier_1 = __nccwpck_require__(76652);
+const file_extensions_1 = __nccwpck_require__(9156);
+const ts_transpile_module_1 = __nccwpck_require__(87857);
+var repl_1 = __nccwpck_require__(8371);
+Object.defineProperty(exports, "createRepl", ({ enumerable: true, get: function () { return repl_1.createRepl; } }));
+/**
+ * Does this version of node obey the package.json "type" field
+ * and throw ERR_REQUIRE_ESM when attempting to require() an ESM modules.
+ */
+const engineSupportsPackageTypeField = parseInt(process.versions.node.split('.')[0], 10) >= 12;
+/**
+ * Assert that script can be loaded as CommonJS when we attempt to require it.
+ * If it should be loaded as ESM, throw ERR_REQUIRE_ESM like node does.
+ *
+ * Loaded conditionally so we don't need to support older node versions
+ */
+let assertScriptCanLoadAsCJS = engineSupportsPackageTypeField
+    ? (__nccwpck_require__(88232).assertScriptCanLoadAsCJSImpl)
+    : () => {
+        /* noop */
+    };
+/**
+ * Registered `ts-node` instance information.
+ */
+exports.REGISTER_INSTANCE = Symbol.for('ts-node.register.instance');
+/** @internal */
+exports.env = process.env;
+/**
+ * @internal
+ */
+exports.INSPECT_CUSTOM = util.inspect.custom || 'inspect';
+/**
+ * Debugging `ts-node`.
+ */
+const shouldDebug = (0, util_1.yn)(exports.env.TS_NODE_DEBUG);
+/** @internal */
+exports.debug = shouldDebug
+    ? (...args) => console.log(`[ts-node ${new Date().toISOString()}]`, ...args)
+    : () => undefined;
+const debugFn = shouldDebug
+    ? (key, fn) => {
+        let i = 0;
+        return (x) => {
+            (0, exports.debug)(key, x, ++i);
+            return fn(x);
+        };
     }
-  }
-
-  if (options['no-cd']) {
-    dirs = dirs.slice(1);
-  } else {
-    dir = path.resolve(dirs.shift());
-    _cd('', dir);
-  }
-
-  _dirStack = dirs;
-  return _dirs(options.quiet ? '-q' : '');
-}
-exports.pushd = _pushd;
-
-//@
-//@
-//@ ### popd([options,] ['-N' | '+N'])
-//@
-//@ Available options:
-//@
-//@ + `-n`: Suppress the normal directory change when removing directories from the stack, so that only the stack is manipulated.
-//@ + `-q`: Supresses output to the console.
-//@
-//@ Arguments:
-//@
-//@ + `+N`: Removes the Nth directory (counting from the left of the list printed by dirs), starting with zero.
-//@ + `-N`: Removes the Nth directory (counting from the right of the list printed by dirs), starting with zero.
-//@
-//@ Examples:
-//@
-//@ ```javascript
-//@ echo(process.cwd()); // '/usr'
-//@ pushd('/etc');       // '/etc /usr'
-//@ echo(process.cwd()); // '/etc'
-//@ popd();              // '/usr'
-//@ echo(process.cwd()); // '/usr'
-//@ ```
-//@
-//@ When no arguments are given, `popd` removes the top directory from the stack and performs a `cd` to the new top directory. The elements are numbered from 0, starting at the first directory listed with dirs (i.e., `popd` is equivalent to `popd +0`). Returns an array of paths in the stack.
-function _popd(options, index) {
-  if (_isStackIndex(options)) {
-    index = options;
-    options = '';
-  }
-
-  options = common.parseOptions(options, {
-    'n': 'no-cd',
-    'q': 'quiet',
-  });
-
-  if (!_dirStack.length) {
-    return common.error('directory stack empty');
-  }
-
-  index = _parseStackIndex(index || '+0');
-
-  if (options['no-cd'] || index > 0 || _dirStack.length + index === 0) {
-    index = index > 0 ? index - 1 : index;
-    _dirStack.splice(index, 1);
-  } else {
-    var dir = path.resolve(_dirStack.shift());
-    _cd('', dir);
-  }
-
-  return _dirs(options.quiet ? '-q' : '');
-}
-exports.popd = _popd;
-
-//@
-//@
-//@ ### dirs([options | '+N' | '-N'])
-//@
-//@ Available options:
-//@
-//@ + `-c`: Clears the directory stack by deleting all of the elements.
-//@ + `-q`: Supresses output to the console.
-//@
-//@ Arguments:
-//@
-//@ + `+N`: Displays the Nth directory (counting from the left of the list printed by dirs when invoked without options), starting with zero.
-//@ + `-N`: Displays the Nth directory (counting from the right of the list printed by dirs when invoked without options), starting with zero.
-//@
-//@ Display the list of currently remembered directories. Returns an array of paths in the stack, or a single path if `+N` or `-N` was specified.
-//@
-//@ See also: `pushd`, `popd`
-function _dirs(options, index) {
-  if (_isStackIndex(options)) {
-    index = options;
-    options = '';
-  }
-
-  options = common.parseOptions(options, {
-    'c': 'clear',
-    'q': 'quiet',
-  });
-
-  if (options.clear) {
-    _dirStack = [];
-    return _dirStack;
-  }
-
-  var stack = _actualDirStack();
-
-  if (index) {
-    index = _parseStackIndex(index);
-
-    if (index < 0) {
-      index = stack.length + index;
+    : (_, fn) => fn;
+/**
+ * Export the current version.
+ */
+exports.VERSION = __nccwpck_require__(46686).version;
+/**
+ * Default register options, including values specified via environment
+ * variables.
+ * @internal
+ */
+exports.DEFAULTS = {
+    cwd: (_a = exports.env.TS_NODE_CWD) !== null && _a !== void 0 ? _a : exports.env.TS_NODE_DIR,
+    emit: (0, util_1.yn)(exports.env.TS_NODE_EMIT),
+    scope: (0, util_1.yn)(exports.env.TS_NODE_SCOPE),
+    scopeDir: exports.env.TS_NODE_SCOPE_DIR,
+    files: (0, util_1.yn)(exports.env.TS_NODE_FILES),
+    pretty: (0, util_1.yn)(exports.env.TS_NODE_PRETTY),
+    compiler: exports.env.TS_NODE_COMPILER,
+    compilerOptions: (0, util_1.parse)(exports.env.TS_NODE_COMPILER_OPTIONS),
+    ignore: (0, util_1.split)(exports.env.TS_NODE_IGNORE),
+    project: exports.env.TS_NODE_PROJECT,
+    skipProject: (0, util_1.yn)(exports.env.TS_NODE_SKIP_PROJECT),
+    skipIgnore: (0, util_1.yn)(exports.env.TS_NODE_SKIP_IGNORE),
+    preferTsExts: (0, util_1.yn)(exports.env.TS_NODE_PREFER_TS_EXTS),
+    ignoreDiagnostics: (0, util_1.split)(exports.env.TS_NODE_IGNORE_DIAGNOSTICS),
+    transpileOnly: (0, util_1.yn)(exports.env.TS_NODE_TRANSPILE_ONLY),
+    typeCheck: (0, util_1.yn)(exports.env.TS_NODE_TYPE_CHECK),
+    compilerHost: (0, util_1.yn)(exports.env.TS_NODE_COMPILER_HOST),
+    logError: (0, util_1.yn)(exports.env.TS_NODE_LOG_ERROR),
+    experimentalReplAwait: (_b = (0, util_1.yn)(exports.env.TS_NODE_EXPERIMENTAL_REPL_AWAIT)) !== null && _b !== void 0 ? _b : undefined,
+    tsTrace: console.log.bind(console),
+};
+/**
+ * TypeScript diagnostics error.
+ */
+class TSError extends make_error_1.BaseError {
+    constructor(diagnosticText, diagnosticCodes, diagnostics = []) {
+        super(`⨯ Unable to compile TypeScript:\n${diagnosticText}`);
+        this.diagnosticCodes = diagnosticCodes;
+        this.name = 'TSError';
+        Object.defineProperty(this, 'diagnosticText', {
+            configurable: true,
+            writable: true,
+            value: diagnosticText,
+        });
+        Object.defineProperty(this, 'diagnostics', {
+            configurable: true,
+            writable: true,
+            value: diagnostics,
+        });
     }
-
-    if (!options.quiet) {
-      common.log(stack[index]);
+    /**
+     * @internal
+     */
+    [exports.INSPECT_CUSTOM]() {
+        return this.diagnosticText;
     }
-    return stack[index];
-  }
-
-  if (!options.quiet) {
-    common.log(stack.join(' '));
-  }
-
-  return stack;
 }
-exports.dirs = _dirs;
-
-
-/***/ }),
-
-/***/ 99534:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
-
-var format = (__nccwpck_require__(73837).format);
-
-var common = __nccwpck_require__(17673);
-
-common.register('echo', _echo, {
-  allowGlobbing: false,
-});
-
-//@
-//@ ### echo([options,] string [, string ...])
-//@
-//@ Available options:
-//@
-//@ + `-e`: interpret backslash escapes (default)
-//@ + `-n`: remove trailing newline from output
-//@
-//@ Examples:
-//@
-//@ ```javascript
-//@ echo('hello world');
-//@ var str = echo('hello world');
-//@ echo('-n', 'no newline at end');
-//@ ```
-//@
-//@ Prints `string` to stdout, and returns string with additional utility methods
-//@ like `.to()`.
-function _echo(opts) {
-  // allow strings starting with '-', see issue #20
-  var messages = [].slice.call(arguments, opts ? 0 : 1);
-  var options = {};
-
-  // If the first argument starts with '-', parse it as options string.
-  // If parseOptions throws, it wasn't an options string.
-  try {
-    options = common.parseOptions(messages[0], {
-      'e': 'escapes',
-      'n': 'no_newline',
-    }, {
-      silent: true,
-    });
-
-    // Allow null to be echoed
-    if (messages[0]) {
-      messages.shift();
+exports.TSError = TSError;
+const TS_NODE_SERVICE_BRAND = Symbol('TS_NODE_SERVICE_BRAND');
+function register(serviceOrOpts) {
+    // Is this a Service or a RegisterOptions?
+    let service = serviceOrOpts;
+    if (!(serviceOrOpts === null || serviceOrOpts === void 0 ? void 0 : serviceOrOpts[TS_NODE_SERVICE_BRAND])) {
+        // Not a service; is options
+        service = create((serviceOrOpts !== null && serviceOrOpts !== void 0 ? serviceOrOpts : {}));
     }
-  } catch (_) {
-    // Clear out error if an error occurred
-    common.state.error = null;
-  }
-
-  var output = format.apply(null, messages);
-
-  // Add newline if -n is not passed.
-  if (!options.no_newline) {
-    output += '\n';
-  }
-
-  process.stdout.write(output);
-
-  return output;
-}
-
-module.exports = _echo;
-
-
-/***/ }),
-
-/***/ 49862:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
-
-var common = __nccwpck_require__(17673);
-
-//@
-//@ ### error()
-//@
-//@ Tests if error occurred in the last command. Returns a truthy value if an
-//@ error returned, or a falsy value otherwise.
-//@
-//@ **Note**: do not rely on the
-//@ return value to be an error message. If you need the last error message, use
-//@ the `.stderr` attribute from the last command's return value instead.
-function error() {
-  return common.state.error;
-}
-module.exports = error;
-
-
-/***/ }),
-
-/***/ 24416:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
-
-/* module decorator */ module = __nccwpck_require__.nmd(module);
-if (require.main !== module) {
-  throw new Error('This file should not be required');
+    const originalJsHandler = require.extensions['.js'];
+    // Expose registered instance globally.
+    process[exports.REGISTER_INSTANCE] = service;
+    // Register the extensions.
+    registerExtensions(service.options.preferTsExts, service.extensions.compiled, service, originalJsHandler);
+    (0, cjs_resolve_hooks_1.installCommonjsResolveHooksIfNecessary)(service);
+    // Require specified modules before start-up.
+    module_1.Module._preloadModules(service.options.require);
+    return service;
 }
-
-var childProcess = __nccwpck_require__(32081);
-var fs = __nccwpck_require__(57147);
-
-var paramFilePath = process.argv[2];
-
-var serializedParams = fs.readFileSync(paramFilePath, 'utf8');
-var params = JSON.parse(serializedParams);
-
-var cmd = params.command;
-var execOptions = params.execOptions;
-var pipe = params.pipe;
-var stdoutFile = params.stdoutFile;
-var stderrFile = params.stderrFile;
-
-var c = childProcess.exec(cmd, execOptions, function (err) {
-  if (!err) {
-    process.exitCode = 0;
-  } else if (err.code === undefined) {
-    process.exitCode = 1;
-  } else {
-    process.exitCode = err.code;
-  }
-});
-
-var stdoutStream = fs.createWriteStream(stdoutFile);
-var stderrStream = fs.createWriteStream(stderrFile);
-
-c.stdout.pipe(stdoutStream);
-c.stderr.pipe(stderrStream);
-c.stdout.pipe(process.stdout);
-c.stderr.pipe(process.stderr);
-
-if (pipe) {
-  c.stdin.end(pipe);
+exports.register = register;
+/**
+ * Create TypeScript compiler instance.
+ *
+ * @category Basic
+ */
+function create(rawOptions = {}) {
+    const foundConfigResult = (0, configuration_1.findAndReadConfig)(rawOptions);
+    return createFromPreloadedConfig(foundConfigResult);
 }
-
-
-/***/ }),
-
-/***/ 74221:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
-
-var common = __nccwpck_require__(17673);
-var _tempDir = (__nccwpck_require__(40591).tempDir);
-var _pwd = __nccwpck_require__(24020);
-var path = __nccwpck_require__(71017);
-var fs = __nccwpck_require__(57147);
-var child = __nccwpck_require__(32081);
-
-var DEFAULT_MAXBUFFER_SIZE = 20 * 1024 * 1024;
-var DEFAULT_ERROR_CODE = 1;
-
-common.register('exec', _exec, {
-  unix: false,
-  canReceivePipe: true,
-  wrapOutput: false,
-});
-
-// We use this function to run `exec` synchronously while also providing realtime
-// output.
-function execSync(cmd, opts, pipe) {
-  if (!common.config.execPath) {
-    common.error('Unable to find a path to the node binary. Please manually set config.execPath');
-  }
-
-  var tempDir = _tempDir();
-  var paramsFile = path.resolve(tempDir + '/' + common.randomFileName());
-  var stderrFile = path.resolve(tempDir + '/' + common.randomFileName());
-  var stdoutFile = path.resolve(tempDir + '/' + common.randomFileName());
-
-  opts = common.extend({
-    silent: common.config.silent,
-    cwd: _pwd().toString(),
-    env: process.env,
-    maxBuffer: DEFAULT_MAXBUFFER_SIZE,
-    encoding: 'utf8',
-  }, opts);
-
-  if (fs.existsSync(paramsFile)) common.unlinkSync(paramsFile);
-  if (fs.existsSync(stderrFile)) common.unlinkSync(stderrFile);
-  if (fs.existsSync(stdoutFile)) common.unlinkSync(stdoutFile);
-
-  opts.cwd = path.resolve(opts.cwd);
-
-  var paramsToSerialize = {
-    command: cmd,
-    execOptions: opts,
-    pipe: pipe,
-    stdoutFile: stdoutFile,
-    stderrFile: stderrFile,
-  };
-
-  // Create the files and ensure these are locked down (for read and write) to
-  // the current user. The main concerns here are:
-  //
-  // * If we execute a command which prints sensitive output, then
-  //   stdoutFile/stderrFile must not be readable by other users.
-  // * paramsFile must not be readable by other users, or else they can read it
-  //   to figure out the path for stdoutFile/stderrFile and create these first
-  //   (locked down to their own access), which will crash exec() when it tries
-  //   to write to the files.
-  function writeFileLockedDown(filePath, data) {
-    fs.writeFileSync(filePath, data, {
-      encoding: 'utf8',
-      mode: parseInt('600', 8),
-    });
-  }
-  writeFileLockedDown(stdoutFile, '');
-  writeFileLockedDown(stderrFile, '');
-  writeFileLockedDown(paramsFile, JSON.stringify(paramsToSerialize));
-
-  var execArgs = [
-    __nccwpck_require__.ab + "exec-child.js",
-    paramsFile,
-  ];
-
-  /* istanbul ignore else */
-  if (opts.silent) {
-    opts.stdio = 'ignore';
-  } else {
-    opts.stdio = [0, 1, 2];
-  }
-
-  var code = 0;
-
-  // Welcome to the future
-  try {
-    // Bad things if we pass in a `shell` option to child_process.execFileSync,
-    // so we need to explicitly remove it here.
-    delete opts.shell;
-
-    child.execFileSync(common.config.execPath, execArgs, opts);
-  } catch (e) {
-    // Commands with non-zero exit code raise an exception.
-    code = e.status || DEFAULT_ERROR_CODE;
-  }
-
-  // fs.readFileSync uses buffer encoding by default, so call
-  // it without the encoding option if the encoding is 'buffer'.
-  // Also, if the exec timeout is too short for node to start up,
-  // the files will not be created, so these calls will throw.
-  var stdout = '';
-  var stderr = '';
-  if (opts.encoding === 'buffer') {
-    stdout = fs.readFileSync(stdoutFile);
-    stderr = fs.readFileSync(stderrFile);
-  } else {
-    stdout = fs.readFileSync(stdoutFile, opts.encoding);
-    stderr = fs.readFileSync(stderrFile, opts.encoding);
-  }
-
-  // No biggie if we can't erase the files now -- they're in a temp dir anyway
-  // and we locked down permissions (see the note above).
-  try { common.unlinkSync(paramsFile); } catch (e) {}
-  try { common.unlinkSync(stderrFile); } catch (e) {}
-  try { common.unlinkSync(stdoutFile); } catch (e) {}
-
-  if (code !== 0) {
-    // Note: `silent` should be unconditionally true to avoid double-printing
-    // the command's stderr, and to avoid printing any stderr when the user has
-    // set `shell.config.silent`.
-    common.error(stderr, code, { continue: true, silent: true });
-  }
-  var obj = common.ShellString(stdout, stderr, code);
-  return obj;
-} // execSync()
-
-// Wrapper around exec() to enable echoing output to console in real time
-function execAsync(cmd, opts, pipe, callback) {
-  opts = common.extend({
-    silent: common.config.silent,
-    cwd: _pwd().toString(),
-    env: process.env,
-    maxBuffer: DEFAULT_MAXBUFFER_SIZE,
-    encoding: 'utf8',
-  }, opts);
-
-  var c = child.exec(cmd, opts, function (err, stdout, stderr) {
-    if (callback) {
-      if (!err) {
-        callback(0, stdout, stderr);
-      } else if (err.code === undefined) {
-        // See issue #536
-        /* istanbul ignore next */
-        callback(1, stdout, stderr);
-      } else {
-        callback(err.code, stdout, stderr);
-      }
+exports.create = create;
+/** @internal */
+function createFromPreloadedConfig(foundConfigResult) {
+    var _a, _b, _c, _d;
+    const { configFilePath, cwd, options, config, compiler, projectLocalResolveDir, optionBasePaths, } = foundConfigResult;
+    const projectLocalResolveHelper = (0, util_1.createProjectLocalResolveHelper)(projectLocalResolveDir);
+    const ts = (0, configuration_1.loadCompiler)(compiler);
+    // Experimental REPL await is not compatible targets lower than ES2018
+    const targetSupportsTla = config.options.target >= ts.ScriptTarget.ES2018;
+    if (options.experimentalReplAwait === true && !targetSupportsTla) {
+        throw new Error('Experimental REPL await is not compatible with targets lower than ES2018');
     }
-  });
-
-  if (pipe) c.stdin.end(pipe);
-
-  if (!opts.silent) {
-    c.stdout.pipe(process.stdout);
-    c.stderr.pipe(process.stderr);
-  }
-
-  return c;
+    // Top-level await was added in TS 3.8
+    const tsVersionSupportsTla = (0, util_1.versionGteLt)(ts.version, '3.8.0');
+    if (options.experimentalReplAwait === true && !tsVersionSupportsTla) {
+        throw new Error('Experimental REPL await is not compatible with TypeScript versions older than 3.8');
+    }
+    const shouldReplAwait = options.experimentalReplAwait !== false &&
+        tsVersionSupportsTla &&
+        targetSupportsTla;
+    // swc implies two other options
+    // typeCheck option was implemented specifically to allow overriding tsconfig transpileOnly from the command-line
+    // So we should allow using typeCheck to override swc
+    if (options.swc && !options.typeCheck) {
+        if (options.transpileOnly === false) {
+            throw new Error("Cannot enable 'swc' option with 'transpileOnly: false'.  'swc' implies 'transpileOnly'.");
+        }
+        if (options.transpiler) {
+            throw new Error("Cannot specify both 'swc' and 'transpiler' options.  'swc' uses the built-in swc transpiler.");
+        }
+    }
+    const readFile = options.readFile || ts.sys.readFile;
+    const fileExists = options.fileExists || ts.sys.fileExists;
+    // typeCheck can override transpileOnly, useful for CLI flag to override config file
+    const transpileOnly = (options.transpileOnly === true || options.swc === true) &&
+        options.typeCheck !== true;
+    let transpiler = undefined;
+    let transpilerBasePath = undefined;
+    if (options.transpiler) {
+        transpiler = options.transpiler;
+        transpilerBasePath = optionBasePaths.transpiler;
+    }
+    else if (options.swc) {
+        transpiler = __nccwpck_require__.ab + "swc.js";
+        transpilerBasePath = optionBasePaths.swc;
+    }
+    const transformers = options.transformers || undefined;
+    const diagnosticFilters = [
+        {
+            appliesToAllFiles: true,
+            filenamesAbsolute: [],
+            diagnosticsIgnored: [
+                6059,
+                18002,
+                18003,
+                ...(options.experimentalTsImportSpecifiers
+                    ? [
+                        2691, // "An import path cannot end with a '.ts' extension. Consider importing '' instead."
+                    ]
+                    : []),
+                ...(options.ignoreDiagnostics || []),
+            ].map(Number),
+        },
+    ];
+    const configDiagnosticList = filterDiagnostics(config.errors, diagnosticFilters);
+    const outputCache = new Map();
+    const configFileDirname = configFilePath ? (0, path_1.dirname)(configFilePath) : null;
+    const scopeDir = (_c = (_b = (_a = options.scopeDir) !== null && _a !== void 0 ? _a : config.options.rootDir) !== null && _b !== void 0 ? _b : configFileDirname) !== null && _c !== void 0 ? _c : cwd;
+    const ignoreBaseDir = configFileDirname !== null && configFileDirname !== void 0 ? configFileDirname : cwd;
+    const isScoped = options.scope
+        ? (fileName) => (0, path_1.relative)(scopeDir, fileName).charAt(0) !== '.'
+        : () => true;
+    const shouldIgnore = createIgnore(ignoreBaseDir, options.skipIgnore
+        ? []
+        : (options.ignore || ['(?:^|/)node_modules/']).map((str) => new RegExp(str)));
+    const diagnosticHost = {
+        getNewLine: () => ts.sys.newLine,
+        getCurrentDirectory: () => cwd,
+        // TODO switch to getCanonicalFileName we already create later in scope
+        getCanonicalFileName: ts.sys.useCaseSensitiveFileNames
+            ? (x) => x
+            : (x) => x.toLowerCase(),
+    };
+    if (options.transpileOnly && typeof transformers === 'function') {
+        throw new TypeError('Transformers function is unavailable in "--transpile-only"');
+    }
+    let createTranspiler = initializeTranspilerFactory();
+    function initializeTranspilerFactory() {
+        var _a;
+        if (__nccwpck_require__.ab + "swc.js") {
+            if (!transpileOnly)
+                throw new Error('Custom transpiler can only be used when transpileOnly is enabled.');
+            const transpilerName = typeof transpiler === 'string' ? transpiler : transpiler[0];
+            const transpilerOptions = typeof transpiler === 'string' ? {} : (_a = transpiler[1]) !== null && _a !== void 0 ? _a : {};
+            const transpilerConfigLocalResolveHelper = transpilerBasePath
+                ? (0, util_1.createProjectLocalResolveHelper)(transpilerBasePath)
+                : projectLocalResolveHelper;
+            const transpilerPath = transpilerConfigLocalResolveHelper(transpilerName, true);
+            const transpilerFactory = __nccwpck_require__(3833)(transpilerPath)
+                .create;
+            return createTranspiler;
+            function createTranspiler(compilerOptions, nodeModuleEmitKind) {
+                return transpilerFactory === null || transpilerFactory === void 0 ? void 0 : transpilerFactory({
+                    service: {
+                        options,
+                        config: {
+                            ...config,
+                            options: compilerOptions,
+                        },
+                        projectLocalResolveHelper,
+                    },
+                    transpilerConfigLocalResolveHelper,
+                    nodeModuleEmitKind,
+                    ...transpilerOptions,
+                });
+            }
+        }
+    }
+    /**
+     * True if require() hooks should interop with experimental ESM loader.
+     * Enabled explicitly via a flag since it is a breaking change.
+     */
+    let experimentalEsmLoader = false;
+    function enableExperimentalEsmLoaderInterop() {
+        experimentalEsmLoader = true;
+    }
+    // Install source map support and read from memory cache.
+    installSourceMapSupport();
+    function installSourceMapSupport() {
+        const sourceMapSupport = __nccwpck_require__(89254);
+        sourceMapSupport.install({
+            environment: 'node',
+            retrieveFile(pathOrUrl) {
+                var _a;
+                let path = pathOrUrl;
+                // If it's a file URL, convert to local path
+                // Note: fileURLToPath does not exist on early node v10
+                // I could not find a way to handle non-URLs except to swallow an error
+                if (experimentalEsmLoader && path.startsWith('file://')) {
+                    try {
+                        path = (0, url_1.fileURLToPath)(path);
+                    }
+                    catch (e) {
+                        /* swallow error */
+                    }
+                }
+                path = (0, util_1.normalizeSlashes)(path);
+                return ((_a = outputCache.get(path)) === null || _a === void 0 ? void 0 : _a.content) || '';
+            },
+            redirectConflictingLibrary: true,
+            onConflictingLibraryRedirect(request, parent, isMain, options, redirectedRequest) {
+                (0, exports.debug)(`Redirected an attempt to require source-map-support to instead receive @cspotcode/source-map-support.  "${parent.filename}" attempted to require or resolve "${request}" and was redirected to "${redirectedRequest}".`);
+            },
+        });
+    }
+    const shouldHavePrettyErrors = options.pretty === undefined ? process.stdout.isTTY : options.pretty;
+    const formatDiagnostics = shouldHavePrettyErrors
+        ? ts.formatDiagnosticsWithColorAndContext || ts.formatDiagnostics
+        : ts.formatDiagnostics;
+    function createTSError(diagnostics) {
+        const diagnosticText = formatDiagnostics(diagnostics, diagnosticHost);
+        const diagnosticCodes = diagnostics.map((x) => x.code);
+        return new TSError(diagnosticText, diagnosticCodes, diagnostics);
+    }
+    function reportTSError(configDiagnosticList) {
+        const error = createTSError(configDiagnosticList);
+        if (options.logError) {
+            // Print error in red color and continue execution.
+            console.error('\x1b[31m%s\x1b[0m', error);
+        }
+        else {
+            // Throw error and exit the script.
+            throw error;
+        }
+    }
+    // Render the configuration errors.
+    if (configDiagnosticList.length)
+        reportTSError(configDiagnosticList);
+    const jsxEmitPreserve = config.options.jsx === ts.JsxEmit.Preserve;
+    /**
+     * Get the extension for a transpiled file.
+     * [MUST_UPDATE_FOR_NEW_FILE_EXTENSIONS]
+     */
+    function getEmitExtension(path) {
+        const lastDotIndex = path.lastIndexOf('.');
+        if (lastDotIndex >= 0) {
+            const ext = path.slice(lastDotIndex);
+            switch (ext) {
+                case '.js':
+                case '.ts':
+                    return '.js';
+                case '.jsx':
+                case '.tsx':
+                    return jsxEmitPreserve ? '.jsx' : '.js';
+                case '.mjs':
+                case '.mts':
+                    return '.mjs';
+                case '.cjs':
+                case '.cts':
+                    return '.cjs';
+            }
+        }
+        return '.js';
+    }
+    /**
+     * Get output from TS compiler w/typechecking.  `undefined` in `transpileOnly`
+     * mode.
+     */
+    let getOutput;
+    let getTypeInfo;
+    const getCanonicalFileName = ts.createGetCanonicalFileName(ts.sys.useCaseSensitiveFileNames);
+    const moduleTypeClassifier = (0, module_type_classifier_1.createModuleTypeClassifier)({
+        basePath: (_d = options.optionBasePaths) === null || _d === void 0 ? void 0 : _d.moduleTypes,
+        patterns: options.moduleTypes,
+    });
+    const extensions = (0, file_extensions_1.getExtensions)(config, options, ts.version);
+    // Use full language services when the fast option is disabled.
+    if (!transpileOnly) {
+        const fileContents = new Map();
+        const rootFileNames = new Set(config.fileNames);
+        const cachedReadFile = (0, util_1.cachedLookup)(debugFn('readFile', readFile));
+        // Use language services by default
+        if (!options.compilerHost) {
+            let projectVersion = 1;
+            const fileVersions = new Map(Array.from(rootFileNames).map((fileName) => [fileName, 0]));
+            const getCustomTransformers = () => {
+                if (typeof transformers === 'function') {
+                    const program = service.getProgram();
+                    return program ? transformers(program) : undefined;
+                }
+                return transformers;
+            };
+            // Create the compiler host for type checking.
+            const serviceHost = {
+                getProjectVersion: () => String(projectVersion),
+                getScriptFileNames: () => Array.from(rootFileNames),
+                getScriptVersion: (fileName) => {
+                    const version = fileVersions.get(fileName);
+                    return version ? version.toString() : '';
+                },
+                getScriptSnapshot(fileName) {
+                    // TODO ordering of this with getScriptVersion?  Should they sync up?
+                    let contents = fileContents.get(fileName);
+                    // Read contents into TypeScript memory cache.
+                    if (contents === undefined) {
+                        contents = cachedReadFile(fileName);
+                        if (contents === undefined)
+                            return;
+                        fileVersions.set(fileName, 1);
+                        fileContents.set(fileName, contents);
+                        projectVersion++;
+                    }
+                    return ts.ScriptSnapshot.fromString(contents);
+                },
+                readFile: cachedReadFile,
+                readDirectory: ts.sys.readDirectory,
+                getDirectories: (0, util_1.cachedLookup)(debugFn('getDirectories', ts.sys.getDirectories)),
+                fileExists: (0, util_1.cachedLookup)(debugFn('fileExists', fileExists)),
+                directoryExists: (0, util_1.cachedLookup)(debugFn('directoryExists', ts.sys.directoryExists)),
+                realpath: ts.sys.realpath
+                    ? (0, util_1.cachedLookup)(debugFn('realpath', ts.sys.realpath))
+                    : undefined,
+                getNewLine: () => ts.sys.newLine,
+                useCaseSensitiveFileNames: () => ts.sys.useCaseSensitiveFileNames,
+                getCurrentDirectory: () => cwd,
+                getCompilationSettings: () => config.options,
+                getDefaultLibFileName: () => ts.getDefaultLibFilePath(config.options),
+                getCustomTransformers: getCustomTransformers,
+                trace: options.tsTrace,
+            };
+            const { resolveModuleNames, getResolvedModuleWithFailedLookupLocationsFromCache, resolveTypeReferenceDirectives, isFileKnownToBeInternal, markBucketOfFilenameInternal, } = (0, resolver_functions_1.createResolverFunctions)({
+                host: serviceHost,
+                getCanonicalFileName,
+                ts,
+                cwd,
+                config,
+                projectLocalResolveHelper,
+                options,
+                extensions,
+            });
+            serviceHost.resolveModuleNames = resolveModuleNames;
+            serviceHost.getResolvedModuleWithFailedLookupLocationsFromCache =
+                getResolvedModuleWithFailedLookupLocationsFromCache;
+            serviceHost.resolveTypeReferenceDirectives =
+                resolveTypeReferenceDirectives;
+            const registry = ts.createDocumentRegistry(ts.sys.useCaseSensitiveFileNames, cwd);
+            const service = ts.createLanguageService(serviceHost, registry);
+            const updateMemoryCache = (contents, fileName) => {
+                // Add to `rootFiles` as necessary, either to make TS include a file it has not seen,
+                // or to trigger a re-classification of files from external to internal.
+                if (!rootFileNames.has(fileName) &&
+                    !isFileKnownToBeInternal(fileName)) {
+                    markBucketOfFilenameInternal(fileName);
+                    rootFileNames.add(fileName);
+                    // Increment project version for every change to rootFileNames.
+                    projectVersion++;
+                }
+                const previousVersion = fileVersions.get(fileName) || 0;
+                const previousContents = fileContents.get(fileName);
+                // Avoid incrementing cache when nothing has changed.
+                if (contents !== previousContents) {
+                    fileVersions.set(fileName, previousVersion + 1);
+                    fileContents.set(fileName, contents);
+                    // Increment project version for every file change.
+                    projectVersion++;
+                }
+            };
+            let previousProgram = undefined;
+            getOutput = (code, fileName) => {
+                updateMemoryCache(code, fileName);
+                const programBefore = service.getProgram();
+                if (programBefore !== previousProgram) {
+                    (0, exports.debug)(`compiler rebuilt Program instance when getting output for ${fileName}`);
+                }
+                const output = service.getEmitOutput(fileName);
+                // Get the relevant diagnostics - this is 3x faster than `getPreEmitDiagnostics`.
+                const diagnostics = service
+                    .getSemanticDiagnostics(fileName)
+                    .concat(service.getSyntacticDiagnostics(fileName));
+                const programAfter = service.getProgram();
+                (0, exports.debug)('invariant: Is service.getProject() identical before and after getting emit output and diagnostics? (should always be true) ', programBefore === programAfter);
+                previousProgram = programAfter;
+                const diagnosticList = filterDiagnostics(diagnostics, diagnosticFilters);
+                if (diagnosticList.length)
+                    reportTSError(diagnosticList);
+                if (output.emitSkipped) {
+                    return [undefined, undefined, true];
+                }
+                // Throw an error when requiring `.d.ts` files.
+                if (output.outputFiles.length === 0) {
+                    throw new TypeError(`Unable to require file: ${(0, path_1.relative)(cwd, fileName)}\n` +
+                        'This is usually the result of a faulty configuration or import. ' +
+                        'Make sure there is a `.js`, `.json` or other executable extension with ' +
+                        'loader attached before `ts-node` available.');
+                }
+                return [output.outputFiles[1].text, output.outputFiles[0].text, false];
+            };
+            getTypeInfo = (code, fileName, position) => {
+                const normalizedFileName = (0, util_1.normalizeSlashes)(fileName);
+                updateMemoryCache(code, normalizedFileName);
+                const info = service.getQuickInfoAtPosition(normalizedFileName, position);
+                const name = ts.displayPartsToString(info ? info.displayParts : []);
+                const comment = ts.displayPartsToString(info ? info.documentation : []);
+                return { name, comment };
+            };
+        }
+        else {
+            const sys = {
+                ...ts.sys,
+                ...diagnosticHost,
+                readFile: (fileName) => {
+                    const cacheContents = fileContents.get(fileName);
+                    if (cacheContents !== undefined)
+                        return cacheContents;
+                    const contents = cachedReadFile(fileName);
+                    if (contents)
+                        fileContents.set(fileName, contents);
+                    return contents;
+                },
+                readDirectory: ts.sys.readDirectory,
+                getDirectories: (0, util_1.cachedLookup)(debugFn('getDirectories', ts.sys.getDirectories)),
+                fileExists: (0, util_1.cachedLookup)(debugFn('fileExists', fileExists)),
+                directoryExists: (0, util_1.cachedLookup)(debugFn('directoryExists', ts.sys.directoryExists)),
+                resolvePath: (0, util_1.cachedLookup)(debugFn('resolvePath', ts.sys.resolvePath)),
+                realpath: ts.sys.realpath
+                    ? (0, util_1.cachedLookup)(debugFn('realpath', ts.sys.realpath))
+                    : undefined,
+            };
+            const host = ts.createIncrementalCompilerHost
+                ? ts.createIncrementalCompilerHost(config.options, sys)
+                : {
+                    ...sys,
+                    getSourceFile: (fileName, languageVersion) => {
+                        const contents = sys.readFile(fileName);
+                        if (contents === undefined)
+                            return;
+                        return ts.createSourceFile(fileName, contents, languageVersion);
+                    },
+                    getDefaultLibLocation: () => (0, util_1.normalizeSlashes)((0, path_1.dirname)(compiler)),
+                    getDefaultLibFileName: () => (0, util_1.normalizeSlashes)((0, path_1.join)((0, path_1.dirname)(compiler), ts.getDefaultLibFileName(config.options))),
+                    useCaseSensitiveFileNames: () => sys.useCaseSensitiveFileNames,
+                };
+            host.trace = options.tsTrace;
+            const { resolveModuleNames, resolveTypeReferenceDirectives, isFileKnownToBeInternal, markBucketOfFilenameInternal, } = (0, resolver_functions_1.createResolverFunctions)({
+                host,
+                cwd,
+                config,
+                ts,
+                getCanonicalFileName,
+                projectLocalResolveHelper,
+                options,
+                extensions,
+            });
+            host.resolveModuleNames = resolveModuleNames;
+            host.resolveTypeReferenceDirectives = resolveTypeReferenceDirectives;
+            // Fallback for older TypeScript releases without incremental API.
+            let builderProgram = ts.createIncrementalProgram
+                ? ts.createIncrementalProgram({
+                    rootNames: Array.from(rootFileNames),
+                    options: config.options,
+                    host,
+                    configFileParsingDiagnostics: config.errors,
+                    projectReferences: config.projectReferences,
+                })
+                : ts.createEmitAndSemanticDiagnosticsBuilderProgram(Array.from(rootFileNames), config.options, host, undefined, config.errors, config.projectReferences);
+            // Read and cache custom transformers.
+            const customTransformers = typeof transformers === 'function'
+                ? transformers(builderProgram.getProgram())
+                : transformers;
+            // Set the file contents into cache manually.
+            const updateMemoryCache = (contents, fileName) => {
+                const previousContents = fileContents.get(fileName);
+                const contentsChanged = previousContents !== contents;
+                if (contentsChanged) {
+                    fileContents.set(fileName, contents);
+                }
+                // Add to `rootFiles` when discovered by compiler for the first time.
+                let addedToRootFileNames = false;
+                if (!rootFileNames.has(fileName) &&
+                    !isFileKnownToBeInternal(fileName)) {
+                    markBucketOfFilenameInternal(fileName);
+                    rootFileNames.add(fileName);
+                    addedToRootFileNames = true;
+                }
+                // Update program when file changes.
+                if (addedToRootFileNames || contentsChanged) {
+                    builderProgram = ts.createEmitAndSemanticDiagnosticsBuilderProgram(Array.from(rootFileNames), config.options, host, builderProgram, config.errors, config.projectReferences);
+                }
+            };
+            getOutput = (code, fileName) => {
+                let outText = '';
+                let outMap = '';
+                updateMemoryCache(code, fileName);
+                const sourceFile = builderProgram.getSourceFile(fileName);
+                if (!sourceFile)
+                    throw new TypeError(`Unable to read file: ${fileName}`);
+                const program = builderProgram.getProgram();
+                const diagnostics = ts.getPreEmitDiagnostics(program, sourceFile);
+                const diagnosticList = filterDiagnostics(diagnostics, diagnosticFilters);
+                if (diagnosticList.length)
+                    reportTSError(diagnosticList);
+                const result = builderProgram.emit(sourceFile, (path, file, writeByteOrderMark) => {
+                    if (path.endsWith('.map')) {
+                        outMap = file;
+                    }
+                    else {
+                        outText = file;
+                    }
+                    if (options.emit)
+                        sys.writeFile(path, file, writeByteOrderMark);
+                }, undefined, undefined, customTransformers);
+                if (result.emitSkipped) {
+                    return [undefined, undefined, true];
+                }
+                // Throw an error when requiring files that cannot be compiled.
+                if (outText === '') {
+                    if (program.isSourceFileFromExternalLibrary(sourceFile)) {
+                        throw new TypeError(`Unable to compile file from external library: ${(0, path_1.relative)(cwd, fileName)}`);
+                    }
+                    throw new TypeError(`Unable to require file: ${(0, path_1.relative)(cwd, fileName)}\n` +
+                        'This is usually the result of a faulty configuration or import. ' +
+                        'Make sure there is a `.js`, `.json` or other executable extension with ' +
+                        'loader attached before `ts-node` available.');
+                }
+                return [outText, outMap, false];
+            };
+            getTypeInfo = (code, fileName, position) => {
+                const normalizedFileName = (0, util_1.normalizeSlashes)(fileName);
+                updateMemoryCache(code, normalizedFileName);
+                const sourceFile = builderProgram.getSourceFile(normalizedFileName);
+                if (!sourceFile)
+                    throw new TypeError(`Unable to read file: ${fileName}`);
+                const node = getTokenAtPosition(ts, sourceFile, position);
+                const checker = builderProgram.getProgram().getTypeChecker();
+                const symbol = checker.getSymbolAtLocation(node);
+                if (!symbol)
+                    return { name: '', comment: '' };
+                const type = checker.getTypeOfSymbolAtLocation(symbol, node);
+                const signatures = [
+                    ...type.getConstructSignatures(),
+                    ...type.getCallSignatures(),
+                ];
+                return {
+                    name: signatures.length
+                        ? signatures.map((x) => checker.signatureToString(x)).join('\n')
+                        : checker.typeToString(type),
+                    comment: ts.displayPartsToString(symbol ? symbol.getDocumentationComment(checker) : []),
+                };
+            };
+            // Write `.tsbuildinfo` when `--build` is enabled.
+            if (options.emit && config.options.incremental) {
+                process.on('exit', () => {
+                    // Emits `.tsbuildinfo` to filesystem.
+                    builderProgram.getProgram().emitBuildInfo();
+                });
+            }
+        }
+    }
+    else {
+        getTypeInfo = () => {
+            throw new TypeError('Type information is unavailable in "--transpile-only"');
+        };
+    }
+    function createTranspileOnlyGetOutputFunction(overrideModuleType, nodeModuleEmitKind) {
+        const compilerOptions = { ...config.options };
+        if (overrideModuleType !== undefined)
+            compilerOptions.module = overrideModuleType;
+        let customTranspiler = createTranspiler === null || createTranspiler === void 0 ? void 0 : createTranspiler(compilerOptions, nodeModuleEmitKind);
+        let tsTranspileModule = (0, util_1.versionGteLt)(ts.version, '4.7.0')
+            ? (0, ts_transpile_module_1.createTsTranspileModule)(ts, {
+                compilerOptions,
+                reportDiagnostics: true,
+                transformers: transformers,
+            })
+            : undefined;
+        return (code, fileName) => {
+            let result;
+            if (customTranspiler) {
+                result = customTranspiler.transpile(code, {
+                    fileName,
+                });
+            }
+            else if (tsTranspileModule) {
+                result = tsTranspileModule(code, {
+                    fileName,
+                }, nodeModuleEmitKind === 'nodeesm' ? 'module' : 'commonjs');
+            }
+            else {
+                result = ts.transpileModule(code, {
+                    fileName,
+                    compilerOptions,
+                    reportDiagnostics: true,
+                    transformers: transformers,
+                });
+            }
+            const diagnosticList = filterDiagnostics(result.diagnostics || [], diagnosticFilters);
+            if (diagnosticList.length)
+                reportTSError(diagnosticList);
+            return [result.outputText, result.sourceMapText, false];
+        };
+    }
+    // When true, these mean that a `moduleType` override will cause a different emit
+    // than the TypeScript compiler, so we *must* overwrite the emit.
+    const shouldOverwriteEmitWhenForcingCommonJS = config.options.module !== ts.ModuleKind.CommonJS;
+    // [MUST_UPDATE_FOR_NEW_MODULEKIND]
+    const shouldOverwriteEmitWhenForcingEsm = !(config.options.module === ts.ModuleKind.ES2015 ||
+        (ts.ModuleKind.ES2020 && config.options.module === ts.ModuleKind.ES2020) ||
+        (ts.ModuleKind.ES2022 && config.options.module === ts.ModuleKind.ES2022) ||
+        config.options.module === ts.ModuleKind.ESNext);
+    /**
+     * node16 or nodenext
+     * [MUST_UPDATE_FOR_NEW_MODULEKIND]
+     */
+    const isNodeModuleType = (ts.ModuleKind.Node16 && config.options.module === ts.ModuleKind.Node16) ||
+        (ts.ModuleKind.NodeNext &&
+            config.options.module === ts.ModuleKind.NodeNext);
+    const getOutputForceCommonJS = createTranspileOnlyGetOutputFunction(ts.ModuleKind.CommonJS);
+    const getOutputForceNodeCommonJS = createTranspileOnlyGetOutputFunction(ts.ModuleKind.NodeNext, 'nodecjs');
+    const getOutputForceNodeESM = createTranspileOnlyGetOutputFunction(ts.ModuleKind.NodeNext, 'nodeesm');
+    // [MUST_UPDATE_FOR_NEW_MODULEKIND]
+    const getOutputForceESM = createTranspileOnlyGetOutputFunction(ts.ModuleKind.ES2022 || ts.ModuleKind.ES2020 || ts.ModuleKind.ES2015);
+    const getOutputTranspileOnly = createTranspileOnlyGetOutputFunction();
+    // Create a simple TypeScript compiler proxy.
+    function compile(code, fileName, lineOffset = 0) {
+        const normalizedFileName = (0, util_1.normalizeSlashes)(fileName);
+        const classification = moduleTypeClassifier.classifyModuleByModuleTypeOverrides(normalizedFileName);
+        let value = '';
+        let sourceMap = '';
+        let emitSkipped = true;
+        if (getOutput) {
+            // Must always call normal getOutput to throw typechecking errors
+            [value, sourceMap, emitSkipped] = getOutput(code, normalizedFileName);
+        }
+        // If module classification contradicts the above, call the relevant transpiler
+        if (classification.moduleType === 'cjs' &&
+            (shouldOverwriteEmitWhenForcingCommonJS || emitSkipped)) {
+            [value, sourceMap] = getOutputForceCommonJS(code, normalizedFileName);
+        }
+        else if (classification.moduleType === 'esm' &&
+            (shouldOverwriteEmitWhenForcingEsm || emitSkipped)) {
+            [value, sourceMap] = getOutputForceESM(code, normalizedFileName);
+        }
+        else if (emitSkipped) {
+            // Happens when ts compiler skips emit or in transpileOnly mode
+            const classification = (0, node_module_type_classifier_1.classifyModule)(fileName, isNodeModuleType);
+            [value, sourceMap] =
+                classification === 'nodecjs'
+                    ? getOutputForceNodeCommonJS(code, normalizedFileName)
+                    : classification === 'nodeesm'
+                        ? getOutputForceNodeESM(code, normalizedFileName)
+                        : classification === 'cjs'
+                            ? getOutputForceCommonJS(code, normalizedFileName)
+                            : classification === 'esm'
+                                ? getOutputForceESM(code, normalizedFileName)
+                                : getOutputTranspileOnly(code, normalizedFileName);
+        }
+        const output = updateOutput(value, normalizedFileName, sourceMap, getEmitExtension);
+        outputCache.set(normalizedFileName, { content: output });
+        return output;
+    }
+    let active = true;
+    const enabled = (enabled) => enabled === undefined ? active : (active = !!enabled);
+    const ignored = (fileName) => {
+        if (!active)
+            return true;
+        const ext = (0, path_1.extname)(fileName);
+        if (extensions.compiled.includes(ext)) {
+            return !isScoped(fileName) || shouldIgnore(fileName);
+        }
+        return true;
+    };
+    function addDiagnosticFilter(filter) {
+        diagnosticFilters.push({
+            ...filter,
+            filenamesAbsolute: filter.filenamesAbsolute.map((f) => (0, util_1.normalizeSlashes)(f)),
+        });
+    }
+    const getNodeEsmResolver = (0, util_1.once)(() => (__nccwpck_require__(74284).createResolve)({
+        extensions,
+        preferTsExts: options.preferTsExts,
+        tsNodeExperimentalSpecifierResolution: options.experimentalSpecifierResolution,
+    }));
+    const getNodeEsmGetFormat = (0, util_1.once)(() => (__nccwpck_require__(17604).createGetFormat)(options.experimentalSpecifierResolution, getNodeEsmResolver()));
+    const getNodeCjsLoader = (0, util_1.once)(() => (__nccwpck_require__(88232).createCjsLoader)({
+        extensions,
+        preferTsExts: options.preferTsExts,
+        nodeEsmResolver: getNodeEsmResolver(),
+    }));
+    return {
+        [TS_NODE_SERVICE_BRAND]: true,
+        ts,
+        compilerPath: compiler,
+        config,
+        compile,
+        getTypeInfo,
+        ignored,
+        enabled,
+        options,
+        configFilePath,
+        moduleTypeClassifier,
+        shouldReplAwait,
+        addDiagnosticFilter,
+        installSourceMapSupport,
+        enableExperimentalEsmLoaderInterop,
+        transpileOnly,
+        projectLocalResolveHelper,
+        getNodeEsmResolver,
+        getNodeEsmGetFormat,
+        getNodeCjsLoader,
+        extensions,
+    };
 }
-
-//@
-//@ ### exec(command [, options] [, callback])
-//@
-//@ Available options:
-//@
-//@ + `async`: Asynchronous execution. If a callback is provided, it will be set to
-//@   `true`, regardless of the passed value (default: `false`).
-//@ + `silent`: Do not echo program output to console (default: `false`).
-//@ + `encoding`: Character encoding to use. Affects the values returned to stdout and stderr, and
-//@   what is written to stdout and stderr when not in silent mode (default: `'utf8'`).
-//@ + and any option available to Node.js's
-//@   [`child_process.exec()`](https://nodejs.org/api/child_process.html#child_process_child_process_exec_command_options_callback)
-//@
-//@ Examples:
-//@
-//@ ```javascript
-//@ var version = exec('node --version', {silent:true}).stdout;
-//@
-//@ var child = exec('some_long_running_process', {async:true});
-//@ child.stdout.on('data', function(data) {
-//@   /* ... do something with data ... */
-//@ });
-//@
-//@ exec('some_long_running_process', function(code, stdout, stderr) {
-//@   console.log('Exit code:', code);
-//@   console.log('Program output:', stdout);
-//@   console.log('Program stderr:', stderr);
-//@ });
-//@ ```
-//@
-//@ Executes the given `command` _synchronously_, unless otherwise specified.  When in synchronous
-//@ mode, this returns a `ShellString` (compatible with ShellJS v0.6.x, which returns an object
-//@ of the form `{ code:..., stdout:... , stderr:... }`). Otherwise, this returns the child process
-//@ object, and the `callback` receives the arguments `(code, stdout, stderr)`.
-//@
-//@ Not seeing the behavior you want? `exec()` runs everything through `sh`
-//@ by default (or `cmd.exe` on Windows), which differs from `bash`. If you
-//@ need bash-specific behavior, try out the `{shell: 'path/to/bash'}` option.
-function _exec(command, options, callback) {
-  options = options || {};
-  if (!command) common.error('must specify command');
-
-  var pipe = common.readFromPipe();
-
-  // Callback is defined instead of options.
-  if (typeof options === 'function') {
-    callback = options;
-    options = { async: true };
-  }
-
-  // Callback is defined with options.
-  if (typeof options === 'object' && typeof callback === 'function') {
-    options.async = true;
-  }
-
-  options = common.extend({
-    silent: common.config.silent,
-    async: false,
-  }, options);
-
-  if (options.async) {
-    return execAsync(command, options, pipe, callback);
-  } else {
-    return execSync(command, options, pipe);
-  }
+exports.createFromPreloadedConfig = createFromPreloadedConfig;
+/**
+ * Check if the filename should be ignored.
+ */
+function createIgnore(ignoreBaseDir, ignore) {
+    return (fileName) => {
+        const relname = (0, path_1.relative)(ignoreBaseDir, fileName);
+        const path = (0, util_1.normalizeSlashes)(relname);
+        return ignore.some((x) => x.test(path));
+    };
 }
-module.exports = _exec;
-
+/**
+ * Register the extensions to support when importing files.
+ */
+function registerExtensions(preferTsExts, extensions, service, originalJsHandler) {
+    const exts = new Set(extensions);
+    // Can't add these extensions cuz would allow omitting file extension; node requires ext for .cjs and .mjs
+    // Unless they're already registered by something else (nyc does this):
+    // then we *must* hook them or else our transformer will not be called.
+    for (const cannotAdd of ['.mts', '.cts', '.mjs', '.cjs']) {
+        if (exts.has(cannotAdd) && !(0, util_1.hasOwnProperty)(require.extensions, cannotAdd)) {
+            // Unrecognized file exts can be transformed via the `.js` handler.
+            exts.add('.js');
+            exts.delete(cannotAdd);
+        }
+    }
+    // Register new extensions.
+    for (const ext of exts) {
+        registerExtension(ext, service, originalJsHandler);
+    }
+    if (preferTsExts) {
+        const preferredExtensions = new Set([
+            ...exts,
+            ...Object.keys(require.extensions),
+        ]);
+        // Re-sort iteration order of Object.keys()
+        for (const ext of preferredExtensions) {
+            const old = Object.getOwnPropertyDescriptor(require.extensions, ext);
+            delete require.extensions[ext];
+            Object.defineProperty(require.extensions, ext, old);
+        }
+    }
+}
+/**
+ * Register the extension for node.
+ */
+function registerExtension(ext, service, originalHandler) {
+    const old = require.extensions[ext] || originalHandler;
+    require.extensions[ext] = function (m, filename) {
+        if (service.ignored(filename))
+            return old(m, filename);
+        assertScriptCanLoadAsCJS(service, m, filename);
+        const _compile = m._compile;
+        m._compile = function (code, fileName) {
+            (0, exports.debug)('module._compile', fileName);
+            const result = service.compile(code, fileName);
+            return _compile.call(this, result, fileName);
+        };
+        return old(m, filename);
+    };
+}
+/**
+ * Update the output remapping the source map.
+ */
+function updateOutput(outputText, fileName, sourceMap, getEmitExtension) {
+    const base64Map = Buffer.from(updateSourceMap(sourceMap, fileName), 'utf8').toString('base64');
+    const sourceMapContent = `//# sourceMappingURL=data:application/json;charset=utf-8;base64,${base64Map}`;
+    // Expected form: `//# sourceMappingURL=foo bar.js.map` or `//# sourceMappingURL=foo%20bar.js.map` for input file "foo bar.tsx"
+    // Percent-encoding behavior added in TS 4.1.1: https://github.com/microsoft/TypeScript/issues/40951
+    const prefix = '//# sourceMappingURL=';
+    const prefixLength = prefix.length;
+    const baseName = /*foo.tsx*/ (0, path_1.basename)(fileName);
+    const extName = /*.tsx*/ (0, path_1.extname)(fileName);
+    const extension = /*.js*/ getEmitExtension(fileName);
+    const sourcemapFilename = baseName.slice(0, -extName.length) + extension + '.map';
+    const sourceMapLengthWithoutPercentEncoding = prefixLength + sourcemapFilename.length;
+    /*
+     * Only rewrite if existing directive exists at the location we expect, to support:
+     *   a) compilers that do not append a sourcemap directive
+     *   b) situations where we did the math wrong
+     *     Not ideal, but appending our sourcemap *after* a pre-existing sourcemap still overrides, so the end-user is happy.
+     */
+    if (outputText.substr(-sourceMapLengthWithoutPercentEncoding, prefixLength) ===
+        prefix) {
+        return (outputText.slice(0, -sourceMapLengthWithoutPercentEncoding) +
+            sourceMapContent);
+    }
+    // If anyone asks why we're not using URL, the URL equivalent is: `u = new URL('http://d'); u.pathname = "/" + sourcemapFilename; return u.pathname.slice(1);
+    const sourceMapLengthWithPercentEncoding = prefixLength + encodeURI(sourcemapFilename).length;
+    if (outputText.substr(-sourceMapLengthWithPercentEncoding, prefixLength) ===
+        prefix) {
+        return (outputText.slice(0, -sourceMapLengthWithPercentEncoding) +
+            sourceMapContent);
+    }
+    return `${outputText}\n${sourceMapContent}`;
+}
+/**
+ * Update the source map contents for improved output.
+ */
+function updateSourceMap(sourceMapText, fileName) {
+    const sourceMap = JSON.parse(sourceMapText);
+    sourceMap.file = fileName;
+    sourceMap.sources = [fileName];
+    delete sourceMap.sourceRoot;
+    return JSON.stringify(sourceMap);
+}
+/**
+ * Filter diagnostics.
+ */
+function filterDiagnostics(diagnostics, filters) {
+    return diagnostics.filter((d) => filters.every((f) => {
+        var _a;
+        return (!f.appliesToAllFiles &&
+            f.filenamesAbsolute.indexOf((_a = d.file) === null || _a === void 0 ? void 0 : _a.fileName) === -1) ||
+            f.diagnosticsIgnored.indexOf(d.code) === -1;
+    }));
+}
+/**
+ * Get token at file position.
+ *
+ * Reference: https://github.com/microsoft/TypeScript/blob/fcd9334f57d85b73dd66ad2d21c02e84822f4841/src/services/utilities.ts#L705-L731
+ */
+function getTokenAtPosition(ts, sourceFile, position) {
+    let current = sourceFile;
+    outer: while (true) {
+        for (const child of current.getChildren(sourceFile)) {
+            const start = child.getFullStart();
+            if (start > position)
+                break;
+            const end = child.getEnd();
+            if (position <= end) {
+                current = child;
+                continue outer;
+            }
+        }
+        return current;
+    }
+}
+/**
+ * Create an implementation of node's ESM loader hooks.
+ *
+ * This may be useful if you
+ * want to wrap or compose the loader hooks to add additional functionality or
+ * combine with another loader.
+ *
+ * Node changed the hooks API, so there are two possible APIs.  This function
+ * detects your node version and returns the appropriate API.
+ *
+ * @category ESM Loader
+ */
+const createEsmHooks = (tsNodeService) => (__nccwpck_require__(36057)/* .createEsmHooks */ .lT)(tsNodeService);
+exports.createEsmHooks = createEsmHooks;
+//# sourceMappingURL=index.js.map
 
 /***/ }),
 
-/***/ 49198:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
-
-var path = __nccwpck_require__(71017);
-var common = __nccwpck_require__(17673);
-var _ls = __nccwpck_require__(9644);
-
-common.register('find', _find, {});
-
-//@
-//@ ### find(path [, path ...])
-//@ ### find(path_array)
-//@
-//@ Examples:
-//@
-//@ ```javascript
-//@ find('src', 'lib');
-//@ find(['src', 'lib']); // same as above
-//@ find('.').filter(function(file) { return file.match(/\.js$/); });
-//@ ```
-//@
-//@ Returns array of all files (however deep) in the given paths.
-//@
-//@ The main difference from `ls('-R', path)` is that the resulting file names
-//@ include the base directories (e.g., `lib/resources/file1` instead of just `file1`).
-function _find(options, paths) {
-  if (!paths) {
-    common.error('no path specified');
-  } else if (typeof paths === 'string') {
-    paths = [].slice.call(arguments, 1);
-  }
+/***/ 74025:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
-  var list = [];
+"use strict";
 
-  function pushFile(file) {
-    if (process.platform === 'win32') {
-      file = file.replace(/\\/g, '/');
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.createModuleTypeClassifier = void 0;
+const ts_internals_1 = __nccwpck_require__(80301);
+const util_1 = __nccwpck_require__(26239);
+/**
+ * @internal
+ * May receive non-normalized options -- basePath and patterns -- and will normalize them
+ * internally.
+ * However, calls to `classifyModule` must pass pre-normalized paths!
+ */
+function createModuleTypeClassifier(options) {
+    const { patterns, basePath: _basePath } = options;
+    const basePath = _basePath !== undefined
+        ? (0, util_1.normalizeSlashes)(_basePath).replace(/\/$/, '')
+        : undefined;
+    const patternTypePairs = Object.entries(patterns !== null && patterns !== void 0 ? patterns : []).map(([_pattern, type]) => {
+        const pattern = (0, util_1.normalizeSlashes)(_pattern);
+        return { pattern: parsePattern(basePath, pattern), type };
+    });
+    const classifications = {
+        package: {
+            moduleType: 'auto',
+        },
+        cjs: {
+            moduleType: 'cjs',
+        },
+        esm: {
+            moduleType: 'esm',
+        },
+    };
+    const auto = classifications.package;
+    // Passed path must be normalized!
+    function classifyModuleNonCached(path) {
+        const matched = matchPatterns(patternTypePairs, (_) => _.pattern, path);
+        if (matched)
+            return classifications[matched.type];
+        return auto;
     }
-    list.push(file);
-  }
-
-  // why not simply do `ls('-R', paths)`? because the output wouldn't give the base dirs
-  // to get the base dir in the output, we need instead `ls('-R', 'dir/*')` for every directory
-
-  paths.forEach(function (file) {
-    var stat;
-    try {
-      stat = common.statFollowLinks(file);
-    } catch (e) {
-      common.error('no such file or directory: ' + file);
+    const classifyModule = (0, util_1.cachedLookup)(classifyModuleNonCached);
+    function classifyModuleAuto(path) {
+        return auto;
     }
-
-    pushFile(file);
-
-    if (stat.isDirectory()) {
-      _ls({ recursive: true, all: true }, file).forEach(function (subfile) {
-        pushFile(path.join(file, subfile));
-      });
+    return {
+        classifyModuleByModuleTypeOverrides: patternTypePairs.length
+            ? classifyModule
+            : classifyModuleAuto,
+    };
+}
+exports.createModuleTypeClassifier = createModuleTypeClassifier;
+function parsePattern(basePath, patternString) {
+    const pattern = (0, ts_internals_1.getPatternFromSpec)(patternString, basePath);
+    return pattern !== undefined ? new RegExp(pattern) : /(?:)/;
+}
+function matchPatterns(objects, getPattern, candidate) {
+    for (let i = objects.length - 1; i >= 0; i--) {
+        const object = objects[i];
+        const pattern = getPattern(object);
+        if (pattern === null || pattern === void 0 ? void 0 : pattern.test(candidate)) {
+            return object;
+        }
     }
-  });
-
-  return list;
 }
-module.exports = _find;
-
+//# sourceMappingURL=module-type-classifier.js.map
 
 /***/ }),
 
-/***/ 78869:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+/***/ 76652:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
-var common = __nccwpck_require__(17673);
-var fs = __nccwpck_require__(57147);
+"use strict";
 
-common.register('grep', _grep, {
-  globStart: 2, // don't glob-expand the regex
-  canReceivePipe: true,
-  cmdOptions: {
-    'v': 'inverse',
-    'l': 'nameOnly',
-    'i': 'ignoreCase',
-  },
-});
-
-//@
-//@ ### grep([options,] regex_filter, file [, file ...])
-//@ ### grep([options,] regex_filter, file_array)
-//@
-//@ Available options:
-//@
-//@ + `-v`: Invert `regex_filter` (only print non-matching lines).
-//@ + `-l`: Print only filenames of matching files.
-//@ + `-i`: Ignore case.
-//@
-//@ Examples:
-//@
-//@ ```javascript
-//@ grep('-v', 'GLOBAL_VARIABLE', '*.js');
-//@ grep('GLOBAL_VARIABLE', '*.js');
-//@ ```
-//@
-//@ Reads input string from given files and returns a string containing all lines of the
-//@ file that match the given `regex_filter`.
-function _grep(options, regex, files) {
-  // Check if this is coming from a pipe
-  var pipe = common.readFromPipe();
-
-  if (!files && !pipe) common.error('no paths given', 2);
-
-  files = [].slice.call(arguments, 2);
-
-  if (pipe) {
-    files.unshift('-');
-  }
-
-  var grep = [];
-  if (options.ignoreCase) {
-    regex = new RegExp(regex, 'i');
-  }
-  files.forEach(function (file) {
-    if (!fs.existsSync(file) && file !== '-') {
-      common.error('no such file or directory: ' + file, 2, { continue: true });
-      return;
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.classifyModule = void 0;
+const node_internal_modules_cjs_loader_1 = __nccwpck_require__(88232);
+/**
+ * Determine how to emit a module based on tsconfig "module" and package.json "type"
+ *
+ * Supports module=nodenext/node16 with transpileOnly, where we cannot ask the
+ * TS typechecker to tell us if a file is CJS or ESM.
+ *
+ * Return values indicate:
+ * - cjs
+ * - esm
+ * - nodecjs == node-flavored cjs where dynamic imports are *not* transformed into `require()`
+ * - undefined == emit according to tsconfig `module` config, whatever that is
+ * @internal
+ */
+function classifyModule(nativeFilename, isNodeModuleType) {
+    // [MUST_UPDATE_FOR_NEW_FILE_EXTENSIONS]
+    const lastDotIndex = nativeFilename.lastIndexOf('.');
+    const ext = lastDotIndex >= 0 ? nativeFilename.slice(lastDotIndex) : '';
+    switch (ext) {
+        case '.cjs':
+        case '.cts':
+            return isNodeModuleType ? 'nodecjs' : 'cjs';
+        case '.mjs':
+        case '.mts':
+            return isNodeModuleType ? 'nodeesm' : 'esm';
     }
-
-    var contents = file === '-' ? pipe : fs.readFileSync(file, 'utf8');
-    if (options.nameOnly) {
-      if (contents.match(regex)) {
-        grep.push(file);
-      }
-    } else {
-      var lines = contents.split('\n');
-      lines.forEach(function (line) {
-        var matched = line.match(regex);
-        if ((options.inverse && !matched) || (!options.inverse && matched)) {
-          grep.push(line);
-        }
-      });
+    if (isNodeModuleType) {
+        const packageScope = (0, node_internal_modules_cjs_loader_1.readPackageScope)(nativeFilename);
+        if (packageScope && packageScope.data.type === 'module')
+            return 'nodeesm';
+        return 'nodecjs';
     }
-  });
-
-  return grep.join('\n') + '\n';
+    return undefined;
 }
-module.exports = _grep;
-
+exports.classifyModule = classifyModule;
+//# sourceMappingURL=node-module-type-classifier.js.map
 
 /***/ }),
 
-/***/ 41712:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
-
-var common = __nccwpck_require__(17673);
-var fs = __nccwpck_require__(57147);
-
-common.register('head', _head, {
-  canReceivePipe: true,
-  cmdOptions: {
-    'n': 'numLines',
-  },
-});
-
-// Reads |numLines| lines or the entire file, whichever is less.
-function readSomeLines(file, numLines) {
-  var buf = common.buffer();
-  var bufLength = buf.length;
-  var bytesRead = bufLength;
-  var pos = 0;
+/***/ 8371:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
-  var fdr = fs.openSync(file, 'r');
-  var numLinesRead = 0;
-  var ret = '';
-  while (bytesRead === bufLength && numLinesRead < numLines) {
-    bytesRead = fs.readSync(fdr, buf, 0, bufLength, pos);
-    var bufStr = buf.toString('utf8', 0, bytesRead);
-    numLinesRead += bufStr.split('\n').length - 1;
-    ret += bufStr;
-    pos += bytesRead;
-  }
+"use strict";
 
-  fs.closeSync(fdr);
-  return ret;
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.setupContext = exports.createEvalAwarePartialHost = exports.EvalState = exports.createRepl = exports.REPL_NAME = exports.REPL_FILENAME = exports.STDIN_NAME = exports.STDIN_FILENAME = exports.EVAL_NAME = exports.EVAL_FILENAME = void 0;
+const os_1 = __nccwpck_require__(22037);
+const path_1 = __nccwpck_require__(71017);
+const repl_1 = __nccwpck_require__(38102);
+const vm_1 = __nccwpck_require__(26144);
+const index_1 = __nccwpck_require__(94828);
+const fs_1 = __nccwpck_require__(57147);
+const console_1 = __nccwpck_require__(96206);
+const assert = __nccwpck_require__(39491);
+const module_1 = __nccwpck_require__(98188);
+// Lazy-loaded.
+let _processTopLevelAwait;
+function getProcessTopLevelAwait() {
+    if (_processTopLevelAwait === undefined) {
+        ({
+            processTopLevelAwait: _processTopLevelAwait,
+        } = __nccwpck_require__(18088));
+    }
+    return _processTopLevelAwait;
 }
-
-//@
-//@ ### head([{'-n': \},] file [, file ...])
-//@ ### head([{'-n': \},] file_array)
-//@
-//@ Available options:
-//@
-//@ + `-n `: Show the first `` lines of the files
-//@
-//@ Examples:
-//@
-//@ ```javascript
-//@ var str = head({'-n': 1}, 'file*.txt');
-//@ var str = head('file1', 'file2');
-//@ var str = head(['file1', 'file2']); // same as above
-//@ ```
-//@
-//@ Read the start of a file.
-function _head(options, files) {
-  var head = [];
-  var pipe = common.readFromPipe();
-
-  if (!files && !pipe) common.error('no paths given');
-
-  var idx = 1;
-  if (options.numLines === true) {
-    idx = 2;
-    options.numLines = Number(arguments[1]);
-  } else if (options.numLines === false) {
-    options.numLines = 10;
-  }
-  files = [].slice.call(arguments, idx);
-
-  if (pipe) {
-    files.unshift('-');
-  }
-
-  var shouldAppendNewline = false;
-  files.forEach(function (file) {
-    if (file !== '-') {
-      if (!fs.existsSync(file)) {
-        common.error('no such file or directory: ' + file, { continue: true });
-        return;
-      } else if (common.statFollowLinks(file).isDirectory()) {
-        common.error("error reading '" + file + "': Is a directory", {
-          continue: true,
+let diff;
+function getDiffLines() {
+    if (diff === undefined) {
+        diff = __nccwpck_require__(95214);
+    }
+    return diff.diffLines;
+}
+/** @internal */
+exports.EVAL_FILENAME = `[eval].ts`;
+/** @internal */
+exports.EVAL_NAME = `[eval]`;
+/** @internal */
+exports.STDIN_FILENAME = `[stdin].ts`;
+/** @internal */
+exports.STDIN_NAME = `[stdin]`;
+/** @internal */
+exports.REPL_FILENAME = '.ts';
+/** @internal */
+exports.REPL_NAME = '';
+/**
+ * Create a ts-node REPL instance.
+ *
+ * Pay close attention to the example below.  Today, the API requires a few lines
+ * of boilerplate to correctly bind the `ReplService` to the ts-node `Service` and
+ * vice-versa.
+ *
+ * Usage example:
+ *
+ *     const repl = tsNode.createRepl();
+ *     const service = tsNode.create({...repl.evalAwarePartialHost});
+ *     repl.setService(service);
+ *     repl.start();
+ *
+ * @category REPL
+ */
+function createRepl(options = {}) {
+    var _a, _b, _c, _d, _e;
+    const { ignoreDiagnosticsThatAreAnnoyingInInteractiveRepl = true } = options;
+    let service = options.service;
+    let nodeReplServer;
+    // If `useGlobal` is not true, then REPL creates a context when started.
+    // This stores a reference to it or to `global`, whichever is used, after REPL has started.
+    let context;
+    const state = (_a = options.state) !== null && _a !== void 0 ? _a : new EvalState((0, path_1.join)(process.cwd(), exports.REPL_FILENAME));
+    const evalAwarePartialHost = createEvalAwarePartialHost(state, options.composeWithEvalAwarePartialHost);
+    const stdin = (_b = options.stdin) !== null && _b !== void 0 ? _b : process.stdin;
+    const stdout = (_c = options.stdout) !== null && _c !== void 0 ? _c : process.stdout;
+    const stderr = (_d = options.stderr) !== null && _d !== void 0 ? _d : process.stderr;
+    const _console = stdout === process.stdout && stderr === process.stderr
+        ? console
+        : new console_1.Console(stdout, stderr);
+    const replService = {
+        state: (_e = options.state) !== null && _e !== void 0 ? _e : new EvalState((0, path_1.join)(process.cwd(), exports.EVAL_FILENAME)),
+        setService,
+        evalCode,
+        evalCodeInternal,
+        nodeEval,
+        evalAwarePartialHost,
+        start,
+        startInternal,
+        stdin,
+        stdout,
+        stderr,
+        console: _console,
+    };
+    return replService;
+    function setService(_service) {
+        service = _service;
+        if (ignoreDiagnosticsThatAreAnnoyingInInteractiveRepl) {
+            service.addDiagnosticFilter({
+                appliesToAllFiles: false,
+                filenamesAbsolute: [state.path],
+                diagnosticsIgnored: [
+                    2393,
+                    6133,
+                    7027,
+                    ...(service.shouldReplAwait ? topLevelAwaitDiagnosticCodes : []),
+                ],
+            });
+        }
+    }
+    function evalCode(code) {
+        const result = appendCompileAndEvalInput({
+            service: service,
+            state,
+            input: code,
+            context,
+            overrideIsCompletion: false,
         });
-        return;
-      }
+        assert(result.containsTopLevelAwait === false);
+        return result.value;
     }
-
-    var contents;
-    if (file === '-') {
-      contents = pipe;
-    } else if (options.numLines < 0) {
-      contents = fs.readFileSync(file, 'utf8');
-    } else {
-      contents = readSomeLines(file, options.numLines);
+    function evalCodeInternal(options) {
+        const { code, enableTopLevelAwait, context } = options;
+        return appendCompileAndEvalInput({
+            service: service,
+            state,
+            input: code,
+            enableTopLevelAwait,
+            context,
+        });
     }
-
-    var lines = contents.split('\n');
-    var hasTrailingNewline = (lines[lines.length - 1] === '');
-    if (hasTrailingNewline) {
-      lines.pop();
+    function nodeEval(code, context, _filename, callback) {
+        // TODO: Figure out how to handle completion here.
+        if (code === '.scope') {
+            callback(null);
+            return;
+        }
+        try {
+            const evalResult = evalCodeInternal({
+                code,
+                enableTopLevelAwait: true,
+                context,
+            });
+            if (evalResult.containsTopLevelAwait) {
+                (async () => {
+                    try {
+                        callback(null, await evalResult.valuePromise);
+                    }
+                    catch (promiseError) {
+                        handleError(promiseError);
+                    }
+                })();
+            }
+            else {
+                callback(null, evalResult.value);
+            }
+        }
+        catch (error) {
+            handleError(error);
+        }
+        // Log TSErrors, check if they're recoverable, log helpful hints for certain
+        // well-known errors, and invoke `callback()`
+        // TODO should evalCode API get the same error-handling benefits?
+        function handleError(error) {
+            var _a, _b;
+            // Don't show TLA hint if the user explicitly disabled repl top level await
+            const canLogTopLevelAwaitHint = service.options.experimentalReplAwait !== false &&
+                !service.shouldReplAwait;
+            if (error instanceof index_1.TSError) {
+                // Support recoverable compilations using >= node 6.
+                if (repl_1.Recoverable && isRecoverable(error)) {
+                    callback(new repl_1.Recoverable(error));
+                    return;
+                }
+                else {
+                    _console.error(error);
+                    if (canLogTopLevelAwaitHint &&
+                        error.diagnosticCodes.some((dC) => topLevelAwaitDiagnosticCodes.includes(dC))) {
+                        _console.error(getTopLevelAwaitHint());
+                    }
+                    callback(null);
+                }
+            }
+            else {
+                let _error = error;
+                if (canLogTopLevelAwaitHint &&
+                    _error instanceof SyntaxError &&
+                    ((_a = _error.message) === null || _a === void 0 ? void 0 : _a.includes('await is only valid'))) {
+                    try {
+                        // Only way I know to make our hint appear after the error
+                        _error.message += `\n\n${getTopLevelAwaitHint()}`;
+                        _error.stack = (_b = _error.stack) === null || _b === void 0 ? void 0 : _b.replace(/(SyntaxError:.*)/, (_, $1) => `${$1}\n\n${getTopLevelAwaitHint()}`);
+                    }
+                    catch { }
+                }
+                callback(_error);
+            }
+        }
+        function getTopLevelAwaitHint() {
+            return `Hint: REPL top-level await requires TypeScript version 3.8 or higher and target ES2018 or higher. You are using TypeScript ${service.ts.version} and target ${service.ts.ScriptTarget[service.config.options.target]}.`;
+        }
     }
-    shouldAppendNewline = (hasTrailingNewline || options.numLines < lines.length);
-
-    head = head.concat(lines.slice(0, options.numLines));
-  });
-
-  if (shouldAppendNewline) {
-    head.push(''); // to add a trailing newline once we join
-  }
-  return head.join('\n');
-}
-module.exports = _head;
-
-
-/***/ }),
-
-/***/ 76786:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
-
-var fs = __nccwpck_require__(57147);
-var path = __nccwpck_require__(71017);
-var common = __nccwpck_require__(17673);
-
-common.register('ln', _ln, {
-  cmdOptions: {
-    's': 'symlink',
-    'f': 'force',
-  },
-});
-
-//@
-//@ ### ln([options,] source, dest)
-//@
-//@ Available options:
-//@
-//@ + `-s`: symlink
-//@ + `-f`: force
-//@
-//@ Examples:
-//@
-//@ ```javascript
-//@ ln('file', 'newlink');
-//@ ln('-sf', 'file', 'existing');
-//@ ```
-//@
-//@ Links `source` to `dest`. Use `-f` to force the link, should `dest` already exist.
-function _ln(options, source, dest) {
-  if (!source || !dest) {
-    common.error('Missing  and/or ');
-  }
-
-  source = String(source);
-  var sourcePath = path.normalize(source).replace(RegExp(path.sep + '$'), '');
-  var isAbsolute = (path.resolve(source) === sourcePath);
-  dest = path.resolve(process.cwd(), String(dest));
-
-  if (fs.existsSync(dest)) {
-    if (!options.force) {
-      common.error('Destination file exists', { continue: true });
+    // Note: `code` argument is deprecated
+    function start(code) {
+        startInternal({ code });
     }
-
-    fs.unlinkSync(dest);
-  }
-
-  if (options.symlink) {
-    var isWindows = process.platform === 'win32';
-    var linkType = isWindows ? 'file' : null;
-    var resolvedSourcePath = isAbsolute ? sourcePath : path.resolve(process.cwd(), path.dirname(dest), source);
-    if (!fs.existsSync(resolvedSourcePath)) {
-      common.error('Source file does not exist', { continue: true });
-    } else if (isWindows && common.statFollowLinks(resolvedSourcePath).isDirectory()) {
-      linkType = 'junction';
+    // Note: `code` argument is deprecated
+    function startInternal(options) {
+        const { code, forceToBeModule = true, ...optionsOverride } = options !== null && options !== void 0 ? options : {};
+        // TODO assert that `service` is set; remove all `service!` non-null assertions
+        // Eval incoming code before the REPL starts.
+        // Note: deprecated
+        if (code) {
+            try {
+                evalCode(`${code}\n`);
+            }
+            catch (err) {
+                _console.error(err);
+                // Note: should not be killing the process here, but this codepath is deprecated anyway
+                process.exit(1);
+            }
+        }
+        // In case the typescript compiler hasn't compiled anything yet,
+        // make it run though compilation at least one time before
+        // the REPL starts for a snappier user experience on startup.
+        service === null || service === void 0 ? void 0 : service.compile('', state.path);
+        const repl = (0, repl_1.start)({
+            prompt: '> ',
+            input: replService.stdin,
+            output: replService.stdout,
+            // Mimicking node's REPL implementation: https://github.com/nodejs/node/blob/168b22ba073ee1cbf8d0bcb4ded7ff3099335d04/lib/internal/repl.js#L28-L30
+            terminal: stdout.isTTY &&
+                !parseInt(index_1.env.NODE_NO_READLINE, 10),
+            eval: nodeEval,
+            useGlobal: true,
+            ...optionsOverride,
+        });
+        nodeReplServer = repl;
+        context = repl.context;
+        // Bookmark the point where we should reset the REPL state.
+        const resetEval = appendToEvalState(state, '');
+        function reset() {
+            resetEval();
+            // Hard fix for TypeScript forcing `Object.defineProperty(exports, ...)`.
+            runInContext('exports = module.exports', state.path, context);
+            if (forceToBeModule) {
+                state.input += 'export {};void 0;\n';
+            }
+            // Declare node builtins.
+            // Skip the same builtins as `addBuiltinLibsToObject`:
+            //   those starting with _
+            //   those containing /
+            //   those that already exist as globals
+            // Intentionally suppress type errors in case @types/node does not declare any of them, and because
+            // `declare import` is technically invalid syntax.
+            // Avoid this when in transpileOnly, because third-party transpilers may not handle `declare import`.
+            if (!(service === null || service === void 0 ? void 0 : service.transpileOnly)) {
+                state.input += `// @ts-ignore\n${module_1.builtinModules
+                    .filter((name) => !name.startsWith('_') &&
+                    !name.includes('/') &&
+                    !['console', 'module', 'process'].includes(name))
+                    .map((name) => `declare import ${name} = require('${name}')`)
+                    .join(';')}\n`;
+            }
+        }
+        reset();
+        repl.on('reset', reset);
+        repl.defineCommand('type', {
+            help: 'Check the type of a TypeScript identifier',
+            action: function (identifier) {
+                if (!identifier) {
+                    repl.displayPrompt();
+                    return;
+                }
+                const undo = appendToEvalState(state, identifier);
+                const { name, comment } = service.getTypeInfo(state.input, state.path, state.input.length);
+                undo();
+                if (name)
+                    repl.outputStream.write(`${name}\n`);
+                if (comment)
+                    repl.outputStream.write(`${comment}\n`);
+                repl.displayPrompt();
+            },
+        });
+        // Set up REPL history when available natively via node.js >= 11.
+        if (repl.setupHistory) {
+            const historyPath = index_1.env.TS_NODE_HISTORY || (0, path_1.join)((0, os_1.homedir)(), '.ts_node_repl_history');
+            repl.setupHistory(historyPath, (err) => {
+                if (!err)
+                    return;
+                _console.error(err);
+                process.exit(1);
+            });
+        }
+        return repl;
     }
-
-    try {
-      fs.symlinkSync(linkType === 'junction' ? resolvedSourcePath : source, dest, linkType);
-    } catch (err) {
-      common.error(err.message);
+}
+exports.createRepl = createRepl;
+/**
+ * Eval state management. Stores virtual `[eval].ts` file
+ */
+class EvalState {
+    constructor(path) {
+        this.path = path;
+        /** @internal */
+        this.input = '';
+        /** @internal */
+        this.output = '';
+        /** @internal */
+        this.version = 0;
+        /** @internal */
+        this.lines = 0;
     }
-  } else {
-    if (!fs.existsSync(source)) {
-      common.error('Source file does not exist', { continue: true });
+}
+exports.EvalState = EvalState;
+function createEvalAwarePartialHost(state, composeWith) {
+    function readFile(path) {
+        if (path === state.path)
+            return state.input;
+        if (composeWith === null || composeWith === void 0 ? void 0 : composeWith.readFile)
+            return composeWith.readFile(path);
+        try {
+            return (0, fs_1.readFileSync)(path, 'utf8');
+        }
+        catch (err) {
+            /* Ignore. */
+        }
     }
-    try {
-      fs.linkSync(source, dest);
-    } catch (err) {
-      common.error(err.message);
+    function fileExists(path) {
+        if (path === state.path)
+            return true;
+        if (composeWith === null || composeWith === void 0 ? void 0 : composeWith.fileExists)
+            return composeWith.fileExists(path);
+        try {
+            const stats = (0, fs_1.statSync)(path);
+            return stats.isFile() || stats.isFIFO();
+        }
+        catch (err) {
+            return false;
+        }
     }
-  }
-  return '';
+    return { readFile, fileExists };
 }
-module.exports = _ln;
-
-
-/***/ }),
-
-/***/ 9644:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
-
-var path = __nccwpck_require__(71017);
-var fs = __nccwpck_require__(57147);
-var common = __nccwpck_require__(17673);
-var glob = __nccwpck_require__(20557);
-
-var globPatternRecursive = path.sep + '**';
-
-common.register('ls', _ls, {
-  cmdOptions: {
-    'R': 'recursive',
-    'A': 'all',
-    'L': 'link',
-    'a': 'all_deprecated',
-    'd': 'directory',
-    'l': 'long',
-  },
-});
-
-//@
-//@ ### ls([options,] [path, ...])
-//@ ### ls([options,] path_array)
-//@
-//@ Available options:
-//@
-//@ + `-R`: recursive
-//@ + `-A`: all files (include files beginning with `.`, except for `.` and `..`)
-//@ + `-L`: follow symlinks
-//@ + `-d`: list directories themselves, not their contents
-//@ + `-l`: list objects representing each file, each with fields containing `ls
-//@         -l` output fields. See
-//@         [`fs.Stats`](https://nodejs.org/api/fs.html#fs_class_fs_stats)
-//@         for more info
-//@
-//@ Examples:
-//@
-//@ ```javascript
-//@ ls('projs/*.js');
-//@ ls('-R', '/users/me', '/tmp');
-//@ ls('-R', ['/users/me', '/tmp']); // same as above
-//@ ls('-l', 'file.txt'); // { name: 'file.txt', mode: 33188, nlink: 1, ...}
-//@ ```
-//@
-//@ Returns array of files in the given `path`, or files in
-//@ the current directory if no `path` is  provided.
-function _ls(options, paths) {
-  if (options.all_deprecated) {
-    // We won't support the -a option as it's hard to image why it's useful
-    // (it includes '.' and '..' in addition to '.*' files)
-    // For backwards compatibility we'll dump a deprecated message and proceed as before
-    common.log('ls: Option -a is deprecated. Use -A instead');
-    options.all = true;
-  }
-
-  if (!paths) {
-    paths = ['.'];
-  } else {
-    paths = [].slice.call(arguments, 1);
-  }
-
-  var list = [];
-
-  function pushFile(abs, relName, stat) {
-    if (process.platform === 'win32') {
-      relName = relName.replace(/\\/g, '/');
+exports.createEvalAwarePartialHost = createEvalAwarePartialHost;
+const sourcemapCommentRe = /\/\/# ?sourceMappingURL=\S+[\s\r\n]*$/;
+/**
+ * Evaluate the code snippet.
+ *
+ * Append it to virtual .ts file, compile, handle compiler errors, compute a diff of the JS, and eval any code that
+ * appears as "added" in the diff.
+ */
+function appendCompileAndEvalInput(options) {
+    const { service, state, wrappedErr, enableTopLevelAwait = false, context, overrideIsCompletion, } = options;
+    let { input } = options;
+    // It's confusing for `{ a: 1 }` to be interpreted as a block statement
+    // rather than an object literal. So, we first try to wrap it in
+    // parentheses, so that it will be interpreted as an expression.
+    // Based on https://github.com/nodejs/node/blob/c2e6822153bad023ab7ebd30a6117dcc049e475c/lib/repl.js#L413-L422
+    let wrappedCmd = false;
+    if (!wrappedErr && /^\s*{/.test(input) && !/;\s*$/.test(input)) {
+        input = `(${input.trim()})\n`;
+        wrappedCmd = true;
     }
-    if (options.long) {
-      stat = stat || (options.link ? common.statFollowLinks(abs) : common.statNoFollowLinks(abs));
-      list.push(addLsAttributes(relName, stat));
-    } else {
-      // list.push(path.relative(rel || '.', file));
-      list.push(relName);
+    const lines = state.lines;
+    const isCompletion = overrideIsCompletion !== null && overrideIsCompletion !== void 0 ? overrideIsCompletion : !/\n$/.test(input);
+    const undo = appendToEvalState(state, input);
+    let output;
+    // Based on https://github.com/nodejs/node/blob/92573721c7cff104ccb82b6ed3e8aa69c4b27510/lib/repl.js#L457-L461
+    function adjustUseStrict(code) {
+        // "void 0" keeps the repl from returning "use strict" as the result
+        // value for statements and declarations that don't return a value.
+        return code.replace(/^"use strict";/, '"use strict"; void 0;');
     }
-  }
-
-  paths.forEach(function (p) {
-    var stat;
-
     try {
-      stat = options.link ? common.statFollowLinks(p) : common.statNoFollowLinks(p);
-      // follow links to directories by default
-      if (stat.isSymbolicLink()) {
-        /* istanbul ignore next */
-        // workaround for https://github.com/shelljs/shelljs/issues/795
-        // codecov seems to have a bug that miscalculate this block as uncovered.
-        // but according to nyc report this block does get covered.
-        try {
-          var _stat = common.statFollowLinks(p);
-          if (_stat.isDirectory()) {
-            stat = _stat;
-          }
-        } catch (_) {} // bad symlink, treat it like a file
-      }
-    } catch (e) {
-      common.error('no such file or directory: ' + p, 2, { continue: true });
-      return;
+        output = service.compile(state.input, state.path, -lines);
     }
-
-    // If the stat succeeded
-    if (stat.isDirectory() && !options.directory) {
-      if (options.recursive) {
-        // use glob, because it's simple
-        glob.sync(p + globPatternRecursive, { dot: options.all, follow: options.link })
-          .forEach(function (item) {
-            // Glob pattern returns the directory itself and needs to be filtered out.
-            if (path.relative(p, item)) {
-              pushFile(item, path.relative(p, item));
+    catch (err) {
+        undo();
+        if (wrappedCmd) {
+            if (err instanceof index_1.TSError && err.diagnosticCodes[0] === 2339) {
+                // Ensure consistent and more sane behavior between { a: 1 }['b'] and ({ a: 1 }['b'])
+                throw err;
             }
-          });
-      } else if (options.all) {
-        // use fs.readdirSync, because it's fast
-        fs.readdirSync(p).forEach(function (item) {
-          pushFile(path.join(p, item), item);
-        });
-      } else {
-        // use fs.readdirSync and then filter out secret files
-        fs.readdirSync(p).forEach(function (item) {
-          if (item[0] !== '.') {
-            pushFile(path.join(p, item), item);
-          }
+            // Unwrap and try again
+            return appendCompileAndEvalInput({
+                ...options,
+                wrappedErr: err,
+            });
+        }
+        if (wrappedErr)
+            throw wrappedErr;
+        throw err;
+    }
+    output = adjustUseStrict(output);
+    // Note: REPL does not respect sourcemaps!
+    // To properly do that, we'd need to prefix the code we eval -- which comes
+    // from `diffLines` -- with newlines so that it's at the proper line numbers.
+    // Then we'd need to ensure each bit of eval-ed code, if there are multiples,
+    // has the sourcemap appended to it.
+    // We might also need to integrate with our sourcemap hooks' cache; I'm not sure.
+    const outputWithoutSourcemapComment = output.replace(sourcemapCommentRe, '');
+    const oldOutputWithoutSourcemapComment = state.output.replace(sourcemapCommentRe, '');
+    // Use `diff` to check for new JavaScript to execute.
+    const changes = getDiffLines()(oldOutputWithoutSourcemapComment, outputWithoutSourcemapComment);
+    if (isCompletion) {
+        undo();
+    }
+    else {
+        state.output = output;
+        // Insert a semicolon to make sure that the code doesn't interact with the next line,
+        // for example to prevent `2\n+ 2` from producing 4.
+        // This is safe since the output will not change since we can only get here with successful inputs,
+        // and adding a semicolon to the end of a successful input won't ever change the output.
+        state.input = state.input.replace(/([^\n\s])([\n\s]*)$/, (all, lastChar, whitespace) => {
+            if (lastChar !== ';')
+                return `${lastChar};${whitespace}`;
+            return all;
         });
-      }
-    } else {
-      pushFile(p, p, stat);
     }
-  });
-
-  // Add methods, to make this more compatible with ShellStrings
-  return list;
+    let commands = [];
+    let containsTopLevelAwait = false;
+    // Build a list of "commands": bits of JS code in the diff that must be executed.
+    for (const change of changes) {
+        if (change.added) {
+            if (enableTopLevelAwait &&
+                service.shouldReplAwait &&
+                change.value.indexOf('await') > -1) {
+                const processTopLevelAwait = getProcessTopLevelAwait();
+                // Newline prevents comments to mess with wrapper
+                const wrappedResult = processTopLevelAwait(change.value + '\n');
+                if (wrappedResult !== null) {
+                    containsTopLevelAwait = true;
+                    commands.push({
+                        mustAwait: true,
+                        execCommand: () => runInContext(wrappedResult, state.path, context),
+                    });
+                    continue;
+                }
+            }
+            commands.push({
+                execCommand: () => runInContext(change.value, state.path, context),
+            });
+        }
+    }
+    // Execute all commands asynchronously if necessary, returning the result or a
+    // promise of the result.
+    if (containsTopLevelAwait) {
+        return {
+            containsTopLevelAwait,
+            valuePromise: (async () => {
+                let value;
+                for (const command of commands) {
+                    const r = command.execCommand();
+                    value = command.mustAwait ? await r : r;
+                }
+                return value;
+            })(),
+        };
+    }
+    else {
+        return {
+            containsTopLevelAwait: false,
+            value: commands.reduce((_, c) => c.execCommand(), undefined),
+        };
+    }
 }
-
-function addLsAttributes(pathName, stats) {
-  // Note: this object will contain more information than .toString() returns
-  stats.name = pathName;
-  stats.toString = function () {
-    // Return a string resembling unix's `ls -l` format
-    return [this.mode, this.nlink, this.uid, this.gid, this.size, this.mtime, this.name].join(' ');
-  };
-  return stats;
+/**
+ * Low-level execution of JS code in context
+ */
+function runInContext(code, filename, context) {
+    const script = new vm_1.Script(code, { filename });
+    if (context === undefined || context === global) {
+        return script.runInThisContext();
+    }
+    else {
+        return script.runInContext(context);
+    }
 }
-
-module.exports = _ls;
-
-
-/***/ }),
-
-/***/ 69494:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
-
-var common = __nccwpck_require__(17673);
-var fs = __nccwpck_require__(57147);
-var path = __nccwpck_require__(71017);
-
-common.register('mkdir', _mkdir, {
-  cmdOptions: {
-    'p': 'fullpath',
-  },
-});
-
-// Recursively creates `dir`
-function mkdirSyncRecursive(dir) {
-  var baseDir = path.dirname(dir);
-
-  // Prevents some potential problems arising from malformed UNCs or
-  // insufficient permissions.
-  /* istanbul ignore next */
-  if (baseDir === dir) {
-    common.error('dirname() failed: [' + dir + ']');
-  }
-
-  // Base dir exists, no recursion necessary
-  if (fs.existsSync(baseDir)) {
-    fs.mkdirSync(dir, parseInt('0777', 8));
-    return;
-  }
-
-  // Base dir does not exist, go recursive
-  mkdirSyncRecursive(baseDir);
-
-  // Base dir created, can create dir
-  fs.mkdirSync(dir, parseInt('0777', 8));
+/**
+ * Append to the eval instance and return an undo function.
+ */
+function appendToEvalState(state, input) {
+    const undoInput = state.input;
+    const undoVersion = state.version;
+    const undoOutput = state.output;
+    const undoLines = state.lines;
+    state.input += input;
+    state.lines += lineCount(input);
+    state.version++;
+    return function () {
+        state.input = undoInput;
+        state.output = undoOutput;
+        state.version = undoVersion;
+        state.lines = undoLines;
+    };
 }
+/**
+ * Count the number of lines.
+ */
+function lineCount(value) {
+    let count = 0;
+    for (const char of value) {
+        if (char === '\n') {
+            count++;
+        }
+    }
+    return count;
+}
+/**
+ * TS diagnostic codes which are recoverable, meaning that the user likely entered an incomplete line of code
+ * and should be prompted for the next.  For example, starting a multi-line for() loop and not finishing it.
+ * null value means code is always recoverable.  `Set` means code is only recoverable when occurring alongside at least one
+ * of the other codes.
+ */
+const RECOVERY_CODES = new Map([
+    [1003, null],
+    [1005, null],
+    [1109, null],
+    [1126, null],
+    [
+        1136,
+        new Set([1005]), // happens when typing out an object literal or block scope across multiple lines: '{ foo: 123,'
+    ],
+    [1160, null],
+    [1161, null],
+    [2355, null],
+    [2391, null],
+    [
+        7010,
+        new Set([1005]), // happens when fn signature spread across multiple lines: 'function a(\nb: any\n) {'
+    ],
+]);
+/**
+ * Diagnostic codes raised when using top-level await.
+ * These are suppressed when top-level await is enabled.
+ * When it is *not* enabled, these trigger a helpful hint about enabling top-level await.
+ */
+const topLevelAwaitDiagnosticCodes = [
+    1375,
+    1378,
+    1431,
+    1432, // Top-level 'for await' loops are only allowed when the 'module' option is set to 'esnext' or 'system', and the 'target' option is set to 'es2017' or higher.
+];
+/**
+ * Check if a function can recover gracefully.
+ */
+function isRecoverable(error) {
+    return error.diagnosticCodes.every((code) => {
+        const deps = RECOVERY_CODES.get(code);
+        return (deps === null ||
+            (deps && error.diagnosticCodes.some((code) => deps.has(code))));
+    });
+}
+/**
+ * @internal
+ * Set properties on `context` before eval-ing [stdin] or [eval] input.
+ */
+function setupContext(context, module, filenameAndDirname) {
+    if (filenameAndDirname) {
+        context.__dirname = '.';
+        context.__filename = `[${filenameAndDirname}]`;
+    }
+    context.module = module;
+    context.exports = module.exports;
+    context.require = __nccwpck_require__(3833).bind(module);
+}
+exports.setupContext = setupContext;
+//# sourceMappingURL=repl.js.map
 
-//@
-//@ ### mkdir([options,] dir [, dir ...])
-//@ ### mkdir([options,] dir_array)
-//@
-//@ Available options:
-//@
-//@ + `-p`: full path (and create intermediate directories, if necessary)
-//@
-//@ Examples:
-//@
-//@ ```javascript
-//@ mkdir('-p', '/tmp/a/b/c/d', '/tmp/e/f/g');
-//@ mkdir('-p', ['/tmp/a/b/c/d', '/tmp/e/f/g']); // same as above
-//@ ```
-//@
-//@ Creates directories.
-function _mkdir(options, dirs) {
-  if (!dirs) common.error('no paths given');
-
-  if (typeof dirs === 'string') {
-    dirs = [].slice.call(arguments, 1);
-  }
-  // if it's array leave it as it is
+/***/ }),
 
-  dirs.forEach(function (dir) {
-    try {
-      var stat = common.statNoFollowLinks(dir);
-      if (!options.fullpath) {
-        common.error('path already exists: ' + dir, { continue: true });
-      } else if (stat.isFile()) {
-        common.error('cannot create directory ' + dir + ': File exists', { continue: true });
-      }
-      return; // skip dir
-    } catch (e) {
-      // do nothing
-    }
+/***/ 83638:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
-    // Base dir does not exist, and no -p option given
-    var baseDir = path.dirname(dir);
-    if (!fs.existsSync(baseDir) && !options.fullpath) {
-      common.error('no such file or directory: ' + baseDir, { continue: true });
-      return; // skip dir
-    }
+"use strict";
 
-    try {
-      if (options.fullpath) {
-        mkdirSyncRecursive(path.resolve(dir));
-      } else {
-        fs.mkdirSync(dir, parseInt('0777', 8));
-      }
-    } catch (e) {
-      var reason;
-      if (e.code === 'EACCES') {
-        reason = 'Permission denied';
-      } else if (e.code === 'ENOTDIR' || e.code === 'ENOENT') {
-        reason = 'Not a directory';
-      } else {
-        /* istanbul ignore next */
-        throw e;
-      }
-      common.error('cannot create directory ' + dir + ': ' + reason, { continue: true });
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.createResolverFunctions = void 0;
+const path_1 = __nccwpck_require__(71017);
+/**
+ * @internal
+ * In a factory because these are shared across both CompilerHost and LanguageService codepaths
+ */
+function createResolverFunctions(kwargs) {
+    const { host, ts, config, cwd, getCanonicalFileName, projectLocalResolveHelper, options, extensions, } = kwargs;
+    const moduleResolutionCache = ts.createModuleResolutionCache(cwd, getCanonicalFileName, config.options);
+    const knownInternalFilenames = new Set();
+    /** "Buckets" (module directories) whose contents should be marked "internal" */
+    const internalBuckets = new Set();
+    // Get bucket for a source filename.  Bucket is the containing `./node_modules/*/` directory
+    // For '/project/node_modules/foo/node_modules/bar/lib/index.js' bucket is '/project/node_modules/foo/node_modules/bar/'
+    // For '/project/node_modules/foo/node_modules/@scope/bar/lib/index.js' bucket is '/project/node_modules/foo/node_modules/@scope/bar/'
+    const moduleBucketRe = /.*\/node_modules\/(?:@[^\/]+\/)?[^\/]+\//;
+    function getModuleBucket(filename) {
+        const find = moduleBucketRe.exec(filename);
+        if (find)
+            return find[0];
+        return '';
     }
-  });
-  return '';
-} // mkdir
-module.exports = _mkdir;
-
+    // Mark that this file and all siblings in its bucket should be "internal"
+    function markBucketOfFilenameInternal(filename) {
+        internalBuckets.add(getModuleBucket(filename));
+    }
+    function isFileInInternalBucket(filename) {
+        return internalBuckets.has(getModuleBucket(filename));
+    }
+    function isFileKnownToBeInternal(filename) {
+        return knownInternalFilenames.has(filename);
+    }
+    /**
+     * If we need to emit JS for a file, force TS to consider it non-external
+     */
+    const fixupResolvedModule = (resolvedModule) => {
+        const { resolvedFileName } = resolvedModule;
+        if (resolvedFileName === undefined)
+            return;
+        // [MUST_UPDATE_FOR_NEW_FILE_EXTENSIONS]
+        // .ts,.mts,.cts is always switched to internal
+        // .js is switched on-demand
+        if (resolvedModule.isExternalLibraryImport &&
+            ((resolvedFileName.endsWith('.ts') &&
+                !resolvedFileName.endsWith('.d.ts')) ||
+                (resolvedFileName.endsWith('.cts') &&
+                    !resolvedFileName.endsWith('.d.cts')) ||
+                (resolvedFileName.endsWith('.mts') &&
+                    !resolvedFileName.endsWith('.d.mts')) ||
+                isFileKnownToBeInternal(resolvedFileName) ||
+                isFileInInternalBucket(resolvedFileName))) {
+            resolvedModule.isExternalLibraryImport = false;
+        }
+        if (!resolvedModule.isExternalLibraryImport) {
+            knownInternalFilenames.add(resolvedFileName);
+        }
+    };
+    /*
+     * NOTE:
+     * Older ts versions do not pass `redirectedReference` nor `options`.
+     * We must pass `redirectedReference` to newer ts versions, but cannot rely on `options`, hence the weird argument name
+     */
+    const resolveModuleNames = (moduleNames, containingFile, reusedNames, redirectedReference, optionsOnlyWithNewerTsVersions, containingSourceFile) => {
+        return moduleNames.map((moduleName, i) => {
+            var _a, _b;
+            const mode = containingSourceFile
+                ? (_b = (_a = ts).getModeForResolutionAtIndex) === null || _b === void 0 ? void 0 : _b.call(_a, containingSourceFile, i)
+                : undefined;
+            let { resolvedModule } = ts.resolveModuleName(moduleName, containingFile, config.options, host, moduleResolutionCache, redirectedReference, mode);
+            if (!resolvedModule && options.experimentalTsImportSpecifiers) {
+                const lastDotIndex = moduleName.lastIndexOf('.');
+                const ext = lastDotIndex >= 0 ? moduleName.slice(lastDotIndex) : '';
+                if (ext) {
+                    const replacements = extensions.tsResolverEquivalents.get(ext);
+                    for (const replacementExt of replacements !== null && replacements !== void 0 ? replacements : []) {
+                        ({ resolvedModule } = ts.resolveModuleName(moduleName.slice(0, -ext.length) + replacementExt, containingFile, config.options, host, moduleResolutionCache, redirectedReference, mode));
+                        if (resolvedModule)
+                            break;
+                    }
+                }
+            }
+            if (resolvedModule) {
+                fixupResolvedModule(resolvedModule);
+            }
+            return resolvedModule;
+        });
+    };
+    // language service never calls this, but TS docs recommend that we implement it
+    const getResolvedModuleWithFailedLookupLocationsFromCache = (moduleName, containingFile, resolutionMode) => {
+        const ret = ts.resolveModuleNameFromCache(moduleName, containingFile, moduleResolutionCache, resolutionMode);
+        if (ret && ret.resolvedModule) {
+            fixupResolvedModule(ret.resolvedModule);
+        }
+        return ret;
+    };
+    const resolveTypeReferenceDirectives = (typeDirectiveNames, containingFile, redirectedReference, options, containingFileMode // new impliedNodeFormat is accepted by compilerHost
+    ) => {
+        // Note: seems to be called with empty typeDirectiveNames array for all files.
+        // TODO consider using `ts.loadWithTypeDirectiveCache`
+        return typeDirectiveNames.map((typeDirectiveName) => {
+            // Copy-pasted from TS source:
+            const nameIsString = typeof typeDirectiveName === 'string';
+            const mode = nameIsString
+                ? undefined
+                : ts.getModeForFileReference(typeDirectiveName, containingFileMode);
+            const strName = nameIsString
+                ? typeDirectiveName
+                : typeDirectiveName.fileName.toLowerCase();
+            let { resolvedTypeReferenceDirective } = ts.resolveTypeReferenceDirective(strName, containingFile, config.options, host, redirectedReference, undefined, mode);
+            if (typeDirectiveName === 'node' && !resolvedTypeReferenceDirective) {
+                // Resolve @types/node relative to project first, then __dirname (copy logic from elsewhere / refactor into reusable function)
+                let typesNodePackageJsonPath;
+                try {
+                    typesNodePackageJsonPath = projectLocalResolveHelper('@types/node/package.json', true);
+                }
+                catch { } // gracefully do nothing when @types/node is not installed for any reason
+                if (typesNodePackageJsonPath) {
+                    const typeRoots = [(0, path_1.resolve)(typesNodePackageJsonPath, '../..')];
+                    ({ resolvedTypeReferenceDirective } =
+                        ts.resolveTypeReferenceDirective(typeDirectiveName, containingFile, {
+                            ...config.options,
+                            typeRoots,
+                        }, host, redirectedReference));
+                }
+            }
+            if (resolvedTypeReferenceDirective) {
+                fixupResolvedModule(resolvedTypeReferenceDirective);
+            }
+            return resolvedTypeReferenceDirective;
+        });
+    };
+    return {
+        resolveModuleNames,
+        getResolvedModuleWithFailedLookupLocationsFromCache,
+        resolveTypeReferenceDirectives,
+        isFileKnownToBeInternal,
+        markBucketOfFilenameInternal,
+    };
+}
+exports.createResolverFunctions = createResolverFunctions;
+//# sourceMappingURL=resolver-functions.js.map
 
 /***/ }),
 
-/***/ 31285:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
-
-var fs = __nccwpck_require__(57147);
-var path = __nccwpck_require__(71017);
-var common = __nccwpck_require__(17673);
-var cp = __nccwpck_require__(6135);
-var rm = __nccwpck_require__(37720);
+/***/ 80301:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
-common.register('mv', _mv, {
-  cmdOptions: {
-    'f': '!no_force',
-    'n': 'no_force',
-  },
-});
+"use strict";
 
-// Checks if cureent file was created recently
-function checkRecentCreated(sources, index) {
-  var lookedSource = sources[index];
-  return sources.slice(0, index).some(function (src) {
-    return path.basename(src) === path.basename(lookedSource);
-  });
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.getEmitScriptTarget = exports.getUseDefineForClassFields = exports.getPatternFromSpec = exports.createTsInternals = void 0;
+const path_1 = __nccwpck_require__(71017);
+const util_1 = __nccwpck_require__(26239);
+/** @internal */
+exports.createTsInternals = (0, util_1.cachedLookup)(createTsInternalsUncached);
+/**
+ * Given a reference to the TS compiler, return some TS internal functions that we
+ * could not or did not want to grab off the `ts` object.
+ * These have been copy-pasted from TS's source and tweaked as necessary.
+ *
+ * NOTE: This factory returns *only* functions which need a reference to the TS
+ * compiler.  Other functions do not need a reference to the TS compiler so are
+ * exported directly from this file.
+ */
+function createTsInternalsUncached(_ts) {
+    const ts = _ts;
+    /**
+     * Copied from:
+     * https://github.com/microsoft/TypeScript/blob/v4.3.2/src/compiler/commandLineParser.ts#L2821-L2846
+     */
+    function getExtendsConfigPath(extendedConfig, host, basePath, errors, createDiagnostic) {
+        extendedConfig = (0, util_1.normalizeSlashes)(extendedConfig);
+        if (isRootedDiskPath(extendedConfig) ||
+            startsWith(extendedConfig, './') ||
+            startsWith(extendedConfig, '../')) {
+            let extendedConfigPath = getNormalizedAbsolutePath(extendedConfig, basePath);
+            if (!host.fileExists(extendedConfigPath) &&
+                !endsWith(extendedConfigPath, ts.Extension.Json)) {
+                extendedConfigPath = `${extendedConfigPath}.json`;
+                if (!host.fileExists(extendedConfigPath)) {
+                    errors.push(createDiagnostic(ts.Diagnostics.File_0_not_found, extendedConfig));
+                    return undefined;
+                }
+            }
+            return extendedConfigPath;
+        }
+        // If the path isn't a rooted or relative path, resolve like a module
+        const tsGte5_3_0 = (0, util_1.versionGteLt)(ts.version, '5.3.0');
+        const resolved = ts.nodeModuleNameResolver(extendedConfig, combinePaths(basePath, 'tsconfig.json'), { moduleResolution: ts.ModuleResolutionKind.NodeJs }, host, 
+        /*cache*/ undefined, 
+        /*projectRefs*/ undefined, 
+        /*conditionsOrIsConfigLookup*/ tsGte5_3_0 ? undefined : true, 
+        /*isConfigLookup*/ tsGte5_3_0 ? true : undefined);
+        if (resolved.resolvedModule) {
+            return resolved.resolvedModule.resolvedFileName;
+        }
+        errors.push(createDiagnostic(ts.Diagnostics.File_0_not_found, extendedConfig));
+        return undefined;
+    }
+    return { getExtendsConfigPath };
 }
-
-//@
-//@ ### mv([options ,] source [, source ...], dest')
-//@ ### mv([options ,] source_array, dest')
-//@
-//@ Available options:
-//@
-//@ + `-f`: force (default behavior)
-//@ + `-n`: no-clobber
-//@
-//@ Examples:
-//@
-//@ ```javascript
-//@ mv('-n', 'file', 'dir/');
-//@ mv('file1', 'file2', 'dir/');
-//@ mv(['file1', 'file2'], 'dir/'); // same as above
-//@ ```
-//@
-//@ Moves `source` file(s) to `dest`.
-function _mv(options, sources, dest) {
-  // Get sources, dest
-  if (arguments.length < 3) {
-    common.error('missing  and/or ');
-  } else if (arguments.length > 3) {
-    sources = [].slice.call(arguments, 1, arguments.length - 1);
-    dest = arguments[arguments.length - 1];
-  } else if (typeof sources === 'string') {
-    sources = [sources];
-  } else {
-    // TODO(nate): figure out if we actually need this line
-    common.error('invalid arguments');
-  }
-
-  var exists = fs.existsSync(dest);
-  var stats = exists && common.statFollowLinks(dest);
-
-  // Dest is not existing dir, but multiple sources given
-  if ((!exists || !stats.isDirectory()) && sources.length > 1) {
-    common.error('dest is not a directory (too many sources)');
-  }
-
-  // Dest is an existing file, but no -f given
-  if (exists && stats.isFile() && options.no_force) {
-    common.error('dest file already exists: ' + dest);
-  }
-
-  sources.forEach(function (src, srcIndex) {
-    if (!fs.existsSync(src)) {
-      common.error('no such file or directory: ' + src, { continue: true });
-      return; // skip file
+// These functions have alternative implementation to avoid copying too much from TS
+function isRootedDiskPath(path) {
+    return (0, path_1.isAbsolute)(path);
+}
+function combinePaths(path, ...paths) {
+    return (0, util_1.normalizeSlashes)((0, path_1.resolve)(path, ...paths.filter((path) => path)));
+}
+function getNormalizedAbsolutePath(fileName, currentDirectory) {
+    return (0, util_1.normalizeSlashes)(currentDirectory != null
+        ? (0, path_1.resolve)(currentDirectory, fileName)
+        : (0, path_1.resolve)(fileName));
+}
+function startsWith(str, prefix) {
+    return str.lastIndexOf(prefix, 0) === 0;
+}
+function endsWith(str, suffix) {
+    const expectedPos = str.length - suffix.length;
+    return expectedPos >= 0 && str.indexOf(suffix, expectedPos) === expectedPos;
+}
+// Reserved characters, forces escaping of any non-word (or digit), non-whitespace character.
+// It may be inefficient (we could just match (/[-[\]{}()*+?.,\\^$|#\s]/g), but this is future
+// proof.
+const reservedCharacterPattern = /[^\w\s\/]/g;
+/**
+ * @internal
+ * See also: getRegularExpressionForWildcard, which seems to do almost the same thing
+ */
+function getPatternFromSpec(spec, basePath) {
+    const pattern = spec && getSubPatternFromSpec(spec, basePath, excludeMatcher);
+    return pattern && `^(${pattern})${'($|/)'}`;
+}
+exports.getPatternFromSpec = getPatternFromSpec;
+function getSubPatternFromSpec(spec, basePath, { singleAsteriskRegexFragment, doubleAsteriskRegexFragment, replaceWildcardCharacter, }) {
+    let subpattern = '';
+    let hasWrittenComponent = false;
+    const components = getNormalizedPathComponents(spec, basePath);
+    const lastComponent = last(components);
+    // getNormalizedPathComponents includes the separator for the root component.
+    // We need to remove to create our regex correctly.
+    components[0] = removeTrailingDirectorySeparator(components[0]);
+    if (isImplicitGlob(lastComponent)) {
+        components.push('**', '*');
     }
-
-    // If here, src exists
-
-    // When copying to '/path/dir':
-    //    thisDest = '/path/dir/file1'
-    var thisDest = dest;
-    if (fs.existsSync(dest) && common.statFollowLinks(dest).isDirectory()) {
-      thisDest = path.normalize(dest + '/' + path.basename(src));
+    let optionalCount = 0;
+    for (let component of components) {
+        if (component === '**') {
+            subpattern += doubleAsteriskRegexFragment;
+        }
+        else {
+            if (hasWrittenComponent) {
+                subpattern += directorySeparator;
+            }
+            subpattern += component.replace(reservedCharacterPattern, replaceWildcardCharacter);
+        }
+        hasWrittenComponent = true;
     }
-
-    var thisDestExists = fs.existsSync(thisDest);
-
-    if (thisDestExists && checkRecentCreated(sources, srcIndex)) {
-      // cannot overwrite file created recently in current execution, but we want to continue copying other files
-      if (!options.no_force) {
-        common.error("will not overwrite just-created '" + thisDest + "' with '" + src + "'", { continue: true });
-      }
-      return;
+    while (optionalCount > 0) {
+        subpattern += ')?';
+        optionalCount--;
     }
-
-    if (fs.existsSync(thisDest) && options.no_force) {
-      common.error('dest file already exists: ' + thisDest, { continue: true });
-      return; // skip file
+    return subpattern;
+}
+const directoriesMatcher = {
+    singleAsteriskRegexFragment: '[^/]*',
+    /**
+     * Regex for the ** wildcard. Matches any num of subdirectories. When used for including
+     * files or directories, does not match subdirectories that start with a . character
+     */
+    doubleAsteriskRegexFragment: `(/[^/.][^/]*)*?`,
+    replaceWildcardCharacter: (match) => replaceWildcardCharacter(match, directoriesMatcher.singleAsteriskRegexFragment),
+};
+const excludeMatcher = {
+    singleAsteriskRegexFragment: '[^/]*',
+    doubleAsteriskRegexFragment: '(/.+?)?',
+    replaceWildcardCharacter: (match) => replaceWildcardCharacter(match, excludeMatcher.singleAsteriskRegexFragment),
+};
+function getNormalizedPathComponents(path, currentDirectory) {
+    return reducePathComponents(getPathComponents(path, currentDirectory));
+}
+function getPathComponents(path, currentDirectory = '') {
+    path = combinePaths(currentDirectory, path);
+    return pathComponents(path, getRootLength(path));
+}
+function reducePathComponents(components) {
+    if (!some(components))
+        return [];
+    const reduced = [components[0]];
+    for (let i = 1; i < components.length; i++) {
+        const component = components[i];
+        if (!component)
+            continue;
+        if (component === '.')
+            continue;
+        if (component === '..') {
+            if (reduced.length > 1) {
+                if (reduced[reduced.length - 1] !== '..') {
+                    reduced.pop();
+                    continue;
+                }
+            }
+            else if (reduced[0])
+                continue;
+        }
+        reduced.push(component);
     }
-
-    if (path.resolve(src) === path.dirname(path.resolve(thisDest))) {
-      common.error('cannot move to self: ' + src, { continue: true });
-      return; // skip file
+    return reduced;
+}
+function getRootLength(path) {
+    const rootLength = getEncodedRootLength(path);
+    return rootLength < 0 ? ~rootLength : rootLength;
+}
+function getEncodedRootLength(path) {
+    if (!path)
+        return 0;
+    const ch0 = path.charCodeAt(0);
+    // POSIX or UNC
+    if (ch0 === 47 /* CharacterCodes.slash */ || ch0 === 92 /* CharacterCodes.backslash */) {
+        if (path.charCodeAt(1) !== ch0)
+            return 1; // POSIX: "/" (or non-normalized "\")
+        const p1 = path.indexOf(ch0 === 47 /* CharacterCodes.slash */ ? directorySeparator : altDirectorySeparator, 2);
+        if (p1 < 0)
+            return path.length; // UNC: "//server" or "\\server"
+        return p1 + 1; // UNC: "//server/" or "\\server\"
     }
-
-    try {
-      fs.renameSync(src, thisDest);
-    } catch (e) {
-      /* istanbul ignore next */
-      if (e.code === 'EXDEV') {
-        // If we're trying to `mv` to an external partition, we'll actually need
-        // to perform a copy and then clean up the original file. If either the
-        // copy or the rm fails with an exception, we should allow this
-        // exception to pass up to the top level.
-        cp('-r', src, thisDest);
-        rm('-rf', src);
-      }
+    // DOS
+    if (isVolumeCharacter(ch0) && path.charCodeAt(1) === 58 /* CharacterCodes.colon */) {
+        const ch2 = path.charCodeAt(2);
+        if (ch2 === 47 /* CharacterCodes.slash */ || ch2 === 92 /* CharacterCodes.backslash */)
+            return 3; // DOS: "c:/" or "c:\"
+        if (path.length === 2)
+            return 2; // DOS: "c:" (but not "c:d")
     }
-  }); // forEach(src)
-  return '';
-} // mv
-module.exports = _mv;
-
-
-/***/ }),
-
-/***/ 42535:
-/***/ (() => {
-
-// see dirs.js
-
-
-/***/ }),
-
-/***/ 47928:
-/***/ (() => {
-
-// see dirs.js
-
-
-/***/ }),
-
-/***/ 24020:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
-
-var path = __nccwpck_require__(71017);
-var common = __nccwpck_require__(17673);
-
-common.register('pwd', _pwd, {
-  allowGlobbing: false,
-});
-
-//@
-//@ ### pwd()
-//@
-//@ Returns the current directory.
-function _pwd() {
-  var pwd = path.resolve(process.cwd());
-  return pwd;
-}
-module.exports = _pwd;
-
-
-/***/ }),
-
-/***/ 37720:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
-
-var common = __nccwpck_require__(17673);
-var fs = __nccwpck_require__(57147);
-
-common.register('rm', _rm, {
-  cmdOptions: {
-    'f': 'force',
-    'r': 'recursive',
-    'R': 'recursive',
-  },
-});
-
-// Recursively removes 'dir'
-// Adapted from https://github.com/ryanmcgrath/wrench-js
-//
-// Copyright (c) 2010 Ryan McGrath
-// Copyright (c) 2012 Artur Adib
-//
-// Licensed under the MIT License
-// http://www.opensource.org/licenses/mit-license.php
-function rmdirSyncRecursive(dir, force, fromSymlink) {
-  var files;
-
-  files = fs.readdirSync(dir);
-
-  // Loop through and delete everything in the sub-tree after checking it
-  for (var i = 0; i < files.length; i++) {
-    var file = dir + '/' + files[i];
-    var currFile = common.statNoFollowLinks(file);
-
-    if (currFile.isDirectory()) { // Recursive function back to the beginning
-      rmdirSyncRecursive(file, force);
-    } else { // Assume it's a file - perhaps a try/catch belongs here?
-      if (force || isWriteable(file)) {
-        try {
-          common.unlinkSync(file);
-        } catch (e) {
-          /* istanbul ignore next */
-          common.error('could not remove file (code ' + e.code + '): ' + file, {
-            continue: true,
-          });
+    // URL
+    const schemeEnd = path.indexOf(urlSchemeSeparator);
+    if (schemeEnd !== -1) {
+        const authorityStart = schemeEnd + urlSchemeSeparator.length;
+        const authorityEnd = path.indexOf(directorySeparator, authorityStart);
+        if (authorityEnd !== -1) {
+            // URL: "file:///", "file://server/", "file://server/path"
+            // For local "file" URLs, include the leading DOS volume (if present).
+            // Per https://www.ietf.org/rfc/rfc1738.txt, a host of "" or "localhost" is a
+            // special case interpreted as "the machine from which the URL is being interpreted".
+            const scheme = path.slice(0, schemeEnd);
+            const authority = path.slice(authorityStart, authorityEnd);
+            if (scheme === 'file' &&
+                (authority === '' || authority === 'localhost') &&
+                isVolumeCharacter(path.charCodeAt(authorityEnd + 1))) {
+                const volumeSeparatorEnd = getFileUrlVolumeSeparatorEnd(path, authorityEnd + 2);
+                if (volumeSeparatorEnd !== -1) {
+                    if (path.charCodeAt(volumeSeparatorEnd) === 47 /* CharacterCodes.slash */) {
+                        // URL: "file:///c:/", "file://localhost/c:/", "file:///c%3a/", "file://localhost/c%3a/"
+                        return ~(volumeSeparatorEnd + 1);
+                    }
+                    if (volumeSeparatorEnd === path.length) {
+                        // URL: "file:///c:", "file://localhost/c:", "file:///c$3a", "file://localhost/c%3a"
+                        // but not "file:///c:d" or "file:///c%3ad"
+                        return ~volumeSeparatorEnd;
+                    }
+                }
+            }
+            return ~(authorityEnd + 1); // URL: "file://server/", "http://server/"
         }
-      }
+        return ~path.length; // URL: "file://server", "http://server"
     }
-  }
-
-  // if was directory was referenced through a symbolic link,
-  // the contents should be removed, but not the directory itself
-  if (fromSymlink) return;
-
-  // Now that we know everything in the sub-tree has been deleted, we can delete the main directory.
-  // Huzzah for the shopkeep.
-
-  var result;
-  try {
-    // Retry on windows, sometimes it takes a little time before all the files in the directory are gone
-    var start = Date.now();
-
-    // TODO: replace this with a finite loop
-    for (;;) {
-      try {
-        result = fs.rmdirSync(dir);
-        if (fs.existsSync(dir)) throw { code: 'EAGAIN' };
-        break;
-      } catch (er) {
-        /* istanbul ignore next */
-        // In addition to error codes, also check if the directory still exists and loop again if true
-        if (process.platform === 'win32' && (er.code === 'ENOTEMPTY' || er.code === 'EBUSY' || er.code === 'EPERM' || er.code === 'EAGAIN')) {
-          if (Date.now() - start > 1000) throw er;
-        } else if (er.code === 'ENOENT') {
-          // Directory did not exist, deletion was successful
-          break;
-        } else {
-          throw er;
-        }
-      }
+    // relative
+    return 0;
+}
+function ensureTrailingDirectorySeparator(path) {
+    if (!hasTrailingDirectorySeparator(path)) {
+        return path + directorySeparator;
     }
-  } catch (e) {
-    common.error('could not remove directory (code ' + e.code + '): ' + dir, { continue: true });
-  }
-
-  return result;
-} // rmdirSyncRecursive
-
-// Hack to determine if file has write permissions for current user
-// Avoids having to check user, group, etc, but it's probably slow
-function isWriteable(file) {
-  var writePermission = true;
-  try {
-    var __fd = fs.openSync(file, 'a');
-    fs.closeSync(__fd);
-  } catch (e) {
-    writePermission = false;
-  }
-
-  return writePermission;
+    return path;
 }
-
-function handleFile(file, options) {
-  if (options.force || isWriteable(file)) {
-    // -f was passed, or file is writable, so it can be removed
-    common.unlinkSync(file);
-  } else {
-    common.error('permission denied: ' + file, { continue: true });
-  }
+function hasTrailingDirectorySeparator(path) {
+    return (path.length > 0 && isAnyDirectorySeparator(path.charCodeAt(path.length - 1)));
 }
-
-function handleDirectory(file, options) {
-  if (options.recursive) {
-    // -r was passed, so directory can be removed
-    rmdirSyncRecursive(file, options.force);
-  } else {
-    common.error('path is a directory', { continue: true });
-  }
+function isAnyDirectorySeparator(charCode) {
+    return (charCode === 47 /* CharacterCodes.slash */ || charCode === 92 /* CharacterCodes.backslash */);
 }
-
-function handleSymbolicLink(file, options) {
-  var stats;
-  try {
-    stats = common.statFollowLinks(file);
-  } catch (e) {
-    // symlink is broken, so remove the symlink itself
-    common.unlinkSync(file);
-    return;
-  }
-
-  if (stats.isFile()) {
-    common.unlinkSync(file);
-  } else if (stats.isDirectory()) {
-    if (file[file.length - 1] === '/') {
-      // trailing separator, so remove the contents, not the link
-      if (options.recursive) {
-        // -r was passed, so directory can be removed
-        var fromSymlink = true;
-        rmdirSyncRecursive(file, options.force, fromSymlink);
-      } else {
-        common.error('path is a directory', { continue: true });
-      }
-    } else {
-      // no trailing separator, so remove the link
-      common.unlinkSync(file);
+function removeTrailingDirectorySeparator(path) {
+    if (hasTrailingDirectorySeparator(path)) {
+        return path.substr(0, path.length - 1);
     }
-  }
+    return path;
 }
-
-function handleFIFO(file) {
-  common.unlinkSync(file);
+const directorySeparator = '/';
+const altDirectorySeparator = '\\';
+const urlSchemeSeparator = '://';
+function isVolumeCharacter(charCode) {
+    return ((charCode >= 97 /* CharacterCodes.a */ && charCode <= 122 /* CharacterCodes.z */) ||
+        (charCode >= 65 /* CharacterCodes.A */ && charCode <= 90 /* CharacterCodes.Z */));
 }
-
-//@
-//@ ### rm([options,] file [, file ...])
-//@ ### rm([options,] file_array)
-//@
-//@ Available options:
-//@
-//@ + `-f`: force
-//@ + `-r, -R`: recursive
-//@
-//@ Examples:
-//@
-//@ ```javascript
-//@ rm('-rf', '/tmp/*');
-//@ rm('some_file.txt', 'another_file.txt');
-//@ rm(['some_file.txt', 'another_file.txt']); // same as above
-//@ ```
-//@
-//@ Removes files.
-function _rm(options, files) {
-  if (!files) common.error('no paths given');
-
-  // Convert to array
-  files = [].slice.call(arguments, 1);
-
-  files.forEach(function (file) {
-    var lstats;
-    try {
-      var filepath = (file[file.length - 1] === '/')
-        ? file.slice(0, -1) // remove the '/' so lstatSync can detect symlinks
-        : file;
-      lstats = common.statNoFollowLinks(filepath); // test for existence
-    } catch (e) {
-      // Path does not exist, no force flag given
-      if (!options.force) {
-        common.error('no such file or directory: ' + file, { continue: true });
-      }
-      return; // skip file
+function getFileUrlVolumeSeparatorEnd(url, start) {
+    const ch0 = url.charCodeAt(start);
+    if (ch0 === 58 /* CharacterCodes.colon */)
+        return start + 1;
+    if (ch0 === 37 /* CharacterCodes.percent */ &&
+        url.charCodeAt(start + 1) === 51 /* CharacterCodes._3 */) {
+        const ch2 = url.charCodeAt(start + 2);
+        if (ch2 === 97 /* CharacterCodes.a */ || ch2 === 65 /* CharacterCodes.A */)
+            return start + 3;
     }
-
-    // If here, path exists
-    if (lstats.isFile()) {
-      handleFile(file, options);
-    } else if (lstats.isDirectory()) {
-      handleDirectory(file, options);
-    } else if (lstats.isSymbolicLink()) {
-      handleSymbolicLink(file, options);
-    } else if (lstats.isFIFO()) {
-      handleFIFO(file);
+    return -1;
+}
+function some(array, predicate) {
+    if (array) {
+        if (predicate) {
+            for (const v of array) {
+                if (predicate(v)) {
+                    return true;
+                }
+            }
+        }
+        else {
+            return array.length > 0;
+        }
     }
-  }); // forEach(file)
-  return '';
-} // rm
-module.exports = _rm;
-
+    return false;
+}
+function pathComponents(path, rootLength) {
+    const root = path.substring(0, rootLength);
+    const rest = path.substring(rootLength).split(directorySeparator);
+    if (rest.length && !lastOrUndefined(rest))
+        rest.pop();
+    return [root, ...rest];
+}
+function lastOrUndefined(array) {
+    return array.length === 0 ? undefined : array[array.length - 1];
+}
+function last(array) {
+    // Debug.assert(array.length !== 0);
+    return array[array.length - 1];
+}
+function replaceWildcardCharacter(match, singleAsteriskRegexFragment) {
+    return match === '*'
+        ? singleAsteriskRegexFragment
+        : match === '?'
+            ? '[^/]'
+            : '\\' + match;
+}
+/**
+ * An "includes" path "foo" is implicitly a glob "foo/** /*" (without the space) if its last component has no extension,
+ * and does not contain any glob characters itself.
+ */
+function isImplicitGlob(lastPathComponent) {
+    return !/[.*?]/.test(lastPathComponent);
+}
+const ts_ScriptTarget_ES5 = 1;
+const ts_ScriptTarget_ES2022 = 9;
+const ts_ScriptTarget_ESNext = 99;
+const ts_ModuleKind_Node16 = 100;
+const ts_ModuleKind_NodeNext = 199;
+// https://github.com/microsoft/TypeScript/blob/fc418a2e611c88cf9afa0115ff73490b2397d311/src/compiler/utilities.ts#L8761
+function getUseDefineForClassFields(compilerOptions) {
+    return compilerOptions.useDefineForClassFields === undefined
+        ? getEmitScriptTarget(compilerOptions) >= ts_ScriptTarget_ES2022
+        : compilerOptions.useDefineForClassFields;
+}
+exports.getUseDefineForClassFields = getUseDefineForClassFields;
+// https://github.com/microsoft/TypeScript/blob/fc418a2e611c88cf9afa0115ff73490b2397d311/src/compiler/utilities.ts#L8556
+function getEmitScriptTarget(compilerOptions) {
+    var _a;
+    return ((_a = compilerOptions.target) !== null && _a !== void 0 ? _a : ((compilerOptions.module === ts_ModuleKind_Node16 && ts_ScriptTarget_ES2022) ||
+        (compilerOptions.module === ts_ModuleKind_NodeNext && ts_ScriptTarget_ESNext) ||
+        ts_ScriptTarget_ES5));
+}
+exports.getEmitScriptTarget = getEmitScriptTarget;
+//# sourceMappingURL=ts-internals.js.map
 
 /***/ }),
 
-/***/ 46926:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
-
-var common = __nccwpck_require__(17673);
-var fs = __nccwpck_require__(57147);
-
-common.register('sed', _sed, {
-  globStart: 3, // don't glob-expand regexes
-  canReceivePipe: true,
-  cmdOptions: {
-    'i': 'inplace',
-  },
-});
+/***/ 87857:
+/***/ ((__unused_webpack_module, exports) => {
 
-//@
-//@ ### sed([options,] search_regex, replacement, file [, file ...])
-//@ ### sed([options,] search_regex, replacement, file_array)
-//@
-//@ Available options:
-//@
-//@ + `-i`: Replace contents of `file` in-place. _Note that no backups will be created!_
-//@
-//@ Examples:
-//@
-//@ ```javascript
-//@ sed('-i', 'PROGRAM_VERSION', 'v0.1.3', 'source.js');
-//@ sed(/.*DELETE_THIS_LINE.*\n/, '', 'source.js');
-//@ ```
-//@
-//@ Reads an input string from `file`s, and performs a JavaScript `replace()` on the input
-//@ using the given `search_regex` and `replacement` string or function. Returns the new string after replacement.
-//@
-//@ Note:
-//@
-//@ Like unix `sed`, ShellJS `sed` supports capture groups. Capture groups are specified
-//@ using the `$n` syntax:
-//@
-//@ ```javascript
-//@ sed(/(\w+)\s(\w+)/, '$2, $1', 'file.txt');
-//@ ```
-function _sed(options, regex, replacement, files) {
-  // Check if this is coming from a pipe
-  var pipe = common.readFromPipe();
+"use strict";
 
-  if (typeof replacement !== 'string' && typeof replacement !== 'function') {
-    if (typeof replacement === 'number') {
-      replacement = replacement.toString(); // fallback
-    } else {
-      common.error('invalid replacement string');
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.createTsTranspileModule = void 0;
+/** @internal */
+function createTsTranspileModule(ts, transpileOptions) {
+    const { createProgram, createSourceFile, getDefaultCompilerOptions, getImpliedNodeFormatForFile, fixupCompilerOptions, transpileOptionValueCompilerOptions, getNewLineCharacter, fileExtensionIs, normalizePath, Debug, toPath, getSetExternalModuleIndicator, getEntries, addRange, hasProperty, getEmitScriptTarget, getDirectoryPath, } = ts;
+    const compilerOptionsDiagnostics = [];
+    const options = transpileOptions.compilerOptions
+        ? fixupCompilerOptions(transpileOptions.compilerOptions, compilerOptionsDiagnostics)
+        : {};
+    // mix in default options
+    const defaultOptions = getDefaultCompilerOptions();
+    for (const key in defaultOptions) {
+        if (hasProperty(defaultOptions, key) && options[key] === undefined) {
+            options[key] = defaultOptions[key];
+        }
     }
-  }
-
-  // Convert all search strings to RegExp
-  if (typeof regex === 'string') {
-    regex = RegExp(regex);
-  }
+    for (const option of transpileOptionValueCompilerOptions) {
+        options[option.name] = option.transpileOptionValue;
+    }
+    // transpileModule does not write anything to disk so there is no need to verify that there are no conflicts between input and output paths.
+    options.suppressOutputPathCheck = true;
+    // Filename can be non-ts file.
+    options.allowNonTsExtensions = true;
+    const newLine = getNewLineCharacter(options);
+    // Create a compilerHost object to allow the compiler to read and write files
+    const compilerHost = {
+        getSourceFile: (fileName) => fileName === normalizePath(inputFileName) ? sourceFile : undefined,
+        writeFile: (name, text) => {
+            if (fileExtensionIs(name, '.map')) {
+                Debug.assertEqual(sourceMapText, undefined, 'Unexpected multiple source map outputs, file:', name);
+                sourceMapText = text;
+            }
+            else {
+                Debug.assertEqual(outputText, undefined, 'Unexpected multiple outputs, file:', name);
+                outputText = text;
+            }
+        },
+        getDefaultLibFileName: () => 'lib.d.ts',
+        useCaseSensitiveFileNames: () => true,
+        getCanonicalFileName: (fileName) => fileName,
+        getCurrentDirectory: () => '',
+        getNewLine: () => newLine,
+        fileExists: (fileName) => fileName === inputFileName || fileName === packageJsonFileName,
+        readFile: (fileName) => fileName === packageJsonFileName ? `{"type": "${_packageJsonType}"}` : '',
+        directoryExists: () => true,
+        getDirectories: () => [],
+    };
+    let inputFileName;
+    let packageJsonFileName;
+    let _packageJsonType;
+    let sourceFile;
+    let outputText;
+    let sourceMapText;
+    return transpileModule;
+    function transpileModule(input, transpileOptions2, packageJsonType = 'commonjs') {
+        // if jsx is specified then treat file as .tsx
+        inputFileName =
+            transpileOptions2.fileName ||
+                (transpileOptions.compilerOptions && transpileOptions.compilerOptions.jsx
+                    ? 'module.tsx'
+                    : 'module.ts');
+        packageJsonFileName = getDirectoryPath(inputFileName) + '/package.json';
+        _packageJsonType = packageJsonType;
+        sourceFile = createSourceFile(inputFileName, input, {
+            languageVersion: getEmitScriptTarget(options),
+            impliedNodeFormat: getImpliedNodeFormatForFile(toPath(inputFileName, '', compilerHost.getCanonicalFileName), 
+            /*cache*/ undefined, compilerHost, options),
+            setExternalModuleIndicator: getSetExternalModuleIndicator(options),
+        });
+        if (transpileOptions2.moduleName) {
+            sourceFile.moduleName = transpileOptions2.moduleName;
+        }
+        if (transpileOptions2.renamedDependencies) {
+            sourceFile.renamedDependencies = new Map(getEntries(transpileOptions2.renamedDependencies));
+        }
+        // Output
+        outputText = undefined;
+        sourceMapText = undefined;
+        const program = createProgram([inputFileName], options, compilerHost);
+        const diagnostics = compilerOptionsDiagnostics.slice();
+        if (transpileOptions.reportDiagnostics) {
+            addRange(
+            /*to*/ diagnostics, 
+            /*from*/ program.getSyntacticDiagnostics(sourceFile));
+            addRange(/*to*/ diagnostics, /*from*/ program.getOptionsDiagnostics());
+        }
+        // Emit
+        program.emit(
+        /*targetSourceFile*/ undefined, 
+        /*writeFile*/ undefined, 
+        /*cancellationToken*/ undefined, 
+        /*emitOnlyDtsFiles*/ undefined, transpileOptions.transformers);
+        if (outputText === undefined)
+            return Debug.fail('Output generation failed');
+        return { outputText, diagnostics, sourceMapText };
+    }
+}
+exports.createTsTranspileModule = createTsTranspileModule;
+//# sourceMappingURL=ts-transpile-module.js.map
 
-  if (!files && !pipe) {
-    common.error('no files given');
-  }
+/***/ }),
 
-  files = [].slice.call(arguments, 3);
+/***/ 88933:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
-  if (pipe) {
-    files.unshift('-');
-  }
+"use strict";
 
-  var sed = [];
-  files.forEach(function (file) {
-    if (!fs.existsSync(file) && file !== '-') {
-      common.error('no such file or directory: ' + file, 2, { continue: true });
-      return;
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.getDefaultTsconfigJsonForNodeVersion = void 0;
+const nodeMajor = parseInt(process.versions.node.split('.')[0], 10);
+/**
+ * return parsed JSON of the bundled @tsconfig/bases config appropriate for the
+ * running version of nodejs
+ * @internal
+ */
+function getDefaultTsconfigJsonForNodeVersion(ts) {
+    const tsInternal = ts;
+    if (nodeMajor >= 16) {
+        const config = __nccwpck_require__(39777);
+        if (configCompatible(config))
+            return config;
     }
-
-    var contents = file === '-' ? pipe : fs.readFileSync(file, 'utf8');
-    var lines = contents.split('\n');
-    var result = lines.map(function (line) {
-      return line.replace(regex, replacement);
-    }).join('\n');
-
-    sed.push(result);
-
-    if (options.inplace) {
-      fs.writeFileSync(file, result, 'utf8');
+    if (nodeMajor >= 14) {
+        const config = __nccwpck_require__(83754);
+        if (configCompatible(config))
+            return config;
+    }
+    if (nodeMajor >= 12) {
+        const config = __nccwpck_require__(56049);
+        if (configCompatible(config))
+            return config;
+    }
+    return __nccwpck_require__(78250);
+    // Verify that tsconfig target and lib options are compatible with TypeScript compiler
+    function configCompatible(config) {
+        return (typeof ts.ScriptTarget[config.compilerOptions.target.toUpperCase()] === 'number' &&
+            tsInternal.libs &&
+            config.compilerOptions.lib.every((lib) => tsInternal.libs.includes(lib)));
     }
-  });
-
-  return sed.join('\n');
 }
-module.exports = _sed;
-
+exports.getDefaultTsconfigJsonForNodeVersion = getDefaultTsconfigJsonForNodeVersion;
+//# sourceMappingURL=tsconfigs.js.map
 
 /***/ }),
 
-/***/ 20011:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
-
-var common = __nccwpck_require__(17673);
+/***/ 26239:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
-common.register('set', _set, {
-  allowGlobbing: false,
-  wrapOutput: false,
-});
+"use strict";
 
-//@
-//@ ### set(options)
-//@
-//@ Available options:
-//@
-//@ + `+/-e`: exit upon error (`config.fatal`)
-//@ + `+/-v`: verbose: show all commands (`config.verbose`)
-//@ + `+/-f`: disable filename expansion (globbing)
-//@
-//@ Examples:
-//@
-//@ ```javascript
-//@ set('-e'); // exit upon first error
-//@ set('+e'); // this undoes a "set('-e')"
-//@ ```
-//@
-//@ Sets global configuration variables.
-function _set(options) {
-  if (!options) {
-    var args = [].slice.call(arguments, 0);
-    if (args.length < 2) common.error('must provide an argument');
-    options = args[1];
-  }
-  var negate = (options[0] === '+');
-  if (negate) {
-    options = '-' + options.slice(1); // parseOptions needs a '-' prefix
-  }
-  options = common.parseOptions(options, {
-    'e': 'fatal',
-    'v': 'verbose',
-    'f': 'noglob',
-  });
-
-  if (negate) {
-    Object.keys(options).forEach(function (key) {
-      options[key] = !options[key];
-    });
-  }
-
-  Object.keys(options).forEach(function (key) {
-    // Only change the global config if `negate` is false and the option is true
-    // or if `negate` is true and the option is false (aka negate !== option)
-    if (negate !== options[key]) {
-      common.config[key] = options[key];
+var _a;
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.versionGteLt = exports.once = exports.getBasePathForProjectLocalDependencyResolution = exports.createProjectLocalResolveHelper = exports.attemptRequireWithV8CompileCache = exports.cachedLookup = exports.hasOwnProperty = exports.normalizeSlashes = exports.parse = exports.split = exports.assign = exports.yn = exports.createRequire = void 0;
+const module_1 = __nccwpck_require__(98188);
+const ynModule = __nccwpck_require__(45001);
+const path_1 = __nccwpck_require__(71017);
+/** @internal */
+exports.createRequire = (_a = module_1.createRequire !== null && module_1.createRequire !== void 0 ? module_1.createRequire : module_1.createRequireFromPath) !== null && _a !== void 0 ? _a : __nccwpck_require__(14838);
+/**
+ * Wrapper around yn module that returns `undefined` instead of `null`.
+ * This is implemented by yn v4, but we're staying on v3 to avoid v4's node 10 requirement.
+ * @internal
+ */
+function yn(value) {
+    var _a;
+    return (_a = ynModule(value)) !== null && _a !== void 0 ? _a : undefined;
+}
+exports.yn = yn;
+/**
+ * Like `Object.assign`, but ignores `undefined` properties.
+ *
+ * @internal
+ */
+function assign(initialValue, ...sources) {
+    for (const source of sources) {
+        for (const key of Object.keys(source)) {
+            const value = source[key];
+            if (value !== undefined)
+                initialValue[key] = value;
+        }
     }
-  });
-  return;
+    return initialValue;
 }
-module.exports = _set;
-
-
-/***/ }),
-
-/***/ 37472:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
-
-var common = __nccwpck_require__(17673);
-var fs = __nccwpck_require__(57147);
-
-common.register('sort', _sort, {
-  canReceivePipe: true,
-  cmdOptions: {
-    'r': 'reverse',
-    'n': 'numerical',
-  },
-});
-
-// parse out the number prefix of a line
-function parseNumber(str) {
-  var match = str.match(/^\s*(\d*)\s*(.*)$/);
-  return { num: Number(match[1]), value: match[2] };
+exports.assign = assign;
+/**
+ * Split a string array of values
+ * and remove empty strings from the resulting array.
+ * @internal
+ */
+function split(value) {
+    return typeof value === 'string'
+        ? value.split(/ *, */g).filter((v) => v !== '')
+        : undefined;
 }
-
-// compare two strings case-insensitively, but examine case for strings that are
-// case-insensitive equivalent
-function unixCmp(a, b) {
-  var aLower = a.toLowerCase();
-  var bLower = b.toLowerCase();
-  return (aLower === bLower ?
-      -1 * a.localeCompare(b) : // unix sort treats case opposite how javascript does
-      aLower.localeCompare(bLower));
+exports.split = split;
+/**
+ * Parse a string as JSON.
+ * @internal
+ */
+function parse(value) {
+    return typeof value === 'string' ? JSON.parse(value) : undefined;
 }
-
-// compare two strings in the fashion that unix sort's -n option works
-function numericalCmp(a, b) {
-  var objA = parseNumber(a);
-  var objB = parseNumber(b);
-  if (objA.hasOwnProperty('num') && objB.hasOwnProperty('num')) {
-    return ((objA.num !== objB.num) ?
-        (objA.num - objB.num) :
-        unixCmp(objA.value, objB.value));
-  } else {
-    return unixCmp(objA.value, objB.value);
-  }
+exports.parse = parse;
+const directorySeparator = '/';
+const backslashRegExp = /\\/g;
+/**
+ * Replace backslashes with forward slashes.
+ * @internal
+ */
+function normalizeSlashes(value) {
+    return value.replace(backslashRegExp, directorySeparator);
 }
+exports.normalizeSlashes = normalizeSlashes;
+/**
+ * Safe `hasOwnProperty`
+ * @internal
+ */
+function hasOwnProperty(object, property) {
+    return Object.prototype.hasOwnProperty.call(object, property);
+}
+exports.hasOwnProperty = hasOwnProperty;
+/**
+ * Cached fs operation wrapper.
+ */
+function cachedLookup(fn) {
+    const cache = new Map();
+    return (arg) => {
+        if (!cache.has(arg)) {
+            const v = fn(arg);
+            cache.set(arg, v);
+            return v;
+        }
+        return cache.get(arg);
+    };
+}
+exports.cachedLookup = cachedLookup;
+/**
+ * @internal
+ * Require something with v8-compile-cache, which should make subsequent requires faster.
+ * Do lots of error-handling so that, worst case, we require without the cache, and users are not blocked.
+ */
+function attemptRequireWithV8CompileCache(requireFn, specifier) {
+    try {
+        const v8CC = (__nccwpck_require__(26669).install)();
+        try {
+            return requireFn(specifier);
+        }
+        finally {
+            v8CC === null || v8CC === void 0 ? void 0 : v8CC.uninstall();
+        }
+    }
+    catch (e) {
+        return requireFn(specifier);
+    }
+}
+exports.attemptRequireWithV8CompileCache = attemptRequireWithV8CompileCache;
+/**
+ * Helper to discover dependencies relative to a user's project, optionally
+ * falling back to relative to ts-node.  This supports global installations of
+ * ts-node, for example where someone does `#!/usr/bin/env -S ts-node --swc` and
+ * we need to fallback to a global install of @swc/core
+ * @internal
+ */
+function createProjectLocalResolveHelper(localDirectory) {
+    return function projectLocalResolveHelper(specifier, fallbackToTsNodeRelative) {
+        return require.resolve(specifier, {
+            paths: fallbackToTsNodeRelative
+                ? [localDirectory, __dirname]
+                : [localDirectory],
+        });
+    };
+}
+exports.createProjectLocalResolveHelper = createProjectLocalResolveHelper;
+/**
+ * Used as a reminder of all the factors we must consider when finding project-local dependencies and when a config file
+ * on disk may or may not exist.
+ * @internal
+ */
+function getBasePathForProjectLocalDependencyResolution(configFilePath, projectSearchDirOption, projectOption, cwdOption) {
+    var _a;
+    if (configFilePath != null)
+        return (0, path_1.dirname)(configFilePath);
+    return (_a = projectSearchDirOption !== null && projectSearchDirOption !== void 0 ? projectSearchDirOption : projectOption) !== null && _a !== void 0 ? _a : cwdOption;
+    // TODO technically breaks if projectOption is path to a file, not a directory,
+    // and we attempt to resolve relative specifiers.  By the time we resolve relative specifiers,
+    // should have configFilePath, so not reach this codepath.
+}
+exports.getBasePathForProjectLocalDependencyResolution = getBasePathForProjectLocalDependencyResolution;
+/** @internal */
+function once(fn) {
+    let value;
+    let ran = false;
+    function onceFn(...args) {
+        if (ran)
+            return value;
+        value = fn(...args);
+        ran = true;
+        return value;
+    }
+    return onceFn;
+}
+exports.once = once;
+/** @internal */
+function versionGteLt(version, gteRequirement, ltRequirement) {
+    const [major, minor, patch, extra] = parse(version);
+    const [gteMajor, gteMinor, gtePatch] = parse(gteRequirement);
+    const isGte = major > gteMajor ||
+        (major === gteMajor &&
+            (minor > gteMinor || (minor === gteMinor && patch >= gtePatch)));
+    let isLt = true;
+    if (ltRequirement) {
+        const [ltMajor, ltMinor, ltPatch] = parse(ltRequirement);
+        isLt =
+            major < ltMajor ||
+                (major === ltMajor &&
+                    (minor < ltMinor || (minor === ltMinor && patch < ltPatch)));
+    }
+    return isGte && isLt;
+    function parse(requirement) {
+        return requirement.split(/[\.-]/).map((s) => parseInt(s, 10));
+    }
+}
+exports.versionGteLt = versionGteLt;
+//# sourceMappingURL=util.js.map
 
-//@
-//@ ### sort([options,] file [, file ...])
-//@ ### sort([options,] file_array)
-//@
-//@ Available options:
-//@
-//@ + `-r`: Reverse the results
-//@ + `-n`: Compare according to numerical value
-//@
-//@ Examples:
-//@
-//@ ```javascript
-//@ sort('foo.txt', 'bar.txt');
-//@ sort('-r', 'foo.txt');
-//@ ```
-//@
-//@ Return the contents of the `file`s, sorted line-by-line. Sorting multiple
-//@ files mixes their content (just as unix `sort` does).
-function _sort(options, files) {
-  // Check if this is coming from a pipe
-  var pipe = common.readFromPipe();
-
-  if (!files && !pipe) common.error('no files given');
+/***/ }),
 
-  files = [].slice.call(arguments, 1);
+/***/ 12047:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
-  if (pipe) {
-    files.unshift('-');
-  }
+"use strict";
 
-  var lines = files.reduce(function (accum, file) {
-    if (file !== '-') {
-      if (!fs.existsSync(file)) {
-        common.error('no such file or directory: ' + file, { continue: true });
-        return accum;
-      } else if (common.statFollowLinks(file).isDirectory()) {
-        common.error('read failed: ' + file + ': Is a directory', {
-          continue: true,
-        });
-        return accum;
-      }
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.configLoader = exports.loadConfig = void 0;
+var TsConfigLoader2 = __nccwpck_require__(94009);
+var path = __nccwpck_require__(71017);
+function loadConfig(cwd) {
+    if (cwd === void 0) { cwd = process.cwd(); }
+    return configLoader({ cwd: cwd });
+}
+exports.loadConfig = loadConfig;
+function configLoader(_a) {
+    var cwd = _a.cwd, explicitParams = _a.explicitParams, _b = _a.tsConfigLoader, tsConfigLoader = _b === void 0 ? TsConfigLoader2.tsConfigLoader : _b;
+    if (explicitParams) {
+        var absoluteBaseUrl = path.isAbsolute(explicitParams.baseUrl)
+            ? explicitParams.baseUrl
+            : path.join(cwd, explicitParams.baseUrl);
+        return {
+            resultType: "success",
+            configFileAbsolutePath: "",
+            baseUrl: explicitParams.baseUrl,
+            absoluteBaseUrl: absoluteBaseUrl,
+            paths: explicitParams.paths,
+            mainFields: explicitParams.mainFields,
+            addMatchAll: explicitParams.addMatchAll,
+        };
+    }
+    // Load tsconfig and create path matching function
+    var loadResult = tsConfigLoader({
+        cwd: cwd,
+        getEnv: function (key) { return process.env[key]; },
+    });
+    if (!loadResult.tsConfigPath) {
+        return {
+            resultType: "failed",
+            message: "Couldn't find tsconfig.json",
+        };
     }
+    return {
+        resultType: "success",
+        configFileAbsolutePath: loadResult.tsConfigPath,
+        baseUrl: loadResult.baseUrl,
+        absoluteBaseUrl: path.resolve(path.dirname(loadResult.tsConfigPath), loadResult.baseUrl || ""),
+        paths: loadResult.paths || {},
+        addMatchAll: loadResult.baseUrl !== undefined,
+    };
+}
+exports.configLoader = configLoader;
+//# sourceMappingURL=config-loader.js.map
 
-    var contents = file === '-' ? pipe : fs.readFileSync(file, 'utf8');
-    return accum.concat(contents.trimRight().split('\n'));
-  }, []);
+/***/ }),
 
-  var sorted = lines.sort(options.numerical ? numericalCmp : unixCmp);
+/***/ 40250:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
-  if (options.reverse) {
-    sorted = sorted.reverse();
-  }
+"use strict";
 
-  return sorted.join('\n') + '\n';
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.removeExtension = exports.fileExistsAsync = exports.readJsonFromDiskAsync = exports.readJsonFromDiskSync = exports.fileExistsSync = void 0;
+var fs = __nccwpck_require__(57147);
+function fileExistsSync(path) {
+    // If the file doesn't exist, avoid throwing an exception over the native barrier for every miss
+    if (!fs.existsSync(path)) {
+        return false;
+    }
+    try {
+        var stats = fs.statSync(path);
+        return stats.isFile();
+    }
+    catch (err) {
+        // If error, assume file did not exist
+        return false;
+    }
 }
-
-module.exports = _sort;
-
+exports.fileExistsSync = fileExistsSync;
+/**
+ * Reads package.json from disk
+ *
+ * @param file Path to package.json
+ */
+// eslint-disable-next-line @typescript-eslint/no-explicit-any
+function readJsonFromDiskSync(packageJsonPath) {
+    if (!fs.existsSync(packageJsonPath)) {
+        return undefined;
+    }
+    // eslint-disable-next-line @typescript-eslint/no-require-imports
+    return require(packageJsonPath);
+}
+exports.readJsonFromDiskSync = readJsonFromDiskSync;
+function readJsonFromDiskAsync(path, 
+// eslint-disable-next-line @typescript-eslint/no-explicit-any
+callback) {
+    fs.readFile(path, "utf8", function (err, result) {
+        // If error, assume file did not exist
+        if (err || !result) {
+            return callback();
+        }
+        var json = JSON.parse(result);
+        return callback(undefined, json);
+    });
+}
+exports.readJsonFromDiskAsync = readJsonFromDiskAsync;
+function fileExistsAsync(path2, callback2) {
+    fs.stat(path2, function (err, stats) {
+        if (err) {
+            // If error assume file does not exist
+            return callback2(undefined, false);
+        }
+        callback2(undefined, stats ? stats.isFile() : false);
+    });
+}
+exports.fileExistsAsync = fileExistsAsync;
+function removeExtension(path) {
+    return path.substring(0, path.lastIndexOf(".")) || path;
+}
+exports.removeExtension = removeExtension;
+//# sourceMappingURL=filesystem.js.map
 
 /***/ }),
 
-/***/ 18968:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
-
-var common = __nccwpck_require__(17673);
-var fs = __nccwpck_require__(57147);
+/***/ 24961:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
-common.register('tail', _tail, {
-  canReceivePipe: true,
-  cmdOptions: {
-    'n': 'numLines',
-  },
-});
+"use strict";
 
-//@
-//@ ### tail([{'-n': \},] file [, file ...])
-//@ ### tail([{'-n': \},] file_array)
-//@
-//@ Available options:
-//@
-//@ + `-n `: Show the last `` lines of `file`s
-//@
-//@ Examples:
-//@
-//@ ```javascript
-//@ var str = tail({'-n': 1}, 'file*.txt');
-//@ var str = tail('file1', 'file2');
-//@ var str = tail(['file1', 'file2']); // same as above
-//@ ```
-//@
-//@ Read the end of a `file`.
-function _tail(options, files) {
-  var tail = [];
-  var pipe = common.readFromPipe();
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.loadConfig = exports.register = exports.matchFromAbsolutePathsAsync = exports.createMatchPathAsync = exports.matchFromAbsolutePaths = exports.createMatchPath = void 0;
+// register is used from register.js in root dir
+var match_path_sync_1 = __nccwpck_require__(48600);
+Object.defineProperty(exports, "createMatchPath", ({ enumerable: true, get: function () { return match_path_sync_1.createMatchPath; } }));
+Object.defineProperty(exports, "matchFromAbsolutePaths", ({ enumerable: true, get: function () { return match_path_sync_1.matchFromAbsolutePaths; } }));
+var match_path_async_1 = __nccwpck_require__(51294);
+Object.defineProperty(exports, "createMatchPathAsync", ({ enumerable: true, get: function () { return match_path_async_1.createMatchPathAsync; } }));
+Object.defineProperty(exports, "matchFromAbsolutePathsAsync", ({ enumerable: true, get: function () { return match_path_async_1.matchFromAbsolutePathsAsync; } }));
+var register_1 = __nccwpck_require__(24186);
+Object.defineProperty(exports, "register", ({ enumerable: true, get: function () { return register_1.register; } }));
+var config_loader_1 = __nccwpck_require__(12047);
+Object.defineProperty(exports, "loadConfig", ({ enumerable: true, get: function () { return config_loader_1.loadConfig; } }));
+//# sourceMappingURL=index.js.map
 
-  if (!files && !pipe) common.error('no paths given');
+/***/ }),
 
-  var idx = 1;
-  if (options.numLines === true) {
-    idx = 2;
-    options.numLines = Number(arguments[1]);
-  } else if (options.numLines === false) {
-    options.numLines = 10;
-  }
-  options.numLines = -1 * Math.abs(options.numLines);
-  files = [].slice.call(arguments, idx);
+/***/ 68262:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
-  if (pipe) {
-    files.unshift('-');
-  }
+"use strict";
 
-  var shouldAppendNewline = false;
-  files.forEach(function (file) {
-    if (file !== '-') {
-      if (!fs.existsSync(file)) {
-        common.error('no such file or directory: ' + file, { continue: true });
-        return;
-      } else if (common.statFollowLinks(file).isDirectory()) {
-        common.error("error reading '" + file + "': Is a directory", {
-          continue: true,
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.getAbsoluteMappingEntries = void 0;
+var path = __nccwpck_require__(71017);
+/**
+ * Converts an absolute baseUrl and paths to an array of absolute mapping entries.
+ * The array is sorted by longest prefix.
+ * Having an array with entries allows us to keep a sorting order rather than
+ * sort by keys each time we use the mappings.
+ *
+ * @param absoluteBaseUrl
+ * @param paths
+ * @param addMatchAll
+ */
+function getAbsoluteMappingEntries(absoluteBaseUrl, paths, addMatchAll) {
+    // Resolve all paths to absolute form once here, and sort them by
+    // longest prefix once here, this saves time on each request later.
+    // We need to put them in an array to preserve the sorting order.
+    var sortedKeys = sortByLongestPrefix(Object.keys(paths));
+    var absolutePaths = [];
+    for (var _i = 0, sortedKeys_1 = sortedKeys; _i < sortedKeys_1.length; _i++) {
+        var key = sortedKeys_1[_i];
+        absolutePaths.push({
+            pattern: key,
+            paths: paths[key].map(function (pathToResolve) {
+                return path.resolve(absoluteBaseUrl, pathToResolve);
+            }),
         });
-        return;
-      }
     }
-
-    var contents = file === '-' ? pipe : fs.readFileSync(file, 'utf8');
-
-    var lines = contents.split('\n');
-    if (lines[lines.length - 1] === '') {
-      lines.pop();
-      shouldAppendNewline = true;
-    } else {
-      shouldAppendNewline = false;
+    // If there is no match-all path specified in the paths section of tsconfig, then try to match
+    // all paths relative to baseUrl, this is how typescript works.
+    if (!paths["*"] && addMatchAll) {
+        absolutePaths.push({
+            pattern: "*",
+            paths: ["".concat(absoluteBaseUrl.replace(/\/$/, ""), "/*")],
+        });
     }
-
-    tail = tail.concat(lines.slice(options.numLines));
-  });
-
-  if (shouldAppendNewline) {
-    tail.push(''); // to add a trailing newline once we join
-  }
-  return tail.join('\n');
+    return absolutePaths;
 }
-module.exports = _tail;
-
+exports.getAbsoluteMappingEntries = getAbsoluteMappingEntries;
+/**
+ * Sort path patterns.
+ * If a module name can be matched with multiple patterns then pattern with the longest prefix will be picked.
+ */
+function sortByLongestPrefix(arr) {
+    return arr
+        .concat()
+        .sort(function (a, b) { return getPrefixLength(b) - getPrefixLength(a); });
+}
+function getPrefixLength(pattern) {
+    var prefixLength = pattern.indexOf("*");
+    return pattern.substr(0, prefixLength).length;
+}
+//# sourceMappingURL=mapping-entry.js.map
 
 /***/ }),
 
-/***/ 40591:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
-
-var common = __nccwpck_require__(17673);
-var os = __nccwpck_require__(22037);
-var fs = __nccwpck_require__(57147);
-
-common.register('tempdir', _tempDir, {
-  allowGlobbing: false,
-  wrapOutput: false,
-});
-
-// Returns false if 'dir' is not a writeable directory, 'dir' otherwise
-function writeableDir(dir) {
-  if (!dir || !fs.existsSync(dir)) return false;
+/***/ 51294:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
-  if (!common.statFollowLinks(dir).isDirectory()) return false;
+"use strict";
 
-  var testFile = dir + '/' + common.randomFileName();
-  try {
-    fs.writeFileSync(testFile, ' ');
-    common.unlinkSync(testFile);
-    return dir;
-  } catch (e) {
-    /* istanbul ignore next */
-    return false;
-  }
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.matchFromAbsolutePathsAsync = exports.createMatchPathAsync = void 0;
+var path = __nccwpck_require__(71017);
+var TryPath = __nccwpck_require__(3998);
+var MappingEntry = __nccwpck_require__(68262);
+var Filesystem = __nccwpck_require__(40250);
+/**
+ * See the sync version for docs.
+ */
+function createMatchPathAsync(absoluteBaseUrl, paths, mainFields, addMatchAll) {
+    if (mainFields === void 0) { mainFields = ["main"]; }
+    if (addMatchAll === void 0) { addMatchAll = true; }
+    var absolutePaths = MappingEntry.getAbsoluteMappingEntries(absoluteBaseUrl, paths, addMatchAll);
+    return function (requestedModule, readJson, fileExists, extensions, callback) {
+        return matchFromAbsolutePathsAsync(absolutePaths, requestedModule, readJson, fileExists, extensions, callback, mainFields);
+    };
 }
-
-// Variable to cache the tempdir value for successive lookups.
-var cachedTempDir;
-
-//@
-//@ ### tempdir()
-//@
-//@ Examples:
-//@
-//@ ```javascript
-//@ var tmp = tempdir(); // "/tmp" for most *nix platforms
-//@ ```
-//@
-//@ Searches and returns string containing a writeable, platform-dependent temporary directory.
-//@ Follows Python's [tempfile algorithm](http://docs.python.org/library/tempfile.html#tempfile.tempdir).
-function _tempDir() {
-  if (cachedTempDir) return cachedTempDir;
-
-  cachedTempDir = writeableDir(os.tmpdir()) ||
-                  writeableDir(process.env.TMPDIR) ||
-                  writeableDir(process.env.TEMP) ||
-                  writeableDir(process.env.TMP) ||
-                  writeableDir(process.env.Wimp$ScrapDir) || // RiscOS
-                  writeableDir('C:\\TEMP') || // Windows
-                  writeableDir('C:\\TMP') || // Windows
-                  writeableDir('\\TEMP') || // Windows
-                  writeableDir('\\TMP') || // Windows
-                  writeableDir('/tmp') ||
-                  writeableDir('/var/tmp') ||
-                  writeableDir('/usr/tmp') ||
-                  writeableDir('.'); // last resort
-
-  return cachedTempDir;
+exports.createMatchPathAsync = createMatchPathAsync;
+/**
+ * See the sync version for docs.
+ */
+function matchFromAbsolutePathsAsync(absolutePathMappings, requestedModule, readJson, fileExists, extensions, callback, mainFields) {
+    if (readJson === void 0) { readJson = Filesystem.readJsonFromDiskAsync; }
+    if (fileExists === void 0) { fileExists = Filesystem.fileExistsAsync; }
+    if (extensions === void 0) { extensions = Object.keys(require.extensions); }
+    if (mainFields === void 0) { mainFields = ["main"]; }
+    var tryPaths = TryPath.getPathsToTry(extensions, absolutePathMappings, requestedModule);
+    if (!tryPaths) {
+        return callback();
+    }
+    findFirstExistingPath(tryPaths, readJson, fileExists, callback, 0, mainFields);
 }
-
-// Indicates if the tempdir value is currently cached. This is exposed for tests
-// only. The return value should only be tested for truthiness.
-function isCached() {
-  return cachedTempDir;
+exports.matchFromAbsolutePathsAsync = matchFromAbsolutePathsAsync;
+function findFirstExistingMainFieldMappedFile(packageJson, mainFields, packageJsonPath, fileExistsAsync, doneCallback, index) {
+    if (index === void 0) { index = 0; }
+    if (index >= mainFields.length) {
+        return doneCallback(undefined, undefined);
+    }
+    var tryNext = function () {
+        return findFirstExistingMainFieldMappedFile(packageJson, mainFields, packageJsonPath, fileExistsAsync, doneCallback, index + 1);
+    };
+    var mainFieldSelector = mainFields[index];
+    var mainFieldMapping = typeof mainFieldSelector === "string"
+        ? packageJson[mainFieldSelector]
+        : mainFieldSelector.reduce(function (obj, key) { return obj[key]; }, packageJson);
+    if (typeof mainFieldMapping !== "string") {
+        // Skip mappings that are not pointers to replacement files
+        return tryNext();
+    }
+    var mappedFilePath = path.join(path.dirname(packageJsonPath), mainFieldMapping);
+    fileExistsAsync(mappedFilePath, function (err, exists) {
+        if (err) {
+            return doneCallback(err);
+        }
+        if (exists) {
+            return doneCallback(undefined, mappedFilePath);
+        }
+        return tryNext();
+    });
 }
-
-// Clears the cached tempDir value, if one is cached. This is exposed for tests
-// only.
-function clearCache() {
-  cachedTempDir = undefined;
+// Recursive loop to probe for physical files
+function findFirstExistingPath(tryPaths, readJson, fileExists, doneCallback, index, mainFields) {
+    if (index === void 0) { index = 0; }
+    if (mainFields === void 0) { mainFields = ["main"]; }
+    var tryPath = tryPaths[index];
+    if (tryPath.type === "file" ||
+        tryPath.type === "extension" ||
+        tryPath.type === "index") {
+        fileExists(tryPath.path, function (err, exists) {
+            if (err) {
+                return doneCallback(err);
+            }
+            if (exists) {
+                return doneCallback(undefined, TryPath.getStrippedPath(tryPath));
+            }
+            if (index === tryPaths.length - 1) {
+                return doneCallback();
+            }
+            // Continue with the next path
+            return findFirstExistingPath(tryPaths, readJson, fileExists, doneCallback, index + 1, mainFields);
+        });
+    }
+    else if (tryPath.type === "package") {
+        readJson(tryPath.path, function (err, packageJson) {
+            if (err) {
+                return doneCallback(err);
+            }
+            if (packageJson) {
+                return findFirstExistingMainFieldMappedFile(packageJson, mainFields, tryPath.path, fileExists, function (mainFieldErr, mainFieldMappedFile) {
+                    if (mainFieldErr) {
+                        return doneCallback(mainFieldErr);
+                    }
+                    if (mainFieldMappedFile) {
+                        return doneCallback(undefined, mainFieldMappedFile);
+                    }
+                    // No field in package json was a valid option. Continue with the next path.
+                    return findFirstExistingPath(tryPaths, readJson, fileExists, doneCallback, index + 1, mainFields);
+                });
+            }
+            // This is async code, we need to return unconditionally, otherwise the code still falls
+            // through and keeps recursing. While this might work in general, libraries that use neo-async
+            // like Webpack will actually not allow you to call the same callback twice.
+            //
+            // An example of where this caused issues:
+            // https://github.com/dividab/tsconfig-paths-webpack-plugin/issues/11
+            //
+            // Continue with the next path
+            return findFirstExistingPath(tryPaths, readJson, fileExists, doneCallback, index + 1, mainFields);
+        });
+    }
+    else {
+        TryPath.exhaustiveTypeException(tryPath.type);
+    }
 }
-
-module.exports.tempDir = _tempDir;
-module.exports.isCached = isCached;
-module.exports.clearCache = clearCache;
-
+//# sourceMappingURL=match-path-async.js.map
 
 /***/ }),
 
-/***/ 39063:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
-
-var common = __nccwpck_require__(17673);
-var fs = __nccwpck_require__(57147);
-
-common.register('test', _test, {
-  cmdOptions: {
-    'b': 'block',
-    'c': 'character',
-    'd': 'directory',
-    'e': 'exists',
-    'f': 'file',
-    'L': 'link',
-    'p': 'pipe',
-    'S': 'socket',
-  },
-  wrapOutput: false,
-  allowGlobbing: false,
-});
-
+/***/ 48600:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
-//@
-//@ ### test(expression)
-//@
-//@ Available expression primaries:
-//@
-//@ + `'-b', 'path'`: true if path is a block device
-//@ + `'-c', 'path'`: true if path is a character device
-//@ + `'-d', 'path'`: true if path is a directory
-//@ + `'-e', 'path'`: true if path exists
-//@ + `'-f', 'path'`: true if path is a regular file
-//@ + `'-L', 'path'`: true if path is a symbolic link
-//@ + `'-p', 'path'`: true if path is a pipe (FIFO)
-//@ + `'-S', 'path'`: true if path is a socket
-//@
-//@ Examples:
-//@
-//@ ```javascript
-//@ if (test('-d', path)) { /* do something with dir */ };
-//@ if (!test('-f', path)) continue; // skip if it's a regular file
-//@ ```
-//@
-//@ Evaluates `expression` using the available primaries and returns corresponding value.
-function _test(options, path) {
-  if (!path) common.error('no path given');
+"use strict";
 
-  var canInterpret = false;
-  Object.keys(options).forEach(function (key) {
-    if (options[key] === true) {
-      canInterpret = true;
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.matchFromAbsolutePaths = exports.createMatchPath = void 0;
+var path = __nccwpck_require__(71017);
+var Filesystem = __nccwpck_require__(40250);
+var MappingEntry = __nccwpck_require__(68262);
+var TryPath = __nccwpck_require__(3998);
+/**
+ * Creates a function that can resolve paths according to tsconfig paths property.
+ *
+ * @param absoluteBaseUrl Absolute version of baseUrl as specified in tsconfig.
+ * @param paths The paths as specified in tsconfig.
+ * @param mainFields A list of package.json field names to try when resolving module files. Select a nested field using an array of field names.
+ * @param addMatchAll Add a match-all "*" rule if none is present
+ * @returns a function that can resolve paths.
+ */
+function createMatchPath(absoluteBaseUrl, paths, mainFields, addMatchAll) {
+    if (mainFields === void 0) { mainFields = ["main"]; }
+    if (addMatchAll === void 0) { addMatchAll = true; }
+    var absolutePaths = MappingEntry.getAbsoluteMappingEntries(absoluteBaseUrl, paths, addMatchAll);
+    return function (requestedModule, readJson, fileExists, extensions) {
+        return matchFromAbsolutePaths(absolutePaths, requestedModule, readJson, fileExists, extensions, mainFields);
+    };
+}
+exports.createMatchPath = createMatchPath;
+/**
+ * Finds a path from tsconfig that matches a module load request.
+ *
+ * @param absolutePathMappings The paths to try as specified in tsconfig but resolved to absolute form.
+ * @param requestedModule The required module name.
+ * @param readJson Function that can read json from a path (useful for testing).
+ * @param fileExists Function that checks for existence of a file at a path (useful for testing).
+ * @param extensions File extensions to probe for (useful for testing).
+ * @param mainFields A list of package.json field names to try when resolving module files. Select a nested field using an array of field names.
+ * @returns the found path, or undefined if no path was found.
+ */
+function matchFromAbsolutePaths(absolutePathMappings, requestedModule, readJson, fileExists, extensions, mainFields) {
+    if (readJson === void 0) { readJson = Filesystem.readJsonFromDiskSync; }
+    if (fileExists === void 0) { fileExists = Filesystem.fileExistsSync; }
+    if (extensions === void 0) { extensions = Object.keys(require.extensions); }
+    if (mainFields === void 0) { mainFields = ["main"]; }
+    var tryPaths = TryPath.getPathsToTry(extensions, absolutePathMappings, requestedModule);
+    if (!tryPaths) {
+        return undefined;
     }
-  });
-
-  if (!canInterpret) common.error('could not interpret expression');
-
-  if (options.link) {
-    try {
-      return common.statNoFollowLinks(path).isSymbolicLink();
-    } catch (e) {
-      return false;
+    return findFirstExistingPath(tryPaths, readJson, fileExists, mainFields);
+}
+exports.matchFromAbsolutePaths = matchFromAbsolutePaths;
+function findFirstExistingMainFieldMappedFile(packageJson, mainFields, packageJsonPath, fileExists) {
+    for (var index = 0; index < mainFields.length; index++) {
+        var mainFieldSelector = mainFields[index];
+        var candidateMapping = typeof mainFieldSelector === "string"
+            ? packageJson[mainFieldSelector]
+            : mainFieldSelector.reduce(function (obj, key) { return obj[key]; }, packageJson);
+        if (candidateMapping && typeof candidateMapping === "string") {
+            var candidateFilePath = path.join(path.dirname(packageJsonPath), candidateMapping);
+            if (fileExists(candidateFilePath)) {
+                return candidateFilePath;
+            }
+        }
     }
-  }
-
-  if (!fs.existsSync(path)) return false;
-
-  if (options.exists) return true;
-
-  var stats = common.statFollowLinks(path);
-
-  if (options.block) return stats.isBlockDevice();
-
-  if (options.character) return stats.isCharacterDevice();
-
-  if (options.directory) return stats.isDirectory();
-
-  if (options.file) return stats.isFile();
-
-  /* istanbul ignore next */
-  if (options.pipe) return stats.isFIFO();
-
-  /* istanbul ignore next */
-  if (options.socket) return stats.isSocket();
-
-  /* istanbul ignore next */
-  return false; // fallback
-} // test
-module.exports = _test;
-
+    return undefined;
+}
+function findFirstExistingPath(tryPaths, readJson, fileExists, mainFields) {
+    if (readJson === void 0) { readJson = Filesystem.readJsonFromDiskSync; }
+    if (mainFields === void 0) { mainFields = ["main"]; }
+    for (var _i = 0, tryPaths_1 = tryPaths; _i < tryPaths_1.length; _i++) {
+        var tryPath = tryPaths_1[_i];
+        if (tryPath.type === "file" ||
+            tryPath.type === "extension" ||
+            tryPath.type === "index") {
+            if (fileExists(tryPath.path)) {
+                return TryPath.getStrippedPath(tryPath);
+            }
+        }
+        else if (tryPath.type === "package") {
+            var packageJson = readJson(tryPath.path);
+            if (packageJson) {
+                var mainFieldMappedFile = findFirstExistingMainFieldMappedFile(packageJson, mainFields, tryPath.path, fileExists);
+                if (mainFieldMappedFile) {
+                    return mainFieldMappedFile;
+                }
+            }
+        }
+        else {
+            TryPath.exhaustiveTypeException(tryPath.type);
+        }
+    }
+    return undefined;
+}
+//# sourceMappingURL=match-path-sync.js.map
 
 /***/ }),
 
-/***/ 94897:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
-
-var common = __nccwpck_require__(17673);
-var fs = __nccwpck_require__(57147);
-var path = __nccwpck_require__(71017);
-
-common.register('to', _to, {
-  pipeOnly: true,
-  wrapOutput: false,
-});
-
-//@
-//@ ### ShellString.prototype.to(file)
-//@
-//@ Examples:
-//@
-//@ ```javascript
-//@ cat('input.txt').to('output.txt');
-//@ ```
-//@
-//@ Analogous to the redirection operator `>` in Unix, but works with
-//@ `ShellStrings` (such as those returned by `cat`, `grep`, etc.). _Like Unix
-//@ redirections, `to()` will overwrite any existing file!_
-function _to(options, file) {
-  if (!file) common.error('wrong arguments');
+/***/ 24186:
+/***/ (function(__unused_webpack_module, exports, __nccwpck_require__) {
 
-  if (!fs.existsSync(path.dirname(file))) {
-    common.error('no such file or directory: ' + path.dirname(file));
-  }
+"use strict";
 
-  try {
-    fs.writeFileSync(file, this.stdout || this.toString(), 'utf8');
-    return this;
-  } catch (e) {
-    /* istanbul ignore next */
-    common.error('could not write to file (code ' + e.code + '): ' + file, { continue: true });
-  }
+var __spreadArray = (this && this.__spreadArray) || function (to, from, pack) {
+    if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {
+        if (ar || !(i in from)) {
+            if (!ar) ar = Array.prototype.slice.call(from, 0, i);
+            ar[i] = from[i];
+        }
+    }
+    return to.concat(ar || Array.prototype.slice.call(from));
+};
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.register = void 0;
+var match_path_sync_1 = __nccwpck_require__(48600);
+var config_loader_1 = __nccwpck_require__(12047);
+var noOp = function () { return void 0; };
+function getCoreModules(builtinModules) {
+    builtinModules = builtinModules || [
+        "assert",
+        "buffer",
+        "child_process",
+        "cluster",
+        "crypto",
+        "dgram",
+        "dns",
+        "domain",
+        "events",
+        "fs",
+        "http",
+        "https",
+        "net",
+        "os",
+        "path",
+        "punycode",
+        "querystring",
+        "readline",
+        "stream",
+        "string_decoder",
+        "tls",
+        "tty",
+        "url",
+        "util",
+        "v8",
+        "vm",
+        "zlib",
+    ];
+    var coreModules = {};
+    for (var _i = 0, builtinModules_1 = builtinModules; _i < builtinModules_1.length; _i++) {
+        var module_1 = builtinModules_1[_i];
+        coreModules[module_1] = true;
+    }
+    return coreModules;
 }
-module.exports = _to;
-
+/**
+ * Installs a custom module load function that can adhere to paths in tsconfig.
+ * Returns a function to undo paths registration.
+ */
+function register(params) {
+    var cwd;
+    var explicitParams;
+    if (params) {
+        cwd = params.cwd;
+        if (params.baseUrl || params.paths) {
+            explicitParams = params;
+        }
+    }
+    else {
+        // eslint-disable-next-line
+        var minimist = __nccwpck_require__(40311);
+        var argv = minimist(process.argv.slice(2), {
+            // eslint-disable-next-line id-denylist
+            string: ["project"],
+            alias: {
+                project: ["P"],
+            },
+        });
+        cwd = argv.project;
+    }
+    var configLoaderResult = (0, config_loader_1.configLoader)({
+        cwd: cwd !== null && cwd !== void 0 ? cwd : process.cwd(),
+        explicitParams: explicitParams,
+    });
+    if (configLoaderResult.resultType === "failed") {
+        console.warn("".concat(configLoaderResult.message, ". tsconfig-paths will be skipped"));
+        return noOp;
+    }
+    var matchPath = (0, match_path_sync_1.createMatchPath)(configLoaderResult.absoluteBaseUrl, configLoaderResult.paths, configLoaderResult.mainFields, configLoaderResult.addMatchAll);
+    // Patch node's module loading
+    // eslint-disable-next-line @typescript-eslint/no-require-imports,@typescript-eslint/no-var-requires
+    var Module = __nccwpck_require__(98188);
+    // eslint-disable-next-line no-underscore-dangle
+    var originalResolveFilename = Module._resolveFilename;
+    var coreModules = getCoreModules(Module.builtinModules);
+    // eslint-disable-next-line @typescript-eslint/no-explicit-any,no-underscore-dangle
+    Module._resolveFilename = function (request, _parent) {
+        var isCoreModule = coreModules.hasOwnProperty(request);
+        if (!isCoreModule) {
+            var found = matchPath(request);
+            if (found) {
+                var modifiedArguments = __spreadArray([found], [].slice.call(arguments, 1), true); // Passes all arguments. Even those that is not specified above.
+                return originalResolveFilename.apply(this, modifiedArguments);
+            }
+        }
+        return originalResolveFilename.apply(this, arguments);
+    };
+    return function () {
+        // Return node's module loading to original state.
+        // eslint-disable-next-line no-underscore-dangle
+        Module._resolveFilename = originalResolveFilename;
+    };
+}
+exports.register = register;
+//# sourceMappingURL=register.js.map
 
 /***/ }),
 
-/***/ 60228:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+/***/ 3998:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
-var common = __nccwpck_require__(17673);
-var fs = __nccwpck_require__(57147);
+"use strict";
+
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.exhaustiveTypeException = exports.getStrippedPath = exports.getPathsToTry = void 0;
 var path = __nccwpck_require__(71017);
+var path_1 = __nccwpck_require__(71017);
+var filesystem_1 = __nccwpck_require__(40250);
+/**
+ * Builds a list of all physical paths to try by:
+ * 1. Check for file named exactly as request.
+ * 2. Check for files named as request ending in any of the extensions.
+ * 3. Check for file specified in package.json's main property.
+ * 4. Check for files named as request ending in "index" with any of the extensions.
+ */
+function getPathsToTry(extensions, absolutePathMappings, requestedModule) {
+    if (!absolutePathMappings || !requestedModule || requestedModule[0] === ".") {
+        return undefined;
+    }
+    var pathsToTry = [];
+    for (var _i = 0, absolutePathMappings_1 = absolutePathMappings; _i < absolutePathMappings_1.length; _i++) {
+        var entry = absolutePathMappings_1[_i];
+        var starMatch = entry.pattern === requestedModule
+            ? ""
+            : matchStar(entry.pattern, requestedModule);
+        if (starMatch !== undefined) {
+            var _loop_1 = function (physicalPathPattern) {
+                var physicalPath = physicalPathPattern.replace("*", starMatch);
+                pathsToTry.push({ type: "file", path: physicalPath });
+                pathsToTry.push.apply(pathsToTry, extensions.map(function (e) { return ({ type: "extension", path: physicalPath + e }); }));
+                pathsToTry.push({
+                    type: "package",
+                    path: path.join(physicalPath, "/package.json"),
+                });
+                var indexPath = path.join(physicalPath, "/index");
+                pathsToTry.push.apply(pathsToTry, extensions.map(function (e) { return ({ type: "index", path: indexPath + e }); }));
+            };
+            for (var _a = 0, _b = entry.paths; _a < _b.length; _a++) {
+                var physicalPathPattern = _b[_a];
+                _loop_1(physicalPathPattern);
+            }
+        }
+    }
+    return pathsToTry.length === 0 ? undefined : pathsToTry;
+}
+exports.getPathsToTry = getPathsToTry;
+// Not sure why we don't just return the full found path?
+function getStrippedPath(tryPath) {
+    return tryPath.type === "index"
+        ? (0, path_1.dirname)(tryPath.path)
+        : tryPath.type === "file"
+            ? tryPath.path
+            : tryPath.type === "extension"
+                ? (0, filesystem_1.removeExtension)(tryPath.path)
+                : tryPath.type === "package"
+                    ? tryPath.path
+                    : exhaustiveTypeException(tryPath.type);
+}
+exports.getStrippedPath = getStrippedPath;
+function exhaustiveTypeException(check) {
+    throw new Error("Unknown type ".concat(check));
+}
+exports.exhaustiveTypeException = exhaustiveTypeException;
+/**
+ * Matches pattern with a single star against search.
+ * Star must match at least one character to be considered a match.
+ *
+ * @param patttern for example "foo*"
+ * @param search for example "fooawesomebar"
+ * @returns the part of search that * matches, or undefined if no match.
+ */
+function matchStar(pattern, search) {
+    if (search.length < pattern.length) {
+        return undefined;
+    }
+    if (pattern === "*") {
+        return search;
+    }
+    var star = pattern.indexOf("*");
+    if (star === -1) {
+        return undefined;
+    }
+    var part1 = pattern.substring(0, star);
+    var part2 = pattern.substring(star + 1);
+    if (search.substr(0, star) !== part1) {
+        return undefined;
+    }
+    if (search.substr(search.length - part2.length) !== part2) {
+        return undefined;
+    }
+    return search.substr(star, search.length - part2.length);
+}
+//# sourceMappingURL=try-path.js.map
 
-common.register('toEnd', _toEnd, {
-  pipeOnly: true,
-  wrapOutput: false,
-});
+/***/ }),
 
-//@
-//@ ### ShellString.prototype.toEnd(file)
-//@
-//@ Examples:
-//@
-//@ ```javascript
-//@ cat('input.txt').toEnd('output.txt');
-//@ ```
-//@
-//@ Analogous to the redirect-and-append operator `>>` in Unix, but works with
-//@ `ShellStrings` (such as those returned by `cat`, `grep`, etc.).
-function _toEnd(options, file) {
-  if (!file) common.error('wrong arguments');
+/***/ 94009:
+/***/ (function(__unused_webpack_module, exports, __nccwpck_require__) {
 
-  if (!fs.existsSync(path.dirname(file))) {
-    common.error('no such file or directory: ' + path.dirname(file));
-  }
+"use strict";
 
-  try {
-    fs.appendFileSync(file, this.stdout || this.toString(), 'utf8');
-    return this;
-  } catch (e) {
-    /* istanbul ignore next */
-    common.error('could not append to file (code ' + e.code + '): ' + file, { continue: true });
-  }
+var __assign = (this && this.__assign) || function () {
+    __assign = Object.assign || function(t) {
+        for (var s, i = 1, n = arguments.length; i < n; i++) {
+            s = arguments[i];
+            for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
+                t[p] = s[p];
+        }
+        return t;
+    };
+    return __assign.apply(this, arguments);
+};
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.loadTsconfig = exports.walkForTsConfig = exports.tsConfigLoader = void 0;
+var path = __nccwpck_require__(71017);
+var fs = __nccwpck_require__(57147);
+// eslint-disable-next-line @typescript-eslint/no-require-imports
+var JSON5 = __nccwpck_require__(29941);
+// eslint-disable-next-line @typescript-eslint/no-require-imports
+var StripBom = __nccwpck_require__(65891);
+function tsConfigLoader(_a) {
+    var getEnv = _a.getEnv, cwd = _a.cwd, _b = _a.loadSync, loadSync = _b === void 0 ? loadSyncDefault : _b;
+    var TS_NODE_PROJECT = getEnv("TS_NODE_PROJECT");
+    var TS_NODE_BASEURL = getEnv("TS_NODE_BASEURL");
+    // tsconfig.loadSync handles if TS_NODE_PROJECT is a file or directory
+    // and also overrides baseURL if TS_NODE_BASEURL is available.
+    var loadResult = loadSync(cwd, TS_NODE_PROJECT, TS_NODE_BASEURL);
+    return loadResult;
 }
-module.exports = _toEnd;
-
+exports.tsConfigLoader = tsConfigLoader;
+function loadSyncDefault(cwd, filename, baseUrl) {
+    // Tsconfig.loadSync uses path.resolve. This is why we can use an absolute path as filename
+    var configPath = resolveConfigPath(cwd, filename);
+    if (!configPath) {
+        return {
+            tsConfigPath: undefined,
+            baseUrl: undefined,
+            paths: undefined,
+        };
+    }
+    var config = loadTsconfig(configPath);
+    return {
+        tsConfigPath: configPath,
+        baseUrl: baseUrl ||
+            (config && config.compilerOptions && config.compilerOptions.baseUrl),
+        paths: config && config.compilerOptions && config.compilerOptions.paths,
+    };
+}
+function resolveConfigPath(cwd, filename) {
+    if (filename) {
+        var absolutePath = fs.lstatSync(filename).isDirectory()
+            ? path.resolve(filename, "./tsconfig.json")
+            : path.resolve(cwd, filename);
+        return absolutePath;
+    }
+    if (fs.statSync(cwd).isFile()) {
+        return path.resolve(cwd);
+    }
+    var configAbsolutePath = walkForTsConfig(cwd);
+    return configAbsolutePath ? path.resolve(configAbsolutePath) : undefined;
+}
+function walkForTsConfig(directory, readdirSync) {
+    if (readdirSync === void 0) { readdirSync = fs.readdirSync; }
+    var files = readdirSync(directory);
+    var filesToCheck = ["tsconfig.json", "jsconfig.json"];
+    for (var _i = 0, filesToCheck_1 = filesToCheck; _i < filesToCheck_1.length; _i++) {
+        var fileToCheck = filesToCheck_1[_i];
+        if (files.indexOf(fileToCheck) !== -1) {
+            return path.join(directory, fileToCheck);
+        }
+    }
+    var parentDirectory = path.dirname(directory);
+    // If we reached the top
+    if (directory === parentDirectory) {
+        return undefined;
+    }
+    return walkForTsConfig(parentDirectory, readdirSync);
+}
+exports.walkForTsConfig = walkForTsConfig;
+function loadTsconfig(configFilePath, 
+// eslint-disable-next-line no-shadow
+existsSync, readFileSync) {
+    if (existsSync === void 0) { existsSync = fs.existsSync; }
+    if (readFileSync === void 0) { readFileSync = function (filename) {
+        return fs.readFileSync(filename, "utf8");
+    }; }
+    if (!existsSync(configFilePath)) {
+        return undefined;
+    }
+    var configString = readFileSync(configFilePath);
+    var cleanedJson = StripBom(configString);
+    var config;
+    try {
+        config = JSON5.parse(cleanedJson);
+    }
+    catch (e) {
+        throw new Error("".concat(configFilePath, " is malformed ").concat(e.message));
+    }
+    var extendedConfig = config.extends;
+    if (extendedConfig) {
+        if (typeof extendedConfig === "string" &&
+            extendedConfig.indexOf(".json") === -1) {
+            extendedConfig += ".json";
+        }
+        var currentDir = path.dirname(configFilePath);
+        var extendedConfigPath = path.join(currentDir, extendedConfig);
+        if (extendedConfig.indexOf("/") !== -1 &&
+            extendedConfig.indexOf(".") !== -1 &&
+            !existsSync(extendedConfigPath)) {
+            extendedConfigPath = path.join(currentDir, "node_modules", extendedConfig);
+        }
+        var base = loadTsconfig(extendedConfigPath, existsSync, readFileSync) || {};
+        // baseUrl should be interpreted as relative to the base tsconfig,
+        // but we need to update it so it is relative to the original tsconfig being loaded
+        if (base.compilerOptions && base.compilerOptions.baseUrl) {
+            var extendsDir = path.dirname(extendedConfig);
+            base.compilerOptions.baseUrl = path.join(extendsDir, base.compilerOptions.baseUrl);
+        }
+        return __assign(__assign(__assign({}, base), config), { compilerOptions: __assign(__assign({}, base.compilerOptions), config.compilerOptions) });
+    }
+    return config;
+}
+exports.loadTsconfig = loadTsconfig;
+//# sourceMappingURL=tsconfig-loader.js.map
 
 /***/ }),
 
-/***/ 28440:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
-
-var common = __nccwpck_require__(17673);
-var fs = __nccwpck_require__(57147);
+/***/ 65891:
+/***/ ((module) => {
 
-common.register('touch', _touch, {
-  cmdOptions: {
-    'a': 'atime_only',
-    'c': 'no_create',
-    'd': 'date',
-    'm': 'mtime_only',
-    'r': 'reference',
-  },
-});
+"use strict";
 
-//@
-//@ ### touch([options,] file [, file ...])
-//@ ### touch([options,] file_array)
-//@
-//@ Available options:
-//@
-//@ + `-a`: Change only the access time
-//@ + `-c`: Do not create any files
-//@ + `-m`: Change only the modification time
-//@ + `-d DATE`: Parse `DATE` and use it instead of current time
-//@ + `-r FILE`: Use `FILE`'s times instead of current time
-//@
-//@ Examples:
-//@
-//@ ```javascript
-//@ touch('source.js');
-//@ touch('-c', '/path/to/some/dir/source.js');
-//@ touch({ '-r': FILE }, '/path/to/some/dir/source.js');
-//@ ```
-//@
-//@ Update the access and modification times of each `FILE` to the current time.
-//@ A `FILE` argument that does not exist is created empty, unless `-c` is supplied.
-//@ This is a partial implementation of [`touch(1)`](http://linux.die.net/man/1/touch).
-function _touch(opts, files) {
-  if (!files) {
-    common.error('no files given');
-  } else if (typeof files === 'string') {
-    files = [].slice.call(arguments, 1);
-  } else {
-    common.error('file arg should be a string file path or an Array of string file paths');
-  }
+module.exports = x => {
+	if (typeof x !== 'string') {
+		throw new TypeError('Expected a string, got ' + typeof x);
+	}
 
-  files.forEach(function (f) {
-    touchFile(opts, f);
-  });
-  return '';
-}
+	// Catches EFBBBF (UTF-8 BOM) because the buffer-to-string
+	// conversion translates it to FEFF (UTF-16 BOM)
+	if (x.charCodeAt(0) === 0xFEFF) {
+		return x.slice(1);
+	}
 
-function touchFile(opts, file) {
-  var stat = tryStatFile(file);
+	return x;
+};
 
-  if (stat && stat.isDirectory()) {
-    // don't error just exit
-    return;
-  }
 
-  // if the file doesn't already exist and the user has specified --no-create then
-  // this script is finished
-  if (!stat && opts.no_create) {
-    return;
-  }
+/***/ }),
 
-  // open the file and then close it. this will create it if it doesn't exist but will
-  // not truncate the file
-  fs.closeSync(fs.openSync(file, 'a'));
+/***/ 41464:
+/***/ ((module) => {
 
-  //
-  // Set timestamps
-  //
+/******************************************************************************
+Copyright (c) Microsoft Corporation.
 
-  // setup some defaults
-  var now = new Date();
-  var mtime = opts.date || now;
-  var atime = opts.date || now;
+Permission to use, copy, modify, and/or distribute this software for any
+purpose with or without fee is hereby granted.
 
-  // use reference file
-  if (opts.reference) {
-    var refStat = tryStatFile(opts.reference);
-    if (!refStat) {
-      common.error('failed to get attributess of ' + opts.reference);
+THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH
+REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY
+AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,
+INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM
+LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR
+OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
+PERFORMANCE OF THIS SOFTWARE.
+***************************************************************************** */
+/* global global, define, Symbol, Reflect, Promise, SuppressedError */
+var __extends;
+var __assign;
+var __rest;
+var __decorate;
+var __param;
+var __esDecorate;
+var __runInitializers;
+var __propKey;
+var __setFunctionName;
+var __metadata;
+var __awaiter;
+var __generator;
+var __exportStar;
+var __values;
+var __read;
+var __spread;
+var __spreadArrays;
+var __spreadArray;
+var __await;
+var __asyncGenerator;
+var __asyncDelegator;
+var __asyncValues;
+var __makeTemplateObject;
+var __importStar;
+var __importDefault;
+var __classPrivateFieldGet;
+var __classPrivateFieldSet;
+var __classPrivateFieldIn;
+var __createBinding;
+var __addDisposableResource;
+var __disposeResources;
+(function (factory) {
+    var root = typeof global === "object" ? global : typeof self === "object" ? self : typeof this === "object" ? this : {};
+    if (typeof define === "function" && define.amd) {
+        define("tslib", ["exports"], function (exports) { factory(createExporter(root, createExporter(exports))); });
     }
-    mtime = refStat.mtime;
-    atime = refStat.atime;
-  } else if (opts.date) {
-    mtime = opts.date;
-    atime = opts.date;
-  }
-
-  if (opts.atime_only && opts.mtime_only) {
-    // keep the new values of mtime and atime like GNU
-  } else if (opts.atime_only) {
-    mtime = stat.mtime;
-  } else if (opts.mtime_only) {
-    atime = stat.atime;
-  }
-
-  fs.utimesSync(file, atime, mtime);
-}
-
-module.exports = _touch;
+    else if ( true && typeof module.exports === "object") {
+        factory(createExporter(root, createExporter(module.exports)));
+    }
+    else {
+        factory(createExporter(root));
+    }
+    function createExporter(exports, previous) {
+        if (exports !== root) {
+            if (typeof Object.create === "function") {
+                Object.defineProperty(exports, "__esModule", { value: true });
+            }
+            else {
+                exports.__esModule = true;
+            }
+        }
+        return function (id, v) { return exports[id] = previous ? previous(id, v) : v; };
+    }
+})
+(function (exporter) {
+    var extendStatics = Object.setPrototypeOf ||
+        ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
+        function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };
 
-function tryStatFile(filePath) {
-  try {
-    return common.statFollowLinks(filePath);
-  } catch (e) {
-    return null;
-  }
-}
+    __extends = function (d, b) {
+        if (typeof b !== "function" && b !== null)
+            throw new TypeError("Class extends value " + String(b) + " is not a constructor or null");
+        extendStatics(d, b);
+        function __() { this.constructor = d; }
+        d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
+    };
 
+    __assign = Object.assign || function (t) {
+        for (var s, i = 1, n = arguments.length; i < n; i++) {
+            s = arguments[i];
+            for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];
+        }
+        return t;
+    };
 
-/***/ }),
+    __rest = function (s, e) {
+        var t = {};
+        for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
+            t[p] = s[p];
+        if (s != null && typeof Object.getOwnPropertySymbols === "function")
+            for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
+                if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
+                    t[p[i]] = s[p[i]];
+            }
+        return t;
+    };
 
-/***/ 55499:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+    __decorate = function (decorators, target, key, desc) {
+        var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
+        if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
+        else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
+        return c > 3 && r && Object.defineProperty(target, key, r), r;
+    };
 
-var common = __nccwpck_require__(17673);
-var fs = __nccwpck_require__(57147);
+    __param = function (paramIndex, decorator) {
+        return function (target, key) { decorator(target, key, paramIndex); }
+    };
 
-// add c spaces to the left of str
-function lpad(c, str) {
-  var res = '' + str;
-  if (res.length < c) {
-    res = Array((c - res.length) + 1).join(' ') + res;
-  }
-  return res;
-}
+    __esDecorate = function (ctor, descriptorIn, decorators, contextIn, initializers, extraInitializers) {
+        function accept(f) { if (f !== void 0 && typeof f !== "function") throw new TypeError("Function expected"); return f; }
+        var kind = contextIn.kind, key = kind === "getter" ? "get" : kind === "setter" ? "set" : "value";
+        var target = !descriptorIn && ctor ? contextIn["static"] ? ctor : ctor.prototype : null;
+        var descriptor = descriptorIn || (target ? Object.getOwnPropertyDescriptor(target, contextIn.name) : {});
+        var _, done = false;
+        for (var i = decorators.length - 1; i >= 0; i--) {
+            var context = {};
+            for (var p in contextIn) context[p] = p === "access" ? {} : contextIn[p];
+            for (var p in contextIn.access) context.access[p] = contextIn.access[p];
+            context.addInitializer = function (f) { if (done) throw new TypeError("Cannot add initializers after decoration has completed"); extraInitializers.push(accept(f || null)); };
+            var result = (0, decorators[i])(kind === "accessor" ? { get: descriptor.get, set: descriptor.set } : descriptor[key], context);
+            if (kind === "accessor") {
+                if (result === void 0) continue;
+                if (result === null || typeof result !== "object") throw new TypeError("Object expected");
+                if (_ = accept(result.get)) descriptor.get = _;
+                if (_ = accept(result.set)) descriptor.set = _;
+                if (_ = accept(result.init)) initializers.unshift(_);
+            }
+            else if (_ = accept(result)) {
+                if (kind === "field") initializers.unshift(_);
+                else descriptor[key] = _;
+            }
+        }
+        if (target) Object.defineProperty(target, contextIn.name, descriptor);
+        done = true;
+    };
 
-common.register('uniq', _uniq, {
-  canReceivePipe: true,
-  cmdOptions: {
-    'i': 'ignoreCase',
-    'c': 'count',
-    'd': 'duplicates',
-  },
-});
+    __runInitializers = function (thisArg, initializers, value) {
+        var useValue = arguments.length > 2;
+        for (var i = 0; i < initializers.length; i++) {
+            value = useValue ? initializers[i].call(thisArg, value) : initializers[i].call(thisArg);
+        }
+        return useValue ? value : void 0;
+    };
 
-//@
-//@ ### uniq([options,] [input, [output]])
-//@
-//@ Available options:
-//@
-//@ + `-i`: Ignore case while comparing
-//@ + `-c`: Prefix lines by the number of occurrences
-//@ + `-d`: Only print duplicate lines, one for each group of identical lines
-//@
-//@ Examples:
-//@
-//@ ```javascript
-//@ uniq('foo.txt');
-//@ uniq('-i', 'foo.txt');
-//@ uniq('-cd', 'foo.txt', 'bar.txt');
-//@ ```
-//@
-//@ Filter adjacent matching lines from `input`.
-function _uniq(options, input, output) {
-  // Check if this is coming from a pipe
-  var pipe = common.readFromPipe();
+    __propKey = function (x) {
+        return typeof x === "symbol" ? x : "".concat(x);
+    };
 
-  if (!pipe) {
-    if (!input) common.error('no input given');
+    __setFunctionName = function (f, name, prefix) {
+        if (typeof name === "symbol") name = name.description ? "[".concat(name.description, "]") : "";
+        return Object.defineProperty(f, "name", { configurable: true, value: prefix ? "".concat(prefix, " ", name) : name });
+    };
 
-    if (!fs.existsSync(input)) {
-      common.error(input + ': No such file or directory');
-    } else if (common.statFollowLinks(input).isDirectory()) {
-      common.error("error reading '" + input + "'");
-    }
-  }
-  if (output && fs.existsSync(output) && common.statFollowLinks(output).isDirectory()) {
-    common.error(output + ': Is a directory');
-  }
+    __metadata = function (metadataKey, metadataValue) {
+        if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(metadataKey, metadataValue);
+    };
 
-  var lines = (input ? fs.readFileSync(input, 'utf8') : pipe).
-              trimRight().
-              split('\n');
+    __awaiter = function (thisArg, _arguments, P, generator) {
+        function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
+        return new (P || (P = Promise))(function (resolve, reject) {
+            function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
+            function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
+            function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
+            step((generator = generator.apply(thisArg, _arguments || [])).next());
+        });
+    };
 
-  var compare = function (a, b) {
-    return options.ignoreCase ?
-           a.toLocaleLowerCase().localeCompare(b.toLocaleLowerCase()) :
-           a.localeCompare(b);
-  };
-  var uniqed = lines.reduceRight(function (res, e) {
-    // Perform uniq -c on the input
-    if (res.length === 0) {
-      return [{ count: 1, ln: e }];
-    } else if (compare(res[0].ln, e) === 0) {
-      return [{ count: res[0].count + 1, ln: e }].concat(res.slice(1));
-    } else {
-      return [{ count: 1, ln: e }].concat(res);
-    }
-  }, []).filter(function (obj) {
-                 // Do we want only duplicated objects?
-    return options.duplicates ? obj.count > 1 : true;
-  }).map(function (obj) {
-                 // Are we tracking the counts of each line?
-    return (options.count ? (lpad(7, obj.count) + ' ') : '') + obj.ln;
-  }).join('\n') + '\n';
+    __generator = function (thisArg, body) {
+        var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;
+        return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
+        function verb(n) { return function (v) { return step([n, v]); }; }
+        function step(op) {
+            if (f) throw new TypeError("Generator is already executing.");
+            while (g && (g = 0, op[0] && (_ = 0)), _) try {
+                if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
+                if (y = 0, t) op = [op[0] & 2, t.value];
+                switch (op[0]) {
+                    case 0: case 1: t = op; break;
+                    case 4: _.label++; return { value: op[1], done: false };
+                    case 5: _.label++; y = op[1]; op = [0]; continue;
+                    case 7: op = _.ops.pop(); _.trys.pop(); continue;
+                    default:
+                        if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
+                        if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
+                        if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
+                        if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
+                        if (t[2]) _.ops.pop();
+                        _.trys.pop(); continue;
+                }
+                op = body.call(thisArg, _);
+            } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
+            if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
+        }
+    };
 
-  if (output) {
-    (new common.ShellString(uniqed)).to(output);
-    // if uniq writes to output, nothing is passed to the next command in the pipeline (if any)
-    return '';
-  } else {
-    return uniqed;
-  }
-}
+    __exportStar = function(m, o) {
+        for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(o, p)) __createBinding(o, m, p);
+    };
 
-module.exports = _uniq;
+    __createBinding = Object.create ? (function(o, m, k, k2) {
+        if (k2 === undefined) k2 = k;
+        var desc = Object.getOwnPropertyDescriptor(m, k);
+        if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
+            desc = { enumerable: true, get: function() { return m[k]; } };
+        }
+        Object.defineProperty(o, k2, desc);
+    }) : (function(o, m, k, k2) {
+        if (k2 === undefined) k2 = k;
+        o[k2] = m[k];
+    });
 
+    __values = function (o) {
+        var s = typeof Symbol === "function" && Symbol.iterator, m = s && o[s], i = 0;
+        if (m) return m.call(o);
+        if (o && typeof o.length === "number") return {
+            next: function () {
+                if (o && i >= o.length) o = void 0;
+                return { value: o && o[i++], done: !o };
+            }
+        };
+        throw new TypeError(s ? "Object is not iterable." : "Symbol.iterator is not defined.");
+    };
 
-/***/ }),
+    __read = function (o, n) {
+        var m = typeof Symbol === "function" && o[Symbol.iterator];
+        if (!m) return o;
+        var i = m.call(o), r, ar = [], e;
+        try {
+            while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);
+        }
+        catch (error) { e = { error: error }; }
+        finally {
+            try {
+                if (r && !r.done && (m = i["return"])) m.call(i);
+            }
+            finally { if (e) throw e.error; }
+        }
+        return ar;
+    };
 
-/***/ 5405:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+    /** @deprecated */
+    __spread = function () {
+        for (var ar = [], i = 0; i < arguments.length; i++)
+            ar = ar.concat(__read(arguments[i]));
+        return ar;
+    };
 
-var common = __nccwpck_require__(17673);
-var fs = __nccwpck_require__(57147);
-var path = __nccwpck_require__(71017);
+    /** @deprecated */
+    __spreadArrays = function () {
+        for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;
+        for (var r = Array(s), k = 0, i = 0; i < il; i++)
+            for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)
+                r[k] = a[j];
+        return r;
+    };
 
-common.register('which', _which, {
-  allowGlobbing: false,
-  cmdOptions: {
-    'a': 'all',
-  },
-});
+    __spreadArray = function (to, from, pack) {
+        if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {
+            if (ar || !(i in from)) {
+                if (!ar) ar = Array.prototype.slice.call(from, 0, i);
+                ar[i] = from[i];
+            }
+        }
+        return to.concat(ar || Array.prototype.slice.call(from));
+    };
 
-// XP's system default value for `PATHEXT` system variable, just in case it's not
-// set on Windows.
-var XP_DEFAULT_PATHEXT = '.com;.exe;.bat;.cmd;.vbs;.vbe;.js;.jse;.wsf;.wsh';
+    __await = function (v) {
+        return this instanceof __await ? (this.v = v, this) : new __await(v);
+    };
 
-// For earlier versions of NodeJS that doesn't have a list of constants (< v6)
-var FILE_EXECUTABLE_MODE = 1;
+    __asyncGenerator = function (thisArg, _arguments, generator) {
+        if (!Symbol.asyncIterator) throw new TypeError("Symbol.asyncIterator is not defined.");
+        var g = generator.apply(thisArg, _arguments || []), i, q = [];
+        return i = {}, verb("next"), verb("throw"), verb("return"), i[Symbol.asyncIterator] = function () { return this; }, i;
+        function verb(n) { if (g[n]) i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; }
+        function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } }
+        function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r);  }
+        function fulfill(value) { resume("next", value); }
+        function reject(value) { resume("throw", value); }
+        function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); }
+    };
 
-function isWindowsPlatform() {
-  return process.platform === 'win32';
-}
+    __asyncDelegator = function (o) {
+        var i, p;
+        return i = {}, verb("next"), verb("throw", function (e) { throw e; }), verb("return"), i[Symbol.iterator] = function () { return this; }, i;
+        function verb(n, f) { i[n] = o[n] ? function (v) { return (p = !p) ? { value: __await(o[n](v)), done: false } : f ? f(v) : v; } : f; }
+    };
 
-// Cross-platform method for splitting environment `PATH` variables
-function splitPath(p) {
-  return p ? p.split(path.delimiter) : [];
-}
+    __asyncValues = function (o) {
+        if (!Symbol.asyncIterator) throw new TypeError("Symbol.asyncIterator is not defined.");
+        var m = o[Symbol.asyncIterator], i;
+        return m ? m.call(o) : (o = typeof __values === "function" ? __values(o) : o[Symbol.iterator](), i = {}, verb("next"), verb("throw"), verb("return"), i[Symbol.asyncIterator] = function () { return this; }, i);
+        function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; }
+        function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); }
+    };
 
-// Tests are running all cases for this func but it stays uncovered by codecov due to unknown reason
-/* istanbul ignore next */
-function isExecutable(pathName) {
-  try {
-    // TODO(node-support): replace with fs.constants.X_OK once remove support for node < v6
-    fs.accessSync(pathName, FILE_EXECUTABLE_MODE);
-  } catch (err) {
-    return false;
-  }
-  return true;
-}
+    __makeTemplateObject = function (cooked, raw) {
+        if (Object.defineProperty) { Object.defineProperty(cooked, "raw", { value: raw }); } else { cooked.raw = raw; }
+        return cooked;
+    };
 
-function checkPath(pathName) {
-  return fs.existsSync(pathName) && !common.statFollowLinks(pathName).isDirectory()
-    && (isWindowsPlatform() || isExecutable(pathName));
-}
+    var __setModuleDefault = Object.create ? (function(o, v) {
+        Object.defineProperty(o, "default", { enumerable: true, value: v });
+    }) : function(o, v) {
+        o["default"] = v;
+    };
 
-//@
-//@ ### which(command)
-//@
-//@ Examples:
-//@
-//@ ```javascript
-//@ var nodeExec = which('node');
-//@ ```
-//@
-//@ Searches for `command` in the system's `PATH`. On Windows, this uses the
-//@ `PATHEXT` variable to append the extension if it's not already executable.
-//@ Returns string containing the absolute path to `command`.
-function _which(options, cmd) {
-  if (!cmd) common.error('must specify command');
+    __importStar = function (mod) {
+        if (mod && mod.__esModule) return mod;
+        var result = {};
+        if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
+        __setModuleDefault(result, mod);
+        return result;
+    };
 
-  var isWindows = isWindowsPlatform();
-  var pathArray = splitPath(process.env.PATH);
+    __importDefault = function (mod) {
+        return (mod && mod.__esModule) ? mod : { "default": mod };
+    };
 
-  var queryMatches = [];
+    __classPrivateFieldGet = function (receiver, state, kind, f) {
+        if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a getter");
+        if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot read private member from an object whose class did not declare it");
+        return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
+    };
 
-  // No relative/absolute paths provided?
-  if (cmd.indexOf('/') === -1) {
-    // Assume that there are no extensions to append to queries (this is the
-    // case for unix)
-    var pathExtArray = [''];
-    if (isWindows) {
-      // In case the PATHEXT variable is somehow not set (e.g.
-      // child_process.spawn with an empty environment), use the XP default.
-      var pathExtEnv = process.env.PATHEXT || XP_DEFAULT_PATHEXT;
-      pathExtArray = splitPath(pathExtEnv.toUpperCase());
-    }
+    __classPrivateFieldSet = function (receiver, state, value, kind, f) {
+        if (kind === "m") throw new TypeError("Private method is not writable");
+        if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a setter");
+        if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot write private member to an object whose class did not declare it");
+        return (kind === "a" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;
+    };
 
-    // Search for command in PATH
-    for (var k = 0; k < pathArray.length; k++) {
-      // already found it
-      if (queryMatches.length > 0 && !options.all) break;
+    __classPrivateFieldIn = function (state, receiver) {
+        if (receiver === null || (typeof receiver !== "object" && typeof receiver !== "function")) throw new TypeError("Cannot use 'in' operator on non-object");
+        return typeof state === "function" ? receiver === state : state.has(receiver);
+    };
 
-      var attempt = path.resolve(pathArray[k], cmd);
+    __addDisposableResource = function (env, value, async) {
+        if (value !== null && value !== void 0) {
+            if (typeof value !== "object" && typeof value !== "function") throw new TypeError("Object expected.");
+            var dispose;
+            if (async) {
+                if (!Symbol.asyncDispose) throw new TypeError("Symbol.asyncDispose is not defined.");
+                dispose = value[Symbol.asyncDispose];
+            }
+            if (dispose === void 0) {
+                if (!Symbol.dispose) throw new TypeError("Symbol.dispose is not defined.");
+                dispose = value[Symbol.dispose];
+            }
+            if (typeof dispose !== "function") throw new TypeError("Object not disposable.");
+            env.stack.push({ value: value, dispose: dispose, async: async });
+        }
+        else if (async) {
+            env.stack.push({ async: true });
+        }
+        return value;
+    };
 
-      if (isWindows) {
-        attempt = attempt.toUpperCase();
-      }
+    var _SuppressedError = typeof SuppressedError === "function" ? SuppressedError : function (error, suppressed, message) {
+        var e = new Error(message);
+        return e.name = "SuppressedError", e.error = error, e.suppressed = suppressed, e;
+    };
 
-      var match = attempt.match(/\.[^<>:"/\|?*.]+$/);
-      if (match && pathExtArray.indexOf(match[0]) >= 0) { // this is Windows-only
-        // The user typed a query with the file extension, like
-        // `which('node.exe')`
-        if (checkPath(attempt)) {
-          queryMatches.push(attempt);
-          break;
+    __disposeResources = function (env) {
+        function fail(e) {
+            env.error = env.hasError ? new _SuppressedError(e, env.error, "An error was suppressed during disposal.") : e;
+            env.hasError = true;
         }
-      } else { // All-platforms
-        // Cycle through the PATHEXT array, and check each extension
-        // Note: the array is always [''] on Unix
-        for (var i = 0; i < pathExtArray.length; i++) {
-          var ext = pathExtArray[i];
-          var newAttempt = attempt + ext;
-          if (checkPath(newAttempt)) {
-            queryMatches.push(newAttempt);
-            break;
-          }
+        function next() {
+            while (env.stack.length) {
+                var rec = env.stack.pop();
+                try {
+                    var result = rec.dispose && rec.dispose.call(rec.value);
+                    if (rec.async) return Promise.resolve(result).then(next, function(e) { fail(e); return next(); });
+                }
+                catch (e) {
+                    fail(e);
+                }
+            }
+            if (env.hasError) throw env.error;
         }
-      }
-    }
-  } else if (checkPath(cmd)) { // a valid absolute or relative path
-    queryMatches.push(path.resolve(cmd));
-  }
+        return next();
+    };
 
-  if (queryMatches.length > 0) {
-    return options.all ? queryMatches : queryMatches[0];
-  }
-  return options.all ? [] : null;
-}
-module.exports = _which;
+    exporter("__extends", __extends);
+    exporter("__assign", __assign);
+    exporter("__rest", __rest);
+    exporter("__decorate", __decorate);
+    exporter("__param", __param);
+    exporter("__esDecorate", __esDecorate);
+    exporter("__runInitializers", __runInitializers);
+    exporter("__propKey", __propKey);
+    exporter("__setFunctionName", __setFunctionName);
+    exporter("__metadata", __metadata);
+    exporter("__awaiter", __awaiter);
+    exporter("__generator", __generator);
+    exporter("__exportStar", __exportStar);
+    exporter("__createBinding", __createBinding);
+    exporter("__values", __values);
+    exporter("__read", __read);
+    exporter("__spread", __spread);
+    exporter("__spreadArrays", __spreadArrays);
+    exporter("__spreadArray", __spreadArray);
+    exporter("__await", __await);
+    exporter("__asyncGenerator", __asyncGenerator);
+    exporter("__asyncDelegator", __asyncDelegator);
+    exporter("__asyncValues", __asyncValues);
+    exporter("__makeTemplateObject", __makeTemplateObject);
+    exporter("__importStar", __importStar);
+    exporter("__importDefault", __importDefault);
+    exporter("__classPrivateFieldGet", __classPrivateFieldGet);
+    exporter("__classPrivateFieldSet", __classPrivateFieldSet);
+    exporter("__classPrivateFieldIn", __classPrivateFieldIn);
+    exporter("__addDisposableResource", __addDisposableResource);
+    exporter("__disposeResources", __disposeResources);
+});
 
 
 /***/ }),
 
-/***/ 42059:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
+/***/ 2932:
+/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
-var SourceMapConsumer = (__nccwpck_require__(36096).SourceMapConsumer);
-var path = __nccwpck_require__(71017);
+module.exports = __nccwpck_require__(17146);
 
-var fs;
-try {
-  fs = __nccwpck_require__(57147);
-  if (!fs.existsSync || !fs.readFileSync) {
-    // fs doesn't have all methods we need
-    fs = null;
-  }
-} catch (err) {
-  /* nop */
-}
 
-var bufferFrom = __nccwpck_require__(82415);
+/***/ }),
 
-// Only install once if called multiple times
-var errorFormatterInstalled = false;
-var uncaughtShimInstalled = false;
+/***/ 17146:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
-// If true, the caches are reset before a stack trace formatting operation
-var emptyCacheBetweenOperations = false;
+"use strict";
 
-// Supports {browser, node, auto}
-var environment = "auto";
 
-// Maps a file path to a string containing the file contents
-var fileContentsCache = {};
+var net = __nccwpck_require__(41808);
+var tls = __nccwpck_require__(24404);
+var http = __nccwpck_require__(13685);
+var https = __nccwpck_require__(95687);
+var events = __nccwpck_require__(82361);
+var assert = __nccwpck_require__(39491);
+var util = __nccwpck_require__(73837);
 
-// Maps a file path to a source map for that file
-var sourceMapCache = {};
 
-// Regex for detecting source maps
-var reSourceMap = /^data:application\/json[^,]+base64,/;
+exports.httpOverHttp = httpOverHttp;
+exports.httpsOverHttp = httpsOverHttp;
+exports.httpOverHttps = httpOverHttps;
+exports.httpsOverHttps = httpsOverHttps;
 
-// Priority list of retrieve handlers
-var retrieveFileHandlers = [];
-var retrieveMapHandlers = [];
 
-function isInBrowser() {
-  if (environment === "browser")
-    return true;
-  if (environment === "node")
-    return false;
-  return ((typeof window !== 'undefined') && (typeof XMLHttpRequest === 'function') && !(window.require && window.module && window.process && window.process.type === "renderer"));
+function httpOverHttp(options) {
+  var agent = new TunnelingAgent(options);
+  agent.request = http.request;
+  return agent;
 }
 
-function hasGlobalProcessEventEmitter() {
-  return ((typeof process === 'object') && (process !== null) && (typeof process.on === 'function'));
+function httpsOverHttp(options) {
+  var agent = new TunnelingAgent(options);
+  agent.request = http.request;
+  agent.createSocket = createSecureSocket;
+  agent.defaultPort = 443;
+  return agent;
 }
 
-function handlerExec(list) {
-  return function(arg) {
-    for (var i = 0; i < list.length; i++) {
-      var ret = list[i](arg);
-      if (ret) {
-        return ret;
-      }
-    }
-    return null;
-  };
+function httpOverHttps(options) {
+  var agent = new TunnelingAgent(options);
+  agent.request = https.request;
+  return agent;
 }
 
-var retrieveFile = handlerExec(retrieveFileHandlers);
+function httpsOverHttps(options) {
+  var agent = new TunnelingAgent(options);
+  agent.request = https.request;
+  agent.createSocket = createSecureSocket;
+  agent.defaultPort = 443;
+  return agent;
+}
 
-retrieveFileHandlers.push(function(path) {
-  // Trim the path to make sure there is no extra whitespace.
-  path = path.trim();
-  if (/^file:/.test(path)) {
-    // existsSync/readFileSync can't handle file protocol, but once stripped, it works
-    path = path.replace(/file:\/\/\/(\w:)?/, function(protocol, drive) {
-      return drive ?
-        '' : // file:///C:/dir/file -> C:/dir/file
-        '/'; // file:///root-dir/file -> /root-dir/file
-    });
-  }
-  if (path in fileContentsCache) {
-    return fileContentsCache[path];
-  }
 
-  var contents = '';
-  try {
-    if (!fs) {
-      // Use SJAX if we are in the browser
-      var xhr = new XMLHttpRequest();
-      xhr.open('GET', path, /** async */ false);
-      xhr.send(null);
-      if (xhr.readyState === 4 && xhr.status === 200) {
-        contents = xhr.responseText;
+function TunnelingAgent(options) {
+  var self = this;
+  self.options = options || {};
+  self.proxyOptions = self.options.proxy || {};
+  self.maxSockets = self.options.maxSockets || http.Agent.defaultMaxSockets;
+  self.requests = [];
+  self.sockets = [];
+
+  self.on('free', function onFree(socket, host, port, localAddress) {
+    var options = toOptions(host, port, localAddress);
+    for (var i = 0, len = self.requests.length; i < len; ++i) {
+      var pending = self.requests[i];
+      if (pending.host === options.host && pending.port === options.port) {
+        // Detect the request to connect same origin server,
+        // reuse the connection.
+        self.requests.splice(i, 1);
+        pending.request.onSocket(socket);
+        return;
       }
-    } else if (fs.existsSync(path)) {
-      // Otherwise, use the filesystem
-      contents = fs.readFileSync(path, 'utf8');
     }
-  } catch (er) {
-    /* ignore any errors */
-  }
+    socket.destroy();
+    self.removeSocket(socket);
+  });
+}
+util.inherits(TunnelingAgent, events.EventEmitter);
 
-  return fileContentsCache[path] = contents;
-});
+TunnelingAgent.prototype.addRequest = function addRequest(req, host, port, localAddress) {
+  var self = this;
+  var options = mergeOptions({request: req}, self.options, toOptions(host, port, localAddress));
 
-// Support URLs relative to a directory, but be careful about a protocol prefix
-// in case we are in the browser (i.e. directories may start with "http://" or "file:///")
-function supportRelativeURL(file, url) {
-  if (!file) return url;
-  var dir = path.dirname(file);
-  var match = /^\w+:\/\/[^\/]*/.exec(dir);
-  var protocol = match ? match[0] : '';
-  var startPath = dir.slice(protocol.length);
-  if (protocol && /^\/\w\:/.test(startPath)) {
-    // handle file:///C:/ paths
-    protocol += '/';
-    return protocol + path.resolve(dir.slice(protocol.length), url).replace(/\\/g, '/');
+  if (self.sockets.length >= this.maxSockets) {
+    // We are over limit so we'll add it to the queue.
+    self.requests.push(options);
+    return;
   }
-  return protocol + path.resolve(dir.slice(protocol.length), url);
-}
-
-function retrieveSourceMapURL(source) {
-  var fileData;
 
-  if (isInBrowser()) {
-     try {
-       var xhr = new XMLHttpRequest();
-       xhr.open('GET', source, false);
-       xhr.send(null);
-       fileData = xhr.readyState === 4 ? xhr.responseText : null;
+  // If we are under maxSockets create a new one.
+  self.createSocket(options, function(socket) {
+    socket.on('free', onFree);
+    socket.on('close', onCloseOrRemove);
+    socket.on('agentRemove', onCloseOrRemove);
+    req.onSocket(socket);
 
-       // Support providing a sourceMappingURL via the SourceMap header
-       var sourceMapHeader = xhr.getResponseHeader("SourceMap") ||
-                             xhr.getResponseHeader("X-SourceMap");
-       if (sourceMapHeader) {
-         return sourceMapHeader;
-       }
-     } catch (e) {
-     }
-  }
+    function onFree() {
+      self.emit('free', socket, options);
+    }
 
-  // Get the URL of the source map
-  fileData = retrieveFile(source);
-  var re = /(?:\/\/[@#][\s]*sourceMappingURL=([^\s'"]+)[\s]*$)|(?:\/\*[@#][\s]*sourceMappingURL=([^\s*'"]+)[\s]*(?:\*\/)[\s]*$)/mg;
-  // Keep executing the search to find the *last* sourceMappingURL to avoid
-  // picking up sourceMappingURLs from comments, strings, etc.
-  var lastMatch, match;
-  while (match = re.exec(fileData)) lastMatch = match;
-  if (!lastMatch) return null;
-  return lastMatch[1];
+    function onCloseOrRemove(err) {
+      self.removeSocket(socket);
+      socket.removeListener('free', onFree);
+      socket.removeListener('close', onCloseOrRemove);
+      socket.removeListener('agentRemove', onCloseOrRemove);
+    }
+  });
 };
 
-// Can be overridden by the retrieveSourceMap option to install. Takes a
-// generated source filename; returns a {map, optional url} object, or null if
-// there is no source map.  The map field may be either a string or the parsed
-// JSON object (ie, it must be a valid argument to the SourceMapConsumer
-// constructor).
-var retrieveSourceMap = handlerExec(retrieveMapHandlers);
-retrieveMapHandlers.push(function(source) {
-  var sourceMappingURL = retrieveSourceMapURL(source);
-  if (!sourceMappingURL) return null;
+TunnelingAgent.prototype.createSocket = function createSocket(options, cb) {
+  var self = this;
+  var placeholder = {};
+  self.sockets.push(placeholder);
 
-  // Read the contents of the source map
-  var sourceMapData;
-  if (reSourceMap.test(sourceMappingURL)) {
-    // Support source map URL as a data url
-    var rawData = sourceMappingURL.slice(sourceMappingURL.indexOf(',') + 1);
-    sourceMapData = bufferFrom(rawData, "base64").toString();
-    sourceMappingURL = source;
-  } else {
-    // Support source map URLs relative to the source URL
-    sourceMappingURL = supportRelativeURL(source, sourceMappingURL);
-    sourceMapData = retrieveFile(sourceMappingURL);
+  var connectOptions = mergeOptions({}, self.proxyOptions, {
+    method: 'CONNECT',
+    path: options.host + ':' + options.port,
+    agent: false,
+    headers: {
+      host: options.host + ':' + options.port
+    }
+  });
+  if (options.localAddress) {
+    connectOptions.localAddress = options.localAddress;
+  }
+  if (connectOptions.proxyAuth) {
+    connectOptions.headers = connectOptions.headers || {};
+    connectOptions.headers['Proxy-Authorization'] = 'Basic ' +
+        new Buffer(connectOptions.proxyAuth).toString('base64');
   }
 
-  if (!sourceMapData) {
-    return null;
+  debug('making CONNECT request');
+  var connectReq = self.request(connectOptions);
+  connectReq.useChunkedEncodingByDefault = false; // for v0.6
+  connectReq.once('response', onResponse); // for v0.6
+  connectReq.once('upgrade', onUpgrade);   // for v0.6
+  connectReq.once('connect', onConnect);   // for v0.7 or later
+  connectReq.once('error', onError);
+  connectReq.end();
+
+  function onResponse(res) {
+    // Very hacky. This is necessary to avoid http-parser leaks.
+    res.upgrade = true;
   }
 
-  return {
-    url: sourceMappingURL,
-    map: sourceMapData
-  };
-});
+  function onUpgrade(res, socket, head) {
+    // Hacky.
+    process.nextTick(function() {
+      onConnect(res, socket, head);
+    });
+  }
 
-function mapSourcePosition(position) {
-  var sourceMap = sourceMapCache[position.source];
-  if (!sourceMap) {
-    // Call the (overrideable) retrieveSourceMap function to get the source map.
-    var urlAndMap = retrieveSourceMap(position.source);
-    if (urlAndMap) {
-      sourceMap = sourceMapCache[position.source] = {
-        url: urlAndMap.url,
-        map: new SourceMapConsumer(urlAndMap.map)
-      };
+  function onConnect(res, socket, head) {
+    connectReq.removeAllListeners();
+    socket.removeAllListeners();
 
-      // Load all sources stored inline with the source map into the file cache
-      // to pretend like they are already loaded. They may not exist on disk.
-      if (sourceMap.map.sourcesContent) {
-        sourceMap.map.sources.forEach(function(source, i) {
-          var contents = sourceMap.map.sourcesContent[i];
-          if (contents) {
-            var url = supportRelativeURL(sourceMap.url, source);
-            fileContentsCache[url] = contents;
-          }
-        });
-      }
-    } else {
-      sourceMap = sourceMapCache[position.source] = {
-        url: null,
-        map: null
-      };
+    if (res.statusCode !== 200) {
+      debug('tunneling socket could not be established, statusCode=%d',
+        res.statusCode);
+      socket.destroy();
+      var error = new Error('tunneling socket could not be established, ' +
+        'statusCode=' + res.statusCode);
+      error.code = 'ECONNRESET';
+      options.request.emit('error', error);
+      self.removeSocket(placeholder);
+      return;
+    }
+    if (head.length > 0) {
+      debug('got illegal response body from proxy');
+      socket.destroy();
+      var error = new Error('got illegal response body from proxy');
+      error.code = 'ECONNRESET';
+      options.request.emit('error', error);
+      self.removeSocket(placeholder);
+      return;
     }
+    debug('tunneling connection has established');
+    self.sockets[self.sockets.indexOf(placeholder)] = socket;
+    return cb(socket);
   }
 
-  // Resolve the source URL relative to the URL of the source map
-  if (sourceMap && sourceMap.map && typeof sourceMap.map.originalPositionFor === 'function') {
-    var originalPosition = sourceMap.map.originalPositionFor(position);
+  function onError(cause) {
+    connectReq.removeAllListeners();
 
-    // Only return the original position if a matching line was found. If no
-    // matching line is found then we return position instead, which will cause
-    // the stack trace to print the path and line for the compiled file. It is
-    // better to give a precise location in the compiled file than a vague
-    // location in the original file.
-    if (originalPosition.source !== null) {
-      originalPosition.source = supportRelativeURL(
-        sourceMap.url, originalPosition.source);
-      return originalPosition;
-    }
+    debug('tunneling socket could not be established, cause=%s\n',
+          cause.message, cause.stack);
+    var error = new Error('tunneling socket could not be established, ' +
+                          'cause=' + cause.message);
+    error.code = 'ECONNRESET';
+    options.request.emit('error', error);
+    self.removeSocket(placeholder);
   }
+};
 
-  return position;
-}
+TunnelingAgent.prototype.removeSocket = function removeSocket(socket) {
+  var pos = this.sockets.indexOf(socket)
+  if (pos === -1) {
+    return;
+  }
+  this.sockets.splice(pos, 1);
 
-// Parses code generated by FormatEvalOrigin(), a function inside V8:
-// https://code.google.com/p/v8/source/browse/trunk/src/messages.js
-function mapEvalOrigin(origin) {
-  // Most eval() calls are in this format
-  var match = /^eval at ([^(]+) \((.+):(\d+):(\d+)\)$/.exec(origin);
-  if (match) {
-    var position = mapSourcePosition({
-      source: match[2],
-      line: +match[3],
-      column: match[4] - 1
+  var pending = this.requests.shift();
+  if (pending) {
+    // If we have pending requests and a socket gets closed a new one
+    // needs to be created to take over in the pool for the one that closed.
+    this.createSocket(pending, function(socket) {
+      pending.request.onSocket(socket);
     });
-    return 'eval at ' + match[1] + ' (' + position.source + ':' +
-      position.line + ':' + (position.column + 1) + ')';
   }
+};
 
-  // Parse nested eval() calls using recursion
-  match = /^eval at ([^(]+) \((.+)\)$/.exec(origin);
-  if (match) {
-    return 'eval at ' + match[1] + ' (' + mapEvalOrigin(match[2]) + ')';
-  }
+function createSecureSocket(options, cb) {
+  var self = this;
+  TunnelingAgent.prototype.createSocket.call(self, options, function(socket) {
+    var hostHeader = options.request.getHeader('host');
+    var tlsOptions = mergeOptions({}, self.options, {
+      socket: socket,
+      servername: hostHeader ? hostHeader.replace(/:.*$/, '') : options.host
+    });
 
-  // Make sure we still return useful information if we didn't find anything
-  return origin;
+    // 0 is dummy port for v0.6
+    var secureSocket = tls.connect(0, tlsOptions);
+    self.sockets[self.sockets.indexOf(socket)] = secureSocket;
+    cb(secureSocket);
+  });
 }
 
-// This is copied almost verbatim from the V8 source code at
-// https://code.google.com/p/v8/source/browse/trunk/src/messages.js. The
-// implementation of wrapCallSite() used to just forward to the actual source
-// code of CallSite.prototype.toString but unfortunately a new release of V8
-// did something to the prototype chain and broke the shim. The only fix I
-// could find was copy/paste.
-function CallSiteToString() {
-  var fileName;
-  var fileLocation = "";
-  if (this.isNative()) {
-    fileLocation = "native";
-  } else {
-    fileName = this.getScriptNameOrSourceURL();
-    if (!fileName && this.isEval()) {
-      fileLocation = this.getEvalOrigin();
-      fileLocation += ", ";  // Expecting source position to follow.
-    }
 
-    if (fileName) {
-      fileLocation += fileName;
-    } else {
-      // Source code does not originate from a file and is not native, but we
-      // can still get the source position inside the source string, e.g. in
-      // an eval string.
-      fileLocation += "";
-    }
-    var lineNumber = this.getLineNumber();
-    if (lineNumber != null) {
-      fileLocation += ":" + lineNumber;
-      var columnNumber = this.getColumnNumber();
-      if (columnNumber) {
-        fileLocation += ":" + columnNumber;
-      }
-    }
+function toOptions(host, port, localAddress) {
+  if (typeof host === 'string') { // since v0.10
+    return {
+      host: host,
+      port: port,
+      localAddress: localAddress
+    };
   }
+  return host; // for v0.11 or later
+}
 
-  var line = "";
-  var functionName = this.getFunctionName();
-  var addSuffix = true;
-  var isConstructor = this.isConstructor();
-  var isMethodCall = !(this.isToplevel() || isConstructor);
-  if (isMethodCall) {
-    var typeName = this.getTypeName();
-    // Fixes shim to be backward compatable with Node v0 to v4
-    if (typeName === "[object Object]") {
-      typeName = "null";
-    }
-    var methodName = this.getMethodName();
-    if (functionName) {
-      if (typeName && functionName.indexOf(typeName) != 0) {
-        line += typeName + ".";
-      }
-      line += functionName;
-      if (methodName && functionName.indexOf("." + methodName) != functionName.length - methodName.length - 1) {
-        line += " [as " + methodName + "]";
+function mergeOptions(target) {
+  for (var i = 1, len = arguments.length; i < len; ++i) {
+    var overrides = arguments[i];
+    if (typeof overrides === 'object') {
+      var keys = Object.keys(overrides);
+      for (var j = 0, keyLen = keys.length; j < keyLen; ++j) {
+        var k = keys[j];
+        if (overrides[k] !== undefined) {
+          target[k] = overrides[k];
+        }
       }
-    } else {
-      line += typeName + "." + (methodName || "");
     }
-  } else if (isConstructor) {
-    line += "new " + (functionName || "");
-  } else if (functionName) {
-    line += functionName;
-  } else {
-    line += fileLocation;
-    addSuffix = false;
-  }
-  if (addSuffix) {
-    line += " (" + fileLocation + ")";
   }
-  return line;
+  return target;
 }
 
-function cloneCallSite(frame) {
-  var object = {};
-  Object.getOwnPropertyNames(Object.getPrototypeOf(frame)).forEach(function(name) {
-    object[name] = /^(?:is|get)/.test(name) ? function() { return frame[name].call(frame); } : frame[name];
-  });
-  object.toString = CallSiteToString;
-  return object;
-}
 
-function wrapCallSite(frame) {
-  if(frame.isNative()) {
-    return frame;
+var debug;
+if (process.env.NODE_DEBUG && /\btunnel\b/.test(process.env.NODE_DEBUG)) {
+  debug = function() {
+    var args = Array.prototype.slice.call(arguments);
+    if (typeof args[0] === 'string') {
+      args[0] = 'TUNNEL: ' + args[0];
+    } else {
+      args.unshift('TUNNEL:');
+    }
+    console.error.apply(console, args);
   }
+} else {
+  debug = function() {};
+}
+exports.debug = debug; // for test
 
-  // Most call sites will return the source file from getFileName(), but code
-  // passed to eval() ending in "//# sourceURL=..." will return the source file
-  // from getScriptNameOrSourceURL() instead
-  var source = frame.getFileName() || frame.getScriptNameOrSourceURL();
-  if (source) {
-    var line = frame.getLineNumber();
-    var column = frame.getColumnNumber() - 1;
 
-    // Fix position in Node where some (internal) code is prepended.
-    // See https://github.com/evanw/node-source-map-support/issues/36
-    var headerLength = 62;
-    if (line === 1 && column > headerLength && !isInBrowser() && !frame.isEval()) {
-      column -= headerLength;
-    }
+/***/ }),
 
-    var position = mapSourcePosition({
-      source: source,
-      line: line,
-      column: column
-    });
-    frame = cloneCallSite(frame);
-    var originalFunctionName = frame.getFunctionName;
-    frame.getFunctionName = function() { return position.name || originalFunctionName(); };
-    frame.getFileName = function() { return position.source; };
-    frame.getLineNumber = function() { return position.line; };
-    frame.getColumnNumber = function() { return position.column + 1; };
-    frame.getScriptNameOrSourceURL = function() { return position.source; };
-    return frame;
-  }
+/***/ 81151:
+/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
-  // Code called using eval() needs special handling
-  var origin = frame.isEval() && frame.getEvalOrigin();
-  if (origin) {
-    origin = mapEvalOrigin(origin);
-    frame = cloneCallSite(frame);
-    frame.getEvalOrigin = function() { return origin; };
-    return frame;
-  }
+"use strict";
+/*! *****************************************************************************
+Copyright (c) Microsoft Corporation. All rights reserved.
+Licensed under the Apache License, Version 2.0 (the "License"); you may not use
+this file except in compliance with the License. You may obtain a copy of the
+License at http://www.apache.org/licenses/LICENSE-2.0
 
-  // If we get here then we were unable to change the source position
-  return frame;
-}
+THIS CODE IS PROVIDED ON AN *AS IS* BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
+KIND, EITHER EXPRESS OR IMPLIED, INCLUDING WITHOUT LIMITATION ANY IMPLIED
+WARRANTIES OR CONDITIONS OF TITLE, FITNESS FOR A PARTICULAR PURPOSE,
+MERCHANTABLITY OR NON-INFRINGEMENT.
 
-// This function is part of the V8 stack trace API, for more info see:
-// https://v8.dev/docs/stack-trace-api
-function prepareStackTrace(error, stack) {
-  if (emptyCacheBetweenOperations) {
-    fileContentsCache = {};
-    sourceMapCache = {};
-  }
+See the Apache Version 2.0 License for specific language governing permissions
+and limitations under the License.
+***************************************************************************** */
 
-  var name = error.name || 'Error';
-  var message = error.message || '';
-  var errorString = name + ": " + message;
 
-  return errorString + stack.map(function(frame) {
-    return '\n    at ' + wrapCallSite(frame);
-  }).join('');
-}
 
-// Generate position and snippet of original source with pointer
-function getErrorSource(error) {
-  var match = /\n    at [^(]+ \((.*):(\d+):(\d+)\)/.exec(error.stack);
-  if (match) {
-    var source = match[1];
-    var line = +match[2];
-    var column = +match[3];
+var ts = (() => {
+  var __defProp = Object.defineProperty;
+  var __getOwnPropNames = Object.getOwnPropertyNames;
+  var __esm = (fn, res) => function __init() {
+    return fn && (res = (0, fn[__getOwnPropNames(fn)[0]])(fn = 0)), res;
+  };
+  var __commonJS = (cb, mod) => function __require() {
+    return mod || (0, cb[__getOwnPropNames(cb)[0]])((mod = { exports: {} }).exports, mod), mod.exports;
+  };
+  var __export = (target, all) => {
+    for (var name in all)
+      __defProp(target, name, { get: all[name], enumerable: true });
+  };
 
-    // Support the inline sourceContents inside the source map
-    var contents = fileContentsCache[source];
+  // src/compiler/corePublic.ts
+  var versionMajorMinor, version, Comparison;
+  var init_corePublic = __esm({
+    "src/compiler/corePublic.ts"() {
+      "use strict";
+      versionMajorMinor = "5.3";
+      version = "5.3.3";
+      Comparison = /* @__PURE__ */ ((Comparison3) => {
+        Comparison3[Comparison3["LessThan"] = -1] = "LessThan";
+        Comparison3[Comparison3["EqualTo"] = 0] = "EqualTo";
+        Comparison3[Comparison3["GreaterThan"] = 1] = "GreaterThan";
+        return Comparison3;
+      })(Comparison || {});
+    }
+  });
 
-    // Support files on disk
-    if (!contents && fs && fs.existsSync(source)) {
-      try {
-        contents = fs.readFileSync(source, 'utf8');
-      } catch (er) {
-        contents = '';
+  // src/compiler/core.ts
+  function length(array) {
+    return array ? array.length : 0;
+  }
+  function forEach(array, callback) {
+    if (array) {
+      for (let i = 0; i < array.length; i++) {
+        const result = callback(array[i], i);
+        if (result) {
+          return result;
+        }
       }
     }
-
-    // Format the line from the original source code like node does
-    if (contents) {
-      var code = contents.split(/(?:\r\n|\r|\n)/)[line - 1];
-      if (code) {
-        return source + ':' + line + '\n' + code + '\n' +
-          new Array(column).join(' ') + '^';
+    return void 0;
+  }
+  function forEachRight(array, callback) {
+    if (array) {
+      for (let i = array.length - 1; i >= 0; i--) {
+        const result = callback(array[i], i);
+        if (result) {
+          return result;
+        }
       }
     }
+    return void 0;
   }
-  return null;
-}
-
-function printErrorAndExit (error) {
-  var source = getErrorSource(error);
-
-  // Ensure error is printed synchronously and not truncated
-  if (process.stderr._handle && process.stderr._handle.setBlocking) {
-    process.stderr._handle.setBlocking(true);
+  function firstDefined(array, callback) {
+    if (array === void 0) {
+      return void 0;
+    }
+    for (let i = 0; i < array.length; i++) {
+      const result = callback(array[i], i);
+      if (result !== void 0) {
+        return result;
+      }
+    }
+    return void 0;
   }
-
-  if (source) {
-    console.error();
-    console.error(source);
+  function firstDefinedIterator(iter, callback) {
+    for (const value of iter) {
+      const result = callback(value);
+      if (result !== void 0) {
+        return result;
+      }
+    }
+    return void 0;
   }
-
-  console.error(error.stack);
-  process.exit(1);
-}
-
-function shimEmitUncaughtException () {
-  var origEmit = process.emit;
-
-  process.emit = function (type) {
-    if (type === 'uncaughtException') {
-      var hasStack = (arguments[1] && arguments[1].stack);
-      var hasListeners = (this.listeners(type).length > 0);
-
-      if (hasStack && !hasListeners) {
-        return printErrorAndExit(arguments[1]);
+  function reduceLeftIterator(iterator, f, initial) {
+    let result = initial;
+    if (iterator) {
+      let pos = 0;
+      for (const value of iterator) {
+        result = f(result, value, pos);
+        pos++;
       }
     }
-
-    return origEmit.apply(this, arguments);
-  };
-}
-
-var originalRetrieveFileHandlers = retrieveFileHandlers.slice(0);
-var originalRetrieveMapHandlers = retrieveMapHandlers.slice(0);
-
-exports.wrapCallSite = wrapCallSite;
-exports.getErrorSource = getErrorSource;
-exports.mapSourcePosition = mapSourcePosition;
-exports.retrieveSourceMap = retrieveSourceMap;
-
-exports.install = function(options) {
-  options = options || {};
-
-  if (options.environment) {
-    environment = options.environment;
-    if (["node", "browser", "auto"].indexOf(environment) === -1) {
-      throw new Error("environment " + environment + " was unknown. Available options are {auto, browser, node}")
+    return result;
+  }
+  function zipWith(arrayA, arrayB, callback) {
+    const result = [];
+    Debug.assertEqual(arrayA.length, arrayB.length);
+    for (let i = 0; i < arrayA.length; i++) {
+      result.push(callback(arrayA[i], arrayB[i], i));
     }
+    return result;
   }
-
-  // Allow sources to be found by methods other than reading the files
-  // directly from disk.
-  if (options.retrieveFile) {
-    if (options.overrideRetrieveFile) {
-      retrieveFileHandlers.length = 0;
+  function intersperse(input, element) {
+    if (input.length <= 1) {
+      return input;
     }
-
-    retrieveFileHandlers.unshift(options.retrieveFile);
+    const result = [];
+    for (let i = 0, n = input.length; i < n; i++) {
+      if (i)
+        result.push(element);
+      result.push(input[i]);
+    }
+    return result;
   }
-
-  // Allow source maps to be found by methods other than reading the files
-  // directly from disk.
-  if (options.retrieveSourceMap) {
-    if (options.overrideRetrieveSourceMap) {
-      retrieveMapHandlers.length = 0;
+  function every(array, callback) {
+    if (array) {
+      for (let i = 0; i < array.length; i++) {
+        if (!callback(array[i], i)) {
+          return false;
+        }
+      }
     }
-
-    retrieveMapHandlers.unshift(options.retrieveSourceMap);
+    return true;
   }
-
-  // Support runtime transpilers that include inline source maps
-  if (options.hookRequire && !isInBrowser()) {
-    var Module;
-    try {
-      Module = __nccwpck_require__(98188);
-    } catch (err) {
-      // NOP: Loading in catch block to convert webpack error to warning.
+  function find(array, predicate, startIndex) {
+    if (array === void 0)
+      return void 0;
+    for (let i = startIndex ?? 0; i < array.length; i++) {
+      const value = array[i];
+      if (predicate(value, i)) {
+        return value;
+      }
     }
-    var $compile = Module.prototype._compile;
-
-    if (!$compile.__sourceMapSupport) {
-      Module.prototype._compile = function(content, filename) {
-        fileContentsCache[filename] = content;
-        sourceMapCache[filename] = undefined;
-        return $compile.call(this, content, filename);
-      };
-
-      Module.prototype._compile.__sourceMapSupport = true;
+    return void 0;
+  }
+  function findLast(array, predicate, startIndex) {
+    if (array === void 0)
+      return void 0;
+    for (let i = startIndex ?? array.length - 1; i >= 0; i--) {
+      const value = array[i];
+      if (predicate(value, i)) {
+        return value;
+      }
     }
+    return void 0;
   }
-
-  // Configure options
-  if (!emptyCacheBetweenOperations) {
-    emptyCacheBetweenOperations = 'emptyCacheBetweenOperations' in options ?
-      options.emptyCacheBetweenOperations : false;
+  function findIndex(array, predicate, startIndex) {
+    if (array === void 0)
+      return -1;
+    for (let i = startIndex ?? 0; i < array.length; i++) {
+      if (predicate(array[i], i)) {
+        return i;
+      }
+    }
+    return -1;
   }
-
-  // Install the error reformatter
-  if (!errorFormatterInstalled) {
-    errorFormatterInstalled = true;
-    Error.prepareStackTrace = prepareStackTrace;
+  function findLastIndex(array, predicate, startIndex) {
+    if (array === void 0)
+      return -1;
+    for (let i = startIndex ?? array.length - 1; i >= 0; i--) {
+      if (predicate(array[i], i)) {
+        return i;
+      }
+    }
+    return -1;
   }
-
-  if (!uncaughtShimInstalled) {
-    var installHandler = 'handleUncaughtExceptions' in options ?
-      options.handleUncaughtExceptions : true;
-
-    // Provide the option to not install the uncaught exception handler. This is
-    // to support other uncaught exception handlers (in test frameworks, for
-    // example). If this handler is not installed and there are no other uncaught
-    // exception handlers, uncaught exceptions will be caught by node's built-in
-    // exception handler and the process will still be terminated. However, the
-    // generated JavaScript code will be shown above the stack trace instead of
-    // the original source code.
-    if (installHandler && hasGlobalProcessEventEmitter()) {
-      uncaughtShimInstalled = true;
-      shimEmitUncaughtException();
+  function findMap(array, callback) {
+    for (let i = 0; i < array.length; i++) {
+      const result = callback(array[i], i);
+      if (result) {
+        return result;
+      }
     }
+    return Debug.fail();
   }
-};
-
-exports.resetRetrieveHandlers = function() {
-  retrieveFileHandlers.length = 0;
-  retrieveMapHandlers.length = 0;
-
-  retrieveFileHandlers = originalRetrieveFileHandlers.slice(0);
-  retrieveMapHandlers = originalRetrieveMapHandlers.slice(0);
-  
-  retrieveSourceMap = handlerExec(retrieveMapHandlers);
-  retrieveFile = handlerExec(retrieveFileHandlers);
-}
-
-
-/***/ }),
-
-/***/ 30176:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
-
-/* -*- Mode: js; js-indent-level: 2; -*- */
-/*
- * Copyright 2011 Mozilla Foundation and contributors
- * Licensed under the New BSD license. See LICENSE or:
- * http://opensource.org/licenses/BSD-3-Clause
- */
-
-var util = __nccwpck_require__(16511);
-var has = Object.prototype.hasOwnProperty;
-var hasNativeMap = typeof Map !== "undefined";
-
-/**
- * A data structure which is a combination of an array and a set. Adding a new
- * member is O(1), testing for membership is O(1), and finding the index of an
- * element is O(1). Removing elements from the set is not supported. Only
- * strings are supported for membership.
- */
-function ArraySet() {
-  this._array = [];
-  this._set = hasNativeMap ? new Map() : Object.create(null);
-}
-
-/**
- * Static method for creating ArraySet instances from an existing array.
- */
-ArraySet.fromArray = function ArraySet_fromArray(aArray, aAllowDuplicates) {
-  var set = new ArraySet();
-  for (var i = 0, len = aArray.length; i < len; i++) {
-    set.add(aArray[i], aAllowDuplicates);
+  function contains(array, value, equalityComparer = equateValues) {
+    if (array) {
+      for (const v of array) {
+        if (equalityComparer(v, value)) {
+          return true;
+        }
+      }
+    }
+    return false;
   }
-  return set;
-};
-
-/**
- * Return how many unique items are in this ArraySet. If duplicates have been
- * added, than those do not count towards the size.
- *
- * @returns Number
- */
-ArraySet.prototype.size = function ArraySet_size() {
-  return hasNativeMap ? this._set.size : Object.getOwnPropertyNames(this._set).length;
-};
-
-/**
- * Add the given string to this set.
- *
- * @param String aStr
- */
-ArraySet.prototype.add = function ArraySet_add(aStr, aAllowDuplicates) {
-  var sStr = hasNativeMap ? aStr : util.toSetString(aStr);
-  var isDuplicate = hasNativeMap ? this.has(aStr) : has.call(this._set, sStr);
-  var idx = this._array.length;
-  if (!isDuplicate || aAllowDuplicates) {
-    this._array.push(aStr);
+  function arraysEqual(a, b, equalityComparer = equateValues) {
+    return a.length === b.length && a.every((x, i) => equalityComparer(x, b[i]));
   }
-  if (!isDuplicate) {
-    if (hasNativeMap) {
-      this._set.set(aStr, idx);
-    } else {
-      this._set[sStr] = idx;
+  function indexOfAnyCharCode(text, charCodes, start) {
+    for (let i = start || 0; i < text.length; i++) {
+      if (contains(charCodes, text.charCodeAt(i))) {
+        return i;
+      }
     }
+    return -1;
   }
-};
-
-/**
- * Is the given string a member of this set?
- *
- * @param String aStr
- */
-ArraySet.prototype.has = function ArraySet_has(aStr) {
-  if (hasNativeMap) {
-    return this._set.has(aStr);
-  } else {
-    var sStr = util.toSetString(aStr);
-    return has.call(this._set, sStr);
+  function countWhere(array, predicate) {
+    let count = 0;
+    if (array) {
+      for (let i = 0; i < array.length; i++) {
+        const v = array[i];
+        if (predicate(v, i)) {
+          count++;
+        }
+      }
+    }
+    return count;
   }
-};
-
-/**
- * What is the index of the given string in the array?
- *
- * @param String aStr
- */
-ArraySet.prototype.indexOf = function ArraySet_indexOf(aStr) {
-  if (hasNativeMap) {
-    var idx = this._set.get(aStr);
-    if (idx >= 0) {
-        return idx;
+  function filter(array, f) {
+    if (array) {
+      const len = array.length;
+      let i = 0;
+      while (i < len && f(array[i]))
+        i++;
+      if (i < len) {
+        const result = array.slice(0, i);
+        i++;
+        while (i < len) {
+          const item = array[i];
+          if (f(item)) {
+            result.push(item);
+          }
+          i++;
+        }
+        return result;
+      }
     }
-  } else {
-    var sStr = util.toSetString(aStr);
-    if (has.call(this._set, sStr)) {
-      return this._set[sStr];
+    return array;
+  }
+  function filterMutate(array, f) {
+    let outIndex = 0;
+    for (let i = 0; i < array.length; i++) {
+      if (f(array[i], i, array)) {
+        array[outIndex] = array[i];
+        outIndex++;
+      }
     }
+    array.length = outIndex;
   }
-
-  throw new Error('"' + aStr + '" is not in the set.');
-};
-
-/**
- * What is the element at the given index?
- *
- * @param Number aIdx
- */
-ArraySet.prototype.at = function ArraySet_at(aIdx) {
-  if (aIdx >= 0 && aIdx < this._array.length) {
-    return this._array[aIdx];
+  function clear(array) {
+    array.length = 0;
   }
-  throw new Error('No element indexed by ' + aIdx);
-};
-
-/**
- * Returns the array representation of this set (which has the proper indices
- * indicated by indexOf). Note that this is a copy of the internal array used
- * for storing the members so that no one can mess with internal state.
- */
-ArraySet.prototype.toArray = function ArraySet_toArray() {
-  return this._array.slice();
-};
-
-exports.I = ArraySet;
-
-
-/***/ }),
-
-/***/ 14590:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
-
-/* -*- Mode: js; js-indent-level: 2; -*- */
-/*
- * Copyright 2011 Mozilla Foundation and contributors
- * Licensed under the New BSD license. See LICENSE or:
- * http://opensource.org/licenses/BSD-3-Clause
- *
- * Based on the Base 64 VLQ implementation in Closure Compiler:
- * https://code.google.com/p/closure-compiler/source/browse/trunk/src/com/google/debugging/sourcemap/Base64VLQ.java
- *
- * Copyright 2011 The Closure Compiler Authors. All rights reserved.
- * Redistribution and use in source and binary forms, with or without
- * modification, are permitted provided that the following conditions are
- * met:
- *
- *  * Redistributions of source code must retain the above copyright
- *    notice, this list of conditions and the following disclaimer.
- *  * Redistributions in binary form must reproduce the above
- *    copyright notice, this list of conditions and the following
- *    disclaimer in the documentation and/or other materials provided
- *    with the distribution.
- *  * Neither the name of Google Inc. nor the names of its
- *    contributors may be used to endorse or promote products derived
- *    from this software without specific prior written permission.
- *
- * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
- * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
- * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
- * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
- * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
- * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
- * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
- * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
- * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
- * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
- * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
- */
-
-var base64 = __nccwpck_require__(94521);
-
-// A single base 64 digit can contain 6 bits of data. For the base 64 variable
-// length quantities we use in the source map spec, the first bit is the sign,
-// the next four bits are the actual value, and the 6th bit is the
-// continuation bit. The continuation bit tells us whether there are more
-// digits in this value following this digit.
-//
-//   Continuation
-//   |    Sign
-//   |    |
-//   V    V
-//   101011
-
-var VLQ_BASE_SHIFT = 5;
-
-// binary: 100000
-var VLQ_BASE = 1 << VLQ_BASE_SHIFT;
-
-// binary: 011111
-var VLQ_BASE_MASK = VLQ_BASE - 1;
-
-// binary: 100000
-var VLQ_CONTINUATION_BIT = VLQ_BASE;
-
-/**
- * Converts from a two-complement value to a value where the sign bit is
- * placed in the least significant bit.  For example, as decimals:
- *   1 becomes 2 (10 binary), -1 becomes 3 (11 binary)
- *   2 becomes 4 (100 binary), -2 becomes 5 (101 binary)
- */
-function toVLQSigned(aValue) {
-  return aValue < 0
-    ? ((-aValue) << 1) + 1
-    : (aValue << 1) + 0;
-}
-
-/**
- * Converts to a two-complement value from a value where the sign bit is
- * placed in the least significant bit.  For example, as decimals:
- *   2 (10 binary) becomes 1, 3 (11 binary) becomes -1
- *   4 (100 binary) becomes 2, 5 (101 binary) becomes -2
- */
-function fromVLQSigned(aValue) {
-  var isNegative = (aValue & 1) === 1;
-  var shifted = aValue >> 1;
-  return isNegative
-    ? -shifted
-    : shifted;
-}
-
-/**
- * Returns the base 64 VLQ encoded value.
- */
-exports.encode = function base64VLQ_encode(aValue) {
-  var encoded = "";
-  var digit;
-
-  var vlq = toVLQSigned(aValue);
-
-  do {
-    digit = vlq & VLQ_BASE_MASK;
-    vlq >>>= VLQ_BASE_SHIFT;
-    if (vlq > 0) {
-      // There are still more digits in this value, so we must make sure the
-      // continuation bit is marked.
-      digit |= VLQ_CONTINUATION_BIT;
-    }
-    encoded += base64.encode(digit);
-  } while (vlq > 0);
-
-  return encoded;
-};
-
-/**
- * Decodes the next base 64 VLQ value from the given string and returns the
- * value and the rest of the string via the out parameter.
- */
-exports.decode = function base64VLQ_decode(aStr, aIndex, aOutParam) {
-  var strLen = aStr.length;
-  var result = 0;
-  var shift = 0;
-  var continuation, digit;
-
-  do {
-    if (aIndex >= strLen) {
-      throw new Error("Expected more digits in base 64 VLQ value.");
-    }
-
-    digit = base64.decode(aStr.charCodeAt(aIndex++));
-    if (digit === -1) {
-      throw new Error("Invalid base64 digit: " + aStr.charAt(aIndex - 1));
+  function map(array, f) {
+    let result;
+    if (array) {
+      result = [];
+      for (let i = 0; i < array.length; i++) {
+        result.push(f(array[i], i));
+      }
     }
-
-    continuation = !!(digit & VLQ_CONTINUATION_BIT);
-    digit &= VLQ_BASE_MASK;
-    result = result + (digit << shift);
-    shift += VLQ_BASE_SHIFT;
-  } while (continuation);
-
-  aOutParam.value = fromVLQSigned(result);
-  aOutParam.rest = aIndex;
-};
-
-
-/***/ }),
-
-/***/ 94521:
-/***/ ((__unused_webpack_module, exports) => {
-
-/* -*- Mode: js; js-indent-level: 2; -*- */
-/*
- * Copyright 2011 Mozilla Foundation and contributors
- * Licensed under the New BSD license. See LICENSE or:
- * http://opensource.org/licenses/BSD-3-Clause
- */
-
-var intToCharMap = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/'.split('');
-
-/**
- * Encode an integer in the range of 0 to 63 to a single base 64 digit.
- */
-exports.encode = function (number) {
-  if (0 <= number && number < intToCharMap.length) {
-    return intToCharMap[number];
-  }
-  throw new TypeError("Must be between 0 and 63: " + number);
-};
-
-/**
- * Decode a single base 64 character code digit to an integer. Returns -1 on
- * failure.
- */
-exports.decode = function (charCode) {
-  var bigA = 65;     // 'A'
-  var bigZ = 90;     // 'Z'
-
-  var littleA = 97;  // 'a'
-  var littleZ = 122; // 'z'
-
-  var zero = 48;     // '0'
-  var nine = 57;     // '9'
-
-  var plus = 43;     // '+'
-  var slash = 47;    // '/'
-
-  var littleOffset = 26;
-  var numberOffset = 52;
-
-  // 0 - 25: ABCDEFGHIJKLMNOPQRSTUVWXYZ
-  if (bigA <= charCode && charCode <= bigZ) {
-    return (charCode - bigA);
+    return result;
   }
-
-  // 26 - 51: abcdefghijklmnopqrstuvwxyz
-  if (littleA <= charCode && charCode <= littleZ) {
-    return (charCode - littleA + littleOffset);
+  function* mapIterator(iter, mapFn) {
+    for (const x of iter) {
+      yield mapFn(x);
+    }
   }
-
-  // 52 - 61: 0123456789
-  if (zero <= charCode && charCode <= nine) {
-    return (charCode - zero + numberOffset);
+  function sameMap(array, f) {
+    if (array) {
+      for (let i = 0; i < array.length; i++) {
+        const item = array[i];
+        const mapped = f(item, i);
+        if (item !== mapped) {
+          const result = array.slice(0, i);
+          result.push(mapped);
+          for (i++; i < array.length; i++) {
+            result.push(f(array[i], i));
+          }
+          return result;
+        }
+      }
+    }
+    return array;
   }
-
-  // 62: +
-  if (charCode == plus) {
-    return 62;
+  function flatten(array) {
+    const result = [];
+    for (const v of array) {
+      if (v) {
+        if (isArray(v)) {
+          addRange(result, v);
+        } else {
+          result.push(v);
+        }
+      }
+    }
+    return result;
   }
-
-  // 63: /
-  if (charCode == slash) {
-    return 63;
+  function flatMap(array, mapfn) {
+    let result;
+    if (array) {
+      for (let i = 0; i < array.length; i++) {
+        const v = mapfn(array[i], i);
+        if (v) {
+          if (isArray(v)) {
+            result = addRange(result, v);
+          } else {
+            result = append(result, v);
+          }
+        }
+      }
+    }
+    return result || emptyArray;
   }
-
-  // Invalid base64 digit.
-  return -1;
-};
-
-
-/***/ }),
-
-/***/ 94351:
-/***/ ((__unused_webpack_module, exports) => {
-
-/* -*- Mode: js; js-indent-level: 2; -*- */
-/*
- * Copyright 2011 Mozilla Foundation and contributors
- * Licensed under the New BSD license. See LICENSE or:
- * http://opensource.org/licenses/BSD-3-Clause
- */
-
-exports.GREATEST_LOWER_BOUND = 1;
-exports.LEAST_UPPER_BOUND = 2;
-
-/**
- * Recursive implementation of binary search.
- *
- * @param aLow Indices here and lower do not contain the needle.
- * @param aHigh Indices here and higher do not contain the needle.
- * @param aNeedle The element being searched for.
- * @param aHaystack The non-empty array being searched.
- * @param aCompare Function which takes two elements and returns -1, 0, or 1.
- * @param aBias Either 'binarySearch.GREATEST_LOWER_BOUND' or
- *     'binarySearch.LEAST_UPPER_BOUND'. Specifies whether to return the
- *     closest element that is smaller than or greater than the one we are
- *     searching for, respectively, if the exact element cannot be found.
- */
-function recursiveSearch(aLow, aHigh, aNeedle, aHaystack, aCompare, aBias) {
-  // This function terminates when one of the following is true:
-  //
-  //   1. We find the exact element we are looking for.
-  //
-  //   2. We did not find the exact element, but we can return the index of
-  //      the next-closest element.
-  //
-  //   3. We did not find the exact element, and there is no next-closest
-  //      element than the one we are searching for, so we return -1.
-  var mid = Math.floor((aHigh - aLow) / 2) + aLow;
-  var cmp = aCompare(aNeedle, aHaystack[mid], true);
-  if (cmp === 0) {
-    // Found the element we are looking for.
-    return mid;
+  function flatMapToMutable(array, mapfn) {
+    const result = [];
+    if (array) {
+      for (let i = 0; i < array.length; i++) {
+        const v = mapfn(array[i], i);
+        if (v) {
+          if (isArray(v)) {
+            addRange(result, v);
+          } else {
+            result.push(v);
+          }
+        }
+      }
+    }
+    return result;
   }
-  else if (cmp > 0) {
-    // Our needle is greater than aHaystack[mid].
-    if (aHigh - mid > 1) {
-      // The element is in the upper half.
-      return recursiveSearch(mid, aHigh, aNeedle, aHaystack, aCompare, aBias);
+  function* flatMapIterator(iter, mapfn) {
+    for (const x of iter) {
+      const iter2 = mapfn(x);
+      if (!iter2)
+        continue;
+      yield* iter2;
     }
-
-    // The exact needle element was not found in this haystack. Determine if
-    // we are in termination case (3) or (2) and return the appropriate thing.
-    if (aBias == exports.LEAST_UPPER_BOUND) {
-      return aHigh < aHaystack.length ? aHigh : -1;
-    } else {
-      return mid;
+  }
+  function sameFlatMap(array, mapfn) {
+    let result;
+    if (array) {
+      for (let i = 0; i < array.length; i++) {
+        const item = array[i];
+        const mapped = mapfn(item, i);
+        if (result || item !== mapped || isArray(mapped)) {
+          if (!result) {
+            result = array.slice(0, i);
+          }
+          if (isArray(mapped)) {
+            addRange(result, mapped);
+          } else {
+            result.push(mapped);
+          }
+        }
+      }
     }
+    return result || array;
   }
-  else {
-    // Our needle is less than aHaystack[mid].
-    if (mid - aLow > 1) {
-      // The element is in the lower half.
-      return recursiveSearch(aLow, mid, aNeedle, aHaystack, aCompare, aBias);
+  function mapAllOrFail(array, mapFn) {
+    const result = [];
+    for (let i = 0; i < array.length; i++) {
+      const mapped = mapFn(array[i], i);
+      if (mapped === void 0) {
+        return void 0;
+      }
+      result.push(mapped);
     }
-
-    // we are in termination case (3) or (2) and return the appropriate thing.
-    if (aBias == exports.LEAST_UPPER_BOUND) {
-      return mid;
-    } else {
-      return aLow < 0 ? -1 : aLow;
+    return result;
+  }
+  function mapDefined(array, mapFn) {
+    const result = [];
+    if (array) {
+      for (let i = 0; i < array.length; i++) {
+        const mapped = mapFn(array[i], i);
+        if (mapped !== void 0) {
+          result.push(mapped);
+        }
+      }
     }
+    return result;
   }
-}
-
-/**
- * This is an implementation of binary search which will always try and return
- * the index of the closest element if there is no exact hit. This is because
- * mappings between original and generated line/col pairs are single points,
- * and there is an implicit region between each of them, so a miss just means
- * that you aren't on the very start of a region.
- *
- * @param aNeedle The element you are looking for.
- * @param aHaystack The array that is being searched.
- * @param aCompare A function which takes the needle and an element in the
- *     array and returns -1, 0, or 1 depending on whether the needle is less
- *     than, equal to, or greater than the element, respectively.
- * @param aBias Either 'binarySearch.GREATEST_LOWER_BOUND' or
- *     'binarySearch.LEAST_UPPER_BOUND'. Specifies whether to return the
- *     closest element that is smaller than or greater than the one we are
- *     searching for, respectively, if the exact element cannot be found.
- *     Defaults to 'binarySearch.GREATEST_LOWER_BOUND'.
- */
-exports.search = function search(aNeedle, aHaystack, aCompare, aBias) {
-  if (aHaystack.length === 0) {
-    return -1;
+  function* mapDefinedIterator(iter, mapFn) {
+    for (const x of iter) {
+      const value = mapFn(x);
+      if (value !== void 0) {
+        yield value;
+      }
+    }
   }
-
-  var index = recursiveSearch(-1, aHaystack.length, aNeedle, aHaystack,
-                              aCompare, aBias || exports.GREATEST_LOWER_BOUND);
-  if (index < 0) {
-    return -1;
+  function mapDefinedEntries(map2, f) {
+    if (!map2) {
+      return void 0;
+    }
+    const result = /* @__PURE__ */ new Map();
+    map2.forEach((value, key) => {
+      const entry = f(key, value);
+      if (entry !== void 0) {
+        const [newKey, newValue] = entry;
+        if (newKey !== void 0 && newValue !== void 0) {
+          result.set(newKey, newValue);
+        }
+      }
+    });
+    return result;
   }
-
-  // We have found either the exact element, or the next-closest element than
-  // the one we are searching for. However, there may be more than one such
-  // element. Make sure we always return the smallest of these.
-  while (index - 1 >= 0) {
-    if (aCompare(aHaystack[index], aHaystack[index - 1], true) !== 0) {
-      break;
+  function getOrUpdate(map2, key, callback) {
+    if (map2.has(key)) {
+      return map2.get(key);
     }
-    --index;
+    const value = callback();
+    map2.set(key, value);
+    return value;
   }
-
-  return index;
-};
-
-
-/***/ }),
-
-/***/ 31247:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
-
-/* -*- Mode: js; js-indent-level: 2; -*- */
-/*
- * Copyright 2014 Mozilla Foundation and contributors
- * Licensed under the New BSD license. See LICENSE or:
- * http://opensource.org/licenses/BSD-3-Clause
- */
-
-var util = __nccwpck_require__(16511);
-
-/**
- * Determine whether mappingB is after mappingA with respect to generated
- * position.
- */
-function generatedPositionAfter(mappingA, mappingB) {
-  // Optimized for most common case
-  var lineA = mappingA.generatedLine;
-  var lineB = mappingB.generatedLine;
-  var columnA = mappingA.generatedColumn;
-  var columnB = mappingB.generatedColumn;
-  return lineB > lineA || lineB == lineA && columnB >= columnA ||
-         util.compareByGeneratedPositionsInflated(mappingA, mappingB) <= 0;
-}
-
-/**
- * A data structure to provide a sorted view of accumulated mappings in a
- * performance conscious manner. It trades a neglibable overhead in general
- * case for a large speedup in case of mappings being added in order.
- */
-function MappingList() {
-  this._array = [];
-  this._sorted = true;
-  // Serves as infimum
-  this._last = {generatedLine: -1, generatedColumn: 0};
-}
-
-/**
- * Iterate through internal items. This method takes the same arguments that
- * `Array.prototype.forEach` takes.
- *
- * NOTE: The order of the mappings is NOT guaranteed.
- */
-MappingList.prototype.unsortedForEach =
-  function MappingList_forEach(aCallback, aThisArg) {
-    this._array.forEach(aCallback, aThisArg);
-  };
-
-/**
- * Add the given source mapping.
- *
- * @param Object aMapping
- */
-MappingList.prototype.add = function MappingList_add(aMapping) {
-  if (generatedPositionAfter(this._last, aMapping)) {
-    this._last = aMapping;
-    this._array.push(aMapping);
-  } else {
-    this._sorted = false;
-    this._array.push(aMapping);
+  function tryAddToSet(set, value) {
+    if (!set.has(value)) {
+      set.add(value);
+      return true;
+    }
+    return false;
   }
-};
-
-/**
- * Returns the flat, sorted array of mappings. The mappings are sorted by
- * generated position.
- *
- * WARNING: This method returns internal data without copying, for
- * performance. The return value must NOT be mutated, and should be treated as
- * an immutable borrow. If you want to take ownership, you must make your own
- * copy.
- */
-MappingList.prototype.toArray = function MappingList_toArray() {
-  if (!this._sorted) {
-    this._array.sort(util.compareByGeneratedPositionsInflated);
-    this._sorted = true;
+  function* singleIterator(value) {
+    yield value;
   }
-  return this._array;
-};
-
-exports.H = MappingList;
-
-
-/***/ }),
-
-/***/ 44347:
-/***/ ((__unused_webpack_module, exports) => {
-
-/* -*- Mode: js; js-indent-level: 2; -*- */
-/*
- * Copyright 2011 Mozilla Foundation and contributors
- * Licensed under the New BSD license. See LICENSE or:
- * http://opensource.org/licenses/BSD-3-Clause
- */
-
-// It turns out that some (most?) JavaScript engines don't self-host
-// `Array.prototype.sort`. This makes sense because C++ will likely remain
-// faster than JS when doing raw CPU-intensive sorting. However, when using a
-// custom comparator function, calling back and forth between the VM's C++ and
-// JIT'd JS is rather slow *and* loses JIT type information, resulting in
-// worse generated code for the comparator function than would be optimal. In
-// fact, when sorting with a comparator, these costs outweigh the benefits of
-// sorting in C++. By using our own JS-implemented Quick Sort (below), we get
-// a ~3500ms mean speed-up in `bench/bench.html`.
-
-/**
- * Swap the elements indexed by `x` and `y` in the array `ary`.
- *
- * @param {Array} ary
- *        The array.
- * @param {Number} x
- *        The index of the first item.
- * @param {Number} y
- *        The index of the second item.
- */
-function swap(ary, x, y) {
-  var temp = ary[x];
-  ary[x] = ary[y];
-  ary[y] = temp;
-}
-
-/**
- * Returns a random integer within the range `low .. high` inclusive.
- *
- * @param {Number} low
- *        The lower bound on the range.
- * @param {Number} high
- *        The upper bound on the range.
- */
-function randomIntInRange(low, high) {
-  return Math.round(low + (Math.random() * (high - low)));
-}
-
-/**
- * The Quick Sort algorithm.
- *
- * @param {Array} ary
- *        An array to sort.
- * @param {function} comparator
- *        Function to use to compare two items.
- * @param {Number} p
- *        Start index of the array
- * @param {Number} r
- *        End index of the array
- */
-function doQuickSort(ary, comparator, p, r) {
-  // If our lower bound is less than our upper bound, we (1) partition the
-  // array into two pieces and (2) recurse on each half. If it is not, this is
-  // the empty array and our base case.
-
-  if (p < r) {
-    // (1) Partitioning.
-    //
-    // The partitioning chooses a pivot between `p` and `r` and moves all
-    // elements that are less than or equal to the pivot to the before it, and
-    // all the elements that are greater than it after it. The effect is that
-    // once partition is done, the pivot is in the exact place it will be when
-    // the array is put in sorted order, and it will not need to be moved
-    // again. This runs in O(n) time.
-
-    // Always choose a random pivot so that an input array which is reverse
-    // sorted does not cause O(n^2) running time.
-    var pivotIndex = randomIntInRange(p, r);
-    var i = p - 1;
-
-    swap(ary, pivotIndex, r);
-    var pivot = ary[r];
-
-    // Immediately after `j` is incremented in this loop, the following hold
-    // true:
-    //
-    //   * Every element in `ary[p .. i]` is less than or equal to the pivot.
-    //
-    //   * Every element in `ary[i+1 .. j-1]` is greater than the pivot.
-    for (var j = p; j < r; j++) {
-      if (comparator(ary[j], pivot) <= 0) {
-        i += 1;
-        swap(ary, i, j);
+  function spanMap(array, keyfn, mapfn) {
+    let result;
+    if (array) {
+      result = [];
+      const len = array.length;
+      let previousKey;
+      let key;
+      let start = 0;
+      let pos = 0;
+      while (start < len) {
+        while (pos < len) {
+          const value = array[pos];
+          key = keyfn(value, pos);
+          if (pos === 0) {
+            previousKey = key;
+          } else if (key !== previousKey) {
+            break;
+          }
+          pos++;
+        }
+        if (start < pos) {
+          const v = mapfn(array.slice(start, pos), previousKey, start, pos);
+          if (v) {
+            result.push(v);
+          }
+          start = pos;
+        }
+        previousKey = key;
+        pos++;
       }
     }
-
-    swap(ary, i + 1, j);
-    var q = i + 1;
-
-    // (2) Recurse on each half.
-
-    doQuickSort(ary, comparator, p, q - 1);
-    doQuickSort(ary, comparator, q + 1, r);
-  }
-}
-
-/**
- * Sort the given array in-place with the given comparator function.
- *
- * @param {Array} ary
- *        An array to sort.
- * @param {function} comparator
- *        Function to use to compare two items.
- */
-exports.U = function (ary, comparator) {
-  doQuickSort(ary, comparator, 0, ary.length - 1);
-};
-
-
-/***/ }),
-
-/***/ 52718:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
-
-var __webpack_unused_export__;
-/* -*- Mode: js; js-indent-level: 2; -*- */
-/*
- * Copyright 2011 Mozilla Foundation and contributors
- * Licensed under the New BSD license. See LICENSE or:
- * http://opensource.org/licenses/BSD-3-Clause
- */
-
-var util = __nccwpck_require__(16511);
-var binarySearch = __nccwpck_require__(94351);
-var ArraySet = (__nccwpck_require__(30176)/* .ArraySet */ .I);
-var base64VLQ = __nccwpck_require__(14590);
-var quickSort = (__nccwpck_require__(44347)/* .quickSort */ .U);
-
-function SourceMapConsumer(aSourceMap, aSourceMapURL) {
-  var sourceMap = aSourceMap;
-  if (typeof aSourceMap === 'string') {
-    sourceMap = util.parseSourceMapInput(aSourceMap);
+    return result;
   }
-
-  return sourceMap.sections != null
-    ? new IndexedSourceMapConsumer(sourceMap, aSourceMapURL)
-    : new BasicSourceMapConsumer(sourceMap, aSourceMapURL);
-}
-
-SourceMapConsumer.fromSourceMap = function(aSourceMap, aSourceMapURL) {
-  return BasicSourceMapConsumer.fromSourceMap(aSourceMap, aSourceMapURL);
-}
-
-/**
- * The version of the source mapping spec that we are consuming.
- */
-SourceMapConsumer.prototype._version = 3;
-
-// `__generatedMappings` and `__originalMappings` are arrays that hold the
-// parsed mapping coordinates from the source map's "mappings" attribute. They
-// are lazily instantiated, accessed via the `_generatedMappings` and
-// `_originalMappings` getters respectively, and we only parse the mappings
-// and create these arrays once queried for a source location. We jump through
-// these hoops because there can be many thousands of mappings, and parsing
-// them is expensive, so we only want to do it if we must.
-//
-// Each object in the arrays is of the form:
-//
-//     {
-//       generatedLine: The line number in the generated code,
-//       generatedColumn: The column number in the generated code,
-//       source: The path to the original source file that generated this
-//               chunk of code,
-//       originalLine: The line number in the original source that
-//                     corresponds to this chunk of generated code,
-//       originalColumn: The column number in the original source that
-//                       corresponds to this chunk of generated code,
-//       name: The name of the original symbol which generated this chunk of
-//             code.
-//     }
-//
-// All properties except for `generatedLine` and `generatedColumn` can be
-// `null`.
-//
-// `_generatedMappings` is ordered by the generated positions.
-//
-// `_originalMappings` is ordered by the original positions.
-
-SourceMapConsumer.prototype.__generatedMappings = null;
-Object.defineProperty(SourceMapConsumer.prototype, '_generatedMappings', {
-  configurable: true,
-  enumerable: true,
-  get: function () {
-    if (!this.__generatedMappings) {
-      this._parseMappings(this._mappings, this.sourceRoot);
+  function mapEntries(map2, f) {
+    if (!map2) {
+      return void 0;
     }
-
-    return this.__generatedMappings;
+    const result = /* @__PURE__ */ new Map();
+    map2.forEach((value, key) => {
+      const [newKey, newValue] = f(key, value);
+      result.set(newKey, newValue);
+    });
+    return result;
   }
-});
-
-SourceMapConsumer.prototype.__originalMappings = null;
-Object.defineProperty(SourceMapConsumer.prototype, '_originalMappings', {
-  configurable: true,
-  enumerable: true,
-  get: function () {
-    if (!this.__originalMappings) {
-      this._parseMappings(this._mappings, this.sourceRoot);
+  function some(array, predicate) {
+    if (array) {
+      if (predicate) {
+        for (const v of array) {
+          if (predicate(v)) {
+            return true;
+          }
+        }
+      } else {
+        return array.length > 0;
+      }
     }
-
-    return this.__originalMappings;
+    return false;
   }
-});
-
-SourceMapConsumer.prototype._charIsMappingSeparator =
-  function SourceMapConsumer_charIsMappingSeparator(aStr, index) {
-    var c = aStr.charAt(index);
-    return c === ";" || c === ",";
-  };
-
-/**
- * Parse the mappings in a string in to a data structure which we can easily
- * query (the ordered arrays in the `this.__generatedMappings` and
- * `this.__originalMappings` properties).
- */
-SourceMapConsumer.prototype._parseMappings =
-  function SourceMapConsumer_parseMappings(aStr, aSourceRoot) {
-    throw new Error("Subclasses must implement _parseMappings");
-  };
-
-SourceMapConsumer.GENERATED_ORDER = 1;
-SourceMapConsumer.ORIGINAL_ORDER = 2;
-
-SourceMapConsumer.GREATEST_LOWER_BOUND = 1;
-SourceMapConsumer.LEAST_UPPER_BOUND = 2;
-
-/**
- * Iterate over each mapping between an original source/line/column and a
- * generated line/column in this source map.
- *
- * @param Function aCallback
- *        The function that is called with each mapping.
- * @param Object aContext
- *        Optional. If specified, this object will be the value of `this` every
- *        time that `aCallback` is called.
- * @param aOrder
- *        Either `SourceMapConsumer.GENERATED_ORDER` or
- *        `SourceMapConsumer.ORIGINAL_ORDER`. Specifies whether you want to
- *        iterate over the mappings sorted by the generated file's line/column
- *        order or the original's source/line/column order, respectively. Defaults to
- *        `SourceMapConsumer.GENERATED_ORDER`.
- */
-SourceMapConsumer.prototype.eachMapping =
-  function SourceMapConsumer_eachMapping(aCallback, aContext, aOrder) {
-    var context = aContext || null;
-    var order = aOrder || SourceMapConsumer.GENERATED_ORDER;
-
-    var mappings;
-    switch (order) {
-    case SourceMapConsumer.GENERATED_ORDER:
-      mappings = this._generatedMappings;
-      break;
-    case SourceMapConsumer.ORIGINAL_ORDER:
-      mappings = this._originalMappings;
-      break;
-    default:
-      throw new Error("Unknown order of iteration.");
-    }
-
-    var sourceRoot = this.sourceRoot;
-    mappings.map(function (mapping) {
-      var source = mapping.source === null ? null : this._sources.at(mapping.source);
-      source = util.computeSourceURL(sourceRoot, source, this._sourceMapURL);
-      return {
-        source: source,
-        generatedLine: mapping.generatedLine,
-        generatedColumn: mapping.generatedColumn,
-        originalLine: mapping.originalLine,
-        originalColumn: mapping.originalColumn,
-        name: mapping.name === null ? null : this._names.at(mapping.name)
-      };
-    }, this).forEach(aCallback, context);
-  };
-
-/**
- * Returns all generated line and column information for the original source,
- * line, and column provided. If no column is provided, returns all mappings
- * corresponding to a either the line we are searching for or the next
- * closest line that has any mappings. Otherwise, returns all mappings
- * corresponding to the given line and either the column we are searching for
- * or the next closest column that has any offsets.
- *
- * The only argument is an object with the following properties:
- *
- *   - source: The filename of the original source.
- *   - line: The line number in the original source.  The line number is 1-based.
- *   - column: Optional. the column number in the original source.
- *    The column number is 0-based.
- *
- * and an array of objects is returned, each with the following properties:
- *
- *   - line: The line number in the generated source, or null.  The
- *    line number is 1-based.
- *   - column: The column number in the generated source, or null.
- *    The column number is 0-based.
- */
-SourceMapConsumer.prototype.allGeneratedPositionsFor =
-  function SourceMapConsumer_allGeneratedPositionsFor(aArgs) {
-    var line = util.getArg(aArgs, 'line');
-
-    // When there is no exact match, BasicSourceMapConsumer.prototype._findMapping
-    // returns the index of the closest mapping less than the needle. By
-    // setting needle.originalColumn to 0, we thus find the last mapping for
-    // the given line, provided such a mapping exists.
-    var needle = {
-      source: util.getArg(aArgs, 'source'),
-      originalLine: line,
-      originalColumn: util.getArg(aArgs, 'column', 0)
-    };
-
-    needle.source = this._findSourceIndex(needle.source);
-    if (needle.source < 0) {
-      return [];
-    }
-
-    var mappings = [];
-
-    var index = this._findMapping(needle,
-                                  this._originalMappings,
-                                  "originalLine",
-                                  "originalColumn",
-                                  util.compareByOriginalPositions,
-                                  binarySearch.LEAST_UPPER_BOUND);
-    if (index >= 0) {
-      var mapping = this._originalMappings[index];
-
-      if (aArgs.column === undefined) {
-        var originalLine = mapping.originalLine;
-
-        // Iterate until either we run out of mappings, or we run into
-        // a mapping for a different line than the one we found. Since
-        // mappings are sorted, this is guaranteed to find all mappings for
-        // the line we found.
-        while (mapping && mapping.originalLine === originalLine) {
-          mappings.push({
-            line: util.getArg(mapping, 'generatedLine', null),
-            column: util.getArg(mapping, 'generatedColumn', null),
-            lastColumn: util.getArg(mapping, 'lastGeneratedColumn', null)
-          });
-
-          mapping = this._originalMappings[++index];
-        }
+  function getRangesWhere(arr, pred, cb) {
+    let start;
+    for (let i = 0; i < arr.length; i++) {
+      if (pred(arr[i])) {
+        start = start === void 0 ? i : start;
       } else {
-        var originalColumn = mapping.originalColumn;
-
-        // Iterate until either we run out of mappings, or we run into
-        // a mapping for a different line than the one we were searching for.
-        // Since mappings are sorted, this is guaranteed to find all mappings for
-        // the line we are searching for.
-        while (mapping &&
-               mapping.originalLine === line &&
-               mapping.originalColumn == originalColumn) {
-          mappings.push({
-            line: util.getArg(mapping, 'generatedLine', null),
-            column: util.getArg(mapping, 'generatedColumn', null),
-            lastColumn: util.getArg(mapping, 'lastGeneratedColumn', null)
-          });
-
-          mapping = this._originalMappings[++index];
+        if (start !== void 0) {
+          cb(start, i);
+          start = void 0;
         }
       }
     }
-
-    return mappings;
-  };
-
-exports.SourceMapConsumer = SourceMapConsumer;
-
-/**
- * A BasicSourceMapConsumer instance represents a parsed source map which we can
- * query for information about the original file positions by giving it a file
- * position in the generated source.
- *
- * The first parameter is the raw source map (either as a JSON string, or
- * already parsed to an object). According to the spec, source maps have the
- * following attributes:
- *
- *   - version: Which version of the source map spec this map is following.
- *   - sources: An array of URLs to the original source files.
- *   - names: An array of identifiers which can be referrenced by individual mappings.
- *   - sourceRoot: Optional. The URL root from which all sources are relative.
- *   - sourcesContent: Optional. An array of contents of the original source files.
- *   - mappings: A string of base64 VLQs which contain the actual mappings.
- *   - file: Optional. The generated file this source map is associated with.
- *
- * Here is an example source map, taken from the source map spec[0]:
- *
- *     {
- *       version : 3,
- *       file: "out.js",
- *       sourceRoot : "",
- *       sources: ["foo.js", "bar.js"],
- *       names: ["src", "maps", "are", "fun"],
- *       mappings: "AA,AB;;ABCDE;"
- *     }
- *
- * The second parameter, if given, is a string whose value is the URL
- * at which the source map was found.  This URL is used to compute the
- * sources array.
- *
- * [0]: https://docs.google.com/document/d/1U1RGAehQwRypUTovF1KRlpiOFze0b-_2gc6fAH0KY0k/edit?pli=1#
- */
-function BasicSourceMapConsumer(aSourceMap, aSourceMapURL) {
-  var sourceMap = aSourceMap;
-  if (typeof aSourceMap === 'string') {
-    sourceMap = util.parseSourceMapInput(aSourceMap);
+    if (start !== void 0)
+      cb(start, arr.length);
   }
-
-  var version = util.getArg(sourceMap, 'version');
-  var sources = util.getArg(sourceMap, 'sources');
-  // Sass 3.3 leaves out the 'names' array, so we deviate from the spec (which
-  // requires the array) to play nice here.
-  var names = util.getArg(sourceMap, 'names', []);
-  var sourceRoot = util.getArg(sourceMap, 'sourceRoot', null);
-  var sourcesContent = util.getArg(sourceMap, 'sourcesContent', null);
-  var mappings = util.getArg(sourceMap, 'mappings');
-  var file = util.getArg(sourceMap, 'file', null);
-
-  // Once again, Sass deviates from the spec and supplies the version as a
-  // string rather than a number, so we use loose equality checking here.
-  if (version != this._version) {
-    throw new Error('Unsupported version: ' + version);
+  function concatenate(array1, array2) {
+    if (!some(array2))
+      return array1;
+    if (!some(array1))
+      return array2;
+    return [...array1, ...array2];
   }
-
-  if (sourceRoot) {
-    sourceRoot = util.normalize(sourceRoot);
+  function selectIndex(_, i) {
+    return i;
   }
-
-  sources = sources
-    .map(String)
-    // Some source maps produce relative source paths like "./foo.js" instead of
-    // "foo.js".  Normalize these first so that future comparisons will succeed.
-    // See bugzil.la/1090768.
-    .map(util.normalize)
-    // Always ensure that absolute sources are internally stored relative to
-    // the source root, if the source root is absolute. Not doing this would
-    // be particularly problematic when the source root is a prefix of the
-    // source (valid, but why??). See github issue #199 and bugzil.la/1188982.
-    .map(function (source) {
-      return sourceRoot && util.isAbsolute(sourceRoot) && util.isAbsolute(source)
-        ? util.relative(sourceRoot, source)
-        : source;
-    });
-
-  // Pass `true` below to allow duplicate names and sources. While source maps
-  // are intended to be compressed and deduplicated, the TypeScript compiler
-  // sometimes generates source maps with duplicates in them. See Github issue
-  // #72 and bugzil.la/889492.
-  this._names = ArraySet.fromArray(names.map(String), true);
-  this._sources = ArraySet.fromArray(sources, true);
-
-  this._absoluteSources = this._sources.toArray().map(function (s) {
-    return util.computeSourceURL(sourceRoot, s, aSourceMapURL);
-  });
-
-  this.sourceRoot = sourceRoot;
-  this.sourcesContent = sourcesContent;
-  this._mappings = mappings;
-  this._sourceMapURL = aSourceMapURL;
-  this.file = file;
-}
-
-BasicSourceMapConsumer.prototype = Object.create(SourceMapConsumer.prototype);
-BasicSourceMapConsumer.prototype.consumer = SourceMapConsumer;
-
-/**
- * Utility function to find the index of a source.  Returns -1 if not
- * found.
- */
-BasicSourceMapConsumer.prototype._findSourceIndex = function(aSource) {
-  var relativeSource = aSource;
-  if (this.sourceRoot != null) {
-    relativeSource = util.relative(this.sourceRoot, relativeSource);
+  function indicesOf(array) {
+    return array.map(selectIndex);
   }
-
-  if (this._sources.has(relativeSource)) {
-    return this._sources.indexOf(relativeSource);
+  function deduplicateRelational(array, equalityComparer, comparer) {
+    const indices = indicesOf(array);
+    stableSortIndices(array, indices, comparer);
+    let last2 = array[indices[0]];
+    const deduplicated = [indices[0]];
+    for (let i = 1; i < indices.length; i++) {
+      const index = indices[i];
+      const item = array[index];
+      if (!equalityComparer(last2, item)) {
+        deduplicated.push(index);
+        last2 = item;
+      }
+    }
+    deduplicated.sort();
+    return deduplicated.map((i) => array[i]);
   }
-
-  // Maybe aSource is an absolute URL as returned by |sources|.  In
-  // this case we can't simply undo the transform.
-  var i;
-  for (i = 0; i < this._absoluteSources.length; ++i) {
-    if (this._absoluteSources[i] == aSource) {
-      return i;
+  function deduplicateEquality(array, equalityComparer) {
+    const result = [];
+    for (const item of array) {
+      pushIfUnique(result, item, equalityComparer);
     }
+    return result;
   }
-
-  return -1;
-};
-
-/**
- * Create a BasicSourceMapConsumer from a SourceMapGenerator.
- *
- * @param SourceMapGenerator aSourceMap
- *        The source map that will be consumed.
- * @param String aSourceMapURL
- *        The URL at which the source map can be found (optional)
- * @returns BasicSourceMapConsumer
- */
-BasicSourceMapConsumer.fromSourceMap =
-  function SourceMapConsumer_fromSourceMap(aSourceMap, aSourceMapURL) {
-    var smc = Object.create(BasicSourceMapConsumer.prototype);
-
-    var names = smc._names = ArraySet.fromArray(aSourceMap._names.toArray(), true);
-    var sources = smc._sources = ArraySet.fromArray(aSourceMap._sources.toArray(), true);
-    smc.sourceRoot = aSourceMap._sourceRoot;
-    smc.sourcesContent = aSourceMap._generateSourcesContent(smc._sources.toArray(),
-                                                            smc.sourceRoot);
-    smc.file = aSourceMap._file;
-    smc._sourceMapURL = aSourceMapURL;
-    smc._absoluteSources = smc._sources.toArray().map(function (s) {
-      return util.computeSourceURL(smc.sourceRoot, s, aSourceMapURL);
-    });
-
-    // Because we are modifying the entries (by converting string sources and
-    // names to indices into the sources and names ArraySets), we have to make
-    // a copy of the entry or else bad things happen. Shared mutable state
-    // strikes again! See github issue #191.
-
-    var generatedMappings = aSourceMap._mappings.toArray().slice();
-    var destGeneratedMappings = smc.__generatedMappings = [];
-    var destOriginalMappings = smc.__originalMappings = [];
-
-    for (var i = 0, length = generatedMappings.length; i < length; i++) {
-      var srcMapping = generatedMappings[i];
-      var destMapping = new Mapping;
-      destMapping.generatedLine = srcMapping.generatedLine;
-      destMapping.generatedColumn = srcMapping.generatedColumn;
-
-      if (srcMapping.source) {
-        destMapping.source = sources.indexOf(srcMapping.source);
-        destMapping.originalLine = srcMapping.originalLine;
-        destMapping.originalColumn = srcMapping.originalColumn;
-
-        if (srcMapping.name) {
-          destMapping.name = names.indexOf(srcMapping.name);
-        }
-
-        destOriginalMappings.push(destMapping);
+  function deduplicate(array, equalityComparer, comparer) {
+    return array.length === 0 ? [] : array.length === 1 ? array.slice() : comparer ? deduplicateRelational(array, equalityComparer, comparer) : deduplicateEquality(array, equalityComparer);
+  }
+  function deduplicateSorted(array, comparer) {
+    if (array.length === 0)
+      return emptyArray;
+    let last2 = array[0];
+    const deduplicated = [last2];
+    for (let i = 1; i < array.length; i++) {
+      const next = array[i];
+      switch (comparer(next, last2)) {
+        case true:
+        case 0 /* EqualTo */:
+          continue;
+        case -1 /* LessThan */:
+          return Debug.fail("Array is unsorted.");
       }
-
-      destGeneratedMappings.push(destMapping);
+      deduplicated.push(last2 = next);
     }
-
-    quickSort(smc.__originalMappings, util.compareByOriginalPositions);
-
-    return smc;
-  };
-
-/**
- * The version of the source mapping spec that we are consuming.
- */
-BasicSourceMapConsumer.prototype._version = 3;
-
-/**
- * The list of original sources.
- */
-Object.defineProperty(BasicSourceMapConsumer.prototype, 'sources', {
-  get: function () {
-    return this._absoluteSources.slice();
+    return deduplicated;
   }
-});
-
-/**
- * Provide the JIT with a nice shape / hidden class.
- */
-function Mapping() {
-  this.generatedLine = 0;
-  this.generatedColumn = 0;
-  this.source = null;
-  this.originalLine = null;
-  this.originalColumn = null;
-  this.name = null;
-}
-
-/**
- * Parse the mappings in a string in to a data structure which we can easily
- * query (the ordered arrays in the `this.__generatedMappings` and
- * `this.__originalMappings` properties).
- */
-BasicSourceMapConsumer.prototype._parseMappings =
-  function SourceMapConsumer_parseMappings(aStr, aSourceRoot) {
-    var generatedLine = 1;
-    var previousGeneratedColumn = 0;
-    var previousOriginalLine = 0;
-    var previousOriginalColumn = 0;
-    var previousSource = 0;
-    var previousName = 0;
-    var length = aStr.length;
-    var index = 0;
-    var cachedSegments = {};
-    var temp = {};
-    var originalMappings = [];
-    var generatedMappings = [];
-    var mapping, str, segment, end, value;
-
-    while (index < length) {
-      if (aStr.charAt(index) === ';') {
-        generatedLine++;
-        index++;
-        previousGeneratedColumn = 0;
+  function createSortedArray() {
+    return [];
+  }
+  function insertSorted(array, insert, compare, allowDuplicates) {
+    if (array.length === 0) {
+      array.push(insert);
+      return true;
+    }
+    const insertIndex = binarySearch(array, insert, identity, compare);
+    if (insertIndex < 0) {
+      array.splice(~insertIndex, 0, insert);
+      return true;
+    }
+    if (allowDuplicates) {
+      array.splice(insertIndex, 0, insert);
+      return true;
+    }
+    return false;
+  }
+  function sortAndDeduplicate(array, comparer, equalityComparer) {
+    return deduplicateSorted(sort(array, comparer), equalityComparer || comparer || compareStringsCaseSensitive);
+  }
+  function arrayIsSorted(array, comparer) {
+    if (array.length < 2)
+      return true;
+    for (let i = 1, len = array.length; i < len; i++) {
+      if (comparer(array[i - 1], array[i]) === 1 /* GreaterThan */) {
+        return false;
       }
-      else if (aStr.charAt(index) === ',') {
-        index++;
+    }
+    return true;
+  }
+  function detectSortCaseSensitivity(array, getString, compareStringsCaseSensitive2, compareStringsCaseInsensitive2) {
+    let kind = 3 /* Both */;
+    if (array.length < 2)
+      return kind;
+    let prevElement = getString(array[0]);
+    for (let i = 1, len = array.length; i < len && kind !== 0 /* None */; i++) {
+      const element = getString(array[i]);
+      if (kind & 1 /* CaseSensitive */ && compareStringsCaseSensitive2(prevElement, element) > 0) {
+        kind &= ~1 /* CaseSensitive */;
       }
-      else {
-        mapping = new Mapping();
-        mapping.generatedLine = generatedLine;
-
-        // Because each offset is encoded relative to the previous one,
-        // many segments often have the same encoding. We can exploit this
-        // fact by caching the parsed variable length fields of each segment,
-        // allowing us to avoid a second parse if we encounter the same
-        // segment again.
-        for (end = index; end < length; end++) {
-          if (this._charIsMappingSeparator(aStr, end)) {
-            break;
-          }
-        }
-        str = aStr.slice(index, end);
-
-        segment = cachedSegments[str];
-        if (segment) {
-          index += str.length;
-        } else {
-          segment = [];
-          while (index < end) {
-            base64VLQ.decode(aStr, index, temp);
-            value = temp.value;
-            index = temp.rest;
-            segment.push(value);
-          }
-
-          if (segment.length === 2) {
-            throw new Error('Found a source, but no line and column');
-          }
-
-          if (segment.length === 3) {
-            throw new Error('Found a source and line, but no column');
-          }
-
-          cachedSegments[str] = segment;
-        }
-
-        // Generated column.
-        mapping.generatedColumn = previousGeneratedColumn + segment[0];
-        previousGeneratedColumn = mapping.generatedColumn;
-
-        if (segment.length > 1) {
-          // Original source.
-          mapping.source = previousSource + segment[1];
-          previousSource += segment[1];
-
-          // Original line.
-          mapping.originalLine = previousOriginalLine + segment[2];
-          previousOriginalLine = mapping.originalLine;
-          // Lines are stored 0-based
-          mapping.originalLine += 1;
-
-          // Original column.
-          mapping.originalColumn = previousOriginalColumn + segment[3];
-          previousOriginalColumn = mapping.originalColumn;
-
-          if (segment.length > 4) {
-            // Original name.
-            mapping.name = previousName + segment[4];
-            previousName += segment[4];
-          }
-        }
-
-        generatedMappings.push(mapping);
-        if (typeof mapping.originalLine === 'number') {
-          originalMappings.push(mapping);
-        }
+      if (kind & 2 /* CaseInsensitive */ && compareStringsCaseInsensitive2(prevElement, element) > 0) {
+        kind &= ~2 /* CaseInsensitive */;
       }
+      prevElement = element;
     }
-
-    quickSort(generatedMappings, util.compareByGeneratedPositionsDeflated);
-    this.__generatedMappings = generatedMappings;
-
-    quickSort(originalMappings, util.compareByOriginalPositions);
-    this.__originalMappings = originalMappings;
-  };
-
-/**
- * Find the mapping that best matches the hypothetical "needle" mapping that
- * we are searching for in the given "haystack" of mappings.
- */
-BasicSourceMapConsumer.prototype._findMapping =
-  function SourceMapConsumer_findMapping(aNeedle, aMappings, aLineName,
-                                         aColumnName, aComparator, aBias) {
-    // To return the position we are searching for, we must first find the
-    // mapping for the given position and then return the opposite position it
-    // points to. Because the mappings are sorted, we can use binary search to
-    // find the best mapping.
-
-    if (aNeedle[aLineName] <= 0) {
-      throw new TypeError('Line must be greater than or equal to 1, got '
-                          + aNeedle[aLineName]);
+    return kind;
+  }
+  function arrayIsEqualTo(array1, array2, equalityComparer = equateValues) {
+    if (!array1 || !array2) {
+      return array1 === array2;
     }
-    if (aNeedle[aColumnName] < 0) {
-      throw new TypeError('Column must be greater than or equal to 0, got '
-                          + aNeedle[aColumnName]);
+    if (array1.length !== array2.length) {
+      return false;
     }
-
-    return binarySearch.search(aNeedle, aMappings, aComparator, aBias);
-  };
-
-/**
- * Compute the last column for each generated mapping. The last column is
- * inclusive.
- */
-BasicSourceMapConsumer.prototype.computeColumnSpans =
-  function SourceMapConsumer_computeColumnSpans() {
-    for (var index = 0; index < this._generatedMappings.length; ++index) {
-      var mapping = this._generatedMappings[index];
-
-      // Mappings do not contain a field for the last generated columnt. We
-      // can come up with an optimistic estimate, however, by assuming that
-      // mappings are contiguous (i.e. given two consecutive mappings, the
-      // first mapping ends where the second one starts).
-      if (index + 1 < this._generatedMappings.length) {
-        var nextMapping = this._generatedMappings[index + 1];
-
-        if (mapping.generatedLine === nextMapping.generatedLine) {
-          mapping.lastGeneratedColumn = nextMapping.generatedColumn - 1;
-          continue;
-        }
+    for (let i = 0; i < array1.length; i++) {
+      if (!equalityComparer(array1[i], array2[i], i)) {
+        return false;
       }
-
-      // The last mapping for each line spans the entire line.
-      mapping.lastGeneratedColumn = Infinity;
     }
-  };
-
-/**
- * Returns the original source, line, and column information for the generated
- * source's line and column positions provided. The only argument is an object
- * with the following properties:
- *
- *   - line: The line number in the generated source.  The line number
- *     is 1-based.
- *   - column: The column number in the generated source.  The column
- *     number is 0-based.
- *   - bias: Either 'SourceMapConsumer.GREATEST_LOWER_BOUND' or
- *     'SourceMapConsumer.LEAST_UPPER_BOUND'. Specifies whether to return the
- *     closest element that is smaller than or greater than the one we are
- *     searching for, respectively, if the exact element cannot be found.
- *     Defaults to 'SourceMapConsumer.GREATEST_LOWER_BOUND'.
- *
- * and an object is returned with the following properties:
- *
- *   - source: The original source file, or null.
- *   - line: The line number in the original source, or null.  The
- *     line number is 1-based.
- *   - column: The column number in the original source, or null.  The
- *     column number is 0-based.
- *   - name: The original identifier, or null.
- */
-BasicSourceMapConsumer.prototype.originalPositionFor =
-  function SourceMapConsumer_originalPositionFor(aArgs) {
-    var needle = {
-      generatedLine: util.getArg(aArgs, 'line'),
-      generatedColumn: util.getArg(aArgs, 'column')
-    };
-
-    var index = this._findMapping(
-      needle,
-      this._generatedMappings,
-      "generatedLine",
-      "generatedColumn",
-      util.compareByGeneratedPositionsDeflated,
-      util.getArg(aArgs, 'bias', SourceMapConsumer.GREATEST_LOWER_BOUND)
-    );
-
-    if (index >= 0) {
-      var mapping = this._generatedMappings[index];
-
-      if (mapping.generatedLine === needle.generatedLine) {
-        var source = util.getArg(mapping, 'source', null);
-        if (source !== null) {
-          source = this._sources.at(source);
-          source = util.computeSourceURL(this.sourceRoot, source, this._sourceMapURL);
+    return true;
+  }
+  function compact(array) {
+    let result;
+    if (array) {
+      for (let i = 0; i < array.length; i++) {
+        const v = array[i];
+        if (result || !v) {
+          if (!result) {
+            result = array.slice(0, i);
+          }
+          if (v) {
+            result.push(v);
+          }
         }
-        var name = util.getArg(mapping, 'name', null);
-        if (name !== null) {
-          name = this._names.at(name);
+      }
+    }
+    return result || array;
+  }
+  function relativeComplement(arrayA, arrayB, comparer) {
+    if (!arrayB || !arrayA || arrayB.length === 0 || arrayA.length === 0)
+      return arrayB;
+    const result = [];
+    loopB:
+      for (let offsetA = 0, offsetB = 0; offsetB < arrayB.length; offsetB++) {
+        if (offsetB > 0) {
+          Debug.assertGreaterThanOrEqual(comparer(arrayB[offsetB], arrayB[offsetB - 1]), 0 /* EqualTo */);
         }
-        return {
-          source: source,
-          line: util.getArg(mapping, 'originalLine', null),
-          column: util.getArg(mapping, 'originalColumn', null),
-          name: name
-        };
+        loopA:
+          for (const startA = offsetA; offsetA < arrayA.length; offsetA++) {
+            if (offsetA > startA) {
+              Debug.assertGreaterThanOrEqual(comparer(arrayA[offsetA], arrayA[offsetA - 1]), 0 /* EqualTo */);
+            }
+            switch (comparer(arrayB[offsetB], arrayA[offsetA])) {
+              case -1 /* LessThan */:
+                result.push(arrayB[offsetB]);
+                continue loopB;
+              case 0 /* EqualTo */:
+                continue loopB;
+              case 1 /* GreaterThan */:
+                continue loopA;
+            }
+          }
+      }
+    return result;
+  }
+  function append(to, value) {
+    if (value === void 0)
+      return to;
+    if (to === void 0)
+      return [value];
+    to.push(value);
+    return to;
+  }
+  function combine(xs, ys) {
+    if (xs === void 0)
+      return ys;
+    if (ys === void 0)
+      return xs;
+    if (isArray(xs))
+      return isArray(ys) ? concatenate(xs, ys) : append(xs, ys);
+    if (isArray(ys))
+      return append(ys, xs);
+    return [xs, ys];
+  }
+  function toOffset(array, offset) {
+    return offset < 0 ? array.length + offset : offset;
+  }
+  function addRange(to, from, start, end) {
+    if (from === void 0 || from.length === 0)
+      return to;
+    if (to === void 0)
+      return from.slice(start, end);
+    start = start === void 0 ? 0 : toOffset(from, start);
+    end = end === void 0 ? from.length : toOffset(from, end);
+    for (let i = start; i < end && i < from.length; i++) {
+      if (from[i] !== void 0) {
+        to.push(from[i]);
       }
     }
-
-    return {
-      source: null,
-      line: null,
-      column: null,
-      name: null
-    };
-  };
-
-/**
- * Return true if we have the source content for every source in the source
- * map, false otherwise.
- */
-BasicSourceMapConsumer.prototype.hasContentsOfAllSources =
-  function BasicSourceMapConsumer_hasContentsOfAllSources() {
-    if (!this.sourcesContent) {
+    return to;
+  }
+  function pushIfUnique(array, toAdd, equalityComparer) {
+    if (contains(array, toAdd, equalityComparer)) {
       return false;
+    } else {
+      array.push(toAdd);
+      return true;
     }
-    return this.sourcesContent.length >= this._sources.size() &&
-      !this.sourcesContent.some(function (sc) { return sc == null; });
-  };
-
-/**
- * Returns the original source content. The only argument is the url of the
- * original source file. Returns null if no original source content is
- * available.
- */
-BasicSourceMapConsumer.prototype.sourceContentFor =
-  function SourceMapConsumer_sourceContentFor(aSource, nullOnMissing) {
-    if (!this.sourcesContent) {
-      return null;
-    }
-
-    var index = this._findSourceIndex(aSource);
-    if (index >= 0) {
-      return this.sourcesContent[index];
+  }
+  function appendIfUnique(array, toAdd, equalityComparer) {
+    if (array) {
+      pushIfUnique(array, toAdd, equalityComparer);
+      return array;
+    } else {
+      return [toAdd];
     }
-
-    var relativeSource = aSource;
-    if (this.sourceRoot != null) {
-      relativeSource = util.relative(this.sourceRoot, relativeSource);
+  }
+  function stableSortIndices(array, indices, comparer) {
+    indices.sort((x, y) => comparer(array[x], array[y]) || compareValues(x, y));
+  }
+  function sort(array, comparer) {
+    return array.length === 0 ? array : array.slice().sort(comparer);
+  }
+  function* arrayReverseIterator(array) {
+    for (let i = array.length - 1; i >= 0; i--) {
+      yield array[i];
     }
-
-    var url;
-    if (this.sourceRoot != null
-        && (url = util.urlParse(this.sourceRoot))) {
-      // XXX: file:// URIs and absolute paths lead to unexpected behavior for
-      // many users. We can help them out when they expect file:// URIs to
-      // behave like it would if they were running a local HTTP server. See
-      // https://bugzilla.mozilla.org/show_bug.cgi?id=885597.
-      var fileUriAbsPath = relativeSource.replace(/^file:\/\//, "");
-      if (url.scheme == "file"
-          && this._sources.has(fileUriAbsPath)) {
-        return this.sourcesContent[this._sources.indexOf(fileUriAbsPath)]
+  }
+  function stableSort(array, comparer) {
+    const indices = indicesOf(array);
+    stableSortIndices(array, indices, comparer);
+    return indices.map((i) => array[i]);
+  }
+  function rangeEquals(array1, array2, pos, end) {
+    while (pos < end) {
+      if (array1[pos] !== array2[pos]) {
+        return false;
       }
-
-      if ((!url.path || url.path == "/")
-          && this._sources.has("/" + relativeSource)) {
-        return this.sourcesContent[this._sources.indexOf("/" + relativeSource)];
+      pos++;
+    }
+    return true;
+  }
+  function firstOrUndefined(array) {
+    return array === void 0 || array.length === 0 ? void 0 : array[0];
+  }
+  function firstOrUndefinedIterator(iter) {
+    if (iter) {
+      for (const value of iter) {
+        return value;
       }
     }
-
-    // This function is used recursively from
-    // IndexedSourceMapConsumer.prototype.sourceContentFor. In that case, we
-    // don't want to throw if we can't find the source - we just want to
-    // return null, so we provide a flag to exit gracefully.
-    if (nullOnMissing) {
-      return null;
+    return void 0;
+  }
+  function first(array) {
+    Debug.assert(array.length !== 0);
+    return array[0];
+  }
+  function firstIterator(iter) {
+    for (const value of iter) {
+      return value;
     }
-    else {
-      throw new Error('"' + relativeSource + '" is not in the SourceMap.');
+    Debug.fail("iterator is empty");
+  }
+  function lastOrUndefined(array) {
+    return array === void 0 || array.length === 0 ? void 0 : array[array.length - 1];
+  }
+  function last(array) {
+    Debug.assert(array.length !== 0);
+    return array[array.length - 1];
+  }
+  function singleOrUndefined(array) {
+    return array && array.length === 1 ? array[0] : void 0;
+  }
+  function single(array) {
+    return Debug.checkDefined(singleOrUndefined(array));
+  }
+  function singleOrMany(array) {
+    return array && array.length === 1 ? array[0] : array;
+  }
+  function replaceElement(array, index, value) {
+    const result = array.slice(0);
+    result[index] = value;
+    return result;
+  }
+  function binarySearch(array, value, keySelector, keyComparer, offset) {
+    return binarySearchKey(array, keySelector(value), keySelector, keyComparer, offset);
+  }
+  function binarySearchKey(array, key, keySelector, keyComparer, offset) {
+    if (!some(array)) {
+      return -1;
     }
-  };
-
-/**
- * Returns the generated line and column information for the original source,
- * line, and column positions provided. The only argument is an object with
- * the following properties:
- *
- *   - source: The filename of the original source.
- *   - line: The line number in the original source.  The line number
- *     is 1-based.
- *   - column: The column number in the original source.  The column
- *     number is 0-based.
- *   - bias: Either 'SourceMapConsumer.GREATEST_LOWER_BOUND' or
- *     'SourceMapConsumer.LEAST_UPPER_BOUND'. Specifies whether to return the
- *     closest element that is smaller than or greater than the one we are
- *     searching for, respectively, if the exact element cannot be found.
- *     Defaults to 'SourceMapConsumer.GREATEST_LOWER_BOUND'.
- *
- * and an object is returned with the following properties:
- *
- *   - line: The line number in the generated source, or null.  The
- *     line number is 1-based.
- *   - column: The column number in the generated source, or null.
- *     The column number is 0-based.
- */
-BasicSourceMapConsumer.prototype.generatedPositionFor =
-  function SourceMapConsumer_generatedPositionFor(aArgs) {
-    var source = util.getArg(aArgs, 'source');
-    source = this._findSourceIndex(source);
-    if (source < 0) {
-      return {
-        line: null,
-        column: null,
-        lastColumn: null
-      };
+    let low = offset || 0;
+    let high = array.length - 1;
+    while (low <= high) {
+      const middle = low + (high - low >> 1);
+      const midKey = keySelector(array[middle], middle);
+      switch (keyComparer(midKey, key)) {
+        case -1 /* LessThan */:
+          low = middle + 1;
+          break;
+        case 0 /* EqualTo */:
+          return middle;
+        case 1 /* GreaterThan */:
+          high = middle - 1;
+          break;
+      }
     }
-
-    var needle = {
-      source: source,
-      originalLine: util.getArg(aArgs, 'line'),
-      originalColumn: util.getArg(aArgs, 'column')
-    };
-
-    var index = this._findMapping(
-      needle,
-      this._originalMappings,
-      "originalLine",
-      "originalColumn",
-      util.compareByOriginalPositions,
-      util.getArg(aArgs, 'bias', SourceMapConsumer.GREATEST_LOWER_BOUND)
-    );
-
-    if (index >= 0) {
-      var mapping = this._originalMappings[index];
-
-      if (mapping.source === needle.source) {
-        return {
-          line: util.getArg(mapping, 'generatedLine', null),
-          column: util.getArg(mapping, 'generatedColumn', null),
-          lastColumn: util.getArg(mapping, 'lastGeneratedColumn', null)
-        };
+    return ~low;
+  }
+  function reduceLeft(array, f, initial, start, count) {
+    if (array && array.length > 0) {
+      const size = array.length;
+      if (size > 0) {
+        let pos = start === void 0 || start < 0 ? 0 : start;
+        const end = count === void 0 || pos + count > size - 1 ? size - 1 : pos + count;
+        let result;
+        if (arguments.length <= 2) {
+          result = array[pos];
+          pos++;
+        } else {
+          result = initial;
+        }
+        while (pos <= end) {
+          result = f(result, array[pos], pos);
+          pos++;
+        }
+        return result;
       }
     }
-
-    return {
-      line: null,
-      column: null,
-      lastColumn: null
-    };
-  };
-
-__webpack_unused_export__ = BasicSourceMapConsumer;
-
-/**
- * An IndexedSourceMapConsumer instance represents a parsed source map which
- * we can query for information. It differs from BasicSourceMapConsumer in
- * that it takes "indexed" source maps (i.e. ones with a "sections" field) as
- * input.
- *
- * The first parameter is a raw source map (either as a JSON string, or already
- * parsed to an object). According to the spec for indexed source maps, they
- * have the following attributes:
- *
- *   - version: Which version of the source map spec this map is following.
- *   - file: Optional. The generated file this source map is associated with.
- *   - sections: A list of section definitions.
- *
- * Each value under the "sections" field has two fields:
- *   - offset: The offset into the original specified at which this section
- *       begins to apply, defined as an object with a "line" and "column"
- *       field.
- *   - map: A source map definition. This source map could also be indexed,
- *       but doesn't have to be.
- *
- * Instead of the "map" field, it's also possible to have a "url" field
- * specifying a URL to retrieve a source map from, but that's currently
- * unsupported.
- *
- * Here's an example source map, taken from the source map spec[0], but
- * modified to omit a section which uses the "url" field.
- *
- *  {
- *    version : 3,
- *    file: "app.js",
- *    sections: [{
- *      offset: {line:100, column:10},
- *      map: {
- *        version : 3,
- *        file: "section.js",
- *        sources: ["foo.js", "bar.js"],
- *        names: ["src", "maps", "are", "fun"],
- *        mappings: "AAAA,E;;ABCDE;"
- *      }
- *    }],
- *  }
- *
- * The second parameter, if given, is a string whose value is the URL
- * at which the source map was found.  This URL is used to compute the
- * sources array.
- *
- * [0]: https://docs.google.com/document/d/1U1RGAehQwRypUTovF1KRlpiOFze0b-_2gc6fAH0KY0k/edit#heading=h.535es3xeprgt
- */
-function IndexedSourceMapConsumer(aSourceMap, aSourceMapURL) {
-  var sourceMap = aSourceMap;
-  if (typeof aSourceMap === 'string') {
-    sourceMap = util.parseSourceMapInput(aSourceMap);
+    return initial;
   }
-
-  var version = util.getArg(sourceMap, 'version');
-  var sections = util.getArg(sourceMap, 'sections');
-
-  if (version != this._version) {
-    throw new Error('Unsupported version: ' + version);
+  function hasProperty(map2, key) {
+    return hasOwnProperty.call(map2, key);
   }
-
-  this._sources = new ArraySet();
-  this._names = new ArraySet();
-
-  var lastOffset = {
-    line: -1,
-    column: 0
-  };
-  this._sections = sections.map(function (s) {
-    if (s.url) {
-      // The url field will require support for asynchronicity.
-      // See https://github.com/mozilla/source-map/issues/16
-      throw new Error('Support for url field in sections not implemented.');
+  function getProperty(map2, key) {
+    return hasOwnProperty.call(map2, key) ? map2[key] : void 0;
+  }
+  function getOwnKeys(map2) {
+    const keys = [];
+    for (const key in map2) {
+      if (hasOwnProperty.call(map2, key)) {
+        keys.push(key);
+      }
     }
-    var offset = util.getArg(s, 'offset');
-    var offsetLine = util.getArg(offset, 'line');
-    var offsetColumn = util.getArg(offset, 'column');
-
-    if (offsetLine < lastOffset.line ||
-        (offsetLine === lastOffset.line && offsetColumn < lastOffset.column)) {
-      throw new Error('Section offsets must be ordered and non-overlapping.');
+    return keys;
+  }
+  function getAllKeys(obj) {
+    const result = [];
+    do {
+      const names = Object.getOwnPropertyNames(obj);
+      for (const name of names) {
+        pushIfUnique(result, name);
+      }
+    } while (obj = Object.getPrototypeOf(obj));
+    return result;
+  }
+  function getOwnValues(collection) {
+    const values = [];
+    for (const key in collection) {
+      if (hasOwnProperty.call(collection, key)) {
+        values.push(collection[key]);
+      }
     }
-    lastOffset = offset;
-
-    return {
-      generatedOffset: {
-        // The offset fields are 0-based, but we use 1-based indices when
-        // encoding/decoding from VLQ.
-        generatedLine: offsetLine + 1,
-        generatedColumn: offsetColumn + 1
-      },
-      consumer: new SourceMapConsumer(util.getArg(s, 'map'), aSourceMapURL)
+    return values;
+  }
+  function arrayOf(count, f) {
+    const result = new Array(count);
+    for (let i = 0; i < count; i++) {
+      result[i] = f(i);
     }
-  });
-}
-
-IndexedSourceMapConsumer.prototype = Object.create(SourceMapConsumer.prototype);
-IndexedSourceMapConsumer.prototype.constructor = SourceMapConsumer;
-
-/**
- * The version of the source mapping spec that we are consuming.
- */
-IndexedSourceMapConsumer.prototype._version = 3;
-
-/**
- * The list of original sources.
- */
-Object.defineProperty(IndexedSourceMapConsumer.prototype, 'sources', {
-  get: function () {
-    var sources = [];
-    for (var i = 0; i < this._sections.length; i++) {
-      for (var j = 0; j < this._sections[i].consumer.sources.length; j++) {
-        sources.push(this._sections[i].consumer.sources[j]);
-      }
+    return result;
+  }
+  function arrayFrom(iterator, map2) {
+    const result = [];
+    for (const value of iterator) {
+      result.push(map2 ? map2(value) : value);
     }
-    return sources;
+    return result;
   }
-});
-
-/**
- * Returns the original source, line, and column information for the generated
- * source's line and column positions provided. The only argument is an object
- * with the following properties:
- *
- *   - line: The line number in the generated source.  The line number
- *     is 1-based.
- *   - column: The column number in the generated source.  The column
- *     number is 0-based.
- *
- * and an object is returned with the following properties:
- *
- *   - source: The original source file, or null.
- *   - line: The line number in the original source, or null.  The
- *     line number is 1-based.
- *   - column: The column number in the original source, or null.  The
- *     column number is 0-based.
- *   - name: The original identifier, or null.
- */
-IndexedSourceMapConsumer.prototype.originalPositionFor =
-  function IndexedSourceMapConsumer_originalPositionFor(aArgs) {
-    var needle = {
-      generatedLine: util.getArg(aArgs, 'line'),
-      generatedColumn: util.getArg(aArgs, 'column')
-    };
-
-    // Find the section containing the generated position we're trying to map
-    // to an original position.
-    var sectionIndex = binarySearch.search(needle, this._sections,
-      function(needle, section) {
-        var cmp = needle.generatedLine - section.generatedOffset.generatedLine;
-        if (cmp) {
-          return cmp;
+  function assign(t, ...args) {
+    for (const arg of args) {
+      if (arg === void 0)
+        continue;
+      for (const p in arg) {
+        if (hasProperty(arg, p)) {
+          t[p] = arg[p];
         }
-
-        return (needle.generatedColumn -
-                section.generatedOffset.generatedColumn);
-      });
-    var section = this._sections[sectionIndex];
-
-    if (!section) {
-      return {
-        source: null,
-        line: null,
-        column: null,
-        name: null
-      };
+      }
     }
-
-    return section.consumer.originalPositionFor({
-      line: needle.generatedLine -
-        (section.generatedOffset.generatedLine - 1),
-      column: needle.generatedColumn -
-        (section.generatedOffset.generatedLine === needle.generatedLine
-         ? section.generatedOffset.generatedColumn - 1
-         : 0),
-      bias: aArgs.bias
-    });
-  };
-
-/**
- * Return true if we have the source content for every source in the source
- * map, false otherwise.
- */
-IndexedSourceMapConsumer.prototype.hasContentsOfAllSources =
-  function IndexedSourceMapConsumer_hasContentsOfAllSources() {
-    return this._sections.every(function (s) {
-      return s.consumer.hasContentsOfAllSources();
-    });
-  };
-
-/**
- * Returns the original source content. The only argument is the url of the
- * original source file. Returns null if no original source content is
- * available.
- */
-IndexedSourceMapConsumer.prototype.sourceContentFor =
-  function IndexedSourceMapConsumer_sourceContentFor(aSource, nullOnMissing) {
-    for (var i = 0; i < this._sections.length; i++) {
-      var section = this._sections[i];
-
-      var content = section.consumer.sourceContentFor(aSource, true);
-      if (content) {
-        return content;
+    return t;
+  }
+  function equalOwnProperties(left, right, equalityComparer = equateValues) {
+    if (left === right)
+      return true;
+    if (!left || !right)
+      return false;
+    for (const key in left) {
+      if (hasOwnProperty.call(left, key)) {
+        if (!hasOwnProperty.call(right, key))
+          return false;
+        if (!equalityComparer(left[key], right[key]))
+          return false;
       }
     }
-    if (nullOnMissing) {
-      return null;
+    for (const key in right) {
+      if (hasOwnProperty.call(right, key)) {
+        if (!hasOwnProperty.call(left, key))
+          return false;
+      }
     }
-    else {
-      throw new Error('"' + aSource + '" is not in the SourceMap.');
+    return true;
+  }
+  function arrayToMap(array, makeKey, makeValue = identity) {
+    const result = /* @__PURE__ */ new Map();
+    for (const value of array) {
+      const key = makeKey(value);
+      if (key !== void 0)
+        result.set(key, makeValue(value));
     }
-  };
-
-/**
- * Returns the generated line and column information for the original source,
- * line, and column positions provided. The only argument is an object with
- * the following properties:
- *
- *   - source: The filename of the original source.
- *   - line: The line number in the original source.  The line number
- *     is 1-based.
- *   - column: The column number in the original source.  The column
- *     number is 0-based.
- *
- * and an object is returned with the following properties:
- *
- *   - line: The line number in the generated source, or null.  The
- *     line number is 1-based. 
- *   - column: The column number in the generated source, or null.
- *     The column number is 0-based.
- */
-IndexedSourceMapConsumer.prototype.generatedPositionFor =
-  function IndexedSourceMapConsumer_generatedPositionFor(aArgs) {
-    for (var i = 0; i < this._sections.length; i++) {
-      var section = this._sections[i];
-
-      // Only consider this section if the requested source is in the list of
-      // sources of the consumer.
-      if (section.consumer._findSourceIndex(util.getArg(aArgs, 'source')) === -1) {
-        continue;
-      }
-      var generatedPosition = section.consumer.generatedPositionFor(aArgs);
-      if (generatedPosition) {
-        var ret = {
-          line: generatedPosition.line +
-            (section.generatedOffset.generatedLine - 1),
-          column: generatedPosition.column +
-            (section.generatedOffset.generatedLine === generatedPosition.line
-             ? section.generatedOffset.generatedColumn - 1
-             : 0)
-        };
-        return ret;
+    return result;
+  }
+  function arrayToNumericMap(array, makeKey, makeValue = identity) {
+    const result = [];
+    for (const value of array) {
+      result[makeKey(value)] = makeValue(value);
+    }
+    return result;
+  }
+  function arrayToMultiMap(values, makeKey, makeValue = identity) {
+    const result = createMultiMap();
+    for (const value of values) {
+      result.add(makeKey(value), makeValue(value));
+    }
+    return result;
+  }
+  function group(values, getGroupId, resultSelector = identity) {
+    return arrayFrom(arrayToMultiMap(values, getGroupId).values(), resultSelector);
+  }
+  function groupBy(values, keySelector) {
+    const result = {};
+    if (values) {
+      for (const value of values) {
+        const key = `${keySelector(value)}`;
+        const array = result[key] ?? (result[key] = []);
+        array.push(value);
       }
     }
-
-    return {
-      line: null,
-      column: null
-    };
-  };
-
-/**
- * Parse the mappings in a string in to a data structure which we can easily
- * query (the ordered arrays in the `this.__generatedMappings` and
- * `this.__originalMappings` properties).
- */
-IndexedSourceMapConsumer.prototype._parseMappings =
-  function IndexedSourceMapConsumer_parseMappings(aStr, aSourceRoot) {
-    this.__generatedMappings = [];
-    this.__originalMappings = [];
-    for (var i = 0; i < this._sections.length; i++) {
-      var section = this._sections[i];
-      var sectionMappings = section.consumer._generatedMappings;
-      for (var j = 0; j < sectionMappings.length; j++) {
-        var mapping = sectionMappings[j];
-
-        var source = section.consumer._sources.at(mapping.source);
-        source = util.computeSourceURL(section.consumer.sourceRoot, source, this._sourceMapURL);
-        this._sources.add(source);
-        source = this._sources.indexOf(source);
-
-        var name = null;
-        if (mapping.name) {
-          name = section.consumer._names.at(mapping.name);
-          this._names.add(name);
-          name = this._names.indexOf(name);
-        }
-
-        // The mappings coming from the consumer for the section have
-        // generated positions relative to the start of the section, so we
-        // need to offset them to be relative to the start of the concatenated
-        // generated file.
-        var adjustedMapping = {
-          source: source,
-          generatedLine: mapping.generatedLine +
-            (section.generatedOffset.generatedLine - 1),
-          generatedColumn: mapping.generatedColumn +
-            (section.generatedOffset.generatedLine === mapping.generatedLine
-            ? section.generatedOffset.generatedColumn - 1
-            : 0),
-          originalLine: mapping.originalLine,
-          originalColumn: mapping.originalColumn,
-          name: name
-        };
-
-        this.__generatedMappings.push(adjustedMapping);
-        if (typeof adjustedMapping.originalLine === 'number') {
-          this.__originalMappings.push(adjustedMapping);
-        }
+    return result;
+  }
+  function clone(object) {
+    const result = {};
+    for (const id in object) {
+      if (hasOwnProperty.call(object, id)) {
+        result[id] = object[id];
       }
     }
-
-    quickSort(this.__generatedMappings, util.compareByGeneratedPositionsDeflated);
-    quickSort(this.__originalMappings, util.compareByOriginalPositions);
-  };
-
-__webpack_unused_export__ = IndexedSourceMapConsumer;
-
-
-/***/ }),
-
-/***/ 66677:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
-
-/* -*- Mode: js; js-indent-level: 2; -*- */
-/*
- * Copyright 2011 Mozilla Foundation and contributors
- * Licensed under the New BSD license. See LICENSE or:
- * http://opensource.org/licenses/BSD-3-Clause
- */
-
-var base64VLQ = __nccwpck_require__(14590);
-var util = __nccwpck_require__(16511);
-var ArraySet = (__nccwpck_require__(30176)/* .ArraySet */ .I);
-var MappingList = (__nccwpck_require__(31247)/* .MappingList */ .H);
-
-/**
- * An instance of the SourceMapGenerator represents a source map which is
- * being built incrementally. You may pass an object with the following
- * properties:
- *
- *   - file: The filename of the generated source.
- *   - sourceRoot: A root for all relative URLs in this source map.
- */
-function SourceMapGenerator(aArgs) {
-  if (!aArgs) {
-    aArgs = {};
+    return result;
   }
-  this._file = util.getArg(aArgs, 'file', null);
-  this._sourceRoot = util.getArg(aArgs, 'sourceRoot', null);
-  this._skipValidation = util.getArg(aArgs, 'skipValidation', false);
-  this._sources = new ArraySet();
-  this._names = new ArraySet();
-  this._mappings = new MappingList();
-  this._sourcesContents = null;
-}
-
-SourceMapGenerator.prototype._version = 3;
-
-/**
- * Creates a new SourceMapGenerator based on a SourceMapConsumer
- *
- * @param aSourceMapConsumer The SourceMap.
- */
-SourceMapGenerator.fromSourceMap =
-  function SourceMapGenerator_fromSourceMap(aSourceMapConsumer) {
-    var sourceRoot = aSourceMapConsumer.sourceRoot;
-    var generator = new SourceMapGenerator({
-      file: aSourceMapConsumer.file,
-      sourceRoot: sourceRoot
-    });
-    aSourceMapConsumer.eachMapping(function (mapping) {
-      var newMapping = {
-        generated: {
-          line: mapping.generatedLine,
-          column: mapping.generatedColumn
-        }
-      };
-
-      if (mapping.source != null) {
-        newMapping.source = mapping.source;
-        if (sourceRoot != null) {
-          newMapping.source = util.relative(sourceRoot, newMapping.source);
-        }
-
-        newMapping.original = {
-          line: mapping.originalLine,
-          column: mapping.originalColumn
-        };
-
-        if (mapping.name != null) {
-          newMapping.name = mapping.name;
-        }
-      }
-
-      generator.addMapping(newMapping);
-    });
-    aSourceMapConsumer.sources.forEach(function (sourceFile) {
-      var sourceRelative = sourceFile;
-      if (sourceRoot !== null) {
-        sourceRelative = util.relative(sourceRoot, sourceFile);
-      }
-
-      if (!generator._sources.has(sourceRelative)) {
-        generator._sources.add(sourceRelative);
-      }
-
-      var content = aSourceMapConsumer.sourceContentFor(sourceFile);
-      if (content != null) {
-        generator.setSourceContent(sourceFile, content);
+  function extend(first2, second) {
+    const result = {};
+    for (const id in second) {
+      if (hasOwnProperty.call(second, id)) {
+        result[id] = second[id];
       }
-    });
-    return generator;
-  };
-
-/**
- * Add a single mapping from original source line and column to the generated
- * source's line and column for this source map being created. The mapping
- * object should have the following properties:
- *
- *   - generated: An object with the generated line and column positions.
- *   - original: An object with the original line and column positions.
- *   - source: The original source file (relative to the sourceRoot).
- *   - name: An optional original token name for this mapping.
- */
-SourceMapGenerator.prototype.addMapping =
-  function SourceMapGenerator_addMapping(aArgs) {
-    var generated = util.getArg(aArgs, 'generated');
-    var original = util.getArg(aArgs, 'original', null);
-    var source = util.getArg(aArgs, 'source', null);
-    var name = util.getArg(aArgs, 'name', null);
-
-    if (!this._skipValidation) {
-      this._validateMapping(generated, original, source, name);
     }
-
-    if (source != null) {
-      source = String(source);
-      if (!this._sources.has(source)) {
-        this._sources.add(source);
+    for (const id in first2) {
+      if (hasOwnProperty.call(first2, id)) {
+        result[id] = first2[id];
       }
     }
-
-    if (name != null) {
-      name = String(name);
-      if (!this._names.has(name)) {
-        this._names.add(name);
+    return result;
+  }
+  function copyProperties(first2, second) {
+    for (const id in second) {
+      if (hasOwnProperty.call(second, id)) {
+        first2[id] = second[id];
       }
     }
-
-    this._mappings.add({
-      generatedLine: generated.line,
-      generatedColumn: generated.column,
-      originalLine: original != null && original.line,
-      originalColumn: original != null && original.column,
-      source: source,
-      name: name
-    });
-  };
-
-/**
- * Set the source content for a source file.
- */
-SourceMapGenerator.prototype.setSourceContent =
-  function SourceMapGenerator_setSourceContent(aSourceFile, aSourceContent) {
-    var source = aSourceFile;
-    if (this._sourceRoot != null) {
-      source = util.relative(this._sourceRoot, source);
+  }
+  function maybeBind(obj, fn) {
+    return fn ? fn.bind(obj) : void 0;
+  }
+  function createMultiMap() {
+    const map2 = /* @__PURE__ */ new Map();
+    map2.add = multiMapAdd;
+    map2.remove = multiMapRemove;
+    return map2;
+  }
+  function multiMapAdd(key, value) {
+    let values = this.get(key);
+    if (values) {
+      values.push(value);
+    } else {
+      this.set(key, values = [value]);
     }
-
-    if (aSourceContent != null) {
-      // Add the source content to the _sourcesContents map.
-      // Create a new _sourcesContents map if the property is null.
-      if (!this._sourcesContents) {
-        this._sourcesContents = Object.create(null);
-      }
-      this._sourcesContents[util.toSetString(source)] = aSourceContent;
-    } else if (this._sourcesContents) {
-      // Remove the source file from the _sourcesContents map.
-      // If the _sourcesContents map is empty, set the property to null.
-      delete this._sourcesContents[util.toSetString(source)];
-      if (Object.keys(this._sourcesContents).length === 0) {
-        this._sourcesContents = null;
+    return values;
+  }
+  function multiMapRemove(key, value) {
+    const values = this.get(key);
+    if (values) {
+      unorderedRemoveItem(values, value);
+      if (!values.length) {
+        this.delete(key);
       }
     }
-  };
-
-/**
- * Applies the mappings of a sub-source-map for a specific source file to the
- * source map being generated. Each mapping to the supplied source file is
- * rewritten using the supplied source map. Note: The resolution for the
- * resulting mappings is the minimium of this map and the supplied map.
- *
- * @param aSourceMapConsumer The source map to be applied.
- * @param aSourceFile Optional. The filename of the source file.
- *        If omitted, SourceMapConsumer's file property will be used.
- * @param aSourceMapPath Optional. The dirname of the path to the source map
- *        to be applied. If relative, it is relative to the SourceMapConsumer.
- *        This parameter is needed when the two source maps aren't in the same
- *        directory, and the source map to be applied contains relative source
- *        paths. If so, those relative source paths need to be rewritten
- *        relative to the SourceMapGenerator.
- */
-SourceMapGenerator.prototype.applySourceMap =
-  function SourceMapGenerator_applySourceMap(aSourceMapConsumer, aSourceFile, aSourceMapPath) {
-    var sourceFile = aSourceFile;
-    // If aSourceFile is omitted, we will use the file property of the SourceMap
-    if (aSourceFile == null) {
-      if (aSourceMapConsumer.file == null) {
-        throw new Error(
-          'SourceMapGenerator.prototype.applySourceMap requires either an explicit source file, ' +
-          'or the source map\'s "file" property. Both were omitted.'
+  }
+  function createQueue(items) {
+    const elements = (items == null ? void 0 : items.slice()) || [];
+    let headIndex = 0;
+    function isEmpty() {
+      return headIndex === elements.length;
+    }
+    function enqueue(...items2) {
+      elements.push(...items2);
+    }
+    function dequeue() {
+      if (isEmpty()) {
+        throw new Error("Queue is empty");
+      }
+      const result = elements[headIndex];
+      elements[headIndex] = void 0;
+      headIndex++;
+      if (headIndex > 100 && headIndex > elements.length >> 1) {
+        const newLength = elements.length - headIndex;
+        elements.copyWithin(
+          /*target*/
+          0,
+          /*start*/
+          headIndex
         );
+        elements.length = newLength;
+        headIndex = 0;
       }
-      sourceFile = aSourceMapConsumer.file;
+      return result;
     }
-    var sourceRoot = this._sourceRoot;
-    // Make "sourceFile" relative if an absolute Url is passed.
-    if (sourceRoot != null) {
-      sourceFile = util.relative(sourceRoot, sourceFile);
+    return {
+      enqueue,
+      dequeue,
+      isEmpty
+    };
+  }
+  function createSet(getHashCode, equals) {
+    const multiMap = /* @__PURE__ */ new Map();
+    let size = 0;
+    function* getElementIterator() {
+      for (const value of multiMap.values()) {
+        if (isArray(value)) {
+          yield* value;
+        } else {
+          yield value;
+        }
+      }
     }
-    // Applying the SourceMap can add and remove items from the sources and
-    // the names array.
-    var newSources = new ArraySet();
-    var newNames = new ArraySet();
-
-    // Find mappings for the "sourceFile"
-    this._mappings.unsortedForEach(function (mapping) {
-      if (mapping.source === sourceFile && mapping.originalLine != null) {
-        // Check if it can be mapped by the source map, then update the mapping.
-        var original = aSourceMapConsumer.originalPositionFor({
-          line: mapping.originalLine,
-          column: mapping.originalColumn
-        });
-        if (original.source != null) {
-          // Copy mapping
-          mapping.source = original.source;
-          if (aSourceMapPath != null) {
-            mapping.source = util.join(aSourceMapPath, mapping.source)
+    const set = {
+      has(element) {
+        const hash = getHashCode(element);
+        if (!multiMap.has(hash))
+          return false;
+        const candidates = multiMap.get(hash);
+        if (!isArray(candidates))
+          return equals(candidates, element);
+        for (const candidate of candidates) {
+          if (equals(candidate, element)) {
+            return true;
           }
-          if (sourceRoot != null) {
-            mapping.source = util.relative(sourceRoot, mapping.source);
+        }
+        return false;
+      },
+      add(element) {
+        const hash = getHashCode(element);
+        if (multiMap.has(hash)) {
+          const values = multiMap.get(hash);
+          if (isArray(values)) {
+            if (!contains(values, element, equals)) {
+              values.push(element);
+              size++;
+            }
+          } else {
+            const value = values;
+            if (!equals(value, element)) {
+              multiMap.set(hash, [value, element]);
+              size++;
+            }
           }
-          mapping.originalLine = original.line;
-          mapping.originalColumn = original.column;
-          if (original.name != null) {
-            mapping.name = original.name;
+        } else {
+          multiMap.set(hash, element);
+          size++;
+        }
+        return this;
+      },
+      delete(element) {
+        const hash = getHashCode(element);
+        if (!multiMap.has(hash))
+          return false;
+        const candidates = multiMap.get(hash);
+        if (isArray(candidates)) {
+          for (let i = 0; i < candidates.length; i++) {
+            if (equals(candidates[i], element)) {
+              if (candidates.length === 1) {
+                multiMap.delete(hash);
+              } else if (candidates.length === 2) {
+                multiMap.set(hash, candidates[1 - i]);
+              } else {
+                unorderedRemoveItemAt(candidates, i);
+              }
+              size--;
+              return true;
+            }
+          }
+        } else {
+          const candidate = candidates;
+          if (equals(candidate, element)) {
+            multiMap.delete(hash);
+            size--;
+            return true;
           }
         }
+        return false;
+      },
+      clear() {
+        multiMap.clear();
+        size = 0;
+      },
+      get size() {
+        return size;
+      },
+      forEach(action) {
+        for (const elements of arrayFrom(multiMap.values())) {
+          if (isArray(elements)) {
+            for (const element of elements) {
+              action(element, element, set);
+            }
+          } else {
+            const element = elements;
+            action(element, element, set);
+          }
+        }
+      },
+      keys() {
+        return getElementIterator();
+      },
+      values() {
+        return getElementIterator();
+      },
+      *entries() {
+        for (const value of getElementIterator()) {
+          yield [value, value];
+        }
+      },
+      [Symbol.iterator]: () => {
+        return getElementIterator();
+      },
+      [Symbol.toStringTag]: multiMap[Symbol.toStringTag]
+    };
+    return set;
+  }
+  function isArray(value) {
+    return Array.isArray(value);
+  }
+  function toArray(value) {
+    return isArray(value) ? value : [value];
+  }
+  function isString(text) {
+    return typeof text === "string";
+  }
+  function isNumber(x) {
+    return typeof x === "number";
+  }
+  function tryCast(value, test) {
+    return value !== void 0 && test(value) ? value : void 0;
+  }
+  function cast(value, test) {
+    if (value !== void 0 && test(value))
+      return value;
+    return Debug.fail(`Invalid cast. The supplied value ${value} did not pass the test '${Debug.getFunctionName(test)}'.`);
+  }
+  function noop(_) {
+  }
+  function returnFalse() {
+    return false;
+  }
+  function returnTrue() {
+    return true;
+  }
+  function returnUndefined() {
+    return void 0;
+  }
+  function identity(x) {
+    return x;
+  }
+  function toLowerCase(x) {
+    return x.toLowerCase();
+  }
+  function toFileNameLowerCase(x) {
+    return fileNameLowerCaseRegExp.test(x) ? x.replace(fileNameLowerCaseRegExp, toLowerCase) : x;
+  }
+  function notImplemented() {
+    throw new Error("Not implemented");
+  }
+  function memoize(callback) {
+    let value;
+    return () => {
+      if (callback) {
+        value = callback();
+        callback = void 0;
       }
-
-      var source = mapping.source;
-      if (source != null && !newSources.has(source)) {
-        newSources.add(source);
+      return value;
+    };
+  }
+  function memoizeOne(callback) {
+    const map2 = /* @__PURE__ */ new Map();
+    return (arg) => {
+      const key = `${typeof arg}:${arg}`;
+      let value = map2.get(key);
+      if (value === void 0 && !map2.has(key)) {
+        value = callback(arg);
+        map2.set(key, value);
       }
-
-      var name = mapping.name;
-      if (name != null && !newNames.has(name)) {
-        newNames.add(name);
+      return value;
+    };
+  }
+  function memoizeWeak(callback) {
+    const map2 = /* @__PURE__ */ new WeakMap();
+    return (arg) => {
+      let value = map2.get(arg);
+      if (value === void 0 && !map2.has(arg)) {
+        value = callback(arg);
+        map2.set(arg, value);
       }
-
-    }, this);
-    this._sources = newSources;
-    this._names = newNames;
-
-    // Copy sourcesContents of applied map.
-    aSourceMapConsumer.sources.forEach(function (sourceFile) {
-      var content = aSourceMapConsumer.sourceContentFor(sourceFile);
-      if (content != null) {
-        if (aSourceMapPath != null) {
-          sourceFile = util.join(aSourceMapPath, sourceFile);
+      return value;
+    };
+  }
+  function memoizeCached(callback, cache) {
+    return (...args) => {
+      let value = cache.get(args);
+      if (value === void 0 && !cache.has(args)) {
+        value = callback(...args);
+        cache.set(args, value);
+      }
+      return value;
+    };
+  }
+  function compose(a, b, c, d, e) {
+    if (!!e) {
+      const args = [];
+      for (let i = 0; i < arguments.length; i++) {
+        args[i] = arguments[i];
+      }
+      return (t) => reduceLeft(args, (u, f) => f(u), t);
+    } else if (d) {
+      return (t) => d(c(b(a(t))));
+    } else if (c) {
+      return (t) => c(b(a(t)));
+    } else if (b) {
+      return (t) => b(a(t));
+    } else if (a) {
+      return (t) => a(t);
+    } else {
+      return (t) => t;
+    }
+  }
+  function equateValues(a, b) {
+    return a === b;
+  }
+  function equateStringsCaseInsensitive(a, b) {
+    return a === b || a !== void 0 && b !== void 0 && a.toUpperCase() === b.toUpperCase();
+  }
+  function equateStringsCaseSensitive(a, b) {
+    return equateValues(a, b);
+  }
+  function compareComparableValues(a, b) {
+    return a === b ? 0 /* EqualTo */ : a === void 0 ? -1 /* LessThan */ : b === void 0 ? 1 /* GreaterThan */ : a < b ? -1 /* LessThan */ : 1 /* GreaterThan */;
+  }
+  function compareValues(a, b) {
+    return compareComparableValues(a, b);
+  }
+  function compareTextSpans(a, b) {
+    return compareValues(a == null ? void 0 : a.start, b == null ? void 0 : b.start) || compareValues(a == null ? void 0 : a.length, b == null ? void 0 : b.length);
+  }
+  function min(items, compare) {
+    return reduceLeft(items, (x, y) => compare(x, y) === -1 /* LessThan */ ? x : y);
+  }
+  function compareStringsCaseInsensitive(a, b) {
+    if (a === b)
+      return 0 /* EqualTo */;
+    if (a === void 0)
+      return -1 /* LessThan */;
+    if (b === void 0)
+      return 1 /* GreaterThan */;
+    a = a.toUpperCase();
+    b = b.toUpperCase();
+    return a < b ? -1 /* LessThan */ : a > b ? 1 /* GreaterThan */ : 0 /* EqualTo */;
+  }
+  function compareStringsCaseInsensitiveEslintCompatible(a, b) {
+    if (a === b)
+      return 0 /* EqualTo */;
+    if (a === void 0)
+      return -1 /* LessThan */;
+    if (b === void 0)
+      return 1 /* GreaterThan */;
+    a = a.toLowerCase();
+    b = b.toLowerCase();
+    return a < b ? -1 /* LessThan */ : a > b ? 1 /* GreaterThan */ : 0 /* EqualTo */;
+  }
+  function compareStringsCaseSensitive(a, b) {
+    return compareComparableValues(a, b);
+  }
+  function getStringComparer(ignoreCase) {
+    return ignoreCase ? compareStringsCaseInsensitive : compareStringsCaseSensitive;
+  }
+  function getUILocale() {
+    return uiLocale;
+  }
+  function setUILocale(value) {
+    if (uiLocale !== value) {
+      uiLocale = value;
+      uiComparerCaseSensitive = void 0;
+    }
+  }
+  function compareStringsCaseSensitiveUI(a, b) {
+    const comparer = uiComparerCaseSensitive || (uiComparerCaseSensitive = createUIStringComparer(uiLocale));
+    return comparer(a, b);
+  }
+  function compareProperties(a, b, key, comparer) {
+    return a === b ? 0 /* EqualTo */ : a === void 0 ? -1 /* LessThan */ : b === void 0 ? 1 /* GreaterThan */ : comparer(a[key], b[key]);
+  }
+  function compareBooleans(a, b) {
+    return compareValues(a ? 1 : 0, b ? 1 : 0);
+  }
+  function getSpellingSuggestion(name, candidates, getName) {
+    const maximumLengthDifference = Math.max(2, Math.floor(name.length * 0.34));
+    let bestDistance = Math.floor(name.length * 0.4) + 1;
+    let bestCandidate;
+    for (const candidate of candidates) {
+      const candidateName = getName(candidate);
+      if (candidateName !== void 0 && Math.abs(candidateName.length - name.length) <= maximumLengthDifference) {
+        if (candidateName === name) {
+          continue;
         }
-        if (sourceRoot != null) {
-          sourceFile = util.relative(sourceRoot, sourceFile);
+        if (candidateName.length < 3 && candidateName.toLowerCase() !== name.toLowerCase()) {
+          continue;
         }
-        this.setSourceContent(sourceFile, content);
+        const distance = levenshteinWithMax(name, candidateName, bestDistance - 0.1);
+        if (distance === void 0) {
+          continue;
+        }
+        Debug.assert(distance < bestDistance);
+        bestDistance = distance;
+        bestCandidate = candidate;
       }
-    }, this);
-  };
-
-/**
- * A mapping can have one of the three levels of data:
- *
- *   1. Just the generated position.
- *   2. The Generated position, original position, and original source.
- *   3. Generated and original position, original source, as well as a name
- *      token.
- *
- * To maintain consistency, we validate that any new mapping being added falls
- * in to one of these categories.
- */
-SourceMapGenerator.prototype._validateMapping =
-  function SourceMapGenerator_validateMapping(aGenerated, aOriginal, aSource,
-                                              aName) {
-    // When aOriginal is truthy but has empty values for .line and .column,
-    // it is most likely a programmer error. In this case we throw a very
-    // specific error message to try to guide them the right way.
-    // For example: https://github.com/Polymer/polymer-bundler/pull/519
-    if (aOriginal && typeof aOriginal.line !== 'number' && typeof aOriginal.column !== 'number') {
-        throw new Error(
-            'original.line and original.column are not numbers -- you probably meant to omit ' +
-            'the original mapping entirely and only map the generated position. If so, pass ' +
-            'null for the original mapping instead of an object with empty or null values.'
-        );
-    }
-
-    if (aGenerated && 'line' in aGenerated && 'column' in aGenerated
-        && aGenerated.line > 0 && aGenerated.column >= 0
-        && !aOriginal && !aSource && !aName) {
-      // Case 1.
-      return;
     }
-    else if (aGenerated && 'line' in aGenerated && 'column' in aGenerated
-             && aOriginal && 'line' in aOriginal && 'column' in aOriginal
-             && aGenerated.line > 0 && aGenerated.column >= 0
-             && aOriginal.line > 0 && aOriginal.column >= 0
-             && aSource) {
-      // Cases 2 and 3.
-      return;
+    return bestCandidate;
+  }
+  function levenshteinWithMax(s1, s2, max) {
+    let previous = new Array(s2.length + 1);
+    let current = new Array(s2.length + 1);
+    const big = max + 0.01;
+    for (let i = 0; i <= s2.length; i++) {
+      previous[i] = i;
     }
-    else {
-      throw new Error('Invalid mapping: ' + JSON.stringify({
-        generated: aGenerated,
-        source: aSource,
-        original: aOriginal,
-        name: aName
-      }));
+    for (let i = 1; i <= s1.length; i++) {
+      const c1 = s1.charCodeAt(i - 1);
+      const minJ = Math.ceil(i > max ? i - max : 1);
+      const maxJ = Math.floor(s2.length > max + i ? max + i : s2.length);
+      current[0] = i;
+      let colMin = i;
+      for (let j = 1; j < minJ; j++) {
+        current[j] = big;
+      }
+      for (let j = minJ; j <= maxJ; j++) {
+        const substitutionDistance = s1[i - 1].toLowerCase() === s2[j - 1].toLowerCase() ? previous[j - 1] + 0.1 : previous[j - 1] + 2;
+        const dist = c1 === s2.charCodeAt(j - 1) ? previous[j - 1] : Math.min(
+          /*delete*/
+          previous[j] + 1,
+          /*insert*/
+          current[j - 1] + 1,
+          /*substitute*/
+          substitutionDistance
+        );
+        current[j] = dist;
+        colMin = Math.min(colMin, dist);
+      }
+      for (let j = maxJ + 1; j <= s2.length; j++) {
+        current[j] = big;
+      }
+      if (colMin > max) {
+        return void 0;
+      }
+      const temp = previous;
+      previous = current;
+      current = temp;
     }
-  };
-
-/**
- * Serialize the accumulated mappings in to the stream of base 64 VLQs
- * specified by the source map format.
- */
-SourceMapGenerator.prototype._serializeMappings =
-  function SourceMapGenerator_serializeMappings() {
-    var previousGeneratedColumn = 0;
-    var previousGeneratedLine = 1;
-    var previousOriginalColumn = 0;
-    var previousOriginalLine = 0;
-    var previousName = 0;
-    var previousSource = 0;
-    var result = '';
-    var next;
-    var mapping;
-    var nameIdx;
-    var sourceIdx;
-
-    var mappings = this._mappings.toArray();
-    for (var i = 0, len = mappings.length; i < len; i++) {
-      mapping = mappings[i];
-      next = ''
-
-      if (mapping.generatedLine !== previousGeneratedLine) {
-        previousGeneratedColumn = 0;
-        while (mapping.generatedLine !== previousGeneratedLine) {
-          next += ';';
-          previousGeneratedLine++;
+    const res = previous[s2.length];
+    return res > max ? void 0 : res;
+  }
+  function endsWith(str, suffix) {
+    const expectedPos = str.length - suffix.length;
+    return expectedPos >= 0 && str.indexOf(suffix, expectedPos) === expectedPos;
+  }
+  function removeSuffix(str, suffix) {
+    return endsWith(str, suffix) ? str.slice(0, str.length - suffix.length) : str;
+  }
+  function tryRemoveSuffix(str, suffix) {
+    return endsWith(str, suffix) ? str.slice(0, str.length - suffix.length) : void 0;
+  }
+  function removeMinAndVersionNumbers(fileName) {
+    let end = fileName.length;
+    for (let pos = end - 1; pos > 0; pos--) {
+      let ch = fileName.charCodeAt(pos);
+      if (ch >= 48 /* _0 */ && ch <= 57 /* _9 */) {
+        do {
+          --pos;
+          ch = fileName.charCodeAt(pos);
+        } while (pos > 0 && ch >= 48 /* _0 */ && ch <= 57 /* _9 */);
+      } else if (pos > 4 && (ch === 110 /* n */ || ch === 78 /* N */)) {
+        --pos;
+        ch = fileName.charCodeAt(pos);
+        if (ch !== 105 /* i */ && ch !== 73 /* I */) {
+          break;
         }
-      }
-      else {
-        if (i > 0) {
-          if (!util.compareByGeneratedPositionsInflated(mapping, mappings[i - 1])) {
-            continue;
-          }
-          next += ',';
+        --pos;
+        ch = fileName.charCodeAt(pos);
+        if (ch !== 109 /* m */ && ch !== 77 /* M */) {
+          break;
         }
+        --pos;
+        ch = fileName.charCodeAt(pos);
+      } else {
+        break;
       }
-
-      next += base64VLQ.encode(mapping.generatedColumn
-                                 - previousGeneratedColumn);
-      previousGeneratedColumn = mapping.generatedColumn;
-
-      if (mapping.source != null) {
-        sourceIdx = this._sources.indexOf(mapping.source);
-        next += base64VLQ.encode(sourceIdx - previousSource);
-        previousSource = sourceIdx;
-
-        // lines are stored 0-based in SourceMap spec version 3
-        next += base64VLQ.encode(mapping.originalLine - 1
-                                   - previousOriginalLine);
-        previousOriginalLine = mapping.originalLine - 1;
-
-        next += base64VLQ.encode(mapping.originalColumn
-                                   - previousOriginalColumn);
-        previousOriginalColumn = mapping.originalColumn;
-
-        if (mapping.name != null) {
-          nameIdx = this._names.indexOf(mapping.name);
-          next += base64VLQ.encode(nameIdx - previousName);
-          previousName = nameIdx;
-        }
+      if (ch !== 45 /* minus */ && ch !== 46 /* dot */) {
+        break;
       }
-
-      result += next;
+      end = pos;
     }
-
-    return result;
-  };
-
-SourceMapGenerator.prototype._generateSourcesContent =
-  function SourceMapGenerator_generateSourcesContent(aSources, aSourceRoot) {
-    return aSources.map(function (source) {
-      if (!this._sourcesContents) {
-        return null;
+    return end === fileName.length ? fileName : fileName.slice(0, end);
+  }
+  function orderedRemoveItem(array, item) {
+    for (let i = 0; i < array.length; i++) {
+      if (array[i] === item) {
+        orderedRemoveItemAt(array, i);
+        return true;
       }
-      if (aSourceRoot != null) {
-        source = util.relative(aSourceRoot, source);
+    }
+    return false;
+  }
+  function orderedRemoveItemAt(array, index) {
+    for (let i = index; i < array.length - 1; i++) {
+      array[i] = array[i + 1];
+    }
+    array.pop();
+  }
+  function unorderedRemoveItemAt(array, index) {
+    array[index] = array[array.length - 1];
+    array.pop();
+  }
+  function unorderedRemoveItem(array, item) {
+    return unorderedRemoveFirstItemWhere(array, (element) => element === item);
+  }
+  function unorderedRemoveFirstItemWhere(array, predicate) {
+    for (let i = 0; i < array.length; i++) {
+      if (predicate(array[i])) {
+        unorderedRemoveItemAt(array, i);
+        return true;
       }
-      var key = util.toSetString(source);
-      return Object.prototype.hasOwnProperty.call(this._sourcesContents, key)
-        ? this._sourcesContents[key]
-        : null;
-    }, this);
-  };
-
-/**
- * Externalize the source map.
- */
-SourceMapGenerator.prototype.toJSON =
-  function SourceMapGenerator_toJSON() {
-    var map = {
-      version: this._version,
-      sources: this._sources.toArray(),
-      names: this._names.toArray(),
-      mappings: this._serializeMappings()
+    }
+    return false;
+  }
+  function createGetCanonicalFileName(useCaseSensitiveFileNames2) {
+    return useCaseSensitiveFileNames2 ? identity : toFileNameLowerCase;
+  }
+  function patternText({ prefix, suffix }) {
+    return `${prefix}*${suffix}`;
+  }
+  function matchedText(pattern, candidate) {
+    Debug.assert(isPatternMatch(pattern, candidate));
+    return candidate.substring(pattern.prefix.length, candidate.length - pattern.suffix.length);
+  }
+  function findBestPatternMatch(values, getPattern, candidate) {
+    let matchedValue;
+    let longestMatchPrefixLength = -1;
+    for (const v of values) {
+      const pattern = getPattern(v);
+      if (isPatternMatch(pattern, candidate) && pattern.prefix.length > longestMatchPrefixLength) {
+        longestMatchPrefixLength = pattern.prefix.length;
+        matchedValue = v;
+      }
+    }
+    return matchedValue;
+  }
+  function startsWith(str, prefix) {
+    return str.lastIndexOf(prefix, 0) === 0;
+  }
+  function removePrefix(str, prefix) {
+    return startsWith(str, prefix) ? str.substr(prefix.length) : str;
+  }
+  function tryRemovePrefix(str, prefix, getCanonicalFileName = identity) {
+    return startsWith(getCanonicalFileName(str), getCanonicalFileName(prefix)) ? str.substring(prefix.length) : void 0;
+  }
+  function isPatternMatch({ prefix, suffix }, candidate) {
+    return candidate.length >= prefix.length + suffix.length && startsWith(candidate, prefix) && endsWith(candidate, suffix);
+  }
+  function and(f, g) {
+    return (arg) => f(arg) && g(arg);
+  }
+  function or(...fs) {
+    return (...args) => {
+      let lastResult;
+      for (const f of fs) {
+        lastResult = f(...args);
+        if (lastResult) {
+          return lastResult;
+        }
+      }
+      return lastResult;
     };
-    if (this._file != null) {
-      map.file = this._file;
+  }
+  function not(fn) {
+    return (...args) => !fn(...args);
+  }
+  function assertType(_) {
+  }
+  function singleElementArray(t) {
+    return t === void 0 ? void 0 : [t];
+  }
+  function enumerateInsertsAndDeletes(newItems, oldItems, comparer, inserted, deleted, unchanged) {
+    unchanged = unchanged || noop;
+    let newIndex = 0;
+    let oldIndex = 0;
+    const newLen = newItems.length;
+    const oldLen = oldItems.length;
+    let hasChanges = false;
+    while (newIndex < newLen && oldIndex < oldLen) {
+      const newItem = newItems[newIndex];
+      const oldItem = oldItems[oldIndex];
+      const compareResult = comparer(newItem, oldItem);
+      if (compareResult === -1 /* LessThan */) {
+        inserted(newItem);
+        newIndex++;
+        hasChanges = true;
+      } else if (compareResult === 1 /* GreaterThan */) {
+        deleted(oldItem);
+        oldIndex++;
+        hasChanges = true;
+      } else {
+        unchanged(oldItem, newItem);
+        newIndex++;
+        oldIndex++;
+      }
     }
-    if (this._sourceRoot != null) {
-      map.sourceRoot = this._sourceRoot;
+    while (newIndex < newLen) {
+      inserted(newItems[newIndex++]);
+      hasChanges = true;
     }
-    if (this._sourcesContents) {
-      map.sourcesContent = this._generateSourcesContent(map.sources, map.sourceRoot);
-    }
-
-    return map;
-  };
-
-/**
- * Render the source map being generated to a string.
- */
-SourceMapGenerator.prototype.toString =
-  function SourceMapGenerator_toString() {
-    return JSON.stringify(this.toJSON());
-  };
-
-exports.h = SourceMapGenerator;
-
-
-/***/ }),
-
-/***/ 3129:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
-
-var __webpack_unused_export__;
-/* -*- Mode: js; js-indent-level: 2; -*- */
-/*
- * Copyright 2011 Mozilla Foundation and contributors
- * Licensed under the New BSD license. See LICENSE or:
- * http://opensource.org/licenses/BSD-3-Clause
- */
-
-var SourceMapGenerator = (__nccwpck_require__(66677)/* .SourceMapGenerator */ .h);
-var util = __nccwpck_require__(16511);
-
-// Matches a Windows-style `\r\n` newline or a `\n` newline used by all other
-// operating systems these days (capturing the result).
-var REGEX_NEWLINE = /(\r?\n)/;
-
-// Newline character code for charCodeAt() comparisons
-var NEWLINE_CODE = 10;
-
-// Private symbol for identifying `SourceNode`s when multiple versions of
-// the source-map library are loaded. This MUST NOT CHANGE across
-// versions!
-var isSourceNode = "$$$isSourceNode$$$";
-
-/**
- * SourceNodes provide a way to abstract over interpolating/concatenating
- * snippets of generated JavaScript source code while maintaining the line and
- * column information associated with the original source code.
- *
- * @param aLine The original line number.
- * @param aColumn The original column number.
- * @param aSource The original source's filename.
- * @param aChunks Optional. An array of strings which are snippets of
- *        generated JS, or other SourceNodes.
- * @param aName The original identifier.
- */
-function SourceNode(aLine, aColumn, aSource, aChunks, aName) {
-  this.children = [];
-  this.sourceContents = {};
-  this.line = aLine == null ? null : aLine;
-  this.column = aColumn == null ? null : aColumn;
-  this.source = aSource == null ? null : aSource;
-  this.name = aName == null ? null : aName;
-  this[isSourceNode] = true;
-  if (aChunks != null) this.add(aChunks);
-}
-
-/**
- * Creates a SourceNode from generated code and a SourceMapConsumer.
- *
- * @param aGeneratedCode The generated code
- * @param aSourceMapConsumer The SourceMap for the generated code
- * @param aRelativePath Optional. The path that relative sources in the
- *        SourceMapConsumer should be relative to.
- */
-SourceNode.fromStringWithSourceMap =
-  function SourceNode_fromStringWithSourceMap(aGeneratedCode, aSourceMapConsumer, aRelativePath) {
-    // The SourceNode we want to fill with the generated code
-    // and the SourceMap
-    var node = new SourceNode();
-
-    // All even indices of this array are one line of the generated code,
-    // while all odd indices are the newlines between two adjacent lines
-    // (since `REGEX_NEWLINE` captures its match).
-    // Processed fragments are accessed by calling `shiftNextLine`.
-    var remainingLines = aGeneratedCode.split(REGEX_NEWLINE);
-    var remainingLinesIndex = 0;
-    var shiftNextLine = function() {
-      var lineContents = getNextLine();
-      // The last line of a file might not have a newline.
-      var newLine = getNextLine() || "";
-      return lineContents + newLine;
-
-      function getNextLine() {
-        return remainingLinesIndex < remainingLines.length ?
-            remainingLines[remainingLinesIndex++] : undefined;
-      }
-    };
-
-    // We need to remember the position of "remainingLines"
-    var lastGeneratedLine = 1, lastGeneratedColumn = 0;
-
-    // The generate SourceNodes we need a code range.
-    // To extract it current and last mapping is used.
-    // Here we store the last mapping.
-    var lastMapping = null;
-
-    aSourceMapConsumer.eachMapping(function (mapping) {
-      if (lastMapping !== null) {
-        // We add the code from "lastMapping" to "mapping":
-        // First check if there is a new line in between.
-        if (lastGeneratedLine < mapping.generatedLine) {
-          // Associate first line with "lastMapping"
-          addMappingWithCode(lastMapping, shiftNextLine());
-          lastGeneratedLine++;
-          lastGeneratedColumn = 0;
-          // The remaining code is added without mapping
-        } else {
-          // There is no new line in between.
-          // Associate the code between "lastGeneratedColumn" and
-          // "mapping.generatedColumn" with "lastMapping"
-          var nextLine = remainingLines[remainingLinesIndex] || '';
-          var code = nextLine.substr(0, mapping.generatedColumn -
-                                        lastGeneratedColumn);
-          remainingLines[remainingLinesIndex] = nextLine.substr(mapping.generatedColumn -
-                                              lastGeneratedColumn);
-          lastGeneratedColumn = mapping.generatedColumn;
-          addMappingWithCode(lastMapping, code);
-          // No more remaining code, continue
-          lastMapping = mapping;
-          return;
-        }
-      }
-      // We add the generated code until the first mapping
-      // to the SourceNode without any mapping.
-      // Each line is added as separate string.
-      while (lastGeneratedLine < mapping.generatedLine) {
-        node.add(shiftNextLine());
-        lastGeneratedLine++;
-      }
-      if (lastGeneratedColumn < mapping.generatedColumn) {
-        var nextLine = remainingLines[remainingLinesIndex] || '';
-        node.add(nextLine.substr(0, mapping.generatedColumn));
-        remainingLines[remainingLinesIndex] = nextLine.substr(mapping.generatedColumn);
-        lastGeneratedColumn = mapping.generatedColumn;
-      }
-      lastMapping = mapping;
-    }, this);
-    // We have processed all mappings.
-    if (remainingLinesIndex < remainingLines.length) {
-      if (lastMapping) {
-        // Associate the remaining code in the current line with "lastMapping"
-        addMappingWithCode(lastMapping, shiftNextLine());
-      }
-      // and add the remaining lines without any mapping
-      node.add(remainingLines.splice(remainingLinesIndex).join(""));
-    }
-
-    // Copy sourcesContent into SourceNode
-    aSourceMapConsumer.sources.forEach(function (sourceFile) {
-      var content = aSourceMapConsumer.sourceContentFor(sourceFile);
-      if (content != null) {
-        if (aRelativePath != null) {
-          sourceFile = util.join(aRelativePath, sourceFile);
-        }
-        node.setSourceContent(sourceFile, content);
-      }
-    });
-
-    return node;
-
-    function addMappingWithCode(mapping, code) {
-      if (mapping === null || mapping.source === undefined) {
-        node.add(code);
-      } else {
-        var source = aRelativePath
-          ? util.join(aRelativePath, mapping.source)
-          : mapping.source;
-        node.add(new SourceNode(mapping.originalLine,
-                                mapping.originalColumn,
-                                source,
-                                code,
-                                mapping.name));
-      }
-    }
-  };
-
-/**
- * Add a chunk of generated JS to this source node.
- *
- * @param aChunk A string snippet of generated JS code, another instance of
- *        SourceNode, or an array where each member is one of those things.
- */
-SourceNode.prototype.add = function SourceNode_add(aChunk) {
-  if (Array.isArray(aChunk)) {
-    aChunk.forEach(function (chunk) {
-      this.add(chunk);
-    }, this);
-  }
-  else if (aChunk[isSourceNode] || typeof aChunk === "string") {
-    if (aChunk) {
-      this.children.push(aChunk);
+    while (oldIndex < oldLen) {
+      deleted(oldItems[oldIndex++]);
+      hasChanges = true;
     }
+    return hasChanges;
   }
-  else {
-    throw new TypeError(
-      "Expected a SourceNode, string, or an array of SourceNodes and strings. Got " + aChunk
+  function cartesianProduct(arrays) {
+    const result = [];
+    cartesianProductWorker(
+      arrays,
+      result,
+      /*outer*/
+      void 0,
+      0
     );
+    return result;
   }
-  return this;
-};
-
-/**
- * Add a chunk of generated JS to the beginning of this source node.
- *
- * @param aChunk A string snippet of generated JS code, another instance of
- *        SourceNode, or an array where each member is one of those things.
- */
-SourceNode.prototype.prepend = function SourceNode_prepend(aChunk) {
-  if (Array.isArray(aChunk)) {
-    for (var i = aChunk.length-1; i >= 0; i--) {
-      this.prepend(aChunk[i]);
+  function cartesianProductWorker(arrays, result, outer, index) {
+    for (const element of arrays[index]) {
+      let inner;
+      if (outer) {
+        inner = outer.slice();
+        inner.push(element);
+      } else {
+        inner = [element];
+      }
+      if (index === arrays.length - 1) {
+        result.push(inner);
+      } else {
+        cartesianProductWorker(arrays, result, inner, index + 1);
+      }
     }
   }
-  else if (aChunk[isSourceNode] || typeof aChunk === "string") {
-    this.children.unshift(aChunk);
-  }
-  else {
-    throw new TypeError(
-      "Expected a SourceNode, string, or an array of SourceNodes and strings. Got " + aChunk
-    );
-  }
-  return this;
-};
-
-/**
- * Walk over the tree of JS snippets in this node and its children. The
- * walking function is called once for each snippet of JS and is passed that
- * snippet and the its original associated source's line/column location.
- *
- * @param aFn The traversal function.
- */
-SourceNode.prototype.walk = function SourceNode_walk(aFn) {
-  var chunk;
-  for (var i = 0, len = this.children.length; i < len; i++) {
-    chunk = this.children[i];
-    if (chunk[isSourceNode]) {
-      chunk.walk(aFn);
-    }
-    else {
-      if (chunk !== '') {
-        aFn(chunk, { source: this.source,
-                     line: this.line,
-                     column: this.column,
-                     name: this.name });
+  function takeWhile(array, predicate) {
+    if (array) {
+      const len = array.length;
+      let index = 0;
+      while (index < len && predicate(array[index])) {
+        index++;
       }
+      return array.slice(0, index);
     }
   }
-};
-
-/**
- * Like `String.prototype.join` except for SourceNodes. Inserts `aStr` between
- * each of `this.children`.
- *
- * @param aSep The separator.
- */
-SourceNode.prototype.join = function SourceNode_join(aSep) {
-  var newChildren;
-  var i;
-  var len = this.children.length;
-  if (len > 0) {
-    newChildren = [];
-    for (i = 0; i < len-1; i++) {
-      newChildren.push(this.children[i]);
-      newChildren.push(aSep);
+  function skipWhile(array, predicate) {
+    if (array) {
+      const len = array.length;
+      let index = 0;
+      while (index < len && predicate(array[index])) {
+        index++;
+      }
+      return array.slice(index);
     }
-    newChildren.push(this.children[i]);
-    this.children = newChildren;
-  }
-  return this;
-};
-
-/**
- * Call String.prototype.replace on the very right-most source snippet. Useful
- * for trimming whitespace from the end of a source node, etc.
- *
- * @param aPattern The pattern to replace.
- * @param aReplacement The thing to replace the pattern with.
- */
-SourceNode.prototype.replaceRight = function SourceNode_replaceRight(aPattern, aReplacement) {
-  var lastChild = this.children[this.children.length - 1];
-  if (lastChild[isSourceNode]) {
-    lastChild.replaceRight(aPattern, aReplacement);
-  }
-  else if (typeof lastChild === 'string') {
-    this.children[this.children.length - 1] = lastChild.replace(aPattern, aReplacement);
   }
-  else {
-    this.children.push(''.replace(aPattern, aReplacement));
+  function isNodeLikeSystem() {
+    return typeof process !== "undefined" && !!process.nextTick && !process.browser && "object" === "object";
   }
-  return this;
-};
-
-/**
- * Set the source content for a source file. This will be added to the SourceMapGenerator
- * in the sourcesContent field.
- *
- * @param aSourceFile The filename of the source file
- * @param aSourceContent The content of the source file
- */
-SourceNode.prototype.setSourceContent =
-  function SourceNode_setSourceContent(aSourceFile, aSourceContent) {
-    this.sourceContents[util.toSetString(aSourceFile)] = aSourceContent;
-  };
-
-/**
- * Walk over the tree of SourceNodes. The walking function is called for each
- * source file content and is passed the filename and source content.
- *
- * @param aFn The traversal function.
- */
-SourceNode.prototype.walkSourceContents =
-  function SourceNode_walkSourceContents(aFn) {
-    for (var i = 0, len = this.children.length; i < len; i++) {
-      if (this.children[i][isSourceNode]) {
-        this.children[i].walkSourceContents(aFn);
-      }
-    }
-
-    var sources = Object.keys(this.sourceContents);
-    for (var i = 0, len = sources.length; i < len; i++) {
-      aFn(util.fromSetString(sources[i]), this.sourceContents[sources[i]]);
+  var emptyArray, emptyMap, emptySet, SortKind, elementAt, hasOwnProperty, fileNameLowerCaseRegExp, AssertionLevel, createUIStringComparer, uiComparerCaseSensitive, uiLocale;
+  var init_core = __esm({
+    "src/compiler/core.ts"() {
+      "use strict";
+      init_ts2();
+      emptyArray = [];
+      emptyMap = /* @__PURE__ */ new Map();
+      emptySet = /* @__PURE__ */ new Set();
+      SortKind = /* @__PURE__ */ ((SortKind2) => {
+        SortKind2[SortKind2["None"] = 0] = "None";
+        SortKind2[SortKind2["CaseSensitive"] = 1] = "CaseSensitive";
+        SortKind2[SortKind2["CaseInsensitive"] = 2] = "CaseInsensitive";
+        SortKind2[SortKind2["Both"] = 3] = "Both";
+        return SortKind2;
+      })(SortKind || {});
+      elementAt = !!Array.prototype.at ? (array, offset) => array == null ? void 0 : array.at(offset) : (array, offset) => {
+        if (array) {
+          offset = toOffset(array, offset);
+          if (offset < array.length) {
+            return array[offset];
+          }
+        }
+        return void 0;
+      };
+      hasOwnProperty = Object.prototype.hasOwnProperty;
+      fileNameLowerCaseRegExp = /[^\u0130\u0131\u00DFa-z0-9\\/:\-_. ]+/g;
+      AssertionLevel = /* @__PURE__ */ ((AssertionLevel2) => {
+        AssertionLevel2[AssertionLevel2["None"] = 0] = "None";
+        AssertionLevel2[AssertionLevel2["Normal"] = 1] = "Normal";
+        AssertionLevel2[AssertionLevel2["Aggressive"] = 2] = "Aggressive";
+        AssertionLevel2[AssertionLevel2["VeryAggressive"] = 3] = "VeryAggressive";
+        return AssertionLevel2;
+      })(AssertionLevel || {});
+      createUIStringComparer = (() => {
+        return createIntlCollatorStringComparer;
+        function compareWithCallback(a, b, comparer) {
+          if (a === b)
+            return 0 /* EqualTo */;
+          if (a === void 0)
+            return -1 /* LessThan */;
+          if (b === void 0)
+            return 1 /* GreaterThan */;
+          const value = comparer(a, b);
+          return value < 0 ? -1 /* LessThan */ : value > 0 ? 1 /* GreaterThan */ : 0 /* EqualTo */;
+        }
+        function createIntlCollatorStringComparer(locale) {
+          const comparer = new Intl.Collator(locale, { usage: "sort", sensitivity: "variant" }).compare;
+          return (a, b) => compareWithCallback(a, b, comparer);
+        }
+      })();
     }
-  };
-
-/**
- * Return the string representation of this source node. Walks over the tree
- * and concatenates all the various snippets together to one string.
- */
-SourceNode.prototype.toString = function SourceNode_toString() {
-  var str = "";
-  this.walk(function (chunk) {
-    str += chunk;
   });
-  return str;
-};
 
-/**
- * Returns the string representation of this source node along with a source
- * map.
- */
-SourceNode.prototype.toStringWithSourceMap = function SourceNode_toStringWithSourceMap(aArgs) {
-  var generated = {
-    code: "",
-    line: 1,
-    column: 0
-  };
-  var map = new SourceMapGenerator(aArgs);
-  var sourceMappingActive = false;
-  var lastOriginalSource = null;
-  var lastOriginalLine = null;
-  var lastOriginalColumn = null;
-  var lastOriginalName = null;
-  this.walk(function (chunk, original) {
-    generated.code += chunk;
-    if (original.source !== null
-        && original.line !== null
-        && original.column !== null) {
-      if(lastOriginalSource !== original.source
-         || lastOriginalLine !== original.line
-         || lastOriginalColumn !== original.column
-         || lastOriginalName !== original.name) {
-        map.addMapping({
-          source: original.source,
-          original: {
-            line: original.line,
-            column: original.column
-          },
-          generated: {
-            line: generated.line,
-            column: generated.column
-          },
-          name: original.name
-        });
-      }
-      lastOriginalSource = original.source;
-      lastOriginalLine = original.line;
-      lastOriginalColumn = original.column;
-      lastOriginalName = original.name;
-      sourceMappingActive = true;
-    } else if (sourceMappingActive) {
-      map.addMapping({
-        generated: {
-          line: generated.line,
-          column: generated.column
+  // src/compiler/debug.ts
+  var LogLevel, Debug;
+  var init_debug = __esm({
+    "src/compiler/debug.ts"() {
+      "use strict";
+      init_ts2();
+      init_ts2();
+      LogLevel = /* @__PURE__ */ ((LogLevel3) => {
+        LogLevel3[LogLevel3["Off"] = 0] = "Off";
+        LogLevel3[LogLevel3["Error"] = 1] = "Error";
+        LogLevel3[LogLevel3["Warning"] = 2] = "Warning";
+        LogLevel3[LogLevel3["Info"] = 3] = "Info";
+        LogLevel3[LogLevel3["Verbose"] = 4] = "Verbose";
+        return LogLevel3;
+      })(LogLevel || {});
+      ((Debug2) => {
+        let currentAssertionLevel = 0 /* None */;
+        Debug2.currentLogLevel = 2 /* Warning */;
+        Debug2.isDebugging = false;
+        function shouldLog(level) {
+          return Debug2.currentLogLevel <= level;
         }
-      });
-      lastOriginalSource = null;
-      sourceMappingActive = false;
-    }
-    for (var idx = 0, length = chunk.length; idx < length; idx++) {
-      if (chunk.charCodeAt(idx) === NEWLINE_CODE) {
-        generated.line++;
-        generated.column = 0;
-        // Mappings end at eol
-        if (idx + 1 === length) {
-          lastOriginalSource = null;
-          sourceMappingActive = false;
-        } else if (sourceMappingActive) {
-          map.addMapping({
-            source: original.source,
-            original: {
-              line: original.line,
-              column: original.column
+        Debug2.shouldLog = shouldLog;
+        function logMessage(level, s) {
+          if (Debug2.loggingHost && shouldLog(level)) {
+            Debug2.loggingHost.log(level, s);
+          }
+        }
+        function log(s) {
+          logMessage(3 /* Info */, s);
+        }
+        Debug2.log = log;
+        ((_log) => {
+          function error2(s) {
+            logMessage(1 /* Error */, s);
+          }
+          _log.error = error2;
+          function warn(s) {
+            logMessage(2 /* Warning */, s);
+          }
+          _log.warn = warn;
+          function log2(s) {
+            logMessage(3 /* Info */, s);
+          }
+          _log.log = log2;
+          function trace2(s) {
+            logMessage(4 /* Verbose */, s);
+          }
+          _log.trace = trace2;
+        })(log = Debug2.log || (Debug2.log = {}));
+        const assertionCache = {};
+        function getAssertionLevel() {
+          return currentAssertionLevel;
+        }
+        Debug2.getAssertionLevel = getAssertionLevel;
+        function setAssertionLevel(level) {
+          const prevAssertionLevel = currentAssertionLevel;
+          currentAssertionLevel = level;
+          if (level > prevAssertionLevel) {
+            for (const key of getOwnKeys(assertionCache)) {
+              const cachedFunc = assertionCache[key];
+              if (cachedFunc !== void 0 && Debug2[key] !== cachedFunc.assertion && level >= cachedFunc.level) {
+                Debug2[key] = cachedFunc;
+                assertionCache[key] = void 0;
+              }
+            }
+          }
+        }
+        Debug2.setAssertionLevel = setAssertionLevel;
+        function shouldAssert(level) {
+          return currentAssertionLevel >= level;
+        }
+        Debug2.shouldAssert = shouldAssert;
+        function shouldAssertFunction(level, name) {
+          if (!shouldAssert(level)) {
+            assertionCache[name] = { level, assertion: Debug2[name] };
+            Debug2[name] = noop;
+            return false;
+          }
+          return true;
+        }
+        function fail(message, stackCrawlMark) {
+          debugger;
+          const e = new Error(message ? `Debug Failure. ${message}` : "Debug Failure.");
+          if (Error.captureStackTrace) {
+            Error.captureStackTrace(e, stackCrawlMark || fail);
+          }
+          throw e;
+        }
+        Debug2.fail = fail;
+        function failBadSyntaxKind(node, message, stackCrawlMark) {
+          return fail(
+            `${message || "Unexpected node."}\r
+Node ${formatSyntaxKind(node.kind)} was unexpected.`,
+            stackCrawlMark || failBadSyntaxKind
+          );
+        }
+        Debug2.failBadSyntaxKind = failBadSyntaxKind;
+        function assert(expression, message, verboseDebugInfo, stackCrawlMark) {
+          if (!expression) {
+            message = message ? `False expression: ${message}` : "False expression.";
+            if (verboseDebugInfo) {
+              message += "\r\nVerbose Debug Information: " + (typeof verboseDebugInfo === "string" ? verboseDebugInfo : verboseDebugInfo());
+            }
+            fail(message, stackCrawlMark || assert);
+          }
+        }
+        Debug2.assert = assert;
+        function assertEqual(a, b, msg, msg2, stackCrawlMark) {
+          if (a !== b) {
+            const message = msg ? msg2 ? `${msg} ${msg2}` : msg : "";
+            fail(`Expected ${a} === ${b}. ${message}`, stackCrawlMark || assertEqual);
+          }
+        }
+        Debug2.assertEqual = assertEqual;
+        function assertLessThan(a, b, msg, stackCrawlMark) {
+          if (a >= b) {
+            fail(`Expected ${a} < ${b}. ${msg || ""}`, stackCrawlMark || assertLessThan);
+          }
+        }
+        Debug2.assertLessThan = assertLessThan;
+        function assertLessThanOrEqual(a, b, stackCrawlMark) {
+          if (a > b) {
+            fail(`Expected ${a} <= ${b}`, stackCrawlMark || assertLessThanOrEqual);
+          }
+        }
+        Debug2.assertLessThanOrEqual = assertLessThanOrEqual;
+        function assertGreaterThanOrEqual(a, b, stackCrawlMark) {
+          if (a < b) {
+            fail(`Expected ${a} >= ${b}`, stackCrawlMark || assertGreaterThanOrEqual);
+          }
+        }
+        Debug2.assertGreaterThanOrEqual = assertGreaterThanOrEqual;
+        function assertIsDefined(value, message, stackCrawlMark) {
+          if (value === void 0 || value === null) {
+            fail(message, stackCrawlMark || assertIsDefined);
+          }
+        }
+        Debug2.assertIsDefined = assertIsDefined;
+        function checkDefined(value, message, stackCrawlMark) {
+          assertIsDefined(value, message, stackCrawlMark || checkDefined);
+          return value;
+        }
+        Debug2.checkDefined = checkDefined;
+        function assertEachIsDefined(value, message, stackCrawlMark) {
+          for (const v of value) {
+            assertIsDefined(v, message, stackCrawlMark || assertEachIsDefined);
+          }
+        }
+        Debug2.assertEachIsDefined = assertEachIsDefined;
+        function checkEachDefined(value, message, stackCrawlMark) {
+          assertEachIsDefined(value, message, stackCrawlMark || checkEachDefined);
+          return value;
+        }
+        Debug2.checkEachDefined = checkEachDefined;
+        function assertNever(member, message = "Illegal value:", stackCrawlMark) {
+          const detail = typeof member === "object" && hasProperty(member, "kind") && hasProperty(member, "pos") ? "SyntaxKind: " + formatSyntaxKind(member.kind) : JSON.stringify(member);
+          return fail(`${message} ${detail}`, stackCrawlMark || assertNever);
+        }
+        Debug2.assertNever = assertNever;
+        function assertEachNode(nodes, test, message, stackCrawlMark) {
+          if (shouldAssertFunction(1 /* Normal */, "assertEachNode")) {
+            assert(
+              test === void 0 || every(nodes, test),
+              message || "Unexpected node.",
+              () => `Node array did not pass test '${getFunctionName(test)}'.`,
+              stackCrawlMark || assertEachNode
+            );
+          }
+        }
+        Debug2.assertEachNode = assertEachNode;
+        function assertNode(node, test, message, stackCrawlMark) {
+          if (shouldAssertFunction(1 /* Normal */, "assertNode")) {
+            assert(
+              node !== void 0 && (test === void 0 || test(node)),
+              message || "Unexpected node.",
+              () => `Node ${formatSyntaxKind(node == null ? void 0 : node.kind)} did not pass test '${getFunctionName(test)}'.`,
+              stackCrawlMark || assertNode
+            );
+          }
+        }
+        Debug2.assertNode = assertNode;
+        function assertNotNode(node, test, message, stackCrawlMark) {
+          if (shouldAssertFunction(1 /* Normal */, "assertNotNode")) {
+            assert(
+              node === void 0 || test === void 0 || !test(node),
+              message || "Unexpected node.",
+              () => `Node ${formatSyntaxKind(node.kind)} should not have passed test '${getFunctionName(test)}'.`,
+              stackCrawlMark || assertNotNode
+            );
+          }
+        }
+        Debug2.assertNotNode = assertNotNode;
+        function assertOptionalNode(node, test, message, stackCrawlMark) {
+          if (shouldAssertFunction(1 /* Normal */, "assertOptionalNode")) {
+            assert(
+              test === void 0 || node === void 0 || test(node),
+              message || "Unexpected node.",
+              () => `Node ${formatSyntaxKind(node == null ? void 0 : node.kind)} did not pass test '${getFunctionName(test)}'.`,
+              stackCrawlMark || assertOptionalNode
+            );
+          }
+        }
+        Debug2.assertOptionalNode = assertOptionalNode;
+        function assertOptionalToken(node, kind, message, stackCrawlMark) {
+          if (shouldAssertFunction(1 /* Normal */, "assertOptionalToken")) {
+            assert(
+              kind === void 0 || node === void 0 || node.kind === kind,
+              message || "Unexpected node.",
+              () => `Node ${formatSyntaxKind(node == null ? void 0 : node.kind)} was not a '${formatSyntaxKind(kind)}' token.`,
+              stackCrawlMark || assertOptionalToken
+            );
+          }
+        }
+        Debug2.assertOptionalToken = assertOptionalToken;
+        function assertMissingNode(node, message, stackCrawlMark) {
+          if (shouldAssertFunction(1 /* Normal */, "assertMissingNode")) {
+            assert(
+              node === void 0,
+              message || "Unexpected node.",
+              () => `Node ${formatSyntaxKind(node.kind)} was unexpected'.`,
+              stackCrawlMark || assertMissingNode
+            );
+          }
+        }
+        Debug2.assertMissingNode = assertMissingNode;
+        function type(_value) {
+        }
+        Debug2.type = type;
+        function getFunctionName(func) {
+          if (typeof func !== "function") {
+            return "";
+          } else if (hasProperty(func, "name")) {
+            return func.name;
+          } else {
+            const text = Function.prototype.toString.call(func);
+            const match = /^function\s+([\w$]+)\s*\(/.exec(text);
+            return match ? match[1] : "";
+          }
+        }
+        Debug2.getFunctionName = getFunctionName;
+        function formatSymbol(symbol) {
+          return `{ name: ${unescapeLeadingUnderscores(symbol.escapedName)}; flags: ${formatSymbolFlags(symbol.flags)}; declarations: ${map(symbol.declarations, (node) => formatSyntaxKind(node.kind))} }`;
+        }
+        Debug2.formatSymbol = formatSymbol;
+        function formatEnum(value = 0, enumObject, isFlags) {
+          const members = getEnumMembers(enumObject);
+          if (value === 0) {
+            return members.length > 0 && members[0][0] === 0 ? members[0][1] : "0";
+          }
+          if (isFlags) {
+            const result = [];
+            let remainingFlags = value;
+            for (const [enumValue, enumName] of members) {
+              if (enumValue > value) {
+                break;
+              }
+              if (enumValue !== 0 && enumValue & value) {
+                result.push(enumName);
+                remainingFlags &= ~enumValue;
+              }
+            }
+            if (remainingFlags === 0) {
+              return result.join("|");
+            }
+          } else {
+            for (const [enumValue, enumName] of members) {
+              if (enumValue === value) {
+                return enumName;
+              }
+            }
+          }
+          return value.toString();
+        }
+        Debug2.formatEnum = formatEnum;
+        const enumMemberCache = /* @__PURE__ */ new Map();
+        function getEnumMembers(enumObject) {
+          const existing = enumMemberCache.get(enumObject);
+          if (existing) {
+            return existing;
+          }
+          const result = [];
+          for (const name in enumObject) {
+            const value = enumObject[name];
+            if (typeof value === "number") {
+              result.push([value, name]);
+            }
+          }
+          const sorted = stableSort(result, (x, y) => compareValues(x[0], y[0]));
+          enumMemberCache.set(enumObject, sorted);
+          return sorted;
+        }
+        function formatSyntaxKind(kind) {
+          return formatEnum(
+            kind,
+            SyntaxKind,
+            /*isFlags*/
+            false
+          );
+        }
+        Debug2.formatSyntaxKind = formatSyntaxKind;
+        function formatSnippetKind(kind) {
+          return formatEnum(
+            kind,
+            SnippetKind,
+            /*isFlags*/
+            false
+          );
+        }
+        Debug2.formatSnippetKind = formatSnippetKind;
+        function formatScriptKind(kind) {
+          return formatEnum(
+            kind,
+            ScriptKind,
+            /*isFlags*/
+            false
+          );
+        }
+        Debug2.formatScriptKind = formatScriptKind;
+        function formatNodeFlags(flags) {
+          return formatEnum(
+            flags,
+            NodeFlags,
+            /*isFlags*/
+            true
+          );
+        }
+        Debug2.formatNodeFlags = formatNodeFlags;
+        function formatModifierFlags(flags) {
+          return formatEnum(
+            flags,
+            ModifierFlags,
+            /*isFlags*/
+            true
+          );
+        }
+        Debug2.formatModifierFlags = formatModifierFlags;
+        function formatTransformFlags(flags) {
+          return formatEnum(
+            flags,
+            TransformFlags,
+            /*isFlags*/
+            true
+          );
+        }
+        Debug2.formatTransformFlags = formatTransformFlags;
+        function formatEmitFlags(flags) {
+          return formatEnum(
+            flags,
+            EmitFlags,
+            /*isFlags*/
+            true
+          );
+        }
+        Debug2.formatEmitFlags = formatEmitFlags;
+        function formatSymbolFlags(flags) {
+          return formatEnum(
+            flags,
+            SymbolFlags,
+            /*isFlags*/
+            true
+          );
+        }
+        Debug2.formatSymbolFlags = formatSymbolFlags;
+        function formatTypeFlags(flags) {
+          return formatEnum(
+            flags,
+            TypeFlags,
+            /*isFlags*/
+            true
+          );
+        }
+        Debug2.formatTypeFlags = formatTypeFlags;
+        function formatSignatureFlags(flags) {
+          return formatEnum(
+            flags,
+            SignatureFlags,
+            /*isFlags*/
+            true
+          );
+        }
+        Debug2.formatSignatureFlags = formatSignatureFlags;
+        function formatObjectFlags(flags) {
+          return formatEnum(
+            flags,
+            ObjectFlags,
+            /*isFlags*/
+            true
+          );
+        }
+        Debug2.formatObjectFlags = formatObjectFlags;
+        function formatFlowFlags(flags) {
+          return formatEnum(
+            flags,
+            FlowFlags,
+            /*isFlags*/
+            true
+          );
+        }
+        Debug2.formatFlowFlags = formatFlowFlags;
+        function formatRelationComparisonResult(result) {
+          return formatEnum(
+            result,
+            RelationComparisonResult,
+            /*isFlags*/
+            true
+          );
+        }
+        Debug2.formatRelationComparisonResult = formatRelationComparisonResult;
+        function formatCheckMode(mode) {
+          return formatEnum(
+            mode,
+            CheckMode,
+            /*isFlags*/
+            true
+          );
+        }
+        Debug2.formatCheckMode = formatCheckMode;
+        function formatSignatureCheckMode(mode) {
+          return formatEnum(
+            mode,
+            SignatureCheckMode,
+            /*isFlags*/
+            true
+          );
+        }
+        Debug2.formatSignatureCheckMode = formatSignatureCheckMode;
+        function formatTypeFacts(facts) {
+          return formatEnum(
+            facts,
+            TypeFacts,
+            /*isFlags*/
+            true
+          );
+        }
+        Debug2.formatTypeFacts = formatTypeFacts;
+        let isDebugInfoEnabled = false;
+        let flowNodeProto;
+        function attachFlowNodeDebugInfoWorker(flowNode) {
+          if (!("__debugFlowFlags" in flowNode)) {
+            Object.defineProperties(flowNode, {
+              // for use with vscode-js-debug's new customDescriptionGenerator in launch.json
+              __tsDebuggerDisplay: {
+                value() {
+                  const flowHeader = this.flags & 2 /* Start */ ? "FlowStart" : this.flags & 4 /* BranchLabel */ ? "FlowBranchLabel" : this.flags & 8 /* LoopLabel */ ? "FlowLoopLabel" : this.flags & 16 /* Assignment */ ? "FlowAssignment" : this.flags & 32 /* TrueCondition */ ? "FlowTrueCondition" : this.flags & 64 /* FalseCondition */ ? "FlowFalseCondition" : this.flags & 128 /* SwitchClause */ ? "FlowSwitchClause" : this.flags & 256 /* ArrayMutation */ ? "FlowArrayMutation" : this.flags & 512 /* Call */ ? "FlowCall" : this.flags & 1024 /* ReduceLabel */ ? "FlowReduceLabel" : this.flags & 1 /* Unreachable */ ? "FlowUnreachable" : "UnknownFlow";
+                  const remainingFlags = this.flags & ~(2048 /* Referenced */ - 1);
+                  return `${flowHeader}${remainingFlags ? ` (${formatFlowFlags(remainingFlags)})` : ""}`;
+                }
+              },
+              __debugFlowFlags: {
+                get() {
+                  return formatEnum(
+                    this.flags,
+                    FlowFlags,
+                    /*isFlags*/
+                    true
+                  );
+                }
+              },
+              __debugToString: {
+                value() {
+                  return formatControlFlowGraph(this);
+                }
+              }
+            });
+          }
+        }
+        function attachFlowNodeDebugInfo(flowNode) {
+          if (isDebugInfoEnabled) {
+            if (typeof Object.setPrototypeOf === "function") {
+              if (!flowNodeProto) {
+                flowNodeProto = Object.create(Object.prototype);
+                attachFlowNodeDebugInfoWorker(flowNodeProto);
+              }
+              Object.setPrototypeOf(flowNode, flowNodeProto);
+            } else {
+              attachFlowNodeDebugInfoWorker(flowNode);
+            }
+          }
+        }
+        Debug2.attachFlowNodeDebugInfo = attachFlowNodeDebugInfo;
+        let nodeArrayProto;
+        function attachNodeArrayDebugInfoWorker(array) {
+          if (!("__tsDebuggerDisplay" in array)) {
+            Object.defineProperties(array, {
+              __tsDebuggerDisplay: {
+                value(defaultValue) {
+                  defaultValue = String(defaultValue).replace(/(?:,[\s\w\d_]+:[^,]+)+\]$/, "]");
+                  return `NodeArray ${defaultValue}`;
+                }
+              }
+            });
+          }
+        }
+        function attachNodeArrayDebugInfo(array) {
+          if (isDebugInfoEnabled) {
+            if (typeof Object.setPrototypeOf === "function") {
+              if (!nodeArrayProto) {
+                nodeArrayProto = Object.create(Array.prototype);
+                attachNodeArrayDebugInfoWorker(nodeArrayProto);
+              }
+              Object.setPrototypeOf(array, nodeArrayProto);
+            } else {
+              attachNodeArrayDebugInfoWorker(array);
+            }
+          }
+        }
+        Debug2.attachNodeArrayDebugInfo = attachNodeArrayDebugInfo;
+        function enableDebugInfo() {
+          if (isDebugInfoEnabled)
+            return;
+          const weakTypeTextMap = /* @__PURE__ */ new WeakMap();
+          const weakNodeTextMap = /* @__PURE__ */ new WeakMap();
+          Object.defineProperties(objectAllocator.getSymbolConstructor().prototype, {
+            // for use with vscode-js-debug's new customDescriptionGenerator in launch.json
+            __tsDebuggerDisplay: {
+              value() {
+                const symbolHeader = this.flags & 33554432 /* Transient */ ? "TransientSymbol" : "Symbol";
+                const remainingSymbolFlags = this.flags & ~33554432 /* Transient */;
+                return `${symbolHeader} '${symbolName(this)}'${remainingSymbolFlags ? ` (${formatSymbolFlags(remainingSymbolFlags)})` : ""}`;
+              }
             },
-            generated: {
-              line: generated.line,
-              column: generated.column
+            __debugFlags: {
+              get() {
+                return formatSymbolFlags(this.flags);
+              }
+            }
+          });
+          Object.defineProperties(objectAllocator.getTypeConstructor().prototype, {
+            // for use with vscode-js-debug's new customDescriptionGenerator in launch.json
+            __tsDebuggerDisplay: {
+              value() {
+                const typeHeader = this.flags & 67359327 /* Intrinsic */ ? `IntrinsicType ${this.intrinsicName}${this.debugIntrinsicName ? ` (${this.debugIntrinsicName})` : ""}` : this.flags & 98304 /* Nullable */ ? "NullableType" : this.flags & 384 /* StringOrNumberLiteral */ ? `LiteralType ${JSON.stringify(this.value)}` : this.flags & 2048 /* BigIntLiteral */ ? `LiteralType ${this.value.negative ? "-" : ""}${this.value.base10Value}n` : this.flags & 8192 /* UniqueESSymbol */ ? "UniqueESSymbolType" : this.flags & 32 /* Enum */ ? "EnumType" : this.flags & 1048576 /* Union */ ? "UnionType" : this.flags & 2097152 /* Intersection */ ? "IntersectionType" : this.flags & 4194304 /* Index */ ? "IndexType" : this.flags & 8388608 /* IndexedAccess */ ? "IndexedAccessType" : this.flags & 16777216 /* Conditional */ ? "ConditionalType" : this.flags & 33554432 /* Substitution */ ? "SubstitutionType" : this.flags & 262144 /* TypeParameter */ ? "TypeParameter" : this.flags & 524288 /* Object */ ? this.objectFlags & 3 /* ClassOrInterface */ ? "InterfaceType" : this.objectFlags & 4 /* Reference */ ? "TypeReference" : this.objectFlags & 8 /* Tuple */ ? "TupleType" : this.objectFlags & 16 /* Anonymous */ ? "AnonymousType" : this.objectFlags & 32 /* Mapped */ ? "MappedType" : this.objectFlags & 1024 /* ReverseMapped */ ? "ReverseMappedType" : this.objectFlags & 256 /* EvolvingArray */ ? "EvolvingArrayType" : "ObjectType" : "Type";
+                const remainingObjectFlags = this.flags & 524288 /* Object */ ? this.objectFlags & ~1343 /* ObjectTypeKindMask */ : 0;
+                return `${typeHeader}${this.symbol ? ` '${symbolName(this.symbol)}'` : ""}${remainingObjectFlags ? ` (${formatObjectFlags(remainingObjectFlags)})` : ""}`;
+              }
             },
-            name: original.name
+            __debugFlags: {
+              get() {
+                return formatTypeFlags(this.flags);
+              }
+            },
+            __debugObjectFlags: {
+              get() {
+                return this.flags & 524288 /* Object */ ? formatObjectFlags(this.objectFlags) : "";
+              }
+            },
+            __debugTypeToString: {
+              value() {
+                let text = weakTypeTextMap.get(this);
+                if (text === void 0) {
+                  text = this.checker.typeToString(this);
+                  weakTypeTextMap.set(this, text);
+                }
+                return text;
+              }
+            }
           });
-        }
-      } else {
-        generated.column++;
-      }
-    }
-  });
-  this.walkSourceContents(function (sourceFile, sourceContent) {
-    map.setSourceContent(sourceFile, sourceContent);
-  });
-
-  return { code: generated.code, map: map };
-};
-
-__webpack_unused_export__ = SourceNode;
-
-
-/***/ }),
-
-/***/ 16511:
-/***/ ((__unused_webpack_module, exports) => {
-
-/* -*- Mode: js; js-indent-level: 2; -*- */
-/*
- * Copyright 2011 Mozilla Foundation and contributors
- * Licensed under the New BSD license. See LICENSE or:
- * http://opensource.org/licenses/BSD-3-Clause
- */
-
-/**
- * This is a helper function for getting values from parameter/options
- * objects.
- *
- * @param args The object we are extracting values from
- * @param name The name of the property we are getting.
- * @param defaultValue An optional value to return if the property is missing
- * from the object. If this is not specified and the property is missing, an
- * error will be thrown.
- */
-function getArg(aArgs, aName, aDefaultValue) {
-  if (aName in aArgs) {
-    return aArgs[aName];
-  } else if (arguments.length === 3) {
-    return aDefaultValue;
-  } else {
-    throw new Error('"' + aName + '" is a required argument.');
-  }
-}
-exports.getArg = getArg;
-
-var urlRegexp = /^(?:([\w+\-.]+):)?\/\/(?:(\w+:\w+)@)?([\w.-]*)(?::(\d+))?(.*)$/;
-var dataUrlRegexp = /^data:.+\,.+$/;
-
-function urlParse(aUrl) {
-  var match = aUrl.match(urlRegexp);
-  if (!match) {
-    return null;
-  }
-  return {
-    scheme: match[1],
-    auth: match[2],
-    host: match[3],
-    port: match[4],
-    path: match[5]
-  };
-}
-exports.urlParse = urlParse;
+          Object.defineProperties(objectAllocator.getSignatureConstructor().prototype, {
+            __debugFlags: {
+              get() {
+                return formatSignatureFlags(this.flags);
+              }
+            },
+            __debugSignatureToString: {
+              value() {
+                var _a;
+                return (_a = this.checker) == null ? void 0 : _a.signatureToString(this);
+              }
+            }
+          });
+          const nodeConstructors = [
+            objectAllocator.getNodeConstructor(),
+            objectAllocator.getIdentifierConstructor(),
+            objectAllocator.getTokenConstructor(),
+            objectAllocator.getSourceFileConstructor()
+          ];
+          for (const ctor of nodeConstructors) {
+            if (!hasProperty(ctor.prototype, "__debugKind")) {
+              Object.defineProperties(ctor.prototype, {
+                // for use with vscode-js-debug's new customDescriptionGenerator in launch.json
+                __tsDebuggerDisplay: {
+                  value() {
+                    const nodeHeader = isGeneratedIdentifier(this) ? "GeneratedIdentifier" : isIdentifier(this) ? `Identifier '${idText(this)}'` : isPrivateIdentifier(this) ? `PrivateIdentifier '${idText(this)}'` : isStringLiteral(this) ? `StringLiteral ${JSON.stringify(this.text.length < 10 ? this.text : this.text.slice(10) + "...")}` : isNumericLiteral(this) ? `NumericLiteral ${this.text}` : isBigIntLiteral(this) ? `BigIntLiteral ${this.text}n` : isTypeParameterDeclaration(this) ? "TypeParameterDeclaration" : isParameter(this) ? "ParameterDeclaration" : isConstructorDeclaration(this) ? "ConstructorDeclaration" : isGetAccessorDeclaration(this) ? "GetAccessorDeclaration" : isSetAccessorDeclaration(this) ? "SetAccessorDeclaration" : isCallSignatureDeclaration(this) ? "CallSignatureDeclaration" : isConstructSignatureDeclaration(this) ? "ConstructSignatureDeclaration" : isIndexSignatureDeclaration(this) ? "IndexSignatureDeclaration" : isTypePredicateNode(this) ? "TypePredicateNode" : isTypeReferenceNode(this) ? "TypeReferenceNode" : isFunctionTypeNode(this) ? "FunctionTypeNode" : isConstructorTypeNode(this) ? "ConstructorTypeNode" : isTypeQueryNode(this) ? "TypeQueryNode" : isTypeLiteralNode(this) ? "TypeLiteralNode" : isArrayTypeNode(this) ? "ArrayTypeNode" : isTupleTypeNode(this) ? "TupleTypeNode" : isOptionalTypeNode(this) ? "OptionalTypeNode" : isRestTypeNode(this) ? "RestTypeNode" : isUnionTypeNode(this) ? "UnionTypeNode" : isIntersectionTypeNode(this) ? "IntersectionTypeNode" : isConditionalTypeNode(this) ? "ConditionalTypeNode" : isInferTypeNode(this) ? "InferTypeNode" : isParenthesizedTypeNode(this) ? "ParenthesizedTypeNode" : isThisTypeNode(this) ? "ThisTypeNode" : isTypeOperatorNode(this) ? "TypeOperatorNode" : isIndexedAccessTypeNode(this) ? "IndexedAccessTypeNode" : isMappedTypeNode(this) ? "MappedTypeNode" : isLiteralTypeNode(this) ? "LiteralTypeNode" : isNamedTupleMember(this) ? "NamedTupleMember" : isImportTypeNode(this) ? "ImportTypeNode" : formatSyntaxKind(this.kind);
+                    return `${nodeHeader}${this.flags ? ` (${formatNodeFlags(this.flags)})` : ""}`;
+                  }
+                },
+                __debugKind: {
+                  get() {
+                    return formatSyntaxKind(this.kind);
+                  }
+                },
+                __debugNodeFlags: {
+                  get() {
+                    return formatNodeFlags(this.flags);
+                  }
+                },
+                __debugModifierFlags: {
+                  get() {
+                    return formatModifierFlags(getEffectiveModifierFlagsNoCache(this));
+                  }
+                },
+                __debugTransformFlags: {
+                  get() {
+                    return formatTransformFlags(this.transformFlags);
+                  }
+                },
+                __debugIsParseTreeNode: {
+                  get() {
+                    return isParseTreeNode(this);
+                  }
+                },
+                __debugEmitFlags: {
+                  get() {
+                    return formatEmitFlags(getEmitFlags(this));
+                  }
+                },
+                __debugGetText: {
+                  value(includeTrivia) {
+                    if (nodeIsSynthesized(this))
+                      return "";
+                    let text = weakNodeTextMap.get(this);
+                    if (text === void 0) {
+                      const parseNode = getParseTreeNode(this);
+                      const sourceFile = parseNode && getSourceFileOfNode(parseNode);
+                      text = sourceFile ? getSourceTextOfNodeFromSourceFile(sourceFile, parseNode, includeTrivia) : "";
+                      weakNodeTextMap.set(this, text);
+                    }
+                    return text;
+                  }
+                }
+              });
+            }
+          }
+          isDebugInfoEnabled = true;
+        }
+        Debug2.enableDebugInfo = enableDebugInfo;
+        function formatVariance(varianceFlags) {
+          const variance = varianceFlags & 7 /* VarianceMask */;
+          let result = variance === 0 /* Invariant */ ? "in out" : variance === 3 /* Bivariant */ ? "[bivariant]" : variance === 2 /* Contravariant */ ? "in" : variance === 1 /* Covariant */ ? "out" : variance === 4 /* Independent */ ? "[independent]" : "";
+          if (varianceFlags & 8 /* Unmeasurable */) {
+            result += " (unmeasurable)";
+          } else if (varianceFlags & 16 /* Unreliable */) {
+            result += " (unreliable)";
+          }
+          return result;
+        }
+        Debug2.formatVariance = formatVariance;
+        class DebugTypeMapper {
+          __debugToString() {
+            var _a;
+            type(this);
+            switch (this.kind) {
+              case 3 /* Function */:
+                return ((_a = this.debugInfo) == null ? void 0 : _a.call(this)) || "(function mapper)";
+              case 0 /* Simple */:
+                return `${this.source.__debugTypeToString()} -> ${this.target.__debugTypeToString()}`;
+              case 1 /* Array */:
+                return zipWith(
+                  this.sources,
+                  this.targets || map(this.sources, () => "any"),
+                  (s, t) => `${s.__debugTypeToString()} -> ${typeof t === "string" ? t : t.__debugTypeToString()}`
+                ).join(", ");
+              case 2 /* Deferred */:
+                return zipWith(
+                  this.sources,
+                  this.targets,
+                  (s, t) => `${s.__debugTypeToString()} -> ${t().__debugTypeToString()}`
+                ).join(", ");
+              case 5 /* Merged */:
+              case 4 /* Composite */:
+                return `m1: ${this.mapper1.__debugToString().split("\n").join("\n    ")}
+m2: ${this.mapper2.__debugToString().split("\n").join("\n    ")}`;
+              default:
+                return assertNever(this);
+            }
+          }
+        }
+        Debug2.DebugTypeMapper = DebugTypeMapper;
+        function attachDebugPrototypeIfDebug(mapper) {
+          if (Debug2.isDebugging) {
+            return Object.setPrototypeOf(mapper, DebugTypeMapper.prototype);
+          }
+          return mapper;
+        }
+        Debug2.attachDebugPrototypeIfDebug = attachDebugPrototypeIfDebug;
+        function printControlFlowGraph(flowNode) {
+          return console.log(formatControlFlowGraph(flowNode));
+        }
+        Debug2.printControlFlowGraph = printControlFlowGraph;
+        function formatControlFlowGraph(flowNode) {
+          let nextDebugFlowId = -1;
+          function getDebugFlowNodeId(f) {
+            if (!f.id) {
+              f.id = nextDebugFlowId;
+              nextDebugFlowId--;
+            }
+            return f.id;
+          }
+          let BoxCharacter;
+          ((BoxCharacter2) => {
+            BoxCharacter2["lr"] = "\u2500";
+            BoxCharacter2["ud"] = "\u2502";
+            BoxCharacter2["dr"] = "\u256D";
+            BoxCharacter2["dl"] = "\u256E";
+            BoxCharacter2["ul"] = "\u256F";
+            BoxCharacter2["ur"] = "\u2570";
+            BoxCharacter2["udr"] = "\u251C";
+            BoxCharacter2["udl"] = "\u2524";
+            BoxCharacter2["dlr"] = "\u252C";
+            BoxCharacter2["ulr"] = "\u2534";
+            BoxCharacter2["udlr"] = "\u256B";
+          })(BoxCharacter || (BoxCharacter = {}));
+          let Connection;
+          ((Connection2) => {
+            Connection2[Connection2["None"] = 0] = "None";
+            Connection2[Connection2["Up"] = 1] = "Up";
+            Connection2[Connection2["Down"] = 2] = "Down";
+            Connection2[Connection2["Left"] = 4] = "Left";
+            Connection2[Connection2["Right"] = 8] = "Right";
+            Connection2[Connection2["UpDown"] = 3] = "UpDown";
+            Connection2[Connection2["LeftRight"] = 12] = "LeftRight";
+            Connection2[Connection2["UpLeft"] = 5] = "UpLeft";
+            Connection2[Connection2["UpRight"] = 9] = "UpRight";
+            Connection2[Connection2["DownLeft"] = 6] = "DownLeft";
+            Connection2[Connection2["DownRight"] = 10] = "DownRight";
+            Connection2[Connection2["UpDownLeft"] = 7] = "UpDownLeft";
+            Connection2[Connection2["UpDownRight"] = 11] = "UpDownRight";
+            Connection2[Connection2["UpLeftRight"] = 13] = "UpLeftRight";
+            Connection2[Connection2["DownLeftRight"] = 14] = "DownLeftRight";
+            Connection2[Connection2["UpDownLeftRight"] = 15] = "UpDownLeftRight";
+            Connection2[Connection2["NoChildren"] = 16] = "NoChildren";
+          })(Connection || (Connection = {}));
+          const hasAntecedentFlags = 16 /* Assignment */ | 96 /* Condition */ | 128 /* SwitchClause */ | 256 /* ArrayMutation */ | 512 /* Call */ | 1024 /* ReduceLabel */;
+          const hasNodeFlags = 2 /* Start */ | 16 /* Assignment */ | 512 /* Call */ | 96 /* Condition */ | 256 /* ArrayMutation */;
+          const links = /* @__PURE__ */ Object.create(
+            /*o*/
+            null
+          );
+          const nodes = [];
+          const edges = [];
+          const root = buildGraphNode(flowNode, /* @__PURE__ */ new Set());
+          for (const node of nodes) {
+            node.text = renderFlowNode(node.flowNode, node.circular);
+            computeLevel(node);
+          }
+          const height = computeHeight(root);
+          const columnWidths = computeColumnWidths(height);
+          computeLanes(root, 0);
+          return renderGraph();
+          function isFlowSwitchClause(f) {
+            return !!(f.flags & 128 /* SwitchClause */);
+          }
+          function hasAntecedents(f) {
+            return !!(f.flags & 12 /* Label */) && !!f.antecedents;
+          }
+          function hasAntecedent(f) {
+            return !!(f.flags & hasAntecedentFlags);
+          }
+          function hasNode(f) {
+            return !!(f.flags & hasNodeFlags);
+          }
+          function getChildren(node) {
+            const children = [];
+            for (const edge of node.edges) {
+              if (edge.source === node) {
+                children.push(edge.target);
+              }
+            }
+            return children;
+          }
+          function getParents(node) {
+            const parents = [];
+            for (const edge of node.edges) {
+              if (edge.target === node) {
+                parents.push(edge.source);
+              }
+            }
+            return parents;
+          }
+          function buildGraphNode(flowNode2, seen) {
+            const id = getDebugFlowNodeId(flowNode2);
+            let graphNode = links[id];
+            if (graphNode && seen.has(flowNode2)) {
+              graphNode.circular = true;
+              graphNode = {
+                id: -1,
+                flowNode: flowNode2,
+                edges: [],
+                text: "",
+                lane: -1,
+                endLane: -1,
+                level: -1,
+                circular: "circularity"
+              };
+              nodes.push(graphNode);
+              return graphNode;
+            }
+            seen.add(flowNode2);
+            if (!graphNode) {
+              links[id] = graphNode = { id, flowNode: flowNode2, edges: [], text: "", lane: -1, endLane: -1, level: -1, circular: false };
+              nodes.push(graphNode);
+              if (hasAntecedents(flowNode2)) {
+                for (const antecedent of flowNode2.antecedents) {
+                  buildGraphEdge(graphNode, antecedent, seen);
+                }
+              } else if (hasAntecedent(flowNode2)) {
+                buildGraphEdge(graphNode, flowNode2.antecedent, seen);
+              }
+            }
+            seen.delete(flowNode2);
+            return graphNode;
+          }
+          function buildGraphEdge(source, antecedent, seen) {
+            const target = buildGraphNode(antecedent, seen);
+            const edge = { source, target };
+            edges.push(edge);
+            source.edges.push(edge);
+            target.edges.push(edge);
+          }
+          function computeLevel(node) {
+            if (node.level !== -1) {
+              return node.level;
+            }
+            let level = 0;
+            for (const parent2 of getParents(node)) {
+              level = Math.max(level, computeLevel(parent2) + 1);
+            }
+            return node.level = level;
+          }
+          function computeHeight(node) {
+            let height2 = 0;
+            for (const child of getChildren(node)) {
+              height2 = Math.max(height2, computeHeight(child));
+            }
+            return height2 + 1;
+          }
+          function computeColumnWidths(height2) {
+            const columns = fill(Array(height2), 0);
+            for (const node of nodes) {
+              columns[node.level] = Math.max(columns[node.level], node.text.length);
+            }
+            return columns;
+          }
+          function computeLanes(node, lane) {
+            if (node.lane === -1) {
+              node.lane = lane;
+              node.endLane = lane;
+              const children = getChildren(node);
+              for (let i = 0; i < children.length; i++) {
+                if (i > 0)
+                  lane++;
+                const child = children[i];
+                computeLanes(child, lane);
+                if (child.endLane > node.endLane) {
+                  lane = child.endLane;
+                }
+              }
+              node.endLane = lane;
+            }
+          }
+          function getHeader(flags) {
+            if (flags & 2 /* Start */)
+              return "Start";
+            if (flags & 4 /* BranchLabel */)
+              return "Branch";
+            if (flags & 8 /* LoopLabel */)
+              return "Loop";
+            if (flags & 16 /* Assignment */)
+              return "Assignment";
+            if (flags & 32 /* TrueCondition */)
+              return "True";
+            if (flags & 64 /* FalseCondition */)
+              return "False";
+            if (flags & 128 /* SwitchClause */)
+              return "SwitchClause";
+            if (flags & 256 /* ArrayMutation */)
+              return "ArrayMutation";
+            if (flags & 512 /* Call */)
+              return "Call";
+            if (flags & 1024 /* ReduceLabel */)
+              return "ReduceLabel";
+            if (flags & 1 /* Unreachable */)
+              return "Unreachable";
+            throw new Error();
+          }
+          function getNodeText(node) {
+            const sourceFile = getSourceFileOfNode(node);
+            return getSourceTextOfNodeFromSourceFile(
+              sourceFile,
+              node,
+              /*includeTrivia*/
+              false
+            );
+          }
+          function renderFlowNode(flowNode2, circular) {
+            let text = getHeader(flowNode2.flags);
+            if (circular) {
+              text = `${text}#${getDebugFlowNodeId(flowNode2)}`;
+            }
+            if (hasNode(flowNode2)) {
+              if (flowNode2.node) {
+                text += ` (${getNodeText(flowNode2.node)})`;
+              }
+            } else if (isFlowSwitchClause(flowNode2)) {
+              const clauses = [];
+              for (let i = flowNode2.clauseStart; i < flowNode2.clauseEnd; i++) {
+                const clause = flowNode2.switchStatement.caseBlock.clauses[i];
+                if (isDefaultClause(clause)) {
+                  clauses.push("default");
+                } else {
+                  clauses.push(getNodeText(clause.expression));
+                }
+              }
+              text += ` (${clauses.join(", ")})`;
+            }
+            return circular === "circularity" ? `Circular(${text})` : text;
+          }
+          function renderGraph() {
+            const columnCount = columnWidths.length;
+            const laneCount = nodes.reduce((x, n) => Math.max(x, n.lane), 0) + 1;
+            const lanes = fill(Array(laneCount), "");
+            const grid = columnWidths.map(() => Array(laneCount));
+            const connectors = columnWidths.map(() => fill(Array(laneCount), 0));
+            for (const node of nodes) {
+              grid[node.level][node.lane] = node;
+              const children = getChildren(node);
+              for (let i = 0; i < children.length; i++) {
+                const child = children[i];
+                let connector = 8 /* Right */;
+                if (child.lane === node.lane)
+                  connector |= 4 /* Left */;
+                if (i > 0)
+                  connector |= 1 /* Up */;
+                if (i < children.length - 1)
+                  connector |= 2 /* Down */;
+                connectors[node.level][child.lane] |= connector;
+              }
+              if (children.length === 0) {
+                connectors[node.level][node.lane] |= 16 /* NoChildren */;
+              }
+              const parents = getParents(node);
+              for (let i = 0; i < parents.length; i++) {
+                const parent2 = parents[i];
+                let connector = 4 /* Left */;
+                if (i > 0)
+                  connector |= 1 /* Up */;
+                if (i < parents.length - 1)
+                  connector |= 2 /* Down */;
+                connectors[node.level - 1][parent2.lane] |= connector;
+              }
+            }
+            for (let column = 0; column < columnCount; column++) {
+              for (let lane = 0; lane < laneCount; lane++) {
+                const left = column > 0 ? connectors[column - 1][lane] : 0;
+                const above = lane > 0 ? connectors[column][lane - 1] : 0;
+                let connector = connectors[column][lane];
+                if (!connector) {
+                  if (left & 8 /* Right */)
+                    connector |= 12 /* LeftRight */;
+                  if (above & 2 /* Down */)
+                    connector |= 3 /* UpDown */;
+                  connectors[column][lane] = connector;
+                }
+              }
+            }
+            for (let column = 0; column < columnCount; column++) {
+              for (let lane = 0; lane < lanes.length; lane++) {
+                const connector = connectors[column][lane];
+                const fill2 = connector & 4 /* Left */ ? "\u2500" /* lr */ : " ";
+                const node = grid[column][lane];
+                if (!node) {
+                  if (column < columnCount - 1) {
+                    writeLane(lane, repeat(fill2, columnWidths[column] + 1));
+                  }
+                } else {
+                  writeLane(lane, node.text);
+                  if (column < columnCount - 1) {
+                    writeLane(lane, " ");
+                    writeLane(lane, repeat(fill2, columnWidths[column] - node.text.length));
+                  }
+                }
+                writeLane(lane, getBoxCharacter(connector));
+                writeLane(lane, connector & 8 /* Right */ && column < columnCount - 1 && !grid[column + 1][lane] ? "\u2500" /* lr */ : " ");
+              }
+            }
+            return `
+${lanes.join("\n")}
+`;
+            function writeLane(lane, text) {
+              lanes[lane] += text;
+            }
+          }
+          function getBoxCharacter(connector) {
+            switch (connector) {
+              case 3 /* UpDown */:
+                return "\u2502" /* ud */;
+              case 12 /* LeftRight */:
+                return "\u2500" /* lr */;
+              case 5 /* UpLeft */:
+                return "\u256F" /* ul */;
+              case 9 /* UpRight */:
+                return "\u2570" /* ur */;
+              case 6 /* DownLeft */:
+                return "\u256E" /* dl */;
+              case 10 /* DownRight */:
+                return "\u256D" /* dr */;
+              case 7 /* UpDownLeft */:
+                return "\u2524" /* udl */;
+              case 11 /* UpDownRight */:
+                return "\u251C" /* udr */;
+              case 13 /* UpLeftRight */:
+                return "\u2534" /* ulr */;
+              case 14 /* DownLeftRight */:
+                return "\u252C" /* dlr */;
+              case 15 /* UpDownLeftRight */:
+                return "\u256B" /* udlr */;
+            }
+            return " ";
+          }
+          function fill(array, value) {
+            if (array.fill) {
+              array.fill(value);
+            } else {
+              for (let i = 0; i < array.length; i++) {
+                array[i] = value;
+              }
+            }
+            return array;
+          }
+          function repeat(ch, length2) {
+            if (ch.repeat) {
+              return length2 > 0 ? ch.repeat(length2) : "";
+            }
+            let s = "";
+            while (s.length < length2) {
+              s += ch;
+            }
+            return s;
+          }
+        }
+        Debug2.formatControlFlowGraph = formatControlFlowGraph;
+      })(Debug || (Debug = {}));
+    }
+  });
 
-function urlGenerate(aParsedUrl) {
-  var url = '';
-  if (aParsedUrl.scheme) {
-    url += aParsedUrl.scheme + ':';
-  }
-  url += '//';
-  if (aParsedUrl.auth) {
-    url += aParsedUrl.auth + '@';
-  }
-  if (aParsedUrl.host) {
-    url += aParsedUrl.host;
-  }
-  if (aParsedUrl.port) {
-    url += ":" + aParsedUrl.port
-  }
-  if (aParsedUrl.path) {
-    url += aParsedUrl.path;
+  // src/compiler/semver.ts
+  function tryParseComponents(text) {
+    const match = versionRegExp.exec(text);
+    if (!match)
+      return void 0;
+    const [, major, minor = "0", patch = "0", prerelease = "", build2 = ""] = match;
+    if (prerelease && !prereleaseRegExp.test(prerelease))
+      return void 0;
+    if (build2 && !buildRegExp.test(build2))
+      return void 0;
+    return {
+      major: parseInt(major, 10),
+      minor: parseInt(minor, 10),
+      patch: parseInt(patch, 10),
+      prerelease,
+      build: build2
+    };
   }
-  return url;
-}
-exports.urlGenerate = urlGenerate;
-
-/**
- * Normalizes a path, or the path portion of a URL:
- *
- * - Replaces consecutive slashes with one slash.
- * - Removes unnecessary '.' parts.
- * - Removes unnecessary '/..' parts.
- *
- * Based on code in the Node.js 'path' core module.
- *
- * @param aPath The path or url to normalize.
- */
-function normalize(aPath) {
-  var path = aPath;
-  var url = urlParse(aPath);
-  if (url) {
-    if (!url.path) {
-      return aPath;
+  function comparePrereleaseIdentifiers(left, right) {
+    if (left === right)
+      return 0 /* EqualTo */;
+    if (left.length === 0)
+      return right.length === 0 ? 0 /* EqualTo */ : 1 /* GreaterThan */;
+    if (right.length === 0)
+      return -1 /* LessThan */;
+    const length2 = Math.min(left.length, right.length);
+    for (let i = 0; i < length2; i++) {
+      const leftIdentifier = left[i];
+      const rightIdentifier = right[i];
+      if (leftIdentifier === rightIdentifier)
+        continue;
+      const leftIsNumeric = numericIdentifierRegExp.test(leftIdentifier);
+      const rightIsNumeric = numericIdentifierRegExp.test(rightIdentifier);
+      if (leftIsNumeric || rightIsNumeric) {
+        if (leftIsNumeric !== rightIsNumeric)
+          return leftIsNumeric ? -1 /* LessThan */ : 1 /* GreaterThan */;
+        const result = compareValues(+leftIdentifier, +rightIdentifier);
+        if (result)
+          return result;
+      } else {
+        const result = compareStringsCaseSensitive(leftIdentifier, rightIdentifier);
+        if (result)
+          return result;
+      }
     }
-    path = url.path;
+    return compareValues(left.length, right.length);
   }
-  var isAbsolute = exports.isAbsolute(path);
-
-  var parts = path.split(/\/+/);
-  for (var part, up = 0, i = parts.length - 1; i >= 0; i--) {
-    part = parts[i];
-    if (part === '.') {
-      parts.splice(i, 1);
-    } else if (part === '..') {
-      up++;
-    } else if (up > 0) {
-      if (part === '') {
-        // The first part is blank if the path is absolute. Trying to go
-        // above the root is a no-op. Therefore we can remove all '..' parts
-        // directly after the root.
-        parts.splice(i + 1, up);
-        up = 0;
+  function parseRange(text) {
+    const alternatives = [];
+    for (let range of text.trim().split(logicalOrRegExp)) {
+      if (!range)
+        continue;
+      const comparators = [];
+      range = range.trim();
+      const match = hyphenRegExp.exec(range);
+      if (match) {
+        if (!parseHyphen(match[1], match[2], comparators))
+          return void 0;
       } else {
-        parts.splice(i, 2);
-        up--;
+        for (const simple of range.split(whitespaceRegExp)) {
+          const match2 = rangeRegExp.exec(simple.trim());
+          if (!match2 || !parseComparator(match2[1], match2[2], comparators))
+            return void 0;
+        }
       }
+      alternatives.push(comparators);
     }
+    return alternatives;
   }
-  path = parts.join('/');
-
-  if (path === '') {
-    path = isAbsolute ? '/' : '.';
+  function parsePartial(text) {
+    const match = partialRegExp.exec(text);
+    if (!match)
+      return void 0;
+    const [, major, minor = "*", patch = "*", prerelease, build2] = match;
+    const version2 = new Version(
+      isWildcard(major) ? 0 : parseInt(major, 10),
+      isWildcard(major) || isWildcard(minor) ? 0 : parseInt(minor, 10),
+      isWildcard(major) || isWildcard(minor) || isWildcard(patch) ? 0 : parseInt(patch, 10),
+      prerelease,
+      build2
+    );
+    return { version: version2, major, minor, patch };
   }
-
-  if (url) {
-    url.path = path;
-    return urlGenerate(url);
+  function parseHyphen(left, right, comparators) {
+    const leftResult = parsePartial(left);
+    if (!leftResult)
+      return false;
+    const rightResult = parsePartial(right);
+    if (!rightResult)
+      return false;
+    if (!isWildcard(leftResult.major)) {
+      comparators.push(createComparator(">=", leftResult.version));
+    }
+    if (!isWildcard(rightResult.major)) {
+      comparators.push(
+        isWildcard(rightResult.minor) ? createComparator("<", rightResult.version.increment("major")) : isWildcard(rightResult.patch) ? createComparator("<", rightResult.version.increment("minor")) : createComparator("<=", rightResult.version)
+      );
+    }
+    return true;
   }
-  return path;
-}
-exports.normalize = normalize;
-
-/**
- * Joins two paths/URLs.
- *
- * @param aRoot The root path or URL.
- * @param aPath The path or URL to be joined with the root.
- *
- * - If aPath is a URL or a data URI, aPath is returned, unless aPath is a
- *   scheme-relative URL: Then the scheme of aRoot, if any, is prepended
- *   first.
- * - Otherwise aPath is a path. If aRoot is a URL, then its path portion
- *   is updated with the result and aRoot is returned. Otherwise the result
- *   is returned.
- *   - If aPath is absolute, the result is aPath.
- *   - Otherwise the two paths are joined with a slash.
- * - Joining for example 'http://' and 'www.example.com' is also supported.
- */
-function join(aRoot, aPath) {
-  if (aRoot === "") {
-    aRoot = ".";
+  function parseComparator(operator, text, comparators) {
+    const result = parsePartial(text);
+    if (!result)
+      return false;
+    const { version: version2, major, minor, patch } = result;
+    if (!isWildcard(major)) {
+      switch (operator) {
+        case "~":
+          comparators.push(createComparator(">=", version2));
+          comparators.push(createComparator(
+            "<",
+            version2.increment(
+              isWildcard(minor) ? "major" : "minor"
+            )
+          ));
+          break;
+        case "^":
+          comparators.push(createComparator(">=", version2));
+          comparators.push(createComparator(
+            "<",
+            version2.increment(
+              version2.major > 0 || isWildcard(minor) ? "major" : version2.minor > 0 || isWildcard(patch) ? "minor" : "patch"
+            )
+          ));
+          break;
+        case "<":
+        case ">=":
+          comparators.push(
+            isWildcard(minor) || isWildcard(patch) ? createComparator(operator, version2.with({ prerelease: "0" })) : createComparator(operator, version2)
+          );
+          break;
+        case "<=":
+        case ">":
+          comparators.push(
+            isWildcard(minor) ? createComparator(operator === "<=" ? "<" : ">=", version2.increment("major").with({ prerelease: "0" })) : isWildcard(patch) ? createComparator(operator === "<=" ? "<" : ">=", version2.increment("minor").with({ prerelease: "0" })) : createComparator(operator, version2)
+          );
+          break;
+        case "=":
+        case void 0:
+          if (isWildcard(minor) || isWildcard(patch)) {
+            comparators.push(createComparator(">=", version2.with({ prerelease: "0" })));
+            comparators.push(createComparator("<", version2.increment(isWildcard(minor) ? "major" : "minor").with({ prerelease: "0" })));
+          } else {
+            comparators.push(createComparator("=", version2));
+          }
+          break;
+        default:
+          return false;
+      }
+    } else if (operator === "<" || operator === ">") {
+      comparators.push(createComparator("<", Version.zero));
+    }
+    return true;
   }
-  if (aPath === "") {
-    aPath = ".";
+  function isWildcard(part) {
+    return part === "*" || part === "x" || part === "X";
   }
-  var aPathUrl = urlParse(aPath);
-  var aRootUrl = urlParse(aRoot);
-  if (aRootUrl) {
-    aRoot = aRootUrl.path || '/';
+  function createComparator(operator, operand) {
+    return { operator, operand };
   }
-
-  // `join(foo, '//www.example.org')`
-  if (aPathUrl && !aPathUrl.scheme) {
-    if (aRootUrl) {
-      aPathUrl.scheme = aRootUrl.scheme;
+  function testDisjunction(version2, alternatives) {
+    if (alternatives.length === 0)
+      return true;
+    for (const alternative of alternatives) {
+      if (testAlternative(version2, alternative))
+        return true;
     }
-    return urlGenerate(aPathUrl);
+    return false;
   }
-
-  if (aPathUrl || aPath.match(dataUrlRegexp)) {
-    return aPath;
+  function testAlternative(version2, comparators) {
+    for (const comparator of comparators) {
+      if (!testComparator(version2, comparator.operator, comparator.operand))
+        return false;
+    }
+    return true;
   }
-
-  // `join('http://', 'www.example.com')`
-  if (aRootUrl && !aRootUrl.host && !aRootUrl.path) {
-    aRootUrl.host = aPath;
-    return urlGenerate(aRootUrl);
+  function testComparator(version2, operator, operand) {
+    const cmp = version2.compareTo(operand);
+    switch (operator) {
+      case "<":
+        return cmp < 0;
+      case "<=":
+        return cmp <= 0;
+      case ">":
+        return cmp > 0;
+      case ">=":
+        return cmp >= 0;
+      case "=":
+        return cmp === 0;
+      default:
+        return Debug.assertNever(operator);
+    }
   }
-
-  var joined = aPath.charAt(0) === '/'
-    ? aPath
-    : normalize(aRoot.replace(/\/+$/, '') + '/' + aPath);
-
-  if (aRootUrl) {
-    aRootUrl.path = joined;
-    return urlGenerate(aRootUrl);
+  function formatDisjunction(alternatives) {
+    return map(alternatives, formatAlternative).join(" || ") || "*";
   }
-  return joined;
-}
-exports.join = join;
-
-exports.isAbsolute = function (aPath) {
-  return aPath.charAt(0) === '/' || urlRegexp.test(aPath);
-};
-
-/**
- * Make a path relative to a URL or another path.
- *
- * @param aRoot The root path or URL.
- * @param aPath The path or URL to be made relative to aRoot.
- */
-function relative(aRoot, aPath) {
-  if (aRoot === "") {
-    aRoot = ".";
+  function formatAlternative(comparators) {
+    return map(comparators, formatComparator).join(" ");
   }
-
-  aRoot = aRoot.replace(/\/$/, '');
-
-  // It is possible for the path to be above the root. In this case, simply
-  // checking whether the root is a prefix of the path won't work. Instead, we
-  // need to remove components from the root one by one, until either we find
-  // a prefix that fits, or we run out of components to remove.
-  var level = 0;
-  while (aPath.indexOf(aRoot + '/') !== 0) {
-    var index = aRoot.lastIndexOf("/");
-    if (index < 0) {
-      return aPath;
+  function formatComparator(comparator) {
+    return `${comparator.operator}${comparator.operand}`;
+  }
+  var versionRegExp, prereleaseRegExp, prereleasePartRegExp, buildRegExp, buildPartRegExp, numericIdentifierRegExp, _Version, Version, VersionRange, logicalOrRegExp, whitespaceRegExp, partialRegExp, hyphenRegExp, rangeRegExp;
+  var init_semver = __esm({
+    "src/compiler/semver.ts"() {
+      "use strict";
+      init_ts2();
+      versionRegExp = /^(0|[1-9]\d*)(?:\.(0|[1-9]\d*)(?:\.(0|[1-9]\d*)(?:-([a-z0-9-.]+))?(?:\+([a-z0-9-.]+))?)?)?$/i;
+      prereleaseRegExp = /^(?:0|[1-9]\d*|[a-z-][a-z0-9-]*)(?:\.(?:0|[1-9]\d*|[a-z-][a-z0-9-]*))*$/i;
+      prereleasePartRegExp = /^(?:0|[1-9]\d*|[a-z-][a-z0-9-]*)$/i;
+      buildRegExp = /^[a-z0-9-]+(?:\.[a-z0-9-]+)*$/i;
+      buildPartRegExp = /^[a-z0-9-]+$/i;
+      numericIdentifierRegExp = /^(0|[1-9]\d*)$/;
+      _Version = class _Version {
+        constructor(major, minor = 0, patch = 0, prerelease = "", build2 = "") {
+          if (typeof major === "string") {
+            const result = Debug.checkDefined(tryParseComponents(major), "Invalid version");
+            ({ major, minor, patch, prerelease, build: build2 } = result);
+          }
+          Debug.assert(major >= 0, "Invalid argument: major");
+          Debug.assert(minor >= 0, "Invalid argument: minor");
+          Debug.assert(patch >= 0, "Invalid argument: patch");
+          const prereleaseArray = prerelease ? isArray(prerelease) ? prerelease : prerelease.split(".") : emptyArray;
+          const buildArray = build2 ? isArray(build2) ? build2 : build2.split(".") : emptyArray;
+          Debug.assert(every(prereleaseArray, (s) => prereleasePartRegExp.test(s)), "Invalid argument: prerelease");
+          Debug.assert(every(buildArray, (s) => buildPartRegExp.test(s)), "Invalid argument: build");
+          this.major = major;
+          this.minor = minor;
+          this.patch = patch;
+          this.prerelease = prereleaseArray;
+          this.build = buildArray;
+        }
+        static tryParse(text) {
+          const result = tryParseComponents(text);
+          if (!result)
+            return void 0;
+          const { major, minor, patch, prerelease, build: build2 } = result;
+          return new _Version(major, minor, patch, prerelease, build2);
+        }
+        compareTo(other) {
+          if (this === other)
+            return 0 /* EqualTo */;
+          if (other === void 0)
+            return 1 /* GreaterThan */;
+          return compareValues(this.major, other.major) || compareValues(this.minor, other.minor) || compareValues(this.patch, other.patch) || comparePrereleaseIdentifiers(this.prerelease, other.prerelease);
+        }
+        increment(field) {
+          switch (field) {
+            case "major":
+              return new _Version(this.major + 1, 0, 0);
+            case "minor":
+              return new _Version(this.major, this.minor + 1, 0);
+            case "patch":
+              return new _Version(this.major, this.minor, this.patch + 1);
+            default:
+              return Debug.assertNever(field);
+          }
+        }
+        with(fields) {
+          const {
+            major = this.major,
+            minor = this.minor,
+            patch = this.patch,
+            prerelease = this.prerelease,
+            build: build2 = this.build
+          } = fields;
+          return new _Version(major, minor, patch, prerelease, build2);
+        }
+        toString() {
+          let result = `${this.major}.${this.minor}.${this.patch}`;
+          if (some(this.prerelease))
+            result += `-${this.prerelease.join(".")}`;
+          if (some(this.build))
+            result += `+${this.build.join(".")}`;
+          return result;
+        }
+      };
+      _Version.zero = new _Version(0, 0, 0, ["0"]);
+      Version = _Version;
+      VersionRange = class _VersionRange {
+        constructor(spec) {
+          this._alternatives = spec ? Debug.checkDefined(parseRange(spec), "Invalid range spec.") : emptyArray;
+        }
+        static tryParse(text) {
+          const sets = parseRange(text);
+          if (sets) {
+            const range = new _VersionRange("");
+            range._alternatives = sets;
+            return range;
+          }
+          return void 0;
+        }
+        /**
+         * Tests whether a version matches the range. This is equivalent to `satisfies(version, range, { includePrerelease: true })`.
+         * in `node-semver`.
+         */
+        test(version2) {
+          if (typeof version2 === "string")
+            version2 = new Version(version2);
+          return testDisjunction(version2, this._alternatives);
+        }
+        toString() {
+          return formatDisjunction(this._alternatives);
+        }
+      };
+      logicalOrRegExp = /\|\|/g;
+      whitespaceRegExp = /\s+/g;
+      partialRegExp = /^([xX*0]|[1-9]\d*)(?:\.([xX*0]|[1-9]\d*)(?:\.([xX*0]|[1-9]\d*)(?:-([a-z0-9-.]+))?(?:\+([a-z0-9-.]+))?)?)?$/i;
+      hyphenRegExp = /^\s*([a-z0-9-+.*]+)\s+-\s+([a-z0-9-+.*]+)\s*$/i;
+      rangeRegExp = /^(~|\^|<|<=|>|>=|=)?\s*([a-z0-9-+.*]+)$/i;
     }
+  });
 
-    // If the only part of the root that is left is the scheme (i.e. http://,
-    // file:///, etc.), one or more slashes (/), or simply nothing at all, we
-    // have exhausted all components, so the path is not relative to the root.
-    aRoot = aRoot.slice(0, index);
-    if (aRoot.match(/^([^\/]+:\/)?\/*$/)) {
-      return aPath;
+  // src/compiler/performanceCore.ts
+  function hasRequiredAPI(performance2, PerformanceObserver2) {
+    return typeof performance2 === "object" && typeof performance2.timeOrigin === "number" && typeof performance2.mark === "function" && typeof performance2.measure === "function" && typeof performance2.now === "function" && typeof performance2.clearMarks === "function" && typeof performance2.clearMeasures === "function" && typeof PerformanceObserver2 === "function";
+  }
+  function tryGetWebPerformanceHooks() {
+    if (typeof performance === "object" && typeof PerformanceObserver === "function" && hasRequiredAPI(performance, PerformanceObserver)) {
+      return {
+        // For now we always write native performance events when running in the browser. We may
+        // make this conditional in the future if we find that native web performance hooks
+        // in the browser also slow down compilation.
+        shouldWriteNativeEvents: true,
+        performance,
+        PerformanceObserver
+      };
     }
-
-    ++level;
   }
-
-  // Make sure we add a "../" for each component we removed from the root.
-  return Array(level + 1).join("../") + aPath.substr(aRoot.length + 1);
-}
-exports.relative = relative;
-
-var supportsNullProto = (function () {
-  var obj = Object.create(null);
-  return !('__proto__' in obj);
-}());
-
-function identity (s) {
-  return s;
-}
-
-/**
- * Because behavior goes wacky when you set `__proto__` on objects, we
- * have to prefix all the strings in our set with an arbitrary character.
- *
- * See https://github.com/mozilla/source-map/pull/31 and
- * https://github.com/mozilla/source-map/issues/30
- *
- * @param String aStr
- */
-function toSetString(aStr) {
-  if (isProtoString(aStr)) {
-    return '$' + aStr;
+  function tryGetNodePerformanceHooks() {
+    if (isNodeLikeSystem()) {
+      try {
+        const { performance: performance2, PerformanceObserver: PerformanceObserver2 } =   __nccwpck_require__(4074);
+        if (hasRequiredAPI(performance2, PerformanceObserver2)) {
+          return {
+            // By default, only write native events when generating a cpu profile or using the v8 profiler.
+            shouldWriteNativeEvents: false,
+            performance: performance2,
+            PerformanceObserver: PerformanceObserver2
+          };
+        }
+      } catch {
+      }
+    }
   }
-
-  return aStr;
-}
-exports.toSetString = supportsNullProto ? identity : toSetString;
-
-function fromSetString(aStr) {
-  if (isProtoString(aStr)) {
-    return aStr.slice(1);
+  function tryGetNativePerformanceHooks() {
+    return nativePerformanceHooks;
   }
+  var nativePerformanceHooks, nativePerformance, timestamp;
+  var init_performanceCore = __esm({
+    "src/compiler/performanceCore.ts"() {
+      "use strict";
+      init_ts2();
+      nativePerformanceHooks = tryGetWebPerformanceHooks() || tryGetNodePerformanceHooks();
+      nativePerformance = nativePerformanceHooks == null ? void 0 : nativePerformanceHooks.performance;
+      timestamp = nativePerformance ? () => nativePerformance.now() : Date.now ? Date.now : () => +/* @__PURE__ */ new Date();
+    }
+  });
 
-  return aStr;
-}
-exports.fromSetString = supportsNullProto ? identity : fromSetString;
+  // src/compiler/perfLogger.ts
+  var etwModule, perfLogger;
+  var init_perfLogger = __esm({
+    "src/compiler/perfLogger.ts"() {
+      "use strict";
+      try {
+        const etwModulePath = process.env.TS_ETW_MODULE_PATH ?? "./node_modules/@microsoft/typescript-etw";
+        etwModule =   require(etwModulePath);
+      } catch (e) {
+        etwModule = void 0;
+      }
+      perfLogger = (etwModule == null ? void 0 : etwModule.logEvent) ? etwModule : void 0;
+    }
+  });
 
-function isProtoString(s) {
-  if (!s) {
-    return false;
+  // src/compiler/performance.ts
+  function createTimerIf(condition, measureName, startMarkName, endMarkName) {
+    return condition ? createTimer(measureName, startMarkName, endMarkName) : nullTimer;
   }
-
-  var length = s.length;
-
-  if (length < 9 /* "__proto__".length */) {
-    return false;
-  }
-
-  if (s.charCodeAt(length - 1) !== 95  /* '_' */ ||
-      s.charCodeAt(length - 2) !== 95  /* '_' */ ||
-      s.charCodeAt(length - 3) !== 111 /* 'o' */ ||
-      s.charCodeAt(length - 4) !== 116 /* 't' */ ||
-      s.charCodeAt(length - 5) !== 111 /* 'o' */ ||
-      s.charCodeAt(length - 6) !== 114 /* 'r' */ ||
-      s.charCodeAt(length - 7) !== 112 /* 'p' */ ||
-      s.charCodeAt(length - 8) !== 95  /* '_' */ ||
-      s.charCodeAt(length - 9) !== 95  /* '_' */) {
-    return false;
-  }
-
-  for (var i = length - 10; i >= 0; i--) {
-    if (s.charCodeAt(i) !== 36 /* '$' */) {
-      return false;
+  function createTimer(measureName, startMarkName, endMarkName) {
+    let enterCount = 0;
+    return {
+      enter,
+      exit
+    };
+    function enter() {
+      if (++enterCount === 1) {
+        mark(startMarkName);
+      }
     }
-  }
-
-  return true;
-}
-
-/**
- * Comparator between two mappings where the original positions are compared.
- *
- * Optionally pass in `true` as `onlyCompareGenerated` to consider two
- * mappings with the same original source/line/column, but different generated
- * line and column the same. Useful when searching for a mapping with a
- * stubbed out mapping.
- */
-function compareByOriginalPositions(mappingA, mappingB, onlyCompareOriginal) {
-  var cmp = strcmp(mappingA.source, mappingB.source);
-  if (cmp !== 0) {
-    return cmp;
-  }
-
-  cmp = mappingA.originalLine - mappingB.originalLine;
-  if (cmp !== 0) {
-    return cmp;
-  }
-
-  cmp = mappingA.originalColumn - mappingB.originalColumn;
-  if (cmp !== 0 || onlyCompareOriginal) {
-    return cmp;
-  }
-
-  cmp = mappingA.generatedColumn - mappingB.generatedColumn;
-  if (cmp !== 0) {
-    return cmp;
-  }
-
-  cmp = mappingA.generatedLine - mappingB.generatedLine;
-  if (cmp !== 0) {
-    return cmp;
-  }
-
-  return strcmp(mappingA.name, mappingB.name);
-}
-exports.compareByOriginalPositions = compareByOriginalPositions;
-
-/**
- * Comparator between two mappings with deflated source and name indices where
- * the generated positions are compared.
- *
- * Optionally pass in `true` as `onlyCompareGenerated` to consider two
- * mappings with the same generated line and column, but different
- * source/name/original line and column the same. Useful when searching for a
- * mapping with a stubbed out mapping.
- */
-function compareByGeneratedPositionsDeflated(mappingA, mappingB, onlyCompareGenerated) {
-  var cmp = mappingA.generatedLine - mappingB.generatedLine;
-  if (cmp !== 0) {
-    return cmp;
-  }
-
-  cmp = mappingA.generatedColumn - mappingB.generatedColumn;
-  if (cmp !== 0 || onlyCompareGenerated) {
-    return cmp;
-  }
-
-  cmp = strcmp(mappingA.source, mappingB.source);
-  if (cmp !== 0) {
-    return cmp;
-  }
-
-  cmp = mappingA.originalLine - mappingB.originalLine;
-  if (cmp !== 0) {
-    return cmp;
-  }
-
-  cmp = mappingA.originalColumn - mappingB.originalColumn;
-  if (cmp !== 0) {
-    return cmp;
-  }
-
-  return strcmp(mappingA.name, mappingB.name);
-}
-exports.compareByGeneratedPositionsDeflated = compareByGeneratedPositionsDeflated;
-
-function strcmp(aStr1, aStr2) {
-  if (aStr1 === aStr2) {
-    return 0;
-  }
-
-  if (aStr1 === null) {
-    return 1; // aStr2 !== null
-  }
-
-  if (aStr2 === null) {
-    return -1; // aStr1 !== null
-  }
-
-  if (aStr1 > aStr2) {
-    return 1;
-  }
-
-  return -1;
-}
-
-/**
- * Comparator between two mappings with inflated source and name strings where
- * the generated positions are compared.
- */
-function compareByGeneratedPositionsInflated(mappingA, mappingB) {
-  var cmp = mappingA.generatedLine - mappingB.generatedLine;
-  if (cmp !== 0) {
-    return cmp;
-  }
-
-  cmp = mappingA.generatedColumn - mappingB.generatedColumn;
-  if (cmp !== 0) {
-    return cmp;
-  }
-
-  cmp = strcmp(mappingA.source, mappingB.source);
-  if (cmp !== 0) {
-    return cmp;
-  }
-
-  cmp = mappingA.originalLine - mappingB.originalLine;
-  if (cmp !== 0) {
-    return cmp;
-  }
-
-  cmp = mappingA.originalColumn - mappingB.originalColumn;
-  if (cmp !== 0) {
-    return cmp;
-  }
-
-  return strcmp(mappingA.name, mappingB.name);
-}
-exports.compareByGeneratedPositionsInflated = compareByGeneratedPositionsInflated;
-
-/**
- * Strip any JSON XSSI avoidance prefix from the string (as documented
- * in the source maps specification), and then parse the string as
- * JSON.
- */
-function parseSourceMapInput(str) {
-  return JSON.parse(str.replace(/^\)]}'[^\n]*\n/, ''));
-}
-exports.parseSourceMapInput = parseSourceMapInput;
-
-/**
- * Compute the URL of a source given the the source root, the source's
- * URL, and the source map's URL.
- */
-function computeSourceURL(sourceRoot, sourceURL, sourceMapURL) {
-  sourceURL = sourceURL || '';
-
-  if (sourceRoot) {
-    // This follows what Chrome does.
-    if (sourceRoot[sourceRoot.length - 1] !== '/' && sourceURL[0] !== '/') {
-      sourceRoot += '/';
+    function exit() {
+      if (--enterCount === 0) {
+        mark(endMarkName);
+        measure(measureName, startMarkName, endMarkName);
+      } else if (enterCount < 0) {
+        Debug.fail("enter/exit count does not match.");
+      }
     }
-    // The spec says:
-    //   Line 4: An optional source root, useful for relocating source
-    //   files on a server or removing repeated values in the
-    //   “sources” entry.  This value is prepended to the individual
-    //   entries in the “source” field.
-    sourceURL = sourceRoot + sourceURL;
   }
-
-  // Historically, SourceMapConsumer did not take the sourceMapURL as
-  // a parameter.  This mode is still somewhat supported, which is why
-  // this code block is conditional.  However, it's preferable to pass
-  // the source map URL to SourceMapConsumer, so that this function
-  // can implement the source URL resolution algorithm as outlined in
-  // the spec.  This block is basically the equivalent of:
-  //    new URL(sourceURL, sourceMapURL).toString()
-  // ... except it avoids using URL, which wasn't available in the
-  // older releases of node still supported by this library.
-  //
-  // The spec says:
-  //   If the sources are not absolute URLs after prepending of the
-  //   “sourceRoot”, the sources are resolved relative to the
-  //   SourceMap (like resolving script src in a html document).
-  if (sourceMapURL) {
-    var parsed = urlParse(sourceMapURL);
-    if (!parsed) {
-      throw new Error("sourceMapURL could not be parsed");
-    }
-    if (parsed.path) {
-      // Strip the last path component, but keep the "/".
-      var index = parsed.path.lastIndexOf('/');
-      if (index >= 0) {
-        parsed.path = parsed.path.substring(0, index + 1);
+  function mark(markName) {
+    if (enabled) {
+      const count = counts.get(markName) ?? 0;
+      counts.set(markName, count + 1);
+      marks.set(markName, timestamp());
+      performanceImpl == null ? void 0 : performanceImpl.mark(markName);
+      if (typeof onProfilerEvent === "function") {
+        onProfilerEvent(markName);
       }
     }
-    sourceURL = join(urlGenerate(parsed), sourceURL);
-  }
-
-  return normalize(sourceURL);
-}
-exports.computeSourceURL = computeSourceURL;
-
-
-/***/ }),
-
-/***/ 36096:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
-
-/*
- * Copyright 2009-2011 Mozilla Foundation and contributors
- * Licensed under the New BSD license. See LICENSE.txt or:
- * http://opensource.org/licenses/BSD-3-Clause
- */
-/* unused reexport */ __nccwpck_require__(66677)/* .SourceMapGenerator */ .h;
-exports.SourceMapConsumer = __nccwpck_require__(52718).SourceMapConsumer;
-/* unused reexport */ __nccwpck_require__(3129);
-
-
-/***/ }),
-
-/***/ 32147:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
-
-"use strict";
-
-const stripAnsi = __nccwpck_require__(93847);
-const isFullwidthCodePoint = __nccwpck_require__(46766);
-const emojiRegex = __nccwpck_require__(77510);
-
-const stringWidth = string => {
-	if (typeof string !== 'string' || string.length === 0) {
-		return 0;
-	}
-
-	string = stripAnsi(string);
-
-	if (string.length === 0) {
-		return 0;
-	}
-
-	string = string.replace(emojiRegex(), '  ');
-
-	let width = 0;
-
-	for (let i = 0; i < string.length; i++) {
-		const code = string.codePointAt(i);
-
-		// Ignore control characters
-		if (code <= 0x1F || (code >= 0x7F && code <= 0x9F)) {
-			continue;
-		}
-
-		// Ignore combining characters
-		if (code >= 0x300 && code <= 0x36F) {
-			continue;
-		}
-
-		// Surrogates
-		if (code > 0xFFFF) {
-			i++;
-		}
-
-		width += isFullwidthCodePoint(code) ? 2 : 1;
-	}
-
-	return width;
-};
-
-module.exports = stringWidth;
-// TODO: remove this in the next major version
-module.exports["default"] = stringWidth;
-
-
-/***/ }),
-
-/***/ 26590:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
-
-"use strict";
-// Copyright Joyent, Inc. and other Node contributors.
-//
-// 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.
-
-
-
-/**/
-
-var Buffer = (__nccwpck_require__(87128).Buffer);
-/**/
-
-var isEncoding = Buffer.isEncoding || function (encoding) {
-  encoding = '' + encoding;
-  switch (encoding && encoding.toLowerCase()) {
-    case 'hex':case 'utf8':case 'utf-8':case 'ascii':case 'binary':case 'base64':case 'ucs2':case 'ucs-2':case 'utf16le':case 'utf-16le':case 'raw':
-      return true;
-    default:
-      return false;
   }
-};
-
-function _normalizeEncoding(enc) {
-  if (!enc) return 'utf8';
-  var retried;
-  while (true) {
-    switch (enc) {
-      case 'utf8':
-      case 'utf-8':
-        return 'utf8';
-      case 'ucs2':
-      case 'ucs-2':
-      case 'utf16le':
-      case 'utf-16le':
-        return 'utf16le';
-      case 'latin1':
-      case 'binary':
-        return 'latin1';
-      case 'base64':
-      case 'ascii':
-      case 'hex':
-        return enc;
-      default:
-        if (retried) return; // undefined
-        enc = ('' + enc).toLowerCase();
-        retried = true;
+  function measure(measureName, startMarkName, endMarkName) {
+    if (enabled) {
+      const end = (endMarkName !== void 0 ? marks.get(endMarkName) : void 0) ?? timestamp();
+      const start = (startMarkName !== void 0 ? marks.get(startMarkName) : void 0) ?? timeorigin;
+      const previousDuration = durations.get(measureName) || 0;
+      durations.set(measureName, previousDuration + (end - start));
+      performanceImpl == null ? void 0 : performanceImpl.measure(measureName, startMarkName, endMarkName);
     }
   }
-};
-
-// Do not cache `Buffer.isEncoding` when checking encoding names as some
-// modules monkey-patch it to support additional encodings
-function normalizeEncoding(enc) {
-  var nenc = _normalizeEncoding(enc);
-  if (typeof nenc !== 'string' && (Buffer.isEncoding === isEncoding || !isEncoding(enc))) throw new Error('Unknown encoding: ' + enc);
-  return nenc || enc;
-}
-
-// StringDecoder provides an interface for efficiently splitting a series of
-// buffers into a series of JS strings without breaking apart multi-byte
-// characters.
-exports.s = StringDecoder;
-function StringDecoder(encoding) {
-  this.encoding = normalizeEncoding(encoding);
-  var nb;
-  switch (this.encoding) {
-    case 'utf16le':
-      this.text = utf16Text;
-      this.end = utf16End;
-      nb = 4;
-      break;
-    case 'utf8':
-      this.fillLast = utf8FillLast;
-      nb = 4;
-      break;
-    case 'base64':
-      this.text = base64Text;
-      this.end = base64End;
-      nb = 3;
-      break;
-    default:
-      this.write = simpleWrite;
-      this.end = simpleEnd;
-      return;
+  function getCount(markName) {
+    return counts.get(markName) || 0;
   }
-  this.lastNeed = 0;
-  this.lastTotal = 0;
-  this.lastChar = Buffer.allocUnsafe(nb);
-}
-
-StringDecoder.prototype.write = function (buf) {
-  if (buf.length === 0) return '';
-  var r;
-  var i;
-  if (this.lastNeed) {
-    r = this.fillLast(buf);
-    if (r === undefined) return '';
-    i = this.lastNeed;
-    this.lastNeed = 0;
-  } else {
-    i = 0;
+  function getDuration(measureName) {
+    return durations.get(measureName) || 0;
   }
-  if (i < buf.length) return r ? r + this.text(buf, i) : this.text(buf, i);
-  return r || '';
-};
-
-StringDecoder.prototype.end = utf8End;
-
-// Returns only complete characters in a Buffer
-StringDecoder.prototype.text = utf8Text;
-
-// Attempts to complete a partial non-UTF-8 character using bytes from a Buffer
-StringDecoder.prototype.fillLast = function (buf) {
-  if (this.lastNeed <= buf.length) {
-    buf.copy(this.lastChar, this.lastTotal - this.lastNeed, 0, this.lastNeed);
-    return this.lastChar.toString(this.encoding, 0, this.lastTotal);
+  function forEachMeasure(cb) {
+    durations.forEach((duration, measureName) => cb(measureName, duration));
   }
-  buf.copy(this.lastChar, this.lastTotal - this.lastNeed, 0, buf.length);
-  this.lastNeed -= buf.length;
-};
-
-// Checks the type of a UTF-8 byte, whether it's ASCII, a leading byte, or a
-// continuation byte. If an invalid byte is detected, -2 is returned.
-function utf8CheckByte(byte) {
-  if (byte <= 0x7F) return 0;else if (byte >> 5 === 0x06) return 2;else if (byte >> 4 === 0x0E) return 3;else if (byte >> 3 === 0x1E) return 4;
-  return byte >> 6 === 0x02 ? -1 : -2;
-}
-
-// Checks at most 3 bytes at the end of a Buffer in order to detect an
-// incomplete multi-byte UTF-8 character. The total number of bytes (2, 3, or 4)
-// needed to complete the UTF-8 character (if applicable) are returned.
-function utf8CheckIncomplete(self, buf, i) {
-  var j = buf.length - 1;
-  if (j < i) return 0;
-  var nb = utf8CheckByte(buf[j]);
-  if (nb >= 0) {
-    if (nb > 0) self.lastNeed = nb - 1;
-    return nb;
+  function forEachMark(cb) {
+    marks.forEach((_time, markName) => cb(markName));
   }
-  if (--j < i || nb === -2) return 0;
-  nb = utf8CheckByte(buf[j]);
-  if (nb >= 0) {
-    if (nb > 0) self.lastNeed = nb - 2;
-    return nb;
+  function clearMeasures(name) {
+    if (name !== void 0)
+      durations.delete(name);
+    else
+      durations.clear();
+    performanceImpl == null ? void 0 : performanceImpl.clearMeasures(name);
   }
-  if (--j < i || nb === -2) return 0;
-  nb = utf8CheckByte(buf[j]);
-  if (nb >= 0) {
-    if (nb > 0) {
-      if (nb === 2) nb = 0;else self.lastNeed = nb - 3;
+  function clearMarks(name) {
+    if (name !== void 0) {
+      counts.delete(name);
+      marks.delete(name);
+    } else {
+      counts.clear();
+      marks.clear();
     }
-    return nb;
+    performanceImpl == null ? void 0 : performanceImpl.clearMarks(name);
   }
-  return 0;
-}
-
-// Validates as many continuation bytes for a multi-byte UTF-8 character as
-// needed or are available. If we see a non-continuation byte where we expect
-// one, we "replace" the validated continuation bytes we've seen so far with
-// a single UTF-8 replacement character ('\ufffd'), to match v8's UTF-8 decoding
-// behavior. The continuation byte check is included three times in the case
-// where all of the continuation bytes for a character exist in the same buffer.
-// It is also done this way as a slight performance increase instead of using a
-// loop.
-function utf8CheckExtraBytes(self, buf, p) {
-  if ((buf[0] & 0xC0) !== 0x80) {
-    self.lastNeed = 0;
-    return '\ufffd';
+  function isEnabled() {
+    return enabled;
   }
-  if (self.lastNeed > 1 && buf.length > 1) {
-    if ((buf[1] & 0xC0) !== 0x80) {
-      self.lastNeed = 1;
-      return '\ufffd';
-    }
-    if (self.lastNeed > 2 && buf.length > 2) {
-      if ((buf[2] & 0xC0) !== 0x80) {
-        self.lastNeed = 2;
-        return '\ufffd';
+  function enable(system = sys) {
+    var _a;
+    if (!enabled) {
+      enabled = true;
+      perfHooks || (perfHooks = tryGetNativePerformanceHooks());
+      if (perfHooks) {
+        timeorigin = perfHooks.performance.timeOrigin;
+        if (perfHooks.shouldWriteNativeEvents || ((_a = system == null ? void 0 : system.cpuProfilingEnabled) == null ? void 0 : _a.call(system)) || (system == null ? void 0 : system.debugMode)) {
+          performanceImpl = perfHooks.performance;
+        }
       }
     }
+    return true;
   }
-}
-
-// Attempts to complete a multi-byte UTF-8 character using bytes from a Buffer.
-function utf8FillLast(buf) {
-  var p = this.lastTotal - this.lastNeed;
-  var r = utf8CheckExtraBytes(this, buf, p);
-  if (r !== undefined) return r;
-  if (this.lastNeed <= buf.length) {
-    buf.copy(this.lastChar, p, 0, this.lastNeed);
-    return this.lastChar.toString(this.encoding, 0, this.lastTotal);
-  }
-  buf.copy(this.lastChar, p, 0, buf.length);
-  this.lastNeed -= buf.length;
-}
-
-// Returns all complete UTF-8 characters in a Buffer. If the Buffer ended on a
-// partial character, the character's bytes are buffered until the required
-// number of bytes are available.
-function utf8Text(buf, i) {
-  var total = utf8CheckIncomplete(this, buf, i);
-  if (!this.lastNeed) return buf.toString('utf8', i);
-  this.lastTotal = total;
-  var end = buf.length - (total - this.lastNeed);
-  buf.copy(this.lastChar, 0, end);
-  return buf.toString('utf8', i, end);
-}
-
-// For UTF-8, a replacement character is added when ending on a partial
-// character.
-function utf8End(buf) {
-  var r = buf && buf.length ? this.write(buf) : '';
-  if (this.lastNeed) return r + '\ufffd';
-  return r;
-}
-
-// UTF-16LE typically needs two bytes per character, but even if we have an even
-// number of bytes available, we need to check if we end on a leading/high
-// surrogate. In that case, we need to wait for the next two bytes in order to
-// decode the last character properly.
-function utf16Text(buf, i) {
-  if ((buf.length - i) % 2 === 0) {
-    var r = buf.toString('utf16le', i);
-    if (r) {
-      var c = r.charCodeAt(r.length - 1);
-      if (c >= 0xD800 && c <= 0xDBFF) {
-        this.lastNeed = 2;
-        this.lastTotal = 4;
-        this.lastChar[0] = buf[buf.length - 2];
-        this.lastChar[1] = buf[buf.length - 1];
-        return r.slice(0, -1);
-      }
+  function disable() {
+    if (enabled) {
+      marks.clear();
+      counts.clear();
+      durations.clear();
+      performanceImpl = void 0;
+      enabled = false;
     }
-    return r;
-  }
-  this.lastNeed = 1;
-  this.lastTotal = 2;
-  this.lastChar[0] = buf[buf.length - 1];
-  return buf.toString('utf16le', i, buf.length - 1);
-}
-
-// For UTF-16LE we do not explicitly append special replacement characters if we
-// end on a partial character, we simply let v8 handle that.
-function utf16End(buf) {
-  var r = buf && buf.length ? this.write(buf) : '';
-  if (this.lastNeed) {
-    var end = this.lastTotal - this.lastNeed;
-    return r + this.lastChar.toString('utf16le', 0, end);
-  }
-  return r;
-}
-
-function base64Text(buf, i) {
-  var n = (buf.length - i) % 3;
-  if (n === 0) return buf.toString('base64', i);
-  this.lastNeed = 3 - n;
-  this.lastTotal = 3;
-  if (n === 1) {
-    this.lastChar[0] = buf[buf.length - 1];
-  } else {
-    this.lastChar[0] = buf[buf.length - 2];
-    this.lastChar[1] = buf[buf.length - 1];
-  }
-  return buf.toString('base64', i, buf.length - n);
-}
-
-function base64End(buf) {
-  var r = buf && buf.length ? this.write(buf) : '';
-  if (this.lastNeed) return r + this.lastChar.toString('base64', 0, 3 - this.lastNeed);
-  return r;
-}
-
-// Pass bytes on through for single-byte encodings (e.g. ascii, latin1, hex)
-function simpleWrite(buf) {
-  return buf.toString(this.encoding);
-}
-
-function simpleEnd(buf) {
-  return buf && buf.length ? this.write(buf) : '';
-}
-
-/***/ }),
-
-/***/ 93847:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
-
-"use strict";
-
-const ansiRegex = __nccwpck_require__(67752);
-
-module.exports = string => typeof string === 'string' ? string.replace(ansiRegex(), '') : string;
-
-
-/***/ }),
-
-/***/ 67752:
-/***/ ((module) => {
-
-"use strict";
-
-
-module.exports = ({onlyFirst = false} = {}) => {
-	const pattern = [
-		'[\\u001B\\u009B][[\\]()#;?]*(?:(?:(?:(?:;[-a-zA-Z\\d\\/#&.:=?%@~_]+)*|[a-zA-Z\\d]+(?:;[-a-zA-Z\\d\\/#&.:=?%@~_]*)*)?\\u0007)',
-		'(?:(?:\\d{1,4}(?:;\\d{0,4})*)?[\\dA-PR-TZcf-ntqry=><~]))'
-	].join('|');
-
-	return new RegExp(pattern, onlyFirst ? undefined : 'g');
-};
-
-
-/***/ }),
-
-/***/ 22196:
-/***/ ((module) => {
-
-"use strict";
-
-module.exports = x => {
-	if (typeof x !== 'string') {
-		throw new TypeError('Expected a string, got ' + typeof x);
-	}
-
-	// Catches EFBBBF (UTF-8 BOM) because the buffer-to-string
-	// conversion translates it to FEFF (UTF-16 BOM)
-	if (x.charCodeAt(0) === 0xFEFF) {
-		return x.slice(1);
-	}
-
-	return x;
-};
-
-
-/***/ }),
-
-/***/ 9679:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
-
-"use strict";
-
-const os = __nccwpck_require__(22037);
-const tty = __nccwpck_require__(76224);
-const hasFlag = __nccwpck_require__(97);
-
-const {env} = process;
-
-let forceColor;
-if (hasFlag('no-color') ||
-	hasFlag('no-colors') ||
-	hasFlag('color=false') ||
-	hasFlag('color=never')) {
-	forceColor = 0;
-} else if (hasFlag('color') ||
-	hasFlag('colors') ||
-	hasFlag('color=true') ||
-	hasFlag('color=always')) {
-	forceColor = 1;
-}
-
-if ('FORCE_COLOR' in env) {
-	if (env.FORCE_COLOR === 'true') {
-		forceColor = 1;
-	} else if (env.FORCE_COLOR === 'false') {
-		forceColor = 0;
-	} else {
-		forceColor = env.FORCE_COLOR.length === 0 ? 1 : Math.min(parseInt(env.FORCE_COLOR, 10), 3);
-	}
-}
-
-function translateLevel(level) {
-	if (level === 0) {
-		return false;
-	}
-
-	return {
-		level,
-		hasBasic: true,
-		has256: level >= 2,
-		has16m: level >= 3
-	};
-}
-
-function supportsColor(haveStream, streamIsTTY) {
-	if (forceColor === 0) {
-		return 0;
-	}
-
-	if (hasFlag('color=16m') ||
-		hasFlag('color=full') ||
-		hasFlag('color=truecolor')) {
-		return 3;
-	}
-
-	if (hasFlag('color=256')) {
-		return 2;
-	}
-
-	if (haveStream && !streamIsTTY && forceColor === undefined) {
-		return 0;
-	}
-
-	const min = forceColor || 0;
-
-	if (env.TERM === 'dumb') {
-		return min;
-	}
-
-	if (process.platform === 'win32') {
-		// Windows 10 build 10586 is the first Windows release that supports 256 colors.
-		// Windows 10 build 14931 is the first release that supports 16m/TrueColor.
-		const osRelease = os.release().split('.');
-		if (
-			Number(osRelease[0]) >= 10 &&
-			Number(osRelease[2]) >= 10586
-		) {
-			return Number(osRelease[2]) >= 14931 ? 3 : 2;
-		}
-
-		return 1;
-	}
-
-	if ('CI' in env) {
-		if (['TRAVIS', 'CIRCLECI', 'APPVEYOR', 'GITLAB_CI', 'GITHUB_ACTIONS', 'BUILDKITE'].some(sign => sign in env) || env.CI_NAME === 'codeship') {
-			return 1;
-		}
-
-		return min;
-	}
-
-	if ('TEAMCITY_VERSION' in env) {
-		return /^(9\.(0*[1-9]\d*)\.|\d{2,}\.)/.test(env.TEAMCITY_VERSION) ? 1 : 0;
-	}
-
-	if (env.COLORTERM === 'truecolor') {
-		return 3;
-	}
-
-	if ('TERM_PROGRAM' in env) {
-		const version = parseInt((env.TERM_PROGRAM_VERSION || '').split('.')[0], 10);
-
-		switch (env.TERM_PROGRAM) {
-			case 'iTerm.app':
-				return version >= 3 ? 3 : 2;
-			case 'Apple_Terminal':
-				return 2;
-			// No default
-		}
-	}
-
-	if (/-256(color)?$/i.test(env.TERM)) {
-		return 2;
-	}
-
-	if (/^screen|^xterm|^vt100|^vt220|^rxvt|color|ansi|cygwin|linux/i.test(env.TERM)) {
-		return 1;
-	}
-
-	if ('COLORTERM' in env) {
-		return 1;
-	}
-
-	return min;
-}
-
-function getSupportLevel(stream) {
-	const level = supportsColor(stream, stream && stream.isTTY);
-	return translateLevel(level);
-}
-
-module.exports = {
-	supportsColor: getSupportLevel,
-	stdout: translateLevel(supportsColor(true, tty.isatty(1))),
-	stderr: translateLevel(supportsColor(true, tty.isatty(2)))
-};
-
-
-/***/ }),
-
-/***/ 57218:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
-
-var util = __nccwpck_require__(73837)
-var bl = __nccwpck_require__(1236)
-var headers = __nccwpck_require__(82249)
-
-var Writable = (__nccwpck_require__(88550).Writable)
-var PassThrough = (__nccwpck_require__(88550).PassThrough)
-
-var noop = function () {}
-
-var overflow = function (size) {
-  size &= 511
-  return size && 512 - size
-}
-
-var emptyStream = function (self, offset) {
-  var s = new Source(self, offset)
-  s.end()
-  return s
-}
-
-var mixinPax = function (header, pax) {
-  if (pax.path) header.name = pax.path
-  if (pax.linkpath) header.linkname = pax.linkpath
-  if (pax.size) header.size = parseInt(pax.size, 10)
-  header.pax = pax
-  return header
-}
-
-var Source = function (self, offset) {
-  this._parent = self
-  this.offset = offset
-  PassThrough.call(this, { autoDestroy: false })
-}
-
-util.inherits(Source, PassThrough)
-
-Source.prototype.destroy = function (err) {
-  this._parent.destroy(err)
-}
-
-var Extract = function (opts) {
-  if (!(this instanceof Extract)) return new Extract(opts)
-  Writable.call(this, opts)
-
-  opts = opts || {}
-
-  this._offset = 0
-  this._buffer = bl()
-  this._missing = 0
-  this._partial = false
-  this._onparse = noop
-  this._header = null
-  this._stream = null
-  this._overflow = null
-  this._cb = null
-  this._locked = false
-  this._destroyed = false
-  this._pax = null
-  this._paxGlobal = null
-  this._gnuLongPath = null
-  this._gnuLongLinkPath = null
-
-  var self = this
-  var b = self._buffer
-
-  var oncontinue = function () {
-    self._continue()
-  }
-
-  var onunlock = function (err) {
-    self._locked = false
-    if (err) return self.destroy(err)
-    if (!self._stream) oncontinue()
-  }
-
-  var onstreamend = function () {
-    self._stream = null
-    var drain = overflow(self._header.size)
-    if (drain) self._parse(drain, ondrain)
-    else self._parse(512, onheader)
-    if (!self._locked) oncontinue()
-  }
-
-  var ondrain = function () {
-    self._buffer.consume(overflow(self._header.size))
-    self._parse(512, onheader)
-    oncontinue()
-  }
-
-  var onpaxglobalheader = function () {
-    var size = self._header.size
-    self._paxGlobal = headers.decodePax(b.slice(0, size))
-    b.consume(size)
-    onstreamend()
-  }
-
-  var onpaxheader = function () {
-    var size = self._header.size
-    self._pax = headers.decodePax(b.slice(0, size))
-    if (self._paxGlobal) self._pax = Object.assign({}, self._paxGlobal, self._pax)
-    b.consume(size)
-    onstreamend()
-  }
-
-  var ongnulongpath = function () {
-    var size = self._header.size
-    this._gnuLongPath = headers.decodeLongPath(b.slice(0, size), opts.filenameEncoding)
-    b.consume(size)
-    onstreamend()
   }
-
-  var ongnulonglinkpath = function () {
-    var size = self._header.size
-    this._gnuLongLinkPath = headers.decodeLongPath(b.slice(0, size), opts.filenameEncoding)
-    b.consume(size)
-    onstreamend()
-  }
-
-  var onheader = function () {
-    var offset = self._offset
-    var header
-    try {
-      header = self._header = headers.decode(b.slice(0, 512), opts.filenameEncoding, opts.allowUnknownFormat)
-    } catch (err) {
-      self.emit('error', err)
-    }
-    b.consume(512)
-
-    if (!header) {
-      self._parse(512, onheader)
-      oncontinue()
-      return
-    }
-    if (header.type === 'gnu-long-path') {
-      self._parse(header.size, ongnulongpath)
-      oncontinue()
-      return
-    }
-    if (header.type === 'gnu-long-link-path') {
-      self._parse(header.size, ongnulonglinkpath)
-      oncontinue()
-      return
-    }
-    if (header.type === 'pax-global-header') {
-      self._parse(header.size, onpaxglobalheader)
-      oncontinue()
-      return
-    }
-    if (header.type === 'pax-header') {
-      self._parse(header.size, onpaxheader)
-      oncontinue()
-      return
-    }
-
-    if (self._gnuLongPath) {
-      header.name = self._gnuLongPath
-      self._gnuLongPath = null
+  var perfHooks, performanceImpl, nullTimer, enabled, timeorigin, marks, counts, durations;
+  var init_performance = __esm({
+    "src/compiler/performance.ts"() {
+      "use strict";
+      init_ts2();
+      nullTimer = { enter: noop, exit: noop };
+      enabled = false;
+      timeorigin = timestamp();
+      marks = /* @__PURE__ */ new Map();
+      counts = /* @__PURE__ */ new Map();
+      durations = /* @__PURE__ */ new Map();
     }
+  });
 
-    if (self._gnuLongLinkPath) {
-      header.linkname = self._gnuLongLinkPath
-      self._gnuLongLinkPath = null
+  // src/compiler/_namespaces/ts.performance.ts
+  var ts_performance_exports = {};
+  __export(ts_performance_exports, {
+    clearMarks: () => clearMarks,
+    clearMeasures: () => clearMeasures,
+    createTimer: () => createTimer,
+    createTimerIf: () => createTimerIf,
+    disable: () => disable,
+    enable: () => enable,
+    forEachMark: () => forEachMark,
+    forEachMeasure: () => forEachMeasure,
+    getCount: () => getCount,
+    getDuration: () => getDuration,
+    isEnabled: () => isEnabled,
+    mark: () => mark,
+    measure: () => measure,
+    nullTimer: () => nullTimer
+  });
+  var init_ts_performance = __esm({
+    "src/compiler/_namespaces/ts.performance.ts"() {
+      "use strict";
+      init_performance();
     }
+  });
 
-    if (self._pax) {
-      self._header = header = mixinPax(header, self._pax)
-      self._pax = null
-    }
-
-    self._locked = true
-
-    if (!header.size || header.type === 'directory') {
-      self._parse(512, onheader)
-      self.emit('entry', header, emptyStream(self, offset), onunlock)
-      return
-    }
-
-    self._stream = new Source(self, offset)
-
-    self.emit('entry', header, self._stream, onunlock)
-    self._parse(header.size, onstreamend)
-    oncontinue()
-  }
-
-  this._onheader = onheader
-  this._parse(512, onheader)
-}
-
-util.inherits(Extract, Writable)
-
-Extract.prototype.destroy = function (err) {
-  if (this._destroyed) return
-  this._destroyed = true
-
-  if (err) this.emit('error', err)
-  this.emit('close')
-  if (this._stream) this._stream.emit('close')
-}
-
-Extract.prototype._parse = function (size, onparse) {
-  if (this._destroyed) return
-  this._offset += size
-  this._missing = size
-  if (onparse === this._onheader) this._partial = false
-  this._onparse = onparse
-}
-
-Extract.prototype._continue = function () {
-  if (this._destroyed) return
-  var cb = this._cb
-  this._cb = noop
-  if (this._overflow) this._write(this._overflow, undefined, cb)
-  else cb()
-}
-
-Extract.prototype._write = function (data, enc, cb) {
-  if (this._destroyed) return
-
-  var s = this._stream
-  var b = this._buffer
-  var missing = this._missing
-  if (data.length) this._partial = true
-
-  // we do not reach end-of-chunk now. just forward it
-
-  if (data.length < missing) {
-    this._missing -= data.length
-    this._overflow = null
-    if (s) return s.write(data, cb)
-    b.append(data)
-    return cb()
-  }
-
-  // end-of-chunk. the parser should call cb.
-
-  this._cb = cb
-  this._missing = 0
-
-  var overflow = null
-  if (data.length > missing) {
-    overflow = data.slice(missing)
-    data = data.slice(0, missing)
-  }
-
-  if (s) s.end(data)
-  else b.append(data)
-
-  this._overflow = overflow
-  this._onparse()
-}
-
-Extract.prototype._final = function (cb) {
-  if (this._partial) return this.destroy(new Error('Unexpected end of data'))
-  cb()
-}
-
-module.exports = Extract
-
-
-/***/ }),
-
-/***/ 82249:
-/***/ ((__unused_webpack_module, exports) => {
-
-var alloc = Buffer.alloc
-
-var ZEROS = '0000000000000000000'
-var SEVENS = '7777777777777777777'
-var ZERO_OFFSET = '0'.charCodeAt(0)
-var USTAR_MAGIC = Buffer.from('ustar\x00', 'binary')
-var USTAR_VER = Buffer.from('00', 'binary')
-var GNU_MAGIC = Buffer.from('ustar\x20', 'binary')
-var GNU_VER = Buffer.from('\x20\x00', 'binary')
-var MASK = parseInt('7777', 8)
-var MAGIC_OFFSET = 257
-var VERSION_OFFSET = 263
-
-var clamp = function (index, len, defaultValue) {
-  if (typeof index !== 'number') return defaultValue
-  index = ~~index // Coerce to integer.
-  if (index >= len) return len
-  if (index >= 0) return index
-  index += len
-  if (index >= 0) return index
-  return 0
-}
-
-var toType = function (flag) {
-  switch (flag) {
-    case 0:
-      return 'file'
-    case 1:
-      return 'link'
-    case 2:
-      return 'symlink'
-    case 3:
-      return 'character-device'
-    case 4:
-      return 'block-device'
-    case 5:
-      return 'directory'
-    case 6:
-      return 'fifo'
-    case 7:
-      return 'contiguous-file'
-    case 72:
-      return 'pax-header'
-    case 55:
-      return 'pax-global-header'
-    case 27:
-      return 'gnu-long-link-path'
-    case 28:
-    case 30:
-      return 'gnu-long-path'
-  }
-
-  return null
-}
-
-var toTypeflag = function (flag) {
-  switch (flag) {
-    case 'file':
-      return 0
-    case 'link':
-      return 1
-    case 'symlink':
-      return 2
-    case 'character-device':
-      return 3
-    case 'block-device':
-      return 4
-    case 'directory':
-      return 5
-    case 'fifo':
-      return 6
-    case 'contiguous-file':
-      return 7
-    case 'pax-header':
-      return 72
-  }
-
-  return 0
-}
-
-var indexOf = function (block, num, offset, end) {
-  for (; offset < end; offset++) {
-    if (block[offset] === num) return offset
-  }
-  return end
-}
-
-var cksum = function (block) {
-  var sum = 8 * 32
-  for (var i = 0; i < 148; i++) sum += block[i]
-  for (var j = 156; j < 512; j++) sum += block[j]
-  return sum
-}
-
-var encodeOct = function (val, n) {
-  val = val.toString(8)
-  if (val.length > n) return SEVENS.slice(0, n) + ' '
-  else return ZEROS.slice(0, n - val.length) + val + ' '
-}
-
-/* Copied from the node-tar repo and modified to meet
- * tar-stream coding standard.
- *
- * Source: https://github.com/npm/node-tar/blob/51b6627a1f357d2eb433e7378e5f05e83b7aa6cd/lib/header.js#L349
- */
-function parse256 (buf) {
-  // first byte MUST be either 80 or FF
-  // 80 for positive, FF for 2's comp
-  var positive
-  if (buf[0] === 0x80) positive = true
-  else if (buf[0] === 0xFF) positive = false
-  else return null
-
-  // build up a base-256 tuple from the least sig to the highest
-  var tuple = []
-  for (var i = buf.length - 1; i > 0; i--) {
-    var byte = buf[i]
-    if (positive) tuple.push(byte)
-    else tuple.push(0xFF - byte)
-  }
-
-  var sum = 0
-  var l = tuple.length
-  for (i = 0; i < l; i++) {
-    sum += tuple[i] * Math.pow(256, i)
-  }
-
-  return positive ? sum : -1 * sum
-}
-
-var decodeOct = function (val, offset, length) {
-  val = val.slice(offset, offset + length)
-  offset = 0
-
-  // If prefixed with 0x80 then parse as a base-256 integer
-  if (val[offset] & 0x80) {
-    return parse256(val)
-  } else {
-    // Older versions of tar can prefix with spaces
-    while (offset < val.length && val[offset] === 32) offset++
-    var end = clamp(indexOf(val, 32, offset, val.length), val.length, val.length)
-    while (offset < end && val[offset] === 0) offset++
-    if (end === offset) return 0
-    return parseInt(val.slice(offset, end).toString(), 8)
-  }
-}
-
-var decodeStr = function (val, offset, length, encoding) {
-  return val.slice(offset, indexOf(val, 0, offset, offset + length)).toString(encoding)
-}
-
-var addLength = function (str) {
-  var len = Buffer.byteLength(str)
-  var digits = Math.floor(Math.log(len) / Math.log(10)) + 1
-  if (len + digits >= Math.pow(10, digits)) digits++
-
-  return (len + digits) + str
-}
-
-exports.decodeLongPath = function (buf, encoding) {
-  return decodeStr(buf, 0, buf.length, encoding)
-}
-
-exports.encodePax = function (opts) { // TODO: encode more stuff in pax
-  var result = ''
-  if (opts.name) result += addLength(' path=' + opts.name + '\n')
-  if (opts.linkname) result += addLength(' linkpath=' + opts.linkname + '\n')
-  var pax = opts.pax
-  if (pax) {
-    for (var key in pax) {
-      result += addLength(' ' + key + '=' + pax[key] + '\n')
-    }
-  }
-  return Buffer.from(result)
-}
-
-exports.decodePax = function (buf) {
-  var result = {}
-
-  while (buf.length) {
-    var i = 0
-    while (i < buf.length && buf[i] !== 32) i++
-    var len = parseInt(buf.slice(0, i).toString(), 10)
-    if (!len) return result
-
-    var b = buf.slice(i + 1, len - 1).toString()
-    var keyIndex = b.indexOf('=')
-    if (keyIndex === -1) return result
-    result[b.slice(0, keyIndex)] = b.slice(keyIndex + 1)
-
-    buf = buf.slice(len)
-  }
-
-  return result
-}
-
-exports.encode = function (opts) {
-  var buf = alloc(512)
-  var name = opts.name
-  var prefix = ''
-
-  if (opts.typeflag === 5 && name[name.length - 1] !== '/') name += '/'
-  if (Buffer.byteLength(name) !== name.length) return null // utf-8
-
-  while (Buffer.byteLength(name) > 100) {
-    var i = name.indexOf('/')
-    if (i === -1) return null
-    prefix += prefix ? '/' + name.slice(0, i) : name.slice(0, i)
-    name = name.slice(i + 1)
-  }
-
-  if (Buffer.byteLength(name) > 100 || Buffer.byteLength(prefix) > 155) return null
-  if (opts.linkname && Buffer.byteLength(opts.linkname) > 100) return null
-
-  buf.write(name)
-  buf.write(encodeOct(opts.mode & MASK, 6), 100)
-  buf.write(encodeOct(opts.uid, 6), 108)
-  buf.write(encodeOct(opts.gid, 6), 116)
-  buf.write(encodeOct(opts.size, 11), 124)
-  buf.write(encodeOct((opts.mtime.getTime() / 1000) | 0, 11), 136)
-
-  buf[156] = ZERO_OFFSET + toTypeflag(opts.type)
-
-  if (opts.linkname) buf.write(opts.linkname, 157)
-
-  USTAR_MAGIC.copy(buf, MAGIC_OFFSET)
-  USTAR_VER.copy(buf, VERSION_OFFSET)
-  if (opts.uname) buf.write(opts.uname, 265)
-  if (opts.gname) buf.write(opts.gname, 297)
-  buf.write(encodeOct(opts.devmajor || 0, 6), 329)
-  buf.write(encodeOct(opts.devminor || 0, 6), 337)
-
-  if (prefix) buf.write(prefix, 345)
-
-  buf.write(encodeOct(cksum(buf), 6), 148)
-
-  return buf
-}
-
-exports.decode = function (buf, filenameEncoding, allowUnknownFormat) {
-  var typeflag = buf[156] === 0 ? 0 : buf[156] - ZERO_OFFSET
-
-  var name = decodeStr(buf, 0, 100, filenameEncoding)
-  var mode = decodeOct(buf, 100, 8)
-  var uid = decodeOct(buf, 108, 8)
-  var gid = decodeOct(buf, 116, 8)
-  var size = decodeOct(buf, 124, 12)
-  var mtime = decodeOct(buf, 136, 12)
-  var type = toType(typeflag)
-  var linkname = buf[157] === 0 ? null : decodeStr(buf, 157, 100, filenameEncoding)
-  var uname = decodeStr(buf, 265, 32)
-  var gname = decodeStr(buf, 297, 32)
-  var devmajor = decodeOct(buf, 329, 8)
-  var devminor = decodeOct(buf, 337, 8)
-
-  var c = cksum(buf)
-
-  // checksum is still initial value if header was null.
-  if (c === 8 * 32) return null
-
-  // valid checksum
-  if (c !== decodeOct(buf, 148, 8)) throw new Error('Invalid tar header. Maybe the tar is corrupted or it needs to be gunzipped?')
-
-  if (USTAR_MAGIC.compare(buf, MAGIC_OFFSET, MAGIC_OFFSET + 6) === 0) {
-    // ustar (posix) format.
-    // prepend prefix, if present.
-    if (buf[345]) name = decodeStr(buf, 345, 155, filenameEncoding) + '/' + name
-  } else if (GNU_MAGIC.compare(buf, MAGIC_OFFSET, MAGIC_OFFSET + 6) === 0 &&
-             GNU_VER.compare(buf, VERSION_OFFSET, VERSION_OFFSET + 2) === 0) {
-    // 'gnu'/'oldgnu' format. Similar to ustar, but has support for incremental and
-    // multi-volume tarballs.
-  } else {
-    if (!allowUnknownFormat) {
-      throw new Error('Invalid tar header: unknown format.')
-    }
-  }
-
-  // to support old tar versions that use trailing / to indicate dirs
-  if (typeflag === 0 && name && name[name.length - 1] === '/') typeflag = 5
-
-  return {
-    name,
-    mode,
-    uid,
-    gid,
-    size,
-    mtime: new Date(1000 * mtime),
-    type,
-    linkname,
-    uname,
-    gname,
-    devmajor,
-    devminor
-  }
-}
-
-
-/***/ }),
-
-/***/ 93983:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
-
-exports.extract = __nccwpck_require__(57218)
-exports.pack = __nccwpck_require__(89766)
-
-
-/***/ }),
-
-/***/ 89766:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
-
-var constants = __nccwpck_require__(21978)
-var eos = __nccwpck_require__(69867)
-var inherits = __nccwpck_require__(2868)
-var alloc = Buffer.alloc
-
-var Readable = (__nccwpck_require__(88550).Readable)
-var Writable = (__nccwpck_require__(88550).Writable)
-var StringDecoder = (__nccwpck_require__(71576).StringDecoder)
-
-var headers = __nccwpck_require__(82249)
-
-var DMODE = parseInt('755', 8)
-var FMODE = parseInt('644', 8)
-
-var END_OF_TAR = alloc(1024)
-
-var noop = function () {}
-
-var overflow = function (self, size) {
-  size &= 511
-  if (size) self.push(END_OF_TAR.slice(0, 512 - size))
-}
-
-function modeToType (mode) {
-  switch (mode & constants.S_IFMT) {
-    case constants.S_IFBLK: return 'block-device'
-    case constants.S_IFCHR: return 'character-device'
-    case constants.S_IFDIR: return 'directory'
-    case constants.S_IFIFO: return 'fifo'
-    case constants.S_IFLNK: return 'symlink'
-  }
-
-  return 'file'
-}
-
-var Sink = function (to) {
-  Writable.call(this)
-  this.written = 0
-  this._to = to
-  this._destroyed = false
-}
-
-inherits(Sink, Writable)
-
-Sink.prototype._write = function (data, enc, cb) {
-  this.written += data.length
-  if (this._to.push(data)) return cb()
-  this._to._drain = cb
-}
-
-Sink.prototype.destroy = function () {
-  if (this._destroyed) return
-  this._destroyed = true
-  this.emit('close')
-}
-
-var LinkSink = function () {
-  Writable.call(this)
-  this.linkname = ''
-  this._decoder = new StringDecoder('utf-8')
-  this._destroyed = false
-}
-
-inherits(LinkSink, Writable)
-
-LinkSink.prototype._write = function (data, enc, cb) {
-  this.linkname += this._decoder.write(data)
-  cb()
-}
-
-LinkSink.prototype.destroy = function () {
-  if (this._destroyed) return
-  this._destroyed = true
-  this.emit('close')
-}
-
-var Void = function () {
-  Writable.call(this)
-  this._destroyed = false
-}
-
-inherits(Void, Writable)
-
-Void.prototype._write = function (data, enc, cb) {
-  cb(new Error('No body allowed for this entry'))
-}
-
-Void.prototype.destroy = function () {
-  if (this._destroyed) return
-  this._destroyed = true
-  this.emit('close')
-}
-
-var Pack = function (opts) {
-  if (!(this instanceof Pack)) return new Pack(opts)
-  Readable.call(this, opts)
-
-  this._drain = noop
-  this._finalized = false
-  this._finalizing = false
-  this._destroyed = false
-  this._stream = null
-}
-
-inherits(Pack, Readable)
-
-Pack.prototype.entry = function (header, buffer, callback) {
-  if (this._stream) throw new Error('already piping an entry')
-  if (this._finalized || this._destroyed) return
-
-  if (typeof buffer === 'function') {
-    callback = buffer
-    buffer = null
-  }
-
-  if (!callback) callback = noop
-
-  var self = this
-
-  if (!header.size || header.type === 'symlink') header.size = 0
-  if (!header.type) header.type = modeToType(header.mode)
-  if (!header.mode) header.mode = header.type === 'directory' ? DMODE : FMODE
-  if (!header.uid) header.uid = 0
-  if (!header.gid) header.gid = 0
-  if (!header.mtime) header.mtime = new Date()
-
-  if (typeof buffer === 'string') buffer = Buffer.from(buffer)
-  if (Buffer.isBuffer(buffer)) {
-    header.size = buffer.length
-    this._encode(header)
-    var ok = this.push(buffer)
-    overflow(self, header.size)
-    if (ok) process.nextTick(callback)
-    else this._drain = callback
-    return new Void()
-  }
-
-  if (header.type === 'symlink' && !header.linkname) {
-    var linkSink = new LinkSink()
-    eos(linkSink, function (err) {
-      if (err) { // stream was closed
-        self.destroy()
-        return callback(err)
-      }
-
-      header.linkname = linkSink.linkname
-      self._encode(header)
-      callback()
-    })
-
-    return linkSink
-  }
-
-  this._encode(header)
-
-  if (header.type !== 'file' && header.type !== 'contiguous-file') {
-    process.nextTick(callback)
-    return new Void()
-  }
-
-  var sink = new Sink(this)
-
-  this._stream = sink
-
-  eos(sink, function (err) {
-    self._stream = null
-
-    if (err) { // stream was closed
-      self.destroy()
-      return callback(err)
-    }
-
-    if (sink.written !== header.size) { // corrupting tar
-      self.destroy()
-      return callback(new Error('size mismatch'))
-    }
-
-    overflow(self, header.size)
-    if (self._finalizing) self.finalize()
-    callback()
-  })
-
-  return sink
-}
-
-Pack.prototype.finalize = function () {
-  if (this._stream) {
-    this._finalizing = true
-    return
-  }
-
-  if (this._finalized) return
-  this._finalized = true
-  this.push(END_OF_TAR)
-  this.push(null)
-}
-
-Pack.prototype.destroy = function (err) {
-  if (this._destroyed) return
-  this._destroyed = true
-
-  if (err) this.emit('error', err)
-  this.emit('close')
-  if (this._stream && this._stream.destroy) this._stream.destroy()
-}
-
-Pack.prototype._encode = function (header) {
-  if (!header.pax) {
-    var buf = headers.encode(header)
-    if (buf) {
-      this.push(buf)
-      return
-    }
-  }
-  this._encodePax(header)
-}
-
-Pack.prototype._encodePax = function (header) {
-  var paxHeader = headers.encodePax({
-    name: header.name,
-    linkname: header.linkname,
-    pax: header.pax
-  })
-
-  var newHeader = {
-    name: 'PaxHeader',
-    mode: header.mode,
-    uid: header.uid,
-    gid: header.gid,
-    size: paxHeader.length,
-    mtime: header.mtime,
-    type: 'pax-header',
-    linkname: header.linkname && 'PaxHeader',
-    uname: header.uname,
-    gname: header.gname,
-    devmajor: header.devmajor,
-    devminor: header.devminor
-  }
-
-  this.push(headers.encode(newHeader))
-  this.push(paxHeader)
-  overflow(this, paxHeader.length)
-
-  newHeader.size = header.size
-  newHeader.type = header.type
-  this.push(headers.encode(newHeader))
-}
-
-Pack.prototype._read = function (n) {
-  var drain = this._drain
-  this._drain = noop
-  drain()
-}
-
-module.exports = Pack
-
-
-/***/ }),
-
-/***/ 49503:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
-
-/*!
- * Tmp
- *
- * Copyright (c) 2011-2017 KARASZI Istvan 
- *
- * MIT Licensed
- */
-
-/*
- * Module dependencies.
- */
-const fs = __nccwpck_require__(57147);
-const os = __nccwpck_require__(22037);
-const path = __nccwpck_require__(71017);
-const crypto = __nccwpck_require__(6113);
-const _c = { fs: fs.constants, os: os.constants };
-const rimraf = __nccwpck_require__(8414);
-
-/*
- * The working inner variables.
- */
-const
-  // the random characters to choose from
-  RANDOM_CHARS = '0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz',
-
-  TEMPLATE_PATTERN = /XXXXXX/,
-
-  DEFAULT_TRIES = 3,
-
-  CREATE_FLAGS = (_c.O_CREAT || _c.fs.O_CREAT) | (_c.O_EXCL || _c.fs.O_EXCL) | (_c.O_RDWR || _c.fs.O_RDWR),
-
-  // constants are off on the windows platform and will not match the actual errno codes
-  IS_WIN32 = os.platform() === 'win32',
-  EBADF = _c.EBADF || _c.os.errno.EBADF,
-  ENOENT = _c.ENOENT || _c.os.errno.ENOENT,
-
-  DIR_MODE = 0o700 /* 448 */,
-  FILE_MODE = 0o600 /* 384 */,
-
-  EXIT = 'exit',
-
-  // this will hold the objects need to be removed on exit
-  _removeObjects = [],
-
-  // API change in fs.rmdirSync leads to error when passing in a second parameter, e.g. the callback
-  FN_RMDIR_SYNC = fs.rmdirSync.bind(fs),
-  FN_RIMRAF_SYNC = rimraf.sync;
-
-let
-  _gracefulCleanup = false;
-
-/**
- * Gets a temporary file name.
- *
- * @param {(Options|tmpNameCallback)} options options or callback
- * @param {?tmpNameCallback} callback the callback function
- */
-function tmpName(options, callback) {
-  const
-    args = _parseArguments(options, callback),
-    opts = args[0],
-    cb = args[1];
-
-  try {
-    _assertAndSanitizeOptions(opts);
-  } catch (err) {
-    return cb(err);
-  }
-
-  let tries = opts.tries;
-  (function _getUniqueName() {
-    try {
-      const name = _generateTmpName(opts);
-
-      // check whether the path exists then retry if needed
-      fs.stat(name, function (err) {
-        /* istanbul ignore else */
-        if (!err) {
-          /* istanbul ignore else */
-          if (tries-- > 0) return _getUniqueName();
-
-          return cb(new Error('Could not get a unique tmp filename, max tries reached ' + name));
+  // src/compiler/tracing.ts
+  var tracing, tracingEnabled, startTracing, dumpTracingLegend;
+  var init_tracing = __esm({
+    "src/compiler/tracing.ts"() {
+      "use strict";
+      init_ts2();
+      init_ts_performance();
+      ((tracingEnabled2) => {
+        let fs;
+        let traceCount = 0;
+        let traceFd = 0;
+        let mode;
+        const typeCatalog = [];
+        let legendPath;
+        const legend = [];
+        function startTracing2(tracingMode, traceDir, configFilePath) {
+          Debug.assert(!tracing, "Tracing already started");
+          if (fs === void 0) {
+            try {
+              fs =   __nccwpck_require__(57147);
+            } catch (e) {
+              throw new Error(`tracing requires having fs
+(original error: ${e.message || e})`);
+            }
+          }
+          mode = tracingMode;
+          typeCatalog.length = 0;
+          if (legendPath === void 0) {
+            legendPath = combinePaths(traceDir, "legend.json");
+          }
+          if (!fs.existsSync(traceDir)) {
+            fs.mkdirSync(traceDir, { recursive: true });
+          }
+          const countPart = mode === "build" ? `.${process.pid}-${++traceCount}` : mode === "server" ? `.${process.pid}` : ``;
+          const tracePath = combinePaths(traceDir, `trace${countPart}.json`);
+          const typesPath = combinePaths(traceDir, `types${countPart}.json`);
+          legend.push({
+            configFilePath,
+            tracePath,
+            typesPath
+          });
+          traceFd = fs.openSync(tracePath, "w");
+          tracing = tracingEnabled2;
+          const meta = { cat: "__metadata", ph: "M", ts: 1e3 * timestamp(), pid: 1, tid: 1 };
+          fs.writeSync(
+            traceFd,
+            "[\n" + [{ name: "process_name", args: { name: "tsc" }, ...meta }, { name: "thread_name", args: { name: "Main" }, ...meta }, { name: "TracingStartedInBrowser", ...meta, cat: "disabled-by-default-devtools.timeline" }].map((v) => JSON.stringify(v)).join(",\n")
+          );
         }
-
-        cb(null, name);
-      });
-    } catch (err) {
-      cb(err);
+        tracingEnabled2.startTracing = startTracing2;
+        function stopTracing() {
+          Debug.assert(tracing, "Tracing is not in progress");
+          Debug.assert(!!typeCatalog.length === (mode !== "server"));
+          fs.writeSync(traceFd, `
+]
+`);
+          fs.closeSync(traceFd);
+          tracing = void 0;
+          if (typeCatalog.length) {
+            dumpTypes(typeCatalog);
+          } else {
+            legend[legend.length - 1].typesPath = void 0;
+          }
+        }
+        tracingEnabled2.stopTracing = stopTracing;
+        function recordType(type) {
+          if (mode !== "server") {
+            typeCatalog.push(type);
+          }
+        }
+        tracingEnabled2.recordType = recordType;
+        let Phase;
+        ((Phase2) => {
+          Phase2["Parse"] = "parse";
+          Phase2["Program"] = "program";
+          Phase2["Bind"] = "bind";
+          Phase2["Check"] = "check";
+          Phase2["CheckTypes"] = "checkTypes";
+          Phase2["Emit"] = "emit";
+          Phase2["Session"] = "session";
+        })(Phase = tracingEnabled2.Phase || (tracingEnabled2.Phase = {}));
+        function instant(phase, name, args) {
+          writeEvent("I", phase, name, args, `"s":"g"`);
+        }
+        tracingEnabled2.instant = instant;
+        const eventStack = [];
+        function push(phase, name, args, separateBeginAndEnd = false) {
+          if (separateBeginAndEnd) {
+            writeEvent("B", phase, name, args);
+          }
+          eventStack.push({ phase, name, args, time: 1e3 * timestamp(), separateBeginAndEnd });
+        }
+        tracingEnabled2.push = push;
+        function pop(results) {
+          Debug.assert(eventStack.length > 0);
+          writeStackEvent(eventStack.length - 1, 1e3 * timestamp(), results);
+          eventStack.length--;
+        }
+        tracingEnabled2.pop = pop;
+        function popAll() {
+          const endTime = 1e3 * timestamp();
+          for (let i = eventStack.length - 1; i >= 0; i--) {
+            writeStackEvent(i, endTime);
+          }
+          eventStack.length = 0;
+        }
+        tracingEnabled2.popAll = popAll;
+        const sampleInterval = 1e3 * 10;
+        function writeStackEvent(index, endTime, results) {
+          const { phase, name, args, time, separateBeginAndEnd } = eventStack[index];
+          if (separateBeginAndEnd) {
+            Debug.assert(!results, "`results` are not supported for events with `separateBeginAndEnd`");
+            writeEvent(
+              "E",
+              phase,
+              name,
+              args,
+              /*extras*/
+              void 0,
+              endTime
+            );
+          } else if (sampleInterval - time % sampleInterval <= endTime - time) {
+            writeEvent("X", phase, name, { ...args, results }, `"dur":${endTime - time}`, time);
+          }
+        }
+        function writeEvent(eventType, phase, name, args, extras, time = 1e3 * timestamp()) {
+          if (mode === "server" && phase === "checkTypes" /* CheckTypes */)
+            return;
+          mark("beginTracing");
+          fs.writeSync(traceFd, `,
+{"pid":1,"tid":1,"ph":"${eventType}","cat":"${phase}","ts":${time},"name":"${name}"`);
+          if (extras)
+            fs.writeSync(traceFd, `,${extras}`);
+          if (args)
+            fs.writeSync(traceFd, `,"args":${JSON.stringify(args)}`);
+          fs.writeSync(traceFd, `}`);
+          mark("endTracing");
+          measure("Tracing", "beginTracing", "endTracing");
+        }
+        function getLocation(node) {
+          const file = getSourceFileOfNode(node);
+          return !file ? void 0 : {
+            path: file.path,
+            start: indexFromOne(getLineAndCharacterOfPosition(file, node.pos)),
+            end: indexFromOne(getLineAndCharacterOfPosition(file, node.end))
+          };
+          function indexFromOne(lc) {
+            return {
+              line: lc.line + 1,
+              character: lc.character + 1
+            };
+          }
+        }
+        function dumpTypes(types) {
+          var _a, _b, _c, _d, _e, _f, _g, _h, _i, _j, _k, _l, _m, _n, _o, _p, _q, _r, _s;
+          mark("beginDumpTypes");
+          const typesPath = legend[legend.length - 1].typesPath;
+          const typesFd = fs.openSync(typesPath, "w");
+          const recursionIdentityMap = /* @__PURE__ */ new Map();
+          fs.writeSync(typesFd, "[");
+          const numTypes = types.length;
+          for (let i = 0; i < numTypes; i++) {
+            const type = types[i];
+            const objectFlags = type.objectFlags;
+            const symbol = type.aliasSymbol ?? type.symbol;
+            let display;
+            if (objectFlags & 16 /* Anonymous */ | type.flags & 2944 /* Literal */) {
+              try {
+                display = (_a = type.checker) == null ? void 0 : _a.typeToString(type);
+              } catch {
+                display = void 0;
+              }
+            }
+            let indexedAccessProperties = {};
+            if (type.flags & 8388608 /* IndexedAccess */) {
+              const indexedAccessType = type;
+              indexedAccessProperties = {
+                indexedAccessObjectType: (_b = indexedAccessType.objectType) == null ? void 0 : _b.id,
+                indexedAccessIndexType: (_c = indexedAccessType.indexType) == null ? void 0 : _c.id
+              };
+            }
+            let referenceProperties = {};
+            if (objectFlags & 4 /* Reference */) {
+              const referenceType = type;
+              referenceProperties = {
+                instantiatedType: (_d = referenceType.target) == null ? void 0 : _d.id,
+                typeArguments: (_e = referenceType.resolvedTypeArguments) == null ? void 0 : _e.map((t) => t.id),
+                referenceLocation: getLocation(referenceType.node)
+              };
+            }
+            let conditionalProperties = {};
+            if (type.flags & 16777216 /* Conditional */) {
+              const conditionalType = type;
+              conditionalProperties = {
+                conditionalCheckType: (_f = conditionalType.checkType) == null ? void 0 : _f.id,
+                conditionalExtendsType: (_g = conditionalType.extendsType) == null ? void 0 : _g.id,
+                conditionalTrueType: ((_h = conditionalType.resolvedTrueType) == null ? void 0 : _h.id) ?? -1,
+                conditionalFalseType: ((_i = conditionalType.resolvedFalseType) == null ? void 0 : _i.id) ?? -1
+              };
+            }
+            let substitutionProperties = {};
+            if (type.flags & 33554432 /* Substitution */) {
+              const substitutionType = type;
+              substitutionProperties = {
+                substitutionBaseType: (_j = substitutionType.baseType) == null ? void 0 : _j.id,
+                constraintType: (_k = substitutionType.constraint) == null ? void 0 : _k.id
+              };
+            }
+            let reverseMappedProperties = {};
+            if (objectFlags & 1024 /* ReverseMapped */) {
+              const reverseMappedType = type;
+              reverseMappedProperties = {
+                reverseMappedSourceType: (_l = reverseMappedType.source) == null ? void 0 : _l.id,
+                reverseMappedMappedType: (_m = reverseMappedType.mappedType) == null ? void 0 : _m.id,
+                reverseMappedConstraintType: (_n = reverseMappedType.constraintType) == null ? void 0 : _n.id
+              };
+            }
+            let evolvingArrayProperties = {};
+            if (objectFlags & 256 /* EvolvingArray */) {
+              const evolvingArrayType = type;
+              evolvingArrayProperties = {
+                evolvingArrayElementType: evolvingArrayType.elementType.id,
+                evolvingArrayFinalType: (_o = evolvingArrayType.finalArrayType) == null ? void 0 : _o.id
+              };
+            }
+            let recursionToken;
+            const recursionIdentity = type.checker.getRecursionIdentity(type);
+            if (recursionIdentity) {
+              recursionToken = recursionIdentityMap.get(recursionIdentity);
+              if (!recursionToken) {
+                recursionToken = recursionIdentityMap.size;
+                recursionIdentityMap.set(recursionIdentity, recursionToken);
+              }
+            }
+            const descriptor = {
+              id: type.id,
+              intrinsicName: type.intrinsicName,
+              symbolName: (symbol == null ? void 0 : symbol.escapedName) && unescapeLeadingUnderscores(symbol.escapedName),
+              recursionId: recursionToken,
+              isTuple: objectFlags & 8 /* Tuple */ ? true : void 0,
+              unionTypes: type.flags & 1048576 /* Union */ ? (_p = type.types) == null ? void 0 : _p.map((t) => t.id) : void 0,
+              intersectionTypes: type.flags & 2097152 /* Intersection */ ? type.types.map((t) => t.id) : void 0,
+              aliasTypeArguments: (_q = type.aliasTypeArguments) == null ? void 0 : _q.map((t) => t.id),
+              keyofType: type.flags & 4194304 /* Index */ ? (_r = type.type) == null ? void 0 : _r.id : void 0,
+              ...indexedAccessProperties,
+              ...referenceProperties,
+              ...conditionalProperties,
+              ...substitutionProperties,
+              ...reverseMappedProperties,
+              ...evolvingArrayProperties,
+              destructuringPattern: getLocation(type.pattern),
+              firstDeclaration: getLocation((_s = symbol == null ? void 0 : symbol.declarations) == null ? void 0 : _s[0]),
+              flags: Debug.formatTypeFlags(type.flags).split("|"),
+              display
+            };
+            fs.writeSync(typesFd, JSON.stringify(descriptor));
+            if (i < numTypes - 1) {
+              fs.writeSync(typesFd, ",\n");
+            }
+          }
+          fs.writeSync(typesFd, "]\n");
+          fs.closeSync(typesFd);
+          mark("endDumpTypes");
+          measure("Dump types", "beginDumpTypes", "endDumpTypes");
+        }
+        function dumpLegend() {
+          if (!legendPath) {
+            return;
+          }
+          fs.writeFileSync(legendPath, JSON.stringify(legend));
+        }
+        tracingEnabled2.dumpLegend = dumpLegend;
+      })(tracingEnabled || (tracingEnabled = {}));
+      startTracing = tracingEnabled.startTracing;
+      dumpTracingLegend = tracingEnabled.dumpLegend;
     }
-  }());
-}
+  });
 
-/**
- * Synchronous version of tmpName.
- *
- * @param {Object} options
- * @returns {string} the generated random name
- * @throws {Error} if the options are invalid or could not generate a filename
- */
-function tmpNameSync(options) {
-  const
-    args = _parseArguments(options),
-    opts = args[0];
-
-  _assertAndSanitizeOptions(opts);
-
-  let tries = opts.tries;
-  do {
-    const name = _generateTmpName(opts);
-    try {
-      fs.statSync(name);
-    } catch (e) {
-      return name;
-    }
-  } while (tries-- > 0);
-
-  throw new Error('Could not get a unique tmp filename, max tries reached');
-}
-
-/**
- * Creates and opens a temporary file.
- *
- * @param {(Options|null|undefined|fileCallback)} options the config options or the callback function or null or undefined
- * @param {?fileCallback} callback
- */
-function file(options, callback) {
-  const
-    args = _parseArguments(options, callback),
-    opts = args[0],
-    cb = args[1];
-
-  // gets a temporary filename
-  tmpName(opts, function _tmpNameCreated(err, name) {
-    /* istanbul ignore else */
-    if (err) return cb(err);
-
-    // create and open the file
-    fs.open(name, CREATE_FLAGS, opts.mode || FILE_MODE, function _fileCreated(err, fd) {
-      /* istanbu ignore else */
-      if (err) return cb(err);
-
-      if (opts.discardDescriptor) {
-        return fs.close(fd, function _discardCallback(possibleErr) {
-          // the chance of getting an error on close here is rather low and might occur in the most edgiest cases only
-          return cb(possibleErr, name, undefined, _prepareTmpFileRemoveCallback(name, -1, opts, false));
-        });
-      } else {
-        // detachDescriptor passes the descriptor whereas discardDescriptor closes it, either way, we no longer care
-        // about the descriptor
-        const discardOrDetachDescriptor = opts.discardDescriptor || opts.detachDescriptor;
-        cb(null, name, fd, _prepareTmpFileRemoveCallback(name, discardOrDetachDescriptor ? -1 : fd, opts, false));
-      }
-    });
-  });
-}
-
-/**
- * Synchronous version of file.
- *
- * @param {Options} options
- * @returns {FileSyncObject} object consists of name, fd and removeCallback
- * @throws {Error} if cannot create a file
- */
-function fileSync(options) {
-  const
-    args = _parseArguments(options),
-    opts = args[0];
-
-  const discardOrDetachDescriptor = opts.discardDescriptor || opts.detachDescriptor;
-  const name = tmpNameSync(opts);
-  var fd = fs.openSync(name, CREATE_FLAGS, opts.mode || FILE_MODE);
-  /* istanbul ignore else */
-  if (opts.discardDescriptor) {
-    fs.closeSync(fd);
-    fd = undefined;
-  }
-
-  return {
-    name: name,
-    fd: fd,
-    removeCallback: _prepareTmpFileRemoveCallback(name, discardOrDetachDescriptor ? -1 : fd, opts, true)
-  };
-}
-
-/**
- * Creates a temporary directory.
- *
- * @param {(Options|dirCallback)} options the options or the callback function
- * @param {?dirCallback} callback
- */
-function dir(options, callback) {
-  const
-    args = _parseArguments(options, callback),
-    opts = args[0],
-    cb = args[1];
-
-  // gets a temporary filename
-  tmpName(opts, function _tmpNameCreated(err, name) {
-    /* istanbul ignore else */
-    if (err) return cb(err);
-
-    // create the directory
-    fs.mkdir(name, opts.mode || DIR_MODE, function _dirCreated(err) {
-      /* istanbul ignore else */
-      if (err) return cb(err);
-
-      cb(null, name, _prepareTmpDirRemoveCallback(name, opts, false));
-    });
-  });
-}
-
-/**
- * Synchronous version of dir.
- *
- * @param {Options} options
- * @returns {DirSyncObject} object consists of name and removeCallback
- * @throws {Error} if it cannot create a directory
- */
-function dirSync(options) {
-  const
-    args = _parseArguments(options),
-    opts = args[0];
-
-  const name = tmpNameSync(opts);
-  fs.mkdirSync(name, opts.mode || DIR_MODE);
-
-  return {
-    name: name,
-    removeCallback: _prepareTmpDirRemoveCallback(name, opts, true)
-  };
-}
-
-/**
- * Removes files asynchronously.
- *
- * @param {Object} fdPath
- * @param {Function} next
- * @private
- */
-function _removeFileAsync(fdPath, next) {
-  const _handler = function (err) {
-    if (err && !_isENOENT(err)) {
-      // reraise any unanticipated error
-      return next(err);
-    }
-    next();
-  };
-
-  if (0 <= fdPath[0])
-    fs.close(fdPath[0], function () {
-      fs.unlink(fdPath[1], _handler);
-    });
-  else fs.unlink(fdPath[1], _handler);
-}
-
-/**
- * Removes files synchronously.
- *
- * @param {Object} fdPath
- * @private
- */
-function _removeFileSync(fdPath) {
-  let rethrownException = null;
-  try {
-    if (0 <= fdPath[0]) fs.closeSync(fdPath[0]);
-  } catch (e) {
-    // reraise any unanticipated error
-    if (!_isEBADF(e) && !_isENOENT(e)) throw e;
-  } finally {
-    try {
-      fs.unlinkSync(fdPath[1]);
-    }
-    catch (e) {
-      // reraise any unanticipated error
-      if (!_isENOENT(e)) rethrownException = e;
-    }
-  }
-  if (rethrownException !== null) {
-    throw rethrownException;
-  }
-}
-
-/**
- * Prepares the callback for removal of the temporary file.
- *
- * Returns either a sync callback or a async callback depending on whether
- * fileSync or file was called, which is expressed by the sync parameter.
- *
- * @param {string} name the path of the file
- * @param {number} fd file descriptor
- * @param {Object} opts
- * @param {boolean} sync
- * @returns {fileCallback | fileCallbackSync}
- * @private
- */
-function _prepareTmpFileRemoveCallback(name, fd, opts, sync) {
-  const removeCallbackSync = _prepareRemoveCallback(_removeFileSync, [fd, name], sync);
-  const removeCallback = _prepareRemoveCallback(_removeFileAsync, [fd, name], sync, removeCallbackSync);
-
-  if (!opts.keep) _removeObjects.unshift(removeCallbackSync);
-
-  return sync ? removeCallbackSync : removeCallback;
-}
-
-/**
- * Prepares the callback for removal of the temporary directory.
- *
- * Returns either a sync callback or a async callback depending on whether
- * tmpFileSync or tmpFile was called, which is expressed by the sync parameter.
- *
- * @param {string} name
- * @param {Object} opts
- * @param {boolean} sync
- * @returns {Function} the callback
- * @private
- */
-function _prepareTmpDirRemoveCallback(name, opts, sync) {
-  const removeFunction = opts.unsafeCleanup ? rimraf : fs.rmdir.bind(fs);
-  const removeFunctionSync = opts.unsafeCleanup ? FN_RIMRAF_SYNC : FN_RMDIR_SYNC;
-  const removeCallbackSync = _prepareRemoveCallback(removeFunctionSync, name, sync);
-  const removeCallback = _prepareRemoveCallback(removeFunction, name, sync, removeCallbackSync);
-  if (!opts.keep) _removeObjects.unshift(removeCallbackSync);
-
-  return sync ? removeCallbackSync : removeCallback;
-}
-
-/**
- * Creates a guarded function wrapping the removeFunction call.
- *
- * The cleanup callback is save to be called multiple times.
- * Subsequent invocations will be ignored.
- *
- * @param {Function} removeFunction
- * @param {string} fileOrDirName
- * @param {boolean} sync
- * @param {cleanupCallbackSync?} cleanupCallbackSync
- * @returns {cleanupCallback | cleanupCallbackSync}
- * @private
- */
-function _prepareRemoveCallback(removeFunction, fileOrDirName, sync, cleanupCallbackSync) {
-  let called = false;
-
-  // if sync is true, the next parameter will be ignored
-  return function _cleanupCallback(next) {
-
-    /* istanbul ignore else */
-    if (!called) {
-      // remove cleanupCallback from cache
-      const toRemove = cleanupCallbackSync || _cleanupCallback;
-      const index = _removeObjects.indexOf(toRemove);
-      /* istanbul ignore else */
-      if (index >= 0) _removeObjects.splice(index, 1);
-
-      called = true;
-      if (sync || removeFunction === FN_RMDIR_SYNC || removeFunction === FN_RIMRAF_SYNC) {
-        return removeFunction(fileOrDirName);
-      } else {
-        return removeFunction(fileOrDirName, next || function() {});
-      }
-    }
-  };
-}
-
-/**
- * The garbage collector.
- *
- * @private
- */
-function _garbageCollector() {
-  /* istanbul ignore else */
-  if (!_gracefulCleanup) return;
-
-  // the function being called removes itself from _removeObjects,
-  // loop until _removeObjects is empty
-  while (_removeObjects.length) {
-    try {
-      _removeObjects[0]();
-    } catch (e) {
-      // already removed?
-    }
-  }
-}
-
-/**
- * Random name generator based on crypto.
- * Adapted from http://blog.tompawlak.org/how-to-generate-random-values-nodejs-javascript
- *
- * @param {number} howMany
- * @returns {string} the generated random name
- * @private
- */
-function _randomChars(howMany) {
-  let
-    value = [],
-    rnd = null;
-
-  // make sure that we do not fail because we ran out of entropy
-  try {
-    rnd = crypto.randomBytes(howMany);
-  } catch (e) {
-    rnd = crypto.pseudoRandomBytes(howMany);
-  }
-
-  for (var i = 0; i < howMany; i++) {
-    value.push(RANDOM_CHARS[rnd[i] % RANDOM_CHARS.length]);
-  }
-
-  return value.join('');
-}
-
-/**
- * Helper which determines whether a string s is blank, that is undefined, or empty or null.
- *
- * @private
- * @param {string} s
- * @returns {Boolean} true whether the string s is blank, false otherwise
- */
-function _isBlank(s) {
-  return s === null || _isUndefined(s) || !s.trim();
-}
-
-/**
- * Checks whether the `obj` parameter is defined or not.
- *
- * @param {Object} obj
- * @returns {boolean} true if the object is undefined
- * @private
- */
-function _isUndefined(obj) {
-  return typeof obj === 'undefined';
-}
-
-/**
- * Parses the function arguments.
- *
- * This function helps to have optional arguments.
- *
- * @param {(Options|null|undefined|Function)} options
- * @param {?Function} callback
- * @returns {Array} parsed arguments
- * @private
- */
-function _parseArguments(options, callback) {
-  /* istanbul ignore else */
-  if (typeof options === 'function') {
-    return [{}, options];
-  }
-
-  /* istanbul ignore else */
-  if (_isUndefined(options)) {
-    return [{}, callback];
-  }
-
-  // copy options so we do not leak the changes we make internally
-  const actualOptions = {};
-  for (const key of Object.getOwnPropertyNames(options)) {
-    actualOptions[key] = options[key];
-  }
-
-  return [actualOptions, callback];
-}
-
-/**
- * Generates a new temporary name.
- *
- * @param {Object} opts
- * @returns {string} the new random name according to opts
- * @private
- */
-function _generateTmpName(opts) {
-
-  const tmpDir = opts.tmpdir;
-
-  /* istanbul ignore else */
-  if (!_isUndefined(opts.name))
-    return path.join(tmpDir, opts.dir, opts.name);
-
-  /* istanbul ignore else */
-  if (!_isUndefined(opts.template))
-    return path.join(tmpDir, opts.dir, opts.template).replace(TEMPLATE_PATTERN, _randomChars(6));
-
-  // prefix and postfix
-  const name = [
-    opts.prefix ? opts.prefix : 'tmp',
-    '-',
-    process.pid,
-    '-',
-    _randomChars(12),
-    opts.postfix ? '-' + opts.postfix : ''
-  ].join('');
-
-  return path.join(tmpDir, opts.dir, name);
-}
-
-/**
- * Asserts whether the specified options are valid, also sanitizes options and provides sane defaults for missing
- * options.
- *
- * @param {Options} options
- * @private
- */
-function _assertAndSanitizeOptions(options) {
-
-  options.tmpdir = _getTmpDir(options);
-
-  const tmpDir = options.tmpdir;
-
-  /* istanbul ignore else */
-  if (!_isUndefined(options.name))
-    _assertIsRelative(options.name, 'name', tmpDir);
-  /* istanbul ignore else */
-  if (!_isUndefined(options.dir))
-    _assertIsRelative(options.dir, 'dir', tmpDir);
-  /* istanbul ignore else */
-  if (!_isUndefined(options.template)) {
-    _assertIsRelative(options.template, 'template', tmpDir);
-    if (!options.template.match(TEMPLATE_PATTERN))
-      throw new Error(`Invalid template, found "${options.template}".`);
-  }
-  /* istanbul ignore else */
-  if (!_isUndefined(options.tries) && isNaN(options.tries) || options.tries < 0)
-    throw new Error(`Invalid tries, found "${options.tries}".`);
-
-  // if a name was specified we will try once
-  options.tries = _isUndefined(options.name) ? options.tries || DEFAULT_TRIES : 1;
-  options.keep = !!options.keep;
-  options.detachDescriptor = !!options.detachDescriptor;
-  options.discardDescriptor = !!options.discardDescriptor;
-  options.unsafeCleanup = !!options.unsafeCleanup;
-
-  // sanitize dir, also keep (multiple) blanks if the user, purportedly sane, requests us to
-  options.dir = _isUndefined(options.dir) ? '' : path.relative(tmpDir, _resolvePath(options.dir, tmpDir));
-  options.template = _isUndefined(options.template) ? undefined : path.relative(tmpDir, _resolvePath(options.template, tmpDir));
-  // sanitize further if template is relative to options.dir
-  options.template = _isBlank(options.template) ? undefined : path.relative(options.dir, options.template);
-
-  // for completeness' sake only, also keep (multiple) blanks if the user, purportedly sane, requests us to
-  options.name = _isUndefined(options.name) ? undefined : _sanitizeName(options.name);
-  options.prefix = _isUndefined(options.prefix) ? '' : options.prefix;
-  options.postfix = _isUndefined(options.postfix) ? '' : options.postfix;
-}
-
-/**
- * Resolve the specified path name in respect to tmpDir.
- *
- * The specified name might include relative path components, e.g. ../
- * so we need to resolve in order to be sure that is is located inside tmpDir
- *
- * @param name
- * @param tmpDir
- * @returns {string}
- * @private
- */
-function _resolvePath(name, tmpDir) {
-  const sanitizedName = _sanitizeName(name);
-  if (sanitizedName.startsWith(tmpDir)) {
-    return path.resolve(sanitizedName);
-  } else {
-    return path.resolve(path.join(tmpDir, sanitizedName));
-  }
-}
-
-/**
- * Sanitize the specified path name by removing all quote characters.
- *
- * @param name
- * @returns {string}
- * @private
- */
-function _sanitizeName(name) {
-  if (_isBlank(name)) {
-    return name;
-  }
-  return name.replace(/["']/g, '');
-}
-
-/**
- * Asserts whether specified name is relative to the specified tmpDir.
- *
- * @param {string} name
- * @param {string} option
- * @param {string} tmpDir
- * @throws {Error}
- * @private
- */
-function _assertIsRelative(name, option, tmpDir) {
-  if (option === 'name') {
-    // assert that name is not absolute and does not contain a path
-    if (path.isAbsolute(name))
-      throw new Error(`${option} option must not contain an absolute path, found "${name}".`);
-    // must not fail on valid . or .. or similar such constructs
-    let basename = path.basename(name);
-    if (basename === '..' || basename === '.' || basename !== name)
-      throw new Error(`${option} option must not contain a path, found "${name}".`);
-  }
-  else { // if (option === 'dir' || option === 'template') {
-    // assert that dir or template are relative to tmpDir
-    if (path.isAbsolute(name) && !name.startsWith(tmpDir)) {
-      throw new Error(`${option} option must be relative to "${tmpDir}", found "${name}".`);
-    }
-    let resolvedPath = _resolvePath(name, tmpDir);
-    if (!resolvedPath.startsWith(tmpDir))
-      throw new Error(`${option} option must be relative to "${tmpDir}", found "${resolvedPath}".`);
-  }
-}
-
-/**
- * Helper for testing against EBADF to compensate changes made to Node 7.x under Windows.
- *
- * @private
- */
-function _isEBADF(error) {
-  return _isExpectedError(error, -EBADF, 'EBADF');
-}
-
-/**
- * Helper for testing against ENOENT to compensate changes made to Node 7.x under Windows.
- *
- * @private
- */
-function _isENOENT(error) {
-  return _isExpectedError(error, -ENOENT, 'ENOENT');
-}
-
-/**
- * Helper to determine whether the expected error code matches the actual code and errno,
- * which will differ between the supported node versions.
- *
- * - Node >= 7.0:
- *   error.code {string}
- *   error.errno {number} any numerical value will be negated
- *
- * CAVEAT
- *
- * On windows, the errno for EBADF is -4083 but os.constants.errno.EBADF is different and we must assume that ENOENT
- * is no different here.
- *
- * @param {SystemError} error
- * @param {number} errno
- * @param {string} code
- * @private
- */
-function _isExpectedError(error, errno, code) {
-  return IS_WIN32 ? error.code === code : error.code === code && error.errno === errno;
-}
-
-/**
- * Sets the graceful cleanup.
- *
- * If graceful cleanup is set, tmp will remove all controlled temporary objects on process exit, otherwise the
- * temporary objects will remain in place, waiting to be cleaned up on system restart or otherwise scheduled temporary
- * object removals.
- */
-function setGracefulCleanup() {
-  _gracefulCleanup = true;
-}
-
-/**
- * Returns the currently configured tmp dir from os.tmpdir().
- *
- * @private
- * @param {?Options} options
- * @returns {string} the currently configured tmp dir
- */
-function _getTmpDir(options) {
-  return path.resolve(_sanitizeName(options && options.tmpdir || os.tmpdir()));
-}
-
-// Install process exit listener
-process.addListener(EXIT, _garbageCollector);
-
-/**
- * Configuration options.
- *
- * @typedef {Object} Options
- * @property {?boolean} keep the temporary object (file or dir) will not be garbage collected
- * @property {?number} tries the number of tries before give up the name generation
- * @property (?int) mode the access mode, defaults are 0o700 for directories and 0o600 for files
- * @property {?string} template the "mkstemp" like filename template
- * @property {?string} name fixed name relative to tmpdir or the specified dir option
- * @property {?string} dir tmp directory relative to the root tmp directory in use
- * @property {?string} prefix prefix for the generated name
- * @property {?string} postfix postfix for the generated name
- * @property {?string} tmpdir the root tmp directory which overrides the os tmpdir
- * @property {?boolean} unsafeCleanup recursively removes the created temporary directory, even when it's not empty
- * @property {?boolean} detachDescriptor detaches the file descriptor, caller is responsible for closing the file, tmp will no longer try closing the file during garbage collection
- * @property {?boolean} discardDescriptor discards the file descriptor (closes file, fd is -1), tmp will no longer try closing the file during garbage collection
- */
-
-/**
- * @typedef {Object} FileSyncObject
- * @property {string} name the name of the file
- * @property {string} fd the file descriptor or -1 if the fd has been discarded
- * @property {fileCallback} removeCallback the callback function to remove the file
- */
-
-/**
- * @typedef {Object} DirSyncObject
- * @property {string} name the name of the directory
- * @property {fileCallback} removeCallback the callback function to remove the directory
- */
-
-/**
- * @callback tmpNameCallback
- * @param {?Error} err the error object if anything goes wrong
- * @param {string} name the temporary file name
- */
-
-/**
- * @callback fileCallback
- * @param {?Error} err the error object if anything goes wrong
- * @param {string} name the temporary file name
- * @param {number} fd the file descriptor or -1 if the fd had been discarded
- * @param {cleanupCallback} fn the cleanup callback function
- */
-
-/**
- * @callback fileCallbackSync
- * @param {?Error} err the error object if anything goes wrong
- * @param {string} name the temporary file name
- * @param {number} fd the file descriptor or -1 if the fd had been discarded
- * @param {cleanupCallbackSync} fn the cleanup callback function
- */
-
-/**
- * @callback dirCallback
- * @param {?Error} err the error object if anything goes wrong
- * @param {string} name the temporary file name
- * @param {cleanupCallback} fn the cleanup callback function
- */
-
-/**
- * @callback dirCallbackSync
- * @param {?Error} err the error object if anything goes wrong
- * @param {string} name the temporary file name
- * @param {cleanupCallbackSync} fn the cleanup callback function
- */
-
-/**
- * Removes the temporary created file or directory.
- *
- * @callback cleanupCallback
- * @param {simpleCallback} [next] function to call whenever the tmp object needs to be removed
- */
-
-/**
- * Removes the temporary created file or directory.
- *
- * @callback cleanupCallbackSync
- */
-
-/**
- * Callback function for function composition.
- * @see {@link https://github.com/raszi/node-tmp/issues/57|raszi/node-tmp#57}
- *
- * @callback simpleCallback
- */
-
-// exporting all the needed methods
-
-// evaluate _getTmpDir() lazily, mainly for simplifying testing but it also will
-// allow users to reconfigure the temporary directory
-Object.defineProperty(module.exports, "tmpdir", ({
-  enumerable: true,
-  configurable: false,
-  get: function () {
-    return _getTmpDir();
-  }
-}));
-
-module.exports.dir = dir;
-module.exports.dirSync = dirSync;
-
-module.exports.file = file;
-module.exports.fileSync = fileSync;
-
-module.exports.tmpName = tmpName;
-module.exports.tmpNameSync = tmpNameSync;
-
-module.exports.setGracefulCleanup = setGracefulCleanup;
-
-
-/***/ }),
-
-/***/ 12085:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
-
-"use strict";
-/*!
- * to-regex-range 
- *
- * Copyright (c) 2015-present, Jon Schlinkert.
- * Released under the MIT License.
- */
-
-
-
-const isNumber = __nccwpck_require__(83834);
-
-const toRegexRange = (min, max, options) => {
-  if (isNumber(min) === false) {
-    throw new TypeError('toRegexRange: expected the first argument to be a number');
-  }
-
-  if (max === void 0 || min === max) {
-    return String(min);
-  }
-
-  if (isNumber(max) === false) {
-    throw new TypeError('toRegexRange: expected the second argument to be a number.');
-  }
-
-  let opts = { relaxZeros: true, ...options };
-  if (typeof opts.strictZeros === 'boolean') {
-    opts.relaxZeros = opts.strictZeros === false;
-  }
-
-  let relax = String(opts.relaxZeros);
-  let shorthand = String(opts.shorthand);
-  let capture = String(opts.capture);
-  let wrap = String(opts.wrap);
-  let cacheKey = min + ':' + max + '=' + relax + shorthand + capture + wrap;
-
-  if (toRegexRange.cache.hasOwnProperty(cacheKey)) {
-    return toRegexRange.cache[cacheKey].result;
-  }
-
-  let a = Math.min(min, max);
-  let b = Math.max(min, max);
-
-  if (Math.abs(a - b) === 1) {
-    let result = min + '|' + max;
-    if (opts.capture) {
-      return `(${result})`;
-    }
-    if (opts.wrap === false) {
-      return result;
-    }
-    return `(?:${result})`;
-  }
-
-  let isPadded = hasPadding(min) || hasPadding(max);
-  let state = { min, max, a, b };
-  let positives = [];
-  let negatives = [];
-
-  if (isPadded) {
-    state.isPadded = isPadded;
-    state.maxLen = String(state.max).length;
-  }
-
-  if (a < 0) {
-    let newMin = b < 0 ? Math.abs(b) : 1;
-    negatives = splitToPatterns(newMin, Math.abs(a), state, opts);
-    a = state.a = 0;
-  }
-
-  if (b >= 0) {
-    positives = splitToPatterns(a, b, state, opts);
-  }
-
-  state.negatives = negatives;
-  state.positives = positives;
-  state.result = collatePatterns(negatives, positives, opts);
-
-  if (opts.capture === true) {
-    state.result = `(${state.result})`;
-  } else if (opts.wrap !== false && (positives.length + negatives.length) > 1) {
-    state.result = `(?:${state.result})`;
-  }
-
-  toRegexRange.cache[cacheKey] = state;
-  return state.result;
-};
-
-function collatePatterns(neg, pos, options) {
-  let onlyNegative = filterPatterns(neg, pos, '-', false, options) || [];
-  let onlyPositive = filterPatterns(pos, neg, '', false, options) || [];
-  let intersected = filterPatterns(neg, pos, '-?', true, options) || [];
-  let subpatterns = onlyNegative.concat(intersected).concat(onlyPositive);
-  return subpatterns.join('|');
-}
-
-function splitToRanges(min, max) {
-  let nines = 1;
-  let zeros = 1;
-
-  let stop = countNines(min, nines);
-  let stops = new Set([max]);
-
-  while (min <= stop && stop <= max) {
-    stops.add(stop);
-    nines += 1;
-    stop = countNines(min, nines);
-  }
-
-  stop = countZeros(max + 1, zeros) - 1;
-
-  while (min < stop && stop <= max) {
-    stops.add(stop);
-    zeros += 1;
-    stop = countZeros(max + 1, zeros) - 1;
-  }
-
-  stops = [...stops];
-  stops.sort(compare);
-  return stops;
-}
-
-/**
- * Convert a range to a regex pattern
- * @param {Number} `start`
- * @param {Number} `stop`
- * @return {String}
- */
-
-function rangeToPattern(start, stop, options) {
-  if (start === stop) {
-    return { pattern: start, count: [], digits: 0 };
-  }
-
-  let zipped = zip(start, stop);
-  let digits = zipped.length;
-  let pattern = '';
-  let count = 0;
-
-  for (let i = 0; i < digits; i++) {
-    let [startDigit, stopDigit] = zipped[i];
-
-    if (startDigit === stopDigit) {
-      pattern += startDigit;
-
-    } else if (startDigit !== '0' || stopDigit !== '9') {
-      pattern += toCharacterClass(startDigit, stopDigit, options);
-
-    } else {
-      count++;
-    }
-  }
-
-  if (count) {
-    pattern += options.shorthand === true ? '\\d' : '[0-9]';
-  }
-
-  return { pattern, count: [count], digits };
-}
-
-function splitToPatterns(min, max, tok, options) {
-  let ranges = splitToRanges(min, max);
-  let tokens = [];
-  let start = min;
-  let prev;
-
-  for (let i = 0; i < ranges.length; i++) {
-    let max = ranges[i];
-    let obj = rangeToPattern(String(start), String(max), options);
-    let zeros = '';
-
-    if (!tok.isPadded && prev && prev.pattern === obj.pattern) {
-      if (prev.count.length > 1) {
-        prev.count.pop();
-      }
-
-      prev.count.push(obj.count[0]);
-      prev.string = prev.pattern + toQuantifier(prev.count);
-      start = max + 1;
-      continue;
-    }
-
-    if (tok.isPadded) {
-      zeros = padZeros(max, tok, options);
-    }
-
-    obj.string = zeros + obj.pattern + toQuantifier(obj.count);
-    tokens.push(obj);
-    start = max + 1;
-    prev = obj;
-  }
-
-  return tokens;
-}
-
-function filterPatterns(arr, comparison, prefix, intersection, options) {
-  let result = [];
-
-  for (let ele of arr) {
-    let { string } = ele;
-
-    // only push if _both_ are negative...
-    if (!intersection && !contains(comparison, 'string', string)) {
-      result.push(prefix + string);
-    }
-
-    // or _both_ are positive
-    if (intersection && contains(comparison, 'string', string)) {
-      result.push(prefix + string);
-    }
-  }
-  return result;
-}
-
-/**
- * Zip strings
- */
-
-function zip(a, b) {
-  let arr = [];
-  for (let i = 0; i < a.length; i++) arr.push([a[i], b[i]]);
-  return arr;
-}
-
-function compare(a, b) {
-  return a > b ? 1 : b > a ? -1 : 0;
-}
-
-function contains(arr, key, val) {
-  return arr.some(ele => ele[key] === val);
-}
-
-function countNines(min, len) {
-  return Number(String(min).slice(0, -len) + '9'.repeat(len));
-}
-
-function countZeros(integer, zeros) {
-  return integer - (integer % Math.pow(10, zeros));
-}
-
-function toQuantifier(digits) {
-  let [start = 0, stop = ''] = digits;
-  if (stop || start > 1) {
-    return `{${start + (stop ? ',' + stop : '')}}`;
-  }
-  return '';
-}
-
-function toCharacterClass(a, b, options) {
-  return `[${a}${(b - a === 1) ? '' : '-'}${b}]`;
-}
-
-function hasPadding(str) {
-  return /^-?(0+)\d/.test(str);
-}
-
-function padZeros(value, tok, options) {
-  if (!tok.isPadded) {
-    return value;
-  }
-
-  let diff = Math.abs(tok.maxLen - String(value).length);
-  let relax = options.relaxZeros !== false;
-
-  switch (diff) {
-    case 0:
-      return '';
-    case 1:
-      return relax ? '0?' : '0';
-    case 2:
-      return relax ? '0{0,2}' : '00';
-    default: {
-      return relax ? `0{0,${diff}}` : `0{${diff}}`;
-    }
-  }
-}
-
-/**
- * Cache
- */
-
-toRegexRange.cache = {};
-toRegexRange.clearCache = () => (toRegexRange.cache = {});
-
-/**
- * Expose `toRegexRange`
- */
-
-module.exports = toRegexRange;
-
-
-/***/ }),
-
-/***/ 83834:
-/***/ ((module) => {
-
-"use strict";
-/*!
- * is-number 
- *
- * Copyright (c) 2014-present, Jon Schlinkert.
- * Released under the MIT License.
- */
-
-
-
-module.exports = function(num) {
-  if (typeof num === 'number') {
-    return num - num === 0;
-  }
-  if (typeof num === 'string' && num.trim() !== '') {
-    return Number.isFinite ? Number.isFinite(+num) : isFinite(+num);
-  }
-  return false;
-};
-
-
-/***/ }),
-
-/***/ 87956:
-/***/ ((module) => {
-
-// Copied from https://github.com/nodejs/node/blob/master/lib/internal/constants.js
-module.exports = {
-  CHAR_FORWARD_SLASH: 47, /* / */
-};
-
-
-/***/ }),
-
-/***/ 79944:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
-
-"use strict";
-
-
-const path = __nccwpck_require__(71017);
-
-exports.codes = {
-  ERR_INPUT_TYPE_NOT_ALLOWED: createErrorCtor(joinArgs('ERR_INPUT_TYPE_NOT_ALLOWED')),
-  ERR_INVALID_ARG_VALUE: createErrorCtor(joinArgs('ERR_INVALID_ARG_VALUE')),
-  ERR_INVALID_MODULE_SPECIFIER: createErrorCtor(joinArgs('ERR_INVALID_MODULE_SPECIFIER')),
-  ERR_INVALID_PACKAGE_CONFIG: createErrorCtor(joinArgs('ERR_INVALID_PACKAGE_CONFIG')),
-  ERR_INVALID_PACKAGE_TARGET: createErrorCtor(joinArgs('ERR_INVALID_PACKAGE_TARGET')),
-  ERR_MANIFEST_DEPENDENCY_MISSING: createErrorCtor(joinArgs('ERR_MANIFEST_DEPENDENCY_MISSING')),
-  ERR_MODULE_NOT_FOUND: createErrorCtor((path, base, type = 'package') => {
-    return `Cannot find ${type} '${path}' imported from ${base}`
-  }),
-  ERR_PACKAGE_IMPORT_NOT_DEFINED: createErrorCtor(joinArgs('ERR_PACKAGE_IMPORT_NOT_DEFINED')),
-  ERR_PACKAGE_PATH_NOT_EXPORTED: createErrorCtor(joinArgs('ERR_PACKAGE_PATH_NOT_EXPORTED')),
-  ERR_UNSUPPORTED_DIR_IMPORT: createErrorCtor(joinArgs('ERR_UNSUPPORTED_DIR_IMPORT')),
-  ERR_UNSUPPORTED_ESM_URL_SCHEME: createErrorCtor(joinArgs('ERR_UNSUPPORTED_ESM_URL_SCHEME')),
-  ERR_UNKNOWN_FILE_EXTENSION: createErrorCtor(joinArgs('ERR_UNKNOWN_FILE_EXTENSION')),
-}
-
-function joinArgs(name) {
-  return (...args) => {
-    return [name, ...args].join(' ')
-  }
-}
-
-function createErrorCtor(errorMessageCreator) {
-  return class CustomError extends Error {
-    constructor(...args) {
-      super(errorMessageCreator(...args))
-    }
-  }
-}
-exports.createErrRequireEsm = createErrRequireEsm;
-
-// Native ERR_REQUIRE_ESM Error is declared here:
-//   https://github.com/nodejs/node/blob/2d5d77306f6dff9110c1f77fefab25f973415770/lib/internal/errors.js#L1294-L1313
-// Error class factory is implemented here:
-//   function E: https://github.com/nodejs/node/blob/2d5d77306f6dff9110c1f77fefab25f973415770/lib/internal/errors.js#L323-L341
-//   function makeNodeErrorWithCode: https://github.com/nodejs/node/blob/2d5d77306f6dff9110c1f77fefab25f973415770/lib/internal/errors.js#L251-L278
-// The code below should create an error that matches the native error as closely as possible.
-// Third-party libraries which attempt to catch the native ERR_REQUIRE_ESM should recognize our imitation error.
-function createErrRequireEsm(filename, parentPath, packageJsonPath) {
-  const code = 'ERR_REQUIRE_ESM'
-  const err = new Error(getErrRequireEsmMessage(filename, parentPath, packageJsonPath))
-  // Set `name` to be used in stack trace, generate stack trace with that name baked in, then re-declare the `name` field.
-  // This trick is copied from node's source.
-  err.name = `Error [${ code }]`
-  err.stack
-  Object.defineProperty(err, 'name', {
-    value: 'Error',
-    enumerable: false,
-    writable: true,
-    configurable: true
-  })
-  err.code = code
-  return err
-}
-
-// Copy-pasted from https://github.com/nodejs/node/blob/b533fb3508009e5f567cc776daba8fbf665386a6/lib/internal/errors.js#L1293-L1311
-// so that our error message is identical to the native message.
-function getErrRequireEsmMessage(filename, parentPath = null, packageJsonPath = null) {
-  const ext = path.extname(filename)
-  let msg = `Must use import to load ES Module: ${filename}`;
-  if (parentPath && packageJsonPath) {
-    const path = __nccwpck_require__(71017);
-    const basename = path.basename(filename) === path.basename(parentPath) ?
-      filename : path.basename(filename);
-    msg +=
-      '\nrequire() of ES modules is not supported.\nrequire() of ' +
-      `${filename} ${parentPath ? `from ${parentPath} ` : ''}` +
-      `is an ES module file as it is a ${ext} file whose nearest parent ` +
-      `package.json contains "type": "module" which defines all ${ext} ` +
-      'files in that package scope as ES modules.\nInstead ' +
-      'change the requiring code to use ' +
-      'import(), or remove "type": "module" from ' +
-      `${packageJsonPath}.\n`;
-    return msg;
+  // src/compiler/types.ts
+  function diagnosticCategoryName(d, lowerCase = true) {
+    const name = DiagnosticCategory[d.category];
+    return lowerCase ? name.toLowerCase() : name;
   }
-  return msg;
-}
-
-
-/***/ }),
-
-/***/ 6836:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
-
-"use strict";
-// Copied from https://github.com/nodejs/node/blob/v17.0.1/lib/internal/modules/cjs/helpers.js
-
-
-
-const {
-  ArrayPrototypeForEach,
-  ObjectDefineProperty,
-  ObjectPrototypeHasOwnProperty,
-  SafeSet,
-  StringPrototypeIncludes,
-  StringPrototypeStartsWith,
-} = __nccwpck_require__(5335);
-
-const { getOptionValue } = __nccwpck_require__(45519);
-const userConditions = getOptionValue('--conditions');
-
-const noAddons = getOptionValue('--no-addons');
-const addonConditions = noAddons ? [] : ['node-addons'];
-
-// TODO: Use this set when resolving pkg#exports conditions in loader.js.
-const cjsConditions = new SafeSet([
-  'require',
-  'node',
-  ...addonConditions,
-  ...userConditions,
-]);
-
-/**
- * @param {any} object
- * @param {string} [dummyModuleName]
- * @return {void}
- */
-function addBuiltinLibsToObject(object, dummyModuleName) {
-  // Make built-in modules available directly (loaded lazily).
-  const Module = (__nccwpck_require__(98188).Module);
-  const { builtinModules } = Module;
-
-  // To require built-in modules in user-land and ignore modules whose
-  // `canBeRequiredByUsers` is false. So we create a dummy module object and not
-  // use `require()` directly.
-  const dummyModule = new Module(dummyModuleName);
-
-  ArrayPrototypeForEach(builtinModules, (name) => {
-    // Neither add underscored modules, nor ones that contain slashes (e.g.,
-    // 'fs/promises') or ones that are already defined.
-    if (StringPrototypeStartsWith(name, '_') ||
-        StringPrototypeIncludes(name, '/') ||
-        ObjectPrototypeHasOwnProperty(object, name)) {
-      return;
-    }
-    // Goals of this mechanism are:
-    // - Lazy loading of built-in modules
-    // - Having all built-in modules available as non-enumerable properties
-    // - Allowing the user to re-assign these variables as if there were no
-    //   pre-existing globals with the same name.
-
-    const setReal = (val) => {
-      // Deleting the property before re-assigning it disables the
-      // getter/setter mechanism.
-      delete object[name];
-      object[name] = val;
-    };
-
-    ObjectDefineProperty(object, name, {
-      get: () => {
-        // Node 12 hack; remove when we drop node12 support
-        const lib = (dummyModule.require || require)(name);
-
-        // Disable the current getter/setter and set up a new
-        // non-enumerable property.
-        delete object[name];
-        ObjectDefineProperty(object, name, {
-          get: () => lib,
-          set: setReal,
-          configurable: true,
-          enumerable: false
-        });
-
-        return lib;
-      },
-      set: setReal,
-      configurable: true,
-      enumerable: false
-    });
-  });
-}
-
-exports.addBuiltinLibsToObject = addBuiltinLibsToObject;
-exports.cjsConditions = cjsConditions;
-
-
-/***/ }),
-
-/***/ 11717:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
-
-"use strict";
-// Copied from several files in node's source code.
-// https://github.com/nodejs/node/blob/2d5d77306f6dff9110c1f77fefab25f973415770/lib/internal/modules/cjs/loader.js
-// Each function and variable below must have a comment linking to the source in node's github repo.
-
-
-
-const {
-  ArrayIsArray,
-  ArrayPrototypeIncludes,
-  ArrayPrototypeJoin,
-  ArrayPrototypePush,
-  JSONParse,
-  ObjectKeys,
-  RegExpPrototypeTest,
-  SafeMap,
-  SafeWeakMap,
-  StringPrototypeCharCodeAt,
-  StringPrototypeEndsWith,
-  StringPrototypeLastIndexOf,
-  StringPrototypeIndexOf,
-  StringPrototypeMatch,
-  StringPrototypeSlice,
-  StringPrototypeStartsWith,
-} = __nccwpck_require__(5335);
-const { NativeModule } = __nccwpck_require__(10765);
-const { pathToFileURL, fileURLToPath } = __nccwpck_require__(57310);
-const fs = __nccwpck_require__(57147);
-const path = __nccwpck_require__(71017);
-const { sep } = path;
-const { internalModuleStat } = __nccwpck_require__(22785);
-const packageJsonReader = __nccwpck_require__(19867);
-const {
-  cjsConditions,
-} = __nccwpck_require__(6836);
-const { getOptionValue } = __nccwpck_require__(45519);
-const preserveSymlinks = getOptionValue('--preserve-symlinks');
-const preserveSymlinksMain = getOptionValue('--preserve-symlinks-main');
-const {normalizeSlashes} = __nccwpck_require__(81842);
-const {createErrRequireEsm} = __nccwpck_require__(79944);
-const {
-  codes: {
-    ERR_INVALID_MODULE_SPECIFIER,
-  },
-} = __nccwpck_require__(79944);
-
-const {
-  CHAR_FORWARD_SLASH,
-} = __nccwpck_require__(87956);
-
-const Module = __nccwpck_require__(98188);
-
-const isWindows = process.platform === 'win32';
-
-let statCache = null;
-
-function stat(filename) {
-  filename = path.toNamespacedPath(filename);
-  if (statCache !== null) {
-    const result = statCache.get(filename);
-    if (result !== undefined) return result;
-  }
-  const result = internalModuleStat(filename);
-  if (statCache !== null && result >= 0) {
-    // Only set cache when `internalModuleStat(filename)` succeeds.
-    statCache.set(filename, result);
-  }
-  return result;
-}
-
-// Note:
-// we cannot get access to node's internal cache, which is populated from
-// within node's Module constructor.  So the cache here will always be empty.
-// It's possible we could approximate our own cache by building it up with
-// hacky workarounds, but it's not worth the complexity and flakiness.
-const moduleParentCache = new SafeWeakMap();
-
-// Given a module name, and a list of paths to test, returns the first
-// matching file in the following precedence.
-//
-// require("a.")
-//   -> a.
-//
-// require("a")
-//   -> a
-//   -> a.
-//   -> a/index.
-
-const packageJsonCache = new SafeMap();
-
-function readPackage(requestPath) {
-  const jsonPath = path.resolve(requestPath, 'package.json');
-
-  const existing = packageJsonCache.get(jsonPath);
-  if (existing !== undefined) return existing;
-
-  const result = packageJsonReader.read(jsonPath);
-  const json = result.containsKeys === false ? '{}' : result.string;
-  if (json === undefined) {
-    packageJsonCache.set(jsonPath, false);
-    return false;
-  }
-
-  try {
-    const parsed = JSONParse(json);
-    const filtered = {
-      name: parsed.name,
-      main: parsed.main,
-      exports: parsed.exports,
-      imports: parsed.imports,
-      type: parsed.type
-    };
-    packageJsonCache.set(jsonPath, filtered);
-    return filtered;
-  } catch (e) {
-    e.path = jsonPath;
-    e.message = 'Error parsing ' + jsonPath + ': ' + e.message;
-    throw e;
-  }
-}
-
-function readPackageScope(checkPath) {
-  const rootSeparatorIndex = StringPrototypeIndexOf(checkPath, sep);
-  let separatorIndex;
-  do {
-    separatorIndex = StringPrototypeLastIndexOf(checkPath, sep);
-    checkPath = StringPrototypeSlice(checkPath, 0, separatorIndex);
-    if (StringPrototypeEndsWith(checkPath, sep + 'node_modules'))
-      return false;
-    const pjson = readPackage(checkPath + sep);
-    if (pjson) return {
-      data: pjson,
-      path: checkPath,
-    };
-  } while (separatorIndex > rootSeparatorIndex);
-  return false;
-}
-
-/**
- * @param {{
- *   nodeEsmResolver: ReturnType,
- *   extensions: import('../src/file-extensions').Extensions,
- *   preferTsExts
- * }} opts
- */
-function createCjsLoader(opts) {
-const {nodeEsmResolver, preferTsExts} = opts;
-const {replacementsForCjs, replacementsForJs, replacementsForMjs, replacementsForJsx} = opts.extensions;
-const {
-  encodedSepRegEx,
-  packageExportsResolve,
-  packageImportsResolve
-} = nodeEsmResolver;
-
-function tryPackage(requestPath, exts, isMain, originalPath) {
-  // const pkg = readPackage(requestPath)?.main;
-  const tmp = readPackage(requestPath)
-  const pkg = tmp != null ? tmp.main : undefined;
-
-  if (!pkg) {
-    return tryExtensions(path.resolve(requestPath, 'index'), exts, isMain);
-  }
-
-  const filename = path.resolve(requestPath, pkg);
-  let actual = tryReplacementExtensions(filename, isMain) ||
-    tryFile(filename, isMain) ||
-    tryExtensions(filename, exts, isMain) ||
-    tryExtensions(path.resolve(filename, 'index'), exts, isMain);
-  if (actual === false) {
-    actual = tryExtensions(path.resolve(requestPath, 'index'), exts, isMain);
-    if (!actual) {
-      // eslint-disable-next-line no-restricted-syntax
-      const err = new Error(
-        `Cannot find module '${filename}'. ` +
-        'Please verify that the package.json has a valid "main" entry'
-      );
-      err.code = 'MODULE_NOT_FOUND';
-      err.path = path.resolve(requestPath, 'package.json');
-      err.requestPath = originalPath;
-      // TODO(BridgeAR): Add the requireStack as well.
-      throw err;
-    } else {
-      const jsonPath = path.resolve(requestPath, 'package.json');
-      process.emitWarning(
-        `Invalid 'main' field in '${jsonPath}' of '${pkg}'. ` +
-          'Please either fix that or report it to the module author',
-        'DeprecationWarning',
-        'DEP0128'
-      );
-    }
-  }
-  return actual;
-}
-
-// In order to minimize unnecessary lstat() calls,
-// this cache is a list of known-real paths.
-// Set to an empty Map to reset.
-const realpathCache = new SafeMap();
-
-// Check if the file exists and is not a directory
-// if using --preserve-symlinks and isMain is false,
-// keep symlinks intact, otherwise resolve to the
-// absolute realpath.
-function tryFile(requestPath, isMain) {
-  const rc = stat(requestPath);
-  if (rc !== 0) return;
-  if (preserveSymlinks && !isMain) {
-    return path.resolve(requestPath);
-  }
-  return toRealPath(requestPath);
-}
-
-function toRealPath(requestPath) {
-  return fs.realpathSync(requestPath, {
-    // [internalFS.realpathCacheKey]: realpathCache
-  });
-}
-
-function statReplacementExtensions(p) {
-  const lastDotIndex = p.lastIndexOf('.');
-  if(lastDotIndex >= 0) {
-    const ext = p.slice(lastDotIndex);
-    if (ext === '.js' || ext === '.jsx' || ext === '.mjs' || ext === '.cjs') {
-      const pathnameWithoutExtension = p.slice(0, lastDotIndex);
-      const replacementExts =
-        ext === '.js' ? replacementsForJs
-        : ext === '.jsx' ? replacementsForJsx
-        : ext === '.mjs' ? replacementsForMjs
-        : replacementsForCjs;
-      for (let i = 0; i < replacementExts.length; i++) {
-        const filename = pathnameWithoutExtension + replacementExts[i];
-        const rc = stat(filename);
-        if (rc === 0) {
-          return [rc, filename];
-        }
-      }
-    }
-  }
-  return [stat(p), p];
-}
-function tryReplacementExtensions(p, isMain) {
-  const lastDotIndex = p.lastIndexOf('.');
-  if(lastDotIndex >= 0) {
-    const ext = p.slice(lastDotIndex);
-    if (ext === '.js' || ext === '.jsx' || ext === '.mjs' || ext === '.cjs') {
-      const pathnameWithoutExtension = p.slice(0, lastDotIndex);
-      const replacementExts =
-        ext === '.js' ? replacementsForJs
-        : ext === '.jsx' ? replacementsForJsx
-        : ext === '.mjs' ? replacementsForMjs
-        : replacementsForCjs;
-      for (let i = 0; i < replacementExts.length; i++) {
-        const filename = tryFile(pathnameWithoutExtension + replacementExts[i], isMain);
-        if (filename) {
-          return filename;
-        }
-      }
-    }
-  }
-  return false;
-}
-
-// Given a path, check if the file exists with any of the set extensions
-function tryExtensions(p, exts, isMain) {
-  for (let i = 0; i < exts.length; i++) {
-    const filename = tryFile(p + exts[i], isMain);
-
-    if (filename) {
-      return filename;
-    }
-  }
-  return false;
-}
-
-function trySelfParentPath(parent) {
-  if (!parent) return false;
-
-  if (parent.filename) {
-    return parent.filename;
-  } else if (parent.id === '' || parent.id === 'internal/preload') {
-    try {
-      return process.cwd() + path.sep;
-    } catch {
-      return false;
-    }
-  }
-}
-
-function trySelf(parentPath, request) {
-  if (!parentPath) return false;
-
-  const { data: pkg, path: pkgPath } = readPackageScope(parentPath) || {};
-  if (!pkg || pkg.exports === undefined) return false;
-  if (typeof pkg.name !== 'string') return false;
-
-  let expansion;
-  if (request === pkg.name) {
-    expansion = '.';
-  } else if (StringPrototypeStartsWith(request, `${pkg.name}/`)) {
-    expansion = '.' + StringPrototypeSlice(request, pkg.name.length);
-  } else {
-    return false;
-  }
-
-  try {
-    return finalizeEsmResolution(packageExportsResolve(
-      pathToFileURL(pkgPath + '/package.json'), expansion, pkg,
-      pathToFileURL(parentPath), cjsConditions).resolved, parentPath, pkgPath);
-  } catch (e) {
-    if (e.code === 'ERR_MODULE_NOT_FOUND')
-      throw createEsmNotFoundErr(request, pkgPath + '/package.json');
-    throw e;
-  }
-}
-
-// This only applies to requests of a specific form:
-// 1. name/.*
-// 2. @scope/name/.*
-const EXPORTS_PATTERN = /^((?:@[^/\\%]+\/)?[^./\\%][^/\\%]*)(\/.*)?$/;
-function resolveExports(nmPath, request) {
-  // The implementation's behavior is meant to mirror resolution in ESM.
-  const { 1: name, 2: expansion = '' } =
-    StringPrototypeMatch(request, EXPORTS_PATTERN) || [];
-  if (!name)
-    return;
-  const pkgPath = path.resolve(nmPath, name);
-  const pkg = readPackage(pkgPath);
-  // if (pkg?.exports != null) {
-  if (pkg != null && pkg.exports != null) {
-    try {
-      return finalizeEsmResolution(packageExportsResolve(
-        pathToFileURL(pkgPath + '/package.json'), '.' + expansion, pkg, null,
-        cjsConditions).resolved, null, pkgPath);
-    } catch (e) {
-      if (e.code === 'ERR_MODULE_NOT_FOUND')
-        throw createEsmNotFoundErr(request, pkgPath + '/package.json');
-      throw e;
-    }
-  }
-}
-
-// Backwards compat for old node versions
-const hasModulePathCache = !!(__nccwpck_require__(98188)._pathCache);
-const Module_pathCache = Object.create(null);
-const Module_pathCache_get = hasModulePathCache ? (cacheKey) => Module._pathCache[cacheKey] : (cacheKey) => Module_pathCache[cacheKey];
-const Module_pathCache_set = hasModulePathCache ? (cacheKey, value) => (Module._pathCache[cacheKey] = value) : (cacheKey) => (Module_pathCache[cacheKey] = value);
-
-const trailingSlashRegex = /(?:^|\/)\.?\.$/;
-const Module_findPath = function _findPath(request, paths, isMain) {
-  const absoluteRequest = path.isAbsolute(request);
-  if (absoluteRequest) {
-    paths = [''];
-  } else if (!paths || paths.length === 0) {
-    return false;
-  }
-
-  const cacheKey = request + '\x00' + ArrayPrototypeJoin(paths, '\x00');
-  const entry = Module_pathCache_get(cacheKey);
-  if (entry)
-    return entry;
-
-  let exts;
-  let trailingSlash = request.length > 0 &&
-    StringPrototypeCharCodeAt(request, request.length - 1) ===
-    CHAR_FORWARD_SLASH;
-  if (!trailingSlash) {
-    trailingSlash = RegExpPrototypeTest(trailingSlashRegex, request);
-  }
-
-  // For each path
-  for (let i = 0; i < paths.length; i++) {
-    // Don't search further if path doesn't exist
-    const curPath = paths[i];
-    if (curPath && stat(curPath) < 1) continue;
-
-    if (!absoluteRequest) {
-      const exportsResolved = resolveExports(curPath, request);
-      if (exportsResolved)
-        return exportsResolved;
-    }
-
-    const _basePath = path.resolve(curPath, request);
-    let filename;
-
-    const [rc, basePath] = statReplacementExtensions(_basePath);
-    if (!trailingSlash) {
-      if (rc === 0) {  // File.
-        if (!isMain) {
-          if (preserveSymlinks) {
-            filename = path.resolve(basePath);
-          } else {
-            filename = toRealPath(basePath);
-          }
-        } else if (preserveSymlinksMain) {
-          // For the main module, we use the preserveSymlinksMain flag instead
-          // mainly for backward compatibility, as the preserveSymlinks flag
-          // historically has not applied to the main module.  Most likely this
-          // was intended to keep .bin/ binaries working, as following those
-          // symlinks is usually required for the imports in the corresponding
-          // files to resolve; that said, in some use cases following symlinks
-          // causes bigger problems which is why the preserveSymlinksMain option
-          // is needed.
-          filename = path.resolve(basePath);
-        } else {
-          filename = toRealPath(basePath);
-        }
-      }
-
-      if (!filename) {
-        // Try it with each of the extensions
-        if (exts === undefined)
-          exts = ObjectKeys(Module._extensions);
-        filename = tryExtensions(basePath, exts, isMain);
-      }
-    }
-
-    if (!filename && rc === 1) {  // Directory.
-      // try it with each of the extensions at "index"
-      if (exts === undefined)
-        exts = ObjectKeys(Module._extensions);
-      filename = tryPackage(basePath, exts, isMain, request);
-    }
-
-    if (filename) {
-      Module_pathCache_set(cacheKey, filename);
-      return filename;
-    }
-  }
-
-  return false;
-};
-
-const Module_resolveFilename = function _resolveFilename(request, parent, isMain, options) {
-  if (StringPrototypeStartsWith(request, 'node:') ||
-      NativeModule.canBeRequiredByUsers(request)) {
-    return request;
-  }
-
-  let paths;
-
-  if (typeof options === 'object' && options !== null) {
-    if (ArrayIsArray(options.paths)) {
-      const isRelative = StringPrototypeStartsWith(request, './') ||
-          StringPrototypeStartsWith(request, '../') ||
-          ((isWindows && StringPrototypeStartsWith(request, '.\\')) ||
-          StringPrototypeStartsWith(request, '..\\'));
-
-      if (isRelative) {
-        paths = options.paths;
-      } else {
-        const fakeParent = new Module('', null);
-
-        paths = [];
-
-        for (let i = 0; i < options.paths.length; i++) {
-          const path = options.paths[i];
-          fakeParent.paths = Module._nodeModulePaths(path);
-          const lookupPaths = Module._resolveLookupPaths(request, fakeParent);
-
-          for (let j = 0; j < lookupPaths.length; j++) {
-            if (!ArrayPrototypeIncludes(paths, lookupPaths[j]))
-              ArrayPrototypePush(paths, lookupPaths[j]);
-          }
-        }
-      }
-    } else if (options.paths === undefined) {
-      paths = Module._resolveLookupPaths(request, parent);
-    } else {
-      throw new ERR_INVALID_ARG_VALUE('options.paths', options.paths);
-    }
-  } else {
-    paths = Module._resolveLookupPaths(request, parent);
-  }
-
-  // if (parent?.filename) {
-  // node 12 hack
-  if (parent != null && parent.filename) {
-    if (request[0] === '#') {
-      const pkg = readPackageScope(parent.filename) || {};
-
-      // if (pkg.data?.imports != null) {
-      // node 12 hack
-      if (pkg.data != null && pkg.data.imports != null) {
-        try {
-          return finalizeEsmResolution(
-            packageImportsResolve(request, pathToFileURL(parent.filename),
-                                  cjsConditions), parent.filename,
-            pkg.path);
-        } catch (e) {
-          if (e.code === 'ERR_MODULE_NOT_FOUND')
-            throw createEsmNotFoundErr(request);
-          throw e;
-        }
-      }
-    }
-  }
-
-  // Try module self resolution first
-  const parentPath = trySelfParentPath(parent);
-  const selfResolved = trySelf(parentPath, request);
-  if (selfResolved) {
-    const cacheKey = request + '\x00' +
-         (paths.length === 1 ? paths[0] : ArrayPrototypeJoin(paths, '\x00'));
-    Module._pathCache[cacheKey] = selfResolved;
-    return selfResolved;
-  }
-
-  // Look up the filename first, since that's the cache key.
-  const filename = Module._findPath(request, paths, isMain, false);
-  if (filename) return filename;
-  const requireStack = [];
-  for (let cursor = parent;
-    cursor;
-    cursor = moduleParentCache.get(cursor)) {
-    ArrayPrototypePush(requireStack, cursor.filename || cursor.id);
-  }
-  let message = `Cannot find module '${request}'`;
-  if (requireStack.length > 0) {
-    message = message + '\nRequire stack:\n- ' +
-              ArrayPrototypeJoin(requireStack, '\n- ');
-  }
-  // eslint-disable-next-line no-restricted-syntax
-  const err = new Error(message);
-  err.code = 'MODULE_NOT_FOUND';
-  err.requireStack = requireStack;
-  throw err;
-};
-
-function finalizeEsmResolution(resolved, parentPath, pkgPath) {
-  if (RegExpPrototypeTest(encodedSepRegEx, resolved))
-    throw new ERR_INVALID_MODULE_SPECIFIER(
-      resolved, 'must not include encoded "/" or "\\" characters', parentPath);
-  const filename = fileURLToPath(resolved);
-  const actual = tryReplacementExtensions(filename) || tryFile(filename);
-  if (actual)
-    return actual;
-  const err = createEsmNotFoundErr(filename,
-                                   path.resolve(pkgPath, 'package.json'));
-  throw err;
-}
-
-function createEsmNotFoundErr(request, path) {
-  // eslint-disable-next-line no-restricted-syntax
-  const err = new Error(`Cannot find module '${request}'`);
-  err.code = 'MODULE_NOT_FOUND';
-  if (path)
-    err.path = path;
-  // TODO(BridgeAR): Add the requireStack as well.
-  return err;
-}
-
-
-return {
-  Module_findPath,
-  Module_resolveFilename
-}
-
-}
-
-/**
- * copied from Module._extensions['.js']
- * https://github.com/nodejs/node/blob/v15.3.0/lib/internal/modules/cjs/loader.js#L1113-L1120
- * @param {import('../src/index').Service} service
- * @param {NodeJS.Module} module
- * @param {string} filename
- */
-function assertScriptCanLoadAsCJSImpl(service, module, filename) {
-  const pkg = readPackageScope(filename);
-
-  // ts-node modification: allow our configuration to override
-  const tsNodeClassification = service.moduleTypeClassifier.classifyModuleByModuleTypeOverrides(normalizeSlashes(filename));
-  if(tsNodeClassification.moduleType === 'cjs') return;
-
-  // ignore package.json when file extension is ESM-only or CJS-only
-  // [MUST_UPDATE_FOR_NEW_FILE_EXTENSIONS]
-  const lastDotIndex = filename.lastIndexOf('.');
-  const ext = lastDotIndex >= 0 ? filename.slice(lastDotIndex) : '';
-
-  if((ext === '.cts' || ext === '.cjs') && tsNodeClassification.moduleType === 'auto') return;
-
-  // Function require shouldn't be used in ES modules.
-  if (ext === '.mts' || ext === '.mjs' || tsNodeClassification.moduleType === 'esm' || (pkg && pkg.data && pkg.data.type === 'module')) {
-    const parentPath = module.parent && module.parent.filename;
-    const packageJsonPath = pkg ? path.resolve(pkg.path, 'package.json') : null;
-    throw createErrRequireEsm(filename, parentPath, packageJsonPath);
-  }
-}
-
-
-module.exports = {
-  createCjsLoader,
-  assertScriptCanLoadAsCJSImpl,
-  readPackageScope
-};
-
-
-/***/ }),
-
-/***/ 77114:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
-
-"use strict";
-// Copied from https://raw.githubusercontent.com/nodejs/node/v15.3.0/lib/internal/modules/esm/get_format.js
-
-
-const {
-  RegExpPrototypeExec,
-  StringPrototypeStartsWith,
-} = __nccwpck_require__(5335);
-const { extname } = __nccwpck_require__(71017);
-const { getOptionValue } = __nccwpck_require__(45519);
-
-const [nodeMajor, nodeMinor] = process.versions.node.split('.').map(s => parseInt(s, 10));
-const experimentalJsonModules =
-  nodeMajor > 17
-  || (nodeMajor === 17 && nodeMinor >= 5)
-  || (nodeMajor === 16 && nodeMinor >= 15)
-  || getOptionValue('--experimental-json-modules');
-const experimentalWasmModules = getOptionValue('--experimental-wasm-modules');
-const { URL, fileURLToPath } = __nccwpck_require__(57310);
-const { ERR_UNKNOWN_FILE_EXTENSION } = (__nccwpck_require__(79944).codes);
-
-const extensionFormatMap = {
-  '__proto__': null,
-  '.cjs': 'commonjs',
-  '.js': 'module',
-  '.mjs': 'module'
-};
-
-const legacyExtensionFormatMap = {
-  '__proto__': null,
-  '.cjs': 'commonjs',
-  '.js': 'commonjs',
-  '.json': 'commonjs',
-  '.mjs': 'module',
-  '.node': 'commonjs'
-};
-
-if (experimentalWasmModules)
-  extensionFormatMap['.wasm'] = legacyExtensionFormatMap['.wasm'] = 'wasm';
-
-if (experimentalJsonModules)
-  extensionFormatMap['.json'] = legacyExtensionFormatMap['.json'] = 'json';
-
-/**
- *
- * @param {'node' | 'explicit'} [tsNodeExperimentalSpecifierResolution]
- * @param {ReturnType<
- *  typeof import('../dist-raw/node-internal-modules-esm-resolve').createResolve
- * >} nodeEsmResolver
- */
-function createGetFormat(tsNodeExperimentalSpecifierResolution, nodeEsmResolver) {
-// const experimentalSpeciferResolution = tsNodeExperimentalSpecifierResolution ?? getOptionValue('--experimental-specifier-resolution');
-let experimentalSpeciferResolution = tsNodeExperimentalSpecifierResolution != null ? tsNodeExperimentalSpecifierResolution : getOptionValue('--experimental-specifier-resolution');
-const { getPackageType } = nodeEsmResolver;
-
-/**
- * @param {string} url
- * @param {{}} context
- * @param {any} defaultGetFormatUnused
- * @returns {ReturnType}
- */
-function defaultGetFormat(url, context, defaultGetFormatUnused) {
-  if (StringPrototypeStartsWith(url, 'node:')) {
-    return { format: 'builtin' };
-  }
-  const parsed = new URL(url);
-  if (parsed.protocol === 'data:') {
-    const [ , mime ] = RegExpPrototypeExec(
-      /^([^/]+\/[^;,]+)(?:[^,]*?)(;base64)?,/,
-      parsed.pathname,
-    ) || [ null, null, null ];
-    const format = ({
-      '__proto__': null,
-      'text/javascript': 'module',
-      'application/json': experimentalJsonModules ? 'json' : null,
-      'application/wasm': experimentalWasmModules ? 'wasm' : null
-    })[mime] || null;
-    return { format };
-  } else if (parsed.protocol === 'file:') {
-    const ext = extname(parsed.pathname);
-    let format;
-    if (ext === '.js') {
-      format = getPackageType(parsed.href) === 'module' ? 'module' : 'commonjs';
-    } else {
-      format = extensionFormatMap[ext];
-    }
-    if (!format) {
-      if (experimentalSpeciferResolution === 'node') {
-        process.emitWarning(
-          'The Node.js specifier resolution in ESM is experimental.',
-          'ExperimentalWarning');
-        format = legacyExtensionFormatMap[ext];
-      } else {
-        throw new ERR_UNKNOWN_FILE_EXTENSION(ext, fileURLToPath(url));
-      }
-    }
-    return { format: format || null };
-  }
-  return { format: null };
-}
-
-return {defaultGetFormat};
-}
-
-module.exports = {
-  createGetFormat
-};
-
-
-/***/ }),
-
-/***/ 83788:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
-
-"use strict";
-// Copied from https://raw.githubusercontent.com/nodejs/node/v15.3.0/lib/internal/modules/esm/resolve.js
-
-
-
-const {versionGteLt} = __nccwpck_require__(81842);
-
-// Test for node >14.13.1 || (>=12.20.0 && <13)
-const builtinModuleProtocol =
-  versionGteLt(process.versions.node, '14.13.1') ||
-  versionGteLt(process.versions.node, '12.20.0', '13.0.0')
-    ? 'node:'
-    : 'nodejs:';
-
-const {
-  ArrayIsArray,
-  ArrayPrototypeJoin,
-  ArrayPrototypeShift,
-  JSONParse,
-  JSONStringify,
-  ObjectFreeze,
-  ObjectGetOwnPropertyNames,
-  ObjectPrototypeHasOwnProperty,
-  RegExpPrototypeTest,
-  SafeMap,
-  SafeSet,
-  StringPrototypeEndsWith,
-  StringPrototypeIndexOf,
-  StringPrototypeLastIndexOf,
-  StringPrototypeReplace,
-  StringPrototypeSlice,
-  StringPrototypeSplit,
-  StringPrototypeStartsWith,
-  StringPrototypeSubstr,
-} = __nccwpck_require__(5335);
-
-// const internalFS = require('internal/fs/utils');
-const Module = __nccwpck_require__(98188);
-const { NativeModule } = __nccwpck_require__(10765);
-const {
-  realpathSync,
-  statSync,
-  Stats,
-} = __nccwpck_require__(57147);
-// const { getOptionValue } = require('internal/options');
-const { getOptionValue } = __nccwpck_require__(45519);
-// // Do not eagerly grab .manifest, it may be in TDZ
-// const policy = getOptionValue('--experimental-policy') ?
-//   require('internal/process/policy') :
-//   null;
-// disabled for now.  I am not sure if/how we should support this
-const policy = null;
-const { sep, relative } = __nccwpck_require__(71017);
-const preserveSymlinks = getOptionValue('--preserve-symlinks');
-const preserveSymlinksMain = getOptionValue('--preserve-symlinks-main');
-const typeFlag = getOptionValue('--input-type');
-// const { URL, pathToFileURL, fileURLToPath } = require('internal/url');
-const { URL, pathToFileURL, fileURLToPath } = __nccwpck_require__(57310);
-const {
-  ERR_INPUT_TYPE_NOT_ALLOWED,
-  ERR_INVALID_ARG_VALUE,
-  ERR_INVALID_MODULE_SPECIFIER,
-  ERR_INVALID_PACKAGE_CONFIG,
-  ERR_INVALID_PACKAGE_TARGET,
-  ERR_MANIFEST_DEPENDENCY_MISSING,
-  ERR_MODULE_NOT_FOUND,
-  ERR_PACKAGE_IMPORT_NOT_DEFINED,
-  ERR_PACKAGE_PATH_NOT_EXPORTED,
-  ERR_UNSUPPORTED_DIR_IMPORT,
-  ERR_UNSUPPORTED_ESM_URL_SCHEME,
-// } = require('internal/errors').codes;
-} = (__nccwpck_require__(79944).codes);
-
-// const { Module: CJSModule } = require('internal/modules/cjs/loader');
-const CJSModule = Module;
-
-// const packageJsonReader = require('internal/modules/package_json_reader');
-const packageJsonReader = __nccwpck_require__(19867);
-const userConditions = getOptionValue('--conditions');
-const DEFAULT_CONDITIONS = ObjectFreeze(['node', 'import', ...userConditions]);
-const DEFAULT_CONDITIONS_SET = new SafeSet(DEFAULT_CONDITIONS);
-
-const pendingDeprecation = getOptionValue('--pending-deprecation');
-
-/**
- * @param {{
- *  extensions: import('../src/file-extensions').Extensions,
- *  preferTsExts: boolean | undefined;
- *  tsNodeExperimentalSpecifierResolution: import('../src/index').ExperimentalSpecifierResolution | undefined;
- * }} opts
- */
-function createResolve(opts) {
-// TODO receive cached fs implementations here
-const {preferTsExts, tsNodeExperimentalSpecifierResolution, extensions} = opts;
-const esrnExtensions = extensions.experimentalSpecifierResolutionAddsIfOmitted;
-const {legacyMainResolveAddsIfOmitted, replacementsForCjs, replacementsForJs, replacementsForMjs, replacementsForJsx} = extensions;
-// const experimentalSpecifierResolution = tsNodeExperimentalSpecifierResolution ?? getOptionValue('--experimental-specifier-resolution');
-const experimentalSpecifierResolution = tsNodeExperimentalSpecifierResolution != null ? tsNodeExperimentalSpecifierResolution : getOptionValue('--experimental-specifier-resolution');
-
-const emittedPackageWarnings = new SafeSet();
-function emitFolderMapDeprecation(match, pjsonUrl, isExports, base) {
-  const pjsonPath = fileURLToPath(pjsonUrl);
-  if (!pendingDeprecation) {
-    const nodeModulesIndex = StringPrototypeLastIndexOf(pjsonPath,
-                                                        '/node_modules/');
-    if (nodeModulesIndex !== -1) {
-      const afterNodeModulesPath = StringPrototypeSlice(pjsonPath,
-                                                        nodeModulesIndex + 14,
-                                                        -13);
-      try {
-        const { packageSubpath } = parsePackageName(afterNodeModulesPath);
-        if (packageSubpath === '.')
-          return;
-      } catch {}
-    }
-  }
-  if (emittedPackageWarnings.has(pjsonPath + '|' + match))
-    return;
-  emittedPackageWarnings.add(pjsonPath + '|' + match);
-  process.emitWarning(
-    `Use of deprecated folder mapping "${match}" in the ${isExports ?
-      '"exports"' : '"imports"'} field module resolution of the package at ${
-      pjsonPath}${base ? ` imported from ${fileURLToPath(base)}` : ''}.\n` +
-      `Update this package.json to use a subpath pattern like "${match}*".`,
-    'DeprecationWarning',
-    'DEP0148'
-  );
-}
-
-function getConditionsSet(conditions) {
-  if (conditions !== undefined && conditions !== DEFAULT_CONDITIONS) {
-    if (!ArrayIsArray(conditions)) {
-      throw new ERR_INVALID_ARG_VALUE('conditions', conditions,
-                                      'expected an array');
-    }
-    return new SafeSet(conditions);
-  }
-  return DEFAULT_CONDITIONS_SET;
-}
-
-const realpathCache = new SafeMap();
-const packageJSONCache = new SafeMap();  /* string -> PackageConfig */
-
-const statSupportsThrowIfNoEntry = versionGteLt(process.versions.node, '15.3.0') ||
-  versionGteLt(process.versions.node, '14.17.0', '15.0.0');
-const tryStatSync = statSupportsThrowIfNoEntry ? tryStatSyncWithoutErrors : tryStatSyncWithErrors;
-const statsIfNotFound = new Stats();
-function tryStatSyncWithoutErrors(path) {
-  const stats = statSync(path, { throwIfNoEntry: false });
-  if(stats != null) return stats;
-  return statsIfNotFound;
-}
-function tryStatSyncWithErrors(path) {
-  try {
-    return statSync(path);
-  } catch {
-    return statsIfNotFound;
-  }
-}
-
-function getPackageConfig(path, specifier, base) {
-  const existing = packageJSONCache.get(path);
-  if (existing !== undefined) {
-    return existing;
-  }
-  const source = packageJsonReader.read(path).string;
-  if (source === undefined) {
-    const packageConfig = {
-      pjsonPath: path,
-      exists: false,
-      main: undefined,
-      name: undefined,
-      type: 'none',
-      exports: undefined,
-      imports: undefined,
-    };
-    packageJSONCache.set(path, packageConfig);
-    return packageConfig;
-  }
-
-  let packageJSON;
-  try {
-    packageJSON = JSONParse(source);
-  } catch (error) {
-    throw new ERR_INVALID_PACKAGE_CONFIG(
-      path,
-      (base ? `"${specifier}" from ` : '') + fileURLToPath(base || specifier),
-      error.message
-    );
-  }
-
-  let { imports, main, name, type } = packageJSON;
-  const { exports } = packageJSON;
-  if (typeof imports !== 'object' || imports === null) imports = undefined;
-  if (typeof main !== 'string') main = undefined;
-  if (typeof name !== 'string') name = undefined;
-  // Ignore unknown types for forwards compatibility
-  if (type !== 'module' && type !== 'commonjs') type = 'none';
-
-  const packageConfig = {
-    pjsonPath: path,
-    exists: true,
-    main,
-    name,
-    type,
-    exports,
-    imports,
-  };
-  packageJSONCache.set(path, packageConfig);
-  return packageConfig;
-}
-
-function getPackageScopeConfig(resolved) {
-  let packageJSONUrl = new URL('./package.json', resolved);
-  while (true) {
-    const packageJSONPath = packageJSONUrl.pathname;
-    if (StringPrototypeEndsWith(packageJSONPath, 'node_modules/package.json'))
-      break;
-    const packageConfig = getPackageConfig(fileURLToPath(packageJSONUrl),
-                                           resolved);
-    if (packageConfig.exists) return packageConfig;
-
-    const lastPackageJSONUrl = packageJSONUrl;
-    packageJSONUrl = new URL('../package.json', packageJSONUrl);
-
-    // Terminates at root where ../package.json equals ../../package.json
-    // (can't just check "/package.json" for Windows support).
-    if (packageJSONUrl.pathname === lastPackageJSONUrl.pathname) break;
-  }
-  const packageJSONPath = fileURLToPath(packageJSONUrl);
-  const packageConfig = {
-    pjsonPath: packageJSONPath,
-    exists: false,
-    main: undefined,
-    name: undefined,
-    type: 'none',
-    exports: undefined,
-    imports: undefined,
-  };
-  packageJSONCache.set(packageJSONPath, packageConfig);
-  return packageConfig;
-}
-
-/*
- * Legacy CommonJS main resolution:
- * 1. let M = pkg_url + (json main field)
- * 2. TRY(M, M.js, M.json, M.node)
- * 3. TRY(M/index.js, M/index.json, M/index.node)
- * 4. TRY(pkg_url/index.js, pkg_url/index.json, pkg_url/index.node)
- * 5. NOT_FOUND
- */
-function fileExists(url) {
-  return tryStatSync(fileURLToPath(url)).isFile();
-}
-
-function legacyMainResolve(packageJSONUrl, packageConfig, base) {
-  let guess;
-  if (packageConfig.main !== undefined) {
-    // Note: fs check redundances will be handled by Descriptor cache here.
-    if(guess = resolveReplacementExtensions(new URL(`./${packageConfig.main}`, packageJSONUrl))) {
-      return guess;
-    }
-    if (fileExists(guess = new URL(`./${packageConfig.main}`,
-                                   packageJSONUrl))) {
-      return guess;
-    }
-    for(const extension of legacyMainResolveAddsIfOmitted) {
-      if (fileExists(guess = new URL(`./${packageConfig.main}${extension}`,
-                                    packageJSONUrl))) {
-        return guess;
-      }
-    }
-    for(const extension of legacyMainResolveAddsIfOmitted) {
-      if (fileExists(guess = new URL(`./${packageConfig.main}/index${extension}`,
-                                    packageJSONUrl))) {
-        return guess;
-      }
-    }
-    // Fallthrough.
-  }
-  for(const extension of legacyMainResolveAddsIfOmitted) {
-    if (fileExists(guess = new URL(`./index${extension}`, packageJSONUrl))) {
-      return guess;
-    }
-  }
-  // Not found.
-  throw new ERR_MODULE_NOT_FOUND(
-    fileURLToPath(new URL('.', packageJSONUrl)), fileURLToPath(base));
-}
-
-/** attempts replacement extensions, then tries exact name, then attempts appending extensions */
-function resolveExtensionsWithTryExactName(search) {
-  const resolvedReplacementExtension = resolveReplacementExtensions(search);
-  if(resolvedReplacementExtension) return resolvedReplacementExtension;
-  if (fileExists(search)) return search;
-  return resolveExtensions(search);
-}
-
-// This appends missing extensions
-function resolveExtensions(search) {
-  for (let i = 0; i < esrnExtensions.length; i++) {
-    const extension = esrnExtensions[i];
-    const guess = new URL(`${search.pathname}${extension}`, search);
-    if (fileExists(guess)) return guess;
-  }
-  return undefined;
-}
-
-/** This replaces JS with TS extensions */
-function resolveReplacementExtensions(search) {
-  const lastDotIndex = search.pathname.lastIndexOf('.');
-  if(lastDotIndex >= 0) {
-    const ext = search.pathname.slice(lastDotIndex);
-    if (ext === '.js' || ext === '.jsx' || ext === '.mjs' || ext === '.cjs') {
-      const pathnameWithoutExtension = search.pathname.slice(0, lastDotIndex);
-      const replacementExts =
-        ext === '.js' ? replacementsForJs
-        : ext === '.jsx' ? replacementsForJsx
-        : ext === '.mjs' ? replacementsForMjs
-        : replacementsForCjs;
-      const guess = new URL(search.toString());
-      for (let i = 0; i < replacementExts.length; i++) {
-        const extension = replacementExts[i];
-        guess.pathname = `${pathnameWithoutExtension}${extension}`;
-        if (fileExists(guess)) return guess;
-      }
-    }
-  }
-  return undefined;
-}
-
-function resolveIndex(search) {
-  return resolveExtensions(new URL('index', search));
-}
-
-const encodedSepRegEx = /%2F|%2C/i;
-function finalizeResolution(resolved, base) {
-  if (RegExpPrototypeTest(encodedSepRegEx, resolved.pathname))
-    throw new ERR_INVALID_MODULE_SPECIFIER(
-      resolved.pathname, 'must not include encoded "/" or "\\" characters',
-      fileURLToPath(base));
-
-  if (experimentalSpecifierResolution === 'node') {
-    const path = fileURLToPath(resolved);
-    let file = resolveExtensionsWithTryExactName(resolved);
-    if (file !== undefined) return file;
-    if (!StringPrototypeEndsWith(path, '/')) {
-      file = resolveIndex(new URL(`${resolved}/`));
-      if (file !== undefined) return file;
-    } else {
-      return resolveIndex(resolved) || resolved;
-    }
-    throw new ERR_MODULE_NOT_FOUND(
-      resolved.pathname, fileURLToPath(base), 'module');
-  }
-
-  const file = resolveReplacementExtensions(resolved) || resolved;
-  const path = fileURLToPath(file);
-
-  const stats = tryStatSync(StringPrototypeEndsWith(path, '/') ?
-    StringPrototypeSlice(path, -1) : path);
-  if (stats.isDirectory()) {
-    const err = new ERR_UNSUPPORTED_DIR_IMPORT(path, fileURLToPath(base));
-    err.url = String(resolved);
-    throw err;
-  } else if (!stats.isFile()) {
-    throw new ERR_MODULE_NOT_FOUND(
-      path || resolved.pathname, fileURLToPath(base), 'module');
-  }
-
-  return file;
-}
-
-function throwImportNotDefined(specifier, packageJSONUrl, base) {
-  throw new ERR_PACKAGE_IMPORT_NOT_DEFINED(
-    specifier, packageJSONUrl && fileURLToPath(new URL('.', packageJSONUrl)),
-    fileURLToPath(base));
-}
-
-function throwExportsNotFound(subpath, packageJSONUrl, base) {
-  throw new ERR_PACKAGE_PATH_NOT_EXPORTED(
-    fileURLToPath(new URL('.', packageJSONUrl)), subpath,
-    base && fileURLToPath(base));
-}
-
-function throwInvalidSubpath(subpath, packageJSONUrl, internal, base) {
-  const reason = `request is not a valid subpath for the "${internal ?
-    'imports' : 'exports'}" resolution of ${fileURLToPath(packageJSONUrl)}`;
-  throw new ERR_INVALID_MODULE_SPECIFIER(subpath, reason,
-                                         base && fileURLToPath(base));
-}
-
-function throwInvalidPackageTarget(
-  subpath, target, packageJSONUrl, internal, base) {
-  if (typeof target === 'object' && target !== null) {
-    target = JSONStringify(target, null, '');
-  } else {
-    target = `${target}`;
-  }
-  throw new ERR_INVALID_PACKAGE_TARGET(
-    fileURLToPath(new URL('.', packageJSONUrl)), subpath, target,
-    internal, base && fileURLToPath(base));
-}
-
-const invalidSegmentRegEx = /(^|\\|\/)(\.\.?|node_modules)(\\|\/|$)/;
-const patternRegEx = /\*/g;
-
-function resolvePackageTargetString(
-  target, subpath, match, packageJSONUrl, base, pattern, internal, conditions) {
-  if (subpath !== '' && !pattern && target[target.length - 1] !== '/')
-    throwInvalidPackageTarget(match, target, packageJSONUrl, internal, base);
-
-  if (!StringPrototypeStartsWith(target, './')) {
-    if (internal && !StringPrototypeStartsWith(target, '../') &&
-        !StringPrototypeStartsWith(target, '/')) {
-      let isURL = false;
-      try {
-        new URL(target);
-        isURL = true;
-      } catch {}
-      if (!isURL) {
-        const exportTarget = pattern ?
-          StringPrototypeReplace(target, patternRegEx, subpath) :
-          target + subpath;
-        return packageResolve(exportTarget, packageJSONUrl, conditions);
-      }
-    }
-    throwInvalidPackageTarget(match, target, packageJSONUrl, internal, base);
-  }
-
-  if (RegExpPrototypeTest(invalidSegmentRegEx, StringPrototypeSlice(target, 2)))
-    throwInvalidPackageTarget(match, target, packageJSONUrl, internal, base);
-
-  const resolved = new URL(target, packageJSONUrl);
-  const resolvedPath = resolved.pathname;
-  const packagePath = new URL('.', packageJSONUrl).pathname;
-
-  if (!StringPrototypeStartsWith(resolvedPath, packagePath))
-    throwInvalidPackageTarget(match, target, packageJSONUrl, internal, base);
-
-  if (subpath === '') return resolved;
-
-  if (RegExpPrototypeTest(invalidSegmentRegEx, subpath))
-    throwInvalidSubpath(match + subpath, packageJSONUrl, internal, base);
-
-  if (pattern)
-    return new URL(StringPrototypeReplace(resolved.href, patternRegEx,
-                                          subpath));
-  return new URL(subpath, resolved);
-}
-
-/**
- * @param {string} key
- * @returns {boolean}
- */
-function isArrayIndex(key) {
-  const keyNum = +key;
-  if (`${keyNum}` !== key) return false;
-  return keyNum >= 0 && keyNum < 0xFFFF_FFFF;
-}
-
-function resolvePackageTarget(packageJSONUrl, target, subpath, packageSubpath,
-                              base, pattern, internal, conditions) {
-  if (typeof target === 'string') {
-    return resolvePackageTargetString(
-      target, subpath, packageSubpath, packageJSONUrl, base, pattern, internal,
-      conditions);
-  } else if (ArrayIsArray(target)) {
-    if (target.length === 0)
-      return null;
-
-    let lastException;
-    for (let i = 0; i < target.length; i++) {
-      const targetItem = target[i];
-      let resolved;
-      try {
-        resolved = resolvePackageTarget(
-          packageJSONUrl, targetItem, subpath, packageSubpath, base, pattern,
-          internal, conditions);
-      } catch (e) {
-        lastException = e;
-        if (e.code === 'ERR_INVALID_PACKAGE_TARGET')
-          continue;
-        throw e;
-      }
-      if (resolved === undefined)
-        continue;
-      if (resolved === null) {
-        lastException = null;
-        continue;
-      }
-      return resolved;
-    }
-    if (lastException === undefined || lastException === null)
-      return lastException;
-    throw lastException;
-  } else if (typeof target === 'object' && target !== null) {
-    const keys = ObjectGetOwnPropertyNames(target);
-    for (let i = 0; i < keys.length; i++) {
-      const key = keys[i];
-      if (isArrayIndex(key)) {
-        throw new ERR_INVALID_PACKAGE_CONFIG(
-          fileURLToPath(packageJSONUrl), base,
-          '"exports" cannot contain numeric property keys.');
-      }
-    }
-    for (let i = 0; i < keys.length; i++) {
-      const key = keys[i];
-      if (key === 'default' || conditions.has(key)) {
-        const conditionalTarget = target[key];
-        const resolved = resolvePackageTarget(
-          packageJSONUrl, conditionalTarget, subpath, packageSubpath, base,
-          pattern, internal, conditions);
-        if (resolved === undefined)
-          continue;
-        return resolved;
-      }
-    }
-    return undefined;
-  } else if (target === null) {
-    return null;
-  }
-  throwInvalidPackageTarget(packageSubpath, target, packageJSONUrl, internal,
-                            base);
-}
-
-function isConditionalExportsMainSugar(exports, packageJSONUrl, base) {
-  if (typeof exports === 'string' || ArrayIsArray(exports)) return true;
-  if (typeof exports !== 'object' || exports === null) return false;
-
-  const keys = ObjectGetOwnPropertyNames(exports);
-  let isConditionalSugar = false;
-  let i = 0;
-  for (let j = 0; j < keys.length; j++) {
-    const key = keys[j];
-    const curIsConditionalSugar = key === '' || key[0] !== '.';
-    if (i++ === 0) {
-      isConditionalSugar = curIsConditionalSugar;
-    } else if (isConditionalSugar !== curIsConditionalSugar) {
-      throw new ERR_INVALID_PACKAGE_CONFIG(
-        fileURLToPath(packageJSONUrl), base,
-        '"exports" cannot contain some keys starting with \'.\' and some not.' +
-        ' The exports object must either be an object of package subpath keys' +
-        ' or an object of main entry condition name keys only.');
-    }
-  }
-  return isConditionalSugar;
-}
-
-/**
- * @param {URL} packageJSONUrl
- * @param {string} packageSubpath
- * @param {object} packageConfig
- * @param {string} base
- * @param {Set} conditions
- * @returns {{resolved: URL, exact: boolean}}
- */
-function packageExportsResolve(
-  packageJSONUrl, packageSubpath, packageConfig, base, conditions) {
-  let exports = packageConfig.exports;
-  if (isConditionalExportsMainSugar(exports, packageJSONUrl, base))
-    exports = { '.': exports };
-
-  if (ObjectPrototypeHasOwnProperty(exports, packageSubpath)) {
-    const target = exports[packageSubpath];
-    const resolved = resolvePackageTarget(
-      packageJSONUrl, target, '', packageSubpath, base, false, false, conditions
-    );
-    if (resolved === null || resolved === undefined)
-      throwExportsNotFound(packageSubpath, packageJSONUrl, base);
-    return { resolved, exact: true };
-  }
-
-  let bestMatch = '';
-  const keys = ObjectGetOwnPropertyNames(exports);
-  for (let i = 0; i < keys.length; i++) {
-    const key = keys[i];
-    if (key[key.length - 1] === '*' &&
-        StringPrototypeStartsWith(packageSubpath,
-                                  StringPrototypeSlice(key, 0, -1)) &&
-        packageSubpath.length >= key.length &&
-        key.length > bestMatch.length) {
-      bestMatch = key;
-    } else if (key[key.length - 1] === '/' &&
-      StringPrototypeStartsWith(packageSubpath, key) &&
-      key.length > bestMatch.length) {
-      bestMatch = key;
-    }
-  }
-
-  if (bestMatch) {
-    const target = exports[bestMatch];
-    const pattern = bestMatch[bestMatch.length - 1] === '*';
-    const subpath = StringPrototypeSubstr(packageSubpath, bestMatch.length -
-      (pattern ? 1 : 0));
-    const resolved = resolvePackageTarget(packageJSONUrl, target, subpath,
-                                          bestMatch, base, pattern, false,
-                                          conditions);
-    if (resolved === null || resolved === undefined)
-      throwExportsNotFound(packageSubpath, packageJSONUrl, base);
-    if (!pattern)
-      emitFolderMapDeprecation(bestMatch, packageJSONUrl, true, base);
-    return { resolved, exact: pattern };
-  }
-
-  throwExportsNotFound(packageSubpath, packageJSONUrl, base);
-}
-
-function packageImportsResolve(name, base, conditions) {
-  if (name === '#' || StringPrototypeStartsWith(name, '#/')) {
-    const reason = 'is not a valid internal imports specifier name';
-    throw new ERR_INVALID_MODULE_SPECIFIER(name, reason, fileURLToPath(base));
-  }
-  let packageJSONUrl;
-  const packageConfig = getPackageScopeConfig(base);
-  if (packageConfig.exists) {
-    packageJSONUrl = pathToFileURL(packageConfig.pjsonPath);
-    const imports = packageConfig.imports;
-    if (imports) {
-      if (ObjectPrototypeHasOwnProperty(imports, name)) {
-        const resolved = resolvePackageTarget(
-          packageJSONUrl, imports[name], '', name, base, false, true, conditions
-        );
-        if (resolved !== null)
-          return { resolved, exact: true };
-      } else {
-        let bestMatch = '';
-        const keys = ObjectGetOwnPropertyNames(imports);
-        for (let i = 0; i < keys.length; i++) {
-          const key = keys[i];
-          if (key[key.length - 1] === '*' &&
-              StringPrototypeStartsWith(name,
-                                        StringPrototypeSlice(key, 0, -1)) &&
-              name.length >= key.length &&
-              key.length > bestMatch.length) {
-            bestMatch = key;
-          } else if (key[key.length - 1] === '/' &&
-            StringPrototypeStartsWith(name, key) &&
-            key.length > bestMatch.length) {
-            bestMatch = key;
-          }
-        }
-
-        if (bestMatch) {
-          const target = imports[bestMatch];
-          const pattern = bestMatch[bestMatch.length - 1] === '*';
-          const subpath = StringPrototypeSubstr(name, bestMatch.length -
-            (pattern ? 1 : 0));
-          const resolved = resolvePackageTarget(
-            packageJSONUrl, target, subpath, bestMatch, base, pattern, true,
-            conditions);
-          if (resolved !== null) {
-            if (!pattern)
-              emitFolderMapDeprecation(bestMatch, packageJSONUrl, false, base);
-            return { resolved, exact: pattern };
-          }
-        }
-      }
-    }
-  }
-  throwImportNotDefined(name, packageJSONUrl, base);
-}
-
-function getPackageType(url) {
-  const packageConfig = getPackageScopeConfig(url);
-  return packageConfig.type;
-}
-
-function parsePackageName(specifier, base) {
-  let separatorIndex = StringPrototypeIndexOf(specifier, '/');
-  let validPackageName = true;
-  let isScoped = false;
-  if (specifier[0] === '@') {
-    isScoped = true;
-    if (separatorIndex === -1 || specifier.length === 0) {
-      validPackageName = false;
-    } else {
-      separatorIndex = StringPrototypeIndexOf(
-        specifier, '/', separatorIndex + 1);
-    }
-  }
-
-  const packageName = separatorIndex === -1 ?
-    specifier : StringPrototypeSlice(specifier, 0, separatorIndex);
-
-  // Package name cannot have leading . and cannot have percent-encoding or
-  // separators.
-  for (let i = 0; i < packageName.length; i++) {
-    if (packageName[i] === '%' || packageName[i] === '\\') {
-      validPackageName = false;
-      break;
-    }
-  }
-
-  if (!validPackageName) {
-    throw new ERR_INVALID_MODULE_SPECIFIER(
-      specifier, 'is not a valid package name', fileURLToPath(base));
-  }
-
-  const packageSubpath = '.' + (separatorIndex === -1 ? '' :
-    StringPrototypeSlice(specifier, separatorIndex));
-
-  return { packageName, packageSubpath, isScoped };
-}
-
-/**
- * @param {string} specifier
- * @param {URL} base
- * @param {Set} conditions
- * @returns {URL}
- */
-function packageResolve(specifier, base, conditions) {
-  const { packageName, packageSubpath, isScoped } =
-    parsePackageName(specifier, base);
-
-  // ResolveSelf
-  const packageConfig = getPackageScopeConfig(base);
-  if (packageConfig.exists) {
-    const packageJSONUrl = pathToFileURL(packageConfig.pjsonPath);
-    if (packageConfig.name === packageName &&
-        packageConfig.exports !== undefined && packageConfig.exports !== null) {
-      return packageExportsResolve(
-        packageJSONUrl, packageSubpath, packageConfig, base, conditions
-      ).resolved;
-    }
-  }
-
-  let packageJSONUrl =
-    new URL('./node_modules/' + packageName + '/package.json', base);
-  let packageJSONPath = fileURLToPath(packageJSONUrl);
-  let lastPath;
-  do {
-    const stat = tryStatSync(StringPrototypeSlice(packageJSONPath, 0,
-                                                  packageJSONPath.length - 13));
-    if (!stat.isDirectory()) {
-      lastPath = packageJSONPath;
-      packageJSONUrl = new URL((isScoped ?
-        '../../../../node_modules/' : '../../../node_modules/') +
-        packageName + '/package.json', packageJSONUrl);
-      packageJSONPath = fileURLToPath(packageJSONUrl);
-      continue;
-    }
-
-    // Package match.
-    const packageConfig = getPackageConfig(packageJSONPath, specifier, base);
-    if (packageConfig.exports !== undefined && packageConfig.exports !== null)
-      return packageExportsResolve(
-        packageJSONUrl, packageSubpath, packageConfig, base, conditions
-      ).resolved;
-    if (packageSubpath === '.')
-      return legacyMainResolve(packageJSONUrl, packageConfig, base);
-    return new URL(packageSubpath, packageJSONUrl);
-    // Cross-platform root check.
-  } while (packageJSONPath.length !== lastPath.length);
-
-  // eslint can't handle the above code.
-  // eslint-disable-next-line no-unreachable
-  throw new ERR_MODULE_NOT_FOUND(packageName, fileURLToPath(base));
-}
-
-function isBareSpecifier(specifier) {
-  return specifier[0] && specifier[0] !== '/' && specifier[0] !== '.';
-}
-
-function isRelativeSpecifier(specifier) {
-  if (specifier[0] === '.') {
-    if (specifier.length === 1 || specifier[1] === '/') return true;
-    if (specifier[1] === '.') {
-      if (specifier.length === 2 || specifier[2] === '/') return true;
-    }
-  }
-  return false;
-}
-
-function shouldBeTreatedAsRelativeOrAbsolutePath(specifier) {
-  if (specifier === '') return false;
-  if (specifier[0] === '/') return true;
-  return isRelativeSpecifier(specifier);
-}
-
-/**
- * @param {string} specifier
- * @param {URL} base
- * @param {Set} conditions
- * @returns {URL}
- */
-function moduleResolve(specifier, base, conditions) {
-  // Order swapped from spec for minor perf gain.
-  // Ok since relative URLs cannot parse as URLs.
-  let resolved;
-  if (shouldBeTreatedAsRelativeOrAbsolutePath(specifier)) {
-    resolved = new URL(specifier, base);
-  } else if (specifier[0] === '#') {
-    ({ resolved } = packageImportsResolve(specifier, base, conditions));
-  } else {
-    try {
-      resolved = new URL(specifier);
-    } catch {
-      resolved = packageResolve(specifier, base, conditions);
-    }
-  }
-  return finalizeResolution(resolved, base);
-}
-
-/**
- * Try to resolve an import as a CommonJS module
- * @param {string} specifier
- * @param {string} parentURL
- * @returns {boolean|string}
- */
-function resolveAsCommonJS(specifier, parentURL) {
-  try {
-    const parent = fileURLToPath(parentURL);
-    const tmpModule = new CJSModule(parent, null);
-    tmpModule.paths = CJSModule._nodeModulePaths(parent);
-
-    let found = CJSModule._resolveFilename(specifier, tmpModule, false);
-
-    // If it is a relative specifier return the relative path
-    // to the parent
-    if (isRelativeSpecifier(specifier)) {
-      found = relative(parent, found);
-      // Add '.separator if the path does not start with '..separator'
-      // This should be a safe assumption because when loading
-      // esm modules there should be always a file specified so
-      // there should not be a specifier like '..' or '.'
-      if (!StringPrototypeStartsWith(found, `..${sep}`)) {
-        found = `.${sep}${found}`;
-      }
-    } else if (isBareSpecifier(specifier)) {
-      // If it is a bare specifier return the relative path within the
-      // module
-      const pkg = StringPrototypeSplit(specifier, '/')[0];
-      const index = StringPrototypeIndexOf(found, pkg);
-      if (index !== -1) {
-        found = StringPrototypeSlice(found, index);
-      }
-    }
-    // Normalize the path separator to give a valid suggestion
-    // on Windows
-    if (process.platform === 'win32') {
-      found = StringPrototypeReplace(found, new RegExp(`\\${sep}`, 'g'), '/');
-    }
-    return found;
-  } catch {
-    return false;
-  }
-}
-
-function defaultResolve(specifier, context = {}, defaultResolveUnused) {
-  let { parentURL, conditions } = context;
-  if (parentURL && policy != null && policy.manifest) {
-    const redirects = policy.manifest.getDependencyMapper(parentURL);
-    if (redirects) {
-      const { resolve, reaction } = redirects;
-      const destination = resolve(specifier, new SafeSet(conditions));
-      let missing = true;
-      if (destination === true) {
-        missing = false;
-      } else if (destination) {
-        const href = destination.href;
-        return { url: href };
-      }
-      if (missing) {
-        reaction(new ERR_MANIFEST_DEPENDENCY_MISSING(
-          parentURL,
-          specifier,
-          ArrayPrototypeJoin([...conditions], ', '))
-        );
-      }
-    }
-  }
-  let parsed;
-  try {
-    parsed = new URL(specifier);
-    if (parsed.protocol === 'data:') {
-      return {
-        url: specifier
-      };
-    }
-  } catch {}
-  if (parsed && parsed.protocol === builtinModuleProtocol)
-    return { url: specifier };
-  if (parsed && parsed.protocol !== 'file:' && parsed.protocol !== 'data:')
-    throw new ERR_UNSUPPORTED_ESM_URL_SCHEME(parsed);
-  if (NativeModule.canBeRequiredByUsers(specifier)) {
-    return {
-      url: builtinModuleProtocol + specifier
-    };
-  }
-  if (parentURL && StringPrototypeStartsWith(parentURL, 'data:')) {
-    // This is gonna blow up, we want the error
-    new URL(specifier, parentURL);
-  }
-
-  const isMain = parentURL === undefined;
-  if (isMain) {
-    parentURL = pathToFileURL(`${process.cwd()}/`).href;
-
-    // This is the initial entry point to the program, and --input-type has
-    // been passed as an option; but --input-type can only be used with
-    // --eval, --print or STDIN string input. It is not allowed with file
-    // input, to avoid user confusion over how expansive the effect of the
-    // flag should be (i.e. entry point only, package scope surrounding the
-    // entry point, etc.).
-    if (typeFlag)
-      throw new ERR_INPUT_TYPE_NOT_ALLOWED();
-  }
-
-  conditions = getConditionsSet(conditions);
-  let url;
-  try {
-    url = moduleResolve(specifier, parentURL, conditions);
-  } catch (error) {
-    // Try to give the user a hint of what would have been the
-    // resolved CommonJS module
-    if (error.code === 'ERR_MODULE_NOT_FOUND' ||
-        error.code === 'ERR_UNSUPPORTED_DIR_IMPORT') {
-      if (StringPrototypeStartsWith(specifier, 'file://')) {
-        specifier = fileURLToPath(specifier);
-      }
-      const found = resolveAsCommonJS(specifier, parentURL);
-      if (found) {
-        // Modify the stack and message string to include the hint
-        const lines = StringPrototypeSplit(error.stack, '\n');
-        const hint = `Did you mean to import ${found}?`;
-        error.stack =
-          ArrayPrototypeShift(lines) + '\n' +
-          hint + '\n' +
-          ArrayPrototypeJoin(lines, '\n');
-        error.message += `\n${hint}`;
-      }
-    }
-    throw error;
-  }
-
-  if (isMain ? !preserveSymlinksMain : !preserveSymlinks) {
-    const urlPath = fileURLToPath(url);
-    const real = realpathSync(urlPath, {
-      // [internalFS.realpathCacheKey]: realpathCache
-    });
-    const old = url;
-    url = pathToFileURL(
-      real + (StringPrototypeEndsWith(urlPath, sep) ? '/' : ''));
-    url.search = old.search;
-    url.hash = old.hash;
-  }
-
-  return { url: `${url}` };
-}
-
-return {
-  DEFAULT_CONDITIONS,
-  defaultResolve,
-  encodedSepRegEx,
-  getPackageType,
-  packageExportsResolve,
-  packageImportsResolve
-};
-}
-module.exports = {
-  createResolve
-};
-
-
-/***/ }),
-
-/***/ 19867:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
-
-"use strict";
-// copied from https://github.com/nodejs/node/blob/v15.3.0/lib/internal/modules/package_json_reader.js
-
-
-const { SafeMap } = __nccwpck_require__(5335);
-const { internalModuleReadJSON } = __nccwpck_require__(22785);
-const { pathToFileURL } = __nccwpck_require__(57310);
-const { toNamespacedPath } = __nccwpck_require__(71017);
-// const { getOptionValue } = require('./node-options');
-
-const cache = new SafeMap();
-
-let manifest;
-
-/**
- * @param {string} jsonPath
- * @return {{string: string, containsKeys: boolean}}
- */
-function read(jsonPath) {
-  if (cache.has(jsonPath)) {
-    return cache.get(jsonPath);
-  }
-
-  const [string, containsKeys] = internalModuleReadJSON(
-    toNamespacedPath(jsonPath)
-  );
-  const result = { string, containsKeys };
-  if (string !== undefined) {
-    if (manifest === undefined) {
-      // manifest = getOptionValue('--experimental-policy') ?
-      //   require('internal/process/policy').manifest :
-      //   null;
-      // disabled for now.  I am not sure if/how we should support this
-      manifest = null;
-    }
-    if (manifest !== null) {
-      const jsonURL = pathToFileURL(jsonPath);
-      manifest.assertIntegrity(jsonURL, string);
-    }
-  }
-  cache.set(jsonPath, result);
-  return result;
-}
-
-module.exports = { read };
-
-
-/***/ }),
-
-/***/ 43803:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
-
-"use strict";
-// copied from https://github.com/nodejs/node/blob/88799930794045795e8abac874730f9eba7e2300/lib/internal/repl/await.js
-
-
-const {
-  ArrayFrom,
-  ArrayPrototypeForEach,
-  ArrayPrototypeIncludes,
-  ArrayPrototypeJoin,
-  ArrayPrototypePop,
-  ArrayPrototypePush,
-  FunctionPrototype,
-  ObjectKeys,
-  RegExpPrototypeSymbolReplace,
-  StringPrototypeEndsWith,
-  StringPrototypeIncludes,
-  StringPrototypeIndexOf,
-  StringPrototypeRepeat,
-  StringPrototypeSplit,
-  StringPrototypeStartsWith,
-  SyntaxError,
-} = __nccwpck_require__(5335);
-
-const parser = (__nccwpck_require__(89761).Parser);
-const walk = __nccwpck_require__(51697);
-const { Recoverable } = __nccwpck_require__(38102);
-
-function isTopLevelDeclaration(state) {
-  return state.ancestors[state.ancestors.length - 2] === state.body;
-}
-
-const noop = FunctionPrototype;
-const visitorsWithoutAncestors = {
-  ClassDeclaration(node, state, c) {
-    if (isTopLevelDeclaration(state)) {
-      state.prepend(node, `${node.id.name}=`);
-      ArrayPrototypePush(
-        state.hoistedDeclarationStatements,
-        `let ${node.id.name}; `
-      );
-    }
-
-    walk.base.ClassDeclaration(node, state, c);
-  },
-  ForOfStatement(node, state, c) {
-    if (node.await === true) {
-      state.containsAwait = true;
-    }
-    walk.base.ForOfStatement(node, state, c);
-  },
-  FunctionDeclaration(node, state, c) {
-    state.prepend(node, `${node.id.name}=`);
-    ArrayPrototypePush(
-      state.hoistedDeclarationStatements,
-      `var ${node.id.name}; `
-    );
-  },
-  FunctionExpression: noop,
-  ArrowFunctionExpression: noop,
-  MethodDefinition: noop,
-  AwaitExpression(node, state, c) {
-    state.containsAwait = true;
-    walk.base.AwaitExpression(node, state, c);
-  },
-  ReturnStatement(node, state, c) {
-    state.containsReturn = true;
-    walk.base.ReturnStatement(node, state, c);
-  },
-  VariableDeclaration(node, state, c) {
-    const variableKind = node.kind;
-    const isIterableForDeclaration = ArrayPrototypeIncludes(
-      ['ForOfStatement', 'ForInStatement'],
-      state.ancestors[state.ancestors.length - 2].type
-    );
-
-    if (variableKind === 'var' || isTopLevelDeclaration(state)) {
-      state.replace(
-        node.start,
-        node.start + variableKind.length + (isIterableForDeclaration ? 1 : 0),
-        variableKind === 'var' && isIterableForDeclaration ?
-          '' :
-          'void' + (node.declarations.length === 1 ? '' : ' (')
-      );
-
-      if (!isIterableForDeclaration) {
-        ArrayPrototypeForEach(node.declarations, (decl) => {
-          state.prepend(decl, '(');
-          state.append(decl, decl.init ? ')' : '=undefined)');
-        });
-
-        if (node.declarations.length !== 1) {
-          state.append(node.declarations[node.declarations.length - 1], ')');
-        }
-      }
-
-      const variableIdentifiersToHoist = [
-        ['var', []],
-        ['let', []],
-      ];
-      function registerVariableDeclarationIdentifiers(node) {
-        switch (node.type) {
-          case 'Identifier':
-            ArrayPrototypePush(
-              variableIdentifiersToHoist[variableKind === 'var' ? 0 : 1][1],
-              node.name
-            );
-            break;
-          case 'ObjectPattern':
-            ArrayPrototypeForEach(node.properties, (property) => {
-              registerVariableDeclarationIdentifiers(property.value);
-            });
-            break;
-          case 'ArrayPattern':
-            ArrayPrototypeForEach(node.elements, (element) => {
-              registerVariableDeclarationIdentifiers(element);
-            });
-            break;
-        }
-      }
-
-      ArrayPrototypeForEach(node.declarations, (decl) => {
-        registerVariableDeclarationIdentifiers(decl.id);
-      });
-
-      ArrayPrototypeForEach(
-        variableIdentifiersToHoist,
-        ({ 0: kind, 1: identifiers }) => {
-          if (identifiers.length > 0) {
-            ArrayPrototypePush(
-              state.hoistedDeclarationStatements,
-              `${kind} ${ArrayPrototypeJoin(identifiers, ', ')}; `
-            );
-          }
-        }
-      );
-    }
-
-    walk.base.VariableDeclaration(node, state, c);
-  }
-};
-
-const visitors = {};
-for (const nodeType of ObjectKeys(walk.base)) {
-  const callback = visitorsWithoutAncestors[nodeType] || walk.base[nodeType];
-  visitors[nodeType] = (node, state, c) => {
-    const isNew = node !== state.ancestors[state.ancestors.length - 1];
-    if (isNew) {
-      ArrayPrototypePush(state.ancestors, node);
-    }
-    callback(node, state, c);
-    if (isNew) {
-      ArrayPrototypePop(state.ancestors);
-    }
-  };
-}
-
-function processTopLevelAwait(src) {
-  const wrapPrefix = '(async () => { ';
-  const wrapped = `${wrapPrefix}${src} })()`;
-  const wrappedArray = ArrayFrom(wrapped);
-  let root;
-  try {
-    root = parser.parse(wrapped, { ecmaVersion: 'latest' });
-  } catch (e) {
-    if (StringPrototypeStartsWith(e.message, 'Unterminated '))
-      throw new Recoverable(e);
-    // If the parse error is before the first "await", then use the execution
-    // error. Otherwise we must emit this parse error, making it look like a
-    // proper syntax error.
-    const awaitPos = StringPrototypeIndexOf(src, 'await');
-    const errPos = e.pos - wrapPrefix.length;
-    if (awaitPos > errPos)
-      return null;
-    // Convert keyword parse errors on await into their original errors when
-    // possible.
-    if (errPos === awaitPos + 6 &&
-        StringPrototypeIncludes(e.message, 'Expecting Unicode escape sequence'))
-      return null;
-    if (errPos === awaitPos + 7 &&
-        StringPrototypeIncludes(e.message, 'Unexpected token'))
-      return null;
-    const line = e.loc.line;
-    const column = line === 1 ? e.loc.column - wrapPrefix.length : e.loc.column;
-    let message = '\n' + StringPrototypeSplit(src, '\n')[line - 1] + '\n' +
-        StringPrototypeRepeat(' ', column) +
-        '^\n\n' + RegExpPrototypeSymbolReplace(/ \([^)]+\)/, e.message, '');
-    // V8 unexpected token errors include the token string.
-    if (StringPrototypeEndsWith(message, 'Unexpected token'))
-      message += " '" +
-        // Wrapper end may cause acorn to report error position after the source
-        ((src.length - 1) >= (e.pos - wrapPrefix.length)
-          ? src[e.pos - wrapPrefix.length]
-          : src[src.length - 1]) +
-        "'";
-    // eslint-disable-next-line no-restricted-syntax
-    throw new SyntaxError(message);
-  }
-  const body = root.body[0].expression.callee.body;
-  const state = {
-    body,
-    ancestors: [],
-    hoistedDeclarationStatements: [],
-    replace(from, to, str) {
-      for (let i = from; i < to; i++) {
-        wrappedArray[i] = '';
-      }
-      if (from === to) str += wrappedArray[from];
-      wrappedArray[from] = str;
-    },
-    prepend(node, str) {
-      wrappedArray[node.start] = str + wrappedArray[node.start];
-    },
-    append(node, str) {
-      wrappedArray[node.end - 1] += str;
-    },
-    containsAwait: false,
-    containsReturn: false
-  };
-
-  walk.recursive(body, state, visitors);
-
-  // Do not transform if
-  // 1. False alarm: there isn't actually an await expression.
-  // 2. There is a top-level return, which is not allowed.
-  if (!state.containsAwait || state.containsReturn) {
-    return null;
-  }
-
-  const last = body.body[body.body.length - 1];
-  if (last.type === 'ExpressionStatement') {
-    // For an expression statement of the form
-    // ( expr ) ;
-    // ^^^^^^^^^^   // last
-    //   ^^^^       // last.expression
-    //
-    // We do not want the left parenthesis before the `return` keyword;
-    // therefore we prepend the `return (` to `last`.
-    //
-    // On the other hand, we do not want the right parenthesis after the
-    // semicolon. Since there can only be more right parentheses between
-    // last.expression.end and the semicolon, appending one more to
-    // last.expression should be fine.
-    state.prepend(last, 'return (');
-    state.append(last.expression, ')');
-  }
-
-  return (
-    ArrayPrototypeJoin(state.hoistedDeclarationStatements, '') +
-    ArrayPrototypeJoin(wrappedArray, '')
-  );
-}
-
-module.exports = {
-  processTopLevelAwait
-};
-
-
-/***/ }),
-
-/***/ 22785:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
-
-const fs = __nccwpck_require__(57147);
-const {versionGteLt} = __nccwpck_require__(81842);
-
-// In node's core, this is implemented in C
-// https://github.com/nodejs/node/blob/v15.3.0/src/node_file.cc#L891-L985
-/**
- * @param {string} path
- * @returns {[] | [string, boolean]}
- */
-function internalModuleReadJSON(path) {
-  let string
-  try {
-    string = fs.readFileSync(path, 'utf8')
-  } catch (e) {
-    if (e.code === 'ENOENT') return []
-    throw e
-  }
-  // Node's implementation checks for the presence of relevant keys: main, name, type, exports, imports
-  // Node does this for performance to skip unnecessary parsing.
-  // This would slow us down and, based on our usage, we can skip it.
-  const containsKeys = true
-  return [string, containsKeys]
-}
-
-// In node's core, this is implemented in C
-// https://github.com/nodejs/node/blob/63e7dc1e5c71b70c80ed9eda230991edb00811e2/src/node_file.cc#L987-L1005
-/**
- * @param {string} path
- * @returns {number} 0 = file, 1 = dir, negative = error
- */
-function internalModuleStat(path) {
-  const stat = fs.statSync(path, { throwIfNoEntry: false });
-  if(!stat) return -1;
-  if(stat.isFile()) return 0;
-  if(stat.isDirectory()) return 1;
-}
-
-/**
- * @param {string} path
- * @returns {number} 0 = file, 1 = dir, negative = error
- */
-function internalModuleStatInefficient(path) {
-  try {
-    const stat = fs.statSync(path);
-    if(stat.isFile()) return 0;
-    if(stat.isDirectory()) return 1;
-  } catch(e) {
-    return -e.errno || -1;
-  }
-}
-
-const statSupportsThrowIfNoEntry = versionGteLt(process.versions.node, '15.3.0') ||
-  versionGteLt(process.versions.node, '14.17.0', '15.0.0');
-
-module.exports = {
-  internalModuleReadJSON,
-  internalModuleStat: statSupportsThrowIfNoEntry ? internalModuleStat : internalModuleStatInefficient
-};
-
-
-/***/ }),
-
-/***/ 10765:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
-
-
-// Node imports this from 'internal/bootstrap/loaders'
-const Module = __nccwpck_require__(98188);
-const NativeModule = {
-  canBeRequiredByUsers(specifier) {
-    return Module.builtinModules.includes(specifier)
-  }
-};
-exports.NativeModule = NativeModule;
-
-
-/***/ }),
-
-/***/ 45519:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
-
-// Replacement for node's internal 'internal/options' module
-
-exports.getOptionValue = getOptionValue;
-function getOptionValue(opt) {
-  parseOptions();
-  return options[opt];
-}
-
-let options;
-function parseOptions() {
-  if (!options) {
-    options = {
-      '--preserve-symlinks': false,
-      '--preserve-symlinks-main': false,
-      '--input-type': undefined,
-      '--experimental-specifier-resolution': 'explicit',
-      '--experimental-policy': undefined,
-      '--conditions': [],
-      '--pending-deprecation': false,
-      ...parseArgv(getNodeOptionsEnvArgv()),
-      ...parseArgv(process.execArgv),
-      ...getOptionValuesFromOtherEnvVars()
-    }
-  }
-}
-
-function parseArgv(argv) {
-  return __nccwpck_require__(13474)({
-    '--preserve-symlinks': Boolean,
-    '--preserve-symlinks-main': Boolean,
-    '--input-type': String,
-    '--experimental-specifier-resolution': String,
-    // Legacy alias for node versions prior to 12.16
-    '--es-module-specifier-resolution': '--experimental-specifier-resolution',
-    '--experimental-policy': String,
-    '--conditions': [String],
-    '--pending-deprecation': Boolean,
-    '--experimental-json-modules': Boolean,
-    '--experimental-wasm-modules': Boolean,
-  }, {
-    argv,
-    permissive: true
-  });
-}
-
-function getNodeOptionsEnvArgv() {
-  const errors = [];
-  const envArgv = ParseNodeOptionsEnvVar(process.env.NODE_OPTIONS || '', errors);
-  if (errors.length !== 0) {
-    // TODO: handle errors somehow
-  }
-  return envArgv;
-}
-
-// Direct JS port of C implementation: https://github.com/nodejs/node/blob/67ba825037b4082d5d16f922fb9ce54516b4a869/src/node_options.cc#L1024-L1063
-function ParseNodeOptionsEnvVar(node_options, errors) {
-  const env_argv = [];
-
-  let is_in_string = false;
-  let will_start_new_arg = true;
-  for (let index = 0; index < node_options.length; ++index) {
-      let c = node_options[index];
-
-      // Backslashes escape the following character
-      if (c === '\\' && is_in_string) {
-          if (index + 1 === node_options.length) {
-              errors.push("invalid value for NODE_OPTIONS " +
-                  "(invalid escape)\n");
-              return env_argv;
-          } else {
-              c = node_options[++index];
-          }
-      } else if (c === ' ' && !is_in_string) {
-          will_start_new_arg = true;
-          continue;
-      } else if (c === '"') {
-          is_in_string = !is_in_string;
-          continue;
-      }
-
-      if (will_start_new_arg) {
-          env_argv.push(c);
-          will_start_new_arg = false;
-      } else {
-          env_argv[env_argv.length - 1] += c;
-      }
-  }
-
-  if (is_in_string) {
-      errors.push("invalid value for NODE_OPTIONS " +
-          "(unterminated string)\n");
-  }
-  return env_argv;
-}
-
-// Get option values that can be specified via env vars besides NODE_OPTIONS
-function getOptionValuesFromOtherEnvVars() {
-  const options = {};
-  if(process.env.NODE_PENDING_DEPRECATION === '1') {
-    options['--pending-deprecation'] = true;
-  }
-  return options;
-}
-
-
-/***/ }),
-
-/***/ 5335:
-/***/ ((module) => {
-
-module.exports = {
-  ArrayFrom: Array.from,
-  ArrayIsArray: Array.isArray,
-  ArrayPrototypeShift: (obj) => Array.prototype.shift.call(obj),
-  ArrayPrototypeForEach: (arr, ...rest) => Array.prototype.forEach.apply(arr, rest),
-  ArrayPrototypeIncludes: (arr, ...rest) => Array.prototype.includes.apply(arr, rest),
-  ArrayPrototypeJoin: (arr, ...rest) => Array.prototype.join.apply(arr, rest),
-  ArrayPrototypePop: (arr, ...rest) => Array.prototype.pop.apply(arr, rest),
-  ArrayPrototypePush: (arr, ...rest) => Array.prototype.push.apply(arr, rest),
-  FunctionPrototype: Function.prototype,
-  JSONParse: JSON.parse,
-  JSONStringify: JSON.stringify,
-  ObjectFreeze: Object.freeze,
-  ObjectKeys: Object.keys,
-  ObjectGetOwnPropertyNames: Object.getOwnPropertyNames,
-  ObjectDefineProperty: Object.defineProperty,
-  ObjectPrototypeHasOwnProperty: (obj, prop) => Object.prototype.hasOwnProperty.call(obj, prop),
-  RegExpPrototypeExec: (obj, string) => RegExp.prototype.exec.call(obj, string),
-  RegExpPrototypeTest: (obj, string) => RegExp.prototype.test.call(obj, string),
-  RegExpPrototypeSymbolReplace: (obj, ...rest) => RegExp.prototype[Symbol.replace].apply(obj, rest),
-  SafeMap: Map,
-  SafeSet: Set,
-  SafeWeakMap: WeakMap,
-  StringPrototypeEndsWith: (str, ...rest) => String.prototype.endsWith.apply(str, rest),
-  StringPrototypeIncludes: (str, ...rest) => String.prototype.includes.apply(str, rest),
-  StringPrototypeLastIndexOf: (str, ...rest) => String.prototype.lastIndexOf.apply(str, rest),
-  StringPrototypeIndexOf: (str, ...rest) => String.prototype.indexOf.apply(str, rest),
-  StringPrototypeRepeat: (str, ...rest) => String.prototype.repeat.apply(str, rest),
-  StringPrototypeReplace: (str, ...rest) => String.prototype.replace.apply(str, rest),
-  StringPrototypeSlice: (str, ...rest) => String.prototype.slice.apply(str, rest),
-  StringPrototypeSplit: (str, ...rest) => String.prototype.split.apply(str, rest),
-  StringPrototypeStartsWith: (str, ...rest) => String.prototype.startsWith.apply(str, rest),
-  StringPrototypeSubstr: (str, ...rest) => String.prototype.substr.apply(str, rest),
-  StringPrototypeCharCodeAt: (str, ...rest) => String.prototype.charCodeAt.apply(str, rest),
-  StringPrototypeMatch: (str, ...rest) => String.prototype.match.apply(str, rest),
-  SyntaxError: SyntaxError
-};
-
-
-/***/ }),
-
-/***/ 26972:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
-
-"use strict";
-
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.installCommonjsResolveHooksIfNecessary = void 0;
-/**
- * @internal
- */
-function installCommonjsResolveHooksIfNecessary(tsNodeService) {
-    const Module = __nccwpck_require__(98188);
-    const originalResolveFilename = Module._resolveFilename;
-    const originalFindPath = Module._findPath;
-    const shouldInstallHook = tsNodeService.options.experimentalResolver;
-    if (shouldInstallHook) {
-        const { Module_findPath, Module_resolveFilename } = tsNodeService.getNodeCjsLoader();
-        Module._resolveFilename = _resolveFilename;
-        Module._findPath = _findPath;
-        function _resolveFilename(request, parent, isMain, options, ...rest) {
-            if (!tsNodeService.enabled())
-                return originalResolveFilename.call(this, request, parent, isMain, options, ...rest);
-            return Module_resolveFilename.call(this, request, parent, isMain, options, ...rest);
-        }
-        function _findPath() {
-            if (!tsNodeService.enabled())
-                return originalFindPath.apply(this, arguments);
-            return Module_findPath.apply(this, arguments);
-        }
-    }
-}
-exports.installCommonjsResolveHooksIfNecessary = installCommonjsResolveHooksIfNecessary;
-//# sourceMappingURL=cjs-resolve-hooks.js.map
-
-/***/ }),
-
-/***/ 76692:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
-
-"use strict";
-
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.getTsConfigDefaults = exports.ComputeAsCommonRootOfFiles = exports.loadCompiler = exports.resolveAndLoadCompiler = exports.readConfig = exports.findAndReadConfig = void 0;
-const path_1 = __nccwpck_require__(71017);
-const index_1 = __nccwpck_require__(51351);
-const ts_internals_1 = __nccwpck_require__(37432);
-const tsconfigs_1 = __nccwpck_require__(7518);
-const util_1 = __nccwpck_require__(81842);
-/**
- * TypeScript compiler option values required by `ts-node` which cannot be overridden.
- */
-const TS_NODE_COMPILER_OPTIONS = {
-    sourceMap: true,
-    inlineSourceMap: false,
-    inlineSources: true,
-    declaration: false,
-    noEmit: false,
-    outDir: '.ts-node',
-};
-/*
- * Do post-processing on config options to support `ts-node`.
- */
-function fixConfig(ts, config) {
-    // Delete options that *should not* be passed through.
-    delete config.options.out;
-    delete config.options.outFile;
-    delete config.options.composite;
-    delete config.options.declarationDir;
-    delete config.options.declarationMap;
-    delete config.options.emitDeclarationOnly;
-    // Target ES5 output by default (instead of ES3).
-    if (config.options.target === undefined) {
-        config.options.target = ts.ScriptTarget.ES5;
-    }
-    // Target CommonJS modules by default (instead of magically switching to ES6 when the target is ES6).
-    if (config.options.module === undefined) {
-        config.options.module = ts.ModuleKind.CommonJS;
-    }
-    return config;
-}
-/** @internal */
-function findAndReadConfig(rawOptions) {
-    var _a, _b, _c, _d, _e;
-    const cwd = (0, path_1.resolve)((_c = (_b = (_a = rawOptions.cwd) !== null && _a !== void 0 ? _a : rawOptions.dir) !== null && _b !== void 0 ? _b : index_1.DEFAULTS.cwd) !== null && _c !== void 0 ? _c : process.cwd());
-    const compilerName = (_d = rawOptions.compiler) !== null && _d !== void 0 ? _d : index_1.DEFAULTS.compiler;
-    // Compute minimum options to read the config file.
-    let projectLocalResolveDir = (0, util_1.getBasePathForProjectLocalDependencyResolution)(undefined, rawOptions.projectSearchDir, rawOptions.project, cwd);
-    let { compiler, ts } = resolveAndLoadCompiler(compilerName, projectLocalResolveDir);
-    // Read config file and merge new options between env and CLI options.
-    const { configFilePath, config, tsNodeOptionsFromTsconfig, optionBasePaths } = readConfig(cwd, ts, rawOptions);
-    const options = (0, util_1.assign)({}, index_1.DEFAULTS, tsNodeOptionsFromTsconfig || {}, { optionBasePaths }, rawOptions);
-    options.require = [
-        ...(tsNodeOptionsFromTsconfig.require || []),
-        ...(rawOptions.require || []),
-    ];
-    // Re-resolve the compiler in case it has changed.
-    // Compiler is loaded relative to tsconfig.json, so tsconfig discovery may cause us to load a
-    // different compiler than we did above, even if the name has not changed.
-    if (configFilePath) {
-        projectLocalResolveDir = (0, util_1.getBasePathForProjectLocalDependencyResolution)(configFilePath, rawOptions.projectSearchDir, rawOptions.project, cwd);
-        ({ compiler } = resolveCompiler(options.compiler, (_e = optionBasePaths.compiler) !== null && _e !== void 0 ? _e : projectLocalResolveDir));
-    }
-    return {
-        options,
-        config,
-        projectLocalResolveDir,
-        optionBasePaths,
-        configFilePath,
-        cwd,
-        compiler,
-    };
-}
-exports.findAndReadConfig = findAndReadConfig;
-/**
- * Load TypeScript configuration. Returns the parsed TypeScript config and
- * any `ts-node` options specified in the config file.
- *
- * Even when a tsconfig.json is not loaded, this function still handles merging
- * compilerOptions from various sources: API, environment variables, etc.
- *
- * @internal
- */
-function readConfig(cwd, ts, rawApiOptions) {
-    var _a, _b, _c;
-    // Ordered [a, b, c] where config a extends b extends c
-    const configChain = [];
-    let config = { compilerOptions: {} };
-    let basePath = cwd;
-    let configFilePath = undefined;
-    const projectSearchDir = (0, path_1.resolve)(cwd, (_a = rawApiOptions.projectSearchDir) !== null && _a !== void 0 ? _a : cwd);
-    const { fileExists = ts.sys.fileExists, readFile = ts.sys.readFile, skipProject = index_1.DEFAULTS.skipProject, project = index_1.DEFAULTS.project, tsTrace = index_1.DEFAULTS.tsTrace, } = rawApiOptions;
-    // Read project configuration when available.
-    if (!skipProject) {
-        if (project) {
-            const resolved = (0, path_1.resolve)(cwd, project);
-            const nested = (0, path_1.join)(resolved, 'tsconfig.json');
-            configFilePath = fileExists(nested) ? nested : resolved;
-        }
-        else {
-            configFilePath = ts.findConfigFile(projectSearchDir, fileExists);
-        }
-        if (configFilePath) {
-            let pathToNextConfigInChain = configFilePath;
-            const tsInternals = (0, ts_internals_1.createTsInternals)(ts);
-            const errors = [];
-            // Follow chain of "extends"
-            while (true) {
-                const result = ts.readConfigFile(pathToNextConfigInChain, readFile);
-                // Return diagnostics.
-                if (result.error) {
-                    return {
-                        configFilePath,
-                        config: { errors: [result.error], fileNames: [], options: {} },
-                        tsNodeOptionsFromTsconfig: {},
-                        optionBasePaths: {},
-                    };
-                }
-                const c = result.config;
-                const bp = (0, path_1.dirname)(pathToNextConfigInChain);
-                configChain.push({
-                    config: c,
-                    basePath: bp,
-                    configPath: pathToNextConfigInChain,
-                });
-                if (c.extends == null)
-                    break;
-                const resolvedExtendedConfigPath = tsInternals.getExtendsConfigPath(c.extends, {
-                    fileExists,
-                    readDirectory: ts.sys.readDirectory,
-                    readFile,
-                    useCaseSensitiveFileNames: ts.sys.useCaseSensitiveFileNames,
-                    trace: tsTrace,
-                }, bp, errors, ts.createCompilerDiagnostic);
-                if (errors.length) {
-                    return {
-                        configFilePath,
-                        config: { errors, fileNames: [], options: {} },
-                        tsNodeOptionsFromTsconfig: {},
-                        optionBasePaths: {},
-                    };
-                }
-                if (resolvedExtendedConfigPath == null)
-                    break;
-                pathToNextConfigInChain = resolvedExtendedConfigPath;
-            }
-            ({ config, basePath } = configChain[0]);
-        }
-    }
-    // Merge and fix ts-node options that come from tsconfig.json(s)
-    const tsNodeOptionsFromTsconfig = {};
-    const optionBasePaths = {};
-    for (let i = configChain.length - 1; i >= 0; i--) {
-        const { config, basePath, configPath } = configChain[i];
-        const options = filterRecognizedTsConfigTsNodeOptions(config['ts-node']).recognized;
-        // Some options are relative to the config file, so must be converted to absolute paths here
-        if (options.require) {
-            // Modules are found relative to the tsconfig file, not the `dir` option
-            const tsconfigRelativeResolver = (0, util_1.createProjectLocalResolveHelper)((0, path_1.dirname)(configPath));
-            options.require = options.require.map((path) => tsconfigRelativeResolver(path, false));
-        }
-        if (options.scopeDir) {
-            options.scopeDir = (0, path_1.resolve)(basePath, options.scopeDir);
-        }
-        // Downstream code uses the basePath; we do not do that here.
-        if (options.moduleTypes) {
-            optionBasePaths.moduleTypes = basePath;
-        }
-        if (options.transpiler != null) {
-            optionBasePaths.transpiler = basePath;
-        }
-        if (options.compiler != null) {
-            optionBasePaths.compiler = basePath;
-        }
-        if (options.swc != null) {
-            optionBasePaths.swc = basePath;
-        }
-        (0, util_1.assign)(tsNodeOptionsFromTsconfig, options);
-    }
-    // Remove resolution of "files".
-    const files = (_c = (_b = rawApiOptions.files) !== null && _b !== void 0 ? _b : tsNodeOptionsFromTsconfig.files) !== null && _c !== void 0 ? _c : index_1.DEFAULTS.files;
-    // Only if a config file is *not* loaded, load an implicit configuration from @tsconfig/bases
-    const skipDefaultCompilerOptions = configFilePath != null;
-    const defaultCompilerOptionsForNodeVersion = skipDefaultCompilerOptions
-        ? undefined
-        : {
-            ...(0, tsconfigs_1.getDefaultTsconfigJsonForNodeVersion)(ts).compilerOptions,
-            types: ['node'],
-        };
-    // Merge compilerOptions from all sources
-    config.compilerOptions = Object.assign({}, 
-    // automatically-applied options from @tsconfig/bases
-    defaultCompilerOptionsForNodeVersion, 
-    // tsconfig.json "compilerOptions"
-    config.compilerOptions, 
-    // from env var
-    index_1.DEFAULTS.compilerOptions, 
-    // tsconfig.json "ts-node": "compilerOptions"
-    tsNodeOptionsFromTsconfig.compilerOptions, 
-    // passed programmatically
-    rawApiOptions.compilerOptions, 
-    // overrides required by ts-node, cannot be changed
-    TS_NODE_COMPILER_OPTIONS);
-    const fixedConfig = fixConfig(ts, ts.parseJsonConfigFileContent(config, {
-        fileExists,
-        readFile,
-        // Only used for globbing "files", "include", "exclude"
-        // When `files` option disabled, we want to avoid the fs calls
-        readDirectory: files ? ts.sys.readDirectory : () => [],
-        useCaseSensitiveFileNames: ts.sys.useCaseSensitiveFileNames,
-    }, basePath, undefined, configFilePath));
-    return {
-        configFilePath,
-        config: fixedConfig,
-        tsNodeOptionsFromTsconfig,
-        optionBasePaths,
-    };
-}
-exports.readConfig = readConfig;
-/**
- * Load the typescript compiler. It is required to load the tsconfig but might
- * be changed by the tsconfig, so we have to do this twice.
- * @internal
- */
-function resolveAndLoadCompiler(name, relativeToPath) {
-    const { compiler } = resolveCompiler(name, relativeToPath);
-    const ts = loadCompiler(compiler);
-    return { compiler, ts };
-}
-exports.resolveAndLoadCompiler = resolveAndLoadCompiler;
-function resolveCompiler(name, relativeToPath) {
-    const projectLocalResolveHelper = (0, util_1.createProjectLocalResolveHelper)(relativeToPath);
-    const compiler = projectLocalResolveHelper(name || 'typescript', true);
-    return { compiler };
-}
-/** @internal */
-function loadCompiler(compiler) {
-    return (0, util_1.attemptRequireWithV8CompileCache)(require, compiler);
-}
-exports.loadCompiler = loadCompiler;
-/**
- * Given the raw "ts-node" sub-object from a tsconfig, return an object with only the properties
- * recognized by "ts-node"
- */
-function filterRecognizedTsConfigTsNodeOptions(jsonObject) {
-    if (jsonObject == null)
-        return { recognized: {}, unrecognized: {} };
-    const { compiler, compilerHost, compilerOptions, emit, files, ignore, ignoreDiagnostics, logError, preferTsExts, pretty, require, skipIgnore, transpileOnly, typeCheck, transpiler, scope, scopeDir, moduleTypes, experimentalReplAwait, swc, experimentalResolver, esm, experimentalSpecifierResolution, experimentalTsImportSpecifiers, ...unrecognized } = jsonObject;
-    const filteredTsConfigOptions = {
-        compiler,
-        compilerHost,
-        compilerOptions,
-        emit,
-        experimentalReplAwait,
-        files,
-        ignore,
-        ignoreDiagnostics,
-        logError,
-        preferTsExts,
-        pretty,
-        require,
-        skipIgnore,
-        transpileOnly,
-        typeCheck,
-        transpiler,
-        scope,
-        scopeDir,
-        moduleTypes,
-        swc,
-        experimentalResolver,
-        esm,
-        experimentalSpecifierResolution,
-        experimentalTsImportSpecifiers,
-    };
-    // Use the typechecker to make sure this implementation has the correct set of properties
-    const catchExtraneousProps = null;
-    const catchMissingProps = null;
-    return { recognized: filteredTsConfigOptions, unrecognized };
-}
-/** @internal */
-exports.ComputeAsCommonRootOfFiles = Symbol();
-/**
- * Some TS compiler options have defaults which are not provided by TS's config parsing functions.
- * This function centralizes the logic for computing those defaults.
- * @internal
- */
-function getTsConfigDefaults(config, basePath, _files, _include, _exclude) {
-    const { composite = false } = config.options;
-    let rootDir = config.options.rootDir;
-    if (rootDir == null) {
-        if (composite)
-            rootDir = basePath;
-        // Return this symbol to avoid computing from `files`, which would require fs calls
-        else
-            rootDir = exports.ComputeAsCommonRootOfFiles;
-    }
-    const { outDir = rootDir } = config.options;
-    // Docs are wrong: https://www.typescriptlang.org/tsconfig#include
-    // Docs say **, but it's actually **/*; compiler throws error for **
-    const include = _files ? [] : ['**/*'];
-    const files = _files !== null && _files !== void 0 ? _files : [];
-    // Docs are misleading: https://www.typescriptlang.org/tsconfig#exclude
-    // Docs say it excludes node_modules, bower_components, jspm_packages, but actually those are excluded via behavior of "include"
-    const exclude = _exclude !== null && _exclude !== void 0 ? _exclude : [outDir]; // TODO technically, outDir is absolute path, but exclude should be relative glob pattern?
-    // TODO compute baseUrl
-    return { rootDir, outDir, include, files, exclude, composite };
-}
-exports.getTsConfigDefaults = getTsConfigDefaults;
-//# sourceMappingURL=configuration.js.map
-
-/***/ }),
-
-/***/ 13108:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
-
-"use strict";
-var __webpack_unused_export__;
-
-__webpack_unused_export__ = ({ value: true });
-exports.lT = __webpack_unused_export__ = __webpack_unused_export__ = void 0;
-const index_1 = __nccwpck_require__(51351);
-const url_1 = __nccwpck_require__(57310);
-const path_1 = __nccwpck_require__(71017);
-const assert = __nccwpck_require__(39491);
-const util_1 = __nccwpck_require__(81842);
-const module_1 = __nccwpck_require__(98188);
-// The hooks API changed in node version X so we need to check for backwards compatibility.
-const newHooksAPI = (0, util_1.versionGteLt)(process.versions.node, '16.12.0');
-/** @internal */
-function filterHooksByAPIVersion(hooks) {
-    const { getFormat, load, resolve, transformSource } = hooks;
-    // Explicit return type to avoid TS's non-ideal inferred type
-    const hooksAPI = newHooksAPI
-        ? { resolve, load, getFormat: undefined, transformSource: undefined }
-        : { resolve, getFormat, transformSource, load: undefined };
-    return hooksAPI;
-}
-__webpack_unused_export__ = filterHooksByAPIVersion;
-/** @internal */
-function registerAndCreateEsmHooks(opts) {
-    // Automatically performs registration just like `-r ts-node/register`
-    const tsNodeInstance = (0, index_1.register)(opts);
-    return createEsmHooks(tsNodeInstance);
-}
-__webpack_unused_export__ = registerAndCreateEsmHooks;
-function createEsmHooks(tsNodeService) {
-    tsNodeService.enableExperimentalEsmLoaderInterop();
-    // Custom implementation that considers additional file extensions and automatically adds file extensions
-    const nodeResolveImplementation = tsNodeService.getNodeEsmResolver();
-    const nodeGetFormatImplementation = tsNodeService.getNodeEsmGetFormat();
-    const extensions = tsNodeService.extensions;
-    const hooksAPI = filterHooksByAPIVersion({
-        resolve,
-        load,
-        getFormat,
-        transformSource,
-    });
-    function isFileUrlOrNodeStyleSpecifier(parsed) {
-        // We only understand file:// URLs, but in node, the specifier can be a node-style `./foo` or `foo`
-        const { protocol } = parsed;
-        return protocol === null || protocol === 'file:';
-    }
-    /**
-     * Named "probably" as a reminder that this is a guess.
-     * node does not explicitly tell us if we're resolving the entrypoint or not.
-     */
-    function isProbablyEntrypoint(specifier, parentURL) {
-        return parentURL === undefined && specifier.startsWith('file://');
-    }
-    // Side-channel between `resolve()` and `load()` hooks
-    const rememberIsProbablyEntrypoint = new Set();
-    const rememberResolvedViaCommonjsFallback = new Set();
-    async function resolve(specifier, context, defaultResolve) {
-        const defer = async () => {
-            const r = await defaultResolve(specifier, context, defaultResolve);
-            return r;
-        };
-        // See: https://github.com/nodejs/node/discussions/41711
-        // nodejs will likely implement a similar fallback.  Till then, we can do our users a favor and fallback today.
-        async function entrypointFallback(cb) {
-            try {
-                const resolution = await cb();
-                if ((resolution === null || resolution === void 0 ? void 0 : resolution.url) &&
-                    isProbablyEntrypoint(specifier, context.parentURL))
-                    rememberIsProbablyEntrypoint.add(resolution.url);
-                return resolution;
-            }
-            catch (esmResolverError) {
-                if (!isProbablyEntrypoint(specifier, context.parentURL))
-                    throw esmResolverError;
-                try {
-                    let cjsSpecifier = specifier;
-                    // Attempt to convert from ESM file:// to CommonJS path
-                    try {
-                        if (specifier.startsWith('file://'))
-                            cjsSpecifier = (0, url_1.fileURLToPath)(specifier);
-                    }
-                    catch { }
-                    const resolution = (0, url_1.pathToFileURL)((0, module_1.createRequire)(process.cwd()).resolve(cjsSpecifier)).toString();
-                    rememberIsProbablyEntrypoint.add(resolution);
-                    rememberResolvedViaCommonjsFallback.add(resolution);
-                    return { url: resolution, format: 'commonjs' };
-                }
-                catch (commonjsResolverError) {
-                    throw esmResolverError;
-                }
-            }
-        }
-        return addShortCircuitFlag(async () => {
-            const parsed = (0, url_1.parse)(specifier);
-            const { pathname, protocol, hostname } = parsed;
-            if (!isFileUrlOrNodeStyleSpecifier(parsed)) {
-                return entrypointFallback(defer);
-            }
-            if (protocol !== null && protocol !== 'file:') {
-                return entrypointFallback(defer);
-            }
-            // Malformed file:// URL?  We should always see `null` or `''`
-            if (hostname) {
-                // TODO file://./foo sets `hostname` to `'.'`.  Perhaps we should special-case this.
-                return entrypointFallback(defer);
-            }
-            // pathname is the path to be resolved
-            return entrypointFallback(() => nodeResolveImplementation.defaultResolve(specifier, context, defaultResolve));
-        });
-    }
-    // `load` from new loader hook API (See description at the top of this file)
-    async function load(url, context, defaultLoad) {
-        return addShortCircuitFlag(async () => {
-            var _a;
-            // If we get a format hint from resolve() on the context then use it
-            // otherwise call the old getFormat() hook using node's old built-in defaultGetFormat() that ships with ts-node
-            const format = (_a = context.format) !== null && _a !== void 0 ? _a : (await getFormat(url, context, nodeGetFormatImplementation.defaultGetFormat)).format;
-            let source = undefined;
-            if (format !== 'builtin' && format !== 'commonjs') {
-                // Call the new defaultLoad() to get the source
-                const { source: rawSource } = await defaultLoad(url, {
-                    ...context,
-                    format,
-                }, defaultLoad);
-                if (rawSource === undefined || rawSource === null) {
-                    throw new Error(`Failed to load raw source: Format was '${format}' and url was '${url}''.`);
-                }
-                // Emulate node's built-in old defaultTransformSource() so we can re-use the old transformSource() hook
-                const defaultTransformSource = async (source, _context, _defaultTransformSource) => ({ source });
-                // Call the old hook
-                const { source: transformedSource } = await transformSource(rawSource, { url, format }, defaultTransformSource);
-                source = transformedSource;
-            }
-            return { format, source };
-        });
-    }
-    async function getFormat(url, context, defaultGetFormat) {
-        const defer = (overrideUrl = url) => defaultGetFormat(overrideUrl, context, defaultGetFormat);
-        // See: https://github.com/nodejs/node/discussions/41711
-        // nodejs will likely implement a similar fallback.  Till then, we can do our users a favor and fallback today.
-        async function entrypointFallback(cb) {
-            try {
-                return await cb();
-            }
-            catch (getFormatError) {
-                if (!rememberIsProbablyEntrypoint.has(url))
-                    throw getFormatError;
-                return { format: 'commonjs' };
-            }
-        }
-        const parsed = (0, url_1.parse)(url);
-        if (!isFileUrlOrNodeStyleSpecifier(parsed)) {
-            return entrypointFallback(defer);
-        }
-        const { pathname } = parsed;
-        assert(pathname !== null, 'ESM getFormat() hook: URL should never have null pathname');
-        const nativePath = (0, url_1.fileURLToPath)(url);
-        let nodeSays;
-        // If file has extension not understood by node, then ask node how it would treat the emitted extension.
-        // E.g. .mts compiles to .mjs, so ask node how to classify an .mjs file.
-        const ext = (0, path_1.extname)(nativePath);
-        const tsNodeIgnored = tsNodeService.ignored(nativePath);
-        const nodeEquivalentExt = extensions.nodeEquivalents.get(ext);
-        if (nodeEquivalentExt && !tsNodeIgnored) {
-            nodeSays = await entrypointFallback(() => defer((0, url_1.format)((0, url_1.pathToFileURL)(nativePath + nodeEquivalentExt))));
-        }
-        else {
-            try {
-                nodeSays = await entrypointFallback(defer);
-            }
-            catch (e) {
-                if (e instanceof Error &&
-                    tsNodeIgnored &&
-                    extensions.nodeDoesNotUnderstand.includes(ext)) {
-                    e.message +=
-                        `\n\n` +
-                            `Hint:\n` +
-                            `ts-node is configured to ignore this file.\n` +
-                            `If you want ts-node to handle this file, consider enabling the "skipIgnore" option or adjusting your "ignore" patterns.\n` +
-                            `https://typestrong.org/ts-node/docs/scope\n`;
-                }
-                throw e;
-            }
-        }
-        // For files compiled by ts-node that node believes are either CJS or ESM, check if we should override that classification
-        if (!tsNodeService.ignored(nativePath) &&
-            (nodeSays.format === 'commonjs' || nodeSays.format === 'module')) {
-            const { moduleType } = tsNodeService.moduleTypeClassifier.classifyModuleByModuleTypeOverrides((0, util_1.normalizeSlashes)(nativePath));
-            if (moduleType === 'cjs') {
-                return { format: 'commonjs' };
-            }
-            else if (moduleType === 'esm') {
-                return { format: 'module' };
-            }
-        }
-        return nodeSays;
-    }
-    async function transformSource(source, context, defaultTransformSource) {
-        if (source === null || source === undefined) {
-            throw new Error('No source');
-        }
-        const defer = () => defaultTransformSource(source, context, defaultTransformSource);
-        const sourceAsString = typeof source === 'string' ? source : source.toString('utf8');
-        const { url } = context;
-        const parsed = (0, url_1.parse)(url);
-        if (!isFileUrlOrNodeStyleSpecifier(parsed)) {
-            return defer();
-        }
-        const nativePath = (0, url_1.fileURLToPath)(url);
-        if (tsNodeService.ignored(nativePath)) {
-            return defer();
-        }
-        const emittedJs = tsNodeService.compile(sourceAsString, nativePath);
-        return { source: emittedJs };
-    }
-    return hooksAPI;
-}
-exports.lT = createEsmHooks;
-async function addShortCircuitFlag(fn) {
-    const ret = await fn();
-    // Not sure if this is necessary; being lazy.  Can revisit in the future.
-    if (ret == null)
-        return ret;
-    return {
-        ...ret,
-        shortCircuit: true,
-    };
-}
-//# sourceMappingURL=esm.js.map
-
-/***/ }),
-
-/***/ 50872:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
-
-"use strict";
-
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.getExtensions = void 0;
-const util_1 = __nccwpck_require__(81842);
-const nodeEquivalents = new Map([
-    ['.ts', '.js'],
-    ['.tsx', '.js'],
-    ['.jsx', '.js'],
-    ['.mts', '.mjs'],
-    ['.cts', '.cjs'],
-]);
-const tsResolverEquivalents = new Map([
-    ['.ts', ['.js']],
-    ['.tsx', ['.js', '.jsx']],
-    ['.mts', ['.mjs']],
-    ['.cts', ['.cjs']],
-]);
-// All extensions understood by vanilla node
-const vanillaNodeExtensions = [
-    '.js',
-    '.json',
-    '.node',
-    '.mjs',
-    '.cjs',
-];
-// Extensions added by vanilla node's require() if you omit them:
-// js, json, node
-// Extensions added by vanilla node if you omit them with --experimental-specifier-resolution=node
-// js, json, node, mjs
-// Extensions added by ESM codepath's legacy package.json "main" resolver
-// js, json, node (not mjs!)
-const nodeDoesNotUnderstand = [
-    '.ts',
-    '.tsx',
-    '.jsx',
-    '.cts',
-    '.mts',
-];
-/**
- * [MUST_UPDATE_FOR_NEW_FILE_EXTENSIONS]
- * @internal
- */
-function getExtensions(config, options, tsVersion) {
-    // TS 4.5 is first version to understand .cts, .mts, .cjs, and .mjs extensions
-    const tsSupportsMtsCtsExts = (0, util_1.versionGteLt)(tsVersion, '4.5.0');
-    const requiresHigherTypescriptVersion = [];
-    if (!tsSupportsMtsCtsExts)
-        requiresHigherTypescriptVersion.push('.cts', '.cjs', '.mts', '.mjs');
-    const allPossibleExtensionsSortedByPreference = Array.from(new Set([
-        ...(options.preferTsExts ? nodeDoesNotUnderstand : []),
-        ...vanillaNodeExtensions,
-        ...nodeDoesNotUnderstand,
-    ]));
-    const compiledJsUnsorted = ['.ts'];
-    const compiledJsxUnsorted = [];
-    if (config.options.jsx)
-        compiledJsxUnsorted.push('.tsx');
-    if (tsSupportsMtsCtsExts)
-        compiledJsUnsorted.push('.mts', '.cts');
-    if (config.options.allowJs) {
-        compiledJsUnsorted.push('.js');
-        if (config.options.jsx)
-            compiledJsxUnsorted.push('.jsx');
-        if (tsSupportsMtsCtsExts)
-            compiledJsUnsorted.push('.mjs', '.cjs');
-    }
-    const compiledUnsorted = [...compiledJsUnsorted, ...compiledJsxUnsorted];
-    const compiled = allPossibleExtensionsSortedByPreference.filter((ext) => compiledUnsorted.includes(ext));
-    const compiledNodeDoesNotUnderstand = nodeDoesNotUnderstand.filter((ext) => compiled.includes(ext));
-    /**
-     * TS's resolver can resolve foo.js to foo.ts, by replacing .js extension with several source extensions.
-     * IMPORTANT: Must preserve ordering according to preferTsExts!
-     *            Must include the .js/.mjs/.cjs extension in the array!
-     *            This affects resolution behavior!
-     * [MUST_UPDATE_FOR_NEW_FILE_EXTENSIONS]
-     */
-    const r = allPossibleExtensionsSortedByPreference.filter((ext) => [...compiledUnsorted, '.js', '.mjs', '.cjs', '.mts', '.cts'].includes(ext));
-    const replacementsForJs = r.filter((ext) => ['.js', '.jsx', '.ts', '.tsx'].includes(ext));
-    const replacementsForJsx = r.filter((ext) => ['.jsx', '.tsx'].includes(ext));
-    const replacementsForMjs = r.filter((ext) => ['.mjs', '.mts'].includes(ext));
-    const replacementsForCjs = r.filter((ext) => ['.cjs', '.cts'].includes(ext));
-    const replacementsForJsOrMjs = r.filter((ext) => ['.js', '.jsx', '.ts', '.tsx', '.mjs', '.mts'].includes(ext));
-    // Node allows omitting .js or .mjs extension in certain situations (CJS, ESM w/experimental flag)
-    // So anything that compiles to .js or .mjs can also be omitted.
-    const experimentalSpecifierResolutionAddsIfOmitted = Array.from(new Set([...replacementsForJsOrMjs, '.json', '.node']));
-    // Same as above, except node curiuosly doesn't do .mjs here
-    const legacyMainResolveAddsIfOmitted = Array.from(new Set([...replacementsForJs, '.json', '.node']));
-    return {
-        /** All file extensions we transform, ordered by resolution preference according to preferTsExts */
-        compiled,
-        /** Resolved extensions that vanilla node will not understand; we should handle them */
-        nodeDoesNotUnderstand,
-        /** Like the above, but only the ones we're compiling */
-        compiledNodeDoesNotUnderstand,
-        /**
-         * Mapping from extensions understood by tsc to the equivalent for node,
-         * as far as getFormat is concerned.
-         */
-        nodeEquivalents,
-        /**
-         * Mapping from extensions rejected by TSC in import specifiers, to the
-         * possible alternatives that TS's resolver will accept.
-         *
-         * When we allow users to opt-in to .ts extensions in import specifiers, TS's
-         * resolver requires us to replace the .ts extensions with .js alternatives.
-         * Otherwise, resolution fails.
-         *
-         * Note TS's resolver is only used by, and only required for, typechecking.
-         * This is separate from node's resolver, which we hook separately and which
-         * does not require this mapping.
-         */
-        tsResolverEquivalents,
-        /**
-         * Extensions that we can support if the user upgrades their typescript version.
-         * Used when raising hints.
-         */
-        requiresHigherTypescriptVersion,
-        /**
-         * --experimental-specifier-resolution=node will add these extensions.
-         */
-        experimentalSpecifierResolutionAddsIfOmitted,
-        /**
-         * ESM loader will add these extensions to package.json "main" field
-         */
-        legacyMainResolveAddsIfOmitted,
-        replacementsForMjs,
-        replacementsForCjs,
-        replacementsForJsx,
-        replacementsForJs,
-    };
-}
-exports.getExtensions = getExtensions;
-//# sourceMappingURL=file-extensions.js.map
-
-/***/ }),
-
-/***/ 51351:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
-
-"use strict";
-
-var _a, _b;
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.createEsmHooks = exports.createFromPreloadedConfig = exports.create = exports.register = exports.TSError = exports.DEFAULTS = exports.VERSION = exports.debug = exports.INSPECT_CUSTOM = exports.env = exports.REGISTER_INSTANCE = exports.createRepl = void 0;
-const path_1 = __nccwpck_require__(71017);
-const module_1 = __nccwpck_require__(98188);
-const util = __nccwpck_require__(73837);
-const url_1 = __nccwpck_require__(57310);
-const make_error_1 = __nccwpck_require__(80976);
-const util_1 = __nccwpck_require__(81842);
-const configuration_1 = __nccwpck_require__(76692);
-const module_type_classifier_1 = __nccwpck_require__(26705);
-const resolver_functions_1 = __nccwpck_require__(59765);
-const cjs_resolve_hooks_1 = __nccwpck_require__(26972);
-const node_module_type_classifier_1 = __nccwpck_require__(59503);
-const file_extensions_1 = __nccwpck_require__(50872);
-const ts_transpile_module_1 = __nccwpck_require__(72598);
-var repl_1 = __nccwpck_require__(45890);
-Object.defineProperty(exports, "createRepl", ({ enumerable: true, get: function () { return repl_1.createRepl; } }));
-/**
- * Does this version of node obey the package.json "type" field
- * and throw ERR_REQUIRE_ESM when attempting to require() an ESM modules.
- */
-const engineSupportsPackageTypeField = parseInt(process.versions.node.split('.')[0], 10) >= 12;
-/**
- * Assert that script can be loaded as CommonJS when we attempt to require it.
- * If it should be loaded as ESM, throw ERR_REQUIRE_ESM like node does.
- *
- * Loaded conditionally so we don't need to support older node versions
- */
-let assertScriptCanLoadAsCJS = engineSupportsPackageTypeField
-    ? (__nccwpck_require__(11717).assertScriptCanLoadAsCJSImpl)
-    : () => {
-        /* noop */
-    };
-/**
- * Registered `ts-node` instance information.
- */
-exports.REGISTER_INSTANCE = Symbol.for('ts-node.register.instance');
-/** @internal */
-exports.env = process.env;
-/**
- * @internal
- */
-exports.INSPECT_CUSTOM = util.inspect.custom || 'inspect';
-/**
- * Debugging `ts-node`.
- */
-const shouldDebug = (0, util_1.yn)(exports.env.TS_NODE_DEBUG);
-/** @internal */
-exports.debug = shouldDebug
-    ? (...args) => console.log(`[ts-node ${new Date().toISOString()}]`, ...args)
-    : () => undefined;
-const debugFn = shouldDebug
-    ? (key, fn) => {
-        let i = 0;
-        return (x) => {
-            (0, exports.debug)(key, x, ++i);
-            return fn(x);
-        };
-    }
-    : (_, fn) => fn;
-/**
- * Export the current version.
- */
-exports.VERSION = __nccwpck_require__(46686).version;
-/**
- * Default register options, including values specified via environment
- * variables.
- * @internal
- */
-exports.DEFAULTS = {
-    cwd: (_a = exports.env.TS_NODE_CWD) !== null && _a !== void 0 ? _a : exports.env.TS_NODE_DIR,
-    emit: (0, util_1.yn)(exports.env.TS_NODE_EMIT),
-    scope: (0, util_1.yn)(exports.env.TS_NODE_SCOPE),
-    scopeDir: exports.env.TS_NODE_SCOPE_DIR,
-    files: (0, util_1.yn)(exports.env.TS_NODE_FILES),
-    pretty: (0, util_1.yn)(exports.env.TS_NODE_PRETTY),
-    compiler: exports.env.TS_NODE_COMPILER,
-    compilerOptions: (0, util_1.parse)(exports.env.TS_NODE_COMPILER_OPTIONS),
-    ignore: (0, util_1.split)(exports.env.TS_NODE_IGNORE),
-    project: exports.env.TS_NODE_PROJECT,
-    skipProject: (0, util_1.yn)(exports.env.TS_NODE_SKIP_PROJECT),
-    skipIgnore: (0, util_1.yn)(exports.env.TS_NODE_SKIP_IGNORE),
-    preferTsExts: (0, util_1.yn)(exports.env.TS_NODE_PREFER_TS_EXTS),
-    ignoreDiagnostics: (0, util_1.split)(exports.env.TS_NODE_IGNORE_DIAGNOSTICS),
-    transpileOnly: (0, util_1.yn)(exports.env.TS_NODE_TRANSPILE_ONLY),
-    typeCheck: (0, util_1.yn)(exports.env.TS_NODE_TYPE_CHECK),
-    compilerHost: (0, util_1.yn)(exports.env.TS_NODE_COMPILER_HOST),
-    logError: (0, util_1.yn)(exports.env.TS_NODE_LOG_ERROR),
-    experimentalReplAwait: (_b = (0, util_1.yn)(exports.env.TS_NODE_EXPERIMENTAL_REPL_AWAIT)) !== null && _b !== void 0 ? _b : undefined,
-    tsTrace: console.log.bind(console),
-};
-/**
- * TypeScript diagnostics error.
- */
-class TSError extends make_error_1.BaseError {
-    constructor(diagnosticText, diagnosticCodes, diagnostics = []) {
-        super(`⨯ Unable to compile TypeScript:\n${diagnosticText}`);
-        this.diagnosticCodes = diagnosticCodes;
-        this.name = 'TSError';
-        Object.defineProperty(this, 'diagnosticText', {
-            configurable: true,
-            writable: true,
-            value: diagnosticText,
-        });
-        Object.defineProperty(this, 'diagnostics', {
-            configurable: true,
-            writable: true,
-            value: diagnostics,
-        });
-    }
-    /**
-     * @internal
-     */
-    [exports.INSPECT_CUSTOM]() {
-        return this.diagnosticText;
-    }
-}
-exports.TSError = TSError;
-const TS_NODE_SERVICE_BRAND = Symbol('TS_NODE_SERVICE_BRAND');
-function register(serviceOrOpts) {
-    // Is this a Service or a RegisterOptions?
-    let service = serviceOrOpts;
-    if (!(serviceOrOpts === null || serviceOrOpts === void 0 ? void 0 : serviceOrOpts[TS_NODE_SERVICE_BRAND])) {
-        // Not a service; is options
-        service = create((serviceOrOpts !== null && serviceOrOpts !== void 0 ? serviceOrOpts : {}));
-    }
-    const originalJsHandler = require.extensions['.js'];
-    // Expose registered instance globally.
-    process[exports.REGISTER_INSTANCE] = service;
-    // Register the extensions.
-    registerExtensions(service.options.preferTsExts, service.extensions.compiled, service, originalJsHandler);
-    (0, cjs_resolve_hooks_1.installCommonjsResolveHooksIfNecessary)(service);
-    // Require specified modules before start-up.
-    module_1.Module._preloadModules(service.options.require);
-    return service;
-}
-exports.register = register;
-/**
- * Create TypeScript compiler instance.
- *
- * @category Basic
- */
-function create(rawOptions = {}) {
-    const foundConfigResult = (0, configuration_1.findAndReadConfig)(rawOptions);
-    return createFromPreloadedConfig(foundConfigResult);
-}
-exports.create = create;
-/** @internal */
-function createFromPreloadedConfig(foundConfigResult) {
-    var _a, _b, _c, _d;
-    const { configFilePath, cwd, options, config, compiler, projectLocalResolveDir, optionBasePaths, } = foundConfigResult;
-    const projectLocalResolveHelper = (0, util_1.createProjectLocalResolveHelper)(projectLocalResolveDir);
-    const ts = (0, configuration_1.loadCompiler)(compiler);
-    // Experimental REPL await is not compatible targets lower than ES2018
-    const targetSupportsTla = config.options.target >= ts.ScriptTarget.ES2018;
-    if (options.experimentalReplAwait === true && !targetSupportsTla) {
-        throw new Error('Experimental REPL await is not compatible with targets lower than ES2018');
-    }
-    // Top-level await was added in TS 3.8
-    const tsVersionSupportsTla = (0, util_1.versionGteLt)(ts.version, '3.8.0');
-    if (options.experimentalReplAwait === true && !tsVersionSupportsTla) {
-        throw new Error('Experimental REPL await is not compatible with TypeScript versions older than 3.8');
-    }
-    const shouldReplAwait = options.experimentalReplAwait !== false &&
-        tsVersionSupportsTla &&
-        targetSupportsTla;
-    // swc implies two other options
-    // typeCheck option was implemented specifically to allow overriding tsconfig transpileOnly from the command-line
-    // So we should allow using typeCheck to override swc
-    if (options.swc && !options.typeCheck) {
-        if (options.transpileOnly === false) {
-            throw new Error("Cannot enable 'swc' option with 'transpileOnly: false'.  'swc' implies 'transpileOnly'.");
-        }
-        if (options.transpiler) {
-            throw new Error("Cannot specify both 'swc' and 'transpiler' options.  'swc' uses the built-in swc transpiler.");
-        }
-    }
-    const readFile = options.readFile || ts.sys.readFile;
-    const fileExists = options.fileExists || ts.sys.fileExists;
-    // typeCheck can override transpileOnly, useful for CLI flag to override config file
-    const transpileOnly = (options.transpileOnly === true || options.swc === true) &&
-        options.typeCheck !== true;
-    let transpiler = undefined;
-    let transpilerBasePath = undefined;
-    if (options.transpiler) {
-        transpiler = options.transpiler;
-        transpilerBasePath = optionBasePaths.transpiler;
-    }
-    else if (options.swc) {
-        transpiler = __nccwpck_require__.ab + "swc.js";
-        transpilerBasePath = optionBasePaths.swc;
-    }
-    const transformers = options.transformers || undefined;
-    const diagnosticFilters = [
-        {
-            appliesToAllFiles: true,
-            filenamesAbsolute: [],
-            diagnosticsIgnored: [
-                6059,
-                18002,
-                18003,
-                ...(options.experimentalTsImportSpecifiers
-                    ? [
-                        2691, // "An import path cannot end with a '.ts' extension. Consider importing '' instead."
-                    ]
-                    : []),
-                ...(options.ignoreDiagnostics || []),
-            ].map(Number),
-        },
-    ];
-    const configDiagnosticList = filterDiagnostics(config.errors, diagnosticFilters);
-    const outputCache = new Map();
-    const configFileDirname = configFilePath ? (0, path_1.dirname)(configFilePath) : null;
-    const scopeDir = (_c = (_b = (_a = options.scopeDir) !== null && _a !== void 0 ? _a : config.options.rootDir) !== null && _b !== void 0 ? _b : configFileDirname) !== null && _c !== void 0 ? _c : cwd;
-    const ignoreBaseDir = configFileDirname !== null && configFileDirname !== void 0 ? configFileDirname : cwd;
-    const isScoped = options.scope
-        ? (fileName) => (0, path_1.relative)(scopeDir, fileName).charAt(0) !== '.'
-        : () => true;
-    const shouldIgnore = createIgnore(ignoreBaseDir, options.skipIgnore
-        ? []
-        : (options.ignore || ['(?:^|/)node_modules/']).map((str) => new RegExp(str)));
-    const diagnosticHost = {
-        getNewLine: () => ts.sys.newLine,
-        getCurrentDirectory: () => cwd,
-        // TODO switch to getCanonicalFileName we already create later in scope
-        getCanonicalFileName: ts.sys.useCaseSensitiveFileNames
-            ? (x) => x
-            : (x) => x.toLowerCase(),
-    };
-    if (options.transpileOnly && typeof transformers === 'function') {
-        throw new TypeError('Transformers function is unavailable in "--transpile-only"');
-    }
-    let createTranspiler = initializeTranspilerFactory();
-    function initializeTranspilerFactory() {
-        var _a;
-        if (__nccwpck_require__.ab + "swc.js") {
-            if (!transpileOnly)
-                throw new Error('Custom transpiler can only be used when transpileOnly is enabled.');
-            const transpilerName = typeof transpiler === 'string' ? transpiler : transpiler[0];
-            const transpilerOptions = typeof transpiler === 'string' ? {} : (_a = transpiler[1]) !== null && _a !== void 0 ? _a : {};
-            const transpilerConfigLocalResolveHelper = transpilerBasePath
-                ? (0, util_1.createProjectLocalResolveHelper)(transpilerBasePath)
-                : projectLocalResolveHelper;
-            const transpilerPath = transpilerConfigLocalResolveHelper(transpilerName, true);
-            const transpilerFactory = __nccwpck_require__(3833)(transpilerPath)
-                .create;
-            return createTranspiler;
-            function createTranspiler(compilerOptions, nodeModuleEmitKind) {
-                return transpilerFactory === null || transpilerFactory === void 0 ? void 0 : transpilerFactory({
-                    service: {
-                        options,
-                        config: {
-                            ...config,
-                            options: compilerOptions,
-                        },
-                        projectLocalResolveHelper,
-                    },
-                    transpilerConfigLocalResolveHelper,
-                    nodeModuleEmitKind,
-                    ...transpilerOptions,
-                });
-            }
-        }
-    }
-    /**
-     * True if require() hooks should interop with experimental ESM loader.
-     * Enabled explicitly via a flag since it is a breaking change.
-     */
-    let experimentalEsmLoader = false;
-    function enableExperimentalEsmLoaderInterop() {
-        experimentalEsmLoader = true;
-    }
-    // Install source map support and read from memory cache.
-    installSourceMapSupport();
-    function installSourceMapSupport() {
-        const sourceMapSupport = __nccwpck_require__(62090);
-        sourceMapSupport.install({
-            environment: 'node',
-            retrieveFile(pathOrUrl) {
-                var _a;
-                let path = pathOrUrl;
-                // If it's a file URL, convert to local path
-                // Note: fileURLToPath does not exist on early node v10
-                // I could not find a way to handle non-URLs except to swallow an error
-                if (experimentalEsmLoader && path.startsWith('file://')) {
-                    try {
-                        path = (0, url_1.fileURLToPath)(path);
-                    }
-                    catch (e) {
-                        /* swallow error */
-                    }
-                }
-                path = (0, util_1.normalizeSlashes)(path);
-                return ((_a = outputCache.get(path)) === null || _a === void 0 ? void 0 : _a.content) || '';
-            },
-            redirectConflictingLibrary: true,
-            onConflictingLibraryRedirect(request, parent, isMain, options, redirectedRequest) {
-                (0, exports.debug)(`Redirected an attempt to require source-map-support to instead receive @cspotcode/source-map-support.  "${parent.filename}" attempted to require or resolve "${request}" and was redirected to "${redirectedRequest}".`);
-            },
-        });
-    }
-    const shouldHavePrettyErrors = options.pretty === undefined ? process.stdout.isTTY : options.pretty;
-    const formatDiagnostics = shouldHavePrettyErrors
-        ? ts.formatDiagnosticsWithColorAndContext || ts.formatDiagnostics
-        : ts.formatDiagnostics;
-    function createTSError(diagnostics) {
-        const diagnosticText = formatDiagnostics(diagnostics, diagnosticHost);
-        const diagnosticCodes = diagnostics.map((x) => x.code);
-        return new TSError(diagnosticText, diagnosticCodes, diagnostics);
-    }
-    function reportTSError(configDiagnosticList) {
-        const error = createTSError(configDiagnosticList);
-        if (options.logError) {
-            // Print error in red color and continue execution.
-            console.error('\x1b[31m%s\x1b[0m', error);
-        }
-        else {
-            // Throw error and exit the script.
-            throw error;
-        }
-    }
-    // Render the configuration errors.
-    if (configDiagnosticList.length)
-        reportTSError(configDiagnosticList);
-    const jsxEmitPreserve = config.options.jsx === ts.JsxEmit.Preserve;
-    /**
-     * Get the extension for a transpiled file.
-     * [MUST_UPDATE_FOR_NEW_FILE_EXTENSIONS]
-     */
-    function getEmitExtension(path) {
-        const lastDotIndex = path.lastIndexOf('.');
-        if (lastDotIndex >= 0) {
-            const ext = path.slice(lastDotIndex);
-            switch (ext) {
-                case '.js':
-                case '.ts':
-                    return '.js';
-                case '.jsx':
-                case '.tsx':
-                    return jsxEmitPreserve ? '.jsx' : '.js';
-                case '.mjs':
-                case '.mts':
-                    return '.mjs';
-                case '.cjs':
-                case '.cts':
-                    return '.cjs';
-            }
-        }
-        return '.js';
-    }
-    /**
-     * Get output from TS compiler w/typechecking.  `undefined` in `transpileOnly`
-     * mode.
-     */
-    let getOutput;
-    let getTypeInfo;
-    const getCanonicalFileName = ts.createGetCanonicalFileName(ts.sys.useCaseSensitiveFileNames);
-    const moduleTypeClassifier = (0, module_type_classifier_1.createModuleTypeClassifier)({
-        basePath: (_d = options.optionBasePaths) === null || _d === void 0 ? void 0 : _d.moduleTypes,
-        patterns: options.moduleTypes,
-    });
-    const extensions = (0, file_extensions_1.getExtensions)(config, options, ts.version);
-    // Use full language services when the fast option is disabled.
-    if (!transpileOnly) {
-        const fileContents = new Map();
-        const rootFileNames = new Set(config.fileNames);
-        const cachedReadFile = (0, util_1.cachedLookup)(debugFn('readFile', readFile));
-        // Use language services by default
-        if (!options.compilerHost) {
-            let projectVersion = 1;
-            const fileVersions = new Map(Array.from(rootFileNames).map((fileName) => [fileName, 0]));
-            const getCustomTransformers = () => {
-                if (typeof transformers === 'function') {
-                    const program = service.getProgram();
-                    return program ? transformers(program) : undefined;
-                }
-                return transformers;
-            };
-            // Create the compiler host for type checking.
-            const serviceHost = {
-                getProjectVersion: () => String(projectVersion),
-                getScriptFileNames: () => Array.from(rootFileNames),
-                getScriptVersion: (fileName) => {
-                    const version = fileVersions.get(fileName);
-                    return version ? version.toString() : '';
-                },
-                getScriptSnapshot(fileName) {
-                    // TODO ordering of this with getScriptVersion?  Should they sync up?
-                    let contents = fileContents.get(fileName);
-                    // Read contents into TypeScript memory cache.
-                    if (contents === undefined) {
-                        contents = cachedReadFile(fileName);
-                        if (contents === undefined)
-                            return;
-                        fileVersions.set(fileName, 1);
-                        fileContents.set(fileName, contents);
-                        projectVersion++;
-                    }
-                    return ts.ScriptSnapshot.fromString(contents);
-                },
-                readFile: cachedReadFile,
-                readDirectory: ts.sys.readDirectory,
-                getDirectories: (0, util_1.cachedLookup)(debugFn('getDirectories', ts.sys.getDirectories)),
-                fileExists: (0, util_1.cachedLookup)(debugFn('fileExists', fileExists)),
-                directoryExists: (0, util_1.cachedLookup)(debugFn('directoryExists', ts.sys.directoryExists)),
-                realpath: ts.sys.realpath
-                    ? (0, util_1.cachedLookup)(debugFn('realpath', ts.sys.realpath))
-                    : undefined,
-                getNewLine: () => ts.sys.newLine,
-                useCaseSensitiveFileNames: () => ts.sys.useCaseSensitiveFileNames,
-                getCurrentDirectory: () => cwd,
-                getCompilationSettings: () => config.options,
-                getDefaultLibFileName: () => ts.getDefaultLibFilePath(config.options),
-                getCustomTransformers: getCustomTransformers,
-                trace: options.tsTrace,
-            };
-            const { resolveModuleNames, getResolvedModuleWithFailedLookupLocationsFromCache, resolveTypeReferenceDirectives, isFileKnownToBeInternal, markBucketOfFilenameInternal, } = (0, resolver_functions_1.createResolverFunctions)({
-                host: serviceHost,
-                getCanonicalFileName,
-                ts,
-                cwd,
-                config,
-                projectLocalResolveHelper,
-                options,
-                extensions,
-            });
-            serviceHost.resolveModuleNames = resolveModuleNames;
-            serviceHost.getResolvedModuleWithFailedLookupLocationsFromCache =
-                getResolvedModuleWithFailedLookupLocationsFromCache;
-            serviceHost.resolveTypeReferenceDirectives =
-                resolveTypeReferenceDirectives;
-            const registry = ts.createDocumentRegistry(ts.sys.useCaseSensitiveFileNames, cwd);
-            const service = ts.createLanguageService(serviceHost, registry);
-            const updateMemoryCache = (contents, fileName) => {
-                // Add to `rootFiles` as necessary, either to make TS include a file it has not seen,
-                // or to trigger a re-classification of files from external to internal.
-                if (!rootFileNames.has(fileName) &&
-                    !isFileKnownToBeInternal(fileName)) {
-                    markBucketOfFilenameInternal(fileName);
-                    rootFileNames.add(fileName);
-                    // Increment project version for every change to rootFileNames.
-                    projectVersion++;
-                }
-                const previousVersion = fileVersions.get(fileName) || 0;
-                const previousContents = fileContents.get(fileName);
-                // Avoid incrementing cache when nothing has changed.
-                if (contents !== previousContents) {
-                    fileVersions.set(fileName, previousVersion + 1);
-                    fileContents.set(fileName, contents);
-                    // Increment project version for every file change.
-                    projectVersion++;
-                }
-            };
-            let previousProgram = undefined;
-            getOutput = (code, fileName) => {
-                updateMemoryCache(code, fileName);
-                const programBefore = service.getProgram();
-                if (programBefore !== previousProgram) {
-                    (0, exports.debug)(`compiler rebuilt Program instance when getting output for ${fileName}`);
-                }
-                const output = service.getEmitOutput(fileName);
-                // Get the relevant diagnostics - this is 3x faster than `getPreEmitDiagnostics`.
-                const diagnostics = service
-                    .getSemanticDiagnostics(fileName)
-                    .concat(service.getSyntacticDiagnostics(fileName));
-                const programAfter = service.getProgram();
-                (0, exports.debug)('invariant: Is service.getProject() identical before and after getting emit output and diagnostics? (should always be true) ', programBefore === programAfter);
-                previousProgram = programAfter;
-                const diagnosticList = filterDiagnostics(diagnostics, diagnosticFilters);
-                if (diagnosticList.length)
-                    reportTSError(diagnosticList);
-                if (output.emitSkipped) {
-                    return [undefined, undefined, true];
-                }
-                // Throw an error when requiring `.d.ts` files.
-                if (output.outputFiles.length === 0) {
-                    throw new TypeError(`Unable to require file: ${(0, path_1.relative)(cwd, fileName)}\n` +
-                        'This is usually the result of a faulty configuration or import. ' +
-                        'Make sure there is a `.js`, `.json` or other executable extension with ' +
-                        'loader attached before `ts-node` available.');
-                }
-                return [output.outputFiles[1].text, output.outputFiles[0].text, false];
-            };
-            getTypeInfo = (code, fileName, position) => {
-                const normalizedFileName = (0, util_1.normalizeSlashes)(fileName);
-                updateMemoryCache(code, normalizedFileName);
-                const info = service.getQuickInfoAtPosition(normalizedFileName, position);
-                const name = ts.displayPartsToString(info ? info.displayParts : []);
-                const comment = ts.displayPartsToString(info ? info.documentation : []);
-                return { name, comment };
-            };
-        }
-        else {
-            const sys = {
-                ...ts.sys,
-                ...diagnosticHost,
-                readFile: (fileName) => {
-                    const cacheContents = fileContents.get(fileName);
-                    if (cacheContents !== undefined)
-                        return cacheContents;
-                    const contents = cachedReadFile(fileName);
-                    if (contents)
-                        fileContents.set(fileName, contents);
-                    return contents;
-                },
-                readDirectory: ts.sys.readDirectory,
-                getDirectories: (0, util_1.cachedLookup)(debugFn('getDirectories', ts.sys.getDirectories)),
-                fileExists: (0, util_1.cachedLookup)(debugFn('fileExists', fileExists)),
-                directoryExists: (0, util_1.cachedLookup)(debugFn('directoryExists', ts.sys.directoryExists)),
-                resolvePath: (0, util_1.cachedLookup)(debugFn('resolvePath', ts.sys.resolvePath)),
-                realpath: ts.sys.realpath
-                    ? (0, util_1.cachedLookup)(debugFn('realpath', ts.sys.realpath))
-                    : undefined,
-            };
-            const host = ts.createIncrementalCompilerHost
-                ? ts.createIncrementalCompilerHost(config.options, sys)
-                : {
-                    ...sys,
-                    getSourceFile: (fileName, languageVersion) => {
-                        const contents = sys.readFile(fileName);
-                        if (contents === undefined)
-                            return;
-                        return ts.createSourceFile(fileName, contents, languageVersion);
-                    },
-                    getDefaultLibLocation: () => (0, util_1.normalizeSlashes)((0, path_1.dirname)(compiler)),
-                    getDefaultLibFileName: () => (0, util_1.normalizeSlashes)((0, path_1.join)((0, path_1.dirname)(compiler), ts.getDefaultLibFileName(config.options))),
-                    useCaseSensitiveFileNames: () => sys.useCaseSensitiveFileNames,
-                };
-            host.trace = options.tsTrace;
-            const { resolveModuleNames, resolveTypeReferenceDirectives, isFileKnownToBeInternal, markBucketOfFilenameInternal, } = (0, resolver_functions_1.createResolverFunctions)({
-                host,
-                cwd,
-                config,
-                ts,
-                getCanonicalFileName,
-                projectLocalResolveHelper,
-                options,
-                extensions,
-            });
-            host.resolveModuleNames = resolveModuleNames;
-            host.resolveTypeReferenceDirectives = resolveTypeReferenceDirectives;
-            // Fallback for older TypeScript releases without incremental API.
-            let builderProgram = ts.createIncrementalProgram
-                ? ts.createIncrementalProgram({
-                    rootNames: Array.from(rootFileNames),
-                    options: config.options,
-                    host,
-                    configFileParsingDiagnostics: config.errors,
-                    projectReferences: config.projectReferences,
-                })
-                : ts.createEmitAndSemanticDiagnosticsBuilderProgram(Array.from(rootFileNames), config.options, host, undefined, config.errors, config.projectReferences);
-            // Read and cache custom transformers.
-            const customTransformers = typeof transformers === 'function'
-                ? transformers(builderProgram.getProgram())
-                : transformers;
-            // Set the file contents into cache manually.
-            const updateMemoryCache = (contents, fileName) => {
-                const previousContents = fileContents.get(fileName);
-                const contentsChanged = previousContents !== contents;
-                if (contentsChanged) {
-                    fileContents.set(fileName, contents);
-                }
-                // Add to `rootFiles` when discovered by compiler for the first time.
-                let addedToRootFileNames = false;
-                if (!rootFileNames.has(fileName) &&
-                    !isFileKnownToBeInternal(fileName)) {
-                    markBucketOfFilenameInternal(fileName);
-                    rootFileNames.add(fileName);
-                    addedToRootFileNames = true;
-                }
-                // Update program when file changes.
-                if (addedToRootFileNames || contentsChanged) {
-                    builderProgram = ts.createEmitAndSemanticDiagnosticsBuilderProgram(Array.from(rootFileNames), config.options, host, builderProgram, config.errors, config.projectReferences);
-                }
-            };
-            getOutput = (code, fileName) => {
-                let outText = '';
-                let outMap = '';
-                updateMemoryCache(code, fileName);
-                const sourceFile = builderProgram.getSourceFile(fileName);
-                if (!sourceFile)
-                    throw new TypeError(`Unable to read file: ${fileName}`);
-                const program = builderProgram.getProgram();
-                const diagnostics = ts.getPreEmitDiagnostics(program, sourceFile);
-                const diagnosticList = filterDiagnostics(diagnostics, diagnosticFilters);
-                if (diagnosticList.length)
-                    reportTSError(diagnosticList);
-                const result = builderProgram.emit(sourceFile, (path, file, writeByteOrderMark) => {
-                    if (path.endsWith('.map')) {
-                        outMap = file;
-                    }
-                    else {
-                        outText = file;
-                    }
-                    if (options.emit)
-                        sys.writeFile(path, file, writeByteOrderMark);
-                }, undefined, undefined, customTransformers);
-                if (result.emitSkipped) {
-                    return [undefined, undefined, true];
-                }
-                // Throw an error when requiring files that cannot be compiled.
-                if (outText === '') {
-                    if (program.isSourceFileFromExternalLibrary(sourceFile)) {
-                        throw new TypeError(`Unable to compile file from external library: ${(0, path_1.relative)(cwd, fileName)}`);
-                    }
-                    throw new TypeError(`Unable to require file: ${(0, path_1.relative)(cwd, fileName)}\n` +
-                        'This is usually the result of a faulty configuration or import. ' +
-                        'Make sure there is a `.js`, `.json` or other executable extension with ' +
-                        'loader attached before `ts-node` available.');
-                }
-                return [outText, outMap, false];
-            };
-            getTypeInfo = (code, fileName, position) => {
-                const normalizedFileName = (0, util_1.normalizeSlashes)(fileName);
-                updateMemoryCache(code, normalizedFileName);
-                const sourceFile = builderProgram.getSourceFile(normalizedFileName);
-                if (!sourceFile)
-                    throw new TypeError(`Unable to read file: ${fileName}`);
-                const node = getTokenAtPosition(ts, sourceFile, position);
-                const checker = builderProgram.getProgram().getTypeChecker();
-                const symbol = checker.getSymbolAtLocation(node);
-                if (!symbol)
-                    return { name: '', comment: '' };
-                const type = checker.getTypeOfSymbolAtLocation(symbol, node);
-                const signatures = [
-                    ...type.getConstructSignatures(),
-                    ...type.getCallSignatures(),
-                ];
-                return {
-                    name: signatures.length
-                        ? signatures.map((x) => checker.signatureToString(x)).join('\n')
-                        : checker.typeToString(type),
-                    comment: ts.displayPartsToString(symbol ? symbol.getDocumentationComment(checker) : []),
-                };
-            };
-            // Write `.tsbuildinfo` when `--build` is enabled.
-            if (options.emit && config.options.incremental) {
-                process.on('exit', () => {
-                    // Emits `.tsbuildinfo` to filesystem.
-                    builderProgram.getProgram().emitBuildInfo();
-                });
-            }
-        }
-    }
-    else {
-        getTypeInfo = () => {
-            throw new TypeError('Type information is unavailable in "--transpile-only"');
-        };
-    }
-    function createTranspileOnlyGetOutputFunction(overrideModuleType, nodeModuleEmitKind) {
-        const compilerOptions = { ...config.options };
-        if (overrideModuleType !== undefined)
-            compilerOptions.module = overrideModuleType;
-        let customTranspiler = createTranspiler === null || createTranspiler === void 0 ? void 0 : createTranspiler(compilerOptions, nodeModuleEmitKind);
-        let tsTranspileModule = (0, util_1.versionGteLt)(ts.version, '4.7.0')
-            ? (0, ts_transpile_module_1.createTsTranspileModule)(ts, {
-                compilerOptions,
-                reportDiagnostics: true,
-                transformers: transformers,
-            })
-            : undefined;
-        return (code, fileName) => {
-            let result;
-            if (customTranspiler) {
-                result = customTranspiler.transpile(code, {
-                    fileName,
-                });
-            }
-            else if (tsTranspileModule) {
-                result = tsTranspileModule(code, {
-                    fileName,
-                }, nodeModuleEmitKind === 'nodeesm' ? 'module' : 'commonjs');
-            }
-            else {
-                result = ts.transpileModule(code, {
-                    fileName,
-                    compilerOptions,
-                    reportDiagnostics: true,
-                    transformers: transformers,
-                });
-            }
-            const diagnosticList = filterDiagnostics(result.diagnostics || [], diagnosticFilters);
-            if (diagnosticList.length)
-                reportTSError(diagnosticList);
-            return [result.outputText, result.sourceMapText, false];
-        };
-    }
-    // When true, these mean that a `moduleType` override will cause a different emit
-    // than the TypeScript compiler, so we *must* overwrite the emit.
-    const shouldOverwriteEmitWhenForcingCommonJS = config.options.module !== ts.ModuleKind.CommonJS;
-    // [MUST_UPDATE_FOR_NEW_MODULEKIND]
-    const shouldOverwriteEmitWhenForcingEsm = !(config.options.module === ts.ModuleKind.ES2015 ||
-        (ts.ModuleKind.ES2020 && config.options.module === ts.ModuleKind.ES2020) ||
-        (ts.ModuleKind.ES2022 && config.options.module === ts.ModuleKind.ES2022) ||
-        config.options.module === ts.ModuleKind.ESNext);
-    /**
-     * node16 or nodenext
-     * [MUST_UPDATE_FOR_NEW_MODULEKIND]
-     */
-    const isNodeModuleType = (ts.ModuleKind.Node16 && config.options.module === ts.ModuleKind.Node16) ||
-        (ts.ModuleKind.NodeNext &&
-            config.options.module === ts.ModuleKind.NodeNext);
-    const getOutputForceCommonJS = createTranspileOnlyGetOutputFunction(ts.ModuleKind.CommonJS);
-    const getOutputForceNodeCommonJS = createTranspileOnlyGetOutputFunction(ts.ModuleKind.NodeNext, 'nodecjs');
-    const getOutputForceNodeESM = createTranspileOnlyGetOutputFunction(ts.ModuleKind.NodeNext, 'nodeesm');
-    // [MUST_UPDATE_FOR_NEW_MODULEKIND]
-    const getOutputForceESM = createTranspileOnlyGetOutputFunction(ts.ModuleKind.ES2022 || ts.ModuleKind.ES2020 || ts.ModuleKind.ES2015);
-    const getOutputTranspileOnly = createTranspileOnlyGetOutputFunction();
-    // Create a simple TypeScript compiler proxy.
-    function compile(code, fileName, lineOffset = 0) {
-        const normalizedFileName = (0, util_1.normalizeSlashes)(fileName);
-        const classification = moduleTypeClassifier.classifyModuleByModuleTypeOverrides(normalizedFileName);
-        let value = '';
-        let sourceMap = '';
-        let emitSkipped = true;
-        if (getOutput) {
-            // Must always call normal getOutput to throw typechecking errors
-            [value, sourceMap, emitSkipped] = getOutput(code, normalizedFileName);
-        }
-        // If module classification contradicts the above, call the relevant transpiler
-        if (classification.moduleType === 'cjs' &&
-            (shouldOverwriteEmitWhenForcingCommonJS || emitSkipped)) {
-            [value, sourceMap] = getOutputForceCommonJS(code, normalizedFileName);
-        }
-        else if (classification.moduleType === 'esm' &&
-            (shouldOverwriteEmitWhenForcingEsm || emitSkipped)) {
-            [value, sourceMap] = getOutputForceESM(code, normalizedFileName);
-        }
-        else if (emitSkipped) {
-            // Happens when ts compiler skips emit or in transpileOnly mode
-            const classification = (0, node_module_type_classifier_1.classifyModule)(fileName, isNodeModuleType);
-            [value, sourceMap] =
-                classification === 'nodecjs'
-                    ? getOutputForceNodeCommonJS(code, normalizedFileName)
-                    : classification === 'nodeesm'
-                        ? getOutputForceNodeESM(code, normalizedFileName)
-                        : classification === 'cjs'
-                            ? getOutputForceCommonJS(code, normalizedFileName)
-                            : classification === 'esm'
-                                ? getOutputForceESM(code, normalizedFileName)
-                                : getOutputTranspileOnly(code, normalizedFileName);
-        }
-        const output = updateOutput(value, normalizedFileName, sourceMap, getEmitExtension);
-        outputCache.set(normalizedFileName, { content: output });
-        return output;
-    }
-    let active = true;
-    const enabled = (enabled) => enabled === undefined ? active : (active = !!enabled);
-    const ignored = (fileName) => {
-        if (!active)
-            return true;
-        const ext = (0, path_1.extname)(fileName);
-        if (extensions.compiled.includes(ext)) {
-            return !isScoped(fileName) || shouldIgnore(fileName);
-        }
-        return true;
-    };
-    function addDiagnosticFilter(filter) {
-        diagnosticFilters.push({
-            ...filter,
-            filenamesAbsolute: filter.filenamesAbsolute.map((f) => (0, util_1.normalizeSlashes)(f)),
-        });
-    }
-    const getNodeEsmResolver = (0, util_1.once)(() => (__nccwpck_require__(83788).createResolve)({
-        extensions,
-        preferTsExts: options.preferTsExts,
-        tsNodeExperimentalSpecifierResolution: options.experimentalSpecifierResolution,
-    }));
-    const getNodeEsmGetFormat = (0, util_1.once)(() => (__nccwpck_require__(77114).createGetFormat)(options.experimentalSpecifierResolution, getNodeEsmResolver()));
-    const getNodeCjsLoader = (0, util_1.once)(() => (__nccwpck_require__(11717).createCjsLoader)({
-        extensions,
-        preferTsExts: options.preferTsExts,
-        nodeEsmResolver: getNodeEsmResolver(),
-    }));
-    return {
-        [TS_NODE_SERVICE_BRAND]: true,
-        ts,
-        compilerPath: compiler,
-        config,
-        compile,
-        getTypeInfo,
-        ignored,
-        enabled,
-        options,
-        configFilePath,
-        moduleTypeClassifier,
-        shouldReplAwait,
-        addDiagnosticFilter,
-        installSourceMapSupport,
-        enableExperimentalEsmLoaderInterop,
-        transpileOnly,
-        projectLocalResolveHelper,
-        getNodeEsmResolver,
-        getNodeEsmGetFormat,
-        getNodeCjsLoader,
-        extensions,
-    };
-}
-exports.createFromPreloadedConfig = createFromPreloadedConfig;
-/**
- * Check if the filename should be ignored.
- */
-function createIgnore(ignoreBaseDir, ignore) {
-    return (fileName) => {
-        const relname = (0, path_1.relative)(ignoreBaseDir, fileName);
-        const path = (0, util_1.normalizeSlashes)(relname);
-        return ignore.some((x) => x.test(path));
-    };
-}
-/**
- * Register the extensions to support when importing files.
- */
-function registerExtensions(preferTsExts, extensions, service, originalJsHandler) {
-    const exts = new Set(extensions);
-    // Can't add these extensions cuz would allow omitting file extension; node requires ext for .cjs and .mjs
-    // Unless they're already registered by something else (nyc does this):
-    // then we *must* hook them or else our transformer will not be called.
-    for (const cannotAdd of ['.mts', '.cts', '.mjs', '.cjs']) {
-        if (exts.has(cannotAdd) && !(0, util_1.hasOwnProperty)(require.extensions, cannotAdd)) {
-            // Unrecognized file exts can be transformed via the `.js` handler.
-            exts.add('.js');
-            exts.delete(cannotAdd);
-        }
-    }
-    // Register new extensions.
-    for (const ext of exts) {
-        registerExtension(ext, service, originalJsHandler);
-    }
-    if (preferTsExts) {
-        const preferredExtensions = new Set([
-            ...exts,
-            ...Object.keys(require.extensions),
-        ]);
-        // Re-sort iteration order of Object.keys()
-        for (const ext of preferredExtensions) {
-            const old = Object.getOwnPropertyDescriptor(require.extensions, ext);
-            delete require.extensions[ext];
-            Object.defineProperty(require.extensions, ext, old);
-        }
-    }
-}
-/**
- * Register the extension for node.
- */
-function registerExtension(ext, service, originalHandler) {
-    const old = require.extensions[ext] || originalHandler;
-    require.extensions[ext] = function (m, filename) {
-        if (service.ignored(filename))
-            return old(m, filename);
-        assertScriptCanLoadAsCJS(service, m, filename);
-        const _compile = m._compile;
-        m._compile = function (code, fileName) {
-            (0, exports.debug)('module._compile', fileName);
-            const result = service.compile(code, fileName);
-            return _compile.call(this, result, fileName);
-        };
-        return old(m, filename);
-    };
-}
-/**
- * Update the output remapping the source map.
- */
-function updateOutput(outputText, fileName, sourceMap, getEmitExtension) {
-    const base64Map = Buffer.from(updateSourceMap(sourceMap, fileName), 'utf8').toString('base64');
-    const sourceMapContent = `//# sourceMappingURL=data:application/json;charset=utf-8;base64,${base64Map}`;
-    // Expected form: `//# sourceMappingURL=foo bar.js.map` or `//# sourceMappingURL=foo%20bar.js.map` for input file "foo bar.tsx"
-    // Percent-encoding behavior added in TS 4.1.1: https://github.com/microsoft/TypeScript/issues/40951
-    const prefix = '//# sourceMappingURL=';
-    const prefixLength = prefix.length;
-    const baseName = /*foo.tsx*/ (0, path_1.basename)(fileName);
-    const extName = /*.tsx*/ (0, path_1.extname)(fileName);
-    const extension = /*.js*/ getEmitExtension(fileName);
-    const sourcemapFilename = baseName.slice(0, -extName.length) + extension + '.map';
-    const sourceMapLengthWithoutPercentEncoding = prefixLength + sourcemapFilename.length;
-    /*
-     * Only rewrite if existing directive exists at the location we expect, to support:
-     *   a) compilers that do not append a sourcemap directive
-     *   b) situations where we did the math wrong
-     *     Not ideal, but appending our sourcemap *after* a pre-existing sourcemap still overrides, so the end-user is happy.
-     */
-    if (outputText.substr(-sourceMapLengthWithoutPercentEncoding, prefixLength) ===
-        prefix) {
-        return (outputText.slice(0, -sourceMapLengthWithoutPercentEncoding) +
-            sourceMapContent);
-    }
-    // If anyone asks why we're not using URL, the URL equivalent is: `u = new URL('http://d'); u.pathname = "/" + sourcemapFilename; return u.pathname.slice(1);
-    const sourceMapLengthWithPercentEncoding = prefixLength + encodeURI(sourcemapFilename).length;
-    if (outputText.substr(-sourceMapLengthWithPercentEncoding, prefixLength) ===
-        prefix) {
-        return (outputText.slice(0, -sourceMapLengthWithPercentEncoding) +
-            sourceMapContent);
-    }
-    return `${outputText}\n${sourceMapContent}`;
-}
-/**
- * Update the source map contents for improved output.
- */
-function updateSourceMap(sourceMapText, fileName) {
-    const sourceMap = JSON.parse(sourceMapText);
-    sourceMap.file = fileName;
-    sourceMap.sources = [fileName];
-    delete sourceMap.sourceRoot;
-    return JSON.stringify(sourceMap);
-}
-/**
- * Filter diagnostics.
- */
-function filterDiagnostics(diagnostics, filters) {
-    return diagnostics.filter((d) => filters.every((f) => {
-        var _a;
-        return (!f.appliesToAllFiles &&
-            f.filenamesAbsolute.indexOf((_a = d.file) === null || _a === void 0 ? void 0 : _a.fileName) === -1) ||
-            f.diagnosticsIgnored.indexOf(d.code) === -1;
-    }));
-}
-/**
- * Get token at file position.
- *
- * Reference: https://github.com/microsoft/TypeScript/blob/fcd9334f57d85b73dd66ad2d21c02e84822f4841/src/services/utilities.ts#L705-L731
- */
-function getTokenAtPosition(ts, sourceFile, position) {
-    let current = sourceFile;
-    outer: while (true) {
-        for (const child of current.getChildren(sourceFile)) {
-            const start = child.getFullStart();
-            if (start > position)
-                break;
-            const end = child.getEnd();
-            if (position <= end) {
-                current = child;
-                continue outer;
-            }
-        }
-        return current;
-    }
-}
-/**
- * Create an implementation of node's ESM loader hooks.
- *
- * This may be useful if you
- * want to wrap or compose the loader hooks to add additional functionality or
- * combine with another loader.
- *
- * Node changed the hooks API, so there are two possible APIs.  This function
- * detects your node version and returns the appropriate API.
- *
- * @category ESM Loader
- */
-const createEsmHooks = (tsNodeService) => (__nccwpck_require__(13108)/* .createEsmHooks */ .lT)(tsNodeService);
-exports.createEsmHooks = createEsmHooks;
-//# sourceMappingURL=index.js.map
-
-/***/ }),
-
-/***/ 26705:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
-
-"use strict";
-
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.createModuleTypeClassifier = void 0;
-const ts_internals_1 = __nccwpck_require__(37432);
-const util_1 = __nccwpck_require__(81842);
-/**
- * @internal
- * May receive non-normalized options -- basePath and patterns -- and will normalize them
- * internally.
- * However, calls to `classifyModule` must pass pre-normalized paths!
- */
-function createModuleTypeClassifier(options) {
-    const { patterns, basePath: _basePath } = options;
-    const basePath = _basePath !== undefined
-        ? (0, util_1.normalizeSlashes)(_basePath).replace(/\/$/, '')
-        : undefined;
-    const patternTypePairs = Object.entries(patterns !== null && patterns !== void 0 ? patterns : []).map(([_pattern, type]) => {
-        const pattern = (0, util_1.normalizeSlashes)(_pattern);
-        return { pattern: parsePattern(basePath, pattern), type };
-    });
-    const classifications = {
-        package: {
-            moduleType: 'auto',
-        },
-        cjs: {
-            moduleType: 'cjs',
-        },
-        esm: {
-            moduleType: 'esm',
-        },
-    };
-    const auto = classifications.package;
-    // Passed path must be normalized!
-    function classifyModuleNonCached(path) {
-        const matched = matchPatterns(patternTypePairs, (_) => _.pattern, path);
-        if (matched)
-            return classifications[matched.type];
-        return auto;
-    }
-    const classifyModule = (0, util_1.cachedLookup)(classifyModuleNonCached);
-    function classifyModuleAuto(path) {
-        return auto;
-    }
-    return {
-        classifyModuleByModuleTypeOverrides: patternTypePairs.length
-            ? classifyModule
-            : classifyModuleAuto,
-    };
-}
-exports.createModuleTypeClassifier = createModuleTypeClassifier;
-function parsePattern(basePath, patternString) {
-    const pattern = (0, ts_internals_1.getPatternFromSpec)(patternString, basePath);
-    return pattern !== undefined ? new RegExp(pattern) : /(?:)/;
-}
-function matchPatterns(objects, getPattern, candidate) {
-    for (let i = objects.length - 1; i >= 0; i--) {
-        const object = objects[i];
-        const pattern = getPattern(object);
-        if (pattern === null || pattern === void 0 ? void 0 : pattern.test(candidate)) {
-            return object;
-        }
-    }
-}
-//# sourceMappingURL=module-type-classifier.js.map
-
-/***/ }),
-
-/***/ 59503:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
-
-"use strict";
-
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.classifyModule = void 0;
-const node_internal_modules_cjs_loader_1 = __nccwpck_require__(11717);
-/**
- * Determine how to emit a module based on tsconfig "module" and package.json "type"
- *
- * Supports module=nodenext/node16 with transpileOnly, where we cannot ask the
- * TS typechecker to tell us if a file is CJS or ESM.
- *
- * Return values indicate:
- * - cjs
- * - esm
- * - nodecjs == node-flavored cjs where dynamic imports are *not* transformed into `require()`
- * - undefined == emit according to tsconfig `module` config, whatever that is
- * @internal
- */
-function classifyModule(nativeFilename, isNodeModuleType) {
-    // [MUST_UPDATE_FOR_NEW_FILE_EXTENSIONS]
-    const lastDotIndex = nativeFilename.lastIndexOf('.');
-    const ext = lastDotIndex >= 0 ? nativeFilename.slice(lastDotIndex) : '';
-    switch (ext) {
-        case '.cjs':
-        case '.cts':
-            return isNodeModuleType ? 'nodecjs' : 'cjs';
-        case '.mjs':
-        case '.mts':
-            return isNodeModuleType ? 'nodeesm' : 'esm';
-    }
-    if (isNodeModuleType) {
-        const packageScope = (0, node_internal_modules_cjs_loader_1.readPackageScope)(nativeFilename);
-        if (packageScope && packageScope.data.type === 'module')
-            return 'nodeesm';
-        return 'nodecjs';
-    }
-    return undefined;
-}
-exports.classifyModule = classifyModule;
-//# sourceMappingURL=node-module-type-classifier.js.map
-
-/***/ }),
-
-/***/ 45890:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
-
-"use strict";
-
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.setupContext = exports.createEvalAwarePartialHost = exports.EvalState = exports.createRepl = exports.REPL_NAME = exports.REPL_FILENAME = exports.STDIN_NAME = exports.STDIN_FILENAME = exports.EVAL_NAME = exports.EVAL_FILENAME = void 0;
-const os_1 = __nccwpck_require__(22037);
-const path_1 = __nccwpck_require__(71017);
-const repl_1 = __nccwpck_require__(38102);
-const vm_1 = __nccwpck_require__(26144);
-const index_1 = __nccwpck_require__(51351);
-const fs_1 = __nccwpck_require__(57147);
-const console_1 = __nccwpck_require__(96206);
-const assert = __nccwpck_require__(39491);
-const module_1 = __nccwpck_require__(98188);
-// Lazy-loaded.
-let _processTopLevelAwait;
-function getProcessTopLevelAwait() {
-    if (_processTopLevelAwait === undefined) {
-        ({
-            processTopLevelAwait: _processTopLevelAwait,
-        } = __nccwpck_require__(43803));
-    }
-    return _processTopLevelAwait;
-}
-let diff;
-function getDiffLines() {
-    if (diff === undefined) {
-        diff = __nccwpck_require__(45604);
-    }
-    return diff.diffLines;
-}
-/** @internal */
-exports.EVAL_FILENAME = `[eval].ts`;
-/** @internal */
-exports.EVAL_NAME = `[eval]`;
-/** @internal */
-exports.STDIN_FILENAME = `[stdin].ts`;
-/** @internal */
-exports.STDIN_NAME = `[stdin]`;
-/** @internal */
-exports.REPL_FILENAME = '.ts';
-/** @internal */
-exports.REPL_NAME = '';
-/**
- * Create a ts-node REPL instance.
- *
- * Pay close attention to the example below.  Today, the API requires a few lines
- * of boilerplate to correctly bind the `ReplService` to the ts-node `Service` and
- * vice-versa.
- *
- * Usage example:
- *
- *     const repl = tsNode.createRepl();
- *     const service = tsNode.create({...repl.evalAwarePartialHost});
- *     repl.setService(service);
- *     repl.start();
- *
- * @category REPL
- */
-function createRepl(options = {}) {
-    var _a, _b, _c, _d, _e;
-    const { ignoreDiagnosticsThatAreAnnoyingInInteractiveRepl = true } = options;
-    let service = options.service;
-    let nodeReplServer;
-    // If `useGlobal` is not true, then REPL creates a context when started.
-    // This stores a reference to it or to `global`, whichever is used, after REPL has started.
-    let context;
-    const state = (_a = options.state) !== null && _a !== void 0 ? _a : new EvalState((0, path_1.join)(process.cwd(), exports.REPL_FILENAME));
-    const evalAwarePartialHost = createEvalAwarePartialHost(state, options.composeWithEvalAwarePartialHost);
-    const stdin = (_b = options.stdin) !== null && _b !== void 0 ? _b : process.stdin;
-    const stdout = (_c = options.stdout) !== null && _c !== void 0 ? _c : process.stdout;
-    const stderr = (_d = options.stderr) !== null && _d !== void 0 ? _d : process.stderr;
-    const _console = stdout === process.stdout && stderr === process.stderr
-        ? console
-        : new console_1.Console(stdout, stderr);
-    const replService = {
-        state: (_e = options.state) !== null && _e !== void 0 ? _e : new EvalState((0, path_1.join)(process.cwd(), exports.EVAL_FILENAME)),
-        setService,
-        evalCode,
-        evalCodeInternal,
-        nodeEval,
-        evalAwarePartialHost,
-        start,
-        startInternal,
-        stdin,
-        stdout,
-        stderr,
-        console: _console,
-    };
-    return replService;
-    function setService(_service) {
-        service = _service;
-        if (ignoreDiagnosticsThatAreAnnoyingInInteractiveRepl) {
-            service.addDiagnosticFilter({
-                appliesToAllFiles: false,
-                filenamesAbsolute: [state.path],
-                diagnosticsIgnored: [
-                    2393,
-                    6133,
-                    7027,
-                    ...(service.shouldReplAwait ? topLevelAwaitDiagnosticCodes : []),
-                ],
-            });
-        }
-    }
-    function evalCode(code) {
-        const result = appendCompileAndEvalInput({
-            service: service,
-            state,
-            input: code,
-            context,
-            overrideIsCompletion: false,
-        });
-        assert(result.containsTopLevelAwait === false);
-        return result.value;
-    }
-    function evalCodeInternal(options) {
-        const { code, enableTopLevelAwait, context } = options;
-        return appendCompileAndEvalInput({
-            service: service,
-            state,
-            input: code,
-            enableTopLevelAwait,
-            context,
-        });
-    }
-    function nodeEval(code, context, _filename, callback) {
-        // TODO: Figure out how to handle completion here.
-        if (code === '.scope') {
-            callback(null);
-            return;
-        }
-        try {
-            const evalResult = evalCodeInternal({
-                code,
-                enableTopLevelAwait: true,
-                context,
-            });
-            if (evalResult.containsTopLevelAwait) {
-                (async () => {
-                    try {
-                        callback(null, await evalResult.valuePromise);
-                    }
-                    catch (promiseError) {
-                        handleError(promiseError);
-                    }
-                })();
-            }
-            else {
-                callback(null, evalResult.value);
-            }
-        }
-        catch (error) {
-            handleError(error);
-        }
-        // Log TSErrors, check if they're recoverable, log helpful hints for certain
-        // well-known errors, and invoke `callback()`
-        // TODO should evalCode API get the same error-handling benefits?
-        function handleError(error) {
-            var _a, _b;
-            // Don't show TLA hint if the user explicitly disabled repl top level await
-            const canLogTopLevelAwaitHint = service.options.experimentalReplAwait !== false &&
-                !service.shouldReplAwait;
-            if (error instanceof index_1.TSError) {
-                // Support recoverable compilations using >= node 6.
-                if (repl_1.Recoverable && isRecoverable(error)) {
-                    callback(new repl_1.Recoverable(error));
-                    return;
-                }
-                else {
-                    _console.error(error);
-                    if (canLogTopLevelAwaitHint &&
-                        error.diagnosticCodes.some((dC) => topLevelAwaitDiagnosticCodes.includes(dC))) {
-                        _console.error(getTopLevelAwaitHint());
-                    }
-                    callback(null);
-                }
-            }
-            else {
-                let _error = error;
-                if (canLogTopLevelAwaitHint &&
-                    _error instanceof SyntaxError &&
-                    ((_a = _error.message) === null || _a === void 0 ? void 0 : _a.includes('await is only valid'))) {
-                    try {
-                        // Only way I know to make our hint appear after the error
-                        _error.message += `\n\n${getTopLevelAwaitHint()}`;
-                        _error.stack = (_b = _error.stack) === null || _b === void 0 ? void 0 : _b.replace(/(SyntaxError:.*)/, (_, $1) => `${$1}\n\n${getTopLevelAwaitHint()}`);
-                    }
-                    catch { }
-                }
-                callback(_error);
-            }
-        }
-        function getTopLevelAwaitHint() {
-            return `Hint: REPL top-level await requires TypeScript version 3.8 or higher and target ES2018 or higher. You are using TypeScript ${service.ts.version} and target ${service.ts.ScriptTarget[service.config.options.target]}.`;
-        }
-    }
-    // Note: `code` argument is deprecated
-    function start(code) {
-        startInternal({ code });
-    }
-    // Note: `code` argument is deprecated
-    function startInternal(options) {
-        const { code, forceToBeModule = true, ...optionsOverride } = options !== null && options !== void 0 ? options : {};
-        // TODO assert that `service` is set; remove all `service!` non-null assertions
-        // Eval incoming code before the REPL starts.
-        // Note: deprecated
-        if (code) {
-            try {
-                evalCode(`${code}\n`);
-            }
-            catch (err) {
-                _console.error(err);
-                // Note: should not be killing the process here, but this codepath is deprecated anyway
-                process.exit(1);
-            }
-        }
-        // In case the typescript compiler hasn't compiled anything yet,
-        // make it run though compilation at least one time before
-        // the REPL starts for a snappier user experience on startup.
-        service === null || service === void 0 ? void 0 : service.compile('', state.path);
-        const repl = (0, repl_1.start)({
-            prompt: '> ',
-            input: replService.stdin,
-            output: replService.stdout,
-            // Mimicking node's REPL implementation: https://github.com/nodejs/node/blob/168b22ba073ee1cbf8d0bcb4ded7ff3099335d04/lib/internal/repl.js#L28-L30
-            terminal: stdout.isTTY &&
-                !parseInt(index_1.env.NODE_NO_READLINE, 10),
-            eval: nodeEval,
-            useGlobal: true,
-            ...optionsOverride,
-        });
-        nodeReplServer = repl;
-        context = repl.context;
-        // Bookmark the point where we should reset the REPL state.
-        const resetEval = appendToEvalState(state, '');
-        function reset() {
-            resetEval();
-            // Hard fix for TypeScript forcing `Object.defineProperty(exports, ...)`.
-            runInContext('exports = module.exports', state.path, context);
-            if (forceToBeModule) {
-                state.input += 'export {};void 0;\n';
-            }
-            // Declare node builtins.
-            // Skip the same builtins as `addBuiltinLibsToObject`:
-            //   those starting with _
-            //   those containing /
-            //   those that already exist as globals
-            // Intentionally suppress type errors in case @types/node does not declare any of them, and because
-            // `declare import` is technically invalid syntax.
-            // Avoid this when in transpileOnly, because third-party transpilers may not handle `declare import`.
-            if (!(service === null || service === void 0 ? void 0 : service.transpileOnly)) {
-                state.input += `// @ts-ignore\n${module_1.builtinModules
-                    .filter((name) => !name.startsWith('_') &&
-                    !name.includes('/') &&
-                    !['console', 'module', 'process'].includes(name))
-                    .map((name) => `declare import ${name} = require('${name}')`)
-                    .join(';')}\n`;
-            }
-        }
-        reset();
-        repl.on('reset', reset);
-        repl.defineCommand('type', {
-            help: 'Check the type of a TypeScript identifier',
-            action: function (identifier) {
-                if (!identifier) {
-                    repl.displayPrompt();
-                    return;
-                }
-                const undo = appendToEvalState(state, identifier);
-                const { name, comment } = service.getTypeInfo(state.input, state.path, state.input.length);
-                undo();
-                if (name)
-                    repl.outputStream.write(`${name}\n`);
-                if (comment)
-                    repl.outputStream.write(`${comment}\n`);
-                repl.displayPrompt();
-            },
-        });
-        // Set up REPL history when available natively via node.js >= 11.
-        if (repl.setupHistory) {
-            const historyPath = index_1.env.TS_NODE_HISTORY || (0, path_1.join)((0, os_1.homedir)(), '.ts_node_repl_history');
-            repl.setupHistory(historyPath, (err) => {
-                if (!err)
-                    return;
-                _console.error(err);
-                process.exit(1);
-            });
-        }
-        return repl;
-    }
-}
-exports.createRepl = createRepl;
-/**
- * Eval state management. Stores virtual `[eval].ts` file
- */
-class EvalState {
-    constructor(path) {
-        this.path = path;
-        /** @internal */
-        this.input = '';
-        /** @internal */
-        this.output = '';
-        /** @internal */
-        this.version = 0;
-        /** @internal */
-        this.lines = 0;
-    }
-}
-exports.EvalState = EvalState;
-function createEvalAwarePartialHost(state, composeWith) {
-    function readFile(path) {
-        if (path === state.path)
-            return state.input;
-        if (composeWith === null || composeWith === void 0 ? void 0 : composeWith.readFile)
-            return composeWith.readFile(path);
-        try {
-            return (0, fs_1.readFileSync)(path, 'utf8');
-        }
-        catch (err) {
-            /* Ignore. */
-        }
-    }
-    function fileExists(path) {
-        if (path === state.path)
-            return true;
-        if (composeWith === null || composeWith === void 0 ? void 0 : composeWith.fileExists)
-            return composeWith.fileExists(path);
-        try {
-            const stats = (0, fs_1.statSync)(path);
-            return stats.isFile() || stats.isFIFO();
-        }
-        catch (err) {
-            return false;
-        }
-    }
-    return { readFile, fileExists };
-}
-exports.createEvalAwarePartialHost = createEvalAwarePartialHost;
-const sourcemapCommentRe = /\/\/# ?sourceMappingURL=\S+[\s\r\n]*$/;
-/**
- * Evaluate the code snippet.
- *
- * Append it to virtual .ts file, compile, handle compiler errors, compute a diff of the JS, and eval any code that
- * appears as "added" in the diff.
- */
-function appendCompileAndEvalInput(options) {
-    const { service, state, wrappedErr, enableTopLevelAwait = false, context, overrideIsCompletion, } = options;
-    let { input } = options;
-    // It's confusing for `{ a: 1 }` to be interpreted as a block statement
-    // rather than an object literal. So, we first try to wrap it in
-    // parentheses, so that it will be interpreted as an expression.
-    // Based on https://github.com/nodejs/node/blob/c2e6822153bad023ab7ebd30a6117dcc049e475c/lib/repl.js#L413-L422
-    let wrappedCmd = false;
-    if (!wrappedErr && /^\s*{/.test(input) && !/;\s*$/.test(input)) {
-        input = `(${input.trim()})\n`;
-        wrappedCmd = true;
-    }
-    const lines = state.lines;
-    const isCompletion = overrideIsCompletion !== null && overrideIsCompletion !== void 0 ? overrideIsCompletion : !/\n$/.test(input);
-    const undo = appendToEvalState(state, input);
-    let output;
-    // Based on https://github.com/nodejs/node/blob/92573721c7cff104ccb82b6ed3e8aa69c4b27510/lib/repl.js#L457-L461
-    function adjustUseStrict(code) {
-        // "void 0" keeps the repl from returning "use strict" as the result
-        // value for statements and declarations that don't return a value.
-        return code.replace(/^"use strict";/, '"use strict"; void 0;');
-    }
-    try {
-        output = service.compile(state.input, state.path, -lines);
-    }
-    catch (err) {
-        undo();
-        if (wrappedCmd) {
-            if (err instanceof index_1.TSError && err.diagnosticCodes[0] === 2339) {
-                // Ensure consistent and more sane behavior between { a: 1 }['b'] and ({ a: 1 }['b'])
-                throw err;
-            }
-            // Unwrap and try again
-            return appendCompileAndEvalInput({
-                ...options,
-                wrappedErr: err,
-            });
-        }
-        if (wrappedErr)
-            throw wrappedErr;
-        throw err;
-    }
-    output = adjustUseStrict(output);
-    // Note: REPL does not respect sourcemaps!
-    // To properly do that, we'd need to prefix the code we eval -- which comes
-    // from `diffLines` -- with newlines so that it's at the proper line numbers.
-    // Then we'd need to ensure each bit of eval-ed code, if there are multiples,
-    // has the sourcemap appended to it.
-    // We might also need to integrate with our sourcemap hooks' cache; I'm not sure.
-    const outputWithoutSourcemapComment = output.replace(sourcemapCommentRe, '');
-    const oldOutputWithoutSourcemapComment = state.output.replace(sourcemapCommentRe, '');
-    // Use `diff` to check for new JavaScript to execute.
-    const changes = getDiffLines()(oldOutputWithoutSourcemapComment, outputWithoutSourcemapComment);
-    if (isCompletion) {
-        undo();
-    }
-    else {
-        state.output = output;
-        // Insert a semicolon to make sure that the code doesn't interact with the next line,
-        // for example to prevent `2\n+ 2` from producing 4.
-        // This is safe since the output will not change since we can only get here with successful inputs,
-        // and adding a semicolon to the end of a successful input won't ever change the output.
-        state.input = state.input.replace(/([^\n\s])([\n\s]*)$/, (all, lastChar, whitespace) => {
-            if (lastChar !== ';')
-                return `${lastChar};${whitespace}`;
-            return all;
-        });
-    }
-    let commands = [];
-    let containsTopLevelAwait = false;
-    // Build a list of "commands": bits of JS code in the diff that must be executed.
-    for (const change of changes) {
-        if (change.added) {
-            if (enableTopLevelAwait &&
-                service.shouldReplAwait &&
-                change.value.indexOf('await') > -1) {
-                const processTopLevelAwait = getProcessTopLevelAwait();
-                // Newline prevents comments to mess with wrapper
-                const wrappedResult = processTopLevelAwait(change.value + '\n');
-                if (wrappedResult !== null) {
-                    containsTopLevelAwait = true;
-                    commands.push({
-                        mustAwait: true,
-                        execCommand: () => runInContext(wrappedResult, state.path, context),
-                    });
-                    continue;
-                }
-            }
-            commands.push({
-                execCommand: () => runInContext(change.value, state.path, context),
-            });
-        }
-    }
-    // Execute all commands asynchronously if necessary, returning the result or a
-    // promise of the result.
-    if (containsTopLevelAwait) {
-        return {
-            containsTopLevelAwait,
-            valuePromise: (async () => {
-                let value;
-                for (const command of commands) {
-                    const r = command.execCommand();
-                    value = command.mustAwait ? await r : r;
-                }
-                return value;
-            })(),
-        };
-    }
-    else {
-        return {
-            containsTopLevelAwait: false,
-            value: commands.reduce((_, c) => c.execCommand(), undefined),
-        };
-    }
-}
-/**
- * Low-level execution of JS code in context
- */
-function runInContext(code, filename, context) {
-    const script = new vm_1.Script(code, { filename });
-    if (context === undefined || context === global) {
-        return script.runInThisContext();
-    }
-    else {
-        return script.runInContext(context);
-    }
-}
-/**
- * Append to the eval instance and return an undo function.
- */
-function appendToEvalState(state, input) {
-    const undoInput = state.input;
-    const undoVersion = state.version;
-    const undoOutput = state.output;
-    const undoLines = state.lines;
-    state.input += input;
-    state.lines += lineCount(input);
-    state.version++;
-    return function () {
-        state.input = undoInput;
-        state.output = undoOutput;
-        state.version = undoVersion;
-        state.lines = undoLines;
-    };
-}
-/**
- * Count the number of lines.
- */
-function lineCount(value) {
-    let count = 0;
-    for (const char of value) {
-        if (char === '\n') {
-            count++;
-        }
-    }
-    return count;
-}
-/**
- * TS diagnostic codes which are recoverable, meaning that the user likely entered an incomplete line of code
- * and should be prompted for the next.  For example, starting a multi-line for() loop and not finishing it.
- * null value means code is always recoverable.  `Set` means code is only recoverable when occurring alongside at least one
- * of the other codes.
- */
-const RECOVERY_CODES = new Map([
-    [1003, null],
-    [1005, null],
-    [1109, null],
-    [1126, null],
-    [
-        1136,
-        new Set([1005]), // happens when typing out an object literal or block scope across multiple lines: '{ foo: 123,'
-    ],
-    [1160, null],
-    [1161, null],
-    [2355, null],
-    [2391, null],
-    [
-        7010,
-        new Set([1005]), // happens when fn signature spread across multiple lines: 'function a(\nb: any\n) {'
-    ],
-]);
-/**
- * Diagnostic codes raised when using top-level await.
- * These are suppressed when top-level await is enabled.
- * When it is *not* enabled, these trigger a helpful hint about enabling top-level await.
- */
-const topLevelAwaitDiagnosticCodes = [
-    1375,
-    1378,
-    1431,
-    1432, // Top-level 'for await' loops are only allowed when the 'module' option is set to 'esnext' or 'system', and the 'target' option is set to 'es2017' or higher.
-];
-/**
- * Check if a function can recover gracefully.
- */
-function isRecoverable(error) {
-    return error.diagnosticCodes.every((code) => {
-        const deps = RECOVERY_CODES.get(code);
-        return (deps === null ||
-            (deps && error.diagnosticCodes.some((code) => deps.has(code))));
-    });
-}
-/**
- * @internal
- * Set properties on `context` before eval-ing [stdin] or [eval] input.
- */
-function setupContext(context, module, filenameAndDirname) {
-    if (filenameAndDirname) {
-        context.__dirname = '.';
-        context.__filename = `[${filenameAndDirname}]`;
-    }
-    context.module = module;
-    context.exports = module.exports;
-    context.require = __nccwpck_require__(3833).bind(module);
-}
-exports.setupContext = setupContext;
-//# sourceMappingURL=repl.js.map
-
-/***/ }),
-
-/***/ 59765:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
-
-"use strict";
-
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.createResolverFunctions = void 0;
-const path_1 = __nccwpck_require__(71017);
-/**
- * @internal
- * In a factory because these are shared across both CompilerHost and LanguageService codepaths
- */
-function createResolverFunctions(kwargs) {
-    const { host, ts, config, cwd, getCanonicalFileName, projectLocalResolveHelper, options, extensions, } = kwargs;
-    const moduleResolutionCache = ts.createModuleResolutionCache(cwd, getCanonicalFileName, config.options);
-    const knownInternalFilenames = new Set();
-    /** "Buckets" (module directories) whose contents should be marked "internal" */
-    const internalBuckets = new Set();
-    // Get bucket for a source filename.  Bucket is the containing `./node_modules/*/` directory
-    // For '/project/node_modules/foo/node_modules/bar/lib/index.js' bucket is '/project/node_modules/foo/node_modules/bar/'
-    // For '/project/node_modules/foo/node_modules/@scope/bar/lib/index.js' bucket is '/project/node_modules/foo/node_modules/@scope/bar/'
-    const moduleBucketRe = /.*\/node_modules\/(?:@[^\/]+\/)?[^\/]+\//;
-    function getModuleBucket(filename) {
-        const find = moduleBucketRe.exec(filename);
-        if (find)
-            return find[0];
-        return '';
-    }
-    // Mark that this file and all siblings in its bucket should be "internal"
-    function markBucketOfFilenameInternal(filename) {
-        internalBuckets.add(getModuleBucket(filename));
-    }
-    function isFileInInternalBucket(filename) {
-        return internalBuckets.has(getModuleBucket(filename));
-    }
-    function isFileKnownToBeInternal(filename) {
-        return knownInternalFilenames.has(filename);
-    }
-    /**
-     * If we need to emit JS for a file, force TS to consider it non-external
-     */
-    const fixupResolvedModule = (resolvedModule) => {
-        const { resolvedFileName } = resolvedModule;
-        if (resolvedFileName === undefined)
-            return;
-        // [MUST_UPDATE_FOR_NEW_FILE_EXTENSIONS]
-        // .ts,.mts,.cts is always switched to internal
-        // .js is switched on-demand
-        if (resolvedModule.isExternalLibraryImport &&
-            ((resolvedFileName.endsWith('.ts') &&
-                !resolvedFileName.endsWith('.d.ts')) ||
-                (resolvedFileName.endsWith('.cts') &&
-                    !resolvedFileName.endsWith('.d.cts')) ||
-                (resolvedFileName.endsWith('.mts') &&
-                    !resolvedFileName.endsWith('.d.mts')) ||
-                isFileKnownToBeInternal(resolvedFileName) ||
-                isFileInInternalBucket(resolvedFileName))) {
-            resolvedModule.isExternalLibraryImport = false;
-        }
-        if (!resolvedModule.isExternalLibraryImport) {
-            knownInternalFilenames.add(resolvedFileName);
-        }
-    };
-    /*
-     * NOTE:
-     * Older ts versions do not pass `redirectedReference` nor `options`.
-     * We must pass `redirectedReference` to newer ts versions, but cannot rely on `options`, hence the weird argument name
-     */
-    const resolveModuleNames = (moduleNames, containingFile, reusedNames, redirectedReference, optionsOnlyWithNewerTsVersions, containingSourceFile) => {
-        return moduleNames.map((moduleName, i) => {
-            var _a, _b;
-            const mode = containingSourceFile
-                ? (_b = (_a = ts).getModeForResolutionAtIndex) === null || _b === void 0 ? void 0 : _b.call(_a, containingSourceFile, i)
-                : undefined;
-            let { resolvedModule } = ts.resolveModuleName(moduleName, containingFile, config.options, host, moduleResolutionCache, redirectedReference, mode);
-            if (!resolvedModule && options.experimentalTsImportSpecifiers) {
-                const lastDotIndex = moduleName.lastIndexOf('.');
-                const ext = lastDotIndex >= 0 ? moduleName.slice(lastDotIndex) : '';
-                if (ext) {
-                    const replacements = extensions.tsResolverEquivalents.get(ext);
-                    for (const replacementExt of replacements !== null && replacements !== void 0 ? replacements : []) {
-                        ({ resolvedModule } = ts.resolveModuleName(moduleName.slice(0, -ext.length) + replacementExt, containingFile, config.options, host, moduleResolutionCache, redirectedReference, mode));
-                        if (resolvedModule)
-                            break;
-                    }
-                }
-            }
-            if (resolvedModule) {
-                fixupResolvedModule(resolvedModule);
-            }
-            return resolvedModule;
-        });
-    };
-    // language service never calls this, but TS docs recommend that we implement it
-    const getResolvedModuleWithFailedLookupLocationsFromCache = (moduleName, containingFile, resolutionMode) => {
-        const ret = ts.resolveModuleNameFromCache(moduleName, containingFile, moduleResolutionCache, resolutionMode);
-        if (ret && ret.resolvedModule) {
-            fixupResolvedModule(ret.resolvedModule);
-        }
-        return ret;
-    };
-    const resolveTypeReferenceDirectives = (typeDirectiveNames, containingFile, redirectedReference, options, containingFileMode // new impliedNodeFormat is accepted by compilerHost
-    ) => {
-        // Note: seems to be called with empty typeDirectiveNames array for all files.
-        // TODO consider using `ts.loadWithTypeDirectiveCache`
-        return typeDirectiveNames.map((typeDirectiveName) => {
-            // Copy-pasted from TS source:
-            const nameIsString = typeof typeDirectiveName === 'string';
-            const mode = nameIsString
-                ? undefined
-                : ts.getModeForFileReference(typeDirectiveName, containingFileMode);
-            const strName = nameIsString
-                ? typeDirectiveName
-                : typeDirectiveName.fileName.toLowerCase();
-            let { resolvedTypeReferenceDirective } = ts.resolveTypeReferenceDirective(strName, containingFile, config.options, host, redirectedReference, undefined, mode);
-            if (typeDirectiveName === 'node' && !resolvedTypeReferenceDirective) {
-                // Resolve @types/node relative to project first, then __dirname (copy logic from elsewhere / refactor into reusable function)
-                let typesNodePackageJsonPath;
-                try {
-                    typesNodePackageJsonPath = projectLocalResolveHelper('@types/node/package.json', true);
-                }
-                catch { } // gracefully do nothing when @types/node is not installed for any reason
-                if (typesNodePackageJsonPath) {
-                    const typeRoots = [(0, path_1.resolve)(typesNodePackageJsonPath, '../..')];
-                    ({ resolvedTypeReferenceDirective } =
-                        ts.resolveTypeReferenceDirective(typeDirectiveName, containingFile, {
-                            ...config.options,
-                            typeRoots,
-                        }, host, redirectedReference));
-                }
-            }
-            if (resolvedTypeReferenceDirective) {
-                fixupResolvedModule(resolvedTypeReferenceDirective);
-            }
-            return resolvedTypeReferenceDirective;
-        });
-    };
-    return {
-        resolveModuleNames,
-        getResolvedModuleWithFailedLookupLocationsFromCache,
-        resolveTypeReferenceDirectives,
-        isFileKnownToBeInternal,
-        markBucketOfFilenameInternal,
-    };
-}
-exports.createResolverFunctions = createResolverFunctions;
-//# sourceMappingURL=resolver-functions.js.map
-
-/***/ }),
-
-/***/ 37432:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
-
-"use strict";
-
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.getPatternFromSpec = exports.createTsInternals = void 0;
-const path_1 = __nccwpck_require__(71017);
-const util_1 = __nccwpck_require__(81842);
-/** @internal */
-exports.createTsInternals = (0, util_1.cachedLookup)(createTsInternalsUncached);
-/**
- * Given a reference to the TS compiler, return some TS internal functions that we
- * could not or did not want to grab off the `ts` object.
- * These have been copy-pasted from TS's source and tweaked as necessary.
- *
- * NOTE: This factory returns *only* functions which need a reference to the TS
- * compiler.  Other functions do not need a reference to the TS compiler so are
- * exported directly from this file.
- */
-function createTsInternalsUncached(_ts) {
-    const ts = _ts;
-    /**
-     * Copied from:
-     * https://github.com/microsoft/TypeScript/blob/v4.3.2/src/compiler/commandLineParser.ts#L2821-L2846
-     */
-    function getExtendsConfigPath(extendedConfig, host, basePath, errors, createDiagnostic) {
-        extendedConfig = (0, util_1.normalizeSlashes)(extendedConfig);
-        if (isRootedDiskPath(extendedConfig) ||
-            startsWith(extendedConfig, './') ||
-            startsWith(extendedConfig, '../')) {
-            let extendedConfigPath = getNormalizedAbsolutePath(extendedConfig, basePath);
-            if (!host.fileExists(extendedConfigPath) &&
-                !endsWith(extendedConfigPath, ts.Extension.Json)) {
-                extendedConfigPath = `${extendedConfigPath}.json`;
-                if (!host.fileExists(extendedConfigPath)) {
-                    errors.push(createDiagnostic(ts.Diagnostics.File_0_not_found, extendedConfig));
-                    return undefined;
-                }
-            }
-            return extendedConfigPath;
-        }
-        // If the path isn't a rooted or relative path, resolve like a module
-        const resolved = ts.nodeModuleNameResolver(extendedConfig, combinePaths(basePath, 'tsconfig.json'), { moduleResolution: ts.ModuleResolutionKind.NodeJs }, host, 
-        /*cache*/ undefined, 
-        /*projectRefs*/ undefined, 
-        /*lookupConfig*/ true);
-        if (resolved.resolvedModule) {
-            return resolved.resolvedModule.resolvedFileName;
-        }
-        errors.push(createDiagnostic(ts.Diagnostics.File_0_not_found, extendedConfig));
-        return undefined;
-    }
-    return { getExtendsConfigPath };
-}
-// These functions have alternative implementation to avoid copying too much from TS
-function isRootedDiskPath(path) {
-    return (0, path_1.isAbsolute)(path);
-}
-function combinePaths(path, ...paths) {
-    return (0, util_1.normalizeSlashes)((0, path_1.resolve)(path, ...paths.filter((path) => path)));
-}
-function getNormalizedAbsolutePath(fileName, currentDirectory) {
-    return (0, util_1.normalizeSlashes)(currentDirectory != null
-        ? (0, path_1.resolve)(currentDirectory, fileName)
-        : (0, path_1.resolve)(fileName));
-}
-function startsWith(str, prefix) {
-    return str.lastIndexOf(prefix, 0) === 0;
-}
-function endsWith(str, suffix) {
-    const expectedPos = str.length - suffix.length;
-    return expectedPos >= 0 && str.indexOf(suffix, expectedPos) === expectedPos;
-}
-// Reserved characters, forces escaping of any non-word (or digit), non-whitespace character.
-// It may be inefficient (we could just match (/[-[\]{}()*+?.,\\^$|#\s]/g), but this is future
-// proof.
-const reservedCharacterPattern = /[^\w\s\/]/g;
-/**
- * @internal
- * See also: getRegularExpressionForWildcard, which seems to do almost the same thing
- */
-function getPatternFromSpec(spec, basePath) {
-    const pattern = spec && getSubPatternFromSpec(spec, basePath, excludeMatcher);
-    return pattern && `^(${pattern})${'($|/)'}`;
-}
-exports.getPatternFromSpec = getPatternFromSpec;
-function getSubPatternFromSpec(spec, basePath, { singleAsteriskRegexFragment, doubleAsteriskRegexFragment, replaceWildcardCharacter, }) {
-    let subpattern = '';
-    let hasWrittenComponent = false;
-    const components = getNormalizedPathComponents(spec, basePath);
-    const lastComponent = last(components);
-    // getNormalizedPathComponents includes the separator for the root component.
-    // We need to remove to create our regex correctly.
-    components[0] = removeTrailingDirectorySeparator(components[0]);
-    if (isImplicitGlob(lastComponent)) {
-        components.push('**', '*');
-    }
-    let optionalCount = 0;
-    for (let component of components) {
-        if (component === '**') {
-            subpattern += doubleAsteriskRegexFragment;
-        }
-        else {
-            if (hasWrittenComponent) {
-                subpattern += directorySeparator;
-            }
-            subpattern += component.replace(reservedCharacterPattern, replaceWildcardCharacter);
-        }
-        hasWrittenComponent = true;
-    }
-    while (optionalCount > 0) {
-        subpattern += ')?';
-        optionalCount--;
-    }
-    return subpattern;
-}
-const directoriesMatcher = {
-    singleAsteriskRegexFragment: '[^/]*',
-    /**
-     * Regex for the ** wildcard. Matches any num of subdirectories. When used for including
-     * files or directories, does not match subdirectories that start with a . character
-     */
-    doubleAsteriskRegexFragment: `(/[^/.][^/]*)*?`,
-    replaceWildcardCharacter: (match) => replaceWildcardCharacter(match, directoriesMatcher.singleAsteriskRegexFragment),
-};
-const excludeMatcher = {
-    singleAsteriskRegexFragment: '[^/]*',
-    doubleAsteriskRegexFragment: '(/.+?)?',
-    replaceWildcardCharacter: (match) => replaceWildcardCharacter(match, excludeMatcher.singleAsteriskRegexFragment),
-};
-function getNormalizedPathComponents(path, currentDirectory) {
-    return reducePathComponents(getPathComponents(path, currentDirectory));
-}
-function getPathComponents(path, currentDirectory = '') {
-    path = combinePaths(currentDirectory, path);
-    return pathComponents(path, getRootLength(path));
-}
-function reducePathComponents(components) {
-    if (!some(components))
-        return [];
-    const reduced = [components[0]];
-    for (let i = 1; i < components.length; i++) {
-        const component = components[i];
-        if (!component)
-            continue;
-        if (component === '.')
-            continue;
-        if (component === '..') {
-            if (reduced.length > 1) {
-                if (reduced[reduced.length - 1] !== '..') {
-                    reduced.pop();
-                    continue;
-                }
-            }
-            else if (reduced[0])
-                continue;
-        }
-        reduced.push(component);
-    }
-    return reduced;
-}
-function getRootLength(path) {
-    const rootLength = getEncodedRootLength(path);
-    return rootLength < 0 ? ~rootLength : rootLength;
-}
-function getEncodedRootLength(path) {
-    if (!path)
-        return 0;
-    const ch0 = path.charCodeAt(0);
-    // POSIX or UNC
-    if (ch0 === 47 /* CharacterCodes.slash */ || ch0 === 92 /* CharacterCodes.backslash */) {
-        if (path.charCodeAt(1) !== ch0)
-            return 1; // POSIX: "/" (or non-normalized "\")
-        const p1 = path.indexOf(ch0 === 47 /* CharacterCodes.slash */ ? directorySeparator : altDirectorySeparator, 2);
-        if (p1 < 0)
-            return path.length; // UNC: "//server" or "\\server"
-        return p1 + 1; // UNC: "//server/" or "\\server\"
-    }
-    // DOS
-    if (isVolumeCharacter(ch0) && path.charCodeAt(1) === 58 /* CharacterCodes.colon */) {
-        const ch2 = path.charCodeAt(2);
-        if (ch2 === 47 /* CharacterCodes.slash */ || ch2 === 92 /* CharacterCodes.backslash */)
-            return 3; // DOS: "c:/" or "c:\"
-        if (path.length === 2)
-            return 2; // DOS: "c:" (but not "c:d")
-    }
-    // URL
-    const schemeEnd = path.indexOf(urlSchemeSeparator);
-    if (schemeEnd !== -1) {
-        const authorityStart = schemeEnd + urlSchemeSeparator.length;
-        const authorityEnd = path.indexOf(directorySeparator, authorityStart);
-        if (authorityEnd !== -1) {
-            // URL: "file:///", "file://server/", "file://server/path"
-            // For local "file" URLs, include the leading DOS volume (if present).
-            // Per https://www.ietf.org/rfc/rfc1738.txt, a host of "" or "localhost" is a
-            // special case interpreted as "the machine from which the URL is being interpreted".
-            const scheme = path.slice(0, schemeEnd);
-            const authority = path.slice(authorityStart, authorityEnd);
-            if (scheme === 'file' &&
-                (authority === '' || authority === 'localhost') &&
-                isVolumeCharacter(path.charCodeAt(authorityEnd + 1))) {
-                const volumeSeparatorEnd = getFileUrlVolumeSeparatorEnd(path, authorityEnd + 2);
-                if (volumeSeparatorEnd !== -1) {
-                    if (path.charCodeAt(volumeSeparatorEnd) === 47 /* CharacterCodes.slash */) {
-                        // URL: "file:///c:/", "file://localhost/c:/", "file:///c%3a/", "file://localhost/c%3a/"
-                        return ~(volumeSeparatorEnd + 1);
-                    }
-                    if (volumeSeparatorEnd === path.length) {
-                        // URL: "file:///c:", "file://localhost/c:", "file:///c$3a", "file://localhost/c%3a"
-                        // but not "file:///c:d" or "file:///c%3ad"
-                        return ~volumeSeparatorEnd;
-                    }
-                }
-            }
-            return ~(authorityEnd + 1); // URL: "file://server/", "http://server/"
-        }
-        return ~path.length; // URL: "file://server", "http://server"
-    }
-    // relative
-    return 0;
-}
-function ensureTrailingDirectorySeparator(path) {
-    if (!hasTrailingDirectorySeparator(path)) {
-        return path + directorySeparator;
-    }
-    return path;
-}
-function hasTrailingDirectorySeparator(path) {
-    return (path.length > 0 && isAnyDirectorySeparator(path.charCodeAt(path.length - 1)));
-}
-function isAnyDirectorySeparator(charCode) {
-    return (charCode === 47 /* CharacterCodes.slash */ || charCode === 92 /* CharacterCodes.backslash */);
-}
-function removeTrailingDirectorySeparator(path) {
-    if (hasTrailingDirectorySeparator(path)) {
-        return path.substr(0, path.length - 1);
-    }
-    return path;
-}
-const directorySeparator = '/';
-const altDirectorySeparator = '\\';
-const urlSchemeSeparator = '://';
-function isVolumeCharacter(charCode) {
-    return ((charCode >= 97 /* CharacterCodes.a */ && charCode <= 122 /* CharacterCodes.z */) ||
-        (charCode >= 65 /* CharacterCodes.A */ && charCode <= 90 /* CharacterCodes.Z */));
-}
-function getFileUrlVolumeSeparatorEnd(url, start) {
-    const ch0 = url.charCodeAt(start);
-    if (ch0 === 58 /* CharacterCodes.colon */)
-        return start + 1;
-    if (ch0 === 37 /* CharacterCodes.percent */ &&
-        url.charCodeAt(start + 1) === 51 /* CharacterCodes._3 */) {
-        const ch2 = url.charCodeAt(start + 2);
-        if (ch2 === 97 /* CharacterCodes.a */ || ch2 === 65 /* CharacterCodes.A */)
-            return start + 3;
-    }
-    return -1;
-}
-function some(array, predicate) {
-    if (array) {
-        if (predicate) {
-            for (const v of array) {
-                if (predicate(v)) {
-                    return true;
-                }
-            }
-        }
-        else {
-            return array.length > 0;
-        }
-    }
-    return false;
-}
-function pathComponents(path, rootLength) {
-    const root = path.substring(0, rootLength);
-    const rest = path.substring(rootLength).split(directorySeparator);
-    if (rest.length && !lastOrUndefined(rest))
-        rest.pop();
-    return [root, ...rest];
-}
-function lastOrUndefined(array) {
-    return array.length === 0 ? undefined : array[array.length - 1];
-}
-function last(array) {
-    // Debug.assert(array.length !== 0);
-    return array[array.length - 1];
-}
-function replaceWildcardCharacter(match, singleAsteriskRegexFragment) {
-    return match === '*'
-        ? singleAsteriskRegexFragment
-        : match === '?'
-            ? '[^/]'
-            : '\\' + match;
-}
-/**
- * An "includes" path "foo" is implicitly a glob "foo/** /*" (without the space) if its last component has no extension,
- * and does not contain any glob characters itself.
- */
-function isImplicitGlob(lastPathComponent) {
-    return !/[.*?]/.test(lastPathComponent);
-}
-//# sourceMappingURL=ts-internals.js.map
-
-/***/ }),
-
-/***/ 72598:
-/***/ ((__unused_webpack_module, exports) => {
-
-"use strict";
-
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.createTsTranspileModule = void 0;
-/** @internal */
-function createTsTranspileModule(ts, transpileOptions) {
-    const { createProgram, createSourceFile, getDefaultCompilerOptions, getImpliedNodeFormatForFile, fixupCompilerOptions, transpileOptionValueCompilerOptions, getNewLineCharacter, fileExtensionIs, normalizePath, Debug, toPath, getSetExternalModuleIndicator, getEntries, addRange, hasProperty, getEmitScriptTarget, getDirectoryPath, } = ts;
-    const compilerOptionsDiagnostics = [];
-    const options = transpileOptions.compilerOptions
-        ? fixupCompilerOptions(transpileOptions.compilerOptions, compilerOptionsDiagnostics)
-        : {};
-    // mix in default options
-    const defaultOptions = getDefaultCompilerOptions();
-    for (const key in defaultOptions) {
-        if (hasProperty(defaultOptions, key) && options[key] === undefined) {
-            options[key] = defaultOptions[key];
-        }
-    }
-    for (const option of transpileOptionValueCompilerOptions) {
-        options[option.name] = option.transpileOptionValue;
-    }
-    // transpileModule does not write anything to disk so there is no need to verify that there are no conflicts between input and output paths.
-    options.suppressOutputPathCheck = true;
-    // Filename can be non-ts file.
-    options.allowNonTsExtensions = true;
-    const newLine = getNewLineCharacter(options);
-    // Create a compilerHost object to allow the compiler to read and write files
-    const compilerHost = {
-        getSourceFile: (fileName) => fileName === normalizePath(inputFileName) ? sourceFile : undefined,
-        writeFile: (name, text) => {
-            if (fileExtensionIs(name, '.map')) {
-                Debug.assertEqual(sourceMapText, undefined, 'Unexpected multiple source map outputs, file:', name);
-                sourceMapText = text;
-            }
-            else {
-                Debug.assertEqual(outputText, undefined, 'Unexpected multiple outputs, file:', name);
-                outputText = text;
-            }
-        },
-        getDefaultLibFileName: () => 'lib.d.ts',
-        useCaseSensitiveFileNames: () => true,
-        getCanonicalFileName: (fileName) => fileName,
-        getCurrentDirectory: () => '',
-        getNewLine: () => newLine,
-        fileExists: (fileName) => fileName === inputFileName || fileName === packageJsonFileName,
-        readFile: (fileName) => fileName === packageJsonFileName ? `{"type": "${_packageJsonType}"}` : '',
-        directoryExists: () => true,
-        getDirectories: () => [],
-    };
-    let inputFileName;
-    let packageJsonFileName;
-    let _packageJsonType;
-    let sourceFile;
-    let outputText;
-    let sourceMapText;
-    return transpileModule;
-    function transpileModule(input, transpileOptions2, packageJsonType = 'commonjs') {
-        // if jsx is specified then treat file as .tsx
-        inputFileName =
-            transpileOptions2.fileName ||
-                (transpileOptions.compilerOptions && transpileOptions.compilerOptions.jsx
-                    ? 'module.tsx'
-                    : 'module.ts');
-        packageJsonFileName = getDirectoryPath(inputFileName) + '/package.json';
-        _packageJsonType = packageJsonType;
-        sourceFile = createSourceFile(inputFileName, input, {
-            languageVersion: getEmitScriptTarget(options),
-            impliedNodeFormat: getImpliedNodeFormatForFile(toPath(inputFileName, '', compilerHost.getCanonicalFileName), 
-            /*cache*/ undefined, compilerHost, options),
-            setExternalModuleIndicator: getSetExternalModuleIndicator(options),
-        });
-        if (transpileOptions2.moduleName) {
-            sourceFile.moduleName = transpileOptions2.moduleName;
-        }
-        if (transpileOptions2.renamedDependencies) {
-            sourceFile.renamedDependencies = new Map(getEntries(transpileOptions2.renamedDependencies));
-        }
-        // Output
-        outputText = undefined;
-        sourceMapText = undefined;
-        const program = createProgram([inputFileName], options, compilerHost);
-        const diagnostics = compilerOptionsDiagnostics.slice();
-        if (transpileOptions.reportDiagnostics) {
-            addRange(
-            /*to*/ diagnostics, 
-            /*from*/ program.getSyntacticDiagnostics(sourceFile));
-            addRange(/*to*/ diagnostics, /*from*/ program.getOptionsDiagnostics());
-        }
-        // Emit
-        program.emit(
-        /*targetSourceFile*/ undefined, 
-        /*writeFile*/ undefined, 
-        /*cancellationToken*/ undefined, 
-        /*emitOnlyDtsFiles*/ undefined, transpileOptions.transformers);
-        if (outputText === undefined)
-            return Debug.fail('Output generation failed');
-        return { outputText, diagnostics, sourceMapText };
-    }
-}
-exports.createTsTranspileModule = createTsTranspileModule;
-//# sourceMappingURL=ts-transpile-module.js.map
-
-/***/ }),
-
-/***/ 7518:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
-
-"use strict";
-
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.getDefaultTsconfigJsonForNodeVersion = void 0;
-const nodeMajor = parseInt(process.versions.node.split('.')[0], 10);
-/**
- * return parsed JSON of the bundled @tsconfig/bases config appropriate for the
- * running version of nodejs
- * @internal
- */
-function getDefaultTsconfigJsonForNodeVersion(ts) {
-    const tsInternal = ts;
-    if (nodeMajor >= 16) {
-        const config = __nccwpck_require__(39777);
-        if (configCompatible(config))
-            return config;
-    }
-    if (nodeMajor >= 14) {
-        const config = __nccwpck_require__(83754);
-        if (configCompatible(config))
-            return config;
-    }
-    if (nodeMajor >= 12) {
-        const config = __nccwpck_require__(56049);
-        if (configCompatible(config))
-            return config;
-    }
-    return __nccwpck_require__(78250);
-    // Verify that tsconfig target and lib options are compatible with TypeScript compiler
-    function configCompatible(config) {
-        return (typeof ts.ScriptTarget[config.compilerOptions.target.toUpperCase()] === 'number' &&
-            tsInternal.libs &&
-            config.compilerOptions.lib.every((lib) => tsInternal.libs.includes(lib)));
-    }
-}
-exports.getDefaultTsconfigJsonForNodeVersion = getDefaultTsconfigJsonForNodeVersion;
-//# sourceMappingURL=tsconfigs.js.map
-
-/***/ }),
-
-/***/ 81842:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
-
-"use strict";
-
-var _a;
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.versionGteLt = exports.once = exports.getBasePathForProjectLocalDependencyResolution = exports.createProjectLocalResolveHelper = exports.attemptRequireWithV8CompileCache = exports.cachedLookup = exports.hasOwnProperty = exports.normalizeSlashes = exports.parse = exports.split = exports.assign = exports.yn = exports.createRequire = void 0;
-const module_1 = __nccwpck_require__(98188);
-const ynModule = __nccwpck_require__(22287);
-const path_1 = __nccwpck_require__(71017);
-/** @internal */
-exports.createRequire = (_a = module_1.createRequire !== null && module_1.createRequire !== void 0 ? module_1.createRequire : module_1.createRequireFromPath) !== null && _a !== void 0 ? _a : __nccwpck_require__(6691);
-/**
- * Wrapper around yn module that returns `undefined` instead of `null`.
- * This is implemented by yn v4, but we're staying on v3 to avoid v4's node 10 requirement.
- * @internal
- */
-function yn(value) {
-    var _a;
-    return (_a = ynModule(value)) !== null && _a !== void 0 ? _a : undefined;
-}
-exports.yn = yn;
-/**
- * Like `Object.assign`, but ignores `undefined` properties.
- *
- * @internal
- */
-function assign(initialValue, ...sources) {
-    for (const source of sources) {
-        for (const key of Object.keys(source)) {
-            const value = source[key];
-            if (value !== undefined)
-                initialValue[key] = value;
-        }
-    }
-    return initialValue;
-}
-exports.assign = assign;
-/**
- * Split a string array of values
- * and remove empty strings from the resulting array.
- * @internal
- */
-function split(value) {
-    return typeof value === 'string'
-        ? value.split(/ *, */g).filter((v) => v !== '')
-        : undefined;
-}
-exports.split = split;
-/**
- * Parse a string as JSON.
- * @internal
- */
-function parse(value) {
-    return typeof value === 'string' ? JSON.parse(value) : undefined;
-}
-exports.parse = parse;
-const directorySeparator = '/';
-const backslashRegExp = /\\/g;
-/**
- * Replace backslashes with forward slashes.
- * @internal
- */
-function normalizeSlashes(value) {
-    return value.replace(backslashRegExp, directorySeparator);
-}
-exports.normalizeSlashes = normalizeSlashes;
-/**
- * Safe `hasOwnProperty`
- * @internal
- */
-function hasOwnProperty(object, property) {
-    return Object.prototype.hasOwnProperty.call(object, property);
-}
-exports.hasOwnProperty = hasOwnProperty;
-/**
- * Cached fs operation wrapper.
- */
-function cachedLookup(fn) {
-    const cache = new Map();
-    return (arg) => {
-        if (!cache.has(arg)) {
-            const v = fn(arg);
-            cache.set(arg, v);
-            return v;
-        }
-        return cache.get(arg);
-    };
-}
-exports.cachedLookup = cachedLookup;
-/**
- * @internal
- * Require something with v8-compile-cache, which should make subsequent requires faster.
- * Do lots of error-handling so that, worst case, we require without the cache, and users are not blocked.
- */
-function attemptRequireWithV8CompileCache(requireFn, specifier) {
-    try {
-        const v8CC = (__nccwpck_require__(25476).install)();
-        try {
-            return requireFn(specifier);
-        }
-        finally {
-            v8CC === null || v8CC === void 0 ? void 0 : v8CC.uninstall();
-        }
-    }
-    catch (e) {
-        return requireFn(specifier);
-    }
-}
-exports.attemptRequireWithV8CompileCache = attemptRequireWithV8CompileCache;
-/**
- * Helper to discover dependencies relative to a user's project, optionally
- * falling back to relative to ts-node.  This supports global installations of
- * ts-node, for example where someone does `#!/usr/bin/env -S ts-node --swc` and
- * we need to fallback to a global install of @swc/core
- * @internal
- */
-function createProjectLocalResolveHelper(localDirectory) {
-    return function projectLocalResolveHelper(specifier, fallbackToTsNodeRelative) {
-        return require.resolve(specifier, {
-            paths: fallbackToTsNodeRelative
-                ? [localDirectory, __dirname]
-                : [localDirectory],
-        });
-    };
-}
-exports.createProjectLocalResolveHelper = createProjectLocalResolveHelper;
-/**
- * Used as a reminder of all the factors we must consider when finding project-local dependencies and when a config file
- * on disk may or may not exist.
- * @internal
- */
-function getBasePathForProjectLocalDependencyResolution(configFilePath, projectSearchDirOption, projectOption, cwdOption) {
-    var _a;
-    if (configFilePath != null)
-        return (0, path_1.dirname)(configFilePath);
-    return (_a = projectSearchDirOption !== null && projectSearchDirOption !== void 0 ? projectSearchDirOption : projectOption) !== null && _a !== void 0 ? _a : cwdOption;
-    // TODO technically breaks if projectOption is path to a file, not a directory,
-    // and we attempt to resolve relative specifiers.  By the time we resolve relative specifiers,
-    // should have configFilePath, so not reach this codepath.
-}
-exports.getBasePathForProjectLocalDependencyResolution = getBasePathForProjectLocalDependencyResolution;
-/** @internal */
-function once(fn) {
-    let value;
-    let ran = false;
-    function onceFn(...args) {
-        if (ran)
-            return value;
-        value = fn(...args);
-        ran = true;
-        return value;
-    }
-    return onceFn;
-}
-exports.once = once;
-/** @internal */
-function versionGteLt(version, gteRequirement, ltRequirement) {
-    const [major, minor, patch, extra] = parse(version);
-    const [gteMajor, gteMinor, gtePatch] = parse(gteRequirement);
-    const isGte = major > gteMajor ||
-        (major === gteMajor &&
-            (minor > gteMinor || (minor === gteMinor && patch >= gtePatch)));
-    let isLt = true;
-    if (ltRequirement) {
-        const [ltMajor, ltMinor, ltPatch] = parse(ltRequirement);
-        isLt =
-            major < ltMajor ||
-                (major === ltMajor &&
-                    (minor < ltMinor || (minor === ltMinor && patch < ltPatch)));
-    }
-    return isGte && isLt;
-    function parse(requirement) {
-        return requirement.split(/[\.-]/).map((s) => parseInt(s, 10));
-    }
-}
-exports.versionGteLt = versionGteLt;
-//# sourceMappingURL=util.js.map
-
-/***/ }),
-
-/***/ 58145:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
-
-"use strict";
-
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.configLoader = exports.loadConfig = void 0;
-var TsConfigLoader2 = __nccwpck_require__(36968);
-var path = __nccwpck_require__(71017);
-function loadConfig(cwd) {
-    if (cwd === void 0) { cwd = process.cwd(); }
-    return configLoader({ cwd: cwd });
-}
-exports.loadConfig = loadConfig;
-function configLoader(_a) {
-    var cwd = _a.cwd, explicitParams = _a.explicitParams, _b = _a.tsConfigLoader, tsConfigLoader = _b === void 0 ? TsConfigLoader2.tsConfigLoader : _b;
-    if (explicitParams) {
-        var absoluteBaseUrl = path.isAbsolute(explicitParams.baseUrl)
-            ? explicitParams.baseUrl
-            : path.join(cwd, explicitParams.baseUrl);
-        return {
-            resultType: "success",
-            configFileAbsolutePath: "",
-            baseUrl: explicitParams.baseUrl,
-            absoluteBaseUrl: absoluteBaseUrl,
-            paths: explicitParams.paths,
-            mainFields: explicitParams.mainFields,
-            addMatchAll: explicitParams.addMatchAll,
-        };
-    }
-    // Load tsconfig and create path matching function
-    var loadResult = tsConfigLoader({
-        cwd: cwd,
-        getEnv: function (key) { return process.env[key]; },
-    });
-    if (!loadResult.tsConfigPath) {
-        return {
-            resultType: "failed",
-            message: "Couldn't find tsconfig.json",
-        };
-    }
-    return {
-        resultType: "success",
-        configFileAbsolutePath: loadResult.tsConfigPath,
-        baseUrl: loadResult.baseUrl,
-        absoluteBaseUrl: path.resolve(path.dirname(loadResult.tsConfigPath), loadResult.baseUrl || ""),
-        paths: loadResult.paths || {},
-        addMatchAll: loadResult.baseUrl !== undefined,
-    };
-}
-exports.configLoader = configLoader;
-//# sourceMappingURL=config-loader.js.map
-
-/***/ }),
-
-/***/ 30478:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
-
-"use strict";
-
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.removeExtension = exports.fileExistsAsync = exports.readJsonFromDiskAsync = exports.readJsonFromDiskSync = exports.fileExistsSync = void 0;
-var fs = __nccwpck_require__(57147);
-function fileExistsSync(path) {
-    // If the file doesn't exist, avoid throwing an exception over the native barrier for every miss
-    if (!fs.existsSync(path)) {
-        return false;
-    }
-    try {
-        var stats = fs.statSync(path);
-        return stats.isFile();
-    }
-    catch (err) {
-        // If error, assume file did not exist
-        return false;
-    }
-}
-exports.fileExistsSync = fileExistsSync;
-/**
- * Reads package.json from disk
- *
- * @param file Path to package.json
- */
-// eslint-disable-next-line @typescript-eslint/no-explicit-any
-function readJsonFromDiskSync(packageJsonPath) {
-    if (!fs.existsSync(packageJsonPath)) {
-        return undefined;
-    }
-    // eslint-disable-next-line @typescript-eslint/no-require-imports
-    return require(packageJsonPath);
-}
-exports.readJsonFromDiskSync = readJsonFromDiskSync;
-function readJsonFromDiskAsync(path, 
-// eslint-disable-next-line @typescript-eslint/no-explicit-any
-callback) {
-    fs.readFile(path, "utf8", function (err, result) {
-        // If error, assume file did not exist
-        if (err || !result) {
-            return callback();
-        }
-        var json = JSON.parse(result);
-        return callback(undefined, json);
-    });
-}
-exports.readJsonFromDiskAsync = readJsonFromDiskAsync;
-function fileExistsAsync(path2, callback2) {
-    fs.stat(path2, function (err, stats) {
-        if (err) {
-            // If error assume file does not exist
-            return callback2(undefined, false);
-        }
-        callback2(undefined, stats ? stats.isFile() : false);
-    });
-}
-exports.fileExistsAsync = fileExistsAsync;
-function removeExtension(path) {
-    return path.substring(0, path.lastIndexOf(".")) || path;
-}
-exports.removeExtension = removeExtension;
-//# sourceMappingURL=filesystem.js.map
-
-/***/ }),
-
-/***/ 10839:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
-
-"use strict";
-
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.loadConfig = exports.register = exports.matchFromAbsolutePathsAsync = exports.createMatchPathAsync = exports.matchFromAbsolutePaths = exports.createMatchPath = void 0;
-// register is used from register.js in root dir
-var match_path_sync_1 = __nccwpck_require__(79232);
-Object.defineProperty(exports, "createMatchPath", ({ enumerable: true, get: function () { return match_path_sync_1.createMatchPath; } }));
-Object.defineProperty(exports, "matchFromAbsolutePaths", ({ enumerable: true, get: function () { return match_path_sync_1.matchFromAbsolutePaths; } }));
-var match_path_async_1 = __nccwpck_require__(89114);
-Object.defineProperty(exports, "createMatchPathAsync", ({ enumerable: true, get: function () { return match_path_async_1.createMatchPathAsync; } }));
-Object.defineProperty(exports, "matchFromAbsolutePathsAsync", ({ enumerable: true, get: function () { return match_path_async_1.matchFromAbsolutePathsAsync; } }));
-var register_1 = __nccwpck_require__(71994);
-Object.defineProperty(exports, "register", ({ enumerable: true, get: function () { return register_1.register; } }));
-var config_loader_1 = __nccwpck_require__(58145);
-Object.defineProperty(exports, "loadConfig", ({ enumerable: true, get: function () { return config_loader_1.loadConfig; } }));
-//# sourceMappingURL=index.js.map
-
-/***/ }),
-
-/***/ 1243:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
-
-"use strict";
-
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.getAbsoluteMappingEntries = void 0;
-var path = __nccwpck_require__(71017);
-/**
- * Converts an absolute baseUrl and paths to an array of absolute mapping entries.
- * The array is sorted by longest prefix.
- * Having an array with entries allows us to keep a sorting order rather than
- * sort by keys each time we use the mappings.
- *
- * @param absoluteBaseUrl
- * @param paths
- * @param addMatchAll
- */
-function getAbsoluteMappingEntries(absoluteBaseUrl, paths, addMatchAll) {
-    // Resolve all paths to absolute form once here, and sort them by
-    // longest prefix once here, this saves time on each request later.
-    // We need to put them in an array to preserve the sorting order.
-    var sortedKeys = sortByLongestPrefix(Object.keys(paths));
-    var absolutePaths = [];
-    for (var _i = 0, sortedKeys_1 = sortedKeys; _i < sortedKeys_1.length; _i++) {
-        var key = sortedKeys_1[_i];
-        absolutePaths.push({
-            pattern: key,
-            paths: paths[key].map(function (pathToResolve) {
-                return path.resolve(absoluteBaseUrl, pathToResolve);
-            }),
-        });
-    }
-    // If there is no match-all path specified in the paths section of tsconfig, then try to match
-    // all paths relative to baseUrl, this is how typescript works.
-    if (!paths["*"] && addMatchAll) {
-        absolutePaths.push({
-            pattern: "*",
-            paths: ["".concat(absoluteBaseUrl.replace(/\/$/, ""), "/*")],
-        });
-    }
-    return absolutePaths;
-}
-exports.getAbsoluteMappingEntries = getAbsoluteMappingEntries;
-/**
- * Sort path patterns.
- * If a module name can be matched with multiple patterns then pattern with the longest prefix will be picked.
- */
-function sortByLongestPrefix(arr) {
-    return arr
-        .concat()
-        .sort(function (a, b) { return getPrefixLength(b) - getPrefixLength(a); });
-}
-function getPrefixLength(pattern) {
-    var prefixLength = pattern.indexOf("*");
-    return pattern.substr(0, prefixLength).length;
-}
-//# sourceMappingURL=mapping-entry.js.map
-
-/***/ }),
-
-/***/ 89114:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
-
-"use strict";
-
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.matchFromAbsolutePathsAsync = exports.createMatchPathAsync = void 0;
-var path = __nccwpck_require__(71017);
-var TryPath = __nccwpck_require__(29964);
-var MappingEntry = __nccwpck_require__(1243);
-var Filesystem = __nccwpck_require__(30478);
-/**
- * See the sync version for docs.
- */
-function createMatchPathAsync(absoluteBaseUrl, paths, mainFields, addMatchAll) {
-    if (mainFields === void 0) { mainFields = ["main"]; }
-    if (addMatchAll === void 0) { addMatchAll = true; }
-    var absolutePaths = MappingEntry.getAbsoluteMappingEntries(absoluteBaseUrl, paths, addMatchAll);
-    return function (requestedModule, readJson, fileExists, extensions, callback) {
-        return matchFromAbsolutePathsAsync(absolutePaths, requestedModule, readJson, fileExists, extensions, callback, mainFields);
-    };
-}
-exports.createMatchPathAsync = createMatchPathAsync;
-/**
- * See the sync version for docs.
- */
-function matchFromAbsolutePathsAsync(absolutePathMappings, requestedModule, readJson, fileExists, extensions, callback, mainFields) {
-    if (readJson === void 0) { readJson = Filesystem.readJsonFromDiskAsync; }
-    if (fileExists === void 0) { fileExists = Filesystem.fileExistsAsync; }
-    if (extensions === void 0) { extensions = Object.keys(require.extensions); }
-    if (mainFields === void 0) { mainFields = ["main"]; }
-    var tryPaths = TryPath.getPathsToTry(extensions, absolutePathMappings, requestedModule);
-    if (!tryPaths) {
-        return callback();
-    }
-    findFirstExistingPath(tryPaths, readJson, fileExists, callback, 0, mainFields);
-}
-exports.matchFromAbsolutePathsAsync = matchFromAbsolutePathsAsync;
-function findFirstExistingMainFieldMappedFile(packageJson, mainFields, packageJsonPath, fileExistsAsync, doneCallback, index) {
-    if (index === void 0) { index = 0; }
-    if (index >= mainFields.length) {
-        return doneCallback(undefined, undefined);
-    }
-    var tryNext = function () {
-        return findFirstExistingMainFieldMappedFile(packageJson, mainFields, packageJsonPath, fileExistsAsync, doneCallback, index + 1);
-    };
-    var mainFieldSelector = mainFields[index];
-    var mainFieldMapping = typeof mainFieldSelector === "string"
-        ? packageJson[mainFieldSelector]
-        : mainFieldSelector.reduce(function (obj, key) { return obj[key]; }, packageJson);
-    if (typeof mainFieldMapping !== "string") {
-        // Skip mappings that are not pointers to replacement files
-        return tryNext();
-    }
-    var mappedFilePath = path.join(path.dirname(packageJsonPath), mainFieldMapping);
-    fileExistsAsync(mappedFilePath, function (err, exists) {
-        if (err) {
-            return doneCallback(err);
-        }
-        if (exists) {
-            return doneCallback(undefined, mappedFilePath);
-        }
-        return tryNext();
-    });
-}
-// Recursive loop to probe for physical files
-function findFirstExistingPath(tryPaths, readJson, fileExists, doneCallback, index, mainFields) {
-    if (index === void 0) { index = 0; }
-    if (mainFields === void 0) { mainFields = ["main"]; }
-    var tryPath = tryPaths[index];
-    if (tryPath.type === "file" ||
-        tryPath.type === "extension" ||
-        tryPath.type === "index") {
-        fileExists(tryPath.path, function (err, exists) {
-            if (err) {
-                return doneCallback(err);
-            }
-            if (exists) {
-                return doneCallback(undefined, TryPath.getStrippedPath(tryPath));
-            }
-            if (index === tryPaths.length - 1) {
-                return doneCallback();
-            }
-            // Continue with the next path
-            return findFirstExistingPath(tryPaths, readJson, fileExists, doneCallback, index + 1, mainFields);
-        });
-    }
-    else if (tryPath.type === "package") {
-        readJson(tryPath.path, function (err, packageJson) {
-            if (err) {
-                return doneCallback(err);
-            }
-            if (packageJson) {
-                return findFirstExistingMainFieldMappedFile(packageJson, mainFields, tryPath.path, fileExists, function (mainFieldErr, mainFieldMappedFile) {
-                    if (mainFieldErr) {
-                        return doneCallback(mainFieldErr);
-                    }
-                    if (mainFieldMappedFile) {
-                        return doneCallback(undefined, mainFieldMappedFile);
-                    }
-                    // No field in package json was a valid option. Continue with the next path.
-                    return findFirstExistingPath(tryPaths, readJson, fileExists, doneCallback, index + 1, mainFields);
-                });
-            }
-            // This is async code, we need to return unconditionally, otherwise the code still falls
-            // through and keeps recursing. While this might work in general, libraries that use neo-async
-            // like Webpack will actually not allow you to call the same callback twice.
-            //
-            // An example of where this caused issues:
-            // https://github.com/dividab/tsconfig-paths-webpack-plugin/issues/11
-            //
-            // Continue with the next path
-            return findFirstExistingPath(tryPaths, readJson, fileExists, doneCallback, index + 1, mainFields);
-        });
-    }
-    else {
-        TryPath.exhaustiveTypeException(tryPath.type);
-    }
-}
-//# sourceMappingURL=match-path-async.js.map
-
-/***/ }),
-
-/***/ 79232:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
-
-"use strict";
-
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.matchFromAbsolutePaths = exports.createMatchPath = void 0;
-var path = __nccwpck_require__(71017);
-var Filesystem = __nccwpck_require__(30478);
-var MappingEntry = __nccwpck_require__(1243);
-var TryPath = __nccwpck_require__(29964);
-/**
- * Creates a function that can resolve paths according to tsconfig paths property.
- *
- * @param absoluteBaseUrl Absolute version of baseUrl as specified in tsconfig.
- * @param paths The paths as specified in tsconfig.
- * @param mainFields A list of package.json field names to try when resolving module files. Select a nested field using an array of field names.
- * @param addMatchAll Add a match-all "*" rule if none is present
- * @returns a function that can resolve paths.
- */
-function createMatchPath(absoluteBaseUrl, paths, mainFields, addMatchAll) {
-    if (mainFields === void 0) { mainFields = ["main"]; }
-    if (addMatchAll === void 0) { addMatchAll = true; }
-    var absolutePaths = MappingEntry.getAbsoluteMappingEntries(absoluteBaseUrl, paths, addMatchAll);
-    return function (requestedModule, readJson, fileExists, extensions) {
-        return matchFromAbsolutePaths(absolutePaths, requestedModule, readJson, fileExists, extensions, mainFields);
-    };
-}
-exports.createMatchPath = createMatchPath;
-/**
- * Finds a path from tsconfig that matches a module load request.
- *
- * @param absolutePathMappings The paths to try as specified in tsconfig but resolved to absolute form.
- * @param requestedModule The required module name.
- * @param readJson Function that can read json from a path (useful for testing).
- * @param fileExists Function that checks for existence of a file at a path (useful for testing).
- * @param extensions File extensions to probe for (useful for testing).
- * @param mainFields A list of package.json field names to try when resolving module files. Select a nested field using an array of field names.
- * @returns the found path, or undefined if no path was found.
- */
-function matchFromAbsolutePaths(absolutePathMappings, requestedModule, readJson, fileExists, extensions, mainFields) {
-    if (readJson === void 0) { readJson = Filesystem.readJsonFromDiskSync; }
-    if (fileExists === void 0) { fileExists = Filesystem.fileExistsSync; }
-    if (extensions === void 0) { extensions = Object.keys(require.extensions); }
-    if (mainFields === void 0) { mainFields = ["main"]; }
-    var tryPaths = TryPath.getPathsToTry(extensions, absolutePathMappings, requestedModule);
-    if (!tryPaths) {
-        return undefined;
-    }
-    return findFirstExistingPath(tryPaths, readJson, fileExists, mainFields);
-}
-exports.matchFromAbsolutePaths = matchFromAbsolutePaths;
-function findFirstExistingMainFieldMappedFile(packageJson, mainFields, packageJsonPath, fileExists) {
-    for (var index = 0; index < mainFields.length; index++) {
-        var mainFieldSelector = mainFields[index];
-        var candidateMapping = typeof mainFieldSelector === "string"
-            ? packageJson[mainFieldSelector]
-            : mainFieldSelector.reduce(function (obj, key) { return obj[key]; }, packageJson);
-        if (candidateMapping && typeof candidateMapping === "string") {
-            var candidateFilePath = path.join(path.dirname(packageJsonPath), candidateMapping);
-            if (fileExists(candidateFilePath)) {
-                return candidateFilePath;
-            }
-        }
-    }
-    return undefined;
-}
-function findFirstExistingPath(tryPaths, readJson, fileExists, mainFields) {
-    if (readJson === void 0) { readJson = Filesystem.readJsonFromDiskSync; }
-    if (mainFields === void 0) { mainFields = ["main"]; }
-    for (var _i = 0, tryPaths_1 = tryPaths; _i < tryPaths_1.length; _i++) {
-        var tryPath = tryPaths_1[_i];
-        if (tryPath.type === "file" ||
-            tryPath.type === "extension" ||
-            tryPath.type === "index") {
-            if (fileExists(tryPath.path)) {
-                return TryPath.getStrippedPath(tryPath);
-            }
-        }
-        else if (tryPath.type === "package") {
-            var packageJson = readJson(tryPath.path);
-            if (packageJson) {
-                var mainFieldMappedFile = findFirstExistingMainFieldMappedFile(packageJson, mainFields, tryPath.path, fileExists);
-                if (mainFieldMappedFile) {
-                    return mainFieldMappedFile;
-                }
-            }
-        }
-        else {
-            TryPath.exhaustiveTypeException(tryPath.type);
-        }
-    }
-    return undefined;
-}
-//# sourceMappingURL=match-path-sync.js.map
-
-/***/ }),
-
-/***/ 71994:
-/***/ (function(__unused_webpack_module, exports, __nccwpck_require__) {
-
-"use strict";
-
-var __spreadArray = (this && this.__spreadArray) || function (to, from, pack) {
-    if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {
-        if (ar || !(i in from)) {
-            if (!ar) ar = Array.prototype.slice.call(from, 0, i);
-            ar[i] = from[i];
-        }
-    }
-    return to.concat(ar || Array.prototype.slice.call(from));
-};
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.register = void 0;
-var match_path_sync_1 = __nccwpck_require__(79232);
-var config_loader_1 = __nccwpck_require__(58145);
-var noOp = function () { return void 0; };
-function getCoreModules(builtinModules) {
-    builtinModules = builtinModules || [
-        "assert",
-        "buffer",
-        "child_process",
-        "cluster",
-        "crypto",
-        "dgram",
-        "dns",
-        "domain",
-        "events",
-        "fs",
-        "http",
-        "https",
-        "net",
-        "os",
-        "path",
-        "punycode",
-        "querystring",
-        "readline",
-        "stream",
-        "string_decoder",
-        "tls",
-        "tty",
-        "url",
-        "util",
-        "v8",
-        "vm",
-        "zlib",
-    ];
-    var coreModules = {};
-    for (var _i = 0, builtinModules_1 = builtinModules; _i < builtinModules_1.length; _i++) {
-        var module_1 = builtinModules_1[_i];
-        coreModules[module_1] = true;
-    }
-    return coreModules;
-}
-/**
- * Installs a custom module load function that can adhere to paths in tsconfig.
- * Returns a function to undo paths registration.
- */
-function register(params) {
-    var cwd;
-    var explicitParams;
-    if (params) {
-        cwd = params.cwd;
-        if (params.baseUrl || params.paths) {
-            explicitParams = params;
-        }
-    }
-    else {
-        // eslint-disable-next-line
-        var minimist = __nccwpck_require__(11474);
-        var argv = minimist(process.argv.slice(2), {
-            // eslint-disable-next-line id-denylist
-            string: ["project"],
-            alias: {
-                project: ["P"],
-            },
-        });
-        cwd = argv.project;
-    }
-    var configLoaderResult = (0, config_loader_1.configLoader)({
-        cwd: cwd !== null && cwd !== void 0 ? cwd : process.cwd(),
-        explicitParams: explicitParams,
-    });
-    if (configLoaderResult.resultType === "failed") {
-        console.warn("".concat(configLoaderResult.message, ". tsconfig-paths will be skipped"));
-        return noOp;
-    }
-    var matchPath = (0, match_path_sync_1.createMatchPath)(configLoaderResult.absoluteBaseUrl, configLoaderResult.paths, configLoaderResult.mainFields, configLoaderResult.addMatchAll);
-    // Patch node's module loading
-    // eslint-disable-next-line @typescript-eslint/no-require-imports,@typescript-eslint/no-var-requires
-    var Module = __nccwpck_require__(98188);
-    // eslint-disable-next-line no-underscore-dangle
-    var originalResolveFilename = Module._resolveFilename;
-    var coreModules = getCoreModules(Module.builtinModules);
-    // eslint-disable-next-line @typescript-eslint/no-explicit-any,no-underscore-dangle
-    Module._resolveFilename = function (request, _parent) {
-        var isCoreModule = coreModules.hasOwnProperty(request);
-        if (!isCoreModule) {
-            var found = matchPath(request);
-            if (found) {
-                var modifiedArguments = __spreadArray([found], [].slice.call(arguments, 1), true); // Passes all arguments. Even those that is not specified above.
-                return originalResolveFilename.apply(this, modifiedArguments);
-            }
-        }
-        return originalResolveFilename.apply(this, arguments);
-    };
-    return function () {
-        // Return node's module loading to original state.
-        // eslint-disable-next-line no-underscore-dangle
-        Module._resolveFilename = originalResolveFilename;
-    };
-}
-exports.register = register;
-//# sourceMappingURL=register.js.map
-
-/***/ }),
-
-/***/ 29964:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
-
-"use strict";
-
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.exhaustiveTypeException = exports.getStrippedPath = exports.getPathsToTry = void 0;
-var path = __nccwpck_require__(71017);
-var path_1 = __nccwpck_require__(71017);
-var filesystem_1 = __nccwpck_require__(30478);
-/**
- * Builds a list of all physical paths to try by:
- * 1. Check for file named exactly as request.
- * 2. Check for files named as request ending in any of the extensions.
- * 3. Check for file specified in package.json's main property.
- * 4. Check for files named as request ending in "index" with any of the extensions.
- */
-function getPathsToTry(extensions, absolutePathMappings, requestedModule) {
-    if (!absolutePathMappings || !requestedModule || requestedModule[0] === ".") {
-        return undefined;
-    }
-    var pathsToTry = [];
-    for (var _i = 0, absolutePathMappings_1 = absolutePathMappings; _i < absolutePathMappings_1.length; _i++) {
-        var entry = absolutePathMappings_1[_i];
-        var starMatch = entry.pattern === requestedModule
-            ? ""
-            : matchStar(entry.pattern, requestedModule);
-        if (starMatch !== undefined) {
-            var _loop_1 = function (physicalPathPattern) {
-                var physicalPath = physicalPathPattern.replace("*", starMatch);
-                pathsToTry.push({ type: "file", path: physicalPath });
-                pathsToTry.push.apply(pathsToTry, extensions.map(function (e) { return ({ type: "extension", path: physicalPath + e }); }));
-                pathsToTry.push({
-                    type: "package",
-                    path: path.join(physicalPath, "/package.json"),
-                });
-                var indexPath = path.join(physicalPath, "/index");
-                pathsToTry.push.apply(pathsToTry, extensions.map(function (e) { return ({ type: "index", path: indexPath + e }); }));
-            };
-            for (var _a = 0, _b = entry.paths; _a < _b.length; _a++) {
-                var physicalPathPattern = _b[_a];
-                _loop_1(physicalPathPattern);
-            }
-        }
-    }
-    return pathsToTry.length === 0 ? undefined : pathsToTry;
-}
-exports.getPathsToTry = getPathsToTry;
-// Not sure why we don't just return the full found path?
-function getStrippedPath(tryPath) {
-    return tryPath.type === "index"
-        ? (0, path_1.dirname)(tryPath.path)
-        : tryPath.type === "file"
-            ? tryPath.path
-            : tryPath.type === "extension"
-                ? (0, filesystem_1.removeExtension)(tryPath.path)
-                : tryPath.type === "package"
-                    ? tryPath.path
-                    : exhaustiveTypeException(tryPath.type);
-}
-exports.getStrippedPath = getStrippedPath;
-function exhaustiveTypeException(check) {
-    throw new Error("Unknown type ".concat(check));
-}
-exports.exhaustiveTypeException = exhaustiveTypeException;
-/**
- * Matches pattern with a single star against search.
- * Star must match at least one character to be considered a match.
- *
- * @param patttern for example "foo*"
- * @param search for example "fooawesomebar"
- * @returns the part of search that * matches, or undefined if no match.
- */
-function matchStar(pattern, search) {
-    if (search.length < pattern.length) {
-        return undefined;
-    }
-    if (pattern === "*") {
-        return search;
-    }
-    var star = pattern.indexOf("*");
-    if (star === -1) {
-        return undefined;
-    }
-    var part1 = pattern.substring(0, star);
-    var part2 = pattern.substring(star + 1);
-    if (search.substr(0, star) !== part1) {
-        return undefined;
-    }
-    if (search.substr(search.length - part2.length) !== part2) {
-        return undefined;
-    }
-    return search.substr(star, search.length - part2.length);
-}
-//# sourceMappingURL=try-path.js.map
-
-/***/ }),
-
-/***/ 36968:
-/***/ (function(__unused_webpack_module, exports, __nccwpck_require__) {
-
-"use strict";
-
-var __assign = (this && this.__assign) || function () {
-    __assign = Object.assign || function(t) {
-        for (var s, i = 1, n = arguments.length; i < n; i++) {
-            s = arguments[i];
-            for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
-                t[p] = s[p];
-        }
-        return t;
-    };
-    return __assign.apply(this, arguments);
-};
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.loadTsconfig = exports.walkForTsConfig = exports.tsConfigLoader = void 0;
-var path = __nccwpck_require__(71017);
-var fs = __nccwpck_require__(57147);
-// eslint-disable-next-line @typescript-eslint/no-require-imports
-var JSON5 = __nccwpck_require__(89501);
-// eslint-disable-next-line @typescript-eslint/no-require-imports
-var StripBom = __nccwpck_require__(22196);
-function tsConfigLoader(_a) {
-    var getEnv = _a.getEnv, cwd = _a.cwd, _b = _a.loadSync, loadSync = _b === void 0 ? loadSyncDefault : _b;
-    var TS_NODE_PROJECT = getEnv("TS_NODE_PROJECT");
-    var TS_NODE_BASEURL = getEnv("TS_NODE_BASEURL");
-    // tsconfig.loadSync handles if TS_NODE_PROJECT is a file or directory
-    // and also overrides baseURL if TS_NODE_BASEURL is available.
-    var loadResult = loadSync(cwd, TS_NODE_PROJECT, TS_NODE_BASEURL);
-    return loadResult;
-}
-exports.tsConfigLoader = tsConfigLoader;
-function loadSyncDefault(cwd, filename, baseUrl) {
-    // Tsconfig.loadSync uses path.resolve. This is why we can use an absolute path as filename
-    var configPath = resolveConfigPath(cwd, filename);
-    if (!configPath) {
-        return {
-            tsConfigPath: undefined,
-            baseUrl: undefined,
-            paths: undefined,
-        };
-    }
-    var config = loadTsconfig(configPath);
-    return {
-        tsConfigPath: configPath,
-        baseUrl: baseUrl ||
-            (config && config.compilerOptions && config.compilerOptions.baseUrl),
-        paths: config && config.compilerOptions && config.compilerOptions.paths,
-    };
-}
-function resolveConfigPath(cwd, filename) {
-    if (filename) {
-        var absolutePath = fs.lstatSync(filename).isDirectory()
-            ? path.resolve(filename, "./tsconfig.json")
-            : path.resolve(cwd, filename);
-        return absolutePath;
-    }
-    if (fs.statSync(cwd).isFile()) {
-        return path.resolve(cwd);
-    }
-    var configAbsolutePath = walkForTsConfig(cwd);
-    return configAbsolutePath ? path.resolve(configAbsolutePath) : undefined;
-}
-function walkForTsConfig(directory, readdirSync) {
-    if (readdirSync === void 0) { readdirSync = fs.readdirSync; }
-    var files = readdirSync(directory);
-    var filesToCheck = ["tsconfig.json", "jsconfig.json"];
-    for (var _i = 0, filesToCheck_1 = filesToCheck; _i < filesToCheck_1.length; _i++) {
-        var fileToCheck = filesToCheck_1[_i];
-        if (files.indexOf(fileToCheck) !== -1) {
-            return path.join(directory, fileToCheck);
-        }
-    }
-    var parentDirectory = path.dirname(directory);
-    // If we reached the top
-    if (directory === parentDirectory) {
-        return undefined;
-    }
-    return walkForTsConfig(parentDirectory, readdirSync);
-}
-exports.walkForTsConfig = walkForTsConfig;
-function loadTsconfig(configFilePath, 
-// eslint-disable-next-line no-shadow
-existsSync, readFileSync) {
-    if (existsSync === void 0) { existsSync = fs.existsSync; }
-    if (readFileSync === void 0) { readFileSync = function (filename) {
-        return fs.readFileSync(filename, "utf8");
-    }; }
-    if (!existsSync(configFilePath)) {
-        return undefined;
-    }
-    var configString = readFileSync(configFilePath);
-    var cleanedJson = StripBom(configString);
-    var config;
-    try {
-        config = JSON5.parse(cleanedJson);
-    }
-    catch (e) {
-        throw new Error("".concat(configFilePath, " is malformed ").concat(e.message));
-    }
-    var extendedConfig = config.extends;
-    if (extendedConfig) {
-        if (typeof extendedConfig === "string" &&
-            extendedConfig.indexOf(".json") === -1) {
-            extendedConfig += ".json";
-        }
-        var currentDir = path.dirname(configFilePath);
-        var extendedConfigPath = path.join(currentDir, extendedConfig);
-        if (extendedConfig.indexOf("/") !== -1 &&
-            extendedConfig.indexOf(".") !== -1 &&
-            !existsSync(extendedConfigPath)) {
-            extendedConfigPath = path.join(currentDir, "node_modules", extendedConfig);
-        }
-        var base = loadTsconfig(extendedConfigPath, existsSync, readFileSync) || {};
-        // baseUrl should be interpreted as relative to the base tsconfig,
-        // but we need to update it so it is relative to the original tsconfig being loaded
-        if (base.compilerOptions && base.compilerOptions.baseUrl) {
-            var extendsDir = path.dirname(extendedConfig);
-            base.compilerOptions.baseUrl = path.join(extendsDir, base.compilerOptions.baseUrl);
-        }
-        return __assign(__assign(__assign({}, base), config), { compilerOptions: __assign(__assign({}, base.compilerOptions), config.compilerOptions) });
-    }
-    return config;
-}
-exports.loadTsconfig = loadTsconfig;
-//# sourceMappingURL=tsconfig-loader.js.map
-
-/***/ }),
-
-/***/ 65315:
-/***/ ((module) => {
-
-/******************************************************************************
-Copyright (c) Microsoft Corporation.
-
-Permission to use, copy, modify, and/or distribute this software for any
-purpose with or without fee is hereby granted.
-
-THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH
-REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY
-AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,
-INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM
-LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR
-OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
-PERFORMANCE OF THIS SOFTWARE.
-***************************************************************************** */
-/* global global, define, Symbol, Reflect, Promise, SuppressedError */
-var __extends;
-var __assign;
-var __rest;
-var __decorate;
-var __param;
-var __esDecorate;
-var __runInitializers;
-var __propKey;
-var __setFunctionName;
-var __metadata;
-var __awaiter;
-var __generator;
-var __exportStar;
-var __values;
-var __read;
-var __spread;
-var __spreadArrays;
-var __spreadArray;
-var __await;
-var __asyncGenerator;
-var __asyncDelegator;
-var __asyncValues;
-var __makeTemplateObject;
-var __importStar;
-var __importDefault;
-var __classPrivateFieldGet;
-var __classPrivateFieldSet;
-var __classPrivateFieldIn;
-var __createBinding;
-var __addDisposableResource;
-var __disposeResources;
-(function (factory) {
-    var root = typeof global === "object" ? global : typeof self === "object" ? self : typeof this === "object" ? this : {};
-    if (typeof define === "function" && define.amd) {
-        define("tslib", ["exports"], function (exports) { factory(createExporter(root, createExporter(exports))); });
-    }
-    else if ( true && typeof module.exports === "object") {
-        factory(createExporter(root, createExporter(module.exports)));
-    }
-    else {
-        factory(createExporter(root));
-    }
-    function createExporter(exports, previous) {
-        if (exports !== root) {
-            if (typeof Object.create === "function") {
-                Object.defineProperty(exports, "__esModule", { value: true });
-            }
-            else {
-                exports.__esModule = true;
-            }
-        }
-        return function (id, v) { return exports[id] = previous ? previous(id, v) : v; };
-    }
-})
-(function (exporter) {
-    var extendStatics = Object.setPrototypeOf ||
-        ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
-        function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };
-
-    __extends = function (d, b) {
-        if (typeof b !== "function" && b !== null)
-            throw new TypeError("Class extends value " + String(b) + " is not a constructor or null");
-        extendStatics(d, b);
-        function __() { this.constructor = d; }
-        d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
-    };
-
-    __assign = Object.assign || function (t) {
-        for (var s, i = 1, n = arguments.length; i < n; i++) {
-            s = arguments[i];
-            for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];
-        }
-        return t;
-    };
-
-    __rest = function (s, e) {
-        var t = {};
-        for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
-            t[p] = s[p];
-        if (s != null && typeof Object.getOwnPropertySymbols === "function")
-            for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
-                if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
-                    t[p[i]] = s[p[i]];
-            }
-        return t;
-    };
-
-    __decorate = function (decorators, target, key, desc) {
-        var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
-        if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
-        else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
-        return c > 3 && r && Object.defineProperty(target, key, r), r;
-    };
-
-    __param = function (paramIndex, decorator) {
-        return function (target, key) { decorator(target, key, paramIndex); }
-    };
-
-    __esDecorate = function (ctor, descriptorIn, decorators, contextIn, initializers, extraInitializers) {
-        function accept(f) { if (f !== void 0 && typeof f !== "function") throw new TypeError("Function expected"); return f; }
-        var kind = contextIn.kind, key = kind === "getter" ? "get" : kind === "setter" ? "set" : "value";
-        var target = !descriptorIn && ctor ? contextIn["static"] ? ctor : ctor.prototype : null;
-        var descriptor = descriptorIn || (target ? Object.getOwnPropertyDescriptor(target, contextIn.name) : {});
-        var _, done = false;
-        for (var i = decorators.length - 1; i >= 0; i--) {
-            var context = {};
-            for (var p in contextIn) context[p] = p === "access" ? {} : contextIn[p];
-            for (var p in contextIn.access) context.access[p] = contextIn.access[p];
-            context.addInitializer = function (f) { if (done) throw new TypeError("Cannot add initializers after decoration has completed"); extraInitializers.push(accept(f || null)); };
-            var result = (0, decorators[i])(kind === "accessor" ? { get: descriptor.get, set: descriptor.set } : descriptor[key], context);
-            if (kind === "accessor") {
-                if (result === void 0) continue;
-                if (result === null || typeof result !== "object") throw new TypeError("Object expected");
-                if (_ = accept(result.get)) descriptor.get = _;
-                if (_ = accept(result.set)) descriptor.set = _;
-                if (_ = accept(result.init)) initializers.unshift(_);
-            }
-            else if (_ = accept(result)) {
-                if (kind === "field") initializers.unshift(_);
-                else descriptor[key] = _;
-            }
-        }
-        if (target) Object.defineProperty(target, contextIn.name, descriptor);
-        done = true;
-    };
-
-    __runInitializers = function (thisArg, initializers, value) {
-        var useValue = arguments.length > 2;
-        for (var i = 0; i < initializers.length; i++) {
-            value = useValue ? initializers[i].call(thisArg, value) : initializers[i].call(thisArg);
-        }
-        return useValue ? value : void 0;
-    };
-
-    __propKey = function (x) {
-        return typeof x === "symbol" ? x : "".concat(x);
-    };
-
-    __setFunctionName = function (f, name, prefix) {
-        if (typeof name === "symbol") name = name.description ? "[".concat(name.description, "]") : "";
-        return Object.defineProperty(f, "name", { configurable: true, value: prefix ? "".concat(prefix, " ", name) : name });
-    };
-
-    __metadata = function (metadataKey, metadataValue) {
-        if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(metadataKey, metadataValue);
-    };
-
-    __awaiter = function (thisArg, _arguments, P, generator) {
-        function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
-        return new (P || (P = Promise))(function (resolve, reject) {
-            function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
-            function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
-            function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
-            step((generator = generator.apply(thisArg, _arguments || [])).next());
-        });
-    };
-
-    __generator = function (thisArg, body) {
-        var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;
-        return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
-        function verb(n) { return function (v) { return step([n, v]); }; }
-        function step(op) {
-            if (f) throw new TypeError("Generator is already executing.");
-            while (g && (g = 0, op[0] && (_ = 0)), _) try {
-                if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
-                if (y = 0, t) op = [op[0] & 2, t.value];
-                switch (op[0]) {
-                    case 0: case 1: t = op; break;
-                    case 4: _.label++; return { value: op[1], done: false };
-                    case 5: _.label++; y = op[1]; op = [0]; continue;
-                    case 7: op = _.ops.pop(); _.trys.pop(); continue;
-                    default:
-                        if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
-                        if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
-                        if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
-                        if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
-                        if (t[2]) _.ops.pop();
-                        _.trys.pop(); continue;
-                }
-                op = body.call(thisArg, _);
-            } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
-            if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
-        }
-    };
-
-    __exportStar = function(m, o) {
-        for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(o, p)) __createBinding(o, m, p);
-    };
-
-    __createBinding = Object.create ? (function(o, m, k, k2) {
-        if (k2 === undefined) k2 = k;
-        var desc = Object.getOwnPropertyDescriptor(m, k);
-        if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
-            desc = { enumerable: true, get: function() { return m[k]; } };
-        }
-        Object.defineProperty(o, k2, desc);
-    }) : (function(o, m, k, k2) {
-        if (k2 === undefined) k2 = k;
-        o[k2] = m[k];
-    });
-
-    __values = function (o) {
-        var s = typeof Symbol === "function" && Symbol.iterator, m = s && o[s], i = 0;
-        if (m) return m.call(o);
-        if (o && typeof o.length === "number") return {
-            next: function () {
-                if (o && i >= o.length) o = void 0;
-                return { value: o && o[i++], done: !o };
-            }
-        };
-        throw new TypeError(s ? "Object is not iterable." : "Symbol.iterator is not defined.");
-    };
-
-    __read = function (o, n) {
-        var m = typeof Symbol === "function" && o[Symbol.iterator];
-        if (!m) return o;
-        var i = m.call(o), r, ar = [], e;
-        try {
-            while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);
-        }
-        catch (error) { e = { error: error }; }
-        finally {
-            try {
-                if (r && !r.done && (m = i["return"])) m.call(i);
-            }
-            finally { if (e) throw e.error; }
-        }
-        return ar;
-    };
-
-    /** @deprecated */
-    __spread = function () {
-        for (var ar = [], i = 0; i < arguments.length; i++)
-            ar = ar.concat(__read(arguments[i]));
-        return ar;
-    };
-
-    /** @deprecated */
-    __spreadArrays = function () {
-        for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;
-        for (var r = Array(s), k = 0, i = 0; i < il; i++)
-            for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)
-                r[k] = a[j];
-        return r;
-    };
-
-    __spreadArray = function (to, from, pack) {
-        if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {
-            if (ar || !(i in from)) {
-                if (!ar) ar = Array.prototype.slice.call(from, 0, i);
-                ar[i] = from[i];
-            }
-        }
-        return to.concat(ar || Array.prototype.slice.call(from));
-    };
-
-    __await = function (v) {
-        return this instanceof __await ? (this.v = v, this) : new __await(v);
-    };
-
-    __asyncGenerator = function (thisArg, _arguments, generator) {
-        if (!Symbol.asyncIterator) throw new TypeError("Symbol.asyncIterator is not defined.");
-        var g = generator.apply(thisArg, _arguments || []), i, q = [];
-        return i = {}, verb("next"), verb("throw"), verb("return"), i[Symbol.asyncIterator] = function () { return this; }, i;
-        function verb(n) { if (g[n]) i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; }
-        function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } }
-        function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r);  }
-        function fulfill(value) { resume("next", value); }
-        function reject(value) { resume("throw", value); }
-        function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); }
-    };
-
-    __asyncDelegator = function (o) {
-        var i, p;
-        return i = {}, verb("next"), verb("throw", function (e) { throw e; }), verb("return"), i[Symbol.iterator] = function () { return this; }, i;
-        function verb(n, f) { i[n] = o[n] ? function (v) { return (p = !p) ? { value: __await(o[n](v)), done: false } : f ? f(v) : v; } : f; }
-    };
-
-    __asyncValues = function (o) {
-        if (!Symbol.asyncIterator) throw new TypeError("Symbol.asyncIterator is not defined.");
-        var m = o[Symbol.asyncIterator], i;
-        return m ? m.call(o) : (o = typeof __values === "function" ? __values(o) : o[Symbol.iterator](), i = {}, verb("next"), verb("throw"), verb("return"), i[Symbol.asyncIterator] = function () { return this; }, i);
-        function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; }
-        function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); }
-    };
-
-    __makeTemplateObject = function (cooked, raw) {
-        if (Object.defineProperty) { Object.defineProperty(cooked, "raw", { value: raw }); } else { cooked.raw = raw; }
-        return cooked;
-    };
-
-    var __setModuleDefault = Object.create ? (function(o, v) {
-        Object.defineProperty(o, "default", { enumerable: true, value: v });
-    }) : function(o, v) {
-        o["default"] = v;
-    };
-
-    __importStar = function (mod) {
-        if (mod && mod.__esModule) return mod;
-        var result = {};
-        if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
-        __setModuleDefault(result, mod);
-        return result;
-    };
-
-    __importDefault = function (mod) {
-        return (mod && mod.__esModule) ? mod : { "default": mod };
-    };
-
-    __classPrivateFieldGet = function (receiver, state, kind, f) {
-        if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a getter");
-        if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot read private member from an object whose class did not declare it");
-        return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
-    };
-
-    __classPrivateFieldSet = function (receiver, state, value, kind, f) {
-        if (kind === "m") throw new TypeError("Private method is not writable");
-        if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a setter");
-        if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot write private member to an object whose class did not declare it");
-        return (kind === "a" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;
-    };
-
-    __classPrivateFieldIn = function (state, receiver) {
-        if (receiver === null || (typeof receiver !== "object" && typeof receiver !== "function")) throw new TypeError("Cannot use 'in' operator on non-object");
-        return typeof state === "function" ? receiver === state : state.has(receiver);
-    };
-
-    __addDisposableResource = function (env, value, async) {
-        if (value !== null && value !== void 0) {
-            if (typeof value !== "object" && typeof value !== "function") throw new TypeError("Object expected.");
-            var dispose;
-            if (async) {
-                if (!Symbol.asyncDispose) throw new TypeError("Symbol.asyncDispose is not defined.");
-                dispose = value[Symbol.asyncDispose];
-            }
-            if (dispose === void 0) {
-                if (!Symbol.dispose) throw new TypeError("Symbol.dispose is not defined.");
-                dispose = value[Symbol.dispose];
-            }
-            if (typeof dispose !== "function") throw new TypeError("Object not disposable.");
-            env.stack.push({ value: value, dispose: dispose, async: async });
-        }
-        else if (async) {
-            env.stack.push({ async: true });
-        }
-        return value;
-    };
-
-    var _SuppressedError = typeof SuppressedError === "function" ? SuppressedError : function (error, suppressed, message) {
-        var e = new Error(message);
-        return e.name = "SuppressedError", e.error = error, e.suppressed = suppressed, e;
-    };
-
-    __disposeResources = function (env) {
-        function fail(e) {
-            env.error = env.hasError ? new _SuppressedError(e, env.error, "An error was suppressed during disposal.") : e;
-            env.hasError = true;
-        }
-        function next() {
-            while (env.stack.length) {
-                var rec = env.stack.pop();
-                try {
-                    var result = rec.dispose && rec.dispose.call(rec.value);
-                    if (rec.async) return Promise.resolve(result).then(next, function(e) { fail(e); return next(); });
-                }
-                catch (e) {
-                    fail(e);
-                }
-            }
-            if (env.hasError) throw env.error;
-        }
-        return next();
-    };
-
-    exporter("__extends", __extends);
-    exporter("__assign", __assign);
-    exporter("__rest", __rest);
-    exporter("__decorate", __decorate);
-    exporter("__param", __param);
-    exporter("__esDecorate", __esDecorate);
-    exporter("__runInitializers", __runInitializers);
-    exporter("__propKey", __propKey);
-    exporter("__setFunctionName", __setFunctionName);
-    exporter("__metadata", __metadata);
-    exporter("__awaiter", __awaiter);
-    exporter("__generator", __generator);
-    exporter("__exportStar", __exportStar);
-    exporter("__createBinding", __createBinding);
-    exporter("__values", __values);
-    exporter("__read", __read);
-    exporter("__spread", __spread);
-    exporter("__spreadArrays", __spreadArrays);
-    exporter("__spreadArray", __spreadArray);
-    exporter("__await", __await);
-    exporter("__asyncGenerator", __asyncGenerator);
-    exporter("__asyncDelegator", __asyncDelegator);
-    exporter("__asyncValues", __asyncValues);
-    exporter("__makeTemplateObject", __makeTemplateObject);
-    exporter("__importStar", __importStar);
-    exporter("__importDefault", __importDefault);
-    exporter("__classPrivateFieldGet", __classPrivateFieldGet);
-    exporter("__classPrivateFieldSet", __classPrivateFieldSet);
-    exporter("__classPrivateFieldIn", __classPrivateFieldIn);
-    exporter("__addDisposableResource", __addDisposableResource);
-    exporter("__disposeResources", __disposeResources);
-});
-
-
-/***/ }),
-
-/***/ 57383:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
-
-module.exports = __nccwpck_require__(39161);
-
-
-/***/ }),
-
-/***/ 39161:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
-
-"use strict";
-
-
-var net = __nccwpck_require__(41808);
-var tls = __nccwpck_require__(24404);
-var http = __nccwpck_require__(13685);
-var https = __nccwpck_require__(95687);
-var events = __nccwpck_require__(82361);
-var assert = __nccwpck_require__(39491);
-var util = __nccwpck_require__(73837);
-
-
-exports.httpOverHttp = httpOverHttp;
-exports.httpsOverHttp = httpsOverHttp;
-exports.httpOverHttps = httpOverHttps;
-exports.httpsOverHttps = httpsOverHttps;
-
-
-function httpOverHttp(options) {
-  var agent = new TunnelingAgent(options);
-  agent.request = http.request;
-  return agent;
-}
-
-function httpsOverHttp(options) {
-  var agent = new TunnelingAgent(options);
-  agent.request = http.request;
-  agent.createSocket = createSecureSocket;
-  agent.defaultPort = 443;
-  return agent;
-}
-
-function httpOverHttps(options) {
-  var agent = new TunnelingAgent(options);
-  agent.request = https.request;
-  return agent;
-}
-
-function httpsOverHttps(options) {
-  var agent = new TunnelingAgent(options);
-  agent.request = https.request;
-  agent.createSocket = createSecureSocket;
-  agent.defaultPort = 443;
-  return agent;
-}
-
-
-function TunnelingAgent(options) {
-  var self = this;
-  self.options = options || {};
-  self.proxyOptions = self.options.proxy || {};
-  self.maxSockets = self.options.maxSockets || http.Agent.defaultMaxSockets;
-  self.requests = [];
-  self.sockets = [];
-
-  self.on('free', function onFree(socket, host, port, localAddress) {
-    var options = toOptions(host, port, localAddress);
-    for (var i = 0, len = self.requests.length; i < len; ++i) {
-      var pending = self.requests[i];
-      if (pending.host === options.host && pending.port === options.port) {
-        // Detect the request to connect same origin server,
-        // reuse the connection.
-        self.requests.splice(i, 1);
-        pending.request.onSocket(socket);
-        return;
-      }
-    }
-    socket.destroy();
-    self.removeSocket(socket);
-  });
-}
-util.inherits(TunnelingAgent, events.EventEmitter);
-
-TunnelingAgent.prototype.addRequest = function addRequest(req, host, port, localAddress) {
-  var self = this;
-  var options = mergeOptions({request: req}, self.options, toOptions(host, port, localAddress));
-
-  if (self.sockets.length >= this.maxSockets) {
-    // We are over limit so we'll add it to the queue.
-    self.requests.push(options);
-    return;
-  }
-
-  // If we are under maxSockets create a new one.
-  self.createSocket(options, function(socket) {
-    socket.on('free', onFree);
-    socket.on('close', onCloseOrRemove);
-    socket.on('agentRemove', onCloseOrRemove);
-    req.onSocket(socket);
-
-    function onFree() {
-      self.emit('free', socket, options);
-    }
-
-    function onCloseOrRemove(err) {
-      self.removeSocket(socket);
-      socket.removeListener('free', onFree);
-      socket.removeListener('close', onCloseOrRemove);
-      socket.removeListener('agentRemove', onCloseOrRemove);
-    }
-  });
-};
-
-TunnelingAgent.prototype.createSocket = function createSocket(options, cb) {
-  var self = this;
-  var placeholder = {};
-  self.sockets.push(placeholder);
-
-  var connectOptions = mergeOptions({}, self.proxyOptions, {
-    method: 'CONNECT',
-    path: options.host + ':' + options.port,
-    agent: false,
-    headers: {
-      host: options.host + ':' + options.port
-    }
-  });
-  if (options.localAddress) {
-    connectOptions.localAddress = options.localAddress;
-  }
-  if (connectOptions.proxyAuth) {
-    connectOptions.headers = connectOptions.headers || {};
-    connectOptions.headers['Proxy-Authorization'] = 'Basic ' +
-        new Buffer(connectOptions.proxyAuth).toString('base64');
-  }
-
-  debug('making CONNECT request');
-  var connectReq = self.request(connectOptions);
-  connectReq.useChunkedEncodingByDefault = false; // for v0.6
-  connectReq.once('response', onResponse); // for v0.6
-  connectReq.once('upgrade', onUpgrade);   // for v0.6
-  connectReq.once('connect', onConnect);   // for v0.7 or later
-  connectReq.once('error', onError);
-  connectReq.end();
-
-  function onResponse(res) {
-    // Very hacky. This is necessary to avoid http-parser leaks.
-    res.upgrade = true;
-  }
-
-  function onUpgrade(res, socket, head) {
-    // Hacky.
-    process.nextTick(function() {
-      onConnect(res, socket, head);
-    });
-  }
-
-  function onConnect(res, socket, head) {
-    connectReq.removeAllListeners();
-    socket.removeAllListeners();
-
-    if (res.statusCode !== 200) {
-      debug('tunneling socket could not be established, statusCode=%d',
-        res.statusCode);
-      socket.destroy();
-      var error = new Error('tunneling socket could not be established, ' +
-        'statusCode=' + res.statusCode);
-      error.code = 'ECONNRESET';
-      options.request.emit('error', error);
-      self.removeSocket(placeholder);
-      return;
-    }
-    if (head.length > 0) {
-      debug('got illegal response body from proxy');
-      socket.destroy();
-      var error = new Error('got illegal response body from proxy');
-      error.code = 'ECONNRESET';
-      options.request.emit('error', error);
-      self.removeSocket(placeholder);
-      return;
-    }
-    debug('tunneling connection has established');
-    self.sockets[self.sockets.indexOf(placeholder)] = socket;
-    return cb(socket);
-  }
-
-  function onError(cause) {
-    connectReq.removeAllListeners();
-
-    debug('tunneling socket could not be established, cause=%s\n',
-          cause.message, cause.stack);
-    var error = new Error('tunneling socket could not be established, ' +
-                          'cause=' + cause.message);
-    error.code = 'ECONNRESET';
-    options.request.emit('error', error);
-    self.removeSocket(placeholder);
-  }
-};
-
-TunnelingAgent.prototype.removeSocket = function removeSocket(socket) {
-  var pos = this.sockets.indexOf(socket)
-  if (pos === -1) {
-    return;
-  }
-  this.sockets.splice(pos, 1);
-
-  var pending = this.requests.shift();
-  if (pending) {
-    // If we have pending requests and a socket gets closed a new one
-    // needs to be created to take over in the pool for the one that closed.
-    this.createSocket(pending, function(socket) {
-      pending.request.onSocket(socket);
-    });
-  }
-};
-
-function createSecureSocket(options, cb) {
-  var self = this;
-  TunnelingAgent.prototype.createSocket.call(self, options, function(socket) {
-    var hostHeader = options.request.getHeader('host');
-    var tlsOptions = mergeOptions({}, self.options, {
-      socket: socket,
-      servername: hostHeader ? hostHeader.replace(/:.*$/, '') : options.host
-    });
-
-    // 0 is dummy port for v0.6
-    var secureSocket = tls.connect(0, tlsOptions);
-    self.sockets[self.sockets.indexOf(socket)] = secureSocket;
-    cb(secureSocket);
-  });
-}
-
-
-function toOptions(host, port, localAddress) {
-  if (typeof host === 'string') { // since v0.10
-    return {
-      host: host,
-      port: port,
-      localAddress: localAddress
-    };
-  }
-  return host; // for v0.11 or later
-}
-
-function mergeOptions(target) {
-  for (var i = 1, len = arguments.length; i < len; ++i) {
-    var overrides = arguments[i];
-    if (typeof overrides === 'object') {
-      var keys = Object.keys(overrides);
-      for (var j = 0, keyLen = keys.length; j < keyLen; ++j) {
-        var k = keys[j];
-        if (overrides[k] !== undefined) {
-          target[k] = overrides[k];
-        }
-      }
-    }
-  }
-  return target;
-}
-
-
-var debug;
-if (process.env.NODE_DEBUG && /\btunnel\b/.test(process.env.NODE_DEBUG)) {
-  debug = function() {
-    var args = Array.prototype.slice.call(arguments);
-    if (typeof args[0] === 'string') {
-      args[0] = 'TUNNEL: ' + args[0];
-    } else {
-      args.unshift('TUNNEL:');
-    }
-    console.error.apply(console, args);
-  }
-} else {
-  debug = function() {};
-}
-exports.debug = debug; // for test
-
-
-/***/ }),
-
-/***/ 70048:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
-
-"use strict";
-/*! *****************************************************************************
-Copyright (c) Microsoft Corporation. All rights reserved.
-Licensed under the Apache License, Version 2.0 (the "License"); you may not use
-this file except in compliance with the License. You may obtain a copy of the
-License at http://www.apache.org/licenses/LICENSE-2.0
-
-THIS CODE IS PROVIDED ON AN *AS IS* BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
-KIND, EITHER EXPRESS OR IMPLIED, INCLUDING WITHOUT LIMITATION ANY IMPLIED
-WARRANTIES OR CONDITIONS OF TITLE, FITNESS FOR A PARTICULAR PURPOSE,
-MERCHANTABLITY OR NON-INFRINGEMENT.
-
-See the Apache Version 2.0 License for specific language governing permissions
-and limitations under the License.
-***************************************************************************** */
-
-
-
-var ts = (() => {
-  var __defProp = Object.defineProperty;
-  var __getOwnPropNames = Object.getOwnPropertyNames;
-  var __esm = (fn, res) => function __init() {
-    return fn && (res = (0, fn[__getOwnPropNames(fn)[0]])(fn = 0)), res;
-  };
-  var __commonJS = (cb, mod) => function __require() {
-    return mod || (0, cb[__getOwnPropNames(cb)[0]])((mod = { exports: {} }).exports, mod), mod.exports;
-  };
-  var __export = (target, all) => {
-    for (var name in all)
-      __defProp(target, name, { get: all[name], enumerable: true });
-  };
-
-  // src/compiler/corePublic.ts
-  var versionMajorMinor, version, Comparison;
-  var init_corePublic = __esm({
-    "src/compiler/corePublic.ts"() {
-      "use strict";
-      versionMajorMinor = "5.1";
-      version = "5.1.6";
-      Comparison = /* @__PURE__ */ ((Comparison3) => {
-        Comparison3[Comparison3["LessThan"] = -1] = "LessThan";
-        Comparison3[Comparison3["EqualTo"] = 0] = "EqualTo";
-        Comparison3[Comparison3["GreaterThan"] = 1] = "GreaterThan";
-        return Comparison3;
-      })(Comparison || {});
-    }
-  });
-
-  // src/compiler/core.ts
-  function length(array) {
-    return array ? array.length : 0;
-  }
-  function forEach(array, callback) {
-    if (array) {
-      for (let i = 0; i < array.length; i++) {
-        const result = callback(array[i], i);
-        if (result) {
-          return result;
-        }
-      }
-    }
-    return void 0;
-  }
-  function forEachRight(array, callback) {
-    if (array) {
-      for (let i = array.length - 1; i >= 0; i--) {
-        const result = callback(array[i], i);
-        if (result) {
-          return result;
-        }
-      }
-    }
-    return void 0;
-  }
-  function firstDefined(array, callback) {
-    if (array === void 0) {
-      return void 0;
-    }
-    for (let i = 0; i < array.length; i++) {
-      const result = callback(array[i], i);
-      if (result !== void 0) {
-        return result;
-      }
-    }
-    return void 0;
-  }
-  function firstDefinedIterator(iter, callback) {
-    for (const value of iter) {
-      const result = callback(value);
-      if (result !== void 0) {
-        return result;
-      }
-    }
-    return void 0;
-  }
-  function reduceLeftIterator(iterator, f, initial) {
-    let result = initial;
-    if (iterator) {
-      let pos = 0;
-      for (const value of iterator) {
-        result = f(result, value, pos);
-        pos++;
-      }
-    }
-    return result;
-  }
-  function zipWith(arrayA, arrayB, callback) {
-    const result = [];
-    Debug.assertEqual(arrayA.length, arrayB.length);
-    for (let i = 0; i < arrayA.length; i++) {
-      result.push(callback(arrayA[i], arrayB[i], i));
-    }
-    return result;
-  }
-  function intersperse(input, element) {
-    if (input.length <= 1) {
-      return input;
-    }
-    const result = [];
-    for (let i = 0, n = input.length; i < n; i++) {
-      if (i)
-        result.push(element);
-      result.push(input[i]);
-    }
-    return result;
-  }
-  function every(array, callback) {
-    if (array) {
-      for (let i = 0; i < array.length; i++) {
-        if (!callback(array[i], i)) {
-          return false;
-        }
-      }
-    }
-    return true;
-  }
-  function find(array, predicate, startIndex) {
-    if (array === void 0)
-      return void 0;
-    for (let i = startIndex ?? 0; i < array.length; i++) {
-      const value = array[i];
-      if (predicate(value, i)) {
-        return value;
-      }
-    }
-    return void 0;
-  }
-  function findLast(array, predicate, startIndex) {
-    if (array === void 0)
-      return void 0;
-    for (let i = startIndex ?? array.length - 1; i >= 0; i--) {
-      const value = array[i];
-      if (predicate(value, i)) {
-        return value;
-      }
-    }
-    return void 0;
-  }
-  function findIndex(array, predicate, startIndex) {
-    if (array === void 0)
-      return -1;
-    for (let i = startIndex ?? 0; i < array.length; i++) {
-      if (predicate(array[i], i)) {
-        return i;
-      }
-    }
-    return -1;
-  }
-  function findLastIndex(array, predicate, startIndex) {
-    if (array === void 0)
-      return -1;
-    for (let i = startIndex ?? array.length - 1; i >= 0; i--) {
-      if (predicate(array[i], i)) {
-        return i;
-      }
-    }
-    return -1;
-  }
-  function findMap(array, callback) {
-    for (let i = 0; i < array.length; i++) {
-      const result = callback(array[i], i);
-      if (result) {
-        return result;
-      }
-    }
-    return Debug.fail();
-  }
-  function contains(array, value, equalityComparer = equateValues) {
-    if (array) {
-      for (const v of array) {
-        if (equalityComparer(v, value)) {
-          return true;
-        }
-      }
-    }
-    return false;
-  }
-  function arraysEqual(a, b, equalityComparer = equateValues) {
-    return a.length === b.length && a.every((x, i) => equalityComparer(x, b[i]));
-  }
-  function indexOfAnyCharCode(text, charCodes, start) {
-    for (let i = start || 0; i < text.length; i++) {
-      if (contains(charCodes, text.charCodeAt(i))) {
-        return i;
-      }
-    }
-    return -1;
-  }
-  function countWhere(array, predicate) {
-    let count = 0;
-    if (array) {
-      for (let i = 0; i < array.length; i++) {
-        const v = array[i];
-        if (predicate(v, i)) {
-          count++;
-        }
-      }
-    }
-    return count;
-  }
-  function filter(array, f) {
-    if (array) {
-      const len = array.length;
-      let i = 0;
-      while (i < len && f(array[i]))
-        i++;
-      if (i < len) {
-        const result = array.slice(0, i);
-        i++;
-        while (i < len) {
-          const item = array[i];
-          if (f(item)) {
-            result.push(item);
-          }
-          i++;
-        }
-        return result;
-      }
-    }
-    return array;
-  }
-  function filterMutate(array, f) {
-    let outIndex = 0;
-    for (let i = 0; i < array.length; i++) {
-      if (f(array[i], i, array)) {
-        array[outIndex] = array[i];
-        outIndex++;
-      }
-    }
-    array.length = outIndex;
-  }
-  function clear(array) {
-    array.length = 0;
-  }
-  function map(array, f) {
-    let result;
-    if (array) {
-      result = [];
-      for (let i = 0; i < array.length; i++) {
-        result.push(f(array[i], i));
-      }
-    }
-    return result;
-  }
-  function* mapIterator(iter, mapFn) {
-    for (const x of iter) {
-      yield mapFn(x);
-    }
-  }
-  function sameMap(array, f) {
-    if (array) {
-      for (let i = 0; i < array.length; i++) {
-        const item = array[i];
-        const mapped = f(item, i);
-        if (item !== mapped) {
-          const result = array.slice(0, i);
-          result.push(mapped);
-          for (i++; i < array.length; i++) {
-            result.push(f(array[i], i));
-          }
-          return result;
-        }
-      }
-    }
-    return array;
-  }
-  function flatten(array) {
-    const result = [];
-    for (const v of array) {
-      if (v) {
-        if (isArray(v)) {
-          addRange(result, v);
-        } else {
-          result.push(v);
-        }
-      }
-    }
-    return result;
-  }
-  function flatMap(array, mapfn) {
-    let result;
-    if (array) {
-      for (let i = 0; i < array.length; i++) {
-        const v = mapfn(array[i], i);
-        if (v) {
-          if (isArray(v)) {
-            result = addRange(result, v);
-          } else {
-            result = append(result, v);
-          }
-        }
-      }
-    }
-    return result || emptyArray;
-  }
-  function flatMapToMutable(array, mapfn) {
-    const result = [];
-    if (array) {
-      for (let i = 0; i < array.length; i++) {
-        const v = mapfn(array[i], i);
-        if (v) {
-          if (isArray(v)) {
-            addRange(result, v);
-          } else {
-            result.push(v);
-          }
-        }
-      }
-    }
-    return result;
-  }
-  function* flatMapIterator(iter, mapfn) {
-    for (const x of iter) {
-      const iter2 = mapfn(x);
-      if (!iter2)
-        continue;
-      yield* iter2;
-    }
-  }
-  function sameFlatMap(array, mapfn) {
-    let result;
-    if (array) {
-      for (let i = 0; i < array.length; i++) {
-        const item = array[i];
-        const mapped = mapfn(item, i);
-        if (result || item !== mapped || isArray(mapped)) {
-          if (!result) {
-            result = array.slice(0, i);
-          }
-          if (isArray(mapped)) {
-            addRange(result, mapped);
-          } else {
-            result.push(mapped);
-          }
-        }
-      }
-    }
-    return result || array;
-  }
-  function mapAllOrFail(array, mapFn) {
-    const result = [];
-    for (let i = 0; i < array.length; i++) {
-      const mapped = mapFn(array[i], i);
-      if (mapped === void 0) {
-        return void 0;
-      }
-      result.push(mapped);
-    }
-    return result;
-  }
-  function mapDefined(array, mapFn) {
-    const result = [];
-    if (array) {
-      for (let i = 0; i < array.length; i++) {
-        const mapped = mapFn(array[i], i);
-        if (mapped !== void 0) {
-          result.push(mapped);
-        }
-      }
-    }
-    return result;
-  }
-  function* mapDefinedIterator(iter, mapFn) {
-    for (const x of iter) {
-      const value = mapFn(x);
-      if (value !== void 0) {
-        yield value;
-      }
-    }
-  }
-  function mapDefinedEntries(map2, f) {
-    if (!map2) {
-      return void 0;
-    }
-    const result = /* @__PURE__ */ new Map();
-    map2.forEach((value, key) => {
-      const entry = f(key, value);
-      if (entry !== void 0) {
-        const [newKey, newValue] = entry;
-        if (newKey !== void 0 && newValue !== void 0) {
-          result.set(newKey, newValue);
-        }
-      }
-    });
-    return result;
-  }
-  function getOrUpdate(map2, key, callback) {
-    if (map2.has(key)) {
-      return map2.get(key);
-    }
-    const value = callback();
-    map2.set(key, value);
-    return value;
-  }
-  function tryAddToSet(set, value) {
-    if (!set.has(value)) {
-      set.add(value);
-      return true;
-    }
-    return false;
-  }
-  function* singleIterator(value) {
-    yield value;
-  }
-  function spanMap(array, keyfn, mapfn) {
-    let result;
-    if (array) {
-      result = [];
-      const len = array.length;
-      let previousKey;
-      let key;
-      let start = 0;
-      let pos = 0;
-      while (start < len) {
-        while (pos < len) {
-          const value = array[pos];
-          key = keyfn(value, pos);
-          if (pos === 0) {
-            previousKey = key;
-          } else if (key !== previousKey) {
-            break;
-          }
-          pos++;
-        }
-        if (start < pos) {
-          const v = mapfn(array.slice(start, pos), previousKey, start, pos);
-          if (v) {
-            result.push(v);
-          }
-          start = pos;
-        }
-        previousKey = key;
-        pos++;
-      }
-    }
-    return result;
-  }
-  function mapEntries(map2, f) {
-    if (!map2) {
-      return void 0;
-    }
-    const result = /* @__PURE__ */ new Map();
-    map2.forEach((value, key) => {
-      const [newKey, newValue] = f(key, value);
-      result.set(newKey, newValue);
-    });
-    return result;
-  }
-  function some(array, predicate) {
-    if (array) {
-      if (predicate) {
-        for (const v of array) {
-          if (predicate(v)) {
-            return true;
-          }
-        }
-      } else {
-        return array.length > 0;
-      }
-    }
-    return false;
-  }
-  function getRangesWhere(arr, pred, cb) {
-    let start;
-    for (let i = 0; i < arr.length; i++) {
-      if (pred(arr[i])) {
-        start = start === void 0 ? i : start;
-      } else {
-        if (start !== void 0) {
-          cb(start, i);
-          start = void 0;
-        }
-      }
-    }
-    if (start !== void 0)
-      cb(start, arr.length);
-  }
-  function concatenate(array1, array2) {
-    if (!some(array2))
-      return array1;
-    if (!some(array1))
-      return array2;
-    return [...array1, ...array2];
-  }
-  function selectIndex(_, i) {
-    return i;
-  }
-  function indicesOf(array) {
-    return array.map(selectIndex);
-  }
-  function deduplicateRelational(array, equalityComparer, comparer) {
-    const indices = indicesOf(array);
-    stableSortIndices(array, indices, comparer);
-    let last2 = array[indices[0]];
-    const deduplicated = [indices[0]];
-    for (let i = 1; i < indices.length; i++) {
-      const index = indices[i];
-      const item = array[index];
-      if (!equalityComparer(last2, item)) {
-        deduplicated.push(index);
-        last2 = item;
-      }
-    }
-    deduplicated.sort();
-    return deduplicated.map((i) => array[i]);
-  }
-  function deduplicateEquality(array, equalityComparer) {
-    const result = [];
-    for (const item of array) {
-      pushIfUnique(result, item, equalityComparer);
-    }
-    return result;
-  }
-  function deduplicate(array, equalityComparer, comparer) {
-    return array.length === 0 ? [] : array.length === 1 ? array.slice() : comparer ? deduplicateRelational(array, equalityComparer, comparer) : deduplicateEquality(array, equalityComparer);
-  }
-  function deduplicateSorted(array, comparer) {
-    if (array.length === 0)
-      return emptyArray;
-    let last2 = array[0];
-    const deduplicated = [last2];
-    for (let i = 1; i < array.length; i++) {
-      const next = array[i];
-      switch (comparer(next, last2)) {
-        case true:
-        case 0 /* EqualTo */:
-          continue;
-        case -1 /* LessThan */:
-          return Debug.fail("Array is unsorted.");
-      }
-      deduplicated.push(last2 = next);
-    }
-    return deduplicated;
-  }
-  function createSortedArray() {
-    return [];
-  }
-  function insertSorted(array, insert, compare, allowDuplicates) {
-    if (array.length === 0) {
-      array.push(insert);
-      return true;
-    }
-    const insertIndex = binarySearch(array, insert, identity, compare);
-    if (insertIndex < 0) {
-      array.splice(~insertIndex, 0, insert);
-      return true;
-    }
-    if (allowDuplicates) {
-      array.splice(insertIndex, 0, insert);
-      return true;
-    }
-    return false;
-  }
-  function sortAndDeduplicate(array, comparer, equalityComparer) {
-    return deduplicateSorted(sort(array, comparer), equalityComparer || comparer || compareStringsCaseSensitive);
-  }
-  function arrayIsSorted(array, comparer) {
-    if (array.length < 2)
-      return true;
-    for (let i = 1, len = array.length; i < len; i++) {
-      if (comparer(array[i - 1], array[i]) === 1 /* GreaterThan */) {
-        return false;
-      }
-    }
-    return true;
-  }
-  function detectSortCaseSensitivity(array, getString, compareStringsCaseSensitive2, compareStringsCaseInsensitive2) {
-    let kind = 3 /* Both */;
-    if (array.length < 2)
-      return kind;
-    let prevElement = getString(array[0]);
-    for (let i = 1, len = array.length; i < len && kind !== 0 /* None */; i++) {
-      const element = getString(array[i]);
-      if (kind & 1 /* CaseSensitive */ && compareStringsCaseSensitive2(prevElement, element) > 0) {
-        kind &= ~1 /* CaseSensitive */;
-      }
-      if (kind & 2 /* CaseInsensitive */ && compareStringsCaseInsensitive2(prevElement, element) > 0) {
-        kind &= ~2 /* CaseInsensitive */;
-      }
-      prevElement = element;
-    }
-    return kind;
-  }
-  function arrayIsEqualTo(array1, array2, equalityComparer = equateValues) {
-    if (!array1 || !array2) {
-      return array1 === array2;
-    }
-    if (array1.length !== array2.length) {
-      return false;
-    }
-    for (let i = 0; i < array1.length; i++) {
-      if (!equalityComparer(array1[i], array2[i], i)) {
-        return false;
-      }
-    }
-    return true;
-  }
-  function compact(array) {
-    let result;
-    if (array) {
-      for (let i = 0; i < array.length; i++) {
-        const v = array[i];
-        if (result || !v) {
-          if (!result) {
-            result = array.slice(0, i);
-          }
-          if (v) {
-            result.push(v);
-          }
-        }
-      }
-    }
-    return result || array;
-  }
-  function relativeComplement(arrayA, arrayB, comparer) {
-    if (!arrayB || !arrayA || arrayB.length === 0 || arrayA.length === 0)
-      return arrayB;
-    const result = [];
-    loopB:
-      for (let offsetA = 0, offsetB = 0; offsetB < arrayB.length; offsetB++) {
-        if (offsetB > 0) {
-          Debug.assertGreaterThanOrEqual(comparer(arrayB[offsetB], arrayB[offsetB - 1]), 0 /* EqualTo */);
-        }
-        loopA:
-          for (const startA = offsetA; offsetA < arrayA.length; offsetA++) {
-            if (offsetA > startA) {
-              Debug.assertGreaterThanOrEqual(comparer(arrayA[offsetA], arrayA[offsetA - 1]), 0 /* EqualTo */);
-            }
-            switch (comparer(arrayB[offsetB], arrayA[offsetA])) {
-              case -1 /* LessThan */:
-                result.push(arrayB[offsetB]);
-                continue loopB;
-              case 0 /* EqualTo */:
-                continue loopB;
-              case 1 /* GreaterThan */:
-                continue loopA;
-            }
-          }
-      }
-    return result;
-  }
-  function append(to, value) {
-    if (value === void 0)
-      return to;
-    if (to === void 0)
-      return [value];
-    to.push(value);
-    return to;
-  }
-  function combine(xs, ys) {
-    if (xs === void 0)
-      return ys;
-    if (ys === void 0)
-      return xs;
-    if (isArray(xs))
-      return isArray(ys) ? concatenate(xs, ys) : append(xs, ys);
-    if (isArray(ys))
-      return append(ys, xs);
-    return [xs, ys];
-  }
-  function toOffset(array, offset) {
-    return offset < 0 ? array.length + offset : offset;
-  }
-  function addRange(to, from, start, end) {
-    if (from === void 0 || from.length === 0)
-      return to;
-    if (to === void 0)
-      return from.slice(start, end);
-    start = start === void 0 ? 0 : toOffset(from, start);
-    end = end === void 0 ? from.length : toOffset(from, end);
-    for (let i = start; i < end && i < from.length; i++) {
-      if (from[i] !== void 0) {
-        to.push(from[i]);
-      }
-    }
-    return to;
-  }
-  function pushIfUnique(array, toAdd, equalityComparer) {
-    if (contains(array, toAdd, equalityComparer)) {
-      return false;
-    } else {
-      array.push(toAdd);
-      return true;
-    }
-  }
-  function appendIfUnique(array, toAdd, equalityComparer) {
-    if (array) {
-      pushIfUnique(array, toAdd, equalityComparer);
-      return array;
-    } else {
-      return [toAdd];
-    }
-  }
-  function stableSortIndices(array, indices, comparer) {
-    indices.sort((x, y) => comparer(array[x], array[y]) || compareValues(x, y));
-  }
-  function sort(array, comparer) {
-    return array.length === 0 ? array : array.slice().sort(comparer);
-  }
-  function* arrayReverseIterator(array) {
-    for (let i = array.length - 1; i >= 0; i--) {
-      yield array[i];
-    }
-  }
-  function stableSort(array, comparer) {
-    const indices = indicesOf(array);
-    stableSortIndices(array, indices, comparer);
-    return indices.map((i) => array[i]);
-  }
-  function rangeEquals(array1, array2, pos, end) {
-    while (pos < end) {
-      if (array1[pos] !== array2[pos]) {
-        return false;
-      }
-      pos++;
-    }
-    return true;
-  }
-  function firstOrUndefined(array) {
-    return array === void 0 || array.length === 0 ? void 0 : array[0];
-  }
-  function firstOrUndefinedIterator(iter) {
-    if (iter) {
-      for (const value of iter) {
-        return value;
-      }
-    }
-    return void 0;
-  }
-  function first(array) {
-    Debug.assert(array.length !== 0);
-    return array[0];
-  }
-  function firstIterator(iter) {
-    for (const value of iter) {
-      return value;
-    }
-    Debug.fail("iterator is empty");
-  }
-  function lastOrUndefined(array) {
-    return array === void 0 || array.length === 0 ? void 0 : array[array.length - 1];
-  }
-  function last(array) {
-    Debug.assert(array.length !== 0);
-    return array[array.length - 1];
-  }
-  function singleOrUndefined(array) {
-    return array && array.length === 1 ? array[0] : void 0;
-  }
-  function single(array) {
-    return Debug.checkDefined(singleOrUndefined(array));
-  }
-  function singleOrMany(array) {
-    return array && array.length === 1 ? array[0] : array;
-  }
-  function replaceElement(array, index, value) {
-    const result = array.slice(0);
-    result[index] = value;
-    return result;
-  }
-  function binarySearch(array, value, keySelector, keyComparer, offset) {
-    return binarySearchKey(array, keySelector(value), keySelector, keyComparer, offset);
-  }
-  function binarySearchKey(array, key, keySelector, keyComparer, offset) {
-    if (!some(array)) {
-      return -1;
-    }
-    let low = offset || 0;
-    let high = array.length - 1;
-    while (low <= high) {
-      const middle = low + (high - low >> 1);
-      const midKey = keySelector(array[middle], middle);
-      switch (keyComparer(midKey, key)) {
-        case -1 /* LessThan */:
-          low = middle + 1;
-          break;
-        case 0 /* EqualTo */:
-          return middle;
-        case 1 /* GreaterThan */:
-          high = middle - 1;
-          break;
-      }
-    }
-    return ~low;
-  }
-  function reduceLeft(array, f, initial, start, count) {
-    if (array && array.length > 0) {
-      const size = array.length;
-      if (size > 0) {
-        let pos = start === void 0 || start < 0 ? 0 : start;
-        const end = count === void 0 || pos + count > size - 1 ? size - 1 : pos + count;
-        let result;
-        if (arguments.length <= 2) {
-          result = array[pos];
-          pos++;
-        } else {
-          result = initial;
-        }
-        while (pos <= end) {
-          result = f(result, array[pos], pos);
-          pos++;
-        }
-        return result;
-      }
-    }
-    return initial;
-  }
-  function hasProperty(map2, key) {
-    return hasOwnProperty.call(map2, key);
-  }
-  function getProperty(map2, key) {
-    return hasOwnProperty.call(map2, key) ? map2[key] : void 0;
-  }
-  function getOwnKeys(map2) {
-    const keys = [];
-    for (const key in map2) {
-      if (hasOwnProperty.call(map2, key)) {
-        keys.push(key);
-      }
-    }
-    return keys;
-  }
-  function getAllKeys(obj) {
-    const result = [];
-    do {
-      const names = Object.getOwnPropertyNames(obj);
-      for (const name of names) {
-        pushIfUnique(result, name);
-      }
-    } while (obj = Object.getPrototypeOf(obj));
-    return result;
-  }
-  function getOwnValues(collection) {
-    const values = [];
-    for (const key in collection) {
-      if (hasOwnProperty.call(collection, key)) {
-        values.push(collection[key]);
-      }
-    }
-    return values;
-  }
-  function arrayOf(count, f) {
-    const result = new Array(count);
-    for (let i = 0; i < count; i++) {
-      result[i] = f(i);
-    }
-    return result;
-  }
-  function arrayFrom(iterator, map2) {
-    const result = [];
-    for (const value of iterator) {
-      result.push(map2 ? map2(value) : value);
-    }
-    return result;
-  }
-  function assign(t, ...args) {
-    for (const arg of args) {
-      if (arg === void 0)
-        continue;
-      for (const p in arg) {
-        if (hasProperty(arg, p)) {
-          t[p] = arg[p];
-        }
-      }
-    }
-    return t;
-  }
-  function equalOwnProperties(left, right, equalityComparer = equateValues) {
-    if (left === right)
-      return true;
-    if (!left || !right)
-      return false;
-    for (const key in left) {
-      if (hasOwnProperty.call(left, key)) {
-        if (!hasOwnProperty.call(right, key))
-          return false;
-        if (!equalityComparer(left[key], right[key]))
-          return false;
-      }
-    }
-    for (const key in right) {
-      if (hasOwnProperty.call(right, key)) {
-        if (!hasOwnProperty.call(left, key))
-          return false;
-      }
-    }
-    return true;
-  }
-  function arrayToMap(array, makeKey, makeValue = identity) {
-    const result = /* @__PURE__ */ new Map();
-    for (const value of array) {
-      const key = makeKey(value);
-      if (key !== void 0)
-        result.set(key, makeValue(value));
-    }
-    return result;
-  }
-  function arrayToNumericMap(array, makeKey, makeValue = identity) {
-    const result = [];
-    for (const value of array) {
-      result[makeKey(value)] = makeValue(value);
-    }
-    return result;
-  }
-  function arrayToMultiMap(values, makeKey, makeValue = identity) {
-    const result = createMultiMap();
-    for (const value of values) {
-      result.add(makeKey(value), makeValue(value));
-    }
-    return result;
-  }
-  function group(values, getGroupId, resultSelector = identity) {
-    return arrayFrom(arrayToMultiMap(values, getGroupId).values(), resultSelector);
-  }
-  function groupBy(values, keySelector) {
-    const result = {};
-    if (values) {
-      for (const value of values) {
-        const key = `${keySelector(value)}`;
-        const array = result[key] ?? (result[key] = []);
-        array.push(value);
-      }
-    }
-    return result;
-  }
-  function clone(object) {
-    const result = {};
-    for (const id in object) {
-      if (hasOwnProperty.call(object, id)) {
-        result[id] = object[id];
-      }
-    }
-    return result;
-  }
-  function extend(first2, second) {
-    const result = {};
-    for (const id in second) {
-      if (hasOwnProperty.call(second, id)) {
-        result[id] = second[id];
-      }
-    }
-    for (const id in first2) {
-      if (hasOwnProperty.call(first2, id)) {
-        result[id] = first2[id];
-      }
-    }
-    return result;
-  }
-  function copyProperties(first2, second) {
-    for (const id in second) {
-      if (hasOwnProperty.call(second, id)) {
-        first2[id] = second[id];
-      }
-    }
-  }
-  function maybeBind(obj, fn) {
-    return fn ? fn.bind(obj) : void 0;
-  }
-  function createMultiMap() {
-    const map2 = /* @__PURE__ */ new Map();
-    map2.add = multiMapAdd;
-    map2.remove = multiMapRemove;
-    return map2;
-  }
-  function multiMapAdd(key, value) {
-    let values = this.get(key);
-    if (values) {
-      values.push(value);
-    } else {
-      this.set(key, values = [value]);
-    }
-    return values;
-  }
-  function multiMapRemove(key, value) {
-    const values = this.get(key);
-    if (values) {
-      unorderedRemoveItem(values, value);
-      if (!values.length) {
-        this.delete(key);
-      }
-    }
-  }
-  function createQueue(items) {
-    const elements = (items == null ? void 0 : items.slice()) || [];
-    let headIndex = 0;
-    function isEmpty() {
-      return headIndex === elements.length;
-    }
-    function enqueue(...items2) {
-      elements.push(...items2);
-    }
-    function dequeue() {
-      if (isEmpty()) {
-        throw new Error("Queue is empty");
-      }
-      const result = elements[headIndex];
-      elements[headIndex] = void 0;
-      headIndex++;
-      if (headIndex > 100 && headIndex > elements.length >> 1) {
-        const newLength = elements.length - headIndex;
-        elements.copyWithin(
-          /*target*/
-          0,
-          /*start*/
-          headIndex
-        );
-        elements.length = newLength;
-        headIndex = 0;
-      }
-      return result;
-    }
-    return {
-      enqueue,
-      dequeue,
-      isEmpty
-    };
-  }
-  function createSet(getHashCode, equals) {
-    const multiMap = /* @__PURE__ */ new Map();
-    let size = 0;
-    function* getElementIterator() {
-      for (const value of multiMap.values()) {
-        if (isArray(value)) {
-          yield* value;
-        } else {
-          yield value;
-        }
-      }
-    }
-    const set = {
-      has(element) {
-        const hash = getHashCode(element);
-        if (!multiMap.has(hash))
-          return false;
-        const candidates = multiMap.get(hash);
-        if (!isArray(candidates))
-          return equals(candidates, element);
-        for (const candidate of candidates) {
-          if (equals(candidate, element)) {
-            return true;
-          }
-        }
-        return false;
-      },
-      add(element) {
-        const hash = getHashCode(element);
-        if (multiMap.has(hash)) {
-          const values = multiMap.get(hash);
-          if (isArray(values)) {
-            if (!contains(values, element, equals)) {
-              values.push(element);
-              size++;
-            }
-          } else {
-            const value = values;
-            if (!equals(value, element)) {
-              multiMap.set(hash, [value, element]);
-              size++;
-            }
-          }
-        } else {
-          multiMap.set(hash, element);
-          size++;
-        }
-        return this;
-      },
-      delete(element) {
-        const hash = getHashCode(element);
-        if (!multiMap.has(hash))
-          return false;
-        const candidates = multiMap.get(hash);
-        if (isArray(candidates)) {
-          for (let i = 0; i < candidates.length; i++) {
-            if (equals(candidates[i], element)) {
-              if (candidates.length === 1) {
-                multiMap.delete(hash);
-              } else if (candidates.length === 2) {
-                multiMap.set(hash, candidates[1 - i]);
-              } else {
-                unorderedRemoveItemAt(candidates, i);
-              }
-              size--;
-              return true;
-            }
-          }
-        } else {
-          const candidate = candidates;
-          if (equals(candidate, element)) {
-            multiMap.delete(hash);
-            size--;
-            return true;
-          }
-        }
-        return false;
-      },
-      clear() {
-        multiMap.clear();
-        size = 0;
-      },
-      get size() {
-        return size;
-      },
-      forEach(action) {
-        for (const elements of arrayFrom(multiMap.values())) {
-          if (isArray(elements)) {
-            for (const element of elements) {
-              action(element, element, set);
-            }
-          } else {
-            const element = elements;
-            action(element, element, set);
-          }
-        }
-      },
-      keys() {
-        return getElementIterator();
-      },
-      values() {
-        return getElementIterator();
-      },
-      *entries() {
-        for (const value of getElementIterator()) {
-          yield [value, value];
-        }
-      },
-      [Symbol.iterator]: () => {
-        return getElementIterator();
-      },
-      [Symbol.toStringTag]: multiMap[Symbol.toStringTag]
-    };
-    return set;
-  }
-  function isArray(value) {
-    return Array.isArray(value);
-  }
-  function toArray(value) {
-    return isArray(value) ? value : [value];
-  }
-  function isString(text) {
-    return typeof text === "string";
-  }
-  function isNumber(x) {
-    return typeof x === "number";
-  }
-  function tryCast(value, test) {
-    return value !== void 0 && test(value) ? value : void 0;
-  }
-  function cast(value, test) {
-    if (value !== void 0 && test(value))
-      return value;
-    return Debug.fail(`Invalid cast. The supplied value ${value} did not pass the test '${Debug.getFunctionName(test)}'.`);
-  }
-  function noop(_) {
-  }
-  function returnFalse() {
-    return false;
-  }
-  function returnTrue() {
-    return true;
-  }
-  function returnUndefined() {
-    return void 0;
-  }
-  function identity(x) {
-    return x;
-  }
-  function toLowerCase(x) {
-    return x.toLowerCase();
-  }
-  function toFileNameLowerCase(x) {
-    return fileNameLowerCaseRegExp.test(x) ? x.replace(fileNameLowerCaseRegExp, toLowerCase) : x;
-  }
-  function notImplemented() {
-    throw new Error("Not implemented");
-  }
-  function memoize(callback) {
-    let value;
-    return () => {
-      if (callback) {
-        value = callback();
-        callback = void 0;
-      }
-      return value;
-    };
-  }
-  function memoizeOne(callback) {
-    const map2 = /* @__PURE__ */ new Map();
-    return (arg) => {
-      const key = `${typeof arg}:${arg}`;
-      let value = map2.get(key);
-      if (value === void 0 && !map2.has(key)) {
-        value = callback(arg);
-        map2.set(key, value);
-      }
-      return value;
-    };
-  }
-  function memoizeWeak(callback) {
-    const map2 = /* @__PURE__ */ new WeakMap();
-    return (arg) => {
-      let value = map2.get(arg);
-      if (value === void 0 && !map2.has(arg)) {
-        value = callback(arg);
-        map2.set(arg, value);
-      }
-      return value;
-    };
-  }
-  function memoizeCached(callback, cache) {
-    return (...args) => {
-      let value = cache.get(args);
-      if (value === void 0 && !cache.has(args)) {
-        value = callback(...args);
-        cache.set(args, value);
-      }
-      return value;
-    };
-  }
-  function compose(a, b, c, d, e) {
-    if (!!e) {
-      const args = [];
-      for (let i = 0; i < arguments.length; i++) {
-        args[i] = arguments[i];
-      }
-      return (t) => reduceLeft(args, (u, f) => f(u), t);
-    } else if (d) {
-      return (t) => d(c(b(a(t))));
-    } else if (c) {
-      return (t) => c(b(a(t)));
-    } else if (b) {
-      return (t) => b(a(t));
-    } else if (a) {
-      return (t) => a(t);
-    } else {
-      return (t) => t;
-    }
-  }
-  function equateValues(a, b) {
-    return a === b;
-  }
-  function equateStringsCaseInsensitive(a, b) {
-    return a === b || a !== void 0 && b !== void 0 && a.toUpperCase() === b.toUpperCase();
-  }
-  function equateStringsCaseSensitive(a, b) {
-    return equateValues(a, b);
-  }
-  function compareComparableValues(a, b) {
-    return a === b ? 0 /* EqualTo */ : a === void 0 ? -1 /* LessThan */ : b === void 0 ? 1 /* GreaterThan */ : a < b ? -1 /* LessThan */ : 1 /* GreaterThan */;
-  }
-  function compareValues(a, b) {
-    return compareComparableValues(a, b);
-  }
-  function compareTextSpans(a, b) {
-    return compareValues(a == null ? void 0 : a.start, b == null ? void 0 : b.start) || compareValues(a == null ? void 0 : a.length, b == null ? void 0 : b.length);
-  }
-  function min(items, compare) {
-    return reduceLeft(items, (x, y) => compare(x, y) === -1 /* LessThan */ ? x : y);
-  }
-  function compareStringsCaseInsensitive(a, b) {
-    if (a === b)
-      return 0 /* EqualTo */;
-    if (a === void 0)
-      return -1 /* LessThan */;
-    if (b === void 0)
-      return 1 /* GreaterThan */;
-    a = a.toUpperCase();
-    b = b.toUpperCase();
-    return a < b ? -1 /* LessThan */ : a > b ? 1 /* GreaterThan */ : 0 /* EqualTo */;
-  }
-  function compareStringsCaseInsensitiveEslintCompatible(a, b) {
-    if (a === b)
-      return 0 /* EqualTo */;
-    if (a === void 0)
-      return -1 /* LessThan */;
-    if (b === void 0)
-      return 1 /* GreaterThan */;
-    a = a.toLowerCase();
-    b = b.toLowerCase();
-    return a < b ? -1 /* LessThan */ : a > b ? 1 /* GreaterThan */ : 0 /* EqualTo */;
-  }
-  function compareStringsCaseSensitive(a, b) {
-    return compareComparableValues(a, b);
-  }
-  function getStringComparer(ignoreCase) {
-    return ignoreCase ? compareStringsCaseInsensitive : compareStringsCaseSensitive;
-  }
-  function getUILocale() {
-    return uiLocale;
-  }
-  function setUILocale(value) {
-    if (uiLocale !== value) {
-      uiLocale = value;
-      uiComparerCaseSensitive = void 0;
-    }
-  }
-  function compareStringsCaseSensitiveUI(a, b) {
-    const comparer = uiComparerCaseSensitive || (uiComparerCaseSensitive = createUIStringComparer(uiLocale));
-    return comparer(a, b);
-  }
-  function compareProperties(a, b, key, comparer) {
-    return a === b ? 0 /* EqualTo */ : a === void 0 ? -1 /* LessThan */ : b === void 0 ? 1 /* GreaterThan */ : comparer(a[key], b[key]);
-  }
-  function compareBooleans(a, b) {
-    return compareValues(a ? 1 : 0, b ? 1 : 0);
-  }
-  function getSpellingSuggestion(name, candidates, getName) {
-    const maximumLengthDifference = Math.max(2, Math.floor(name.length * 0.34));
-    let bestDistance = Math.floor(name.length * 0.4) + 1;
-    let bestCandidate;
-    for (const candidate of candidates) {
-      const candidateName = getName(candidate);
-      if (candidateName !== void 0 && Math.abs(candidateName.length - name.length) <= maximumLengthDifference) {
-        if (candidateName === name) {
-          continue;
-        }
-        if (candidateName.length < 3 && candidateName.toLowerCase() !== name.toLowerCase()) {
-          continue;
-        }
-        const distance = levenshteinWithMax(name, candidateName, bestDistance - 0.1);
-        if (distance === void 0) {
-          continue;
-        }
-        Debug.assert(distance < bestDistance);
-        bestDistance = distance;
-        bestCandidate = candidate;
-      }
-    }
-    return bestCandidate;
-  }
-  function levenshteinWithMax(s1, s2, max) {
-    let previous = new Array(s2.length + 1);
-    let current = new Array(s2.length + 1);
-    const big = max + 0.01;
-    for (let i = 0; i <= s2.length; i++) {
-      previous[i] = i;
-    }
-    for (let i = 1; i <= s1.length; i++) {
-      const c1 = s1.charCodeAt(i - 1);
-      const minJ = Math.ceil(i > max ? i - max : 1);
-      const maxJ = Math.floor(s2.length > max + i ? max + i : s2.length);
-      current[0] = i;
-      let colMin = i;
-      for (let j = 1; j < minJ; j++) {
-        current[j] = big;
-      }
-      for (let j = minJ; j <= maxJ; j++) {
-        const substitutionDistance = s1[i - 1].toLowerCase() === s2[j - 1].toLowerCase() ? previous[j - 1] + 0.1 : previous[j - 1] + 2;
-        const dist = c1 === s2.charCodeAt(j - 1) ? previous[j - 1] : Math.min(
-          /*delete*/
-          previous[j] + 1,
-          /*insert*/
-          current[j - 1] + 1,
-          /*substitute*/
-          substitutionDistance
-        );
-        current[j] = dist;
-        colMin = Math.min(colMin, dist);
-      }
-      for (let j = maxJ + 1; j <= s2.length; j++) {
-        current[j] = big;
-      }
-      if (colMin > max) {
-        return void 0;
-      }
-      const temp = previous;
-      previous = current;
-      current = temp;
-    }
-    const res = previous[s2.length];
-    return res > max ? void 0 : res;
-  }
-  function endsWith(str, suffix) {
-    const expectedPos = str.length - suffix.length;
-    return expectedPos >= 0 && str.indexOf(suffix, expectedPos) === expectedPos;
-  }
-  function removeSuffix(str, suffix) {
-    return endsWith(str, suffix) ? str.slice(0, str.length - suffix.length) : str;
-  }
-  function tryRemoveSuffix(str, suffix) {
-    return endsWith(str, suffix) ? str.slice(0, str.length - suffix.length) : void 0;
-  }
-  function stringContains(str, substring) {
-    return str.indexOf(substring) !== -1;
-  }
-  function removeMinAndVersionNumbers(fileName) {
-    let end = fileName.length;
-    for (let pos = end - 1; pos > 0; pos--) {
-      let ch = fileName.charCodeAt(pos);
-      if (ch >= 48 /* _0 */ && ch <= 57 /* _9 */) {
-        do {
-          --pos;
-          ch = fileName.charCodeAt(pos);
-        } while (pos > 0 && ch >= 48 /* _0 */ && ch <= 57 /* _9 */);
-      } else if (pos > 4 && (ch === 110 /* n */ || ch === 78 /* N */)) {
-        --pos;
-        ch = fileName.charCodeAt(pos);
-        if (ch !== 105 /* i */ && ch !== 73 /* I */) {
-          break;
-        }
-        --pos;
-        ch = fileName.charCodeAt(pos);
-        if (ch !== 109 /* m */ && ch !== 77 /* M */) {
-          break;
-        }
-        --pos;
-        ch = fileName.charCodeAt(pos);
-      } else {
-        break;
-      }
-      if (ch !== 45 /* minus */ && ch !== 46 /* dot */) {
-        break;
-      }
-      end = pos;
-    }
-    return end === fileName.length ? fileName : fileName.slice(0, end);
-  }
-  function orderedRemoveItem(array, item) {
-    for (let i = 0; i < array.length; i++) {
-      if (array[i] === item) {
-        orderedRemoveItemAt(array, i);
-        return true;
-      }
-    }
-    return false;
-  }
-  function orderedRemoveItemAt(array, index) {
-    for (let i = index; i < array.length - 1; i++) {
-      array[i] = array[i + 1];
-    }
-    array.pop();
-  }
-  function unorderedRemoveItemAt(array, index) {
-    array[index] = array[array.length - 1];
-    array.pop();
-  }
-  function unorderedRemoveItem(array, item) {
-    return unorderedRemoveFirstItemWhere(array, (element) => element === item);
-  }
-  function unorderedRemoveFirstItemWhere(array, predicate) {
-    for (let i = 0; i < array.length; i++) {
-      if (predicate(array[i])) {
-        unorderedRemoveItemAt(array, i);
-        return true;
-      }
-    }
-    return false;
-  }
-  function createGetCanonicalFileName(useCaseSensitiveFileNames) {
-    return useCaseSensitiveFileNames ? identity : toFileNameLowerCase;
-  }
-  function patternText({ prefix, suffix }) {
-    return `${prefix}*${suffix}`;
-  }
-  function matchedText(pattern, candidate) {
-    Debug.assert(isPatternMatch(pattern, candidate));
-    return candidate.substring(pattern.prefix.length, candidate.length - pattern.suffix.length);
-  }
-  function findBestPatternMatch(values, getPattern, candidate) {
-    let matchedValue;
-    let longestMatchPrefixLength = -1;
-    for (const v of values) {
-      const pattern = getPattern(v);
-      if (isPatternMatch(pattern, candidate) && pattern.prefix.length > longestMatchPrefixLength) {
-        longestMatchPrefixLength = pattern.prefix.length;
-        matchedValue = v;
-      }
-    }
-    return matchedValue;
-  }
-  function startsWith(str, prefix) {
-    return str.lastIndexOf(prefix, 0) === 0;
-  }
-  function removePrefix(str, prefix) {
-    return startsWith(str, prefix) ? str.substr(prefix.length) : str;
-  }
-  function tryRemovePrefix(str, prefix, getCanonicalFileName = identity) {
-    return startsWith(getCanonicalFileName(str), getCanonicalFileName(prefix)) ? str.substring(prefix.length) : void 0;
-  }
-  function isPatternMatch({ prefix, suffix }, candidate) {
-    return candidate.length >= prefix.length + suffix.length && startsWith(candidate, prefix) && endsWith(candidate, suffix);
-  }
-  function and(f, g) {
-    return (arg) => f(arg) && g(arg);
-  }
-  function or(...fs) {
-    return (...args) => {
-      let lastResult;
-      for (const f of fs) {
-        lastResult = f(...args);
-        if (lastResult) {
-          return lastResult;
-        }
-      }
-      return lastResult;
-    };
-  }
-  function not(fn) {
-    return (...args) => !fn(...args);
-  }
-  function assertType(_) {
-  }
-  function singleElementArray(t) {
-    return t === void 0 ? void 0 : [t];
-  }
-  function enumerateInsertsAndDeletes(newItems, oldItems, comparer, inserted, deleted, unchanged) {
-    unchanged = unchanged || noop;
-    let newIndex = 0;
-    let oldIndex = 0;
-    const newLen = newItems.length;
-    const oldLen = oldItems.length;
-    let hasChanges = false;
-    while (newIndex < newLen && oldIndex < oldLen) {
-      const newItem = newItems[newIndex];
-      const oldItem = oldItems[oldIndex];
-      const compareResult = comparer(newItem, oldItem);
-      if (compareResult === -1 /* LessThan */) {
-        inserted(newItem);
-        newIndex++;
-        hasChanges = true;
-      } else if (compareResult === 1 /* GreaterThan */) {
-        deleted(oldItem);
-        oldIndex++;
-        hasChanges = true;
-      } else {
-        unchanged(oldItem, newItem);
-        newIndex++;
-        oldIndex++;
-      }
-    }
-    while (newIndex < newLen) {
-      inserted(newItems[newIndex++]);
-      hasChanges = true;
-    }
-    while (oldIndex < oldLen) {
-      deleted(oldItems[oldIndex++]);
-      hasChanges = true;
-    }
-    return hasChanges;
-  }
-  function cartesianProduct(arrays) {
-    const result = [];
-    cartesianProductWorker(
-      arrays,
-      result,
-      /*outer*/
-      void 0,
-      0
-    );
-    return result;
-  }
-  function cartesianProductWorker(arrays, result, outer, index) {
-    for (const element of arrays[index]) {
-      let inner;
-      if (outer) {
-        inner = outer.slice();
-        inner.push(element);
-      } else {
-        inner = [element];
-      }
-      if (index === arrays.length - 1) {
-        result.push(inner);
-      } else {
-        cartesianProductWorker(arrays, result, inner, index + 1);
-      }
-    }
-  }
-  function padLeft(s, length2, padString = " ") {
-    return length2 <= s.length ? s : padString.repeat(length2 - s.length) + s;
-  }
-  function padRight(s, length2, padString = " ") {
-    return length2 <= s.length ? s : s + padString.repeat(length2 - s.length);
-  }
-  function takeWhile(array, predicate) {
-    if (array) {
-      const len = array.length;
-      let index = 0;
-      while (index < len && predicate(array[index])) {
-        index++;
-      }
-      return array.slice(0, index);
-    }
-  }
-  function skipWhile(array, predicate) {
-    if (array) {
-      const len = array.length;
-      let index = 0;
-      while (index < len && predicate(array[index])) {
-        index++;
-      }
-      return array.slice(index);
-    }
-  }
-  function trimEndImpl(s) {
-    let end = s.length - 1;
-    while (end >= 0) {
-      if (!isWhiteSpaceLike(s.charCodeAt(end)))
-        break;
-      end--;
-    }
-    return s.slice(0, end + 1);
-  }
-  function isNodeLikeSystem() {
-    return typeof process !== "undefined" && !!process.nextTick && !process.browser && "object" === "object";
-  }
-  var emptyArray, emptyMap, emptySet, SortKind, elementAt, hasOwnProperty, fileNameLowerCaseRegExp, AssertionLevel, createUIStringComparer, uiComparerCaseSensitive, uiLocale, trimString, trimStringEnd, trimStringStart;
-  var init_core = __esm({
-    "src/compiler/core.ts"() {
-      "use strict";
-      init_ts2();
-      emptyArray = [];
-      emptyMap = /* @__PURE__ */ new Map();
-      emptySet = /* @__PURE__ */ new Set();
-      SortKind = /* @__PURE__ */ ((SortKind2) => {
-        SortKind2[SortKind2["None"] = 0] = "None";
-        SortKind2[SortKind2["CaseSensitive"] = 1] = "CaseSensitive";
-        SortKind2[SortKind2["CaseInsensitive"] = 2] = "CaseInsensitive";
-        SortKind2[SortKind2["Both"] = 3] = "Both";
-        return SortKind2;
-      })(SortKind || {});
-      elementAt = !!Array.prototype.at ? (array, offset) => array == null ? void 0 : array.at(offset) : (array, offset) => {
-        if (array) {
-          offset = toOffset(array, offset);
-          if (offset < array.length) {
-            return array[offset];
-          }
-        }
-        return void 0;
-      };
-      hasOwnProperty = Object.prototype.hasOwnProperty;
-      fileNameLowerCaseRegExp = /[^\u0130\u0131\u00DFa-z0-9\\/:\-_\. ]+/g;
-      AssertionLevel = /* @__PURE__ */ ((AssertionLevel2) => {
-        AssertionLevel2[AssertionLevel2["None"] = 0] = "None";
-        AssertionLevel2[AssertionLevel2["Normal"] = 1] = "Normal";
-        AssertionLevel2[AssertionLevel2["Aggressive"] = 2] = "Aggressive";
-        AssertionLevel2[AssertionLevel2["VeryAggressive"] = 3] = "VeryAggressive";
-        return AssertionLevel2;
-      })(AssertionLevel || {});
-      createUIStringComparer = (() => {
-        let defaultComparer;
-        let enUSComparer;
-        const stringComparerFactory = getStringComparerFactory();
-        return createStringComparer;
-        function compareWithCallback(a, b, comparer) {
-          if (a === b)
-            return 0 /* EqualTo */;
-          if (a === void 0)
-            return -1 /* LessThan */;
-          if (b === void 0)
-            return 1 /* GreaterThan */;
-          const value = comparer(a, b);
-          return value < 0 ? -1 /* LessThan */ : value > 0 ? 1 /* GreaterThan */ : 0 /* EqualTo */;
-        }
-        function createIntlCollatorStringComparer(locale) {
-          const comparer = new Intl.Collator(locale, { usage: "sort", sensitivity: "variant" }).compare;
-          return (a, b) => compareWithCallback(a, b, comparer);
-        }
-        function createLocaleCompareStringComparer(locale) {
-          if (locale !== void 0)
-            return createFallbackStringComparer();
-          return (a, b) => compareWithCallback(a, b, compareStrings);
-          function compareStrings(a, b) {
-            return a.localeCompare(b);
-          }
-        }
-        function createFallbackStringComparer() {
-          return (a, b) => compareWithCallback(a, b, compareDictionaryOrder);
-          function compareDictionaryOrder(a, b) {
-            return compareStrings(a.toUpperCase(), b.toUpperCase()) || compareStrings(a, b);
-          }
-          function compareStrings(a, b) {
-            return a < b ? -1 /* LessThan */ : a > b ? 1 /* GreaterThan */ : 0 /* EqualTo */;
-          }
-        }
-        function getStringComparerFactory() {
-          if (typeof Intl === "object" && typeof Intl.Collator === "function") {
-            return createIntlCollatorStringComparer;
-          }
-          if (typeof String.prototype.localeCompare === "function" && typeof String.prototype.toLocaleUpperCase === "function" && "a".localeCompare("B") < 0) {
-            return createLocaleCompareStringComparer;
-          }
-          return createFallbackStringComparer;
-        }
-        function createStringComparer(locale) {
-          if (locale === void 0) {
-            return defaultComparer || (defaultComparer = stringComparerFactory(locale));
-          } else if (locale === "en-US") {
-            return enUSComparer || (enUSComparer = stringComparerFactory(locale));
-          } else {
-            return stringComparerFactory(locale);
-          }
-        }
-      })();
-      trimString = !!String.prototype.trim ? (s) => s.trim() : (s) => trimStringEnd(trimStringStart(s));
-      trimStringEnd = !!String.prototype.trimEnd ? (s) => s.trimEnd() : trimEndImpl;
-      trimStringStart = !!String.prototype.trimStart ? (s) => s.trimStart() : (s) => s.replace(/^\s+/g, "");
-    }
-  });
-
-  // src/compiler/debug.ts
-  var LogLevel, Debug;
-  var init_debug = __esm({
-    "src/compiler/debug.ts"() {
-      "use strict";
-      init_ts2();
-      init_ts2();
-      LogLevel = /* @__PURE__ */ ((LogLevel2) => {
-        LogLevel2[LogLevel2["Off"] = 0] = "Off";
-        LogLevel2[LogLevel2["Error"] = 1] = "Error";
-        LogLevel2[LogLevel2["Warning"] = 2] = "Warning";
-        LogLevel2[LogLevel2["Info"] = 3] = "Info";
-        LogLevel2[LogLevel2["Verbose"] = 4] = "Verbose";
-        return LogLevel2;
-      })(LogLevel || {});
-      ((Debug2) => {
-        let currentAssertionLevel = 0 /* None */;
-        Debug2.currentLogLevel = 2 /* Warning */;
-        Debug2.isDebugging = false;
-        function shouldLog(level) {
-          return Debug2.currentLogLevel <= level;
-        }
-        Debug2.shouldLog = shouldLog;
-        function logMessage(level, s) {
-          if (Debug2.loggingHost && shouldLog(level)) {
-            Debug2.loggingHost.log(level, s);
-          }
-        }
-        function log(s) {
-          logMessage(3 /* Info */, s);
-        }
-        Debug2.log = log;
-        ((_log) => {
-          function error(s) {
-            logMessage(1 /* Error */, s);
-          }
-          _log.error = error;
-          function warn(s) {
-            logMessage(2 /* Warning */, s);
-          }
-          _log.warn = warn;
-          function log2(s) {
-            logMessage(3 /* Info */, s);
-          }
-          _log.log = log2;
-          function trace2(s) {
-            logMessage(4 /* Verbose */, s);
-          }
-          _log.trace = trace2;
-        })(log = Debug2.log || (Debug2.log = {}));
-        const assertionCache = {};
-        function getAssertionLevel() {
-          return currentAssertionLevel;
-        }
-        Debug2.getAssertionLevel = getAssertionLevel;
-        function setAssertionLevel(level) {
-          const prevAssertionLevel = currentAssertionLevel;
-          currentAssertionLevel = level;
-          if (level > prevAssertionLevel) {
-            for (const key of getOwnKeys(assertionCache)) {
-              const cachedFunc = assertionCache[key];
-              if (cachedFunc !== void 0 && Debug2[key] !== cachedFunc.assertion && level >= cachedFunc.level) {
-                Debug2[key] = cachedFunc;
-                assertionCache[key] = void 0;
-              }
-            }
-          }
-        }
-        Debug2.setAssertionLevel = setAssertionLevel;
-        function shouldAssert(level) {
-          return currentAssertionLevel >= level;
-        }
-        Debug2.shouldAssert = shouldAssert;
-        function shouldAssertFunction(level, name) {
-          if (!shouldAssert(level)) {
-            assertionCache[name] = { level, assertion: Debug2[name] };
-            Debug2[name] = noop;
-            return false;
-          }
-          return true;
-        }
-        function fail(message, stackCrawlMark) {
-          debugger;
-          const e = new Error(message ? `Debug Failure. ${message}` : "Debug Failure.");
-          if (Error.captureStackTrace) {
-            Error.captureStackTrace(e, stackCrawlMark || fail);
-          }
-          throw e;
-        }
-        Debug2.fail = fail;
-        function failBadSyntaxKind(node, message, stackCrawlMark) {
-          return fail(
-            `${message || "Unexpected node."}\r
-Node ${formatSyntaxKind(node.kind)} was unexpected.`,
-            stackCrawlMark || failBadSyntaxKind
-          );
-        }
-        Debug2.failBadSyntaxKind = failBadSyntaxKind;
-        function assert(expression, message, verboseDebugInfo, stackCrawlMark) {
-          if (!expression) {
-            message = message ? `False expression: ${message}` : "False expression.";
-            if (verboseDebugInfo) {
-              message += "\r\nVerbose Debug Information: " + (typeof verboseDebugInfo === "string" ? verboseDebugInfo : verboseDebugInfo());
-            }
-            fail(message, stackCrawlMark || assert);
-          }
-        }
-        Debug2.assert = assert;
-        function assertEqual(a, b, msg, msg2, stackCrawlMark) {
-          if (a !== b) {
-            const message = msg ? msg2 ? `${msg} ${msg2}` : msg : "";
-            fail(`Expected ${a} === ${b}. ${message}`, stackCrawlMark || assertEqual);
-          }
-        }
-        Debug2.assertEqual = assertEqual;
-        function assertLessThan(a, b, msg, stackCrawlMark) {
-          if (a >= b) {
-            fail(`Expected ${a} < ${b}. ${msg || ""}`, stackCrawlMark || assertLessThan);
-          }
-        }
-        Debug2.assertLessThan = assertLessThan;
-        function assertLessThanOrEqual(a, b, stackCrawlMark) {
-          if (a > b) {
-            fail(`Expected ${a} <= ${b}`, stackCrawlMark || assertLessThanOrEqual);
-          }
-        }
-        Debug2.assertLessThanOrEqual = assertLessThanOrEqual;
-        function assertGreaterThanOrEqual(a, b, stackCrawlMark) {
-          if (a < b) {
-            fail(`Expected ${a} >= ${b}`, stackCrawlMark || assertGreaterThanOrEqual);
-          }
-        }
-        Debug2.assertGreaterThanOrEqual = assertGreaterThanOrEqual;
-        function assertIsDefined(value, message, stackCrawlMark) {
-          if (value === void 0 || value === null) {
-            fail(message, stackCrawlMark || assertIsDefined);
-          }
-        }
-        Debug2.assertIsDefined = assertIsDefined;
-        function checkDefined(value, message, stackCrawlMark) {
-          assertIsDefined(value, message, stackCrawlMark || checkDefined);
-          return value;
-        }
-        Debug2.checkDefined = checkDefined;
-        function assertEachIsDefined(value, message, stackCrawlMark) {
-          for (const v of value) {
-            assertIsDefined(v, message, stackCrawlMark || assertEachIsDefined);
-          }
-        }
-        Debug2.assertEachIsDefined = assertEachIsDefined;
-        function checkEachDefined(value, message, stackCrawlMark) {
-          assertEachIsDefined(value, message, stackCrawlMark || checkEachDefined);
-          return value;
-        }
-        Debug2.checkEachDefined = checkEachDefined;
-        function assertNever(member, message = "Illegal value:", stackCrawlMark) {
-          const detail = typeof member === "object" && hasProperty(member, "kind") && hasProperty(member, "pos") ? "SyntaxKind: " + formatSyntaxKind(member.kind) : JSON.stringify(member);
-          return fail(`${message} ${detail}`, stackCrawlMark || assertNever);
-        }
-        Debug2.assertNever = assertNever;
-        function assertEachNode(nodes, test, message, stackCrawlMark) {
-          if (shouldAssertFunction(1 /* Normal */, "assertEachNode")) {
-            assert(
-              test === void 0 || every(nodes, test),
-              message || "Unexpected node.",
-              () => `Node array did not pass test '${getFunctionName(test)}'.`,
-              stackCrawlMark || assertEachNode
-            );
-          }
-        }
-        Debug2.assertEachNode = assertEachNode;
-        function assertNode(node, test, message, stackCrawlMark) {
-          if (shouldAssertFunction(1 /* Normal */, "assertNode")) {
-            assert(
-              node !== void 0 && (test === void 0 || test(node)),
-              message || "Unexpected node.",
-              () => `Node ${formatSyntaxKind(node == null ? void 0 : node.kind)} did not pass test '${getFunctionName(test)}'.`,
-              stackCrawlMark || assertNode
-            );
-          }
-        }
-        Debug2.assertNode = assertNode;
-        function assertNotNode(node, test, message, stackCrawlMark) {
-          if (shouldAssertFunction(1 /* Normal */, "assertNotNode")) {
-            assert(
-              node === void 0 || test === void 0 || !test(node),
-              message || "Unexpected node.",
-              () => `Node ${formatSyntaxKind(node.kind)} should not have passed test '${getFunctionName(test)}'.`,
-              stackCrawlMark || assertNotNode
-            );
-          }
-        }
-        Debug2.assertNotNode = assertNotNode;
-        function assertOptionalNode(node, test, message, stackCrawlMark) {
-          if (shouldAssertFunction(1 /* Normal */, "assertOptionalNode")) {
-            assert(
-              test === void 0 || node === void 0 || test(node),
-              message || "Unexpected node.",
-              () => `Node ${formatSyntaxKind(node == null ? void 0 : node.kind)} did not pass test '${getFunctionName(test)}'.`,
-              stackCrawlMark || assertOptionalNode
-            );
-          }
-        }
-        Debug2.assertOptionalNode = assertOptionalNode;
-        function assertOptionalToken(node, kind, message, stackCrawlMark) {
-          if (shouldAssertFunction(1 /* Normal */, "assertOptionalToken")) {
-            assert(
-              kind === void 0 || node === void 0 || node.kind === kind,
-              message || "Unexpected node.",
-              () => `Node ${formatSyntaxKind(node == null ? void 0 : node.kind)} was not a '${formatSyntaxKind(kind)}' token.`,
-              stackCrawlMark || assertOptionalToken
-            );
-          }
-        }
-        Debug2.assertOptionalToken = assertOptionalToken;
-        function assertMissingNode(node, message, stackCrawlMark) {
-          if (shouldAssertFunction(1 /* Normal */, "assertMissingNode")) {
-            assert(
-              node === void 0,
-              message || "Unexpected node.",
-              () => `Node ${formatSyntaxKind(node.kind)} was unexpected'.`,
-              stackCrawlMark || assertMissingNode
-            );
-          }
-        }
-        Debug2.assertMissingNode = assertMissingNode;
-        function type(_value) {
-        }
-        Debug2.type = type;
-        function getFunctionName(func) {
-          if (typeof func !== "function") {
-            return "";
-          } else if (hasProperty(func, "name")) {
-            return func.name;
-          } else {
-            const text = Function.prototype.toString.call(func);
-            const match = /^function\s+([\w\$]+)\s*\(/.exec(text);
-            return match ? match[1] : "";
-          }
-        }
-        Debug2.getFunctionName = getFunctionName;
-        function formatSymbol(symbol) {
-          return `{ name: ${unescapeLeadingUnderscores(symbol.escapedName)}; flags: ${formatSymbolFlags(symbol.flags)}; declarations: ${map(symbol.declarations, (node) => formatSyntaxKind(node.kind))} }`;
-        }
-        Debug2.formatSymbol = formatSymbol;
-        function formatEnum(value = 0, enumObject, isFlags) {
-          const members = getEnumMembers(enumObject);
-          if (value === 0) {
-            return members.length > 0 && members[0][0] === 0 ? members[0][1] : "0";
-          }
-          if (isFlags) {
-            const result = [];
-            let remainingFlags = value;
-            for (const [enumValue, enumName] of members) {
-              if (enumValue > value) {
-                break;
-              }
-              if (enumValue !== 0 && enumValue & value) {
-                result.push(enumName);
-                remainingFlags &= ~enumValue;
-              }
-            }
-            if (remainingFlags === 0) {
-              return result.join("|");
-            }
-          } else {
-            for (const [enumValue, enumName] of members) {
-              if (enumValue === value) {
-                return enumName;
-              }
-            }
-          }
-          return value.toString();
-        }
-        Debug2.formatEnum = formatEnum;
-        const enumMemberCache = /* @__PURE__ */ new Map();
-        function getEnumMembers(enumObject) {
-          const existing = enumMemberCache.get(enumObject);
-          if (existing) {
-            return existing;
-          }
-          const result = [];
-          for (const name in enumObject) {
-            const value = enumObject[name];
-            if (typeof value === "number") {
-              result.push([value, name]);
-            }
-          }
-          const sorted = stableSort(result, (x, y) => compareValues(x[0], y[0]));
-          enumMemberCache.set(enumObject, sorted);
-          return sorted;
-        }
-        function formatSyntaxKind(kind) {
-          return formatEnum(
-            kind,
-            SyntaxKind,
-            /*isFlags*/
-            false
-          );
-        }
-        Debug2.formatSyntaxKind = formatSyntaxKind;
-        function formatSnippetKind(kind) {
-          return formatEnum(
-            kind,
-            SnippetKind,
-            /*isFlags*/
-            false
-          );
-        }
-        Debug2.formatSnippetKind = formatSnippetKind;
-        function formatNodeFlags(flags) {
-          return formatEnum(
-            flags,
-            NodeFlags,
-            /*isFlags*/
-            true
-          );
-        }
-        Debug2.formatNodeFlags = formatNodeFlags;
-        function formatModifierFlags(flags) {
-          return formatEnum(
-            flags,
-            ModifierFlags,
-            /*isFlags*/
-            true
-          );
-        }
-        Debug2.formatModifierFlags = formatModifierFlags;
-        function formatTransformFlags(flags) {
-          return formatEnum(
-            flags,
-            TransformFlags,
-            /*isFlags*/
-            true
-          );
-        }
-        Debug2.formatTransformFlags = formatTransformFlags;
-        function formatEmitFlags(flags) {
-          return formatEnum(
-            flags,
-            EmitFlags,
-            /*isFlags*/
-            true
-          );
-        }
-        Debug2.formatEmitFlags = formatEmitFlags;
-        function formatSymbolFlags(flags) {
-          return formatEnum(
-            flags,
-            SymbolFlags,
-            /*isFlags*/
-            true
-          );
-        }
-        Debug2.formatSymbolFlags = formatSymbolFlags;
-        function formatTypeFlags(flags) {
-          return formatEnum(
-            flags,
-            TypeFlags,
-            /*isFlags*/
-            true
-          );
-        }
-        Debug2.formatTypeFlags = formatTypeFlags;
-        function formatSignatureFlags(flags) {
-          return formatEnum(
-            flags,
-            SignatureFlags,
-            /*isFlags*/
-            true
-          );
-        }
-        Debug2.formatSignatureFlags = formatSignatureFlags;
-        function formatObjectFlags(flags) {
-          return formatEnum(
-            flags,
-            ObjectFlags,
-            /*isFlags*/
-            true
-          );
-        }
-        Debug2.formatObjectFlags = formatObjectFlags;
-        function formatFlowFlags(flags) {
-          return formatEnum(
-            flags,
-            FlowFlags,
-            /*isFlags*/
-            true
-          );
-        }
-        Debug2.formatFlowFlags = formatFlowFlags;
-        function formatRelationComparisonResult(result) {
-          return formatEnum(
-            result,
-            RelationComparisonResult,
-            /*isFlags*/
-            true
-          );
-        }
-        Debug2.formatRelationComparisonResult = formatRelationComparisonResult;
-        function formatCheckMode(mode) {
-          return formatEnum(
-            mode,
-            CheckMode,
-            /*isFlags*/
-            true
-          );
-        }
-        Debug2.formatCheckMode = formatCheckMode;
-        function formatSignatureCheckMode(mode) {
-          return formatEnum(
-            mode,
-            SignatureCheckMode,
-            /*isFlags*/
-            true
-          );
-        }
-        Debug2.formatSignatureCheckMode = formatSignatureCheckMode;
-        function formatTypeFacts(facts) {
-          return formatEnum(
-            facts,
-            TypeFacts,
-            /*isFlags*/
-            true
-          );
-        }
-        Debug2.formatTypeFacts = formatTypeFacts;
-        let isDebugInfoEnabled = false;
-        let flowNodeProto;
-        function attachFlowNodeDebugInfoWorker(flowNode) {
-          if (!("__debugFlowFlags" in flowNode)) {
-            Object.defineProperties(flowNode, {
-              // for use with vscode-js-debug's new customDescriptionGenerator in launch.json
-              __tsDebuggerDisplay: {
-                value() {
-                  const flowHeader = this.flags & 2 /* Start */ ? "FlowStart" : this.flags & 4 /* BranchLabel */ ? "FlowBranchLabel" : this.flags & 8 /* LoopLabel */ ? "FlowLoopLabel" : this.flags & 16 /* Assignment */ ? "FlowAssignment" : this.flags & 32 /* TrueCondition */ ? "FlowTrueCondition" : this.flags & 64 /* FalseCondition */ ? "FlowFalseCondition" : this.flags & 128 /* SwitchClause */ ? "FlowSwitchClause" : this.flags & 256 /* ArrayMutation */ ? "FlowArrayMutation" : this.flags & 512 /* Call */ ? "FlowCall" : this.flags & 1024 /* ReduceLabel */ ? "FlowReduceLabel" : this.flags & 1 /* Unreachable */ ? "FlowUnreachable" : "UnknownFlow";
-                  const remainingFlags = this.flags & ~(2048 /* Referenced */ - 1);
-                  return `${flowHeader}${remainingFlags ? ` (${formatFlowFlags(remainingFlags)})` : ""}`;
-                }
-              },
-              __debugFlowFlags: { get() {
-                return formatEnum(
-                  this.flags,
-                  FlowFlags,
-                  /*isFlags*/
-                  true
-                );
-              } },
-              __debugToString: { value() {
-                return formatControlFlowGraph(this);
-              } }
-            });
-          }
-        }
-        function attachFlowNodeDebugInfo(flowNode) {
-          if (isDebugInfoEnabled) {
-            if (typeof Object.setPrototypeOf === "function") {
-              if (!flowNodeProto) {
-                flowNodeProto = Object.create(Object.prototype);
-                attachFlowNodeDebugInfoWorker(flowNodeProto);
-              }
-              Object.setPrototypeOf(flowNode, flowNodeProto);
-            } else {
-              attachFlowNodeDebugInfoWorker(flowNode);
-            }
-          }
-        }
-        Debug2.attachFlowNodeDebugInfo = attachFlowNodeDebugInfo;
-        let nodeArrayProto;
-        function attachNodeArrayDebugInfoWorker(array) {
-          if (!("__tsDebuggerDisplay" in array)) {
-            Object.defineProperties(array, {
-              __tsDebuggerDisplay: {
-                value(defaultValue) {
-                  defaultValue = String(defaultValue).replace(/(?:,[\s\w\d_]+:[^,]+)+\]$/, "]");
-                  return `NodeArray ${defaultValue}`;
-                }
-              }
-            });
-          }
-        }
-        function attachNodeArrayDebugInfo(array) {
-          if (isDebugInfoEnabled) {
-            if (typeof Object.setPrototypeOf === "function") {
-              if (!nodeArrayProto) {
-                nodeArrayProto = Object.create(Array.prototype);
-                attachNodeArrayDebugInfoWorker(nodeArrayProto);
-              }
-              Object.setPrototypeOf(array, nodeArrayProto);
-            } else {
-              attachNodeArrayDebugInfoWorker(array);
-            }
-          }
-        }
-        Debug2.attachNodeArrayDebugInfo = attachNodeArrayDebugInfo;
-        function enableDebugInfo() {
-          if (isDebugInfoEnabled)
-            return;
-          const weakTypeTextMap = /* @__PURE__ */ new WeakMap();
-          const weakNodeTextMap = /* @__PURE__ */ new WeakMap();
-          Object.defineProperties(objectAllocator.getSymbolConstructor().prototype, {
-            // for use with vscode-js-debug's new customDescriptionGenerator in launch.json
-            __tsDebuggerDisplay: {
-              value() {
-                const symbolHeader = this.flags & 33554432 /* Transient */ ? "TransientSymbol" : "Symbol";
-                const remainingSymbolFlags = this.flags & ~33554432 /* Transient */;
-                return `${symbolHeader} '${symbolName(this)}'${remainingSymbolFlags ? ` (${formatSymbolFlags(remainingSymbolFlags)})` : ""}`;
-              }
-            },
-            __debugFlags: { get() {
-              return formatSymbolFlags(this.flags);
-            } }
-          });
-          Object.defineProperties(objectAllocator.getTypeConstructor().prototype, {
-            // for use with vscode-js-debug's new customDescriptionGenerator in launch.json
-            __tsDebuggerDisplay: {
-              value() {
-                const typeHeader = this.flags & 98304 /* Nullable */ ? "NullableType" : this.flags & 384 /* StringOrNumberLiteral */ ? `LiteralType ${JSON.stringify(this.value)}` : this.flags & 2048 /* BigIntLiteral */ ? `LiteralType ${this.value.negative ? "-" : ""}${this.value.base10Value}n` : this.flags & 8192 /* UniqueESSymbol */ ? "UniqueESSymbolType" : this.flags & 32 /* Enum */ ? "EnumType" : this.flags & 67359327 /* Intrinsic */ ? `IntrinsicType ${this.intrinsicName}` : this.flags & 1048576 /* Union */ ? "UnionType" : this.flags & 2097152 /* Intersection */ ? "IntersectionType" : this.flags & 4194304 /* Index */ ? "IndexType" : this.flags & 8388608 /* IndexedAccess */ ? "IndexedAccessType" : this.flags & 16777216 /* Conditional */ ? "ConditionalType" : this.flags & 33554432 /* Substitution */ ? "SubstitutionType" : this.flags & 262144 /* TypeParameter */ ? "TypeParameter" : this.flags & 524288 /* Object */ ? this.objectFlags & 3 /* ClassOrInterface */ ? "InterfaceType" : this.objectFlags & 4 /* Reference */ ? "TypeReference" : this.objectFlags & 8 /* Tuple */ ? "TupleType" : this.objectFlags & 16 /* Anonymous */ ? "AnonymousType" : this.objectFlags & 32 /* Mapped */ ? "MappedType" : this.objectFlags & 1024 /* ReverseMapped */ ? "ReverseMappedType" : this.objectFlags & 256 /* EvolvingArray */ ? "EvolvingArrayType" : "ObjectType" : "Type";
-                const remainingObjectFlags = this.flags & 524288 /* Object */ ? this.objectFlags & ~1343 /* ObjectTypeKindMask */ : 0;
-                return `${typeHeader}${this.symbol ? ` '${symbolName(this.symbol)}'` : ""}${remainingObjectFlags ? ` (${formatObjectFlags(remainingObjectFlags)})` : ""}`;
-              }
-            },
-            __debugFlags: { get() {
-              return formatTypeFlags(this.flags);
-            } },
-            __debugObjectFlags: { get() {
-              return this.flags & 524288 /* Object */ ? formatObjectFlags(this.objectFlags) : "";
-            } },
-            __debugTypeToString: {
-              value() {
-                let text = weakTypeTextMap.get(this);
-                if (text === void 0) {
-                  text = this.checker.typeToString(this);
-                  weakTypeTextMap.set(this, text);
-                }
-                return text;
-              }
-            }
-          });
-          Object.defineProperties(objectAllocator.getSignatureConstructor().prototype, {
-            __debugFlags: { get() {
-              return formatSignatureFlags(this.flags);
-            } },
-            __debugSignatureToString: { value() {
-              var _a;
-              return (_a = this.checker) == null ? void 0 : _a.signatureToString(this);
-            } }
-          });
-          const nodeConstructors = [
-            objectAllocator.getNodeConstructor(),
-            objectAllocator.getIdentifierConstructor(),
-            objectAllocator.getTokenConstructor(),
-            objectAllocator.getSourceFileConstructor()
-          ];
-          for (const ctor of nodeConstructors) {
-            if (!hasProperty(ctor.prototype, "__debugKind")) {
-              Object.defineProperties(ctor.prototype, {
-                // for use with vscode-js-debug's new customDescriptionGenerator in launch.json
-                __tsDebuggerDisplay: {
-                  value() {
-                    const nodeHeader = isGeneratedIdentifier(this) ? "GeneratedIdentifier" : isIdentifier(this) ? `Identifier '${idText(this)}'` : isPrivateIdentifier(this) ? `PrivateIdentifier '${idText(this)}'` : isStringLiteral(this) ? `StringLiteral ${JSON.stringify(this.text.length < 10 ? this.text : this.text.slice(10) + "...")}` : isNumericLiteral(this) ? `NumericLiteral ${this.text}` : isBigIntLiteral(this) ? `BigIntLiteral ${this.text}n` : isTypeParameterDeclaration(this) ? "TypeParameterDeclaration" : isParameter(this) ? "ParameterDeclaration" : isConstructorDeclaration(this) ? "ConstructorDeclaration" : isGetAccessorDeclaration(this) ? "GetAccessorDeclaration" : isSetAccessorDeclaration(this) ? "SetAccessorDeclaration" : isCallSignatureDeclaration(this) ? "CallSignatureDeclaration" : isConstructSignatureDeclaration(this) ? "ConstructSignatureDeclaration" : isIndexSignatureDeclaration(this) ? "IndexSignatureDeclaration" : isTypePredicateNode(this) ? "TypePredicateNode" : isTypeReferenceNode(this) ? "TypeReferenceNode" : isFunctionTypeNode(this) ? "FunctionTypeNode" : isConstructorTypeNode(this) ? "ConstructorTypeNode" : isTypeQueryNode(this) ? "TypeQueryNode" : isTypeLiteralNode(this) ? "TypeLiteralNode" : isArrayTypeNode(this) ? "ArrayTypeNode" : isTupleTypeNode(this) ? "TupleTypeNode" : isOptionalTypeNode(this) ? "OptionalTypeNode" : isRestTypeNode(this) ? "RestTypeNode" : isUnionTypeNode(this) ? "UnionTypeNode" : isIntersectionTypeNode(this) ? "IntersectionTypeNode" : isConditionalTypeNode(this) ? "ConditionalTypeNode" : isInferTypeNode(this) ? "InferTypeNode" : isParenthesizedTypeNode(this) ? "ParenthesizedTypeNode" : isThisTypeNode(this) ? "ThisTypeNode" : isTypeOperatorNode(this) ? "TypeOperatorNode" : isIndexedAccessTypeNode(this) ? "IndexedAccessTypeNode" : isMappedTypeNode(this) ? "MappedTypeNode" : isLiteralTypeNode(this) ? "LiteralTypeNode" : isNamedTupleMember(this) ? "NamedTupleMember" : isImportTypeNode(this) ? "ImportTypeNode" : formatSyntaxKind(this.kind);
-                    return `${nodeHeader}${this.flags ? ` (${formatNodeFlags(this.flags)})` : ""}`;
-                  }
-                },
-                __debugKind: { get() {
-                  return formatSyntaxKind(this.kind);
-                } },
-                __debugNodeFlags: { get() {
-                  return formatNodeFlags(this.flags);
-                } },
-                __debugModifierFlags: { get() {
-                  return formatModifierFlags(getEffectiveModifierFlagsNoCache(this));
-                } },
-                __debugTransformFlags: { get() {
-                  return formatTransformFlags(this.transformFlags);
-                } },
-                __debugIsParseTreeNode: { get() {
-                  return isParseTreeNode(this);
-                } },
-                __debugEmitFlags: { get() {
-                  return formatEmitFlags(getEmitFlags(this));
-                } },
-                __debugGetText: {
-                  value(includeTrivia) {
-                    if (nodeIsSynthesized(this))
-                      return "";
-                    let text = weakNodeTextMap.get(this);
-                    if (text === void 0) {
-                      const parseNode = getParseTreeNode(this);
-                      const sourceFile = parseNode && getSourceFileOfNode(parseNode);
-                      text = sourceFile ? getSourceTextOfNodeFromSourceFile(sourceFile, parseNode, includeTrivia) : "";
-                      weakNodeTextMap.set(this, text);
-                    }
-                    return text;
-                  }
-                }
-              });
-            }
-          }
-          isDebugInfoEnabled = true;
-        }
-        Debug2.enableDebugInfo = enableDebugInfo;
-        function formatVariance(varianceFlags) {
-          const variance = varianceFlags & 7 /* VarianceMask */;
-          let result = variance === 0 /* Invariant */ ? "in out" : variance === 3 /* Bivariant */ ? "[bivariant]" : variance === 2 /* Contravariant */ ? "in" : variance === 1 /* Covariant */ ? "out" : variance === 4 /* Independent */ ? "[independent]" : "";
-          if (varianceFlags & 8 /* Unmeasurable */) {
-            result += " (unmeasurable)";
-          } else if (varianceFlags & 16 /* Unreliable */) {
-            result += " (unreliable)";
-          }
-          return result;
-        }
-        Debug2.formatVariance = formatVariance;
-        class DebugTypeMapper {
-          __debugToString() {
-            var _a;
-            type(this);
-            switch (this.kind) {
-              case 3 /* Function */:
-                return ((_a = this.debugInfo) == null ? void 0 : _a.call(this)) || "(function mapper)";
-              case 0 /* Simple */:
-                return `${this.source.__debugTypeToString()} -> ${this.target.__debugTypeToString()}`;
-              case 1 /* Array */:
-                return zipWith(
-                  this.sources,
-                  this.targets || map(this.sources, () => "any"),
-                  (s, t) => `${s.__debugTypeToString()} -> ${typeof t === "string" ? t : t.__debugTypeToString()}`
-                ).join(", ");
-              case 2 /* Deferred */:
-                return zipWith(
-                  this.sources,
-                  this.targets,
-                  (s, t) => `${s.__debugTypeToString()} -> ${t().__debugTypeToString()}`
-                ).join(", ");
-              case 5 /* Merged */:
-              case 4 /* Composite */:
-                return `m1: ${this.mapper1.__debugToString().split("\n").join("\n    ")}
-m2: ${this.mapper2.__debugToString().split("\n").join("\n    ")}`;
-              default:
-                return assertNever(this);
-            }
-          }
-        }
-        Debug2.DebugTypeMapper = DebugTypeMapper;
-        function attachDebugPrototypeIfDebug(mapper) {
-          if (Debug2.isDebugging) {
-            return Object.setPrototypeOf(mapper, DebugTypeMapper.prototype);
-          }
-          return mapper;
-        }
-        Debug2.attachDebugPrototypeIfDebug = attachDebugPrototypeIfDebug;
-        function printControlFlowGraph(flowNode) {
-          return console.log(formatControlFlowGraph(flowNode));
-        }
-        Debug2.printControlFlowGraph = printControlFlowGraph;
-        function formatControlFlowGraph(flowNode) {
-          let nextDebugFlowId = -1;
-          function getDebugFlowNodeId(f) {
-            if (!f.id) {
-              f.id = nextDebugFlowId;
-              nextDebugFlowId--;
-            }
-            return f.id;
-          }
-          let BoxCharacter;
-          ((BoxCharacter2) => {
-            BoxCharacter2["lr"] = "\u2500";
-            BoxCharacter2["ud"] = "\u2502";
-            BoxCharacter2["dr"] = "\u256D";
-            BoxCharacter2["dl"] = "\u256E";
-            BoxCharacter2["ul"] = "\u256F";
-            BoxCharacter2["ur"] = "\u2570";
-            BoxCharacter2["udr"] = "\u251C";
-            BoxCharacter2["udl"] = "\u2524";
-            BoxCharacter2["dlr"] = "\u252C";
-            BoxCharacter2["ulr"] = "\u2534";
-            BoxCharacter2["udlr"] = "\u256B";
-          })(BoxCharacter || (BoxCharacter = {}));
-          let Connection;
-          ((Connection2) => {
-            Connection2[Connection2["None"] = 0] = "None";
-            Connection2[Connection2["Up"] = 1] = "Up";
-            Connection2[Connection2["Down"] = 2] = "Down";
-            Connection2[Connection2["Left"] = 4] = "Left";
-            Connection2[Connection2["Right"] = 8] = "Right";
-            Connection2[Connection2["UpDown"] = 3] = "UpDown";
-            Connection2[Connection2["LeftRight"] = 12] = "LeftRight";
-            Connection2[Connection2["UpLeft"] = 5] = "UpLeft";
-            Connection2[Connection2["UpRight"] = 9] = "UpRight";
-            Connection2[Connection2["DownLeft"] = 6] = "DownLeft";
-            Connection2[Connection2["DownRight"] = 10] = "DownRight";
-            Connection2[Connection2["UpDownLeft"] = 7] = "UpDownLeft";
-            Connection2[Connection2["UpDownRight"] = 11] = "UpDownRight";
-            Connection2[Connection2["UpLeftRight"] = 13] = "UpLeftRight";
-            Connection2[Connection2["DownLeftRight"] = 14] = "DownLeftRight";
-            Connection2[Connection2["UpDownLeftRight"] = 15] = "UpDownLeftRight";
-            Connection2[Connection2["NoChildren"] = 16] = "NoChildren";
-          })(Connection || (Connection = {}));
-          const hasAntecedentFlags = 16 /* Assignment */ | 96 /* Condition */ | 128 /* SwitchClause */ | 256 /* ArrayMutation */ | 512 /* Call */ | 1024 /* ReduceLabel */;
-          const hasNodeFlags = 2 /* Start */ | 16 /* Assignment */ | 512 /* Call */ | 96 /* Condition */ | 256 /* ArrayMutation */;
-          const links = /* @__PURE__ */ Object.create(
-            /*o*/
-            null
-          );
-          const nodes = [];
-          const edges = [];
-          const root = buildGraphNode(flowNode, /* @__PURE__ */ new Set());
-          for (const node of nodes) {
-            node.text = renderFlowNode(node.flowNode, node.circular);
-            computeLevel(node);
-          }
-          const height = computeHeight(root);
-          const columnWidths = computeColumnWidths(height);
-          computeLanes(root, 0);
-          return renderGraph();
-          function isFlowSwitchClause(f) {
-            return !!(f.flags & 128 /* SwitchClause */);
-          }
-          function hasAntecedents(f) {
-            return !!(f.flags & 12 /* Label */) && !!f.antecedents;
-          }
-          function hasAntecedent(f) {
-            return !!(f.flags & hasAntecedentFlags);
-          }
-          function hasNode(f) {
-            return !!(f.flags & hasNodeFlags);
-          }
-          function getChildren(node) {
-            const children = [];
-            for (const edge of node.edges) {
-              if (edge.source === node) {
-                children.push(edge.target);
-              }
-            }
-            return children;
-          }
-          function getParents(node) {
-            const parents = [];
-            for (const edge of node.edges) {
-              if (edge.target === node) {
-                parents.push(edge.source);
-              }
-            }
-            return parents;
-          }
-          function buildGraphNode(flowNode2, seen) {
-            const id = getDebugFlowNodeId(flowNode2);
-            let graphNode = links[id];
-            if (graphNode && seen.has(flowNode2)) {
-              graphNode.circular = true;
-              graphNode = {
-                id: -1,
-                flowNode: flowNode2,
-                edges: [],
-                text: "",
-                lane: -1,
-                endLane: -1,
-                level: -1,
-                circular: "circularity"
-              };
-              nodes.push(graphNode);
-              return graphNode;
-            }
-            seen.add(flowNode2);
-            if (!graphNode) {
-              links[id] = graphNode = { id, flowNode: flowNode2, edges: [], text: "", lane: -1, endLane: -1, level: -1, circular: false };
-              nodes.push(graphNode);
-              if (hasAntecedents(flowNode2)) {
-                for (const antecedent of flowNode2.antecedents) {
-                  buildGraphEdge(graphNode, antecedent, seen);
-                }
-              } else if (hasAntecedent(flowNode2)) {
-                buildGraphEdge(graphNode, flowNode2.antecedent, seen);
-              }
-            }
-            seen.delete(flowNode2);
-            return graphNode;
-          }
-          function buildGraphEdge(source, antecedent, seen) {
-            const target = buildGraphNode(antecedent, seen);
-            const edge = { source, target };
-            edges.push(edge);
-            source.edges.push(edge);
-            target.edges.push(edge);
-          }
-          function computeLevel(node) {
-            if (node.level !== -1) {
-              return node.level;
-            }
-            let level = 0;
-            for (const parent2 of getParents(node)) {
-              level = Math.max(level, computeLevel(parent2) + 1);
-            }
-            return node.level = level;
-          }
-          function computeHeight(node) {
-            let height2 = 0;
-            for (const child of getChildren(node)) {
-              height2 = Math.max(height2, computeHeight(child));
-            }
-            return height2 + 1;
-          }
-          function computeColumnWidths(height2) {
-            const columns = fill(Array(height2), 0);
-            for (const node of nodes) {
-              columns[node.level] = Math.max(columns[node.level], node.text.length);
-            }
-            return columns;
-          }
-          function computeLanes(node, lane) {
-            if (node.lane === -1) {
-              node.lane = lane;
-              node.endLane = lane;
-              const children = getChildren(node);
-              for (let i = 0; i < children.length; i++) {
-                if (i > 0)
-                  lane++;
-                const child = children[i];
-                computeLanes(child, lane);
-                if (child.endLane > node.endLane) {
-                  lane = child.endLane;
-                }
-              }
-              node.endLane = lane;
-            }
-          }
-          function getHeader(flags) {
-            if (flags & 2 /* Start */)
-              return "Start";
-            if (flags & 4 /* BranchLabel */)
-              return "Branch";
-            if (flags & 8 /* LoopLabel */)
-              return "Loop";
-            if (flags & 16 /* Assignment */)
-              return "Assignment";
-            if (flags & 32 /* TrueCondition */)
-              return "True";
-            if (flags & 64 /* FalseCondition */)
-              return "False";
-            if (flags & 128 /* SwitchClause */)
-              return "SwitchClause";
-            if (flags & 256 /* ArrayMutation */)
-              return "ArrayMutation";
-            if (flags & 512 /* Call */)
-              return "Call";
-            if (flags & 1024 /* ReduceLabel */)
-              return "ReduceLabel";
-            if (flags & 1 /* Unreachable */)
-              return "Unreachable";
-            throw new Error();
-          }
-          function getNodeText(node) {
-            const sourceFile = getSourceFileOfNode(node);
-            return getSourceTextOfNodeFromSourceFile(
-              sourceFile,
-              node,
-              /*includeTrivia*/
-              false
-            );
-          }
-          function renderFlowNode(flowNode2, circular) {
-            let text = getHeader(flowNode2.flags);
-            if (circular) {
-              text = `${text}#${getDebugFlowNodeId(flowNode2)}`;
-            }
-            if (hasNode(flowNode2)) {
-              if (flowNode2.node) {
-                text += ` (${getNodeText(flowNode2.node)})`;
-              }
-            } else if (isFlowSwitchClause(flowNode2)) {
-              const clauses = [];
-              for (let i = flowNode2.clauseStart; i < flowNode2.clauseEnd; i++) {
-                const clause = flowNode2.switchStatement.caseBlock.clauses[i];
-                if (isDefaultClause(clause)) {
-                  clauses.push("default");
-                } else {
-                  clauses.push(getNodeText(clause.expression));
-                }
-              }
-              text += ` (${clauses.join(", ")})`;
-            }
-            return circular === "circularity" ? `Circular(${text})` : text;
-          }
-          function renderGraph() {
-            const columnCount = columnWidths.length;
-            const laneCount = nodes.reduce((x, n) => Math.max(x, n.lane), 0) + 1;
-            const lanes = fill(Array(laneCount), "");
-            const grid = columnWidths.map(() => Array(laneCount));
-            const connectors = columnWidths.map(() => fill(Array(laneCount), 0));
-            for (const node of nodes) {
-              grid[node.level][node.lane] = node;
-              const children = getChildren(node);
-              for (let i = 0; i < children.length; i++) {
-                const child = children[i];
-                let connector = 8 /* Right */;
-                if (child.lane === node.lane)
-                  connector |= 4 /* Left */;
-                if (i > 0)
-                  connector |= 1 /* Up */;
-                if (i < children.length - 1)
-                  connector |= 2 /* Down */;
-                connectors[node.level][child.lane] |= connector;
-              }
-              if (children.length === 0) {
-                connectors[node.level][node.lane] |= 16 /* NoChildren */;
-              }
-              const parents = getParents(node);
-              for (let i = 0; i < parents.length; i++) {
-                const parent2 = parents[i];
-                let connector = 4 /* Left */;
-                if (i > 0)
-                  connector |= 1 /* Up */;
-                if (i < parents.length - 1)
-                  connector |= 2 /* Down */;
-                connectors[node.level - 1][parent2.lane] |= connector;
-              }
-            }
-            for (let column = 0; column < columnCount; column++) {
-              for (let lane = 0; lane < laneCount; lane++) {
-                const left = column > 0 ? connectors[column - 1][lane] : 0;
-                const above = lane > 0 ? connectors[column][lane - 1] : 0;
-                let connector = connectors[column][lane];
-                if (!connector) {
-                  if (left & 8 /* Right */)
-                    connector |= 12 /* LeftRight */;
-                  if (above & 2 /* Down */)
-                    connector |= 3 /* UpDown */;
-                  connectors[column][lane] = connector;
-                }
-              }
-            }
-            for (let column = 0; column < columnCount; column++) {
-              for (let lane = 0; lane < lanes.length; lane++) {
-                const connector = connectors[column][lane];
-                const fill2 = connector & 4 /* Left */ ? "\u2500" /* lr */ : " ";
-                const node = grid[column][lane];
-                if (!node) {
-                  if (column < columnCount - 1) {
-                    writeLane(lane, repeat(fill2, columnWidths[column] + 1));
-                  }
-                } else {
-                  writeLane(lane, node.text);
-                  if (column < columnCount - 1) {
-                    writeLane(lane, " ");
-                    writeLane(lane, repeat(fill2, columnWidths[column] - node.text.length));
-                  }
-                }
-                writeLane(lane, getBoxCharacter(connector));
-                writeLane(lane, connector & 8 /* Right */ && column < columnCount - 1 && !grid[column + 1][lane] ? "\u2500" /* lr */ : " ");
-              }
-            }
-            return `
-${lanes.join("\n")}
-`;
-            function writeLane(lane, text) {
-              lanes[lane] += text;
-            }
-          }
-          function getBoxCharacter(connector) {
-            switch (connector) {
-              case 3 /* UpDown */:
-                return "\u2502" /* ud */;
-              case 12 /* LeftRight */:
-                return "\u2500" /* lr */;
-              case 5 /* UpLeft */:
-                return "\u256F" /* ul */;
-              case 9 /* UpRight */:
-                return "\u2570" /* ur */;
-              case 6 /* DownLeft */:
-                return "\u256E" /* dl */;
-              case 10 /* DownRight */:
-                return "\u256D" /* dr */;
-              case 7 /* UpDownLeft */:
-                return "\u2524" /* udl */;
-              case 11 /* UpDownRight */:
-                return "\u251C" /* udr */;
-              case 13 /* UpLeftRight */:
-                return "\u2534" /* ulr */;
-              case 14 /* DownLeftRight */:
-                return "\u252C" /* dlr */;
-              case 15 /* UpDownLeftRight */:
-                return "\u256B" /* udlr */;
-            }
-            return " ";
-          }
-          function fill(array, value) {
-            if (array.fill) {
-              array.fill(value);
-            } else {
-              for (let i = 0; i < array.length; i++) {
-                array[i] = value;
-              }
-            }
-            return array;
-          }
-          function repeat(ch, length2) {
-            if (ch.repeat) {
-              return length2 > 0 ? ch.repeat(length2) : "";
-            }
-            let s = "";
-            while (s.length < length2) {
-              s += ch;
-            }
-            return s;
-          }
-        }
-        Debug2.formatControlFlowGraph = formatControlFlowGraph;
-      })(Debug || (Debug = {}));
-    }
-  });
-
-  // src/compiler/semver.ts
-  function tryParseComponents(text) {
-    const match = versionRegExp.exec(text);
-    if (!match)
-      return void 0;
-    const [, major, minor = "0", patch = "0", prerelease = "", build2 = ""] = match;
-    if (prerelease && !prereleaseRegExp.test(prerelease))
-      return void 0;
-    if (build2 && !buildRegExp.test(build2))
-      return void 0;
-    return {
-      major: parseInt(major, 10),
-      minor: parseInt(minor, 10),
-      patch: parseInt(patch, 10),
-      prerelease,
-      build: build2
-    };
-  }
-  function comparePrereleaseIdentifiers(left, right) {
-    if (left === right)
-      return 0 /* EqualTo */;
-    if (left.length === 0)
-      return right.length === 0 ? 0 /* EqualTo */ : 1 /* GreaterThan */;
-    if (right.length === 0)
-      return -1 /* LessThan */;
-    const length2 = Math.min(left.length, right.length);
-    for (let i = 0; i < length2; i++) {
-      const leftIdentifier = left[i];
-      const rightIdentifier = right[i];
-      if (leftIdentifier === rightIdentifier)
-        continue;
-      const leftIsNumeric = numericIdentifierRegExp.test(leftIdentifier);
-      const rightIsNumeric = numericIdentifierRegExp.test(rightIdentifier);
-      if (leftIsNumeric || rightIsNumeric) {
-        if (leftIsNumeric !== rightIsNumeric)
-          return leftIsNumeric ? -1 /* LessThan */ : 1 /* GreaterThan */;
-        const result = compareValues(+leftIdentifier, +rightIdentifier);
-        if (result)
-          return result;
-      } else {
-        const result = compareStringsCaseSensitive(leftIdentifier, rightIdentifier);
-        if (result)
-          return result;
-      }
-    }
-    return compareValues(left.length, right.length);
-  }
-  function parseRange(text) {
-    const alternatives = [];
-    for (let range of trimString(text).split(logicalOrRegExp)) {
-      if (!range)
-        continue;
-      const comparators = [];
-      range = trimString(range);
-      const match = hyphenRegExp.exec(range);
-      if (match) {
-        if (!parseHyphen(match[1], match[2], comparators))
-          return void 0;
-      } else {
-        for (const simple of range.split(whitespaceRegExp)) {
-          const match2 = rangeRegExp.exec(trimString(simple));
-          if (!match2 || !parseComparator(match2[1], match2[2], comparators))
-            return void 0;
-        }
-      }
-      alternatives.push(comparators);
-    }
-    return alternatives;
-  }
-  function parsePartial(text) {
-    const match = partialRegExp.exec(text);
-    if (!match)
-      return void 0;
-    const [, major, minor = "*", patch = "*", prerelease, build2] = match;
-    const version2 = new Version(
-      isWildcard(major) ? 0 : parseInt(major, 10),
-      isWildcard(major) || isWildcard(minor) ? 0 : parseInt(minor, 10),
-      isWildcard(major) || isWildcard(minor) || isWildcard(patch) ? 0 : parseInt(patch, 10),
-      prerelease,
-      build2
-    );
-    return { version: version2, major, minor, patch };
-  }
-  function parseHyphen(left, right, comparators) {
-    const leftResult = parsePartial(left);
-    if (!leftResult)
-      return false;
-    const rightResult = parsePartial(right);
-    if (!rightResult)
-      return false;
-    if (!isWildcard(leftResult.major)) {
-      comparators.push(createComparator(">=", leftResult.version));
-    }
-    if (!isWildcard(rightResult.major)) {
-      comparators.push(
-        isWildcard(rightResult.minor) ? createComparator("<", rightResult.version.increment("major")) : isWildcard(rightResult.patch) ? createComparator("<", rightResult.version.increment("minor")) : createComparator("<=", rightResult.version)
-      );
-    }
-    return true;
-  }
-  function parseComparator(operator, text, comparators) {
-    const result = parsePartial(text);
-    if (!result)
-      return false;
-    const { version: version2, major, minor, patch } = result;
-    if (!isWildcard(major)) {
-      switch (operator) {
-        case "~":
-          comparators.push(createComparator(">=", version2));
-          comparators.push(createComparator("<", version2.increment(
-            isWildcard(minor) ? "major" : "minor"
-          )));
-          break;
-        case "^":
-          comparators.push(createComparator(">=", version2));
-          comparators.push(createComparator("<", version2.increment(
-            version2.major > 0 || isWildcard(minor) ? "major" : version2.minor > 0 || isWildcard(patch) ? "minor" : "patch"
-          )));
-          break;
-        case "<":
-        case ">=":
-          comparators.push(
-            isWildcard(minor) || isWildcard(patch) ? createComparator(operator, version2.with({ prerelease: "0" })) : createComparator(operator, version2)
-          );
-          break;
-        case "<=":
-        case ">":
-          comparators.push(
-            isWildcard(minor) ? createComparator(operator === "<=" ? "<" : ">=", version2.increment("major").with({ prerelease: "0" })) : isWildcard(patch) ? createComparator(operator === "<=" ? "<" : ">=", version2.increment("minor").with({ prerelease: "0" })) : createComparator(operator, version2)
-          );
-          break;
-        case "=":
-        case void 0:
-          if (isWildcard(minor) || isWildcard(patch)) {
-            comparators.push(createComparator(">=", version2.with({ prerelease: "0" })));
-            comparators.push(createComparator("<", version2.increment(isWildcard(minor) ? "major" : "minor").with({ prerelease: "0" })));
-          } else {
-            comparators.push(createComparator("=", version2));
-          }
-          break;
-        default:
-          return false;
-      }
-    } else if (operator === "<" || operator === ">") {
-      comparators.push(createComparator("<", Version.zero));
-    }
-    return true;
-  }
-  function isWildcard(part) {
-    return part === "*" || part === "x" || part === "X";
-  }
-  function createComparator(operator, operand) {
-    return { operator, operand };
-  }
-  function testDisjunction(version2, alternatives) {
-    if (alternatives.length === 0)
-      return true;
-    for (const alternative of alternatives) {
-      if (testAlternative(version2, alternative))
-        return true;
-    }
-    return false;
-  }
-  function testAlternative(version2, comparators) {
-    for (const comparator of comparators) {
-      if (!testComparator(version2, comparator.operator, comparator.operand))
-        return false;
-    }
-    return true;
-  }
-  function testComparator(version2, operator, operand) {
-    const cmp = version2.compareTo(operand);
-    switch (operator) {
-      case "<":
-        return cmp < 0;
-      case "<=":
-        return cmp <= 0;
-      case ">":
-        return cmp > 0;
-      case ">=":
-        return cmp >= 0;
-      case "=":
-        return cmp === 0;
-      default:
-        return Debug.assertNever(operator);
-    }
-  }
-  function formatDisjunction(alternatives) {
-    return map(alternatives, formatAlternative).join(" || ") || "*";
-  }
-  function formatAlternative(comparators) {
-    return map(comparators, formatComparator).join(" ");
-  }
-  function formatComparator(comparator) {
-    return `${comparator.operator}${comparator.operand}`;
-  }
-  var versionRegExp, prereleaseRegExp, prereleasePartRegExp, buildRegExp, buildPartRegExp, numericIdentifierRegExp, _Version, Version, VersionRange, logicalOrRegExp, whitespaceRegExp, partialRegExp, hyphenRegExp, rangeRegExp;
-  var init_semver = __esm({
-    "src/compiler/semver.ts"() {
-      "use strict";
-      init_ts2();
-      versionRegExp = /^(0|[1-9]\d*)(?:\.(0|[1-9]\d*)(?:\.(0|[1-9]\d*)(?:\-([a-z0-9-.]+))?(?:\+([a-z0-9-.]+))?)?)?$/i;
-      prereleaseRegExp = /^(?:0|[1-9]\d*|[a-z-][a-z0-9-]*)(?:\.(?:0|[1-9]\d*|[a-z-][a-z0-9-]*))*$/i;
-      prereleasePartRegExp = /^(?:0|[1-9]\d*|[a-z-][a-z0-9-]*)$/i;
-      buildRegExp = /^[a-z0-9-]+(?:\.[a-z0-9-]+)*$/i;
-      buildPartRegExp = /^[a-z0-9-]+$/i;
-      numericIdentifierRegExp = /^(0|[1-9]\d*)$/;
-      _Version = class {
-        constructor(major, minor = 0, patch = 0, prerelease = "", build2 = "") {
-          if (typeof major === "string") {
-            const result = Debug.checkDefined(tryParseComponents(major), "Invalid version");
-            ({ major, minor, patch, prerelease, build: build2 } = result);
-          }
-          Debug.assert(major >= 0, "Invalid argument: major");
-          Debug.assert(minor >= 0, "Invalid argument: minor");
-          Debug.assert(patch >= 0, "Invalid argument: patch");
-          const prereleaseArray = prerelease ? isArray(prerelease) ? prerelease : prerelease.split(".") : emptyArray;
-          const buildArray = build2 ? isArray(build2) ? build2 : build2.split(".") : emptyArray;
-          Debug.assert(every(prereleaseArray, (s) => prereleasePartRegExp.test(s)), "Invalid argument: prerelease");
-          Debug.assert(every(buildArray, (s) => buildPartRegExp.test(s)), "Invalid argument: build");
-          this.major = major;
-          this.minor = minor;
-          this.patch = patch;
-          this.prerelease = prereleaseArray;
-          this.build = buildArray;
-        }
-        static tryParse(text) {
-          const result = tryParseComponents(text);
-          if (!result)
-            return void 0;
-          const { major, minor, patch, prerelease, build: build2 } = result;
-          return new _Version(major, minor, patch, prerelease, build2);
-        }
-        compareTo(other) {
-          if (this === other)
-            return 0 /* EqualTo */;
-          if (other === void 0)
-            return 1 /* GreaterThan */;
-          return compareValues(this.major, other.major) || compareValues(this.minor, other.minor) || compareValues(this.patch, other.patch) || comparePrereleaseIdentifiers(this.prerelease, other.prerelease);
-        }
-        increment(field) {
-          switch (field) {
-            case "major":
-              return new _Version(this.major + 1, 0, 0);
-            case "minor":
-              return new _Version(this.major, this.minor + 1, 0);
-            case "patch":
-              return new _Version(this.major, this.minor, this.patch + 1);
-            default:
-              return Debug.assertNever(field);
-          }
-        }
-        with(fields) {
-          const {
-            major = this.major,
-            minor = this.minor,
-            patch = this.patch,
-            prerelease = this.prerelease,
-            build: build2 = this.build
-          } = fields;
-          return new _Version(major, minor, patch, prerelease, build2);
-        }
-        toString() {
-          let result = `${this.major}.${this.minor}.${this.patch}`;
-          if (some(this.prerelease))
-            result += `-${this.prerelease.join(".")}`;
-          if (some(this.build))
-            result += `+${this.build.join(".")}`;
-          return result;
-        }
-      };
-      Version = _Version;
-      Version.zero = new _Version(0, 0, 0, ["0"]);
-      VersionRange = class {
-        constructor(spec) {
-          this._alternatives = spec ? Debug.checkDefined(parseRange(spec), "Invalid range spec.") : emptyArray;
-        }
-        static tryParse(text) {
-          const sets = parseRange(text);
-          if (sets) {
-            const range = new VersionRange("");
-            range._alternatives = sets;
-            return range;
-          }
-          return void 0;
-        }
-        /**
-         * Tests whether a version matches the range. This is equivalent to `satisfies(version, range, { includePrerelease: true })`.
-         * in `node-semver`.
-         */
-        test(version2) {
-          if (typeof version2 === "string")
-            version2 = new Version(version2);
-          return testDisjunction(version2, this._alternatives);
-        }
-        toString() {
-          return formatDisjunction(this._alternatives);
-        }
-      };
-      logicalOrRegExp = /\|\|/g;
-      whitespaceRegExp = /\s+/g;
-      partialRegExp = /^([xX*0]|[1-9]\d*)(?:\.([xX*0]|[1-9]\d*)(?:\.([xX*0]|[1-9]\d*)(?:-([a-z0-9-.]+))?(?:\+([a-z0-9-.]+))?)?)?$/i;
-      hyphenRegExp = /^\s*([a-z0-9-+.*]+)\s+-\s+([a-z0-9-+.*]+)\s*$/i;
-      rangeRegExp = /^(~|\^|<|<=|>|>=|=)?\s*([a-z0-9-+.*]+)$/i;
-    }
-  });
-
-  // src/compiler/performanceCore.ts
-  function hasRequiredAPI(performance2, PerformanceObserver2) {
-    return typeof performance2 === "object" && typeof performance2.timeOrigin === "number" && typeof performance2.mark === "function" && typeof performance2.measure === "function" && typeof performance2.now === "function" && typeof performance2.clearMarks === "function" && typeof performance2.clearMeasures === "function" && typeof PerformanceObserver2 === "function";
-  }
-  function tryGetWebPerformanceHooks() {
-    if (typeof performance === "object" && typeof PerformanceObserver === "function" && hasRequiredAPI(performance, PerformanceObserver)) {
-      return {
-        // For now we always write native performance events when running in the browser. We may
-        // make this conditional in the future if we find that native web performance hooks
-        // in the browser also slow down compilation.
-        shouldWriteNativeEvents: true,
-        performance,
-        PerformanceObserver
-      };
-    }
-  }
-  function tryGetNodePerformanceHooks() {
-    if (isNodeLikeSystem()) {
-      try {
-        const { performance: performance2, PerformanceObserver: PerformanceObserver2 } =   __nccwpck_require__(4074);
-        if (hasRequiredAPI(performance2, PerformanceObserver2)) {
-          return {
-            // By default, only write native events when generating a cpu profile or using the v8 profiler.
-            shouldWriteNativeEvents: false,
-            performance: performance2,
-            PerformanceObserver: PerformanceObserver2
-          };
-        }
-      } catch {
-      }
-    }
-  }
-  function tryGetNativePerformanceHooks() {
-    return nativePerformanceHooks;
-  }
-  var nativePerformanceHooks, nativePerformance, timestamp;
-  var init_performanceCore = __esm({
-    "src/compiler/performanceCore.ts"() {
-      "use strict";
-      init_ts2();
-      nativePerformanceHooks = tryGetWebPerformanceHooks() || tryGetNodePerformanceHooks();
-      nativePerformance = nativePerformanceHooks == null ? void 0 : nativePerformanceHooks.performance;
-      timestamp = nativePerformance ? () => nativePerformance.now() : Date.now ? Date.now : () => +/* @__PURE__ */ new Date();
-    }
-  });
-
-  // src/compiler/perfLogger.ts
-  var etwModule, perfLogger;
-  var init_perfLogger = __esm({
-    "src/compiler/perfLogger.ts"() {
-      "use strict";
-      try {
-        const etwModulePath = process.env.TS_ETW_MODULE_PATH ?? "./node_modules/@microsoft/typescript-etw";
-        etwModule =   require(etwModulePath);
-      } catch (e) {
-        etwModule = void 0;
-      }
-      perfLogger = (etwModule == null ? void 0 : etwModule.logEvent) ? etwModule : void 0;
-    }
-  });
-
-  // src/compiler/performance.ts
-  function createTimerIf(condition, measureName, startMarkName, endMarkName) {
-    return condition ? createTimer(measureName, startMarkName, endMarkName) : nullTimer;
-  }
-  function createTimer(measureName, startMarkName, endMarkName) {
-    let enterCount = 0;
-    return {
-      enter,
-      exit
-    };
-    function enter() {
-      if (++enterCount === 1) {
-        mark(startMarkName);
-      }
-    }
-    function exit() {
-      if (--enterCount === 0) {
-        mark(endMarkName);
-        measure(measureName, startMarkName, endMarkName);
-      } else if (enterCount < 0) {
-        Debug.fail("enter/exit count does not match.");
-      }
-    }
-  }
-  function mark(markName) {
-    if (enabled) {
-      const count = counts.get(markName) ?? 0;
-      counts.set(markName, count + 1);
-      marks.set(markName, timestamp());
-      performanceImpl == null ? void 0 : performanceImpl.mark(markName);
-      if (typeof onProfilerEvent === "function") {
-        onProfilerEvent(markName);
-      }
-    }
-  }
-  function measure(measureName, startMarkName, endMarkName) {
-    if (enabled) {
-      const end = (endMarkName !== void 0 ? marks.get(endMarkName) : void 0) ?? timestamp();
-      const start = (startMarkName !== void 0 ? marks.get(startMarkName) : void 0) ?? timeorigin;
-      const previousDuration = durations.get(measureName) || 0;
-      durations.set(measureName, previousDuration + (end - start));
-      performanceImpl == null ? void 0 : performanceImpl.measure(measureName, startMarkName, endMarkName);
-    }
-  }
-  function getCount(markName) {
-    return counts.get(markName) || 0;
-  }
-  function getDuration(measureName) {
-    return durations.get(measureName) || 0;
-  }
-  function forEachMeasure(cb) {
-    durations.forEach((duration, measureName) => cb(measureName, duration));
-  }
-  function forEachMark(cb) {
-    marks.forEach((_time, markName) => cb(markName));
-  }
-  function clearMeasures(name) {
-    if (name !== void 0)
-      durations.delete(name);
-    else
-      durations.clear();
-    performanceImpl == null ? void 0 : performanceImpl.clearMeasures(name);
-  }
-  function clearMarks(name) {
-    if (name !== void 0) {
-      counts.delete(name);
-      marks.delete(name);
-    } else {
-      counts.clear();
-      marks.clear();
-    }
-    performanceImpl == null ? void 0 : performanceImpl.clearMarks(name);
-  }
-  function isEnabled() {
-    return enabled;
-  }
-  function enable(system = sys) {
-    var _a;
-    if (!enabled) {
-      enabled = true;
-      perfHooks || (perfHooks = tryGetNativePerformanceHooks());
-      if (perfHooks) {
-        timeorigin = perfHooks.performance.timeOrigin;
-        if (perfHooks.shouldWriteNativeEvents || ((_a = system == null ? void 0 : system.cpuProfilingEnabled) == null ? void 0 : _a.call(system)) || (system == null ? void 0 : system.debugMode)) {
-          performanceImpl = perfHooks.performance;
-        }
-      }
-    }
-    return true;
-  }
-  function disable() {
-    if (enabled) {
-      marks.clear();
-      counts.clear();
-      durations.clear();
-      performanceImpl = void 0;
-      enabled = false;
-    }
-  }
-  var perfHooks, performanceImpl, nullTimer, enabled, timeorigin, marks, counts, durations;
-  var init_performance = __esm({
-    "src/compiler/performance.ts"() {
-      "use strict";
-      init_ts2();
-      nullTimer = { enter: noop, exit: noop };
-      enabled = false;
-      timeorigin = timestamp();
-      marks = /* @__PURE__ */ new Map();
-      counts = /* @__PURE__ */ new Map();
-      durations = /* @__PURE__ */ new Map();
-    }
-  });
-
-  // src/compiler/_namespaces/ts.performance.ts
-  var ts_performance_exports = {};
-  __export(ts_performance_exports, {
-    clearMarks: () => clearMarks,
-    clearMeasures: () => clearMeasures,
-    createTimer: () => createTimer,
-    createTimerIf: () => createTimerIf,
-    disable: () => disable,
-    enable: () => enable,
-    forEachMark: () => forEachMark,
-    forEachMeasure: () => forEachMeasure,
-    getCount: () => getCount,
-    getDuration: () => getDuration,
-    isEnabled: () => isEnabled,
-    mark: () => mark,
-    measure: () => measure,
-    nullTimer: () => nullTimer
-  });
-  var init_ts_performance = __esm({
-    "src/compiler/_namespaces/ts.performance.ts"() {
-      "use strict";
-      init_performance();
-    }
-  });
-
-  // src/compiler/tracing.ts
-  var tracing, tracingEnabled, startTracing, dumpTracingLegend;
-  var init_tracing = __esm({
-    "src/compiler/tracing.ts"() {
-      "use strict";
-      init_ts2();
-      init_ts_performance();
-      ((tracingEnabled2) => {
-        let fs;
-        let traceCount = 0;
-        let traceFd = 0;
-        let mode;
-        const typeCatalog = [];
-        let legendPath;
-        const legend = [];
-        function startTracing2(tracingMode, traceDir, configFilePath) {
-          Debug.assert(!tracing, "Tracing already started");
-          if (fs === void 0) {
-            try {
-              fs =   __nccwpck_require__(57147);
-            } catch (e) {
-              throw new Error(`tracing requires having fs
-(original error: ${e.message || e})`);
-            }
-          }
-          mode = tracingMode;
-          typeCatalog.length = 0;
-          if (legendPath === void 0) {
-            legendPath = combinePaths(traceDir, "legend.json");
-          }
-          if (!fs.existsSync(traceDir)) {
-            fs.mkdirSync(traceDir, { recursive: true });
-          }
-          const countPart = mode === "build" ? `.${process.pid}-${++traceCount}` : mode === "server" ? `.${process.pid}` : ``;
-          const tracePath = combinePaths(traceDir, `trace${countPart}.json`);
-          const typesPath = combinePaths(traceDir, `types${countPart}.json`);
-          legend.push({
-            configFilePath,
-            tracePath,
-            typesPath
-          });
-          traceFd = fs.openSync(tracePath, "w");
-          tracing = tracingEnabled2;
-          const meta = { cat: "__metadata", ph: "M", ts: 1e3 * timestamp(), pid: 1, tid: 1 };
-          fs.writeSync(
-            traceFd,
-            "[\n" + [
-              { name: "process_name", args: { name: "tsc" }, ...meta },
-              { name: "thread_name", args: { name: "Main" }, ...meta },
-              { name: "TracingStartedInBrowser", ...meta, cat: "disabled-by-default-devtools.timeline" }
-            ].map((v) => JSON.stringify(v)).join(",\n")
-          );
-        }
-        tracingEnabled2.startTracing = startTracing2;
-        function stopTracing() {
-          Debug.assert(tracing, "Tracing is not in progress");
-          Debug.assert(!!typeCatalog.length === (mode !== "server"));
-          fs.writeSync(traceFd, `
-]
-`);
-          fs.closeSync(traceFd);
-          tracing = void 0;
-          if (typeCatalog.length) {
-            dumpTypes(typeCatalog);
-          } else {
-            legend[legend.length - 1].typesPath = void 0;
-          }
-        }
-        tracingEnabled2.stopTracing = stopTracing;
-        function recordType(type) {
-          if (mode !== "server") {
-            typeCatalog.push(type);
-          }
-        }
-        tracingEnabled2.recordType = recordType;
-        let Phase;
-        ((Phase2) => {
-          Phase2["Parse"] = "parse";
-          Phase2["Program"] = "program";
-          Phase2["Bind"] = "bind";
-          Phase2["Check"] = "check";
-          Phase2["CheckTypes"] = "checkTypes";
-          Phase2["Emit"] = "emit";
-          Phase2["Session"] = "session";
-        })(Phase = tracingEnabled2.Phase || (tracingEnabled2.Phase = {}));
-        function instant(phase, name, args) {
-          writeEvent("I", phase, name, args, `"s":"g"`);
-        }
-        tracingEnabled2.instant = instant;
-        const eventStack = [];
-        function push(phase, name, args, separateBeginAndEnd = false) {
-          if (separateBeginAndEnd) {
-            writeEvent("B", phase, name, args);
-          }
-          eventStack.push({ phase, name, args, time: 1e3 * timestamp(), separateBeginAndEnd });
-        }
-        tracingEnabled2.push = push;
-        function pop(results) {
-          Debug.assert(eventStack.length > 0);
-          writeStackEvent(eventStack.length - 1, 1e3 * timestamp(), results);
-          eventStack.length--;
-        }
-        tracingEnabled2.pop = pop;
-        function popAll() {
-          const endTime = 1e3 * timestamp();
-          for (let i = eventStack.length - 1; i >= 0; i--) {
-            writeStackEvent(i, endTime);
-          }
-          eventStack.length = 0;
-        }
-        tracingEnabled2.popAll = popAll;
-        const sampleInterval = 1e3 * 10;
-        function writeStackEvent(index, endTime, results) {
-          const { phase, name, args, time, separateBeginAndEnd } = eventStack[index];
-          if (separateBeginAndEnd) {
-            Debug.assert(!results, "`results` are not supported for events with `separateBeginAndEnd`");
-            writeEvent(
-              "E",
-              phase,
-              name,
-              args,
-              /*extras*/
-              void 0,
-              endTime
-            );
-          } else if (sampleInterval - time % sampleInterval <= endTime - time) {
-            writeEvent("X", phase, name, { ...args, results }, `"dur":${endTime - time}`, time);
-          }
-        }
-        function writeEvent(eventType, phase, name, args, extras, time = 1e3 * timestamp()) {
-          if (mode === "server" && phase === "checkTypes" /* CheckTypes */)
-            return;
-          mark("beginTracing");
-          fs.writeSync(traceFd, `,
-{"pid":1,"tid":1,"ph":"${eventType}","cat":"${phase}","ts":${time},"name":"${name}"`);
-          if (extras)
-            fs.writeSync(traceFd, `,${extras}`);
-          if (args)
-            fs.writeSync(traceFd, `,"args":${JSON.stringify(args)}`);
-          fs.writeSync(traceFd, `}`);
-          mark("endTracing");
-          measure("Tracing", "beginTracing", "endTracing");
-        }
-        function getLocation(node) {
-          const file = getSourceFileOfNode(node);
-          return !file ? void 0 : {
-            path: file.path,
-            start: indexFromOne(getLineAndCharacterOfPosition(file, node.pos)),
-            end: indexFromOne(getLineAndCharacterOfPosition(file, node.end))
-          };
-          function indexFromOne(lc) {
-            return {
-              line: lc.line + 1,
-              character: lc.character + 1
-            };
-          }
-        }
-        function dumpTypes(types) {
-          var _a, _b, _c, _d, _e, _f, _g, _h, _i, _j, _k, _l, _m, _n, _o, _p, _q, _r, _s;
-          mark("beginDumpTypes");
-          const typesPath = legend[legend.length - 1].typesPath;
-          const typesFd = fs.openSync(typesPath, "w");
-          const recursionIdentityMap = /* @__PURE__ */ new Map();
-          fs.writeSync(typesFd, "[");
-          const numTypes = types.length;
-          for (let i = 0; i < numTypes; i++) {
-            const type = types[i];
-            const objectFlags = type.objectFlags;
-            const symbol = type.aliasSymbol ?? type.symbol;
-            let display;
-            if (objectFlags & 16 /* Anonymous */ | type.flags & 2944 /* Literal */) {
-              try {
-                display = (_a = type.checker) == null ? void 0 : _a.typeToString(type);
-              } catch {
-                display = void 0;
-              }
-            }
-            let indexedAccessProperties = {};
-            if (type.flags & 8388608 /* IndexedAccess */) {
-              const indexedAccessType = type;
-              indexedAccessProperties = {
-                indexedAccessObjectType: (_b = indexedAccessType.objectType) == null ? void 0 : _b.id,
-                indexedAccessIndexType: (_c = indexedAccessType.indexType) == null ? void 0 : _c.id
-              };
-            }
-            let referenceProperties = {};
-            if (objectFlags & 4 /* Reference */) {
-              const referenceType = type;
-              referenceProperties = {
-                instantiatedType: (_d = referenceType.target) == null ? void 0 : _d.id,
-                typeArguments: (_e = referenceType.resolvedTypeArguments) == null ? void 0 : _e.map((t) => t.id),
-                referenceLocation: getLocation(referenceType.node)
-              };
-            }
-            let conditionalProperties = {};
-            if (type.flags & 16777216 /* Conditional */) {
-              const conditionalType = type;
-              conditionalProperties = {
-                conditionalCheckType: (_f = conditionalType.checkType) == null ? void 0 : _f.id,
-                conditionalExtendsType: (_g = conditionalType.extendsType) == null ? void 0 : _g.id,
-                conditionalTrueType: ((_h = conditionalType.resolvedTrueType) == null ? void 0 : _h.id) ?? -1,
-                conditionalFalseType: ((_i = conditionalType.resolvedFalseType) == null ? void 0 : _i.id) ?? -1
-              };
-            }
-            let substitutionProperties = {};
-            if (type.flags & 33554432 /* Substitution */) {
-              const substitutionType = type;
-              substitutionProperties = {
-                substitutionBaseType: (_j = substitutionType.baseType) == null ? void 0 : _j.id,
-                constraintType: (_k = substitutionType.constraint) == null ? void 0 : _k.id
-              };
-            }
-            let reverseMappedProperties = {};
-            if (objectFlags & 1024 /* ReverseMapped */) {
-              const reverseMappedType = type;
-              reverseMappedProperties = {
-                reverseMappedSourceType: (_l = reverseMappedType.source) == null ? void 0 : _l.id,
-                reverseMappedMappedType: (_m = reverseMappedType.mappedType) == null ? void 0 : _m.id,
-                reverseMappedConstraintType: (_n = reverseMappedType.constraintType) == null ? void 0 : _n.id
-              };
-            }
-            let evolvingArrayProperties = {};
-            if (objectFlags & 256 /* EvolvingArray */) {
-              const evolvingArrayType = type;
-              evolvingArrayProperties = {
-                evolvingArrayElementType: evolvingArrayType.elementType.id,
-                evolvingArrayFinalType: (_o = evolvingArrayType.finalArrayType) == null ? void 0 : _o.id
-              };
-            }
-            let recursionToken;
-            const recursionIdentity = type.checker.getRecursionIdentity(type);
-            if (recursionIdentity) {
-              recursionToken = recursionIdentityMap.get(recursionIdentity);
-              if (!recursionToken) {
-                recursionToken = recursionIdentityMap.size;
-                recursionIdentityMap.set(recursionIdentity, recursionToken);
-              }
-            }
-            const descriptor = {
-              id: type.id,
-              intrinsicName: type.intrinsicName,
-              symbolName: (symbol == null ? void 0 : symbol.escapedName) && unescapeLeadingUnderscores(symbol.escapedName),
-              recursionId: recursionToken,
-              isTuple: objectFlags & 8 /* Tuple */ ? true : void 0,
-              unionTypes: type.flags & 1048576 /* Union */ ? (_p = type.types) == null ? void 0 : _p.map((t) => t.id) : void 0,
-              intersectionTypes: type.flags & 2097152 /* Intersection */ ? type.types.map((t) => t.id) : void 0,
-              aliasTypeArguments: (_q = type.aliasTypeArguments) == null ? void 0 : _q.map((t) => t.id),
-              keyofType: type.flags & 4194304 /* Index */ ? (_r = type.type) == null ? void 0 : _r.id : void 0,
-              ...indexedAccessProperties,
-              ...referenceProperties,
-              ...conditionalProperties,
-              ...substitutionProperties,
-              ...reverseMappedProperties,
-              ...evolvingArrayProperties,
-              destructuringPattern: getLocation(type.pattern),
-              firstDeclaration: getLocation((_s = symbol == null ? void 0 : symbol.declarations) == null ? void 0 : _s[0]),
-              flags: Debug.formatTypeFlags(type.flags).split("|"),
-              display
-            };
-            fs.writeSync(typesFd, JSON.stringify(descriptor));
-            if (i < numTypes - 1) {
-              fs.writeSync(typesFd, ",\n");
-            }
-          }
-          fs.writeSync(typesFd, "]\n");
-          fs.closeSync(typesFd);
-          mark("endDumpTypes");
-          measure("Dump types", "beginDumpTypes", "endDumpTypes");
-        }
-        function dumpLegend() {
-          if (!legendPath) {
-            return;
-          }
-          fs.writeFileSync(legendPath, JSON.stringify(legend));
-        }
-        tracingEnabled2.dumpLegend = dumpLegend;
-      })(tracingEnabled || (tracingEnabled = {}));
-      startTracing = tracingEnabled.startTracing;
-      dumpTracingLegend = tracingEnabled.dumpLegend;
-    }
-  });
-
-  // src/compiler/types.ts
-  function diagnosticCategoryName(d, lowerCase = true) {
-    const name = DiagnosticCategory[d.category];
-    return lowerCase ? name.toLowerCase() : name;
-  }
-  var SyntaxKind, NodeFlags, ModifierFlags, JsxFlags, RelationComparisonResult, GeneratedIdentifierFlags, TokenFlags, FlowFlags, CommentDirectiveType, OperationCanceledException, FileIncludeKind, FilePreprocessingDiagnosticsKind, EmitOnly, StructureIsReused, ExitStatus, MemberOverrideStatus, UnionReduction, ContextFlags, NodeBuilderFlags, TypeFormatFlags, SymbolFormatFlags, SymbolAccessibility, SyntheticSymbolKind, TypePredicateKind, TypeReferenceSerializationKind, SymbolFlags, EnumKind, CheckFlags, InternalSymbolName, NodeCheckFlags, TypeFlags, ObjectFlags, VarianceFlags, ElementFlags, AccessFlags, IndexFlags, JsxReferenceKind, SignatureKind, SignatureFlags, IndexKind, TypeMapKind, InferencePriority, InferenceFlags, Ternary, AssignmentDeclarationKind, DiagnosticCategory, ModuleResolutionKind, ModuleDetectionKind, WatchFileKind, WatchDirectoryKind, PollingWatchKind, ModuleKind, JsxEmit, ImportsNotUsedAsValues, NewLineKind, ScriptKind, ScriptTarget, LanguageVariant, WatchDirectoryFlags, CharacterCodes, Extension, TransformFlags, SnippetKind, EmitFlags, InternalEmitFlags, ExternalEmitHelpers, EmitHint, OuterExpressionKinds, LexicalEnvironmentFlags, BundleFileSectionKind, ListFormat, PragmaKindFlags, commentPragmas;
+  var SyntaxKind, NodeFlags, ModifierFlags, JsxFlags, RelationComparisonResult, GeneratedIdentifierFlags, TokenFlags, FlowFlags, CommentDirectiveType, OperationCanceledException, FileIncludeKind, FilePreprocessingDiagnosticsKind, EmitOnly, StructureIsReused, ExitStatus, MemberOverrideStatus, UnionReduction, ContextFlags, NodeBuilderFlags, TypeFormatFlags, SymbolFormatFlags, SymbolAccessibility, SyntheticSymbolKind, TypePredicateKind, TypeReferenceSerializationKind, SymbolFlags, EnumKind, CheckFlags, InternalSymbolName, NodeCheckFlags, TypeFlags, ObjectFlags, VarianceFlags, ElementFlags, AccessFlags, IndexFlags, JsxReferenceKind, SignatureKind, SignatureFlags, IndexKind, TypeMapKind, InferencePriority, InferenceFlags, Ternary, AssignmentDeclarationKind, DiagnosticCategory, ModuleResolutionKind, ModuleDetectionKind, WatchFileKind, WatchDirectoryKind, PollingWatchKind, ModuleKind, JsxEmit, ImportsNotUsedAsValues, NewLineKind, ScriptKind, ScriptTarget, LanguageVariant, WatchDirectoryFlags, CharacterCodes, Extension, TransformFlags, SnippetKind, EmitFlags, InternalEmitFlags, ExternalEmitHelpers, EmitHint, OuterExpressionKinds, LexicalEnvironmentFlags, BundleFileSectionKind, ListFormat, PragmaKindFlags, commentPragmas, JSDocParsingMode;
   var init_types = __esm({
     "src/compiler/types.ts"() {
       "use strict";
@@ -103045,210 +85639,213 @@ ${lanes.join("\n")}
         SyntaxKind5[SyntaxKind5["UndefinedKeyword"] = 157] = "UndefinedKeyword";
         SyntaxKind5[SyntaxKind5["UniqueKeyword"] = 158] = "UniqueKeyword";
         SyntaxKind5[SyntaxKind5["UnknownKeyword"] = 159] = "UnknownKeyword";
-        SyntaxKind5[SyntaxKind5["FromKeyword"] = 160] = "FromKeyword";
-        SyntaxKind5[SyntaxKind5["GlobalKeyword"] = 161] = "GlobalKeyword";
-        SyntaxKind5[SyntaxKind5["BigIntKeyword"] = 162] = "BigIntKeyword";
-        SyntaxKind5[SyntaxKind5["OverrideKeyword"] = 163] = "OverrideKeyword";
-        SyntaxKind5[SyntaxKind5["OfKeyword"] = 164] = "OfKeyword";
-        SyntaxKind5[SyntaxKind5["QualifiedName"] = 165] = "QualifiedName";
-        SyntaxKind5[SyntaxKind5["ComputedPropertyName"] = 166] = "ComputedPropertyName";
-        SyntaxKind5[SyntaxKind5["TypeParameter"] = 167] = "TypeParameter";
-        SyntaxKind5[SyntaxKind5["Parameter"] = 168] = "Parameter";
-        SyntaxKind5[SyntaxKind5["Decorator"] = 169] = "Decorator";
-        SyntaxKind5[SyntaxKind5["PropertySignature"] = 170] = "PropertySignature";
-        SyntaxKind5[SyntaxKind5["PropertyDeclaration"] = 171] = "PropertyDeclaration";
-        SyntaxKind5[SyntaxKind5["MethodSignature"] = 172] = "MethodSignature";
-        SyntaxKind5[SyntaxKind5["MethodDeclaration"] = 173] = "MethodDeclaration";
-        SyntaxKind5[SyntaxKind5["ClassStaticBlockDeclaration"] = 174] = "ClassStaticBlockDeclaration";
-        SyntaxKind5[SyntaxKind5["Constructor"] = 175] = "Constructor";
-        SyntaxKind5[SyntaxKind5["GetAccessor"] = 176] = "GetAccessor";
-        SyntaxKind5[SyntaxKind5["SetAccessor"] = 177] = "SetAccessor";
-        SyntaxKind5[SyntaxKind5["CallSignature"] = 178] = "CallSignature";
-        SyntaxKind5[SyntaxKind5["ConstructSignature"] = 179] = "ConstructSignature";
-        SyntaxKind5[SyntaxKind5["IndexSignature"] = 180] = "IndexSignature";
-        SyntaxKind5[SyntaxKind5["TypePredicate"] = 181] = "TypePredicate";
-        SyntaxKind5[SyntaxKind5["TypeReference"] = 182] = "TypeReference";
-        SyntaxKind5[SyntaxKind5["FunctionType"] = 183] = "FunctionType";
-        SyntaxKind5[SyntaxKind5["ConstructorType"] = 184] = "ConstructorType";
-        SyntaxKind5[SyntaxKind5["TypeQuery"] = 185] = "TypeQuery";
-        SyntaxKind5[SyntaxKind5["TypeLiteral"] = 186] = "TypeLiteral";
-        SyntaxKind5[SyntaxKind5["ArrayType"] = 187] = "ArrayType";
-        SyntaxKind5[SyntaxKind5["TupleType"] = 188] = "TupleType";
-        SyntaxKind5[SyntaxKind5["OptionalType"] = 189] = "OptionalType";
-        SyntaxKind5[SyntaxKind5["RestType"] = 190] = "RestType";
-        SyntaxKind5[SyntaxKind5["UnionType"] = 191] = "UnionType";
-        SyntaxKind5[SyntaxKind5["IntersectionType"] = 192] = "IntersectionType";
-        SyntaxKind5[SyntaxKind5["ConditionalType"] = 193] = "ConditionalType";
-        SyntaxKind5[SyntaxKind5["InferType"] = 194] = "InferType";
-        SyntaxKind5[SyntaxKind5["ParenthesizedType"] = 195] = "ParenthesizedType";
-        SyntaxKind5[SyntaxKind5["ThisType"] = 196] = "ThisType";
-        SyntaxKind5[SyntaxKind5["TypeOperator"] = 197] = "TypeOperator";
-        SyntaxKind5[SyntaxKind5["IndexedAccessType"] = 198] = "IndexedAccessType";
-        SyntaxKind5[SyntaxKind5["MappedType"] = 199] = "MappedType";
-        SyntaxKind5[SyntaxKind5["LiteralType"] = 200] = "LiteralType";
-        SyntaxKind5[SyntaxKind5["NamedTupleMember"] = 201] = "NamedTupleMember";
-        SyntaxKind5[SyntaxKind5["TemplateLiteralType"] = 202] = "TemplateLiteralType";
-        SyntaxKind5[SyntaxKind5["TemplateLiteralTypeSpan"] = 203] = "TemplateLiteralTypeSpan";
-        SyntaxKind5[SyntaxKind5["ImportType"] = 204] = "ImportType";
-        SyntaxKind5[SyntaxKind5["ObjectBindingPattern"] = 205] = "ObjectBindingPattern";
-        SyntaxKind5[SyntaxKind5["ArrayBindingPattern"] = 206] = "ArrayBindingPattern";
-        SyntaxKind5[SyntaxKind5["BindingElement"] = 207] = "BindingElement";
-        SyntaxKind5[SyntaxKind5["ArrayLiteralExpression"] = 208] = "ArrayLiteralExpression";
-        SyntaxKind5[SyntaxKind5["ObjectLiteralExpression"] = 209] = "ObjectLiteralExpression";
-        SyntaxKind5[SyntaxKind5["PropertyAccessExpression"] = 210] = "PropertyAccessExpression";
-        SyntaxKind5[SyntaxKind5["ElementAccessExpression"] = 211] = "ElementAccessExpression";
-        SyntaxKind5[SyntaxKind5["CallExpression"] = 212] = "CallExpression";
-        SyntaxKind5[SyntaxKind5["NewExpression"] = 213] = "NewExpression";
-        SyntaxKind5[SyntaxKind5["TaggedTemplateExpression"] = 214] = "TaggedTemplateExpression";
-        SyntaxKind5[SyntaxKind5["TypeAssertionExpression"] = 215] = "TypeAssertionExpression";
-        SyntaxKind5[SyntaxKind5["ParenthesizedExpression"] = 216] = "ParenthesizedExpression";
-        SyntaxKind5[SyntaxKind5["FunctionExpression"] = 217] = "FunctionExpression";
-        SyntaxKind5[SyntaxKind5["ArrowFunction"] = 218] = "ArrowFunction";
-        SyntaxKind5[SyntaxKind5["DeleteExpression"] = 219] = "DeleteExpression";
-        SyntaxKind5[SyntaxKind5["TypeOfExpression"] = 220] = "TypeOfExpression";
-        SyntaxKind5[SyntaxKind5["VoidExpression"] = 221] = "VoidExpression";
-        SyntaxKind5[SyntaxKind5["AwaitExpression"] = 222] = "AwaitExpression";
-        SyntaxKind5[SyntaxKind5["PrefixUnaryExpression"] = 223] = "PrefixUnaryExpression";
-        SyntaxKind5[SyntaxKind5["PostfixUnaryExpression"] = 224] = "PostfixUnaryExpression";
-        SyntaxKind5[SyntaxKind5["BinaryExpression"] = 225] = "BinaryExpression";
-        SyntaxKind5[SyntaxKind5["ConditionalExpression"] = 226] = "ConditionalExpression";
-        SyntaxKind5[SyntaxKind5["TemplateExpression"] = 227] = "TemplateExpression";
-        SyntaxKind5[SyntaxKind5["YieldExpression"] = 228] = "YieldExpression";
-        SyntaxKind5[SyntaxKind5["SpreadElement"] = 229] = "SpreadElement";
-        SyntaxKind5[SyntaxKind5["ClassExpression"] = 230] = "ClassExpression";
-        SyntaxKind5[SyntaxKind5["OmittedExpression"] = 231] = "OmittedExpression";
-        SyntaxKind5[SyntaxKind5["ExpressionWithTypeArguments"] = 232] = "ExpressionWithTypeArguments";
-        SyntaxKind5[SyntaxKind5["AsExpression"] = 233] = "AsExpression";
-        SyntaxKind5[SyntaxKind5["NonNullExpression"] = 234] = "NonNullExpression";
-        SyntaxKind5[SyntaxKind5["MetaProperty"] = 235] = "MetaProperty";
-        SyntaxKind5[SyntaxKind5["SyntheticExpression"] = 236] = "SyntheticExpression";
-        SyntaxKind5[SyntaxKind5["SatisfiesExpression"] = 237] = "SatisfiesExpression";
-        SyntaxKind5[SyntaxKind5["TemplateSpan"] = 238] = "TemplateSpan";
-        SyntaxKind5[SyntaxKind5["SemicolonClassElement"] = 239] = "SemicolonClassElement";
-        SyntaxKind5[SyntaxKind5["Block"] = 240] = "Block";
-        SyntaxKind5[SyntaxKind5["EmptyStatement"] = 241] = "EmptyStatement";
-        SyntaxKind5[SyntaxKind5["VariableStatement"] = 242] = "VariableStatement";
-        SyntaxKind5[SyntaxKind5["ExpressionStatement"] = 243] = "ExpressionStatement";
-        SyntaxKind5[SyntaxKind5["IfStatement"] = 244] = "IfStatement";
-        SyntaxKind5[SyntaxKind5["DoStatement"] = 245] = "DoStatement";
-        SyntaxKind5[SyntaxKind5["WhileStatement"] = 246] = "WhileStatement";
-        SyntaxKind5[SyntaxKind5["ForStatement"] = 247] = "ForStatement";
-        SyntaxKind5[SyntaxKind5["ForInStatement"] = 248] = "ForInStatement";
-        SyntaxKind5[SyntaxKind5["ForOfStatement"] = 249] = "ForOfStatement";
-        SyntaxKind5[SyntaxKind5["ContinueStatement"] = 250] = "ContinueStatement";
-        SyntaxKind5[SyntaxKind5["BreakStatement"] = 251] = "BreakStatement";
-        SyntaxKind5[SyntaxKind5["ReturnStatement"] = 252] = "ReturnStatement";
-        SyntaxKind5[SyntaxKind5["WithStatement"] = 253] = "WithStatement";
-        SyntaxKind5[SyntaxKind5["SwitchStatement"] = 254] = "SwitchStatement";
-        SyntaxKind5[SyntaxKind5["LabeledStatement"] = 255] = "LabeledStatement";
-        SyntaxKind5[SyntaxKind5["ThrowStatement"] = 256] = "ThrowStatement";
-        SyntaxKind5[SyntaxKind5["TryStatement"] = 257] = "TryStatement";
-        SyntaxKind5[SyntaxKind5["DebuggerStatement"] = 258] = "DebuggerStatement";
-        SyntaxKind5[SyntaxKind5["VariableDeclaration"] = 259] = "VariableDeclaration";
-        SyntaxKind5[SyntaxKind5["VariableDeclarationList"] = 260] = "VariableDeclarationList";
-        SyntaxKind5[SyntaxKind5["FunctionDeclaration"] = 261] = "FunctionDeclaration";
-        SyntaxKind5[SyntaxKind5["ClassDeclaration"] = 262] = "ClassDeclaration";
-        SyntaxKind5[SyntaxKind5["InterfaceDeclaration"] = 263] = "InterfaceDeclaration";
-        SyntaxKind5[SyntaxKind5["TypeAliasDeclaration"] = 264] = "TypeAliasDeclaration";
-        SyntaxKind5[SyntaxKind5["EnumDeclaration"] = 265] = "EnumDeclaration";
-        SyntaxKind5[SyntaxKind5["ModuleDeclaration"] = 266] = "ModuleDeclaration";
-        SyntaxKind5[SyntaxKind5["ModuleBlock"] = 267] = "ModuleBlock";
-        SyntaxKind5[SyntaxKind5["CaseBlock"] = 268] = "CaseBlock";
-        SyntaxKind5[SyntaxKind5["NamespaceExportDeclaration"] = 269] = "NamespaceExportDeclaration";
-        SyntaxKind5[SyntaxKind5["ImportEqualsDeclaration"] = 270] = "ImportEqualsDeclaration";
-        SyntaxKind5[SyntaxKind5["ImportDeclaration"] = 271] = "ImportDeclaration";
-        SyntaxKind5[SyntaxKind5["ImportClause"] = 272] = "ImportClause";
-        SyntaxKind5[SyntaxKind5["NamespaceImport"] = 273] = "NamespaceImport";
-        SyntaxKind5[SyntaxKind5["NamedImports"] = 274] = "NamedImports";
-        SyntaxKind5[SyntaxKind5["ImportSpecifier"] = 275] = "ImportSpecifier";
-        SyntaxKind5[SyntaxKind5["ExportAssignment"] = 276] = "ExportAssignment";
-        SyntaxKind5[SyntaxKind5["ExportDeclaration"] = 277] = "ExportDeclaration";
-        SyntaxKind5[SyntaxKind5["NamedExports"] = 278] = "NamedExports";
-        SyntaxKind5[SyntaxKind5["NamespaceExport"] = 279] = "NamespaceExport";
-        SyntaxKind5[SyntaxKind5["ExportSpecifier"] = 280] = "ExportSpecifier";
-        SyntaxKind5[SyntaxKind5["MissingDeclaration"] = 281] = "MissingDeclaration";
-        SyntaxKind5[SyntaxKind5["ExternalModuleReference"] = 282] = "ExternalModuleReference";
-        SyntaxKind5[SyntaxKind5["JsxElement"] = 283] = "JsxElement";
-        SyntaxKind5[SyntaxKind5["JsxSelfClosingElement"] = 284] = "JsxSelfClosingElement";
-        SyntaxKind5[SyntaxKind5["JsxOpeningElement"] = 285] = "JsxOpeningElement";
-        SyntaxKind5[SyntaxKind5["JsxClosingElement"] = 286] = "JsxClosingElement";
-        SyntaxKind5[SyntaxKind5["JsxFragment"] = 287] = "JsxFragment";
-        SyntaxKind5[SyntaxKind5["JsxOpeningFragment"] = 288] = "JsxOpeningFragment";
-        SyntaxKind5[SyntaxKind5["JsxClosingFragment"] = 289] = "JsxClosingFragment";
-        SyntaxKind5[SyntaxKind5["JsxAttribute"] = 290] = "JsxAttribute";
-        SyntaxKind5[SyntaxKind5["JsxAttributes"] = 291] = "JsxAttributes";
-        SyntaxKind5[SyntaxKind5["JsxSpreadAttribute"] = 292] = "JsxSpreadAttribute";
-        SyntaxKind5[SyntaxKind5["JsxExpression"] = 293] = "JsxExpression";
-        SyntaxKind5[SyntaxKind5["JsxNamespacedName"] = 294] = "JsxNamespacedName";
-        SyntaxKind5[SyntaxKind5["CaseClause"] = 295] = "CaseClause";
-        SyntaxKind5[SyntaxKind5["DefaultClause"] = 296] = "DefaultClause";
-        SyntaxKind5[SyntaxKind5["HeritageClause"] = 297] = "HeritageClause";
-        SyntaxKind5[SyntaxKind5["CatchClause"] = 298] = "CatchClause";
-        SyntaxKind5[SyntaxKind5["AssertClause"] = 299] = "AssertClause";
-        SyntaxKind5[SyntaxKind5["AssertEntry"] = 300] = "AssertEntry";
-        SyntaxKind5[SyntaxKind5["ImportTypeAssertionContainer"] = 301] = "ImportTypeAssertionContainer";
-        SyntaxKind5[SyntaxKind5["PropertyAssignment"] = 302] = "PropertyAssignment";
-        SyntaxKind5[SyntaxKind5["ShorthandPropertyAssignment"] = 303] = "ShorthandPropertyAssignment";
-        SyntaxKind5[SyntaxKind5["SpreadAssignment"] = 304] = "SpreadAssignment";
-        SyntaxKind5[SyntaxKind5["EnumMember"] = 305] = "EnumMember";
-        SyntaxKind5[SyntaxKind5["UnparsedPrologue"] = 306] = "UnparsedPrologue";
-        SyntaxKind5[SyntaxKind5["UnparsedPrepend"] = 307] = "UnparsedPrepend";
-        SyntaxKind5[SyntaxKind5["UnparsedText"] = 308] = "UnparsedText";
-        SyntaxKind5[SyntaxKind5["UnparsedInternalText"] = 309] = "UnparsedInternalText";
-        SyntaxKind5[SyntaxKind5["UnparsedSyntheticReference"] = 310] = "UnparsedSyntheticReference";
-        SyntaxKind5[SyntaxKind5["SourceFile"] = 311] = "SourceFile";
-        SyntaxKind5[SyntaxKind5["Bundle"] = 312] = "Bundle";
-        SyntaxKind5[SyntaxKind5["UnparsedSource"] = 313] = "UnparsedSource";
-        SyntaxKind5[SyntaxKind5["InputFiles"] = 314] = "InputFiles";
-        SyntaxKind5[SyntaxKind5["JSDocTypeExpression"] = 315] = "JSDocTypeExpression";
-        SyntaxKind5[SyntaxKind5["JSDocNameReference"] = 316] = "JSDocNameReference";
-        SyntaxKind5[SyntaxKind5["JSDocMemberName"] = 317] = "JSDocMemberName";
-        SyntaxKind5[SyntaxKind5["JSDocAllType"] = 318] = "JSDocAllType";
-        SyntaxKind5[SyntaxKind5["JSDocUnknownType"] = 319] = "JSDocUnknownType";
-        SyntaxKind5[SyntaxKind5["JSDocNullableType"] = 320] = "JSDocNullableType";
-        SyntaxKind5[SyntaxKind5["JSDocNonNullableType"] = 321] = "JSDocNonNullableType";
-        SyntaxKind5[SyntaxKind5["JSDocOptionalType"] = 322] = "JSDocOptionalType";
-        SyntaxKind5[SyntaxKind5["JSDocFunctionType"] = 323] = "JSDocFunctionType";
-        SyntaxKind5[SyntaxKind5["JSDocVariadicType"] = 324] = "JSDocVariadicType";
-        SyntaxKind5[SyntaxKind5["JSDocNamepathType"] = 325] = "JSDocNamepathType";
-        SyntaxKind5[SyntaxKind5["JSDoc"] = 326] = "JSDoc";
-        SyntaxKind5[SyntaxKind5["JSDocComment"] = 326 /* JSDoc */] = "JSDocComment";
-        SyntaxKind5[SyntaxKind5["JSDocText"] = 327] = "JSDocText";
-        SyntaxKind5[SyntaxKind5["JSDocTypeLiteral"] = 328] = "JSDocTypeLiteral";
-        SyntaxKind5[SyntaxKind5["JSDocSignature"] = 329] = "JSDocSignature";
-        SyntaxKind5[SyntaxKind5["JSDocLink"] = 330] = "JSDocLink";
-        SyntaxKind5[SyntaxKind5["JSDocLinkCode"] = 331] = "JSDocLinkCode";
-        SyntaxKind5[SyntaxKind5["JSDocLinkPlain"] = 332] = "JSDocLinkPlain";
-        SyntaxKind5[SyntaxKind5["JSDocTag"] = 333] = "JSDocTag";
-        SyntaxKind5[SyntaxKind5["JSDocAugmentsTag"] = 334] = "JSDocAugmentsTag";
-        SyntaxKind5[SyntaxKind5["JSDocImplementsTag"] = 335] = "JSDocImplementsTag";
-        SyntaxKind5[SyntaxKind5["JSDocAuthorTag"] = 336] = "JSDocAuthorTag";
-        SyntaxKind5[SyntaxKind5["JSDocDeprecatedTag"] = 337] = "JSDocDeprecatedTag";
-        SyntaxKind5[SyntaxKind5["JSDocClassTag"] = 338] = "JSDocClassTag";
-        SyntaxKind5[SyntaxKind5["JSDocPublicTag"] = 339] = "JSDocPublicTag";
-        SyntaxKind5[SyntaxKind5["JSDocPrivateTag"] = 340] = "JSDocPrivateTag";
-        SyntaxKind5[SyntaxKind5["JSDocProtectedTag"] = 341] = "JSDocProtectedTag";
-        SyntaxKind5[SyntaxKind5["JSDocReadonlyTag"] = 342] = "JSDocReadonlyTag";
-        SyntaxKind5[SyntaxKind5["JSDocOverrideTag"] = 343] = "JSDocOverrideTag";
-        SyntaxKind5[SyntaxKind5["JSDocCallbackTag"] = 344] = "JSDocCallbackTag";
-        SyntaxKind5[SyntaxKind5["JSDocOverloadTag"] = 345] = "JSDocOverloadTag";
-        SyntaxKind5[SyntaxKind5["JSDocEnumTag"] = 346] = "JSDocEnumTag";
-        SyntaxKind5[SyntaxKind5["JSDocParameterTag"] = 347] = "JSDocParameterTag";
-        SyntaxKind5[SyntaxKind5["JSDocReturnTag"] = 348] = "JSDocReturnTag";
-        SyntaxKind5[SyntaxKind5["JSDocThisTag"] = 349] = "JSDocThisTag";
-        SyntaxKind5[SyntaxKind5["JSDocTypeTag"] = 350] = "JSDocTypeTag";
-        SyntaxKind5[SyntaxKind5["JSDocTemplateTag"] = 351] = "JSDocTemplateTag";
-        SyntaxKind5[SyntaxKind5["JSDocTypedefTag"] = 352] = "JSDocTypedefTag";
-        SyntaxKind5[SyntaxKind5["JSDocSeeTag"] = 353] = "JSDocSeeTag";
-        SyntaxKind5[SyntaxKind5["JSDocPropertyTag"] = 354] = "JSDocPropertyTag";
-        SyntaxKind5[SyntaxKind5["JSDocThrowsTag"] = 355] = "JSDocThrowsTag";
-        SyntaxKind5[SyntaxKind5["JSDocSatisfiesTag"] = 356] = "JSDocSatisfiesTag";
-        SyntaxKind5[SyntaxKind5["SyntaxList"] = 357] = "SyntaxList";
-        SyntaxKind5[SyntaxKind5["NotEmittedStatement"] = 358] = "NotEmittedStatement";
-        SyntaxKind5[SyntaxKind5["PartiallyEmittedExpression"] = 359] = "PartiallyEmittedExpression";
-        SyntaxKind5[SyntaxKind5["CommaListExpression"] = 360] = "CommaListExpression";
-        SyntaxKind5[SyntaxKind5["SyntheticReferenceExpression"] = 361] = "SyntheticReferenceExpression";
-        SyntaxKind5[SyntaxKind5["Count"] = 362] = "Count";
+        SyntaxKind5[SyntaxKind5["UsingKeyword"] = 160] = "UsingKeyword";
+        SyntaxKind5[SyntaxKind5["FromKeyword"] = 161] = "FromKeyword";
+        SyntaxKind5[SyntaxKind5["GlobalKeyword"] = 162] = "GlobalKeyword";
+        SyntaxKind5[SyntaxKind5["BigIntKeyword"] = 163] = "BigIntKeyword";
+        SyntaxKind5[SyntaxKind5["OverrideKeyword"] = 164] = "OverrideKeyword";
+        SyntaxKind5[SyntaxKind5["OfKeyword"] = 165] = "OfKeyword";
+        SyntaxKind5[SyntaxKind5["QualifiedName"] = 166] = "QualifiedName";
+        SyntaxKind5[SyntaxKind5["ComputedPropertyName"] = 167] = "ComputedPropertyName";
+        SyntaxKind5[SyntaxKind5["TypeParameter"] = 168] = "TypeParameter";
+        SyntaxKind5[SyntaxKind5["Parameter"] = 169] = "Parameter";
+        SyntaxKind5[SyntaxKind5["Decorator"] = 170] = "Decorator";
+        SyntaxKind5[SyntaxKind5["PropertySignature"] = 171] = "PropertySignature";
+        SyntaxKind5[SyntaxKind5["PropertyDeclaration"] = 172] = "PropertyDeclaration";
+        SyntaxKind5[SyntaxKind5["MethodSignature"] = 173] = "MethodSignature";
+        SyntaxKind5[SyntaxKind5["MethodDeclaration"] = 174] = "MethodDeclaration";
+        SyntaxKind5[SyntaxKind5["ClassStaticBlockDeclaration"] = 175] = "ClassStaticBlockDeclaration";
+        SyntaxKind5[SyntaxKind5["Constructor"] = 176] = "Constructor";
+        SyntaxKind5[SyntaxKind5["GetAccessor"] = 177] = "GetAccessor";
+        SyntaxKind5[SyntaxKind5["SetAccessor"] = 178] = "SetAccessor";
+        SyntaxKind5[SyntaxKind5["CallSignature"] = 179] = "CallSignature";
+        SyntaxKind5[SyntaxKind5["ConstructSignature"] = 180] = "ConstructSignature";
+        SyntaxKind5[SyntaxKind5["IndexSignature"] = 181] = "IndexSignature";
+        SyntaxKind5[SyntaxKind5["TypePredicate"] = 182] = "TypePredicate";
+        SyntaxKind5[SyntaxKind5["TypeReference"] = 183] = "TypeReference";
+        SyntaxKind5[SyntaxKind5["FunctionType"] = 184] = "FunctionType";
+        SyntaxKind5[SyntaxKind5["ConstructorType"] = 185] = "ConstructorType";
+        SyntaxKind5[SyntaxKind5["TypeQuery"] = 186] = "TypeQuery";
+        SyntaxKind5[SyntaxKind5["TypeLiteral"] = 187] = "TypeLiteral";
+        SyntaxKind5[SyntaxKind5["ArrayType"] = 188] = "ArrayType";
+        SyntaxKind5[SyntaxKind5["TupleType"] = 189] = "TupleType";
+        SyntaxKind5[SyntaxKind5["OptionalType"] = 190] = "OptionalType";
+        SyntaxKind5[SyntaxKind5["RestType"] = 191] = "RestType";
+        SyntaxKind5[SyntaxKind5["UnionType"] = 192] = "UnionType";
+        SyntaxKind5[SyntaxKind5["IntersectionType"] = 193] = "IntersectionType";
+        SyntaxKind5[SyntaxKind5["ConditionalType"] = 194] = "ConditionalType";
+        SyntaxKind5[SyntaxKind5["InferType"] = 195] = "InferType";
+        SyntaxKind5[SyntaxKind5["ParenthesizedType"] = 196] = "ParenthesizedType";
+        SyntaxKind5[SyntaxKind5["ThisType"] = 197] = "ThisType";
+        SyntaxKind5[SyntaxKind5["TypeOperator"] = 198] = "TypeOperator";
+        SyntaxKind5[SyntaxKind5["IndexedAccessType"] = 199] = "IndexedAccessType";
+        SyntaxKind5[SyntaxKind5["MappedType"] = 200] = "MappedType";
+        SyntaxKind5[SyntaxKind5["LiteralType"] = 201] = "LiteralType";
+        SyntaxKind5[SyntaxKind5["NamedTupleMember"] = 202] = "NamedTupleMember";
+        SyntaxKind5[SyntaxKind5["TemplateLiteralType"] = 203] = "TemplateLiteralType";
+        SyntaxKind5[SyntaxKind5["TemplateLiteralTypeSpan"] = 204] = "TemplateLiteralTypeSpan";
+        SyntaxKind5[SyntaxKind5["ImportType"] = 205] = "ImportType";
+        SyntaxKind5[SyntaxKind5["ObjectBindingPattern"] = 206] = "ObjectBindingPattern";
+        SyntaxKind5[SyntaxKind5["ArrayBindingPattern"] = 207] = "ArrayBindingPattern";
+        SyntaxKind5[SyntaxKind5["BindingElement"] = 208] = "BindingElement";
+        SyntaxKind5[SyntaxKind5["ArrayLiteralExpression"] = 209] = "ArrayLiteralExpression";
+        SyntaxKind5[SyntaxKind5["ObjectLiteralExpression"] = 210] = "ObjectLiteralExpression";
+        SyntaxKind5[SyntaxKind5["PropertyAccessExpression"] = 211] = "PropertyAccessExpression";
+        SyntaxKind5[SyntaxKind5["ElementAccessExpression"] = 212] = "ElementAccessExpression";
+        SyntaxKind5[SyntaxKind5["CallExpression"] = 213] = "CallExpression";
+        SyntaxKind5[SyntaxKind5["NewExpression"] = 214] = "NewExpression";
+        SyntaxKind5[SyntaxKind5["TaggedTemplateExpression"] = 215] = "TaggedTemplateExpression";
+        SyntaxKind5[SyntaxKind5["TypeAssertionExpression"] = 216] = "TypeAssertionExpression";
+        SyntaxKind5[SyntaxKind5["ParenthesizedExpression"] = 217] = "ParenthesizedExpression";
+        SyntaxKind5[SyntaxKind5["FunctionExpression"] = 218] = "FunctionExpression";
+        SyntaxKind5[SyntaxKind5["ArrowFunction"] = 219] = "ArrowFunction";
+        SyntaxKind5[SyntaxKind5["DeleteExpression"] = 220] = "DeleteExpression";
+        SyntaxKind5[SyntaxKind5["TypeOfExpression"] = 221] = "TypeOfExpression";
+        SyntaxKind5[SyntaxKind5["VoidExpression"] = 222] = "VoidExpression";
+        SyntaxKind5[SyntaxKind5["AwaitExpression"] = 223] = "AwaitExpression";
+        SyntaxKind5[SyntaxKind5["PrefixUnaryExpression"] = 224] = "PrefixUnaryExpression";
+        SyntaxKind5[SyntaxKind5["PostfixUnaryExpression"] = 225] = "PostfixUnaryExpression";
+        SyntaxKind5[SyntaxKind5["BinaryExpression"] = 226] = "BinaryExpression";
+        SyntaxKind5[SyntaxKind5["ConditionalExpression"] = 227] = "ConditionalExpression";
+        SyntaxKind5[SyntaxKind5["TemplateExpression"] = 228] = "TemplateExpression";
+        SyntaxKind5[SyntaxKind5["YieldExpression"] = 229] = "YieldExpression";
+        SyntaxKind5[SyntaxKind5["SpreadElement"] = 230] = "SpreadElement";
+        SyntaxKind5[SyntaxKind5["ClassExpression"] = 231] = "ClassExpression";
+        SyntaxKind5[SyntaxKind5["OmittedExpression"] = 232] = "OmittedExpression";
+        SyntaxKind5[SyntaxKind5["ExpressionWithTypeArguments"] = 233] = "ExpressionWithTypeArguments";
+        SyntaxKind5[SyntaxKind5["AsExpression"] = 234] = "AsExpression";
+        SyntaxKind5[SyntaxKind5["NonNullExpression"] = 235] = "NonNullExpression";
+        SyntaxKind5[SyntaxKind5["MetaProperty"] = 236] = "MetaProperty";
+        SyntaxKind5[SyntaxKind5["SyntheticExpression"] = 237] = "SyntheticExpression";
+        SyntaxKind5[SyntaxKind5["SatisfiesExpression"] = 238] = "SatisfiesExpression";
+        SyntaxKind5[SyntaxKind5["TemplateSpan"] = 239] = "TemplateSpan";
+        SyntaxKind5[SyntaxKind5["SemicolonClassElement"] = 240] = "SemicolonClassElement";
+        SyntaxKind5[SyntaxKind5["Block"] = 241] = "Block";
+        SyntaxKind5[SyntaxKind5["EmptyStatement"] = 242] = "EmptyStatement";
+        SyntaxKind5[SyntaxKind5["VariableStatement"] = 243] = "VariableStatement";
+        SyntaxKind5[SyntaxKind5["ExpressionStatement"] = 244] = "ExpressionStatement";
+        SyntaxKind5[SyntaxKind5["IfStatement"] = 245] = "IfStatement";
+        SyntaxKind5[SyntaxKind5["DoStatement"] = 246] = "DoStatement";
+        SyntaxKind5[SyntaxKind5["WhileStatement"] = 247] = "WhileStatement";
+        SyntaxKind5[SyntaxKind5["ForStatement"] = 248] = "ForStatement";
+        SyntaxKind5[SyntaxKind5["ForInStatement"] = 249] = "ForInStatement";
+        SyntaxKind5[SyntaxKind5["ForOfStatement"] = 250] = "ForOfStatement";
+        SyntaxKind5[SyntaxKind5["ContinueStatement"] = 251] = "ContinueStatement";
+        SyntaxKind5[SyntaxKind5["BreakStatement"] = 252] = "BreakStatement";
+        SyntaxKind5[SyntaxKind5["ReturnStatement"] = 253] = "ReturnStatement";
+        SyntaxKind5[SyntaxKind5["WithStatement"] = 254] = "WithStatement";
+        SyntaxKind5[SyntaxKind5["SwitchStatement"] = 255] = "SwitchStatement";
+        SyntaxKind5[SyntaxKind5["LabeledStatement"] = 256] = "LabeledStatement";
+        SyntaxKind5[SyntaxKind5["ThrowStatement"] = 257] = "ThrowStatement";
+        SyntaxKind5[SyntaxKind5["TryStatement"] = 258] = "TryStatement";
+        SyntaxKind5[SyntaxKind5["DebuggerStatement"] = 259] = "DebuggerStatement";
+        SyntaxKind5[SyntaxKind5["VariableDeclaration"] = 260] = "VariableDeclaration";
+        SyntaxKind5[SyntaxKind5["VariableDeclarationList"] = 261] = "VariableDeclarationList";
+        SyntaxKind5[SyntaxKind5["FunctionDeclaration"] = 262] = "FunctionDeclaration";
+        SyntaxKind5[SyntaxKind5["ClassDeclaration"] = 263] = "ClassDeclaration";
+        SyntaxKind5[SyntaxKind5["InterfaceDeclaration"] = 264] = "InterfaceDeclaration";
+        SyntaxKind5[SyntaxKind5["TypeAliasDeclaration"] = 265] = "TypeAliasDeclaration";
+        SyntaxKind5[SyntaxKind5["EnumDeclaration"] = 266] = "EnumDeclaration";
+        SyntaxKind5[SyntaxKind5["ModuleDeclaration"] = 267] = "ModuleDeclaration";
+        SyntaxKind5[SyntaxKind5["ModuleBlock"] = 268] = "ModuleBlock";
+        SyntaxKind5[SyntaxKind5["CaseBlock"] = 269] = "CaseBlock";
+        SyntaxKind5[SyntaxKind5["NamespaceExportDeclaration"] = 270] = "NamespaceExportDeclaration";
+        SyntaxKind5[SyntaxKind5["ImportEqualsDeclaration"] = 271] = "ImportEqualsDeclaration";
+        SyntaxKind5[SyntaxKind5["ImportDeclaration"] = 272] = "ImportDeclaration";
+        SyntaxKind5[SyntaxKind5["ImportClause"] = 273] = "ImportClause";
+        SyntaxKind5[SyntaxKind5["NamespaceImport"] = 274] = "NamespaceImport";
+        SyntaxKind5[SyntaxKind5["NamedImports"] = 275] = "NamedImports";
+        SyntaxKind5[SyntaxKind5["ImportSpecifier"] = 276] = "ImportSpecifier";
+        SyntaxKind5[SyntaxKind5["ExportAssignment"] = 277] = "ExportAssignment";
+        SyntaxKind5[SyntaxKind5["ExportDeclaration"] = 278] = "ExportDeclaration";
+        SyntaxKind5[SyntaxKind5["NamedExports"] = 279] = "NamedExports";
+        SyntaxKind5[SyntaxKind5["NamespaceExport"] = 280] = "NamespaceExport";
+        SyntaxKind5[SyntaxKind5["ExportSpecifier"] = 281] = "ExportSpecifier";
+        SyntaxKind5[SyntaxKind5["MissingDeclaration"] = 282] = "MissingDeclaration";
+        SyntaxKind5[SyntaxKind5["ExternalModuleReference"] = 283] = "ExternalModuleReference";
+        SyntaxKind5[SyntaxKind5["JsxElement"] = 284] = "JsxElement";
+        SyntaxKind5[SyntaxKind5["JsxSelfClosingElement"] = 285] = "JsxSelfClosingElement";
+        SyntaxKind5[SyntaxKind5["JsxOpeningElement"] = 286] = "JsxOpeningElement";
+        SyntaxKind5[SyntaxKind5["JsxClosingElement"] = 287] = "JsxClosingElement";
+        SyntaxKind5[SyntaxKind5["JsxFragment"] = 288] = "JsxFragment";
+        SyntaxKind5[SyntaxKind5["JsxOpeningFragment"] = 289] = "JsxOpeningFragment";
+        SyntaxKind5[SyntaxKind5["JsxClosingFragment"] = 290] = "JsxClosingFragment";
+        SyntaxKind5[SyntaxKind5["JsxAttribute"] = 291] = "JsxAttribute";
+        SyntaxKind5[SyntaxKind5["JsxAttributes"] = 292] = "JsxAttributes";
+        SyntaxKind5[SyntaxKind5["JsxSpreadAttribute"] = 293] = "JsxSpreadAttribute";
+        SyntaxKind5[SyntaxKind5["JsxExpression"] = 294] = "JsxExpression";
+        SyntaxKind5[SyntaxKind5["JsxNamespacedName"] = 295] = "JsxNamespacedName";
+        SyntaxKind5[SyntaxKind5["CaseClause"] = 296] = "CaseClause";
+        SyntaxKind5[SyntaxKind5["DefaultClause"] = 297] = "DefaultClause";
+        SyntaxKind5[SyntaxKind5["HeritageClause"] = 298] = "HeritageClause";
+        SyntaxKind5[SyntaxKind5["CatchClause"] = 299] = "CatchClause";
+        SyntaxKind5[SyntaxKind5["ImportAttributes"] = 300] = "ImportAttributes";
+        SyntaxKind5[SyntaxKind5["ImportAttribute"] = 301] = "ImportAttribute";
+        SyntaxKind5[SyntaxKind5["AssertClause"] = 300 /* ImportAttributes */] = "AssertClause";
+        SyntaxKind5[SyntaxKind5["AssertEntry"] = 301 /* ImportAttribute */] = "AssertEntry";
+        SyntaxKind5[SyntaxKind5["ImportTypeAssertionContainer"] = 302] = "ImportTypeAssertionContainer";
+        SyntaxKind5[SyntaxKind5["PropertyAssignment"] = 303] = "PropertyAssignment";
+        SyntaxKind5[SyntaxKind5["ShorthandPropertyAssignment"] = 304] = "ShorthandPropertyAssignment";
+        SyntaxKind5[SyntaxKind5["SpreadAssignment"] = 305] = "SpreadAssignment";
+        SyntaxKind5[SyntaxKind5["EnumMember"] = 306] = "EnumMember";
+        SyntaxKind5[SyntaxKind5["UnparsedPrologue"] = 307] = "UnparsedPrologue";
+        SyntaxKind5[SyntaxKind5["UnparsedPrepend"] = 308] = "UnparsedPrepend";
+        SyntaxKind5[SyntaxKind5["UnparsedText"] = 309] = "UnparsedText";
+        SyntaxKind5[SyntaxKind5["UnparsedInternalText"] = 310] = "UnparsedInternalText";
+        SyntaxKind5[SyntaxKind5["UnparsedSyntheticReference"] = 311] = "UnparsedSyntheticReference";
+        SyntaxKind5[SyntaxKind5["SourceFile"] = 312] = "SourceFile";
+        SyntaxKind5[SyntaxKind5["Bundle"] = 313] = "Bundle";
+        SyntaxKind5[SyntaxKind5["UnparsedSource"] = 314] = "UnparsedSource";
+        SyntaxKind5[SyntaxKind5["InputFiles"] = 315] = "InputFiles";
+        SyntaxKind5[SyntaxKind5["JSDocTypeExpression"] = 316] = "JSDocTypeExpression";
+        SyntaxKind5[SyntaxKind5["JSDocNameReference"] = 317] = "JSDocNameReference";
+        SyntaxKind5[SyntaxKind5["JSDocMemberName"] = 318] = "JSDocMemberName";
+        SyntaxKind5[SyntaxKind5["JSDocAllType"] = 319] = "JSDocAllType";
+        SyntaxKind5[SyntaxKind5["JSDocUnknownType"] = 320] = "JSDocUnknownType";
+        SyntaxKind5[SyntaxKind5["JSDocNullableType"] = 321] = "JSDocNullableType";
+        SyntaxKind5[SyntaxKind5["JSDocNonNullableType"] = 322] = "JSDocNonNullableType";
+        SyntaxKind5[SyntaxKind5["JSDocOptionalType"] = 323] = "JSDocOptionalType";
+        SyntaxKind5[SyntaxKind5["JSDocFunctionType"] = 324] = "JSDocFunctionType";
+        SyntaxKind5[SyntaxKind5["JSDocVariadicType"] = 325] = "JSDocVariadicType";
+        SyntaxKind5[SyntaxKind5["JSDocNamepathType"] = 326] = "JSDocNamepathType";
+        SyntaxKind5[SyntaxKind5["JSDoc"] = 327] = "JSDoc";
+        SyntaxKind5[SyntaxKind5["JSDocComment"] = 327 /* JSDoc */] = "JSDocComment";
+        SyntaxKind5[SyntaxKind5["JSDocText"] = 328] = "JSDocText";
+        SyntaxKind5[SyntaxKind5["JSDocTypeLiteral"] = 329] = "JSDocTypeLiteral";
+        SyntaxKind5[SyntaxKind5["JSDocSignature"] = 330] = "JSDocSignature";
+        SyntaxKind5[SyntaxKind5["JSDocLink"] = 331] = "JSDocLink";
+        SyntaxKind5[SyntaxKind5["JSDocLinkCode"] = 332] = "JSDocLinkCode";
+        SyntaxKind5[SyntaxKind5["JSDocLinkPlain"] = 333] = "JSDocLinkPlain";
+        SyntaxKind5[SyntaxKind5["JSDocTag"] = 334] = "JSDocTag";
+        SyntaxKind5[SyntaxKind5["JSDocAugmentsTag"] = 335] = "JSDocAugmentsTag";
+        SyntaxKind5[SyntaxKind5["JSDocImplementsTag"] = 336] = "JSDocImplementsTag";
+        SyntaxKind5[SyntaxKind5["JSDocAuthorTag"] = 337] = "JSDocAuthorTag";
+        SyntaxKind5[SyntaxKind5["JSDocDeprecatedTag"] = 338] = "JSDocDeprecatedTag";
+        SyntaxKind5[SyntaxKind5["JSDocClassTag"] = 339] = "JSDocClassTag";
+        SyntaxKind5[SyntaxKind5["JSDocPublicTag"] = 340] = "JSDocPublicTag";
+        SyntaxKind5[SyntaxKind5["JSDocPrivateTag"] = 341] = "JSDocPrivateTag";
+        SyntaxKind5[SyntaxKind5["JSDocProtectedTag"] = 342] = "JSDocProtectedTag";
+        SyntaxKind5[SyntaxKind5["JSDocReadonlyTag"] = 343] = "JSDocReadonlyTag";
+        SyntaxKind5[SyntaxKind5["JSDocOverrideTag"] = 344] = "JSDocOverrideTag";
+        SyntaxKind5[SyntaxKind5["JSDocCallbackTag"] = 345] = "JSDocCallbackTag";
+        SyntaxKind5[SyntaxKind5["JSDocOverloadTag"] = 346] = "JSDocOverloadTag";
+        SyntaxKind5[SyntaxKind5["JSDocEnumTag"] = 347] = "JSDocEnumTag";
+        SyntaxKind5[SyntaxKind5["JSDocParameterTag"] = 348] = "JSDocParameterTag";
+        SyntaxKind5[SyntaxKind5["JSDocReturnTag"] = 349] = "JSDocReturnTag";
+        SyntaxKind5[SyntaxKind5["JSDocThisTag"] = 350] = "JSDocThisTag";
+        SyntaxKind5[SyntaxKind5["JSDocTypeTag"] = 351] = "JSDocTypeTag";
+        SyntaxKind5[SyntaxKind5["JSDocTemplateTag"] = 352] = "JSDocTemplateTag";
+        SyntaxKind5[SyntaxKind5["JSDocTypedefTag"] = 353] = "JSDocTypedefTag";
+        SyntaxKind5[SyntaxKind5["JSDocSeeTag"] = 354] = "JSDocSeeTag";
+        SyntaxKind5[SyntaxKind5["JSDocPropertyTag"] = 355] = "JSDocPropertyTag";
+        SyntaxKind5[SyntaxKind5["JSDocThrowsTag"] = 356] = "JSDocThrowsTag";
+        SyntaxKind5[SyntaxKind5["JSDocSatisfiesTag"] = 357] = "JSDocSatisfiesTag";
+        SyntaxKind5[SyntaxKind5["SyntaxList"] = 358] = "SyntaxList";
+        SyntaxKind5[SyntaxKind5["NotEmittedStatement"] = 359] = "NotEmittedStatement";
+        SyntaxKind5[SyntaxKind5["PartiallyEmittedExpression"] = 360] = "PartiallyEmittedExpression";
+        SyntaxKind5[SyntaxKind5["CommaListExpression"] = 361] = "CommaListExpression";
+        SyntaxKind5[SyntaxKind5["SyntheticReferenceExpression"] = 362] = "SyntheticReferenceExpression";
+        SyntaxKind5[SyntaxKind5["Count"] = 363] = "Count";
         SyntaxKind5[SyntaxKind5["FirstAssignment"] = 64 /* EqualsToken */] = "FirstAssignment";
         SyntaxKind5[SyntaxKind5["LastAssignment"] = 79 /* CaretEqualsToken */] = "LastAssignment";
         SyntaxKind5[SyntaxKind5["FirstCompoundAssignment"] = 65 /* PlusEqualsToken */] = "FirstCompoundAssignment";
@@ -103256,15 +85853,15 @@ ${lanes.join("\n")}
         SyntaxKind5[SyntaxKind5["FirstReservedWord"] = 83 /* BreakKeyword */] = "FirstReservedWord";
         SyntaxKind5[SyntaxKind5["LastReservedWord"] = 118 /* WithKeyword */] = "LastReservedWord";
         SyntaxKind5[SyntaxKind5["FirstKeyword"] = 83 /* BreakKeyword */] = "FirstKeyword";
-        SyntaxKind5[SyntaxKind5["LastKeyword"] = 164 /* OfKeyword */] = "LastKeyword";
+        SyntaxKind5[SyntaxKind5["LastKeyword"] = 165 /* OfKeyword */] = "LastKeyword";
         SyntaxKind5[SyntaxKind5["FirstFutureReservedWord"] = 119 /* ImplementsKeyword */] = "FirstFutureReservedWord";
         SyntaxKind5[SyntaxKind5["LastFutureReservedWord"] = 127 /* YieldKeyword */] = "LastFutureReservedWord";
-        SyntaxKind5[SyntaxKind5["FirstTypeNode"] = 181 /* TypePredicate */] = "FirstTypeNode";
-        SyntaxKind5[SyntaxKind5["LastTypeNode"] = 204 /* ImportType */] = "LastTypeNode";
+        SyntaxKind5[SyntaxKind5["FirstTypeNode"] = 182 /* TypePredicate */] = "FirstTypeNode";
+        SyntaxKind5[SyntaxKind5["LastTypeNode"] = 205 /* ImportType */] = "LastTypeNode";
         SyntaxKind5[SyntaxKind5["FirstPunctuation"] = 19 /* OpenBraceToken */] = "FirstPunctuation";
         SyntaxKind5[SyntaxKind5["LastPunctuation"] = 79 /* CaretEqualsToken */] = "LastPunctuation";
         SyntaxKind5[SyntaxKind5["FirstToken"] = 0 /* Unknown */] = "FirstToken";
-        SyntaxKind5[SyntaxKind5["LastToken"] = 164 /* LastKeyword */] = "LastToken";
+        SyntaxKind5[SyntaxKind5["LastToken"] = 165 /* LastKeyword */] = "LastToken";
         SyntaxKind5[SyntaxKind5["FirstTriviaToken"] = 2 /* SingleLineCommentTrivia */] = "FirstTriviaToken";
         SyntaxKind5[SyntaxKind5["LastTriviaToken"] = 7 /* ConflictMarkerTrivia */] = "LastTriviaToken";
         SyntaxKind5[SyntaxKind5["FirstLiteralToken"] = 9 /* NumericLiteral */] = "FirstLiteralToken";
@@ -103273,86 +85870,100 @@ ${lanes.join("\n")}
         SyntaxKind5[SyntaxKind5["LastTemplateToken"] = 18 /* TemplateTail */] = "LastTemplateToken";
         SyntaxKind5[SyntaxKind5["FirstBinaryOperator"] = 30 /* LessThanToken */] = "FirstBinaryOperator";
         SyntaxKind5[SyntaxKind5["LastBinaryOperator"] = 79 /* CaretEqualsToken */] = "LastBinaryOperator";
-        SyntaxKind5[SyntaxKind5["FirstStatement"] = 242 /* VariableStatement */] = "FirstStatement";
-        SyntaxKind5[SyntaxKind5["LastStatement"] = 258 /* DebuggerStatement */] = "LastStatement";
-        SyntaxKind5[SyntaxKind5["FirstNode"] = 165 /* QualifiedName */] = "FirstNode";
-        SyntaxKind5[SyntaxKind5["FirstJSDocNode"] = 315 /* JSDocTypeExpression */] = "FirstJSDocNode";
-        SyntaxKind5[SyntaxKind5["LastJSDocNode"] = 356 /* JSDocSatisfiesTag */] = "LastJSDocNode";
-        SyntaxKind5[SyntaxKind5["FirstJSDocTagNode"] = 333 /* JSDocTag */] = "FirstJSDocTagNode";
-        SyntaxKind5[SyntaxKind5["LastJSDocTagNode"] = 356 /* JSDocSatisfiesTag */] = "LastJSDocTagNode";
+        SyntaxKind5[SyntaxKind5["FirstStatement"] = 243 /* VariableStatement */] = "FirstStatement";
+        SyntaxKind5[SyntaxKind5["LastStatement"] = 259 /* DebuggerStatement */] = "LastStatement";
+        SyntaxKind5[SyntaxKind5["FirstNode"] = 166 /* QualifiedName */] = "FirstNode";
+        SyntaxKind5[SyntaxKind5["FirstJSDocNode"] = 316 /* JSDocTypeExpression */] = "FirstJSDocNode";
+        SyntaxKind5[SyntaxKind5["LastJSDocNode"] = 357 /* JSDocSatisfiesTag */] = "LastJSDocNode";
+        SyntaxKind5[SyntaxKind5["FirstJSDocTagNode"] = 334 /* JSDocTag */] = "FirstJSDocTagNode";
+        SyntaxKind5[SyntaxKind5["LastJSDocTagNode"] = 357 /* JSDocSatisfiesTag */] = "LastJSDocTagNode";
         SyntaxKind5[SyntaxKind5["FirstContextualKeyword"] = 128 /* AbstractKeyword */] = "FirstContextualKeyword";
-        SyntaxKind5[SyntaxKind5["LastContextualKeyword"] = 164 /* OfKeyword */] = "LastContextualKeyword";
+        SyntaxKind5[SyntaxKind5["LastContextualKeyword"] = 165 /* OfKeyword */] = "LastContextualKeyword";
         return SyntaxKind5;
       })(SyntaxKind || {});
       NodeFlags = /* @__PURE__ */ ((NodeFlags3) => {
         NodeFlags3[NodeFlags3["None"] = 0] = "None";
         NodeFlags3[NodeFlags3["Let"] = 1] = "Let";
         NodeFlags3[NodeFlags3["Const"] = 2] = "Const";
-        NodeFlags3[NodeFlags3["NestedNamespace"] = 4] = "NestedNamespace";
-        NodeFlags3[NodeFlags3["Synthesized"] = 8] = "Synthesized";
-        NodeFlags3[NodeFlags3["Namespace"] = 16] = "Namespace";
-        NodeFlags3[NodeFlags3["OptionalChain"] = 32] = "OptionalChain";
-        NodeFlags3[NodeFlags3["ExportContext"] = 64] = "ExportContext";
-        NodeFlags3[NodeFlags3["ContainsThis"] = 128] = "ContainsThis";
-        NodeFlags3[NodeFlags3["HasImplicitReturn"] = 256] = "HasImplicitReturn";
-        NodeFlags3[NodeFlags3["HasExplicitReturn"] = 512] = "HasExplicitReturn";
-        NodeFlags3[NodeFlags3["GlobalAugmentation"] = 1024] = "GlobalAugmentation";
-        NodeFlags3[NodeFlags3["HasAsyncFunctions"] = 2048] = "HasAsyncFunctions";
-        NodeFlags3[NodeFlags3["DisallowInContext"] = 4096] = "DisallowInContext";
-        NodeFlags3[NodeFlags3["YieldContext"] = 8192] = "YieldContext";
-        NodeFlags3[NodeFlags3["DecoratorContext"] = 16384] = "DecoratorContext";
-        NodeFlags3[NodeFlags3["AwaitContext"] = 32768] = "AwaitContext";
-        NodeFlags3[NodeFlags3["DisallowConditionalTypesContext"] = 65536] = "DisallowConditionalTypesContext";
-        NodeFlags3[NodeFlags3["ThisNodeHasError"] = 131072] = "ThisNodeHasError";
-        NodeFlags3[NodeFlags3["JavaScriptFile"] = 262144] = "JavaScriptFile";
-        NodeFlags3[NodeFlags3["ThisNodeOrAnySubNodesHasError"] = 524288] = "ThisNodeOrAnySubNodesHasError";
-        NodeFlags3[NodeFlags3["HasAggregatedChildData"] = 1048576] = "HasAggregatedChildData";
-        NodeFlags3[NodeFlags3["PossiblyContainsDynamicImport"] = 2097152] = "PossiblyContainsDynamicImport";
-        NodeFlags3[NodeFlags3["PossiblyContainsImportMeta"] = 4194304] = "PossiblyContainsImportMeta";
-        NodeFlags3[NodeFlags3["JSDoc"] = 8388608] = "JSDoc";
-        NodeFlags3[NodeFlags3["Ambient"] = 16777216] = "Ambient";
-        NodeFlags3[NodeFlags3["InWithStatement"] = 33554432] = "InWithStatement";
-        NodeFlags3[NodeFlags3["JsonFile"] = 67108864] = "JsonFile";
-        NodeFlags3[NodeFlags3["TypeCached"] = 134217728] = "TypeCached";
-        NodeFlags3[NodeFlags3["Deprecated"] = 268435456] = "Deprecated";
-        NodeFlags3[NodeFlags3["BlockScoped"] = 3] = "BlockScoped";
-        NodeFlags3[NodeFlags3["ReachabilityCheckFlags"] = 768] = "ReachabilityCheckFlags";
-        NodeFlags3[NodeFlags3["ReachabilityAndEmitFlags"] = 2816] = "ReachabilityAndEmitFlags";
-        NodeFlags3[NodeFlags3["ContextFlags"] = 50720768] = "ContextFlags";
-        NodeFlags3[NodeFlags3["TypeExcludesFlags"] = 40960] = "TypeExcludesFlags";
-        NodeFlags3[NodeFlags3["PermanentlySetIncrementalFlags"] = 6291456] = "PermanentlySetIncrementalFlags";
-        NodeFlags3[NodeFlags3["IdentifierHasExtendedUnicodeEscape"] = 128 /* ContainsThis */] = "IdentifierHasExtendedUnicodeEscape";
-        NodeFlags3[NodeFlags3["IdentifierIsInJSDocNamespace"] = 2048 /* HasAsyncFunctions */] = "IdentifierIsInJSDocNamespace";
+        NodeFlags3[NodeFlags3["Using"] = 4] = "Using";
+        NodeFlags3[NodeFlags3["AwaitUsing"] = 6] = "AwaitUsing";
+        NodeFlags3[NodeFlags3["NestedNamespace"] = 8] = "NestedNamespace";
+        NodeFlags3[NodeFlags3["Synthesized"] = 16] = "Synthesized";
+        NodeFlags3[NodeFlags3["Namespace"] = 32] = "Namespace";
+        NodeFlags3[NodeFlags3["OptionalChain"] = 64] = "OptionalChain";
+        NodeFlags3[NodeFlags3["ExportContext"] = 128] = "ExportContext";
+        NodeFlags3[NodeFlags3["ContainsThis"] = 256] = "ContainsThis";
+        NodeFlags3[NodeFlags3["HasImplicitReturn"] = 512] = "HasImplicitReturn";
+        NodeFlags3[NodeFlags3["HasExplicitReturn"] = 1024] = "HasExplicitReturn";
+        NodeFlags3[NodeFlags3["GlobalAugmentation"] = 2048] = "GlobalAugmentation";
+        NodeFlags3[NodeFlags3["HasAsyncFunctions"] = 4096] = "HasAsyncFunctions";
+        NodeFlags3[NodeFlags3["DisallowInContext"] = 8192] = "DisallowInContext";
+        NodeFlags3[NodeFlags3["YieldContext"] = 16384] = "YieldContext";
+        NodeFlags3[NodeFlags3["DecoratorContext"] = 32768] = "DecoratorContext";
+        NodeFlags3[NodeFlags3["AwaitContext"] = 65536] = "AwaitContext";
+        NodeFlags3[NodeFlags3["DisallowConditionalTypesContext"] = 131072] = "DisallowConditionalTypesContext";
+        NodeFlags3[NodeFlags3["ThisNodeHasError"] = 262144] = "ThisNodeHasError";
+        NodeFlags3[NodeFlags3["JavaScriptFile"] = 524288] = "JavaScriptFile";
+        NodeFlags3[NodeFlags3["ThisNodeOrAnySubNodesHasError"] = 1048576] = "ThisNodeOrAnySubNodesHasError";
+        NodeFlags3[NodeFlags3["HasAggregatedChildData"] = 2097152] = "HasAggregatedChildData";
+        NodeFlags3[NodeFlags3["PossiblyContainsDynamicImport"] = 4194304] = "PossiblyContainsDynamicImport";
+        NodeFlags3[NodeFlags3["PossiblyContainsImportMeta"] = 8388608] = "PossiblyContainsImportMeta";
+        NodeFlags3[NodeFlags3["JSDoc"] = 16777216] = "JSDoc";
+        NodeFlags3[NodeFlags3["Ambient"] = 33554432] = "Ambient";
+        NodeFlags3[NodeFlags3["InWithStatement"] = 67108864] = "InWithStatement";
+        NodeFlags3[NodeFlags3["JsonFile"] = 134217728] = "JsonFile";
+        NodeFlags3[NodeFlags3["TypeCached"] = 268435456] = "TypeCached";
+        NodeFlags3[NodeFlags3["Deprecated"] = 536870912] = "Deprecated";
+        NodeFlags3[NodeFlags3["BlockScoped"] = 7] = "BlockScoped";
+        NodeFlags3[NodeFlags3["Constant"] = 6] = "Constant";
+        NodeFlags3[NodeFlags3["ReachabilityCheckFlags"] = 1536] = "ReachabilityCheckFlags";
+        NodeFlags3[NodeFlags3["ReachabilityAndEmitFlags"] = 5632] = "ReachabilityAndEmitFlags";
+        NodeFlags3[NodeFlags3["ContextFlags"] = 101441536] = "ContextFlags";
+        NodeFlags3[NodeFlags3["TypeExcludesFlags"] = 81920] = "TypeExcludesFlags";
+        NodeFlags3[NodeFlags3["PermanentlySetIncrementalFlags"] = 12582912] = "PermanentlySetIncrementalFlags";
+        NodeFlags3[NodeFlags3["IdentifierHasExtendedUnicodeEscape"] = 256 /* ContainsThis */] = "IdentifierHasExtendedUnicodeEscape";
+        NodeFlags3[NodeFlags3["IdentifierIsInJSDocNamespace"] = 4096 /* HasAsyncFunctions */] = "IdentifierIsInJSDocNamespace";
         return NodeFlags3;
       })(NodeFlags || {});
       ModifierFlags = /* @__PURE__ */ ((ModifierFlags3) => {
         ModifierFlags3[ModifierFlags3["None"] = 0] = "None";
-        ModifierFlags3[ModifierFlags3["Export"] = 1] = "Export";
-        ModifierFlags3[ModifierFlags3["Ambient"] = 2] = "Ambient";
-        ModifierFlags3[ModifierFlags3["Public"] = 4] = "Public";
-        ModifierFlags3[ModifierFlags3["Private"] = 8] = "Private";
-        ModifierFlags3[ModifierFlags3["Protected"] = 16] = "Protected";
-        ModifierFlags3[ModifierFlags3["Static"] = 32] = "Static";
-        ModifierFlags3[ModifierFlags3["Readonly"] = 64] = "Readonly";
-        ModifierFlags3[ModifierFlags3["Accessor"] = 128] = "Accessor";
-        ModifierFlags3[ModifierFlags3["Abstract"] = 256] = "Abstract";
-        ModifierFlags3[ModifierFlags3["Async"] = 512] = "Async";
-        ModifierFlags3[ModifierFlags3["Default"] = 1024] = "Default";
-        ModifierFlags3[ModifierFlags3["Const"] = 2048] = "Const";
-        ModifierFlags3[ModifierFlags3["HasComputedJSDocModifiers"] = 4096] = "HasComputedJSDocModifiers";
-        ModifierFlags3[ModifierFlags3["Deprecated"] = 8192] = "Deprecated";
-        ModifierFlags3[ModifierFlags3["Override"] = 16384] = "Override";
-        ModifierFlags3[ModifierFlags3["In"] = 32768] = "In";
-        ModifierFlags3[ModifierFlags3["Out"] = 65536] = "Out";
-        ModifierFlags3[ModifierFlags3["Decorator"] = 131072] = "Decorator";
+        ModifierFlags3[ModifierFlags3["Public"] = 1] = "Public";
+        ModifierFlags3[ModifierFlags3["Private"] = 2] = "Private";
+        ModifierFlags3[ModifierFlags3["Protected"] = 4] = "Protected";
+        ModifierFlags3[ModifierFlags3["Readonly"] = 8] = "Readonly";
+        ModifierFlags3[ModifierFlags3["Override"] = 16] = "Override";
+        ModifierFlags3[ModifierFlags3["Export"] = 32] = "Export";
+        ModifierFlags3[ModifierFlags3["Abstract"] = 64] = "Abstract";
+        ModifierFlags3[ModifierFlags3["Ambient"] = 128] = "Ambient";
+        ModifierFlags3[ModifierFlags3["Static"] = 256] = "Static";
+        ModifierFlags3[ModifierFlags3["Accessor"] = 512] = "Accessor";
+        ModifierFlags3[ModifierFlags3["Async"] = 1024] = "Async";
+        ModifierFlags3[ModifierFlags3["Default"] = 2048] = "Default";
+        ModifierFlags3[ModifierFlags3["Const"] = 4096] = "Const";
+        ModifierFlags3[ModifierFlags3["In"] = 8192] = "In";
+        ModifierFlags3[ModifierFlags3["Out"] = 16384] = "Out";
+        ModifierFlags3[ModifierFlags3["Decorator"] = 32768] = "Decorator";
+        ModifierFlags3[ModifierFlags3["Deprecated"] = 65536] = "Deprecated";
+        ModifierFlags3[ModifierFlags3["JSDocPublic"] = 8388608] = "JSDocPublic";
+        ModifierFlags3[ModifierFlags3["JSDocPrivate"] = 16777216] = "JSDocPrivate";
+        ModifierFlags3[ModifierFlags3["JSDocProtected"] = 33554432] = "JSDocProtected";
+        ModifierFlags3[ModifierFlags3["JSDocReadonly"] = 67108864] = "JSDocReadonly";
+        ModifierFlags3[ModifierFlags3["JSDocOverride"] = 134217728] = "JSDocOverride";
+        ModifierFlags3[ModifierFlags3["SyntacticOrJSDocModifiers"] = 31] = "SyntacticOrJSDocModifiers";
+        ModifierFlags3[ModifierFlags3["SyntacticOnlyModifiers"] = 65504] = "SyntacticOnlyModifiers";
+        ModifierFlags3[ModifierFlags3["SyntacticModifiers"] = 65535] = "SyntacticModifiers";
+        ModifierFlags3[ModifierFlags3["JSDocCacheOnlyModifiers"] = 260046848] = "JSDocCacheOnlyModifiers";
+        ModifierFlags3[ModifierFlags3["JSDocOnlyModifiers"] = 65536 /* Deprecated */] = "JSDocOnlyModifiers";
+        ModifierFlags3[ModifierFlags3["NonCacheOnlyModifiers"] = 131071] = "NonCacheOnlyModifiers";
+        ModifierFlags3[ModifierFlags3["HasComputedJSDocModifiers"] = 268435456] = "HasComputedJSDocModifiers";
         ModifierFlags3[ModifierFlags3["HasComputedFlags"] = 536870912] = "HasComputedFlags";
-        ModifierFlags3[ModifierFlags3["AccessibilityModifier"] = 28] = "AccessibilityModifier";
-        ModifierFlags3[ModifierFlags3["ParameterPropertyModifier"] = 16476] = "ParameterPropertyModifier";
-        ModifierFlags3[ModifierFlags3["NonPublicAccessibilityModifier"] = 24] = "NonPublicAccessibilityModifier";
-        ModifierFlags3[ModifierFlags3["TypeScriptModifier"] = 117086] = "TypeScriptModifier";
-        ModifierFlags3[ModifierFlags3["ExportDefault"] = 1025] = "ExportDefault";
-        ModifierFlags3[ModifierFlags3["All"] = 258047] = "All";
-        ModifierFlags3[ModifierFlags3["Modifier"] = 126975] = "Modifier";
+        ModifierFlags3[ModifierFlags3["AccessibilityModifier"] = 7] = "AccessibilityModifier";
+        ModifierFlags3[ModifierFlags3["ParameterPropertyModifier"] = 31] = "ParameterPropertyModifier";
+        ModifierFlags3[ModifierFlags3["NonPublicAccessibilityModifier"] = 6] = "NonPublicAccessibilityModifier";
+        ModifierFlags3[ModifierFlags3["TypeScriptModifier"] = 28895] = "TypeScriptModifier";
+        ModifierFlags3[ModifierFlags3["ExportDefault"] = 2080] = "ExportDefault";
+        ModifierFlags3[ModifierFlags3["All"] = 131071] = "All";
+        ModifierFlags3[ModifierFlags3["Modifier"] = 98303] = "Modifier";
         return ModifierFlags3;
       })(ModifierFlags || {});
       JsxFlags = /* @__PURE__ */ ((JsxFlags2) => {
@@ -103735,15 +86346,13 @@ ${lanes.join("\n")}
         NodeCheckFlags2[NodeCheckFlags2["ContainsCapturedBlockScopeBinding"] = 8192] = "ContainsCapturedBlockScopeBinding";
         NodeCheckFlags2[NodeCheckFlags2["CapturedBlockScopedBinding"] = 16384] = "CapturedBlockScopedBinding";
         NodeCheckFlags2[NodeCheckFlags2["BlockScopedBindingInLoop"] = 32768] = "BlockScopedBindingInLoop";
-        NodeCheckFlags2[NodeCheckFlags2["ClassWithBodyScopedClassBinding"] = 65536] = "ClassWithBodyScopedClassBinding";
-        NodeCheckFlags2[NodeCheckFlags2["BodyScopedClassBinding"] = 131072] = "BodyScopedClassBinding";
-        NodeCheckFlags2[NodeCheckFlags2["NeedsLoopOutParameter"] = 262144] = "NeedsLoopOutParameter";
-        NodeCheckFlags2[NodeCheckFlags2["AssignmentsMarked"] = 524288] = "AssignmentsMarked";
-        NodeCheckFlags2[NodeCheckFlags2["ClassWithConstructorReference"] = 1048576] = "ClassWithConstructorReference";
-        NodeCheckFlags2[NodeCheckFlags2["ConstructorReferenceInClass"] = 2097152] = "ConstructorReferenceInClass";
-        NodeCheckFlags2[NodeCheckFlags2["ContainsClassWithPrivateIdentifiers"] = 4194304] = "ContainsClassWithPrivateIdentifiers";
-        NodeCheckFlags2[NodeCheckFlags2["ContainsSuperPropertyInStaticInitializer"] = 8388608] = "ContainsSuperPropertyInStaticInitializer";
-        NodeCheckFlags2[NodeCheckFlags2["InCheckIdentifier"] = 16777216] = "InCheckIdentifier";
+        NodeCheckFlags2[NodeCheckFlags2["NeedsLoopOutParameter"] = 65536] = "NeedsLoopOutParameter";
+        NodeCheckFlags2[NodeCheckFlags2["AssignmentsMarked"] = 131072] = "AssignmentsMarked";
+        NodeCheckFlags2[NodeCheckFlags2["ContainsConstructorReference"] = 262144] = "ContainsConstructorReference";
+        NodeCheckFlags2[NodeCheckFlags2["ConstructorReference"] = 536870912] = "ConstructorReference";
+        NodeCheckFlags2[NodeCheckFlags2["ContainsClassWithPrivateIdentifiers"] = 1048576] = "ContainsClassWithPrivateIdentifiers";
+        NodeCheckFlags2[NodeCheckFlags2["ContainsSuperPropertyInStaticInitializer"] = 2097152] = "ContainsSuperPropertyInStaticInitializer";
+        NodeCheckFlags2[NodeCheckFlags2["InCheckIdentifier"] = 4194304] = "InCheckIdentifier";
         return NodeCheckFlags2;
       })(NodeCheckFlags || {});
       TypeFlags = /* @__PURE__ */ ((TypeFlags2) => {
@@ -103803,7 +86412,7 @@ ${lanes.join("\n")}
         TypeFlags2[TypeFlags2["InstantiablePrimitive"] = 406847488] = "InstantiablePrimitive";
         TypeFlags2[TypeFlags2["Instantiable"] = 465829888] = "Instantiable";
         TypeFlags2[TypeFlags2["StructuredOrInstantiable"] = 469499904] = "StructuredOrInstantiable";
-        TypeFlags2[TypeFlags2["ObjectFlagsType"] = 138117121] = "ObjectFlagsType";
+        TypeFlags2[TypeFlags2["ObjectFlagsType"] = 3899393] = "ObjectFlagsType";
         TypeFlags2[TypeFlags2["Simplifiable"] = 25165824] = "Simplifiable";
         TypeFlags2[TypeFlags2["Singleton"] = 67358815] = "Singleton";
         TypeFlags2[TypeFlags2["Narrowable"] = 536624127] = "Narrowable";
@@ -103842,6 +86451,7 @@ ${lanes.join("\n")}
         ObjectFlags3[ObjectFlags3["ClassOrInterface"] = 3] = "ClassOrInterface";
         ObjectFlags3[ObjectFlags3["RequiresWidening"] = 196608] = "RequiresWidening";
         ObjectFlags3[ObjectFlags3["PropagatingFlags"] = 458752] = "PropagatingFlags";
+        ObjectFlags3[ObjectFlags3["InstantiatedMapped"] = 96] = "InstantiatedMapped";
         ObjectFlags3[ObjectFlags3["ObjectTypeKindMask"] = 1343] = "ObjectTypeKindMask";
         ObjectFlags3[ObjectFlags3["ContainsSpread"] = 2097152] = "ContainsSpread";
         ObjectFlags3[ObjectFlags3["ObjectRestType"] = 4194304] = "ObjectRestType";
@@ -103924,7 +86534,8 @@ ${lanes.join("\n")}
         SignatureFlags5[SignatureFlags5["IsOuterCallChain"] = 16] = "IsOuterCallChain";
         SignatureFlags5[SignatureFlags5["IsUntypedSignatureInJSFile"] = 32] = "IsUntypedSignatureInJSFile";
         SignatureFlags5[SignatureFlags5["IsNonInferrable"] = 64] = "IsNonInferrable";
-        SignatureFlags5[SignatureFlags5["PropagatingFlags"] = 39] = "PropagatingFlags";
+        SignatureFlags5[SignatureFlags5["IsSignatureCandidateForOverloadFailure"] = 128] = "IsSignatureCandidateForOverloadFailure";
+        SignatureFlags5[SignatureFlags5["PropagatingFlags"] = 167] = "PropagatingFlags";
         SignatureFlags5[SignatureFlags5["CallChainFlags"] = 24] = "CallChainFlags";
         return SignatureFlags5;
       })(SignatureFlags || {});
@@ -103994,14 +86605,14 @@ ${lanes.join("\n")}
         DiagnosticCategory2[DiagnosticCategory2["Message"] = 3] = "Message";
         return DiagnosticCategory2;
       })(DiagnosticCategory || {});
-      ModuleResolutionKind = /* @__PURE__ */ ((ModuleResolutionKind2) => {
-        ModuleResolutionKind2[ModuleResolutionKind2["Classic"] = 1] = "Classic";
-        ModuleResolutionKind2[ModuleResolutionKind2["NodeJs"] = 2] = "NodeJs";
-        ModuleResolutionKind2[ModuleResolutionKind2["Node10"] = 2] = "Node10";
-        ModuleResolutionKind2[ModuleResolutionKind2["Node16"] = 3] = "Node16";
-        ModuleResolutionKind2[ModuleResolutionKind2["NodeNext"] = 99] = "NodeNext";
-        ModuleResolutionKind2[ModuleResolutionKind2["Bundler"] = 100] = "Bundler";
-        return ModuleResolutionKind2;
+      ModuleResolutionKind = /* @__PURE__ */ ((ModuleResolutionKind3) => {
+        ModuleResolutionKind3[ModuleResolutionKind3["Classic"] = 1] = "Classic";
+        ModuleResolutionKind3[ModuleResolutionKind3["NodeJs"] = 2] = "NodeJs";
+        ModuleResolutionKind3[ModuleResolutionKind3["Node10"] = 2] = "Node10";
+        ModuleResolutionKind3[ModuleResolutionKind3["Node16"] = 3] = "Node16";
+        ModuleResolutionKind3[ModuleResolutionKind3["NodeNext"] = 99] = "NodeNext";
+        ModuleResolutionKind3[ModuleResolutionKind3["Bundler"] = 100] = "Bundler";
+        return ModuleResolutionKind3;
       })(ModuleResolutionKind || {});
       ModuleDetectionKind = /* @__PURE__ */ ((ModuleDetectionKind2) => {
         ModuleDetectionKind2[ModuleDetectionKind2["Legacy"] = 1] = "Legacy";
@@ -104009,51 +86620,51 @@ ${lanes.join("\n")}
         ModuleDetectionKind2[ModuleDetectionKind2["Force"] = 3] = "Force";
         return ModuleDetectionKind2;
       })(ModuleDetectionKind || {});
-      WatchFileKind = /* @__PURE__ */ ((WatchFileKind2) => {
-        WatchFileKind2[WatchFileKind2["FixedPollingInterval"] = 0] = "FixedPollingInterval";
-        WatchFileKind2[WatchFileKind2["PriorityPollingInterval"] = 1] = "PriorityPollingInterval";
-        WatchFileKind2[WatchFileKind2["DynamicPriorityPolling"] = 2] = "DynamicPriorityPolling";
-        WatchFileKind2[WatchFileKind2["FixedChunkSizePolling"] = 3] = "FixedChunkSizePolling";
-        WatchFileKind2[WatchFileKind2["UseFsEvents"] = 4] = "UseFsEvents";
-        WatchFileKind2[WatchFileKind2["UseFsEventsOnParentDirectory"] = 5] = "UseFsEventsOnParentDirectory";
-        return WatchFileKind2;
+      WatchFileKind = /* @__PURE__ */ ((WatchFileKind3) => {
+        WatchFileKind3[WatchFileKind3["FixedPollingInterval"] = 0] = "FixedPollingInterval";
+        WatchFileKind3[WatchFileKind3["PriorityPollingInterval"] = 1] = "PriorityPollingInterval";
+        WatchFileKind3[WatchFileKind3["DynamicPriorityPolling"] = 2] = "DynamicPriorityPolling";
+        WatchFileKind3[WatchFileKind3["FixedChunkSizePolling"] = 3] = "FixedChunkSizePolling";
+        WatchFileKind3[WatchFileKind3["UseFsEvents"] = 4] = "UseFsEvents";
+        WatchFileKind3[WatchFileKind3["UseFsEventsOnParentDirectory"] = 5] = "UseFsEventsOnParentDirectory";
+        return WatchFileKind3;
       })(WatchFileKind || {});
-      WatchDirectoryKind = /* @__PURE__ */ ((WatchDirectoryKind2) => {
-        WatchDirectoryKind2[WatchDirectoryKind2["UseFsEvents"] = 0] = "UseFsEvents";
-        WatchDirectoryKind2[WatchDirectoryKind2["FixedPollingInterval"] = 1] = "FixedPollingInterval";
-        WatchDirectoryKind2[WatchDirectoryKind2["DynamicPriorityPolling"] = 2] = "DynamicPriorityPolling";
-        WatchDirectoryKind2[WatchDirectoryKind2["FixedChunkSizePolling"] = 3] = "FixedChunkSizePolling";
-        return WatchDirectoryKind2;
+      WatchDirectoryKind = /* @__PURE__ */ ((WatchDirectoryKind3) => {
+        WatchDirectoryKind3[WatchDirectoryKind3["UseFsEvents"] = 0] = "UseFsEvents";
+        WatchDirectoryKind3[WatchDirectoryKind3["FixedPollingInterval"] = 1] = "FixedPollingInterval";
+        WatchDirectoryKind3[WatchDirectoryKind3["DynamicPriorityPolling"] = 2] = "DynamicPriorityPolling";
+        WatchDirectoryKind3[WatchDirectoryKind3["FixedChunkSizePolling"] = 3] = "FixedChunkSizePolling";
+        return WatchDirectoryKind3;
       })(WatchDirectoryKind || {});
-      PollingWatchKind = /* @__PURE__ */ ((PollingWatchKind2) => {
-        PollingWatchKind2[PollingWatchKind2["FixedInterval"] = 0] = "FixedInterval";
-        PollingWatchKind2[PollingWatchKind2["PriorityInterval"] = 1] = "PriorityInterval";
-        PollingWatchKind2[PollingWatchKind2["DynamicPriority"] = 2] = "DynamicPriority";
-        PollingWatchKind2[PollingWatchKind2["FixedChunkSize"] = 3] = "FixedChunkSize";
-        return PollingWatchKind2;
+      PollingWatchKind = /* @__PURE__ */ ((PollingWatchKind3) => {
+        PollingWatchKind3[PollingWatchKind3["FixedInterval"] = 0] = "FixedInterval";
+        PollingWatchKind3[PollingWatchKind3["PriorityInterval"] = 1] = "PriorityInterval";
+        PollingWatchKind3[PollingWatchKind3["DynamicPriority"] = 2] = "DynamicPriority";
+        PollingWatchKind3[PollingWatchKind3["FixedChunkSize"] = 3] = "FixedChunkSize";
+        return PollingWatchKind3;
       })(PollingWatchKind || {});
-      ModuleKind = /* @__PURE__ */ ((ModuleKind2) => {
-        ModuleKind2[ModuleKind2["None"] = 0] = "None";
-        ModuleKind2[ModuleKind2["CommonJS"] = 1] = "CommonJS";
-        ModuleKind2[ModuleKind2["AMD"] = 2] = "AMD";
-        ModuleKind2[ModuleKind2["UMD"] = 3] = "UMD";
-        ModuleKind2[ModuleKind2["System"] = 4] = "System";
-        ModuleKind2[ModuleKind2["ES2015"] = 5] = "ES2015";
-        ModuleKind2[ModuleKind2["ES2020"] = 6] = "ES2020";
-        ModuleKind2[ModuleKind2["ES2022"] = 7] = "ES2022";
-        ModuleKind2[ModuleKind2["ESNext"] = 99] = "ESNext";
-        ModuleKind2[ModuleKind2["Node16"] = 100] = "Node16";
-        ModuleKind2[ModuleKind2["NodeNext"] = 199] = "NodeNext";
-        return ModuleKind2;
+      ModuleKind = /* @__PURE__ */ ((ModuleKind3) => {
+        ModuleKind3[ModuleKind3["None"] = 0] = "None";
+        ModuleKind3[ModuleKind3["CommonJS"] = 1] = "CommonJS";
+        ModuleKind3[ModuleKind3["AMD"] = 2] = "AMD";
+        ModuleKind3[ModuleKind3["UMD"] = 3] = "UMD";
+        ModuleKind3[ModuleKind3["System"] = 4] = "System";
+        ModuleKind3[ModuleKind3["ES2015"] = 5] = "ES2015";
+        ModuleKind3[ModuleKind3["ES2020"] = 6] = "ES2020";
+        ModuleKind3[ModuleKind3["ES2022"] = 7] = "ES2022";
+        ModuleKind3[ModuleKind3["ESNext"] = 99] = "ESNext";
+        ModuleKind3[ModuleKind3["Node16"] = 100] = "Node16";
+        ModuleKind3[ModuleKind3["NodeNext"] = 199] = "NodeNext";
+        return ModuleKind3;
       })(ModuleKind || {});
-      JsxEmit = /* @__PURE__ */ ((JsxEmit2) => {
-        JsxEmit2[JsxEmit2["None"] = 0] = "None";
-        JsxEmit2[JsxEmit2["Preserve"] = 1] = "Preserve";
-        JsxEmit2[JsxEmit2["React"] = 2] = "React";
-        JsxEmit2[JsxEmit2["ReactNative"] = 3] = "ReactNative";
-        JsxEmit2[JsxEmit2["ReactJSX"] = 4] = "ReactJSX";
-        JsxEmit2[JsxEmit2["ReactJSXDev"] = 5] = "ReactJSXDev";
-        return JsxEmit2;
+      JsxEmit = /* @__PURE__ */ ((JsxEmit3) => {
+        JsxEmit3[JsxEmit3["None"] = 0] = "None";
+        JsxEmit3[JsxEmit3["Preserve"] = 1] = "Preserve";
+        JsxEmit3[JsxEmit3["React"] = 2] = "React";
+        JsxEmit3[JsxEmit3["ReactNative"] = 3] = "ReactNative";
+        JsxEmit3[JsxEmit3["ReactJSX"] = 4] = "ReactJSX";
+        JsxEmit3[JsxEmit3["ReactJSXDev"] = 5] = "ReactJSXDev";
+        return JsxEmit3;
       })(JsxEmit || {});
       ImportsNotUsedAsValues = /* @__PURE__ */ ((ImportsNotUsedAsValues2) => {
         ImportsNotUsedAsValues2[ImportsNotUsedAsValues2["Remove"] = 0] = "Remove";
@@ -104061,37 +86672,37 @@ ${lanes.join("\n")}
         ImportsNotUsedAsValues2[ImportsNotUsedAsValues2["Error"] = 2] = "Error";
         return ImportsNotUsedAsValues2;
       })(ImportsNotUsedAsValues || {});
-      NewLineKind = /* @__PURE__ */ ((NewLineKind2) => {
-        NewLineKind2[NewLineKind2["CarriageReturnLineFeed"] = 0] = "CarriageReturnLineFeed";
-        NewLineKind2[NewLineKind2["LineFeed"] = 1] = "LineFeed";
-        return NewLineKind2;
+      NewLineKind = /* @__PURE__ */ ((NewLineKind3) => {
+        NewLineKind3[NewLineKind3["CarriageReturnLineFeed"] = 0] = "CarriageReturnLineFeed";
+        NewLineKind3[NewLineKind3["LineFeed"] = 1] = "LineFeed";
+        return NewLineKind3;
       })(NewLineKind || {});
-      ScriptKind = /* @__PURE__ */ ((ScriptKind5) => {
-        ScriptKind5[ScriptKind5["Unknown"] = 0] = "Unknown";
-        ScriptKind5[ScriptKind5["JS"] = 1] = "JS";
-        ScriptKind5[ScriptKind5["JSX"] = 2] = "JSX";
-        ScriptKind5[ScriptKind5["TS"] = 3] = "TS";
-        ScriptKind5[ScriptKind5["TSX"] = 4] = "TSX";
-        ScriptKind5[ScriptKind5["External"] = 5] = "External";
-        ScriptKind5[ScriptKind5["JSON"] = 6] = "JSON";
-        ScriptKind5[ScriptKind5["Deferred"] = 7] = "Deferred";
-        return ScriptKind5;
+      ScriptKind = /* @__PURE__ */ ((ScriptKind7) => {
+        ScriptKind7[ScriptKind7["Unknown"] = 0] = "Unknown";
+        ScriptKind7[ScriptKind7["JS"] = 1] = "JS";
+        ScriptKind7[ScriptKind7["JSX"] = 2] = "JSX";
+        ScriptKind7[ScriptKind7["TS"] = 3] = "TS";
+        ScriptKind7[ScriptKind7["TSX"] = 4] = "TSX";
+        ScriptKind7[ScriptKind7["External"] = 5] = "External";
+        ScriptKind7[ScriptKind7["JSON"] = 6] = "JSON";
+        ScriptKind7[ScriptKind7["Deferred"] = 7] = "Deferred";
+        return ScriptKind7;
       })(ScriptKind || {});
-      ScriptTarget = /* @__PURE__ */ ((ScriptTarget10) => {
-        ScriptTarget10[ScriptTarget10["ES3"] = 0] = "ES3";
-        ScriptTarget10[ScriptTarget10["ES5"] = 1] = "ES5";
-        ScriptTarget10[ScriptTarget10["ES2015"] = 2] = "ES2015";
-        ScriptTarget10[ScriptTarget10["ES2016"] = 3] = "ES2016";
-        ScriptTarget10[ScriptTarget10["ES2017"] = 4] = "ES2017";
-        ScriptTarget10[ScriptTarget10["ES2018"] = 5] = "ES2018";
-        ScriptTarget10[ScriptTarget10["ES2019"] = 6] = "ES2019";
-        ScriptTarget10[ScriptTarget10["ES2020"] = 7] = "ES2020";
-        ScriptTarget10[ScriptTarget10["ES2021"] = 8] = "ES2021";
-        ScriptTarget10[ScriptTarget10["ES2022"] = 9] = "ES2022";
-        ScriptTarget10[ScriptTarget10["ESNext"] = 99] = "ESNext";
-        ScriptTarget10[ScriptTarget10["JSON"] = 100] = "JSON";
-        ScriptTarget10[ScriptTarget10["Latest"] = 99 /* ESNext */] = "Latest";
-        return ScriptTarget10;
+      ScriptTarget = /* @__PURE__ */ ((ScriptTarget11) => {
+        ScriptTarget11[ScriptTarget11["ES3"] = 0] = "ES3";
+        ScriptTarget11[ScriptTarget11["ES5"] = 1] = "ES5";
+        ScriptTarget11[ScriptTarget11["ES2015"] = 2] = "ES2015";
+        ScriptTarget11[ScriptTarget11["ES2016"] = 3] = "ES2016";
+        ScriptTarget11[ScriptTarget11["ES2017"] = 4] = "ES2017";
+        ScriptTarget11[ScriptTarget11["ES2018"] = 5] = "ES2018";
+        ScriptTarget11[ScriptTarget11["ES2019"] = 6] = "ES2019";
+        ScriptTarget11[ScriptTarget11["ES2020"] = 7] = "ES2020";
+        ScriptTarget11[ScriptTarget11["ES2021"] = 8] = "ES2021";
+        ScriptTarget11[ScriptTarget11["ES2022"] = 9] = "ES2022";
+        ScriptTarget11[ScriptTarget11["ESNext"] = 99] = "ESNext";
+        ScriptTarget11[ScriptTarget11["JSON"] = 100] = "JSON";
+        ScriptTarget11[ScriptTarget11["Latest"] = 99 /* ESNext */] = "Latest";
+        return ScriptTarget11;
       })(ScriptTarget || {});
       LanguageVariant = /* @__PURE__ */ ((LanguageVariant4) => {
         LanguageVariant4[LanguageVariant4["Standard"] = 0] = "Standard";
@@ -104390,8 +87001,9 @@ ${lanes.join("\n")}
         ExternalEmitHelpers2[ExternalEmitHelpers2["CreateBinding"] = 4194304] = "CreateBinding";
         ExternalEmitHelpers2[ExternalEmitHelpers2["SetFunctionName"] = 8388608] = "SetFunctionName";
         ExternalEmitHelpers2[ExternalEmitHelpers2["PropKey"] = 16777216] = "PropKey";
+        ExternalEmitHelpers2[ExternalEmitHelpers2["AddDisposableResourceAndDisposeResources"] = 33554432] = "AddDisposableResourceAndDisposeResources";
         ExternalEmitHelpers2[ExternalEmitHelpers2["FirstEmitHelper"] = 1 /* Extends */] = "FirstEmitHelper";
-        ExternalEmitHelpers2[ExternalEmitHelpers2["LastEmitHelper"] = 16777216 /* PropKey */] = "LastEmitHelper";
+        ExternalEmitHelpers2[ExternalEmitHelpers2["LastEmitHelper"] = 33554432 /* AddDisposableResourceAndDisposeResources */] = "LastEmitHelper";
         ExternalEmitHelpers2[ExternalEmitHelpers2["ForOfIncludes"] = 256 /* Values */] = "ForOfIncludes";
         ExternalEmitHelpers2[ExternalEmitHelpers2["ForAwaitOfIncludes"] = 16384 /* AsyncValues */] = "ForAwaitOfIncludes";
         ExternalEmitHelpers2[ExternalEmitHelpers2["AsyncGeneratorIncludes"] = 6144] = "AsyncGeneratorIncludes";
@@ -104480,7 +87092,8 @@ ${lanes.join("\n")}
         ListFormat2[ListFormat2["ObjectBindingPatternElements"] = 525136] = "ObjectBindingPatternElements";
         ListFormat2[ListFormat2["ArrayBindingPatternElements"] = 524880] = "ArrayBindingPatternElements";
         ListFormat2[ListFormat2["ObjectLiteralExpressionProperties"] = 526226] = "ObjectLiteralExpressionProperties";
-        ListFormat2[ListFormat2["ImportClauseEntries"] = 526226] = "ImportClauseEntries";
+        ListFormat2[ListFormat2["ImportAttributes"] = 526226] = "ImportAttributes";
+        ListFormat2[ListFormat2["ImportClauseEntries"] = 526226 /* ImportAttributes */] = "ImportClauseEntries";
         ListFormat2[ListFormat2["ArrayLiteralExpressionElements"] = 8914] = "ArrayLiteralExpressionElements";
         ListFormat2[ListFormat2["CommaListElements"] = 528] = "CommaListElements";
         ListFormat2[ListFormat2["CallExpressionArguments"] = 2576] = "CallExpressionArguments";
@@ -104561,6 +87174,13 @@ ${lanes.join("\n")}
           kind: 4 /* MultiLine */
         }
       };
+      JSDocParsingMode = /* @__PURE__ */ ((JSDocParsingMode6) => {
+        JSDocParsingMode6[JSDocParsingMode6["ParseAll"] = 0] = "ParseAll";
+        JSDocParsingMode6[JSDocParsingMode6["ParseNone"] = 1] = "ParseNone";
+        JSDocParsingMode6[JSDocParsingMode6["ParseForTypeErrors"] = 2] = "ParseForTypeErrors";
+        JSDocParsingMode6[JSDocParsingMode6["ParseForTypeInfo"] = 3] = "ParseForTypeInfo";
+        return JSDocParsingMode6;
+      })(JSDocParsingMode || {});
     }
   });
 
@@ -104772,10 +87392,10 @@ ${lanes.join("\n")}
       pollingIntervalQueue(pollingInterval).pollScheduled = host.setTimeout(pollingInterval === 250 /* Low */ ? pollLowPollingIntervalQueue : pollPollingIntervalQueue, pollingInterval, pollingInterval === 250 /* Low */ ? "pollLowPollingIntervalQueue" : "pollPollingIntervalQueue", pollingIntervalQueue(pollingInterval));
     }
   }
-  function createUseFsEventsOnParentDirectoryWatchFile(fsWatch, useCaseSensitiveFileNames) {
+  function createUseFsEventsOnParentDirectoryWatchFile(fsWatch, useCaseSensitiveFileNames2) {
     const fileWatcherCallbacks = createMultiMap();
     const dirWatchers = /* @__PURE__ */ new Map();
-    const toCanonicalName = createGetCanonicalFileName(useCaseSensitiveFileNames);
+    const toCanonicalName = createGetCanonicalFileName(useCaseSensitiveFileNames2);
     return nonPollingWatchFile;
     function nonPollingWatchFile(fileName, callback, _pollingInterval, fallbackOptions) {
       const filePath = toCanonicalName(fileName);
@@ -104851,8 +87471,8 @@ ${lanes.join("\n")}
       pollScheduled = host.setTimeout(pollQueue, 2e3 /* High */, "pollQueue");
     }
   }
-  function createSingleWatcherPerName(cache, useCaseSensitiveFileNames, name, callback, createWatcher) {
-    const toCanonicalFileName = createGetCanonicalFileName(useCaseSensitiveFileNames);
+  function createSingleWatcherPerName(cache, useCaseSensitiveFileNames2, name, callback, createWatcher) {
+    const toCanonicalFileName = createGetCanonicalFileName(useCaseSensitiveFileNames2);
     const path = toCanonicalFileName(name);
     const existing = cache.get(path);
     if (existing) {
@@ -104902,7 +87522,7 @@ ${lanes.join("\n")}
   }
   function createDirectoryWatcherSupportingRecursive({
     watchDirectory,
-    useCaseSensitiveFileNames,
+    useCaseSensitiveFileNames: useCaseSensitiveFileNames2,
     getCurrentDirectory,
     getAccessibleSortedChildDirectories,
     fileSystemEntryExists,
@@ -104914,8 +87534,8 @@ ${lanes.join("\n")}
     const callbackCache = createMultiMap();
     const cacheToUpdateChildWatches = /* @__PURE__ */ new Map();
     let timerToUpdateChildWatches;
-    const filePathComparer = getStringComparer(!useCaseSensitiveFileNames);
-    const toCanonicalFilePath = createGetCanonicalFileName(useCaseSensitiveFileNames);
+    const filePathComparer = getStringComparer(!useCaseSensitiveFileNames2);
+    const toCanonicalFilePath = createGetCanonicalFileName(useCaseSensitiveFileNames2);
     return (dirName, callback, recursive, options) => recursive ? createDirectoryWatcher(dirName, options, callback) : watchDirectory(dirName, callback, recursive, options);
     function createDirectoryWatcher(dirName, options, callback) {
       const dirPath = toCanonicalFilePath(dirName);
@@ -105082,14 +87702,14 @@ ${lanes.join("\n")}
       }
     }
     function isIgnoredPath(path, options) {
-      return some(ignoredPaths, (searchPath) => isInPath(path, searchPath)) || isIgnoredByWatchOptions(path, options, useCaseSensitiveFileNames, getCurrentDirectory);
+      return some(ignoredPaths, (searchPath) => isInPath(path, searchPath)) || isIgnoredByWatchOptions(path, options, useCaseSensitiveFileNames2, getCurrentDirectory);
     }
     function isInPath(path, searchPath) {
-      if (stringContains(path, searchPath))
+      if (path.includes(searchPath))
         return true;
-      if (useCaseSensitiveFileNames)
+      if (useCaseSensitiveFileNames2)
         return false;
-      return stringContains(toCanonicalFilePath(path), searchPath);
+      return toCanonicalFilePath(path).includes(searchPath);
     }
   }
   function createFileWatcherCallback(callback) {
@@ -105105,14 +87725,14 @@ ${lanes.join("\n")}
       }
     };
   }
-  function isIgnoredByWatchOptions(pathToCheck, options, useCaseSensitiveFileNames, getCurrentDirectory) {
-    return ((options == null ? void 0 : options.excludeDirectories) || (options == null ? void 0 : options.excludeFiles)) && (matchesExclude(pathToCheck, options == null ? void 0 : options.excludeFiles, useCaseSensitiveFileNames, getCurrentDirectory()) || matchesExclude(pathToCheck, options == null ? void 0 : options.excludeDirectories, useCaseSensitiveFileNames, getCurrentDirectory()));
+  function isIgnoredByWatchOptions(pathToCheck, options, useCaseSensitiveFileNames2, getCurrentDirectory) {
+    return ((options == null ? void 0 : options.excludeDirectories) || (options == null ? void 0 : options.excludeFiles)) && (matchesExclude(pathToCheck, options == null ? void 0 : options.excludeFiles, useCaseSensitiveFileNames2, getCurrentDirectory()) || matchesExclude(pathToCheck, options == null ? void 0 : options.excludeDirectories, useCaseSensitiveFileNames2, getCurrentDirectory()));
   }
-  function createFsWatchCallbackForDirectoryWatcherCallback(directoryName, callback, options, useCaseSensitiveFileNames, getCurrentDirectory) {
+  function createFsWatchCallbackForDirectoryWatcherCallback(directoryName, callback, options, useCaseSensitiveFileNames2, getCurrentDirectory) {
     return (eventName, relativeFileName) => {
       if (eventName === "rename") {
         const fileName = !relativeFileName ? directoryName : normalizePath(combinePaths(directoryName, relativeFileName));
-        if (!relativeFileName || !isIgnoredByWatchOptions(fileName, options, useCaseSensitiveFileNames, getCurrentDirectory)) {
+        if (!relativeFileName || !isIgnoredByWatchOptions(fileName, options, useCaseSensitiveFileNames2, getCurrentDirectory)) {
           callback(fileName);
         }
       }
@@ -105125,7 +87745,7 @@ ${lanes.join("\n")}
     clearTimeout: clearTimeout2,
     fsWatchWorker,
     fileSystemEntryExists,
-    useCaseSensitiveFileNames,
+    useCaseSensitiveFileNames: useCaseSensitiveFileNames2,
     getCurrentDirectory,
     fsSupportsRecursiveFsWatch,
     getAccessibleSortedChildDirectories,
@@ -105197,7 +87817,7 @@ ${lanes.join("\n")}
           );
         case 5 /* UseFsEventsOnParentDirectory */:
           if (!nonPollingWatchFile) {
-            nonPollingWatchFile = createUseFsEventsOnParentDirectoryWatchFile(fsWatch, useCaseSensitiveFileNames);
+            nonPollingWatchFile = createUseFsEventsOnParentDirectoryWatchFile(fsWatch, useCaseSensitiveFileNames2);
           }
           return nonPollingWatchFile(fileName, callback, pollingInterval, getFallbackOptions(options));
         default:
@@ -105246,7 +87866,7 @@ ${lanes.join("\n")}
         return fsWatch(
           directoryName,
           1 /* Directory */,
-          createFsWatchCallbackForDirectoryWatcherCallback(directoryName, callback, options, useCaseSensitiveFileNames, getCurrentDirectory),
+          createFsWatchCallbackForDirectoryWatcherCallback(directoryName, callback, options, useCaseSensitiveFileNames2, getCurrentDirectory),
           recursive,
           500 /* Medium */,
           getFallbackOptions(options)
@@ -105254,7 +87874,7 @@ ${lanes.join("\n")}
       }
       if (!hostRecursiveDirectoryWatcher) {
         hostRecursiveDirectoryWatcher = createDirectoryWatcherSupportingRecursive({
-          useCaseSensitiveFileNames,
+          useCaseSensitiveFileNames: useCaseSensitiveFileNames2,
           getCurrentDirectory,
           fileSystemEntryExists,
           getAccessibleSortedChildDirectories,
@@ -105300,7 +87920,7 @@ ${lanes.join("\n")}
           return fsWatch(
             directoryName,
             1 /* Directory */,
-            createFsWatchCallbackForDirectoryWatcherCallback(directoryName, callback, options, useCaseSensitiveFileNames, getCurrentDirectory),
+            createFsWatchCallbackForDirectoryWatcherCallback(directoryName, callback, options, useCaseSensitiveFileNames2, getCurrentDirectory),
             recursive,
             500 /* Medium */,
             getFallbackOptions(watchDirectoryOptions)
@@ -105328,7 +87948,7 @@ ${lanes.join("\n")}
     function pollingWatchFile(fileName, callback, pollingInterval, options) {
       return createSingleWatcherPerName(
         pollingWatches,
-        useCaseSensitiveFileNames,
+        useCaseSensitiveFileNames2,
         fileName,
         callback,
         (cb) => pollingWatchFileWorker(fileName, cb, pollingInterval, options)
@@ -105337,7 +87957,7 @@ ${lanes.join("\n")}
     function fsWatch(fileOrDirectory, entryKind, callback, recursive, fallbackPollingInterval, fallbackOptions) {
       return createSingleWatcherPerName(
         recursive ? fsWatchesRecursive : fsWatches,
-        useCaseSensitiveFileNames,
+        useCaseSensitiveFileNames2,
         fileOrDirectory,
         callback,
         (cb) => fsWatchHandlingExistenceOnHost(fileOrDirectory, entryKind, cb, recursive, fallbackPollingInterval, fallbackOptions)
@@ -105496,7 +88116,7 @@ ${lanes.join("\n")}
           const Buffer2 =   (__nccwpck_require__(14300).Buffer);
           const isLinuxOrMacOs = process.platform === "linux" || process.platform === "darwin";
           const platform = _os.platform();
-          const useCaseSensitiveFileNames = isFileSystemCaseSensitive();
+          const useCaseSensitiveFileNames2 = isFileSystemCaseSensitive();
           const fsRealpath = !!_fs.realpathSync.native ? process.platform === "win32" ? fsRealPathHandlingLongPath : _fs.realpathSync.native : _fs.realpathSync;
           const executingFilePath = __filename.endsWith("sys.js") ? _path.join(_path.dirname(__dirname), "__fake__.js") : __filename;
           const fsSupportsRecursiveFsWatch = process.platform === "win32" || process.platform === "darwin";
@@ -105507,7 +88127,7 @@ ${lanes.join("\n")}
             setTimeout,
             clearTimeout,
             fsWatchWorker,
-            useCaseSensitiveFileNames,
+            useCaseSensitiveFileNames: useCaseSensitiveFileNames2,
             getCurrentDirectory,
             fileSystemEntryExists,
             // Node 4.0 `fs.watch` function supports the "recursive" option on both OSX and Windows
@@ -105524,7 +88144,7 @@ ${lanes.join("\n")}
           const nodeSystem = {
             args: process.argv.slice(2),
             newLine: _os.EOL,
-            useCaseSensitiveFileNames,
+            useCaseSensitiveFileNames: useCaseSensitiveFileNames2,
             write(s) {
               process.stdout.write(s);
             },
@@ -105589,10 +88209,10 @@ ${lanes.join("\n")}
             disableCPUProfiler,
             cpuProfilingEnabled: () => !!activeSession || contains(process.execArgv, "--cpu-prof") || contains(process.execArgv, "--prof"),
             realpath,
-            debugMode: !!process.env.NODE_INSPECTOR_IPC || !!process.env.VSCODE_INSPECTOR_OPTIONS || some(process.execArgv, (arg) => /^--(inspect|debug)(-brk)?(=\d+)?$/i.test(arg)),
+            debugMode: !!process.env.NODE_INSPECTOR_IPC || !!process.env.VSCODE_INSPECTOR_OPTIONS || some(process.execArgv, (arg) => /^--(inspect|debug)(-brk)?(=\d+)?$/i.test(arg)) || !!process.recordreplay,
             tryEnableSourceMapsForHost() {
               try {
-                  (__nccwpck_require__(42059).install)();
+                  (__nccwpck_require__(98841).install)();
               } catch {
               }
             },
@@ -105615,8 +88235,8 @@ ${lanes.join("\n")}
               try {
                 const modulePath = resolveJSModule(moduleName, baseDir, nodeSystem);
                 return { module:   require(modulePath), modulePath, error: void 0 };
-              } catch (error) {
-                return { module: void 0, modulePath: void 0, error };
+              } catch (error2) {
+                return { module: void 0, modulePath: void 0, error: error2 };
               }
             }
           };
@@ -105653,12 +88273,12 @@ ${lanes.join("\n")}
             for (const node of profile.nodes) {
               if (node.callFrame.url) {
                 const url = normalizeSlashes(node.callFrame.url);
-                if (containsPath(fileUrlRoot, url, useCaseSensitiveFileNames)) {
+                if (containsPath(fileUrlRoot, url, useCaseSensitiveFileNames2)) {
                   node.callFrame.url = getRelativePathToDirectoryOrUrl(
                     fileUrlRoot,
                     url,
                     fileUrlRoot,
-                    createGetCanonicalFileName(useCaseSensitiveFileNames),
+                    createGetCanonicalFileName(useCaseSensitiveFileNames2),
                     /*isAbsolutePathAnUrl*/
                     true
                   );
@@ -105703,6 +88323,9 @@ ${lanes.join("\n")}
             return Buffer2.from && Buffer2.from !== Int8Array.from ? Buffer2.from(input, encoding) : new Buffer2(input, encoding);
           }
           function isFileSystemCaseSensitive() {
+            if (typeof process.versions.pnp !== `undefined`) {
+              return true;
+            }
             if (platform === "win32" || platform === "win64") {
               return false;
             }
@@ -105838,7 +88461,7 @@ ${lanes.join("\n")}
             }
           }
           function readDirectory(path, extensions, excludes, includes, depth) {
-            return matchFiles(path, extensions, excludes, includes, useCaseSensitiveFileNames, process.cwd(), depth, getAccessibleFileSystemEntries, realpath);
+            return matchFiles(path, extensions, excludes, includes, useCaseSensitiveFileNames2, process.cwd(), depth, getAccessibleFileSystemEntries, realpath);
           }
           function fileSystemEntryExists(path, entryKind) {
             const originalStackTraceLimit = Error.stackTraceLimit;
@@ -105924,7 +88547,9 @@ ${lanes.join("\n")}
       })();
       if (sys && sys.getEnvironmentVariable) {
         setCustomPollingValues(sys);
-        Debug.setAssertionLevel(/^development$/i.test(sys.getEnvironmentVariable("NODE_ENV")) ? 1 /* Normal */ : 0 /* None */);
+        Debug.setAssertionLevel(
+          /^development$/i.test(sys.getEnvironmentVariable("NODE_ENV")) ? 1 /* Normal */ : 0 /* None */
+        );
       }
       if (sys && sys.debugMode) {
         Debug.isDebugging = true;
@@ -105956,7 +88581,7 @@ ${lanes.join("\n")}
     return !pathIsAbsolute(path) && !pathIsRelative(path);
   }
   function hasExtension(fileName) {
-    return stringContains(getBaseFileName(fileName), ".");
+    return getBaseFileName(fileName).includes(".");
   }
   function fileExtensionIs(path, extension) {
     return path.length > extension.length && endsWith(path, extension);
@@ -106101,7 +88726,7 @@ ${lanes.join("\n")}
     return root + pathComponents2.slice(1, length2).join(directorySeparator);
   }
   function normalizeSlashes(path) {
-    return path.indexOf("\\") !== -1 ? path.replace(backslashRegExp, directorySeparator) : path;
+    return path.includes("\\") ? path.replace(backslashRegExp, directorySeparator) : path;
   }
   function reducePathComponents(components) {
     if (!some(components))
@@ -106414,6 +89039,7 @@ ${lanes.join("\n")}
         Type_is_referenced_directly_or_indirectly_in_the_fulfillment_callback_of_its_own_then_method: diag(1062, 1 /* Error */, "Type_is_referenced_directly_or_indirectly_in_the_fulfillment_callback_of_its_own_then_method_1062", "Type is referenced directly or indirectly in the fulfillment callback of its own 'then' method."),
         An_export_assignment_cannot_be_used_in_a_namespace: diag(1063, 1 /* Error */, "An_export_assignment_cannot_be_used_in_a_namespace_1063", "An export assignment cannot be used in a namespace."),
         The_return_type_of_an_async_function_or_method_must_be_the_global_Promise_T_type_Did_you_mean_to_write_Promise_0: diag(1064, 1 /* Error */, "The_return_type_of_an_async_function_or_method_must_be_the_global_Promise_T_type_Did_you_mean_to_wri_1064", "The return type of an async function or method must be the global Promise type. Did you mean to write 'Promise<{0}>'?"),
+        The_return_type_of_an_async_function_or_method_must_be_the_global_Promise_T_type: diag(1065, 1 /* Error */, "The_return_type_of_an_async_function_or_method_must_be_the_global_Promise_T_type_1065", "The return type of an async function or method must be the global Promise type."),
         In_ambient_enum_declarations_member_initializer_must_be_constant_expression: diag(1066, 1 /* Error */, "In_ambient_enum_declarations_member_initializer_must_be_constant_expression_1066", "In ambient enum declarations member initializer must be constant expression."),
         Unexpected_token_A_constructor_method_accessor_or_property_was_expected: diag(1068, 1 /* Error */, "Unexpected_token_A_constructor_method_accessor_or_property_was_expected_1068", "Unexpected token. A constructor, method, accessor, or property was expected."),
         Unexpected_token_A_type_parameter_name_was_expected_without_curly_braces: diag(1069, 1 /* Error */, "Unexpected_token_A_type_parameter_name_was_expected_without_curly_braces_1069", "Unexpected token. A type parameter name was expected without curly braces."),
@@ -106443,6 +89069,7 @@ ${lanes.join("\n")}
         A_return_statement_can_only_be_used_within_a_function_body: diag(1108, 1 /* Error */, "A_return_statement_can_only_be_used_within_a_function_body_1108", "A 'return' statement can only be used within a function body."),
         Expression_expected: diag(1109, 1 /* Error */, "Expression_expected_1109", "Expression expected."),
         Type_expected: diag(1110, 1 /* Error */, "Type_expected_1110", "Type expected."),
+        Private_field_0_must_be_declared_in_an_enclosing_class: diag(1111, 1 /* Error */, "Private_field_0_must_be_declared_in_an_enclosing_class_1111", "Private field '{0}' must be declared in an enclosing class."),
         A_default_clause_cannot_appear_more_than_once_in_a_switch_statement: diag(1113, 1 /* Error */, "A_default_clause_cannot_appear_more_than_once_in_a_switch_statement_1113", "A 'default' clause cannot appear more than once in a 'switch' statement."),
         Duplicate_label_0: diag(1114, 1 /* Error */, "Duplicate_label_0_1114", "Duplicate label '{0}'."),
         A_continue_statement_can_only_jump_to_a_label_of_an_enclosing_iteration_statement: diag(1115, 1 /* Error */, "A_continue_statement_can_only_jump_to_a_label_of_an_enclosing_iteration_statement_1115", "A 'continue' statement can only jump to a label of an enclosing iteration statement."),
@@ -106477,9 +89104,8 @@ ${lanes.join("\n")}
         Import_declarations_in_a_namespace_cannot_reference_a_module: diag(1147, 1 /* Error */, "Import_declarations_in_a_namespace_cannot_reference_a_module_1147", "Import declarations in a namespace cannot reference a module."),
         Cannot_use_imports_exports_or_module_augmentations_when_module_is_none: diag(1148, 1 /* Error */, "Cannot_use_imports_exports_or_module_augmentations_when_module_is_none_1148", "Cannot use imports, exports, or module augmentations when '--module' is 'none'."),
         File_name_0_differs_from_already_included_file_name_1_only_in_casing: diag(1149, 1 /* Error */, "File_name_0_differs_from_already_included_file_name_1_only_in_casing_1149", "File name '{0}' differs from already included file name '{1}' only in casing."),
-        const_declarations_must_be_initialized: diag(1155, 1 /* Error */, "const_declarations_must_be_initialized_1155", "'const' declarations must be initialized."),
-        const_declarations_can_only_be_declared_inside_a_block: diag(1156, 1 /* Error */, "const_declarations_can_only_be_declared_inside_a_block_1156", "'const' declarations can only be declared inside a block."),
-        let_declarations_can_only_be_declared_inside_a_block: diag(1157, 1 /* Error */, "let_declarations_can_only_be_declared_inside_a_block_1157", "'let' declarations can only be declared inside a block."),
+        _0_declarations_must_be_initialized: diag(1155, 1 /* Error */, "_0_declarations_must_be_initialized_1155", "'{0}' declarations must be initialized."),
+        _0_declarations_can_only_be_declared_inside_a_block: diag(1156, 1 /* Error */, "_0_declarations_can_only_be_declared_inside_a_block_1156", "'{0}' declarations can only be declared inside a block."),
         Unterminated_template_literal: diag(1160, 1 /* Error */, "Unterminated_template_literal_1160", "Unterminated template literal."),
         Unterminated_regular_expression_literal: diag(1161, 1 /* Error */, "Unterminated_regular_expression_literal_1161", "Unterminated regular expression literal."),
         An_object_member_cannot_be_declared_optional: diag(1162, 1 /* Error */, "An_object_member_cannot_be_declared_optional_1162", "An object member cannot be declared optional."),
@@ -106661,8 +89287,6 @@ ${lanes.join("\n")}
         Class_constructor_may_not_be_a_generator: diag(1368, 1 /* Error */, "Class_constructor_may_not_be_a_generator_1368", "Class constructor may not be a generator."),
         Did_you_mean_0: diag(1369, 3 /* Message */, "Did_you_mean_0_1369", "Did you mean '{0}'?"),
         This_import_is_never_used_as_a_value_and_must_use_import_type_because_importsNotUsedAsValues_is_set_to_error: diag(1371, 1 /* Error */, "This_import_is_never_used_as_a_value_and_must_use_import_type_because_importsNotUsedAsValues_is_set__1371", "This import is never used as a value and must use 'import type' because 'importsNotUsedAsValues' is set to 'error'."),
-        Convert_to_type_only_import: diag(1373, 3 /* Message */, "Convert_to_type_only_import_1373", "Convert to type-only import"),
-        Convert_all_imports_not_used_as_a_value_to_type_only_imports: diag(1374, 3 /* Message */, "Convert_all_imports_not_used_as_a_value_to_type_only_imports_1374", "Convert all imports not used as a value to type-only imports"),
         await_expressions_are_only_allowed_at_the_top_level_of_a_file_when_that_file_is_a_module_but_this_file_has_no_imports_or_exports_Consider_adding_an_empty_export_to_make_this_file_a_module: diag(1375, 1 /* Error */, "await_expressions_are_only_allowed_at_the_top_level_of_a_file_when_that_file_is_a_module_but_this_fi_1375", "'await' expressions are only allowed at the top level of a file when that file is a module, but this file has no imports or exports. Consider adding an empty 'export {}' to make this file a module."),
         _0_was_imported_here: diag(1376, 3 /* Message */, "_0_was_imported_here_1376", "'{0}' was imported here."),
         _0_was_exported_here: diag(1377, 3 /* Message */, "_0_was_exported_here_1377", "'{0}' was exported here."),
@@ -106733,9 +89357,8 @@ ${lanes.join("\n")}
         _0_resolves_to_a_type_only_declaration_and_must_be_imported_using_a_type_only_import_when_preserveValueImports_and_isolatedModules_are_both_enabled: diag(1446, 1 /* Error */, "_0_resolves_to_a_type_only_declaration_and_must_be_imported_using_a_type_only_import_when_preserveVa_1446", "'{0}' resolves to a type-only declaration and must be imported using a type-only import when 'preserveValueImports' and 'isolatedModules' are both enabled."),
         _0_resolves_to_a_type_only_declaration_and_must_be_re_exported_using_a_type_only_re_export_when_1_is_enabled: diag(1448, 1 /* Error */, "_0_resolves_to_a_type_only_declaration_and_must_be_re_exported_using_a_type_only_re_export_when_1_is_1448", "'{0}' resolves to a type-only declaration and must be re-exported using a type-only re-export when '{1}' is enabled."),
         Preserve_unused_imported_values_in_the_JavaScript_output_that_would_otherwise_be_removed: diag(1449, 3 /* Message */, "Preserve_unused_imported_values_in_the_JavaScript_output_that_would_otherwise_be_removed_1449", "Preserve unused imported values in the JavaScript output that would otherwise be removed."),
-        Dynamic_imports_can_only_accept_a_module_specifier_and_an_optional_assertion_as_arguments: diag(1450, 3 /* Message */, "Dynamic_imports_can_only_accept_a_module_specifier_and_an_optional_assertion_as_arguments_1450", "Dynamic imports can only accept a module specifier and an optional assertion as arguments"),
+        Dynamic_imports_can_only_accept_a_module_specifier_and_an_optional_set_of_attributes_as_arguments: diag(1450, 3 /* Message */, "Dynamic_imports_can_only_accept_a_module_specifier_and_an_optional_set_of_attributes_as_arguments_1450", "Dynamic imports can only accept a module specifier and an optional set of attributes as arguments"),
         Private_identifiers_are_only_allowed_in_class_bodies_and_may_only_be_used_as_part_of_a_class_member_declaration_property_access_or_on_the_left_hand_side_of_an_in_expression: diag(1451, 1 /* Error */, "Private_identifiers_are_only_allowed_in_class_bodies_and_may_only_be_used_as_part_of_a_class_member__1451", "Private identifiers are only allowed in class bodies and may only be used as part of a class member declaration, property access, or on the left-hand-side of an 'in' expression"),
-        resolution_mode_assertions_are_only_supported_when_moduleResolution_is_node16_or_nodenext: diag(1452, 1 /* Error */, "resolution_mode_assertions_are_only_supported_when_moduleResolution_is_node16_or_nodenext_1452", "'resolution-mode' assertions are only supported when `moduleResolution` is `node16` or `nodenext`."),
         resolution_mode_should_be_either_require_or_import: diag(1453, 1 /* Error */, "resolution_mode_should_be_either_require_or_import_1453", "`resolution-mode` should be either `require` or `import`."),
         resolution_mode_can_only_be_set_for_type_only_imports: diag(1454, 1 /* Error */, "resolution_mode_can_only_be_set_for_type_only_imports_1454", "`resolution-mode` can only be set for type-only imports."),
         resolution_mode_is_the_only_valid_key_for_type_import_assertions: diag(1455, 1 /* Error */, "resolution_mode_is_the_only_valid_key_for_type_import_assertions_1455", "`resolution-mode` is the only valid key for type import assertions."),
@@ -106745,6 +89368,8 @@ ${lanes.join("\n")}
         File_is_CommonJS_module_because_0_has_field_type_whose_value_is_not_module: diag(1459, 3 /* Message */, "File_is_CommonJS_module_because_0_has_field_type_whose_value_is_not_module_1459", `File is CommonJS module because '{0}' has field "type" whose value is not "module"`),
         File_is_CommonJS_module_because_0_does_not_have_field_type: diag(1460, 3 /* Message */, "File_is_CommonJS_module_because_0_does_not_have_field_type_1460", `File is CommonJS module because '{0}' does not have field "type"`),
         File_is_CommonJS_module_because_package_json_was_not_found: diag(1461, 3 /* Message */, "File_is_CommonJS_module_because_package_json_was_not_found_1461", "File is CommonJS module because 'package.json' was not found"),
+        resolution_mode_is_the_only_valid_key_for_type_import_attributes: diag(1463, 1 /* Error */, "resolution_mode_is_the_only_valid_key_for_type_import_attributes_1463", "'resolution-mode' is the only valid key for type import attributes."),
+        Type_import_attributes_should_have_exactly_one_key_resolution_mode_with_value_import_or_require: diag(1464, 1 /* Error */, "Type_import_attributes_should_have_exactly_one_key_resolution_mode_with_value_import_or_require_1464", "Type import attributes should have exactly one key - 'resolution-mode' - with value 'import' or 'require'."),
         The_import_meta_meta_property_is_not_allowed_in_files_which_will_build_into_CommonJS_output: diag(1470, 1 /* Error */, "The_import_meta_meta_property_is_not_allowed_in_files_which_will_build_into_CommonJS_output_1470", "The 'import.meta' meta-property is not allowed in files which will build into CommonJS output."),
         Module_0_cannot_be_imported_using_this_construct_The_specifier_only_resolves_to_an_ES_module_which_cannot_be_imported_with_require_Use_an_ECMAScript_import_instead: diag(1471, 1 /* Error */, "Module_0_cannot_be_imported_using_this_construct_The_specifier_only_resolves_to_an_ES_module_which_c_1471", "Module '{0}' cannot be imported using this construct. The specifier only resolves to an ES module, which cannot be imported with 'require'. Use an ECMAScript import instead."),
         catch_or_finally_expected: diag(1472, 1 /* Error */, "catch_or_finally_expected_1472", "'catch' or 'finally' expected."),
@@ -106766,6 +89391,12 @@ ${lanes.join("\n")}
         Escape_sequence_0_is_not_allowed: diag(1488, 1 /* Error */, "Escape_sequence_0_is_not_allowed_1488", "Escape sequence '{0}' is not allowed."),
         Decimals_with_leading_zeros_are_not_allowed: diag(1489, 1 /* Error */, "Decimals_with_leading_zeros_are_not_allowed_1489", "Decimals with leading zeros are not allowed."),
         File_appears_to_be_binary: diag(1490, 1 /* Error */, "File_appears_to_be_binary_1490", "File appears to be binary."),
+        _0_modifier_cannot_appear_on_a_using_declaration: diag(1491, 1 /* Error */, "_0_modifier_cannot_appear_on_a_using_declaration_1491", "'{0}' modifier cannot appear on a 'using' declaration."),
+        _0_declarations_may_not_have_binding_patterns: diag(1492, 1 /* Error */, "_0_declarations_may_not_have_binding_patterns_1492", "'{0}' declarations may not have binding patterns."),
+        The_left_hand_side_of_a_for_in_statement_cannot_be_a_using_declaration: diag(1493, 1 /* Error */, "The_left_hand_side_of_a_for_in_statement_cannot_be_a_using_declaration_1493", "The left-hand side of a 'for...in' statement cannot be a 'using' declaration."),
+        The_left_hand_side_of_a_for_in_statement_cannot_be_an_await_using_declaration: diag(1494, 1 /* Error */, "The_left_hand_side_of_a_for_in_statement_cannot_be_an_await_using_declaration_1494", "The left-hand side of a 'for...in' statement cannot be an 'await using' declaration."),
+        _0_modifier_cannot_appear_on_an_await_using_declaration: diag(1495, 1 /* Error */, "_0_modifier_cannot_appear_on_an_await_using_declaration_1495", "'{0}' modifier cannot appear on an 'await using' declaration."),
+        Identifier_string_literal_or_number_literal_expected: diag(1496, 1 /* Error */, "Identifier_string_literal_or_number_literal_expected_1496", "Identifier, string literal, or number literal expected."),
         The_types_of_0_are_incompatible_between_these_types: diag(2200, 1 /* Error */, "The_types_of_0_are_incompatible_between_these_types_2200", "The types of '{0}' are incompatible between these types."),
         The_types_returned_by_0_are_incompatible_between_these_types: diag(2201, 1 /* Error */, "The_types_returned_by_0_are_incompatible_between_these_types_2201", "The types returned by '{0}' are incompatible between these types."),
         Call_signature_return_types_0_and_1_are_incompatible: diag(
@@ -106860,7 +89491,6 @@ ${lanes.join("\n")}
         This_syntax_requires_an_imported_helper_named_1_which_does_not_exist_in_0_Consider_upgrading_your_version_of_0: diag(2343, 1 /* Error */, "This_syntax_requires_an_imported_helper_named_1_which_does_not_exist_in_0_Consider_upgrading_your_ve_2343", "This syntax requires an imported helper named '{1}' which does not exist in '{0}'. Consider upgrading your version of '{0}'."),
         Type_0_does_not_satisfy_the_constraint_1: diag(2344, 1 /* Error */, "Type_0_does_not_satisfy_the_constraint_1_2344", "Type '{0}' does not satisfy the constraint '{1}'."),
         Argument_of_type_0_is_not_assignable_to_parameter_of_type_1: diag(2345, 1 /* Error */, "Argument_of_type_0_is_not_assignable_to_parameter_of_type_1_2345", "Argument of type '{0}' is not assignable to parameter of type '{1}'."),
-        Call_target_does_not_contain_any_signatures: diag(2346, 1 /* Error */, "Call_target_does_not_contain_any_signatures_2346", "Call target does not contain any signatures."),
         Untyped_function_calls_may_not_accept_type_arguments: diag(2347, 1 /* Error */, "Untyped_function_calls_may_not_accept_type_arguments_2347", "Untyped function calls may not accept type arguments."),
         Value_of_type_0_is_not_callable_Did_you_mean_to_include_new: diag(2348, 1 /* Error */, "Value_of_type_0_is_not_callable_Did_you_mean_to_include_new_2348", "Value of type '{0}' is not callable. Did you mean to include 'new'?"),
         This_expression_is_not_callable: diag(2349, 1 /* Error */, "This_expression_is_not_callable_2349", "This expression is not callable."),
@@ -106873,7 +89503,7 @@ ${lanes.join("\n")}
         An_arithmetic_operand_must_be_of_type_any_number_bigint_or_an_enum_type: diag(2356, 1 /* Error */, "An_arithmetic_operand_must_be_of_type_any_number_bigint_or_an_enum_type_2356", "An arithmetic operand must be of type 'any', 'number', 'bigint' or an enum type."),
         The_operand_of_an_increment_or_decrement_operator_must_be_a_variable_or_a_property_access: diag(2357, 1 /* Error */, "The_operand_of_an_increment_or_decrement_operator_must_be_a_variable_or_a_property_access_2357", "The operand of an increment or decrement operator must be a variable or a property access."),
         The_left_hand_side_of_an_instanceof_expression_must_be_of_type_any_an_object_type_or_a_type_parameter: diag(2358, 1 /* Error */, "The_left_hand_side_of_an_instanceof_expression_must_be_of_type_any_an_object_type_or_a_type_paramete_2358", "The left-hand side of an 'instanceof' expression must be of type 'any', an object type or a type parameter."),
-        The_right_hand_side_of_an_instanceof_expression_must_be_of_type_any_or_of_a_type_assignable_to_the_Function_interface_type: diag(2359, 1 /* Error */, "The_right_hand_side_of_an_instanceof_expression_must_be_of_type_any_or_of_a_type_assignable_to_the_F_2359", "The right-hand side of an 'instanceof' expression must be of type 'any' or of a type assignable to the 'Function' interface type."),
+        The_right_hand_side_of_an_instanceof_expression_must_be_either_of_type_any_a_class_function_or_other_type_assignable_to_the_Function_interface_type_or_an_object_type_with_a_Symbol_hasInstance_method: diag(2359, 1 /* Error */, "The_right_hand_side_of_an_instanceof_expression_must_be_either_of_type_any_a_class_function_or_other_2359", "The right-hand side of an 'instanceof' expression must be either of type 'any', a class, function, or other type assignable to the 'Function' interface type, or an object type with a 'Symbol.hasInstance' method."),
         The_left_hand_side_of_an_arithmetic_operation_must_be_of_type_any_number_bigint_or_an_enum_type: diag(2362, 1 /* Error */, "The_left_hand_side_of_an_arithmetic_operation_must_be_of_type_any_number_bigint_or_an_enum_type_2362", "The left-hand side of an arithmetic operation must be of type 'any', 'number', 'bigint' or an enum type."),
         The_right_hand_side_of_an_arithmetic_operation_must_be_of_type_any_number_bigint_or_an_enum_type: diag(2363, 1 /* Error */, "The_right_hand_side_of_an_arithmetic_operation_must_be_of_type_any_number_bigint_or_an_enum_type_2363", "The right-hand side of an arithmetic operation must be of type 'any', 'number', 'bigint' or an enum type."),
         The_left_hand_side_of_an_assignment_expression_must_be_a_variable_or_a_property_access: diag(2364, 1 /* Error */, "The_left_hand_side_of_an_assignment_expression_must_be_a_variable_or_a_property_access_2364", "The left-hand side of an assignment expression must be a variable or a property access."),
@@ -107296,15 +89926,15 @@ ${lanes.join("\n")}
         Type_0_is_not_assignable_to_type_1_Did_you_mean_2: diag(2820, 1 /* Error */, "Type_0_is_not_assignable_to_type_1_Did_you_mean_2_2820", "Type '{0}' is not assignable to type '{1}'. Did you mean '{2}'?"),
         Import_assertions_are_only_supported_when_the_module_option_is_set_to_esnext_or_nodenext: diag(2821, 1 /* Error */, "Import_assertions_are_only_supported_when_the_module_option_is_set_to_esnext_or_nodenext_2821", "Import assertions are only supported when the '--module' option is set to 'esnext' or 'nodenext'."),
         Import_assertions_cannot_be_used_with_type_only_imports_or_exports: diag(2822, 1 /* Error */, "Import_assertions_cannot_be_used_with_type_only_imports_or_exports_2822", "Import assertions cannot be used with type-only imports or exports."),
+        Import_attributes_are_only_supported_when_the_module_option_is_set_to_esnext_or_nodenext: diag(2823, 1 /* Error */, "Import_attributes_are_only_supported_when_the_module_option_is_set_to_esnext_or_nodenext_2823", "Import attributes are only supported when the '--module' option is set to 'esnext' or 'nodenext'."),
         Cannot_find_namespace_0_Did_you_mean_1: diag(2833, 1 /* Error */, "Cannot_find_namespace_0_Did_you_mean_1_2833", "Cannot find namespace '{0}'. Did you mean '{1}'?"),
-        Relative_import_paths_need_explicit_file_extensions_in_EcmaScript_imports_when_moduleResolution_is_node16_or_nodenext_Consider_adding_an_extension_to_the_import_path: diag(2834, 1 /* Error */, "Relative_import_paths_need_explicit_file_extensions_in_EcmaScript_imports_when_moduleResolution_is_n_2834", "Relative import paths need explicit file extensions in EcmaScript imports when '--moduleResolution' is 'node16' or 'nodenext'. Consider adding an extension to the import path."),
-        Relative_import_paths_need_explicit_file_extensions_in_EcmaScript_imports_when_moduleResolution_is_node16_or_nodenext_Did_you_mean_0: diag(2835, 1 /* Error */, "Relative_import_paths_need_explicit_file_extensions_in_EcmaScript_imports_when_moduleResolution_is_n_2835", "Relative import paths need explicit file extensions in EcmaScript imports when '--moduleResolution' is 'node16' or 'nodenext'. Did you mean '{0}'?"),
-        Import_assertions_are_not_allowed_on_statements_that_transpile_to_commonjs_require_calls: diag(2836, 1 /* Error */, "Import_assertions_are_not_allowed_on_statements_that_transpile_to_commonjs_require_calls_2836", "Import assertions are not allowed on statements that transpile to commonjs 'require' calls."),
+        Relative_import_paths_need_explicit_file_extensions_in_ECMAScript_imports_when_moduleResolution_is_node16_or_nodenext_Consider_adding_an_extension_to_the_import_path: diag(2834, 1 /* Error */, "Relative_import_paths_need_explicit_file_extensions_in_ECMAScript_imports_when_moduleResolution_is_n_2834", "Relative import paths need explicit file extensions in ECMAScript imports when '--moduleResolution' is 'node16' or 'nodenext'. Consider adding an extension to the import path."),
+        Relative_import_paths_need_explicit_file_extensions_in_ECMAScript_imports_when_moduleResolution_is_node16_or_nodenext_Did_you_mean_0: diag(2835, 1 /* Error */, "Relative_import_paths_need_explicit_file_extensions_in_ECMAScript_imports_when_moduleResolution_is_n_2835", "Relative import paths need explicit file extensions in ECMAScript imports when '--moduleResolution' is 'node16' or 'nodenext'. Did you mean '{0}'?"),
+        Import_assertions_are_not_allowed_on_statements_that_compile_to_CommonJS_require_calls: diag(2836, 1 /* Error */, "Import_assertions_are_not_allowed_on_statements_that_compile_to_CommonJS_require_calls_2836", "Import assertions are not allowed on statements that compile to CommonJS 'require' calls."),
         Import_assertion_values_must_be_string_literal_expressions: diag(2837, 1 /* Error */, "Import_assertion_values_must_be_string_literal_expressions_2837", "Import assertion values must be string literal expressions."),
         All_declarations_of_0_must_have_identical_constraints: diag(2838, 1 /* Error */, "All_declarations_of_0_must_have_identical_constraints_2838", "All declarations of '{0}' must have identical constraints."),
         This_condition_will_always_return_0_since_JavaScript_compares_objects_by_reference_not_value: diag(2839, 1 /* Error */, "This_condition_will_always_return_0_since_JavaScript_compares_objects_by_reference_not_value_2839", "This condition will always return '{0}' since JavaScript compares objects by reference, not value."),
-        An_interface_cannot_extend_a_primitive_type_like_0_an_interface_can_only_extend_named_types_and_classes: diag(2840, 1 /* Error */, "An_interface_cannot_extend_a_primitive_type_like_0_an_interface_can_only_extend_named_types_and_clas_2840", "An interface cannot extend a primitive type like '{0}'; an interface can only extend named types and classes"),
-        The_type_of_this_expression_cannot_be_named_without_a_resolution_mode_assertion_which_is_an_unstable_feature_Use_nightly_TypeScript_to_silence_this_error_Try_updating_with_npm_install_D_typescript_next: diag(2841, 1 /* Error */, "The_type_of_this_expression_cannot_be_named_without_a_resolution_mode_assertion_which_is_an_unstable_2841", "The type of this expression cannot be named without a 'resolution-mode' assertion, which is an unstable feature. Use nightly TypeScript to silence this error. Try updating with 'npm install -D typescript@next'."),
+        An_interface_cannot_extend_a_primitive_type_like_0_It_can_only_extend_other_named_object_types: diag(2840, 1 /* Error */, "An_interface_cannot_extend_a_primitive_type_like_0_It_can_only_extend_other_named_object_types_2840", "An interface cannot extend a primitive type like '{0}'. It can only extend other named object types."),
         _0_is_an_unused_renaming_of_1_Did_you_intend_to_use_it_as_a_type_annotation: diag(2842, 1 /* Error */, "_0_is_an_unused_renaming_of_1_Did_you_intend_to_use_it_as_a_type_annotation_2842", "'{0}' is an unused renaming of '{1}'. Did you intend to use it as a type annotation?"),
         We_can_only_write_a_type_for_0_by_adding_a_type_for_the_entire_parameter_here: diag(2843, 1 /* Error */, "We_can_only_write_a_type_for_0_by_adding_a_type_for_the_entire_parameter_here_2843", "We can only write a type for '{0}' by adding a type for the entire parameter here."),
         Type_of_instance_member_variable_0_cannot_reference_identifier_1_declared_in_the_constructor: diag(2844, 1 /* Error */, "Type_of_instance_member_variable_0_cannot_reference_identifier_1_declared_in_the_constructor_2844", "Type of instance member variable '{0}' cannot reference identifier '{1}' declared in the constructor."),
@@ -107312,6 +89942,21 @@ ${lanes.join("\n")}
         A_declaration_file_cannot_be_imported_without_import_type_Did_you_mean_to_import_an_implementation_file_0_instead: diag(2846, 1 /* Error */, "A_declaration_file_cannot_be_imported_without_import_type_Did_you_mean_to_import_an_implementation_f_2846", "A declaration file cannot be imported without 'import type'. Did you mean to import an implementation file '{0}' instead?"),
         The_right_hand_side_of_an_instanceof_expression_must_not_be_an_instantiation_expression: diag(2848, 1 /* Error */, "The_right_hand_side_of_an_instanceof_expression_must_not_be_an_instantiation_expression_2848", "The right-hand side of an 'instanceof' expression must not be an instantiation expression."),
         Target_signature_provides_too_few_arguments_Expected_0_or_more_but_got_1: diag(2849, 1 /* Error */, "Target_signature_provides_too_few_arguments_Expected_0_or_more_but_got_1_2849", "Target signature provides too few arguments. Expected {0} or more, but got {1}."),
+        The_initializer_of_a_using_declaration_must_be_either_an_object_with_a_Symbol_dispose_method_or_be_null_or_undefined: diag(2850, 1 /* Error */, "The_initializer_of_a_using_declaration_must_be_either_an_object_with_a_Symbol_dispose_method_or_be_n_2850", "The initializer of a 'using' declaration must be either an object with a '[Symbol.dispose]()' method, or be 'null' or 'undefined'."),
+        The_initializer_of_an_await_using_declaration_must_be_either_an_object_with_a_Symbol_asyncDispose_or_Symbol_dispose_method_or_be_null_or_undefined: diag(2851, 1 /* Error */, "The_initializer_of_an_await_using_declaration_must_be_either_an_object_with_a_Symbol_asyncDispose_or_2851", "The initializer of an 'await using' declaration must be either an object with a '[Symbol.asyncDispose]()' or '[Symbol.dispose]()' method, or be 'null' or 'undefined'."),
+        await_using_statements_are_only_allowed_within_async_functions_and_at_the_top_levels_of_modules: diag(2852, 1 /* Error */, "await_using_statements_are_only_allowed_within_async_functions_and_at_the_top_levels_of_modules_2852", "'await using' statements are only allowed within async functions and at the top levels of modules."),
+        await_using_statements_are_only_allowed_at_the_top_level_of_a_file_when_that_file_is_a_module_but_this_file_has_no_imports_or_exports_Consider_adding_an_empty_export_to_make_this_file_a_module: diag(2853, 1 /* Error */, "await_using_statements_are_only_allowed_at_the_top_level_of_a_file_when_that_file_is_a_module_but_th_2853", "'await using' statements are only allowed at the top level of a file when that file is a module, but this file has no imports or exports. Consider adding an empty 'export {}' to make this file a module."),
+        Top_level_await_using_statements_are_only_allowed_when_the_module_option_is_set_to_es2022_esnext_system_node16_or_nodenext_and_the_target_option_is_set_to_es2017_or_higher: diag(2854, 1 /* Error */, "Top_level_await_using_statements_are_only_allowed_when_the_module_option_is_set_to_es2022_esnext_sys_2854", "Top-level 'await using' statements are only allowed when the 'module' option is set to 'es2022', 'esnext', 'system', 'node16', or 'nodenext', and the 'target' option is set to 'es2017' or higher."),
+        Class_field_0_defined_by_the_parent_class_is_not_accessible_in_the_child_class_via_super: diag(2855, 1 /* Error */, "Class_field_0_defined_by_the_parent_class_is_not_accessible_in_the_child_class_via_super_2855", "Class field '{0}' defined by the parent class is not accessible in the child class via super."),
+        Import_attributes_are_not_allowed_on_statements_that_compile_to_CommonJS_require_calls: diag(2856, 1 /* Error */, "Import_attributes_are_not_allowed_on_statements_that_compile_to_CommonJS_require_calls_2856", "Import attributes are not allowed on statements that compile to CommonJS 'require' calls."),
+        Import_attributes_cannot_be_used_with_type_only_imports_or_exports: diag(2857, 1 /* Error */, "Import_attributes_cannot_be_used_with_type_only_imports_or_exports_2857", "Import attributes cannot be used with type-only imports or exports."),
+        Import_attribute_values_must_be_string_literal_expressions: diag(2858, 1 /* Error */, "Import_attribute_values_must_be_string_literal_expressions_2858", "Import attribute values must be string literal expressions."),
+        Excessive_complexity_comparing_types_0_and_1: diag(2859, 1 /* Error */, "Excessive_complexity_comparing_types_0_and_1_2859", "Excessive complexity comparing types '{0}' and '{1}'."),
+        The_left_hand_side_of_an_instanceof_expression_must_be_assignable_to_the_first_argument_of_the_right_hand_side_s_Symbol_hasInstance_method: diag(2860, 1 /* Error */, "The_left_hand_side_of_an_instanceof_expression_must_be_assignable_to_the_first_argument_of_the_right_2860", "The left-hand side of an 'instanceof' expression must be assignable to the first argument of the right-hand side's '[Symbol.hasInstance]' method."),
+        An_object_s_Symbol_hasInstance_method_must_return_a_boolean_value_for_it_to_be_used_on_the_right_hand_side_of_an_instanceof_expression: diag(2861, 1 /* Error */, "An_object_s_Symbol_hasInstance_method_must_return_a_boolean_value_for_it_to_be_used_on_the_right_han_2861", "An object's '[Symbol.hasInstance]' method must return a boolean value for it to be used on the right-hand side of an 'instanceof' expression."),
+        Type_0_is_generic_and_can_only_be_indexed_for_reading: diag(2862, 1 /* Error */, "Type_0_is_generic_and_can_only_be_indexed_for_reading_2862", "Type '{0}' is generic and can only be indexed for reading."),
+        A_class_cannot_extend_a_primitive_type_like_0_Classes_can_only_extend_constructable_values: diag(2863, 1 /* Error */, "A_class_cannot_extend_a_primitive_type_like_0_Classes_can_only_extend_constructable_values_2863", "A class cannot extend a primitive type like '{0}'. Classes can only extend constructable values."),
+        A_class_cannot_implement_a_primitive_type_like_0_It_can_only_implement_other_named_object_types: diag(2864, 1 /* Error */, "A_class_cannot_implement_a_primitive_type_like_0_It_can_only_implement_other_named_object_types_2864", "A class cannot implement a primitive type like '{0}'. It can only implement other named object types."),
         Import_declaration_0_is_using_private_name_1: diag(4e3, 1 /* Error */, "Import_declaration_0_is_using_private_name_1_4000", "Import declaration '{0}' is using private name '{1}'."),
         Type_parameter_0_of_exported_class_has_or_is_using_private_name_1: diag(4002, 1 /* Error */, "Type_parameter_0_of_exported_class_has_or_is_using_private_name_1_4002", "Type parameter '{0}' of exported class has or is using private name '{1}'."),
         Type_parameter_0_of_exported_interface_has_or_is_using_private_name_1: diag(4004, 1 /* Error */, "Type_parameter_0_of_exported_interface_has_or_is_using_private_name_1_4004", "Type parameter '{0}' of exported interface has or is using private name '{1}'."),
@@ -107420,7 +90065,6 @@ ${lanes.join("\n")}
         This_member_cannot_have_a_JSDoc_comment_with_an_override_tag_because_it_is_not_declared_in_the_base_class_0: diag(4122, 1 /* Error */, "This_member_cannot_have_a_JSDoc_comment_with_an_override_tag_because_it_is_not_declared_in_the_base__4122", "This member cannot have a JSDoc comment with an '@override' tag because it is not declared in the base class '{0}'."),
         This_member_cannot_have_a_JSDoc_comment_with_an_override_tag_because_it_is_not_declared_in_the_base_class_0_Did_you_mean_1: diag(4123, 1 /* Error */, "This_member_cannot_have_a_JSDoc_comment_with_an_override_tag_because_it_is_not_declared_in_the_base__4123", "This member cannot have a JSDoc comment with an 'override' tag because it is not declared in the base class '{0}'. Did you mean '{1}'?"),
         Compiler_option_0_of_value_1_is_unstable_Use_nightly_TypeScript_to_silence_this_error_Try_updating_with_npm_install_D_typescript_next: diag(4124, 1 /* Error */, "Compiler_option_0_of_value_1_is_unstable_Use_nightly_TypeScript_to_silence_this_error_Try_updating_w_4124", "Compiler option '{0}' of value '{1}' is unstable. Use nightly TypeScript to silence this error. Try updating with 'npm install -D typescript@next'."),
-        resolution_mode_assertions_are_unstable_Use_nightly_TypeScript_to_silence_this_error_Try_updating_with_npm_install_D_typescript_next: diag(4125, 1 /* Error */, "resolution_mode_assertions_are_unstable_Use_nightly_TypeScript_to_silence_this_error_Try_updating_wi_4125", "'resolution-mode' assertions are unstable. Use nightly TypeScript to silence this error. Try updating with 'npm install -D typescript@next'."),
         The_current_host_does_not_support_the_0_option: diag(5001, 1 /* Error */, "The_current_host_does_not_support_the_0_option_5001", "The current host does not support the '{0}' option."),
         Cannot_find_the_common_subdirectory_path_for_the_input_files: diag(5009, 1 /* Error */, "Cannot_find_the_common_subdirectory_path_for_the_input_files_5009", "Cannot find the common subdirectory path for the input files."),
         File_specification_cannot_end_in_a_recursive_directory_wildcard_Asterisk_Asterisk_Colon_0: diag(5010, 1 /* Error */, "File_specification_cannot_end_in_a_recursive_directory_wildcard_Asterisk_Asterisk_Colon_0_5010", "File specification cannot end in a recursive directory wildcard ('**'): '{0}'."),
@@ -107465,7 +90109,6 @@ ${lanes.join("\n")}
         Cannot_find_a_tsconfig_json_file_at_the_current_directory_Colon_0: diag(5081, 1 /* Error */, "Cannot_find_a_tsconfig_json_file_at_the_current_directory_Colon_0_5081", "Cannot find a tsconfig.json file at the current directory: {0}."),
         _0_could_be_instantiated_with_an_arbitrary_type_which_could_be_unrelated_to_1: diag(5082, 1 /* Error */, "_0_could_be_instantiated_with_an_arbitrary_type_which_could_be_unrelated_to_1_5082", "'{0}' could be instantiated with an arbitrary type which could be unrelated to '{1}'."),
         Cannot_read_file_0: diag(5083, 1 /* Error */, "Cannot_read_file_0_5083", "Cannot read file '{0}'."),
-        Tuple_members_must_all_have_names_or_all_not_have_names: diag(5084, 1 /* Error */, "Tuple_members_must_all_have_names_or_all_not_have_names_5084", "Tuple members must all have names or all not have names."),
         A_tuple_member_cannot_be_both_optional_and_rest: diag(5085, 1 /* Error */, "A_tuple_member_cannot_be_both_optional_and_rest_5085", "A tuple member cannot be both optional and rest."),
         A_labeled_tuple_element_is_declared_as_optional_with_a_question_mark_after_the_name_and_before_the_colon_rather_than_after_the_type: diag(5086, 1 /* Error */, "A_labeled_tuple_element_is_declared_as_optional_with_a_question_mark_after_the_name_and_before_the_c_5086", "A labeled tuple element is declared as optional with a question mark after the name and before the colon, rather than after the type."),
         A_labeled_tuple_element_is_declared_as_rest_with_a_before_the_name_rather_than_before_the_type: diag(5087, 1 /* Error */, "A_labeled_tuple_element_is_declared_as_rest_with_a_before_the_name_rather_than_before_the_type_5087", "A labeled tuple element is declared as rest with a '...' before the name, rather than before the type."),
@@ -107488,6 +90131,8 @@ ${lanes.join("\n")}
         Use_0_instead: diag(5106, 3 /* Message */, "Use_0_instead_5106", "Use '{0}' instead."),
         Option_0_1_is_deprecated_and_will_stop_functioning_in_TypeScript_2_Specify_compilerOption_ignoreDeprecations_Colon_3_to_silence_this_error: diag(5107, 1 /* Error */, "Option_0_1_is_deprecated_and_will_stop_functioning_in_TypeScript_2_Specify_compilerOption_ignoreDepr_5107", `Option '{0}={1}' is deprecated and will stop functioning in TypeScript {2}. Specify compilerOption '"ignoreDeprecations": "{3}"' to silence this error.`),
         Option_0_1_has_been_removed_Please_remove_it_from_your_configuration: diag(5108, 1 /* Error */, "Option_0_1_has_been_removed_Please_remove_it_from_your_configuration_5108", "Option '{0}={1}' has been removed. Please remove it from your configuration."),
+        Option_moduleResolution_must_be_set_to_0_or_left_unspecified_when_option_module_is_set_to_1: diag(5109, 1 /* Error */, "Option_moduleResolution_must_be_set_to_0_or_left_unspecified_when_option_module_is_set_to_1_5109", "Option 'moduleResolution' must be set to '{0}' (or left unspecified) when option 'module' is set to '{1}'."),
+        Option_module_must_be_set_to_0_when_option_moduleResolution_is_set_to_1: diag(5110, 1 /* Error */, "Option_module_must_be_set_to_0_when_option_moduleResolution_is_set_to_1_5110", "Option 'module' must be set to '{0}' when option 'moduleResolution' is set to '{1}'."),
         Generates_a_sourcemap_for_each_corresponding_d_ts_file: diag(6e3, 3 /* Message */, "Generates_a_sourcemap_for_each_corresponding_d_ts_file_6000", "Generates a sourcemap for each corresponding '.d.ts' file."),
         Concatenate_and_emit_output_to_single_file: diag(6001, 3 /* Message */, "Concatenate_and_emit_output_to_single_file_6001", "Concatenate and emit output to single file."),
         Generates_corresponding_d_ts_file: diag(6002, 3 /* Message */, "Generates_corresponding_d_ts_file_6002", "Generates corresponding '.d.ts' file."),
@@ -107868,6 +90513,8 @@ ${lanes.join("\n")}
         Resolved_under_condition_0: diag(6414, 3 /* Message */, "Resolved_under_condition_0_6414", "Resolved under condition '{0}'."),
         Failed_to_resolve_under_condition_0: diag(6415, 3 /* Message */, "Failed_to_resolve_under_condition_0_6415", "Failed to resolve under condition '{0}'."),
         Exiting_conditional_exports: diag(6416, 3 /* Message */, "Exiting_conditional_exports_6416", "Exiting conditional exports."),
+        Searching_all_ancestor_node_modules_directories_for_preferred_extensions_Colon_0: diag(6417, 3 /* Message */, "Searching_all_ancestor_node_modules_directories_for_preferred_extensions_Colon_0_6417", "Searching all ancestor node_modules directories for preferred extensions: {0}."),
+        Searching_all_ancestor_node_modules_directories_for_fallback_extensions_Colon_0: diag(6418, 3 /* Message */, "Searching_all_ancestor_node_modules_directories_for_fallback_extensions_Colon_0_6418", "Searching all ancestor node_modules directories for fallback extensions: {0}."),
         The_expected_type_comes_from_property_0_which_is_declared_here_on_type_1: diag(6500, 3 /* Message */, "The_expected_type_comes_from_property_0_which_is_declared_here_on_type_1_6500", "The expected type comes from property '{0}' which is declared here on type '{1}'"),
         The_expected_type_comes_from_this_index_signature: diag(6501, 3 /* Message */, "The_expected_type_comes_from_this_index_signature_6501", "The expected type comes from this index signature."),
         The_expected_type_comes_from_the_return_type_of_this_signature: diag(6502, 3 /* Message */, "The_expected_type_comes_from_the_return_type_of_this_signature_6502", "The expected type comes from the return type of this signature."),
@@ -108106,6 +90753,7 @@ ${lanes.join("\n")}
         Parameter_modifiers_can_only_be_used_in_TypeScript_files: diag(8012, 1 /* Error */, "Parameter_modifiers_can_only_be_used_in_TypeScript_files_8012", "Parameter modifiers can only be used in TypeScript files."),
         Non_null_assertions_can_only_be_used_in_TypeScript_files: diag(8013, 1 /* Error */, "Non_null_assertions_can_only_be_used_in_TypeScript_files_8013", "Non-null assertions can only be used in TypeScript files."),
         Type_assertion_expressions_can_only_be_used_in_TypeScript_files: diag(8016, 1 /* Error */, "Type_assertion_expressions_can_only_be_used_in_TypeScript_files_8016", "Type assertion expressions can only be used in TypeScript files."),
+        Signature_declarations_can_only_be_used_in_TypeScript_files: diag(8017, 1 /* Error */, "Signature_declarations_can_only_be_used_in_TypeScript_files_8017", "Signature declarations can only be used in TypeScript files."),
         Report_errors_in_js_files: diag(8019, 3 /* Message */, "Report_errors_in_js_files_8019", "Report errors in .js files."),
         JSDoc_types_can_only_be_used_inside_documentation_comments: diag(8020, 1 /* Error */, "JSDoc_types_can_only_be_used_inside_documentation_comments_8020", "JSDoc types can only be used inside documentation comments."),
         JSDoc_typedef_tag_should_either_have_a_type_annotation_or_be_followed_by_property_or_member_tags: diag(8021, 1 /* Error */, "JSDoc_typedef_tag_should_either_have_a_type_annotation_or_be_followed_by_property_or_member_tags_8021", "JSDoc '@typedef' tag should either have a type annotation or be followed by '@property' or '@member' tags."),
@@ -108149,6 +90797,7 @@ ${lanes.join("\n")}
         Unknown_type_acquisition_option_0_Did_you_mean_1: diag(17018, 1 /* Error */, "Unknown_type_acquisition_option_0_Did_you_mean_1_17018", "Unknown type acquisition option '{0}'. Did you mean '{1}'?"),
         _0_at_the_end_of_a_type_is_not_valid_TypeScript_syntax_Did_you_mean_to_write_1: diag(17019, 1 /* Error */, "_0_at_the_end_of_a_type_is_not_valid_TypeScript_syntax_Did_you_mean_to_write_1_17019", "'{0}' at the end of a type is not valid TypeScript syntax. Did you mean to write '{1}'?"),
         _0_at_the_start_of_a_type_is_not_valid_TypeScript_syntax_Did_you_mean_to_write_1: diag(17020, 1 /* Error */, "_0_at_the_start_of_a_type_is_not_valid_TypeScript_syntax_Did_you_mean_to_write_1_17020", "'{0}' at the start of a type is not valid TypeScript syntax. Did you mean to write '{1}'?"),
+        Unicode_escape_sequence_cannot_appear_here: diag(17021, 1 /* Error */, "Unicode_escape_sequence_cannot_appear_here_17021", "Unicode escape sequence cannot appear here."),
         Circularity_detected_while_resolving_configuration_Colon_0: diag(18e3, 1 /* Error */, "Circularity_detected_while_resolving_configuration_Colon_0_18000", "Circularity detected while resolving configuration: {0}"),
         The_files_list_in_config_file_0_is_empty: diag(18002, 1 /* Error */, "The_files_list_in_config_file_0_is_empty_18002", "The 'files' list in config file '{0}' is empty."),
         No_inputs_were_found_in_config_file_0_Specified_include_paths_were_1_and_exclude_paths_were_2: diag(18003, 1 /* Error */, "No_inputs_were_found_in_config_file_0_Specified_include_paths_were_1_and_exclude_paths_were_2_18003", "No inputs were found in config file '{0}'. Specified 'include' paths were '{1}' and 'exclude' paths were '{2}'."),
@@ -108354,7 +91003,7 @@ ${lanes.join("\n")}
         Could_not_convert_to_arrow_function: diag(95151, 3 /* Message */, "Could_not_convert_to_arrow_function_95151", "Could not convert to arrow function"),
         Could_not_convert_to_named_function: diag(95152, 3 /* Message */, "Could_not_convert_to_named_function_95152", "Could not convert to named function"),
         Could_not_convert_to_anonymous_function: diag(95153, 3 /* Message */, "Could_not_convert_to_anonymous_function_95153", "Could not convert to anonymous function"),
-        Can_only_convert_string_concatenation: diag(95154, 3 /* Message */, "Can_only_convert_string_concatenation_95154", "Can only convert string concatenation"),
+        Can_only_convert_string_concatenations_and_string_literals: diag(95154, 3 /* Message */, "Can_only_convert_string_concatenations_and_string_literals_95154", "Can only convert string concatenations and string literals"),
         Selection_is_not_a_valid_statement_or_statements: diag(95155, 3 /* Message */, "Selection_is_not_a_valid_statement_or_statements_95155", "Selection is not a valid statement or statements"),
         Add_missing_function_declaration_0: diag(95156, 3 /* Message */, "Add_missing_function_declaration_0_95156", "Add missing function declaration '{0}'"),
         Add_all_missing_function_declarations: diag(95157, 3 /* Message */, "Add_all_missing_function_declarations_95157", "Add all missing function declarations"),
@@ -108380,6 +91029,14 @@ ${lanes.join("\n")}
         Convert_all_typedef_to_TypeScript_types: diag(95177, 3 /* Message */, "Convert_all_typedef_to_TypeScript_types_95177", "Convert all typedef to TypeScript types."),
         Move_to_file: diag(95178, 3 /* Message */, "Move_to_file_95178", "Move to file"),
         Cannot_move_to_file_selected_file_is_invalid: diag(95179, 3 /* Message */, "Cannot_move_to_file_selected_file_is_invalid_95179", "Cannot move to file, selected file is invalid"),
+        Use_import_type: diag(95180, 3 /* Message */, "Use_import_type_95180", "Use 'import type'"),
+        Use_type_0: diag(95181, 3 /* Message */, "Use_type_0_95181", "Use 'type {0}'"),
+        Fix_all_with_type_only_imports: diag(95182, 3 /* Message */, "Fix_all_with_type_only_imports_95182", "Fix all with type-only imports"),
+        Cannot_move_statements_to_the_selected_file: diag(95183, 3 /* Message */, "Cannot_move_statements_to_the_selected_file_95183", "Cannot move statements to the selected file"),
+        Inline_variable: diag(95184, 3 /* Message */, "Inline_variable_95184", "Inline variable"),
+        Could_not_find_variable_to_inline: diag(95185, 3 /* Message */, "Could_not_find_variable_to_inline_95185", "Could not find variable to inline."),
+        Variables_with_multiple_declarations_cannot_be_inlined: diag(95186, 3 /* Message */, "Variables_with_multiple_declarations_cannot_be_inlined_95186", "Variables with multiple declarations cannot be inlined."),
+        Add_missing_comma_for_object_member_completion_0: diag(95187, 3 /* Message */, "Add_missing_comma_for_object_member_completion_0_95187", "Add missing comma for object member completion '{0}'."),
         No_value_exists_in_scope_for_the_shorthand_property_0_Either_declare_one_or_provide_an_initializer: diag(18004, 1 /* Error */, "No_value_exists_in_scope_for_the_shorthand_property_0_Either_declare_one_or_provide_an_initializer_18004", "No value exists in scope for the shorthand property '{0}'. Either declare one or provide an initializer."),
         Classes_may_not_have_a_field_named_constructor: diag(18006, 1 /* Error */, "Classes_may_not_have_a_field_named_constructor_18006", "Classes may not have a field named 'constructor'."),
         JSX_expressions_may_not_use_the_comma_operator_Did_you_mean_to_write_an_array: diag(18007, 1 /* Error */, "JSX_expressions_may_not_use_the_comma_operator_Did_you_mean_to_write_an_array_18007", "JSX expressions may not use the comma operator. Did you mean to write an array?"),
@@ -108406,8 +91063,8 @@ ${lanes.join("\n")}
         Specify_the_JSX_fragment_factory_function_to_use_when_targeting_react_JSX_emit_with_jsxFactory_compiler_option_is_specified_e_g_Fragment: diag(18034, 3 /* Message */, "Specify_the_JSX_fragment_factory_function_to_use_when_targeting_react_JSX_emit_with_jsxFactory_compi_18034", "Specify the JSX fragment factory function to use when targeting 'react' JSX emit with 'jsxFactory' compiler option is specified, e.g. 'Fragment'."),
         Invalid_value_for_jsxFragmentFactory_0_is_not_a_valid_identifier_or_qualified_name: diag(18035, 1 /* Error */, "Invalid_value_for_jsxFragmentFactory_0_is_not_a_valid_identifier_or_qualified_name_18035", "Invalid value for 'jsxFragmentFactory'. '{0}' is not a valid identifier or qualified-name."),
         Class_decorators_can_t_be_used_with_static_private_identifier_Consider_removing_the_experimental_decorator: diag(18036, 1 /* Error */, "Class_decorators_can_t_be_used_with_static_private_identifier_Consider_removing_the_experimental_dec_18036", "Class decorators can't be used with static private identifier. Consider removing the experimental decorator."),
-        Await_expression_cannot_be_used_inside_a_class_static_block: diag(18037, 1 /* Error */, "Await_expression_cannot_be_used_inside_a_class_static_block_18037", "Await expression cannot be used inside a class static block."),
-        For_await_loops_cannot_be_used_inside_a_class_static_block: diag(18038, 1 /* Error */, "For_await_loops_cannot_be_used_inside_a_class_static_block_18038", "'For await' loops cannot be used inside a class static block."),
+        await_expression_cannot_be_used_inside_a_class_static_block: diag(18037, 1 /* Error */, "await_expression_cannot_be_used_inside_a_class_static_block_18037", "'await' expression cannot be used inside a class static block."),
+        for_await_loops_cannot_be_used_inside_a_class_static_block: diag(18038, 1 /* Error */, "for_await_loops_cannot_be_used_inside_a_class_static_block_18038", "'for await' loops cannot be used inside a class static block."),
         Invalid_use_of_0_It_cannot_be_used_inside_a_class_static_block: diag(18039, 1 /* Error */, "Invalid_use_of_0_It_cannot_be_used_inside_a_class_static_block_18039", "Invalid use of '{0}'. It cannot be used inside a class static block."),
         A_return_statement_cannot_be_used_inside_a_class_static_block: diag(18041, 1 /* Error */, "A_return_statement_cannot_be_used_inside_a_class_static_block_18041", "A 'return' statement cannot be used inside a class static block."),
         _0_is_a_type_and_cannot_be_imported_in_JavaScript_files_Use_1_in_a_JSDoc_type_annotation: diag(18042, 1 /* Error */, "_0_is_a_type_and_cannot_be_imported_in_JavaScript_files_Use_1_in_a_JSDoc_type_annotation_18042", "'{0}' is a type and cannot be imported in JavaScript files. Use '{1}' in a JSDoc type annotation."),
@@ -108421,7 +91078,8 @@ ${lanes.join("\n")}
         The_value_0_cannot_be_used_here: diag(18050, 1 /* Error */, "The_value_0_cannot_be_used_here_18050", "The value '{0}' cannot be used here."),
         Compiler_option_0_cannot_be_given_an_empty_string: diag(18051, 1 /* Error */, "Compiler_option_0_cannot_be_given_an_empty_string_18051", "Compiler option '{0}' cannot be given an empty string."),
         Non_abstract_class_0_does_not_implement_all_abstract_members_of_1: diag(18052, 1 /* Error */, "Non_abstract_class_0_does_not_implement_all_abstract_members_of_1_18052", "Non-abstract class '{0}' does not implement all abstract members of '{1}'"),
-        Its_type_0_is_not_a_valid_JSX_element_type: diag(18053, 1 /* Error */, "Its_type_0_is_not_a_valid_JSX_element_type_18053", "Its type '{0}' is not a valid JSX element type.")
+        Its_type_0_is_not_a_valid_JSX_element_type: diag(18053, 1 /* Error */, "Its_type_0_is_not_a_valid_JSX_element_type_18053", "Its type '{0}' is not a valid JSX element type."),
+        await_using_statements_cannot_be_used_inside_a_class_static_block: diag(18054, 1 /* Error */, "await_using_statements_cannot_be_used_inside_a_class_static_block_18054", "'await using' statements cannot be used inside a class static block.")
       };
     }
   });
@@ -108698,9 +91356,9 @@ ${lanes.join("\n")}
     }
     return false;
   }
-  function scanConflictMarkerTrivia(text, pos, error) {
-    if (error) {
-      error(Diagnostics.Merge_conflict_marker_encountered, pos, mergeConflictMarkerLength);
+  function scanConflictMarkerTrivia(text, pos, error2) {
+    if (error2) {
+      error2(Diagnostics.Merge_conflict_marker_encountered, pos, mergeConflictMarkerLength);
     }
     const ch = text.charCodeAt(pos);
     const len = text.length;
@@ -108936,6 +91594,8 @@ ${lanes.join("\n")}
     var tokenFlags;
     var commentDirectives;
     var inJSDocType = 0;
+    var scriptKind = 0 /* Unknown */;
+    var jsDocParsingMode = 0 /* ParseAll */;
     setText(text, start, length2);
     var scanner2 = {
       getTokenFullStart: () => fullStartPos,
@@ -108979,6 +91639,8 @@ ${lanes.join("\n")}
       setText,
       setScriptTarget,
       setLanguageVariant,
+      setScriptKind,
+      setJSDocParsingMode,
       setOnError,
       resetTokenState,
       setTextPos: resetTokenState,
@@ -108996,7 +91658,7 @@ ${lanes.join("\n")}
       });
     }
     return scanner2;
-    function error(message, errPos = pos, length3, arg0) {
+    function error2(message, errPos = pos, length3, arg0) {
       if (onError) {
         const oldPos = pos;
         pos = errPos;
@@ -109020,9 +91682,9 @@ ${lanes.join("\n")}
           } else {
             tokenFlags |= 16384 /* ContainsInvalidSeparator */;
             if (isPreviousTokenSeparator) {
-              error(Diagnostics.Multiple_consecutive_numeric_separators_are_not_permitted, pos, 1);
+              error2(Diagnostics.Multiple_consecutive_numeric_separators_are_not_permitted, pos, 1);
             } else {
-              error(Diagnostics.Numeric_separators_are_not_allowed_here, pos, 1);
+              error2(Diagnostics.Numeric_separators_are_not_allowed_here, pos, 1);
             }
           }
           pos++;
@@ -109039,7 +91701,7 @@ ${lanes.join("\n")}
       }
       if (text.charCodeAt(pos - 1) === 95 /* _ */) {
         tokenFlags |= 16384 /* ContainsInvalidSeparator */;
-        error(Diagnostics.Numeric_separators_are_not_allowed_here, pos - 1, 1);
+        error2(Diagnostics.Numeric_separators_are_not_allowed_here, pos - 1, 1);
       }
       return result + text.substring(start2, pos);
     }
@@ -109050,7 +91712,7 @@ ${lanes.join("\n")}
         pos++;
         if (text.charCodeAt(pos) === 95 /* _ */) {
           tokenFlags |= 512 /* ContainsSeparator */ | 16384 /* ContainsInvalidSeparator */;
-          error(Diagnostics.Numeric_separators_are_not_allowed_here, pos, 1);
+          error2(Diagnostics.Numeric_separators_are_not_allowed_here, pos, 1);
           pos--;
           mainFragment = scanNumberFragment();
         } else if (!scanDigits()) {
@@ -109065,8 +91727,8 @@ ${lanes.join("\n")}
           const literal = (withMinus ? "-" : "") + "0o" + (+tokenValue).toString(8);
           if (withMinus)
             start2--;
-          error(Diagnostics.Octal_literals_are_not_allowed_Use_the_syntax_0, start2, pos - start2, literal);
-          return { type: 9 /* NumericLiteral */, value: tokenValue };
+          error2(Diagnostics.Octal_literals_are_not_allowed_Use_the_syntax_0, start2, pos - start2, literal);
+          return 9 /* NumericLiteral */;
         }
       } else {
         mainFragment = scanNumberFragment();
@@ -109086,7 +91748,7 @@ ${lanes.join("\n")}
         const preNumericPart = pos;
         const finalFragment = scanNumberFragment();
         if (!finalFragment) {
-          error(Diagnostics.Digit_expected);
+          error2(Diagnostics.Digit_expected);
         } else {
           scientificFragment = text.substring(end2, preNumericPart) + finalFragment;
           end2 = pos;
@@ -109105,21 +91767,19 @@ ${lanes.join("\n")}
         result = text.substring(start2, end2);
       }
       if (tokenFlags & 8192 /* ContainsLeadingZero */) {
-        error(Diagnostics.Decimals_with_leading_zeros_are_not_allowed, start2, end2 - start2);
-        return { type: 9 /* NumericLiteral */, value: "" + +result };
+        error2(Diagnostics.Decimals_with_leading_zeros_are_not_allowed, start2, end2 - start2);
+        tokenValue = "" + +result;
+        return 9 /* NumericLiteral */;
       }
       if (decimalFragment !== void 0 || tokenFlags & 16 /* Scientific */) {
         checkForIdentifierStartAfterNumericLiteral(start2, decimalFragment === void 0 && !!(tokenFlags & 16 /* Scientific */));
-        return {
-          type: 9 /* NumericLiteral */,
-          value: "" + +result
-          // if value is not an integer, it can be safely coerced to a number
-        };
+        tokenValue = "" + +result;
+        return 9 /* NumericLiteral */;
       } else {
         tokenValue = result;
         const type = checkBigIntSuffix();
         checkForIdentifierStartAfterNumericLiteral(start2);
-        return { type, value: tokenValue };
+        return type;
       }
     }
     function checkForIdentifierStartAfterNumericLiteral(numericStart, isScientific) {
@@ -109130,12 +91790,12 @@ ${lanes.join("\n")}
       const { length: length3 } = scanIdentifierParts();
       if (length3 === 1 && text[identifierStart] === "n") {
         if (isScientific) {
-          error(Diagnostics.A_bigint_literal_cannot_use_exponential_notation, numericStart, identifierStart - numericStart + 1);
+          error2(Diagnostics.A_bigint_literal_cannot_use_exponential_notation, numericStart, identifierStart - numericStart + 1);
         } else {
-          error(Diagnostics.A_bigint_literal_must_be_an_integer, numericStart, identifierStart - numericStart + 1);
+          error2(Diagnostics.A_bigint_literal_must_be_an_integer, numericStart, identifierStart - numericStart + 1);
         }
       } else {
-        error(Diagnostics.An_identifier_or_keyword_cannot_immediately_follow_a_numeric_literal, identifierStart, length3);
+        error2(Diagnostics.An_identifier_or_keyword_cannot_immediately_follow_a_numeric_literal, identifierStart, length3);
         pos = identifierStart;
       }
     }
@@ -109182,9 +91842,9 @@ ${lanes.join("\n")}
             allowSeparator = false;
             isPreviousTokenSeparator = true;
           } else if (isPreviousTokenSeparator) {
-            error(Diagnostics.Multiple_consecutive_numeric_separators_are_not_permitted, pos, 1);
+            error2(Diagnostics.Multiple_consecutive_numeric_separators_are_not_permitted, pos, 1);
           } else {
-            error(Diagnostics.Numeric_separators_are_not_allowed_here, pos, 1);
+            error2(Diagnostics.Numeric_separators_are_not_allowed_here, pos, 1);
           }
           pos++;
           continue;
@@ -109203,7 +91863,7 @@ ${lanes.join("\n")}
         valueChars = [];
       }
       if (text.charCodeAt(pos - 1) === 95 /* _ */) {
-        error(Diagnostics.Numeric_separators_are_not_allowed_here, pos - 1, 1);
+        error2(Diagnostics.Numeric_separators_are_not_allowed_here, pos - 1, 1);
       }
       return String.fromCharCode(...valueChars);
     }
@@ -109216,7 +91876,7 @@ ${lanes.join("\n")}
         if (pos >= end) {
           result += text.substring(start2, pos);
           tokenFlags |= 4 /* Unterminated */;
-          error(Diagnostics.Unterminated_string_literal);
+          error2(Diagnostics.Unterminated_string_literal);
           break;
         }
         const ch = text.charCodeAt(pos);
@@ -109234,10 +91894,10 @@ ${lanes.join("\n")}
           start2 = pos;
           continue;
         }
-        if (isLineBreak(ch) && !jsxAttributeString) {
+        if ((ch === 10 /* lineFeed */ || ch === 13 /* carriageReturn */) && !jsxAttributeString) {
           result += text.substring(start2, pos);
           tokenFlags |= 4 /* Unterminated */;
-          error(Diagnostics.Unterminated_string_literal);
+          error2(Diagnostics.Unterminated_string_literal);
           break;
         }
         pos++;
@@ -109254,7 +91914,7 @@ ${lanes.join("\n")}
         if (pos >= end) {
           contents += text.substring(start2, pos);
           tokenFlags |= 4 /* Unterminated */;
-          error(Diagnostics.Unterminated_template_literal);
+          error2(Diagnostics.Unterminated_template_literal);
           resultingToken = startedWithBacktick ? 15 /* NoSubstitutionTemplateLiteral */ : 18 /* TemplateTail */;
           break;
         }
@@ -109297,7 +91957,7 @@ ${lanes.join("\n")}
       const start2 = pos;
       pos++;
       if (pos >= end) {
-        error(Diagnostics.Unexpected_end_of_text);
+        error2(Diagnostics.Unexpected_end_of_text);
         return "";
       }
       const ch = text.charCodeAt(pos);
@@ -109323,7 +91983,7 @@ ${lanes.join("\n")}
           tokenFlags |= 2048 /* ContainsInvalidEscape */;
           if (shouldEmitInvalidEscapeError) {
             const code = parseInt(text.substring(start2 + 1, pos), 8);
-            error(Diagnostics.Octal_escape_sequences_are_not_allowed_Use_the_syntax_0, start2, pos - start2, "\\x" + padLeft(code.toString(16), 2, "0"));
+            error2(Diagnostics.Octal_escape_sequences_are_not_allowed_Use_the_syntax_0, start2, pos - start2, "\\x" + code.toString(16).padStart(2, "0"));
             return String.fromCharCode(code);
           }
           return text.substring(start2, pos);
@@ -109331,7 +91991,7 @@ ${lanes.join("\n")}
         case 57 /* _9 */:
           tokenFlags |= 2048 /* ContainsInvalidEscape */;
           if (shouldEmitInvalidEscapeError) {
-            error(Diagnostics.Escape_sequence_0_is_not_allowed, start2, pos - start2, text.substring(start2, pos));
+            error2(Diagnostics.Escape_sequence_0_is_not_allowed, start2, pos - start2, text.substring(start2, pos));
             return String.fromCharCode(ch);
           }
           return text.substring(start2, pos);
@@ -109363,28 +92023,28 @@ ${lanes.join("\n")}
             if (escapedValue < 0) {
               tokenFlags |= 2048 /* ContainsInvalidEscape */;
               if (shouldEmitInvalidEscapeError) {
-                error(Diagnostics.Hexadecimal_digit_expected);
+                error2(Diagnostics.Hexadecimal_digit_expected);
               }
               return text.substring(start2, pos);
             }
             if (!isCodePoint(escapedValue)) {
               tokenFlags |= 2048 /* ContainsInvalidEscape */;
               if (shouldEmitInvalidEscapeError) {
-                error(Diagnostics.An_extended_Unicode_escape_value_must_be_between_0x0_and_0x10FFFF_inclusive);
+                error2(Diagnostics.An_extended_Unicode_escape_value_must_be_between_0x0_and_0x10FFFF_inclusive);
               }
               return text.substring(start2, pos);
             }
             if (pos >= end) {
               tokenFlags |= 2048 /* ContainsInvalidEscape */;
               if (shouldEmitInvalidEscapeError) {
-                error(Diagnostics.Unexpected_end_of_text);
+                error2(Diagnostics.Unexpected_end_of_text);
               }
               return text.substring(start2, pos);
             }
             if (text.charCodeAt(pos) !== 125 /* closeBrace */) {
               tokenFlags |= 2048 /* ContainsInvalidEscape */;
               if (shouldEmitInvalidEscapeError) {
-                error(Diagnostics.Unterminated_Unicode_escape_sequence);
+                error2(Diagnostics.Unterminated_Unicode_escape_sequence);
               }
               return text.substring(start2, pos);
             }
@@ -109396,7 +92056,7 @@ ${lanes.join("\n")}
             if (!(pos < end && isHexDigit(text.charCodeAt(pos)))) {
               tokenFlags |= 2048 /* ContainsInvalidEscape */;
               if (shouldEmitInvalidEscapeError) {
-                error(Diagnostics.Hexadecimal_digit_expected);
+                error2(Diagnostics.Hexadecimal_digit_expected);
               }
               return text.substring(start2, pos);
             }
@@ -109408,7 +92068,7 @@ ${lanes.join("\n")}
             if (!(pos < end && isHexDigit(text.charCodeAt(pos)))) {
               tokenFlags |= 2048 /* ContainsInvalidEscape */;
               if (shouldEmitInvalidEscapeError) {
-                error(Diagnostics.Hexadecimal_digit_expected);
+                error2(Diagnostics.Hexadecimal_digit_expected);
               }
               return text.substring(start2, pos);
             }
@@ -109436,19 +92096,19 @@ ${lanes.join("\n")}
       const escapedValue = escapedValueString ? parseInt(escapedValueString, 16) : -1;
       let isInvalidExtendedEscape = false;
       if (escapedValue < 0) {
-        error(Diagnostics.Hexadecimal_digit_expected);
+        error2(Diagnostics.Hexadecimal_digit_expected);
         isInvalidExtendedEscape = true;
       } else if (escapedValue > 1114111) {
-        error(Diagnostics.An_extended_Unicode_escape_value_must_be_between_0x0_and_0x10FFFF_inclusive);
+        error2(Diagnostics.An_extended_Unicode_escape_value_must_be_between_0x0_and_0x10FFFF_inclusive);
         isInvalidExtendedEscape = true;
       }
       if (pos >= end) {
-        error(Diagnostics.Unexpected_end_of_text);
+        error2(Diagnostics.Unexpected_end_of_text);
         isInvalidExtendedEscape = true;
       } else if (text.charCodeAt(pos) === 125 /* closeBrace */) {
         pos++;
       } else {
-        error(Diagnostics.Unterminated_Unicode_escape_sequence);
+        error2(Diagnostics.Unterminated_Unicode_escape_sequence);
         isInvalidExtendedEscape = true;
       }
       if (isInvalidExtendedEscape) {
@@ -109542,9 +92202,9 @@ ${lanes.join("\n")}
             separatorAllowed = false;
             isPreviousTokenSeparator = true;
           } else if (isPreviousTokenSeparator) {
-            error(Diagnostics.Multiple_consecutive_numeric_separators_are_not_permitted, pos, 1);
+            error2(Diagnostics.Multiple_consecutive_numeric_separators_are_not_permitted, pos, 1);
           } else {
-            error(Diagnostics.Numeric_separators_are_not_allowed_here, pos, 1);
+            error2(Diagnostics.Numeric_separators_are_not_allowed_here, pos, 1);
           }
           pos++;
           continue;
@@ -109558,7 +92218,7 @@ ${lanes.join("\n")}
         isPreviousTokenSeparator = false;
       }
       if (text.charCodeAt(pos - 1) === 95 /* _ */) {
-        error(Diagnostics.Numeric_separators_are_not_allowed_here, pos - 1, 1);
+        error2(Diagnostics.Numeric_separators_are_not_allowed_here, pos - 1, 1);
       }
       return value;
     }
@@ -109588,7 +92248,7 @@ ${lanes.join("\n")}
         const ch = codePointAt(text, pos);
         if (pos === 0) {
           if (ch === 65533 /* replacementCharacter */) {
-            error(Diagnostics.File_appears_to_be_binary);
+            error2(Diagnostics.File_appears_to_be_binary);
             pos = end;
             return token = 8 /* NonTextFileMarkerTrivia */;
           }
@@ -109728,7 +92388,7 @@ ${lanes.join("\n")}
             return token = 41 /* MinusToken */;
           case 46 /* dot */:
             if (isDigit(text.charCodeAt(pos + 1))) {
-              tokenValue = scanNumber().value;
+              scanNumber();
               return token = 9 /* NumericLiteral */;
             }
             if (text.charCodeAt(pos + 1) === 46 /* dot */ && text.charCodeAt(pos + 2) === 46 /* dot */) {
@@ -109759,9 +92419,7 @@ ${lanes.join("\n")}
             }
             if (text.charCodeAt(pos + 1) === 42 /* asterisk */) {
               pos += 2;
-              if (text.charCodeAt(pos) === 42 /* asterisk */ && text.charCodeAt(pos + 1) !== 47 /* slash */) {
-                tokenFlags |= 2 /* PrecedingJSDocComment */;
-              }
+              const isJSDoc2 = text.charCodeAt(pos) === 42 /* asterisk */ && text.charCodeAt(pos + 1) !== 47 /* slash */;
               let commentClosed = false;
               let lastLineStart = tokenStart;
               while (pos < end) {
@@ -109777,9 +92435,12 @@ ${lanes.join("\n")}
                   tokenFlags |= 1 /* PrecedingLineBreak */;
                 }
               }
+              if (isJSDoc2 && shouldParseJSDoc()) {
+                tokenFlags |= 2 /* PrecedingJSDocComment */;
+              }
               commentDirectives = appendIfCommentDirective(commentDirectives, text.slice(lastLineStart, pos), commentDirectiveRegExMultiLine, lastLineStart);
               if (!commentClosed) {
-                error(Diagnostics.Asterisk_Slash_expected);
+                error2(Diagnostics.Asterisk_Slash_expected);
               }
               if (skipTrivia2) {
                 continue;
@@ -109804,7 +92465,7 @@ ${lanes.join("\n")}
                 true
               );
               if (!tokenValue) {
-                error(Diagnostics.Hexadecimal_digit_expected);
+                error2(Diagnostics.Hexadecimal_digit_expected);
                 tokenValue = "0";
               }
               tokenValue = "0x" + tokenValue;
@@ -109817,7 +92478,7 @@ ${lanes.join("\n")}
                 2
               );
               if (!tokenValue) {
-                error(Diagnostics.Binary_digit_expected);
+                error2(Diagnostics.Binary_digit_expected);
                 tokenValue = "0";
               }
               tokenValue = "0b" + tokenValue;
@@ -109830,7 +92491,7 @@ ${lanes.join("\n")}
                 8
               );
               if (!tokenValue) {
-                error(Diagnostics.Octal_digit_expected);
+                error2(Diagnostics.Octal_digit_expected);
                 tokenValue = "0";
               }
               tokenValue = "0o" + tokenValue;
@@ -109846,8 +92507,7 @@ ${lanes.join("\n")}
           case 55 /* _7 */:
           case 56 /* _8 */:
           case 57 /* _9 */:
-            ({ type: token, value: tokenValue } = scanNumber());
-            return token;
+            return token = scanNumber();
           case 58 /* colon */:
             pos++;
             return token = 59 /* ColonToken */;
@@ -109856,7 +92516,7 @@ ${lanes.join("\n")}
             return token = 27 /* SemicolonToken */;
           case 60 /* lessThan */:
             if (isConflictMarkerTrivia(text, pos)) {
-              pos = scanConflictMarkerTrivia(text, pos, error);
+              pos = scanConflictMarkerTrivia(text, pos, error2);
               if (skipTrivia2) {
                 continue;
               } else {
@@ -109879,7 +92539,7 @@ ${lanes.join("\n")}
             return token = 30 /* LessThanToken */;
           case 61 /* equals */:
             if (isConflictMarkerTrivia(text, pos)) {
-              pos = scanConflictMarkerTrivia(text, pos, error);
+              pos = scanConflictMarkerTrivia(text, pos, error2);
               if (skipTrivia2) {
                 continue;
               } else {
@@ -109899,7 +92559,7 @@ ${lanes.join("\n")}
             return token = 64 /* EqualsToken */;
           case 62 /* greaterThan */:
             if (isConflictMarkerTrivia(text, pos)) {
-              pos = scanConflictMarkerTrivia(text, pos, error);
+              pos = scanConflictMarkerTrivia(text, pos, error2);
               if (skipTrivia2) {
                 continue;
               } else {
@@ -109937,7 +92597,7 @@ ${lanes.join("\n")}
             return token = 19 /* OpenBraceToken */;
           case 124 /* bar */:
             if (isConflictMarkerTrivia(text, pos)) {
-              pos = scanConflictMarkerTrivia(text, pos, error);
+              pos = scanConflictMarkerTrivia(text, pos, error2);
               if (skipTrivia2) {
                 continue;
               } else {
@@ -109979,12 +92639,12 @@ ${lanes.join("\n")}
               tokenValue = String.fromCharCode(cookedChar) + scanIdentifierParts();
               return token = getIdentifierToken();
             }
-            error(Diagnostics.Invalid_character);
+            error2(Diagnostics.Invalid_character);
             pos++;
             return token = 0 /* Unknown */;
           case 35 /* hash */:
             if (pos !== 0 && text[pos + 1] === "!") {
-              error(Diagnostics.can_only_be_used_at_the_start_of_a_file);
+              error2(Diagnostics.can_only_be_used_at_the_start_of_a_file);
               pos++;
               return token = 0 /* Unknown */;
             }
@@ -110012,7 +92672,7 @@ ${lanes.join("\n")}
               scanIdentifier(charAfterHash, languageVersion);
             } else {
               tokenValue = "#";
-              error(Diagnostics.Invalid_character, pos++, charSize(ch));
+              error2(Diagnostics.Invalid_character, pos++, charSize(ch));
             }
             return token = 81 /* PrivateIdentifier */;
           default:
@@ -110028,12 +92688,27 @@ ${lanes.join("\n")}
               continue;
             }
             const size = charSize(ch);
-            error(Diagnostics.Invalid_character, pos, size);
+            error2(Diagnostics.Invalid_character, pos, size);
             pos += size;
             return token = 0 /* Unknown */;
         }
       }
     }
+    function shouldParseJSDoc() {
+      switch (jsDocParsingMode) {
+        case 0 /* ParseAll */:
+          return true;
+        case 1 /* ParseNone */:
+          return false;
+      }
+      if (scriptKind !== 3 /* TS */ && scriptKind !== 4 /* TSX */) {
+        return true;
+      }
+      if (jsDocParsingMode === 3 /* ParseForTypeInfo */) {
+        return false;
+      }
+      return jsDocSeeOrLink.test(text.slice(fullStartPos, pos));
+    }
     function reScanInvalidIdentifier() {
       Debug.assert(token === 0 /* Unknown */, "'reScanInvalidIdentifier' should only be called when the current token is 'SyntaxKind.Unknown'.");
       pos = tokenStart = fullStartPos;
@@ -110094,13 +92769,13 @@ ${lanes.join("\n")}
         while (true) {
           if (p >= end) {
             tokenFlags |= 4 /* Unterminated */;
-            error(Diagnostics.Unterminated_regular_expression_literal);
+            error2(Diagnostics.Unterminated_regular_expression_literal);
             break;
           }
           const ch = text.charCodeAt(p);
           if (isLineBreak(ch)) {
             tokenFlags |= 4 /* Unterminated */;
-            error(Diagnostics.Unterminated_regular_expression_literal);
+            error2(Diagnostics.Unterminated_regular_expression_literal);
             break;
           }
           if (inEscape) {
@@ -110127,7 +92802,7 @@ ${lanes.join("\n")}
       return token;
     }
     function appendIfCommentDirective(commentDirectives2, text2, commentDirectiveRegEx, lineStart) {
-      const type = getDirectiveFromComment(trimStringStart(text2), commentDirectiveRegEx);
+      const type = getDirectiveFromComment(text2.trimStart(), commentDirectiveRegEx);
       if (type === void 0) {
         return commentDirectives2;
       }
@@ -110212,16 +92887,16 @@ ${lanes.join("\n")}
         }
         if (char === 60 /* lessThan */) {
           if (isConflictMarkerTrivia(text, pos)) {
-            pos = scanConflictMarkerTrivia(text, pos, error);
+            pos = scanConflictMarkerTrivia(text, pos, error2);
             return token = 7 /* ConflictMarkerTrivia */;
           }
           break;
         }
         if (char === 62 /* greaterThan */) {
-          error(Diagnostics.Unexpected_token_Did_you_mean_or_gt, pos, 1);
+          error2(Diagnostics.Unexpected_token_Did_you_mean_or_gt, pos, 1);
         }
         if (char === 125 /* closeBrace */) {
-          error(Diagnostics.Unexpected_token_Did_you_mean_or_rbrace, pos, 1);
+          error2(Diagnostics.Unexpected_token_Did_you_mean_or_rbrace, pos, 1);
         }
         if (isLineBreak(char) && firstNonWhitespace === 0) {
           firstNonWhitespace = -1;
@@ -110448,6 +93123,12 @@ ${lanes.join("\n")}
     function setLanguageVariant(variant) {
       languageVariant = variant;
     }
+    function setScriptKind(kind) {
+      scriptKind = kind;
+    }
+    function setJSDocParsingMode(kind) {
+      jsDocParsingMode = kind;
+    }
     function resetTokenState(position) {
       Debug.assert(position >= 0);
       pos = position;
@@ -110461,6 +93142,9 @@ ${lanes.join("\n")}
       inJSDocType += inType ? 1 : -1;
     }
   }
+  function codePointAt(s, i) {
+    return s.codePointAt(i);
+  }
   function charSize(ch) {
     if (ch >= 65536) {
       return 2;
@@ -110479,7 +93163,7 @@ ${lanes.join("\n")}
   function utf16EncodeAsString(codePoint) {
     return utf16EncodeAsStringWorker(codePoint);
   }
-  var textToKeywordObj, textToKeyword, textToToken, unicodeES3IdentifierStart, unicodeES3IdentifierPart, unicodeES5IdentifierStart, unicodeES5IdentifierPart, unicodeESNextIdentifierStart, unicodeESNextIdentifierPart, commentDirectiveRegExSingleLine, commentDirectiveRegExMultiLine, tokenStrings, mergeConflictMarkerLength, shebangTriviaRegex, codePointAt, utf16EncodeAsStringWorker;
+  var textToKeywordObj, textToKeyword, textToToken, unicodeES3IdentifierStart, unicodeES3IdentifierPart, unicodeES5IdentifierStart, unicodeES5IdentifierPart, unicodeESNextIdentifierStart, unicodeESNextIdentifierPart, commentDirectiveRegExSingleLine, commentDirectiveRegExMultiLine, jsDocSeeOrLink, tokenStrings, mergeConflictMarkerLength, shebangTriviaRegex, utf16EncodeAsStringWorker;
   var init_scanner = __esm({
     "src/compiler/scanner.ts"() {
       "use strict";
@@ -110491,7 +93175,7 @@ ${lanes.join("\n")}
         as: 130 /* AsKeyword */,
         asserts: 131 /* AssertsKeyword */,
         assert: 132 /* AssertKeyword */,
-        bigint: 162 /* BigIntKeyword */,
+        bigint: 163 /* BigIntKeyword */,
         boolean: 136 /* BooleanKeyword */,
         break: 83 /* BreakKeyword */,
         case: 84 /* CaseKeyword */,
@@ -110512,7 +93196,7 @@ ${lanes.join("\n")}
         false: 97 /* FalseKeyword */,
         finally: 98 /* FinallyKeyword */,
         for: 99 /* ForKeyword */,
-        from: 160 /* FromKeyword */,
+        from: 161 /* FromKeyword */,
         function: 100 /* FunctionKeyword */,
         get: 139 /* GetKeyword */,
         if: 101 /* IfKeyword */,
@@ -110537,11 +93221,11 @@ ${lanes.join("\n")}
         private: 123 /* PrivateKeyword */,
         protected: 124 /* ProtectedKeyword */,
         public: 125 /* PublicKeyword */,
-        override: 163 /* OverrideKeyword */,
+        override: 164 /* OverrideKeyword */,
         out: 147 /* OutKeyword */,
         readonly: 148 /* ReadonlyKeyword */,
         require: 149 /* RequireKeyword */,
-        global: 161 /* GlobalKeyword */,
+        global: 162 /* GlobalKeyword */,
         return: 107 /* ReturnKeyword */,
         satisfies: 152 /* SatisfiesKeyword */,
         set: 153 /* SetKeyword */,
@@ -110559,6 +93243,7 @@ ${lanes.join("\n")}
         undefined: 157 /* UndefinedKeyword */,
         unique: 158 /* UniqueKeyword */,
         unknown: 159 /* UnknownKeyword */,
+        using: 160 /* UsingKeyword */,
         var: 115 /* VarKeyword */,
         void: 116 /* VoidKeyword */,
         while: 117 /* WhileKeyword */,
@@ -110566,7 +93251,7 @@ ${lanes.join("\n")}
         yield: 127 /* YieldKeyword */,
         async: 134 /* AsyncKeyword */,
         await: 135 /* AwaitKeyword */,
-        of: 164 /* OfKeyword */
+        of: 165 /* OfKeyword */
       };
       textToKeyword = new Map(Object.entries(textToKeywordObj));
       textToToken = new Map(Object.entries({
@@ -110641,23 +93326,10 @@ ${lanes.join("\n")}
       unicodeESNextIdentifierPart = [48, 57, 65, 90, 95, 95, 97, 122, 170, 170, 181, 181, 183, 183, 186, 186, 192, 214, 216, 246, 248, 705, 710, 721, 736, 740, 748, 748, 750, 750, 768, 884, 886, 887, 890, 893, 895, 895, 902, 906, 908, 908, 910, 929, 931, 1013, 1015, 1153, 1155, 1159, 1162, 1327, 1329, 1366, 1369, 1369, 1376, 1416, 1425, 1469, 1471, 1471, 1473, 1474, 1476, 1477, 1479, 1479, 1488, 1514, 1519, 1522, 1552, 1562, 1568, 1641, 1646, 1747, 1749, 1756, 1759, 1768, 1770, 1788, 1791, 1791, 1808, 1866, 1869, 1969, 1984, 2037, 2042, 2042, 2045, 2045, 2048, 2093, 2112, 2139, 2144, 2154, 2208, 2228, 2230, 2237, 2259, 2273, 2275, 2403, 2406, 2415, 2417, 2435, 2437, 2444, 2447, 2448, 2451, 2472, 2474, 2480, 2482, 2482, 2486, 2489, 2492, 2500, 2503, 2504, 2507, 2510, 2519, 2519, 2524, 2525, 2527, 2531, 2534, 2545, 2556, 2556, 2558, 2558, 2561, 2563, 2565, 2570, 2575, 2576, 2579, 2600, 2602, 2608, 2610, 2611, 2613, 2614, 2616, 2617, 2620, 2620, 2622, 2626, 2631, 2632, 2635, 2637, 2641, 2641, 2649, 2652, 2654, 2654, 2662, 2677, 2689, 2691, 2693, 2701, 2703, 2705, 2707, 2728, 2730, 2736, 2738, 2739, 2741, 2745, 2748, 2757, 2759, 2761, 2763, 2765, 2768, 2768, 2784, 2787, 2790, 2799, 2809, 2815, 2817, 2819, 2821, 2828, 2831, 2832, 2835, 2856, 2858, 2864, 2866, 2867, 2869, 2873, 2876, 2884, 2887, 2888, 2891, 2893, 2902, 2903, 2908, 2909, 2911, 2915, 2918, 2927, 2929, 2929, 2946, 2947, 2949, 2954, 2958, 2960, 2962, 2965, 2969, 2970, 2972, 2972, 2974, 2975, 2979, 2980, 2984, 2986, 2990, 3001, 3006, 3010, 3014, 3016, 3018, 3021, 3024, 3024, 3031, 3031, 3046, 3055, 3072, 3084, 3086, 3088, 3090, 3112, 3114, 3129, 3133, 3140, 3142, 3144, 3146, 3149, 3157, 3158, 3160, 3162, 3168, 3171, 3174, 3183, 3200, 3203, 3205, 3212, 3214, 3216, 3218, 3240, 3242, 3251, 3253, 3257, 3260, 3268, 3270, 3272, 3274, 3277, 3285, 3286, 3294, 3294, 3296, 3299, 3302, 3311, 3313, 3314, 3328, 3331, 3333, 3340, 3342, 3344, 3346, 3396, 3398, 3400, 3402, 3406, 3412, 3415, 3423, 3427, 3430, 3439, 3450, 3455, 3458, 3459, 3461, 3478, 3482, 3505, 3507, 3515, 3517, 3517, 3520, 3526, 3530, 3530, 3535, 3540, 3542, 3542, 3544, 3551, 3558, 3567, 3570, 3571, 3585, 3642, 3648, 3662, 3664, 3673, 3713, 3714, 3716, 3716, 3718, 3722, 3724, 3747, 3749, 3749, 3751, 3773, 3776, 3780, 3782, 3782, 3784, 3789, 3792, 3801, 3804, 3807, 3840, 3840, 3864, 3865, 3872, 3881, 3893, 3893, 3895, 3895, 3897, 3897, 3902, 3911, 3913, 3948, 3953, 3972, 3974, 3991, 3993, 4028, 4038, 4038, 4096, 4169, 4176, 4253, 4256, 4293, 4295, 4295, 4301, 4301, 4304, 4346, 4348, 4680, 4682, 4685, 4688, 4694, 4696, 4696, 4698, 4701, 4704, 4744, 4746, 4749, 4752, 4784, 4786, 4789, 4792, 4798, 4800, 4800, 4802, 4805, 4808, 4822, 4824, 4880, 4882, 4885, 4888, 4954, 4957, 4959, 4969, 4977, 4992, 5007, 5024, 5109, 5112, 5117, 5121, 5740, 5743, 5759, 5761, 5786, 5792, 5866, 5870, 5880, 5888, 5900, 5902, 5908, 5920, 5940, 5952, 5971, 5984, 5996, 5998, 6e3, 6002, 6003, 6016, 6099, 6103, 6103, 6108, 6109, 6112, 6121, 6155, 6157, 6160, 6169, 6176, 6264, 6272, 6314, 6320, 6389, 6400, 6430, 6432, 6443, 6448, 6459, 6470, 6509, 6512, 6516, 6528, 6571, 6576, 6601, 6608, 6618, 6656, 6683, 6688, 6750, 6752, 6780, 6783, 6793, 6800, 6809, 6823, 6823, 6832, 6845, 6912, 6987, 6992, 7001, 7019, 7027, 7040, 7155, 7168, 7223, 7232, 7241, 7245, 7293, 7296, 7304, 7312, 7354, 7357, 7359, 7376, 7378, 7380, 7418, 7424, 7673, 7675, 7957, 7960, 7965, 7968, 8005, 8008, 8013, 8016, 8023, 8025, 8025, 8027, 8027, 8029, 8029, 8031, 8061, 8064, 8116, 8118, 8124, 8126, 8126, 8130, 8132, 8134, 8140, 8144, 8147, 8150, 8155, 8160, 8172, 8178, 8180, 8182, 8188, 8255, 8256, 8276, 8276, 8305, 8305, 8319, 8319, 8336, 8348, 8400, 8412, 8417, 8417, 8421, 8432, 8450, 8450, 8455, 8455, 8458, 8467, 8469, 8469, 8472, 8477, 8484, 8484, 8486, 8486, 8488, 8488, 8490, 8505, 8508, 8511, 8517, 8521, 8526, 8526, 8544, 8584, 11264, 11310, 11312, 11358, 11360, 11492, 11499, 11507, 11520, 11557, 11559, 11559, 11565, 11565, 11568, 11623, 11631, 11631, 11647, 11670, 11680, 11686, 11688, 11694, 11696, 11702, 11704, 11710, 11712, 11718, 11720, 11726, 11728, 11734, 11736, 11742, 11744, 11775, 12293, 12295, 12321, 12335, 12337, 12341, 12344, 12348, 12353, 12438, 12441, 12447, 12449, 12538, 12540, 12543, 12549, 12591, 12593, 12686, 12704, 12730, 12784, 12799, 13312, 19893, 19968, 40943, 40960, 42124, 42192, 42237, 42240, 42508, 42512, 42539, 42560, 42607, 42612, 42621, 42623, 42737, 42775, 42783, 42786, 42888, 42891, 42943, 42946, 42950, 42999, 43047, 43072, 43123, 43136, 43205, 43216, 43225, 43232, 43255, 43259, 43259, 43261, 43309, 43312, 43347, 43360, 43388, 43392, 43456, 43471, 43481, 43488, 43518, 43520, 43574, 43584, 43597, 43600, 43609, 43616, 43638, 43642, 43714, 43739, 43741, 43744, 43759, 43762, 43766, 43777, 43782, 43785, 43790, 43793, 43798, 43808, 43814, 43816, 43822, 43824, 43866, 43868, 43879, 43888, 44010, 44012, 44013, 44016, 44025, 44032, 55203, 55216, 55238, 55243, 55291, 63744, 64109, 64112, 64217, 64256, 64262, 64275, 64279, 64285, 64296, 64298, 64310, 64312, 64316, 64318, 64318, 64320, 64321, 64323, 64324, 64326, 64433, 64467, 64829, 64848, 64911, 64914, 64967, 65008, 65019, 65024, 65039, 65056, 65071, 65075, 65076, 65101, 65103, 65136, 65140, 65142, 65276, 65296, 65305, 65313, 65338, 65343, 65343, 65345, 65370, 65382, 65470, 65474, 65479, 65482, 65487, 65490, 65495, 65498, 65500, 65536, 65547, 65549, 65574, 65576, 65594, 65596, 65597, 65599, 65613, 65616, 65629, 65664, 65786, 65856, 65908, 66045, 66045, 66176, 66204, 66208, 66256, 66272, 66272, 66304, 66335, 66349, 66378, 66384, 66426, 66432, 66461, 66464, 66499, 66504, 66511, 66513, 66517, 66560, 66717, 66720, 66729, 66736, 66771, 66776, 66811, 66816, 66855, 66864, 66915, 67072, 67382, 67392, 67413, 67424, 67431, 67584, 67589, 67592, 67592, 67594, 67637, 67639, 67640, 67644, 67644, 67647, 67669, 67680, 67702, 67712, 67742, 67808, 67826, 67828, 67829, 67840, 67861, 67872, 67897, 67968, 68023, 68030, 68031, 68096, 68099, 68101, 68102, 68108, 68115, 68117, 68119, 68121, 68149, 68152, 68154, 68159, 68159, 68192, 68220, 68224, 68252, 68288, 68295, 68297, 68326, 68352, 68405, 68416, 68437, 68448, 68466, 68480, 68497, 68608, 68680, 68736, 68786, 68800, 68850, 68864, 68903, 68912, 68921, 69376, 69404, 69415, 69415, 69424, 69456, 69600, 69622, 69632, 69702, 69734, 69743, 69759, 69818, 69840, 69864, 69872, 69881, 69888, 69940, 69942, 69951, 69956, 69958, 69968, 70003, 70006, 70006, 70016, 70084, 70089, 70092, 70096, 70106, 70108, 70108, 70144, 70161, 70163, 70199, 70206, 70206, 70272, 70278, 70280, 70280, 70282, 70285, 70287, 70301, 70303, 70312, 70320, 70378, 70384, 70393, 70400, 70403, 70405, 70412, 70415, 70416, 70419, 70440, 70442, 70448, 70450, 70451, 70453, 70457, 70459, 70468, 70471, 70472, 70475, 70477, 70480, 70480, 70487, 70487, 70493, 70499, 70502, 70508, 70512, 70516, 70656, 70730, 70736, 70745, 70750, 70751, 70784, 70853, 70855, 70855, 70864, 70873, 71040, 71093, 71096, 71104, 71128, 71133, 71168, 71232, 71236, 71236, 71248, 71257, 71296, 71352, 71360, 71369, 71424, 71450, 71453, 71467, 71472, 71481, 71680, 71738, 71840, 71913, 71935, 71935, 72096, 72103, 72106, 72151, 72154, 72161, 72163, 72164, 72192, 72254, 72263, 72263, 72272, 72345, 72349, 72349, 72384, 72440, 72704, 72712, 72714, 72758, 72760, 72768, 72784, 72793, 72818, 72847, 72850, 72871, 72873, 72886, 72960, 72966, 72968, 72969, 72971, 73014, 73018, 73018, 73020, 73021, 73023, 73031, 73040, 73049, 73056, 73061, 73063, 73064, 73066, 73102, 73104, 73105, 73107, 73112, 73120, 73129, 73440, 73462, 73728, 74649, 74752, 74862, 74880, 75075, 77824, 78894, 82944, 83526, 92160, 92728, 92736, 92766, 92768, 92777, 92880, 92909, 92912, 92916, 92928, 92982, 92992, 92995, 93008, 93017, 93027, 93047, 93053, 93071, 93760, 93823, 93952, 94026, 94031, 94087, 94095, 94111, 94176, 94177, 94179, 94179, 94208, 100343, 100352, 101106, 110592, 110878, 110928, 110930, 110948, 110951, 110960, 111355, 113664, 113770, 113776, 113788, 113792, 113800, 113808, 113817, 113821, 113822, 119141, 119145, 119149, 119154, 119163, 119170, 119173, 119179, 119210, 119213, 119362, 119364, 119808, 119892, 119894, 119964, 119966, 119967, 119970, 119970, 119973, 119974, 119977, 119980, 119982, 119993, 119995, 119995, 119997, 120003, 120005, 120069, 120071, 120074, 120077, 120084, 120086, 120092, 120094, 120121, 120123, 120126, 120128, 120132, 120134, 120134, 120138, 120144, 120146, 120485, 120488, 120512, 120514, 120538, 120540, 120570, 120572, 120596, 120598, 120628, 120630, 120654, 120656, 120686, 120688, 120712, 120714, 120744, 120746, 120770, 120772, 120779, 120782, 120831, 121344, 121398, 121403, 121452, 121461, 121461, 121476, 121476, 121499, 121503, 121505, 121519, 122880, 122886, 122888, 122904, 122907, 122913, 122915, 122916, 122918, 122922, 123136, 123180, 123184, 123197, 123200, 123209, 123214, 123214, 123584, 123641, 124928, 125124, 125136, 125142, 125184, 125259, 125264, 125273, 126464, 126467, 126469, 126495, 126497, 126498, 126500, 126500, 126503, 126503, 126505, 126514, 126516, 126519, 126521, 126521, 126523, 126523, 126530, 126530, 126535, 126535, 126537, 126537, 126539, 126539, 126541, 126543, 126545, 126546, 126548, 126548, 126551, 126551, 126553, 126553, 126555, 126555, 126557, 126557, 126559, 126559, 126561, 126562, 126564, 126564, 126567, 126570, 126572, 126578, 126580, 126583, 126585, 126588, 126590, 126590, 126592, 126601, 126603, 126619, 126625, 126627, 126629, 126633, 126635, 126651, 131072, 173782, 173824, 177972, 177984, 178205, 178208, 183969, 183984, 191456, 194560, 195101, 917760, 917999];
       commentDirectiveRegExSingleLine = /^\/\/\/?\s*@(ts-expect-error|ts-ignore)/;
       commentDirectiveRegExMultiLine = /^(?:\/|\*)*\s*@(ts-expect-error|ts-ignore)/;
+      jsDocSeeOrLink = /@(?:see|link)/i;
       tokenStrings = makeReverseMap(textToToken);
       mergeConflictMarkerLength = "<<<<<<<".length;
       shebangTriviaRegex = /^#!.*/;
-      codePointAt = String.prototype.codePointAt ? (s, i) => s.codePointAt(i) : function codePointAt2(str, i) {
-        const size = str.length;
-        if (i < 0 || i >= size) {
-          return void 0;
-        }
-        const first2 = str.charCodeAt(i);
-        if (first2 >= 55296 && first2 <= 56319 && size > i + 1) {
-          const second = str.charCodeAt(i + 1);
-          if (second >= 56320 && second <= 57343) {
-            return (first2 - 55296) * 1024 + second - 56320 + 65536;
-          }
-        }
-        return first2;
-      };
       utf16EncodeAsStringWorker = String.fromCodePoint ? (codePoint) => String.fromCodePoint(codePoint) : utf16EncodeAsStringFallback;
     }
   });
@@ -110788,16 +93460,16 @@ ${lanes.join("\n")}
     );
   }
   function getTypeParameterOwner(d) {
-    if (d && d.kind === 167 /* TypeParameter */) {
+    if (d && d.kind === 168 /* TypeParameter */) {
       for (let current = d; current; current = current.parent) {
-        if (isFunctionLike(current) || isClassLike(current) || current.kind === 263 /* InterfaceDeclaration */) {
+        if (isFunctionLike(current) || isClassLike(current) || current.kind === 264 /* InterfaceDeclaration */) {
           return current;
         }
       }
     }
   }
   function isParameterPropertyDeclaration(node, parent2) {
-    return isParameter(node) && hasSyntacticModifier(node, 16476 /* ParameterPropertyModifier */) && parent2.kind === 175 /* Constructor */;
+    return isParameter(node) && hasSyntacticModifier(node, 31 /* ParameterPropertyModifier */) && parent2.kind === 176 /* Constructor */;
   }
   function isEmptyBindingPattern(node) {
     if (isBindingPattern(node)) {
@@ -110823,14 +93495,14 @@ ${lanes.join("\n")}
       node = walkUpBindingElementsAndPatterns(node);
     }
     let flags = getFlags(node);
-    if (node.kind === 259 /* VariableDeclaration */) {
+    if (node.kind === 260 /* VariableDeclaration */) {
       node = node.parent;
     }
-    if (node && node.kind === 260 /* VariableDeclarationList */) {
+    if (node && node.kind === 261 /* VariableDeclarationList */) {
       flags |= getFlags(node);
       node = node.parent;
     }
-    if (node && node.kind === 242 /* VariableStatement */) {
+    if (node && node.kind === 243 /* VariableStatement */) {
       flags |= getFlags(node);
     }
     return flags;
@@ -110842,11 +93514,14 @@ ${lanes.join("\n")}
     return getCombinedFlags(node, getEffectiveModifierFlagsAlwaysIncludeJSDoc);
   }
   function getCombinedNodeFlags(node) {
-    return getCombinedFlags(node, (n) => n.flags);
+    return getCombinedFlags(node, getNodeFlags);
+  }
+  function getNodeFlags(node) {
+    return node.flags;
   }
   function validateLocaleAndSetLanguage(locale, sys2, errors) {
     const lowerCaseLocale = locale.toLowerCase();
-    const matchResult = /^([a-z]+)([_\-]([a-z]+))?$/.exec(lowerCaseLocale);
+    const matchResult = /^([a-z]+)([_-]([a-z]+))?$/.exec(lowerCaseLocale);
     if (!matchResult) {
       if (errors) {
         errors.push(createCompilerDiagnostic(Diagnostics.Locale_must_be_of_the_form_language_or_language_territory_For_example_0_or_1, "en", "ja-jp"));
@@ -110919,7 +93594,7 @@ ${lanes.join("\n")}
     return void 0;
   }
   function isParseTreeNode(node) {
-    return (node.flags & 8 /* Synthesized */) === 0;
+    return (node.flags & 16 /* Synthesized */) === 0;
   }
   function getParseTreeNode(node, nodeTest) {
     if (node === void 0 || isParseTreeNode(node)) {
@@ -110962,30 +93637,30 @@ ${lanes.join("\n")}
       return getDeclarationIdentifier(hostNode);
     }
     switch (hostNode.kind) {
-      case 242 /* VariableStatement */:
+      case 243 /* VariableStatement */:
         if (hostNode.declarationList && hostNode.declarationList.declarations[0]) {
           return getDeclarationIdentifier(hostNode.declarationList.declarations[0]);
         }
         break;
-      case 243 /* ExpressionStatement */:
+      case 244 /* ExpressionStatement */:
         let expr = hostNode.expression;
-        if (expr.kind === 225 /* BinaryExpression */ && expr.operatorToken.kind === 64 /* EqualsToken */) {
+        if (expr.kind === 226 /* BinaryExpression */ && expr.operatorToken.kind === 64 /* EqualsToken */) {
           expr = expr.left;
         }
         switch (expr.kind) {
-          case 210 /* PropertyAccessExpression */:
+          case 211 /* PropertyAccessExpression */:
             return expr.name;
-          case 211 /* ElementAccessExpression */:
+          case 212 /* ElementAccessExpression */:
             const arg = expr.argumentExpression;
             if (isIdentifier(arg)) {
               return arg;
             }
         }
         break;
-      case 216 /* ParenthesizedExpression */: {
+      case 217 /* ParenthesizedExpression */: {
         return getDeclarationIdentifier(hostNode.expression);
       }
-      case 255 /* LabeledStatement */: {
+      case 256 /* LabeledStatement */: {
         if (isDeclaration(hostNode.statement) || isExpression(hostNode.statement)) {
           return getDeclarationIdentifier(hostNode.statement);
         }
@@ -111016,16 +93691,16 @@ ${lanes.join("\n")}
     switch (declaration.kind) {
       case 80 /* Identifier */:
         return declaration;
-      case 354 /* JSDocPropertyTag */:
-      case 347 /* JSDocParameterTag */: {
+      case 355 /* JSDocPropertyTag */:
+      case 348 /* JSDocParameterTag */: {
         const { name } = declaration;
-        if (name.kind === 165 /* QualifiedName */) {
+        if (name.kind === 166 /* QualifiedName */) {
           return name.right;
         }
         break;
       }
-      case 212 /* CallExpression */:
-      case 225 /* BinaryExpression */: {
+      case 213 /* CallExpression */:
+      case 226 /* BinaryExpression */: {
         const expr2 = declaration;
         switch (getAssignmentDeclarationKind(expr2)) {
           case 1 /* ExportsProperty */:
@@ -111041,15 +93716,15 @@ ${lanes.join("\n")}
             return void 0;
         }
       }
-      case 352 /* JSDocTypedefTag */:
+      case 353 /* JSDocTypedefTag */:
         return getNameOfJSDocTypedef(declaration);
-      case 346 /* JSDocEnumTag */:
+      case 347 /* JSDocEnumTag */:
         return nameForNamelessJSDocTypedef(declaration);
-      case 276 /* ExportAssignment */: {
+      case 277 /* ExportAssignment */: {
         const { expression } = declaration;
         return isIdentifier(expression) ? expression : void 0;
       }
-      case 211 /* ElementAccessExpression */:
+      case 212 /* ElementAccessExpression */:
         const expr = declaration;
         if (isBindableStaticElementAccessExpression(expr)) {
           return expr.argumentExpression;
@@ -111083,7 +93758,7 @@ ${lanes.join("\n")}
     }
   }
   function getModifiers(node) {
-    if (hasSyntacticModifier(node, 126975 /* Modifier */)) {
+    if (hasSyntacticModifier(node, 98303 /* Modifier */)) {
       return filter(node.modifiers, isModifier);
     }
   }
@@ -111296,10 +93971,10 @@ ${lanes.join("\n")}
     return getJSDocTags(node).filter((doc) => doc.kind === kind);
   }
   function getTextOfJSDocComment(comment) {
-    return typeof comment === "string" ? comment : comment == null ? void 0 : comment.map((c) => c.kind === 327 /* JSDocText */ ? c.text : formatJSDocLink(c)).join("");
+    return typeof comment === "string" ? comment : comment == null ? void 0 : comment.map((c) => c.kind === 328 /* JSDocText */ ? c.text : formatJSDocLink(c)).join("");
   }
   function formatJSDocLink(link) {
-    const kind = link.kind === 330 /* JSDocLink */ ? "link" : link.kind === 331 /* JSDocLinkCode */ ? "linkcode" : "linkplain";
+    const kind = link.kind === 331 /* JSDocLink */ ? "link" : link.kind === 332 /* JSDocLinkCode */ ? "linkcode" : "linkplain";
     const name = link.name ? entityNameToString(link.name) : "";
     const space = link.name && link.text.startsWith("://") ? "" : " ";
     return `{@${kind} ${name}${space}${link.text}}`;
@@ -111315,7 +93990,7 @@ ${lanes.join("\n")}
       return emptyArray;
     }
     if (isJSDocTypeAlias(node)) {
-      Debug.assert(node.parent.kind === 326 /* JSDoc */);
+      Debug.assert(node.parent.kind === 327 /* JSDoc */);
       return flatMap(node.parent.tags, (tag) => isJSDocTemplateTag(tag) ? tag.typeParameters : void 0);
     }
     if (node.typeParameters) {
@@ -111343,20 +94018,20 @@ ${lanes.join("\n")}
     return node.kind === 80 /* Identifier */ || node.kind === 81 /* PrivateIdentifier */;
   }
   function isGetOrSetAccessorDeclaration(node) {
-    return node.kind === 177 /* SetAccessor */ || node.kind === 176 /* GetAccessor */;
+    return node.kind === 178 /* SetAccessor */ || node.kind === 177 /* GetAccessor */;
   }
   function isPropertyAccessChain(node) {
-    return isPropertyAccessExpression(node) && !!(node.flags & 32 /* OptionalChain */);
+    return isPropertyAccessExpression(node) && !!(node.flags & 64 /* OptionalChain */);
   }
   function isElementAccessChain(node) {
-    return isElementAccessExpression(node) && !!(node.flags & 32 /* OptionalChain */);
+    return isElementAccessExpression(node) && !!(node.flags & 64 /* OptionalChain */);
   }
   function isCallChain(node) {
-    return isCallExpression(node) && !!(node.flags & 32 /* OptionalChain */);
+    return isCallExpression(node) && !!(node.flags & 64 /* OptionalChain */);
   }
   function isOptionalChain(node) {
     const kind = node.kind;
-    return !!(node.flags & 32 /* OptionalChain */) && (kind === 210 /* PropertyAccessExpression */ || kind === 211 /* ElementAccessExpression */ || kind === 212 /* CallExpression */ || kind === 234 /* NonNullExpression */);
+    return !!(node.flags & 64 /* OptionalChain */) && (kind === 211 /* PropertyAccessExpression */ || kind === 212 /* ElementAccessExpression */ || kind === 213 /* CallExpression */ || kind === 235 /* NonNullExpression */);
   }
   function isOptionalChainRoot(node) {
     return isOptionalChain(node) && !isNonNullExpression(node) && !!node.questionDotToken;
@@ -111368,7 +94043,7 @@ ${lanes.join("\n")}
     return !isOptionalChain(node.parent) || isOptionalChainRoot(node.parent) || node !== node.parent.expression;
   }
   function isNullishCoalesce(node) {
-    return node.kind === 225 /* BinaryExpression */ && node.operatorToken.kind === 61 /* QuestionQuestionToken */;
+    return node.kind === 226 /* BinaryExpression */ && node.operatorToken.kind === 61 /* QuestionQuestionToken */;
   }
   function isConstTypeReference(node) {
     return isTypeReferenceNode(node) && isIdentifier(node.typeName) && node.typeName.escapedText === "const" && !node.typeArguments;
@@ -111377,37 +94052,37 @@ ${lanes.join("\n")}
     return skipOuterExpressions(node, 8 /* PartiallyEmittedExpressions */);
   }
   function isNonNullChain(node) {
-    return isNonNullExpression(node) && !!(node.flags & 32 /* OptionalChain */);
+    return isNonNullExpression(node) && !!(node.flags & 64 /* OptionalChain */);
   }
   function isBreakOrContinueStatement(node) {
-    return node.kind === 251 /* BreakStatement */ || node.kind === 250 /* ContinueStatement */;
+    return node.kind === 252 /* BreakStatement */ || node.kind === 251 /* ContinueStatement */;
   }
   function isNamedExportBindings(node) {
-    return node.kind === 279 /* NamespaceExport */ || node.kind === 278 /* NamedExports */;
+    return node.kind === 280 /* NamespaceExport */ || node.kind === 279 /* NamedExports */;
   }
   function isUnparsedTextLike(node) {
     switch (node.kind) {
-      case 308 /* UnparsedText */:
-      case 309 /* UnparsedInternalText */:
+      case 309 /* UnparsedText */:
+      case 310 /* UnparsedInternalText */:
         return true;
       default:
         return false;
     }
   }
   function isUnparsedNode(node) {
-    return isUnparsedTextLike(node) || node.kind === 306 /* UnparsedPrologue */ || node.kind === 310 /* UnparsedSyntheticReference */;
+    return isUnparsedTextLike(node) || node.kind === 307 /* UnparsedPrologue */ || node.kind === 311 /* UnparsedSyntheticReference */;
   }
   function isJSDocPropertyLikeTag(node) {
-    return node.kind === 354 /* JSDocPropertyTag */ || node.kind === 347 /* JSDocParameterTag */;
+    return node.kind === 355 /* JSDocPropertyTag */ || node.kind === 348 /* JSDocParameterTag */;
   }
   function isNode(node) {
     return isNodeKind(node.kind);
   }
   function isNodeKind(kind) {
-    return kind >= 165 /* FirstNode */;
+    return kind >= 166 /* FirstNode */;
   }
   function isTokenKind(kind) {
-    return kind >= 0 /* FirstToken */ && kind <= 164 /* LastToken */;
+    return kind >= 0 /* FirstToken */ && kind <= 165 /* LastToken */;
   }
   function isToken(n) {
     return isTokenKind(n.kind);
@@ -111423,11 +94098,11 @@ ${lanes.join("\n")}
   }
   function isLiteralExpressionOfObject(node) {
     switch (node.kind) {
-      case 209 /* ObjectLiteralExpression */:
-      case 208 /* ArrayLiteralExpression */:
+      case 210 /* ObjectLiteralExpression */:
+      case 209 /* ArrayLiteralExpression */:
       case 14 /* RegularExpressionLiteral */:
-      case 217 /* FunctionExpression */:
-      case 230 /* ClassExpression */:
+      case 218 /* FunctionExpression */:
+      case 231 /* ClassExpression */:
         return true;
     }
     return false;
@@ -111447,23 +94122,23 @@ ${lanes.join("\n")}
   }
   function isTypeOnlyImportDeclaration(node) {
     switch (node.kind) {
-      case 275 /* ImportSpecifier */:
+      case 276 /* ImportSpecifier */:
         return node.isTypeOnly || node.parent.parent.isTypeOnly;
-      case 273 /* NamespaceImport */:
+      case 274 /* NamespaceImport */:
         return node.parent.isTypeOnly;
-      case 272 /* ImportClause */:
-      case 270 /* ImportEqualsDeclaration */:
+      case 273 /* ImportClause */:
+      case 271 /* ImportEqualsDeclaration */:
         return node.isTypeOnly;
     }
     return false;
   }
   function isTypeOnlyExportDeclaration(node) {
     switch (node.kind) {
-      case 280 /* ExportSpecifier */:
+      case 281 /* ExportSpecifier */:
         return node.isTypeOnly || node.parent.parent.isTypeOnly;
-      case 277 /* ExportDeclaration */:
+      case 278 /* ExportDeclaration */:
         return node.isTypeOnly && !!node.moduleSpecifier && !node.exportClause;
-      case 279 /* NamespaceExport */:
+      case 280 /* NamespaceExport */:
         return node.parent.isTypeOnly;
     }
     return false;
@@ -111471,12 +94146,12 @@ ${lanes.join("\n")}
   function isTypeOnlyImportOrExportDeclaration(node) {
     return isTypeOnlyImportDeclaration(node) || isTypeOnlyExportDeclaration(node);
   }
-  function isAssertionKey(node) {
-    return isStringLiteral(node) || isIdentifier(node);
-  }
   function isStringTextContainingNode(node) {
     return node.kind === 11 /* StringLiteral */ || isTemplateLiteralKind(node.kind);
   }
+  function isImportAttributeName(node) {
+    return isStringLiteral(node) || isIdentifier(node);
+  }
   function isGeneratedIdentifier(node) {
     var _a;
     return isIdentifier(node) && ((_a = node.emitNode) == null ? void 0 : _a.autoGenerate) !== void 0;
@@ -111485,6 +94160,10 @@ ${lanes.join("\n")}
     var _a;
     return isPrivateIdentifier(node) && ((_a = node.emitNode) == null ? void 0 : _a.autoGenerate) !== void 0;
   }
+  function isFileLevelReservedGeneratedIdentifier(node) {
+    const flags = node.emitNode.autoGenerate.flags;
+    return !!(flags & 32 /* FileLevel */) && !!(flags & 16 /* Optimistic */) && !!(flags & 8 /* ReservedInNestedScopes */);
+  }
   function isPrivateIdentifierClassElementDeclaration(node) {
     return (isPropertyDeclaration(node) || isMethodOrAccessor(node)) && isPrivateIdentifier(node.name);
   }
@@ -111507,31 +94186,31 @@ ${lanes.join("\n")}
       case 148 /* ReadonlyKeyword */:
       case 126 /* StaticKeyword */:
       case 147 /* OutKeyword */:
-      case 163 /* OverrideKeyword */:
+      case 164 /* OverrideKeyword */:
         return true;
     }
     return false;
   }
   function isParameterPropertyModifier(kind) {
-    return !!(modifierToFlag(kind) & 16476 /* ParameterPropertyModifier */);
+    return !!(modifierToFlag(kind) & 31 /* ParameterPropertyModifier */);
   }
   function isClassMemberModifier(idToken) {
-    return isParameterPropertyModifier(idToken) || idToken === 126 /* StaticKeyword */ || idToken === 163 /* OverrideKeyword */ || idToken === 129 /* AccessorKeyword */;
+    return isParameterPropertyModifier(idToken) || idToken === 126 /* StaticKeyword */ || idToken === 164 /* OverrideKeyword */ || idToken === 129 /* AccessorKeyword */;
   }
   function isModifier(node) {
     return isModifierKind(node.kind);
   }
   function isEntityName(node) {
     const kind = node.kind;
-    return kind === 165 /* QualifiedName */ || kind === 80 /* Identifier */;
+    return kind === 166 /* QualifiedName */ || kind === 80 /* Identifier */;
   }
   function isPropertyName(node) {
     const kind = node.kind;
-    return kind === 80 /* Identifier */ || kind === 81 /* PrivateIdentifier */ || kind === 11 /* StringLiteral */ || kind === 9 /* NumericLiteral */ || kind === 166 /* ComputedPropertyName */;
+    return kind === 80 /* Identifier */ || kind === 81 /* PrivateIdentifier */ || kind === 11 /* StringLiteral */ || kind === 9 /* NumericLiteral */ || kind === 167 /* ComputedPropertyName */;
   }
   function isBindingName(node) {
     const kind = node.kind;
-    return kind === 80 /* Identifier */ || kind === 205 /* ObjectBindingPattern */ || kind === 206 /* ArrayBindingPattern */;
+    return kind === 80 /* Identifier */ || kind === 206 /* ObjectBindingPattern */ || kind === 207 /* ArrayBindingPattern */;
   }
   function isFunctionLike(node) {
     return !!node && isFunctionLikeKind(node.kind);
@@ -111547,13 +94226,13 @@ ${lanes.join("\n")}
   }
   function isFunctionLikeDeclarationKind(kind) {
     switch (kind) {
-      case 261 /* FunctionDeclaration */:
-      case 173 /* MethodDeclaration */:
-      case 175 /* Constructor */:
-      case 176 /* GetAccessor */:
-      case 177 /* SetAccessor */:
-      case 217 /* FunctionExpression */:
-      case 218 /* ArrowFunction */:
+      case 262 /* FunctionDeclaration */:
+      case 174 /* MethodDeclaration */:
+      case 176 /* Constructor */:
+      case 177 /* GetAccessor */:
+      case 178 /* SetAccessor */:
+      case 218 /* FunctionExpression */:
+      case 219 /* ArrowFunction */:
         return true;
       default:
         return false;
@@ -111561,14 +94240,14 @@ ${lanes.join("\n")}
   }
   function isFunctionLikeKind(kind) {
     switch (kind) {
-      case 172 /* MethodSignature */:
-      case 178 /* CallSignature */:
-      case 329 /* JSDocSignature */:
-      case 179 /* ConstructSignature */:
-      case 180 /* IndexSignature */:
-      case 183 /* FunctionType */:
-      case 323 /* JSDocFunctionType */:
-      case 184 /* ConstructorType */:
+      case 173 /* MethodSignature */:
+      case 179 /* CallSignature */:
+      case 330 /* JSDocSignature */:
+      case 180 /* ConstructSignature */:
+      case 181 /* IndexSignature */:
+      case 184 /* FunctionType */:
+      case 324 /* JSDocFunctionType */:
+      case 185 /* ConstructorType */:
         return true;
       default:
         return isFunctionLikeDeclarationKind(kind);
@@ -111579,22 +94258,32 @@ ${lanes.join("\n")}
   }
   function isClassElement(node) {
     const kind = node.kind;
-    return kind === 175 /* Constructor */ || kind === 171 /* PropertyDeclaration */ || kind === 173 /* MethodDeclaration */ || kind === 176 /* GetAccessor */ || kind === 177 /* SetAccessor */ || kind === 180 /* IndexSignature */ || kind === 174 /* ClassStaticBlockDeclaration */ || kind === 239 /* SemicolonClassElement */;
+    return kind === 176 /* Constructor */ || kind === 172 /* PropertyDeclaration */ || kind === 174 /* MethodDeclaration */ || kind === 177 /* GetAccessor */ || kind === 178 /* SetAccessor */ || kind === 181 /* IndexSignature */ || kind === 175 /* ClassStaticBlockDeclaration */ || kind === 240 /* SemicolonClassElement */;
   }
   function isClassLike(node) {
-    return node && (node.kind === 262 /* ClassDeclaration */ || node.kind === 230 /* ClassExpression */);
+    return node && (node.kind === 263 /* ClassDeclaration */ || node.kind === 231 /* ClassExpression */);
   }
   function isAccessor(node) {
-    return node && (node.kind === 176 /* GetAccessor */ || node.kind === 177 /* SetAccessor */);
+    return node && (node.kind === 177 /* GetAccessor */ || node.kind === 178 /* SetAccessor */);
   }
   function isAutoAccessorPropertyDeclaration(node) {
     return isPropertyDeclaration(node) && hasAccessorModifier(node);
   }
+  function isClassInstanceProperty(node) {
+    if (isInJSFile(node) && isExpandoPropertyDeclaration(node)) {
+      return (!isBindableStaticAccessExpression(node) || !isPrototypeAccess(node.expression)) && !isBindableStaticNameExpression(
+        node,
+        /*excludeThisKeyword*/
+        true
+      );
+    }
+    return node.parent && isClassLike(node.parent) && isPropertyDeclaration(node) && !hasAccessorModifier(node);
+  }
   function isMethodOrAccessor(node) {
     switch (node.kind) {
-      case 173 /* MethodDeclaration */:
-      case 176 /* GetAccessor */:
-      case 177 /* SetAccessor */:
+      case 174 /* MethodDeclaration */:
+      case 177 /* GetAccessor */:
+      case 178 /* SetAccessor */:
         return true;
       default:
         return false;
@@ -111602,10 +94291,10 @@ ${lanes.join("\n")}
   }
   function isNamedClassElement(node) {
     switch (node.kind) {
-      case 173 /* MethodDeclaration */:
-      case 176 /* GetAccessor */:
-      case 177 /* SetAccessor */:
-      case 171 /* PropertyDeclaration */:
+      case 174 /* MethodDeclaration */:
+      case 177 /* GetAccessor */:
+      case 178 /* SetAccessor */:
+      case 172 /* PropertyDeclaration */:
         return true;
       default:
         return false;
@@ -111616,22 +94305,22 @@ ${lanes.join("\n")}
   }
   function isTypeElement(node) {
     const kind = node.kind;
-    return kind === 179 /* ConstructSignature */ || kind === 178 /* CallSignature */ || kind === 170 /* PropertySignature */ || kind === 172 /* MethodSignature */ || kind === 180 /* IndexSignature */ || kind === 176 /* GetAccessor */ || kind === 177 /* SetAccessor */;
+    return kind === 180 /* ConstructSignature */ || kind === 179 /* CallSignature */ || kind === 171 /* PropertySignature */ || kind === 173 /* MethodSignature */ || kind === 181 /* IndexSignature */ || kind === 177 /* GetAccessor */ || kind === 178 /* SetAccessor */;
   }
   function isClassOrTypeElement(node) {
     return isTypeElement(node) || isClassElement(node);
   }
   function isObjectLiteralElementLike(node) {
     const kind = node.kind;
-    return kind === 302 /* PropertyAssignment */ || kind === 303 /* ShorthandPropertyAssignment */ || kind === 304 /* SpreadAssignment */ || kind === 173 /* MethodDeclaration */ || kind === 176 /* GetAccessor */ || kind === 177 /* SetAccessor */;
+    return kind === 303 /* PropertyAssignment */ || kind === 304 /* ShorthandPropertyAssignment */ || kind === 305 /* SpreadAssignment */ || kind === 174 /* MethodDeclaration */ || kind === 177 /* GetAccessor */ || kind === 178 /* SetAccessor */;
   }
   function isTypeNode(node) {
     return isTypeNodeKind(node.kind);
   }
   function isFunctionOrConstructorTypeNode(node) {
     switch (node.kind) {
-      case 183 /* FunctionType */:
-      case 184 /* ConstructorType */:
+      case 184 /* FunctionType */:
+      case 185 /* ConstructorType */:
         return true;
     }
     return false;
@@ -111639,23 +94328,23 @@ ${lanes.join("\n")}
   function isBindingPattern(node) {
     if (node) {
       const kind = node.kind;
-      return kind === 206 /* ArrayBindingPattern */ || kind === 205 /* ObjectBindingPattern */;
+      return kind === 207 /* ArrayBindingPattern */ || kind === 206 /* ObjectBindingPattern */;
     }
     return false;
   }
   function isAssignmentPattern(node) {
     const kind = node.kind;
-    return kind === 208 /* ArrayLiteralExpression */ || kind === 209 /* ObjectLiteralExpression */;
+    return kind === 209 /* ArrayLiteralExpression */ || kind === 210 /* ObjectLiteralExpression */;
   }
   function isArrayBindingElement(node) {
     const kind = node.kind;
-    return kind === 207 /* BindingElement */ || kind === 231 /* OmittedExpression */;
+    return kind === 208 /* BindingElement */ || kind === 232 /* OmittedExpression */;
   }
   function isDeclarationBindingElement(bindingElement) {
     switch (bindingElement.kind) {
-      case 259 /* VariableDeclaration */:
-      case 168 /* Parameter */:
-      case 207 /* BindingElement */:
+      case 260 /* VariableDeclaration */:
+      case 169 /* Parameter */:
+      case 208 /* BindingElement */:
         return true;
     }
     return false;
@@ -111668,40 +94357,40 @@ ${lanes.join("\n")}
   }
   function isObjectBindingOrAssignmentPattern(node) {
     switch (node.kind) {
-      case 205 /* ObjectBindingPattern */:
-      case 209 /* ObjectLiteralExpression */:
+      case 206 /* ObjectBindingPattern */:
+      case 210 /* ObjectLiteralExpression */:
         return true;
     }
     return false;
   }
   function isObjectBindingOrAssignmentElement(node) {
     switch (node.kind) {
-      case 207 /* BindingElement */:
-      case 302 /* PropertyAssignment */:
-      case 303 /* ShorthandPropertyAssignment */:
-      case 304 /* SpreadAssignment */:
+      case 208 /* BindingElement */:
+      case 303 /* PropertyAssignment */:
+      case 304 /* ShorthandPropertyAssignment */:
+      case 305 /* SpreadAssignment */:
         return true;
     }
     return false;
   }
   function isArrayBindingOrAssignmentPattern(node) {
     switch (node.kind) {
-      case 206 /* ArrayBindingPattern */:
-      case 208 /* ArrayLiteralExpression */:
+      case 207 /* ArrayBindingPattern */:
+      case 209 /* ArrayLiteralExpression */:
         return true;
     }
     return false;
   }
   function isArrayBindingOrAssignmentElement(node) {
     switch (node.kind) {
-      case 207 /* BindingElement */:
-      case 231 /* OmittedExpression */:
-      case 229 /* SpreadElement */:
-      case 208 /* ArrayLiteralExpression */:
-      case 209 /* ObjectLiteralExpression */:
+      case 208 /* BindingElement */:
+      case 232 /* OmittedExpression */:
+      case 230 /* SpreadElement */:
+      case 209 /* ArrayLiteralExpression */:
+      case 210 /* ObjectLiteralExpression */:
       case 80 /* Identifier */:
-      case 210 /* PropertyAccessExpression */:
-      case 211 /* ElementAccessExpression */:
+      case 211 /* PropertyAccessExpression */:
+      case 212 /* ElementAccessExpression */:
         return true;
     }
     return isAssignmentExpression(
@@ -111712,50 +94401,53 @@ ${lanes.join("\n")}
   }
   function isPropertyAccessOrQualifiedNameOrImportTypeNode(node) {
     const kind = node.kind;
-    return kind === 210 /* PropertyAccessExpression */ || kind === 165 /* QualifiedName */ || kind === 204 /* ImportType */;
+    return kind === 211 /* PropertyAccessExpression */ || kind === 166 /* QualifiedName */ || kind === 205 /* ImportType */;
   }
   function isPropertyAccessOrQualifiedName(node) {
     const kind = node.kind;
-    return kind === 210 /* PropertyAccessExpression */ || kind === 165 /* QualifiedName */;
+    return kind === 211 /* PropertyAccessExpression */ || kind === 166 /* QualifiedName */;
+  }
+  function isCallLikeOrFunctionLikeExpression(node) {
+    return isCallLikeExpression(node) || isFunctionExpressionOrArrowFunction(node);
   }
   function isCallLikeExpression(node) {
     switch (node.kind) {
-      case 285 /* JsxOpeningElement */:
-      case 284 /* JsxSelfClosingElement */:
-      case 212 /* CallExpression */:
-      case 213 /* NewExpression */:
-      case 214 /* TaggedTemplateExpression */:
-      case 169 /* Decorator */:
+      case 286 /* JsxOpeningElement */:
+      case 285 /* JsxSelfClosingElement */:
+      case 213 /* CallExpression */:
+      case 214 /* NewExpression */:
+      case 215 /* TaggedTemplateExpression */:
+      case 170 /* Decorator */:
         return true;
       default:
         return false;
     }
   }
   function isCallOrNewExpression(node) {
-    return node.kind === 212 /* CallExpression */ || node.kind === 213 /* NewExpression */;
+    return node.kind === 213 /* CallExpression */ || node.kind === 214 /* NewExpression */;
   }
   function isTemplateLiteral(node) {
     const kind = node.kind;
-    return kind === 227 /* TemplateExpression */ || kind === 15 /* NoSubstitutionTemplateLiteral */;
+    return kind === 228 /* TemplateExpression */ || kind === 15 /* NoSubstitutionTemplateLiteral */;
   }
   function isLeftHandSideExpression(node) {
     return isLeftHandSideExpressionKind(skipPartiallyEmittedExpressions(node).kind);
   }
   function isLeftHandSideExpressionKind(kind) {
     switch (kind) {
-      case 210 /* PropertyAccessExpression */:
-      case 211 /* ElementAccessExpression */:
-      case 213 /* NewExpression */:
-      case 212 /* CallExpression */:
-      case 283 /* JsxElement */:
-      case 284 /* JsxSelfClosingElement */:
-      case 287 /* JsxFragment */:
-      case 214 /* TaggedTemplateExpression */:
-      case 208 /* ArrayLiteralExpression */:
-      case 216 /* ParenthesizedExpression */:
-      case 209 /* ObjectLiteralExpression */:
-      case 230 /* ClassExpression */:
-      case 217 /* FunctionExpression */:
+      case 211 /* PropertyAccessExpression */:
+      case 212 /* ElementAccessExpression */:
+      case 214 /* NewExpression */:
+      case 213 /* CallExpression */:
+      case 284 /* JsxElement */:
+      case 285 /* JsxSelfClosingElement */:
+      case 288 /* JsxFragment */:
+      case 215 /* TaggedTemplateExpression */:
+      case 209 /* ArrayLiteralExpression */:
+      case 217 /* ParenthesizedExpression */:
+      case 210 /* ObjectLiteralExpression */:
+      case 231 /* ClassExpression */:
+      case 218 /* FunctionExpression */:
       case 80 /* Identifier */:
       case 81 /* PrivateIdentifier */:
       case 14 /* RegularExpressionLiteral */:
@@ -111763,17 +94455,17 @@ ${lanes.join("\n")}
       case 10 /* BigIntLiteral */:
       case 11 /* StringLiteral */:
       case 15 /* NoSubstitutionTemplateLiteral */:
-      case 227 /* TemplateExpression */:
+      case 228 /* TemplateExpression */:
       case 97 /* FalseKeyword */:
       case 106 /* NullKeyword */:
       case 110 /* ThisKeyword */:
       case 112 /* TrueKeyword */:
       case 108 /* SuperKeyword */:
-      case 234 /* NonNullExpression */:
-      case 232 /* ExpressionWithTypeArguments */:
-      case 235 /* MetaProperty */:
+      case 235 /* NonNullExpression */:
+      case 233 /* ExpressionWithTypeArguments */:
+      case 236 /* MetaProperty */:
       case 102 /* ImportKeyword */:
-      case 281 /* MissingDeclaration */:
+      case 282 /* MissingDeclaration */:
         return true;
       default:
         return false;
@@ -111784,13 +94476,13 @@ ${lanes.join("\n")}
   }
   function isUnaryExpressionKind(kind) {
     switch (kind) {
-      case 223 /* PrefixUnaryExpression */:
-      case 224 /* PostfixUnaryExpression */:
-      case 219 /* DeleteExpression */:
-      case 220 /* TypeOfExpression */:
-      case 221 /* VoidExpression */:
-      case 222 /* AwaitExpression */:
-      case 215 /* TypeAssertionExpression */:
+      case 224 /* PrefixUnaryExpression */:
+      case 225 /* PostfixUnaryExpression */:
+      case 220 /* DeleteExpression */:
+      case 221 /* TypeOfExpression */:
+      case 222 /* VoidExpression */:
+      case 223 /* AwaitExpression */:
+      case 216 /* TypeAssertionExpression */:
         return true;
       default:
         return isLeftHandSideExpressionKind(kind);
@@ -111798,9 +94490,9 @@ ${lanes.join("\n")}
   }
   function isUnaryExpressionWithWrite(expr) {
     switch (expr.kind) {
-      case 224 /* PostfixUnaryExpression */:
+      case 225 /* PostfixUnaryExpression */:
         return true;
-      case 223 /* PrefixUnaryExpression */:
+      case 224 /* PrefixUnaryExpression */:
         return expr.operator === 46 /* PlusPlusToken */ || expr.operator === 47 /* MinusMinusToken */;
       default:
         return false;
@@ -111811,7 +94503,7 @@ ${lanes.join("\n")}
       case 106 /* NullKeyword */:
       case 112 /* TrueKeyword */:
       case 97 /* FalseKeyword */:
-      case 223 /* PrefixUnaryExpression */:
+      case 224 /* PrefixUnaryExpression */:
         return true;
       default:
         return isLiteralExpression(node);
@@ -111822,16 +94514,16 @@ ${lanes.join("\n")}
   }
   function isExpressionKind(kind) {
     switch (kind) {
-      case 226 /* ConditionalExpression */:
-      case 228 /* YieldExpression */:
-      case 218 /* ArrowFunction */:
-      case 225 /* BinaryExpression */:
-      case 229 /* SpreadElement */:
-      case 233 /* AsExpression */:
-      case 231 /* OmittedExpression */:
-      case 360 /* CommaListExpression */:
-      case 359 /* PartiallyEmittedExpression */:
-      case 237 /* SatisfiesExpression */:
+      case 227 /* ConditionalExpression */:
+      case 229 /* YieldExpression */:
+      case 219 /* ArrowFunction */:
+      case 226 /* BinaryExpression */:
+      case 230 /* SpreadElement */:
+      case 234 /* AsExpression */:
+      case 232 /* OmittedExpression */:
+      case 361 /* CommaListExpression */:
+      case 360 /* PartiallyEmittedExpression */:
+      case 238 /* SatisfiesExpression */:
         return true;
       default:
         return isUnaryExpressionKind(kind);
@@ -111839,20 +94531,20 @@ ${lanes.join("\n")}
   }
   function isAssertionExpression(node) {
     const kind = node.kind;
-    return kind === 215 /* TypeAssertionExpression */ || kind === 233 /* AsExpression */;
+    return kind === 216 /* TypeAssertionExpression */ || kind === 234 /* AsExpression */;
   }
   function isNotEmittedOrPartiallyEmittedNode(node) {
     return isNotEmittedStatement(node) || isPartiallyEmittedExpression(node);
   }
   function isIterationStatement(node, lookInLabeledStatements) {
     switch (node.kind) {
-      case 247 /* ForStatement */:
-      case 248 /* ForInStatement */:
-      case 249 /* ForOfStatement */:
-      case 245 /* DoStatement */:
-      case 246 /* WhileStatement */:
+      case 248 /* ForStatement */:
+      case 249 /* ForInStatement */:
+      case 250 /* ForOfStatement */:
+      case 246 /* DoStatement */:
+      case 247 /* WhileStatement */:
         return true;
-      case 255 /* LabeledStatement */:
+      case 256 /* LabeledStatement */:
         return lookInLabeledStatements && isIterationStatement(node.statement, lookInLabeledStatements);
     }
     return false;
@@ -111864,13 +94556,13 @@ ${lanes.join("\n")}
     return some(statements, isScopeMarker);
   }
   function needsScopeMarker(result) {
-    return !isAnyImportOrReExport(result) && !isExportAssignment(result) && !hasSyntacticModifier(result, 1 /* Export */) && !isAmbientModule(result);
+    return !isAnyImportOrReExport(result) && !isExportAssignment(result) && !hasSyntacticModifier(result, 32 /* Export */) && !isAmbientModule(result);
   }
   function isExternalModuleIndicator(result) {
-    return isAnyImportOrReExport(result) || isExportAssignment(result) || hasSyntacticModifier(result, 1 /* Export */);
+    return isAnyImportOrReExport(result) || isExportAssignment(result) || hasSyntacticModifier(result, 32 /* Export */);
   }
   function isForInOrOfStatement(node) {
-    return node.kind === 248 /* ForInStatement */ || node.kind === 249 /* ForOfStatement */;
+    return node.kind === 249 /* ForInStatement */ || node.kind === 250 /* ForOfStatement */;
   }
   function isConciseBody(node) {
     return isBlock(node) || isExpression(node);
@@ -111883,89 +94575,89 @@ ${lanes.join("\n")}
   }
   function isModuleBody(node) {
     const kind = node.kind;
-    return kind === 267 /* ModuleBlock */ || kind === 266 /* ModuleDeclaration */ || kind === 80 /* Identifier */;
+    return kind === 268 /* ModuleBlock */ || kind === 267 /* ModuleDeclaration */ || kind === 80 /* Identifier */;
   }
   function isNamespaceBody(node) {
     const kind = node.kind;
-    return kind === 267 /* ModuleBlock */ || kind === 266 /* ModuleDeclaration */;
+    return kind === 268 /* ModuleBlock */ || kind === 267 /* ModuleDeclaration */;
   }
   function isJSDocNamespaceBody(node) {
     const kind = node.kind;
-    return kind === 80 /* Identifier */ || kind === 266 /* ModuleDeclaration */;
+    return kind === 80 /* Identifier */ || kind === 267 /* ModuleDeclaration */;
   }
   function isNamedImportBindings(node) {
     const kind = node.kind;
-    return kind === 274 /* NamedImports */ || kind === 273 /* NamespaceImport */;
+    return kind === 275 /* NamedImports */ || kind === 274 /* NamespaceImport */;
   }
   function isModuleOrEnumDeclaration(node) {
-    return node.kind === 266 /* ModuleDeclaration */ || node.kind === 265 /* EnumDeclaration */;
+    return node.kind === 267 /* ModuleDeclaration */ || node.kind === 266 /* EnumDeclaration */;
   }
   function canHaveSymbol(node) {
     switch (node.kind) {
-      case 218 /* ArrowFunction */:
-      case 225 /* BinaryExpression */:
-      case 207 /* BindingElement */:
-      case 212 /* CallExpression */:
-      case 178 /* CallSignature */:
-      case 262 /* ClassDeclaration */:
-      case 230 /* ClassExpression */:
-      case 174 /* ClassStaticBlockDeclaration */:
-      case 175 /* Constructor */:
-      case 184 /* ConstructorType */:
-      case 179 /* ConstructSignature */:
-      case 211 /* ElementAccessExpression */:
-      case 265 /* EnumDeclaration */:
-      case 305 /* EnumMember */:
-      case 276 /* ExportAssignment */:
-      case 277 /* ExportDeclaration */:
-      case 280 /* ExportSpecifier */:
-      case 261 /* FunctionDeclaration */:
-      case 217 /* FunctionExpression */:
-      case 183 /* FunctionType */:
-      case 176 /* GetAccessor */:
+      case 219 /* ArrowFunction */:
+      case 226 /* BinaryExpression */:
+      case 208 /* BindingElement */:
+      case 213 /* CallExpression */:
+      case 179 /* CallSignature */:
+      case 263 /* ClassDeclaration */:
+      case 231 /* ClassExpression */:
+      case 175 /* ClassStaticBlockDeclaration */:
+      case 176 /* Constructor */:
+      case 185 /* ConstructorType */:
+      case 180 /* ConstructSignature */:
+      case 212 /* ElementAccessExpression */:
+      case 266 /* EnumDeclaration */:
+      case 306 /* EnumMember */:
+      case 277 /* ExportAssignment */:
+      case 278 /* ExportDeclaration */:
+      case 281 /* ExportSpecifier */:
+      case 262 /* FunctionDeclaration */:
+      case 218 /* FunctionExpression */:
+      case 184 /* FunctionType */:
+      case 177 /* GetAccessor */:
       case 80 /* Identifier */:
-      case 272 /* ImportClause */:
-      case 270 /* ImportEqualsDeclaration */:
-      case 275 /* ImportSpecifier */:
-      case 180 /* IndexSignature */:
-      case 263 /* InterfaceDeclaration */:
-      case 344 /* JSDocCallbackTag */:
-      case 346 /* JSDocEnumTag */:
-      case 323 /* JSDocFunctionType */:
-      case 347 /* JSDocParameterTag */:
-      case 354 /* JSDocPropertyTag */:
-      case 329 /* JSDocSignature */:
-      case 352 /* JSDocTypedefTag */:
-      case 328 /* JSDocTypeLiteral */:
-      case 290 /* JsxAttribute */:
-      case 291 /* JsxAttributes */:
-      case 292 /* JsxSpreadAttribute */:
-      case 199 /* MappedType */:
-      case 173 /* MethodDeclaration */:
-      case 172 /* MethodSignature */:
-      case 266 /* ModuleDeclaration */:
-      case 201 /* NamedTupleMember */:
-      case 279 /* NamespaceExport */:
-      case 269 /* NamespaceExportDeclaration */:
-      case 273 /* NamespaceImport */:
-      case 213 /* NewExpression */:
+      case 273 /* ImportClause */:
+      case 271 /* ImportEqualsDeclaration */:
+      case 276 /* ImportSpecifier */:
+      case 181 /* IndexSignature */:
+      case 264 /* InterfaceDeclaration */:
+      case 345 /* JSDocCallbackTag */:
+      case 347 /* JSDocEnumTag */:
+      case 324 /* JSDocFunctionType */:
+      case 348 /* JSDocParameterTag */:
+      case 355 /* JSDocPropertyTag */:
+      case 330 /* JSDocSignature */:
+      case 353 /* JSDocTypedefTag */:
+      case 329 /* JSDocTypeLiteral */:
+      case 291 /* JsxAttribute */:
+      case 292 /* JsxAttributes */:
+      case 293 /* JsxSpreadAttribute */:
+      case 200 /* MappedType */:
+      case 174 /* MethodDeclaration */:
+      case 173 /* MethodSignature */:
+      case 267 /* ModuleDeclaration */:
+      case 202 /* NamedTupleMember */:
+      case 280 /* NamespaceExport */:
+      case 270 /* NamespaceExportDeclaration */:
+      case 274 /* NamespaceImport */:
+      case 214 /* NewExpression */:
       case 15 /* NoSubstitutionTemplateLiteral */:
       case 9 /* NumericLiteral */:
-      case 209 /* ObjectLiteralExpression */:
-      case 168 /* Parameter */:
-      case 210 /* PropertyAccessExpression */:
-      case 302 /* PropertyAssignment */:
-      case 171 /* PropertyDeclaration */:
-      case 170 /* PropertySignature */:
-      case 177 /* SetAccessor */:
-      case 303 /* ShorthandPropertyAssignment */:
-      case 311 /* SourceFile */:
-      case 304 /* SpreadAssignment */:
+      case 210 /* ObjectLiteralExpression */:
+      case 169 /* Parameter */:
+      case 211 /* PropertyAccessExpression */:
+      case 303 /* PropertyAssignment */:
+      case 172 /* PropertyDeclaration */:
+      case 171 /* PropertySignature */:
+      case 178 /* SetAccessor */:
+      case 304 /* ShorthandPropertyAssignment */:
+      case 312 /* SourceFile */:
+      case 305 /* SpreadAssignment */:
       case 11 /* StringLiteral */:
-      case 264 /* TypeAliasDeclaration */:
-      case 186 /* TypeLiteral */:
-      case 167 /* TypeParameter */:
-      case 259 /* VariableDeclaration */:
+      case 265 /* TypeAliasDeclaration */:
+      case 187 /* TypeLiteral */:
+      case 168 /* TypeParameter */:
+      case 260 /* VariableDeclaration */:
         return true;
       default:
         return false;
@@ -111973,53 +94665,53 @@ ${lanes.join("\n")}
   }
   function canHaveLocals(node) {
     switch (node.kind) {
-      case 218 /* ArrowFunction */:
-      case 240 /* Block */:
-      case 178 /* CallSignature */:
-      case 268 /* CaseBlock */:
-      case 298 /* CatchClause */:
-      case 174 /* ClassStaticBlockDeclaration */:
-      case 193 /* ConditionalType */:
-      case 175 /* Constructor */:
-      case 184 /* ConstructorType */:
-      case 179 /* ConstructSignature */:
-      case 247 /* ForStatement */:
-      case 248 /* ForInStatement */:
-      case 249 /* ForOfStatement */:
-      case 261 /* FunctionDeclaration */:
-      case 217 /* FunctionExpression */:
-      case 183 /* FunctionType */:
-      case 176 /* GetAccessor */:
-      case 180 /* IndexSignature */:
-      case 344 /* JSDocCallbackTag */:
-      case 346 /* JSDocEnumTag */:
-      case 323 /* JSDocFunctionType */:
-      case 329 /* JSDocSignature */:
-      case 352 /* JSDocTypedefTag */:
-      case 199 /* MappedType */:
-      case 173 /* MethodDeclaration */:
-      case 172 /* MethodSignature */:
-      case 266 /* ModuleDeclaration */:
-      case 177 /* SetAccessor */:
-      case 311 /* SourceFile */:
-      case 264 /* TypeAliasDeclaration */:
+      case 219 /* ArrowFunction */:
+      case 241 /* Block */:
+      case 179 /* CallSignature */:
+      case 269 /* CaseBlock */:
+      case 299 /* CatchClause */:
+      case 175 /* ClassStaticBlockDeclaration */:
+      case 194 /* ConditionalType */:
+      case 176 /* Constructor */:
+      case 185 /* ConstructorType */:
+      case 180 /* ConstructSignature */:
+      case 248 /* ForStatement */:
+      case 249 /* ForInStatement */:
+      case 250 /* ForOfStatement */:
+      case 262 /* FunctionDeclaration */:
+      case 218 /* FunctionExpression */:
+      case 184 /* FunctionType */:
+      case 177 /* GetAccessor */:
+      case 181 /* IndexSignature */:
+      case 345 /* JSDocCallbackTag */:
+      case 347 /* JSDocEnumTag */:
+      case 324 /* JSDocFunctionType */:
+      case 330 /* JSDocSignature */:
+      case 353 /* JSDocTypedefTag */:
+      case 200 /* MappedType */:
+      case 174 /* MethodDeclaration */:
+      case 173 /* MethodSignature */:
+      case 267 /* ModuleDeclaration */:
+      case 178 /* SetAccessor */:
+      case 312 /* SourceFile */:
+      case 265 /* TypeAliasDeclaration */:
         return true;
       default:
         return false;
     }
   }
   function isDeclarationKind(kind) {
-    return kind === 218 /* ArrowFunction */ || kind === 207 /* BindingElement */ || kind === 262 /* ClassDeclaration */ || kind === 230 /* ClassExpression */ || kind === 174 /* ClassStaticBlockDeclaration */ || kind === 175 /* Constructor */ || kind === 265 /* EnumDeclaration */ || kind === 305 /* EnumMember */ || kind === 280 /* ExportSpecifier */ || kind === 261 /* FunctionDeclaration */ || kind === 217 /* FunctionExpression */ || kind === 176 /* GetAccessor */ || kind === 272 /* ImportClause */ || kind === 270 /* ImportEqualsDeclaration */ || kind === 275 /* ImportSpecifier */ || kind === 263 /* InterfaceDeclaration */ || kind === 290 /* JsxAttribute */ || kind === 173 /* MethodDeclaration */ || kind === 172 /* MethodSignature */ || kind === 266 /* ModuleDeclaration */ || kind === 269 /* NamespaceExportDeclaration */ || kind === 273 /* NamespaceImport */ || kind === 279 /* NamespaceExport */ || kind === 168 /* Parameter */ || kind === 302 /* PropertyAssignment */ || kind === 171 /* PropertyDeclaration */ || kind === 170 /* PropertySignature */ || kind === 177 /* SetAccessor */ || kind === 303 /* ShorthandPropertyAssignment */ || kind === 264 /* TypeAliasDeclaration */ || kind === 167 /* TypeParameter */ || kind === 259 /* VariableDeclaration */ || kind === 352 /* JSDocTypedefTag */ || kind === 344 /* JSDocCallbackTag */ || kind === 354 /* JSDocPropertyTag */;
+    return kind === 219 /* ArrowFunction */ || kind === 208 /* BindingElement */ || kind === 263 /* ClassDeclaration */ || kind === 231 /* ClassExpression */ || kind === 175 /* ClassStaticBlockDeclaration */ || kind === 176 /* Constructor */ || kind === 266 /* EnumDeclaration */ || kind === 306 /* EnumMember */ || kind === 281 /* ExportSpecifier */ || kind === 262 /* FunctionDeclaration */ || kind === 218 /* FunctionExpression */ || kind === 177 /* GetAccessor */ || kind === 273 /* ImportClause */ || kind === 271 /* ImportEqualsDeclaration */ || kind === 276 /* ImportSpecifier */ || kind === 264 /* InterfaceDeclaration */ || kind === 291 /* JsxAttribute */ || kind === 174 /* MethodDeclaration */ || kind === 173 /* MethodSignature */ || kind === 267 /* ModuleDeclaration */ || kind === 270 /* NamespaceExportDeclaration */ || kind === 274 /* NamespaceImport */ || kind === 280 /* NamespaceExport */ || kind === 169 /* Parameter */ || kind === 303 /* PropertyAssignment */ || kind === 172 /* PropertyDeclaration */ || kind === 171 /* PropertySignature */ || kind === 178 /* SetAccessor */ || kind === 304 /* ShorthandPropertyAssignment */ || kind === 265 /* TypeAliasDeclaration */ || kind === 168 /* TypeParameter */ || kind === 260 /* VariableDeclaration */ || kind === 353 /* JSDocTypedefTag */ || kind === 345 /* JSDocCallbackTag */ || kind === 355 /* JSDocPropertyTag */;
   }
   function isDeclarationStatementKind(kind) {
-    return kind === 261 /* FunctionDeclaration */ || kind === 281 /* MissingDeclaration */ || kind === 262 /* ClassDeclaration */ || kind === 263 /* InterfaceDeclaration */ || kind === 264 /* TypeAliasDeclaration */ || kind === 265 /* EnumDeclaration */ || kind === 266 /* ModuleDeclaration */ || kind === 271 /* ImportDeclaration */ || kind === 270 /* ImportEqualsDeclaration */ || kind === 277 /* ExportDeclaration */ || kind === 276 /* ExportAssignment */ || kind === 269 /* NamespaceExportDeclaration */;
+    return kind === 262 /* FunctionDeclaration */ || kind === 282 /* MissingDeclaration */ || kind === 263 /* ClassDeclaration */ || kind === 264 /* InterfaceDeclaration */ || kind === 265 /* TypeAliasDeclaration */ || kind === 266 /* EnumDeclaration */ || kind === 267 /* ModuleDeclaration */ || kind === 272 /* ImportDeclaration */ || kind === 271 /* ImportEqualsDeclaration */ || kind === 278 /* ExportDeclaration */ || kind === 277 /* ExportAssignment */ || kind === 270 /* NamespaceExportDeclaration */;
   }
   function isStatementKindButNotDeclarationKind(kind) {
-    return kind === 251 /* BreakStatement */ || kind === 250 /* ContinueStatement */ || kind === 258 /* DebuggerStatement */ || kind === 245 /* DoStatement */ || kind === 243 /* ExpressionStatement */ || kind === 241 /* EmptyStatement */ || kind === 248 /* ForInStatement */ || kind === 249 /* ForOfStatement */ || kind === 247 /* ForStatement */ || kind === 244 /* IfStatement */ || kind === 255 /* LabeledStatement */ || kind === 252 /* ReturnStatement */ || kind === 254 /* SwitchStatement */ || kind === 256 /* ThrowStatement */ || kind === 257 /* TryStatement */ || kind === 242 /* VariableStatement */ || kind === 246 /* WhileStatement */ || kind === 253 /* WithStatement */ || kind === 358 /* NotEmittedStatement */;
+    return kind === 252 /* BreakStatement */ || kind === 251 /* ContinueStatement */ || kind === 259 /* DebuggerStatement */ || kind === 246 /* DoStatement */ || kind === 244 /* ExpressionStatement */ || kind === 242 /* EmptyStatement */ || kind === 249 /* ForInStatement */ || kind === 250 /* ForOfStatement */ || kind === 248 /* ForStatement */ || kind === 245 /* IfStatement */ || kind === 256 /* LabeledStatement */ || kind === 253 /* ReturnStatement */ || kind === 255 /* SwitchStatement */ || kind === 257 /* ThrowStatement */ || kind === 258 /* TryStatement */ || kind === 243 /* VariableStatement */ || kind === 247 /* WhileStatement */ || kind === 254 /* WithStatement */ || kind === 359 /* NotEmittedStatement */;
   }
   function isDeclaration(node) {
-    if (node.kind === 167 /* TypeParameter */) {
-      return node.parent && node.parent.kind !== 351 /* JSDocTemplateTag */ || isInJSFile(node);
+    if (node.kind === 168 /* TypeParameter */) {
+      return node.parent && node.parent.kind !== 352 /* JSDocTemplateTag */ || isInJSFile(node);
     }
     return isDeclarationKind(node.kind);
   }
@@ -112034,10 +94726,10 @@ ${lanes.join("\n")}
     return isStatementKindButNotDeclarationKind(kind) || isDeclarationStatementKind(kind) || isBlockStatement(node);
   }
   function isBlockStatement(node) {
-    if (node.kind !== 240 /* Block */)
+    if (node.kind !== 241 /* Block */)
       return false;
     if (node.parent !== void 0) {
-      if (node.parent.kind === 257 /* TryStatement */ || node.parent.kind === 298 /* CatchClause */) {
+      if (node.parent.kind === 258 /* TryStatement */ || node.parent.kind === 299 /* CatchClause */) {
         return false;
       }
     }
@@ -112045,50 +94737,50 @@ ${lanes.join("\n")}
   }
   function isStatementOrBlock(node) {
     const kind = node.kind;
-    return isStatementKindButNotDeclarationKind(kind) || isDeclarationStatementKind(kind) || kind === 240 /* Block */;
+    return isStatementKindButNotDeclarationKind(kind) || isDeclarationStatementKind(kind) || kind === 241 /* Block */;
   }
   function isModuleReference(node) {
     const kind = node.kind;
-    return kind === 282 /* ExternalModuleReference */ || kind === 165 /* QualifiedName */ || kind === 80 /* Identifier */;
+    return kind === 283 /* ExternalModuleReference */ || kind === 166 /* QualifiedName */ || kind === 80 /* Identifier */;
   }
   function isJsxTagNameExpression(node) {
     const kind = node.kind;
-    return kind === 110 /* ThisKeyword */ || kind === 80 /* Identifier */ || kind === 210 /* PropertyAccessExpression */ || kind === 294 /* JsxNamespacedName */;
+    return kind === 110 /* ThisKeyword */ || kind === 80 /* Identifier */ || kind === 211 /* PropertyAccessExpression */ || kind === 295 /* JsxNamespacedName */;
   }
   function isJsxChild(node) {
     const kind = node.kind;
-    return kind === 283 /* JsxElement */ || kind === 293 /* JsxExpression */ || kind === 284 /* JsxSelfClosingElement */ || kind === 12 /* JsxText */ || kind === 287 /* JsxFragment */;
+    return kind === 284 /* JsxElement */ || kind === 294 /* JsxExpression */ || kind === 285 /* JsxSelfClosingElement */ || kind === 12 /* JsxText */ || kind === 288 /* JsxFragment */;
   }
   function isJsxAttributeLike(node) {
     const kind = node.kind;
-    return kind === 290 /* JsxAttribute */ || kind === 292 /* JsxSpreadAttribute */;
+    return kind === 291 /* JsxAttribute */ || kind === 293 /* JsxSpreadAttribute */;
   }
   function isStringLiteralOrJsxExpression(node) {
     const kind = node.kind;
-    return kind === 11 /* StringLiteral */ || kind === 293 /* JsxExpression */;
+    return kind === 11 /* StringLiteral */ || kind === 294 /* JsxExpression */;
   }
   function isJsxOpeningLikeElement(node) {
     const kind = node.kind;
-    return kind === 285 /* JsxOpeningElement */ || kind === 284 /* JsxSelfClosingElement */;
+    return kind === 286 /* JsxOpeningElement */ || kind === 285 /* JsxSelfClosingElement */;
   }
   function isCaseOrDefaultClause(node) {
     const kind = node.kind;
-    return kind === 295 /* CaseClause */ || kind === 296 /* DefaultClause */;
+    return kind === 296 /* CaseClause */ || kind === 297 /* DefaultClause */;
   }
   function isJSDocNode(node) {
-    return node.kind >= 315 /* FirstJSDocNode */ && node.kind <= 356 /* LastJSDocNode */;
+    return node.kind >= 316 /* FirstJSDocNode */ && node.kind <= 357 /* LastJSDocNode */;
   }
   function isJSDocCommentContainingNode(node) {
-    return node.kind === 326 /* JSDoc */ || node.kind === 325 /* JSDocNamepathType */ || node.kind === 327 /* JSDocText */ || isJSDocLinkLike(node) || isJSDocTag(node) || isJSDocTypeLiteral(node) || isJSDocSignature(node);
+    return node.kind === 327 /* JSDoc */ || node.kind === 326 /* JSDocNamepathType */ || node.kind === 328 /* JSDocText */ || isJSDocLinkLike(node) || isJSDocTag(node) || isJSDocTypeLiteral(node) || isJSDocSignature(node);
   }
   function isJSDocTag(node) {
-    return node.kind >= 333 /* FirstJSDocTagNode */ && node.kind <= 356 /* LastJSDocTagNode */;
+    return node.kind >= 334 /* FirstJSDocTagNode */ && node.kind <= 357 /* LastJSDocTagNode */;
   }
   function isSetAccessor(node) {
-    return node.kind === 177 /* SetAccessor */;
+    return node.kind === 178 /* SetAccessor */;
   }
   function isGetAccessor(node) {
-    return node.kind === 176 /* GetAccessor */;
+    return node.kind === 177 /* GetAccessor */;
   }
   function hasJSDocNodes(node) {
     if (!canHaveJSDoc(node))
@@ -112104,22 +94796,22 @@ ${lanes.join("\n")}
   }
   function hasOnlyExpressionInitializer(node) {
     switch (node.kind) {
-      case 259 /* VariableDeclaration */:
-      case 168 /* Parameter */:
-      case 207 /* BindingElement */:
-      case 171 /* PropertyDeclaration */:
-      case 302 /* PropertyAssignment */:
-      case 305 /* EnumMember */:
+      case 260 /* VariableDeclaration */:
+      case 169 /* Parameter */:
+      case 208 /* BindingElement */:
+      case 172 /* PropertyDeclaration */:
+      case 303 /* PropertyAssignment */:
+      case 306 /* EnumMember */:
         return true;
       default:
         return false;
     }
   }
   function isObjectLiteralElement(node) {
-    return node.kind === 290 /* JsxAttribute */ || node.kind === 292 /* JsxSpreadAttribute */ || isObjectLiteralElementLike(node);
+    return node.kind === 291 /* JsxAttribute */ || node.kind === 293 /* JsxSpreadAttribute */ || isObjectLiteralElementLike(node);
   }
   function isTypeReferenceType(node) {
-    return node.kind === 182 /* TypeReference */ || node.kind === 232 /* ExpressionWithTypeArguments */;
+    return node.kind === 183 /* TypeReference */ || node.kind === 233 /* ExpressionWithTypeArguments */;
   }
   function guessIndentation(lines) {
     let indentation = MAX_SMI_X86;
@@ -112146,7 +94838,7 @@ ${lanes.join("\n")}
     return node.kind === 11 /* StringLiteral */ || node.kind === 15 /* NoSubstitutionTemplateLiteral */;
   }
   function isJSDocLinkLike(node) {
-    return node.kind === 330 /* JSDocLink */ || node.kind === 331 /* JSDocLinkCode */ || node.kind === 332 /* JSDocLinkPlain */;
+    return node.kind === 331 /* JSDocLink */ || node.kind === 332 /* JSDocLinkCode */ || node.kind === 333 /* JSDocLinkPlain */;
   }
   function hasRestParameter(s) {
     const last2 = lastOrUndefined(s.parameters);
@@ -112154,7 +94846,7 @@ ${lanes.join("\n")}
   }
   function isRestParameter(node) {
     const type = isJSDocParameterTag(node) ? node.typeExpression && node.typeExpression.type : node.type;
-    return node.dotDotDotToken !== void 0 || !!type && type.kind === 324 /* JSDocVariadicType */;
+    return node.dotDotDotToken !== void 0 || !!type && type.kind === 325 /* JSDocVariadicType */;
   }
   var unchangedTextChangeRange, supportedLocaleDirectories, MAX_SMI_X86;
   var init_utilitiesPublic = __esm({
@@ -112289,26 +94981,6 @@ ${lanes.join("\n")}
   function getFullWidth(node) {
     return node.end - node.pos;
   }
-  function getResolvedModule(sourceFile, moduleNameText, mode) {
-    var _a, _b;
-    return (_b = (_a = sourceFile == null ? void 0 : sourceFile.resolvedModules) == null ? void 0 : _a.get(moduleNameText, mode)) == null ? void 0 : _b.resolvedModule;
-  }
-  function setResolvedModule(sourceFile, moduleNameText, resolvedModule, mode) {
-    if (!sourceFile.resolvedModules) {
-      sourceFile.resolvedModules = createModeAwareCache();
-    }
-    sourceFile.resolvedModules.set(moduleNameText, mode, resolvedModule);
-  }
-  function setResolvedTypeReferenceDirective(sourceFile, typeReferenceDirectiveName, resolvedTypeReferenceDirective, mode) {
-    if (!sourceFile.resolvedTypeReferenceDirectiveNames) {
-      sourceFile.resolvedTypeReferenceDirectiveNames = createModeAwareCache();
-    }
-    sourceFile.resolvedTypeReferenceDirectiveNames.set(typeReferenceDirectiveName, mode, resolvedTypeReferenceDirective);
-  }
-  function getResolvedTypeReferenceDirective(sourceFile, typeReferenceDirectiveName, mode) {
-    var _a, _b;
-    return (_b = (_a = sourceFile == null ? void 0 : sourceFile.resolvedTypeReferenceDirectiveNames) == null ? void 0 : _a.get(typeReferenceDirectiveName, mode)) == null ? void 0 : _b.resolvedTypeReferenceDirective;
-  }
   function projectReferenceIsEqualTo(oldRef, newRef) {
     return oldRef.path === newRef.path && !oldRef.prepend === !newRef.prepend && !oldRef.circular === !newRef.circular;
   }
@@ -112316,14 +94988,14 @@ ${lanes.join("\n")}
     return oldResolution === newResolution || oldResolution.resolvedModule === newResolution.resolvedModule || !!oldResolution.resolvedModule && !!newResolution.resolvedModule && oldResolution.resolvedModule.isExternalLibraryImport === newResolution.resolvedModule.isExternalLibraryImport && oldResolution.resolvedModule.extension === newResolution.resolvedModule.extension && oldResolution.resolvedModule.resolvedFileName === newResolution.resolvedModule.resolvedFileName && oldResolution.resolvedModule.originalPath === newResolution.resolvedModule.originalPath && packageIdIsEqual(oldResolution.resolvedModule.packageId, newResolution.resolvedModule.packageId) && oldResolution.node10Result === newResolution.node10Result;
   }
   function createModuleNotFoundChain(sourceFile, host, moduleReference, mode, packageName) {
-    var _a, _b;
-    const node10Result = (_b = (_a = sourceFile.resolvedModules) == null ? void 0 : _a.get(moduleReference, mode)) == null ? void 0 : _b.node10Result;
+    var _a;
+    const node10Result = (_a = host.getResolvedModule(sourceFile, moduleReference, mode)) == null ? void 0 : _a.node10Result;
     const result = node10Result ? chainDiagnosticMessages(
       /*details*/
       void 0,
       Diagnostics.There_are_types_at_0_but_this_result_could_not_be_resolved_when_respecting_package_json_exports_The_1_library_may_need_to_update_its_package_json_or_typings,
       node10Result,
-      node10Result.indexOf(nodeModulesPathPart + "@types/") > -1 ? `@types/${mangleScopedPackageName(packageName)}` : packageName
+      node10Result.includes(nodeModulesPathPart + "@types/") ? `@types/${mangleScopedPackageName(packageName)}` : packageName
     ) : host.typesPackageExists(packageName) ? chainDiagnosticMessages(
       /*details*/
       void 0,
@@ -112359,14 +95031,14 @@ ${lanes.join("\n")}
   function typeDirectiveIsEqualTo(oldResolution, newResolution) {
     return oldResolution === newResolution || oldResolution.resolvedTypeReferenceDirective === newResolution.resolvedTypeReferenceDirective || !!oldResolution.resolvedTypeReferenceDirective && !!newResolution.resolvedTypeReferenceDirective && oldResolution.resolvedTypeReferenceDirective.resolvedFileName === newResolution.resolvedTypeReferenceDirective.resolvedFileName && !!oldResolution.resolvedTypeReferenceDirective.primary === !!newResolution.resolvedTypeReferenceDirective.primary && oldResolution.resolvedTypeReferenceDirective.originalPath === newResolution.resolvedTypeReferenceDirective.originalPath;
   }
-  function hasChangesInResolutions(names, newSourceFile, newResolutions, oldResolutions, comparer, nameAndModeGetter) {
+  function hasChangesInResolutions(names, newSourceFile, newResolutions, getOldResolution, comparer, nameAndModeGetter) {
     Debug.assert(names.length === newResolutions.length);
     for (let i = 0; i < names.length; i++) {
       const newResolution = newResolutions[i];
       const entry = names[i];
       const name = nameAndModeGetter.getName(entry);
       const mode = nameAndModeGetter.getMode(entry, newSourceFile);
-      const oldResolution = oldResolutions && oldResolutions.get(name, mode);
+      const oldResolution = getOldResolution(name, mode);
       const changed = oldResolution ? !newResolution || !comparer(oldResolution, newResolution) : newResolution;
       if (changed) {
         return true;
@@ -112376,19 +95048,19 @@ ${lanes.join("\n")}
   }
   function containsParseError(node) {
     aggregateChildData(node);
-    return (node.flags & 524288 /* ThisNodeOrAnySubNodesHasError */) !== 0;
+    return (node.flags & 1048576 /* ThisNodeOrAnySubNodesHasError */) !== 0;
   }
   function aggregateChildData(node) {
-    if (!(node.flags & 1048576 /* HasAggregatedChildData */)) {
-      const thisNodeOrAnySubNodesHasError = (node.flags & 131072 /* ThisNodeHasError */) !== 0 || forEachChild(node, containsParseError);
+    if (!(node.flags & 2097152 /* HasAggregatedChildData */)) {
+      const thisNodeOrAnySubNodesHasError = (node.flags & 262144 /* ThisNodeHasError */) !== 0 || forEachChild(node, containsParseError);
       if (thisNodeOrAnySubNodesHasError) {
-        node.flags |= 524288 /* ThisNodeOrAnySubNodesHasError */;
+        node.flags |= 1048576 /* ThisNodeOrAnySubNodesHasError */;
       }
-      node.flags |= 1048576 /* HasAggregatedChildData */;
+      node.flags |= 2097152 /* HasAggregatedChildData */;
     }
   }
   function getSourceFileOfNode(node) {
-    while (node && node.kind !== 311 /* SourceFile */) {
+    while (node && node.kind !== 312 /* SourceFile */) {
       node = node.parent;
     }
     return node;
@@ -112401,11 +95073,11 @@ ${lanes.join("\n")}
   }
   function isStatementWithLocals(node) {
     switch (node.kind) {
-      case 240 /* Block */:
-      case 268 /* CaseBlock */:
-      case 247 /* ForStatement */:
-      case 248 /* ForInStatement */:
-      case 249 /* ForOfStatement */:
+      case 241 /* Block */:
+      case 269 /* CaseBlock */:
+      case 248 /* ForStatement */:
+      case 249 /* ForInStatement */:
+      case 250 /* ForOfStatement */:
         return true;
     }
     return false;
@@ -112564,7 +95236,7 @@ ${lanes.join("\n")}
     if (includeJsDoc && hasJSDocNodes(node)) {
       return getTokenPosOfNode(node.jsDoc[0], sourceFile);
     }
-    if (node.kind === 357 /* SyntaxList */ && node._children.length > 0) {
+    if (node.kind === 358 /* SyntaxList */ && node._children.length > 0) {
       return getTokenPosOfNode(node._children[0], sourceFile, includeJsDoc);
     }
     return skipTrivia(
@@ -112599,7 +95271,7 @@ ${lanes.join("\n")}
     }
     let text = sourceText.substring(includeTrivia ? node.pos : skipTrivia(sourceText, node.pos), node.end);
     if (isJSDocTypeExpressionOrChild(node)) {
-      text = text.split(/\r\n|\n|\r/).map((line) => trimStringStart(line.replace(/^\s*\*/, ""))).join("\n");
+      text = text.split(/\r\n|\n|\r/).map((line) => line.replace(/^\s*\*/, "").trimStart()).join("\n");
     }
     return text;
   }
@@ -112620,402 +95292,6 @@ ${lanes.join("\n")}
     const emitNode = node.emitNode;
     return emitNode && emitNode.internalFlags || 0;
   }
-  function getScriptTargetFeatures() {
-    return new Map(Object.entries({
-      Array: new Map(Object.entries({
-        es2015: [
-          "find",
-          "findIndex",
-          "fill",
-          "copyWithin",
-          "entries",
-          "keys",
-          "values"
-        ],
-        es2016: [
-          "includes"
-        ],
-        es2019: [
-          "flat",
-          "flatMap"
-        ],
-        es2022: [
-          "at"
-        ],
-        es2023: [
-          "findLastIndex",
-          "findLast"
-        ]
-      })),
-      Iterator: new Map(Object.entries({
-        es2015: emptyArray
-      })),
-      AsyncIterator: new Map(Object.entries({
-        es2015: emptyArray
-      })),
-      Atomics: new Map(Object.entries({
-        es2017: emptyArray
-      })),
-      SharedArrayBuffer: new Map(Object.entries({
-        es2017: emptyArray
-      })),
-      AsyncIterable: new Map(Object.entries({
-        es2018: emptyArray
-      })),
-      AsyncIterableIterator: new Map(Object.entries({
-        es2018: emptyArray
-      })),
-      AsyncGenerator: new Map(Object.entries({
-        es2018: emptyArray
-      })),
-      AsyncGeneratorFunction: new Map(Object.entries({
-        es2018: emptyArray
-      })),
-      RegExp: new Map(Object.entries({
-        es2015: [
-          "flags",
-          "sticky",
-          "unicode"
-        ],
-        es2018: [
-          "dotAll"
-        ]
-      })),
-      Reflect: new Map(Object.entries({
-        es2015: [
-          "apply",
-          "construct",
-          "defineProperty",
-          "deleteProperty",
-          "get",
-          " getOwnPropertyDescriptor",
-          "getPrototypeOf",
-          "has",
-          "isExtensible",
-          "ownKeys",
-          "preventExtensions",
-          "set",
-          "setPrototypeOf"
-        ]
-      })),
-      ArrayConstructor: new Map(Object.entries({
-        es2015: [
-          "from",
-          "of"
-        ]
-      })),
-      ObjectConstructor: new Map(Object.entries({
-        es2015: [
-          "assign",
-          "getOwnPropertySymbols",
-          "keys",
-          "is",
-          "setPrototypeOf"
-        ],
-        es2017: [
-          "values",
-          "entries",
-          "getOwnPropertyDescriptors"
-        ],
-        es2019: [
-          "fromEntries"
-        ],
-        es2022: [
-          "hasOwn"
-        ]
-      })),
-      NumberConstructor: new Map(Object.entries({
-        es2015: [
-          "isFinite",
-          "isInteger",
-          "isNaN",
-          "isSafeInteger",
-          "parseFloat",
-          "parseInt"
-        ]
-      })),
-      Math: new Map(Object.entries({
-        es2015: [
-          "clz32",
-          "imul",
-          "sign",
-          "log10",
-          "log2",
-          "log1p",
-          "expm1",
-          "cosh",
-          "sinh",
-          "tanh",
-          "acosh",
-          "asinh",
-          "atanh",
-          "hypot",
-          "trunc",
-          "fround",
-          "cbrt"
-        ]
-      })),
-      Map: new Map(Object.entries({
-        es2015: [
-          "entries",
-          "keys",
-          "values"
-        ]
-      })),
-      Set: new Map(Object.entries({
-        es2015: [
-          "entries",
-          "keys",
-          "values"
-        ]
-      })),
-      PromiseConstructor: new Map(Object.entries({
-        es2015: [
-          "all",
-          "race",
-          "reject",
-          "resolve"
-        ],
-        es2020: [
-          "allSettled"
-        ],
-        es2021: [
-          "any"
-        ]
-      })),
-      Symbol: new Map(Object.entries({
-        es2015: [
-          "for",
-          "keyFor"
-        ],
-        es2019: [
-          "description"
-        ]
-      })),
-      WeakMap: new Map(Object.entries({
-        es2015: [
-          "entries",
-          "keys",
-          "values"
-        ]
-      })),
-      WeakSet: new Map(Object.entries({
-        es2015: [
-          "entries",
-          "keys",
-          "values"
-        ]
-      })),
-      String: new Map(Object.entries({
-        es2015: [
-          "codePointAt",
-          "includes",
-          "endsWith",
-          "normalize",
-          "repeat",
-          "startsWith",
-          "anchor",
-          "big",
-          "blink",
-          "bold",
-          "fixed",
-          "fontcolor",
-          "fontsize",
-          "italics",
-          "link",
-          "small",
-          "strike",
-          "sub",
-          "sup"
-        ],
-        es2017: [
-          "padStart",
-          "padEnd"
-        ],
-        es2019: [
-          "trimStart",
-          "trimEnd",
-          "trimLeft",
-          "trimRight"
-        ],
-        es2020: [
-          "matchAll"
-        ],
-        es2021: [
-          "replaceAll"
-        ],
-        es2022: [
-          "at"
-        ]
-      })),
-      StringConstructor: new Map(Object.entries({
-        es2015: [
-          "fromCodePoint",
-          "raw"
-        ]
-      })),
-      DateTimeFormat: new Map(Object.entries({
-        es2017: [
-          "formatToParts"
-        ]
-      })),
-      Promise: new Map(Object.entries({
-        es2015: emptyArray,
-        es2018: [
-          "finally"
-        ]
-      })),
-      RegExpMatchArray: new Map(Object.entries({
-        es2018: [
-          "groups"
-        ]
-      })),
-      RegExpExecArray: new Map(Object.entries({
-        es2018: [
-          "groups"
-        ]
-      })),
-      Intl: new Map(Object.entries({
-        es2018: [
-          "PluralRules"
-        ]
-      })),
-      NumberFormat: new Map(Object.entries({
-        es2018: [
-          "formatToParts"
-        ]
-      })),
-      SymbolConstructor: new Map(Object.entries({
-        es2020: [
-          "matchAll"
-        ]
-      })),
-      DataView: new Map(Object.entries({
-        es2020: [
-          "setBigInt64",
-          "setBigUint64",
-          "getBigInt64",
-          "getBigUint64"
-        ]
-      })),
-      BigInt: new Map(Object.entries({
-        es2020: emptyArray
-      })),
-      RelativeTimeFormat: new Map(Object.entries({
-        es2020: [
-          "format",
-          "formatToParts",
-          "resolvedOptions"
-        ]
-      })),
-      Int8Array: new Map(Object.entries({
-        es2022: [
-          "at"
-        ],
-        es2023: [
-          "findLastIndex",
-          "findLast"
-        ]
-      })),
-      Uint8Array: new Map(Object.entries({
-        es2022: [
-          "at"
-        ],
-        es2023: [
-          "findLastIndex",
-          "findLast"
-        ]
-      })),
-      Uint8ClampedArray: new Map(Object.entries({
-        es2022: [
-          "at"
-        ],
-        es2023: [
-          "findLastIndex",
-          "findLast"
-        ]
-      })),
-      Int16Array: new Map(Object.entries({
-        es2022: [
-          "at"
-        ],
-        es2023: [
-          "findLastIndex",
-          "findLast"
-        ]
-      })),
-      Uint16Array: new Map(Object.entries({
-        es2022: [
-          "at"
-        ],
-        es2023: [
-          "findLastIndex",
-          "findLast"
-        ]
-      })),
-      Int32Array: new Map(Object.entries({
-        es2022: [
-          "at"
-        ],
-        es2023: [
-          "findLastIndex",
-          "findLast"
-        ]
-      })),
-      Uint32Array: new Map(Object.entries({
-        es2022: [
-          "at"
-        ],
-        es2023: [
-          "findLastIndex",
-          "findLast"
-        ]
-      })),
-      Float32Array: new Map(Object.entries({
-        es2022: [
-          "at"
-        ],
-        es2023: [
-          "findLastIndex",
-          "findLast"
-        ]
-      })),
-      Float64Array: new Map(Object.entries({
-        es2022: [
-          "at"
-        ],
-        es2023: [
-          "findLastIndex",
-          "findLast"
-        ]
-      })),
-      BigInt64Array: new Map(Object.entries({
-        es2020: emptyArray,
-        es2022: [
-          "at"
-        ],
-        es2023: [
-          "findLastIndex",
-          "findLast"
-        ]
-      })),
-      BigUint64Array: new Map(Object.entries({
-        es2020: emptyArray,
-        es2022: [
-          "at"
-        ],
-        es2023: [
-          "findLastIndex",
-          "findLast"
-        ]
-      })),
-      Error: new Map(Object.entries({
-        es2022: [
-          "cause"
-        ]
-      }))
-    }));
-  }
   function getLiteralText(node, sourceFile, flags) {
     if (sourceFile && canUseOriginalText(node, flags)) {
       return getSourceTextOfNodeFromSourceFile(sourceFile, node);
@@ -113079,11 +95355,11 @@ ${lanes.join("\n")}
     return getBaseFileName(moduleName).replace(/^(\d)/, "_$1").replace(/\W/g, "_");
   }
   function isBlockOrCatchScoped(declaration) {
-    return (getCombinedNodeFlags(declaration) & 3 /* BlockScoped */) !== 0 || isCatchClauseVariableDeclarationOrBindingElement(declaration);
+    return (getCombinedNodeFlags(declaration) & 7 /* BlockScoped */) !== 0 || isCatchClauseVariableDeclarationOrBindingElement(declaration);
   }
   function isCatchClauseVariableDeclarationOrBindingElement(declaration) {
     const node = getRootDeclaration(declaration);
-    return node.kind === 259 /* VariableDeclaration */ && node.parent.kind === 298 /* CatchClause */;
+    return node.kind === 260 /* VariableDeclaration */ && node.parent.kind === 299 /* CatchClause */;
   }
   function isAmbientModule(node) {
     return isModuleDeclaration(node) && (node.name.kind === 11 /* StringLiteral */ || isGlobalScopeAugmentation(node));
@@ -113101,22 +95377,22 @@ ${lanes.join("\n")}
     return isShorthandAmbientModule(moduleSymbol.valueDeclaration);
   }
   function isShorthandAmbientModule(node) {
-    return !!node && node.kind === 266 /* ModuleDeclaration */ && !node.body;
+    return !!node && node.kind === 267 /* ModuleDeclaration */ && !node.body;
   }
   function isBlockScopedContainerTopLevel(node) {
-    return node.kind === 311 /* SourceFile */ || node.kind === 266 /* ModuleDeclaration */ || isFunctionLikeOrClassStaticBlockDeclaration(node);
+    return node.kind === 312 /* SourceFile */ || node.kind === 267 /* ModuleDeclaration */ || isFunctionLikeOrClassStaticBlockDeclaration(node);
   }
   function isGlobalScopeAugmentation(module2) {
-    return !!(module2.flags & 1024 /* GlobalAugmentation */);
+    return !!(module2.flags & 2048 /* GlobalAugmentation */);
   }
   function isExternalModuleAugmentation(node) {
     return isAmbientModule(node) && isModuleAugmentationExternal(node);
   }
   function isModuleAugmentationExternal(node) {
     switch (node.parent.kind) {
-      case 311 /* SourceFile */:
+      case 312 /* SourceFile */:
         return isExternalModule(node.parent);
-      case 267 /* ModuleBlock */:
+      case 268 /* ModuleBlock */:
         return isAmbientModule(node.parent.parent) && isSourceFile(node.parent.parent.parent) && !isExternalModule(node.parent.parent.parent);
     }
     return false;
@@ -113159,28 +95435,28 @@ ${lanes.join("\n")}
     return false;
   }
   function isAmbientPropertyDeclaration(node) {
-    return !!(node.flags & 16777216 /* Ambient */) || hasSyntacticModifier(node, 2 /* Ambient */);
+    return !!(node.flags & 33554432 /* Ambient */) || hasSyntacticModifier(node, 128 /* Ambient */);
   }
   function isBlockScope(node, parentNode) {
     switch (node.kind) {
-      case 311 /* SourceFile */:
-      case 268 /* CaseBlock */:
-      case 298 /* CatchClause */:
-      case 266 /* ModuleDeclaration */:
-      case 247 /* ForStatement */:
-      case 248 /* ForInStatement */:
-      case 249 /* ForOfStatement */:
-      case 175 /* Constructor */:
-      case 173 /* MethodDeclaration */:
-      case 176 /* GetAccessor */:
-      case 177 /* SetAccessor */:
-      case 261 /* FunctionDeclaration */:
-      case 217 /* FunctionExpression */:
-      case 218 /* ArrowFunction */:
-      case 171 /* PropertyDeclaration */:
-      case 174 /* ClassStaticBlockDeclaration */:
+      case 312 /* SourceFile */:
+      case 269 /* CaseBlock */:
+      case 299 /* CatchClause */:
+      case 267 /* ModuleDeclaration */:
+      case 248 /* ForStatement */:
+      case 249 /* ForInStatement */:
+      case 250 /* ForOfStatement */:
+      case 176 /* Constructor */:
+      case 174 /* MethodDeclaration */:
+      case 177 /* GetAccessor */:
+      case 178 /* SetAccessor */:
+      case 262 /* FunctionDeclaration */:
+      case 218 /* FunctionExpression */:
+      case 219 /* ArrowFunction */:
+      case 172 /* PropertyDeclaration */:
+      case 175 /* ClassStaticBlockDeclaration */:
         return true;
-      case 240 /* Block */:
+      case 241 /* Block */:
         return !isFunctionLikeOrClassStaticBlockDeclaration(parentNode);
     }
     return false;
@@ -113188,9 +95464,9 @@ ${lanes.join("\n")}
   function isDeclarationWithTypeParameters(node) {
     Debug.type(node);
     switch (node.kind) {
-      case 344 /* JSDocCallbackTag */:
-      case 352 /* JSDocTypedefTag */:
-      case 329 /* JSDocSignature */:
+      case 345 /* JSDocCallbackTag */:
+      case 353 /* JSDocTypedefTag */:
+      case 330 /* JSDocSignature */:
         return true;
       default:
         assertType(node);
@@ -113200,25 +95476,25 @@ ${lanes.join("\n")}
   function isDeclarationWithTypeParameterChildren(node) {
     Debug.type(node);
     switch (node.kind) {
-      case 178 /* CallSignature */:
-      case 179 /* ConstructSignature */:
-      case 172 /* MethodSignature */:
-      case 180 /* IndexSignature */:
-      case 183 /* FunctionType */:
-      case 184 /* ConstructorType */:
-      case 323 /* JSDocFunctionType */:
-      case 262 /* ClassDeclaration */:
-      case 230 /* ClassExpression */:
-      case 263 /* InterfaceDeclaration */:
-      case 264 /* TypeAliasDeclaration */:
-      case 351 /* JSDocTemplateTag */:
-      case 261 /* FunctionDeclaration */:
-      case 173 /* MethodDeclaration */:
-      case 175 /* Constructor */:
-      case 176 /* GetAccessor */:
-      case 177 /* SetAccessor */:
-      case 217 /* FunctionExpression */:
-      case 218 /* ArrowFunction */:
+      case 179 /* CallSignature */:
+      case 180 /* ConstructSignature */:
+      case 173 /* MethodSignature */:
+      case 181 /* IndexSignature */:
+      case 184 /* FunctionType */:
+      case 185 /* ConstructorType */:
+      case 324 /* JSDocFunctionType */:
+      case 263 /* ClassDeclaration */:
+      case 231 /* ClassExpression */:
+      case 264 /* InterfaceDeclaration */:
+      case 265 /* TypeAliasDeclaration */:
+      case 352 /* JSDocTemplateTag */:
+      case 262 /* FunctionDeclaration */:
+      case 174 /* MethodDeclaration */:
+      case 176 /* Constructor */:
+      case 177 /* GetAccessor */:
+      case 178 /* SetAccessor */:
+      case 218 /* FunctionExpression */:
+      case 219 /* ArrowFunction */:
         return true;
       default:
         assertType(node);
@@ -113227,8 +95503,8 @@ ${lanes.join("\n")}
   }
   function isAnyImportSyntax(node) {
     switch (node.kind) {
-      case 271 /* ImportDeclaration */:
-      case 270 /* ImportEqualsDeclaration */:
+      case 272 /* ImportDeclaration */:
+      case 271 /* ImportEqualsDeclaration */:
         return true;
       default:
         return false;
@@ -113239,15 +95515,15 @@ ${lanes.join("\n")}
   }
   function isLateVisibilityPaintedStatement(node) {
     switch (node.kind) {
-      case 271 /* ImportDeclaration */:
-      case 270 /* ImportEqualsDeclaration */:
-      case 242 /* VariableStatement */:
-      case 262 /* ClassDeclaration */:
-      case 261 /* FunctionDeclaration */:
-      case 266 /* ModuleDeclaration */:
-      case 264 /* TypeAliasDeclaration */:
-      case 263 /* InterfaceDeclaration */:
-      case 265 /* EnumDeclaration */:
+      case 272 /* ImportDeclaration */:
+      case 271 /* ImportEqualsDeclaration */:
+      case 243 /* VariableStatement */:
+      case 263 /* ClassDeclaration */:
+      case 262 /* FunctionDeclaration */:
+      case 267 /* ModuleDeclaration */:
+      case 265 /* TypeAliasDeclaration */:
+      case 264 /* InterfaceDeclaration */:
+      case 266 /* EnumDeclaration */:
         return true;
       default:
         return false;
@@ -113259,6 +95535,9 @@ ${lanes.join("\n")}
   function isAnyImportOrReExport(node) {
     return isAnyImportSyntax(node) || isExportDeclaration(node);
   }
+  function getEnclosingContainer(node) {
+    return findAncestor(node.parent, (n) => !!(getContainerFlags(n) & 1 /* IsContainer */));
+  }
   function getEnclosingBlockScopeContainer(node) {
     return findAncestor(node.parent, (current) => isBlockScope(current, current.parent));
   }
@@ -113276,7 +95555,7 @@ ${lanes.join("\n")}
     return info.declaration ? declarationNameToString(info.declaration.parameters[0].name) : void 0;
   }
   function isComputedNonLiteralName(name) {
-    return name.kind === 166 /* ComputedPropertyName */ && !isStringOrNumericLiteralLike(name.expression);
+    return name.kind === 167 /* ComputedPropertyName */ && !isStringOrNumericLiteralLike(name.expression);
   }
   function tryGetTextOfPropertyName(name) {
     var _a;
@@ -113288,11 +95567,11 @@ ${lanes.join("\n")}
       case 9 /* NumericLiteral */:
       case 15 /* NoSubstitutionTemplateLiteral */:
         return escapeLeadingUnderscores(name.text);
-      case 166 /* ComputedPropertyName */:
+      case 167 /* ComputedPropertyName */:
         if (isStringOrNumericLiteralLike(name.expression))
           return escapeLeadingUnderscores(name.expression.text);
         return void 0;
-      case 294 /* JsxNamespacedName */:
+      case 295 /* JsxNamespacedName */:
         return getEscapedTextOfJsxNamespacedName(name);
       default:
         return Debug.assertNever(name);
@@ -113308,17 +95587,17 @@ ${lanes.join("\n")}
       case 81 /* PrivateIdentifier */:
       case 80 /* Identifier */:
         return getFullWidth(name) === 0 ? idText(name) : getTextOfNode(name);
-      case 165 /* QualifiedName */:
+      case 166 /* QualifiedName */:
         return entityNameToString(name.left) + "." + entityNameToString(name.right);
-      case 210 /* PropertyAccessExpression */:
+      case 211 /* PropertyAccessExpression */:
         if (isIdentifier(name.name) || isPrivateIdentifier(name.name)) {
           return entityNameToString(name.expression) + "." + entityNameToString(name.name);
         } else {
           return Debug.assertNever(name.name);
         }
-      case 317 /* JSDocMemberName */:
+      case 318 /* JSDocMemberName */:
         return entityNameToString(name.left) + entityNameToString(name.right);
-      case 294 /* JsxNamespacedName */:
+      case 295 /* JsxNamespacedName */:
         return entityNameToString(name.namespace) + ":" + entityNameToString(name.name);
       default:
         return Debug.assertNever(name);
@@ -113344,16 +95623,14 @@ ${lanes.join("\n")}
     const start = skipTrivia(sourceFile.text, nodes.pos);
     return createFileDiagnosticFromMessageChain(sourceFile, start, nodes.end - start, messageChain, relatedInformation);
   }
-  function assertDiagnosticLocation(file, start, length2) {
+  function assertDiagnosticLocation(sourceText, start, length2) {
     Debug.assertGreaterThanOrEqual(start, 0);
     Debug.assertGreaterThanOrEqual(length2, 0);
-    if (file) {
-      Debug.assertLessThanOrEqual(start, file.text.length);
-      Debug.assertLessThanOrEqual(start + length2, file.text.length);
-    }
+    Debug.assertLessThanOrEqual(start, sourceText.length);
+    Debug.assertLessThanOrEqual(start + length2, sourceText.length);
   }
   function createFileDiagnosticFromMessageChain(file, start, length2, messageChain, relatedInformation) {
-    assertDiagnosticLocation(file, start, length2);
+    assertDiagnosticLocation(file.text, start, length2);
     return {
       file,
       start,
@@ -113424,7 +95701,7 @@ ${lanes.join("\n")}
   }
   function getErrorSpanForArrowFunction(sourceFile, node) {
     const pos = skipTrivia(sourceFile.text, node.pos);
-    if (node.body && node.body.kind === 240 /* Block */) {
+    if (node.body && node.body.kind === 241 /* Block */) {
       const { line: startLine } = getLineAndCharacterOfPosition(sourceFile, node.body.pos);
       const { line: endLine } = getLineAndCharacterOfPosition(sourceFile, node.body.end);
       if (startLine < endLine) {
@@ -113436,7 +95713,7 @@ ${lanes.join("\n")}
   function getErrorSpanForNode(sourceFile, node) {
     let errorNode = node;
     switch (node.kind) {
-      case 311 /* SourceFile */: {
+      case 312 /* SourceFile */: {
         const pos2 = skipTrivia(
           sourceFile.text,
           0,
@@ -113448,43 +95725,43 @@ ${lanes.join("\n")}
         }
         return getSpanOfTokenAtPosition(sourceFile, pos2);
       }
-      case 259 /* VariableDeclaration */:
-      case 207 /* BindingElement */:
-      case 262 /* ClassDeclaration */:
-      case 230 /* ClassExpression */:
-      case 263 /* InterfaceDeclaration */:
-      case 266 /* ModuleDeclaration */:
-      case 265 /* EnumDeclaration */:
-      case 305 /* EnumMember */:
-      case 261 /* FunctionDeclaration */:
-      case 217 /* FunctionExpression */:
-      case 173 /* MethodDeclaration */:
-      case 176 /* GetAccessor */:
-      case 177 /* SetAccessor */:
-      case 264 /* TypeAliasDeclaration */:
-      case 171 /* PropertyDeclaration */:
-      case 170 /* PropertySignature */:
-      case 273 /* NamespaceImport */:
+      case 260 /* VariableDeclaration */:
+      case 208 /* BindingElement */:
+      case 263 /* ClassDeclaration */:
+      case 231 /* ClassExpression */:
+      case 264 /* InterfaceDeclaration */:
+      case 267 /* ModuleDeclaration */:
+      case 266 /* EnumDeclaration */:
+      case 306 /* EnumMember */:
+      case 262 /* FunctionDeclaration */:
+      case 218 /* FunctionExpression */:
+      case 174 /* MethodDeclaration */:
+      case 177 /* GetAccessor */:
+      case 178 /* SetAccessor */:
+      case 265 /* TypeAliasDeclaration */:
+      case 172 /* PropertyDeclaration */:
+      case 171 /* PropertySignature */:
+      case 274 /* NamespaceImport */:
         errorNode = node.name;
         break;
-      case 218 /* ArrowFunction */:
+      case 219 /* ArrowFunction */:
         return getErrorSpanForArrowFunction(sourceFile, node);
-      case 295 /* CaseClause */:
-      case 296 /* DefaultClause */: {
+      case 296 /* CaseClause */:
+      case 297 /* DefaultClause */: {
         const start = skipTrivia(sourceFile.text, node.pos);
         const end = node.statements.length > 0 ? node.statements[0].pos : node.end;
         return createTextSpanFromBounds(start, end);
       }
-      case 252 /* ReturnStatement */:
-      case 228 /* YieldExpression */: {
+      case 253 /* ReturnStatement */:
+      case 229 /* YieldExpression */: {
         const pos2 = skipTrivia(sourceFile.text, node.pos);
         return getSpanOfTokenAtPosition(sourceFile, pos2);
       }
-      case 237 /* SatisfiesExpression */: {
+      case 238 /* SatisfiesExpression */: {
         const pos2 = skipTrivia(sourceFile.text, node.expression.end);
         return getSpanOfTokenAtPosition(sourceFile, pos2);
       }
-      case 356 /* JSDocSatisfiesTag */: {
+      case 357 /* JSDocSatisfiesTag */: {
         const pos2 = skipTrivia(sourceFile.text, node.tagName.pos);
         return getSpanOfTokenAtPosition(sourceFile, pos2);
       }
@@ -113511,22 +95788,28 @@ ${lanes.join("\n")}
     return file.scriptKind === 6 /* JSON */;
   }
   function isEnumConst(node) {
-    return !!(getCombinedModifierFlags(node) & 2048 /* Const */);
+    return !!(getCombinedModifierFlags(node) & 4096 /* Const */);
   }
   function isDeclarationReadonly(declaration) {
-    return !!(getCombinedModifierFlags(declaration) & 64 /* Readonly */ && !isParameterPropertyDeclaration(declaration, declaration.parent));
+    return !!(getCombinedModifierFlags(declaration) & 8 /* Readonly */ && !isParameterPropertyDeclaration(declaration, declaration.parent));
+  }
+  function isVarAwaitUsing(node) {
+    return (getCombinedNodeFlags(node) & 7 /* BlockScoped */) === 6 /* AwaitUsing */;
+  }
+  function isVarUsing(node) {
+    return (getCombinedNodeFlags(node) & 7 /* BlockScoped */) === 4 /* Using */;
   }
   function isVarConst(node) {
-    return !!(getCombinedNodeFlags(node) & 2 /* Const */);
+    return (getCombinedNodeFlags(node) & 7 /* BlockScoped */) === 2 /* Const */;
   }
   function isLet(node) {
-    return !!(getCombinedNodeFlags(node) & 1 /* Let */);
+    return (getCombinedNodeFlags(node) & 7 /* BlockScoped */) === 1 /* Let */;
   }
   function isSuperCall(n) {
-    return n.kind === 212 /* CallExpression */ && n.expression.kind === 108 /* SuperKeyword */;
+    return n.kind === 213 /* CallExpression */ && n.expression.kind === 108 /* SuperKeyword */;
   }
   function isImportCall(n) {
-    return n.kind === 212 /* CallExpression */ && n.expression.kind === 102 /* ImportKeyword */;
+    return n.kind === 213 /* CallExpression */ && n.expression.kind === 102 /* ImportKeyword */;
   }
   function isImportMeta(n) {
     return isMetaProperty(n) && n.keywordToken === 102 /* ImportKeyword */ && n.name.escapedText === "meta";
@@ -113535,7 +95818,7 @@ ${lanes.join("\n")}
     return isImportTypeNode(n) && isLiteralTypeNode(n.argument) && isStringLiteral(n.argument.literal);
   }
   function isPrologueDirective(node) {
-    return node.kind === 243 /* ExpressionStatement */ && node.expression.kind === 11 /* StringLiteral */;
+    return node.kind === 244 /* ExpressionStatement */ && node.expression.kind === 11 /* StringLiteral */;
   }
   function isCustomPrologue(node) {
     return !!(getEmitFlags(node) & 2097152 /* CustomPrologue */);
@@ -113553,18 +95836,18 @@ ${lanes.join("\n")}
     return node.kind !== 12 /* JsxText */ ? getLeadingCommentRanges(sourceFileOfNode.text, node.pos) : void 0;
   }
   function getJSDocCommentRanges(node, text) {
-    const commentRanges = node.kind === 168 /* Parameter */ || node.kind === 167 /* TypeParameter */ || node.kind === 217 /* FunctionExpression */ || node.kind === 218 /* ArrowFunction */ || node.kind === 216 /* ParenthesizedExpression */ || node.kind === 259 /* VariableDeclaration */ || node.kind === 280 /* ExportSpecifier */ ? concatenate(getTrailingCommentRanges(text, node.pos), getLeadingCommentRanges(text, node.pos)) : getLeadingCommentRanges(text, node.pos);
+    const commentRanges = node.kind === 169 /* Parameter */ || node.kind === 168 /* TypeParameter */ || node.kind === 218 /* FunctionExpression */ || node.kind === 219 /* ArrowFunction */ || node.kind === 217 /* ParenthesizedExpression */ || node.kind === 260 /* VariableDeclaration */ || node.kind === 281 /* ExportSpecifier */ ? concatenate(getTrailingCommentRanges(text, node.pos), getLeadingCommentRanges(text, node.pos)) : getLeadingCommentRanges(text, node.pos);
     return filter(commentRanges, (comment) => text.charCodeAt(comment.pos + 1) === 42 /* asterisk */ && text.charCodeAt(comment.pos + 2) === 42 /* asterisk */ && text.charCodeAt(comment.pos + 3) !== 47 /* slash */);
   }
   function isPartOfTypeNode(node) {
-    if (181 /* FirstTypeNode */ <= node.kind && node.kind <= 204 /* LastTypeNode */) {
+    if (182 /* FirstTypeNode */ <= node.kind && node.kind <= 205 /* LastTypeNode */) {
       return true;
     }
     switch (node.kind) {
       case 133 /* AnyKeyword */:
       case 159 /* UnknownKeyword */:
       case 150 /* NumberKeyword */:
-      case 162 /* BigIntKeyword */:
+      case 163 /* BigIntKeyword */:
       case 154 /* StringKeyword */:
       case 136 /* BooleanKeyword */:
       case 155 /* SymbolKeyword */:
@@ -113574,64 +95857,61 @@ ${lanes.join("\n")}
       case 146 /* NeverKeyword */:
         return true;
       case 116 /* VoidKeyword */:
-        return node.parent.kind !== 221 /* VoidExpression */;
-      case 232 /* ExpressionWithTypeArguments */:
+        return node.parent.kind !== 222 /* VoidExpression */;
+      case 233 /* ExpressionWithTypeArguments */:
         return isHeritageClause(node.parent) && !isExpressionWithTypeArgumentsInClassExtendsClause(node);
-      case 167 /* TypeParameter */:
-        return node.parent.kind === 199 /* MappedType */ || node.parent.kind === 194 /* InferType */;
+      case 168 /* TypeParameter */:
+        return node.parent.kind === 200 /* MappedType */ || node.parent.kind === 195 /* InferType */;
       case 80 /* Identifier */:
-        if (node.parent.kind === 165 /* QualifiedName */ && node.parent.right === node) {
+        if (node.parent.kind === 166 /* QualifiedName */ && node.parent.right === node) {
           node = node.parent;
-        } else if (node.parent.kind === 210 /* PropertyAccessExpression */ && node.parent.name === node) {
+        } else if (node.parent.kind === 211 /* PropertyAccessExpression */ && node.parent.name === node) {
           node = node.parent;
         }
-        Debug.assert(
-          node.kind === 80 /* Identifier */ || node.kind === 165 /* QualifiedName */ || node.kind === 210 /* PropertyAccessExpression */,
-          "'node' was expected to be a qualified name, identifier or property access in 'isPartOfTypeNode'."
-        );
-      case 165 /* QualifiedName */:
-      case 210 /* PropertyAccessExpression */:
+        Debug.assert(node.kind === 80 /* Identifier */ || node.kind === 166 /* QualifiedName */ || node.kind === 211 /* PropertyAccessExpression */, "'node' was expected to be a qualified name, identifier or property access in 'isPartOfTypeNode'.");
+      case 166 /* QualifiedName */:
+      case 211 /* PropertyAccessExpression */:
       case 110 /* ThisKeyword */: {
         const { parent: parent2 } = node;
-        if (parent2.kind === 185 /* TypeQuery */) {
+        if (parent2.kind === 186 /* TypeQuery */) {
           return false;
         }
-        if (parent2.kind === 204 /* ImportType */) {
+        if (parent2.kind === 205 /* ImportType */) {
           return !parent2.isTypeOf;
         }
-        if (181 /* FirstTypeNode */ <= parent2.kind && parent2.kind <= 204 /* LastTypeNode */) {
+        if (182 /* FirstTypeNode */ <= parent2.kind && parent2.kind <= 205 /* LastTypeNode */) {
           return true;
         }
         switch (parent2.kind) {
-          case 232 /* ExpressionWithTypeArguments */:
+          case 233 /* ExpressionWithTypeArguments */:
             return isHeritageClause(parent2.parent) && !isExpressionWithTypeArgumentsInClassExtendsClause(parent2);
-          case 167 /* TypeParameter */:
+          case 168 /* TypeParameter */:
             return node === parent2.constraint;
-          case 351 /* JSDocTemplateTag */:
+          case 352 /* JSDocTemplateTag */:
             return node === parent2.constraint;
-          case 171 /* PropertyDeclaration */:
-          case 170 /* PropertySignature */:
-          case 168 /* Parameter */:
-          case 259 /* VariableDeclaration */:
+          case 172 /* PropertyDeclaration */:
+          case 171 /* PropertySignature */:
+          case 169 /* Parameter */:
+          case 260 /* VariableDeclaration */:
             return node === parent2.type;
-          case 261 /* FunctionDeclaration */:
-          case 217 /* FunctionExpression */:
-          case 218 /* ArrowFunction */:
-          case 175 /* Constructor */:
-          case 173 /* MethodDeclaration */:
-          case 172 /* MethodSignature */:
-          case 176 /* GetAccessor */:
-          case 177 /* SetAccessor */:
+          case 262 /* FunctionDeclaration */:
+          case 218 /* FunctionExpression */:
+          case 219 /* ArrowFunction */:
+          case 176 /* Constructor */:
+          case 174 /* MethodDeclaration */:
+          case 173 /* MethodSignature */:
+          case 177 /* GetAccessor */:
+          case 178 /* SetAccessor */:
             return node === parent2.type;
-          case 178 /* CallSignature */:
-          case 179 /* ConstructSignature */:
-          case 180 /* IndexSignature */:
+          case 179 /* CallSignature */:
+          case 180 /* ConstructSignature */:
+          case 181 /* IndexSignature */:
             return node === parent2.type;
-          case 215 /* TypeAssertionExpression */:
+          case 216 /* TypeAssertionExpression */:
             return node === parent2.type;
-          case 212 /* CallExpression */:
-          case 213 /* NewExpression */:
-          case 214 /* TaggedTemplateExpression */:
+          case 213 /* CallExpression */:
+          case 214 /* NewExpression */:
+          case 215 /* TaggedTemplateExpression */:
             return contains(parent2.typeArguments, node);
         }
       }
@@ -113651,23 +95931,23 @@ ${lanes.join("\n")}
     return traverse(body);
     function traverse(node) {
       switch (node.kind) {
-        case 252 /* ReturnStatement */:
+        case 253 /* ReturnStatement */:
           return visitor(node);
-        case 268 /* CaseBlock */:
-        case 240 /* Block */:
-        case 244 /* IfStatement */:
-        case 245 /* DoStatement */:
-        case 246 /* WhileStatement */:
-        case 247 /* ForStatement */:
-        case 248 /* ForInStatement */:
-        case 249 /* ForOfStatement */:
-        case 253 /* WithStatement */:
-        case 254 /* SwitchStatement */:
-        case 295 /* CaseClause */:
-        case 296 /* DefaultClause */:
-        case 255 /* LabeledStatement */:
-        case 257 /* TryStatement */:
-        case 298 /* CatchClause */:
+        case 269 /* CaseBlock */:
+        case 241 /* Block */:
+        case 245 /* IfStatement */:
+        case 246 /* DoStatement */:
+        case 247 /* WhileStatement */:
+        case 248 /* ForStatement */:
+        case 249 /* ForInStatement */:
+        case 250 /* ForOfStatement */:
+        case 254 /* WithStatement */:
+        case 255 /* SwitchStatement */:
+        case 296 /* CaseClause */:
+        case 297 /* DefaultClause */:
+        case 256 /* LabeledStatement */:
+        case 258 /* TryStatement */:
+        case 299 /* CatchClause */:
           return forEachChild(node, traverse);
       }
     }
@@ -113676,21 +95956,21 @@ ${lanes.join("\n")}
     return traverse(body);
     function traverse(node) {
       switch (node.kind) {
-        case 228 /* YieldExpression */:
+        case 229 /* YieldExpression */:
           visitor(node);
           const operand = node.expression;
           if (operand) {
             traverse(operand);
           }
           return;
-        case 265 /* EnumDeclaration */:
-        case 263 /* InterfaceDeclaration */:
-        case 266 /* ModuleDeclaration */:
-        case 264 /* TypeAliasDeclaration */:
+        case 266 /* EnumDeclaration */:
+        case 264 /* InterfaceDeclaration */:
+        case 267 /* ModuleDeclaration */:
+        case 265 /* TypeAliasDeclaration */:
           return;
         default:
           if (isFunctionLike(node)) {
-            if (node.name && node.name.kind === 166 /* ComputedPropertyName */) {
+            if (node.name && node.name.kind === 167 /* ComputedPropertyName */) {
               traverse(node.name.expression);
               return;
             }
@@ -113701,9 +95981,9 @@ ${lanes.join("\n")}
     }
   }
   function getRestParameterElementType(node) {
-    if (node && node.kind === 187 /* ArrayType */) {
+    if (node && node.kind === 188 /* ArrayType */) {
       return node.elementType;
-    } else if (node && node.kind === 182 /* TypeReference */) {
+    } else if (node && node.kind === 183 /* TypeReference */) {
       return singleOrUndefined(node.typeArguments);
     } else {
       return void 0;
@@ -113711,26 +95991,26 @@ ${lanes.join("\n")}
   }
   function getMembersOfDeclaration(node) {
     switch (node.kind) {
-      case 263 /* InterfaceDeclaration */:
-      case 262 /* ClassDeclaration */:
-      case 230 /* ClassExpression */:
-      case 186 /* TypeLiteral */:
+      case 264 /* InterfaceDeclaration */:
+      case 263 /* ClassDeclaration */:
+      case 231 /* ClassExpression */:
+      case 187 /* TypeLiteral */:
         return node.members;
-      case 209 /* ObjectLiteralExpression */:
+      case 210 /* ObjectLiteralExpression */:
         return node.properties;
     }
   }
   function isVariableLike(node) {
     if (node) {
       switch (node.kind) {
-        case 207 /* BindingElement */:
-        case 305 /* EnumMember */:
-        case 168 /* Parameter */:
-        case 302 /* PropertyAssignment */:
-        case 171 /* PropertyDeclaration */:
-        case 170 /* PropertySignature */:
-        case 303 /* ShorthandPropertyAssignment */:
-        case 259 /* VariableDeclaration */:
+        case 208 /* BindingElement */:
+        case 306 /* EnumMember */:
+        case 169 /* Parameter */:
+        case 303 /* PropertyAssignment */:
+        case 172 /* PropertyDeclaration */:
+        case 171 /* PropertySignature */:
+        case 304 /* ShorthandPropertyAssignment */:
+        case 260 /* VariableDeclaration */:
           return true;
       }
     }
@@ -113740,7 +96020,7 @@ ${lanes.join("\n")}
     return isVariableLike(node) || isAccessor(node);
   }
   function isVariableDeclarationInVariableStatement(node) {
-    return node.parent.kind === 260 /* VariableDeclarationList */ && node.parent.parent.kind === 242 /* VariableStatement */;
+    return node.parent.kind === 261 /* VariableDeclarationList */ && node.parent.parent.kind === 243 /* VariableStatement */;
   }
   function isCommonJsExportedExpression(node) {
     if (!isInJSFile(node))
@@ -113757,13 +96037,13 @@ ${lanes.join("\n")}
   }
   function introducesArgumentsExoticObject(node) {
     switch (node.kind) {
-      case 173 /* MethodDeclaration */:
-      case 172 /* MethodSignature */:
-      case 175 /* Constructor */:
-      case 176 /* GetAccessor */:
-      case 177 /* SetAccessor */:
-      case 261 /* FunctionDeclaration */:
-      case 217 /* FunctionExpression */:
+      case 174 /* MethodDeclaration */:
+      case 173 /* MethodSignature */:
+      case 176 /* Constructor */:
+      case 177 /* GetAccessor */:
+      case 178 /* SetAccessor */:
+      case 262 /* FunctionDeclaration */:
+      case 218 /* FunctionExpression */:
         return true;
     }
     return false;
@@ -113773,20 +96053,20 @@ ${lanes.join("\n")}
       if (beforeUnwrapLabelCallback) {
         beforeUnwrapLabelCallback(node);
       }
-      if (node.statement.kind !== 255 /* LabeledStatement */) {
+      if (node.statement.kind !== 256 /* LabeledStatement */) {
         return node.statement;
       }
       node = node.statement;
     }
   }
   function isFunctionBlock(node) {
-    return node && node.kind === 240 /* Block */ && isFunctionLike(node.parent);
+    return node && node.kind === 241 /* Block */ && isFunctionLike(node.parent);
   }
   function isObjectLiteralMethod(node) {
-    return node && node.kind === 173 /* MethodDeclaration */ && node.parent.kind === 209 /* ObjectLiteralExpression */;
+    return node && node.kind === 174 /* MethodDeclaration */ && node.parent.kind === 210 /* ObjectLiteralExpression */;
   }
   function isObjectLiteralOrClassExpressionMethodOrAccessor(node) {
-    return (node.kind === 173 /* MethodDeclaration */ || node.kind === 176 /* GetAccessor */ || node.kind === 177 /* SetAccessor */) && (node.parent.kind === 209 /* ObjectLiteralExpression */ || node.parent.kind === 230 /* ClassExpression */);
+    return (node.kind === 174 /* MethodDeclaration */ || node.kind === 177 /* GetAccessor */ || node.kind === 178 /* SetAccessor */) && (node.parent.kind === 210 /* ObjectLiteralExpression */ || node.parent.kind === 231 /* ClassExpression */);
   }
   function isIdentifierTypePredicate(predicate) {
     return predicate && predicate.kind === 1 /* Identifier */;
@@ -113803,11 +96083,7 @@ ${lanes.join("\n")}
     });
   }
   function getPropertyArrayElementValue(objectLiteral, propKey, elementValue) {
-    return forEachPropertyAssignment(
-      objectLiteral,
-      propKey,
-      (property) => isArrayLiteralExpression(property.initializer) ? find(property.initializer.elements, (element) => isStringLiteral(element) && element.text === elementValue) : void 0
-    );
+    return forEachPropertyAssignment(objectLiteral, propKey, (property) => isArrayLiteralExpression(property.initializer) ? find(property.initializer.elements, (element) => isStringLiteral(element) && element.text === elementValue) : void 0);
   }
   function getTsConfigObjectLiteralExpression(tsConfigSourceFile) {
     if (tsConfigSourceFile && tsConfigSourceFile.statements.length) {
@@ -113841,64 +96117,68 @@ ${lanes.join("\n")}
   function getContainingFunctionOrClassStaticBlock(node) {
     return findAncestor(node.parent, isFunctionLikeOrClassStaticBlockDeclaration);
   }
+  function getContainingClassExcludingClassDecorators(node) {
+    const decorator = findAncestor(node.parent, (n) => isClassLike(n) ? "quit" : isDecorator(n));
+    return decorator && isClassLike(decorator.parent) ? getContainingClass(decorator.parent) : getContainingClass(decorator ?? node);
+  }
   function getThisContainer(node, includeArrowFunctions, includeClassComputedPropertyName) {
-    Debug.assert(node.kind !== 311 /* SourceFile */);
+    Debug.assert(node.kind !== 312 /* SourceFile */);
     while (true) {
       node = node.parent;
       if (!node) {
         return Debug.fail();
       }
       switch (node.kind) {
-        case 166 /* ComputedPropertyName */:
+        case 167 /* ComputedPropertyName */:
           if (includeClassComputedPropertyName && isClassLike(node.parent.parent)) {
             return node;
           }
           node = node.parent.parent;
           break;
-        case 169 /* Decorator */:
-          if (node.parent.kind === 168 /* Parameter */ && isClassElement(node.parent.parent)) {
+        case 170 /* Decorator */:
+          if (node.parent.kind === 169 /* Parameter */ && isClassElement(node.parent.parent)) {
             node = node.parent.parent;
           } else if (isClassElement(node.parent)) {
             node = node.parent;
           }
           break;
-        case 218 /* ArrowFunction */:
+        case 219 /* ArrowFunction */:
           if (!includeArrowFunctions) {
             continue;
           }
-        case 261 /* FunctionDeclaration */:
-        case 217 /* FunctionExpression */:
-        case 266 /* ModuleDeclaration */:
-        case 174 /* ClassStaticBlockDeclaration */:
-        case 171 /* PropertyDeclaration */:
-        case 170 /* PropertySignature */:
-        case 173 /* MethodDeclaration */:
-        case 172 /* MethodSignature */:
-        case 175 /* Constructor */:
-        case 176 /* GetAccessor */:
-        case 177 /* SetAccessor */:
-        case 178 /* CallSignature */:
-        case 179 /* ConstructSignature */:
-        case 180 /* IndexSignature */:
-        case 265 /* EnumDeclaration */:
-        case 311 /* SourceFile */:
+        case 262 /* FunctionDeclaration */:
+        case 218 /* FunctionExpression */:
+        case 267 /* ModuleDeclaration */:
+        case 175 /* ClassStaticBlockDeclaration */:
+        case 172 /* PropertyDeclaration */:
+        case 171 /* PropertySignature */:
+        case 174 /* MethodDeclaration */:
+        case 173 /* MethodSignature */:
+        case 176 /* Constructor */:
+        case 177 /* GetAccessor */:
+        case 178 /* SetAccessor */:
+        case 179 /* CallSignature */:
+        case 180 /* ConstructSignature */:
+        case 181 /* IndexSignature */:
+        case 266 /* EnumDeclaration */:
+        case 312 /* SourceFile */:
           return node;
       }
     }
   }
   function isThisContainerOrFunctionBlock(node) {
     switch (node.kind) {
-      case 218 /* ArrowFunction */:
-      case 261 /* FunctionDeclaration */:
-      case 217 /* FunctionExpression */:
-      case 171 /* PropertyDeclaration */:
+      case 219 /* ArrowFunction */:
+      case 262 /* FunctionDeclaration */:
+      case 218 /* FunctionExpression */:
+      case 172 /* PropertyDeclaration */:
         return true;
-      case 240 /* Block */:
+      case 241 /* Block */:
         switch (node.parent.kind) {
-          case 175 /* Constructor */:
-          case 173 /* MethodDeclaration */:
-          case 176 /* GetAccessor */:
-          case 177 /* SetAccessor */:
+          case 176 /* Constructor */:
+          case 174 /* MethodDeclaration */:
+          case 177 /* GetAccessor */:
+          case 178 /* SetAccessor */:
             return true;
           default:
             return false;
@@ -113930,9 +96210,9 @@ ${lanes.join("\n")}
     );
     if (container) {
       switch (container.kind) {
-        case 175 /* Constructor */:
-        case 261 /* FunctionDeclaration */:
-        case 217 /* FunctionExpression */:
+        case 176 /* Constructor */:
+        case 262 /* FunctionDeclaration */:
+        case 218 /* FunctionExpression */:
           return container;
       }
     }
@@ -113945,26 +96225,26 @@ ${lanes.join("\n")}
         return void 0;
       }
       switch (node.kind) {
-        case 166 /* ComputedPropertyName */:
+        case 167 /* ComputedPropertyName */:
           node = node.parent;
           break;
-        case 261 /* FunctionDeclaration */:
-        case 217 /* FunctionExpression */:
-        case 218 /* ArrowFunction */:
+        case 262 /* FunctionDeclaration */:
+        case 218 /* FunctionExpression */:
+        case 219 /* ArrowFunction */:
           if (!stopOnFunctions) {
             continue;
           }
-        case 171 /* PropertyDeclaration */:
-        case 170 /* PropertySignature */:
-        case 173 /* MethodDeclaration */:
-        case 172 /* MethodSignature */:
-        case 175 /* Constructor */:
-        case 176 /* GetAccessor */:
-        case 177 /* SetAccessor */:
-        case 174 /* ClassStaticBlockDeclaration */:
+        case 172 /* PropertyDeclaration */:
+        case 171 /* PropertySignature */:
+        case 174 /* MethodDeclaration */:
+        case 173 /* MethodSignature */:
+        case 176 /* Constructor */:
+        case 177 /* GetAccessor */:
+        case 178 /* SetAccessor */:
+        case 175 /* ClassStaticBlockDeclaration */:
           return node;
-        case 169 /* Decorator */:
-          if (node.parent.kind === 168 /* Parameter */ && isClassElement(node.parent.parent)) {
+        case 170 /* Decorator */:
+          if (node.parent.kind === 169 /* Parameter */ && isClassElement(node.parent.parent)) {
             node = node.parent.parent;
           } else if (isClassElement(node.parent)) {
             node = node.parent;
@@ -113974,14 +96254,14 @@ ${lanes.join("\n")}
     }
   }
   function getImmediatelyInvokedFunctionExpression(func) {
-    if (func.kind === 217 /* FunctionExpression */ || func.kind === 218 /* ArrowFunction */) {
+    if (func.kind === 218 /* FunctionExpression */ || func.kind === 219 /* ArrowFunction */) {
       let prev = func;
       let parent2 = func.parent;
-      while (parent2.kind === 216 /* ParenthesizedExpression */) {
+      while (parent2.kind === 217 /* ParenthesizedExpression */) {
         prev = parent2;
         parent2 = parent2.parent;
       }
-      if (parent2.kind === 212 /* CallExpression */ && parent2.expression === prev) {
+      if (parent2.kind === 213 /* CallExpression */ && parent2.expression === prev) {
         return parent2;
       }
     }
@@ -113991,11 +96271,11 @@ ${lanes.join("\n")}
   }
   function isSuperProperty(node) {
     const kind = node.kind;
-    return (kind === 210 /* PropertyAccessExpression */ || kind === 211 /* ElementAccessExpression */) && node.expression.kind === 108 /* SuperKeyword */;
+    return (kind === 211 /* PropertyAccessExpression */ || kind === 212 /* ElementAccessExpression */) && node.expression.kind === 108 /* SuperKeyword */;
   }
   function isThisProperty(node) {
     const kind = node.kind;
-    return (kind === 210 /* PropertyAccessExpression */ || kind === 211 /* ElementAccessExpression */) && node.expression.kind === 110 /* ThisKeyword */;
+    return (kind === 211 /* PropertyAccessExpression */ || kind === 212 /* ElementAccessExpression */) && node.expression.kind === 110 /* ThisKeyword */;
   }
   function isThisInitializedDeclaration(node) {
     var _a;
@@ -114006,23 +96286,25 @@ ${lanes.join("\n")}
   }
   function getEntityNameFromTypeNode(node) {
     switch (node.kind) {
-      case 182 /* TypeReference */:
+      case 183 /* TypeReference */:
         return node.typeName;
-      case 232 /* ExpressionWithTypeArguments */:
+      case 233 /* ExpressionWithTypeArguments */:
         return isEntityNameExpression(node.expression) ? node.expression : void 0;
       case 80 /* Identifier */:
-      case 165 /* QualifiedName */:
+      case 166 /* QualifiedName */:
         return node;
     }
     return void 0;
   }
   function getInvokedExpression(node) {
     switch (node.kind) {
-      case 214 /* TaggedTemplateExpression */:
+      case 215 /* TaggedTemplateExpression */:
         return node.tag;
-      case 285 /* JsxOpeningElement */:
-      case 284 /* JsxSelfClosingElement */:
+      case 286 /* JsxOpeningElement */:
+      case 285 /* JsxSelfClosingElement */:
         return node.tagName;
+      case 226 /* BinaryExpression */:
+        return node.right;
       default:
         return node.expression;
     }
@@ -114032,20 +96314,20 @@ ${lanes.join("\n")}
       return false;
     }
     switch (node.kind) {
-      case 262 /* ClassDeclaration */:
+      case 263 /* ClassDeclaration */:
         return true;
-      case 230 /* ClassExpression */:
+      case 231 /* ClassExpression */:
         return !useLegacyDecorators;
-      case 171 /* PropertyDeclaration */:
+      case 172 /* PropertyDeclaration */:
         return parent2 !== void 0 && (useLegacyDecorators ? isClassDeclaration(parent2) : isClassLike(parent2) && !hasAbstractModifier(node) && !hasAmbientModifier(node));
-      case 176 /* GetAccessor */:
-      case 177 /* SetAccessor */:
-      case 173 /* MethodDeclaration */:
+      case 177 /* GetAccessor */:
+      case 178 /* SetAccessor */:
+      case 174 /* MethodDeclaration */:
         return node.body !== void 0 && parent2 !== void 0 && (useLegacyDecorators ? isClassDeclaration(parent2) : isClassLike(parent2));
-      case 168 /* Parameter */:
+      case 169 /* Parameter */:
         if (!useLegacyDecorators)
           return false;
-        return parent2 !== void 0 && parent2.body !== void 0 && (parent2.kind === 175 /* Constructor */ || parent2.kind === 173 /* MethodDeclaration */ || parent2.kind === 177 /* SetAccessor */) && getThisParameter(parent2) !== node && grandparent !== void 0 && grandparent.kind === 262 /* ClassDeclaration */;
+        return parent2 !== void 0 && parent2.body !== void 0 && (parent2.kind === 176 /* Constructor */ || parent2.kind === 174 /* MethodDeclaration */ || parent2.kind === 178 /* SetAccessor */) && getThisParameter(parent2) !== node && grandparent !== void 0 && grandparent.kind === 263 /* ClassDeclaration */;
     }
     return false;
   }
@@ -114057,13 +96339,13 @@ ${lanes.join("\n")}
   }
   function childIsDecorated(useLegacyDecorators, node, parent2) {
     switch (node.kind) {
-      case 262 /* ClassDeclaration */:
+      case 263 /* ClassDeclaration */:
         return some(node.members, (m) => nodeOrChildIsDecorated(useLegacyDecorators, m, node, parent2));
-      case 230 /* ClassExpression */:
+      case 231 /* ClassExpression */:
         return !useLegacyDecorators && some(node.members, (m) => nodeOrChildIsDecorated(useLegacyDecorators, m, node, parent2));
-      case 173 /* MethodDeclaration */:
-      case 177 /* SetAccessor */:
-      case 175 /* Constructor */:
+      case 174 /* MethodDeclaration */:
+      case 178 /* SetAccessor */:
+      case 176 /* Constructor */:
         return some(node.parameters, (p) => nodeIsDecorated(useLegacyDecorators, p, node, parent2));
       default:
         return false;
@@ -114114,7 +96396,7 @@ ${lanes.join("\n")}
   }
   function isJSXTagName(node) {
     const { parent: parent2 } = node;
-    if (parent2.kind === 285 /* JsxOpeningElement */ || parent2.kind === 284 /* JsxSelfClosingElement */ || parent2.kind === 286 /* JsxClosingElement */) {
+    if (parent2.kind === 286 /* JsxOpeningElement */ || parent2.kind === 285 /* JsxSelfClosingElement */ || parent2.kind === 287 /* JsxClosingElement */) {
       return parent2.tagName === node;
     }
     return false;
@@ -114126,54 +96408,54 @@ ${lanes.join("\n")}
       case 112 /* TrueKeyword */:
       case 97 /* FalseKeyword */:
       case 14 /* RegularExpressionLiteral */:
-      case 208 /* ArrayLiteralExpression */:
-      case 209 /* ObjectLiteralExpression */:
-      case 210 /* PropertyAccessExpression */:
-      case 211 /* ElementAccessExpression */:
-      case 212 /* CallExpression */:
-      case 213 /* NewExpression */:
-      case 214 /* TaggedTemplateExpression */:
-      case 233 /* AsExpression */:
-      case 215 /* TypeAssertionExpression */:
-      case 237 /* SatisfiesExpression */:
-      case 234 /* NonNullExpression */:
-      case 216 /* ParenthesizedExpression */:
-      case 217 /* FunctionExpression */:
-      case 230 /* ClassExpression */:
-      case 218 /* ArrowFunction */:
-      case 221 /* VoidExpression */:
-      case 219 /* DeleteExpression */:
-      case 220 /* TypeOfExpression */:
-      case 223 /* PrefixUnaryExpression */:
-      case 224 /* PostfixUnaryExpression */:
-      case 225 /* BinaryExpression */:
-      case 226 /* ConditionalExpression */:
-      case 229 /* SpreadElement */:
-      case 227 /* TemplateExpression */:
-      case 231 /* OmittedExpression */:
-      case 283 /* JsxElement */:
-      case 284 /* JsxSelfClosingElement */:
-      case 287 /* JsxFragment */:
-      case 228 /* YieldExpression */:
-      case 222 /* AwaitExpression */:
-      case 235 /* MetaProperty */:
+      case 209 /* ArrayLiteralExpression */:
+      case 210 /* ObjectLiteralExpression */:
+      case 211 /* PropertyAccessExpression */:
+      case 212 /* ElementAccessExpression */:
+      case 213 /* CallExpression */:
+      case 214 /* NewExpression */:
+      case 215 /* TaggedTemplateExpression */:
+      case 234 /* AsExpression */:
+      case 216 /* TypeAssertionExpression */:
+      case 238 /* SatisfiesExpression */:
+      case 235 /* NonNullExpression */:
+      case 217 /* ParenthesizedExpression */:
+      case 218 /* FunctionExpression */:
+      case 231 /* ClassExpression */:
+      case 219 /* ArrowFunction */:
+      case 222 /* VoidExpression */:
+      case 220 /* DeleteExpression */:
+      case 221 /* TypeOfExpression */:
+      case 224 /* PrefixUnaryExpression */:
+      case 225 /* PostfixUnaryExpression */:
+      case 226 /* BinaryExpression */:
+      case 227 /* ConditionalExpression */:
+      case 230 /* SpreadElement */:
+      case 228 /* TemplateExpression */:
+      case 232 /* OmittedExpression */:
+      case 284 /* JsxElement */:
+      case 285 /* JsxSelfClosingElement */:
+      case 288 /* JsxFragment */:
+      case 229 /* YieldExpression */:
+      case 223 /* AwaitExpression */:
+      case 236 /* MetaProperty */:
         return true;
-      case 232 /* ExpressionWithTypeArguments */:
+      case 233 /* ExpressionWithTypeArguments */:
         return !isHeritageClause(node.parent) && !isJSDocAugmentsTag(node.parent);
-      case 165 /* QualifiedName */:
-        while (node.parent.kind === 165 /* QualifiedName */) {
+      case 166 /* QualifiedName */:
+        while (node.parent.kind === 166 /* QualifiedName */) {
           node = node.parent;
         }
-        return node.parent.kind === 185 /* TypeQuery */ || isJSDocLinkLike(node.parent) || isJSDocNameReference(node.parent) || isJSDocMemberName(node.parent) || isJSXTagName(node);
-      case 317 /* JSDocMemberName */:
+        return node.parent.kind === 186 /* TypeQuery */ || isJSDocLinkLike(node.parent) || isJSDocNameReference(node.parent) || isJSDocMemberName(node.parent) || isJSXTagName(node);
+      case 318 /* JSDocMemberName */:
         while (isJSDocMemberName(node.parent)) {
           node = node.parent;
         }
-        return node.parent.kind === 185 /* TypeQuery */ || isJSDocLinkLike(node.parent) || isJSDocNameReference(node.parent) || isJSDocMemberName(node.parent) || isJSXTagName(node);
+        return node.parent.kind === 186 /* TypeQuery */ || isJSDocLinkLike(node.parent) || isJSDocNameReference(node.parent) || isJSDocMemberName(node.parent) || isJSXTagName(node);
       case 81 /* PrivateIdentifier */:
         return isBinaryExpression(node.parent) && node.parent.left === node && node.parent.operatorToken.kind === 103 /* InKeyword */;
       case 80 /* Identifier */:
-        if (node.parent.kind === 185 /* TypeQuery */ || isJSDocLinkLike(node.parent) || isJSDocNameReference(node.parent) || isJSDocMemberName(node.parent) || isJSXTagName(node)) {
+        if (node.parent.kind === 186 /* TypeQuery */ || isJSDocLinkLike(node.parent) || isJSDocNameReference(node.parent) || isJSDocMemberName(node.parent) || isJSXTagName(node)) {
           return true;
         }
       case 9 /* NumericLiteral */:
@@ -114189,64 +96471,64 @@ ${lanes.join("\n")}
   function isInExpressionContext(node) {
     const { parent: parent2 } = node;
     switch (parent2.kind) {
-      case 259 /* VariableDeclaration */:
-      case 168 /* Parameter */:
-      case 171 /* PropertyDeclaration */:
-      case 170 /* PropertySignature */:
-      case 305 /* EnumMember */:
-      case 302 /* PropertyAssignment */:
-      case 207 /* BindingElement */:
+      case 260 /* VariableDeclaration */:
+      case 169 /* Parameter */:
+      case 172 /* PropertyDeclaration */:
+      case 171 /* PropertySignature */:
+      case 306 /* EnumMember */:
+      case 303 /* PropertyAssignment */:
+      case 208 /* BindingElement */:
         return parent2.initializer === node;
-      case 243 /* ExpressionStatement */:
-      case 244 /* IfStatement */:
-      case 245 /* DoStatement */:
-      case 246 /* WhileStatement */:
-      case 252 /* ReturnStatement */:
-      case 253 /* WithStatement */:
-      case 254 /* SwitchStatement */:
-      case 295 /* CaseClause */:
-      case 256 /* ThrowStatement */:
+      case 244 /* ExpressionStatement */:
+      case 245 /* IfStatement */:
+      case 246 /* DoStatement */:
+      case 247 /* WhileStatement */:
+      case 253 /* ReturnStatement */:
+      case 254 /* WithStatement */:
+      case 255 /* SwitchStatement */:
+      case 296 /* CaseClause */:
+      case 257 /* ThrowStatement */:
         return parent2.expression === node;
-      case 247 /* ForStatement */:
+      case 248 /* ForStatement */:
         const forStatement = parent2;
-        return forStatement.initializer === node && forStatement.initializer.kind !== 260 /* VariableDeclarationList */ || forStatement.condition === node || forStatement.incrementor === node;
-      case 248 /* ForInStatement */:
-      case 249 /* ForOfStatement */:
-        const forInStatement = parent2;
-        return forInStatement.initializer === node && forInStatement.initializer.kind !== 260 /* VariableDeclarationList */ || forInStatement.expression === node;
-      case 215 /* TypeAssertionExpression */:
-      case 233 /* AsExpression */:
+        return forStatement.initializer === node && forStatement.initializer.kind !== 261 /* VariableDeclarationList */ || forStatement.condition === node || forStatement.incrementor === node;
+      case 249 /* ForInStatement */:
+      case 250 /* ForOfStatement */:
+        const forInOrOfStatement = parent2;
+        return forInOrOfStatement.initializer === node && forInOrOfStatement.initializer.kind !== 261 /* VariableDeclarationList */ || forInOrOfStatement.expression === node;
+      case 216 /* TypeAssertionExpression */:
+      case 234 /* AsExpression */:
         return node === parent2.expression;
-      case 238 /* TemplateSpan */:
+      case 239 /* TemplateSpan */:
         return node === parent2.expression;
-      case 166 /* ComputedPropertyName */:
+      case 167 /* ComputedPropertyName */:
         return node === parent2.expression;
-      case 169 /* Decorator */:
-      case 293 /* JsxExpression */:
-      case 292 /* JsxSpreadAttribute */:
-      case 304 /* SpreadAssignment */:
+      case 170 /* Decorator */:
+      case 294 /* JsxExpression */:
+      case 293 /* JsxSpreadAttribute */:
+      case 305 /* SpreadAssignment */:
         return true;
-      case 232 /* ExpressionWithTypeArguments */:
+      case 233 /* ExpressionWithTypeArguments */:
         return parent2.expression === node && !isPartOfTypeNode(parent2);
-      case 303 /* ShorthandPropertyAssignment */:
+      case 304 /* ShorthandPropertyAssignment */:
         return parent2.objectAssignmentInitializer === node;
-      case 237 /* SatisfiesExpression */:
+      case 238 /* SatisfiesExpression */:
         return node === parent2.expression;
       default:
         return isExpressionNode(parent2);
     }
   }
   function isPartOfTypeQuery(node) {
-    while (node.kind === 165 /* QualifiedName */ || node.kind === 80 /* Identifier */) {
+    while (node.kind === 166 /* QualifiedName */ || node.kind === 80 /* Identifier */) {
       node = node.parent;
     }
-    return node.kind === 185 /* TypeQuery */;
+    return node.kind === 186 /* TypeQuery */;
   }
   function isNamespaceReexportDeclaration(node) {
     return isNamespaceExport(node) && !!node.parent.moduleSpecifier;
   }
   function isExternalModuleImportEqualsDeclaration(node) {
-    return node.kind === 270 /* ImportEqualsDeclaration */ && node.moduleReference.kind === 282 /* ExternalModuleReference */;
+    return node.kind === 271 /* ImportEqualsDeclaration */ && node.moduleReference.kind === 283 /* ExternalModuleReference */;
   }
   function getExternalModuleImportEqualsDeclarationExpression(node) {
     Debug.assert(isExternalModuleImportEqualsDeclaration(node));
@@ -114256,7 +96538,7 @@ ${lanes.join("\n")}
     return isVariableDeclarationInitializedToBareOrAccessedRequire(node) && getLeftmostAccessExpression(node.initializer).arguments[0];
   }
   function isInternalModuleImportEqualsDeclaration(node) {
-    return node.kind === 270 /* ImportEqualsDeclaration */ && node.moduleReference.kind !== 282 /* ExternalModuleReference */;
+    return node.kind === 271 /* ImportEqualsDeclaration */ && node.moduleReference.kind !== 283 /* ExternalModuleReference */;
   }
   function isSourceFileJS(file) {
     return isInJSFile(file);
@@ -114265,22 +96547,22 @@ ${lanes.join("\n")}
     return !isInJSFile(file);
   }
   function isInJSFile(node) {
-    return !!node && !!(node.flags & 262144 /* JavaScriptFile */);
+    return !!node && !!(node.flags & 524288 /* JavaScriptFile */);
   }
   function isInJsonFile(node) {
-    return !!node && !!(node.flags & 67108864 /* JsonFile */);
+    return !!node && !!(node.flags & 134217728 /* JsonFile */);
   }
   function isSourceFileNotJson(file) {
     return !isJsonSourceFile(file);
   }
   function isInJSDoc(node) {
-    return !!node && !!(node.flags & 8388608 /* JSDoc */);
+    return !!node && !!(node.flags & 16777216 /* JSDoc */);
   }
   function isJSDocIndexSignature(node) {
     return isTypeReferenceNode(node) && isIdentifier(node.typeName) && node.typeName.escapedText === "Object" && node.typeArguments && node.typeArguments.length === 2 && (node.typeArguments[0].kind === 154 /* StringKeyword */ || node.typeArguments[0].kind === 150 /* NumberKeyword */);
   }
   function isRequireCall(callExpression, requireStringLiteralLikeArgument) {
-    if (callExpression.kind !== 212 /* CallExpression */) {
+    if (callExpression.kind !== 213 /* CallExpression */) {
       return false;
     }
     const { expression, arguments: args } = callExpression;
@@ -114357,9 +96639,9 @@ ${lanes.join("\n")}
   function getExpandoInitializer(initializer, isPrototypeAssignment) {
     if (isCallExpression(initializer)) {
       const e = skipParentheses(initializer.expression);
-      return e.kind === 217 /* FunctionExpression */ || e.kind === 218 /* ArrowFunction */ ? initializer : void 0;
+      return e.kind === 218 /* FunctionExpression */ || e.kind === 219 /* ArrowFunction */ ? initializer : void 0;
     }
-    if (initializer.kind === 217 /* FunctionExpression */ || initializer.kind === 230 /* ClassExpression */ || initializer.kind === 218 /* ArrowFunction */) {
+    if (initializer.kind === 218 /* FunctionExpression */ || initializer.kind === 231 /* ClassExpression */ || initializer.kind === 219 /* ArrowFunction */) {
       return initializer;
     }
     if (isObjectLiteralExpression(initializer) && (initializer.properties.length === 0 || isPrototypeAssignment)) {
@@ -114550,11 +96832,11 @@ ${lanes.join("\n")}
     return isBinaryExpression(node) && getAssignmentDeclarationKind(node) === 3 /* PrototypeProperty */;
   }
   function isSpecialPropertyDeclaration(expr) {
-    return isInJSFile(expr) && expr.parent && expr.parent.kind === 243 /* ExpressionStatement */ && (!isElementAccessExpression(expr) || isLiteralLikeElementAccess(expr)) && !!getJSDocTypeTag(expr.parent);
+    return isInJSFile(expr) && expr.parent && expr.parent.kind === 244 /* ExpressionStatement */ && (!isElementAccessExpression(expr) || isLiteralLikeElementAccess(expr)) && !!getJSDocTypeTag(expr.parent);
   }
   function setValueDeclaration(symbol, node) {
     const { valueDeclaration } = symbol;
-    if (!valueDeclaration || !(node.flags & 16777216 /* Ambient */ && !isInJSFile(node) && !(valueDeclaration.flags & 16777216 /* Ambient */)) && (isAssignmentDeclaration(valueDeclaration) && !isAssignmentDeclaration(node)) || valueDeclaration.kind !== node.kind && isEffectiveModuleDeclaration(valueDeclaration)) {
+    if (!valueDeclaration || !(node.flags & 33554432 /* Ambient */ && !isInJSFile(node) && !(valueDeclaration.flags & 33554432 /* Ambient */)) && (isAssignmentDeclaration(valueDeclaration) && !isAssignmentDeclaration(node)) || valueDeclaration.kind !== node.kind && isEffectiveModuleDeclaration(valueDeclaration)) {
       symbol.valueDeclaration = node;
     }
   }
@@ -114563,30 +96845,33 @@ ${lanes.join("\n")}
       return false;
     }
     const decl = symbol.valueDeclaration;
-    return decl.kind === 261 /* FunctionDeclaration */ || isVariableDeclaration(decl) && decl.initializer && isFunctionLike(decl.initializer);
+    return decl.kind === 262 /* FunctionDeclaration */ || isVariableDeclaration(decl) && decl.initializer && isFunctionLike(decl.initializer);
   }
   function tryGetModuleSpecifierFromDeclaration(node) {
     var _a, _b;
     switch (node.kind) {
-      case 259 /* VariableDeclaration */:
-      case 207 /* BindingElement */:
+      case 260 /* VariableDeclaration */:
+      case 208 /* BindingElement */:
         return (_a = findAncestor(node.initializer, (node2) => isRequireCall(
           node2,
           /*requireStringLiteralLikeArgument*/
           true
         ))) == null ? void 0 : _a.arguments[0];
-      case 271 /* ImportDeclaration */:
+      case 272 /* ImportDeclaration */:
+      case 278 /* ExportDeclaration */:
         return tryCast(node.moduleSpecifier, isStringLiteralLike);
-      case 270 /* ImportEqualsDeclaration */:
+      case 271 /* ImportEqualsDeclaration */:
         return tryCast((_b = tryCast(node.moduleReference, isExternalModuleReference)) == null ? void 0 : _b.expression, isStringLiteralLike);
-      case 272 /* ImportClause */:
-      case 279 /* NamespaceExport */:
+      case 273 /* ImportClause */:
+      case 280 /* NamespaceExport */:
         return tryCast(node.parent.moduleSpecifier, isStringLiteralLike);
-      case 273 /* NamespaceImport */:
-      case 280 /* ExportSpecifier */:
+      case 274 /* NamespaceImport */:
+      case 281 /* ExportSpecifier */:
         return tryCast(node.parent.parent.moduleSpecifier, isStringLiteralLike);
-      case 275 /* ImportSpecifier */:
+      case 276 /* ImportSpecifier */:
         return tryCast(node.parent.parent.parent.moduleSpecifier, isStringLiteralLike);
+      case 205 /* ImportType */:
+        return isLiteralImportTypeNode(node) ? node.argument.literal : void 0;
       default:
         Debug.assertNever(node);
     }
@@ -114596,18 +96881,18 @@ ${lanes.join("\n")}
   }
   function tryGetImportFromModuleSpecifier(node) {
     switch (node.parent.kind) {
-      case 271 /* ImportDeclaration */:
-      case 277 /* ExportDeclaration */:
+      case 272 /* ImportDeclaration */:
+      case 278 /* ExportDeclaration */:
         return node.parent;
-      case 282 /* ExternalModuleReference */:
+      case 283 /* ExternalModuleReference */:
         return node.parent.parent;
-      case 212 /* CallExpression */:
+      case 213 /* CallExpression */:
         return isImportCall(node.parent) || isRequireCall(
           node.parent,
           /*requireStringLiteralLikeArgument*/
           false
         ) ? node.parent : void 0;
-      case 200 /* LiteralType */:
+      case 201 /* LiteralType */:
         Debug.assert(isStringLiteral(node));
         return tryCast(node.parent.parent, isImportTypeNode);
       default:
@@ -114616,16 +96901,16 @@ ${lanes.join("\n")}
   }
   function getExternalModuleName(node) {
     switch (node.kind) {
-      case 271 /* ImportDeclaration */:
-      case 277 /* ExportDeclaration */:
+      case 272 /* ImportDeclaration */:
+      case 278 /* ExportDeclaration */:
         return node.moduleSpecifier;
-      case 270 /* ImportEqualsDeclaration */:
-        return node.moduleReference.kind === 282 /* ExternalModuleReference */ ? node.moduleReference.expression : void 0;
-      case 204 /* ImportType */:
+      case 271 /* ImportEqualsDeclaration */:
+        return node.moduleReference.kind === 283 /* ExternalModuleReference */ ? node.moduleReference.expression : void 0;
+      case 205 /* ImportType */:
         return isLiteralImportTypeNode(node) ? node.argument.literal : void 0;
-      case 212 /* CallExpression */:
+      case 213 /* CallExpression */:
         return node.arguments[0];
-      case 266 /* ModuleDeclaration */:
+      case 267 /* ModuleDeclaration */:
         return node.name.kind === 11 /* StringLiteral */ ? node.name : void 0;
       default:
         return Debug.assertNever(node);
@@ -114633,18 +96918,18 @@ ${lanes.join("\n")}
   }
   function getNamespaceDeclarationNode(node) {
     switch (node.kind) {
-      case 271 /* ImportDeclaration */:
+      case 272 /* ImportDeclaration */:
         return node.importClause && tryCast(node.importClause.namedBindings, isNamespaceImport);
-      case 270 /* ImportEqualsDeclaration */:
+      case 271 /* ImportEqualsDeclaration */:
         return node;
-      case 277 /* ExportDeclaration */:
+      case 278 /* ExportDeclaration */:
         return node.exportClause && tryCast(node.exportClause, isNamespaceExport);
       default:
         return Debug.assertNever(node);
     }
   }
   function isDefaultImport(node) {
-    return node.kind === 271 /* ImportDeclaration */ && !!node.importClause && !!node.importClause.name;
+    return node.kind === 272 /* ImportDeclaration */ && !!node.importClause && !!node.importClause.name;
   }
   function forEachImportClauseDeclaration(node, action) {
     if (node.name) {
@@ -114661,13 +96946,13 @@ ${lanes.join("\n")}
   function hasQuestionToken(node) {
     if (node) {
       switch (node.kind) {
-        case 168 /* Parameter */:
-        case 173 /* MethodDeclaration */:
-        case 172 /* MethodSignature */:
-        case 303 /* ShorthandPropertyAssignment */:
-        case 302 /* PropertyAssignment */:
-        case 171 /* PropertyDeclaration */:
-        case 170 /* PropertySignature */:
+        case 169 /* Parameter */:
+        case 174 /* MethodDeclaration */:
+        case 173 /* MethodSignature */:
+        case 304 /* ShorthandPropertyAssignment */:
+        case 303 /* PropertyAssignment */:
+        case 172 /* PropertyDeclaration */:
+        case 171 /* PropertySignature */:
           return node.questionToken !== void 0;
       }
     }
@@ -114679,7 +96964,7 @@ ${lanes.join("\n")}
     return !!name && name.escapedText === "new";
   }
   function isJSDocTypeAlias(node) {
-    return node.kind === 352 /* JSDocTypedefTag */ || node.kind === 344 /* JSDocCallbackTag */ || node.kind === 346 /* JSDocEnumTag */;
+    return node.kind === 353 /* JSDocTypedefTag */ || node.kind === 345 /* JSDocCallbackTag */ || node.kind === 347 /* JSDocEnumTag */;
   }
   function isTypeAlias(node) {
     return isJSDocTypeAlias(node) || isTypeAliasDeclaration(node);
@@ -114692,12 +96977,12 @@ ${lanes.join("\n")}
   }
   function getSingleInitializerOfVariableStatementOrPropertyDeclaration(node) {
     switch (node.kind) {
-      case 242 /* VariableStatement */:
+      case 243 /* VariableStatement */:
         const v = getSingleVariableOfVariableStatement(node);
         return v && v.initializer;
-      case 171 /* PropertyDeclaration */:
+      case 172 /* PropertyDeclaration */:
         return node.initializer;
-      case 302 /* PropertyAssignment */:
+      case 303 /* PropertyAssignment */:
         return node.initializer;
     }
   }
@@ -114705,26 +96990,26 @@ ${lanes.join("\n")}
     return isVariableStatement(node) ? firstOrUndefined(node.declarationList.declarations) : void 0;
   }
   function getNestedModuleDeclaration(node) {
-    return isModuleDeclaration(node) && node.body && node.body.kind === 266 /* ModuleDeclaration */ ? node.body : void 0;
+    return isModuleDeclaration(node) && node.body && node.body.kind === 267 /* ModuleDeclaration */ ? node.body : void 0;
   }
   function canHaveFlowNode(node) {
-    if (node.kind >= 242 /* FirstStatement */ && node.kind <= 258 /* LastStatement */) {
+    if (node.kind >= 243 /* FirstStatement */ && node.kind <= 259 /* LastStatement */) {
       return true;
     }
     switch (node.kind) {
       case 80 /* Identifier */:
       case 110 /* ThisKeyword */:
       case 108 /* SuperKeyword */:
-      case 165 /* QualifiedName */:
-      case 235 /* MetaProperty */:
-      case 211 /* ElementAccessExpression */:
-      case 210 /* PropertyAccessExpression */:
-      case 207 /* BindingElement */:
-      case 217 /* FunctionExpression */:
-      case 218 /* ArrowFunction */:
-      case 173 /* MethodDeclaration */:
-      case 176 /* GetAccessor */:
-      case 177 /* SetAccessor */:
+      case 166 /* QualifiedName */:
+      case 236 /* MetaProperty */:
+      case 212 /* ElementAccessExpression */:
+      case 211 /* PropertyAccessExpression */:
+      case 208 /* BindingElement */:
+      case 218 /* FunctionExpression */:
+      case 219 /* ArrowFunction */:
+      case 174 /* MethodDeclaration */:
+      case 177 /* GetAccessor */:
+      case 178 /* SetAccessor */:
         return true;
       default:
         return false;
@@ -114732,72 +97017,72 @@ ${lanes.join("\n")}
   }
   function canHaveJSDoc(node) {
     switch (node.kind) {
-      case 218 /* ArrowFunction */:
-      case 225 /* BinaryExpression */:
-      case 240 /* Block */:
-      case 251 /* BreakStatement */:
-      case 178 /* CallSignature */:
-      case 295 /* CaseClause */:
-      case 262 /* ClassDeclaration */:
-      case 230 /* ClassExpression */:
-      case 174 /* ClassStaticBlockDeclaration */:
-      case 175 /* Constructor */:
-      case 184 /* ConstructorType */:
-      case 179 /* ConstructSignature */:
-      case 250 /* ContinueStatement */:
-      case 258 /* DebuggerStatement */:
-      case 245 /* DoStatement */:
-      case 211 /* ElementAccessExpression */:
-      case 241 /* EmptyStatement */:
+      case 219 /* ArrowFunction */:
+      case 226 /* BinaryExpression */:
+      case 241 /* Block */:
+      case 252 /* BreakStatement */:
+      case 179 /* CallSignature */:
+      case 296 /* CaseClause */:
+      case 263 /* ClassDeclaration */:
+      case 231 /* ClassExpression */:
+      case 175 /* ClassStaticBlockDeclaration */:
+      case 176 /* Constructor */:
+      case 185 /* ConstructorType */:
+      case 180 /* ConstructSignature */:
+      case 251 /* ContinueStatement */:
+      case 259 /* DebuggerStatement */:
+      case 246 /* DoStatement */:
+      case 212 /* ElementAccessExpression */:
+      case 242 /* EmptyStatement */:
       case 1 /* EndOfFileToken */:
-      case 265 /* EnumDeclaration */:
-      case 305 /* EnumMember */:
-      case 276 /* ExportAssignment */:
-      case 277 /* ExportDeclaration */:
-      case 280 /* ExportSpecifier */:
-      case 243 /* ExpressionStatement */:
-      case 248 /* ForInStatement */:
-      case 249 /* ForOfStatement */:
-      case 247 /* ForStatement */:
-      case 261 /* FunctionDeclaration */:
-      case 217 /* FunctionExpression */:
-      case 183 /* FunctionType */:
-      case 176 /* GetAccessor */:
+      case 266 /* EnumDeclaration */:
+      case 306 /* EnumMember */:
+      case 277 /* ExportAssignment */:
+      case 278 /* ExportDeclaration */:
+      case 281 /* ExportSpecifier */:
+      case 244 /* ExpressionStatement */:
+      case 249 /* ForInStatement */:
+      case 250 /* ForOfStatement */:
+      case 248 /* ForStatement */:
+      case 262 /* FunctionDeclaration */:
+      case 218 /* FunctionExpression */:
+      case 184 /* FunctionType */:
+      case 177 /* GetAccessor */:
       case 80 /* Identifier */:
-      case 244 /* IfStatement */:
-      case 271 /* ImportDeclaration */:
-      case 270 /* ImportEqualsDeclaration */:
-      case 180 /* IndexSignature */:
-      case 263 /* InterfaceDeclaration */:
-      case 323 /* JSDocFunctionType */:
-      case 329 /* JSDocSignature */:
-      case 255 /* LabeledStatement */:
-      case 173 /* MethodDeclaration */:
-      case 172 /* MethodSignature */:
-      case 266 /* ModuleDeclaration */:
-      case 201 /* NamedTupleMember */:
-      case 269 /* NamespaceExportDeclaration */:
-      case 209 /* ObjectLiteralExpression */:
-      case 168 /* Parameter */:
-      case 216 /* ParenthesizedExpression */:
-      case 210 /* PropertyAccessExpression */:
-      case 302 /* PropertyAssignment */:
-      case 171 /* PropertyDeclaration */:
-      case 170 /* PropertySignature */:
-      case 252 /* ReturnStatement */:
-      case 239 /* SemicolonClassElement */:
-      case 177 /* SetAccessor */:
-      case 303 /* ShorthandPropertyAssignment */:
-      case 304 /* SpreadAssignment */:
-      case 254 /* SwitchStatement */:
-      case 256 /* ThrowStatement */:
-      case 257 /* TryStatement */:
-      case 264 /* TypeAliasDeclaration */:
-      case 167 /* TypeParameter */:
-      case 259 /* VariableDeclaration */:
-      case 242 /* VariableStatement */:
-      case 246 /* WhileStatement */:
-      case 253 /* WithStatement */:
+      case 245 /* IfStatement */:
+      case 272 /* ImportDeclaration */:
+      case 271 /* ImportEqualsDeclaration */:
+      case 181 /* IndexSignature */:
+      case 264 /* InterfaceDeclaration */:
+      case 324 /* JSDocFunctionType */:
+      case 330 /* JSDocSignature */:
+      case 256 /* LabeledStatement */:
+      case 174 /* MethodDeclaration */:
+      case 173 /* MethodSignature */:
+      case 267 /* ModuleDeclaration */:
+      case 202 /* NamedTupleMember */:
+      case 270 /* NamespaceExportDeclaration */:
+      case 210 /* ObjectLiteralExpression */:
+      case 169 /* Parameter */:
+      case 217 /* ParenthesizedExpression */:
+      case 211 /* PropertyAccessExpression */:
+      case 303 /* PropertyAssignment */:
+      case 172 /* PropertyDeclaration */:
+      case 171 /* PropertySignature */:
+      case 253 /* ReturnStatement */:
+      case 240 /* SemicolonClassElement */:
+      case 178 /* SetAccessor */:
+      case 304 /* ShorthandPropertyAssignment */:
+      case 305 /* SpreadAssignment */:
+      case 255 /* SwitchStatement */:
+      case 257 /* ThrowStatement */:
+      case 258 /* TryStatement */:
+      case 265 /* TypeAliasDeclaration */:
+      case 168 /* TypeParameter */:
+      case 260 /* VariableDeclaration */:
+      case 243 /* VariableStatement */:
+      case 247 /* WhileStatement */:
+      case 254 /* WithStatement */:
         return true;
       default:
         return false;
@@ -114813,11 +97098,11 @@ ${lanes.join("\n")}
       if (hasJSDocNodes(node)) {
         result = addRange(result, filterOwnedJSDocTags(hostNode, last(node.jsDoc)));
       }
-      if (node.kind === 168 /* Parameter */) {
+      if (node.kind === 169 /* Parameter */) {
         result = addRange(result, (noCache ? getJSDocParameterTagsNoCache : getJSDocParameterTags)(node));
         break;
       }
-      if (node.kind === 167 /* TypeParameter */) {
+      if (node.kind === 168 /* TypeParameter */) {
         result = addRange(result, (noCache ? getJSDocTypeParameterTagsNoCache : getJSDocTypeParameterTags)(node));
         break;
       }
@@ -114837,9 +97122,9 @@ ${lanes.join("\n")}
   }
   function getNextJSDocCommentLocation(node) {
     const parent2 = node.parent;
-    if (parent2.kind === 302 /* PropertyAssignment */ || parent2.kind === 276 /* ExportAssignment */ || parent2.kind === 171 /* PropertyDeclaration */ || parent2.kind === 243 /* ExpressionStatement */ && node.kind === 210 /* PropertyAccessExpression */ || parent2.kind === 252 /* ReturnStatement */ || getNestedModuleDeclaration(parent2) || isBinaryExpression(node) && node.operatorToken.kind === 64 /* EqualsToken */) {
+    if (parent2.kind === 303 /* PropertyAssignment */ || parent2.kind === 277 /* ExportAssignment */ || parent2.kind === 172 /* PropertyDeclaration */ || parent2.kind === 244 /* ExpressionStatement */ && node.kind === 211 /* PropertyAccessExpression */ || parent2.kind === 253 /* ReturnStatement */ || getNestedModuleDeclaration(parent2) || isAssignmentExpression(node)) {
       return parent2;
-    } else if (parent2.parent && (getSingleVariableOfVariableStatement(parent2.parent) === node || isBinaryExpression(parent2) && parent2.operatorToken.kind === 64 /* EqualsToken */)) {
+    } else if (parent2.parent && (getSingleVariableOfVariableStatement(parent2.parent) === node || isAssignmentExpression(parent2))) {
       return parent2.parent;
     } else if (parent2.parent && parent2.parent.parent && (getSingleVariableOfVariableStatement(parent2.parent.parent) || getSingleInitializerOfVariableStatementOrPropertyDeclaration(parent2.parent.parent) === node || getSourceOfDefaultedAssignment(parent2.parent.parent))) {
       return parent2.parent.parent;
@@ -114903,68 +97188,100 @@ ${lanes.join("\n")}
   function hasTypeArguments(node) {
     return !!node.typeArguments;
   }
-  function getAssignmentTargetKind(node) {
+  function getAssignmentTarget(node) {
     let parent2 = node.parent;
     while (true) {
       switch (parent2.kind) {
-        case 225 /* BinaryExpression */:
-          const binaryOperator = parent2.operatorToken.kind;
-          return isAssignmentOperator(binaryOperator) && parent2.left === node ? binaryOperator === 64 /* EqualsToken */ || isLogicalOrCoalescingAssignmentOperator(binaryOperator) ? 1 /* Definite */ : 2 /* Compound */ : 0 /* None */;
-        case 223 /* PrefixUnaryExpression */:
-        case 224 /* PostfixUnaryExpression */:
-          const unaryOperator = parent2.operator;
-          return unaryOperator === 46 /* PlusPlusToken */ || unaryOperator === 47 /* MinusMinusToken */ ? 2 /* Compound */ : 0 /* None */;
-        case 248 /* ForInStatement */:
-        case 249 /* ForOfStatement */:
-          return parent2.initializer === node ? 1 /* Definite */ : 0 /* None */;
-        case 216 /* ParenthesizedExpression */:
-        case 208 /* ArrayLiteralExpression */:
-        case 229 /* SpreadElement */:
-        case 234 /* NonNullExpression */:
+        case 226 /* BinaryExpression */:
+          const binaryExpression = parent2;
+          const binaryOperator = binaryExpression.operatorToken.kind;
+          return isAssignmentOperator(binaryOperator) && binaryExpression.left === node ? binaryExpression : void 0;
+        case 224 /* PrefixUnaryExpression */:
+        case 225 /* PostfixUnaryExpression */:
+          const unaryExpression = parent2;
+          const unaryOperator = unaryExpression.operator;
+          return unaryOperator === 46 /* PlusPlusToken */ || unaryOperator === 47 /* MinusMinusToken */ ? unaryExpression : void 0;
+        case 249 /* ForInStatement */:
+        case 250 /* ForOfStatement */:
+          const forInOrOfStatement = parent2;
+          return forInOrOfStatement.initializer === node ? forInOrOfStatement : void 0;
+        case 217 /* ParenthesizedExpression */:
+        case 209 /* ArrayLiteralExpression */:
+        case 230 /* SpreadElement */:
+        case 235 /* NonNullExpression */:
           node = parent2;
           break;
-        case 304 /* SpreadAssignment */:
+        case 305 /* SpreadAssignment */:
           node = parent2.parent;
           break;
-        case 303 /* ShorthandPropertyAssignment */:
+        case 304 /* ShorthandPropertyAssignment */:
           if (parent2.name !== node) {
-            return 0 /* None */;
+            return void 0;
           }
           node = parent2.parent;
           break;
-        case 302 /* PropertyAssignment */:
+        case 303 /* PropertyAssignment */:
           if (parent2.name === node) {
-            return 0 /* None */;
+            return void 0;
           }
           node = parent2.parent;
           break;
         default:
-          return 0 /* None */;
+          return void 0;
       }
       parent2 = node.parent;
     }
   }
+  function getAssignmentTargetKind(node) {
+    const target = getAssignmentTarget(node);
+    if (!target) {
+      return 0 /* None */;
+    }
+    switch (target.kind) {
+      case 226 /* BinaryExpression */:
+        const binaryOperator = target.operatorToken.kind;
+        return binaryOperator === 64 /* EqualsToken */ || isLogicalOrCoalescingAssignmentOperator(binaryOperator) ? 1 /* Definite */ : 2 /* Compound */;
+      case 224 /* PrefixUnaryExpression */:
+      case 225 /* PostfixUnaryExpression */:
+        return 2 /* Compound */;
+      case 249 /* ForInStatement */:
+      case 250 /* ForOfStatement */:
+        return 1 /* Definite */;
+    }
+  }
   function isAssignmentTarget(node) {
-    return getAssignmentTargetKind(node) !== 0 /* None */;
+    return !!getAssignmentTarget(node);
+  }
+  function isCompoundLikeAssignment(assignment) {
+    const right = skipParentheses(assignment.right);
+    return right.kind === 226 /* BinaryExpression */ && isShiftOperatorOrHigher(right.operatorToken.kind);
+  }
+  function isInCompoundLikeAssignment(node) {
+    const target = getAssignmentTarget(node);
+    return !!target && isAssignmentExpression(
+      target,
+      /*excludeCompoundAssignment*/
+      true
+    ) && isCompoundLikeAssignment(target);
   }
   function isNodeWithPossibleHoistedDeclaration(node) {
     switch (node.kind) {
-      case 240 /* Block */:
-      case 242 /* VariableStatement */:
-      case 253 /* WithStatement */:
-      case 244 /* IfStatement */:
-      case 254 /* SwitchStatement */:
-      case 268 /* CaseBlock */:
-      case 295 /* CaseClause */:
-      case 296 /* DefaultClause */:
-      case 255 /* LabeledStatement */:
-      case 247 /* ForStatement */:
-      case 248 /* ForInStatement */:
-      case 249 /* ForOfStatement */:
-      case 245 /* DoStatement */:
-      case 246 /* WhileStatement */:
-      case 257 /* TryStatement */:
-      case 298 /* CatchClause */:
+      case 241 /* Block */:
+      case 243 /* VariableStatement */:
+      case 254 /* WithStatement */:
+      case 245 /* IfStatement */:
+      case 255 /* SwitchStatement */:
+      case 269 /* CaseBlock */:
+      case 296 /* CaseClause */:
+      case 297 /* DefaultClause */:
+      case 256 /* LabeledStatement */:
+      case 248 /* ForStatement */:
+      case 249 /* ForInStatement */:
+      case 250 /* ForOfStatement */:
+      case 246 /* DoStatement */:
+      case 247 /* WhileStatement */:
+      case 258 /* TryStatement */:
+      case 299 /* CatchClause */:
         return true;
     }
     return false;
@@ -114979,14 +97296,14 @@ ${lanes.join("\n")}
     return node;
   }
   function walkUpParenthesizedTypes(node) {
-    return walkUp(node, 195 /* ParenthesizedType */);
+    return walkUp(node, 196 /* ParenthesizedType */);
   }
   function walkUpParenthesizedExpressions(node) {
-    return walkUp(node, 216 /* ParenthesizedExpression */);
+    return walkUp(node, 217 /* ParenthesizedExpression */);
   }
   function walkUpParenthesizedTypesAndGetParentAndChild(node) {
     let child;
-    while (node && node.kind === 195 /* ParenthesizedType */) {
+    while (node && node.kind === 196 /* ParenthesizedType */) {
       child = node;
       node = node.parent;
     }
@@ -115002,11 +97319,11 @@ ${lanes.join("\n")}
     return skipOuterExpressions(node, flags);
   }
   function isDeleteTarget(node) {
-    if (node.kind !== 210 /* PropertyAccessExpression */ && node.kind !== 211 /* ElementAccessExpression */) {
+    if (node.kind !== 211 /* PropertyAccessExpression */ && node.kind !== 212 /* ElementAccessExpression */) {
       return false;
     }
     node = walkUpParenthesizedExpressions(node.parent);
-    return node && node.kind === 219 /* DeleteExpression */;
+    return node && node.kind === 220 /* DeleteExpression */;
   }
   function isNodeDescendantOf(node, ancestor) {
     while (node) {
@@ -115044,55 +97361,55 @@ ${lanes.join("\n")}
     }
   }
   function isLiteralComputedPropertyDeclarationName(node) {
-    return isStringOrNumericLiteralLike(node) && node.parent.kind === 166 /* ComputedPropertyName */ && isDeclaration(node.parent.parent);
+    return isStringOrNumericLiteralLike(node) && node.parent.kind === 167 /* ComputedPropertyName */ && isDeclaration(node.parent.parent);
   }
   function isIdentifierName(node) {
     const parent2 = node.parent;
     switch (parent2.kind) {
-      case 171 /* PropertyDeclaration */:
-      case 170 /* PropertySignature */:
-      case 173 /* MethodDeclaration */:
-      case 172 /* MethodSignature */:
-      case 176 /* GetAccessor */:
-      case 177 /* SetAccessor */:
-      case 305 /* EnumMember */:
-      case 302 /* PropertyAssignment */:
-      case 210 /* PropertyAccessExpression */:
+      case 172 /* PropertyDeclaration */:
+      case 171 /* PropertySignature */:
+      case 174 /* MethodDeclaration */:
+      case 173 /* MethodSignature */:
+      case 177 /* GetAccessor */:
+      case 178 /* SetAccessor */:
+      case 306 /* EnumMember */:
+      case 303 /* PropertyAssignment */:
+      case 211 /* PropertyAccessExpression */:
         return parent2.name === node;
-      case 165 /* QualifiedName */:
+      case 166 /* QualifiedName */:
         return parent2.right === node;
-      case 207 /* BindingElement */:
-      case 275 /* ImportSpecifier */:
+      case 208 /* BindingElement */:
+      case 276 /* ImportSpecifier */:
         return parent2.propertyName === node;
-      case 280 /* ExportSpecifier */:
-      case 290 /* JsxAttribute */:
-      case 284 /* JsxSelfClosingElement */:
-      case 285 /* JsxOpeningElement */:
-      case 286 /* JsxClosingElement */:
+      case 281 /* ExportSpecifier */:
+      case 291 /* JsxAttribute */:
+      case 285 /* JsxSelfClosingElement */:
+      case 286 /* JsxOpeningElement */:
+      case 287 /* JsxClosingElement */:
         return true;
     }
     return false;
   }
   function isAliasSymbolDeclaration(node) {
-    if (node.kind === 270 /* ImportEqualsDeclaration */ || node.kind === 269 /* NamespaceExportDeclaration */ || node.kind === 272 /* ImportClause */ && !!node.name || node.kind === 273 /* NamespaceImport */ || node.kind === 279 /* NamespaceExport */ || node.kind === 275 /* ImportSpecifier */ || node.kind === 280 /* ExportSpecifier */ || node.kind === 276 /* ExportAssignment */ && exportAssignmentIsAlias(node)) {
+    if (node.kind === 271 /* ImportEqualsDeclaration */ || node.kind === 270 /* NamespaceExportDeclaration */ || node.kind === 273 /* ImportClause */ && !!node.name || node.kind === 274 /* NamespaceImport */ || node.kind === 280 /* NamespaceExport */ || node.kind === 276 /* ImportSpecifier */ || node.kind === 281 /* ExportSpecifier */ || node.kind === 277 /* ExportAssignment */ && exportAssignmentIsAlias(node)) {
       return true;
     }
     return isInJSFile(node) && (isBinaryExpression(node) && getAssignmentDeclarationKind(node) === 2 /* ModuleExports */ && exportAssignmentIsAlias(node) || isPropertyAccessExpression(node) && isBinaryExpression(node.parent) && node.parent.left === node && node.parent.operatorToken.kind === 64 /* EqualsToken */ && isAliasableExpression(node.parent.right));
   }
   function getAliasDeclarationFromName(node) {
     switch (node.parent.kind) {
-      case 272 /* ImportClause */:
-      case 275 /* ImportSpecifier */:
-      case 273 /* NamespaceImport */:
-      case 280 /* ExportSpecifier */:
-      case 276 /* ExportAssignment */:
-      case 270 /* ImportEqualsDeclaration */:
-      case 279 /* NamespaceExport */:
+      case 273 /* ImportClause */:
+      case 276 /* ImportSpecifier */:
+      case 274 /* NamespaceImport */:
+      case 281 /* ExportSpecifier */:
+      case 277 /* ExportAssignment */:
+      case 271 /* ImportEqualsDeclaration */:
+      case 280 /* NamespaceExport */:
         return node.parent;
-      case 165 /* QualifiedName */:
+      case 166 /* QualifiedName */:
         do {
           node = node.parent;
-        } while (node.parent.kind === 165 /* QualifiedName */);
+        } while (node.parent.kind === 166 /* QualifiedName */);
         return getAliasDeclarationFromName(node);
     }
   }
@@ -115107,7 +97424,7 @@ ${lanes.join("\n")}
     return isExportAssignment(node) ? node.expression : node.right;
   }
   function getPropertyAssignmentAliasLikeExpression(node) {
-    return node.kind === 303 /* ShorthandPropertyAssignment */ ? node.name : node.kind === 302 /* PropertyAssignment */ ? node.initializer : node.parent.right;
+    return node.kind === 304 /* ShorthandPropertyAssignment */ ? node.name : node.kind === 303 /* PropertyAssignment */ ? node.initializer : node.parent.right;
   }
   function getEffectiveBaseTypeNode(node) {
     const baseType = getClassExtendsHeritageElement(node);
@@ -115158,7 +97475,7 @@ ${lanes.join("\n")}
     return void 0;
   }
   function isKeyword(token) {
-    return 83 /* FirstKeyword */ <= token && token <= 164 /* LastKeyword */;
+    return 83 /* FirstKeyword */ <= token && token <= 165 /* LastKeyword */;
   }
   function isPunctuation(token) {
     return 19 /* FirstPunctuation */ <= token && token <= 79 /* LastPunctuation */;
@@ -115167,7 +97484,7 @@ ${lanes.join("\n")}
     return isKeyword(token) || isPunctuation(token);
   }
   function isContextualKeyword(token) {
-    return 128 /* FirstContextualKeyword */ <= token && token <= 164 /* LastContextualKeyword */;
+    return 128 /* FirstContextualKeyword */ <= token && token <= 165 /* LastContextualKeyword */;
   }
   function isNonContextualKeyword(token) {
     return isKeyword(token) && !isContextualKeyword(token);
@@ -115196,14 +97513,14 @@ ${lanes.join("\n")}
     }
     let flags = 0 /* Normal */;
     switch (node.kind) {
-      case 261 /* FunctionDeclaration */:
-      case 217 /* FunctionExpression */:
-      case 173 /* MethodDeclaration */:
+      case 262 /* FunctionDeclaration */:
+      case 218 /* FunctionExpression */:
+      case 174 /* MethodDeclaration */:
         if (node.asteriskToken) {
           flags |= 1 /* Generator */;
         }
-      case 218 /* ArrowFunction */:
-        if (hasSyntacticModifier(node, 512 /* Async */)) {
+      case 219 /* ArrowFunction */:
+        if (hasSyntacticModifier(node, 1024 /* Async */)) {
           flags |= 2 /* Async */;
         }
         break;
@@ -115215,11 +97532,11 @@ ${lanes.join("\n")}
   }
   function isAsyncFunction(node) {
     switch (node.kind) {
-      case 261 /* FunctionDeclaration */:
-      case 217 /* FunctionExpression */:
-      case 218 /* ArrowFunction */:
-      case 173 /* MethodDeclaration */:
-        return node.body !== void 0 && node.asteriskToken === void 0 && hasSyntacticModifier(node, 512 /* Async */);
+      case 262 /* FunctionDeclaration */:
+      case 218 /* FunctionExpression */:
+      case 219 /* ArrowFunction */:
+      case 174 /* MethodDeclaration */:
+        return node.body !== void 0 && node.asteriskToken === void 0 && hasSyntacticModifier(node, 1024 /* Async */);
     }
     return false;
   }
@@ -115234,7 +97551,7 @@ ${lanes.join("\n")}
     return !!name && isDynamicName(name);
   }
   function isDynamicName(name) {
-    if (!(name.kind === 166 /* ComputedPropertyName */ || name.kind === 211 /* ElementAccessExpression */)) {
+    if (!(name.kind === 167 /* ComputedPropertyName */ || name.kind === 212 /* ElementAccessExpression */)) {
       return false;
     }
     const expr = isElementAccessExpression(name) ? skipParentheses(name.argumentExpression) : name.expression;
@@ -115246,9 +97563,10 @@ ${lanes.join("\n")}
       case 81 /* PrivateIdentifier */:
         return name.escapedText;
       case 11 /* StringLiteral */:
+      case 15 /* NoSubstitutionTemplateLiteral */:
       case 9 /* NumericLiteral */:
         return escapeLeadingUnderscores(name.text);
-      case 166 /* ComputedPropertyName */:
+      case 167 /* ComputedPropertyName */:
         const nameExpression = name.expression;
         if (isStringOrNumericLiteralLike(nameExpression)) {
           return escapeLeadingUnderscores(nameExpression.text);
@@ -115259,7 +97577,7 @@ ${lanes.join("\n")}
           return nameExpression.operand.text;
         }
         return void 0;
-      case 294 /* JsxNamespacedName */:
+      case 295 /* JsxNamespacedName */:
         return getEscapedTextOfJsxNamespacedName(name);
       default:
         return Debug.assertNever(name);
@@ -115303,13 +97621,17 @@ ${lanes.join("\n")}
   function isAnonymousFunctionDefinition(node, cb) {
     node = skipOuterExpressions(node);
     switch (node.kind) {
-      case 230 /* ClassExpression */:
-      case 217 /* FunctionExpression */:
+      case 231 /* ClassExpression */:
+        if (classHasDeclaredOrExplicitlyAssignedName(node)) {
+          return false;
+        }
+        break;
+      case 218 /* FunctionExpression */:
         if (node.name) {
           return false;
         }
         break;
-      case 218 /* ArrowFunction */:
+      case 219 /* ArrowFunction */:
         break;
       default:
         return false;
@@ -115318,19 +97640,19 @@ ${lanes.join("\n")}
   }
   function isNamedEvaluationSource(node) {
     switch (node.kind) {
-      case 302 /* PropertyAssignment */:
+      case 303 /* PropertyAssignment */:
         return !isProtoSetter(node.name);
-      case 303 /* ShorthandPropertyAssignment */:
+      case 304 /* ShorthandPropertyAssignment */:
         return !!node.objectAssignmentInitializer;
-      case 259 /* VariableDeclaration */:
+      case 260 /* VariableDeclaration */:
         return isIdentifier(node.name) && !!node.initializer;
-      case 168 /* Parameter */:
+      case 169 /* Parameter */:
         return isIdentifier(node.name) && !!node.initializer && !node.dotDotDotToken;
-      case 207 /* BindingElement */:
+      case 208 /* BindingElement */:
         return isIdentifier(node.name) && !!node.initializer && !node.dotDotDotToken;
-      case 171 /* PropertyDeclaration */:
+      case 172 /* PropertyDeclaration */:
         return !!node.initializer;
-      case 225 /* BinaryExpression */:
+      case 226 /* BinaryExpression */:
         switch (node.operatorToken.kind) {
           case 64 /* EqualsToken */:
           case 77 /* AmpersandAmpersandEqualsToken */:
@@ -115339,7 +97661,7 @@ ${lanes.join("\n")}
             return isIdentifier(node.left);
         }
         break;
-      case 276 /* ExportAssignment */:
+      case 277 /* ExportAssignment */:
         return true;
     }
     return false;
@@ -115348,18 +97670,18 @@ ${lanes.join("\n")}
     if (!isNamedEvaluationSource(node))
       return false;
     switch (node.kind) {
-      case 302 /* PropertyAssignment */:
+      case 303 /* PropertyAssignment */:
         return isAnonymousFunctionDefinition(node.initializer, cb);
-      case 303 /* ShorthandPropertyAssignment */:
+      case 304 /* ShorthandPropertyAssignment */:
         return isAnonymousFunctionDefinition(node.objectAssignmentInitializer, cb);
-      case 259 /* VariableDeclaration */:
-      case 168 /* Parameter */:
-      case 207 /* BindingElement */:
-      case 171 /* PropertyDeclaration */:
+      case 260 /* VariableDeclaration */:
+      case 169 /* Parameter */:
+      case 208 /* BindingElement */:
+      case 172 /* PropertyDeclaration */:
         return isAnonymousFunctionDefinition(node.initializer, cb);
-      case 225 /* BinaryExpression */:
+      case 226 /* BinaryExpression */:
         return isAnonymousFunctionDefinition(node.right, cb);
-      case 276 /* ExportAssignment */:
+      case 277 /* ExportAssignment */:
         return isAnonymousFunctionDefinition(node.expression, cb);
     }
   }
@@ -115368,17 +97690,17 @@ ${lanes.join("\n")}
   }
   function isParameterDeclaration(node) {
     const root = getRootDeclaration(node);
-    return root.kind === 168 /* Parameter */;
+    return root.kind === 169 /* Parameter */;
   }
   function getRootDeclaration(node) {
-    while (node.kind === 207 /* BindingElement */) {
+    while (node.kind === 208 /* BindingElement */) {
       node = node.parent.parent;
     }
     return node;
   }
   function nodeStartsNewLexicalEnvironment(node) {
     const kind = node.kind;
-    return kind === 175 /* Constructor */ || kind === 217 /* FunctionExpression */ || kind === 261 /* FunctionDeclaration */ || kind === 218 /* ArrowFunction */ || kind === 173 /* MethodDeclaration */ || kind === 176 /* GetAccessor */ || kind === 177 /* SetAccessor */ || kind === 266 /* ModuleDeclaration */ || kind === 311 /* SourceFile */;
+    return kind === 176 /* Constructor */ || kind === 218 /* FunctionExpression */ || kind === 262 /* FunctionDeclaration */ || kind === 219 /* ArrowFunction */ || kind === 174 /* MethodDeclaration */ || kind === 177 /* GetAccessor */ || kind === 178 /* SetAccessor */ || kind === 267 /* ModuleDeclaration */ || kind === 312 /* SourceFile */;
   }
   function nodeIsSynthesized(range) {
     return positionIsSynthesized(range.pos) || positionIsSynthesized(range.end);
@@ -115388,22 +97710,22 @@ ${lanes.join("\n")}
   }
   function getExpressionAssociativity(expression) {
     const operator = getOperator(expression);
-    const hasArguments = expression.kind === 213 /* NewExpression */ && expression.arguments !== void 0;
+    const hasArguments = expression.kind === 214 /* NewExpression */ && expression.arguments !== void 0;
     return getOperatorAssociativity(expression.kind, operator, hasArguments);
   }
   function getOperatorAssociativity(kind, operator, hasArguments) {
     switch (kind) {
-      case 213 /* NewExpression */:
+      case 214 /* NewExpression */:
         return hasArguments ? 0 /* Left */ : 1 /* Right */;
-      case 223 /* PrefixUnaryExpression */:
-      case 220 /* TypeOfExpression */:
-      case 221 /* VoidExpression */:
-      case 219 /* DeleteExpression */:
-      case 222 /* AwaitExpression */:
-      case 226 /* ConditionalExpression */:
-      case 228 /* YieldExpression */:
+      case 224 /* PrefixUnaryExpression */:
+      case 221 /* TypeOfExpression */:
+      case 222 /* VoidExpression */:
+      case 220 /* DeleteExpression */:
+      case 223 /* AwaitExpression */:
+      case 227 /* ConditionalExpression */:
+      case 229 /* YieldExpression */:
         return 1 /* Right */;
-      case 225 /* BinaryExpression */:
+      case 226 /* BinaryExpression */:
         switch (operator) {
           case 43 /* AsteriskAsteriskToken */:
           case 64 /* EqualsToken */:
@@ -115429,13 +97751,13 @@ ${lanes.join("\n")}
   }
   function getExpressionPrecedence(expression) {
     const operator = getOperator(expression);
-    const hasArguments = expression.kind === 213 /* NewExpression */ && expression.arguments !== void 0;
+    const hasArguments = expression.kind === 214 /* NewExpression */ && expression.arguments !== void 0;
     return getOperatorPrecedence(expression.kind, operator, hasArguments);
   }
   function getOperator(expression) {
-    if (expression.kind === 225 /* BinaryExpression */) {
+    if (expression.kind === 226 /* BinaryExpression */) {
       return expression.operatorToken.kind;
-    } else if (expression.kind === 223 /* PrefixUnaryExpression */ || expression.kind === 224 /* PostfixUnaryExpression */) {
+    } else if (expression.kind === 224 /* PrefixUnaryExpression */ || expression.kind === 225 /* PostfixUnaryExpression */) {
       return expression.operator;
     } else {
       return expression.kind;
@@ -115443,15 +97765,15 @@ ${lanes.join("\n")}
   }
   function getOperatorPrecedence(nodeKind, operatorKind, hasArguments) {
     switch (nodeKind) {
-      case 360 /* CommaListExpression */:
+      case 361 /* CommaListExpression */:
         return 0 /* Comma */;
-      case 229 /* SpreadElement */:
+      case 230 /* SpreadElement */:
         return 1 /* Spread */;
-      case 228 /* YieldExpression */:
+      case 229 /* YieldExpression */:
         return 2 /* Yield */;
-      case 226 /* ConditionalExpression */:
+      case 227 /* ConditionalExpression */:
         return 4 /* Conditional */;
-      case 225 /* BinaryExpression */:
+      case 226 /* BinaryExpression */:
         switch (operatorKind) {
           case 28 /* CommaToken */:
             return 0 /* Comma */;
@@ -115475,27 +97797,27 @@ ${lanes.join("\n")}
           default:
             return getBinaryOperatorPrecedence(operatorKind);
         }
-      case 215 /* TypeAssertionExpression */:
-      case 234 /* NonNullExpression */:
-      case 223 /* PrefixUnaryExpression */:
-      case 220 /* TypeOfExpression */:
-      case 221 /* VoidExpression */:
-      case 219 /* DeleteExpression */:
-      case 222 /* AwaitExpression */:
+      case 216 /* TypeAssertionExpression */:
+      case 235 /* NonNullExpression */:
+      case 224 /* PrefixUnaryExpression */:
+      case 221 /* TypeOfExpression */:
+      case 222 /* VoidExpression */:
+      case 220 /* DeleteExpression */:
+      case 223 /* AwaitExpression */:
         return 16 /* Unary */;
-      case 224 /* PostfixUnaryExpression */:
+      case 225 /* PostfixUnaryExpression */:
         return 17 /* Update */;
-      case 212 /* CallExpression */:
+      case 213 /* CallExpression */:
         return 18 /* LeftHandSide */;
-      case 213 /* NewExpression */:
+      case 214 /* NewExpression */:
         return hasArguments ? 19 /* Member */ : 18 /* LeftHandSide */;
-      case 214 /* TaggedTemplateExpression */:
-      case 210 /* PropertyAccessExpression */:
-      case 211 /* ElementAccessExpression */:
-      case 235 /* MetaProperty */:
+      case 215 /* TaggedTemplateExpression */:
+      case 211 /* PropertyAccessExpression */:
+      case 212 /* ElementAccessExpression */:
+      case 236 /* MetaProperty */:
         return 19 /* Member */;
-      case 233 /* AsExpression */:
-      case 237 /* SatisfiesExpression */:
+      case 234 /* AsExpression */:
+      case 238 /* SatisfiesExpression */:
         return 11 /* Relational */;
       case 110 /* ThisKeyword */:
       case 108 /* SuperKeyword */:
@@ -115507,19 +97829,19 @@ ${lanes.join("\n")}
       case 9 /* NumericLiteral */:
       case 10 /* BigIntLiteral */:
       case 11 /* StringLiteral */:
-      case 208 /* ArrayLiteralExpression */:
-      case 209 /* ObjectLiteralExpression */:
-      case 217 /* FunctionExpression */:
-      case 218 /* ArrowFunction */:
-      case 230 /* ClassExpression */:
+      case 209 /* ArrayLiteralExpression */:
+      case 210 /* ObjectLiteralExpression */:
+      case 218 /* FunctionExpression */:
+      case 219 /* ArrowFunction */:
+      case 231 /* ClassExpression */:
       case 14 /* RegularExpressionLiteral */:
       case 15 /* NoSubstitutionTemplateLiteral */:
-      case 227 /* TemplateExpression */:
-      case 216 /* ParenthesizedExpression */:
-      case 231 /* OmittedExpression */:
-      case 283 /* JsxElement */:
-      case 284 /* JsxSelfClosingElement */:
-      case 287 /* JsxFragment */:
+      case 228 /* TemplateExpression */:
+      case 217 /* ParenthesizedExpression */:
+      case 232 /* OmittedExpression */:
+      case 284 /* JsxElement */:
+      case 285 /* JsxSelfClosingElement */:
+      case 288 /* JsxFragment */:
         return 20 /* Primary */;
       default:
         return -1 /* Invalid */;
@@ -115572,7 +97894,7 @@ ${lanes.join("\n")}
   function getSemanticJsxChildren(children) {
     return filter(children, (i) => {
       switch (i.kind) {
-        case 293 /* JsxExpression */:
+        case 294 /* JsxExpression */:
           return !!i.expression;
         case 12 /* JsxText */:
           return !i.containsOnlyTriviaWhiteSpaces;
@@ -115645,8 +97967,11 @@ ${lanes.join("\n")}
   function escapeTemplateSubstitution(str) {
     return str.replace(templateSubstitutionRegExp, "\\${");
   }
+  function containsInvalidEscapeFlag(node) {
+    return !!((node.templateFlags || 0) & 2048 /* ContainsInvalidEscape */);
+  }
   function hasInvalidEscape(template) {
-    return template && !!(isNoSubstitutionTemplateLiteral(template) ? template.templateFlags : template.head.templateFlags || some(template.templateSpans, (span) => !!span.literal.templateFlags));
+    return template && !!(isNoSubstitutionTemplateLiteral(template) ? containsInvalidEscapeFlag(template) : containsInvalidEscapeFlag(template.head) || some(template.templateSpans, (span) => containsInvalidEscapeFlag(span.literal)));
   }
   function encodeUtf16EscapeSequence(charCode) {
     const hexCharCode = charCode.toString(16).toUpperCase();
@@ -115697,7 +98022,7 @@ ${lanes.join("\n")}
   }
   function isIntrinsicJsxName(name) {
     const ch = name.charCodeAt(0);
-    return ch >= 97 /* a */ && ch <= 122 /* z */ || stringContains(name, "-");
+    return ch >= 97 /* a */ && ch <= 122 /* z */ || name.includes("-");
   }
   function getIndentString(level) {
     const singleLevel = indentStrings[1];
@@ -115709,12 +98034,9 @@ ${lanes.join("\n")}
   function getIndentSize() {
     return indentStrings[1].length;
   }
-  function isNightly() {
-    return stringContains(version, "-dev") || stringContains(version, "-insiders");
-  }
   function createTextWriter(newLine) {
     var output;
-    var indent2;
+    var indent3;
     var lineStart;
     var lineCount;
     var linePos;
@@ -115732,7 +98054,7 @@ ${lanes.join("\n")}
     function writeText(s) {
       if (s && s.length) {
         if (lineStart) {
-          s = getIndentString(indent2) + s;
+          s = getIndentString(indent3) + s;
           lineStart = false;
         }
         output += s;
@@ -115751,7 +98073,7 @@ ${lanes.join("\n")}
     }
     function reset2() {
       output = "";
-      indent2 = 0;
+      indent3 = 0;
       lineStart = true;
       lineCount = 0;
       linePos = 0;
@@ -115788,15 +98110,15 @@ ${lanes.join("\n")}
       writeLiteral,
       writeLine,
       increaseIndent: () => {
-        indent2++;
+        indent3++;
       },
       decreaseIndent: () => {
-        indent2--;
+        indent3--;
       },
-      getIndent: () => indent2,
+      getIndent: () => indent3,
       getTextPos: () => output.length,
       getLine: () => lineCount,
-      getColumn: () => lineStart ? indent2 * getIndentSize() : output.length - linePos,
+      getColumn: () => lineStart ? indent3 * getIndentSize() : output.length - linePos,
       getText: () => output,
       isAtStartOfLine: () => lineStart,
       hasTrailingComment: () => hasTrailingComment,
@@ -115900,7 +98222,7 @@ ${lanes.join("\n")}
       return void 0;
     }
     const specifier = getExternalModuleName(declaration);
-    if (specifier && isStringLiteralLike(specifier) && !pathIsRelative(specifier.text) && getCanonicalAbsolutePath(host, file.path).indexOf(getCanonicalAbsolutePath(host, ensureTrailingDirectorySeparator(host.getCommonSourceDirectory()))) === -1) {
+    if (specifier && isStringLiteralLike(specifier) && !pathIsRelative(specifier.text) && !getCanonicalAbsolutePath(host, file.path).includes(getCanonicalAbsolutePath(host, ensureTrailingDirectorySeparator(host.getCommonSourceDirectory())))) {
       return void 0;
     }
     return getResolvedExternalModuleName(host, file);
@@ -115976,7 +98298,31 @@ ${lanes.join("\n")}
   }
   function sourceFileMayBeEmitted(sourceFile, host, forceDtsEmit) {
     const options = host.getCompilerOptions();
-    return !(options.noEmitForJsFiles && isSourceFileJS(sourceFile)) && !sourceFile.isDeclarationFile && !host.isSourceFileFromExternalLibrary(sourceFile) && (forceDtsEmit || !(isJsonSourceFile(sourceFile) && host.getResolvedProjectReferenceToRedirect(sourceFile.fileName)) && !host.isSourceOfProjectReferenceRedirect(sourceFile.fileName));
+    if (options.noEmitForJsFiles && isSourceFileJS(sourceFile))
+      return false;
+    if (sourceFile.isDeclarationFile)
+      return false;
+    if (host.isSourceFileFromExternalLibrary(sourceFile))
+      return false;
+    if (forceDtsEmit)
+      return true;
+    if (host.isSourceOfProjectReferenceRedirect(sourceFile.fileName))
+      return false;
+    if (!isJsonSourceFile(sourceFile))
+      return true;
+    if (host.getResolvedProjectReferenceToRedirect(sourceFile.fileName))
+      return false;
+    if (outFile(options))
+      return true;
+    if (!options.outDir)
+      return false;
+    if (options.rootDir || options.composite && options.configFilePath) {
+      const commonDir = getNormalizedAbsolutePath(getCommonSourceDirectory(options, () => [], host.getCurrentDirectory(), host.getCanonicalFileName), host.getCurrentDirectory());
+      const outputPath = getSourceFilePathInNewDirWorker(sourceFile.fileName, options.outDir, host.getCurrentDirectory(), commonDir, host.getCanonicalFileName);
+      if (comparePaths(sourceFile.fileName, outputPath, host.getCurrentDirectory(), !host.useCaseSensitiveFileNames()) === 0 /* EqualTo */)
+        return false;
+    }
+    return true;
   }
   function getSourceFilePathInNewDir(fileName, host, newDirPath) {
     return getSourceFilePathInNewDirWorker(fileName, newDirPath, host.getCurrentDirectory(), host.getCommonSourceDirectory(), (f) => host.getCanonicalFileName(f));
@@ -115988,9 +98334,16 @@ ${lanes.join("\n")}
     return combinePaths(newDirPath, sourceFilePath);
   }
   function writeFile(host, diagnostics, fileName, text, writeByteOrderMark, sourceFiles, data) {
-    host.writeFile(fileName, text, writeByteOrderMark, (hostErrorMessage) => {
-      diagnostics.add(createCompilerDiagnostic(Diagnostics.Could_not_write_file_0_Colon_1, fileName, hostErrorMessage));
-    }, sourceFiles, data);
+    host.writeFile(
+      fileName,
+      text,
+      writeByteOrderMark,
+      (hostErrorMessage) => {
+        diagnostics.add(createCompilerDiagnostic(Diagnostics.Could_not_write_file_0_Colon_1, fileName, hostErrorMessage));
+      },
+      sourceFiles,
+      data
+    );
   }
   function ensureDirectoriesExist(directoryPath, createDirectory, directoryExists) {
     if (directoryPath.length > getRootLength(directoryPath) && !directoryExists(directoryPath)) {
@@ -116041,6 +98394,12 @@ ${lanes.join("\n")}
   function isThisIdentifier(node) {
     return !!node && node.kind === 80 /* Identifier */ && identifierIsThisKeyword(node);
   }
+  function isInTypeQuery(node) {
+    return !!findAncestor(
+      node,
+      (n) => n.kind === 186 /* TypeQuery */ ? true : n.kind === 80 /* Identifier */ || n.kind === 166 /* QualifiedName */ ? false : "quit"
+    );
+  }
   function isThisInTypeQuery(node) {
     if (!isThisIdentifier(node)) {
       return false;
@@ -116048,7 +98407,7 @@ ${lanes.join("\n")}
     while (isQualifiedName(node.parent) && node.parent.left === node) {
       node = node.parent;
     }
-    return node.parent.kind === 185 /* TypeQuery */;
+    return node.parent.kind === 186 /* TypeQuery */;
   }
   function identifierIsThisKeyword(id) {
     return id.escapedText === "this";
@@ -116060,9 +98419,9 @@ ${lanes.join("\n")}
     let setAccessor;
     if (hasDynamicName(accessor)) {
       firstAccessor = accessor;
-      if (accessor.kind === 176 /* GetAccessor */) {
+      if (accessor.kind === 177 /* GetAccessor */) {
         getAccessor = accessor;
-      } else if (accessor.kind === 177 /* SetAccessor */) {
+      } else if (accessor.kind === 178 /* SetAccessor */) {
         setAccessor = accessor;
       } else {
         Debug.fail("Accessor has wrong kind");
@@ -116078,10 +98437,10 @@ ${lanes.join("\n")}
             } else if (!secondAccessor) {
               secondAccessor = member;
             }
-            if (member.kind === 176 /* GetAccessor */ && !getAccessor) {
+            if (member.kind === 177 /* GetAccessor */ && !getAccessor) {
               getAccessor = member;
             }
-            if (member.kind === 177 /* SetAccessor */ && !setAccessor) {
+            if (member.kind === 178 /* SetAccessor */ && !setAccessor) {
               setAccessor = member;
             }
           }
@@ -116113,7 +98472,7 @@ ${lanes.join("\n")}
     return flatMap(getJSDocTags(node), (tag) => isNonTypeAliasTemplate(tag) ? tag.typeParameters : void 0);
   }
   function isNonTypeAliasTemplate(tag) {
-    return isJSDocTemplateTag(tag) && !(tag.parent.kind === 326 /* JSDoc */ && (tag.parent.tags.some(isJSDocTypeAlias) || tag.parent.tags.some(isJSDocOverloadTag)));
+    return isJSDocTemplateTag(tag) && !(tag.parent.kind === 327 /* JSDoc */ && (tag.parent.tags.some(isJSDocTypeAlias) || tag.parent.tags.some(isJSDocOverloadTag)));
   }
   function getEffectiveSetAccessorTypeAnnotationNode(node) {
     const parameter = getSetAccessorValueParameter(node);
@@ -116239,7 +98598,7 @@ ${lanes.join("\n")}
   }
   function writeTrimmedCurrentLine(text, commentEnd, writer, newLine, pos, nextLineStart) {
     const end = Math.min(commentEnd, nextLineStart - 1);
-    const currentLineText = trimString(text.substring(pos, end));
+    const currentLineText = text.substring(pos, end).trim();
     if (currentLineText) {
       writer.writeComment(currentLineText);
       if (end !== commentEnd) {
@@ -116276,25 +98635,25 @@ ${lanes.join("\n")}
     return isClassElement(node) && hasStaticModifier(node) || isClassStaticBlockDeclaration(node);
   }
   function hasStaticModifier(node) {
-    return hasSyntacticModifier(node, 32 /* Static */);
+    return hasSyntacticModifier(node, 256 /* Static */);
   }
   function hasOverrideModifier(node) {
-    return hasEffectiveModifier(node, 16384 /* Override */);
+    return hasEffectiveModifier(node, 16 /* Override */);
   }
   function hasAbstractModifier(node) {
-    return hasSyntacticModifier(node, 256 /* Abstract */);
+    return hasSyntacticModifier(node, 64 /* Abstract */);
   }
   function hasAmbientModifier(node) {
-    return hasSyntacticModifier(node, 2 /* Ambient */);
+    return hasSyntacticModifier(node, 128 /* Ambient */);
   }
   function hasAccessorModifier(node) {
-    return hasSyntacticModifier(node, 128 /* Accessor */);
+    return hasSyntacticModifier(node, 512 /* Accessor */);
   }
   function hasEffectiveReadonlyModifier(node) {
-    return hasEffectiveModifier(node, 64 /* Readonly */);
+    return hasEffectiveModifier(node, 8 /* Readonly */);
   }
   function hasDecorators(node) {
-    return hasSyntacticModifier(node, 131072 /* Decorator */);
+    return hasSyntacticModifier(node, 32768 /* Decorator */);
   }
   function getSelectedEffectiveModifierFlags(node, flags) {
     return getEffectiveModifierFlags(node) & flags;
@@ -116303,16 +98662,19 @@ ${lanes.join("\n")}
     return getSyntacticModifierFlags(node) & flags;
   }
   function getModifierFlagsWorker(node, includeJSDoc, alwaysIncludeJSDoc) {
-    if (node.kind >= 0 /* FirstToken */ && node.kind <= 164 /* LastToken */) {
+    if (node.kind >= 0 /* FirstToken */ && node.kind <= 165 /* LastToken */) {
       return 0 /* None */;
     }
     if (!(node.modifierFlagsCache & 536870912 /* HasComputedFlags */)) {
       node.modifierFlagsCache = getSyntacticModifierFlagsNoCache(node) | 536870912 /* HasComputedFlags */;
     }
-    if (includeJSDoc && !(node.modifierFlagsCache & 4096 /* HasComputedJSDocModifiers */) && (alwaysIncludeJSDoc || isInJSFile(node)) && node.parent) {
-      node.modifierFlagsCache |= getJSDocModifierFlagsNoCache(node) | 4096 /* HasComputedJSDocModifiers */;
+    if (alwaysIncludeJSDoc || includeJSDoc && isInJSFile(node)) {
+      if (!(node.modifierFlagsCache & 268435456 /* HasComputedJSDocModifiers */) && node.parent) {
+        node.modifierFlagsCache |= getRawJSDocModifierFlagsNoCache(node) | 268435456 /* HasComputedJSDocModifiers */;
+      }
+      return selectEffectiveModifierFlags(node.modifierFlagsCache);
     }
-    return node.modifierFlagsCache & ~(536870912 /* HasComputedFlags */ | 4096 /* HasComputedJSDocModifiers */);
+    return selectSyntacticModifierFlags(node.modifierFlagsCache);
   }
   function getEffectiveModifierFlags(node) {
     return getModifierFlagsWorker(
@@ -116337,33 +98699,42 @@ ${lanes.join("\n")}
       false
     );
   }
-  function getJSDocModifierFlagsNoCache(node) {
+  function getRawJSDocModifierFlagsNoCache(node) {
     let flags = 0 /* None */;
     if (!!node.parent && !isParameter(node)) {
       if (isInJSFile(node)) {
         if (getJSDocPublicTagNoCache(node))
-          flags |= 4 /* Public */;
+          flags |= 8388608 /* JSDocPublic */;
         if (getJSDocPrivateTagNoCache(node))
-          flags |= 8 /* Private */;
+          flags |= 16777216 /* JSDocPrivate */;
         if (getJSDocProtectedTagNoCache(node))
-          flags |= 16 /* Protected */;
+          flags |= 33554432 /* JSDocProtected */;
         if (getJSDocReadonlyTagNoCache(node))
-          flags |= 64 /* Readonly */;
+          flags |= 67108864 /* JSDocReadonly */;
         if (getJSDocOverrideTagNoCache(node))
-          flags |= 16384 /* Override */;
+          flags |= 134217728 /* JSDocOverride */;
       }
       if (getJSDocDeprecatedTagNoCache(node))
-        flags |= 8192 /* Deprecated */;
+        flags |= 65536 /* Deprecated */;
     }
     return flags;
   }
+  function selectSyntacticModifierFlags(flags) {
+    return flags & 65535 /* SyntacticModifiers */;
+  }
+  function selectEffectiveModifierFlags(flags) {
+    return flags & 131071 /* NonCacheOnlyModifiers */ | (flags & 260046848 /* JSDocCacheOnlyModifiers */) >>> 23;
+  }
+  function getJSDocModifierFlagsNoCache(node) {
+    return selectEffectiveModifierFlags(getRawJSDocModifierFlagsNoCache(node));
+  }
   function getEffectiveModifierFlagsNoCache(node) {
     return getSyntacticModifierFlagsNoCache(node) | getJSDocModifierFlagsNoCache(node);
   }
   function getSyntacticModifierFlagsNoCache(node) {
     let flags = canHaveModifiers(node) ? modifiersToFlags(node.modifiers) : 0 /* None */;
-    if (node.flags & 4 /* NestedNamespace */ || node.kind === 80 /* Identifier */ && node.flags & 2048 /* IdentifierIsInJSDocNamespace */) {
-      flags |= 1 /* Export */;
+    if (node.flags & 8 /* NestedNamespace */ || node.kind === 80 /* Identifier */ && node.flags & 4096 /* IdentifierIsInJSDocNamespace */) {
+      flags |= 32 /* Export */;
     }
     return flags;
   }
@@ -116379,37 +98750,37 @@ ${lanes.join("\n")}
   function modifierToFlag(token) {
     switch (token) {
       case 126 /* StaticKeyword */:
-        return 32 /* Static */;
+        return 256 /* Static */;
       case 125 /* PublicKeyword */:
-        return 4 /* Public */;
+        return 1 /* Public */;
       case 124 /* ProtectedKeyword */:
-        return 16 /* Protected */;
+        return 4 /* Protected */;
       case 123 /* PrivateKeyword */:
-        return 8 /* Private */;
+        return 2 /* Private */;
       case 128 /* AbstractKeyword */:
-        return 256 /* Abstract */;
+        return 64 /* Abstract */;
       case 129 /* AccessorKeyword */:
-        return 128 /* Accessor */;
+        return 512 /* Accessor */;
       case 95 /* ExportKeyword */:
-        return 1 /* Export */;
+        return 32 /* Export */;
       case 138 /* DeclareKeyword */:
-        return 2 /* Ambient */;
+        return 128 /* Ambient */;
       case 87 /* ConstKeyword */:
-        return 2048 /* Const */;
+        return 4096 /* Const */;
       case 90 /* DefaultKeyword */:
-        return 1024 /* Default */;
+        return 2048 /* Default */;
       case 134 /* AsyncKeyword */:
-        return 512 /* Async */;
+        return 1024 /* Async */;
       case 148 /* ReadonlyKeyword */:
-        return 64 /* Readonly */;
-      case 163 /* OverrideKeyword */:
-        return 16384 /* Override */;
+        return 8 /* Readonly */;
+      case 164 /* OverrideKeyword */:
+        return 16 /* Override */;
       case 103 /* InKeyword */:
-        return 32768 /* In */;
+        return 8192 /* In */;
       case 147 /* OutKeyword */:
-        return 65536 /* Out */;
-      case 169 /* Decorator */:
-        return 131072 /* Decorator */;
+        return 16384 /* Out */;
+      case 170 /* Decorator */:
+        return 32768 /* Decorator */;
     }
     return 0 /* None */;
   }
@@ -116465,7 +98836,7 @@ ${lanes.join("\n")}
       true
     )) {
       const kind = node.left.kind;
-      return kind === 209 /* ObjectLiteralExpression */ || kind === 208 /* ArrayLiteralExpression */;
+      return kind === 210 /* ObjectLiteralExpression */ || kind === 209 /* ArrayLiteralExpression */;
     }
     return false;
   }
@@ -116479,12 +98850,12 @@ ${lanes.join("\n")}
     switch (node.kind) {
       case 80 /* Identifier */:
         return node;
-      case 165 /* QualifiedName */:
+      case 166 /* QualifiedName */:
         do {
           node = node.left;
         } while (node.kind !== 80 /* Identifier */);
         return node;
-      case 210 /* PropertyAccessExpression */:
+      case 211 /* PropertyAccessExpression */:
         do {
           node = node.expression;
         } while (node.kind !== 80 /* Identifier */);
@@ -116492,7 +98863,7 @@ ${lanes.join("\n")}
     }
   }
   function isDottedName(node) {
-    return node.kind === 80 /* Identifier */ || node.kind === 110 /* ThisKeyword */ || node.kind === 108 /* SuperKeyword */ || node.kind === 235 /* MetaProperty */ || node.kind === 210 /* PropertyAccessExpression */ && isDottedName(node.expression) || node.kind === 216 /* ParenthesizedExpression */ && isDottedName(node.expression);
+    return node.kind === 80 /* Identifier */ || node.kind === 110 /* ThisKeyword */ || node.kind === 108 /* SuperKeyword */ || node.kind === 236 /* MetaProperty */ || node.kind === 211 /* PropertyAccessExpression */ && isDottedName(node.expression) || node.kind === 217 /* ParenthesizedExpression */ && isDottedName(node.expression);
   }
   function isPropertyAccessEntityNameExpression(node) {
     return isPropertyAccessExpression(node) && isIdentifier(node.name) && isEntityNameExpression(node.expression);
@@ -116519,19 +98890,25 @@ ${lanes.join("\n")}
     return isBindableStaticAccessExpression(node) && getElementOrPropertyAccessName(node) === "prototype";
   }
   function isRightSideOfQualifiedNameOrPropertyAccess(node) {
-    return node.parent.kind === 165 /* QualifiedName */ && node.parent.right === node || node.parent.kind === 210 /* PropertyAccessExpression */ && node.parent.name === node;
+    return node.parent.kind === 166 /* QualifiedName */ && node.parent.right === node || node.parent.kind === 211 /* PropertyAccessExpression */ && node.parent.name === node || node.parent.kind === 236 /* MetaProperty */ && node.parent.name === node;
   }
   function isRightSideOfAccessExpression(node) {
-    return isPropertyAccessExpression(node.parent) && node.parent.name === node || isElementAccessExpression(node.parent) && node.parent.argumentExpression === node;
+    return !!node.parent && (isPropertyAccessExpression(node.parent) && node.parent.name === node || isElementAccessExpression(node.parent) && node.parent.argumentExpression === node);
   }
   function isRightSideOfQualifiedNameOrPropertyAccessOrJSDocMemberName(node) {
     return isQualifiedName(node.parent) && node.parent.right === node || isPropertyAccessExpression(node.parent) && node.parent.name === node || isJSDocMemberName(node.parent) && node.parent.right === node;
   }
+  function isInstanceOfExpression(node) {
+    return isBinaryExpression(node) && node.operatorToken.kind === 104 /* InstanceOfKeyword */;
+  }
+  function isRightSideOfInstanceofExpression(node) {
+    return isInstanceOfExpression(node.parent) && node === node.parent.right;
+  }
   function isEmptyObjectLiteral(expression) {
-    return expression.kind === 209 /* ObjectLiteralExpression */ && expression.properties.length === 0;
+    return expression.kind === 210 /* ObjectLiteralExpression */ && expression.properties.length === 0;
   }
   function isEmptyArrayLiteral(expression) {
-    return expression.kind === 208 /* ArrayLiteralExpression */ && expression.elements.length === 0;
+    return expression.kind === 209 /* ArrayLiteralExpression */ && expression.elements.length === 0;
   }
   function getLocalSymbolForExportDefault(symbol) {
     if (!isExportDefaultSymbol(symbol) || !symbol.declarations)
@@ -116543,7 +98920,7 @@ ${lanes.join("\n")}
     return void 0;
   }
   function isExportDefaultSymbol(symbol) {
-    return symbol && length(symbol.declarations) > 0 && hasSyntacticModifier(symbol.declarations[0], 1024 /* Default */);
+    return symbol && length(symbol.declarations) > 0 && hasSyntacticModifier(symbol.declarations[0], 2048 /* Default */);
   }
   function tryExtractTSExtension(fileName) {
     return find(supportedTSExtensionsForExtractExtension, (extension) => fileExtensionIs(fileName, extension));
@@ -116797,8 +99174,8 @@ ${lanes.join("\n")}
     const parseNode = getParseTreeNode(node);
     if (parseNode) {
       switch (parseNode.parent.kind) {
-        case 265 /* EnumDeclaration */:
-        case 266 /* ModuleDeclaration */:
+        case 266 /* EnumDeclaration */:
+        case 267 /* ModuleDeclaration */:
           return parseNode === parseNode.parent.name;
       }
     }
@@ -116823,16 +99200,16 @@ ${lanes.join("\n")}
     if (s.valueDeclaration) {
       const declaration = isWrite && s.declarations && find(s.declarations, isSetAccessorDeclaration) || s.flags & 32768 /* GetAccessor */ && find(s.declarations, isGetAccessorDeclaration) || s.valueDeclaration;
       const flags = getCombinedModifierFlags(declaration);
-      return s.parent && s.parent.flags & 32 /* Class */ ? flags : flags & ~28 /* AccessibilityModifier */;
+      return s.parent && s.parent.flags & 32 /* Class */ ? flags : flags & ~7 /* AccessibilityModifier */;
     }
     if (getCheckFlags(s) & 6 /* Synthetic */) {
       const checkFlags = s.links.checkFlags;
-      const accessModifier = checkFlags & 1024 /* ContainsPrivate */ ? 8 /* Private */ : checkFlags & 256 /* ContainsPublic */ ? 4 /* Public */ : 16 /* Protected */;
-      const staticModifier = checkFlags & 2048 /* ContainsStatic */ ? 32 /* Static */ : 0;
+      const accessModifier = checkFlags & 1024 /* ContainsPrivate */ ? 2 /* Private */ : checkFlags & 256 /* ContainsPublic */ ? 1 /* Public */ : 4 /* Protected */;
+      const staticModifier = checkFlags & 2048 /* ContainsStatic */ ? 256 /* Static */ : 0;
       return accessModifier | staticModifier;
     }
     if (s.flags & 4194304 /* Prototype */) {
-      return 4 /* Public */ | 32 /* Static */;
+      return 1 /* Public */ | 256 /* Static */;
     }
     return 0;
   }
@@ -116851,24 +99228,24 @@ ${lanes.join("\n")}
   function accessKind(node) {
     const { parent: parent2 } = node;
     switch (parent2 == null ? void 0 : parent2.kind) {
-      case 216 /* ParenthesizedExpression */:
+      case 217 /* ParenthesizedExpression */:
         return accessKind(parent2);
-      case 224 /* PostfixUnaryExpression */:
-      case 223 /* PrefixUnaryExpression */:
+      case 225 /* PostfixUnaryExpression */:
+      case 224 /* PrefixUnaryExpression */:
         const { operator } = parent2;
         return operator === 46 /* PlusPlusToken */ || operator === 47 /* MinusMinusToken */ ? 2 /* ReadWrite */ : 0 /* Read */;
-      case 225 /* BinaryExpression */:
+      case 226 /* BinaryExpression */:
         const { left, operatorToken } = parent2;
         return left === node && isAssignmentOperator(operatorToken.kind) ? operatorToken.kind === 64 /* EqualsToken */ ? 1 /* Write */ : 2 /* ReadWrite */ : 0 /* Read */;
-      case 210 /* PropertyAccessExpression */:
+      case 211 /* PropertyAccessExpression */:
         return parent2.name !== node ? 0 /* Read */ : accessKind(parent2);
-      case 302 /* PropertyAssignment */: {
+      case 303 /* PropertyAssignment */: {
         const parentAccess = accessKind(parent2.parent);
         return node === parent2.name ? reverseAccessKind(parentAccess) : parentAccess;
       }
-      case 303 /* ShorthandPropertyAssignment */:
+      case 304 /* ShorthandPropertyAssignment */:
         return node === parent2.objectAssignmentInitializer ? 0 /* Read */ : accessKind(parent2.parent);
-      case 208 /* ArrayLiteralExpression */:
+      case 209 /* ArrayLiteralExpression */:
         return accessKind(parent2);
       default:
         return 0 /* Read */;
@@ -116931,7 +99308,7 @@ ${lanes.join("\n")}
   function isAbstractConstructorSymbol(symbol) {
     if (symbol.flags & 32 /* Class */) {
       const declaration = getClassLikeDeclarationOfSymbol(symbol);
-      return !!declaration && hasSyntacticModifier(declaration, 256 /* Abstract */);
+      return !!declaration && hasSyntacticModifier(declaration, 64 /* Abstract */);
     }
     return false;
   }
@@ -116940,7 +99317,7 @@ ${lanes.join("\n")}
     return (_a = symbol.declarations) == null ? void 0 : _a.find(isClassLike);
   }
   function getObjectFlags(type) {
-    return type.flags & 138117121 /* ObjectFlagsType */ ? type.objectFlags : 0;
+    return type.flags & 3899393 /* ObjectFlagsType */ ? type.objectFlags : 0;
   }
   function forSomeAncestorDirectory(directory, callback) {
     return !!forEachAncestorDirectory(directory, (d) => callback(d) ? true : void 0);
@@ -116953,21 +99330,17 @@ ${lanes.join("\n")}
   }
   function getLastChild(node) {
     let lastChild;
-    forEachChild(
-      node,
-      (child) => {
-        if (nodeIsPresent(child))
-          lastChild = child;
-      },
-      (children) => {
-        for (let i = children.length - 1; i >= 0; i--) {
-          if (nodeIsPresent(children[i])) {
-            lastChild = children[i];
-            break;
-          }
+    forEachChild(node, (child) => {
+      if (nodeIsPresent(child))
+        lastChild = child;
+    }, (children) => {
+      for (let i = children.length - 1; i >= 0; i--) {
+        if (nodeIsPresent(children[i])) {
+          lastChild = children[i];
+          break;
         }
       }
-    );
+    });
     return lastChild;
   }
   function addToSeen(seen, key, value = true) {
@@ -116981,16 +99354,16 @@ ${lanes.join("\n")}
     return isClassLike(node) || isInterfaceDeclaration(node) || isTypeLiteralNode(node);
   }
   function isTypeNodeKind(kind) {
-    return kind >= 181 /* FirstTypeNode */ && kind <= 204 /* LastTypeNode */ || kind === 133 /* AnyKeyword */ || kind === 159 /* UnknownKeyword */ || kind === 150 /* NumberKeyword */ || kind === 162 /* BigIntKeyword */ || kind === 151 /* ObjectKeyword */ || kind === 136 /* BooleanKeyword */ || kind === 154 /* StringKeyword */ || kind === 155 /* SymbolKeyword */ || kind === 116 /* VoidKeyword */ || kind === 157 /* UndefinedKeyword */ || kind === 146 /* NeverKeyword */ || kind === 141 /* IntrinsicKeyword */ || kind === 232 /* ExpressionWithTypeArguments */ || kind === 318 /* JSDocAllType */ || kind === 319 /* JSDocUnknownType */ || kind === 320 /* JSDocNullableType */ || kind === 321 /* JSDocNonNullableType */ || kind === 322 /* JSDocOptionalType */ || kind === 323 /* JSDocFunctionType */ || kind === 324 /* JSDocVariadicType */;
+    return kind >= 182 /* FirstTypeNode */ && kind <= 205 /* LastTypeNode */ || kind === 133 /* AnyKeyword */ || kind === 159 /* UnknownKeyword */ || kind === 150 /* NumberKeyword */ || kind === 163 /* BigIntKeyword */ || kind === 151 /* ObjectKeyword */ || kind === 136 /* BooleanKeyword */ || kind === 154 /* StringKeyword */ || kind === 155 /* SymbolKeyword */ || kind === 116 /* VoidKeyword */ || kind === 157 /* UndefinedKeyword */ || kind === 146 /* NeverKeyword */ || kind === 141 /* IntrinsicKeyword */ || kind === 233 /* ExpressionWithTypeArguments */ || kind === 319 /* JSDocAllType */ || kind === 320 /* JSDocUnknownType */ || kind === 321 /* JSDocNullableType */ || kind === 322 /* JSDocNonNullableType */ || kind === 323 /* JSDocOptionalType */ || kind === 324 /* JSDocFunctionType */ || kind === 325 /* JSDocVariadicType */;
   }
   function isAccessExpression(node) {
-    return node.kind === 210 /* PropertyAccessExpression */ || node.kind === 211 /* ElementAccessExpression */;
+    return node.kind === 211 /* PropertyAccessExpression */ || node.kind === 212 /* ElementAccessExpression */;
   }
   function getNameOfAccessExpression(node) {
-    if (node.kind === 210 /* PropertyAccessExpression */) {
+    if (node.kind === 211 /* PropertyAccessExpression */) {
       return node.name;
     }
-    Debug.assert(node.kind === 211 /* ElementAccessExpression */);
+    Debug.assert(node.kind === 212 /* ElementAccessExpression */);
     return node.argumentExpression;
   }
   function isBundleFileTextLike(section) {
@@ -117003,7 +99376,7 @@ ${lanes.join("\n")}
     }
   }
   function isNamedImportsOrExports(node) {
-    return node.kind === 274 /* NamedImports */ || node.kind === 278 /* NamedExports */;
+    return node.kind === 275 /* NamedImports */ || node.kind === 279 /* NamedExports */;
   }
   function getLeftmostAccessExpression(expr) {
     while (isAccessExpression(expr)) {
@@ -117016,12 +99389,12 @@ ${lanes.join("\n")}
       return walkAccessExpression(name.parent);
     }
     function walkAccessExpression(access) {
-      if (access.kind === 210 /* PropertyAccessExpression */) {
+      if (access.kind === 211 /* PropertyAccessExpression */) {
         const res = action(access.name);
         if (res !== void 0) {
           return res;
         }
-      } else if (access.kind === 211 /* ElementAccessExpression */) {
+      } else if (access.kind === 212 /* ElementAccessExpression */) {
         if (isIdentifier(access.argumentExpression) || isStringLiteralLike(access.argumentExpression)) {
           const res = action(access.argumentExpression);
           if (res !== void 0) {
@@ -117043,28 +99416,28 @@ ${lanes.join("\n")}
   function getLeftmostExpression(node, stopAtCallExpressions) {
     while (true) {
       switch (node.kind) {
-        case 224 /* PostfixUnaryExpression */:
+        case 225 /* PostfixUnaryExpression */:
           node = node.operand;
           continue;
-        case 225 /* BinaryExpression */:
+        case 226 /* BinaryExpression */:
           node = node.left;
           continue;
-        case 226 /* ConditionalExpression */:
+        case 227 /* ConditionalExpression */:
           node = node.condition;
           continue;
-        case 214 /* TaggedTemplateExpression */:
+        case 215 /* TaggedTemplateExpression */:
           node = node.tag;
           continue;
-        case 212 /* CallExpression */:
+        case 213 /* CallExpression */:
           if (stopAtCallExpressions) {
             return node;
           }
-        case 233 /* AsExpression */:
-        case 211 /* ElementAccessExpression */:
-        case 210 /* PropertyAccessExpression */:
-        case 234 /* NonNullExpression */:
-        case 359 /* PartiallyEmittedExpression */:
-        case 237 /* SatisfiesExpression */:
+        case 234 /* AsExpression */:
+        case 212 /* ElementAccessExpression */:
+        case 211 /* PropertyAccessExpression */:
+        case 235 /* NonNullExpression */:
+        case 360 /* PartiallyEmittedExpression */:
+        case 238 /* SatisfiesExpression */:
           node = node.expression;
           continue;
       }
@@ -117145,8 +99518,8 @@ ${lanes.join("\n")}
     Object.assign(objectAllocator, alloc);
     forEach(objectAllocatorPatchers, (fn) => fn(objectAllocator));
   }
-  function formatStringFromArgs(text, args, baseIndex = 0) {
-    return text.replace(/{(\d+)}/g, (_match, index) => "" + Debug.checkDefined(args[+index + baseIndex]));
+  function formatStringFromArgs(text, args) {
+    return text.replace(/{(\d+)}/g, (_match, index) => "" + Debug.checkDefined(args[+index]));
   }
   function setLocalizedDiagnosticMessages(messages) {
     localizedDiagnosticMessages = messages;
@@ -117159,16 +99532,14 @@ ${lanes.join("\n")}
   function getLocaleSpecificMessage(message) {
     return localizedDiagnosticMessages && localizedDiagnosticMessages[message.key] || message.message;
   }
-  function createDetachedDiagnostic(fileName, start, length2, message) {
-    assertDiagnosticLocation(
-      /*file*/
-      void 0,
-      start,
-      length2
-    );
+  function createDetachedDiagnostic(fileName, sourceText, start, length2, message, ...args) {
+    if (start + length2 > sourceText.length) {
+      length2 = sourceText.length - start;
+    }
+    assertDiagnosticLocation(sourceText, start, length2);
     let text = getLocaleSpecificMessage(message);
-    if (arguments.length > 4) {
-      text = formatStringFromArgs(text, arguments, 4);
+    if (some(args)) {
+      text = formatStringFromArgs(text, args);
     }
     return {
       file: void 0,
@@ -117220,11 +99591,11 @@ ${lanes.join("\n")}
     }
     return diagnosticsWithLocation;
   }
-  function createFileDiagnostic(file, start, length2, message) {
-    assertDiagnosticLocation(file, start, length2);
+  function createFileDiagnostic(file, start, length2, message, ...args) {
+    assertDiagnosticLocation(file.text, start, length2);
     let text = getLocaleSpecificMessage(message);
-    if (arguments.length > 4) {
-      text = formatStringFromArgs(text, arguments, 4);
+    if (some(args)) {
+      text = formatStringFromArgs(text, args);
     }
     return {
       file,
@@ -117237,17 +99608,17 @@ ${lanes.join("\n")}
       reportsDeprecated: message.reportsDeprecated
     };
   }
-  function formatMessage(_dummy, message) {
+  function formatMessage(message, ...args) {
     let text = getLocaleSpecificMessage(message);
-    if (arguments.length > 2) {
-      text = formatStringFromArgs(text, arguments, 2);
+    if (some(args)) {
+      text = formatStringFromArgs(text, args);
     }
     return text;
   }
-  function createCompilerDiagnostic(message) {
+  function createCompilerDiagnostic(message, ...args) {
     let text = getLocaleSpecificMessage(message);
-    if (arguments.length > 1) {
-      text = formatStringFromArgs(text, arguments, 1);
+    if (some(args)) {
+      text = formatStringFromArgs(text, args);
     }
     return {
       file: void 0,
@@ -117271,10 +99642,10 @@ ${lanes.join("\n")}
       relatedInformation
     };
   }
-  function chainDiagnosticMessages(details, message) {
+  function chainDiagnosticMessages(details, message, ...args) {
     let text = getLocaleSpecificMessage(message);
-    if (arguments.length > 2) {
-      text = formatStringFromArgs(text, arguments, 2);
+    if (some(args)) {
+      text = formatStringFromArgs(text, args);
     }
     return {
       messageText: text,
@@ -117522,6 +99893,9 @@ ${lanes.join("\n")}
   function getUseDefineForClassFields(compilerOptions) {
     return compilerOptions.useDefineForClassFields === void 0 ? getEmitScriptTarget(compilerOptions) >= 9 /* ES2022 */ : compilerOptions.useDefineForClassFields;
   }
+  function getEmitStandardClassFields(compilerOptions) {
+    return compilerOptions.useDefineForClassFields !== false && getEmitScriptTarget(compilerOptions) >= 9 /* ES2022 */;
+  }
   function compilerOptionsAffectSemanticDiagnostics(newOptions, oldOptions) {
     return optionsHaveChanges(oldOptions, newOptions, semanticDiagnosticsOptionDeclarations);
   }
@@ -117532,7 +99906,7 @@ ${lanes.join("\n")}
     return optionsHaveChanges(oldOptions, newOptions, affectsDeclarationPathOptionDeclarations);
   }
   function getCompilerOptionValue(options, option) {
-    return option.strictFlag ? getStrictOptionValue(options, option.name) : options[option.name];
+    return option.strictFlag ? getStrictOptionValue(options, option.name) : option.allowJsFlag ? getAllowJSCompilerOption(options) : options[option.name];
   }
   function getJSXTransformEnabled(options) {
     const jsx = options.jsx;
@@ -117574,19 +99948,16 @@ ${lanes.join("\n")}
         if (!containsIgnoredPath(symlinkPath)) {
           symlinkPath = ensureTrailingDirectorySeparator(symlinkPath);
           if (real !== false && !(symlinkedDirectories == null ? void 0 : symlinkedDirectories.has(symlinkPath))) {
-            (symlinkedDirectoriesByRealpath || (symlinkedDirectoriesByRealpath = createMultiMap())).add(ensureTrailingDirectorySeparator(real.realPath), symlink);
+            (symlinkedDirectoriesByRealpath || (symlinkedDirectoriesByRealpath = createMultiMap())).add(real.realPath, symlink);
           }
           (symlinkedDirectories || (symlinkedDirectories = /* @__PURE__ */ new Map())).set(symlinkPath, real);
         }
       },
-      setSymlinksFromResolutions(files, typeReferenceDirectives) {
-        var _a, _b;
+      setSymlinksFromResolutions(forEachResolvedModule, forEachResolvedTypeReferenceDirective, typeReferenceDirectives) {
         Debug.assert(!hasProcessedResolutions);
         hasProcessedResolutions = true;
-        for (const file of files) {
-          (_a = file.resolvedModules) == null ? void 0 : _a.forEach((resolution) => processResolution(this, resolution.resolvedModule));
-          (_b = file.resolvedTypeReferenceDirectiveNames) == null ? void 0 : _b.forEach((resolution) => processResolution(this, resolution.resolvedTypeReferenceDirective));
-        }
+        forEachResolvedModule((resolution) => processResolution(this, resolution.resolvedModule));
+        forEachResolvedTypeReferenceDirective((resolution) => processResolution(this, resolution.resolvedTypeReferenceDirective));
         typeReferenceDirectives.forEach((resolution) => processResolution(this, resolution.resolvedTypeReferenceDirective));
       },
       hasProcessedResolutions: () => hasProcessedResolutions
@@ -117600,7 +99971,10 @@ ${lanes.join("\n")}
       if (commonResolved && commonOriginal) {
         cache.setSymlinkedDirectory(
           commonOriginal,
-          { real: commonResolved, realPath: toPath(commonResolved, cwd, getCanonicalFileName) }
+          {
+            real: ensureTrailingDirectorySeparator(commonResolved),
+            realPath: ensureTrailingDirectorySeparator(toPath(commonResolved, cwd, getCanonicalFileName))
+          }
         );
       }
     }
@@ -117707,7 +100081,7 @@ ${lanes.join("\n")}
   function replaceWildcardCharacter(match, singleAsteriskRegexFragment) {
     return match === "*" ? singleAsteriskRegexFragment : match === "?" ? "[^/]" : "\\" + match;
   }
-  function getFileMatcherPatterns(path, excludes, includes, useCaseSensitiveFileNames, currentDirectory) {
+  function getFileMatcherPatterns(path, excludes, includes, useCaseSensitiveFileNames2, currentDirectory) {
     path = normalizePath(path);
     currentDirectory = normalizePath(currentDirectory);
     const absolutePath = combinePaths(currentDirectory, path);
@@ -117716,22 +100090,22 @@ ${lanes.join("\n")}
       includeFilePattern: getRegularExpressionForWildcard(includes, absolutePath, "files"),
       includeDirectoryPattern: getRegularExpressionForWildcard(includes, absolutePath, "directories"),
       excludePattern: getRegularExpressionForWildcard(excludes, absolutePath, "exclude"),
-      basePaths: getBasePaths(path, includes, useCaseSensitiveFileNames)
+      basePaths: getBasePaths(path, includes, useCaseSensitiveFileNames2)
     };
   }
-  function getRegexFromPattern(pattern, useCaseSensitiveFileNames) {
-    return new RegExp(pattern, useCaseSensitiveFileNames ? "" : "i");
+  function getRegexFromPattern(pattern, useCaseSensitiveFileNames2) {
+    return new RegExp(pattern, useCaseSensitiveFileNames2 ? "" : "i");
   }
-  function matchFiles(path, extensions, excludes, includes, useCaseSensitiveFileNames, currentDirectory, depth, getFileSystemEntries, realpath) {
+  function matchFiles(path, extensions, excludes, includes, useCaseSensitiveFileNames2, currentDirectory, depth, getFileSystemEntries, realpath) {
     path = normalizePath(path);
     currentDirectory = normalizePath(currentDirectory);
-    const patterns = getFileMatcherPatterns(path, excludes, includes, useCaseSensitiveFileNames, currentDirectory);
-    const includeFileRegexes = patterns.includeFilePatterns && patterns.includeFilePatterns.map((pattern) => getRegexFromPattern(pattern, useCaseSensitiveFileNames));
-    const includeDirectoryRegex = patterns.includeDirectoryPattern && getRegexFromPattern(patterns.includeDirectoryPattern, useCaseSensitiveFileNames);
-    const excludeRegex = patterns.excludePattern && getRegexFromPattern(patterns.excludePattern, useCaseSensitiveFileNames);
+    const patterns = getFileMatcherPatterns(path, excludes, includes, useCaseSensitiveFileNames2, currentDirectory);
+    const includeFileRegexes = patterns.includeFilePatterns && patterns.includeFilePatterns.map((pattern) => getRegexFromPattern(pattern, useCaseSensitiveFileNames2));
+    const includeDirectoryRegex = patterns.includeDirectoryPattern && getRegexFromPattern(patterns.includeDirectoryPattern, useCaseSensitiveFileNames2);
+    const excludeRegex = patterns.excludePattern && getRegexFromPattern(patterns.excludePattern, useCaseSensitiveFileNames2);
     const results = includeFileRegexes ? includeFileRegexes.map(() => []) : [[]];
     const visited = /* @__PURE__ */ new Map();
-    const toCanonical = createGetCanonicalFileName(useCaseSensitiveFileNames);
+    const toCanonical = createGetCanonicalFileName(useCaseSensitiveFileNames2);
     for (const basePath of patterns.basePaths) {
       visitDirectory(basePath, combinePaths(currentDirectory, basePath), depth);
     }
@@ -117773,7 +100147,7 @@ ${lanes.join("\n")}
       }
     }
   }
-  function getBasePaths(path, includes, useCaseSensitiveFileNames) {
+  function getBasePaths(path, includes, useCaseSensitiveFileNames2) {
     const basePaths = [path];
     if (includes) {
       const includeBasePaths = [];
@@ -117781,9 +100155,9 @@ ${lanes.join("\n")}
         const absolute = isRootedDiskPath(include) ? include : normalizePath(combinePaths(path, include));
         includeBasePaths.push(getIncludeBasePath(absolute));
       }
-      includeBasePaths.sort(getStringComparer(!useCaseSensitiveFileNames));
+      includeBasePaths.sort(getStringComparer(!useCaseSensitiveFileNames2));
       for (const includeBasePath of includeBasePaths) {
-        if (every(basePaths, (basePath) => !containsPath(basePath, includeBasePath, path, !useCaseSensitiveFileNames))) {
+        if (every(basePaths, (basePath) => !containsPath(basePath, includeBasePath, path, !useCaseSensitiveFileNames2))) {
           basePaths.push(includeBasePath);
         }
       }
@@ -117830,7 +100204,7 @@ ${lanes.join("\n")}
     const flatBuiltins = flatten(builtins);
     const extensions = [
       ...builtins,
-      ...mapDefined(extraFileExtensions, (x) => x.scriptKind === 7 /* Deferred */ || needJsExtensions && isJSLike(x.scriptKind) && flatBuiltins.indexOf(x.extension) === -1 ? [x.extension] : void 0)
+      ...mapDefined(extraFileExtensions, (x) => x.scriptKind === 7 /* Deferred */ || needJsExtensions && isJSLike(x.scriptKind) && !flatBuiltins.includes(x.extension) ? [x.extension] : void 0)
     ];
     return extensions;
   }
@@ -118142,39 +100516,39 @@ ${lanes.join("\n")}
     return success && result === 10 /* BigIntLiteral */ && scanner2.getTokenEnd() === s.length + 1 && !(flags & 512 /* ContainsSeparator */) && (!roundTripOnly || s === pseudoBigIntToString({ negative, base10Value: parsePseudoBigInt(scanner2.getTokenValue()) }));
   }
   function isValidTypeOnlyAliasUseSite(useSite) {
-    return !!(useSite.flags & 16777216 /* Ambient */) || isPartOfTypeQuery(useSite) || isIdentifierInNonEmittingHeritageClause(useSite) || isPartOfPossiblyValidTypeOrAbstractComputedPropertyName(useSite) || !(isExpressionNode(useSite) || isShorthandPropertyNameUseSite(useSite));
+    return !!(useSite.flags & 33554432 /* Ambient */) || isPartOfTypeQuery(useSite) || isIdentifierInNonEmittingHeritageClause(useSite) || isPartOfPossiblyValidTypeOrAbstractComputedPropertyName(useSite) || !(isExpressionNode(useSite) || isShorthandPropertyNameUseSite(useSite));
   }
   function isShorthandPropertyNameUseSite(useSite) {
     return isIdentifier(useSite) && isShorthandPropertyAssignment(useSite.parent) && useSite.parent.name === useSite;
   }
   function isPartOfPossiblyValidTypeOrAbstractComputedPropertyName(node) {
-    while (node.kind === 80 /* Identifier */ || node.kind === 210 /* PropertyAccessExpression */) {
+    while (node.kind === 80 /* Identifier */ || node.kind === 211 /* PropertyAccessExpression */) {
       node = node.parent;
     }
-    if (node.kind !== 166 /* ComputedPropertyName */) {
+    if (node.kind !== 167 /* ComputedPropertyName */) {
       return false;
     }
-    if (hasSyntacticModifier(node.parent, 256 /* Abstract */)) {
+    if (hasSyntacticModifier(node.parent, 64 /* Abstract */)) {
       return true;
     }
     const containerKind = node.parent.parent.kind;
-    return containerKind === 263 /* InterfaceDeclaration */ || containerKind === 186 /* TypeLiteral */;
+    return containerKind === 264 /* InterfaceDeclaration */ || containerKind === 187 /* TypeLiteral */;
   }
   function isIdentifierInNonEmittingHeritageClause(node) {
     if (node.kind !== 80 /* Identifier */)
       return false;
     const heritageClause = findAncestor(node.parent, (parent2) => {
       switch (parent2.kind) {
-        case 297 /* HeritageClause */:
+        case 298 /* HeritageClause */:
           return true;
-        case 210 /* PropertyAccessExpression */:
-        case 232 /* ExpressionWithTypeArguments */:
+        case 211 /* PropertyAccessExpression */:
+        case 233 /* ExpressionWithTypeArguments */:
           return false;
         default:
           return "quit";
       }
     });
-    return (heritageClause == null ? void 0 : heritageClause.token) === 119 /* ImplementsKeyword */ || (heritageClause == null ? void 0 : heritageClause.parent.kind) === 263 /* InterfaceDeclaration */;
+    return (heritageClause == null ? void 0 : heritageClause.token) === 119 /* ImplementsKeyword */ || (heritageClause == null ? void 0 : heritageClause.parent.kind) === 264 /* InterfaceDeclaration */;
   }
   function isIdentifierTypeReference(node) {
     return isTypeReferenceNode(node) && isIdentifier(node.typeName);
@@ -118280,26 +100654,26 @@ ${lanes.join("\n")}
     }
   }
   function containsIgnoredPath(path) {
-    return some(ignoredPaths, (p) => stringContains(path, p));
+    return some(ignoredPaths, (p) => path.includes(p));
   }
   function getContainingNodeArray(node) {
     if (!node.parent)
       return void 0;
     switch (node.kind) {
-      case 167 /* TypeParameter */:
+      case 168 /* TypeParameter */:
         const { parent: parent3 } = node;
-        return parent3.kind === 194 /* InferType */ ? void 0 : parent3.typeParameters;
-      case 168 /* Parameter */:
+        return parent3.kind === 195 /* InferType */ ? void 0 : parent3.typeParameters;
+      case 169 /* Parameter */:
         return node.parent.parameters;
-      case 203 /* TemplateLiteralTypeSpan */:
+      case 204 /* TemplateLiteralTypeSpan */:
         return node.parent.templateSpans;
-      case 238 /* TemplateSpan */:
+      case 239 /* TemplateSpan */:
         return node.parent.templateSpans;
-      case 169 /* Decorator */: {
+      case 170 /* Decorator */: {
         const { parent: parent4 } = node;
         return canHaveDecorators(parent4) ? parent4.modifiers : void 0;
       }
-      case 297 /* HeritageClause */:
+      case 298 /* HeritageClause */:
         return node.parent.heritageClauses;
     }
     const { parent: parent2 } = node;
@@ -118307,43 +100681,43 @@ ${lanes.join("\n")}
       return isJSDocTypeLiteral(node.parent) ? void 0 : node.parent.tags;
     }
     switch (parent2.kind) {
-      case 186 /* TypeLiteral */:
-      case 263 /* InterfaceDeclaration */:
+      case 187 /* TypeLiteral */:
+      case 264 /* InterfaceDeclaration */:
         return isTypeElement(node) ? parent2.members : void 0;
-      case 191 /* UnionType */:
-      case 192 /* IntersectionType */:
+      case 192 /* UnionType */:
+      case 193 /* IntersectionType */:
         return parent2.types;
-      case 188 /* TupleType */:
-      case 208 /* ArrayLiteralExpression */:
-      case 360 /* CommaListExpression */:
-      case 274 /* NamedImports */:
-      case 278 /* NamedExports */:
+      case 189 /* TupleType */:
+      case 209 /* ArrayLiteralExpression */:
+      case 361 /* CommaListExpression */:
+      case 275 /* NamedImports */:
+      case 279 /* NamedExports */:
         return parent2.elements;
-      case 209 /* ObjectLiteralExpression */:
-      case 291 /* JsxAttributes */:
+      case 210 /* ObjectLiteralExpression */:
+      case 292 /* JsxAttributes */:
         return parent2.properties;
-      case 212 /* CallExpression */:
-      case 213 /* NewExpression */:
+      case 213 /* CallExpression */:
+      case 214 /* NewExpression */:
         return isTypeNode(node) ? parent2.typeArguments : parent2.expression === node ? void 0 : parent2.arguments;
-      case 283 /* JsxElement */:
-      case 287 /* JsxFragment */:
+      case 284 /* JsxElement */:
+      case 288 /* JsxFragment */:
         return isJsxChild(node) ? parent2.children : void 0;
-      case 285 /* JsxOpeningElement */:
-      case 284 /* JsxSelfClosingElement */:
+      case 286 /* JsxOpeningElement */:
+      case 285 /* JsxSelfClosingElement */:
         return isTypeNode(node) ? parent2.typeArguments : void 0;
-      case 240 /* Block */:
-      case 295 /* CaseClause */:
-      case 296 /* DefaultClause */:
-      case 267 /* ModuleBlock */:
+      case 241 /* Block */:
+      case 296 /* CaseClause */:
+      case 297 /* DefaultClause */:
+      case 268 /* ModuleBlock */:
         return parent2.statements;
-      case 268 /* CaseBlock */:
+      case 269 /* CaseBlock */:
         return parent2.clauses;
-      case 262 /* ClassDeclaration */:
-      case 230 /* ClassExpression */:
+      case 263 /* ClassDeclaration */:
+      case 231 /* ClassExpression */:
         return isClassElement(node) ? parent2.members : void 0;
-      case 265 /* EnumDeclaration */:
+      case 266 /* EnumDeclaration */:
         return isEnumMember(node) ? parent2.members : void 0;
-      case 311 /* SourceFile */:
+      case 312 /* SourceFile */:
         return parent2.statements;
     }
   }
@@ -118352,7 +100726,7 @@ ${lanes.join("\n")}
       if (some(node.parameters, (p) => !getEffectiveTypeAnnotationNode(p))) {
         return true;
       }
-      if (node.kind !== 218 /* ArrowFunction */) {
+      if (node.kind !== 219 /* ArrowFunction */) {
         const parameter = firstOrUndefined(node.parameters);
         if (!(parameter && parameterIsThisKeyword(parameter))) {
           return true;
@@ -118365,14 +100739,14 @@ ${lanes.join("\n")}
     return name === "Infinity" || name === "-Infinity" || name === "NaN";
   }
   function isCatchClauseVariableDeclaration(node) {
-    return node.kind === 259 /* VariableDeclaration */ && node.parent.kind === 298 /* CatchClause */;
+    return node.kind === 260 /* VariableDeclaration */ && node.parent.kind === 299 /* CatchClause */;
   }
   function isParameterOrCatchClauseVariable(symbol) {
     const declaration = symbol.valueDeclaration && getRootDeclaration(symbol.valueDeclaration);
     return !!declaration && (isParameter(declaration) || isCatchClauseVariableDeclaration(declaration));
   }
   function isFunctionExpressionOrArrowFunction(node) {
-    return node.kind === 217 /* FunctionExpression */ || node.kind === 218 /* ArrowFunction */;
+    return node.kind === 218 /* FunctionExpression */ || node.kind === 219 /* ArrowFunction */;
   }
   function escapeSnippetText(text) {
     return text.replace(/\$/gm, () => "\\$");
@@ -118380,8 +100754,9 @@ ${lanes.join("\n")}
   function isNumericLiteralName(name) {
     return (+name).toString() === name;
   }
-  function createPropertyNameNodeForIdentifierOrLiteral(name, target, singleQuote, stringNamed) {
-    return isIdentifierText(name, target) ? factory.createIdentifier(name) : !stringNamed && isNumericLiteralName(name) && +name >= 0 ? factory.createNumericLiteral(+name) : factory.createStringLiteral(name, !!singleQuote);
+  function createPropertyNameNodeForIdentifierOrLiteral(name, target, singleQuote, stringNamed, isMethod) {
+    const isMethodNamedNew = isMethod && name === "new";
+    return !isMethodNamedNew && isIdentifierText(name, target) ? factory.createIdentifier(name) : !stringNamed && !isMethodNamedNew && isNumericLiteralName(name) && +name >= 0 ? factory.createNumericLiteral(+name) : factory.createStringLiteral(name, !!singleQuote);
   }
   function isThisTypeParameter(type) {
     return !!(type.flags & 262144 /* TypeParameter */ && type.isThisType);
@@ -118435,23 +100810,23 @@ ${lanes.join("\n")}
   }
   function getParameterTypeNode(parameter) {
     var _a;
-    return parameter.kind === 347 /* JSDocParameterTag */ ? (_a = parameter.typeExpression) == null ? void 0 : _a.type : parameter.type;
+    return parameter.kind === 348 /* JSDocParameterTag */ ? (_a = parameter.typeExpression) == null ? void 0 : _a.type : parameter.type;
   }
   function isTypeDeclaration(node) {
     switch (node.kind) {
-      case 167 /* TypeParameter */:
-      case 262 /* ClassDeclaration */:
-      case 263 /* InterfaceDeclaration */:
-      case 264 /* TypeAliasDeclaration */:
-      case 265 /* EnumDeclaration */:
-      case 352 /* JSDocTypedefTag */:
-      case 344 /* JSDocCallbackTag */:
-      case 346 /* JSDocEnumTag */:
+      case 168 /* TypeParameter */:
+      case 263 /* ClassDeclaration */:
+      case 264 /* InterfaceDeclaration */:
+      case 265 /* TypeAliasDeclaration */:
+      case 266 /* EnumDeclaration */:
+      case 353 /* JSDocTypedefTag */:
+      case 345 /* JSDocCallbackTag */:
+      case 347 /* JSDocEnumTag */:
         return true;
-      case 272 /* ImportClause */:
+      case 273 /* ImportClause */:
         return node.isTypeOnly;
-      case 275 /* ImportSpecifier */:
-      case 280 /* ExportSpecifier */:
+      case 276 /* ImportSpecifier */:
+      case 281 /* ExportSpecifier */:
         return node.parent.parent.isTypeOnly;
       default:
         return false;
@@ -118465,7 +100840,7 @@ ${lanes.join("\n")}
       return false;
     }
     const { isBracketed, typeExpression } = node;
-    return isBracketed || !!typeExpression && typeExpression.type.kind === 322 /* JSDocOptionalType */;
+    return isBracketed || !!typeExpression && typeExpression.type.kind === 323 /* JSDocOptionalType */;
   }
   function canUsePropertyAccess(name, languageVersion) {
     if (name.length === 0) {
@@ -118480,17 +100855,17 @@ ${lanes.join("\n")}
   }
   function isJSDocOptionalParameter(node) {
     return isInJSFile(node) && // node.type should only be a JSDocOptionalType when node is a parameter of a JSDocFunctionType
-    (node.type && node.type.kind === 322 /* JSDocOptionalType */ || getJSDocParameterTags(node).some(({ isBracketed, typeExpression }) => isBracketed || !!typeExpression && typeExpression.type.kind === 322 /* JSDocOptionalType */));
+    (node.type && node.type.kind === 323 /* JSDocOptionalType */ || getJSDocParameterTags(node).some(({ isBracketed, typeExpression }) => isBracketed || !!typeExpression && typeExpression.type.kind === 323 /* JSDocOptionalType */));
   }
   function isOptionalDeclaration(declaration) {
     switch (declaration.kind) {
-      case 171 /* PropertyDeclaration */:
-      case 170 /* PropertySignature */:
+      case 172 /* PropertyDeclaration */:
+      case 171 /* PropertySignature */:
         return !!declaration.questionToken;
-      case 168 /* Parameter */:
+      case 169 /* Parameter */:
         return !!declaration.questionToken || isJSDocOptionalParameter(declaration);
-      case 354 /* JSDocPropertyTag */:
-      case 347 /* JSDocParameterTag */:
+      case 355 /* JSDocPropertyTag */:
+      case 348 /* JSDocParameterTag */:
         return isOptionalJSDocPropertyLikeTag(declaration);
       default:
         return false;
@@ -118498,7 +100873,7 @@ ${lanes.join("\n")}
   }
   function isNonNullAccess(node) {
     const kind = node.kind;
-    return (kind === 210 /* PropertyAccessExpression */ || kind === 211 /* ElementAccessExpression */) && isNonNullExpression(node.expression);
+    return (kind === 211 /* PropertyAccessExpression */ || kind === 212 /* ElementAccessExpression */) && isNonNullExpression(node.expression);
   }
   function isJSDocSatisfiesExpression(node) {
     return isInJSFile(node) && isParenthesizedExpression(node) && hasJSDocNodes(node) && !!getJSDocSatisfiesTag(node);
@@ -118518,7 +100893,7 @@ ${lanes.join("\n")}
   }
   function isJsxAttributeName(node) {
     const kind = node.kind;
-    return kind === 80 /* Identifier */ || kind === 294 /* JsxNamespacedName */;
+    return kind === 80 /* Identifier */ || kind === 295 /* JsxNamespacedName */;
   }
   function getEscapedTextOfJsxNamespacedName(node) {
     return `${node.namespace.escapedText}:${idText(node.name)}`;
@@ -118529,7 +100904,28 @@ ${lanes.join("\n")}
   function intrinsicTagNameToString(node) {
     return isIdentifier(node) ? idText(node) : getTextOfJsxNamespacedName(node);
   }
-  var resolvingEmptyArray, externalHelpersModuleNameText, defaultMaximumTruncationLength, noTruncationMaximumTruncationLength, stringWriter, GetLiteralTextFlags, fullTripleSlashReferencePathRegEx, fullTripleSlashReferenceTypeReferenceDirectiveRegEx, fullTripleSlashLibReferenceRegEx, fullTripleSlashAMDReferencePathRegEx, fullTripleSlashAMDModuleRegEx, defaultLibReferenceRegEx, AssignmentKind, FunctionFlags, Associativity, OperatorPrecedence, templateSubstitutionRegExp, doubleQuoteEscapedCharsRegExp, singleQuoteEscapedCharsRegExp, backtickQuoteEscapedCharsRegExp, escapedCharsMap, nonAsciiCharacters, jsxDoubleQuoteEscapedCharsRegExp, jsxSingleQuoteEscapedCharsRegExp, jsxEscapedCharsMap, indentStrings, base64Digits, carriageReturnLineFeed, lineFeed, objectAllocator, objectAllocatorPatchers, localizedDiagnosticMessages, reservedCharacterPattern, wildcardCharCodes, commonPackageFolders, implicitExcludePathRegexPattern, filesMatcher, directoriesMatcher, excludeMatcher, wildcardMatchers, supportedTSExtensions, supportedTSExtensionsFlat, supportedTSExtensionsWithJson, supportedTSExtensionsForExtractExtension, supportedJSExtensions, supportedJSExtensionsFlat, allSupportedExtensions, allSupportedExtensionsWithJson, supportedDeclarationExtensions, supportedTSImplementationExtensions, extensionsNotSupportingExtensionlessResolution, ModuleSpecifierEnding, extensionsToRemove, emptyFileSystemEntries;
+  function isTypeUsableAsPropertyName(type) {
+    return !!(type.flags & 8576 /* StringOrNumberLiteralOrUnique */);
+  }
+  function getPropertyNameFromType(type) {
+    if (type.flags & 8192 /* UniqueESSymbol */) {
+      return type.escapedName;
+    }
+    if (type.flags & (128 /* StringLiteral */ | 256 /* NumberLiteral */)) {
+      return escapeLeadingUnderscores("" + type.value);
+    }
+    return Debug.fail();
+  }
+  function isExpandoPropertyDeclaration(declaration) {
+    return !!declaration && (isPropertyAccessExpression(declaration) || isElementAccessExpression(declaration) || isBinaryExpression(declaration));
+  }
+  function hasResolutionModeOverride(node) {
+    if (node === void 0) {
+      return false;
+    }
+    return !!getResolutionModeOverride(node.attributes);
+  }
+  var resolvingEmptyArray, externalHelpersModuleNameText, defaultMaximumTruncationLength, noTruncationMaximumTruncationLength, stringWriter, getScriptTargetFeatures, GetLiteralTextFlags, fullTripleSlashReferencePathRegEx, fullTripleSlashReferenceTypeReferenceDirectiveRegEx, fullTripleSlashLibReferenceRegEx, fullTripleSlashAMDReferencePathRegEx, fullTripleSlashAMDModuleRegEx, defaultLibReferenceRegEx, AssignmentKind, FunctionFlags, Associativity, OperatorPrecedence, templateSubstitutionRegExp, doubleQuoteEscapedCharsRegExp, singleQuoteEscapedCharsRegExp, backtickQuoteEscapedCharsRegExp, escapedCharsMap, nonAsciiCharacters, jsxDoubleQuoteEscapedCharsRegExp, jsxSingleQuoteEscapedCharsRegExp, jsxEscapedCharsMap, indentStrings, base64Digits, carriageReturnLineFeed, lineFeed, objectAllocator, objectAllocatorPatchers, localizedDiagnosticMessages, reservedCharacterPattern, wildcardCharCodes, commonPackageFolders, implicitExcludePathRegexPattern, filesMatcher, directoriesMatcher, excludeMatcher, wildcardMatchers, supportedTSExtensions, supportedTSExtensionsFlat, supportedTSExtensionsWithJson, supportedTSExtensionsForExtractExtension, supportedJSExtensions, supportedJSExtensionsFlat, allSupportedExtensions, allSupportedExtensionsWithJson, supportedDeclarationExtensions, supportedTSImplementationExtensions, extensionsNotSupportingExtensionlessResolution, ModuleSpecifierEnding, extensionsToRemove, emptyFileSystemEntries;
   var init_utilities = __esm({
     "src/compiler/utilities.ts"() {
       "use strict";
@@ -118539,6 +100935,402 @@ ${lanes.join("\n")}
       defaultMaximumTruncationLength = 160;
       noTruncationMaximumTruncationLength = 1e6;
       stringWriter = createSingleLineStringWriter();
+      getScriptTargetFeatures = /* @__PURE__ */ memoize(
+        () => new Map(Object.entries({
+          Array: new Map(Object.entries({
+            es2015: [
+              "find",
+              "findIndex",
+              "fill",
+              "copyWithin",
+              "entries",
+              "keys",
+              "values"
+            ],
+            es2016: [
+              "includes"
+            ],
+            es2019: [
+              "flat",
+              "flatMap"
+            ],
+            es2022: [
+              "at"
+            ],
+            es2023: [
+              "findLastIndex",
+              "findLast"
+            ]
+          })),
+          Iterator: new Map(Object.entries({
+            es2015: emptyArray
+          })),
+          AsyncIterator: new Map(Object.entries({
+            es2015: emptyArray
+          })),
+          Atomics: new Map(Object.entries({
+            es2017: emptyArray
+          })),
+          SharedArrayBuffer: new Map(Object.entries({
+            es2017: emptyArray
+          })),
+          AsyncIterable: new Map(Object.entries({
+            es2018: emptyArray
+          })),
+          AsyncIterableIterator: new Map(Object.entries({
+            es2018: emptyArray
+          })),
+          AsyncGenerator: new Map(Object.entries({
+            es2018: emptyArray
+          })),
+          AsyncGeneratorFunction: new Map(Object.entries({
+            es2018: emptyArray
+          })),
+          RegExp: new Map(Object.entries({
+            es2015: [
+              "flags",
+              "sticky",
+              "unicode"
+            ],
+            es2018: [
+              "dotAll"
+            ]
+          })),
+          Reflect: new Map(Object.entries({
+            es2015: [
+              "apply",
+              "construct",
+              "defineProperty",
+              "deleteProperty",
+              "get",
+              "getOwnPropertyDescriptor",
+              "getPrototypeOf",
+              "has",
+              "isExtensible",
+              "ownKeys",
+              "preventExtensions",
+              "set",
+              "setPrototypeOf"
+            ]
+          })),
+          ArrayConstructor: new Map(Object.entries({
+            es2015: [
+              "from",
+              "of"
+            ]
+          })),
+          ObjectConstructor: new Map(Object.entries({
+            es2015: [
+              "assign",
+              "getOwnPropertySymbols",
+              "keys",
+              "is",
+              "setPrototypeOf"
+            ],
+            es2017: [
+              "values",
+              "entries",
+              "getOwnPropertyDescriptors"
+            ],
+            es2019: [
+              "fromEntries"
+            ],
+            es2022: [
+              "hasOwn"
+            ]
+          })),
+          NumberConstructor: new Map(Object.entries({
+            es2015: [
+              "isFinite",
+              "isInteger",
+              "isNaN",
+              "isSafeInteger",
+              "parseFloat",
+              "parseInt"
+            ]
+          })),
+          Math: new Map(Object.entries({
+            es2015: [
+              "clz32",
+              "imul",
+              "sign",
+              "log10",
+              "log2",
+              "log1p",
+              "expm1",
+              "cosh",
+              "sinh",
+              "tanh",
+              "acosh",
+              "asinh",
+              "atanh",
+              "hypot",
+              "trunc",
+              "fround",
+              "cbrt"
+            ]
+          })),
+          Map: new Map(Object.entries({
+            es2015: [
+              "entries",
+              "keys",
+              "values"
+            ]
+          })),
+          Set: new Map(Object.entries({
+            es2015: [
+              "entries",
+              "keys",
+              "values"
+            ]
+          })),
+          PromiseConstructor: new Map(Object.entries({
+            es2015: [
+              "all",
+              "race",
+              "reject",
+              "resolve"
+            ],
+            es2020: [
+              "allSettled"
+            ],
+            es2021: [
+              "any"
+            ]
+          })),
+          Symbol: new Map(Object.entries({
+            es2015: [
+              "for",
+              "keyFor"
+            ],
+            es2019: [
+              "description"
+            ]
+          })),
+          WeakMap: new Map(Object.entries({
+            es2015: [
+              "entries",
+              "keys",
+              "values"
+            ]
+          })),
+          WeakSet: new Map(Object.entries({
+            es2015: [
+              "entries",
+              "keys",
+              "values"
+            ]
+          })),
+          String: new Map(Object.entries({
+            es2015: [
+              "codePointAt",
+              "includes",
+              "endsWith",
+              "normalize",
+              "repeat",
+              "startsWith",
+              "anchor",
+              "big",
+              "blink",
+              "bold",
+              "fixed",
+              "fontcolor",
+              "fontsize",
+              "italics",
+              "link",
+              "small",
+              "strike",
+              "sub",
+              "sup"
+            ],
+            es2017: [
+              "padStart",
+              "padEnd"
+            ],
+            es2019: [
+              "trimStart",
+              "trimEnd",
+              "trimLeft",
+              "trimRight"
+            ],
+            es2020: [
+              "matchAll"
+            ],
+            es2021: [
+              "replaceAll"
+            ],
+            es2022: [
+              "at"
+            ]
+          })),
+          StringConstructor: new Map(Object.entries({
+            es2015: [
+              "fromCodePoint",
+              "raw"
+            ]
+          })),
+          DateTimeFormat: new Map(Object.entries({
+            es2017: [
+              "formatToParts"
+            ]
+          })),
+          Promise: new Map(Object.entries({
+            es2015: emptyArray,
+            es2018: [
+              "finally"
+            ]
+          })),
+          RegExpMatchArray: new Map(Object.entries({
+            es2018: [
+              "groups"
+            ]
+          })),
+          RegExpExecArray: new Map(Object.entries({
+            es2018: [
+              "groups"
+            ]
+          })),
+          Intl: new Map(Object.entries({
+            es2018: [
+              "PluralRules"
+            ]
+          })),
+          NumberFormat: new Map(Object.entries({
+            es2018: [
+              "formatToParts"
+            ]
+          })),
+          SymbolConstructor: new Map(Object.entries({
+            es2020: [
+              "matchAll"
+            ]
+          })),
+          DataView: new Map(Object.entries({
+            es2020: [
+              "setBigInt64",
+              "setBigUint64",
+              "getBigInt64",
+              "getBigUint64"
+            ]
+          })),
+          BigInt: new Map(Object.entries({
+            es2020: emptyArray
+          })),
+          RelativeTimeFormat: new Map(Object.entries({
+            es2020: [
+              "format",
+              "formatToParts",
+              "resolvedOptions"
+            ]
+          })),
+          Int8Array: new Map(Object.entries({
+            es2022: [
+              "at"
+            ],
+            es2023: [
+              "findLastIndex",
+              "findLast"
+            ]
+          })),
+          Uint8Array: new Map(Object.entries({
+            es2022: [
+              "at"
+            ],
+            es2023: [
+              "findLastIndex",
+              "findLast"
+            ]
+          })),
+          Uint8ClampedArray: new Map(Object.entries({
+            es2022: [
+              "at"
+            ],
+            es2023: [
+              "findLastIndex",
+              "findLast"
+            ]
+          })),
+          Int16Array: new Map(Object.entries({
+            es2022: [
+              "at"
+            ],
+            es2023: [
+              "findLastIndex",
+              "findLast"
+            ]
+          })),
+          Uint16Array: new Map(Object.entries({
+            es2022: [
+              "at"
+            ],
+            es2023: [
+              "findLastIndex",
+              "findLast"
+            ]
+          })),
+          Int32Array: new Map(Object.entries({
+            es2022: [
+              "at"
+            ],
+            es2023: [
+              "findLastIndex",
+              "findLast"
+            ]
+          })),
+          Uint32Array: new Map(Object.entries({
+            es2022: [
+              "at"
+            ],
+            es2023: [
+              "findLastIndex",
+              "findLast"
+            ]
+          })),
+          Float32Array: new Map(Object.entries({
+            es2022: [
+              "at"
+            ],
+            es2023: [
+              "findLastIndex",
+              "findLast"
+            ]
+          })),
+          Float64Array: new Map(Object.entries({
+            es2022: [
+              "at"
+            ],
+            es2023: [
+              "findLastIndex",
+              "findLast"
+            ]
+          })),
+          BigInt64Array: new Map(Object.entries({
+            es2020: emptyArray,
+            es2022: [
+              "at"
+            ],
+            es2023: [
+              "findLastIndex",
+              "findLast"
+            ]
+          })),
+          BigUint64Array: new Map(Object.entries({
+            es2020: emptyArray,
+            es2022: [
+              "at"
+            ],
+            es2023: [
+              "findLastIndex",
+              "findLast"
+            ]
+          })),
+          Error: new Map(Object.entries({
+            es2022: [
+              "cause"
+            ]
+          }))
+        }))
+      );
       GetLiteralTextFlags = /* @__PURE__ */ ((GetLiteralTextFlags2) => {
         GetLiteralTextFlags2[GetLiteralTextFlags2["None"] = 0] = "None";
         GetLiteralTextFlags2[GetLiteralTextFlags2["NeverAsciiEscape"] = 1] = "NeverAsciiEscape";
@@ -118601,9 +101393,9 @@ ${lanes.join("\n")}
         return OperatorPrecedence2;
       })(OperatorPrecedence || {});
       templateSubstitutionRegExp = /\$\{/g;
-      doubleQuoteEscapedCharsRegExp = /[\\\"\u0000-\u001f\t\v\f\b\r\n\u2028\u2029\u0085]/g;
-      singleQuoteEscapedCharsRegExp = /[\\\'\u0000-\u001f\t\v\f\b\r\n\u2028\u2029\u0085]/g;
-      backtickQuoteEscapedCharsRegExp = /\r\n|[\\\`\u0000-\u001f\t\v\f\b\r\u2028\u2029\u0085]/g;
+      doubleQuoteEscapedCharsRegExp = /[\\"\u0000-\u001f\t\v\f\b\r\n\u2028\u2029\u0085]/g;
+      singleQuoteEscapedCharsRegExp = /[\\'\u0000-\u001f\t\v\f\b\r\n\u2028\u2029\u0085]/g;
+      backtickQuoteEscapedCharsRegExp = /\r\n|[\\`\u0000-\u001f\t\v\f\b\r\u2028\u2029\u0085]/g;
       escapedCharsMap = new Map(Object.entries({
         "	": "\\t",
         "\v": "\\v",
@@ -118625,8 +101417,8 @@ ${lanes.join("\n")}
         // special case for CRLFs in backticks
       }));
       nonAsciiCharacters = /[^\u0000-\u007F]/g;
-      jsxDoubleQuoteEscapedCharsRegExp = /[\"\u0000-\u001f\u2028\u2029\u0085]/g;
-      jsxSingleQuoteEscapedCharsRegExp = /[\'\u0000-\u001f\u2028\u2029\u0085]/g;
+      jsxDoubleQuoteEscapedCharsRegExp = /["\u0000-\u001f\u2028\u2029\u0085]/g;
+      jsxSingleQuoteEscapedCharsRegExp = /['\u0000-\u001f\u2028\u2029\u0085]/g;
       jsxEscapedCharsMap = new Map(Object.entries({
         '"': """,
         "'": "'"
@@ -118647,7 +101439,7 @@ ${lanes.join("\n")}
         getSourceMapSourceConstructor: () => SourceMapSource
       };
       objectAllocatorPatchers = [];
-      reservedCharacterPattern = /[^\w\s\/]/g;
+      reservedCharacterPattern = /[^\w\s/]/g;
       wildcardCharCodes = [42 /* asterisk */, 63 /* question */];
       commonPackageFolders = ["node_modules", "bower_components", "jspm_packages"];
       implicitExcludePathRegexPattern = `(?!(${commonPackageFolders.join("|")})(/|$))`;
@@ -118838,16 +101630,16 @@ ${lanes.join("\n")}
       return parenthesizerRule;
     }
     function binaryOperandNeedsParentheses(binaryOperator, operand, isLeftSideOfBinary, leftOperand) {
-      const binaryOperatorPrecedence = getOperatorPrecedence(225 /* BinaryExpression */, binaryOperator);
-      const binaryOperatorAssociativity = getOperatorAssociativity(225 /* BinaryExpression */, binaryOperator);
+      const binaryOperatorPrecedence = getOperatorPrecedence(226 /* BinaryExpression */, binaryOperator);
+      const binaryOperatorAssociativity = getOperatorAssociativity(226 /* BinaryExpression */, binaryOperator);
       const emittedOperand = skipPartiallyEmittedExpressions(operand);
-      if (!isLeftSideOfBinary && operand.kind === 218 /* ArrowFunction */ && binaryOperatorPrecedence > 3 /* Assignment */) {
+      if (!isLeftSideOfBinary && operand.kind === 219 /* ArrowFunction */ && binaryOperatorPrecedence > 3 /* Assignment */) {
         return true;
       }
       const operandPrecedence = getExpressionPrecedence(emittedOperand);
       switch (compareValues(operandPrecedence, binaryOperatorPrecedence)) {
         case -1 /* LessThan */:
-          if (!isLeftSideOfBinary && binaryOperatorAssociativity === 1 /* Right */ && operand.kind === 228 /* YieldExpression */) {
+          if (!isLeftSideOfBinary && binaryOperatorAssociativity === 1 /* Right */ && operand.kind === 229 /* YieldExpression */) {
             return false;
           }
           return true;
@@ -118881,7 +101673,7 @@ ${lanes.join("\n")}
       if (isLiteralKind(node.kind)) {
         return node.kind;
       }
-      if (node.kind === 225 /* BinaryExpression */ && node.operatorToken.kind === 40 /* PlusToken */) {
+      if (node.kind === 226 /* BinaryExpression */ && node.operatorToken.kind === 40 /* PlusToken */) {
         if (node.cachedLiteralKind !== void 0) {
           return node.cachedLiteralKind;
         }
@@ -118894,7 +101686,7 @@ ${lanes.join("\n")}
     }
     function parenthesizeBinaryOperand(binaryOperator, operand, isLeftSideOfBinary, leftOperand) {
       const skipped = skipPartiallyEmittedExpressions(operand);
-      if (skipped.kind === 216 /* ParenthesizedExpression */) {
+      if (skipped.kind === 217 /* ParenthesizedExpression */) {
         return operand;
       }
       return binaryOperandNeedsParentheses(binaryOperator, operand, isLeftSideOfBinary, leftOperand) ? factory2.createParenthesizedExpression(operand) : operand;
@@ -118920,7 +101712,7 @@ ${lanes.join("\n")}
       return isCommaSequence(expression) ? factory2.createParenthesizedExpression(expression) : expression;
     }
     function parenthesizeConditionOfConditionalExpression(condition) {
-      const conditionalPrecedence = getOperatorPrecedence(226 /* ConditionalExpression */, 58 /* QuestionToken */);
+      const conditionalPrecedence = getOperatorPrecedence(227 /* ConditionalExpression */, 58 /* QuestionToken */);
       const emittedCondition = skipPartiallyEmittedExpressions(condition);
       const conditionPrecedence = getExpressionPrecedence(emittedCondition);
       if (compareValues(conditionPrecedence, conditionalPrecedence) !== 1 /* GreaterThan */) {
@@ -118941,8 +101733,8 @@ ${lanes.join("\n")}
           /*stopAtCallExpressions*/
           false
         ).kind) {
-          case 230 /* ClassExpression */:
-          case 217 /* FunctionExpression */:
+          case 231 /* ClassExpression */:
+          case 218 /* FunctionExpression */:
             needsParens = true;
         }
       }
@@ -118955,16 +101747,16 @@ ${lanes.join("\n")}
         true
       );
       switch (leftmostExpr.kind) {
-        case 212 /* CallExpression */:
+        case 213 /* CallExpression */:
           return factory2.createParenthesizedExpression(expression);
-        case 213 /* NewExpression */:
+        case 214 /* NewExpression */:
           return !leftmostExpr.arguments ? factory2.createParenthesizedExpression(expression) : expression;
       }
       return parenthesizeLeftSideOfAccess(expression);
     }
     function parenthesizeLeftSideOfAccess(expression, optionalChain) {
       const emittedExpression = skipPartiallyEmittedExpressions(expression);
-      if (isLeftHandSideExpression(emittedExpression) && (emittedExpression.kind !== 213 /* NewExpression */ || emittedExpression.arguments) && (optionalChain || !isOptionalChain(emittedExpression))) {
+      if (isLeftHandSideExpression(emittedExpression) && (emittedExpression.kind !== 214 /* NewExpression */ || emittedExpression.arguments) && (optionalChain || !isOptionalChain(emittedExpression))) {
         return expression;
       }
       return setTextRange(factory2.createParenthesizedExpression(expression), expression);
@@ -118982,7 +101774,7 @@ ${lanes.join("\n")}
     function parenthesizeExpressionForDisallowedComma(expression) {
       const emittedExpression = skipPartiallyEmittedExpressions(expression);
       const expressionPrecedence = getExpressionPrecedence(emittedExpression);
-      const commaPrecedence = getOperatorPrecedence(225 /* BinaryExpression */, 28 /* CommaToken */);
+      const commaPrecedence = getOperatorPrecedence(226 /* BinaryExpression */, 28 /* CommaToken */);
       return expressionPrecedence > commaPrecedence ? expression : setTextRange(factory2.createParenthesizedExpression(expression), expression);
     }
     function parenthesizeExpressionOfExpressionStatement(expression) {
@@ -118990,7 +101782,7 @@ ${lanes.join("\n")}
       if (isCallExpression(emittedExpression)) {
         const callee = emittedExpression.expression;
         const kind = skipPartiallyEmittedExpressions(callee).kind;
-        if (kind === 217 /* FunctionExpression */ || kind === 218 /* ArrowFunction */) {
+        if (kind === 218 /* FunctionExpression */ || kind === 219 /* ArrowFunction */) {
           const updated = factory2.updateCallExpression(
             emittedExpression,
             setTextRange(factory2.createParenthesizedExpression(callee), callee),
@@ -119005,7 +101797,7 @@ ${lanes.join("\n")}
         /*stopAtCallExpressions*/
         false
       ).kind;
-      if (leftmostExpressionKind === 209 /* ObjectLiteralExpression */ || leftmostExpressionKind === 217 /* FunctionExpression */) {
+      if (leftmostExpressionKind === 210 /* ObjectLiteralExpression */ || leftmostExpressionKind === 218 /* FunctionExpression */) {
         return setTextRange(factory2.createParenthesizedExpression(expression), expression);
       }
       return expression;
@@ -119015,31 +101807,31 @@ ${lanes.join("\n")}
         body,
         /*stopAtCallExpressions*/
         false
-      ).kind === 209 /* ObjectLiteralExpression */)) {
+      ).kind === 210 /* ObjectLiteralExpression */)) {
         return setTextRange(factory2.createParenthesizedExpression(body), body);
       }
       return body;
     }
     function parenthesizeCheckTypeOfConditionalType(checkType) {
       switch (checkType.kind) {
-        case 183 /* FunctionType */:
-        case 184 /* ConstructorType */:
-        case 193 /* ConditionalType */:
+        case 184 /* FunctionType */:
+        case 185 /* ConstructorType */:
+        case 194 /* ConditionalType */:
           return factory2.createParenthesizedType(checkType);
       }
       return checkType;
     }
     function parenthesizeExtendsTypeOfConditionalType(extendsType) {
       switch (extendsType.kind) {
-        case 193 /* ConditionalType */:
+        case 194 /* ConditionalType */:
           return factory2.createParenthesizedType(extendsType);
       }
       return extendsType;
     }
     function parenthesizeConstituentTypeOfUnionType(type) {
       switch (type.kind) {
-        case 191 /* UnionType */:
-        case 192 /* IntersectionType */:
+        case 192 /* UnionType */:
+        case 193 /* IntersectionType */:
           return factory2.createParenthesizedType(type);
       }
       return parenthesizeCheckTypeOfConditionalType(type);
@@ -119049,8 +101841,8 @@ ${lanes.join("\n")}
     }
     function parenthesizeConstituentTypeOfIntersectionType(type) {
       switch (type.kind) {
-        case 191 /* UnionType */:
-        case 192 /* IntersectionType */:
+        case 192 /* UnionType */:
+        case 193 /* IntersectionType */:
           return factory2.createParenthesizedType(type);
       }
       return parenthesizeConstituentTypeOfUnionType(type);
@@ -119060,23 +101852,23 @@ ${lanes.join("\n")}
     }
     function parenthesizeOperandOfTypeOperator(type) {
       switch (type.kind) {
-        case 192 /* IntersectionType */:
+        case 193 /* IntersectionType */:
           return factory2.createParenthesizedType(type);
       }
       return parenthesizeConstituentTypeOfIntersectionType(type);
     }
     function parenthesizeOperandOfReadonlyTypeOperator(type) {
       switch (type.kind) {
-        case 197 /* TypeOperator */:
+        case 198 /* TypeOperator */:
           return factory2.createParenthesizedType(type);
       }
       return parenthesizeOperandOfTypeOperator(type);
     }
     function parenthesizeNonArrayTypeOfPostfixType(type) {
       switch (type.kind) {
-        case 194 /* InferType */:
-        case 197 /* TypeOperator */:
-        case 185 /* TypeQuery */:
+        case 195 /* InferType */:
+        case 198 /* TypeOperator */:
+        case 186 /* TypeQuery */:
           return factory2.createParenthesizedType(type);
       }
       return parenthesizeOperandOfTypeOperator(type);
@@ -119168,6 +101960,7 @@ ${lanes.join("\n")}
     return {
       convertToFunctionBlock,
       convertToFunctionExpression,
+      convertToClassExpression,
       convertToArrayAssignmentElement,
       convertToObjectAssignmentElement,
       convertToAssignmentPattern,
@@ -119185,10 +101978,11 @@ ${lanes.join("\n")}
       return body;
     }
     function convertToFunctionExpression(node) {
+      var _a;
       if (!node.body)
         return Debug.fail(`Cannot convert a FunctionDeclaration without a body`);
       const updated = factory2.createFunctionExpression(
-        getModifiers(node),
+        (_a = getModifiers(node)) == null ? void 0 : _a.filter((modifier) => !isExportModifier(modifier) && !isDefaultModifier(modifier)),
         node.asteriskToken,
         node.name,
         node.typeParameters,
@@ -119207,6 +102001,26 @@ ${lanes.join("\n")}
       }
       return updated;
     }
+    function convertToClassExpression(node) {
+      var _a;
+      const updated = factory2.createClassExpression(
+        (_a = node.modifiers) == null ? void 0 : _a.filter((modifier) => !isExportModifier(modifier) && !isDefaultModifier(modifier)),
+        node.name,
+        node.typeParameters,
+        node.heritageClauses,
+        node.members
+      );
+      setOriginalNode(updated, node);
+      setTextRange(updated, node);
+      if (getStartsOnNewLine(node)) {
+        setStartsOnNewLine(
+          updated,
+          /*newLine*/
+          true
+        );
+      }
+      return updated;
+    }
     function convertToArrayAssignmentElement(element) {
       if (isBindingElement(element)) {
         if (element.dotDotDotToken) {
@@ -119241,11 +102055,11 @@ ${lanes.join("\n")}
     }
     function convertToAssignmentPattern(node) {
       switch (node.kind) {
-        case 206 /* ArrayBindingPattern */:
-        case 208 /* ArrayLiteralExpression */:
+        case 207 /* ArrayBindingPattern */:
+        case 209 /* ArrayLiteralExpression */:
           return convertToArrayAssignmentPattern(node);
-        case 205 /* ObjectBindingPattern */:
-        case 209 /* ObjectLiteralExpression */:
+        case 206 /* ObjectBindingPattern */:
+        case 210 /* ObjectLiteralExpression */:
           return convertToObjectAssignmentPattern(node);
       }
     }
@@ -119288,6 +102102,7 @@ ${lanes.join("\n")}
       nullNodeConverters = {
         convertToFunctionBlock: notImplemented,
         convertToFunctionExpression: notImplemented,
+        convertToClassExpression: notImplemented,
         convertToArrayAssignmentElement: notImplemented,
         convertToObjectAssignmentElement: notImplemented,
         convertToAssignmentPattern: notImplemented,
@@ -119579,6 +102394,10 @@ ${lanes.join("\n")}
       updateAssertEntry,
       createImportTypeAssertionContainer,
       updateImportTypeAssertionContainer,
+      createImportAttributes,
+      updateImportAttributes,
+      createImportAttribute,
+      updateImportAttribute,
       createNamespaceImport,
       updateNamespaceImport,
       createNamespaceExport,
@@ -119600,40 +102419,40 @@ ${lanes.join("\n")}
       updateExternalModuleReference,
       // lazily load factory members for JSDoc types with similar structure
       get createJSDocAllType() {
-        return getJSDocPrimaryTypeCreateFunction(318 /* JSDocAllType */);
+        return getJSDocPrimaryTypeCreateFunction(319 /* JSDocAllType */);
       },
       get createJSDocUnknownType() {
-        return getJSDocPrimaryTypeCreateFunction(319 /* JSDocUnknownType */);
+        return getJSDocPrimaryTypeCreateFunction(320 /* JSDocUnknownType */);
       },
       get createJSDocNonNullableType() {
-        return getJSDocPrePostfixUnaryTypeCreateFunction(321 /* JSDocNonNullableType */);
+        return getJSDocPrePostfixUnaryTypeCreateFunction(322 /* JSDocNonNullableType */);
       },
       get updateJSDocNonNullableType() {
-        return getJSDocPrePostfixUnaryTypeUpdateFunction(321 /* JSDocNonNullableType */);
+        return getJSDocPrePostfixUnaryTypeUpdateFunction(322 /* JSDocNonNullableType */);
       },
       get createJSDocNullableType() {
-        return getJSDocPrePostfixUnaryTypeCreateFunction(320 /* JSDocNullableType */);
+        return getJSDocPrePostfixUnaryTypeCreateFunction(321 /* JSDocNullableType */);
       },
       get updateJSDocNullableType() {
-        return getJSDocPrePostfixUnaryTypeUpdateFunction(320 /* JSDocNullableType */);
+        return getJSDocPrePostfixUnaryTypeUpdateFunction(321 /* JSDocNullableType */);
       },
       get createJSDocOptionalType() {
-        return getJSDocUnaryTypeCreateFunction(322 /* JSDocOptionalType */);
+        return getJSDocUnaryTypeCreateFunction(323 /* JSDocOptionalType */);
       },
       get updateJSDocOptionalType() {
-        return getJSDocUnaryTypeUpdateFunction(322 /* JSDocOptionalType */);
+        return getJSDocUnaryTypeUpdateFunction(323 /* JSDocOptionalType */);
       },
       get createJSDocVariadicType() {
-        return getJSDocUnaryTypeCreateFunction(324 /* JSDocVariadicType */);
+        return getJSDocUnaryTypeCreateFunction(325 /* JSDocVariadicType */);
       },
       get updateJSDocVariadicType() {
-        return getJSDocUnaryTypeUpdateFunction(324 /* JSDocVariadicType */);
+        return getJSDocUnaryTypeUpdateFunction(325 /* JSDocVariadicType */);
       },
       get createJSDocNamepathType() {
-        return getJSDocUnaryTypeCreateFunction(325 /* JSDocNamepathType */);
+        return getJSDocUnaryTypeCreateFunction(326 /* JSDocNamepathType */);
       },
       get updateJSDocNamepathType() {
-        return getJSDocUnaryTypeUpdateFunction(325 /* JSDocNamepathType */);
+        return getJSDocUnaryTypeUpdateFunction(326 /* JSDocNamepathType */);
       },
       createJSDocFunctionType,
       updateJSDocFunctionType,
@@ -119673,82 +102492,82 @@ ${lanes.join("\n")}
       updateJSDocLinkPlain,
       // lazily load factory members for JSDoc tags with similar structure
       get createJSDocTypeTag() {
-        return getJSDocTypeLikeTagCreateFunction(350 /* JSDocTypeTag */);
+        return getJSDocTypeLikeTagCreateFunction(351 /* JSDocTypeTag */);
       },
       get updateJSDocTypeTag() {
-        return getJSDocTypeLikeTagUpdateFunction(350 /* JSDocTypeTag */);
+        return getJSDocTypeLikeTagUpdateFunction(351 /* JSDocTypeTag */);
       },
       get createJSDocReturnTag() {
-        return getJSDocTypeLikeTagCreateFunction(348 /* JSDocReturnTag */);
+        return getJSDocTypeLikeTagCreateFunction(349 /* JSDocReturnTag */);
       },
       get updateJSDocReturnTag() {
-        return getJSDocTypeLikeTagUpdateFunction(348 /* JSDocReturnTag */);
+        return getJSDocTypeLikeTagUpdateFunction(349 /* JSDocReturnTag */);
       },
       get createJSDocThisTag() {
-        return getJSDocTypeLikeTagCreateFunction(349 /* JSDocThisTag */);
+        return getJSDocTypeLikeTagCreateFunction(350 /* JSDocThisTag */);
       },
       get updateJSDocThisTag() {
-        return getJSDocTypeLikeTagUpdateFunction(349 /* JSDocThisTag */);
+        return getJSDocTypeLikeTagUpdateFunction(350 /* JSDocThisTag */);
       },
       get createJSDocAuthorTag() {
-        return getJSDocSimpleTagCreateFunction(336 /* JSDocAuthorTag */);
+        return getJSDocSimpleTagCreateFunction(337 /* JSDocAuthorTag */);
       },
       get updateJSDocAuthorTag() {
-        return getJSDocSimpleTagUpdateFunction(336 /* JSDocAuthorTag */);
+        return getJSDocSimpleTagUpdateFunction(337 /* JSDocAuthorTag */);
       },
       get createJSDocClassTag() {
-        return getJSDocSimpleTagCreateFunction(338 /* JSDocClassTag */);
+        return getJSDocSimpleTagCreateFunction(339 /* JSDocClassTag */);
       },
       get updateJSDocClassTag() {
-        return getJSDocSimpleTagUpdateFunction(338 /* JSDocClassTag */);
+        return getJSDocSimpleTagUpdateFunction(339 /* JSDocClassTag */);
       },
       get createJSDocPublicTag() {
-        return getJSDocSimpleTagCreateFunction(339 /* JSDocPublicTag */);
+        return getJSDocSimpleTagCreateFunction(340 /* JSDocPublicTag */);
       },
       get updateJSDocPublicTag() {
-        return getJSDocSimpleTagUpdateFunction(339 /* JSDocPublicTag */);
+        return getJSDocSimpleTagUpdateFunction(340 /* JSDocPublicTag */);
       },
       get createJSDocPrivateTag() {
-        return getJSDocSimpleTagCreateFunction(340 /* JSDocPrivateTag */);
+        return getJSDocSimpleTagCreateFunction(341 /* JSDocPrivateTag */);
       },
       get updateJSDocPrivateTag() {
-        return getJSDocSimpleTagUpdateFunction(340 /* JSDocPrivateTag */);
+        return getJSDocSimpleTagUpdateFunction(341 /* JSDocPrivateTag */);
       },
       get createJSDocProtectedTag() {
-        return getJSDocSimpleTagCreateFunction(341 /* JSDocProtectedTag */);
+        return getJSDocSimpleTagCreateFunction(342 /* JSDocProtectedTag */);
       },
       get updateJSDocProtectedTag() {
-        return getJSDocSimpleTagUpdateFunction(341 /* JSDocProtectedTag */);
+        return getJSDocSimpleTagUpdateFunction(342 /* JSDocProtectedTag */);
       },
       get createJSDocReadonlyTag() {
-        return getJSDocSimpleTagCreateFunction(342 /* JSDocReadonlyTag */);
+        return getJSDocSimpleTagCreateFunction(343 /* JSDocReadonlyTag */);
       },
       get updateJSDocReadonlyTag() {
-        return getJSDocSimpleTagUpdateFunction(342 /* JSDocReadonlyTag */);
+        return getJSDocSimpleTagUpdateFunction(343 /* JSDocReadonlyTag */);
       },
       get createJSDocOverrideTag() {
-        return getJSDocSimpleTagCreateFunction(343 /* JSDocOverrideTag */);
+        return getJSDocSimpleTagCreateFunction(344 /* JSDocOverrideTag */);
       },
       get updateJSDocOverrideTag() {
-        return getJSDocSimpleTagUpdateFunction(343 /* JSDocOverrideTag */);
+        return getJSDocSimpleTagUpdateFunction(344 /* JSDocOverrideTag */);
       },
       get createJSDocDeprecatedTag() {
-        return getJSDocSimpleTagCreateFunction(337 /* JSDocDeprecatedTag */);
+        return getJSDocSimpleTagCreateFunction(338 /* JSDocDeprecatedTag */);
       },
       get updateJSDocDeprecatedTag() {
-        return getJSDocSimpleTagUpdateFunction(337 /* JSDocDeprecatedTag */);
+        return getJSDocSimpleTagUpdateFunction(338 /* JSDocDeprecatedTag */);
       },
       get createJSDocThrowsTag() {
-        return getJSDocTypeLikeTagCreateFunction(355 /* JSDocThrowsTag */);
+        return getJSDocTypeLikeTagCreateFunction(356 /* JSDocThrowsTag */);
       },
       get updateJSDocThrowsTag() {
-        return getJSDocTypeLikeTagUpdateFunction(355 /* JSDocThrowsTag */);
+        return getJSDocTypeLikeTagUpdateFunction(356 /* JSDocThrowsTag */);
       },
       get createJSDocSatisfiesTag() {
-        return getJSDocTypeLikeTagCreateFunction(356 /* JSDocSatisfiesTag */);
+        return getJSDocTypeLikeTagCreateFunction(357 /* JSDocSatisfiesTag */);
       },
       get updateJSDocSatisfiesTag() {
-        return getJSDocTypeLikeTagUpdateFunction(356 /* JSDocSatisfiesTag */);
+        return getJSDocTypeLikeTagUpdateFunction(357 /* JSDocSatisfiesTag */);
       },
       createJSDocEnumTag,
       updateJSDocEnumTag,
@@ -119923,6 +102742,7 @@ ${lanes.join("\n")}
       createExportDefault,
       createExternalModuleExport,
       createTypeCheck,
+      createIsNotTypeCheck,
       createMethodCall,
       createGlobalMethodCall,
       createFunctionBindCall,
@@ -119954,7 +102774,9 @@ ${lanes.join("\n")}
       ensureUseStrict,
       liftToBlock,
       mergeLexicalEnvironment,
-      updateModifiers
+      replaceModifiers,
+      replaceDecoratorsAndModifiers,
+      replacePropertyName
     };
     forEach(nodeFactoryPatchers, (fn) => fn(factory2));
     return factory2;
@@ -120112,11 +102934,11 @@ ${lanes.join("\n")}
       }
       const node = createBaseIdentifier(escapeLeadingUnderscores(text));
       if (hasExtendedUnicodeEscape)
-        node.flags |= 128 /* IdentifierHasExtendedUnicodeEscape */;
+        node.flags |= 256 /* IdentifierHasExtendedUnicodeEscape */;
       if (node.escapedText === "await") {
         node.transformFlags |= 67108864 /* ContainsPossibleTopLevelAwait */;
       }
-      if (node.flags & 128 /* IdentifierHasExtendedUnicodeEscape */) {
+      if (node.flags & 256 /* IdentifierHasExtendedUnicodeEscape */) {
         node.transformFlags |= 1024 /* ContainsES2015 */;
       }
       return node;
@@ -120211,7 +103033,7 @@ ${lanes.join("\n")}
       return baseFactory2.createBaseTokenNode(kind);
     }
     function createToken(token) {
-      Debug.assert(token >= 0 /* FirstToken */ && token <= 164 /* LastToken */, "Invalid token");
+      Debug.assert(token >= 0 /* FirstToken */ && token <= 165 /* LastToken */, "Invalid token");
       Debug.assert(token <= 15 /* FirstTemplateToken */ || token >= 18 /* LastTemplateToken */, "Invalid token. Use 'createTemplateLiteralLikeNode' to create template literals.");
       Debug.assert(token <= 9 /* FirstLiteralToken */ || token >= 15 /* LastLiteralToken */, "Invalid token. Use 'createLiteralLikeNode' to create literals.");
       Debug.assert(token !== 80 /* Identifier */, "Invalid token. Use 'createIdentifier' to create identifiers");
@@ -120221,6 +103043,9 @@ ${lanes.join("\n")}
         case 134 /* AsyncKeyword */:
           transformFlags = 256 /* ContainsES2017 */ | 128 /* ContainsES2018 */;
           break;
+        case 160 /* UsingKeyword */:
+          transformFlags = 4 /* ContainsESNext */;
+          break;
         case 125 /* PublicKeyword */:
         case 123 /* PrivateKeyword */:
         case 124 /* ProtectedKeyword */:
@@ -120230,12 +103055,12 @@ ${lanes.join("\n")}
         case 87 /* ConstKeyword */:
         case 133 /* AnyKeyword */:
         case 150 /* NumberKeyword */:
-        case 162 /* BigIntKeyword */:
+        case 163 /* BigIntKeyword */:
         case 146 /* NeverKeyword */:
         case 151 /* ObjectKeyword */:
         case 103 /* InKeyword */:
         case 147 /* OutKeyword */:
-        case 163 /* OverrideKeyword */:
+        case 164 /* OverrideKeyword */:
         case 154 /* StringKeyword */:
         case 136 /* BooleanKeyword */:
         case 155 /* SymbolKeyword */:
@@ -120284,40 +103109,40 @@ ${lanes.join("\n")}
     }
     function createModifiersFromModifierFlags(flags2) {
       const result = [];
-      if (flags2 & 1 /* Export */)
+      if (flags2 & 32 /* Export */)
         result.push(createModifier(95 /* ExportKeyword */));
-      if (flags2 & 2 /* Ambient */)
+      if (flags2 & 128 /* Ambient */)
         result.push(createModifier(138 /* DeclareKeyword */));
-      if (flags2 & 1024 /* Default */)
+      if (flags2 & 2048 /* Default */)
         result.push(createModifier(90 /* DefaultKeyword */));
-      if (flags2 & 2048 /* Const */)
+      if (flags2 & 4096 /* Const */)
         result.push(createModifier(87 /* ConstKeyword */));
-      if (flags2 & 4 /* Public */)
+      if (flags2 & 1 /* Public */)
         result.push(createModifier(125 /* PublicKeyword */));
-      if (flags2 & 8 /* Private */)
+      if (flags2 & 2 /* Private */)
         result.push(createModifier(123 /* PrivateKeyword */));
-      if (flags2 & 16 /* Protected */)
+      if (flags2 & 4 /* Protected */)
         result.push(createModifier(124 /* ProtectedKeyword */));
-      if (flags2 & 256 /* Abstract */)
+      if (flags2 & 64 /* Abstract */)
         result.push(createModifier(128 /* AbstractKeyword */));
-      if (flags2 & 32 /* Static */)
+      if (flags2 & 256 /* Static */)
         result.push(createModifier(126 /* StaticKeyword */));
-      if (flags2 & 16384 /* Override */)
-        result.push(createModifier(163 /* OverrideKeyword */));
-      if (flags2 & 64 /* Readonly */)
+      if (flags2 & 16 /* Override */)
+        result.push(createModifier(164 /* OverrideKeyword */));
+      if (flags2 & 8 /* Readonly */)
         result.push(createModifier(148 /* ReadonlyKeyword */));
-      if (flags2 & 128 /* Accessor */)
+      if (flags2 & 512 /* Accessor */)
         result.push(createModifier(129 /* AccessorKeyword */));
-      if (flags2 & 512 /* Async */)
+      if (flags2 & 1024 /* Async */)
         result.push(createModifier(134 /* AsyncKeyword */));
-      if (flags2 & 32768 /* In */)
+      if (flags2 & 8192 /* In */)
         result.push(createModifier(103 /* InKeyword */));
-      if (flags2 & 65536 /* Out */)
+      if (flags2 & 16384 /* Out */)
         result.push(createModifier(147 /* OutKeyword */));
       return result.length ? result : void 0;
     }
     function createQualifiedName(left, right) {
-      const node = createBaseNode(165 /* QualifiedName */);
+      const node = createBaseNode(166 /* QualifiedName */);
       node.left = left;
       node.right = asName(right);
       node.transformFlags |= propagateChildFlags(node.left) | propagateIdentifierNameFlags(node.right);
@@ -120328,7 +103153,7 @@ ${lanes.join("\n")}
       return node.left !== left || node.right !== right ? update(createQualifiedName(left, right), node) : node;
     }
     function createComputedPropertyName(expression) {
-      const node = createBaseNode(166 /* ComputedPropertyName */);
+      const node = createBaseNode(167 /* ComputedPropertyName */);
       node.expression = parenthesizerRules().parenthesizeExpressionOfComputedPropertyName(expression);
       node.transformFlags |= propagateChildFlags(node.expression) | 1024 /* ContainsES2015 */ | 131072 /* ContainsComputedPropertyName */;
       return node;
@@ -120337,7 +103162,7 @@ ${lanes.join("\n")}
       return node.expression !== expression ? update(createComputedPropertyName(expression), node) : node;
     }
     function createTypeParameterDeclaration(modifiers, name, constraint, defaultType) {
-      const node = createBaseDeclaration(167 /* TypeParameter */);
+      const node = createBaseDeclaration(168 /* TypeParameter */);
       node.modifiers = asNodeArray(modifiers);
       node.name = asName(name);
       node.constraint = constraint;
@@ -120351,7 +103176,7 @@ ${lanes.join("\n")}
       return node.modifiers !== modifiers || node.name !== name || node.constraint !== constraint || node.default !== defaultType ? update(createTypeParameterDeclaration(modifiers, name, constraint, defaultType), node) : node;
     }
     function createParameterDeclaration(modifiers, dotDotDotToken, name, questionToken, type, initializer) {
-      const node = createBaseDeclaration(168 /* Parameter */);
+      const node = createBaseDeclaration(169 /* Parameter */);
       node.modifiers = asNodeArray(modifiers);
       node.dotDotDotToken = dotDotDotToken;
       node.name = asName(name);
@@ -120361,7 +103186,7 @@ ${lanes.join("\n")}
       if (isThisIdentifier(node.name)) {
         node.transformFlags = 1 /* ContainsTypeScript */;
       } else {
-        node.transformFlags = propagateChildrenFlags(node.modifiers) | propagateChildFlags(node.dotDotDotToken) | propagateNameFlags(node.name) | propagateChildFlags(node.questionToken) | propagateChildFlags(node.initializer) | (node.questionToken ?? node.type ? 1 /* ContainsTypeScript */ : 0 /* None */) | (node.dotDotDotToken ?? node.initializer ? 1024 /* ContainsES2015 */ : 0 /* None */) | (modifiersToFlags(node.modifiers) & 16476 /* ParameterPropertyModifier */ ? 8192 /* ContainsTypeScriptClassSyntax */ : 0 /* None */);
+        node.transformFlags = propagateChildrenFlags(node.modifiers) | propagateChildFlags(node.dotDotDotToken) | propagateNameFlags(node.name) | propagateChildFlags(node.questionToken) | propagateChildFlags(node.initializer) | (node.questionToken ?? node.type ? 1 /* ContainsTypeScript */ : 0 /* None */) | (node.dotDotDotToken ?? node.initializer ? 1024 /* ContainsES2015 */ : 0 /* None */) | (modifiersToFlags(node.modifiers) & 31 /* ParameterPropertyModifier */ ? 8192 /* ContainsTypeScriptClassSyntax */ : 0 /* None */);
       }
       node.jsDoc = void 0;
       return node;
@@ -120370,7 +103195,7 @@ ${lanes.join("\n")}
       return node.modifiers !== modifiers || node.dotDotDotToken !== dotDotDotToken || node.name !== name || node.questionToken !== questionToken || node.type !== type || node.initializer !== initializer ? update(createParameterDeclaration(modifiers, dotDotDotToken, name, questionToken, type, initializer), node) : node;
     }
     function createDecorator(expression) {
-      const node = createBaseNode(169 /* Decorator */);
+      const node = createBaseNode(170 /* Decorator */);
       node.expression = parenthesizerRules().parenthesizeLeftSideOfAccess(
         expression,
         /*optionalChain*/
@@ -120383,7 +103208,7 @@ ${lanes.join("\n")}
       return node.expression !== expression ? update(createDecorator(expression), node) : node;
     }
     function createPropertySignature(modifiers, name, questionToken, type) {
-      const node = createBaseDeclaration(170 /* PropertySignature */);
+      const node = createBaseDeclaration(171 /* PropertySignature */);
       node.modifiers = asNodeArray(modifiers);
       node.name = asName(name);
       node.type = type;
@@ -120403,15 +103228,15 @@ ${lanes.join("\n")}
       return update(updated, original);
     }
     function createPropertyDeclaration(modifiers, name, questionOrExclamationToken, type, initializer) {
-      const node = createBaseDeclaration(171 /* PropertyDeclaration */);
+      const node = createBaseDeclaration(172 /* PropertyDeclaration */);
       node.modifiers = asNodeArray(modifiers);
       node.name = asName(name);
       node.questionToken = questionOrExclamationToken && isQuestionToken(questionOrExclamationToken) ? questionOrExclamationToken : void 0;
       node.exclamationToken = questionOrExclamationToken && isExclamationToken(questionOrExclamationToken) ? questionOrExclamationToken : void 0;
       node.type = type;
       node.initializer = asInitializer(initializer);
-      const isAmbient = node.flags & 16777216 /* Ambient */ || modifiersToFlags(node.modifiers) & 2 /* Ambient */;
-      node.transformFlags = propagateChildrenFlags(node.modifiers) | propagateNameFlags(node.name) | propagateChildFlags(node.initializer) | (isAmbient || node.questionToken || node.exclamationToken || node.type ? 1 /* ContainsTypeScript */ : 0 /* None */) | (isComputedPropertyName(node.name) || modifiersToFlags(node.modifiers) & 32 /* Static */ && node.initializer ? 8192 /* ContainsTypeScriptClassSyntax */ : 0 /* None */) | 16777216 /* ContainsClassFields */;
+      const isAmbient = node.flags & 33554432 /* Ambient */ || modifiersToFlags(node.modifiers) & 128 /* Ambient */;
+      node.transformFlags = propagateChildrenFlags(node.modifiers) | propagateNameFlags(node.name) | propagateChildFlags(node.initializer) | (isAmbient || node.questionToken || node.exclamationToken || node.type ? 1 /* ContainsTypeScript */ : 0 /* None */) | (isComputedPropertyName(node.name) || modifiersToFlags(node.modifiers) & 256 /* Static */ && node.initializer ? 8192 /* ContainsTypeScriptClassSyntax */ : 0 /* None */) | 16777216 /* ContainsClassFields */;
       node.jsDoc = void 0;
       return node;
     }
@@ -120419,7 +103244,7 @@ ${lanes.join("\n")}
       return node.modifiers !== modifiers || node.name !== name || node.questionToken !== (questionOrExclamationToken !== void 0 && isQuestionToken(questionOrExclamationToken) ? questionOrExclamationToken : void 0) || node.exclamationToken !== (questionOrExclamationToken !== void 0 && isExclamationToken(questionOrExclamationToken) ? questionOrExclamationToken : void 0) || node.type !== type || node.initializer !== initializer ? update(createPropertyDeclaration(modifiers, name, questionOrExclamationToken, type, initializer), node) : node;
     }
     function createMethodSignature(modifiers, name, questionToken, typeParameters, parameters, type) {
-      const node = createBaseDeclaration(172 /* MethodSignature */);
+      const node = createBaseDeclaration(173 /* MethodSignature */);
       node.modifiers = asNodeArray(modifiers);
       node.name = asName(name);
       node.questionToken = questionToken;
@@ -120437,7 +103262,7 @@ ${lanes.join("\n")}
       return node.modifiers !== modifiers || node.name !== name || node.questionToken !== questionToken || node.typeParameters !== typeParameters || node.parameters !== parameters || node.type !== type ? finishUpdateBaseSignatureDeclaration(createMethodSignature(modifiers, name, questionToken, typeParameters, parameters, type), node) : node;
     }
     function createMethodDeclaration(modifiers, asteriskToken, name, questionToken, typeParameters, parameters, type, body) {
-      const node = createBaseDeclaration(173 /* MethodDeclaration */);
+      const node = createBaseDeclaration(174 /* MethodDeclaration */);
       node.modifiers = asNodeArray(modifiers);
       node.asteriskToken = asteriskToken;
       node.name = asName(name);
@@ -120450,7 +103275,7 @@ ${lanes.join("\n")}
       if (!node.body) {
         node.transformFlags = 1 /* ContainsTypeScript */;
       } else {
-        const isAsync = modifiersToFlags(node.modifiers) & 512 /* Async */;
+        const isAsync = modifiersToFlags(node.modifiers) & 1024 /* Async */;
         const isGenerator = !!node.asteriskToken;
         const isAsyncGenerator = isAsync && isGenerator;
         node.transformFlags = propagateChildrenFlags(node.modifiers) | propagateChildFlags(node.asteriskToken) | propagateNameFlags(node.name) | propagateChildFlags(node.questionToken) | propagateChildrenFlags(node.typeParameters) | propagateChildrenFlags(node.parameters) | propagateChildFlags(node.type) | propagateChildFlags(node.body) & ~67108864 /* ContainsPossibleTopLevelAwait */ | (isAsyncGenerator ? 128 /* ContainsES2018 */ : isAsync ? 256 /* ContainsES2017 */ : isGenerator ? 2048 /* ContainsGenerator */ : 0 /* None */) | (node.questionToken || node.typeParameters || node.type ? 1 /* ContainsTypeScript */ : 0 /* None */) | 1024 /* ContainsES2015 */;
@@ -120474,7 +103299,7 @@ ${lanes.join("\n")}
       return update(updated, original);
     }
     function createClassStaticBlockDeclaration(body) {
-      const node = createBaseDeclaration(174 /* ClassStaticBlockDeclaration */);
+      const node = createBaseDeclaration(175 /* ClassStaticBlockDeclaration */);
       node.body = body;
       node.transformFlags = propagateChildFlags(body) | 16777216 /* ContainsClassFields */;
       node.modifiers = void 0;
@@ -120495,7 +103320,7 @@ ${lanes.join("\n")}
       return update(updated, original);
     }
     function createConstructorDeclaration(modifiers, parameters, body) {
-      const node = createBaseDeclaration(175 /* Constructor */);
+      const node = createBaseDeclaration(176 /* Constructor */);
       node.modifiers = asNodeArray(modifiers);
       node.parameters = createNodeArray(parameters);
       node.body = body;
@@ -120521,7 +103346,7 @@ ${lanes.join("\n")}
       return finishUpdateBaseSignatureDeclaration(updated, original);
     }
     function createGetAccessorDeclaration(modifiers, name, parameters, type, body) {
-      const node = createBaseDeclaration(176 /* GetAccessor */);
+      const node = createBaseDeclaration(177 /* GetAccessor */);
       node.modifiers = asNodeArray(modifiers);
       node.name = asName(name);
       node.parameters = createNodeArray(parameters);
@@ -120552,7 +103377,7 @@ ${lanes.join("\n")}
       return finishUpdateBaseSignatureDeclaration(updated, original);
     }
     function createSetAccessorDeclaration(modifiers, name, parameters, body) {
-      const node = createBaseDeclaration(177 /* SetAccessor */);
+      const node = createBaseDeclaration(178 /* SetAccessor */);
       node.modifiers = asNodeArray(modifiers);
       node.name = asName(name);
       node.parameters = createNodeArray(parameters);
@@ -120584,7 +103409,7 @@ ${lanes.join("\n")}
       return finishUpdateBaseSignatureDeclaration(updated, original);
     }
     function createCallSignature(typeParameters, parameters, type) {
-      const node = createBaseDeclaration(178 /* CallSignature */);
+      const node = createBaseDeclaration(179 /* CallSignature */);
       node.typeParameters = asNodeArray(typeParameters);
       node.parameters = asNodeArray(parameters);
       node.type = type;
@@ -120599,7 +103424,7 @@ ${lanes.join("\n")}
       return node.typeParameters !== typeParameters || node.parameters !== parameters || node.type !== type ? finishUpdateBaseSignatureDeclaration(createCallSignature(typeParameters, parameters, type), node) : node;
     }
     function createConstructSignature(typeParameters, parameters, type) {
-      const node = createBaseDeclaration(179 /* ConstructSignature */);
+      const node = createBaseDeclaration(180 /* ConstructSignature */);
       node.typeParameters = asNodeArray(typeParameters);
       node.parameters = asNodeArray(parameters);
       node.type = type;
@@ -120614,7 +103439,7 @@ ${lanes.join("\n")}
       return node.typeParameters !== typeParameters || node.parameters !== parameters || node.type !== type ? finishUpdateBaseSignatureDeclaration(createConstructSignature(typeParameters, parameters, type), node) : node;
     }
     function createIndexSignature(modifiers, parameters, type) {
-      const node = createBaseDeclaration(180 /* IndexSignature */);
+      const node = createBaseDeclaration(181 /* IndexSignature */);
       node.modifiers = asNodeArray(modifiers);
       node.parameters = asNodeArray(parameters);
       node.type = type;
@@ -120629,7 +103454,7 @@ ${lanes.join("\n")}
       return node.parameters !== parameters || node.type !== type || node.modifiers !== modifiers ? finishUpdateBaseSignatureDeclaration(createIndexSignature(modifiers, parameters, type), node) : node;
     }
     function createTemplateLiteralTypeSpan(type, literal) {
-      const node = createBaseNode(203 /* TemplateLiteralTypeSpan */);
+      const node = createBaseNode(204 /* TemplateLiteralTypeSpan */);
       node.type = type;
       node.literal = literal;
       node.transformFlags = 1 /* ContainsTypeScript */;
@@ -120642,7 +103467,7 @@ ${lanes.join("\n")}
       return createToken(kind);
     }
     function createTypePredicateNode(assertsModifier, parameterName, type) {
-      const node = createBaseNode(181 /* TypePredicate */);
+      const node = createBaseNode(182 /* TypePredicate */);
       node.assertsModifier = assertsModifier;
       node.parameterName = asName(parameterName);
       node.type = type;
@@ -120653,7 +103478,7 @@ ${lanes.join("\n")}
       return node.assertsModifier !== assertsModifier || node.parameterName !== parameterName || node.type !== type ? update(createTypePredicateNode(assertsModifier, parameterName, type), node) : node;
     }
     function createTypeReferenceNode(typeName, typeArguments) {
-      const node = createBaseNode(182 /* TypeReference */);
+      const node = createBaseNode(183 /* TypeReference */);
       node.typeName = asName(typeName);
       node.typeArguments = typeArguments && parenthesizerRules().parenthesizeTypeArguments(createNodeArray(typeArguments));
       node.transformFlags = 1 /* ContainsTypeScript */;
@@ -120663,7 +103488,7 @@ ${lanes.join("\n")}
       return node.typeName !== typeName || node.typeArguments !== typeArguments ? update(createTypeReferenceNode(typeName, typeArguments), node) : node;
     }
     function createFunctionTypeNode(typeParameters, parameters, type) {
-      const node = createBaseDeclaration(183 /* FunctionType */);
+      const node = createBaseDeclaration(184 /* FunctionType */);
       node.typeParameters = asNodeArray(typeParameters);
       node.parameters = asNodeArray(parameters);
       node.type = type;
@@ -120688,7 +103513,7 @@ ${lanes.join("\n")}
       return args.length === 4 ? createConstructorTypeNode1(...args) : args.length === 3 ? createConstructorTypeNode2(...args) : Debug.fail("Incorrect number of arguments specified.");
     }
     function createConstructorTypeNode1(modifiers, typeParameters, parameters, type) {
-      const node = createBaseDeclaration(184 /* ConstructorType */);
+      const node = createBaseDeclaration(185 /* ConstructorType */);
       node.modifiers = asNodeArray(modifiers);
       node.typeParameters = asNodeArray(typeParameters);
       node.parameters = asNodeArray(parameters);
@@ -120719,7 +103544,7 @@ ${lanes.join("\n")}
       return updateConstructorTypeNode1(node, node.modifiers, typeParameters, parameters, type);
     }
     function createTypeQueryNode(exprName, typeArguments) {
-      const node = createBaseNode(185 /* TypeQuery */);
+      const node = createBaseNode(186 /* TypeQuery */);
       node.exprName = exprName;
       node.typeArguments = typeArguments && parenthesizerRules().parenthesizeTypeArguments(typeArguments);
       node.transformFlags = 1 /* ContainsTypeScript */;
@@ -120729,7 +103554,7 @@ ${lanes.join("\n")}
       return node.exprName !== exprName || node.typeArguments !== typeArguments ? update(createTypeQueryNode(exprName, typeArguments), node) : node;
     }
     function createTypeLiteralNode(members) {
-      const node = createBaseDeclaration(186 /* TypeLiteral */);
+      const node = createBaseDeclaration(187 /* TypeLiteral */);
       node.members = createNodeArray(members);
       node.transformFlags = 1 /* ContainsTypeScript */;
       return node;
@@ -120738,7 +103563,7 @@ ${lanes.join("\n")}
       return node.members !== members ? update(createTypeLiteralNode(members), node) : node;
     }
     function createArrayTypeNode(elementType) {
-      const node = createBaseNode(187 /* ArrayType */);
+      const node = createBaseNode(188 /* ArrayType */);
       node.elementType = parenthesizerRules().parenthesizeNonArrayTypeOfPostfixType(elementType);
       node.transformFlags = 1 /* ContainsTypeScript */;
       return node;
@@ -120747,7 +103572,7 @@ ${lanes.join("\n")}
       return node.elementType !== elementType ? update(createArrayTypeNode(elementType), node) : node;
     }
     function createTupleTypeNode(elements) {
-      const node = createBaseNode(188 /* TupleType */);
+      const node = createBaseNode(189 /* TupleType */);
       node.elements = createNodeArray(parenthesizerRules().parenthesizeElementTypesOfTupleType(elements));
       node.transformFlags = 1 /* ContainsTypeScript */;
       return node;
@@ -120756,7 +103581,7 @@ ${lanes.join("\n")}
       return node.elements !== elements ? update(createTupleTypeNode(elements), node) : node;
     }
     function createNamedTupleMember(dotDotDotToken, name, questionToken, type) {
-      const node = createBaseDeclaration(201 /* NamedTupleMember */);
+      const node = createBaseDeclaration(202 /* NamedTupleMember */);
       node.dotDotDotToken = dotDotDotToken;
       node.name = name;
       node.questionToken = questionToken;
@@ -120769,7 +103594,7 @@ ${lanes.join("\n")}
       return node.dotDotDotToken !== dotDotDotToken || node.name !== name || node.questionToken !== questionToken || node.type !== type ? update(createNamedTupleMember(dotDotDotToken, name, questionToken, type), node) : node;
     }
     function createOptionalTypeNode(type) {
-      const node = createBaseNode(189 /* OptionalType */);
+      const node = createBaseNode(190 /* OptionalType */);
       node.type = parenthesizerRules().parenthesizeTypeOfOptionalType(type);
       node.transformFlags = 1 /* ContainsTypeScript */;
       return node;
@@ -120778,7 +103603,7 @@ ${lanes.join("\n")}
       return node.type !== type ? update(createOptionalTypeNode(type), node) : node;
     }
     function createRestTypeNode(type) {
-      const node = createBaseNode(190 /* RestType */);
+      const node = createBaseNode(191 /* RestType */);
       node.type = type;
       node.transformFlags = 1 /* ContainsTypeScript */;
       return node;
@@ -120796,19 +103621,19 @@ ${lanes.join("\n")}
       return node.types !== types ? update(createUnionOrIntersectionTypeNode(node.kind, types, parenthesize), node) : node;
     }
     function createUnionTypeNode(types) {
-      return createUnionOrIntersectionTypeNode(191 /* UnionType */, types, parenthesizerRules().parenthesizeConstituentTypesOfUnionType);
+      return createUnionOrIntersectionTypeNode(192 /* UnionType */, types, parenthesizerRules().parenthesizeConstituentTypesOfUnionType);
     }
     function updateUnionTypeNode(node, types) {
       return updateUnionOrIntersectionTypeNode(node, types, parenthesizerRules().parenthesizeConstituentTypesOfUnionType);
     }
     function createIntersectionTypeNode(types) {
-      return createUnionOrIntersectionTypeNode(192 /* IntersectionType */, types, parenthesizerRules().parenthesizeConstituentTypesOfIntersectionType);
+      return createUnionOrIntersectionTypeNode(193 /* IntersectionType */, types, parenthesizerRules().parenthesizeConstituentTypesOfIntersectionType);
     }
     function updateIntersectionTypeNode(node, types) {
       return updateUnionOrIntersectionTypeNode(node, types, parenthesizerRules().parenthesizeConstituentTypesOfIntersectionType);
     }
     function createConditionalTypeNode(checkType, extendsType, trueType, falseType) {
-      const node = createBaseNode(193 /* ConditionalType */);
+      const node = createBaseNode(194 /* ConditionalType */);
       node.checkType = parenthesizerRules().parenthesizeCheckTypeOfConditionalType(checkType);
       node.extendsType = parenthesizerRules().parenthesizeExtendsTypeOfConditionalType(extendsType);
       node.trueType = trueType;
@@ -120822,7 +103647,7 @@ ${lanes.join("\n")}
       return node.checkType !== checkType || node.extendsType !== extendsType || node.trueType !== trueType || node.falseType !== falseType ? update(createConditionalTypeNode(checkType, extendsType, trueType, falseType), node) : node;
     }
     function createInferTypeNode(typeParameter) {
-      const node = createBaseNode(194 /* InferType */);
+      const node = createBaseNode(195 /* InferType */);
       node.typeParameter = typeParameter;
       node.transformFlags = 1 /* ContainsTypeScript */;
       return node;
@@ -120831,7 +103656,7 @@ ${lanes.join("\n")}
       return node.typeParameter !== typeParameter ? update(createInferTypeNode(typeParameter), node) : node;
     }
     function createTemplateLiteralType(head, templateSpans) {
-      const node = createBaseNode(202 /* TemplateLiteralType */);
+      const node = createBaseNode(203 /* TemplateLiteralType */);
       node.head = head;
       node.templateSpans = createNodeArray(templateSpans);
       node.transformFlags = 1 /* ContainsTypeScript */;
@@ -120840,21 +103665,24 @@ ${lanes.join("\n")}
     function updateTemplateLiteralType(node, head, templateSpans) {
       return node.head !== head || node.templateSpans !== templateSpans ? update(createTemplateLiteralType(head, templateSpans), node) : node;
     }
-    function createImportTypeNode(argument, assertions, qualifier, typeArguments, isTypeOf = false) {
-      const node = createBaseNode(204 /* ImportType */);
+    function createImportTypeNode(argument, attributes, qualifier, typeArguments, isTypeOf = false) {
+      const node = createBaseNode(205 /* ImportType */);
       node.argument = argument;
-      node.assertions = assertions;
+      node.attributes = attributes;
+      if (node.assertions && node.assertions.assertClause && node.attributes) {
+        node.assertions.assertClause = node.attributes;
+      }
       node.qualifier = qualifier;
       node.typeArguments = typeArguments && parenthesizerRules().parenthesizeTypeArguments(typeArguments);
       node.isTypeOf = isTypeOf;
       node.transformFlags = 1 /* ContainsTypeScript */;
       return node;
     }
-    function updateImportTypeNode(node, argument, assertions, qualifier, typeArguments, isTypeOf = node.isTypeOf) {
-      return node.argument !== argument || node.assertions !== assertions || node.qualifier !== qualifier || node.typeArguments !== typeArguments || node.isTypeOf !== isTypeOf ? update(createImportTypeNode(argument, assertions, qualifier, typeArguments, isTypeOf), node) : node;
+    function updateImportTypeNode(node, argument, attributes, qualifier, typeArguments, isTypeOf = node.isTypeOf) {
+      return node.argument !== argument || node.attributes !== attributes || node.qualifier !== qualifier || node.typeArguments !== typeArguments || node.isTypeOf !== isTypeOf ? update(createImportTypeNode(argument, attributes, qualifier, typeArguments, isTypeOf), node) : node;
     }
     function createParenthesizedType(type) {
-      const node = createBaseNode(195 /* ParenthesizedType */);
+      const node = createBaseNode(196 /* ParenthesizedType */);
       node.type = type;
       node.transformFlags = 1 /* ContainsTypeScript */;
       return node;
@@ -120863,12 +103691,12 @@ ${lanes.join("\n")}
       return node.type !== type ? update(createParenthesizedType(type), node) : node;
     }
     function createThisTypeNode() {
-      const node = createBaseNode(196 /* ThisType */);
+      const node = createBaseNode(197 /* ThisType */);
       node.transformFlags = 1 /* ContainsTypeScript */;
       return node;
     }
     function createTypeOperatorNode(operator, type) {
-      const node = createBaseNode(197 /* TypeOperator */);
+      const node = createBaseNode(198 /* TypeOperator */);
       node.operator = operator;
       node.type = operator === 148 /* ReadonlyKeyword */ ? parenthesizerRules().parenthesizeOperandOfReadonlyTypeOperator(type) : parenthesizerRules().parenthesizeOperandOfTypeOperator(type);
       node.transformFlags = 1 /* ContainsTypeScript */;
@@ -120878,7 +103706,7 @@ ${lanes.join("\n")}
       return node.type !== type ? update(createTypeOperatorNode(node.operator, type), node) : node;
     }
     function createIndexedAccessTypeNode(objectType, indexType) {
-      const node = createBaseNode(198 /* IndexedAccessType */);
+      const node = createBaseNode(199 /* IndexedAccessType */);
       node.objectType = parenthesizerRules().parenthesizeNonArrayTypeOfPostfixType(objectType);
       node.indexType = indexType;
       node.transformFlags = 1 /* ContainsTypeScript */;
@@ -120888,7 +103716,7 @@ ${lanes.join("\n")}
       return node.objectType !== objectType || node.indexType !== indexType ? update(createIndexedAccessTypeNode(objectType, indexType), node) : node;
     }
     function createMappedTypeNode(readonlyToken, typeParameter, nameType, questionToken, type, members) {
-      const node = createBaseDeclaration(199 /* MappedType */);
+      const node = createBaseDeclaration(200 /* MappedType */);
       node.readonlyToken = readonlyToken;
       node.typeParameter = typeParameter;
       node.nameType = nameType;
@@ -120904,7 +103732,7 @@ ${lanes.join("\n")}
       return node.readonlyToken !== readonlyToken || node.typeParameter !== typeParameter || node.nameType !== nameType || node.questionToken !== questionToken || node.type !== type || node.members !== members ? update(createMappedTypeNode(readonlyToken, typeParameter, nameType, questionToken, type, members), node) : node;
     }
     function createLiteralTypeNode(literal) {
-      const node = createBaseNode(200 /* LiteralType */);
+      const node = createBaseNode(201 /* LiteralType */);
       node.literal = literal;
       node.transformFlags = 1 /* ContainsTypeScript */;
       return node;
@@ -120913,7 +103741,7 @@ ${lanes.join("\n")}
       return node.literal !== literal ? update(createLiteralTypeNode(literal), node) : node;
     }
     function createObjectBindingPattern(elements) {
-      const node = createBaseNode(205 /* ObjectBindingPattern */);
+      const node = createBaseNode(206 /* ObjectBindingPattern */);
       node.elements = createNodeArray(elements);
       node.transformFlags |= propagateChildrenFlags(node.elements) | 1024 /* ContainsES2015 */ | 524288 /* ContainsBindingPattern */;
       if (node.transformFlags & 32768 /* ContainsRestOrSpread */) {
@@ -120925,7 +103753,7 @@ ${lanes.join("\n")}
       return node.elements !== elements ? update(createObjectBindingPattern(elements), node) : node;
     }
     function createArrayBindingPattern(elements) {
-      const node = createBaseNode(206 /* ArrayBindingPattern */);
+      const node = createBaseNode(207 /* ArrayBindingPattern */);
       node.elements = createNodeArray(elements);
       node.transformFlags |= propagateChildrenFlags(node.elements) | 1024 /* ContainsES2015 */ | 524288 /* ContainsBindingPattern */;
       return node;
@@ -120934,7 +103762,7 @@ ${lanes.join("\n")}
       return node.elements !== elements ? update(createArrayBindingPattern(elements), node) : node;
     }
     function createBindingElement(dotDotDotToken, propertyName, name, initializer) {
-      const node = createBaseDeclaration(207 /* BindingElement */);
+      const node = createBaseDeclaration(208 /* BindingElement */);
       node.dotDotDotToken = dotDotDotToken;
       node.propertyName = asName(propertyName);
       node.name = asName(name);
@@ -120947,7 +103775,7 @@ ${lanes.join("\n")}
       return node.propertyName !== propertyName || node.dotDotDotToken !== dotDotDotToken || node.name !== name || node.initializer !== initializer ? update(createBindingElement(dotDotDotToken, propertyName, name, initializer), node) : node;
     }
     function createArrayLiteralExpression(elements, multiLine) {
-      const node = createBaseNode(208 /* ArrayLiteralExpression */);
+      const node = createBaseNode(209 /* ArrayLiteralExpression */);
       const lastElement = elements && lastOrUndefined(elements);
       const elementsArray = createNodeArray(elements, lastElement && isOmittedExpression(lastElement) ? true : void 0);
       node.elements = parenthesizerRules().parenthesizeExpressionsOfCommaDelimitedList(elementsArray);
@@ -120959,7 +103787,7 @@ ${lanes.join("\n")}
       return node.elements !== elements ? update(createArrayLiteralExpression(elements, node.multiLine), node) : node;
     }
     function createObjectLiteralExpression(properties, multiLine) {
-      const node = createBaseDeclaration(209 /* ObjectLiteralExpression */);
+      const node = createBaseDeclaration(210 /* ObjectLiteralExpression */);
       node.properties = createNodeArray(properties);
       node.multiLine = multiLine;
       node.transformFlags |= propagateChildrenFlags(node.properties);
@@ -120970,7 +103798,7 @@ ${lanes.join("\n")}
       return node.properties !== properties ? update(createObjectLiteralExpression(properties, node.multiLine), node) : node;
     }
     function createBasePropertyAccessExpression(expression, questionDotToken, name) {
-      const node = createBaseDeclaration(210 /* PropertyAccessExpression */);
+      const node = createBaseDeclaration(211 /* PropertyAccessExpression */);
       node.expression = expression;
       node.questionDotToken = questionDotToken;
       node.name = name;
@@ -121011,16 +103839,16 @@ ${lanes.join("\n")}
         questionDotToken,
         asName(name)
       );
-      node.flags |= 32 /* OptionalChain */;
+      node.flags |= 64 /* OptionalChain */;
       node.transformFlags |= 32 /* ContainsES2020 */;
       return node;
     }
     function updatePropertyAccessChain(node, expression, questionDotToken, name) {
-      Debug.assert(!!(node.flags & 32 /* OptionalChain */), "Cannot update a PropertyAccessExpression using updatePropertyAccessChain. Use updatePropertyAccess instead.");
+      Debug.assert(!!(node.flags & 64 /* OptionalChain */), "Cannot update a PropertyAccessExpression using updatePropertyAccessChain. Use updatePropertyAccess instead.");
       return node.expression !== expression || node.questionDotToken !== questionDotToken || node.name !== name ? update(createPropertyAccessChain(expression, questionDotToken, name), node) : node;
     }
     function createBaseElementAccessExpression(expression, questionDotToken, argumentExpression) {
-      const node = createBaseDeclaration(211 /* ElementAccessExpression */);
+      const node = createBaseDeclaration(212 /* ElementAccessExpression */);
       node.expression = expression;
       node.questionDotToken = questionDotToken;
       node.argumentExpression = argumentExpression;
@@ -121061,16 +103889,16 @@ ${lanes.join("\n")}
         questionDotToken,
         asExpression(index)
       );
-      node.flags |= 32 /* OptionalChain */;
+      node.flags |= 64 /* OptionalChain */;
       node.transformFlags |= 32 /* ContainsES2020 */;
       return node;
     }
     function updateElementAccessChain(node, expression, questionDotToken, argumentExpression) {
-      Debug.assert(!!(node.flags & 32 /* OptionalChain */), "Cannot update a ElementAccessExpression using updateElementAccessChain. Use updateElementAccess instead.");
+      Debug.assert(!!(node.flags & 64 /* OptionalChain */), "Cannot update a ElementAccessExpression using updateElementAccessChain. Use updateElementAccess instead.");
       return node.expression !== expression || node.questionDotToken !== questionDotToken || node.argumentExpression !== argumentExpression ? update(createElementAccessChain(expression, questionDotToken, argumentExpression), node) : node;
     }
     function createBaseCallExpression(expression, questionDotToken, typeArguments, argumentsArray) {
-      const node = createBaseDeclaration(212 /* CallExpression */);
+      const node = createBaseDeclaration(213 /* CallExpression */);
       node.expression = expression;
       node.questionDotToken = questionDotToken;
       node.typeArguments = typeArguments;
@@ -121118,16 +103946,16 @@ ${lanes.join("\n")}
         asNodeArray(typeArguments),
         parenthesizerRules().parenthesizeExpressionsOfCommaDelimitedList(createNodeArray(argumentsArray))
       );
-      node.flags |= 32 /* OptionalChain */;
+      node.flags |= 64 /* OptionalChain */;
       node.transformFlags |= 32 /* ContainsES2020 */;
       return node;
     }
     function updateCallChain(node, expression, questionDotToken, typeArguments, argumentsArray) {
-      Debug.assert(!!(node.flags & 32 /* OptionalChain */), "Cannot update a CallExpression using updateCallChain. Use updateCall instead.");
+      Debug.assert(!!(node.flags & 64 /* OptionalChain */), "Cannot update a CallExpression using updateCallChain. Use updateCall instead.");
       return node.expression !== expression || node.questionDotToken !== questionDotToken || node.typeArguments !== typeArguments || node.arguments !== argumentsArray ? update(createCallChain(expression, questionDotToken, typeArguments, argumentsArray), node) : node;
     }
     function createNewExpression(expression, typeArguments, argumentsArray) {
-      const node = createBaseDeclaration(213 /* NewExpression */);
+      const node = createBaseDeclaration(214 /* NewExpression */);
       node.expression = parenthesizerRules().parenthesizeExpressionOfNew(expression);
       node.typeArguments = asNodeArray(typeArguments);
       node.arguments = argumentsArray ? parenthesizerRules().parenthesizeExpressionsOfCommaDelimitedList(argumentsArray) : void 0;
@@ -121141,7 +103969,7 @@ ${lanes.join("\n")}
       return node.expression !== expression || node.typeArguments !== typeArguments || node.arguments !== argumentsArray ? update(createNewExpression(expression, typeArguments, argumentsArray), node) : node;
     }
     function createTaggedTemplateExpression(tag, typeArguments, template) {
-      const node = createBaseNode(214 /* TaggedTemplateExpression */);
+      const node = createBaseNode(215 /* TaggedTemplateExpression */);
       node.tag = parenthesizerRules().parenthesizeLeftSideOfAccess(
         tag,
         /*optionalChain*/
@@ -121162,7 +103990,7 @@ ${lanes.join("\n")}
       return node.tag !== tag || node.typeArguments !== typeArguments || node.template !== template ? update(createTaggedTemplateExpression(tag, typeArguments, template), node) : node;
     }
     function createTypeAssertion(type, expression) {
-      const node = createBaseNode(215 /* TypeAssertionExpression */);
+      const node = createBaseNode(216 /* TypeAssertionExpression */);
       node.expression = parenthesizerRules().parenthesizeOperandOfPrefixUnary(expression);
       node.type = type;
       node.transformFlags |= propagateChildFlags(node.expression) | propagateChildFlags(node.type) | 1 /* ContainsTypeScript */;
@@ -121172,7 +104000,7 @@ ${lanes.join("\n")}
       return node.type !== type || node.expression !== expression ? update(createTypeAssertion(type, expression), node) : node;
     }
     function createParenthesizedExpression(expression) {
-      const node = createBaseNode(216 /* ParenthesizedExpression */);
+      const node = createBaseNode(217 /* ParenthesizedExpression */);
       node.expression = expression;
       node.transformFlags = propagateChildFlags(node.expression);
       node.jsDoc = void 0;
@@ -121182,7 +104010,7 @@ ${lanes.join("\n")}
       return node.expression !== expression ? update(createParenthesizedExpression(expression), node) : node;
     }
     function createFunctionExpression(modifiers, asteriskToken, name, typeParameters, parameters, type, body) {
-      const node = createBaseDeclaration(217 /* FunctionExpression */);
+      const node = createBaseDeclaration(218 /* FunctionExpression */);
       node.modifiers = asNodeArray(modifiers);
       node.asteriskToken = asteriskToken;
       node.name = asName(name);
@@ -121190,7 +104018,7 @@ ${lanes.join("\n")}
       node.parameters = createNodeArray(parameters);
       node.type = type;
       node.body = body;
-      const isAsync = modifiersToFlags(node.modifiers) & 512 /* Async */;
+      const isAsync = modifiersToFlags(node.modifiers) & 1024 /* Async */;
       const isGenerator = !!node.asteriskToken;
       const isAsyncGenerator = isAsync && isGenerator;
       node.transformFlags = propagateChildrenFlags(node.modifiers) | propagateChildFlags(node.asteriskToken) | propagateNameFlags(node.name) | propagateChildrenFlags(node.typeParameters) | propagateChildrenFlags(node.parameters) | propagateChildFlags(node.type) | propagateChildFlags(node.body) & ~67108864 /* ContainsPossibleTopLevelAwait */ | (isAsyncGenerator ? 128 /* ContainsES2018 */ : isAsync ? 256 /* ContainsES2017 */ : isGenerator ? 2048 /* ContainsGenerator */ : 0 /* None */) | (node.typeParameters || node.type ? 1 /* ContainsTypeScript */ : 0 /* None */) | 4194304 /* ContainsHoistedDeclarationOrCompletion */;
@@ -121207,14 +104035,14 @@ ${lanes.join("\n")}
       return node.name !== name || node.modifiers !== modifiers || node.asteriskToken !== asteriskToken || node.typeParameters !== typeParameters || node.parameters !== parameters || node.type !== type || node.body !== body ? finishUpdateBaseSignatureDeclaration(createFunctionExpression(modifiers, asteriskToken, name, typeParameters, parameters, type, body), node) : node;
     }
     function createArrowFunction(modifiers, typeParameters, parameters, type, equalsGreaterThanToken, body) {
-      const node = createBaseDeclaration(218 /* ArrowFunction */);
+      const node = createBaseDeclaration(219 /* ArrowFunction */);
       node.modifiers = asNodeArray(modifiers);
       node.typeParameters = asNodeArray(typeParameters);
       node.parameters = createNodeArray(parameters);
       node.type = type;
       node.equalsGreaterThanToken = equalsGreaterThanToken ?? createToken(39 /* EqualsGreaterThanToken */);
       node.body = parenthesizerRules().parenthesizeConciseBodyOfArrowFunction(body);
-      const isAsync = modifiersToFlags(node.modifiers) & 512 /* Async */;
+      const isAsync = modifiersToFlags(node.modifiers) & 1024 /* Async */;
       node.transformFlags = propagateChildrenFlags(node.modifiers) | propagateChildrenFlags(node.typeParameters) | propagateChildrenFlags(node.parameters) | propagateChildFlags(node.type) | propagateChildFlags(node.equalsGreaterThanToken) | propagateChildFlags(node.body) & ~67108864 /* ContainsPossibleTopLevelAwait */ | (node.typeParameters || node.type ? 1 /* ContainsTypeScript */ : 0 /* None */) | (isAsync ? 256 /* ContainsES2017 */ | 16384 /* ContainsLexicalThis */ : 0 /* None */) | 1024 /* ContainsES2015 */;
       node.typeArguments = void 0;
       node.jsDoc = void 0;
@@ -121229,7 +104057,7 @@ ${lanes.join("\n")}
       return node.modifiers !== modifiers || node.typeParameters !== typeParameters || node.parameters !== parameters || node.type !== type || node.equalsGreaterThanToken !== equalsGreaterThanToken || node.body !== body ? finishUpdateBaseSignatureDeclaration(createArrowFunction(modifiers, typeParameters, parameters, type, equalsGreaterThanToken, body), node) : node;
     }
     function createDeleteExpression(expression) {
-      const node = createBaseNode(219 /* DeleteExpression */);
+      const node = createBaseNode(220 /* DeleteExpression */);
       node.expression = parenthesizerRules().parenthesizeOperandOfPrefixUnary(expression);
       node.transformFlags |= propagateChildFlags(node.expression);
       return node;
@@ -121238,7 +104066,7 @@ ${lanes.join("\n")}
       return node.expression !== expression ? update(createDeleteExpression(expression), node) : node;
     }
     function createTypeOfExpression(expression) {
-      const node = createBaseNode(220 /* TypeOfExpression */);
+      const node = createBaseNode(221 /* TypeOfExpression */);
       node.expression = parenthesizerRules().parenthesizeOperandOfPrefixUnary(expression);
       node.transformFlags |= propagateChildFlags(node.expression);
       return node;
@@ -121247,7 +104075,7 @@ ${lanes.join("\n")}
       return node.expression !== expression ? update(createTypeOfExpression(expression), node) : node;
     }
     function createVoidExpression(expression) {
-      const node = createBaseNode(221 /* VoidExpression */);
+      const node = createBaseNode(222 /* VoidExpression */);
       node.expression = parenthesizerRules().parenthesizeOperandOfPrefixUnary(expression);
       node.transformFlags |= propagateChildFlags(node.expression);
       return node;
@@ -121256,7 +104084,7 @@ ${lanes.join("\n")}
       return node.expression !== expression ? update(createVoidExpression(expression), node) : node;
     }
     function createAwaitExpression(expression) {
-      const node = createBaseNode(222 /* AwaitExpression */);
+      const node = createBaseNode(223 /* AwaitExpression */);
       node.expression = parenthesizerRules().parenthesizeOperandOfPrefixUnary(expression);
       node.transformFlags |= propagateChildFlags(node.expression) | 256 /* ContainsES2017 */ | 128 /* ContainsES2018 */ | 2097152 /* ContainsAwait */;
       return node;
@@ -121265,7 +104093,7 @@ ${lanes.join("\n")}
       return node.expression !== expression ? update(createAwaitExpression(expression), node) : node;
     }
     function createPrefixUnaryExpression(operator, operand) {
-      const node = createBaseNode(223 /* PrefixUnaryExpression */);
+      const node = createBaseNode(224 /* PrefixUnaryExpression */);
       node.operator = operator;
       node.operand = parenthesizerRules().parenthesizeOperandOfPrefixUnary(operand);
       node.transformFlags |= propagateChildFlags(node.operand);
@@ -121278,7 +104106,7 @@ ${lanes.join("\n")}
       return node.operand !== operand ? update(createPrefixUnaryExpression(node.operator, operand), node) : node;
     }
     function createPostfixUnaryExpression(operand, operator) {
-      const node = createBaseNode(224 /* PostfixUnaryExpression */);
+      const node = createBaseNode(225 /* PostfixUnaryExpression */);
       node.operator = operator;
       node.operand = parenthesizerRules().parenthesizeOperandOfPostfixUnary(operand);
       node.transformFlags |= propagateChildFlags(node.operand);
@@ -121291,7 +104119,7 @@ ${lanes.join("\n")}
       return node.operand !== operand ? update(createPostfixUnaryExpression(operand, node.operator), node) : node;
     }
     function createBinaryExpression(left, operator, right) {
-      const node = createBaseDeclaration(225 /* BinaryExpression */);
+      const node = createBaseDeclaration(226 /* BinaryExpression */);
       const operatorToken = asToken(operator);
       const operatorKind = operatorToken.kind;
       node.left = parenthesizerRules().parenthesizeLeftSideOfBinary(operatorKind, left);
@@ -121324,7 +104152,7 @@ ${lanes.join("\n")}
       return node.left !== left || node.operatorToken !== operator || node.right !== right ? update(createBinaryExpression(left, operator, right), node) : node;
     }
     function createConditionalExpression(condition, questionToken, whenTrue, colonToken, whenFalse) {
-      const node = createBaseNode(226 /* ConditionalExpression */);
+      const node = createBaseNode(227 /* ConditionalExpression */);
       node.condition = parenthesizerRules().parenthesizeConditionOfConditionalExpression(condition);
       node.questionToken = questionToken ?? createToken(58 /* QuestionToken */);
       node.whenTrue = parenthesizerRules().parenthesizeBranchOfConditionalExpression(whenTrue);
@@ -121337,7 +104165,7 @@ ${lanes.join("\n")}
       return node.condition !== condition || node.questionToken !== questionToken || node.whenTrue !== whenTrue || node.colonToken !== colonToken || node.whenFalse !== whenFalse ? update(createConditionalExpression(condition, questionToken, whenTrue, colonToken, whenFalse), node) : node;
     }
     function createTemplateExpression(head, templateSpans) {
-      const node = createBaseNode(227 /* TemplateExpression */);
+      const node = createBaseNode(228 /* TemplateExpression */);
       node.head = head;
       node.templateSpans = createNodeArray(templateSpans);
       node.transformFlags |= propagateChildFlags(node.head) | propagateChildrenFlags(node.templateSpans) | 1024 /* ContainsES2015 */;
@@ -121412,7 +104240,7 @@ ${lanes.join("\n")}
     }
     function createYieldExpression(asteriskToken, expression) {
       Debug.assert(!asteriskToken || !!expression, "A `YieldExpression` with an asteriskToken must have an expression.");
-      const node = createBaseNode(228 /* YieldExpression */);
+      const node = createBaseNode(229 /* YieldExpression */);
       node.expression = expression && parenthesizerRules().parenthesizeExpressionForDisallowedComma(expression);
       node.asteriskToken = asteriskToken;
       node.transformFlags |= propagateChildFlags(node.expression) | propagateChildFlags(node.asteriskToken) | 1024 /* ContainsES2015 */ | 128 /* ContainsES2018 */ | 1048576 /* ContainsYield */;
@@ -121422,7 +104250,7 @@ ${lanes.join("\n")}
       return node.expression !== expression || node.asteriskToken !== asteriskToken ? update(createYieldExpression(asteriskToken, expression), node) : node;
     }
     function createSpreadElement(expression) {
-      const node = createBaseNode(229 /* SpreadElement */);
+      const node = createBaseNode(230 /* SpreadElement */);
       node.expression = parenthesizerRules().parenthesizeExpressionForDisallowedComma(expression);
       node.transformFlags |= propagateChildFlags(node.expression) | 1024 /* ContainsES2015 */ | 32768 /* ContainsRestOrSpread */;
       return node;
@@ -121431,7 +104259,7 @@ ${lanes.join("\n")}
       return node.expression !== expression ? update(createSpreadElement(expression), node) : node;
     }
     function createClassExpression(modifiers, name, typeParameters, heritageClauses, members) {
-      const node = createBaseDeclaration(230 /* ClassExpression */);
+      const node = createBaseDeclaration(231 /* ClassExpression */);
       node.modifiers = asNodeArray(modifiers);
       node.name = asName(name);
       node.typeParameters = asNodeArray(typeParameters);
@@ -121445,10 +104273,10 @@ ${lanes.join("\n")}
       return node.modifiers !== modifiers || node.name !== name || node.typeParameters !== typeParameters || node.heritageClauses !== heritageClauses || node.members !== members ? update(createClassExpression(modifiers, name, typeParameters, heritageClauses, members), node) : node;
     }
     function createOmittedExpression() {
-      return createBaseNode(231 /* OmittedExpression */);
+      return createBaseNode(232 /* OmittedExpression */);
     }
     function createExpressionWithTypeArguments(expression, typeArguments) {
-      const node = createBaseNode(232 /* ExpressionWithTypeArguments */);
+      const node = createBaseNode(233 /* ExpressionWithTypeArguments */);
       node.expression = parenthesizerRules().parenthesizeLeftSideOfAccess(
         expression,
         /*optionalChain*/
@@ -121462,7 +104290,7 @@ ${lanes.join("\n")}
       return node.expression !== expression || node.typeArguments !== typeArguments ? update(createExpressionWithTypeArguments(expression, typeArguments), node) : node;
     }
     function createAsExpression(expression, type) {
-      const node = createBaseNode(233 /* AsExpression */);
+      const node = createBaseNode(234 /* AsExpression */);
       node.expression = expression;
       node.type = type;
       node.transformFlags |= propagateChildFlags(node.expression) | propagateChildFlags(node.type) | 1 /* ContainsTypeScript */;
@@ -121472,7 +104300,7 @@ ${lanes.join("\n")}
       return node.expression !== expression || node.type !== type ? update(createAsExpression(expression, type), node) : node;
     }
     function createNonNullExpression(expression) {
-      const node = createBaseNode(234 /* NonNullExpression */);
+      const node = createBaseNode(235 /* NonNullExpression */);
       node.expression = parenthesizerRules().parenthesizeLeftSideOfAccess(
         expression,
         /*optionalChain*/
@@ -121488,7 +104316,7 @@ ${lanes.join("\n")}
       return node.expression !== expression ? update(createNonNullExpression(expression), node) : node;
     }
     function createSatisfiesExpression(expression, type) {
-      const node = createBaseNode(237 /* SatisfiesExpression */);
+      const node = createBaseNode(238 /* SatisfiesExpression */);
       node.expression = expression;
       node.type = type;
       node.transformFlags |= propagateChildFlags(node.expression) | propagateChildFlags(node.type) | 1 /* ContainsTypeScript */;
@@ -121498,8 +104326,8 @@ ${lanes.join("\n")}
       return node.expression !== expression || node.type !== type ? update(createSatisfiesExpression(expression, type), node) : node;
     }
     function createNonNullChain(expression) {
-      const node = createBaseNode(234 /* NonNullExpression */);
-      node.flags |= 32 /* OptionalChain */;
+      const node = createBaseNode(235 /* NonNullExpression */);
+      node.flags |= 64 /* OptionalChain */;
       node.expression = parenthesizerRules().parenthesizeLeftSideOfAccess(
         expression,
         /*optionalChain*/
@@ -121509,11 +104337,11 @@ ${lanes.join("\n")}
       return node;
     }
     function updateNonNullChain(node, expression) {
-      Debug.assert(!!(node.flags & 32 /* OptionalChain */), "Cannot update a NonNullExpression using updateNonNullChain. Use updateNonNullExpression instead.");
+      Debug.assert(!!(node.flags & 64 /* OptionalChain */), "Cannot update a NonNullExpression using updateNonNullChain. Use updateNonNullExpression instead.");
       return node.expression !== expression ? update(createNonNullChain(expression), node) : node;
     }
     function createMetaProperty(keywordToken, name) {
-      const node = createBaseNode(235 /* MetaProperty */);
+      const node = createBaseNode(236 /* MetaProperty */);
       node.keywordToken = keywordToken;
       node.name = name;
       node.transformFlags |= propagateChildFlags(node.name);
@@ -121534,7 +104362,7 @@ ${lanes.join("\n")}
       return node.name !== name ? update(createMetaProperty(node.keywordToken, name), node) : node;
     }
     function createTemplateSpan(expression, literal) {
-      const node = createBaseNode(238 /* TemplateSpan */);
+      const node = createBaseNode(239 /* TemplateSpan */);
       node.expression = expression;
       node.literal = literal;
       node.transformFlags |= propagateChildFlags(node.expression) | propagateChildFlags(node.literal) | 1024 /* ContainsES2015 */;
@@ -121544,12 +104372,12 @@ ${lanes.join("\n")}
       return node.expression !== expression || node.literal !== literal ? update(createTemplateSpan(expression, literal), node) : node;
     }
     function createSemicolonClassElement() {
-      const node = createBaseNode(239 /* SemicolonClassElement */);
+      const node = createBaseNode(240 /* SemicolonClassElement */);
       node.transformFlags |= 1024 /* ContainsES2015 */;
       return node;
     }
     function createBlock(statements, multiLine) {
-      const node = createBaseNode(240 /* Block */);
+      const node = createBaseNode(241 /* Block */);
       node.statements = createNodeArray(statements);
       node.multiLine = multiLine;
       node.transformFlags |= propagateChildrenFlags(node.statements);
@@ -121562,11 +104390,11 @@ ${lanes.join("\n")}
       return node.statements !== statements ? update(createBlock(statements, node.multiLine), node) : node;
     }
     function createVariableStatement(modifiers, declarationList) {
-      const node = createBaseNode(242 /* VariableStatement */);
+      const node = createBaseNode(243 /* VariableStatement */);
       node.modifiers = asNodeArray(modifiers);
       node.declarationList = isArray(declarationList) ? createVariableDeclarationList(declarationList) : declarationList;
       node.transformFlags |= propagateChildrenFlags(node.modifiers) | propagateChildFlags(node.declarationList);
-      if (modifiersToFlags(node.modifiers) & 2 /* Ambient */) {
+      if (modifiersToFlags(node.modifiers) & 128 /* Ambient */) {
         node.transformFlags = 1 /* ContainsTypeScript */;
       }
       node.jsDoc = void 0;
@@ -121577,12 +104405,12 @@ ${lanes.join("\n")}
       return node.modifiers !== modifiers || node.declarationList !== declarationList ? update(createVariableStatement(modifiers, declarationList), node) : node;
     }
     function createEmptyStatement() {
-      const node = createBaseNode(241 /* EmptyStatement */);
+      const node = createBaseNode(242 /* EmptyStatement */);
       node.jsDoc = void 0;
       return node;
     }
     function createExpressionStatement(expression) {
-      const node = createBaseNode(243 /* ExpressionStatement */);
+      const node = createBaseNode(244 /* ExpressionStatement */);
       node.expression = parenthesizerRules().parenthesizeExpressionOfExpressionStatement(expression);
       node.transformFlags |= propagateChildFlags(node.expression);
       node.jsDoc = void 0;
@@ -121593,7 +104421,7 @@ ${lanes.join("\n")}
       return node.expression !== expression ? update(createExpressionStatement(expression), node) : node;
     }
     function createIfStatement(expression, thenStatement, elseStatement) {
-      const node = createBaseNode(244 /* IfStatement */);
+      const node = createBaseNode(245 /* IfStatement */);
       node.expression = expression;
       node.thenStatement = asEmbeddedStatement(thenStatement);
       node.elseStatement = asEmbeddedStatement(elseStatement);
@@ -121606,7 +104434,7 @@ ${lanes.join("\n")}
       return node.expression !== expression || node.thenStatement !== thenStatement || node.elseStatement !== elseStatement ? update(createIfStatement(expression, thenStatement, elseStatement), node) : node;
     }
     function createDoStatement(statement, expression) {
-      const node = createBaseNode(245 /* DoStatement */);
+      const node = createBaseNode(246 /* DoStatement */);
       node.statement = asEmbeddedStatement(statement);
       node.expression = expression;
       node.transformFlags |= propagateChildFlags(node.statement) | propagateChildFlags(node.expression);
@@ -121618,7 +104446,7 @@ ${lanes.join("\n")}
       return node.statement !== statement || node.expression !== expression ? update(createDoStatement(statement, expression), node) : node;
     }
     function createWhileStatement(expression, statement) {
-      const node = createBaseNode(246 /* WhileStatement */);
+      const node = createBaseNode(247 /* WhileStatement */);
       node.expression = expression;
       node.statement = asEmbeddedStatement(statement);
       node.transformFlags |= propagateChildFlags(node.expression) | propagateChildFlags(node.statement);
@@ -121630,7 +104458,7 @@ ${lanes.join("\n")}
       return node.expression !== expression || node.statement !== statement ? update(createWhileStatement(expression, statement), node) : node;
     }
     function createForStatement(initializer, condition, incrementor, statement) {
-      const node = createBaseNode(247 /* ForStatement */);
+      const node = createBaseNode(248 /* ForStatement */);
       node.initializer = initializer;
       node.condition = condition;
       node.incrementor = incrementor;
@@ -121646,7 +104474,7 @@ ${lanes.join("\n")}
       return node.initializer !== initializer || node.condition !== condition || node.incrementor !== incrementor || node.statement !== statement ? update(createForStatement(initializer, condition, incrementor, statement), node) : node;
     }
     function createForInStatement(initializer, expression, statement) {
-      const node = createBaseNode(248 /* ForInStatement */);
+      const node = createBaseNode(249 /* ForInStatement */);
       node.initializer = initializer;
       node.expression = expression;
       node.statement = asEmbeddedStatement(statement);
@@ -121661,7 +104489,7 @@ ${lanes.join("\n")}
       return node.initializer !== initializer || node.expression !== expression || node.statement !== statement ? update(createForInStatement(initializer, expression, statement), node) : node;
     }
     function createForOfStatement(awaitModifier, initializer, expression, statement) {
-      const node = createBaseNode(249 /* ForOfStatement */);
+      const node = createBaseNode(250 /* ForOfStatement */);
       node.awaitModifier = awaitModifier;
       node.initializer = initializer;
       node.expression = parenthesizerRules().parenthesizeExpressionForDisallowedComma(expression);
@@ -121679,7 +104507,7 @@ ${lanes.join("\n")}
       return node.awaitModifier !== awaitModifier || node.initializer !== initializer || node.expression !== expression || node.statement !== statement ? update(createForOfStatement(awaitModifier, initializer, expression, statement), node) : node;
     }
     function createContinueStatement(label) {
-      const node = createBaseNode(250 /* ContinueStatement */);
+      const node = createBaseNode(251 /* ContinueStatement */);
       node.label = asName(label);
       node.transformFlags |= propagateChildFlags(node.label) | 4194304 /* ContainsHoistedDeclarationOrCompletion */;
       node.jsDoc = void 0;
@@ -121690,7 +104518,7 @@ ${lanes.join("\n")}
       return node.label !== label ? update(createContinueStatement(label), node) : node;
     }
     function createBreakStatement(label) {
-      const node = createBaseNode(251 /* BreakStatement */);
+      const node = createBaseNode(252 /* BreakStatement */);
       node.label = asName(label);
       node.transformFlags |= propagateChildFlags(node.label) | 4194304 /* ContainsHoistedDeclarationOrCompletion */;
       node.jsDoc = void 0;
@@ -121701,7 +104529,7 @@ ${lanes.join("\n")}
       return node.label !== label ? update(createBreakStatement(label), node) : node;
     }
     function createReturnStatement(expression) {
-      const node = createBaseNode(252 /* ReturnStatement */);
+      const node = createBaseNode(253 /* ReturnStatement */);
       node.expression = expression;
       node.transformFlags |= propagateChildFlags(node.expression) | 128 /* ContainsES2018 */ | 4194304 /* ContainsHoistedDeclarationOrCompletion */;
       node.jsDoc = void 0;
@@ -121712,7 +104540,7 @@ ${lanes.join("\n")}
       return node.expression !== expression ? update(createReturnStatement(expression), node) : node;
     }
     function createWithStatement(expression, statement) {
-      const node = createBaseNode(253 /* WithStatement */);
+      const node = createBaseNode(254 /* WithStatement */);
       node.expression = expression;
       node.statement = asEmbeddedStatement(statement);
       node.transformFlags |= propagateChildFlags(node.expression) | propagateChildFlags(node.statement);
@@ -121724,7 +104552,7 @@ ${lanes.join("\n")}
       return node.expression !== expression || node.statement !== statement ? update(createWithStatement(expression, statement), node) : node;
     }
     function createSwitchStatement(expression, caseBlock) {
-      const node = createBaseNode(254 /* SwitchStatement */);
+      const node = createBaseNode(255 /* SwitchStatement */);
       node.expression = parenthesizerRules().parenthesizeExpressionForDisallowedComma(expression);
       node.caseBlock = caseBlock;
       node.transformFlags |= propagateChildFlags(node.expression) | propagateChildFlags(node.caseBlock);
@@ -121737,7 +104565,7 @@ ${lanes.join("\n")}
       return node.expression !== expression || node.caseBlock !== caseBlock ? update(createSwitchStatement(expression, caseBlock), node) : node;
     }
     function createLabeledStatement(label, statement) {
-      const node = createBaseNode(255 /* LabeledStatement */);
+      const node = createBaseNode(256 /* LabeledStatement */);
       node.label = asName(label);
       node.statement = asEmbeddedStatement(statement);
       node.transformFlags |= propagateChildFlags(node.label) | propagateChildFlags(node.statement);
@@ -121749,7 +104577,7 @@ ${lanes.join("\n")}
       return node.label !== label || node.statement !== statement ? update(createLabeledStatement(label, statement), node) : node;
     }
     function createThrowStatement(expression) {
-      const node = createBaseNode(256 /* ThrowStatement */);
+      const node = createBaseNode(257 /* ThrowStatement */);
       node.expression = expression;
       node.transformFlags |= propagateChildFlags(node.expression);
       node.jsDoc = void 0;
@@ -121760,7 +104588,7 @@ ${lanes.join("\n")}
       return node.expression !== expression ? update(createThrowStatement(expression), node) : node;
     }
     function createTryStatement(tryBlock, catchClause, finallyBlock) {
-      const node = createBaseNode(257 /* TryStatement */);
+      const node = createBaseNode(258 /* TryStatement */);
       node.tryBlock = tryBlock;
       node.catchClause = catchClause;
       node.finallyBlock = finallyBlock;
@@ -121773,13 +104601,13 @@ ${lanes.join("\n")}
       return node.tryBlock !== tryBlock || node.catchClause !== catchClause || node.finallyBlock !== finallyBlock ? update(createTryStatement(tryBlock, catchClause, finallyBlock), node) : node;
     }
     function createDebuggerStatement() {
-      const node = createBaseNode(258 /* DebuggerStatement */);
+      const node = createBaseNode(259 /* DebuggerStatement */);
       node.jsDoc = void 0;
       node.flowNode = void 0;
       return node;
     }
     function createVariableDeclaration(name, exclamationToken, type, initializer) {
-      const node = createBaseDeclaration(259 /* VariableDeclaration */);
+      const node = createBaseDeclaration(260 /* VariableDeclaration */);
       node.name = asName(name);
       node.exclamationToken = exclamationToken;
       node.type = type;
@@ -121792,20 +104620,23 @@ ${lanes.join("\n")}
       return node.name !== name || node.type !== type || node.exclamationToken !== exclamationToken || node.initializer !== initializer ? update(createVariableDeclaration(name, exclamationToken, type, initializer), node) : node;
     }
     function createVariableDeclarationList(declarations, flags2 = 0 /* None */) {
-      const node = createBaseNode(260 /* VariableDeclarationList */);
-      node.flags |= flags2 & 3 /* BlockScoped */;
+      const node = createBaseNode(261 /* VariableDeclarationList */);
+      node.flags |= flags2 & 7 /* BlockScoped */;
       node.declarations = createNodeArray(declarations);
       node.transformFlags |= propagateChildrenFlags(node.declarations) | 4194304 /* ContainsHoistedDeclarationOrCompletion */;
-      if (flags2 & 3 /* BlockScoped */) {
+      if (flags2 & 7 /* BlockScoped */) {
         node.transformFlags |= 1024 /* ContainsES2015 */ | 262144 /* ContainsBlockScopedBinding */;
       }
+      if (flags2 & 4 /* Using */) {
+        node.transformFlags |= 4 /* ContainsESNext */;
+      }
       return node;
     }
     function updateVariableDeclarationList(node, declarations) {
       return node.declarations !== declarations ? update(createVariableDeclarationList(declarations, node.flags), node) : node;
     }
     function createFunctionDeclaration(modifiers, asteriskToken, name, typeParameters, parameters, type, body) {
-      const node = createBaseDeclaration(261 /* FunctionDeclaration */);
+      const node = createBaseDeclaration(262 /* FunctionDeclaration */);
       node.modifiers = asNodeArray(modifiers);
       node.asteriskToken = asteriskToken;
       node.name = asName(name);
@@ -121813,10 +104644,10 @@ ${lanes.join("\n")}
       node.parameters = createNodeArray(parameters);
       node.type = type;
       node.body = body;
-      if (!node.body || modifiersToFlags(node.modifiers) & 2 /* Ambient */) {
+      if (!node.body || modifiersToFlags(node.modifiers) & 128 /* Ambient */) {
         node.transformFlags = 1 /* ContainsTypeScript */;
       } else {
-        const isAsync = modifiersToFlags(node.modifiers) & 512 /* Async */;
+        const isAsync = modifiersToFlags(node.modifiers) & 1024 /* Async */;
         const isGenerator = !!node.asteriskToken;
         const isAsyncGenerator = isAsync && isGenerator;
         node.transformFlags = propagateChildrenFlags(node.modifiers) | propagateChildFlags(node.asteriskToken) | propagateNameFlags(node.name) | propagateChildrenFlags(node.typeParameters) | propagateChildrenFlags(node.parameters) | propagateChildFlags(node.type) | propagateChildFlags(node.body) & ~67108864 /* ContainsPossibleTopLevelAwait */ | (isAsyncGenerator ? 128 /* ContainsES2018 */ : isAsync ? 256 /* ContainsES2017 */ : isGenerator ? 2048 /* ContainsGenerator */ : 0 /* None */) | (node.typeParameters || node.type ? 1 /* ContainsTypeScript */ : 0 /* None */) | 4194304 /* ContainsHoistedDeclarationOrCompletion */;
@@ -121841,13 +104672,13 @@ ${lanes.join("\n")}
       return finishUpdateBaseSignatureDeclaration(updated, original);
     }
     function createClassDeclaration(modifiers, name, typeParameters, heritageClauses, members) {
-      const node = createBaseDeclaration(262 /* ClassDeclaration */);
+      const node = createBaseDeclaration(263 /* ClassDeclaration */);
       node.modifiers = asNodeArray(modifiers);
       node.name = asName(name);
       node.typeParameters = asNodeArray(typeParameters);
       node.heritageClauses = asNodeArray(heritageClauses);
       node.members = createNodeArray(members);
-      if (modifiersToFlags(node.modifiers) & 2 /* Ambient */) {
+      if (modifiersToFlags(node.modifiers) & 128 /* Ambient */) {
         node.transformFlags = 1 /* ContainsTypeScript */;
       } else {
         node.transformFlags |= propagateChildrenFlags(node.modifiers) | propagateNameFlags(node.name) | propagateChildrenFlags(node.typeParameters) | propagateChildrenFlags(node.heritageClauses) | propagateChildrenFlags(node.members) | (node.typeParameters ? 1 /* ContainsTypeScript */ : 0 /* None */) | 1024 /* ContainsES2015 */;
@@ -121862,7 +104693,7 @@ ${lanes.join("\n")}
       return node.modifiers !== modifiers || node.name !== name || node.typeParameters !== typeParameters || node.heritageClauses !== heritageClauses || node.members !== members ? update(createClassDeclaration(modifiers, name, typeParameters, heritageClauses, members), node) : node;
     }
     function createInterfaceDeclaration(modifiers, name, typeParameters, heritageClauses, members) {
-      const node = createBaseDeclaration(263 /* InterfaceDeclaration */);
+      const node = createBaseDeclaration(264 /* InterfaceDeclaration */);
       node.modifiers = asNodeArray(modifiers);
       node.name = asName(name);
       node.typeParameters = asNodeArray(typeParameters);
@@ -121876,7 +104707,7 @@ ${lanes.join("\n")}
       return node.modifiers !== modifiers || node.name !== name || node.typeParameters !== typeParameters || node.heritageClauses !== heritageClauses || node.members !== members ? update(createInterfaceDeclaration(modifiers, name, typeParameters, heritageClauses, members), node) : node;
     }
     function createTypeAliasDeclaration(modifiers, name, typeParameters, type) {
-      const node = createBaseDeclaration(264 /* TypeAliasDeclaration */);
+      const node = createBaseDeclaration(265 /* TypeAliasDeclaration */);
       node.modifiers = asNodeArray(modifiers);
       node.name = asName(name);
       node.typeParameters = asNodeArray(typeParameters);
@@ -121891,7 +104722,7 @@ ${lanes.join("\n")}
       return node.modifiers !== modifiers || node.name !== name || node.typeParameters !== typeParameters || node.type !== type ? update(createTypeAliasDeclaration(modifiers, name, typeParameters, type), node) : node;
     }
     function createEnumDeclaration(modifiers, name, members) {
-      const node = createBaseDeclaration(265 /* EnumDeclaration */);
+      const node = createBaseDeclaration(266 /* EnumDeclaration */);
       node.modifiers = asNodeArray(modifiers);
       node.name = asName(name);
       node.members = createNodeArray(members);
@@ -121904,12 +104735,12 @@ ${lanes.join("\n")}
       return node.modifiers !== modifiers || node.name !== name || node.members !== members ? update(createEnumDeclaration(modifiers, name, members), node) : node;
     }
     function createModuleDeclaration(modifiers, name, body, flags2 = 0 /* None */) {
-      const node = createBaseDeclaration(266 /* ModuleDeclaration */);
+      const node = createBaseDeclaration(267 /* ModuleDeclaration */);
       node.modifiers = asNodeArray(modifiers);
-      node.flags |= flags2 & (16 /* Namespace */ | 4 /* NestedNamespace */ | 1024 /* GlobalAugmentation */);
+      node.flags |= flags2 & (32 /* Namespace */ | 8 /* NestedNamespace */ | 2048 /* GlobalAugmentation */);
       node.name = name;
       node.body = body;
-      if (modifiersToFlags(node.modifiers) & 2 /* Ambient */) {
+      if (modifiersToFlags(node.modifiers) & 128 /* Ambient */) {
         node.transformFlags = 1 /* ContainsTypeScript */;
       } else {
         node.transformFlags |= propagateChildrenFlags(node.modifiers) | propagateChildFlags(node.name) | propagateChildFlags(node.body) | 1 /* ContainsTypeScript */;
@@ -121924,7 +104755,7 @@ ${lanes.join("\n")}
       return node.modifiers !== modifiers || node.name !== name || node.body !== body ? update(createModuleDeclaration(modifiers, name, body, node.flags), node) : node;
     }
     function createModuleBlock(statements) {
-      const node = createBaseNode(267 /* ModuleBlock */);
+      const node = createBaseNode(268 /* ModuleBlock */);
       node.statements = createNodeArray(statements);
       node.transformFlags |= propagateChildrenFlags(node.statements);
       node.jsDoc = void 0;
@@ -121934,7 +104765,7 @@ ${lanes.join("\n")}
       return node.statements !== statements ? update(createModuleBlock(statements), node) : node;
     }
     function createCaseBlock(clauses) {
-      const node = createBaseNode(268 /* CaseBlock */);
+      const node = createBaseNode(269 /* CaseBlock */);
       node.clauses = createNodeArray(clauses);
       node.transformFlags |= propagateChildrenFlags(node.clauses);
       node.locals = void 0;
@@ -121945,7 +104776,7 @@ ${lanes.join("\n")}
       return node.clauses !== clauses ? update(createCaseBlock(clauses), node) : node;
     }
     function createNamespaceExportDeclaration(name) {
-      const node = createBaseDeclaration(269 /* NamespaceExportDeclaration */);
+      const node = createBaseDeclaration(270 /* NamespaceExportDeclaration */);
       node.name = asName(name);
       node.transformFlags |= propagateIdentifierNameFlags(node.name) | 1 /* ContainsTypeScript */;
       node.modifiers = void 0;
@@ -121962,7 +104793,7 @@ ${lanes.join("\n")}
       return update(updated, original);
     }
     function createImportEqualsDeclaration(modifiers, isTypeOnly, name, moduleReference) {
-      const node = createBaseDeclaration(270 /* ImportEqualsDeclaration */);
+      const node = createBaseDeclaration(271 /* ImportEqualsDeclaration */);
       node.modifiers = asNodeArray(modifiers);
       node.name = asName(name);
       node.isTypeOnly = isTypeOnly;
@@ -121978,22 +104809,22 @@ ${lanes.join("\n")}
     function updateImportEqualsDeclaration(node, modifiers, isTypeOnly, name, moduleReference) {
       return node.modifiers !== modifiers || node.isTypeOnly !== isTypeOnly || node.name !== name || node.moduleReference !== moduleReference ? update(createImportEqualsDeclaration(modifiers, isTypeOnly, name, moduleReference), node) : node;
     }
-    function createImportDeclaration(modifiers, importClause, moduleSpecifier, assertClause) {
-      const node = createBaseNode(271 /* ImportDeclaration */);
+    function createImportDeclaration(modifiers, importClause, moduleSpecifier, attributes) {
+      const node = createBaseNode(272 /* ImportDeclaration */);
       node.modifiers = asNodeArray(modifiers);
       node.importClause = importClause;
       node.moduleSpecifier = moduleSpecifier;
-      node.assertClause = assertClause;
+      node.attributes = node.assertClause = attributes;
       node.transformFlags |= propagateChildFlags(node.importClause) | propagateChildFlags(node.moduleSpecifier);
       node.transformFlags &= ~67108864 /* ContainsPossibleTopLevelAwait */;
       node.jsDoc = void 0;
       return node;
     }
-    function updateImportDeclaration(node, modifiers, importClause, moduleSpecifier, assertClause) {
-      return node.modifiers !== modifiers || node.importClause !== importClause || node.moduleSpecifier !== moduleSpecifier || node.assertClause !== assertClause ? update(createImportDeclaration(modifiers, importClause, moduleSpecifier, assertClause), node) : node;
+    function updateImportDeclaration(node, modifiers, importClause, moduleSpecifier, attributes) {
+      return node.modifiers !== modifiers || node.importClause !== importClause || node.moduleSpecifier !== moduleSpecifier || node.attributes !== attributes ? update(createImportDeclaration(modifiers, importClause, moduleSpecifier, attributes), node) : node;
     }
     function createImportClause(isTypeOnly, name, namedBindings) {
-      const node = createBaseDeclaration(272 /* ImportClause */);
+      const node = createBaseDeclaration(273 /* ImportClause */);
       node.isTypeOnly = isTypeOnly;
       node.name = name;
       node.namedBindings = namedBindings;
@@ -122008,9 +104839,10 @@ ${lanes.join("\n")}
       return node.isTypeOnly !== isTypeOnly || node.name !== name || node.namedBindings !== namedBindings ? update(createImportClause(isTypeOnly, name, namedBindings), node) : node;
     }
     function createAssertClause(elements, multiLine) {
-      const node = createBaseNode(299 /* AssertClause */);
+      const node = createBaseNode(300 /* AssertClause */);
       node.elements = createNodeArray(elements);
       node.multiLine = multiLine;
+      node.token = 132 /* AssertKeyword */;
       node.transformFlags |= 4 /* ContainsESNext */;
       return node;
     }
@@ -122018,7 +104850,7 @@ ${lanes.join("\n")}
       return node.elements !== elements || node.multiLine !== multiLine ? update(createAssertClause(elements, multiLine), node) : node;
     }
     function createAssertEntry(name, value) {
-      const node = createBaseNode(300 /* AssertEntry */);
+      const node = createBaseNode(301 /* AssertEntry */);
       node.name = name;
       node.value = value;
       node.transformFlags |= 4 /* ContainsESNext */;
@@ -122028,7 +104860,7 @@ ${lanes.join("\n")}
       return node.name !== name || node.value !== value ? update(createAssertEntry(name, value), node) : node;
     }
     function createImportTypeAssertionContainer(clause, multiLine) {
-      const node = createBaseNode(301 /* ImportTypeAssertionContainer */);
+      const node = createBaseNode(302 /* ImportTypeAssertionContainer */);
       node.assertClause = clause;
       node.multiLine = multiLine;
       return node;
@@ -122036,8 +104868,29 @@ ${lanes.join("\n")}
     function updateImportTypeAssertionContainer(node, clause, multiLine) {
       return node.assertClause !== clause || node.multiLine !== multiLine ? update(createImportTypeAssertionContainer(clause, multiLine), node) : node;
     }
+    function createImportAttributes(elements, multiLine, token) {
+      const node = createBaseNode(300 /* ImportAttributes */);
+      node.token = token ?? 118 /* WithKeyword */;
+      node.elements = createNodeArray(elements);
+      node.multiLine = multiLine;
+      node.transformFlags |= 4 /* ContainsESNext */;
+      return node;
+    }
+    function updateImportAttributes(node, elements, multiLine) {
+      return node.elements !== elements || node.multiLine !== multiLine ? update(createImportAttributes(elements, multiLine, node.token), node) : node;
+    }
+    function createImportAttribute(name, value) {
+      const node = createBaseNode(301 /* ImportAttribute */);
+      node.name = name;
+      node.value = value;
+      node.transformFlags |= 4 /* ContainsESNext */;
+      return node;
+    }
+    function updateImportAttribute(node, name, value) {
+      return node.name !== name || node.value !== value ? update(createImportAttribute(name, value), node) : node;
+    }
     function createNamespaceImport(name) {
-      const node = createBaseDeclaration(273 /* NamespaceImport */);
+      const node = createBaseDeclaration(274 /* NamespaceImport */);
       node.name = name;
       node.transformFlags |= propagateChildFlags(node.name);
       node.transformFlags &= ~67108864 /* ContainsPossibleTopLevelAwait */;
@@ -122047,7 +104900,7 @@ ${lanes.join("\n")}
       return node.name !== name ? update(createNamespaceImport(name), node) : node;
     }
     function createNamespaceExport(name) {
-      const node = createBaseDeclaration(279 /* NamespaceExport */);
+      const node = createBaseDeclaration(280 /* NamespaceExport */);
       node.name = name;
       node.transformFlags |= propagateChildFlags(node.name) | 32 /* ContainsES2020 */;
       node.transformFlags &= ~67108864 /* ContainsPossibleTopLevelAwait */;
@@ -122057,7 +104910,7 @@ ${lanes.join("\n")}
       return node.name !== name ? update(createNamespaceExport(name), node) : node;
     }
     function createNamedImports(elements) {
-      const node = createBaseNode(274 /* NamedImports */);
+      const node = createBaseNode(275 /* NamedImports */);
       node.elements = createNodeArray(elements);
       node.transformFlags |= propagateChildrenFlags(node.elements);
       node.transformFlags &= ~67108864 /* ContainsPossibleTopLevelAwait */;
@@ -122067,7 +104920,7 @@ ${lanes.join("\n")}
       return node.elements !== elements ? update(createNamedImports(elements), node) : node;
     }
     function createImportSpecifier(isTypeOnly, propertyName, name) {
-      const node = createBaseDeclaration(275 /* ImportSpecifier */);
+      const node = createBaseDeclaration(276 /* ImportSpecifier */);
       node.isTypeOnly = isTypeOnly;
       node.propertyName = propertyName;
       node.name = name;
@@ -122079,7 +104932,7 @@ ${lanes.join("\n")}
       return node.isTypeOnly !== isTypeOnly || node.propertyName !== propertyName || node.name !== name ? update(createImportSpecifier(isTypeOnly, propertyName, name), node) : node;
     }
     function createExportAssignment2(modifiers, isExportEquals, expression) {
-      const node = createBaseDeclaration(276 /* ExportAssignment */);
+      const node = createBaseDeclaration(277 /* ExportAssignment */);
       node.modifiers = asNodeArray(modifiers);
       node.isExportEquals = isExportEquals;
       node.expression = isExportEquals ? parenthesizerRules().parenthesizeRightSideOfBinary(
@@ -122096,20 +104949,20 @@ ${lanes.join("\n")}
     function updateExportAssignment(node, modifiers, expression) {
       return node.modifiers !== modifiers || node.expression !== expression ? update(createExportAssignment2(modifiers, node.isExportEquals, expression), node) : node;
     }
-    function createExportDeclaration(modifiers, isTypeOnly, exportClause, moduleSpecifier, assertClause) {
-      const node = createBaseDeclaration(277 /* ExportDeclaration */);
+    function createExportDeclaration(modifiers, isTypeOnly, exportClause, moduleSpecifier, attributes) {
+      const node = createBaseDeclaration(278 /* ExportDeclaration */);
       node.modifiers = asNodeArray(modifiers);
       node.isTypeOnly = isTypeOnly;
       node.exportClause = exportClause;
       node.moduleSpecifier = moduleSpecifier;
-      node.assertClause = assertClause;
+      node.attributes = node.assertClause = attributes;
       node.transformFlags |= propagateChildrenFlags(node.modifiers) | propagateChildFlags(node.exportClause) | propagateChildFlags(node.moduleSpecifier);
       node.transformFlags &= ~67108864 /* ContainsPossibleTopLevelAwait */;
       node.jsDoc = void 0;
       return node;
     }
-    function updateExportDeclaration(node, modifiers, isTypeOnly, exportClause, moduleSpecifier, assertClause) {
-      return node.modifiers !== modifiers || node.isTypeOnly !== isTypeOnly || node.exportClause !== exportClause || node.moduleSpecifier !== moduleSpecifier || node.assertClause !== assertClause ? finishUpdateExportDeclaration(createExportDeclaration(modifiers, isTypeOnly, exportClause, moduleSpecifier, assertClause), node) : node;
+    function updateExportDeclaration(node, modifiers, isTypeOnly, exportClause, moduleSpecifier, attributes) {
+      return node.modifiers !== modifiers || node.isTypeOnly !== isTypeOnly || node.exportClause !== exportClause || node.moduleSpecifier !== moduleSpecifier || node.attributes !== attributes ? finishUpdateExportDeclaration(createExportDeclaration(modifiers, isTypeOnly, exportClause, moduleSpecifier, attributes), node) : node;
     }
     function finishUpdateExportDeclaration(updated, original) {
       if (updated !== original) {
@@ -122120,7 +104973,7 @@ ${lanes.join("\n")}
       return update(updated, original);
     }
     function createNamedExports(elements) {
-      const node = createBaseNode(278 /* NamedExports */);
+      const node = createBaseNode(279 /* NamedExports */);
       node.elements = createNodeArray(elements);
       node.transformFlags |= propagateChildrenFlags(node.elements);
       node.transformFlags &= ~67108864 /* ContainsPossibleTopLevelAwait */;
@@ -122130,7 +104983,7 @@ ${lanes.join("\n")}
       return node.elements !== elements ? update(createNamedExports(elements), node) : node;
     }
     function createExportSpecifier(isTypeOnly, propertyName, name) {
-      const node = createBaseNode(280 /* ExportSpecifier */);
+      const node = createBaseNode(281 /* ExportSpecifier */);
       node.isTypeOnly = isTypeOnly;
       node.propertyName = asName(propertyName);
       node.name = asName(name);
@@ -122143,12 +104996,12 @@ ${lanes.join("\n")}
       return node.isTypeOnly !== isTypeOnly || node.propertyName !== propertyName || node.name !== name ? update(createExportSpecifier(isTypeOnly, propertyName, name), node) : node;
     }
     function createMissingDeclaration() {
-      const node = createBaseDeclaration(281 /* MissingDeclaration */);
+      const node = createBaseDeclaration(282 /* MissingDeclaration */);
       node.jsDoc = void 0;
       return node;
     }
     function createExternalModuleReference(expression) {
-      const node = createBaseNode(282 /* ExternalModuleReference */);
+      const node = createBaseNode(283 /* ExternalModuleReference */);
       node.expression = expression;
       node.transformFlags |= propagateChildFlags(node.expression);
       node.transformFlags &= ~67108864 /* ContainsPossibleTopLevelAwait */;
@@ -122180,7 +105033,7 @@ ${lanes.join("\n")}
       return node.type !== type ? update(createJSDocUnaryTypeWorker(kind, type), node) : node;
     }
     function createJSDocFunctionType(parameters, type) {
-      const node = createBaseDeclaration(323 /* JSDocFunctionType */);
+      const node = createBaseDeclaration(324 /* JSDocFunctionType */);
       node.parameters = asNodeArray(parameters);
       node.type = type;
       node.transformFlags = propagateChildrenFlags(node.parameters) | (node.type ? 1 /* ContainsTypeScript */ : 0 /* None */);
@@ -122194,7 +105047,7 @@ ${lanes.join("\n")}
       return node.parameters !== parameters || node.type !== type ? update(createJSDocFunctionType(parameters, type), node) : node;
     }
     function createJSDocTypeLiteral(propertyTags, isArrayType = false) {
-      const node = createBaseDeclaration(328 /* JSDocTypeLiteral */);
+      const node = createBaseDeclaration(329 /* JSDocTypeLiteral */);
       node.jsDocPropertyTags = asNodeArray(propertyTags);
       node.isArrayType = isArrayType;
       return node;
@@ -122203,7 +105056,7 @@ ${lanes.join("\n")}
       return node.jsDocPropertyTags !== propertyTags || node.isArrayType !== isArrayType ? update(createJSDocTypeLiteral(propertyTags, isArrayType), node) : node;
     }
     function createJSDocTypeExpression(type) {
-      const node = createBaseNode(315 /* JSDocTypeExpression */);
+      const node = createBaseNode(316 /* JSDocTypeExpression */);
       node.type = type;
       return node;
     }
@@ -122211,7 +105064,7 @@ ${lanes.join("\n")}
       return node.type !== type ? update(createJSDocTypeExpression(type), node) : node;
     }
     function createJSDocSignature(typeParameters, parameters, type) {
-      const node = createBaseDeclaration(329 /* JSDocSignature */);
+      const node = createBaseDeclaration(330 /* JSDocSignature */);
       node.typeParameters = asNodeArray(typeParameters);
       node.parameters = createNodeArray(parameters);
       node.type = type;
@@ -122240,7 +105093,7 @@ ${lanes.join("\n")}
       return node;
     }
     function createJSDocTemplateTag(tagName, constraint, typeParameters, comment) {
-      const node = createBaseJSDocTag(351 /* JSDocTemplateTag */, tagName ?? createIdentifier("template"), comment);
+      const node = createBaseJSDocTag(352 /* JSDocTemplateTag */, tagName ?? createIdentifier("template"), comment);
       node.constraint = constraint;
       node.typeParameters = createNodeArray(typeParameters);
       return node;
@@ -122249,7 +105102,7 @@ ${lanes.join("\n")}
       return node.tagName !== tagName || node.constraint !== constraint || node.typeParameters !== typeParameters || node.comment !== comment ? update(createJSDocTemplateTag(tagName, constraint, typeParameters, comment), node) : node;
     }
     function createJSDocTypedefTag(tagName, typeExpression, fullName, comment) {
-      const node = createBaseJSDocTagDeclaration(352 /* JSDocTypedefTag */, tagName ?? createIdentifier("typedef"), comment);
+      const node = createBaseJSDocTagDeclaration(353 /* JSDocTypedefTag */, tagName ?? createIdentifier("typedef"), comment);
       node.typeExpression = typeExpression;
       node.fullName = fullName;
       node.name = getJSDocTypeAliasName(fullName);
@@ -122261,7 +105114,7 @@ ${lanes.join("\n")}
       return node.tagName !== tagName || node.typeExpression !== typeExpression || node.fullName !== fullName || node.comment !== comment ? update(createJSDocTypedefTag(tagName, typeExpression, fullName, comment), node) : node;
     }
     function createJSDocParameterTag(tagName, name, isBracketed, typeExpression, isNameFirst, comment) {
-      const node = createBaseJSDocTagDeclaration(347 /* JSDocParameterTag */, tagName ?? createIdentifier("param"), comment);
+      const node = createBaseJSDocTagDeclaration(348 /* JSDocParameterTag */, tagName ?? createIdentifier("param"), comment);
       node.typeExpression = typeExpression;
       node.name = name;
       node.isNameFirst = !!isNameFirst;
@@ -122272,7 +105125,7 @@ ${lanes.join("\n")}
       return node.tagName !== tagName || node.name !== name || node.isBracketed !== isBracketed || node.typeExpression !== typeExpression || node.isNameFirst !== isNameFirst || node.comment !== comment ? update(createJSDocParameterTag(tagName, name, isBracketed, typeExpression, isNameFirst, comment), node) : node;
     }
     function createJSDocPropertyTag(tagName, name, isBracketed, typeExpression, isNameFirst, comment) {
-      const node = createBaseJSDocTagDeclaration(354 /* JSDocPropertyTag */, tagName ?? createIdentifier("prop"), comment);
+      const node = createBaseJSDocTagDeclaration(355 /* JSDocPropertyTag */, tagName ?? createIdentifier("prop"), comment);
       node.typeExpression = typeExpression;
       node.name = name;
       node.isNameFirst = !!isNameFirst;
@@ -122283,7 +105136,7 @@ ${lanes.join("\n")}
       return node.tagName !== tagName || node.name !== name || node.isBracketed !== isBracketed || node.typeExpression !== typeExpression || node.isNameFirst !== isNameFirst || node.comment !== comment ? update(createJSDocPropertyTag(tagName, name, isBracketed, typeExpression, isNameFirst, comment), node) : node;
     }
     function createJSDocCallbackTag(tagName, typeExpression, fullName, comment) {
-      const node = createBaseJSDocTagDeclaration(344 /* JSDocCallbackTag */, tagName ?? createIdentifier("callback"), comment);
+      const node = createBaseJSDocTagDeclaration(345 /* JSDocCallbackTag */, tagName ?? createIdentifier("callback"), comment);
       node.typeExpression = typeExpression;
       node.fullName = fullName;
       node.name = getJSDocTypeAliasName(fullName);
@@ -122295,7 +105148,7 @@ ${lanes.join("\n")}
       return node.tagName !== tagName || node.typeExpression !== typeExpression || node.fullName !== fullName || node.comment !== comment ? update(createJSDocCallbackTag(tagName, typeExpression, fullName, comment), node) : node;
     }
     function createJSDocOverloadTag(tagName, typeExpression, comment) {
-      const node = createBaseJSDocTag(345 /* JSDocOverloadTag */, tagName ?? createIdentifier("overload"), comment);
+      const node = createBaseJSDocTag(346 /* JSDocOverloadTag */, tagName ?? createIdentifier("overload"), comment);
       node.typeExpression = typeExpression;
       return node;
     }
@@ -122303,7 +105156,7 @@ ${lanes.join("\n")}
       return node.tagName !== tagName || node.typeExpression !== typeExpression || node.comment !== comment ? update(createJSDocOverloadTag(tagName, typeExpression, comment), node) : node;
     }
     function createJSDocAugmentsTag(tagName, className, comment) {
-      const node = createBaseJSDocTag(334 /* JSDocAugmentsTag */, tagName ?? createIdentifier("augments"), comment);
+      const node = createBaseJSDocTag(335 /* JSDocAugmentsTag */, tagName ?? createIdentifier("augments"), comment);
       node.class = className;
       return node;
     }
@@ -122311,12 +105164,12 @@ ${lanes.join("\n")}
       return node.tagName !== tagName || node.class !== className || node.comment !== comment ? update(createJSDocAugmentsTag(tagName, className, comment), node) : node;
     }
     function createJSDocImplementsTag(tagName, className, comment) {
-      const node = createBaseJSDocTag(335 /* JSDocImplementsTag */, tagName ?? createIdentifier("implements"), comment);
+      const node = createBaseJSDocTag(336 /* JSDocImplementsTag */, tagName ?? createIdentifier("implements"), comment);
       node.class = className;
       return node;
     }
     function createJSDocSeeTag(tagName, name, comment) {
-      const node = createBaseJSDocTag(353 /* JSDocSeeTag */, tagName ?? createIdentifier("see"), comment);
+      const node = createBaseJSDocTag(354 /* JSDocSeeTag */, tagName ?? createIdentifier("see"), comment);
       node.name = name;
       return node;
     }
@@ -122324,7 +105177,7 @@ ${lanes.join("\n")}
       return node.tagName !== tagName || node.name !== name || node.comment !== comment ? update(createJSDocSeeTag(tagName, name, comment), node) : node;
     }
     function createJSDocNameReference(name) {
-      const node = createBaseNode(316 /* JSDocNameReference */);
+      const node = createBaseNode(317 /* JSDocNameReference */);
       node.name = name;
       return node;
     }
@@ -122332,7 +105185,7 @@ ${lanes.join("\n")}
       return node.name !== name ? update(createJSDocNameReference(name), node) : node;
     }
     function createJSDocMemberName(left, right) {
-      const node = createBaseNode(317 /* JSDocMemberName */);
+      const node = createBaseNode(318 /* JSDocMemberName */);
       node.left = left;
       node.right = right;
       node.transformFlags |= propagateChildFlags(node.left) | propagateChildFlags(node.right);
@@ -122342,7 +105195,7 @@ ${lanes.join("\n")}
       return node.left !== left || node.right !== right ? update(createJSDocMemberName(left, right), node) : node;
     }
     function createJSDocLink(name, text) {
-      const node = createBaseNode(330 /* JSDocLink */);
+      const node = createBaseNode(331 /* JSDocLink */);
       node.name = name;
       node.text = text;
       return node;
@@ -122351,7 +105204,7 @@ ${lanes.join("\n")}
       return node.name !== name ? update(createJSDocLink(name, text), node) : node;
     }
     function createJSDocLinkCode(name, text) {
-      const node = createBaseNode(331 /* JSDocLinkCode */);
+      const node = createBaseNode(332 /* JSDocLinkCode */);
       node.name = name;
       node.text = text;
       return node;
@@ -122360,7 +105213,7 @@ ${lanes.join("\n")}
       return node.name !== name ? update(createJSDocLinkCode(name, text), node) : node;
     }
     function createJSDocLinkPlain(name, text) {
-      const node = createBaseNode(332 /* JSDocLinkPlain */);
+      const node = createBaseNode(333 /* JSDocLinkPlain */);
       node.name = name;
       node.text = text;
       return node;
@@ -122387,14 +105240,14 @@ ${lanes.join("\n")}
       return node.tagName !== tagName || node.typeExpression !== typeExpression || node.comment !== comment ? update(createJSDocTypeLikeTagWorker(kind, tagName, typeExpression, comment), node) : node;
     }
     function createJSDocUnknownTag(tagName, comment) {
-      const node = createBaseJSDocTag(333 /* JSDocTag */, tagName, comment);
+      const node = createBaseJSDocTag(334 /* JSDocTag */, tagName, comment);
       return node;
     }
     function updateJSDocUnknownTag(node, tagName, comment) {
       return node.tagName !== tagName || node.comment !== comment ? update(createJSDocUnknownTag(tagName, comment), node) : node;
     }
     function createJSDocEnumTag(tagName, typeExpression, comment) {
-      const node = createBaseJSDocTagDeclaration(346 /* JSDocEnumTag */, tagName ?? createIdentifier(getDefaultTagNameForKind(346 /* JSDocEnumTag */)), comment);
+      const node = createBaseJSDocTagDeclaration(347 /* JSDocEnumTag */, tagName ?? createIdentifier(getDefaultTagNameForKind(347 /* JSDocEnumTag */)), comment);
       node.typeExpression = typeExpression;
       node.locals = void 0;
       node.nextContainer = void 0;
@@ -122404,7 +105257,7 @@ ${lanes.join("\n")}
       return node.tagName !== tagName || node.typeExpression !== typeExpression || node.comment !== comment ? update(createJSDocEnumTag(tagName, typeExpression, comment), node) : node;
     }
     function createJSDocText(text) {
-      const node = createBaseNode(327 /* JSDocText */);
+      const node = createBaseNode(328 /* JSDocText */);
       node.text = text;
       return node;
     }
@@ -122412,7 +105265,7 @@ ${lanes.join("\n")}
       return node.text !== text ? update(createJSDocText(text), node) : node;
     }
     function createJSDocComment(comment, tags) {
-      const node = createBaseNode(326 /* JSDoc */);
+      const node = createBaseNode(327 /* JSDoc */);
       node.comment = comment;
       node.tags = asNodeArray(tags);
       return node;
@@ -122421,7 +105274,7 @@ ${lanes.join("\n")}
       return node.comment !== comment || node.tags !== tags ? update(createJSDocComment(comment, tags), node) : node;
     }
     function createJsxElement(openingElement, children, closingElement) {
-      const node = createBaseNode(283 /* JsxElement */);
+      const node = createBaseNode(284 /* JsxElement */);
       node.openingElement = openingElement;
       node.children = createNodeArray(children);
       node.closingElement = closingElement;
@@ -122432,7 +105285,7 @@ ${lanes.join("\n")}
       return node.openingElement !== openingElement || node.children !== children || node.closingElement !== closingElement ? update(createJsxElement(openingElement, children, closingElement), node) : node;
     }
     function createJsxSelfClosingElement(tagName, typeArguments, attributes) {
-      const node = createBaseNode(284 /* JsxSelfClosingElement */);
+      const node = createBaseNode(285 /* JsxSelfClosingElement */);
       node.tagName = tagName;
       node.typeArguments = asNodeArray(typeArguments);
       node.attributes = attributes;
@@ -122446,7 +105299,7 @@ ${lanes.join("\n")}
       return node.tagName !== tagName || node.typeArguments !== typeArguments || node.attributes !== attributes ? update(createJsxSelfClosingElement(tagName, typeArguments, attributes), node) : node;
     }
     function createJsxOpeningElement(tagName, typeArguments, attributes) {
-      const node = createBaseNode(285 /* JsxOpeningElement */);
+      const node = createBaseNode(286 /* JsxOpeningElement */);
       node.tagName = tagName;
       node.typeArguments = asNodeArray(typeArguments);
       node.attributes = attributes;
@@ -122460,7 +105313,7 @@ ${lanes.join("\n")}
       return node.tagName !== tagName || node.typeArguments !== typeArguments || node.attributes !== attributes ? update(createJsxOpeningElement(tagName, typeArguments, attributes), node) : node;
     }
     function createJsxClosingElement(tagName) {
-      const node = createBaseNode(286 /* JsxClosingElement */);
+      const node = createBaseNode(287 /* JsxClosingElement */);
       node.tagName = tagName;
       node.transformFlags |= propagateChildFlags(node.tagName) | 2 /* ContainsJsx */;
       return node;
@@ -122469,7 +105322,7 @@ ${lanes.join("\n")}
       return node.tagName !== tagName ? update(createJsxClosingElement(tagName), node) : node;
     }
     function createJsxFragment(openingFragment, children, closingFragment) {
-      const node = createBaseNode(287 /* JsxFragment */);
+      const node = createBaseNode(288 /* JsxFragment */);
       node.openingFragment = openingFragment;
       node.children = createNodeArray(children);
       node.closingFragment = closingFragment;
@@ -122490,17 +105343,17 @@ ${lanes.join("\n")}
       return node.text !== text || node.containsOnlyTriviaWhiteSpaces !== containsOnlyTriviaWhiteSpaces ? update(createJsxText(text, containsOnlyTriviaWhiteSpaces), node) : node;
     }
     function createJsxOpeningFragment() {
-      const node = createBaseNode(288 /* JsxOpeningFragment */);
+      const node = createBaseNode(289 /* JsxOpeningFragment */);
       node.transformFlags |= 2 /* ContainsJsx */;
       return node;
     }
     function createJsxJsxClosingFragment() {
-      const node = createBaseNode(289 /* JsxClosingFragment */);
+      const node = createBaseNode(290 /* JsxClosingFragment */);
       node.transformFlags |= 2 /* ContainsJsx */;
       return node;
     }
     function createJsxAttribute(name, initializer) {
-      const node = createBaseDeclaration(290 /* JsxAttribute */);
+      const node = createBaseDeclaration(291 /* JsxAttribute */);
       node.name = name;
       node.initializer = initializer;
       node.transformFlags |= propagateChildFlags(node.name) | propagateChildFlags(node.initializer) | 2 /* ContainsJsx */;
@@ -122510,7 +105363,7 @@ ${lanes.join("\n")}
       return node.name !== name || node.initializer !== initializer ? update(createJsxAttribute(name, initializer), node) : node;
     }
     function createJsxAttributes(properties) {
-      const node = createBaseDeclaration(291 /* JsxAttributes */);
+      const node = createBaseDeclaration(292 /* JsxAttributes */);
       node.properties = createNodeArray(properties);
       node.transformFlags |= propagateChildrenFlags(node.properties) | 2 /* ContainsJsx */;
       return node;
@@ -122519,7 +105372,7 @@ ${lanes.join("\n")}
       return node.properties !== properties ? update(createJsxAttributes(properties), node) : node;
     }
     function createJsxSpreadAttribute(expression) {
-      const node = createBaseNode(292 /* JsxSpreadAttribute */);
+      const node = createBaseNode(293 /* JsxSpreadAttribute */);
       node.expression = expression;
       node.transformFlags |= propagateChildFlags(node.expression) | 2 /* ContainsJsx */;
       return node;
@@ -122528,7 +105381,7 @@ ${lanes.join("\n")}
       return node.expression !== expression ? update(createJsxSpreadAttribute(expression), node) : node;
     }
     function createJsxExpression(dotDotDotToken, expression) {
-      const node = createBaseNode(293 /* JsxExpression */);
+      const node = createBaseNode(294 /* JsxExpression */);
       node.dotDotDotToken = dotDotDotToken;
       node.expression = expression;
       node.transformFlags |= propagateChildFlags(node.dotDotDotToken) | propagateChildFlags(node.expression) | 2 /* ContainsJsx */;
@@ -122538,7 +105391,7 @@ ${lanes.join("\n")}
       return node.expression !== expression ? update(createJsxExpression(node.dotDotDotToken, expression), node) : node;
     }
     function createJsxNamespacedName(namespace, name) {
-      const node = createBaseNode(294 /* JsxNamespacedName */);
+      const node = createBaseNode(295 /* JsxNamespacedName */);
       node.namespace = namespace;
       node.name = name;
       node.transformFlags |= propagateChildFlags(node.namespace) | propagateChildFlags(node.name) | 2 /* ContainsJsx */;
@@ -122548,7 +105401,7 @@ ${lanes.join("\n")}
       return node.namespace !== namespace || node.name !== name ? update(createJsxNamespacedName(namespace, name), node) : node;
     }
     function createCaseClause(expression, statements) {
-      const node = createBaseNode(295 /* CaseClause */);
+      const node = createBaseNode(296 /* CaseClause */);
       node.expression = parenthesizerRules().parenthesizeExpressionForDisallowedComma(expression);
       node.statements = createNodeArray(statements);
       node.transformFlags |= propagateChildFlags(node.expression) | propagateChildrenFlags(node.statements);
@@ -122559,7 +105412,7 @@ ${lanes.join("\n")}
       return node.expression !== expression || node.statements !== statements ? update(createCaseClause(expression, statements), node) : node;
     }
     function createDefaultClause(statements) {
-      const node = createBaseNode(296 /* DefaultClause */);
+      const node = createBaseNode(297 /* DefaultClause */);
       node.statements = createNodeArray(statements);
       node.transformFlags = propagateChildrenFlags(node.statements);
       return node;
@@ -122568,7 +105421,7 @@ ${lanes.join("\n")}
       return node.statements !== statements ? update(createDefaultClause(statements), node) : node;
     }
     function createHeritageClause(token, types) {
-      const node = createBaseNode(297 /* HeritageClause */);
+      const node = createBaseNode(298 /* HeritageClause */);
       node.token = token;
       node.types = createNodeArray(types);
       node.transformFlags |= propagateChildrenFlags(node.types);
@@ -122588,7 +105441,7 @@ ${lanes.join("\n")}
       return node.types !== types ? update(createHeritageClause(node.token, types), node) : node;
     }
     function createCatchClause(variableDeclaration, block) {
-      const node = createBaseNode(298 /* CatchClause */);
+      const node = createBaseNode(299 /* CatchClause */);
       node.variableDeclaration = asVariableDeclaration(variableDeclaration);
       node.block = block;
       node.transformFlags |= propagateChildFlags(node.variableDeclaration) | propagateChildFlags(node.block) | (!variableDeclaration ? 64 /* ContainsES2019 */ : 0 /* None */);
@@ -122600,7 +105453,7 @@ ${lanes.join("\n")}
       return node.variableDeclaration !== variableDeclaration || node.block !== block ? update(createCatchClause(variableDeclaration, block), node) : node;
     }
     function createPropertyAssignment(name, initializer) {
-      const node = createBaseDeclaration(302 /* PropertyAssignment */);
+      const node = createBaseDeclaration(303 /* PropertyAssignment */);
       node.name = asName(name);
       node.initializer = parenthesizerRules().parenthesizeExpressionForDisallowedComma(initializer);
       node.transformFlags |= propagateNameFlags(node.name) | propagateChildFlags(node.initializer);
@@ -122622,7 +105475,7 @@ ${lanes.join("\n")}
       return update(updated, original);
     }
     function createShorthandPropertyAssignment(name, objectAssignmentInitializer) {
-      const node = createBaseDeclaration(303 /* ShorthandPropertyAssignment */);
+      const node = createBaseDeclaration(304 /* ShorthandPropertyAssignment */);
       node.name = asName(name);
       node.objectAssignmentInitializer = objectAssignmentInitializer && parenthesizerRules().parenthesizeExpressionForDisallowedComma(objectAssignmentInitializer);
       node.transformFlags |= propagateIdentifierNameFlags(node.name) | propagateChildFlags(node.objectAssignmentInitializer) | 1024 /* ContainsES2015 */;
@@ -122646,7 +105499,7 @@ ${lanes.join("\n")}
       return update(updated, original);
     }
     function createSpreadAssignment(expression) {
-      const node = createBaseDeclaration(304 /* SpreadAssignment */);
+      const node = createBaseDeclaration(305 /* SpreadAssignment */);
       node.expression = parenthesizerRules().parenthesizeExpressionForDisallowedComma(expression);
       node.transformFlags |= propagateChildFlags(node.expression) | 128 /* ContainsES2018 */ | 65536 /* ContainsObjectRestOrSpread */;
       node.jsDoc = void 0;
@@ -122656,7 +105509,7 @@ ${lanes.join("\n")}
       return node.expression !== expression ? update(createSpreadAssignment(expression), node) : node;
     }
     function createEnumMember(name, initializer) {
-      const node = createBaseDeclaration(305 /* EnumMember */);
+      const node = createBaseDeclaration(306 /* EnumMember */);
       node.name = asName(name);
       node.initializer = initializer && parenthesizerRules().parenthesizeExpressionForDisallowedComma(initializer);
       node.transformFlags |= propagateChildFlags(node.name) | propagateChildFlags(node.initializer) | 1 /* ContainsTypeScript */;
@@ -122667,7 +105520,7 @@ ${lanes.join("\n")}
       return node.name !== name || node.initializer !== initializer ? update(createEnumMember(name, initializer), node) : node;
     }
     function createSourceFile2(statements, endOfFileToken, flags2) {
-      const node = baseFactory2.createBaseSourceFileNode(311 /* SourceFile */);
+      const node = baseFactory2.createBaseSourceFileNode(312 /* SourceFile */);
       node.statements = createNodeArray(statements);
       node.endOfFileToken = endOfFileToken;
       node.flags |= flags2;
@@ -122707,7 +105560,6 @@ ${lanes.join("\n")}
       node.imports = void 0;
       node.moduleAugmentations = void 0;
       node.ambientModuleNames = void 0;
-      node.resolvedModules = void 0;
       node.classifiableNames = void 0;
       node.impliedNodeFormat = void 0;
       return node;
@@ -122737,7 +105589,7 @@ ${lanes.join("\n")}
     }
     function cloneRedirectedSourceFile(source) {
       const node = createRedirectedSourceFile(source.redirectInfo);
-      node.flags |= source.flags & ~8 /* Synthesized */;
+      node.flags |= source.flags & ~16 /* Synthesized */;
       node.fileName = source.fileName;
       node.path = source.path;
       node.resolvedPath = source.resolvedPath;
@@ -122748,8 +105600,8 @@ ${lanes.join("\n")}
       return node;
     }
     function cloneSourceFileWorker(source) {
-      const node = baseFactory2.createBaseSourceFileNode(311 /* SourceFile */);
-      node.flags |= source.flags & ~8 /* Synthesized */;
+      const node = baseFactory2.createBaseSourceFileNode(312 /* SourceFile */);
+      node.flags |= source.flags & ~16 /* Synthesized */;
       for (const p in source) {
         if (hasProperty(node, p) || !hasProperty(source, p)) {
           continue;
@@ -122782,7 +105634,7 @@ ${lanes.join("\n")}
       return node.statements !== statements || node.isDeclarationFile !== isDeclarationFile || node.referencedFiles !== referencedFiles || node.typeReferenceDirectives !== typeReferenceDirectives || node.hasNoDefaultLib !== hasNoDefaultLib || node.libReferenceDirectives !== libReferenceDirectives ? update(cloneSourceFileWithChanges(node, statements, isDeclarationFile, referencedFiles, typeReferenceDirectives, hasNoDefaultLib, libReferenceDirectives), node) : node;
     }
     function createBundle(sourceFiles, prepends = emptyArray) {
-      const node = createBaseNode(312 /* Bundle */);
+      const node = createBaseNode(313 /* Bundle */);
       node.prepends = prepends;
       node.sourceFiles = sourceFiles;
       node.syntheticFileReferences = void 0;
@@ -122795,7 +105647,7 @@ ${lanes.join("\n")}
       return node.sourceFiles !== sourceFiles || node.prepends !== prepends ? update(createBundle(sourceFiles, prepends), node) : node;
     }
     function createUnparsedSource(prologues, syntheticReferences, texts) {
-      const node = createBaseNode(313 /* UnparsedSource */);
+      const node = createBaseNode(314 /* UnparsedSource */);
       node.prologues = prologues;
       node.syntheticReferences = syntheticReferences;
       node.texts = texts;
@@ -122812,48 +105664,48 @@ ${lanes.join("\n")}
       return node;
     }
     function createUnparsedPrologue(data) {
-      return createBaseUnparsedNode(306 /* UnparsedPrologue */, data);
+      return createBaseUnparsedNode(307 /* UnparsedPrologue */, data);
     }
     function createUnparsedPrepend(data, texts) {
-      const node = createBaseUnparsedNode(307 /* UnparsedPrepend */, data);
+      const node = createBaseUnparsedNode(308 /* UnparsedPrepend */, data);
       node.texts = texts;
       return node;
     }
     function createUnparsedTextLike(data, internal) {
-      return createBaseUnparsedNode(internal ? 309 /* UnparsedInternalText */ : 308 /* UnparsedText */, data);
+      return createBaseUnparsedNode(internal ? 310 /* UnparsedInternalText */ : 309 /* UnparsedText */, data);
     }
     function createUnparsedSyntheticReference(section) {
-      const node = createBaseNode(310 /* UnparsedSyntheticReference */);
+      const node = createBaseNode(311 /* UnparsedSyntheticReference */);
       node.data = section.data;
       node.section = section;
       return node;
     }
     function createInputFiles2() {
-      const node = createBaseNode(314 /* InputFiles */);
+      const node = createBaseNode(315 /* InputFiles */);
       node.javascriptText = "";
       node.declarationText = "";
       return node;
     }
     function createSyntheticExpression(type, isSpread = false, tupleNameSource) {
-      const node = createBaseNode(236 /* SyntheticExpression */);
+      const node = createBaseNode(237 /* SyntheticExpression */);
       node.type = type;
       node.isSpread = isSpread;
       node.tupleNameSource = tupleNameSource;
       return node;
     }
     function createSyntaxList3(children) {
-      const node = createBaseNode(357 /* SyntaxList */);
+      const node = createBaseNode(358 /* SyntaxList */);
       node._children = children;
       return node;
     }
     function createNotEmittedStatement(original) {
-      const node = createBaseNode(358 /* NotEmittedStatement */);
+      const node = createBaseNode(359 /* NotEmittedStatement */);
       node.original = original;
       setTextRange(node, original);
       return node;
     }
     function createPartiallyEmittedExpression(expression, original) {
-      const node = createBaseNode(359 /* PartiallyEmittedExpression */);
+      const node = createBaseNode(360 /* PartiallyEmittedExpression */);
       node.expression = expression;
       node.original = original;
       node.transformFlags |= propagateChildFlags(node.expression) | 1 /* ContainsTypeScript */;
@@ -122875,7 +105727,7 @@ ${lanes.join("\n")}
       return node;
     }
     function createCommaListExpression(elements) {
-      const node = createBaseNode(360 /* CommaListExpression */);
+      const node = createBaseNode(361 /* CommaListExpression */);
       node.elements = createNodeArray(sameFlatMap(elements, flattenCommaElements));
       node.transformFlags |= propagateChildrenFlags(node.elements);
       return node;
@@ -122884,7 +105736,7 @@ ${lanes.join("\n")}
       return node.elements !== elements ? update(createCommaListExpression(elements), node) : node;
     }
     function createSyntheticReferenceExpression(expression, thisArg) {
-      const node = createBaseNode(361 /* SyntheticReferenceExpression */);
+      const node = createBaseNode(362 /* SyntheticReferenceExpression */);
       node.expression = expression;
       node.thisArg = thisArg;
       node.transformFlags |= propagateChildFlags(node.expression) | propagateChildFlags(node.thisArg);
@@ -122895,7 +105747,7 @@ ${lanes.join("\n")}
     }
     function cloneGeneratedIdentifier(node) {
       const clone2 = createBaseIdentifier(node.escapedText);
-      clone2.flags |= node.flags & ~8 /* Synthesized */;
+      clone2.flags |= node.flags & ~16 /* Synthesized */;
       clone2.transformFlags = node.transformFlags;
       setOriginalNode(clone2, node);
       setIdentifierAutoGenerate(clone2, { ...node.emitNode.autoGenerate });
@@ -122903,7 +105755,7 @@ ${lanes.join("\n")}
     }
     function cloneIdentifier(node) {
       const clone2 = createBaseIdentifier(node.escapedText);
-      clone2.flags |= node.flags & ~8 /* Synthesized */;
+      clone2.flags |= node.flags & ~16 /* Synthesized */;
       clone2.jsDoc = node.jsDoc;
       clone2.flowNode = node.flowNode;
       clone2.symbol = node.symbol;
@@ -122916,7 +105768,7 @@ ${lanes.join("\n")}
     }
     function cloneGeneratedPrivateIdentifier(node) {
       const clone2 = createBasePrivateIdentifier(node.escapedText);
-      clone2.flags |= node.flags & ~8 /* Synthesized */;
+      clone2.flags |= node.flags & ~16 /* Synthesized */;
       clone2.transformFlags = node.transformFlags;
       setOriginalNode(clone2, node);
       setIdentifierAutoGenerate(clone2, { ...node.emitNode.autoGenerate });
@@ -122924,7 +105776,7 @@ ${lanes.join("\n")}
     }
     function clonePrivateIdentifier(node) {
       const clone2 = createBasePrivateIdentifier(node.escapedText);
-      clone2.flags |= node.flags & ~8 /* Synthesized */;
+      clone2.flags |= node.flags & ~16 /* Synthesized */;
       clone2.transformFlags = node.transformFlags;
       setOriginalNode(clone2, node);
       return clone2;
@@ -122949,7 +105801,7 @@ ${lanes.join("\n")}
         return clonePrivateIdentifier(node);
       }
       const clone2 = !isNodeKind(node.kind) ? baseFactory2.createBaseTokenNode(node.kind) : baseFactory2.createBaseNode(node.kind);
-      clone2.flags |= node.flags & ~8 /* Synthesized */;
+      clone2.flags |= node.flags & ~16 /* Synthesized */;
       clone2.transformFlags = node.transformFlags;
       setOriginalNode(clone2, node);
       for (const key in node) {
@@ -123042,7 +105894,10 @@ ${lanes.join("\n")}
       );
     }
     function createTypeCheck(value, tag) {
-      return tag === "undefined" ? factory2.createStrictEquality(value, createVoidZero()) : factory2.createStrictEquality(createTypeOfExpression(value), createStringLiteral(tag));
+      return tag === "null" ? factory2.createStrictEquality(value, createNull()) : tag === "undefined" ? factory2.createStrictEquality(value, createVoidZero()) : factory2.createStrictEquality(createTypeOfExpression(value), createStringLiteral(tag));
+    }
+    function createIsNotTypeCheck(value, tag) {
+      return tag === "null" ? factory2.createStrictInequality(value, createNull()) : tag === "undefined" ? factory2.createStrictInequality(value, createVoidZero()) : factory2.createStrictInequality(createTypeOfExpression(value), createStringLiteral(tag));
     }
     function createMethodCall(object, methodName, argumentsList) {
       if (isCallChain(object)) {
@@ -123117,17 +105972,17 @@ ${lanes.join("\n")}
     }
     function updateOuterExpression(outerExpression, expression) {
       switch (outerExpression.kind) {
-        case 216 /* ParenthesizedExpression */:
+        case 217 /* ParenthesizedExpression */:
           return updateParenthesizedExpression(outerExpression, expression);
-        case 215 /* TypeAssertionExpression */:
+        case 216 /* TypeAssertionExpression */:
           return updateTypeAssertion(outerExpression, outerExpression.type, expression);
-        case 233 /* AsExpression */:
+        case 234 /* AsExpression */:
           return updateAsExpression(outerExpression, expression, outerExpression.type);
-        case 237 /* SatisfiesExpression */:
+        case 238 /* SatisfiesExpression */:
           return updateSatisfiesExpression(outerExpression, expression, outerExpression.type);
-        case 234 /* NonNullExpression */:
+        case 235 /* NonNullExpression */:
           return updateNonNullExpression(outerExpression, expression);
-        case 359 /* PartiallyEmittedExpression */:
+        case 360 /* PartiallyEmittedExpression */:
           return updatePartiallyEmittedExpression(outerExpression, expression);
       }
     }
@@ -123167,13 +106022,13 @@ ${lanes.join("\n")}
         case 10 /* BigIntLiteral */:
         case 11 /* StringLiteral */:
           return false;
-        case 208 /* ArrayLiteralExpression */:
+        case 209 /* ArrayLiteralExpression */:
           const elements = target.elements;
           if (elements.length === 0) {
             return false;
           }
           return true;
-        case 209 /* ObjectLiteralExpression */:
+        case 210 /* ObjectLiteralExpression */:
           return target.properties.length > 0;
         default:
           return true;
@@ -123316,7 +106171,7 @@ ${lanes.join("\n")}
       return qualifiedName;
     }
     function getExternalModuleOrNamespaceExportName(ns, node, allowComments, allowSourceMaps) {
-      if (ns && hasSyntacticModifier(node, 1 /* Export */)) {
+      if (ns && hasSyntacticModifier(node, 32 /* Export */)) {
         return getNamespaceMemberName(ns, getName(node), allowComments, allowSourceMaps);
       }
       return getExportName(node, allowComments, allowSourceMaps);
@@ -123427,14 +106282,35 @@ ${lanes.join("\n")}
       }
       return statements;
     }
-    function updateModifiers(node, modifiers) {
+    function replaceModifiers(node, modifiers) {
       let modifierArray;
       if (typeof modifiers === "number") {
         modifierArray = createModifiersFromModifierFlags(modifiers);
       } else {
         modifierArray = modifiers;
       }
-      return isTypeParameterDeclaration(node) ? updateTypeParameterDeclaration(node, modifierArray, node.name, node.constraint, node.default) : isParameter(node) ? updateParameterDeclaration(node, modifierArray, node.dotDotDotToken, node.name, node.questionToken, node.type, node.initializer) : isConstructorTypeNode(node) ? updateConstructorTypeNode1(node, modifierArray, node.typeParameters, node.parameters, node.type) : isPropertySignature(node) ? updatePropertySignature(node, modifierArray, node.name, node.questionToken, node.type) : isPropertyDeclaration(node) ? updatePropertyDeclaration2(node, modifierArray, node.name, node.questionToken ?? node.exclamationToken, node.type, node.initializer) : isMethodSignature(node) ? updateMethodSignature(node, modifierArray, node.name, node.questionToken, node.typeParameters, node.parameters, node.type) : isMethodDeclaration(node) ? updateMethodDeclaration(node, modifierArray, node.asteriskToken, node.name, node.questionToken, node.typeParameters, node.parameters, node.type, node.body) : isConstructorDeclaration(node) ? updateConstructorDeclaration(node, modifierArray, node.parameters, node.body) : isGetAccessorDeclaration(node) ? updateGetAccessorDeclaration(node, modifierArray, node.name, node.parameters, node.type, node.body) : isSetAccessorDeclaration(node) ? updateSetAccessorDeclaration(node, modifierArray, node.name, node.parameters, node.body) : isIndexSignatureDeclaration(node) ? updateIndexSignature(node, modifierArray, node.parameters, node.type) : isFunctionExpression(node) ? updateFunctionExpression(node, modifierArray, node.asteriskToken, node.name, node.typeParameters, node.parameters, node.type, node.body) : isArrowFunction(node) ? updateArrowFunction(node, modifierArray, node.typeParameters, node.parameters, node.type, node.equalsGreaterThanToken, node.body) : isClassExpression(node) ? updateClassExpression(node, modifierArray, node.name, node.typeParameters, node.heritageClauses, node.members) : isVariableStatement(node) ? updateVariableStatement(node, modifierArray, node.declarationList) : isFunctionDeclaration(node) ? updateFunctionDeclaration(node, modifierArray, node.asteriskToken, node.name, node.typeParameters, node.parameters, node.type, node.body) : isClassDeclaration(node) ? updateClassDeclaration(node, modifierArray, node.name, node.typeParameters, node.heritageClauses, node.members) : isInterfaceDeclaration(node) ? updateInterfaceDeclaration(node, modifierArray, node.name, node.typeParameters, node.heritageClauses, node.members) : isTypeAliasDeclaration(node) ? updateTypeAliasDeclaration(node, modifierArray, node.name, node.typeParameters, node.type) : isEnumDeclaration(node) ? updateEnumDeclaration(node, modifierArray, node.name, node.members) : isModuleDeclaration(node) ? updateModuleDeclaration(node, modifierArray, node.name, node.body) : isImportEqualsDeclaration(node) ? updateImportEqualsDeclaration(node, modifierArray, node.isTypeOnly, node.name, node.moduleReference) : isImportDeclaration(node) ? updateImportDeclaration(node, modifierArray, node.importClause, node.moduleSpecifier, node.assertClause) : isExportAssignment(node) ? updateExportAssignment(node, modifierArray, node.expression) : isExportDeclaration(node) ? updateExportDeclaration(node, modifierArray, node.isTypeOnly, node.exportClause, node.moduleSpecifier, node.assertClause) : Debug.assertNever(node);
+      return isTypeParameterDeclaration(node) ? updateTypeParameterDeclaration(node, modifierArray, node.name, node.constraint, node.default) : isParameter(node) ? updateParameterDeclaration(node, modifierArray, node.dotDotDotToken, node.name, node.questionToken, node.type, node.initializer) : isConstructorTypeNode(node) ? updateConstructorTypeNode1(node, modifierArray, node.typeParameters, node.parameters, node.type) : isPropertySignature(node) ? updatePropertySignature(node, modifierArray, node.name, node.questionToken, node.type) : isPropertyDeclaration(node) ? updatePropertyDeclaration2(node, modifierArray, node.name, node.questionToken ?? node.exclamationToken, node.type, node.initializer) : isMethodSignature(node) ? updateMethodSignature(node, modifierArray, node.name, node.questionToken, node.typeParameters, node.parameters, node.type) : isMethodDeclaration(node) ? updateMethodDeclaration(node, modifierArray, node.asteriskToken, node.name, node.questionToken, node.typeParameters, node.parameters, node.type, node.body) : isConstructorDeclaration(node) ? updateConstructorDeclaration(node, modifierArray, node.parameters, node.body) : isGetAccessorDeclaration(node) ? updateGetAccessorDeclaration(node, modifierArray, node.name, node.parameters, node.type, node.body) : isSetAccessorDeclaration(node) ? updateSetAccessorDeclaration(node, modifierArray, node.name, node.parameters, node.body) : isIndexSignatureDeclaration(node) ? updateIndexSignature(node, modifierArray, node.parameters, node.type) : isFunctionExpression(node) ? updateFunctionExpression(node, modifierArray, node.asteriskToken, node.name, node.typeParameters, node.parameters, node.type, node.body) : isArrowFunction(node) ? updateArrowFunction(node, modifierArray, node.typeParameters, node.parameters, node.type, node.equalsGreaterThanToken, node.body) : isClassExpression(node) ? updateClassExpression(node, modifierArray, node.name, node.typeParameters, node.heritageClauses, node.members) : isVariableStatement(node) ? updateVariableStatement(node, modifierArray, node.declarationList) : isFunctionDeclaration(node) ? updateFunctionDeclaration(node, modifierArray, node.asteriskToken, node.name, node.typeParameters, node.parameters, node.type, node.body) : isClassDeclaration(node) ? updateClassDeclaration(node, modifierArray, node.name, node.typeParameters, node.heritageClauses, node.members) : isInterfaceDeclaration(node) ? updateInterfaceDeclaration(node, modifierArray, node.name, node.typeParameters, node.heritageClauses, node.members) : isTypeAliasDeclaration(node) ? updateTypeAliasDeclaration(node, modifierArray, node.name, node.typeParameters, node.type) : isEnumDeclaration(node) ? updateEnumDeclaration(node, modifierArray, node.name, node.members) : isModuleDeclaration(node) ? updateModuleDeclaration(node, modifierArray, node.name, node.body) : isImportEqualsDeclaration(node) ? updateImportEqualsDeclaration(node, modifierArray, node.isTypeOnly, node.name, node.moduleReference) : isImportDeclaration(node) ? updateImportDeclaration(node, modifierArray, node.importClause, node.moduleSpecifier, node.attributes) : isExportAssignment(node) ? updateExportAssignment(node, modifierArray, node.expression) : isExportDeclaration(node) ? updateExportDeclaration(node, modifierArray, node.isTypeOnly, node.exportClause, node.moduleSpecifier, node.attributes) : Debug.assertNever(node);
+    }
+    function replaceDecoratorsAndModifiers(node, modifierArray) {
+      return isParameter(node) ? updateParameterDeclaration(node, modifierArray, node.dotDotDotToken, node.name, node.questionToken, node.type, node.initializer) : isPropertyDeclaration(node) ? updatePropertyDeclaration2(node, modifierArray, node.name, node.questionToken ?? node.exclamationToken, node.type, node.initializer) : isMethodDeclaration(node) ? updateMethodDeclaration(node, modifierArray, node.asteriskToken, node.name, node.questionToken, node.typeParameters, node.parameters, node.type, node.body) : isGetAccessorDeclaration(node) ? updateGetAccessorDeclaration(node, modifierArray, node.name, node.parameters, node.type, node.body) : isSetAccessorDeclaration(node) ? updateSetAccessorDeclaration(node, modifierArray, node.name, node.parameters, node.body) : isClassExpression(node) ? updateClassExpression(node, modifierArray, node.name, node.typeParameters, node.heritageClauses, node.members) : isClassDeclaration(node) ? updateClassDeclaration(node, modifierArray, node.name, node.typeParameters, node.heritageClauses, node.members) : Debug.assertNever(node);
+    }
+    function replacePropertyName(node, name) {
+      switch (node.kind) {
+        case 177 /* GetAccessor */:
+          return updateGetAccessorDeclaration(node, node.modifiers, name, node.parameters, node.type, node.body);
+        case 178 /* SetAccessor */:
+          return updateSetAccessorDeclaration(node, node.modifiers, name, node.parameters, node.body);
+        case 174 /* MethodDeclaration */:
+          return updateMethodDeclaration(node, node.modifiers, node.asteriskToken, name, node.questionToken, node.typeParameters, node.parameters, node.type, node.body);
+        case 173 /* MethodSignature */:
+          return updateMethodSignature(node, node.modifiers, name, node.questionToken, node.typeParameters, node.parameters, node.type);
+        case 172 /* PropertyDeclaration */:
+          return updatePropertyDeclaration2(node, node.modifiers, name, node.questionToken ?? node.exclamationToken, node.type, node.initializer);
+        case 171 /* PropertySignature */:
+          return updatePropertySignature(node, node.modifiers, name, node.questionToken, node.type);
+        case 303 /* PropertyAssignment */:
+          return updatePropertyAssignment(node, name, node.initializer);
+      }
     }
     function asNodeArray(array) {
       return array ? createNodeArray(array) : void 0;
@@ -123484,43 +106360,43 @@ ${lanes.join("\n")}
   }
   function getDefaultTagNameForKind(kind) {
     switch (kind) {
-      case 350 /* JSDocTypeTag */:
+      case 351 /* JSDocTypeTag */:
         return "type";
-      case 348 /* JSDocReturnTag */:
+      case 349 /* JSDocReturnTag */:
         return "returns";
-      case 349 /* JSDocThisTag */:
+      case 350 /* JSDocThisTag */:
         return "this";
-      case 346 /* JSDocEnumTag */:
+      case 347 /* JSDocEnumTag */:
         return "enum";
-      case 336 /* JSDocAuthorTag */:
+      case 337 /* JSDocAuthorTag */:
         return "author";
-      case 338 /* JSDocClassTag */:
+      case 339 /* JSDocClassTag */:
         return "class";
-      case 339 /* JSDocPublicTag */:
+      case 340 /* JSDocPublicTag */:
         return "public";
-      case 340 /* JSDocPrivateTag */:
+      case 341 /* JSDocPrivateTag */:
         return "private";
-      case 341 /* JSDocProtectedTag */:
+      case 342 /* JSDocProtectedTag */:
         return "protected";
-      case 342 /* JSDocReadonlyTag */:
+      case 343 /* JSDocReadonlyTag */:
         return "readonly";
-      case 343 /* JSDocOverrideTag */:
+      case 344 /* JSDocOverrideTag */:
         return "override";
-      case 351 /* JSDocTemplateTag */:
+      case 352 /* JSDocTemplateTag */:
         return "template";
-      case 352 /* JSDocTypedefTag */:
+      case 353 /* JSDocTypedefTag */:
         return "typedef";
-      case 347 /* JSDocParameterTag */:
+      case 348 /* JSDocParameterTag */:
         return "param";
-      case 354 /* JSDocPropertyTag */:
+      case 355 /* JSDocPropertyTag */:
         return "prop";
-      case 344 /* JSDocCallbackTag */:
+      case 345 /* JSDocCallbackTag */:
         return "callback";
-      case 345 /* JSDocOverloadTag */:
+      case 346 /* JSDocOverloadTag */:
         return "overload";
-      case 334 /* JSDocAugmentsTag */:
+      case 335 /* JSDocAugmentsTag */:
         return "augments";
-      case 335 /* JSDocImplementsTag */:
+      case 336 /* JSDocImplementsTag */:
         return "implements";
       default:
         return Debug.fail(`Unsupported kind: ${Debug.formatSyntaxKind(kind)}`);
@@ -123602,77 +106478,77 @@ ${lanes.join("\n")}
     children.transformFlags = subtreeFlags;
   }
   function getTransformFlagsSubtreeExclusions(kind) {
-    if (kind >= 181 /* FirstTypeNode */ && kind <= 204 /* LastTypeNode */) {
+    if (kind >= 182 /* FirstTypeNode */ && kind <= 205 /* LastTypeNode */) {
       return -2 /* TypeExcludes */;
     }
     switch (kind) {
-      case 212 /* CallExpression */:
-      case 213 /* NewExpression */:
-      case 208 /* ArrayLiteralExpression */:
+      case 213 /* CallExpression */:
+      case 214 /* NewExpression */:
+      case 209 /* ArrayLiteralExpression */:
         return -2147450880 /* ArrayLiteralOrCallOrNewExcludes */;
-      case 266 /* ModuleDeclaration */:
+      case 267 /* ModuleDeclaration */:
         return -1941676032 /* ModuleExcludes */;
-      case 168 /* Parameter */:
+      case 169 /* Parameter */:
         return -2147483648 /* ParameterExcludes */;
-      case 218 /* ArrowFunction */:
+      case 219 /* ArrowFunction */:
         return -2072174592 /* ArrowFunctionExcludes */;
-      case 217 /* FunctionExpression */:
-      case 261 /* FunctionDeclaration */:
+      case 218 /* FunctionExpression */:
+      case 262 /* FunctionDeclaration */:
         return -1937940480 /* FunctionExcludes */;
-      case 260 /* VariableDeclarationList */:
+      case 261 /* VariableDeclarationList */:
         return -2146893824 /* VariableDeclarationListExcludes */;
-      case 262 /* ClassDeclaration */:
-      case 230 /* ClassExpression */:
+      case 263 /* ClassDeclaration */:
+      case 231 /* ClassExpression */:
         return -2147344384 /* ClassExcludes */;
-      case 175 /* Constructor */:
+      case 176 /* Constructor */:
         return -1937948672 /* ConstructorExcludes */;
-      case 171 /* PropertyDeclaration */:
+      case 172 /* PropertyDeclaration */:
         return -2013249536 /* PropertyExcludes */;
-      case 173 /* MethodDeclaration */:
-      case 176 /* GetAccessor */:
-      case 177 /* SetAccessor */:
+      case 174 /* MethodDeclaration */:
+      case 177 /* GetAccessor */:
+      case 178 /* SetAccessor */:
         return -2005057536 /* MethodOrAccessorExcludes */;
       case 133 /* AnyKeyword */:
       case 150 /* NumberKeyword */:
-      case 162 /* BigIntKeyword */:
+      case 163 /* BigIntKeyword */:
       case 146 /* NeverKeyword */:
       case 154 /* StringKeyword */:
       case 151 /* ObjectKeyword */:
       case 136 /* BooleanKeyword */:
       case 155 /* SymbolKeyword */:
       case 116 /* VoidKeyword */:
-      case 167 /* TypeParameter */:
-      case 170 /* PropertySignature */:
-      case 172 /* MethodSignature */:
-      case 178 /* CallSignature */:
-      case 179 /* ConstructSignature */:
-      case 180 /* IndexSignature */:
-      case 263 /* InterfaceDeclaration */:
-      case 264 /* TypeAliasDeclaration */:
+      case 168 /* TypeParameter */:
+      case 171 /* PropertySignature */:
+      case 173 /* MethodSignature */:
+      case 179 /* CallSignature */:
+      case 180 /* ConstructSignature */:
+      case 181 /* IndexSignature */:
+      case 264 /* InterfaceDeclaration */:
+      case 265 /* TypeAliasDeclaration */:
         return -2 /* TypeExcludes */;
-      case 209 /* ObjectLiteralExpression */:
+      case 210 /* ObjectLiteralExpression */:
         return -2147278848 /* ObjectLiteralExcludes */;
-      case 298 /* CatchClause */:
+      case 299 /* CatchClause */:
         return -2147418112 /* CatchClauseExcludes */;
-      case 205 /* ObjectBindingPattern */:
-      case 206 /* ArrayBindingPattern */:
+      case 206 /* ObjectBindingPattern */:
+      case 207 /* ArrayBindingPattern */:
         return -2147450880 /* BindingPatternExcludes */;
-      case 215 /* TypeAssertionExpression */:
-      case 237 /* SatisfiesExpression */:
-      case 233 /* AsExpression */:
-      case 359 /* PartiallyEmittedExpression */:
-      case 216 /* ParenthesizedExpression */:
+      case 216 /* TypeAssertionExpression */:
+      case 238 /* SatisfiesExpression */:
+      case 234 /* AsExpression */:
+      case 360 /* PartiallyEmittedExpression */:
+      case 217 /* ParenthesizedExpression */:
       case 108 /* SuperKeyword */:
         return -2147483648 /* OuterExpressionExcludes */;
-      case 210 /* PropertyAccessExpression */:
-      case 211 /* ElementAccessExpression */:
+      case 211 /* PropertyAccessExpression */:
+      case 212 /* ElementAccessExpression */:
         return -2147483648 /* PropertyAccessExcludes */;
       default:
         return -2147483648 /* NodeExcludes */;
     }
   }
   function makeSynthetic(node) {
-    node.flags |= 8 /* Synthesized */;
+    node.flags |= 16 /* Synthesized */;
     return node;
   }
   function createUnparsedSourceFile(textOrInputFiles, mapPathOrType, mapTextOrStripInternal) {
@@ -123921,11 +106797,13 @@ ${lanes.join("\n")}
     return new (SourceMapSource2 || (SourceMapSource2 = objectAllocator.getSourceMapSourceConstructor()))(fileName, text, skipTrivia2);
   }
   function setOriginalNode(node, original) {
-    node.original = original;
-    if (original) {
-      const emitNode = original.emitNode;
-      if (emitNode)
-        node.emitNode = mergeEmitNode(emitNode, node.emitNode);
+    if (node.original !== original) {
+      node.original = original;
+      if (original) {
+        const emitNode = original.emitNode;
+        if (emitNode)
+          node.emitNode = mergeEmitNode(emitNode, node.emitNode);
+      }
     }
     return node;
   }
@@ -123941,35 +106819,53 @@ ${lanes.join("\n")}
       constantValue,
       helpers,
       startsOnNewLine,
-      snippetElement
+      snippetElement,
+      classThis,
+      assignedName
     } = sourceEmitNode;
     if (!destEmitNode)
       destEmitNode = {};
-    if (leadingComments)
-      destEmitNode.leadingComments = addRange(leadingComments.slice(), destEmitNode.leadingComments);
-    if (trailingComments)
-      destEmitNode.trailingComments = addRange(trailingComments.slice(), destEmitNode.trailingComments);
-    if (flags)
+    if (flags) {
       destEmitNode.flags = flags;
-    if (internalFlags)
+    }
+    if (internalFlags) {
       destEmitNode.internalFlags = internalFlags & ~8 /* Immutable */;
-    if (commentRange)
+    }
+    if (leadingComments) {
+      destEmitNode.leadingComments = addRange(leadingComments.slice(), destEmitNode.leadingComments);
+    }
+    if (trailingComments) {
+      destEmitNode.trailingComments = addRange(trailingComments.slice(), destEmitNode.trailingComments);
+    }
+    if (commentRange) {
       destEmitNode.commentRange = commentRange;
-    if (sourceMapRange)
+    }
+    if (sourceMapRange) {
       destEmitNode.sourceMapRange = sourceMapRange;
-    if (tokenSourceMapRanges)
+    }
+    if (tokenSourceMapRanges) {
       destEmitNode.tokenSourceMapRanges = mergeTokenSourceMapRanges(tokenSourceMapRanges, destEmitNode.tokenSourceMapRanges);
-    if (constantValue !== void 0)
+    }
+    if (constantValue !== void 0) {
       destEmitNode.constantValue = constantValue;
+    }
     if (helpers) {
       for (const helper of helpers) {
         destEmitNode.helpers = appendIfUnique(destEmitNode.helpers, helper);
       }
     }
-    if (startsOnNewLine !== void 0)
+    if (startsOnNewLine !== void 0) {
       destEmitNode.startsOnNewLine = startsOnNewLine;
-    if (snippetElement !== void 0)
+    }
+    if (snippetElement !== void 0) {
       destEmitNode.snippetElement = snippetElement;
+    }
+    if (classThis) {
+      destEmitNode.classThis = classThis;
+    }
+    if (assignedName) {
+      destEmitNode.assignedName = assignedName;
+    }
     return destEmitNode;
   }
   function mergeTokenSourceMapRanges(sourceRanges, destRanges) {
@@ -124012,7 +106908,7 @@ ${lanes.join("\n")}
   function getOrCreateEmitNode(node) {
     if (!node.emitNode) {
       if (isParseTreeNode(node)) {
-        if (node.kind === 311 /* SourceFile */) {
+        if (node.kind === 312 /* SourceFile */) {
           return node.emitNode = { annotatedNodes: [node] };
         }
         const sourceFile = getSourceFileOfNode(getParseTreeNode(getSourceFileOfNode(node))) ?? Debug.fail("Could not determine parsed source file.");
@@ -124274,7 +107170,10 @@ ${lanes.join("\n")}
       // Class Fields Helpers
       createClassPrivateFieldGetHelper,
       createClassPrivateFieldSetHelper,
-      createClassPrivateFieldInHelper
+      createClassPrivateFieldInHelper,
+      // 'using' helpers
+      createAddDisposableResourceHelper,
+      createDisposeResourcesHelper
     };
     function getUnscopedHelperName(name) {
       return setEmitFlags(factory2.createIdentifier(name), 8192 /* HelperName */ | 4 /* AdviseOnEmitNode */);
@@ -124329,10 +107228,12 @@ ${lanes.join("\n")}
       );
     }
     function createESDecorateClassContextObject(contextIn) {
-      return factory2.createObjectLiteralExpression([
+      const properties = [
         factory2.createPropertyAssignment(factory2.createIdentifier("kind"), factory2.createStringLiteral("class")),
-        factory2.createPropertyAssignment(factory2.createIdentifier("name"), contextIn.name)
-      ]);
+        factory2.createPropertyAssignment(factory2.createIdentifier("name"), contextIn.name),
+        factory2.createPropertyAssignment(factory2.createIdentifier("metadata"), contextIn.metadata)
+      ];
+      return factory2.createObjectLiteralExpression(properties);
     }
     function createESDecorateClassElementAccessGetMethod(elementName) {
       const accessor = elementName.computed ? factory2.createElementAccessExpression(factory2.createIdentifier("obj"), elementName.name) : factory2.createPropertyAccessExpression(factory2.createIdentifier("obj"), elementName.name);
@@ -124436,13 +107337,15 @@ ${lanes.join("\n")}
       return factory2.createObjectLiteralExpression(properties);
     }
     function createESDecorateClassElementContextObject(contextIn) {
-      return factory2.createObjectLiteralExpression([
+      const properties = [
         factory2.createPropertyAssignment(factory2.createIdentifier("kind"), factory2.createStringLiteral(contextIn.kind)),
         factory2.createPropertyAssignment(factory2.createIdentifier("name"), contextIn.name.computed ? contextIn.name.name : factory2.createStringLiteralFromNode(contextIn.name.name)),
         factory2.createPropertyAssignment(factory2.createIdentifier("static"), contextIn.static ? factory2.createTrue() : factory2.createFalse()),
         factory2.createPropertyAssignment(factory2.createIdentifier("private"), contextIn.private ? factory2.createTrue() : factory2.createFalse()),
-        factory2.createPropertyAssignment(factory2.createIdentifier("access"), createESDecorateClassElementAccessObject(contextIn.name, contextIn.access))
-      ]);
+        factory2.createPropertyAssignment(factory2.createIdentifier("access"), createESDecorateClassElementAccessObject(contextIn.name, contextIn.access)),
+        factory2.createPropertyAssignment(factory2.createIdentifier("metadata"), contextIn.metadata)
+      ];
+      return factory2.createObjectLiteralExpression(properties);
     }
     function createESDecorateContextObject(contextIn) {
       return contextIn.kind === "class" ? createESDecorateClassContextObject(contextIn) : createESDecorateClassElementContextObject(contextIn);
@@ -124753,6 +107656,24 @@ ${lanes.join("\n")}
         [state, receiver]
       );
     }
+    function createAddDisposableResourceHelper(envBinding, value, async) {
+      context.requestEmitHelper(addDisposableResourceHelper);
+      return factory2.createCallExpression(
+        getUnscopedHelperName("__addDisposableResource"),
+        /*typeArguments*/
+        void 0,
+        [envBinding, value, async ? factory2.createTrue() : factory2.createFalse()]
+      );
+    }
+    function createDisposeResourcesHelper(envBinding) {
+      context.requestEmitHelper(disposeResourcesHelper);
+      return factory2.createCallExpression(
+        getUnscopedHelperName("__disposeResources"),
+        /*typeArguments*/
+        void 0,
+        [envBinding]
+      );
+    }
   }
   function compareEmitHelpers(x, y) {
     if (x === y)
@@ -124805,13 +107726,15 @@ ${lanes.join("\n")}
       classPrivateFieldSetHelper,
       classPrivateFieldInHelper,
       createBindingHelper,
-      setModuleDefaultHelper
+      setModuleDefaultHelper,
+      addDisposableResourceHelper,
+      disposeResourcesHelper
     ], (helper) => helper.name));
   }
   function isCallToHelper(firstSegment, helperName) {
     return isCallExpression(firstSegment) && isIdentifier(firstSegment.expression) && (getEmitFlags(firstSegment.expression) & 8192 /* HelperName */) !== 0 && firstSegment.expression.escapedText === helperName;
   }
-  var PrivateIdentifierKind, decorateHelper, metadataHelper, paramHelper, esDecorateHelper, runInitializersHelper, assignHelper, awaitHelper, asyncGeneratorHelper, asyncDelegator, asyncValues, restHelper, awaiterHelper, extendsHelper, templateObjectHelper, readHelper, spreadArrayHelper, propKeyHelper, setFunctionNameHelper, valuesHelper, generatorHelper, createBindingHelper, setModuleDefaultHelper, importStarHelper, importDefaultHelper, exportStarHelper, classPrivateFieldGetHelper, classPrivateFieldSetHelper, classPrivateFieldInHelper, allUnscopedEmitHelpers, asyncSuperHelper, advancedAsyncSuperHelper;
+  var PrivateIdentifierKind, decorateHelper, metadataHelper, paramHelper, esDecorateHelper, runInitializersHelper, assignHelper, awaitHelper, asyncGeneratorHelper, asyncDelegator, asyncValues, restHelper, awaiterHelper, extendsHelper, templateObjectHelper, readHelper, spreadArrayHelper, propKeyHelper, setFunctionNameHelper, valuesHelper, generatorHelper, createBindingHelper, setModuleDefaultHelper, importStarHelper, importDefaultHelper, exportStarHelper, classPrivateFieldGetHelper, classPrivateFieldSetHelper, classPrivateFieldInHelper, addDisposableResourceHelper, disposeResourcesHelper, allUnscopedEmitHelpers, asyncSuperHelper, advancedAsyncSuperHelper;
   var init_emitHelpers = __esm({
     "src/compiler/factory/emitHelpers.ts"() {
       "use strict";
@@ -124934,17 +107857,18 @@ ${lanes.join("\n")}
         scoped: false,
         dependencies: [awaitHelper],
         text: `
-            var __asyncGenerator = (this && this.__asyncGenerator) || function (thisArg, _arguments, generator) {
-                if (!Symbol.asyncIterator) throw new TypeError("Symbol.asyncIterator is not defined.");
-                var g = generator.apply(thisArg, _arguments || []), i, q = [];
-                return i = {}, verb("next"), verb("throw"), verb("return"), i[Symbol.asyncIterator] = function () { return this; }, i;
-                function verb(n) { if (g[n]) i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; }
-                function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } }
-                function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); }
-                function fulfill(value) { resume("next", value); }
-                function reject(value) { resume("throw", value); }
-                function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); }
-            };`
+        var __asyncGenerator = (this && this.__asyncGenerator) || function (thisArg, _arguments, generator) {
+            if (!Symbol.asyncIterator) throw new TypeError("Symbol.asyncIterator is not defined.");
+            var g = generator.apply(thisArg, _arguments || []), i, q = [];
+            return i = {}, verb("next"), verb("throw"), verb("return", awaitReturn), i[Symbol.asyncIterator] = function () { return this; }, i;
+            function awaitReturn(f) { return function (v) { return Promise.resolve(v).then(f, reject); }; }
+            function verb(n, f) { if (g[n]) { i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; if (f) i[n] = f(i[n]); } }
+            function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } }
+            function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); }
+            function fulfill(value) { resume("next", value); }
+            function reject(value) { resume("throw", value); }
+            function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); }
+        };`
       };
       asyncDelegator = {
         name: "typescript:asyncDelegator",
@@ -125243,6 +108167,63 @@ ${lanes.join("\n")}
                 return typeof state === "function" ? receiver === state : state.has(receiver);
             };`
       };
+      addDisposableResourceHelper = {
+        name: "typescript:addDisposableResource",
+        importName: "__addDisposableResource",
+        scoped: false,
+        text: `
+        var __addDisposableResource = (this && this.__addDisposableResource) || function (env, value, async) {
+            if (value !== null && value !== void 0) {
+                if (typeof value !== "object" && typeof value !== "function") throw new TypeError("Object expected.");
+                var dispose;
+                if (async) {
+                    if (!Symbol.asyncDispose) throw new TypeError("Symbol.asyncDispose is not defined.");
+                    dispose = value[Symbol.asyncDispose];
+                }
+                if (dispose === void 0) {
+                    if (!Symbol.dispose) throw new TypeError("Symbol.dispose is not defined.");
+                    dispose = value[Symbol.dispose];
+                }
+                if (typeof dispose !== "function") throw new TypeError("Object not disposable.");
+                env.stack.push({ value: value, dispose: dispose, async: async });
+            }
+            else if (async) {
+                env.stack.push({ async: true });
+            }
+            return value;
+        };`
+      };
+      disposeResourcesHelper = {
+        name: "typescript:disposeResources",
+        importName: "__disposeResources",
+        scoped: false,
+        text: `
+        var __disposeResources = (this && this.__disposeResources) || (function (SuppressedError) {
+            return function (env) {
+                function fail(e) {
+                    env.error = env.hasError ? new SuppressedError(e, env.error, "An error was suppressed during disposal.") : e;
+                    env.hasError = true;
+                }
+                function next() {
+                    while (env.stack.length) {
+                        var rec = env.stack.pop();
+                        try {
+                            var result = rec.dispose && rec.dispose.call(rec.value);
+                            if (rec.async) return Promise.resolve(result).then(next, function(e) { fail(e); return next(); });
+                        }
+                        catch (e) {
+                            fail(e);
+                        }
+                    }
+                    if (env.hasError) throw env.error;
+                }
+                return next();
+            };
+        })(typeof SuppressedError === "function" ? SuppressedError : function (error, suppressed, message) {
+            var e = new Error(message);
+            return e.name = "SuppressedError", e.error = error, e.suppressed = suppressed, e;
+        });`
+      };
       asyncSuperHelper = {
         name: "typescript:async-super",
         scoped: true,
@@ -125350,7 +108331,7 @@ ${lanes.join("\n")}
     return node.kind === 128 /* AbstractKeyword */;
   }
   function isOverrideModifier(node) {
-    return node.kind === 163 /* OverrideKeyword */;
+    return node.kind === 164 /* OverrideKeyword */;
   }
   function isAccessorModifier(node) {
     return node.kind === 129 /* AccessorKeyword */;
@@ -125365,577 +108346,583 @@ ${lanes.join("\n")}
     return node.kind === 84 /* CaseKeyword */;
   }
   function isQualifiedName(node) {
-    return node.kind === 165 /* QualifiedName */;
+    return node.kind === 166 /* QualifiedName */;
   }
   function isComputedPropertyName(node) {
-    return node.kind === 166 /* ComputedPropertyName */;
+    return node.kind === 167 /* ComputedPropertyName */;
   }
   function isTypeParameterDeclaration(node) {
-    return node.kind === 167 /* TypeParameter */;
+    return node.kind === 168 /* TypeParameter */;
   }
   function isParameter(node) {
-    return node.kind === 168 /* Parameter */;
+    return node.kind === 169 /* Parameter */;
   }
   function isDecorator(node) {
-    return node.kind === 169 /* Decorator */;
+    return node.kind === 170 /* Decorator */;
   }
   function isPropertySignature(node) {
-    return node.kind === 170 /* PropertySignature */;
+    return node.kind === 171 /* PropertySignature */;
   }
   function isPropertyDeclaration(node) {
-    return node.kind === 171 /* PropertyDeclaration */;
+    return node.kind === 172 /* PropertyDeclaration */;
   }
   function isMethodSignature(node) {
-    return node.kind === 172 /* MethodSignature */;
+    return node.kind === 173 /* MethodSignature */;
   }
   function isMethodDeclaration(node) {
-    return node.kind === 173 /* MethodDeclaration */;
+    return node.kind === 174 /* MethodDeclaration */;
   }
   function isClassStaticBlockDeclaration(node) {
-    return node.kind === 174 /* ClassStaticBlockDeclaration */;
+    return node.kind === 175 /* ClassStaticBlockDeclaration */;
   }
   function isConstructorDeclaration(node) {
-    return node.kind === 175 /* Constructor */;
+    return node.kind === 176 /* Constructor */;
   }
   function isGetAccessorDeclaration(node) {
-    return node.kind === 176 /* GetAccessor */;
+    return node.kind === 177 /* GetAccessor */;
   }
   function isSetAccessorDeclaration(node) {
-    return node.kind === 177 /* SetAccessor */;
+    return node.kind === 178 /* SetAccessor */;
   }
   function isCallSignatureDeclaration(node) {
-    return node.kind === 178 /* CallSignature */;
+    return node.kind === 179 /* CallSignature */;
   }
   function isConstructSignatureDeclaration(node) {
-    return node.kind === 179 /* ConstructSignature */;
+    return node.kind === 180 /* ConstructSignature */;
   }
   function isIndexSignatureDeclaration(node) {
-    return node.kind === 180 /* IndexSignature */;
+    return node.kind === 181 /* IndexSignature */;
   }
   function isTypePredicateNode(node) {
-    return node.kind === 181 /* TypePredicate */;
+    return node.kind === 182 /* TypePredicate */;
   }
   function isTypeReferenceNode(node) {
-    return node.kind === 182 /* TypeReference */;
+    return node.kind === 183 /* TypeReference */;
   }
   function isFunctionTypeNode(node) {
-    return node.kind === 183 /* FunctionType */;
+    return node.kind === 184 /* FunctionType */;
   }
   function isConstructorTypeNode(node) {
-    return node.kind === 184 /* ConstructorType */;
+    return node.kind === 185 /* ConstructorType */;
   }
   function isTypeQueryNode(node) {
-    return node.kind === 185 /* TypeQuery */;
+    return node.kind === 186 /* TypeQuery */;
   }
   function isTypeLiteralNode(node) {
-    return node.kind === 186 /* TypeLiteral */;
+    return node.kind === 187 /* TypeLiteral */;
   }
   function isArrayTypeNode(node) {
-    return node.kind === 187 /* ArrayType */;
+    return node.kind === 188 /* ArrayType */;
   }
   function isTupleTypeNode(node) {
-    return node.kind === 188 /* TupleType */;
+    return node.kind === 189 /* TupleType */;
   }
   function isNamedTupleMember(node) {
-    return node.kind === 201 /* NamedTupleMember */;
+    return node.kind === 202 /* NamedTupleMember */;
   }
   function isOptionalTypeNode(node) {
-    return node.kind === 189 /* OptionalType */;
+    return node.kind === 190 /* OptionalType */;
   }
   function isRestTypeNode(node) {
-    return node.kind === 190 /* RestType */;
+    return node.kind === 191 /* RestType */;
   }
   function isUnionTypeNode(node) {
-    return node.kind === 191 /* UnionType */;
+    return node.kind === 192 /* UnionType */;
   }
   function isIntersectionTypeNode(node) {
-    return node.kind === 192 /* IntersectionType */;
+    return node.kind === 193 /* IntersectionType */;
   }
   function isConditionalTypeNode(node) {
-    return node.kind === 193 /* ConditionalType */;
+    return node.kind === 194 /* ConditionalType */;
   }
   function isInferTypeNode(node) {
-    return node.kind === 194 /* InferType */;
+    return node.kind === 195 /* InferType */;
   }
   function isParenthesizedTypeNode(node) {
-    return node.kind === 195 /* ParenthesizedType */;
+    return node.kind === 196 /* ParenthesizedType */;
   }
   function isThisTypeNode(node) {
-    return node.kind === 196 /* ThisType */;
+    return node.kind === 197 /* ThisType */;
   }
   function isTypeOperatorNode(node) {
-    return node.kind === 197 /* TypeOperator */;
+    return node.kind === 198 /* TypeOperator */;
   }
   function isIndexedAccessTypeNode(node) {
-    return node.kind === 198 /* IndexedAccessType */;
+    return node.kind === 199 /* IndexedAccessType */;
   }
   function isMappedTypeNode(node) {
-    return node.kind === 199 /* MappedType */;
+    return node.kind === 200 /* MappedType */;
   }
   function isLiteralTypeNode(node) {
-    return node.kind === 200 /* LiteralType */;
+    return node.kind === 201 /* LiteralType */;
   }
   function isImportTypeNode(node) {
-    return node.kind === 204 /* ImportType */;
+    return node.kind === 205 /* ImportType */;
   }
   function isTemplateLiteralTypeSpan(node) {
-    return node.kind === 203 /* TemplateLiteralTypeSpan */;
+    return node.kind === 204 /* TemplateLiteralTypeSpan */;
   }
   function isTemplateLiteralTypeNode(node) {
-    return node.kind === 202 /* TemplateLiteralType */;
+    return node.kind === 203 /* TemplateLiteralType */;
   }
   function isObjectBindingPattern(node) {
-    return node.kind === 205 /* ObjectBindingPattern */;
+    return node.kind === 206 /* ObjectBindingPattern */;
   }
   function isArrayBindingPattern(node) {
-    return node.kind === 206 /* ArrayBindingPattern */;
+    return node.kind === 207 /* ArrayBindingPattern */;
   }
   function isBindingElement(node) {
-    return node.kind === 207 /* BindingElement */;
+    return node.kind === 208 /* BindingElement */;
   }
   function isArrayLiteralExpression(node) {
-    return node.kind === 208 /* ArrayLiteralExpression */;
+    return node.kind === 209 /* ArrayLiteralExpression */;
   }
   function isObjectLiteralExpression(node) {
-    return node.kind === 209 /* ObjectLiteralExpression */;
+    return node.kind === 210 /* ObjectLiteralExpression */;
   }
   function isPropertyAccessExpression(node) {
-    return node.kind === 210 /* PropertyAccessExpression */;
+    return node.kind === 211 /* PropertyAccessExpression */;
   }
   function isElementAccessExpression(node) {
-    return node.kind === 211 /* ElementAccessExpression */;
+    return node.kind === 212 /* ElementAccessExpression */;
   }
   function isCallExpression(node) {
-    return node.kind === 212 /* CallExpression */;
+    return node.kind === 213 /* CallExpression */;
   }
   function isNewExpression(node) {
-    return node.kind === 213 /* NewExpression */;
+    return node.kind === 214 /* NewExpression */;
   }
   function isTaggedTemplateExpression(node) {
-    return node.kind === 214 /* TaggedTemplateExpression */;
+    return node.kind === 215 /* TaggedTemplateExpression */;
   }
   function isTypeAssertionExpression(node) {
-    return node.kind === 215 /* TypeAssertionExpression */;
+    return node.kind === 216 /* TypeAssertionExpression */;
   }
   function isParenthesizedExpression(node) {
-    return node.kind === 216 /* ParenthesizedExpression */;
+    return node.kind === 217 /* ParenthesizedExpression */;
   }
   function isFunctionExpression(node) {
-    return node.kind === 217 /* FunctionExpression */;
+    return node.kind === 218 /* FunctionExpression */;
   }
   function isArrowFunction(node) {
-    return node.kind === 218 /* ArrowFunction */;
+    return node.kind === 219 /* ArrowFunction */;
   }
   function isDeleteExpression(node) {
-    return node.kind === 219 /* DeleteExpression */;
+    return node.kind === 220 /* DeleteExpression */;
   }
   function isTypeOfExpression(node) {
-    return node.kind === 220 /* TypeOfExpression */;
+    return node.kind === 221 /* TypeOfExpression */;
   }
   function isVoidExpression(node) {
-    return node.kind === 221 /* VoidExpression */;
+    return node.kind === 222 /* VoidExpression */;
   }
   function isAwaitExpression(node) {
-    return node.kind === 222 /* AwaitExpression */;
+    return node.kind === 223 /* AwaitExpression */;
   }
   function isPrefixUnaryExpression(node) {
-    return node.kind === 223 /* PrefixUnaryExpression */;
+    return node.kind === 224 /* PrefixUnaryExpression */;
   }
   function isPostfixUnaryExpression(node) {
-    return node.kind === 224 /* PostfixUnaryExpression */;
+    return node.kind === 225 /* PostfixUnaryExpression */;
   }
   function isBinaryExpression(node) {
-    return node.kind === 225 /* BinaryExpression */;
+    return node.kind === 226 /* BinaryExpression */;
   }
   function isConditionalExpression(node) {
-    return node.kind === 226 /* ConditionalExpression */;
+    return node.kind === 227 /* ConditionalExpression */;
   }
   function isTemplateExpression(node) {
-    return node.kind === 227 /* TemplateExpression */;
+    return node.kind === 228 /* TemplateExpression */;
   }
   function isYieldExpression(node) {
-    return node.kind === 228 /* YieldExpression */;
+    return node.kind === 229 /* YieldExpression */;
   }
   function isSpreadElement(node) {
-    return node.kind === 229 /* SpreadElement */;
+    return node.kind === 230 /* SpreadElement */;
   }
   function isClassExpression(node) {
-    return node.kind === 230 /* ClassExpression */;
+    return node.kind === 231 /* ClassExpression */;
   }
   function isOmittedExpression(node) {
-    return node.kind === 231 /* OmittedExpression */;
+    return node.kind === 232 /* OmittedExpression */;
   }
   function isExpressionWithTypeArguments(node) {
-    return node.kind === 232 /* ExpressionWithTypeArguments */;
+    return node.kind === 233 /* ExpressionWithTypeArguments */;
   }
   function isAsExpression(node) {
-    return node.kind === 233 /* AsExpression */;
+    return node.kind === 234 /* AsExpression */;
   }
   function isSatisfiesExpression(node) {
-    return node.kind === 237 /* SatisfiesExpression */;
+    return node.kind === 238 /* SatisfiesExpression */;
   }
   function isNonNullExpression(node) {
-    return node.kind === 234 /* NonNullExpression */;
+    return node.kind === 235 /* NonNullExpression */;
   }
   function isMetaProperty(node) {
-    return node.kind === 235 /* MetaProperty */;
+    return node.kind === 236 /* MetaProperty */;
   }
   function isSyntheticExpression(node) {
-    return node.kind === 236 /* SyntheticExpression */;
+    return node.kind === 237 /* SyntheticExpression */;
   }
   function isPartiallyEmittedExpression(node) {
-    return node.kind === 359 /* PartiallyEmittedExpression */;
+    return node.kind === 360 /* PartiallyEmittedExpression */;
   }
   function isCommaListExpression(node) {
-    return node.kind === 360 /* CommaListExpression */;
+    return node.kind === 361 /* CommaListExpression */;
   }
   function isTemplateSpan(node) {
-    return node.kind === 238 /* TemplateSpan */;
+    return node.kind === 239 /* TemplateSpan */;
   }
   function isSemicolonClassElement(node) {
-    return node.kind === 239 /* SemicolonClassElement */;
+    return node.kind === 240 /* SemicolonClassElement */;
   }
   function isBlock(node) {
-    return node.kind === 240 /* Block */;
+    return node.kind === 241 /* Block */;
   }
   function isVariableStatement(node) {
-    return node.kind === 242 /* VariableStatement */;
+    return node.kind === 243 /* VariableStatement */;
   }
   function isEmptyStatement(node) {
-    return node.kind === 241 /* EmptyStatement */;
+    return node.kind === 242 /* EmptyStatement */;
   }
   function isExpressionStatement(node) {
-    return node.kind === 243 /* ExpressionStatement */;
+    return node.kind === 244 /* ExpressionStatement */;
   }
   function isIfStatement(node) {
-    return node.kind === 244 /* IfStatement */;
+    return node.kind === 245 /* IfStatement */;
   }
   function isDoStatement(node) {
-    return node.kind === 245 /* DoStatement */;
+    return node.kind === 246 /* DoStatement */;
   }
   function isWhileStatement(node) {
-    return node.kind === 246 /* WhileStatement */;
+    return node.kind === 247 /* WhileStatement */;
   }
   function isForStatement(node) {
-    return node.kind === 247 /* ForStatement */;
+    return node.kind === 248 /* ForStatement */;
   }
   function isForInStatement(node) {
-    return node.kind === 248 /* ForInStatement */;
+    return node.kind === 249 /* ForInStatement */;
   }
   function isForOfStatement(node) {
-    return node.kind === 249 /* ForOfStatement */;
+    return node.kind === 250 /* ForOfStatement */;
   }
   function isContinueStatement(node) {
-    return node.kind === 250 /* ContinueStatement */;
+    return node.kind === 251 /* ContinueStatement */;
   }
   function isBreakStatement(node) {
-    return node.kind === 251 /* BreakStatement */;
+    return node.kind === 252 /* BreakStatement */;
   }
   function isReturnStatement(node) {
-    return node.kind === 252 /* ReturnStatement */;
+    return node.kind === 253 /* ReturnStatement */;
   }
   function isWithStatement(node) {
-    return node.kind === 253 /* WithStatement */;
+    return node.kind === 254 /* WithStatement */;
   }
   function isSwitchStatement(node) {
-    return node.kind === 254 /* SwitchStatement */;
+    return node.kind === 255 /* SwitchStatement */;
   }
   function isLabeledStatement(node) {
-    return node.kind === 255 /* LabeledStatement */;
+    return node.kind === 256 /* LabeledStatement */;
   }
   function isThrowStatement(node) {
-    return node.kind === 256 /* ThrowStatement */;
+    return node.kind === 257 /* ThrowStatement */;
   }
   function isTryStatement(node) {
-    return node.kind === 257 /* TryStatement */;
+    return node.kind === 258 /* TryStatement */;
   }
   function isDebuggerStatement(node) {
-    return node.kind === 258 /* DebuggerStatement */;
+    return node.kind === 259 /* DebuggerStatement */;
   }
   function isVariableDeclaration(node) {
-    return node.kind === 259 /* VariableDeclaration */;
+    return node.kind === 260 /* VariableDeclaration */;
   }
   function isVariableDeclarationList(node) {
-    return node.kind === 260 /* VariableDeclarationList */;
+    return node.kind === 261 /* VariableDeclarationList */;
   }
   function isFunctionDeclaration(node) {
-    return node.kind === 261 /* FunctionDeclaration */;
+    return node.kind === 262 /* FunctionDeclaration */;
   }
   function isClassDeclaration(node) {
-    return node.kind === 262 /* ClassDeclaration */;
+    return node.kind === 263 /* ClassDeclaration */;
   }
   function isInterfaceDeclaration(node) {
-    return node.kind === 263 /* InterfaceDeclaration */;
+    return node.kind === 264 /* InterfaceDeclaration */;
   }
   function isTypeAliasDeclaration(node) {
-    return node.kind === 264 /* TypeAliasDeclaration */;
+    return node.kind === 265 /* TypeAliasDeclaration */;
   }
   function isEnumDeclaration(node) {
-    return node.kind === 265 /* EnumDeclaration */;
+    return node.kind === 266 /* EnumDeclaration */;
   }
   function isModuleDeclaration(node) {
-    return node.kind === 266 /* ModuleDeclaration */;
+    return node.kind === 267 /* ModuleDeclaration */;
   }
   function isModuleBlock(node) {
-    return node.kind === 267 /* ModuleBlock */;
+    return node.kind === 268 /* ModuleBlock */;
   }
   function isCaseBlock(node) {
-    return node.kind === 268 /* CaseBlock */;
+    return node.kind === 269 /* CaseBlock */;
   }
   function isNamespaceExportDeclaration(node) {
-    return node.kind === 269 /* NamespaceExportDeclaration */;
+    return node.kind === 270 /* NamespaceExportDeclaration */;
   }
   function isImportEqualsDeclaration(node) {
-    return node.kind === 270 /* ImportEqualsDeclaration */;
+    return node.kind === 271 /* ImportEqualsDeclaration */;
   }
   function isImportDeclaration(node) {
-    return node.kind === 271 /* ImportDeclaration */;
+    return node.kind === 272 /* ImportDeclaration */;
   }
   function isImportClause(node) {
-    return node.kind === 272 /* ImportClause */;
+    return node.kind === 273 /* ImportClause */;
   }
   function isImportTypeAssertionContainer(node) {
-    return node.kind === 301 /* ImportTypeAssertionContainer */;
+    return node.kind === 302 /* ImportTypeAssertionContainer */;
   }
   function isAssertClause(node) {
-    return node.kind === 299 /* AssertClause */;
+    return node.kind === 300 /* AssertClause */;
   }
   function isAssertEntry(node) {
-    return node.kind === 300 /* AssertEntry */;
+    return node.kind === 301 /* AssertEntry */;
+  }
+  function isImportAttributes(node) {
+    return node.kind === 300 /* ImportAttributes */;
+  }
+  function isImportAttribute(node) {
+    return node.kind === 301 /* ImportAttribute */;
   }
   function isNamespaceImport(node) {
-    return node.kind === 273 /* NamespaceImport */;
+    return node.kind === 274 /* NamespaceImport */;
   }
   function isNamespaceExport(node) {
-    return node.kind === 279 /* NamespaceExport */;
+    return node.kind === 280 /* NamespaceExport */;
   }
   function isNamedImports(node) {
-    return node.kind === 274 /* NamedImports */;
+    return node.kind === 275 /* NamedImports */;
   }
   function isImportSpecifier(node) {
-    return node.kind === 275 /* ImportSpecifier */;
+    return node.kind === 276 /* ImportSpecifier */;
   }
   function isExportAssignment(node) {
-    return node.kind === 276 /* ExportAssignment */;
+    return node.kind === 277 /* ExportAssignment */;
   }
   function isExportDeclaration(node) {
-    return node.kind === 277 /* ExportDeclaration */;
+    return node.kind === 278 /* ExportDeclaration */;
   }
   function isNamedExports(node) {
-    return node.kind === 278 /* NamedExports */;
+    return node.kind === 279 /* NamedExports */;
   }
   function isExportSpecifier(node) {
-    return node.kind === 280 /* ExportSpecifier */;
+    return node.kind === 281 /* ExportSpecifier */;
   }
   function isMissingDeclaration(node) {
-    return node.kind === 281 /* MissingDeclaration */;
+    return node.kind === 282 /* MissingDeclaration */;
   }
   function isNotEmittedStatement(node) {
-    return node.kind === 358 /* NotEmittedStatement */;
+    return node.kind === 359 /* NotEmittedStatement */;
   }
   function isSyntheticReference(node) {
-    return node.kind === 361 /* SyntheticReferenceExpression */;
+    return node.kind === 362 /* SyntheticReferenceExpression */;
   }
   function isExternalModuleReference(node) {
-    return node.kind === 282 /* ExternalModuleReference */;
+    return node.kind === 283 /* ExternalModuleReference */;
   }
   function isJsxElement(node) {
-    return node.kind === 283 /* JsxElement */;
+    return node.kind === 284 /* JsxElement */;
   }
   function isJsxSelfClosingElement(node) {
-    return node.kind === 284 /* JsxSelfClosingElement */;
+    return node.kind === 285 /* JsxSelfClosingElement */;
   }
   function isJsxOpeningElement(node) {
-    return node.kind === 285 /* JsxOpeningElement */;
+    return node.kind === 286 /* JsxOpeningElement */;
   }
   function isJsxClosingElement(node) {
-    return node.kind === 286 /* JsxClosingElement */;
+    return node.kind === 287 /* JsxClosingElement */;
   }
   function isJsxFragment(node) {
-    return node.kind === 287 /* JsxFragment */;
+    return node.kind === 288 /* JsxFragment */;
   }
   function isJsxOpeningFragment(node) {
-    return node.kind === 288 /* JsxOpeningFragment */;
+    return node.kind === 289 /* JsxOpeningFragment */;
   }
   function isJsxClosingFragment(node) {
-    return node.kind === 289 /* JsxClosingFragment */;
+    return node.kind === 290 /* JsxClosingFragment */;
   }
   function isJsxAttribute(node) {
-    return node.kind === 290 /* JsxAttribute */;
+    return node.kind === 291 /* JsxAttribute */;
   }
   function isJsxAttributes(node) {
-    return node.kind === 291 /* JsxAttributes */;
+    return node.kind === 292 /* JsxAttributes */;
   }
   function isJsxSpreadAttribute(node) {
-    return node.kind === 292 /* JsxSpreadAttribute */;
+    return node.kind === 293 /* JsxSpreadAttribute */;
   }
   function isJsxExpression(node) {
-    return node.kind === 293 /* JsxExpression */;
+    return node.kind === 294 /* JsxExpression */;
   }
   function isJsxNamespacedName(node) {
-    return node.kind === 294 /* JsxNamespacedName */;
+    return node.kind === 295 /* JsxNamespacedName */;
   }
   function isCaseClause(node) {
-    return node.kind === 295 /* CaseClause */;
+    return node.kind === 296 /* CaseClause */;
   }
   function isDefaultClause(node) {
-    return node.kind === 296 /* DefaultClause */;
+    return node.kind === 297 /* DefaultClause */;
   }
   function isHeritageClause(node) {
-    return node.kind === 297 /* HeritageClause */;
+    return node.kind === 298 /* HeritageClause */;
   }
   function isCatchClause(node) {
-    return node.kind === 298 /* CatchClause */;
+    return node.kind === 299 /* CatchClause */;
   }
   function isPropertyAssignment(node) {
-    return node.kind === 302 /* PropertyAssignment */;
+    return node.kind === 303 /* PropertyAssignment */;
   }
   function isShorthandPropertyAssignment(node) {
-    return node.kind === 303 /* ShorthandPropertyAssignment */;
+    return node.kind === 304 /* ShorthandPropertyAssignment */;
   }
   function isSpreadAssignment(node) {
-    return node.kind === 304 /* SpreadAssignment */;
+    return node.kind === 305 /* SpreadAssignment */;
   }
   function isEnumMember(node) {
-    return node.kind === 305 /* EnumMember */;
+    return node.kind === 306 /* EnumMember */;
   }
   function isUnparsedPrepend(node) {
-    return node.kind === 307 /* UnparsedPrepend */;
+    return node.kind === 308 /* UnparsedPrepend */;
   }
   function isSourceFile(node) {
-    return node.kind === 311 /* SourceFile */;
+    return node.kind === 312 /* SourceFile */;
   }
   function isBundle(node) {
-    return node.kind === 312 /* Bundle */;
+    return node.kind === 313 /* Bundle */;
   }
   function isUnparsedSource(node) {
-    return node.kind === 313 /* UnparsedSource */;
+    return node.kind === 314 /* UnparsedSource */;
   }
   function isJSDocTypeExpression(node) {
-    return node.kind === 315 /* JSDocTypeExpression */;
+    return node.kind === 316 /* JSDocTypeExpression */;
   }
   function isJSDocNameReference(node) {
-    return node.kind === 316 /* JSDocNameReference */;
+    return node.kind === 317 /* JSDocNameReference */;
   }
   function isJSDocMemberName(node) {
-    return node.kind === 317 /* JSDocMemberName */;
+    return node.kind === 318 /* JSDocMemberName */;
   }
   function isJSDocLink(node) {
-    return node.kind === 330 /* JSDocLink */;
+    return node.kind === 331 /* JSDocLink */;
   }
   function isJSDocLinkCode(node) {
-    return node.kind === 331 /* JSDocLinkCode */;
+    return node.kind === 332 /* JSDocLinkCode */;
   }
   function isJSDocLinkPlain(node) {
-    return node.kind === 332 /* JSDocLinkPlain */;
+    return node.kind === 333 /* JSDocLinkPlain */;
   }
   function isJSDocAllType(node) {
-    return node.kind === 318 /* JSDocAllType */;
+    return node.kind === 319 /* JSDocAllType */;
   }
   function isJSDocUnknownType(node) {
-    return node.kind === 319 /* JSDocUnknownType */;
+    return node.kind === 320 /* JSDocUnknownType */;
   }
   function isJSDocNullableType(node) {
-    return node.kind === 320 /* JSDocNullableType */;
+    return node.kind === 321 /* JSDocNullableType */;
   }
   function isJSDocNonNullableType(node) {
-    return node.kind === 321 /* JSDocNonNullableType */;
+    return node.kind === 322 /* JSDocNonNullableType */;
   }
   function isJSDocOptionalType(node) {
-    return node.kind === 322 /* JSDocOptionalType */;
+    return node.kind === 323 /* JSDocOptionalType */;
   }
   function isJSDocFunctionType(node) {
-    return node.kind === 323 /* JSDocFunctionType */;
+    return node.kind === 324 /* JSDocFunctionType */;
   }
   function isJSDocVariadicType(node) {
-    return node.kind === 324 /* JSDocVariadicType */;
+    return node.kind === 325 /* JSDocVariadicType */;
   }
   function isJSDocNamepathType(node) {
-    return node.kind === 325 /* JSDocNamepathType */;
+    return node.kind === 326 /* JSDocNamepathType */;
   }
   function isJSDoc(node) {
-    return node.kind === 326 /* JSDoc */;
+    return node.kind === 327 /* JSDoc */;
   }
   function isJSDocTypeLiteral(node) {
-    return node.kind === 328 /* JSDocTypeLiteral */;
+    return node.kind === 329 /* JSDocTypeLiteral */;
   }
   function isJSDocSignature(node) {
-    return node.kind === 329 /* JSDocSignature */;
+    return node.kind === 330 /* JSDocSignature */;
   }
   function isJSDocAugmentsTag(node) {
-    return node.kind === 334 /* JSDocAugmentsTag */;
+    return node.kind === 335 /* JSDocAugmentsTag */;
   }
   function isJSDocAuthorTag(node) {
-    return node.kind === 336 /* JSDocAuthorTag */;
+    return node.kind === 337 /* JSDocAuthorTag */;
   }
   function isJSDocClassTag(node) {
-    return node.kind === 338 /* JSDocClassTag */;
+    return node.kind === 339 /* JSDocClassTag */;
   }
   function isJSDocCallbackTag(node) {
-    return node.kind === 344 /* JSDocCallbackTag */;
+    return node.kind === 345 /* JSDocCallbackTag */;
   }
   function isJSDocPublicTag(node) {
-    return node.kind === 339 /* JSDocPublicTag */;
+    return node.kind === 340 /* JSDocPublicTag */;
   }
   function isJSDocPrivateTag(node) {
-    return node.kind === 340 /* JSDocPrivateTag */;
+    return node.kind === 341 /* JSDocPrivateTag */;
   }
   function isJSDocProtectedTag(node) {
-    return node.kind === 341 /* JSDocProtectedTag */;
+    return node.kind === 342 /* JSDocProtectedTag */;
   }
   function isJSDocReadonlyTag(node) {
-    return node.kind === 342 /* JSDocReadonlyTag */;
+    return node.kind === 343 /* JSDocReadonlyTag */;
   }
   function isJSDocOverrideTag(node) {
-    return node.kind === 343 /* JSDocOverrideTag */;
+    return node.kind === 344 /* JSDocOverrideTag */;
   }
   function isJSDocOverloadTag(node) {
-    return node.kind === 345 /* JSDocOverloadTag */;
+    return node.kind === 346 /* JSDocOverloadTag */;
   }
   function isJSDocDeprecatedTag(node) {
-    return node.kind === 337 /* JSDocDeprecatedTag */;
+    return node.kind === 338 /* JSDocDeprecatedTag */;
   }
   function isJSDocSeeTag(node) {
-    return node.kind === 353 /* JSDocSeeTag */;
+    return node.kind === 354 /* JSDocSeeTag */;
   }
   function isJSDocEnumTag(node) {
-    return node.kind === 346 /* JSDocEnumTag */;
+    return node.kind === 347 /* JSDocEnumTag */;
   }
   function isJSDocParameterTag(node) {
-    return node.kind === 347 /* JSDocParameterTag */;
+    return node.kind === 348 /* JSDocParameterTag */;
   }
   function isJSDocReturnTag(node) {
-    return node.kind === 348 /* JSDocReturnTag */;
+    return node.kind === 349 /* JSDocReturnTag */;
   }
   function isJSDocThisTag(node) {
-    return node.kind === 349 /* JSDocThisTag */;
+    return node.kind === 350 /* JSDocThisTag */;
   }
   function isJSDocTypeTag(node) {
-    return node.kind === 350 /* JSDocTypeTag */;
+    return node.kind === 351 /* JSDocTypeTag */;
   }
   function isJSDocTemplateTag(node) {
-    return node.kind === 351 /* JSDocTemplateTag */;
+    return node.kind === 352 /* JSDocTemplateTag */;
   }
   function isJSDocTypedefTag(node) {
-    return node.kind === 352 /* JSDocTypedefTag */;
+    return node.kind === 353 /* JSDocTypedefTag */;
   }
   function isJSDocUnknownTag(node) {
-    return node.kind === 333 /* JSDocTag */;
+    return node.kind === 334 /* JSDocTag */;
   }
   function isJSDocPropertyTag(node) {
-    return node.kind === 354 /* JSDocPropertyTag */;
+    return node.kind === 355 /* JSDocPropertyTag */;
   }
   function isJSDocImplementsTag(node) {
-    return node.kind === 335 /* JSDocImplementsTag */;
+    return node.kind === 336 /* JSDocImplementsTag */;
   }
   function isJSDocSatisfiesTag(node) {
-    return node.kind === 356 /* JSDocSatisfiesTag */;
+    return node.kind === 357 /* JSDocSatisfiesTag */;
   }
   function isJSDocThrowsTag(node) {
-    return node.kind === 355 /* JSDocThrowsTag */;
+    return node.kind === 356 /* JSDocThrowsTag */;
   }
   function isSyntaxList(n) {
-    return n.kind === 357 /* SyntaxList */;
+    return n.kind === 358 /* SyntaxList */;
   }
   var init_nodeTests = __esm({
     "src/compiler/factory/nodeTests.ts"() {
@@ -126249,14 +109236,14 @@ ${lanes.join("\n")}
       Debug.failBadSyntaxKind(property.name, "Private identifiers are not allowed in object literals.");
     }
     switch (property.kind) {
-      case 176 /* GetAccessor */:
-      case 177 /* SetAccessor */:
+      case 177 /* GetAccessor */:
+      case 178 /* SetAccessor */:
         return createExpressionForAccessorDeclaration(factory2, node.properties, property, receiver, !!node.multiLine);
-      case 302 /* PropertyAssignment */:
+      case 303 /* PropertyAssignment */:
         return createExpressionForPropertyAssignment(factory2, property, receiver);
-      case 303 /* ShorthandPropertyAssignment */:
+      case 304 /* ShorthandPropertyAssignment */:
         return createExpressionForShorthandPropertyAssignment(factory2, property, receiver);
-      case 173 /* MethodDeclaration */:
+      case 174 /* MethodDeclaration */:
         return createExpressionForMethodDeclaration(factory2, property, receiver);
     }
   }
@@ -126309,7 +109296,7 @@ ${lanes.join("\n")}
     return firstStatement !== void 0 && isPrologueDirective(firstStatement) && isUseStrictPrologue(firstStatement);
   }
   function isCommaExpression(node) {
-    return node.kind === 225 /* BinaryExpression */ && node.operatorToken.kind === 28 /* CommaToken */;
+    return node.kind === 226 /* BinaryExpression */ && node.operatorToken.kind === 28 /* CommaToken */;
   }
   function isCommaSequence(node) {
     return isCommaExpression(node) || isCommaListExpression(node);
@@ -126324,19 +109311,19 @@ ${lanes.join("\n")}
   }
   function isOuterExpression(node, kinds = 15 /* All */) {
     switch (node.kind) {
-      case 216 /* ParenthesizedExpression */:
+      case 217 /* ParenthesizedExpression */:
         if (kinds & 16 /* ExcludeJSDocTypeAssertion */ && isJSDocTypeAssertion(node)) {
           return false;
         }
         return (kinds & 1 /* Parentheses */) !== 0;
-      case 215 /* TypeAssertionExpression */:
-      case 233 /* AsExpression */:
-      case 232 /* ExpressionWithTypeArguments */:
-      case 237 /* SatisfiesExpression */:
+      case 216 /* TypeAssertionExpression */:
+      case 234 /* AsExpression */:
+      case 233 /* ExpressionWithTypeArguments */:
+      case 238 /* SatisfiesExpression */:
         return (kinds & 2 /* TypeAssertions */) !== 0;
-      case 234 /* NonNullExpression */:
+      case 235 /* NonNullExpression */:
         return (kinds & 4 /* NonNullAssertions */) !== 0;
-      case 359 /* PartiallyEmittedExpression */:
+      case 360 /* PartiallyEmittedExpression */:
         return (kinds & 8 /* PartiallyEmittedExpressions */) !== 0;
     }
     return false;
@@ -126394,21 +109381,18 @@ ${lanes.join("\n")}
           if (some(helperNames)) {
             helperNames.sort(compareStringsCaseSensitive);
             namedBindings = nodeFactory.createNamedImports(
-              map(
-                helperNames,
-                (name) => isFileLevelUniqueName(sourceFile, name) ? nodeFactory.createImportSpecifier(
-                  /*isTypeOnly*/
-                  false,
-                  /*propertyName*/
-                  void 0,
-                  nodeFactory.createIdentifier(name)
-                ) : nodeFactory.createImportSpecifier(
-                  /*isTypeOnly*/
-                  false,
-                  nodeFactory.createIdentifier(name),
-                  helperFactory.getUnscopedHelperName(name)
-                )
-              )
+              map(helperNames, (name) => isFileLevelUniqueName(sourceFile, name) ? nodeFactory.createImportSpecifier(
+                /*isTypeOnly*/
+                false,
+                /*propertyName*/
+                void 0,
+                nodeFactory.createIdentifier(name)
+              ) : nodeFactory.createImportSpecifier(
+                /*isTypeOnly*/
+                false,
+                nodeFactory.createIdentifier(name),
+                helperFactory.getUnscopedHelperName(name)
+              ))
             );
             const parseNode = getOriginalNode(sourceFile, isSourceFile);
             const emitNode = getOrCreateEmitNode(parseNode);
@@ -126433,7 +109417,7 @@ ${lanes.join("\n")}
             namedBindings
           ),
           nodeFactory.createStringLiteral(externalHelpersModuleNameText),
-          /*assertClause*/
+          /*attributes*/
           void 0
         );
         addInternalEmitFlags(externalHelpersImportDeclaration, 2 /* NeverApplyImportHelper */);
@@ -126473,10 +109457,10 @@ ${lanes.join("\n")}
       const name = namespaceDeclaration.name;
       return isGeneratedIdentifier(name) ? name : factory2.createIdentifier(getSourceTextOfNodeFromSourceFile(sourceFile, name) || idText(name));
     }
-    if (node.kind === 271 /* ImportDeclaration */ && node.importClause) {
+    if (node.kind === 272 /* ImportDeclaration */ && node.importClause) {
       return factory2.getGeneratedNameForNode(node);
     }
-    if (node.kind === 277 /* ExportDeclaration */ && node.moduleSpecifier) {
+    if (node.kind === 278 /* ExportDeclaration */ && node.moduleSpecifier) {
       return factory2.getGeneratedNameForNode(node);
     }
     return void 0;
@@ -126539,11 +109523,11 @@ ${lanes.join("\n")}
     }
     if (isObjectLiteralElementLike(bindingElement)) {
       switch (bindingElement.kind) {
-        case 302 /* PropertyAssignment */:
+        case 303 /* PropertyAssignment */:
           return getTargetOfBindingOrAssignmentElement(bindingElement.initializer);
-        case 303 /* ShorthandPropertyAssignment */:
+        case 304 /* ShorthandPropertyAssignment */:
           return bindingElement.name;
-        case 304 /* SpreadAssignment */:
+        case 305 /* SpreadAssignment */:
           return getTargetOfBindingOrAssignmentElement(bindingElement.expression);
       }
       return void 0;
@@ -126562,11 +109546,11 @@ ${lanes.join("\n")}
   }
   function getRestIndicatorOfBindingOrAssignmentElement(bindingElement) {
     switch (bindingElement.kind) {
-      case 168 /* Parameter */:
-      case 207 /* BindingElement */:
+      case 169 /* Parameter */:
+      case 208 /* BindingElement */:
         return bindingElement.dotDotDotToken;
-      case 229 /* SpreadElement */:
-      case 304 /* SpreadAssignment */:
+      case 230 /* SpreadElement */:
+      case 305 /* SpreadAssignment */:
         return bindingElement;
     }
     return void 0;
@@ -126578,7 +109562,7 @@ ${lanes.join("\n")}
   }
   function tryGetPropertyNameOfBindingOrAssignmentElement(bindingElement) {
     switch (bindingElement.kind) {
-      case 207 /* BindingElement */:
+      case 208 /* BindingElement */:
         if (bindingElement.propertyName) {
           const propertyName = bindingElement.propertyName;
           if (isPrivateIdentifier(propertyName)) {
@@ -126587,7 +109571,7 @@ ${lanes.join("\n")}
           return isComputedPropertyName(propertyName) && isStringOrNumericLiteral(propertyName.expression) ? propertyName.expression : propertyName;
         }
         break;
-      case 302 /* PropertyAssignment */:
+      case 303 /* PropertyAssignment */:
         if (bindingElement.name) {
           const propertyName = bindingElement.name;
           if (isPrivateIdentifier(propertyName)) {
@@ -126596,7 +109580,7 @@ ${lanes.join("\n")}
           return isComputedPropertyName(propertyName) && isStringOrNumericLiteral(propertyName.expression) ? propertyName.expression : propertyName;
         }
         break;
-      case 304 /* SpreadAssignment */:
+      case 305 /* SpreadAssignment */:
         if (bindingElement.name && isPrivateIdentifier(bindingElement.name)) {
           return Debug.failBadSyntaxKind(bindingElement.name);
         }
@@ -126613,11 +109597,11 @@ ${lanes.join("\n")}
   }
   function getElementsOfBindingOrAssignmentPattern(name) {
     switch (name.kind) {
-      case 205 /* ObjectBindingPattern */:
-      case 206 /* ArrayBindingPattern */:
-      case 208 /* ArrayLiteralExpression */:
+      case 206 /* ObjectBindingPattern */:
+      case 207 /* ArrayBindingPattern */:
+      case 209 /* ArrayLiteralExpression */:
         return name.elements;
-      case 209 /* ObjectLiteralExpression */:
+      case 210 /* ObjectLiteralExpression */:
         return name.properties;
     }
   }
@@ -126634,19 +109618,19 @@ ${lanes.join("\n")}
   }
   function canHaveIllegalType(node) {
     const kind = node.kind;
-    return kind === 175 /* Constructor */ || kind === 177 /* SetAccessor */;
+    return kind === 176 /* Constructor */ || kind === 178 /* SetAccessor */;
   }
   function canHaveIllegalTypeParameters(node) {
     const kind = node.kind;
-    return kind === 175 /* Constructor */ || kind === 176 /* GetAccessor */ || kind === 177 /* SetAccessor */;
+    return kind === 176 /* Constructor */ || kind === 177 /* GetAccessor */ || kind === 178 /* SetAccessor */;
   }
   function canHaveIllegalDecorators(node) {
     const kind = node.kind;
-    return kind === 302 /* PropertyAssignment */ || kind === 303 /* ShorthandPropertyAssignment */ || kind === 261 /* FunctionDeclaration */ || kind === 175 /* Constructor */ || kind === 180 /* IndexSignature */ || kind === 174 /* ClassStaticBlockDeclaration */ || kind === 281 /* MissingDeclaration */ || kind === 242 /* VariableStatement */ || kind === 263 /* InterfaceDeclaration */ || kind === 264 /* TypeAliasDeclaration */ || kind === 265 /* EnumDeclaration */ || kind === 266 /* ModuleDeclaration */ || kind === 270 /* ImportEqualsDeclaration */ || kind === 271 /* ImportDeclaration */ || kind === 269 /* NamespaceExportDeclaration */ || kind === 277 /* ExportDeclaration */ || kind === 276 /* ExportAssignment */;
+    return kind === 303 /* PropertyAssignment */ || kind === 304 /* ShorthandPropertyAssignment */ || kind === 262 /* FunctionDeclaration */ || kind === 176 /* Constructor */ || kind === 181 /* IndexSignature */ || kind === 175 /* ClassStaticBlockDeclaration */ || kind === 282 /* MissingDeclaration */ || kind === 243 /* VariableStatement */ || kind === 264 /* InterfaceDeclaration */ || kind === 265 /* TypeAliasDeclaration */ || kind === 266 /* EnumDeclaration */ || kind === 267 /* ModuleDeclaration */ || kind === 271 /* ImportEqualsDeclaration */ || kind === 272 /* ImportDeclaration */ || kind === 270 /* NamespaceExportDeclaration */ || kind === 278 /* ExportDeclaration */ || kind === 277 /* ExportAssignment */;
   }
   function canHaveIllegalModifiers(node) {
     const kind = node.kind;
-    return kind === 174 /* ClassStaticBlockDeclaration */ || kind === 302 /* PropertyAssignment */ || kind === 303 /* ShorthandPropertyAssignment */ || kind === 281 /* MissingDeclaration */ || kind === 269 /* NamespaceExportDeclaration */;
+    return kind === 175 /* ClassStaticBlockDeclaration */ || kind === 303 /* PropertyAssignment */ || kind === 304 /* ShorthandPropertyAssignment */ || kind === 282 /* MissingDeclaration */ || kind === 270 /* NamespaceExportDeclaration */;
   }
   function isQuestionOrExclamationToken(node) {
     return isQuestionToken(node) || isExclamationToken(node);
@@ -126813,7 +109797,7 @@ ${lanes.join("\n")}
       initializer
     );
   }
-  function createAccessorPropertyGetRedirector(factory2, node, modifiers, name) {
+  function createAccessorPropertyGetRedirector(factory2, node, modifiers, name, receiver = factory2.createThis()) {
     return factory2.createGetAccessorDeclaration(
       modifiers,
       name,
@@ -126823,7 +109807,7 @@ ${lanes.join("\n")}
       factory2.createBlock([
         factory2.createReturnStatement(
           factory2.createPropertyAccessExpression(
-            factory2.createThis(),
+            receiver,
             factory2.getGeneratedPrivateNameForNode(
               node.name,
               /*prefix*/
@@ -126835,7 +109819,7 @@ ${lanes.join("\n")}
       ])
     );
   }
-  function createAccessorPropertySetRedirector(factory2, node, modifiers, name) {
+  function createAccessorPropertySetRedirector(factory2, node, modifiers, name, receiver = factory2.createThis()) {
     return factory2.createSetAccessorDeclaration(
       modifiers,
       name,
@@ -126850,7 +109834,7 @@ ${lanes.join("\n")}
         factory2.createExpressionStatement(
           factory2.createAssignment(
             factory2.createPropertyAccessExpression(
-              factory2.createThis(),
+              receiver,
               factory2.getGeneratedPrivateNameForNode(
                 node.name,
                 /*prefix*/
@@ -127051,11 +110035,11 @@ ${lanes.join("\n")}
   }
   function canHaveModifiers(node) {
     const kind = node.kind;
-    return kind === 167 /* TypeParameter */ || kind === 168 /* Parameter */ || kind === 170 /* PropertySignature */ || kind === 171 /* PropertyDeclaration */ || kind === 172 /* MethodSignature */ || kind === 173 /* MethodDeclaration */ || kind === 175 /* Constructor */ || kind === 176 /* GetAccessor */ || kind === 177 /* SetAccessor */ || kind === 180 /* IndexSignature */ || kind === 184 /* ConstructorType */ || kind === 217 /* FunctionExpression */ || kind === 218 /* ArrowFunction */ || kind === 230 /* ClassExpression */ || kind === 242 /* VariableStatement */ || kind === 261 /* FunctionDeclaration */ || kind === 262 /* ClassDeclaration */ || kind === 263 /* InterfaceDeclaration */ || kind === 264 /* TypeAliasDeclaration */ || kind === 265 /* EnumDeclaration */ || kind === 266 /* ModuleDeclaration */ || kind === 270 /* ImportEqualsDeclaration */ || kind === 271 /* ImportDeclaration */ || kind === 276 /* ExportAssignment */ || kind === 277 /* ExportDeclaration */;
+    return kind === 168 /* TypeParameter */ || kind === 169 /* Parameter */ || kind === 171 /* PropertySignature */ || kind === 172 /* PropertyDeclaration */ || kind === 173 /* MethodSignature */ || kind === 174 /* MethodDeclaration */ || kind === 176 /* Constructor */ || kind === 177 /* GetAccessor */ || kind === 178 /* SetAccessor */ || kind === 181 /* IndexSignature */ || kind === 185 /* ConstructorType */ || kind === 218 /* FunctionExpression */ || kind === 219 /* ArrowFunction */ || kind === 231 /* ClassExpression */ || kind === 243 /* VariableStatement */ || kind === 262 /* FunctionDeclaration */ || kind === 263 /* ClassDeclaration */ || kind === 264 /* InterfaceDeclaration */ || kind === 265 /* TypeAliasDeclaration */ || kind === 266 /* EnumDeclaration */ || kind === 267 /* ModuleDeclaration */ || kind === 271 /* ImportEqualsDeclaration */ || kind === 272 /* ImportDeclaration */ || kind === 277 /* ExportAssignment */ || kind === 278 /* ExportDeclaration */;
   }
   function canHaveDecorators(node) {
     const kind = node.kind;
-    return kind === 168 /* Parameter */ || kind === 171 /* PropertyDeclaration */ || kind === 173 /* MethodDeclaration */ || kind === 176 /* GetAccessor */ || kind === 177 /* SetAccessor */ || kind === 230 /* ClassExpression */ || kind === 262 /* ClassDeclaration */;
+    return kind === 169 /* Parameter */ || kind === 172 /* PropertyDeclaration */ || kind === 174 /* MethodDeclaration */ || kind === 177 /* GetAccessor */ || kind === 178 /* SetAccessor */ || kind === 231 /* ClassExpression */ || kind === 263 /* ClassDeclaration */;
   }
   var init_utilitiesPublic2 = __esm({
     "src/compiler/factory/utilitiesPublic.ts"() {
@@ -127091,7 +110075,7 @@ ${lanes.join("\n")}
     return canHaveModifiers(node) && hasModifierOfKind(node, 95 /* ExportKeyword */) || isImportEqualsDeclaration(node) && isExternalModuleReference(node.moduleReference) || isImportDeclaration(node) || isExportAssignment(node) || isExportDeclaration(node) ? node : void 0;
   }
   function getImportMetaIfNecessary(sourceFile) {
-    return sourceFile.flags & 4194304 /* PossiblyContainsImportMeta */ ? walkTreeForImportMeta(sourceFile) : void 0;
+    return sourceFile.flags & 8388608 /* PossiblyContainsImportMeta */ ? walkTreeForImportMeta(sourceFile) : void 0;
   }
   function walkTreeForImportMeta(node) {
     return isImportMeta2(node) ? node : forEachChild(node, walkTreeForImportMeta);
@@ -127155,7 +110139,7 @@ ${lanes.join("\n")}
     return visitNode2(cbNode, node.expression);
   }
   function forEachChild(node, cbNode, cbNodes) {
-    if (node === void 0 || node.kind <= 164 /* LastToken */) {
+    if (node === void 0 || node.kind <= 165 /* LastToken */) {
       return;
     }
     const fn = forEachChildTable[node.kind];
@@ -127190,7 +110174,7 @@ ${lanes.join("\n")}
             continue;
           return res;
         }
-        if (current.kind >= 165 /* FirstNode */) {
+        if (current.kind >= 166 /* FirstNode */) {
           for (const child of gatherPossibleChildren(current)) {
             queue.push(child);
             parents.push(current);
@@ -127225,7 +110209,8 @@ ${lanes.join("\n")}
     const {
       languageVersion,
       setExternalModuleIndicator: overrideSetExternalModuleIndicator,
-      impliedNodeFormat: format
+      impliedNodeFormat: format,
+      jsDocParsingMode
     } = typeof languageVersionOrOptions === "object" ? languageVersionOrOptions : { languageVersion: languageVersionOrOptions };
     if (languageVersion === 100 /* JSON */) {
       result = Parser.parseSourceFile(
@@ -127236,7 +110221,8 @@ ${lanes.join("\n")}
         void 0,
         setParentNodes,
         6 /* JSON */,
-        noop
+        noop,
+        jsDocParsingMode
       );
     } else {
       const setIndicator = format === void 0 ? overrideSetExternalModuleIndicator : (file) => {
@@ -127251,7 +110237,8 @@ ${lanes.join("\n")}
         void 0,
         setParentNodes,
         scriptKind,
-        setIndicator
+        setIndicator,
+        jsDocParsingMode
       );
     }
     (_c = perfLogger) == null ? void 0 : _c.logStopParseSourceFile();
@@ -127271,7 +110258,7 @@ ${lanes.join("\n")}
   }
   function updateSourceFile(sourceFile, newText, textChangeRange, aggressiveChecks = false) {
     const newSourceFile = IncrementalParser.updateSourceFile(sourceFile, newText, textChangeRange, aggressiveChecks);
-    newSourceFile.flags |= sourceFile.flags & 6291456 /* PermanentlySetIncrementalFlags */;
+    newSourceFile.flags |= sourceFile.flags & 12582912 /* PermanentlySetIncrementalFlags */;
     return newSourceFile;
   }
   function parseIsolatedJSDocComment(content, start, length2) {
@@ -127285,7 +110272,7 @@ ${lanes.join("\n")}
     return Parser.JSDocParser.parseJSDocTypeExpressionForTests(content, start, length2);
   }
   function isDeclarationFileName(fileName) {
-    return fileExtensionIsOneOf(fileName, supportedDeclarationExtensions) || fileExtensionIs(fileName, ".ts" /* Ts */) && stringContains(getBaseFileName(fileName), ".d.");
+    return fileExtensionIsOneOf(fileName, supportedDeclarationExtensions) || fileExtensionIs(fileName, ".ts" /* Ts */) && getBaseFileName(fileName).includes(".d.");
   }
   function parseResolutionMode(mode, pos, end, reportDiagnostic) {
     if (!mode) {
@@ -127468,7 +110455,7 @@ ${lanes.join("\n")}
       return {};
     if (!pragma.args)
       return {};
-    const args = trimString(text).split(/\s+/);
+    const args = text.trim().split(/\s+/);
     const argMap = {};
     for (let i = 0; i < pragma.args.length; i++) {
       const argument = pragma.args[i];
@@ -127492,7 +110479,7 @@ ${lanes.join("\n")}
     if (lhs.kind === 110 /* ThisKeyword */) {
       return true;
     }
-    if (lhs.kind === 294 /* JsxNamespacedName */) {
+    if (lhs.kind === 295 /* JsxNamespacedName */) {
       return lhs.namespace.escapedText === rhs.namespace.escapedText && lhs.name.escapedText === rhs.name.escapedText;
     }
     return lhs.name.escapedText === rhs.name.escapedText && tagNamesAreEquivalent(lhs.expression, rhs.expression);
@@ -127512,428 +110499,428 @@ ${lanes.join("\n")}
       };
       parseNodeFactory = createNodeFactory(1 /* NoParenthesizerRules */, parseBaseNodeFactory);
       forEachChildTable = {
-        [165 /* QualifiedName */]: function forEachChildInQualifiedName(node, cbNode, _cbNodes) {
+        [166 /* QualifiedName */]: function forEachChildInQualifiedName(node, cbNode, _cbNodes) {
           return visitNode2(cbNode, node.left) || visitNode2(cbNode, node.right);
         },
-        [167 /* TypeParameter */]: function forEachChildInTypeParameter(node, cbNode, cbNodes) {
+        [168 /* TypeParameter */]: function forEachChildInTypeParameter(node, cbNode, cbNodes) {
           return visitNodes(cbNode, cbNodes, node.modifiers) || visitNode2(cbNode, node.name) || visitNode2(cbNode, node.constraint) || visitNode2(cbNode, node.default) || visitNode2(cbNode, node.expression);
         },
-        [303 /* ShorthandPropertyAssignment */]: function forEachChildInShorthandPropertyAssignment(node, cbNode, cbNodes) {
+        [304 /* ShorthandPropertyAssignment */]: function forEachChildInShorthandPropertyAssignment(node, cbNode, cbNodes) {
           return visitNodes(cbNode, cbNodes, node.modifiers) || visitNode2(cbNode, node.name) || visitNode2(cbNode, node.questionToken) || visitNode2(cbNode, node.exclamationToken) || visitNode2(cbNode, node.equalsToken) || visitNode2(cbNode, node.objectAssignmentInitializer);
         },
-        [304 /* SpreadAssignment */]: function forEachChildInSpreadAssignment(node, cbNode, _cbNodes) {
+        [305 /* SpreadAssignment */]: function forEachChildInSpreadAssignment(node, cbNode, _cbNodes) {
           return visitNode2(cbNode, node.expression);
         },
-        [168 /* Parameter */]: function forEachChildInParameter(node, cbNode, cbNodes) {
+        [169 /* Parameter */]: function forEachChildInParameter(node, cbNode, cbNodes) {
           return visitNodes(cbNode, cbNodes, node.modifiers) || visitNode2(cbNode, node.dotDotDotToken) || visitNode2(cbNode, node.name) || visitNode2(cbNode, node.questionToken) || visitNode2(cbNode, node.type) || visitNode2(cbNode, node.initializer);
         },
-        [171 /* PropertyDeclaration */]: function forEachChildInPropertyDeclaration(node, cbNode, cbNodes) {
+        [172 /* PropertyDeclaration */]: function forEachChildInPropertyDeclaration(node, cbNode, cbNodes) {
           return visitNodes(cbNode, cbNodes, node.modifiers) || visitNode2(cbNode, node.name) || visitNode2(cbNode, node.questionToken) || visitNode2(cbNode, node.exclamationToken) || visitNode2(cbNode, node.type) || visitNode2(cbNode, node.initializer);
         },
-        [170 /* PropertySignature */]: function forEachChildInPropertySignature(node, cbNode, cbNodes) {
+        [171 /* PropertySignature */]: function forEachChildInPropertySignature(node, cbNode, cbNodes) {
           return visitNodes(cbNode, cbNodes, node.modifiers) || visitNode2(cbNode, node.name) || visitNode2(cbNode, node.questionToken) || visitNode2(cbNode, node.type) || visitNode2(cbNode, node.initializer);
         },
-        [302 /* PropertyAssignment */]: function forEachChildInPropertyAssignment(node, cbNode, cbNodes) {
+        [303 /* PropertyAssignment */]: function forEachChildInPropertyAssignment(node, cbNode, cbNodes) {
           return visitNodes(cbNode, cbNodes, node.modifiers) || visitNode2(cbNode, node.name) || visitNode2(cbNode, node.questionToken) || visitNode2(cbNode, node.exclamationToken) || visitNode2(cbNode, node.initializer);
         },
-        [259 /* VariableDeclaration */]: function forEachChildInVariableDeclaration(node, cbNode, _cbNodes) {
+        [260 /* VariableDeclaration */]: function forEachChildInVariableDeclaration(node, cbNode, _cbNodes) {
           return visitNode2(cbNode, node.name) || visitNode2(cbNode, node.exclamationToken) || visitNode2(cbNode, node.type) || visitNode2(cbNode, node.initializer);
         },
-        [207 /* BindingElement */]: function forEachChildInBindingElement(node, cbNode, _cbNodes) {
+        [208 /* BindingElement */]: function forEachChildInBindingElement(node, cbNode, _cbNodes) {
           return visitNode2(cbNode, node.dotDotDotToken) || visitNode2(cbNode, node.propertyName) || visitNode2(cbNode, node.name) || visitNode2(cbNode, node.initializer);
         },
-        [180 /* IndexSignature */]: function forEachChildInIndexSignature(node, cbNode, cbNodes) {
+        [181 /* IndexSignature */]: function forEachChildInIndexSignature(node, cbNode, cbNodes) {
           return visitNodes(cbNode, cbNodes, node.modifiers) || visitNodes(cbNode, cbNodes, node.typeParameters) || visitNodes(cbNode, cbNodes, node.parameters) || visitNode2(cbNode, node.type);
         },
-        [184 /* ConstructorType */]: function forEachChildInConstructorType(node, cbNode, cbNodes) {
+        [185 /* ConstructorType */]: function forEachChildInConstructorType(node, cbNode, cbNodes) {
           return visitNodes(cbNode, cbNodes, node.modifiers) || visitNodes(cbNode, cbNodes, node.typeParameters) || visitNodes(cbNode, cbNodes, node.parameters) || visitNode2(cbNode, node.type);
         },
-        [183 /* FunctionType */]: function forEachChildInFunctionType(node, cbNode, cbNodes) {
+        [184 /* FunctionType */]: function forEachChildInFunctionType(node, cbNode, cbNodes) {
           return visitNodes(cbNode, cbNodes, node.modifiers) || visitNodes(cbNode, cbNodes, node.typeParameters) || visitNodes(cbNode, cbNodes, node.parameters) || visitNode2(cbNode, node.type);
         },
-        [178 /* CallSignature */]: forEachChildInCallOrConstructSignature,
-        [179 /* ConstructSignature */]: forEachChildInCallOrConstructSignature,
-        [173 /* MethodDeclaration */]: function forEachChildInMethodDeclaration(node, cbNode, cbNodes) {
+        [179 /* CallSignature */]: forEachChildInCallOrConstructSignature,
+        [180 /* ConstructSignature */]: forEachChildInCallOrConstructSignature,
+        [174 /* MethodDeclaration */]: function forEachChildInMethodDeclaration(node, cbNode, cbNodes) {
           return visitNodes(cbNode, cbNodes, node.modifiers) || visitNode2(cbNode, node.asteriskToken) || visitNode2(cbNode, node.name) || visitNode2(cbNode, node.questionToken) || visitNode2(cbNode, node.exclamationToken) || visitNodes(cbNode, cbNodes, node.typeParameters) || visitNodes(cbNode, cbNodes, node.parameters) || visitNode2(cbNode, node.type) || visitNode2(cbNode, node.body);
         },
-        [172 /* MethodSignature */]: function forEachChildInMethodSignature(node, cbNode, cbNodes) {
+        [173 /* MethodSignature */]: function forEachChildInMethodSignature(node, cbNode, cbNodes) {
           return visitNodes(cbNode, cbNodes, node.modifiers) || visitNode2(cbNode, node.name) || visitNode2(cbNode, node.questionToken) || visitNodes(cbNode, cbNodes, node.typeParameters) || visitNodes(cbNode, cbNodes, node.parameters) || visitNode2(cbNode, node.type);
         },
-        [175 /* Constructor */]: function forEachChildInConstructor(node, cbNode, cbNodes) {
+        [176 /* Constructor */]: function forEachChildInConstructor(node, cbNode, cbNodes) {
           return visitNodes(cbNode, cbNodes, node.modifiers) || visitNode2(cbNode, node.name) || visitNodes(cbNode, cbNodes, node.typeParameters) || visitNodes(cbNode, cbNodes, node.parameters) || visitNode2(cbNode, node.type) || visitNode2(cbNode, node.body);
         },
-        [176 /* GetAccessor */]: function forEachChildInGetAccessor(node, cbNode, cbNodes) {
+        [177 /* GetAccessor */]: function forEachChildInGetAccessor(node, cbNode, cbNodes) {
           return visitNodes(cbNode, cbNodes, node.modifiers) || visitNode2(cbNode, node.name) || visitNodes(cbNode, cbNodes, node.typeParameters) || visitNodes(cbNode, cbNodes, node.parameters) || visitNode2(cbNode, node.type) || visitNode2(cbNode, node.body);
         },
-        [177 /* SetAccessor */]: function forEachChildInSetAccessor(node, cbNode, cbNodes) {
+        [178 /* SetAccessor */]: function forEachChildInSetAccessor(node, cbNode, cbNodes) {
           return visitNodes(cbNode, cbNodes, node.modifiers) || visitNode2(cbNode, node.name) || visitNodes(cbNode, cbNodes, node.typeParameters) || visitNodes(cbNode, cbNodes, node.parameters) || visitNode2(cbNode, node.type) || visitNode2(cbNode, node.body);
         },
-        [261 /* FunctionDeclaration */]: function forEachChildInFunctionDeclaration(node, cbNode, cbNodes) {
+        [262 /* FunctionDeclaration */]: function forEachChildInFunctionDeclaration(node, cbNode, cbNodes) {
           return visitNodes(cbNode, cbNodes, node.modifiers) || visitNode2(cbNode, node.asteriskToken) || visitNode2(cbNode, node.name) || visitNodes(cbNode, cbNodes, node.typeParameters) || visitNodes(cbNode, cbNodes, node.parameters) || visitNode2(cbNode, node.type) || visitNode2(cbNode, node.body);
         },
-        [217 /* FunctionExpression */]: function forEachChildInFunctionExpression(node, cbNode, cbNodes) {
+        [218 /* FunctionExpression */]: function forEachChildInFunctionExpression(node, cbNode, cbNodes) {
           return visitNodes(cbNode, cbNodes, node.modifiers) || visitNode2(cbNode, node.asteriskToken) || visitNode2(cbNode, node.name) || visitNodes(cbNode, cbNodes, node.typeParameters) || visitNodes(cbNode, cbNodes, node.parameters) || visitNode2(cbNode, node.type) || visitNode2(cbNode, node.body);
         },
-        [218 /* ArrowFunction */]: function forEachChildInArrowFunction(node, cbNode, cbNodes) {
+        [219 /* ArrowFunction */]: function forEachChildInArrowFunction(node, cbNode, cbNodes) {
           return visitNodes(cbNode, cbNodes, node.modifiers) || visitNodes(cbNode, cbNodes, node.typeParameters) || visitNodes(cbNode, cbNodes, node.parameters) || visitNode2(cbNode, node.type) || visitNode2(cbNode, node.equalsGreaterThanToken) || visitNode2(cbNode, node.body);
         },
-        [174 /* ClassStaticBlockDeclaration */]: function forEachChildInClassStaticBlockDeclaration(node, cbNode, cbNodes) {
+        [175 /* ClassStaticBlockDeclaration */]: function forEachChildInClassStaticBlockDeclaration(node, cbNode, cbNodes) {
           return visitNodes(cbNode, cbNodes, node.modifiers) || visitNode2(cbNode, node.body);
         },
-        [182 /* TypeReference */]: function forEachChildInTypeReference(node, cbNode, cbNodes) {
+        [183 /* TypeReference */]: function forEachChildInTypeReference(node, cbNode, cbNodes) {
           return visitNode2(cbNode, node.typeName) || visitNodes(cbNode, cbNodes, node.typeArguments);
         },
-        [181 /* TypePredicate */]: function forEachChildInTypePredicate(node, cbNode, _cbNodes) {
+        [182 /* TypePredicate */]: function forEachChildInTypePredicate(node, cbNode, _cbNodes) {
           return visitNode2(cbNode, node.assertsModifier) || visitNode2(cbNode, node.parameterName) || visitNode2(cbNode, node.type);
         },
-        [185 /* TypeQuery */]: function forEachChildInTypeQuery(node, cbNode, cbNodes) {
+        [186 /* TypeQuery */]: function forEachChildInTypeQuery(node, cbNode, cbNodes) {
           return visitNode2(cbNode, node.exprName) || visitNodes(cbNode, cbNodes, node.typeArguments);
         },
-        [186 /* TypeLiteral */]: function forEachChildInTypeLiteral(node, cbNode, cbNodes) {
+        [187 /* TypeLiteral */]: function forEachChildInTypeLiteral(node, cbNode, cbNodes) {
           return visitNodes(cbNode, cbNodes, node.members);
         },
-        [187 /* ArrayType */]: function forEachChildInArrayType(node, cbNode, _cbNodes) {
+        [188 /* ArrayType */]: function forEachChildInArrayType(node, cbNode, _cbNodes) {
           return visitNode2(cbNode, node.elementType);
         },
-        [188 /* TupleType */]: function forEachChildInTupleType(node, cbNode, cbNodes) {
+        [189 /* TupleType */]: function forEachChildInTupleType(node, cbNode, cbNodes) {
           return visitNodes(cbNode, cbNodes, node.elements);
         },
-        [191 /* UnionType */]: forEachChildInUnionOrIntersectionType,
-        [192 /* IntersectionType */]: forEachChildInUnionOrIntersectionType,
-        [193 /* ConditionalType */]: function forEachChildInConditionalType(node, cbNode, _cbNodes) {
+        [192 /* UnionType */]: forEachChildInUnionOrIntersectionType,
+        [193 /* IntersectionType */]: forEachChildInUnionOrIntersectionType,
+        [194 /* ConditionalType */]: function forEachChildInConditionalType(node, cbNode, _cbNodes) {
           return visitNode2(cbNode, node.checkType) || visitNode2(cbNode, node.extendsType) || visitNode2(cbNode, node.trueType) || visitNode2(cbNode, node.falseType);
         },
-        [194 /* InferType */]: function forEachChildInInferType(node, cbNode, _cbNodes) {
+        [195 /* InferType */]: function forEachChildInInferType(node, cbNode, _cbNodes) {
           return visitNode2(cbNode, node.typeParameter);
         },
-        [204 /* ImportType */]: function forEachChildInImportType(node, cbNode, cbNodes) {
-          return visitNode2(cbNode, node.argument) || visitNode2(cbNode, node.assertions) || visitNode2(cbNode, node.qualifier) || visitNodes(cbNode, cbNodes, node.typeArguments);
+        [205 /* ImportType */]: function forEachChildInImportType(node, cbNode, cbNodes) {
+          return visitNode2(cbNode, node.argument) || visitNode2(cbNode, node.attributes) || visitNode2(cbNode, node.qualifier) || visitNodes(cbNode, cbNodes, node.typeArguments);
         },
-        [301 /* ImportTypeAssertionContainer */]: function forEachChildInImportTypeAssertionContainer(node, cbNode, _cbNodes) {
+        [302 /* ImportTypeAssertionContainer */]: function forEachChildInImportTypeAssertionContainer(node, cbNode, _cbNodes) {
           return visitNode2(cbNode, node.assertClause);
         },
-        [195 /* ParenthesizedType */]: forEachChildInParenthesizedTypeOrTypeOperator,
-        [197 /* TypeOperator */]: forEachChildInParenthesizedTypeOrTypeOperator,
-        [198 /* IndexedAccessType */]: function forEachChildInIndexedAccessType(node, cbNode, _cbNodes) {
+        [196 /* ParenthesizedType */]: forEachChildInParenthesizedTypeOrTypeOperator,
+        [198 /* TypeOperator */]: forEachChildInParenthesizedTypeOrTypeOperator,
+        [199 /* IndexedAccessType */]: function forEachChildInIndexedAccessType(node, cbNode, _cbNodes) {
           return visitNode2(cbNode, node.objectType) || visitNode2(cbNode, node.indexType);
         },
-        [199 /* MappedType */]: function forEachChildInMappedType(node, cbNode, cbNodes) {
+        [200 /* MappedType */]: function forEachChildInMappedType(node, cbNode, cbNodes) {
           return visitNode2(cbNode, node.readonlyToken) || visitNode2(cbNode, node.typeParameter) || visitNode2(cbNode, node.nameType) || visitNode2(cbNode, node.questionToken) || visitNode2(cbNode, node.type) || visitNodes(cbNode, cbNodes, node.members);
         },
-        [200 /* LiteralType */]: function forEachChildInLiteralType(node, cbNode, _cbNodes) {
+        [201 /* LiteralType */]: function forEachChildInLiteralType(node, cbNode, _cbNodes) {
           return visitNode2(cbNode, node.literal);
         },
-        [201 /* NamedTupleMember */]: function forEachChildInNamedTupleMember(node, cbNode, _cbNodes) {
+        [202 /* NamedTupleMember */]: function forEachChildInNamedTupleMember(node, cbNode, _cbNodes) {
           return visitNode2(cbNode, node.dotDotDotToken) || visitNode2(cbNode, node.name) || visitNode2(cbNode, node.questionToken) || visitNode2(cbNode, node.type);
         },
-        [205 /* ObjectBindingPattern */]: forEachChildInObjectOrArrayBindingPattern,
-        [206 /* ArrayBindingPattern */]: forEachChildInObjectOrArrayBindingPattern,
-        [208 /* ArrayLiteralExpression */]: function forEachChildInArrayLiteralExpression(node, cbNode, cbNodes) {
+        [206 /* ObjectBindingPattern */]: forEachChildInObjectOrArrayBindingPattern,
+        [207 /* ArrayBindingPattern */]: forEachChildInObjectOrArrayBindingPattern,
+        [209 /* ArrayLiteralExpression */]: function forEachChildInArrayLiteralExpression(node, cbNode, cbNodes) {
           return visitNodes(cbNode, cbNodes, node.elements);
         },
-        [209 /* ObjectLiteralExpression */]: function forEachChildInObjectLiteralExpression(node, cbNode, cbNodes) {
+        [210 /* ObjectLiteralExpression */]: function forEachChildInObjectLiteralExpression(node, cbNode, cbNodes) {
           return visitNodes(cbNode, cbNodes, node.properties);
         },
-        [210 /* PropertyAccessExpression */]: function forEachChildInPropertyAccessExpression(node, cbNode, _cbNodes) {
+        [211 /* PropertyAccessExpression */]: function forEachChildInPropertyAccessExpression(node, cbNode, _cbNodes) {
           return visitNode2(cbNode, node.expression) || visitNode2(cbNode, node.questionDotToken) || visitNode2(cbNode, node.name);
         },
-        [211 /* ElementAccessExpression */]: function forEachChildInElementAccessExpression(node, cbNode, _cbNodes) {
+        [212 /* ElementAccessExpression */]: function forEachChildInElementAccessExpression(node, cbNode, _cbNodes) {
           return visitNode2(cbNode, node.expression) || visitNode2(cbNode, node.questionDotToken) || visitNode2(cbNode, node.argumentExpression);
         },
-        [212 /* CallExpression */]: forEachChildInCallOrNewExpression,
-        [213 /* NewExpression */]: forEachChildInCallOrNewExpression,
-        [214 /* TaggedTemplateExpression */]: function forEachChildInTaggedTemplateExpression(node, cbNode, cbNodes) {
+        [213 /* CallExpression */]: forEachChildInCallOrNewExpression,
+        [214 /* NewExpression */]: forEachChildInCallOrNewExpression,
+        [215 /* TaggedTemplateExpression */]: function forEachChildInTaggedTemplateExpression(node, cbNode, cbNodes) {
           return visitNode2(cbNode, node.tag) || visitNode2(cbNode, node.questionDotToken) || visitNodes(cbNode, cbNodes, node.typeArguments) || visitNode2(cbNode, node.template);
         },
-        [215 /* TypeAssertionExpression */]: function forEachChildInTypeAssertionExpression(node, cbNode, _cbNodes) {
+        [216 /* TypeAssertionExpression */]: function forEachChildInTypeAssertionExpression(node, cbNode, _cbNodes) {
           return visitNode2(cbNode, node.type) || visitNode2(cbNode, node.expression);
         },
-        [216 /* ParenthesizedExpression */]: function forEachChildInParenthesizedExpression(node, cbNode, _cbNodes) {
+        [217 /* ParenthesizedExpression */]: function forEachChildInParenthesizedExpression(node, cbNode, _cbNodes) {
           return visitNode2(cbNode, node.expression);
         },
-        [219 /* DeleteExpression */]: function forEachChildInDeleteExpression(node, cbNode, _cbNodes) {
+        [220 /* DeleteExpression */]: function forEachChildInDeleteExpression(node, cbNode, _cbNodes) {
           return visitNode2(cbNode, node.expression);
         },
-        [220 /* TypeOfExpression */]: function forEachChildInTypeOfExpression(node, cbNode, _cbNodes) {
+        [221 /* TypeOfExpression */]: function forEachChildInTypeOfExpression(node, cbNode, _cbNodes) {
           return visitNode2(cbNode, node.expression);
         },
-        [221 /* VoidExpression */]: function forEachChildInVoidExpression(node, cbNode, _cbNodes) {
+        [222 /* VoidExpression */]: function forEachChildInVoidExpression(node, cbNode, _cbNodes) {
           return visitNode2(cbNode, node.expression);
         },
-        [223 /* PrefixUnaryExpression */]: function forEachChildInPrefixUnaryExpression(node, cbNode, _cbNodes) {
+        [224 /* PrefixUnaryExpression */]: function forEachChildInPrefixUnaryExpression(node, cbNode, _cbNodes) {
           return visitNode2(cbNode, node.operand);
         },
-        [228 /* YieldExpression */]: function forEachChildInYieldExpression(node, cbNode, _cbNodes) {
+        [229 /* YieldExpression */]: function forEachChildInYieldExpression(node, cbNode, _cbNodes) {
           return visitNode2(cbNode, node.asteriskToken) || visitNode2(cbNode, node.expression);
         },
-        [222 /* AwaitExpression */]: function forEachChildInAwaitExpression(node, cbNode, _cbNodes) {
+        [223 /* AwaitExpression */]: function forEachChildInAwaitExpression(node, cbNode, _cbNodes) {
           return visitNode2(cbNode, node.expression);
         },
-        [224 /* PostfixUnaryExpression */]: function forEachChildInPostfixUnaryExpression(node, cbNode, _cbNodes) {
+        [225 /* PostfixUnaryExpression */]: function forEachChildInPostfixUnaryExpression(node, cbNode, _cbNodes) {
           return visitNode2(cbNode, node.operand);
         },
-        [225 /* BinaryExpression */]: function forEachChildInBinaryExpression(node, cbNode, _cbNodes) {
+        [226 /* BinaryExpression */]: function forEachChildInBinaryExpression(node, cbNode, _cbNodes) {
           return visitNode2(cbNode, node.left) || visitNode2(cbNode, node.operatorToken) || visitNode2(cbNode, node.right);
         },
-        [233 /* AsExpression */]: function forEachChildInAsExpression(node, cbNode, _cbNodes) {
+        [234 /* AsExpression */]: function forEachChildInAsExpression(node, cbNode, _cbNodes) {
           return visitNode2(cbNode, node.expression) || visitNode2(cbNode, node.type);
         },
-        [234 /* NonNullExpression */]: function forEachChildInNonNullExpression(node, cbNode, _cbNodes) {
+        [235 /* NonNullExpression */]: function forEachChildInNonNullExpression(node, cbNode, _cbNodes) {
           return visitNode2(cbNode, node.expression);
         },
-        [237 /* SatisfiesExpression */]: function forEachChildInSatisfiesExpression(node, cbNode, _cbNodes) {
+        [238 /* SatisfiesExpression */]: function forEachChildInSatisfiesExpression(node, cbNode, _cbNodes) {
           return visitNode2(cbNode, node.expression) || visitNode2(cbNode, node.type);
         },
-        [235 /* MetaProperty */]: function forEachChildInMetaProperty(node, cbNode, _cbNodes) {
+        [236 /* MetaProperty */]: function forEachChildInMetaProperty(node, cbNode, _cbNodes) {
           return visitNode2(cbNode, node.name);
         },
-        [226 /* ConditionalExpression */]: function forEachChildInConditionalExpression(node, cbNode, _cbNodes) {
+        [227 /* ConditionalExpression */]: function forEachChildInConditionalExpression(node, cbNode, _cbNodes) {
           return visitNode2(cbNode, node.condition) || visitNode2(cbNode, node.questionToken) || visitNode2(cbNode, node.whenTrue) || visitNode2(cbNode, node.colonToken) || visitNode2(cbNode, node.whenFalse);
         },
-        [229 /* SpreadElement */]: function forEachChildInSpreadElement(node, cbNode, _cbNodes) {
+        [230 /* SpreadElement */]: function forEachChildInSpreadElement(node, cbNode, _cbNodes) {
           return visitNode2(cbNode, node.expression);
         },
-        [240 /* Block */]: forEachChildInBlock,
-        [267 /* ModuleBlock */]: forEachChildInBlock,
-        [311 /* SourceFile */]: function forEachChildInSourceFile(node, cbNode, cbNodes) {
+        [241 /* Block */]: forEachChildInBlock,
+        [268 /* ModuleBlock */]: forEachChildInBlock,
+        [312 /* SourceFile */]: function forEachChildInSourceFile(node, cbNode, cbNodes) {
           return visitNodes(cbNode, cbNodes, node.statements) || visitNode2(cbNode, node.endOfFileToken);
         },
-        [242 /* VariableStatement */]: function forEachChildInVariableStatement(node, cbNode, cbNodes) {
+        [243 /* VariableStatement */]: function forEachChildInVariableStatement(node, cbNode, cbNodes) {
           return visitNodes(cbNode, cbNodes, node.modifiers) || visitNode2(cbNode, node.declarationList);
         },
-        [260 /* VariableDeclarationList */]: function forEachChildInVariableDeclarationList(node, cbNode, cbNodes) {
+        [261 /* VariableDeclarationList */]: function forEachChildInVariableDeclarationList(node, cbNode, cbNodes) {
           return visitNodes(cbNode, cbNodes, node.declarations);
         },
-        [243 /* ExpressionStatement */]: function forEachChildInExpressionStatement(node, cbNode, _cbNodes) {
+        [244 /* ExpressionStatement */]: function forEachChildInExpressionStatement(node, cbNode, _cbNodes) {
           return visitNode2(cbNode, node.expression);
         },
-        [244 /* IfStatement */]: function forEachChildInIfStatement(node, cbNode, _cbNodes) {
+        [245 /* IfStatement */]: function forEachChildInIfStatement(node, cbNode, _cbNodes) {
           return visitNode2(cbNode, node.expression) || visitNode2(cbNode, node.thenStatement) || visitNode2(cbNode, node.elseStatement);
         },
-        [245 /* DoStatement */]: function forEachChildInDoStatement(node, cbNode, _cbNodes) {
+        [246 /* DoStatement */]: function forEachChildInDoStatement(node, cbNode, _cbNodes) {
           return visitNode2(cbNode, node.statement) || visitNode2(cbNode, node.expression);
         },
-        [246 /* WhileStatement */]: function forEachChildInWhileStatement(node, cbNode, _cbNodes) {
+        [247 /* WhileStatement */]: function forEachChildInWhileStatement(node, cbNode, _cbNodes) {
           return visitNode2(cbNode, node.expression) || visitNode2(cbNode, node.statement);
         },
-        [247 /* ForStatement */]: function forEachChildInForStatement(node, cbNode, _cbNodes) {
+        [248 /* ForStatement */]: function forEachChildInForStatement(node, cbNode, _cbNodes) {
           return visitNode2(cbNode, node.initializer) || visitNode2(cbNode, node.condition) || visitNode2(cbNode, node.incrementor) || visitNode2(cbNode, node.statement);
         },
-        [248 /* ForInStatement */]: function forEachChildInForInStatement(node, cbNode, _cbNodes) {
+        [249 /* ForInStatement */]: function forEachChildInForInStatement(node, cbNode, _cbNodes) {
           return visitNode2(cbNode, node.initializer) || visitNode2(cbNode, node.expression) || visitNode2(cbNode, node.statement);
         },
-        [249 /* ForOfStatement */]: function forEachChildInForOfStatement(node, cbNode, _cbNodes) {
+        [250 /* ForOfStatement */]: function forEachChildInForOfStatement(node, cbNode, _cbNodes) {
           return visitNode2(cbNode, node.awaitModifier) || visitNode2(cbNode, node.initializer) || visitNode2(cbNode, node.expression) || visitNode2(cbNode, node.statement);
         },
-        [250 /* ContinueStatement */]: forEachChildInContinueOrBreakStatement,
-        [251 /* BreakStatement */]: forEachChildInContinueOrBreakStatement,
-        [252 /* ReturnStatement */]: function forEachChildInReturnStatement(node, cbNode, _cbNodes) {
+        [251 /* ContinueStatement */]: forEachChildInContinueOrBreakStatement,
+        [252 /* BreakStatement */]: forEachChildInContinueOrBreakStatement,
+        [253 /* ReturnStatement */]: function forEachChildInReturnStatement(node, cbNode, _cbNodes) {
           return visitNode2(cbNode, node.expression);
         },
-        [253 /* WithStatement */]: function forEachChildInWithStatement(node, cbNode, _cbNodes) {
+        [254 /* WithStatement */]: function forEachChildInWithStatement(node, cbNode, _cbNodes) {
           return visitNode2(cbNode, node.expression) || visitNode2(cbNode, node.statement);
         },
-        [254 /* SwitchStatement */]: function forEachChildInSwitchStatement(node, cbNode, _cbNodes) {
+        [255 /* SwitchStatement */]: function forEachChildInSwitchStatement(node, cbNode, _cbNodes) {
           return visitNode2(cbNode, node.expression) || visitNode2(cbNode, node.caseBlock);
         },
-        [268 /* CaseBlock */]: function forEachChildInCaseBlock(node, cbNode, cbNodes) {
+        [269 /* CaseBlock */]: function forEachChildInCaseBlock(node, cbNode, cbNodes) {
           return visitNodes(cbNode, cbNodes, node.clauses);
         },
-        [295 /* CaseClause */]: function forEachChildInCaseClause(node, cbNode, cbNodes) {
+        [296 /* CaseClause */]: function forEachChildInCaseClause(node, cbNode, cbNodes) {
           return visitNode2(cbNode, node.expression) || visitNodes(cbNode, cbNodes, node.statements);
         },
-        [296 /* DefaultClause */]: function forEachChildInDefaultClause(node, cbNode, cbNodes) {
+        [297 /* DefaultClause */]: function forEachChildInDefaultClause(node, cbNode, cbNodes) {
           return visitNodes(cbNode, cbNodes, node.statements);
         },
-        [255 /* LabeledStatement */]: function forEachChildInLabeledStatement(node, cbNode, _cbNodes) {
+        [256 /* LabeledStatement */]: function forEachChildInLabeledStatement(node, cbNode, _cbNodes) {
           return visitNode2(cbNode, node.label) || visitNode2(cbNode, node.statement);
         },
-        [256 /* ThrowStatement */]: function forEachChildInThrowStatement(node, cbNode, _cbNodes) {
+        [257 /* ThrowStatement */]: function forEachChildInThrowStatement(node, cbNode, _cbNodes) {
           return visitNode2(cbNode, node.expression);
         },
-        [257 /* TryStatement */]: function forEachChildInTryStatement(node, cbNode, _cbNodes) {
+        [258 /* TryStatement */]: function forEachChildInTryStatement(node, cbNode, _cbNodes) {
           return visitNode2(cbNode, node.tryBlock) || visitNode2(cbNode, node.catchClause) || visitNode2(cbNode, node.finallyBlock);
         },
-        [298 /* CatchClause */]: function forEachChildInCatchClause(node, cbNode, _cbNodes) {
+        [299 /* CatchClause */]: function forEachChildInCatchClause(node, cbNode, _cbNodes) {
           return visitNode2(cbNode, node.variableDeclaration) || visitNode2(cbNode, node.block);
         },
-        [169 /* Decorator */]: function forEachChildInDecorator(node, cbNode, _cbNodes) {
+        [170 /* Decorator */]: function forEachChildInDecorator(node, cbNode, _cbNodes) {
           return visitNode2(cbNode, node.expression);
         },
-        [262 /* ClassDeclaration */]: forEachChildInClassDeclarationOrExpression,
-        [230 /* ClassExpression */]: forEachChildInClassDeclarationOrExpression,
-        [263 /* InterfaceDeclaration */]: function forEachChildInInterfaceDeclaration(node, cbNode, cbNodes) {
+        [263 /* ClassDeclaration */]: forEachChildInClassDeclarationOrExpression,
+        [231 /* ClassExpression */]: forEachChildInClassDeclarationOrExpression,
+        [264 /* InterfaceDeclaration */]: function forEachChildInInterfaceDeclaration(node, cbNode, cbNodes) {
           return visitNodes(cbNode, cbNodes, node.modifiers) || visitNode2(cbNode, node.name) || visitNodes(cbNode, cbNodes, node.typeParameters) || visitNodes(cbNode, cbNodes, node.heritageClauses) || visitNodes(cbNode, cbNodes, node.members);
         },
-        [264 /* TypeAliasDeclaration */]: function forEachChildInTypeAliasDeclaration(node, cbNode, cbNodes) {
+        [265 /* TypeAliasDeclaration */]: function forEachChildInTypeAliasDeclaration(node, cbNode, cbNodes) {
           return visitNodes(cbNode, cbNodes, node.modifiers) || visitNode2(cbNode, node.name) || visitNodes(cbNode, cbNodes, node.typeParameters) || visitNode2(cbNode, node.type);
         },
-        [265 /* EnumDeclaration */]: function forEachChildInEnumDeclaration(node, cbNode, cbNodes) {
+        [266 /* EnumDeclaration */]: function forEachChildInEnumDeclaration(node, cbNode, cbNodes) {
           return visitNodes(cbNode, cbNodes, node.modifiers) || visitNode2(cbNode, node.name) || visitNodes(cbNode, cbNodes, node.members);
         },
-        [305 /* EnumMember */]: function forEachChildInEnumMember(node, cbNode, _cbNodes) {
+        [306 /* EnumMember */]: function forEachChildInEnumMember(node, cbNode, _cbNodes) {
           return visitNode2(cbNode, node.name) || visitNode2(cbNode, node.initializer);
         },
-        [266 /* ModuleDeclaration */]: function forEachChildInModuleDeclaration(node, cbNode, cbNodes) {
+        [267 /* ModuleDeclaration */]: function forEachChildInModuleDeclaration(node, cbNode, cbNodes) {
           return visitNodes(cbNode, cbNodes, node.modifiers) || visitNode2(cbNode, node.name) || visitNode2(cbNode, node.body);
         },
-        [270 /* ImportEqualsDeclaration */]: function forEachChildInImportEqualsDeclaration(node, cbNode, cbNodes) {
+        [271 /* ImportEqualsDeclaration */]: function forEachChildInImportEqualsDeclaration(node, cbNode, cbNodes) {
           return visitNodes(cbNode, cbNodes, node.modifiers) || visitNode2(cbNode, node.name) || visitNode2(cbNode, node.moduleReference);
         },
-        [271 /* ImportDeclaration */]: function forEachChildInImportDeclaration(node, cbNode, cbNodes) {
-          return visitNodes(cbNode, cbNodes, node.modifiers) || visitNode2(cbNode, node.importClause) || visitNode2(cbNode, node.moduleSpecifier) || visitNode2(cbNode, node.assertClause);
+        [272 /* ImportDeclaration */]: function forEachChildInImportDeclaration(node, cbNode, cbNodes) {
+          return visitNodes(cbNode, cbNodes, node.modifiers) || visitNode2(cbNode, node.importClause) || visitNode2(cbNode, node.moduleSpecifier) || visitNode2(cbNode, node.attributes);
         },
-        [272 /* ImportClause */]: function forEachChildInImportClause(node, cbNode, _cbNodes) {
+        [273 /* ImportClause */]: function forEachChildInImportClause(node, cbNode, _cbNodes) {
           return visitNode2(cbNode, node.name) || visitNode2(cbNode, node.namedBindings);
         },
-        [299 /* AssertClause */]: function forEachChildInAssertClause(node, cbNode, cbNodes) {
+        [300 /* ImportAttributes */]: function forEachChildInImportAttributes(node, cbNode, cbNodes) {
           return visitNodes(cbNode, cbNodes, node.elements);
         },
-        [300 /* AssertEntry */]: function forEachChildInAssertEntry(node, cbNode, _cbNodes) {
+        [301 /* ImportAttribute */]: function forEachChildInImportAttribute(node, cbNode, _cbNodes) {
           return visitNode2(cbNode, node.name) || visitNode2(cbNode, node.value);
         },
-        [269 /* NamespaceExportDeclaration */]: function forEachChildInNamespaceExportDeclaration(node, cbNode, cbNodes) {
+        [270 /* NamespaceExportDeclaration */]: function forEachChildInNamespaceExportDeclaration(node, cbNode, cbNodes) {
           return visitNodes(cbNode, cbNodes, node.modifiers) || visitNode2(cbNode, node.name);
         },
-        [273 /* NamespaceImport */]: function forEachChildInNamespaceImport(node, cbNode, _cbNodes) {
+        [274 /* NamespaceImport */]: function forEachChildInNamespaceImport(node, cbNode, _cbNodes) {
           return visitNode2(cbNode, node.name);
         },
-        [279 /* NamespaceExport */]: function forEachChildInNamespaceExport(node, cbNode, _cbNodes) {
+        [280 /* NamespaceExport */]: function forEachChildInNamespaceExport(node, cbNode, _cbNodes) {
           return visitNode2(cbNode, node.name);
         },
-        [274 /* NamedImports */]: forEachChildInNamedImportsOrExports,
-        [278 /* NamedExports */]: forEachChildInNamedImportsOrExports,
-        [277 /* ExportDeclaration */]: function forEachChildInExportDeclaration(node, cbNode, cbNodes) {
-          return visitNodes(cbNode, cbNodes, node.modifiers) || visitNode2(cbNode, node.exportClause) || visitNode2(cbNode, node.moduleSpecifier) || visitNode2(cbNode, node.assertClause);
+        [275 /* NamedImports */]: forEachChildInNamedImportsOrExports,
+        [279 /* NamedExports */]: forEachChildInNamedImportsOrExports,
+        [278 /* ExportDeclaration */]: function forEachChildInExportDeclaration(node, cbNode, cbNodes) {
+          return visitNodes(cbNode, cbNodes, node.modifiers) || visitNode2(cbNode, node.exportClause) || visitNode2(cbNode, node.moduleSpecifier) || visitNode2(cbNode, node.attributes);
         },
-        [275 /* ImportSpecifier */]: forEachChildInImportOrExportSpecifier,
-        [280 /* ExportSpecifier */]: forEachChildInImportOrExportSpecifier,
-        [276 /* ExportAssignment */]: function forEachChildInExportAssignment(node, cbNode, cbNodes) {
+        [276 /* ImportSpecifier */]: forEachChildInImportOrExportSpecifier,
+        [281 /* ExportSpecifier */]: forEachChildInImportOrExportSpecifier,
+        [277 /* ExportAssignment */]: function forEachChildInExportAssignment(node, cbNode, cbNodes) {
           return visitNodes(cbNode, cbNodes, node.modifiers) || visitNode2(cbNode, node.expression);
         },
-        [227 /* TemplateExpression */]: function forEachChildInTemplateExpression(node, cbNode, cbNodes) {
+        [228 /* TemplateExpression */]: function forEachChildInTemplateExpression(node, cbNode, cbNodes) {
           return visitNode2(cbNode, node.head) || visitNodes(cbNode, cbNodes, node.templateSpans);
         },
-        [238 /* TemplateSpan */]: function forEachChildInTemplateSpan(node, cbNode, _cbNodes) {
+        [239 /* TemplateSpan */]: function forEachChildInTemplateSpan(node, cbNode, _cbNodes) {
           return visitNode2(cbNode, node.expression) || visitNode2(cbNode, node.literal);
         },
-        [202 /* TemplateLiteralType */]: function forEachChildInTemplateLiteralType(node, cbNode, cbNodes) {
+        [203 /* TemplateLiteralType */]: function forEachChildInTemplateLiteralType(node, cbNode, cbNodes) {
           return visitNode2(cbNode, node.head) || visitNodes(cbNode, cbNodes, node.templateSpans);
         },
-        [203 /* TemplateLiteralTypeSpan */]: function forEachChildInTemplateLiteralTypeSpan(node, cbNode, _cbNodes) {
+        [204 /* TemplateLiteralTypeSpan */]: function forEachChildInTemplateLiteralTypeSpan(node, cbNode, _cbNodes) {
           return visitNode2(cbNode, node.type) || visitNode2(cbNode, node.literal);
         },
-        [166 /* ComputedPropertyName */]: function forEachChildInComputedPropertyName(node, cbNode, _cbNodes) {
+        [167 /* ComputedPropertyName */]: function forEachChildInComputedPropertyName(node, cbNode, _cbNodes) {
           return visitNode2(cbNode, node.expression);
         },
-        [297 /* HeritageClause */]: function forEachChildInHeritageClause(node, cbNode, cbNodes) {
+        [298 /* HeritageClause */]: function forEachChildInHeritageClause(node, cbNode, cbNodes) {
           return visitNodes(cbNode, cbNodes, node.types);
         },
-        [232 /* ExpressionWithTypeArguments */]: function forEachChildInExpressionWithTypeArguments(node, cbNode, cbNodes) {
+        [233 /* ExpressionWithTypeArguments */]: function forEachChildInExpressionWithTypeArguments(node, cbNode, cbNodes) {
           return visitNode2(cbNode, node.expression) || visitNodes(cbNode, cbNodes, node.typeArguments);
         },
-        [282 /* ExternalModuleReference */]: function forEachChildInExternalModuleReference(node, cbNode, _cbNodes) {
+        [283 /* ExternalModuleReference */]: function forEachChildInExternalModuleReference(node, cbNode, _cbNodes) {
           return visitNode2(cbNode, node.expression);
         },
-        [281 /* MissingDeclaration */]: function forEachChildInMissingDeclaration(node, cbNode, cbNodes) {
+        [282 /* MissingDeclaration */]: function forEachChildInMissingDeclaration(node, cbNode, cbNodes) {
           return visitNodes(cbNode, cbNodes, node.modifiers);
         },
-        [360 /* CommaListExpression */]: function forEachChildInCommaListExpression(node, cbNode, cbNodes) {
+        [361 /* CommaListExpression */]: function forEachChildInCommaListExpression(node, cbNode, cbNodes) {
           return visitNodes(cbNode, cbNodes, node.elements);
         },
-        [283 /* JsxElement */]: function forEachChildInJsxElement(node, cbNode, cbNodes) {
+        [284 /* JsxElement */]: function forEachChildInJsxElement(node, cbNode, cbNodes) {
           return visitNode2(cbNode, node.openingElement) || visitNodes(cbNode, cbNodes, node.children) || visitNode2(cbNode, node.closingElement);
         },
-        [287 /* JsxFragment */]: function forEachChildInJsxFragment(node, cbNode, cbNodes) {
+        [288 /* JsxFragment */]: function forEachChildInJsxFragment(node, cbNode, cbNodes) {
           return visitNode2(cbNode, node.openingFragment) || visitNodes(cbNode, cbNodes, node.children) || visitNode2(cbNode, node.closingFragment);
         },
-        [284 /* JsxSelfClosingElement */]: forEachChildInJsxOpeningOrSelfClosingElement,
-        [285 /* JsxOpeningElement */]: forEachChildInJsxOpeningOrSelfClosingElement,
-        [291 /* JsxAttributes */]: function forEachChildInJsxAttributes(node, cbNode, cbNodes) {
+        [285 /* JsxSelfClosingElement */]: forEachChildInJsxOpeningOrSelfClosingElement,
+        [286 /* JsxOpeningElement */]: forEachChildInJsxOpeningOrSelfClosingElement,
+        [292 /* JsxAttributes */]: function forEachChildInJsxAttributes(node, cbNode, cbNodes) {
           return visitNodes(cbNode, cbNodes, node.properties);
         },
-        [290 /* JsxAttribute */]: function forEachChildInJsxAttribute(node, cbNode, _cbNodes) {
+        [291 /* JsxAttribute */]: function forEachChildInJsxAttribute(node, cbNode, _cbNodes) {
           return visitNode2(cbNode, node.name) || visitNode2(cbNode, node.initializer);
         },
-        [292 /* JsxSpreadAttribute */]: function forEachChildInJsxSpreadAttribute(node, cbNode, _cbNodes) {
+        [293 /* JsxSpreadAttribute */]: function forEachChildInJsxSpreadAttribute(node, cbNode, _cbNodes) {
           return visitNode2(cbNode, node.expression);
         },
-        [293 /* JsxExpression */]: function forEachChildInJsxExpression(node, cbNode, _cbNodes) {
+        [294 /* JsxExpression */]: function forEachChildInJsxExpression(node, cbNode, _cbNodes) {
           return visitNode2(cbNode, node.dotDotDotToken) || visitNode2(cbNode, node.expression);
         },
-        [286 /* JsxClosingElement */]: function forEachChildInJsxClosingElement(node, cbNode, _cbNodes) {
+        [287 /* JsxClosingElement */]: function forEachChildInJsxClosingElement(node, cbNode, _cbNodes) {
           return visitNode2(cbNode, node.tagName);
         },
-        [294 /* JsxNamespacedName */]: function forEachChildInJsxNamespacedName(node, cbNode, _cbNodes) {
+        [295 /* JsxNamespacedName */]: function forEachChildInJsxNamespacedName(node, cbNode, _cbNodes) {
           return visitNode2(cbNode, node.namespace) || visitNode2(cbNode, node.name);
         },
-        [189 /* OptionalType */]: forEachChildInOptionalRestOrJSDocParameterModifier,
-        [190 /* RestType */]: forEachChildInOptionalRestOrJSDocParameterModifier,
-        [315 /* JSDocTypeExpression */]: forEachChildInOptionalRestOrJSDocParameterModifier,
-        [321 /* JSDocNonNullableType */]: forEachChildInOptionalRestOrJSDocParameterModifier,
-        [320 /* JSDocNullableType */]: forEachChildInOptionalRestOrJSDocParameterModifier,
-        [322 /* JSDocOptionalType */]: forEachChildInOptionalRestOrJSDocParameterModifier,
-        [324 /* JSDocVariadicType */]: forEachChildInOptionalRestOrJSDocParameterModifier,
-        [323 /* JSDocFunctionType */]: function forEachChildInJSDocFunctionType(node, cbNode, cbNodes) {
+        [190 /* OptionalType */]: forEachChildInOptionalRestOrJSDocParameterModifier,
+        [191 /* RestType */]: forEachChildInOptionalRestOrJSDocParameterModifier,
+        [316 /* JSDocTypeExpression */]: forEachChildInOptionalRestOrJSDocParameterModifier,
+        [322 /* JSDocNonNullableType */]: forEachChildInOptionalRestOrJSDocParameterModifier,
+        [321 /* JSDocNullableType */]: forEachChildInOptionalRestOrJSDocParameterModifier,
+        [323 /* JSDocOptionalType */]: forEachChildInOptionalRestOrJSDocParameterModifier,
+        [325 /* JSDocVariadicType */]: forEachChildInOptionalRestOrJSDocParameterModifier,
+        [324 /* JSDocFunctionType */]: function forEachChildInJSDocFunctionType(node, cbNode, cbNodes) {
           return visitNodes(cbNode, cbNodes, node.parameters) || visitNode2(cbNode, node.type);
         },
-        [326 /* JSDoc */]: function forEachChildInJSDoc(node, cbNode, cbNodes) {
+        [327 /* JSDoc */]: function forEachChildInJSDoc(node, cbNode, cbNodes) {
           return (typeof node.comment === "string" ? void 0 : visitNodes(cbNode, cbNodes, node.comment)) || visitNodes(cbNode, cbNodes, node.tags);
         },
-        [353 /* JSDocSeeTag */]: function forEachChildInJSDocSeeTag(node, cbNode, cbNodes) {
+        [354 /* JSDocSeeTag */]: function forEachChildInJSDocSeeTag(node, cbNode, cbNodes) {
           return visitNode2(cbNode, node.tagName) || visitNode2(cbNode, node.name) || (typeof node.comment === "string" ? void 0 : visitNodes(cbNode, cbNodes, node.comment));
         },
-        [316 /* JSDocNameReference */]: function forEachChildInJSDocNameReference(node, cbNode, _cbNodes) {
+        [317 /* JSDocNameReference */]: function forEachChildInJSDocNameReference(node, cbNode, _cbNodes) {
           return visitNode2(cbNode, node.name);
         },
-        [317 /* JSDocMemberName */]: function forEachChildInJSDocMemberName(node, cbNode, _cbNodes) {
+        [318 /* JSDocMemberName */]: function forEachChildInJSDocMemberName(node, cbNode, _cbNodes) {
           return visitNode2(cbNode, node.left) || visitNode2(cbNode, node.right);
         },
-        [347 /* JSDocParameterTag */]: forEachChildInJSDocParameterOrPropertyTag,
-        [354 /* JSDocPropertyTag */]: forEachChildInJSDocParameterOrPropertyTag,
-        [336 /* JSDocAuthorTag */]: function forEachChildInJSDocAuthorTag(node, cbNode, cbNodes) {
+        [348 /* JSDocParameterTag */]: forEachChildInJSDocParameterOrPropertyTag,
+        [355 /* JSDocPropertyTag */]: forEachChildInJSDocParameterOrPropertyTag,
+        [337 /* JSDocAuthorTag */]: function forEachChildInJSDocAuthorTag(node, cbNode, cbNodes) {
           return visitNode2(cbNode, node.tagName) || (typeof node.comment === "string" ? void 0 : visitNodes(cbNode, cbNodes, node.comment));
         },
-        [335 /* JSDocImplementsTag */]: function forEachChildInJSDocImplementsTag(node, cbNode, cbNodes) {
+        [336 /* JSDocImplementsTag */]: function forEachChildInJSDocImplementsTag(node, cbNode, cbNodes) {
           return visitNode2(cbNode, node.tagName) || visitNode2(cbNode, node.class) || (typeof node.comment === "string" ? void 0 : visitNodes(cbNode, cbNodes, node.comment));
         },
-        [334 /* JSDocAugmentsTag */]: function forEachChildInJSDocAugmentsTag(node, cbNode, cbNodes) {
+        [335 /* JSDocAugmentsTag */]: function forEachChildInJSDocAugmentsTag(node, cbNode, cbNodes) {
           return visitNode2(cbNode, node.tagName) || visitNode2(cbNode, node.class) || (typeof node.comment === "string" ? void 0 : visitNodes(cbNode, cbNodes, node.comment));
         },
-        [351 /* JSDocTemplateTag */]: function forEachChildInJSDocTemplateTag(node, cbNode, cbNodes) {
+        [352 /* JSDocTemplateTag */]: function forEachChildInJSDocTemplateTag(node, cbNode, cbNodes) {
           return visitNode2(cbNode, node.tagName) || visitNode2(cbNode, node.constraint) || visitNodes(cbNode, cbNodes, node.typeParameters) || (typeof node.comment === "string" ? void 0 : visitNodes(cbNode, cbNodes, node.comment));
         },
-        [352 /* JSDocTypedefTag */]: function forEachChildInJSDocTypedefTag(node, cbNode, cbNodes) {
-          return visitNode2(cbNode, node.tagName) || (node.typeExpression && node.typeExpression.kind === 315 /* JSDocTypeExpression */ ? visitNode2(cbNode, node.typeExpression) || visitNode2(cbNode, node.fullName) || (typeof node.comment === "string" ? void 0 : visitNodes(cbNode, cbNodes, node.comment)) : visitNode2(cbNode, node.fullName) || visitNode2(cbNode, node.typeExpression) || (typeof node.comment === "string" ? void 0 : visitNodes(cbNode, cbNodes, node.comment)));
+        [353 /* JSDocTypedefTag */]: function forEachChildInJSDocTypedefTag(node, cbNode, cbNodes) {
+          return visitNode2(cbNode, node.tagName) || (node.typeExpression && node.typeExpression.kind === 316 /* JSDocTypeExpression */ ? visitNode2(cbNode, node.typeExpression) || visitNode2(cbNode, node.fullName) || (typeof node.comment === "string" ? void 0 : visitNodes(cbNode, cbNodes, node.comment)) : visitNode2(cbNode, node.fullName) || visitNode2(cbNode, node.typeExpression) || (typeof node.comment === "string" ? void 0 : visitNodes(cbNode, cbNodes, node.comment)));
         },
-        [344 /* JSDocCallbackTag */]: function forEachChildInJSDocCallbackTag(node, cbNode, cbNodes) {
+        [345 /* JSDocCallbackTag */]: function forEachChildInJSDocCallbackTag(node, cbNode, cbNodes) {
           return visitNode2(cbNode, node.tagName) || visitNode2(cbNode, node.fullName) || visitNode2(cbNode, node.typeExpression) || (typeof node.comment === "string" ? void 0 : visitNodes(cbNode, cbNodes, node.comment));
         },
-        [348 /* JSDocReturnTag */]: forEachChildInJSDocTypeLikeTag,
-        [350 /* JSDocTypeTag */]: forEachChildInJSDocTypeLikeTag,
-        [349 /* JSDocThisTag */]: forEachChildInJSDocTypeLikeTag,
-        [346 /* JSDocEnumTag */]: forEachChildInJSDocTypeLikeTag,
-        [356 /* JSDocSatisfiesTag */]: forEachChildInJSDocTypeLikeTag,
-        [355 /* JSDocThrowsTag */]: forEachChildInJSDocTypeLikeTag,
-        [345 /* JSDocOverloadTag */]: forEachChildInJSDocTypeLikeTag,
-        [329 /* JSDocSignature */]: function forEachChildInJSDocSignature(node, cbNode, _cbNodes) {
+        [349 /* JSDocReturnTag */]: forEachChildInJSDocTypeLikeTag,
+        [351 /* JSDocTypeTag */]: forEachChildInJSDocTypeLikeTag,
+        [350 /* JSDocThisTag */]: forEachChildInJSDocTypeLikeTag,
+        [347 /* JSDocEnumTag */]: forEachChildInJSDocTypeLikeTag,
+        [357 /* JSDocSatisfiesTag */]: forEachChildInJSDocTypeLikeTag,
+        [356 /* JSDocThrowsTag */]: forEachChildInJSDocTypeLikeTag,
+        [346 /* JSDocOverloadTag */]: forEachChildInJSDocTypeLikeTag,
+        [330 /* JSDocSignature */]: function forEachChildInJSDocSignature(node, cbNode, _cbNodes) {
           return forEach(node.typeParameters, cbNode) || forEach(node.parameters, cbNode) || visitNode2(cbNode, node.type);
         },
-        [330 /* JSDocLink */]: forEachChildInJSDocLinkCodeOrPlain,
-        [331 /* JSDocLinkCode */]: forEachChildInJSDocLinkCodeOrPlain,
-        [332 /* JSDocLinkPlain */]: forEachChildInJSDocLinkCodeOrPlain,
-        [328 /* JSDocTypeLiteral */]: function forEachChildInJSDocTypeLiteral(node, cbNode, _cbNodes) {
+        [331 /* JSDocLink */]: forEachChildInJSDocLinkCodeOrPlain,
+        [332 /* JSDocLinkCode */]: forEachChildInJSDocLinkCodeOrPlain,
+        [333 /* JSDocLinkPlain */]: forEachChildInJSDocLinkCodeOrPlain,
+        [329 /* JSDocTypeLiteral */]: function forEachChildInJSDocTypeLiteral(node, cbNode, _cbNodes) {
           return forEach(node.jsDocPropertyTags, cbNode);
         },
-        [333 /* JSDocTag */]: forEachChildInJSDocTag,
-        [338 /* JSDocClassTag */]: forEachChildInJSDocTag,
-        [339 /* JSDocPublicTag */]: forEachChildInJSDocTag,
-        [340 /* JSDocPrivateTag */]: forEachChildInJSDocTag,
-        [341 /* JSDocProtectedTag */]: forEachChildInJSDocTag,
-        [342 /* JSDocReadonlyTag */]: forEachChildInJSDocTag,
-        [337 /* JSDocDeprecatedTag */]: forEachChildInJSDocTag,
-        [343 /* JSDocOverrideTag */]: forEachChildInJSDocTag,
-        [359 /* PartiallyEmittedExpression */]: forEachChildInPartiallyEmittedExpression
+        [334 /* JSDocTag */]: forEachChildInJSDocTag,
+        [339 /* JSDocClassTag */]: forEachChildInJSDocTag,
+        [340 /* JSDocPublicTag */]: forEachChildInJSDocTag,
+        [341 /* JSDocPrivateTag */]: forEachChildInJSDocTag,
+        [342 /* JSDocProtectedTag */]: forEachChildInJSDocTag,
+        [343 /* JSDocReadonlyTag */]: forEachChildInJSDocTag,
+        [338 /* JSDocDeprecatedTag */]: forEachChildInJSDocTag,
+        [344 /* JSDocOverrideTag */]: forEachChildInJSDocTag,
+        [360 /* PartiallyEmittedExpression */]: forEachChildInPartiallyEmittedExpression
       };
       ((Parser2) => {
         var scanner2 = createScanner(
@@ -127941,7 +110928,7 @@ ${lanes.join("\n")}
           /*skipTrivia*/
           true
         );
-        var disallowInAndDecoratorContext = 4096 /* DisallowInContext */ | 16384 /* DecoratorContext */;
+        var disallowInAndDecoratorContext = 8192 /* DisallowInContext */ | 32768 /* DecoratorContext */;
         var NodeConstructor2;
         var TokenConstructor2;
         var IdentifierConstructor2;
@@ -128035,7 +111022,7 @@ ${lanes.join("\n")}
         var contextFlags;
         var topLevel = true;
         var parseErrorBeforeNextFinishedNode = false;
-        function parseSourceFile(fileName2, sourceText2, languageVersion2, syntaxCursor2, setParentNodes = false, scriptKind2, setExternalModuleIndicatorOverride) {
+        function parseSourceFile(fileName2, sourceText2, languageVersion2, syntaxCursor2, setParentNodes = false, scriptKind2, setExternalModuleIndicatorOverride, jsDocParsingMode = 0 /* ParseAll */) {
           var _a;
           scriptKind2 = ensureScriptKind(fileName2, scriptKind2);
           if (scriptKind2 === 6 /* JSON */) {
@@ -128057,8 +111044,8 @@ ${lanes.join("\n")}
             result2.pragmas = emptyMap;
             return result2;
           }
-          initializeState(fileName2, sourceText2, languageVersion2, syntaxCursor2, scriptKind2);
-          const result = parseSourceFileWorker(languageVersion2, setParentNodes, scriptKind2, setExternalModuleIndicatorOverride || setExternalModuleIndicator);
+          initializeState(fileName2, sourceText2, languageVersion2, syntaxCursor2, scriptKind2, jsDocParsingMode);
+          const result = parseSourceFileWorker(languageVersion2, setParentNodes, scriptKind2, setExternalModuleIndicatorOverride || setExternalModuleIndicator, jsDocParsingMode);
           clearState();
           return result;
         }
@@ -128070,20 +111057,21 @@ ${lanes.join("\n")}
             languageVersion2,
             /*syntaxCursor*/
             void 0,
-            1 /* JS */
+            1 /* JS */,
+            0 /* ParseAll */
           );
           nextToken();
           const entityName = parseEntityName(
             /*allowReservedWords*/
             true
           );
-          const isInvalid = token() === 1 /* EndOfFileToken */ && !parseDiagnostics.length;
+          const isValid = token() === 1 /* EndOfFileToken */ && !parseDiagnostics.length;
           clearState();
-          return isInvalid ? entityName : void 0;
+          return isValid ? entityName : void 0;
         }
         Parser2.parseIsolatedEntityName = parseIsolatedEntityName2;
         function parseJsonText2(fileName2, sourceText2, languageVersion2 = 2 /* ES2015 */, syntaxCursor2, setParentNodes = false) {
-          initializeState(fileName2, sourceText2, languageVersion2, syntaxCursor2, 6 /* JSON */);
+          initializeState(fileName2, sourceText2, languageVersion2, syntaxCursor2, 6 /* JSON */, 0 /* ParseAll */);
           sourceFlags = contextFlags;
           nextToken();
           const pos = getNodePos();
@@ -128164,7 +111152,7 @@ ${lanes.join("\n")}
           return result;
         }
         Parser2.parseJsonText = parseJsonText2;
-        function initializeState(_fileName, _sourceText, _languageVersion, _syntaxCursor, _scriptKind) {
+        function initializeState(_fileName, _sourceText, _languageVersion, _syntaxCursor, _scriptKind, _jsDocParsingMode) {
           NodeConstructor2 = objectAllocator.getNodeConstructor();
           TokenConstructor2 = objectAllocator.getTokenConstructor();
           IdentifierConstructor2 = objectAllocator.getIdentifierConstructor();
@@ -128186,10 +111174,10 @@ ${lanes.join("\n")}
           switch (scriptKind) {
             case 1 /* JS */:
             case 2 /* JSX */:
-              contextFlags = 262144 /* JavaScriptFile */;
+              contextFlags = 524288 /* JavaScriptFile */;
               break;
             case 6 /* JSON */:
-              contextFlags = 262144 /* JavaScriptFile */ | 67108864 /* JsonFile */;
+              contextFlags = 524288 /* JavaScriptFile */ | 134217728 /* JsonFile */;
               break;
             default:
               contextFlags = 0 /* None */;
@@ -128200,11 +111188,15 @@ ${lanes.join("\n")}
           scanner2.setOnError(scanError);
           scanner2.setScriptTarget(languageVersion);
           scanner2.setLanguageVariant(languageVariant);
+          scanner2.setScriptKind(scriptKind);
+          scanner2.setJSDocParsingMode(_jsDocParsingMode);
         }
         function clearState() {
           scanner2.clearCommentDirectives();
           scanner2.setText("");
           scanner2.setOnError(void 0);
+          scanner2.setScriptKind(0 /* Unknown */);
+          scanner2.setJSDocParsingMode(0 /* ParseAll */);
           sourceText = void 0;
           languageVersion = void 0;
           syntaxCursor = void 0;
@@ -128218,16 +111210,17 @@ ${lanes.join("\n")}
           notParenthesizedArrow = void 0;
           topLevel = true;
         }
-        function parseSourceFileWorker(languageVersion2, setParentNodes, scriptKind2, setExternalModuleIndicator2) {
+        function parseSourceFileWorker(languageVersion2, setParentNodes, scriptKind2, setExternalModuleIndicator2, jsDocParsingMode) {
           const isDeclarationFile = isDeclarationFileName(fileName);
           if (isDeclarationFile) {
-            contextFlags |= 16777216 /* Ambient */;
+            contextFlags |= 33554432 /* Ambient */;
           }
           sourceFlags = contextFlags;
           nextToken();
           const statements = parseList(0 /* SourceElements */, parseStatement);
           Debug.assert(token() === 1 /* EndOfFileToken */);
-          const endOfFileToken = addJSDocComment(parseTokenNode());
+          const endHasJSDoc = hasPrecedingJSDocComment();
+          const endOfFileToken = withJSDoc(parseTokenNode(), endHasJSDoc);
           const sourceFile = createSourceFile2(fileName, languageVersion2, scriptKind2, isDeclarationFile, statements, endOfFileToken, sourceFlags, setExternalModuleIndicator2);
           processCommentPragmas(sourceFile, sourceText);
           processPragmasIntoFields(sourceFile, reportPragmaDiagnostic);
@@ -128236,6 +111229,7 @@ ${lanes.join("\n")}
           sourceFile.identifierCount = identifierCount;
           sourceFile.identifiers = identifiers;
           sourceFile.parseDiagnostics = attachFileToDiagnostics(parseDiagnostics, sourceFile);
+          sourceFile.jsDocParsingMode = jsDocParsingMode;
           if (jsDocDiagnostics) {
             sourceFile.jsDocDiagnostics = attachFileToDiagnostics(jsDocDiagnostics, sourceFile);
           }
@@ -128244,21 +111238,21 @@ ${lanes.join("\n")}
           }
           return sourceFile;
           function reportPragmaDiagnostic(pos, end, diagnostic) {
-            parseDiagnostics.push(createDetachedDiagnostic(fileName, pos, end, diagnostic));
+            parseDiagnostics.push(createDetachedDiagnostic(fileName, sourceText, pos, end, diagnostic));
           }
         }
-        function withJSDoc(node, hasJSDoc) {
-          return hasJSDoc ? addJSDocComment(node) : node;
-        }
         let hasDeprecatedTag = false;
-        function addJSDocComment(node) {
+        function withJSDoc(node, hasJSDoc) {
+          if (!hasJSDoc) {
+            return node;
+          }
           Debug.assert(!node.jsDoc);
           const jsDoc = mapDefined(getJSDocCommentRanges(node, sourceText), (comment) => JSDocParser.parseJSDocComment(node, comment.pos, comment.end - comment.pos));
           if (jsDoc.length)
             node.jsDoc = jsDoc;
           if (hasDeprecatedTag) {
             hasDeprecatedTag = false;
-            node.flags |= 268435456 /* Deprecated */;
+            node.flags |= 536870912 /* Deprecated */;
           }
           return node;
         }
@@ -128283,7 +111277,7 @@ ${lanes.join("\n")}
             }
             speculationHelper(() => {
               const savedContextFlags = contextFlags;
-              contextFlags |= 32768 /* AwaitContext */;
+              contextFlags |= 65536 /* AwaitContext */;
               scanner2.resetTokenState(nextStatement.pos);
               nextToken();
               while (token() !== 1 /* EndOfFileToken */) {
@@ -128318,7 +111312,7 @@ ${lanes.join("\n")}
           syntaxCursor = savedSyntaxCursor;
           return factory2.updateSourceFile(sourceFile, setTextRange(factoryCreateNodeArray(statements), sourceFile.statements));
           function containsPossibleTopLevelAwait(node) {
-            return !(node.flags & 32768 /* AwaitContext */) && !!(node.transformFlags & 67108864 /* ContainsPossibleTopLevelAwait */);
+            return !(node.flags & 65536 /* AwaitContext */) && !!(node.transformFlags & 67108864 /* ContainsPossibleTopLevelAwait */);
           }
           function findNextStatementWithAwait(statements2, start2) {
             for (let i = start2; i < statements2.length; i++) {
@@ -128382,16 +111376,16 @@ ${lanes.join("\n")}
           }
         }
         function setDisallowInContext(val) {
-          setContextFlag(val, 4096 /* DisallowInContext */);
+          setContextFlag(val, 8192 /* DisallowInContext */);
         }
         function setYieldContext(val) {
-          setContextFlag(val, 8192 /* YieldContext */);
+          setContextFlag(val, 16384 /* YieldContext */);
         }
         function setDecoratorContext(val) {
-          setContextFlag(val, 16384 /* DecoratorContext */);
+          setContextFlag(val, 32768 /* DecoratorContext */);
         }
         function setAwaitContext(val) {
-          setContextFlag(val, 32768 /* AwaitContext */);
+          setContextFlag(val, 65536 /* AwaitContext */);
         }
         function doOutsideOfContext(context, func) {
           const contextFlagsToClear = context & contextFlags;
@@ -128430,52 +111424,52 @@ ${lanes.join("\n")}
           return func();
         }
         function allowInAnd(func) {
-          return doOutsideOfContext(4096 /* DisallowInContext */, func);
+          return doOutsideOfContext(8192 /* DisallowInContext */, func);
         }
         function disallowInAnd(func) {
-          return doInsideOfContext(4096 /* DisallowInContext */, func);
+          return doInsideOfContext(8192 /* DisallowInContext */, func);
         }
         function allowConditionalTypesAnd(func) {
-          return doOutsideOfContext(65536 /* DisallowConditionalTypesContext */, func);
+          return doOutsideOfContext(131072 /* DisallowConditionalTypesContext */, func);
         }
         function disallowConditionalTypesAnd(func) {
-          return doInsideOfContext(65536 /* DisallowConditionalTypesContext */, func);
+          return doInsideOfContext(131072 /* DisallowConditionalTypesContext */, func);
         }
         function doInYieldContext(func) {
-          return doInsideOfContext(8192 /* YieldContext */, func);
+          return doInsideOfContext(16384 /* YieldContext */, func);
         }
         function doInDecoratorContext(func) {
-          return doInsideOfContext(16384 /* DecoratorContext */, func);
+          return doInsideOfContext(32768 /* DecoratorContext */, func);
         }
         function doInAwaitContext(func) {
-          return doInsideOfContext(32768 /* AwaitContext */, func);
+          return doInsideOfContext(65536 /* AwaitContext */, func);
         }
         function doOutsideOfAwaitContext(func) {
-          return doOutsideOfContext(32768 /* AwaitContext */, func);
+          return doOutsideOfContext(65536 /* AwaitContext */, func);
         }
         function doInYieldAndAwaitContext(func) {
-          return doInsideOfContext(8192 /* YieldContext */ | 32768 /* AwaitContext */, func);
+          return doInsideOfContext(16384 /* YieldContext */ | 65536 /* AwaitContext */, func);
         }
         function doOutsideOfYieldAndAwaitContext(func) {
-          return doOutsideOfContext(8192 /* YieldContext */ | 32768 /* AwaitContext */, func);
+          return doOutsideOfContext(16384 /* YieldContext */ | 65536 /* AwaitContext */, func);
         }
         function inContext(flags) {
           return (contextFlags & flags) !== 0;
         }
         function inYieldContext() {
-          return inContext(8192 /* YieldContext */);
+          return inContext(16384 /* YieldContext */);
         }
         function inDisallowInContext() {
-          return inContext(4096 /* DisallowInContext */);
+          return inContext(8192 /* DisallowInContext */);
         }
         function inDisallowConditionalTypesContext() {
-          return inContext(65536 /* DisallowConditionalTypesContext */);
+          return inContext(131072 /* DisallowConditionalTypesContext */);
         }
         function inDecoratorContext() {
-          return inContext(16384 /* DecoratorContext */);
+          return inContext(32768 /* DecoratorContext */);
         }
         function inAwaitContext() {
-          return inContext(32768 /* AwaitContext */);
+          return inContext(65536 /* AwaitContext */);
         }
         function parseErrorAtCurrentToken(message, ...args) {
           return parseErrorAt(scanner2.getTokenStart(), scanner2.getTokenEnd(), message, ...args);
@@ -128484,7 +111478,7 @@ ${lanes.join("\n")}
           const lastError = lastOrUndefined(parseDiagnostics);
           let result;
           if (!lastError || start !== lastError.start) {
-            result = createDetachedDiagnostic(fileName, start, length2, message, ...args);
+            result = createDetachedDiagnostic(fileName, sourceText, start, length2, message, ...args);
             parseDiagnostics.push(result);
           }
           parseErrorBeforeNextFinishedNode = true;
@@ -128712,7 +111706,7 @@ ${lanes.join("\n")}
           if (lastError) {
             addRelatedInfo(
               lastError,
-              createDetachedDiagnostic(fileName, openPosition, 1, Diagnostics.The_parser_expected_to_find_a_1_to_match_the_0_token_here, tokenToString(openKind), tokenToString(closeKind))
+              createDetachedDiagnostic(fileName, sourceText, openPosition, 1, Diagnostics.The_parser_expected_to_find_a_1_to_match_the_0_token_here, tokenToString(openKind), tokenToString(closeKind))
             );
           }
         }
@@ -128799,7 +111793,7 @@ ${lanes.join("\n")}
           }
           if (parseErrorBeforeNextFinishedNode) {
             parseErrorBeforeNextFinishedNode = false;
-            node.flags |= 131072 /* ThisNodeHasError */;
+            node.flags |= 262144 /* ThisNodeHasError */;
           }
           return node;
         }
@@ -128828,7 +111822,7 @@ ${lanes.join("\n")}
             "",
             /*isSingleQuote*/
             void 0
-          ) : kind === 281 /* MissingDeclaration */ ? factory2.createMissingDeclaration() : factoryCreateToken(kind);
+          ) : kind === 282 /* MissingDeclaration */ ? factory2.createMissingDeclaration() : factoryCreateToken(kind);
           return finishNode(result, pos);
         }
         function internIdentifier(text) {
@@ -128882,10 +111876,16 @@ ${lanes.join("\n")}
         function parseIdentifierName(diagnosticMessage) {
           return createIdentifier(tokenIsIdentifierOrKeyword(token()), diagnosticMessage);
         }
+        function parseIdentifierNameErrorOnUnicodeEscapeSequence() {
+          if (scanner2.hasUnicodeEscape() || scanner2.hasExtendedUnicodeEscape()) {
+            parseErrorAtCurrentToken(Diagnostics.Unicode_escape_sequence_cannot_appear_here);
+          }
+          return createIdentifier(tokenIsIdentifierOrKeyword(token()));
+        }
         function isLiteralPropertyName() {
           return tokenIsIdentifierOrKeyword(token()) || token() === 11 /* StringLiteral */ || token() === 9 /* NumericLiteral */;
         }
-        function isAssertionKey2() {
+        function isImportAttributeName2() {
           return tokenIsIdentifierOrKeyword(token()) || token() === 11 /* StringLiteral */;
         }
         function parsePropertyNameWorker(allowComputedPropertyNames) {
@@ -129004,8 +112004,8 @@ ${lanes.join("\n")}
               return isLiteralPropertyName();
             case 9 /* ObjectBindingElements */:
               return token() === 23 /* OpenBracketToken */ || token() === 26 /* DotDotDotToken */ || isLiteralPropertyName();
-            case 24 /* AssertEntries */:
-              return isAssertionKey2();
+            case 24 /* ImportAttributes */:
+              return isImportAttributeName2();
             case 7 /* HeritageClauseElement */:
               if (token() === 19 /* OpenBraceToken */) {
                 return lookAhead(isValidHeritageClauseObjectLiteral);
@@ -129045,6 +112045,9 @@ ${lanes.join("\n")}
             case 22 /* HeritageClauses */:
               return isHeritageClause2();
             case 23 /* ImportOrExportSpecifiers */:
+              if (token() === 161 /* FromKeyword */ && lookAhead(nextTokenIsStringLiteral)) {
+                return false;
+              }
               return tokenIsIdentifierOrKeyword(token());
             case 13 /* JsxAttributes */:
               return tokenIsIdentifierOrKeyword(token()) || token() === 19 /* OpenBraceToken */;
@@ -129105,7 +112108,7 @@ ${lanes.join("\n")}
             case 12 /* ObjectLiteralMembers */:
             case 9 /* ObjectBindingElements */:
             case 23 /* ImportOrExportSpecifiers */:
-            case 24 /* AssertEntries */:
+            case 24 /* ImportAttributes */:
               return token() === 20 /* CloseBraceToken */;
             case 3 /* SwitchClauseStatements */:
               return token() === 20 /* CloseBraceToken */ || token() === 84 /* CaseKeyword */ || token() === 90 /* DefaultKeyword */;
@@ -129201,7 +112204,7 @@ ${lanes.join("\n")}
           if (nodeIsMissing(node) || node.intersectsChange || containsParseError(node)) {
             return void 0;
           }
-          const nodeContextFlags = node.flags & 50720768 /* ContextFlags */;
+          const nodeContextFlags = node.flags & 101441536 /* ContextFlags */;
           if (nodeContextFlags !== contextFlags) {
             return void 0;
           }
@@ -129259,14 +112262,14 @@ ${lanes.join("\n")}
         function isReusableClassMember(node) {
           if (node) {
             switch (node.kind) {
-              case 175 /* Constructor */:
-              case 180 /* IndexSignature */:
-              case 176 /* GetAccessor */:
-              case 177 /* SetAccessor */:
-              case 171 /* PropertyDeclaration */:
-              case 239 /* SemicolonClassElement */:
+              case 176 /* Constructor */:
+              case 181 /* IndexSignature */:
+              case 177 /* GetAccessor */:
+              case 178 /* SetAccessor */:
+              case 172 /* PropertyDeclaration */:
+              case 240 /* SemicolonClassElement */:
                 return true;
-              case 173 /* MethodDeclaration */:
+              case 174 /* MethodDeclaration */:
                 const methodDeclaration = node;
                 const nameIsConstructor = methodDeclaration.name.kind === 80 /* Identifier */ && methodDeclaration.name.escapedText === "constructor";
                 return !nameIsConstructor;
@@ -129277,8 +112280,8 @@ ${lanes.join("\n")}
         function isReusableSwitchClause(node) {
           if (node) {
             switch (node.kind) {
-              case 295 /* CaseClause */:
-              case 296 /* DefaultClause */:
+              case 296 /* CaseClause */:
+              case 297 /* DefaultClause */:
                 return true;
             }
           }
@@ -129287,65 +112290,65 @@ ${lanes.join("\n")}
         function isReusableStatement(node) {
           if (node) {
             switch (node.kind) {
-              case 261 /* FunctionDeclaration */:
-              case 242 /* VariableStatement */:
-              case 240 /* Block */:
-              case 244 /* IfStatement */:
-              case 243 /* ExpressionStatement */:
-              case 256 /* ThrowStatement */:
-              case 252 /* ReturnStatement */:
-              case 254 /* SwitchStatement */:
-              case 251 /* BreakStatement */:
-              case 250 /* ContinueStatement */:
-              case 248 /* ForInStatement */:
-              case 249 /* ForOfStatement */:
-              case 247 /* ForStatement */:
-              case 246 /* WhileStatement */:
-              case 253 /* WithStatement */:
-              case 241 /* EmptyStatement */:
-              case 257 /* TryStatement */:
-              case 255 /* LabeledStatement */:
-              case 245 /* DoStatement */:
-              case 258 /* DebuggerStatement */:
-              case 271 /* ImportDeclaration */:
-              case 270 /* ImportEqualsDeclaration */:
-              case 277 /* ExportDeclaration */:
-              case 276 /* ExportAssignment */:
-              case 266 /* ModuleDeclaration */:
-              case 262 /* ClassDeclaration */:
-              case 263 /* InterfaceDeclaration */:
-              case 265 /* EnumDeclaration */:
-              case 264 /* TypeAliasDeclaration */:
+              case 262 /* FunctionDeclaration */:
+              case 243 /* VariableStatement */:
+              case 241 /* Block */:
+              case 245 /* IfStatement */:
+              case 244 /* ExpressionStatement */:
+              case 257 /* ThrowStatement */:
+              case 253 /* ReturnStatement */:
+              case 255 /* SwitchStatement */:
+              case 252 /* BreakStatement */:
+              case 251 /* ContinueStatement */:
+              case 249 /* ForInStatement */:
+              case 250 /* ForOfStatement */:
+              case 248 /* ForStatement */:
+              case 247 /* WhileStatement */:
+              case 254 /* WithStatement */:
+              case 242 /* EmptyStatement */:
+              case 258 /* TryStatement */:
+              case 256 /* LabeledStatement */:
+              case 246 /* DoStatement */:
+              case 259 /* DebuggerStatement */:
+              case 272 /* ImportDeclaration */:
+              case 271 /* ImportEqualsDeclaration */:
+              case 278 /* ExportDeclaration */:
+              case 277 /* ExportAssignment */:
+              case 267 /* ModuleDeclaration */:
+              case 263 /* ClassDeclaration */:
+              case 264 /* InterfaceDeclaration */:
+              case 266 /* EnumDeclaration */:
+              case 265 /* TypeAliasDeclaration */:
                 return true;
             }
           }
           return false;
         }
         function isReusableEnumMember(node) {
-          return node.kind === 305 /* EnumMember */;
+          return node.kind === 306 /* EnumMember */;
         }
         function isReusableTypeMember(node) {
           if (node) {
             switch (node.kind) {
-              case 179 /* ConstructSignature */:
-              case 172 /* MethodSignature */:
-              case 180 /* IndexSignature */:
-              case 170 /* PropertySignature */:
-              case 178 /* CallSignature */:
+              case 180 /* ConstructSignature */:
+              case 173 /* MethodSignature */:
+              case 181 /* IndexSignature */:
+              case 171 /* PropertySignature */:
+              case 179 /* CallSignature */:
                 return true;
             }
           }
           return false;
         }
         function isReusableVariableDeclaration(node) {
-          if (node.kind !== 259 /* VariableDeclaration */) {
+          if (node.kind !== 260 /* VariableDeclaration */) {
             return false;
           }
           const variableDeclarator = node;
           return variableDeclarator.initializer === void 0;
         }
         function isReusableParameter(node) {
-          if (node.kind !== 168 /* Parameter */) {
+          if (node.kind !== 169 /* Parameter */) {
             return false;
           }
           const parameter = node;
@@ -129403,12 +112406,15 @@ ${lanes.join("\n")}
             case 22 /* HeritageClauses */:
               return parseErrorAtCurrentToken(Diagnostics.Unexpected_token_expected);
             case 23 /* ImportOrExportSpecifiers */:
+              if (token() === 161 /* FromKeyword */) {
+                return parseErrorAtCurrentToken(Diagnostics._0_expected, "}");
+              }
               return parseErrorAtCurrentToken(Diagnostics.Identifier_expected);
             case 13 /* JsxAttributes */:
               return parseErrorAtCurrentToken(Diagnostics.Identifier_expected);
             case 14 /* JsxChildren */:
               return parseErrorAtCurrentToken(Diagnostics.Identifier_expected);
-            case 24 /* AssertEntries */:
+            case 24 /* ImportAttributes */:
               return parseErrorAtCurrentToken(Diagnostics.Identifier_or_string_literal_expected);
             case 25 /* JSDocComment */:
               return parseErrorAtCurrentToken(Diagnostics.Identifier_expected);
@@ -129502,7 +112508,9 @@ ${lanes.join("\n")}
                 parseRightSideOfDot(
                   allowReservedWords,
                   /*allowPrivateIdentifiers*/
-                  false
+                  false,
+                  /*allowUnicodeEscapeSequenceInIdentifierName*/
+                  true
                 )
               ),
               pos
@@ -129513,7 +112521,7 @@ ${lanes.join("\n")}
         function createQualifiedName(entity, name) {
           return finishNode(factory2.createQualifiedName(entity, name), entity.pos);
         }
-        function parseRightSideOfDot(allowIdentifierNames, allowPrivateIdentifiers) {
+        function parseRightSideOfDot(allowIdentifierNames, allowPrivateIdentifiers, allowUnicodeEscapeSequenceInIdentifierName) {
           if (scanner2.hasPrecedingLineBreak() && tokenIsIdentifierOrKeyword(token())) {
             const matchesPattern = lookAhead(nextTokenIsIdentifierOrKeywordOnSameLine);
             if (matchesPattern) {
@@ -129534,7 +112542,10 @@ ${lanes.join("\n")}
               Diagnostics.Identifier_expected
             );
           }
-          return allowIdentifierNames ? parseIdentifierName() : parseIdentifier();
+          if (allowIdentifierNames) {
+            return allowUnicodeEscapeSequenceInIdentifierName ? parseIdentifierName() : parseIdentifierNameErrorOnUnicodeEscapeSequence();
+          }
+          return parseIdentifier();
         }
         function parseTemplateSpans(isTaggedTemplate) {
           const pos = getNodePos();
@@ -129682,14 +112693,14 @@ ${lanes.join("\n")}
         }
         function typeHasArrowFunctionBlockingParseError(node) {
           switch (node.kind) {
-            case 182 /* TypeReference */:
+            case 183 /* TypeReference */:
               return nodeIsMissing(node.typeName);
-            case 183 /* FunctionType */:
-            case 184 /* ConstructorType */: {
+            case 184 /* FunctionType */:
+            case 185 /* ConstructorType */: {
               const { parameters, type } = node;
               return isMissingList(parameters) || typeHasArrowFunctionBlockingParseError(type);
             }
-            case 195 /* ParenthesizedType */:
+            case 196 /* ParenthesizedType */:
               return typeHasArrowFunctionBlockingParseError(node.type);
             default:
               return false;
@@ -129981,7 +112992,7 @@ ${lanes.join("\n")}
         function parseSignatureMember(kind) {
           const pos = getNodePos();
           const hasJSDoc = hasPrecedingJSDocComment();
-          if (kind === 179 /* ConstructSignature */) {
+          if (kind === 180 /* ConstructSignature */) {
             parseExpected(105 /* NewKeyword */);
           }
           const typeParameters = parseTypeParameters();
@@ -129992,7 +113003,7 @@ ${lanes.join("\n")}
             true
           );
           parseTypeMemberSemicolon();
-          const node = kind === 178 /* CallSignature */ ? factory2.createCallSignature(typeParameters, parameters, type) : factory2.createConstructSignature(typeParameters, parameters, type);
+          const node = kind === 179 /* CallSignature */ ? factory2.createCallSignature(typeParameters, parameters, type) : factory2.createConstructSignature(typeParameters, parameters, type);
           return withJSDoc(finishNode(node, pos), hasJSDoc);
         }
         function isIndexSignature() {
@@ -130077,10 +113088,10 @@ ${lanes.join("\n")}
         }
         function parseTypeMember() {
           if (token() === 21 /* OpenParenToken */ || token() === 30 /* LessThanToken */) {
-            return parseSignatureMember(178 /* CallSignature */);
+            return parseSignatureMember(179 /* CallSignature */);
           }
           if (token() === 105 /* NewKeyword */ && lookAhead(nextTokenIsOpenParenOrLessThan)) {
-            return parseSignatureMember(179 /* ConstructSignature */);
+            return parseSignatureMember(180 /* ConstructSignature */);
           }
           const pos = getNodePos();
           const hasJSDoc = hasPrecedingJSDocComment();
@@ -130089,10 +113100,10 @@ ${lanes.join("\n")}
             false
           );
           if (parseContextualModifier(139 /* GetKeyword */)) {
-            return parseAccessorDeclaration(pos, hasJSDoc, modifiers, 176 /* GetAccessor */, 4 /* Type */);
+            return parseAccessorDeclaration(pos, hasJSDoc, modifiers, 177 /* GetAccessor */, 4 /* Type */);
           }
           if (parseContextualModifier(153 /* SetKeyword */)) {
-            return parseAccessorDeclaration(pos, hasJSDoc, modifiers, 177 /* SetAccessor */, 4 /* Type */);
+            return parseAccessorDeclaration(pos, hasJSDoc, modifiers, 178 /* SetAccessor */, 4 /* Type */);
           }
           if (isIndexSignature()) {
             return parseIndexSignatureDeclaration(pos, hasJSDoc, modifiers);
@@ -130278,43 +113289,43 @@ ${lanes.join("\n")}
           nextToken();
           return token() === 102 /* ImportKeyword */;
         }
-        function parseImportTypeAssertions() {
-          const pos = getNodePos();
-          const openBracePosition = scanner2.getTokenStart();
-          parseExpected(19 /* OpenBraceToken */);
-          const multiLine = scanner2.hasPrecedingLineBreak();
-          parseExpected(132 /* AssertKeyword */);
-          parseExpected(59 /* ColonToken */);
-          const clause = parseAssertClause(
-            /*skipAssertKeyword*/
-            true
-          );
-          if (!parseExpected(20 /* CloseBraceToken */)) {
-            const lastError = lastOrUndefined(parseDiagnostics);
-            if (lastError && lastError.code === Diagnostics._0_expected.code) {
-              addRelatedInfo(
-                lastError,
-                createDetachedDiagnostic(fileName, openBracePosition, 1, Diagnostics.The_parser_expected_to_find_a_1_to_match_the_0_token_here, "{", "}")
-              );
-            }
-          }
-          return finishNode(factory2.createImportTypeAssertionContainer(clause, multiLine), pos);
-        }
         function parseImportType() {
-          sourceFlags |= 2097152 /* PossiblyContainsDynamicImport */;
+          sourceFlags |= 4194304 /* PossiblyContainsDynamicImport */;
           const pos = getNodePos();
           const isTypeOf = parseOptional(114 /* TypeOfKeyword */);
           parseExpected(102 /* ImportKeyword */);
           parseExpected(21 /* OpenParenToken */);
           const type = parseType();
-          let assertions;
+          let attributes;
           if (parseOptional(28 /* CommaToken */)) {
-            assertions = parseImportTypeAssertions();
+            const openBracePosition = scanner2.getTokenStart();
+            parseExpected(19 /* OpenBraceToken */);
+            const currentToken2 = token();
+            if (currentToken2 === 118 /* WithKeyword */ || currentToken2 === 132 /* AssertKeyword */) {
+              nextToken();
+            } else {
+              parseErrorAtCurrentToken(Diagnostics._0_expected, tokenToString(118 /* WithKeyword */));
+            }
+            parseExpected(59 /* ColonToken */);
+            attributes = parseImportAttributes(
+              currentToken2,
+              /*skipKeyword*/
+              true
+            );
+            if (!parseExpected(20 /* CloseBraceToken */)) {
+              const lastError = lastOrUndefined(parseDiagnostics);
+              if (lastError && lastError.code === Diagnostics._0_expected.code) {
+                addRelatedInfo(
+                  lastError,
+                  createDetachedDiagnostic(fileName, sourceText, openBracePosition, 1, Diagnostics.The_parser_expected_to_find_a_1_to_match_the_0_token_here, "{", "}")
+                );
+              }
+            }
           }
           parseExpected(22 /* CloseParenToken */);
           const qualifier = parseOptional(25 /* DotToken */) ? parseEntityNameOfTypeReference() : void 0;
           const typeArguments = parseTypeArgumentsOfTypeReference();
-          return finishNode(factory2.createImportTypeNode(type, assertions, qualifier, typeArguments, isTypeOf), pos);
+          return finishNode(factory2.createImportTypeNode(type, attributes, qualifier, typeArguments, isTypeOf), pos);
         }
         function nextTokenIsNumericOrBigIntLiteral() {
           nextToken();
@@ -130326,7 +113337,7 @@ ${lanes.join("\n")}
             case 159 /* UnknownKeyword */:
             case 154 /* StringKeyword */:
             case 150 /* NumberKeyword */:
-            case 162 /* BigIntKeyword */:
+            case 163 /* BigIntKeyword */:
             case 155 /* SymbolKeyword */:
             case 136 /* BooleanKeyword */:
             case 157 /* UndefinedKeyword */:
@@ -130392,7 +113403,7 @@ ${lanes.join("\n")}
             case 159 /* UnknownKeyword */:
             case 154 /* StringKeyword */:
             case 150 /* NumberKeyword */:
-            case 162 /* BigIntKeyword */:
+            case 163 /* BigIntKeyword */:
             case 136 /* BooleanKeyword */:
             case 148 /* ReadonlyKeyword */:
             case 155 /* SymbolKeyword */:
@@ -130638,8 +113649,8 @@ ${lanes.join("\n")}
           return finishNode(factory2.createTypePredicateNode(assertsModifier, parameterName, type), pos);
         }
         function parseType() {
-          if (contextFlags & 40960 /* TypeExcludesFlags */) {
-            return doOutsideOfContext(40960 /* TypeExcludesFlags */, parseType);
+          if (contextFlags & 81920 /* TypeExcludesFlags */) {
+            return doOutsideOfContext(81920 /* TypeExcludesFlags */, parseType);
           }
           if (isStartOfFunctionTypeOrConstructorType()) {
             return parseFunctionOrConstructorType();
@@ -130760,12 +113771,14 @@ ${lanes.join("\n")}
             return arrowExpression;
           }
           const pos = getNodePos();
+          const hasJSDoc = hasPrecedingJSDocComment();
           const expr = parseBinaryExpressionOrHigher(0 /* Lowest */);
           if (expr.kind === 80 /* Identifier */ && token() === 39 /* EqualsGreaterThanToken */) {
             return parseSimpleArrowFunctionExpression(
               pos,
               expr,
               allowReturnTypeInArrowFunction,
+              hasJSDoc,
               /*asyncModifier*/
               void 0
             );
@@ -130811,7 +113824,7 @@ ${lanes.join("\n")}
             ), pos);
           }
         }
-        function parseSimpleArrowFunctionExpression(pos, identifier, allowReturnTypeInArrowFunction, asyncModifier) {
+        function parseSimpleArrowFunctionExpression(pos, identifier, allowReturnTypeInArrowFunction, hasJSDoc, asyncModifier) {
           Debug.assert(token() === 39 /* EqualsGreaterThanToken */, "parseSimpleArrowFunctionExpression should only have been called if we had a =>");
           const parameter = factory2.createParameterDeclaration(
             /*modifiers*/
@@ -130844,7 +113857,7 @@ ${lanes.join("\n")}
             equalsGreaterThanToken,
             body
           );
-          return addJSDocComment(finishNode(node, pos));
+          return withJSDoc(finishNode(node, pos), hasJSDoc);
         }
         function tryParseParenthesizedArrowFunctionExpression(allowReturnTypeInArrowFunction) {
           const triState = isParenthesizedArrowFunctionExpression();
@@ -130972,9 +113985,10 @@ ${lanes.join("\n")}
           if (token() === 134 /* AsyncKeyword */) {
             if (lookAhead(isUnParenthesizedAsyncArrowFunctionWorker) === 1 /* True */) {
               const pos = getNodePos();
+              const hasJSDoc = hasPrecedingJSDocComment();
               const asyncModifier = parseModifiersForArrowFunction();
               const expr = parseBinaryExpressionOrHigher(0 /* Lowest */);
-              return parseSimpleArrowFunctionExpression(pos, expr, allowReturnTypeInArrowFunction, asyncModifier);
+              return parseSimpleArrowFunctionExpression(pos, expr, allowReturnTypeInArrowFunction, hasJSDoc, asyncModifier);
             }
           }
           return void 0;
@@ -131028,7 +114042,7 @@ ${lanes.join("\n")}
             return void 0;
           }
           let unwrappedType = type;
-          while ((unwrappedType == null ? void 0 : unwrappedType.kind) === 195 /* ParenthesizedType */) {
+          while ((unwrappedType == null ? void 0 : unwrappedType.kind) === 196 /* ParenthesizedType */) {
             unwrappedType = unwrappedType.type;
           }
           const hasJSDocFunctionType = unwrappedType && isJSDocFunctionType(unwrappedType);
@@ -131091,7 +114105,7 @@ ${lanes.join("\n")}
           return parseBinaryExpressionRest(precedence, leftOperand, pos);
         }
         function isInOrOfKeyword(t) {
-          return t === 103 /* InKeyword */ || t === 164 /* OfKeyword */;
+          return t === 103 /* InKeyword */ || t === 165 /* OfKeyword */;
         }
         function parseBinaryExpressionRest(precedence, leftOperand, pos) {
           while (true) {
@@ -131173,7 +114187,7 @@ ${lanes.join("\n")}
           if (token() === 43 /* AsteriskAsteriskToken */) {
             const pos = skipTrivia(sourceText, simpleUnaryExpression.pos);
             const { end } = simpleUnaryExpression;
-            if (simpleUnaryExpression.kind === 215 /* TypeAssertionExpression */) {
+            if (simpleUnaryExpression.kind === 216 /* TypeAssertionExpression */) {
               parseErrorAt(pos, end, Diagnostics.A_type_assertion_expression_is_not_allowed_in_the_left_hand_side_of_an_exponentiation_expression_Consider_enclosing_the_expression_in_parentheses);
             } else {
               Debug.assert(isKeywordOrPunctuation(unaryOperator));
@@ -131260,13 +114274,13 @@ ${lanes.join("\n")}
           let expression;
           if (token() === 102 /* ImportKeyword */) {
             if (lookAhead(nextTokenIsOpenParenOrLessThan)) {
-              sourceFlags |= 2097152 /* PossiblyContainsDynamicImport */;
+              sourceFlags |= 4194304 /* PossiblyContainsDynamicImport */;
               expression = parseTokenNode();
             } else if (lookAhead(nextTokenIsDot)) {
               nextToken();
               nextToken();
               expression = finishNode(factory2.createMetaProperty(102 /* ImportKeyword */, parseIdentifierName()), pos);
-              sourceFlags |= 4194304 /* PossiblyContainsImportMeta */;
+              sourceFlags |= 8388608 /* PossiblyContainsImportMeta */;
             } else {
               expression = parseMemberExpressionOrHigher();
             }
@@ -131306,6 +114320,8 @@ ${lanes.join("\n")}
             /*allowIdentifierNames*/
             true,
             /*allowPrivateIdentifiers*/
+            true,
+            /*allowUnicodeEscapeSequenceInIdentifierName*/
             true
           )), pos);
         }
@@ -131313,11 +114329,11 @@ ${lanes.join("\n")}
           const pos = getNodePos();
           const opening = parseJsxOpeningOrSelfClosingElementOrOpeningFragment(inExpressionContext);
           let result;
-          if (opening.kind === 285 /* JsxOpeningElement */) {
+          if (opening.kind === 286 /* JsxOpeningElement */) {
             let children = parseJsxChildren(opening);
             let closingElement;
             const lastChild = children[children.length - 1];
-            if ((lastChild == null ? void 0 : lastChild.kind) === 283 /* JsxElement */ && !tagNamesAreEquivalent(lastChild.openingElement.tagName, lastChild.closingElement.tagName) && tagNamesAreEquivalent(opening.tagName, lastChild.closingElement.tagName)) {
+            if ((lastChild == null ? void 0 : lastChild.kind) === 284 /* JsxElement */ && !tagNamesAreEquivalent(lastChild.openingElement.tagName, lastChild.closingElement.tagName) && tagNamesAreEquivalent(opening.tagName, lastChild.closingElement.tagName)) {
               const end = lastChild.children.end;
               const newLast = finishNode(
                 factory2.createJsxElement(
@@ -131341,10 +114357,10 @@ ${lanes.join("\n")}
               }
             }
             result = finishNode(factory2.createJsxElement(opening, children, closingElement), pos);
-          } else if (opening.kind === 288 /* JsxOpeningFragment */) {
+          } else if (opening.kind === 289 /* JsxOpeningFragment */) {
             result = finishNode(factory2.createJsxFragment(opening, parseJsxChildren(opening), parseJsxClosingFragment(inExpressionContext)), pos);
           } else {
-            Debug.assert(opening.kind === 284 /* JsxSelfClosingElement */);
+            Debug.assert(opening.kind === 285 /* JsxSelfClosingElement */);
             result = opening;
           }
           if (!mustBeUnary && inExpressionContext && token() === 30 /* LessThanToken */) {
@@ -131417,7 +114433,7 @@ ${lanes.join("\n")}
             if (!child)
               break;
             list.push(child);
-            if (isJsxOpeningElement(openingTag) && (child == null ? void 0 : child.kind) === 283 /* JsxElement */ && !tagNamesAreEquivalent(child.openingElement.tagName, child.closingElement.tagName) && tagNamesAreEquivalent(openingTag.tagName, child.closingElement.tagName)) {
+            if (isJsxOpeningElement(openingTag) && (child == null ? void 0 : child.kind) === 284 /* JsxElement */ && !tagNamesAreEquivalent(child.openingElement.tagName, child.closingElement.tagName) && tagNamesAreEquivalent(openingTag.tagName, child.closingElement.tagName)) {
               break;
             }
           }
@@ -131436,7 +114452,7 @@ ${lanes.join("\n")}
             return finishNode(factory2.createJsxOpeningFragment(), pos);
           }
           const tagName = parseJsxElementName();
-          const typeArguments = (contextFlags & 262144 /* JavaScriptFile */) === 0 ? tryParseTypeArguments() : void 0;
+          const typeArguments = (contextFlags & 524288 /* JavaScriptFile */) === 0 ? tryParseTypeArguments() : void 0;
           const attributes = parseJsxAttributes();
           let node;
           if (token() === 32 /* GreaterThanToken */) {
@@ -131473,6 +114489,8 @@ ${lanes.join("\n")}
               /*allowIdentifierNames*/
               true,
               /*allowPrivateIdentifiers*/
+              false,
+              /*allowUnicodeEscapeSequenceInIdentifierName*/
               false
             )), pos);
           }
@@ -131482,10 +114500,10 @@ ${lanes.join("\n")}
           const pos = getNodePos();
           scanJsxIdentifier();
           const isThis2 = token() === 110 /* ThisKeyword */;
-          const tagName = parseIdentifierName();
+          const tagName = parseIdentifierNameErrorOnUnicodeEscapeSequence();
           if (parseOptional(59 /* ColonToken */)) {
             scanJsxIdentifier();
-            return finishNode(factory2.createJsxNamespacedName(tagName, parseIdentifierName()), pos);
+            return finishNode(factory2.createJsxNamespacedName(tagName, parseIdentifierNameErrorOnUnicodeEscapeSequence()), pos);
           }
           return isThis2 ? finishNode(factory2.createToken(110 /* ThisKeyword */), pos) : tagName;
         }
@@ -131497,7 +114515,9 @@ ${lanes.join("\n")}
           let dotDotDotToken;
           let expression;
           if (token() !== 20 /* CloseBraceToken */) {
-            dotDotDotToken = parseOptionalToken(26 /* DotDotDotToken */);
+            if (!inExpressionContext) {
+              dotDotDotToken = parseOptionalToken(26 /* DotDotDotToken */);
+            }
             expression = parseExpression();
           }
           if (inExpressionContext) {
@@ -131546,10 +114566,10 @@ ${lanes.join("\n")}
         function parseJsxAttributeName() {
           const pos = getNodePos();
           scanJsxIdentifier();
-          const attrName = parseIdentifierName();
+          const attrName = parseIdentifierNameErrorOnUnicodeEscapeSequence();
           if (parseOptional(59 /* ColonToken */)) {
             scanJsxIdentifier();
-            return finishNode(factory2.createJsxNamespacedName(attrName, parseIdentifierName()), pos);
+            return finishNode(factory2.createJsxNamespacedName(attrName, parseIdentifierNameErrorOnUnicodeEscapeSequence()), pos);
           }
           return attrName;
         }
@@ -131614,17 +114634,17 @@ ${lanes.join("\n")}
           return token() === 29 /* QuestionDotToken */ && lookAhead(nextTokenIsIdentifierOrKeywordOrOpenBracketOrTemplate);
         }
         function tryReparseOptionalChain(node) {
-          if (node.flags & 32 /* OptionalChain */) {
+          if (node.flags & 64 /* OptionalChain */) {
             return true;
           }
           if (isNonNullExpression(node)) {
             let expr = node.expression;
-            while (isNonNullExpression(expr) && !(expr.flags & 32 /* OptionalChain */)) {
+            while (isNonNullExpression(expr) && !(expr.flags & 64 /* OptionalChain */)) {
               expr = expr.expression;
             }
-            if (expr.flags & 32 /* OptionalChain */) {
+            if (expr.flags & 64 /* OptionalChain */) {
               while (isNonNullExpression(node)) {
-                node.flags |= 32 /* OptionalChain */;
+                node.flags |= 64 /* OptionalChain */;
                 node = node.expression;
               }
               return true;
@@ -131637,6 +114657,8 @@ ${lanes.join("\n")}
             /*allowIdentifierNames*/
             true,
             /*allowPrivateIdentifiers*/
+            true,
+            /*allowUnicodeEscapeSequenceInIdentifierName*/
             true
           );
           const isOptionalChain2 = questionDotToken || tryReparseOptionalChain(expression);
@@ -131690,7 +114712,7 @@ ${lanes.join("\n")}
               continue;
             }
             if (isTemplateStartOfTaggedTemplate()) {
-              expression = !questionDotToken && expression.kind === 232 /* ExpressionWithTypeArguments */ ? parseTaggedTemplateRest(pos, expression.expression, questionDotToken, expression.typeArguments) : parseTaggedTemplateRest(
+              expression = !questionDotToken && expression.kind === 233 /* ExpressionWithTypeArguments */ ? parseTaggedTemplateRest(pos, expression.expression, questionDotToken, expression.typeArguments) : parseTaggedTemplateRest(
                 pos,
                 expression,
                 questionDotToken,
@@ -131729,8 +114751,8 @@ ${lanes.join("\n")}
               true
             )
           );
-          if (questionDotToken || tag.flags & 32 /* OptionalChain */) {
-            tagExpression.flags |= 32 /* OptionalChain */;
+          if (questionDotToken || tag.flags & 64 /* OptionalChain */) {
+            tagExpression.flags |= 64 /* OptionalChain */;
           }
           tagExpression.questionDotToken = questionDotToken;
           return finishNode(tagExpression, pos);
@@ -131753,7 +114775,7 @@ ${lanes.join("\n")}
               }
             }
             if (typeArguments || token() === 21 /* OpenParenToken */) {
-              if (!questionDotToken && expression.kind === 232 /* ExpressionWithTypeArguments */) {
+              if (!questionDotToken && expression.kind === 233 /* ExpressionWithTypeArguments */) {
                 typeArguments = expression.typeArguments;
                 expression = expression.expression;
               }
@@ -131782,7 +114804,7 @@ ${lanes.join("\n")}
           return result;
         }
         function parseTypeArgumentsInExpression() {
-          if ((contextFlags & 262144 /* JavaScriptFile */) !== 0) {
+          if ((contextFlags & 524288 /* JavaScriptFile */) !== 0) {
             return void 0;
           }
           if (reScanLessThanToken() !== 30 /* LessThanToken */) {
@@ -131914,10 +114936,10 @@ ${lanes.join("\n")}
             true
           );
           if (parseContextualModifier(139 /* GetKeyword */)) {
-            return parseAccessorDeclaration(pos, hasJSDoc, modifiers, 176 /* GetAccessor */, 0 /* None */);
+            return parseAccessorDeclaration(pos, hasJSDoc, modifiers, 177 /* GetAccessor */, 0 /* None */);
           }
           if (parseContextualModifier(153 /* SetKeyword */)) {
-            return parseAccessorDeclaration(pos, hasJSDoc, modifiers, 177 /* SetAccessor */, 0 /* None */);
+            return parseAccessorDeclaration(pos, hasJSDoc, modifiers, 178 /* SetAccessor */, 0 /* None */);
           }
           const asteriskToken = parseOptionalToken(42 /* AsteriskToken */);
           const tokenIsIdentifier = isIdentifier2();
@@ -132011,7 +115033,7 @@ ${lanes.join("\n")}
             false
           );
           let typeArguments;
-          if (expression.kind === 232 /* ExpressionWithTypeArguments */) {
+          if (expression.kind === 233 /* ExpressionWithTypeArguments */) {
             typeArguments = expression.typeArguments;
             expression = expression.expression;
           }
@@ -132121,7 +115143,8 @@ ${lanes.join("\n")}
           parseExpected(21 /* OpenParenToken */);
           let initializer;
           if (token() !== 27 /* SemicolonToken */) {
-            if (token() === 115 /* VarKeyword */ || token() === 121 /* LetKeyword */ || token() === 87 /* ConstKeyword */) {
+            if (token() === 115 /* VarKeyword */ || token() === 121 /* LetKeyword */ || token() === 87 /* ConstKeyword */ || token() === 160 /* UsingKeyword */ && lookAhead(nextTokenIsBindingIdentifierOrStartOfDestructuringOnSameLineDisallowOf) || // this one is meant to allow of
+            token() === 135 /* AwaitKeyword */ && lookAhead(nextTokenIsUsingKeywordThenBindingIdentifierOrStartOfObjectDestructuringOnSameLine)) {
               initializer = parseVariableDeclarationList(
                 /*inForStatementInitializer*/
                 true
@@ -132131,7 +115154,7 @@ ${lanes.join("\n")}
             }
           }
           let node;
-          if (awaitToken ? parseExpected(164 /* OfKeyword */) : parseOptional(164 /* OfKeyword */)) {
+          if (awaitToken ? parseExpected(165 /* OfKeyword */) : parseOptional(165 /* OfKeyword */)) {
             const expression = allowInAnd(() => parseAssignmentExpressionOrHigher(
               /*allowReturnTypeInArrowFunction*/
               true
@@ -132155,10 +115178,10 @@ ${lanes.join("\n")}
         function parseBreakOrContinueStatement(kind) {
           const pos = getNodePos();
           const hasJSDoc = hasPrecedingJSDocComment();
-          parseExpected(kind === 251 /* BreakStatement */ ? 83 /* BreakKeyword */ : 88 /* ContinueKeyword */);
+          parseExpected(kind === 252 /* BreakStatement */ ? 83 /* BreakKeyword */ : 88 /* ContinueKeyword */);
           const label = canParseSemicolon() ? void 0 : parseIdentifier();
           parseSemicolon();
-          const node = kind === 251 /* BreakStatement */ ? factory2.createBreakStatement(label) : factory2.createContinueStatement(label);
+          const node = kind === 252 /* BreakStatement */ ? factory2.createBreakStatement(label) : factory2.createContinueStatement(label);
           return withJSDoc(finishNode(node, pos), hasJSDoc);
         }
         function parseReturnStatement() {
@@ -132177,7 +115200,7 @@ ${lanes.join("\n")}
           const openParenParsed = parseExpected(21 /* OpenParenToken */);
           const expression = allowInAnd(parseExpression);
           parseExpectedMatchingBrackets(21 /* OpenParenToken */, 22 /* CloseParenToken */, openParenParsed, openParenPosition);
-          const statement = doInsideOfContext(33554432 /* InWithStatement */, parseStatement);
+          const statement = doInsideOfContext(67108864 /* InWithStatement */, parseStatement);
           return withJSDoc(finishNode(factory2.createWithStatement(expression, statement), pos), hasJSDoc);
         }
         function parseCaseClause() {
@@ -132317,6 +115340,10 @@ ${lanes.join("\n")}
               case 86 /* ClassKeyword */:
               case 94 /* EnumKeyword */:
                 return true;
+              case 160 /* UsingKeyword */:
+                return isUsingDeclaration();
+              case 135 /* AwaitKeyword */:
+                return isAwaitUsingDeclaration();
               case 120 /* InterfaceKeyword */:
               case 156 /* TypeKeyword */:
                 return nextTokenIsIdentifierOnSameLine();
@@ -132331,12 +115358,16 @@ ${lanes.join("\n")}
               case 124 /* ProtectedKeyword */:
               case 125 /* PublicKeyword */:
               case 148 /* ReadonlyKeyword */:
+                const previousToken = token();
                 nextToken();
                 if (scanner2.hasPrecedingLineBreak()) {
                   return false;
                 }
+                if (previousToken === 138 /* DeclareKeyword */ && token() === 156 /* TypeKeyword */) {
+                  return true;
+                }
                 continue;
-              case 161 /* GlobalKeyword */:
+              case 162 /* GlobalKeyword */:
                 nextToken();
                 return token() === 19 /* OpenBraceToken */ || token() === 80 /* Identifier */ || token() === 95 /* ExportKeyword */;
               case 102 /* ImportKeyword */:
@@ -132369,6 +115400,7 @@ ${lanes.join("\n")}
             case 19 /* OpenBraceToken */:
             case 115 /* VarKeyword */:
             case 121 /* LetKeyword */:
+            case 160 /* UsingKeyword */:
             case 100 /* FunctionKeyword */:
             case 86 /* ClassKeyword */:
             case 94 /* EnumKeyword */:
@@ -132398,7 +115430,7 @@ ${lanes.join("\n")}
             case 144 /* ModuleKeyword */:
             case 145 /* NamespaceKeyword */:
             case 156 /* TypeKeyword */:
-            case 161 /* GlobalKeyword */:
+            case 162 /* GlobalKeyword */:
               return true;
             case 129 /* AccessorKeyword */:
             case 125 /* PublicKeyword */:
@@ -132418,6 +115450,30 @@ ${lanes.join("\n")}
         function isLetDeclaration() {
           return lookAhead(nextTokenIsBindingIdentifierOrStartOfDestructuring);
         }
+        function nextTokenIsBindingIdentifierOrStartOfDestructuringOnSameLineDisallowOf() {
+          return nextTokenIsBindingIdentifierOrStartOfDestructuringOnSameLine(
+            /*disallowOf*/
+            true
+          );
+        }
+        function nextTokenIsBindingIdentifierOrStartOfDestructuringOnSameLine(disallowOf) {
+          nextToken();
+          if (disallowOf && token() === 165 /* OfKeyword */)
+            return false;
+          return (isBindingIdentifier() || token() === 19 /* OpenBraceToken */) && !scanner2.hasPrecedingLineBreak();
+        }
+        function isUsingDeclaration() {
+          return lookAhead(nextTokenIsBindingIdentifierOrStartOfDestructuringOnSameLine);
+        }
+        function nextTokenIsUsingKeywordThenBindingIdentifierOrStartOfObjectDestructuringOnSameLine(disallowOf) {
+          if (nextToken() === 160 /* UsingKeyword */) {
+            return nextTokenIsBindingIdentifierOrStartOfDestructuringOnSameLine(disallowOf);
+          }
+          return false;
+        }
+        function isAwaitUsingDeclaration() {
+          return lookAhead(nextTokenIsUsingKeywordThenBindingIdentifierOrStartOfObjectDestructuringOnSameLine);
+        }
         function parseStatement() {
           switch (token()) {
             case 27 /* SemicolonToken */:
@@ -132444,6 +115500,26 @@ ${lanes.join("\n")}
                 );
               }
               break;
+            case 135 /* AwaitKeyword */:
+              if (isAwaitUsingDeclaration()) {
+                return parseVariableStatement(
+                  getNodePos(),
+                  hasPrecedingJSDocComment(),
+                  /*modifiers*/
+                  void 0
+                );
+              }
+              break;
+            case 160 /* UsingKeyword */:
+              if (isUsingDeclaration()) {
+                return parseVariableStatement(
+                  getNodePos(),
+                  hasPrecedingJSDocComment(),
+                  /*modifiers*/
+                  void 0
+                );
+              }
+              break;
             case 100 /* FunctionKeyword */:
               return parseFunctionDeclaration(
                 getNodePos(),
@@ -132467,9 +115543,9 @@ ${lanes.join("\n")}
             case 99 /* ForKeyword */:
               return parseForOrForInOrForOfStatement();
             case 88 /* ContinueKeyword */:
-              return parseBreakOrContinueStatement(250 /* ContinueStatement */);
+              return parseBreakOrContinueStatement(251 /* ContinueStatement */);
             case 83 /* BreakKeyword */:
-              return parseBreakOrContinueStatement(251 /* BreakStatement */);
+              return parseBreakOrContinueStatement(252 /* BreakStatement */);
             case 107 /* ReturnKeyword */:
               return parseReturnStatement();
             case 118 /* WithKeyword */:
@@ -132503,7 +115579,7 @@ ${lanes.join("\n")}
             case 129 /* AccessorKeyword */:
             case 126 /* StaticKeyword */:
             case 148 /* ReadonlyKeyword */:
-            case 161 /* GlobalKeyword */:
+            case 162 /* GlobalKeyword */:
               if (isStartOfDeclaration()) {
                 return parseDeclaration();
               }
@@ -132528,15 +115604,15 @@ ${lanes.join("\n")}
               return node;
             }
             for (const m of modifiers) {
-              m.flags |= 16777216 /* Ambient */;
+              m.flags |= 33554432 /* Ambient */;
             }
-            return doInsideOfContext(16777216 /* Ambient */, () => parseDeclarationWorker(pos, hasJSDoc, modifiers));
+            return doInsideOfContext(33554432 /* Ambient */, () => parseDeclarationWorker(pos, hasJSDoc, modifiers));
           } else {
             return parseDeclarationWorker(pos, hasJSDoc, modifiers);
           }
         }
         function tryReuseAmbientDeclaration(pos) {
-          return doInsideOfContext(16777216 /* Ambient */, () => {
+          return doInsideOfContext(33554432 /* Ambient */, () => {
             const node = currentNode(parsingContext, pos);
             if (node) {
               return consumeNode(node);
@@ -132548,6 +115624,8 @@ ${lanes.join("\n")}
             case 115 /* VarKeyword */:
             case 121 /* LetKeyword */:
             case 87 /* ConstKeyword */:
+            case 160 /* UsingKeyword */:
+            case 135 /* AwaitKeyword */:
               return parseVariableStatement(pos, hasJSDoc, modifiersIn);
             case 100 /* FunctionKeyword */:
               return parseFunctionDeclaration(pos, hasJSDoc, modifiersIn);
@@ -132559,7 +115637,7 @@ ${lanes.join("\n")}
               return parseTypeAliasDeclaration(pos, hasJSDoc, modifiersIn);
             case 94 /* EnumKeyword */:
               return parseEnumDeclaration(pos, hasJSDoc, modifiersIn);
-            case 161 /* GlobalKeyword */:
+            case 162 /* GlobalKeyword */:
             case 144 /* ModuleKeyword */:
             case 145 /* NamespaceKeyword */:
               return parseModuleDeclaration(pos, hasJSDoc, modifiersIn);
@@ -132579,7 +115657,7 @@ ${lanes.join("\n")}
             default:
               if (modifiersIn) {
                 const missing = createMissingNode(
-                  281 /* MissingDeclaration */,
+                  282 /* MissingDeclaration */,
                   /*reportAtCurrentPosition*/
                   true,
                   Diagnostics.Declaration_expected
@@ -132591,6 +115669,9 @@ ${lanes.join("\n")}
               return void 0;
           }
         }
+        function nextTokenIsStringLiteral() {
+          return nextToken() === 11 /* StringLiteral */;
+        }
         function nextTokenIsIdentifierOrStringLiteralOnSameLine() {
           nextToken();
           return !scanner2.hasPrecedingLineBreak() && (isIdentifier2() || token() === 11 /* StringLiteral */);
@@ -132643,14 +115724,14 @@ ${lanes.join("\n")}
         function parseObjectBindingPattern() {
           const pos = getNodePos();
           parseExpected(19 /* OpenBraceToken */);
-          const elements = parseDelimitedList(9 /* ObjectBindingElements */, parseObjectBindingElement);
+          const elements = allowInAnd(() => parseDelimitedList(9 /* ObjectBindingElements */, parseObjectBindingElement));
           parseExpected(20 /* CloseBraceToken */);
           return finishNode(factory2.createObjectBindingPattern(elements), pos);
         }
         function parseArrayBindingPattern() {
           const pos = getNodePos();
           parseExpected(23 /* OpenBracketToken */);
-          const elements = parseDelimitedList(10 /* ArrayBindingElements */, parseArrayBindingElement);
+          const elements = allowInAnd(() => parseDelimitedList(10 /* ArrayBindingElements */, parseArrayBindingElement));
           parseExpected(24 /* CloseBracketToken */);
           return finishNode(factory2.createArrayBindingPattern(elements), pos);
         }
@@ -132697,12 +115778,20 @@ ${lanes.join("\n")}
             case 87 /* ConstKeyword */:
               flags |= 2 /* Const */;
               break;
+            case 160 /* UsingKeyword */:
+              flags |= 4 /* Using */;
+              break;
+            case 135 /* AwaitKeyword */:
+              Debug.assert(isAwaitUsingDeclaration());
+              flags |= 6 /* AwaitUsing */;
+              nextToken();
+              break;
             default:
               Debug.fail();
           }
           nextToken();
           let declarations;
-          if (token() === 164 /* OfKeyword */ && lookAhead(canFollowContextualOfKeyword)) {
+          if (token() === 165 /* OfKeyword */ && lookAhead(canFollowContextualOfKeyword)) {
             declarations = createMissingList();
           } else {
             const savedDisallowIn = inDisallowInContext();
@@ -132732,11 +115821,11 @@ ${lanes.join("\n")}
           const modifierFlags = modifiersToFlags(modifiers);
           parseExpected(100 /* FunctionKeyword */);
           const asteriskToken = parseOptionalToken(42 /* AsteriskToken */);
-          const name = modifierFlags & 1024 /* Default */ ? parseOptionalBindingIdentifier() : parseBindingIdentifier();
+          const name = modifierFlags & 2048 /* Default */ ? parseOptionalBindingIdentifier() : parseBindingIdentifier();
           const isGenerator = asteriskToken ? 1 /* Yield */ : 0 /* None */;
-          const isAsync = modifierFlags & 512 /* Async */ ? 2 /* Await */ : 0 /* None */;
+          const isAsync = modifierFlags & 1024 /* Async */ ? 2 /* Await */ : 0 /* None */;
           const typeParameters = parseTypeParameters();
-          if (modifierFlags & 1 /* Export */)
+          if (modifierFlags & 32 /* Export */)
             setAwaitContext(
               /*value*/
               true
@@ -132808,7 +115897,7 @@ ${lanes.join("\n")}
         function parsePropertyDeclaration(pos, hasJSDoc, modifiers, name, questionToken) {
           const exclamationToken = !questionToken && !scanner2.hasPrecedingLineBreak() ? parseOptionalToken(54 /* ExclamationToken */) : void 0;
           const type = parseTypeAnnotation();
-          const initializer = doOutsideOfContext(8192 /* YieldContext */ | 32768 /* AwaitContext */ | 4096 /* DisallowInContext */, parseInitializer);
+          const initializer = doOutsideOfContext(16384 /* YieldContext */ | 65536 /* AwaitContext */ | 8192 /* DisallowInContext */, parseInitializer);
           parseSemicolonAfterPropertyName(name, type, initializer);
           const node = factory2.createPropertyDeclaration(
             modifiers,
@@ -132848,7 +115937,7 @@ ${lanes.join("\n")}
             false
           );
           const body = parseFunctionBlockOrSemicolon(flags);
-          const node = kind === 176 /* GetAccessor */ ? factory2.createGetAccessorDeclaration(modifiers, name, parameters, type, body) : factory2.createSetAccessorDeclaration(modifiers, name, parameters, body);
+          const node = kind === 177 /* GetAccessor */ ? factory2.createGetAccessorDeclaration(modifiers, name, parameters, type, body) : factory2.createSetAccessorDeclaration(modifiers, name, parameters, body);
           node.typeParameters = typeParameters;
           if (isSetAccessorDeclaration(node))
             node.type = type;
@@ -133014,10 +116103,10 @@ ${lanes.join("\n")}
             return parseClassStaticBlockDeclaration(pos, hasJSDoc, modifiers);
           }
           if (parseContextualModifier(139 /* GetKeyword */)) {
-            return parseAccessorDeclaration(pos, hasJSDoc, modifiers, 176 /* GetAccessor */, 0 /* None */);
+            return parseAccessorDeclaration(pos, hasJSDoc, modifiers, 177 /* GetAccessor */, 0 /* None */);
           }
           if (parseContextualModifier(153 /* SetKeyword */)) {
-            return parseAccessorDeclaration(pos, hasJSDoc, modifiers, 177 /* SetAccessor */, 0 /* None */);
+            return parseAccessorDeclaration(pos, hasJSDoc, modifiers, 178 /* SetAccessor */, 0 /* None */);
           }
           if (token() === 137 /* ConstructorKeyword */ || token() === 11 /* StringLiteral */) {
             const constructorDeclaration = tryParseConstructorDeclaration(pos, hasJSDoc, modifiers);
@@ -133032,9 +116121,9 @@ ${lanes.join("\n")}
             const isAmbient = some(modifiers, isDeclareModifier);
             if (isAmbient) {
               for (const m of modifiers) {
-                m.flags |= 16777216 /* Ambient */;
+                m.flags |= 33554432 /* Ambient */;
               }
-              return doInsideOfContext(16777216 /* Ambient */, () => parsePropertyOrMethodDeclaration(pos, hasJSDoc, modifiers));
+              return doInsideOfContext(33554432 /* Ambient */, () => parsePropertyOrMethodDeclaration(pos, hasJSDoc, modifiers));
             } else {
               return parsePropertyOrMethodDeclaration(pos, hasJSDoc, modifiers);
             }
@@ -133065,10 +116154,10 @@ ${lanes.join("\n")}
             true
           );
           if (token() === 86 /* ClassKeyword */) {
-            return parseClassDeclarationOrExpression(pos, hasJSDoc, modifiers, 230 /* ClassExpression */);
+            return parseClassDeclarationOrExpression(pos, hasJSDoc, modifiers, 231 /* ClassExpression */);
           }
           const missing = createMissingNode(
-            281 /* MissingDeclaration */,
+            282 /* MissingDeclaration */,
             /*reportAtCurrentPosition*/
             true,
             Diagnostics.Expression_expected
@@ -133083,11 +116172,11 @@ ${lanes.join("\n")}
             hasPrecedingJSDocComment(),
             /*modifiers*/
             void 0,
-            230 /* ClassExpression */
+            231 /* ClassExpression */
           );
         }
         function parseClassDeclaration(pos, hasJSDoc, modifiers) {
-          return parseClassDeclarationOrExpression(pos, hasJSDoc, modifiers, 262 /* ClassDeclaration */);
+          return parseClassDeclarationOrExpression(pos, hasJSDoc, modifiers, 263 /* ClassDeclaration */);
         }
         function parseClassDeclarationOrExpression(pos, hasJSDoc, modifiers, kind) {
           const savedAwaitContext = inAwaitContext();
@@ -133108,7 +116197,7 @@ ${lanes.join("\n")}
             members = createMissingList();
           }
           setAwaitContext(savedAwaitContext);
-          const node = kind === 262 /* ClassDeclaration */ ? factory2.createClassDeclaration(modifiers, name, typeParameters, heritageClauses, members) : factory2.createClassExpression(modifiers, name, typeParameters, heritageClauses, members);
+          const node = kind === 263 /* ClassDeclaration */ ? factory2.createClassDeclaration(modifiers, name, typeParameters, heritageClauses, members) : factory2.createClassExpression(modifiers, name, typeParameters, heritageClauses, members);
           return withJSDoc(finishNode(node, pos), hasJSDoc);
         }
         function parseNameOfClassDeclarationOrExpression() {
@@ -133134,7 +116223,7 @@ ${lanes.join("\n")}
         function parseExpressionWithTypeArguments() {
           const pos = getNodePos();
           const expression = parseLeftHandSideExpressionOrHigher();
-          if (expression.kind === 232 /* ExpressionWithTypeArguments */) {
+          if (expression.kind === 233 /* ExpressionWithTypeArguments */) {
             return expression;
           }
           const typeArguments = tryParseTypeArguments();
@@ -133160,6 +116249,9 @@ ${lanes.join("\n")}
         }
         function parseTypeAliasDeclaration(pos, hasJSDoc, modifiers) {
           parseExpected(156 /* TypeKeyword */);
+          if (scanner2.hasPrecedingLineBreak()) {
+            parseErrorAtCurrentToken(Diagnostics.Line_break_not_permitted_here);
+          }
           const name = parseIdentifier();
           const typeParameters = parseTypeParameters();
           parseExpected(64 /* EqualsToken */);
@@ -133200,15 +116292,15 @@ ${lanes.join("\n")}
           return finishNode(factory2.createModuleBlock(statements), pos);
         }
         function parseModuleOrNamespaceDeclaration(pos, hasJSDoc, modifiers, flags) {
-          const namespaceFlag = flags & 16 /* Namespace */;
-          const name = parseIdentifier();
+          const namespaceFlag = flags & 32 /* Namespace */;
+          const name = flags & 8 /* NestedNamespace */ ? parseIdentifierName() : parseIdentifier();
           const body = parseOptional(25 /* DotToken */) ? parseModuleOrNamespaceDeclaration(
             getNodePos(),
             /*hasJSDoc*/
             false,
             /*modifiers*/
             void 0,
-            4 /* NestedNamespace */ | namespaceFlag
+            8 /* NestedNamespace */ | namespaceFlag
           ) : parseModuleBlock();
           const node = factory2.createModuleDeclaration(modifiers, name, body, flags);
           return withJSDoc(finishNode(node, pos), hasJSDoc);
@@ -133216,9 +116308,9 @@ ${lanes.join("\n")}
         function parseAmbientExternalModuleDeclaration(pos, hasJSDoc, modifiersIn) {
           let flags = 0;
           let name;
-          if (token() === 161 /* GlobalKeyword */) {
+          if (token() === 162 /* GlobalKeyword */) {
             name = parseIdentifier();
-            flags |= 1024 /* GlobalAugmentation */;
+            flags |= 2048 /* GlobalAugmentation */;
           } else {
             name = parseLiteralNode();
             name.text = internIdentifier(name.text);
@@ -133234,10 +116326,10 @@ ${lanes.join("\n")}
         }
         function parseModuleDeclaration(pos, hasJSDoc, modifiersIn) {
           let flags = 0;
-          if (token() === 161 /* GlobalKeyword */) {
+          if (token() === 162 /* GlobalKeyword */) {
             return parseAmbientExternalModuleDeclaration(pos, hasJSDoc, modifiersIn);
           } else if (parseOptional(145 /* NamespaceKeyword */)) {
-            flags |= 16 /* Namespace */;
+            flags |= 32 /* Namespace */;
           } else {
             parseExpected(144 /* ModuleKeyword */);
             if (token() === 11 /* StringLiteral */) {
@@ -133275,7 +116367,7 @@ ${lanes.join("\n")}
             identifier = parseIdentifier();
           }
           let isTypeOnly = false;
-          if (token() !== 160 /* FromKeyword */ && (identifier == null ? void 0 : identifier.escapedText) === "type" && (isIdentifier2() || tokenAfterImportDefinitelyProducesImportDeclaration())) {
+          if (token() !== 161 /* FromKeyword */ && (identifier == null ? void 0 : identifier.escapedText) === "type" && (isIdentifier2() || tokenAfterImportDefinitelyProducesImportDeclaration())) {
             isTypeOnly = true;
             identifier = isIdentifier2() ? parseIdentifier() : void 0;
           }
@@ -133287,18 +116379,19 @@ ${lanes.join("\n")}
           token() === 42 /* AsteriskToken */ || // import *
           token() === 19 /* OpenBraceToken */) {
             importClause = parseImportClause(identifier, afterImportPos, isTypeOnly);
-            parseExpected(160 /* FromKeyword */);
+            parseExpected(161 /* FromKeyword */);
           }
           const moduleSpecifier = parseModuleSpecifier();
-          let assertClause;
-          if (token() === 132 /* AssertKeyword */ && !scanner2.hasPrecedingLineBreak()) {
-            assertClause = parseAssertClause();
+          const currentToken2 = token();
+          let attributes;
+          if ((currentToken2 === 118 /* WithKeyword */ || currentToken2 === 132 /* AssertKeyword */) && !scanner2.hasPrecedingLineBreak()) {
+            attributes = parseImportAttributes(currentToken2);
           }
           parseSemicolon();
-          const node = factory2.createImportDeclaration(modifiers, importClause, moduleSpecifier, assertClause);
+          const node = factory2.createImportDeclaration(modifiers, importClause, moduleSpecifier, attributes);
           return withJSDoc(finishNode(node, pos), hasJSDoc);
         }
-        function parseAssertEntry() {
+        function parseImportAttribute() {
           const pos = getNodePos();
           const name = tokenIsIdentifierOrKeyword(token()) ? parseIdentifierName() : parseLiteralLikeNode(11 /* StringLiteral */);
           parseExpected(59 /* ColonToken */);
@@ -133306,19 +116399,19 @@ ${lanes.join("\n")}
             /*allowReturnTypeInArrowFunction*/
             true
           );
-          return finishNode(factory2.createAssertEntry(name, value), pos);
+          return finishNode(factory2.createImportAttribute(name, value), pos);
         }
-        function parseAssertClause(skipAssertKeyword) {
+        function parseImportAttributes(token2, skipKeyword) {
           const pos = getNodePos();
-          if (!skipAssertKeyword) {
-            parseExpected(132 /* AssertKeyword */);
+          if (!skipKeyword) {
+            parseExpected(token2);
           }
           const openBracePosition = scanner2.getTokenStart();
           if (parseExpected(19 /* OpenBraceToken */)) {
             const multiLine = scanner2.hasPrecedingLineBreak();
             const elements = parseDelimitedList(
-              24 /* AssertEntries */,
-              parseAssertEntry,
+              24 /* ImportAttributes */,
+              parseImportAttribute,
               /*considerSemicolonAsDelimiter*/
               true
             );
@@ -133327,11 +116420,11 @@ ${lanes.join("\n")}
               if (lastError && lastError.code === Diagnostics._0_expected.code) {
                 addRelatedInfo(
                   lastError,
-                  createDetachedDiagnostic(fileName, openBracePosition, 1, Diagnostics.The_parser_expected_to_find_a_1_to_match_the_0_token_here, "{", "}")
+                  createDetachedDiagnostic(fileName, sourceText, openBracePosition, 1, Diagnostics.The_parser_expected_to_find_a_1_to_match_the_0_token_here, "{", "}")
                 );
               }
             }
-            return finishNode(factory2.createAssertClause(elements, multiLine), pos);
+            return finishNode(factory2.createImportAttributes(elements, multiLine, token2), pos);
           } else {
             const elements = createNodeArray(
               [],
@@ -133341,10 +116434,11 @@ ${lanes.join("\n")}
               /*hasTrailingComma*/
               false
             );
-            return finishNode(factory2.createAssertClause(
+            return finishNode(factory2.createImportAttributes(
               elements,
               /*multiLine*/
-              false
+              false,
+              token2
             ), pos);
           }
         }
@@ -133352,7 +116446,7 @@ ${lanes.join("\n")}
           return token() === 42 /* AsteriskToken */ || token() === 19 /* OpenBraceToken */;
         }
         function tokenAfterImportedIdentifierDefinitelyProducesImportDeclaration() {
-          return token() === 28 /* CommaToken */ || token() === 160 /* FromKeyword */;
+          return token() === 28 /* CommaToken */ || token() === 161 /* FromKeyword */;
         }
         function parseImportEqualsDeclaration(pos, hasJSDoc, modifiers, identifier, isTypeOnly) {
           parseExpected(64 /* EqualsToken */);
@@ -133365,7 +116459,7 @@ ${lanes.join("\n")}
         function parseImportClause(identifier, pos, isTypeOnly) {
           let namedBindings;
           if (!identifier || parseOptional(28 /* CommaToken */)) {
-            namedBindings = token() === 42 /* AsteriskToken */ ? parseNamespaceImport() : parseNamedImportsOrExports(274 /* NamedImports */);
+            namedBindings = token() === 42 /* AsteriskToken */ ? parseNamespaceImport() : parseNamedImportsOrExports(275 /* NamedImports */);
           }
           return finishNode(factory2.createImportClause(isTypeOnly, identifier, namedBindings), pos);
         }
@@ -133401,15 +116495,15 @@ ${lanes.join("\n")}
         }
         function parseNamedImportsOrExports(kind) {
           const pos = getNodePos();
-          const node = kind === 274 /* NamedImports */ ? factory2.createNamedImports(parseBracketedList(23 /* ImportOrExportSpecifiers */, parseImportSpecifier, 19 /* OpenBraceToken */, 20 /* CloseBraceToken */)) : factory2.createNamedExports(parseBracketedList(23 /* ImportOrExportSpecifiers */, parseExportSpecifier, 19 /* OpenBraceToken */, 20 /* CloseBraceToken */));
+          const node = kind === 275 /* NamedImports */ ? factory2.createNamedImports(parseBracketedList(23 /* ImportOrExportSpecifiers */, parseImportSpecifier, 19 /* OpenBraceToken */, 20 /* CloseBraceToken */)) : factory2.createNamedExports(parseBracketedList(23 /* ImportOrExportSpecifiers */, parseExportSpecifier, 19 /* OpenBraceToken */, 20 /* CloseBraceToken */));
           return finishNode(node, pos);
         }
         function parseExportSpecifier() {
           const hasJSDoc = hasPrecedingJSDocComment();
-          return withJSDoc(parseImportOrExportSpecifier(280 /* ExportSpecifier */), hasJSDoc);
+          return withJSDoc(parseImportOrExportSpecifier(281 /* ExportSpecifier */), hasJSDoc);
         }
         function parseImportSpecifier() {
-          return parseImportOrExportSpecifier(275 /* ImportSpecifier */);
+          return parseImportOrExportSpecifier(276 /* ImportSpecifier */);
         }
         function parseImportOrExportSpecifier(kind) {
           const pos = getNodePos();
@@ -133453,10 +116547,10 @@ ${lanes.join("\n")}
             parseExpected(130 /* AsKeyword */);
             name = parseNameWithKeywordCheck();
           }
-          if (kind === 275 /* ImportSpecifier */ && checkIdentifierIsKeyword) {
+          if (kind === 276 /* ImportSpecifier */ && checkIdentifierIsKeyword) {
             parseErrorAt(checkIdentifierStart, checkIdentifierEnd, Diagnostics.Identifier_expected);
           }
-          const node = kind === 275 /* ImportSpecifier */ ? factory2.createImportSpecifier(isTypeOnly, propertyName, name) : factory2.createExportSpecifier(isTypeOnly, propertyName, name);
+          const node = kind === 276 /* ImportSpecifier */ ? factory2.createImportSpecifier(isTypeOnly, propertyName, name) : factory2.createExportSpecifier(isTypeOnly, propertyName, name);
           return finishNode(node, pos);
           function parseNameWithKeywordCheck() {
             checkIdentifierIsKeyword = isKeyword(token()) && !isIdentifier2();
@@ -133476,28 +116570,29 @@ ${lanes.join("\n")}
           );
           let exportClause;
           let moduleSpecifier;
-          let assertClause;
+          let attributes;
           const isTypeOnly = parseOptional(156 /* TypeKeyword */);
           const namespaceExportPos = getNodePos();
           if (parseOptional(42 /* AsteriskToken */)) {
             if (parseOptional(130 /* AsKeyword */)) {
               exportClause = parseNamespaceExport(namespaceExportPos);
             }
-            parseExpected(160 /* FromKeyword */);
+            parseExpected(161 /* FromKeyword */);
             moduleSpecifier = parseModuleSpecifier();
           } else {
-            exportClause = parseNamedImportsOrExports(278 /* NamedExports */);
-            if (token() === 160 /* FromKeyword */ || token() === 11 /* StringLiteral */ && !scanner2.hasPrecedingLineBreak()) {
-              parseExpected(160 /* FromKeyword */);
+            exportClause = parseNamedImportsOrExports(279 /* NamedExports */);
+            if (token() === 161 /* FromKeyword */ || token() === 11 /* StringLiteral */ && !scanner2.hasPrecedingLineBreak()) {
+              parseExpected(161 /* FromKeyword */);
               moduleSpecifier = parseModuleSpecifier();
             }
           }
-          if (moduleSpecifier && token() === 132 /* AssertKeyword */ && !scanner2.hasPrecedingLineBreak()) {
-            assertClause = parseAssertClause();
+          const currentToken2 = token();
+          if (moduleSpecifier && (currentToken2 === 118 /* WithKeyword */ || currentToken2 === 132 /* AssertKeyword */) && !scanner2.hasPrecedingLineBreak()) {
+            attributes = parseImportAttributes(currentToken2);
           }
           parseSemicolon();
           setAwaitContext(savedAwaitContext);
-          const node = factory2.createExportDeclaration(modifiers, isTypeOnly, exportClause, moduleSpecifier, assertClause);
+          const node = factory2.createExportDeclaration(modifiers, isTypeOnly, exportClause, moduleSpecifier, attributes);
           return withJSDoc(finishNode(node, pos), hasJSDoc);
         }
         function parseExportAssignment(pos, hasJSDoc, modifiers) {
@@ -133547,7 +116642,7 @@ ${lanes.join("\n")}
           ParsingContext2[ParsingContext2["TupleElementTypes"] = 21] = "TupleElementTypes";
           ParsingContext2[ParsingContext2["HeritageClauses"] = 22] = "HeritageClauses";
           ParsingContext2[ParsingContext2["ImportOrExportSpecifiers"] = 23] = "ImportOrExportSpecifiers";
-          ParsingContext2[ParsingContext2["AssertEntries"] = 24] = "AssertEntries";
+          ParsingContext2[ParsingContext2["ImportAttributes"] = 24] = "ImportAttributes";
           ParsingContext2[ParsingContext2["JSDocComment"] = 25] = "JSDocComment";
           ParsingContext2[ParsingContext2["Count"] = 26] = "Count";
         })(ParsingContext || (ParsingContext = {}));
@@ -133566,7 +116661,8 @@ ${lanes.join("\n")}
               99 /* Latest */,
               /*syntaxCursor*/
               void 0,
-              1 /* JS */
+              1 /* JS */,
+              0 /* ParseAll */
             );
             scanner2.setText(content, start, length2);
             currentToken = scanner2.scan();
@@ -133593,7 +116689,7 @@ ${lanes.join("\n")}
           function parseJSDocTypeExpression(mayOmitBraces) {
             const pos = getNodePos();
             const hasBrace = (mayOmitBraces ? parseOptional : parseExpected)(19 /* OpenBraceToken */);
-            const type = doInsideOfContext(8388608 /* JSDoc */, parseJSDocType);
+            const type = doInsideOfContext(16777216 /* JSDoc */, parseJSDocType);
             if (!mayOmitBraces || hasBrace) {
               parseExpectedJSDoc(20 /* CloseBraceToken */);
             }
@@ -133630,9 +116726,10 @@ ${lanes.join("\n")}
               99 /* Latest */,
               /*syntaxCursor*/
               void 0,
-              1 /* JS */
+              1 /* JS */,
+              0 /* ParseAll */
             );
-            const jsDoc = doInsideOfContext(8388608 /* JSDoc */, () => parseJSDocCommentWorker(start, length2));
+            const jsDoc = doInsideOfContext(16777216 /* JSDoc */, () => parseJSDocCommentWorker(start, length2));
             const sourceFile = { languageVariant: 0 /* Standard */, text: content };
             const diagnostics = attachFileToDiagnostics(parseDiagnostics, sourceFile);
             clearState();
@@ -133643,9 +116740,9 @@ ${lanes.join("\n")}
             const saveToken = currentToken;
             const saveParseDiagnosticsLength = parseDiagnostics.length;
             const saveParseErrorBeforeNextFinishedNode = parseErrorBeforeNextFinishedNode;
-            const comment = doInsideOfContext(8388608 /* JSDoc */, () => parseJSDocCommentWorker(start, length2));
+            const comment = doInsideOfContext(16777216 /* JSDoc */, () => parseJSDocCommentWorker(start, length2));
             setParent(comment, parent2);
-            if (contextFlags & 262144 /* JavaScriptFile */) {
+            if (contextFlags & 524288 /* JavaScriptFile */) {
               if (!jsDocDiagnostics) {
                 jsDocDiagnostics = [];
               }
@@ -133671,8 +116768,6 @@ ${lanes.join("\n")}
             PropertyLikeParse2[PropertyLikeParse2["CallbackParameter"] = 4] = "CallbackParameter";
           })(PropertyLikeParse || (PropertyLikeParse = {}));
           function parseJSDocCommentWorker(start = 0, length2) {
-            const saveParsingContext = parsingContext;
-            parsingContext |= 1 << 25 /* JSDocComment */;
             const content = sourceText;
             const end = length2 === void 0 ? content.length : start + length2;
             length2 = end - start;
@@ -133689,26 +116784,28 @@ ${lanes.join("\n")}
             let commentsPos;
             let comments = [];
             const parts = [];
+            const saveParsingContext = parsingContext;
+            parsingContext |= 1 << 25 /* JSDocComment */;
             const result = scanner2.scanRange(start + 3, length2 - 5, doJSDocScan);
             parsingContext = saveParsingContext;
             return result;
             function doJSDocScan() {
               let state = 1 /* SawAsterisk */;
               let margin;
-              let indent2 = start - (content.lastIndexOf("\n", start) + 1) + 4;
+              let indent3 = start - (content.lastIndexOf("\n", start) + 1) + 4;
               function pushComment(text) {
                 if (!margin) {
-                  margin = indent2;
+                  margin = indent3;
                 }
                 comments.push(text);
-                indent2 += text.length;
+                indent3 += text.length;
               }
               nextTokenJSDoc();
               while (parseOptionalJsdoc(5 /* WhitespaceTrivia */))
                 ;
               if (parseOptionalJsdoc(4 /* NewLineTrivia */)) {
                 state = 0 /* BeginningOfLine */;
-                indent2 = 0;
+                indent3 = 0;
               }
               loop:
                 while (true) {
@@ -133717,14 +116814,14 @@ ${lanes.join("\n")}
                       removeTrailingWhitespace(comments);
                       if (!commentsPos)
                         commentsPos = getNodePos();
-                      addTag(parseTag(indent2));
+                      addTag(parseTag(indent3));
                       state = 0 /* BeginningOfLine */;
                       margin = void 0;
                       break;
                     case 4 /* NewLineTrivia */:
                       comments.push(scanner2.getTokenText());
                       state = 0 /* BeginningOfLine */;
-                      indent2 = 0;
+                      indent3 = 0;
                       break;
                     case 42 /* AsteriskToken */:
                       const asterisk = scanner2.getTokenText();
@@ -133734,16 +116831,16 @@ ${lanes.join("\n")}
                       } else {
                         Debug.assert(state === 0 /* BeginningOfLine */);
                         state = 1 /* SawAsterisk */;
-                        indent2 += asterisk.length;
+                        indent3 += asterisk.length;
                       }
                       break;
                     case 5 /* WhitespaceTrivia */:
                       Debug.assert(state !== 2 /* SavingComments */, "whitespace shouldn't come from the scanner while saving top-level comment text");
                       const whitespace = scanner2.getTokenText();
-                      if (margin !== void 0 && indent2 + whitespace.length > margin) {
-                        comments.push(whitespace.slice(margin - indent2));
+                      if (margin !== void 0 && indent3 + whitespace.length > margin) {
+                        comments.push(whitespace.slice(margin - indent3));
                       }
-                      indent2 += whitespace.length;
+                      indent3 += whitespace.length;
                       break;
                     case 1 /* EndOfFileToken */:
                       break loop;
@@ -133780,7 +116877,7 @@ ${lanes.join("\n")}
                     nextTokenJSDoc();
                   }
                 }
-              const trimmedComments = trimStringEnd(comments.join(""));
+              const trimmedComments = comments.join("").trimEnd();
               if (parts.length && trimmedComments.length) {
                 parts.push(finishNode(factory2.createJSDocText(trimmedComments), linkEnd ?? start, commentsPos));
               }
@@ -133796,7 +116893,7 @@ ${lanes.join("\n")}
             }
             function removeTrailingWhitespace(comments2) {
               while (comments2.length) {
-                const trimmed = trimStringEnd(comments2[comments2.length - 1]);
+                const trimmed = comments2[comments2.length - 1].trimEnd();
                 if (trimmed === "") {
                   comments2.pop();
                 } else if (trimmed.length < comments2[comments2.length - 1].length) {
@@ -133945,7 +117042,7 @@ ${lanes.join("\n")}
               }
               return parseTagComments(margin, indentText.slice(margin));
             }
-            function parseTagComments(indent2, initialMargin) {
+            function parseTagComments(indent3, initialMargin) {
               const commentsPos2 = getNodePos();
               let comments2 = [];
               const parts2 = [];
@@ -133954,10 +117051,10 @@ ${lanes.join("\n")}
               let margin;
               function pushComment(text) {
                 if (!margin) {
-                  margin = indent2;
+                  margin = indent3;
                 }
                 comments2.push(text);
-                indent2 += text.length;
+                indent3 += text.length;
               }
               if (initialMargin !== void 0) {
                 if (initialMargin !== "") {
@@ -133972,7 +117069,7 @@ ${lanes.join("\n")}
                     case 4 /* NewLineTrivia */:
                       state = 0 /* BeginningOfLine */;
                       comments2.push(scanner2.getTokenText());
-                      indent2 = 0;
+                      indent3 = 0;
                       break;
                     case 60 /* AtToken */:
                       scanner2.resetTokenState(scanner2.getTokenEnd() - 1);
@@ -133982,11 +117079,11 @@ ${lanes.join("\n")}
                     case 5 /* WhitespaceTrivia */:
                       Debug.assert(state !== 2 /* SavingComments */ && state !== 3 /* SavingBackticks */, "whitespace shouldn't come from the scanner while saving comment text");
                       const whitespace = scanner2.getTokenText();
-                      if (margin !== void 0 && indent2 + whitespace.length > margin) {
-                        comments2.push(whitespace.slice(margin - indent2));
+                      if (margin !== void 0 && indent3 + whitespace.length > margin) {
+                        comments2.push(whitespace.slice(margin - indent3));
                         state = 2 /* SavingComments */;
                       }
-                      indent2 += whitespace.length;
+                      indent3 += whitespace.length;
                       break;
                     case 19 /* OpenBraceToken */:
                       state = 2 /* SavingComments */;
@@ -134019,7 +117116,7 @@ ${lanes.join("\n")}
                     case 42 /* AsteriskToken */:
                       if (state === 0 /* BeginningOfLine */) {
                         state = 1 /* SawAsterisk */;
-                        indent2 += 1;
+                        indent3 += 1;
                         break;
                       }
                     default:
@@ -134036,7 +117133,7 @@ ${lanes.join("\n")}
                   }
                 }
               removeLeadingNewlines(comments2);
-              const trimmedComments = trimStringEnd(comments2.join(""));
+              const trimmedComments = comments2.join("").trimEnd();
               if (parts2.length) {
                 if (trimmedComments.length) {
                   parts2.push(finishNode(factory2.createJSDocText(trimmedComments), linkEnd2 ?? commentsPos2));
@@ -134084,8 +117181,8 @@ ${lanes.join("\n")}
             function isJSDocLinkTag(kind) {
               return kind === "link" || kind === "linkcode" || kind === "linkplain";
             }
-            function parseUnknownTag(start2, tagName, indent2, indentText) {
-              return finishNode(factory2.createJSDocUnknownTag(tagName, parseTrailingTagComments(start2, getNodePos(), indent2, indentText)), start2);
+            function parseUnknownTag(start2, tagName, indent3, indentText) {
+              return finishNode(factory2.createJSDocUnknownTag(tagName, parseTrailingTagComments(start2, getNodePos(), indent3, indentText)), start2);
             }
             function addTag(tag) {
               if (!tag) {
@@ -134126,13 +117223,13 @@ ${lanes.join("\n")}
               switch (node.kind) {
                 case 151 /* ObjectKeyword */:
                   return true;
-                case 187 /* ArrayType */:
+                case 188 /* ArrayType */:
                   return isObjectOrObjectArrayTypeReference(node.elementType);
                 default:
                   return isTypeReferenceNode(node) && isIdentifier(node.typeName) && node.typeName.escapedText === "Object" && !node.typeArguments;
               }
             }
-            function parseParameterOrPropertyTag(start2, tagName, target, indent2) {
+            function parseParameterOrPropertyTag(start2, tagName, target, indent3) {
               let typeExpression = tryParseTypeExpression();
               let isNameFirst = !typeExpression;
               skipWhitespaceOrAsterisk();
@@ -134141,8 +117238,8 @@ ${lanes.join("\n")}
               if (isNameFirst && !lookAhead(parseJSDocLinkPrefix)) {
                 typeExpression = tryParseTypeExpression();
               }
-              const comment = parseTrailingTagComments(start2, getNodePos(), indent2, indentText);
-              const nestedTypeLiteral = target !== 4 /* CallbackParameter */ && parseNestedTypeLiteral(typeExpression, name, target, indent2);
+              const comment = parseTrailingTagComments(start2, getNodePos(), indent3, indentText);
+              const nestedTypeLiteral = parseNestedTypeLiteral(typeExpression, name, target, indent3);
               if (nestedTypeLiteral) {
                 typeExpression = nestedTypeLiteral;
                 isNameFirst = true;
@@ -134150,32 +117247,32 @@ ${lanes.join("\n")}
               const result2 = target === 1 /* Property */ ? factory2.createJSDocPropertyTag(tagName, name, isBracketed, typeExpression, isNameFirst, comment) : factory2.createJSDocParameterTag(tagName, name, isBracketed, typeExpression, isNameFirst, comment);
               return finishNode(result2, start2);
             }
-            function parseNestedTypeLiteral(typeExpression, name, target, indent2) {
+            function parseNestedTypeLiteral(typeExpression, name, target, indent3) {
               if (typeExpression && isObjectOrObjectArrayTypeReference(typeExpression.type)) {
                 const pos = getNodePos();
                 let child;
                 let children;
-                while (child = tryParse(() => parseChildParameterOrPropertyTag(target, indent2, name))) {
-                  if (child.kind === 347 /* JSDocParameterTag */ || child.kind === 354 /* JSDocPropertyTag */) {
+                while (child = tryParse(() => parseChildParameterOrPropertyTag(target, indent3, name))) {
+                  if (child.kind === 348 /* JSDocParameterTag */ || child.kind === 355 /* JSDocPropertyTag */) {
                     children = append(children, child);
-                  } else if (child.kind === 351 /* JSDocTemplateTag */) {
+                  } else if (child.kind === 352 /* JSDocTemplateTag */) {
                     parseErrorAtRange(child.tagName, Diagnostics.A_JSDoc_template_tag_may_not_follow_a_typedef_callback_or_overload_tag);
                   }
                 }
                 if (children) {
-                  const literal = finishNode(factory2.createJSDocTypeLiteral(children, typeExpression.type.kind === 187 /* ArrayType */), pos);
+                  const literal = finishNode(factory2.createJSDocTypeLiteral(children, typeExpression.type.kind === 188 /* ArrayType */), pos);
                   return finishNode(factory2.createJSDocTypeExpression(literal), pos);
                 }
               }
             }
-            function parseReturnTag(start2, tagName, indent2, indentText) {
+            function parseReturnTag(start2, tagName, indent3, indentText) {
               if (some(tags, isJSDocReturnTag)) {
                 parseErrorAt(tagName.pos, scanner2.getTokenStart(), Diagnostics._0_tag_already_specified, unescapeLeadingUnderscores(tagName.escapedText));
               }
               const typeExpression = tryParseTypeExpression();
-              return finishNode(factory2.createJSDocReturnTag(tagName, typeExpression, parseTrailingTagComments(start2, getNodePos(), indent2, indentText)), start2);
+              return finishNode(factory2.createJSDocReturnTag(tagName, typeExpression, parseTrailingTagComments(start2, getNodePos(), indent3, indentText)), start2);
             }
-            function parseTypeTag(start2, tagName, indent2, indentText) {
+            function parseTypeTag(start2, tagName, indent3, indentText) {
               if (some(tags, isJSDocTypeTag)) {
                 parseErrorAt(tagName.pos, scanner2.getTokenStart(), Diagnostics._0_tag_already_specified, unescapeLeadingUnderscores(tagName.escapedText));
               }
@@ -134183,25 +117280,25 @@ ${lanes.join("\n")}
                 /*mayOmitBraces*/
                 true
               );
-              const comments2 = indent2 !== void 0 && indentText !== void 0 ? parseTrailingTagComments(start2, getNodePos(), indent2, indentText) : void 0;
+              const comments2 = indent3 !== void 0 && indentText !== void 0 ? parseTrailingTagComments(start2, getNodePos(), indent3, indentText) : void 0;
               return finishNode(factory2.createJSDocTypeTag(tagName, typeExpression, comments2), start2);
             }
-            function parseSeeTag(start2, tagName, indent2, indentText) {
+            function parseSeeTag(start2, tagName, indent3, indentText) {
               const isMarkdownOrJSDocLink = token() === 23 /* OpenBracketToken */ || lookAhead(() => nextTokenJSDoc() === 60 /* AtToken */ && tokenIsIdentifierOrKeyword(nextTokenJSDoc()) && isJSDocLinkTag(scanner2.getTokenValue()));
               const nameExpression = isMarkdownOrJSDocLink ? void 0 : parseJSDocNameReference();
-              const comments2 = indent2 !== void 0 && indentText !== void 0 ? parseTrailingTagComments(start2, getNodePos(), indent2, indentText) : void 0;
+              const comments2 = indent3 !== void 0 && indentText !== void 0 ? parseTrailingTagComments(start2, getNodePos(), indent3, indentText) : void 0;
               return finishNode(factory2.createJSDocSeeTag(tagName, nameExpression, comments2), start2);
             }
-            function parseThrowsTag(start2, tagName, indent2, indentText) {
+            function parseThrowsTag(start2, tagName, indent3, indentText) {
               const typeExpression = tryParseTypeExpression();
-              const comment = parseTrailingTagComments(start2, getNodePos(), indent2, indentText);
+              const comment = parseTrailingTagComments(start2, getNodePos(), indent3, indentText);
               return finishNode(factory2.createJSDocThrowsTag(tagName, typeExpression, comment), start2);
             }
-            function parseAuthorTag(start2, tagName, indent2, indentText) {
+            function parseAuthorTag(start2, tagName, indent3, indentText) {
               const commentStart = getNodePos();
               const textOnly = parseAuthorNameAndEmail();
               let commentEnd = scanner2.getTokenFullStart();
-              const comments2 = parseTrailingTagComments(start2, commentEnd, indent2, indentText);
+              const comments2 = parseTrailingTagComments(start2, commentEnd, indent3, indentText);
               if (!comments2) {
                 commentEnd = scanner2.getTokenFullStart();
               }
@@ -134285,28 +117382,28 @@ ${lanes.join("\n")}
               skipWhitespace();
               return finishNode(factory2.createJSDocEnumTag(tagName, typeExpression, parseTrailingTagComments(start2, getNodePos(), margin, indentText)), start2);
             }
-            function parseTypedefTag(start2, tagName, indent2, indentText) {
+            function parseTypedefTag(start2, tagName, indent3, indentText) {
               let typeExpression = tryParseTypeExpression();
               skipWhitespaceOrAsterisk();
               const fullName = parseJSDocTypeNameWithNamespace();
               skipWhitespace();
-              let comment = parseTagComments(indent2);
+              let comment = parseTagComments(indent3);
               let end2;
               if (!typeExpression || isObjectOrObjectArrayTypeReference(typeExpression.type)) {
                 let child;
                 let childTypeTag;
                 let jsDocPropertyTags;
                 let hasChildren = false;
-                while (child = tryParse(() => parseChildPropertyTag(indent2))) {
-                  if (child.kind === 351 /* JSDocTemplateTag */) {
+                while (child = tryParse(() => parseChildPropertyTag(indent3))) {
+                  if (child.kind === 352 /* JSDocTemplateTag */) {
                     break;
                   }
                   hasChildren = true;
-                  if (child.kind === 350 /* JSDocTypeTag */) {
+                  if (child.kind === 351 /* JSDocTypeTag */) {
                     if (childTypeTag) {
                       const lastError = parseErrorAtCurrentToken(Diagnostics.A_JSDoc_typedef_comment_may_not_contain_multiple_type_tags);
                       if (lastError) {
-                        addRelatedInfo(lastError, createDetachedDiagnostic(fileName, 0, 0, Diagnostics.The_tag_was_first_specified_here));
+                        addRelatedInfo(lastError, createDetachedDiagnostic(fileName, sourceText, 0, 0, Diagnostics.The_tag_was_first_specified_here));
                       }
                       break;
                     } else {
@@ -134317,7 +117414,7 @@ ${lanes.join("\n")}
                   }
                 }
                 if (hasChildren) {
-                  const isArrayType = typeExpression && typeExpression.type.kind === 187 /* ArrayType */;
+                  const isArrayType = typeExpression && typeExpression.type.kind === 188 /* ArrayType */;
                   const jsdocTypeLiteral = factory2.createJSDocTypeLiteral(jsDocPropertyTags, isArrayType);
                   typeExpression = childTypeTag && childTypeTag.typeExpression && !isObjectOrObjectArrayTypeReference(childTypeTag.typeExpression.type) ? childTypeTag.typeExpression : finishNode(jsdocTypeLiteral, start2);
                   end2 = typeExpression.end;
@@ -134325,7 +117422,7 @@ ${lanes.join("\n")}
               }
               end2 = end2 || comment !== void 0 ? getNodePos() : (fullName ?? typeExpression ?? tagName).end;
               if (!comment) {
-                comment = parseTrailingTagComments(start2, end2, indent2, indentText);
+                comment = parseTrailingTagComments(start2, end2, indent3, indentText);
               }
               const typedefTag = factory2.createJSDocTypedefTag(tagName, typeExpression, fullName, comment);
               return finishNode(typedefTag, start2, end2);
@@ -134346,21 +117443,21 @@ ${lanes.join("\n")}
                   void 0,
                   typeNameOrNamespaceName,
                   body,
-                  nested ? 4 /* NestedNamespace */ : void 0
+                  nested ? 8 /* NestedNamespace */ : void 0
                 );
                 return finishNode(jsDocNamespaceNode, start2);
               }
               if (nested) {
-                typeNameOrNamespaceName.flags |= 2048 /* IdentifierIsInJSDocNamespace */;
+                typeNameOrNamespaceName.flags |= 4096 /* IdentifierIsInJSDocNamespace */;
               }
               return typeNameOrNamespaceName;
             }
-            function parseCallbackTagParameters(indent2) {
+            function parseCallbackTagParameters(indent3) {
               const pos = getNodePos();
               let child;
               let parameters;
-              while (child = tryParse(() => parseChildParameterOrPropertyTag(4 /* CallbackParameter */, indent2))) {
-                if (child.kind === 351 /* JSDocTemplateTag */) {
+              while (child = tryParse(() => parseChildParameterOrPropertyTag(4 /* CallbackParameter */, indent3))) {
+                if (child.kind === 352 /* JSDocTemplateTag */) {
                   parseErrorAtRange(child.tagName, Diagnostics.A_JSDoc_template_tag_may_not_follow_a_typedef_callback_or_overload_tag);
                   break;
                 }
@@ -134368,12 +117465,12 @@ ${lanes.join("\n")}
               }
               return createNodeArray(parameters || [], pos);
             }
-            function parseJSDocSignature(start2, indent2) {
-              const parameters = parseCallbackTagParameters(indent2);
+            function parseJSDocSignature(start2, indent3) {
+              const parameters = parseCallbackTagParameters(indent3);
               const returnTag = tryParse(() => {
                 if (parseOptionalJsdoc(60 /* AtToken */)) {
-                  const tag = parseTag(indent2);
-                  if (tag && tag.kind === 348 /* JSDocReturnTag */) {
+                  const tag = parseTag(indent3);
+                  if (tag && tag.kind === 349 /* JSDocReturnTag */) {
                     return tag;
                   }
                 }
@@ -134385,23 +117482,23 @@ ${lanes.join("\n")}
                 returnTag
               ), start2);
             }
-            function parseCallbackTag(start2, tagName, indent2, indentText) {
+            function parseCallbackTag(start2, tagName, indent3, indentText) {
               const fullName = parseJSDocTypeNameWithNamespace();
               skipWhitespace();
-              let comment = parseTagComments(indent2);
-              const typeExpression = parseJSDocSignature(start2, indent2);
+              let comment = parseTagComments(indent3);
+              const typeExpression = parseJSDocSignature(start2, indent3);
               if (!comment) {
-                comment = parseTrailingTagComments(start2, getNodePos(), indent2, indentText);
+                comment = parseTrailingTagComments(start2, getNodePos(), indent3, indentText);
               }
               const end2 = comment !== void 0 ? getNodePos() : typeExpression.end;
               return finishNode(factory2.createJSDocCallbackTag(tagName, typeExpression, fullName, comment), start2, end2);
             }
-            function parseOverloadTag(start2, tagName, indent2, indentText) {
+            function parseOverloadTag(start2, tagName, indent3, indentText) {
               skipWhitespace();
-              let comment = parseTagComments(indent2);
-              const typeExpression = parseJSDocSignature(start2, indent2);
+              let comment = parseTagComments(indent3);
+              const typeExpression = parseJSDocSignature(start2, indent3);
               if (!comment) {
-                comment = parseTrailingTagComments(start2, getNodePos(), indent2, indentText);
+                comment = parseTrailingTagComments(start2, getNodePos(), indent3, indentText);
               }
               const end2 = comment !== void 0 ? getNodePos() : typeExpression.end;
               return finishNode(factory2.createJSDocOverloadTag(tagName, typeExpression, comment), start2, end2);
@@ -134417,18 +117514,18 @@ ${lanes.join("\n")}
               }
               return a.escapedText === b.escapedText;
             }
-            function parseChildPropertyTag(indent2) {
-              return parseChildParameterOrPropertyTag(1 /* Property */, indent2);
+            function parseChildPropertyTag(indent3) {
+              return parseChildParameterOrPropertyTag(1 /* Property */, indent3);
             }
-            function parseChildParameterOrPropertyTag(target, indent2, name) {
+            function parseChildParameterOrPropertyTag(target, indent3, name) {
               let canParseTag = true;
               let seenAsterisk = false;
               while (true) {
                 switch (nextTokenJSDoc()) {
                   case 60 /* AtToken */:
                     if (canParseTag) {
-                      const child = tryParseChildTag(target, indent2);
-                      if (child && (child.kind === 347 /* JSDocParameterTag */ || child.kind === 354 /* JSDocPropertyTag */) && target !== 4 /* CallbackParameter */ && name && (isIdentifier(child.name) || !escapedTextsEqual(name, child.name.left))) {
+                      const child = tryParseChildTag(target, indent3);
+                      if (child && (child.kind === 348 /* JSDocParameterTag */ || child.kind === 355 /* JSDocPropertyTag */) && name && (isIdentifier(child.name) || !escapedTextsEqual(name, child.name.left))) {
                         return false;
                       }
                       return child;
@@ -134453,7 +117550,7 @@ ${lanes.join("\n")}
                 }
               }
             }
-            function tryParseChildTag(target, indent2) {
+            function tryParseChildTag(target, indent3) {
               Debug.assert(token() === 60 /* AtToken */);
               const start2 = scanner2.getTokenFullStart();
               nextTokenJSDoc();
@@ -134473,14 +117570,14 @@ ${lanes.join("\n")}
                   t = 2 /* Parameter */ | 4 /* CallbackParameter */;
                   break;
                 case "template":
-                  return parseTemplateTag(start2, tagName, indent2, indentText);
+                  return parseTemplateTag(start2, tagName, indent3, indentText);
                 default:
                   return false;
               }
               if (!(target & t)) {
                 return false;
               }
-              return parseParameterOrPropertyTag(start2, tagName, target, indent2);
+              return parseParameterOrPropertyTag(start2, tagName, target, indent3);
             }
             function parseTemplateTagTypeParameter() {
               const typeParameterPos = getNodePos();
@@ -134493,7 +117590,7 @@ ${lanes.join("\n")}
               if (isBracketed) {
                 skipWhitespace();
                 parseExpected(64 /* EqualsToken */);
-                defaultType = doInsideOfContext(8388608 /* JSDoc */, parseJSDocType);
+                defaultType = doInsideOfContext(16777216 /* JSDoc */, parseJSDocType);
                 parseExpected(24 /* CloseBracketToken */);
               }
               if (nodeIsMissing(name)) {
@@ -134521,10 +117618,10 @@ ${lanes.join("\n")}
               } while (parseOptionalJsdoc(28 /* CommaToken */));
               return createNodeArray(typeParameters, pos);
             }
-            function parseTemplateTag(start2, tagName, indent2, indentText) {
+            function parseTemplateTag(start2, tagName, indent3, indentText) {
               const constraint = token() === 19 /* OpenBraceToken */ ? parseJSDocTypeExpression() : void 0;
               const typeParameters = parseTemplateTagTypeParameters();
-              return finishNode(factory2.createJSDocTemplateTag(tagName, constraint, typeParameters, parseTrailingTagComments(start2, getNodePos(), indent2, indentText)), start2);
+              return finishNode(factory2.createJSDocTemplateTag(tagName, constraint, typeParameters, parseTrailingTagComments(start2, getNodePos(), indent3, indentText)), start2);
             }
             function parseOptionalJsdoc(t) {
               if (token() === t) {
@@ -134585,7 +117682,8 @@ ${lanes.join("\n")}
               /*setParentNodes*/
               true,
               sourceFile.scriptKind,
-              sourceFile.setExternalModuleIndicator
+              sourceFile.setExternalModuleIndicator,
+              sourceFile.jsDocParsingMode
             );
           }
           const incrementalSourceFile = sourceFile;
@@ -134600,16 +117698,7 @@ ${lanes.join("\n")}
           Debug.assert(textSpanEnd(changeRange.span) === textSpanEnd(textChangeRange.span));
           Debug.assert(textSpanEnd(textChangeRangeNewSpan(changeRange)) === textSpanEnd(textChangeRangeNewSpan(textChangeRange)));
           const delta = textChangeRangeNewSpan(changeRange).length - changeRange.span.length;
-          updateTokenPositionsAndMarkElements(
-            incrementalSourceFile,
-            changeRange.span.start,
-            textSpanEnd(changeRange.span),
-            textSpanEnd(textChangeRangeNewSpan(changeRange)),
-            delta,
-            oldText,
-            newText,
-            aggressiveChecks
-          );
+          updateTokenPositionsAndMarkElements(incrementalSourceFile, changeRange.span.start, textSpanEnd(changeRange.span), textSpanEnd(textChangeRangeNewSpan(changeRange)), delta, oldText, newText, aggressiveChecks);
           const result = Parser.parseSourceFile(
             sourceFile.fileName,
             newText,
@@ -134618,7 +117707,8 @@ ${lanes.join("\n")}
             /*setParentNodes*/
             true,
             sourceFile.scriptKind,
-            sourceFile.setExternalModuleIndicator
+            sourceFile.setExternalModuleIndicator,
+            sourceFile.jsDocParsingMode
           );
           result.commentDirectives = getNewCommentDirectives(
             sourceFile.commentDirectives,
@@ -134943,7 +118033,7 @@ ${lanes.join("\n")}
       })(IncrementalParser || (IncrementalParser = {}));
       namedArgRegExCache = /* @__PURE__ */ new Map();
       tripleSlashXMLCommentStartRegEx = /^\/\/\/\s*<(\S+)\s.*?\/>/im;
-      singleLinePragmaRegEx = /^\/\/\/?\s*@(\S+)\s*(.*)\s*$/im;
+      singleLinePragmaRegEx = /^\/\/\/?\s*@([^\s:]+)(.*)\s*$/im;
     }
   });
 
@@ -134971,14 +118061,14 @@ ${lanes.join("\n")}
     return createDiagnostic(Diagnostics.Argument_for_0_option_must_be_Colon_1, `--${opt.name}`, stringNames);
   }
   function parseCustomTypeOption(opt, value, errors) {
-    return convertJsonOptionOfCustomType(opt, trimString(value || ""), errors);
+    return convertJsonOptionOfCustomType(opt, (value ?? "").trim(), errors);
   }
   function parseListTypeOption(opt, value = "", errors) {
-    value = trimString(value);
+    value = value.trim();
     if (startsWith(value, "-")) {
       return void 0;
     }
-    if (opt.type === "listOrElement" && !stringContains(value, ",")) {
+    if (opt.type === "listOrElement" && !value.includes(",")) {
       return validateJsonOptionValue(opt, value, errors);
     }
     if (value === "") {
@@ -135199,9 +118289,8 @@ ${lanes.join("\n")}
     }
     return { buildOptions, watchOptions, projects, errors };
   }
-  function getDiagnosticText(_message, ..._args) {
-    const diagnostic = createCompilerDiagnostic.apply(void 0, arguments);
-    return diagnostic.messageText;
+  function getDiagnosticText(message, ...args) {
+    return cast(createCompilerDiagnostic(message, ...args).messageText, isString);
   }
   function getParsedCommandLineOfConfigFile(configFileName, optionsToExtend, host, extendedConfigCache, watchOptionsToExtend, extraFileExtensions) {
     const configFileText = tryReadFile(configFileName, (fileName) => host.readFile(fileName));
@@ -135329,7 +118418,7 @@ ${lanes.join("\n")}
   function convertConfigFileToObject(sourceFile, errors, jsonConversionNotifier) {
     var _a;
     const rootExpression = (_a = sourceFile.statements[0]) == null ? void 0 : _a.expression;
-    if (rootExpression && rootExpression.kind !== 209 /* ObjectLiteralExpression */) {
+    if (rootExpression && rootExpression.kind !== 210 /* ObjectLiteralExpression */) {
       errors.push(createDiagnosticForNodeInSourceFile(
         sourceFile,
         rootExpression,
@@ -135381,7 +118470,7 @@ ${lanes.join("\n")}
       var _a;
       const result = returnValue ? {} : void 0;
       for (const element of node.properties) {
-        if (element.kind !== 302 /* PropertyAssignment */) {
+        if (element.kind !== 303 /* PropertyAssignment */) {
           errors.push(createDiagnosticForNodeInSourceFile(sourceFile, element, Diagnostics.Property_assignment_expected));
           continue;
         }
@@ -135426,15 +118515,15 @@ ${lanes.join("\n")}
           return valueExpression.text;
         case 9 /* NumericLiteral */:
           return Number(valueExpression.text);
-        case 223 /* PrefixUnaryExpression */:
+        case 224 /* PrefixUnaryExpression */:
           if (valueExpression.operator !== 41 /* MinusToken */ || valueExpression.operand.kind !== 9 /* NumericLiteral */) {
             break;
           }
           return -Number(valueExpression.operand.text);
-        case 209 /* ObjectLiteralExpression */:
+        case 210 /* ObjectLiteralExpression */:
           const objectLiteralExpression = valueExpression;
           return convertObjectLiteralExpressionToJson(objectLiteralExpression, option);
-        case 208 /* ArrayLiteralExpression */:
+        case 209 /* ArrayLiteralExpression */:
           return convertArrayLiteralExpressionToJson(
             valueExpression.elements,
             option && option.element
@@ -135817,8 +118906,8 @@ ${lanes.join("\n")}
             const fileName = configFileName || "tsconfig.json";
             const diagnosticMessage = Diagnostics.The_files_list_in_config_file_0_is_empty;
             const nodeValue = forEachTsConfigPropArray(sourceFile, "files", (property) => property.initializer);
-            const error = createDiagnosticForNodeInSourceFileOrCompilerDiagnostic(sourceFile, nodeValue, diagnosticMessage, fileName);
-            errors.push(error);
+            const error2 = createDiagnosticForNodeInSourceFileOrCompilerDiagnostic(sourceFile, nodeValue, diagnosticMessage, fileName);
+            errors.push(error2);
           } else {
             createCompilerDiagnosticOnlyIfJson(Diagnostics.The_files_list_in_config_file_0_is_empty, configFileName || "tsconfig.json");
           }
@@ -135925,8 +119014,8 @@ ${lanes.join("\n")}
       }
     }
   }
-  function isErrorNoInputFiles(error) {
-    return error.code === Diagnostics.No_inputs_were_found_in_config_file_0_Specified_include_paths_were_1_and_exclude_paths_were_2.code;
+  function isErrorNoInputFiles(error2) {
+    return error2.code === Diagnostics.No_inputs_were_found_in_config_file_0_Specified_include_paths_were_1_and_exclude_paths_were_2.code;
   }
   function getErrorForNoInputFiles({ includeSpecs, excludeSpecs }, configFileName) {
     return createCompilerDiagnostic(
@@ -135947,7 +119036,7 @@ ${lanes.join("\n")}
     if (shouldReportNoInputFiles(fileNames, canJsonReportNoInutFiles)) {
       configParseDiagnostics.push(getErrorForNoInputFiles(configFileSpecs, configFileName));
     } else {
-      filterMutate(configParseDiagnostics, (error) => !isErrorNoInputFiles(error));
+      filterMutate(configParseDiagnostics, (error2) => !isErrorNoInputFiles(error2));
     }
     return existingErrors !== configParseDiagnostics.length;
   }
@@ -135958,7 +119047,7 @@ ${lanes.join("\n")}
     var _a;
     basePath = normalizeSlashes(basePath);
     const resolvedPath = getNormalizedAbsolutePath(configFileName || "", basePath);
-    if (resolutionStack.indexOf(resolvedPath) >= 0) {
+    if (resolutionStack.includes(resolvedPath)) {
       errors.push(createCompilerDiagnostic(Diagnostics.Circularity_detected_while_resolving_configuration_Colon_0, [...resolutionStack, resolvedPath].join(" -> ")));
       return { raw: json || convertToObject(sourceFile, errors) };
     }
@@ -136040,14 +119129,17 @@ ${lanes.join("\n")}
       for (let index = 0; index < value.length; index++) {
         const fileName = value[index];
         if (isString(fileName)) {
-          extendedConfigPath = append(extendedConfigPath, getExtendsConfigPath(
-            fileName,
-            host,
-            newBase,
-            errors,
-            valueExpression == null ? void 0 : valueExpression.elements[index],
-            sourceFile
-          ));
+          extendedConfigPath = append(
+            extendedConfigPath,
+            getExtendsConfigPath(
+              fileName,
+              host,
+              newBase,
+              errors,
+              valueExpression == null ? void 0 : valueExpression.elements[index],
+              sourceFile
+            )
+          );
         } else {
           convertJsonOption(extendsOptionDeclaration.element, value, basePath, errors, propertyAssignment, valueExpression == null ? void 0 : valueExpression.elements[index], sourceFile);
         }
@@ -136355,19 +119447,19 @@ ${lanes.join("\n")}
     const wildcardFiles = arrayFrom(wildcardFileMap.values());
     return literalFiles.concat(wildcardFiles, arrayFrom(wildCardJsonFileMap.values()));
   }
-  function isExcludedFile(pathToCheck, spec, basePath, useCaseSensitiveFileNames, currentDirectory) {
+  function isExcludedFile(pathToCheck, spec, basePath, useCaseSensitiveFileNames2, currentDirectory) {
     const { validatedFilesSpec, validatedIncludeSpecs, validatedExcludeSpecs } = spec;
     if (!length(validatedIncludeSpecs) || !length(validatedExcludeSpecs))
       return false;
     basePath = normalizePath(basePath);
-    const keyMapper = createGetCanonicalFileName(useCaseSensitiveFileNames);
+    const keyMapper = createGetCanonicalFileName(useCaseSensitiveFileNames2);
     if (validatedFilesSpec) {
       for (const fileName of validatedFilesSpec) {
         if (keyMapper(getNormalizedAbsolutePath(fileName, basePath)) === pathToCheck)
           return false;
       }
     }
-    return matchesExcludeWorker(pathToCheck, validatedExcludeSpecs, useCaseSensitiveFileNames, currentDirectory, basePath);
+    return matchesExcludeWorker(pathToCheck, validatedExcludeSpecs, useCaseSensitiveFileNames2, currentDirectory, basePath);
   }
   function invalidDotDotAfterRecursiveWildcard(s) {
     const wildcardIndex = startsWith(s, "**/") ? 0 : s.indexOf("/**/");
@@ -136377,17 +119469,17 @@ ${lanes.join("\n")}
     const lastDotIndex = endsWith(s, "/..") ? s.length : s.lastIndexOf("/../");
     return lastDotIndex > wildcardIndex;
   }
-  function matchesExclude(pathToCheck, excludeSpecs, useCaseSensitiveFileNames, currentDirectory) {
+  function matchesExclude(pathToCheck, excludeSpecs, useCaseSensitiveFileNames2, currentDirectory) {
     return matchesExcludeWorker(
       pathToCheck,
       filter(excludeSpecs, (spec) => !invalidDotDotAfterRecursiveWildcard(spec)),
-      useCaseSensitiveFileNames,
+      useCaseSensitiveFileNames2,
       currentDirectory
     );
   }
-  function matchesExcludeWorker(pathToCheck, excludeSpecs, useCaseSensitiveFileNames, currentDirectory, basePath) {
+  function matchesExcludeWorker(pathToCheck, excludeSpecs, useCaseSensitiveFileNames2, currentDirectory, basePath) {
     const excludePattern = getRegularExpressionForWildcard(excludeSpecs, combinePaths(normalizePath(currentDirectory), basePath), "exclude");
-    const excludeRegex = excludePattern && getRegexFromPattern(excludePattern, useCaseSensitiveFileNames);
+    const excludeRegex = excludePattern && getRegexFromPattern(excludePattern, useCaseSensitiveFileNames2);
     if (!excludeRegex)
       return false;
     if (excludeRegex.test(pathToCheck))
@@ -136417,9 +119509,9 @@ ${lanes.join("\n")}
       return [Diagnostics.File_specification_cannot_contain_a_parent_directory_that_appears_after_a_recursive_directory_wildcard_Asterisk_Asterisk_Colon_0, spec];
     }
   }
-  function getWildcardDirectories({ validatedIncludeSpecs: include, validatedExcludeSpecs: exclude }, path, useCaseSensitiveFileNames) {
+  function getWildcardDirectories({ validatedIncludeSpecs: include, validatedExcludeSpecs: exclude }, path, useCaseSensitiveFileNames2) {
     const rawExcludeRegex = getRegularExpressionForWildcard(exclude, path, "exclude");
-    const excludeRegex = rawExcludeRegex && new RegExp(rawExcludeRegex, useCaseSensitiveFileNames ? "" : "i");
+    const excludeRegex = rawExcludeRegex && new RegExp(rawExcludeRegex, useCaseSensitiveFileNames2 ? "" : "i");
     const wildcardDirectories = {};
     if (include !== void 0) {
       const recursiveKeys = [];
@@ -136428,7 +119520,7 @@ ${lanes.join("\n")}
         if (excludeRegex && excludeRegex.test(spec)) {
           continue;
         }
-        const match = getWildcardDirectoryFromSpec(spec, useCaseSensitiveFileNames);
+        const match = getWildcardDirectoryFromSpec(spec, useCaseSensitiveFileNames2);
         if (match) {
           const { key, flags } = match;
           const existingFlags = wildcardDirectories[key];
@@ -136443,7 +119535,7 @@ ${lanes.join("\n")}
       for (const key in wildcardDirectories) {
         if (hasProperty(wildcardDirectories, key)) {
           for (const recursiveKey of recursiveKeys) {
-            if (key !== recursiveKey && containsPath(recursiveKey, key, path, !useCaseSensitiveFileNames)) {
+            if (key !== recursiveKey && containsPath(recursiveKey, key, path, !useCaseSensitiveFileNames2)) {
               delete wildcardDirectories[key];
             }
           }
@@ -136452,20 +119544,20 @@ ${lanes.join("\n")}
     }
     return wildcardDirectories;
   }
-  function getWildcardDirectoryFromSpec(spec, useCaseSensitiveFileNames) {
+  function getWildcardDirectoryFromSpec(spec, useCaseSensitiveFileNames2) {
     const match = wildcardDirectoryPattern.exec(spec);
     if (match) {
       const questionWildcardIndex = spec.indexOf("?");
       const starWildcardIndex = spec.indexOf("*");
       const lastDirectorySeperatorIndex = spec.lastIndexOf(directorySeparator);
       return {
-        key: useCaseSensitiveFileNames ? match[0] : toFileNameLowerCase(match[0]),
+        key: useCaseSensitiveFileNames2 ? match[0] : toFileNameLowerCase(match[0]),
         flags: questionWildcardIndex !== -1 && questionWildcardIndex < lastDirectorySeperatorIndex || starWildcardIndex !== -1 && starWildcardIndex < lastDirectorySeperatorIndex ? 1 /* Recursive */ : 0 /* None */
       };
     }
     if (isImplicitGlob(spec.substring(spec.lastIndexOf(directorySeparator) + 1))) {
       return {
-        key: removeTrailingDirectorySeparator(useCaseSensitiveFileNames ? spec : toFileNameLowerCase(spec)),
+        key: removeTrailingDirectorySeparator(useCaseSensitiveFileNames2 ? spec : toFileNameLowerCase(spec)),
         flags: 1 /* Recursive */
       };
     }
@@ -136477,7 +119569,7 @@ ${lanes.join("\n")}
       return false;
     }
     for (const ext of extensionGroup) {
-      if (fileExtensionIs(file, ext)) {
+      if (fileExtensionIs(file, ext) && (ext !== ".ts" /* Ts */ || !fileExtensionIs(file, ".d.ts" /* Dts */))) {
         return false;
       }
       const higherPriorityPath = keyMapper(changeExtension(file, ext));
@@ -136615,6 +119707,7 @@ ${lanes.join("\n")}
         ["es2015.symbol", "lib.es2015.symbol.d.ts"],
         ["es2015.symbol.wellknown", "lib.es2015.symbol.wellknown.d.ts"],
         ["es2016.array.include", "lib.es2016.array.include.d.ts"],
+        ["es2017.date", "lib.es2017.date.d.ts"],
         ["es2017.object", "lib.es2017.object.d.ts"],
         ["es2017.sharedmemory", "lib.es2017.sharedmemory.d.ts"],
         ["es2017.string", "lib.es2017.string.d.ts"],
@@ -136650,14 +119743,18 @@ ${lanes.join("\n")}
         ["es2022.string", "lib.es2022.string.d.ts"],
         ["es2022.regexp", "lib.es2022.regexp.d.ts"],
         ["es2023.array", "lib.es2023.array.d.ts"],
+        ["es2023.collection", "lib.es2023.collection.d.ts"],
         ["esnext.array", "lib.es2023.array.d.ts"],
+        ["esnext.collection", "lib.es2023.collection.d.ts"],
         ["esnext.symbol", "lib.es2019.symbol.d.ts"],
         ["esnext.asynciterable", "lib.es2018.asynciterable.d.ts"],
         ["esnext.intl", "lib.esnext.intl.d.ts"],
+        ["esnext.disposable", "lib.esnext.disposable.d.ts"],
         ["esnext.bigint", "lib.es2020.bigint.d.ts"],
         ["esnext.string", "lib.es2022.string.d.ts"],
         ["esnext.promise", "lib.es2021.promise.d.ts"],
         ["esnext.weakref", "lib.es2021.weakref.d.ts"],
+        ["esnext.decorators", "lib.esnext.decorators.d.ts"],
         ["decorators", "lib.decorators.d.ts"],
         ["decorators.legacy", "lib.decorators.legacy.d.ts"]
       ];
@@ -136964,6 +120061,7 @@ ${lanes.join("\n")}
           node16: 100 /* Node16 */,
           nodenext: 199 /* NodeNext */
         })),
+        affectsSourceFile: true,
         affectsModuleResolution: true,
         affectsEmit: true,
         affectsBuildInfo: true,
@@ -137056,7 +120154,8 @@ ${lanes.join("\n")}
         {
           name: "allowJs",
           type: "boolean",
-          affectsModuleResolution: true,
+          allowJsFlag: true,
+          affectsBuildInfo: true,
           showInSimplifiedHelpView: true,
           category: Diagnostics.JavaScript_Support,
           description: Diagnostics.Allow_JavaScript_files_to_be_a_part_of_your_program_Use_the_checkJS_option_to_get_errors_from_these_files,
@@ -137065,6 +120164,9 @@ ${lanes.join("\n")}
         {
           name: "checkJs",
           type: "boolean",
+          affectsModuleResolution: true,
+          affectsSemanticDiagnostics: true,
+          affectsBuildInfo: true,
           showInSimplifiedHelpView: true,
           category: Diagnostics.JavaScript_Support,
           description: Diagnostics.Enable_error_reporting_in_type_checked_JavaScript_files,
@@ -137077,6 +120179,10 @@ ${lanes.join("\n")}
           affectsEmit: true,
           affectsBuildInfo: true,
           affectsModuleResolution: true,
+          // The checker emits an error when it sees JSX but this option is not set in compilerOptions.
+          // This is effectively a semantic error, so mark this option as affecting semantic diagnostics
+          // so we know to refresh errors when this option is changed.
+          affectsSemanticDiagnostics: true,
           paramType: Diagnostics.KIND,
           showInSimplifiedHelpView: true,
           category: Diagnostics.Language_and_Environment,
@@ -137291,7 +120397,7 @@ ${lanes.join("\n")}
           strictFlag: true,
           category: Diagnostics.Type_Checking,
           description: Diagnostics.Default_catch_clause_variables_as_unknown_instead_of_any,
-          defaultValueDescription: false
+          defaultValueDescription: Diagnostics.false_unless_strict_is_set
         },
         {
           name: "alwaysStrict",
@@ -137392,6 +120498,7 @@ ${lanes.join("\n")}
             bundler: 100 /* Bundler */
           })),
           deprecatedKeys: /* @__PURE__ */ new Set(["node"]),
+          affectsSourceFile: true,
           affectsModuleResolution: true,
           paramType: Diagnostics.STRATEGY,
           category: Diagnostics.Modules,
@@ -137642,7 +120749,7 @@ ${lanes.join("\n")}
           affectsBuildInfo: true,
           affectsDeclarationPath: true,
           isFilePath: false,
-          // This is intentionally broken to support compatability with existing tsconfig files
+          // This is intentionally broken to support compatibility with existing tsconfig files
           // for correct behaviour, please use outFile
           category: Diagnostics.Backwards_Compatibility,
           paramType: Diagnostics.FILE,
@@ -137934,6 +121041,7 @@ ${lanes.join("\n")}
             legacy: 1 /* Legacy */,
             force: 3 /* Force */
           })),
+          affectsSourceFile: true,
           affectsModuleResolution: true,
           description: Diagnostics.Control_what_method_is_used_to_detect_module_format_JS_files,
           category: Diagnostics.Language_and_Environment,
@@ -137953,7 +121061,7 @@ ${lanes.join("\n")}
       affectsEmitOptionDeclarations = optionDeclarations.filter((option) => !!option.affectsEmit);
       affectsDeclarationPathOptionDeclarations = optionDeclarations.filter((option) => !!option.affectsDeclarationPath);
       moduleResolutionOptionDeclarations = optionDeclarations.filter((option) => !!option.affectsModuleResolution);
-      sourceFileAffectingCompilerOptions = optionDeclarations.filter((option) => !!option.affectsSourceFile || !!option.affectsModuleResolution || !!option.affectsBindDiagnostics);
+      sourceFileAffectingCompilerOptions = optionDeclarations.filter((option) => !!option.affectsSourceFile || !!option.affectsBindDiagnostics);
       optionsAffectingProgramStructure = optionDeclarations.filter((option) => !!option.affectsProgramStructure);
       transpileOptionValueCompilerOptions = optionDeclarations.filter((option) => hasProperty(option, "transpileOptionValue"));
       optionsForBuild = [
@@ -138099,9 +121207,76 @@ ${lanes.join("\n")}
     }
   });
 
+  // src/compiler/pnp.ts
+  function getPnpApi(path) {
+    if (typeof process.versions.pnp === "undefined") {
+      return;
+    }
+    const { findPnpApi } =   __nccwpck_require__(98188);
+    if (findPnpApi) {
+      return findPnpApi(`${path}/`);
+    }
+  }
+  function getPnpApiPath(path) {
+    var _a;
+    return (_a = getPnpApi(path)) == null ? void 0 : _a.resolveRequest(
+      "pnpapi",
+      /*issuer*/
+      null
+    );
+  }
+  function getPnpTypeRoots(currentDirectory) {
+    const pnpApi = getPnpApi(currentDirectory);
+    if (!pnpApi) {
+      return [];
+    }
+    currentDirectory = resolvePath(currentDirectory);
+    const currentPackage = pnpApi.findPackageLocator(`${currentDirectory}/`);
+    if (!currentPackage) {
+      return [];
+    }
+    const { packageDependencies } = pnpApi.getPackageInformation(currentPackage);
+    const typeRoots = [];
+    for (const [name, referencish] of Array.from(packageDependencies.entries())) {
+      if (name.startsWith(`@types/`) && referencish !== null) {
+        const dependencyLocator = pnpApi.getLocator(name, referencish);
+        const { packageLocation } = pnpApi.getPackageInformation(dependencyLocator);
+        typeRoots.push(getDirectoryPath(packageLocation));
+      }
+    }
+    return typeRoots;
+  }
+  function isImportablePathPnp(fromPath, toPath3) {
+    const pnpApi = getPnpApi(fromPath);
+    const fromLocator = pnpApi.findPackageLocator(fromPath);
+    const toLocator = pnpApi.findPackageLocator(toPath3);
+    if (toLocator === null) {
+      return false;
+    }
+    const fromInfo = pnpApi.getPackageInformation(fromLocator);
+    const toReference = fromInfo.packageDependencies.get(toLocator.name);
+    if (toReference) {
+      return toReference === toLocator.reference;
+    }
+    for (const reference of fromInfo.packageDependencies.values()) {
+      if (Array.isArray(reference)) {
+        if (reference[0] === toLocator.name && reference[1] === toLocator.reference) {
+          return true;
+        }
+      }
+    }
+    return false;
+  }
+  var init_pnp = __esm({
+    "src/compiler/pnp.ts"() {
+      "use strict";
+      init_path();
+    }
+  });
+
   // src/compiler/moduleNameResolver.ts
-  function trace(host) {
-    host.trace(formatMessage.apply(void 0, arguments));
+  function trace(host, message, ...args) {
+    host.trace(formatMessage(message, ...args));
   }
   function isTraceEnabled(compilerOptions, host) {
     return !!compilerOptions.traceResolution && host.trace !== void 0;
@@ -138145,6 +121320,18 @@ ${lanes.join("\n")}
       result.push("JSON");
     return result.join(", ");
   }
+  function extensionsToExtensionsArray(extensions) {
+    const result = [];
+    if (extensions & 1 /* TypeScript */)
+      result.push(...supportedTSImplementationExtensions);
+    if (extensions & 2 /* JavaScript */)
+      result.push(...supportedJSExtensionsFlat);
+    if (extensions & 4 /* Declaration */)
+      result.push(...supportedDeclarationExtensions);
+    if (extensions & 8 /* Json */)
+      result.push(".json" /* Json */);
+    return result;
+  }
   function resolvedTypeScriptOnly(resolved) {
     if (!resolved) {
       return void 0;
@@ -138152,7 +121339,7 @@ ${lanes.join("\n")}
     Debug.assert(extensionIsTS(resolved.extension));
     return { fileName: resolved.path, packageId: resolved.packageId };
   }
-  function createResolvedModuleWithFailedLookupLocationsHandlingSymlink(moduleName, resolved, isExternalLibraryImport, failedLookupLocations, affectingLocations, diagnostics, state, legacyResult) {
+  function createResolvedModuleWithFailedLookupLocationsHandlingSymlink(moduleName, resolved, isExternalLibraryImport, failedLookupLocations, affectingLocations, diagnostics, state, cache, legacyResult) {
     if (!state.resultFromCache && !state.compilerOptions.preserveSymlinks && resolved && isExternalLibraryImport && !resolved.originalPath && !isExternalModuleNameRelative(moduleName)) {
       const { resolvedFileName, originalPath } = getOriginalAndResolvedFileName(resolved.path, state.host, state.traceEnabled);
       if (originalPath)
@@ -138165,15 +121352,25 @@ ${lanes.join("\n")}
       affectingLocations,
       diagnostics,
       state.resultFromCache,
+      cache,
       legacyResult
     );
   }
-  function createResolvedModuleWithFailedLookupLocations(resolved, isExternalLibraryImport, failedLookupLocations, affectingLocations, diagnostics, resultFromCache, legacyResult) {
+  function createResolvedModuleWithFailedLookupLocations(resolved, isExternalLibraryImport, failedLookupLocations, affectingLocations, diagnostics, resultFromCache, cache, legacyResult) {
     if (resultFromCache) {
-      resultFromCache.failedLookupLocations = updateResolutionField(resultFromCache.failedLookupLocations, failedLookupLocations);
-      resultFromCache.affectingLocations = updateResolutionField(resultFromCache.affectingLocations, affectingLocations);
-      resultFromCache.resolutionDiagnostics = updateResolutionField(resultFromCache.resolutionDiagnostics, diagnostics);
-      return resultFromCache;
+      if (!(cache == null ? void 0 : cache.isReadonly)) {
+        resultFromCache.failedLookupLocations = updateResolutionField(resultFromCache.failedLookupLocations, failedLookupLocations);
+        resultFromCache.affectingLocations = updateResolutionField(resultFromCache.affectingLocations, affectingLocations);
+        resultFromCache.resolutionDiagnostics = updateResolutionField(resultFromCache.resolutionDiagnostics, diagnostics);
+        return resultFromCache;
+      } else {
+        return {
+          ...resultFromCache,
+          failedLookupLocations: initializeResolutionFieldForReadonlyCache(resultFromCache.failedLookupLocations, failedLookupLocations),
+          affectingLocations: initializeResolutionFieldForReadonlyCache(resultFromCache.affectingLocations, affectingLocations),
+          resolutionDiagnostics: initializeResolutionFieldForReadonlyCache(resultFromCache.resolutionDiagnostics, diagnostics)
+        };
+      }
     }
     return {
       resolvedModule: resolved && {
@@ -138201,6 +121398,13 @@ ${lanes.join("\n")}
     to.push(...value);
     return to;
   }
+  function initializeResolutionFieldForReadonlyCache(fromCache, value) {
+    if (!(fromCache == null ? void 0 : fromCache.length))
+      return initializeResolutionField(value);
+    if (!value.length)
+      return fromCache.slice();
+    return [...fromCache, ...value];
+  }
   function readPackageJsonField(jsonContent, fieldName, typeOfTag, state) {
     if (!hasProperty(jsonContent, fieldName)) {
       if (state.traceEnabled) {
@@ -138308,7 +121512,7 @@ ${lanes.join("\n")}
       return getDefaultTypeRoots(currentDirectory);
     }
   }
-  function getDefaultTypeRoots(currentDirectory) {
+  function getNodeModulesTypeRoots(currentDirectory) {
     let typeRoots;
     forEachAncestorDirectory(normalizePath(currentDirectory), (directory) => {
       const atTypes = combinePaths(directory, nodeModulesAtTypes);
@@ -138317,8 +121521,17 @@ ${lanes.join("\n")}
     return typeRoots;
   }
   function arePathsEqual(path1, path2, host) {
-    const useCaseSensitiveFileNames = typeof host.useCaseSensitiveFileNames === "function" ? host.useCaseSensitiveFileNames() : host.useCaseSensitiveFileNames;
-    return comparePaths(path1, path2, !useCaseSensitiveFileNames) === 0 /* EqualTo */;
+    const useCaseSensitiveFileNames2 = typeof host.useCaseSensitiveFileNames === "function" ? host.useCaseSensitiveFileNames() : host.useCaseSensitiveFileNames;
+    return comparePaths(path1, path2, !useCaseSensitiveFileNames2) === 0 /* EqualTo */;
+  }
+  function getDefaultTypeRoots(currentDirectory) {
+    const nmTypes = getNodeModulesTypeRoots(currentDirectory);
+    const pnpTypes = getPnpTypeRoots(currentDirectory);
+    if (nmTypes == null ? void 0 : nmTypes.length) {
+      return [...nmTypes, ...pnpTypes];
+    } else if (pnpTypes.length) {
+      return pnpTypes;
+    }
   }
   function getOriginalAndResolvedFileName(fileName, host, traceEnabled) {
     const resolvedFileName = realPath(fileName, host, traceEnabled);
@@ -138376,10 +121589,14 @@ ${lanes.join("\n")}
     const failedLookupLocations = [];
     const affectingLocations = [];
     let features = getNodeResolutionFeatures(options);
-    if (resolutionMode === 99 /* ESNext */ && (getEmitModuleResolutionKind(options) === 3 /* Node16 */ || getEmitModuleResolutionKind(options) === 99 /* NodeNext */)) {
+    if (resolutionMode !== void 0) {
+      features |= 30 /* AllFeatures */;
+    }
+    const moduleResolution = getEmitModuleResolutionKind(options);
+    if (resolutionMode === 99 /* ESNext */ && (3 /* Node16 */ <= moduleResolution && moduleResolution <= 99 /* NodeNext */)) {
       features |= 32 /* EsmMode */;
     }
-    const conditions = features & 8 /* Exports */ ? getConditions(options, !!(features & 32 /* EsmMode */)) : [];
+    const conditions = features & 8 /* Exports */ ? getConditions(options, resolutionMode) : [];
     const diagnostics = [];
     const moduleResolutionState = {
       compilerOptions: options,
@@ -138421,15 +121638,15 @@ ${lanes.join("\n")}
       affectingLocations: initializeResolutionField(affectingLocations),
       resolutionDiagnostics: initializeResolutionField(diagnostics)
     };
-    if (containingDirectory) {
-      cache == null ? void 0 : cache.getOrCreateCacheForDirectory(containingDirectory, redirectedReference).set(
+    if (containingDirectory && cache && !cache.isReadonly) {
+      cache.getOrCreateCacheForDirectory(containingDirectory, redirectedReference).set(
         typeReferenceDirectiveName,
         /*mode*/
         resolutionMode,
         result
       );
       if (!isExternalModuleNameRelative(typeReferenceDirectiveName)) {
-        cache == null ? void 0 : cache.getOrCreateCacheForNonRelativeName(typeReferenceDirectiveName, resolutionMode, redirectedReference).set(containingDirectory, result);
+        cache.getOrCreateCacheForNonRelativeName(typeReferenceDirectiveName, resolutionMode, redirectedReference).set(containingDirectory, result);
       }
     }
     if (traceEnabled)
@@ -138470,12 +121687,7 @@ ${lanes.join("\n")}
             }
           }
           return resolvedTypeScriptOnly(
-            loadNodeModuleFromDirectory(
-              4 /* Declaration */,
-              candidate,
-              !directoryExists,
-              moduleResolutionState
-            )
+            loadNodeModuleFromDirectory(4 /* Declaration */, candidate, !directoryExists, moduleResolutionState)
           );
         });
       } else {
@@ -138552,18 +121764,41 @@ ${lanes.join("\n")}
     }
     return features;
   }
-  function getConditions(options, esmMode) {
-    const conditions = esmMode || getEmitModuleResolutionKind(options) === 100 /* Bundler */ ? ["import"] : ["require"];
+  function getConditions(options, resolutionMode) {
+    const moduleResolution = getEmitModuleResolutionKind(options);
+    if (resolutionMode === void 0) {
+      if (moduleResolution === 100 /* Bundler */) {
+        resolutionMode = 99 /* ESNext */;
+      } else if (moduleResolution === 2 /* Node10 */) {
+        return [];
+      }
+    }
+    const conditions = resolutionMode === 99 /* ESNext */ ? ["import"] : ["require"];
     if (!options.noDtsResolution) {
       conditions.push("types");
     }
-    if (getEmitModuleResolutionKind(options) !== 100 /* Bundler */) {
+    if (moduleResolution !== 100 /* Bundler */) {
       conditions.push("node");
     }
     return concatenate(conditions, options.customConditions);
   }
   function resolvePackageNameToPackageJson(packageName, containingDirectory, options, host, cache) {
     const moduleResolutionState = getTemporaryModuleResolutionState(cache == null ? void 0 : cache.getPackageJsonInfoCache(), host, options);
+    const pnpapi = getPnpApi(containingDirectory);
+    if (pnpapi) {
+      try {
+        const resolution = pnpapi.resolveToUnqualified(packageName, `${containingDirectory}/`, { considerBuiltins: false });
+        const candidate = normalizeSlashes(resolution).replace(/\/$/, "");
+        return getPackageJsonInfo(
+          candidate,
+          /*onlyRecordFailures*/
+          false,
+          moduleResolutionState
+        );
+      } catch {
+        return;
+      }
+    }
     return forEachAncestorDirectory(containingDirectory, (ancestorDirectory) => {
       if (getBaseFileName(ancestorDirectory) !== "node_modules") {
         const nodeModulesFolder = combinePaths(ancestorDirectory, "node_modules");
@@ -138621,11 +121856,10 @@ ${lanes.join("\n")}
     return str + "}";
   }
   function getKeyForCompilerOptions(options, affectingOptionDeclarations) {
-    return affectingOptionDeclarations.map((option) => compilerOptionValueToString(getCompilerOptionValue(options, option))).join("|") + (options.pathsBasePath ? `|${options.pathsBasePath}` : void 0);
+    return affectingOptionDeclarations.map((option) => compilerOptionValueToString(getCompilerOptionValue(options, option))).join("|") + `|${options.pathsBasePath}`;
   }
-  function createCacheWithRedirects(ownOptions) {
+  function createCacheWithRedirects(ownOptions, optionsToRedirectsKey) {
     const redirectsMap = /* @__PURE__ */ new Map();
-    const optionsToRedirectsKey = /* @__PURE__ */ new Map();
     const redirectsKeyToMap = /* @__PURE__ */ new Map();
     let ownMap = /* @__PURE__ */ new Map();
     if (ownOptions)
@@ -138634,7 +121868,8 @@ ${lanes.join("\n")}
       getMapOfCacheRedirects,
       getOrCreateMapOfCacheRedirects,
       update,
-      clear: clear2
+      clear: clear2,
+      getOwnMap: () => ownMap
     };
     function getMapOfCacheRedirects(redirectedReference) {
       return redirectedReference ? getOrCreateMap(
@@ -138735,13 +121970,14 @@ ${lanes.join("\n")}
     }
     return result;
   }
-  function createPerDirectoryResolutionCache(currentDirectory, getCanonicalFileName, options) {
-    const directoryToModuleNameMap = createCacheWithRedirects(options);
+  function createPerDirectoryResolutionCache(currentDirectory, getCanonicalFileName, options, optionsToRedirectsKey) {
+    const directoryToModuleNameMap = createCacheWithRedirects(options, optionsToRedirectsKey);
     return {
       getFromDirectoryCache,
       getOrCreateCacheForDirectory,
       clear: clear2,
-      update
+      update,
+      directoryToModuleNameMap
     };
     function clear2() {
       directoryToModuleNameMap.clear();
@@ -138797,23 +122033,14 @@ ${lanes.join("\n")}
       return result;
     }
   }
-  function zipToModeAwareCache(file, keys, values, nameAndModeGetter) {
-    Debug.assert(keys.length === values.length);
-    const map2 = createModeAwareCache();
-    for (let i = 0; i < keys.length; ++i) {
-      const entry = keys[i];
-      map2.set(nameAndModeGetter.getName(entry), nameAndModeGetter.getMode(entry, file), values[i]);
-    }
-    return map2;
-  }
   function getOriginalOrResolvedModuleFileName(result) {
     return result.resolvedModule && (result.resolvedModule.originalPath || result.resolvedModule.resolvedFileName);
   }
   function getOriginalOrResolvedTypeReferenceFileName(result) {
     return result.resolvedTypeReferenceDirective && (result.resolvedTypeReferenceDirective.originalPath || result.resolvedTypeReferenceDirective.resolvedFileName);
   }
-  function createNonRelativeNameResolutionCache(currentDirectory, getCanonicalFileName, options, getResolvedFileName) {
-    const moduleNameToDirectoryMap = createCacheWithRedirects(options);
+  function createNonRelativeNameResolutionCache(currentDirectory, getCanonicalFileName, options, getResolvedFileName, optionsToRedirectsKey) {
+    const moduleNameToDirectoryMap = createCacheWithRedirects(options, optionsToRedirectsKey);
     return {
       getFromNonRelativeNameCache,
       getOrCreateCacheForNonRelativeName,
@@ -138881,13 +122108,20 @@ ${lanes.join("\n")}
       }
     }
   }
-  function createModuleOrTypeReferenceResolutionCache(currentDirectory, getCanonicalFileName, options, packageJsonInfoCache, getResolvedFileName) {
-    const perDirectoryResolutionCache = createPerDirectoryResolutionCache(currentDirectory, getCanonicalFileName, options);
+  function createModuleOrTypeReferenceResolutionCache(currentDirectory, getCanonicalFileName, options, packageJsonInfoCache, getResolvedFileName, optionsToRedirectsKey) {
+    optionsToRedirectsKey ?? (optionsToRedirectsKey = /* @__PURE__ */ new Map());
+    const perDirectoryResolutionCache = createPerDirectoryResolutionCache(
+      currentDirectory,
+      getCanonicalFileName,
+      options,
+      optionsToRedirectsKey
+    );
     const nonRelativeNameResolutionCache = createNonRelativeNameResolutionCache(
       currentDirectory,
       getCanonicalFileName,
       options,
-      getResolvedFileName
+      getResolvedFileName,
+      optionsToRedirectsKey
     );
     packageJsonInfoCache ?? (packageJsonInfoCache = createPackageJsonInfoCache(currentDirectory, getCanonicalFileName));
     return {
@@ -138897,7 +122131,8 @@ ${lanes.join("\n")}
       clear: clear2,
       update,
       getPackageJsonInfoCache: () => packageJsonInfoCache,
-      clearAllExceptPackageJsonInfoCache
+      clearAllExceptPackageJsonInfoCache,
+      optionsToRedirectsKey
     };
     function clear2() {
       clearAllExceptPackageJsonInfoCache();
@@ -138912,24 +122147,26 @@ ${lanes.join("\n")}
       nonRelativeNameResolutionCache.update(options2);
     }
   }
-  function createModuleResolutionCache(currentDirectory, getCanonicalFileName, options, packageJsonInfoCache) {
+  function createModuleResolutionCache(currentDirectory, getCanonicalFileName, options, packageJsonInfoCache, optionsToRedirectsKey) {
     const result = createModuleOrTypeReferenceResolutionCache(
       currentDirectory,
       getCanonicalFileName,
       options,
       packageJsonInfoCache,
-      getOriginalOrResolvedModuleFileName
+      getOriginalOrResolvedModuleFileName,
+      optionsToRedirectsKey
     );
     result.getOrCreateCacheForModuleName = (nonRelativeName, mode, redirectedReference) => result.getOrCreateCacheForNonRelativeName(nonRelativeName, mode, redirectedReference);
     return result;
   }
-  function createTypeReferenceDirectiveResolutionCache(currentDirectory, getCanonicalFileName, options, packageJsonInfoCache) {
+  function createTypeReferenceDirectiveResolutionCache(currentDirectory, getCanonicalFileName, options, packageJsonInfoCache, optionsToRedirectsKey) {
     return createModuleOrTypeReferenceResolutionCache(
       currentDirectory,
       getCanonicalFileName,
       options,
       packageJsonInfoCache,
-      getOriginalOrResolvedTypeReferenceFileName
+      getOriginalOrResolvedTypeReferenceFileName,
+      optionsToRedirectsKey
     );
   }
   function getOptionsForLibraryResolution(options) {
@@ -139000,13 +122237,13 @@ ${lanes.join("\n")}
           result = nodeNextModuleNameResolver(moduleName, containingFile, compilerOptions, host, cache, redirectedReference, resolutionMode);
           break;
         case 2 /* Node10 */:
-          result = nodeModuleNameResolver(moduleName, containingFile, compilerOptions, host, cache, redirectedReference);
+          result = nodeModuleNameResolver(moduleName, containingFile, compilerOptions, host, cache, redirectedReference, resolutionMode ? getConditions(compilerOptions, resolutionMode) : void 0);
           break;
         case 1 /* Classic */:
           result = classicNameResolver(moduleName, containingFile, compilerOptions, host, cache, redirectedReference);
           break;
         case 100 /* Bundler */:
-          result = bundlerModuleNameResolver(moduleName, containingFile, compilerOptions, host, cache, redirectedReference);
+          result = bundlerModuleNameResolver(moduleName, containingFile, compilerOptions, host, cache, redirectedReference, resolutionMode ? getConditions(compilerOptions, resolutionMode) : void 0);
           break;
         default:
           return Debug.fail(`Unexpected moduleResolution: ${moduleResolution}`);
@@ -139014,9 +122251,11 @@ ${lanes.join("\n")}
       if (result && result.resolvedModule)
         (_b = perfLogger) == null ? void 0 : _b.logInfoEvent(`Module "${moduleName}" resolved to "${result.resolvedModule.resolvedFileName}"`);
       (_c = perfLogger) == null ? void 0 : _c.logStopResolveModule(result && result.resolvedModule ? "" + result.resolvedModule.resolvedFileName : "null");
-      cache == null ? void 0 : cache.getOrCreateCacheForDirectory(containingDirectory, redirectedReference).set(moduleName, resolutionMode, result);
-      if (!isExternalModuleNameRelative(moduleName)) {
-        cache == null ? void 0 : cache.getOrCreateCacheForNonRelativeName(moduleName, resolutionMode, redirectedReference).set(containingDirectory, result);
+      if (cache && !cache.isReadonly) {
+        cache.getOrCreateCacheForDirectory(containingDirectory, redirectedReference).set(moduleName, resolutionMode, result);
+        if (!isExternalModuleNameRelative(moduleName)) {
+          cache.getOrCreateCacheForNonRelativeName(moduleName, resolutionMode, redirectedReference).set(containingDirectory, result);
+        }
       }
     }
     if (traceEnabled) {
@@ -139171,7 +122410,7 @@ ${lanes.join("\n")}
       resolutionMode
     );
   }
-  function nodeNextModuleNameResolverWorker(features, moduleName, containingFile, compilerOptions, host, cache, redirectedReference, resolutionMode) {
+  function nodeNextModuleNameResolverWorker(features, moduleName, containingFile, compilerOptions, host, cache, redirectedReference, resolutionMode, conditions) {
     const containingDirectory = getDirectoryPath(containingFile);
     const esmMode = resolutionMode === 99 /* ESNext */ ? 32 /* EsmMode */ : 0;
     let extensions = compilerOptions.noDtsResolution ? 3 /* ImplementationFiles */ : 1 /* TypeScript */ | 2 /* JavaScript */ | 4 /* Declaration */;
@@ -139188,7 +122427,8 @@ ${lanes.join("\n")}
       extensions,
       /*isConfigLookup*/
       false,
-      redirectedReference
+      redirectedReference,
+      conditions
     );
   }
   function tryResolveJSModuleWorker(moduleName, initialDir, host) {
@@ -139204,10 +122444,12 @@ ${lanes.join("\n")}
       /*isConfigLookup*/
       false,
       /*redirectedReference*/
+      void 0,
+      /*conditions*/
       void 0
     );
   }
-  function bundlerModuleNameResolver(moduleName, containingFile, compilerOptions, host, cache, redirectedReference) {
+  function bundlerModuleNameResolver(moduleName, containingFile, compilerOptions, host, cache, redirectedReference, conditions) {
     const containingDirectory = getDirectoryPath(containingFile);
     let extensions = compilerOptions.noDtsResolution ? 3 /* ImplementationFiles */ : 1 /* TypeScript */ | 2 /* JavaScript */ | 4 /* Declaration */;
     if (getResolveJsonModule(compilerOptions)) {
@@ -139223,10 +122465,11 @@ ${lanes.join("\n")}
       extensions,
       /*isConfigLookup*/
       false,
-      redirectedReference
+      redirectedReference,
+      conditions
     );
   }
-  function nodeModuleNameResolver(moduleName, containingFile, compilerOptions, host, cache, redirectedReference, isConfigLookup) {
+  function nodeModuleNameResolver(moduleName, containingFile, compilerOptions, host, cache, redirectedReference, conditions, isConfigLookup) {
     let extensions;
     if (isConfigLookup) {
       extensions = 8 /* Json */;
@@ -139237,7 +122480,7 @@ ${lanes.join("\n")}
     } else {
       extensions = getResolveJsonModule(compilerOptions) ? 1 /* TypeScript */ | 2 /* JavaScript */ | 4 /* Declaration */ | 8 /* Json */ : 1 /* TypeScript */ | 2 /* JavaScript */ | 4 /* Declaration */;
     }
-    return nodeModuleNameResolverWorker(0 /* None */, moduleName, getDirectoryPath(containingFile), compilerOptions, host, cache, extensions, !!isConfigLookup, redirectedReference);
+    return nodeModuleNameResolverWorker(conditions ? 30 /* AllFeatures */ : 0 /* None */, moduleName, getDirectoryPath(containingFile), compilerOptions, host, cache, extensions, !!isConfigLookup, redirectedReference, conditions);
   }
   function nodeNextJsonConfigResolver(moduleName, containingFile, host) {
     return nodeModuleNameResolverWorker(
@@ -139252,15 +122495,21 @@ ${lanes.join("\n")}
       /*isConfigLookup*/
       true,
       /*redirectedReference*/
+      void 0,
+      /*conditions*/
       void 0
     );
   }
-  function nodeModuleNameResolverWorker(features, moduleName, containingDirectory, compilerOptions, host, cache, extensions, isConfigLookup, redirectedReference) {
+  function nodeModuleNameResolverWorker(features, moduleName, containingDirectory, compilerOptions, host, cache, extensions, isConfigLookup, redirectedReference, conditions) {
     var _a, _b, _c, _d;
     const traceEnabled = isTraceEnabled(compilerOptions, host);
     const failedLookupLocations = [];
     const affectingLocations = [];
-    const conditions = getConditions(compilerOptions, !!(features & 32 /* EsmMode */));
+    const moduleResolution = getEmitModuleResolutionKind(compilerOptions);
+    conditions ?? (conditions = getConditions(
+      compilerOptions,
+      moduleResolution === 100 /* Bundler */ || moduleResolution === 2 /* Node10 */ ? void 0 : features & 32 /* EsmMode */ ? 99 /* ESNext */ : 1 /* CommonJS */
+    ));
     const diagnostics = [];
     const state = {
       compilerOptions,
@@ -139270,17 +122519,17 @@ ${lanes.join("\n")}
       affectingLocations,
       packageJsonInfoCache: cache,
       features,
-      conditions,
+      conditions: conditions ?? emptyArray,
       requestContainingDirectory: containingDirectory,
       reportDiagnostic: (diag2) => void diagnostics.push(diag2),
       isConfigLookup,
       candidateIsFromPackageJsonField: false
     };
-    if (traceEnabled && moduleResolutionSupportsPackageJsonExportsAndImports(getEmitModuleResolutionKind(compilerOptions))) {
-      trace(host, Diagnostics.Resolving_in_0_mode_with_conditions_1, features & 32 /* EsmMode */ ? "ESM" : "CJS", conditions.map((c) => `'${c}'`).join(", "));
+    if (traceEnabled && moduleResolutionSupportsPackageJsonExportsAndImports(moduleResolution)) {
+      trace(host, Diagnostics.Resolving_in_0_mode_with_conditions_1, features & 32 /* EsmMode */ ? "ESM" : "CJS", state.conditions.map((c) => `'${c}'`).join(", "));
     }
     let result;
-    if (getEmitModuleResolutionKind(compilerOptions) === 2 /* Node10 */) {
+    if (moduleResolution === 2 /* Node10 */) {
       const priorityExtensions = extensions & (1 /* TypeScript */ | 4 /* Declaration */);
       const secondaryExtensions = extensions & ~(1 /* TypeScript */ | 4 /* Declaration */);
       result = priorityExtensions && tryResolve(priorityExtensions, state) || secondaryExtensions && tryResolve(secondaryExtensions, state) || void 0;
@@ -139288,7 +122537,7 @@ ${lanes.join("\n")}
       result = tryResolve(extensions, state);
     }
     let legacyResult;
-    if (((_a = result == null ? void 0 : result.value) == null ? void 0 : _a.isExternalLibraryImport) && !isConfigLookup && extensions & (1 /* TypeScript */ | 4 /* Declaration */) && features & 8 /* Exports */ && !isExternalModuleNameRelative(moduleName) && !extensionIsOk(1 /* TypeScript */ | 4 /* Declaration */, result.value.resolved.extension) && conditions.indexOf("import") > -1) {
+    if (((_a = result == null ? void 0 : result.value) == null ? void 0 : _a.isExternalLibraryImport) && !isConfigLookup && extensions & (1 /* TypeScript */ | 4 /* Declaration */) && features & 8 /* Exports */ && !isExternalModuleNameRelative(moduleName) && !extensionIsOk(1 /* TypeScript */ | 4 /* Declaration */, result.value.resolved.extension) && (conditions == null ? void 0 : conditions.includes("import"))) {
       traceIfEnabled(state, Diagnostics.Resolution_of_non_relative_name_failed_trying_with_modern_Node_resolution_features_disabled_to_see_if_npm_library_needs_configuration_update);
       const diagnosticState = {
         ...state,
@@ -139308,6 +122557,7 @@ ${lanes.join("\n")}
       affectingLocations,
       diagnostics,
       state,
+      cache,
       legacyResult
     );
     function tryResolve(extensions2, state2) {
@@ -139332,7 +122582,7 @@ ${lanes.join("\n")}
           resolved2 = loadModuleFromSelfNameReference(extensions2, moduleName, containingDirectory, state2, cache, redirectedReference);
         }
         if (!resolved2) {
-          if (moduleName.indexOf(":") > -1) {
+          if (moduleName.includes(":")) {
             if (traceEnabled) {
               trace(host, Diagnostics.Skipping_module_0_that_looks_like_an_absolute_URI_target_file_types_Colon_1, moduleName, formatExtensions(extensions2));
             }
@@ -139377,7 +122627,6 @@ ${lanes.join("\n")}
     if (traceEnabled) {
       trace(host, Diagnostics.Resolving_real_path_for_0_result_1, path, real);
     }
-    Debug.assert(host.fileExists(real), `${path} linked to nonexistent file ${real}`);
     return real;
   }
   function nodeLoadModuleByRelativeName(extensions, candidate, onlyRecordFailures, state, considerPackageJson) {
@@ -139421,7 +122670,7 @@ ${lanes.join("\n")}
     return void 0;
   }
   function pathContainsNodeModules(path) {
-    return stringContains(path, nodeModulesPathPart);
+    return path.includes(nodeModulesPathPart);
   }
   function parseNodeModuleFromPath(resolved, isFolder) {
     const path = normalizePath(resolved);
@@ -139457,7 +122706,7 @@ ${lanes.join("\n")}
   }
   function loadModuleFromFileNoImplicitExtensions(extensions, candidate, onlyRecordFailures, state) {
     const filename = getBaseFileName(candidate);
-    if (filename.indexOf(".") === -1) {
+    if (!filename.includes(".")) {
       return void 0;
     }
     let extensionless = removeFileExtension(candidate);
@@ -139569,19 +122818,11 @@ ${lanes.join("\n")}
     entrypoints = append(entrypoints, mainResolution == null ? void 0 : mainResolution.path);
     if (features & 8 /* Exports */ && packageJsonInfo.contents.packageJsonContent.exports) {
       const conditionSets = deduplicate(
-        [getConditions(
-          options,
-          /*esmMode*/
-          true
-        ), getConditions(
-          options,
-          /*esmMode*/
-          false
-        )],
+        [getConditions(options, 99 /* ESNext */), getConditions(options, 1 /* CommonJS */)],
         arrayIsEqualTo
       );
       for (const conditions of conditionSets) {
-        const loadPackageJsonExportsState = { ...loadPackageJsonMainState, failedLookupLocations: [], conditions };
+        const loadPackageJsonExportsState = { ...loadPackageJsonMainState, failedLookupLocations: [], conditions, host };
         const exportResolutions = loadEntrypointsFromExportMap(
           packageJsonInfo,
           packageJsonInfo.contents.packageJsonContent.exports,
@@ -139613,23 +122854,44 @@ ${lanes.join("\n")}
     return entrypoints;
     function loadEntrypointsFromTargetExports(target) {
       var _a, _b;
-      if (typeof target === "string" && startsWith(target, "./") && target.indexOf("*") === -1) {
-        const partsAfterFirst = getPathComponents(target).slice(2);
-        if (partsAfterFirst.indexOf("..") >= 0 || partsAfterFirst.indexOf(".") >= 0 || partsAfterFirst.indexOf("node_modules") >= 0) {
-          return false;
-        }
-        const resolvedTarget = combinePaths(scope.packageDirectory, target);
-        const finalPath = getNormalizedAbsolutePath(resolvedTarget, (_b = (_a = state.host).getCurrentDirectory) == null ? void 0 : _b.call(_a));
-        const result = loadFileNameFromPackageJsonField(
-          extensions,
-          finalPath,
-          /*onlyRecordFailures*/
-          false,
-          state
-        );
-        if (result) {
-          entrypoints = appendIfUnique(entrypoints, result, (a, b) => a.path === b.path);
-          return true;
+      if (typeof target === "string" && startsWith(target, "./")) {
+        if (target.includes("*") && state.host.readDirectory) {
+          if (target.indexOf("*") !== target.lastIndexOf("*")) {
+            return false;
+          }
+          state.host.readDirectory(
+            scope.packageDirectory,
+            extensionsToExtensionsArray(extensions),
+            /*excludes*/
+            void 0,
+            [
+              isDeclarationFileName(target) ? target.replace("*", "**/*") : changeAnyExtension(target.replace("*", "**/*"), getDeclarationEmitExtensionForPath(target))
+            ]
+          ).forEach((entry) => {
+            entrypoints = appendIfUnique(entrypoints, {
+              path: entry,
+              ext: getAnyExtensionFromPath(entry),
+              resolvedUsingTsExtension: void 0
+            });
+          });
+        } else {
+          const partsAfterFirst = getPathComponents(target).slice(2);
+          if (partsAfterFirst.includes("..") || partsAfterFirst.includes(".") || partsAfterFirst.includes("node_modules")) {
+            return false;
+          }
+          const resolvedTarget = combinePaths(scope.packageDirectory, target);
+          const finalPath = getNormalizedAbsolutePath(resolvedTarget, (_b = (_a = state.host).getCurrentDirectory) == null ? void 0 : _b.call(_a));
+          const result = loadFileNameFromPackageJsonField(
+            extensions,
+            finalPath,
+            /*onlyRecordFailures*/
+            false,
+            state
+          );
+          if (result) {
+            entrypoints = appendIfUnique(entrypoints, result, (a, b) => a.path === b.path);
+            return true;
+          }
         }
       } else if (Array.isArray(target)) {
         for (const t of target) {
@@ -139688,7 +122950,7 @@ ${lanes.join("\n")}
     return packageJsonInfo.contents.versionPaths || void 0;
   }
   function getPackageJsonInfo(packageDirectory, onlyRecordFailures, state) {
-    var _a, _b, _c, _d, _e, _f, _g, _h;
+    var _a, _b, _c, _d, _e, _f;
     const { host, traceEnabled } = state;
     const packageJsonPath = combinePaths(packageDirectory, "package.json");
     if (onlyRecordFailures) {
@@ -139716,15 +122978,17 @@ ${lanes.join("\n")}
         trace(host, Diagnostics.Found_package_json_at_0, packageJsonPath);
       }
       const result = { packageDirectory, contents: { packageJsonContent, versionPaths: void 0, resolvedEntrypoints: void 0 } };
-      (_e = state.packageJsonInfoCache) == null ? void 0 : _e.setPackageJsonInfo(packageJsonPath, result);
-      (_f = state.affectingLocations) == null ? void 0 : _f.push(packageJsonPath);
+      if (state.packageJsonInfoCache && !state.packageJsonInfoCache.isReadonly)
+        state.packageJsonInfoCache.setPackageJsonInfo(packageJsonPath, result);
+      (_e = state.affectingLocations) == null ? void 0 : _e.push(packageJsonPath);
       return result;
     } else {
       if (directoryExists && traceEnabled) {
         trace(host, Diagnostics.File_0_does_not_exist, packageJsonPath);
       }
-      (_g = state.packageJsonInfoCache) == null ? void 0 : _g.setPackageJsonInfo(packageJsonPath, directoryExists);
-      (_h = state.failedLookupLocations) == null ? void 0 : _h.push(packageJsonPath);
+      if (state.packageJsonInfoCache && !state.packageJsonInfoCache.isReadonly)
+        state.packageJsonInfoCache.setPackageJsonInfo(packageJsonPath, directoryExists);
+      (_f = state.failedLookupLocations) == null ? void 0 : _f.push(packageJsonPath);
     }
   }
   function loadNodeModuleFromDirectoryWorker(extensions, candidate, onlyRecordFailures, state, jsonContent, versionPaths) {
@@ -139838,6 +123102,9 @@ ${lanes.join("\n")}
     }
     const trailingParts = parts.slice(nameParts.length);
     const subpath = !length(trailingParts) ? "." : `.${directorySeparator}${trailingParts.join(directorySeparator)}`;
+    if (getAllowJSCompilerOption(state.compilerOptions) && !pathContainsNodeModules(directory)) {
+      return loadModuleFromExports(scope, extensions, subpath, state, cache, redirectedReference);
+    }
     const priorityExtensions = extensions & (1 /* TypeScript */ | 4 /* Declaration */);
     const secondaryExtensions = extensions & ~(1 /* TypeScript */ | 4 /* Declaration */);
     return loadModuleFromExports(scope, priorityExtensions, subpath, state, cache, redirectedReference) || loadModuleFromExports(scope, secondaryExtensions, subpath, state, cache, redirectedReference);
@@ -139979,7 +123246,7 @@ ${lanes.join("\n")}
   }
   function loadModuleFromImportsOrExports(extensions, state, cache, redirectedReference, moduleName, lookupTable, scope, isImports) {
     const loadModuleFromTargetImportOrExport = getLoadModuleFromTargetImportOrExport(extensions, state, cache, redirectedReference, moduleName, scope, isImports);
-    if (!endsWith(moduleName, directorySeparator) && moduleName.indexOf("*") === -1 && hasProperty(lookupTable, moduleName)) {
+    if (!endsWith(moduleName, directorySeparator) && !moduleName.includes("*") && hasProperty(lookupTable, moduleName)) {
       const target = lookupTable[moduleName];
       return loadModuleFromTargetImportOrExport(
         target,
@@ -139990,7 +123257,7 @@ ${lanes.join("\n")}
         moduleName
       );
     }
-    const expandingKeys = sort(filter(getOwnKeys(lookupTable), (k) => k.indexOf("*") !== -1 || endsWith(k, "/")), comparePatternKeys);
+    const expandingKeys = sort(filter(getOwnKeys(lookupTable), (k) => k.includes("*") || endsWith(k, "/")), comparePatternKeys);
     for (const potentialTarget of expandingKeys) {
       if (state.features & 16 /* ExportsPatternTrailers */ && matchesPatternWithTrailer(potentialTarget, moduleName)) {
         const target = lookupTable[potentialTarget];
@@ -140062,15 +123329,18 @@ ${lanes.join("\n")}
               extensions,
               /*isConfigLookup*/
               false,
-              redirectedReference
+              redirectedReference,
+              state.conditions
+            );
+            return toSearchResult(
+              result.resolvedModule ? {
+                path: result.resolvedModule.resolvedFileName,
+                extension: result.resolvedModule.extension,
+                packageId: result.resolvedModule.packageId,
+                originalPath: result.resolvedModule.originalPath,
+                resolvedUsingTsExtension: result.resolvedModule.resolvedUsingTsExtension
+              } : void 0
             );
-            return toSearchResult(result.resolvedModule ? {
-              path: result.resolvedModule.resolvedFileName,
-              extension: result.resolvedModule.extension,
-              packageId: result.resolvedModule.packageId,
-              originalPath: result.resolvedModule.originalPath,
-              resolvedUsingTsExtension: result.resolvedModule.resolvedUsingTsExtension
-            } : void 0);
           }
           if (state.traceEnabled) {
             trace(state.host, Diagnostics.package_json_scope_0_has_invalid_type_for_target_of_specifier_1, scope.packageDirectory, moduleName);
@@ -140082,7 +123352,7 @@ ${lanes.join("\n")}
         }
         const parts = pathIsRelative(target) ? getPathComponents(target).slice(1) : getPathComponents(target);
         const partsAfterFirst = parts.slice(1);
-        if (partsAfterFirst.indexOf("..") >= 0 || partsAfterFirst.indexOf(".") >= 0 || partsAfterFirst.indexOf("node_modules") >= 0) {
+        if (partsAfterFirst.includes("..") || partsAfterFirst.includes(".") || partsAfterFirst.includes("node_modules")) {
           if (state.traceEnabled) {
             trace(state.host, Diagnostics.package_json_scope_0_has_invalid_type_for_target_of_specifier_1, scope.packageDirectory, moduleName);
           }
@@ -140093,7 +123363,7 @@ ${lanes.join("\n")}
         }
         const resolvedTarget = combinePaths(scope.packageDirectory, target);
         const subpathParts = getPathComponents(subpath);
-        if (subpathParts.indexOf("..") >= 0 || subpathParts.indexOf(".") >= 0 || subpathParts.indexOf("node_modules") >= 0) {
+        if (subpathParts.includes("..") || subpathParts.includes(".") || subpathParts.includes("node_modules")) {
           if (state.traceEnabled) {
             trace(state.host, Diagnostics.package_json_scope_0_has_invalid_type_for_target_of_specifier_1, scope.packageDirectory, moduleName);
           }
@@ -140103,13 +123373,7 @@ ${lanes.join("\n")}
           );
         }
         if (state.traceEnabled) {
-          trace(
-            state.host,
-            Diagnostics.Using_0_subpath_1_with_target_2,
-            isImports ? "imports" : "exports",
-            key,
-            pattern ? target.replace(/\*/g, subpath) : target + subpath
-          );
+          trace(state.host, Diagnostics.Using_0_subpath_1_with_target_2, isImports ? "imports" : "exports", key, pattern ? target.replace(/\*/g, subpath) : target + subpath);
         }
         const finalPath = toAbsolutePath(pattern ? resolvedTarget.replace(/\*/g, subpath) : resolvedTarget + subpath);
         const inputLink = tryLoadInputFileForPath(finalPath, subpath, combinePaths(scope.packageDirectory, "package.json"), isImports);
@@ -140126,7 +123390,7 @@ ${lanes.join("\n")}
         if (!Array.isArray(target)) {
           traceIfEnabled(state, Diagnostics.Entering_conditional_exports);
           for (const condition of getOwnKeys(target)) {
-            if (condition === "default" || state.conditions.indexOf(condition) >= 0 || isApplicableVersionedTypesKey(state.conditions, condition)) {
+            if (condition === "default" || state.conditions.includes(condition) || isApplicableVersionedTypesKey(state.conditions, condition)) {
               traceIfEnabled(state, Diagnostics.Matched_0_condition_1, isImports ? "imports" : "exports", condition);
               const subTarget = target[condition];
               const result = loadModuleFromTargetImportOrExport(subTarget, subpath, pattern, key);
@@ -140185,13 +123449,10 @@ ${lanes.join("\n")}
       function combineDirectoryPath(root, dir) {
         return ensureTrailingDirectorySeparator(combinePaths(root, dir));
       }
-      function useCaseSensitiveFileNames() {
-        return !state.host.useCaseSensitiveFileNames ? true : typeof state.host.useCaseSensitiveFileNames === "boolean" ? state.host.useCaseSensitiveFileNames : state.host.useCaseSensitiveFileNames();
-      }
       function tryLoadInputFileForPath(finalPath, entry, packagePath, isImports2) {
         var _a, _b, _c, _d;
-        if (!state.isConfigLookup && (state.compilerOptions.declarationDir || state.compilerOptions.outDir) && finalPath.indexOf("/node_modules/") === -1 && (state.compilerOptions.configFile ? containsPath(scope.packageDirectory, toAbsolutePath(state.compilerOptions.configFile.fileName), !useCaseSensitiveFileNames()) : true)) {
-          const getCanonicalFileName = hostGetCanonicalFileName({ useCaseSensitiveFileNames });
+        if (!state.isConfigLookup && (state.compilerOptions.declarationDir || state.compilerOptions.outDir) && !finalPath.includes("/node_modules/") && (state.compilerOptions.configFile ? containsPath(scope.packageDirectory, toAbsolutePath(state.compilerOptions.configFile.fileName), !useCaseSensitiveFileNames(state)) : true)) {
+          const getCanonicalFileName = hostGetCanonicalFileName({ useCaseSensitiveFileNames: () => useCaseSensitiveFileNames(state) });
           const commonSourceDirGuesses = [];
           if (state.compilerOptions.rootDir || state.compilerOptions.composite && state.compilerOptions.configFilePath) {
             const commonDir = toAbsolutePath(getCommonSourceDirectory(state.compilerOptions, () => [], ((_b = (_a = state.host).getCurrentDirectory) == null ? void 0 : _b.call(_a)) || "", getCanonicalFileName));
@@ -140220,7 +123481,7 @@ ${lanes.join("\n")}
           for (const commonSourceDirGuess of commonSourceDirGuesses) {
             const candidateDirectories = getOutputDirectoriesForBaseDirectory(commonSourceDirGuess);
             for (const candidateDir of candidateDirectories) {
-              if (containsPath(candidateDir, finalPath, !useCaseSensitiveFileNames())) {
+              if (containsPath(candidateDir, finalPath, !useCaseSensitiveFileNames(state))) {
                 const pathFragment = finalPath.slice(candidateDir.length + 1);
                 const possibleInputBase = combinePaths(commonSourceDirGuess, pathFragment);
                 const jsAndDtsExtensions = [".mjs" /* Mjs */, ".cjs" /* Cjs */, ".js" /* Js */, ".json" /* Json */, ".d.mts" /* Dmts */, ".d.cts" /* Dcts */, ".d.ts" /* Dts */];
@@ -140230,7 +123491,7 @@ ${lanes.join("\n")}
                     for (const possibleExt of inputExts) {
                       if (!extensionIsOk(extensions, possibleExt))
                         continue;
-                      const possibleInputWithInputExtension = changeAnyExtension(possibleInputBase, possibleExt, ext, !useCaseSensitiveFileNames());
+                      const possibleInputWithInputExtension = changeAnyExtension(possibleInputBase, possibleExt, ext, !useCaseSensitiveFileNames(state));
                       if (state.host.fileExists(possibleInputWithInputExtension)) {
                         return toSearchResult(withPackageId(scope, loadFileNameFromPackageJsonField(
                           extensions,
@@ -140264,7 +123525,7 @@ ${lanes.join("\n")}
     }
   }
   function isApplicableVersionedTypesKey(conditions, key) {
-    if (conditions.indexOf("types") === -1)
+    if (!conditions.includes("types"))
       return false;
     if (!startsWith(key, "types@"))
       return false;
@@ -140304,15 +123565,25 @@ ${lanes.join("\n")}
     const priorityExtensions = extensions & (1 /* TypeScript */ | 4 /* Declaration */);
     const secondaryExtensions = extensions & ~(1 /* TypeScript */ | 4 /* Declaration */);
     if (priorityExtensions) {
+      traceIfEnabled(state, Diagnostics.Searching_all_ancestor_node_modules_directories_for_preferred_extensions_Colon_0, formatExtensions(priorityExtensions));
       const result = lookup(priorityExtensions);
       if (result)
         return result;
     }
     if (secondaryExtensions && !typesScopeOnly) {
+      traceIfEnabled(state, Diagnostics.Searching_all_ancestor_node_modules_directories_for_fallback_extensions_Colon_0, formatExtensions(secondaryExtensions));
       return lookup(secondaryExtensions);
     }
     function lookup(extensions2) {
-      return forEachAncestorDirectory(normalizeSlashes(directory), (ancestorDirectory) => {
+      const issuer = normalizeSlashes(directory);
+      if (getPnpApi(issuer)) {
+        const resolutionFromCache = tryFindNonRelativeModuleNameInCache(cache, moduleName, mode, issuer, redirectedReference, state);
+        if (resolutionFromCache) {
+          return resolutionFromCache;
+        }
+        return toSearchResult(loadModuleFromImmediateNodeModulesDirectoryPnP(extensions2, moduleName, issuer, state, typesScopeOnly, cache, redirectedReference));
+      }
+      return forEachAncestorDirectory(issuer, (ancestorDirectory) => {
         if (getBaseFileName(ancestorDirectory) !== "node_modules") {
           const resolutionFromCache = tryFindNonRelativeModuleNameInCache(cache, moduleName, mode, ancestorDirectory, redirectedReference, state);
           if (resolutionFromCache) {
@@ -140347,11 +123618,40 @@ ${lanes.join("\n")}
       return loadModuleFromSpecificNodeModulesDirectory(4 /* Declaration */, mangleScopedPackageNameWithTrace(moduleName, state), nodeModulesAtTypes2, nodeModulesAtTypesExists, state, cache, redirectedReference);
     }
   }
+  function loadModuleFromImmediateNodeModulesDirectoryPnP(extensions, moduleName, directory, state, typesScopeOnly, cache, redirectedReference) {
+    const issuer = normalizeSlashes(directory);
+    if (!typesScopeOnly) {
+      const packageResult = tryLoadModuleUsingPnpResolution(extensions, moduleName, issuer, state, cache, redirectedReference);
+      if (packageResult) {
+        return packageResult;
+      }
+    }
+    if (extensions & 4 /* Declaration */) {
+      return tryLoadModuleUsingPnpResolution(4 /* Declaration */, `@types/${mangleScopedPackageNameWithTrace(moduleName, state)}`, issuer, state, cache, redirectedReference);
+    }
+  }
   function loadModuleFromSpecificNodeModulesDirectory(extensions, moduleName, nodeModulesDirectory, nodeModulesDirectoryExists, state, cache, redirectedReference) {
-    var _a, _b;
     const candidate = normalizePath(combinePaths(nodeModulesDirectory, moduleName));
     const { packageName, rest } = parsePackageName(moduleName);
     const packageDirectory = combinePaths(nodeModulesDirectory, packageName);
+    return loadModuleFromSpecificNodeModulesDirectoryImpl(extensions, nodeModulesDirectoryExists, state, cache, redirectedReference, candidate, rest, packageDirectory);
+  }
+  function loadModuleFromPnpResolution(extensions, packageDirectory, rest, state, cache, redirectedReference) {
+    const candidate = normalizePath(combinePaths(packageDirectory, rest));
+    return loadModuleFromSpecificNodeModulesDirectoryImpl(
+      extensions,
+      /*nodeModulesDirectoryExists*/
+      true,
+      state,
+      cache,
+      redirectedReference,
+      candidate,
+      rest,
+      packageDirectory
+    );
+  }
+  function loadModuleFromSpecificNodeModulesDirectoryImpl(extensions, nodeModulesDirectoryExists, state, cache, redirectedReference, candidate, rest, packageDirectory) {
+    var _a, _b;
     let rootPackageInfo;
     let packageInfo = getPackageJsonInfo(candidate, !nodeModulesDirectoryExists, state);
     if (rest !== "" && packageInfo && (!(state.features & 8 /* Exports */) || !hasProperty(((_a = rootPackageInfo = getPackageJsonInfo(packageDirectory, !nodeModulesDirectoryExists, state)) == null ? void 0 : _a.contents.packageJsonContent) ?? emptyArray, "exports"))) {
@@ -140466,7 +123766,7 @@ ${lanes.join("\n")}
     return mangledName;
   }
   function unmangleScopedPackageName(typesPackageName) {
-    return stringContains(typesPackageName, mangledScopedPackageSeparator) ? "@" + typesPackageName.replace(mangledScopedPackageSeparator, directorySeparator) : typesPackageName;
+    return typesPackageName.includes(mangledScopedPackageSeparator) ? "@" + typesPackageName.replace(mangledScopedPackageSeparator, directorySeparator) : typesPackageName;
   }
   function tryFindNonRelativeModuleNameInCache(cache, moduleName, mode, containingDirectory, redirectedReference, state) {
     const result = cache && cache.getFromNonRelativeNameCache(moduleName, mode, containingDirectory, redirectedReference);
@@ -140514,7 +123814,8 @@ ${lanes.join("\n")}
       failedLookupLocations,
       affectingLocations,
       diagnostics,
-      state
+      state,
+      cache
     );
     function tryResolve(extensions) {
       const resolvedUsingSettings = tryLoadModuleUsingOptionalResolutionSettings(extensions, moduleName, containingDirectory, loadModuleFromFileNoPackageId, state);
@@ -140633,7 +123934,9 @@ ${lanes.join("\n")}
       failedLookupLocations,
       affectingLocations,
       diagnostics,
-      state.resultFromCache
+      state.resultFromCache,
+      /*cache*/
+      void 0
     );
   }
   function toSearchResult(value) {
@@ -140644,11 +123947,27 @@ ${lanes.join("\n")}
       trace(state.host, diagnostic, ...args);
     }
   }
+  function useCaseSensitiveFileNames(state) {
+    return !state.host.useCaseSensitiveFileNames ? true : typeof state.host.useCaseSensitiveFileNames === "boolean" ? state.host.useCaseSensitiveFileNames : state.host.useCaseSensitiveFileNames();
+  }
+  function loadPnpPackageResolution(packageName, containingDirectory) {
+    try {
+      const resolution = getPnpApi(containingDirectory).resolveToUnqualified(packageName, `${containingDirectory}/`, { considerBuiltins: false });
+      return normalizeSlashes(resolution).replace(/\/$/, "");
+    } catch {
+    }
+  }
+  function tryLoadModuleUsingPnpResolution(extensions, moduleName, containingDirectory, state, cache, redirectedReference) {
+    const { packageName, rest } = parsePackageName(moduleName);
+    const packageResolution = loadPnpPackageResolution(packageName, containingDirectory);
+    return packageResolution ? loadModuleFromPnpResolution(extensions, packageResolution, rest, state, cache, redirectedReference) : void 0;
+  }
   var typeScriptVersion, nodeModulesAtTypes, NodeResolutionFeatures, nodeModulesPathPart, mangledScopedPackageSeparator;
   var init_moduleNameResolver = __esm({
     "src/compiler/moduleNameResolver.ts"() {
       "use strict";
       init_ts2();
+      init_pnp();
       nodeModulesAtTypes = combinePaths("node_modules", "@types");
       NodeResolutionFeatures = /* @__PURE__ */ ((NodeResolutionFeatures2) => {
         NodeResolutionFeatures2[NodeResolutionFeatures2["None"] = 0] = "None";
@@ -140692,23 +124011,23 @@ ${lanes.join("\n")}
   }
   function getModuleInstanceStateWorker(node, visited) {
     switch (node.kind) {
-      case 263 /* InterfaceDeclaration */:
-      case 264 /* TypeAliasDeclaration */:
+      case 264 /* InterfaceDeclaration */:
+      case 265 /* TypeAliasDeclaration */:
         return 0 /* NonInstantiated */;
-      case 265 /* EnumDeclaration */:
+      case 266 /* EnumDeclaration */:
         if (isEnumConst(node)) {
           return 2 /* ConstEnumOnly */;
         }
         break;
-      case 271 /* ImportDeclaration */:
-      case 270 /* ImportEqualsDeclaration */:
-        if (!hasSyntacticModifier(node, 1 /* Export */)) {
+      case 272 /* ImportDeclaration */:
+      case 271 /* ImportEqualsDeclaration */:
+        if (!hasSyntacticModifier(node, 32 /* Export */)) {
           return 0 /* NonInstantiated */;
         }
         break;
-      case 277 /* ExportDeclaration */:
+      case 278 /* ExportDeclaration */:
         const exportDeclaration = node;
-        if (!exportDeclaration.moduleSpecifier && exportDeclaration.exportClause && exportDeclaration.exportClause.kind === 278 /* NamedExports */) {
+        if (!exportDeclaration.moduleSpecifier && exportDeclaration.exportClause && exportDeclaration.exportClause.kind === 279 /* NamedExports */) {
           let state = 0 /* NonInstantiated */;
           for (const specifier of exportDeclaration.exportClause.elements) {
             const specifierState = getModuleInstanceStateForAliasTarget(specifier, visited);
@@ -140722,7 +124041,7 @@ ${lanes.join("\n")}
           return state;
         }
         break;
-      case 267 /* ModuleBlock */: {
+      case 268 /* ModuleBlock */: {
         let state = 0 /* NonInstantiated */;
         forEachChild(node, (n) => {
           const childState = getModuleInstanceStateCached(n, visited);
@@ -140741,10 +124060,10 @@ ${lanes.join("\n")}
         });
         return state;
       }
-      case 266 /* ModuleDeclaration */:
+      case 267 /* ModuleDeclaration */:
         return getModuleInstanceState(node, visited);
       case 80 /* Identifier */:
-        if (node.flags & 2048 /* IdentifierIsInJSDocNamespace */) {
+        if (node.flags & 4096 /* IdentifierIsInJSDocNamespace */) {
           return 0 /* NonInstantiated */;
         }
     }
@@ -140774,6 +124093,9 @@ ${lanes.join("\n")}
             if (found === 1 /* Instantiated */) {
               return found;
             }
+            if (statement.kind === 271 /* ImportEqualsDeclaration */) {
+              found = 1 /* Instantiated */;
+            }
           }
         }
         if (found !== void 0) {
@@ -140907,7 +124229,7 @@ ${lanes.join("\n")}
       }
     }
     function getDeclarationName(node) {
-      if (node.kind === 276 /* ExportAssignment */) {
+      if (node.kind === 277 /* ExportAssignment */) {
         return node.isExportEquals ? "export=" /* ExportEquals */ : "default" /* Default */;
       }
       const name = getNameOfDeclaration(node);
@@ -140916,7 +124238,7 @@ ${lanes.join("\n")}
           const moduleName = getTextOfIdentifierOrLiteral(name);
           return isGlobalScopeAugmentation(node) ? "__global" : `"${moduleName}"`;
         }
-        if (name.kind === 166 /* ComputedPropertyName */) {
+        if (name.kind === 167 /* ComputedPropertyName */) {
           const nameExpression = name.expression;
           if (isStringOrNumericLiteralLike(nameExpression)) {
             return escapeLeadingUnderscores(nameExpression.text);
@@ -140941,31 +124263,31 @@ ${lanes.join("\n")}
         return isPropertyNameLiteral(name) ? getEscapedTextOfIdentifierOrLiteral(name) : void 0;
       }
       switch (node.kind) {
-        case 175 /* Constructor */:
+        case 176 /* Constructor */:
           return "__constructor" /* Constructor */;
-        case 183 /* FunctionType */:
-        case 178 /* CallSignature */:
-        case 329 /* JSDocSignature */:
+        case 184 /* FunctionType */:
+        case 179 /* CallSignature */:
+        case 330 /* JSDocSignature */:
           return "__call" /* Call */;
-        case 184 /* ConstructorType */:
-        case 179 /* ConstructSignature */:
+        case 185 /* ConstructorType */:
+        case 180 /* ConstructSignature */:
           return "__new" /* New */;
-        case 180 /* IndexSignature */:
+        case 181 /* IndexSignature */:
           return "__index" /* Index */;
-        case 277 /* ExportDeclaration */:
+        case 278 /* ExportDeclaration */:
           return "__export" /* ExportStar */;
-        case 311 /* SourceFile */:
+        case 312 /* SourceFile */:
           return "export=" /* ExportEquals */;
-        case 225 /* BinaryExpression */:
+        case 226 /* BinaryExpression */:
           if (getAssignmentDeclarationKind(node) === 2 /* ModuleExports */) {
             return "export=" /* ExportEquals */;
           }
           Debug.fail("Unknown binary declaration kind");
           break;
-        case 323 /* JSDocFunctionType */:
+        case 324 /* JSDocFunctionType */:
           return isJSDocConstructSignature(node) ? "__new" /* New */ : "__call" /* Call */;
-        case 168 /* Parameter */:
-          Debug.assert(node.parent.kind === 323 /* JSDocFunctionType */, "Impossible parameter parent kind", () => `parent is: ${Debug.formatSyntaxKind(node.parent.kind)}, expected JSDocFunctionType`);
+        case 169 /* Parameter */:
+          Debug.assert(node.parent.kind === 324 /* JSDocFunctionType */, "Impossible parameter parent kind", () => `parent is: ${Debug.formatSyntaxKind(node.parent.kind)}, expected JSDocFunctionType`);
           const functionType = node.parent;
           const index = functionType.parameters.indexOf(node);
           return "arg" + index;
@@ -140976,7 +124298,7 @@ ${lanes.join("\n")}
     }
     function declareSymbol(symbolTable, parent3, node, includes, excludes, isReplaceableByMethod, isComputedName) {
       Debug.assert(isComputedName || !hasDynamicName(node));
-      const isDefaultExport = hasSyntacticModifier(node, 1024 /* Default */) || isExportSpecifier(node) && node.name.escapedText === "default";
+      const isDefaultExport = hasSyntacticModifier(node, 2048 /* Default */) || isExportSpecifier(node) && node.name.escapedText === "default";
       const name = isComputedName ? "__computed" /* Computed */ : isDefaultExport && parent3 ? "default" /* Default */ : getDeclarationName(node);
       let symbol;
       if (name === void 0) {
@@ -141012,7 +124334,7 @@ ${lanes.join("\n")}
                 messageNeedsName = false;
                 multipleDefaultExports = true;
               } else {
-                if (symbol.declarations && symbol.declarations.length && (node.kind === 276 /* ExportAssignment */ && !node.isExportEquals)) {
+                if (symbol.declarations && symbol.declarations.length && (node.kind === 277 /* ExportAssignment */ && !node.isExportEquals)) {
                   message = Diagnostics.A_module_cannot_have_multiple_default_exports;
                   messageNeedsName = false;
                   multipleDefaultExports = true;
@@ -141020,7 +124342,7 @@ ${lanes.join("\n")}
               }
             }
             const relatedInformation = [];
-            if (isTypeAliasDeclaration(node) && nodeIsMissing(node.type) && hasSyntacticModifier(node, 1 /* Export */) && symbol.flags & (2097152 /* Alias */ | 788968 /* Type */ | 1920 /* Namespace */)) {
+            if (isTypeAliasDeclaration(node) && nodeIsMissing(node.type) && hasSyntacticModifier(node, 32 /* Export */) && symbol.flags & (2097152 /* Alias */ | 788968 /* Type */ | 1920 /* Namespace */)) {
               relatedInformation.push(createDiagnosticForNode2(node, Diagnostics.Did_you_mean_0, `export type { ${unescapeLeadingUnderscores(node.name.escapedText)} }`));
             }
             const declarationName = getNameOfDeclaration(node) || node;
@@ -141049,9 +124371,9 @@ ${lanes.join("\n")}
       return symbol;
     }
     function declareModuleMember(node, symbolFlags, symbolExcludes) {
-      const hasExportModifier = !!(getCombinedModifierFlags(node) & 1 /* Export */) || jsdocTreatAsExported(node);
+      const hasExportModifier = !!(getCombinedModifierFlags(node) & 32 /* Export */) || jsdocTreatAsExported(node);
       if (symbolFlags & 2097152 /* Alias */) {
-        if (node.kind === 280 /* ExportSpecifier */ || node.kind === 270 /* ImportEqualsDeclaration */ && hasExportModifier) {
+        if (node.kind === 281 /* ExportSpecifier */ || node.kind === 271 /* ImportEqualsDeclaration */ && hasExportModifier) {
           return declareSymbol(container.symbol.exports, container.symbol, node, symbolFlags, symbolExcludes);
         } else {
           Debug.assertNode(container, canHaveLocals);
@@ -141067,8 +124389,8 @@ ${lanes.join("\n")}
       } else {
         if (isJSDocTypeAlias(node))
           Debug.assert(isInJSFile(node));
-        if (!isAmbientModule(node) && (hasExportModifier || container.flags & 64 /* ExportContext */)) {
-          if (!canHaveLocals(container) || !container.locals || hasSyntacticModifier(node, 1024 /* Default */) && !getDeclarationName(node)) {
+        if (!isAmbientModule(node) && (hasExportModifier || container.flags & 128 /* ExportContext */)) {
+          if (!canHaveLocals(container) || !container.locals || hasSyntacticModifier(node, 2048 /* Default */) && !getDeclarationName(node)) {
             return declareSymbol(container.symbol.exports, container.symbol, node, symbolFlags, symbolExcludes);
           }
           const exportKind = symbolFlags & 111551 /* Value */ ? 1048576 /* ExportValue */ : 0;
@@ -141109,7 +124431,7 @@ ${lanes.join("\n")}
         return false;
       if (isPropertyAccessEntityNameExpression(declName.parent) && isTopLevelNamespaceAssignment(declName.parent))
         return true;
-      if (isDeclaration(declName.parent) && getCombinedModifierFlags(declName.parent) & 1 /* Export */)
+      if (isDeclaration(declName.parent) && getCombinedModifierFlags(declName.parent) & 32 /* Export */)
         return true;
       return false;
     }
@@ -141118,7 +124440,7 @@ ${lanes.join("\n")}
       const saveThisParentContainer = thisParentContainer;
       const savedBlockScopeContainer = blockScopeContainer;
       if (containerFlags & 1 /* IsContainer */) {
-        if (node.kind !== 218 /* ArrowFunction */) {
+        if (node.kind !== 219 /* ArrowFunction */) {
           thisParentContainer = container;
         }
         container = blockScopeContainer = node;
@@ -141140,35 +124462,35 @@ ${lanes.join("\n")}
         const saveExceptionTarget = currentExceptionTarget;
         const saveActiveLabelList = activeLabelList;
         const saveHasExplicitReturn = hasExplicitReturn;
-        const isImmediatelyInvoked = containerFlags & 16 /* IsFunctionExpression */ && !hasSyntacticModifier(node, 512 /* Async */) && !node.asteriskToken && !!getImmediatelyInvokedFunctionExpression(node) || node.kind === 174 /* ClassStaticBlockDeclaration */;
+        const isImmediatelyInvoked = containerFlags & 16 /* IsFunctionExpression */ && !hasSyntacticModifier(node, 1024 /* Async */) && !node.asteriskToken && !!getImmediatelyInvokedFunctionExpression(node) || node.kind === 175 /* ClassStaticBlockDeclaration */;
         if (!isImmediatelyInvoked) {
           currentFlow = initFlowNode({ flags: 2 /* Start */ });
           if (containerFlags & (16 /* IsFunctionExpression */ | 128 /* IsObjectLiteralOrClassExpressionMethodOrAccessor */)) {
             currentFlow.node = node;
           }
         }
-        currentReturnTarget = isImmediatelyInvoked || node.kind === 175 /* Constructor */ || isInJSFile(node) && (node.kind === 261 /* FunctionDeclaration */ || node.kind === 217 /* FunctionExpression */) ? createBranchLabel() : void 0;
+        currentReturnTarget = isImmediatelyInvoked || node.kind === 176 /* Constructor */ || isInJSFile(node) && (node.kind === 262 /* FunctionDeclaration */ || node.kind === 218 /* FunctionExpression */) ? createBranchLabel() : void 0;
         currentExceptionTarget = void 0;
         currentBreakTarget = void 0;
         currentContinueTarget = void 0;
         activeLabelList = void 0;
         hasExplicitReturn = false;
         bindChildren(node);
-        node.flags &= ~2816 /* ReachabilityAndEmitFlags */;
+        node.flags &= ~5632 /* ReachabilityAndEmitFlags */;
         if (!(currentFlow.flags & 1 /* Unreachable */) && containerFlags & 8 /* IsFunctionLike */ && nodeIsPresent(node.body)) {
-          node.flags |= 256 /* HasImplicitReturn */;
+          node.flags |= 512 /* HasImplicitReturn */;
           if (hasExplicitReturn)
-            node.flags |= 512 /* HasExplicitReturn */;
+            node.flags |= 1024 /* HasExplicitReturn */;
           node.endFlowNode = currentFlow;
         }
-        if (node.kind === 311 /* SourceFile */) {
+        if (node.kind === 312 /* SourceFile */) {
           node.flags |= emitFlags;
           node.endFlowNode = currentFlow;
         }
         if (currentReturnTarget) {
           addAntecedent(currentReturnTarget, currentFlow);
           currentFlow = finishFlowLabel(currentReturnTarget);
-          if (node.kind === 175 /* Constructor */ || node.kind === 174 /* ClassStaticBlockDeclaration */ || isInJSFile(node) && (node.kind === 261 /* FunctionDeclaration */ || node.kind === 217 /* FunctionExpression */)) {
+          if (node.kind === 176 /* Constructor */ || node.kind === 175 /* ClassStaticBlockDeclaration */ || isInJSFile(node) && (node.kind === 262 /* FunctionDeclaration */ || node.kind === 218 /* FunctionExpression */)) {
             node.returnFlowNode = currentFlow;
           }
         }
@@ -141185,7 +124507,7 @@ ${lanes.join("\n")}
         seenThisKeyword = false;
         bindChildren(node);
         Debug.assertNotNode(node, isIdentifier);
-        node.flags = seenThisKeyword ? node.flags | 128 /* ContainsThis */ : node.flags & ~128 /* ContainsThis */;
+        node.flags = seenThisKeyword ? node.flags | 256 /* ContainsThis */ : node.flags & ~256 /* ContainsThis */;
       } else {
         bindChildren(node);
       }
@@ -141194,8 +124516,8 @@ ${lanes.join("\n")}
       blockScopeContainer = savedBlockScopeContainer;
     }
     function bindEachFunctionsFirst(nodes) {
-      bindEach(nodes, (n) => n.kind === 261 /* FunctionDeclaration */ ? bind(n) : void 0);
-      bindEach(nodes, (n) => n.kind !== 261 /* FunctionDeclaration */ ? bind(n) : void 0);
+      bindEach(nodes, (n) => n.kind === 262 /* FunctionDeclaration */ ? bind(n) : void 0);
+      bindEach(nodes, (n) => n.kind !== 262 /* FunctionDeclaration */ ? bind(n) : void 0);
     }
     function bindEach(nodes, bindFunction = bind) {
       if (nodes === void 0) {
@@ -141215,59 +124537,59 @@ ${lanes.join("\n")}
         inAssignmentPattern = saveInAssignmentPattern;
         return;
       }
-      if (node.kind >= 242 /* FirstStatement */ && node.kind <= 258 /* LastStatement */ && !options.allowUnreachableCode) {
+      if (node.kind >= 243 /* FirstStatement */ && node.kind <= 259 /* LastStatement */ && !options.allowUnreachableCode) {
         node.flowNode = currentFlow;
       }
       switch (node.kind) {
-        case 246 /* WhileStatement */:
+        case 247 /* WhileStatement */:
           bindWhileStatement(node);
           break;
-        case 245 /* DoStatement */:
+        case 246 /* DoStatement */:
           bindDoStatement(node);
           break;
-        case 247 /* ForStatement */:
+        case 248 /* ForStatement */:
           bindForStatement(node);
           break;
-        case 248 /* ForInStatement */:
-        case 249 /* ForOfStatement */:
+        case 249 /* ForInStatement */:
+        case 250 /* ForOfStatement */:
           bindForInOrForOfStatement(node);
           break;
-        case 244 /* IfStatement */:
+        case 245 /* IfStatement */:
           bindIfStatement(node);
           break;
-        case 252 /* ReturnStatement */:
-        case 256 /* ThrowStatement */:
+        case 253 /* ReturnStatement */:
+        case 257 /* ThrowStatement */:
           bindReturnOrThrow(node);
           break;
-        case 251 /* BreakStatement */:
-        case 250 /* ContinueStatement */:
+        case 252 /* BreakStatement */:
+        case 251 /* ContinueStatement */:
           bindBreakOrContinueStatement(node);
           break;
-        case 257 /* TryStatement */:
+        case 258 /* TryStatement */:
           bindTryStatement(node);
           break;
-        case 254 /* SwitchStatement */:
+        case 255 /* SwitchStatement */:
           bindSwitchStatement(node);
           break;
-        case 268 /* CaseBlock */:
+        case 269 /* CaseBlock */:
           bindCaseBlock(node);
           break;
-        case 295 /* CaseClause */:
+        case 296 /* CaseClause */:
           bindCaseClause(node);
           break;
-        case 243 /* ExpressionStatement */:
+        case 244 /* ExpressionStatement */:
           bindExpressionStatement(node);
           break;
-        case 255 /* LabeledStatement */:
+        case 256 /* LabeledStatement */:
           bindLabeledStatement(node);
           break;
-        case 223 /* PrefixUnaryExpression */:
+        case 224 /* PrefixUnaryExpression */:
           bindPrefixUnaryExpressionFlow(node);
           break;
-        case 224 /* PostfixUnaryExpression */:
+        case 225 /* PostfixUnaryExpression */:
           bindPostfixUnaryExpressionFlow(node);
           break;
-        case 225 /* BinaryExpression */:
+        case 226 /* BinaryExpression */:
           if (isDestructuringAssignment(node)) {
             inAssignmentPattern = saveInAssignmentPattern;
             bindDestructuringAssignmentFlow(node);
@@ -141275,49 +124597,49 @@ ${lanes.join("\n")}
           }
           bindBinaryExpressionFlow(node);
           break;
-        case 219 /* DeleteExpression */:
+        case 220 /* DeleteExpression */:
           bindDeleteExpressionFlow(node);
           break;
-        case 226 /* ConditionalExpression */:
+        case 227 /* ConditionalExpression */:
           bindConditionalExpressionFlow(node);
           break;
-        case 259 /* VariableDeclaration */:
+        case 260 /* VariableDeclaration */:
           bindVariableDeclarationFlow(node);
           break;
-        case 210 /* PropertyAccessExpression */:
-        case 211 /* ElementAccessExpression */:
+        case 211 /* PropertyAccessExpression */:
+        case 212 /* ElementAccessExpression */:
           bindAccessExpressionFlow(node);
           break;
-        case 212 /* CallExpression */:
+        case 213 /* CallExpression */:
           bindCallExpressionFlow(node);
           break;
-        case 234 /* NonNullExpression */:
+        case 235 /* NonNullExpression */:
           bindNonNullExpressionFlow(node);
           break;
-        case 352 /* JSDocTypedefTag */:
-        case 344 /* JSDocCallbackTag */:
-        case 346 /* JSDocEnumTag */:
+        case 353 /* JSDocTypedefTag */:
+        case 345 /* JSDocCallbackTag */:
+        case 347 /* JSDocEnumTag */:
           bindJSDocTypeAlias(node);
           break;
-        case 311 /* SourceFile */: {
+        case 312 /* SourceFile */: {
           bindEachFunctionsFirst(node.statements);
           bind(node.endOfFileToken);
           break;
         }
-        case 240 /* Block */:
-        case 267 /* ModuleBlock */:
+        case 241 /* Block */:
+        case 268 /* ModuleBlock */:
           bindEachFunctionsFirst(node.statements);
           break;
-        case 207 /* BindingElement */:
+        case 208 /* BindingElement */:
           bindBindingElementFlow(node);
           break;
-        case 168 /* Parameter */:
+        case 169 /* Parameter */:
           bindParameterFlow(node);
           break;
-        case 209 /* ObjectLiteralExpression */:
-        case 208 /* ArrayLiteralExpression */:
-        case 302 /* PropertyAssignment */:
-        case 229 /* SpreadElement */:
+        case 210 /* ObjectLiteralExpression */:
+        case 209 /* ArrayLiteralExpression */:
+        case 303 /* PropertyAssignment */:
+        case 230 /* SpreadElement */:
           inAssignmentPattern = saveInAssignmentPattern;
         default:
           bindEachChild(node);
@@ -141331,19 +124653,19 @@ ${lanes.join("\n")}
         case 80 /* Identifier */:
         case 81 /* PrivateIdentifier */:
         case 110 /* ThisKeyword */:
-        case 210 /* PropertyAccessExpression */:
-        case 211 /* ElementAccessExpression */:
+        case 211 /* PropertyAccessExpression */:
+        case 212 /* ElementAccessExpression */:
           return containsNarrowableReference(expr);
-        case 212 /* CallExpression */:
+        case 213 /* CallExpression */:
           return hasNarrowableArgument(expr);
-        case 216 /* ParenthesizedExpression */:
-        case 234 /* NonNullExpression */:
+        case 217 /* ParenthesizedExpression */:
+        case 235 /* NonNullExpression */:
           return isNarrowingExpression(expr.expression);
-        case 225 /* BinaryExpression */:
+        case 226 /* BinaryExpression */:
           return isNarrowingBinaryExpression(expr);
-        case 223 /* PrefixUnaryExpression */:
+        case 224 /* PrefixUnaryExpression */:
           return expr.operator === 54 /* ExclamationToken */ && isNarrowingExpression(expr.operand);
-        case 220 /* TypeOfExpression */:
+        case 221 /* TypeOfExpression */:
           return isNarrowingExpression(expr.expression);
       }
       return false;
@@ -141362,7 +124684,7 @@ ${lanes.join("\n")}
           }
         }
       }
-      if (expr.expression.kind === 210 /* PropertyAccessExpression */ && containsNarrowableReference(expr.expression.expression)) {
+      if (expr.expression.kind === 211 /* PropertyAccessExpression */ && containsNarrowableReference(expr.expression.expression)) {
         return true;
       }
       return false;
@@ -141381,7 +124703,7 @@ ${lanes.join("\n")}
         case 36 /* ExclamationEqualsToken */:
         case 37 /* EqualsEqualsEqualsToken */:
         case 38 /* ExclamationEqualsEqualsToken */:
-          return isNarrowableOperand(expr.left) || isNarrowableOperand(expr.right) || isNarrowingTypeofOperands(expr.right, expr.left) || isNarrowingTypeofOperands(expr.left, expr.right);
+          return isNarrowableOperand(expr.left) || isNarrowableOperand(expr.right) || isNarrowingTypeofOperands(expr.right, expr.left) || isNarrowingTypeofOperands(expr.left, expr.right) || (isBooleanLiteral(expr.right) && isNarrowingExpression(expr.left) || isBooleanLiteral(expr.left) && isNarrowingExpression(expr.right));
         case 104 /* InstanceOfKeyword */:
           return isNarrowableOperand(expr.left);
         case 103 /* InKeyword */:
@@ -141393,9 +124715,9 @@ ${lanes.join("\n")}
     }
     function isNarrowableOperand(expr) {
       switch (expr.kind) {
-        case 216 /* ParenthesizedExpression */:
+        case 217 /* ParenthesizedExpression */:
           return isNarrowableOperand(expr.expression);
-        case 225 /* BinaryExpression */:
+        case 226 /* BinaryExpression */:
           switch (expr.operatorToken.kind) {
             case 64 /* EqualsToken */:
               return isNarrowableOperand(expr.left);
@@ -141468,21 +124790,21 @@ ${lanes.join("\n")}
     function isStatementCondition(node) {
       const parent3 = node.parent;
       switch (parent3.kind) {
-        case 244 /* IfStatement */:
-        case 246 /* WhileStatement */:
-        case 245 /* DoStatement */:
+        case 245 /* IfStatement */:
+        case 247 /* WhileStatement */:
+        case 246 /* DoStatement */:
           return parent3.expression === node;
-        case 247 /* ForStatement */:
-        case 226 /* ConditionalExpression */:
+        case 248 /* ForStatement */:
+        case 227 /* ConditionalExpression */:
           return parent3.condition === node;
       }
       return false;
     }
     function isLogicalExpression(node) {
       while (true) {
-        if (node.kind === 216 /* ParenthesizedExpression */) {
+        if (node.kind === 217 /* ParenthesizedExpression */) {
           node = node.expression;
-        } else if (node.kind === 223 /* PrefixUnaryExpression */ && node.operator === 54 /* ExclamationToken */) {
+        } else if (node.kind === 224 /* PrefixUnaryExpression */ && node.operator === 54 /* ExclamationToken */) {
           node = node.operand;
         } else {
           return isLogicalOrCoalescingBinaryExpression(node);
@@ -141525,7 +124847,7 @@ ${lanes.join("\n")}
     }
     function setContinueTarget(node, target) {
       let label = activeLabelList;
-      while (label && node.parent.kind === 255 /* LabeledStatement */) {
+      while (label && node.parent.kind === 256 /* LabeledStatement */) {
         label.continueTarget = target;
         label = label.next;
         node = node.parent;
@@ -141576,12 +124898,12 @@ ${lanes.join("\n")}
       bind(node.expression);
       addAntecedent(preLoopLabel, currentFlow);
       currentFlow = preLoopLabel;
-      if (node.kind === 249 /* ForOfStatement */) {
+      if (node.kind === 250 /* ForOfStatement */) {
         bind(node.awaitModifier);
       }
       addAntecedent(postLoopLabel, currentFlow);
       bind(node.initializer);
-      if (node.initializer.kind !== 260 /* VariableDeclarationList */) {
+      if (node.initializer.kind !== 261 /* VariableDeclarationList */) {
         bindAssignmentTargetFlow(node.initializer);
       }
       bindIterativeStatement(node.statement, postLoopLabel, preLoopLabel);
@@ -141603,7 +124925,7 @@ ${lanes.join("\n")}
     }
     function bindReturnOrThrow(node) {
       bind(node.expression);
-      if (node.kind === 252 /* ReturnStatement */) {
+      if (node.kind === 253 /* ReturnStatement */) {
         hasExplicitReturn = true;
         if (currentReturnTarget) {
           addAntecedent(currentReturnTarget, currentFlow);
@@ -141620,7 +124942,7 @@ ${lanes.join("\n")}
       return void 0;
     }
     function bindBreakOrContinueFlow(node, breakTarget, continueTarget) {
-      const flowLabel = node.kind === 251 /* BreakStatement */ ? breakTarget : continueTarget;
+      const flowLabel = node.kind === 252 /* BreakStatement */ ? breakTarget : continueTarget;
       if (flowLabel) {
         addAntecedent(flowLabel, currentFlow);
         currentFlow = unreachableFlow;
@@ -141690,7 +125012,7 @@ ${lanes.join("\n")}
       preSwitchCaseFlow = currentFlow;
       bind(node.caseBlock);
       addAntecedent(postSwitchLabel, currentFlow);
-      const hasDefault = forEach(node.caseBlock.clauses, (c) => c.kind === 296 /* DefaultClause */);
+      const hasDefault = forEach(node.caseBlock.clauses, (c) => c.kind === 297 /* DefaultClause */);
       node.possiblyExhaustive = !hasDefault && !postSwitchLabel.antecedents;
       if (!hasDefault) {
         addAntecedent(postSwitchLabel, createFlowSwitchClause(preSwitchCaseFlow, node, 0, 0));
@@ -141701,7 +125023,7 @@ ${lanes.join("\n")}
     }
     function bindCaseBlock(node) {
       const clauses = node.clauses;
-      const isNarrowingSwitch = isNarrowingExpression(node.parent.expression);
+      const isNarrowingSwitch = node.parent.expression.kind === 112 /* TrueKeyword */ || isNarrowingExpression(node.parent.expression);
       let fallthroughFlow = unreachableFlow;
       for (let i = 0; i < clauses.length; i++) {
         const clauseStart = i;
@@ -141733,7 +125055,7 @@ ${lanes.join("\n")}
       maybeBindExpressionFlowIfCall(node.expression);
     }
     function maybeBindExpressionFlowIfCall(node) {
-      if (node.kind === 212 /* CallExpression */) {
+      if (node.kind === 213 /* CallExpression */) {
         const call = node;
         if (call.expression.kind !== 108 /* SuperKeyword */ && isDottedName(call.expression)) {
           currentFlow = createFlowCall(currentFlow, call);
@@ -141759,7 +125081,7 @@ ${lanes.join("\n")}
       currentFlow = finishFlowLabel(postStatementLabel);
     }
     function bindDestructuringTargetFlow(node) {
-      if (node.kind === 225 /* BinaryExpression */ && node.operatorToken.kind === 64 /* EqualsToken */) {
+      if (node.kind === 226 /* BinaryExpression */ && node.operatorToken.kind === 64 /* EqualsToken */) {
         bindAssignmentTargetFlow(node.left);
       } else {
         bindAssignmentTargetFlow(node);
@@ -141768,21 +125090,21 @@ ${lanes.join("\n")}
     function bindAssignmentTargetFlow(node) {
       if (isNarrowableReference(node)) {
         currentFlow = createFlowMutation(16 /* Assignment */, currentFlow, node);
-      } else if (node.kind === 208 /* ArrayLiteralExpression */) {
+      } else if (node.kind === 209 /* ArrayLiteralExpression */) {
         for (const e of node.elements) {
-          if (e.kind === 229 /* SpreadElement */) {
+          if (e.kind === 230 /* SpreadElement */) {
             bindAssignmentTargetFlow(e.expression);
           } else {
             bindDestructuringTargetFlow(e);
           }
         }
-      } else if (node.kind === 209 /* ObjectLiteralExpression */) {
+      } else if (node.kind === 210 /* ObjectLiteralExpression */) {
         for (const p of node.properties) {
-          if (p.kind === 302 /* PropertyAssignment */) {
+          if (p.kind === 303 /* PropertyAssignment */) {
             bindDestructuringTargetFlow(p.initializer);
-          } else if (p.kind === 303 /* ShorthandPropertyAssignment */) {
+          } else if (p.kind === 304 /* ShorthandPropertyAssignment */) {
             bindAssignmentTargetFlow(p.name);
-          } else if (p.kind === 304 /* SpreadAssignment */) {
+          } else if (p.kind === 305 /* SpreadAssignment */) {
             bindAssignmentTargetFlow(p.expression);
           }
         }
@@ -141913,7 +125235,7 @@ ${lanes.join("\n")}
           const operator = node.operatorToken.kind;
           if (isAssignmentOperator(operator) && !isAssignmentTarget(node)) {
             bindAssignmentTargetFlow(node.left);
-            if (operator === 64 /* EqualsToken */ && node.left.kind === 211 /* ElementAccessExpression */) {
+            if (operator === 64 /* EqualsToken */ && node.left.kind === 212 /* ElementAccessExpression */) {
               const elementAccess = node.left;
               if (isNarrowableOperand(elementAccess.expression)) {
                 currentFlow = createFlowMutation(256 /* ArrayMutation */, currentFlow, node);
@@ -141941,7 +125263,7 @@ ${lanes.join("\n")}
     }
     function bindDeleteExpressionFlow(node) {
       bindEachChild(node);
-      if (node.expression.kind === 210 /* PropertyAccessExpression */) {
+      if (node.expression.kind === 211 /* PropertyAccessExpression */) {
         bindAssignmentTargetFlow(node.expression);
       }
     }
@@ -142006,7 +125328,7 @@ ${lanes.join("\n")}
     }
     function bindJSDocTypeAlias(node) {
       bind(node.tagName);
-      if (node.kind !== 346 /* JSDocEnumTag */ && node.fullName) {
+      if (node.kind !== 347 /* JSDocEnumTag */ && node.fullName) {
         setParent(node.fullName, node);
         setParentRecursive(
           node.fullName,
@@ -142021,7 +125343,7 @@ ${lanes.join("\n")}
     function bindJSDocClassTag(node) {
       bindEachChild(node);
       const host = getHostSignatureFromJSDoc(node);
-      if (host && host.kind !== 173 /* MethodDeclaration */) {
+      if (host && host.kind !== 174 /* MethodDeclaration */) {
         addDeclarationToSymbol(host.symbol, host, 32 /* Class */);
       }
     }
@@ -142034,15 +125356,15 @@ ${lanes.join("\n")}
     }
     function bindOptionalChainRest(node) {
       switch (node.kind) {
-        case 210 /* PropertyAccessExpression */:
+        case 211 /* PropertyAccessExpression */:
           bind(node.questionDotToken);
           bind(node.name);
           break;
-        case 211 /* ElementAccessExpression */:
+        case 212 /* ElementAccessExpression */:
           bind(node.questionDotToken);
           bind(node.argumentExpression);
           break;
-        case 212 /* CallExpression */:
+        case 213 /* CallExpression */:
           bind(node.questionDotToken);
           bindEach(node.typeArguments);
           bindEach(node.arguments);
@@ -142089,7 +125411,7 @@ ${lanes.join("\n")}
         bindOptionalChainFlow(node);
       } else {
         const expr = skipParentheses(node.expression);
-        if (expr.kind === 217 /* FunctionExpression */ || expr.kind === 218 /* ArrowFunction */) {
+        if (expr.kind === 218 /* FunctionExpression */ || expr.kind === 219 /* ArrowFunction */) {
           bindEach(node.typeArguments);
           bindEach(node.arguments);
           bind(node.expression);
@@ -142100,7 +125422,7 @@ ${lanes.join("\n")}
           }
         }
       }
-      if (node.expression.kind === 210 /* PropertyAccessExpression */) {
+      if (node.expression.kind === 211 /* PropertyAccessExpression */) {
         const propertyAccess = node.expression;
         if (isIdentifier(propertyAccess.name) && isNarrowableOperand(propertyAccess.expression) && isPushOrUnshiftIdentifier(propertyAccess.name)) {
           currentFlow = createFlowMutation(256 /* ArrayMutation */, currentFlow, node);
@@ -142115,39 +125437,39 @@ ${lanes.join("\n")}
     }
     function declareSymbolAndAddToSymbolTable(node, symbolFlags, symbolExcludes) {
       switch (container.kind) {
-        case 266 /* ModuleDeclaration */:
+        case 267 /* ModuleDeclaration */:
           return declareModuleMember(node, symbolFlags, symbolExcludes);
-        case 311 /* SourceFile */:
+        case 312 /* SourceFile */:
           return declareSourceFileMember(node, symbolFlags, symbolExcludes);
-        case 230 /* ClassExpression */:
-        case 262 /* ClassDeclaration */:
+        case 231 /* ClassExpression */:
+        case 263 /* ClassDeclaration */:
           return declareClassMember(node, symbolFlags, symbolExcludes);
-        case 265 /* EnumDeclaration */:
+        case 266 /* EnumDeclaration */:
           return declareSymbol(container.symbol.exports, container.symbol, node, symbolFlags, symbolExcludes);
-        case 186 /* TypeLiteral */:
-        case 328 /* JSDocTypeLiteral */:
-        case 209 /* ObjectLiteralExpression */:
-        case 263 /* InterfaceDeclaration */:
-        case 291 /* JsxAttributes */:
+        case 187 /* TypeLiteral */:
+        case 329 /* JSDocTypeLiteral */:
+        case 210 /* ObjectLiteralExpression */:
+        case 264 /* InterfaceDeclaration */:
+        case 292 /* JsxAttributes */:
           return declareSymbol(container.symbol.members, container.symbol, node, symbolFlags, symbolExcludes);
-        case 183 /* FunctionType */:
-        case 184 /* ConstructorType */:
-        case 178 /* CallSignature */:
-        case 179 /* ConstructSignature */:
-        case 329 /* JSDocSignature */:
-        case 180 /* IndexSignature */:
-        case 173 /* MethodDeclaration */:
-        case 172 /* MethodSignature */:
-        case 175 /* Constructor */:
-        case 176 /* GetAccessor */:
-        case 177 /* SetAccessor */:
-        case 261 /* FunctionDeclaration */:
-        case 217 /* FunctionExpression */:
-        case 218 /* ArrowFunction */:
-        case 323 /* JSDocFunctionType */:
-        case 174 /* ClassStaticBlockDeclaration */:
-        case 264 /* TypeAliasDeclaration */:
-        case 199 /* MappedType */:
+        case 184 /* FunctionType */:
+        case 185 /* ConstructorType */:
+        case 179 /* CallSignature */:
+        case 180 /* ConstructSignature */:
+        case 330 /* JSDocSignature */:
+        case 181 /* IndexSignature */:
+        case 174 /* MethodDeclaration */:
+        case 173 /* MethodSignature */:
+        case 176 /* Constructor */:
+        case 177 /* GetAccessor */:
+        case 178 /* SetAccessor */:
+        case 262 /* FunctionDeclaration */:
+        case 218 /* FunctionExpression */:
+        case 219 /* ArrowFunction */:
+        case 324 /* JSDocFunctionType */:
+        case 175 /* ClassStaticBlockDeclaration */:
+        case 265 /* TypeAliasDeclaration */:
+        case 200 /* MappedType */:
           if (container.locals)
             Debug.assertNode(container, canHaveLocals);
           return declareSymbol(
@@ -142178,16 +125500,16 @@ ${lanes.join("\n")}
       return !!body && body.statements.some((s) => isExportDeclaration(s) || isExportAssignment(s));
     }
     function setExportContextFlag(node) {
-      if (node.flags & 16777216 /* Ambient */ && !hasExportDeclarations(node)) {
-        node.flags |= 64 /* ExportContext */;
+      if (node.flags & 33554432 /* Ambient */ && !hasExportDeclarations(node)) {
+        node.flags |= 128 /* ExportContext */;
       } else {
-        node.flags &= ~64 /* ExportContext */;
+        node.flags &= ~128 /* ExportContext */;
       }
     }
     function bindModuleDeclaration(node) {
       setExportContextFlag(node);
       if (isAmbientModule(node)) {
-        if (hasSyntacticModifier(node, 1 /* Export */)) {
+        if (hasSyntacticModifier(node, 32 /* Export */)) {
           errorOnFirstToken(node, Diagnostics.export_modifier_cannot_be_applied_to_ambient_modules_and_module_augmentations_since_they_are_always_visible);
         }
         if (isModuleAugmentationExternal(node)) {
@@ -142249,10 +125571,10 @@ ${lanes.join("\n")}
     }
     function bindBlockScopedDeclaration(node, symbolFlags, symbolExcludes) {
       switch (blockScopeContainer.kind) {
-        case 266 /* ModuleDeclaration */:
+        case 267 /* ModuleDeclaration */:
           declareModuleMember(node, symbolFlags, symbolExcludes);
           break;
-        case 311 /* SourceFile */:
+        case 312 /* SourceFile */:
           if (isExternalOrCommonJsModule(container)) {
             declareModuleMember(node, symbolFlags, symbolExcludes);
             break;
@@ -142284,7 +125606,7 @@ ${lanes.join("\n")}
       const saveCurrentFlow = currentFlow;
       for (const typeAlias of delayedTypeAliases) {
         const host = typeAlias.parent.parent;
-        container = findAncestor(host.parent, (n) => !!(getContainerFlags(n) & 1 /* IsContainer */)) || file;
+        container = getEnclosingContainer(host) || file;
         blockScopeContainer = getEnclosingBlockScopeContainer(host) || file;
         currentFlow = initFlowNode({ flags: 2 /* Start */ });
         parent2 = typeAlias;
@@ -142342,37 +125664,21 @@ ${lanes.join("\n")}
       currentFlow = saveCurrentFlow;
     }
     function checkContextualIdentifier(node) {
-      if (!file.parseDiagnostics.length && !(node.flags & 16777216 /* Ambient */) && !(node.flags & 8388608 /* JSDoc */) && !isIdentifierName(node)) {
+      if (!file.parseDiagnostics.length && !(node.flags & 33554432 /* Ambient */) && !(node.flags & 16777216 /* JSDoc */) && !isIdentifierName(node)) {
         const originalKeywordKind = identifierToKeywordKind(node);
         if (originalKeywordKind === void 0) {
           return;
         }
         if (inStrictMode && originalKeywordKind >= 119 /* FirstFutureReservedWord */ && originalKeywordKind <= 127 /* LastFutureReservedWord */) {
-          file.bindDiagnostics.push(createDiagnosticForNode2(
-            node,
-            getStrictModeIdentifierMessage(node),
-            declarationNameToString(node)
-          ));
+          file.bindDiagnostics.push(createDiagnosticForNode2(node, getStrictModeIdentifierMessage(node), declarationNameToString(node)));
         } else if (originalKeywordKind === 135 /* AwaitKeyword */) {
           if (isExternalModule(file) && isInTopLevelContext(node)) {
-            file.bindDiagnostics.push(createDiagnosticForNode2(
-              node,
-              Diagnostics.Identifier_expected_0_is_a_reserved_word_at_the_top_level_of_a_module,
-              declarationNameToString(node)
-            ));
-          } else if (node.flags & 32768 /* AwaitContext */) {
-            file.bindDiagnostics.push(createDiagnosticForNode2(
-              node,
-              Diagnostics.Identifier_expected_0_is_a_reserved_word_that_cannot_be_used_here,
-              declarationNameToString(node)
-            ));
+            file.bindDiagnostics.push(createDiagnosticForNode2(node, Diagnostics.Identifier_expected_0_is_a_reserved_word_at_the_top_level_of_a_module, declarationNameToString(node)));
+          } else if (node.flags & 65536 /* AwaitContext */) {
+            file.bindDiagnostics.push(createDiagnosticForNode2(node, Diagnostics.Identifier_expected_0_is_a_reserved_word_that_cannot_be_used_here, declarationNameToString(node)));
           }
-        } else if (originalKeywordKind === 127 /* YieldKeyword */ && node.flags & 8192 /* YieldContext */) {
-          file.bindDiagnostics.push(createDiagnosticForNode2(
-            node,
-            Diagnostics.Identifier_expected_0_is_a_reserved_word_that_cannot_be_used_here,
-            declarationNameToString(node)
-          ));
+        } else if (originalKeywordKind === 127 /* YieldKeyword */ && node.flags & 16384 /* YieldContext */) {
+          file.bindDiagnostics.push(createDiagnosticForNode2(node, Diagnostics.Identifier_expected_0_is_a_reserved_word_that_cannot_be_used_here, declarationNameToString(node)));
         }
       }
     }
@@ -142388,11 +125694,7 @@ ${lanes.join("\n")}
     function checkPrivateIdentifier(node) {
       if (node.escapedText === "#constructor") {
         if (!file.parseDiagnostics.length) {
-          file.bindDiagnostics.push(createDiagnosticForNode2(
-            node,
-            Diagnostics.constructor_is_a_reserved_word,
-            declarationNameToString(node)
-          ));
+          file.bindDiagnostics.push(createDiagnosticForNode2(node, Diagnostics.constructor_is_a_reserved_word, declarationNameToString(node)));
         }
       }
     }
@@ -142420,13 +125722,7 @@ ${lanes.join("\n")}
         const identifier = name;
         if (isEvalOrArgumentsIdentifier(identifier)) {
           const span = getErrorSpanForNode(file, name);
-          file.bindDiagnostics.push(createFileDiagnostic(
-            file,
-            span.start,
-            span.length,
-            getStrictModeEvalOrArgumentsMessage(contextNode),
-            idText(identifier)
-          ));
+          file.bindDiagnostics.push(createFileDiagnostic(file, span.start, span.length, getStrictModeEvalOrArgumentsMessage(contextNode), idText(identifier)));
         }
       }
     }
@@ -142455,14 +125751,9 @@ ${lanes.join("\n")}
     }
     function checkStrictModeFunctionDeclaration(node) {
       if (languageVersion < 2 /* ES2015 */) {
-        if (blockScopeContainer.kind !== 311 /* SourceFile */ && blockScopeContainer.kind !== 266 /* ModuleDeclaration */ && !isFunctionLikeOrClassStaticBlockDeclaration(blockScopeContainer)) {
+        if (blockScopeContainer.kind !== 312 /* SourceFile */ && blockScopeContainer.kind !== 267 /* ModuleDeclaration */ && !isFunctionLikeOrClassStaticBlockDeclaration(blockScopeContainer)) {
           const errorSpan = getErrorSpanForNode(file, node);
-          file.bindDiagnostics.push(createFileDiagnostic(
-            file,
-            errorSpan.start,
-            errorSpan.length,
-            getStrictModeBlockScopeFunctionDeclarationMessage(node)
-          ));
+          file.bindDiagnostics.push(createFileDiagnostic(file, errorSpan.start, errorSpan.length, getStrictModeBlockScopeFunctionDeclarationMessage(node)));
         }
       }
     }
@@ -142517,7 +125808,7 @@ ${lanes.join("\n")}
         node.tracingPath = file.path;
       const saveInStrictMode = inStrictMode;
       bindWorker(node);
-      if (node.kind > 164 /* LastToken */) {
+      if (node.kind > 165 /* LastToken */) {
         const saveParent = parent2;
         parent2 = node;
         const containerFlags = getContainerFlags(node);
@@ -142574,7 +125865,7 @@ ${lanes.join("\n")}
     function bindWorker(node) {
       switch (node.kind) {
         case 80 /* Identifier */:
-          if (node.flags & 2048 /* IdentifierIsInJSDocNamespace */) {
+          if (node.flags & 4096 /* IdentifierIsInJSDocNamespace */) {
             let parentNode = node.parent;
             while (parentNode && !isJSDocTypeAlias(parentNode)) {
               parentNode = parentNode.parent;
@@ -142583,23 +125874,23 @@ ${lanes.join("\n")}
             break;
           }
         case 110 /* ThisKeyword */:
-          if (currentFlow && (isExpression(node) || parent2.kind === 303 /* ShorthandPropertyAssignment */)) {
+          if (currentFlow && (isExpression(node) || parent2.kind === 304 /* ShorthandPropertyAssignment */)) {
             node.flowNode = currentFlow;
           }
           return checkContextualIdentifier(node);
-        case 165 /* QualifiedName */:
+        case 166 /* QualifiedName */:
           if (currentFlow && isPartOfTypeQuery(node)) {
             node.flowNode = currentFlow;
           }
           break;
-        case 235 /* MetaProperty */:
+        case 236 /* MetaProperty */:
         case 108 /* SuperKeyword */:
           node.flowNode = currentFlow;
           break;
         case 81 /* PrivateIdentifier */:
           return checkPrivateIdentifier(node);
-        case 210 /* PropertyAccessExpression */:
-        case 211 /* ElementAccessExpression */:
+        case 211 /* PropertyAccessExpression */:
+        case 212 /* ElementAccessExpression */:
           const expr = node;
           if (currentFlow && isNarrowableReference(expr)) {
             expr.flowNode = currentFlow;
@@ -142618,7 +125909,7 @@ ${lanes.join("\n")}
             );
           }
           break;
-        case 225 /* BinaryExpression */:
+        case 226 /* BinaryExpression */:
           const specialKind = getAssignmentDeclarationKind(node);
           switch (specialKind) {
             case 1 /* ExportsProperty */:
@@ -142653,81 +125944,77 @@ ${lanes.join("\n")}
               Debug.fail("Unknown binary expression special property assignment kind");
           }
           return checkStrictModeBinaryExpression(node);
-        case 298 /* CatchClause */:
+        case 299 /* CatchClause */:
           return checkStrictModeCatchClause(node);
-        case 219 /* DeleteExpression */:
+        case 220 /* DeleteExpression */:
           return checkStrictModeDeleteExpression(node);
-        case 224 /* PostfixUnaryExpression */:
+        case 225 /* PostfixUnaryExpression */:
           return checkStrictModePostfixUnaryExpression(node);
-        case 223 /* PrefixUnaryExpression */:
+        case 224 /* PrefixUnaryExpression */:
           return checkStrictModePrefixUnaryExpression(node);
-        case 253 /* WithStatement */:
+        case 254 /* WithStatement */:
           return checkStrictModeWithStatement(node);
-        case 255 /* LabeledStatement */:
+        case 256 /* LabeledStatement */:
           return checkStrictModeLabeledStatement(node);
-        case 196 /* ThisType */:
+        case 197 /* ThisType */:
           seenThisKeyword = true;
           return;
-        case 181 /* TypePredicate */:
+        case 182 /* TypePredicate */:
           break;
-        case 167 /* TypeParameter */:
+        case 168 /* TypeParameter */:
           return bindTypeParameter(node);
-        case 168 /* Parameter */:
+        case 169 /* Parameter */:
           return bindParameter(node);
-        case 259 /* VariableDeclaration */:
+        case 260 /* VariableDeclaration */:
           return bindVariableDeclarationOrBindingElement(node);
-        case 207 /* BindingElement */:
+        case 208 /* BindingElement */:
           node.flowNode = currentFlow;
           return bindVariableDeclarationOrBindingElement(node);
-        case 171 /* PropertyDeclaration */:
-        case 170 /* PropertySignature */:
+        case 172 /* PropertyDeclaration */:
+        case 171 /* PropertySignature */:
           return bindPropertyWorker(node);
-        case 302 /* PropertyAssignment */:
-        case 303 /* ShorthandPropertyAssignment */:
+        case 303 /* PropertyAssignment */:
+        case 304 /* ShorthandPropertyAssignment */:
           return bindPropertyOrMethodOrAccessor(node, 4 /* Property */, 0 /* PropertyExcludes */);
-        case 305 /* EnumMember */:
+        case 306 /* EnumMember */:
           return bindPropertyOrMethodOrAccessor(node, 8 /* EnumMember */, 900095 /* EnumMemberExcludes */);
-        case 178 /* CallSignature */:
-        case 179 /* ConstructSignature */:
-        case 180 /* IndexSignature */:
+        case 179 /* CallSignature */:
+        case 180 /* ConstructSignature */:
+        case 181 /* IndexSignature */:
           return declareSymbolAndAddToSymbolTable(node, 131072 /* Signature */, 0 /* None */);
-        case 173 /* MethodDeclaration */:
-        case 172 /* MethodSignature */:
-          return bindPropertyOrMethodOrAccessor(
-            node,
-            8192 /* Method */ | (node.questionToken ? 16777216 /* Optional */ : 0 /* None */),
-            isObjectLiteralMethod(node) ? 0 /* PropertyExcludes */ : 103359 /* MethodExcludes */
-          );
-        case 261 /* FunctionDeclaration */:
+        case 174 /* MethodDeclaration */:
+        case 173 /* MethodSignature */:
+          return bindPropertyOrMethodOrAccessor(node, 8192 /* Method */ | (node.questionToken ? 16777216 /* Optional */ : 0 /* None */), isObjectLiteralMethod(node) ? 0 /* PropertyExcludes */ : 103359 /* MethodExcludes */);
+        case 262 /* FunctionDeclaration */:
           return bindFunctionDeclaration(node);
-        case 175 /* Constructor */:
+        case 176 /* Constructor */:
           return declareSymbolAndAddToSymbolTable(
             node,
             16384 /* Constructor */,
             /*symbolExcludes:*/
             0 /* None */
           );
-        case 176 /* GetAccessor */:
+        case 177 /* GetAccessor */:
           return bindPropertyOrMethodOrAccessor(node, 32768 /* GetAccessor */, 46015 /* GetAccessorExcludes */);
-        case 177 /* SetAccessor */:
+        case 178 /* SetAccessor */:
           return bindPropertyOrMethodOrAccessor(node, 65536 /* SetAccessor */, 78783 /* SetAccessorExcludes */);
-        case 183 /* FunctionType */:
-        case 323 /* JSDocFunctionType */:
-        case 329 /* JSDocSignature */:
-        case 184 /* ConstructorType */:
+        case 184 /* FunctionType */:
+        case 324 /* JSDocFunctionType */:
+        case 330 /* JSDocSignature */:
+        case 185 /* ConstructorType */:
           return bindFunctionOrConstructorType(node);
-        case 186 /* TypeLiteral */:
-        case 328 /* JSDocTypeLiteral */:
-        case 199 /* MappedType */:
+        case 187 /* TypeLiteral */:
+        case 329 /* JSDocTypeLiteral */:
+        case 200 /* MappedType */:
           return bindAnonymousTypeWorker(node);
-        case 338 /* JSDocClassTag */:
+        case 339 /* JSDocClassTag */:
           return bindJSDocClassTag(node);
-        case 209 /* ObjectLiteralExpression */:
+        case 210 /* ObjectLiteralExpression */:
           return bindObjectLiteralExpression(node);
-        case 217 /* FunctionExpression */:
-        case 218 /* ArrowFunction */:
+        case 218 /* FunctionExpression */:
+        case 219 /* ArrowFunction */:
           return bindFunctionExpression(node);
-        case 212 /* CallExpression */:
+        case 213 /* CallExpression */:
           const assignmentKind = getAssignmentDeclarationKind(node);
           switch (assignmentKind) {
             case 7 /* ObjectDefinePropertyValue */:
@@ -142745,60 +126032,60 @@ ${lanes.join("\n")}
             bindCallExpression(node);
           }
           break;
-        case 230 /* ClassExpression */:
-        case 262 /* ClassDeclaration */:
+        case 231 /* ClassExpression */:
+        case 263 /* ClassDeclaration */:
           inStrictMode = true;
           return bindClassLikeDeclaration(node);
-        case 263 /* InterfaceDeclaration */:
+        case 264 /* InterfaceDeclaration */:
           return bindBlockScopedDeclaration(node, 64 /* Interface */, 788872 /* InterfaceExcludes */);
-        case 264 /* TypeAliasDeclaration */:
+        case 265 /* TypeAliasDeclaration */:
           return bindBlockScopedDeclaration(node, 524288 /* TypeAlias */, 788968 /* TypeAliasExcludes */);
-        case 265 /* EnumDeclaration */:
+        case 266 /* EnumDeclaration */:
           return bindEnumDeclaration(node);
-        case 266 /* ModuleDeclaration */:
+        case 267 /* ModuleDeclaration */:
           return bindModuleDeclaration(node);
-        case 291 /* JsxAttributes */:
+        case 292 /* JsxAttributes */:
           return bindJsxAttributes(node);
-        case 290 /* JsxAttribute */:
+        case 291 /* JsxAttribute */:
           return bindJsxAttribute(node, 4 /* Property */, 0 /* PropertyExcludes */);
-        case 270 /* ImportEqualsDeclaration */:
-        case 273 /* NamespaceImport */:
-        case 275 /* ImportSpecifier */:
-        case 280 /* ExportSpecifier */:
+        case 271 /* ImportEqualsDeclaration */:
+        case 274 /* NamespaceImport */:
+        case 276 /* ImportSpecifier */:
+        case 281 /* ExportSpecifier */:
           return declareSymbolAndAddToSymbolTable(node, 2097152 /* Alias */, 2097152 /* AliasExcludes */);
-        case 269 /* NamespaceExportDeclaration */:
+        case 270 /* NamespaceExportDeclaration */:
           return bindNamespaceExportDeclaration(node);
-        case 272 /* ImportClause */:
+        case 273 /* ImportClause */:
           return bindImportClause(node);
-        case 277 /* ExportDeclaration */:
+        case 278 /* ExportDeclaration */:
           return bindExportDeclaration(node);
-        case 276 /* ExportAssignment */:
+        case 277 /* ExportAssignment */:
           return bindExportAssignment(node);
-        case 311 /* SourceFile */:
+        case 312 /* SourceFile */:
           updateStrictModeStatementList(node.statements);
           return bindSourceFileIfExternalModule();
-        case 240 /* Block */:
+        case 241 /* Block */:
           if (!isFunctionLikeOrClassStaticBlockDeclaration(node.parent)) {
             return;
           }
-        case 267 /* ModuleBlock */:
+        case 268 /* ModuleBlock */:
           return updateStrictModeStatementList(node.statements);
-        case 347 /* JSDocParameterTag */:
-          if (node.parent.kind === 329 /* JSDocSignature */) {
+        case 348 /* JSDocParameterTag */:
+          if (node.parent.kind === 330 /* JSDocSignature */) {
             return bindParameter(node);
           }
-          if (node.parent.kind !== 328 /* JSDocTypeLiteral */) {
+          if (node.parent.kind !== 329 /* JSDocTypeLiteral */) {
             break;
           }
-        case 354 /* JSDocPropertyTag */:
+        case 355 /* JSDocPropertyTag */:
           const propTag = node;
-          const flags = propTag.isBracketed || propTag.typeExpression && propTag.typeExpression.type.kind === 322 /* JSDocOptionalType */ ? 4 /* Property */ | 16777216 /* Optional */ : 4 /* Property */;
+          const flags = propTag.isBracketed || propTag.typeExpression && propTag.typeExpression.type.kind === 323 /* JSDocOptionalType */ ? 4 /* Property */ | 16777216 /* Optional */ : 4 /* Property */;
           return declareSymbolAndAddToSymbolTable(propTag, flags, 0 /* PropertyExcludes */);
-        case 352 /* JSDocTypedefTag */:
-        case 344 /* JSDocCallbackTag */:
-        case 346 /* JSDocEnumTag */:
+        case 353 /* JSDocTypedefTag */:
+        case 345 /* JSDocCallbackTag */:
+        case 347 /* JSDocEnumTag */:
           return (delayedTypeAliases || (delayedTypeAliases = [])).push(node);
-        case 345 /* JSDocOverloadTag */:
+        case 346 /* JSDocOverloadTag */:
           return bind(node.typeExpression);
       }
     }
@@ -142950,8 +126237,8 @@ ${lanes.join("\n")}
         false
       );
       switch (thisContainer.kind) {
-        case 261 /* FunctionDeclaration */:
-        case 217 /* FunctionExpression */:
+        case 262 /* FunctionDeclaration */:
+        case 218 /* FunctionExpression */:
           let constructorSymbol = thisContainer.symbol;
           if (isBinaryExpression(thisContainer.parent) && thisContainer.parent.operatorToken.kind === 64 /* EqualsToken */) {
             const l = thisContainer.parent.left;
@@ -142969,12 +126256,12 @@ ${lanes.join("\n")}
             addDeclarationToSymbol(constructorSymbol, constructorSymbol.valueDeclaration, 32 /* Class */);
           }
           break;
-        case 175 /* Constructor */:
-        case 171 /* PropertyDeclaration */:
-        case 173 /* MethodDeclaration */:
-        case 176 /* GetAccessor */:
-        case 177 /* SetAccessor */:
-        case 174 /* ClassStaticBlockDeclaration */:
+        case 176 /* Constructor */:
+        case 172 /* PropertyDeclaration */:
+        case 174 /* MethodDeclaration */:
+        case 177 /* GetAccessor */:
+        case 178 /* SetAccessor */:
+        case 175 /* ClassStaticBlockDeclaration */:
           const containingClass = thisContainer.parent;
           const symbolTable = isStatic(thisContainer) ? containingClass.symbol.exports : containingClass.symbol.members;
           if (hasDynamicName(node)) {
@@ -142991,7 +126278,7 @@ ${lanes.join("\n")}
             );
           }
           break;
-        case 311 /* SourceFile */:
+        case 312 /* SourceFile */:
           if (hasDynamicName(node)) {
             break;
           } else if (thisContainer.commonJsModuleIndicator) {
@@ -143000,7 +126287,7 @@ ${lanes.join("\n")}
             declareSymbolAndAddToSymbolTable(node, 1 /* FunctionScopedVariable */, 111550 /* FunctionScopedVariableExcludes */);
           }
           break;
-        case 266 /* ModuleDeclaration */:
+        case 267 /* ModuleDeclaration */:
           break;
         default:
           Debug.failBadSyntaxKind(thisContainer);
@@ -143028,7 +126315,7 @@ ${lanes.join("\n")}
     function bindSpecialPropertyDeclaration(node) {
       if (node.expression.kind === 110 /* ThisKeyword */) {
         bindThisPropertyAssignment(node);
-      } else if (isBindableStaticAccessExpression(node) && node.parent.parent.kind === 311 /* SourceFile */) {
+      } else if (isBindableStaticAccessExpression(node) && node.parent.parent.kind === 312 /* SourceFile */) {
         if (isPrototypeAccess(node.expression)) {
           bindPrototypePropertyAssignment(node, node.parent);
         } else {
@@ -143077,7 +126364,7 @@ ${lanes.join("\n")}
     }
     function bindObjectDefinePropertyAssignment(node) {
       let namespaceSymbol = lookupSymbolForPropertyAccess(node.arguments[0]);
-      const isToplevel = node.parent.parent.kind === 311 /* SourceFile */;
+      const isToplevel = node.parent.parent.kind === 312 /* SourceFile */;
       namespaceSymbol = bindPotentiallyMissingNamespaces(
         namespaceSymbol,
         node.arguments[0],
@@ -143191,7 +126478,7 @@ ${lanes.join("\n")}
       declareSymbol(symbolTable, namespaceSymbol, declaration, includes | 67108864 /* Assignment */, excludes & ~67108864 /* Assignment */);
     }
     function isTopLevelNamespaceAssignment(propertyAccess) {
-      return isBinaryExpression(propertyAccess.parent) ? getParentOfBinaryExpression(propertyAccess.parent).parent.kind === 311 /* SourceFile */ : propertyAccess.parent.parent.kind === 311 /* SourceFile */;
+      return isBinaryExpression(propertyAccess.parent) ? getParentOfBinaryExpression(propertyAccess.parent).parent.kind === 312 /* SourceFile */ : propertyAccess.parent.parent.kind === 312 /* SourceFile */;
     }
     function bindPropertyAssignment(name, propertyAccess, isPrototypeProperty, containerIsClass) {
       let namespaceSymbol = lookupSymbolForPropertyAccess(name, container) || lookupSymbolForPropertyAccess(name, blockScopeContainer);
@@ -143253,7 +126540,7 @@ ${lanes.join("\n")}
       }
     }
     function bindClassLikeDeclaration(node) {
-      if (node.kind === 262 /* ClassDeclaration */) {
+      if (node.kind === 263 /* ClassDeclaration */) {
         bindBlockScopedDeclaration(node, 32 /* Class */, 899503 /* ClassExcludes */);
       } else {
         const bindingName = node.name ? node.name.escapedText : "__class" /* Class */;
@@ -143282,8 +126569,8 @@ ${lanes.join("\n")}
         checkStrictModeEvalOrArguments(node, node.name);
       }
       if (!isBindingPattern(node.name)) {
-        const possibleVariableDecl = node.kind === 259 /* VariableDeclaration */ ? node : node.parent.parent;
-        if (isInJSFile(node) && shouldResolveJsRequire(options) && isVariableDeclarationInitializedToBareOrAccessedRequire(possibleVariableDecl) && !getJSDocTypeTag(node) && !(getCombinedModifierFlags(node) & 1 /* Export */)) {
+        const possibleVariableDecl = node.kind === 260 /* VariableDeclaration */ ? node : node.parent.parent;
+        if (isInJSFile(node) && shouldResolveJsRequire(options) && isVariableDeclarationInitializedToBareOrAccessedRequire(possibleVariableDecl) && !getJSDocTypeTag(node) && !(getCombinedModifierFlags(node) & 32 /* Export */)) {
           declareSymbolAndAddToSymbolTable(node, 2097152 /* Alias */, 2097152 /* AliasExcludes */);
         } else if (isBlockOrCatchScoped(node)) {
           bindBlockScopedDeclaration(node, 2 /* BlockScopedVariable */, 111551 /* BlockScopedVariableExcludes */);
@@ -143295,10 +126582,10 @@ ${lanes.join("\n")}
       }
     }
     function bindParameter(node) {
-      if (node.kind === 347 /* JSDocParameterTag */ && container.kind !== 329 /* JSDocSignature */) {
+      if (node.kind === 348 /* JSDocParameterTag */ && container.kind !== 330 /* JSDocSignature */) {
         return;
       }
-      if (inStrictMode && !(node.flags & 16777216 /* Ambient */)) {
+      if (inStrictMode && !(node.flags & 33554432 /* Ambient */)) {
         checkStrictModeEvalOrArguments(node, node.name);
       }
       if (isBindingPattern(node.name)) {
@@ -143312,9 +126599,9 @@ ${lanes.join("\n")}
       }
     }
     function bindFunctionDeclaration(node) {
-      if (!file.isDeclarationFile && !(node.flags & 16777216 /* Ambient */)) {
+      if (!file.isDeclarationFile && !(node.flags & 33554432 /* Ambient */)) {
         if (isAsyncFunction(node)) {
-          emitFlags |= 2048 /* HasAsyncFunctions */;
+          emitFlags |= 4096 /* HasAsyncFunctions */;
         }
       }
       checkStrictModeFunctionName(node);
@@ -143326,9 +126613,9 @@ ${lanes.join("\n")}
       }
     }
     function bindFunctionExpression(node) {
-      if (!file.isDeclarationFile && !(node.flags & 16777216 /* Ambient */)) {
+      if (!file.isDeclarationFile && !(node.flags & 33554432 /* Ambient */)) {
         if (isAsyncFunction(node)) {
-          emitFlags |= 2048 /* HasAsyncFunctions */;
+          emitFlags |= 4096 /* HasAsyncFunctions */;
         }
       }
       if (currentFlow) {
@@ -143339,8 +126626,8 @@ ${lanes.join("\n")}
       return bindAnonymousDeclaration(node, 16 /* Function */, bindingName);
     }
     function bindPropertyOrMethodOrAccessor(node, symbolFlags, symbolExcludes) {
-      if (!file.isDeclarationFile && !(node.flags & 16777216 /* Ambient */) && isAsyncFunction(node)) {
-        emitFlags |= 2048 /* HasAsyncFunctions */;
+      if (!file.isDeclarationFile && !(node.flags & 33554432 /* Ambient */) && isAsyncFunction(node)) {
+        emitFlags |= 4096 /* HasAsyncFunctions */;
       }
       if (currentFlow && isObjectLiteralOrClassExpressionMethodOrAccessor(node)) {
         node.flowNode = currentFlow;
@@ -143368,7 +126655,7 @@ ${lanes.join("\n")}
         } else {
           declareSymbolAndAddToSymbolTable(node, 262144 /* TypeParameter */, 526824 /* TypeParameterExcludes */);
         }
-      } else if (node.parent.kind === 194 /* InferType */) {
+      } else if (node.parent.kind === 195 /* InferType */) {
         const container2 = getInferTypeContainer(node.parent);
         if (container2) {
           Debug.assertNode(container2, canHaveLocals);
@@ -143399,14 +126686,14 @@ ${lanes.join("\n")}
       if (currentFlow === unreachableFlow) {
         const reportError = (
           // report error on all statements except empty ones
-          isStatementButNotDeclaration(node) && node.kind !== 241 /* EmptyStatement */ || // report error on class declarations
-          node.kind === 262 /* ClassDeclaration */ || // report error on instantiated modules or const-enums only modules if preserveConstEnums is set
-          node.kind === 266 /* ModuleDeclaration */ && shouldReportErrorOnModuleDeclaration(node)
+          isStatementButNotDeclaration(node) && node.kind !== 242 /* EmptyStatement */ || // report error on class declarations
+          node.kind === 263 /* ClassDeclaration */ || // report error on instantiated modules or const-enums only modules if preserveConstEnums is set
+          node.kind === 267 /* ModuleDeclaration */ && shouldReportErrorOnModuleDeclaration(node)
         );
         if (reportError) {
           currentFlow = reportedUnreachableFlow;
           if (!options.allowUnreachableCode) {
-            const isError = unreachableCodeIsError(options) && !(node.flags & 16777216 /* Ambient */) && (!isVariableStatement(node) || !!(getCombinedNodeFlags(node.declarationList) & 3 /* BlockScoped */) || node.declarationList.declarations.some((d) => !!d.initializer));
+            const isError = unreachableCodeIsError(options) && !(node.flags & 33554432 /* Ambient */) && (!isVariableStatement(node) || !!(getCombinedNodeFlags(node.declarationList) & 7 /* BlockScoped */) || node.declarationList.declarations.some((d) => !!d.initializer));
             eachUnreachableRange(node, (start, end) => errorOrSuggestionOnRange(isError, start, end, Diagnostics.Unreachable_code_detected));
           }
         }
@@ -143425,17 +126712,17 @@ ${lanes.join("\n")}
   }
   function isExecutableStatement(s) {
     return !isFunctionDeclaration(s) && !isPurelyTypeDeclaration(s) && !isEnumDeclaration(s) && // `var x;` may declare a variable used above
-    !(isVariableStatement(s) && !(getCombinedNodeFlags(s) & (1 /* Let */ | 2 /* Const */)) && s.declarationList.declarations.some((d) => !d.initializer));
+    !(isVariableStatement(s) && !(getCombinedNodeFlags(s) & 7 /* BlockScoped */) && s.declarationList.declarations.some((d) => !d.initializer));
   }
   function isPurelyTypeDeclaration(s) {
     switch (s.kind) {
-      case 263 /* InterfaceDeclaration */:
-      case 264 /* TypeAliasDeclaration */:
+      case 264 /* InterfaceDeclaration */:
+      case 265 /* TypeAliasDeclaration */:
         return true;
-      case 266 /* ModuleDeclaration */:
+      case 267 /* ModuleDeclaration */:
         return getModuleInstanceState(s) !== 1 /* Instantiated */;
-      case 265 /* EnumDeclaration */:
-        return hasSyntacticModifier(s, 2048 /* Const */);
+      case 266 /* EnumDeclaration */:
+        return hasSyntacticModifier(s, 4096 /* Const */);
       default:
         return false;
     }
@@ -143469,54 +126756,54 @@ ${lanes.join("\n")}
   }
   function getContainerFlags(node) {
     switch (node.kind) {
-      case 230 /* ClassExpression */:
-      case 262 /* ClassDeclaration */:
-      case 265 /* EnumDeclaration */:
-      case 209 /* ObjectLiteralExpression */:
-      case 186 /* TypeLiteral */:
-      case 328 /* JSDocTypeLiteral */:
-      case 291 /* JsxAttributes */:
+      case 231 /* ClassExpression */:
+      case 263 /* ClassDeclaration */:
+      case 266 /* EnumDeclaration */:
+      case 210 /* ObjectLiteralExpression */:
+      case 187 /* TypeLiteral */:
+      case 329 /* JSDocTypeLiteral */:
+      case 292 /* JsxAttributes */:
         return 1 /* IsContainer */;
-      case 263 /* InterfaceDeclaration */:
+      case 264 /* InterfaceDeclaration */:
         return 1 /* IsContainer */ | 64 /* IsInterface */;
-      case 266 /* ModuleDeclaration */:
-      case 264 /* TypeAliasDeclaration */:
-      case 199 /* MappedType */:
-      case 180 /* IndexSignature */:
+      case 267 /* ModuleDeclaration */:
+      case 265 /* TypeAliasDeclaration */:
+      case 200 /* MappedType */:
+      case 181 /* IndexSignature */:
         return 1 /* IsContainer */ | 32 /* HasLocals */;
-      case 311 /* SourceFile */:
+      case 312 /* SourceFile */:
         return 1 /* IsContainer */ | 4 /* IsControlFlowContainer */ | 32 /* HasLocals */;
-      case 176 /* GetAccessor */:
-      case 177 /* SetAccessor */:
-      case 173 /* MethodDeclaration */:
+      case 177 /* GetAccessor */:
+      case 178 /* SetAccessor */:
+      case 174 /* MethodDeclaration */:
         if (isObjectLiteralOrClassExpressionMethodOrAccessor(node)) {
           return 1 /* IsContainer */ | 4 /* IsControlFlowContainer */ | 32 /* HasLocals */ | 8 /* IsFunctionLike */ | 128 /* IsObjectLiteralOrClassExpressionMethodOrAccessor */;
         }
-      case 175 /* Constructor */:
-      case 261 /* FunctionDeclaration */:
-      case 172 /* MethodSignature */:
-      case 178 /* CallSignature */:
-      case 329 /* JSDocSignature */:
-      case 323 /* JSDocFunctionType */:
-      case 183 /* FunctionType */:
-      case 179 /* ConstructSignature */:
-      case 184 /* ConstructorType */:
-      case 174 /* ClassStaticBlockDeclaration */:
+      case 176 /* Constructor */:
+      case 262 /* FunctionDeclaration */:
+      case 173 /* MethodSignature */:
+      case 179 /* CallSignature */:
+      case 330 /* JSDocSignature */:
+      case 324 /* JSDocFunctionType */:
+      case 184 /* FunctionType */:
+      case 180 /* ConstructSignature */:
+      case 185 /* ConstructorType */:
+      case 175 /* ClassStaticBlockDeclaration */:
         return 1 /* IsContainer */ | 4 /* IsControlFlowContainer */ | 32 /* HasLocals */ | 8 /* IsFunctionLike */;
-      case 217 /* FunctionExpression */:
-      case 218 /* ArrowFunction */:
+      case 218 /* FunctionExpression */:
+      case 219 /* ArrowFunction */:
         return 1 /* IsContainer */ | 4 /* IsControlFlowContainer */ | 32 /* HasLocals */ | 8 /* IsFunctionLike */ | 16 /* IsFunctionExpression */;
-      case 267 /* ModuleBlock */:
+      case 268 /* ModuleBlock */:
         return 4 /* IsControlFlowContainer */;
-      case 171 /* PropertyDeclaration */:
+      case 172 /* PropertyDeclaration */:
         return node.initializer ? 4 /* IsControlFlowContainer */ : 0;
-      case 298 /* CatchClause */:
-      case 247 /* ForStatement */:
-      case 248 /* ForInStatement */:
-      case 249 /* ForOfStatement */:
-      case 268 /* CaseBlock */:
+      case 299 /* CatchClause */:
+      case 248 /* ForStatement */:
+      case 249 /* ForInStatement */:
+      case 250 /* ForOfStatement */:
+      case 269 /* CaseBlock */:
         return 2 /* IsBlockScopedContainer */ | 32 /* HasLocals */;
-      case 240 /* Block */:
+      case 241 /* Block */:
         return isFunctionLike(node.parent) || isClassStaticBlockDeclaration(node.parent) ? 0 /* None */ : 2 /* IsBlockScopedContainer */ | 32 /* HasLocals */;
     }
     return 0 /* None */;
@@ -143534,7 +126821,7 @@ ${lanes.join("\n")}
       return (_d = (_c = container.symbol) == null ? void 0 : _c.exports) == null ? void 0 : _d.get(name);
     }
   }
-  var ModuleInstanceState, binder;
+  var ModuleInstanceState, ContainerFlags, binder;
   var init_binder = __esm({
     "src/compiler/binder.ts"() {
       "use strict";
@@ -143546,6 +126833,18 @@ ${lanes.join("\n")}
         ModuleInstanceState2[ModuleInstanceState2["ConstEnumOnly"] = 2] = "ConstEnumOnly";
         return ModuleInstanceState2;
       })(ModuleInstanceState || {});
+      ContainerFlags = /* @__PURE__ */ ((ContainerFlags2) => {
+        ContainerFlags2[ContainerFlags2["None"] = 0] = "None";
+        ContainerFlags2[ContainerFlags2["IsContainer"] = 1] = "IsContainer";
+        ContainerFlags2[ContainerFlags2["IsBlockScopedContainer"] = 2] = "IsBlockScopedContainer";
+        ContainerFlags2[ContainerFlags2["IsControlFlowContainer"] = 4] = "IsControlFlowContainer";
+        ContainerFlags2[ContainerFlags2["IsFunctionLike"] = 8] = "IsFunctionLike";
+        ContainerFlags2[ContainerFlags2["IsFunctionExpression"] = 16] = "IsFunctionExpression";
+        ContainerFlags2[ContainerFlags2["HasLocals"] = 32] = "HasLocals";
+        ContainerFlags2[ContainerFlags2["IsInterface"] = 64] = "IsInterface";
+        ContainerFlags2[ContainerFlags2["IsObjectLiteralOrClassExpressionMethodOrAccessor"] = 128] = "IsObjectLiteralOrClassExpressionMethodOrAccessor";
+        return ContainerFlags2;
+      })(ContainerFlags || {});
       binder = /* @__PURE__ */ createBinder();
     }
   });
@@ -143692,7 +126991,7 @@ ${lanes.join("\n")}
           symbol.exports.forEach(visitSymbol);
         }
         forEach(symbol.declarations, (d) => {
-          if (d.type && d.type.kind === 185 /* TypeQuery */) {
+          if (d.type && d.type.kind === 186 /* TypeQuery */) {
             const query = d.type;
             const entity = getResolvedSymbol(getFirstIdentifier2(query.exprName));
             visitSymbol(entity);
@@ -143766,20 +127065,17 @@ ${lanes.join("\n")}
   function getNodeModulesPackageName(compilerOptions, importingSourceFile, nodeModulesFileName, host, preferences, options = {}) {
     const info = getInfo(importingSourceFile.path, host);
     const modulePaths = getAllModulePaths(importingSourceFile.path, nodeModulesFileName, host, preferences, options);
-    return firstDefined(
-      modulePaths,
-      (modulePath) => tryGetModuleNameAsNodeModule(
-        modulePath,
-        info,
-        importingSourceFile,
-        host,
-        compilerOptions,
-        preferences,
-        /*packageNameOnly*/
-        true,
-        options.overrideImportMode
-      )
-    );
+    return firstDefined(modulePaths, (modulePath) => tryGetModuleNameAsNodeModule(
+      modulePath,
+      info,
+      importingSourceFile,
+      host,
+      compilerOptions,
+      preferences,
+      /*packageNameOnly*/
+      true,
+      options.overrideImportMode
+    ));
   }
   function getModuleSpecifierWorker(compilerOptions, importingSourceFile, importingSourceFileName, toFileName2, host, preferences, userPreferences, options = {}) {
     const info = getInfo(importingSourceFileName, host);
@@ -143823,10 +127119,12 @@ ${lanes.join("\n")}
       importingSourceFile,
       host,
       userPreferences,
-      options
+      options,
+      /*forAutoImport*/
+      false
     ).moduleSpecifiers;
   }
-  function getModuleSpecifiersWithCacheInfo(moduleSymbol, checker, compilerOptions, importingSourceFile, host, userPreferences, options = {}) {
+  function getModuleSpecifiersWithCacheInfo(moduleSymbol, checker, compilerOptions, importingSourceFile, host, userPreferences, options = {}, forAutoImport) {
     let computedWithoutCache = false;
     const ambient = tryGetModuleNameFromAmbientModule(moduleSymbol, checker);
     if (ambient)
@@ -143844,11 +127142,19 @@ ${lanes.join("\n")}
       return { moduleSpecifiers: emptyArray, computedWithoutCache };
     computedWithoutCache = true;
     modulePaths || (modulePaths = getAllModulePathsWorker(importingSourceFile.path, moduleSourceFile.originalFileName, host));
-    const result = computeModuleSpecifiers(modulePaths, compilerOptions, importingSourceFile, host, userPreferences, options);
+    const result = computeModuleSpecifiers(
+      modulePaths,
+      compilerOptions,
+      importingSourceFile,
+      host,
+      userPreferences,
+      options,
+      forAutoImport
+    );
     cache == null ? void 0 : cache.set(importingSourceFile.path, moduleSourceFile.path, userPreferences, options, modulePaths, result);
     return { moduleSpecifiers: result, computedWithoutCache };
   }
-  function computeModuleSpecifiers(modulePaths, compilerOptions, importingSourceFile, host, userPreferences, options = {}) {
+  function computeModuleSpecifiers(modulePaths, compilerOptions, importingSourceFile, host, userPreferences, options = {}, forAutoImport) {
     const info = getInfo(importingSourceFile.path, host);
     const preferences = getPreferences(userPreferences, compilerOptions, importingSourceFile);
     const existingSpecifier = forEach(modulePaths, (modulePath) => forEach(
@@ -143905,7 +127211,7 @@ ${lanes.join("\n")}
           redirectPathsSpecifiers = append(redirectPathsSpecifiers, local);
         } else if (pathIsBareSpecifier(local)) {
           pathsSpecifiers = append(pathsSpecifiers, local);
-        } else if (!importedFileIsInNodeModules || modulePath.isInNodeModules) {
+        } else if (forAutoImport || !importedFileIsInNodeModules || modulePath.isInNodeModules) {
           relativeSpecifiers = append(relativeSpecifiers, local);
         }
       }
@@ -144046,7 +127352,15 @@ ${lanes.join("\n")}
       /*preferSymlinks*/
       true,
       (path, isRedirect) => {
-        const isInNodeModules = pathContainsNodeModules(path);
+        let isInNodeModules = pathContainsNodeModules(path);
+        const pnpapi = getPnpApi(path);
+        if (!isInNodeModules && pnpapi) {
+          const fromLocator = pnpapi.findPackageLocator(importingFileName);
+          const toLocator = pnpapi.findPackageLocator(path);
+          if (fromLocator && toLocator && fromLocator !== toLocator) {
+            isInNodeModules = true;
+          }
+        }
         allFileNames.set(path, { path: getCanonicalFileName(path), isRedirect, isInNodeModules });
         importedFileFromNodeModules = importedFileFromNodeModules || isInNodeModules;
       }
@@ -144088,32 +127402,29 @@ ${lanes.join("\n")}
     if (decl) {
       return decl.name.text;
     }
-    const ambientModuleDeclareCandidates = mapDefined(
-      moduleSymbol.declarations,
-      (d) => {
-        var _a2, _b, _c, _d;
-        if (!isModuleDeclaration(d))
-          return;
-        const topNamespace = getTopNamespace(d);
-        if (!(((_a2 = topNamespace == null ? void 0 : topNamespace.parent) == null ? void 0 : _a2.parent) && isModuleBlock(topNamespace.parent) && isAmbientModule(topNamespace.parent.parent) && isSourceFile(topNamespace.parent.parent.parent)))
-          return;
-        const exportAssignment = (_d = (_c = (_b = topNamespace.parent.parent.symbol.exports) == null ? void 0 : _b.get("export=")) == null ? void 0 : _c.valueDeclaration) == null ? void 0 : _d.expression;
-        if (!exportAssignment)
-          return;
-        const exportSymbol = checker.getSymbolAtLocation(exportAssignment);
-        if (!exportSymbol)
-          return;
-        const originalExportSymbol = (exportSymbol == null ? void 0 : exportSymbol.flags) & 2097152 /* Alias */ ? checker.getAliasedSymbol(exportSymbol) : exportSymbol;
-        if (originalExportSymbol === d.symbol)
-          return topNamespace.parent.parent;
-        function getTopNamespace(namespaceDeclaration) {
-          while (namespaceDeclaration.flags & 4 /* NestedNamespace */) {
-            namespaceDeclaration = namespaceDeclaration.parent;
-          }
-          return namespaceDeclaration;
+    const ambientModuleDeclareCandidates = mapDefined(moduleSymbol.declarations, (d) => {
+      var _a2, _b, _c, _d;
+      if (!isModuleDeclaration(d))
+        return;
+      const topNamespace = getTopNamespace(d);
+      if (!(((_a2 = topNamespace == null ? void 0 : topNamespace.parent) == null ? void 0 : _a2.parent) && isModuleBlock(topNamespace.parent) && isAmbientModule(topNamespace.parent.parent) && isSourceFile(topNamespace.parent.parent.parent)))
+        return;
+      const exportAssignment = (_d = (_c = (_b = topNamespace.parent.parent.symbol.exports) == null ? void 0 : _b.get("export=")) == null ? void 0 : _c.valueDeclaration) == null ? void 0 : _d.expression;
+      if (!exportAssignment)
+        return;
+      const exportSymbol = checker.getSymbolAtLocation(exportAssignment);
+      if (!exportSymbol)
+        return;
+      const originalExportSymbol = (exportSymbol == null ? void 0 : exportSymbol.flags) & 2097152 /* Alias */ ? checker.getAliasedSymbol(exportSymbol) : exportSymbol;
+      if (originalExportSymbol === d.symbol)
+        return topNamespace.parent.parent;
+      function getTopNamespace(namespaceDeclaration) {
+        while (namespaceDeclaration.flags & 8 /* NestedNamespace */) {
+          namespaceDeclaration = namespaceDeclaration.parent;
         }
+        return namespaceDeclaration;
       }
-    );
+    });
     const ambientModuleDeclare = ambientModuleDeclareCandidates[0];
     if (ambientModuleDeclare) {
       return ambientModuleDeclare.name.text;
@@ -144137,7 +127448,9 @@ ${lanes.join("\n")}
           for (const { ending, value } of candidates) {
             if (value.length >= prefix.length + suffix.length && startsWith(value, prefix) && endsWith(value, suffix) && validateEnding({ ending, value })) {
               const matchedStar = value.substring(prefix.length, value.length - suffix.length);
-              return pathIsRelative(matchedStar) ? void 0 : key.replace("*", matchedStar);
+              if (!pathIsRelative(matchedStar)) {
+                return key.replace("*", matchedStar);
+              }
             }
           }
         } else if (some(candidates, (c) => c.ending !== 0 /* Minimal */ && pattern === c.value) || some(candidates, (c) => c.ending === 0 /* Minimal */ && pattern === c.value && validateEnding(c))) {
@@ -144202,14 +127515,14 @@ ${lanes.join("\n")}
             /*currentDirectory*/
             void 0
           );
-          const mode2 = endsWith(k, "/") ? 1 /* Directory */ : stringContains(k, "*") ? 2 /* Pattern */ : 0 /* Exact */;
+          const mode2 = endsWith(k, "/") ? 1 /* Directory */ : k.includes("*") ? 2 /* Pattern */ : 0 /* Exact */;
           return tryGetModuleNameFromExports(options, targetFilePath, packageDirectory, subPackageName, exports[k], conditions, mode2);
         });
       } else {
         for (const key of getOwnKeys(exports)) {
-          if (key === "default" || conditions.indexOf(key) >= 0 || isApplicableVersionedTypesKey(conditions, key)) {
+          if (key === "default" || conditions.includes(key) || isApplicableVersionedTypesKey(conditions, key)) {
             const subTarget = exports[key];
-            const result = tryGetModuleNameFromExports(options, targetFilePath, packageDirectory, packageName, subTarget, conditions);
+            const result = tryGetModuleNameFromExports(options, targetFilePath, packageDirectory, packageName, subTarget, conditions, mode);
             if (result) {
               return result;
             }
@@ -144238,7 +127551,41 @@ ${lanes.join("\n")}
     if (!host.fileExists || !host.readFile) {
       return void 0;
     }
-    const parts = getNodeModulePathParts(path);
+    let parts = getNodeModulePathParts(path);
+    let pnpPackageName;
+    const pnpApi = getPnpApi(path);
+    if (pnpApi) {
+      const fromLocator = pnpApi.findPackageLocator(importingSourceFile.fileName);
+      const toLocator = pnpApi.findPackageLocator(path);
+      if (fromLocator === toLocator) {
+        return void 0;
+      }
+      if (fromLocator && toLocator) {
+        const fromInfo = pnpApi.getPackageInformation(fromLocator);
+        if (toLocator.reference === fromInfo.packageDependencies.get(toLocator.name)) {
+          pnpPackageName = toLocator.name;
+        } else {
+          for (const [name, reference] of fromInfo.packageDependencies) {
+            if (Array.isArray(reference)) {
+              if (reference[0] === toLocator.name && reference[1] === toLocator.reference) {
+                pnpPackageName = name;
+                break;
+              }
+            }
+          }
+        }
+        if (!parts) {
+          const toInfo = pnpApi.getPackageInformation(toLocator);
+          parts = {
+            topLevelNodeModulesIndex: void 0,
+            topLevelPackageNameIndex: void 0,
+            // The last character from packageLocation is the trailing "/", we want to point to it
+            packageRootIndex: toInfo.packageLocation.length - 1,
+            fileNameIndex: path.lastIndexOf(`/`)
+          };
+        }
+      }
+    }
     if (!parts) {
       return void 0;
     }
@@ -144276,14 +127623,16 @@ ${lanes.join("\n")}
     if (isRedirect && !isPackageRootPath) {
       return void 0;
     }
-    const globalTypingsCacheLocation = host.getGlobalTypingsCacheLocation && host.getGlobalTypingsCacheLocation();
-    const pathToTopLevelNodeModules = getCanonicalFileName(moduleSpecifier.substring(0, parts.topLevelNodeModulesIndex));
-    if (!(startsWith(sourceDirectory, pathToTopLevelNodeModules) || globalTypingsCacheLocation && startsWith(getCanonicalFileName(globalTypingsCacheLocation), pathToTopLevelNodeModules))) {
-      return void 0;
+    if (typeof process.versions.pnp === "undefined") {
+      const globalTypingsCacheLocation = host.getGlobalTypingsCacheLocation && host.getGlobalTypingsCacheLocation();
+      const pathToTopLevelNodeModules = getCanonicalFileName(moduleSpecifier.substring(0, parts.topLevelNodeModulesIndex));
+      if (!(startsWith(sourceDirectory, pathToTopLevelNodeModules) || globalTypingsCacheLocation && startsWith(getCanonicalFileName(globalTypingsCacheLocation), pathToTopLevelNodeModules))) {
+        return void 0;
+      }
     }
-    const nodeModulesDirectoryName = moduleSpecifier.substring(parts.topLevelPackageNameIndex + 1);
-    const packageName = getPackageNameFromTypesPackageName(nodeModulesDirectoryName);
-    return getEmitModuleResolutionKind(options) === 1 /* Classic */ && packageName === nodeModulesDirectoryName ? void 0 : packageName;
+    const nodeModulesDirectoryName = typeof pnpPackageName !== "undefined" ? pnpPackageName + moduleSpecifier.substring(parts.packageRootIndex) : moduleSpecifier.substring(parts.topLevelPackageNameIndex + 1);
+    const packageNameFromPath = getPackageNameFromTypesPackageName(nodeModulesDirectoryName);
+    return getEmitModuleResolutionKind(options) === 1 /* Classic */ && packageNameFromPath === nodeModulesDirectoryName ? void 0 : packageNameFromPath;
     function tryDirectoryWithPackageJson(packageRootIndex) {
       var _a, _b;
       const packageRootPath = path.substring(0, packageRootIndex);
@@ -144296,9 +127645,9 @@ ${lanes.join("\n")}
         const importMode = overrideMode || importingSourceFile.impliedNodeFormat;
         if (getResolvePackageJsonExports(options)) {
           const nodeModulesDirectoryName2 = packageRootPath.substring(parts.topLevelPackageNameIndex + 1);
-          const packageName2 = getPackageNameFromTypesPackageName(nodeModulesDirectoryName2);
-          const conditions = getConditions(options, importMode === 99 /* ESNext */);
-          const fromExports = packageJsonContent.exports ? tryGetModuleNameFromExports(options, path, packageRootPath, packageName2, packageJsonContent.exports, conditions) : void 0;
+          const packageName = getPackageNameFromTypesPackageName(pnpPackageName ? pnpPackageName : nodeModulesDirectoryName2);
+          const conditions = getConditions(options, importMode);
+          const fromExports = packageJsonContent.exports ? tryGetModuleNameFromExports(options, path, packageRootPath, packageName, packageJsonContent.exports, conditions) : void 0;
           if (fromExports) {
             const withJsExtension = !hasTSFileExtension(fromExports.moduleFileToTry) ? fromExports : { moduleFileToTry: removeFileExtension(fromExports.moduleFileToTry) + tryGetJSExtensionForFile(fromExports.moduleFileToTry, options) };
             return { ...withJsExtension, verbatimFromExports: true };
@@ -144373,7 +127722,7 @@ ${lanes.join("\n")}
       return fileName;
     } else if (fileExtensionIsOneOf(fileName, [".d.mts" /* Dmts */, ".mts" /* Mts */, ".d.cts" /* Dcts */, ".cts" /* Cts */])) {
       return noExtension + getJSExtensionForFile(fileName, options);
-    } else if (!fileExtensionIsOneOf(fileName, [".d.ts" /* Dts */]) && fileExtensionIsOneOf(fileName, [".ts" /* Ts */]) && stringContains(fileName, ".d.")) {
+    } else if (!fileExtensionIsOneOf(fileName, [".d.ts" /* Dts */]) && fileExtensionIsOneOf(fileName, [".ts" /* Ts */]) && fileName.includes(".d.")) {
       return tryGetRealFileNameForNonJsDeclarationFileName(fileName);
     }
     switch (allowedEndings[0]) {
@@ -144399,7 +127748,7 @@ ${lanes.join("\n")}
   }
   function tryGetRealFileNameForNonJsDeclarationFileName(fileName) {
     const baseName = getBaseFileName(fileName);
-    if (!endsWith(fileName, ".ts" /* Ts */) || !stringContains(baseName, ".d.") || fileExtensionIsOneOf(baseName, [".d.ts" /* Dts */]))
+    if (!endsWith(fileName, ".ts" /* Ts */) || !baseName.includes(".d.") || fileExtensionIsOneOf(baseName, [".d.ts" /* Dts */]))
       return void 0;
     const noExtension = removeExtension(fileName, ".ts" /* Ts */);
     const ext = noExtension.substring(noExtension.lastIndexOf("."));
@@ -144450,6 +127799,7 @@ ${lanes.join("\n")}
     "src/compiler/moduleSpecifiers.ts"() {
       "use strict";
       init_ts2();
+      init_pnp();
     }
   });
 
@@ -144507,7 +127857,7 @@ ${lanes.join("\n")}
     var externalHelpersModule;
     var Symbol47 = objectAllocator.getSymbolConstructor();
     var Type27 = objectAllocator.getTypeConstructor();
-    var Signature15 = objectAllocator.getSignatureConstructor();
+    var Signature14 = objectAllocator.getSignatureConstructor();
     var typeCount = 0;
     var symbolCount = 0;
     var totalInstantiationCount = 0;
@@ -144524,6 +127874,7 @@ ${lanes.join("\n")}
     var moduleKind = getEmitModuleKind(compilerOptions);
     var legacyDecorators = !!compilerOptions.experimentalDecorators;
     var useDefineForClassFields = getUseDefineForClassFields(compilerOptions);
+    var emitStandardClassFields = getEmitStandardClassFields(compilerOptions);
     var allowSyntheticDefaultImports = getAllowSyntheticDefaultImports(compilerOptions);
     var strictNullChecks = getStrictOptionValue(compilerOptions, "strictNullChecks");
     var strictFunctionTypes = getStrictOptionValue(compilerOptions, "strictFunctionTypes");
@@ -144551,6 +127902,10 @@ ${lanes.join("\n")}
     var isolatedModulesLikeFlagName = compilerOptions.verbatimModuleSyntax ? "verbatimModuleSyntax" : "isolatedModules";
     var canCollectSymbolAliasAccessabilityData = !compilerOptions.verbatimModuleSyntax || !!compilerOptions.importsNotUsedAsValues;
     var apparentArgumentCount;
+    var lastGetCombinedNodeFlagsNode;
+    var lastGetCombinedNodeFlagsResult = 0 /* None */;
+    var lastGetCombinedModifierFlagsNode;
+    var lastGetCombinedModifierFlagsResult = 0 /* None */;
     const checker = {
       getNodeCount: () => reduceLeft(host.getSourceFiles(), (n, s) => n + s.nodeCount, 0),
       getIdentifierCount: () => reduceLeft(host.getSourceFiles(), (n, s) => n + s.identifierCount, 0),
@@ -144610,7 +127965,7 @@ ${lanes.join("\n")}
         return node ? getTypeFromTypeNode(node) : errorType;
       },
       getParameterType: getTypeAtPosition,
-      getParameterIdentifierNameAtPosition,
+      getParameterIdentifierInfoAtPosition,
       getPromisedTypeOfPromise,
       getAwaitedType: (type) => getAwaitedType(type),
       getReturnTypeOfSignature,
@@ -144728,13 +128083,7 @@ ${lanes.join("\n")}
       getTypeOfPropertyOfContextualType,
       getFullyQualifiedName,
       getResolvedSignature: (node, candidatesOutArray, argumentCount) => getResolvedSignatureWorker(node, candidatesOutArray, argumentCount, 0 /* Normal */),
-      getResolvedSignatureForStringLiteralCompletions: (call, editingArgument, candidatesOutArray) => runWithInferenceBlockedFromSourceNode(editingArgument, () => getResolvedSignatureWorker(
-        call,
-        candidatesOutArray,
-        /*argumentCount*/
-        void 0,
-        32 /* IsForStringLiteralArgumentCompletions */
-      )),
+      getCandidateSignaturesForStringLiteralCompletions,
       getResolvedSignatureForSignatureHelp: (node, candidatesOutArray, argumentCount) => runWithoutResolvedSignatureCaching(node, () => getResolvedSignatureWorker(node, candidatesOutArray, argumentCount, 16 /* IsForSignatureHelp */)),
       getExpandedParameters,
       hasEffectiveRestParameter,
@@ -144908,7 +128257,7 @@ ${lanes.join("\n")}
           Debug.assert(!!(getNodeLinks(file).flags & 1 /* TypeChecked */));
           diagnostics2 = addRange(diagnostics2, suggestionDiagnostics.getDiagnostics(file.fileName));
           checkUnusedIdentifiers(getPotentiallyUnusedIdentifiers(file), (containingNode, kind, diag2) => {
-            if (!containsParseError(containingNode) && !unusedIsError(kind, !!(containingNode.flags & 16777216 /* Ambient */))) {
+            if (!containsParseError(containingNode) && !unusedIsError(kind, !!(containingNode.flags & 33554432 /* Ambient */))) {
               (diagnostics2 || (diagnostics2 = [])).push({ ...diag2, category: 2 /* Suggestion */ });
             }
           });
@@ -144933,17 +128282,59 @@ ${lanes.join("\n")}
       isTypeParameterPossiblyReferenced,
       typeHasCallOrConstructSignatures
     };
-    function runWithoutResolvedSignatureCaching(node, fn) {
-      const containingCall = findAncestor(node, isCallLikeExpression);
-      const containingCallResolvedSignature = containingCall && getNodeLinks(containingCall).resolvedSignature;
-      if (containingCall) {
-        getNodeLinks(containingCall).resolvedSignature = void 0;
+    function getCandidateSignaturesForStringLiteralCompletions(call, editingArgument) {
+      const candidatesSet = /* @__PURE__ */ new Set();
+      const candidates = [];
+      runWithInferenceBlockedFromSourceNode(editingArgument, () => getResolvedSignatureWorker(
+        call,
+        candidates,
+        /*argumentCount*/
+        void 0,
+        0 /* Normal */
+      ));
+      for (const candidate of candidates) {
+        candidatesSet.add(candidate);
       }
-      const result = fn();
-      if (containingCall) {
-        getNodeLinks(containingCall).resolvedSignature = containingCallResolvedSignature;
+      candidates.length = 0;
+      runWithoutResolvedSignatureCaching(editingArgument, () => getResolvedSignatureWorker(
+        call,
+        candidates,
+        /*argumentCount*/
+        void 0,
+        0 /* Normal */
+      ));
+      for (const candidate of candidates) {
+        candidatesSet.add(candidate);
       }
-      return result;
+      return arrayFrom(candidatesSet);
+    }
+    function runWithoutResolvedSignatureCaching(node, fn) {
+      node = findAncestor(node, isCallLikeOrFunctionLikeExpression);
+      if (node) {
+        const cachedResolvedSignatures = [];
+        const cachedTypes2 = [];
+        while (node) {
+          const nodeLinks2 = getNodeLinks(node);
+          cachedResolvedSignatures.push([nodeLinks2, nodeLinks2.resolvedSignature]);
+          nodeLinks2.resolvedSignature = void 0;
+          if (isFunctionExpressionOrArrowFunction(node)) {
+            const symbolLinks2 = getSymbolLinks(getSymbolOfDeclaration(node));
+            const type = symbolLinks2.type;
+            cachedTypes2.push([symbolLinks2, type]);
+            symbolLinks2.type = void 0;
+          }
+          node = findAncestor(node.parent, isCallLikeOrFunctionLikeExpression);
+        }
+        const result = fn();
+        for (const [nodeLinks2, resolvedSignature] of cachedResolvedSignatures) {
+          nodeLinks2.resolvedSignature = resolvedSignature;
+        }
+        for (const [symbolLinks2, type] of cachedTypes2) {
+          symbolLinks2.type = type;
+        }
+        return result;
+      }
+      return fn();
     }
     function runWithInferenceBlockedFromSourceNode(node, fn) {
       const containingCall = findAncestor(node, isCallLikeExpression);
@@ -144995,28 +128386,72 @@ ${lanes.join("\n")}
     var resolvingSymbol = createSymbol(0, "__resolving__" /* Resolving */);
     var unresolvedSymbols = /* @__PURE__ */ new Map();
     var errorTypes = /* @__PURE__ */ new Map();
+    var seenIntrinsicNames = /* @__PURE__ */ new Set();
     var anyType = createIntrinsicType(1 /* Any */, "any");
-    var autoType = createIntrinsicType(1 /* Any */, "any", 262144 /* NonInferrableType */);
-    var wildcardType = createIntrinsicType(1 /* Any */, "any");
+    var autoType = createIntrinsicType(1 /* Any */, "any", 262144 /* NonInferrableType */, "auto");
+    var wildcardType = createIntrinsicType(
+      1 /* Any */,
+      "any",
+      /*objectFlags*/
+      void 0,
+      "wildcard"
+    );
+    var blockedStringType = createIntrinsicType(
+      1 /* Any */,
+      "any",
+      /*objectFlags*/
+      void 0,
+      "blocked string"
+    );
     var errorType = createIntrinsicType(1 /* Any */, "error");
     var unresolvedType = createIntrinsicType(1 /* Any */, "unresolved");
-    var nonInferrableAnyType = createIntrinsicType(1 /* Any */, "any", 65536 /* ContainsWideningType */);
+    var nonInferrableAnyType = createIntrinsicType(1 /* Any */, "any", 65536 /* ContainsWideningType */, "non-inferrable");
     var intrinsicMarkerType = createIntrinsicType(1 /* Any */, "intrinsic");
     var unknownType = createIntrinsicType(2 /* Unknown */, "unknown");
-    var nonNullUnknownType = createIntrinsicType(2 /* Unknown */, "unknown");
+    var nonNullUnknownType = createIntrinsicType(
+      2 /* Unknown */,
+      "unknown",
+      /*objectFlags*/
+      void 0,
+      "non-null"
+    );
     var undefinedType = createIntrinsicType(32768 /* Undefined */, "undefined");
-    var undefinedWideningType = strictNullChecks ? undefinedType : createIntrinsicType(32768 /* Undefined */, "undefined", 65536 /* ContainsWideningType */);
-    var missingType = createIntrinsicType(32768 /* Undefined */, "undefined");
+    var undefinedWideningType = strictNullChecks ? undefinedType : createIntrinsicType(32768 /* Undefined */, "undefined", 65536 /* ContainsWideningType */, "widening");
+    var missingType = createIntrinsicType(
+      32768 /* Undefined */,
+      "undefined",
+      /*objectFlags*/
+      void 0,
+      "missing"
+    );
     var undefinedOrMissingType = exactOptionalPropertyTypes ? missingType : undefinedType;
-    var optionalType = createIntrinsicType(32768 /* Undefined */, "undefined");
+    var optionalType = createIntrinsicType(
+      32768 /* Undefined */,
+      "undefined",
+      /*objectFlags*/
+      void 0,
+      "optional"
+    );
     var nullType = createIntrinsicType(65536 /* Null */, "null");
-    var nullWideningType = strictNullChecks ? nullType : createIntrinsicType(65536 /* Null */, "null", 65536 /* ContainsWideningType */);
+    var nullWideningType = strictNullChecks ? nullType : createIntrinsicType(65536 /* Null */, "null", 65536 /* ContainsWideningType */, "widening");
     var stringType = createIntrinsicType(4 /* String */, "string");
     var numberType = createIntrinsicType(8 /* Number */, "number");
     var bigintType = createIntrinsicType(64 /* BigInt */, "bigint");
-    var falseType = createIntrinsicType(512 /* BooleanLiteral */, "false");
+    var falseType = createIntrinsicType(
+      512 /* BooleanLiteral */,
+      "false",
+      /*objectFlags*/
+      void 0,
+      "fresh"
+    );
     var regularFalseType = createIntrinsicType(512 /* BooleanLiteral */, "false");
-    var trueType = createIntrinsicType(512 /* BooleanLiteral */, "true");
+    var trueType = createIntrinsicType(
+      512 /* BooleanLiteral */,
+      "true",
+      /*objectFlags*/
+      void 0,
+      "fresh"
+    );
     var regularTrueType = createIntrinsicType(512 /* BooleanLiteral */, "true");
     trueType.regularType = regularTrueType;
     trueType.freshType = trueType;
@@ -145030,9 +128465,21 @@ ${lanes.join("\n")}
     var esSymbolType = createIntrinsicType(4096 /* ESSymbol */, "symbol");
     var voidType = createIntrinsicType(16384 /* Void */, "void");
     var neverType = createIntrinsicType(131072 /* Never */, "never");
-    var silentNeverType = createIntrinsicType(131072 /* Never */, "never", 262144 /* NonInferrableType */);
-    var implicitNeverType = createIntrinsicType(131072 /* Never */, "never");
-    var unreachableNeverType = createIntrinsicType(131072 /* Never */, "never");
+    var silentNeverType = createIntrinsicType(131072 /* Never */, "never", 262144 /* NonInferrableType */, "silent");
+    var implicitNeverType = createIntrinsicType(
+      131072 /* Never */,
+      "never",
+      /*objectFlags*/
+      void 0,
+      "implicit"
+    );
+    var unreachableNeverType = createIntrinsicType(
+      131072 /* Never */,
+      "never",
+      /*objectFlags*/
+      void 0,
+      "unreachable"
+    );
     var nonPrimitiveType = createIntrinsicType(67108864 /* NonPrimitive */, "object");
     var stringOrNumberType = getUnionType([stringType, numberType]);
     var stringNumberSymbolType = getUnionType([stringType, numberType, esSymbolType]);
@@ -145042,7 +128489,13 @@ ${lanes.join("\n")}
     var numericStringType = getTemplateLiteralType(["", ""], [numberType]);
     var restrictiveMapper = makeFunctionTypeMapper((t) => t.flags & 262144 /* TypeParameter */ ? getRestrictiveTypeParameter(t) : t, () => "(restrictive mapper)");
     var permissiveMapper = makeFunctionTypeMapper((t) => t.flags & 262144 /* TypeParameter */ ? wildcardType : t, () => "(permissive mapper)");
-    var uniqueLiteralType = createIntrinsicType(131072 /* Never */, "never");
+    var uniqueLiteralType = createIntrinsicType(
+      131072 /* Never */,
+      "never",
+      /*objectFlags*/
+      void 0,
+      "unique literal"
+    );
     var uniqueLiteralMapper = makeFunctionTypeMapper((t) => t.flags & 262144 /* TypeParameter */ ? uniqueLiteralType : t, () => "(unique literal mapper)");
     var outofbandVarianceMarkerHandler;
     var reportUnreliableMapper = makeFunctionTypeMapper((t) => {
@@ -145247,7 +128700,7 @@ ${lanes.join("\n")}
     };
     var amalgamatedDuplicates;
     var reverseMappedCache = /* @__PURE__ */ new Map();
-    var inInferTypeForHomomorphicMappedType = false;
+    var homomorphicMappedTypeInferenceStack = [];
     var ambientModulesCache;
     var patternAmbientModules;
     var patternAmbientModuleAugmentations;
@@ -145288,6 +128741,8 @@ ${lanes.join("\n")}
     var deferredGlobalImportMetaType;
     var deferredGlobalImportMetaExpressionType;
     var deferredGlobalImportCallOptionsType;
+    var deferredGlobalDisposableType;
+    var deferredGlobalAsyncDisposableType;
     var deferredGlobalExtractSymbol;
     var deferredGlobalOmitSymbol;
     var deferredGlobalAwaitedSymbol;
@@ -145459,14 +128914,14 @@ ${lanes.join("\n")}
       }
     }
     function errorSkippedOn(key, location, message, ...args) {
-      const diagnostic = error(location, message, ...args);
+      const diagnostic = error2(location, message, ...args);
       diagnostic.skippedOn = key;
       return diagnostic;
     }
     function createError(location, message, ...args) {
       return location ? createDiagnosticForNode(location, message, ...args) : createCompilerDiagnostic(message, ...args);
     }
-    function error(location, message, ...args) {
+    function error2(location, message, ...args) {
       const diagnostic = createError(location, message, ...args);
       diagnostics.add(diagnostic);
       return diagnostic;
@@ -145490,7 +128945,7 @@ ${lanes.join("\n")}
       addErrorOrSuggestion(isError, "message" in message ? createDiagnosticForNode(location, message, ...args) : createDiagnosticForNodeFromMessageChain(getSourceFileOfNode(location), location, message));
     }
     function errorAndMaybeSuggestAwait(location, maybeMissingAwait, message, ...args) {
-      const diagnostic = error(location, message, ...args);
+      const diagnostic = error2(location, message, ...args);
       if (maybeMissingAwait) {
         const related = createDiagnosticForNode(location, Diagnostics.Did_you_forget_to_use_await);
         addRelatedInfo(diagnostic, related);
@@ -145516,7 +128971,7 @@ ${lanes.join("\n")}
       return !!symbol.valueDeclaration && isDeprecatedDeclaration2(symbol.valueDeclaration) || length(symbol.declarations) && every(symbol.declarations, isDeprecatedDeclaration2);
     }
     function isDeprecatedDeclaration2(declaration) {
-      return !!(getCombinedNodeFlags(declaration) & 268435456 /* Deprecated */);
+      return !!(getCombinedNodeFlagsCached(declaration) & 536870912 /* Deprecated */);
     }
     function addDeprecatedSuggestion(location, declarations, deprecatedEntity) {
       const diagnostic = createDiagnosticForNode(location, Diagnostics._0_is_deprecated, deprecatedEntity);
@@ -145636,7 +129091,7 @@ ${lanes.join("\n")}
         }
       } else if (target.flags & 1024 /* NamespaceModule */) {
         if (target !== globalThisSymbol) {
-          error(
+          error2(
             source.declarations && getNameOfDeclaration(source.declarations[0]),
             Diagnostics.Cannot_augment_module_0_with_value_exports_because_it_resolves_to_a_non_module_entity,
             symbolToString(target)
@@ -145730,7 +129185,7 @@ ${lanes.join("\n")}
       if (isGlobalScopeAugmentation(moduleAugmentation)) {
         mergeSymbolTable(globals, moduleAugmentation.symbol.exports);
       } else {
-        const moduleNotFoundError = !(moduleName.parent.parent.flags & 16777216 /* Ambient */) ? Diagnostics.Invalid_module_name_in_augmentation_module_0_cannot_be_found : void 0;
+        const moduleNotFoundError = !(moduleName.parent.parent.flags & 33554432 /* Ambient */) ? Diagnostics.Invalid_module_name_in_augmentation_module_0_cannot_be_found : void 0;
         let mainModule = resolveExternalModuleNameWorker(
           moduleName,
           moduleName,
@@ -145766,7 +129221,7 @@ ${lanes.join("\n")}
             mergeSymbol(mainModule, moduleAugmentation.symbol);
           }
         } else {
-          error(moduleName, Diagnostics.Cannot_augment_module_0_because_it_resolves_to_a_non_module_entity, moduleName.text);
+          error2(moduleName, Diagnostics.Cannot_augment_module_0_because_it_resolves_to_a_non_module_entity, moduleName.text);
         }
       }
     }
@@ -145794,7 +129249,7 @@ ${lanes.join("\n")}
       return nodeLinks[nodeId] || (nodeLinks[nodeId] = new NodeLinks());
     }
     function isGlobalSourceFile(node) {
-      return node.kind === 311 /* SourceFile */ && !isExternalOrCommonJsModule(node);
+      return node.kind === 312 /* SourceFile */ && !isExternalOrCommonJsModule(node);
     }
     function getSymbol2(symbols, name, meaning) {
       if (meaning) {
@@ -145805,7 +129260,7 @@ ${lanes.join("\n")}
             return symbol;
           }
           if (symbol.flags & 2097152 /* Alias */) {
-            const targetFlags = getAllSymbolFlags(symbol);
+            const targetFlags = getSymbolFlags(symbol);
             if (targetFlags & meaning) {
               return symbol;
             }
@@ -145828,7 +129283,7 @@ ${lanes.join("\n")}
       const useFile = getSourceFileOfNode(usage);
       const declContainer = getEnclosingBlockScopeContainer(declaration);
       if (declarationFile !== useFile) {
-        if (moduleKind && (declarationFile.externalModuleIndicator || useFile.externalModuleIndicator) || !outFile(compilerOptions) || isInTypeQuery(usage) || declaration.flags & 16777216 /* Ambient */) {
+        if (moduleKind && (declarationFile.externalModuleIndicator || useFile.externalModuleIndicator) || !outFile(compilerOptions) || isInTypeQuery(usage) || declaration.flags & 33554432 /* Ambient */) {
           return true;
         }
         if (isUsedInFunctionOrInstanceProperty(usage, declaration)) {
@@ -145837,14 +129292,17 @@ ${lanes.join("\n")}
         const sourceFiles = host.getSourceFiles();
         return sourceFiles.indexOf(declarationFile) <= sourceFiles.indexOf(useFile);
       }
+      if (!!(usage.flags & 16777216 /* JSDoc */) || isInTypeQuery(usage) || isInAmbientOrTypeNode(usage)) {
+        return true;
+      }
       if (declaration.pos <= usage.pos && !(isPropertyDeclaration(declaration) && isThisProperty(usage.parent) && !declaration.initializer && !declaration.exclamationToken)) {
-        if (declaration.kind === 207 /* BindingElement */) {
-          const errorBindingElement = getAncestor(usage, 207 /* BindingElement */);
+        if (declaration.kind === 208 /* BindingElement */) {
+          const errorBindingElement = getAncestor(usage, 208 /* BindingElement */);
           if (errorBindingElement) {
             return findAncestor(errorBindingElement, isBindingElement) !== findAncestor(declaration, isBindingElement) || declaration.pos < errorBindingElement.pos;
           }
-          return isBlockScopedNameDeclaredBeforeUse(getAncestor(declaration, 259 /* VariableDeclaration */), usage);
-        } else if (declaration.kind === 259 /* VariableDeclaration */) {
+          return isBlockScopedNameDeclaredBeforeUse(getAncestor(declaration, 260 /* VariableDeclaration */), usage);
+        } else if (declaration.kind === 260 /* VariableDeclaration */) {
           return !isImmediatelyUsedInInitializerOfBlockScopedVariable(declaration, usage);
         } else if (isClassDeclaration(declaration)) {
           return !findAncestor(usage, (n) => isComputedPropertyName(n) && n.parent.parent === declaration);
@@ -145856,21 +129314,18 @@ ${lanes.join("\n")}
             false
           );
         } else if (isParameterPropertyDeclaration(declaration, declaration.parent)) {
-          return !(getEmitScriptTarget(compilerOptions) === 99 /* ESNext */ && useDefineForClassFields && getContainingClass(declaration) === getContainingClass(usage) && isUsedInFunctionOrInstanceProperty(usage, declaration));
+          return !(emitStandardClassFields && getContainingClass(declaration) === getContainingClass(usage) && isUsedInFunctionOrInstanceProperty(usage, declaration));
         }
         return true;
       }
-      if (usage.parent.kind === 280 /* ExportSpecifier */ || usage.parent.kind === 276 /* ExportAssignment */ && usage.parent.isExportEquals) {
+      if (usage.parent.kind === 281 /* ExportSpecifier */ || usage.parent.kind === 277 /* ExportAssignment */ && usage.parent.isExportEquals) {
         return true;
       }
-      if (usage.kind === 276 /* ExportAssignment */ && usage.isExportEquals) {
-        return true;
-      }
-      if (!!(usage.flags & 8388608 /* JSDoc */) || isInTypeQuery(usage) || isInAmbientOrTypeNode(usage)) {
+      if (usage.kind === 277 /* ExportAssignment */ && usage.isExportEquals) {
         return true;
       }
       if (isUsedInFunctionOrInstanceProperty(usage, declaration)) {
-        if (getEmitScriptTarget(compilerOptions) >= 9 /* ES2022 */ && useDefineForClassFields && getContainingClass(declaration) && (isPropertyDeclaration(declaration) || isParameterPropertyDeclaration(declaration, declaration.parent))) {
+        if (emitStandardClassFields && getContainingClass(declaration) && (isPropertyDeclaration(declaration) || isParameterPropertyDeclaration(declaration, declaration.parent))) {
           return !isPropertyImmediatelyReferencedWithinDeclaration(
             declaration,
             usage,
@@ -145884,9 +129339,9 @@ ${lanes.join("\n")}
       return false;
       function isImmediatelyUsedInInitializerOfBlockScopedVariable(declaration2, usage2) {
         switch (declaration2.parent.parent.kind) {
-          case 242 /* VariableStatement */:
-          case 247 /* ForStatement */:
-          case 249 /* ForOfStatement */:
+          case 243 /* VariableStatement */:
+          case 248 /* ForStatement */:
+          case 250 /* ForOfStatement */:
             if (isSameScopeDescendentOf(usage2, declaration2, declContainer)) {
               return true;
             }
@@ -145911,7 +129366,7 @@ ${lanes.join("\n")}
             const initializerOfProperty = propertyDeclaration.initializer === current;
             if (initializerOfProperty) {
               if (isStatic(current.parent)) {
-                if (declaration2.kind === 173 /* MethodDeclaration */) {
+                if (declaration2.kind === 174 /* MethodDeclaration */) {
                   return true;
                 }
                 if (isPropertyDeclaration(declaration2) && getContainingClass(usage2) === getContainingClass(declaration2)) {
@@ -145925,7 +129380,7 @@ ${lanes.join("\n")}
                   }
                 }
               } else {
-                const isDeclarationInstanceProperty = declaration2.kind === 171 /* PropertyDeclaration */ && !isStatic(declaration2);
+                const isDeclarationInstanceProperty = declaration2.kind === 172 /* PropertyDeclaration */ && !isStatic(declaration2);
                 if (!isDeclarationInstanceProperty || getContainingClass(usage2) !== getContainingClass(declaration2)) {
                   return true;
                 }
@@ -145944,15 +129399,15 @@ ${lanes.join("\n")}
             return "quit";
           }
           switch (node.kind) {
-            case 218 /* ArrowFunction */:
+            case 219 /* ArrowFunction */:
               return true;
-            case 171 /* PropertyDeclaration */:
+            case 172 /* PropertyDeclaration */:
               return stopAtAnyPropertyDeclaration && (isPropertyDeclaration(declaration2) && node.parent === declaration2.parent || isParameterPropertyDeclaration(declaration2, declaration2.parent) && node.parent === declaration2.parent.parent) ? "quit" : true;
-            case 240 /* Block */:
+            case 241 /* Block */:
               switch (node.parent.kind) {
-                case 176 /* GetAccessor */:
-                case 173 /* MethodDeclaration */:
-                case 177 /* SetAccessor */:
+                case 177 /* GetAccessor */:
+                case 174 /* MethodDeclaration */:
+                case 178 /* SetAccessor */:
                   return true;
                 default:
                   return false;
@@ -145982,19 +129437,19 @@ ${lanes.join("\n")}
       }
       function requiresScopeChangeWorker(node) {
         switch (node.kind) {
-          case 218 /* ArrowFunction */:
-          case 217 /* FunctionExpression */:
-          case 261 /* FunctionDeclaration */:
-          case 175 /* Constructor */:
+          case 219 /* ArrowFunction */:
+          case 218 /* FunctionExpression */:
+          case 262 /* FunctionDeclaration */:
+          case 176 /* Constructor */:
             return false;
-          case 173 /* MethodDeclaration */:
-          case 176 /* GetAccessor */:
-          case 177 /* SetAccessor */:
-          case 302 /* PropertyAssignment */:
+          case 174 /* MethodDeclaration */:
+          case 177 /* GetAccessor */:
+          case 178 /* SetAccessor */:
+          case 303 /* PropertyAssignment */:
             return requiresScopeChangeWorker(node.name);
-          case 171 /* PropertyDeclaration */:
+          case 172 /* PropertyDeclaration */:
             if (hasStaticModifier(node)) {
-              return target < 99 /* ESNext */ || !useDefineForClassFields;
+              return !emitStandardClassFields;
             }
             return requiresScopeChangeWorker(node.name);
           default:
@@ -146033,7 +129488,7 @@ ${lanes.join("\n")}
           if (name === "const" && isConstAssertion(location)) {
             return void 0;
           }
-          if (isModuleDeclaration(location) && lastLocation && location.name === lastLocation) {
+          if (isModuleOrEnumDeclaration(location) && lastLocation && location.name === lastLocation) {
             lastLocation = location;
             location = location.parent;
           }
@@ -146041,17 +129496,17 @@ ${lanes.join("\n")}
             if (result = lookup(location.locals, name, meaning)) {
               let useResult = true;
               if (isFunctionLike(location) && lastLocation && lastLocation !== location.body) {
-                if (meaning & result.flags & 788968 /* Type */ && lastLocation.kind !== 326 /* JSDoc */) {
-                  useResult = result.flags & 262144 /* TypeParameter */ ? lastLocation === location.type || lastLocation.kind === 168 /* Parameter */ || lastLocation.kind === 347 /* JSDocParameterTag */ || lastLocation.kind === 348 /* JSDocReturnTag */ || lastLocation.kind === 167 /* TypeParameter */ : false;
+                if (meaning & result.flags & 788968 /* Type */ && lastLocation.kind !== 327 /* JSDoc */) {
+                  useResult = result.flags & 262144 /* TypeParameter */ ? lastLocation === location.type || lastLocation.kind === 169 /* Parameter */ || lastLocation.kind === 348 /* JSDocParameterTag */ || lastLocation.kind === 349 /* JSDocReturnTag */ || lastLocation.kind === 168 /* TypeParameter */ : false;
                 }
                 if (meaning & result.flags & 3 /* Variable */) {
                   if (useOuterVariableScopeInParameter(result, location, lastLocation)) {
                     useResult = false;
                   } else if (result.flags & 1 /* FunctionScopedVariable */) {
-                    useResult = lastLocation.kind === 168 /* Parameter */ || lastLocation === location.type && !!findAncestor(result.valueDeclaration, isParameter);
+                    useResult = lastLocation.kind === 169 /* Parameter */ || lastLocation === location.type && !!findAncestor(result.valueDeclaration, isParameter);
                   }
                 }
-              } else if (location.kind === 193 /* ConditionalType */) {
+              } else if (location.kind === 194 /* ConditionalType */) {
                 useResult = lastLocation === location.trueType;
               }
               if (useResult) {
@@ -146063,13 +129518,13 @@ ${lanes.join("\n")}
           }
           withinDeferredContext = withinDeferredContext || getIsDeferredContext(location, lastLocation);
           switch (location.kind) {
-            case 311 /* SourceFile */:
+            case 312 /* SourceFile */:
               if (!isExternalOrCommonJsModule(location))
                 break;
               isInExternalModule = true;
-            case 266 /* ModuleDeclaration */:
+            case 267 /* ModuleDeclaration */:
               const moduleExports = ((_a = getSymbolOfDeclaration(location)) == null ? void 0 : _a.exports) || emptySymbols;
-              if (location.kind === 311 /* SourceFile */ || isModuleDeclaration(location) && location.flags & 16777216 /* Ambient */ && !isGlobalScopeAugmentation(location)) {
+              if (location.kind === 312 /* SourceFile */ || isModuleDeclaration(location) && location.flags & 33554432 /* Ambient */ && !isGlobalScopeAugmentation(location)) {
                 if (result = moduleExports.get("default" /* Default */)) {
                   const localSymbol = getLocalSymbolForExportDefault(result);
                   if (localSymbol && result.flags & meaning && localSymbol.escapedName === name) {
@@ -146078,7 +129533,7 @@ ${lanes.join("\n")}
                   result = void 0;
                 }
                 const moduleExport = moduleExports.get(name);
-                if (moduleExport && moduleExport.flags === 2097152 /* Alias */ && (getDeclarationOfKind(moduleExport, 280 /* ExportSpecifier */) || getDeclarationOfKind(moduleExport, 279 /* NamespaceExport */))) {
+                if (moduleExport && moduleExport.flags === 2097152 /* Alias */ && (getDeclarationOfKind(moduleExport, 281 /* ExportSpecifier */) || getDeclarationOfKind(moduleExport, 280 /* NamespaceExport */))) {
                   break;
                 }
               }
@@ -146090,10 +129545,10 @@ ${lanes.join("\n")}
                 }
               }
               break;
-            case 265 /* EnumDeclaration */:
+            case 266 /* EnumDeclaration */:
               if (result = lookup(((_c = getSymbolOfDeclaration(location)) == null ? void 0 : _c.exports) || emptySymbols, name, meaning & 8 /* EnumMember */)) {
-                if (nameNotFoundMessage && getIsolatedModules(compilerOptions) && !(location.flags & 16777216 /* Ambient */) && getSourceFileOfNode(location) !== getSourceFileOfNode(result.valueDeclaration)) {
-                  error(
+                if (nameNotFoundMessage && getIsolatedModules(compilerOptions) && !(location.flags & 33554432 /* Ambient */) && getSourceFileOfNode(location) !== getSourceFileOfNode(result.valueDeclaration)) {
+                  error2(
                     errorLocation,
                     Diagnostics.Cannot_access_0_from_another_file_without_qualification_when_1_is_enabled_Use_2_instead,
                     unescapeLeadingUnderscores(name),
@@ -146104,7 +129559,7 @@ ${lanes.join("\n")}
                 break loop;
               }
               break;
-            case 171 /* PropertyDeclaration */:
+            case 172 /* PropertyDeclaration */:
               if (!isStatic(location)) {
                 const ctor = findConstructorDeclaration(location.parent);
                 if (ctor && ctor.locals) {
@@ -146115,9 +129570,9 @@ ${lanes.join("\n")}
                 }
               }
               break;
-            case 262 /* ClassDeclaration */:
-            case 230 /* ClassExpression */:
-            case 263 /* InterfaceDeclaration */:
+            case 263 /* ClassDeclaration */:
+            case 231 /* ClassExpression */:
+            case 264 /* InterfaceDeclaration */:
               if (result = lookup(getSymbolOfDeclaration(location).members || emptySymbols, name, meaning & 788968 /* Type */)) {
                 if (!isTypeParameterSymbolDeclaredInContainer(result, location)) {
                   result = void 0;
@@ -146125,7 +129580,7 @@ ${lanes.join("\n")}
                 }
                 if (lastLocation && isStatic(lastLocation)) {
                   if (nameNotFoundMessage) {
-                    error(errorLocation, Diagnostics.Static_members_cannot_reference_class_type_parameters);
+                    error2(errorLocation, Diagnostics.Static_members_cannot_reference_class_type_parameters);
                   }
                   return void 0;
                 }
@@ -146139,43 +129594,43 @@ ${lanes.join("\n")}
                 }
               }
               break;
-            case 232 /* ExpressionWithTypeArguments */:
+            case 233 /* ExpressionWithTypeArguments */:
               if (lastLocation === location.expression && location.parent.token === 96 /* ExtendsKeyword */) {
                 const container = location.parent.parent;
                 if (isClassLike(container) && (result = lookup(getSymbolOfDeclaration(container).members, name, meaning & 788968 /* Type */))) {
                   if (nameNotFoundMessage) {
-                    error(errorLocation, Diagnostics.Base_class_expressions_cannot_reference_class_type_parameters);
+                    error2(errorLocation, Diagnostics.Base_class_expressions_cannot_reference_class_type_parameters);
                   }
                   return void 0;
                 }
               }
               break;
-            case 166 /* ComputedPropertyName */:
+            case 167 /* ComputedPropertyName */:
               grandparent = location.parent.parent;
-              if (isClassLike(grandparent) || grandparent.kind === 263 /* InterfaceDeclaration */) {
+              if (isClassLike(grandparent) || grandparent.kind === 264 /* InterfaceDeclaration */) {
                 if (result = lookup(getSymbolOfDeclaration(grandparent).members, name, meaning & 788968 /* Type */)) {
                   if (nameNotFoundMessage) {
-                    error(errorLocation, Diagnostics.A_computed_property_name_cannot_reference_a_type_parameter_from_its_containing_type);
+                    error2(errorLocation, Diagnostics.A_computed_property_name_cannot_reference_a_type_parameter_from_its_containing_type);
                   }
                   return void 0;
                 }
               }
               break;
-            case 218 /* ArrowFunction */:
+            case 219 /* ArrowFunction */:
               if (getEmitScriptTarget(compilerOptions) >= 2 /* ES2015 */) {
                 break;
               }
-            case 173 /* MethodDeclaration */:
-            case 175 /* Constructor */:
-            case 176 /* GetAccessor */:
-            case 177 /* SetAccessor */:
-            case 261 /* FunctionDeclaration */:
+            case 174 /* MethodDeclaration */:
+            case 176 /* Constructor */:
+            case 177 /* GetAccessor */:
+            case 178 /* SetAccessor */:
+            case 262 /* FunctionDeclaration */:
               if (meaning & 3 /* Variable */ && name === "arguments") {
                 result = argumentsSymbol;
                 break loop;
               }
               break;
-            case 217 /* FunctionExpression */:
+            case 218 /* FunctionExpression */:
               if (meaning & 3 /* Variable */ && name === "arguments") {
                 result = argumentsSymbol;
                 break loop;
@@ -146188,37 +129643,37 @@ ${lanes.join("\n")}
                 }
               }
               break;
-            case 169 /* Decorator */:
-              if (location.parent && location.parent.kind === 168 /* Parameter */) {
+            case 170 /* Decorator */:
+              if (location.parent && location.parent.kind === 169 /* Parameter */) {
                 location = location.parent;
               }
-              if (location.parent && (isClassElement(location.parent) || location.parent.kind === 262 /* ClassDeclaration */)) {
+              if (location.parent && (isClassElement(location.parent) || location.parent.kind === 263 /* ClassDeclaration */)) {
                 location = location.parent;
               }
               break;
-            case 352 /* JSDocTypedefTag */:
-            case 344 /* JSDocCallbackTag */:
-            case 346 /* JSDocEnumTag */:
+            case 353 /* JSDocTypedefTag */:
+            case 345 /* JSDocCallbackTag */:
+            case 347 /* JSDocEnumTag */:
               const root = getJSDocRoot(location);
               if (root) {
                 location = root.parent;
               }
               break;
-            case 168 /* Parameter */:
+            case 169 /* Parameter */:
               if (lastLocation && (lastLocation === location.initializer || lastLocation === location.name && isBindingPattern(lastLocation))) {
                 if (!associatedDeclarationForContainingInitializerOrBindingName) {
                   associatedDeclarationForContainingInitializerOrBindingName = location;
                 }
               }
               break;
-            case 207 /* BindingElement */:
+            case 208 /* BindingElement */:
               if (lastLocation && (lastLocation === location.initializer || lastLocation === location.name && isBindingPattern(lastLocation))) {
                 if (isParameterDeclaration(location) && !associatedDeclarationForContainingInitializerOrBindingName) {
                   associatedDeclarationForContainingInitializerOrBindingName = location;
                 }
               }
               break;
-            case 194 /* InferType */:
+            case 195 /* InferType */:
               if (meaning & 262144 /* TypeParameter */) {
                 const parameterName = location.typeParameter.name;
                 if (parameterName && name === parameterName.escapedText) {
@@ -146227,7 +129682,7 @@ ${lanes.join("\n")}
                 }
               }
               break;
-            case 280 /* ExportSpecifier */:
+            case 281 /* ExportSpecifier */:
               if (lastLocation && lastLocation === location.propertyName && location.parent.parent.moduleSpecifier) {
                 location = location.parent.parent.parent;
               }
@@ -146265,8 +129720,8 @@ ${lanes.join("\n")}
         }
       }
       function checkAndReportErrorForInvalidInitializer() {
-        if (propertyWithInvalidInitializer && !(useDefineForClassFields && getEmitScriptTarget(compilerOptions) >= 9 /* ES2022 */)) {
-          error(
+        if (propertyWithInvalidInitializer && !emitStandardClassFields) {
+          error2(
             errorLocation,
             errorLocation && propertyWithInvalidInitializer.type && textRangeContainsPositionInclusive(propertyWithInvalidInitializer.type, errorLocation.pos) ? Diagnostics.Type_of_instance_member_variable_0_cannot_reference_identifier_1_declared_in_the_constructor : Diagnostics.Initializer_of_instance_member_variable_0_cannot_reference_identifier_1_declared_in_the_constructor,
             declarationNameToString(propertyWithInvalidInitializer.name),
@@ -146279,14 +129734,14 @@ ${lanes.join("\n")}
       if (!result) {
         if (nameNotFoundMessage) {
           addLazyDiagnostic(() => {
-            if (!errorLocation || errorLocation.parent.kind !== 330 /* JSDocLink */ && !checkAndReportErrorForMissingPrefix(errorLocation, name, nameArg) && // TODO: GH#18217
+            if (!errorLocation || errorLocation.parent.kind !== 331 /* JSDocLink */ && !checkAndReportErrorForMissingPrefix(errorLocation, name, nameArg) && // TODO: GH#18217
             !checkAndReportErrorForInvalidInitializer() && !checkAndReportErrorForExtendingInterface(errorLocation) && !checkAndReportErrorForUsingTypeAsNamespace(errorLocation, name, meaning) && !checkAndReportErrorForExportingPrimitiveType(errorLocation, name) && !checkAndReportErrorForUsingNamespaceAsTypeOrValue(errorLocation, name, meaning) && !checkAndReportErrorForUsingTypeAsValue(errorLocation, name, meaning) && !checkAndReportErrorForUsingValueAsType(errorLocation, name, meaning)) {
               let suggestion;
               let suggestedLib;
               if (nameArg) {
                 suggestedLib = getSuggestedLibForNonExistentName(nameArg);
                 if (suggestedLib) {
-                  error(errorLocation, nameNotFoundMessage, diagnosticName(nameArg), suggestedLib);
+                  error2(errorLocation, nameNotFoundMessage, diagnosticName(nameArg), suggestedLib);
                 }
               }
               if (!suggestedLib && getSpellingSuggestions && suggestionCount < maximumSuggestionCount) {
@@ -146315,7 +129770,7 @@ ${lanes.join("\n")}
                 }
               }
               if (!suggestion && !suggestedLib && nameArg) {
-                error(errorLocation, nameNotFoundMessage, diagnosticName(nameArg));
+                error2(errorLocation, nameNotFoundMessage, diagnosticName(nameArg));
               }
               suggestionCount++;
             }
@@ -146333,7 +129788,7 @@ ${lanes.join("\n")}
               checkResolvedBlockScopedVariable(exportOrLocalSymbol, errorLocation);
             }
           }
-          if (result && isInExternalModule && (meaning & 111551 /* Value */) === 111551 /* Value */ && !(originalLocation.flags & 8388608 /* JSDoc */)) {
+          if (result && isInExternalModule && (meaning & 111551 /* Value */) === 111551 /* Value */ && !(originalLocation.flags & 16777216 /* JSDoc */)) {
             const merged = getMergedSymbol(result);
             if (length(merged.declarations) && every(merged.declarations, (d) => isNamespaceExportDeclaration(d) || isSourceFile(d) && !!d.symbol.globalExports)) {
               errorOrSuggestion(!compilerOptions.allowUmdGlobalAccess, errorLocation, Diagnostics._0_refers_to_a_UMD_global_but_the_current_file_is_a_module_Consider_adding_an_import_instead, unescapeLeadingUnderscores(name));
@@ -146343,18 +129798,18 @@ ${lanes.join("\n")}
             const candidate = getMergedSymbol(getLateBoundSymbol(result));
             const root = getRootDeclaration(associatedDeclarationForContainingInitializerOrBindingName);
             if (candidate === getSymbolOfDeclaration(associatedDeclarationForContainingInitializerOrBindingName)) {
-              error(errorLocation, Diagnostics.Parameter_0_cannot_reference_itself, declarationNameToString(associatedDeclarationForContainingInitializerOrBindingName.name));
+              error2(errorLocation, Diagnostics.Parameter_0_cannot_reference_itself, declarationNameToString(associatedDeclarationForContainingInitializerOrBindingName.name));
             } else if (candidate.valueDeclaration && candidate.valueDeclaration.pos > associatedDeclarationForContainingInitializerOrBindingName.pos && root.parent.locals && lookup(root.parent.locals, candidate.escapedName, meaning) === candidate) {
-              error(errorLocation, Diagnostics.Parameter_0_cannot_reference_identifier_1_declared_after_it, declarationNameToString(associatedDeclarationForContainingInitializerOrBindingName.name), declarationNameToString(errorLocation));
+              error2(errorLocation, Diagnostics.Parameter_0_cannot_reference_identifier_1_declared_after_it, declarationNameToString(associatedDeclarationForContainingInitializerOrBindingName.name), declarationNameToString(errorLocation));
             }
           }
           if (result && errorLocation && meaning & 111551 /* Value */ && result.flags & 2097152 /* Alias */ && !(result.flags & 111551 /* Value */) && !isValidTypeOnlyAliasUseSite(errorLocation)) {
             const typeOnlyDeclaration = getTypeOnlyAliasDeclaration(result, 111551 /* Value */);
             if (typeOnlyDeclaration) {
-              const message = typeOnlyDeclaration.kind === 280 /* ExportSpecifier */ || typeOnlyDeclaration.kind === 277 /* ExportDeclaration */ || typeOnlyDeclaration.kind === 279 /* NamespaceExport */ ? Diagnostics._0_cannot_be_used_as_a_value_because_it_was_exported_using_export_type : Diagnostics._0_cannot_be_used_as_a_value_because_it_was_imported_using_import_type;
+              const message = typeOnlyDeclaration.kind === 281 /* ExportSpecifier */ || typeOnlyDeclaration.kind === 278 /* ExportDeclaration */ || typeOnlyDeclaration.kind === 280 /* NamespaceExport */ ? Diagnostics._0_cannot_be_used_as_a_value_because_it_was_exported_using_export_type : Diagnostics._0_cannot_be_used_as_a_value_because_it_was_imported_using_import_type;
               const unescapedName = unescapeLeadingUnderscores(name);
               addTypeOnlyDeclarationRelatedInfo(
-                error(errorLocation, message, unescapedName),
+                error2(errorLocation, message, unescapedName),
                 typeOnlyDeclaration,
                 unescapedName
               );
@@ -146371,31 +129826,31 @@ ${lanes.join("\n")}
         diagnostic,
         createDiagnosticForNode(
           typeOnlyDeclaration,
-          typeOnlyDeclaration.kind === 280 /* ExportSpecifier */ || typeOnlyDeclaration.kind === 277 /* ExportDeclaration */ || typeOnlyDeclaration.kind === 279 /* NamespaceExport */ ? Diagnostics._0_was_exported_here : Diagnostics._0_was_imported_here,
+          typeOnlyDeclaration.kind === 281 /* ExportSpecifier */ || typeOnlyDeclaration.kind === 278 /* ExportDeclaration */ || typeOnlyDeclaration.kind === 280 /* NamespaceExport */ ? Diagnostics._0_was_exported_here : Diagnostics._0_was_imported_here,
           unescapedName
         )
       );
     }
     function getIsDeferredContext(location, lastLocation) {
-      if (location.kind !== 218 /* ArrowFunction */ && location.kind !== 217 /* FunctionExpression */) {
-        return isTypeQueryNode(location) || (isFunctionLikeDeclaration(location) || location.kind === 171 /* PropertyDeclaration */ && !isStatic(location)) && (!lastLocation || lastLocation !== location.name);
+      if (location.kind !== 219 /* ArrowFunction */ && location.kind !== 218 /* FunctionExpression */) {
+        return isTypeQueryNode(location) || (isFunctionLikeDeclaration(location) || location.kind === 172 /* PropertyDeclaration */ && !isStatic(location)) && (!lastLocation || lastLocation !== location.name);
       }
       if (lastLocation && lastLocation === location.name) {
         return false;
       }
-      if (location.asteriskToken || hasSyntacticModifier(location, 512 /* Async */)) {
+      if (location.asteriskToken || hasSyntacticModifier(location, 1024 /* Async */)) {
         return true;
       }
       return !getImmediatelyInvokedFunctionExpression(location);
     }
     function isSelfReferenceLocation(node) {
       switch (node.kind) {
-        case 261 /* FunctionDeclaration */:
-        case 262 /* ClassDeclaration */:
-        case 263 /* InterfaceDeclaration */:
-        case 265 /* EnumDeclaration */:
-        case 264 /* TypeAliasDeclaration */:
-        case 266 /* ModuleDeclaration */:
+        case 262 /* FunctionDeclaration */:
+        case 263 /* ClassDeclaration */:
+        case 264 /* InterfaceDeclaration */:
+        case 266 /* EnumDeclaration */:
+        case 265 /* TypeAliasDeclaration */:
+        case 267 /* ModuleDeclaration */:
           return true;
         default:
           return false;
@@ -146407,7 +129862,7 @@ ${lanes.join("\n")}
     function isTypeParameterSymbolDeclaredInContainer(symbol, container) {
       if (symbol.declarations) {
         for (const decl of symbol.declarations) {
-          if (decl.kind === 167 /* TypeParameter */) {
+          if (decl.kind === 168 /* TypeParameter */) {
             const parent2 = isJSDocTemplateTag(decl.parent) ? getJSDocHost(decl.parent) : decl.parent;
             if (parent2 === container) {
               return !(isJSDocTemplateTag(decl.parent) && find(decl.parent.parent.tags, isJSDocTypeAlias));
@@ -146437,13 +129892,13 @@ ${lanes.join("\n")}
           }
           const constructorType = getTypeOfSymbol(classSymbol);
           if (getPropertyOfType(constructorType, name)) {
-            error(errorLocation, Diagnostics.Cannot_find_name_0_Did_you_mean_the_static_member_1_0, diagnosticName(nameArg), symbolToString(classSymbol));
+            error2(errorLocation, Diagnostics.Cannot_find_name_0_Did_you_mean_the_static_member_1_0, diagnosticName(nameArg), symbolToString(classSymbol));
             return true;
           }
           if (location === container && !isStatic(location)) {
             const instanceType = getDeclaredTypeOfSymbol(classSymbol).thisType;
             if (getPropertyOfType(instanceType, name)) {
-              error(errorLocation, Diagnostics.Cannot_find_name_0_Did_you_mean_the_instance_member_this_0, diagnosticName(nameArg));
+              error2(errorLocation, Diagnostics.Cannot_find_name_0_Did_you_mean_the_instance_member_this_0, diagnosticName(nameArg));
               return true;
             }
           }
@@ -146460,7 +129915,7 @@ ${lanes.join("\n")}
         /*ignoreErrors*/
         true
       )) {
-        error(errorLocation, Diagnostics.Cannot_extend_an_interface_0_Did_you_mean_implements, getTextOfNode(expression));
+        error2(errorLocation, Diagnostics.Cannot_extend_an_interface_0_Did_you_mean_implements, getTextOfNode(expression));
         return true;
       }
       return false;
@@ -146468,9 +129923,9 @@ ${lanes.join("\n")}
     function getEntityNameForExtendingInterface(node) {
       switch (node.kind) {
         case 80 /* Identifier */:
-        case 210 /* PropertyAccessExpression */:
+        case 211 /* PropertyAccessExpression */:
           return node.parent ? getEntityNameForExtendingInterface(node.parent) : void 0;
-        case 232 /* ExpressionWithTypeArguments */:
+        case 233 /* ExpressionWithTypeArguments */:
           if (isEntityNameExpression(node.expression)) {
             return node.expression;
           }
@@ -146499,7 +129954,7 @@ ${lanes.join("\n")}
             const propName = parent2.right.escapedText;
             const propType = getPropertyOfType(getDeclaredTypeOfSymbol(symbol), propName);
             if (propType) {
-              error(
+              error2(
                 parent2,
                 Diagnostics.Cannot_access_0_1_because_0_is_a_type_but_not_a_namespace_Did_you_mean_to_retrieve_the_type_of_the_property_1_in_0_with_0_1,
                 unescapeLeadingUnderscores(name),
@@ -146508,7 +129963,7 @@ ${lanes.join("\n")}
               return true;
             }
           }
-          error(errorLocation, Diagnostics._0_only_refers_to_a_type_but_is_being_used_as_a_namespace_here, unescapeLeadingUnderscores(name));
+          error2(errorLocation, Diagnostics._0_only_refers_to_a_type_but_is_being_used_as_a_namespace_here, unescapeLeadingUnderscores(name));
           return true;
         }
       }
@@ -146528,7 +129983,7 @@ ${lanes.join("\n")}
           false
         ));
         if (symbol && !(symbol.flags & 1920 /* Namespace */)) {
-          error(errorLocation, Diagnostics._0_refers_to_a_value_but_is_being_used_as_a_type_here_Did_you_mean_typeof_0, unescapeLeadingUnderscores(name));
+          error2(errorLocation, Diagnostics._0_refers_to_a_value_but_is_being_used_as_a_type_here_Did_you_mean_typeof_0, unescapeLeadingUnderscores(name));
           return true;
         }
       }
@@ -146538,8 +129993,8 @@ ${lanes.join("\n")}
       return name === "any" || name === "string" || name === "number" || name === "boolean" || name === "never" || name === "unknown";
     }
     function checkAndReportErrorForExportingPrimitiveType(errorLocation, name) {
-      if (isPrimitiveTypeName(name) && errorLocation.parent.kind === 280 /* ExportSpecifier */) {
-        error(errorLocation, Diagnostics.Cannot_export_0_Only_local_declarations_can_be_exported_from_a_module, name);
+      if (isPrimitiveTypeName(name) && errorLocation.parent.kind === 281 /* ExportSpecifier */) {
+        error2(errorLocation, Diagnostics.Cannot_export_0_Only_local_declarations_can_be_exported_from_a_module, name);
         return true;
       }
       return false;
@@ -146547,10 +130002,19 @@ ${lanes.join("\n")}
     function checkAndReportErrorForUsingTypeAsValue(errorLocation, name, meaning) {
       if (meaning & 111551 /* Value */) {
         if (isPrimitiveTypeName(name)) {
-          if (isExtendedByInterface(errorLocation)) {
-            error(errorLocation, Diagnostics.An_interface_cannot_extend_a_primitive_type_like_0_an_interface_can_only_extend_named_types_and_classes, unescapeLeadingUnderscores(name));
+          const grandparent = errorLocation.parent.parent;
+          if (grandparent && grandparent.parent && isHeritageClause(grandparent)) {
+            const heritageKind = grandparent.token;
+            const containerKind = grandparent.parent.kind;
+            if (containerKind === 264 /* InterfaceDeclaration */ && heritageKind === 96 /* ExtendsKeyword */) {
+              error2(errorLocation, Diagnostics.An_interface_cannot_extend_a_primitive_type_like_0_It_can_only_extend_other_named_object_types, unescapeLeadingUnderscores(name));
+            } else if (containerKind === 263 /* ClassDeclaration */ && heritageKind === 96 /* ExtendsKeyword */) {
+              error2(errorLocation, Diagnostics.A_class_cannot_extend_a_primitive_type_like_0_Classes_can_only_extend_constructable_values, unescapeLeadingUnderscores(name));
+            } else if (containerKind === 263 /* ClassDeclaration */ && heritageKind === 119 /* ImplementsKeyword */) {
+              error2(errorLocation, Diagnostics.A_class_cannot_implement_a_primitive_type_like_0_It_can_only_implement_other_named_object_types, unescapeLeadingUnderscores(name));
+            }
           } else {
-            error(errorLocation, Diagnostics._0_only_refers_to_a_type_but_is_being_used_as_a_value_here, unescapeLeadingUnderscores(name));
+            error2(errorLocation, Diagnostics._0_only_refers_to_a_type_but_is_being_used_as_a_value_here, unescapeLeadingUnderscores(name));
           }
           return true;
         }
@@ -146565,31 +130029,21 @@ ${lanes.join("\n")}
           /*isUse*/
           false
         ));
-        const allFlags = symbol && getAllSymbolFlags(symbol);
+        const allFlags = symbol && getSymbolFlags(symbol);
         if (symbol && allFlags !== void 0 && !(allFlags & 111551 /* Value */)) {
           const rawName = unescapeLeadingUnderscores(name);
           if (isES2015OrLaterConstructorName(name)) {
-            error(errorLocation, Diagnostics._0_only_refers_to_a_type_but_is_being_used_as_a_value_here_Do_you_need_to_change_your_target_library_Try_changing_the_lib_compiler_option_to_es2015_or_later, rawName);
+            error2(errorLocation, Diagnostics._0_only_refers_to_a_type_but_is_being_used_as_a_value_here_Do_you_need_to_change_your_target_library_Try_changing_the_lib_compiler_option_to_es2015_or_later, rawName);
           } else if (maybeMappedType(errorLocation, symbol)) {
-            error(errorLocation, Diagnostics._0_only_refers_to_a_type_but_is_being_used_as_a_value_here_Did_you_mean_to_use_1_in_0, rawName, rawName === "K" ? "P" : "K");
+            error2(errorLocation, Diagnostics._0_only_refers_to_a_type_but_is_being_used_as_a_value_here_Did_you_mean_to_use_1_in_0, rawName, rawName === "K" ? "P" : "K");
           } else {
-            error(errorLocation, Diagnostics._0_only_refers_to_a_type_but_is_being_used_as_a_value_here, rawName);
+            error2(errorLocation, Diagnostics._0_only_refers_to_a_type_but_is_being_used_as_a_value_here, rawName);
           }
           return true;
         }
       }
       return false;
     }
-    function isExtendedByInterface(node) {
-      const grandparent = node.parent.parent;
-      const parentOfGrandparent = grandparent.parent;
-      if (grandparent && parentOfGrandparent) {
-        const isExtending = isHeritageClause(grandparent) && grandparent.token === 96 /* ExtendsKeyword */;
-        const isInterface = isInterfaceDeclaration(parentOfGrandparent);
-        return isExtending && isInterface;
-      }
-      return false;
-    }
     function maybeMappedType(node, symbol) {
       const container = findAncestor(node.parent, (n) => isComputedPropertyName(n) || isPropertySignature(n) ? false : isTypeLiteralNode(n) || "quit");
       if (container && container.members.length === 1) {
@@ -146629,7 +130083,7 @@ ${lanes.join("\n")}
           false
         ));
         if (symbol) {
-          error(
+          error2(
             errorLocation,
             Diagnostics.Cannot_use_namespace_0_as_a_value,
             unescapeLeadingUnderscores(name)
@@ -146649,7 +130103,7 @@ ${lanes.join("\n")}
           false
         ));
         if (symbol) {
-          error(errorLocation, Diagnostics.Cannot_use_namespace_0_as_a_type, unescapeLeadingUnderscores(name));
+          error2(errorLocation, Diagnostics.Cannot_use_namespace_0_as_a_type, unescapeLeadingUnderscores(name));
           return true;
         }
       }
@@ -146662,40 +130116,37 @@ ${lanes.join("\n")}
         return;
       }
       const declaration = (_a = result.declarations) == null ? void 0 : _a.find(
-        (d) => isBlockOrCatchScoped(d) || isClassLike(d) || d.kind === 265 /* EnumDeclaration */
+        (d) => isBlockOrCatchScoped(d) || isClassLike(d) || d.kind === 266 /* EnumDeclaration */
       );
       if (declaration === void 0)
         return Debug.fail("checkResolvedBlockScopedVariable could not find block-scoped declaration");
-      if (!(declaration.flags & 16777216 /* Ambient */) && !isBlockScopedNameDeclaredBeforeUse(declaration, errorLocation)) {
+      if (!(declaration.flags & 33554432 /* Ambient */) && !isBlockScopedNameDeclaredBeforeUse(declaration, errorLocation)) {
         let diagnosticMessage;
         const declarationName = declarationNameToString(getNameOfDeclaration(declaration));
         if (result.flags & 2 /* BlockScopedVariable */) {
-          diagnosticMessage = error(errorLocation, Diagnostics.Block_scoped_variable_0_used_before_its_declaration, declarationName);
+          diagnosticMessage = error2(errorLocation, Diagnostics.Block_scoped_variable_0_used_before_its_declaration, declarationName);
         } else if (result.flags & 32 /* Class */) {
-          diagnosticMessage = error(errorLocation, Diagnostics.Class_0_used_before_its_declaration, declarationName);
+          diagnosticMessage = error2(errorLocation, Diagnostics.Class_0_used_before_its_declaration, declarationName);
         } else if (result.flags & 256 /* RegularEnum */) {
-          diagnosticMessage = error(errorLocation, Diagnostics.Enum_0_used_before_its_declaration, declarationName);
+          diagnosticMessage = error2(errorLocation, Diagnostics.Enum_0_used_before_its_declaration, declarationName);
         }
         if (diagnosticMessage) {
-          addRelatedInfo(
-            diagnosticMessage,
-            createDiagnosticForNode(declaration, Diagnostics._0_is_declared_here, declarationName)
-          );
+          addRelatedInfo(diagnosticMessage, createDiagnosticForNode(declaration, Diagnostics._0_is_declared_here, declarationName));
         }
       }
     }
     function isSameScopeDescendentOf(initial, parent2, stopAt) {
-      return !!parent2 && !!findAncestor(initial, (n) => n === parent2 || (n === stopAt || isFunctionLike(n) && (!getImmediatelyInvokedFunctionExpression(n) || isAsyncFunction(n)) ? "quit" : false));
+      return !!parent2 && !!findAncestor(initial, (n) => n === parent2 || (n === stopAt || isFunctionLike(n) && (!getImmediatelyInvokedFunctionExpression(n) || getFunctionFlags(n) & 3 /* AsyncGenerator */) ? "quit" : false));
     }
     function getAnyImportSyntax(node) {
       switch (node.kind) {
-        case 270 /* ImportEqualsDeclaration */:
+        case 271 /* ImportEqualsDeclaration */:
           return node;
-        case 272 /* ImportClause */:
+        case 273 /* ImportClause */:
           return node.parent;
-        case 273 /* NamespaceImport */:
+        case 274 /* NamespaceImport */:
           return node.parent.parent;
-        case 275 /* ImportSpecifier */:
+        case 276 /* ImportSpecifier */:
           return node.parent.parent.parent;
         default:
           return void 0;
@@ -146705,7 +130156,7 @@ ${lanes.join("\n")}
       return symbol.declarations && findLast(symbol.declarations, isAliasSymbolDeclaration2);
     }
     function isAliasSymbolDeclaration2(node) {
-      return node.kind === 270 /* ImportEqualsDeclaration */ || node.kind === 269 /* NamespaceExportDeclaration */ || node.kind === 272 /* ImportClause */ && !!node.name || node.kind === 273 /* NamespaceImport */ || node.kind === 279 /* NamespaceExport */ || node.kind === 275 /* ImportSpecifier */ || node.kind === 280 /* ExportSpecifier */ || node.kind === 276 /* ExportAssignment */ && exportAssignmentIsAlias(node) || isBinaryExpression(node) && getAssignmentDeclarationKind(node) === 2 /* ModuleExports */ && exportAssignmentIsAlias(node) || isAccessExpression(node) && isBinaryExpression(node.parent) && node.parent.left === node && node.parent.operatorToken.kind === 64 /* EqualsToken */ && isAliasableOrJsExpression(node.parent.right) || node.kind === 303 /* ShorthandPropertyAssignment */ || node.kind === 302 /* PropertyAssignment */ && isAliasableOrJsExpression(node.initializer) || node.kind === 259 /* VariableDeclaration */ && isVariableDeclarationInitializedToBareOrAccessedRequire(node) || node.kind === 207 /* BindingElement */ && isVariableDeclarationInitializedToBareOrAccessedRequire(node.parent.parent);
+      return node.kind === 271 /* ImportEqualsDeclaration */ || node.kind === 270 /* NamespaceExportDeclaration */ || node.kind === 273 /* ImportClause */ && !!node.name || node.kind === 274 /* NamespaceImport */ || node.kind === 280 /* NamespaceExport */ || node.kind === 276 /* ImportSpecifier */ || node.kind === 281 /* ExportSpecifier */ || node.kind === 277 /* ExportAssignment */ && exportAssignmentIsAlias(node) || isBinaryExpression(node) && getAssignmentDeclarationKind(node) === 2 /* ModuleExports */ && exportAssignmentIsAlias(node) || isAccessExpression(node) && isBinaryExpression(node.parent) && node.parent.left === node && node.parent.operatorToken.kind === 64 /* EqualsToken */ && isAliasableOrJsExpression(node.parent.right) || node.kind === 304 /* ShorthandPropertyAssignment */ || node.kind === 303 /* PropertyAssignment */ && isAliasableOrJsExpression(node.initializer) || node.kind === 260 /* VariableDeclaration */ && isVariableDeclarationInitializedToBareOrAccessedRequire(node) || node.kind === 208 /* BindingElement */ && isVariableDeclarationInitializedToBareOrAccessedRequire(node.parent.parent);
     }
     function isAliasableOrJsExpression(e) {
       return isAliasableExpression(e) || isFunctionExpression(e) && isJSConstructor(e);
@@ -146716,7 +130167,7 @@ ${lanes.join("\n")}
         const name = getLeftmostAccessExpression(commonJSPropertyAccess.expression).arguments[0];
         return isIdentifier(commonJSPropertyAccess.name) ? resolveSymbol(getPropertyOfType(resolveExternalModuleTypeByLiteral(name), commonJSPropertyAccess.name.escapedText)) : void 0;
       }
-      if (isVariableDeclaration(node) || node.moduleReference.kind === 282 /* ExternalModuleReference */) {
+      if (isVariableDeclaration(node) || node.moduleReference.kind === 283 /* ExternalModuleReference */) {
         const immediate = resolveExternalModuleName(
           node,
           getExternalModuleRequireArgument(node) || getExternalModuleImportEqualsDeclarationExpression(node)
@@ -146745,11 +130196,11 @@ ${lanes.join("\n")}
         false
       ) && !node.isTypeOnly) {
         const typeOnlyDeclaration = getTypeOnlyAliasDeclaration(getSymbolOfDeclaration(node));
-        const isExport = typeOnlyDeclaration.kind === 280 /* ExportSpecifier */ || typeOnlyDeclaration.kind === 277 /* ExportDeclaration */;
+        const isExport = typeOnlyDeclaration.kind === 281 /* ExportSpecifier */ || typeOnlyDeclaration.kind === 278 /* ExportDeclaration */;
         const message = isExport ? Diagnostics.An_import_alias_cannot_reference_a_declaration_that_was_exported_using_export_type : Diagnostics.An_import_alias_cannot_reference_a_declaration_that_was_imported_using_import_type;
         const relatedMessage = isExport ? Diagnostics._0_was_exported_here : Diagnostics._0_was_imported_here;
-        const name = typeOnlyDeclaration.kind === 277 /* ExportDeclaration */ ? "*" : unescapeLeadingUnderscores(typeOnlyDeclaration.name.escapedText);
-        addRelatedInfo(error(node.moduleReference, message), createDiagnosticForNode(typeOnlyDeclaration, relatedMessage, name));
+        const name = typeOnlyDeclaration.kind === 278 /* ExportDeclaration */ ? "*" : unescapeLeadingUnderscores(typeOnlyDeclaration.name.escapedText);
+        addRelatedInfo(error2(node.moduleReference, message), createDiagnosticForNode(typeOnlyDeclaration, relatedMessage, name));
       }
     }
     function resolveExportByName(moduleSymbol, name, sourceNode, dontResolveAlias) {
@@ -146771,7 +130222,7 @@ ${lanes.join("\n")}
       return resolved;
     }
     function isSyntacticDefault(node) {
-      return isExportAssignment(node) && !node.isExportEquals || hasSyntacticModifier(node, 1024 /* Default */) || isExportSpecifier(node);
+      return isExportAssignment(node) && !node.isExportEquals || hasSyntacticModifier(node, 2048 /* Default */) || isExportSpecifier(node) || isNamespaceExport(node);
     }
     function getUsageModeForExpression(usage) {
       return isStringLiteralLike(usage) ? getModeForUsageLocation(getSourceFileOfNode(usage), usage) : void 0;
@@ -146854,13 +130305,16 @@ ${lanes.join("\n")}
           const compilerOptionName = moduleKind >= 5 /* ES2015 */ ? "allowSyntheticDefaultImports" : "esModuleInterop";
           const exportEqualsSymbol = moduleSymbol.exports.get("export=" /* ExportEquals */);
           const exportAssignment = exportEqualsSymbol.valueDeclaration;
-          const err = error(node.name, Diagnostics.Module_0_can_only_be_default_imported_using_the_1_flag, symbolToString(moduleSymbol), compilerOptionName);
+          const err = error2(node.name, Diagnostics.Module_0_can_only_be_default_imported_using_the_1_flag, symbolToString(moduleSymbol), compilerOptionName);
           if (exportAssignment) {
-            addRelatedInfo(err, createDiagnosticForNode(
-              exportAssignment,
-              Diagnostics.This_module_is_declared_with_export_and_can_only_be_used_with_a_default_import_when_using_the_0_flag,
-              compilerOptionName
-            ));
+            addRelatedInfo(
+              err,
+              createDiagnosticForNode(
+                exportAssignment,
+                Diagnostics.This_module_is_declared_with_export_and_can_only_be_used_with_a_default_import_when_using_the_0_flag,
+                compilerOptionName
+              )
+            );
           }
         } else if (isImportClause(node)) {
           reportNonDefaultExport(moduleSymbol, node);
@@ -146890,15 +130344,15 @@ ${lanes.join("\n")}
     }
     function getModuleSpecifierForImportOrExport(node) {
       switch (node.kind) {
-        case 272 /* ImportClause */:
+        case 273 /* ImportClause */:
           return node.parent.moduleSpecifier;
-        case 270 /* ImportEqualsDeclaration */:
+        case 271 /* ImportEqualsDeclaration */:
           return isExternalModuleReference(node.moduleReference) ? node.moduleReference.expression : void 0;
-        case 273 /* NamespaceImport */:
+        case 274 /* NamespaceImport */:
           return node.parent.parent.moduleSpecifier;
-        case 275 /* ImportSpecifier */:
+        case 276 /* ImportSpecifier */:
           return node.parent.parent.parent.moduleSpecifier;
-        case 280 /* ExportSpecifier */:
+        case 281 /* ExportSpecifier */:
           return node.parent.parent.moduleSpecifier;
         default:
           return Debug.assertNever(node);
@@ -146907,20 +130361,22 @@ ${lanes.join("\n")}
     function reportNonDefaultExport(moduleSymbol, node) {
       var _a, _b, _c;
       if ((_a = moduleSymbol.exports) == null ? void 0 : _a.has(node.symbol.escapedName)) {
-        error(
+        error2(
           node.name,
           Diagnostics.Module_0_has_no_default_export_Did_you_mean_to_use_import_1_from_0_instead,
           symbolToString(moduleSymbol),
           symbolToString(node.symbol)
         );
       } else {
-        const diagnostic = error(node.name, Diagnostics.Module_0_has_no_default_export, symbolToString(moduleSymbol));
+        const diagnostic = error2(node.name, Diagnostics.Module_0_has_no_default_export, symbolToString(moduleSymbol));
         const exportStar = (_b = moduleSymbol.exports) == null ? void 0 : _b.get("__export" /* ExportStar */);
         if (exportStar) {
-          const defaultExport = (_c = exportStar.declarations) == null ? void 0 : _c.find((decl) => {
-            var _a2, _b2;
-            return !!(isExportDeclaration(decl) && decl.moduleSpecifier && ((_b2 = (_a2 = resolveExternalModuleName(decl, decl.moduleSpecifier)) == null ? void 0 : _a2.exports) == null ? void 0 : _b2.has("default" /* Default */)));
-          });
+          const defaultExport = (_c = exportStar.declarations) == null ? void 0 : _c.find(
+            (decl) => {
+              var _a2, _b2;
+              return !!(isExportDeclaration(decl) && decl.moduleSpecifier && ((_b2 = (_a2 = resolveExternalModuleName(decl, decl.moduleSpecifier)) == null ? void 0 : _a2.exports) == null ? void 0 : _b2.has("default" /* Default */)));
+            }
+          );
           if (defaultExport) {
             addRelatedInfo(diagnostic, createDiagnosticForNode(defaultExport, Diagnostics.export_Asterisk_does_not_re_export_a_default));
           }
@@ -147065,16 +130521,13 @@ ${lanes.join("\n")}
       const suggestion = getSuggestedSymbolForNonexistentModule(name, targetSymbol);
       if (suggestion !== void 0) {
         const suggestionName = symbolToString(suggestion);
-        const diagnostic = error(name, Diagnostics._0_has_no_exported_member_named_1_Did_you_mean_2, moduleName, declarationName, suggestionName);
+        const diagnostic = error2(name, Diagnostics._0_has_no_exported_member_named_1_Did_you_mean_2, moduleName, declarationName, suggestionName);
         if (suggestion.valueDeclaration) {
-          addRelatedInfo(
-            diagnostic,
-            createDiagnosticForNode(suggestion.valueDeclaration, Diagnostics._0_is_declared_here, suggestionName)
-          );
+          addRelatedInfo(diagnostic, createDiagnosticForNode(suggestion.valueDeclaration, Diagnostics._0_is_declared_here, suggestionName));
         }
       } else {
         if ((_a = moduleSymbol.exports) == null ? void 0 : _a.has("default" /* Default */)) {
-          error(
+          error2(
             name,
             Diagnostics.Module_0_has_no_exported_member_1_Did_you_mean_to_use_import_1_from_0_instead,
             moduleName,
@@ -147092,32 +130545,29 @@ ${lanes.join("\n")}
       if (localSymbol) {
         const exportedEqualsSymbol = exports == null ? void 0 : exports.get("export=" /* ExportEquals */);
         if (exportedEqualsSymbol) {
-          getSymbolIfSameReference(exportedEqualsSymbol, localSymbol) ? reportInvalidImportEqualsExportMember(node, name, declarationName, moduleName) : error(name, Diagnostics.Module_0_has_no_exported_member_1, moduleName, declarationName);
+          getSymbolIfSameReference(exportedEqualsSymbol, localSymbol) ? reportInvalidImportEqualsExportMember(node, name, declarationName, moduleName) : error2(name, Diagnostics.Module_0_has_no_exported_member_1, moduleName, declarationName);
         } else {
           const exportedSymbol = exports ? find(symbolsToArray(exports), (symbol) => !!getSymbolIfSameReference(symbol, localSymbol)) : void 0;
-          const diagnostic = exportedSymbol ? error(name, Diagnostics.Module_0_declares_1_locally_but_it_is_exported_as_2, moduleName, declarationName, symbolToString(exportedSymbol)) : error(name, Diagnostics.Module_0_declares_1_locally_but_it_is_not_exported, moduleName, declarationName);
+          const diagnostic = exportedSymbol ? error2(name, Diagnostics.Module_0_declares_1_locally_but_it_is_exported_as_2, moduleName, declarationName, symbolToString(exportedSymbol)) : error2(name, Diagnostics.Module_0_declares_1_locally_but_it_is_not_exported, moduleName, declarationName);
           if (localSymbol.declarations) {
-            addRelatedInfo(
-              diagnostic,
-              ...map(localSymbol.declarations, (decl, index) => createDiagnosticForNode(decl, index === 0 ? Diagnostics._0_is_declared_here : Diagnostics.and_here, declarationName))
-            );
+            addRelatedInfo(diagnostic, ...map(localSymbol.declarations, (decl, index) => createDiagnosticForNode(decl, index === 0 ? Diagnostics._0_is_declared_here : Diagnostics.and_here, declarationName)));
           }
         }
       } else {
-        error(name, Diagnostics.Module_0_has_no_exported_member_1, moduleName, declarationName);
+        error2(name, Diagnostics.Module_0_has_no_exported_member_1, moduleName, declarationName);
       }
     }
     function reportInvalidImportEqualsExportMember(node, name, declarationName, moduleName) {
       if (moduleKind >= 5 /* ES2015 */) {
         const message = getESModuleInterop(compilerOptions) ? Diagnostics._0_can_only_be_imported_by_using_a_default_import : Diagnostics._0_can_only_be_imported_by_turning_on_the_esModuleInterop_flag_and_using_a_default_import;
-        error(name, message, declarationName);
+        error2(name, message, declarationName);
       } else {
         if (isInJSFile(node)) {
           const message = getESModuleInterop(compilerOptions) ? Diagnostics._0_can_only_be_imported_by_using_a_require_call_or_by_using_a_default_import : Diagnostics._0_can_only_be_imported_by_using_a_require_call_or_by_turning_on_the_esModuleInterop_flag_and_using_a_default_import;
-          error(name, message, declarationName);
+          error2(name, message, declarationName);
         } else {
           const message = getESModuleInterop(compilerOptions) ? Diagnostics._0_can_only_be_imported_by_using_import_1_require_2_or_a_default_import : Diagnostics._0_can_only_be_imported_by_using_import_1_require_2_or_by_turning_on_the_esModuleInterop_flag_and_using_a_default_import;
-          error(name, message, declarationName, declarationName, moduleName);
+          error2(name, message, declarationName, declarationName, moduleName);
         }
       }
     }
@@ -147231,26 +130681,26 @@ ${lanes.join("\n")}
     }
     function getTargetOfAliasDeclaration(node, dontRecursivelyResolve = false) {
       switch (node.kind) {
-        case 270 /* ImportEqualsDeclaration */:
-        case 259 /* VariableDeclaration */:
+        case 271 /* ImportEqualsDeclaration */:
+        case 260 /* VariableDeclaration */:
           return getTargetOfImportEqualsDeclaration(node, dontRecursivelyResolve);
-        case 272 /* ImportClause */:
+        case 273 /* ImportClause */:
           return getTargetOfImportClause(node, dontRecursivelyResolve);
-        case 273 /* NamespaceImport */:
+        case 274 /* NamespaceImport */:
           return getTargetOfNamespaceImport(node, dontRecursivelyResolve);
-        case 279 /* NamespaceExport */:
+        case 280 /* NamespaceExport */:
           return getTargetOfNamespaceExport(node, dontRecursivelyResolve);
-        case 275 /* ImportSpecifier */:
-        case 207 /* BindingElement */:
+        case 276 /* ImportSpecifier */:
+        case 208 /* BindingElement */:
           return getTargetOfImportSpecifier(node, dontRecursivelyResolve);
-        case 280 /* ExportSpecifier */:
+        case 281 /* ExportSpecifier */:
           return getTargetOfExportSpecifier(node, 111551 /* Value */ | 788968 /* Type */ | 1920 /* Namespace */, dontRecursivelyResolve);
-        case 276 /* ExportAssignment */:
-        case 225 /* BinaryExpression */:
+        case 277 /* ExportAssignment */:
+        case 226 /* BinaryExpression */:
           return getTargetOfExportAssignment(node, dontRecursivelyResolve);
-        case 269 /* NamespaceExportDeclaration */:
+        case 270 /* NamespaceExportDeclaration */:
           return getTargetOfNamespaceExportDeclaration(node, dontRecursivelyResolve);
-        case 303 /* ShorthandPropertyAssignment */:
+        case 304 /* ShorthandPropertyAssignment */:
           return resolveEntityName(
             node.name,
             111551 /* Value */ | 788968 /* Type */ | 1920 /* Namespace */,
@@ -147258,10 +130708,10 @@ ${lanes.join("\n")}
             true,
             dontRecursivelyResolve
           );
-        case 302 /* PropertyAssignment */:
+        case 303 /* PropertyAssignment */:
           return getTargetOfAliasLikeExpression(node.initializer, dontRecursivelyResolve);
-        case 211 /* ElementAccessExpression */:
-        case 210 /* PropertyAccessExpression */:
+        case 212 /* ElementAccessExpression */:
+        case 211 /* PropertyAccessExpression */:
           return getTargetOfAccessExpression(node, dontRecursivelyResolve);
         default:
           return Debug.fail();
@@ -147287,7 +130737,7 @@ ${lanes.join("\n")}
         if (links.aliasTarget === resolvingSymbol) {
           links.aliasTarget = target || unknownSymbol;
         } else {
-          error(node, Diagnostics.Circular_definition_of_import_alias_0, symbolToString(symbol));
+          error2(node, Diagnostics.Circular_definition_of_import_alias_0, symbolToString(symbol));
         }
       } else if (links.aliasTarget === resolvingSymbol) {
         links.aliasTarget = unknownSymbol;
@@ -147301,11 +130751,23 @@ ${lanes.join("\n")}
       }
       return void 0;
     }
-    function getAllSymbolFlags(symbol) {
-      let flags = symbol.flags;
+    function getSymbolFlags(symbol, excludeTypeOnlyMeanings, excludeLocalMeanings) {
+      const typeOnlyDeclaration = excludeTypeOnlyMeanings && getTypeOnlyAliasDeclaration(symbol);
+      const typeOnlyDeclarationIsExportStar = typeOnlyDeclaration && isExportDeclaration(typeOnlyDeclaration);
+      const typeOnlyResolution = typeOnlyDeclaration && (typeOnlyDeclarationIsExportStar ? resolveExternalModuleName(
+        typeOnlyDeclaration.moduleSpecifier,
+        typeOnlyDeclaration.moduleSpecifier,
+        /*ignoreErrors*/
+        true
+      ) : resolveAlias(typeOnlyDeclaration.symbol));
+      const typeOnlyExportStarTargets = typeOnlyDeclarationIsExportStar && typeOnlyResolution ? getExportsOfModule(typeOnlyResolution) : void 0;
+      let flags = excludeLocalMeanings ? 0 /* None */ : symbol.flags;
       let seenSymbols;
       while (symbol.flags & 2097152 /* Alias */) {
-        const target = resolveAlias(symbol);
+        const target = getExportSymbolOfValueSymbolIfExported(resolveAlias(symbol));
+        if (!typeOnlyDeclarationIsExportStar && target === typeOnlyResolution || (typeOnlyExportStarTargets == null ? void 0 : typeOnlyExportStarTargets.get(target.escapedName)) === target) {
+          break;
+        }
         if (target === unknownSymbol) {
           return 67108863 /* All */;
         }
@@ -147362,8 +130824,8 @@ ${lanes.join("\n")}
         return links.typeOnlyDeclaration || void 0;
       }
       if (links.typeOnlyDeclaration) {
-        const resolved = links.typeOnlyDeclaration.kind === 277 /* ExportDeclaration */ ? resolveSymbol(getExportsOfModule(links.typeOnlyDeclaration.symbol.parent).get(links.typeOnlyExportStarName || symbol.escapedName)) : resolveAlias(links.typeOnlyDeclaration.symbol);
-        return getAllSymbolFlags(resolved) & include ? links.typeOnlyDeclaration : void 0;
+        const resolved = links.typeOnlyDeclaration.kind === 278 /* ExportDeclaration */ ? resolveSymbol(getExportsOfModule(links.typeOnlyDeclaration.symbol.parent).get(links.typeOnlyExportStarName || symbol.escapedName)) : resolveAlias(links.typeOnlyDeclaration.symbol);
+        return getSymbolFlags(resolved) & include ? links.typeOnlyDeclaration : void 0;
       }
       return void 0;
     }
@@ -147374,7 +130836,11 @@ ${lanes.join("\n")}
       const symbol = getSymbolOfDeclaration(node);
       const target = resolveAlias(symbol);
       if (target) {
-        const markAlias = target === unknownSymbol || getAllSymbolFlags(target) & 111551 /* Value */ && !isConstEnumOrConstEnumOnlyModule(target) && !getTypeOnlyAliasDeclaration(symbol, 111551 /* Value */);
+        const markAlias = target === unknownSymbol || getSymbolFlags(
+          symbol,
+          /*excludeTypeOnlyMeanings*/
+          true
+        ) & 111551 /* Value */ && !isConstEnumOrConstEnumOnlyModule(target);
         if (markAlias) {
           markAliasSymbolAsReferenced(symbol);
         }
@@ -147389,7 +130855,7 @@ ${lanes.join("\n")}
         if (!node)
           return Debug.fail();
         if (isInternalModuleImportEqualsDeclaration(node)) {
-          if (getAllSymbolFlags(resolveSymbol(symbol)) & 111551 /* Value */) {
+          if (getSymbolFlags(resolveSymbol(symbol)) & 111551 /* Value */) {
             checkExpressionCached(node.moduleReference);
           }
         }
@@ -147405,7 +130871,7 @@ ${lanes.join("\n")}
       if (entityName.kind === 80 /* Identifier */ && isRightSideOfQualifiedNameOrPropertyAccess(entityName)) {
         entityName = entityName.parent;
       }
-      if (entityName.kind === 80 /* Identifier */ || entityName.parent.kind === 165 /* QualifiedName */) {
+      if (entityName.kind === 80 /* Identifier */ || entityName.parent.kind === 166 /* QualifiedName */) {
         return resolveEntityName(
           entityName,
           1920 /* Namespace */,
@@ -147414,7 +130880,7 @@ ${lanes.join("\n")}
           dontResolveAlias
         );
       } else {
-        Debug.assert(entityName.parent.kind === 270 /* ImportEqualsDeclaration */);
+        Debug.assert(entityName.parent.kind === 271 /* ImportEqualsDeclaration */);
         return resolveEntityName(
           entityName,
           111551 /* Value */ | 788968 /* Type */ | 1920 /* Namespace */,
@@ -147487,9 +130953,9 @@ ${lanes.join("\n")}
         if (!symbol) {
           return getMergedSymbol(symbolFromJSPrototype);
         }
-      } else if (name.kind === 165 /* QualifiedName */ || name.kind === 210 /* PropertyAccessExpression */) {
-        const left = name.kind === 165 /* QualifiedName */ ? name.left : name.expression;
-        const right = name.kind === 165 /* QualifiedName */ ? name.right : name.name;
+      } else if (name.kind === 166 /* QualifiedName */ || name.kind === 211 /* PropertyAccessExpression */) {
+        const left = name.kind === 166 /* QualifiedName */ ? name.left : name.expression;
+        const right = name.kind === 166 /* QualifiedName */ ? name.right : name.name;
         let namespace = resolveEntityName(
           left,
           namespaceMeaning,
@@ -147523,13 +130989,13 @@ ${lanes.join("\n")}
             const declarationName = declarationNameToString(right);
             const suggestionForNonexistentModule = getSuggestedSymbolForNonexistentModule(right, namespace);
             if (suggestionForNonexistentModule) {
-              error(right, Diagnostics._0_has_no_exported_member_named_1_Did_you_mean_2, namespaceName, declarationName, symbolToString(suggestionForNonexistentModule));
+              error2(right, Diagnostics._0_has_no_exported_member_named_1_Did_you_mean_2, namespaceName, declarationName, symbolToString(suggestionForNonexistentModule));
               return void 0;
             }
             const containingQualifiedName = isQualifiedName(name) && getContainingQualifiedNameNode(name);
             const canSuggestTypeof = globalObjectType && meaning & 788968 /* Type */ && containingQualifiedName && !isTypeOfExpression(containingQualifiedName.parent) && tryGetQualifiedNameAsValue(containingQualifiedName);
             if (canSuggestTypeof) {
-              error(
+              error2(
                 containingQualifiedName,
                 Diagnostics._0_refers_to_a_value_but_is_being_used_as_a_type_here_Did_you_mean_typeof_0,
                 entityNameToString(containingQualifiedName)
@@ -147539,7 +131005,7 @@ ${lanes.join("\n")}
             if (meaning & 1920 /* Namespace */ && isQualifiedName(name.parent)) {
               const exportedTypeSymbol = getMergedSymbol(getSymbol2(getExportsOfSymbol(namespace), right.escapedText, 788968 /* Type */));
               if (exportedTypeSymbol) {
-                error(
+                error2(
                   name.parent.right,
                   Diagnostics.Cannot_access_0_1_because_0_is_a_type_but_not_a_namespace_Did_you_mean_to_retrieve_the_type_of_the_property_1_in_0_with_0_1,
                   symbolToString(exportedTypeSymbol),
@@ -147548,7 +131014,7 @@ ${lanes.join("\n")}
                 return void 0;
               }
             }
-            error(right, Diagnostics.Namespace_0_has_no_exported_member_1, namespaceName, declarationName);
+            error2(right, Diagnostics.Namespace_0_has_no_exported_member_1, namespaceName, declarationName);
           }
           return void 0;
         }
@@ -147556,7 +131022,7 @@ ${lanes.join("\n")}
         Debug.assertNever(name, "Unknown entity name kind.");
       }
       Debug.assert((getCheckFlags(symbol) & 1 /* Instantiated */) === 0, "Should never get an instantiated symbol here.");
-      if (!nodeIsSynthesized(name) && isEntityName(name) && (symbol.flags & 2097152 /* Alias */ || name.parent.kind === 276 /* ExportAssignment */)) {
+      if (!nodeIsSynthesized(name) && isEntityName(name) && (symbol.flags & 2097152 /* Alias */ || name.parent.kind === 277 /* ExportAssignment */)) {
         markSymbolOfAliasDeclarationIfTypeOnly(
           getAliasDeclarationFromName(name),
           symbol,
@@ -147586,7 +131052,7 @@ ${lanes.join("\n")}
       }
     }
     function getAssignmentDeclarationLocation(node) {
-      const typeAlias = findAncestor(node, (node2) => !(isJSDocNode(node2) || node2.flags & 8388608 /* JSDoc */) ? "quit" : isJSDocTypeAlias(node2));
+      const typeAlias = findAncestor(node, (node2) => !(isJSDocNode(node2) || node2.flags & 16777216 /* JSDoc */) ? "quit" : isJSDocTypeAlias(node2));
       if (typeAlias) {
         return;
       }
@@ -147649,11 +131115,11 @@ ${lanes.join("\n")}
       return isStringLiteralLike(moduleReferenceExpression) ? resolveExternalModule(location, moduleReferenceExpression.text, moduleNotFoundError, moduleReferenceExpression, isForAugmentation) : void 0;
     }
     function resolveExternalModule(location, moduleReference, moduleNotFoundError, errorNode, isForAugmentation = false) {
-      var _a, _b, _c, _d, _e, _f, _g, _h, _i;
+      var _a, _b, _c, _d, _e, _f, _g, _h, _i, _j;
       if (startsWith(moduleReference, "@types/")) {
         const diag2 = Diagnostics.Cannot_import_type_declaration_files_Consider_importing_0_instead_of_1;
         const withoutAtTypePrefix = removePrefix(moduleReference, "@types/");
-        error(errorNode, diag2, withoutAtTypePrefix, moduleReference);
+        error2(errorNode, diag2, withoutAtTypePrefix, moduleReference);
       }
       const ambientModule = tryFindAmbientModule(
         moduleReference,
@@ -147667,25 +131133,28 @@ ${lanes.join("\n")}
       const contextSpecifier = isStringLiteralLike(location) ? location : ((_a = findAncestor(location, isImportCall)) == null ? void 0 : _a.arguments[0]) || ((_b = findAncestor(location, isImportDeclaration)) == null ? void 0 : _b.moduleSpecifier) || ((_c = findAncestor(location, isExternalModuleImportEqualsDeclaration)) == null ? void 0 : _c.moduleReference.expression) || ((_d = findAncestor(location, isExportDeclaration)) == null ? void 0 : _d.moduleSpecifier) || ((_e = isModuleDeclaration(location) ? location : location.parent && isModuleDeclaration(location.parent) && location.parent.name === location ? location.parent : void 0) == null ? void 0 : _e.name) || ((_f = isLiteralImportTypeNode(location) ? location : void 0) == null ? void 0 : _f.argument.literal);
       const mode = contextSpecifier && isStringLiteralLike(contextSpecifier) ? getModeForUsageLocation(currentSourceFile, contextSpecifier) : currentSourceFile.impliedNodeFormat;
       const moduleResolutionKind = getEmitModuleResolutionKind(compilerOptions);
-      const resolvedModule = getResolvedModule(currentSourceFile, moduleReference, mode);
+      const resolvedModule = (_g = host.getResolvedModule(currentSourceFile, moduleReference, mode)) == null ? void 0 : _g.resolvedModule;
       const resolutionDiagnostic = resolvedModule && getResolutionDiagnostic(compilerOptions, resolvedModule, currentSourceFile);
       const sourceFile = resolvedModule && (!resolutionDiagnostic || resolutionDiagnostic === Diagnostics.Module_0_was_resolved_to_1_but_jsx_is_not_set) && host.getSourceFile(resolvedModule.resolvedFileName);
       if (sourceFile) {
         if (resolutionDiagnostic) {
-          error(errorNode, resolutionDiagnostic, moduleReference, resolvedModule.resolvedFileName);
+          error2(errorNode, resolutionDiagnostic, moduleReference, resolvedModule.resolvedFileName);
         }
         if (resolvedModule.resolvedUsingTsExtension && isDeclarationFileName(moduleReference)) {
-          const importOrExport = ((_g = findAncestor(location, isImportDeclaration)) == null ? void 0 : _g.importClause) || findAncestor(location, or(isImportEqualsDeclaration, isExportDeclaration));
+          const importOrExport = ((_h = findAncestor(location, isImportDeclaration)) == null ? void 0 : _h.importClause) || findAncestor(location, or(isImportEqualsDeclaration, isExportDeclaration));
           if (importOrExport && !importOrExport.isTypeOnly || findAncestor(location, isImportCall)) {
-            error(
+            error2(
               errorNode,
               Diagnostics.A_declaration_file_cannot_be_imported_without_import_type_Did_you_mean_to_import_an_implementation_file_0_instead,
               getSuggestedImportSource(Debug.checkDefined(tryExtractTSExtension(moduleReference)))
             );
           }
         } else if (resolvedModule.resolvedUsingTsExtension && !shouldAllowImportingTsExtension(compilerOptions, currentSourceFile.fileName)) {
-          const tsExtension = Debug.checkDefined(tryExtractTSExtension(moduleReference));
-          error(errorNode, Diagnostics.An_import_path_can_only_end_with_a_0_extension_when_allowImportingTsExtensions_is_enabled, tsExtension);
+          const importOrExport = ((_i = findAncestor(location, isImportDeclaration)) == null ? void 0 : _i.importClause) || findAncestor(location, or(isImportEqualsDeclaration, isExportDeclaration));
+          if (!((importOrExport == null ? void 0 : importOrExport.isTypeOnly) || findAncestor(location, isImportTypeNode))) {
+            const tsExtension = Debug.checkDefined(tryExtractTSExtension(moduleReference));
+            error2(errorNode, Diagnostics.An_import_path_can_only_end_with_a_0_extension_when_allowImportingTsExtensions_is_enabled, tsExtension);
+          }
         }
         if (sourceFile.symbol) {
           if (resolvedModule.isExternalLibraryImport && !resolutionExtensionIsTSOrJson(resolvedModule.extension)) {
@@ -147701,11 +131170,10 @@ ${lanes.join("\n")}
           }
           if (moduleResolutionKind === 3 /* Node16 */ || moduleResolutionKind === 99 /* NodeNext */) {
             const isSyncImport = currentSourceFile.impliedNodeFormat === 1 /* CommonJS */ && !findAncestor(location, isImportCall) || !!findAncestor(location, isImportEqualsDeclaration);
-            const overrideClauseHost = findAncestor(location, (l) => isImportTypeNode(l) || isExportDeclaration(l) || isImportDeclaration(l));
-            const overrideClause = overrideClauseHost && isImportTypeNode(overrideClauseHost) ? (_h = overrideClauseHost.assertions) == null ? void 0 : _h.assertClause : overrideClauseHost == null ? void 0 : overrideClauseHost.assertClause;
-            if (isSyncImport && sourceFile.impliedNodeFormat === 99 /* ESNext */ && !getResolutionModeOverrideForClause(overrideClause)) {
+            const overrideHost = findAncestor(location, (l) => isImportTypeNode(l) || isExportDeclaration(l) || isImportDeclaration(l));
+            if (isSyncImport && sourceFile.impliedNodeFormat === 99 /* ESNext */ && !hasResolutionModeOverride(overrideHost)) {
               if (findAncestor(location, isImportEqualsDeclaration)) {
-                error(errorNode, Diagnostics.Module_0_cannot_be_imported_using_this_construct_The_specifier_only_resolves_to_an_ES_module_which_cannot_be_imported_with_require_Use_an_ECMAScript_import_instead, moduleReference);
+                error2(errorNode, Diagnostics.Module_0_cannot_be_imported_using_this_construct_The_specifier_only_resolves_to_an_ES_module_which_cannot_be_imported_with_require_Use_an_ECMAScript_import_instead, moduleReference);
               } else {
                 let diagnosticDetails;
                 const ext = tryGetExtensionFromPath2(currentSourceFile.fileName);
@@ -147746,18 +131214,22 @@ ${lanes.join("\n")}
                     }
                   }
                 }
-                diagnostics.add(createDiagnosticForNodeFromMessageChain(getSourceFileOfNode(errorNode), errorNode, chainDiagnosticMessages(
-                  diagnosticDetails,
-                  Diagnostics.The_current_file_is_a_CommonJS_module_whose_imports_will_produce_require_calls_however_the_referenced_file_is_an_ECMAScript_module_and_cannot_be_imported_with_require_Consider_writing_a_dynamic_import_0_call_instead,
-                  moduleReference
-                )));
+                diagnostics.add(createDiagnosticForNodeFromMessageChain(
+                  getSourceFileOfNode(errorNode),
+                  errorNode,
+                  chainDiagnosticMessages(
+                    diagnosticDetails,
+                    Diagnostics.The_current_file_is_a_CommonJS_module_whose_imports_will_produce_require_calls_however_the_referenced_file_is_an_ECMAScript_module_and_cannot_be_imported_with_require_Consider_writing_a_dynamic_import_0_call_instead,
+                    moduleReference
+                  )
+                ));
               }
             }
           }
           return getMergedSymbol(sourceFile.symbol);
         }
         if (moduleNotFoundError) {
-          error(errorNode, Diagnostics.File_0_is_not_a_module, sourceFile.fileName);
+          error2(errorNode, Diagnostics.File_0_is_not_a_module, sourceFile.fileName);
         }
         return void 0;
       }
@@ -147774,7 +131246,7 @@ ${lanes.join("\n")}
       if (resolvedModule && !resolutionExtensionIsTSOrJson(resolvedModule.extension) && resolutionDiagnostic === void 0 || resolutionDiagnostic === Diagnostics.Could_not_find_a_declaration_file_for_module_0_1_implicitly_has_an_any_type) {
         if (isForAugmentation) {
           const diag2 = Diagnostics.Invalid_module_name_in_augmentation_Module_0_resolves_to_an_untyped_module_at_1_which_cannot_be_augmented;
-          error(errorNode, diag2, moduleReference, resolvedModule.resolvedFileName);
+          error2(errorNode, diag2, moduleReference, resolvedModule.resolvedFileName);
         } else {
           errorOnImplicitAnyModule(
             /*isError*/
@@ -147792,31 +131264,27 @@ ${lanes.join("\n")}
         if (resolvedModule) {
           const redirect = host.getProjectReferenceRedirect(resolvedModule.resolvedFileName);
           if (redirect) {
-            error(errorNode, Diagnostics.Output_file_0_has_not_been_built_from_source_file_1, redirect, resolvedModule.resolvedFileName);
+            error2(errorNode, Diagnostics.Output_file_0_has_not_been_built_from_source_file_1, redirect, resolvedModule.resolvedFileName);
             return void 0;
           }
         }
         if (resolutionDiagnostic) {
-          error(errorNode, resolutionDiagnostic, moduleReference, resolvedModule.resolvedFileName);
+          error2(errorNode, resolutionDiagnostic, moduleReference, resolvedModule.resolvedFileName);
         } else {
           const isExtensionlessRelativePathImport = pathIsRelative(moduleReference) && !hasExtension(moduleReference);
           const resolutionIsNode16OrNext = moduleResolutionKind === 3 /* Node16 */ || moduleResolutionKind === 99 /* NodeNext */;
           if (!getResolveJsonModule(compilerOptions) && fileExtensionIs(moduleReference, ".json" /* Json */) && moduleResolutionKind !== 1 /* Classic */ && hasJsonModuleEmitEnabled(compilerOptions)) {
-            error(errorNode, Diagnostics.Cannot_find_module_0_Consider_using_resolveJsonModule_to_import_module_with_json_extension, moduleReference);
+            error2(errorNode, Diagnostics.Cannot_find_module_0_Consider_using_resolveJsonModule_to_import_module_with_json_extension, moduleReference);
           } else if (mode === 99 /* ESNext */ && resolutionIsNode16OrNext && isExtensionlessRelativePathImport) {
             const absoluteRef = getNormalizedAbsolutePath(moduleReference, getDirectoryPath(currentSourceFile.path));
-            const suggestedExt = (_i = suggestedExtensions.find(([actualExt, _importExt]) => host.fileExists(absoluteRef + actualExt))) == null ? void 0 : _i[1];
+            const suggestedExt = (_j = suggestedExtensions.find(([actualExt, _importExt]) => host.fileExists(absoluteRef + actualExt))) == null ? void 0 : _j[1];
             if (suggestedExt) {
-              error(
-                errorNode,
-                Diagnostics.Relative_import_paths_need_explicit_file_extensions_in_EcmaScript_imports_when_moduleResolution_is_node16_or_nodenext_Did_you_mean_0,
-                moduleReference + suggestedExt
-              );
+              error2(errorNode, Diagnostics.Relative_import_paths_need_explicit_file_extensions_in_ECMAScript_imports_when_moduleResolution_is_node16_or_nodenext_Did_you_mean_0, moduleReference + suggestedExt);
             } else {
-              error(errorNode, Diagnostics.Relative_import_paths_need_explicit_file_extensions_in_EcmaScript_imports_when_moduleResolution_is_node16_or_nodenext_Consider_adding_an_extension_to_the_import_path);
+              error2(errorNode, Diagnostics.Relative_import_paths_need_explicit_file_extensions_in_ECMAScript_imports_when_moduleResolution_is_node16_or_nodenext_Consider_adding_an_extension_to_the_import_path);
             }
           } else {
-            error(errorNode, moduleNotFoundError, moduleReference);
+            error2(errorNode, moduleNotFoundError, moduleReference);
           }
         }
       }
@@ -147836,12 +131304,16 @@ ${lanes.join("\n")}
       if (!isExternalModuleNameRelative(moduleReference) && packageId) {
         errorInfo = createModuleNotFoundChain(sourceFile, host, moduleReference, mode, packageId.name);
       }
-      errorOrSuggestion(isError, errorNode, chainDiagnosticMessages(
-        errorInfo,
-        Diagnostics.Could_not_find_a_declaration_file_for_module_0_1_implicitly_has_an_any_type,
-        moduleReference,
-        resolvedFileName
-      ));
+      errorOrSuggestion(
+        isError,
+        errorNode,
+        chainDiagnosticMessages(
+          errorInfo,
+          Diagnostics.Could_not_find_a_declaration_file_for_module_0_1_implicitly_has_an_any_type,
+          moduleReference,
+          resolvedFileName
+        )
+      );
     }
     function resolveExternalModuleSymbol(moduleSymbol, dontResolveAlias) {
       if (moduleSymbol == null ? void 0 : moduleSymbol.exports) {
@@ -147880,9 +131352,9 @@ ${lanes.join("\n")}
       var _a;
       const symbol = resolveExternalModuleSymbol(moduleSymbol, dontResolveAlias);
       if (!dontResolveAlias && symbol) {
-        if (!suppressInteropError && !(symbol.flags & (1536 /* Module */ | 3 /* Variable */)) && !getDeclarationOfKind(symbol, 311 /* SourceFile */)) {
+        if (!suppressInteropError && !(symbol.flags & (1536 /* Module */ | 3 /* Variable */)) && !getDeclarationOfKind(symbol, 312 /* SourceFile */)) {
           const compilerOptionName = moduleKind >= 5 /* ES2015 */ ? "allowSyntheticDefaultImports" : "esModuleInterop";
-          error(referencingLocation, Diagnostics.This_module_can_only_be_referenced_with_ECMAScript_imports_Slashexports_by_turning_on_the_0_flag_and_referencing_its_default_export, compilerOptionName);
+          error2(referencingLocation, Diagnostics.This_module_can_only_be_referenced_with_ECMAScript_imports_Slashexports_by_turning_on_the_0_flag_and_referencing_its_default_export, compilerOptionName);
           return symbol;
         }
         const referenceParent = referencingLocation.parent;
@@ -148078,10 +131550,12 @@ ${lanes.join("\n")}
         }
         if (exportStar == null ? void 0 : exportStar.isTypeOnly) {
           typeOnlyExportStarMap ?? (typeOnlyExportStarMap = /* @__PURE__ */ new Map());
-          symbols.forEach((_, escapedName) => typeOnlyExportStarMap.set(
-            escapedName,
-            exportStar
-          ));
+          symbols.forEach(
+            (_, escapedName) => typeOnlyExportStarMap.set(
+              escapedName,
+              exportStar
+            )
+          );
         }
         return symbols;
       }
@@ -148237,12 +131711,12 @@ ${lanes.join("\n")}
       return getMergedSymbol(symbol && (symbol.flags & 1048576 /* ExportValue */) !== 0 && symbol.exportSymbol || symbol);
     }
     function symbolIsValue(symbol, includeTypeOnlyMembers) {
-      return !!(symbol.flags & 111551 /* Value */ || symbol.flags & 2097152 /* Alias */ && getAllSymbolFlags(symbol) & 111551 /* Value */ && (includeTypeOnlyMembers || !getTypeOnlyAliasDeclaration(symbol)));
+      return !!(symbol.flags & 111551 /* Value */ || symbol.flags & 2097152 /* Alias */ && getSymbolFlags(symbol, !includeTypeOnlyMembers) & 111551 /* Value */);
     }
     function findConstructorDeclaration(node) {
       const members = node.members;
       for (const member of members) {
-        if (member.kind === 175 /* Constructor */ && nodeIsPresent(member.body)) {
+        if (member.kind === 176 /* Constructor */ && nodeIsPresent(member.body)) {
           return member;
         }
       }
@@ -148263,12 +131737,21 @@ ${lanes.join("\n")}
     function createOriginType(flags) {
       return new Type27(checker, flags);
     }
-    function createIntrinsicType(kind, intrinsicName, objectFlags = 0 /* None */) {
+    function createIntrinsicType(kind, intrinsicName, objectFlags = 0 /* None */, debugIntrinsicName) {
+      checkIntrinsicName(intrinsicName, debugIntrinsicName);
       const type = createType(kind);
       type.intrinsicName = intrinsicName;
-      type.objectFlags = objectFlags;
+      type.debugIntrinsicName = debugIntrinsicName;
+      type.objectFlags = objectFlags | 524288 /* CouldContainTypeVariablesComputed */ | 2097152 /* IsGenericTypeComputed */ | 33554432 /* IsUnknownLikeUnionComputed */ | 16777216 /* IsNeverIntersectionComputed */;
       return type;
     }
+    function checkIntrinsicName(name, debug) {
+      const key = `${name},${debug ?? ""}`;
+      if (seenIntrinsicNames.has(key)) {
+        Debug.fail(`Duplicate intrinsic type name ${name}${debug ? ` (${debug})` : ""}; you may need to pass a name to createIntrinsicType.`);
+      }
+      seenIntrinsicNames.add(key);
+    }
     function createObjectType(objectFlags, symbol) {
       const type = createTypeWithSymbol(524288 /* Object */, symbol);
       type.objectFlags = objectFlags;
@@ -148317,13 +131800,7 @@ ${lanes.join("\n")}
       return resolved;
     }
     function createAnonymousType(symbol, members, callSignatures, constructSignatures, indexInfos) {
-      return setStructuredTypeMembers(
-        createObjectType(16 /* Anonymous */, symbol),
-        members,
-        callSignatures,
-        constructSignatures,
-        indexInfos
-      );
+      return setStructuredTypeMembers(createObjectType(16 /* Anonymous */, symbol), members, callSignatures, constructSignatures, indexInfos);
     }
     function getResolvedTypeWithoutAbstractConstructSignatures(type) {
       if (type.constructSignatures.length === 0)
@@ -148360,11 +131837,11 @@ ${lanes.join("\n")}
           }
         }
         switch (location.kind) {
-          case 311 /* SourceFile */:
+          case 312 /* SourceFile */:
             if (!isExternalOrCommonJsModule(location)) {
               break;
             }
-          case 266 /* ModuleDeclaration */:
+          case 267 /* ModuleDeclaration */:
             const sym = getSymbolOfDeclaration(location);
             if (result = callback(
               (sym == null ? void 0 : sym.exports) || emptySymbols,
@@ -148377,9 +131854,9 @@ ${lanes.join("\n")}
               return result;
             }
             break;
-          case 262 /* ClassDeclaration */:
-          case 230 /* ClassExpression */:
-          case 263 /* InterfaceDeclaration */:
+          case 263 /* ClassDeclaration */:
+          case 231 /* ClassExpression */:
+          case 264 /* InterfaceDeclaration */:
             let table;
             (getSymbolOfDeclaration(location).members || emptySymbols).forEach((memberSymbol, key) => {
               if (memberSymbol.flags & (788968 /* Type */ & ~67108864 /* Assignment */)) {
@@ -148457,7 +131934,7 @@ ${lanes.join("\n")}
           return [symbol];
         }
         const result2 = forEachEntry(symbols, (symbolFromSymbolTable) => {
-          if (symbolFromSymbolTable.flags & 2097152 /* Alias */ && symbolFromSymbolTable.escapedName !== "export=" /* ExportEquals */ && symbolFromSymbolTable.escapedName !== "default" /* Default */ && !(isUMDExportSymbol(symbolFromSymbolTable) && enclosingDeclaration && isExternalModule(getSourceFileOfNode(enclosingDeclaration))) && (!useOnlyExternalAliasing || some(symbolFromSymbolTable.declarations, isExternalModuleImportEqualsDeclaration)) && (isLocalNameLookup ? !some(symbolFromSymbolTable.declarations, isNamespaceReexportDeclaration) : true) && (ignoreQualification || !getDeclarationOfKind(symbolFromSymbolTable, 280 /* ExportSpecifier */))) {
+          if (symbolFromSymbolTable.flags & 2097152 /* Alias */ && symbolFromSymbolTable.escapedName !== "export=" /* ExportEquals */ && symbolFromSymbolTable.escapedName !== "default" /* Default */ && !(isUMDExportSymbol(symbolFromSymbolTable) && enclosingDeclaration && isExternalModule(getSourceFileOfNode(enclosingDeclaration))) && (!useOnlyExternalAliasing || some(symbolFromSymbolTable.declarations, isExternalModuleImportEqualsDeclaration)) && (isLocalNameLookup ? !some(symbolFromSymbolTable.declarations, isNamespaceReexportDeclaration) : true) && (ignoreQualification || !getDeclarationOfKind(symbolFromSymbolTable, 281 /* ExportSpecifier */))) {
             const resolvedImportedSymbol = resolveAlias(symbolFromSymbolTable);
             const candidate = getCandidateListForSymbol(symbolFromSymbolTable, resolvedImportedSymbol, ignoreQualification);
             if (candidate) {
@@ -148502,9 +131979,9 @@ ${lanes.join("\n")}
         if (symbolFromSymbolTable === symbol) {
           return true;
         }
-        const shouldResolveAlias = symbolFromSymbolTable.flags & 2097152 /* Alias */ && !getDeclarationOfKind(symbolFromSymbolTable, 280 /* ExportSpecifier */);
+        const shouldResolveAlias = symbolFromSymbolTable.flags & 2097152 /* Alias */ && !getDeclarationOfKind(symbolFromSymbolTable, 281 /* ExportSpecifier */);
         symbolFromSymbolTable = shouldResolveAlias ? resolveAlias(symbolFromSymbolTable) : symbolFromSymbolTable;
-        const flags = shouldResolveAlias ? getAllSymbolFlags(symbolFromSymbolTable) : symbolFromSymbolTable.flags;
+        const flags = shouldResolveAlias ? getSymbolFlags(symbolFromSymbolTable) : symbolFromSymbolTable.flags;
         if (flags & meaning) {
           qualify = true;
           return true;
@@ -148517,10 +131994,10 @@ ${lanes.join("\n")}
       if (symbol.declarations && symbol.declarations.length) {
         for (const declaration of symbol.declarations) {
           switch (declaration.kind) {
-            case 171 /* PropertyDeclaration */:
-            case 173 /* MethodDeclaration */:
-            case 176 /* GetAccessor */:
-            case 177 /* SetAccessor */:
+            case 172 /* PropertyDeclaration */:
+            case 174 /* MethodDeclaration */:
+            case 177 /* GetAccessor */:
+            case 178 /* SetAccessor */:
               continue;
             default:
               return false;
@@ -148656,10 +132133,10 @@ ${lanes.join("\n")}
       return node && getSymbolOfDeclaration(node);
     }
     function hasExternalModuleSymbol(declaration) {
-      return isAmbientModule(declaration) || declaration.kind === 311 /* SourceFile */ && isExternalOrCommonJsModule(declaration);
+      return isAmbientModule(declaration) || declaration.kind === 312 /* SourceFile */ && isExternalOrCommonJsModule(declaration);
     }
     function hasNonGlobalAugmentationExternalModuleSymbol(declaration) {
-      return isModuleWithStringLiteralName(declaration) || declaration.kind === 311 /* SourceFile */ && isExternalOrCommonJsModule(declaration);
+      return isModuleWithStringLiteralName(declaration) || declaration.kind === 312 /* SourceFile */ && isExternalOrCommonJsModule(declaration);
     }
     function hasVisibleDeclarations(symbol, shouldComputeAliasToMakeVisible) {
       let aliasesToMakeVisible;
@@ -148671,20 +132148,20 @@ ${lanes.join("\n")}
         var _a, _b;
         if (!isDeclarationVisible(declaration)) {
           const anyImportSyntax = getAnyImportSyntax(declaration);
-          if (anyImportSyntax && !hasSyntacticModifier(anyImportSyntax, 1 /* Export */) && // import clause without export
+          if (anyImportSyntax && !hasSyntacticModifier(anyImportSyntax, 32 /* Export */) && // import clause without export
           isDeclarationVisible(anyImportSyntax.parent)) {
             return addVisibleAlias(declaration, anyImportSyntax);
-          } else if (isVariableDeclaration(declaration) && isVariableStatement(declaration.parent.parent) && !hasSyntacticModifier(declaration.parent.parent, 1 /* Export */) && // unexported variable statement
+          } else if (isVariableDeclaration(declaration) && isVariableStatement(declaration.parent.parent) && !hasSyntacticModifier(declaration.parent.parent, 32 /* Export */) && // unexported variable statement
           isDeclarationVisible(declaration.parent.parent.parent)) {
             return addVisibleAlias(declaration, declaration.parent.parent);
-          } else if (isLateVisibilityPaintedStatement(declaration) && !hasSyntacticModifier(declaration, 1 /* Export */) && isDeclarationVisible(declaration.parent)) {
+          } else if (isLateVisibilityPaintedStatement(declaration) && !hasSyntacticModifier(declaration, 32 /* Export */) && isDeclarationVisible(declaration.parent)) {
             return addVisibleAlias(declaration, declaration);
           } else if (isBindingElement(declaration)) {
-            if (symbol.flags & 2097152 /* Alias */ && isInJSFile(declaration) && ((_a = declaration.parent) == null ? void 0 : _a.parent) && isVariableDeclaration(declaration.parent.parent) && ((_b = declaration.parent.parent.parent) == null ? void 0 : _b.parent) && isVariableStatement(declaration.parent.parent.parent.parent) && !hasSyntacticModifier(declaration.parent.parent.parent.parent, 1 /* Export */) && declaration.parent.parent.parent.parent.parent && isDeclarationVisible(declaration.parent.parent.parent.parent.parent)) {
+            if (symbol.flags & 2097152 /* Alias */ && isInJSFile(declaration) && ((_a = declaration.parent) == null ? void 0 : _a.parent) && isVariableDeclaration(declaration.parent.parent) && ((_b = declaration.parent.parent.parent) == null ? void 0 : _b.parent) && isVariableStatement(declaration.parent.parent.parent.parent) && !hasSyntacticModifier(declaration.parent.parent.parent.parent, 32 /* Export */) && declaration.parent.parent.parent.parent.parent && isDeclarationVisible(declaration.parent.parent.parent.parent.parent)) {
               return addVisibleAlias(declaration, declaration.parent.parent.parent.parent);
             } else if (symbol.flags & 2 /* BlockScopedVariable */) {
               const variableStatement = findAncestor(declaration, isVariableStatement);
-              if (hasSyntacticModifier(variableStatement, 1 /* Export */)) {
+              if (hasSyntacticModifier(variableStatement, 32 /* Export */)) {
                 return true;
               }
               if (!isDeclarationVisible(variableStatement.parent)) {
@@ -148707,9 +132184,9 @@ ${lanes.join("\n")}
     }
     function isEntityNameVisible(entityName, enclosingDeclaration) {
       let meaning;
-      if (entityName.parent.kind === 185 /* TypeQuery */ || entityName.parent.kind === 232 /* ExpressionWithTypeArguments */ && !isPartOfTypeNode(entityName.parent) || entityName.parent.kind === 166 /* ComputedPropertyName */) {
+      if (entityName.parent.kind === 186 /* TypeQuery */ || entityName.parent.kind === 233 /* ExpressionWithTypeArguments */ && !isPartOfTypeNode(entityName.parent) || entityName.parent.kind === 167 /* ComputedPropertyName */) {
         meaning = 111551 /* Value */ | 1048576 /* ExportValue */;
-      } else if (entityName.kind === 165 /* QualifiedName */ || entityName.kind === 210 /* PropertyAccessExpression */ || entityName.parent.kind === 270 /* ImportEqualsDeclaration */) {
+      } else if (entityName.kind === 166 /* QualifiedName */ || entityName.kind === 211 /* PropertyAccessExpression */ || entityName.parent.kind === 271 /* ImportEqualsDeclaration */) {
         meaning = 1920 /* Namespace */;
       } else {
         meaning = 788968 /* Type */;
@@ -148775,7 +132252,7 @@ ${lanes.join("\n")}
       return writer ? symbolToStringWorker(writer).getText() : usingSingleLineStringWriter(symbolToStringWorker);
       function symbolToStringWorker(writer2) {
         const entity = builder(symbol, meaning, enclosingDeclaration, nodeFlags);
-        const printer = (enclosingDeclaration == null ? void 0 : enclosingDeclaration.kind) === 311 /* SourceFile */ ? createPrinterWithRemoveCommentsNeverAsciiEscape() : createPrinterWithRemoveComments();
+        const printer = (enclosingDeclaration == null ? void 0 : enclosingDeclaration.kind) === 312 /* SourceFile */ ? createPrinterWithRemoveCommentsNeverAsciiEscape() : createPrinterWithRemoveComments();
         const sourceFile = enclosingDeclaration && getSourceFileOfNode(enclosingDeclaration);
         printer.writeNode(
           4 /* Unspecified */,
@@ -148792,9 +132269,9 @@ ${lanes.join("\n")}
       function signatureToStringWorker(writer2) {
         let sigOutput;
         if (flags & 262144 /* WriteArrowStyleSignature */) {
-          sigOutput = kind === 1 /* Construct */ ? 184 /* ConstructorType */ : 183 /* FunctionType */;
+          sigOutput = kind === 1 /* Construct */ ? 185 /* ConstructorType */ : 184 /* FunctionType */;
         } else {
-          sigOutput = kind === 1 /* Construct */ ? 179 /* ConstructSignature */ : 178 /* CallSignature */;
+          sigOutput = kind === 1 /* Construct */ ? 180 /* ConstructSignature */ : 179 /* CallSignature */;
         }
         const sig = nodeBuilder.signatureToSignatureDeclaration(signature, sigOutput, enclosingDeclaration, toNodeBuilderFlags(flags) | 70221824 /* IgnoreErrors */ | 512 /* WriteTypeParametersInQualifiedName */);
         const printer = createPrinterWithRemoveCommentsOmitTrailingSemicolon();
@@ -148896,7 +132373,7 @@ ${lanes.join("\n")}
         return symbolToExpression(symbol, context, meaning);
       }
       function withContext(enclosingDeclaration, flags, tracker, cb) {
-        Debug.assert(enclosingDeclaration === void 0 || (enclosingDeclaration.flags & 8 /* Synthesized */) === 0);
+        Debug.assert(enclosingDeclaration === void 0 || (enclosingDeclaration.flags & 16 /* Synthesized */) === 0);
         const moduleResolverHost = (tracker == null ? void 0 : tracker.trackSymbol) ? tracker.moduleResolverHost : flags & 134217728 /* DoNotIncludeSymbolChain */ ? createBasicNodeBuilderModuleSpecifierResolutionHost(host) : void 0;
         const context = {
           enclosingDeclaration,
@@ -148907,7 +132384,8 @@ ${lanes.join("\n")}
           visitedTypes: void 0,
           symbolDepth: void 0,
           inferTypeParameters: void 0,
-          approximateLength: 0
+          approximateLength: 0,
+          trackedSymbols: void 0
         };
         context.tracker = new SymbolTrackerImpl(context, tracker, moduleResolverHost);
         const resultingNode = cb(context);
@@ -148968,7 +132446,7 @@ ${lanes.join("\n")}
         }
         if (type.flags & 64 /* BigInt */) {
           context.approximateLength += 6;
-          return factory.createKeywordTypeNode(162 /* BigIntKeyword */);
+          return factory.createKeywordTypeNode(163 /* BigIntKeyword */);
         }
         if (type.flags & 16 /* Boolean */ && !type.aliasSymbol) {
           context.approximateLength += 7;
@@ -149241,11 +132719,13 @@ ${lanes.join("\n")}
           return !!type2.target && isMappedTypeHomomorphic(type2.target) && !isMappedTypeHomomorphic(type2);
         }
         function createMappedTypeNodeFromType(type2) {
+          var _a2;
           Debug.assert(!!(type2.flags & 524288 /* Object */));
           const readonlyToken = type2.declaration.readonlyToken ? factory.createToken(type2.declaration.readonlyToken.kind) : void 0;
           const questionToken = type2.declaration.questionToken ? factory.createToken(type2.declaration.questionToken.kind) : void 0;
           let appropriateConstraintTypeNode;
           let newTypeVariable;
+          const needsModifierPreservingWrapper = !isMappedTypeWithKeyofConstraintDeclaration(type2) && !(getModifiersTypeFromMappedType(type2).flags & 2 /* Unknown */) && context.flags & 4 /* GenerateNamesForShadowedTypeParams */ && !(getConstraintTypeFromMappedType(type2).flags & 262144 /* TypeParameter */ && ((_a2 = getConstraintOfTypeParameter(getConstraintTypeFromMappedType(type2))) == null ? void 0 : _a2.flags) & 4194304 /* Index */);
           if (isMappedTypeWithKeyofConstraintDeclaration(type2)) {
             if (isHomomorphicMappedTypeWithNonHomomorphicInstantiation(type2) && context.flags & 4 /* GenerateNamesForShadowedTypeParams */) {
               const newParam = createTypeParameter(createSymbol(262144 /* TypeParameter */, "T"));
@@ -149253,6 +132733,11 @@ ${lanes.join("\n")}
               newTypeVariable = factory.createTypeReferenceNode(name);
             }
             appropriateConstraintTypeNode = factory.createTypeOperatorNode(143 /* KeyOfKeyword */, newTypeVariable || typeToTypeNodeHelper(getModifiersTypeFromMappedType(type2), context));
+          } else if (needsModifierPreservingWrapper) {
+            const newParam = createTypeParameter(createSymbol(262144 /* TypeParameter */, "T"));
+            const name = typeParameterToName(newParam, context);
+            newTypeVariable = factory.createTypeReferenceNode(name);
+            appropriateConstraintTypeNode = newTypeVariable;
           } else {
             appropriateConstraintTypeNode = typeToTypeNodeHelper(getConstraintTypeFromMappedType(type2), context);
           }
@@ -149283,6 +132768,18 @@ ${lanes.join("\n")}
               result,
               factory.createKeywordTypeNode(146 /* NeverKeyword */)
             );
+          } else if (needsModifierPreservingWrapper) {
+            return factory.createConditionalTypeNode(
+              typeToTypeNodeHelper(getConstraintTypeFromMappedType(type2), context),
+              factory.createInferTypeNode(factory.createTypeParameterDeclaration(
+                /*modifiers*/
+                void 0,
+                factory.cloneNode(newTypeVariable.typeName),
+                factory.createTypeOperatorNode(143 /* KeyOfKeyword */, typeToTypeNodeHelper(getModifiersTypeFromMappedType(type2), context))
+              )),
+              result,
+              factory.createKeywordTypeNode(146 /* NeverKeyword */)
+            );
           }
           return result;
         }
@@ -149334,7 +132831,7 @@ ${lanes.join("\n")}
             const isStaticMethodSymbol = !!(symbol.flags & 8192 /* Method */) && // typeof static method
             some(symbol.declarations, (declaration) => isStatic(declaration));
             const isNonLocalFunctionSymbol = !!(symbol.flags & 16 /* Function */) && (symbol.parent || // is exported function symbol
-            forEach(symbol.declarations, (declaration) => declaration.parent.kind === 311 /* SourceFile */ || declaration.parent.kind === 267 /* ModuleBlock */));
+            forEach(symbol.declarations, (declaration) => declaration.parent.kind === 312 /* SourceFile */ || declaration.parent.kind === 268 /* ModuleBlock */));
             if (isStaticMethodSymbol || isNonLocalFunctionSymbol) {
               return (!!(context.flags & 4096 /* UseTypeOfFunction */) || ((_a3 = context.visitedTypes) == null ? void 0 : _a3.has(typeId))) && // it is type of the symbol uses itself recursively
               (!(context.flags & 8 /* UseStructuralFallback */) || isValueSymbolAccessible(symbol, context.enclosingDeclaration));
@@ -149342,7 +132839,7 @@ ${lanes.join("\n")}
           }
         }
         function visitAndTransformType(type2, transform2) {
-          var _a2, _b2;
+          var _a2, _b2, _c;
           const typeId = type2.id;
           const isConstructorObject = getObjectFlags(type2) & 16 /* Anonymous */ && type2.symbol && type2.symbol.flags & 32 /* Class */;
           const id = getObjectFlags(type2) & 4 /* Reference */ && type2.node ? "N" + getNodeId(type2.node) : type2.flags & 16777216 /* Conditional */ ? "N" + getNodeId(type2.root.node) : type2.symbol ? (isConstructorObject ? "+" : "") + getSymbolId(type2.symbol) : void 0;
@@ -149359,6 +132856,13 @@ ${lanes.join("\n")}
           }
           const cachedResult = (_a2 = links == null ? void 0 : links.serializedTypes) == null ? void 0 : _a2.get(key);
           if (cachedResult) {
+            (_b2 = cachedResult.trackedSymbols) == null ? void 0 : _b2.forEach(
+              ([symbol, enclosingDeclaration, meaning]) => context.tracker.trackSymbol(
+                symbol,
+                enclosingDeclaration,
+                meaning
+              )
+            );
             if (cachedResult.truncating) {
               context.truncating = true;
             }
@@ -149374,16 +132878,24 @@ ${lanes.join("\n")}
             context.symbolDepth.set(id, depth + 1);
           }
           context.visitedTypes.add(typeId);
+          const prevTrackedSymbols = context.trackedSymbols;
+          context.trackedSymbols = void 0;
           const startLength = context.approximateLength;
           const result = transform2(type2);
           const addedLength = context.approximateLength - startLength;
           if (!context.reportedDiagnostic && !context.encounteredError) {
-            (_b2 = links == null ? void 0 : links.serializedTypes) == null ? void 0 : _b2.set(key, { node: result, truncating: context.truncating, addedLength });
+            (_c = links == null ? void 0 : links.serializedTypes) == null ? void 0 : _c.set(key, {
+              node: result,
+              truncating: context.truncating,
+              addedLength,
+              trackedSymbols: context.trackedSymbols
+            });
           }
           context.visitedTypes.delete(typeId);
           if (id) {
             context.symbolDepth.set(id, depth);
           }
+          context.trackedSymbols = prevTrackedSymbols;
           return result;
           function deepCloneOrReuseNode(node) {
             if (!nodeIsSynthesized(node) && getParseTreeNode(node) === node) {
@@ -149417,12 +132929,12 @@ ${lanes.join("\n")}
             }
             if (resolved.callSignatures.length === 1 && !resolved.constructSignatures.length) {
               const signature = resolved.callSignatures[0];
-              const signatureNode = signatureToSignatureDeclarationHelper(signature, 183 /* FunctionType */, context);
+              const signatureNode = signatureToSignatureDeclarationHelper(signature, 184 /* FunctionType */, context);
               return signatureNode;
             }
             if (resolved.constructSignatures.length === 1 && !resolved.callSignatures.length) {
               const signature = resolved.constructSignatures[0];
-              const signatureNode = signatureToSignatureDeclarationHelper(signature, 184 /* ConstructorType */, context);
+              const signatureNode = signatureToSignatureDeclarationHelper(signature, 185 /* ConstructorType */, context);
               return signatureNode;
             }
           }
@@ -149462,19 +132974,18 @@ ${lanes.join("\n")}
               const arity = getTypeReferenceArity(type2);
               const tupleConstituentNodes = mapToTypeNodes(typeArguments.slice(0, arity), context);
               if (tupleConstituentNodes) {
-                if (type2.target.labeledElementDeclarations) {
-                  for (let i = 0; i < tupleConstituentNodes.length; i++) {
-                    const flags = type2.target.elementFlags[i];
+                const { labeledElementDeclarations } = type2.target;
+                for (let i = 0; i < tupleConstituentNodes.length; i++) {
+                  const flags = type2.target.elementFlags[i];
+                  const labeledElementDeclaration = labeledElementDeclarations == null ? void 0 : labeledElementDeclarations[i];
+                  if (labeledElementDeclaration) {
                     tupleConstituentNodes[i] = factory.createNamedTupleMember(
                       flags & 12 /* Variable */ ? factory.createToken(26 /* DotDotDotToken */) : void 0,
-                      factory.createIdentifier(unescapeLeadingUnderscores(getTupleElementLabel(type2.target.labeledElementDeclarations[i]))),
+                      factory.createIdentifier(unescapeLeadingUnderscores(getTupleElementLabel(labeledElementDeclaration))),
                       flags & 2 /* Optional */ ? factory.createToken(58 /* QuestionToken */) : void 0,
                       flags & 4 /* Rest */ ? factory.createArrayTypeNode(tupleConstituentNodes[i]) : tupleConstituentNodes[i]
                     );
-                  }
-                } else {
-                  for (let i = 0; i < Math.min(arity, tupleConstituentNodes.length); i++) {
-                    const flags = type2.target.elementFlags[i];
+                  } else {
                     tupleConstituentNodes[i] = flags & 12 /* Variable */ ? factory.createRestTypeNode(flags & 4 /* Rest */ ? factory.createArrayTypeNode(tupleConstituentNodes[i]) : tupleConstituentNodes[i]) : flags & 2 /* Optional */ ? factory.createOptionalTypeNode(tupleConstituentNodes[i]) : tupleConstituentNodes[i];
                   }
                 }
@@ -149535,11 +133046,7 @@ ${lanes.join("\n")}
                 }
               } else {
                 if (typeArguments !== getIdentifierTypeArguments(qualifier.right)) {
-                  qualifier = factory.updateQualifiedName(
-                    qualifier,
-                    qualifier.left,
-                    setIdentifierTypeArguments(factory.cloneNode(qualifier.right), typeArguments)
-                  );
+                  qualifier = factory.updateQualifiedName(qualifier, qualifier.left, setIdentifierTypeArguments(factory.cloneNode(qualifier.right), typeArguments));
                 }
               }
             }
@@ -149551,7 +133058,7 @@ ${lanes.join("\n")}
             return factory.updateImportTypeNode(
               root,
               root.argument,
-              root.assertions,
+              root.attributes,
               qualifier,
               typeArguments,
               root.isTypeOf
@@ -149565,11 +133072,7 @@ ${lanes.join("\n")}
               }
             } else {
               if (typeArguments !== getIdentifierTypeArguments(typeName.right)) {
-                typeName = factory.updateQualifiedName(
-                  typeName,
-                  typeName.left,
-                  setIdentifierTypeArguments(factory.cloneNode(typeName.right), typeArguments)
-                );
+                typeName = factory.updateQualifiedName(typeName, typeName.left, setIdentifierTypeArguments(factory.cloneNode(typeName.right), typeArguments));
               }
             }
             typeArguments = ref.typeArguments;
@@ -149608,12 +133111,12 @@ ${lanes.join("\n")}
           }
           const typeElements = [];
           for (const signature of resolvedType.callSignatures) {
-            typeElements.push(signatureToSignatureDeclarationHelper(signature, 178 /* CallSignature */, context));
+            typeElements.push(signatureToSignatureDeclarationHelper(signature, 179 /* CallSignature */, context));
           }
           for (const signature of resolvedType.constructSignatures) {
             if (signature.flags & 4 /* Abstract */)
               continue;
-            typeElements.push(signatureToSignatureDeclarationHelper(signature, 179 /* ConstructSignature */, context));
+            typeElements.push(signatureToSignatureDeclarationHelper(signature, 180 /* ConstructSignature */, context));
           }
           for (const info of resolvedType.indexInfos) {
             typeElements.push(indexInfoToIndexSignatureDeclarationHelper(info, context, resolvedType.objectFlags & 1024 /* ReverseMapped */ ? createElidedInformationPlaceholder(context) : void 0));
@@ -149629,7 +133132,7 @@ ${lanes.join("\n")}
               if (propertySymbol.flags & 4194304 /* Prototype */) {
                 continue;
               }
-              if (getDeclarationModifierFlagsFromSymbol(propertySymbol) & (8 /* Private */ | 16 /* Protected */) && context.tracker.reportPrivateInBaseOfClassExpression) {
+              if (getDeclarationModifierFlagsFromSymbol(propertySymbol) & (2 /* Private */ | 4 /* Protected */) && context.tracker.reportPrivateInBaseOfClassExpression) {
                 context.tracker.reportPrivateInBaseOfClassExpression(unescapeLeadingUnderscores(propertySymbol.escapedName));
               }
             }
@@ -149693,44 +133196,68 @@ ${lanes.join("\n")}
         const propertyName = getPropertyNameNodeForSymbol(propertySymbol, context);
         context.enclosingDeclaration = saveEnclosingDeclaration;
         context.approximateLength += symbolName(propertySymbol).length + 1;
+        if (propertySymbol.flags & 98304 /* Accessor */) {
+          const writeType = getWriteTypeOfSymbol(propertySymbol);
+          if (propertyType !== writeType && !isErrorType(propertyType) && !isErrorType(writeType)) {
+            const getterDeclaration = getDeclarationOfKind(propertySymbol, 177 /* GetAccessor */);
+            const getterSignature = getSignatureFromDeclaration(getterDeclaration);
+            typeElements.push(
+              setCommentRange(
+                signatureToSignatureDeclarationHelper(getterSignature, 177 /* GetAccessor */, context, { name: propertyName }),
+                getterDeclaration
+              )
+            );
+            const setterDeclaration = getDeclarationOfKind(propertySymbol, 178 /* SetAccessor */);
+            const setterSignature = getSignatureFromDeclaration(setterDeclaration);
+            typeElements.push(
+              setCommentRange(
+                signatureToSignatureDeclarationHelper(setterSignature, 178 /* SetAccessor */, context, { name: propertyName }),
+                setterDeclaration
+              )
+            );
+            return;
+          }
+        }
         const optionalToken = propertySymbol.flags & 16777216 /* Optional */ ? factory.createToken(58 /* QuestionToken */) : void 0;
         if (propertySymbol.flags & (16 /* Function */ | 8192 /* Method */) && !getPropertiesOfObjectType(propertyType).length && !isReadonlySymbol(propertySymbol)) {
           const signatures = getSignaturesOfType(filterType(propertyType, (t) => !(t.flags & 32768 /* Undefined */)), 0 /* Call */);
           for (const signature of signatures) {
-            const methodDeclaration = signatureToSignatureDeclarationHelper(signature, 172 /* MethodSignature */, context, { name: propertyName, questionToken: optionalToken });
+            const methodDeclaration = signatureToSignatureDeclarationHelper(signature, 173 /* MethodSignature */, context, { name: propertyName, questionToken: optionalToken });
             typeElements.push(preserveCommentsOn(methodDeclaration));
           }
+          if (signatures.length || !optionalToken) {
+            return;
+          }
+        }
+        let propertyTypeNode;
+        if (shouldUsePlaceholderForProperty(propertySymbol, context)) {
+          propertyTypeNode = createElidedInformationPlaceholder(context);
         } else {
-          let propertyTypeNode;
-          if (shouldUsePlaceholderForProperty(propertySymbol, context)) {
-            propertyTypeNode = createElidedInformationPlaceholder(context);
-          } else {
-            if (propertyIsReverseMapped) {
-              context.reverseMappedStack || (context.reverseMappedStack = []);
-              context.reverseMappedStack.push(propertySymbol);
-            }
-            propertyTypeNode = propertyType ? serializeTypeForDeclaration(context, propertyType, propertySymbol, saveEnclosingDeclaration) : factory.createKeywordTypeNode(133 /* AnyKeyword */);
-            if (propertyIsReverseMapped) {
-              context.reverseMappedStack.pop();
-            }
+          if (propertyIsReverseMapped) {
+            context.reverseMappedStack || (context.reverseMappedStack = []);
+            context.reverseMappedStack.push(propertySymbol);
           }
-          const modifiers = isReadonlySymbol(propertySymbol) ? [factory.createToken(148 /* ReadonlyKeyword */)] : void 0;
-          if (modifiers) {
-            context.approximateLength += 9;
+          propertyTypeNode = propertyType ? serializeTypeForDeclaration(context, propertyType, propertySymbol, saveEnclosingDeclaration) : factory.createKeywordTypeNode(133 /* AnyKeyword */);
+          if (propertyIsReverseMapped) {
+            context.reverseMappedStack.pop();
           }
-          const propertySignature = factory.createPropertySignature(
-            modifiers,
-            propertyName,
-            optionalToken,
-            propertyTypeNode
-          );
-          typeElements.push(preserveCommentsOn(propertySignature));
         }
+        const modifiers = isReadonlySymbol(propertySymbol) ? [factory.createToken(148 /* ReadonlyKeyword */)] : void 0;
+        if (modifiers) {
+          context.approximateLength += 9;
+        }
+        const propertySignature = factory.createPropertySignature(
+          modifiers,
+          propertyName,
+          optionalToken,
+          propertyTypeNode
+        );
+        typeElements.push(preserveCommentsOn(propertySignature));
         function preserveCommentsOn(node) {
           var _a2;
-          if (some(propertySymbol.declarations, (d) => d.kind === 354 /* JSDocPropertyTag */)) {
-            const d = (_a2 = propertySymbol.declarations) == null ? void 0 : _a2.find((d2) => d2.kind === 354 /* JSDocPropertyTag */);
-            const commentText = getTextOfJSDocComment(d.comment);
+          const jsdocPropertyTag = (_a2 = propertySymbol.declarations) == null ? void 0 : _a2.find((d) => d.kind === 355 /* JSDocPropertyTag */);
+          if (jsdocPropertyTag) {
+            const commentText = getTextOfJSDocComment(jsdocPropertyTag.comment);
             if (commentText) {
               setSyntheticLeadingComments(node, [{ kind: 3 /* MultiLineCommentTrivia */, text: "*\n * " + commentText.replace(/\n/g, "\n * ") + "\n ", pos: -1, end: -1, hasTrailingNewLine: true }]);
             }
@@ -149835,6 +133362,7 @@ ${lanes.join("\n")}
         );
       }
       function signatureToSignatureDeclarationHelper(signature, kind, context, options) {
+        var _a;
         const suppressAny = context.flags & 256 /* SuppressAnyReturnType */;
         if (suppressAny)
           context.flags &= ~256 /* SuppressAnyReturnType */;
@@ -149884,7 +133412,7 @@ ${lanes.join("\n")}
             }
           }
         }
-        const parameters = (some(expandedParams, (p) => p !== expandedParams[expandedParams.length - 1] && !!(getCheckFlags(p) & 32768 /* RestParameter */)) ? signature.parameters : expandedParams).map((parameter) => symbolToParameterDeclaration(parameter, context, kind === 175 /* Constructor */, options == null ? void 0 : options.privateSymbolVisitor, options == null ? void 0 : options.bundledImports));
+        const parameters = (some(expandedParams, (p) => p !== expandedParams[expandedParams.length - 1] && !!(getCheckFlags(p) & 32768 /* RestParameter */)) ? signature.parameters : expandedParams).map((parameter) => symbolToParameterDeclaration(parameter, context, kind === 176 /* Constructor */, options == null ? void 0 : options.privateSymbolVisitor, options == null ? void 0 : options.bundledImports));
         const thisParameter = context.flags & 33554432 /* OmitThisParameter */ ? void 0 : tryGetThisParameterDeclaration(signature, context);
         if (thisParameter) {
           parameters.unshift(thisParameter);
@@ -149905,11 +133433,11 @@ ${lanes.join("\n")}
           }
         }
         let modifiers = options == null ? void 0 : options.modifiers;
-        if (kind === 184 /* ConstructorType */ && signature.flags & 4 /* Abstract */) {
+        if (kind === 185 /* ConstructorType */ && signature.flags & 4 /* Abstract */) {
           const flags = modifiersToFlags(modifiers);
-          modifiers = factory.createModifiersFromModifierFlags(flags | 256 /* Abstract */);
+          modifiers = factory.createModifiersFromModifierFlags(flags | 64 /* Abstract */);
         }
-        const node = kind === 178 /* CallSignature */ ? factory.createCallSignature(typeParameters, parameters, returnTypeNode) : kind === 179 /* ConstructSignature */ ? factory.createConstructSignature(typeParameters, parameters, returnTypeNode) : kind === 172 /* MethodSignature */ ? factory.createMethodSignature(modifiers, (options == null ? void 0 : options.name) ?? factory.createIdentifier(""), options == null ? void 0 : options.questionToken, typeParameters, parameters, returnTypeNode) : kind === 173 /* MethodDeclaration */ ? factory.createMethodDeclaration(
+        const node = kind === 179 /* CallSignature */ ? factory.createCallSignature(typeParameters, parameters, returnTypeNode) : kind === 180 /* ConstructSignature */ ? factory.createConstructSignature(typeParameters, parameters, returnTypeNode) : kind === 173 /* MethodSignature */ ? factory.createMethodSignature(modifiers, (options == null ? void 0 : options.name) ?? factory.createIdentifier(""), options == null ? void 0 : options.questionToken, typeParameters, parameters, returnTypeNode) : kind === 174 /* MethodDeclaration */ ? factory.createMethodDeclaration(
           modifiers,
           /*asteriskToken*/
           void 0,
@@ -149921,25 +133449,25 @@ ${lanes.join("\n")}
           returnTypeNode,
           /*body*/
           void 0
-        ) : kind === 175 /* Constructor */ ? factory.createConstructorDeclaration(
+        ) : kind === 176 /* Constructor */ ? factory.createConstructorDeclaration(
           modifiers,
           parameters,
           /*body*/
           void 0
-        ) : kind === 176 /* GetAccessor */ ? factory.createGetAccessorDeclaration(
+        ) : kind === 177 /* GetAccessor */ ? factory.createGetAccessorDeclaration(
           modifiers,
           (options == null ? void 0 : options.name) ?? factory.createIdentifier(""),
           parameters,
           returnTypeNode,
           /*body*/
           void 0
-        ) : kind === 177 /* SetAccessor */ ? factory.createSetAccessorDeclaration(
+        ) : kind === 178 /* SetAccessor */ ? factory.createSetAccessorDeclaration(
           modifiers,
           (options == null ? void 0 : options.name) ?? factory.createIdentifier(""),
           parameters,
           /*body*/
           void 0
-        ) : kind === 180 /* IndexSignature */ ? factory.createIndexSignature(modifiers, parameters, returnTypeNode) : kind === 323 /* JSDocFunctionType */ ? factory.createJSDocFunctionType(parameters, returnTypeNode) : kind === 183 /* FunctionType */ ? factory.createFunctionTypeNode(typeParameters, parameters, returnTypeNode ?? factory.createTypeReferenceNode(factory.createIdentifier(""))) : kind === 184 /* ConstructorType */ ? factory.createConstructorTypeNode(modifiers, typeParameters, parameters, returnTypeNode ?? factory.createTypeReferenceNode(factory.createIdentifier(""))) : kind === 261 /* FunctionDeclaration */ ? factory.createFunctionDeclaration(
+        ) : kind === 181 /* IndexSignature */ ? factory.createIndexSignature(modifiers, parameters, returnTypeNode) : kind === 324 /* JSDocFunctionType */ ? factory.createJSDocFunctionType(parameters, returnTypeNode) : kind === 184 /* FunctionType */ ? factory.createFunctionTypeNode(typeParameters, parameters, returnTypeNode ?? factory.createTypeReferenceNode(factory.createIdentifier(""))) : kind === 185 /* ConstructorType */ ? factory.createConstructorTypeNode(modifiers, typeParameters, parameters, returnTypeNode ?? factory.createTypeReferenceNode(factory.createIdentifier(""))) : kind === 262 /* FunctionDeclaration */ ? factory.createFunctionDeclaration(
           modifiers,
           /*asteriskToken*/
           void 0,
@@ -149949,7 +133477,7 @@ ${lanes.join("\n")}
           returnTypeNode,
           /*body*/
           void 0
-        ) : kind === 217 /* FunctionExpression */ ? factory.createFunctionExpression(
+        ) : kind === 218 /* FunctionExpression */ ? factory.createFunctionExpression(
           modifiers,
           /*asteriskToken*/
           void 0,
@@ -149958,7 +133486,7 @@ ${lanes.join("\n")}
           parameters,
           returnTypeNode,
           factory.createBlock([])
-        ) : kind === 218 /* ArrowFunction */ ? factory.createArrowFunction(
+        ) : kind === 219 /* ArrowFunction */ ? factory.createArrowFunction(
           modifiers,
           typeParameters,
           parameters,
@@ -149970,6 +133498,20 @@ ${lanes.join("\n")}
         if (typeArguments) {
           node.typeArguments = factory.createNodeArray(typeArguments);
         }
+        if (((_a = signature.declaration) == null ? void 0 : _a.kind) === 330 /* JSDocSignature */ && signature.declaration.parent.kind === 346 /* JSDocOverloadTag */) {
+          const comment = getTextOfNode(
+            signature.declaration.parent.parent,
+            /*includeTrivia*/
+            true
+          ).slice(2, -2).split(/\r\n|\n|\r/).map((line) => line.replace(/^\s+/, " ")).join("\n");
+          addSyntheticLeadingComment(
+            node,
+            3 /* MultiLineCommentTrivia */,
+            comment,
+            /*hasTrailingNewLine*/
+            true
+          );
+        }
         cleanup == null ? void 0 : cleanup();
         return node;
       }
@@ -150007,11 +133549,17 @@ ${lanes.join("\n")}
         const constraintNode = constraint && typeToTypeNodeHelper(constraint, context);
         return typeParameterToDeclarationWithConstraint(type, context, constraintNode);
       }
-      function symbolToParameterDeclaration(parameterSymbol, context, preserveModifierFlags, privateSymbolVisitor, bundledImports) {
-        let parameterDeclaration = getDeclarationOfKind(parameterSymbol, 168 /* Parameter */);
-        if (!parameterDeclaration && !isTransientSymbol(parameterSymbol)) {
-          parameterDeclaration = getDeclarationOfKind(parameterSymbol, 347 /* JSDocParameterTag */);
+      function getEffectiveParameterDeclaration(parameterSymbol) {
+        const parameterDeclaration = getDeclarationOfKind(parameterSymbol, 169 /* Parameter */);
+        if (parameterDeclaration) {
+          return parameterDeclaration;
+        }
+        if (!isTransientSymbol(parameterSymbol)) {
+          return getDeclarationOfKind(parameterSymbol, 348 /* JSDocParameterTag */);
         }
+      }
+      function symbolToParameterDeclaration(parameterSymbol, context, preserveModifierFlags, privateSymbolVisitor, bundledImports) {
+        const parameterDeclaration = getEffectiveParameterDeclaration(parameterSymbol);
         let parameterType = getTypeOfSymbol(parameterSymbol);
         if (parameterDeclaration && isRequiredInitializedParameter(parameterDeclaration)) {
           parameterType = getOptionalType(parameterType);
@@ -150020,7 +133568,7 @@ ${lanes.join("\n")}
         const modifiers = !(context.flags & 8192 /* OmitParameterModifiers */) && preserveModifierFlags && parameterDeclaration && canHaveModifiers(parameterDeclaration) ? map(getModifiers(parameterDeclaration), factory.cloneNode) : void 0;
         const isRest = parameterDeclaration && isRestParameter(parameterDeclaration) || getCheckFlags(parameterSymbol) & 32768 /* RestParameter */;
         const dotDotDotToken = isRest ? factory.createToken(26 /* DotDotDotToken */) : void 0;
-        const name = parameterDeclaration ? parameterDeclaration.name ? parameterDeclaration.name.kind === 80 /* Identifier */ ? setEmitFlags(factory.cloneNode(parameterDeclaration.name), 16777216 /* NoAsciiEscaping */) : parameterDeclaration.name.kind === 165 /* QualifiedName */ ? setEmitFlags(factory.cloneNode(parameterDeclaration.name.right), 16777216 /* NoAsciiEscaping */) : cloneBindingName(parameterDeclaration.name) : symbolName(parameterSymbol) : symbolName(parameterSymbol);
+        const name = parameterToParameterDeclarationName(parameterSymbol, parameterDeclaration, context);
         const isOptional = parameterDeclaration && isOptionalParameter(parameterDeclaration) || getCheckFlags(parameterSymbol) & 16384 /* OptionalParameter */;
         const questionToken = isOptional ? factory.createToken(58 /* QuestionToken */) : void 0;
         const parameterNode = factory.createParameterDeclaration(
@@ -150034,6 +133582,9 @@ ${lanes.join("\n")}
         );
         context.approximateLength += symbolName(parameterSymbol).length + 3;
         return parameterNode;
+      }
+      function parameterToParameterDeclarationName(parameterSymbol, parameterDeclaration, context) {
+        return parameterDeclaration ? parameterDeclaration.name ? parameterDeclaration.name.kind === 80 /* Identifier */ ? setEmitFlags(factory.cloneNode(parameterDeclaration.name), 16777216 /* NoAsciiEscaping */) : parameterDeclaration.name.kind === 166 /* QualifiedName */ ? setEmitFlags(factory.cloneNode(parameterDeclaration.name.right), 16777216 /* NoAsciiEscaping */) : cloneBindingName(parameterDeclaration.name) : symbolName(parameterSymbol) : symbolName(parameterSymbol);
         function cloneBindingName(node) {
           return elideInitializerAndSetEmitFlags(node);
           function elideInitializerAndSetEmitFlags(node2) {
@@ -150109,7 +133660,9 @@ ${lanes.join("\n")}
           if (!accessibleSymbolChain || needsQualification(accessibleSymbolChain[0], context.enclosingDeclaration, accessibleSymbolChain.length === 1 ? meaning2 : getQualifiedLeftMeaning(meaning2))) {
             const parents = getContainersOfSymbol(accessibleSymbolChain ? accessibleSymbolChain[0] : symbol2, context.enclosingDeclaration, meaning2);
             if (length(parents)) {
-              parentSpecifiers = parents.map((symbol3) => some(symbol3.declarations, hasNonGlobalAugmentationExternalModuleSymbol) ? getSpecifierForModuleSymbol(symbol3, context) : void 0);
+              parentSpecifiers = parents.map(
+                (symbol3) => some(symbol3.declarations, hasNonGlobalAugmentationExternalModuleSymbol) ? getSpecifierForModuleSymbol(symbol3, context) : void 0
+              );
               const indices = parents.map((_, i) => i);
               indices.sort(sortByBestName);
               const sortedParents = indices.map((i) => parents[i]);
@@ -150200,11 +133753,11 @@ ${lanes.join("\n")}
         return top;
       }
       function getSpecifierForModuleSymbol(symbol, context, overrideImportMode) {
-        let file = getDeclarationOfKind(symbol, 311 /* SourceFile */);
+        let file = getDeclarationOfKind(symbol, 312 /* SourceFile */);
         if (!file) {
           const equivalentFileSymbol = firstDefined(symbol.declarations, (d) => getFileSymbolIfFileSymbolExportEqualsContainer(d, symbol));
           if (equivalentFileSymbol) {
-            file = getDeclarationOfKind(equivalentFileSymbol, 311 /* SourceFile */);
+            file = getDeclarationOfKind(equivalentFileSymbol, 312 /* SourceFile */);
           }
         }
         if (file && file.moduleName !== void 0) {
@@ -150260,7 +133813,6 @@ ${lanes.join("\n")}
         return symbol.parent ? factory.createQualifiedName(symbolToEntityNameNode(symbol.parent), identifier) : identifier;
       }
       function symbolToTypeNode(symbol, context, meaning, overrideTypeArguments) {
-        var _a, _b, _c, _d;
         const chain = lookupSymbolChain(symbol, context, meaning, !(context.flags & 16384 /* UseAliasDefinedOutsideCurrentScope */));
         const isTypeOf = meaning === 111551 /* Value */;
         if (some(chain[0].declarations, hasNonGlobalAugmentationExternalModuleSymbol)) {
@@ -150269,40 +133821,42 @@ ${lanes.join("\n")}
           const contextFile = getSourceFileOfNode(getOriginalNode(context.enclosingDeclaration));
           const targetFile = getSourceFileOfModule(chain[0]);
           let specifier;
-          let assertion;
+          let attributes;
           if (getEmitModuleResolutionKind(compilerOptions) === 3 /* Node16 */ || getEmitModuleResolutionKind(compilerOptions) === 99 /* NodeNext */) {
             if ((targetFile == null ? void 0 : targetFile.impliedNodeFormat) === 99 /* ESNext */ && targetFile.impliedNodeFormat !== (contextFile == null ? void 0 : contextFile.impliedNodeFormat)) {
               specifier = getSpecifierForModuleSymbol(chain[0], context, 99 /* ESNext */);
-              assertion = factory.createImportTypeAssertionContainer(factory.createAssertClause(factory.createNodeArray([
-                factory.createAssertEntry(
-                  factory.createStringLiteral("resolution-mode"),
-                  factory.createStringLiteral("import")
-                )
-              ])));
-              (_b = (_a = context.tracker).reportImportTypeNodeResolutionModeOverride) == null ? void 0 : _b.call(_a);
+              attributes = factory.createImportAttributes(
+                factory.createNodeArray([
+                  factory.createImportAttribute(
+                    factory.createStringLiteral("resolution-mode"),
+                    factory.createStringLiteral("import")
+                  )
+                ])
+              );
             }
           }
           if (!specifier) {
             specifier = getSpecifierForModuleSymbol(chain[0], context);
           }
-          if (!(context.flags & 67108864 /* AllowNodeModulesRelativePaths */) && getEmitModuleResolutionKind(compilerOptions) !== 1 /* Classic */ && specifier.indexOf("/node_modules/") >= 0) {
+          if (!(context.flags & 67108864 /* AllowNodeModulesRelativePaths */) && getEmitModuleResolutionKind(compilerOptions) !== 1 /* Classic */ && specifier.includes("/node_modules/")) {
             const oldSpecifier = specifier;
             if (getEmitModuleResolutionKind(compilerOptions) === 3 /* Node16 */ || getEmitModuleResolutionKind(compilerOptions) === 99 /* NodeNext */) {
               const swappedMode = (contextFile == null ? void 0 : contextFile.impliedNodeFormat) === 99 /* ESNext */ ? 1 /* CommonJS */ : 99 /* ESNext */;
               specifier = getSpecifierForModuleSymbol(chain[0], context, swappedMode);
-              if (specifier.indexOf("/node_modules/") >= 0) {
+              if (specifier.includes("/node_modules/")) {
                 specifier = oldSpecifier;
               } else {
-                assertion = factory.createImportTypeAssertionContainer(factory.createAssertClause(factory.createNodeArray([
-                  factory.createAssertEntry(
-                    factory.createStringLiteral("resolution-mode"),
-                    factory.createStringLiteral(swappedMode === 99 /* ESNext */ ? "import" : "require")
-                  )
-                ])));
-                (_d = (_c = context.tracker).reportImportTypeNodeResolutionModeOverride) == null ? void 0 : _d.call(_c);
+                attributes = factory.createImportAttributes(
+                  factory.createNodeArray([
+                    factory.createImportAttribute(
+                      factory.createStringLiteral("resolution-mode"),
+                      factory.createStringLiteral(swappedMode === 99 /* ESNext */ ? "import" : "require")
+                    )
+                  ])
+                );
               }
             }
-            if (!assertion) {
+            if (!attributes) {
               context.encounteredError = true;
               if (context.tracker.reportLikelyUnsafeImportRequiredError) {
                 context.tracker.reportLikelyUnsafeImportRequiredError(oldSpecifier);
@@ -150322,11 +133876,11 @@ ${lanes.join("\n")}
                 void 0
               );
             }
-            return factory.createImportTypeNode(lit, assertion, nonRootParts, typeParameterNodes, isTypeOf);
+            return factory.createImportTypeNode(lit, attributes, nonRootParts, typeParameterNodes, isTypeOf);
           } else {
             const splitNode = getTopmostIndexedAccessType(nonRootParts);
             const qualifier = splitNode.objectType.typeName;
-            return factory.createIndexedAccessTypeNode(factory.createImportTypeNode(lit, assertion, qualifier, typeParameterNodes, isTypeOf), splitNode.indexType);
+            return factory.createIndexedAccessTypeNode(factory.createImportTypeNode(lit, attributes, qualifier, typeParameterNodes, isTypeOf), splitNode.indexType);
           }
         }
         const entityName = createAccessFromSymbolChain(chain, chain.length - 1, 0);
@@ -150526,7 +134080,18 @@ ${lanes.join("\n")}
       }
       function isStringNamed(d) {
         const name = getNameOfDeclaration(d);
-        return !!name && isStringLiteral(name);
+        if (!name) {
+          return false;
+        }
+        if (isComputedPropertyName(name)) {
+          const type = checkExpression(name.expression);
+          return !!(type.flags & 402653316 /* StringLike */);
+        }
+        if (isElementAccessExpression(name)) {
+          const type = checkExpression(name.argumentExpression);
+          return !!(type.flags & 402653316 /* StringLike */);
+        }
+        return isStringLiteral(name);
       }
       function isSingleQuotedStringNamed(d) {
         const name = getNameOfDeclaration(d);
@@ -150539,14 +134104,15 @@ ${lanes.join("\n")}
       function getPropertyNameNodeForSymbol(symbol, context) {
         const stringNamed = !!length(symbol.declarations) && every(symbol.declarations, isStringNamed);
         const singleQuote = !!length(symbol.declarations) && every(symbol.declarations, isSingleQuotedStringNamed);
-        const fromNameType = getPropertyNameNodeForSymbolFromNameType(symbol, context, singleQuote, stringNamed);
+        const isMethod = !!(symbol.flags & 8192 /* Method */);
+        const fromNameType = getPropertyNameNodeForSymbolFromNameType(symbol, context, singleQuote, stringNamed, isMethod);
         if (fromNameType) {
           return fromNameType;
         }
         const rawName = unescapeLeadingUnderscores(symbol.escapedName);
-        return createPropertyNameNodeForIdentifierOrLiteral(rawName, getEmitScriptTarget(compilerOptions), singleQuote, stringNamed);
+        return createPropertyNameNodeForIdentifierOrLiteral(rawName, getEmitScriptTarget(compilerOptions), singleQuote, stringNamed, isMethod);
       }
-      function getPropertyNameNodeForSymbolFromNameType(symbol, context, singleQuote, stringNamed) {
+      function getPropertyNameNodeForSymbolFromNameType(symbol, context, singleQuote, stringNamed, isMethod) {
         const nameType = getSymbolLinks(symbol).nameType;
         if (nameType) {
           if (nameType.flags & 384 /* StringOrNumberLiteral */) {
@@ -150557,7 +134123,7 @@ ${lanes.join("\n")}
             if (isNumericLiteralName(name) && startsWith(name, "-")) {
               return factory.createComputedPropertyName(factory.createNumericLiteral(+name));
             }
-            return createPropertyNameNodeForIdentifierOrLiteral(name, getEmitScriptTarget(compilerOptions));
+            return createPropertyNameNodeForIdentifierOrLiteral(name, getEmitScriptTarget(compilerOptions), singleQuote, stringNamed, isMethod);
           }
           if (nameType.flags & 8192 /* UniqueESSymbol */) {
             return factory.createComputedPropertyName(symbolToExpression(nameType.symbol, context, 111551 /* Value */));
@@ -150684,7 +134250,7 @@ ${lanes.join("\n")}
         }
         return transformed === existing ? setTextRange(factory.cloneNode(existing), existing) : transformed;
         function visitExistingNodeTreeSymbols(node) {
-          if (isJSDocAllType(node) || node.kind === 325 /* JSDocNamepathType */) {
+          if (isJSDocAllType(node) || node.kind === 326 /* JSDocNamepathType */) {
             return factory.createKeywordTypeNode(133 /* AnyKeyword */);
           }
           if (isJSDocUnknownType(node)) {
@@ -150790,7 +134356,7 @@ ${lanes.join("\n")}
             return factory.updateImportTypeNode(
               node,
               factory.updateLiteralTypeNode(node.argument, rewriteModuleSpecifier(node, node.argument.literal)),
-              node.assertions,
+              node.attributes,
               node.qualifier,
               visitNodes2(node.typeArguments, visitExistingNodeTreeSymbols, isTypeNode),
               node.isTypeOf
@@ -150846,15 +134412,16 @@ ${lanes.join("\n")}
         }
       }
       function symbolTableToDeclarationStatements(symbolTable, context, bundled) {
+        var _a;
         const serializePropertySymbolForClass = makeSerializePropertySymbol(
           factory.createPropertyDeclaration,
-          173 /* MethodDeclaration */,
+          174 /* MethodDeclaration */,
           /*useAccessors*/
           true
         );
         const serializePropertySymbolForInterfaceWorker = makeSerializePropertySymbol(
           (mods, name, question, type) => factory.createPropertySignature(mods, name, question, type),
-          172 /* MethodSignature */,
+          173 /* MethodSignature */,
           /*useAccessors*/
           false
         );
@@ -150867,12 +134434,15 @@ ${lanes.join("\n")}
           ...oldcontext,
           usedSymbolNames: new Set(oldcontext.usedSymbolNames),
           remappedSymbolNames: /* @__PURE__ */ new Map(),
+          remappedSymbolReferences: new Map((_a = oldcontext.remappedSymbolReferences) == null ? void 0 : _a.entries()),
           tracker: void 0
         };
         const tracker = {
           ...oldcontext.tracker.inner,
           trackSymbol: (sym, decl, meaning) => {
-            var _a;
+            var _a2, _b;
+            if ((_a2 = context.remappedSymbolNames) == null ? void 0 : _a2.has(getSymbolId(sym)))
+              return false;
             const accessibleResult = isSymbolAccessible(
               sym,
               decl,
@@ -150883,9 +134453,13 @@ ${lanes.join("\n")}
             if (accessibleResult.accessibility === 0 /* Accessible */) {
               const chain = lookupSymbolChainWorker(sym, context, meaning);
               if (!(sym.flags & 4 /* Property */)) {
-                includePrivateSymbol(chain[0]);
+                const root = chain[0];
+                const contextFile = getSourceFileOfNode(oldcontext.enclosingDeclaration);
+                if (some(root.declarations, (d) => getSourceFileOfNode(d) === contextFile)) {
+                  includePrivateSymbol(root);
+                }
               }
-            } else if ((_a = oldcontext.tracker.inner) == null ? void 0 : _a.trackSymbol) {
+            } else if ((_b = oldcontext.tracker.inner) == null ? void 0 : _b.trackSymbol) {
               return oldcontext.tracker.inner.trackSymbol(sym, decl, meaning);
             }
             return false;
@@ -150918,7 +134492,7 @@ ${lanes.join("\n")}
           const nsIndex = findIndex(statements, isModuleDeclaration);
           let ns = nsIndex !== -1 ? statements[nsIndex] : void 0;
           if (ns && exportAssignment && exportAssignment.isExportEquals && isIdentifier(exportAssignment.expression) && isIdentifier(ns.name) && idText(ns.name) === idText(exportAssignment.expression) && ns.body && isModuleBlock(ns.body)) {
-            const excessExports = filter(statements, (s) => !!(getEffectiveModifierFlags(s) & 1 /* Export */));
+            const excessExports = filter(statements, (s) => !!(getEffectiveModifierFlags(s) & 32 /* Export */));
             const name = ns.name;
             let body = ns.body;
             if (length(excessExports)) {
@@ -150928,30 +134502,33 @@ ${lanes.join("\n")}
                 ns.name,
                 body = factory.updateModuleBlock(
                   body,
-                  factory.createNodeArray([...ns.body.statements, factory.createExportDeclaration(
-                    /*modifiers*/
-                    void 0,
-                    /*isTypeOnly*/
-                    false,
-                    factory.createNamedExports(map(flatMap(excessExports, (e) => getNamesOfDeclaration(e)), (id) => factory.createExportSpecifier(
+                  factory.createNodeArray([
+                    ...ns.body.statements,
+                    factory.createExportDeclaration(
+                      /*modifiers*/
+                      void 0,
                       /*isTypeOnly*/
                       false,
-                      /*propertyName*/
-                      void 0,
-                      id
-                    ))),
-                    /*moduleSpecifier*/
-                    void 0
-                  )])
+                      factory.createNamedExports(map(flatMap(excessExports, (e) => getNamesOfDeclaration(e)), (id) => factory.createExportSpecifier(
+                        /*isTypeOnly*/
+                        false,
+                        /*propertyName*/
+                        void 0,
+                        id
+                      ))),
+                      /*moduleSpecifier*/
+                      void 0
+                    )
+                  ])
                 )
               );
               statements = [...statements.slice(0, nsIndex), ns, ...statements.slice(nsIndex + 1)];
             }
             if (!find(statements, (s) => s !== ns && nodeHasName(s, name))) {
               results = [];
-              const mixinExportFlag = !some(body.statements, (s) => hasSyntacticModifier(s, 1 /* Export */) || isExportAssignment(s) || isExportDeclaration(s));
+              const mixinExportFlag = !some(body.statements, (s) => hasSyntacticModifier(s, 32 /* Export */) || isExportAssignment(s) || isExportDeclaration(s));
               forEach(body.statements, (s) => {
-                addResult(s, mixinExportFlag ? 1 /* Export */ : 0 /* None */);
+                addResult(s, mixinExportFlag ? 32 /* Export */ : 0 /* None */);
               });
               statements = [...filter(statements, (s) => s !== ns && s !== exportAssignment), ...results];
             }
@@ -150962,15 +134539,18 @@ ${lanes.join("\n")}
           const exports = filter(statements, (d) => isExportDeclaration(d) && !d.moduleSpecifier && !!d.exportClause && isNamedExports(d.exportClause));
           if (length(exports) > 1) {
             const nonExports = filter(statements, (d) => !isExportDeclaration(d) || !!d.moduleSpecifier || !d.exportClause);
-            statements = [...nonExports, factory.createExportDeclaration(
-              /*modifiers*/
-              void 0,
-              /*isTypeOnly*/
-              false,
-              factory.createNamedExports(flatMap(exports, (e) => cast(e.exportClause, isNamedExports).elements)),
-              /*moduleSpecifier*/
-              void 0
-            )];
+            statements = [
+              ...nonExports,
+              factory.createExportDeclaration(
+                /*modifiers*/
+                void 0,
+                /*isTypeOnly*/
+                false,
+                factory.createNamedExports(flatMap(exports, (e) => cast(e.exportClause, isNamedExports).elements)),
+                /*moduleSpecifier*/
+                void 0
+              )
+            ];
           }
           const reexports = filter(statements, (d) => isExportDeclaration(d) && !!d.moduleSpecifier && !!d.exportClause && isNamedExports(d.exportClause));
           if (length(reexports) > 1) {
@@ -150979,7 +134559,7 @@ ${lanes.join("\n")}
               for (const group2 of groups) {
                 if (group2.length > 1) {
                   statements = [
-                    ...filter(statements, (s) => group2.indexOf(s) === -1),
+                    ...filter(statements, (s) => !group2.includes(s)),
                     factory.createExportDeclaration(
                       /*modifiers*/
                       void 0,
@@ -150996,7 +134576,7 @@ ${lanes.join("\n")}
           return statements;
         }
         function inlineExportModifiers(statements) {
-          const index = findIndex(statements, (d) => isExportDeclaration(d) && !d.moduleSpecifier && !d.assertClause && !!d.exportClause && isNamedExports(d.exportClause));
+          const index = findIndex(statements, (d) => isExportDeclaration(d) && !d.moduleSpecifier && !d.attributes && !!d.exportClause && isNamedExports(d.exportClause));
           if (index >= 0) {
             const exportDecl = statements[index];
             const replacements = mapDefined(exportDecl.exportClause.elements, (e) => {
@@ -151024,7 +134604,7 @@ ${lanes.join("\n")}
                   replacements
                 ),
                 exportDecl.moduleSpecifier,
-                exportDecl.assertClause
+                exportDecl.attributes
               );
             }
           }
@@ -151040,12 +134620,12 @@ ${lanes.join("\n")}
           return statements;
         }
         function addExportModifier(node) {
-          const flags = (getEffectiveModifierFlags(node) | 1 /* Export */) & ~2 /* Ambient */;
-          return factory.updateModifiers(node, flags);
+          const flags = (getEffectiveModifierFlags(node) | 32 /* Export */) & ~128 /* Ambient */;
+          return factory.replaceModifiers(node, flags);
         }
         function removeExportModifier(node) {
-          const flags = getEffectiveModifierFlags(node) & ~1 /* Export */;
-          return factory.updateModifiers(node, flags);
+          const flags = getEffectiveModifierFlags(node) & ~32 /* Export */;
+          return factory.replaceModifiers(node, flags);
         }
         function visitSymbolTable(symbolTable2, suppressNewPrivateContext, propertyAsAlias) {
           if (!suppressNewPrivateContext) {
@@ -151085,13 +134665,19 @@ ${lanes.join("\n")}
             if (context.reportedDiagnostic) {
               oldcontext.reportedDiagnostic = context.reportedDiagnostic;
             }
+            if (context.trackedSymbols) {
+              if (!oldContext.trackedSymbols)
+                oldContext.trackedSymbols = context.trackedSymbols;
+              else
+                Debug.assert(context.trackedSymbols === oldContext.trackedSymbols);
+            }
             context = oldContext;
           }
         }
-        function serializeSymbolWorker(symbol, isPrivate, propertyAsAlias) {
-          var _a, _b, _c, _d;
-          const symbolName2 = unescapeLeadingUnderscores(symbol.escapedName);
-          const isDefault = symbol.escapedName === "default" /* Default */;
+        function serializeSymbolWorker(symbol, isPrivate, propertyAsAlias, escapedSymbolName = symbol.escapedName) {
+          var _a2, _b, _c, _d, _e, _f;
+          const symbolName2 = unescapeLeadingUnderscores(escapedSymbolName);
+          const isDefault = escapedSymbolName === "default" /* Default */;
           if (isPrivate && !(context.flags & 131072 /* AllowAnonymousIdentifier */) && isStringANonContextualKeyword(symbolName2) && !isDefault) {
             context.encounteredError = true;
             return;
@@ -151101,8 +134687,8 @@ ${lanes.join("\n")}
           if (needsPostExportDefault || needsExportDeclaration) {
             isPrivate = true;
           }
-          const modifierFlags = (!isPrivate ? 1 /* Export */ : 0) | (isDefault && !needsPostExportDefault ? 1024 /* Default */ : 0);
-          const isConstMergedWithNS = symbol.flags & 1536 /* Module */ && symbol.flags & (2 /* BlockScopedVariable */ | 1 /* FunctionScopedVariable */ | 4 /* Property */) && symbol.escapedName !== "export=" /* ExportEquals */;
+          const modifierFlags = (!isPrivate ? 32 /* Export */ : 0) | (isDefault && !needsPostExportDefault ? 2048 /* Default */ : 0);
+          const isConstMergedWithNS = symbol.flags & 1536 /* Module */ && symbol.flags & (2 /* BlockScopedVariable */ | 1 /* FunctionScopedVariable */ | 4 /* Property */) && escapedSymbolName !== "export=" /* ExportEquals */;
           const isConstMergedWithNSPrintableAsSignatureMerge = isConstMergedWithNS && isTypeRepresentableAsFunctionNamespaceMerge(getTypeOfSymbol(symbol), symbol);
           if (symbol.flags & (16 /* Function */ | 8192 /* Method */) || isConstMergedWithNSPrintableAsSignatureMerge) {
             serializeAsFunctionNamespaceMerge(getTypeOfSymbol(symbol), symbol, getInternalSymbolName(symbol, symbolName2), modifierFlags);
@@ -151110,7 +134696,7 @@ ${lanes.join("\n")}
           if (symbol.flags & 524288 /* TypeAlias */) {
             serializeTypeAlias(symbol, symbolName2, modifierFlags);
           }
-          if (symbol.flags & (2 /* BlockScopedVariable */ | 1 /* FunctionScopedVariable */ | 4 /* Property */ | 98304 /* Accessor */) && symbol.escapedName !== "export=" /* ExportEquals */ && !(symbol.flags & 4194304 /* Prototype */) && !(symbol.flags & 32 /* Class */) && !(symbol.flags & 8192 /* Method */) && !isConstMergedWithNSPrintableAsSignatureMerge) {
+          if (symbol.flags & (2 /* BlockScopedVariable */ | 1 /* FunctionScopedVariable */ | 4 /* Property */ | 98304 /* Accessor */) && escapedSymbolName !== "export=" /* ExportEquals */ && !(symbol.flags & 4194304 /* Prototype */) && !(symbol.flags & 32 /* Class */) && !(symbol.flags & 8192 /* Method */) && !isConstMergedWithNSPrintableAsSignatureMerge) {
             if (propertyAsAlias) {
               const createdExport = serializeMaybeAliasAssignment(symbol);
               if (createdExport) {
@@ -151120,17 +134706,24 @@ ${lanes.join("\n")}
             } else {
               const type = getTypeOfSymbol(symbol);
               const localName = getInternalSymbolName(symbol, symbolName2);
-              if (!(symbol.flags & 16 /* Function */) && isTypeRepresentableAsFunctionNamespaceMerge(type, symbol)) {
+              if (type.symbol && type.symbol !== symbol && type.symbol.flags & 16 /* Function */ && some(type.symbol.declarations, isFunctionExpressionOrArrowFunction) && (((_a2 = type.symbol.members) == null ? void 0 : _a2.size) || ((_b = type.symbol.exports) == null ? void 0 : _b.size))) {
+                if (!context.remappedSymbolReferences) {
+                  context.remappedSymbolReferences = /* @__PURE__ */ new Map();
+                }
+                context.remappedSymbolReferences.set(getSymbolId(type.symbol), symbol);
+                serializeSymbolWorker(type.symbol, isPrivate, propertyAsAlias, escapedSymbolName);
+                context.remappedSymbolReferences.delete(getSymbolId(type.symbol));
+              } else if (!(symbol.flags & 16 /* Function */) && isTypeRepresentableAsFunctionNamespaceMerge(type, symbol)) {
                 serializeAsFunctionNamespaceMerge(type, symbol, localName, modifierFlags);
               } else {
-                const flags = !(symbol.flags & 2 /* BlockScopedVariable */) ? ((_a = symbol.parent) == null ? void 0 : _a.valueDeclaration) && isSourceFile((_b = symbol.parent) == null ? void 0 : _b.valueDeclaration) ? 2 /* Const */ : void 0 : isConstVariable(symbol) ? 2 /* Const */ : 1 /* Let */;
+                const flags = !(symbol.flags & 2 /* BlockScopedVariable */) ? ((_c = symbol.parent) == null ? void 0 : _c.valueDeclaration) && isSourceFile((_d = symbol.parent) == null ? void 0 : _d.valueDeclaration) ? 2 /* Const */ : void 0 : isConstantVariable(symbol) ? 2 /* Const */ : 1 /* Let */;
                 const name = needsPostExportDefault || !(symbol.flags & 4 /* Property */) ? localName : getUnusedName(localName, symbol);
                 let textRange = symbol.declarations && find(symbol.declarations, (d) => isVariableDeclaration(d));
                 if (textRange && isVariableDeclarationList(textRange.parent) && textRange.parent.declarations.length === 1) {
                   textRange = textRange.parent.parent;
                 }
-                const propertyAccessRequire = (_c = symbol.declarations) == null ? void 0 : _c.find(isPropertyAccessExpression);
-                if (propertyAccessRequire && isBinaryExpression(propertyAccessRequire.parent) && isIdentifier(propertyAccessRequire.parent.right) && ((_d = type.symbol) == null ? void 0 : _d.valueDeclaration) && isSourceFile(type.symbol.valueDeclaration)) {
+                const propertyAccessRequire = (_e = symbol.declarations) == null ? void 0 : _e.find(isPropertyAccessExpression);
+                if (propertyAccessRequire && isBinaryExpression(propertyAccessRequire.parent) && isIdentifier(propertyAccessRequire.parent.right) && ((_f = type.symbol) == null ? void 0 : _f.valueDeclaration) && isSourceFile(type.symbol.valueDeclaration)) {
                   const alias = localName === propertyAccessRequire.parent.right.escapedText ? void 0 : propertyAccessRequire.parent.right;
                   addResult(
                     factory.createExportDeclaration(
@@ -151149,19 +134742,22 @@ ${lanes.join("\n")}
                   );
                   context.tracker.trackSymbol(type.symbol, context.enclosingDeclaration, 111551 /* Value */);
                 } else {
-                  const statement = setTextRange(factory.createVariableStatement(
-                    /*modifiers*/
-                    void 0,
-                    factory.createVariableDeclarationList([
-                      factory.createVariableDeclaration(
-                        name,
-                        /*exclamationToken*/
-                        void 0,
-                        serializeTypeForDeclaration(context, type, symbol, enclosingDeclaration, includePrivateSymbol, bundled)
-                      )
-                    ], flags)
-                  ), textRange);
-                  addResult(statement, name !== localName ? modifierFlags & ~1 /* Export */ : modifierFlags);
+                  const statement = setTextRange(
+                    factory.createVariableStatement(
+                      /*modifiers*/
+                      void 0,
+                      factory.createVariableDeclarationList([
+                        factory.createVariableDeclaration(
+                          name,
+                          /*exclamationToken*/
+                          void 0,
+                          serializeTypeForDeclaration(context, type, symbol, enclosingDeclaration, includePrivateSymbol, bundled)
+                        )
+                      ], flags)
+                    ),
+                    textRange
+                  );
+                  addResult(statement, name !== localName ? modifierFlags & ~32 /* Export */ : modifierFlags);
                   if (name !== localName && !isPrivate) {
                     addResult(
                       factory.createExportDeclaration(
@@ -151234,18 +134830,21 @@ ${lanes.join("\n")}
               factory.createIdentifier(getInternalSymbolName(symbol, symbolName2))
             ), 0 /* None */);
           } else if (needsExportDeclaration) {
-            addResult(factory.createExportDeclaration(
-              /*modifiers*/
-              void 0,
-              /*isTypeOnly*/
-              false,
-              factory.createNamedExports([factory.createExportSpecifier(
+            addResult(
+              factory.createExportDeclaration(
+                /*modifiers*/
+                void 0,
                 /*isTypeOnly*/
                 false,
-                getInternalSymbolName(symbol, symbolName2),
-                symbolName2
-              )])
-            ), 0 /* None */);
+                factory.createNamedExports([factory.createExportSpecifier(
+                  /*isTypeOnly*/
+                  false,
+                  getInternalSymbolName(symbol, symbolName2),
+                  symbolName2
+                )])
+              ),
+              0 /* None */
+            );
           }
         }
         function includePrivateSymbol(symbol) {
@@ -151253,10 +134852,7 @@ ${lanes.join("\n")}
             return;
           Debug.assertIsDefined(deferredPrivatesStack[deferredPrivatesStack.length - 1]);
           getUnusedName(unescapeLeadingUnderscores(symbol.escapedName), symbol);
-          const isExternalImportAlias = !!(symbol.flags & 2097152 /* Alias */) && !some(
-            symbol.declarations,
-            (d) => !!findAncestor(d, isExportDeclaration) || isNamespaceExport(d) || isImportEqualsDeclaration(d) && !isExternalModuleReference(d.moduleReference)
-          );
+          const isExternalImportAlias = !!(symbol.flags & 2097152 /* Alias */) && !some(symbol.declarations, (d) => !!findAncestor(d, isExportDeclaration) || isNamespaceExport(d) || isImportEqualsDeclaration(d) && !isExternalModuleReference(d.moduleReference));
           deferredPrivatesStack[isExternalImportAlias ? 0 : deferredPrivatesStack.length - 1].set(getSymbolId(symbol), symbol);
         }
         function isExportingScope(enclosingDeclaration2) {
@@ -151266,43 +134862,46 @@ ${lanes.join("\n")}
           if (canHaveModifiers(node)) {
             let newModifierFlags = 0 /* None */;
             const enclosingDeclaration2 = context.enclosingDeclaration && (isJSDocTypeAlias(context.enclosingDeclaration) ? getSourceFileOfNode(context.enclosingDeclaration) : context.enclosingDeclaration);
-            if (additionalModifierFlags & 1 /* Export */ && enclosingDeclaration2 && (isExportingScope(enclosingDeclaration2) || isModuleDeclaration(enclosingDeclaration2)) && canHaveExportModifier(node)) {
-              newModifierFlags |= 1 /* Export */;
+            if (additionalModifierFlags & 32 /* Export */ && enclosingDeclaration2 && (isExportingScope(enclosingDeclaration2) || isModuleDeclaration(enclosingDeclaration2)) && canHaveExportModifier(node)) {
+              newModifierFlags |= 32 /* Export */;
             }
-            if (addingDeclare && !(newModifierFlags & 1 /* Export */) && (!enclosingDeclaration2 || !(enclosingDeclaration2.flags & 16777216 /* Ambient */)) && (isEnumDeclaration(node) || isVariableStatement(node) || isFunctionDeclaration(node) || isClassDeclaration(node) || isModuleDeclaration(node))) {
-              newModifierFlags |= 2 /* Ambient */;
+            if (addingDeclare && !(newModifierFlags & 32 /* Export */) && (!enclosingDeclaration2 || !(enclosingDeclaration2.flags & 33554432 /* Ambient */)) && (isEnumDeclaration(node) || isVariableStatement(node) || isFunctionDeclaration(node) || isClassDeclaration(node) || isModuleDeclaration(node))) {
+              newModifierFlags |= 128 /* Ambient */;
             }
-            if (additionalModifierFlags & 1024 /* Default */ && (isClassDeclaration(node) || isInterfaceDeclaration(node) || isFunctionDeclaration(node))) {
-              newModifierFlags |= 1024 /* Default */;
+            if (additionalModifierFlags & 2048 /* Default */ && (isClassDeclaration(node) || isInterfaceDeclaration(node) || isFunctionDeclaration(node))) {
+              newModifierFlags |= 2048 /* Default */;
             }
             if (newModifierFlags) {
-              node = factory.updateModifiers(node, newModifierFlags | getEffectiveModifierFlags(node));
+              node = factory.replaceModifiers(node, newModifierFlags | getEffectiveModifierFlags(node));
             }
           }
           results.push(node);
         }
         function serializeTypeAlias(symbol, symbolName2, modifierFlags) {
-          var _a;
+          var _a2;
           const aliasType = getDeclaredTypeOfTypeAlias(symbol);
           const typeParams = getSymbolLinks(symbol).typeParameters;
           const typeParamDecls = map(typeParams, (p) => typeParameterToDeclaration(p, context));
-          const jsdocAliasDecl = (_a = symbol.declarations) == null ? void 0 : _a.find(isJSDocTypeAlias);
+          const jsdocAliasDecl = (_a2 = symbol.declarations) == null ? void 0 : _a2.find(isJSDocTypeAlias);
           const commentText = getTextOfJSDocComment(jsdocAliasDecl ? jsdocAliasDecl.comment || jsdocAliasDecl.parent.comment : void 0);
           const oldFlags = context.flags;
           context.flags |= 8388608 /* InTypeAlias */;
           const oldEnclosingDecl = context.enclosingDeclaration;
           context.enclosingDeclaration = jsdocAliasDecl;
           const typeNode = jsdocAliasDecl && jsdocAliasDecl.typeExpression && isJSDocTypeExpression(jsdocAliasDecl.typeExpression) && serializeExistingTypeNode(context, jsdocAliasDecl.typeExpression.type, includePrivateSymbol, bundled) || typeToTypeNodeHelper(aliasType, context);
-          addResult(setSyntheticLeadingComments(
-            factory.createTypeAliasDeclaration(
-              /*modifiers*/
-              void 0,
-              getInternalSymbolName(symbol, symbolName2),
-              typeParamDecls,
-              typeNode
+          addResult(
+            setSyntheticLeadingComments(
+              factory.createTypeAliasDeclaration(
+                /*modifiers*/
+                void 0,
+                getInternalSymbolName(symbol, symbolName2),
+                typeParamDecls,
+                typeNode
+              ),
+              !commentText ? [] : [{ kind: 3 /* MultiLineCommentTrivia */, text: "*\n * " + commentText.replace(/\n/g, "\n * ") + "\n ", pos: -1, end: -1, hasTrailingNewLine: true }]
             ),
-            !commentText ? [] : [{ kind: 3 /* MultiLineCommentTrivia */, text: "*\n * " + commentText.replace(/\n/g, "\n * ") + "\n ", pos: -1, end: -1, hasTrailingNewLine: true }]
-          ), modifierFlags);
+            modifierFlags
+          );
           context.flags = oldFlags;
           context.enclosingDeclaration = oldEnclosingDecl;
         }
@@ -151313,25 +134912,28 @@ ${lanes.join("\n")}
           const baseTypes = getBaseTypes(interfaceType);
           const baseType = length(baseTypes) ? getIntersectionType(baseTypes) : void 0;
           const members = flatMap(getPropertiesOfType(interfaceType), (p) => serializePropertySymbolForInterface(p, baseType));
-          const callSignatures = serializeSignatures(0 /* Call */, interfaceType, baseType, 178 /* CallSignature */);
-          const constructSignatures = serializeSignatures(1 /* Construct */, interfaceType, baseType, 179 /* ConstructSignature */);
+          const callSignatures = serializeSignatures(0 /* Call */, interfaceType, baseType, 179 /* CallSignature */);
+          const constructSignatures = serializeSignatures(1 /* Construct */, interfaceType, baseType, 180 /* ConstructSignature */);
           const indexSignatures = serializeIndexSignatures(interfaceType, baseType);
           const heritageClauses = !length(baseTypes) ? void 0 : [factory.createHeritageClause(96 /* ExtendsKeyword */, mapDefined(baseTypes, (b) => trySerializeAsTypeReference(b, 111551 /* Value */)))];
-          addResult(factory.createInterfaceDeclaration(
-            /*modifiers*/
-            void 0,
-            getInternalSymbolName(symbol, symbolName2),
-            typeParamDecls,
-            heritageClauses,
-            [...indexSignatures, ...constructSignatures, ...callSignatures, ...members]
-          ), modifierFlags);
+          addResult(
+            factory.createInterfaceDeclaration(
+              /*modifiers*/
+              void 0,
+              getInternalSymbolName(symbol, symbolName2),
+              typeParamDecls,
+              heritageClauses,
+              [...indexSignatures, ...constructSignatures, ...callSignatures, ...members]
+            ),
+            modifierFlags
+          );
         }
         function getNamespaceMembersForSerialization(symbol) {
           const exports = getExportsOfSymbol(symbol);
           return !exports ? [] : filter(arrayFrom(exports.values()), (m) => isNamespaceMember(m) && isIdentifierText(m.escapedName, 99 /* ESNext */));
         }
         function isTypeOnlyNamespace(symbol) {
-          return every(getNamespaceMembersForSerialization(symbol), (m) => !(getAllSymbolFlags(resolveSymbol(m)) & 111551 /* Value */));
+          return every(getNamespaceMembersForSerialization(symbol), (m) => !(getSymbolFlags(resolveSymbol(m)) & 111551 /* Value */));
         }
         function serializeModule(symbol, symbolName2, modifierFlags) {
           const members = getNamespaceMembersForSerialization(symbol);
@@ -151351,12 +134953,12 @@ ${lanes.join("\n")}
               /*isTypeOnly*/
               false,
               factory.createNamedExports(mapDefined(filter(mergedMembers, (n) => n.escapedName !== "export=" /* ExportEquals */), (s) => {
-                var _a, _b;
+                var _a2, _b;
                 const name = unescapeLeadingUnderscores(s.escapedName);
                 const localName2 = getInternalSymbolName(s, name);
                 const aliasDecl = s.declarations && getDeclarationOfAliasSymbol(s);
                 if (containingFile && (aliasDecl ? containingFile !== getSourceFileOfNode(aliasDecl) : !some(s.declarations, (d) => getSourceFileOfNode(d) === containingFile))) {
-                  (_b = (_a = context.tracker) == null ? void 0 : _a.reportNonlocalAugmentation) == null ? void 0 : _b.call(_a, containingFile, symbol, s);
+                  (_b = (_a2 = context.tracker) == null ? void 0 : _a2.reportNonlocalAugmentation) == null ? void 0 : _b.call(_a2, containingFile, symbol, s);
                   return void 0;
                 }
                 const target = aliasDecl && getTargetOfAliasDeclaration(
@@ -151374,29 +134976,38 @@ ${lanes.join("\n")}
                 );
               }))
             )]);
-            addResult(factory.createModuleDeclaration(
-              /*modifiers*/
-              void 0,
-              factory.createIdentifier(localName),
-              nsBody,
-              16 /* Namespace */
-            ), 0 /* None */);
+            addResult(
+              factory.createModuleDeclaration(
+                /*modifiers*/
+                void 0,
+                factory.createIdentifier(localName),
+                nsBody,
+                32 /* Namespace */
+              ),
+              0 /* None */
+            );
           }
         }
         function serializeEnum(symbol, symbolName2, modifierFlags) {
-          addResult(factory.createEnumDeclaration(
-            factory.createModifiersFromModifierFlags(isConstEnumSymbol(symbol) ? 2048 /* Const */ : 0),
-            getInternalSymbolName(symbol, symbolName2),
-            map(filter(getPropertiesOfType(getTypeOfSymbol(symbol)), (p) => !!(p.flags & 8 /* EnumMember */)), (p) => {
-              const initializedValue = p.declarations && p.declarations[0] && isEnumMember(p.declarations[0]) ? getConstantValue2(p.declarations[0]) : void 0;
-              return factory.createEnumMember(unescapeLeadingUnderscores(p.escapedName), initializedValue === void 0 ? void 0 : typeof initializedValue === "string" ? factory.createStringLiteral(initializedValue) : factory.createNumericLiteral(initializedValue));
-            })
-          ), modifierFlags);
+          addResult(
+            factory.createEnumDeclaration(
+              factory.createModifiersFromModifierFlags(isConstEnumSymbol(symbol) ? 4096 /* Const */ : 0),
+              getInternalSymbolName(symbol, symbolName2),
+              map(filter(getPropertiesOfType(getTypeOfSymbol(symbol)), (p) => !!(p.flags & 8 /* EnumMember */)), (p) => {
+                const initializedValue = p.declarations && p.declarations[0] && isEnumMember(p.declarations[0]) ? getConstantValue2(p.declarations[0]) : void 0;
+                return factory.createEnumMember(
+                  unescapeLeadingUnderscores(p.escapedName),
+                  initializedValue === void 0 ? void 0 : typeof initializedValue === "string" ? factory.createStringLiteral(initializedValue) : factory.createNumericLiteral(initializedValue)
+                );
+              })
+            ),
+            modifierFlags
+          );
         }
         function serializeAsFunctionNamespaceMerge(type, symbol, localName, modifierFlags) {
           const signatures = getSignaturesOfType(type, 0 /* Call */);
           for (const sig of signatures) {
-            const decl = signatureToSignatureDeclarationHelper(sig, 261 /* FunctionDeclaration */, context, { name: factory.createIdentifier(localName), privateSymbolVisitor: includePrivateSymbol, bundledImports: bundled });
+            const decl = signatureToSignatureDeclarationHelper(sig, 262 /* FunctionDeclaration */, context, { name: factory.createIdentifier(localName), privateSymbolVisitor: includePrivateSymbol, bundledImports: bundled });
             addResult(setTextRange(decl, getSignatureTextRangeLocation(sig)), modifierFlags);
           }
           if (!(symbol.flags & (512 /* ValueModule */ | 1024 /* NamespaceModule */) && !!symbol.exports && !!symbol.exports.size)) {
@@ -151423,20 +135034,14 @@ ${lanes.join("\n")}
         }
         function serializeAsNamespaceDeclaration(props, localName, modifierFlags, suppressNewPrivateContext) {
           if (length(props)) {
-            const localVsRemoteMap = arrayToMultiMap(
-              props,
-              (p) => !length(p.declarations) || some(
-                p.declarations,
-                (d) => getSourceFileOfNode(d) === getSourceFileOfNode(context.enclosingDeclaration)
-              ) ? "local" : "remote"
-            );
+            const localVsRemoteMap = arrayToMultiMap(props, (p) => !length(p.declarations) || some(p.declarations, (d) => getSourceFileOfNode(d) === getSourceFileOfNode(context.enclosingDeclaration)) ? "local" : "remote");
             const localProps = localVsRemoteMap.get("local") || emptyArray;
             let fakespace = parseNodeFactory.createModuleDeclaration(
               /*modifiers*/
               void 0,
               factory.createIdentifier(localName),
               factory.createModuleBlock([]),
-              16 /* Namespace */
+              32 /* Namespace */
             );
             setParent(fakespace, enclosingDeclaration);
             fakespace.locals = createSymbolTable(props);
@@ -151470,7 +135075,7 @@ ${lanes.join("\n")}
                 factory.createIdentifier("default" /* Default */)
               )])
             ) : d);
-            const exportModifierStripped = every(defaultReplaced, (d) => hasSyntacticModifier(d, 1 /* Export */)) ? map(defaultReplaced, removeExportModifier) : defaultReplaced;
+            const exportModifierStripped = every(defaultReplaced, (d) => hasSyntacticModifier(d, 32 /* Export */)) ? map(defaultReplaced, removeExportModifier) : defaultReplaced;
             fakespace = factory.updateModuleDeclaration(
               fakespace,
               fakespace.modifiers,
@@ -151506,10 +135111,7 @@ ${lanes.join("\n")}
             }
             return cleanup(factory.createExpressionWithTypeArguments(
               expr,
-              map(
-                e.typeArguments,
-                (a) => serializeExistingTypeNode(context, a, includePrivateSymbol, bundled) || typeToTypeNodeHelper(getTypeFromTypeNode(a), context)
-              )
+              map(e.typeArguments, (a) => serializeExistingTypeNode(context, a, includePrivateSymbol, bundled) || typeToTypeNodeHelper(getTypeFromTypeNode(a), context))
             ));
             function cleanup(result2) {
               context.enclosingDeclaration = oldEnclosing;
@@ -151522,8 +135124,8 @@ ${lanes.join("\n")}
           return void 0;
         }
         function serializeAsClass(symbol, localName, modifierFlags) {
-          var _a, _b;
-          const originalDecl = (_a = symbol.declarations) == null ? void 0 : _a.find(isClassLike);
+          var _a2, _b;
+          const originalDecl = (_a2 = symbol.declarations) == null ? void 0 : _a2.find(isClassLike);
           const oldEnclosing = context.enclosingDeclaration;
           context.enclosingDeclaration = originalDecl || oldEnclosing;
           const localParams = getLocalTypeParametersOfClassOrInterfaceOrTypeAlias(symbol);
@@ -151576,21 +135178,27 @@ ${lanes.join("\n")}
           );
           const isNonConstructableClassLikeInJsFile = !isClass && !!symbol.valueDeclaration && isInJSFile(symbol.valueDeclaration) && !some(getSignaturesOfType(staticType, 1 /* Construct */));
           const constructors = isNonConstructableClassLikeInJsFile ? [factory.createConstructorDeclaration(
-            factory.createModifiersFromModifierFlags(8 /* Private */),
+            factory.createModifiersFromModifierFlags(2 /* Private */),
             [],
             /*body*/
             void 0
-          )] : serializeSignatures(1 /* Construct */, staticType, staticBaseType, 175 /* Constructor */);
+          )] : serializeSignatures(1 /* Construct */, staticType, staticBaseType, 176 /* Constructor */);
           const indexSignatures = serializeIndexSignatures(classType, baseTypes[0]);
           context.enclosingDeclaration = oldEnclosing;
-          addResult(setTextRange(factory.createClassDeclaration(
-            /*modifiers*/
-            void 0,
-            localName,
-            typeParamDecls,
-            heritageClauses,
-            [...indexSignatures, ...staticMembers, ...constructors, ...publicProperties, ...privateProperties]
-          ), symbol.declarations && filter(symbol.declarations, (d) => isClassDeclaration(d) || isClassExpression(d))[0]), modifierFlags);
+          addResult(
+            setTextRange(
+              factory.createClassDeclaration(
+                /*modifiers*/
+                void 0,
+                localName,
+                typeParamDecls,
+                heritageClauses,
+                [...indexSignatures, ...staticMembers, ...constructors, ...publicProperties, ...privateProperties]
+              ),
+              symbol.declarations && filter(symbol.declarations, (d) => isClassDeclaration(d) || isClassExpression(d))[0]
+            ),
+            modifierFlags
+          );
         }
         function getSomeTargetNameFromDeclarations(declarations) {
           return firstDefined(declarations, (d) => {
@@ -151613,7 +135221,7 @@ ${lanes.join("\n")}
           });
         }
         function serializeAsAlias(symbol, localName, modifierFlags) {
-          var _a, _b, _c, _d, _e;
+          var _a2, _b, _c, _d, _e;
           const node = getDeclarationOfAliasSymbol(symbol);
           if (!node)
             return Debug.fail();
@@ -151632,160 +135240,184 @@ ${lanes.join("\n")}
           const targetName = getInternalSymbolName(target, verbatimTargetName);
           includePrivateSymbol(target);
           switch (node.kind) {
-            case 207 /* BindingElement */:
-              if (((_b = (_a = node.parent) == null ? void 0 : _a.parent) == null ? void 0 : _b.kind) === 259 /* VariableDeclaration */) {
+            case 208 /* BindingElement */:
+              if (((_b = (_a2 = node.parent) == null ? void 0 : _a2.parent) == null ? void 0 : _b.kind) === 260 /* VariableDeclaration */) {
                 const specifier2 = getSpecifierForModuleSymbol(target.parent || target, context);
                 const { propertyName } = node;
-                addResult(factory.createImportDeclaration(
-                  /*modifiers*/
-                  void 0,
-                  factory.createImportClause(
-                    /*isTypeOnly*/
-                    false,
-                    /*name*/
+                addResult(
+                  factory.createImportDeclaration(
+                    /*modifiers*/
                     void 0,
-                    factory.createNamedImports([factory.createImportSpecifier(
+                    factory.createImportClause(
                       /*isTypeOnly*/
                       false,
-                      propertyName && isIdentifier(propertyName) ? factory.createIdentifier(idText(propertyName)) : void 0,
-                      factory.createIdentifier(localName)
-                    )])
+                      /*name*/
+                      void 0,
+                      factory.createNamedImports([factory.createImportSpecifier(
+                        /*isTypeOnly*/
+                        false,
+                        propertyName && isIdentifier(propertyName) ? factory.createIdentifier(idText(propertyName)) : void 0,
+                        factory.createIdentifier(localName)
+                      )])
+                    ),
+                    factory.createStringLiteral(specifier2),
+                    /*attributes*/
+                    void 0
                   ),
-                  factory.createStringLiteral(specifier2),
-                  /*assertClause*/
-                  void 0
-                ), 0 /* None */);
+                  0 /* None */
+                );
                 break;
               }
               Debug.failBadSyntaxKind(((_c = node.parent) == null ? void 0 : _c.parent) || node, "Unhandled binding element grandparent kind in declaration serialization");
               break;
-            case 303 /* ShorthandPropertyAssignment */:
-              if (((_e = (_d = node.parent) == null ? void 0 : _d.parent) == null ? void 0 : _e.kind) === 225 /* BinaryExpression */) {
+            case 304 /* ShorthandPropertyAssignment */:
+              if (((_e = (_d = node.parent) == null ? void 0 : _d.parent) == null ? void 0 : _e.kind) === 226 /* BinaryExpression */) {
                 serializeExportSpecifier(
                   unescapeLeadingUnderscores(symbol.escapedName),
                   targetName
                 );
               }
               break;
-            case 259 /* VariableDeclaration */:
+            case 260 /* VariableDeclaration */:
               if (isPropertyAccessExpression(node.initializer)) {
                 const initializer = node.initializer;
                 const uniqueName = factory.createUniqueName(localName);
                 const specifier2 = getSpecifierForModuleSymbol(target.parent || target, context);
-                addResult(factory.createImportEqualsDeclaration(
-                  /*modifiers*/
-                  void 0,
-                  /*isTypeOnly*/
-                  false,
-                  uniqueName,
-                  factory.createExternalModuleReference(factory.createStringLiteral(specifier2))
-                ), 0 /* None */);
-                addResult(factory.createImportEqualsDeclaration(
-                  /*modifiers*/
-                  void 0,
-                  /*isTypeOnly*/
-                  false,
-                  factory.createIdentifier(localName),
-                  factory.createQualifiedName(uniqueName, initializer.name)
-                ), modifierFlags);
+                addResult(
+                  factory.createImportEqualsDeclaration(
+                    /*modifiers*/
+                    void 0,
+                    /*isTypeOnly*/
+                    false,
+                    uniqueName,
+                    factory.createExternalModuleReference(factory.createStringLiteral(specifier2))
+                  ),
+                  0 /* None */
+                );
+                addResult(
+                  factory.createImportEqualsDeclaration(
+                    /*modifiers*/
+                    void 0,
+                    /*isTypeOnly*/
+                    false,
+                    factory.createIdentifier(localName),
+                    factory.createQualifiedName(uniqueName, initializer.name)
+                  ),
+                  modifierFlags
+                );
                 break;
               }
-            case 270 /* ImportEqualsDeclaration */:
+            case 271 /* ImportEqualsDeclaration */:
               if (target.escapedName === "export=" /* ExportEquals */ && some(target.declarations, (d) => isSourceFile(d) && isJsonSourceFile(d))) {
                 serializeMaybeAliasAssignment(symbol);
                 break;
               }
               const isLocalImport = !(target.flags & 512 /* ValueModule */) && !isVariableDeclaration(node);
-              addResult(factory.createImportEqualsDeclaration(
-                /*modifiers*/
-                void 0,
-                /*isTypeOnly*/
-                false,
-                factory.createIdentifier(localName),
-                isLocalImport ? symbolToName(
-                  target,
-                  context,
-                  67108863 /* All */,
-                  /*expectsIdentifier*/
-                  false
-                ) : factory.createExternalModuleReference(factory.createStringLiteral(getSpecifierForModuleSymbol(target, context)))
-              ), isLocalImport ? modifierFlags : 0 /* None */);
+              addResult(
+                factory.createImportEqualsDeclaration(
+                  /*modifiers*/
+                  void 0,
+                  /*isTypeOnly*/
+                  false,
+                  factory.createIdentifier(localName),
+                  isLocalImport ? symbolToName(
+                    target,
+                    context,
+                    67108863 /* All */,
+                    /*expectsIdentifier*/
+                    false
+                  ) : factory.createExternalModuleReference(factory.createStringLiteral(getSpecifierForModuleSymbol(target, context)))
+                ),
+                isLocalImport ? modifierFlags : 0 /* None */
+              );
               break;
-            case 269 /* NamespaceExportDeclaration */:
+            case 270 /* NamespaceExportDeclaration */:
               addResult(factory.createNamespaceExportDeclaration(idText(node.name)), 0 /* None */);
               break;
-            case 272 /* ImportClause */: {
+            case 273 /* ImportClause */: {
               const generatedSpecifier = getSpecifierForModuleSymbol(target.parent || target, context);
               const specifier2 = bundled ? factory.createStringLiteral(generatedSpecifier) : node.parent.moduleSpecifier;
-              addResult(factory.createImportDeclaration(
-                /*modifiers*/
-                void 0,
-                factory.createImportClause(
-                  /*isTypeOnly*/
-                  false,
-                  factory.createIdentifier(localName),
-                  /*namedBindings*/
-                  void 0
+              addResult(
+                factory.createImportDeclaration(
+                  /*modifiers*/
+                  void 0,
+                  factory.createImportClause(
+                    /*isTypeOnly*/
+                    false,
+                    factory.createIdentifier(localName),
+                    /*namedBindings*/
+                    void 0
+                  ),
+                  specifier2,
+                  node.parent.attributes
                 ),
-                specifier2,
-                node.parent.assertClause
-              ), 0 /* None */);
+                0 /* None */
+              );
               break;
             }
-            case 273 /* NamespaceImport */: {
+            case 274 /* NamespaceImport */: {
               const generatedSpecifier = getSpecifierForModuleSymbol(target.parent || target, context);
               const specifier2 = bundled ? factory.createStringLiteral(generatedSpecifier) : node.parent.parent.moduleSpecifier;
-              addResult(factory.createImportDeclaration(
-                /*modifiers*/
-                void 0,
-                factory.createImportClause(
-                  /*isTypeOnly*/
-                  false,
-                  /*name*/
+              addResult(
+                factory.createImportDeclaration(
+                  /*modifiers*/
                   void 0,
-                  factory.createNamespaceImport(factory.createIdentifier(localName))
+                  factory.createImportClause(
+                    /*isTypeOnly*/
+                    false,
+                    /*name*/
+                    void 0,
+                    factory.createNamespaceImport(factory.createIdentifier(localName))
+                  ),
+                  specifier2,
+                  node.parent.attributes
                 ),
-                specifier2,
-                node.parent.parent.assertClause
-              ), 0 /* None */);
+                0 /* None */
+              );
               break;
             }
-            case 279 /* NamespaceExport */:
-              addResult(factory.createExportDeclaration(
-                /*modifiers*/
-                void 0,
-                /*isTypeOnly*/
-                false,
-                factory.createNamespaceExport(factory.createIdentifier(localName)),
-                factory.createStringLiteral(getSpecifierForModuleSymbol(target, context))
-              ), 0 /* None */);
+            case 280 /* NamespaceExport */:
+              addResult(
+                factory.createExportDeclaration(
+                  /*modifiers*/
+                  void 0,
+                  /*isTypeOnly*/
+                  false,
+                  factory.createNamespaceExport(factory.createIdentifier(localName)),
+                  factory.createStringLiteral(getSpecifierForModuleSymbol(target, context))
+                ),
+                0 /* None */
+              );
               break;
-            case 275 /* ImportSpecifier */: {
+            case 276 /* ImportSpecifier */: {
               const generatedSpecifier = getSpecifierForModuleSymbol(target.parent || target, context);
               const specifier2 = bundled ? factory.createStringLiteral(generatedSpecifier) : node.parent.parent.parent.moduleSpecifier;
-              addResult(factory.createImportDeclaration(
-                /*modifiers*/
-                void 0,
-                factory.createImportClause(
-                  /*isTypeOnly*/
-                  false,
-                  /*name*/
+              addResult(
+                factory.createImportDeclaration(
+                  /*modifiers*/
                   void 0,
-                  factory.createNamedImports([
-                    factory.createImportSpecifier(
-                      /*isTypeOnly*/
-                      false,
-                      localName !== verbatimTargetName ? factory.createIdentifier(verbatimTargetName) : void 0,
-                      factory.createIdentifier(localName)
-                    )
-                  ])
+                  factory.createImportClause(
+                    /*isTypeOnly*/
+                    false,
+                    /*name*/
+                    void 0,
+                    factory.createNamedImports([
+                      factory.createImportSpecifier(
+                        /*isTypeOnly*/
+                        false,
+                        localName !== verbatimTargetName ? factory.createIdentifier(verbatimTargetName) : void 0,
+                        factory.createIdentifier(localName)
+                      )
+                    ])
+                  ),
+                  specifier2,
+                  node.parent.parent.parent.attributes
                 ),
-                specifier2,
-                node.parent.parent.parent.assertClause
-              ), 0 /* None */);
+                0 /* None */
+              );
               break;
             }
-            case 280 /* ExportSpecifier */:
+            case 281 /* ExportSpecifier */:
               const specifier = node.parent.parent.moduleSpecifier;
               serializeExportSpecifier(
                 unescapeLeadingUnderscores(symbol.escapedName),
@@ -151793,12 +135425,12 @@ ${lanes.join("\n")}
                 specifier && isStringLiteralLike(specifier) ? factory.createStringLiteral(specifier.text) : void 0
               );
               break;
-            case 276 /* ExportAssignment */:
+            case 277 /* ExportAssignment */:
               serializeMaybeAliasAssignment(symbol);
               break;
-            case 225 /* BinaryExpression */:
-            case 210 /* PropertyAccessExpression */:
-            case 211 /* ElementAccessExpression */:
+            case 226 /* BinaryExpression */:
+            case 211 /* PropertyAccessExpression */:
+            case 212 /* ElementAccessExpression */:
               if (symbol.escapedName === "default" /* Default */ || symbol.escapedName === "export=" /* ExportEquals */) {
                 serializeMaybeAliasAssignment(symbol);
               } else {
@@ -151810,22 +135442,25 @@ ${lanes.join("\n")}
           }
         }
         function serializeExportSpecifier(localName, targetName, specifier) {
-          addResult(factory.createExportDeclaration(
-            /*modifiers*/
-            void 0,
-            /*isTypeOnly*/
-            false,
-            factory.createNamedExports([factory.createExportSpecifier(
+          addResult(
+            factory.createExportDeclaration(
+              /*modifiers*/
+              void 0,
               /*isTypeOnly*/
               false,
-              localName !== targetName ? targetName : void 0,
-              localName
-            )]),
-            specifier
-          ), 0 /* None */);
+              factory.createNamedExports([factory.createExportSpecifier(
+                /*isTypeOnly*/
+                false,
+                localName !== targetName ? targetName : void 0,
+                localName
+              )]),
+              specifier
+            ),
+            0 /* None */
+          );
         }
         function serializeMaybeAliasAssignment(symbol) {
-          var _a;
+          var _a2;
           if (symbol.flags & 4194304 /* Prototype */) {
             return false;
           }
@@ -151870,20 +135505,23 @@ ${lanes.join("\n")}
                 serializeExportSpecifier(name, getInternalSymbolName(target, symbolName(target)));
               } else {
                 const varName = getUnusedName(name, symbol);
-                addResult(factory.createImportEqualsDeclaration(
-                  /*modifiers*/
-                  void 0,
-                  /*isTypeOnly*/
-                  false,
-                  factory.createIdentifier(varName),
-                  symbolToName(
-                    target,
-                    context,
-                    67108863 /* All */,
-                    /*expectsIdentifier*/
-                    false
-                  )
-                ), 0 /* None */);
+                addResult(
+                  factory.createImportEqualsDeclaration(
+                    /*modifiers*/
+                    void 0,
+                    /*isTypeOnly*/
+                    false,
+                    factory.createIdentifier(varName),
+                    symbolToName(
+                      target,
+                      context,
+                      67108863 /* All */,
+                      /*expectsIdentifier*/
+                      false
+                    )
+                  ),
+                  0 /* None */
+                );
                 serializeExportSpecifier(name, varName);
               }
             }
@@ -151893,8 +135531,9 @@ ${lanes.join("\n")}
             const varName = getUnusedName(name, symbol);
             const typeToSerialize = getWidenedType(getTypeOfSymbol(getMergedSymbol(symbol)));
             if (isTypeRepresentableAsFunctionNamespaceMerge(typeToSerialize, symbol)) {
-              serializeAsFunctionNamespaceMerge(typeToSerialize, symbol, varName, isExportAssignmentCompatibleSymbolName ? 0 /* None */ : 1 /* Export */);
+              serializeAsFunctionNamespaceMerge(typeToSerialize, symbol, varName, isExportAssignmentCompatibleSymbolName ? 0 /* None */ : 32 /* Export */);
             } else {
+              const flags = ((_a2 = context.enclosingDeclaration) == null ? void 0 : _a2.kind) === 267 /* ModuleDeclaration */ && (!(symbol.flags & 98304 /* Accessor */) || symbol.flags & 65536 /* SetAccessor */) ? 1 /* Let */ : 2 /* Const */;
               const statement = factory.createVariableStatement(
                 /*modifiers*/
                 void 0,
@@ -151905,11 +135544,11 @@ ${lanes.join("\n")}
                     void 0,
                     serializeTypeForDeclaration(context, typeToSerialize, symbol, enclosingDeclaration, includePrivateSymbol, bundled)
                   )
-                ], ((_a = context.enclosingDeclaration) == null ? void 0 : _a.kind) === 266 /* ModuleDeclaration */ ? 1 /* Let */ : 2 /* Const */)
+                ], flags)
               );
               addResult(
                 statement,
-                target && target.flags & 4 /* Property */ && target.escapedName === "export=" /* ExportEquals */ ? 2 /* Ambient */ : name === varName ? 1 /* Export */ : 0 /* None */
+                target && target.flags & 4 /* Property */ && target.escapedName === "export=" /* ExportEquals */ ? 128 /* Ambient */ : name === varName ? 32 /* Export */ : 0 /* None */
               );
             }
             if (isExportAssignmentCompatibleSymbolName) {
@@ -151931,79 +135570,114 @@ ${lanes.join("\n")}
           const ctxSrc = getSourceFileOfNode(context.enclosingDeclaration);
           return getObjectFlags(typeToSerialize) & (16 /* Anonymous */ | 32 /* Mapped */) && !length(getIndexInfosOfType(typeToSerialize)) && !isClassInstanceSide(typeToSerialize) && // While a class instance is potentially representable as a NS, prefer printing a reference to the instance type and serializing the class
           !!(length(filter(getPropertiesOfType(typeToSerialize), isNamespaceMember)) || length(getSignaturesOfType(typeToSerialize, 0 /* Call */))) && !length(getSignaturesOfType(typeToSerialize, 1 /* Construct */)) && // TODO: could probably serialize as function + ns + class, now that that's OK
-          !getDeclarationWithTypeAnnotation(hostSymbol, enclosingDeclaration) && !(typeToSerialize.symbol && some(typeToSerialize.symbol.declarations, (d) => getSourceFileOfNode(d) !== ctxSrc)) && !some(getPropertiesOfType(typeToSerialize), (p) => isLateBoundName(p.escapedName)) && !some(getPropertiesOfType(typeToSerialize), (p) => some(p.declarations, (d) => getSourceFileOfNode(d) !== ctxSrc)) && every(getPropertiesOfType(typeToSerialize), (p) => isIdentifierText(symbolName(p), languageVersion));
+          !getDeclarationWithTypeAnnotation(hostSymbol, enclosingDeclaration) && !(typeToSerialize.symbol && some(typeToSerialize.symbol.declarations, (d) => getSourceFileOfNode(d) !== ctxSrc)) && !some(getPropertiesOfType(typeToSerialize), (p) => isLateBoundName(p.escapedName)) && !some(getPropertiesOfType(typeToSerialize), (p) => some(p.declarations, (d) => getSourceFileOfNode(d) !== ctxSrc)) && every(getPropertiesOfType(typeToSerialize), (p) => {
+            if (!isIdentifierText(symbolName(p), languageVersion)) {
+              return false;
+            }
+            if (!(p.flags & 98304 /* Accessor */)) {
+              return true;
+            }
+            return getNonMissingTypeOfSymbol(p) === getWriteTypeOfSymbol(p);
+          });
         }
         function makeSerializePropertySymbol(createProperty2, methodKind, useAccessors) {
           return function serializePropertySymbol(p, isStatic2, baseType) {
-            var _a, _b, _c, _d, _e;
+            var _a2, _b, _c, _d, _e;
             const modifierFlags = getDeclarationModifierFlagsFromSymbol(p);
-            const isPrivate = !!(modifierFlags & 8 /* Private */);
+            const isPrivate = !!(modifierFlags & 2 /* Private */);
             if (isStatic2 && p.flags & (788968 /* Type */ | 1920 /* Namespace */ | 2097152 /* Alias */)) {
               return [];
             }
             if (p.flags & 4194304 /* Prototype */ || p.escapedName === "constructor" || baseType && getPropertyOfType(baseType, p.escapedName) && isReadonlySymbol(getPropertyOfType(baseType, p.escapedName)) === isReadonlySymbol(p) && (p.flags & 16777216 /* Optional */) === (getPropertyOfType(baseType, p.escapedName).flags & 16777216 /* Optional */) && isTypeIdenticalTo(getTypeOfSymbol(p), getTypeOfPropertyOfType(baseType, p.escapedName))) {
               return [];
             }
-            const flag = modifierFlags & ~512 /* Async */ | (isStatic2 ? 32 /* Static */ : 0);
+            const flag = modifierFlags & ~1024 /* Async */ | (isStatic2 ? 256 /* Static */ : 0);
             const name = getPropertyNameNodeForSymbol(p, context);
-            const firstPropertyLikeDecl = (_a = p.declarations) == null ? void 0 : _a.find(or(isPropertyDeclaration, isAccessor, isVariableDeclaration, isPropertySignature, isBinaryExpression, isPropertyAccessExpression));
+            const firstPropertyLikeDecl = (_a2 = p.declarations) == null ? void 0 : _a2.find(or(isPropertyDeclaration, isAccessor, isVariableDeclaration, isPropertySignature, isBinaryExpression, isPropertyAccessExpression));
             if (p.flags & 98304 /* Accessor */ && useAccessors) {
               const result = [];
               if (p.flags & 65536 /* SetAccessor */) {
-                result.push(setTextRange(factory.createSetAccessorDeclaration(
-                  factory.createModifiersFromModifierFlags(flag),
-                  name,
-                  [factory.createParameterDeclaration(
-                    /*modifiers*/
-                    void 0,
-                    /*dotDotDotToken*/
-                    void 0,
-                    "arg",
-                    /*questionToken*/
-                    void 0,
-                    isPrivate ? void 0 : serializeTypeForDeclaration(context, getTypeOfSymbol(p), p, enclosingDeclaration, includePrivateSymbol, bundled)
-                  )],
-                  /*body*/
-                  void 0
-                ), ((_b = p.declarations) == null ? void 0 : _b.find(isSetAccessor)) || firstPropertyLikeDecl));
+                const setter = p.declarations && forEach(p.declarations, (d) => {
+                  if (d.kind === 178 /* SetAccessor */) {
+                    return d;
+                  }
+                  if (isCallExpression(d) && isBindableObjectDefinePropertyCall(d)) {
+                    return forEach(d.arguments[2].properties, (propDecl) => {
+                      const id = getNameOfDeclaration(propDecl);
+                      if (!!id && isIdentifier(id) && idText(id) === "set") {
+                        return propDecl;
+                      }
+                    });
+                  }
+                });
+                Debug.assert(!!setter);
+                const paramSymbol = isFunctionLikeDeclaration(setter) ? getSignatureFromDeclaration(setter).parameters[0] : void 0;
+                result.push(setTextRange(
+                  factory.createSetAccessorDeclaration(
+                    factory.createModifiersFromModifierFlags(flag),
+                    name,
+                    [factory.createParameterDeclaration(
+                      /*modifiers*/
+                      void 0,
+                      /*dotDotDotToken*/
+                      void 0,
+                      paramSymbol ? parameterToParameterDeclarationName(paramSymbol, getEffectiveParameterDeclaration(paramSymbol), context) : "value",
+                      /*questionToken*/
+                      void 0,
+                      isPrivate ? void 0 : serializeTypeForDeclaration(context, getTypeOfSymbol(p), p, enclosingDeclaration, includePrivateSymbol, bundled)
+                    )],
+                    /*body*/
+                    void 0
+                  ),
+                  ((_b = p.declarations) == null ? void 0 : _b.find(isSetAccessor)) || firstPropertyLikeDecl
+                ));
               }
               if (p.flags & 32768 /* GetAccessor */) {
-                const isPrivate2 = modifierFlags & 8 /* Private */;
-                result.push(setTextRange(factory.createGetAccessorDeclaration(
-                  factory.createModifiersFromModifierFlags(flag),
-                  name,
-                  [],
-                  isPrivate2 ? void 0 : serializeTypeForDeclaration(context, getTypeOfSymbol(p), p, enclosingDeclaration, includePrivateSymbol, bundled),
-                  /*body*/
-                  void 0
-                ), ((_c = p.declarations) == null ? void 0 : _c.find(isGetAccessor)) || firstPropertyLikeDecl));
+                const isPrivate2 = modifierFlags & 2 /* Private */;
+                result.push(setTextRange(
+                  factory.createGetAccessorDeclaration(
+                    factory.createModifiersFromModifierFlags(flag),
+                    name,
+                    [],
+                    isPrivate2 ? void 0 : serializeTypeForDeclaration(context, getTypeOfSymbol(p), p, enclosingDeclaration, includePrivateSymbol, bundled),
+                    /*body*/
+                    void 0
+                  ),
+                  ((_c = p.declarations) == null ? void 0 : _c.find(isGetAccessor)) || firstPropertyLikeDecl
+                ));
               }
               return result;
             } else if (p.flags & (4 /* Property */ | 3 /* Variable */ | 98304 /* Accessor */)) {
-              return setTextRange(createProperty2(
-                factory.createModifiersFromModifierFlags((isReadonlySymbol(p) ? 64 /* Readonly */ : 0) | flag),
-                name,
-                p.flags & 16777216 /* Optional */ ? factory.createToken(58 /* QuestionToken */) : void 0,
-                isPrivate ? void 0 : serializeTypeForDeclaration(context, getWriteTypeOfSymbol(p), p, enclosingDeclaration, includePrivateSymbol, bundled),
-                // TODO: https://github.com/microsoft/TypeScript/pull/32372#discussion_r328386357
-                // interface members can't have initializers, however class members _can_
-                /*initializer*/
-                void 0
-              ), ((_d = p.declarations) == null ? void 0 : _d.find(or(isPropertyDeclaration, isVariableDeclaration))) || firstPropertyLikeDecl);
-            }
-            if (p.flags & (8192 /* Method */ | 16 /* Function */)) {
-              const type = getTypeOfSymbol(p);
-              const signatures = getSignaturesOfType(type, 0 /* Call */);
-              if (flag & 8 /* Private */) {
-                return setTextRange(createProperty2(
-                  factory.createModifiersFromModifierFlags((isReadonlySymbol(p) ? 64 /* Readonly */ : 0) | flag),
+              return setTextRange(
+                createProperty2(
+                  factory.createModifiersFromModifierFlags((isReadonlySymbol(p) ? 8 /* Readonly */ : 0) | flag),
                   name,
                   p.flags & 16777216 /* Optional */ ? factory.createToken(58 /* QuestionToken */) : void 0,
-                  /*type*/
-                  void 0,
+                  isPrivate ? void 0 : serializeTypeForDeclaration(context, getWriteTypeOfSymbol(p), p, enclosingDeclaration, includePrivateSymbol, bundled),
+                  // TODO: https://github.com/microsoft/TypeScript/pull/32372#discussion_r328386357
+                  // interface members can't have initializers, however class members _can_
                   /*initializer*/
                   void 0
-                ), ((_e = p.declarations) == null ? void 0 : _e.find(isFunctionLikeDeclaration)) || signatures[0] && signatures[0].declaration || p.declarations && p.declarations[0]);
+                ),
+                ((_d = p.declarations) == null ? void 0 : _d.find(or(isPropertyDeclaration, isVariableDeclaration))) || firstPropertyLikeDecl
+              );
+            }
+            if (p.flags & (8192 /* Method */ | 16 /* Function */)) {
+              const type = getTypeOfSymbol(p);
+              const signatures = getSignaturesOfType(type, 0 /* Call */);
+              if (flag & 2 /* Private */) {
+                return setTextRange(
+                  createProperty2(
+                    factory.createModifiersFromModifierFlags((isReadonlySymbol(p) ? 8 /* Readonly */ : 0) | flag),
+                    name,
+                    p.flags & 16777216 /* Optional */ ? factory.createToken(58 /* QuestionToken */) : void 0,
+                    /*type*/
+                    void 0,
+                    /*initializer*/
+                    void 0
+                  ),
+                  ((_e = p.declarations) == null ? void 0 : _e.find(isFunctionLikeDeclaration)) || signatures[0] && signatures[0].declaration || p.declarations && p.declarations[0]
+                );
               }
               const results2 = [];
               for (const sig of signatures) {
@@ -152070,17 +135744,20 @@ ${lanes.join("\n")}
             let privateProtected = 0;
             for (const s of signatures) {
               if (s.declaration) {
-                privateProtected |= getSelectedEffectiveModifierFlags(s.declaration, 8 /* Private */ | 16 /* Protected */);
+                privateProtected |= getSelectedEffectiveModifierFlags(s.declaration, 2 /* Private */ | 4 /* Protected */);
               }
             }
             if (privateProtected) {
-              return [setTextRange(factory.createConstructorDeclaration(
-                factory.createModifiersFromModifierFlags(privateProtected),
-                /*parameters*/
-                [],
-                /*body*/
-                void 0
-              ), signatures[0].declaration)];
+              return [setTextRange(
+                factory.createConstructorDeclaration(
+                  factory.createModifiersFromModifierFlags(privateProtected),
+                  /*parameters*/
+                  [],
+                  /*body*/
+                  void 0
+                ),
+                signatures[0].declaration
+              )];
             }
           }
           const results2 = [];
@@ -152162,7 +135839,7 @@ ${lanes.join("\n")}
           }
         }
         function getUnusedName(input, symbol) {
-          var _a, _b;
+          var _a2, _b;
           const id = symbol ? getSymbolId(symbol) : void 0;
           if (id) {
             if (context.remappedSymbolNames.has(id)) {
@@ -152174,7 +135851,7 @@ ${lanes.join("\n")}
           }
           let i = 0;
           const original = input;
-          while ((_a = context.usedSymbolNames) == null ? void 0 : _a.has(input)) {
+          while ((_a2 = context.usedSymbolNames) == null ? void 0 : _a2.has(input)) {
             i++;
             input = `${original}_${i}`;
           }
@@ -152260,10 +135937,10 @@ ${lanes.join("\n")}
       return result || types;
     }
     function visibilityToString(flags) {
-      if (flags === 8 /* Private */) {
+      if (flags === 2 /* Private */) {
         return "private";
       }
-      if (flags === 16 /* Protected */) {
+      if (flags === 4 /* Protected */) {
         return "protected";
       }
       return "public";
@@ -152278,10 +135955,10 @@ ${lanes.join("\n")}
       return void 0;
     }
     function isTopLevelInExternalModuleAugmentation(node) {
-      return node && node.parent && node.parent.kind === 267 /* ModuleBlock */ && isExternalModuleAugmentation(node.parent.parent);
+      return node && node.parent && node.parent.kind === 268 /* ModuleBlock */ && isExternalModuleAugmentation(node.parent.parent);
     }
     function isDefaultBindingContext(location) {
-      return location.kind === 311 /* SourceFile */ || isAmbientModule(location);
+      return location.kind === 312 /* SourceFile */ || isAmbientModule(location);
     }
     function getNameOfSymbolFromNameType(symbol, context) {
       const nameType = getSymbolLinks(symbol).nameType;
@@ -152302,6 +135979,10 @@ ${lanes.join("\n")}
       }
     }
     function getNameOfSymbolAsWritten(symbol, context) {
+      var _a;
+      if ((_a = context == null ? void 0 : context.remappedSymbolReferences) == null ? void 0 : _a.has(getSymbolId(symbol))) {
+        symbol = context.remappedSymbolReferences.get(getSymbolId(symbol));
+      }
       if (context && symbol.escapedName === "default" /* Default */ && !(context.flags & 16384 /* UseAliasDefinedOutsideCurrentScope */) && // If it's not the first part of an entity name, it must print as `default`
       (!(context.flags & 16777216 /* InInitialEntityName */) || // if the symbol is synthesized, it will only be referenced externally it must print as `default`
       !symbol.declarations || // if not in the same binding context (source file, module declaration), it must print as `default`
@@ -152329,17 +136010,17 @@ ${lanes.join("\n")}
         if (!declaration) {
           declaration = symbol.declarations[0];
         }
-        if (declaration.parent && declaration.parent.kind === 259 /* VariableDeclaration */) {
+        if (declaration.parent && declaration.parent.kind === 260 /* VariableDeclaration */) {
           return declarationNameToString(declaration.parent.name);
         }
         switch (declaration.kind) {
-          case 230 /* ClassExpression */:
-          case 217 /* FunctionExpression */:
-          case 218 /* ArrowFunction */:
+          case 231 /* ClassExpression */:
+          case 218 /* FunctionExpression */:
+          case 219 /* ArrowFunction */:
             if (context && !context.encounteredError && !(context.flags & 131072 /* AllowAnonymousIdentifier */)) {
               context.encounteredError = true;
             }
-            return declaration.kind === 230 /* ClassExpression */ ? "(Anonymous class)" : "(Anonymous function)";
+            return declaration.kind === 231 /* ClassExpression */ ? "(Anonymous class)" : "(Anonymous function)";
         }
       }
       const name = getNameOfSymbolFromNameType(symbol, context);
@@ -152356,66 +136037,66 @@ ${lanes.join("\n")}
       return false;
       function determineIfDeclarationIsVisible() {
         switch (node.kind) {
-          case 344 /* JSDocCallbackTag */:
-          case 352 /* JSDocTypedefTag */:
-          case 346 /* JSDocEnumTag */:
+          case 345 /* JSDocCallbackTag */:
+          case 353 /* JSDocTypedefTag */:
+          case 347 /* JSDocEnumTag */:
             return !!(node.parent && node.parent.parent && node.parent.parent.parent && isSourceFile(node.parent.parent.parent));
-          case 207 /* BindingElement */:
+          case 208 /* BindingElement */:
             return isDeclarationVisible(node.parent.parent);
-          case 259 /* VariableDeclaration */:
+          case 260 /* VariableDeclaration */:
             if (isBindingPattern(node.name) && !node.name.elements.length) {
               return false;
             }
-          case 266 /* ModuleDeclaration */:
-          case 262 /* ClassDeclaration */:
-          case 263 /* InterfaceDeclaration */:
-          case 264 /* TypeAliasDeclaration */:
-          case 261 /* FunctionDeclaration */:
-          case 265 /* EnumDeclaration */:
-          case 270 /* ImportEqualsDeclaration */:
+          case 267 /* ModuleDeclaration */:
+          case 263 /* ClassDeclaration */:
+          case 264 /* InterfaceDeclaration */:
+          case 265 /* TypeAliasDeclaration */:
+          case 262 /* FunctionDeclaration */:
+          case 266 /* EnumDeclaration */:
+          case 271 /* ImportEqualsDeclaration */:
             if (isExternalModuleAugmentation(node)) {
               return true;
             }
             const parent2 = getDeclarationContainer(node);
-            if (!(getCombinedModifierFlags(node) & 1 /* Export */) && !(node.kind !== 270 /* ImportEqualsDeclaration */ && parent2.kind !== 311 /* SourceFile */ && parent2.flags & 16777216 /* Ambient */)) {
+            if (!(getCombinedModifierFlagsCached(node) & 32 /* Export */) && !(node.kind !== 271 /* ImportEqualsDeclaration */ && parent2.kind !== 312 /* SourceFile */ && parent2.flags & 33554432 /* Ambient */)) {
               return isGlobalSourceFile(parent2);
             }
             return isDeclarationVisible(parent2);
-          case 171 /* PropertyDeclaration */:
-          case 170 /* PropertySignature */:
-          case 176 /* GetAccessor */:
-          case 177 /* SetAccessor */:
-          case 173 /* MethodDeclaration */:
-          case 172 /* MethodSignature */:
-            if (hasEffectiveModifier(node, 8 /* Private */ | 16 /* Protected */)) {
+          case 172 /* PropertyDeclaration */:
+          case 171 /* PropertySignature */:
+          case 177 /* GetAccessor */:
+          case 178 /* SetAccessor */:
+          case 174 /* MethodDeclaration */:
+          case 173 /* MethodSignature */:
+            if (hasEffectiveModifier(node, 2 /* Private */ | 4 /* Protected */)) {
               return false;
             }
-          case 175 /* Constructor */:
-          case 179 /* ConstructSignature */:
-          case 178 /* CallSignature */:
-          case 180 /* IndexSignature */:
-          case 168 /* Parameter */:
-          case 267 /* ModuleBlock */:
-          case 183 /* FunctionType */:
-          case 184 /* ConstructorType */:
-          case 186 /* TypeLiteral */:
-          case 182 /* TypeReference */:
-          case 187 /* ArrayType */:
-          case 188 /* TupleType */:
-          case 191 /* UnionType */:
-          case 192 /* IntersectionType */:
-          case 195 /* ParenthesizedType */:
-          case 201 /* NamedTupleMember */:
+          case 176 /* Constructor */:
+          case 180 /* ConstructSignature */:
+          case 179 /* CallSignature */:
+          case 181 /* IndexSignature */:
+          case 169 /* Parameter */:
+          case 268 /* ModuleBlock */:
+          case 184 /* FunctionType */:
+          case 185 /* ConstructorType */:
+          case 187 /* TypeLiteral */:
+          case 183 /* TypeReference */:
+          case 188 /* ArrayType */:
+          case 189 /* TupleType */:
+          case 192 /* UnionType */:
+          case 193 /* IntersectionType */:
+          case 196 /* ParenthesizedType */:
+          case 202 /* NamedTupleMember */:
             return isDeclarationVisible(node.parent);
-          case 272 /* ImportClause */:
-          case 273 /* NamespaceImport */:
-          case 275 /* ImportSpecifier */:
+          case 273 /* ImportClause */:
+          case 274 /* NamespaceImport */:
+          case 276 /* ImportSpecifier */:
             return false;
-          case 167 /* TypeParameter */:
-          case 311 /* SourceFile */:
-          case 269 /* NamespaceExportDeclaration */:
+          case 168 /* TypeParameter */:
+          case 312 /* SourceFile */:
+          case 270 /* NamespaceExportDeclaration */:
             return true;
-          case 276 /* ExportAssignment */:
+          case 277 /* ExportAssignment */:
             return false;
           default:
             return false;
@@ -152424,7 +136105,7 @@ ${lanes.join("\n")}
     }
     function collectLinkedAliases(node, setVisibility) {
       let exportSymbol;
-      if (node.parent && node.parent.kind === 276 /* ExportAssignment */) {
+      if (node.parent && node.parent.kind === 277 /* ExportAssignment */) {
         exportSymbol = resolveName(
           node,
           node.escapedText,
@@ -152435,7 +136116,7 @@ ${lanes.join("\n")}
           /*isUse*/
           false
         );
-      } else if (node.parent.kind === 280 /* ExportSpecifier */) {
+      } else if (node.parent.kind === 281 /* ExportSpecifier */) {
         exportSymbol = getTargetOfExportSpecifier(node.parent, 111551 /* Value */ | 788968 /* Type */ | 1920 /* Namespace */ | 2097152 /* Alias */);
       }
       let result;
@@ -152539,12 +136220,12 @@ ${lanes.join("\n")}
     function getDeclarationContainer(node) {
       return findAncestor(getRootDeclaration(node), (node2) => {
         switch (node2.kind) {
-          case 259 /* VariableDeclaration */:
-          case 260 /* VariableDeclarationList */:
-          case 275 /* ImportSpecifier */:
-          case 274 /* NamedImports */:
-          case 273 /* NamespaceImport */:
-          case 272 /* ImportClause */:
+          case 260 /* VariableDeclaration */:
+          case 261 /* VariableDeclarationList */:
+          case 276 /* ImportSpecifier */:
+          case 275 /* NamedImports */:
+          case 274 /* NamespaceImport */:
+          case 273 /* ImportClause */:
             return false;
           default:
             return true;
@@ -152559,9 +136240,16 @@ ${lanes.join("\n")}
       const prop = getPropertyOfType(type, name);
       return prop ? getTypeOfSymbol(prop) : void 0;
     }
-    function getTypeOfPropertyOrIndexSignature(type, name) {
+    function getTypeOfPropertyOrIndexSignatureOfType(type, name) {
       var _a;
-      return getTypeOfPropertyOfType(type, name) || ((_a = getApplicableIndexInfoForName(type, name)) == null ? void 0 : _a.type) || unknownType;
+      let propType;
+      return getTypeOfPropertyOfType(type, name) || (propType = (_a = getApplicableIndexInfoForName(type, name)) == null ? void 0 : _a.type) && addOptionality(
+        propType,
+        /*isProperty*/
+        true,
+        /*isOptional*/
+        true
+      );
     }
     function isTypeAny(type) {
       return type && (type.flags & 1 /* Any */) !== 0;
@@ -152599,7 +136287,7 @@ ${lanes.join("\n")}
       const unspreadableToRestKeys = [];
       for (const prop of getPropertiesOfType(source)) {
         const literalTypeFromProperty = getLiteralTypeFromProperty(prop, 8576 /* StringOrNumberLiteralOrUnique */);
-        if (!isTypeAssignableTo(literalTypeFromProperty, omitKeyType) && !(getDeclarationModifierFlagsFromSymbol(prop) & (8 /* Private */ | 16 /* Protected */)) && isSpreadableProperty(prop)) {
+        if (!isTypeAssignableTo(literalTypeFromProperty, omitKeyType) && !(getDeclarationModifierFlagsFromSymbol(prop) & (2 /* Private */ | 4 /* Protected */)) && isSpreadableProperty(prop)) {
           spreadableProperties.push(prop);
         } else {
           unspreadableToRestKeys.push(literalTypeFromProperty);
@@ -152662,23 +136350,23 @@ ${lanes.join("\n")}
     function getParentElementAccess(node) {
       const ancestor = node.parent.parent;
       switch (ancestor.kind) {
-        case 207 /* BindingElement */:
-        case 302 /* PropertyAssignment */:
+        case 208 /* BindingElement */:
+        case 303 /* PropertyAssignment */:
           return getSyntheticElementAccess(ancestor);
-        case 208 /* ArrayLiteralExpression */:
+        case 209 /* ArrayLiteralExpression */:
           return getSyntheticElementAccess(node.parent);
-        case 259 /* VariableDeclaration */:
+        case 260 /* VariableDeclaration */:
           return ancestor.initializer;
-        case 225 /* BinaryExpression */:
+        case 226 /* BinaryExpression */:
           return ancestor.right;
       }
     }
     function getDestructuringPropertyName(node) {
       const parent2 = node.parent;
-      if (node.kind === 207 /* BindingElement */ && parent2.kind === 205 /* ObjectBindingPattern */) {
+      if (node.kind === 208 /* BindingElement */ && parent2.kind === 206 /* ObjectBindingPattern */) {
         return getLiteralPropertyNameText(node.propertyName || node.name);
       }
-      if (node.kind === 302 /* PropertyAssignment */ || node.kind === 303 /* ShorthandPropertyAssignment */) {
+      if (node.kind === 303 /* PropertyAssignment */ || node.kind === 304 /* ShorthandPropertyAssignment */) {
         return getLiteralPropertyNameText(node.name);
       }
       return "" + parent2.elements.indexOf(node);
@@ -152688,26 +136376,31 @@ ${lanes.join("\n")}
       return type.flags & (128 /* StringLiteral */ | 256 /* NumberLiteral */) ? "" + type.value : void 0;
     }
     function getTypeForBindingElement(declaration) {
-      const checkMode = declaration.dotDotDotToken ? 64 /* RestBindingElement */ : 0 /* Normal */;
+      const checkMode = declaration.dotDotDotToken ? 32 /* RestBindingElement */ : 0 /* Normal */;
       const parentType = getTypeForBindingElementParent(declaration.parent.parent, checkMode);
-      return parentType && getBindingElementTypeFromParentType(declaration, parentType);
+      return parentType && getBindingElementTypeFromParentType(
+        declaration,
+        parentType,
+        /*noTupleBoundsCheck*/
+        false
+      );
     }
-    function getBindingElementTypeFromParentType(declaration, parentType) {
+    function getBindingElementTypeFromParentType(declaration, parentType, noTupleBoundsCheck) {
       if (isTypeAny(parentType)) {
         return parentType;
       }
       const pattern = declaration.parent;
-      if (strictNullChecks && declaration.flags & 16777216 /* Ambient */ && isParameterDeclaration(declaration)) {
+      if (strictNullChecks && declaration.flags & 33554432 /* Ambient */ && isParameterDeclaration(declaration)) {
         parentType = getNonNullableType(parentType);
-      } else if (strictNullChecks && pattern.parent.initializer && !(getTypeFacts(getTypeOfInitializer(pattern.parent.initializer)) & 65536 /* EQUndefined */)) {
+      } else if (strictNullChecks && pattern.parent.initializer && !hasTypeFacts(getTypeOfInitializer(pattern.parent.initializer), 65536 /* EQUndefined */)) {
         parentType = getTypeWithFacts(parentType, 524288 /* NEUndefined */);
       }
       let type;
-      if (pattern.kind === 205 /* ObjectBindingPattern */) {
+      if (pattern.kind === 206 /* ObjectBindingPattern */) {
         if (declaration.dotDotDotToken) {
           parentType = getReducedType(parentType);
           if (parentType.flags & 2 /* Unknown */ || !isValidSpreadType(parentType)) {
-            error(declaration, Diagnostics.Rest_types_may_only_be_created_from_object_types);
+            error2(declaration, Diagnostics.Rest_types_may_only_be_created_from_object_types);
             return errorType;
           }
           const literalMembers = [];
@@ -152731,7 +136424,7 @@ ${lanes.join("\n")}
           type = everyType(baseConstraint, isTupleType) ? mapType(baseConstraint, (t) => sliceTupleType(t, index)) : createArrayType(elementType);
         } else if (isArrayLikeType(parentType)) {
           const indexType = getNumberLiteralType(index);
-          const accessFlags = 32 /* ExpressionPosition */ | (hasDefaultValue(declaration) ? 16 /* NoTupleBoundsCheck */ : 0);
+          const accessFlags = 32 /* ExpressionPosition */ | (noTupleBoundsCheck || hasDefaultValue(declaration) ? 16 /* NoTupleBoundsCheck */ : 0);
           const declaredType = getIndexedAccessTypeOrUndefined(parentType, indexType, accessFlags, declaration.name) || errorType;
           type = getFlowTypeOfDestructuring(declaration, declaredType);
         } else {
@@ -152742,7 +136435,7 @@ ${lanes.join("\n")}
         return type;
       }
       if (getEffectiveTypeAnnotationNode(walkUpBindingElementsAndPatterns(declaration))) {
-        return strictNullChecks && !(getTypeFacts(checkDeclarationInitializer(declaration, 0 /* Normal */)) & 16777216 /* IsUndefined */) ? getNonUndefinedType(type) : type;
+        return strictNullChecks && !hasTypeFacts(checkDeclarationInitializer(declaration, 0 /* Normal */), 16777216 /* IsUndefined */) ? getNonUndefinedType(type) : type;
       }
       return widenTypeInferredFromInitializer(declaration, getUnionType([getNonUndefinedType(type), checkDeclarationInitializer(declaration, 0 /* Normal */)], 2 /* Subtype */));
     }
@@ -152767,13 +136460,13 @@ ${lanes.join("\n")}
         /*excludeJSDocTypeAssertions*/
         true
       );
-      return expr.kind === 208 /* ArrayLiteralExpression */ && expr.elements.length === 0;
+      return expr.kind === 209 /* ArrayLiteralExpression */ && expr.elements.length === 0;
     }
     function addOptionality(type, isProperty = false, isOptional = true) {
       return strictNullChecks && isOptional ? getOptionalType(type, isProperty) : type;
     }
     function getTypeForVariableLikeDeclaration(declaration, includeOptionality, checkMode) {
-      if (isVariableDeclaration(declaration) && declaration.parent.parent.kind === 248 /* ForInStatement */) {
+      if (isVariableDeclaration(declaration) && declaration.parent.parent.kind === 249 /* ForInStatement */) {
         const indexType = getIndexType(getNonNullableTypeIfNeeded(checkExpression(
           declaration.parent.parent.expression,
           /*checkMode*/
@@ -152781,7 +136474,7 @@ ${lanes.join("\n")}
         )));
         return indexType.flags & (262144 /* TypeParameter */ | 4194304 /* Index */) ? getExtractStringType(indexType) : stringType;
       }
-      if (isVariableDeclaration(declaration) && declaration.parent.parent.kind === 249 /* ForOfStatement */) {
+      if (isVariableDeclaration(declaration) && declaration.parent.parent.kind === 250 /* ForOfStatement */) {
         const forOfStatement = declaration.parent.parent;
         return checkRightHandSideOfForOf(forOfStatement) || anyType;
       }
@@ -152800,8 +136493,8 @@ ${lanes.join("\n")}
       if (declaredType) {
         return addOptionality(declaredType, isProperty, isOptional);
       }
-      if ((noImplicitAny || isInJSFile(declaration)) && isVariableDeclaration(declaration) && !isBindingPattern(declaration.name) && !(getCombinedModifierFlags(declaration) & 1 /* Export */) && !(declaration.flags & 16777216 /* Ambient */)) {
-        if (!(getCombinedNodeFlags(declaration) & 2 /* Const */) && (!declaration.initializer || isNullOrUndefined3(declaration.initializer))) {
+      if ((noImplicitAny || isInJSFile(declaration)) && isVariableDeclaration(declaration) && !isBindingPattern(declaration.name) && !(getCombinedModifierFlagsCached(declaration) & 32 /* Export */) && !(declaration.flags & 33554432 /* Ambient */)) {
+        if (!(getCombinedNodeFlagsCached(declaration) & 6 /* Constant */) && (!declaration.initializer || isNullOrUndefined3(declaration.initializer))) {
           return autoType;
         }
         if (declaration.initializer && isEmptyArrayLiteral2(declaration.initializer)) {
@@ -152810,8 +136503,8 @@ ${lanes.join("\n")}
       }
       if (isParameter(declaration)) {
         const func = declaration.parent;
-        if (func.kind === 177 /* SetAccessor */ && hasBindableName(func)) {
-          const getter = getDeclarationOfKind(getSymbolOfDeclaration(declaration.parent), 176 /* GetAccessor */);
+        if (func.kind === 178 /* SetAccessor */ && hasBindableName(func)) {
+          const getter = getDeclarationOfKind(getSymbolOfDeclaration(declaration.parent), 177 /* GetAccessor */);
           if (getter) {
             const getterSignature = getSignatureFromDeclaration(getter);
             const thisParameter = getAccessorThisParameter(func);
@@ -152848,7 +136541,7 @@ ${lanes.join("\n")}
       if (isPropertyDeclaration(declaration) && (noImplicitAny || isInJSFile(declaration))) {
         if (!hasStaticModifier(declaration)) {
           const constructor = findConstructorDeclaration(declaration.parent);
-          const type = constructor ? getFlowTypeInConstructor(declaration.symbol, constructor) : getEffectiveModifierFlags(declaration) & 2 /* Ambient */ ? getTypeOfPropertyInBaseClass(declaration.symbol) : void 0;
+          const type = constructor ? getFlowTypeInConstructor(declaration.symbol, constructor) : getEffectiveModifierFlags(declaration) & 128 /* Ambient */ ? getTypeOfPropertyInBaseClass(declaration.symbol) : void 0;
           return type && addOptionality(
             type,
             /*isProperty*/
@@ -152857,7 +136550,7 @@ ${lanes.join("\n")}
           );
         } else {
           const staticBlocks = filter(declaration.parent.members, isClassStaticBlockDeclaration);
-          const type = staticBlocks.length ? getFlowTypeInStaticBlocks(declaration.symbol, staticBlocks) : getEffectiveModifierFlags(declaration) & 2 /* Ambient */ ? getTypeOfPropertyInBaseClass(declaration.symbol) : void 0;
+          const type = staticBlocks.length ? getFlowTypeInStaticBlocks(declaration.symbol, staticBlocks) : getEffectiveModifierFlags(declaration) & 128 /* Ambient */ ? getTypeOfPropertyInBaseClass(declaration.symbol) : void 0;
           return type && addOptionality(
             type,
             /*isProperty*/
@@ -152885,7 +136578,7 @@ ${lanes.join("\n")}
         const links = getSymbolLinks(symbol);
         if (links.isConstructorDeclaredProperty === void 0) {
           links.isConstructorDeclaredProperty = false;
-          links.isConstructorDeclaredProperty = !!getDeclaringConstructor(symbol) && every(symbol.declarations, (declaration) => isBinaryExpression(declaration) && isPossiblyAliasedThisProperty(declaration) && (declaration.left.kind !== 211 /* ElementAccessExpression */ || isStringOrNumericLiteralLike(declaration.left.argumentExpression)) && !getAnnotatedTypeForAssignmentDeclaration(
+          links.isConstructorDeclaredProperty = !!getDeclaringConstructor(symbol) && every(symbol.declarations, (declaration) => isBinaryExpression(declaration) && isPossiblyAliasedThisProperty(declaration) && (declaration.left.kind !== 212 /* ElementAccessExpression */ || isStringOrNumericLiteralLike(declaration.left.argumentExpression)) && !getAnnotatedTypeForAssignmentDeclaration(
             /*declaredType*/
             void 0,
             declaration,
@@ -152913,7 +136606,7 @@ ${lanes.join("\n")}
           /*includeClassComputedPropertyName*/
           false
         );
-        if (container && (container.kind === 175 /* Constructor */ || isJSConstructor(container))) {
+        if (container && (container.kind === 176 /* Constructor */ || isJSConstructor(container))) {
           return container;
         }
       }
@@ -152940,7 +136633,7 @@ ${lanes.join("\n")}
         reference.flowNode = staticBlock.returnFlowNode;
         const flowType = getFlowTypeOfProperty(reference, symbol);
         if (noImplicitAny && (flowType === autoType || flowType === autoArrayType)) {
-          error(symbol.valueDeclaration, Diagnostics.Member_0_implicitly_has_an_1_type, symbolToString(symbol), typeToString(flowType));
+          error2(symbol.valueDeclaration, Diagnostics.Member_0_implicitly_has_an_1_type, symbolToString(symbol), typeToString(flowType));
         }
         if (everyType(flowType, isNullableType)) {
           continue;
@@ -152956,12 +136649,12 @@ ${lanes.join("\n")}
       reference.flowNode = constructor.returnFlowNode;
       const flowType = getFlowTypeOfProperty(reference, symbol);
       if (noImplicitAny && (flowType === autoType || flowType === autoArrayType)) {
-        error(symbol.valueDeclaration, Diagnostics.Member_0_implicitly_has_an_1_type, symbolToString(symbol), typeToString(flowType));
+        error2(symbol.valueDeclaration, Diagnostics.Member_0_implicitly_has_an_1_type, symbolToString(symbol), typeToString(flowType));
       }
       return everyType(flowType, isNullableType) ? void 0 : convertAutoToAny(flowType);
     }
     function getFlowTypeOfProperty(reference, prop) {
-      const initialType = (prop == null ? void 0 : prop.valueDeclaration) && (!isAutoTypedProperty(prop) || getEffectiveModifierFlags(prop.valueDeclaration) & 2 /* Ambient */) && getTypeOfPropertyInBaseClass(prop) || undefinedType;
+      const initialType = (prop == null ? void 0 : prop.valueDeclaration) && (!isAutoTypedProperty(prop) || getEffectiveModifierFlags(prop.valueDeclaration) & 128 /* Ambient */) && getTypeOfPropertyInBaseClass(prop) || undefinedType;
       return getFlowTypeOfReference(reference, autoType, initialType);
     }
     function getWidenedTypeForAssignmentDeclaration(symbol, resolvedSymbol) {
@@ -153028,7 +136721,7 @@ ${lanes.join("\n")}
         false,
         definedInMethod && !definedInConstructor
       ));
-      if (symbol.valueDeclaration && filterType(widened, (t) => !!(t.flags & ~98304 /* Nullable */)) === neverType) {
+      if (symbol.valueDeclaration && isInJSFile(symbol.valueDeclaration) && filterType(widened, (t) => !!(t.flags & ~98304 /* Nullable */)) === neverType) {
         reportImplicitAny(symbol.valueDeclaration, anyType);
         return anyType;
       }
@@ -153131,11 +136824,11 @@ ${lanes.join("\n")}
                 const unescapedName = unescapeLeadingUnderscores(s.escapedName);
                 const exportedMemberName = ((_a = tryCast(exportedMember.valueDeclaration, isNamedDeclaration)) == null ? void 0 : _a.name) || exportedMember.valueDeclaration;
                 addRelatedInfo(
-                  error(s.valueDeclaration, Diagnostics.Duplicate_identifier_0, unescapedName),
+                  error2(s.valueDeclaration, Diagnostics.Duplicate_identifier_0, unescapedName),
                   createDiagnosticForNode(exportedMemberName, Diagnostics._0_was_also_declared_here, unescapedName)
                 );
                 addRelatedInfo(
-                  error(exportedMemberName, Diagnostics.Duplicate_identifier_0, unescapedName),
+                  error2(exportedMemberName, Diagnostics.Duplicate_identifier_0, unescapedName),
                   createDiagnosticForNode(s.valueDeclaration, Diagnostics._0_was_also_declared_here, unescapedName)
                 );
               }
@@ -153193,7 +136886,7 @@ ${lanes.join("\n")}
         /*includeClassComputedPropertyName*/
         false
       );
-      return thisContainer.kind === 175 /* Constructor */ || thisContainer.kind === 261 /* FunctionDeclaration */ || thisContainer.kind === 217 /* FunctionExpression */ && !isPrototypePropertyAssignment(thisContainer.parent);
+      return thisContainer.kind === 176 /* Constructor */ || thisContainer.kind === 262 /* FunctionDeclaration */ || thisContainer.kind === 218 /* FunctionExpression */ && !isPrototypePropertyAssignment(thisContainer.parent);
     }
     function getConstructorDefinedThisAssignmentTypes(types, declarations) {
       Debug.assert(types.length === declarations.length);
@@ -153267,7 +136960,7 @@ ${lanes.join("\n")}
     function getTypeFromArrayBindingPattern(pattern, includePatternInType, reportErrors2) {
       const elements = pattern.elements;
       const lastElement = lastOrUndefined(elements);
-      const restElement = lastElement && lastElement.kind === 207 /* BindingElement */ && lastElement.dotDotDotToken ? lastElement : void 0;
+      const restElement = lastElement && lastElement.kind === 208 /* BindingElement */ && lastElement.dotDotDotToken ? lastElement : void 0;
       if (elements.length === 0 || elements.length === 1 && restElement) {
         return languageVersion >= 2 /* ES2015 */ ? createIterableType(anyType) : anyArrayType;
       }
@@ -153283,7 +136976,7 @@ ${lanes.join("\n")}
       return result;
     }
     function getTypeFromBindingPattern(pattern, includePatternInType = false, reportErrors2 = false) {
-      return pattern.kind === 205 /* ObjectBindingPattern */ ? getTypeFromObjectBindingPattern(pattern, includePatternInType, reportErrors2) : getTypeFromArrayBindingPattern(pattern, includePatternInType, reportErrors2);
+      return pattern.kind === 206 /* ObjectBindingPattern */ ? getTypeFromObjectBindingPattern(pattern, includePatternInType, reportErrors2) : getTypeFromArrayBindingPattern(pattern, includePatternInType, reportErrors2);
     }
     function getWidenedTypeForVariableLikeDeclaration(declaration, reportErrors2) {
       return widenTypeForVariableLikeDeclaration(getTypeForVariableLikeDeclaration(
@@ -153324,7 +137017,7 @@ ${lanes.join("\n")}
     }
     function declarationBelongsToPrivateAmbientMember(declaration) {
       const root = getRootDeclaration(declaration);
-      const memberDeclaration = root.kind === 168 /* Parameter */ ? root.parent : root;
+      const memberDeclaration = root.kind === 169 /* Parameter */ ? root.parent : root;
       return isPrivateWithinAmbient(memberDeclaration);
     }
     function tryGetTypeFromEffectiveTypeNode(node) {
@@ -153398,7 +137091,7 @@ ${lanes.join("\n")}
         return reportCircularityError(symbol);
       }
       let type;
-      if (declaration.kind === 276 /* ExportAssignment */) {
+      if (declaration.kind === 277 /* ExportAssignment */) {
         type = widenTypeForVariableLikeDeclaration(tryGetTypeFromEffectiveTypeNode(declaration) || checkExpressionCached(declaration.expression), declaration);
       } else if (isBinaryExpression(declaration) || isInJSFile(declaration) && (isCallExpression(declaration) || (isPropertyAccessExpression(declaration) || isBindableStaticElementAccessExpression(declaration)) && isBinaryExpression(declaration.parent))) {
         type = getWidenedTypeForAssignmentDeclaration(symbol);
@@ -153439,13 +137132,13 @@ ${lanes.join("\n")}
     function getAnnotatedAccessorTypeNode(accessor) {
       if (accessor) {
         switch (accessor.kind) {
-          case 176 /* GetAccessor */:
+          case 177 /* GetAccessor */:
             const getterTypeAnnotation = getEffectiveReturnTypeNode(accessor);
             return getterTypeAnnotation;
-          case 177 /* SetAccessor */:
+          case 178 /* SetAccessor */:
             const setterTypeAnnotation = getEffectiveSetAccessorTypeAnnotationNode(accessor);
             return setterTypeAnnotation;
-          case 171 /* PropertyDeclaration */:
+          case 172 /* PropertyDeclaration */:
             Debug.assert(hasAccessorModifier(accessor));
             const accessorTypeAnnotation = getEffectiveTypeAnnotationNode(accessor);
             return accessorTypeAnnotation;
@@ -153470,9 +137163,9 @@ ${lanes.join("\n")}
         if (!pushTypeResolution(symbol, 0 /* Type */)) {
           return errorType;
         }
-        const getter = getDeclarationOfKind(symbol, 176 /* GetAccessor */);
-        const setter = getDeclarationOfKind(symbol, 177 /* SetAccessor */);
-        const accessor = tryCast(getDeclarationOfKind(symbol, 171 /* PropertyDeclaration */), isAutoAccessorPropertyDeclaration);
+        const getter = getDeclarationOfKind(symbol, 177 /* GetAccessor */);
+        const setter = getDeclarationOfKind(symbol, 178 /* SetAccessor */);
+        const accessor = tryCast(getDeclarationOfKind(symbol, 172 /* PropertyDeclaration */), isAutoAccessorPropertyDeclaration);
         let type = getter && isInJSFile(getter) && getTypeForDeclarationFromJSDocComment(getter) || getAnnotatedAccessorType(getter) || getAnnotatedAccessorType(setter) || getAnnotatedAccessorType(accessor) || getter && getter.body && getReturnTypeFromBody(getter) || accessor && accessor.initializer && getWidenedTypeForVariableLikeDeclaration(
           accessor,
           /*reportErrors*/
@@ -153490,13 +137183,13 @@ ${lanes.join("\n")}
         }
         if (!popTypeResolution()) {
           if (getAnnotatedAccessorTypeNode(getter)) {
-            error(getter, Diagnostics._0_is_referenced_directly_or_indirectly_in_its_own_type_annotation, symbolToString(symbol));
+            error2(getter, Diagnostics._0_is_referenced_directly_or_indirectly_in_its_own_type_annotation, symbolToString(symbol));
           } else if (getAnnotatedAccessorTypeNode(setter)) {
-            error(setter, Diagnostics._0_is_referenced_directly_or_indirectly_in_its_own_type_annotation, symbolToString(symbol));
+            error2(setter, Diagnostics._0_is_referenced_directly_or_indirectly_in_its_own_type_annotation, symbolToString(symbol));
           } else if (getAnnotatedAccessorTypeNode(accessor)) {
-            error(setter, Diagnostics._0_is_referenced_directly_or_indirectly_in_its_own_type_annotation, symbolToString(symbol));
+            error2(setter, Diagnostics._0_is_referenced_directly_or_indirectly_in_its_own_type_annotation, symbolToString(symbol));
           } else if (getter && noImplicitAny) {
-            error(getter, Diagnostics._0_implicitly_has_return_type_any_because_it_does_not_have_a_return_type_annotation_and_is_referenced_directly_or_indirectly_in_one_of_its_return_expressions, symbolToString(symbol));
+            error2(getter, Diagnostics._0_implicitly_has_return_type_any_because_it_does_not_have_a_return_type_annotation_and_is_referenced_directly_or_indirectly_in_one_of_its_return_expressions, symbolToString(symbol));
           }
           type = anyType;
         }
@@ -153510,11 +137203,11 @@ ${lanes.join("\n")}
         if (!pushTypeResolution(symbol, 8 /* WriteType */)) {
           return errorType;
         }
-        const setter = getDeclarationOfKind(symbol, 177 /* SetAccessor */) ?? tryCast(getDeclarationOfKind(symbol, 171 /* PropertyDeclaration */), isAutoAccessorPropertyDeclaration);
+        const setter = getDeclarationOfKind(symbol, 178 /* SetAccessor */) ?? tryCast(getDeclarationOfKind(symbol, 172 /* PropertyDeclaration */), isAutoAccessorPropertyDeclaration);
         let writeType = getAnnotatedAccessorType(setter);
         if (!popTypeResolution()) {
           if (getAnnotatedAccessorTypeNode(setter)) {
-            error(setter, Diagnostics._0_is_referenced_directly_or_indirectly_in_its_own_type_annotation, symbolToString(symbol));
+            error2(setter, Diagnostics._0_is_referenced_directly_or_indirectly_in_its_own_type_annotation, symbolToString(symbol));
           }
           writeType = anyType;
         }
@@ -153550,7 +137243,7 @@ ${lanes.join("\n")}
       const declaration = symbol.valueDeclaration;
       if (symbol.flags & 1536 /* Module */ && isShorthandAmbientModuleSymbol(symbol)) {
         return anyType;
-      } else if (declaration && (declaration.kind === 225 /* BinaryExpression */ || isAccessExpression(declaration) && declaration.parent.kind === 225 /* BinaryExpression */)) {
+      } else if (declaration && (declaration.kind === 226 /* BinaryExpression */ || isAccessExpression(declaration) && declaration.parent.kind === 226 /* BinaryExpression */)) {
         return getWidenedTypeForAssignmentDeclaration(symbol);
       } else if (symbol.flags & 512 /* ValueModule */ && declaration && isSourceFile(declaration) && declaration.commonJsModuleIndicator) {
         const resolvedModule = resolveExternalModuleSymbol(symbol);
@@ -153585,6 +137278,9 @@ ${lanes.join("\n")}
     function getTypeOfAlias(symbol) {
       const links = getSymbolLinks(symbol);
       if (!links.type) {
+        if (!pushTypeResolution(symbol, 0 /* Type */)) {
+          return errorType;
+        }
         const targetSymbol = resolveAlias(symbol);
         const exportSymbol = symbol.declarations && getTargetOfAliasDeclaration(
           getDeclarationOfAliasSymbol(symbol),
@@ -153592,7 +137288,11 @@ ${lanes.join("\n")}
           true
         );
         const declaredType = firstDefined(exportSymbol == null ? void 0 : exportSymbol.declarations, (d) => isExportAssignment(d) ? tryGetTypeFromEffectiveTypeNode(d) : void 0);
-        links.type = (exportSymbol == null ? void 0 : exportSymbol.declarations) && isDuplicatedCommonJSExport(exportSymbol.declarations) && symbol.declarations.length ? getFlowTypeFromCommonJSExport(exportSymbol) : isDuplicatedCommonJSExport(symbol.declarations) ? autoType : declaredType ? declaredType : getAllSymbolFlags(targetSymbol) & 111551 /* Value */ ? getTypeOfSymbol(targetSymbol) : errorType;
+        links.type = (exportSymbol == null ? void 0 : exportSymbol.declarations) && isDuplicatedCommonJSExport(exportSymbol.declarations) && symbol.declarations.length ? getFlowTypeFromCommonJSExport(exportSymbol) : isDuplicatedCommonJSExport(symbol.declarations) ? autoType : declaredType ? declaredType : getSymbolFlags(targetSymbol) & 111551 /* Value */ ? getTypeOfSymbol(targetSymbol) : errorType;
+        if (!popTypeResolution()) {
+          reportCircularityError(exportSymbol ?? symbol);
+          return links.type = errorType;
+        }
       }
       return links.type;
     }
@@ -153606,20 +137306,19 @@ ${lanes.join("\n")}
     }
     function reportCircularityError(symbol) {
       const declaration = symbol.valueDeclaration;
-      if (getEffectiveTypeAnnotationNode(declaration)) {
-        error(
-          symbol.valueDeclaration,
-          Diagnostics._0_is_referenced_directly_or_indirectly_in_its_own_type_annotation,
-          symbolToString(symbol)
-        );
-        return errorType;
-      }
-      if (noImplicitAny && (declaration.kind !== 168 /* Parameter */ || declaration.initializer)) {
-        error(
-          symbol.valueDeclaration,
-          Diagnostics._0_implicitly_has_type_any_because_it_does_not_have_a_type_annotation_and_is_referenced_directly_or_indirectly_in_its_own_initializer,
-          symbolToString(symbol)
-        );
+      if (declaration) {
+        if (getEffectiveTypeAnnotationNode(declaration)) {
+          error2(symbol.valueDeclaration, Diagnostics._0_is_referenced_directly_or_indirectly_in_its_own_type_annotation, symbolToString(symbol));
+          return errorType;
+        }
+        if (noImplicitAny && (declaration.kind !== 169 /* Parameter */ || declaration.initializer)) {
+          error2(symbol.valueDeclaration, Diagnostics._0_implicitly_has_type_any_because_it_does_not_have_a_type_annotation_and_is_referenced_directly_or_indirectly_in_its_own_initializer, symbolToString(symbol));
+        }
+      } else if (symbol.flags & 2097152 /* Alias */) {
+        const node = getDeclarationOfAliasSymbol(symbol);
+        if (node) {
+          error2(node, Diagnostics.Circular_definition_of_import_alias_0, symbolToString(symbol));
+        }
       }
       return anyType;
     }
@@ -153647,7 +137346,7 @@ ${lanes.join("\n")}
         return checkFlags & 2 /* SyntheticProperty */ ? checkFlags & 65536 /* DeferredType */ ? getWriteTypeOfSymbolWithDeferredType(symbol) || getTypeOfSymbolWithDeferredType(symbol) : (
           // NOTE: cast to TransientSymbol should be safe because only TransientSymbols can have CheckFlags.SyntheticProperty
           symbol.links.writeType || symbol.links.type
-        ) : getTypeOfSymbol(symbol);
+        ) : removeMissingType(getTypeOfSymbol(symbol), !!(symbol.flags & 16777216 /* Optional */));
       }
       if (symbol.flags & 98304 /* Accessor */) {
         return checkFlags & 1 /* Instantiated */ ? getWriteTypeOfInstantiatedSymbol(symbol) : getWriteTypeOfAccessors(symbol);
@@ -153728,43 +137427,43 @@ ${lanes.join("\n")}
           return void 0;
         }
         switch (node.kind) {
-          case 262 /* ClassDeclaration */:
-          case 230 /* ClassExpression */:
-          case 263 /* InterfaceDeclaration */:
-          case 178 /* CallSignature */:
-          case 179 /* ConstructSignature */:
-          case 172 /* MethodSignature */:
-          case 183 /* FunctionType */:
-          case 184 /* ConstructorType */:
-          case 323 /* JSDocFunctionType */:
-          case 261 /* FunctionDeclaration */:
-          case 173 /* MethodDeclaration */:
-          case 217 /* FunctionExpression */:
-          case 218 /* ArrowFunction */:
-          case 264 /* TypeAliasDeclaration */:
-          case 351 /* JSDocTemplateTag */:
-          case 352 /* JSDocTypedefTag */:
-          case 346 /* JSDocEnumTag */:
-          case 344 /* JSDocCallbackTag */:
-          case 199 /* MappedType */:
-          case 193 /* ConditionalType */: {
+          case 263 /* ClassDeclaration */:
+          case 231 /* ClassExpression */:
+          case 264 /* InterfaceDeclaration */:
+          case 179 /* CallSignature */:
+          case 180 /* ConstructSignature */:
+          case 173 /* MethodSignature */:
+          case 184 /* FunctionType */:
+          case 185 /* ConstructorType */:
+          case 324 /* JSDocFunctionType */:
+          case 262 /* FunctionDeclaration */:
+          case 174 /* MethodDeclaration */:
+          case 218 /* FunctionExpression */:
+          case 219 /* ArrowFunction */:
+          case 265 /* TypeAliasDeclaration */:
+          case 352 /* JSDocTemplateTag */:
+          case 353 /* JSDocTypedefTag */:
+          case 347 /* JSDocEnumTag */:
+          case 345 /* JSDocCallbackTag */:
+          case 200 /* MappedType */:
+          case 194 /* ConditionalType */: {
             const outerTypeParameters = getOuterTypeParameters(node, includeThisTypes);
-            if (node.kind === 199 /* MappedType */) {
+            if (node.kind === 200 /* MappedType */) {
               return append(outerTypeParameters, getDeclaredTypeOfTypeParameter(getSymbolOfDeclaration(node.typeParameter)));
-            } else if (node.kind === 193 /* ConditionalType */) {
+            } else if (node.kind === 194 /* ConditionalType */) {
               return concatenate(outerTypeParameters, getInferTypeParameters(node));
             }
             const outerAndOwnTypeParameters = appendTypeParameters(outerTypeParameters, getEffectiveTypeParameterDeclarations(node));
-            const thisType = includeThisTypes && (node.kind === 262 /* ClassDeclaration */ || node.kind === 230 /* ClassExpression */ || node.kind === 263 /* InterfaceDeclaration */ || isJSConstructor(node)) && getDeclaredTypeOfClassOrInterface(getSymbolOfDeclaration(node)).thisType;
+            const thisType = includeThisTypes && (node.kind === 263 /* ClassDeclaration */ || node.kind === 231 /* ClassExpression */ || node.kind === 264 /* InterfaceDeclaration */ || isJSConstructor(node)) && getDeclaredTypeOfClassOrInterface(getSymbolOfDeclaration(node)).thisType;
             return thisType ? append(outerAndOwnTypeParameters, thisType) : outerAndOwnTypeParameters;
           }
-          case 347 /* JSDocParameterTag */:
+          case 348 /* JSDocParameterTag */:
             const paramSymbol = getParameterSymbolFromJSDoc(node);
             if (paramSymbol) {
               node = paramSymbol.valueDeclaration;
             }
             break;
-          case 326 /* JSDoc */: {
+          case 327 /* JSDoc */: {
             const outerTypeParameters = getOuterTypeParameters(node, includeThisTypes);
             return node.tags ? appendTypeParameters(outerTypeParameters, flatMap(node.tags, (t) => isJSDocTemplateTag(t) ? t.typeParameters : void 0)) : outerTypeParameters;
           }
@@ -153774,14 +137473,14 @@ ${lanes.join("\n")}
     function getOuterTypeParametersOfClassOrInterface(symbol) {
       var _a;
       const declaration = symbol.flags & 32 /* Class */ || symbol.flags & 16 /* Function */ ? symbol.valueDeclaration : (_a = symbol.declarations) == null ? void 0 : _a.find((decl) => {
-        if (decl.kind === 263 /* InterfaceDeclaration */) {
+        if (decl.kind === 264 /* InterfaceDeclaration */) {
           return true;
         }
-        if (decl.kind !== 259 /* VariableDeclaration */) {
+        if (decl.kind !== 260 /* VariableDeclaration */) {
           return false;
         }
         const initializer = decl.initializer;
-        return !!initializer && (initializer.kind === 217 /* FunctionExpression */ || initializer.kind === 218 /* ArrowFunction */);
+        return !!initializer && (initializer.kind === 218 /* FunctionExpression */ || initializer.kind === 219 /* ArrowFunction */);
       });
       Debug.assert(!!declaration, "Class was missing valueDeclaration -OR- non-class had no interface declarations");
       return getOuterTypeParameters(declaration);
@@ -153792,7 +137491,7 @@ ${lanes.join("\n")}
       }
       let result;
       for (const node of symbol.declarations) {
-        if (node.kind === 263 /* InterfaceDeclaration */ || node.kind === 262 /* ClassDeclaration */ || node.kind === 230 /* ClassExpression */ || isJSConstructor(node) || isTypeAlias(node)) {
+        if (node.kind === 264 /* InterfaceDeclaration */ || node.kind === 263 /* ClassDeclaration */ || node.kind === 231 /* ClassExpression */ || isJSConstructor(node) || isTypeAlias(node)) {
           const declaration = node;
           result = appendTypeParameters(result, getEffectiveTypeParameterDeclarations(declaration));
         }
@@ -153830,10 +137529,7 @@ ${lanes.join("\n")}
     function getConstructorsForTypeArguments(type, typeArgumentNodes, location) {
       const typeArgCount = length(typeArgumentNodes);
       const isJavascript = isInJSFile(location);
-      return filter(
-        getSignaturesOfType(type, 1 /* Construct */),
-        (sig) => (isJavascript || typeArgCount >= getMinTypeArgumentCount(sig.typeParameters)) && typeArgCount <= length(sig.typeParameters)
-      );
+      return filter(getSignaturesOfType(type, 1 /* Construct */), (sig) => (isJavascript || typeArgCount >= getMinTypeArgumentCount(sig.typeParameters)) && typeArgCount <= length(sig.typeParameters));
     }
     function getInstantiatedConstructorsForTypeArguments(type, typeArgumentNodes, location) {
       const signatures = getConstructorsForTypeArguments(type, typeArgumentNodes, location);
@@ -153860,11 +137556,11 @@ ${lanes.join("\n")}
           resolveStructuredTypeMembers(baseConstructorType);
         }
         if (!popTypeResolution()) {
-          error(type.symbol.valueDeclaration, Diagnostics._0_is_referenced_directly_or_indirectly_in_its_own_base_expression, symbolToString(type.symbol));
+          error2(type.symbol.valueDeclaration, Diagnostics._0_is_referenced_directly_or_indirectly_in_its_own_base_expression, symbolToString(type.symbol));
           return type.resolvedBaseConstructorType = errorType;
         }
         if (!(baseConstructorType.flags & 1 /* Any */) && baseConstructorType !== nullWideningType && !isConstructorType(baseConstructorType)) {
-          const err = error(baseTypeNode.expression, Diagnostics.Type_0_is_not_a_constructor_function_type, typeToString(baseConstructorType));
+          const err = error2(baseTypeNode.expression, Diagnostics.Type_0_is_not_a_constructor_function_type, typeToString(baseConstructorType));
           if (baseConstructorType.flags & 262144 /* TypeParameter */) {
             const constraint = getConstraintFromTypeParameter(baseConstructorType);
             let ctorReturn = unknownType;
@@ -153906,7 +137602,7 @@ ${lanes.join("\n")}
       return resolvedImplementsTypes;
     }
     function reportCircularBaseType(node, type) {
-      error(node, Diagnostics.Type_0_recursively_references_itself_as_a_base_type, typeToString(
+      error2(node, Diagnostics.Type_0_recursively_references_itself_as_a_base_type, typeToString(
         type,
         /*enclosingDeclaration*/
         void 0,
@@ -153930,7 +137626,7 @@ ${lanes.join("\n")}
           }
           if (!popTypeResolution() && type.symbol.declarations) {
             for (const declaration of type.symbol.declarations) {
-              if (declaration.kind === 262 /* ClassDeclaration */ || declaration.kind === 263 /* InterfaceDeclaration */) {
+              if (declaration.kind === 263 /* ClassDeclaration */ || declaration.kind === 264 /* InterfaceDeclaration */) {
                 reportCircularBaseType(declaration, type);
               }
             }
@@ -153960,7 +137656,7 @@ ${lanes.join("\n")}
       } else {
         const constructors = getInstantiatedConstructorsForTypeArguments(baseConstructorType, baseTypeNode.typeArguments, baseTypeNode);
         if (!constructors.length) {
-          error(baseTypeNode.expression, Diagnostics.No_base_constructor_has_the_specified_number_of_type_arguments);
+          error2(baseTypeNode.expression, Diagnostics.No_base_constructor_has_the_specified_number_of_type_arguments);
           return type.resolvedBaseTypes = emptyArray;
         }
         baseType = getReturnTypeOfSignature(constructors[0]);
@@ -153980,16 +137676,12 @@ ${lanes.join("\n")}
         return type.resolvedBaseTypes = emptyArray;
       }
       if (type === reducedBaseType || hasBaseType(reducedBaseType, type)) {
-        error(
-          type.symbol.valueDeclaration,
-          Diagnostics.Type_0_recursively_references_itself_as_a_base_type,
-          typeToString(
-            type,
-            /*enclosingDeclaration*/
-            void 0,
-            2 /* WriteArrayAsGenericType */
-          )
-        );
+        error2(type.symbol.valueDeclaration, Diagnostics.Type_0_recursively_references_itself_as_a_base_type, typeToString(
+          type,
+          /*enclosingDeclaration*/
+          void 0,
+          2 /* WriteArrayAsGenericType */
+        ));
         return type.resolvedBaseTypes = emptyArray;
       }
       if (type.resolvedBaseTypes === resolvingEmptyArray) {
@@ -154019,7 +137711,7 @@ ${lanes.join("\n")}
       type.resolvedBaseTypes = type.resolvedBaseTypes || emptyArray;
       if (type.symbol.declarations) {
         for (const declaration of type.symbol.declarations) {
-          if (declaration.kind === 263 /* InterfaceDeclaration */ && getInterfaceBaseTypeNodes(declaration)) {
+          if (declaration.kind === 264 /* InterfaceDeclaration */ && getInterfaceBaseTypeNodes(declaration)) {
             for (const node of getInterfaceBaseTypeNodes(declaration)) {
               const baseType = getReducedType(getTypeFromTypeNode(node));
               if (!isErrorType(baseType)) {
@@ -154034,7 +137726,7 @@ ${lanes.join("\n")}
                     reportCircularBaseType(declaration, type);
                   }
                 } else {
-                  error(node, Diagnostics.An_interface_can_only_extend_an_object_type_or_intersection_of_object_types_with_statically_known_members);
+                  error2(node, Diagnostics.An_interface_can_only_extend_an_object_type_or_intersection_of_object_types_with_statically_known_members);
                 }
               }
             }
@@ -154047,8 +137739,8 @@ ${lanes.join("\n")}
         return true;
       }
       for (const declaration of symbol.declarations) {
-        if (declaration.kind === 263 /* InterfaceDeclaration */) {
-          if (declaration.flags & 128 /* ContainsThis */) {
+        if (declaration.kind === 264 /* InterfaceDeclaration */) {
+          if (declaration.flags & 256 /* ContainsThis */) {
             return false;
           }
           const baseTypeNodes = getInterfaceBaseTypeNodes(declaration);
@@ -154119,10 +137811,10 @@ ${lanes.join("\n")}
           }
         } else {
           type = errorType;
-          if (declaration.kind === 346 /* JSDocEnumTag */) {
-            error(declaration.typeExpression.type, Diagnostics.Type_alias_0_circularly_references_itself, symbolToString(symbol));
+          if (declaration.kind === 347 /* JSDocEnumTag */) {
+            error2(declaration.typeExpression.type, Diagnostics.Type_alias_0_circularly_references_itself, symbolToString(symbol));
           } else {
-            error(isNamedDeclaration(declaration) ? declaration.name || declaration : declaration, Diagnostics.Type_alias_0_circularly_references_itself, symbolToString(symbol));
+            error2(isNamedDeclaration(declaration) ? declaration.name || declaration : declaration, Diagnostics.Type_alias_0_circularly_references_itself, symbolToString(symbol));
           }
         }
         links.declaredType = type;
@@ -154138,12 +137830,14 @@ ${lanes.join("\n")}
         const memberTypeList = [];
         if (symbol.declarations) {
           for (const declaration of symbol.declarations) {
-            if (declaration.kind === 265 /* EnumDeclaration */) {
+            if (declaration.kind === 266 /* EnumDeclaration */) {
               for (const member of declaration.members) {
                 if (hasBindableName(member)) {
                   const memberSymbol = getSymbolOfDeclaration(member);
                   const value = getEnumMemberValue(member);
-                  const memberType = getFreshTypeOfLiteralType(value !== void 0 ? getEnumLiteralType(value, getSymbolId(symbol), memberSymbol) : createComputedEnumType(memberSymbol));
+                  const memberType = getFreshTypeOfLiteralType(
+                    value !== void 0 ? getEnumLiteralType(value, getSymbolId(symbol), memberSymbol) : createComputedEnumType(memberSymbol)
+                  );
                   getSymbolLinks(memberSymbol).declaredType = memberType;
                   memberTypeList.push(getRegularTypeOfLiteralType(memberType));
                 }
@@ -154223,18 +137917,18 @@ ${lanes.join("\n")}
         case 159 /* UnknownKeyword */:
         case 154 /* StringKeyword */:
         case 150 /* NumberKeyword */:
-        case 162 /* BigIntKeyword */:
+        case 163 /* BigIntKeyword */:
         case 136 /* BooleanKeyword */:
         case 155 /* SymbolKeyword */:
         case 151 /* ObjectKeyword */:
         case 116 /* VoidKeyword */:
         case 157 /* UndefinedKeyword */:
         case 146 /* NeverKeyword */:
-        case 200 /* LiteralType */:
+        case 201 /* LiteralType */:
           return true;
-        case 187 /* ArrayType */:
+        case 188 /* ArrayType */:
           return isThislessType(node.elementType);
-        case 182 /* TypeReference */:
+        case 183 /* TypeReference */:
           return !node.typeArguments || node.typeArguments.every(isThislessType);
       }
       return false;
@@ -154250,21 +137944,21 @@ ${lanes.join("\n")}
     function isThislessFunctionLikeDeclaration(node) {
       const returnType = getEffectiveReturnTypeNode(node);
       const typeParameters = getEffectiveTypeParameterDeclarations(node);
-      return (node.kind === 175 /* Constructor */ || !!returnType && isThislessType(returnType)) && node.parameters.every(isThislessVariableLikeDeclaration) && typeParameters.every(isThislessTypeParameter);
+      return (node.kind === 176 /* Constructor */ || !!returnType && isThislessType(returnType)) && node.parameters.every(isThislessVariableLikeDeclaration) && typeParameters.every(isThislessTypeParameter);
     }
     function isThisless(symbol) {
       if (symbol.declarations && symbol.declarations.length === 1) {
         const declaration = symbol.declarations[0];
         if (declaration) {
           switch (declaration.kind) {
-            case 171 /* PropertyDeclaration */:
-            case 170 /* PropertySignature */:
+            case 172 /* PropertyDeclaration */:
+            case 171 /* PropertySignature */:
               return isThislessVariableLikeDeclaration(declaration);
-            case 173 /* MethodDeclaration */:
-            case 172 /* MethodSignature */:
-            case 175 /* Constructor */:
-            case 176 /* GetAccessor */:
-            case 177 /* SetAccessor */:
+            case 174 /* MethodDeclaration */:
+            case 173 /* MethodSignature */:
+            case 176 /* Constructor */:
+            case 177 /* GetAccessor */:
+            case 178 /* SetAccessor */:
               return isThislessFunctionLikeDeclaration(declaration);
           }
         }
@@ -154307,9 +138001,6 @@ ${lanes.join("\n")}
       }
       return type;
     }
-    function isTypeUsableAsPropertyName(type) {
-      return !!(type.flags & 8576 /* StringOrNumberLiteralOrUnique */);
-    }
     function isLateBindableName(node) {
       if (!isComputedPropertyName(node) && !isElementAccessExpression(node)) {
         return false;
@@ -154330,15 +138021,6 @@ ${lanes.join("\n")}
     function isNonBindableDynamicName(node) {
       return isDynamicName(node) && !isLateBindableName(node);
     }
-    function getPropertyNameFromType(type) {
-      if (type.flags & 8192 /* UniqueESSymbol */) {
-        return type.escapedName;
-      }
-      if (type.flags & (128 /* StringLiteral */ | 256 /* NumberLiteral */)) {
-        return escapeLeadingUnderscores("" + type.value);
-      }
-      return Debug.fail();
-    }
     function addDeclarationToLateBoundSymbol(symbol, member, symbolFlags) {
       Debug.assert(!!(getCheckFlags(symbol) & 4096 /* Late */), "Expected a late-bound symbol.");
       symbol.flags |= symbolFlags;
@@ -154368,11 +138050,11 @@ ${lanes.join("\n")}
           if (!lateSymbol)
             lateSymbols.set(memberName, lateSymbol = createSymbol(0 /* None */, memberName, 4096 /* Late */));
           const earlySymbol = earlySymbols && earlySymbols.get(memberName);
-          if (lateSymbol.flags & getExcludedSymbolFlags(symbolFlags) || earlySymbol) {
+          if (!(parent2.flags & 32 /* Class */) && (lateSymbol.flags & getExcludedSymbolFlags(symbolFlags) || earlySymbol)) {
             const declarations = earlySymbol ? concatenate(earlySymbol.declarations, lateSymbol.declarations) : lateSymbol.declarations;
             const name = !(type.flags & 8192 /* UniqueESSymbol */) && unescapeLeadingUnderscores(memberName) || declarationNameToString(declName);
-            forEach(declarations, (declaration) => error(getNameOfDeclaration(declaration) || declaration, Diagnostics.Property_0_was_also_declared_here, name));
-            error(declName || decl, Diagnostics.Duplicate_property_0, name);
+            forEach(declarations, (declaration) => error2(getNameOfDeclaration(declaration) || declaration, Diagnostics.Property_0_was_also_declared_here, name));
+            error2(declName || decl, Diagnostics.Duplicate_property_0, name);
             lateSymbol = createSymbol(0 /* None */, memberName, 4096 /* Late */);
           }
           lateSymbol.links.nameType = type;
@@ -154388,6 +138070,7 @@ ${lanes.join("\n")}
       return links.resolvedSymbol;
     }
     function getResolvedMembersOrExportsOfSymbol(symbol, resolutionKind) {
+      var _a, _b, _c;
       const links = getSymbolLinks(symbol);
       if (!links[resolutionKind]) {
         const isStatic2 = resolutionKind === "resolvedExports" /* resolvedExports */;
@@ -154406,7 +138089,7 @@ ${lanes.join("\n")}
             }
           }
         }
-        const assignments = symbol.assignmentDeclarationMembers;
+        const assignments = (((_a = symbol.valueDeclaration) == null ? void 0 : _a.kind) === 219 /* ArrowFunction */ || ((_b = symbol.valueDeclaration) == null ? void 0 : _b.kind) === 218 /* FunctionExpression */) && ((_c = getSymbolOfNode(symbol.valueDeclaration.parent)) == null ? void 0 : _c.assignmentDeclarationMembers) || symbol.assignmentDeclarationMembers;
         if (assignments) {
           const decls = arrayFrom(assignments.values());
           for (const member of decls) {
@@ -154419,7 +138102,28 @@ ${lanes.join("\n")}
             }
           }
         }
-        links[resolutionKind] = combineSymbolTables(earlySymbols, lateSymbols) || emptySymbols;
+        let resolved = combineSymbolTables(earlySymbols, lateSymbols);
+        if (symbol.flags & 33554432 /* Transient */ && links.cjsExportMerged && symbol.declarations) {
+          for (const decl of symbol.declarations) {
+            const original = getSymbolLinks(decl.symbol)[resolutionKind];
+            if (!resolved) {
+              resolved = original;
+              continue;
+            }
+            if (!original)
+              continue;
+            original.forEach((s, name) => {
+              const existing = resolved.get(name);
+              if (!existing)
+                resolved.set(name, s);
+              else if (existing === s)
+                return;
+              else
+                resolved.set(name, mergeSymbol(existing, s));
+            });
+          }
+        }
+        links[resolutionKind] = resolved || emptySymbols;
       }
       return links[resolutionKind];
     }
@@ -154478,7 +138182,13 @@ ${lanes.join("\n")}
       const baseTypes = getBaseTypes(source);
       if (baseTypes.length) {
         if (source.symbol && members === getMembersOfSymbol(source.symbol)) {
-          members = createSymbolTable(source.declaredProperties);
+          const symbolTable = createSymbolTable();
+          for (const symbol of members.values()) {
+            if (!(symbol.flags & 262144 /* TypeParameter */)) {
+              symbolTable.set(symbol.escapedName, symbol);
+            }
+          }
+          members = symbolTable;
         }
         setStructuredTypeMembers(type, members, callSignatures, constructSignatures, indexInfos);
         const thisArgument = lastOrUndefined(typeArguments);
@@ -154509,7 +138219,7 @@ ${lanes.join("\n")}
       resolveObjectTypeMembers(type, source, typeParameters, paddedTypeArguments);
     }
     function createSignature(declaration, typeParameters, thisParameter, parameters, resolvedReturnType, resolvedTypePredicate, minArgumentCount, flags) {
-      const sig = new Signature15(checker, flags);
+      const sig = new Signature14(checker, flags);
       sig.declaration = declaration;
       sig.typeParameters = typeParameters;
       sig.parameters = parameters;
@@ -154535,7 +138245,7 @@ ${lanes.join("\n")}
         /*resolvedTypePredicate*/
         void 0,
         sig.minArgumentCount,
-        sig.flags & 39 /* PropagatingFlags */
+        sig.flags & 167 /* PropagatingFlags */
       );
       result.target = sig.target;
       result.mapper = sig.mapper;
@@ -154562,10 +138272,7 @@ ${lanes.join("\n")}
       return signature.optionalCallSignatureCache[key] || (signature.optionalCallSignatureCache[key] = createOptionalCallSignature(signature, callChainFlags));
     }
     function createOptionalCallSignature(signature, callChainFlags) {
-      Debug.assert(
-        callChainFlags === 8 /* IsInnerCallChain */ || callChainFlags === 16 /* IsOuterCallChain */,
-        "An optional call signature can either be for an inner call chain or an outer call chain, but not both."
-      );
+      Debug.assert(callChainFlags === 8 /* IsInnerCallChain */ || callChainFlags === 16 /* IsOuterCallChain */, "An optional call signature can either be for an inner call chain or an outer call chain, but not both.");
       const result = cloneSignature(signature);
       result.flags |= callChainFlags;
       return result;
@@ -154573,17 +138280,18 @@ ${lanes.join("\n")}
     function getExpandedParameters(sig, skipUnionExpanding) {
       if (signatureHasRestParameter(sig)) {
         const restIndex = sig.parameters.length - 1;
+        const restName = sig.parameters[restIndex].escapedName;
         const restType = getTypeOfSymbol(sig.parameters[restIndex]);
         if (isTupleType(restType)) {
-          return [expandSignatureParametersWithTupleMembers(restType, restIndex)];
+          return [expandSignatureParametersWithTupleMembers(restType, restIndex, restName)];
         } else if (!skipUnionExpanding && restType.flags & 1048576 /* Union */ && every(restType.types, isTupleType)) {
-          return map(restType.types, (t) => expandSignatureParametersWithTupleMembers(t, restIndex));
+          return map(restType.types, (t) => expandSignatureParametersWithTupleMembers(t, restIndex, restName));
         }
       }
       return [sig.parameters];
-      function expandSignatureParametersWithTupleMembers(restType, restIndex) {
-        const elementTypes = getElementTypes(restType);
-        const associatedNames = getUniqAssociatedNamesFromTupleType(restType);
+      function expandSignatureParametersWithTupleMembers(restType, restIndex, restName) {
+        const elementTypes = getTypeArguments(restType);
+        const associatedNames = getUniqAssociatedNamesFromTupleType(restType, restName);
         const restParams = map(elementTypes, (t, i) => {
           const name = associatedNames && associatedNames[i] ? associatedNames[i] : getParameterNameAtPosition(sig, restIndex + i, restType);
           const flags = restType.target.elementFlags[i];
@@ -154594,10 +138302,10 @@ ${lanes.join("\n")}
         });
         return concatenate(sig.parameters.slice(0, restIndex), restParams);
       }
-      function getUniqAssociatedNamesFromTupleType(type) {
+      function getUniqAssociatedNamesFromTupleType(type, restName) {
         const associatedNamesMap = /* @__PURE__ */ new Map();
-        return map(type.target.labeledElementDeclarations, (labeledElement) => {
-          const name = getTupleElementLabel(labeledElement);
+        return map(type.target.labeledElementDeclarations, (labeledElement, i) => {
+          const name = getTupleElementLabel(labeledElement, i, restName);
           const prevCounter = associatedNamesMap.get(name);
           if (prevCounter === void 0) {
             associatedNamesMap.set(name, 1);
@@ -154613,7 +138321,7 @@ ${lanes.join("\n")}
       const baseConstructorType = getBaseConstructorTypeOfClass(classType);
       const baseSignatures = getSignaturesOfType(baseConstructorType, 1 /* Construct */);
       const declaration = getClassLikeDeclarationOfSymbol(classType.symbol);
-      const isAbstract = !!declaration && hasSyntacticModifier(declaration, 256 /* Abstract */);
+      const isAbstract = !!declaration && hasSyntacticModifier(declaration, 64 /* Abstract */);
       if (baseSignatures.length === 0) {
         return [createSignature(
           /*declaration*/
@@ -154800,13 +138508,14 @@ ${lanes.join("\n")}
         const paramName = leftName === rightName ? leftName : !leftName ? rightName : !rightName ? leftName : void 0;
         const paramSymbol = createSymbol(
           1 /* FunctionScopedVariable */ | (isOptional && !isRestParam ? 16777216 /* Optional */ : 0),
-          paramName || `arg${i}`
+          paramName || `arg${i}`,
+          isRestParam ? 32768 /* RestParameter */ : isOptional ? 16384 /* OptionalParameter */ : 0
         );
         paramSymbol.links.type = isRestParam ? createArrayType(unionParamType) : unionParamType;
         params[i] = paramSymbol;
       }
       if (needsExtraRestElement) {
-        const restParamSymbol = createSymbol(1 /* FunctionScopedVariable */, "args");
+        const restParamSymbol = createSymbol(1 /* FunctionScopedVariable */, "args", 32768 /* RestParameter */);
         restParamSymbol.links.type = createArrayType(getTypeAtPosition(shorter, longestCount));
         if (shorter === right) {
           restParamSymbol.links.type = instantiateType(restParamSymbol.links.type, mapper);
@@ -154835,7 +138544,7 @@ ${lanes.join("\n")}
         /*resolvedTypePredicate*/
         void 0,
         minArgCount,
-        (left.flags | right.flags) & 39 /* PropagatingFlags */
+        (left.flags | right.flags) & 167 /* PropagatingFlags */
       );
       result.compositeKind = 1048576 /* Union */;
       result.compositeSignatures = concatenate(left.compositeKind !== 2097152 /* Intersection */ && left.compositeSignatures || [left], [right]);
@@ -154851,11 +138560,7 @@ ${lanes.join("\n")}
         for (const info of sourceInfos) {
           const indexType = info.keyType;
           if (every(types, (t) => !!getIndexInfoOfType(t, indexType))) {
-            result.push(createIndexInfo(
-              indexType,
-              getUnionType(map(types, (t) => getIndexTypeOfType(t, indexType))),
-              some(types, (t) => getIndexInfoOfType(t, indexType).isReadonly)
-            ));
+            result.push(createIndexInfo(indexType, getUnionType(map(types, (t) => getIndexTypeOfType(t, indexType))), some(types, (t) => getIndexInfoOfType(t, indexType).isReadonly)));
           }
         }
         return result;
@@ -154947,11 +138652,7 @@ ${lanes.join("\n")}
         for (let i = 0; i < indexInfos.length; i++) {
           const info = indexInfos[i];
           if (info.keyType === newInfo.keyType) {
-            indexInfos[i] = createIndexInfo(
-              info.keyType,
-              union ? getUnionType([info.type, newInfo.type]) : getIntersectionType([info.type, newInfo.type]),
-              union ? info.isReadonly || newInfo.isReadonly : info.isReadonly && newInfo.isReadonly
-            );
+            indexInfos[i] = createIndexInfo(info.keyType, union ? getUnionType([info.type, newInfo.type]) : getIntersectionType([info.type, newInfo.type]), union ? info.isReadonly || newInfo.isReadonly : info.isReadonly && newInfo.isReadonly);
             return indexInfos;
           }
         }
@@ -154983,20 +138684,17 @@ ${lanes.join("\n")}
         setStructuredTypeMembers(type, members2, callSignatures, constructSignatures, indexInfos2);
         return;
       }
-      let members = emptySymbols;
+      let members = getExportsOfSymbol(symbol);
       let indexInfos;
-      if (symbol.exports) {
-        members = getExportsOfSymbol(symbol);
-        if (symbol === globalThisSymbol) {
-          const varsOnly = /* @__PURE__ */ new Map();
-          members.forEach((p) => {
-            var _a;
-            if (!(p.flags & 418 /* BlockScoped */) && !(p.flags & 512 /* ValueModule */ && ((_a = p.declarations) == null ? void 0 : _a.length) && every(p.declarations, isAmbientModule))) {
-              varsOnly.set(p.escapedName, p);
-            }
-          });
-          members = varsOnly;
-        }
+      if (symbol === globalThisSymbol) {
+        const varsOnly = /* @__PURE__ */ new Map();
+        members.forEach((p) => {
+          var _a;
+          if (!(p.flags & 418 /* BlockScoped */) && !(p.flags & 512 /* ValueModule */ && ((_a = p.declarations) == null ? void 0 : _a.length) && every(p.declarations, isAmbientModule))) {
+            varsOnly.set(p.escapedName, p);
+          }
+        });
+        members = varsOnly;
       }
       let baseConstructorIndexInfo;
       setStructuredTypeMembers(type, members, emptyArray, emptyArray, emptyArray);
@@ -155034,20 +138732,23 @@ ${lanes.join("\n")}
         const classType = getDeclaredTypeOfClassOrInterface(symbol);
         let constructSignatures = symbol.members ? getSignaturesOfSymbol(symbol.members.get("__constructor" /* Constructor */)) : emptyArray;
         if (symbol.flags & 16 /* Function */) {
-          constructSignatures = addRange(constructSignatures.slice(), mapDefined(
-            type.callSignatures,
-            (sig) => isJSConstructor(sig.declaration) ? createSignature(
-              sig.declaration,
-              sig.typeParameters,
-              sig.thisParameter,
-              sig.parameters,
-              classType,
-              /*resolvedTypePredicate*/
-              void 0,
-              sig.minArgumentCount,
-              sig.flags & 39 /* PropagatingFlags */
-            ) : void 0
-          ));
+          constructSignatures = addRange(
+            constructSignatures.slice(),
+            mapDefined(
+              type.callSignatures,
+              (sig) => isJSConstructor(sig.declaration) ? createSignature(
+                sig.declaration,
+                sig.typeParameters,
+                sig.thisParameter,
+                sig.parameters,
+                classType,
+                /*resolvedTypePredicate*/
+                void 0,
+                sig.minArgumentCount,
+                sig.flags & 167 /* PropagatingFlags */
+              ) : void 0
+            )
+          );
         }
         if (!constructSignatures.length) {
           constructSignatures = getDefaultConstructSignatures(classType);
@@ -155169,11 +138870,7 @@ ${lanes.join("\n")}
             const isReadonly = !!(templateModifiers & 1 /* IncludeReadonly */ || !(templateModifiers & 2 /* ExcludeReadonly */) && modifiersProp && isReadonlySymbol(modifiersProp));
             const stripOptional = strictNullChecks && !isOptional && modifiersProp && modifiersProp.flags & 16777216 /* Optional */;
             const lateFlag = modifiersProp ? getIsLateCheckFlag(modifiersProp) : 0;
-            const prop = createSymbol(
-              4 /* Property */ | (isOptional ? 16777216 /* Optional */ : 0),
-              propName,
-              lateFlag | 262144 /* Mapped */ | (isReadonly ? 8 /* Readonly */ : 0) | (stripOptional ? 524288 /* StripOptional */ : 0)
-            );
+            const prop = createSymbol(4 /* Property */ | (isOptional ? 16777216 /* Optional */ : 0), propName, lateFlag | 262144 /* Mapped */ | (isReadonly ? 8 /* Readonly */ : 0) | (stripOptional ? 524288 /* StripOptional */ : 0));
             prop.links.mappedType = type;
             prop.links.nameType = propNameType;
             prop.links.keyType = keyType;
@@ -155186,7 +138883,9 @@ ${lanes.join("\n")}
         } else if (isValidIndexKeyType(propNameType) || propNameType.flags & (1 /* Any */ | 32 /* Enum */)) {
           const indexKeyType = propNameType.flags & (1 /* Any */ | 4 /* String */) ? stringType : propNameType.flags & (8 /* Number */ | 32 /* Enum */) ? numberType : propNameType;
           const propType = instantiateType(templateType, appendTypeMapping(type.mapper, typeParameter, keyType));
-          const indexInfo = createIndexInfo(indexKeyType, propType, !!(templateModifiers & 1 /* IncludeReadonly */));
+          const modifiersIndexInfo = getApplicableIndexInfo(modifiersType, propNameType);
+          const isReadonly = !!(templateModifiers & 1 /* IncludeReadonly */ || !(templateModifiers & 2 /* ExcludeReadonly */) && (modifiersIndexInfo == null ? void 0 : modifiersIndexInfo.isReadonly));
+          const indexInfo = createIndexInfo(indexKeyType, propType, isReadonly);
           indexInfos = appendIndexInfo(
             indexInfos,
             indexInfo,
@@ -155212,7 +138911,7 @@ ${lanes.join("\n")}
           true
         ) : symbol.links.checkFlags & 524288 /* StripOptional */ ? removeMissingOrUndefinedType(propType) : propType;
         if (!popTypeResolution()) {
-          error(currentNode, Diagnostics.Type_of_property_0_circularly_references_itself_in_mapped_type_1, symbolToString(symbol), typeToString(mappedType));
+          error2(currentNode, Diagnostics.Type_of_property_0_circularly_references_itself_in_mapped_type_1, symbolToString(symbol), typeToString(mappedType));
           type = errorType;
         }
         symbol.links.type = type;
@@ -155241,7 +138940,7 @@ ${lanes.join("\n")}
     }
     function isMappedTypeWithKeyofConstraintDeclaration(type) {
       const constraintDeclaration = getConstraintDeclarationForMappedType(type);
-      return constraintDeclaration.kind === 197 /* TypeOperator */ && constraintDeclaration.operator === 143 /* KeyOfKeyword */;
+      return constraintDeclaration.kind === 198 /* TypeOperator */ && constraintDeclaration.operator === 143 /* KeyOfKeyword */;
     }
     function getModifiersTypeFromMappedType(type) {
       if (!type.modifiersType) {
@@ -155396,9 +139095,9 @@ ${lanes.join("\n")}
     function getConstraintOfTypeParameter(typeParameter) {
       return hasNonCircularBaseConstraint(typeParameter) ? getConstraintFromTypeParameter(typeParameter) : void 0;
     }
-    function isConstTypeVariable(type) {
+    function isConstTypeVariable(type, depth = 0) {
       var _a;
-      return !!(type && (type.flags & 262144 /* TypeParameter */ && some((_a = type.symbol) == null ? void 0 : _a.declarations, (d) => hasSyntacticModifier(d, 2048 /* Const */)) || type.flags & 1048576 /* Union */ && some(type.types, isConstTypeVariable) || type.flags & 8388608 /* IndexedAccess */ && isConstTypeVariable(type.objectType) || type.flags & 16777216 /* Conditional */ && isConstTypeVariable(getConstraintOfConditionalType(type)) || type.flags & 33554432 /* Substitution */ && isConstTypeVariable(type.baseType) || isGenericTupleType(type) && findIndex(getElementTypes(type), (t, i) => !!(type.target.elementFlags[i] & 8 /* Variadic */) && isConstTypeVariable(t)) >= 0));
+      return depth < 5 && !!(type && (type.flags & 262144 /* TypeParameter */ && some((_a = type.symbol) == null ? void 0 : _a.declarations, (d) => hasSyntacticModifier(d, 4096 /* Const */)) || type.flags & 3145728 /* UnionOrIntersection */ && some(type.types, (t) => isConstTypeVariable(t, depth)) || type.flags & 8388608 /* IndexedAccess */ && isConstTypeVariable(type.objectType, depth + 1) || type.flags & 16777216 /* Conditional */ && isConstTypeVariable(getConstraintOfConditionalType(type), depth + 1) || type.flags & 33554432 /* Substitution */ && isConstTypeVariable(type.baseType, depth) || isGenericTupleType(type) && findIndex(getElementTypes(type), (t, i) => !!(type.target.elementFlags[i] & 8 /* Variadic */) && isConstTypeVariable(t, depth)) >= 0));
     }
     function getConstraintOfIndexedAccess(type) {
       return hasNonCircularBaseConstraint(type) ? getConstraintFromIndexedAccess(type) : void 0;
@@ -155538,7 +139237,7 @@ ${lanes.join("\n")}
             if (t.flags & 262144 /* TypeParameter */) {
               const errorNode = getConstraintDeclaration(t);
               if (errorNode) {
-                const diagnostic = error(errorNode, Diagnostics.Type_parameter_0_has_a_circular_constraint, typeToString(t));
+                const diagnostic = error2(errorNode, Diagnostics.Type_parameter_0_has_a_circular_constraint, typeToString(t));
                 if (currentNode && !isNodeDescendantOf(errorNode, currentNode) && !isNodeDescendantOf(currentNode, errorNode)) {
                   addRelatedInfo(diagnostic, createDiagnosticForNode(currentNode, Diagnostics.Circularity_originates_in_type_at_this_location));
                 }
@@ -155724,7 +139423,7 @@ ${lanes.join("\n")}
             } else if (!isUnion && !isReadonlySymbol(prop)) {
               checkFlags &= ~8 /* Readonly */;
             }
-            checkFlags |= (!(modifiers & 24 /* NonPublicAccessibilityModifier */) ? 256 /* ContainsPublic */ : 0) | (modifiers & 16 /* Protected */ ? 512 /* ContainsProtected */ : 0) | (modifiers & 8 /* Private */ ? 1024 /* ContainsPrivate */ : 0) | (modifiers & 32 /* Static */ ? 2048 /* ContainsStatic */ : 0);
+            checkFlags |= (!(modifiers & 6 /* NonPublicAccessibilityModifier */) ? 256 /* ContainsPublic */ : 0) | (modifiers & 4 /* Protected */ ? 512 /* ContainsProtected */ : 0) | (modifiers & 2 /* Private */ ? 1024 /* ContainsPrivate */ : 0) | (modifiers & 256 /* Static */ ? 2048 /* ContainsStatic */ : 0);
             if (!isPrototypeProperty(prop)) {
               syntheticFlag = 2 /* SyntheticProperty */;
             }
@@ -155780,7 +139479,8 @@ ${lanes.join("\n")}
         const writeType = getWriteTypeOfSymbol(prop);
         if (writeTypes || writeType !== type) {
           writeTypes = append(!writeTypes ? propTypes.slice() : writeTypes, writeType);
-        } else if (type !== firstType) {
+        }
+        if (type !== firstType) {
           checkFlags |= 64 /* HasNonUniformType */;
         }
         if (isLiteralType(type) || isPatternLiteralType(type)) {
@@ -155894,31 +139594,21 @@ ${lanes.join("\n")}
       if (type.flags & 2097152 /* Intersection */ && getObjectFlags(type) & 33554432 /* IsNeverIntersection */) {
         const neverProp = find(getPropertiesOfUnionOrIntersectionType(type), isDiscriminantWithNeverType);
         if (neverProp) {
-          return chainDiagnosticMessages(
-            errorInfo,
-            Diagnostics.The_intersection_0_was_reduced_to_never_because_property_1_has_conflicting_types_in_some_constituents,
-            typeToString(
-              type,
-              /*enclosingDeclaration*/
-              void 0,
-              536870912 /* NoTypeReduction */
-            ),
-            symbolToString(neverProp)
-          );
+          return chainDiagnosticMessages(errorInfo, Diagnostics.The_intersection_0_was_reduced_to_never_because_property_1_has_conflicting_types_in_some_constituents, typeToString(
+            type,
+            /*enclosingDeclaration*/
+            void 0,
+            536870912 /* NoTypeReduction */
+          ), symbolToString(neverProp));
         }
         const privateProp = find(getPropertiesOfUnionOrIntersectionType(type), isConflictingPrivateProperty);
         if (privateProp) {
-          return chainDiagnosticMessages(
-            errorInfo,
-            Diagnostics.The_intersection_0_was_reduced_to_never_because_property_1_exists_in_multiple_constituents_and_is_private_in_some,
-            typeToString(
-              type,
-              /*enclosingDeclaration*/
-              void 0,
-              536870912 /* NoTypeReduction */
-            ),
-            symbolToString(privateProp)
-          );
+          return chainDiagnosticMessages(errorInfo, Diagnostics.The_intersection_0_was_reduced_to_never_because_property_1_exists_in_multiple_constituents_and_is_private_in_some, typeToString(
+            type,
+            /*enclosingDeclaration*/
+            void 0,
+            536870912 /* NoTypeReduction */
+          ), symbolToString(privateProp));
         }
       }
       return errorInfo;
@@ -155955,7 +139645,35 @@ ${lanes.join("\n")}
       return emptyArray;
     }
     function getSignaturesOfType(type, kind) {
-      return getSignaturesOfStructuredType(getReducedApparentType(type), kind);
+      const result = getSignaturesOfStructuredType(getReducedApparentType(type), kind);
+      if (kind === 0 /* Call */ && !length(result) && type.flags & 1048576 /* Union */) {
+        if (type.arrayFallbackSignatures) {
+          return type.arrayFallbackSignatures;
+        }
+        let memberName;
+        if (everyType(type, (t) => {
+          var _a;
+          return !!((_a = t.symbol) == null ? void 0 : _a.parent) && isArrayOrTupleSymbol(t.symbol.parent) && (!memberName ? (memberName = t.symbol.escapedName, true) : memberName === t.symbol.escapedName);
+        })) {
+          const arrayArg = mapType(type, (t) => getMappedType((isReadonlyArraySymbol(t.symbol.parent) ? globalReadonlyArrayType : globalArrayType).typeParameters[0], t.mapper));
+          const arrayType = createArrayType(arrayArg, someType(type, (t) => isReadonlyArraySymbol(t.symbol.parent)));
+          return type.arrayFallbackSignatures = getSignaturesOfType(getTypeOfPropertyOfType(arrayType, memberName), kind);
+        }
+        type.arrayFallbackSignatures = result;
+      }
+      return result;
+    }
+    function isArrayOrTupleSymbol(symbol) {
+      if (!symbol || !globalArrayType.symbol || !globalReadonlyArrayType.symbol) {
+        return false;
+      }
+      return !!getSymbolIfSameReference(symbol, globalArrayType.symbol) || !!getSymbolIfSameReference(symbol, globalReadonlyArrayType.symbol);
+    }
+    function isReadonlyArraySymbol(symbol) {
+      if (!symbol || !globalReadonlyArrayType.symbol) {
+        return false;
+      }
+      return !!getSymbolIfSameReference(symbol, globalReadonlyArrayType.symbol);
     }
     function findIndexInfo(indexInfos, keyType) {
       return find(indexInfos, (info) => info.keyType === keyType);
@@ -155975,16 +139693,12 @@ ${lanes.join("\n")}
           }
         }
       }
-      return applicableInfos ? createIndexInfo(
-        unknownType,
-        getIntersectionType(map(applicableInfos, (info) => info.type)),
-        reduceLeft(
-          applicableInfos,
-          (isReadonly, info) => isReadonly && info.isReadonly,
-          /*initial*/
-          true
-        )
-      ) : applicableInfo ? applicableInfo : stringIndexInfo && isApplicableIndexType(keyType, stringType) ? stringIndexInfo : void 0;
+      return applicableInfos ? createIndexInfo(unknownType, getIntersectionType(map(applicableInfos, (info) => info.type)), reduceLeft(
+        applicableInfos,
+        (isReadonly, info) => isReadonly && info.isReadonly,
+        /*initial*/
+        true
+      )) : applicableInfo ? applicableInfo : stringIndexInfo && isApplicableIndexType(keyType, stringType) ? stringIndexInfo : void 0;
     }
     function isApplicableIndexType(source, target) {
       return isTypeAssignableTo(source, target) || target === stringType && isTypeAssignableTo(source, numberType) || target === numberType && (source === numericStringType || !!(source.flags & 128 /* StringLiteral */) && isNumericLiteralName(source.value));
@@ -156051,7 +139765,7 @@ ${lanes.join("\n")}
       }
       const iife = getImmediatelyInvokedFunctionExpression(node.parent);
       if (iife) {
-        return !node.type && !node.dotDotDotToken && node.parent.parameters.indexOf(node) >= iife.arguments.length;
+        return !node.type && !node.dotDotDotToken && node.parent.parameters.indexOf(node) >= getEffectiveCallArguments(iife).length;
       }
       return false;
     }
@@ -156134,7 +139848,7 @@ ${lanes.join("\n")}
           } else {
             parameters.push(paramSymbol);
           }
-          if (type && type.kind === 200 /* LiteralType */) {
+          if (type && type.kind === 201 /* LiteralType */) {
             flags |= 2 /* HasLiteralTypes */;
           }
           const isOptionalParameter2 = isOptionalJSDocPropertyLikeTag(param) || param.initializer || param.questionToken || isRestParameter(param) || iife && parameters.length > iife.arguments.length && !type || isJSDocOptionalParameter(param);
@@ -156142,8 +139856,8 @@ ${lanes.join("\n")}
             minArgumentCount = parameters.length;
           }
         }
-        if ((declaration.kind === 176 /* GetAccessor */ || declaration.kind === 177 /* SetAccessor */) && hasBindableName(declaration) && (!hasThisParameter2 || !thisParameter)) {
-          const otherKind = declaration.kind === 176 /* GetAccessor */ ? 177 /* SetAccessor */ : 176 /* GetAccessor */;
+        if ((declaration.kind === 177 /* GetAccessor */ || declaration.kind === 178 /* SetAccessor */) && hasBindableName(declaration) && (!hasThisParameter2 || !thisParameter)) {
+          const otherKind = declaration.kind === 177 /* GetAccessor */ ? 178 /* SetAccessor */ : 177 /* GetAccessor */;
           const other = getDeclarationOfKind(getSymbolOfDeclaration(declaration), otherKind);
           if (other) {
             thisParameter = getAnnotatedAccessorThisParameter(other);
@@ -156161,7 +139875,7 @@ ${lanes.join("\n")}
         if (hasRestParameter(declaration) || isInJSFile(declaration) && maybeAddJsSyntheticRestParameter(declaration, parameters)) {
           flags |= 1 /* HasRestParameter */;
         }
-        if (isConstructorTypeNode(declaration) && hasSyntacticModifier(declaration, 256 /* Abstract */) || isConstructorDeclaration(declaration) && hasSyntacticModifier(declaration.parent, 256 /* Abstract */)) {
+        if (isConstructorTypeNode(declaration) && hasSyntacticModifier(declaration, 64 /* Abstract */) || isConstructorDeclaration(declaration) && hasSyntacticModifier(declaration.parent, 64 /* Abstract */)) {
           flags |= 4 /* Abstract */;
         }
         links.resolvedSignature = createSignature(
@@ -156234,15 +139948,15 @@ ${lanes.join("\n")}
         switch (node.kind) {
           case 80 /* Identifier */:
             return node.escapedText === argumentsSymbol.escapedName && getReferencedValueSymbol(node) === argumentsSymbol;
-          case 171 /* PropertyDeclaration */:
-          case 173 /* MethodDeclaration */:
-          case 176 /* GetAccessor */:
-          case 177 /* SetAccessor */:
-            return node.name.kind === 166 /* ComputedPropertyName */ && traverse(node.name);
-          case 210 /* PropertyAccessExpression */:
-          case 211 /* ElementAccessExpression */:
+          case 172 /* PropertyDeclaration */:
+          case 174 /* MethodDeclaration */:
+          case 177 /* GetAccessor */:
+          case 178 /* SetAccessor */:
+            return node.name.kind === 167 /* ComputedPropertyName */ && traverse(node.name);
+          case 211 /* PropertyAccessExpression */:
+          case 212 /* ElementAccessExpression */:
             return traverse(node.expression);
-          case 302 /* PropertyAssignment */:
+          case 303 /* PropertyAssignment */:
             return traverse(node.initializer);
           default:
             return !nodeStartsNewLexicalEnvironment(node) && !isPartOfTypeNode(node) && !!forEachChild(node, traverse);
@@ -156329,19 +140043,14 @@ ${lanes.join("\n")}
     function createTypePredicateFromTypePredicateNode(node, signature) {
       const parameterName = node.parameterName;
       const type = node.type && getTypeFromTypeNode(node.type);
-      return parameterName.kind === 196 /* ThisType */ ? createTypePredicate(
+      return parameterName.kind === 197 /* ThisType */ ? createTypePredicate(
         node.assertsModifier ? 2 /* AssertsThis */ : 0 /* This */,
         /*parameterName*/
         void 0,
         /*parameterIndex*/
         void 0,
         type
-      ) : createTypePredicate(
-        node.assertsModifier ? 3 /* AssertsIdentifier */ : 1 /* Identifier */,
-        parameterName.escapedText,
-        findIndex(signature.parameters, (p) => p.escapedName === parameterName.escapedText),
-        type
-      );
+      ) : createTypePredicate(node.assertsModifier ? 3 /* AssertsIdentifier */ : 1 /* Identifier */, parameterName.escapedText, findIndex(signature.parameters, (p) => p.escapedName === parameterName.escapedText), type);
     }
     function getUnionOrIntersectionType(types, kind, unionReduction) {
       return kind !== 2097152 /* Intersection */ ? getUnionType(types, unionReduction) : getIntersectionType(types);
@@ -156361,14 +140070,14 @@ ${lanes.join("\n")}
           if (signature.declaration) {
             const typeNode = getEffectiveReturnTypeNode(signature.declaration);
             if (typeNode) {
-              error(typeNode, Diagnostics.Return_type_annotation_circularly_references_itself);
+              error2(typeNode, Diagnostics.Return_type_annotation_circularly_references_itself);
             } else if (noImplicitAny) {
               const declaration = signature.declaration;
               const name = getNameOfDeclaration(declaration);
               if (name) {
-                error(name, Diagnostics._0_implicitly_has_return_type_any_because_it_does_not_have_a_return_type_annotation_and_is_referenced_directly_or_indirectly_in_one_of_its_return_expressions, declarationNameToString(name));
+                error2(name, Diagnostics._0_implicitly_has_return_type_any_because_it_does_not_have_a_return_type_annotation_and_is_referenced_directly_or_indirectly_in_one_of_its_return_expressions, declarationNameToString(name));
               } else {
-                error(declaration, Diagnostics.Function_implicitly_has_return_type_any_because_it_does_not_have_a_return_type_annotation_and_is_referenced_directly_or_indirectly_in_one_of_its_return_expressions);
+                error2(declaration, Diagnostics.Function_implicitly_has_return_type_any_because_it_does_not_have_a_return_type_annotation_and_is_referenced_directly_or_indirectly_in_one_of_its_return_expressions);
               }
             }
           }
@@ -156379,7 +140088,7 @@ ${lanes.join("\n")}
       return signature.resolvedReturnType;
     }
     function getReturnTypeFromAnnotation(declaration) {
-      if (declaration.kind === 175 /* Constructor */) {
+      if (declaration.kind === 176 /* Constructor */) {
         return getDeclaredTypeOfClassOrInterface(getMergedSymbol(declaration.parent.symbol));
       }
       const typeNode = getEffectiveReturnTypeNode(declaration);
@@ -156395,12 +140104,12 @@ ${lanes.join("\n")}
       if (typeNode) {
         return getTypeFromTypeNode(typeNode);
       }
-      if (declaration.kind === 176 /* GetAccessor */ && hasBindableName(declaration)) {
+      if (declaration.kind === 177 /* GetAccessor */ && hasBindableName(declaration)) {
         const jsDocType = isInJSFile(declaration) && getTypeForDeclarationFromJSDocComment(declaration);
         if (jsDocType) {
           return jsDocType;
         }
-        const setter = getDeclarationOfKind(getSymbolOfDeclaration(declaration), 177 /* SetAccessor */);
+        const setter = getDeclarationOfKind(getSymbolOfDeclaration(declaration), 178 /* SetAccessor */);
         const setterType = getAnnotatedAccessorType(setter);
         if (setterType) {
           return setterType;
@@ -156409,7 +140118,7 @@ ${lanes.join("\n")}
       return getReturnTypeOfTypeTag(declaration);
     }
     function isResolvingReturnTypeOfSignature(signature) {
-      return !signature.resolvedReturnType && findResolutionCycleStartIndex(signature, 3 /* ResolvedReturnType */) >= 0;
+      return signature.compositeSignatures && some(signature.compositeSignatures, isResolvingReturnTypeOfSignature) || !signature.resolvedReturnType && findResolutionCycleStartIndex(signature, 3 /* ResolvedReturnType */) >= 0;
     }
     function getRestTypeOfSignature(signature) {
       return tryGetRestTypeOfSignature(signature) || anyType;
@@ -156503,7 +140212,7 @@ ${lanes.join("\n")}
       var _a;
       if (!signature.isolatedSignatureType) {
         const kind = (_a = signature.declaration) == null ? void 0 : _a.kind;
-        const isConstructor = kind === void 0 || kind === 175 /* Constructor */ || kind === 179 /* ConstructSignature */ || kind === 184 /* ConstructorType */;
+        const isConstructor = kind === void 0 || kind === 176 /* Constructor */ || kind === 180 /* ConstructSignature */ || kind === 185 /* ConstructorType */;
         const type = createObjectType(16 /* Anonymous */);
         type.members = emptySymbols;
         type.properties = emptyArray;
@@ -156536,12 +140245,7 @@ ${lanes.join("\n")}
             if (parameter.type) {
               forEachType(getTypeFromTypeNode(parameter.type), (keyType) => {
                 if (isValidIndexKeyType(keyType) && !findIndexInfo(indexInfos, keyType)) {
-                  indexInfos.push(createIndexInfo(
-                    keyType,
-                    declaration.type ? getTypeFromTypeNode(declaration.type) : anyType,
-                    hasEffectiveModifier(declaration, 64 /* Readonly */),
-                    declaration
-                  ));
+                  indexInfos.push(createIndexInfo(keyType, declaration.type ? getTypeFromTypeNode(declaration.type) : anyType, hasEffectiveModifier(declaration, 8 /* Readonly */), declaration));
                 }
               });
             }
@@ -156562,9 +140266,9 @@ ${lanes.join("\n")}
       let inferences;
       if ((_a = typeParameter.symbol) == null ? void 0 : _a.declarations) {
         for (const declaration of typeParameter.symbol.declarations) {
-          if (declaration.parent.kind === 194 /* InferType */) {
+          if (declaration.parent.kind === 195 /* InferType */) {
             const [childTypeParameter = declaration.parent, grandParent] = walkUpParenthesizedTypesAndGetParentAndChild(declaration.parent.parent);
-            if (grandParent.kind === 182 /* TypeReference */ && !omitTypeReferences) {
+            if (grandParent.kind === 183 /* TypeReference */ && !omitTypeReferences) {
               const typeReference = grandParent;
               const typeParameters = getTypeParametersForTypeReferenceOrImport(typeReference);
               if (typeParameters) {
@@ -156572,9 +140276,12 @@ ${lanes.join("\n")}
                 if (index < typeParameters.length) {
                   const declaredConstraint = getConstraintOfTypeParameter(typeParameters[index]);
                   if (declaredConstraint) {
-                    const mapper = makeDeferredTypeMapper(typeParameters, typeParameters.map((_, index2) => () => {
-                      return getEffectiveTypeArgumentAtIndex(typeReference, typeParameters, index2);
-                    }));
+                    const mapper = makeDeferredTypeMapper(
+                      typeParameters,
+                      typeParameters.map((_, index2) => () => {
+                        return getEffectiveTypeArgumentAtIndex(typeReference, typeParameters, index2);
+                      })
+                    );
                     const constraint = instantiateType(declaredConstraint, mapper);
                     if (constraint !== typeParameter) {
                       inferences = append(inferences, constraint);
@@ -156582,19 +140289,16 @@ ${lanes.join("\n")}
                   }
                 }
               }
-            } else if (grandParent.kind === 168 /* Parameter */ && grandParent.dotDotDotToken || grandParent.kind === 190 /* RestType */ || grandParent.kind === 201 /* NamedTupleMember */ && grandParent.dotDotDotToken) {
+            } else if (grandParent.kind === 169 /* Parameter */ && grandParent.dotDotDotToken || grandParent.kind === 191 /* RestType */ || grandParent.kind === 202 /* NamedTupleMember */ && grandParent.dotDotDotToken) {
               inferences = append(inferences, createArrayType(unknownType));
-            } else if (grandParent.kind === 203 /* TemplateLiteralTypeSpan */) {
+            } else if (grandParent.kind === 204 /* TemplateLiteralTypeSpan */) {
               inferences = append(inferences, stringType);
-            } else if (grandParent.kind === 167 /* TypeParameter */ && grandParent.parent.kind === 199 /* MappedType */) {
+            } else if (grandParent.kind === 168 /* TypeParameter */ && grandParent.parent.kind === 200 /* MappedType */) {
               inferences = append(inferences, keyofConstraintType);
-            } else if (grandParent.kind === 199 /* MappedType */ && grandParent.type && skipParentheses(grandParent.type) === declaration.parent && grandParent.parent.kind === 193 /* ConditionalType */ && grandParent.parent.extendsType === grandParent && grandParent.parent.checkType.kind === 199 /* MappedType */ && grandParent.parent.checkType.type) {
+            } else if (grandParent.kind === 200 /* MappedType */ && grandParent.type && skipParentheses(grandParent.type) === declaration.parent && grandParent.parent.kind === 194 /* ConditionalType */ && grandParent.parent.extendsType === grandParent && grandParent.parent.checkType.kind === 200 /* MappedType */ && grandParent.parent.checkType.type) {
               const checkMappedType2 = grandParent.parent.checkType;
               const nodeType = getTypeFromTypeNode(checkMappedType2.type);
-              inferences = append(inferences, instantiateType(
-                nodeType,
-                makeUnaryTypeMapper(getDeclaredTypeOfTypeParameter(getSymbolOfDeclaration(checkMappedType2.typeParameter)), checkMappedType2.typeParameter.constraint ? getTypeFromTypeNode(checkMappedType2.typeParameter.constraint) : keyofConstraintType)
-              ));
+              inferences = append(inferences, instantiateType(nodeType, makeUnaryTypeMapper(getDeclaredTypeOfTypeParameter(getSymbolOfDeclaration(checkMappedType2.typeParameter)), checkMappedType2.typeParameter.constraint ? getTypeFromTypeNode(checkMappedType2.typeParameter.constraint) : keyofConstraintType)));
             }
           }
         }
@@ -156613,7 +140317,7 @@ ${lanes.join("\n")}
           } else {
             let type = getTypeFromTypeNode(constraintDeclaration);
             if (type.flags & 1 /* Any */ && !isErrorType(type)) {
-              type = constraintDeclaration.parent.parent.kind === 199 /* MappedType */ ? keyofConstraintType : unknownType;
+              type = constraintDeclaration.parent.parent.kind === 200 /* MappedType */ ? keyofConstraintType : unknownType;
             }
             typeParameter.constraint = type;
           }
@@ -156622,7 +140326,7 @@ ${lanes.join("\n")}
       return typeParameter.constraint === noConstraintType ? void 0 : typeParameter.constraint;
     }
     function getParentSymbolOfTypeParameter(typeParameter) {
-      const tp = getDeclarationOfKind(typeParameter.symbol, 167 /* TypeParameter */);
+      const tp = getDeclarationOfKind(typeParameter.symbol, 168 /* TypeParameter */);
       const host2 = isJSDocTemplateTag(tp.parent) ? getEffectiveContainerForJSDocTemplateTag(tp.parent) : tp.parent;
       return host2 && getSymbolOfNode(host2);
     }
@@ -156707,12 +140411,12 @@ ${lanes.join("\n")}
           return ((_a = type.target.localTypeParameters) == null ? void 0 : _a.map(() => errorType)) || emptyArray;
         }
         const node = type.node;
-        const typeArguments = !node ? emptyArray : node.kind === 182 /* TypeReference */ ? concatenate(type.target.outerTypeParameters, getEffectiveTypeArguments2(node, type.target.localTypeParameters)) : node.kind === 187 /* ArrayType */ ? [getTypeFromTypeNode(node.elementType)] : map(node.elements, getTypeFromTypeNode);
+        const typeArguments = !node ? emptyArray : node.kind === 183 /* TypeReference */ ? concatenate(type.target.outerTypeParameters, getEffectiveTypeArguments2(node, type.target.localTypeParameters)) : node.kind === 188 /* ArrayType */ ? [getTypeFromTypeNode(node.elementType)] : map(node.elements, getTypeFromTypeNode);
         if (popTypeResolution()) {
           type.resolvedTypeArguments = type.mapper ? instantiateTypes(typeArguments, type.mapper) : typeArguments;
         } else {
           type.resolvedTypeArguments = ((_b = type.target.localTypeParameters) == null ? void 0 : _b.map(() => errorType)) || emptyArray;
-          error(
+          error2(
             type.node || currentNode,
             type.target.symbol ? Diagnostics.Type_arguments_for_0_circularly_reference_themselves : Diagnostics.Tuple_type_arguments_circularly_reference_themselves,
             type.target.symbol && symbolToString(type.target.symbol)
@@ -156741,12 +140445,12 @@ ${lanes.join("\n")}
             void 0,
             2 /* WriteArrayAsGenericType */
           );
-          error(node, diag2, typeStr, minTypeArgumentCount, typeParameters.length);
+          error2(node, diag2, typeStr, minTypeArgumentCount, typeParameters.length);
           if (!isJs) {
             return errorType;
           }
         }
-        if (node.kind === 182 /* TypeReference */ && isDeferredTypeReferenceNode(node, length(node.typeArguments) !== typeParameters.length)) {
+        if (node.kind === 183 /* TypeReference */ && isDeferredTypeReferenceNode(node, length(node.typeArguments) !== typeParameters.length)) {
           return createDeferredTypeReference(
             type,
             node,
@@ -156769,12 +140473,7 @@ ${lanes.join("\n")}
       const id = getTypeListId(typeArguments) + getAliasId(aliasSymbol, aliasTypeArguments);
       let instantiation = links.instantiations.get(id);
       if (!instantiation) {
-        links.instantiations.set(id, instantiation = instantiateTypeWithAlias(
-          type,
-          createTypeMapper(typeParameters, fillMissingTypeArguments(typeArguments, typeParameters, getMinTypeArgumentCount(typeParameters), isInJSFile(symbol.valueDeclaration))),
-          aliasSymbol,
-          aliasTypeArguments
-        ));
+        links.instantiations.set(id, instantiation = instantiateTypeWithAlias(type, createTypeMapper(typeParameters, fillMissingTypeArguments(typeArguments, typeParameters, getMinTypeArgumentCount(typeParameters), isInJSFile(symbol.valueDeclaration))), aliasSymbol, aliasTypeArguments));
       }
       return instantiation;
     }
@@ -156784,7 +140483,13 @@ ${lanes.join("\n")}
         const id = getAliasId(symbol, typeArguments);
         let errorType2 = errorTypes.get(id);
         if (!errorType2) {
-          errorType2 = createIntrinsicType(1 /* Any */, "error");
+          errorType2 = createIntrinsicType(
+            1 /* Any */,
+            "error",
+            /*objectFlags*/
+            void 0,
+            `alias ${id}`
+          );
           errorType2.aliasSymbol = symbol;
           errorType2.aliasTypeArguments = typeArguments;
           errorTypes.set(id, errorType2);
@@ -156797,7 +140502,7 @@ ${lanes.join("\n")}
         const numTypeArguments = length(node.typeArguments);
         const minTypeArgumentCount = getMinTypeArgumentCount(typeParameters);
         if (numTypeArguments < minTypeArgumentCount || numTypeArguments > typeParameters.length) {
-          error(
+          error2(
             node,
             minTypeArgumentCount === typeParameters.length ? Diagnostics.Generic_type_0_requires_1_type_argument_s : Diagnostics.Generic_type_0_requires_between_1_and_2_type_arguments,
             symbolToString(symbol),
@@ -156837,9 +140542,9 @@ ${lanes.join("\n")}
     }
     function getTypeReferenceName(node) {
       switch (node.kind) {
-        case 182 /* TypeReference */:
+        case 183 /* TypeReference */:
           return node.typeName;
-        case 232 /* ExpressionWithTypeArguments */:
+        case 233 /* ExpressionWithTypeArguments */:
           const expr = node.expression;
           if (isEntityNameExpression(expr)) {
             return expr;
@@ -156851,10 +140556,10 @@ ${lanes.join("\n")}
       return symbol.parent ? `${getSymbolPath(symbol.parent)}.${symbol.escapedName}` : symbol.escapedName;
     }
     function getUnresolvedSymbolForEntityName(name) {
-      const identifier = name.kind === 165 /* QualifiedName */ ? name.right : name.kind === 210 /* PropertyAccessExpression */ ? name.name : name;
+      const identifier = name.kind === 166 /* QualifiedName */ ? name.right : name.kind === 211 /* PropertyAccessExpression */ ? name.name : name;
       const text = identifier.escapedText;
       if (text) {
-        const parentSymbol = name.kind === 165 /* QualifiedName */ ? getUnresolvedSymbolForEntityName(name.left) : name.kind === 210 /* PropertyAccessExpression */ ? getUnresolvedSymbolForEntityName(name.expression) : void 0;
+        const parentSymbol = name.kind === 166 /* QualifiedName */ ? getUnresolvedSymbolForEntityName(name.left) : name.kind === 211 /* PropertyAccessExpression */ ? getUnresolvedSymbolForEntityName(name.expression) : void 0;
         const path = parentSymbol ? `${getSymbolPath(parentSymbol)}.${text}` : text;
         let result = unresolvedSymbols.get(path);
         if (!result) {
@@ -156906,7 +140611,7 @@ ${lanes.join("\n")}
         const valueType = getTypeOfSymbol(symbol);
         let typeType = valueType;
         if (symbol.valueDeclaration) {
-          const isImportTypeWithQualifier = node.kind === 204 /* ImportType */ && node.qualifier;
+          const isImportTypeWithQualifier = node.kind === 205 /* ImportType */ && node.qualifier;
           if (valueType.symbol && valueType.symbol !== symbol && isImportTypeWithQualifier) {
             typeType = getTypeReferenceType(node, valueType.symbol);
           }
@@ -156934,7 +140639,7 @@ ${lanes.join("\n")}
       return getIntersectionType([substitutionType.constraint, substitutionType.baseType]);
     }
     function isUnaryTupleTypeNode(node) {
-      return node.kind === 188 /* TupleType */ && node.elements.length === 1;
+      return node.kind === 189 /* TupleType */ && node.elements.length === 1;
     }
     function getImpliedConstraint(type, checkNode, extendsNode) {
       return isUnaryTupleTypeNode(checkNode) && isUnaryTupleTypeNode(extendsNode) ? getImpliedConstraint(type, checkNode.elements[0], extendsNode.elements[0]) : getActualTypeVariable(getTypeFromTypeNode(checkNode)) === getActualTypeVariable(type) ? getTypeFromTypeNode(extendsNode) : void 0;
@@ -156942,17 +140647,17 @@ ${lanes.join("\n")}
     function getConditionalFlowTypeOfType(type, node) {
       let constraints;
       let covariant = true;
-      while (node && !isStatement(node) && node.kind !== 326 /* JSDoc */) {
+      while (node && !isStatement(node) && node.kind !== 327 /* JSDoc */) {
         const parent2 = node.parent;
-        if (parent2.kind === 168 /* Parameter */) {
+        if (parent2.kind === 169 /* Parameter */) {
           covariant = !covariant;
         }
-        if ((covariant || type.flags & 8650752 /* TypeVariable */) && parent2.kind === 193 /* ConditionalType */ && node === parent2.trueType) {
+        if ((covariant || type.flags & 8650752 /* TypeVariable */) && parent2.kind === 194 /* ConditionalType */ && node === parent2.trueType) {
           const constraint = getImpliedConstraint(type, parent2.checkType, parent2.extendsType);
           if (constraint) {
             constraints = append(constraints, constraint);
           }
-        } else if (type.flags & 262144 /* TypeParameter */ && parent2.kind === 199 /* MappedType */ && node === parent2.type) {
+        } else if (type.flags & 262144 /* TypeParameter */ && parent2.kind === 200 /* MappedType */ && node === parent2.type) {
           const mappedType = getTypeFromTypeNode(parent2);
           if (getTypeParameterFromMappedType(mappedType) === getActualTypeVariable(type)) {
             const typeParameter = getHomomorphicTypeVariable(mappedType);
@@ -156969,11 +140674,11 @@ ${lanes.join("\n")}
       return constraints ? getSubstitutionType(type, getIntersectionType(constraints)) : type;
     }
     function isJSDocTypeReference(node) {
-      return !!(node.flags & 8388608 /* JSDoc */) && (node.kind === 182 /* TypeReference */ || node.kind === 204 /* ImportType */);
+      return !!(node.flags & 16777216 /* JSDoc */) && (node.kind === 183 /* TypeReference */ || node.kind === 205 /* ImportType */);
     }
     function checkNoTypeArguments(node, symbol) {
       if (node.typeArguments) {
-        error(node, Diagnostics.Type_0_is_not_generic, symbol ? symbolToString(symbol) : node.typeName ? declarationNameToString(node.typeName) : anon);
+        error2(node, Diagnostics.Type_0_is_not_generic, symbol ? symbolToString(symbol) : node.typeName ? declarationNameToString(node.typeName) : anon);
         return false;
       }
       return true;
@@ -157092,9 +140797,9 @@ ${lanes.join("\n")}
         if (declarations) {
           for (const declaration of declarations) {
             switch (declaration.kind) {
-              case 262 /* ClassDeclaration */:
-              case 263 /* InterfaceDeclaration */:
-              case 265 /* EnumDeclaration */:
+              case 263 /* ClassDeclaration */:
+              case 264 /* InterfaceDeclaration */:
+              case 266 /* EnumDeclaration */:
                 return declaration;
             }
           }
@@ -157105,11 +140810,11 @@ ${lanes.join("\n")}
       }
       const type = getDeclaredTypeOfSymbol(symbol);
       if (!(type.flags & 524288 /* Object */)) {
-        error(getTypeDeclaration(symbol), Diagnostics.Global_type_0_must_be_a_class_or_interface_type, symbolName(symbol));
+        error2(getTypeDeclaration(symbol), Diagnostics.Global_type_0_must_be_a_class_or_interface_type, symbolName(symbol));
         return arity ? emptyGenericType : emptyObjectType;
       }
       if (length(type.typeParameters) !== arity) {
-        error(getTypeDeclaration(symbol), Diagnostics.Global_type_0_must_have_1_type_parameter_s, symbolName(symbol), arity);
+        error2(getTypeDeclaration(symbol), Diagnostics.Global_type_0_must_have_1_type_parameter_s, symbolName(symbol), arity);
         return arity ? emptyGenericType : emptyObjectType;
       }
       return type;
@@ -157126,7 +140831,7 @@ ${lanes.join("\n")}
         getDeclaredTypeOfSymbol(symbol);
         if (length(getSymbolLinks(symbol).typeParameters) !== arity) {
           const decl = symbol.declarations && find(symbol.declarations, isTypeAliasDeclaration);
-          error(decl, Diagnostics.Global_type_0_must_have_1_type_parameter_s, symbolName(symbol), arity);
+          error2(decl, Diagnostics.Global_type_0_must_have_1_type_parameter_s, symbolName(symbol), arity);
           return void 0;
         }
       }
@@ -157322,6 +141027,22 @@ ${lanes.join("\n")}
         reportErrors2
       )) || emptyGenericType;
     }
+    function getGlobalDisposableType(reportErrors2) {
+      return deferredGlobalDisposableType || (deferredGlobalDisposableType = getGlobalType(
+        "Disposable",
+        /*arity*/
+        0,
+        reportErrors2
+      )) || emptyObjectType;
+    }
+    function getGlobalAsyncDisposableType(reportErrors2) {
+      return deferredGlobalAsyncDisposableType || (deferredGlobalAsyncDisposableType = getGlobalType(
+        "AsyncDisposable",
+        /*arity*/
+        0,
+        reportErrors2
+      )) || emptyObjectType;
+    }
     function getGlobalTypeOrUndefined(name, arity = 0) {
       const symbol = getGlobalSymbol(
         name,
@@ -157467,11 +141188,11 @@ ${lanes.join("\n")}
     }
     function getTupleElementFlags(node) {
       switch (node.kind) {
-        case 189 /* OptionalType */:
+        case 190 /* OptionalType */:
           return 2 /* Optional */;
-        case 190 /* RestType */:
+        case 191 /* RestType */:
           return getRestTypeElementFlags(node);
-        case 201 /* NamedTupleMember */:
+        case 202 /* NamedTupleMember */:
           return node.questionToken ? 2 /* Optional */ : node.dotDotDotToken ? getRestTypeElementFlags(node) : 1 /* Required */;
         default:
           return 1 /* Required */;
@@ -157487,60 +141208,57 @@ ${lanes.join("\n")}
         return readonly ? globalReadonlyArrayType : globalArrayType;
       }
       const elementFlags = map(node.elements, getTupleElementFlags);
-      const missingName = some(node.elements, (e) => e.kind !== 201 /* NamedTupleMember */);
-      return getTupleTargetType(
-        elementFlags,
-        readonly,
-        /*associatedNames*/
-        missingName ? void 0 : node.elements
-      );
+      return getTupleTargetType(elementFlags, readonly, map(node.elements, memberIfLabeledElementDeclaration));
+    }
+    function memberIfLabeledElementDeclaration(member) {
+      return isNamedTupleMember(member) || isParameter(member) ? member : void 0;
     }
     function isDeferredTypeReferenceNode(node, hasDefaultTypeArguments) {
-      return !!getAliasSymbolForTypeNode(node) || isResolvedByTypeAlias(node) && (node.kind === 187 /* ArrayType */ ? mayResolveTypeAlias(node.elementType) : node.kind === 188 /* TupleType */ ? some(node.elements, mayResolveTypeAlias) : hasDefaultTypeArguments || some(node.typeArguments, mayResolveTypeAlias));
+      return !!getAliasSymbolForTypeNode(node) || isResolvedByTypeAlias(node) && (node.kind === 188 /* ArrayType */ ? mayResolveTypeAlias(node.elementType) : node.kind === 189 /* TupleType */ ? some(node.elements, mayResolveTypeAlias) : hasDefaultTypeArguments || some(node.typeArguments, mayResolveTypeAlias));
     }
     function isResolvedByTypeAlias(node) {
       const parent2 = node.parent;
       switch (parent2.kind) {
-        case 195 /* ParenthesizedType */:
-        case 201 /* NamedTupleMember */:
-        case 182 /* TypeReference */:
-        case 191 /* UnionType */:
-        case 192 /* IntersectionType */:
-        case 198 /* IndexedAccessType */:
-        case 193 /* ConditionalType */:
-        case 197 /* TypeOperator */:
-        case 187 /* ArrayType */:
-        case 188 /* TupleType */:
+        case 196 /* ParenthesizedType */:
+        case 202 /* NamedTupleMember */:
+        case 183 /* TypeReference */:
+        case 192 /* UnionType */:
+        case 193 /* IntersectionType */:
+        case 199 /* IndexedAccessType */:
+        case 194 /* ConditionalType */:
+        case 198 /* TypeOperator */:
+        case 188 /* ArrayType */:
+        case 189 /* TupleType */:
           return isResolvedByTypeAlias(parent2);
-        case 264 /* TypeAliasDeclaration */:
+        case 265 /* TypeAliasDeclaration */:
           return true;
       }
       return false;
     }
     function mayResolveTypeAlias(node) {
       switch (node.kind) {
-        case 182 /* TypeReference */:
+        case 183 /* TypeReference */:
           return isJSDocTypeReference(node) || !!(resolveTypeReferenceName(node, 788968 /* Type */).flags & 524288 /* TypeAlias */);
-        case 185 /* TypeQuery */:
+        case 186 /* TypeQuery */:
           return true;
-        case 197 /* TypeOperator */:
+        case 198 /* TypeOperator */:
           return node.operator !== 158 /* UniqueKeyword */ && mayResolveTypeAlias(node.type);
-        case 195 /* ParenthesizedType */:
-        case 189 /* OptionalType */:
-        case 201 /* NamedTupleMember */:
-        case 322 /* JSDocOptionalType */:
-        case 320 /* JSDocNullableType */:
-        case 321 /* JSDocNonNullableType */:
-        case 315 /* JSDocTypeExpression */:
+        case 196 /* ParenthesizedType */:
+        case 190 /* OptionalType */:
+        case 202 /* NamedTupleMember */:
+        case 323 /* JSDocOptionalType */:
+        case 321 /* JSDocNullableType */:
+        case 322 /* JSDocNonNullableType */:
+        case 316 /* JSDocTypeExpression */:
           return mayResolveTypeAlias(node.type);
-        case 190 /* RestType */:
-          return node.type.kind !== 187 /* ArrayType */ || mayResolveTypeAlias(node.type.elementType);
-        case 191 /* UnionType */:
-        case 192 /* IntersectionType */:
+        case 191 /* RestType */:
+          return node.type.kind !== 188 /* ArrayType */ || mayResolveTypeAlias(node.type.elementType);
+        case 192 /* UnionType */:
+        case 193 /* IntersectionType */:
           return some(node.types, mayResolveTypeAlias);
-        case 198 /* IndexedAccessType */:
+        case 199 /* IndexedAccessType */:
           return mayResolveTypeAlias(node.objectType) || mayResolveTypeAlias(node.indexType);
-        case 193 /* ConditionalType */:
+        case 194 /* ConditionalType */:
           return mayResolveTypeAlias(node.checkType) || mayResolveTypeAlias(node.extendsType) || mayResolveTypeAlias(node.trueType) || mayResolveTypeAlias(node.falseType);
       }
       return false;
@@ -157551,15 +141269,15 @@ ${lanes.join("\n")}
         const target = getArrayOrTupleTargetType(node);
         if (target === emptyGenericType) {
           links.resolvedType = emptyObjectType;
-        } else if (!(node.kind === 188 /* TupleType */ && some(node.elements, (e) => !!(getTupleElementFlags(e) & 8 /* Variadic */))) && isDeferredTypeReferenceNode(node)) {
-          links.resolvedType = node.kind === 188 /* TupleType */ && node.elements.length === 0 ? target : createDeferredTypeReference(
+        } else if (!(node.kind === 189 /* TupleType */ && some(node.elements, (e) => !!(getTupleElementFlags(e) & 8 /* Variadic */))) && isDeferredTypeReferenceNode(node)) {
+          links.resolvedType = node.kind === 189 /* TupleType */ && node.elements.length === 0 ? target : createDeferredTypeReference(
             target,
             node,
             /*mapper*/
             void 0
           );
         } else {
-          const elementTypes = node.kind === 187 /* ArrayType */ ? [getTypeFromTypeNode(node.elementType)] : map(node.elements, getTypeFromTypeNode);
+          const elementTypes = node.kind === 188 /* ArrayType */ ? [getTypeFromTypeNode(node.elementType)] : map(node.elements, getTypeFromTypeNode);
           links.resolvedType = createNormalizedTypeReference(target, elementTypes);
         }
       }
@@ -157568,7 +141286,7 @@ ${lanes.join("\n")}
     function isReadonlyTypeOperator(node) {
       return isTypeOperatorNode(node) && node.operator === 148 /* ReadonlyKeyword */;
     }
-    function createTupleType(elementTypes, elementFlags, readonly = false, namedMemberDeclarations) {
+    function createTupleType(elementTypes, elementFlags, readonly = false, namedMemberDeclarations = []) {
       const tupleTarget = getTupleTargetType(elementFlags || map(elementTypes, (_) => 1 /* Required */), readonly, namedMemberDeclarations);
       return tupleTarget === emptyGenericType ? emptyObjectType : elementTypes.length ? createNormalizedTypeReference(tupleTarget, elementTypes) : tupleTarget;
     }
@@ -157576,7 +141294,7 @@ ${lanes.join("\n")}
       if (elementFlags.length === 1 && elementFlags[0] & 4 /* Rest */) {
         return readonly ? globalReadonlyArrayType : globalArrayType;
       }
-      const key = map(elementFlags, (f) => f & 1 /* Required */ ? "#" : f & 2 /* Optional */ ? "?" : f & 4 /* Rest */ ? "." : "*").join() + (readonly ? "R" : "") + (namedMemberDeclarations && namedMemberDeclarations.length ? "," + map(namedMemberDeclarations, getNodeId).join(",") : "");
+      const key = map(elementFlags, (f) => f & 1 /* Required */ ? "#" : f & 2 /* Optional */ ? "?" : f & 4 /* Rest */ ? "." : "*").join() + (readonly ? "R" : "") + (some(namedMemberDeclarations, (node) => !!node) ? "," + map(namedMemberDeclarations, (node) => node ? getNodeId(node) : "_").join(",") : "");
       let type = tupleTypes.get(key);
       if (!type) {
         tupleTypes.set(key, type = createTupleTargetType(elementFlags, readonly, namedMemberDeclarations));
@@ -157596,11 +141314,7 @@ ${lanes.join("\n")}
           const flags = elementFlags[i];
           combinedFlags |= flags;
           if (!(combinedFlags & 12 /* Variable */)) {
-            const property = createSymbol(
-              4 /* Property */ | (flags & 2 /* Optional */ ? 16777216 /* Optional */ : 0),
-              "" + i,
-              readonly ? 8 /* Readonly */ : 0
-            );
+            const property = createSymbol(4 /* Property */ | (flags & 2 /* Optional */ ? 16777216 /* Optional */ : 0), "" + i, readonly ? 8 /* Readonly */ : 0);
             property.links.tupleLabelDeclaration = namedMemberDeclarations == null ? void 0 : namedMemberDeclarations[i];
             property.links.type = typeParameter;
             properties.push(property);
@@ -157658,7 +141372,7 @@ ${lanes.join("\n")}
       }
       const expandedTypes = [];
       const expandedFlags = [];
-      let expandedDeclarations = [];
+      const expandedDeclarations = [];
       let lastRequiredIndex = -1;
       let firstRestIndex = -1;
       let lastOptionalOrRestIndex = -1;
@@ -157671,7 +141385,10 @@ ${lanes.join("\n")}
           } else if (isTupleType(type)) {
             const elements = getElementTypes(type);
             if (elements.length + expandedTypes.length >= 1e4) {
-              error(currentNode, isPartOfTypeNode(currentNode) ? Diagnostics.Type_produces_a_tuple_type_that_is_too_large_to_represent : Diagnostics.Expression_produces_a_tuple_type_that_is_too_large_to_represent);
+              error2(
+                currentNode,
+                isPartOfTypeNode(currentNode) ? Diagnostics.Type_produces_a_tuple_type_that_is_too_large_to_represent : Diagnostics.Expression_produces_a_tuple_type_that_is_too_large_to_represent
+              );
               return errorType;
             }
             forEach(elements, (t, n) => {
@@ -157690,13 +141407,10 @@ ${lanes.join("\n")}
           expandedFlags[i] = 1 /* Required */;
       }
       if (firstRestIndex >= 0 && firstRestIndex < lastOptionalOrRestIndex) {
-        expandedTypes[firstRestIndex] = getUnionType(sameMap(
-          expandedTypes.slice(firstRestIndex, lastOptionalOrRestIndex + 1),
-          (t, i) => expandedFlags[firstRestIndex + i] & 8 /* Variadic */ ? getIndexedAccessType(t, numberType) : t
-        ));
+        expandedTypes[firstRestIndex] = getUnionType(sameMap(expandedTypes.slice(firstRestIndex, lastOptionalOrRestIndex + 1), (t, i) => expandedFlags[firstRestIndex + i] & 8 /* Variadic */ ? getIndexedAccessType(t, numberType) : t));
         expandedTypes.splice(firstRestIndex + 1, lastOptionalOrRestIndex - firstRestIndex);
         expandedFlags.splice(firstRestIndex + 1, lastOptionalOrRestIndex - firstRestIndex);
-        expandedDeclarations == null ? void 0 : expandedDeclarations.splice(firstRestIndex + 1, lastOptionalOrRestIndex - firstRestIndex);
+        expandedDeclarations.splice(firstRestIndex + 1, lastOptionalOrRestIndex - firstRestIndex);
       }
       const tupleTarget = getTupleTargetType(expandedFlags, target.readonly, expandedDeclarations);
       return tupleTarget === emptyGenericType ? emptyObjectType : expandedFlags.length ? createTypeReference(tupleTarget, expandedTypes) : tupleTarget;
@@ -157716,11 +141430,7 @@ ${lanes.join("\n")}
           true
         ) : type);
         expandedFlags.push(flags);
-        if (expandedDeclarations && declaration) {
-          expandedDeclarations.push(declaration);
-        } else {
-          expandedDeclarations = void 0;
-        }
+        expandedDeclarations.push(declaration);
       }
     }
     function sliceTupleType(type, index, endSkipCount = 0) {
@@ -157735,10 +141445,7 @@ ${lanes.join("\n")}
       );
     }
     function getKnownKeysOfTupleType(type) {
-      return getUnionType(append(
-        arrayOf(type.target.fixedLength, (i) => getStringLiteralType("" + i)),
-        getIndexType(type.target.readonly ? globalReadonlyArrayType : globalArrayType)
-      ));
+      return getUnionType(append(arrayOf(type.target.fixedLength, (i) => getStringLiteralType("" + i)), getIndexType(type.target.readonly ? globalReadonlyArrayType : globalArrayType)));
     }
     function getStartElementCount(type, flags) {
       const index = findIndex(type.elementFlags, (f) => !(f & flags));
@@ -157747,6 +141454,9 @@ ${lanes.join("\n")}
     function getEndElementCount(type, flags) {
       return type.elementFlags.length - findLastIndex(type.elementFlags, (f) => !(f & flags)) - 1;
     }
+    function getTotalFixedElementCount(type) {
+      return type.fixedLength + getEndElementCount(type, 3 /* Fixed */);
+    }
     function getElementTypes(type) {
       const typeArguments = getTypeArguments(type);
       const arity = getTypeReferenceArity(type);
@@ -157836,7 +141546,7 @@ ${lanes.join("\n")}
                 const estimatedCount = count / (len - i) * len;
                 if (estimatedCount > 1e6) {
                   (_a = tracing) == null ? void 0 : _a.instant(tracing.Phase.CheckTypes, "removeSubtypes_DepthLimit", { typeIds: types.map((t) => t.id) });
-                  error(currentNode, Diagnostics.Expression_produces_a_union_type_that_is_too_complex_to_represent);
+                  error2(currentNode, Diagnostics.Expression_produces_a_union_type_that_is_too_complex_to_represent);
                   return void 0;
                 }
               }
@@ -158041,12 +141751,7 @@ ${lanes.join("\n")}
       const links = getNodeLinks(node);
       if (!links.resolvedType) {
         const aliasSymbol = getAliasSymbolForTypeNode(node);
-        links.resolvedType = getUnionType(
-          map(node.types, getTypeFromTypeNode),
-          1 /* Literal */,
-          aliasSymbol,
-          getTypeArgumentsForAliasSymbol(aliasSymbol)
-        );
+        links.resolvedType = getUnionType(map(node.types, getTypeFromTypeNode), 1 /* Literal */, aliasSymbol, getTypeArgumentsForAliasSymbol(aliasSymbol));
       }
       return links.resolvedType;
     }
@@ -158245,7 +141950,7 @@ ${lanes.join("\n")}
       const size = getCrossProductUnionSize(types);
       if (size >= 1e5) {
         (_a = tracing) == null ? void 0 : _a.instant(tracing.Phase.CheckTypes, "checkCrossProductUnion_DepthLimit", { typeIds: types.map((t) => t.id), size });
-        error(currentNode, Diagnostics.Expression_produces_a_union_type_that_is_too_complex_to_represent);
+        error2(currentNode, Diagnostics.Expression_produces_a_union_type_that_is_too_complex_to_represent);
         return false;
       }
       return true;
@@ -158276,15 +141981,14 @@ ${lanes.join("\n")}
     function getConstituentCountOfTypes(types) {
       return reduceLeft(types, (n, t) => n + getConstituentCount(t), 0);
     }
-    function areIntersectedTypesAvoidingPrimitiveReduction(t1, t2) {
-      return !!(t1.flags & (4 /* String */ | 8 /* Number */ | 64 /* BigInt */)) && t2 === emptyTypeLiteralType;
-    }
     function getTypeFromIntersectionTypeNode(node) {
       const links = getNodeLinks(node);
       if (!links.resolvedType) {
         const aliasSymbol = getAliasSymbolForTypeNode(node);
         const types = map(node.types, getTypeFromTypeNode);
-        const noSupertypeReduction = types.length === 2 && (areIntersectedTypesAvoidingPrimitiveReduction(types[0], types[1]) || areIntersectedTypesAvoidingPrimitiveReduction(types[1], types[0]));
+        const emptyIndex = types.length === 2 ? types.indexOf(emptyTypeLiteralType) : -1;
+        const t = emptyIndex >= 0 ? types[1 - emptyIndex] : unknownType;
+        const noSupertypeReduction = !!(t.flags & (4 /* String */ | 8 /* Number */ | 64 /* BigInt */) || t.flags & 134217728 /* TemplateLiteral */ && isPatternLiteralType(t));
         links.resolvedType = getIntersectionType(types, aliasSymbol, getTypeArgumentsForAliasSymbol(aliasSymbol), noSupertypeReduction);
       }
       return links.resolvedType;
@@ -158361,7 +142065,7 @@ ${lanes.join("\n")}
       return neverType;
     }
     function getLiteralTypeFromProperty(prop, include, includeNonPublic) {
-      if (includeNonPublic || !(getDeclarationModifierFlagsFromSymbol(prop) & 24 /* NonPublicAccessibilityModifier */)) {
+      if (includeNonPublic || !(getDeclarationModifierFlagsFromSymbol(prop) & 6 /* NonPublicAccessibilityModifier */)) {
         let type = getSymbolLinks(getLateBoundSymbol(prop)).nameType;
         if (!type) {
           const name = getNameOfDeclaration(prop.valueDeclaration);
@@ -158395,11 +142099,7 @@ ${lanes.join("\n")}
     }
     function getIndexType(type, indexFlags = defaultIndexFlags) {
       type = getReducedType(type);
-      return shouldDeferIndexType(type, indexFlags) ? getIndexTypeForGenericType(type, indexFlags) : type.flags & 1048576 /* Union */ ? getIntersectionType(map(type.types, (t) => getIndexType(t, indexFlags))) : type.flags & 2097152 /* Intersection */ ? getUnionType(map(type.types, (t) => getIndexType(t, indexFlags))) : getObjectFlags(type) & 32 /* Mapped */ ? getIndexTypeForMappedType(type, indexFlags) : type === wildcardType ? wildcardType : type.flags & 2 /* Unknown */ ? neverType : type.flags & (1 /* Any */ | 131072 /* Never */) ? keyofConstraintType : getLiteralTypeFromProperties(
-        type,
-        (indexFlags & 2 /* NoIndexSignatures */ ? 128 /* StringLiteral */ : 402653316 /* StringLike */) | (indexFlags & 1 /* StringsOnly */ ? 0 : 296 /* NumberLike */ | 12288 /* ESSymbolLike */),
-        indexFlags === defaultIndexFlags
-      );
+      return shouldDeferIndexType(type, indexFlags) ? getIndexTypeForGenericType(type, indexFlags) : type.flags & 1048576 /* Union */ ? getIntersectionType(map(type.types, (t) => getIndexType(t, indexFlags))) : type.flags & 2097152 /* Intersection */ ? getUnionType(map(type.types, (t) => getIndexType(t, indexFlags))) : getObjectFlags(type) & 32 /* Mapped */ ? getIndexTypeForMappedType(type, indexFlags) : type === wildcardType ? wildcardType : type.flags & 2 /* Unknown */ ? neverType : type.flags & (1 /* Any */ | 131072 /* Never */) ? keyofConstraintType : getLiteralTypeFromProperties(type, (indexFlags & 2 /* NoIndexSignatures */ ? 128 /* StringLiteral */ : 402653316 /* StringLike */) | (indexFlags & 1 /* StringsOnly */ ? 0 : 296 /* NumberLike */ | 12288 /* ESSymbolLike */), indexFlags === defaultIndexFlags);
     }
     function getExtractStringType(type) {
       if (keyofStringsOnly) {
@@ -158500,11 +142200,6 @@ ${lanes.join("\n")}
     }
     function createTemplateLiteralType(texts, types) {
       const type = createType(134217728 /* TemplateLiteral */);
-      type.objectFlags = getPropagatingFlagsOfTypes(
-        types,
-        /*excludeKinds*/
-        98304 /* Nullable */
-      );
       type.texts = texts;
       type.types = types;
       return type;
@@ -158597,12 +142292,12 @@ ${lanes.join("\n")}
         if (isCallLikeExpression(parent2)) {
           return isCallOrNewExpression(parent2) && isIdentifier(node) && hasMatchingArgument(parent2, node);
         }
-        return every(symbol.declarations, (d) => !isFunctionLike(d) || !!(getCombinedNodeFlags(d) & 268435456 /* Deprecated */));
+        return every(symbol.declarations, (d) => !isFunctionLike(d) || isDeprecatedDeclaration2(d));
       }
       return true;
     }
     function getPropertyTypeForIndexType(originalObjectType, objectType, indexType, fullIndexType, accessNode, accessFlags) {
-      const accessExpression = accessNode && accessNode.kind === 211 /* ElementAccessExpression */ ? accessNode : void 0;
+      const accessExpression = accessNode && accessNode.kind === 212 /* ElementAccessExpression */ ? accessNode : void 0;
       const propName = accessNode && isPrivateIdentifier(accessNode) ? void 0 : getPropertyNameFromIndex(indexType, accessNode);
       if (propName !== void 0) {
         if (accessFlags & 256 /* Contextual */) {
@@ -158617,7 +142312,7 @@ ${lanes.join("\n")}
           if (accessExpression) {
             markPropertyAsReferenced(prop, accessExpression, isSelfTypeAccess(accessExpression.expression, objectType.symbol));
             if (isAssignmentToReadonlyEntity(accessExpression, prop, getAssignmentTargetKind(accessExpression))) {
-              error(accessExpression.argumentExpression, Diagnostics.Cannot_assign_to_0_because_it_is_a_read_only_property, symbolToString(prop));
+              error2(accessExpression.argumentExpression, Diagnostics.Cannot_assign_to_0_because_it_is_a_read_only_property, symbolToString(prop));
               return void 0;
             }
             if (accessFlags & 8 /* CacheSymbol */) {
@@ -158627,7 +142322,7 @@ ${lanes.join("\n")}
               return autoType;
             }
           }
-          const propType = getTypeOfSymbol(prop);
+          const propType = accessFlags & 4 /* Writing */ ? getWriteTypeOfSymbol(prop) : getTypeOfSymbol(prop);
           return accessExpression && getAssignmentTargetKind(accessExpression) !== 1 /* Definite */ ? getFlowTypeOfReference(accessExpression, propType) : accessNode && isIndexedAccessTypeNode(accessNode) && containsMissingType(propType) ? getUnionType([propType, undefinedType]) : propType;
         }
         if (everyType(objectType, isTupleType) && isNumericLiteralName(propName)) {
@@ -158636,26 +142331,17 @@ ${lanes.join("\n")}
             const indexNode = getIndexNodeForAccessExpression(accessNode);
             if (isTupleType(objectType)) {
               if (index < 0) {
-                error(indexNode, Diagnostics.A_tuple_type_cannot_be_indexed_with_a_negative_value);
+                error2(indexNode, Diagnostics.A_tuple_type_cannot_be_indexed_with_a_negative_value);
                 return undefinedType;
               }
-              error(
-                indexNode,
-                Diagnostics.Tuple_type_0_of_length_1_has_no_element_at_index_2,
-                typeToString(objectType),
-                getTypeReferenceArity(objectType),
-                unescapeLeadingUnderscores(propName)
-              );
+              error2(indexNode, Diagnostics.Tuple_type_0_of_length_1_has_no_element_at_index_2, typeToString(objectType), getTypeReferenceArity(objectType), unescapeLeadingUnderscores(propName));
             } else {
-              error(indexNode, Diagnostics.Property_0_does_not_exist_on_type_1, unescapeLeadingUnderscores(propName), typeToString(objectType));
+              error2(indexNode, Diagnostics.Property_0_does_not_exist_on_type_1, unescapeLeadingUnderscores(propName), typeToString(objectType));
             }
           }
           if (index >= 0) {
             errorIfWritingToReadonlyIndex(getIndexInfoOfType(objectType, numberType));
-            return mapType(objectType, (t) => {
-              const restType = getRestTypeOfTupleType(t) || undefinedType;
-              return accessFlags & 1 /* IncludeUndefined */ ? getUnionType([restType, missingType]) : restType;
-            });
+            return getTupleElementTypeOutOfStartCount(objectType, index, accessFlags & 1 /* IncludeUndefined */ ? missingType : void 0);
           }
         }
       }
@@ -158667,13 +142353,17 @@ ${lanes.join("\n")}
         if (indexInfo) {
           if (accessFlags & 2 /* NoIndexSignatures */ && indexInfo.keyType !== numberType) {
             if (accessExpression) {
-              error(accessExpression, Diagnostics.Type_0_cannot_be_used_to_index_type_1, typeToString(indexType), typeToString(originalObjectType));
+              if (accessFlags & 4 /* Writing */) {
+                error2(accessExpression, Diagnostics.Type_0_is_generic_and_can_only_be_indexed_for_reading, typeToString(originalObjectType));
+              } else {
+                error2(accessExpression, Diagnostics.Type_0_cannot_be_used_to_index_type_1, typeToString(indexType), typeToString(originalObjectType));
+              }
             }
             return void 0;
           }
           if (accessNode && indexInfo.keyType === stringType && !isTypeAssignableToKind(indexType, 4 /* String */ | 8 /* Number */)) {
             const indexNode = getIndexNodeForAccessExpression(accessNode);
-            error(indexNode, Diagnostics.Type_0_cannot_be_used_as_an_index_type, typeToString(indexType));
+            error2(indexNode, Diagnostics.Type_0_cannot_be_used_as_an_index_type, typeToString(indexType));
             return accessFlags & 1 /* IncludeUndefined */ ? getUnionType([indexInfo.type, missingType]) : indexInfo.type;
           }
           errorIfWritingToReadonlyIndex(indexInfo);
@@ -158701,23 +142391,23 @@ ${lanes.join("\n")}
             }
           }
           if (objectType.symbol === globalThisSymbol && propName !== void 0 && globalThisSymbol.exports.has(propName) && globalThisSymbol.exports.get(propName).flags & 418 /* BlockScoped */) {
-            error(accessExpression, Diagnostics.Property_0_does_not_exist_on_type_1, unescapeLeadingUnderscores(propName), typeToString(objectType));
+            error2(accessExpression, Diagnostics.Property_0_does_not_exist_on_type_1, unescapeLeadingUnderscores(propName), typeToString(objectType));
           } else if (noImplicitAny && !compilerOptions.suppressImplicitAnyIndexErrors && !(accessFlags & 128 /* SuppressNoImplicitAnyError */)) {
             if (propName !== void 0 && typeHasStaticProperty(propName, objectType)) {
               const typeName = typeToString(objectType);
-              error(accessExpression, Diagnostics.Property_0_does_not_exist_on_type_1_Did_you_mean_to_access_the_static_member_2_instead, propName, typeName, typeName + "[" + getTextOfNode(accessExpression.argumentExpression) + "]");
+              error2(accessExpression, Diagnostics.Property_0_does_not_exist_on_type_1_Did_you_mean_to_access_the_static_member_2_instead, propName, typeName, typeName + "[" + getTextOfNode(accessExpression.argumentExpression) + "]");
             } else if (getIndexTypeOfType(objectType, numberType)) {
-              error(accessExpression.argumentExpression, Diagnostics.Element_implicitly_has_an_any_type_because_index_expression_is_not_of_type_number);
+              error2(accessExpression.argumentExpression, Diagnostics.Element_implicitly_has_an_any_type_because_index_expression_is_not_of_type_number);
             } else {
               let suggestion;
               if (propName !== void 0 && (suggestion = getSuggestionForNonexistentProperty(propName, objectType))) {
                 if (suggestion !== void 0) {
-                  error(accessExpression.argumentExpression, Diagnostics.Property_0_does_not_exist_on_type_1_Did_you_mean_2, propName, typeToString(objectType), suggestion);
+                  error2(accessExpression.argumentExpression, Diagnostics.Property_0_does_not_exist_on_type_1_Did_you_mean_2, propName, typeToString(objectType), suggestion);
                 }
               } else {
                 const suggestion2 = getSuggestionForNonexistentIndexSignature(objectType, accessExpression, indexType);
                 if (suggestion2 !== void 0) {
-                  error(accessExpression, Diagnostics.Element_implicitly_has_an_any_type_because_type_0_has_no_index_signature_Did_you_mean_to_call_1, typeToString(objectType), suggestion2);
+                  error2(accessExpression, Diagnostics.Element_implicitly_has_an_any_type_because_type_0_has_no_index_signature_Did_you_mean_to_call_1, typeToString(objectType), suggestion2);
                 } else {
                   let errorInfo;
                   if (indexType.flags & 1024 /* EnumLiteral */) {
@@ -158782,11 +142472,11 @@ ${lanes.join("\n")}
       if (accessNode) {
         const indexNode = getIndexNodeForAccessExpression(accessNode);
         if (indexType.flags & (128 /* StringLiteral */ | 256 /* NumberLiteral */)) {
-          error(indexNode, Diagnostics.Property_0_does_not_exist_on_type_1, "" + indexType.value, typeToString(objectType));
+          error2(indexNode, Diagnostics.Property_0_does_not_exist_on_type_1, "" + indexType.value, typeToString(objectType));
         } else if (indexType.flags & (4 /* String */ | 8 /* Number */)) {
-          error(indexNode, Diagnostics.Type_0_has_no_matching_index_signature_for_type_1, typeToString(objectType), typeToString(indexType));
+          error2(indexNode, Diagnostics.Type_0_has_no_matching_index_signature_for_type_1, typeToString(objectType), typeToString(indexType));
         } else {
-          error(indexNode, Diagnostics.Type_0_cannot_be_used_as_an_index_type, typeToString(indexType));
+          error2(indexNode, Diagnostics.Type_0_cannot_be_used_as_an_index_type, typeToString(indexType));
         }
       }
       if (isTypeAny(indexType)) {
@@ -158795,16 +142485,24 @@ ${lanes.join("\n")}
       return void 0;
       function errorIfWritingToReadonlyIndex(indexInfo) {
         if (indexInfo && indexInfo.isReadonly && accessExpression && (isAssignmentTarget(accessExpression) || isDeleteTarget(accessExpression))) {
-          error(accessExpression, Diagnostics.Index_signature_in_type_0_only_permits_reading, typeToString(objectType));
+          error2(accessExpression, Diagnostics.Index_signature_in_type_0_only_permits_reading, typeToString(objectType));
         }
       }
     }
     function getIndexNodeForAccessExpression(accessNode) {
-      return accessNode.kind === 211 /* ElementAccessExpression */ ? accessNode.argumentExpression : accessNode.kind === 198 /* IndexedAccessType */ ? accessNode.indexType : accessNode.kind === 166 /* ComputedPropertyName */ ? accessNode.expression : accessNode;
+      return accessNode.kind === 212 /* ElementAccessExpression */ ? accessNode.argumentExpression : accessNode.kind === 199 /* IndexedAccessType */ ? accessNode.indexType : accessNode.kind === 167 /* ComputedPropertyName */ ? accessNode.expression : accessNode;
     }
     function isPatternLiteralPlaceholderType(type) {
       if (type.flags & 2097152 /* Intersection */) {
-        return some(type.types, (t) => !!(t.flags & (2944 /* Literal */ | 65536 /* Null */ | 32768 /* Undefined */)) || isPatternLiteralPlaceholderType(t));
+        let seenPlaceholder = false;
+        for (const t of type.types) {
+          if (t.flags & (2944 /* Literal */ | 98304 /* Nullable */) || isPatternLiteralPlaceholderType(t)) {
+            seenPlaceholder = true;
+          } else if (!(t.flags & 524288 /* Object */)) {
+            return false;
+          }
+        }
+        return seenPlaceholder;
       }
       return !!(type.flags & (1 /* Any */ | 4 /* String */ | 8 /* Number */ | 64 /* BigInt */)) || isPatternLiteralType(type);
     }
@@ -158821,7 +142519,7 @@ ${lanes.join("\n")}
       return !!(getGenericObjectFlags(type) & 8388608 /* IsGenericIndexType */);
     }
     function getGenericObjectFlags(type) {
-      if (type.flags & (3145728 /* UnionOrIntersection */ | 134217728 /* TemplateLiteral */)) {
+      if (type.flags & 3145728 /* UnionOrIntersection */) {
         if (!(type.objectFlags & 2097152 /* IsGenericTypeComputed */)) {
           type.objectFlags |= 2097152 /* IsGenericTypeComputed */ | reduceLeft(type.types, (flags, t) => flags | getGenericObjectFlags(t), 0);
         }
@@ -158833,7 +142531,7 @@ ${lanes.join("\n")}
         }
         return type.objectFlags & 12582912 /* IsGenericType */;
       }
-      return (type.flags & 58982400 /* InstantiableNonPrimitive */ || isGenericMappedType(type) || isGenericTupleType(type) ? 4194304 /* IsGenericObjectType */ : 0) | (type.flags & (58982400 /* InstantiableNonPrimitive */ | 4194304 /* Index */ | 268435456 /* StringMapping */) && !isPatternLiteralType(type) ? 8388608 /* IsGenericIndexType */ : 0);
+      return (type.flags & 58982400 /* InstantiableNonPrimitive */ || isGenericMappedType(type) || isGenericTupleType(type) ? 4194304 /* IsGenericObjectType */ : 0) | (type.flags & (58982400 /* InstantiableNonPrimitive */ | 4194304 /* Index */ | 134217728 /* TemplateLiteral */ | 268435456 /* StringMapping */) && !isPatternLiteralType(type) ? 8388608 /* IsGenericIndexType */ : 0);
     }
     function getSimplifiedType(type, writing) {
       return type.flags & 8388608 /* IndexedAccess */ ? getSimplifiedIndexedAccessType(type, writing) : type.flags & 16777216 /* Conditional */ ? getSimplifiedConditionalType(type, writing) : type;
@@ -158940,7 +142638,7 @@ ${lanes.join("\n")}
       }
       if (compilerOptions.noUncheckedIndexedAccess && accessFlags & 32 /* ExpressionPosition */)
         accessFlags |= 1 /* IncludeUndefined */;
-      if (isGenericIndexType(indexType) || (accessNode && accessNode.kind !== 198 /* IndexedAccessType */ ? isGenericTupleType(objectType) && !indexTypeLessThan(indexType, objectType.target.fixedLength) : isGenericObjectType(objectType) && !(isTupleType(objectType) && indexTypeLessThan(indexType, objectType.target.fixedLength)) || isGenericReducibleType(objectType))) {
+      if (isGenericIndexType(indexType) || (accessNode && accessNode.kind !== 199 /* IndexedAccessType */ ? isGenericTupleType(objectType) && !indexTypeLessThan(indexType, getTotalFixedElementCount(objectType.target)) : isGenericObjectType(objectType) && !(isTupleType(objectType) && indexTypeLessThan(indexType, getTotalFixedElementCount(objectType.target))) || isGenericReducibleType(objectType))) {
         if (objectType.flags & 3 /* AnyOrUnknown */) {
           return objectType;
         }
@@ -159020,7 +142718,7 @@ ${lanes.join("\n")}
       let tailCount = 0;
       while (true) {
         if (tailCount === 1e3) {
-          error(currentNode, Diagnostics.Type_instantiation_is_excessively_deep_and_possibly_infinite);
+          error2(currentNode, Diagnostics.Type_instantiation_is_excessively_deep_and_possibly_infinite);
           return errorType;
         }
         const checkType = instantiateType(getActualTypeVariable(root.checkType), mapper);
@@ -159045,9 +142743,9 @@ ${lanes.join("\n")}
           );
           if (freshMapper) {
             const freshCombinedMapper = combineTypeMappers(mapper, freshMapper);
-            for (const p of freshParams) {
-              if (root.inferTypeParameters.indexOf(p) === -1) {
-                p.mapper = freshCombinedMapper;
+            for (let i = 0; i < freshParams.length; i++) {
+              if (freshParams[i] !== root.inferTypeParameters[i]) {
+                freshParams[i].mapper = freshCombinedMapper;
               }
             }
           }
@@ -159198,11 +142896,11 @@ ${lanes.join("\n")}
       const links = getNodeLinks(node);
       if (!links.resolvedType) {
         if (!isLiteralImportTypeNode(node)) {
-          error(node.argument, Diagnostics.String_literal_expected);
+          error2(node.argument, Diagnostics.String_literal_expected);
           links.resolvedSymbol = unknownSymbol;
           return links.resolvedType = errorType;
         }
-        const targetMeaning = node.isTypeOf ? 111551 /* Value */ : node.flags & 8388608 /* JSDoc */ ? 111551 /* Value */ | 788968 /* Type */ : 788968 /* Type */;
+        const targetMeaning = node.isTypeOf ? 111551 /* Value */ : node.flags & 16777216 /* JSDoc */ ? 111551 /* Value */ | 788968 /* Type */ : 788968 /* Type */;
         const innerModuleSymbol = resolveExternalModuleName(node, node.argument.literal);
         if (!innerModuleSymbol) {
           links.resolvedSymbol = unknownSymbol;
@@ -159232,7 +142930,7 @@ ${lanes.join("\n")}
             const symbolFromModule = node.isTypeOf ? void 0 : getSymbol2(getExportsOfSymbol(mergedResolvedSymbol), current.escapedText, meaning);
             const next = symbolFromModule ?? symbolFromVariable;
             if (!next) {
-              error(current, Diagnostics.Namespace_0_has_no_exported_member_1, getFullyQualifiedName(currentNamespace), declarationNameToString(current));
+              error2(current, Diagnostics.Namespace_0_has_no_exported_member_1, getFullyQualifiedName(currentNamespace), declarationNameToString(current));
               return links.resolvedType = errorType;
             }
             getNodeLinks(current).resolvedSymbol = next;
@@ -159245,7 +142943,7 @@ ${lanes.join("\n")}
             links.resolvedType = resolveImportSymbolType(node, links, moduleSymbol, targetMeaning);
           } else {
             const errorMessage = targetMeaning === 111551 /* Value */ ? Diagnostics.Module_0_does_not_refer_to_a_value_but_is_used_as_a_value_here : Diagnostics.Module_0_does_not_refer_to_a_type_but_is_used_as_a_type_here_Did_you_mean_typeof_import_0;
-            error(node, errorMessage, node.argument.literal.text);
+            error2(node, errorMessage, node.argument.literal.text);
             links.resolvedSymbol = unknownSymbol;
             links.resolvedType = errorType;
           }
@@ -159315,7 +143013,7 @@ ${lanes.join("\n")}
       function getAnonymousPartialType(type2) {
         const members = createSymbolTable();
         for (const prop of getPropertiesOfType(type2)) {
-          if (getDeclarationModifierFlagsFromSymbol(prop) & (8 /* Private */ | 16 /* Protected */)) {
+          if (getDeclarationModifierFlagsFromSymbol(prop) & (2 /* Private */ | 4 /* Protected */)) {
           } else if (isSpreadableProperty(prop)) {
             const isSetonlyAccessor = prop.flags & 65536 /* SetAccessor */ && !(prop.flags & 32768 /* GetAccessor */);
             const flags = 4 /* Property */ | 16777216 /* Optional */;
@@ -159377,7 +143075,7 @@ ${lanes.join("\n")}
       const skippedPrivateMembers = /* @__PURE__ */ new Set();
       const indexInfos = left === emptyObjectType ? getIndexInfosOfType(right) : getUnionIndexInfos([left, right]);
       for (const rightProp of getPropertiesOfType(right)) {
-        if (getDeclarationModifierFlagsFromSymbol(rightProp) & (8 /* Private */ | 16 /* Protected */)) {
+        if (getDeclarationModifierFlagsFromSymbol(rightProp) & (2 /* Private */ | 4 /* Protected */)) {
           skippedPrivateMembers.add(rightProp.escapedName);
         } else if (isSpreadableProperty(rightProp)) {
           members.set(rightProp.escapedName, getSpreadSymbol(rightProp, readonly));
@@ -159508,7 +143206,7 @@ ${lanes.join("\n")}
         false
       );
       const parent2 = container && container.parent;
-      if (parent2 && (isClassLike(parent2) || parent2.kind === 263 /* InterfaceDeclaration */)) {
+      if (parent2 && (isClassLike(parent2) || parent2.kind === 264 /* InterfaceDeclaration */)) {
         if (!isStatic(container) && (!isConstructorDeclaration(container) || isNodeDescendantOf(node, container.body))) {
           return getDeclaredTypeOfClassOrInterface(getSymbolOfDeclaration(parent2)).thisType;
         }
@@ -159516,14 +143214,14 @@ ${lanes.join("\n")}
       if (parent2 && isObjectLiteralExpression(parent2) && isBinaryExpression(parent2.parent) && getAssignmentDeclarationKind(parent2.parent) === 6 /* Prototype */) {
         return getDeclaredTypeOfClassOrInterface(getSymbolOfNode(parent2.parent.left).parent).thisType;
       }
-      const host2 = node.flags & 8388608 /* JSDoc */ ? getHostSignatureFromJSDoc(node) : void 0;
+      const host2 = node.flags & 16777216 /* JSDoc */ ? getHostSignatureFromJSDoc(node) : void 0;
       if (host2 && isFunctionExpression(host2) && isBinaryExpression(host2.parent) && getAssignmentDeclarationKind(host2.parent) === 3 /* PrototypeProperty */) {
         return getDeclaredTypeOfClassOrInterface(getSymbolOfNode(host2.parent.left).parent).thisType;
       }
       if (isJSConstructor(container) && isNodeDescendantOf(node, container.body)) {
         return getDeclaredTypeOfClassOrInterface(getSymbolOfDeclaration(container)).thisType;
       }
-      error(node, Diagnostics.A_this_type_is_available_only_in_a_non_static_member_of_a_class_or_interface);
+      error2(node, Diagnostics.A_this_type_is_available_only_in_a_non_static_member_of_a_class_or_interface);
       return errorType;
     }
     function getTypeFromThisTypeNode(node) {
@@ -159538,17 +143236,17 @@ ${lanes.join("\n")}
     }
     function getArrayElementTypeNode(node) {
       switch (node.kind) {
-        case 195 /* ParenthesizedType */:
+        case 196 /* ParenthesizedType */:
           return getArrayElementTypeNode(node.type);
-        case 188 /* TupleType */:
+        case 189 /* TupleType */:
           if (node.elements.length === 1) {
             node = node.elements[0];
-            if (node.kind === 190 /* RestType */ || node.kind === 201 /* NamedTupleMember */ && node.dotDotDotToken) {
+            if (node.kind === 191 /* RestType */ || node.kind === 202 /* NamedTupleMember */ && node.dotDotDotToken) {
               return getArrayElementTypeNode(node.type);
             }
           }
           break;
-        case 187 /* ArrayType */:
+        case 188 /* ArrayType */:
           return node.elementType;
       }
       return void 0;
@@ -159568,8 +143266,8 @@ ${lanes.join("\n")}
     function getTypeFromTypeNodeWorker(node) {
       switch (node.kind) {
         case 133 /* AnyKeyword */:
-        case 318 /* JSDocAllType */:
-        case 319 /* JSDocUnknownType */:
+        case 319 /* JSDocAllType */:
+        case 320 /* JSDocUnknownType */:
           return anyType;
         case 159 /* UnknownKeyword */:
           return unknownType;
@@ -159577,7 +143275,7 @@ ${lanes.join("\n")}
           return stringType;
         case 150 /* NumberKeyword */:
           return numberType;
-        case 162 /* BigIntKeyword */:
+        case 163 /* BigIntKeyword */:
           return bigintType;
         case 136 /* BooleanKeyword */:
           return booleanType;
@@ -159592,69 +143290,69 @@ ${lanes.join("\n")}
         case 146 /* NeverKeyword */:
           return neverType;
         case 151 /* ObjectKeyword */:
-          return node.flags & 262144 /* JavaScriptFile */ && !noImplicitAny ? anyType : nonPrimitiveType;
+          return node.flags & 524288 /* JavaScriptFile */ && !noImplicitAny ? anyType : nonPrimitiveType;
         case 141 /* IntrinsicKeyword */:
           return intrinsicMarkerType;
-        case 196 /* ThisType */:
+        case 197 /* ThisType */:
         case 110 /* ThisKeyword */:
           return getTypeFromThisTypeNode(node);
-        case 200 /* LiteralType */:
+        case 201 /* LiteralType */:
           return getTypeFromLiteralTypeNode(node);
-        case 182 /* TypeReference */:
+        case 183 /* TypeReference */:
           return getTypeFromTypeReference(node);
-        case 181 /* TypePredicate */:
+        case 182 /* TypePredicate */:
           return node.assertsModifier ? voidType : booleanType;
-        case 232 /* ExpressionWithTypeArguments */:
+        case 233 /* ExpressionWithTypeArguments */:
           return getTypeFromTypeReference(node);
-        case 185 /* TypeQuery */:
+        case 186 /* TypeQuery */:
           return getTypeFromTypeQueryNode(node);
-        case 187 /* ArrayType */:
-        case 188 /* TupleType */:
+        case 188 /* ArrayType */:
+        case 189 /* TupleType */:
           return getTypeFromArrayOrTupleTypeNode(node);
-        case 189 /* OptionalType */:
+        case 190 /* OptionalType */:
           return getTypeFromOptionalTypeNode(node);
-        case 191 /* UnionType */:
+        case 192 /* UnionType */:
           return getTypeFromUnionTypeNode(node);
-        case 192 /* IntersectionType */:
+        case 193 /* IntersectionType */:
           return getTypeFromIntersectionTypeNode(node);
-        case 320 /* JSDocNullableType */:
+        case 321 /* JSDocNullableType */:
           return getTypeFromJSDocNullableTypeNode(node);
-        case 322 /* JSDocOptionalType */:
+        case 323 /* JSDocOptionalType */:
           return addOptionality(getTypeFromTypeNode(node.type));
-        case 201 /* NamedTupleMember */:
+        case 202 /* NamedTupleMember */:
           return getTypeFromNamedTupleTypeNode(node);
-        case 195 /* ParenthesizedType */:
-        case 321 /* JSDocNonNullableType */:
-        case 315 /* JSDocTypeExpression */:
+        case 196 /* ParenthesizedType */:
+        case 322 /* JSDocNonNullableType */:
+        case 316 /* JSDocTypeExpression */:
           return getTypeFromTypeNode(node.type);
-        case 190 /* RestType */:
+        case 191 /* RestType */:
           return getTypeFromRestTypeNode(node);
-        case 324 /* JSDocVariadicType */:
+        case 325 /* JSDocVariadicType */:
           return getTypeFromJSDocVariadicType(node);
-        case 183 /* FunctionType */:
-        case 184 /* ConstructorType */:
-        case 186 /* TypeLiteral */:
-        case 328 /* JSDocTypeLiteral */:
-        case 323 /* JSDocFunctionType */:
-        case 329 /* JSDocSignature */:
+        case 184 /* FunctionType */:
+        case 185 /* ConstructorType */:
+        case 187 /* TypeLiteral */:
+        case 329 /* JSDocTypeLiteral */:
+        case 324 /* JSDocFunctionType */:
+        case 330 /* JSDocSignature */:
           return getTypeFromTypeLiteralOrFunctionOrConstructorTypeNode(node);
-        case 197 /* TypeOperator */:
+        case 198 /* TypeOperator */:
           return getTypeFromTypeOperatorNode(node);
-        case 198 /* IndexedAccessType */:
+        case 199 /* IndexedAccessType */:
           return getTypeFromIndexedAccessTypeNode(node);
-        case 199 /* MappedType */:
+        case 200 /* MappedType */:
           return getTypeFromMappedTypeNode(node);
-        case 193 /* ConditionalType */:
+        case 194 /* ConditionalType */:
           return getTypeFromConditionalTypeNode(node);
-        case 194 /* InferType */:
+        case 195 /* InferType */:
           return getTypeFromInferTypeNode(node);
-        case 202 /* TemplateLiteralType */:
+        case 203 /* TemplateLiteralType */:
           return getTypeFromTemplateTypeNode(node);
-        case 204 /* ImportType */:
+        case 205 /* ImportType */:
           return getTypeFromImportTypeNode(node);
         case 80 /* Identifier */:
-        case 165 /* QualifiedName */:
-        case 210 /* PropertyAccessExpression */:
+        case 166 /* QualifiedName */:
+        case 211 /* PropertyAccessExpression */:
           const symbol = getSymbolAtLocation(node);
           return symbol ? getDeclaredTypeOfSymbol(symbol) : errorType;
         default:
@@ -159790,7 +143488,7 @@ ${lanes.join("\n")}
         /*resolvedTypePredicate*/
         void 0,
         signature.minArgumentCount,
-        signature.flags & 39 /* PropagatingFlags */
+        signature.flags & 167 /* PropagatingFlags */
       );
       result.target = signature;
       result.mapper = mapper;
@@ -159799,7 +143497,12 @@ ${lanes.join("\n")}
     function instantiateSymbol(symbol, mapper) {
       const links = getSymbolLinks(symbol);
       if (links.type && !couldContainTypeVariables(links.type)) {
-        return symbol;
+        if (!(symbol.flags & 65536 /* SetAccessor */)) {
+          return symbol;
+        }
+        if (links.writeType && !couldContainTypeVariables(links.writeType)) {
+          return symbol;
+        }
       }
       if (getCheckFlags(symbol) & 1 /* Instantiated */) {
         symbol = links.target;
@@ -159852,26 +143555,31 @@ ${lanes.join("\n")}
         if (!result) {
           const newMapper = createTypeMapper(typeParameters, typeArguments);
           result = target.objectFlags & 4 /* Reference */ ? createDeferredTypeReference(type.target, type.node, newMapper, newAliasSymbol, newAliasTypeArguments) : target.objectFlags & 32 /* Mapped */ ? instantiateMappedType(target, newMapper, newAliasSymbol, newAliasTypeArguments) : instantiateAnonymousType(target, newMapper, newAliasSymbol, newAliasTypeArguments);
-          if (result.flags & 138117121 /* ObjectFlagsType */ && !(result.objectFlags & 524288 /* CouldContainTypeVariablesComputed */)) {
+          target.instantiations.set(id, result);
+          const resultObjectFlags = getObjectFlags(result);
+          if (result.flags & 3899393 /* ObjectFlagsType */ && !(resultObjectFlags & 524288 /* CouldContainTypeVariablesComputed */)) {
             const resultCouldContainTypeVariables = some(typeArguments, couldContainTypeVariables);
-            if (!(result.objectFlags & 524288 /* CouldContainTypeVariablesComputed */)) {
-              result.objectFlags |= 524288 /* CouldContainTypeVariablesComputed */ | (resultCouldContainTypeVariables ? 1048576 /* CouldContainTypeVariables */ : 0);
+            if (!(getObjectFlags(result) & 524288 /* CouldContainTypeVariablesComputed */)) {
+              if (resultObjectFlags & (32 /* Mapped */ | 16 /* Anonymous */ | 4 /* Reference */)) {
+                result.objectFlags |= 524288 /* CouldContainTypeVariablesComputed */ | (resultCouldContainTypeVariables ? 1048576 /* CouldContainTypeVariables */ : 0);
+              } else {
+                result.objectFlags |= !resultCouldContainTypeVariables ? 524288 /* CouldContainTypeVariablesComputed */ : 0;
+              }
             }
           }
-          target.instantiations.set(id, result);
         }
         return result;
       }
       return type;
     }
     function maybeTypeParameterReference(node) {
-      return !(node.parent.kind === 182 /* TypeReference */ && node.parent.typeArguments && node === node.parent.typeName || node.parent.kind === 204 /* ImportType */ && node.parent.typeArguments && node === node.parent.qualifier);
+      return !(node.parent.kind === 183 /* TypeReference */ && node.parent.typeArguments && node === node.parent.typeName || node.parent.kind === 205 /* ImportType */ && node.parent.typeArguments && node === node.parent.qualifier);
     }
     function isTypeParameterPossiblyReferenced(tp, node) {
       if (tp.symbol && tp.symbol.declarations && tp.symbol.declarations.length === 1) {
         const container = tp.symbol.declarations[0].parent;
         for (let n = node; n !== container; n = n.parent) {
-          if (!n || n.kind === 240 /* Block */ || n.kind === 193 /* ConditionalType */ && forEachChild(n.extendsType, containsReference)) {
+          if (!n || n.kind === 241 /* Block */ || n.kind === 194 /* ConditionalType */ && forEachChild(n.extendsType, containsReference)) {
             return true;
           }
         }
@@ -159880,17 +143588,17 @@ ${lanes.join("\n")}
       return true;
       function containsReference(node2) {
         switch (node2.kind) {
-          case 196 /* ThisType */:
+          case 197 /* ThisType */:
             return !!tp.isThisType;
           case 80 /* Identifier */:
             return !tp.isThisType && isPartOfTypeNode(node2) && maybeTypeParameterReference(node2) && getTypeFromTypeNodeWorker(node2) === tp;
-          case 185 /* TypeQuery */:
+          case 186 /* TypeQuery */:
             const entityName = node2.exprName;
             const firstIdentifier = getFirstIdentifier(entityName);
             if (!isThisIdentifier(firstIdentifier)) {
               const firstIdentifierSymbol = getResolvedSymbol(firstIdentifier);
               const tpDeclaration = tp.symbol.declarations[0];
-              const tpScope = tpDeclaration.kind === 167 /* TypeParameter */ ? tpDeclaration.parent : (
+              const tpScope = tpDeclaration.kind === 168 /* TypeParameter */ ? tpDeclaration.parent : (
                 // Type parameter is a regular type parameter, e.g. foo
                 tp.isThisType ? tpDeclaration : (
                   // Type parameter is the this type, and its declaration is the class declaration.
@@ -159902,8 +143610,8 @@ ${lanes.join("\n")}
               }
             }
             return true;
-          case 173 /* MethodDeclaration */:
-          case 172 /* MethodSignature */:
+          case 174 /* MethodDeclaration */:
+          case 173 /* MethodSignature */:
             return !node2.type && !!node2.body || some(node2.typeParameters, containsReference) || some(node2.parameters, containsReference) || !!node2.type && containsReference(node2.type);
         }
         return !!forEachChild(node2, containsReference);
@@ -159924,24 +143632,29 @@ ${lanes.join("\n")}
       if (typeVariable) {
         const mappedTypeVariable = instantiateType(typeVariable, mapper);
         if (typeVariable !== mappedTypeVariable) {
-          return mapTypeWithAlias(getReducedType(mappedTypeVariable), (t) => {
-            if (t.flags & (3 /* AnyOrUnknown */ | 58982400 /* InstantiableNonPrimitive */ | 524288 /* Object */ | 2097152 /* Intersection */) && t !== wildcardType && !isErrorType(t)) {
-              if (!type.declaration.nameType) {
-                let constraint;
-                if (isArrayType(t) || t.flags & 1 /* Any */ && findResolutionCycleStartIndex(typeVariable, 4 /* ImmediateBaseConstraint */) < 0 && (constraint = getConstraintOfTypeParameter(typeVariable)) && everyType(constraint, isArrayOrTupleType)) {
-                  return instantiateMappedArrayType(t, type, prependTypeMapping(typeVariable, t, mapper));
-                }
-                if (isGenericTupleType(t)) {
-                  return instantiateMappedGenericTupleType(t, type, typeVariable, mapper);
-                }
-                if (isTupleType(t)) {
-                  return instantiateMappedTupleType(t, type, prependTypeMapping(typeVariable, t, mapper));
+          return mapTypeWithAlias(
+            getReducedType(mappedTypeVariable),
+            (t) => {
+              if (t.flags & (3 /* AnyOrUnknown */ | 58982400 /* InstantiableNonPrimitive */ | 524288 /* Object */ | 2097152 /* Intersection */) && t !== wildcardType && !isErrorType(t)) {
+                if (!type.declaration.nameType) {
+                  let constraint;
+                  if (isArrayType(t) || t.flags & 1 /* Any */ && findResolutionCycleStartIndex(typeVariable, 4 /* ImmediateBaseConstraint */) < 0 && (constraint = getConstraintOfTypeParameter(typeVariable)) && everyType(constraint, isArrayOrTupleType)) {
+                    return instantiateMappedArrayType(t, type, prependTypeMapping(typeVariable, t, mapper));
+                  }
+                  if (isGenericTupleType(t)) {
+                    return instantiateMappedGenericTupleType(t, type, typeVariable, mapper);
+                  }
+                  if (isTupleType(t)) {
+                    return instantiateMappedTupleType(t, type, prependTypeMapping(typeVariable, t, mapper));
+                  }
                 }
+                return instantiateAnonymousType(type, prependTypeMapping(typeVariable, t, mapper));
               }
-              return instantiateAnonymousType(type, prependTypeMapping(typeVariable, t, mapper));
-            }
-            return t;
-          }, aliasSymbol, aliasTypeArguments);
+              return t;
+            },
+            aliasSymbol,
+            aliasTypeArguments
+          );
         }
       }
       return instantiateType(getConstraintTypeFromMappedType(type), mapper) === wildcardType ? wildcardType : instantiateAnonymousType(type, mapper, aliasSymbol, aliasTypeArguments);
@@ -159953,6 +143666,9 @@ ${lanes.join("\n")}
       const elementFlags = tupleType.target.elementFlags;
       const elementTypes = map(getElementTypes(tupleType), (t, i) => {
         const singleton = elementFlags[i] & 8 /* Variadic */ ? t : elementFlags[i] & 4 /* Rest */ ? createArrayType(t) : createTupleType([t], [elementFlags[i]]);
+        if (singleton === typeVariable) {
+          return mappedType;
+        }
         return instantiateMappedType(mappedType, prependTypeMapping(typeVariable, singleton, mapper));
       });
       const newReadonly = getModifiedReadonlyState(tupleType.target.readonly, getMappedTypeModifiers(mappedType));
@@ -160040,7 +143756,7 @@ ${lanes.join("\n")}
       }
       if (instantiationDepth === 100 || instantiationCount >= 5e6) {
         (_a = tracing) == null ? void 0 : _a.instant(tracing.Phase.CheckTypes, "instantiateType_DepthLimit", { typeId: type.id, instantiationDepth, instantiationCount });
-        error(currentNode, Diagnostics.Type_instantiation_is_excessively_deep_and_possibly_infinite);
+        error2(currentNode, Diagnostics.Type_instantiation_is_excessively_deep_and_possibly_infinite);
         return errorType;
       }
       totalInstantiationCount++;
@@ -160156,32 +143872,32 @@ ${lanes.join("\n")}
       return createIndexInfo(info.keyType, instantiateType(info.type, mapper), info.isReadonly, info.declaration);
     }
     function isContextSensitive(node) {
-      Debug.assert(node.kind !== 173 /* MethodDeclaration */ || isObjectLiteralMethod(node));
+      Debug.assert(node.kind !== 174 /* MethodDeclaration */ || isObjectLiteralMethod(node));
       switch (node.kind) {
-        case 217 /* FunctionExpression */:
-        case 218 /* ArrowFunction */:
-        case 173 /* MethodDeclaration */:
-        case 261 /* FunctionDeclaration */:
+        case 218 /* FunctionExpression */:
+        case 219 /* ArrowFunction */:
+        case 174 /* MethodDeclaration */:
+        case 262 /* FunctionDeclaration */:
           return isContextSensitiveFunctionLikeDeclaration(node);
-        case 209 /* ObjectLiteralExpression */:
+        case 210 /* ObjectLiteralExpression */:
           return some(node.properties, isContextSensitive);
-        case 208 /* ArrayLiteralExpression */:
+        case 209 /* ArrayLiteralExpression */:
           return some(node.elements, isContextSensitive);
-        case 226 /* ConditionalExpression */:
+        case 227 /* ConditionalExpression */:
           return isContextSensitive(node.whenTrue) || isContextSensitive(node.whenFalse);
-        case 225 /* BinaryExpression */:
+        case 226 /* BinaryExpression */:
           return (node.operatorToken.kind === 57 /* BarBarToken */ || node.operatorToken.kind === 61 /* QuestionQuestionToken */) && (isContextSensitive(node.left) || isContextSensitive(node.right));
-        case 302 /* PropertyAssignment */:
+        case 303 /* PropertyAssignment */:
           return isContextSensitive(node.initializer);
-        case 216 /* ParenthesizedExpression */:
+        case 217 /* ParenthesizedExpression */:
           return isContextSensitive(node.expression);
-        case 291 /* JsxAttributes */:
+        case 292 /* JsxAttributes */:
           return some(node.properties, isContextSensitive) || isJsxOpeningElement(node.parent) && some(node.parent.parent.children, isContextSensitive);
-        case 290 /* JsxAttribute */: {
+        case 291 /* JsxAttribute */: {
           const { initializer } = node;
           return !!initializer && isContextSensitive(initializer);
         }
-        case 293 /* JsxExpression */: {
+        case 294 /* JsxExpression */: {
           const { expression } = node;
           return !!expression && isContextSensitive(expression);
         }
@@ -160195,7 +143911,7 @@ ${lanes.join("\n")}
       if (node.typeParameters || getEffectiveReturnTypeNode(node) || !node.body) {
         return false;
       }
-      if (node.body.kind !== 240 /* Block */) {
+      if (node.body.kind !== 241 /* Block */) {
         return isContextSensitive(node.body);
       }
       return !!forEachReturnStatement(node.body, (statement) => !!statement.expression && isContextSensitive(statement.expression));
@@ -160290,23 +144006,27 @@ ${lanes.join("\n")}
         return true;
       }
       switch (node.kind) {
-        case 293 /* JsxExpression */:
-        case 216 /* ParenthesizedExpression */:
+        case 234 /* AsExpression */:
+          if (!isConstAssertion(node)) {
+            break;
+          }
+        case 294 /* JsxExpression */:
+        case 217 /* ParenthesizedExpression */:
           return elaborateError(node.expression, source, target, relation, headMessage, containingMessageChain, errorOutputContainer);
-        case 225 /* BinaryExpression */:
+        case 226 /* BinaryExpression */:
           switch (node.operatorToken.kind) {
             case 64 /* EqualsToken */:
             case 28 /* CommaToken */:
               return elaborateError(node.right, source, target, relation, headMessage, containingMessageChain, errorOutputContainer);
           }
           break;
-        case 209 /* ObjectLiteralExpression */:
+        case 210 /* ObjectLiteralExpression */:
           return elaborateObjectLiteral(node, source, target, relation, containingMessageChain, errorOutputContainer);
-        case 208 /* ArrayLiteralExpression */:
+        case 209 /* ArrayLiteralExpression */:
           return elaborateArrayLiteral(node, source, target, relation, containingMessageChain, errorOutputContainer);
-        case 291 /* JsxAttributes */:
+        case 292 /* JsxAttributes */:
           return elaborateJsxComponents(node, source, target, relation, containingMessageChain, errorOutputContainer);
-        case 218 /* ArrowFunction */:
+        case 219 /* ArrowFunction */:
           return elaborateArrowFunction(node, source, target, relation, containingMessageChain, errorOutputContainer);
       }
       return false;
@@ -160328,10 +144048,13 @@ ${lanes.join("\n")}
           const resultObj = errorOutputContainer || {};
           checkTypeAssignableTo(source, target, node, headMessage, containingMessageChain, resultObj);
           const diagnostic = resultObj.errors[resultObj.errors.length - 1];
-          addRelatedInfo(diagnostic, createDiagnosticForNode(
-            node,
-            signatures === constructSignatures ? Diagnostics.Did_you_mean_to_use_new_with_this_expression : Diagnostics.Did_you_mean_to_call_this_expression
-          ));
+          addRelatedInfo(
+            diagnostic,
+            createDiagnosticForNode(
+              node,
+              signatures === constructSignatures ? Diagnostics.Did_you_mean_to_use_new_with_this_expression : Diagnostics.Did_you_mean_to_call_this_expression
+            )
+          );
           return true;
         }
       }
@@ -160388,10 +144111,13 @@ ${lanes.join("\n")}
         );
         if (resultObj.errors) {
           if (target.symbol && length(target.symbol.declarations)) {
-            addRelatedInfo(resultObj.errors[resultObj.errors.length - 1], createDiagnosticForNode(
-              target.symbol.declarations[0],
-              Diagnostics.The_expected_type_comes_from_the_return_type_of_this_signature
-            ));
+            addRelatedInfo(
+              resultObj.errors[resultObj.errors.length - 1],
+              createDiagnosticForNode(
+                target.symbol.declarations[0],
+                Diagnostics.The_expected_type_comes_from_the_return_type_of_this_signature
+              )
+            );
           }
           if ((getFunctionFlags(node) & 2 /* Async */) === 0 && !getTypeOfPropertyOfType(sourceReturn, "then") && checkTypeRelatedTo(
             createPromiseType(sourceReturn),
@@ -160400,10 +144126,13 @@ ${lanes.join("\n")}
             /*errorNode*/
             void 0
           )) {
-            addRelatedInfo(resultObj.errors[resultObj.errors.length - 1], createDiagnosticForNode(
-              node,
-              Diagnostics.Did_you_mean_to_mark_this_function_as_async
-            ));
+            addRelatedInfo(
+              resultObj.errors[resultObj.errors.length - 1],
+              createDiagnosticForNode(
+                node,
+                Diagnostics.Did_you_mean_to_mark_this_function_as_async
+              )
+            );
           }
           return true;
         }
@@ -160498,12 +144227,15 @@ ${lanes.join("\n")}
               if (!issuedElaboration && (targetProp && length(targetProp.declarations) || target.symbol && length(target.symbol.declarations))) {
                 const targetNode = targetProp && length(targetProp.declarations) ? targetProp.declarations[0] : target.symbol.declarations[0];
                 if (!getSourceFileOfNode(targetNode).hasNoDefaultLib) {
-                  addRelatedInfo(reportedDiag, createDiagnosticForNode(
-                    targetNode,
-                    Diagnostics.The_expected_type_comes_from_property_0_which_is_declared_here_on_type_1,
-                    propertyName && !(nameType.flags & 8192 /* UniqueESSymbol */) ? unescapeLeadingUnderscores(propertyName) : typeToString(nameType),
-                    typeToString(target)
-                  ));
+                  addRelatedInfo(
+                    reportedDiag,
+                    createDiagnosticForNode(
+                      targetNode,
+                      Diagnostics.The_expected_type_comes_from_property_0_which_is_declared_here_on_type_1,
+                      propertyName && !(nameType.flags & 8192 /* UniqueESSymbol */) ? unescapeLeadingUnderscores(propertyName) : typeToString(nameType),
+                      typeToString(target)
+                    )
+                  );
                 }
               }
             }
@@ -160606,16 +144338,16 @@ ${lanes.join("\n")}
     }
     function getElaborationElementForJsxChild(child, nameType, getInvalidTextDiagnostic) {
       switch (child.kind) {
-        case 293 /* JsxExpression */:
+        case 294 /* JsxExpression */:
           return { errorNode: child, innerExpression: child.expression, nameType };
         case 12 /* JsxText */:
           if (child.containsOnlyTriviaWhiteSpaces) {
             break;
           }
           return { errorNode: child, innerExpression: void 0, nameType, errorMessage: getInvalidTextDiagnostic() };
-        case 283 /* JsxElement */:
-        case 284 /* JsxSelfClosingElement */:
-        case 287 /* JsxFragment */:
+        case 284 /* JsxElement */:
+        case 285 /* JsxSelfClosingElement */:
+        case 288 /* JsxFragment */:
           return { errorNode: child, innerExpression: child, nameType };
         default:
           return Debug.assertNever(child, "Found invalid jsx child");
@@ -160656,7 +144388,7 @@ ${lanes.join("\n")}
             result = elaborateIterableOrArrayLikeTargetElementwise(children, realSource, arrayLikeTargetParts, relation, containingMessageChain, errorOutputContainer) || result;
           } else if (!isTypeRelatedTo(getIndexedAccessType(source, childrenNameType), childrenTargetType, relation)) {
             result = true;
-            const diag2 = error(
+            const diag2 = error2(
               containingElement.openingElement.tagName,
               Diagnostics.This_JSX_tag_s_0_prop_expects_a_single_child_of_type_1_but_multiple_children_were_provided,
               childrenPropName,
@@ -160684,7 +144416,7 @@ ${lanes.join("\n")}
             }
           } else if (!isTypeRelatedTo(getIndexedAccessType(source, childrenNameType), childrenTargetType, relation)) {
             result = true;
-            const diag2 = error(
+            const diag2 = error2(
               containingElement.openingElement.tagName,
               Diagnostics.This_JSX_tag_s_0_prop_expects_type_1_which_requires_multiple_children_but_only_a_single_child_was_provided,
               childrenPropName,
@@ -160704,14 +144436,7 @@ ${lanes.join("\n")}
           const childrenPropName = childPropName === void 0 ? "children" : unescapeLeadingUnderscores(childPropName);
           const childrenTargetType = getIndexedAccessType(target, getStringLiteralType(childrenPropName));
           const diagnostic = Diagnostics._0_components_don_t_accept_text_as_child_elements_Text_in_JSX_has_the_type_string_but_the_expected_type_of_1_is_2;
-          invalidTextDiagnostic = { ...diagnostic, key: "!!ALREADY FORMATTED!!", message: formatMessage(
-            /*dummy*/
-            void 0,
-            diagnostic,
-            tagNameText,
-            childrenPropName,
-            typeToString(childrenTargetType)
-          ) };
+          invalidTextDiagnostic = { ...diagnostic, key: "!!ALREADY FORMATTED!!", message: formatMessage(diagnostic, tagNameText, childrenPropName, typeToString(childrenTargetType)) };
         }
         return invalidTextDiagnostic;
       }
@@ -160765,13 +144490,13 @@ ${lanes.join("\n")}
           continue;
         }
         switch (prop.kind) {
-          case 177 /* SetAccessor */:
-          case 176 /* GetAccessor */:
-          case 173 /* MethodDeclaration */:
-          case 303 /* ShorthandPropertyAssignment */:
+          case 178 /* SetAccessor */:
+          case 177 /* GetAccessor */:
+          case 174 /* MethodDeclaration */:
+          case 304 /* ShorthandPropertyAssignment */:
             yield { errorNode: prop.name, innerExpression: void 0, nameType: type };
             break;
-          case 302 /* PropertyAssignment */:
+          case 303 /* PropertyAssignment */:
             yield { errorNode: prop.name, innerExpression: prop.initializer, nameType: type, errorMessage: isComputedNonLiteralName(prop.name) ? Diagnostics.Type_of_computed_property_s_value_is_0_which_is_not_assignable_to_type_1 : void 0 };
             break;
           default:
@@ -160846,7 +144571,7 @@ ${lanes.join("\n")}
         void instantiateType(sourceRestType || targetRestType, reportUnreliableMarkers);
       }
       const kind = target.declaration ? target.declaration.kind : 0 /* Unknown */;
-      const strictVariance = !(checkMode & 3 /* Callback */) && strictFunctionTypes && kind !== 173 /* MethodDeclaration */ && kind !== 172 /* MethodSignature */ && kind !== 175 /* Constructor */;
+      const strictVariance = !(checkMode & 3 /* Callback */) && strictFunctionTypes && kind !== 174 /* MethodDeclaration */ && kind !== 173 /* MethodSignature */ && kind !== 176 /* Constructor */;
       let result = -1 /* True */;
       const sourceThisType = getThisTypeOfSignature(source);
       if (sourceThisType && sourceThisType !== voidType) {
@@ -160875,7 +144600,7 @@ ${lanes.join("\n")}
         if (sourceType && targetType) {
           const sourceSig = checkMode & 3 /* Callback */ ? void 0 : getSingleCallSignature(getNonNullableType(sourceType));
           const targetSig = checkMode & 3 /* Callback */ ? void 0 : getSingleCallSignature(getNonNullableType(targetType));
-          const callbacks = sourceSig && targetSig && !getTypePredicateOfSignature(sourceSig) && !getTypePredicateOfSignature(targetSig) && (getTypeFacts(sourceType) & 50331648 /* IsUndefinedOrNull */) === (getTypeFacts(targetType) & 50331648 /* IsUndefinedOrNull */);
+          const callbacks = sourceSig && targetSig && !getTypePredicateOfSignature(sourceSig) && !getTypePredicateOfSignature(targetSig) && getTypeFacts(sourceType, 50331648 /* IsUndefinedOrNull */) === getTypeFacts(targetType, 50331648 /* IsUndefinedOrNull */);
           let related = callbacks ? compareSignaturesRelated(targetSig, sourceSig, checkMode & 8 /* StrictArity */ | (strictVariance ? 2 /* StrictCallback */ : 1 /* BivariantCallback */), reportErrors2, errorReporter, incompatibleErrorReporter, compareTypes, reportUnreliableMarkers) : !(checkMode & 3 /* Callback */) && !strictVariance && compareTypes(
             sourceType,
             targetType,
@@ -160892,11 +144617,7 @@ ${lanes.join("\n")}
           }
           if (!related) {
             if (reportErrors2) {
-              errorReporter(
-                Diagnostics.Types_of_parameters_0_and_1_are_incompatible,
-                unescapeLeadingUnderscores(getParameterNameAtPosition(source, i)),
-                unescapeLeadingUnderscores(getParameterNameAtPosition(target, i))
-              );
+              errorReporter(Diagnostics.Types_of_parameters_0_and_1_are_incompatible, unescapeLeadingUnderscores(getParameterNameAtPosition(source, i)), unescapeLeadingUnderscores(getParameterNameAtPosition(target, i)));
             }
             return 0 /* False */;
           }
@@ -161017,16 +144738,12 @@ ${lanes.join("\n")}
           const targetProperty = getPropertyOfType(targetEnumType, property.escapedName);
           if (!targetProperty || !(targetProperty.flags & 8 /* EnumMember */)) {
             if (errorReporter) {
-              errorReporter(
-                Diagnostics.Property_0_is_missing_in_type_1,
-                symbolName(property),
-                typeToString(
-                  getDeclaredTypeOfSymbol(targetSymbol),
-                  /*enclosingDeclaration*/
-                  void 0,
-                  64 /* UseFullyQualifiedType */
-                )
-              );
+              errorReporter(Diagnostics.Property_0_is_missing_in_type_1, symbolName(property), typeToString(
+                getDeclaredTypeOfSymbol(targetSymbol),
+                /*enclosingDeclaration*/
+                void 0,
+                64 /* UseFullyQualifiedType */
+              ));
               enumRelation.set(id, 2 /* Failed */ | 4 /* Reported */);
             } else {
               enumRelation.set(id, 2 /* Failed */);
@@ -161165,6 +144882,7 @@ ${lanes.join("\n")}
       let errorInfo;
       let relatedInfo;
       let maybeKeys;
+      let maybeKeysSet;
       let sourceStack;
       let targetStack;
       let maybeCount = 0;
@@ -161173,8 +144891,10 @@ ${lanes.join("\n")}
       let expandingFlags = 0 /* None */;
       let overflow = false;
       let overrideNextErrorInfo = 0;
+      let skipParentCounter = 0;
       let lastSkippedInfo;
       let incompatibleStack;
+      let relationCount = 16e6 - relation.size >> 3;
       Debug.assert(relation !== identityRelation || !errorNode, "no error reporting in identity checking");
       const result = isRelatedTo(
         source,
@@ -161188,8 +144908,19 @@ ${lanes.join("\n")}
         reportIncompatibleStack();
       }
       if (overflow) {
+        const id = getRelationKey(
+          source,
+          target,
+          /*intersectionState*/
+          0 /* None */,
+          relation,
+          /*ignoreConstraints*/
+          false
+        );
+        relation.set(id, 4 /* Reported */ | 2 /* Failed */);
         (_a = tracing) == null ? void 0 : _a.instant(tracing.Phase.CheckTypes, "checkTypeRelatedTo_DepthLimit", { sourceId: source.id, targetId: target.id, depth: sourceDepth, targetDepth });
-        const diag2 = error(errorNode || currentNode, Diagnostics.Excessive_stack_depth_comparing_types_0_and_1, typeToString(source), typeToString(target));
+        const message = relationCount <= 0 ? Diagnostics.Excessive_complexity_comparing_types_0_and_1 : Diagnostics.Excessive_stack_depth_comparing_types_0_and_1;
+        const diag2 = error2(errorNode || currentNode, message, typeToString(source), typeToString(target));
         if (errorOutputContainer) {
           (errorOutputContainer.errors || (errorOutputContainer.errors = [])).push(diag2);
         }
@@ -161238,6 +144969,7 @@ ${lanes.join("\n")}
         lastSkippedInfo = saved.lastSkippedInfo;
         incompatibleStack = saved.incompatibleStack;
         overrideNextErrorInfo = saved.overrideNextErrorInfo;
+        skipParentCounter = saved.skipParentCounter;
         relatedInfo = saved.relatedInfo;
       }
       function captureErrorCalculationState() {
@@ -161246,6 +144978,7 @@ ${lanes.join("\n")}
           lastSkippedInfo,
           incompatibleStack: incompatibleStack == null ? void 0 : incompatibleStack.slice(),
           overrideNextErrorInfo,
+          skipParentCounter,
           relatedInfo: relatedInfo == null ? void 0 : relatedInfo.slice()
         };
       }
@@ -161350,7 +145083,15 @@ ${lanes.join("\n")}
           reportIncompatibleStack();
         if (message.elidedInCompatabilityPyramid)
           return;
-        errorInfo = chainDiagnosticMessages(errorInfo, message, ...args);
+        if (skipParentCounter === 0) {
+          errorInfo = chainDiagnosticMessages(errorInfo, message, ...args);
+        } else {
+          skipParentCounter--;
+        }
+      }
+      function reportParentSkippedError(message, ...args) {
+        reportError(message, ...args);
+        skipParentCounter++;
       }
       function associateRelatedInfo(info) {
         Debug.assert(!!errorInfo);
@@ -161687,18 +145428,9 @@ ${lanes.join("\n")}
                     }
                   }
                   if (suggestion !== void 0) {
-                    reportError(
-                      Diagnostics.Object_literal_may_only_specify_known_properties_but_0_does_not_exist_in_type_1_Did_you_mean_to_write_2,
-                      symbolToString(prop),
-                      typeToString(errorTarget),
-                      suggestion
-                    );
+                    reportParentSkippedError(Diagnostics.Object_literal_may_only_specify_known_properties_but_0_does_not_exist_in_type_1_Did_you_mean_to_write_2, symbolToString(prop), typeToString(errorTarget), suggestion);
                   } else {
-                    reportError(
-                      Diagnostics.Object_literal_may_only_specify_known_properties_and_0_does_not_exist_in_type_1,
-                      symbolToString(prop),
-                      typeToString(errorTarget)
-                    );
+                    reportParentSkippedError(Diagnostics.Object_literal_may_only_specify_known_properties_and_0_does_not_exist_in_type_1, symbolToString(prop), typeToString(errorTarget));
                   }
                 }
               }
@@ -161719,6 +145451,16 @@ ${lanes.join("\n")}
       }
       function unionOrIntersectionRelatedTo(source2, target2, reportErrors2, intersectionState) {
         if (source2.flags & 1048576 /* Union */) {
+          if (target2.flags & 1048576 /* Union */) {
+            const sourceOrigin = source2.origin;
+            if (sourceOrigin && sourceOrigin.flags & 2097152 /* Intersection */ && target2.aliasSymbol && contains(sourceOrigin.types, target2)) {
+              return -1 /* True */;
+            }
+            const targetOrigin = target2.origin;
+            if (targetOrigin && targetOrigin.flags & 1048576 /* Union */ && source2.aliasSymbol && contains(targetOrigin.types, source2)) {
+              return -1 /* True */;
+            }
+          }
           return relation === comparableRelation ? someTypeRelatedToType(source2, target2, reportErrors2 && !(source2.flags & 402784252 /* Primitive */), intersectionState) : eachTypeRelatedToType(source2, target2, reportErrors2 && !(source2.flags & 402784252 /* Primitive */), intersectionState);
         }
         if (target2.flags & 1048576 /* Union */) {
@@ -162032,11 +145774,19 @@ ${lanes.join("\n")}
             return entry & 1 /* Succeeded */ ? -1 /* True */ : 0 /* False */;
           }
         }
+        if (relationCount <= 0) {
+          overflow = true;
+          return 0 /* False */;
+        }
         if (!maybeKeys) {
           maybeKeys = [];
+          maybeKeysSet = /* @__PURE__ */ new Set();
           sourceStack = [];
           targetStack = [];
         } else {
+          if (maybeKeysSet.has(id)) {
+            return 3 /* Maybe */;
+          }
           const broadestEquivalentId = id.startsWith("*") ? getRelationKey(
             source2,
             target2,
@@ -162045,10 +145795,8 @@ ${lanes.join("\n")}
             /*ignoreConstraints*/
             true
           ) : void 0;
-          for (let i = 0; i < maybeCount; i++) {
-            if (id === maybeKeys[i] || broadestEquivalentId && broadestEquivalentId === maybeKeys[i]) {
-              return 3 /* Maybe */;
-            }
+          if (broadestEquivalentId && maybeKeysSet.has(broadestEquivalentId)) {
+            return 3 /* Maybe */;
           }
           if (sourceDepth === 100 || targetDepth === 100) {
             overflow = true;
@@ -162057,6 +145805,7 @@ ${lanes.join("\n")}
         }
         const maybeStart = maybeCount;
         maybeKeys[maybeCount] = id;
+        maybeKeysSet.add(id);
         maybeCount++;
         const saveExpandingFlags = expandingFlags;
         if (recursionFlags & 1 /* Source */) {
@@ -162109,17 +145858,36 @@ ${lanes.join("\n")}
         if (result2) {
           if (result2 === -1 /* True */ || sourceDepth === 0 && targetDepth === 0) {
             if (result2 === -1 /* True */ || result2 === 3 /* Maybe */) {
-              for (let i = maybeStart; i < maybeCount; i++) {
-                relation.set(maybeKeys[i], 1 /* Succeeded */ | propagatingVarianceFlags);
-              }
+              resetMaybeStack(
+                /*markAllAsSucceeded*/
+                true
+              );
+            } else {
+              resetMaybeStack(
+                /*markAllAsSucceeded*/
+                false
+              );
             }
-            maybeCount = maybeStart;
           }
         } else {
           relation.set(id, (reportErrors2 ? 4 /* Reported */ : 0) | 2 /* Failed */ | propagatingVarianceFlags);
-          maybeCount = maybeStart;
+          relationCount--;
+          resetMaybeStack(
+            /*markAllAsSucceeded*/
+            false
+          );
         }
         return result2;
+        function resetMaybeStack(markAllAsSucceeded) {
+          for (let i = maybeStart; i < maybeCount; i++) {
+            maybeKeysSet.delete(maybeKeys[i]);
+            if (markAllAsSucceeded) {
+              relation.set(maybeKeys[i], 1 /* Succeeded */ | propagatingVarianceFlags);
+              relationCount--;
+            }
+          }
+          maybeCount = maybeStart;
+        }
       }
       function structuredTypeRelatedTo(source2, target2, reportErrors2, intersectionState) {
         const saveErrorInfo = captureErrorCalculationState();
@@ -162531,26 +146299,6 @@ ${lanes.join("\n")}
             )) {
               return result2;
             }
-            if (sourceFlags & 8388608 /* IndexedAccess */) {
-              const indexType = source2.indexType;
-              if (indexType.flags & 4194304 /* Index */) {
-                const unresolvedIndexConstraint = getBaseConstraintOfType(indexType.type);
-                const indexConstraint = unresolvedIndexConstraint && unresolvedIndexConstraint !== noConstraintType ? getIndexType(unresolvedIndexConstraint) : keyofConstraintType;
-                const constraint2 = getIndexedAccessType(source2.objectType, indexConstraint);
-                if (result2 = isRelatedTo(
-                  constraint2,
-                  target2,
-                  1 /* Source */,
-                  /*reportErrors*/
-                  false,
-                  /*headMessage*/
-                  void 0,
-                  intersectionState
-                )) {
-                  return result2;
-                }
-              }
-            }
             if (isMappedTypeGenericIndexedAccess(source2)) {
               const indexConstraint = getConstraintOfType(source2.indexType);
               if (indexConstraint) {
@@ -162894,42 +146642,27 @@ ${lanes.join("\n")}
       function propertyRelatedTo(source2, target2, sourceProp, targetProp, getTypeOfSourceProperty, reportErrors2, intersectionState, skipOptional) {
         const sourcePropFlags = getDeclarationModifierFlagsFromSymbol(sourceProp);
         const targetPropFlags = getDeclarationModifierFlagsFromSymbol(targetProp);
-        if (sourcePropFlags & 8 /* Private */ || targetPropFlags & 8 /* Private */) {
+        if (sourcePropFlags & 2 /* Private */ || targetPropFlags & 2 /* Private */) {
           if (sourceProp.valueDeclaration !== targetProp.valueDeclaration) {
             if (reportErrors2) {
-              if (sourcePropFlags & 8 /* Private */ && targetPropFlags & 8 /* Private */) {
+              if (sourcePropFlags & 2 /* Private */ && targetPropFlags & 2 /* Private */) {
                 reportError(Diagnostics.Types_have_separate_declarations_of_a_private_property_0, symbolToString(targetProp));
               } else {
-                reportError(
-                  Diagnostics.Property_0_is_private_in_type_1_but_not_in_type_2,
-                  symbolToString(targetProp),
-                  typeToString(sourcePropFlags & 8 /* Private */ ? source2 : target2),
-                  typeToString(sourcePropFlags & 8 /* Private */ ? target2 : source2)
-                );
+                reportError(Diagnostics.Property_0_is_private_in_type_1_but_not_in_type_2, symbolToString(targetProp), typeToString(sourcePropFlags & 2 /* Private */ ? source2 : target2), typeToString(sourcePropFlags & 2 /* Private */ ? target2 : source2));
               }
             }
             return 0 /* False */;
           }
-        } else if (targetPropFlags & 16 /* Protected */) {
+        } else if (targetPropFlags & 4 /* Protected */) {
           if (!isValidOverrideOf(sourceProp, targetProp)) {
             if (reportErrors2) {
-              reportError(
-                Diagnostics.Property_0_is_protected_but_type_1_is_not_a_class_derived_from_2,
-                symbolToString(targetProp),
-                typeToString(getDeclaringClass(sourceProp) || source2),
-                typeToString(getDeclaringClass(targetProp) || target2)
-              );
+              reportError(Diagnostics.Property_0_is_protected_but_type_1_is_not_a_class_derived_from_2, symbolToString(targetProp), typeToString(getDeclaringClass(sourceProp) || source2), typeToString(getDeclaringClass(targetProp) || target2));
             }
             return 0 /* False */;
           }
-        } else if (sourcePropFlags & 16 /* Protected */) {
+        } else if (sourcePropFlags & 4 /* Protected */) {
           if (reportErrors2) {
-            reportError(
-              Diagnostics.Property_0_is_protected_in_type_1_but_public_in_type_2,
-              symbolToString(targetProp),
-              typeToString(source2),
-              typeToString(target2)
-            );
+            reportError(Diagnostics.Property_0_is_protected_in_type_1_but_public_in_type_2, symbolToString(targetProp), typeToString(source2), typeToString(target2));
           }
           return 0 /* False */;
         }
@@ -162945,12 +146678,7 @@ ${lanes.join("\n")}
         }
         if (!skipOptional && sourceProp.flags & 16777216 /* Optional */ && targetProp.flags & 106500 /* ClassMember */ && !(targetProp.flags & 16777216 /* Optional */)) {
           if (reportErrors2) {
-            reportError(
-              Diagnostics.Property_0_is_optional_in_type_1_but_required_in_type_2,
-              symbolToString(targetProp),
-              typeToString(source2),
-              typeToString(target2)
-            );
+            reportError(Diagnostics.Property_0_is_optional_in_type_1_but_required_in_type_2, symbolToString(targetProp), typeToString(source2), typeToString(target2));
           }
           return 0 /* False */;
         }
@@ -163196,8 +146924,14 @@ ${lanes.join("\n")}
         }
         const sourceIsJSConstructor = source2.symbol && isJSConstructor(source2.symbol.valueDeclaration);
         const targetIsJSConstructor = target2.symbol && isJSConstructor(target2.symbol.valueDeclaration);
-        const sourceSignatures = getSignaturesOfType(source2, sourceIsJSConstructor && kind === 1 /* Construct */ ? 0 /* Call */ : kind);
-        const targetSignatures = getSignaturesOfType(target2, targetIsJSConstructor && kind === 1 /* Construct */ ? 0 /* Call */ : kind);
+        const sourceSignatures = getSignaturesOfType(
+          source2,
+          sourceIsJSConstructor && kind === 1 /* Construct */ ? 0 /* Call */ : kind
+        );
+        const targetSignatures = getSignaturesOfType(
+          target2,
+          targetIsJSConstructor && kind === 1 /* Construct */ ? 0 /* Call */ : kind
+        );
         if (kind === 1 /* Construct */ && sourceSignatures.length && targetSignatures.length) {
           const sourceIsAbstract = !!(sourceSignatures[0].flags & 4 /* Abstract */);
           const targetIsAbstract = !!(targetSignatures[0].flags & 4 /* Abstract */);
@@ -163236,7 +146970,7 @@ ${lanes.join("\n")}
           const sourceSignature = first(sourceSignatures);
           const targetSignature = first(targetSignatures);
           result2 = signatureRelatedTo(sourceSignature, targetSignature, eraseGenerics, reportErrors2, intersectionState, incompatibleReporter(sourceSignature, targetSignature));
-          if (!result2 && reportErrors2 && kind === 1 /* Construct */ && sourceObjectFlags & targetObjectFlags && (((_a2 = targetSignature.declaration) == null ? void 0 : _a2.kind) === 175 /* Constructor */ || ((_b = sourceSignature.declaration) == null ? void 0 : _b.kind) === 175 /* Constructor */)) {
+          if (!result2 && reportErrors2 && kind === 1 /* Construct */ && sourceObjectFlags & targetObjectFlags && (((_a2 = targetSignature.declaration) == null ? void 0 : _a2.kind) === 176 /* Constructor */ || ((_b = sourceSignature.declaration) == null ? void 0 : _b.kind) === 176 /* Constructor */)) {
             const constructSignatureToString = (signature) => signatureToString(
               signature,
               /*enclosingDeclaration*/
@@ -163271,18 +147005,14 @@ ${lanes.join("\n")}
                 shouldElaborateErrors = false;
               }
               if (shouldElaborateErrors) {
-                reportError(
-                  Diagnostics.Type_0_provides_no_match_for_the_signature_1,
-                  typeToString(source2),
-                  signatureToString(
-                    t,
-                    /*enclosingDeclaration*/
-                    void 0,
-                    /*flags*/
-                    void 0,
-                    kind
-                  )
-                );
+                reportError(Diagnostics.Type_0_provides_no_match_for_the_signature_1, typeToString(source2), signatureToString(
+                  t,
+                  /*enclosingDeclaration*/
+                  void 0,
+                  /*flags*/
+                  void 0,
+                  kind
+                ));
               }
               return 0 /* False */;
             }
@@ -163315,16 +147045,7 @@ ${lanes.join("\n")}
       }
       function signatureRelatedTo(source2, target2, erase, reportErrors2, intersectionState, incompatibleReporter) {
         const checkMode = relation === subtypeRelation ? 16 /* StrictTopSignature */ : relation === strictSubtypeRelation ? 16 /* StrictTopSignature */ | 8 /* StrictArity */ : 0 /* None */;
-        return compareSignaturesRelated(
-          erase ? getErasedSignature(source2) : source2,
-          erase ? getErasedSignature(target2) : target2,
-          checkMode,
-          reportErrors2,
-          reportError,
-          incompatibleReporter,
-          isRelatedToWorker2,
-          reportUnreliableMapper
-        );
+        return compareSignaturesRelated(erase ? getErasedSignature(source2) : source2, erase ? getErasedSignature(target2) : target2, checkMode, reportErrors2, reportError, incompatibleReporter, isRelatedToWorker2, reportUnreliableMapper);
         function isRelatedToWorker2(source3, target3, reportErrors3) {
           return isRelatedTo(
             source3,
@@ -163469,15 +147190,15 @@ ${lanes.join("\n")}
         if (!sourceSignature.declaration || !targetSignature.declaration) {
           return true;
         }
-        const sourceAccessibility = getSelectedEffectiveModifierFlags(sourceSignature.declaration, 24 /* NonPublicAccessibilityModifier */);
-        const targetAccessibility = getSelectedEffectiveModifierFlags(targetSignature.declaration, 24 /* NonPublicAccessibilityModifier */);
-        if (targetAccessibility === 8 /* Private */) {
+        const sourceAccessibility = getSelectedEffectiveModifierFlags(sourceSignature.declaration, 6 /* NonPublicAccessibilityModifier */);
+        const targetAccessibility = getSelectedEffectiveModifierFlags(targetSignature.declaration, 6 /* NonPublicAccessibilityModifier */);
+        if (targetAccessibility === 2 /* Private */) {
           return true;
         }
-        if (targetAccessibility === 16 /* Protected */ && sourceAccessibility !== 8 /* Private */) {
+        if (targetAccessibility === 4 /* Protected */ && sourceAccessibility !== 2 /* Private */) {
           return true;
         }
-        if (targetAccessibility !== 16 /* Protected */ && !sourceAccessibility) {
+        if (targetAccessibility !== 4 /* Protected */ && !sourceAccessibility) {
           return true;
         }
         if (reportErrors2) {
@@ -163522,7 +147243,7 @@ ${lanes.join("\n")}
         let matched = false;
         for (let i = 0; i < types.length; i++) {
           if (include[i]) {
-            const targetType = getTypeOfPropertyOfType(types[i], propertyName);
+            const targetType = getTypeOfPropertyOrIndexSignatureOfType(types[i], propertyName);
             if (targetType && related(getDiscriminatingType(), targetType)) {
               matched = true;
             } else {
@@ -163536,7 +147257,7 @@ ${lanes.join("\n")}
           }
         }
       }
-      const filtered = contains(include, 0 /* False */) ? getUnionType(types.filter((_, i) => include[i])) : target;
+      const filtered = contains(include, 0 /* False */) ? getUnionType(types.filter((_, i) => include[i]), 0 /* None */) : target;
       return filtered.flags & 131072 /* Never */ ? target : filtered;
     }
     function isWeakType(type) {
@@ -163577,7 +147298,7 @@ ${lanes.join("\n")}
         const variances = [];
         for (const tp of typeParameters) {
           const modifiers = getTypeParameterModifiers(tp);
-          let variance = modifiers & 65536 /* Out */ ? modifiers & 32768 /* In */ ? 0 /* Invariant */ : 1 /* Covariant */ : modifiers & 32768 /* In */ ? 2 /* Contravariant */ : void 0;
+          let variance = modifiers & 16384 /* Out */ ? modifiers & 8192 /* In */ ? 0 /* Invariant */ : 1 /* Covariant */ : modifiers & 8192 /* In */ ? 2 /* Contravariant */ : void 0;
           if (variance === void 0) {
             let unmeasurable = false;
             let unreliable = false;
@@ -163625,7 +147346,7 @@ ${lanes.join("\n")}
     }
     function getTypeParameterModifiers(tp) {
       var _a;
-      return reduceLeft((_a = tp.symbol) == null ? void 0 : _a.declarations, (modifiers, d) => modifiers | getEffectiveModifierFlags(d), 0 /* None */) & (32768 /* In */ | 65536 /* Out */ | 2048 /* Const */);
+      return reduceLeft((_a = tp.symbol) == null ? void 0 : _a.declarations, (modifiers, d) => modifiers | getEffectiveModifierFlags(d), 0 /* None */) & (8192 /* In */ | 16384 /* Out */ | 4096 /* Const */);
     }
     function hasCovariantVoidArgument(typeArguments, variances) {
       for (let i = 0; i < variances.length; i++) {
@@ -163710,13 +147431,16 @@ ${lanes.join("\n")}
       });
     }
     function isValidOverrideOf(sourceProp, targetProp) {
-      return !forEachProperty2(targetProp, (tp) => getDeclarationModifierFlagsFromSymbol(tp) & 16 /* Protected */ ? !isPropertyInClassDerivedFrom(sourceProp, getDeclaringClass(tp)) : false);
+      return !forEachProperty2(targetProp, (tp) => getDeclarationModifierFlagsFromSymbol(tp) & 4 /* Protected */ ? !isPropertyInClassDerivedFrom(sourceProp, getDeclaringClass(tp)) : false);
     }
     function isClassDerivedFromDeclaringClasses(checkClass, prop, writing) {
-      return forEachProperty2(prop, (p) => getDeclarationModifierFlagsFromSymbol(p, writing) & 16 /* Protected */ ? !hasBaseType(checkClass, getDeclaringClass(p)) : false) ? void 0 : checkClass;
+      return forEachProperty2(prop, (p) => getDeclarationModifierFlagsFromSymbol(p, writing) & 4 /* Protected */ ? !hasBaseType(checkClass, getDeclaringClass(p)) : false) ? void 0 : checkClass;
     }
     function isDeeplyNestedType(type, stack, depth, maxDepth = 3) {
       if (depth >= maxDepth) {
+        if ((getObjectFlags(type) & 96 /* InstantiatedMapped */) === 96 /* InstantiatedMapped */) {
+          type = getMappedTargetWithSymbol(type);
+        }
         if (type.flags & 2097152 /* Intersection */) {
           return some(type.types, (t) => isDeeplyNestedType(t, stack, depth, maxDepth));
         }
@@ -163725,7 +147449,7 @@ ${lanes.join("\n")}
         let lastTypeId = 0;
         for (let i = 0; i < depth; i++) {
           const t = stack[i];
-          if (t.flags & 2097152 /* Intersection */ ? some(t.types, (u) => getRecursionIdentity(u) === identity2) : getRecursionIdentity(t) === identity2) {
+          if (hasMatchingRecursionIdentity(t, identity2)) {
             if (t.id >= lastTypeId) {
               count++;
               if (count >= maxDepth) {
@@ -163738,9 +147462,25 @@ ${lanes.join("\n")}
       }
       return false;
     }
+    function getMappedTargetWithSymbol(type) {
+      let target;
+      while ((getObjectFlags(type) & 96 /* InstantiatedMapped */) === 96 /* InstantiatedMapped */ && (target = getModifiersTypeFromMappedType(type)) && (target.symbol || target.flags & 2097152 /* Intersection */ && some(target.types, (t) => !!t.symbol))) {
+        type = target;
+      }
+      return type;
+    }
+    function hasMatchingRecursionIdentity(type, identity2) {
+      if ((getObjectFlags(type) & 96 /* InstantiatedMapped */) === 96 /* InstantiatedMapped */) {
+        type = getMappedTargetWithSymbol(type);
+      }
+      if (type.flags & 2097152 /* Intersection */) {
+        return some(type.types, (t) => hasMatchingRecursionIdentity(t, identity2));
+      }
+      return getRecursionIdentity(type) === identity2;
+    }
     function getRecursionIdentity(type) {
       if (type.flags & 524288 /* Object */ && !isObjectOrArrayLiteralType(type)) {
-        if (getObjectFlags(type) && 4 /* Reference */ && type.node) {
+        if (getObjectFlags(type) & 4 /* Reference */ && type.node) {
           return type.node;
         }
         if (type.symbol && !(getObjectFlags(type) & 16 /* Anonymous */ && type.symbol.flags & 32 /* Class */)) {
@@ -163771,8 +147511,8 @@ ${lanes.join("\n")}
       if (sourceProp === targetProp) {
         return -1 /* True */;
       }
-      const sourcePropAccessibility = getDeclarationModifierFlagsFromSymbol(sourceProp) & 24 /* NonPublicAccessibilityModifier */;
-      const targetPropAccessibility = getDeclarationModifierFlagsFromSymbol(targetProp) & 24 /* NonPublicAccessibilityModifier */;
+      const sourcePropAccessibility = getDeclarationModifierFlagsFromSymbol(sourceProp) & 6 /* NonPublicAccessibilityModifier */;
+      const targetPropAccessibility = getDeclarationModifierFlagsFromSymbol(targetProp) & 6 /* NonPublicAccessibilityModifier */;
       if (sourcePropAccessibility !== targetPropAccessibility) {
         return 0 /* False */;
       }
@@ -163910,6 +147650,9 @@ ${lanes.join("\n")}
     function isArrayLikeType(type) {
       return isArrayType(type) || !(type.flags & 98304 /* Nullable */) && isTypeAssignableTo(type, anyReadonlyArrayType);
     }
+    function isMutableArrayLikeType(type) {
+      return isMutableArrayOrTuple(type) || !(type.flags & (1 /* Any */ | 98304 /* Nullable */)) && isTypeAssignableTo(type, anyArrayType);
+    }
     function getSingleBaseForNonAugmentingSubtype(type) {
       if (!(getObjectFlags(type) & 4 /* Reference */) || !(getObjectFlags(type.target) & 3 /* ClassOrInterface */)) {
         return void 0;
@@ -163921,7 +147664,7 @@ ${lanes.join("\n")}
       const target = type.target;
       if (getObjectFlags(target) & 1 /* Class */) {
         const baseTypeNode = getBaseTypeNodeOfClass(target);
-        if (baseTypeNode && baseTypeNode.expression.kind !== 80 /* Identifier */ && baseTypeNode.expression.kind !== 210 /* PropertyAccessExpression */) {
+        if (baseTypeNode && baseTypeNode.expression.kind !== 80 /* Identifier */ && baseTypeNode.expression.kind !== 211 /* PropertyAccessExpression */) {
           return void 0;
         }
       }
@@ -163947,7 +147690,8 @@ ${lanes.join("\n")}
       return !!elementType && isEmptyLiteralType(elementType);
     }
     function isTupleLikeType(type) {
-      return isTupleType(type) || !!getPropertyOfType(type, "0");
+      let lengthType;
+      return isTupleType(type) || !!getPropertyOfType(type, "0") || isArrayLikeType(type) && !!(lengthType = getTypeOfPropertyOfType(type, "length")) && everyType(lengthType, (t) => !!(t.flags & 256 /* NumberLiteral */));
     }
     function isArrayOrTupleLikeType(type) {
       return isArrayLikeType(type) || isTupleLikeType(type);
@@ -163958,17 +147702,7 @@ ${lanes.join("\n")}
         return propType;
       }
       if (everyType(type, isTupleType)) {
-        return mapType(type, (t) => {
-          const tupleType = t;
-          const restType = getRestTypeOfTupleType(tupleType);
-          if (!restType) {
-            return undefinedType;
-          }
-          if (compilerOptions.noUncheckedIndexedAccess && index >= tupleType.target.fixedLength + getEndElementCount(tupleType.target, 3 /* Fixed */)) {
-            return getUnionType([restType, undefinedType]);
-          }
-          return restType;
-        });
+        return getTupleElementTypeOutOfStartCount(type, index, compilerOptions.noUncheckedIndexedAccess ? undefinedType : void 0);
       }
       return void 0;
     }
@@ -164036,6 +147770,19 @@ ${lanes.join("\n")}
     function getRestTypeOfTupleType(type) {
       return getElementTypeOfSliceOfTupleType(type, type.target.fixedLength);
     }
+    function getTupleElementTypeOutOfStartCount(type, index, undefinedOrMissingType2) {
+      return mapType(type, (t) => {
+        const tupleType = t;
+        const restType = getRestTypeOfTupleType(tupleType);
+        if (!restType) {
+          return undefinedType;
+        }
+        if (undefinedOrMissingType2 && index >= getTotalFixedElementCount(tupleType.target)) {
+          return getUnionType([restType, undefinedOrMissingType2]);
+        }
+        return restType;
+      });
+    }
     function getRestArrayTypeOfTupleType(type) {
       const restType = getRestTypeOfTupleType(type);
       return restType && createArrayType(restType);
@@ -164060,7 +147807,7 @@ ${lanes.join("\n")}
       return value.base10Value === "0";
     }
     function removeDefinitelyFalsyTypes(type) {
-      return filterType(type, (t) => !!(getTypeFacts(t) & 4194304 /* Truthy */));
+      return filterType(type, (t) => hasTypeFacts(t, 4194304 /* Truthy */));
     }
     function extractDefinitelyFalsyTypes(type) {
       return mapType(type, getDefinitelyFalsyPartOfType);
@@ -164229,13 +147976,7 @@ ${lanes.join("\n")}
           }
         }
       }
-      const result = createAnonymousType(
-        type.symbol,
-        members,
-        emptyArray,
-        emptyArray,
-        sameMap(getIndexInfosOfType(type), (info) => createIndexInfo(info.keyType, getWidenedType(info.type), info.isReadonly))
-      );
+      const result = createAnonymousType(type.symbol, members, emptyArray, emptyArray, sameMap(getIndexInfosOfType(type), (info) => createIndexInfo(info.keyType, getWidenedType(info.type), info.isReadonly)));
       result.objectFlags |= getObjectFlags(type) & (4096 /* JSLiteral */ | 262144 /* NonInferrableType */);
       return result;
     }
@@ -164304,7 +148045,7 @@ ${lanes.join("\n")}
             const t = getTypeOfSymbol(p);
             if (getObjectFlags(t) & 65536 /* ContainsWideningType */) {
               if (!reportWideningErrorsInType(t)) {
-                error(p.valueDeclaration, Diagnostics.Object_literal_s_property_0_implicitly_has_an_1_type, symbolToString(p), typeToString(getWidenedType(t)));
+                error2(p.valueDeclaration, Diagnostics.Object_literal_s_property_0_implicitly_has_an_1_type, symbolToString(p), typeToString(getWidenedType(t)));
               }
               errorReported = true;
             }
@@ -164320,16 +148061,16 @@ ${lanes.join("\n")}
       }
       let diagnostic;
       switch (declaration.kind) {
-        case 225 /* BinaryExpression */:
-        case 171 /* PropertyDeclaration */:
-        case 170 /* PropertySignature */:
+        case 226 /* BinaryExpression */:
+        case 172 /* PropertyDeclaration */:
+        case 171 /* PropertySignature */:
           diagnostic = noImplicitAny ? Diagnostics.Member_0_implicitly_has_an_1_type : Diagnostics.Member_0_implicitly_has_an_1_type_but_a_better_type_may_be_inferred_from_usage;
           break;
-        case 168 /* Parameter */:
+        case 169 /* Parameter */:
           const param = declaration;
           if (isIdentifier(param.name)) {
             const originalKeywordKind = identifierToKeywordKind(param.name);
-            if ((isCallSignatureDeclaration(param.parent) || isMethodSignature(param.parent) || isFunctionTypeNode(param.parent)) && param.parent.parameters.indexOf(param) > -1 && (resolveName(
+            if ((isCallSignatureDeclaration(param.parent) || isMethodSignature(param.parent) || isFunctionTypeNode(param.parent)) && param.parent.parameters.includes(param) && (resolveName(
               param,
               param.name.escapedText,
               788968 /* Type */,
@@ -164347,40 +148088,40 @@ ${lanes.join("\n")}
           }
           diagnostic = declaration.dotDotDotToken ? noImplicitAny ? Diagnostics.Rest_parameter_0_implicitly_has_an_any_type : Diagnostics.Rest_parameter_0_implicitly_has_an_any_type_but_a_better_type_may_be_inferred_from_usage : noImplicitAny ? Diagnostics.Parameter_0_implicitly_has_an_1_type : Diagnostics.Parameter_0_implicitly_has_an_1_type_but_a_better_type_may_be_inferred_from_usage;
           break;
-        case 207 /* BindingElement */:
+        case 208 /* BindingElement */:
           diagnostic = Diagnostics.Binding_element_0_implicitly_has_an_1_type;
           if (!noImplicitAny) {
             return;
           }
           break;
-        case 323 /* JSDocFunctionType */:
-          error(declaration, Diagnostics.Function_type_which_lacks_return_type_annotation_implicitly_has_an_0_return_type, typeAsString);
+        case 324 /* JSDocFunctionType */:
+          error2(declaration, Diagnostics.Function_type_which_lacks_return_type_annotation_implicitly_has_an_0_return_type, typeAsString);
           return;
-        case 329 /* JSDocSignature */:
+        case 330 /* JSDocSignature */:
           if (noImplicitAny && isJSDocOverloadTag(declaration.parent)) {
-            error(declaration.parent.tagName, Diagnostics.This_overload_implicitly_returns_the_type_0_because_it_lacks_a_return_type_annotation, typeAsString);
+            error2(declaration.parent.tagName, Diagnostics.This_overload_implicitly_returns_the_type_0_because_it_lacks_a_return_type_annotation, typeAsString);
           }
           return;
-        case 261 /* FunctionDeclaration */:
-        case 173 /* MethodDeclaration */:
-        case 172 /* MethodSignature */:
-        case 176 /* GetAccessor */:
-        case 177 /* SetAccessor */:
-        case 217 /* FunctionExpression */:
-        case 218 /* ArrowFunction */:
+        case 262 /* FunctionDeclaration */:
+        case 174 /* MethodDeclaration */:
+        case 173 /* MethodSignature */:
+        case 177 /* GetAccessor */:
+        case 178 /* SetAccessor */:
+        case 218 /* FunctionExpression */:
+        case 219 /* ArrowFunction */:
           if (noImplicitAny && !declaration.name) {
             if (wideningKind === 3 /* GeneratorYield */) {
-              error(declaration, Diagnostics.Generator_implicitly_has_yield_type_0_because_it_does_not_yield_any_values_Consider_supplying_a_return_type_annotation, typeAsString);
+              error2(declaration, Diagnostics.Generator_implicitly_has_yield_type_0_because_it_does_not_yield_any_values_Consider_supplying_a_return_type_annotation, typeAsString);
             } else {
-              error(declaration, Diagnostics.Function_expression_which_lacks_return_type_annotation_implicitly_has_an_0_return_type, typeAsString);
+              error2(declaration, Diagnostics.Function_expression_which_lacks_return_type_annotation_implicitly_has_an_0_return_type, typeAsString);
             }
             return;
           }
           diagnostic = !noImplicitAny ? Diagnostics._0_implicitly_has_an_1_return_type_but_a_better_type_may_be_inferred_from_usage : wideningKind === 3 /* GeneratorYield */ ? Diagnostics._0_which_lacks_return_type_annotation_implicitly_has_an_1_yield_type : Diagnostics._0_which_lacks_return_type_annotation_implicitly_has_an_1_return_type;
           break;
-        case 199 /* MappedType */:
+        case 200 /* MappedType */:
           if (noImplicitAny) {
-            error(declaration, Diagnostics.Mapped_object_type_implicitly_has_an_any_template_type);
+            error2(declaration, Diagnostics.Mapped_object_type_implicitly_has_an_any_template_type);
           }
           return;
         default:
@@ -164415,7 +148156,12 @@ ${lanes.join("\n")}
         callback(getTypeAtPosition(source, i), getTypeAtPosition(target, i));
       }
       if (targetRestType) {
-        callback(getRestTypeAtPosition(source, paramCount), targetRestType);
+        callback(getRestTypeAtPosition(
+          source,
+          paramCount,
+          /*readonly*/
+          isConstTypeVariable(targetRestType) && !someType(targetRestType, isMutableArrayLikeType)
+        ), targetRestType);
       }
     }
     function applyToReturnTypes(source, target, callback) {
@@ -164448,19 +148194,25 @@ ${lanes.join("\n")}
       return context;
     }
     function makeFixingMapperForContext(context) {
-      return makeDeferredTypeMapper(map(context.inferences, (i) => i.typeParameter), map(context.inferences, (inference, i) => () => {
-        if (!inference.isFixed) {
-          inferFromIntraExpressionSites(context);
-          clearCachedInferences(context.inferences);
-          inference.isFixed = true;
-        }
-        return getInferredType(context, i);
-      }));
+      return makeDeferredTypeMapper(
+        map(context.inferences, (i) => i.typeParameter),
+        map(context.inferences, (inference, i) => () => {
+          if (!inference.isFixed) {
+            inferFromIntraExpressionSites(context);
+            clearCachedInferences(context.inferences);
+            inference.isFixed = true;
+          }
+          return getInferredType(context, i);
+        })
+      );
     }
     function makeNonFixingMapperForContext(context) {
-      return makeDeferredTypeMapper(map(context.inferences, (i) => i.typeParameter), map(context.inferences, (_, i) => () => {
-        return getInferredType(context, i);
-      }));
+      return makeDeferredTypeMapper(
+        map(context.inferences, (i) => i.typeParameter),
+        map(context.inferences, (_, i) => () => {
+          return getInferredType(context, i);
+        })
+      );
     }
     function clearCachedInferences(inferences) {
       for (const inference of inferences) {
@@ -164475,7 +148227,7 @@ ${lanes.join("\n")}
     function inferFromIntraExpressionSites(context) {
       if (context.intraExpressionInferenceSites) {
         for (const { node, type } of context.intraExpressionInferenceSites) {
-          const contextualType = node.kind === 173 /* MethodDeclaration */ ? getContextualTypeForObjectLiteralMethod(node, 2 /* NoConstraints */) : getContextualType2(node, 2 /* NoConstraints */);
+          const contextualType = node.kind === 174 /* MethodDeclaration */ ? getContextualTypeForObjectLiteralMethod(node, 2 /* NoConstraints */) : getContextualType2(node, 2 /* NoConstraints */);
           if (contextualType) {
             inferTypes(context.inferences, type, contextualType);
           }
@@ -164519,16 +148271,16 @@ ${lanes.join("\n")}
       if (objectFlags & 524288 /* CouldContainTypeVariablesComputed */) {
         return !!(objectFlags & 1048576 /* CouldContainTypeVariables */);
       }
-      const result = !!(type.flags & 465829888 /* Instantiable */ || type.flags & 524288 /* Object */ && !isNonGenericTopLevelType(type) && (objectFlags & 4 /* Reference */ && (type.node || some(getTypeArguments(type), couldContainTypeVariables)) || objectFlags & 16 /* Anonymous */ && type.symbol && type.symbol.flags & (16 /* Function */ | 8192 /* Method */ | 32 /* Class */ | 2048 /* TypeLiteral */ | 4096 /* ObjectLiteral */) && type.symbol.declarations || objectFlags & (32 /* Mapped */ | 1024 /* ReverseMapped */ | 4194304 /* ObjectRestType */ | 8388608 /* InstantiationExpressionType */)) || type.flags & (3145728 /* UnionOrIntersection */ | 134217728 /* TemplateLiteral */) && !(type.flags & 1024 /* EnumLiteral */) && !isNonGenericTopLevelType(type) && some(type.types, couldContainTypeVariables));
-      if (type.flags & 138117121 /* ObjectFlagsType */) {
+      const result = !!(type.flags & 465829888 /* Instantiable */ || type.flags & 524288 /* Object */ && !isNonGenericTopLevelType(type) && (objectFlags & 4 /* Reference */ && (type.node || some(getTypeArguments(type), couldContainTypeVariables)) || objectFlags & 16 /* Anonymous */ && type.symbol && type.symbol.flags & (16 /* Function */ | 8192 /* Method */ | 32 /* Class */ | 2048 /* TypeLiteral */ | 4096 /* ObjectLiteral */) && type.symbol.declarations || objectFlags & (32 /* Mapped */ | 1024 /* ReverseMapped */ | 4194304 /* ObjectRestType */ | 8388608 /* InstantiationExpressionType */)) || type.flags & 3145728 /* UnionOrIntersection */ && !(type.flags & 1024 /* EnumLiteral */) && !isNonGenericTopLevelType(type) && some(type.types, couldContainTypeVariables));
+      if (type.flags & 3899393 /* ObjectFlagsType */) {
         type.objectFlags |= 524288 /* CouldContainTypeVariablesComputed */ | (result ? 1048576 /* CouldContainTypeVariables */ : 0);
       }
       return result;
     }
     function isNonGenericTopLevelType(type) {
       if (type.aliasSymbol && !type.aliasTypeArguments) {
-        const declaration = getDeclarationOfKind(type.aliasSymbol, 264 /* TypeAliasDeclaration */);
-        return !!(declaration && findAncestor(declaration.parent, (n) => n.kind === 311 /* SourceFile */ ? true : n.kind === 266 /* ModuleDeclaration */ ? false : "quit"));
+        const declaration = getDeclarationOfKind(type.aliasSymbol, 265 /* TypeAliasDeclaration */);
+        return !!(declaration && findAncestor(declaration.parent, (n) => n.kind === 312 /* SourceFile */ ? true : n.kind === 267 /* ModuleDeclaration */ ? false : "quit"));
       }
       return false;
     }
@@ -164570,17 +148322,18 @@ ${lanes.join("\n")}
       );
     }
     function inferTypeForHomomorphicMappedType(source, target, constraint) {
-      if (inInferTypeForHomomorphicMappedType) {
-        return void 0;
+      const cacheKey = source.id + "," + target.id + "," + constraint.id;
+      if (reverseMappedCache.has(cacheKey)) {
+        return reverseMappedCache.get(cacheKey);
       }
-      const key = source.id + "," + target.id + "," + constraint.id;
-      if (reverseMappedCache.has(key)) {
-        return reverseMappedCache.get(key);
+      const recursionKey = source.id + "," + (target.target || target).id;
+      if (contains(homomorphicMappedTypeInferenceStack, recursionKey)) {
+        return void 0;
       }
-      inInferTypeForHomomorphicMappedType = true;
+      homomorphicMappedTypeInferenceStack.push(recursionKey);
       const type = createReverseMappedType(source, target, constraint);
-      inInferTypeForHomomorphicMappedType = false;
-      reverseMappedCache.set(key, type);
+      homomorphicMappedTypeInferenceStack.pop();
+      reverseMappedCache.set(cacheKey, type);
       return type;
     }
     function isPartiallyInferableType(type) {
@@ -164716,6 +148469,9 @@ ${lanes.join("\n")}
       if (source === target || target.flags & (1 /* Any */ | 4 /* String */)) {
         return true;
       }
+      if (target.flags & 2097152 /* Intersection */) {
+        return every(target.types, (t) => t === emptyTypeLiteralType || isValidTypeForTemplateLiteralPlaceholder(source, t));
+      }
       if (source.flags & 128 /* StringLiteral */) {
         const value = source.value;
         return !!(target.flags & 8 /* Number */ && isValidNumberString(
@@ -164726,7 +148482,7 @@ ${lanes.join("\n")}
           value,
           /*roundTripOnly*/
           false
-        ) || target.flags & (512 /* BooleanLiteral */ | 98304 /* Nullable */) && value === target.intrinsicName || target.flags & 268435456 /* StringMapping */ && isMemberOfStringMapping(getStringLiteralType(value), target));
+        ) || target.flags & (512 /* BooleanLiteral */ | 98304 /* Nullable */) && value === target.intrinsicName || target.flags & 268435456 /* StringMapping */ && isMemberOfStringMapping(getStringLiteralType(value), target) || target.flags & 134217728 /* TemplateLiteral */ && isTypeMatchedByTemplateLiteralType(source, target));
       }
       if (source.flags & 134217728 /* TemplateLiteral */) {
         const texts = source.texts;
@@ -164801,7 +148557,6 @@ ${lanes.join("\n")}
       let bivariant = false;
       let propagationType;
       let inferencePriority = 2048 /* MaxValue */;
-      let allowComplexConstraintInference = true;
       let visited;
       let sourceStack;
       let targetStack;
@@ -164811,7 +148566,7 @@ ${lanes.join("\n")}
         if (!couldContainTypeVariables(target)) {
           return;
         }
-        if (source === wildcardType) {
+        if (source === wildcardType || source === blockedStringType) {
           const savePropagationType = propagationType;
           propagationType = source;
           inferFromTypes(target, target);
@@ -164868,6 +148623,10 @@ ${lanes.join("\n")}
               return;
             }
             if (!inference.isFixed) {
+              const candidate = propagationType || source;
+              if (candidate === blockedStringType) {
+                return;
+              }
               if (inference.priority === void 0 || priority < inference.priority) {
                 inference.candidates = void 0;
                 inference.contraCandidates = void 0;
@@ -164875,7 +148634,6 @@ ${lanes.join("\n")}
                 inference.priority = priority;
               }
               if (priority === inference.priority) {
-                const candidate = propagationType || source;
                 if (contravariant && !bivariant) {
                   if (!contains(inference.contraCandidates, candidate)) {
                     inference.contraCandidates = append(inference.contraCandidates, candidate);
@@ -164956,8 +148714,7 @@ ${lanes.join("\n")}
           source = getReducedType(source);
           if (!(priority & 512 /* NoConstraints */ && source.flags & (2097152 /* Intersection */ | 465829888 /* Instantiable */))) {
             const apparentSource = getApparentType(source);
-            if (apparentSource !== source && allowComplexConstraintInference && !(apparentSource.flags & (524288 /* Object */ | 2097152 /* Intersection */))) {
-              allowComplexConstraintInference = false;
+            if (apparentSource !== source && !(apparentSource.flags & (524288 /* Object */ | 2097152 /* Intersection */))) {
               return inferFromTypes(apparentSource, target);
             }
             source = apparentSource;
@@ -165206,11 +148963,7 @@ ${lanes.join("\n")}
                   )) {
                     allTypeFlags &= ~2112 /* BigIntLike */;
                   }
-                  const matchingType = reduceLeft(
-                    constraintTypes,
-                    (left, right) => !(right.flags & allTypeFlags) ? left : left.flags & 4 /* String */ ? left : right.flags & 4 /* String */ ? source2 : left.flags & 134217728 /* TemplateLiteral */ ? left : right.flags & 134217728 /* TemplateLiteral */ && isTypeMatchedByTemplateLiteralType(source2, right) ? source2 : left.flags & 268435456 /* StringMapping */ ? left : right.flags & 268435456 /* StringMapping */ && str === applyStringMapping(right.symbol, str) ? source2 : left.flags & 128 /* StringLiteral */ ? left : right.flags & 128 /* StringLiteral */ && right.value === str ? right : left.flags & 8 /* Number */ ? left : right.flags & 8 /* Number */ ? getNumberLiteralType(+str) : left.flags & 32 /* Enum */ ? left : right.flags & 32 /* Enum */ ? getNumberLiteralType(+str) : left.flags & 256 /* NumberLiteral */ ? left : right.flags & 256 /* NumberLiteral */ && right.value === +str ? right : left.flags & 64 /* BigInt */ ? left : right.flags & 64 /* BigInt */ ? parseBigIntLiteralType(str) : left.flags & 2048 /* BigIntLiteral */ ? left : right.flags & 2048 /* BigIntLiteral */ && pseudoBigIntToString(right.value) === str ? right : left.flags & 16 /* Boolean */ ? left : right.flags & 16 /* Boolean */ ? str === "true" ? trueType : str === "false" ? falseType : booleanType : left.flags & 512 /* BooleanLiteral */ ? left : right.flags & 512 /* BooleanLiteral */ && right.intrinsicName === str ? right : left.flags & 32768 /* Undefined */ ? left : right.flags & 32768 /* Undefined */ && right.intrinsicName === str ? right : left.flags & 65536 /* Null */ ? left : right.flags & 65536 /* Null */ && right.intrinsicName === str ? right : left,
-                    neverType
-                  );
+                  const matchingType = reduceLeft(constraintTypes, (left, right) => !(right.flags & allTypeFlags) ? left : left.flags & 4 /* String */ ? left : right.flags & 4 /* String */ ? source2 : left.flags & 134217728 /* TemplateLiteral */ ? left : right.flags & 134217728 /* TemplateLiteral */ && isTypeMatchedByTemplateLiteralType(source2, right) ? source2 : left.flags & 268435456 /* StringMapping */ ? left : right.flags & 268435456 /* StringMapping */ && str === applyStringMapping(right.symbol, str) ? source2 : left.flags & 128 /* StringLiteral */ ? left : right.flags & 128 /* StringLiteral */ && right.value === str ? right : left.flags & 8 /* Number */ ? left : right.flags & 8 /* Number */ ? getNumberLiteralType(+str) : left.flags & 32 /* Enum */ ? left : right.flags & 32 /* Enum */ ? getNumberLiteralType(+str) : left.flags & 256 /* NumberLiteral */ ? left : right.flags & 256 /* NumberLiteral */ && right.value === +str ? right : left.flags & 64 /* BigInt */ ? left : right.flags & 64 /* BigInt */ ? parseBigIntLiteralType(str) : left.flags & 2048 /* BigIntLiteral */ ? left : right.flags & 2048 /* BigIntLiteral */ && pseudoBigIntToString(right.value) === str ? right : left.flags & 16 /* Boolean */ ? left : right.flags & 16 /* Boolean */ ? str === "true" ? trueType : str === "false" ? falseType : booleanType : left.flags & 512 /* BooleanLiteral */ ? left : right.flags & 512 /* BooleanLiteral */ && right.intrinsicName === str ? right : left.flags & 32768 /* Undefined */ ? left : right.flags & 32768 /* Undefined */ && right.intrinsicName === str ? right : left.flags & 65536 /* Null */ ? left : right.flags & 65536 /* Null */ && right.intrinsicName === str ? right : left, neverType);
                   if (!(matchingType.flags & 131072 /* Never */)) {
                     inferFromTypes(matchingType, target2);
                     continue;
@@ -165256,10 +149009,7 @@ ${lanes.join("\n")}
                 return;
               }
               const startLength = isTupleType(source) ? Math.min(source.target.fixedLength, target.target.fixedLength) : 0;
-              const endLength = Math.min(
-                isTupleType(source) ? getEndElementCount(source.target, 3 /* Fixed */) : 0,
-                target.target.hasRestElement ? getEndElementCount(target.target, 3 /* Fixed */) : 0
-              );
+              const endLength = Math.min(isTupleType(source) ? getEndElementCount(source.target, 3 /* Fixed */) : 0, target.target.hasRestElement ? getEndElementCount(target.target, 3 /* Fixed */) : 0);
               for (let i = 0; i < startLength; i++) {
                 inferFromTypes(getTypeArguments(source)[i], elementTypes[i]);
               }
@@ -165341,19 +149091,21 @@ ${lanes.join("\n")}
       }
       function inferFromSignatures(source, target, kind) {
         const sourceSignatures = getSignaturesOfType(source, kind);
-        const targetSignatures = getSignaturesOfType(target, kind);
         const sourceLen = sourceSignatures.length;
-        const targetLen = targetSignatures.length;
-        const len = sourceLen < targetLen ? sourceLen : targetLen;
-        for (let i = 0; i < len; i++) {
-          inferFromSignature(getBaseSignature(sourceSignatures[sourceLen - len + i]), getErasedSignature(targetSignatures[targetLen - len + i]));
+        if (sourceLen > 0) {
+          const targetSignatures = getSignaturesOfType(target, kind);
+          const targetLen = targetSignatures.length;
+          for (let i = 0; i < targetLen; i++) {
+            const sourceIndex = Math.max(sourceLen - targetLen + i, 0);
+            inferFromSignature(getBaseSignature(sourceSignatures[sourceIndex]), getErasedSignature(targetSignatures[i]));
+          }
         }
       }
       function inferFromSignature(source, target) {
         if (!(source.flags & 64 /* IsNonInferrable */)) {
           const saveBivariant = bivariant;
           const kind = target.declaration ? target.declaration.kind : 0 /* Unknown */;
-          bivariant = bivariant || kind === 173 /* MethodDeclaration */ || kind === 172 /* MethodSignature */ || kind === 175 /* Constructor */;
+          bivariant = bivariant || kind === 174 /* MethodDeclaration */ || kind === 173 /* MethodSignature */ || kind === 176 /* Constructor */;
           applyToParameterTypes(source, target, inferFromContravariantTypesIfStrictFunctionTypes);
           bivariant = saveBivariant;
         }
@@ -165511,7 +149263,7 @@ ${lanes.join("\n")}
             return Diagnostics.Cannot_find_name_0_Did_you_mean_to_write_this_in_an_async_function;
           }
         default:
-          if (node.parent.kind === 303 /* ShorthandPropertyAssignment */) {
+          if (node.parent.kind === 304 /* ShorthandPropertyAssignment */) {
             return Diagnostics.No_value_exists_in_scope_for_the_shorthand_property_0_Either_declare_one_or_provide_an_initializer;
           } else {
             return Diagnostics.Cannot_find_name_0;
@@ -165534,14 +149286,8 @@ ${lanes.join("\n")}
       }
       return links.resolvedSymbol;
     }
-    function isInTypeQuery(node) {
-      return !!findAncestor(
-        node,
-        (n) => n.kind === 185 /* TypeQuery */ ? true : n.kind === 80 /* Identifier */ || n.kind === 165 /* QualifiedName */ ? false : "quit"
-      );
-    }
     function isInAmbientOrTypeNode(node) {
-      return !!(node.flags & 16777216 /* Ambient */ || findAncestor(node, (n) => isInterfaceDeclaration(n) || isTypeAliasDeclaration(n) || isTypeLiteralNode(n)));
+      return !!(node.flags & 33554432 /* Ambient */ || findAncestor(node, (n) => isInterfaceDeclaration(n) || isTypeAliasDeclaration(n) || isTypeLiteralNode(n)));
     }
     function getFlowCacheKey(node, declaredType, initialType, flowContainer) {
       switch (node.kind) {
@@ -165552,41 +149298,41 @@ ${lanes.join("\n")}
           }
         case 110 /* ThisKeyword */:
           return `0|${flowContainer ? getNodeId(flowContainer) : "-1"}|${getTypeId(declaredType)}|${getTypeId(initialType)}`;
-        case 234 /* NonNullExpression */:
-        case 216 /* ParenthesizedExpression */:
+        case 235 /* NonNullExpression */:
+        case 217 /* ParenthesizedExpression */:
           return getFlowCacheKey(node.expression, declaredType, initialType, flowContainer);
-        case 165 /* QualifiedName */:
+        case 166 /* QualifiedName */:
           const left = getFlowCacheKey(node.left, declaredType, initialType, flowContainer);
           return left && left + "." + node.right.escapedText;
-        case 210 /* PropertyAccessExpression */:
-        case 211 /* ElementAccessExpression */:
+        case 211 /* PropertyAccessExpression */:
+        case 212 /* ElementAccessExpression */:
           const propName = getAccessedPropertyName(node);
           if (propName !== void 0) {
             const key = getFlowCacheKey(node.expression, declaredType, initialType, flowContainer);
             return key && key + "." + propName;
           }
           break;
-        case 205 /* ObjectBindingPattern */:
-        case 206 /* ArrayBindingPattern */:
-        case 261 /* FunctionDeclaration */:
-        case 217 /* FunctionExpression */:
-        case 218 /* ArrowFunction */:
-        case 173 /* MethodDeclaration */:
+        case 206 /* ObjectBindingPattern */:
+        case 207 /* ArrayBindingPattern */:
+        case 262 /* FunctionDeclaration */:
+        case 218 /* FunctionExpression */:
+        case 219 /* ArrowFunction */:
+        case 174 /* MethodDeclaration */:
           return `${getNodeId(node)}#${getTypeId(declaredType)}`;
       }
       return void 0;
     }
     function isMatchingReference(source, target) {
       switch (target.kind) {
-        case 216 /* ParenthesizedExpression */:
-        case 234 /* NonNullExpression */:
+        case 217 /* ParenthesizedExpression */:
+        case 235 /* NonNullExpression */:
           return isMatchingReference(source, target.expression);
-        case 225 /* BinaryExpression */:
+        case 226 /* BinaryExpression */:
           return isAssignmentExpression(target) && isMatchingReference(source, target.left) || isBinaryExpression(target) && target.operatorToken.kind === 28 /* CommaToken */ && isMatchingReference(source, target.right);
       }
       switch (source.kind) {
-        case 235 /* MetaProperty */:
-          return target.kind === 235 /* MetaProperty */ && source.keywordToken === target.keywordToken && source.name.escapedText === target.name.escapedText;
+        case 236 /* MetaProperty */:
+          return target.kind === 236 /* MetaProperty */ && source.keywordToken === target.keywordToken && source.name.escapedText === target.name.escapedText;
         case 80 /* Identifier */:
         case 81 /* PrivateIdentifier */:
           return isThisInTypeQuery(source) ? target.kind === 110 /* ThisKeyword */ : target.kind === 80 /* Identifier */ && getResolvedSymbol(source) === getResolvedSymbol(target) || (isVariableDeclaration(target) || isBindingElement(target)) && getExportSymbolOfValueSymbolIfExported(getResolvedSymbol(source)) === getSymbolOfDeclaration(target);
@@ -165594,17 +149340,17 @@ ${lanes.join("\n")}
           return target.kind === 110 /* ThisKeyword */;
         case 108 /* SuperKeyword */:
           return target.kind === 108 /* SuperKeyword */;
-        case 234 /* NonNullExpression */:
-        case 216 /* ParenthesizedExpression */:
+        case 235 /* NonNullExpression */:
+        case 217 /* ParenthesizedExpression */:
           return isMatchingReference(source.expression, target);
-        case 210 /* PropertyAccessExpression */:
-        case 211 /* ElementAccessExpression */:
+        case 211 /* PropertyAccessExpression */:
+        case 212 /* ElementAccessExpression */:
           const sourcePropertyName = getAccessedPropertyName(source);
           const targetPropertyName = isAccessExpression(target) ? getAccessedPropertyName(target) : void 0;
           return sourcePropertyName !== void 0 && targetPropertyName !== void 0 && targetPropertyName === sourcePropertyName && isMatchingReference(source.expression, target.expression);
-        case 165 /* QualifiedName */:
+        case 166 /* QualifiedName */:
           return isAccessExpression(target) && source.right.escapedText === getAccessedPropertyName(target) && isMatchingReference(source.left, target.expression);
-        case 225 /* BinaryExpression */:
+        case 226 /* BinaryExpression */:
           return isBinaryExpression(source) && source.operatorToken.kind === 28 /* CommaToken */ && isMatchingReference(source.right, target);
       }
       return false;
@@ -165638,7 +149384,7 @@ ${lanes.join("\n")}
         /*ignoreErrors*/
         true
       );
-      if (!symbol || !(isConstVariable(symbol) || symbol.flags & 8 /* EnumMember */))
+      if (!symbol || !(isConstantVariable(symbol) || symbol.flags & 8 /* EnumMember */))
         return void 0;
       const declaration = symbol.valueDeclaration;
       if (declaration === void 0)
@@ -165757,7 +149503,7 @@ ${lanes.join("\n")}
     }
     function getMatchingUnionConstituentForObjectLiteral(unionType, node) {
       const keyPropertyName = getKeyPropertyName(unionType);
-      const propNode = keyPropertyName && find(node.properties, (p) => p.symbol && p.kind === 302 /* PropertyAssignment */ && p.symbol.escapedName === keyPropertyName && isPossiblyDiscriminantValue(p.initializer));
+      const propNode = keyPropertyName && find(node.properties, (p) => p.symbol && p.kind === 303 /* PropertyAssignment */ && p.symbol.escapedName === keyPropertyName && isPossiblyDiscriminantValue(p.initializer));
       const propType = propNode && getContextFreeTypeOfExpression(propNode.initializer);
       return propType && getConstituentTypeForKeyType(unionType, propType);
     }
@@ -165767,12 +149513,12 @@ ${lanes.join("\n")}
     function hasMatchingArgument(expression, reference) {
       if (expression.arguments) {
         for (const argument of expression.arguments) {
-          if (isOrContainsMatchingReference(reference, argument)) {
+          if (isOrContainsMatchingReference(reference, argument) || optionalChainContainsReference(argument, reference)) {
             return true;
           }
         }
       }
-      if (expression.expression.kind === 210 /* PropertyAccessExpression */ && isOrContainsMatchingReference(reference, expression.expression.expression)) {
+      if (expression.expression.kind === 211 /* PropertyAccessExpression */ && isOrContainsMatchingReference(reference, expression.expression.expression)) {
         return true;
       }
       return false;
@@ -165814,7 +149560,13 @@ ${lanes.join("\n")}
       const resolved = resolveStructuredTypeMembers(type);
       return !!(resolved.callSignatures.length || resolved.constructSignatures.length || resolved.members.get("bind") && isTypeSubtypeOf(type, globalFunctionType));
     }
-    function getTypeFacts(type) {
+    function getTypeFacts(type, mask2) {
+      return getTypeFactsWorker(type, mask2) & mask2;
+    }
+    function hasTypeFacts(type, mask2) {
+      return getTypeFacts(type, mask2) !== 0;
+    }
+    function getTypeFactsWorker(type, callerOnlyNeeds) {
       if (type.flags & (2097152 /* Intersection */ | 465829888 /* Instantiable */)) {
         type = getBaseConstraintOfType(type) || unknownType;
       }
@@ -165847,6 +149599,10 @@ ${lanes.join("\n")}
         return strictNullChecks ? type === falseType || type === regularFalseType ? 12121864 /* FalseStrictFacts */ : 7927560 /* TrueStrictFacts */ : type === falseType || type === regularFalseType ? 12580616 /* FalseFacts */ : 16774920 /* TrueFacts */;
       }
       if (flags & 524288 /* Object */) {
+        const possibleFacts = strictNullChecks ? 83427327 /* EmptyObjectStrictFacts */ | 7880640 /* FunctionStrictFacts */ | 7888800 /* ObjectStrictFacts */ : 83886079 /* EmptyObjectFacts */ | 16728e3 /* FunctionFacts */ | 16736160 /* ObjectFacts */;
+        if ((callerOnlyNeeds & possibleFacts) === 0) {
+          return 0;
+        }
         return getObjectFlags(type) & 16 /* Anonymous */ && isEmptyObjectType(type) ? strictNullChecks ? 83427327 /* EmptyObjectStrictFacts */ : 83886079 /* EmptyObjectFacts */ : isFunctionObjectType(type) ? strictNullChecks ? 7880640 /* FunctionStrictFacts */ : 16728e3 /* FunctionFacts */ : strictNullChecks ? 7888800 /* ObjectStrictFacts */ : 16736160 /* ObjectFacts */;
       }
       if (flags & 16384 /* Void */) {
@@ -165868,20 +149624,20 @@ ${lanes.join("\n")}
         return 0 /* None */;
       }
       if (flags & 1048576 /* Union */) {
-        return reduceLeft(type.types, (facts, t) => facts | getTypeFacts(t), 0 /* None */);
+        return reduceLeft(type.types, (facts, t) => facts | getTypeFactsWorker(t, callerOnlyNeeds), 0 /* None */);
       }
       if (flags & 2097152 /* Intersection */) {
-        return getIntersectionTypeFacts(type);
+        return getIntersectionTypeFacts(type, callerOnlyNeeds);
       }
       return 83886079 /* UnknownFacts */;
     }
-    function getIntersectionTypeFacts(type) {
+    function getIntersectionTypeFacts(type, callerOnlyNeeds) {
       const ignoreObjects = maybeTypeOfKind(type, 402784252 /* Primitive */);
       let oredFacts = 0 /* None */;
       let andedFacts = 134217727 /* All */;
       for (const t of type.types) {
         if (!(ignoreObjects && t.flags & 524288 /* Object */)) {
-          const f = getTypeFacts(t);
+          const f = getTypeFactsWorker(t, callerOnlyNeeds);
           oredFacts |= f;
           andedFacts &= f;
         }
@@ -165889,19 +149645,19 @@ ${lanes.join("\n")}
       return oredFacts & 8256 /* OrFactsMask */ | andedFacts & 134209471 /* AndFactsMask */;
     }
     function getTypeWithFacts(type, include) {
-      return filterType(type, (t) => (getTypeFacts(t) & include) !== 0);
+      return filterType(type, (t) => hasTypeFacts(t, include));
     }
     function getAdjustedTypeWithFacts(type, facts) {
       const reduced = recombineUnknownType(getTypeWithFacts(strictNullChecks && type.flags & 2 /* Unknown */ ? unknownUnionType : type, facts));
       if (strictNullChecks) {
         switch (facts) {
           case 524288 /* NEUndefined */:
-            return mapType(reduced, (t) => getTypeFacts(t) & 65536 /* EQUndefined */ ? getIntersectionType([t, getTypeFacts(t) & 131072 /* EQNull */ && !maybeTypeOfKind(reduced, 65536 /* Null */) ? getUnionType([emptyObjectType, nullType]) : emptyObjectType]) : t);
+            return mapType(reduced, (t) => hasTypeFacts(t, 65536 /* EQUndefined */) ? getIntersectionType([t, hasTypeFacts(t, 131072 /* EQNull */) && !maybeTypeOfKind(reduced, 65536 /* Null */) ? getUnionType([emptyObjectType, nullType]) : emptyObjectType]) : t);
           case 1048576 /* NENull */:
-            return mapType(reduced, (t) => getTypeFacts(t) & 131072 /* EQNull */ ? getIntersectionType([t, getTypeFacts(t) & 65536 /* EQUndefined */ && !maybeTypeOfKind(reduced, 32768 /* Undefined */) ? getUnionType([emptyObjectType, undefinedType]) : emptyObjectType]) : t);
+            return mapType(reduced, (t) => hasTypeFacts(t, 131072 /* EQNull */) ? getIntersectionType([t, hasTypeFacts(t, 65536 /* EQUndefined */) && !maybeTypeOfKind(reduced, 32768 /* Undefined */) ? getUnionType([emptyObjectType, undefinedType]) : emptyObjectType]) : t);
           case 2097152 /* NEUndefinedOrNull */:
           case 4194304 /* Truthy */:
-            return mapType(reduced, (t) => getTypeFacts(t) & 262144 /* EQUndefinedOrNull */ ? getGlobalNonNullableTypeInstantiation(t) : t);
+            return mapType(reduced, (t) => hasTypeFacts(t, 262144 /* EQUndefinedOrNull */) ? getGlobalNonNullableTypeInstantiation(t) : t);
         }
       }
       return reduced;
@@ -165944,11 +149700,11 @@ ${lanes.join("\n")}
       ) || errorType);
     }
     function getAssignedTypeOfBinaryExpression(node) {
-      const isDestructuringDefaultAssignment = node.parent.kind === 208 /* ArrayLiteralExpression */ && isDestructuringAssignmentTarget(node.parent) || node.parent.kind === 302 /* PropertyAssignment */ && isDestructuringAssignmentTarget(node.parent.parent);
+      const isDestructuringDefaultAssignment = node.parent.kind === 209 /* ArrayLiteralExpression */ && isDestructuringAssignmentTarget(node.parent) || node.parent.kind === 303 /* PropertyAssignment */ && isDestructuringAssignmentTarget(node.parent.parent);
       return isDestructuringDefaultAssignment ? getTypeWithDefault(getAssignedType(node), node.right) : getTypeOfExpression(node.right);
     }
     function isDestructuringAssignmentTarget(parent2) {
-      return parent2.parent.kind === 225 /* BinaryExpression */ && parent2.parent.left === parent2 || parent2.parent.kind === 249 /* ForOfStatement */ && parent2.parent.initializer === parent2;
+      return parent2.parent.kind === 226 /* BinaryExpression */ && parent2.parent.left === parent2 || parent2.parent.kind === 250 /* ForOfStatement */ && parent2.parent.initializer === parent2;
     }
     function getAssignedTypeOfArrayLiteralElement(node, element) {
       return getTypeOfDestructuredArrayElement(getAssignedType(node), node.elements.indexOf(element));
@@ -165965,21 +149721,21 @@ ${lanes.join("\n")}
     function getAssignedType(node) {
       const { parent: parent2 } = node;
       switch (parent2.kind) {
-        case 248 /* ForInStatement */:
+        case 249 /* ForInStatement */:
           return stringType;
-        case 249 /* ForOfStatement */:
+        case 250 /* ForOfStatement */:
           return checkRightHandSideOfForOf(parent2) || errorType;
-        case 225 /* BinaryExpression */:
+        case 226 /* BinaryExpression */:
           return getAssignedTypeOfBinaryExpression(parent2);
-        case 219 /* DeleteExpression */:
+        case 220 /* DeleteExpression */:
           return undefinedType;
-        case 208 /* ArrayLiteralExpression */:
+        case 209 /* ArrayLiteralExpression */:
           return getAssignedTypeOfArrayLiteralElement(parent2, node);
-        case 229 /* SpreadElement */:
+        case 230 /* SpreadElement */:
           return getAssignedTypeOfSpreadExpression(parent2);
-        case 302 /* PropertyAssignment */:
+        case 303 /* PropertyAssignment */:
           return getAssignedTypeOfPropertyAssignment(parent2);
-        case 303 /* ShorthandPropertyAssignment */:
+        case 304 /* ShorthandPropertyAssignment */:
           return getAssignedTypeOfShorthandPropertyAssignment(parent2);
       }
       return errorType;
@@ -165987,7 +149743,7 @@ ${lanes.join("\n")}
     function getInitialTypeOfBindingElement(node) {
       const pattern = node.parent;
       const parentType = getInitialType(pattern.parent);
-      const type = pattern.kind === 205 /* ObjectBindingPattern */ ? getTypeOfDestructuredProperty(parentType, node.propertyName || node.name) : !node.dotDotDotToken ? getTypeOfDestructuredArrayElement(parentType, pattern.elements.indexOf(node)) : getTypeOfDestructuredSpreadExpression(parentType);
+      const type = pattern.kind === 206 /* ObjectBindingPattern */ ? getTypeOfDestructuredProperty(parentType, node.propertyName || node.name) : !node.dotDotDotToken ? getTypeOfDestructuredArrayElement(parentType, pattern.elements.indexOf(node)) : getTypeOfDestructuredSpreadExpression(parentType);
       return getTypeWithDefault(type, node.initializer);
     }
     function getTypeOfInitializer(node) {
@@ -165998,25 +149754,25 @@ ${lanes.join("\n")}
       if (node.initializer) {
         return getTypeOfInitializer(node.initializer);
       }
-      if (node.parent.parent.kind === 248 /* ForInStatement */) {
+      if (node.parent.parent.kind === 249 /* ForInStatement */) {
         return stringType;
       }
-      if (node.parent.parent.kind === 249 /* ForOfStatement */) {
+      if (node.parent.parent.kind === 250 /* ForOfStatement */) {
         return checkRightHandSideOfForOf(node.parent.parent) || errorType;
       }
       return errorType;
     }
     function getInitialType(node) {
-      return node.kind === 259 /* VariableDeclaration */ ? getInitialTypeOfVariableDeclaration(node) : getInitialTypeOfBindingElement(node);
+      return node.kind === 260 /* VariableDeclaration */ ? getInitialTypeOfVariableDeclaration(node) : getInitialTypeOfBindingElement(node);
     }
     function isEmptyArrayAssignment(node) {
-      return node.kind === 259 /* VariableDeclaration */ && node.initializer && isEmptyArrayLiteral2(node.initializer) || node.kind !== 207 /* BindingElement */ && node.parent.kind === 225 /* BinaryExpression */ && isEmptyArrayLiteral2(node.parent.right);
+      return node.kind === 260 /* VariableDeclaration */ && node.initializer && isEmptyArrayLiteral2(node.initializer) || node.kind !== 208 /* BindingElement */ && node.parent.kind === 226 /* BinaryExpression */ && isEmptyArrayLiteral2(node.parent.right);
     }
     function getReferenceCandidate(node) {
       switch (node.kind) {
-        case 216 /* ParenthesizedExpression */:
+        case 217 /* ParenthesizedExpression */:
           return getReferenceCandidate(node.expression);
-        case 225 /* BinaryExpression */:
+        case 226 /* BinaryExpression */:
           switch (node.operatorToken.kind) {
             case 64 /* EqualsToken */:
             case 76 /* BarBarEqualsToken */:
@@ -166031,10 +149787,10 @@ ${lanes.join("\n")}
     }
     function getReferenceRoot(node) {
       const { parent: parent2 } = node;
-      return parent2.kind === 216 /* ParenthesizedExpression */ || parent2.kind === 225 /* BinaryExpression */ && parent2.operatorToken.kind === 64 /* EqualsToken */ && parent2.left === node || parent2.kind === 225 /* BinaryExpression */ && parent2.operatorToken.kind === 28 /* CommaToken */ && parent2.right === node ? getReferenceRoot(parent2) : node;
+      return parent2.kind === 217 /* ParenthesizedExpression */ || parent2.kind === 226 /* BinaryExpression */ && parent2.operatorToken.kind === 64 /* EqualsToken */ && parent2.left === node || parent2.kind === 226 /* BinaryExpression */ && parent2.operatorToken.kind === 28 /* CommaToken */ && parent2.right === node ? getReferenceRoot(parent2) : node;
     }
     function getTypeOfSwitchClause(clause) {
-      if (clause.kind === 295 /* CaseClause */) {
+      if (clause.kind === 296 /* CaseClause */) {
         return getRegularTypeOfLiteralType(getTypeOfExpression(clause.expression));
       }
       return neverType;
@@ -166050,12 +149806,12 @@ ${lanes.join("\n")}
       return links.switchTypes;
     }
     function getSwitchClauseTypeOfWitnesses(switchStatement) {
-      if (some(switchStatement.caseBlock.clauses, (clause) => clause.kind === 295 /* CaseClause */ && !isStringLiteralLike(clause.expression))) {
+      if (some(switchStatement.caseBlock.clauses, (clause) => clause.kind === 296 /* CaseClause */ && !isStringLiteralLike(clause.expression))) {
         return void 0;
       }
       const witnesses = [];
       for (const clause of switchStatement.caseBlock.clauses) {
-        const text = clause.kind === 295 /* CaseClause */ ? clause.expression.text : void 0;
+        const text = clause.kind === 296 /* CaseClause */ ? clause.expression.text : void 0;
         witnesses.push(text && !contains(witnesses, text) ? text : void 0);
       }
       return witnesses;
@@ -166187,7 +149943,9 @@ ${lanes.join("\n")}
       return isTypeSubsetOf(elementType, evolvingArrayType.elementType) ? evolvingArrayType : getEvolvingArrayType(getUnionType([evolvingArrayType.elementType, elementType]));
     }
     function createFinalArrayType(elementType) {
-      return elementType.flags & 131072 /* Never */ ? autoArrayType : createArrayType(elementType.flags & 1048576 /* Union */ ? getUnionType(elementType.types, 2 /* Subtype */) : elementType);
+      return elementType.flags & 131072 /* Never */ ? autoArrayType : createArrayType(
+        elementType.flags & 1048576 /* Union */ ? getUnionType(elementType.types, 2 /* Subtype */) : elementType
+      );
     }
     function getFinalArrayType(evolvingArrayType) {
       return evolvingArrayType.finalArrayType || (evolvingArrayType.finalArrayType = createFinalArrayType(evolvingArrayType.elementType));
@@ -166213,8 +149971,8 @@ ${lanes.join("\n")}
     function isEvolvingArrayOperationTarget(node) {
       const root = getReferenceRoot(node);
       const parent2 = root.parent;
-      const isLengthPushOrUnshift = isPropertyAccessExpression(parent2) && (parent2.name.escapedText === "length" || parent2.parent.kind === 212 /* CallExpression */ && isIdentifier(parent2.name) && isPushOrUnshiftIdentifier(parent2.name));
-      const isElementAssignment = parent2.kind === 211 /* ElementAccessExpression */ && parent2.expression === root && parent2.parent.kind === 225 /* BinaryExpression */ && parent2.parent.operatorToken.kind === 64 /* EqualsToken */ && parent2.parent.left === parent2 && !isAssignmentTarget(parent2.parent) && isTypeAssignableToKind(getTypeOfExpression(parent2.argumentExpression), 296 /* NumberLike */);
+      const isLengthPushOrUnshift = isPropertyAccessExpression(parent2) && (parent2.name.escapedText === "length" || parent2.parent.kind === 213 /* CallExpression */ && isIdentifier(parent2.name) && isPushOrUnshiftIdentifier(parent2.name));
+      const isElementAssignment = parent2.kind === 212 /* ElementAccessExpression */ && parent2.expression === root && parent2.parent.kind === 226 /* BinaryExpression */ && parent2.parent.operatorToken.kind === 64 /* EqualsToken */ && parent2.parent.left === parent2 && !isAssignmentTarget(parent2.parent) && isTypeAssignableToKind(getTypeOfExpression(parent2.argumentExpression), 296 /* NumberLike */);
       return isLengthPushOrUnshift || isElementAssignment;
     }
     function isDeclarationWithExplicitTypeAnnotation(node) {
@@ -166237,7 +149995,7 @@ ${lanes.join("\n")}
           if (isDeclarationWithExplicitTypeAnnotation(declaration)) {
             return getTypeOfSymbol(symbol);
           }
-          if (isVariableDeclaration(declaration) && declaration.parent.parent.kind === 249 /* ForOfStatement */) {
+          if (isVariableDeclaration(declaration) && declaration.parent.parent.kind === 250 /* ForOfStatement */) {
             const statement = declaration.parent.parent;
             const expressionType = getTypeOfDottedName(
               statement.expression,
@@ -166262,7 +150020,7 @@ ${lanes.join("\n")}
       }
     }
     function getTypeOfDottedName(node, diagnostic) {
-      if (!(node.flags & 33554432 /* InWithStatement */)) {
+      if (!(node.flags & 67108864 /* InWithStatement */)) {
         switch (node.kind) {
           case 80 /* Identifier */:
             const symbol = getExportSymbolOfValueSymbolIfExported(getResolvedSymbol(node));
@@ -166271,7 +150029,7 @@ ${lanes.join("\n")}
             return getExplicitThisType(node);
           case 108 /* SuperKeyword */:
             return checkSuperExpression(node);
-          case 210 /* PropertyAccessExpression */: {
+          case 211 /* PropertyAccessExpression */: {
             const type = getTypeOfDottedName(node.expression, diagnostic);
             if (type) {
               const name = node.name;
@@ -166288,7 +150046,7 @@ ${lanes.join("\n")}
             }
             return void 0;
           }
-          case 216 /* ParenthesizedExpression */:
+          case 217 /* ParenthesizedExpression */:
             return getTypeOfDottedName(node.expression, diagnostic);
         }
       }
@@ -166298,7 +150056,10 @@ ${lanes.join("\n")}
       let signature = links.effectsSignature;
       if (signature === void 0) {
         let funcType;
-        if (node.parent.kind === 243 /* ExpressionStatement */) {
+        if (isBinaryExpression(node)) {
+          const rightType = checkNonNullExpression(node.right);
+          funcType = getSymbolHasInstanceMethodOfObjectType(rightType);
+        } else if (node.parent.kind === 244 /* ExpressionStatement */) {
           funcType = getTypeOfDottedName(
             node.expression,
             /*diagnostic*/
@@ -166352,7 +150113,7 @@ ${lanes.join("\n")}
         /*excludeJSDocTypeAssertions*/
         true
       );
-      return node.kind === 97 /* FalseKeyword */ || node.kind === 225 /* BinaryExpression */ && (node.operatorToken.kind === 56 /* AmpersandAmpersandToken */ && (isFalseExpression(node.left) || isFalseExpression(node.right)) || node.operatorToken.kind === 57 /* BarBarToken */ && isFalseExpression(node.left) && isFalseExpression(node.right));
+      return node.kind === 97 /* FalseKeyword */ || node.kind === 226 /* BinaryExpression */ && (node.operatorToken.kind === 56 /* AmpersandAmpersandToken */ && (isFalseExpression(node.left) || isFalseExpression(node.right)) || node.operatorToken.kind === 57 /* BarBarToken */ && isFalseExpression(node.left) && isFalseExpression(node.right));
     }
     function isReachableFlowNodeWorker(flow, noCacheCheck) {
       while (true) {
@@ -166471,14 +150232,16 @@ ${lanes.join("\n")}
     }
     function isConstantReference(node) {
       switch (node.kind) {
+        case 110 /* ThisKeyword */:
+          return true;
         case 80 /* Identifier */:
           if (!isThisInTypeQuery(node)) {
             const symbol = getResolvedSymbol(node);
-            return isConstVariable(symbol) || isParameterOrCatchClauseVariable(symbol) && !isSymbolAssigned(symbol);
+            return isConstantVariable(symbol) || isParameterOrCatchClauseVariable(symbol) && !isSymbolAssigned(symbol);
           }
           break;
-        case 210 /* PropertyAccessExpression */:
-        case 211 /* ElementAccessExpression */:
+        case 211 /* PropertyAccessExpression */:
+        case 212 /* ElementAccessExpression */:
           return isConstantReference(node.expression) && isReadonlySymbol(getNodeLinks(node).resolvedSymbol || unknownSymbol);
       }
       return false;
@@ -166498,7 +150261,7 @@ ${lanes.join("\n")}
       const evolvedType = getTypeFromFlowType(getTypeAtFlowNode(flowNode));
       sharedFlowCount = sharedFlowStart;
       const resultType = getObjectFlags(evolvedType) & 256 /* EvolvingArray */ && isEvolvingArrayOperationTarget(reference) ? autoArrayType : finalizeEvolvingArrayType(evolvedType);
-      if (resultType === unreachableNeverType || reference.parent && reference.parent.kind === 234 /* NonNullExpression */ && !(resultType.flags & 131072 /* Never */) && getTypeWithFacts(resultType, 2097152 /* NEUndefinedOrNull */).flags & 131072 /* Never */) {
+      if (resultType === unreachableNeverType || reference.parent && reference.parent.kind === 235 /* NonNullExpression */ && !(resultType.flags & 131072 /* Never */) && getTypeWithFacts(resultType, 2097152 /* NEUndefinedOrNull */).flags & 131072 /* Never */) {
         return declaredType;
       }
       return resultType === nonNullUnknownType ? unknownType : resultType;
@@ -166567,7 +150330,7 @@ ${lanes.join("\n")}
             target.antecedents = saveAntecedents;
           } else if (flags & 2 /* Start */) {
             const container = flow.node;
-            if (container && container !== flowContainer && reference.kind !== 210 /* PropertyAccessExpression */ && reference.kind !== 211 /* ElementAccessExpression */ && reference.kind !== 110 /* ThisKeyword */) {
+            if (container && container !== flowContainer && reference.kind !== 211 /* PropertyAccessExpression */ && reference.kind !== 212 /* ElementAccessExpression */ && !(reference.kind === 110 /* ThisKeyword */ && container.kind !== 219 /* ArrowFunction */)) {
               flow = container.flowNode;
               continue;
             }
@@ -166586,7 +150349,10 @@ ${lanes.join("\n")}
       }
       function getInitialOrAssignedType(flow) {
         const node = flow.node;
-        return getNarrowableTypeForReference(node.kind === 259 /* VariableDeclaration */ || node.kind === 207 /* BindingElement */ ? getInitialType(node) : getAssignedType(node), reference);
+        return getNarrowableTypeForReference(
+          node.kind === 260 /* VariableDeclaration */ || node.kind === 208 /* BindingElement */ ? getInitialType(node) : getAssignedType(node),
+          reference
+        );
       }
       function getTypeAtFlowAssignment(flow) {
         const node = flow.node;
@@ -166605,24 +150371,25 @@ ${lanes.join("\n")}
             const assignedType = getWidenedLiteralType(getInitialOrAssignedType(flow));
             return isTypeAssignableTo(assignedType, declaredType) ? assignedType : anyArrayType;
           }
-          if (declaredType.flags & 1048576 /* Union */) {
-            return getAssignmentReducedType(declaredType, getInitialOrAssignedType(flow));
+          const t = isInCompoundLikeAssignment(node) ? getBaseTypeOfLiteralType(declaredType) : declaredType;
+          if (t.flags & 1048576 /* Union */) {
+            return getAssignmentReducedType(t, getInitialOrAssignedType(flow));
           }
-          return declaredType;
+          return t;
         }
         if (containsMatchingReference(reference, node)) {
           if (!isReachableFlowNode(flow)) {
             return unreachableNeverType;
           }
-          if (isVariableDeclaration(node) && (isInJSFile(node) || isVarConst(node))) {
+          if (isVariableDeclaration(node) && (isInJSFile(node) || isVarConstLike(node))) {
             const init = getDeclaredExpandoInitializer(node);
-            if (init && (init.kind === 217 /* FunctionExpression */ || init.kind === 218 /* ArrowFunction */)) {
+            if (init && (init.kind === 218 /* FunctionExpression */ || init.kind === 219 /* ArrowFunction */)) {
               return getTypeAtFlowNode(flow.antecedent);
             }
           }
           return declaredType;
         }
-        if (isVariableDeclaration(node) && node.parent.parent.kind === 248 /* ForInStatement */ && (isMatchingReference(reference, node.parent.parent.expression) || optionalChainContainsReference(node.parent.parent.expression, reference))) {
+        if (isVariableDeclaration(node) && node.parent.parent.kind === 249 /* ForInStatement */ && (isMatchingReference(reference, node.parent.parent.expression) || optionalChainContainsReference(node.parent.parent.expression, reference))) {
           return getNonNullableTypeIfNeeded(finalizeEvolvingArrayType(getTypeFromFlowType(getTypeAtFlowNode(flow.antecedent))));
         }
         return void 0;
@@ -166636,7 +150403,7 @@ ${lanes.join("\n")}
         if (node.kind === 97 /* FalseKeyword */) {
           return unreachableNeverType;
         }
-        if (node.kind === 225 /* BinaryExpression */) {
+        if (node.kind === 226 /* BinaryExpression */) {
           if (node.operatorToken.kind === 56 /* AmpersandAmpersandToken */) {
             return narrowTypeByAssertion(narrowTypeByAssertion(type, node.left), node.right);
           }
@@ -166676,13 +150443,13 @@ ${lanes.join("\n")}
       function getTypeAtFlowArrayMutation(flow) {
         if (declaredType === autoType || declaredType === autoArrayType) {
           const node = flow.node;
-          const expr = node.kind === 212 /* CallExpression */ ? node.expression.expression : node.left.expression;
+          const expr = node.kind === 213 /* CallExpression */ ? node.expression.expression : node.left.expression;
           if (isMatchingReference(reference, getReferenceCandidate(expr))) {
             const flowType = getTypeAtFlowNode(flow.antecedent);
             const type = getTypeFromFlowType(flowType);
             if (getObjectFlags(type) & 256 /* EvolvingArray */) {
               let evolvedType2 = type;
-              if (node.kind === 212 /* CallExpression */) {
+              if (node.kind === 213 /* CallExpression */) {
                 for (const arg of node.arguments) {
                   evolvedType2 = addEvolvingArrayElementType(evolvedType2, arg);
                 }
@@ -166714,31 +150481,21 @@ ${lanes.join("\n")}
         return createFlowType(narrowedType, isIncomplete(flowType));
       }
       function getTypeAtSwitchClause(flow) {
-        const expr = flow.switchStatement.expression;
+        const expr = skipParentheses(flow.switchStatement.expression);
         const flowType = getTypeAtFlowNode(flow.antecedent);
         let type = getTypeFromFlowType(flowType);
         if (isMatchingReference(reference, expr)) {
           type = narrowTypeBySwitchOnDiscriminant(type, flow.switchStatement, flow.clauseStart, flow.clauseEnd);
-        } else if (expr.kind === 220 /* TypeOfExpression */ && isMatchingReference(reference, expr.expression)) {
+        } else if (expr.kind === 221 /* TypeOfExpression */ && isMatchingReference(reference, expr.expression)) {
           type = narrowTypeBySwitchOnTypeOf(type, flow.switchStatement, flow.clauseStart, flow.clauseEnd);
+        } else if (expr.kind === 112 /* TrueKeyword */) {
+          type = narrowTypeBySwitchOnTrue(type, flow.switchStatement, flow.clauseStart, flow.clauseEnd);
         } else {
           if (strictNullChecks) {
             if (optionalChainContainsReference(expr, reference)) {
-              type = narrowTypeBySwitchOptionalChainContainment(
-                type,
-                flow.switchStatement,
-                flow.clauseStart,
-                flow.clauseEnd,
-                (t) => !(t.flags & (32768 /* Undefined */ | 131072 /* Never */))
-              );
-            } else if (expr.kind === 220 /* TypeOfExpression */ && optionalChainContainsReference(expr.expression, reference)) {
-              type = narrowTypeBySwitchOptionalChainContainment(
-                type,
-                flow.switchStatement,
-                flow.clauseStart,
-                flow.clauseEnd,
-                (t) => !(t.flags & 131072 /* Never */ || t.flags & 128 /* StringLiteral */ && t.value === "undefined")
-              );
+              type = narrowTypeBySwitchOptionalChainContainment(type, flow.switchStatement, flow.clauseStart, flow.clauseEnd, (t) => !(t.flags & (32768 /* Undefined */ | 131072 /* Never */)));
+            } else if (expr.kind === 221 /* TypeOfExpression */ && optionalChainContainsReference(expr.expression, reference)) {
+              type = narrowTypeBySwitchOptionalChainContainment(type, flow.switchStatement, flow.clauseStart, flow.clauseEnd, (t) => !(t.flags & 131072 /* Never */ || t.flags & 128 /* StringLiteral */ && t.value === "undefined"));
             }
           }
           const access = getDiscriminantPropertyAccess(expr, type);
@@ -166876,7 +150633,7 @@ ${lanes.join("\n")}
           }
         } else if (isIdentifier(expr)) {
           const symbol = getResolvedSymbol(expr);
-          if (isConstVariable(symbol)) {
+          if (isConstantVariable(symbol)) {
             const declaration = symbol.valueDeclaration;
             if (isVariableDeclaration(declaration) && !declaration.type && declaration.initializer && isAccessExpression(declaration.initializer) && isMatchingReference(reference, declaration.initializer.expression)) {
               return declaration.initializer;
@@ -166892,13 +150649,15 @@ ${lanes.join("\n")}
         return void 0;
       }
       function getDiscriminantPropertyAccess(expr, computedType) {
-        const type = declaredType.flags & 1048576 /* Union */ ? declaredType : computedType;
-        if (type.flags & 1048576 /* Union */) {
+        if (declaredType.flags & 1048576 /* Union */ || computedType.flags & 1048576 /* Union */) {
           const access = getCandidateDiscriminantPropertyAccess(expr);
           if (access) {
             const name = getAccessedPropertyName(access);
-            if (name && isDiscriminantProperty(type, name)) {
-              return access;
+            if (name) {
+              const type = declaredType.flags & 1048576 /* Union */ && isTypeSubsetOf(computedType, declaredType) ? declaredType : computedType;
+              if (isDiscriminantProperty(type, name)) {
+                return access;
+              }
             }
           }
         }
@@ -166918,7 +150677,7 @@ ${lanes.join("\n")}
         propType = removeNullable && optionalChain ? getOptionalType(propType) : propType;
         const narrowedPropType = narrowType2(propType);
         return filterType(type, (t) => {
-          const discriminantType = getTypeOfPropertyOrIndexSignature(t, propName);
+          const discriminantType = getTypeOfPropertyOrIndexSignatureOfType(t, propName) || unknownType;
           return !(discriminantType.flags & 131072 /* Never */) && !(narrowedPropType.flags & 131072 /* Never */) && areTypesComparable(narrowedPropType, discriminantType);
         });
       }
@@ -166980,6 +150739,10 @@ ${lanes.join("\n")}
         }
         return type;
       }
+      function narrowTypeByBooleanComparison(type, expr, bool, operator, assumeTrue) {
+        assumeTrue = assumeTrue !== (bool.kind === 112 /* TrueKeyword */) !== (operator !== 38 /* ExclamationEqualsEqualsToken */ && operator !== 36 /* ExclamationEqualsToken */);
+        return narrowType(type, expr, assumeTrue);
+      }
       function narrowTypeByBinaryExpression(type, expr, assumeTrue) {
         switch (expr.operatorToken.kind) {
           case 64 /* EqualsToken */:
@@ -166994,10 +150757,10 @@ ${lanes.join("\n")}
             const operator = expr.operatorToken.kind;
             const left = getReferenceCandidate(expr.left);
             const right = getReferenceCandidate(expr.right);
-            if (left.kind === 220 /* TypeOfExpression */ && isStringLiteralLike(right)) {
+            if (left.kind === 221 /* TypeOfExpression */ && isStringLiteralLike(right)) {
               return narrowTypeByTypeof(type, left, operator, right, assumeTrue);
             }
-            if (right.kind === 220 /* TypeOfExpression */ && isStringLiteralLike(left)) {
+            if (right.kind === 221 /* TypeOfExpression */ && isStringLiteralLike(left)) {
               return narrowTypeByTypeof(type, right, operator, left, assumeTrue);
             }
             if (isMatchingReference(reference, left)) {
@@ -167027,6 +150790,12 @@ ${lanes.join("\n")}
             if (isMatchingConstructorReference(right)) {
               return narrowTypeByConstructor(type, operator, left, assumeTrue);
             }
+            if (isBooleanLiteral(right) && !isAccessExpression(left)) {
+              return narrowTypeByBooleanComparison(type, left, right, operator, assumeTrue);
+            }
+            if (isBooleanLiteral(left) && !isAccessExpression(right)) {
+              return narrowTypeByBooleanComparison(type, right, left, operator, assumeTrue);
+            }
             break;
           case 104 /* InstanceOfKeyword */:
             return narrowTypeByInstanceof(type, expr, assumeTrue);
@@ -167035,12 +150804,15 @@ ${lanes.join("\n")}
               return narrowTypeByPrivateIdentifierInInExpression(type, expr, assumeTrue);
             }
             const target = getReferenceCandidate(expr.right);
-            const leftType = getTypeOfExpression(expr.left);
-            if (leftType.flags & 8576 /* StringOrNumberLiteralOrUnique */) {
-              if (containsMissingType(type) && isAccessExpression(reference) && isMatchingReference(reference.expression, target) && getAccessedPropertyName(reference) === getPropertyNameFromType(leftType)) {
+            if (containsMissingType(type) && isAccessExpression(reference) && isMatchingReference(reference.expression, target)) {
+              const leftType = getTypeOfExpression(expr.left);
+              if (isTypeUsableAsPropertyName(leftType) && getAccessedPropertyName(reference) === getPropertyNameFromType(leftType)) {
                 return getTypeWithFacts(type, assumeTrue ? 524288 /* NEUndefined */ : 65536 /* EQUndefined */);
               }
-              if (isMatchingReference(reference, target)) {
+            }
+            if (isMatchingReference(reference, target)) {
+              const leftType = getTypeOfExpression(expr.left);
+              if (isTypeUsableAsPropertyName(leftType)) {
                 return narrowTypeByInKeyword(type, leftType, assumeTrue);
               }
             }
@@ -167239,14 +151011,14 @@ ${lanes.join("\n")}
           // the constituent based on its type facts. We use the strict subtype relation because it treats `object`
           // as a subtype of `{}`, and we need the type facts check because function types are subtypes of `object`,
           // but are classified as "function" according to `typeof`.
-          isTypeRelatedTo(t, impliedType, strictSubtypeRelation) ? getTypeFacts(t) & facts ? t : neverType : (
+          isTypeRelatedTo(t, impliedType, strictSubtypeRelation) ? hasTypeFacts(t, facts) ? t : neverType : (
             // We next check if the consituent is a supertype of the implied type. If so, we substitute the implied
             // type. This handles top types like `unknown` and `{}`, and supertypes like `{ toString(): string }`.
             isTypeSubtypeOf(impliedType, t) ? impliedType : (
               // Neither the constituent nor the implied type is a subtype of the other, however their domains may still
               // overlap. For example, an unconstrained type parameter and type `string`. If the type facts indicate
               // possible overlap, we form an intersection. Otherwise, we eliminate the constituent.
-              getTypeFacts(t) & facts ? getIntersectionType([t, impliedType]) : neverType
+              hasTypeFacts(t, facts) ? getIntersectionType([t, impliedType]) : neverType
             )
           )
         ));
@@ -167256,15 +151028,51 @@ ${lanes.join("\n")}
         if (!witnesses) {
           return type;
         }
-        const defaultIndex = findIndex(switchStatement.caseBlock.clauses, (clause) => clause.kind === 296 /* DefaultClause */);
+        const defaultIndex = findIndex(switchStatement.caseBlock.clauses, (clause) => clause.kind === 297 /* DefaultClause */);
         const hasDefaultClause = clauseStart === clauseEnd || defaultIndex >= clauseStart && defaultIndex < clauseEnd;
         if (hasDefaultClause) {
           const notEqualFacts = getNotEqualFactsFromTypeofSwitch(clauseStart, clauseEnd, witnesses);
-          return filterType(type, (t) => (getTypeFacts(t) & notEqualFacts) === notEqualFacts);
+          return filterType(type, (t) => getTypeFacts(t, notEqualFacts) === notEqualFacts);
         }
         const clauseWitnesses = witnesses.slice(clauseStart, clauseEnd);
         return getUnionType(map(clauseWitnesses, (text) => text ? narrowTypeByTypeName(type, text) : neverType));
       }
+      function narrowTypeBySwitchOnTrue(type, switchStatement, clauseStart, clauseEnd) {
+        const defaultIndex = findIndex(switchStatement.caseBlock.clauses, (clause) => clause.kind === 297 /* DefaultClause */);
+        const hasDefaultClause = clauseStart === clauseEnd || defaultIndex >= clauseStart && defaultIndex < clauseEnd;
+        for (let i = 0; i < clauseStart; i++) {
+          const clause = switchStatement.caseBlock.clauses[i];
+          if (clause.kind === 296 /* CaseClause */) {
+            type = narrowType(
+              type,
+              clause.expression,
+              /*assumeTrue*/
+              false
+            );
+          }
+        }
+        if (hasDefaultClause) {
+          for (let i = clauseEnd; i < switchStatement.caseBlock.clauses.length; i++) {
+            const clause = switchStatement.caseBlock.clauses[i];
+            if (clause.kind === 296 /* CaseClause */) {
+              type = narrowType(
+                type,
+                clause.expression,
+                /*assumeTrue*/
+                false
+              );
+            }
+          }
+          return type;
+        }
+        const clauses = switchStatement.caseBlock.clauses.slice(clauseStart, clauseEnd);
+        return getUnionType(map(clauses, (clause) => clause.kind === 296 /* CaseClause */ ? narrowType(
+          type,
+          clause.expression,
+          /*assumeTrue*/
+          true
+        ) : neverType));
+      }
       function isMatchingConstructorReference(expr) {
         return (isPropertyAccessExpression(expr) && idText(expr.name) === "constructor" || isElementAccessExpression(expr) && isStringLiteralLike(expr.argumentExpression) && expr.argumentExpression.text === "constructor") && isMatchingReference(reference, expr.expression);
       }
@@ -167304,7 +151112,22 @@ ${lanes.join("\n")}
           }
           return type;
         }
-        const rightType = getTypeOfExpression(expr.right);
+        const right = expr.right;
+        const rightType = getTypeOfExpression(right);
+        if (!isTypeDerivedFrom(rightType, globalObjectType)) {
+          return type;
+        }
+        const signature = getEffectsSignature(expr);
+        const predicate = signature && getTypePredicateOfSignature(signature);
+        if (predicate && predicate.kind === 1 /* Identifier */ && predicate.parameterIndex === 0) {
+          return getNarrowedType(
+            type,
+            predicate.type,
+            assumeTrue,
+            /*checkDerived*/
+            true
+          );
+        }
         if (!isTypeDerivedFrom(rightType, globalFunctionType)) {
           return type;
         }
@@ -167358,7 +151181,10 @@ ${lanes.join("\n")}
         const narrowedType = mapType(candidate, (c) => {
           const discriminant = keyPropertyName && getTypeOfPropertyOfType(c, keyPropertyName);
           const matching = discriminant && getConstituentTypeForKeyType(type, discriminant);
-          const directlyRelated = mapType(matching || type, checkDerived ? (t) => isTypeDerivedFrom(t, c) ? t : isTypeDerivedFrom(c, t) ? c : neverType : (t) => isTypeStrictSubtypeOf(t, c) ? t : isTypeStrictSubtypeOf(c, t) ? c : isTypeSubtypeOf(t, c) ? t : isTypeSubtypeOf(c, t) ? c : neverType);
+          const directlyRelated = mapType(
+            matching || type,
+            checkDerived ? (t) => isTypeDerivedFrom(t, c) ? t : isTypeDerivedFrom(c, t) ? c : neverType : (t) => isTypeStrictSubtypeOf(t, c) ? t : isTypeStrictSubtypeOf(c, t) ? c : isTypeSubtypeOf(t, c) ? t : isTypeSubtypeOf(c, t) ? c : neverType
+          );
           return directlyRelated.flags & 131072 /* Never */ ? mapType(type, (t) => maybeTypeOfKind(t, 465829888 /* Instantiable */) && isRelated(c, getBaseConstraintOfType(t) || unknownType) ? getIntersectionType([t, c]) : neverType) : directlyRelated;
         });
         return !(narrowedType.flags & 131072 /* Never */) ? narrowedType : isTypeSubtypeOf(candidate, type) ? candidate : isTypeAssignableTo(type, candidate) ? type : isTypeAssignableTo(candidate, type) ? candidate : getIntersectionType([type, candidate]);
@@ -167395,7 +151221,7 @@ ${lanes.join("\n")}
                 false
               );
             }
-            if (strictNullChecks && assumeTrue && optionalChainContainsReference(predicateArgument, reference) && !(getTypeFacts(predicate.type) & 65536 /* EQUndefined */)) {
+            if (strictNullChecks && optionalChainContainsReference(predicateArgument, reference) && (assumeTrue && !hasTypeFacts(predicate.type, 65536 /* EQUndefined */) || !assumeTrue && everyType(predicate.type, isNullableType))) {
               type = getAdjustedTypeWithFacts(type, 2097152 /* NEUndefinedOrNull */);
             }
             const access = getDiscriminantPropertyAccess(predicateArgument, type);
@@ -167420,7 +151246,7 @@ ${lanes.join("\n")}
           case 80 /* Identifier */:
             if (!isMatchingReference(reference, expr) && inlineLevel < 5) {
               const symbol = getResolvedSymbol(expr);
-              if (isConstVariable(symbol)) {
+              if (isConstantVariable(symbol)) {
                 const declaration = symbol.valueDeclaration;
                 if (declaration && isVariableDeclaration(declaration) && !declaration.type && declaration.initializer && isConstantReference(reference)) {
                   inlineLevel++;
@@ -167432,17 +151258,17 @@ ${lanes.join("\n")}
             }
           case 110 /* ThisKeyword */:
           case 108 /* SuperKeyword */:
-          case 210 /* PropertyAccessExpression */:
-          case 211 /* ElementAccessExpression */:
+          case 211 /* PropertyAccessExpression */:
+          case 212 /* ElementAccessExpression */:
             return narrowTypeByTruthiness(type, expr, assumeTrue);
-          case 212 /* CallExpression */:
+          case 213 /* CallExpression */:
             return narrowTypeByCallExpression(type, expr, assumeTrue);
-          case 216 /* ParenthesizedExpression */:
-          case 234 /* NonNullExpression */:
+          case 217 /* ParenthesizedExpression */:
+          case 235 /* NonNullExpression */:
             return narrowType(type, expr.expression, assumeTrue);
-          case 225 /* BinaryExpression */:
+          case 226 /* BinaryExpression */:
             return narrowTypeByBinaryExpression(type, expr, assumeTrue);
-          case 223 /* PrefixUnaryExpression */:
+          case 224 /* PrefixUnaryExpression */:
             if (expr.operator === 54 /* ExclamationToken */) {
               return narrowType(type, expr.operand, !assumeTrue);
             }
@@ -167468,7 +151294,15 @@ ${lanes.join("\n")}
           location = location.parent;
         }
         if (isExpressionNode(location) && (!isAssignmentTarget(location) || isWriteAccess(location))) {
-          const type = getTypeOfExpression(location);
+          const type = removeOptionalTypeMarker(
+            isWriteAccess(location) && location.kind === 211 /* PropertyAccessExpression */ ? checkPropertyAccessExpression(
+              location,
+              /*checkMode*/
+              void 0,
+              /*writeOnly*/
+              true
+            ) : getTypeOfExpression(location)
+          );
           if (getExportSymbolOfValueSymbolIfExported(getNodeLinks(location).resolvedSymbol) === symbol) {
             return type;
           }
@@ -167477,10 +151311,10 @@ ${lanes.join("\n")}
       if (isDeclarationName(location) && isSetAccessor(location.parent) && getAnnotatedAccessorTypeNode(location.parent)) {
         return getWriteTypeOfAccessors(location.parent.symbol);
       }
-      return getNonMissingTypeOfSymbol(symbol);
+      return isRightSideOfAccessExpression(location) && isWriteAccess(location.parent) ? getWriteTypeOfSymbol(symbol) : getNonMissingTypeOfSymbol(symbol);
     }
     function getControlFlowContainer(node) {
-      return findAncestor(node.parent, (node2) => isFunctionLike(node2) && !getImmediatelyInvokedFunctionExpression(node2) || node2.kind === 267 /* ModuleBlock */ || node2.kind === 311 /* SourceFile */ || node2.kind === 171 /* PropertyDeclaration */);
+      return findAncestor(node.parent, (node2) => isFunctionLike(node2) && !getImmediatelyInvokedFunctionExpression(node2) || node2.kind === 268 /* ModuleBlock */ || node2.kind === 312 /* SourceFile */ || node2.kind === 172 /* PropertyDeclaration */);
     }
     function isSymbolAssigned(symbol) {
       if (!symbol.valueDeclaration) {
@@ -167488,8 +151322,8 @@ ${lanes.join("\n")}
       }
       const parent2 = getRootDeclaration(symbol.valueDeclaration).parent;
       const links = getNodeLinks(parent2);
-      if (!(links.flags & 524288 /* AssignmentsMarked */)) {
-        links.flags |= 524288 /* AssignmentsMarked */;
+      if (!(links.flags & 131072 /* AssignmentsMarked */)) {
+        links.flags |= 131072 /* AssignmentsMarked */;
         if (!hasParentWithAssignmentsMarked(parent2)) {
           markNodeAssignments(parent2);
         }
@@ -167497,7 +151331,7 @@ ${lanes.join("\n")}
       return symbol.isAssigned || false;
     }
     function hasParentWithAssignmentsMarked(node) {
-      return !!findAncestor(node.parent, (node2) => (isFunctionLike(node2) || isCatchClause(node2)) && !!(getNodeLinks(node2).flags & 524288 /* AssignmentsMarked */));
+      return !!findAncestor(node.parent, (node2) => (isFunctionLike(node2) || isCatchClause(node2)) && !!(getNodeLinks(node2).flags & 131072 /* AssignmentsMarked */));
     }
     function markNodeAssignments(node) {
       if (node.kind === 80 /* Identifier */) {
@@ -167511,8 +151345,8 @@ ${lanes.join("\n")}
         forEachChild(node, markNodeAssignments);
       }
     }
-    function isConstVariable(symbol) {
-      return symbol.flags & 3 /* Variable */ && (getDeclarationNodeFlagsFromSymbol(symbol) & 2 /* Const */) !== 0;
+    function isConstantVariable(symbol) {
+      return symbol.flags & 3 /* Variable */ && (getDeclarationNodeFlagsFromSymbol(symbol) & 6 /* Constant */) !== 0;
     }
     function parameterInitializerContainsUndefined(declaration) {
       const links = getNodeLinks(declaration);
@@ -167521,7 +151355,7 @@ ${lanes.join("\n")}
           reportCircularityError(declaration.symbol);
           return true;
         }
-        const containsUndefined = !!(getTypeFacts(checkDeclarationInitializer(declaration, 0 /* Normal */)) & 16777216 /* IsUndefined */);
+        const containsUndefined = !!hasTypeFacts(checkDeclarationInitializer(declaration, 0 /* Normal */), 16777216 /* IsUndefined */);
         if (!popTypeResolution()) {
           reportCircularityError(declaration.symbol);
           return true;
@@ -167531,12 +151365,12 @@ ${lanes.join("\n")}
       return links.parameterInitializerContainsUndefined;
     }
     function removeOptionalityFromDeclaredType(declaredType, declaration) {
-      const removeUndefined = strictNullChecks && declaration.kind === 168 /* Parameter */ && declaration.initializer && getTypeFacts(declaredType) & 16777216 /* IsUndefined */ && !parameterInitializerContainsUndefined(declaration);
+      const removeUndefined = strictNullChecks && declaration.kind === 169 /* Parameter */ && declaration.initializer && hasTypeFacts(declaredType, 16777216 /* IsUndefined */) && !parameterInitializerContainsUndefined(declaration);
       return removeUndefined ? getTypeWithFacts(declaredType, 524288 /* NEUndefined */) : declaredType;
     }
     function isConstraintPosition(type, node) {
       const parent2 = node.parent;
-      return parent2.kind === 210 /* PropertyAccessExpression */ || parent2.kind === 165 /* QualifiedName */ || parent2.kind === 212 /* CallExpression */ && parent2.expression === node || parent2.kind === 211 /* ElementAccessExpression */ && parent2.expression === node && !(someType(type, isGenericTypeWithoutNullableConstraint) && isGenericIndexType(getTypeOfExpression(parent2.argumentExpression)));
+      return parent2.kind === 211 /* PropertyAccessExpression */ || parent2.kind === 166 /* QualifiedName */ || parent2.kind === 213 /* CallExpression */ && parent2.expression === node || parent2.kind === 212 /* ElementAccessExpression */ && parent2.expression === node && !(someType(type, isGenericTypeWithoutNullableConstraint) && isGenericIndexType(getTypeOfExpression(parent2.argumentExpression)));
     }
     function isGenericTypeWithUnionConstraint(type) {
       return type.flags & 2097152 /* Intersection */ ? some(type.types, isGenericTypeWithUnionConstraint) : !!(type.flags & 465829888 /* Instantiable */ && getBaseConstraintOrType(type).flags & (98304 /* Nullable */ | 1048576 /* Union */));
@@ -167545,7 +151379,7 @@ ${lanes.join("\n")}
       return type.flags & 2097152 /* Intersection */ ? some(type.types, isGenericTypeWithoutNullableConstraint) : !!(type.flags & 465829888 /* Instantiable */ && !maybeTypeOfKind(getBaseConstraintOrType(type), 98304 /* Nullable */));
     }
     function hasContextualTypeWithNoGenericTypes(node, checkMode) {
-      const contextualType = (isIdentifier(node) || isPropertyAccessExpression(node) || isElementAccessExpression(node)) && !((isJsxOpeningElement(node.parent) || isJsxSelfClosingElement(node.parent)) && node.parent.tagName === node) && (checkMode && checkMode & 64 /* RestBindingElement */ ? getContextualType2(node, 8 /* SkipBindingPatterns */) : getContextualType2(
+      const contextualType = (isIdentifier(node) || isPropertyAccessExpression(node) || isElementAccessExpression(node)) && !((isJsxOpeningElement(node.parent) || isJsxSelfClosingElement(node.parent)) && node.parent.tagName === node) && (checkMode && checkMode & 32 /* RestBindingElement */ ? getContextualType2(node, 8 /* SkipBindingPatterns */) : getContextualType2(
         node,
         /*contextFlags*/
         void 0
@@ -167579,9 +151413,13 @@ ${lanes.join("\n")}
         symbol,
         /*excludes*/
         111551 /* Value */
-      ) && !isInTypeQuery(location) && !getTypeOnlyAliasDeclaration(symbol, 111551 /* Value */)) {
+      ) && !isInTypeQuery(location)) {
         const target = resolveAlias(symbol);
-        if (getAllSymbolFlags(target) & (111551 /* Value */ | 1048576 /* ExportValue */)) {
+        if (getSymbolFlags(
+          symbol,
+          /*excludeTypeOnlyMeanings*/
+          true
+        ) & (111551 /* Value */ | 1048576 /* ExportValue */)) {
           if (getIsolatedModules(compilerOptions) || shouldPreserveConstEnums(compilerOptions) && isExportOrExportExpression(location) || !isConstEnumOrConstEnumOnlyModule(getExportSymbolOfValueSymbolIfExported(target))) {
             markAliasSymbolAsReferenced(symbol);
           } else {
@@ -167597,14 +151435,14 @@ ${lanes.join("\n")}
       if (declaration) {
         if (isBindingElement(declaration) && !declaration.initializer && !declaration.dotDotDotToken && declaration.parent.elements.length >= 2) {
           const parent2 = declaration.parent.parent;
-          if (parent2.kind === 259 /* VariableDeclaration */ && getCombinedNodeFlags(declaration) & 2 /* Const */ || parent2.kind === 168 /* Parameter */) {
+          if (parent2.kind === 260 /* VariableDeclaration */ && getCombinedNodeFlagsCached(declaration) & 6 /* Constant */ || parent2.kind === 169 /* Parameter */) {
             const links = getNodeLinks(parent2);
-            if (!(links.flags & 16777216 /* InCheckIdentifier */)) {
-              links.flags |= 16777216 /* InCheckIdentifier */;
+            if (!(links.flags & 4194304 /* InCheckIdentifier */)) {
+              links.flags |= 4194304 /* InCheckIdentifier */;
               const parentType = getTypeForBindingElementParent(parent2, 0 /* Normal */);
               const parentTypeConstraint = parentType && mapType(parentType, getBaseConstraintOrType);
-              links.flags &= ~16777216 /* InCheckIdentifier */;
-              if (parentTypeConstraint && parentTypeConstraint.flags & 1048576 /* Union */ && !(parent2.kind === 168 /* Parameter */ && isSymbolAssigned(symbol))) {
+              links.flags &= ~4194304 /* InCheckIdentifier */;
+              if (parentTypeConstraint && parentTypeConstraint.flags & 1048576 /* Union */ && !(parent2.kind === 169 /* Parameter */ && isSymbolAssigned(symbol))) {
                 const pattern = declaration.parent;
                 const narrowedType = getFlowTypeOfReference(
                   pattern,
@@ -167617,7 +151455,12 @@ ${lanes.join("\n")}
                 if (narrowedType.flags & 131072 /* Never */) {
                   return neverType;
                 }
-                return getBindingElementTypeFromParentType(declaration, narrowedType);
+                return getBindingElementTypeFromParentType(
+                  declaration,
+                  narrowedType,
+                  /*noTupleBoundsCheck*/
+                  true
+                );
               }
             }
           }
@@ -167656,15 +151499,15 @@ ${lanes.join("\n")}
       }
       if (symbol === argumentsSymbol) {
         if (isInPropertyInitializerOrClassStaticBlock(node)) {
-          error(node, Diagnostics.arguments_cannot_be_referenced_in_property_initializers);
+          error2(node, Diagnostics.arguments_cannot_be_referenced_in_property_initializers);
           return errorType;
         }
         const container = getContainingFunction(node);
         if (languageVersion < 2 /* ES2015 */) {
-          if (container.kind === 218 /* ArrowFunction */) {
-            error(node, Diagnostics.The_arguments_object_cannot_be_referenced_in_an_arrow_function_in_ES3_and_ES5_Consider_using_a_standard_function_expression);
-          } else if (hasSyntacticModifier(container, 512 /* Async */)) {
-            error(node, Diagnostics.The_arguments_object_cannot_be_referenced_in_an_async_function_or_method_in_ES3_and_ES5_Consider_using_a_standard_function_or_method);
+          if (container.kind === 219 /* ArrowFunction */) {
+            error2(node, Diagnostics.The_arguments_object_cannot_be_referenced_in_an_arrow_function_in_ES3_and_ES5_Consider_using_a_standard_function_expression);
+          } else if (hasSyntacticModifier(container, 1024 /* Async */)) {
+            error2(node, Diagnostics.The_arguments_object_cannot_be_referenced_in_an_async_function_or_method_in_ES3_and_ES5_Consider_using_a_standard_function_or_method);
           }
         }
         getNodeLinks(container).flags |= 512 /* CaptureArguments */;
@@ -167680,17 +151523,7 @@ ${lanes.join("\n")}
       }
       let declaration = localOrExportSymbol.valueDeclaration;
       if (declaration && localOrExportSymbol.flags & 32 /* Class */) {
-        if (declaration.kind === 262 /* ClassDeclaration */ && nodeIsDecorated(legacyDecorators, declaration)) {
-          let container = getContainingClass(node);
-          while (container !== void 0) {
-            if (container === declaration && container.name !== node) {
-              getNodeLinks(declaration).flags |= 1048576 /* ClassWithConstructorReference */;
-              getNodeLinks(node).flags |= 2097152 /* ConstructorReferenceInClass */;
-              break;
-            }
-            container = getContainingClass(container);
-          }
-        } else if (declaration.kind === 230 /* ClassExpression */) {
+        if (isClassLike(declaration) && declaration.name !== node) {
           let container = getThisContainer(
             node,
             /*includeArrowFunctions*/
@@ -167698,14 +151531,7 @@ ${lanes.join("\n")}
             /*includeClassComputedPropertyName*/
             false
           );
-          while (container.kind !== 311 /* SourceFile */) {
-            if (container.parent === declaration) {
-              if (isPropertyDeclaration(container) && isStatic(container) || isClassStaticBlockDeclaration(container)) {
-                getNodeLinks(declaration).flags |= 1048576 /* ClassWithConstructorReference */;
-                getNodeLinks(node).flags |= 2097152 /* ConstructorReferenceInClass */;
-              }
-              break;
-            }
+          while (container.kind !== 312 /* SourceFile */ && container.parent !== declaration) {
             container = getThisContainer(
               container,
               /*includeArrowFunctions*/
@@ -167714,6 +151540,11 @@ ${lanes.join("\n")}
               false
             );
           }
+          if (container.kind !== 312 /* SourceFile */) {
+            getNodeLinks(declaration).flags |= 262144 /* ContainsConstructorReference */;
+            getNodeLinks(container).flags |= 262144 /* ContainsConstructorReference */;
+            getNodeLinks(node).flags |= 536870912 /* ConstructorReference */;
+          }
         }
       }
       checkNestedBlockScopedBinding(node, symbol);
@@ -167722,14 +151553,14 @@ ${lanes.join("\n")}
       if (assignmentKind) {
         if (!(localOrExportSymbol.flags & 3 /* Variable */) && !(isInJSFile(node) && localOrExportSymbol.flags & 512 /* ValueModule */)) {
           const assignmentError = localOrExportSymbol.flags & 384 /* Enum */ ? Diagnostics.Cannot_assign_to_0_because_it_is_an_enum : localOrExportSymbol.flags & 32 /* Class */ ? Diagnostics.Cannot_assign_to_0_because_it_is_a_class : localOrExportSymbol.flags & 1536 /* Module */ ? Diagnostics.Cannot_assign_to_0_because_it_is_a_namespace : localOrExportSymbol.flags & 16 /* Function */ ? Diagnostics.Cannot_assign_to_0_because_it_is_a_function : localOrExportSymbol.flags & 2097152 /* Alias */ ? Diagnostics.Cannot_assign_to_0_because_it_is_an_import : Diagnostics.Cannot_assign_to_0_because_it_is_not_a_variable;
-          error(node, assignmentError, symbolToString(symbol));
+          error2(node, assignmentError, symbolToString(symbol));
           return errorType;
         }
         if (isReadonlySymbol(localOrExportSymbol)) {
           if (localOrExportSymbol.flags & 3 /* Variable */) {
-            error(node, Diagnostics.Cannot_assign_to_0_because_it_is_a_constant, symbolToString(symbol));
+            error2(node, Diagnostics.Cannot_assign_to_0_because_it_is_a_constant, symbolToString(symbol));
           } else {
-            error(node, Diagnostics.Cannot_assign_to_0_because_it_is_a_read_only_property, symbolToString(symbol));
+            error2(node, Diagnostics.Cannot_assign_to_0_because_it_is_a_read_only_property, symbolToString(symbol));
           }
           return errorType;
         }
@@ -167737,7 +151568,7 @@ ${lanes.join("\n")}
       const isAlias = localOrExportSymbol.flags & 2097152 /* Alias */;
       if (localOrExportSymbol.flags & 3 /* Variable */) {
         if (assignmentKind === 1 /* Definite */) {
-          return type;
+          return isInCompoundLikeAssignment(node) ? getBaseTypeOfLiteralType(type) : type;
         }
       } else if (isAlias) {
         declaration = getDeclarationOfAliasSymbol(symbol);
@@ -167748,30 +151579,30 @@ ${lanes.join("\n")}
         return type;
       }
       type = getNarrowableTypeForReference(type, node, checkMode);
-      const isParameter2 = getRootDeclaration(declaration).kind === 168 /* Parameter */;
+      const isParameter2 = getRootDeclaration(declaration).kind === 169 /* Parameter */;
       const declarationContainer = getControlFlowContainer(declaration);
       let flowContainer = getControlFlowContainer(node);
       const isOuterVariable = flowContainer !== declarationContainer;
       const isSpreadDestructuringAssignmentTarget = node.parent && node.parent.parent && isSpreadAssignment(node.parent) && isDestructuringAssignmentTarget(node.parent.parent);
       const isModuleExports = symbol.flags & 134217728 /* ModuleExports */;
       const typeIsAutomatic = type === autoType || type === autoArrayType;
-      const isAutomaticTypeInNonNull = typeIsAutomatic && node.parent.kind === 234 /* NonNullExpression */;
-      while (flowContainer !== declarationContainer && (flowContainer.kind === 217 /* FunctionExpression */ || flowContainer.kind === 218 /* ArrowFunction */ || isObjectLiteralOrClassExpressionMethodOrAccessor(flowContainer)) && (isConstVariable(localOrExportSymbol) && type !== autoArrayType || isParameter2 && !isSymbolAssigned(localOrExportSymbol))) {
+      const isAutomaticTypeInNonNull = typeIsAutomatic && node.parent.kind === 235 /* NonNullExpression */;
+      while (flowContainer !== declarationContainer && (flowContainer.kind === 218 /* FunctionExpression */ || flowContainer.kind === 219 /* ArrowFunction */ || isObjectLiteralOrClassExpressionMethodOrAccessor(flowContainer)) && (isConstantVariable(localOrExportSymbol) && type !== autoArrayType || isParameter2 && !isSymbolAssigned(localOrExportSymbol))) {
         flowContainer = getControlFlowContainer(flowContainer);
       }
-      const assumeInitialized = isParameter2 || isAlias || isOuterVariable || isSpreadDestructuringAssignmentTarget || isModuleExports || isSameScopedBindingElement(node, declaration) || type !== autoType && type !== autoArrayType && (!strictNullChecks || (type.flags & (3 /* AnyOrUnknown */ | 16384 /* Void */)) !== 0 || isInTypeQuery(node) || isInAmbientOrTypeNode(node) || node.parent.kind === 280 /* ExportSpecifier */) || node.parent.kind === 234 /* NonNullExpression */ || declaration.kind === 259 /* VariableDeclaration */ && declaration.exclamationToken || declaration.flags & 16777216 /* Ambient */;
+      const assumeInitialized = isParameter2 || isAlias || isOuterVariable || isSpreadDestructuringAssignmentTarget || isModuleExports || isSameScopedBindingElement(node, declaration) || type !== autoType && type !== autoArrayType && (!strictNullChecks || (type.flags & (3 /* AnyOrUnknown */ | 16384 /* Void */)) !== 0 || isInTypeQuery(node) || isInAmbientOrTypeNode(node) || node.parent.kind === 281 /* ExportSpecifier */) || node.parent.kind === 235 /* NonNullExpression */ || declaration.kind === 260 /* VariableDeclaration */ && declaration.exclamationToken || declaration.flags & 33554432 /* Ambient */;
       const initialType = isAutomaticTypeInNonNull ? undefinedType : assumeInitialized ? isParameter2 ? removeOptionalityFromDeclaredType(type, declaration) : type : typeIsAutomatic ? undefinedType : getOptionalType(type);
       const flowType = isAutomaticTypeInNonNull ? getNonNullableType(getFlowTypeOfReference(node, type, initialType, flowContainer)) : getFlowTypeOfReference(node, type, initialType, flowContainer);
       if (!isEvolvingArrayOperationTarget(node) && (type === autoType || type === autoArrayType)) {
         if (flowType === autoType || flowType === autoArrayType) {
           if (noImplicitAny) {
-            error(getNameOfDeclaration(declaration), Diagnostics.Variable_0_implicitly_has_type_1_in_some_locations_where_its_type_cannot_be_determined, symbolToString(symbol), typeToString(flowType));
-            error(node, Diagnostics.Variable_0_implicitly_has_an_1_type, symbolToString(symbol), typeToString(flowType));
+            error2(getNameOfDeclaration(declaration), Diagnostics.Variable_0_implicitly_has_type_1_in_some_locations_where_its_type_cannot_be_determined, symbolToString(symbol), typeToString(flowType));
+            error2(node, Diagnostics.Variable_0_implicitly_has_an_1_type, symbolToString(symbol), typeToString(flowType));
           }
           return convertAutoToAny(flowType);
         }
       } else if (!assumeInitialized && !containsUndefinedType(type) && containsUndefinedType(flowType)) {
-        error(node, Diagnostics.Variable_0_is_used_before_being_assigned, symbolToString(symbol));
+        error2(node, Diagnostics.Variable_0_is_used_before_being_assigned, symbolToString(symbol));
         return type;
       }
       return assignmentKind ? getBaseTypeOfLiteralType(flowType) : flowType;
@@ -167813,7 +151644,7 @@ ${lanes.join("\n")}
       ));
     }
     function checkNestedBlockScopedBinding(node, symbol) {
-      if (languageVersion >= 2 /* ES2015 */ || (symbol.flags & (2 /* BlockScopedVariable */ | 32 /* Class */)) === 0 || !symbol.valueDeclaration || isSourceFile(symbol.valueDeclaration) || symbol.valueDeclaration.parent.kind === 298 /* CatchClause */) {
+      if (languageVersion >= 2 /* ES2015 */ || (symbol.flags & (2 /* BlockScopedVariable */ | 32 /* Class */)) === 0 || !symbol.valueDeclaration || isSourceFile(symbol.valueDeclaration) || symbol.valueDeclaration.parent.kind === 299 /* CatchClause */) {
         return;
       }
       const container = getEnclosingBlockScopeContainer(symbol.valueDeclaration);
@@ -167823,7 +151654,7 @@ ${lanes.join("\n")}
         if (isCaptured) {
           let capturesBlockScopeBindingInLoopBody = true;
           if (isForStatement(container)) {
-            const varDeclList = getAncestor(symbol.valueDeclaration, 260 /* VariableDeclarationList */);
+            const varDeclList = getAncestor(symbol.valueDeclaration, 261 /* VariableDeclarationList */);
             if (varDeclList && varDeclList.parent === container) {
               const part = getPartOfForStatementContainingNode(node.parent, container);
               if (part) {
@@ -167842,9 +151673,9 @@ ${lanes.join("\n")}
           }
         }
         if (isForStatement(container)) {
-          const varDeclList = getAncestor(symbol.valueDeclaration, 260 /* VariableDeclarationList */);
+          const varDeclList = getAncestor(symbol.valueDeclaration, 261 /* VariableDeclarationList */);
           if (varDeclList && varDeclList.parent === container && isAssignedInBodyOfForStatement(node, container)) {
-            getNodeLinks(symbol.valueDeclaration).flags |= 262144 /* NeedsLoopOutParameter */;
+            getNodeLinks(symbol.valueDeclaration).flags |= 65536 /* NeedsLoopOutParameter */;
           }
         }
         getNodeLinks(symbol.valueDeclaration).flags |= 32768 /* BlockScopedBindingInLoop */;
@@ -167859,13 +151690,13 @@ ${lanes.join("\n")}
     }
     function isAssignedInBodyOfForStatement(node, container) {
       let current = node;
-      while (current.parent.kind === 216 /* ParenthesizedExpression */) {
+      while (current.parent.kind === 217 /* ParenthesizedExpression */) {
         current = current.parent;
       }
       let isAssigned = false;
       if (isAssignmentTarget(current)) {
         isAssigned = true;
-      } else if (current.parent.kind === 223 /* PrefixUnaryExpression */ || current.parent.kind === 224 /* PostfixUnaryExpression */) {
+      } else if (current.parent.kind === 224 /* PrefixUnaryExpression */ || current.parent.kind === 225 /* PostfixUnaryExpression */) {
         const expr = current.parent;
         isAssigned = expr.operator === 46 /* PlusPlusToken */ || expr.operator === 47 /* MinusMinusToken */;
       }
@@ -167876,7 +151707,7 @@ ${lanes.join("\n")}
     }
     function captureLexicalThis(node, container) {
       getNodeLinks(node).flags |= 2 /* LexicalThis */;
-      if (container.kind === 171 /* PropertyDeclaration */ || container.kind === 175 /* Constructor */) {
+      if (container.kind === 172 /* PropertyDeclaration */ || container.kind === 176 /* Constructor */) {
         const classNode = container.parent;
         getNodeLinks(classNode).flags |= 4 /* CaptureThis */;
       } else {
@@ -167901,13 +151732,13 @@ ${lanes.join("\n")}
           /*noCacheCheck*/
           false
         )) {
-          error(node, diagnosticMessage);
+          error2(node, diagnosticMessage);
         }
       }
     }
     function checkThisInStaticClassFieldInitializerInDecoratedClass(thisExpression, container) {
       if (isPropertyDeclaration(container) && hasStaticModifier(container) && legacyDecorators && container.initializer && textRangeContainsPositionInclusive(container.initializer, thisExpression.pos) && hasDecorators(container.parent)) {
-        error(thisExpression, Diagnostics.Cannot_use_this_in_a_static_property_initializer_of_a_decorated_class);
+        error2(thisExpression, Diagnostics.Cannot_use_this_in_a_static_property_initializer_of_a_decorated_class);
       }
     }
     function checkThisExpression(node) {
@@ -167921,11 +151752,11 @@ ${lanes.join("\n")}
       );
       let capturedByArrowFunction = false;
       let thisInComputedPropertyName = false;
-      if (container.kind === 175 /* Constructor */) {
+      if (container.kind === 176 /* Constructor */) {
         checkThisBeforeSuper(node, container, Diagnostics.super_must_be_called_before_accessing_this_in_the_constructor_of_a_derived_class);
       }
       while (true) {
-        if (container.kind === 218 /* ArrowFunction */) {
+        if (container.kind === 219 /* ArrowFunction */) {
           container = getThisContainer(
             container,
             /*includeArrowFunctions*/
@@ -167934,7 +151765,7 @@ ${lanes.join("\n")}
           );
           capturedByArrowFunction = true;
         }
-        if (container.kind === 166 /* ComputedPropertyName */) {
+        if (container.kind === 167 /* ComputedPropertyName */) {
           container = getThisContainer(
             container,
             !capturedByArrowFunction,
@@ -167948,18 +151779,18 @@ ${lanes.join("\n")}
       }
       checkThisInStaticClassFieldInitializerInDecoratedClass(node, container);
       if (thisInComputedPropertyName) {
-        error(node, Diagnostics.this_cannot_be_referenced_in_a_computed_property_name);
+        error2(node, Diagnostics.this_cannot_be_referenced_in_a_computed_property_name);
       } else {
         switch (container.kind) {
-          case 266 /* ModuleDeclaration */:
-            error(node, Diagnostics.this_cannot_be_referenced_in_a_module_or_namespace_body);
+          case 267 /* ModuleDeclaration */:
+            error2(node, Diagnostics.this_cannot_be_referenced_in_a_module_or_namespace_body);
             break;
-          case 265 /* EnumDeclaration */:
-            error(node, Diagnostics.this_cannot_be_referenced_in_current_location);
+          case 266 /* EnumDeclaration */:
+            error2(node, Diagnostics.this_cannot_be_referenced_in_current_location);
             break;
-          case 175 /* Constructor */:
+          case 176 /* Constructor */:
             if (isInConstructorArgumentInitializer(node, container)) {
-              error(node, Diagnostics.this_cannot_be_referenced_in_constructor_arguments);
+              error2(node, Diagnostics.this_cannot_be_referenced_in_constructor_arguments);
             }
             break;
         }
@@ -167976,9 +151807,9 @@ ${lanes.join("\n")}
       if (noImplicitThis) {
         const globalThisType2 = getTypeOfSymbol(globalThisSymbol);
         if (type === globalThisType2 && capturedByArrowFunction) {
-          error(node, Diagnostics.The_containing_arrow_function_captures_the_global_value_of_this);
+          error2(node, Diagnostics.The_containing_arrow_function_captures_the_global_value_of_this);
         } else if (!type) {
-          const diag2 = error(node, Diagnostics.this_implicitly_has_type_any_because_it_does_not_have_a_type_annotation);
+          const diag2 = error2(node, Diagnostics.this_implicitly_has_type_any_because_it_does_not_have_a_type_annotation);
           if (!isSourceFile(container)) {
             const outsideThis = tryGetThisTypeAt(container);
             if (outsideThis && outsideThis !== globalThisType2) {
@@ -168051,36 +151882,33 @@ ${lanes.join("\n")}
       }
     }
     function getClassNameFromPrototypeMethod(container) {
-      if (container.kind === 217 /* FunctionExpression */ && isBinaryExpression(container.parent) && getAssignmentDeclarationKind(container.parent) === 3 /* PrototypeProperty */) {
+      if (container.kind === 218 /* FunctionExpression */ && isBinaryExpression(container.parent) && getAssignmentDeclarationKind(container.parent) === 3 /* PrototypeProperty */) {
         return container.parent.left.expression.expression;
-      } else if (container.kind === 173 /* MethodDeclaration */ && container.parent.kind === 209 /* ObjectLiteralExpression */ && isBinaryExpression(container.parent.parent) && getAssignmentDeclarationKind(container.parent.parent) === 6 /* Prototype */) {
+      } else if (container.kind === 174 /* MethodDeclaration */ && container.parent.kind === 210 /* ObjectLiteralExpression */ && isBinaryExpression(container.parent.parent) && getAssignmentDeclarationKind(container.parent.parent) === 6 /* Prototype */) {
         return container.parent.parent.left.expression;
-      } else if (container.kind === 217 /* FunctionExpression */ && container.parent.kind === 302 /* PropertyAssignment */ && container.parent.parent.kind === 209 /* ObjectLiteralExpression */ && isBinaryExpression(container.parent.parent.parent) && getAssignmentDeclarationKind(container.parent.parent.parent) === 6 /* Prototype */) {
+      } else if (container.kind === 218 /* FunctionExpression */ && container.parent.kind === 303 /* PropertyAssignment */ && container.parent.parent.kind === 210 /* ObjectLiteralExpression */ && isBinaryExpression(container.parent.parent.parent) && getAssignmentDeclarationKind(container.parent.parent.parent) === 6 /* Prototype */) {
         return container.parent.parent.parent.left.expression;
-      } else if (container.kind === 217 /* FunctionExpression */ && isPropertyAssignment(container.parent) && isIdentifier(container.parent.name) && (container.parent.name.escapedText === "value" || container.parent.name.escapedText === "get" || container.parent.name.escapedText === "set") && isObjectLiteralExpression(container.parent.parent) && isCallExpression(container.parent.parent.parent) && container.parent.parent.parent.arguments[2] === container.parent.parent && getAssignmentDeclarationKind(container.parent.parent.parent) === 9 /* ObjectDefinePrototypeProperty */) {
+      } else if (container.kind === 218 /* FunctionExpression */ && isPropertyAssignment(container.parent) && isIdentifier(container.parent.name) && (container.parent.name.escapedText === "value" || container.parent.name.escapedText === "get" || container.parent.name.escapedText === "set") && isObjectLiteralExpression(container.parent.parent) && isCallExpression(container.parent.parent.parent) && container.parent.parent.parent.arguments[2] === container.parent.parent && getAssignmentDeclarationKind(container.parent.parent.parent) === 9 /* ObjectDefinePrototypeProperty */) {
         return container.parent.parent.parent.arguments[0].expression;
       } else if (isMethodDeclaration(container) && isIdentifier(container.name) && (container.name.escapedText === "value" || container.name.escapedText === "get" || container.name.escapedText === "set") && isObjectLiteralExpression(container.parent) && isCallExpression(container.parent.parent) && container.parent.parent.arguments[2] === container.parent && getAssignmentDeclarationKind(container.parent.parent) === 9 /* ObjectDefinePrototypeProperty */) {
         return container.parent.parent.arguments[0].expression;
       }
     }
     function getTypeForThisExpressionFromJSDoc(node) {
-      const jsdocType = getJSDocType(node);
-      if (jsdocType && jsdocType.kind === 323 /* JSDocFunctionType */) {
-        const jsDocFunctionType = jsdocType;
-        if (jsDocFunctionType.parameters.length > 0 && jsDocFunctionType.parameters[0].name && jsDocFunctionType.parameters[0].name.escapedText === "this" /* This */) {
-          return getTypeFromTypeNode(jsDocFunctionType.parameters[0].type);
-        }
-      }
       const thisTag = getJSDocThisTag(node);
       if (thisTag && thisTag.typeExpression) {
         return getTypeFromTypeNode(thisTag.typeExpression);
       }
+      const signature = getSignatureOfTypeTag(node);
+      if (signature) {
+        return getThisTypeOfSignature(signature);
+      }
     }
     function isInConstructorArgumentInitializer(node, constructorDecl) {
-      return !!findAncestor(node, (n) => isFunctionLikeDeclaration(n) ? "quit" : n.kind === 168 /* Parameter */ && n.parent === constructorDecl);
+      return !!findAncestor(node, (n) => isFunctionLikeDeclaration(n) ? "quit" : n.kind === 169 /* Parameter */ && n.parent === constructorDecl);
     }
     function checkSuperExpression(node) {
-      const isCallExpression2 = node.parent.kind === 212 /* CallExpression */ && node.parent.expression === node;
+      const isCallExpression2 = node.parent.kind === 213 /* CallExpression */ && node.parent.expression === node;
       const immediateContainer = getSuperContainer(
         node,
         /*stopOnFunctions*/
@@ -168090,8 +151918,8 @@ ${lanes.join("\n")}
       let needToCaptureLexicalThis = false;
       let inAsyncFunction = false;
       if (!isCallExpression2) {
-        while (container && container.kind === 218 /* ArrowFunction */) {
-          if (hasSyntacticModifier(container, 512 /* Async */))
+        while (container && container.kind === 219 /* ArrowFunction */) {
+          if (hasSyntacticModifier(container, 1024 /* Async */))
             inAsyncFunction = true;
           container = getSuperContainer(
             container,
@@ -168100,24 +151928,24 @@ ${lanes.join("\n")}
           );
           needToCaptureLexicalThis = languageVersion < 2 /* ES2015 */;
         }
-        if (container && hasSyntacticModifier(container, 512 /* Async */))
+        if (container && hasSyntacticModifier(container, 1024 /* Async */))
           inAsyncFunction = true;
       }
       let nodeCheckFlag = 0;
       if (!container || !isLegalUsageOfSuperExpression(container)) {
-        const current = findAncestor(node, (n) => n === container ? "quit" : n.kind === 166 /* ComputedPropertyName */);
-        if (current && current.kind === 166 /* ComputedPropertyName */) {
-          error(node, Diagnostics.super_cannot_be_referenced_in_a_computed_property_name);
+        const current = findAncestor(node, (n) => n === container ? "quit" : n.kind === 167 /* ComputedPropertyName */);
+        if (current && current.kind === 167 /* ComputedPropertyName */) {
+          error2(node, Diagnostics.super_cannot_be_referenced_in_a_computed_property_name);
         } else if (isCallExpression2) {
-          error(node, Diagnostics.Super_calls_are_not_permitted_outside_constructors_or_in_nested_functions_inside_constructors);
-        } else if (!container || !container.parent || !(isClassLike(container.parent) || container.parent.kind === 209 /* ObjectLiteralExpression */)) {
-          error(node, Diagnostics.super_can_only_be_referenced_in_members_of_derived_classes_or_object_literal_expressions);
+          error2(node, Diagnostics.Super_calls_are_not_permitted_outside_constructors_or_in_nested_functions_inside_constructors);
+        } else if (!container || !container.parent || !(isClassLike(container.parent) || container.parent.kind === 210 /* ObjectLiteralExpression */)) {
+          error2(node, Diagnostics.super_can_only_be_referenced_in_members_of_derived_classes_or_object_literal_expressions);
         } else {
-          error(node, Diagnostics.super_property_access_is_permitted_only_in_a_constructor_member_function_or_member_accessor_of_a_derived_class);
+          error2(node, Diagnostics.super_property_access_is_permitted_only_in_a_constructor_member_function_or_member_accessor_of_a_derived_class);
         }
         return errorType;
       }
-      if (!isCallExpression2 && immediateContainer.kind === 175 /* Constructor */) {
+      if (!isCallExpression2 && immediateContainer.kind === 176 /* Constructor */) {
         checkThisBeforeSuper(node, container, Diagnostics.super_must_be_called_before_accessing_a_property_of_super_in_the_constructor_of_a_derived_class);
       }
       if (isStatic(container) || isCallExpression2) {
@@ -168125,7 +151953,7 @@ ${lanes.join("\n")}
         if (!isCallExpression2 && languageVersion >= 2 /* ES2015 */ && languageVersion <= 8 /* ES2021 */ && (isPropertyDeclaration(container) || isClassStaticBlockDeclaration(container))) {
           forEachEnclosingBlockScopeContainer(node.parent, (current) => {
             if (!isSourceFile(current) || isExternalOrCommonJsModule(current)) {
-              getNodeLinks(current).flags |= 8388608 /* ContainsSuperPropertyInStaticInitializer */;
+              getNodeLinks(current).flags |= 2097152 /* ContainsSuperPropertyInStaticInitializer */;
             }
           });
         }
@@ -168133,7 +151961,7 @@ ${lanes.join("\n")}
         nodeCheckFlag = 16 /* SuperInstance */;
       }
       getNodeLinks(node).flags |= nodeCheckFlag;
-      if (container.kind === 173 /* MethodDeclaration */ && inAsyncFunction) {
+      if (container.kind === 174 /* MethodDeclaration */ && inAsyncFunction) {
         if (isSuperProperty(node.parent) && isAssignmentTarget(node.parent)) {
           getNodeLinks(container).flags |= 256 /* MethodWithSuperPropertyAssignmentInAsync */;
         } else {
@@ -168143,9 +151971,9 @@ ${lanes.join("\n")}
       if (needToCaptureLexicalThis) {
         captureLexicalThis(node.parent, container);
       }
-      if (container.parent.kind === 209 /* ObjectLiteralExpression */) {
+      if (container.parent.kind === 210 /* ObjectLiteralExpression */) {
         if (languageVersion < 2 /* ES2015 */) {
-          error(node, Diagnostics.super_is_only_allowed_in_members_of_object_literal_expressions_when_option_target_is_ES2015_or_higher);
+          error2(node, Diagnostics.super_is_only_allowed_in_members_of_object_literal_expressions_when_option_target_is_ES2015_or_higher);
           return errorType;
         } else {
           return anyType;
@@ -168153,28 +151981,31 @@ ${lanes.join("\n")}
       }
       const classLikeDeclaration = container.parent;
       if (!getClassExtendsHeritageElement(classLikeDeclaration)) {
-        error(node, Diagnostics.super_can_only_be_referenced_in_a_derived_class);
+        error2(node, Diagnostics.super_can_only_be_referenced_in_a_derived_class);
         return errorType;
       }
+      if (classDeclarationExtendsNull(classLikeDeclaration)) {
+        return isCallExpression2 ? errorType : nullWideningType;
+      }
       const classType = getDeclaredTypeOfSymbol(getSymbolOfDeclaration(classLikeDeclaration));
       const baseClassType = classType && getBaseTypes(classType)[0];
       if (!baseClassType) {
         return errorType;
       }
-      if (container.kind === 175 /* Constructor */ && isInConstructorArgumentInitializer(node, container)) {
-        error(node, Diagnostics.super_cannot_be_referenced_in_constructor_arguments);
+      if (container.kind === 176 /* Constructor */ && isInConstructorArgumentInitializer(node, container)) {
+        error2(node, Diagnostics.super_cannot_be_referenced_in_constructor_arguments);
         return errorType;
       }
       return nodeCheckFlag === 32 /* SuperStatic */ ? getBaseConstructorTypeOfClass(classType) : getTypeWithThisArgument(baseClassType, classType.thisType);
       function isLegalUsageOfSuperExpression(container2) {
         if (isCallExpression2) {
-          return container2.kind === 175 /* Constructor */;
+          return container2.kind === 176 /* Constructor */;
         } else {
-          if (isClassLike(container2.parent) || container2.parent.kind === 209 /* ObjectLiteralExpression */) {
+          if (isClassLike(container2.parent) || container2.parent.kind === 210 /* ObjectLiteralExpression */) {
             if (isStatic(container2)) {
-              return container2.kind === 173 /* MethodDeclaration */ || container2.kind === 172 /* MethodSignature */ || container2.kind === 176 /* GetAccessor */ || container2.kind === 177 /* SetAccessor */ || container2.kind === 171 /* PropertyDeclaration */ || container2.kind === 174 /* ClassStaticBlockDeclaration */;
+              return container2.kind === 174 /* MethodDeclaration */ || container2.kind === 173 /* MethodSignature */ || container2.kind === 177 /* GetAccessor */ || container2.kind === 178 /* SetAccessor */ || container2.kind === 172 /* PropertyDeclaration */ || container2.kind === 175 /* ClassStaticBlockDeclaration */;
             } else {
-              return container2.kind === 173 /* MethodDeclaration */ || container2.kind === 172 /* MethodSignature */ || container2.kind === 176 /* GetAccessor */ || container2.kind === 177 /* SetAccessor */ || container2.kind === 171 /* PropertyDeclaration */ || container2.kind === 170 /* PropertySignature */ || container2.kind === 175 /* Constructor */;
+              return container2.kind === 174 /* MethodDeclaration */ || container2.kind === 173 /* MethodSignature */ || container2.kind === 177 /* GetAccessor */ || container2.kind === 178 /* SetAccessor */ || container2.kind === 172 /* PropertyDeclaration */ || container2.kind === 171 /* PropertySignature */ || container2.kind === 176 /* Constructor */;
             }
           }
         }
@@ -168182,7 +152013,7 @@ ${lanes.join("\n")}
       }
     }
     function getContainingObjectLiteral(func) {
-      return (func.kind === 173 /* MethodDeclaration */ || func.kind === 176 /* GetAccessor */ || func.kind === 177 /* SetAccessor */) && func.parent.kind === 209 /* ObjectLiteralExpression */ ? func.parent : func.kind === 217 /* FunctionExpression */ && func.parent.kind === 302 /* PropertyAssignment */ ? func.parent.parent : void 0;
+      return (func.kind === 174 /* MethodDeclaration */ || func.kind === 177 /* GetAccessor */ || func.kind === 178 /* SetAccessor */) && func.parent.kind === 210 /* ObjectLiteralExpression */ ? func.parent : func.kind === 218 /* FunctionExpression */ && func.parent.kind === 303 /* PropertyAssignment */ ? func.parent.parent : void 0;
     }
     function getThisTypeArgument(type) {
       return getObjectFlags(type) & 4 /* Reference */ && type.target === globalThisType ? getTypeArguments(type)[0] : void 0;
@@ -168192,8 +152023,27 @@ ${lanes.join("\n")}
         return t.flags & 2097152 /* Intersection */ ? forEach(t.types, getThisTypeArgument) : getThisTypeArgument(t);
       });
     }
+    function getThisTypeOfObjectLiteralFromContextualType(containingLiteral, contextualType) {
+      let literal = containingLiteral;
+      let type = contextualType;
+      while (type) {
+        const thisType = getThisTypeFromContextualType(type);
+        if (thisType) {
+          return thisType;
+        }
+        if (literal.parent.kind !== 303 /* PropertyAssignment */) {
+          break;
+        }
+        literal = literal.parent.parent;
+        type = getApparentTypeOfContextualType(
+          literal,
+          /*contextFlags*/
+          void 0
+        );
+      }
+    }
     function getContextualThisParameterType(func) {
-      if (func.kind === 218 /* ArrowFunction */) {
+      if (func.kind === 219 /* ArrowFunction */) {
         return void 0;
       }
       if (isContextSensitiveFunctionOrObjectLiteralMethod(func)) {
@@ -168214,27 +152064,14 @@ ${lanes.join("\n")}
             /*contextFlags*/
             void 0
           );
-          let literal = containingLiteral;
-          let type = contextualType;
-          while (type) {
-            const thisType = getThisTypeFromContextualType(type);
-            if (thisType) {
-              return instantiateType(thisType, getMapperFromContext(getInferenceContext(containingLiteral)));
-            }
-            if (literal.parent.kind !== 302 /* PropertyAssignment */) {
-              break;
-            }
-            literal = literal.parent.parent;
-            type = getApparentTypeOfContextualType(
-              literal,
-              /*contextFlags*/
-              void 0
-            );
+          const thisType = getThisTypeOfObjectLiteralFromContextualType(containingLiteral, contextualType);
+          if (thisType) {
+            return instantiateType(thisType, getMapperFromContext(getInferenceContext(containingLiteral)));
           }
           return getWidenedType(contextualType ? getNonNullableType(contextualType) : checkExpressionCached(containingLiteral));
         }
         const parent2 = walkUpParenthesizedExpressions(func.parent);
-        if (parent2.kind === 225 /* BinaryExpression */ && parent2.operatorToken.kind === 64 /* EqualsToken */) {
+        if (isAssignmentExpression(parent2)) {
           const target = parent2.left;
           if (isAccessExpression(target)) {
             const { expression } = target;
@@ -168289,11 +152126,11 @@ ${lanes.join("\n")}
         return getTypeFromTypeNode(typeNode);
       }
       switch (declaration.kind) {
-        case 168 /* Parameter */:
+        case 169 /* Parameter */:
           return getContextuallyTypedParameterType(declaration);
-        case 207 /* BindingElement */:
+        case 208 /* BindingElement */:
           return getContextualTypeForBindingElement(declaration, contextFlags);
-        case 171 /* PropertyDeclaration */:
+        case 172 /* PropertyDeclaration */:
           if (isStatic(declaration)) {
             return getContextualTypeForStaticPropertyDeclaration(declaration, contextFlags);
           }
@@ -168302,10 +152139,10 @@ ${lanes.join("\n")}
     function getContextualTypeForBindingElement(declaration, contextFlags) {
       const parent2 = declaration.parent.parent;
       const name = declaration.propertyName || declaration.name;
-      const parentType = getContextualTypeForVariableLikeDeclaration(parent2, contextFlags) || parent2.kind !== 207 /* BindingElement */ && parent2.initializer && checkDeclarationInitializer(parent2, declaration.dotDotDotToken ? 64 /* RestBindingElement */ : 0 /* Normal */);
+      const parentType = getContextualTypeForVariableLikeDeclaration(parent2, contextFlags) || parent2.kind !== 208 /* BindingElement */ && parent2.initializer && checkDeclarationInitializer(parent2, declaration.dotDotDotToken ? 32 /* RestBindingElement */ : 0 /* Normal */);
       if (!parentType || isBindingPattern(name) || isComputedNonLiteralName(name))
         return void 0;
-      if (parent2.name.kind === 206 /* ArrayBindingPattern */) {
+      if (parent2.name.kind === 207 /* ArrayBindingPattern */) {
         const index = indexOfNode(declaration.parent.elements, declaration);
         if (index < 0)
           return void 0;
@@ -168423,7 +152260,24 @@ ${lanes.join("\n")}
       }
       const signature = getContextualSignatureForFunctionLikeDeclaration(functionDecl);
       if (signature && !isResolvingReturnTypeOfSignature(signature)) {
-        return getReturnTypeOfSignature(signature);
+        const returnType2 = getReturnTypeOfSignature(signature);
+        const functionFlags = getFunctionFlags(functionDecl);
+        if (functionFlags & 1 /* Generator */) {
+          return filterType(returnType2, (t) => {
+            return !!(t.flags & (3 /* AnyOrUnknown */ | 16384 /* Void */ | 58982400 /* InstantiableNonPrimitive */)) || checkGeneratorInstantiationAssignabilityToReturnType(
+              t,
+              functionFlags,
+              /*errorNode*/
+              void 0
+            );
+          });
+        }
+        if (functionFlags & 2 /* Async */) {
+          return filterType(returnType2, (t) => {
+            return !!(t.flags & (3 /* AnyOrUnknown */ | 16384 /* Void */ | 58982400 /* InstantiableNonPrimitive */)) || !!getAwaitedTypeOfPromise(t);
+          });
+        }
+        return returnType2;
       }
       const iife = getImmediatelyInvokedFunctionExpression(functionDecl);
       if (iife) {
@@ -168455,7 +152309,7 @@ ${lanes.join("\n")}
       return signature ? getOrCreateTypeFromSignature(signature) : void 0;
     }
     function getContextualTypeForSubstitutionExpression(template, substitutionExpression) {
-      if (template.parent.kind === 214 /* TaggedTemplateExpression */) {
+      if (template.parent.kind === 215 /* TaggedTemplateExpression */) {
         return getContextualTypeForArgument(template.parent, substitutionExpression);
       }
       return void 0;
@@ -168646,7 +152500,7 @@ ${lanes.join("\n")}
           } else if (t.flags & 3670016 /* StructuredType */) {
             const prop = getPropertyOfType(t, name);
             if (prop) {
-              return isCircularMappedProperty(prop) ? void 0 : getTypeOfSymbol(prop);
+              return isCircularMappedProperty(prop) ? void 0 : removeMissingType(getTypeOfSymbol(prop), !!(prop && prop.flags & 16777216 /* Optional */));
             }
             if (isTupleType(t) && isNumericLiteralName(name) && +name >= 0) {
               const restType = getElementTypeOfSliceOfTupleType(
@@ -168673,7 +152527,7 @@ ${lanes.join("\n")}
     }
     function getContextualTypeForObjectLiteralMethod(node, contextFlags) {
       Debug.assert(isObjectLiteralMethod(node));
-      if (node.flags & 33554432 /* InWithStatement */) {
+      if (node.flags & 67108864 /* InWithStatement */) {
         return void 0;
       }
       return getContextualTypeForObjectLiteralElement(node, contextFlags);
@@ -168731,7 +152585,7 @@ ${lanes.join("\n")}
         (t) => {
           if (isTupleType(t)) {
             if ((firstSpreadIndex === void 0 || index < firstSpreadIndex) && index < t.target.fixedLength) {
-              return getTypeArguments(t)[index];
+              return removeMissingType(getTypeArguments(t)[index], !!(t.target.elementFlags[index] && 2 /* Optional */));
             }
             const offset = length2 !== void 0 && (lastSpreadIndex === void 0 || index > lastSpreadIndex) ? length2 - index : 0;
             const fixedEndLength = offset > 0 && t.target.hasRestElement ? getEndElementCount(t.target, 3 /* Fixed */) : 0;
@@ -168809,16 +152663,17 @@ ${lanes.join("\n")}
         case 9 /* NumericLiteral */:
         case 10 /* BigIntLiteral */:
         case 15 /* NoSubstitutionTemplateLiteral */:
+        case 228 /* TemplateExpression */:
         case 112 /* TrueKeyword */:
         case 97 /* FalseKeyword */:
         case 106 /* NullKeyword */:
         case 80 /* Identifier */:
         case 157 /* UndefinedKeyword */:
           return true;
-        case 210 /* PropertyAccessExpression */:
-        case 216 /* ParenthesizedExpression */:
+        case 211 /* PropertyAccessExpression */:
+        case 217 /* ParenthesizedExpression */:
           return isPossiblyDiscriminantValue(node.expression);
-        case 293 /* JsxExpression */:
+        case 294 /* JsxExpression */:
           return !node.expression || isPossiblyDiscriminantValue(node.expression);
       }
       return false;
@@ -168828,8 +152683,19 @@ ${lanes.join("\n")}
         contextualType,
         concatenate(
           map(
-            filter(node.properties, (p) => !!p.symbol && p.kind === 302 /* PropertyAssignment */ && isPossiblyDiscriminantValue(p.initializer) && isDiscriminantProperty(contextualType, p.symbol.escapedName)),
-            (prop) => [() => getContextFreeTypeOfExpression(prop.initializer), prop.symbol.escapedName]
+            filter(node.properties, (p) => {
+              if (!p.symbol) {
+                return false;
+              }
+              if (p.kind === 303 /* PropertyAssignment */) {
+                return isPossiblyDiscriminantValue(p.initializer) && isDiscriminantProperty(contextualType, p.symbol.escapedName);
+              }
+              if (p.kind === 304 /* ShorthandPropertyAssignment */) {
+                return isDiscriminantProperty(contextualType, p.symbol.escapedName);
+              }
+              return false;
+            }),
+            (prop) => [() => getContextFreeTypeOfExpression(prop.kind === 303 /* PropertyAssignment */ ? prop.initializer : prop.name), prop.symbol.escapedName]
           ),
           map(
             filter(getPropertiesOfType(contextualType), (s) => {
@@ -168848,7 +152714,7 @@ ${lanes.join("\n")}
         contextualType,
         concatenate(
           map(
-            filter(node.properties, (p) => !!p.symbol && p.kind === 290 /* JsxAttribute */ && isDiscriminantProperty(contextualType, p.symbol.escapedName) && (!p.initializer || isPossiblyDiscriminantValue(p.initializer))),
+            filter(node.properties, (p) => !!p.symbol && p.kind === 291 /* JsxAttribute */ && isDiscriminantProperty(contextualType, p.symbol.escapedName) && (!p.initializer || isPossiblyDiscriminantValue(p.initializer))),
             (prop) => [!prop.initializer ? () => trueType : () => getContextFreeTypeOfExpression(prop.initializer), prop.symbol.escapedName]
           ),
           map(
@@ -168913,7 +152779,7 @@ ${lanes.join("\n")}
     }
     function getContextualType2(node, contextFlags) {
       var _a;
-      if (node.flags & 33554432 /* InWithStatement */) {
+      if (node.flags & 67108864 /* InWithStatement */) {
         return void 0;
       }
       const index = findContextualNode(
@@ -168926,47 +152792,47 @@ ${lanes.join("\n")}
       }
       const { parent: parent2 } = node;
       switch (parent2.kind) {
-        case 259 /* VariableDeclaration */:
-        case 168 /* Parameter */:
-        case 171 /* PropertyDeclaration */:
-        case 170 /* PropertySignature */:
-        case 207 /* BindingElement */:
+        case 260 /* VariableDeclaration */:
+        case 169 /* Parameter */:
+        case 172 /* PropertyDeclaration */:
+        case 171 /* PropertySignature */:
+        case 208 /* BindingElement */:
           return getContextualTypeForInitializerExpression(node, contextFlags);
-        case 218 /* ArrowFunction */:
-        case 252 /* ReturnStatement */:
+        case 219 /* ArrowFunction */:
+        case 253 /* ReturnStatement */:
           return getContextualTypeForReturnExpression(node, contextFlags);
-        case 228 /* YieldExpression */:
+        case 229 /* YieldExpression */:
           return getContextualTypeForYieldOperand(parent2, contextFlags);
-        case 222 /* AwaitExpression */:
+        case 223 /* AwaitExpression */:
           return getContextualTypeForAwaitOperand(parent2, contextFlags);
-        case 212 /* CallExpression */:
-        case 213 /* NewExpression */:
+        case 213 /* CallExpression */:
+        case 214 /* NewExpression */:
           return getContextualTypeForArgument(parent2, node);
-        case 169 /* Decorator */:
+        case 170 /* Decorator */:
           return getContextualTypeForDecorator(parent2);
-        case 215 /* TypeAssertionExpression */:
-        case 233 /* AsExpression */:
+        case 216 /* TypeAssertionExpression */:
+        case 234 /* AsExpression */:
           return isConstTypeReference(parent2.type) ? getContextualType2(parent2, contextFlags) : getTypeFromTypeNode(parent2.type);
-        case 225 /* BinaryExpression */:
+        case 226 /* BinaryExpression */:
           return getContextualTypeForBinaryOperand(node, contextFlags);
-        case 302 /* PropertyAssignment */:
-        case 303 /* ShorthandPropertyAssignment */:
+        case 303 /* PropertyAssignment */:
+        case 304 /* ShorthandPropertyAssignment */:
           return getContextualTypeForObjectLiteralElement(parent2, contextFlags);
-        case 304 /* SpreadAssignment */:
+        case 305 /* SpreadAssignment */:
           return getContextualType2(parent2.parent, contextFlags);
-        case 208 /* ArrayLiteralExpression */: {
+        case 209 /* ArrayLiteralExpression */: {
           const arrayLiteral = parent2;
           const type = getApparentTypeOfContextualType(arrayLiteral, contextFlags);
           const elementIndex = indexOfNode(arrayLiteral.elements, node);
           const spreadIndices = (_a = getNodeLinks(arrayLiteral)).spreadIndices ?? (_a.spreadIndices = getSpreadIndices(arrayLiteral.elements));
           return getContextualTypeForElementExpression(type, elementIndex, arrayLiteral.elements.length, spreadIndices.first, spreadIndices.last);
         }
-        case 226 /* ConditionalExpression */:
+        case 227 /* ConditionalExpression */:
           return getContextualTypeForConditionalOperand(node, contextFlags);
-        case 238 /* TemplateSpan */:
-          Debug.assert(parent2.parent.kind === 227 /* TemplateExpression */);
+        case 239 /* TemplateSpan */:
+          Debug.assert(parent2.parent.kind === 228 /* TemplateExpression */);
           return getContextualTypeForSubstitutionExpression(parent2.parent, node);
-        case 216 /* ParenthesizedExpression */: {
+        case 217 /* ParenthesizedExpression */: {
           if (isInJSFile(parent2)) {
             if (isJSDocSatisfiesExpression(parent2)) {
               return getTypeFromTypeNode(getJSDocSatisfiesExpressionType(parent2));
@@ -168978,19 +152844,19 @@ ${lanes.join("\n")}
           }
           return getContextualType2(parent2, contextFlags);
         }
-        case 234 /* NonNullExpression */:
+        case 235 /* NonNullExpression */:
           return getContextualType2(parent2, contextFlags);
-        case 237 /* SatisfiesExpression */:
+        case 238 /* SatisfiesExpression */:
           return getTypeFromTypeNode(parent2.type);
-        case 276 /* ExportAssignment */:
+        case 277 /* ExportAssignment */:
           return tryGetTypeFromEffectiveTypeNode(parent2);
-        case 293 /* JsxExpression */:
+        case 294 /* JsxExpression */:
           return getContextualTypeForJsxExpression(parent2, contextFlags);
-        case 290 /* JsxAttribute */:
-        case 292 /* JsxSpreadAttribute */:
+        case 291 /* JsxAttribute */:
+        case 293 /* JsxSpreadAttribute */:
           return getContextualTypeForJsxAttribute(parent2, contextFlags);
-        case 285 /* JsxOpeningElement */:
-        case 284 /* JsxSelfClosingElement */:
+        case 286 /* JsxOpeningElement */:
+        case 285 /* JsxSelfClosingElement */:
           return getContextualJsxElementAttributesType(parent2, contextFlags);
       }
       return void 0;
@@ -169117,7 +152983,7 @@ ${lanes.join("\n")}
       let attributesType = forcedLookupLocation === void 0 ? getTypeOfFirstParameterOfSignatureWithFallback(sig, unknownType) : forcedLookupLocation === "" ? getReturnTypeOfSignature(sig) : getJsxPropsTypeForSignatureFromMember(sig, forcedLookupLocation);
       if (!attributesType) {
         if (!!forcedLookupLocation && !!length(context.attributes.properties)) {
-          error(context, Diagnostics.JSX_element_class_does_not_support_attributes_because_it_does_not_have_a_0_property, unescapeLeadingUnderscores(forcedLookupLocation));
+          error2(context, Diagnostics.JSX_element_class_does_not_support_attributes_because_it_does_not_have_a_0_property, unescapeLeadingUnderscores(forcedLookupLocation));
         }
         return unknownType;
       }
@@ -169219,7 +153085,7 @@ ${lanes.join("\n")}
         /*resolvedTypePredicate*/
         void 0,
         minArgCount,
-        (left.flags | right.flags) & 39 /* PropagatingFlags */
+        (left.flags | right.flags) & 167 /* PropagatingFlags */
       );
       result.compositeKind = 2097152 /* Intersection */;
       result.compositeSignatures = concatenate(left.compositeKind === 2097152 /* Intersection */ && left.compositeSignatures || [left], [right]);
@@ -169250,7 +153116,7 @@ ${lanes.join("\n")}
       return isFunctionExpressionOrArrowFunction(node) || isObjectLiteralMethod(node) ? getContextualSignature(node) : void 0;
     }
     function getContextualSignature(node) {
-      Debug.assert(node.kind !== 173 /* MethodDeclaration */ || isObjectLiteralMethod(node));
+      Debug.assert(node.kind !== 174 /* MethodDeclaration */ || isObjectLiteralMethod(node));
       const typeTagSignature = getSignatureOfTypeTag(node);
       if (typeTagSignature) {
         return typeTagSignature;
@@ -169301,7 +153167,11 @@ ${lanes.join("\n")}
       return node.isSpread ? getIndexedAccessType(node.type, numberType) : node.type;
     }
     function hasDefaultValue(node) {
-      return node.kind === 207 /* BindingElement */ && !!node.initializer || node.kind === 225 /* BinaryExpression */ && node.operatorToken.kind === 64 /* EqualsToken */;
+      return node.kind === 208 /* BindingElement */ && !!node.initializer || node.kind === 226 /* BinaryExpression */ && node.operatorToken.kind === 64 /* EqualsToken */;
+    }
+    function isSpreadIntoCallOrNew(node) {
+      const parent2 = walkUpParenthesizedExpressions(node.parent);
+      return isSpreadElement(parent2) && isCallOrNewExpression(parent2.parent);
     }
     function checkArrayLiteral(node, checkMode, forceTuple) {
       const elements = node.elements;
@@ -169310,18 +153180,17 @@ ${lanes.join("\n")}
       const elementFlags = [];
       pushCachedContextualType(node);
       const inDestructuringPattern = isAssignmentTarget(node);
-      const isSpreadIntoCallOrNew = isSpreadElement(node.parent) && isCallOrNewExpression(node.parent.parent);
-      const inConstContext = isSpreadIntoCallOrNew || isConstContext(node);
+      const inConstContext = isConstContext(node);
       const contextualType = getApparentTypeOfContextualType(
         node,
         /*contextFlags*/
         void 0
       );
-      const inTupleContext = isSpreadIntoCallOrNew || !!contextualType && someType(contextualType, isTupleLikeType);
+      const inTupleContext = isSpreadIntoCallOrNew(node) || !!contextualType && someType(contextualType, isTupleLikeType);
       let hasOmittedExpression = false;
       for (let i = 0; i < elementCount; i++) {
         const e = elements[i];
-        if (e.kind === 229 /* SpreadElement */) {
+        if (e.kind === 230 /* SpreadElement */) {
           if (languageVersion < 2 /* ES2015 */) {
             checkExternalEmitHelpers(e, compilerOptions.downlevelIteration ? 1536 /* SpreadIncludes */ : 1024 /* SpreadArray */);
           }
@@ -169345,7 +153214,7 @@ ${lanes.join("\n")}
             elementTypes.push(checkIteratedTypeOrElementType(33 /* Spread */, spreadType, undefinedType, e.expression));
             elementFlags.push(4 /* Rest */);
           }
-        } else if (exactOptionalPropertyTypes && e.kind === 231 /* OmittedExpression */) {
+        } else if (exactOptionalPropertyTypes && e.kind === 232 /* OmittedExpression */) {
           hasOmittedExpression = true;
           elementTypes.push(undefinedOrMissingType);
           elementFlags.push(2 /* Optional */);
@@ -169374,10 +153243,13 @@ ${lanes.join("\n")}
           elementTypes,
           elementFlags,
           /*readonly*/
-          inConstContext
+          inConstContext && !(contextualType && someType(contextualType, isMutableArrayLikeType))
         ));
       }
-      return createArrayLiteralType(createArrayType(elementTypes.length ? getUnionType(sameMap(elementTypes, (t, i) => elementFlags[i] & 8 /* Variadic */ ? getIndexedAccessTypeOrUndefined(t, numberType) || anyType : t), 2 /* Subtype */) : strictNullChecks ? implicitNeverType : undefinedWideningType, inConstContext));
+      return createArrayLiteralType(createArrayType(
+        elementTypes.length ? getUnionType(sameMap(elementTypes, (t, i) => elementFlags[i] & 8 /* Variadic */ ? getIndexedAccessTypeOrUndefined(t, numberType) || anyType : t), 2 /* Subtype */) : strictNullChecks ? implicitNeverType : undefinedWideningType,
+        inConstContext
+      ));
     }
     function createArrayLiteralType(type) {
       if (!(getObjectFlags(type) & 4 /* Reference */)) {
@@ -169392,7 +153264,7 @@ ${lanes.join("\n")}
     }
     function isNumericName(name) {
       switch (name.kind) {
-        case 166 /* ComputedPropertyName */:
+        case 167 /* ComputedPropertyName */:
           return isNumericComputedName(name);
         case 80 /* Identifier */:
           return isNumericLiteralName(name.escapedText);
@@ -169409,7 +153281,7 @@ ${lanes.join("\n")}
     function checkComputedPropertyName(node) {
       const links = getNodeLinks(node.expression);
       if (!links.resolvedType) {
-        if ((isTypeLiteralNode(node.parent.parent) || isClassLike(node.parent.parent) || isInterfaceDeclaration(node.parent.parent)) && isBinaryExpression(node.expression) && node.expression.operatorToken.kind === 103 /* InKeyword */ && node.parent.kind !== 176 /* GetAccessor */ && node.parent.kind !== 177 /* SetAccessor */) {
+        if ((isTypeLiteralNode(node.parent.parent) || isClassLike(node.parent.parent) || isInterfaceDeclaration(node.parent.parent)) && isBinaryExpression(node.expression) && node.expression.operatorToken.kind === 103 /* InKeyword */ && node.parent.kind !== 177 /* GetAccessor */ && node.parent.kind !== 178 /* SetAccessor */) {
           return links.resolvedType = errorType;
         }
         links.resolvedType = checkExpression(node.expression);
@@ -169423,7 +153295,7 @@ ${lanes.join("\n")}
           }
         }
         if (links.resolvedType.flags & 98304 /* Nullable */ || !isTypeAssignableToKind(links.resolvedType, 402653316 /* StringLike */ | 296 /* NumberLike */ | 12288 /* ESSymbolLike */) && !isTypeAssignableTo(links.resolvedType, stringNumberSymbolType)) {
-          error(node, Diagnostics.A_computed_property_name_must_be_of_type_string_number_symbol_or_any);
+          error2(node, Diagnostics.A_computed_property_name_must_be_of_type_string_number_symbol_or_any);
         }
       }
       return links.resolvedType;
@@ -169478,7 +153350,7 @@ ${lanes.join("\n")}
         /*contextFlags*/
         void 0
       );
-      const contextualTypeHasPattern = contextualType && contextualType.pattern && (contextualType.pattern.kind === 205 /* ObjectBindingPattern */ || contextualType.pattern.kind === 209 /* ObjectLiteralExpression */);
+      const contextualTypeHasPattern = contextualType && contextualType.pattern && (contextualType.pattern.kind === 206 /* ObjectBindingPattern */ || contextualType.pattern.kind === 210 /* ObjectLiteralExpression */);
       const inConstContext = isConstContext(node);
       const checkFlags = inConstContext ? 8 /* Readonly */ : 0;
       const isInJavascript = isInJSFile(node) && !isInJsonFile(node);
@@ -169497,13 +153369,13 @@ ${lanes.join("\n")}
       let offset = 0;
       for (const memberDecl of node.properties) {
         let member = getSymbolOfDeclaration(memberDecl);
-        const computedNameType = memberDecl.name && memberDecl.name.kind === 166 /* ComputedPropertyName */ ? checkComputedPropertyName(memberDecl.name) : void 0;
-        if (memberDecl.kind === 302 /* PropertyAssignment */ || memberDecl.kind === 303 /* ShorthandPropertyAssignment */ || isObjectLiteralMethod(memberDecl)) {
-          let type = memberDecl.kind === 302 /* PropertyAssignment */ ? checkPropertyAssignment(memberDecl, checkMode) : (
+        const computedNameType = memberDecl.name && memberDecl.name.kind === 167 /* ComputedPropertyName */ ? checkComputedPropertyName(memberDecl.name) : void 0;
+        if (memberDecl.kind === 303 /* PropertyAssignment */ || memberDecl.kind === 304 /* ShorthandPropertyAssignment */ || isObjectLiteralMethod(memberDecl)) {
+          let type = memberDecl.kind === 303 /* PropertyAssignment */ ? checkPropertyAssignment(memberDecl, checkMode) : (
             // avoid resolving the left side of the ShorthandPropertyAssignment outside of the destructuring
             // for error recovery purposes. For example, if a user wrote `{ a = 100 }` instead of `{ a: 100 }`.
             // we don't want to say "could not find 'a'".
-            memberDecl.kind === 303 /* ShorthandPropertyAssignment */ ? checkExpressionForMutableLocation(!inDestructuringPattern && memberDecl.objectAssignmentInitializer ? memberDecl.objectAssignmentInitializer : memberDecl.name, checkMode) : checkObjectLiteralMethod(memberDecl, checkMode)
+            memberDecl.kind === 304 /* ShorthandPropertyAssignment */ ? checkExpressionForMutableLocation(!inDestructuringPattern && memberDecl.objectAssignmentInitializer ? memberDecl.objectAssignmentInitializer : memberDecl.name, checkMode) : checkObjectLiteralMethod(memberDecl, checkMode)
           );
           if (isInJavascript) {
             const jsDocType = getTypeForDeclarationFromJSDocComment(memberDecl);
@@ -169521,7 +153393,7 @@ ${lanes.join("\n")}
             prop.links.nameType = nameType;
           }
           if (inDestructuringPattern) {
-            const isOptional = memberDecl.kind === 302 /* PropertyAssignment */ && hasDefaultValue(memberDecl.initializer) || memberDecl.kind === 303 /* ShorthandPropertyAssignment */ && memberDecl.objectAssignmentInitializer;
+            const isOptional = memberDecl.kind === 303 /* PropertyAssignment */ && hasDefaultValue(memberDecl.initializer) || memberDecl.kind === 304 /* ShorthandPropertyAssignment */ && memberDecl.objectAssignmentInitializer;
             if (isOptional) {
               prop.flags |= 16777216 /* Optional */;
             }
@@ -169530,12 +153402,7 @@ ${lanes.join("\n")}
             if (impliedProp) {
               prop.flags |= impliedProp.flags & 16777216 /* Optional */;
             } else if (!compilerOptions.suppressExcessPropertyErrors && !getIndexInfoOfType(contextualType, stringType)) {
-              error(
-                memberDecl.name,
-                Diagnostics.Object_literal_may_only_specify_known_properties_and_0_does_not_exist_in_type_1,
-                symbolToString(member),
-                typeToString(contextualType)
-              );
+              error2(memberDecl.name, Diagnostics.Object_literal_may_only_specify_known_properties_and_0_does_not_exist_in_type_1, symbolToString(member), typeToString(contextualType));
             }
           }
           prop.declarations = member.declarations;
@@ -169547,13 +153414,13 @@ ${lanes.join("\n")}
           prop.links.target = member;
           member = prop;
           allPropertiesTable == null ? void 0 : allPropertiesTable.set(prop.escapedName, prop);
-          if (contextualType && checkMode & 2 /* Inferential */ && !(checkMode & 4 /* SkipContextSensitive */) && (memberDecl.kind === 302 /* PropertyAssignment */ || memberDecl.kind === 173 /* MethodDeclaration */) && isContextSensitive(memberDecl)) {
+          if (contextualType && checkMode & 2 /* Inferential */ && !(checkMode & 4 /* SkipContextSensitive */) && (memberDecl.kind === 303 /* PropertyAssignment */ || memberDecl.kind === 174 /* MethodDeclaration */) && isContextSensitive(memberDecl)) {
             const inferenceContext = getInferenceContext(node);
             Debug.assert(inferenceContext);
-            const inferenceNode = memberDecl.kind === 302 /* PropertyAssignment */ ? memberDecl.initializer : memberDecl;
+            const inferenceNode = memberDecl.kind === 303 /* PropertyAssignment */ ? memberDecl.initializer : memberDecl;
             addIntraExpressionInferenceSite(inferenceContext, inferenceNode, type);
           }
-        } else if (memberDecl.kind === 304 /* SpreadAssignment */) {
+        } else if (memberDecl.kind === 305 /* SpreadAssignment */) {
           if (languageVersion < 2 /* ES2015 */) {
             checkExternalEmitHelpers(memberDecl, 2 /* Assign */);
           }
@@ -169577,12 +153444,12 @@ ${lanes.join("\n")}
             }
             spread = getSpreadType(spread, mergedType, node.symbol, objectFlags, inConstContext);
           } else {
-            error(memberDecl, Diagnostics.Spread_types_may_only_be_created_from_object_types);
+            error2(memberDecl, Diagnostics.Spread_types_may_only_be_created_from_object_types);
             spread = errorType;
           }
           continue;
         } else {
-          Debug.assert(memberDecl.kind === 176 /* GetAccessor */ || memberDecl.kind === 177 /* SetAccessor */);
+          Debug.assert(memberDecl.kind === 177 /* GetAccessor */ || memberDecl.kind === 178 /* SetAccessor */);
           checkNodeDeferred(memberDecl);
         }
         if (computedNameType && !(computedNameType.flags & 8576 /* StringOrNumberLiteralOrUnique */)) {
@@ -169605,22 +153472,13 @@ ${lanes.join("\n")}
       }
       popContextualType();
       if (contextualTypeHasPattern) {
-        const rootPatternParent = findAncestor(
-          contextualType.pattern.parent,
-          (n) => n.kind === 259 /* VariableDeclaration */ || n.kind === 225 /* BinaryExpression */ || n.kind === 168 /* Parameter */
-        );
-        const spreadOrOutsideRootObject = findAncestor(
-          node,
-          (n) => n === rootPatternParent || n.kind === 304 /* SpreadAssignment */
-        );
-        if (spreadOrOutsideRootObject.kind !== 304 /* SpreadAssignment */) {
+        const rootPatternParent = findAncestor(contextualType.pattern.parent, (n) => n.kind === 260 /* VariableDeclaration */ || n.kind === 226 /* BinaryExpression */ || n.kind === 169 /* Parameter */);
+        const spreadOrOutsideRootObject = findAncestor(node, (n) => n === rootPatternParent || n.kind === 305 /* SpreadAssignment */);
+        if (spreadOrOutsideRootObject.kind !== 305 /* SpreadAssignment */) {
           for (const prop of getPropertiesOfType(contextualType)) {
             if (!propertiesTable.get(prop.escapedName) && !getPropertyOfType(spread, prop.escapedName)) {
               if (!(prop.flags & 16777216 /* Optional */)) {
-                error(
-                  prop.valueDeclaration || ((_a = tryCast(prop, isTransientSymbol)) == null ? void 0 : _a.links.bindingElement),
-                  Diagnostics.Initializer_provides_no_value_for_this_binding_element_and_the_binding_element_has_no_default_value
-                );
+                error2(prop.valueDeclaration || ((_a = tryCast(prop, isTransientSymbol)) == null ? void 0 : _a.links.bindingElement), Diagnostics.Initializer_provides_no_value_for_this_binding_element_and_the_binding_element_has_no_default_value);
               }
               propertiesTable.set(prop.escapedName, prop);
               propertiesArray.push(prop);
@@ -169692,13 +153550,16 @@ ${lanes.join("\n")}
       checkJsxOpeningLikeElementOrOpeningFragment(node.openingFragment);
       const nodeSourceFile = getSourceFileOfNode(node);
       if (getJSXTransformEnabled(compilerOptions) && (compilerOptions.jsxFactory || nodeSourceFile.pragmas.has("jsx")) && !compilerOptions.jsxFragmentFactory && !nodeSourceFile.pragmas.has("jsxfrag")) {
-        error(node, compilerOptions.jsxFactory ? Diagnostics.The_jsxFragmentFactory_compiler_option_must_be_provided_to_use_JSX_fragments_with_the_jsxFactory_compiler_option : Diagnostics.An_jsxFrag_pragma_is_required_when_using_an_jsx_pragma_with_JSX_fragments);
+        error2(
+          node,
+          compilerOptions.jsxFactory ? Diagnostics.The_jsxFragmentFactory_compiler_option_must_be_provided_to_use_JSX_fragments_with_the_jsxFactory_compiler_option : Diagnostics.An_jsxFrag_pragma_is_required_when_using_an_jsx_pragma_with_JSX_fragments
+        );
       }
       checkJsxChildren(node);
       return getJsxElementTypeAt(node) || anyType;
     }
     function isHyphenatedJsxName(name) {
-      return stringContains(name, "-");
+      return name.includes("-");
     }
     function isJsxIntrinsicTagName(tagName) {
       return isIdentifier(tagName) && isIntrinsicJsxName(tagName.escapedText) || isJsxNamespacedName(tagName);
@@ -169748,7 +153609,7 @@ ${lanes.join("\n")}
             addIntraExpressionInferenceSite(inferenceContext, inferenceNode, exprType);
           }
         } else {
-          Debug.assert(attributeDecl.kind === 292 /* JsxSpreadAttribute */);
+          Debug.assert(attributeDecl.kind === 293 /* JsxSpreadAttribute */);
           if (attributesTable.size > 0) {
             spread = getSpreadType(
               spread,
@@ -169777,7 +153638,7 @@ ${lanes.join("\n")}
               checkSpreadPropOverrides(exprType, allAttributesTable, attributeDecl);
             }
           } else {
-            error(attributeDecl.expression, Diagnostics.Spread_types_may_only_be_created_from_object_types);
+            error2(attributeDecl.expression, Diagnostics.Spread_types_may_only_be_created_from_object_types);
             typeToIntersect = typeToIntersect ? getIntersectionType([typeToIntersect, exprType]) : exprType;
           }
         }
@@ -169794,12 +153655,12 @@ ${lanes.join("\n")}
           );
         }
       }
-      const parent2 = openingLikeElement.parent.kind === 283 /* JsxElement */ ? openingLikeElement.parent : void 0;
-      if (parent2 && parent2.openingElement === openingLikeElement && parent2.children.length > 0) {
+      const parent2 = openingLikeElement.parent.kind === 284 /* JsxElement */ ? openingLikeElement.parent : void 0;
+      if (parent2 && parent2.openingElement === openingLikeElement && getSemanticJsxChildren(parent2.children).length > 0) {
         const childrenTypes = checkJsxChildren(parent2, checkMode);
         if (!hasSpreadAnyType && jsxChildrenPropertyName && jsxChildrenPropertyName !== "") {
           if (explicitlySpecifyChildrenAttribute) {
-            error(attributes, Diagnostics._0_are_specified_twice_The_attribute_named_0_will_be_overwritten, unescapeLeadingUnderscores(jsxChildrenPropertyName));
+            error2(attributes, Diagnostics._0_are_specified_twice_The_attribute_named_0_will_be_overwritten, unescapeLeadingUnderscores(jsxChildrenPropertyName));
           }
           const contextualType2 = getApparentTypeOfContextualType(
             openingLikeElement.attributes,
@@ -169853,7 +153714,7 @@ ${lanes.join("\n")}
           if (!child.containsOnlyTriviaWhiteSpaces) {
             childrenTypes.push(stringType);
           }
-        } else if (child.kind === 293 /* JsxExpression */ && !child.expression) {
+        } else if (child.kind === 294 /* JsxExpression */ && !child.expression) {
           continue;
         } else {
           childrenTypes.push(checkExpressionForMutableLocation(child, checkMode));
@@ -169866,7 +153727,7 @@ ${lanes.join("\n")}
         if (!(right.flags & 16777216 /* Optional */)) {
           const left = props.get(right.escapedName);
           if (left) {
-            const diagnostic = error(left.valueDeclaration, Diagnostics._0_is_specified_more_than_once_so_this_usage_will_be_overwritten, unescapeLeadingUnderscores(left.escapedName));
+            const diagnostic = error2(left.valueDeclaration, Diagnostics._0_is_specified_more_than_once_so_this_usage_will_be_overwritten, unescapeLeadingUnderscores(left.escapedName));
             addRelatedInfo(diagnostic, createDiagnosticForNode(spread, Diagnostics.This_spread_always_overwrites_this_property));
           }
         }
@@ -169888,21 +153749,26 @@ ${lanes.join("\n")}
         if (!isErrorType(intrinsicElementsType)) {
           if (!isIdentifier(node.tagName) && !isJsxNamespacedName(node.tagName))
             return Debug.fail();
-          const intrinsicProp = getPropertyOfType(intrinsicElementsType, isJsxNamespacedName(node.tagName) ? getEscapedTextOfJsxNamespacedName(node.tagName) : node.tagName.escapedText);
+          const propName = isJsxNamespacedName(node.tagName) ? getEscapedTextOfJsxNamespacedName(node.tagName) : node.tagName.escapedText;
+          const intrinsicProp = getPropertyOfType(intrinsicElementsType, propName);
           if (intrinsicProp) {
             links.jsxFlags |= 1 /* IntrinsicNamedElement */;
             return links.resolvedSymbol = intrinsicProp;
           }
-          const indexSignatureType = getIndexTypeOfType(intrinsicElementsType, stringType);
-          if (indexSignatureType) {
+          const indexSymbol = getApplicableIndexSymbol(intrinsicElementsType, getStringLiteralType(unescapeLeadingUnderscores(propName)));
+          if (indexSymbol) {
+            links.jsxFlags |= 2 /* IntrinsicIndexedElement */;
+            return links.resolvedSymbol = indexSymbol;
+          }
+          if (getTypeOfPropertyOrIndexSignatureOfType(intrinsicElementsType, propName)) {
             links.jsxFlags |= 2 /* IntrinsicIndexedElement */;
             return links.resolvedSymbol = intrinsicElementsType.symbol;
           }
-          error(node, Diagnostics.Property_0_does_not_exist_on_type_1, intrinsicTagNameToString(node.tagName), "JSX." + JsxNames.IntrinsicElements);
+          error2(node, Diagnostics.Property_0_does_not_exist_on_type_1, intrinsicTagNameToString(node.tagName), "JSX." + JsxNames.IntrinsicElements);
           return links.resolvedSymbol = unknownSymbol;
         } else {
           if (noImplicitAny) {
-            error(node, Diagnostics.JSX_element_implicitly_has_type_any_because_no_interface_JSX_0_exists, unescapeLeadingUnderscores(JsxNames.IntrinsicElements));
+            error2(node, Diagnostics.JSX_element_implicitly_has_type_any_because_no_interface_JSX_0_exists, unescapeLeadingUnderscores(JsxNames.IntrinsicElements));
           }
           return links.resolvedSymbol = unknownSymbol;
         }
@@ -169985,7 +153851,7 @@ ${lanes.join("\n")}
         } else if (propertiesOfJsxElementAttribPropInterface.length === 1) {
           return propertiesOfJsxElementAttribPropInterface[0].escapedName;
         } else if (propertiesOfJsxElementAttribPropInterface.length > 1 && jsxElementAttribPropInterfaceSym.declarations) {
-          error(jsxElementAttribPropInterfaceSym.declarations[0], Diagnostics.The_global_type_JSX_0_may_not_have_more_than_one_property, unescapeLeadingUnderscores(nameOfAttribPropContainer));
+          error2(jsxElementAttribPropInterfaceSym.declarations[0], Diagnostics.The_global_type_JSX_0_may_not_have_more_than_one_property, unescapeLeadingUnderscores(nameOfAttribPropContainer));
         }
       }
       return void 0;
@@ -170008,7 +153874,7 @@ ${lanes.join("\n")}
       } else if (elementType.flags & 128 /* StringLiteral */) {
         const intrinsicType = getIntrinsicAttributesTypeFromStringLiteralType(elementType, caller);
         if (!intrinsicType) {
-          error(caller, Diagnostics.Property_0_does_not_exist_on_type_1, elementType.value, "JSX." + JsxNames.IntrinsicElements);
+          error2(caller, Diagnostics.Property_0_does_not_exist_on_type_1, elementType.value, "JSX." + JsxNames.IntrinsicElements);
           return emptyArray;
         } else {
           const fakeSignature = createSignatureForJSXIntrinsic(caller, intrinsicType);
@@ -170072,6 +153938,7 @@ ${lanes.join("\n")}
       }
     }
     function getIntrinsicAttributesTypeFromJsxOpeningLikeElement(node) {
+      var _a;
       Debug.assert(isJsxIntrinsicTagName(node.tagName));
       const links = getNodeLinks(node);
       if (!links.resolvedJsxElementAttributesType) {
@@ -170079,7 +153946,8 @@ ${lanes.join("\n")}
         if (links.jsxFlags & 1 /* IntrinsicNamedElement */) {
           return links.resolvedJsxElementAttributesType = getTypeOfSymbol(symbol) || errorType;
         } else if (links.jsxFlags & 2 /* IntrinsicIndexedElement */) {
-          return links.resolvedJsxElementAttributesType = getIndexTypeOfType(getJsxType(JsxNames.IntrinsicElements, node), stringType) || errorType;
+          const propName = isJsxNamespacedName(node.tagName) ? getEscapedTextOfJsxNamespacedName(node.tagName) : node.tagName.escapedText;
+          return links.resolvedJsxElementAttributesType = ((_a = getApplicableIndexInfoForName(getJsxType(JsxNames.IntrinsicElements, node), propName)) == null ? void 0 : _a.type) || errorType;
         } else {
           return links.resolvedJsxElementAttributesType = errorType;
         }
@@ -170134,11 +154002,11 @@ ${lanes.join("\n")}
     }
     function checkJsxPreconditions(errorNode) {
       if ((compilerOptions.jsx || 0 /* None */) === 0 /* None */) {
-        error(errorNode, Diagnostics.Cannot_use_JSX_unless_the_jsx_flag_is_provided);
+        error2(errorNode, Diagnostics.Cannot_use_JSX_unless_the_jsx_flag_is_provided);
       }
       if (getJsxElementTypeAt(errorNode) === void 0) {
         if (noImplicitAny) {
-          error(errorNode, Diagnostics.JSX_element_implicitly_has_type_any_because_the_global_type_JSX_Element_does_not_exist);
+          error2(errorNode, Diagnostics.JSX_element_implicitly_has_type_any_because_the_global_type_JSX_Element_does_not_exist);
         }
       }
     }
@@ -170230,7 +154098,7 @@ ${lanes.join("\n")}
       if (node.expression) {
         const type = checkExpression(node.expression, checkMode);
         if (node.dotDotDotToken && type !== anyType && !isArrayType(type)) {
-          error(node, Diagnostics.JSX_spread_child_must_be_an_array_type);
+          error2(node, Diagnostics.JSX_spread_child_must_be_an_array_type);
         }
         return type;
       } else {
@@ -170238,7 +154106,7 @@ ${lanes.join("\n")}
       }
     }
     function getDeclarationNodeFlagsFromSymbol(s) {
-      return s.valueDeclaration ? getCombinedNodeFlags(s.valueDeclaration) : 0;
+      return s.valueDeclaration ? getCombinedNodeFlagsCached(s.valueDeclaration) : 0;
     }
     function isPrototypeProperty(symbol) {
       if (symbol.flags & 8192 /* Method */ || getCheckFlags(symbol) & 4 /* SyntheticMethod */) {
@@ -170250,59 +154118,51 @@ ${lanes.join("\n")}
       }
     }
     function checkPropertyAccessibility(node, isSuper, writing, type, prop, reportError = true) {
-      const errorNode = !reportError ? void 0 : node.kind === 165 /* QualifiedName */ ? node.right : node.kind === 204 /* ImportType */ ? node : node.kind === 207 /* BindingElement */ && node.propertyName ? node.propertyName : node.name;
+      const errorNode = !reportError ? void 0 : node.kind === 166 /* QualifiedName */ ? node.right : node.kind === 205 /* ImportType */ ? node : node.kind === 208 /* BindingElement */ && node.propertyName ? node.propertyName : node.name;
       return checkPropertyAccessibilityAtLocation(node, isSuper, writing, type, prop, errorNode);
     }
     function checkPropertyAccessibilityAtLocation(location, isSuper, writing, containingType, prop, errorNode) {
+      var _a;
       const flags = getDeclarationModifierFlagsFromSymbol(prop, writing);
       if (isSuper) {
         if (languageVersion < 2 /* ES2015 */) {
           if (symbolHasNonMethodDeclaration(prop)) {
             if (errorNode) {
-              error(errorNode, Diagnostics.Only_public_and_protected_methods_of_the_base_class_are_accessible_via_the_super_keyword);
+              error2(errorNode, Diagnostics.Only_public_and_protected_methods_of_the_base_class_are_accessible_via_the_super_keyword);
             }
             return false;
           }
         }
-        if (flags & 256 /* Abstract */) {
+        if (flags & 64 /* Abstract */) {
           if (errorNode) {
-            error(
-              errorNode,
-              Diagnostics.Abstract_method_0_in_class_1_cannot_be_accessed_via_super_expression,
-              symbolToString(prop),
-              typeToString(getDeclaringClass(prop))
-            );
+            error2(errorNode, Diagnostics.Abstract_method_0_in_class_1_cannot_be_accessed_via_super_expression, symbolToString(prop), typeToString(getDeclaringClass(prop)));
+          }
+          return false;
+        }
+        if (!(flags & 256 /* Static */) && ((_a = prop.declarations) == null ? void 0 : _a.some(isClassInstanceProperty))) {
+          if (errorNode) {
+            error2(errorNode, Diagnostics.Class_field_0_defined_by_the_parent_class_is_not_accessible_in_the_child_class_via_super, symbolToString(prop));
           }
           return false;
         }
       }
-      if (flags & 256 /* Abstract */ && symbolHasNonMethodDeclaration(prop) && (isThisProperty(location) || isThisInitializedObjectBindingExpression(location) || isObjectBindingPattern(location.parent) && isThisInitializedDeclaration(location.parent.parent))) {
+      if (flags & 64 /* Abstract */ && symbolHasNonMethodDeclaration(prop) && (isThisProperty(location) || isThisInitializedObjectBindingExpression(location) || isObjectBindingPattern(location.parent) && isThisInitializedDeclaration(location.parent.parent))) {
         const declaringClassDeclaration = getClassLikeDeclarationOfSymbol(getParentOfSymbol(prop));
         if (declaringClassDeclaration && isNodeUsedDuringClassInitialization(location)) {
           if (errorNode) {
-            error(
-              errorNode,
-              Diagnostics.Abstract_property_0_in_class_1_cannot_be_accessed_in_the_constructor,
-              symbolToString(prop),
-              getTextOfIdentifierOrLiteral(declaringClassDeclaration.name)
-            );
+            error2(errorNode, Diagnostics.Abstract_property_0_in_class_1_cannot_be_accessed_in_the_constructor, symbolToString(prop), getTextOfIdentifierOrLiteral(declaringClassDeclaration.name));
           }
           return false;
         }
       }
-      if (!(flags & 24 /* NonPublicAccessibilityModifier */)) {
+      if (!(flags & 6 /* NonPublicAccessibilityModifier */)) {
         return true;
       }
-      if (flags & 8 /* Private */) {
+      if (flags & 2 /* Private */) {
         const declaringClassDeclaration = getClassLikeDeclarationOfSymbol(getParentOfSymbol(prop));
         if (!isNodeWithinClass(location, declaringClassDeclaration)) {
           if (errorNode) {
-            error(
-              errorNode,
-              Diagnostics.Property_0_is_private_and_only_accessible_within_class_1,
-              symbolToString(prop),
-              typeToString(getDeclaringClass(prop))
-            );
+            error2(errorNode, Diagnostics.Property_0_is_private_and_only_accessible_within_class_1, symbolToString(prop), typeToString(getDeclaringClass(prop)));
           }
           return false;
         }
@@ -170318,19 +154178,14 @@ ${lanes.join("\n")}
       if (!enclosingClass) {
         enclosingClass = getEnclosingClassFromThisParameter(location);
         enclosingClass = enclosingClass && isClassDerivedFromDeclaringClasses(enclosingClass, prop, writing);
-        if (flags & 32 /* Static */ || !enclosingClass) {
+        if (flags & 256 /* Static */ || !enclosingClass) {
           if (errorNode) {
-            error(
-              errorNode,
-              Diagnostics.Property_0_is_protected_and_only_accessible_within_class_1_and_its_subclasses,
-              symbolToString(prop),
-              typeToString(getDeclaringClass(prop) || containingType)
-            );
+            error2(errorNode, Diagnostics.Property_0_is_protected_and_only_accessible_within_class_1_and_its_subclasses, symbolToString(prop), typeToString(getDeclaringClass(prop) || containingType));
           }
           return false;
         }
       }
-      if (flags & 32 /* Static */) {
+      if (flags & 256 /* Static */) {
         return true;
       }
       if (containingType.flags & 262144 /* TypeParameter */) {
@@ -170338,13 +154193,7 @@ ${lanes.join("\n")}
       }
       if (!containingType || !hasBaseType(containingType, enclosingClass)) {
         if (errorNode) {
-          error(
-            errorNode,
-            Diagnostics.Property_0_is_protected_and_only_accessible_through_an_instance_of_class_1_This_is_an_instance_of_class_2,
-            symbolToString(prop),
-            typeToString(enclosingClass),
-            typeToString(containingType)
-          );
+          error2(errorNode, Diagnostics.Property_0_is_protected_and_only_accessible_through_an_instance_of_class_1_This_is_an_instance_of_class_2, symbolToString(prop), typeToString(enclosingClass), typeToString(containingType));
         }
         return false;
       }
@@ -170378,7 +154227,7 @@ ${lanes.join("\n")}
       return checkNonNullType(checkExpression(node), node);
     }
     function isNullableType(type) {
-      return !!(getTypeFacts(type) & 50331648 /* IsUndefinedOrNull */);
+      return hasTypeFacts(type, 50331648 /* IsUndefinedOrNull */);
     }
     function getNonNullableTypeIfNeeded(type) {
       return isNullableType(type) ? getNonNullableType(type) : type;
@@ -170386,28 +154235,28 @@ ${lanes.join("\n")}
     function reportObjectPossiblyNullOrUndefinedError(node, facts) {
       const nodeText2 = isEntityNameExpression(node) ? entityNameToString(node) : void 0;
       if (node.kind === 106 /* NullKeyword */) {
-        error(node, Diagnostics.The_value_0_cannot_be_used_here, "null");
+        error2(node, Diagnostics.The_value_0_cannot_be_used_here, "null");
         return;
       }
       if (nodeText2 !== void 0 && nodeText2.length < 100) {
         if (isIdentifier(node) && nodeText2 === "undefined") {
-          error(node, Diagnostics.The_value_0_cannot_be_used_here, "undefined");
+          error2(node, Diagnostics.The_value_0_cannot_be_used_here, "undefined");
           return;
         }
-        error(
+        error2(
           node,
           facts & 16777216 /* IsUndefined */ ? facts & 33554432 /* IsNull */ ? Diagnostics._0_is_possibly_null_or_undefined : Diagnostics._0_is_possibly_undefined : Diagnostics._0_is_possibly_null,
           nodeText2
         );
       } else {
-        error(
+        error2(
           node,
           facts & 16777216 /* IsUndefined */ ? facts & 33554432 /* IsNull */ ? Diagnostics.Object_is_possibly_null_or_undefined : Diagnostics.Object_is_possibly_undefined : Diagnostics.Object_is_possibly_null
         );
       }
     }
     function reportCannotInvokePossiblyNullOrUndefinedError(node, facts) {
-      error(
+      error2(
         node,
         facts & 16777216 /* IsUndefined */ ? facts & 33554432 /* IsNull */ ? Diagnostics.Cannot_invoke_an_object_which_is_possibly_null_or_undefined : Diagnostics.Cannot_invoke_an_object_which_is_possibly_undefined : Diagnostics.Cannot_invoke_an_object_which_is_possibly_null
       );
@@ -170417,14 +154266,14 @@ ${lanes.join("\n")}
         if (isEntityNameExpression(node)) {
           const nodeText2 = entityNameToString(node);
           if (nodeText2.length < 100) {
-            error(node, Diagnostics._0_is_of_type_unknown, nodeText2);
+            error2(node, Diagnostics._0_is_of_type_unknown, nodeText2);
             return errorType;
           }
         }
-        error(node, Diagnostics.Object_is_of_type_unknown);
+        error2(node, Diagnostics.Object_is_of_type_unknown);
         return errorType;
       }
-      const facts = getTypeFacts(type);
+      const facts = getTypeFacts(type, 50331648 /* IsUndefinedOrNull */);
       if (facts & 50331648 /* IsUndefinedOrNull */) {
         reportError(node, facts);
         const t = getNonNullableType(type);
@@ -170441,20 +154290,20 @@ ${lanes.join("\n")}
         if (isEntityNameExpression(node)) {
           const nodeText2 = entityNameToString(node);
           if (isIdentifier(node) && nodeText2 === "undefined") {
-            error(node, Diagnostics.The_value_0_cannot_be_used_here, nodeText2);
+            error2(node, Diagnostics.The_value_0_cannot_be_used_here, nodeText2);
             return nonNullType;
           }
           if (nodeText2.length < 100) {
-            error(node, Diagnostics._0_is_possibly_undefined, nodeText2);
+            error2(node, Diagnostics._0_is_possibly_undefined, nodeText2);
             return nonNullType;
           }
         }
-        error(node, Diagnostics.Object_is_possibly_undefined);
+        error2(node, Diagnostics.Object_is_possibly_undefined);
       }
       return nonNullType;
     }
     function checkPropertyAccessExpression(node, checkMode, writeOnly) {
-      return node.flags & 32 /* OptionalChain */ ? checkPropertyAccessChain(node, checkMode) : checkPropertyAccessExpressionOrQualifiedName(node, node.expression, checkNonNullExpression(node.expression), node.name, checkMode, writeOnly);
+      return node.flags & 64 /* OptionalChain */ ? checkPropertyAccessChain(node, checkMode) : checkPropertyAccessExpressionOrQualifiedName(node, node.expression, checkNonNullExpression(node.expression), node.name, checkMode, writeOnly);
     }
     function checkPropertyAccessChain(node, checkMode) {
       const leftType = checkExpression(node.expression);
@@ -170466,13 +154315,13 @@ ${lanes.join("\n")}
       return checkPropertyAccessExpressionOrQualifiedName(node, node.left, leftType, node.right, checkMode);
     }
     function isMethodAccessForCall(node) {
-      while (node.parent.kind === 216 /* ParenthesizedExpression */) {
+      while (node.parent.kind === 217 /* ParenthesizedExpression */) {
         node = node.parent;
       }
       return isCallOrNewExpression(node.parent) && node.parent.expression === node;
     }
     function lookupSymbolForPrivateIdentifierDeclaration(propName, location) {
-      for (let containingClass = getContainingClass(location); !!containingClass; containingClass = getContainingClass(containingClass)) {
+      for (let containingClass = getContainingClassExcludingClassDecorators(location); !!containingClass; containingClass = getContainingClass(containingClass)) {
         const { symbol } = containingClass;
         const name = getSymbolNameForPrivateIdentifier(symbol, propName);
         const prop = symbol.members && symbol.members.get(name) || symbol.exports && symbol.exports.get(name);
@@ -170544,7 +154393,7 @@ ${lanes.join("\n")}
           const lexicalClass = getContainingClass(lexicalValueDecl);
           Debug.assert(!!lexicalClass);
           if (findAncestor(lexicalClass, (n) => typeClass === n)) {
-            const diagnostic = error(
+            const diagnostic = error2(
               right,
               Diagnostics.The_property_0_cannot_be_accessed_on_type_1_within_this_class_because_it_is_shadowed_by_another_private_identifier_with_the_same_spelling,
               diagName,
@@ -170566,7 +154415,7 @@ ${lanes.join("\n")}
             return true;
           }
         }
-        error(
+        error2(
           right,
           Diagnostics.Property_0_is_not_accessible_outside_class_1_because_it_has_a_private_identifier,
           diagName,
@@ -170608,18 +154457,24 @@ ${lanes.join("\n")}
           if (lexicallyScopedSymbol) {
             return isErrorType(apparentType) ? errorType : apparentType;
           }
-          if (!getContainingClass(right)) {
+          if (getContainingClassExcludingClassDecorators(right) === void 0) {
             grammarErrorOnNode(right, Diagnostics.Private_identifiers_are_not_allowed_outside_class_bodies);
             return anyType;
           }
         }
-        prop = lexicallyScopedSymbol ? getPrivateIdentifierPropertyOfType(leftType, lexicallyScopedSymbol) : void 0;
-        if (!prop && checkPrivateIdentifierPropertyAccess(leftType, right, lexicallyScopedSymbol)) {
-          return errorType;
+        prop = lexicallyScopedSymbol && getPrivateIdentifierPropertyOfType(leftType, lexicallyScopedSymbol);
+        if (prop === void 0) {
+          if (checkPrivateIdentifierPropertyAccess(leftType, right, lexicallyScopedSymbol)) {
+            return errorType;
+          }
+          const containingClass = getContainingClassExcludingClassDecorators(right);
+          if (containingClass && isPlainJsFile(getSourceFileOfNode(containingClass), compilerOptions.checkJs)) {
+            grammarErrorOnNode(right, Diagnostics.Private_field_0_must_be_declared_in_an_enclosing_class, idText(right));
+          }
         } else {
-          const isSetonlyAccessor = prop && prop.flags & 65536 /* SetAccessor */ && !(prop.flags & 32768 /* GetAccessor */);
+          const isSetonlyAccessor = prop.flags & 65536 /* SetAccessor */ && !(prop.flags & 32768 /* GetAccessor */);
           if (isSetonlyAccessor && assignmentKind !== 1 /* Definite */) {
-            error(node, Diagnostics.Private_accessor_was_defined_without_a_getter);
+            error2(node, Diagnostics.Private_accessor_was_defined_without_a_getter);
           }
         }
       } else {
@@ -170633,12 +154488,12 @@ ${lanes.join("\n")}
           apparentType,
           right.escapedText,
           /*skipObjectFunctionPropertyAugment*/
-          false,
+          isConstEnumObjectType(apparentType),
           /*includeTypeOnlyMembers*/
-          node.kind === 165 /* QualifiedName */
+          node.kind === 166 /* QualifiedName */
         );
       }
-      if (isIdentifier(left) && parentSymbol && (getIsolatedModules(compilerOptions) || !(prop && (isConstEnumOrConstEnumOnlyModule(prop) || prop.flags & 8 /* EnumMember */ && node.parent.kind === 305 /* EnumMember */)) || shouldPreserveConstEnums(compilerOptions) && isExportOrExportExpression(node))) {
+      if (isIdentifier(left) && parentSymbol && (getIsolatedModules(compilerOptions) || !(prop && (isConstEnumOrConstEnumOnlyModule(prop) || prop.flags & 8 /* EnumMember */ && node.parent.kind === 306 /* EnumMember */)) || shouldPreserveConstEnums(compilerOptions) && isExportOrExportExpression(node))) {
         markAliasReferenced(parentSymbol, node);
       }
       let propType;
@@ -170656,9 +154511,9 @@ ${lanes.join("\n")}
           }
           if (leftType.symbol === globalThisSymbol) {
             if (globalThisSymbol.exports.has(right.escapedText) && globalThisSymbol.exports.get(right.escapedText).flags & 418 /* BlockScoped */) {
-              error(right, Diagnostics.Property_0_does_not_exist_on_type_1, unescapeLeadingUnderscores(right.escapedText), typeToString(leftType));
+              error2(right, Diagnostics.Property_0_does_not_exist_on_type_1, unescapeLeadingUnderscores(right.escapedText), typeToString(leftType));
             } else if (noImplicitAny) {
-              error(right, Diagnostics.Element_implicitly_has_an_any_type_because_type_0_has_no_index_signature, typeToString(leftType));
+              error2(right, Diagnostics.Element_implicitly_has_an_any_type_because_type_0_has_no_index_signature, typeToString(leftType));
             }
             return anyType;
           }
@@ -170668,13 +154523,13 @@ ${lanes.join("\n")}
           return errorType;
         }
         if (indexInfo.isReadonly && (isAssignmentTarget(node) || isDeleteTarget(node))) {
-          error(node, Diagnostics.Index_signature_in_type_0_only_permits_reading, typeToString(apparentType));
+          error2(node, Diagnostics.Index_signature_in_type_0_only_permits_reading, typeToString(apparentType));
         }
         propType = compilerOptions.noUncheckedIndexedAccess && !isAssignmentTarget(node) ? getUnionType([indexInfo.type, missingType]) : indexInfo.type;
         if (compilerOptions.noPropertyAccessFromIndexSignature && isPropertyAccessExpression(node)) {
-          error(right, Diagnostics.Property_0_comes_from_an_index_signature_so_it_must_be_accessed_with_0, unescapeLeadingUnderscores(right.escapedText));
+          error2(right, Diagnostics.Property_0_comes_from_an_index_signature_so_it_must_be_accessed_with_0, unescapeLeadingUnderscores(right.escapedText));
         }
-        if (indexInfo.declaration && getCombinedNodeFlags(indexInfo.declaration) & 268435456 /* Deprecated */) {
+        if (indexInfo.declaration && isDeprecatedDeclaration2(indexInfo.declaration)) {
           addDeprecatedSuggestion(right, [indexInfo.declaration], right.escapedText);
         }
       } else {
@@ -170687,7 +154542,7 @@ ${lanes.join("\n")}
         getNodeLinks(node).resolvedSymbol = prop;
         checkPropertyAccessibility(node, left.kind === 108 /* SuperKeyword */, isWriteAccess(node), apparentType, prop);
         if (isAssignmentToReadonlyEntity(node, prop, assignmentKind)) {
-          error(right, Diagnostics.Cannot_assign_to_0_because_it_is_a_read_only_property, idText(right));
+          error2(right, Diagnostics.Cannot_assign_to_0_because_it_is_a_read_only_property, idText(right));
           return errorType;
         }
         propType = isThisPropertyAccessInConstructor(node, prop) ? autoType : writeOnly || isWriteOnlyAccess(node) ? getWriteTypeOfSymbol(prop) : getTypeOfSymbol(prop);
@@ -170695,11 +154550,17 @@ ${lanes.join("\n")}
       return getFlowTypeOfAccessExpression(node, prop, propType, right, checkMode);
     }
     function isUncheckedJSSuggestion(node, suggestion, excludeClasses) {
+      var _a;
       const file = getSourceFileOfNode(node);
       if (file) {
         if (compilerOptions.checkJs === void 0 && file.checkJsDirective === void 0 && (file.scriptKind === 1 /* JS */ || file.scriptKind === 2 /* JSX */)) {
           const declarationFile = forEach(suggestion == null ? void 0 : suggestion.declarations, getSourceFileOfNode);
-          return !(file !== declarationFile && !!declarationFile && isGlobalSourceFile(declarationFile)) && !(excludeClasses && suggestion && suggestion.flags & 32 /* Class */) && !(!!node && excludeClasses && isPropertyAccessExpression(node) && node.expression.kind === 110 /* ThisKeyword */);
+          const suggestionHasNoExtendsOrDecorators = !(suggestion == null ? void 0 : suggestion.valueDeclaration) || !isClassLike(suggestion.valueDeclaration) || ((_a = suggestion.valueDeclaration.heritageClauses) == null ? void 0 : _a.length) || classOrConstructorParameterIsDecorated(
+            /*useLegacyDecorators*/
+            false,
+            suggestion.valueDeclaration
+          );
+          return !(file !== declarationFile && !!declarationFile && isGlobalSourceFile(declarationFile)) && !(excludeClasses && suggestion && suggestion.flags & 32 /* Class */ && suggestionHasNoExtendsOrDecorators) && !(!!node && excludeClasses && isPropertyAccessExpression(node) && node.expression.kind === 110 /* ThisKeyword */ && suggestionHasNoExtendsOrDecorators);
         }
       }
       return false;
@@ -170722,7 +154583,7 @@ ${lanes.join("\n")}
         if (declaration && isPropertyWithoutInitializer(declaration)) {
           if (!isStatic(declaration)) {
             const flowContainer = getControlFlowContainer(node);
-            if (flowContainer.kind === 175 /* Constructor */ && flowContainer.parent === declaration.parent && !(declaration.flags & 16777216 /* Ambient */)) {
+            if (flowContainer.kind === 176 /* Constructor */ && flowContainer.parent === declaration.parent && !(declaration.flags & 33554432 /* Ambient */)) {
               assumeUninitialized = true;
             }
           }
@@ -170732,7 +154593,7 @@ ${lanes.join("\n")}
       }
       const flowType = getFlowTypeOfReference(node, propType, assumeUninitialized ? getOptionalType(propType) : propType);
       if (assumeUninitialized && !containsUndefinedType(propType) && containsUndefinedType(flowType)) {
-        error(errorNode, Diagnostics.Property_0_is_used_before_being_assigned, symbolToString(prop));
+        error2(errorNode, Diagnostics.Property_0_is_used_before_being_assigned, symbolToString(prop));
         return propType;
       }
       return assignmentKind ? getBaseTypeOfLiteralType(flowType) : flowType;
@@ -170744,40 +154605,37 @@ ${lanes.join("\n")}
       }
       let diagnosticMessage;
       const declarationName = idText(right);
-      if (isInPropertyInitializerOrClassStaticBlock(node) && !isOptionalPropertyDeclaration(valueDeclaration) && !(isAccessExpression(node) && isAccessExpression(node.expression)) && !isBlockScopedNameDeclaredBeforeUse(valueDeclaration, right) && !(isMethodDeclaration(valueDeclaration) && getCombinedModifierFlags(valueDeclaration) & 32 /* Static */) && (compilerOptions.useDefineForClassFields || !isPropertyDeclaredInAncestorClass(prop))) {
-        diagnosticMessage = error(right, Diagnostics.Property_0_is_used_before_its_initialization, declarationName);
-      } else if (valueDeclaration.kind === 262 /* ClassDeclaration */ && node.parent.kind !== 182 /* TypeReference */ && !(valueDeclaration.flags & 16777216 /* Ambient */) && !isBlockScopedNameDeclaredBeforeUse(valueDeclaration, right)) {
-        diagnosticMessage = error(right, Diagnostics.Class_0_used_before_its_declaration, declarationName);
+      if (isInPropertyInitializerOrClassStaticBlock(node) && !isOptionalPropertyDeclaration(valueDeclaration) && !(isAccessExpression(node) && isAccessExpression(node.expression)) && !isBlockScopedNameDeclaredBeforeUse(valueDeclaration, right) && !(isMethodDeclaration(valueDeclaration) && getCombinedModifierFlagsCached(valueDeclaration) & 256 /* Static */) && (useDefineForClassFields || !isPropertyDeclaredInAncestorClass(prop))) {
+        diagnosticMessage = error2(right, Diagnostics.Property_0_is_used_before_its_initialization, declarationName);
+      } else if (valueDeclaration.kind === 263 /* ClassDeclaration */ && node.parent.kind !== 183 /* TypeReference */ && !(valueDeclaration.flags & 33554432 /* Ambient */) && !isBlockScopedNameDeclaredBeforeUse(valueDeclaration, right)) {
+        diagnosticMessage = error2(right, Diagnostics.Class_0_used_before_its_declaration, declarationName);
       }
       if (diagnosticMessage) {
-        addRelatedInfo(
-          diagnosticMessage,
-          createDiagnosticForNode(valueDeclaration, Diagnostics._0_is_declared_here, declarationName)
-        );
+        addRelatedInfo(diagnosticMessage, createDiagnosticForNode(valueDeclaration, Diagnostics._0_is_declared_here, declarationName));
       }
     }
     function isInPropertyInitializerOrClassStaticBlock(node) {
       return !!findAncestor(node, (node2) => {
         switch (node2.kind) {
-          case 171 /* PropertyDeclaration */:
+          case 172 /* PropertyDeclaration */:
             return true;
-          case 302 /* PropertyAssignment */:
-          case 173 /* MethodDeclaration */:
-          case 176 /* GetAccessor */:
-          case 177 /* SetAccessor */:
-          case 304 /* SpreadAssignment */:
-          case 166 /* ComputedPropertyName */:
-          case 238 /* TemplateSpan */:
-          case 293 /* JsxExpression */:
-          case 290 /* JsxAttribute */:
-          case 291 /* JsxAttributes */:
-          case 292 /* JsxSpreadAttribute */:
-          case 285 /* JsxOpeningElement */:
-          case 232 /* ExpressionWithTypeArguments */:
-          case 297 /* HeritageClause */:
+          case 303 /* PropertyAssignment */:
+          case 174 /* MethodDeclaration */:
+          case 177 /* GetAccessor */:
+          case 178 /* SetAccessor */:
+          case 305 /* SpreadAssignment */:
+          case 167 /* ComputedPropertyName */:
+          case 239 /* TemplateSpan */:
+          case 294 /* JsxExpression */:
+          case 291 /* JsxAttribute */:
+          case 292 /* JsxAttributes */:
+          case 293 /* JsxSpreadAttribute */:
+          case 286 /* JsxOpeningElement */:
+          case 233 /* ExpressionWithTypeArguments */:
+          case 298 /* HeritageClause */:
             return false;
-          case 218 /* ArrowFunction */:
-          case 243 /* ExpressionStatement */:
+          case 219 /* ArrowFunction */:
+          case 244 /* ExpressionStatement */:
             return isBlock(node2.parent) && isClassStaticBlockDeclaration(node2.parent.parent) ? true : "quit";
           default:
             return isExpressionNode(node2) ? false : "quit";
@@ -171001,7 +154859,7 @@ ${lanes.join("\n")}
       if (!valueDeclaration) {
         return;
       }
-      const hasPrivateModifier = hasEffectiveModifier(valueDeclaration, 8 /* Private */);
+      const hasPrivateModifier = hasEffectiveModifier(valueDeclaration, 2 /* Private */);
       const hasPrivateIdentifier = prop.valueDeclaration && isNamedDeclaration(prop.valueDeclaration) && isPrivateIdentifier(prop.valueDeclaration.name);
       if (!hasPrivateModifier && !hasPrivateIdentifier) {
         return;
@@ -171022,9 +154880,9 @@ ${lanes.join("\n")}
     }
     function isValidPropertyAccess(node, propertyName) {
       switch (node.kind) {
-        case 210 /* PropertyAccessExpression */:
+        case 211 /* PropertyAccessExpression */:
           return isValidPropertyAccessWithType(node, node.expression.kind === 108 /* SuperKeyword */, propertyName, getWidenedType(checkExpression(node.expression)));
-        case 165 /* QualifiedName */:
+        case 166 /* QualifiedName */:
           return isValidPropertyAccessWithType(
             node,
             /*isSuper*/
@@ -171032,7 +154890,7 @@ ${lanes.join("\n")}
             propertyName,
             getWidenedType(checkExpression(node.left))
           );
-        case 204 /* ImportType */:
+        case 205 /* ImportType */:
           return isValidPropertyAccessWithType(
             node,
             /*isSuper*/
@@ -171045,7 +154903,7 @@ ${lanes.join("\n")}
     function isValidPropertyAccessForCompletions(node, type, property) {
       return isPropertyAccessible(
         node,
-        node.kind === 210 /* PropertyAccessExpression */ && node.expression.kind === 108 /* SuperKeyword */,
+        node.kind === 211 /* PropertyAccessExpression */ && node.expression.kind === 108 /* SuperKeyword */,
         /*isWrite*/
         false,
         type,
@@ -171078,7 +154936,7 @@ ${lanes.join("\n")}
     }
     function getForInVariableSymbol(node) {
       const initializer = node.initializer;
-      if (initializer.kind === 260 /* VariableDeclarationList */) {
+      if (initializer.kind === 261 /* VariableDeclarationList */) {
         const variable = initializer.declarations[0];
         if (variable && !isBindingPattern(variable.name)) {
           return getSymbolOfDeclaration(variable);
@@ -171099,7 +154957,7 @@ ${lanes.join("\n")}
           let child = expr;
           let node = expr.parent;
           while (node) {
-            if (node.kind === 248 /* ForInStatement */ && child === node.statement && getForInVariableSymbol(node) === symbol && hasNumericPropertyNames(getTypeOfExpression(node.expression))) {
+            if (node.kind === 249 /* ForInStatement */ && child === node.statement && getForInVariableSymbol(node) === symbol && hasNumericPropertyNames(getTypeOfExpression(node.expression))) {
               return true;
             }
             child = node;
@@ -171110,7 +154968,7 @@ ${lanes.join("\n")}
       return false;
     }
     function checkIndexedAccess(node, checkMode) {
-      return node.flags & 32 /* OptionalChain */ ? checkElementAccessChain(node, checkMode) : checkElementAccessExpression(node, checkNonNullExpression(node.expression), checkMode);
+      return node.flags & 64 /* OptionalChain */ ? checkElementAccessChain(node, checkMode) : checkElementAccessExpression(node, checkNonNullExpression(node.expression), checkMode);
     }
     function checkElementAccessChain(node, checkMode) {
       const exprType = checkExpression(node.expression);
@@ -171125,7 +154983,7 @@ ${lanes.join("\n")}
         return objectType;
       }
       if (isConstEnumObjectType(objectType) && !isStringLiteralLike(indexExpression)) {
-        error(indexExpression, Diagnostics.A_const_enum_member_can_only_be_accessed_using_a_string_literal);
+        error2(indexExpression, Diagnostics.A_const_enum_member_can_only_be_accessed_using_a_string_literal);
         return errorType;
       }
       const effectiveIndexType = isForInVariableForNumericPropertyNames(indexExpression) ? numberType : indexType;
@@ -171140,11 +154998,13 @@ ${lanes.join("\n")}
       if (callLikeExpressionMayHaveTypeArguments(node)) {
         forEach(node.typeArguments, checkSourceElement);
       }
-      if (node.kind === 214 /* TaggedTemplateExpression */) {
+      if (node.kind === 215 /* TaggedTemplateExpression */) {
         checkExpression(node.template);
       } else if (isJsxOpeningLikeElement(node)) {
         checkExpression(node.attributes);
-      } else if (node.kind !== 169 /* Decorator */) {
+      } else if (isBinaryExpression(node)) {
+        checkExpression(node.left);
+      } else if (isCallOrNewExpression(node)) {
         forEach(node.arguments, (argument) => {
           checkExpression(argument);
         });
@@ -171189,7 +155049,7 @@ ${lanes.join("\n")}
       }
     }
     function isSpreadArgument(arg) {
-      return !!arg && (arg.kind === 229 /* SpreadElement */ || arg.kind === 236 /* SyntheticExpression */ && arg.isSpread);
+      return !!arg && (arg.kind === 230 /* SpreadElement */ || arg.kind === 237 /* SyntheticExpression */ && arg.isSpread);
     }
     function getSpreadArgumentIndex(args) {
       return findIndex(args, isSpreadArgument);
@@ -171205,9 +155065,9 @@ ${lanes.join("\n")}
       let callIsIncomplete = false;
       let effectiveParameterCount = getParameterCount(signature);
       let effectiveMinimumArguments = getMinArgumentCount(signature);
-      if (node.kind === 214 /* TaggedTemplateExpression */) {
+      if (node.kind === 215 /* TaggedTemplateExpression */) {
         argCount = args.length;
-        if (node.template.kind === 227 /* TemplateExpression */) {
+        if (node.template.kind === 228 /* TemplateExpression */) {
           const lastSpan = last(node.template.templateSpans);
           callIsIncomplete = nodeIsMissing(lastSpan.literal) || !!lastSpan.literal.isUnterminated;
         } else {
@@ -171215,8 +155075,10 @@ ${lanes.join("\n")}
           Debug.assert(templateLiteral.kind === 15 /* NoSubstitutionTemplateLiteral */);
           callIsIncomplete = !!templateLiteral.isUnterminated;
         }
-      } else if (node.kind === 169 /* Decorator */) {
+      } else if (node.kind === 170 /* Decorator */) {
         argCount = getDecoratorArgumentCount(node, signature);
+      } else if (node.kind === 226 /* BinaryExpression */) {
+        argCount = 1;
       } else if (isJsxOpeningLikeElement(node)) {
         callIsIncomplete = node.attributes.end === node.end;
         if (callIsIncomplete) {
@@ -171226,7 +155088,7 @@ ${lanes.join("\n")}
         effectiveParameterCount = args.length === 0 ? effectiveParameterCount : 1;
         effectiveMinimumArguments = Math.min(effectiveMinimumArguments, 1);
       } else if (!node.arguments) {
-        Debug.assert(node.kind === 213 /* NewExpression */);
+        Debug.assert(node.kind === 214 /* NewExpression */);
         return getMinArgumentCount(signature) === 0;
       } else {
         argCount = signatureHelpTrailingComma ? args.length + 1 : args.length;
@@ -171316,13 +155178,13 @@ ${lanes.join("\n")}
         return voidType;
       }
       const thisArgumentType = checkExpression(thisArgumentNode);
-      return isOptionalChainRoot(thisArgumentNode.parent) ? getNonNullableType(thisArgumentType) : isOptionalChain(thisArgumentNode.parent) ? removeOptionalTypeMarker(thisArgumentType) : thisArgumentType;
+      return isRightSideOfInstanceofExpression(thisArgumentNode) ? thisArgumentType : isOptionalChainRoot(thisArgumentNode.parent) ? getNonNullableType(thisArgumentType) : isOptionalChain(thisArgumentNode.parent) ? removeOptionalTypeMarker(thisArgumentType) : thisArgumentType;
     }
     function inferTypeArguments(node, signature, args, checkMode, context) {
       if (isJsxOpeningLikeElement(node)) {
         return inferJsxTypeArguments(node, signature, checkMode, context);
       }
-      if (node.kind !== 169 /* Decorator */) {
+      if (node.kind !== 170 /* Decorator */ && node.kind !== 226 /* BinaryExpression */) {
         const skipBindingPatterns = every(signature.typeParameters, (p) => !!getDefaultFromTypeParameter(p));
         const contextualType = getContextualType2(node, skipBindingPatterns ? 8 /* SkipBindingPatterns */ : 0 /* None */);
         if (contextualType) {
@@ -171359,7 +155221,7 @@ ${lanes.join("\n")}
       }
       for (let i = 0; i < argCount; i++) {
         const arg = args[i];
-        if (arg.kind !== 231 /* OmittedExpression */ && !(checkMode & 32 /* IsForStringLiteralArgumentCompletions */ && hasSkipDirectInferenceFlag(arg))) {
+        if (arg.kind !== 232 /* OmittedExpression */) {
           const paramType = getTypeAtPosition(signature, i);
           if (couldContainTypeVariables(paramType)) {
             const argType = checkExpressionWithContextualType(arg, paramType, context, checkMode);
@@ -171387,11 +155249,11 @@ ${lanes.join("\n")}
       if (index >= argCount - 1) {
         const arg = args[argCount - 1];
         if (isSpreadArgument(arg)) {
-          const spreadType = arg.kind === 236 /* SyntheticExpression */ ? arg.type : checkExpressionWithContextualType(arg.expression, restType, context, checkMode);
+          const spreadType = arg.kind === 237 /* SyntheticExpression */ ? arg.type : checkExpressionWithContextualType(arg.expression, restType, context, checkMode);
           if (isArrayLikeType(spreadType)) {
             return getMutableArrayOrTupleType(spreadType);
           }
-          return createArrayType(checkIteratedTypeOrElementType(33 /* Spread */, spreadType, undefinedType, arg.kind === 229 /* SpreadElement */ ? arg.expression : arg), inConstContext);
+          return createArrayType(checkIteratedTypeOrElementType(33 /* Spread */, spreadType, undefinedType, arg.kind === 230 /* SpreadElement */ ? arg.expression : arg), inConstContext);
         }
       }
       const types = [];
@@ -171400,12 +155262,12 @@ ${lanes.join("\n")}
       for (let i = index; i < argCount; i++) {
         const arg = args[i];
         if (isSpreadArgument(arg)) {
-          const spreadType = arg.kind === 236 /* SyntheticExpression */ ? arg.type : checkExpression(arg.expression);
+          const spreadType = arg.kind === 237 /* SyntheticExpression */ ? arg.type : checkExpression(arg.expression);
           if (isArrayLikeType(spreadType)) {
             types.push(spreadType);
             flags.push(8 /* Variadic */);
           } else {
-            types.push(checkIteratedTypeOrElementType(33 /* Spread */, spreadType, undefinedType, arg.kind === 229 /* SpreadElement */ ? arg.expression : arg));
+            types.push(checkIteratedTypeOrElementType(33 /* Spread */, spreadType, undefinedType, arg.kind === 230 /* SpreadElement */ ? arg.expression : arg));
             flags.push(4 /* Rest */);
           }
         } else {
@@ -171415,11 +155277,13 @@ ${lanes.join("\n")}
           types.push(hasPrimitiveContextualType ? getRegularTypeOfLiteralType(argType) : getWidenedLiteralType(argType));
           flags.push(1 /* Required */);
         }
-        if (arg.kind === 236 /* SyntheticExpression */ && arg.tupleNameSource) {
+        if (arg.kind === 237 /* SyntheticExpression */ && arg.tupleNameSource) {
           names.push(arg.tupleNameSource);
+        } else {
+          names.push(void 0);
         }
       }
-      return createTupleType(types, flags, inConstContext, length(names) === length(types) ? names : void 0);
+      return createTupleType(types, flags, inConstContext && !someType(restType, isMutableArrayLikeType), names);
     }
     function checkTypeArguments(signature, typeArgumentNodes, reportErrors2, headMessage) {
       const isJavascript = isInJSFile(signature.declaration);
@@ -171475,8 +155339,9 @@ ${lanes.join("\n")}
         void 0,
         checkMode
       );
+      const checkAttributesType = checkMode & 4 /* SkipContextSensitive */ ? getRegularTypeOfObjectLiteral(attributesType) : attributesType;
       return checkTagNameDoesNotExpectTooManyArguments() && checkTypeRelatedToAndOptionallyElaborate(
-        attributesType,
+        checkAttributesType,
         paramType,
         relation,
         reportErrors2 ? node.tagName : void 0,
@@ -171592,7 +155457,7 @@ ${lanes.join("\n")}
       const argCount = restType ? Math.min(getParameterCount(signature) - 1, args.length) : args.length;
       for (let i = 0; i < argCount; i++) {
         const arg = args[i];
-        if (arg.kind !== 231 /* OmittedExpression */) {
+        if (arg.kind !== 232 /* OmittedExpression */) {
           const paramType = getTypeAtPosition(signature, i);
           const argType = checkExpressionWithContextualType(
             arg,
@@ -171650,7 +155515,10 @@ ${lanes.join("\n")}
       }
     }
     function getThisArgumentOfCall(node) {
-      const expression = node.kind === 212 /* CallExpression */ ? node.expression : node.kind === 214 /* TaggedTemplateExpression */ ? node.tag : void 0;
+      if (node.kind === 226 /* BinaryExpression */) {
+        return node.right;
+      }
+      const expression = node.kind === 213 /* CallExpression */ ? node.expression : node.kind === 215 /* TaggedTemplateExpression */ ? node.tag : node.kind === 170 /* Decorator */ && !legacyDecorators ? node.expression : void 0;
       if (expression) {
         const callee = skipOuterExpressions(expression);
         if (isAccessExpression(callee)) {
@@ -171665,19 +155533,22 @@ ${lanes.join("\n")}
       return result;
     }
     function getEffectiveCallArguments(node) {
-      if (node.kind === 214 /* TaggedTemplateExpression */) {
+      if (node.kind === 215 /* TaggedTemplateExpression */) {
         const template = node.template;
         const args2 = [createSyntheticExpression(template, getGlobalTemplateStringsArrayType())];
-        if (template.kind === 227 /* TemplateExpression */) {
+        if (template.kind === 228 /* TemplateExpression */) {
           forEach(template.templateSpans, (span) => {
             args2.push(span.expression);
           });
         }
         return args2;
       }
-      if (node.kind === 169 /* Decorator */) {
+      if (node.kind === 170 /* Decorator */) {
         return getEffectiveDecoratorArguments(node);
       }
+      if (node.kind === 226 /* BinaryExpression */) {
+        return [node.left];
+      }
       if (isJsxOpeningLikeElement(node)) {
         return node.attributes.properties.length > 0 || isJsxOpeningElement(node) && node.parent.children.length > 0 ? [node.attributes] : emptyArray;
       }
@@ -171687,17 +155558,12 @@ ${lanes.join("\n")}
         const effectiveArgs = args.slice(0, spreadIndex);
         for (let i = spreadIndex; i < args.length; i++) {
           const arg = args[i];
-          const spreadType = arg.kind === 229 /* SpreadElement */ && (flowLoopCount ? checkExpression(arg.expression) : checkExpressionCached(arg.expression));
+          const spreadType = arg.kind === 230 /* SpreadElement */ && (flowLoopCount ? checkExpression(arg.expression) : checkExpressionCached(arg.expression));
           if (spreadType && isTupleType(spreadType)) {
             forEach(getElementTypes(spreadType), (t, i2) => {
               var _a;
               const flags = spreadType.target.elementFlags[i2];
-              const syntheticArg = createSyntheticExpression(
-                arg,
-                flags & 4 /* Rest */ ? createArrayType(t) : t,
-                !!(flags & 12 /* Variable */),
-                (_a = spreadType.target.labeledElementDeclarations) == null ? void 0 : _a[i2]
-              );
+              const syntheticArg = createSyntheticExpression(arg, flags & 4 /* Rest */ ? createArrayType(t) : t, !!(flags & 12 /* Variable */), (_a = spreadType.target.labeledElementDeclarations) == null ? void 0 : _a[i2]);
               effectiveArgs.push(syntheticArg);
             });
           } else {
@@ -171726,16 +155592,16 @@ ${lanes.join("\n")}
     }
     function getLegacyDecoratorArgumentCount(node, signature) {
       switch (node.parent.kind) {
-        case 262 /* ClassDeclaration */:
-        case 230 /* ClassExpression */:
+        case 263 /* ClassDeclaration */:
+        case 231 /* ClassExpression */:
           return 1;
-        case 171 /* PropertyDeclaration */:
+        case 172 /* PropertyDeclaration */:
           return hasAccessorModifier(node.parent) ? 3 : 2;
-        case 173 /* MethodDeclaration */:
-        case 176 /* GetAccessor */:
-        case 177 /* SetAccessor */:
+        case 174 /* MethodDeclaration */:
+        case 177 /* GetAccessor */:
+        case 178 /* SetAccessor */:
           return languageVersion === 0 /* ES3 */ || signature.parameters.length <= 2 ? 2 : 3;
-        case 168 /* Parameter */:
+        case 169 /* Parameter */:
           return 3;
         default:
           return Debug.fail();
@@ -171831,7 +155697,7 @@ ${lanes.join("\n")}
       if (isVoidPromiseError && isInJSFile(node)) {
         return getDiagnosticForCallNode(node, Diagnostics.Expected_1_argument_but_got_0_new_Promise_needs_a_JSDoc_hint_to_produce_a_resolve_that_can_be_called_without_arguments);
       }
-      const error2 = isDecorator(node) ? hasRestParameter2 ? Diagnostics.The_runtime_will_invoke_the_decorator_with_1_arguments_but_the_decorator_expects_at_least_0 : Diagnostics.The_runtime_will_invoke_the_decorator_with_1_arguments_but_the_decorator_expects_0 : hasRestParameter2 ? Diagnostics.Expected_at_least_0_arguments_but_got_1 : isVoidPromiseError ? Diagnostics.Expected_0_arguments_but_got_1_Did_you_forget_to_include_void_in_your_type_argument_to_Promise : Diagnostics.Expected_0_arguments_but_got_1;
+      const error3 = isDecorator(node) ? hasRestParameter2 ? Diagnostics.The_runtime_will_invoke_the_decorator_with_1_arguments_but_the_decorator_expects_at_least_0 : Diagnostics.The_runtime_will_invoke_the_decorator_with_1_arguments_but_the_decorator_expects_0 : hasRestParameter2 ? Diagnostics.Expected_at_least_0_arguments_but_got_1 : isVoidPromiseError ? Diagnostics.Expected_0_arguments_but_got_1_Did_you_forget_to_include_void_in_your_type_argument_to_Promise : Diagnostics.Expected_0_arguments_but_got_1;
       if (min2 < args.length && args.length < max) {
         if (headMessage) {
           let chain = chainDiagnosticMessages(
@@ -171852,14 +155718,14 @@ ${lanes.join("\n")}
           let chain = chainDiagnosticMessages(
             /*details*/
             void 0,
-            error2,
+            error3,
             parameterRange,
             args.length
           );
           chain = chainDiagnosticMessages(chain, headMessage);
           diagnostic = getDiagnosticForCallNode(node, chain);
         } else {
-          diagnostic = getDiagnosticForCallNode(node, error2, parameterRange, args.length);
+          diagnostic = getDiagnosticForCallNode(node, error3, parameterRange, args.length);
         }
         const parameter = (_a = closestSignature == null ? void 0 : closestSignature.declaration) == null ? void 0 : _a.parameters[closestSignature.thisParameter ? args.length + 1 : args.length];
         if (parameter) {
@@ -171880,14 +155746,14 @@ ${lanes.join("\n")}
           let chain = chainDiagnosticMessages(
             /*details*/
             void 0,
-            error2,
+            error3,
             parameterRange,
             args.length
           );
           chain = chainDiagnosticMessages(chain, headMessage);
           return createDiagnosticForNodeArrayFromMessageChain(getSourceFileOfNode(node), errorSpan, chain);
         }
-        return createDiagnosticForNodeArray(getSourceFileOfNode(node), errorSpan, error2, parameterRange, args.length);
+        return createDiagnosticForNodeArray(getSourceFileOfNode(node), errorSpan, error3, parameterRange, args.length);
       }
     }
     function getTypeArgumentArityError(node, signatures, typeArguments, headMessage) {
@@ -171949,12 +155815,13 @@ ${lanes.join("\n")}
       return createDiagnosticForNodeArray(getSourceFileOfNode(node), typeArguments, Diagnostics.Expected_0_type_arguments_but_got_1, belowArgCount === -Infinity ? aboveArgCount : belowArgCount, argCount);
     }
     function resolveCall(node, signatures, candidatesOutArray, checkMode, callChainFlags, headMessage) {
-      const isTaggedTemplate = node.kind === 214 /* TaggedTemplateExpression */;
-      const isDecorator2 = node.kind === 169 /* Decorator */;
+      const isTaggedTemplate = node.kind === 215 /* TaggedTemplateExpression */;
+      const isDecorator2 = node.kind === 170 /* Decorator */;
       const isJsxOpeningOrSelfClosingElement = isJsxOpeningLikeElement(node);
+      const isInstanceof = node.kind === 226 /* BinaryExpression */;
       const reportErrors2 = !isInferencePartiallyBlocked && !candidatesOutArray;
       let typeArguments;
-      if (!isDecorator2 && !isSuperCall(node)) {
+      if (!isDecorator2 && !isInstanceof && !isSuperCall(node)) {
         typeArguments = node.typeArguments;
         if (isTaggedTemplate || isJsxOpeningOrSelfClosingElement || node.expression.kind !== 108 /* SuperKeyword */) {
           forEach(typeArguments, checkSourceElement);
@@ -171962,21 +155829,15 @@ ${lanes.join("\n")}
       }
       const candidates = candidatesOutArray || [];
       reorderCandidates(signatures, candidates, callChainFlags);
-      if (!candidates.length) {
-        if (reportErrors2) {
-          diagnostics.add(getDiagnosticForCallNode(node, Diagnostics.Call_target_does_not_contain_any_signatures));
-        }
-        return resolveErrorCall(node);
-      }
+      Debug.assert(candidates.length, "Revert #54442 and add a testcase with whatever triggered this");
       const args = getEffectiveCallArguments(node);
       const isSingleNonGenericCandidate = candidates.length === 1 && !candidates[0].typeParameters;
       let argCheckMode = !isDecorator2 && !isSingleNonGenericCandidate && some(args, isContextSensitive) ? 4 /* SkipContextSensitive */ : 0 /* Normal */;
-      argCheckMode |= checkMode & 32 /* IsForStringLiteralArgumentCompletions */;
       let candidatesForArgumentError;
       let candidateForArgumentArityError;
       let candidateForTypeArgumentError;
       let result;
-      const signatureHelpTrailingComma = !!(checkMode & 16 /* IsForSignatureHelp */) && node.kind === 212 /* CallExpression */ && node.arguments.hasTrailingComma;
+      const signatureHelpTrailingComma = !!(checkMode & 16 /* IsForSignatureHelp */) && node.kind === 213 /* CallExpression */ && node.arguments.hasTrailingComma;
       if (candidates.length > 1) {
         result = chooseOverload(candidates, subtypeRelation, isSingleNonGenericCandidate, signatureHelpTrailingComma);
       }
@@ -171989,6 +155850,9 @@ ${lanes.join("\n")}
       result = getCandidateForOverloadFailure(node, candidates, args, !!candidatesOutArray, checkMode);
       getNodeLinks(node).resolvedSignature = result;
       if (reportErrors2) {
+        if (!headMessage && isInstanceof) {
+          headMessage = Diagnostics.The_left_hand_side_of_an_instanceof_expression_must_be_assignable_to_the_first_argument_of_the_right_hand_side_s_Symbol_hasInstance_method;
+        }
         if (candidatesForArgumentError) {
           if (candidatesForArgumentError.length === 1 || candidatesForArgumentError.length > 3) {
             const last2 = candidatesForArgumentError[candidatesForArgumentError.length - 1];
@@ -172195,7 +156059,7 @@ ${lanes.join("\n")}
             continue;
           }
           if (argCheckMode) {
-            argCheckMode = checkMode & 32 /* IsForStringLiteralArgumentCompletions */;
+            argCheckMode = 0 /* Normal */;
             if (inferenceContext) {
               const typeArgumentTypes = inferTypeArguments(node, candidate, args, argCheckMode, inferenceContext);
               checkCandidate = getSignatureInstantiation(candidate, typeArgumentTypes, isInJSFile(candidate.declaration), inferenceContext.inferredTypeParameters);
@@ -172244,7 +156108,7 @@ ${lanes.join("\n")}
         parameters.push(createCombinedSymbolFromTypes(symbols, mapDefined(candidates, (candidate) => tryGetTypeAtPosition(candidate, i))));
       }
       const restParameterSymbols = mapDefined(candidates, (c) => signatureHasRestParameter(c) ? last(c.parameters) : void 0);
-      let flags = 0 /* None */;
+      let flags = 128 /* IsSignatureCandidateForOverloadFailure */;
       if (restParameterSymbols.length !== 0) {
         const type = createArrayType(getUnionType(mapDefined(candidates, tryGetRestTypeOfSignature), 2 /* Subtype */));
         parameters.push(createCombinedSymbolForOverloadFailure(restParameterSymbols, type));
@@ -172369,13 +156233,13 @@ ${lanes.join("\n")}
       const numConstructSignatures = getSignaturesOfType(apparentType, 1 /* Construct */).length;
       if (isUntypedFunctionCall(funcType, apparentType, callSignatures.length, numConstructSignatures)) {
         if (!isErrorType(funcType) && node.typeArguments) {
-          error(node, Diagnostics.Untyped_function_calls_may_not_accept_type_arguments);
+          error2(node, Diagnostics.Untyped_function_calls_may_not_accept_type_arguments);
         }
         return resolveUntypedCall(node);
       }
       if (!callSignatures.length) {
         if (numConstructSignatures) {
-          error(node, Diagnostics.Value_of_type_0_is_not_callable_Did_you_mean_to_include_new, typeToString(funcType));
+          error2(node, Diagnostics.Value_of_type_0_is_not_callable_Did_you_mean_to_include_new, typeToString(funcType));
         } else {
           let relatedInformation;
           if (node.arguments.length === 1) {
@@ -172398,7 +156262,7 @@ ${lanes.join("\n")}
         return resolvingSignature;
       }
       if (callSignatures.some((sig) => isInJSFile(sig.declaration) && !!getJSDocClassTag(sig.declaration))) {
-        error(node, Diagnostics.Value_of_type_0_is_not_callable_Did_you_mean_to_include_new, typeToString(funcType));
+        error2(node, Diagnostics.Value_of_type_0_is_not_callable_Did_you_mean_to_include_new, typeToString(funcType));
         return resolveErrorCall(node);
       }
       return resolveCall(node, callSignatures, candidatesOutArray, checkMode, callChainFlags);
@@ -172413,7 +156277,7 @@ ${lanes.join("\n")}
       if (node.arguments && languageVersion < 1 /* ES5 */) {
         const spreadIndex = getSpreadArgumentIndex(node.arguments);
         if (spreadIndex >= 0) {
-          error(node.arguments[spreadIndex], Diagnostics.Spread_operator_in_new_expressions_is_only_available_when_targeting_ECMAScript_5_and_higher);
+          error2(node.arguments[spreadIndex], Diagnostics.Spread_operator_in_new_expressions_is_only_available_when_targeting_ECMAScript_5_and_higher);
         }
       }
       let expressionType = checkNonNullExpression(node.expression);
@@ -172426,7 +156290,7 @@ ${lanes.join("\n")}
       }
       if (isTypeAny(expressionType)) {
         if (node.typeArguments) {
-          error(node, Diagnostics.Untyped_function_calls_may_not_accept_type_arguments);
+          error2(node, Diagnostics.Untyped_function_calls_may_not_accept_type_arguments);
         }
         return resolveUntypedCall(node);
       }
@@ -172436,12 +156300,12 @@ ${lanes.join("\n")}
           return resolveErrorCall(node);
         }
         if (someSignature(constructSignatures, (signature) => !!(signature.flags & 4 /* Abstract */))) {
-          error(node, Diagnostics.Cannot_create_an_instance_of_an_abstract_class);
+          error2(node, Diagnostics.Cannot_create_an_instance_of_an_abstract_class);
           return resolveErrorCall(node);
         }
         const valueDecl = expressionType.symbol && getClassLikeDeclarationOfSymbol(expressionType.symbol);
-        if (valueDecl && hasSyntacticModifier(valueDecl, 256 /* Abstract */)) {
-          error(node, Diagnostics.Cannot_create_an_instance_of_an_abstract_class);
+        if (valueDecl && hasSyntacticModifier(valueDecl, 64 /* Abstract */)) {
+          error2(node, Diagnostics.Cannot_create_an_instance_of_an_abstract_class);
           return resolveErrorCall(node);
         }
         return resolveCall(node, constructSignatures, candidatesOutArray, checkMode, 0 /* None */);
@@ -172451,10 +156315,10 @@ ${lanes.join("\n")}
         const signature = resolveCall(node, callSignatures, candidatesOutArray, checkMode, 0 /* None */);
         if (!noImplicitAny) {
           if (signature.declaration && !isJSConstructor(signature.declaration) && getReturnTypeOfSignature(signature) !== voidType) {
-            error(node, Diagnostics.Only_a_void_function_can_be_called_with_the_new_keyword);
+            error2(node, Diagnostics.Only_a_void_function_can_be_called_with_the_new_keyword);
           }
           if (getThisTypeOfSignature(signature) === voidType) {
-            error(node, Diagnostics.A_function_that_is_called_with_the_new_keyword_cannot_have_a_this_type_that_is_void);
+            error2(node, Diagnostics.A_function_that_is_called_with_the_new_keyword_cannot_have_a_this_type_that_is_void);
           }
         }
         return signature;
@@ -172503,25 +156367,25 @@ ${lanes.join("\n")}
         return true;
       }
       const declaration = signature.declaration;
-      const modifiers = getSelectedEffectiveModifierFlags(declaration, 24 /* NonPublicAccessibilityModifier */);
-      if (!modifiers || declaration.kind !== 175 /* Constructor */) {
+      const modifiers = getSelectedEffectiveModifierFlags(declaration, 6 /* NonPublicAccessibilityModifier */);
+      if (!modifiers || declaration.kind !== 176 /* Constructor */) {
         return true;
       }
       const declaringClassDeclaration = getClassLikeDeclarationOfSymbol(declaration.parent.symbol);
       const declaringClass = getDeclaredTypeOfSymbol(declaration.parent.symbol);
       if (!isNodeWithinClass(node, declaringClassDeclaration)) {
         const containingClass = getContainingClass(node);
-        if (containingClass && modifiers & 16 /* Protected */) {
+        if (containingClass && modifiers & 4 /* Protected */) {
           const containingType = getTypeOfNode(containingClass);
           if (typeHasProtectedAccessibleBase(declaration.parent.symbol, containingType)) {
             return true;
           }
         }
-        if (modifiers & 8 /* Private */) {
-          error(node, Diagnostics.Constructor_of_class_0_is_private_and_only_accessible_within_the_class_declaration, typeToString(declaringClass));
+        if (modifiers & 2 /* Private */) {
+          error2(node, Diagnostics.Constructor_of_class_0_is_private_and_only_accessible_within_the_class_declaration, typeToString(declaringClass));
         }
-        if (modifiers & 16 /* Protected */) {
-          error(node, Diagnostics.Constructor_of_class_0_is_protected_and_only_accessible_within_the_class_declaration, typeToString(declaringClass));
+        if (modifiers & 4 /* Protected */) {
+          error2(node, Diagnostics.Constructor_of_class_0_is_protected_and_only_accessible_within_the_class_declaration, typeToString(declaringClass));
         }
         return false;
       }
@@ -172621,10 +156485,7 @@ ${lanes.join("\n")}
         const sigs = getSignaturesOfType(getTypeOfSymbol(getSymbolLinks(apparentType.symbol).target), kind);
         if (!sigs || !sigs.length)
           return;
-        addRelatedInfo(
-          diagnostic,
-          createDiagnosticForNode(importNode, Diagnostics.Type_originates_at_this_import_A_namespace_style_import_cannot_be_called_or_constructed_and_will_cause_a_failure_at_runtime_Consider_using_a_default_import_or_import_require_here_instead)
-        );
+        addRelatedInfo(diagnostic, createDiagnosticForNode(importNode, Diagnostics.Type_originates_at_this_import_A_namespace_style_import_cannot_be_called_or_constructed_and_will_cause_a_failure_at_runtime_Consider_using_a_default_import_or_import_require_here_instead));
       }
     }
     function resolveTaggedTemplateExpression(node, candidatesOutArray, checkMode) {
@@ -172651,16 +156512,16 @@ ${lanes.join("\n")}
     }
     function getDiagnosticHeadMessageForDecoratorResolution(node) {
       switch (node.parent.kind) {
-        case 262 /* ClassDeclaration */:
-        case 230 /* ClassExpression */:
+        case 263 /* ClassDeclaration */:
+        case 231 /* ClassExpression */:
           return Diagnostics.Unable_to_resolve_signature_of_class_decorator_when_called_as_an_expression;
-        case 168 /* Parameter */:
+        case 169 /* Parameter */:
           return Diagnostics.Unable_to_resolve_signature_of_parameter_decorator_when_called_as_an_expression;
-        case 171 /* PropertyDeclaration */:
+        case 172 /* PropertyDeclaration */:
           return Diagnostics.Unable_to_resolve_signature_of_property_decorator_when_called_as_an_expression;
-        case 173 /* MethodDeclaration */:
-        case 176 /* GetAccessor */:
-        case 177 /* SetAccessor */:
+        case 174 /* MethodDeclaration */:
+        case 177 /* GetAccessor */:
+        case 178 /* SetAccessor */:
           return Diagnostics.Unable_to_resolve_signature_of_method_decorator_when_called_as_an_expression;
         default:
           return Debug.fail();
@@ -172683,7 +156544,7 @@ ${lanes.join("\n")}
           /*includeTrivia*/
           false
         );
-        error(node, Diagnostics._0_accepts_too_few_arguments_to_be_used_as_a_decorator_here_Did_you_mean_to_call_it_first_and_write_0, nodeStr);
+        error2(node, Diagnostics._0_accepts_too_few_arguments_to_be_used_as_a_decorator_here_Did_you_mean_to_call_it_first_and_write_0, nodeStr);
         return resolveErrorCall(node);
       }
       const headMessage = getDiagnosticHeadMessageForDecoratorResolution(node);
@@ -172773,27 +156634,53 @@ ${lanes.join("\n")}
         return resolveUntypedCall(node);
       }
       if (signatures.length === 0) {
-        error(node.tagName, Diagnostics.JSX_element_type_0_does_not_have_any_construct_or_call_signatures, getTextOfNode(node.tagName));
+        error2(node.tagName, Diagnostics.JSX_element_type_0_does_not_have_any_construct_or_call_signatures, getTextOfNode(node.tagName));
         return resolveErrorCall(node);
       }
       return resolveCall(node, signatures, candidatesOutArray, checkMode, 0 /* None */);
     }
+    function resolveInstanceofExpression(node, candidatesOutArray, checkMode) {
+      const rightType = checkExpression(node.right);
+      if (!isTypeAny(rightType)) {
+        const hasInstanceMethodType = getSymbolHasInstanceMethodOfObjectType(rightType);
+        if (hasInstanceMethodType) {
+          const apparentType = getApparentType(hasInstanceMethodType);
+          if (isErrorType(apparentType)) {
+            return resolveErrorCall(node);
+          }
+          const callSignatures = getSignaturesOfType(apparentType, 0 /* Call */);
+          const constructSignatures = getSignaturesOfType(apparentType, 1 /* Construct */);
+          if (isUntypedFunctionCall(hasInstanceMethodType, apparentType, callSignatures.length, constructSignatures.length)) {
+            return resolveUntypedCall(node);
+          }
+          if (callSignatures.length) {
+            return resolveCall(node, callSignatures, candidatesOutArray, checkMode, 0 /* None */);
+          }
+        } else if (!(typeHasCallOrConstructSignatures(rightType) || isTypeSubtypeOf(rightType, globalFunctionType))) {
+          error2(node.right, Diagnostics.The_right_hand_side_of_an_instanceof_expression_must_be_either_of_type_any_a_class_function_or_other_type_assignable_to_the_Function_interface_type_or_an_object_type_with_a_Symbol_hasInstance_method);
+          return resolveErrorCall(node);
+        }
+      }
+      return anySignature;
+    }
     function isPotentiallyUncalledDecorator(decorator, signatures) {
       return signatures.length && every(signatures, (signature) => signature.minArgumentCount === 0 && !signatureHasRestParameter(signature) && signature.parameters.length < getDecoratorArgumentCount(decorator, signature));
     }
     function resolveSignature(node, candidatesOutArray, checkMode) {
       switch (node.kind) {
-        case 212 /* CallExpression */:
+        case 213 /* CallExpression */:
           return resolveCallExpression(node, candidatesOutArray, checkMode);
-        case 213 /* NewExpression */:
+        case 214 /* NewExpression */:
           return resolveNewExpression(node, candidatesOutArray, checkMode);
-        case 214 /* TaggedTemplateExpression */:
+        case 215 /* TaggedTemplateExpression */:
           return resolveTaggedTemplateExpression(node, candidatesOutArray, checkMode);
-        case 169 /* Decorator */:
+        case 170 /* Decorator */:
           return resolveDecorator(node, candidatesOutArray, checkMode);
-        case 285 /* JsxOpeningElement */:
-        case 284 /* JsxSelfClosingElement */:
+        case 286 /* JsxOpeningElement */:
+        case 285 /* JsxSelfClosingElement */:
           return resolveJsxOpeningLikeElement(node, candidatesOutArray, checkMode);
+        case 226 /* BinaryExpression */:
+          return resolveInstanceofExpression(node, candidatesOutArray, checkMode);
       }
       Debug.assertNever(node, "Branch in 'resolveSignature' should be unreachable.");
     }
@@ -172868,7 +156755,7 @@ ${lanes.join("\n")}
       let name;
       let decl;
       if (isVariableDeclaration(node.parent) && node.parent.initializer === node) {
-        if (!isInJSFile(node) && !(isVarConst(node.parent) && isFunctionLikeDeclaration(node))) {
+        if (!isInJSFile(node) && !(isVarConstLike(node.parent) && isFunctionLikeDeclaration(node))) {
           return void 0;
         }
         name = node.parent.name;
@@ -172905,7 +156792,7 @@ ${lanes.join("\n")}
         return false;
       }
       let parent2 = node.parent;
-      while (parent2 && parent2.kind === 210 /* PropertyAccessExpression */) {
+      while (parent2 && parent2.kind === 211 /* PropertyAccessExpression */) {
         parent2 = parent2.parent;
       }
       if (parent2 && isBinaryExpression(parent2) && isPrototypeAccess(parent2.left) && parent2.operatorToken.kind === 64 /* EqualsToken */) {
@@ -172929,11 +156816,11 @@ ${lanes.join("\n")}
       if (node.expression.kind === 108 /* SuperKeyword */) {
         return voidType;
       }
-      if (node.kind === 213 /* NewExpression */) {
+      if (node.kind === 214 /* NewExpression */) {
         const declaration = signature.declaration;
-        if (declaration && declaration.kind !== 175 /* Constructor */ && declaration.kind !== 179 /* ConstructSignature */ && declaration.kind !== 184 /* ConstructorType */ && !(isJSDocSignature(declaration) && ((_b = (_a = getJSDocRoot(declaration)) == null ? void 0 : _a.parent) == null ? void 0 : _b.kind) === 175 /* Constructor */) && !isJSDocConstructSignature(declaration) && !isJSConstructor(declaration)) {
+        if (declaration && declaration.kind !== 176 /* Constructor */ && declaration.kind !== 180 /* ConstructSignature */ && declaration.kind !== 185 /* ConstructorType */ && !(isJSDocSignature(declaration) && ((_b = (_a = getJSDocRoot(declaration)) == null ? void 0 : _a.parent) == null ? void 0 : _b.kind) === 176 /* Constructor */) && !isJSDocConstructSignature(declaration) && !isJSConstructor(declaration)) {
           if (noImplicitAny) {
-            error(node, Diagnostics.new_expression_whose_target_lacks_a_construct_signature_implicitly_has_an_any_type);
+            error2(node, Diagnostics.new_expression_whose_target_lacks_a_construct_signature_implicitly_has_an_any_type);
           }
           return anyType;
         }
@@ -172945,11 +156832,11 @@ ${lanes.join("\n")}
       if (returnType.flags & 12288 /* ESSymbolLike */ && isSymbolOrSymbolForCall(node)) {
         return getESSymbolLikeTypeForNode(walkUpParenthesizedExpressions(node.parent));
       }
-      if (node.kind === 212 /* CallExpression */ && !node.questionDotToken && node.parent.kind === 243 /* ExpressionStatement */ && returnType.flags & 16384 /* Void */ && getTypePredicateOfSignature(signature)) {
+      if (node.kind === 213 /* CallExpression */ && !node.questionDotToken && node.parent.kind === 244 /* ExpressionStatement */ && returnType.flags & 16384 /* Void */ && getTypePredicateOfSignature(signature)) {
         if (!isDottedName(node.expression)) {
-          error(node.expression, Diagnostics.Assertions_require_the_call_target_to_be_an_identifier_or_qualified_name);
+          error2(node.expression, Diagnostics.Assertions_require_the_call_target_to_be_an_identifier_or_qualified_name);
         } else if (!getEffectsSignature(node)) {
-          const diagnostic = error(node.expression, Diagnostics.Assertions_require_every_name_in_the_call_target_to_be_declared_with_an_explicit_type_annotation);
+          const diagnostic = error2(node.expression, Diagnostics.Assertions_require_every_name_in_the_call_target_to_be_declared_with_an_explicit_type_annotation);
           getTypeOfDottedName(node.expression, diagnostic);
         }
       }
@@ -172968,7 +156855,9 @@ ${lanes.join("\n")}
       return returnType;
     }
     function checkDeprecatedSignature(signature, node) {
-      if (signature.declaration && signature.declaration.flags & 268435456 /* Deprecated */) {
+      if (signature.flags & 128 /* IsSignatureCandidateForOverloadFailure */)
+        return;
+      if (signature.declaration && signature.declaration.flags & 536870912 /* Deprecated */) {
         const suggestionNode = getDeprecatedSuggestionNode(node);
         const name = tryGetPropertyAccessOrIdentifierToString(getInvokedExpression(node));
         addDeprecatedSuggestionWithSignature(suggestionNode, signature.declaration, name, signatureToString(signature));
@@ -172977,20 +156866,20 @@ ${lanes.join("\n")}
     function getDeprecatedSuggestionNode(node) {
       node = skipParentheses(node);
       switch (node.kind) {
-        case 212 /* CallExpression */:
-        case 169 /* Decorator */:
-        case 213 /* NewExpression */:
+        case 213 /* CallExpression */:
+        case 170 /* Decorator */:
+        case 214 /* NewExpression */:
           return getDeprecatedSuggestionNode(node.expression);
-        case 214 /* TaggedTemplateExpression */:
+        case 215 /* TaggedTemplateExpression */:
           return getDeprecatedSuggestionNode(node.tag);
-        case 285 /* JsxOpeningElement */:
-        case 284 /* JsxSelfClosingElement */:
+        case 286 /* JsxOpeningElement */:
+        case 285 /* JsxSelfClosingElement */:
           return getDeprecatedSuggestionNode(node.tagName);
-        case 211 /* ElementAccessExpression */:
+        case 212 /* ElementAccessExpression */:
           return node.argumentExpression;
-        case 210 /* PropertyAccessExpression */:
+        case 211 /* PropertyAccessExpression */:
           return node.name;
-        case 182 /* TypeReference */:
+        case 183 /* TypeReference */:
           const typeReference = node;
           return isQualifiedName(typeReference.typeName) ? typeReference.typeName.right : typeReference;
         default:
@@ -173038,7 +156927,7 @@ ${lanes.join("\n")}
         checkExpressionCached(node.arguments[i]);
       }
       if (specifierType.flags & 32768 /* Undefined */ || specifierType.flags & 65536 /* Null */ || !isTypeAssignableTo(specifierType, stringType)) {
-        error(specifier, Diagnostics.Dynamic_import_s_specifier_must_be_of_type_string_but_here_has_type_0, typeToString(specifierType));
+        error2(specifier, Diagnostics.Dynamic_import_s_specifier_must_be_of_type_string_but_here_has_type_0, typeToString(specifierType));
       }
       if (optionsType) {
         const importCallOptionsType = getGlobalImportCallOptionsType(
@@ -173150,10 +157039,10 @@ ${lanes.join("\n")}
       if (resolvedRequire.flags & 2097152 /* Alias */) {
         return false;
       }
-      const targetDeclarationKind = resolvedRequire.flags & 16 /* Function */ ? 261 /* FunctionDeclaration */ : resolvedRequire.flags & 3 /* Variable */ ? 259 /* VariableDeclaration */ : 0 /* Unknown */;
+      const targetDeclarationKind = resolvedRequire.flags & 16 /* Function */ ? 262 /* FunctionDeclaration */ : resolvedRequire.flags & 3 /* Variable */ ? 260 /* VariableDeclaration */ : 0 /* Unknown */;
       if (targetDeclarationKind !== 0 /* Unknown */) {
         const decl = getDeclarationOfKind(resolvedRequire, targetDeclarationKind);
-        return !!decl && !!(decl.flags & 16777216 /* Ambient */);
+        return !!decl && !!(decl.flags & 33554432 /* Ambient */);
       }
       return false;
     }
@@ -173168,7 +157057,7 @@ ${lanes.join("\n")}
       return getReturnTypeOfSignature(signature);
     }
     function checkAssertion(node, checkMode) {
-      if (node.kind === 215 /* TypeAssertionExpression */) {
+      if (node.kind === 216 /* TypeAssertionExpression */) {
         const file = getSourceFileOfNode(node);
         if (file && fileExtensionIsOneOf(file.fileName, [".cts" /* Cts */, ".mts" /* Mts */])) {
           grammarErrorOnNode(node, Diagnostics.This_syntax_is_reserved_in_files_with_the_mts_or_cts_extension_Use_an_as_expression_instead);
@@ -173184,18 +157073,18 @@ ${lanes.join("\n")}
         case 10 /* BigIntLiteral */:
         case 112 /* TrueKeyword */:
         case 97 /* FalseKeyword */:
-        case 208 /* ArrayLiteralExpression */:
-        case 209 /* ObjectLiteralExpression */:
-        case 227 /* TemplateExpression */:
+        case 209 /* ArrayLiteralExpression */:
+        case 210 /* ObjectLiteralExpression */:
+        case 228 /* TemplateExpression */:
           return true;
-        case 216 /* ParenthesizedExpression */:
+        case 217 /* ParenthesizedExpression */:
           return isValidConstAssertionArgument(node.expression);
-        case 223 /* PrefixUnaryExpression */:
+        case 224 /* PrefixUnaryExpression */:
           const op = node.operator;
           const arg = node.operand;
           return op === 41 /* MinusToken */ && (arg.kind === 9 /* NumericLiteral */ || arg.kind === 10 /* BigIntLiteral */) || op === 40 /* PlusToken */ && arg.kind === 9 /* NumericLiteral */;
-        case 210 /* PropertyAccessExpression */:
-        case 211 /* ElementAccessExpression */:
+        case 211 /* PropertyAccessExpression */:
+        case 212 /* ElementAccessExpression */:
           const expr = skipParentheses(node.expression);
           const symbol = isEntityNameExpression(expr) ? resolveEntityName(
             expr,
@@ -173212,7 +157101,7 @@ ${lanes.join("\n")}
       const exprType = checkExpression(expression, checkMode);
       if (isConstTypeReference(type)) {
         if (!isValidConstAssertionArgument(expression)) {
-          error(expression, Diagnostics.A_const_assertions_can_only_be_applied_to_references_to_enum_members_or_string_number_boolean_array_or_object_literals);
+          error2(expression, Diagnostics.A_const_assertions_can_only_be_applied_to_references_to_enum_members_or_string_number_boolean_array_or_object_literals);
         }
         return getRegularTypeOfLiteralType(exprType);
       }
@@ -173226,12 +157115,12 @@ ${lanes.join("\n")}
       let type;
       let expression;
       switch (node.kind) {
-        case 233 /* AsExpression */:
-        case 215 /* TypeAssertionExpression */:
+        case 234 /* AsExpression */:
+        case 216 /* TypeAssertionExpression */:
           type = node.type;
           expression = node.expression;
           break;
-        case 216 /* ParenthesizedExpression */:
+        case 217 /* ParenthesizedExpression */:
           type = getJSDocTypeAssertionType(node);
           expression = node.expression;
           break;
@@ -173249,12 +157138,7 @@ ${lanes.join("\n")}
         addLazyDiagnostic(() => {
           const widenedType = getWidenedType(exprType);
           if (!isTypeComparableTo(targetType, widenedType)) {
-            checkTypeComparableTo(
-              exprType,
-              targetType,
-              errNode,
-              Diagnostics.Conversion_of_type_0_to_type_1_may_be_a_mistake_because_neither_type_sufficiently_overlaps_with_the_other_If_this_was_intentional_convert_the_expression_to_unknown_first
-            );
+            checkTypeComparableTo(exprType, targetType, errNode, Diagnostics.Conversion_of_type_0_to_type_1_may_be_a_mistake_because_neither_type_sufficiently_overlaps_with_the_other_If_this_was_intentional_convert_the_expression_to_unknown_first);
           }
         });
       }
@@ -173265,18 +157149,18 @@ ${lanes.join("\n")}
       return propagateOptionalTypeMarker(getNonNullableType(nonOptionalType), node, nonOptionalType !== leftType);
     }
     function checkNonNullAssertion(node) {
-      return node.flags & 32 /* OptionalChain */ ? checkNonNullChain(node) : getNonNullableType(checkExpression(node.expression));
+      return node.flags & 64 /* OptionalChain */ ? checkNonNullChain(node) : getNonNullableType(checkExpression(node.expression));
     }
     function checkExpressionWithTypeArguments(node) {
       checkGrammarExpressionWithTypeArguments(node);
       forEach(node.typeArguments, checkSourceElement);
-      if (node.kind === 232 /* ExpressionWithTypeArguments */) {
+      if (node.kind === 233 /* ExpressionWithTypeArguments */) {
         const parent2 = walkUpParenthesizedExpressions(node.parent);
-        if (parent2.kind === 225 /* BinaryExpression */ && parent2.operatorToken.kind === 104 /* InstanceOfKeyword */ && isNodeDescendantOf(node, parent2.right)) {
-          error(node, Diagnostics.The_right_hand_side_of_an_instanceof_expression_must_not_be_an_instantiation_expression);
+        if (parent2.kind === 226 /* BinaryExpression */ && parent2.operatorToken.kind === 104 /* InstanceOfKeyword */ && isNodeDescendantOf(node, parent2.right)) {
+          error2(node, Diagnostics.The_right_hand_side_of_an_instanceof_expression_must_not_be_an_instantiation_expression);
         }
       }
-      const exprType = node.kind === 232 /* ExpressionWithTypeArguments */ ? checkExpression(node.expression) : isThisIdentifier(node.exprName) ? checkThisExpression(node.exprName) : checkExpression(node.exprName);
+      const exprType = node.kind === 233 /* ExpressionWithTypeArguments */ ? checkExpression(node.expression) : isThisIdentifier(node.exprName) ? checkThisExpression(node.exprName) : checkExpression(node.exprName);
       return getInstantiationExpressionType(exprType, node);
     }
     function getInstantiationExpressionType(exprType, node) {
@@ -173360,7 +157244,7 @@ ${lanes.join("\n")}
       if (isErrorType(targetType)) {
         return targetType;
       }
-      const errorNode = findAncestor(target.parent, (n) => n.kind === 237 /* SatisfiesExpression */ || n.kind === 356 /* JSDocSatisfiesTag */);
+      const errorNode = findAncestor(target.parent, (n) => n.kind === 238 /* SatisfiesExpression */ || n.kind === 357 /* JSDocSatisfiesTag */);
       checkTypeAssignableToAndOptionallyElaborate(exprType, targetType, errorNode, expression, Diagnostics.Type_0_does_not_satisfy_the_expected_type_1);
       return exprType;
     }
@@ -173388,9 +157272,9 @@ ${lanes.join("\n")}
     function checkNewTargetMetaProperty(node) {
       const container = getNewTargetContainer(node);
       if (!container) {
-        error(node, Diagnostics.Meta_property_0_is_only_allowed_in_the_body_of_a_function_declaration_function_expression_or_constructor, "new.target");
+        error2(node, Diagnostics.Meta_property_0_is_only_allowed_in_the_body_of_a_function_declaration_function_expression_or_constructor, "new.target");
         return errorType;
-      } else if (container.kind === 175 /* Constructor */) {
+      } else if (container.kind === 176 /* Constructor */) {
         const symbol = getSymbolOfDeclaration(container.parent);
         return getTypeOfSymbol(symbol);
       } else {
@@ -173401,26 +157285,29 @@ ${lanes.join("\n")}
     function checkImportMetaProperty(node) {
       if (moduleKind === 100 /* Node16 */ || moduleKind === 199 /* NodeNext */) {
         if (getSourceFileOfNode(node).impliedNodeFormat !== 99 /* ESNext */) {
-          error(node, Diagnostics.The_import_meta_meta_property_is_not_allowed_in_files_which_will_build_into_CommonJS_output);
+          error2(node, Diagnostics.The_import_meta_meta_property_is_not_allowed_in_files_which_will_build_into_CommonJS_output);
         }
       } else if (moduleKind < 6 /* ES2020 */ && moduleKind !== 4 /* System */) {
-        error(node, Diagnostics.The_import_meta_meta_property_is_only_allowed_when_the_module_option_is_es2020_es2022_esnext_system_node16_or_nodenext);
+        error2(node, Diagnostics.The_import_meta_meta_property_is_only_allowed_when_the_module_option_is_es2020_es2022_esnext_system_node16_or_nodenext);
       }
       const file = getSourceFileOfNode(node);
-      Debug.assert(!!(file.flags & 4194304 /* PossiblyContainsImportMeta */), "Containing file is missing import meta node flag.");
+      Debug.assert(!!(file.flags & 8388608 /* PossiblyContainsImportMeta */), "Containing file is missing import meta node flag.");
       return node.name.escapedText === "meta" ? getGlobalImportMetaType() : errorType;
     }
     function getTypeOfParameter(symbol) {
-      const type = getTypeOfSymbol(symbol);
-      if (strictNullChecks) {
-        const declaration = symbol.valueDeclaration;
-        if (declaration && hasInitializer(declaration)) {
-          return getOptionalType(type);
-        }
-      }
-      return type;
+      const declaration = symbol.valueDeclaration;
+      return addOptionality(
+        getTypeOfSymbol(symbol),
+        /*isProperty*/
+        false,
+        /*isOptional*/
+        !!declaration && (hasInitializer(declaration) || isOptionalDeclaration(declaration))
+      );
     }
-    function getTupleElementLabel(d) {
+    function getTupleElementLabel(d, index, restParameterName = "arg") {
+      if (!d) {
+        return `${restParameterName}_${index}`;
+      }
       Debug.assert(isIdentifier(d.name));
       return d.name.escapedText;
     }
@@ -173434,22 +157321,28 @@ ${lanes.join("\n")}
       if (isTupleType(restType)) {
         const associatedNames = restType.target.labeledElementDeclarations;
         const index = pos - paramCount;
-        return associatedNames && getTupleElementLabel(associatedNames[index]) || restParameter.escapedName + "_" + index;
+        return getTupleElementLabel(associatedNames == null ? void 0 : associatedNames[index], index, restParameter.escapedName);
       }
       return restParameter.escapedName;
     }
-    function getParameterIdentifierNameAtPosition(signature, pos) {
+    function getParameterIdentifierInfoAtPosition(signature, pos) {
       var _a;
-      if (((_a = signature.declaration) == null ? void 0 : _a.kind) === 323 /* JSDocFunctionType */) {
+      if (((_a = signature.declaration) == null ? void 0 : _a.kind) === 324 /* JSDocFunctionType */) {
         return void 0;
       }
       const paramCount = signature.parameters.length - (signatureHasRestParameter(signature) ? 1 : 0);
       if (pos < paramCount) {
         const param = signature.parameters[pos];
-        return isParameterDeclarationWithIdentifierName(param) ? [param.escapedName, false] : void 0;
+        const paramIdent = getParameterDeclarationIdentifier(param);
+        return paramIdent ? {
+          parameter: paramIdent,
+          parameterName: param.escapedName,
+          isRestParameter: false
+        } : void 0;
       }
       const restParameter = signature.parameters[paramCount] || unknownSymbol;
-      if (!isParameterDeclarationWithIdentifierName(restParameter)) {
+      const restIdent = getParameterDeclarationIdentifier(restParameter);
+      if (!restIdent) {
         return void 0;
       }
       const restType = getTypeOfSymbol(restParameter);
@@ -173458,21 +157351,22 @@ ${lanes.join("\n")}
         const index = pos - paramCount;
         const associatedName = associatedNames == null ? void 0 : associatedNames[index];
         const isRestTupleElement = !!(associatedName == null ? void 0 : associatedName.dotDotDotToken);
-        return associatedName ? [
-          getTupleElementLabel(associatedName),
-          isRestTupleElement
-        ] : void 0;
+        if (associatedName) {
+          Debug.assert(isIdentifier(associatedName.name));
+          return { parameter: associatedName.name, parameterName: associatedName.name.escapedText, isRestParameter: isRestTupleElement };
+        }
+        return void 0;
       }
       if (pos === paramCount) {
-        return [restParameter.escapedName, true];
+        return { parameter: restIdent, parameterName: restParameter.escapedName, isRestParameter: true };
       }
       return void 0;
     }
-    function isParameterDeclarationWithIdentifierName(symbol) {
-      return symbol.valueDeclaration && isParameter(symbol.valueDeclaration) && isIdentifier(symbol.valueDeclaration.name);
+    function getParameterDeclarationIdentifier(symbol) {
+      return symbol.valueDeclaration && isParameter(symbol.valueDeclaration) && isIdentifier(symbol.valueDeclaration.name) && symbol.valueDeclaration.name;
     }
     function isValidDeclarationForTupleLabel(d) {
-      return d.kind === 201 /* NamedTupleMember */ || isParameter(d) && d.name && isIdentifier(d.name);
+      return d.kind === 202 /* NamedTupleMember */ || isParameter(d) && d.name && isIdentifier(d.name);
     }
     function getNameableDeclarationAtPosition(signature, pos) {
       const paramCount = signature.parameters.length - (signatureHasRestParameter(signature) ? 1 : 0);
@@ -173506,7 +157400,7 @@ ${lanes.join("\n")}
       }
       return void 0;
     }
-    function getRestTypeAtPosition(source, pos) {
+    function getRestTypeAtPosition(source, pos, readonly) {
       const parameterCount = getParameterCount(source);
       const minArgumentCount = getMinArgumentCount(source);
       const restType = getEffectiveRestType(source);
@@ -173524,18 +157418,9 @@ ${lanes.join("\n")}
           types.push(restType);
           flags.push(8 /* Variadic */);
         }
-        const name = getNameableDeclarationAtPosition(source, i);
-        if (name) {
-          names.push(name);
-        }
+        names.push(getNameableDeclarationAtPosition(source, i));
       }
-      return createTupleType(
-        types,
-        flags,
-        /*readonly*/
-        false,
-        length(names) === length(types) ? names : void 0
-      );
+      return createTupleType(types, flags, readonly, names);
     }
     function getParameterCount(signature) {
       const length2 = signature.parameters.length;
@@ -173615,11 +157500,16 @@ ${lanes.join("\n")}
       const len = signature.parameters.length - (signatureHasRestParameter(signature) ? 1 : 0);
       for (let i = 0; i < len; i++) {
         const declaration = signature.parameters[i].valueDeclaration;
-        if (declaration.type) {
-          const typeNode = getEffectiveTypeAnnotationNode(declaration);
-          if (typeNode) {
-            inferTypes(inferenceContext.inferences, getTypeFromTypeNode(typeNode), getTypeAtPosition(context, i));
-          }
+        const typeNode = getEffectiveTypeAnnotationNode(declaration);
+        if (typeNode) {
+          const source = addOptionality(
+            getTypeFromTypeNode(typeNode),
+            /*isProperty*/
+            false,
+            isOptionalDeclaration(declaration)
+          );
+          const target = getTypeAtPosition(context, i);
+          inferTypes(inferenceContext.inferences, source, target);
         }
       }
     }
@@ -173668,29 +157558,40 @@ ${lanes.join("\n")}
         assignParameterType(parameter);
       }
     }
-    function assignParameterType(parameter, type) {
+    function assignParameterType(parameter, contextualType) {
       const links = getSymbolLinks(parameter);
       if (!links.type) {
         const declaration = parameter.valueDeclaration;
-        links.type = type || (declaration ? getWidenedTypeForVariableLikeDeclaration(
-          declaration,
-          /*reportErrors*/
-          true
-        ) : getTypeOfSymbol(parameter));
+        links.type = addOptionality(
+          contextualType || (declaration ? getWidenedTypeForVariableLikeDeclaration(
+            declaration,
+            /*reportErrors*/
+            true
+          ) : getTypeOfSymbol(parameter)),
+          /*isProperty*/
+          false,
+          /*isOptional*/
+          !!declaration && !declaration.initializer && isOptionalDeclaration(declaration)
+        );
         if (declaration && declaration.name.kind !== 80 /* Identifier */) {
           if (links.type === unknownType) {
             links.type = getTypeFromBindingPattern(declaration.name);
           }
           assignBindingElementTypes(declaration.name, links.type);
         }
-      } else if (type) {
-        Debug.assertEqual(links.type, type, "Parameter symbol already has a cached type which differs from newly assigned type");
+      } else if (contextualType) {
+        Debug.assertEqual(links.type, contextualType, "Parameter symbol already has a cached type which differs from newly assigned type");
       }
     }
     function assignBindingElementTypes(pattern, parentType) {
       for (const element of pattern.elements) {
         if (!isOmittedExpression(element)) {
-          const type = getBindingElementTypeFromParentType(element, parentType);
+          const type = getBindingElementTypeFromParentType(
+            element,
+            parentType,
+            /*noTupleBoundsCheck*/
+            false
+          );
           if (element.name.kind === 80 /* Identifier */) {
             getSymbolLinks(getSymbolOfDeclaration(element)).type = type;
           } else {
@@ -173808,17 +157709,17 @@ ${lanes.join("\n")}
       if (!links.decoratorSignature) {
         links.decoratorSignature = anySignature;
         switch (parent2.kind) {
-          case 262 /* ClassDeclaration */:
-          case 230 /* ClassExpression */: {
+          case 263 /* ClassDeclaration */:
+          case 231 /* ClassExpression */: {
             const node = parent2;
             const targetType = getTypeOfSymbol(getSymbolOfDeclaration(node));
             const contextType = createClassDecoratorContextType(targetType);
             links.decoratorSignature = createESDecoratorCallSignature(targetType, contextType, targetType);
             break;
           }
-          case 173 /* MethodDeclaration */:
-          case 176 /* GetAccessor */:
-          case 177 /* SetAccessor */: {
+          case 174 /* MethodDeclaration */:
+          case 177 /* GetAccessor */:
+          case 178 /* SetAccessor */: {
             const node = parent2;
             if (!isClassLike(node.parent))
               break;
@@ -173830,7 +157731,7 @@ ${lanes.join("\n")}
             links.decoratorSignature = createESDecoratorCallSignature(targetType, contextType, returnType);
             break;
           }
-          case 171 /* PropertyDeclaration */: {
+          case 172 /* PropertyDeclaration */: {
             const node = parent2;
             if (!isClassLike(node.parent))
               break;
@@ -173852,8 +157753,8 @@ ${lanes.join("\n")}
       if (!links.decoratorSignature) {
         links.decoratorSignature = anySignature;
         switch (parent2.kind) {
-          case 262 /* ClassDeclaration */:
-          case 230 /* ClassExpression */: {
+          case 263 /* ClassDeclaration */:
+          case 231 /* ClassExpression */: {
             const node = parent2;
             const targetType = getTypeOfSymbol(getSymbolOfDeclaration(node));
             const targetParam = createParameter("target", targetType);
@@ -173867,7 +157768,7 @@ ${lanes.join("\n")}
             );
             break;
           }
-          case 168 /* Parameter */: {
+          case 169 /* Parameter */: {
             const node = parent2;
             if (!isConstructorDeclaration(node.parent) && !(isMethodDeclaration(node.parent) || isSetAccessorDeclaration(node.parent) && isClassLike(node.parent.parent))) {
               break;
@@ -173893,10 +157794,10 @@ ${lanes.join("\n")}
             );
             break;
           }
-          case 173 /* MethodDeclaration */:
-          case 176 /* GetAccessor */:
-          case 177 /* SetAccessor */:
-          case 171 /* PropertyDeclaration */: {
+          case 174 /* MethodDeclaration */:
+          case 177 /* GetAccessor */:
+          case 178 /* SetAccessor */:
+          case 172 /* PropertyDeclaration */: {
             const node = parent2;
             if (!isClassLike(node.parent))
               break;
@@ -173961,13 +157862,19 @@ ${lanes.join("\n")}
     function createPromiseReturnType(func, promisedType) {
       const promiseType = createPromiseType(promisedType);
       if (promiseType === unknownType) {
-        error(func, isImportCall(func) ? Diagnostics.A_dynamic_import_call_returns_a_Promise_Make_sure_you_have_a_declaration_for_Promise_or_include_ES2015_in_your_lib_option : Diagnostics.An_async_function_or_method_must_return_a_Promise_Make_sure_you_have_a_declaration_for_Promise_or_include_ES2015_in_your_lib_option);
+        error2(
+          func,
+          isImportCall(func) ? Diagnostics.A_dynamic_import_call_returns_a_Promise_Make_sure_you_have_a_declaration_for_Promise_or_include_ES2015_in_your_lib_option : Diagnostics.An_async_function_or_method_must_return_a_Promise_Make_sure_you_have_a_declaration_for_Promise_or_include_ES2015_in_your_lib_option
+        );
         return errorType;
       } else if (!getGlobalPromiseConstructorSymbol(
         /*reportErrors*/
         true
       )) {
-        error(func, isImportCall(func) ? Diagnostics.A_dynamic_import_call_in_ES5_SlashES3_requires_the_Promise_constructor_Make_sure_you_have_a_declaration_for_the_Promise_constructor_or_include_ES2015_in_your_lib_option : Diagnostics.An_async_function_or_method_in_ES5_SlashES3_requires_the_Promise_constructor_Make_sure_you_have_a_declaration_for_the_Promise_constructor_or_include_ES2015_in_your_lib_option);
+        error2(
+          func,
+          isImportCall(func) ? Diagnostics.A_dynamic_import_call_in_ES5_SlashES3_requires_the_Promise_constructor_Make_sure_you_have_a_declaration_for_the_Promise_constructor_or_include_ES2015_in_your_lib_option : Diagnostics.An_async_function_or_method_in_ES5_SlashES3_requires_the_Promise_constructor_Make_sure_you_have_a_declaration_for_the_Promise_constructor_or_include_ES2015_in_your_lib_option
+        );
       }
       return promiseType;
     }
@@ -173991,7 +157898,7 @@ ${lanes.join("\n")}
       let yieldType;
       let nextType;
       let fallbackReturnType = voidType;
-      if (func.body.kind !== 240 /* Block */) {
+      if (func.body.kind !== 241 /* Block */) {
         returnType = checkExpressionCached(func.body, checkMode && checkMode & ~8 /* SkipGenericFunctions */);
         if (isAsync) {
           returnType = unwrapAwaitedType(checkAwaitedType(
@@ -174150,7 +158057,11 @@ ${lanes.join("\n")}
     function getYieldedTypeOfYieldExpression(node, expressionType, sentType, isAsync) {
       const errorNode = node.expression || node;
       const yieldedType = node.asteriskToken ? checkIteratedTypeOrElementType(isAsync ? 19 /* AsyncYieldStar */ : 17 /* YieldStar */, expressionType, sentType, errorNode) : expressionType;
-      return !isAsync ? yieldedType : getAwaitedType(yieldedType, errorNode, node.asteriskToken ? Diagnostics.Type_of_iterated_elements_of_a_yield_Asterisk_operand_must_either_be_a_valid_promise_or_must_not_contain_a_callable_then_member : Diagnostics.Type_of_yield_operand_in_an_async_generator_must_either_be_a_valid_promise_or_must_not_contain_a_callable_then_member);
+      return !isAsync ? yieldedType : getAwaitedType(
+        yieldedType,
+        errorNode,
+        node.asteriskToken ? Diagnostics.Type_of_iterated_elements_of_a_yield_Asterisk_operand_must_either_be_a_valid_promise_or_must_not_contain_a_callable_then_member : Diagnostics.Type_of_yield_operand_in_an_async_generator_must_either_be_a_valid_promise_or_must_not_contain_a_callable_then_member
+      );
     }
     function getNotEqualFactsFromTypeofSwitch(start, end, witnesses) {
       let facts = 0 /* None */;
@@ -174174,7 +158085,7 @@ ${lanes.join("\n")}
       return links.isExhaustive;
     }
     function computeExhaustiveSwitchStatement(node) {
-      if (node.expression.kind === 220 /* TypeOfExpression */) {
+      if (node.expression.kind === 221 /* TypeOfExpression */) {
         const witnesses = getSwitchClauseTypeOfWitnesses(node);
         if (!witnesses) {
           return false;
@@ -174184,7 +158095,7 @@ ${lanes.join("\n")}
         if (operandConstraint.flags & 3 /* AnyOrUnknown */) {
           return (556800 /* AllTypeofNE */ & notEqualFacts) === 556800 /* AllTypeofNE */;
         }
-        return !someType(operandConstraint, (t) => (getTypeFacts(t) & notEqualFacts) === notEqualFacts);
+        return !someType(operandConstraint, (t) => getTypeFacts(t, notEqualFacts) === notEqualFacts);
       }
       const type = checkExpressionCached(node.expression);
       if (!isLiteralType(type)) {
@@ -174205,9 +158116,21 @@ ${lanes.join("\n")}
       let hasReturnWithNoExpression = functionHasImplicitReturn(func);
       let hasReturnOfTypeNever = false;
       forEachReturnStatement(func.body, (returnStatement) => {
-        const expr = returnStatement.expression;
+        let expr = returnStatement.expression;
         if (expr) {
-          if (expr.kind === 212 /* CallExpression */ && expr.expression.kind === 80 /* Identifier */ && checkExpressionCached(expr.expression).symbol === func.symbol) {
+          expr = skipParentheses(
+            expr,
+            /*excludeJSDocTypeAssertions*/
+            true
+          );
+          if (functionFlags & 2 /* Async */ && expr.kind === 223 /* AwaitExpression */) {
+            expr = skipParentheses(
+              expr.expression,
+              /*excludeJSDocTypeAssertions*/
+              true
+            );
+          }
+          if (expr.kind === 213 /* CallExpression */ && expr.expression.kind === 80 /* Identifier */ && checkExpressionCached(expr.expression).symbol === func.symbol) {
             hasReturnOfTypeNever = true;
             return;
           }
@@ -174239,11 +158162,11 @@ ${lanes.join("\n")}
     }
     function mayReturnNever(func) {
       switch (func.kind) {
-        case 217 /* FunctionExpression */:
-        case 218 /* ArrowFunction */:
+        case 218 /* FunctionExpression */:
+        case 219 /* ArrowFunction */:
           return true;
-        case 173 /* MethodDeclaration */:
-          return func.parent.kind === 209 /* ObjectLiteralExpression */;
+        case 174 /* MethodDeclaration */:
+          return func.parent.kind === 210 /* ObjectLiteralExpression */;
         default:
           return false;
       }
@@ -174257,17 +158180,17 @@ ${lanes.join("\n")}
         if (type && (maybeTypeOfKind(type, 16384 /* Void */) || type.flags & (1 /* Any */ | 32768 /* Undefined */))) {
           return;
         }
-        if (func.kind === 172 /* MethodSignature */ || nodeIsMissing(func.body) || func.body.kind !== 240 /* Block */ || !functionHasImplicitReturn(func)) {
+        if (func.kind === 173 /* MethodSignature */ || nodeIsMissing(func.body) || func.body.kind !== 241 /* Block */ || !functionHasImplicitReturn(func)) {
           return;
         }
-        const hasExplicitReturn = func.flags & 512 /* HasExplicitReturn */;
+        const hasExplicitReturn = func.flags & 1024 /* HasExplicitReturn */;
         const errorNode = getEffectiveReturnTypeNode(func) || func;
         if (type && type.flags & 131072 /* Never */) {
-          error(errorNode, Diagnostics.A_function_returning_never_cannot_have_a_reachable_end_point);
+          error2(errorNode, Diagnostics.A_function_returning_never_cannot_have_a_reachable_end_point);
         } else if (type && !hasExplicitReturn) {
-          error(errorNode, Diagnostics.A_function_whose_declared_type_is_neither_undefined_void_nor_any_must_return_a_value);
+          error2(errorNode, Diagnostics.A_function_whose_declared_type_is_neither_undefined_void_nor_any_must_return_a_value);
         } else if (type && strictNullChecks && !isTypeAssignableTo(undefinedType, type)) {
-          error(errorNode, Diagnostics.Function_lacks_ending_return_statement_and_return_type_does_not_include_undefined);
+          error2(errorNode, Diagnostics.Function_lacks_ending_return_statement_and_return_type_does_not_include_undefined);
         } else if (compilerOptions.noImplicitReturns) {
           if (!type) {
             if (!hasExplicitReturn) {
@@ -174278,12 +158201,12 @@ ${lanes.join("\n")}
               return;
             }
           }
-          error(errorNode, Diagnostics.Not_all_code_paths_return_a_value);
+          error2(errorNode, Diagnostics.Not_all_code_paths_return_a_value);
         }
       }
     }
     function checkFunctionExpressionOrObjectLiteralMethod(node, checkMode) {
-      Debug.assert(node.kind !== 173 /* MethodDeclaration */ || isObjectLiteralMethod(node));
+      Debug.assert(node.kind !== 174 /* MethodDeclaration */ || isObjectLiteralMethod(node));
       checkNodeDeferred(node);
       if (isFunctionExpression(node)) {
         checkCollisionsForDeclarationName(node, node.name);
@@ -174319,7 +158242,7 @@ ${lanes.join("\n")}
         return anyFunctionType;
       }
       const hasGrammarError = checkGrammarFunctionLikeDeclaration(node);
-      if (!hasGrammarError && node.kind === 217 /* FunctionExpression */) {
+      if (!hasGrammarError && node.kind === 218 /* FunctionExpression */) {
         checkGrammarForGenerator(node);
       }
       contextuallyCheckFunctionExpressionOrObjectLiteralMethod(node, checkMode);
@@ -174368,7 +158291,7 @@ ${lanes.join("\n")}
       }
     }
     function checkFunctionExpressionOrObjectLiteralMethodDeferred(node) {
-      Debug.assert(node.kind !== 173 /* MethodDeclaration */ || isObjectLiteralMethod(node));
+      Debug.assert(node.kind !== 174 /* MethodDeclaration */ || isObjectLiteralMethod(node));
       const functionFlags = getFunctionFlags(node);
       const returnType = getReturnTypeFromAnnotation(node);
       checkAllCodePathsInNonVoidFunctionReturnOrThrow(node, returnType);
@@ -174376,7 +158299,7 @@ ${lanes.join("\n")}
         if (!getEffectiveReturnTypeNode(node)) {
           getReturnTypeOfSignature(getSignatureFromDeclaration(node));
         }
-        if (node.body.kind === 240 /* Block */) {
+        if (node.body.kind === 241 /* Block */) {
           checkSourceElement(node.body);
         } else {
           const exprType = checkExpression(node.body);
@@ -174438,7 +158361,7 @@ ${lanes.join("\n")}
       return !setProp;
     }
     function isReadonlySymbol(symbol) {
-      return !!(getCheckFlags(symbol) & 8 /* Readonly */ || symbol.flags & 4 /* Property */ && getDeclarationModifierFlagsFromSymbol(symbol) & 64 /* Readonly */ || symbol.flags & 3 /* Variable */ && getDeclarationNodeFlagsFromSymbol(symbol) & 2 /* Const */ || symbol.flags & 98304 /* Accessor */ && !(symbol.flags & 65536 /* SetAccessor */) || symbol.flags & 8 /* EnumMember */ || some(symbol.declarations, isReadonlyAssignmentDeclaration));
+      return !!(getCheckFlags(symbol) & 8 /* Readonly */ || symbol.flags & 4 /* Property */ && getDeclarationModifierFlagsFromSymbol(symbol) & 8 /* Readonly */ || symbol.flags & 3 /* Variable */ && getDeclarationNodeFlagsFromSymbol(symbol) & 6 /* Constant */ || symbol.flags & 98304 /* Accessor */ && !(symbol.flags & 65536 /* SetAccessor */) || symbol.flags & 8 /* EnumMember */ || some(symbol.declarations, isReadonlyAssignmentDeclaration));
     }
     function isAssignmentToReadonlyEntity(expr, symbol, assignmentKind) {
       var _a, _b;
@@ -174448,7 +158371,7 @@ ${lanes.join("\n")}
       if (isReadonlySymbol(symbol)) {
         if (symbol.flags & 4 /* Property */ && isAccessExpression(expr) && expr.expression.kind === 110 /* ThisKeyword */) {
           const ctor = getContainingFunction(expr);
-          if (!(ctor && (ctor.kind === 175 /* Constructor */ || isJSConstructor(ctor)))) {
+          if (!(ctor && (ctor.kind === 176 /* Constructor */ || isJSConstructor(ctor)))) {
             return true;
           }
           if (symbol.valueDeclaration) {
@@ -174469,7 +158392,7 @@ ${lanes.join("\n")}
           const symbol2 = getNodeLinks(node).resolvedSymbol;
           if (symbol2.flags & 2097152 /* Alias */) {
             const declaration = getDeclarationOfAliasSymbol(symbol2);
-            return !!declaration && declaration.kind === 273 /* NamespaceImport */;
+            return !!declaration && declaration.kind === 274 /* NamespaceImport */;
           }
         }
       }
@@ -174478,11 +158401,11 @@ ${lanes.join("\n")}
     function checkReferenceExpression(expr, invalidReferenceMessage, invalidOptionalChainMessage) {
       const node = skipOuterExpressions(expr, 6 /* Assertions */ | 1 /* Parentheses */);
       if (node.kind !== 80 /* Identifier */ && !isAccessExpression(node)) {
-        error(expr, invalidReferenceMessage);
+        error2(expr, invalidReferenceMessage);
         return false;
       }
-      if (node.flags & 32 /* OptionalChain */) {
-        error(expr, invalidOptionalChainMessage);
+      if (node.flags & 64 /* OptionalChain */) {
+        error2(expr, invalidOptionalChainMessage);
         return false;
       }
       return true;
@@ -174491,26 +158414,27 @@ ${lanes.join("\n")}
       checkExpression(node.expression);
       const expr = skipParentheses(node.expression);
       if (!isAccessExpression(expr)) {
-        error(expr, Diagnostics.The_operand_of_a_delete_operator_must_be_a_property_reference);
+        error2(expr, Diagnostics.The_operand_of_a_delete_operator_must_be_a_property_reference);
         return booleanType;
       }
       if (isPropertyAccessExpression(expr) && isPrivateIdentifier(expr.name)) {
-        error(expr, Diagnostics.The_operand_of_a_delete_operator_cannot_be_a_private_identifier);
+        error2(expr, Diagnostics.The_operand_of_a_delete_operator_cannot_be_a_private_identifier);
       }
       const links = getNodeLinks(expr);
       const symbol = getExportSymbolOfValueSymbolIfExported(links.resolvedSymbol);
       if (symbol) {
         if (isReadonlySymbol(symbol)) {
-          error(expr, Diagnostics.The_operand_of_a_delete_operator_cannot_be_a_read_only_property);
+          error2(expr, Diagnostics.The_operand_of_a_delete_operator_cannot_be_a_read_only_property);
+        } else {
+          checkDeleteExpressionMustBeOptional(expr, symbol);
         }
-        checkDeleteExpressionMustBeOptional(expr, symbol);
       }
       return booleanType;
     }
     function checkDeleteExpressionMustBeOptional(expr, symbol) {
       const type = getTypeOfSymbol(symbol);
-      if (strictNullChecks && !(type.flags & (3 /* AnyOrUnknown */ | 131072 /* Never */)) && !(exactOptionalPropertyTypes ? symbol.flags & 16777216 /* Optional */ : getTypeFacts(type) & 16777216 /* IsUndefined */)) {
-        error(expr, Diagnostics.The_operand_of_a_delete_operator_must_be_optional);
+      if (strictNullChecks && !(type.flags & (3 /* AnyOrUnknown */ | 131072 /* Never */)) && !(exactOptionalPropertyTypes ? symbol.flags & 16777216 /* Optional */ : hasTypeFacts(type, 16777216 /* IsUndefined */))) {
+        error2(expr, Diagnostics.The_operand_of_a_delete_operator_must_be_optional);
       }
     }
     function checkTypeOfExpression(node) {
@@ -174518,27 +158442,27 @@ ${lanes.join("\n")}
       return typeofType;
     }
     function checkVoidExpression(node) {
-      checkExpression(node.expression);
+      checkNodeDeferred(node);
       return undefinedWideningType;
     }
-    function checkAwaitExpressionGrammar(node) {
+    function checkAwaitGrammar(node) {
+      let hasError = false;
       const container = getContainingFunctionOrClassStaticBlock(node);
       if (container && isClassStaticBlockDeclaration(container)) {
-        error(node, Diagnostics.Await_expression_cannot_be_used_inside_a_class_static_block);
-      } else if (!(node.flags & 32768 /* AwaitContext */)) {
+        const message = isAwaitExpression(node) ? Diagnostics.await_expression_cannot_be_used_inside_a_class_static_block : Diagnostics.await_using_statements_cannot_be_used_inside_a_class_static_block;
+        error2(node, message);
+        hasError = true;
+      } else if (!(node.flags & 65536 /* AwaitContext */)) {
         if (isInTopLevelContext(node)) {
           const sourceFile = getSourceFileOfNode(node);
           if (!hasParseDiagnostics(sourceFile)) {
             let span;
             if (!isEffectiveExternalModule(sourceFile, compilerOptions)) {
               span ?? (span = getSpanOfTokenAtPosition(sourceFile, node.pos));
-              const diagnostic = createFileDiagnostic(
-                sourceFile,
-                span.start,
-                span.length,
-                Diagnostics.await_expressions_are_only_allowed_at_the_top_level_of_a_file_when_that_file_is_a_module_but_this_file_has_no_imports_or_exports_Consider_adding_an_empty_export_to_make_this_file_a_module
-              );
+              const message = isAwaitExpression(node) ? Diagnostics.await_expressions_are_only_allowed_at_the_top_level_of_a_file_when_that_file_is_a_module_but_this_file_has_no_imports_or_exports_Consider_adding_an_empty_export_to_make_this_file_a_module : Diagnostics.await_using_statements_are_only_allowed_at_the_top_level_of_a_file_when_that_file_is_a_module_but_this_file_has_no_imports_or_exports_Consider_adding_an_empty_export_to_make_this_file_a_module;
+              const diagnostic = createFileDiagnostic(sourceFile, span.start, span.length, message);
               diagnostics.add(diagnostic);
+              hasError = true;
             }
             switch (moduleKind) {
               case 100 /* Node16 */:
@@ -174548,6 +158472,7 @@ ${lanes.join("\n")}
                   diagnostics.add(
                     createFileDiagnostic(sourceFile, span.start, span.length, Diagnostics.The_current_file_is_a_CommonJS_module_and_cannot_use_await_at_the_top_level)
                   );
+                  hasError = true;
                   break;
                 }
               case 7 /* ES2022 */:
@@ -174558,14 +158483,9 @@ ${lanes.join("\n")}
                 }
               default:
                 span ?? (span = getSpanOfTokenAtPosition(sourceFile, node.pos));
-                diagnostics.add(
-                  createFileDiagnostic(
-                    sourceFile,
-                    span.start,
-                    span.length,
-                    Diagnostics.Top_level_await_expressions_are_only_allowed_when_the_module_option_is_set_to_es2022_esnext_system_node16_or_nodenext_and_the_target_option_is_set_to_es2017_or_higher
-                  )
-                );
+                const message = isAwaitExpression(node) ? Diagnostics.Top_level_await_expressions_are_only_allowed_when_the_module_option_is_set_to_es2022_esnext_system_node16_or_nodenext_and_the_target_option_is_set_to_es2017_or_higher : Diagnostics.Top_level_await_using_statements_are_only_allowed_when_the_module_option_is_set_to_es2022_esnext_system_node16_or_nodenext_and_the_target_option_is_set_to_es2017_or_higher;
+                diagnostics.add(createFileDiagnostic(sourceFile, span.start, span.length, message));
+                hasError = true;
                 break;
             }
           }
@@ -174573,21 +158493,25 @@ ${lanes.join("\n")}
           const sourceFile = getSourceFileOfNode(node);
           if (!hasParseDiagnostics(sourceFile)) {
             const span = getSpanOfTokenAtPosition(sourceFile, node.pos);
-            const diagnostic = createFileDiagnostic(sourceFile, span.start, span.length, Diagnostics.await_expressions_are_only_allowed_within_async_functions_and_at_the_top_levels_of_modules);
-            if (container && container.kind !== 175 /* Constructor */ && (getFunctionFlags(container) & 2 /* Async */) === 0) {
+            const message = isAwaitExpression(node) ? Diagnostics.await_expressions_are_only_allowed_within_async_functions_and_at_the_top_levels_of_modules : Diagnostics.await_using_statements_are_only_allowed_within_async_functions_and_at_the_top_levels_of_modules;
+            const diagnostic = createFileDiagnostic(sourceFile, span.start, span.length, message);
+            if (container && container.kind !== 176 /* Constructor */ && (getFunctionFlags(container) & 2 /* Async */) === 0) {
               const relatedInfo = createDiagnosticForNode(container, Diagnostics.Did_you_mean_to_mark_this_function_as_async);
               addRelatedInfo(diagnostic, relatedInfo);
             }
             diagnostics.add(diagnostic);
+            hasError = true;
           }
         }
       }
-      if (isInParameterInitializerBeforeContainingFunction(node)) {
-        error(node, Diagnostics.await_expressions_cannot_be_used_in_a_parameter_initializer);
+      if (isAwaitExpression(node) && isInParameterInitializerBeforeContainingFunction(node)) {
+        error2(node, Diagnostics.await_expressions_cannot_be_used_in_a_parameter_initializer);
+        hasError = true;
       }
+      return hasError;
     }
     function checkAwaitExpression(node) {
-      addLazyDiagnostic(() => checkAwaitExpressionGrammar(node));
+      addLazyDiagnostic(() => checkAwaitGrammar(node));
       const operandType = checkExpression(node.expression);
       const awaitedType = checkAwaitedType(
         operandType,
@@ -174633,26 +158557,22 @@ ${lanes.join("\n")}
         case 55 /* TildeToken */:
           checkNonNullType(operandType, node.operand);
           if (maybeTypeOfKindConsideringBaseConstraint(operandType, 12288 /* ESSymbolLike */)) {
-            error(node.operand, Diagnostics.The_0_operator_cannot_be_applied_to_type_symbol, tokenToString(node.operator));
+            error2(node.operand, Diagnostics.The_0_operator_cannot_be_applied_to_type_symbol, tokenToString(node.operator));
           }
           if (node.operator === 40 /* PlusToken */) {
             if (maybeTypeOfKindConsideringBaseConstraint(operandType, 2112 /* BigIntLike */)) {
-              error(node.operand, Diagnostics.Operator_0_cannot_be_applied_to_type_1, tokenToString(node.operator), typeToString(getBaseTypeOfLiteralType(operandType)));
+              error2(node.operand, Diagnostics.Operator_0_cannot_be_applied_to_type_1, tokenToString(node.operator), typeToString(getBaseTypeOfLiteralType(operandType)));
             }
             return numberType;
           }
           return getUnaryResultType(operandType);
         case 54 /* ExclamationToken */:
           checkTruthinessOfType(operandType, node.operand);
-          const facts = getTypeFacts(operandType) & (4194304 /* Truthy */ | 8388608 /* Falsy */);
+          const facts = getTypeFacts(operandType, 4194304 /* Truthy */ | 8388608 /* Falsy */);
           return facts === 4194304 /* Truthy */ ? falseType : facts === 8388608 /* Falsy */ ? trueType : booleanType;
         case 46 /* PlusPlusToken */:
         case 47 /* MinusMinusToken */:
-          const ok = checkArithmeticOperandType(
-            node.operand,
-            checkNonNullType(operandType, node.operand),
-            Diagnostics.An_arithmetic_operand_must_be_of_type_any_number_bigint_or_an_enum_type
-          );
+          const ok = checkArithmeticOperandType(node.operand, checkNonNullType(operandType, node.operand), Diagnostics.An_arithmetic_operand_must_be_of_type_any_number_bigint_or_an_enum_type);
           if (ok) {
             checkReferenceExpression(
               node.operand,
@@ -174728,16 +158648,35 @@ ${lanes.join("\n")}
     function isConstEnumSymbol(symbol) {
       return (symbol.flags & 128 /* ConstEnum */) !== 0;
     }
-    function checkInstanceOfExpression(left, right, leftType, rightType) {
+    function getSymbolHasInstanceMethodOfObjectType(type) {
+      const hasInstancePropertyName = getPropertyNameForKnownSymbolName("hasInstance");
+      const hasInstanceProperty = getPropertyOfObjectType(type, hasInstancePropertyName);
+      if (hasInstanceProperty) {
+        const hasInstancePropertyType = getTypeOfSymbol(hasInstanceProperty);
+        if (hasInstancePropertyType && getSignaturesOfType(hasInstancePropertyType, 0 /* Call */).length !== 0) {
+          return hasInstancePropertyType;
+        }
+      }
+    }
+    function checkInstanceOfExpression(left, right, leftType, rightType, checkMode) {
       if (leftType === silentNeverType || rightType === silentNeverType) {
         return silentNeverType;
       }
       if (!isTypeAny(leftType) && allTypesAssignableToKind(leftType, 402784252 /* Primitive */)) {
-        error(left, Diagnostics.The_left_hand_side_of_an_instanceof_expression_must_be_of_type_any_an_object_type_or_a_type_parameter);
+        error2(left, Diagnostics.The_left_hand_side_of_an_instanceof_expression_must_be_of_type_any_an_object_type_or_a_type_parameter);
       }
-      if (!(isTypeAny(rightType) || typeHasCallOrConstructSignatures(rightType) || isTypeSubtypeOf(rightType, globalFunctionType))) {
-        error(right, Diagnostics.The_right_hand_side_of_an_instanceof_expression_must_be_of_type_any_or_of_a_type_assignable_to_the_Function_interface_type);
+      Debug.assert(isInstanceOfExpression(left.parent));
+      const signature = getResolvedSignature(
+        left.parent,
+        /*candidatesOutArray*/
+        void 0,
+        checkMode
+      );
+      if (signature === resolvingSignature) {
+        return silentNeverType;
       }
+      const returnType = getReturnTypeOfSignature(signature);
+      checkTypeAssignableTo(returnType, booleanType, right, Diagnostics.An_object_s_Symbol_hasInstance_method_must_return_a_boolean_value_for_it_to_be_used_on_the_right_hand_side_of_an_instanceof_expression);
       return booleanType;
     }
     function hasEmptyObjectIntersection(type) {
@@ -174765,7 +158704,7 @@ ${lanes.join("\n")}
       }
       if (checkTypeAssignableTo(checkNonNullType(rightType, right), nonPrimitiveType, right)) {
         if (hasEmptyObjectIntersection(rightType)) {
-          error(right, Diagnostics.Type_0_may_represent_a_primitive_value_which_is_not_permitted_as_the_right_operand_of_the_in_operator, typeToString(rightType));
+          error2(right, Diagnostics.Type_0_may_represent_a_primitive_value_which_is_not_permitted_as_the_right_operand_of_the_in_operator, typeToString(rightType));
         }
       }
       return booleanType;
@@ -174783,7 +158722,7 @@ ${lanes.join("\n")}
     function checkObjectLiteralDestructuringPropertyAssignment(node, objectLiteralType, propertyIndex, allProperties, rightIsThis = false) {
       const properties = node.properties;
       const property = properties[propertyIndex];
-      if (property.kind === 302 /* PropertyAssignment */ || property.kind === 303 /* ShorthandPropertyAssignment */) {
+      if (property.kind === 303 /* PropertyAssignment */ || property.kind === 304 /* ShorthandPropertyAssignment */) {
         const name = property.name;
         const exprType = getLiteralTypeFromPropertyName(name);
         if (isTypeUsableAsPropertyName(exprType)) {
@@ -174804,10 +158743,10 @@ ${lanes.join("\n")}
         }
         const elementType = getIndexedAccessType(objectLiteralType, exprType, 32 /* ExpressionPosition */, name);
         const type = getFlowTypeOfDestructuring(property, elementType);
-        return checkDestructuringAssignment(property.kind === 303 /* ShorthandPropertyAssignment */ ? property : property.initializer, type);
-      } else if (property.kind === 304 /* SpreadAssignment */) {
+        return checkDestructuringAssignment(property.kind === 304 /* ShorthandPropertyAssignment */ ? property : property.initializer, type);
+      } else if (property.kind === 305 /* SpreadAssignment */) {
         if (propertyIndex < properties.length - 1) {
-          error(property, Diagnostics.A_rest_element_must_be_last_in_a_destructuring_pattern);
+          error2(property, Diagnostics.A_rest_element_must_be_last_in_a_destructuring_pattern);
         } else {
           if (languageVersion < 99 /* ESNext */) {
             checkExternalEmitHelpers(property, 4 /* Rest */);
@@ -174825,7 +158764,7 @@ ${lanes.join("\n")}
           return checkDestructuringAssignment(property.expression, type);
         }
       } else {
-        error(property, Diagnostics.Property_assignment_expected);
+        error2(property, Diagnostics.Property_assignment_expected);
       }
     }
     function checkArrayLiteralAssignment(node, sourceType, checkMode) {
@@ -174837,7 +158776,7 @@ ${lanes.join("\n")}
       let inBoundsType = compilerOptions.noUncheckedIndexedAccess ? void 0 : possiblyOutOfBoundsType;
       for (let i = 0; i < elements.length; i++) {
         let type = possiblyOutOfBoundsType;
-        if (node.elements[i].kind === 229 /* SpreadElement */) {
+        if (node.elements[i].kind === 230 /* SpreadElement */) {
           type = inBoundsType = inBoundsType ?? (checkIteratedTypeOrElementType(65 /* Destructuring */, sourceType, undefinedType, node) || errorType);
         }
         checkArrayLiteralDestructuringElementAssignment(node, sourceType, i, type, checkMode);
@@ -174847,8 +158786,8 @@ ${lanes.join("\n")}
     function checkArrayLiteralDestructuringElementAssignment(node, sourceType, elementIndex, elementType, checkMode) {
       const elements = node.elements;
       const element = elements[elementIndex];
-      if (element.kind !== 231 /* OmittedExpression */) {
-        if (element.kind !== 229 /* SpreadElement */) {
+      if (element.kind !== 232 /* OmittedExpression */) {
+        if (element.kind !== 230 /* SpreadElement */) {
           const indexType = getNumberLiteralType(elementIndex);
           if (isArrayLikeType(sourceType)) {
             const accessFlags = 32 /* ExpressionPosition */ | (hasDefaultValue(element) ? 16 /* NoTupleBoundsCheck */ : 0);
@@ -174860,11 +158799,11 @@ ${lanes.join("\n")}
           return checkDestructuringAssignment(element, elementType, checkMode);
         }
         if (elementIndex < elements.length - 1) {
-          error(element, Diagnostics.A_rest_element_must_be_last_in_a_destructuring_pattern);
+          error2(element, Diagnostics.A_rest_element_must_be_last_in_a_destructuring_pattern);
         } else {
           const restExpression = element.expression;
-          if (restExpression.kind === 225 /* BinaryExpression */ && restExpression.operatorToken.kind === 64 /* EqualsToken */) {
-            error(restExpression.operatorToken, Diagnostics.A_rest_element_cannot_have_an_initializer);
+          if (restExpression.kind === 226 /* BinaryExpression */ && restExpression.operatorToken.kind === 64 /* EqualsToken */) {
+            error2(restExpression.operatorToken, Diagnostics.A_rest_element_cannot_have_an_initializer);
           } else {
             checkGrammarForDisallowedTrailingComma(node.elements, Diagnostics.A_rest_parameter_or_binding_pattern_may_not_have_a_trailing_comma);
             const type = everyType(sourceType, isTupleType) ? mapType(sourceType, (t) => sliceTupleType(t, elementIndex)) : createArrayType(elementType);
@@ -174876,10 +158815,10 @@ ${lanes.join("\n")}
     }
     function checkDestructuringAssignment(exprOrAssignment, sourceType, checkMode, rightIsThis) {
       let target;
-      if (exprOrAssignment.kind === 303 /* ShorthandPropertyAssignment */) {
+      if (exprOrAssignment.kind === 304 /* ShorthandPropertyAssignment */) {
         const prop = exprOrAssignment;
         if (prop.objectAssignmentInitializer) {
-          if (strictNullChecks && !(getTypeFacts(checkExpression(prop.objectAssignmentInitializer)) & 16777216 /* IsUndefined */)) {
+          if (strictNullChecks && !hasTypeFacts(checkExpression(prop.objectAssignmentInitializer), 16777216 /* IsUndefined */)) {
             sourceType = getTypeWithFacts(sourceType, 524288 /* NEUndefined */);
           }
           checkBinaryLikeExpression(prop.name, prop.equalsToken, prop.objectAssignmentInitializer, checkMode);
@@ -174888,26 +158827,26 @@ ${lanes.join("\n")}
       } else {
         target = exprOrAssignment;
       }
-      if (target.kind === 225 /* BinaryExpression */ && target.operatorToken.kind === 64 /* EqualsToken */) {
+      if (target.kind === 226 /* BinaryExpression */ && target.operatorToken.kind === 64 /* EqualsToken */) {
         checkBinaryExpression(target, checkMode);
         target = target.left;
         if (strictNullChecks) {
           sourceType = getTypeWithFacts(sourceType, 524288 /* NEUndefined */);
         }
       }
-      if (target.kind === 209 /* ObjectLiteralExpression */) {
+      if (target.kind === 210 /* ObjectLiteralExpression */) {
         return checkObjectLiteralAssignment(target, sourceType, rightIsThis);
       }
-      if (target.kind === 208 /* ArrayLiteralExpression */) {
+      if (target.kind === 209 /* ArrayLiteralExpression */) {
         return checkArrayLiteralAssignment(target, sourceType, checkMode);
       }
       return checkReferenceAssignment(target, sourceType, checkMode);
     }
     function checkReferenceAssignment(target, sourceType, checkMode) {
       const targetType = checkExpression(target, checkMode);
-      const error2 = target.parent.kind === 304 /* SpreadAssignment */ ? Diagnostics.The_target_of_an_object_rest_assignment_must_be_a_variable_or_a_property_access : Diagnostics.The_left_hand_side_of_an_assignment_expression_must_be_a_variable_or_a_property_access;
-      const optionalError = target.parent.kind === 304 /* SpreadAssignment */ ? Diagnostics.The_target_of_an_object_rest_assignment_may_not_be_an_optional_property_access : Diagnostics.The_left_hand_side_of_an_assignment_expression_may_not_be_an_optional_property_access;
-      if (checkReferenceExpression(target, error2, optionalError)) {
+      const error3 = target.parent.kind === 305 /* SpreadAssignment */ ? Diagnostics.The_target_of_an_object_rest_assignment_must_be_a_variable_or_a_property_access : Diagnostics.The_left_hand_side_of_an_assignment_expression_must_be_a_variable_or_a_property_access;
+      const optionalError = target.parent.kind === 305 /* SpreadAssignment */ ? Diagnostics.The_target_of_an_object_rest_assignment_may_not_be_an_optional_property_access : Diagnostics.The_left_hand_side_of_an_assignment_expression_may_not_be_an_optional_property_access;
+      if (checkReferenceExpression(target, error3, optionalError)) {
         checkTypeAssignableToAndOptionallyElaborate(sourceType, targetType, target, target);
       }
       if (isPrivateIdentifierPropertyAccessExpression(target)) {
@@ -174921,8 +158860,8 @@ ${lanes.join("\n")}
         case 80 /* Identifier */:
         case 11 /* StringLiteral */:
         case 14 /* RegularExpressionLiteral */:
-        case 214 /* TaggedTemplateExpression */:
-        case 227 /* TemplateExpression */:
+        case 215 /* TaggedTemplateExpression */:
+        case 228 /* TemplateExpression */:
         case 15 /* NoSubstitutionTemplateLiteral */:
         case 9 /* NumericLiteral */:
         case 10 /* BigIntLiteral */:
@@ -174930,25 +158869,25 @@ ${lanes.join("\n")}
         case 97 /* FalseKeyword */:
         case 106 /* NullKeyword */:
         case 157 /* UndefinedKeyword */:
-        case 217 /* FunctionExpression */:
-        case 230 /* ClassExpression */:
-        case 218 /* ArrowFunction */:
-        case 208 /* ArrayLiteralExpression */:
-        case 209 /* ObjectLiteralExpression */:
-        case 220 /* TypeOfExpression */:
-        case 234 /* NonNullExpression */:
-        case 284 /* JsxSelfClosingElement */:
-        case 283 /* JsxElement */:
+        case 218 /* FunctionExpression */:
+        case 231 /* ClassExpression */:
+        case 219 /* ArrowFunction */:
+        case 209 /* ArrayLiteralExpression */:
+        case 210 /* ObjectLiteralExpression */:
+        case 221 /* TypeOfExpression */:
+        case 235 /* NonNullExpression */:
+        case 285 /* JsxSelfClosingElement */:
+        case 284 /* JsxElement */:
           return true;
-        case 226 /* ConditionalExpression */:
+        case 227 /* ConditionalExpression */:
           return isSideEffectFree(node.whenTrue) && isSideEffectFree(node.whenFalse);
-        case 225 /* BinaryExpression */:
+        case 226 /* BinaryExpression */:
           if (isAssignmentOperator(node.operatorToken.kind)) {
             return false;
           }
           return isSideEffectFree(node.left) && isSideEffectFree(node.right);
-        case 223 /* PrefixUnaryExpression */:
-        case 224 /* PostfixUnaryExpression */:
+        case 224 /* PrefixUnaryExpression */:
+        case 225 /* PostfixUnaryExpression */:
           switch (node.operator) {
             case 54 /* ExclamationToken */:
             case 40 /* PlusToken */:
@@ -174957,9 +158896,9 @@ ${lanes.join("\n")}
               return true;
           }
           return false;
-        case 221 /* VoidExpression */:
-        case 215 /* TypeAssertionExpression */:
-        case 233 /* AsExpression */:
+        case 222 /* VoidExpression */:
+        case 216 /* TypeAssertionExpression */:
+        case 234 /* AsExpression */:
         default:
           return false;
       }
@@ -175003,7 +158942,7 @@ ${lanes.join("\n")}
         }
         checkGrammarNullishCoalesceWithLogicalExpression(node);
         const operator = node.operatorToken.kind;
-        if (operator === 64 /* EqualsToken */ && (node.left.kind === 209 /* ObjectLiteralExpression */ || node.left.kind === 208 /* ArrayLiteralExpression */)) {
+        if (operator === 64 /* EqualsToken */ && (node.left.kind === 210 /* ObjectLiteralExpression */ || node.left.kind === 209 /* ArrayLiteralExpression */)) {
           state.skip = true;
           setLastResult(state, checkDestructuringAssignment(node.left, checkExpression(node.right, checkMode), checkMode, node.right.kind === 110 /* ThisKeyword */));
           return state;
@@ -175028,7 +158967,7 @@ ${lanes.join("\n")}
           const operator = operatorToken.kind;
           if (isLogicalOrCoalescingBinaryOperator(operator)) {
             let parent2 = node.parent;
-            while (parent2.kind === 216 /* ParenthesizedExpression */ || isLogicalOrCoalescingBinaryExpression(parent2)) {
+            while (parent2.kind === 217 /* ParenthesizedExpression */ || isLogicalOrCoalescingBinaryExpression(parent2)) {
               parent2 = parent2.parent;
             }
             if (operator === 56 /* AmpersandAmpersandToken */ || isIfStatement(parent2)) {
@@ -175052,7 +158991,7 @@ ${lanes.join("\n")}
           Debug.assertIsDefined(leftType);
           const rightType = getLastResult(state);
           Debug.assertIsDefined(rightType);
-          result = checkBinaryLikeExpressionWorker(node.left, node.operatorToken, node.right, leftType, rightType, node);
+          result = checkBinaryLikeExpressionWorker(node.left, node.operatorToken, node.right, leftType, rightType, state.checkMode, node);
         }
         state.skip = false;
         setLeftType(
@@ -175104,7 +159043,7 @@ ${lanes.join("\n")}
     }
     function checkBinaryLikeExpression(left, operatorToken, right, checkMode, errorNode) {
       const operator = operatorToken.kind;
-      if (operator === 64 /* EqualsToken */ && (left.kind === 209 /* ObjectLiteralExpression */ || left.kind === 208 /* ArrayLiteralExpression */)) {
+      if (operator === 64 /* EqualsToken */ && (left.kind === 210 /* ObjectLiteralExpression */ || left.kind === 209 /* ArrayLiteralExpression */)) {
         return checkDestructuringAssignment(left, checkExpression(right, checkMode), checkMode, right.kind === 110 /* ThisKeyword */);
       }
       let leftType;
@@ -175114,9 +159053,9 @@ ${lanes.join("\n")}
         leftType = checkExpression(left, checkMode);
       }
       const rightType = checkExpression(right, checkMode);
-      return checkBinaryLikeExpressionWorker(left, operatorToken, right, leftType, rightType, errorNode);
+      return checkBinaryLikeExpressionWorker(left, operatorToken, right, leftType, rightType, checkMode, errorNode);
     }
-    function checkBinaryLikeExpressionWorker(left, operatorToken, right, leftType, rightType, errorNode) {
+    function checkBinaryLikeExpressionWorker(left, operatorToken, right, leftType, rightType, checkMode, errorNode) {
       const operator = operatorToken.kind;
       switch (operator) {
         case 42 /* AsteriskToken */:
@@ -175148,7 +159087,7 @@ ${lanes.join("\n")}
           rightType = checkNonNullType(rightType, right);
           let suggestedOperator;
           if (leftType.flags & 528 /* BooleanLike */ && rightType.flags & 528 /* BooleanLike */ && (suggestedOperator = getSuggestedBooleanOperator(operatorToken.kind)) !== void 0) {
-            error(errorNode || operatorToken, Diagnostics.The_0_operator_is_not_allowed_for_boolean_types_Consider_using_1_instead, tokenToString(operatorToken.kind), tokenToString(suggestedOperator));
+            error2(errorNode || operatorToken, Diagnostics.The_0_operator_is_not_allowed_for_boolean_types_Consider_using_1_instead, tokenToString(operatorToken.kind), tokenToString(suggestedOperator));
             return numberType;
           } else {
             const leftOk = checkArithmeticOperandType(
@@ -175178,7 +159117,7 @@ ${lanes.join("\n")}
                 case 43 /* AsteriskAsteriskToken */:
                 case 68 /* AsteriskAsteriskEqualsToken */:
                   if (languageVersion < 3 /* ES2016 */) {
-                    error(errorNode, Diagnostics.Exponentiation_cannot_be_performed_on_bigint_values_unless_the_target_option_is_set_to_es2016_or_later);
+                    error2(errorNode, Diagnostics.Exponentiation_cannot_be_performed_on_bigint_values_unless_the_target_option_is_set_to_es2016_or_later);
                   }
               }
               resultType2 = bigintType;
@@ -175245,7 +159184,9 @@ ${lanes.join("\n")}
           }
           if (!resultType) {
             const closeEnoughKind = 296 /* NumberLike */ | 2112 /* BigIntLike */ | 402653316 /* StringLike */ | 3 /* AnyOrUnknown */;
-            reportOperatorError((left2, right2) => isTypeAssignableToKind(left2, closeEnoughKind) && isTypeAssignableToKind(right2, closeEnoughKind));
+            reportOperatorError(
+              (left2, right2) => isTypeAssignableToKind(left2, closeEnoughKind) && isTypeAssignableToKind(right2, closeEnoughKind)
+            );
             return anyType;
           }
           if (operator === 65 /* PlusEqualsToken */) {
@@ -175273,20 +159214,23 @@ ${lanes.join("\n")}
         case 36 /* ExclamationEqualsToken */:
         case 37 /* EqualsEqualsEqualsToken */:
         case 38 /* ExclamationEqualsEqualsToken */:
-          if (isLiteralExpressionOfObject(left) || isLiteralExpressionOfObject(right)) {
-            const eqType = operator === 35 /* EqualsEqualsToken */ || operator === 37 /* EqualsEqualsEqualsToken */;
-            error(errorNode, Diagnostics.This_condition_will_always_return_0_since_JavaScript_compares_objects_by_reference_not_value, eqType ? "false" : "true");
+          if (!(checkMode && checkMode & 64 /* TypeOnly */)) {
+            if ((isLiteralExpressionOfObject(left) || isLiteralExpressionOfObject(right)) && // only report for === and !== in JS, not == or !=
+            (!isInJSFile(left) || (operator === 37 /* EqualsEqualsEqualsToken */ || operator === 38 /* ExclamationEqualsEqualsToken */))) {
+              const eqType = operator === 35 /* EqualsEqualsToken */ || operator === 37 /* EqualsEqualsEqualsToken */;
+              error2(errorNode, Diagnostics.This_condition_will_always_return_0_since_JavaScript_compares_objects_by_reference_not_value, eqType ? "false" : "true");
+            }
+            checkNaNEquality(errorNode, operator, left, right);
+            reportOperatorErrorUnless((left2, right2) => isTypeEqualityComparableTo(left2, right2) || isTypeEqualityComparableTo(right2, left2));
           }
-          checkNaNEquality(errorNode, operator, left, right);
-          reportOperatorErrorUnless((left2, right2) => isTypeEqualityComparableTo(left2, right2) || isTypeEqualityComparableTo(right2, left2));
           return booleanType;
         case 104 /* InstanceOfKeyword */:
-          return checkInstanceOfExpression(left, right, leftType, rightType);
+          return checkInstanceOfExpression(left, right, leftType, rightType, checkMode);
         case 103 /* InKeyword */:
           return checkInExpression(left, right, leftType, rightType);
         case 56 /* AmpersandAmpersandToken */:
         case 77 /* AmpersandAmpersandEqualsToken */: {
-          const resultType2 = getTypeFacts(leftType) & 4194304 /* Truthy */ ? getUnionType([extractDefinitelyFalsyTypes(strictNullChecks ? leftType : getBaseTypeOfLiteralType(rightType)), rightType]) : leftType;
+          const resultType2 = hasTypeFacts(leftType, 4194304 /* Truthy */) ? getUnionType([extractDefinitelyFalsyTypes(strictNullChecks ? leftType : getBaseTypeOfLiteralType(rightType)), rightType]) : leftType;
           if (operator === 77 /* AmpersandAmpersandEqualsToken */) {
             checkAssignmentOperator(rightType);
           }
@@ -175294,7 +159238,7 @@ ${lanes.join("\n")}
         }
         case 57 /* BarBarToken */:
         case 76 /* BarBarEqualsToken */: {
-          const resultType2 = getTypeFacts(leftType) & 8388608 /* Falsy */ ? getUnionType([getNonNullableType(removeDefinitelyFalsyTypes(leftType)), rightType], 2 /* Subtype */) : leftType;
+          const resultType2 = hasTypeFacts(leftType, 8388608 /* Falsy */) ? getUnionType([getNonNullableType(removeDefinitelyFalsyTypes(leftType)), rightType], 2 /* Subtype */) : leftType;
           if (operator === 76 /* BarBarEqualsToken */) {
             checkAssignmentOperator(rightType);
           }
@@ -175302,7 +159246,7 @@ ${lanes.join("\n")}
         }
         case 61 /* QuestionQuestionToken */:
         case 78 /* QuestionQuestionEqualsToken */: {
-          const resultType2 = getTypeFacts(leftType) & 262144 /* EQUndefinedOrNull */ ? getUnionType([getNonNullableType(leftType), rightType], 2 /* Subtype */) : leftType;
+          const resultType2 = hasTypeFacts(leftType, 262144 /* EQUndefinedOrNull */) ? getUnionType([getNonNullableType(leftType), rightType], 2 /* Subtype */) : leftType;
           if (operator === 78 /* QuestionQuestionEqualsToken */) {
             checkAssignmentOperator(rightType);
           }
@@ -175331,7 +159275,7 @@ ${lanes.join("\n")}
               return textSpanContainsPosition(diag2, start);
             });
             if (!isInDiag2657)
-              error(left, Diagnostics.Left_side_of_comma_operator_is_unused_and_has_no_side_effects);
+              error2(left, Diagnostics.Left_side_of_comma_operator_is_unused_and_has_no_side_effects);
           }
           return rightType;
         default:
@@ -175365,13 +159309,13 @@ ${lanes.join("\n")}
         }
       }
       function isIndirectCall(node) {
-        return node.parent.kind === 216 /* ParenthesizedExpression */ && isNumericLiteral(node.left) && node.left.text === "0" && (isCallExpression(node.parent.parent) && node.parent.parent.expression === node.parent || node.parent.parent.kind === 214 /* TaggedTemplateExpression */) && // special-case for "eval" because it's the only non-access case where an indirect call actually affects behavior.
+        return node.parent.kind === 217 /* ParenthesizedExpression */ && isNumericLiteral(node.left) && node.left.text === "0" && (isCallExpression(node.parent.parent) && node.parent.parent.expression === node.parent || node.parent.parent.kind === 215 /* TaggedTemplateExpression */) && // special-case for "eval" because it's the only non-access case where an indirect call actually affects behavior.
         (isAccessExpression(node.right) || isIdentifier(node.right) && node.right.escapedText === "eval");
       }
       function checkForDisallowedESSymbolOperand(operator2) {
         const offendingSymbolOperand = maybeTypeOfKindConsideringBaseConstraint(leftType, 12288 /* ESSymbolLike */) ? left : maybeTypeOfKindConsideringBaseConstraint(rightType, 12288 /* ESSymbolLike */) ? right : void 0;
         if (offendingSymbolOperand) {
-          error(offendingSymbolOperand, Diagnostics.The_0_operator_cannot_be_applied_to_type_symbol, tokenToString(operator2));
+          error2(offendingSymbolOperand, Diagnostics.The_0_operator_cannot_be_applied_to_type_symbol, tokenToString(operator2));
           return false;
         }
         return true;
@@ -175397,7 +159341,7 @@ ${lanes.join("\n")}
         }
         function checkAssignmentOperatorWorker() {
           let assigneeType = leftType;
-          if (isCompoundAssignment(operatorToken.kind) && left.kind === 210 /* PropertyAccessExpression */) {
+          if (isCompoundAssignment(operatorToken.kind) && left.kind === 211 /* PropertyAccessExpression */) {
             assigneeType = checkPropertyAccessExpression(
               left,
               /*checkMode*/
@@ -175406,11 +159350,7 @@ ${lanes.join("\n")}
               true
             );
           }
-          if (checkReferenceExpression(
-            left,
-            Diagnostics.The_left_hand_side_of_an_assignment_expression_must_be_a_variable_or_a_property_access,
-            Diagnostics.The_left_hand_side_of_an_assignment_expression_may_not_be_an_optional_property_access
-          )) {
+          if (checkReferenceExpression(left, Diagnostics.The_left_hand_side_of_an_assignment_expression_must_be_a_variable_or_a_property_access, Diagnostics.The_left_hand_side_of_an_assignment_expression_may_not_be_an_optional_property_access)) {
             let headMessage;
             if (exactOptionalPropertyTypes && isPropertyAccessExpression(left) && maybeTypeOfKind(valueType, 32768 /* Undefined */)) {
               const target = getTypeOfPropertyOfType(getTypeOfExpression(left.expression), left.name.escapedText);
@@ -175492,21 +159432,13 @@ ${lanes.join("\n")}
         const isLeftNaN = isGlobalNaN(skipParentheses(left2));
         const isRightNaN = isGlobalNaN(skipParentheses(right2));
         if (isLeftNaN || isRightNaN) {
-          const err = error(
-            errorNode2,
-            Diagnostics.This_condition_will_always_return_0,
-            tokenToString(operator2 === 37 /* EqualsEqualsEqualsToken */ || operator2 === 35 /* EqualsEqualsToken */ ? 97 /* FalseKeyword */ : 112 /* TrueKeyword */)
-          );
+          const err = error2(errorNode2, Diagnostics.This_condition_will_always_return_0, tokenToString(operator2 === 37 /* EqualsEqualsEqualsToken */ || operator2 === 35 /* EqualsEqualsToken */ ? 97 /* FalseKeyword */ : 112 /* TrueKeyword */));
           if (isLeftNaN && isRightNaN)
             return;
           const operatorString = operator2 === 38 /* ExclamationEqualsEqualsToken */ || operator2 === 36 /* ExclamationEqualsToken */ ? tokenToString(54 /* ExclamationToken */) : "";
           const location = isLeftNaN ? right2 : left2;
           const expression = skipParentheses(location);
-          addRelatedInfo(err, createDiagnosticForNode(
-            location,
-            Diagnostics.Did_you_mean_0,
-            `${operatorString}Number.isNaN(${isEntityNameExpression(expression) ? entityNameToString(expression) : "..."})`
-          ));
+          addRelatedInfo(err, createDiagnosticForNode(location, Diagnostics.Did_you_mean_0, `${operatorString}Number.isNaN(${isEntityNameExpression(expression) ? entityNameToString(expression) : "..."})`));
         }
       }
       function isGlobalNaN(expr) {
@@ -175546,7 +159478,15 @@ ${lanes.join("\n")}
           checkExternalEmitHelpers(node, 256 /* Values */);
         }
       }
-      const returnType = getReturnTypeFromAnnotation(func);
+      let returnType = getReturnTypeFromAnnotation(func);
+      if (returnType && returnType.flags & 1048576 /* Union */) {
+        returnType = filterType(returnType, (t) => checkGeneratorInstantiationAssignabilityToReturnType(
+          t,
+          functionFlags,
+          /*errorNode*/
+          void 0
+        ));
+      }
       const iterationTypes = returnType && getIterationTypesOfGeneratorFunctionReturnType(returnType, isAsync);
       const signatureYieldType = iterationTypes && iterationTypes.yieldType || anyType;
       const signatureNextType = iterationTypes && iterationTypes.nextType || anyType;
@@ -175573,23 +159513,23 @@ ${lanes.join("\n")}
               void 0
             );
             if (!contextualType || isTypeAny(contextualType)) {
-              error(node, Diagnostics.yield_expression_implicitly_results_in_an_any_type_because_its_containing_generator_lacks_a_return_type_annotation);
+              error2(node, Diagnostics.yield_expression_implicitly_results_in_an_any_type_because_its_containing_generator_lacks_a_return_type_annotation);
             }
           }
         });
       }
       return type;
       function checkYieldExpressionGrammar() {
-        if (!(node.flags & 8192 /* YieldContext */)) {
+        if (!(node.flags & 16384 /* YieldContext */)) {
           grammarErrorOnFirstToken(node, Diagnostics.A_yield_expression_is_only_allowed_in_a_generator_body);
         }
         if (isInParameterInitializerBeforeContainingFunction(node)) {
-          error(node, Diagnostics.yield_expressions_cannot_be_used_in_a_parameter_initializer);
+          error2(node, Diagnostics.yield_expressions_cannot_be_used_in_a_parameter_initializer);
         }
       }
     }
     function checkConditionalExpression(node, checkMode) {
-      const type = checkTruthinessExpression(node.condition);
+      const type = checkTruthinessExpression(node.condition, checkMode);
       checkTestingKnownTruthyCallableOrAwaitableType(node.condition, type, node.whenTrue);
       const type1 = checkExpression(node.whenTrue, checkMode);
       const type2 = checkExpression(node.whenFalse, checkMode);
@@ -175605,16 +159545,20 @@ ${lanes.join("\n")}
       for (const span of node.templateSpans) {
         const type = checkExpression(span.expression);
         if (maybeTypeOfKindConsideringBaseConstraint(type, 12288 /* ESSymbolLike */)) {
-          error(span.expression, Diagnostics.Implicit_conversion_of_a_symbol_to_a_string_will_fail_at_runtime_Consider_wrapping_this_expression_in_String);
+          error2(span.expression, Diagnostics.Implicit_conversion_of_a_symbol_to_a_string_will_fail_at_runtime_Consider_wrapping_this_expression_in_String);
         }
         texts.push(span.literal.text);
         types.push(isTypeAssignableTo(type, templateConstraintType) ? type : stringType);
       }
-      return isConstContext(node) || isTemplateLiteralContext(node) || someType(getContextualType2(
+      if (isConstContext(node) || isTemplateLiteralContext(node) || someType(getContextualType2(
         node,
         /*contextFlags*/
         void 0
-      ) || unknownType, isTemplateLiteralContextualType) ? getTemplateLiteralType(texts, types) : stringType;
+      ) || unknownType, isTemplateLiteralContextualType)) {
+        return getTemplateLiteralType(texts, types);
+      }
+      const evaluated = node.parent.kind !== 215 /* TaggedTemplateExpression */ && evaluateTemplateExpression(node);
+      return evaluated ? getFreshTypeOfLiteralType(getStringLiteralType(evaluated)) : stringType;
     }
     function isTemplateLiteralContextualType(type) {
       return !!(type.flags & (128 /* StringLiteral */ | 134217728 /* TemplateLiteral */) || type.flags & 58982400 /* InstantiableNonPrimitive */ && maybeTypeOfKind(getBaseConstraintOfType(type) || unknownType, 402653316 /* StringLike */));
@@ -175670,7 +159614,7 @@ ${lanes.join("\n")}
         /*excludeJSDocTypeAssertions*/
         true
       );
-      return node.kind === 215 /* TypeAssertionExpression */ || node.kind === 233 /* AsExpression */ || isJSDocTypeAssertion(node);
+      return node.kind === 216 /* TypeAssertionExpression */ || node.kind === 234 /* AsExpression */ || isJSDocTypeAssertion(node);
     }
     function checkDeclarationInitializer(declaration, checkMode, contextualType) {
       const initializer = getEffectiveInitializer(declaration);
@@ -175687,7 +159631,7 @@ ${lanes.join("\n")}
         void 0,
         checkMode || 0 /* Normal */
       ) : checkExpressionCached(initializer, checkMode));
-      return isParameter(declaration) && declaration.name.kind === 206 /* ArrayBindingPattern */ && isTupleType(type) && !type.target.hasRestElement && getTypeReferenceArity(type) < declaration.name.elements.length ? padTupleType(type, declaration.name) : type;
+      return isParameter(declaration) && declaration.name.kind === 207 /* ArrayBindingPattern */ && isTupleType(type) && !type.target.hasRestElement && getTypeReferenceArity(type) < declaration.name.elements.length ? padTupleType(type, declaration.name) : type;
     }
     function padTupleType(type, pattern) {
       const patternElements = pattern.elements;
@@ -175695,7 +159639,7 @@ ${lanes.join("\n")}
       const elementFlags = type.target.elementFlags.slice();
       for (let i = getTypeReferenceArity(type); i < patternElements.length; i++) {
         const e = patternElements[i];
-        if (i < patternElements.length - 1 || !(e.kind === 207 /* BindingElement */ && e.dotDotDotToken)) {
+        if (i < patternElements.length - 1 || !(e.kind === 208 /* BindingElement */ && e.dotDotDotToken)) {
           elementTypes.push(!isOmittedExpression(e) && hasDefaultValue(e) ? getTypeFromBindingElement(
             e,
             /*includePatternInType*/
@@ -175712,7 +159656,7 @@ ${lanes.join("\n")}
       return createTupleType(elementTypes, elementFlags, type.target.readonly);
     }
     function widenTypeInferredFromInitializer(declaration, type) {
-      const widened = getCombinedNodeFlags(declaration) & 2 /* Const */ || isDeclarationReadonly(declaration) ? type : getWidenedLiteralType(type);
+      const widened = getCombinedNodeFlagsCached(declaration) & 6 /* Constant */ || isDeclarationReadonly(declaration) ? type : getWidenedLiteralType(type);
       if (isInJSFile(declaration)) {
         if (isEmptyLiteralType(widened)) {
           reportImplicitAny(declaration, anyType);
@@ -175756,14 +159700,14 @@ ${lanes.join("\n")}
       ));
     }
     function checkPropertyAssignment(node, checkMode) {
-      if (node.name.kind === 166 /* ComputedPropertyName */) {
+      if (node.name.kind === 167 /* ComputedPropertyName */) {
         checkComputedPropertyName(node.name);
       }
       return checkExpressionForMutableLocation(node.initializer, checkMode);
     }
     function checkObjectLiteralMethod(node, checkMode) {
       checkGrammarMethod(node);
-      if (node.name.kind === 166 /* ComputedPropertyName */) {
+      if (node.name.kind === 167 /* ComputedPropertyName */) {
         checkComputedPropertyName(node.name);
       }
       const uninstantiatedType = checkFunctionExpressionOrObjectLiteralMethod(node, checkMode);
@@ -175919,18 +159863,18 @@ ${lanes.join("\n")}
       if (quickType) {
         return quickType;
       }
-      if (node.flags & 134217728 /* TypeCached */ && flowTypeCache) {
+      if (node.flags & 268435456 /* TypeCached */ && flowTypeCache) {
         const cachedType = flowTypeCache[getNodeId(node)];
         if (cachedType) {
           return cachedType;
         }
       }
       const startInvocationCount = flowInvocationCount;
-      const type = checkExpression(node);
+      const type = checkExpression(node, 64 /* TypeOnly */);
       if (flowInvocationCount !== startInvocationCount) {
         const cache = flowTypeCache || (flowTypeCache = []);
         cache[getNodeId(node)] = type;
-        setNodeFlags(node, node.flags | 134217728 /* TypeCached */);
+        setNodeFlags(node, node.flags | 268435456 /* TypeCached */);
       }
       return type;
     }
@@ -175995,15 +159939,15 @@ ${lanes.join("\n")}
       return type;
     }
     function checkConstEnumAccess(node, type) {
-      const ok = node.parent.kind === 210 /* PropertyAccessExpression */ && node.parent.expression === node || node.parent.kind === 211 /* ElementAccessExpression */ && node.parent.expression === node || ((node.kind === 80 /* Identifier */ || node.kind === 165 /* QualifiedName */) && isInRightSideOfImportOrExportAssignment(node) || node.parent.kind === 185 /* TypeQuery */ && node.parent.exprName === node) || node.parent.kind === 280 /* ExportSpecifier */;
+      const ok = node.parent.kind === 211 /* PropertyAccessExpression */ && node.parent.expression === node || node.parent.kind === 212 /* ElementAccessExpression */ && node.parent.expression === node || ((node.kind === 80 /* Identifier */ || node.kind === 166 /* QualifiedName */) && isInRightSideOfImportOrExportAssignment(node) || node.parent.kind === 186 /* TypeQuery */ && node.parent.exprName === node) || node.parent.kind === 281 /* ExportSpecifier */;
       if (!ok) {
-        error(node, Diagnostics.const_enums_can_only_be_used_in_property_or_index_access_expressions_or_the_right_hand_side_of_an_import_declaration_or_export_assignment_or_type_query);
+        error2(node, Diagnostics.const_enums_can_only_be_used_in_property_or_index_access_expressions_or_the_right_hand_side_of_an_import_declaration_or_export_assignment_or_type_query);
       }
       if (getIsolatedModules(compilerOptions)) {
         Debug.assert(!!(type.symbol.flags & 128 /* ConstEnum */));
         const constEnumDeclaration = type.symbol.valueDeclaration;
-        if (constEnumDeclaration.flags & 16777216 /* Ambient */) {
-          error(node, Diagnostics.Cannot_access_ambient_const_enums_when_0_is_enabled, isolatedModulesLikeFlagName);
+        if (constEnumDeclaration.flags & 33554432 /* Ambient */ && !isValidTypeOnlyAliasUseSite(node)) {
+          error2(node, Diagnostics.Cannot_access_ambient_const_enums_when_0_is_enabled, isolatedModulesLikeFlagName);
         }
       }
     }
@@ -176022,9 +159966,9 @@ ${lanes.join("\n")}
       const kind = node.kind;
       if (cancellationToken) {
         switch (kind) {
-          case 230 /* ClassExpression */:
-          case 217 /* FunctionExpression */:
-          case 218 /* ArrowFunction */:
+          case 231 /* ClassExpression */:
+          case 218 /* FunctionExpression */:
+          case 219 /* ArrowFunction */:
             cancellationToken.throwIfCancellationRequested();
         }
       }
@@ -176041,7 +159985,7 @@ ${lanes.join("\n")}
           return nullWideningType;
         case 15 /* NoSubstitutionTemplateLiteral */:
         case 11 /* StringLiteral */:
-          return hasSkipDirectInferenceFlag(node) ? anyType : getFreshTypeOfLiteralType(getStringLiteralType(node.text));
+          return hasSkipDirectInferenceFlag(node) ? blockedStringType : getFreshTypeOfLiteralType(getStringLiteralType(node.text));
         case 9 /* NumericLiteral */:
           checkGrammarNumericLiteral(node);
           return getFreshTypeOfLiteralType(getNumberLiteralType(+node.text));
@@ -176055,81 +159999,81 @@ ${lanes.join("\n")}
           return trueType;
         case 97 /* FalseKeyword */:
           return falseType;
-        case 227 /* TemplateExpression */:
+        case 228 /* TemplateExpression */:
           return checkTemplateExpression(node);
         case 14 /* RegularExpressionLiteral */:
           return globalRegExpType;
-        case 208 /* ArrayLiteralExpression */:
+        case 209 /* ArrayLiteralExpression */:
           return checkArrayLiteral(node, checkMode, forceTuple);
-        case 209 /* ObjectLiteralExpression */:
+        case 210 /* ObjectLiteralExpression */:
           return checkObjectLiteral(node, checkMode);
-        case 210 /* PropertyAccessExpression */:
+        case 211 /* PropertyAccessExpression */:
           return checkPropertyAccessExpression(node, checkMode);
-        case 165 /* QualifiedName */:
+        case 166 /* QualifiedName */:
           return checkQualifiedName(node, checkMode);
-        case 211 /* ElementAccessExpression */:
+        case 212 /* ElementAccessExpression */:
           return checkIndexedAccess(node, checkMode);
-        case 212 /* CallExpression */:
+        case 213 /* CallExpression */:
           if (node.expression.kind === 102 /* ImportKeyword */) {
             return checkImportCallExpression(node);
           }
-        case 213 /* NewExpression */:
+        case 214 /* NewExpression */:
           return checkCallExpression(node, checkMode);
-        case 214 /* TaggedTemplateExpression */:
+        case 215 /* TaggedTemplateExpression */:
           return checkTaggedTemplateExpression(node);
-        case 216 /* ParenthesizedExpression */:
+        case 217 /* ParenthesizedExpression */:
           return checkParenthesizedExpression(node, checkMode);
-        case 230 /* ClassExpression */:
+        case 231 /* ClassExpression */:
           return checkClassExpression(node);
-        case 217 /* FunctionExpression */:
-        case 218 /* ArrowFunction */:
+        case 218 /* FunctionExpression */:
+        case 219 /* ArrowFunction */:
           return checkFunctionExpressionOrObjectLiteralMethod(node, checkMode);
-        case 220 /* TypeOfExpression */:
+        case 221 /* TypeOfExpression */:
           return checkTypeOfExpression(node);
-        case 215 /* TypeAssertionExpression */:
-        case 233 /* AsExpression */:
+        case 216 /* TypeAssertionExpression */:
+        case 234 /* AsExpression */:
           return checkAssertion(node, checkMode);
-        case 234 /* NonNullExpression */:
+        case 235 /* NonNullExpression */:
           return checkNonNullAssertion(node);
-        case 232 /* ExpressionWithTypeArguments */:
+        case 233 /* ExpressionWithTypeArguments */:
           return checkExpressionWithTypeArguments(node);
-        case 237 /* SatisfiesExpression */:
+        case 238 /* SatisfiesExpression */:
           return checkSatisfiesExpression(node);
-        case 235 /* MetaProperty */:
+        case 236 /* MetaProperty */:
           return checkMetaProperty(node);
-        case 219 /* DeleteExpression */:
+        case 220 /* DeleteExpression */:
           return checkDeleteExpression(node);
-        case 221 /* VoidExpression */:
+        case 222 /* VoidExpression */:
           return checkVoidExpression(node);
-        case 222 /* AwaitExpression */:
+        case 223 /* AwaitExpression */:
           return checkAwaitExpression(node);
-        case 223 /* PrefixUnaryExpression */:
+        case 224 /* PrefixUnaryExpression */:
           return checkPrefixUnaryExpression(node);
-        case 224 /* PostfixUnaryExpression */:
+        case 225 /* PostfixUnaryExpression */:
           return checkPostfixUnaryExpression(node);
-        case 225 /* BinaryExpression */:
+        case 226 /* BinaryExpression */:
           return checkBinaryExpression(node, checkMode);
-        case 226 /* ConditionalExpression */:
+        case 227 /* ConditionalExpression */:
           return checkConditionalExpression(node, checkMode);
-        case 229 /* SpreadElement */:
+        case 230 /* SpreadElement */:
           return checkSpreadExpression(node, checkMode);
-        case 231 /* OmittedExpression */:
+        case 232 /* OmittedExpression */:
           return undefinedWideningType;
-        case 228 /* YieldExpression */:
+        case 229 /* YieldExpression */:
           return checkYieldExpression(node);
-        case 236 /* SyntheticExpression */:
+        case 237 /* SyntheticExpression */:
           return checkSyntheticExpression(node);
-        case 293 /* JsxExpression */:
+        case 294 /* JsxExpression */:
           return checkJsxExpression(node, checkMode);
-        case 283 /* JsxElement */:
+        case 284 /* JsxElement */:
           return checkJsxElement(node, checkMode);
-        case 284 /* JsxSelfClosingElement */:
+        case 285 /* JsxSelfClosingElement */:
           return checkJsxSelfClosingElement(node, checkMode);
-        case 287 /* JsxFragment */:
+        case 288 /* JsxFragment */:
           return checkJsxFragment(node);
-        case 291 /* JsxAttributes */:
+        case 292 /* JsxAttributes */:
           return checkJsxAttributes(node, checkMode);
-        case 285 /* JsxOpeningElement */:
+        case 286 /* JsxOpeningElement */:
           Debug.fail("Shouldn't ever directly check a JsxOpeningElement");
       }
       return errorType;
@@ -176144,7 +160088,7 @@ ${lanes.join("\n")}
       const typeParameter = getDeclaredTypeOfTypeParameter(getSymbolOfDeclaration(node));
       getBaseConstraintOfType(typeParameter);
       if (!hasNonCircularTypeParameterDefault(typeParameter)) {
-        error(node.default, Diagnostics.Type_parameter_0_has_a_circular_default, typeToString(typeParameter));
+        error2(node.default, Diagnostics.Type_parameter_0_has_a_circular_default, typeToString(typeParameter));
       }
       const constraintType = getConstraintOfTypeParameter(typeParameter);
       const defaultType = getDefaultFromTypeParameter(typeParameter);
@@ -176158,15 +160102,15 @@ ${lanes.join("\n")}
       var _a, _b;
       if (isInterfaceDeclaration(node.parent) || isClassLike(node.parent) || isTypeAliasDeclaration(node.parent)) {
         const typeParameter = getDeclaredTypeOfTypeParameter(getSymbolOfDeclaration(node));
-        const modifiers = getTypeParameterModifiers(typeParameter) & (32768 /* In */ | 65536 /* Out */);
+        const modifiers = getTypeParameterModifiers(typeParameter) & (8192 /* In */ | 16384 /* Out */);
         if (modifiers) {
           const symbol = getSymbolOfDeclaration(node.parent);
           if (isTypeAliasDeclaration(node.parent) && !(getObjectFlags(getDeclaredTypeOfSymbol(symbol)) & (16 /* Anonymous */ | 32 /* Mapped */))) {
-            error(node, Diagnostics.Variance_annotations_are_only_supported_in_type_aliases_for_object_function_constructor_and_mapped_types);
-          } else if (modifiers === 32768 /* In */ || modifiers === 65536 /* Out */) {
+            error2(node, Diagnostics.Variance_annotations_are_only_supported_in_type_aliases_for_object_function_constructor_and_mapped_types);
+          } else if (modifiers === 8192 /* In */ || modifiers === 16384 /* Out */) {
             (_a = tracing) == null ? void 0 : _a.push(tracing.Phase.CheckTypes, "checkTypeParameterDeferred", { parent: getTypeId(getDeclaredTypeOfSymbol(symbol)), id: getTypeId(typeParameter) });
-            const source = createMarkerType(symbol, typeParameter, modifiers === 65536 /* Out */ ? markerSubTypeForCheck : markerSuperTypeForCheck);
-            const target = createMarkerType(symbol, typeParameter, modifiers === 65536 /* Out */ ? markerSuperTypeForCheck : markerSubTypeForCheck);
+            const source = createMarkerType(symbol, typeParameter, modifiers === 16384 /* Out */ ? markerSubTypeForCheck : markerSuperTypeForCheck);
+            const target = createMarkerType(symbol, typeParameter, modifiers === 16384 /* Out */ ? markerSuperTypeForCheck : markerSubTypeForCheck);
             const saveVarianceTypeParameter = typeParameter;
             varianceTypeParameter = typeParameter;
             checkTypeAssignableTo(source, target, node, Diagnostics.Type_0_is_not_assignable_to_type_1_as_implied_by_variance_annotation);
@@ -176180,39 +160124,39 @@ ${lanes.join("\n")}
       checkGrammarModifiers(node);
       checkVariableLikeDeclaration(node);
       const func = getContainingFunction(node);
-      if (hasSyntacticModifier(node, 16476 /* ParameterPropertyModifier */)) {
-        if (!(func.kind === 175 /* Constructor */ && nodeIsPresent(func.body))) {
-          error(node, Diagnostics.A_parameter_property_is_only_allowed_in_a_constructor_implementation);
+      if (hasSyntacticModifier(node, 31 /* ParameterPropertyModifier */)) {
+        if (!(func.kind === 176 /* Constructor */ && nodeIsPresent(func.body))) {
+          error2(node, Diagnostics.A_parameter_property_is_only_allowed_in_a_constructor_implementation);
         }
-        if (func.kind === 175 /* Constructor */ && isIdentifier(node.name) && node.name.escapedText === "constructor") {
-          error(node.name, Diagnostics.constructor_cannot_be_used_as_a_parameter_property_name);
+        if (func.kind === 176 /* Constructor */ && isIdentifier(node.name) && node.name.escapedText === "constructor") {
+          error2(node.name, Diagnostics.constructor_cannot_be_used_as_a_parameter_property_name);
         }
       }
       if (!node.initializer && isOptionalDeclaration(node) && isBindingPattern(node.name) && func.body) {
-        error(node, Diagnostics.A_binding_pattern_parameter_cannot_be_optional_in_an_implementation_signature);
+        error2(node, Diagnostics.A_binding_pattern_parameter_cannot_be_optional_in_an_implementation_signature);
       }
       if (node.name && isIdentifier(node.name) && (node.name.escapedText === "this" || node.name.escapedText === "new")) {
         if (func.parameters.indexOf(node) !== 0) {
-          error(node, Diagnostics.A_0_parameter_must_be_the_first_parameter, node.name.escapedText);
+          error2(node, Diagnostics.A_0_parameter_must_be_the_first_parameter, node.name.escapedText);
         }
-        if (func.kind === 175 /* Constructor */ || func.kind === 179 /* ConstructSignature */ || func.kind === 184 /* ConstructorType */) {
-          error(node, Diagnostics.A_constructor_cannot_have_a_this_parameter);
+        if (func.kind === 176 /* Constructor */ || func.kind === 180 /* ConstructSignature */ || func.kind === 185 /* ConstructorType */) {
+          error2(node, Diagnostics.A_constructor_cannot_have_a_this_parameter);
         }
-        if (func.kind === 218 /* ArrowFunction */) {
-          error(node, Diagnostics.An_arrow_function_cannot_have_a_this_parameter);
+        if (func.kind === 219 /* ArrowFunction */) {
+          error2(node, Diagnostics.An_arrow_function_cannot_have_a_this_parameter);
         }
-        if (func.kind === 176 /* GetAccessor */ || func.kind === 177 /* SetAccessor */) {
-          error(node, Diagnostics.get_and_set_accessors_cannot_declare_this_parameters);
+        if (func.kind === 177 /* GetAccessor */ || func.kind === 178 /* SetAccessor */) {
+          error2(node, Diagnostics.get_and_set_accessors_cannot_declare_this_parameters);
         }
       }
       if (node.dotDotDotToken && !isBindingPattern(node.name) && !isTypeAssignableTo(getReducedType(getTypeOfSymbol(node.symbol)), anyReadonlyArrayType)) {
-        error(node, Diagnostics.A_rest_parameter_must_be_of_an_array_type);
+        error2(node, Diagnostics.A_rest_parameter_must_be_of_an_array_type);
       }
     }
     function checkTypePredicate(node) {
       const parent2 = getTypePredicateParent(node);
       if (!parent2) {
-        error(node, Diagnostics.A_type_predicate_is_only_allowed_in_return_type_position_for_functions_and_methods);
+        error2(node, Diagnostics.A_type_predicate_is_only_allowed_in_return_type_position_for_functions_and_methods);
         return;
       }
       const signature = getSignatureFromDeclaration(parent2);
@@ -176227,7 +160171,7 @@ ${lanes.join("\n")}
       } else {
         if (typePredicate.parameterIndex >= 0) {
           if (signatureHasRestParameter(signature) && typePredicate.parameterIndex === signature.parameters.length - 1) {
-            error(parameterName, Diagnostics.A_type_predicate_cannot_reference_a_rest_parameter);
+            error2(parameterName, Diagnostics.A_type_predicate_cannot_reference_a_rest_parameter);
           } else {
             if (typePredicate.type) {
               const leadingError = () => chainDiagnosticMessages(
@@ -176254,20 +160198,20 @@ ${lanes.join("\n")}
             }
           }
           if (!hasReportedError) {
-            error(node.parameterName, Diagnostics.Cannot_find_parameter_0, typePredicate.parameterName);
+            error2(node.parameterName, Diagnostics.Cannot_find_parameter_0, typePredicate.parameterName);
           }
         }
       }
     }
     function getTypePredicateParent(node) {
       switch (node.parent.kind) {
-        case 218 /* ArrowFunction */:
-        case 178 /* CallSignature */:
-        case 261 /* FunctionDeclaration */:
-        case 217 /* FunctionExpression */:
-        case 183 /* FunctionType */:
-        case 173 /* MethodDeclaration */:
-        case 172 /* MethodSignature */:
+        case 219 /* ArrowFunction */:
+        case 179 /* CallSignature */:
+        case 262 /* FunctionDeclaration */:
+        case 218 /* FunctionExpression */:
+        case 184 /* FunctionType */:
+        case 174 /* MethodDeclaration */:
+        case 173 /* MethodSignature */:
           const parent2 = node.parent;
           if (node === parent2.type) {
             return parent2;
@@ -176281,13 +160225,9 @@ ${lanes.join("\n")}
         }
         const name = element.name;
         if (name.kind === 80 /* Identifier */ && name.escapedText === predicateVariableName) {
-          error(
-            predicateVariableNode,
-            Diagnostics.A_type_predicate_cannot_reference_element_0_in_a_binding_pattern,
-            predicateVariableName
-          );
+          error2(predicateVariableNode, Diagnostics.A_type_predicate_cannot_reference_element_0_in_a_binding_pattern, predicateVariableName);
           return true;
-        } else if (name.kind === 206 /* ArrayBindingPattern */ || name.kind === 205 /* ObjectBindingPattern */) {
+        } else if (name.kind === 207 /* ArrayBindingPattern */ || name.kind === 206 /* ObjectBindingPattern */) {
           if (checkIfTypePredicateVariableIsDeclaredInBindingPattern(
             name,
             predicateVariableNode,
@@ -176299,9 +160239,9 @@ ${lanes.join("\n")}
       }
     }
     function checkSignatureDeclaration(node) {
-      if (node.kind === 180 /* IndexSignature */) {
+      if (node.kind === 181 /* IndexSignature */) {
         checkGrammarIndexSignature(node);
-      } else if (node.kind === 183 /* FunctionType */ || node.kind === 261 /* FunctionDeclaration */ || node.kind === 184 /* ConstructorType */ || node.kind === 178 /* CallSignature */ || node.kind === 175 /* Constructor */ || node.kind === 179 /* ConstructSignature */) {
+      } else if (node.kind === 184 /* FunctionType */ || node.kind === 262 /* FunctionDeclaration */ || node.kind === 185 /* ConstructorType */ || node.kind === 179 /* CallSignature */ || node.kind === 176 /* Constructor */ || node.kind === 180 /* ConstructSignature */) {
         checkGrammarFunctionLikeDeclaration(node);
       }
       const functionFlags = getFunctionFlags(node);
@@ -176325,45 +160265,59 @@ ${lanes.join("\n")}
       addLazyDiagnostic(checkSignatureDeclarationDiagnostics);
       function checkSignatureDeclarationDiagnostics() {
         checkCollisionWithArgumentsInGeneratedCode(node);
-        const returnTypeNode = getEffectiveReturnTypeNode(node);
+        let returnTypeNode = getEffectiveReturnTypeNode(node);
+        let returnTypeErrorLocation = returnTypeNode;
+        if (isInJSFile(node)) {
+          const typeTag = getJSDocTypeTag(node);
+          if (typeTag && typeTag.typeExpression && isTypeReferenceNode(typeTag.typeExpression.type)) {
+            const signature = getSingleCallSignature(getTypeFromTypeNode(typeTag.typeExpression));
+            if (signature && signature.declaration) {
+              returnTypeNode = getEffectiveReturnTypeNode(signature.declaration);
+              returnTypeErrorLocation = typeTag.typeExpression.type;
+            }
+          }
+        }
         if (noImplicitAny && !returnTypeNode) {
           switch (node.kind) {
-            case 179 /* ConstructSignature */:
-              error(node, Diagnostics.Construct_signature_which_lacks_return_type_annotation_implicitly_has_an_any_return_type);
+            case 180 /* ConstructSignature */:
+              error2(node, Diagnostics.Construct_signature_which_lacks_return_type_annotation_implicitly_has_an_any_return_type);
               break;
-            case 178 /* CallSignature */:
-              error(node, Diagnostics.Call_signature_which_lacks_return_type_annotation_implicitly_has_an_any_return_type);
+            case 179 /* CallSignature */:
+              error2(node, Diagnostics.Call_signature_which_lacks_return_type_annotation_implicitly_has_an_any_return_type);
               break;
           }
         }
-        if (returnTypeNode) {
+        if (returnTypeNode && returnTypeErrorLocation) {
           const functionFlags2 = getFunctionFlags(node);
           if ((functionFlags2 & (4 /* Invalid */ | 1 /* Generator */)) === 1 /* Generator */) {
             const returnType = getTypeFromTypeNode(returnTypeNode);
             if (returnType === voidType) {
-              error(returnTypeNode, Diagnostics.A_generator_cannot_have_a_void_type_annotation);
+              error2(returnTypeErrorLocation, Diagnostics.A_generator_cannot_have_a_void_type_annotation);
             } else {
-              const generatorYieldType = getIterationTypeOfGeneratorFunctionReturnType(0 /* Yield */, returnType, (functionFlags2 & 2 /* Async */) !== 0) || anyType;
-              const generatorReturnType = getIterationTypeOfGeneratorFunctionReturnType(1 /* Return */, returnType, (functionFlags2 & 2 /* Async */) !== 0) || generatorYieldType;
-              const generatorNextType = getIterationTypeOfGeneratorFunctionReturnType(2 /* Next */, returnType, (functionFlags2 & 2 /* Async */) !== 0) || unknownType;
-              const generatorInstantiation = createGeneratorReturnType(generatorYieldType, generatorReturnType, generatorNextType, !!(functionFlags2 & 2 /* Async */));
-              checkTypeAssignableTo(generatorInstantiation, returnType, returnTypeNode);
+              checkGeneratorInstantiationAssignabilityToReturnType(returnType, functionFlags2, returnTypeErrorLocation);
             }
           } else if ((functionFlags2 & 3 /* AsyncGenerator */) === 2 /* Async */) {
-            checkAsyncFunctionReturnType(node, returnTypeNode);
+            checkAsyncFunctionReturnType(node, returnTypeNode, returnTypeErrorLocation);
           }
         }
-        if (node.kind !== 180 /* IndexSignature */ && node.kind !== 323 /* JSDocFunctionType */) {
+        if (node.kind !== 181 /* IndexSignature */ && node.kind !== 324 /* JSDocFunctionType */) {
           registerForUnusedIdentifiersCheck(node);
         }
       }
     }
+    function checkGeneratorInstantiationAssignabilityToReturnType(returnType, functionFlags, errorNode) {
+      const generatorYieldType = getIterationTypeOfGeneratorFunctionReturnType(0 /* Yield */, returnType, (functionFlags & 2 /* Async */) !== 0) || anyType;
+      const generatorReturnType = getIterationTypeOfGeneratorFunctionReturnType(1 /* Return */, returnType, (functionFlags & 2 /* Async */) !== 0) || generatorYieldType;
+      const generatorNextType = getIterationTypeOfGeneratorFunctionReturnType(2 /* Next */, returnType, (functionFlags & 2 /* Async */) !== 0) || unknownType;
+      const generatorInstantiation = createGeneratorReturnType(generatorYieldType, generatorReturnType, generatorNextType, !!(functionFlags & 2 /* Async */));
+      return checkTypeAssignableTo(generatorInstantiation, returnType, errorNode);
+    }
     function checkClassForDuplicateDeclarations(node) {
       const instanceNames = /* @__PURE__ */ new Map();
       const staticNames = /* @__PURE__ */ new Map();
       const privateIdentifiers = /* @__PURE__ */ new Map();
       for (const member of node.members) {
-        if (member.kind === 175 /* Constructor */) {
+        if (member.kind === 176 /* Constructor */) {
           for (const param of member.parameters) {
             if (isParameterPropertyDeclaration(param, member) && !isBindingPattern(param.name)) {
               addName(instanceNames, param.name, param.name.escapedText, 3 /* GetOrSetAccessor */);
@@ -176378,19 +160332,19 @@ ${lanes.join("\n")}
           const isPrivate = isPrivateIdentifier(name);
           const privateStaticFlags = isPrivate && isStaticMember ? 16 /* PrivateStatic */ : 0;
           const names = isPrivate ? privateIdentifiers : isStaticMember ? staticNames : instanceNames;
-          const memberName = name && getPropertyNameForPropertyNameNode(name);
+          const memberName = name && getEffectivePropertyNameForPropertyNameNode(name);
           if (memberName) {
             switch (member.kind) {
-              case 176 /* GetAccessor */:
+              case 177 /* GetAccessor */:
                 addName(names, name, memberName, 1 /* GetAccessor */ | privateStaticFlags);
                 break;
-              case 177 /* SetAccessor */:
+              case 178 /* SetAccessor */:
                 addName(names, name, memberName, 2 /* SetAccessor */ | privateStaticFlags);
                 break;
-              case 171 /* PropertyDeclaration */:
+              case 172 /* PropertyDeclaration */:
                 addName(names, name, memberName, 3 /* GetOrSetAccessor */ | privateStaticFlags);
                 break;
-              case 173 /* MethodDeclaration */:
+              case 174 /* MethodDeclaration */:
                 addName(names, name, memberName, 8 /* Method */ | privateStaticFlags);
                 break;
             }
@@ -176401,16 +160355,16 @@ ${lanes.join("\n")}
         const prev = names.get(name);
         if (prev) {
           if ((prev & 16 /* PrivateStatic */) !== (meaning & 16 /* PrivateStatic */)) {
-            error(location, Diagnostics.Duplicate_identifier_0_Static_and_instance_elements_cannot_share_the_same_private_name, getTextOfNode(location));
+            error2(location, Diagnostics.Duplicate_identifier_0_Static_and_instance_elements_cannot_share_the_same_private_name, getTextOfNode(location));
           } else {
             const prevIsMethod = !!(prev & 8 /* Method */);
             const isMethod = !!(meaning & 8 /* Method */);
             if (prevIsMethod || isMethod) {
               if (prevIsMethod !== isMethod) {
-                error(location, Diagnostics.Duplicate_identifier_0, getTextOfNode(location));
+                error2(location, Diagnostics.Duplicate_identifier_0, getTextOfNode(location));
               }
             } else if (prev & meaning & ~16 /* PrivateStatic */) {
-              error(location, Diagnostics.Duplicate_identifier_0, getTextOfNode(location));
+              error2(location, Diagnostics.Duplicate_identifier_0, getTextOfNode(location));
             } else {
               names.set(name, prev | meaning);
             }
@@ -176425,16 +160379,19 @@ ${lanes.join("\n")}
         const memberNameNode = member.name;
         const isStaticMember = isStatic(member);
         if (isStaticMember && memberNameNode) {
-          const memberName = getPropertyNameForPropertyNameNode(memberNameNode);
+          const memberName = getEffectivePropertyNameForPropertyNameNode(memberNameNode);
           switch (memberName) {
             case "name":
             case "length":
             case "caller":
             case "arguments":
+              if (useDefineForClassFields) {
+                break;
+              }
             case "prototype":
               const message = Diagnostics.Static_property_0_conflicts_with_built_in_property_Function_0_of_constructor_function_1;
               const className = getNameOfSymbolAsWritten(getSymbolOfDeclaration(node));
-              error(memberNameNode, message, memberName, className);
+              error2(memberNameNode, message, memberName, className);
               break;
           }
         }
@@ -176443,7 +160400,7 @@ ${lanes.join("\n")}
     function checkObjectTypeForDuplicateDeclarations(node) {
       const names = /* @__PURE__ */ new Map();
       for (const member of node.members) {
-        if (member.kind === 170 /* PropertySignature */) {
+        if (member.kind === 171 /* PropertySignature */) {
           let memberName;
           const name = member.name;
           switch (name.kind) {
@@ -176458,8 +160415,8 @@ ${lanes.join("\n")}
               continue;
           }
           if (names.get(memberName)) {
-            error(getNameOfDeclaration(member.symbol.valueDeclaration), Diagnostics.Duplicate_identifier_0, memberName);
-            error(member.name, Diagnostics.Duplicate_identifier_0, memberName);
+            error2(getNameOfDeclaration(member.symbol.valueDeclaration), Diagnostics.Duplicate_identifier_0, memberName);
+            error2(member.name, Diagnostics.Duplicate_identifier_0, memberName);
           } else {
             names.set(memberName, true);
           }
@@ -176467,7 +160424,7 @@ ${lanes.join("\n")}
       }
     }
     function checkTypeForDuplicateIndexSignatures(node) {
-      if (node.kind === 263 /* InterfaceDeclaration */) {
+      if (node.kind === 264 /* InterfaceDeclaration */) {
         const nodeSymbol = getSymbolOfDeclaration(node);
         if (nodeSymbol.declarations && nodeSymbol.declarations.length > 0 && nodeSymbol.declarations[0] !== node) {
           return;
@@ -176491,7 +160448,7 @@ ${lanes.join("\n")}
         indexSignatureMap.forEach((entry) => {
           if (entry.declarations.length > 1) {
             for (const declaration of entry.declarations) {
-              error(declaration, Diagnostics.Duplicate_index_signature_for_type_0, typeToString(entry.type));
+              error2(declaration, Diagnostics.Duplicate_index_signature_for_type_0, typeToString(entry.type));
             }
           }
         });
@@ -176502,13 +160459,13 @@ ${lanes.join("\n")}
         checkGrammarComputedPropertyName(node.name);
       checkVariableLikeDeclaration(node);
       setNodeLinksForPrivateIdentifierScope(node);
-      if (hasSyntacticModifier(node, 256 /* Abstract */) && node.kind === 171 /* PropertyDeclaration */ && node.initializer) {
-        error(node, Diagnostics.Property_0_cannot_have_an_initializer_because_it_is_marked_abstract, declarationNameToString(node.name));
+      if (hasSyntacticModifier(node, 64 /* Abstract */) && node.kind === 172 /* PropertyDeclaration */ && node.initializer) {
+        error2(node, Diagnostics.Property_0_cannot_have_an_initializer_because_it_is_marked_abstract, declarationNameToString(node.name));
       }
     }
     function checkPropertySignature(node) {
       if (isPrivateIdentifier(node.name)) {
-        error(node, Diagnostics.Private_identifiers_are_not_allowed_outside_class_bodies);
+        error2(node, Diagnostics.Private_identifiers_are_not_allowed_outside_class_bodies);
       }
       return checkPropertyDeclaration(node);
     }
@@ -176516,21 +160473,21 @@ ${lanes.join("\n")}
       if (!checkGrammarMethod(node))
         checkGrammarComputedPropertyName(node.name);
       if (isMethodDeclaration(node) && node.asteriskToken && isIdentifier(node.name) && idText(node.name) === "constructor") {
-        error(node.name, Diagnostics.Class_constructor_may_not_be_a_generator);
+        error2(node.name, Diagnostics.Class_constructor_may_not_be_a_generator);
       }
       checkFunctionOrMethodDeclaration(node);
-      if (hasSyntacticModifier(node, 256 /* Abstract */) && node.kind === 173 /* MethodDeclaration */ && node.body) {
-        error(node, Diagnostics.Method_0_cannot_have_an_implementation_because_it_is_marked_abstract, declarationNameToString(node.name));
+      if (hasSyntacticModifier(node, 64 /* Abstract */) && node.kind === 174 /* MethodDeclaration */ && node.body) {
+        error2(node, Diagnostics.Method_0_cannot_have_an_implementation_because_it_is_marked_abstract, declarationNameToString(node.name));
       }
       if (isPrivateIdentifier(node.name) && !getContainingClass(node)) {
-        error(node, Diagnostics.Private_identifiers_are_not_allowed_outside_class_bodies);
+        error2(node, Diagnostics.Private_identifiers_are_not_allowed_outside_class_bodies);
       }
       setNodeLinksForPrivateIdentifierScope(node);
     }
     function setNodeLinksForPrivateIdentifierScope(node) {
       if (isPrivateIdentifier(node.name) && languageVersion < 99 /* ESNext */) {
         for (let lexicalScope = getEnclosingBlockScopeContainer(node); !!lexicalScope; lexicalScope = getEnclosingBlockScopeContainer(lexicalScope)) {
-          getNodeLinks(lexicalScope).flags |= 4194304 /* ContainsClassWithPrivateIdentifiers */;
+          getNodeLinks(lexicalScope).flags |= 1048576 /* ContainsClassWithPrivateIdentifiers */;
         }
         if (isClassExpression(node.parent)) {
           const enclosingIterationStatement = getEnclosingIterationStatement(node.parent);
@@ -176564,7 +160521,7 @@ ${lanes.join("\n")}
         if (isPrivateIdentifierClassElementDeclaration(n)) {
           return true;
         }
-        return n.kind === 171 /* PropertyDeclaration */ && !isStatic(n) && !!n.initializer;
+        return n.kind === 172 /* PropertyDeclaration */ && !isStatic(n) && !!n.initializer;
       }
       function checkConstructorDeclarationDiagnostics() {
         const containingClassDecl = node.parent;
@@ -176574,12 +160531,12 @@ ${lanes.join("\n")}
           const superCall = findFirstSuperCall(node.body);
           if (superCall) {
             if (classExtendsNull) {
-              error(superCall, Diagnostics.A_constructor_cannot_contain_a_super_call_when_its_class_extends_null);
+              error2(superCall, Diagnostics.A_constructor_cannot_contain_a_super_call_when_its_class_extends_null);
             }
-            const superCallShouldBeRootLevel = (getEmitScriptTarget(compilerOptions) !== 99 /* ESNext */ || !useDefineForClassFields) && (some(node.parent.members, isInstancePropertyWithInitializerOrPrivateIdentifierProperty) || some(node.parameters, (p) => hasSyntacticModifier(p, 16476 /* ParameterPropertyModifier */)));
+            const superCallShouldBeRootLevel = !emitStandardClassFields && (some(node.parent.members, isInstancePropertyWithInitializerOrPrivateIdentifierProperty) || some(node.parameters, (p) => hasSyntacticModifier(p, 31 /* ParameterPropertyModifier */)));
             if (superCallShouldBeRootLevel) {
               if (!superCallIsRootLevelInConstructor(superCall, node.body)) {
-                error(superCall, Diagnostics.A_super_call_must_be_a_root_level_statement_within_a_constructor_of_a_derived_class_that_contains_initialized_properties_parameter_properties_or_private_identifiers);
+                error2(superCall, Diagnostics.A_super_call_must_be_a_root_level_statement_within_a_constructor_of_a_derived_class_that_contains_initialized_properties_parameter_properties_or_private_identifiers);
               } else {
                 let superCallStatement;
                 for (const statement of node.body.statements) {
@@ -176592,12 +160549,12 @@ ${lanes.join("\n")}
                   }
                 }
                 if (superCallStatement === void 0) {
-                  error(node, Diagnostics.A_super_call_must_be_the_first_statement_in_the_constructor_to_refer_to_super_or_this_when_a_derived_class_contains_initialized_properties_parameter_properties_or_private_identifiers);
+                  error2(node, Diagnostics.A_super_call_must_be_the_first_statement_in_the_constructor_to_refer_to_super_or_this_when_a_derived_class_contains_initialized_properties_parameter_properties_or_private_identifiers);
                 }
               }
             }
           } else if (!classExtendsNull) {
-            error(node, Diagnostics.Constructors_for_derived_classes_must_contain_a_super_call);
+            error2(node, Diagnostics.Constructors_for_derived_classes_must_contain_a_super_call);
           }
         }
       }
@@ -176617,7 +160574,7 @@ ${lanes.join("\n")}
     }
     function checkAccessorDeclaration(node) {
       if (isIdentifier(node.name) && idText(node.name) === "constructor" && isClassLike(node.parent)) {
-        error(node.name, Diagnostics.Class_constructor_may_not_be_an_accessor);
+        error2(node.name, Diagnostics.Class_constructor_may_not_be_an_accessor);
       }
       addLazyDiagnostic(checkAccessorDeclarationDiagnostics);
       checkSourceElement(node.body);
@@ -176627,36 +160584,36 @@ ${lanes.join("\n")}
           checkGrammarComputedPropertyName(node.name);
         checkDecorators(node);
         checkSignatureDeclaration(node);
-        if (node.kind === 176 /* GetAccessor */) {
-          if (!(node.flags & 16777216 /* Ambient */) && nodeIsPresent(node.body) && node.flags & 256 /* HasImplicitReturn */) {
-            if (!(node.flags & 512 /* HasExplicitReturn */)) {
-              error(node.name, Diagnostics.A_get_accessor_must_return_a_value);
+        if (node.kind === 177 /* GetAccessor */) {
+          if (!(node.flags & 33554432 /* Ambient */) && nodeIsPresent(node.body) && node.flags & 512 /* HasImplicitReturn */) {
+            if (!(node.flags & 1024 /* HasExplicitReturn */)) {
+              error2(node.name, Diagnostics.A_get_accessor_must_return_a_value);
             }
           }
         }
-        if (node.name.kind === 166 /* ComputedPropertyName */) {
+        if (node.name.kind === 167 /* ComputedPropertyName */) {
           checkComputedPropertyName(node.name);
         }
         if (hasBindableName(node)) {
           const symbol = getSymbolOfDeclaration(node);
-          const getter = getDeclarationOfKind(symbol, 176 /* GetAccessor */);
-          const setter = getDeclarationOfKind(symbol, 177 /* SetAccessor */);
+          const getter = getDeclarationOfKind(symbol, 177 /* GetAccessor */);
+          const setter = getDeclarationOfKind(symbol, 178 /* SetAccessor */);
           if (getter && setter && !(getNodeCheckFlags(getter) & 1 /* TypeChecked */)) {
             getNodeLinks(getter).flags |= 1 /* TypeChecked */;
             const getterFlags = getEffectiveModifierFlags(getter);
             const setterFlags = getEffectiveModifierFlags(setter);
-            if ((getterFlags & 256 /* Abstract */) !== (setterFlags & 256 /* Abstract */)) {
-              error(getter.name, Diagnostics.Accessors_must_both_be_abstract_or_non_abstract);
-              error(setter.name, Diagnostics.Accessors_must_both_be_abstract_or_non_abstract);
+            if ((getterFlags & 64 /* Abstract */) !== (setterFlags & 64 /* Abstract */)) {
+              error2(getter.name, Diagnostics.Accessors_must_both_be_abstract_or_non_abstract);
+              error2(setter.name, Diagnostics.Accessors_must_both_be_abstract_or_non_abstract);
             }
-            if (getterFlags & 16 /* Protected */ && !(setterFlags & (16 /* Protected */ | 8 /* Private */)) || getterFlags & 8 /* Private */ && !(setterFlags & 8 /* Private */)) {
-              error(getter.name, Diagnostics.A_get_accessor_must_be_at_least_as_accessible_as_the_setter);
-              error(setter.name, Diagnostics.A_get_accessor_must_be_at_least_as_accessible_as_the_setter);
+            if (getterFlags & 4 /* Protected */ && !(setterFlags & (4 /* Protected */ | 2 /* Private */)) || getterFlags & 2 /* Private */ && !(setterFlags & 2 /* Private */)) {
+              error2(getter.name, Diagnostics.A_get_accessor_must_be_at_least_as_accessible_as_the_setter);
+              error2(setter.name, Diagnostics.A_get_accessor_must_be_at_least_as_accessible_as_the_setter);
             }
           }
         }
         const returnType = getTypeOfAccessors(getSymbolOfDeclaration(node));
-        if (node.kind === 176 /* GetAccessor */) {
+        if (node.kind === 177 /* GetAccessor */) {
           checkAllCodePathsInNonVoidFunctionReturnOrThrow(node, returnType);
         }
       }
@@ -176671,12 +160628,7 @@ ${lanes.join("\n")}
       return getEffectiveTypeArguments2(node, typeParameters)[index];
     }
     function getEffectiveTypeArguments2(node, typeParameters) {
-      return fillMissingTypeArguments(
-        map(node.typeArguments, getTypeFromTypeNode),
-        typeParameters,
-        getMinTypeArgumentCount(typeParameters),
-        isInJSFile(node)
-      );
+      return fillMissingTypeArguments(map(node.typeArguments, getTypeFromTypeNode), typeParameters, getMinTypeArgumentCount(typeParameters), isInJSFile(node));
     }
     function checkTypeArgumentConstraints(node, typeParameters) {
       let typeArguments;
@@ -176717,7 +160669,7 @@ ${lanes.join("\n")}
     }
     function checkTypeReferenceNode(node) {
       checkGrammarTypeArguments(node, node.typeArguments);
-      if (node.kind === 182 /* TypeReference */ && !isInJSFile(node) && !isInJSDoc(node) && node.typeArguments && node.typeName.end !== node.typeArguments.pos) {
+      if (node.kind === 183 /* TypeReference */ && !isInJSFile(node) && !isInJSDoc(node) && node.typeArguments && node.typeName.end !== node.typeArguments.pos) {
         const sourceFile = getSourceFileOfNode(node);
         if (scanTokenAtPosition(sourceFile, node.typeName.end) === 25 /* DotToken */) {
           grammarErrorAtPos(node, skipTrivia(sourceFile.text, node.typeName.end), 1, Diagnostics.JSDoc_types_can_only_be_used_inside_documentation_comments);
@@ -176739,7 +160691,7 @@ ${lanes.join("\n")}
         }
         const symbol = getNodeLinks(node).resolvedSymbol;
         if (symbol) {
-          if (some(symbol.declarations, (d) => isTypeDeclaration(d) && !!(d.flags & 268435456 /* Deprecated */))) {
+          if (some(symbol.declarations, (d) => isTypeDeclaration(d) && !!(d.flags & 536870912 /* Deprecated */))) {
             addDeprecatedSuggestion(
               getDeprecatedSuggestionNode(node),
               symbol.declarations,
@@ -176779,17 +160731,12 @@ ${lanes.join("\n")}
       const elementTypes = node.elements;
       let seenOptionalElement = false;
       let seenRestElement = false;
-      const hasNamedElement = some(elementTypes, isNamedTupleMember);
       for (const e of elementTypes) {
-        if (e.kind !== 201 /* NamedTupleMember */ && hasNamedElement) {
-          grammarErrorOnNode(e, Diagnostics.Tuple_members_must_all_have_names_or_all_not_have_names);
-          break;
-        }
         const flags = getTupleElementFlags(e);
         if (flags & 8 /* Variadic */) {
           const type = getTypeFromTypeNode(e.type);
           if (!isArrayLikeType(type)) {
-            error(e, Diagnostics.A_rest_element_type_must_be_an_array_type);
+            error2(e, Diagnostics.A_rest_element_type_must_be_an_array_type);
             break;
           }
           if (isArrayType(type) || isTupleType(type) && type.target.combinedFlags & 4 /* Rest */) {
@@ -176826,8 +160773,8 @@ ${lanes.join("\n")}
       const objectType = type.objectType;
       const indexType = type.indexType;
       if (isTypeAssignableTo(indexType, getIndexType(objectType, 0 /* None */))) {
-        if (accessNode.kind === 211 /* ElementAccessExpression */ && isAssignmentTarget(accessNode) && getObjectFlags(objectType) & 32 /* Mapped */ && getMappedTypeModifiers(objectType) & 1 /* IncludeReadonly */) {
-          error(accessNode, Diagnostics.Index_signature_in_type_0_only_permits_reading, typeToString(objectType));
+        if (accessNode.kind === 212 /* ElementAccessExpression */ && isAssignmentTarget(accessNode) && getObjectFlags(objectType) & 32 /* Mapped */ && getMappedTypeModifiers(objectType) & 1 /* IncludeReadonly */) {
+          error2(accessNode, Diagnostics.Index_signature_in_type_0_only_permits_reading, typeToString(objectType));
         }
         return type;
       }
@@ -176839,13 +160786,13 @@ ${lanes.join("\n")}
         const propertyName = getPropertyNameFromIndex(indexType, accessNode);
         if (propertyName) {
           const propertySymbol = forEachType(apparentObjectType, (t) => getPropertyOfType(t, propertyName));
-          if (propertySymbol && getDeclarationModifierFlagsFromSymbol(propertySymbol) & 24 /* NonPublicAccessibilityModifier */) {
-            error(accessNode, Diagnostics.Private_or_protected_member_0_cannot_be_accessed_on_a_type_parameter, unescapeLeadingUnderscores(propertyName));
+          if (propertySymbol && getDeclarationModifierFlagsFromSymbol(propertySymbol) & 6 /* NonPublicAccessibilityModifier */) {
+            error2(accessNode, Diagnostics.Private_or_protected_member_0_cannot_be_accessed_on_a_type_parameter, unescapeLeadingUnderscores(propertyName));
             return errorType;
           }
         }
       }
-      error(accessNode, Diagnostics.Type_0_cannot_be_used_to_index_type_1, typeToString(indexType), typeToString(objectType));
+      error2(accessNode, Diagnostics.Type_0_cannot_be_used_to_index_type_1, typeToString(indexType), typeToString(objectType));
       return errorType;
     }
     function checkIndexedAccessType(node) {
@@ -176887,7 +160834,7 @@ ${lanes.join("\n")}
       forEachChild(node, checkSourceElement);
     }
     function checkInferType(node) {
-      if (!findAncestor(node, (n) => n.parent && n.parent.kind === 193 /* ConditionalType */ && n.parent.extendsType === n)) {
+      if (!findAncestor(node, (n) => n.parent && n.parent.kind === 194 /* ConditionalType */ && n.parent.extendsType === n)) {
         grammarErrorOnNode(node, Diagnostics.infer_declarations_are_only_permitted_in_the_extends_clause_of_a_conditional_type);
       }
       checkSourceElement(node.typeParameter);
@@ -176897,11 +160844,11 @@ ${lanes.join("\n")}
         if (!links.typeParametersChecked) {
           links.typeParametersChecked = true;
           const typeParameter = getDeclaredTypeOfTypeParameter(symbol);
-          const declarations = getDeclarationsOfKind(symbol, 167 /* TypeParameter */);
+          const declarations = getDeclarationsOfKind(symbol, 168 /* TypeParameter */);
           if (!areTypeParametersIdentical(declarations, [typeParameter], (decl) => [decl])) {
             const name = symbolToString(symbol);
             for (const declaration of declarations) {
-              error(declaration.name, Diagnostics.All_declarations_of_0_must_have_identical_constraints, name);
+              error2(declaration.name, Diagnostics.All_declarations_of_0_must_have_identical_constraints, name);
             }
           }
         }
@@ -176918,16 +160865,8 @@ ${lanes.join("\n")}
     }
     function checkImportType(node) {
       checkSourceElement(node.argument);
-      if (node.assertions) {
-        const override = getResolutionModeOverrideForClause(node.assertions.assertClause, grammarErrorOnNode);
-        if (override) {
-          if (!isNightly()) {
-            grammarErrorOnNode(node.assertions.assertClause, Diagnostics.resolution_mode_assertions_are_unstable_Use_nightly_TypeScript_to_silence_this_error_Try_updating_with_npm_install_D_typescript_next);
-          }
-          if (getEmitModuleResolutionKind(compilerOptions) !== 3 /* Node16 */ && getEmitModuleResolutionKind(compilerOptions) !== 99 /* NodeNext */) {
-            grammarErrorOnNode(node.assertions.assertClause, Diagnostics.resolution_mode_assertions_are_only_supported_when_moduleResolution_is_node16_or_nodenext);
-          }
-        }
+      if (node.attributes) {
+        getResolutionModeOverride(node.attributes, grammarErrorOnNode);
       }
       checkTypeReferenceOrImport(node);
     }
@@ -176935,25 +160874,26 @@ ${lanes.join("\n")}
       if (node.dotDotDotToken && node.questionToken) {
         grammarErrorOnNode(node, Diagnostics.A_tuple_member_cannot_be_both_optional_and_rest);
       }
-      if (node.type.kind === 189 /* OptionalType */) {
+      if (node.type.kind === 190 /* OptionalType */) {
         grammarErrorOnNode(node.type, Diagnostics.A_labeled_tuple_element_is_declared_as_optional_with_a_question_mark_after_the_name_and_before_the_colon_rather_than_after_the_type);
       }
-      if (node.type.kind === 190 /* RestType */) {
+      if (node.type.kind === 191 /* RestType */) {
         grammarErrorOnNode(node.type, Diagnostics.A_labeled_tuple_element_is_declared_as_rest_with_a_before_the_name_rather_than_before_the_type);
       }
       checkSourceElement(node.type);
       getTypeFromTypeNode(node);
     }
     function isPrivateWithinAmbient(node) {
-      return (hasEffectiveModifier(node, 8 /* Private */) || isPrivateIdentifierClassElementDeclaration(node)) && !!(node.flags & 16777216 /* Ambient */);
+      return (hasEffectiveModifier(node, 2 /* Private */) || isPrivateIdentifierClassElementDeclaration(node)) && !!(node.flags & 33554432 /* Ambient */);
     }
     function getEffectiveDeclarationFlags(n, flagsToCheck) {
-      let flags = getCombinedModifierFlags(n);
-      if (n.parent.kind !== 263 /* InterfaceDeclaration */ && n.parent.kind !== 262 /* ClassDeclaration */ && n.parent.kind !== 230 /* ClassExpression */ && n.flags & 16777216 /* Ambient */) {
-        if (!(flags & 2 /* Ambient */) && !(isModuleBlock(n.parent) && isModuleDeclaration(n.parent.parent) && isGlobalScopeAugmentation(n.parent.parent))) {
-          flags |= 1 /* Export */;
+      let flags = getCombinedModifierFlagsCached(n);
+      if (n.parent.kind !== 264 /* InterfaceDeclaration */ && n.parent.kind !== 263 /* ClassDeclaration */ && n.parent.kind !== 231 /* ClassExpression */ && n.flags & 33554432 /* Ambient */) {
+        const container = getEnclosingContainer(n);
+        if (container && container.flags & 128 /* ExportContext */ && !(flags & 128 /* Ambient */) && !(isModuleBlock(n.parent) && isModuleDeclaration(n.parent.parent) && isGlobalScopeAugmentation(n.parent.parent))) {
+          flags |= 32 /* Export */;
         }
-        flags |= 2 /* Ambient */;
+        flags |= 128 /* Ambient */;
       }
       return flags & flagsToCheck;
     }
@@ -176971,14 +160911,14 @@ ${lanes.join("\n")}
           const canonicalFlags = getEffectiveDeclarationFlags(getCanonicalOverload(overloads, implementation), flagsToCheck2);
           forEach(overloads, (o) => {
             const deviation = getEffectiveDeclarationFlags(o, flagsToCheck2) ^ canonicalFlags;
-            if (deviation & 1 /* Export */) {
-              error(getNameOfDeclaration(o), Diagnostics.Overload_signatures_must_all_be_exported_or_non_exported);
-            } else if (deviation & 2 /* Ambient */) {
-              error(getNameOfDeclaration(o), Diagnostics.Overload_signatures_must_all_be_ambient_or_non_ambient);
-            } else if (deviation & (8 /* Private */ | 16 /* Protected */)) {
-              error(getNameOfDeclaration(o) || o, Diagnostics.Overload_signatures_must_all_be_public_private_or_protected);
-            } else if (deviation & 256 /* Abstract */) {
-              error(getNameOfDeclaration(o), Diagnostics.Overload_signatures_must_all_be_abstract_or_non_abstract);
+            if (deviation & 32 /* Export */) {
+              error2(getNameOfDeclaration(o), Diagnostics.Overload_signatures_must_all_be_exported_or_non_exported);
+            } else if (deviation & 128 /* Ambient */) {
+              error2(getNameOfDeclaration(o), Diagnostics.Overload_signatures_must_all_be_ambient_or_non_ambient);
+            } else if (deviation & (2 /* Private */ | 4 /* Protected */)) {
+              error2(getNameOfDeclaration(o) || o, Diagnostics.Overload_signatures_must_all_be_public_private_or_protected);
+            } else if (deviation & 64 /* Abstract */) {
+              error2(getNameOfDeclaration(o), Diagnostics.Overload_signatures_must_all_be_abstract_or_non_abstract);
             }
           });
         }
@@ -176989,12 +160929,12 @@ ${lanes.join("\n")}
           forEach(overloads, (o) => {
             const deviation = hasQuestionToken(o) !== canonicalHasQuestionToken;
             if (deviation) {
-              error(getNameOfDeclaration(o), Diagnostics.Overload_signatures_must_all_be_optional_or_required);
+              error2(getNameOfDeclaration(o), Diagnostics.Overload_signatures_must_all_be_optional_or_required);
             }
           });
         }
       }
-      const flagsToCheck = 1 /* Export */ | 2 /* Ambient */ | 8 /* Private */ | 16 /* Protected */ | 256 /* Abstract */;
+      const flagsToCheck = 32 /* Export */ | 128 /* Ambient */ | 2 /* Private */ | 4 /* Protected */ | 64 /* Abstract */;
       let someNodeFlags = 0 /* None */;
       let allNodeFlags = flagsToCheck;
       let someHaveQuestionToken = false;
@@ -177025,27 +160965,27 @@ ${lanes.join("\n")}
             (isPrivateIdentifier(node.name) && isPrivateIdentifier(subsequentName) && node.name.escapedText === subsequentName.escapedText || // Both are computed property names
             isComputedPropertyName(node.name) && isComputedPropertyName(subsequentName) && isTypeIdenticalTo(checkComputedPropertyName(node.name), checkComputedPropertyName(subsequentName)) || // Both are literal property names that are the same.
             isPropertyNameLiteral(node.name) && isPropertyNameLiteral(subsequentName) && getEscapedTextOfIdentifierOrLiteral(node.name) === getEscapedTextOfIdentifierOrLiteral(subsequentName))) {
-              const reportError = (node.kind === 173 /* MethodDeclaration */ || node.kind === 172 /* MethodSignature */) && isStatic(node) !== isStatic(subsequentNode);
+              const reportError = (node.kind === 174 /* MethodDeclaration */ || node.kind === 173 /* MethodSignature */) && isStatic(node) !== isStatic(subsequentNode);
               if (reportError) {
                 const diagnostic = isStatic(node) ? Diagnostics.Function_overload_must_be_static : Diagnostics.Function_overload_must_not_be_static;
-                error(errorNode2, diagnostic);
+                error2(errorNode2, diagnostic);
               }
               return;
             }
             if (nodeIsPresent(subsequentNode.body)) {
-              error(errorNode2, Diagnostics.Function_implementation_name_must_be_0, declarationNameToString(node.name));
+              error2(errorNode2, Diagnostics.Function_implementation_name_must_be_0, declarationNameToString(node.name));
               return;
             }
           }
         }
         const errorNode = node.name || node;
         if (isConstructor) {
-          error(errorNode, Diagnostics.Constructor_implementation_is_missing);
+          error2(errorNode, Diagnostics.Constructor_implementation_is_missing);
         } else {
-          if (hasSyntacticModifier(node, 256 /* Abstract */)) {
-            error(errorNode, Diagnostics.All_declarations_of_an_abstract_method_must_be_consecutive);
+          if (hasSyntacticModifier(node, 64 /* Abstract */)) {
+            error2(errorNode, Diagnostics.All_declarations_of_an_abstract_method_must_be_consecutive);
           } else {
-            error(errorNode, Diagnostics.Function_implementation_is_missing_or_not_immediately_following_the_declaration);
+            error2(errorNode, Diagnostics.Function_implementation_is_missing_or_not_immediately_following_the_declaration);
           }
         }
       }
@@ -177056,15 +160996,15 @@ ${lanes.join("\n")}
       if (declarations) {
         for (const current of declarations) {
           const node = current;
-          const inAmbientContext = node.flags & 16777216 /* Ambient */;
-          const inAmbientContextOrInterface = node.parent && (node.parent.kind === 263 /* InterfaceDeclaration */ || node.parent.kind === 186 /* TypeLiteral */) || inAmbientContext;
+          const inAmbientContext = node.flags & 33554432 /* Ambient */;
+          const inAmbientContextOrInterface = node.parent && (node.parent.kind === 264 /* InterfaceDeclaration */ || node.parent.kind === 187 /* TypeLiteral */) || inAmbientContext;
           if (inAmbientContextOrInterface) {
             previousDeclaration = void 0;
           }
-          if ((node.kind === 262 /* ClassDeclaration */ || node.kind === 230 /* ClassExpression */) && !inAmbientContext) {
+          if ((node.kind === 263 /* ClassDeclaration */ || node.kind === 231 /* ClassExpression */) && !inAmbientContext) {
             hasNonAmbientClass = true;
           }
-          if (node.kind === 261 /* FunctionDeclaration */ || node.kind === 173 /* MethodDeclaration */ || node.kind === 172 /* MethodSignature */ || node.kind === 175 /* Constructor */) {
+          if (node.kind === 262 /* FunctionDeclaration */ || node.kind === 174 /* MethodDeclaration */ || node.kind === 173 /* MethodSignature */ || node.kind === 176 /* Constructor */) {
             functionDeclarations.push(node);
             const currentNodeFlags = getEffectiveDeclarationFlags(node, flagsToCheck);
             someNodeFlags |= currentNodeFlags;
@@ -177108,27 +161048,27 @@ ${lanes.join("\n")}
       }
       if (multipleConstructorImplementation) {
         forEach(functionDeclarations, (declaration) => {
-          error(declaration, Diagnostics.Multiple_constructor_implementations_are_not_allowed);
+          error2(declaration, Diagnostics.Multiple_constructor_implementations_are_not_allowed);
         });
       }
       if (duplicateFunctionDeclaration) {
         forEach(functionDeclarations, (declaration) => {
-          error(getNameOfDeclaration(declaration) || declaration, Diagnostics.Duplicate_function_implementation);
+          error2(getNameOfDeclaration(declaration) || declaration, Diagnostics.Duplicate_function_implementation);
         });
       }
       if (hasNonAmbientClass && !isConstructor && symbol.flags & 16 /* Function */ && declarations) {
-        const relatedDiagnostics = filter(declarations, (d) => d.kind === 262 /* ClassDeclaration */).map((d) => createDiagnosticForNode(d, Diagnostics.Consider_adding_a_declare_modifier_to_this_class));
+        const relatedDiagnostics = filter(declarations, (d) => d.kind === 263 /* ClassDeclaration */).map((d) => createDiagnosticForNode(d, Diagnostics.Consider_adding_a_declare_modifier_to_this_class));
         forEach(declarations, (declaration) => {
-          const diagnostic = declaration.kind === 262 /* ClassDeclaration */ ? Diagnostics.Class_declaration_cannot_implement_overload_list_for_0 : declaration.kind === 261 /* FunctionDeclaration */ ? Diagnostics.Function_with_bodies_can_only_merge_with_classes_that_are_ambient : void 0;
+          const diagnostic = declaration.kind === 263 /* ClassDeclaration */ ? Diagnostics.Class_declaration_cannot_implement_overload_list_for_0 : declaration.kind === 262 /* FunctionDeclaration */ ? Diagnostics.Function_with_bodies_can_only_merge_with_classes_that_are_ambient : void 0;
           if (diagnostic) {
             addRelatedInfo(
-              error(getNameOfDeclaration(declaration) || declaration, diagnostic, symbolName(symbol)),
+              error2(getNameOfDeclaration(declaration) || declaration, diagnostic, symbolName(symbol)),
               ...relatedDiagnostics
             );
           }
         });
       }
-      if (lastSeenNonAmbientDeclaration && !lastSeenNonAmbientDeclaration.body && !hasSyntacticModifier(lastSeenNonAmbientDeclaration, 256 /* Abstract */) && !lastSeenNonAmbientDeclaration.questionToken) {
+      if (lastSeenNonAmbientDeclaration && !lastSeenNonAmbientDeclaration.body && !hasSyntacticModifier(lastSeenNonAmbientDeclaration, 64 /* Abstract */) && !lastSeenNonAmbientDeclaration.questionToken) {
         reportImplementationExpectedError(lastSeenNonAmbientDeclaration);
       }
       if (hasOverloads) {
@@ -177143,7 +161083,7 @@ ${lanes.join("\n")}
             if (!isImplementationCompatibleWithOverload(bodySignature, signature)) {
               const errorNode = signature.declaration && isJSDocSignature(signature.declaration) ? signature.declaration.parent.tagName : signature.declaration;
               addRelatedInfo(
-                error(errorNode, Diagnostics.This_overload_signature_is_not_compatible_with_its_implementation_signature),
+                error2(errorNode, Diagnostics.This_overload_signature_is_not_compatible_with_its_implementation_signature),
                 createDiagnosticForNode(bodyDeclaration, Diagnostics.The_implementation_signature_is_declared_here)
               );
               break;
@@ -177171,9 +161111,9 @@ ${lanes.join("\n")}
       let defaultExportedDeclarationSpaces = 0 /* None */;
       for (const d of symbol.declarations) {
         const declarationSpaces = getDeclarationSpaces(d);
-        const effectiveDeclarationFlags = getEffectiveDeclarationFlags(d, 1 /* Export */ | 1024 /* Default */);
-        if (effectiveDeclarationFlags & 1 /* Export */) {
-          if (effectiveDeclarationFlags & 1024 /* Default */) {
+        const effectiveDeclarationFlags = getEffectiveDeclarationFlags(d, 32 /* Export */ | 2048 /* Default */);
+        if (effectiveDeclarationFlags & 32 /* Export */) {
+          if (effectiveDeclarationFlags & 2048 /* Default */) {
             defaultExportedDeclarationSpaces |= declarationSpaces;
           } else {
             exportedDeclarationSpaces |= declarationSpaces;
@@ -177190,54 +161130,54 @@ ${lanes.join("\n")}
           const declarationSpaces = getDeclarationSpaces(d);
           const name = getNameOfDeclaration(d);
           if (declarationSpaces & commonDeclarationSpacesForDefaultAndNonDefault) {
-            error(name, Diagnostics.Merged_declaration_0_cannot_include_a_default_export_declaration_Consider_adding_a_separate_export_default_0_declaration_instead, declarationNameToString(name));
+            error2(name, Diagnostics.Merged_declaration_0_cannot_include_a_default_export_declaration_Consider_adding_a_separate_export_default_0_declaration_instead, declarationNameToString(name));
           } else if (declarationSpaces & commonDeclarationSpacesForExportsAndLocals) {
-            error(name, Diagnostics.Individual_declarations_in_merged_declaration_0_must_be_all_exported_or_all_local, declarationNameToString(name));
+            error2(name, Diagnostics.Individual_declarations_in_merged_declaration_0_must_be_all_exported_or_all_local, declarationNameToString(name));
           }
         }
       }
       function getDeclarationSpaces(decl) {
         let d = decl;
         switch (d.kind) {
-          case 263 /* InterfaceDeclaration */:
-          case 264 /* TypeAliasDeclaration */:
-          case 352 /* JSDocTypedefTag */:
-          case 344 /* JSDocCallbackTag */:
-          case 346 /* JSDocEnumTag */:
+          case 264 /* InterfaceDeclaration */:
+          case 265 /* TypeAliasDeclaration */:
+          case 353 /* JSDocTypedefTag */:
+          case 345 /* JSDocCallbackTag */:
+          case 347 /* JSDocEnumTag */:
             return 2 /* ExportType */;
-          case 266 /* ModuleDeclaration */:
+          case 267 /* ModuleDeclaration */:
             return isAmbientModule(d) || getModuleInstanceState(d) !== 0 /* NonInstantiated */ ? 4 /* ExportNamespace */ | 1 /* ExportValue */ : 4 /* ExportNamespace */;
-          case 262 /* ClassDeclaration */:
-          case 265 /* EnumDeclaration */:
-          case 305 /* EnumMember */:
+          case 263 /* ClassDeclaration */:
+          case 266 /* EnumDeclaration */:
+          case 306 /* EnumMember */:
             return 2 /* ExportType */ | 1 /* ExportValue */;
-          case 311 /* SourceFile */:
+          case 312 /* SourceFile */:
             return 2 /* ExportType */ | 1 /* ExportValue */ | 4 /* ExportNamespace */;
-          case 276 /* ExportAssignment */:
-          case 225 /* BinaryExpression */:
+          case 277 /* ExportAssignment */:
+          case 226 /* BinaryExpression */:
             const node2 = d;
             const expression = isExportAssignment(node2) ? node2.expression : node2.right;
             if (!isEntityNameExpression(expression)) {
               return 1 /* ExportValue */;
             }
             d = expression;
-          case 270 /* ImportEqualsDeclaration */:
-          case 273 /* NamespaceImport */:
-          case 272 /* ImportClause */:
+          case 271 /* ImportEqualsDeclaration */:
+          case 274 /* NamespaceImport */:
+          case 273 /* ImportClause */:
             let result = 0 /* None */;
             const target = resolveAlias(getSymbolOfDeclaration(d));
             forEach(target.declarations, (d2) => {
               result |= getDeclarationSpaces(d2);
             });
             return result;
-          case 259 /* VariableDeclaration */:
-          case 207 /* BindingElement */:
-          case 261 /* FunctionDeclaration */:
-          case 275 /* ImportSpecifier */:
+          case 260 /* VariableDeclaration */:
+          case 208 /* BindingElement */:
+          case 262 /* FunctionDeclaration */:
+          case 276 /* ImportSpecifier */:
           case 80 /* Identifier */:
             return 1 /* ExportValue */;
-          case 172 /* MethodSignature */:
-          case 170 /* PropertySignature */:
+          case 173 /* MethodSignature */:
+          case 171 /* PropertySignature */:
             return 2 /* ExportType */;
           default:
             return Debug.failBadSyntaxKind(d);
@@ -177272,7 +161212,7 @@ ${lanes.join("\n")}
       const thenSignatures = thenFunction ? getSignaturesOfType(thenFunction, 0 /* Call */) : emptyArray;
       if (thenSignatures.length === 0) {
         if (errorNode) {
-          error(errorNode, Diagnostics.A_promise_must_have_a_then_method);
+          error2(errorNode, Diagnostics.A_promise_must_have_a_then_method);
         }
         return void 0;
       }
@@ -177292,7 +161232,7 @@ ${lanes.join("\n")}
           thisTypeForErrorOut.value = thisTypeForError;
         }
         if (errorNode) {
-          error(errorNode, Diagnostics.The_this_context_of_type_0_is_not_assignable_to_method_s_this_of_type_1, typeToString(type), typeToString(thisTypeForError));
+          error2(errorNode, Diagnostics.The_this_context_of_type_0_is_not_assignable_to_method_s_this_of_type_1, typeToString(type), typeToString(thisTypeForError));
         }
         return void 0;
       }
@@ -177303,7 +161243,7 @@ ${lanes.join("\n")}
       const onfulfilledParameterSignatures = getSignaturesOfType(onfulfilledParameterType, 0 /* Call */);
       if (onfulfilledParameterSignatures.length === 0) {
         if (errorNode) {
-          error(errorNode, Diagnostics.The_first_parameter_of_the_then_method_of_a_promise_must_be_a_callback);
+          error2(errorNode, Diagnostics.The_first_parameter_of_the_then_method_of_a_promise_must_be_a_callback);
         }
         return void 0;
       }
@@ -177384,7 +161324,7 @@ ${lanes.join("\n")}
       if (type.flags & 1048576 /* Union */) {
         if (awaitedTypeStack.lastIndexOf(type.id) >= 0) {
           if (errorNode) {
-            error(errorNode, Diagnostics.Type_is_referenced_directly_or_indirectly_in_the_fulfillment_callback_of_its_own_then_method);
+            error2(errorNode, Diagnostics.Type_is_referenced_directly_or_indirectly_in_the_fulfillment_callback_of_its_own_then_method);
           }
           return void 0;
         }
@@ -177407,7 +161347,7 @@ ${lanes.join("\n")}
       if (promisedType) {
         if (type.id === promisedType.id || awaitedTypeStack.lastIndexOf(promisedType.id) >= 0) {
           if (errorNode) {
-            error(errorNode, Diagnostics.Type_is_referenced_directly_or_indirectly_in_the_fulfillment_callback_of_its_own_then_method);
+            error2(errorNode, Diagnostics.Type_is_referenced_directly_or_indirectly_in_the_fulfillment_callback_of_its_own_then_method);
           }
           return void 0;
         }
@@ -177433,7 +161373,7 @@ ${lanes.join("\n")}
       }
       return typeAsAwaitable.awaitedTypeOfType = type;
     }
-    function checkAsyncFunctionReturnType(node, returnTypeNode) {
+    function checkAsyncFunctionReturnType(node, returnTypeNode, returnTypeErrorLocation) {
       const returnType = getTypeFromTypeNode(returnTypeNode);
       if (languageVersion >= 2 /* ES2015 */) {
         if (isErrorType(returnType)) {
@@ -177444,7 +161384,7 @@ ${lanes.join("\n")}
           true
         );
         if (globalPromiseType !== emptyGenericType && !isReferenceToType2(returnType, globalPromiseType)) {
-          error(returnTypeNode, Diagnostics.The_return_type_of_an_async_function_or_method_must_be_the_global_Promise_T_type_Did_you_mean_to_write_Promise_0, typeToString(getAwaitedTypeNoAlias(returnType) || voidType));
+          reportErrorForInvalidReturnType(Diagnostics.The_return_type_of_an_async_function_or_method_must_be_the_global_Promise_T_type_Did_you_mean_to_write_Promise_0, returnTypeNode, returnTypeErrorLocation, typeToString(getAwaitedTypeNoAlias(returnType) || voidType));
           return;
         }
       } else {
@@ -177454,7 +161394,7 @@ ${lanes.join("\n")}
         }
         const promiseConstructorName = getEntityNameFromTypeNode(returnTypeNode);
         if (promiseConstructorName === void 0) {
-          error(returnTypeNode, Diagnostics.Type_0_is_not_a_valid_async_function_return_type_in_ES5_SlashES3_because_it_does_not_refer_to_a_Promise_compatible_constructor_value, typeToString(returnType));
+          reportErrorForInvalidReturnType(Diagnostics.Type_0_is_not_a_valid_async_function_return_type_in_ES5_SlashES3_because_it_does_not_refer_to_a_Promise_compatible_constructor_value, returnTypeNode, returnTypeErrorLocation, typeToString(returnType));
           return;
         }
         const promiseConstructorSymbol = resolveEntityName(
@@ -177469,9 +161409,9 @@ ${lanes.join("\n")}
             /*reportErrors*/
             false
           )) {
-            error(returnTypeNode, Diagnostics.An_async_function_or_method_in_ES5_SlashES3_requires_the_Promise_constructor_Make_sure_you_have_a_declaration_for_the_Promise_constructor_or_include_ES2015_in_your_lib_option);
+            error2(returnTypeErrorLocation, Diagnostics.An_async_function_or_method_in_ES5_SlashES3_requires_the_Promise_constructor_Make_sure_you_have_a_declaration_for_the_Promise_constructor_or_include_ES2015_in_your_lib_option);
           } else {
-            error(returnTypeNode, Diagnostics.Type_0_is_not_a_valid_async_function_return_type_in_ES5_SlashES3_because_it_does_not_refer_to_a_Promise_compatible_constructor_value, entityNameToString(promiseConstructorName));
+            reportErrorForInvalidReturnType(Diagnostics.Type_0_is_not_a_valid_async_function_return_type_in_ES5_SlashES3_because_it_does_not_refer_to_a_Promise_compatible_constructor_value, returnTypeNode, returnTypeErrorLocation, entityNameToString(promiseConstructorName));
           }
           return;
         }
@@ -177480,26 +161420,22 @@ ${lanes.join("\n")}
           true
         );
         if (globalPromiseConstructorLikeType === emptyObjectType) {
-          error(returnTypeNode, Diagnostics.Type_0_is_not_a_valid_async_function_return_type_in_ES5_SlashES3_because_it_does_not_refer_to_a_Promise_compatible_constructor_value, entityNameToString(promiseConstructorName));
+          reportErrorForInvalidReturnType(Diagnostics.Type_0_is_not_a_valid_async_function_return_type_in_ES5_SlashES3_because_it_does_not_refer_to_a_Promise_compatible_constructor_value, returnTypeNode, returnTypeErrorLocation, entityNameToString(promiseConstructorName));
           return;
         }
-        if (!checkTypeAssignableTo(
-          promiseConstructorType,
-          globalPromiseConstructorLikeType,
-          returnTypeNode,
-          Diagnostics.Type_0_is_not_a_valid_async_function_return_type_in_ES5_SlashES3_because_it_does_not_refer_to_a_Promise_compatible_constructor_value
-        )) {
+        const headMessage = Diagnostics.Type_0_is_not_a_valid_async_function_return_type_in_ES5_SlashES3_because_it_does_not_refer_to_a_Promise_compatible_constructor_value;
+        const errorInfo = () => returnTypeNode === returnTypeErrorLocation ? void 0 : chainDiagnosticMessages(
+          /*details*/
+          void 0,
+          Diagnostics.The_return_type_of_an_async_function_or_method_must_be_the_global_Promise_T_type
+        );
+        if (!checkTypeAssignableTo(promiseConstructorType, globalPromiseConstructorLikeType, returnTypeErrorLocation, headMessage, errorInfo)) {
           return;
         }
         const rootName = promiseConstructorName && getFirstIdentifier(promiseConstructorName);
         const collidingSymbol = getSymbol2(node.locals, rootName.escapedText, 111551 /* Value */);
         if (collidingSymbol) {
-          error(
-            collidingSymbol.valueDeclaration,
-            Diagnostics.Duplicate_identifier_0_Compiler_uses_declaration_1_to_support_async_functions,
-            idText(rootName),
-            entityNameToString(promiseConstructorName)
-          );
+          error2(collidingSymbol.valueDeclaration, Diagnostics.Duplicate_identifier_0_Compiler_uses_declaration_1_to_support_async_functions, idText(rootName), entityNameToString(promiseConstructorName));
           return;
         }
       }
@@ -177510,6 +161446,14 @@ ${lanes.join("\n")}
         node,
         Diagnostics.The_return_type_of_an_async_function_must_either_be_a_valid_promise_or_must_not_contain_a_callable_then_member
       );
+      function reportErrorForInvalidReturnType(message, returnTypeNode2, returnTypeErrorLocation2, typeName) {
+        if (returnTypeNode2 === returnTypeErrorLocation2) {
+          error2(returnTypeErrorLocation2, message, typeName);
+        } else {
+          const diag2 = error2(returnTypeErrorLocation2, Diagnostics.The_return_type_of_an_async_function_or_method_must_be_the_global_Promise_T_type);
+          addRelatedInfo(diag2, createDiagnosticForNode(returnTypeNode2, message, typeName));
+        }
+      }
     }
     function checkDecorator(node) {
       const signature = getResolvedSignature(node);
@@ -177524,21 +161468,21 @@ ${lanes.join("\n")}
       let headMessage;
       const expectedReturnType = decoratorSignature.resolvedReturnType;
       switch (node.parent.kind) {
-        case 262 /* ClassDeclaration */:
-        case 230 /* ClassExpression */:
+        case 263 /* ClassDeclaration */:
+        case 231 /* ClassExpression */:
           headMessage = Diagnostics.Decorator_function_return_type_0_is_not_assignable_to_type_1;
           break;
-        case 171 /* PropertyDeclaration */:
+        case 172 /* PropertyDeclaration */:
           if (!legacyDecorators) {
             headMessage = Diagnostics.Decorator_function_return_type_0_is_not_assignable_to_type_1;
             break;
           }
-        case 168 /* Parameter */:
+        case 169 /* Parameter */:
           headMessage = Diagnostics.Decorator_function_return_type_is_0_but_is_expected_to_be_void_or_any;
           break;
-        case 173 /* MethodDeclaration */:
-        case 176 /* GetAccessor */:
-        case 177 /* SetAccessor */:
+        case 174 /* MethodDeclaration */:
+        case 177 /* GetAccessor */:
+        case 178 /* SetAccessor */:
           headMessage = Diagnostics.Decorator_function_return_type_0_is_not_assignable_to_type_1;
           break;
         default:
@@ -177607,7 +161551,7 @@ ${lanes.join("\n")}
         if (canCollectSymbolAliasAccessabilityData && symbolIsValue(rootSymbol) && !isConstEnumOrConstEnumOnlyModule(resolveAlias(rootSymbol)) && !getTypeOnlyAliasDeclaration(rootSymbol)) {
           markAliasSymbolAsReferenced(rootSymbol);
         } else if (forDecoratorMetadata && getIsolatedModules(compilerOptions) && getEmitModuleKind(compilerOptions) >= 5 /* ES2015 */ && !symbolIsValue(rootSymbol) && !some(rootSymbol.declarations, isTypeOnlyImportOrExportDeclaration)) {
-          const diag2 = error(typeName, Diagnostics.A_type_referenced_in_a_decorated_signature_must_be_imported_with_import_type_or_a_namespace_import_when_isolatedModules_and_emitDecoratorMetadata_are_enabled);
+          const diag2 = error2(typeName, Diagnostics.A_type_referenced_in_a_decorated_signature_must_be_imported_with_import_type_or_a_namespace_import_when_isolatedModules_and_emitDecoratorMetadata_are_enabled);
           const aliasDeclaration = find(rootSymbol.declarations || emptyArray, isAliasSymbolDeclaration2);
           if (aliasDeclaration) {
             addRelatedInfo(diag2, createDiagnosticForNode(aliasDeclaration, Diagnostics._0_was_imported_here, idText(rootName)));
@@ -177628,15 +161572,15 @@ ${lanes.join("\n")}
     function getEntityNameForDecoratorMetadata(node) {
       if (node) {
         switch (node.kind) {
-          case 192 /* IntersectionType */:
-          case 191 /* UnionType */:
+          case 193 /* IntersectionType */:
+          case 192 /* UnionType */:
             return getEntityNameForDecoratorMetadataFromTypeList(node.types);
-          case 193 /* ConditionalType */:
+          case 194 /* ConditionalType */:
             return getEntityNameForDecoratorMetadataFromTypeList([node.trueType, node.falseType]);
-          case 195 /* ParenthesizedType */:
-          case 201 /* NamedTupleMember */:
+          case 196 /* ParenthesizedType */:
+          case 202 /* NamedTupleMember */:
             return getEntityNameForDecoratorMetadata(node.type);
-          case 182 /* TypeReference */:
+          case 183 /* TypeReference */:
             return node.typeName;
         }
       }
@@ -177644,13 +161588,13 @@ ${lanes.join("\n")}
     function getEntityNameForDecoratorMetadataFromTypeList(types) {
       let commonEntityName;
       for (let typeNode of types) {
-        while (typeNode.kind === 195 /* ParenthesizedType */ || typeNode.kind === 201 /* NamedTupleMember */) {
+        while (typeNode.kind === 196 /* ParenthesizedType */ || typeNode.kind === 202 /* NamedTupleMember */) {
           typeNode = typeNode.type;
         }
         if (typeNode.kind === 146 /* NeverKeyword */) {
           continue;
         }
-        if (!strictNullChecks && (typeNode.kind === 200 /* LiteralType */ && typeNode.literal.kind === 106 /* NullKeyword */ || typeNode.kind === 157 /* UndefinedKeyword */)) {
+        if (!strictNullChecks && (typeNode.kind === 201 /* LiteralType */ && typeNode.literal.kind === 106 /* NullKeyword */ || typeNode.kind === 157 /* UndefinedKeyword */)) {
           continue;
         }
         const individualEntityName = getEntityNameForDecoratorMetadata(typeNode);
@@ -177681,7 +161625,7 @@ ${lanes.join("\n")}
       }
       if (legacyDecorators) {
         checkExternalEmitHelpers(firstDecorator, 8 /* Decorate */);
-        if (node.kind === 168 /* Parameter */) {
+        if (node.kind === 169 /* Parameter */) {
           checkExternalEmitHelpers(firstDecorator, 32 /* Param */);
         }
       } else if (languageVersion < 99 /* ESNext */) {
@@ -177707,7 +161651,7 @@ ${lanes.join("\n")}
       if (compilerOptions.emitDecoratorMetadata) {
         checkExternalEmitHelpers(firstDecorator, 16 /* Metadata */);
         switch (node.kind) {
-          case 262 /* ClassDeclaration */:
+          case 263 /* ClassDeclaration */:
             const constructor = getFirstConstructorWithBody(node);
             if (constructor) {
               for (const parameter of constructor.parameters) {
@@ -177715,27 +161659,28 @@ ${lanes.join("\n")}
               }
             }
             break;
-          case 176 /* GetAccessor */:
-          case 177 /* SetAccessor */:
-            const otherKind = node.kind === 176 /* GetAccessor */ ? 177 /* SetAccessor */ : 176 /* GetAccessor */;
+          case 177 /* GetAccessor */:
+          case 178 /* SetAccessor */:
+            const otherKind = node.kind === 177 /* GetAccessor */ ? 178 /* SetAccessor */ : 177 /* GetAccessor */;
             const otherAccessor = getDeclarationOfKind(getSymbolOfDeclaration(node), otherKind);
             markDecoratorMedataDataTypeNodeAsReferenced(getAnnotatedAccessorTypeNode(node) || otherAccessor && getAnnotatedAccessorTypeNode(otherAccessor));
             break;
-          case 173 /* MethodDeclaration */:
+          case 174 /* MethodDeclaration */:
             for (const parameter of node.parameters) {
               markDecoratorMedataDataTypeNodeAsReferenced(getParameterTypeNodeForDecoratorCheck(parameter));
             }
             markDecoratorMedataDataTypeNodeAsReferenced(getEffectiveReturnTypeNode(node));
             break;
-          case 171 /* PropertyDeclaration */:
+          case 172 /* PropertyDeclaration */:
             markDecoratorMedataDataTypeNodeAsReferenced(getEffectiveTypeAnnotationNode(node));
             break;
-          case 168 /* Parameter */:
+          case 169 /* Parameter */:
             markDecoratorMedataDataTypeNodeAsReferenced(getParameterTypeNodeForDecoratorCheck(node));
             const containingSignature = node.parent;
             for (const parameter of containingSignature.parameters) {
               markDecoratorMedataDataTypeNodeAsReferenced(getParameterTypeNodeForDecoratorCheck(parameter));
             }
+            markDecoratorMedataDataTypeNodeAsReferenced(getEffectiveReturnTypeNode(containingSignature));
             break;
         }
       }
@@ -177755,7 +161700,7 @@ ${lanes.join("\n")}
     }
     function checkJSDocTypeAliasTag(node) {
       if (!node.typeExpression) {
-        error(node.name, Diagnostics.JSDoc_typedef_tag_should_either_have_a_type_annotation_or_be_followed_by_property_or_member_tags);
+        error2(node.name, Diagnostics.JSDoc_typedef_tag_should_either_have_a_type_annotation_or_be_followed_by_property_or_member_tags);
       }
       if (node.name) {
         checkTypeNameIsReserved(node.name, Diagnostics.Type_alias_name_cannot_be_0);
@@ -177780,7 +161725,7 @@ ${lanes.join("\n")}
         if (length(tags) > 1) {
           for (let i = 1; i < length(tags); i++) {
             const tagName = tags[i].tagName;
-            error(tagName, Diagnostics._0_tag_already_specified, idText(tagName));
+            error2(tagName, Diagnostics._0_tag_already_specified, idText(tagName));
           }
         }
       }
@@ -177809,43 +161754,49 @@ ${lanes.join("\n")}
         }
       }
     }
+    function checkJSDocThisTag(node) {
+      const host2 = getEffectiveJSDocHost(node);
+      if (host2 && isArrowFunction(host2)) {
+        error2(node.tagName, Diagnostics.An_arrow_function_cannot_have_a_this_parameter);
+      }
+    }
     function checkJSDocImplementsTag(node) {
       const classLike = getEffectiveJSDocHost(node);
       if (!classLike || !isClassDeclaration(classLike) && !isClassExpression(classLike)) {
-        error(classLike, Diagnostics.JSDoc_0_is_not_attached_to_a_class, idText(node.tagName));
+        error2(classLike, Diagnostics.JSDoc_0_is_not_attached_to_a_class, idText(node.tagName));
       }
     }
     function checkJSDocAugmentsTag(node) {
       const classLike = getEffectiveJSDocHost(node);
       if (!classLike || !isClassDeclaration(classLike) && !isClassExpression(classLike)) {
-        error(classLike, Diagnostics.JSDoc_0_is_not_attached_to_a_class, idText(node.tagName));
+        error2(classLike, Diagnostics.JSDoc_0_is_not_attached_to_a_class, idText(node.tagName));
         return;
       }
       const augmentsTags = getJSDocTags(classLike).filter(isJSDocAugmentsTag);
       Debug.assert(augmentsTags.length > 0);
       if (augmentsTags.length > 1) {
-        error(augmentsTags[1], Diagnostics.Class_declarations_cannot_have_more_than_one_augments_or_extends_tag);
+        error2(augmentsTags[1], Diagnostics.Class_declarations_cannot_have_more_than_one_augments_or_extends_tag);
       }
       const name = getIdentifierFromEntityNameExpression(node.class.expression);
       const extend2 = getClassExtendsHeritageElement(classLike);
       if (extend2) {
         const className = getIdentifierFromEntityNameExpression(extend2.expression);
         if (className && name.escapedText !== className.escapedText) {
-          error(name, Diagnostics.JSDoc_0_1_does_not_match_the_extends_2_clause, idText(node.tagName), idText(name), idText(className));
+          error2(name, Diagnostics.JSDoc_0_1_does_not_match_the_extends_2_clause, idText(node.tagName), idText(name), idText(className));
         }
       }
     }
     function checkJSDocAccessibilityModifiers(node) {
       const host2 = getJSDocHost(node);
       if (host2 && isPrivateIdentifierClassElementDeclaration(host2)) {
-        error(node, Diagnostics.An_accessibility_modifier_cannot_be_used_with_a_private_identifier);
+        error2(node, Diagnostics.An_accessibility_modifier_cannot_be_used_with_a_private_identifier);
       }
     }
     function getIdentifierFromEntityNameExpression(node) {
       switch (node.kind) {
         case 80 /* Identifier */:
           return node;
-        case 210 /* PropertyAccessExpression */:
+        case 211 /* PropertyAccessExpression */:
           return node.name;
         default:
           return void 0;
@@ -177856,7 +161807,7 @@ ${lanes.join("\n")}
       checkDecorators(node);
       checkSignatureDeclaration(node);
       const functionFlags = getFunctionFlags(node);
-      if (node.name && node.name.kind === 166 /* ComputedPropertyName */) {
+      if (node.name && node.name.kind === 167 /* ComputedPropertyName */) {
         checkComputedPropertyName(node.name);
       }
       if (hasBindableName(node)) {
@@ -177864,7 +161815,7 @@ ${lanes.join("\n")}
         const localSymbol = node.localSymbol || symbol;
         const firstDeclaration = (_a = localSymbol.declarations) == null ? void 0 : _a.find(
           // Get first non javascript function declaration
-          (declaration) => declaration.kind === node.kind && !(declaration.flags & 262144 /* JavaScriptFile */)
+          (declaration) => declaration.kind === node.kind && !(declaration.flags & 524288 /* JavaScriptFile */)
         );
         if (node === firstDeclaration) {
           checkFunctionOrConstructorSymbol(localSymbol);
@@ -177873,14 +161824,14 @@ ${lanes.join("\n")}
           checkFunctionOrConstructorSymbol(symbol);
         }
       }
-      const body = node.kind === 172 /* MethodSignature */ ? void 0 : node.body;
+      const body = node.kind === 173 /* MethodSignature */ ? void 0 : node.body;
       checkSourceElement(body);
       checkAllCodePathsInNonVoidFunctionReturnOrThrow(node, getReturnTypeFromAnnotation(node));
       addLazyDiagnostic(checkFunctionOrMethodDeclarationDiagnostics);
       if (isInJSFile(node)) {
         const typeTag = getJSDocTypeTag(node);
         if (typeTag && typeTag.typeExpression && !getContextualCallSignature(getTypeFromTypeNode(typeTag.typeExpression), node)) {
-          error(typeTag.typeExpression.type, Diagnostics.The_type_of_a_function_declaration_must_match_the_function_s_signature);
+          error2(typeTag.typeExpression.type, Diagnostics.The_type_of_a_function_declaration_must_match_the_function_s_signature);
         }
       }
       function checkFunctionOrMethodDeclarationDiagnostics() {
@@ -177909,42 +161860,42 @@ ${lanes.join("\n")}
     function checkUnusedIdentifiers(potentiallyUnusedIdentifiers, addDiagnostic) {
       for (const node of potentiallyUnusedIdentifiers) {
         switch (node.kind) {
-          case 262 /* ClassDeclaration */:
-          case 230 /* ClassExpression */:
+          case 263 /* ClassDeclaration */:
+          case 231 /* ClassExpression */:
             checkUnusedClassMembers(node, addDiagnostic);
             checkUnusedTypeParameters(node, addDiagnostic);
             break;
-          case 311 /* SourceFile */:
-          case 266 /* ModuleDeclaration */:
-          case 240 /* Block */:
-          case 268 /* CaseBlock */:
-          case 247 /* ForStatement */:
-          case 248 /* ForInStatement */:
-          case 249 /* ForOfStatement */:
+          case 312 /* SourceFile */:
+          case 267 /* ModuleDeclaration */:
+          case 241 /* Block */:
+          case 269 /* CaseBlock */:
+          case 248 /* ForStatement */:
+          case 249 /* ForInStatement */:
+          case 250 /* ForOfStatement */:
             checkUnusedLocalsAndParameters(node, addDiagnostic);
             break;
-          case 175 /* Constructor */:
-          case 217 /* FunctionExpression */:
-          case 261 /* FunctionDeclaration */:
-          case 218 /* ArrowFunction */:
-          case 173 /* MethodDeclaration */:
-          case 176 /* GetAccessor */:
-          case 177 /* SetAccessor */:
+          case 176 /* Constructor */:
+          case 218 /* FunctionExpression */:
+          case 262 /* FunctionDeclaration */:
+          case 219 /* ArrowFunction */:
+          case 174 /* MethodDeclaration */:
+          case 177 /* GetAccessor */:
+          case 178 /* SetAccessor */:
             if (node.body) {
               checkUnusedLocalsAndParameters(node, addDiagnostic);
             }
             checkUnusedTypeParameters(node, addDiagnostic);
             break;
-          case 172 /* MethodSignature */:
-          case 178 /* CallSignature */:
-          case 179 /* ConstructSignature */:
-          case 183 /* FunctionType */:
-          case 184 /* ConstructorType */:
-          case 264 /* TypeAliasDeclaration */:
-          case 263 /* InterfaceDeclaration */:
+          case 173 /* MethodSignature */:
+          case 179 /* CallSignature */:
+          case 180 /* ConstructSignature */:
+          case 184 /* FunctionType */:
+          case 185 /* ConstructorType */:
+          case 265 /* TypeAliasDeclaration */:
+          case 264 /* InterfaceDeclaration */:
             checkUnusedTypeParameters(node, addDiagnostic);
             break;
-          case 194 /* InferType */:
+          case 195 /* InferType */:
             checkUnusedInferTypeParameter(node, addDiagnostic);
             break;
           default:
@@ -177963,28 +161914,28 @@ ${lanes.join("\n")}
     function checkUnusedClassMembers(node, addDiagnostic) {
       for (const member of node.members) {
         switch (member.kind) {
-          case 173 /* MethodDeclaration */:
-          case 171 /* PropertyDeclaration */:
-          case 176 /* GetAccessor */:
-          case 177 /* SetAccessor */:
-            if (member.kind === 177 /* SetAccessor */ && member.symbol.flags & 32768 /* GetAccessor */) {
+          case 174 /* MethodDeclaration */:
+          case 172 /* PropertyDeclaration */:
+          case 177 /* GetAccessor */:
+          case 178 /* SetAccessor */:
+            if (member.kind === 178 /* SetAccessor */ && member.symbol.flags & 32768 /* GetAccessor */) {
               break;
             }
             const symbol = getSymbolOfDeclaration(member);
-            if (!symbol.isReferenced && (hasEffectiveModifier(member, 8 /* Private */) || isNamedDeclaration(member) && isPrivateIdentifier(member.name)) && !(member.flags & 16777216 /* Ambient */)) {
+            if (!symbol.isReferenced && (hasEffectiveModifier(member, 2 /* Private */) || isNamedDeclaration(member) && isPrivateIdentifier(member.name)) && !(member.flags & 33554432 /* Ambient */)) {
               addDiagnostic(member, 0 /* Local */, createDiagnosticForNode(member.name, Diagnostics._0_is_declared_but_its_value_is_never_read, symbolToString(symbol)));
             }
             break;
-          case 175 /* Constructor */:
+          case 176 /* Constructor */:
             for (const parameter of member.parameters) {
-              if (!parameter.symbol.isReferenced && hasSyntacticModifier(parameter, 8 /* Private */)) {
+              if (!parameter.symbol.isReferenced && hasSyntacticModifier(parameter, 2 /* Private */)) {
                 addDiagnostic(parameter, 0 /* Local */, createDiagnosticForNode(parameter.name, Diagnostics.Property_0_is_declared_but_its_value_is_never_read, symbolName(parameter.symbol)));
               }
             }
             break;
-          case 180 /* IndexSignature */:
-          case 239 /* SemicolonClassElement */:
-          case 174 /* ClassStaticBlockDeclaration */:
+          case 181 /* IndexSignature */:
+          case 240 /* SemicolonClassElement */:
+          case 175 /* ClassStaticBlockDeclaration */:
             break;
           default:
             Debug.fail("Unexpected class member");
@@ -178008,7 +161959,7 @@ ${lanes.join("\n")}
           continue;
         const name = idText(typeParameter.name);
         const { parent: parent2 } = typeParameter;
-        if (parent2.kind !== 194 /* InferType */ && parent2.typeParameters.every(isTypeParameterUnused)) {
+        if (parent2.kind !== 195 /* InferType */ && parent2.typeParameters.every(isTypeParameterUnused)) {
           if (tryAddToSet(seenParentsWithEveryUnused, parent2)) {
             const sourceFile = getSourceFileOfNode(parent2);
             const range = isJSDocTemplateTag(parent2) ? rangeOfNode(parent2) : rangeOfTypeParameters(sourceFile, parent2.typeParameters);
@@ -178066,7 +162017,11 @@ ${lanes.join("\n")}
                 addToGroup(unusedDestructures, declaration.parent, declaration, getNodeId);
               }
             } else if (isVariableDeclaration(declaration)) {
-              addToGroup(unusedVariables, declaration.parent, declaration, getNodeId);
+              const blockScopeKind = getCombinedNodeFlagsCached(declaration) & 7 /* BlockScoped */;
+              const name = getNameOfDeclaration(declaration);
+              if (blockScopeKind !== 4 /* Using */ && blockScopeKind !== 6 /* AwaitUsing */ || !name || !isIdentifierThatStartsWithUnderscore(name)) {
+                addToGroup(unusedVariables, declaration.parent, declaration, getNodeId);
+              }
             } else {
               const parameter = local.valueDeclaration && tryGetRootParameterDeclaration(local.valueDeclaration);
               const name = local.valueDeclaration && getNameOfDeclaration(local.valueDeclaration);
@@ -178087,9 +162042,13 @@ ${lanes.join("\n")}
       });
       unusedImports.forEach(([importClause, unuseds]) => {
         const importDecl = importClause.parent;
-        const nDeclarations = (importClause.name ? 1 : 0) + (importClause.namedBindings ? importClause.namedBindings.kind === 273 /* NamespaceImport */ ? 1 : importClause.namedBindings.elements.length : 0);
+        const nDeclarations = (importClause.name ? 1 : 0) + (importClause.namedBindings ? importClause.namedBindings.kind === 274 /* NamespaceImport */ ? 1 : importClause.namedBindings.elements.length : 0);
         if (nDeclarations === unuseds.length) {
-          addDiagnostic(importDecl, 0 /* Local */, unuseds.length === 1 ? createDiagnosticForNode(importDecl, Diagnostics._0_is_declared_but_its_value_is_never_read, idText(first(unuseds).name)) : createDiagnosticForNode(importDecl, Diagnostics.All_imports_in_import_declaration_are_unused));
+          addDiagnostic(
+            importDecl,
+            0 /* Local */,
+            unuseds.length === 1 ? createDiagnosticForNode(importDecl, Diagnostics._0_is_declared_but_its_value_is_never_read, idText(first(unuseds).name)) : createDiagnosticForNode(importDecl, Diagnostics.All_imports_in_import_declaration_are_unused)
+          );
         } else {
           for (const unused of unuseds)
             errorUnusedLocal(unused, idText(unused.name), addDiagnostic);
@@ -178098,10 +162057,14 @@ ${lanes.join("\n")}
       unusedDestructures.forEach(([bindingPattern, bindingElements]) => {
         const kind = tryGetRootParameterDeclaration(bindingPattern.parent) ? 1 /* Parameter */ : 0 /* Local */;
         if (bindingPattern.elements.length === bindingElements.length) {
-          if (bindingElements.length === 1 && bindingPattern.parent.kind === 259 /* VariableDeclaration */ && bindingPattern.parent.parent.kind === 260 /* VariableDeclarationList */) {
+          if (bindingElements.length === 1 && bindingPattern.parent.kind === 260 /* VariableDeclaration */ && bindingPattern.parent.parent.kind === 261 /* VariableDeclarationList */) {
             addToGroup(unusedVariables, bindingPattern.parent.parent, bindingPattern.parent, getNodeId);
           } else {
-            addDiagnostic(bindingPattern, kind, bindingElements.length === 1 ? createDiagnosticForNode(bindingPattern, Diagnostics._0_is_declared_but_its_value_is_never_read, bindingNameText(first(bindingElements).name)) : createDiagnosticForNode(bindingPattern, Diagnostics.All_destructured_elements_are_unused));
+            addDiagnostic(
+              bindingPattern,
+              kind,
+              bindingElements.length === 1 ? createDiagnosticForNode(bindingPattern, Diagnostics._0_is_declared_but_its_value_is_never_read, bindingNameText(first(bindingElements).name)) : createDiagnosticForNode(bindingPattern, Diagnostics.All_destructured_elements_are_unused)
+            );
           }
         } else {
           for (const e of bindingElements) {
@@ -178111,7 +162074,11 @@ ${lanes.join("\n")}
       });
       unusedVariables.forEach(([declarationList, declarations]) => {
         if (declarationList.declarations.length === declarations.length) {
-          addDiagnostic(declarationList, 0 /* Local */, declarations.length === 1 ? createDiagnosticForNode(first(declarations).name, Diagnostics._0_is_declared_but_its_value_is_never_read, bindingNameText(first(declarations).name)) : createDiagnosticForNode(declarationList.parent.kind === 242 /* VariableStatement */ ? declarationList.parent : declarationList, Diagnostics.All_variables_are_unused));
+          addDiagnostic(
+            declarationList,
+            0 /* Local */,
+            declarations.length === 1 ? createDiagnosticForNode(first(declarations).name, Diagnostics._0_is_declared_but_its_value_is_never_read, bindingNameText(first(declarations).name)) : createDiagnosticForNode(declarationList.parent.kind === 243 /* VariableStatement */ ? declarationList.parent : declarationList, Diagnostics.All_variables_are_unused)
+          );
         } else {
           for (const decl of declarations) {
             addDiagnostic(decl, 0 /* Local */, createDiagnosticForNode(decl, Diagnostics._0_is_declared_but_its_value_is_never_read, bindingNameText(decl.name)));
@@ -178140,21 +162107,21 @@ ${lanes.join("\n")}
       switch (name.kind) {
         case 80 /* Identifier */:
           return idText(name);
-        case 206 /* ArrayBindingPattern */:
-        case 205 /* ObjectBindingPattern */:
+        case 207 /* ArrayBindingPattern */:
+        case 206 /* ObjectBindingPattern */:
           return bindingNameText(cast(first(name.elements), isBindingElement).name);
         default:
           return Debug.assertNever(name);
       }
     }
     function isImportedDeclaration(node) {
-      return node.kind === 272 /* ImportClause */ || node.kind === 275 /* ImportSpecifier */ || node.kind === 273 /* NamespaceImport */;
+      return node.kind === 273 /* ImportClause */ || node.kind === 276 /* ImportSpecifier */ || node.kind === 274 /* NamespaceImport */;
     }
     function importClauseFromImported(decl) {
-      return decl.kind === 272 /* ImportClause */ ? decl : decl.kind === 273 /* NamespaceImport */ ? decl.parent : decl.parent.parent;
+      return decl.kind === 273 /* ImportClause */ ? decl : decl.kind === 274 /* NamespaceImport */ ? decl.parent : decl.parent.parent;
     }
     function checkBlock(node) {
-      if (node.kind === 240 /* Block */) {
+      if (node.kind === 241 /* Block */) {
         checkGrammarStatementInAmbientContext(node);
       }
       if (isFunctionOrModuleBlock(node)) {
@@ -178169,7 +162136,7 @@ ${lanes.join("\n")}
       }
     }
     function checkCollisionWithArgumentsInGeneratedCode(node) {
-      if (languageVersion >= 2 /* ES2015 */ || !hasRestParameter(node) || node.flags & 16777216 /* Ambient */ || nodeIsMissing(node.body)) {
+      if (languageVersion >= 2 /* ES2015 */ || !hasRestParameter(node) || node.flags & 33554432 /* Ambient */ || nodeIsMissing(node.body)) {
         return;
       }
       forEach(node.parameters, (p) => {
@@ -178182,10 +162149,10 @@ ${lanes.join("\n")}
       if ((identifier == null ? void 0 : identifier.escapedText) !== name) {
         return false;
       }
-      if (node.kind === 171 /* PropertyDeclaration */ || node.kind === 170 /* PropertySignature */ || node.kind === 173 /* MethodDeclaration */ || node.kind === 172 /* MethodSignature */ || node.kind === 176 /* GetAccessor */ || node.kind === 177 /* SetAccessor */ || node.kind === 302 /* PropertyAssignment */) {
+      if (node.kind === 172 /* PropertyDeclaration */ || node.kind === 171 /* PropertySignature */ || node.kind === 174 /* MethodDeclaration */ || node.kind === 173 /* MethodSignature */ || node.kind === 177 /* GetAccessor */ || node.kind === 178 /* SetAccessor */ || node.kind === 303 /* PropertyAssignment */) {
         return false;
       }
-      if (node.flags & 16777216 /* Ambient */) {
+      if (node.flags & 33554432 /* Ambient */) {
         return false;
       }
       if (isImportClause(node) || isImportEqualsDeclaration(node) || isImportSpecifier(node)) {
@@ -178204,9 +162171,9 @@ ${lanes.join("\n")}
         if (getNodeCheckFlags(current) & 4 /* CaptureThis */) {
           const isDeclaration2 = node.kind !== 80 /* Identifier */;
           if (isDeclaration2) {
-            error(getNameOfDeclaration(node), Diagnostics.Duplicate_identifier_this_Compiler_uses_variable_declaration_this_to_capture_this_reference);
+            error2(getNameOfDeclaration(node), Diagnostics.Duplicate_identifier_this_Compiler_uses_variable_declaration_this_to_capture_this_reference);
           } else {
-            error(node, Diagnostics.Expression_resolves_to_variable_declaration_this_that_compiler_uses_to_capture_this_reference);
+            error2(node, Diagnostics.Expression_resolves_to_variable_declaration_this_that_compiler_uses_to_capture_this_reference);
           }
           return true;
         }
@@ -178218,9 +162185,9 @@ ${lanes.join("\n")}
         if (getNodeCheckFlags(current) & 8 /* CaptureNewTarget */) {
           const isDeclaration2 = node.kind !== 80 /* Identifier */;
           if (isDeclaration2) {
-            error(getNameOfDeclaration(node), Diagnostics.Duplicate_identifier_newTarget_Compiler_uses_variable_declaration_newTarget_to_capture_new_target_meta_property_reference);
+            error2(getNameOfDeclaration(node), Diagnostics.Duplicate_identifier_newTarget_Compiler_uses_variable_declaration_newTarget_to_capture_new_target_meta_property_reference);
           } else {
-            error(node, Diagnostics.Expression_resolves_to_variable_declaration_newTarget_that_compiler_uses_to_capture_new_target_meta_property_reference);
+            error2(node, Diagnostics.Expression_resolves_to_variable_declaration_newTarget_that_compiler_uses_to_capture_new_target_meta_property_reference);
           }
           return true;
         }
@@ -178238,14 +162205,8 @@ ${lanes.join("\n")}
         return;
       }
       const parent2 = getDeclarationContainer(node);
-      if (parent2.kind === 311 /* SourceFile */ && isExternalOrCommonJsModule(parent2)) {
-        errorSkippedOn(
-          "noEmit",
-          name,
-          Diagnostics.Duplicate_identifier_0_Compiler_reserves_name_1_in_top_level_scope_of_a_module,
-          declarationNameToString(name),
-          declarationNameToString(name)
-        );
+      if (parent2.kind === 312 /* SourceFile */ && isExternalOrCommonJsModule(parent2)) {
+        errorSkippedOn("noEmit", name, Diagnostics.Duplicate_identifier_0_Compiler_reserves_name_1_in_top_level_scope_of_a_module, declarationNameToString(name), declarationNameToString(name));
       }
     }
     function checkCollisionWithGlobalPromiseInGeneratedCode(node, name) {
@@ -178256,14 +162217,8 @@ ${lanes.join("\n")}
         return;
       }
       const parent2 = getDeclarationContainer(node);
-      if (parent2.kind === 311 /* SourceFile */ && isExternalOrCommonJsModule(parent2) && parent2.flags & 2048 /* HasAsyncFunctions */) {
-        errorSkippedOn(
-          "noEmit",
-          name,
-          Diagnostics.Duplicate_identifier_0_Compiler_reserves_name_1_in_top_level_scope_of_a_module_containing_async_functions,
-          declarationNameToString(name),
-          declarationNameToString(name)
-        );
+      if (parent2.kind === 312 /* SourceFile */ && isExternalOrCommonJsModule(parent2) && parent2.flags & 4096 /* HasAsyncFunctions */) {
+        errorSkippedOn("noEmit", name, Diagnostics.Duplicate_identifier_0_Compiler_reserves_name_1_in_top_level_scope_of_a_module_containing_async_functions, declarationNameToString(name), declarationNameToString(name));
       }
     }
     function recordPotentialCollisionWithWeakMapSetInGeneratedCode(node, name) {
@@ -178273,7 +162228,7 @@ ${lanes.join("\n")}
     }
     function checkWeakMapSetCollision(node) {
       const enclosingBlockScope = getEnclosingBlockScopeContainer(node);
-      if (getNodeCheckFlags(enclosingBlockScope) & 4194304 /* ContainsClassWithPrivateIdentifiers */) {
+      if (getNodeCheckFlags(enclosingBlockScope) & 1048576 /* ContainsClassWithPrivateIdentifiers */) {
         Debug.assert(isNamedDeclaration(node) && isIdentifier(node.name) && typeof node.name.escapedText === "string", "The target of a WeakMap/WeakSet collision check should be an identifier");
         errorSkippedOn("noEmit", node, Diagnostics.Compiler_reserves_name_0_when_emitting_private_identifier_downlevel, node.name.escapedText);
       }
@@ -178287,30 +162242,24 @@ ${lanes.join("\n")}
       let hasCollision = false;
       if (isClassExpression(node)) {
         for (const member of node.members) {
-          if (getNodeCheckFlags(member) & 8388608 /* ContainsSuperPropertyInStaticInitializer */) {
+          if (getNodeCheckFlags(member) & 2097152 /* ContainsSuperPropertyInStaticInitializer */) {
             hasCollision = true;
             break;
           }
         }
       } else if (isFunctionExpression(node)) {
-        if (getNodeCheckFlags(node) & 8388608 /* ContainsSuperPropertyInStaticInitializer */) {
+        if (getNodeCheckFlags(node) & 2097152 /* ContainsSuperPropertyInStaticInitializer */) {
           hasCollision = true;
         }
       } else {
         const container = getEnclosingBlockScopeContainer(node);
-        if (container && getNodeCheckFlags(container) & 8388608 /* ContainsSuperPropertyInStaticInitializer */) {
+        if (container && getNodeCheckFlags(container) & 2097152 /* ContainsSuperPropertyInStaticInitializer */) {
           hasCollision = true;
         }
       }
       if (hasCollision) {
         Debug.assert(isNamedDeclaration(node) && isIdentifier(node.name), "The target of a Reflect collision check should be an identifier");
-        errorSkippedOn(
-          "noEmit",
-          node,
-          Diagnostics.Duplicate_identifier_0_Compiler_reserves_name_1_when_emitting_super_references_in_static_initializers,
-          declarationNameToString(node.name),
-          "Reflect"
-        );
+        errorSkippedOn("noEmit", node, Diagnostics.Duplicate_identifier_0_Compiler_reserves_name_1_when_emitting_super_references_in_static_initializers, declarationNameToString(node.name), "Reflect");
       }
     }
     function checkCollisionsForDeclarationName(node, name) {
@@ -178322,7 +162271,7 @@ ${lanes.join("\n")}
       recordPotentialCollisionWithReflectInGeneratedCode(node, name);
       if (isClassLike(node)) {
         checkTypeNameIsReserved(name, Diagnostics.Class_name_cannot_be_0);
-        if (!(node.flags & 16777216 /* Ambient */)) {
+        if (!(node.flags & 33554432 /* Ambient */)) {
           checkClassNameCollisionWithObject(name);
         }
       } else if (isEnumDeclaration(node)) {
@@ -178330,10 +162279,7 @@ ${lanes.join("\n")}
       }
     }
     function checkVarDeclaredNamesNotShadowed(node) {
-      if ((getCombinedNodeFlags(node) & 3 /* BlockScoped */) !== 0 || isParameterDeclaration(node)) {
-        return;
-      }
-      if (node.kind === 259 /* VariableDeclaration */ && !node.initializer) {
+      if ((getCombinedNodeFlagsCached(node) & 7 /* BlockScoped */) !== 0 || isParameterDeclaration(node)) {
         return;
       }
       const symbol = getSymbolOfDeclaration(node);
@@ -178352,13 +162298,13 @@ ${lanes.join("\n")}
           false
         );
         if (localDeclarationSymbol && localDeclarationSymbol !== symbol && localDeclarationSymbol.flags & 2 /* BlockScopedVariable */) {
-          if (getDeclarationNodeFlagsFromSymbol(localDeclarationSymbol) & 3 /* BlockScoped */) {
-            const varDeclList = getAncestor(localDeclarationSymbol.valueDeclaration, 260 /* VariableDeclarationList */);
-            const container = varDeclList.parent.kind === 242 /* VariableStatement */ && varDeclList.parent.parent ? varDeclList.parent.parent : void 0;
-            const namesShareScope = container && (container.kind === 240 /* Block */ && isFunctionLike(container.parent) || container.kind === 267 /* ModuleBlock */ || container.kind === 266 /* ModuleDeclaration */ || container.kind === 311 /* SourceFile */);
+          if (getDeclarationNodeFlagsFromSymbol(localDeclarationSymbol) & 7 /* BlockScoped */) {
+            const varDeclList = getAncestor(localDeclarationSymbol.valueDeclaration, 261 /* VariableDeclarationList */);
+            const container = varDeclList.parent.kind === 243 /* VariableStatement */ && varDeclList.parent.parent ? varDeclList.parent.parent : void 0;
+            const namesShareScope = container && (container.kind === 241 /* Block */ && isFunctionLike(container.parent) || container.kind === 268 /* ModuleBlock */ || container.kind === 267 /* ModuleDeclaration */ || container.kind === 312 /* SourceFile */);
             if (!namesShareScope) {
               const name = symbolToString(localDeclarationSymbol);
-              error(node, Diagnostics.Cannot_initialize_outer_scoped_variable_0_in_the_same_scope_as_block_scoped_declaration_1, name, name);
+              error2(node, Diagnostics.Cannot_initialize_outer_scoped_variable_0_in_the_same_scope_as_block_scoped_declaration_1, name, name);
             }
           }
         }
@@ -178376,7 +162322,7 @@ ${lanes.join("\n")}
       if (!node.name) {
         return;
       }
-      if (node.name.kind === 166 /* ComputedPropertyName */) {
+      if (node.name.kind === 167 /* ComputedPropertyName */) {
         checkComputedPropertyName(node.name);
         if (hasOnlyExpressionInitializer(node) && node.initializer) {
           checkExpressionCached(node.initializer);
@@ -178390,11 +162336,11 @@ ${lanes.join("\n")}
         if (isObjectBindingPattern(node.parent) && node.dotDotDotToken && languageVersion < 5 /* ES2018 */) {
           checkExternalEmitHelpers(node, 4 /* Rest */);
         }
-        if (node.propertyName && node.propertyName.kind === 166 /* ComputedPropertyName */) {
+        if (node.propertyName && node.propertyName.kind === 167 /* ComputedPropertyName */) {
           checkComputedPropertyName(node.propertyName);
         }
         const parent2 = node.parent.parent;
-        const parentCheckMode = node.dotDotDotToken ? 64 /* RestBindingElement */ : 0 /* Normal */;
+        const parentCheckMode = node.dotDotDotToken ? 32 /* RestBindingElement */ : 0 /* Normal */;
         const parentType = getTypeForBindingElementParent(parent2, parentCheckMode);
         const name = node.propertyName || node.name;
         if (parentType && !isBindingPattern(name)) {
@@ -178423,20 +162369,20 @@ ${lanes.join("\n")}
         }
       }
       if (isBindingPattern(node.name)) {
-        if (node.name.kind === 206 /* ArrayBindingPattern */ && languageVersion < 2 /* ES2015 */ && compilerOptions.downlevelIteration) {
+        if (node.name.kind === 207 /* ArrayBindingPattern */ && languageVersion < 2 /* ES2015 */ && compilerOptions.downlevelIteration) {
           checkExternalEmitHelpers(node, 512 /* Read */);
         }
         forEach(node.name.elements, checkSourceElement);
       }
-      if (isParameter(node) && node.initializer && nodeIsMissing(getContainingFunction(node).body)) {
-        error(node, Diagnostics.A_parameter_initializer_is_only_allowed_in_a_function_or_constructor_implementation);
+      if (node.initializer && isParameterDeclaration(node) && nodeIsMissing(getContainingFunction(node).body)) {
+        error2(node, Diagnostics.A_parameter_initializer_is_only_allowed_in_a_function_or_constructor_implementation);
         return;
       }
       if (isBindingPattern(node.name)) {
         if (isInAmbientOrTypeNode(node)) {
           return;
         }
-        const needCheckInitializer = hasOnlyExpressionInitializer(node) && node.initializer && node.parent.parent.kind !== 248 /* ForInStatement */;
+        const needCheckInitializer = hasOnlyExpressionInitializer(node) && node.initializer && node.parent.parent.kind !== 249 /* ForInStatement */;
         const needCheckWidenedType = !some(node.name.elements, not(isOmittedExpression));
         if (needCheckInitializer || needCheckWidenedType) {
           const widenedType = getWidenedTypeForVariableLikeDeclaration(node);
@@ -178468,20 +162414,45 @@ ${lanes.join("\n")}
         const initializer = hasOnlyExpressionInitializer(node) && getEffectiveInitializer(node);
         if (initializer) {
           const isJSObjectLiteralInitializer = isInJSFile(node) && isObjectLiteralExpression(initializer) && (initializer.properties.length === 0 || isPrototypeAccess(node.name)) && !!((_a = symbol.exports) == null ? void 0 : _a.size);
-          if (!isJSObjectLiteralInitializer && node.parent.parent.kind !== 248 /* ForInStatement */) {
+          if (!isJSObjectLiteralInitializer && node.parent.parent.kind !== 249 /* ForInStatement */) {
+            const initializerType = checkExpressionCached(initializer);
             checkTypeAssignableToAndOptionallyElaborate(
-              checkExpressionCached(initializer),
+              initializerType,
               type,
               node,
               initializer,
               /*headMessage*/
               void 0
             );
+            const blockScopeKind = getCombinedNodeFlagsCached(node) & 7 /* BlockScoped */;
+            if (blockScopeKind === 6 /* AwaitUsing */) {
+              const globalAsyncDisposableType = getGlobalAsyncDisposableType(
+                /*reportErrors*/
+                true
+              );
+              const globalDisposableType = getGlobalDisposableType(
+                /*reportErrors*/
+                true
+              );
+              if (globalAsyncDisposableType !== emptyObjectType && globalDisposableType !== emptyObjectType) {
+                const optionalDisposableType = getUnionType([globalAsyncDisposableType, globalDisposableType, nullType, undefinedType]);
+                checkTypeAssignableTo(initializerType, optionalDisposableType, initializer, Diagnostics.The_initializer_of_an_await_using_declaration_must_be_either_an_object_with_a_Symbol_asyncDispose_or_Symbol_dispose_method_or_be_null_or_undefined);
+              }
+            } else if (blockScopeKind === 4 /* Using */) {
+              const globalDisposableType = getGlobalDisposableType(
+                /*reportErrors*/
+                true
+              );
+              if (globalDisposableType !== emptyObjectType) {
+                const optionalDisposableType = getUnionType([globalDisposableType, nullType, undefinedType]);
+                checkTypeAssignableTo(initializerType, optionalDisposableType, initializer, Diagnostics.The_initializer_of_a_using_declaration_must_be_either_an_object_with_a_Symbol_dispose_method_or_be_null_or_undefined);
+              }
+            }
           }
         }
         if (symbol.declarations && symbol.declarations.length > 1) {
           if (some(symbol.declarations, (d) => d !== node && isVariableLike(d) && !areDeclarationFlagsIdentical(d, node))) {
-            error(node.name, Diagnostics.All_declarations_of_0_must_have_identical_modifiers, declarationNameToString(node.name));
+            error2(node.name, Diagnostics.All_declarations_of_0_must_have_identical_modifiers, declarationNameToString(node.name));
           }
         }
       } else {
@@ -178500,12 +162471,12 @@ ${lanes.join("\n")}
           );
         }
         if (symbol.valueDeclaration && !areDeclarationFlagsIdentical(node, symbol.valueDeclaration)) {
-          error(node.name, Diagnostics.All_declarations_of_0_must_have_identical_modifiers, declarationNameToString(node.name));
+          error2(node.name, Diagnostics.All_declarations_of_0_must_have_identical_modifiers, declarationNameToString(node.name));
         }
       }
-      if (node.kind !== 171 /* PropertyDeclaration */ && node.kind !== 170 /* PropertySignature */) {
+      if (node.kind !== 172 /* PropertyDeclaration */ && node.kind !== 171 /* PropertySignature */) {
         checkExportsOnMergedDeclarations(node);
-        if (node.kind === 259 /* VariableDeclaration */ || node.kind === 207 /* BindingElement */) {
+        if (node.kind === 260 /* VariableDeclaration */ || node.kind === 208 /* BindingElement */) {
           checkVarDeclaredNamesNotShadowed(node);
         }
         checkCollisionsForDeclarationName(node, node.name);
@@ -178513,9 +162484,9 @@ ${lanes.join("\n")}
     }
     function errorNextVariableOrPropertyDeclarationMustHaveSameType(firstDeclaration, firstType, nextDeclaration, nextType) {
       const nextDeclarationName = getNameOfDeclaration(nextDeclaration);
-      const message = nextDeclaration.kind === 171 /* PropertyDeclaration */ || nextDeclaration.kind === 170 /* PropertySignature */ ? Diagnostics.Subsequent_property_declarations_must_have_the_same_type_Property_0_must_be_of_type_1_but_here_has_type_2 : Diagnostics.Subsequent_variable_declarations_must_have_the_same_type_Variable_0_must_be_of_type_1_but_here_has_type_2;
+      const message = nextDeclaration.kind === 172 /* PropertyDeclaration */ || nextDeclaration.kind === 171 /* PropertySignature */ ? Diagnostics.Subsequent_property_declarations_must_have_the_same_type_Property_0_must_be_of_type_1_but_here_has_type_2 : Diagnostics.Subsequent_variable_declarations_must_have_the_same_type_Variable_0_must_be_of_type_1_but_here_has_type_2;
       const declName = declarationNameToString(nextDeclarationName);
-      const err = error(
+      const err = error2(
         nextDeclarationName,
         message,
         declName,
@@ -178523,20 +162494,17 @@ ${lanes.join("\n")}
         typeToString(nextType)
       );
       if (firstDeclaration) {
-        addRelatedInfo(
-          err,
-          createDiagnosticForNode(firstDeclaration, Diagnostics._0_was_also_declared_here, declName)
-        );
+        addRelatedInfo(err, createDiagnosticForNode(firstDeclaration, Diagnostics._0_was_also_declared_here, declName));
       }
     }
     function areDeclarationFlagsIdentical(left, right) {
-      if (left.kind === 168 /* Parameter */ && right.kind === 259 /* VariableDeclaration */ || left.kind === 259 /* VariableDeclaration */ && right.kind === 168 /* Parameter */) {
+      if (left.kind === 169 /* Parameter */ && right.kind === 260 /* VariableDeclaration */ || left.kind === 260 /* VariableDeclaration */ && right.kind === 169 /* Parameter */) {
         return true;
       }
       if (hasQuestionToken(left) !== hasQuestionToken(right)) {
         return false;
       }
-      const interestingFlags = 8 /* Private */ | 16 /* Protected */ | 512 /* Async */ | 256 /* Abstract */ | 64 /* Readonly */ | 32 /* Static */;
+      const interestingFlags = 2 /* Private */ | 4 /* Protected */ | 1024 /* Async */ | 64 /* Abstract */ | 8 /* Readonly */ | 256 /* Static */;
       return getSelectedEffectiveModifierFlags(left, interestingFlags) === getSelectedEffectiveModifierFlags(right, interestingFlags);
     }
     function checkVariableDeclaration(node) {
@@ -178550,10 +162518,17 @@ ${lanes.join("\n")}
       checkGrammarBindingElement(node);
       return checkVariableLikeDeclaration(node);
     }
+    function checkVariableDeclarationList(node) {
+      const blockScopeKind = getCombinedNodeFlags(node) & 7 /* BlockScoped */;
+      if (blockScopeKind === 4 /* Using */ || blockScopeKind === 6 /* AwaitUsing */) {
+        checkExternalEmitHelpers(node, 33554432 /* AddDisposableResourceAndDisposeResources */);
+      }
+      forEach(node.declarations, checkSourceElement);
+    }
     function checkVariableStatement(node) {
       if (!checkGrammarModifiers(node) && !checkGrammarVariableDeclarationList(node.declarationList))
-        checkGrammarForDisallowedLetOrConstStatement(node);
-      forEach(node.declarationList.declarations, checkSourceElement);
+        checkGrammarForDisallowedBlockScopedVariableStatement(node);
+      checkVariableDeclarationList(node.declarationList);
     }
     function checkExpressionStatement(node) {
       checkGrammarStatementInAmbientContext(node);
@@ -178564,8 +162539,8 @@ ${lanes.join("\n")}
       const type = checkTruthinessExpression(node.expression);
       checkTestingKnownTruthyCallableOrAwaitableType(node.expression, type, node.thenStatement);
       checkSourceElement(node.thenStatement);
-      if (node.thenStatement.kind === 241 /* EmptyStatement */) {
-        error(node.thenStatement, Diagnostics.The_body_of_an_if_statement_cannot_be_the_empty_statement);
+      if (node.thenStatement.kind === 242 /* EmptyStatement */) {
+        error2(node.thenStatement, Diagnostics.The_body_of_an_if_statement_cannot_be_the_empty_statement);
       }
       checkSourceElement(node.elseStatement);
     }
@@ -178592,7 +162567,7 @@ ${lanes.join("\n")}
         }
         const type = location === condExpr2 ? condType : checkTruthinessExpression(location);
         const isPropertyExpressionCast = isPropertyAccessExpression(location) && isTypeAssertion(location.expression);
-        if (!(getTypeFacts(type) & 4194304 /* Truthy */) || isPropertyExpressionCast)
+        if (!hasTypeFacts(type, 4194304 /* Truthy */) || isPropertyExpressionCast)
           return;
         const callSignatures = getSignaturesOfType(type, 0 /* Call */);
         const isPromise = !!getAwaitedTypeOfPromise(type);
@@ -178615,7 +162590,7 @@ ${lanes.join("\n")}
               getTypeNameForErrorDisplay(type)
             );
           } else {
-            error(location, Diagnostics.This_condition_will_always_return_true_since_this_function_is_always_defined_Did_you_mean_to_call_it_instead);
+            error2(location, Diagnostics.This_condition_will_always_return_true_since_this_function_is_always_defined_Did_you_mean_to_call_it_instead);
           }
         }
       }
@@ -178681,7 +162656,7 @@ ${lanes.join("\n")}
     }
     function checkTruthinessOfType(type, node) {
       if (type.flags & 16384 /* Void */) {
-        error(node, Diagnostics.An_expression_of_type_void_cannot_be_tested_for_truthiness);
+        error2(node, Diagnostics.An_expression_of_type_void_cannot_be_tested_for_truthiness);
       }
       return type;
     }
@@ -178690,13 +162665,13 @@ ${lanes.join("\n")}
     }
     function checkForStatement(node) {
       if (!checkGrammarStatementInAmbientContext(node)) {
-        if (node.initializer && node.initializer.kind === 260 /* VariableDeclarationList */) {
+        if (node.initializer && node.initializer.kind === 261 /* VariableDeclarationList */) {
           checkGrammarVariableDeclarationList(node.initializer);
         }
       }
       if (node.initializer) {
-        if (node.initializer.kind === 260 /* VariableDeclarationList */) {
-          forEach(node.initializer.declarations, checkVariableDeclaration);
+        if (node.initializer.kind === 261 /* VariableDeclarationList */) {
+          checkVariableDeclarationList(node.initializer);
         } else {
           checkExpression(node.initializer);
         }
@@ -178715,7 +162690,7 @@ ${lanes.join("\n")}
       const container = getContainingFunctionOrClassStaticBlock(node);
       if (node.awaitModifier) {
         if (container && isClassStaticBlockDeclaration(container)) {
-          grammarErrorOnNode(node.awaitModifier, Diagnostics.For_await_loops_cannot_be_used_inside_a_class_static_block);
+          grammarErrorOnNode(node.awaitModifier, Diagnostics.for_await_loops_cannot_be_used_inside_a_class_static_block);
         } else {
           const functionFlags = getFunctionFlags(container);
           if ((functionFlags & (4 /* Invalid */ | 2 /* Async */)) === 2 /* Async */ && languageVersion < 99 /* ESNext */) {
@@ -178725,12 +162700,12 @@ ${lanes.join("\n")}
       } else if (compilerOptions.downlevelIteration && languageVersion < 2 /* ES2015 */) {
         checkExternalEmitHelpers(node, 256 /* ForOfIncludes */);
       }
-      if (node.initializer.kind === 260 /* VariableDeclarationList */) {
-        checkForInOrForOfVariableDeclaration(node);
+      if (node.initializer.kind === 261 /* VariableDeclarationList */) {
+        checkVariableDeclarationList(node.initializer);
       } else {
         const varExpr = node.initializer;
         const iteratedType = checkRightHandSideOfForOf(node);
-        if (varExpr.kind === 208 /* ArrayLiteralExpression */ || varExpr.kind === 209 /* ObjectLiteralExpression */) {
+        if (varExpr.kind === 209 /* ArrayLiteralExpression */ || varExpr.kind === 210 /* ObjectLiteralExpression */) {
           checkDestructuringAssignment(varExpr, iteratedType || errorType);
         } else {
           const leftType = checkExpression(varExpr);
@@ -178752,19 +162727,19 @@ ${lanes.join("\n")}
     function checkForInStatement(node) {
       checkGrammarForInOrForOfStatement(node);
       const rightType = getNonNullableTypeIfNeeded(checkExpression(node.expression));
-      if (node.initializer.kind === 260 /* VariableDeclarationList */) {
+      if (node.initializer.kind === 261 /* VariableDeclarationList */) {
         const variable = node.initializer.declarations[0];
         if (variable && isBindingPattern(variable.name)) {
-          error(variable.name, Diagnostics.The_left_hand_side_of_a_for_in_statement_cannot_be_a_destructuring_pattern);
+          error2(variable.name, Diagnostics.The_left_hand_side_of_a_for_in_statement_cannot_be_a_destructuring_pattern);
         }
-        checkForInOrForOfVariableDeclaration(node);
+        checkVariableDeclarationList(node.initializer);
       } else {
         const varExpr = node.initializer;
         const leftType = checkExpression(varExpr);
-        if (varExpr.kind === 208 /* ArrayLiteralExpression */ || varExpr.kind === 209 /* ObjectLiteralExpression */) {
-          error(varExpr, Diagnostics.The_left_hand_side_of_a_for_in_statement_cannot_be_a_destructuring_pattern);
+        if (varExpr.kind === 209 /* ArrayLiteralExpression */ || varExpr.kind === 210 /* ObjectLiteralExpression */) {
+          error2(varExpr, Diagnostics.The_left_hand_side_of_a_for_in_statement_cannot_be_a_destructuring_pattern);
         } else if (!isTypeAssignableTo(getIndexTypeOrString(rightType), leftType)) {
-          error(varExpr, Diagnostics.The_left_hand_side_of_a_for_in_statement_must_be_of_type_string_or_any);
+          error2(varExpr, Diagnostics.The_left_hand_side_of_a_for_in_statement_must_be_of_type_string_or_any);
         } else {
           checkReferenceExpression(
             varExpr,
@@ -178774,20 +162749,13 @@ ${lanes.join("\n")}
         }
       }
       if (rightType === neverType || !isTypeAssignableToKind(rightType, 67108864 /* NonPrimitive */ | 58982400 /* InstantiableNonPrimitive */)) {
-        error(node.expression, Diagnostics.The_right_hand_side_of_a_for_in_statement_must_be_of_type_any_an_object_type_or_a_type_parameter_but_here_has_type_0, typeToString(rightType));
+        error2(node.expression, Diagnostics.The_right_hand_side_of_a_for_in_statement_must_be_of_type_any_an_object_type_or_a_type_parameter_but_here_has_type_0, typeToString(rightType));
       }
       checkSourceElement(node.statement);
       if (node.locals) {
         registerForUnusedIdentifiersCheck(node);
       }
     }
-    function checkForInOrForOfVariableDeclaration(iterationStatement) {
-      const variableDeclarationList = iterationStatement.initializer;
-      if (variableDeclarationList.declarations.length >= 1) {
-        const decl = variableDeclarationList.declarations[0];
-        checkVariableDeclaration(decl);
-      }
-    }
     function checkRightHandSideOfForOf(statement) {
       const use = statement.awaitModifier ? 15 /* ForAwaitOf */ : 13 /* ForOf */;
       return checkIteratedTypeOrElementType(use, checkNonNullExpression(statement.expression), undefinedType, statement.expression);
@@ -178845,7 +162813,7 @@ ${lanes.join("\n")}
         if (hasStringConstituent) {
           if (languageVersion < 1 /* ES5 */) {
             if (errorNode) {
-              error(errorNode, Diagnostics.Using_a_string_in_a_for_of_statement_is_only_supported_in_ECMAScript_5_and_higher);
+              error2(errorNode, Diagnostics.Using_a_string_in_a_for_of_statement_is_only_supported_in_ECMAScript_5_and_higher);
               reportedError = true;
             }
           }
@@ -179163,13 +163131,10 @@ ${lanes.join("\n")}
         !!getAwaitedTypeOfPromise(type) || !allowAsyncIterables && isForOfStatement(errorNode.parent) && errorNode.parent.expression === errorNode && getGlobalAsyncIterableType(
           /*reportErrors*/
           false
-        ) !== emptyGenericType && isTypeAssignableTo(
-          type,
-          getGlobalAsyncIterableType(
-            /*reportErrors*/
-            false
-          )
-        )
+        ) !== emptyGenericType && isTypeAssignableTo(type, getGlobalAsyncIterableType(
+          /*reportErrors*/
+          false
+        ))
       );
       return errorAndMaybeSuggestAwait(errorNode, suggestAwait, message, typeToString(type));
     }
@@ -179305,7 +163270,7 @@ ${lanes.join("\n")}
             errorOutputContainer.errors ?? (errorOutputContainer.errors = []);
             errorOutputContainer.errors.push(createDiagnosticForNode(errorNode, diagnostic, methodName));
           } else {
-            error(errorNode, diagnostic, methodName);
+            error2(errorNode, diagnostic, methodName);
           }
         }
         return methodName === "next" ? noIterationTypes : void 0;
@@ -179360,7 +163325,7 @@ ${lanes.join("\n")}
             errorOutputContainer.errors ?? (errorOutputContainer.errors = []);
             errorOutputContainer.errors.push(createDiagnosticForNode(errorNode, resolver.mustHaveAValueDiagnostic, methodName));
           } else {
-            error(errorNode, resolver.mustHaveAValueDiagnostic, methodName);
+            error2(errorNode, resolver.mustHaveAValueDiagnostic, methodName);
           }
         }
         yieldType = anyType;
@@ -179444,13 +163409,13 @@ ${lanes.join("\n")}
       const functionFlags = getFunctionFlags(container);
       if (strictNullChecks || node.expression || returnType.flags & 131072 /* Never */) {
         const exprType = node.expression ? checkExpressionCached(node.expression) : undefinedType;
-        if (container.kind === 177 /* SetAccessor */) {
+        if (container.kind === 178 /* SetAccessor */) {
           if (node.expression) {
-            error(node, Diagnostics.Setters_cannot_return_a_value);
+            error2(node, Diagnostics.Setters_cannot_return_a_value);
           }
-        } else if (container.kind === 175 /* Constructor */) {
+        } else if (container.kind === 176 /* Constructor */) {
           if (node.expression && !checkTypeAssignableToAndOptionallyElaborate(exprType, returnType, node, node.expression)) {
-            error(node, Diagnostics.Return_type_of_constructor_signature_must_be_assignable_to_the_instance_type_of_the_class);
+            error2(node, Diagnostics.Return_type_of_constructor_signature_must_be_assignable_to_the_instance_type_of_the_class);
           }
         } else if (getReturnTypeFromAnnotation(container)) {
           const unwrappedReturnType = unwrapReturnType(returnType, functionFlags) ?? returnType;
@@ -179465,13 +163430,13 @@ ${lanes.join("\n")}
             checkTypeAssignableToAndOptionallyElaborate(unwrappedExprType, unwrappedReturnType, node, node.expression);
           }
         }
-      } else if (container.kind !== 175 /* Constructor */ && compilerOptions.noImplicitReturns && !isUnwrappedReturnTypeUndefinedVoidOrAny(container, returnType)) {
-        error(node, Diagnostics.Not_all_code_paths_return_a_value);
+      } else if (container.kind !== 176 /* Constructor */ && compilerOptions.noImplicitReturns && !isUnwrappedReturnTypeUndefinedVoidOrAny(container, returnType)) {
+        error2(node, Diagnostics.Not_all_code_paths_return_a_value);
       }
     }
     function checkWithStatement(node) {
       if (!checkGrammarStatementInAmbientContext(node)) {
-        if (node.flags & 32768 /* AwaitContext */) {
+        if (node.flags & 65536 /* AwaitContext */) {
           grammarErrorOnFirstToken(node, Diagnostics.with_statements_are_not_allowed_in_an_async_function_block);
         }
       }
@@ -179489,7 +163454,7 @@ ${lanes.join("\n")}
       let hasDuplicateDefaultClause = false;
       const expressionType = checkExpression(node.expression);
       forEach(node.caseBlock.clauses, (clause) => {
-        if (clause.kind === 296 /* DefaultClause */ && !hasDuplicateDefaultClause) {
+        if (clause.kind === 297 /* DefaultClause */ && !hasDuplicateDefaultClause) {
           if (firstDefaultClause === void 0) {
             firstDefaultClause = clause;
           } else {
@@ -179497,12 +163462,12 @@ ${lanes.join("\n")}
             hasDuplicateDefaultClause = true;
           }
         }
-        if (clause.kind === 295 /* CaseClause */) {
+        if (clause.kind === 296 /* CaseClause */) {
           addLazyDiagnostic(createLazyCaseClauseDiagnostics(clause));
         }
         forEach(clause.statements, checkSourceElement);
         if (compilerOptions.noFallthroughCasesInSwitch && clause.fallthroughFlowNode && isReachableFlowNode(clause.fallthroughFlowNode)) {
-          error(clause, Diagnostics.Fallthrough_case_in_switch);
+          error2(clause, Diagnostics.Fallthrough_case_in_switch);
         }
         function createLazyCaseClauseDiagnostics(clause2) {
           return () => {
@@ -179529,7 +163494,7 @@ ${lanes.join("\n")}
           if (isFunctionLike(current)) {
             return "quit";
           }
-          if (current.kind === 255 /* LabeledStatement */ && current.label.escapedText === node.label.escapedText) {
+          if (current.kind === 256 /* LabeledStatement */ && current.label.escapedText === node.label.escapedText) {
             grammarErrorOnNode(node.label, Diagnostics.Duplicate_label_0, getTextOfNode(node.label));
             return true;
           }
@@ -179619,21 +163584,14 @@ ${lanes.join("\n")}
         return;
       }
       const indexInfos = getApplicableIndexInfos(type, propNameType);
-      const interfaceDeclaration = getObjectFlags(type) & 2 /* Interface */ ? getDeclarationOfKind(type.symbol, 263 /* InterfaceDeclaration */) : void 0;
-      const propDeclaration = declaration && declaration.kind === 225 /* BinaryExpression */ || name && name.kind === 166 /* ComputedPropertyName */ ? declaration : void 0;
+      const interfaceDeclaration = getObjectFlags(type) & 2 /* Interface */ ? getDeclarationOfKind(type.symbol, 264 /* InterfaceDeclaration */) : void 0;
+      const propDeclaration = declaration && declaration.kind === 226 /* BinaryExpression */ || name && name.kind === 167 /* ComputedPropertyName */ ? declaration : void 0;
       const localPropDeclaration = getParentOfSymbol(prop) === type.symbol ? declaration : void 0;
       for (const info of indexInfos) {
         const localIndexDeclaration = info.declaration && getParentOfSymbol(getSymbolOfDeclaration(info.declaration)) === type.symbol ? info.declaration : void 0;
         const errorNode = localPropDeclaration || localIndexDeclaration || (interfaceDeclaration && !some(getBaseTypes(type), (base) => !!getPropertyOfObjectType(base, prop.escapedName) && !!getIndexTypeOfType(base, info.keyType)) ? interfaceDeclaration : void 0);
         if (errorNode && !isTypeAssignableTo(propType, info.type)) {
-          const diagnostic = createError(
-            errorNode,
-            Diagnostics.Property_0_of_type_1_is_not_assignable_to_2_index_type_3,
-            symbolToString(prop),
-            typeToString(propType),
-            typeToString(info.keyType),
-            typeToString(info.type)
-          );
+          const diagnostic = createError(errorNode, Diagnostics.Property_0_of_type_1_is_not_assignable_to_2_index_type_3, symbolToString(prop), typeToString(propType), typeToString(info.keyType), typeToString(info.type));
           if (propDeclaration && errorNode !== propDeclaration) {
             addRelatedInfo(diagnostic, createDiagnosticForNode(propDeclaration, Diagnostics._0_is_declared_here, symbolToString(prop)));
           }
@@ -179644,7 +163602,7 @@ ${lanes.join("\n")}
     function checkIndexConstraintForIndexSignature(type, checkInfo) {
       const declaration = checkInfo.declaration;
       const indexInfos = getApplicableIndexInfos(type, checkInfo.keyType);
-      const interfaceDeclaration = getObjectFlags(type) & 2 /* Interface */ ? getDeclarationOfKind(type.symbol, 263 /* InterfaceDeclaration */) : void 0;
+      const interfaceDeclaration = getObjectFlags(type) & 2 /* Interface */ ? getDeclarationOfKind(type.symbol, 264 /* InterfaceDeclaration */) : void 0;
       const localCheckDeclaration = declaration && getParentOfSymbol(getSymbolOfDeclaration(declaration)) === type.symbol ? declaration : void 0;
       for (const info of indexInfos) {
         if (info === checkInfo)
@@ -179652,14 +163610,7 @@ ${lanes.join("\n")}
         const localIndexDeclaration = info.declaration && getParentOfSymbol(getSymbolOfDeclaration(info.declaration)) === type.symbol ? info.declaration : void 0;
         const errorNode = localCheckDeclaration || localIndexDeclaration || (interfaceDeclaration && !some(getBaseTypes(type), (base) => !!getIndexInfoOfType(base, checkInfo.keyType) && !!getIndexTypeOfType(base, info.keyType)) ? interfaceDeclaration : void 0);
         if (errorNode && !isTypeAssignableTo(checkInfo.type, info.type)) {
-          error(
-            errorNode,
-            Diagnostics._0_index_type_1_is_not_assignable_to_2_index_type_3,
-            typeToString(checkInfo.keyType),
-            typeToString(checkInfo.type),
-            typeToString(info.keyType),
-            typeToString(info.type)
-          );
+          error2(errorNode, Diagnostics._0_index_type_1_is_not_assignable_to_2_index_type_3, typeToString(checkInfo.keyType), typeToString(checkInfo.type), typeToString(info.keyType), typeToString(info.type));
         }
       }
     }
@@ -179675,12 +163626,12 @@ ${lanes.join("\n")}
         case "symbol":
         case "void":
         case "object":
-          error(name, message, name.escapedText);
+          error2(name, message, name.escapedText);
       }
     }
     function checkClassNameCollisionWithObject(name) {
       if (languageVersion >= 1 /* ES5 */ && name.escapedText === "Object" && (moduleKind < 5 /* ES2015 */ || getSourceFileOfNode(name).impliedNodeFormat === 1 /* CommonJS */)) {
-        error(name, Diagnostics.Class_name_cannot_be_Object_when_targeting_ES5_with_module_0, ModuleKind[moduleKind]);
+        error2(name, Diagnostics.Class_name_cannot_be_Object_when_targeting_ES5_with_module_0, ModuleKind[moduleKind]);
       }
     }
     function checkUnmatchedJSDocParameters(node) {
@@ -179703,7 +163654,7 @@ ${lanes.join("\n")}
         const lastJSDocParamIndex = jsdocParameters.length - 1;
         const lastJSDocParam = jsdocParameters[lastJSDocParamIndex];
         if (isJs && lastJSDocParam && isIdentifier(lastJSDocParam.name) && lastJSDocParam.typeExpression && lastJSDocParam.typeExpression.type && !parameters.has(lastJSDocParam.name.escapedText) && !excludedParameters.has(lastJSDocParamIndex) && !isArrayType(getTypeFromTypeNode(lastJSDocParam.typeExpression.type))) {
-          error(lastJSDocParam.name, Diagnostics.JSDoc_param_tag_has_name_0_but_there_is_no_parameter_with_that_name_It_would_match_arguments_if_it_had_an_array_type, idText(lastJSDocParam.name));
+          error2(lastJSDocParam.name, Diagnostics.JSDoc_param_tag_has_name_0_but_there_is_no_parameter_with_that_name_It_would_match_arguments_if_it_had_an_array_type, idText(lastJSDocParam.name));
         }
       } else {
         forEach(jsdocParameters, ({ name, isNameFirst }, index) => {
@@ -179712,7 +163663,7 @@ ${lanes.join("\n")}
           }
           if (isQualifiedName(name)) {
             if (isJs) {
-              error(name, Diagnostics.Qualified_name_0_is_not_allowed_without_a_leading_param_object_1, entityNameToString(name), entityNameToString(name.left));
+              error2(name, Diagnostics.Qualified_name_0_is_not_allowed_without_a_leading_param_object_1, entityNameToString(name), entityNameToString(name.left));
             }
           } else {
             if (!isNameFirst) {
@@ -179737,11 +163688,11 @@ ${lanes.join("\n")}
             seenDefault = true;
             checkTypeParametersNotReferenced(node.default, typeParameterDeclarations, i);
           } else if (seenDefault) {
-            error(node, Diagnostics.Required_type_parameters_may_not_follow_optional_type_parameters);
+            error2(node, Diagnostics.Required_type_parameters_may_not_follow_optional_type_parameters);
           }
           for (let j = 0; j < i; j++) {
             if (typeParameterDeclarations[j].symbol === node.symbol) {
-              error(node.name, Diagnostics.Duplicate_identifier_0, declarationNameToString(node.name));
+              error2(node.name, Diagnostics.Duplicate_identifier_0, declarationNameToString(node.name));
             }
           }
         };
@@ -179750,12 +163701,12 @@ ${lanes.join("\n")}
     function checkTypeParametersNotReferenced(root, typeParameters, index) {
       visit(root);
       function visit(node) {
-        if (node.kind === 182 /* TypeReference */) {
+        if (node.kind === 183 /* TypeReference */) {
           const type = getTypeFromTypeReference(node);
           if (type.flags & 262144 /* TypeParameter */) {
             for (let i = index; i < typeParameters.length; i++) {
               if (type.symbol === getSymbolOfDeclaration(typeParameters[i])) {
-                error(node, Diagnostics.Type_parameter_defaults_can_only_reference_previously_declared_type_parameters);
+                error2(node, Diagnostics.Type_parameter_defaults_can_only_reference_previously_declared_type_parameters);
               }
             }
           }
@@ -179778,7 +163729,7 @@ ${lanes.join("\n")}
         if (!areTypeParametersIdentical(declarations, type.localTypeParameters, getEffectiveTypeParameterDeclarations)) {
           const name = symbolToString(symbol);
           for (const declaration of declarations) {
-            error(declaration.name, Diagnostics.All_declarations_of_0_must_have_identical_type_parameters, name);
+            error2(declaration.name, Diagnostics.All_declarations_of_0_must_have_identical_type_parameters, name);
           }
         }
       }
@@ -179820,7 +163771,7 @@ ${lanes.join("\n")}
         node
       );
       const willTransformPrivateElementsOrClassStaticBlocks = languageVersion <= 9 /* ES2022 */;
-      const willTransformInitializers = !useDefineForClassFields || languageVersion < 9 /* ES2022 */;
+      const willTransformInitializers = !emitStandardClassFields;
       if (willTransformStaticElementsOfDecoratedClass || willTransformPrivateElementsOrClassStaticBlocks) {
         for (const member of node.members) {
           if (willTransformStaticElementsOfDecoratedClass && classElementOrClassElementParameterIsDecorated(
@@ -179881,7 +163832,7 @@ ${lanes.join("\n")}
       if (legacyDecorators && firstDecorator && some(node.members, (p) => hasStaticModifier(p) && isPrivateIdentifierClassElementDeclaration(p))) {
         grammarErrorOnNode(firstDecorator, Diagnostics.Class_decorators_can_t_be_used_with_static_private_identifier_Consider_removing_the_experimental_decorator);
       }
-      if (!node.name && !hasSyntacticModifier(node, 1024 /* Default */)) {
+      if (!node.name && !hasSyntacticModifier(node, 2048 /* Default */)) {
         grammarErrorOnFirstToken(node, Diagnostics.A_class_declaration_without_the_default_modifier_must_have_a_name);
       }
       checkClassLikeDeclaration(node);
@@ -179901,7 +163852,7 @@ ${lanes.join("\n")}
       checkTypeParameterListsIdentical(symbol);
       checkFunctionOrConstructorSymbol(symbol);
       checkClassForDuplicateDeclarations(node);
-      const nodeInAmbientContext = !!(node.flags & 16777216 /* Ambient */);
+      const nodeInAmbientContext = !!(node.flags & 33554432 /* Ambient */);
       if (!nodeInAmbientContext) {
         checkClassForStaticPropertyNameConflicts(node);
       }
@@ -179940,27 +163891,22 @@ ${lanes.join("\n")}
             )) {
               issueMemberSpecificError(node, typeWithThis, baseWithThis, Diagnostics.Class_0_incorrectly_extends_base_class_1);
             } else {
-              checkTypeAssignableTo(
-                staticType,
-                getTypeWithoutSignatures(staticBaseType),
-                node.name || node,
-                Diagnostics.Class_static_side_0_incorrectly_extends_base_class_static_side_1
-              );
+              checkTypeAssignableTo(staticType, getTypeWithoutSignatures(staticBaseType), node.name || node, Diagnostics.Class_static_side_0_incorrectly_extends_base_class_static_side_1);
             }
             if (baseConstructorType.flags & 8650752 /* TypeVariable */) {
               if (!isMixinConstructorType(staticType)) {
-                error(node.name || node, Diagnostics.A_mixin_class_must_have_a_constructor_with_a_single_rest_parameter_of_type_any);
+                error2(node.name || node, Diagnostics.A_mixin_class_must_have_a_constructor_with_a_single_rest_parameter_of_type_any);
               } else {
                 const constructSignatures = getSignaturesOfType(baseConstructorType, 1 /* Construct */);
-                if (constructSignatures.some((signature) => signature.flags & 4 /* Abstract */) && !hasSyntacticModifier(node, 256 /* Abstract */)) {
-                  error(node.name || node, Diagnostics.A_mixin_class_that_extends_from_a_type_variable_containing_an_abstract_construct_signature_must_also_be_declared_abstract);
+                if (constructSignatures.some((signature) => signature.flags & 4 /* Abstract */) && !hasSyntacticModifier(node, 64 /* Abstract */)) {
+                  error2(node.name || node, Diagnostics.A_mixin_class_that_extends_from_a_type_variable_containing_an_abstract_construct_signature_must_also_be_declared_abstract);
                 }
               }
             }
             if (!(staticBaseType.symbol && staticBaseType.symbol.flags & 32 /* Class */) && !(baseConstructorType.flags & 8650752 /* TypeVariable */)) {
               const constructors = getInstantiatedConstructorsForTypeArguments(staticBaseType, baseTypeNode.typeArguments, baseTypeNode);
               if (forEach(constructors, (sig) => !isJSConstructor(sig.declaration) && !isTypeIdenticalTo(getReturnTypeOfSignature(sig), baseType))) {
-                error(baseTypeNode.expression, Diagnostics.Base_constructors_must_all_have_the_same_return_type);
+                error2(baseTypeNode.expression, Diagnostics.Base_constructors_must_all_have_the_same_return_type);
               }
             }
             checkKindsOfPropertyMemberOverrides(type, baseType);
@@ -179972,7 +163918,7 @@ ${lanes.join("\n")}
       if (implementedTypeNodes) {
         for (const typeRefNode of implementedTypeNodes) {
           if (!isEntityNameExpression(typeRefNode.expression) || isOptionalChain(typeRefNode.expression)) {
-            error(typeRefNode.expression, Diagnostics.A_class_can_only_implement_an_identifier_Slashqualified_name_with_optional_type_arguments);
+            error2(typeRefNode.expression, Diagnostics.A_class_can_only_implement_an_identifier_Slashqualified_name_with_optional_type_arguments);
           }
           checkTypeReferenceNode(typeRefNode);
           addLazyDiagnostic(createImplementsDiagnostics(typeRefNode));
@@ -180005,7 +163951,7 @@ ${lanes.join("\n")}
                 issueMemberSpecificError(node, typeWithThis, baseWithThis, genericDiag);
               }
             } else {
-              error(typeRefNode, Diagnostics.A_class_can_only_implement_an_object_type_or_intersection_of_object_types_with_statically_known_members);
+              error2(typeRefNode, Diagnostics.A_class_can_only_implement_an_object_type_or_intersection_of_object_types_with_statically_known_members);
             }
           }
         };
@@ -180072,7 +164018,7 @@ ${lanes.join("\n")}
     }
     function checkMemberForOverrideModifier(node, staticType, baseStaticType, baseWithThis, type, typeWithThis, memberHasOverrideModifier, memberHasAbstractModifier, memberIsStatic, memberIsParameterProperty, memberName, errorNode) {
       const isJs = isInJSFile(node);
-      const nodeInAmbientContext = !!(node.flags & 16777216 /* Ambient */);
+      const nodeInAmbientContext = !!(node.flags & 33554432 /* Ambient */);
       if (baseWithThis && (memberHasOverrideModifier || compilerOptions.noImplicitOverride)) {
         const memberEscapedName = escapeLeadingUnderscores(memberName);
         const thisType = memberIsStatic ? staticType : typeWithThis;
@@ -180083,12 +164029,12 @@ ${lanes.join("\n")}
         if (prop && !baseProp && memberHasOverrideModifier) {
           if (errorNode) {
             const suggestion = getSuggestedSymbolForNonexistentClassMember(memberName, baseType);
-            suggestion ? error(
+            suggestion ? error2(
               errorNode,
               isJs ? Diagnostics.This_member_cannot_have_a_JSDoc_comment_with_an_override_tag_because_it_is_not_declared_in_the_base_class_0_Did_you_mean_1 : Diagnostics.This_member_cannot_have_an_override_modifier_because_it_is_not_declared_in_the_base_class_0_Did_you_mean_1,
               baseClassName,
               symbolToString(suggestion)
-            ) : error(
+            ) : error2(
               errorNode,
               isJs ? Diagnostics.This_member_cannot_have_a_JSDoc_comment_with_an_override_tag_because_it_is_not_declared_in_the_base_class_0 : Diagnostics.This_member_cannot_have_an_override_modifier_because_it_is_not_declared_in_the_base_class_0,
               baseClassName
@@ -180103,12 +164049,12 @@ ${lanes.join("\n")}
           if (!baseHasAbstract) {
             if (errorNode) {
               const diag2 = memberIsParameterProperty ? isJs ? Diagnostics.This_parameter_property_must_have_a_JSDoc_comment_with_an_override_tag_because_it_overrides_a_member_in_the_base_class_0 : Diagnostics.This_parameter_property_must_have_an_override_modifier_because_it_overrides_a_member_in_base_class_0 : isJs ? Diagnostics.This_member_must_have_a_JSDoc_comment_with_an_override_tag_because_it_overrides_a_member_in_the_base_class_0 : Diagnostics.This_member_must_have_an_override_modifier_because_it_overrides_a_member_in_the_base_class_0;
-              error(errorNode, diag2, baseClassName);
+              error2(errorNode, diag2, baseClassName);
             }
             return 1 /* NeedsOverride */;
           } else if (memberHasAbstractModifier && baseHasAbstract) {
             if (errorNode) {
-              error(errorNode, Diagnostics.This_member_must_have_an_override_modifier_because_it_overrides_an_abstract_method_that_is_declared_in_the_base_class_0, baseClassName);
+              error2(errorNode, Diagnostics.This_member_must_have_an_override_modifier_because_it_overrides_an_abstract_method_that_is_declared_in_the_base_class_0, baseClassName);
             }
             return 1 /* NeedsOverride */;
           }
@@ -180116,7 +164062,7 @@ ${lanes.join("\n")}
       } else if (memberHasOverrideModifier) {
         if (errorNode) {
           const className = typeToString(type);
-          error(
+          error2(
             errorNode,
             isJs ? Diagnostics.This_member_cannot_have_a_JSDoc_comment_with_an_override_tag_because_its_containing_class_0_does_not_extend_another_class : Diagnostics.This_member_cannot_have_an_override_modifier_because_its_containing_class_0_does_not_extend_another_class,
             className
@@ -180166,10 +164112,10 @@ ${lanes.join("\n")}
       const signatures = getSignaturesOfType(type, 1 /* Construct */);
       if (signatures.length) {
         const declaration = signatures[0].declaration;
-        if (declaration && hasEffectiveModifier(declaration, 8 /* Private */)) {
+        if (declaration && hasEffectiveModifier(declaration, 2 /* Private */)) {
           const typeClassDeclaration = getClassLikeDeclarationOfSymbol(type.symbol);
           if (!isNodeWithinClass(node, typeClassDeclaration)) {
-            error(node, Diagnostics.Cannot_extend_a_class_0_Class_constructor_is_marked_as_private, getFullyQualifiedName(type.symbol));
+            error2(node, Diagnostics.Cannot_extend_a_class_0_Class_constructor_is_marked_as_private, getFullyQualifiedName(type.symbol));
           }
         }
       }
@@ -180186,7 +164132,7 @@ ${lanes.join("\n")}
       const baseTypes = baseTypeNode && getBaseTypes(type);
       const baseWithThis = (baseTypes == null ? void 0 : baseTypes.length) ? getTypeWithThisArgument(first(baseTypes), type.thisType) : void 0;
       const baseStaticType = getBaseConstructorTypeOfClass(type);
-      const memberHasOverrideModifier = member.parent ? hasOverrideModifier(member) : hasSyntacticModifier(member, 16384 /* Override */);
+      const memberHasOverrideModifier = member.parent ? hasOverrideModifier(member) : hasSyntacticModifier(member, 16 /* Override */);
       return checkMemberForOverrideModifier(
         node,
         staticType,
@@ -180206,7 +164152,7 @@ ${lanes.join("\n")}
       return getCheckFlags(s) & 1 /* Instantiated */ ? s.links.target : s;
     }
     function getClassOrInterfaceDeclarationsOfSymbol(symbol) {
-      return filter(symbol.declarations, (d) => d.kind === 262 /* ClassDeclaration */ || d.kind === 263 /* InterfaceDeclaration */);
+      return filter(symbol.declarations, (d) => d.kind === 263 /* ClassDeclaration */ || d.kind === 264 /* InterfaceDeclaration */);
     }
     function checkKindsOfPropertyMemberOverrides(type, baseType) {
       var _a, _b, _c, _d;
@@ -180227,7 +164173,7 @@ ${lanes.join("\n")}
           Debug.assert(!!derived, "derived should point to something, even if it is the base class' declaration.");
           if (derived === base) {
             const derivedClassDecl = getClassLikeDeclarationOfSymbol(type.symbol);
-            if (baseDeclarationFlags & 256 /* Abstract */ && (!derivedClassDecl || !hasSyntacticModifier(derivedClassDecl, 256 /* Abstract */))) {
+            if (baseDeclarationFlags & 64 /* Abstract */ && (!derivedClassDecl || !hasSyntacticModifier(derivedClassDecl, 64 /* Abstract */))) {
               for (const otherBaseType of getBaseTypes(type)) {
                 if (otherBaseType === baseType)
                   continue;
@@ -180238,14 +164184,14 @@ ${lanes.join("\n")}
                 }
               }
               if (!inheritedAbstractMemberNotImplementedError) {
-                inheritedAbstractMemberNotImplementedError = error(
+                inheritedAbstractMemberNotImplementedError = error2(
                   derivedClassDecl,
                   Diagnostics.Non_abstract_class_0_does_not_implement_all_abstract_members_of_1,
                   typeToString(type),
                   typeToString(baseType)
                 );
               }
-              if (derivedClassDecl.kind === 230 /* ClassExpression */) {
+              if (derivedClassDecl.kind === 231 /* ClassExpression */) {
                 addRelatedInfo(
                   inheritedAbstractMemberNotImplementedError,
                   createDiagnosticForNode(
@@ -180270,7 +164216,7 @@ ${lanes.join("\n")}
             }
           } else {
             const derivedDeclarationFlags = getDeclarationModifierFlagsFromSymbol(derived);
-            if (baseDeclarationFlags & 8 /* Private */ || derivedDeclarationFlags & 8 /* Private */) {
+            if (baseDeclarationFlags & 2 /* Private */ || derivedDeclarationFlags & 2 /* Private */) {
               continue;
             }
             let errorMessage;
@@ -180284,15 +164230,15 @@ ${lanes.join("\n")}
               const overriddenInstanceAccessor = basePropertyFlags === 4 /* Property */ && derivedPropertyFlags !== 4 /* Property */;
               if (overriddenInstanceProperty || overriddenInstanceAccessor) {
                 const errorMessage2 = overriddenInstanceProperty ? Diagnostics._0_is_defined_as_an_accessor_in_class_1_but_is_overridden_here_in_2_as_an_instance_property : Diagnostics._0_is_defined_as_a_property_in_class_1_but_is_overridden_here_in_2_as_an_accessor;
-                error(getNameOfDeclaration(derived.valueDeclaration) || derived.valueDeclaration, errorMessage2, symbolToString(base), typeToString(baseType), typeToString(type));
+                error2(getNameOfDeclaration(derived.valueDeclaration) || derived.valueDeclaration, errorMessage2, symbolToString(base), typeToString(baseType), typeToString(type));
               } else if (useDefineForClassFields) {
-                const uninitialized = (_c = derived.declarations) == null ? void 0 : _c.find((d) => d.kind === 171 /* PropertyDeclaration */ && !d.initializer);
-                if (uninitialized && !(derived.flags & 33554432 /* Transient */) && !(baseDeclarationFlags & 256 /* Abstract */) && !(derivedDeclarationFlags & 256 /* Abstract */) && !((_d = derived.declarations) == null ? void 0 : _d.some((d) => !!(d.flags & 16777216 /* Ambient */)))) {
+                const uninitialized = (_c = derived.declarations) == null ? void 0 : _c.find((d) => d.kind === 172 /* PropertyDeclaration */ && !d.initializer);
+                if (uninitialized && !(derived.flags & 33554432 /* Transient */) && !(baseDeclarationFlags & 64 /* Abstract */) && !(derivedDeclarationFlags & 64 /* Abstract */) && !((_d = derived.declarations) == null ? void 0 : _d.some((d) => !!(d.flags & 33554432 /* Ambient */)))) {
                   const constructor = findConstructorDeclaration(getClassLikeDeclarationOfSymbol(type.symbol));
                   const propName = uninitialized.name;
                   if (uninitialized.exclamationToken || !constructor || !isIdentifier(propName) || !strictNullChecks || !isPropertyInitializedInConstructor(propName, type, constructor)) {
                     const errorMessage2 = Diagnostics.Property_0_will_overwrite_the_base_property_in_1_If_this_is_intentional_add_an_initializer_Otherwise_add_a_declare_modifier_or_remove_the_redundant_declaration;
-                    error(getNameOfDeclaration(derived.valueDeclaration) || derived.valueDeclaration, errorMessage2, symbolToString(base), typeToString(baseType));
+                    error2(getNameOfDeclaration(derived.valueDeclaration) || derived.valueDeclaration, errorMessage2, symbolToString(base), typeToString(baseType));
                   }
                 }
               }
@@ -180309,12 +164255,12 @@ ${lanes.join("\n")}
             } else {
               errorMessage = Diagnostics.Class_0_defines_instance_member_property_1_but_extended_class_2_defines_it_as_instance_member_function;
             }
-            error(getNameOfDeclaration(derived.valueDeclaration) || derived.valueDeclaration, errorMessage, typeToString(baseType), symbolToString(base), typeToString(type));
+            error2(getNameOfDeclaration(derived.valueDeclaration) || derived.valueDeclaration, errorMessage, typeToString(baseType), symbolToString(base), typeToString(type));
           }
         }
     }
     function isPropertyAbstractOrInterface(declaration, baseDeclarationFlags) {
-      return baseDeclarationFlags & 256 /* Abstract */ && (!isPropertyDeclaration(declaration) || !declaration.initializer) || isInterfaceDeclaration(declaration.parent);
+      return baseDeclarationFlags & 64 /* Abstract */ && (!isPropertyDeclaration(declaration) || !declaration.initializer) || isInterfaceDeclaration(declaration.parent);
     }
     function getNonInheritedProperties(type, baseTypes, properties) {
       if (!length(baseTypes)) {
@@ -180374,12 +164320,12 @@ ${lanes.join("\n")}
       return ok;
     }
     function checkPropertyInitialization(node) {
-      if (!strictNullChecks || !strictPropertyInitialization || node.flags & 16777216 /* Ambient */) {
+      if (!strictNullChecks || !strictPropertyInitialization || node.flags & 33554432 /* Ambient */) {
         return;
       }
       const constructor = findConstructorDeclaration(node);
       for (const member of node.members) {
-        if (getEffectiveModifierFlags(member) & 2 /* Ambient */) {
+        if (getEffectiveModifierFlags(member) & 128 /* Ambient */) {
           continue;
         }
         if (!isStatic(member) && isPropertyWithoutInitializer(member)) {
@@ -180388,7 +164334,7 @@ ${lanes.join("\n")}
             const type = getTypeOfSymbol(getSymbolOfDeclaration(member));
             if (!(type.flags & 3 /* AnyOrUnknown */ || containsUndefinedType(type))) {
               if (!constructor || !isPropertyInitializedInConstructor(propName, type, constructor)) {
-                error(member.name, Diagnostics.Property_0_has_no_initializer_and_is_not_definitely_assigned_in_the_constructor, declarationNameToString(propName));
+                error2(member.name, Diagnostics.Property_0_has_no_initializer_and_is_not_definitely_assigned_in_the_constructor, declarationNameToString(propName));
               }
             }
           }
@@ -180396,7 +164342,7 @@ ${lanes.join("\n")}
       }
     }
     function isPropertyWithoutInitializer(node) {
-      return node.kind === 171 /* PropertyDeclaration */ && !hasAbstractModifier(node) && !node.exclamationToken && !node.initializer;
+      return node.kind === 172 /* PropertyDeclaration */ && !hasAbstractModifier(node) && !node.exclamationToken && !node.initializer;
     }
     function isPropertyInitializedInStaticBlocks(propName, propType, staticBlocks, startPos, endPos) {
       for (const staticBlock of staticBlocks) {
@@ -180430,7 +164376,7 @@ ${lanes.join("\n")}
         checkExportsOnMergedDeclarations(node);
         const symbol = getSymbolOfDeclaration(node);
         checkTypeParameterListsIdentical(symbol);
-        const firstInterfaceDecl = getDeclarationOfKind(symbol, 263 /* InterfaceDeclaration */);
+        const firstInterfaceDecl = getDeclarationOfKind(symbol, 264 /* InterfaceDeclaration */);
         if (node === firstInterfaceDecl) {
           const type = getDeclaredTypeOfSymbol(symbol);
           const typeWithThis = getTypeWithThisArgument(type);
@@ -180445,7 +164391,7 @@ ${lanes.join("\n")}
       });
       forEach(getInterfaceBaseTypeNodes(node), (heritageElement) => {
         if (!isEntityNameExpression(heritageElement.expression) || isOptionalChain(heritageElement.expression)) {
-          error(heritageElement.expression, Diagnostics.An_interface_can_only_extend_an_identifier_Slashqualified_name_with_optional_type_arguments);
+          error2(heritageElement.expression, Diagnostics.An_interface_can_only_extend_an_identifier_Slashqualified_name_with_optional_type_arguments);
         }
         checkTypeReferenceNode(heritageElement);
       });
@@ -180462,7 +164408,7 @@ ${lanes.join("\n")}
       checkTypeParameters(node.typeParameters);
       if (node.type.kind === 141 /* IntrinsicKeyword */) {
         if (!intrinsicTypeKinds.has(node.name.escapedText) || length(node.typeParameters) !== 1) {
-          error(node.type, Diagnostics.The_intrinsic_keyword_can_only_be_used_to_declare_compiler_provided_intrinsic_types);
+          error2(node.type, Diagnostics.The_intrinsic_keyword_can_only_be_used_to_declare_compiler_provided_intrinsic_types);
         }
       } else {
         checkSourceElement(node.type);
@@ -180483,23 +164429,23 @@ ${lanes.join("\n")}
     }
     function computeMemberValue(member, autoValue) {
       if (isComputedNonLiteralName(member.name)) {
-        error(member.name, Diagnostics.Computed_property_names_are_not_allowed_in_enums);
+        error2(member.name, Diagnostics.Computed_property_names_are_not_allowed_in_enums);
       } else {
         const text = getTextOfPropertyName(member.name);
         if (isNumericLiteralName(text) && !isInfinityOrNaNString(text)) {
-          error(member.name, Diagnostics.An_enum_member_cannot_have_a_numeric_name);
+          error2(member.name, Diagnostics.An_enum_member_cannot_have_a_numeric_name);
         }
       }
       if (member.initializer) {
         return computeConstantValue(member);
       }
-      if (member.parent.flags & 16777216 /* Ambient */ && !isEnumConst(member.parent)) {
+      if (member.parent.flags & 33554432 /* Ambient */ && !isEnumConst(member.parent)) {
         return void 0;
       }
       if (autoValue !== void 0) {
         return autoValue;
       }
-      error(member.name, Diagnostics.Enum_member_must_have_initializer);
+      error2(member.name, Diagnostics.Enum_member_must_have_initializer);
       return void 0;
     }
     function computeConstantValue(member) {
@@ -180508,12 +164454,15 @@ ${lanes.join("\n")}
       const value = evaluate(initializer, member);
       if (value !== void 0) {
         if (isConstEnum && typeof value === "number" && !isFinite(value)) {
-          error(initializer, isNaN(value) ? Diagnostics.const_enum_member_initializer_was_evaluated_to_disallowed_value_NaN : Diagnostics.const_enum_member_initializer_was_evaluated_to_a_non_finite_value);
+          error2(
+            initializer,
+            isNaN(value) ? Diagnostics.const_enum_member_initializer_was_evaluated_to_disallowed_value_NaN : Diagnostics.const_enum_member_initializer_was_evaluated_to_a_non_finite_value
+          );
         }
       } else if (isConstEnum) {
-        error(initializer, Diagnostics.const_enum_member_initializers_must_be_constant_expressions);
-      } else if (member.parent.flags & 16777216 /* Ambient */) {
-        error(initializer, Diagnostics.In_ambient_enum_declarations_member_initializer_must_be_constant_expression);
+        error2(initializer, Diagnostics.const_enum_member_initializers_must_be_constant_expressions);
+      } else if (member.parent.flags & 33554432 /* Ambient */) {
+        error2(initializer, Diagnostics.In_ambient_enum_declarations_member_initializer_must_be_constant_expression);
       } else {
         checkTypeAssignableTo(checkExpression(initializer), numberType, initializer, Diagnostics.Type_0_is_not_assignable_to_type_1_as_required_for_computed_enum_member_values);
       }
@@ -180521,7 +164470,7 @@ ${lanes.join("\n")}
     }
     function evaluate(expr, location) {
       switch (expr.kind) {
-        case 223 /* PrefixUnaryExpression */:
+        case 224 /* PrefixUnaryExpression */:
           const value = evaluate(expr.operand, location);
           if (typeof value === "number") {
             switch (expr.operator) {
@@ -180534,7 +164483,7 @@ ${lanes.join("\n")}
             }
           }
           break;
-        case 225 /* BinaryExpression */:
+        case 226 /* BinaryExpression */:
           const left = evaluate(expr.left, location);
           const right = evaluate(expr.right, location);
           if (typeof left === "number" && typeof right === "number") {
@@ -180571,18 +164520,30 @@ ${lanes.join("\n")}
         case 11 /* StringLiteral */:
         case 15 /* NoSubstitutionTemplateLiteral */:
           return expr.text;
-        case 227 /* TemplateExpression */:
+        case 228 /* TemplateExpression */:
           return evaluateTemplateExpression(expr, location);
         case 9 /* NumericLiteral */:
           checkGrammarNumericLiteral(expr);
           return +expr.text;
-        case 216 /* ParenthesizedExpression */:
+        case 217 /* ParenthesizedExpression */:
           return evaluate(expr.expression, location);
-        case 80 /* Identifier */:
-          if (isInfinityOrNaNString(expr.escapedText)) {
-            return +expr.escapedText;
+        case 80 /* Identifier */: {
+          const identifier = expr;
+          if (isInfinityOrNaNString(identifier.escapedText) && resolveEntityName(
+            identifier,
+            111551 /* Value */,
+            /*ignoreErrors*/
+            true
+          ) === getGlobalSymbol(
+            identifier.escapedText,
+            111551 /* Value */,
+            /*diagnostic*/
+            void 0
+          )) {
+            return +identifier.escapedText;
           }
-        case 210 /* PropertyAccessExpression */:
+        }
+        case 211 /* PropertyAccessExpression */:
           if (isEntityNameExpression(expr)) {
             const symbol = resolveEntityName(
               expr,
@@ -180592,18 +164553,18 @@ ${lanes.join("\n")}
             );
             if (symbol) {
               if (symbol.flags & 8 /* EnumMember */) {
-                return evaluateEnumMember(expr, symbol, location);
+                return location ? evaluateEnumMember(expr, symbol, location) : getEnumMemberValue(symbol.valueDeclaration);
               }
-              if (isConstVariable(symbol)) {
+              if (isConstantVariable(symbol)) {
                 const declaration = symbol.valueDeclaration;
-                if (declaration && !declaration.type && declaration.initializer && declaration !== location && isBlockScopedNameDeclaredBeforeUse(declaration, location)) {
+                if (declaration && isVariableDeclaration(declaration) && !declaration.type && declaration.initializer && (!location || declaration !== location && isBlockScopedNameDeclaredBeforeUse(declaration, location))) {
                   return evaluate(declaration.initializer, declaration);
                 }
               }
             }
           }
           break;
-        case 211 /* ElementAccessExpression */:
+        case 212 /* ElementAccessExpression */:
           const root = expr.expression;
           if (isEntityNameExpression(root) && isStringLiteralLike(expr.argumentExpression)) {
             const rootSymbol = resolveEntityName(
@@ -180616,7 +164577,7 @@ ${lanes.join("\n")}
               const name = escapeLeadingUnderscores(expr.argumentExpression.text);
               const member = rootSymbol.exports.get(name);
               if (member) {
-                return evaluateEnumMember(expr, member, location);
+                return location ? evaluateEnumMember(expr, member, location) : getEnumMemberValue(member.valueDeclaration);
               }
             }
           }
@@ -180627,11 +164588,11 @@ ${lanes.join("\n")}
     function evaluateEnumMember(expr, symbol, location) {
       const declaration = symbol.valueDeclaration;
       if (!declaration || declaration === location) {
-        error(expr, Diagnostics.Property_0_is_used_before_being_assigned, symbolToString(symbol));
+        error2(expr, Diagnostics.Property_0_is_used_before_being_assigned, symbolToString(symbol));
         return void 0;
       }
       if (!isBlockScopedNameDeclaredBeforeUse(declaration, location)) {
-        error(expr, Diagnostics.A_member_initializer_in_a_enum_declaration_cannot_reference_members_declared_after_it_including_members_defined_in_other_enums);
+        error2(expr, Diagnostics.A_member_initializer_in_a_enum_declaration_cannot_reference_members_declared_after_it_including_members_defined_in_other_enums);
         return 0;
       }
       return getEnumMemberValue(declaration);
@@ -180664,13 +164625,13 @@ ${lanes.join("\n")}
           const enumIsConst = isEnumConst(node);
           forEach(enumSymbol.declarations, (decl) => {
             if (isEnumDeclaration(decl) && isEnumConst(decl) !== enumIsConst) {
-              error(getNameOfDeclaration(decl), Diagnostics.Enum_declarations_must_all_be_const_or_non_const);
+              error2(getNameOfDeclaration(decl), Diagnostics.Enum_declarations_must_all_be_const_or_non_const);
             }
           });
         }
         let seenEnumMissingInitialInitializer = false;
         forEach(enumSymbol.declarations, (declaration) => {
-          if (declaration.kind !== 265 /* EnumDeclaration */) {
+          if (declaration.kind !== 266 /* EnumDeclaration */) {
             return false;
           }
           const enumDeclaration = declaration;
@@ -180680,7 +164641,7 @@ ${lanes.join("\n")}
           const firstEnumMember = enumDeclaration.members[0];
           if (!firstEnumMember.initializer) {
             if (seenEnumMissingInitialInitializer) {
-              error(firstEnumMember.name, Diagnostics.In_an_enum_with_multiple_declarations_only_one_declaration_can_omit_an_initializer_for_its_first_enum_element);
+              error2(firstEnumMember.name, Diagnostics.In_an_enum_with_multiple_declarations_only_one_declaration_can_omit_an_initializer_for_its_first_enum_element);
             } else {
               seenEnumMissingInitialInitializer = true;
             }
@@ -180690,7 +164651,7 @@ ${lanes.join("\n")}
     }
     function checkEnumMember(node) {
       if (isPrivateIdentifier(node.name)) {
-        error(node, Diagnostics.An_enum_member_cannot_be_named_with_a_private_identifier);
+        error2(node, Diagnostics.An_enum_member_cannot_be_named_with_a_private_identifier);
       }
       if (node.initializer) {
         checkExpression(node.initializer);
@@ -180700,7 +164661,7 @@ ${lanes.join("\n")}
       const declarations = symbol.declarations;
       if (declarations) {
         for (const declaration of declarations) {
-          if ((declaration.kind === 262 /* ClassDeclaration */ || declaration.kind === 261 /* FunctionDeclaration */ && nodeIsPresent(declaration.body)) && !(declaration.flags & 16777216 /* Ambient */)) {
+          if ((declaration.kind === 263 /* ClassDeclaration */ || declaration.kind === 262 /* FunctionDeclaration */ && nodeIsPresent(declaration.body)) && !(declaration.flags & 33554432 /* Ambient */)) {
             return declaration;
           }
         }
@@ -180729,9 +164690,9 @@ ${lanes.join("\n")}
       function checkModuleDeclarationDiagnostics() {
         var _a, _b;
         const isGlobalAugmentation = isGlobalScopeAugmentation(node);
-        const inAmbientContext = node.flags & 16777216 /* Ambient */;
+        const inAmbientContext = node.flags & 33554432 /* Ambient */;
         if (isGlobalAugmentation && !inAmbientContext) {
-          error(node.name, Diagnostics.Augmentations_for_the_global_scope_should_have_declare_modifier_unless_they_appear_in_already_ambient_context);
+          error2(node.name, Diagnostics.Augmentations_for_the_global_scope_should_have_declare_modifier_unless_they_appear_in_already_ambient_context);
         }
         const isAmbientExternalModule = isAmbientModule(node);
         const contextErrorMessage = isAmbientExternalModule ? Diagnostics.An_ambient_module_declaration_is_only_allowed_at_the_top_level_in_a_file : Diagnostics.A_namespace_declaration_is_only_allowed_at_the_top_level_of_a_namespace_or_module;
@@ -180750,26 +164711,26 @@ ${lanes.join("\n")}
         const symbol = getSymbolOfDeclaration(node);
         if (symbol.flags & 512 /* ValueModule */ && !inAmbientContext && isInstantiatedModule(node, shouldPreserveConstEnums(compilerOptions))) {
           if (getIsolatedModules(compilerOptions) && !getSourceFileOfNode(node).externalModuleIndicator) {
-            error(node.name, Diagnostics.Namespaces_are_not_allowed_in_global_script_files_when_0_is_enabled_If_this_file_is_not_intended_to_be_a_global_script_set_moduleDetection_to_force_or_add_an_empty_export_statement, isolatedModulesLikeFlagName);
+            error2(node.name, Diagnostics.Namespaces_are_not_allowed_in_global_script_files_when_0_is_enabled_If_this_file_is_not_intended_to_be_a_global_script_set_moduleDetection_to_force_or_add_an_empty_export_statement, isolatedModulesLikeFlagName);
           }
           if (((_a = symbol.declarations) == null ? void 0 : _a.length) > 1) {
             const firstNonAmbientClassOrFunc = getFirstNonAmbientClassOrFunctionDeclaration(symbol);
             if (firstNonAmbientClassOrFunc) {
               if (getSourceFileOfNode(node) !== getSourceFileOfNode(firstNonAmbientClassOrFunc)) {
-                error(node.name, Diagnostics.A_namespace_declaration_cannot_be_in_a_different_file_from_a_class_or_function_with_which_it_is_merged);
+                error2(node.name, Diagnostics.A_namespace_declaration_cannot_be_in_a_different_file_from_a_class_or_function_with_which_it_is_merged);
               } else if (node.pos < firstNonAmbientClassOrFunc.pos) {
-                error(node.name, Diagnostics.A_namespace_declaration_cannot_be_located_prior_to_a_class_or_function_with_which_it_is_merged);
+                error2(node.name, Diagnostics.A_namespace_declaration_cannot_be_located_prior_to_a_class_or_function_with_which_it_is_merged);
               }
             }
-            const mergedClass = getDeclarationOfKind(symbol, 262 /* ClassDeclaration */);
+            const mergedClass = getDeclarationOfKind(symbol, 263 /* ClassDeclaration */);
             if (mergedClass && inSameLexicalScope(node, mergedClass)) {
               getNodeLinks(node).flags |= 2048 /* LexicalModuleMergesWithClass */;
             }
           }
-          if (compilerOptions.verbatimModuleSyntax && node.parent.kind === 311 /* SourceFile */ && (moduleKind === 1 /* CommonJS */ || node.parent.impliedNodeFormat === 1 /* CommonJS */)) {
+          if (compilerOptions.verbatimModuleSyntax && node.parent.kind === 312 /* SourceFile */ && (moduleKind === 1 /* CommonJS */ || node.parent.impliedNodeFormat === 1 /* CommonJS */)) {
             const exportModifier = (_b = node.modifiers) == null ? void 0 : _b.find((m) => m.kind === 95 /* ExportKeyword */);
             if (exportModifier) {
-              error(exportModifier, Diagnostics.A_top_level_export_modifier_cannot_be_used_on_value_declarations_in_a_CommonJS_module_when_verbatimModuleSyntax_is_enabled);
+              error2(exportModifier, Diagnostics.A_top_level_export_modifier_cannot_be_used_on_value_declarations_in_a_CommonJS_module_when_verbatimModuleSyntax_is_enabled);
             }
           }
         }
@@ -180783,15 +164744,15 @@ ${lanes.join("\n")}
             }
           } else if (isGlobalSourceFile(node.parent)) {
             if (isGlobalAugmentation) {
-              error(node.name, Diagnostics.Augmentations_for_the_global_scope_can_only_be_directly_nested_in_external_modules_or_ambient_module_declarations);
+              error2(node.name, Diagnostics.Augmentations_for_the_global_scope_can_only_be_directly_nested_in_external_modules_or_ambient_module_declarations);
             } else if (isExternalModuleNameRelative(getTextOfIdentifierOrLiteral(node.name))) {
-              error(node.name, Diagnostics.Ambient_module_declaration_cannot_specify_relative_module_name);
+              error2(node.name, Diagnostics.Ambient_module_declaration_cannot_specify_relative_module_name);
             }
           } else {
             if (isGlobalAugmentation) {
-              error(node.name, Diagnostics.Augmentations_for_the_global_scope_can_only_be_directly_nested_in_external_modules_or_ambient_module_declarations);
+              error2(node.name, Diagnostics.Augmentations_for_the_global_scope_can_only_be_directly_nested_in_external_modules_or_ambient_module_declarations);
             } else {
-              error(node.name, Diagnostics.Ambient_modules_cannot_be_nested_in_other_modules_or_namespaces);
+              error2(node.name, Diagnostics.Ambient_modules_cannot_be_nested_in_other_modules_or_namespaces);
             }
           }
         }
@@ -180799,21 +164760,21 @@ ${lanes.join("\n")}
     }
     function checkModuleAugmentationElement(node, isGlobalAugmentation) {
       switch (node.kind) {
-        case 242 /* VariableStatement */:
+        case 243 /* VariableStatement */:
           for (const decl of node.declarationList.declarations) {
             checkModuleAugmentationElement(decl, isGlobalAugmentation);
           }
           break;
-        case 276 /* ExportAssignment */:
-        case 277 /* ExportDeclaration */:
+        case 277 /* ExportAssignment */:
+        case 278 /* ExportDeclaration */:
           grammarErrorOnFirstToken(node, Diagnostics.Exports_and_export_assignments_are_not_permitted_in_module_augmentations);
           break;
-        case 270 /* ImportEqualsDeclaration */:
-        case 271 /* ImportDeclaration */:
+        case 271 /* ImportEqualsDeclaration */:
+        case 272 /* ImportDeclaration */:
           grammarErrorOnFirstToken(node, Diagnostics.Imports_are_not_permitted_in_module_augmentations_Consider_moving_them_to_the_enclosing_external_module);
           break;
-        case 207 /* BindingElement */:
-        case 259 /* VariableDeclaration */:
+        case 208 /* BindingElement */:
+        case 260 /* VariableDeclaration */:
           const name = node.name;
           if (isBindingPattern(name)) {
             for (const el of name.elements) {
@@ -180821,12 +164782,12 @@ ${lanes.join("\n")}
             }
             break;
           }
-        case 262 /* ClassDeclaration */:
-        case 265 /* EnumDeclaration */:
-        case 261 /* FunctionDeclaration */:
-        case 263 /* InterfaceDeclaration */:
-        case 266 /* ModuleDeclaration */:
-        case 264 /* TypeAliasDeclaration */:
+        case 263 /* ClassDeclaration */:
+        case 266 /* EnumDeclaration */:
+        case 262 /* FunctionDeclaration */:
+        case 264 /* InterfaceDeclaration */:
+        case 267 /* ModuleDeclaration */:
+        case 265 /* TypeAliasDeclaration */:
           if (isGlobalAugmentation) {
             return;
           }
@@ -180837,12 +164798,12 @@ ${lanes.join("\n")}
       switch (node.kind) {
         case 80 /* Identifier */:
           return node;
-        case 165 /* QualifiedName */:
+        case 166 /* QualifiedName */:
           do {
             node = node.left;
           } while (node.kind !== 80 /* Identifier */);
           return node;
-        case 210 /* PropertyAccessExpression */:
+        case 211 /* PropertyAccessExpression */:
           do {
             if (isModuleExportsAccessExpression(node.expression) && !isPrivateIdentifier(node.name)) {
               return node.name;
@@ -180858,26 +164819,30 @@ ${lanes.join("\n")}
         return false;
       }
       if (!isStringLiteral(moduleName)) {
-        error(moduleName, Diagnostics.String_literal_expected);
+        error2(moduleName, Diagnostics.String_literal_expected);
         return false;
       }
-      const inAmbientExternalModule = node.parent.kind === 267 /* ModuleBlock */ && isAmbientModule(node.parent.parent);
-      if (node.parent.kind !== 311 /* SourceFile */ && !inAmbientExternalModule) {
-        error(moduleName, node.kind === 277 /* ExportDeclaration */ ? Diagnostics.Export_declarations_are_not_permitted_in_a_namespace : Diagnostics.Import_declarations_in_a_namespace_cannot_reference_a_module);
+      const inAmbientExternalModule = node.parent.kind === 268 /* ModuleBlock */ && isAmbientModule(node.parent.parent);
+      if (node.parent.kind !== 312 /* SourceFile */ && !inAmbientExternalModule) {
+        error2(
+          moduleName,
+          node.kind === 278 /* ExportDeclaration */ ? Diagnostics.Export_declarations_are_not_permitted_in_a_namespace : Diagnostics.Import_declarations_in_a_namespace_cannot_reference_a_module
+        );
         return false;
       }
       if (inAmbientExternalModule && isExternalModuleNameRelative(moduleName.text)) {
         if (!isTopLevelInExternalModuleAugmentation(node)) {
-          error(node, Diagnostics.Import_or_export_declaration_in_an_ambient_module_declaration_cannot_reference_module_through_relative_module_name);
+          error2(node, Diagnostics.Import_or_export_declaration_in_an_ambient_module_declaration_cannot_reference_module_through_relative_module_name);
           return false;
         }
       }
-      if (!isImportEqualsDeclaration(node) && node.assertClause) {
+      if (!isImportEqualsDeclaration(node) && node.attributes) {
+        const diagnostic = node.attributes.token === 118 /* WithKeyword */ ? Diagnostics.Import_attribute_values_must_be_string_literal_expressions : Diagnostics.Import_assertion_values_must_be_string_literal_expressions;
         let hasError = false;
-        for (const clause of node.assertClause.elements) {
-          if (!isStringLiteral(clause.value)) {
+        for (const attr of node.attributes.elements) {
+          if (!isStringLiteral(attr.value)) {
             hasError = true;
-            error(clause.value, Diagnostics.Import_assertion_values_must_be_string_literal_expressions);
+            error2(attr.value, diagnostic);
           }
         }
         return !hasError;
@@ -180892,26 +164857,29 @@ ${lanes.join("\n")}
         symbol = getMergedSymbol(symbol.exportSymbol || symbol);
         if (isInJSFile(node) && !(target.flags & 111551 /* Value */) && !isTypeOnlyImportOrExportDeclaration(node)) {
           const errorNode = isImportOrExportSpecifier(node) ? node.propertyName || node.name : isNamedDeclaration(node) ? node.name : node;
-          Debug.assert(node.kind !== 279 /* NamespaceExport */);
-          if (node.kind === 280 /* ExportSpecifier */) {
-            const diag2 = error(errorNode, Diagnostics.Types_cannot_appear_in_export_declarations_in_JavaScript_files);
+          Debug.assert(node.kind !== 280 /* NamespaceExport */);
+          if (node.kind === 281 /* ExportSpecifier */) {
+            const diag2 = error2(errorNode, Diagnostics.Types_cannot_appear_in_export_declarations_in_JavaScript_files);
             const alreadyExportedSymbol = (_b = (_a = getSourceFileOfNode(node).symbol) == null ? void 0 : _a.exports) == null ? void 0 : _b.get((node.propertyName || node.name).escapedText);
             if (alreadyExportedSymbol === target) {
               const exportingDeclaration = (_c = alreadyExportedSymbol.declarations) == null ? void 0 : _c.find(isJSDocNode);
               if (exportingDeclaration) {
-                addRelatedInfo(diag2, createDiagnosticForNode(
-                  exportingDeclaration,
-                  Diagnostics._0_is_automatically_exported_here,
-                  unescapeLeadingUnderscores(alreadyExportedSymbol.escapedName)
-                ));
+                addRelatedInfo(
+                  diag2,
+                  createDiagnosticForNode(
+                    exportingDeclaration,
+                    Diagnostics._0_is_automatically_exported_here,
+                    unescapeLeadingUnderscores(alreadyExportedSymbol.escapedName)
+                  )
+                );
               }
             }
           } else {
-            Debug.assert(node.kind !== 259 /* VariableDeclaration */);
+            Debug.assert(node.kind !== 260 /* VariableDeclaration */);
             const importDeclaration = findAncestor(node, or(isImportDeclaration, isImportEqualsDeclaration));
             const moduleSpecifier = (importDeclaration && ((_d = tryGetModuleSpecifierFromDeclaration(importDeclaration)) == null ? void 0 : _d.text)) ?? "...";
             const importedIdentifier = unescapeLeadingUnderscores(isIdentifier(errorNode) ? errorNode.escapedText : symbol.escapedName);
-            error(
+            error2(
               errorNode,
               Diagnostics._0_is_a_type_and_cannot_be_imported_in_JavaScript_files_Use_1_in_a_JSDoc_type_annotation,
               importedIdentifier,
@@ -180920,47 +164888,47 @@ ${lanes.join("\n")}
           }
           return;
         }
-        const targetFlags = getAllSymbolFlags(target);
+        const targetFlags = getSymbolFlags(target);
         const excludedMeanings = (symbol.flags & (111551 /* Value */ | 1048576 /* ExportValue */) ? 111551 /* Value */ : 0) | (symbol.flags & 788968 /* Type */ ? 788968 /* Type */ : 0) | (symbol.flags & 1920 /* Namespace */ ? 1920 /* Namespace */ : 0);
         if (targetFlags & excludedMeanings) {
-          const message = node.kind === 280 /* ExportSpecifier */ ? Diagnostics.Export_declaration_conflicts_with_exported_declaration_of_0 : Diagnostics.Import_declaration_conflicts_with_local_declaration_of_0;
-          error(node, message, symbolToString(symbol));
+          const message = node.kind === 281 /* ExportSpecifier */ ? Diagnostics.Export_declaration_conflicts_with_exported_declaration_of_0 : Diagnostics.Import_declaration_conflicts_with_local_declaration_of_0;
+          error2(node, message, symbolToString(symbol));
         }
-        if (getIsolatedModules(compilerOptions) && !isTypeOnlyImportOrExportDeclaration(node) && !(node.flags & 16777216 /* Ambient */)) {
+        if (getIsolatedModules(compilerOptions) && !isTypeOnlyImportOrExportDeclaration(node) && !(node.flags & 33554432 /* Ambient */)) {
           const typeOnlyAlias = getTypeOnlyAliasDeclaration(symbol);
           const isType = !(targetFlags & 111551 /* Value */);
           if (isType || typeOnlyAlias) {
             switch (node.kind) {
-              case 272 /* ImportClause */:
-              case 275 /* ImportSpecifier */:
-              case 270 /* ImportEqualsDeclaration */: {
+              case 273 /* ImportClause */:
+              case 276 /* ImportSpecifier */:
+              case 271 /* ImportEqualsDeclaration */: {
                 if (compilerOptions.preserveValueImports || compilerOptions.verbatimModuleSyntax) {
                   Debug.assertIsDefined(node.name, "An ImportClause with a symbol should have a name");
                   const message = compilerOptions.verbatimModuleSyntax && isInternalModuleImportEqualsDeclaration(node) ? Diagnostics.An_import_alias_cannot_resolve_to_a_type_or_type_only_declaration_when_verbatimModuleSyntax_is_enabled : isType ? compilerOptions.verbatimModuleSyntax ? Diagnostics._0_is_a_type_and_must_be_imported_using_a_type_only_import_when_verbatimModuleSyntax_is_enabled : Diagnostics._0_is_a_type_and_must_be_imported_using_a_type_only_import_when_preserveValueImports_and_isolatedModules_are_both_enabled : compilerOptions.verbatimModuleSyntax ? Diagnostics._0_resolves_to_a_type_only_declaration_and_must_be_imported_using_a_type_only_import_when_verbatimModuleSyntax_is_enabled : Diagnostics._0_resolves_to_a_type_only_declaration_and_must_be_imported_using_a_type_only_import_when_preserveValueImports_and_isolatedModules_are_both_enabled;
-                  const name = idText(node.kind === 275 /* ImportSpecifier */ ? node.propertyName || node.name : node.name);
+                  const name = idText(node.kind === 276 /* ImportSpecifier */ ? node.propertyName || node.name : node.name);
                   addTypeOnlyDeclarationRelatedInfo(
-                    error(node, message, name),
+                    error2(node, message, name),
                     isType ? void 0 : typeOnlyAlias,
                     name
                   );
                 }
-                if (isType && node.kind === 270 /* ImportEqualsDeclaration */ && hasEffectiveModifier(node, 1 /* Export */)) {
-                  error(node, Diagnostics.Cannot_use_export_import_on_a_type_or_type_only_namespace_when_0_is_enabled, isolatedModulesLikeFlagName);
+                if (isType && node.kind === 271 /* ImportEqualsDeclaration */ && hasEffectiveModifier(node, 32 /* Export */)) {
+                  error2(node, Diagnostics.Cannot_use_export_import_on_a_type_or_type_only_namespace_when_0_is_enabled, isolatedModulesLikeFlagName);
                 }
                 break;
               }
-              case 280 /* ExportSpecifier */: {
+              case 281 /* ExportSpecifier */: {
                 if (compilerOptions.verbatimModuleSyntax || getSourceFileOfNode(typeOnlyAlias) !== getSourceFileOfNode(node)) {
                   const name = idText(node.propertyName || node.name);
-                  const diagnostic = isType ? error(node, Diagnostics.Re_exporting_a_type_when_0_is_enabled_requires_using_export_type, isolatedModulesLikeFlagName) : error(node, Diagnostics._0_resolves_to_a_type_only_declaration_and_must_be_re_exported_using_a_type_only_re_export_when_1_is_enabled, name, isolatedModulesLikeFlagName);
+                  const diagnostic = isType ? error2(node, Diagnostics.Re_exporting_a_type_when_0_is_enabled_requires_using_export_type, isolatedModulesLikeFlagName) : error2(node, Diagnostics._0_resolves_to_a_type_only_declaration_and_must_be_re_exported_using_a_type_only_re_export_when_1_is_enabled, name, isolatedModulesLikeFlagName);
                   addTypeOnlyDeclarationRelatedInfo(diagnostic, isType ? void 0 : typeOnlyAlias, name);
                   break;
                 }
               }
             }
           }
-          if (compilerOptions.verbatimModuleSyntax && node.kind !== 270 /* ImportEqualsDeclaration */ && !isInJSFile(node) && (moduleKind === 1 /* CommonJS */ || getSourceFileOfNode(node).impliedNodeFormat === 1 /* CommonJS */)) {
-            error(node, Diagnostics.ESM_syntax_is_not_allowed_in_a_CommonJS_module_when_verbatimModuleSyntax_is_enabled);
+          if (compilerOptions.verbatimModuleSyntax && node.kind !== 271 /* ImportEqualsDeclaration */ && !isInJSFile(node) && (moduleKind === 1 /* CommonJS */ || getSourceFileOfNode(node).impliedNodeFormat === 1 /* CommonJS */)) {
+            error2(node, Diagnostics.ESM_syntax_is_not_allowed_in_a_CommonJS_module_when_verbatimModuleSyntax_is_enabled);
           }
         }
         if (isImportSpecifier(node)) {
@@ -181002,36 +164970,30 @@ ${lanes.join("\n")}
     function checkImportBinding(node) {
       checkCollisionsForDeclarationName(node, node.name);
       checkAliasSymbol(node);
-      if (node.kind === 275 /* ImportSpecifier */ && idText(node.propertyName || node.name) === "default" && getESModuleInterop(compilerOptions) && moduleKind !== 4 /* System */ && (moduleKind < 5 /* ES2015 */ || getSourceFileOfNode(node).impliedNodeFormat === 1 /* CommonJS */)) {
+      if (node.kind === 276 /* ImportSpecifier */ && idText(node.propertyName || node.name) === "default" && getESModuleInterop(compilerOptions) && moduleKind !== 4 /* System */ && (moduleKind < 5 /* ES2015 */ || getSourceFileOfNode(node).impliedNodeFormat === 1 /* CommonJS */)) {
         checkExternalEmitHelpers(node, 131072 /* ImportDefault */);
       }
     }
-    function checkAssertClause(declaration) {
+    function checkImportAttributes(declaration) {
       var _a;
-      if (declaration.assertClause) {
-        const validForTypeAssertions = isExclusivelyTypeOnlyImportOrExport(declaration);
-        const override = getResolutionModeOverrideForClause(declaration.assertClause, validForTypeAssertions ? grammarErrorOnNode : void 0);
-        if (validForTypeAssertions && override) {
-          if (!isNightly()) {
-            grammarErrorOnNode(declaration.assertClause, Diagnostics.resolution_mode_assertions_are_unstable_Use_nightly_TypeScript_to_silence_this_error_Try_updating_with_npm_install_D_typescript_next);
-          }
-          if (getEmitModuleResolutionKind(compilerOptions) !== 3 /* Node16 */ && getEmitModuleResolutionKind(compilerOptions) !== 99 /* NodeNext */) {
-            return grammarErrorOnNode(declaration.assertClause, Diagnostics.resolution_mode_assertions_are_only_supported_when_moduleResolution_is_node16_or_nodenext);
-          }
+      const node = declaration.attributes;
+      if (node) {
+        const validForTypeAttributes = isExclusivelyTypeOnlyImportOrExport(declaration);
+        const override = getResolutionModeOverride(node, validForTypeAttributes ? grammarErrorOnNode : void 0);
+        const isImportAttributes2 = declaration.attributes.token === 118 /* WithKeyword */;
+        if (validForTypeAttributes && override) {
           return;
         }
         const mode = moduleKind === 199 /* NodeNext */ && declaration.moduleSpecifier && getUsageModeForExpression(declaration.moduleSpecifier);
         if (mode !== 99 /* ESNext */ && moduleKind !== 99 /* ESNext */) {
-          return grammarErrorOnNode(
-            declaration.assertClause,
-            moduleKind === 199 /* NodeNext */ ? Diagnostics.Import_assertions_are_not_allowed_on_statements_that_transpile_to_commonjs_require_calls : Diagnostics.Import_assertions_are_only_supported_when_the_module_option_is_set_to_esnext_or_nodenext
-          );
+          const message = isImportAttributes2 ? moduleKind === 199 /* NodeNext */ ? Diagnostics.Import_attributes_are_not_allowed_on_statements_that_compile_to_CommonJS_require_calls : Diagnostics.Import_attributes_are_only_supported_when_the_module_option_is_set_to_esnext_or_nodenext : moduleKind === 199 /* NodeNext */ ? Diagnostics.Import_assertions_are_not_allowed_on_statements_that_compile_to_CommonJS_require_calls : Diagnostics.Import_assertions_are_only_supported_when_the_module_option_is_set_to_esnext_or_nodenext;
+          return grammarErrorOnNode(node, message);
         }
         if (isImportDeclaration(declaration) ? (_a = declaration.importClause) == null ? void 0 : _a.isTypeOnly : declaration.isTypeOnly) {
-          return grammarErrorOnNode(declaration.assertClause, Diagnostics.Import_assertions_cannot_be_used_with_type_only_imports_or_exports);
+          return grammarErrorOnNode(node, isImportAttributes2 ? Diagnostics.Import_attributes_cannot_be_used_with_type_only_imports_or_exports : Diagnostics.Import_assertions_cannot_be_used_with_type_only_imports_or_exports);
         }
         if (override) {
-          return grammarErrorOnNode(declaration.assertClause, Diagnostics.resolution_mode_can_only_be_set_for_type_only_imports);
+          return grammarErrorOnNode(node, Diagnostics.resolution_mode_can_only_be_set_for_type_only_imports);
         }
       }
     }
@@ -181049,7 +165011,7 @@ ${lanes.join("\n")}
             checkImportBinding(importClause);
           }
           if (importClause.namedBindings) {
-            if (importClause.namedBindings.kind === 273 /* NamespaceImport */) {
+            if (importClause.namedBindings.kind === 274 /* NamespaceImport */) {
               checkImportBinding(importClause.namedBindings);
               if (moduleKind !== 4 /* System */ && (moduleKind < 5 /* ES2015 */ || getSourceFileOfNode(node).impliedNodeFormat === 1 /* CommonJS */) && getESModuleInterop(compilerOptions)) {
                 checkExternalEmitHelpers(node, 65536 /* ImportStar */);
@@ -181063,7 +165025,7 @@ ${lanes.join("\n")}
           }
         }
       }
-      checkAssertClause(node);
+      checkImportAttributes(node);
     }
     function checkImportEqualsDeclaration(node) {
       if (checkGrammarModuleElementContext(node, isInJSFile(node) ? Diagnostics.An_import_declaration_can_only_be_used_at_the_top_level_of_a_module : Diagnostics.An_import_declaration_can_only_be_used_at_the_top_level_of_a_namespace_or_module)) {
@@ -181072,17 +165034,17 @@ ${lanes.join("\n")}
       checkGrammarModifiers(node);
       if (isInternalModuleImportEqualsDeclaration(node) || checkExternalImportOrExportDeclaration(node)) {
         checkImportBinding(node);
-        if (hasSyntacticModifier(node, 1 /* Export */)) {
+        if (hasSyntacticModifier(node, 32 /* Export */)) {
           markExportAsReferenced(node);
         }
-        if (node.moduleReference.kind !== 282 /* ExternalModuleReference */) {
+        if (node.moduleReference.kind !== 283 /* ExternalModuleReference */) {
           const target = resolveAlias(getSymbolOfDeclaration(node));
           if (target !== unknownSymbol) {
-            const targetFlags = getAllSymbolFlags(target);
+            const targetFlags = getSymbolFlags(target);
             if (targetFlags & 111551 /* Value */) {
               const moduleName = getFirstIdentifier(node.moduleReference);
               if (!(resolveEntityName(moduleName, 111551 /* Value */ | 1920 /* Namespace */).flags & 1920 /* Namespace */)) {
-                error(moduleName, Diagnostics.Module_0_is_hidden_by_a_local_declaration_with_the_same_name, declarationNameToString(moduleName));
+                error2(moduleName, Diagnostics.Module_0_is_hidden_by_a_local_declaration_with_the_same_name, declarationNameToString(moduleName));
               }
             }
             if (targetFlags & 788968 /* Type */) {
@@ -181093,7 +165055,7 @@ ${lanes.join("\n")}
             grammarErrorOnNode(node, Diagnostics.An_import_alias_cannot_use_import_type);
           }
         } else {
-          if (moduleKind >= 5 /* ES2015 */ && getSourceFileOfNode(node).impliedNodeFormat === void 0 && !node.isTypeOnly && !(node.flags & 16777216 /* Ambient */)) {
+          if (moduleKind >= 5 /* ES2015 */ && getSourceFileOfNode(node).impliedNodeFormat === void 0 && !node.isTypeOnly && !(node.flags & 33554432 /* Ambient */)) {
             grammarErrorOnNode(node, Diagnostics.Import_assignment_cannot_be_used_when_targeting_ECMAScript_modules_Consider_using_import_Asterisk_as_ns_from_mod_import_a_from_mod_import_d_from_mod_or_another_module_format_instead);
           }
         }
@@ -181113,15 +165075,15 @@ ${lanes.join("\n")}
       if (!node.moduleSpecifier || checkExternalImportOrExportDeclaration(node)) {
         if (node.exportClause && !isNamespaceExport(node.exportClause)) {
           forEach(node.exportClause.elements, checkExportSpecifier);
-          const inAmbientExternalModule = node.parent.kind === 267 /* ModuleBlock */ && isAmbientModule(node.parent.parent);
-          const inAmbientNamespaceDeclaration = !inAmbientExternalModule && node.parent.kind === 267 /* ModuleBlock */ && !node.moduleSpecifier && node.flags & 16777216 /* Ambient */;
-          if (node.parent.kind !== 311 /* SourceFile */ && !inAmbientExternalModule && !inAmbientNamespaceDeclaration) {
-            error(node, Diagnostics.Export_declarations_are_not_permitted_in_a_namespace);
+          const inAmbientExternalModule = node.parent.kind === 268 /* ModuleBlock */ && isAmbientModule(node.parent.parent);
+          const inAmbientNamespaceDeclaration = !inAmbientExternalModule && node.parent.kind === 268 /* ModuleBlock */ && !node.moduleSpecifier && node.flags & 33554432 /* Ambient */;
+          if (node.parent.kind !== 312 /* SourceFile */ && !inAmbientExternalModule && !inAmbientNamespaceDeclaration) {
+            error2(node, Diagnostics.Export_declarations_are_not_permitted_in_a_namespace);
           }
         } else {
           const moduleSymbol = resolveExternalModuleName(node, node.moduleSpecifier);
           if (moduleSymbol && hasExportAssignmentSymbol(moduleSymbol)) {
-            error(node.moduleSpecifier, Diagnostics.Module_0_uses_export_and_cannot_be_used_with_export_Asterisk, symbolToString(moduleSymbol));
+            error2(node.moduleSpecifier, Diagnostics.Module_0_uses_export_and_cannot_be_used_with_export_Asterisk, symbolToString(moduleSymbol));
           } else if (node.exportClause) {
             checkAliasSymbol(node.exportClause);
           }
@@ -181136,17 +165098,17 @@ ${lanes.join("\n")}
           }
         }
       }
-      checkAssertClause(node);
+      checkImportAttributes(node);
     }
     function checkGrammarExportDeclaration(node) {
       var _a;
-      if (node.isTypeOnly && ((_a = node.exportClause) == null ? void 0 : _a.kind) === 278 /* NamedExports */) {
+      if (node.isTypeOnly && ((_a = node.exportClause) == null ? void 0 : _a.kind) === 279 /* NamedExports */) {
         return checkGrammarNamedImportsOrExports(node.exportClause);
       }
       return false;
     }
     function checkGrammarModuleElementContext(node, errorMessage) {
-      const isInAppropriateContext = node.parent.kind === 311 /* SourceFile */ || node.parent.kind === 267 /* ModuleBlock */ || node.parent.kind === 266 /* ModuleDeclaration */;
+      const isInAppropriateContext = node.parent.kind === 312 /* SourceFile */ || node.parent.kind === 268 /* ModuleBlock */ || node.parent.kind === 267 /* ModuleDeclaration */;
       if (!isInAppropriateContext) {
         grammarErrorOnFirstToken(node, errorMessage);
       }
@@ -181182,7 +165144,7 @@ ${lanes.join("\n")}
       }
       for (const statement of sourceFile.statements) {
         if (canConvertImportDeclarationToTypeOnly(statement) || canConvertImportEqualsDeclarationToTypeOnly(statement)) {
-          error(
+          error2(
             statement,
             Diagnostics.This_import_is_never_used_as_a_value_and_must_use_import_type_because_importsNotUsedAsValues_is_set_to_error
           );
@@ -181212,13 +165174,13 @@ ${lanes.join("\n")}
           true
         );
         if (symbol && (symbol === undefinedSymbol || symbol === globalThisSymbol || symbol.declarations && isGlobalSourceFile(getDeclarationContainer(symbol.declarations[0])))) {
-          error(exportedName, Diagnostics.Cannot_export_0_Only_local_declarations_can_be_exported_from_a_module, idText(exportedName));
+          error2(exportedName, Diagnostics.Cannot_export_0_Only_local_declarations_can_be_exported_from_a_module, idText(exportedName));
         } else {
           if (!node.isTypeOnly && !node.parent.parent.isTypeOnly) {
             markExportAsReferenced(node);
           }
           const target = symbol && (symbol.flags & 2097152 /* Alias */ ? resolveAlias(symbol) : symbol);
-          if (!target || getAllSymbolFlags(target) & 111551 /* Value */) {
+          if (!target || getSymbolFlags(target) & 111551 /* Value */) {
             checkExpressionCached(node.propertyName || node.name);
           }
         }
@@ -181233,12 +165195,12 @@ ${lanes.join("\n")}
       if (checkGrammarModuleElementContext(node, illegalContextMessage)) {
         return;
       }
-      const container = node.parent.kind === 311 /* SourceFile */ ? node.parent : node.parent.parent;
-      if (container.kind === 266 /* ModuleDeclaration */ && !isAmbientModule(container)) {
+      const container = node.parent.kind === 312 /* SourceFile */ ? node.parent : node.parent.parent;
+      if (container.kind === 267 /* ModuleDeclaration */ && !isAmbientModule(container)) {
         if (node.isExportEquals) {
-          error(node, Diagnostics.An_export_assignment_cannot_be_used_in_a_namespace);
+          error2(node, Diagnostics.An_export_assignment_cannot_be_used_in_a_namespace);
         } else {
-          error(node, Diagnostics.A_default_export_can_only_be_used_in_an_ECMAScript_style_module);
+          error2(node, Diagnostics.A_default_export_can_only_be_used_in_an_ECMAScript_style_module);
         }
         return;
       }
@@ -181249,7 +165211,7 @@ ${lanes.join("\n")}
       if (typeAnnotationNode) {
         checkTypeAssignableTo(checkExpressionCached(node.expression), getTypeFromTypeNode(typeAnnotationNode), node.expression);
       }
-      const isIllegalExportDefaultInCJS = !node.isExportEquals && !(node.flags & 16777216 /* Ambient */) && compilerOptions.verbatimModuleSyntax && (moduleKind === 1 /* CommonJS */ || getSourceFileOfNode(node).impliedNodeFormat === 1 /* CommonJS */);
+      const isIllegalExportDefaultInCJS = !node.isExportEquals && !(node.flags & 33554432 /* Ambient */) && compilerOptions.verbatimModuleSyntax && (moduleKind === 1 /* CommonJS */ || getSourceFileOfNode(node).impliedNodeFormat === 1 /* CommonJS */);
       if (node.expression.kind === 80 /* Identifier */) {
         const id = node.expression;
         const sym = getExportSymbolOfValueSymbolIfExported(resolveEntityName(
@@ -181263,17 +165225,17 @@ ${lanes.join("\n")}
         ));
         if (sym) {
           markAliasReferenced(sym, id);
-          if (getAllSymbolFlags(sym) & 111551 /* Value */) {
+          if (getSymbolFlags(sym) & 111551 /* Value */) {
             checkExpressionCached(id);
-            if (!isIllegalExportDefaultInCJS && !(node.flags & 16777216 /* Ambient */) && compilerOptions.verbatimModuleSyntax && getTypeOnlyAliasDeclaration(sym, 111551 /* Value */)) {
-              error(
+            if (!isIllegalExportDefaultInCJS && !(node.flags & 33554432 /* Ambient */) && compilerOptions.verbatimModuleSyntax && getTypeOnlyAliasDeclaration(sym, 111551 /* Value */)) {
+              error2(
                 id,
                 node.isExportEquals ? Diagnostics.An_export_declaration_must_reference_a_real_value_when_verbatimModuleSyntax_is_enabled_but_0_resolves_to_a_type_only_declaration : Diagnostics.An_export_default_must_reference_a_real_value_when_verbatimModuleSyntax_is_enabled_but_0_resolves_to_a_type_only_declaration,
                 idText(id)
               );
             }
-          } else if (!isIllegalExportDefaultInCJS && !(node.flags & 16777216 /* Ambient */) && compilerOptions.verbatimModuleSyntax) {
-            error(
+          } else if (!isIllegalExportDefaultInCJS && !(node.flags & 33554432 /* Ambient */) && compilerOptions.verbatimModuleSyntax) {
+            error2(
               id,
               node.isExportEquals ? Diagnostics.An_export_declaration_must_reference_a_value_when_verbatimModuleSyntax_is_enabled_but_0_only_refers_to_a_type : Diagnostics.An_export_default_must_reference_a_value_when_verbatimModuleSyntax_is_enabled_but_0_only_refers_to_a_type,
               idText(id)
@@ -181293,16 +165255,16 @@ ${lanes.join("\n")}
         checkExpressionCached(node.expression);
       }
       if (isIllegalExportDefaultInCJS) {
-        error(node, Diagnostics.ESM_syntax_is_not_allowed_in_a_CommonJS_module_when_verbatimModuleSyntax_is_enabled);
+        error2(node, Diagnostics.ESM_syntax_is_not_allowed_in_a_CommonJS_module_when_verbatimModuleSyntax_is_enabled);
       }
       checkExternalModuleExports(container);
-      if (node.flags & 16777216 /* Ambient */ && !isEntityNameExpression(node.expression)) {
+      if (node.flags & 33554432 /* Ambient */ && !isEntityNameExpression(node.expression)) {
         grammarErrorOnNode(node.expression, Diagnostics.The_expression_of_an_export_assignment_must_be_an_identifier_or_qualified_name_in_an_ambient_context);
       }
       if (node.isExportEquals) {
-        if (moduleKind >= 5 /* ES2015 */ && (node.flags & 16777216 /* Ambient */ && getSourceFileOfNode(node).impliedNodeFormat === 99 /* ESNext */ || !(node.flags & 16777216 /* Ambient */) && getSourceFileOfNode(node).impliedNodeFormat !== 1 /* CommonJS */)) {
+        if (moduleKind >= 5 /* ES2015 */ && (node.flags & 33554432 /* Ambient */ && getSourceFileOfNode(node).impliedNodeFormat === 99 /* ESNext */ || !(node.flags & 33554432 /* Ambient */) && getSourceFileOfNode(node).impliedNodeFormat !== 1 /* CommonJS */)) {
           grammarErrorOnNode(node, Diagnostics.Export_assignment_cannot_be_used_when_targeting_ECMAScript_modules_Consider_using_export_default_or_another_module_format_instead);
-        } else if (moduleKind === 4 /* System */ && !(node.flags & 16777216 /* Ambient */)) {
+        } else if (moduleKind === 4 /* System */ && !(node.flags & 33554432 /* Ambient */)) {
           grammarErrorOnNode(node, Diagnostics.Export_assignment_is_not_supported_when_module_flag_is_system);
         }
       }
@@ -181318,7 +165280,7 @@ ${lanes.join("\n")}
         if (exportEqualsSymbol && hasExportedMembers(moduleSymbol)) {
           const declaration = getDeclarationOfAliasSymbol(exportEqualsSymbol) || exportEqualsSymbol.valueDeclaration;
           if (declaration && !isTopLevelInExternalModuleAugmentation(declaration) && !isInJSFile(declaration)) {
-            error(declaration, Diagnostics.An_export_assignment_cannot_be_used_in_a_module_with_other_exported_elements);
+            error2(declaration, Diagnostics.An_export_assignment_cannot_be_used_in_a_module_with_other_exported_elements);
           }
         }
         const exports = getExportsOfModule(moduleSymbol);
@@ -181375,182 +165337,184 @@ ${lanes.join("\n")}
       const kind = node.kind;
       if (cancellationToken) {
         switch (kind) {
-          case 266 /* ModuleDeclaration */:
-          case 262 /* ClassDeclaration */:
-          case 263 /* InterfaceDeclaration */:
-          case 261 /* FunctionDeclaration */:
+          case 267 /* ModuleDeclaration */:
+          case 263 /* ClassDeclaration */:
+          case 264 /* InterfaceDeclaration */:
+          case 262 /* FunctionDeclaration */:
             cancellationToken.throwIfCancellationRequested();
         }
       }
-      if (kind >= 242 /* FirstStatement */ && kind <= 258 /* LastStatement */ && canHaveFlowNode(node) && node.flowNode && !isReachableFlowNode(node.flowNode)) {
+      if (kind >= 243 /* FirstStatement */ && kind <= 259 /* LastStatement */ && canHaveFlowNode(node) && node.flowNode && !isReachableFlowNode(node.flowNode)) {
         errorOrSuggestion(compilerOptions.allowUnreachableCode === false, node, Diagnostics.Unreachable_code_detected);
       }
       switch (kind) {
-        case 167 /* TypeParameter */:
+        case 168 /* TypeParameter */:
           return checkTypeParameter(node);
-        case 168 /* Parameter */:
+        case 169 /* Parameter */:
           return checkParameter(node);
-        case 171 /* PropertyDeclaration */:
+        case 172 /* PropertyDeclaration */:
           return checkPropertyDeclaration(node);
-        case 170 /* PropertySignature */:
+        case 171 /* PropertySignature */:
           return checkPropertySignature(node);
-        case 184 /* ConstructorType */:
-        case 183 /* FunctionType */:
-        case 178 /* CallSignature */:
-        case 179 /* ConstructSignature */:
-        case 180 /* IndexSignature */:
+        case 185 /* ConstructorType */:
+        case 184 /* FunctionType */:
+        case 179 /* CallSignature */:
+        case 180 /* ConstructSignature */:
+        case 181 /* IndexSignature */:
           return checkSignatureDeclaration(node);
-        case 173 /* MethodDeclaration */:
-        case 172 /* MethodSignature */:
+        case 174 /* MethodDeclaration */:
+        case 173 /* MethodSignature */:
           return checkMethodDeclaration(node);
-        case 174 /* ClassStaticBlockDeclaration */:
+        case 175 /* ClassStaticBlockDeclaration */:
           return checkClassStaticBlockDeclaration(node);
-        case 175 /* Constructor */:
+        case 176 /* Constructor */:
           return checkConstructorDeclaration(node);
-        case 176 /* GetAccessor */:
-        case 177 /* SetAccessor */:
+        case 177 /* GetAccessor */:
+        case 178 /* SetAccessor */:
           return checkAccessorDeclaration(node);
-        case 182 /* TypeReference */:
+        case 183 /* TypeReference */:
           return checkTypeReferenceNode(node);
-        case 181 /* TypePredicate */:
+        case 182 /* TypePredicate */:
           return checkTypePredicate(node);
-        case 185 /* TypeQuery */:
+        case 186 /* TypeQuery */:
           return checkTypeQuery(node);
-        case 186 /* TypeLiteral */:
+        case 187 /* TypeLiteral */:
           return checkTypeLiteral(node);
-        case 187 /* ArrayType */:
+        case 188 /* ArrayType */:
           return checkArrayType(node);
-        case 188 /* TupleType */:
+        case 189 /* TupleType */:
           return checkTupleType(node);
-        case 191 /* UnionType */:
-        case 192 /* IntersectionType */:
+        case 192 /* UnionType */:
+        case 193 /* IntersectionType */:
           return checkUnionOrIntersectionType(node);
-        case 195 /* ParenthesizedType */:
-        case 189 /* OptionalType */:
-        case 190 /* RestType */:
+        case 196 /* ParenthesizedType */:
+        case 190 /* OptionalType */:
+        case 191 /* RestType */:
           return checkSourceElement(node.type);
-        case 196 /* ThisType */:
+        case 197 /* ThisType */:
           return checkThisType(node);
-        case 197 /* TypeOperator */:
+        case 198 /* TypeOperator */:
           return checkTypeOperator(node);
-        case 193 /* ConditionalType */:
+        case 194 /* ConditionalType */:
           return checkConditionalType(node);
-        case 194 /* InferType */:
+        case 195 /* InferType */:
           return checkInferType(node);
-        case 202 /* TemplateLiteralType */:
+        case 203 /* TemplateLiteralType */:
           return checkTemplateLiteralType(node);
-        case 204 /* ImportType */:
+        case 205 /* ImportType */:
           return checkImportType(node);
-        case 201 /* NamedTupleMember */:
+        case 202 /* NamedTupleMember */:
           return checkNamedTupleMember(node);
-        case 334 /* JSDocAugmentsTag */:
+        case 335 /* JSDocAugmentsTag */:
           return checkJSDocAugmentsTag(node);
-        case 335 /* JSDocImplementsTag */:
+        case 336 /* JSDocImplementsTag */:
           return checkJSDocImplementsTag(node);
-        case 352 /* JSDocTypedefTag */:
-        case 344 /* JSDocCallbackTag */:
-        case 346 /* JSDocEnumTag */:
+        case 353 /* JSDocTypedefTag */:
+        case 345 /* JSDocCallbackTag */:
+        case 347 /* JSDocEnumTag */:
           return checkJSDocTypeAliasTag(node);
-        case 351 /* JSDocTemplateTag */:
+        case 352 /* JSDocTemplateTag */:
           return checkJSDocTemplateTag(node);
-        case 350 /* JSDocTypeTag */:
+        case 351 /* JSDocTypeTag */:
           return checkJSDocTypeTag(node);
-        case 330 /* JSDocLink */:
-        case 331 /* JSDocLinkCode */:
-        case 332 /* JSDocLinkPlain */:
+        case 331 /* JSDocLink */:
+        case 332 /* JSDocLinkCode */:
+        case 333 /* JSDocLinkPlain */:
           return checkJSDocLinkLikeTag(node);
-        case 347 /* JSDocParameterTag */:
+        case 348 /* JSDocParameterTag */:
           return checkJSDocParameterTag(node);
-        case 354 /* JSDocPropertyTag */:
+        case 355 /* JSDocPropertyTag */:
           return checkJSDocPropertyTag(node);
-        case 323 /* JSDocFunctionType */:
+        case 324 /* JSDocFunctionType */:
           checkJSDocFunctionType(node);
-        case 321 /* JSDocNonNullableType */:
-        case 320 /* JSDocNullableType */:
-        case 318 /* JSDocAllType */:
-        case 319 /* JSDocUnknownType */:
-        case 328 /* JSDocTypeLiteral */:
+        case 322 /* JSDocNonNullableType */:
+        case 321 /* JSDocNullableType */:
+        case 319 /* JSDocAllType */:
+        case 320 /* JSDocUnknownType */:
+        case 329 /* JSDocTypeLiteral */:
           checkJSDocTypeIsInJsFile(node);
           forEachChild(node, checkSourceElement);
           return;
-        case 324 /* JSDocVariadicType */:
+        case 325 /* JSDocVariadicType */:
           checkJSDocVariadicType(node);
           return;
-        case 315 /* JSDocTypeExpression */:
+        case 316 /* JSDocTypeExpression */:
           return checkSourceElement(node.type);
-        case 339 /* JSDocPublicTag */:
-        case 341 /* JSDocProtectedTag */:
-        case 340 /* JSDocPrivateTag */:
+        case 340 /* JSDocPublicTag */:
+        case 342 /* JSDocProtectedTag */:
+        case 341 /* JSDocPrivateTag */:
           return checkJSDocAccessibilityModifiers(node);
-        case 356 /* JSDocSatisfiesTag */:
+        case 357 /* JSDocSatisfiesTag */:
           return checkJSDocSatisfiesTag(node);
-        case 198 /* IndexedAccessType */:
+        case 350 /* JSDocThisTag */:
+          return checkJSDocThisTag(node);
+        case 199 /* IndexedAccessType */:
           return checkIndexedAccessType(node);
-        case 199 /* MappedType */:
+        case 200 /* MappedType */:
           return checkMappedType(node);
-        case 261 /* FunctionDeclaration */:
+        case 262 /* FunctionDeclaration */:
           return checkFunctionDeclaration(node);
-        case 240 /* Block */:
-        case 267 /* ModuleBlock */:
+        case 241 /* Block */:
+        case 268 /* ModuleBlock */:
           return checkBlock(node);
-        case 242 /* VariableStatement */:
+        case 243 /* VariableStatement */:
           return checkVariableStatement(node);
-        case 243 /* ExpressionStatement */:
+        case 244 /* ExpressionStatement */:
           return checkExpressionStatement(node);
-        case 244 /* IfStatement */:
+        case 245 /* IfStatement */:
           return checkIfStatement(node);
-        case 245 /* DoStatement */:
+        case 246 /* DoStatement */:
           return checkDoStatement(node);
-        case 246 /* WhileStatement */:
+        case 247 /* WhileStatement */:
           return checkWhileStatement(node);
-        case 247 /* ForStatement */:
+        case 248 /* ForStatement */:
           return checkForStatement(node);
-        case 248 /* ForInStatement */:
+        case 249 /* ForInStatement */:
           return checkForInStatement(node);
-        case 249 /* ForOfStatement */:
+        case 250 /* ForOfStatement */:
           return checkForOfStatement(node);
-        case 250 /* ContinueStatement */:
-        case 251 /* BreakStatement */:
+        case 251 /* ContinueStatement */:
+        case 252 /* BreakStatement */:
           return checkBreakOrContinueStatement(node);
-        case 252 /* ReturnStatement */:
+        case 253 /* ReturnStatement */:
           return checkReturnStatement(node);
-        case 253 /* WithStatement */:
+        case 254 /* WithStatement */:
           return checkWithStatement(node);
-        case 254 /* SwitchStatement */:
+        case 255 /* SwitchStatement */:
           return checkSwitchStatement(node);
-        case 255 /* LabeledStatement */:
+        case 256 /* LabeledStatement */:
           return checkLabeledStatement(node);
-        case 256 /* ThrowStatement */:
+        case 257 /* ThrowStatement */:
           return checkThrowStatement(node);
-        case 257 /* TryStatement */:
+        case 258 /* TryStatement */:
           return checkTryStatement(node);
-        case 259 /* VariableDeclaration */:
+        case 260 /* VariableDeclaration */:
           return checkVariableDeclaration(node);
-        case 207 /* BindingElement */:
+        case 208 /* BindingElement */:
           return checkBindingElement(node);
-        case 262 /* ClassDeclaration */:
+        case 263 /* ClassDeclaration */:
           return checkClassDeclaration(node);
-        case 263 /* InterfaceDeclaration */:
+        case 264 /* InterfaceDeclaration */:
           return checkInterfaceDeclaration(node);
-        case 264 /* TypeAliasDeclaration */:
+        case 265 /* TypeAliasDeclaration */:
           return checkTypeAliasDeclaration(node);
-        case 265 /* EnumDeclaration */:
+        case 266 /* EnumDeclaration */:
           return checkEnumDeclaration(node);
-        case 266 /* ModuleDeclaration */:
+        case 267 /* ModuleDeclaration */:
           return checkModuleDeclaration(node);
-        case 271 /* ImportDeclaration */:
+        case 272 /* ImportDeclaration */:
           return checkImportDeclaration(node);
-        case 270 /* ImportEqualsDeclaration */:
+        case 271 /* ImportEqualsDeclaration */:
           return checkImportEqualsDeclaration(node);
-        case 277 /* ExportDeclaration */:
+        case 278 /* ExportDeclaration */:
           return checkExportDeclaration(node);
-        case 276 /* ExportAssignment */:
+        case 277 /* ExportAssignment */:
           return checkExportAssignment(node);
-        case 241 /* EmptyStatement */:
-        case 258 /* DebuggerStatement */:
+        case 242 /* EmptyStatement */:
+        case 259 /* DebuggerStatement */:
           checkGrammarStatementInAmbientContext(node);
           return;
-        case 281 /* MissingDeclaration */:
+        case 282 /* MissingDeclaration */:
           return checkMissingDeclaration(node);
       }
     }
@@ -181570,9 +165534,14 @@ ${lanes.join("\n")}
           const diagnostic = node.postfix ? Diagnostics._0_at_the_end_of_a_type_is_not_valid_TypeScript_syntax_Did_you_mean_to_write_1 : Diagnostics._0_at_the_start_of_a_type_is_not_valid_TypeScript_syntax_Did_you_mean_to_write_1;
           const typeNode = node.type;
           const type = getTypeFromTypeNode(typeNode);
-          grammarErrorOnNode(node, diagnostic, token, typeToString(
-            isJSDocNullableType(node) && !(type === neverType || type === voidType) ? getUnionType(append([type, undefinedType], node.postfix ? void 0 : nullType)) : type
-          ));
+          grammarErrorOnNode(
+            node,
+            diagnostic,
+            token,
+            typeToString(
+              isJSDocNullableType(node) && !(type === neverType || type === voidType) ? getUnionType(append([type, undefinedType], node.postfix ? void 0 : nullType)) : type
+            )
+          );
         } else {
           grammarErrorOnNode(node, Diagnostics.JSDoc_types_can_only_be_used_inside_documentation_comments);
         }
@@ -181584,16 +165553,16 @@ ${lanes.join("\n")}
       const { parent: parent2 } = node;
       if (isParameter(parent2) && isJSDocFunctionType(parent2.parent)) {
         if (last(parent2.parent.parameters) !== parent2) {
-          error(node, Diagnostics.A_rest_parameter_must_be_last_in_a_parameter_list);
+          error2(node, Diagnostics.A_rest_parameter_must_be_last_in_a_parameter_list);
         }
         return;
       }
       if (!isJSDocTypeExpression(parent2)) {
-        error(node, Diagnostics.JSDoc_may_only_appear_in_the_last_parameter_of_a_signature);
+        error2(node, Diagnostics.JSDoc_may_only_appear_in_the_last_parameter_of_a_signature);
       }
       const paramTag = node.parent.parent;
       if (!isJSDocParameterTag(paramTag)) {
-        error(node, Diagnostics.JSDoc_may_only_appear_in_the_last_parameter_of_a_signature);
+        error2(node, Diagnostics.JSDoc_may_only_appear_in_the_last_parameter_of_a_signature);
         return;
       }
       const param = getParameterSymbolFromJSDoc(paramTag);
@@ -181602,7 +165571,7 @@ ${lanes.join("\n")}
       }
       const host2 = getHostSignatureFromJSDoc(paramTag);
       if (!host2 || last(host2.parameters).symbol !== param) {
-        error(node, Diagnostics.A_rest_parameter_must_be_last_in_a_parameter_list);
+        error2(node, Diagnostics.A_rest_parameter_must_be_last_in_a_parameter_list);
       }
     }
     function getTypeFromJSDocVariadicType(node) {
@@ -181649,39 +165618,48 @@ ${lanes.join("\n")}
       currentNode = node;
       instantiationCount = 0;
       switch (node.kind) {
-        case 212 /* CallExpression */:
-        case 213 /* NewExpression */:
-        case 214 /* TaggedTemplateExpression */:
-        case 169 /* Decorator */:
-        case 285 /* JsxOpeningElement */:
+        case 213 /* CallExpression */:
+        case 214 /* NewExpression */:
+        case 215 /* TaggedTemplateExpression */:
+        case 170 /* Decorator */:
+        case 286 /* JsxOpeningElement */:
           resolveUntypedCall(node);
           break;
-        case 217 /* FunctionExpression */:
-        case 218 /* ArrowFunction */:
-        case 173 /* MethodDeclaration */:
-        case 172 /* MethodSignature */:
+        case 218 /* FunctionExpression */:
+        case 219 /* ArrowFunction */:
+        case 174 /* MethodDeclaration */:
+        case 173 /* MethodSignature */:
           checkFunctionExpressionOrObjectLiteralMethodDeferred(node);
           break;
-        case 176 /* GetAccessor */:
-        case 177 /* SetAccessor */:
+        case 177 /* GetAccessor */:
+        case 178 /* SetAccessor */:
           checkAccessorDeclaration(node);
           break;
-        case 230 /* ClassExpression */:
+        case 231 /* ClassExpression */:
           checkClassExpressionDeferred(node);
           break;
-        case 167 /* TypeParameter */:
+        case 168 /* TypeParameter */:
           checkTypeParameterDeferred(node);
           break;
-        case 284 /* JsxSelfClosingElement */:
+        case 285 /* JsxSelfClosingElement */:
           checkJsxSelfClosingElementDeferred(node);
           break;
-        case 283 /* JsxElement */:
+        case 284 /* JsxElement */:
           checkJsxElementDeferred(node);
           break;
-        case 215 /* TypeAssertionExpression */:
-        case 233 /* AsExpression */:
-        case 216 /* ParenthesizedExpression */:
+        case 216 /* TypeAssertionExpression */:
+        case 234 /* AsExpression */:
+        case 217 /* ParenthesizedExpression */:
           checkAssertionDeferred(node);
+          break;
+        case 222 /* VoidExpression */:
+          checkExpression(node.expression);
+          break;
+        case 226 /* BinaryExpression */:
+          if (isInstanceOfExpression(node)) {
+            resolveUntypedCall(node);
+          }
+          break;
       }
       currentNode = saveCurrentNode;
       (_b = tracing) == null ? void 0 : _b.pop();
@@ -181738,7 +165716,7 @@ ${lanes.join("\n")}
         addLazyDiagnostic(() => {
           if (!node.isDeclarationFile && (compilerOptions.noUnusedLocals || compilerOptions.noUnusedParameters)) {
             checkUnusedIdentifiers(getPotentiallyUnusedIdentifiers(node), (containingNode, kind, diag2) => {
-              if (!containsParseError(containingNode) && unusedIsError(kind, !!(containingNode.flags & 16777216 /* Ambient */))) {
+              if (!containsParseError(containingNode) && unusedIsError(kind, !!(containingNode.flags & 33554432 /* Ambient */))) {
                 diagnostics.add(diag2);
               }
             });
@@ -181817,7 +165795,7 @@ ${lanes.join("\n")}
       return diagnostics.getGlobalDiagnostics();
     }
     function getSymbolsInScope(location, meaning) {
-      if (location.flags & 33554432 /* InWithStatement */) {
+      if (location.flags & 67108864 /* InWithStatement */) {
         return [];
       }
       const symbols = createSymbolTable();
@@ -181831,27 +165809,27 @@ ${lanes.join("\n")}
             copySymbols(location.locals, meaning);
           }
           switch (location.kind) {
-            case 311 /* SourceFile */:
+            case 312 /* SourceFile */:
               if (!isExternalModule(location))
                 break;
-            case 266 /* ModuleDeclaration */:
+            case 267 /* ModuleDeclaration */:
               copyLocallyVisibleExportSymbols(getSymbolOfDeclaration(location).exports, meaning & 2623475 /* ModuleMember */);
               break;
-            case 265 /* EnumDeclaration */:
+            case 266 /* EnumDeclaration */:
               copySymbols(getSymbolOfDeclaration(location).exports, meaning & 8 /* EnumMember */);
               break;
-            case 230 /* ClassExpression */:
+            case 231 /* ClassExpression */:
               const className = location.name;
               if (className) {
                 copySymbol(location.symbol, meaning);
               }
-            case 262 /* ClassDeclaration */:
-            case 263 /* InterfaceDeclaration */:
+            case 263 /* ClassDeclaration */:
+            case 264 /* InterfaceDeclaration */:
               if (!isStaticSymbol) {
                 copySymbols(getMembersOfSymbol(getSymbolOfDeclaration(location)), meaning & 788968 /* Type */);
               }
               break;
-            case 217 /* FunctionExpression */:
+            case 218 /* FunctionExpression */:
               const funcName = location.name;
               if (funcName) {
                 copySymbol(location.symbol, meaning);
@@ -181884,7 +165862,7 @@ ${lanes.join("\n")}
       function copyLocallyVisibleExportSymbols(source, meaning2) {
         if (meaning2) {
           source.forEach((symbol) => {
-            if (!getDeclarationOfKind(symbol, 280 /* ExportSpecifier */) && !getDeclarationOfKind(symbol, 279 /* NamespaceExport */)) {
+            if (!getDeclarationOfKind(symbol, 281 /* ExportSpecifier */) && !getDeclarationOfKind(symbol, 280 /* NamespaceExport */) && symbol.escapedName !== "default" /* Default */) {
               copySymbol(symbol, meaning2);
             }
           });
@@ -181895,16 +165873,16 @@ ${lanes.join("\n")}
       return name.kind === 80 /* Identifier */ && isTypeDeclaration(name.parent) && getNameOfDeclaration(name.parent) === name;
     }
     function isTypeReferenceIdentifier(node) {
-      while (node.parent.kind === 165 /* QualifiedName */) {
+      while (node.parent.kind === 166 /* QualifiedName */) {
         node = node.parent;
       }
-      return node.parent.kind === 182 /* TypeReference */;
+      return node.parent.kind === 183 /* TypeReference */;
     }
     function isInNameOfExpressionWithTypeArguments(node) {
-      while (node.parent.kind === 210 /* PropertyAccessExpression */) {
+      while (node.parent.kind === 211 /* PropertyAccessExpression */) {
         node = node.parent;
       }
-      return node.parent.kind === 232 /* ExpressionWithTypeArguments */;
+      return node.parent.kind === 233 /* ExpressionWithTypeArguments */;
     }
     function forEachEnclosingClass(node, callback) {
       let result;
@@ -181930,13 +165908,13 @@ ${lanes.join("\n")}
       return !!forEachEnclosingClass(node, (n) => n === classDeclaration);
     }
     function getLeftSideOfImportEqualsOrExportAssignment(nodeOnRightSide) {
-      while (nodeOnRightSide.parent.kind === 165 /* QualifiedName */) {
+      while (nodeOnRightSide.parent.kind === 166 /* QualifiedName */) {
         nodeOnRightSide = nodeOnRightSide.parent;
       }
-      if (nodeOnRightSide.parent.kind === 270 /* ImportEqualsDeclaration */) {
+      if (nodeOnRightSide.parent.kind === 271 /* ImportEqualsDeclaration */) {
         return nodeOnRightSide.parent.moduleReference === nodeOnRightSide ? nodeOnRightSide.parent : void 0;
       }
-      if (nodeOnRightSide.parent.kind === 276 /* ExportAssignment */) {
+      if (nodeOnRightSide.parent.kind === 277 /* ExportAssignment */) {
         return nodeOnRightSide.parent.expression === nodeOnRightSide ? nodeOnRightSide.parent : void 0;
       }
       return void 0;
@@ -181962,7 +165940,7 @@ ${lanes.join("\n")}
         node = parent2;
         parent2 = parent2.parent;
       }
-      if (parent2 && parent2.kind === 204 /* ImportType */ && parent2.qualifier === node) {
+      if (parent2 && parent2.kind === 205 /* ImportType */ && parent2.qualifier === node) {
         return parent2;
       }
       return void 0;
@@ -181984,7 +165962,7 @@ ${lanes.join("\n")}
               /*contextFlags*/
               void 0
             );
-            const type = contextualType && getThisTypeFromContextualType(contextualType);
+            const type = getThisTypeOfObjectLiteralFromContextualType(containingLiteral, contextualType);
             return type && !isTypeAny(type);
           }
         }
@@ -181994,7 +165972,7 @@ ${lanes.join("\n")}
       if (isDeclarationName(name)) {
         return getSymbolOfNode(name.parent);
       }
-      if (isInJSFile(name) && name.parent.kind === 210 /* PropertyAccessExpression */ && name.parent === name.parent.parent.left) {
+      if (isInJSFile(name) && name.parent.kind === 211 /* PropertyAccessExpression */ && name.parent === name.parent.parent.left) {
         if (!isPrivateIdentifier(name) && !isJSDocMemberName(name) && !isThisPropertyAndThisTyped(name.parent)) {
           const specialPropertyAssignmentSymbol = getSpecialPropertyAssignmentSymbolFromEntityName(name);
           if (specialPropertyAssignmentSymbol) {
@@ -182002,7 +165980,7 @@ ${lanes.join("\n")}
           }
         }
       }
-      if (name.parent.kind === 276 /* ExportAssignment */ && isEntityNameExpression(name)) {
+      if (name.parent.kind === 277 /* ExportAssignment */ && isEntityNameExpression(name)) {
         const success = resolveEntityName(
           name,
           /*all meanings*/
@@ -182014,7 +165992,7 @@ ${lanes.join("\n")}
           return success;
         }
       } else if (isEntityName(name) && isInRightSideOfImportOrExportAssignment(name)) {
-        const importEqualsDeclaration = getAncestor(name, 270 /* ImportEqualsDeclaration */);
+        const importEqualsDeclaration = getAncestor(name, 271 /* ImportEqualsDeclaration */);
         Debug.assert(importEqualsDeclaration !== void 0);
         return getSymbolOfPartOfRightHandSideOfImportEquals(
           name,
@@ -182035,7 +166013,7 @@ ${lanes.join("\n")}
       }
       if (isInNameOfExpressionWithTypeArguments(name)) {
         let meaning = 0 /* None */;
-        if (name.parent.kind === 232 /* ExpressionWithTypeArguments */) {
+        if (name.parent.kind === 233 /* ExpressionWithTypeArguments */) {
           meaning = isPartOfTypeNode(name) ? 788968 /* Type */ : 111551 /* Value */;
           if (isExpressionWithTypeArgumentsInClassExtendsClause(name.parent)) {
             meaning |= 111551 /* Value */;
@@ -182054,10 +166032,10 @@ ${lanes.join("\n")}
           return entityNameSymbol;
         }
       }
-      if (name.parent.kind === 347 /* JSDocParameterTag */) {
+      if (name.parent.kind === 348 /* JSDocParameterTag */) {
         return getParameterSymbolFromJSDoc(name.parent);
       }
-      if (name.parent.kind === 167 /* TypeParameter */ && name.parent.parent.kind === 351 /* JSDocTemplateTag */) {
+      if (name.parent.kind === 168 /* TypeParameter */ && name.parent.parent.kind === 352 /* JSDocTemplateTag */) {
         Debug.assert(!isInJSFile(name));
         const typeParameter = getTypeParameterFromJsDoc(name.parent);
         return typeParameter && typeParameter.symbol;
@@ -182110,39 +166088,15 @@ ${lanes.join("\n")}
           return result;
         } else if (isPrivateIdentifier(name)) {
           return getSymbolForPrivateIdentifierExpression(name);
-        } else if (name.kind === 210 /* PropertyAccessExpression */ || name.kind === 165 /* QualifiedName */) {
+        } else if (name.kind === 211 /* PropertyAccessExpression */ || name.kind === 166 /* QualifiedName */) {
           const links = getNodeLinks(name);
           if (links.resolvedSymbol) {
             return links.resolvedSymbol;
           }
-          if (name.kind === 210 /* PropertyAccessExpression */) {
+          if (name.kind === 211 /* PropertyAccessExpression */) {
             checkPropertyAccessExpression(name, 0 /* Normal */);
             if (!links.resolvedSymbol) {
-              const expressionType = checkExpressionCached(name.expression);
-              const infos = getApplicableIndexInfos(expressionType, getLiteralTypeFromPropertyName(name.name));
-              if (infos.length && expressionType.members) {
-                const resolved = resolveStructuredTypeMembers(expressionType);
-                const symbol = resolved.members.get("__index" /* Index */);
-                if (infos === getIndexInfosOfType(expressionType)) {
-                  links.resolvedSymbol = symbol;
-                } else if (symbol) {
-                  const symbolLinks2 = getSymbolLinks(symbol);
-                  const declarationList = mapDefined(infos, (i) => i.declaration);
-                  const nodeListId = map(declarationList, getNodeId).join(",");
-                  if (!symbolLinks2.filteredIndexSymbolCache) {
-                    symbolLinks2.filteredIndexSymbolCache = /* @__PURE__ */ new Map();
-                  }
-                  if (symbolLinks2.filteredIndexSymbolCache.has(nodeListId)) {
-                    links.resolvedSymbol = symbolLinks2.filteredIndexSymbolCache.get(nodeListId);
-                  } else {
-                    const copy = createSymbol(131072 /* Signature */, "__index" /* Index */);
-                    copy.declarations = mapDefined(infos, (i) => i.declaration);
-                    copy.parent = expressionType.aliasSymbol ? expressionType.aliasSymbol : expressionType.symbol ? expressionType.symbol : getSymbolAtLocation(copy.declarations[0].parent);
-                    symbolLinks2.filteredIndexSymbolCache.set(nodeListId, copy);
-                    links.resolvedSymbol = symbolLinks2.filteredIndexSymbolCache.get(nodeListId);
-                  }
-                }
-              }
+              links.resolvedSymbol = getApplicableIndexSymbol(checkExpressionCached(name.expression), getLiteralTypeFromPropertyName(name.name));
             }
           } else {
             checkQualifiedName(name, 0 /* Normal */);
@@ -182155,7 +166109,7 @@ ${lanes.join("\n")}
           return resolveJSDocMemberName(name);
         }
       } else if (isTypeReferenceIdentifier(name)) {
-        const meaning = name.parent.kind === 182 /* TypeReference */ ? 788968 /* Type */ : 1920 /* Namespace */;
+        const meaning = name.parent.kind === 183 /* TypeReference */ ? 788968 /* Type */ : 1920 /* Namespace */;
         const symbol = resolveEntityName(
           name,
           meaning,
@@ -182166,7 +166120,7 @@ ${lanes.join("\n")}
         );
         return symbol && symbol !== unknownSymbol ? symbol : getUnresolvedSymbolForEntityName(name);
       }
-      if (name.parent.kind === 181 /* TypePredicate */) {
+      if (name.parent.kind === 182 /* TypePredicate */) {
         return resolveEntityName(
           name,
           /*meaning*/
@@ -182175,6 +166129,31 @@ ${lanes.join("\n")}
       }
       return void 0;
     }
+    function getApplicableIndexSymbol(type, keyType) {
+      const infos = getApplicableIndexInfos(type, keyType);
+      if (infos.length && type.members) {
+        const symbol = getIndexSymbolFromSymbolTable(resolveStructuredTypeMembers(type).members);
+        if (infos === getIndexInfosOfType(type)) {
+          return symbol;
+        } else if (symbol) {
+          const symbolLinks2 = getSymbolLinks(symbol);
+          const declarationList = mapDefined(infos, (i) => i.declaration);
+          const nodeListId = map(declarationList, getNodeId).join(",");
+          if (!symbolLinks2.filteredIndexSymbolCache) {
+            symbolLinks2.filteredIndexSymbolCache = /* @__PURE__ */ new Map();
+          }
+          if (symbolLinks2.filteredIndexSymbolCache.has(nodeListId)) {
+            return symbolLinks2.filteredIndexSymbolCache.get(nodeListId);
+          } else {
+            const copy = createSymbol(131072 /* Signature */, "__index" /* Index */);
+            copy.declarations = mapDefined(infos, (i) => i.declaration);
+            copy.parent = type.aliasSymbol ? type.aliasSymbol : type.symbol ? type.symbol : getSymbolAtLocation(copy.declarations[0].parent);
+            symbolLinks2.filteredIndexSymbolCache.set(nodeListId, copy);
+            return copy;
+          }
+        }
+      }
+    }
     function resolveJSDocMemberName(name, ignoreErrors, container) {
       if (isEntityName(name)) {
         const meaning = 788968 /* Type */ | 1920 /* Namespace */ | 111551 /* Value */;
@@ -182207,7 +166186,7 @@ ${lanes.join("\n")}
       }
       const { parent: parent2 } = node;
       const grandParent = parent2.parent;
-      if (node.flags & 33554432 /* InWithStatement */) {
+      if (node.flags & 67108864 /* InWithStatement */) {
         return void 0;
       }
       if (isDeclarationNameOrImportPropertyName(node)) {
@@ -182219,7 +166198,7 @@ ${lanes.join("\n")}
       if (node.kind === 80 /* Identifier */) {
         if (isInRightSideOfImportOrExportAssignment(node)) {
           return getSymbolOfNameOrPropertyAccessExpression(node);
-        } else if (parent2.kind === 207 /* BindingElement */ && grandParent.kind === 205 /* ObjectBindingPattern */ && node === parent2.propertyName) {
+        } else if (parent2.kind === 208 /* BindingElement */ && grandParent.kind === 206 /* ObjectBindingPattern */ && node === parent2.propertyName) {
           const typeOfPattern = getTypeOfNode(grandParent);
           const propertyDeclaration = getPropertyOfType(typeOfPattern, node.escapedText);
           if (propertyDeclaration) {
@@ -182238,8 +166217,8 @@ ${lanes.join("\n")}
       switch (node.kind) {
         case 80 /* Identifier */:
         case 81 /* PrivateIdentifier */:
-        case 210 /* PropertyAccessExpression */:
-        case 165 /* QualifiedName */:
+        case 211 /* PropertyAccessExpression */:
+        case 166 /* QualifiedName */:
           if (!isThisInTypeQuery(node)) {
             return getSymbolOfNameOrPropertyAccessExpression(node);
           }
@@ -182260,19 +166239,19 @@ ${lanes.join("\n")}
           if (isInExpressionContext(node)) {
             return checkExpression(node).symbol;
           }
-        case 196 /* ThisType */:
+        case 197 /* ThisType */:
           return getTypeFromThisTypeNode(node).symbol;
         case 108 /* SuperKeyword */:
           return checkExpression(node).symbol;
         case 137 /* ConstructorKeyword */:
           const constructorDeclaration = node.parent;
-          if (constructorDeclaration && constructorDeclaration.kind === 175 /* Constructor */) {
+          if (constructorDeclaration && constructorDeclaration.kind === 176 /* Constructor */) {
             return constructorDeclaration.parent.symbol;
           }
           return void 0;
         case 11 /* StringLiteral */:
         case 15 /* NoSubstitutionTemplateLiteral */:
-          if (isExternalModuleImportEqualsDeclaration(node.parent.parent) && getExternalModuleImportEqualsDeclarationExpression(node.parent.parent) === node || (node.parent.kind === 271 /* ImportDeclaration */ || node.parent.kind === 277 /* ExportDeclaration */) && node.parent.moduleSpecifier === node || (isInJSFile(node) && getEmitModuleResolutionKind(compilerOptions) !== 100 /* Bundler */ && isRequireCall(
+          if (isExternalModuleImportEqualsDeclaration(node.parent.parent) && getExternalModuleImportEqualsDeclarationExpression(node.parent.parent) === node || (node.parent.kind === 272 /* ImportDeclaration */ || node.parent.kind === 278 /* ExportDeclaration */) && node.parent.moduleSpecifier === node || (isInJSFile(node) && getEmitModuleResolutionKind(compilerOptions) !== 100 /* Bundler */ && isRequireCall(
             node.parent,
             /*requireStringLiteralLikeArgument*/
             false
@@ -182290,16 +166269,23 @@ ${lanes.join("\n")}
         case 39 /* EqualsGreaterThanToken */:
         case 86 /* ClassKeyword */:
           return getSymbolOfNode(node.parent);
-        case 204 /* ImportType */:
+        case 205 /* ImportType */:
           return isLiteralImportTypeNode(node) ? getSymbolAtLocation(node.argument.literal, ignoreErrors) : void 0;
         case 95 /* ExportKeyword */:
           return isExportAssignment(node.parent) ? Debug.checkDefined(node.parent.symbol) : void 0;
         case 102 /* ImportKeyword */:
         case 105 /* NewKeyword */:
           return isMetaProperty(node.parent) ? checkMetaPropertyKeyword(node.parent).symbol : void 0;
-        case 235 /* MetaProperty */:
+        case 104 /* InstanceOfKeyword */:
+          if (isBinaryExpression(node.parent)) {
+            const type = getTypeOfExpression(node.parent.right);
+            const hasInstanceMethodType = getSymbolHasInstanceMethodOfObjectType(type);
+            return (hasInstanceMethodType == null ? void 0 : hasInstanceMethodType.symbol) ?? type.symbol;
+          }
+          return void 0;
+        case 236 /* MetaProperty */:
           return checkExpression(node).symbol;
-        case 294 /* JsxNamespacedName */:
+        case 295 /* JsxNamespacedName */:
           if (isJSXTagName(node) && isJsxIntrinsicTagName(node)) {
             const symbol = getIntrinsicTagSymbol(node.parent);
             return symbol === unknownSymbol ? void 0 : symbol;
@@ -182318,7 +166304,7 @@ ${lanes.join("\n")}
       return void 0;
     }
     function getShorthandAssignmentValueSymbol(location) {
-      if (location && location.kind === 303 /* ShorthandPropertyAssignment */) {
+      if (location && location.kind === 304 /* ShorthandPropertyAssignment */) {
         return resolveEntityName(location.name, 111551 /* Value */ | 2097152 /* Alias */);
       }
       return void 0;
@@ -182334,7 +166320,7 @@ ${lanes.join("\n")}
       if (isSourceFile(node) && !isExternalModule(node)) {
         return errorType;
       }
-      if (node.flags & 33554432 /* InWithStatement */) {
+      if (node.flags & 67108864 /* InWithStatement */) {
         return errorType;
       }
       const classDecl = tryGetClassImplementingOrExtendingExpressionWithTypeArguments(node);
@@ -182398,16 +166384,16 @@ ${lanes.join("\n")}
       return errorType;
     }
     function getTypeOfAssignmentPattern(expr) {
-      Debug.assert(expr.kind === 209 /* ObjectLiteralExpression */ || expr.kind === 208 /* ArrayLiteralExpression */);
-      if (expr.parent.kind === 249 /* ForOfStatement */) {
+      Debug.assert(expr.kind === 210 /* ObjectLiteralExpression */ || expr.kind === 209 /* ArrayLiteralExpression */);
+      if (expr.parent.kind === 250 /* ForOfStatement */) {
         const iteratedType = checkRightHandSideOfForOf(expr.parent);
         return checkDestructuringAssignment(expr, iteratedType || errorType);
       }
-      if (expr.parent.kind === 225 /* BinaryExpression */) {
+      if (expr.parent.kind === 226 /* BinaryExpression */) {
         const iteratedType = getTypeOfExpression(expr.parent.right);
         return checkDestructuringAssignment(expr, iteratedType || errorType);
       }
-      if (expr.parent.kind === 302 /* PropertyAssignment */) {
+      if (expr.parent.kind === 303 /* PropertyAssignment */) {
         const node2 = cast(expr.parent.parent, isObjectLiteralExpression);
         const typeOfParentObjectLiteral = getTypeOfAssignmentPattern(node2) || errorType;
         const propertyIndex = indexOfNode(node2.properties, expr.parent);
@@ -182440,7 +166426,7 @@ ${lanes.join("\n")}
         case 9 /* NumericLiteral */:
         case 11 /* StringLiteral */:
           return getStringLiteralType(name.text);
-        case 166 /* ComputedPropertyName */:
+        case 167 /* ComputedPropertyName */:
           const nameType = checkComputedPropertyName(name);
           return isTypeAssignableToKind(nameType, 12288 /* ESSymbolLike */) ? nameType : stringType;
         default:
@@ -182510,7 +166496,7 @@ ${lanes.join("\n")}
       return symbolLinks2.exportsSomeValue;
       function isValue(s) {
         s = resolveSymbol(s);
-        return s && !!(getAllSymbolFlags(s) & 111551 /* Value */);
+        return s && !!(getSymbolFlags(s) & 111551 /* Value */);
       }
     }
     function isNameOfModuleOrEnumDeclaration(node) {
@@ -182535,7 +166521,7 @@ ${lanes.join("\n")}
           }
           const parentSymbol = getParentOfSymbol(symbol);
           if (parentSymbol) {
-            if (parentSymbol.flags & 512 /* ValueModule */ && ((_a = parentSymbol.valueDeclaration) == null ? void 0 : _a.kind) === 311 /* SourceFile */) {
+            if (parentSymbol.flags & 512 /* ValueModule */ && ((_a = parentSymbol.valueDeclaration) == null ? void 0 : _a.kind) === 312 /* SourceFile */) {
               const symbolFile = parentSymbol.valueDeclaration;
               const referenceFile = getSourceFileOfNode(node);
               const symbolIsUmdExport = symbolFile !== referenceFile;
@@ -182565,7 +166551,7 @@ ${lanes.join("\n")}
       return void 0;
     }
     function isSymbolOfDestructuredElementOfCatchBinding(symbol) {
-      return symbol.valueDeclaration && isBindingElement(symbol.valueDeclaration) && walkUpBindingElementsAndPatterns(symbol.valueDeclaration).parent.kind === 298 /* CatchClause */;
+      return symbol.valueDeclaration && isBindingElement(symbol.valueDeclaration) && walkUpBindingElementsAndPatterns(symbol.valueDeclaration).parent.kind === 299 /* CatchClause */;
     }
     function isSymbolOfDeclarationWithCollidingName(symbol) {
       if (symbol.flags & 418 /* BlockScoped */ && symbol.valueDeclaration && !isSourceFile(symbol.valueDeclaration)) {
@@ -182593,7 +166579,7 @@ ${lanes.join("\n")}
                 /*lookInLabeledStatements*/
                 false
               );
-              const inLoopBodyBlock = container.kind === 240 /* Block */ && isIterationStatement(
+              const inLoopBodyBlock = container.kind === 241 /* Block */ && isIterationStatement(
                 container.parent,
                 /*lookInLabeledStatements*/
                 false
@@ -182633,39 +166619,48 @@ ${lanes.join("\n")}
     function isValueAliasDeclaration(node) {
       Debug.assert(canCollectSymbolAliasAccessabilityData);
       switch (node.kind) {
-        case 270 /* ImportEqualsDeclaration */:
+        case 271 /* ImportEqualsDeclaration */:
           return isAliasResolvedToValue(getSymbolOfDeclaration(node));
-        case 272 /* ImportClause */:
-        case 273 /* NamespaceImport */:
-        case 275 /* ImportSpecifier */:
-        case 280 /* ExportSpecifier */:
+        case 273 /* ImportClause */:
+        case 274 /* NamespaceImport */:
+        case 276 /* ImportSpecifier */:
+        case 281 /* ExportSpecifier */:
           const symbol = getSymbolOfDeclaration(node);
-          return !!symbol && isAliasResolvedToValue(symbol) && !getTypeOnlyAliasDeclaration(symbol, 111551 /* Value */);
-        case 277 /* ExportDeclaration */:
+          return !!symbol && isAliasResolvedToValue(
+            symbol,
+            /*excludeTypeOnlyValues*/
+            true
+          );
+        case 278 /* ExportDeclaration */:
           const exportClause = node.exportClause;
           return !!exportClause && (isNamespaceExport(exportClause) || some(exportClause.elements, isValueAliasDeclaration));
-        case 276 /* ExportAssignment */:
+        case 277 /* ExportAssignment */:
           return node.expression && node.expression.kind === 80 /* Identifier */ ? isAliasResolvedToValue(getSymbolOfDeclaration(node)) : true;
       }
       return false;
     }
     function isTopLevelValueImportEqualsWithEntityName(nodeIn) {
       const node = getParseTreeNode(nodeIn, isImportEqualsDeclaration);
-      if (node === void 0 || node.parent.kind !== 311 /* SourceFile */ || !isInternalModuleImportEqualsDeclaration(node)) {
+      if (node === void 0 || node.parent.kind !== 312 /* SourceFile */ || !isInternalModuleImportEqualsDeclaration(node)) {
         return false;
       }
       const isValue = isAliasResolvedToValue(getSymbolOfDeclaration(node));
       return isValue && node.moduleReference && !nodeIsMissing(node.moduleReference);
     }
-    function isAliasResolvedToValue(symbol) {
+    function isAliasResolvedToValue(symbol, excludeTypeOnlyValues) {
       if (!symbol) {
         return false;
       }
       const target = getExportSymbolOfValueSymbolIfExported(resolveAlias(symbol));
       if (target === unknownSymbol) {
-        return true;
+        return !excludeTypeOnlyValues || !getTypeOnlyAliasDeclaration(symbol);
       }
-      return !!((getAllSymbolFlags(target) ?? -1) & 111551 /* Value */) && (shouldPreserveConstEnums(compilerOptions) || !isConstEnumOrConstEnumOnlyModule(target));
+      return !!(getSymbolFlags(
+        symbol,
+        excludeTypeOnlyValues,
+        /*excludeLocalMeanings*/
+        true
+      ) & 111551 /* Value */) && (shouldPreserveConstEnums(compilerOptions) || !isConstEnumOrConstEnumOnlyModule(target));
     }
     function isConstEnumOrConstEnumOnlyModule(s) {
       return isConstEnumSymbol(s) || !!s.constEnumOnlyModule;
@@ -182679,7 +166674,7 @@ ${lanes.join("\n")}
           return true;
         }
         const target = getSymbolLinks(symbol).aliasTarget;
-        if (target && getEffectiveModifierFlags(node) & 1 /* Export */ && getAllSymbolFlags(target) & 111551 /* Value */ && (shouldPreserveConstEnums(compilerOptions) || !isConstEnumOrConstEnumOnlyModule(target))) {
+        if (target && getEffectiveModifierFlags(node) & 32 /* Export */ && getSymbolFlags(target) & 111551 /* Value */ && (shouldPreserveConstEnums(compilerOptions) || !isConstEnumOrConstEnumOnlyModule(target))) {
           return true;
         }
       }
@@ -182704,10 +166699,10 @@ ${lanes.join("\n")}
       return false;
     }
     function isRequiredInitializedParameter(parameter) {
-      return !!strictNullChecks && !isOptionalParameter(parameter) && !isJSDocParameterTag(parameter) && !!parameter.initializer && !hasSyntacticModifier(parameter, 16476 /* ParameterPropertyModifier */);
+      return !!strictNullChecks && !isOptionalParameter(parameter) && !isJSDocParameterTag(parameter) && !!parameter.initializer && !hasSyntacticModifier(parameter, 31 /* ParameterPropertyModifier */);
     }
     function isOptionalUninitializedParameterProperty(parameter) {
-      return strictNullChecks && isOptionalParameter(parameter) && !parameter.initializer && hasSyntacticModifier(parameter, 16476 /* ParameterPropertyModifier */);
+      return strictNullChecks && isOptionalParameter(parameter) && !parameter.initializer && hasSyntacticModifier(parameter, 31 /* ParameterPropertyModifier */);
     }
     function isExpandoFunctionDeclaration(node) {
       const declaration = getParseTreeNode(node, isFunctionDeclaration);
@@ -182718,7 +166713,7 @@ ${lanes.join("\n")}
       if (!symbol || !(symbol.flags & 16 /* Function */)) {
         return false;
       }
-      return !!forEachEntry(getExportsOfSymbol(symbol), (p) => p.flags & 111551 /* Value */ && p.valueDeclaration && isPropertyAccessExpression(p.valueDeclaration));
+      return !!forEachEntry(getExportsOfSymbol(symbol), (p) => p.flags & 111551 /* Value */ && isExpandoPropertyDeclaration(p.valueDeclaration));
     }
     function getPropertiesOfContainerFunction(node) {
       const declaration = getParseTreeNode(node, isFunctionDeclaration);
@@ -182741,15 +166736,15 @@ ${lanes.join("\n")}
     }
     function canHaveConstantValue(node) {
       switch (node.kind) {
-        case 305 /* EnumMember */:
-        case 210 /* PropertyAccessExpression */:
-        case 211 /* ElementAccessExpression */:
+        case 306 /* EnumMember */:
+        case 211 /* PropertyAccessExpression */:
+        case 212 /* ElementAccessExpression */:
           return true;
       }
       return false;
     }
     function getConstantValue2(node) {
-      if (node.kind === 305 /* EnumMember */) {
+      if (node.kind === 306 /* EnumMember */) {
         return getEnumMemberValue(node);
       }
       const symbol = getNodeLinks(node).resolvedSymbol;
@@ -182949,24 +166944,24 @@ ${lanes.join("\n")}
           if (symbol) {
             return filter(getExportSymbolOfValueSymbolIfExported(symbol).declarations, (declaration) => {
               switch (declaration.kind) {
-                case 259 /* VariableDeclaration */:
-                case 168 /* Parameter */:
-                case 207 /* BindingElement */:
-                case 171 /* PropertyDeclaration */:
-                case 302 /* PropertyAssignment */:
-                case 303 /* ShorthandPropertyAssignment */:
-                case 305 /* EnumMember */:
-                case 209 /* ObjectLiteralExpression */:
-                case 261 /* FunctionDeclaration */:
-                case 217 /* FunctionExpression */:
-                case 218 /* ArrowFunction */:
-                case 262 /* ClassDeclaration */:
-                case 230 /* ClassExpression */:
-                case 265 /* EnumDeclaration */:
-                case 173 /* MethodDeclaration */:
-                case 176 /* GetAccessor */:
-                case 177 /* SetAccessor */:
-                case 266 /* ModuleDeclaration */:
+                case 260 /* VariableDeclaration */:
+                case 169 /* Parameter */:
+                case 208 /* BindingElement */:
+                case 172 /* PropertyDeclaration */:
+                case 303 /* PropertyAssignment */:
+                case 304 /* ShorthandPropertyAssignment */:
+                case 306 /* EnumMember */:
+                case 210 /* ObjectLiteralExpression */:
+                case 262 /* FunctionDeclaration */:
+                case 218 /* FunctionExpression */:
+                case 219 /* ArrowFunction */:
+                case 263 /* ClassDeclaration */:
+                case 231 /* ClassExpression */:
+                case 266 /* EnumDeclaration */:
+                case 174 /* MethodDeclaration */:
+                case 177 /* GetAccessor */:
+                case 178 /* SetAccessor */:
+                case 267 /* ModuleDeclaration */:
                   return true;
               }
               return false;
@@ -182977,7 +166972,7 @@ ${lanes.join("\n")}
       return void 0;
     }
     function isLiteralConstDeclaration(node) {
-      if (isDeclarationReadonly(node) || isVariableDeclaration(node) && isVarConst(node)) {
+      if (isDeclarationReadonly(node) || isVariableDeclaration(node) && isVarConstLike(node)) {
         return isFreshLiteralType(getTypeOfSymbol(getSymbolOfDeclaration(node)));
       }
       return false;
@@ -183095,12 +167090,12 @@ ${lanes.join("\n")}
         getJsxFragmentFactoryEntity,
         getAllAccessorDeclarations(accessor) {
           accessor = getParseTreeNode(accessor, isGetOrSetAccessorDeclaration);
-          const otherKind = accessor.kind === 177 /* SetAccessor */ ? 176 /* GetAccessor */ : 177 /* SetAccessor */;
+          const otherKind = accessor.kind === 178 /* SetAccessor */ ? 177 /* GetAccessor */ : 178 /* SetAccessor */;
           const otherAccessor = getDeclarationOfKind(getSymbolOfDeclaration(accessor), otherKind);
           const firstAccessor = otherAccessor && otherAccessor.pos < accessor.pos ? otherAccessor : accessor;
           const secondAccessor = otherAccessor && otherAccessor.pos < accessor.pos ? accessor : otherAccessor;
-          const setAccessor = accessor.kind === 177 /* SetAccessor */ ? accessor : otherAccessor;
-          const getAccessor = accessor.kind === 176 /* GetAccessor */ ? accessor : otherAccessor;
+          const setAccessor = accessor.kind === 178 /* SetAccessor */ ? accessor : otherAccessor;
+          const getAccessor = accessor.kind === 177 /* GetAccessor */ ? accessor : otherAccessor;
           return {
             firstAccessor,
             secondAccessor,
@@ -183121,14 +167116,23 @@ ${lanes.join("\n")}
         },
         getDeclarationStatementsForSourceFile: (node, flags, tracker, bundled) => {
           const n = getParseTreeNode(node);
-          Debug.assert(n && n.kind === 311 /* SourceFile */, "Non-sourcefile node passed into getDeclarationsForSourceFile");
+          Debug.assert(n && n.kind === 312 /* SourceFile */, "Non-sourcefile node passed into getDeclarationsForSourceFile");
           const sym = getSymbolOfDeclaration(node);
           if (!sym) {
             return !node.locals ? [] : nodeBuilder.symbolTableToDeclarationStatements(node.locals, node, flags, tracker, bundled);
           }
           return !sym.exports ? [] : nodeBuilder.symbolTableToDeclarationStatements(sym.exports, node, flags, tracker, bundled);
         },
-        isImportRequiredByAugmentation
+        isImportRequiredByAugmentation,
+        tryFindAmbientModule: (moduleReferenceExpression) => {
+          const node = getParseTreeNode(moduleReferenceExpression);
+          const moduleSpecifier = node && isStringLiteralLike(node) ? node.text : void 0;
+          return moduleSpecifier !== void 0 ? tryFindAmbientModule(
+            moduleSpecifier,
+            /*withAugmentations*/
+            true
+          ) : void 0;
+        }
       };
       function isImportRequiredByAugmentation(node) {
         const file = getSourceFileOfNode(node);
@@ -183156,18 +167160,18 @@ ${lanes.join("\n")}
         return false;
       }
       function isInHeritageClause(node) {
-        return node.parent && node.parent.kind === 232 /* ExpressionWithTypeArguments */ && node.parent.parent && node.parent.parent.kind === 297 /* HeritageClause */;
+        return node.parent && node.parent.kind === 233 /* ExpressionWithTypeArguments */ && node.parent.parent && node.parent.parent.kind === 298 /* HeritageClause */;
       }
       function getTypeReferenceDirectivesForEntityName(node) {
         if (!fileToDirective) {
           return void 0;
         }
         let meaning;
-        if (node.parent.kind === 166 /* ComputedPropertyName */) {
+        if (node.parent.kind === 167 /* ComputedPropertyName */) {
           meaning = 111551 /* Value */ | 1048576 /* ExportValue */;
         } else {
           meaning = 788968 /* Type */ | 1920 /* Namespace */;
-          if (node.kind === 80 /* Identifier */ && isInTypeQuery(node) || node.kind === 210 /* PropertyAccessExpression */ && !isInHeritageClause(node)) {
+          if (node.kind === 80 /* Identifier */ && isInTypeQuery(node) || node.kind === 211 /* PropertyAccessExpression */ && !isInHeritageClause(node)) {
             meaning = 111551 /* Value */ | 1048576 /* ExportValue */;
           }
         }
@@ -183210,7 +167214,7 @@ ${lanes.join("\n")}
             break;
           }
         }
-        if (current.valueDeclaration && current.valueDeclaration.kind === 311 /* SourceFile */ && current.flags & 512 /* ValueModule */) {
+        if (current.valueDeclaration && current.valueDeclaration.kind === 312 /* SourceFile */ && current.flags & 512 /* ValueModule */) {
           return false;
         }
         for (const decl of symbol.declarations) {
@@ -183225,17 +167229,17 @@ ${lanes.join("\n")}
         if (fileToDirective.has(file.path))
           return;
         fileToDirective.set(file.path, [key, mode]);
-        for (const { fileName, resolutionMode } of file.referencedFiles) {
+        for (const { fileName } of file.referencedFiles) {
           const resolvedFile = resolveTripleslashReference(fileName, file.fileName);
           const referencedFile = host.getSourceFile(resolvedFile);
           if (referencedFile) {
-            addReferencedFilesToTypeDirective(referencedFile, key, resolutionMode || file.impliedNodeFormat);
+            addReferencedFilesToTypeDirective(referencedFile, key, mode || file.impliedNodeFormat);
           }
         }
       }
     }
     function getExternalModuleFileFromDeclaration(declaration) {
-      const specifier = declaration.kind === 266 /* ModuleDeclaration */ ? tryCast(declaration.name, isStringLiteral) : getExternalModuleName(declaration);
+      const specifier = declaration.kind === 267 /* ModuleDeclaration */ ? tryCast(declaration.name, isStringLiteral) : getExternalModuleName(declaration);
       const moduleSymbol = resolveExternalModuleNameWorker(
         specifier,
         specifier,
@@ -183245,7 +167249,7 @@ ${lanes.join("\n")}
       if (!moduleSymbol) {
         return void 0;
       }
-      return getDeclarationOfKind(moduleSymbol, 311 /* SourceFile */);
+      return getDeclarationOfKind(moduleSymbol, 312 /* SourceFile */);
     }
     function initializeTypeChecker() {
       for (const file of host.getSourceFiles()) {
@@ -183427,11 +167431,11 @@ ${lanes.join("\n")}
     function checkExternalEmitHelpers(location, helpers) {
       if ((requestedExternalEmitHelpers & helpers) !== helpers && compilerOptions.importHelpers) {
         const sourceFile = getSourceFileOfNode(location);
-        if (isEffectiveExternalModule(sourceFile, compilerOptions) && !(location.flags & 16777216 /* Ambient */)) {
+        if (isEffectiveExternalModule(sourceFile, compilerOptions) && !(location.flags & 33554432 /* Ambient */)) {
           const helpersModule = resolveHelpersModule(sourceFile, location);
           if (helpersModule !== unknownSymbol) {
             const uncheckedHelpers = helpers & ~requestedExternalEmitHelpers;
-            for (let helper = 1 /* FirstEmitHelper */; helper <= 16777216 /* LastEmitHelper */; helper <<= 1) {
+            for (let helper = 1 /* FirstEmitHelper */; helper <= 33554432 /* LastEmitHelper */; helper <<= 1) {
               if (uncheckedHelpers & helper) {
                 for (const name of getHelperNames(helper)) {
                   if (requestedExternalEmitHelperNames.has(name))
@@ -183439,18 +167443,18 @@ ${lanes.join("\n")}
                   requestedExternalEmitHelperNames.add(name);
                   const symbol = resolveSymbol(getSymbol2(getExportsOfModule(helpersModule), escapeLeadingUnderscores(name), 111551 /* Value */));
                   if (!symbol) {
-                    error(location, Diagnostics.This_syntax_requires_an_imported_helper_named_1_which_does_not_exist_in_0_Consider_upgrading_your_version_of_0, externalHelpersModuleNameText, name);
+                    error2(location, Diagnostics.This_syntax_requires_an_imported_helper_named_1_which_does_not_exist_in_0_Consider_upgrading_your_version_of_0, externalHelpersModuleNameText, name);
                   } else if (helper & 524288 /* ClassPrivateFieldGet */) {
                     if (!some(getSignaturesOfSymbol(symbol), (signature) => getParameterCount(signature) > 3)) {
-                      error(location, Diagnostics.This_syntax_requires_an_imported_helper_named_1_with_2_parameters_which_is_not_compatible_with_the_one_in_0_Consider_upgrading_your_version_of_0, externalHelpersModuleNameText, name, 4);
+                      error2(location, Diagnostics.This_syntax_requires_an_imported_helper_named_1_with_2_parameters_which_is_not_compatible_with_the_one_in_0_Consider_upgrading_your_version_of_0, externalHelpersModuleNameText, name, 4);
                     }
                   } else if (helper & 1048576 /* ClassPrivateFieldSet */) {
                     if (!some(getSignaturesOfSymbol(symbol), (signature) => getParameterCount(signature) > 4)) {
-                      error(location, Diagnostics.This_syntax_requires_an_imported_helper_named_1_with_2_parameters_which_is_not_compatible_with_the_one_in_0_Consider_upgrading_your_version_of_0, externalHelpersModuleNameText, name, 5);
+                      error2(location, Diagnostics.This_syntax_requires_an_imported_helper_named_1_with_2_parameters_which_is_not_compatible_with_the_one_in_0_Consider_upgrading_your_version_of_0, externalHelpersModuleNameText, name, 5);
                     }
                   } else if (helper & 1024 /* SpreadArray */) {
                     if (!some(getSignaturesOfSymbol(symbol), (signature) => getParameterCount(signature) > 2)) {
-                      error(location, Diagnostics.This_syntax_requires_an_imported_helper_named_1_with_2_parameters_which_is_not_compatible_with_the_one_in_0_Consider_upgrading_your_version_of_0, externalHelpersModuleNameText, name, 3);
+                      error2(location, Diagnostics.This_syntax_requires_an_imported_helper_named_1_with_2_parameters_which_is_not_compatible_with_the_one_in_0_Consider_upgrading_your_version_of_0, externalHelpersModuleNameText, name, 3);
                     }
                   }
                 }
@@ -183513,6 +167517,8 @@ ${lanes.join("\n")}
           return ["__setFunctionName"];
         case 16777216 /* PropKey */:
           return ["__propKey"];
+        case 33554432 /* AddDisposableResourceAndDisposeResources */:
+          return ["__addDisposableResource", "__disposeResources"];
         default:
           return Debug.fail("Unrecognized helper");
       }
@@ -183531,6 +167537,7 @@ ${lanes.join("\n")}
       if (isParameter(node) && parameterIsThisKeyword(node)) {
         return grammarErrorOnFirstToken(node, Diagnostics.Neither_decorators_nor_modifiers_may_be_applied_to_this_parameters);
       }
+      const blockScopeKind = isVariableStatement(node) ? node.declarationList.flags & 7 /* BlockScoped */ : 0 /* None */;
       let lastStatic, lastDeclare, lastAsync, lastOverride, firstDecorator;
       let flags = 0 /* None */;
       let sawExportBeforeDecorators = false;
@@ -183538,97 +167545,97 @@ ${lanes.join("\n")}
       for (const modifier of node.modifiers) {
         if (isDecorator(modifier)) {
           if (!nodeCanBeDecorated(legacyDecorators, node, node.parent, node.parent.parent)) {
-            if (node.kind === 173 /* MethodDeclaration */ && !nodeIsPresent(node.body)) {
+            if (node.kind === 174 /* MethodDeclaration */ && !nodeIsPresent(node.body)) {
               return grammarErrorOnFirstToken(node, Diagnostics.A_decorator_can_only_decorate_a_method_implementation_not_an_overload);
             } else {
               return grammarErrorOnFirstToken(node, Diagnostics.Decorators_are_not_valid_here);
             }
-          } else if (legacyDecorators && (node.kind === 176 /* GetAccessor */ || node.kind === 177 /* SetAccessor */)) {
+          } else if (legacyDecorators && (node.kind === 177 /* GetAccessor */ || node.kind === 178 /* SetAccessor */)) {
             const accessors = getAllAccessorDeclarations(node.parent.members, node);
             if (hasDecorators(accessors.firstAccessor) && node === accessors.secondAccessor) {
               return grammarErrorOnFirstToken(node, Diagnostics.Decorators_cannot_be_applied_to_multiple_get_Slashset_accessors_of_the_same_name);
             }
           }
-          if (flags & ~(1025 /* ExportDefault */ | 131072 /* Decorator */)) {
+          if (flags & ~(2080 /* ExportDefault */ | 32768 /* Decorator */)) {
             return grammarErrorOnNode(modifier, Diagnostics.Decorators_are_not_valid_here);
           }
-          if (hasLeadingDecorators && flags & 126975 /* Modifier */) {
+          if (hasLeadingDecorators && flags & 98303 /* Modifier */) {
             Debug.assertIsDefined(firstDecorator);
             const sourceFile = getSourceFileOfNode(modifier);
             if (!hasParseDiagnostics(sourceFile)) {
               addRelatedInfo(
-                error(modifier, Diagnostics.Decorators_may_not_appear_after_export_or_export_default_if_they_also_appear_before_export),
+                error2(modifier, Diagnostics.Decorators_may_not_appear_after_export_or_export_default_if_they_also_appear_before_export),
                 createDiagnosticForNode(firstDecorator, Diagnostics.Decorator_used_before_export_here)
               );
               return true;
             }
             return false;
           }
-          flags |= 131072 /* Decorator */;
-          if (!(flags & 126975 /* Modifier */)) {
+          flags |= 32768 /* Decorator */;
+          if (!(flags & 98303 /* Modifier */)) {
             hasLeadingDecorators = true;
-          } else if (flags & 1 /* Export */) {
+          } else if (flags & 32 /* Export */) {
             sawExportBeforeDecorators = true;
           }
           firstDecorator ?? (firstDecorator = modifier);
         } else {
           if (modifier.kind !== 148 /* ReadonlyKeyword */) {
-            if (node.kind === 170 /* PropertySignature */ || node.kind === 172 /* MethodSignature */) {
+            if (node.kind === 171 /* PropertySignature */ || node.kind === 173 /* MethodSignature */) {
               return grammarErrorOnNode(modifier, Diagnostics._0_modifier_cannot_appear_on_a_type_member, tokenToString(modifier.kind));
             }
-            if (node.kind === 180 /* IndexSignature */ && (modifier.kind !== 126 /* StaticKeyword */ || !isClassLike(node.parent))) {
+            if (node.kind === 181 /* IndexSignature */ && (modifier.kind !== 126 /* StaticKeyword */ || !isClassLike(node.parent))) {
               return grammarErrorOnNode(modifier, Diagnostics._0_modifier_cannot_appear_on_an_index_signature, tokenToString(modifier.kind));
             }
           }
           if (modifier.kind !== 103 /* InKeyword */ && modifier.kind !== 147 /* OutKeyword */ && modifier.kind !== 87 /* ConstKeyword */) {
-            if (node.kind === 167 /* TypeParameter */) {
+            if (node.kind === 168 /* TypeParameter */) {
               return grammarErrorOnNode(modifier, Diagnostics._0_modifier_cannot_appear_on_a_type_parameter, tokenToString(modifier.kind));
             }
           }
           switch (modifier.kind) {
             case 87 /* ConstKeyword */:
-              if (node.kind !== 265 /* EnumDeclaration */ && node.kind !== 167 /* TypeParameter */) {
+              if (node.kind !== 266 /* EnumDeclaration */ && node.kind !== 168 /* TypeParameter */) {
                 return grammarErrorOnNode(node, Diagnostics.A_class_member_cannot_have_the_0_keyword, tokenToString(87 /* ConstKeyword */));
               }
               const parent2 = node.parent;
-              if (node.kind === 167 /* TypeParameter */ && !(isFunctionLikeDeclaration(parent2) || isClassLike(parent2) || isFunctionTypeNode(parent2) || isConstructorTypeNode(parent2) || isCallSignatureDeclaration(parent2) || isConstructSignatureDeclaration(parent2) || isMethodSignature(parent2))) {
+              if (node.kind === 168 /* TypeParameter */ && !(isFunctionLikeDeclaration(parent2) || isClassLike(parent2) || isFunctionTypeNode(parent2) || isConstructorTypeNode(parent2) || isCallSignatureDeclaration(parent2) || isConstructSignatureDeclaration(parent2) || isMethodSignature(parent2))) {
                 return grammarErrorOnNode(modifier, Diagnostics._0_modifier_can_only_appear_on_a_type_parameter_of_a_function_method_or_class, tokenToString(modifier.kind));
               }
               break;
-            case 163 /* OverrideKeyword */:
-              if (flags & 16384 /* Override */) {
+            case 164 /* OverrideKeyword */:
+              if (flags & 16 /* Override */) {
                 return grammarErrorOnNode(modifier, Diagnostics._0_modifier_already_seen, "override");
-              } else if (flags & 2 /* Ambient */) {
+              } else if (flags & 128 /* Ambient */) {
                 return grammarErrorOnNode(modifier, Diagnostics._0_modifier_cannot_be_used_with_1_modifier, "override", "declare");
-              } else if (flags & 64 /* Readonly */) {
+              } else if (flags & 8 /* Readonly */) {
                 return grammarErrorOnNode(modifier, Diagnostics._0_modifier_must_precede_1_modifier, "override", "readonly");
-              } else if (flags & 128 /* Accessor */) {
+              } else if (flags & 512 /* Accessor */) {
                 return grammarErrorOnNode(modifier, Diagnostics._0_modifier_must_precede_1_modifier, "override", "accessor");
-              } else if (flags & 512 /* Async */) {
+              } else if (flags & 1024 /* Async */) {
                 return grammarErrorOnNode(modifier, Diagnostics._0_modifier_must_precede_1_modifier, "override", "async");
               }
-              flags |= 16384 /* Override */;
+              flags |= 16 /* Override */;
               lastOverride = modifier;
               break;
             case 125 /* PublicKeyword */:
             case 124 /* ProtectedKeyword */:
             case 123 /* PrivateKeyword */:
               const text = visibilityToString(modifierToFlag(modifier.kind));
-              if (flags & 28 /* AccessibilityModifier */) {
+              if (flags & 7 /* AccessibilityModifier */) {
                 return grammarErrorOnNode(modifier, Diagnostics.Accessibility_modifier_already_seen);
-              } else if (flags & 16384 /* Override */) {
+              } else if (flags & 16 /* Override */) {
                 return grammarErrorOnNode(modifier, Diagnostics._0_modifier_must_precede_1_modifier, text, "override");
-              } else if (flags & 32 /* Static */) {
+              } else if (flags & 256 /* Static */) {
                 return grammarErrorOnNode(modifier, Diagnostics._0_modifier_must_precede_1_modifier, text, "static");
-              } else if (flags & 128 /* Accessor */) {
+              } else if (flags & 512 /* Accessor */) {
                 return grammarErrorOnNode(modifier, Diagnostics._0_modifier_must_precede_1_modifier, text, "accessor");
-              } else if (flags & 64 /* Readonly */) {
+              } else if (flags & 8 /* Readonly */) {
                 return grammarErrorOnNode(modifier, Diagnostics._0_modifier_must_precede_1_modifier, text, "readonly");
-              } else if (flags & 512 /* Async */) {
+              } else if (flags & 1024 /* Async */) {
                 return grammarErrorOnNode(modifier, Diagnostics._0_modifier_must_precede_1_modifier, text, "async");
-              } else if (node.parent.kind === 267 /* ModuleBlock */ || node.parent.kind === 311 /* SourceFile */) {
+              } else if (node.parent.kind === 268 /* ModuleBlock */ || node.parent.kind === 312 /* SourceFile */) {
                 return grammarErrorOnNode(modifier, Diagnostics._0_modifier_cannot_appear_on_a_module_or_namespace_element, text);
-              } else if (flags & 256 /* Abstract */) {
+              } else if (flags & 64 /* Abstract */) {
                 if (modifier.kind === 123 /* PrivateKeyword */) {
                   return grammarErrorOnNode(modifier, Diagnostics._0_modifier_cannot_be_used_with_1_modifier, text, "abstract");
                 } else {
@@ -183640,158 +167647,170 @@ ${lanes.join("\n")}
               flags |= modifierToFlag(modifier.kind);
               break;
             case 126 /* StaticKeyword */:
-              if (flags & 32 /* Static */) {
+              if (flags & 256 /* Static */) {
                 return grammarErrorOnNode(modifier, Diagnostics._0_modifier_already_seen, "static");
-              } else if (flags & 64 /* Readonly */) {
+              } else if (flags & 8 /* Readonly */) {
                 return grammarErrorOnNode(modifier, Diagnostics._0_modifier_must_precede_1_modifier, "static", "readonly");
-              } else if (flags & 512 /* Async */) {
+              } else if (flags & 1024 /* Async */) {
                 return grammarErrorOnNode(modifier, Diagnostics._0_modifier_must_precede_1_modifier, "static", "async");
-              } else if (flags & 128 /* Accessor */) {
+              } else if (flags & 512 /* Accessor */) {
                 return grammarErrorOnNode(modifier, Diagnostics._0_modifier_must_precede_1_modifier, "static", "accessor");
-              } else if (node.parent.kind === 267 /* ModuleBlock */ || node.parent.kind === 311 /* SourceFile */) {
+              } else if (node.parent.kind === 268 /* ModuleBlock */ || node.parent.kind === 312 /* SourceFile */) {
                 return grammarErrorOnNode(modifier, Diagnostics._0_modifier_cannot_appear_on_a_module_or_namespace_element, "static");
-              } else if (node.kind === 168 /* Parameter */) {
+              } else if (node.kind === 169 /* Parameter */) {
                 return grammarErrorOnNode(modifier, Diagnostics._0_modifier_cannot_appear_on_a_parameter, "static");
-              } else if (flags & 256 /* Abstract */) {
+              } else if (flags & 64 /* Abstract */) {
                 return grammarErrorOnNode(modifier, Diagnostics._0_modifier_cannot_be_used_with_1_modifier, "static", "abstract");
-              } else if (flags & 16384 /* Override */) {
+              } else if (flags & 16 /* Override */) {
                 return grammarErrorOnNode(modifier, Diagnostics._0_modifier_must_precede_1_modifier, "static", "override");
               }
-              flags |= 32 /* Static */;
+              flags |= 256 /* Static */;
               lastStatic = modifier;
               break;
             case 129 /* AccessorKeyword */:
-              if (flags & 128 /* Accessor */) {
+              if (flags & 512 /* Accessor */) {
                 return grammarErrorOnNode(modifier, Diagnostics._0_modifier_already_seen, "accessor");
-              } else if (flags & 64 /* Readonly */) {
+              } else if (flags & 8 /* Readonly */) {
                 return grammarErrorOnNode(modifier, Diagnostics._0_modifier_cannot_be_used_with_1_modifier, "accessor", "readonly");
-              } else if (flags & 2 /* Ambient */) {
+              } else if (flags & 128 /* Ambient */) {
                 return grammarErrorOnNode(modifier, Diagnostics._0_modifier_cannot_be_used_with_1_modifier, "accessor", "declare");
-              } else if (node.kind !== 171 /* PropertyDeclaration */) {
+              } else if (node.kind !== 172 /* PropertyDeclaration */) {
                 return grammarErrorOnNode(modifier, Diagnostics.accessor_modifier_can_only_appear_on_a_property_declaration);
               }
-              flags |= 128 /* Accessor */;
+              flags |= 512 /* Accessor */;
               break;
             case 148 /* ReadonlyKeyword */:
-              if (flags & 64 /* Readonly */) {
+              if (flags & 8 /* Readonly */) {
                 return grammarErrorOnNode(modifier, Diagnostics._0_modifier_already_seen, "readonly");
-              } else if (node.kind !== 171 /* PropertyDeclaration */ && node.kind !== 170 /* PropertySignature */ && node.kind !== 180 /* IndexSignature */ && node.kind !== 168 /* Parameter */) {
+              } else if (node.kind !== 172 /* PropertyDeclaration */ && node.kind !== 171 /* PropertySignature */ && node.kind !== 181 /* IndexSignature */ && node.kind !== 169 /* Parameter */) {
                 return grammarErrorOnNode(modifier, Diagnostics.readonly_modifier_can_only_appear_on_a_property_declaration_or_index_signature);
-              } else if (flags & 128 /* Accessor */) {
+              } else if (flags & 512 /* Accessor */) {
                 return grammarErrorOnNode(modifier, Diagnostics._0_modifier_cannot_be_used_with_1_modifier, "readonly", "accessor");
               }
-              flags |= 64 /* Readonly */;
+              flags |= 8 /* Readonly */;
               break;
             case 95 /* ExportKeyword */:
-              if (compilerOptions.verbatimModuleSyntax && !(node.flags & 16777216 /* Ambient */) && node.kind !== 264 /* TypeAliasDeclaration */ && node.kind !== 263 /* InterfaceDeclaration */ && // ModuleDeclaration needs to be checked that it is uninstantiated later
-              node.kind !== 266 /* ModuleDeclaration */ && node.parent.kind === 311 /* SourceFile */ && (moduleKind === 1 /* CommonJS */ || getSourceFileOfNode(node).impliedNodeFormat === 1 /* CommonJS */)) {
+              if (compilerOptions.verbatimModuleSyntax && !(node.flags & 33554432 /* Ambient */) && node.kind !== 265 /* TypeAliasDeclaration */ && node.kind !== 264 /* InterfaceDeclaration */ && // ModuleDeclaration needs to be checked that it is uninstantiated later
+              node.kind !== 267 /* ModuleDeclaration */ && node.parent.kind === 312 /* SourceFile */ && (moduleKind === 1 /* CommonJS */ || getSourceFileOfNode(node).impliedNodeFormat === 1 /* CommonJS */)) {
                 return grammarErrorOnNode(modifier, Diagnostics.A_top_level_export_modifier_cannot_be_used_on_value_declarations_in_a_CommonJS_module_when_verbatimModuleSyntax_is_enabled);
               }
-              if (flags & 1 /* Export */) {
+              if (flags & 32 /* Export */) {
                 return grammarErrorOnNode(modifier, Diagnostics._0_modifier_already_seen, "export");
-              } else if (flags & 2 /* Ambient */) {
+              } else if (flags & 128 /* Ambient */) {
                 return grammarErrorOnNode(modifier, Diagnostics._0_modifier_must_precede_1_modifier, "export", "declare");
-              } else if (flags & 256 /* Abstract */) {
+              } else if (flags & 64 /* Abstract */) {
                 return grammarErrorOnNode(modifier, Diagnostics._0_modifier_must_precede_1_modifier, "export", "abstract");
-              } else if (flags & 512 /* Async */) {
+              } else if (flags & 1024 /* Async */) {
                 return grammarErrorOnNode(modifier, Diagnostics._0_modifier_must_precede_1_modifier, "export", "async");
               } else if (isClassLike(node.parent)) {
                 return grammarErrorOnNode(modifier, Diagnostics._0_modifier_cannot_appear_on_class_elements_of_this_kind, "export");
-              } else if (node.kind === 168 /* Parameter */) {
+              } else if (node.kind === 169 /* Parameter */) {
                 return grammarErrorOnNode(modifier, Diagnostics._0_modifier_cannot_appear_on_a_parameter, "export");
+              } else if (blockScopeKind === 4 /* Using */) {
+                return grammarErrorOnNode(modifier, Diagnostics._0_modifier_cannot_appear_on_a_using_declaration, "export");
+              } else if (blockScopeKind === 6 /* AwaitUsing */) {
+                return grammarErrorOnNode(modifier, Diagnostics._0_modifier_cannot_appear_on_an_await_using_declaration, "export");
               }
-              flags |= 1 /* Export */;
+              flags |= 32 /* Export */;
               break;
             case 90 /* DefaultKeyword */:
-              const container = node.parent.kind === 311 /* SourceFile */ ? node.parent : node.parent.parent;
-              if (container.kind === 266 /* ModuleDeclaration */ && !isAmbientModule(container)) {
+              const container = node.parent.kind === 312 /* SourceFile */ ? node.parent : node.parent.parent;
+              if (container.kind === 267 /* ModuleDeclaration */ && !isAmbientModule(container)) {
                 return grammarErrorOnNode(modifier, Diagnostics.A_default_export_can_only_be_used_in_an_ECMAScript_style_module);
-              } else if (!(flags & 1 /* Export */)) {
+              } else if (blockScopeKind === 4 /* Using */) {
+                return grammarErrorOnNode(modifier, Diagnostics._0_modifier_cannot_appear_on_a_using_declaration, "default");
+              } else if (blockScopeKind === 6 /* AwaitUsing */) {
+                return grammarErrorOnNode(modifier, Diagnostics._0_modifier_cannot_appear_on_an_await_using_declaration, "default");
+              } else if (!(flags & 32 /* Export */)) {
                 return grammarErrorOnNode(modifier, Diagnostics._0_modifier_must_precede_1_modifier, "export", "default");
               } else if (sawExportBeforeDecorators) {
                 return grammarErrorOnNode(firstDecorator, Diagnostics.Decorators_are_not_valid_here);
               }
-              flags |= 1024 /* Default */;
+              flags |= 2048 /* Default */;
               break;
             case 138 /* DeclareKeyword */:
-              if (flags & 2 /* Ambient */) {
+              if (flags & 128 /* Ambient */) {
                 return grammarErrorOnNode(modifier, Diagnostics._0_modifier_already_seen, "declare");
-              } else if (flags & 512 /* Async */) {
+              } else if (flags & 1024 /* Async */) {
                 return grammarErrorOnNode(modifier, Diagnostics._0_modifier_cannot_be_used_in_an_ambient_context, "async");
-              } else if (flags & 16384 /* Override */) {
+              } else if (flags & 16 /* Override */) {
                 return grammarErrorOnNode(modifier, Diagnostics._0_modifier_cannot_be_used_in_an_ambient_context, "override");
               } else if (isClassLike(node.parent) && !isPropertyDeclaration(node)) {
                 return grammarErrorOnNode(modifier, Diagnostics._0_modifier_cannot_appear_on_class_elements_of_this_kind, "declare");
-              } else if (node.kind === 168 /* Parameter */) {
+              } else if (node.kind === 169 /* Parameter */) {
                 return grammarErrorOnNode(modifier, Diagnostics._0_modifier_cannot_appear_on_a_parameter, "declare");
-              } else if (node.parent.flags & 16777216 /* Ambient */ && node.parent.kind === 267 /* ModuleBlock */) {
+              } else if (blockScopeKind === 4 /* Using */) {
+                return grammarErrorOnNode(modifier, Diagnostics._0_modifier_cannot_appear_on_a_using_declaration, "declare");
+              } else if (blockScopeKind === 6 /* AwaitUsing */) {
+                return grammarErrorOnNode(modifier, Diagnostics._0_modifier_cannot_appear_on_an_await_using_declaration, "declare");
+              } else if (node.parent.flags & 33554432 /* Ambient */ && node.parent.kind === 268 /* ModuleBlock */) {
                 return grammarErrorOnNode(modifier, Diagnostics.A_declare_modifier_cannot_be_used_in_an_already_ambient_context);
               } else if (isPrivateIdentifierClassElementDeclaration(node)) {
                 return grammarErrorOnNode(modifier, Diagnostics._0_modifier_cannot_be_used_with_a_private_identifier, "declare");
-              } else if (flags & 128 /* Accessor */) {
+              } else if (flags & 512 /* Accessor */) {
                 return grammarErrorOnNode(modifier, Diagnostics._0_modifier_cannot_be_used_with_1_modifier, "declare", "accessor");
               }
-              flags |= 2 /* Ambient */;
+              flags |= 128 /* Ambient */;
               lastDeclare = modifier;
               break;
             case 128 /* AbstractKeyword */:
-              if (flags & 256 /* Abstract */) {
+              if (flags & 64 /* Abstract */) {
                 return grammarErrorOnNode(modifier, Diagnostics._0_modifier_already_seen, "abstract");
               }
-              if (node.kind !== 262 /* ClassDeclaration */ && node.kind !== 184 /* ConstructorType */) {
-                if (node.kind !== 173 /* MethodDeclaration */ && node.kind !== 171 /* PropertyDeclaration */ && node.kind !== 176 /* GetAccessor */ && node.kind !== 177 /* SetAccessor */) {
+              if (node.kind !== 263 /* ClassDeclaration */ && node.kind !== 185 /* ConstructorType */) {
+                if (node.kind !== 174 /* MethodDeclaration */ && node.kind !== 172 /* PropertyDeclaration */ && node.kind !== 177 /* GetAccessor */ && node.kind !== 178 /* SetAccessor */) {
                   return grammarErrorOnNode(modifier, Diagnostics.abstract_modifier_can_only_appear_on_a_class_method_or_property_declaration);
                 }
-                if (!(node.parent.kind === 262 /* ClassDeclaration */ && hasSyntacticModifier(node.parent, 256 /* Abstract */))) {
-                  const message = node.kind === 171 /* PropertyDeclaration */ ? Diagnostics.Abstract_properties_can_only_appear_within_an_abstract_class : Diagnostics.Abstract_methods_can_only_appear_within_an_abstract_class;
+                if (!(node.parent.kind === 263 /* ClassDeclaration */ && hasSyntacticModifier(node.parent, 64 /* Abstract */))) {
+                  const message = node.kind === 172 /* PropertyDeclaration */ ? Diagnostics.Abstract_properties_can_only_appear_within_an_abstract_class : Diagnostics.Abstract_methods_can_only_appear_within_an_abstract_class;
                   return grammarErrorOnNode(modifier, message);
                 }
-                if (flags & 32 /* Static */) {
+                if (flags & 256 /* Static */) {
                   return grammarErrorOnNode(modifier, Diagnostics._0_modifier_cannot_be_used_with_1_modifier, "static", "abstract");
                 }
-                if (flags & 8 /* Private */) {
+                if (flags & 2 /* Private */) {
                   return grammarErrorOnNode(modifier, Diagnostics._0_modifier_cannot_be_used_with_1_modifier, "private", "abstract");
                 }
-                if (flags & 512 /* Async */ && lastAsync) {
+                if (flags & 1024 /* Async */ && lastAsync) {
                   return grammarErrorOnNode(lastAsync, Diagnostics._0_modifier_cannot_be_used_with_1_modifier, "async", "abstract");
                 }
-                if (flags & 16384 /* Override */) {
+                if (flags & 16 /* Override */) {
                   return grammarErrorOnNode(modifier, Diagnostics._0_modifier_must_precede_1_modifier, "abstract", "override");
                 }
-                if (flags & 128 /* Accessor */) {
+                if (flags & 512 /* Accessor */) {
                   return grammarErrorOnNode(modifier, Diagnostics._0_modifier_must_precede_1_modifier, "abstract", "accessor");
                 }
               }
               if (isNamedDeclaration(node) && node.name.kind === 81 /* PrivateIdentifier */) {
                 return grammarErrorOnNode(modifier, Diagnostics._0_modifier_cannot_be_used_with_a_private_identifier, "abstract");
               }
-              flags |= 256 /* Abstract */;
+              flags |= 64 /* Abstract */;
               break;
             case 134 /* AsyncKeyword */:
-              if (flags & 512 /* Async */) {
+              if (flags & 1024 /* Async */) {
                 return grammarErrorOnNode(modifier, Diagnostics._0_modifier_already_seen, "async");
-              } else if (flags & 2 /* Ambient */ || node.parent.flags & 16777216 /* Ambient */) {
+              } else if (flags & 128 /* Ambient */ || node.parent.flags & 33554432 /* Ambient */) {
                 return grammarErrorOnNode(modifier, Diagnostics._0_modifier_cannot_be_used_in_an_ambient_context, "async");
-              } else if (node.kind === 168 /* Parameter */) {
+              } else if (node.kind === 169 /* Parameter */) {
                 return grammarErrorOnNode(modifier, Diagnostics._0_modifier_cannot_appear_on_a_parameter, "async");
               }
-              if (flags & 256 /* Abstract */) {
+              if (flags & 64 /* Abstract */) {
                 return grammarErrorOnNode(modifier, Diagnostics._0_modifier_cannot_be_used_with_1_modifier, "async", "abstract");
               }
-              flags |= 512 /* Async */;
+              flags |= 1024 /* Async */;
               lastAsync = modifier;
               break;
             case 103 /* InKeyword */:
             case 147 /* OutKeyword */:
-              const inOutFlag = modifier.kind === 103 /* InKeyword */ ? 32768 /* In */ : 65536 /* Out */;
+              const inOutFlag = modifier.kind === 103 /* InKeyword */ ? 8192 /* In */ : 16384 /* Out */;
               const inOutText = modifier.kind === 103 /* InKeyword */ ? "in" : "out";
-              if (node.kind !== 167 /* TypeParameter */ || !(isInterfaceDeclaration(node.parent) || isClassLike(node.parent) || isTypeAliasDeclaration(node.parent))) {
+              if (node.kind !== 168 /* TypeParameter */ || !(isInterfaceDeclaration(node.parent) || isClassLike(node.parent) || isTypeAliasDeclaration(node.parent))) {
                 return grammarErrorOnNode(modifier, Diagnostics._0_modifier_can_only_appear_on_a_type_parameter_of_a_class_interface_or_type_alias, inOutText);
               }
               if (flags & inOutFlag) {
                 return grammarErrorOnNode(modifier, Diagnostics._0_modifier_already_seen, inOutText);
               }
-              if (inOutFlag & 32768 /* In */ && flags & 65536 /* Out */) {
+              if (inOutFlag & 8192 /* In */ && flags & 16384 /* Out */) {
                 return grammarErrorOnNode(modifier, Diagnostics._0_modifier_must_precede_1_modifier, "in", "out");
               }
               flags |= inOutFlag;
@@ -183799,25 +167818,25 @@ ${lanes.join("\n")}
           }
         }
       }
-      if (node.kind === 175 /* Constructor */) {
-        if (flags & 32 /* Static */) {
+      if (node.kind === 176 /* Constructor */) {
+        if (flags & 256 /* Static */) {
           return grammarErrorOnNode(lastStatic, Diagnostics._0_modifier_cannot_appear_on_a_constructor_declaration, "static");
         }
-        if (flags & 16384 /* Override */) {
+        if (flags & 16 /* Override */) {
           return grammarErrorOnNode(lastOverride, Diagnostics._0_modifier_cannot_appear_on_a_constructor_declaration, "override");
         }
-        if (flags & 512 /* Async */) {
+        if (flags & 1024 /* Async */) {
           return grammarErrorOnNode(lastAsync, Diagnostics._0_modifier_cannot_appear_on_a_constructor_declaration, "async");
         }
         return false;
-      } else if ((node.kind === 271 /* ImportDeclaration */ || node.kind === 270 /* ImportEqualsDeclaration */) && flags & 2 /* Ambient */) {
+      } else if ((node.kind === 272 /* ImportDeclaration */ || node.kind === 271 /* ImportEqualsDeclaration */) && flags & 128 /* Ambient */) {
         return grammarErrorOnNode(lastDeclare, Diagnostics.A_0_modifier_cannot_be_used_with_an_import_declaration, "declare");
-      } else if (node.kind === 168 /* Parameter */ && flags & 16476 /* ParameterPropertyModifier */ && isBindingPattern(node.name)) {
+      } else if (node.kind === 169 /* Parameter */ && flags & 31 /* ParameterPropertyModifier */ && isBindingPattern(node.name)) {
         return grammarErrorOnNode(node, Diagnostics.A_parameter_property_may_not_be_declared_using_a_binding_pattern);
-      } else if (node.kind === 168 /* Parameter */ && flags & 16476 /* ParameterPropertyModifier */ && node.dotDotDotToken) {
+      } else if (node.kind === 169 /* Parameter */ && flags & 31 /* ParameterPropertyModifier */ && node.dotDotDotToken) {
         return grammarErrorOnNode(node, Diagnostics.A_parameter_property_cannot_be_declared_using_a_rest_parameter);
       }
-      if (flags & 512 /* Async */) {
+      if (flags & 1024 /* Async */) {
         return checkGrammarAsyncModifier(node, lastAsync);
       }
       return false;
@@ -183834,46 +167853,47 @@ ${lanes.join("\n")}
     }
     function findFirstIllegalModifier(node) {
       switch (node.kind) {
-        case 176 /* GetAccessor */:
-        case 177 /* SetAccessor */:
-        case 175 /* Constructor */:
-        case 171 /* PropertyDeclaration */:
-        case 170 /* PropertySignature */:
-        case 173 /* MethodDeclaration */:
-        case 172 /* MethodSignature */:
-        case 180 /* IndexSignature */:
-        case 266 /* ModuleDeclaration */:
-        case 271 /* ImportDeclaration */:
-        case 270 /* ImportEqualsDeclaration */:
-        case 277 /* ExportDeclaration */:
-        case 276 /* ExportAssignment */:
-        case 217 /* FunctionExpression */:
-        case 218 /* ArrowFunction */:
-        case 168 /* Parameter */:
-        case 167 /* TypeParameter */:
+        case 177 /* GetAccessor */:
+        case 178 /* SetAccessor */:
+        case 176 /* Constructor */:
+        case 172 /* PropertyDeclaration */:
+        case 171 /* PropertySignature */:
+        case 174 /* MethodDeclaration */:
+        case 173 /* MethodSignature */:
+        case 181 /* IndexSignature */:
+        case 267 /* ModuleDeclaration */:
+        case 272 /* ImportDeclaration */:
+        case 271 /* ImportEqualsDeclaration */:
+        case 278 /* ExportDeclaration */:
+        case 277 /* ExportAssignment */:
+        case 218 /* FunctionExpression */:
+        case 219 /* ArrowFunction */:
+        case 169 /* Parameter */:
+        case 168 /* TypeParameter */:
           return void 0;
-        case 174 /* ClassStaticBlockDeclaration */:
-        case 302 /* PropertyAssignment */:
-        case 303 /* ShorthandPropertyAssignment */:
-        case 269 /* NamespaceExportDeclaration */:
-        case 281 /* MissingDeclaration */:
+        case 175 /* ClassStaticBlockDeclaration */:
+        case 303 /* PropertyAssignment */:
+        case 304 /* ShorthandPropertyAssignment */:
+        case 270 /* NamespaceExportDeclaration */:
+        case 282 /* MissingDeclaration */:
           return find(node.modifiers, isModifier);
         default:
-          if (node.parent.kind === 267 /* ModuleBlock */ || node.parent.kind === 311 /* SourceFile */) {
+          if (node.parent.kind === 268 /* ModuleBlock */ || node.parent.kind === 312 /* SourceFile */) {
             return void 0;
           }
           switch (node.kind) {
-            case 261 /* FunctionDeclaration */:
+            case 262 /* FunctionDeclaration */:
               return findFirstModifierExcept(node, 134 /* AsyncKeyword */);
-            case 262 /* ClassDeclaration */:
-            case 184 /* ConstructorType */:
+            case 263 /* ClassDeclaration */:
+            case 185 /* ConstructorType */:
               return findFirstModifierExcept(node, 128 /* AbstractKeyword */);
-            case 230 /* ClassExpression */:
-            case 263 /* InterfaceDeclaration */:
-            case 242 /* VariableStatement */:
-            case 264 /* TypeAliasDeclaration */:
+            case 231 /* ClassExpression */:
+            case 264 /* InterfaceDeclaration */:
+            case 265 /* TypeAliasDeclaration */:
               return find(node.modifiers, isModifier);
-            case 265 /* EnumDeclaration */:
+            case 243 /* VariableStatement */:
+              return node.declarationList.flags & 4 /* Using */ ? findFirstModifierExcept(node, 135 /* AwaitKeyword */) : find(node.modifiers, isModifier);
+            case 266 /* EnumDeclaration */:
               return findFirstModifierExcept(node, 87 /* ConstKeyword */);
             default:
               Debug.assertNever(node);
@@ -183889,10 +167909,10 @@ ${lanes.join("\n")}
     }
     function checkGrammarAsyncModifier(node, asyncModifier) {
       switch (node.kind) {
-        case 173 /* MethodDeclaration */:
-        case 261 /* FunctionDeclaration */:
-        case 217 /* FunctionExpression */:
-        case 218 /* ArrowFunction */:
+        case 174 /* MethodDeclaration */:
+        case 262 /* FunctionDeclaration */:
+        case 218 /* FunctionExpression */:
+        case 219 /* ArrowFunction */:
           return false;
       }
       return grammarErrorOnNode(asyncModifier, Diagnostics._0_modifier_cannot_be_used_here, "async");
@@ -183920,7 +167940,7 @@ ${lanes.join("\n")}
           if (i !== parameterCount - 1) {
             return grammarErrorOnNode(parameter.dotDotDotToken, Diagnostics.A_rest_parameter_must_be_last_in_a_parameter_list);
           }
-          if (!(parameter.flags & 16777216 /* Ambient */)) {
+          if (!(parameter.flags & 33554432 /* Ambient */)) {
             checkGrammarForDisallowedTrailingComma(parameters, Diagnostics.A_rest_parameter_or_binding_pattern_may_not_have_a_trailing_comma);
           }
           if (parameter.questionToken) {
@@ -183950,12 +167970,12 @@ ${lanes.join("\n")}
           if (length(nonSimpleParameters)) {
             forEach(nonSimpleParameters, (parameter) => {
               addRelatedInfo(
-                error(parameter, Diagnostics.This_parameter_is_not_allowed_with_use_strict_directive),
+                error2(parameter, Diagnostics.This_parameter_is_not_allowed_with_use_strict_directive),
                 createDiagnosticForNode(useStrictDirective, Diagnostics.use_strict_directive_used_here)
               );
             });
             const diagnostics2 = nonSimpleParameters.map((parameter, index) => index === 0 ? createDiagnosticForNode(parameter, Diagnostics.Non_simple_parameter_declared_here) : createDiagnosticForNode(parameter, Diagnostics.and_here));
-            addRelatedInfo(error(useStrictDirective, Diagnostics.use_strict_directive_cannot_be_used_with_non_simple_parameter_list), ...diagnostics2);
+            addRelatedInfo(error2(useStrictDirective, Diagnostics.use_strict_directive_cannot_be_used_with_non_simple_parameter_list), ...diagnostics2);
             return true;
           }
         }
@@ -184037,7 +168057,7 @@ ${lanes.join("\n")}
       return checkGrammarForDisallowedTrailingComma(typeArguments) || checkGrammarForAtLeastOneTypeArgument(node, typeArguments);
     }
     function checkGrammarTaggedTemplateChain(node) {
-      if (node.questionDotToken || node.flags & 32 /* OptionalChain */) {
+      if (node.questionDotToken || node.flags & 64 /* OptionalChain */) {
         return grammarErrorOnNode(node.template, Diagnostics.Tagged_template_expressions_are_not_permitted_in_an_optional_chain);
       }
       return false;
@@ -184105,11 +168125,11 @@ ${lanes.join("\n")}
       return false;
     }
     function checkGrammarComputedPropertyName(node) {
-      if (node.kind !== 166 /* ComputedPropertyName */) {
+      if (node.kind !== 167 /* ComputedPropertyName */) {
         return false;
       }
       const computedPropertyName = node;
-      if (computedPropertyName.expression.kind === 225 /* BinaryExpression */ && computedPropertyName.expression.operatorToken.kind === 28 /* CommaToken */) {
+      if (computedPropertyName.expression.kind === 226 /* BinaryExpression */ && computedPropertyName.expression.operatorToken.kind === 28 /* CommaToken */) {
         return grammarErrorOnNode(computedPropertyName.expression, Diagnostics.A_comma_expression_is_not_allowed_in_a_computed_property_name);
       }
       return false;
@@ -184117,9 +168137,9 @@ ${lanes.join("\n")}
     function checkGrammarForGenerator(node) {
       if (node.asteriskToken) {
         Debug.assert(
-          node.kind === 261 /* FunctionDeclaration */ || node.kind === 217 /* FunctionExpression */ || node.kind === 173 /* MethodDeclaration */
+          node.kind === 262 /* FunctionDeclaration */ || node.kind === 218 /* FunctionExpression */ || node.kind === 174 /* MethodDeclaration */
         );
-        if (node.flags & 16777216 /* Ambient */) {
+        if (node.flags & 33554432 /* Ambient */) {
           return grammarErrorOnNode(node.asteriskToken, Diagnostics.Generators_are_not_allowed_in_an_ambient_context);
         }
         if (!node.body) {
@@ -184136,7 +168156,7 @@ ${lanes.join("\n")}
     function checkGrammarObjectLiteralExpression(node, inDestructuring) {
       const seen = /* @__PURE__ */ new Map();
       for (const prop of node.properties) {
-        if (prop.kind === 304 /* SpreadAssignment */) {
+        if (prop.kind === 305 /* SpreadAssignment */) {
           if (inDestructuring) {
             const expression = skipParentheses(prop.expression);
             if (isArrayLiteralExpression(expression) || isObjectLiteralExpression(expression)) {
@@ -184146,10 +168166,10 @@ ${lanes.join("\n")}
           continue;
         }
         const name = prop.name;
-        if (name.kind === 166 /* ComputedPropertyName */) {
+        if (name.kind === 167 /* ComputedPropertyName */) {
           checkGrammarComputedPropertyName(name);
         }
-        if (prop.kind === 303 /* ShorthandPropertyAssignment */ && !inDestructuring && prop.objectAssignmentInitializer) {
+        if (prop.kind === 304 /* ShorthandPropertyAssignment */ && !inDestructuring && prop.objectAssignmentInitializer) {
           grammarErrorOnNode(prop.equalsToken, Diagnostics.Did_you_mean_to_use_a_Colon_An_can_only_follow_a_property_name_when_the_containing_object_literal_is_part_of_a_destructuring_pattern);
         }
         if (name.kind === 81 /* PrivateIdentifier */) {
@@ -184157,7 +168177,7 @@ ${lanes.join("\n")}
         }
         if (canHaveModifiers(prop) && prop.modifiers) {
           for (const mod of prop.modifiers) {
-            if (isModifier(mod) && (mod.kind !== 134 /* AsyncKeyword */ || prop.kind !== 173 /* MethodDeclaration */)) {
+            if (isModifier(mod) && (mod.kind !== 134 /* AsyncKeyword */ || prop.kind !== 174 /* MethodDeclaration */)) {
               grammarErrorOnNode(mod, Diagnostics._0_modifier_cannot_be_used_here, getTextOfNode(mod));
             }
           }
@@ -184170,8 +168190,8 @@ ${lanes.join("\n")}
         }
         let currentKind;
         switch (prop.kind) {
-          case 303 /* ShorthandPropertyAssignment */:
-          case 302 /* PropertyAssignment */:
+          case 304 /* ShorthandPropertyAssignment */:
+          case 303 /* PropertyAssignment */:
             checkGrammarForInvalidExclamationToken(prop.exclamationToken, Diagnostics.A_definite_assignment_assertion_is_not_permitted_in_this_context);
             checkGrammarForInvalidQuestionMark(prop.questionToken, Diagnostics.An_object_member_cannot_be_declared_optional);
             if (name.kind === 9 /* NumericLiteral */) {
@@ -184179,13 +168199,13 @@ ${lanes.join("\n")}
             }
             currentKind = 4 /* PropertyAssignment */;
             break;
-          case 173 /* MethodDeclaration */:
+          case 174 /* MethodDeclaration */:
             currentKind = 8 /* Method */;
             break;
-          case 176 /* GetAccessor */:
+          case 177 /* GetAccessor */:
             currentKind = 1 /* GetAccessor */;
             break;
-          case 177 /* SetAccessor */:
+          case 178 /* SetAccessor */:
             currentKind = 2 /* SetAccessor */;
             break;
           default:
@@ -184222,7 +168242,7 @@ ${lanes.join("\n")}
       checkGrammarTypeArguments(node, node.typeArguments);
       const seen = /* @__PURE__ */ new Map();
       for (const attr of node.attributes.properties) {
-        if (attr.kind === 292 /* JsxSpreadAttribute */) {
+        if (attr.kind === 293 /* JsxSpreadAttribute */) {
           continue;
         }
         const { name, initializer } = attr;
@@ -184232,7 +168252,7 @@ ${lanes.join("\n")}
         } else {
           return grammarErrorOnNode(name, Diagnostics.JSX_elements_cannot_have_multiple_attributes_with_the_same_name);
         }
-        if (initializer && initializer.kind === 293 /* JsxExpression */ && !initializer.expression) {
+        if (initializer && initializer.kind === 294 /* JsxExpression */ && !initializer.expression) {
           return grammarErrorOnNode(initializer, Diagnostics.JSX_attributes_must_only_be_assigned_a_non_empty_expression);
         }
       }
@@ -184254,16 +168274,13 @@ ${lanes.join("\n")}
       if (checkGrammarStatementInAmbientContext(forInOrOfStatement)) {
         return true;
       }
-      if (forInOrOfStatement.kind === 249 /* ForOfStatement */ && forInOrOfStatement.awaitModifier) {
-        if (!(forInOrOfStatement.flags & 32768 /* AwaitContext */)) {
+      if (forInOrOfStatement.kind === 250 /* ForOfStatement */ && forInOrOfStatement.awaitModifier) {
+        if (!(forInOrOfStatement.flags & 65536 /* AwaitContext */)) {
           const sourceFile = getSourceFileOfNode(forInOrOfStatement);
           if (isInTopLevelContext(forInOrOfStatement)) {
             if (!hasParseDiagnostics(sourceFile)) {
               if (!isEffectiveExternalModule(sourceFile, compilerOptions)) {
-                diagnostics.add(createDiagnosticForNode(
-                  forInOrOfStatement.awaitModifier,
-                  Diagnostics.for_await_loops_are_only_allowed_at_the_top_level_of_a_file_when_that_file_is_a_module_but_this_file_has_no_imports_or_exports_Consider_adding_an_empty_export_to_make_this_file_a_module
-                ));
+                diagnostics.add(createDiagnosticForNode(forInOrOfStatement.awaitModifier, Diagnostics.for_await_loops_are_only_allowed_at_the_top_level_of_a_file_when_that_file_is_a_module_but_this_file_has_no_imports_or_exports_Consider_adding_an_empty_export_to_make_this_file_a_module));
               }
               switch (moduleKind) {
                 case 100 /* Node16 */:
@@ -184282,10 +168299,7 @@ ${lanes.join("\n")}
                   }
                 default:
                   diagnostics.add(
-                    createDiagnosticForNode(
-                      forInOrOfStatement.awaitModifier,
-                      Diagnostics.Top_level_for_await_loops_are_only_allowed_when_the_module_option_is_set_to_es2022_esnext_system_node16_or_nodenext_and_the_target_option_is_set_to_es2017_or_higher
-                    )
+                    createDiagnosticForNode(forInOrOfStatement.awaitModifier, Diagnostics.Top_level_for_await_loops_are_only_allowed_when_the_module_option_is_set_to_es2022_esnext_system_node16_or_nodenext_and_the_target_option_is_set_to_es2017_or_higher)
                   );
                   break;
               }
@@ -184294,7 +168308,7 @@ ${lanes.join("\n")}
             if (!hasParseDiagnostics(sourceFile)) {
               const diagnostic = createDiagnosticForNode(forInOrOfStatement.awaitModifier, Diagnostics.for_await_loops_are_only_allowed_within_async_functions_and_at_the_top_levels_of_modules);
               const func = getContainingFunction(forInOrOfStatement);
-              if (func && func.kind !== 175 /* Constructor */) {
+              if (func && func.kind !== 176 /* Constructor */) {
                 Debug.assert((getFunctionFlags(func) & 2 /* Async */) === 0, "Enclosing function should never be an async function.");
                 const relatedInfo = createDiagnosticForNode(func, Diagnostics.Did_you_mean_to_mark_this_function_as_async);
                 addRelatedInfo(diagnostic, relatedInfo);
@@ -184306,11 +168320,11 @@ ${lanes.join("\n")}
           return false;
         }
       }
-      if (isForOfStatement(forInOrOfStatement) && !(forInOrOfStatement.flags & 32768 /* AwaitContext */) && isIdentifier(forInOrOfStatement.initializer) && forInOrOfStatement.initializer.escapedText === "async") {
+      if (isForOfStatement(forInOrOfStatement) && !(forInOrOfStatement.flags & 65536 /* AwaitContext */) && isIdentifier(forInOrOfStatement.initializer) && forInOrOfStatement.initializer.escapedText === "async") {
         grammarErrorOnNode(forInOrOfStatement.initializer, Diagnostics.The_left_hand_side_of_a_for_of_statement_may_not_be_async);
         return false;
       }
-      if (forInOrOfStatement.initializer.kind === 260 /* VariableDeclarationList */) {
+      if (forInOrOfStatement.initializer.kind === 261 /* VariableDeclarationList */) {
         const variableList = forInOrOfStatement.initializer;
         if (!checkGrammarVariableDeclarationList(variableList)) {
           const declarations = variableList.declarations;
@@ -184318,16 +168332,16 @@ ${lanes.join("\n")}
             return false;
           }
           if (declarations.length > 1) {
-            const diagnostic = forInOrOfStatement.kind === 248 /* ForInStatement */ ? Diagnostics.Only_a_single_variable_declaration_is_allowed_in_a_for_in_statement : Diagnostics.Only_a_single_variable_declaration_is_allowed_in_a_for_of_statement;
+            const diagnostic = forInOrOfStatement.kind === 249 /* ForInStatement */ ? Diagnostics.Only_a_single_variable_declaration_is_allowed_in_a_for_in_statement : Diagnostics.Only_a_single_variable_declaration_is_allowed_in_a_for_of_statement;
             return grammarErrorOnFirstToken(variableList.declarations[1], diagnostic);
           }
           const firstDeclaration = declarations[0];
           if (firstDeclaration.initializer) {
-            const diagnostic = forInOrOfStatement.kind === 248 /* ForInStatement */ ? Diagnostics.The_variable_declaration_of_a_for_in_statement_cannot_have_an_initializer : Diagnostics.The_variable_declaration_of_a_for_of_statement_cannot_have_an_initializer;
+            const diagnostic = forInOrOfStatement.kind === 249 /* ForInStatement */ ? Diagnostics.The_variable_declaration_of_a_for_in_statement_cannot_have_an_initializer : Diagnostics.The_variable_declaration_of_a_for_of_statement_cannot_have_an_initializer;
             return grammarErrorOnNode(firstDeclaration.name, diagnostic);
           }
           if (firstDeclaration.type) {
-            const diagnostic = forInOrOfStatement.kind === 248 /* ForInStatement */ ? Diagnostics.The_left_hand_side_of_a_for_in_statement_cannot_use_a_type_annotation : Diagnostics.The_left_hand_side_of_a_for_of_statement_cannot_use_a_type_annotation;
+            const diagnostic = forInOrOfStatement.kind === 249 /* ForInStatement */ ? Diagnostics.The_left_hand_side_of_a_for_in_statement_cannot_use_a_type_annotation : Diagnostics.The_left_hand_side_of_a_for_of_statement_cannot_use_a_type_annotation;
             return grammarErrorOnNode(firstDeclaration, diagnostic);
           }
         }
@@ -184335,22 +168349,22 @@ ${lanes.join("\n")}
       return false;
     }
     function checkGrammarAccessor(accessor) {
-      if (!(accessor.flags & 16777216 /* Ambient */) && accessor.parent.kind !== 186 /* TypeLiteral */ && accessor.parent.kind !== 263 /* InterfaceDeclaration */) {
+      if (!(accessor.flags & 33554432 /* Ambient */) && accessor.parent.kind !== 187 /* TypeLiteral */ && accessor.parent.kind !== 264 /* InterfaceDeclaration */) {
         if (languageVersion < 1 /* ES5 */) {
           return grammarErrorOnNode(accessor.name, Diagnostics.Accessors_are_only_available_when_targeting_ECMAScript_5_and_higher);
         }
         if (languageVersion < 2 /* ES2015 */ && isPrivateIdentifier(accessor.name)) {
           return grammarErrorOnNode(accessor.name, Diagnostics.Private_identifiers_are_only_available_when_targeting_ECMAScript_2015_and_higher);
         }
-        if (accessor.body === void 0 && !hasSyntacticModifier(accessor, 256 /* Abstract */)) {
+        if (accessor.body === void 0 && !hasSyntacticModifier(accessor, 64 /* Abstract */)) {
           return grammarErrorAtPos(accessor, accessor.end - 1, ";".length, Diagnostics._0_expected, "{");
         }
       }
       if (accessor.body) {
-        if (hasSyntacticModifier(accessor, 256 /* Abstract */)) {
+        if (hasSyntacticModifier(accessor, 64 /* Abstract */)) {
           return grammarErrorOnNode(accessor, Diagnostics.An_abstract_accessor_cannot_have_an_implementation);
         }
-        if (accessor.parent.kind === 186 /* TypeLiteral */ || accessor.parent.kind === 263 /* InterfaceDeclaration */) {
+        if (accessor.parent.kind === 187 /* TypeLiteral */ || accessor.parent.kind === 264 /* InterfaceDeclaration */) {
           return grammarErrorOnNode(accessor.body, Diagnostics.An_implementation_cannot_be_declared_in_ambient_contexts);
         }
       }
@@ -184360,10 +168374,10 @@ ${lanes.join("\n")}
       if (!doesAccessorHaveCorrectParameterCount(accessor)) {
         return grammarErrorOnNode(
           accessor.name,
-          accessor.kind === 176 /* GetAccessor */ ? Diagnostics.A_get_accessor_cannot_have_parameters : Diagnostics.A_set_accessor_must_have_exactly_one_parameter
+          accessor.kind === 177 /* GetAccessor */ ? Diagnostics.A_get_accessor_cannot_have_parameters : Diagnostics.A_set_accessor_must_have_exactly_one_parameter
         );
       }
-      if (accessor.kind === 177 /* SetAccessor */) {
+      if (accessor.kind === 178 /* SetAccessor */) {
         if (accessor.type) {
           return grammarErrorOnNode(accessor.name, Diagnostics.A_set_accessor_cannot_have_a_return_type_annotation);
         }
@@ -184381,10 +168395,10 @@ ${lanes.join("\n")}
       return false;
     }
     function doesAccessorHaveCorrectParameterCount(accessor) {
-      return getAccessorThisParameter(accessor) || accessor.parameters.length === (accessor.kind === 176 /* GetAccessor */ ? 0 : 1);
+      return getAccessorThisParameter(accessor) || accessor.parameters.length === (accessor.kind === 177 /* GetAccessor */ ? 0 : 1);
     }
     function getAccessorThisParameter(accessor) {
-      if (accessor.parameters.length === (accessor.kind === 176 /* GetAccessor */ ? 1 : 2)) {
+      if (accessor.parameters.length === (accessor.kind === 177 /* GetAccessor */ ? 1 : 2)) {
         return getThisParameter(accessor);
       }
     }
@@ -184401,7 +168415,7 @@ ${lanes.join("\n")}
           }
         }
         switch (parent2.kind) {
-          case 259 /* VariableDeclaration */:
+          case 260 /* VariableDeclaration */:
             const decl = parent2;
             if (decl.name.kind !== 80 /* Identifier */) {
               return grammarErrorOnNode(node, Diagnostics.unique_symbol_types_may_not_be_used_on_a_variable_declaration_with_a_binding_name);
@@ -184413,13 +168427,13 @@ ${lanes.join("\n")}
               return grammarErrorOnNode(parent2.name, Diagnostics.A_variable_whose_type_is_a_unique_symbol_type_must_be_const);
             }
             break;
-          case 171 /* PropertyDeclaration */:
+          case 172 /* PropertyDeclaration */:
             if (!isStatic(parent2) || !hasEffectiveReadonlyModifier(parent2)) {
               return grammarErrorOnNode(parent2.name, Diagnostics.A_property_of_a_class_whose_type_is_a_unique_symbol_type_must_be_both_static_and_readonly);
             }
             break;
-          case 170 /* PropertySignature */:
-            if (!hasSyntacticModifier(parent2, 64 /* Readonly */)) {
+          case 171 /* PropertySignature */:
+            if (!hasSyntacticModifier(parent2, 8 /* Readonly */)) {
               return grammarErrorOnNode(parent2.name, Diagnostics.A_property_of_an_interface_or_type_literal_whose_type_is_a_unique_symbol_type_must_be_readonly);
             }
             break;
@@ -184427,7 +168441,7 @@ ${lanes.join("\n")}
             return grammarErrorOnNode(node, Diagnostics.unique_symbol_types_are_not_allowed_here);
         }
       } else if (node.operator === 148 /* ReadonlyKeyword */) {
-        if (node.type.kind !== 187 /* ArrayType */ && node.type.kind !== 188 /* TupleType */) {
+        if (node.type.kind !== 188 /* ArrayType */ && node.type.kind !== 189 /* TupleType */) {
           return grammarErrorOnFirstToken(node, Diagnostics.readonly_type_modifier_is_only_permitted_on_array_and_tuple_literal_types, tokenToString(155 /* SymbolKeyword */));
         }
       }
@@ -184441,8 +168455,8 @@ ${lanes.join("\n")}
       if (checkGrammarFunctionLikeDeclaration(node)) {
         return true;
       }
-      if (node.kind === 173 /* MethodDeclaration */) {
-        if (node.parent.kind === 209 /* ObjectLiteralExpression */) {
+      if (node.kind === 174 /* MethodDeclaration */) {
+        if (node.parent.kind === 210 /* ObjectLiteralExpression */) {
           if (node.modifiers && !(node.modifiers.length === 1 && first(node.modifiers).kind === 134 /* AsyncKeyword */)) {
             return grammarErrorOnFirstToken(node, Diagnostics.Modifiers_cannot_appear_here);
           } else if (checkGrammarForInvalidQuestionMark(node.questionToken, Diagnostics.An_object_member_cannot_be_declared_optional)) {
@@ -184461,14 +168475,14 @@ ${lanes.join("\n")}
         if (languageVersion < 2 /* ES2015 */ && isPrivateIdentifier(node.name)) {
           return grammarErrorOnNode(node.name, Diagnostics.Private_identifiers_are_only_available_when_targeting_ECMAScript_2015_and_higher);
         }
-        if (node.flags & 16777216 /* Ambient */) {
+        if (node.flags & 33554432 /* Ambient */) {
           return checkGrammarForInvalidDynamicName(node.name, Diagnostics.A_computed_property_name_in_an_ambient_context_must_refer_to_an_expression_whose_type_is_a_literal_type_or_a_unique_symbol_type);
-        } else if (node.kind === 173 /* MethodDeclaration */ && !node.body) {
+        } else if (node.kind === 174 /* MethodDeclaration */ && !node.body) {
           return checkGrammarForInvalidDynamicName(node.name, Diagnostics.A_computed_property_name_in_a_method_overload_must_refer_to_an_expression_whose_type_is_a_literal_type_or_a_unique_symbol_type);
         }
-      } else if (node.parent.kind === 263 /* InterfaceDeclaration */) {
+      } else if (node.parent.kind === 264 /* InterfaceDeclaration */) {
         return checkGrammarForInvalidDynamicName(node.name, Diagnostics.A_computed_property_name_in_an_interface_must_refer_to_an_expression_whose_type_is_a_literal_type_or_a_unique_symbol_type);
-      } else if (node.parent.kind === 186 /* TypeLiteral */) {
+      } else if (node.parent.kind === 187 /* TypeLiteral */) {
         return checkGrammarForInvalidDynamicName(node.name, Diagnostics.A_computed_property_name_in_a_type_literal_must_refer_to_an_expression_whose_type_is_a_literal_type_or_a_unique_symbol_type);
       }
     }
@@ -184479,9 +168493,9 @@ ${lanes.join("\n")}
           return grammarErrorOnNode(node, Diagnostics.Jump_target_cannot_cross_function_boundary);
         }
         switch (current.kind) {
-          case 255 /* LabeledStatement */:
+          case 256 /* LabeledStatement */:
             if (node.label && current.label.escapedText === node.label.escapedText) {
-              const isMisplacedContinueLabel = node.kind === 250 /* ContinueStatement */ && !isIterationStatement(
+              const isMisplacedContinueLabel = node.kind === 251 /* ContinueStatement */ && !isIterationStatement(
                 current.statement,
                 /*lookInLabeledStatements*/
                 true
@@ -184492,8 +168506,8 @@ ${lanes.join("\n")}
               return false;
             }
             break;
-          case 254 /* SwitchStatement */:
-            if (node.kind === 251 /* BreakStatement */ && !node.label) {
+          case 255 /* SwitchStatement */:
+            if (node.kind === 252 /* BreakStatement */ && !node.label) {
               return false;
             }
             break;
@@ -184510,10 +168524,10 @@ ${lanes.join("\n")}
         current = current.parent;
       }
       if (node.label) {
-        const message = node.kind === 251 /* BreakStatement */ ? Diagnostics.A_break_statement_can_only_jump_to_a_label_of_an_enclosing_statement : Diagnostics.A_continue_statement_can_only_jump_to_a_label_of_an_enclosing_iteration_statement;
+        const message = node.kind === 252 /* BreakStatement */ ? Diagnostics.A_break_statement_can_only_jump_to_a_label_of_an_enclosing_statement : Diagnostics.A_continue_statement_can_only_jump_to_a_label_of_an_enclosing_iteration_statement;
         return grammarErrorOnNode(node, message);
       } else {
-        const message = node.kind === 251 /* BreakStatement */ ? Diagnostics.A_break_statement_can_only_be_used_within_an_enclosing_iteration_or_switch_statement : Diagnostics.A_continue_statement_can_only_be_used_within_an_enclosing_iteration_statement;
+        const message = node.kind === 252 /* BreakStatement */ ? Diagnostics.A_break_statement_can_only_be_used_within_an_enclosing_iteration_or_switch_statement : Diagnostics.A_continue_statement_can_only_be_used_within_an_enclosing_iteration_statement;
         return grammarErrorOnNode(node, message);
       }
     }
@@ -184533,10 +168547,10 @@ ${lanes.join("\n")}
       }
     }
     function isStringOrNumberLiteralExpression(expr) {
-      return isStringOrNumericLiteralLike(expr) || expr.kind === 223 /* PrefixUnaryExpression */ && expr.operator === 41 /* MinusToken */ && expr.operand.kind === 9 /* NumericLiteral */;
+      return isStringOrNumericLiteralLike(expr) || expr.kind === 224 /* PrefixUnaryExpression */ && expr.operator === 41 /* MinusToken */ && expr.operand.kind === 9 /* NumericLiteral */;
     }
     function isBigIntLiteralExpression(expr) {
-      return expr.kind === 10 /* BigIntLiteral */ || expr.kind === 223 /* PrefixUnaryExpression */ && expr.operator === 41 /* MinusToken */ && expr.operand.kind === 10 /* BigIntLiteral */;
+      return expr.kind === 10 /* BigIntLiteral */ || expr.kind === 224 /* PrefixUnaryExpression */ && expr.operator === 41 /* MinusToken */ && expr.operand.kind === 10 /* BigIntLiteral */;
     }
     function isSimpleLiteralEnumReference(expr) {
       if ((isPropertyAccessExpression(expr) || isElementAccessExpression(expr) && isStringOrNumberLiteralExpression(expr.argumentExpression)) && isEntityNameExpression(expr.expression)) {
@@ -184547,7 +168561,7 @@ ${lanes.join("\n")}
       const initializer = node.initializer;
       if (initializer) {
         const isInvalidInitializer = !(isStringOrNumberLiteralExpression(initializer) || isSimpleLiteralEnumReference(initializer) || initializer.kind === 112 /* TrueKeyword */ || initializer.kind === 97 /* FalseKeyword */ || isBigIntLiteralExpression(initializer));
-        const isConstOrReadonly = isDeclarationReadonly(node) || isVariableDeclaration(node) && isVarConst(node);
+        const isConstOrReadonly = isDeclarationReadonly(node) || isVariableDeclaration(node) && isVarConstLike(node);
         if (isConstOrReadonly && !node.type) {
           if (isInvalidInitializer) {
             return grammarErrorOnNode(initializer, Diagnostics.A_const_initializer_in_an_ambient_context_must_be_a_string_or_numeric_literal_or_literal_enum_reference);
@@ -184558,27 +168572,41 @@ ${lanes.join("\n")}
       }
     }
     function checkGrammarVariableDeclaration(node) {
-      if (node.parent.parent.kind !== 248 /* ForInStatement */ && node.parent.parent.kind !== 249 /* ForOfStatement */) {
-        if (node.flags & 16777216 /* Ambient */) {
+      const nodeFlags = getCombinedNodeFlagsCached(node);
+      const blockScopeKind = nodeFlags & 7 /* BlockScoped */;
+      if (isBindingPattern(node.name)) {
+        switch (blockScopeKind) {
+          case 6 /* AwaitUsing */:
+            return grammarErrorOnNode(node, Diagnostics._0_declarations_may_not_have_binding_patterns, "await using");
+          case 4 /* Using */:
+            return grammarErrorOnNode(node, Diagnostics._0_declarations_may_not_have_binding_patterns, "using");
+        }
+      }
+      if (node.parent.parent.kind !== 249 /* ForInStatement */ && node.parent.parent.kind !== 250 /* ForOfStatement */) {
+        if (nodeFlags & 33554432 /* Ambient */) {
           checkAmbientInitializer(node);
         } else if (!node.initializer) {
           if (isBindingPattern(node.name) && !isBindingPattern(node.parent)) {
             return grammarErrorOnNode(node, Diagnostics.A_destructuring_declaration_must_have_an_initializer);
           }
-          if (isVarConst(node)) {
-            return grammarErrorOnNode(node, Diagnostics.const_declarations_must_be_initialized);
+          switch (blockScopeKind) {
+            case 6 /* AwaitUsing */:
+              return grammarErrorOnNode(node, Diagnostics._0_declarations_must_be_initialized, "await using");
+            case 4 /* Using */:
+              return grammarErrorOnNode(node, Diagnostics._0_declarations_must_be_initialized, "using");
+            case 2 /* Const */:
+              return grammarErrorOnNode(node, Diagnostics._0_declarations_must_be_initialized, "const");
           }
         }
       }
-      if (node.exclamationToken && (node.parent.parent.kind !== 242 /* VariableStatement */ || !node.type || node.initializer || node.flags & 16777216 /* Ambient */)) {
+      if (node.exclamationToken && (node.parent.parent.kind !== 243 /* VariableStatement */ || !node.type || node.initializer || nodeFlags & 33554432 /* Ambient */)) {
         const message = node.initializer ? Diagnostics.Declarations_with_initializers_cannot_also_have_definite_assignment_assertions : !node.type ? Diagnostics.Declarations_with_definite_assignment_assertions_must_also_have_type_annotations : Diagnostics.A_definite_assignment_assertion_is_not_permitted_in_this_context;
         return grammarErrorOnNode(node.exclamationToken, message);
       }
-      if ((moduleKind < 5 /* ES2015 */ || getSourceFileOfNode(node).impliedNodeFormat === 1 /* CommonJS */) && moduleKind !== 4 /* System */ && !(node.parent.parent.flags & 16777216 /* Ambient */) && hasSyntacticModifier(node.parent.parent, 1 /* Export */)) {
+      if ((moduleKind < 5 /* ES2015 */ || getSourceFileOfNode(node).impliedNodeFormat === 1 /* CommonJS */) && moduleKind !== 4 /* System */ && !(node.parent.parent.flags & 33554432 /* Ambient */) && hasSyntacticModifier(node.parent.parent, 32 /* Export */)) {
         checkESModuleMarker(node.name);
       }
-      const checkLetConstNames = isLet(node) || isVarConst(node);
-      return checkLetConstNames && checkGrammarNameInLetOrConstDeclarations(node.name);
+      return !!blockScopeKind && checkGrammarNameInLetOrConstDeclarations(node.name);
     }
     function checkESModuleMarker(name) {
       if (name.kind === 80 /* Identifier */) {
@@ -184618,29 +168646,39 @@ ${lanes.join("\n")}
       if (!declarationList.declarations.length) {
         return grammarErrorAtPos(declarationList, declarations.pos, declarations.end - declarations.pos, Diagnostics.Variable_declaration_list_cannot_be_empty);
       }
+      const blockScopeFlags = declarationList.flags & 7 /* BlockScoped */;
+      if ((blockScopeFlags === 4 /* Using */ || blockScopeFlags === 6 /* AwaitUsing */) && isForInStatement(declarationList.parent)) {
+        return grammarErrorOnNode(
+          declarationList,
+          blockScopeFlags === 4 /* Using */ ? Diagnostics.The_left_hand_side_of_a_for_in_statement_cannot_be_a_using_declaration : Diagnostics.The_left_hand_side_of_a_for_in_statement_cannot_be_an_await_using_declaration
+        );
+      }
+      if (blockScopeFlags === 6 /* AwaitUsing */) {
+        return checkAwaitGrammar(declarationList);
+      }
       return false;
     }
     function allowLetAndConstDeclarations(parent2) {
       switch (parent2.kind) {
-        case 244 /* IfStatement */:
-        case 245 /* DoStatement */:
-        case 246 /* WhileStatement */:
-        case 253 /* WithStatement */:
-        case 247 /* ForStatement */:
-        case 248 /* ForInStatement */:
-        case 249 /* ForOfStatement */:
+        case 245 /* IfStatement */:
+        case 246 /* DoStatement */:
+        case 247 /* WhileStatement */:
+        case 254 /* WithStatement */:
+        case 248 /* ForStatement */:
+        case 249 /* ForInStatement */:
+        case 250 /* ForOfStatement */:
           return false;
-        case 255 /* LabeledStatement */:
+        case 256 /* LabeledStatement */:
           return allowLetAndConstDeclarations(parent2.parent);
       }
       return true;
     }
-    function checkGrammarForDisallowedLetOrConstStatement(node) {
+    function checkGrammarForDisallowedBlockScopedVariableStatement(node) {
       if (!allowLetAndConstDeclarations(node.parent)) {
-        if (isLet(node.declarationList)) {
-          return grammarErrorOnNode(node, Diagnostics.let_declarations_can_only_be_declared_inside_a_block);
-        } else if (isVarConst(node.declarationList)) {
-          return grammarErrorOnNode(node, Diagnostics.const_declarations_can_only_be_declared_inside_a_block);
+        const blockScopeKind = getCombinedNodeFlagsCached(node.declarationList) & 7 /* BlockScoped */;
+        if (blockScopeKind) {
+          const keyword = blockScopeKind === 1 /* Let */ ? "let" : blockScopeKind === 2 /* Const */ ? "const" : blockScopeKind === 4 /* Using */ ? "using" : blockScopeKind === 6 /* AwaitUsing */ ? "await using" : Debug.fail("Unknown BlockScope flag");
+          return grammarErrorOnNode(node, Diagnostics._0_declarations_can_only_be_declared_inside_a_block, keyword);
         }
       }
     }
@@ -184729,7 +168767,7 @@ ${lanes.join("\n")}
         if (isAutoAccessorPropertyDeclaration(node) && checkGrammarForInvalidQuestionMark(node.questionToken, Diagnostics.An_accessor_property_cannot_be_declared_optional)) {
           return true;
         }
-      } else if (node.parent.kind === 263 /* InterfaceDeclaration */) {
+      } else if (node.parent.kind === 264 /* InterfaceDeclaration */) {
         if (checkGrammarForInvalidDynamicName(node.name, Diagnostics.A_computed_property_name_in_an_interface_must_refer_to_an_expression_whose_type_is_a_literal_type_or_a_unique_symbol_type)) {
           return true;
         }
@@ -184746,23 +168784,23 @@ ${lanes.join("\n")}
           return grammarErrorOnNode(node.initializer, Diagnostics.A_type_literal_property_cannot_have_an_initializer);
         }
       }
-      if (node.flags & 16777216 /* Ambient */) {
+      if (node.flags & 33554432 /* Ambient */) {
         checkAmbientInitializer(node);
       }
-      if (isPropertyDeclaration(node) && node.exclamationToken && (!isClassLike(node.parent) || !node.type || node.initializer || node.flags & 16777216 /* Ambient */ || isStatic(node) || hasAbstractModifier(node))) {
+      if (isPropertyDeclaration(node) && node.exclamationToken && (!isClassLike(node.parent) || !node.type || node.initializer || node.flags & 33554432 /* Ambient */ || isStatic(node) || hasAbstractModifier(node))) {
         const message = node.initializer ? Diagnostics.Declarations_with_initializers_cannot_also_have_definite_assignment_assertions : !node.type ? Diagnostics.Declarations_with_definite_assignment_assertions_must_also_have_type_annotations : Diagnostics.A_definite_assignment_assertion_is_not_permitted_in_this_context;
         return grammarErrorOnNode(node.exclamationToken, message);
       }
     }
     function checkGrammarTopLevelElementForRequiredDeclareModifier(node) {
-      if (node.kind === 263 /* InterfaceDeclaration */ || node.kind === 264 /* TypeAliasDeclaration */ || node.kind === 271 /* ImportDeclaration */ || node.kind === 270 /* ImportEqualsDeclaration */ || node.kind === 277 /* ExportDeclaration */ || node.kind === 276 /* ExportAssignment */ || node.kind === 269 /* NamespaceExportDeclaration */ || hasSyntacticModifier(node, 2 /* Ambient */ | 1 /* Export */ | 1024 /* Default */)) {
+      if (node.kind === 264 /* InterfaceDeclaration */ || node.kind === 265 /* TypeAliasDeclaration */ || node.kind === 272 /* ImportDeclaration */ || node.kind === 271 /* ImportEqualsDeclaration */ || node.kind === 278 /* ExportDeclaration */ || node.kind === 277 /* ExportAssignment */ || node.kind === 270 /* NamespaceExportDeclaration */ || hasSyntacticModifier(node, 128 /* Ambient */ | 32 /* Export */ | 2048 /* Default */)) {
         return false;
       }
       return grammarErrorOnFirstToken(node, Diagnostics.Top_level_declarations_in_d_ts_files_must_start_with_either_a_declare_or_export_modifier);
     }
     function checkGrammarTopLevelElementsForRequiredDeclareModifier(file) {
       for (const decl of file.statements) {
-        if (isDeclaration(decl) || decl.kind === 242 /* VariableStatement */) {
+        if (isDeclaration(decl) || decl.kind === 243 /* VariableStatement */) {
           if (checkGrammarTopLevelElementForRequiredDeclareModifier(decl)) {
             return true;
           }
@@ -184771,15 +168809,15 @@ ${lanes.join("\n")}
       return false;
     }
     function checkGrammarSourceFile(node) {
-      return !!(node.flags & 16777216 /* Ambient */) && checkGrammarTopLevelElementsForRequiredDeclareModifier(node);
+      return !!(node.flags & 33554432 /* Ambient */) && checkGrammarTopLevelElementsForRequiredDeclareModifier(node);
     }
     function checkGrammarStatementInAmbientContext(node) {
-      if (node.flags & 16777216 /* Ambient */) {
+      if (node.flags & 33554432 /* Ambient */) {
         const links = getNodeLinks(node);
         if (!links.hasReportedStatementInAmbientContext && (isFunctionLike(node.parent) || isAccessor(node.parent))) {
           return getNodeLinks(node).hasReportedStatementInAmbientContext = grammarErrorOnFirstToken(node, Diagnostics.An_implementation_cannot_be_declared_in_ambient_contexts);
         }
-        if (node.parent.kind === 240 /* Block */ || node.parent.kind === 267 /* ModuleBlock */ || node.parent.kind === 311 /* SourceFile */) {
+        if (node.parent.kind === 241 /* Block */ || node.parent.kind === 268 /* ModuleBlock */ || node.parent.kind === 312 /* SourceFile */) {
           const links2 = getNodeLinks(node.parent);
           if (!links2.hasReportedStatementInAmbientContext) {
             return links2.hasReportedStatementInAmbientContext = grammarErrorOnFirstToken(node, Diagnostics.Statements_are_not_allowed_in_ambient_contexts);
@@ -184790,7 +168828,7 @@ ${lanes.join("\n")}
       return false;
     }
     function checkGrammarNumericLiteral(node) {
-      const isFractional = getTextOfNode(node).indexOf(".") !== -1;
+      const isFractional = getTextOfNode(node).includes(".");
       const isScientific = node.numericLiteralFlags & 16 /* Scientific */;
       if (isFractional || isScientific) {
         return;
@@ -184848,7 +168886,7 @@ ${lanes.join("\n")}
       if (node.isTypeOnly && node.name && node.namedBindings) {
         return grammarErrorOnNode(node, Diagnostics.A_type_only_import_can_specify_a_default_import_or_named_bindings_but_not_both);
       }
-      if (node.isTypeOnly && ((_a = node.namedBindings) == null ? void 0 : _a.kind) === 274 /* NamedImports */) {
+      if (node.isTypeOnly && ((_a = node.namedBindings) == null ? void 0 : _a.kind) === 275 /* NamedImports */) {
         return checkGrammarNamedImportsOrExports(node.namedBindings);
       }
       return false;
@@ -184858,7 +168896,7 @@ ${lanes.join("\n")}
         if (specifier.isTypeOnly) {
           return grammarErrorOnFirstToken(
             specifier,
-            specifier.kind === 275 /* ImportSpecifier */ ? Diagnostics.The_type_modifier_cannot_be_used_on_a_named_import_when_import_type_is_used_on_its_import_statement : Diagnostics.The_type_modifier_cannot_be_used_on_a_named_export_when_export_type_is_used_on_its_export_statement
+            specifier.kind === 276 /* ImportSpecifier */ ? Diagnostics.The_type_modifier_cannot_be_used_on_a_named_import_when_import_type_is_used_on_its_import_statement : Diagnostics.The_type_modifier_cannot_be_used_on_a_named_export_when_export_type_is_used_on_its_export_statement
           );
         }
       });
@@ -184877,12 +168915,12 @@ ${lanes.join("\n")}
       if (moduleKind !== 99 /* ESNext */ && moduleKind !== 199 /* NodeNext */ && moduleKind !== 100 /* Node16 */) {
         checkGrammarForDisallowedTrailingComma(nodeArguments);
         if (nodeArguments.length > 1) {
-          const assertionArgument = nodeArguments[1];
-          return grammarErrorOnNode(assertionArgument, Diagnostics.Dynamic_imports_only_support_a_second_argument_when_the_module_option_is_set_to_esnext_node16_or_nodenext);
+          const importAttributesArgument = nodeArguments[1];
+          return grammarErrorOnNode(importAttributesArgument, Diagnostics.Dynamic_imports_only_support_a_second_argument_when_the_module_option_is_set_to_esnext_node16_or_nodenext);
         }
       }
       if (nodeArguments.length === 0 || nodeArguments.length > 2) {
-        return grammarErrorOnNode(node, Diagnostics.Dynamic_imports_can_only_accept_a_module_specifier_and_an_optional_assertion_as_arguments);
+        return grammarErrorOnNode(node, Diagnostics.Dynamic_imports_can_only_accept_a_module_specifier_and_an_optional_set_of_attributes_as_arguments);
       }
       const spreadElement = find(nodeArguments, isSpreadElement);
       if (spreadElement) {
@@ -184970,19 +169008,39 @@ ${lanes.join("\n")}
     }
     function getEffectivePropertyNameForPropertyNameNode(node) {
       const name = getPropertyNameForPropertyNameNode(node);
-      return name ? name : isComputedPropertyName(node) && isEntityNameExpression(node.expression) ? tryGetNameFromEntityNameExpression(node.expression) : void 0;
+      return name ? name : isComputedPropertyName(node) ? tryGetNameFromType(getTypeOfExpression(node.expression)) : void 0;
+    }
+    function getCombinedModifierFlagsCached(node) {
+      if (lastGetCombinedModifierFlagsNode === node) {
+        return lastGetCombinedModifierFlagsResult;
+      }
+      lastGetCombinedModifierFlagsNode = node;
+      lastGetCombinedModifierFlagsResult = getCombinedModifierFlags(node);
+      return lastGetCombinedModifierFlagsResult;
+    }
+    function getCombinedNodeFlagsCached(node) {
+      if (lastGetCombinedNodeFlagsNode === node) {
+        return lastGetCombinedNodeFlagsResult;
+      }
+      lastGetCombinedNodeFlagsNode = node;
+      lastGetCombinedNodeFlagsResult = getCombinedNodeFlags(node);
+      return lastGetCombinedNodeFlagsResult;
+    }
+    function isVarConstLike(node) {
+      const blockScopeKind = getCombinedNodeFlagsCached(node) & 7 /* BlockScoped */;
+      return blockScopeKind === 2 /* Const */ || blockScopeKind === 4 /* Using */ || blockScopeKind === 6 /* AwaitUsing */;
     }
   }
   function isNotAccessor(declaration) {
     return !isAccessor(declaration);
   }
   function isNotOverload(declaration) {
-    return declaration.kind !== 261 /* FunctionDeclaration */ && declaration.kind !== 173 /* MethodDeclaration */ || !!declaration.body;
+    return declaration.kind !== 262 /* FunctionDeclaration */ && declaration.kind !== 174 /* MethodDeclaration */ || !!declaration.body;
   }
   function isDeclarationNameOrImportPropertyName(name) {
     switch (name.parent.kind) {
-      case 275 /* ImportSpecifier */:
-      case 280 /* ExportSpecifier */:
+      case 276 /* ImportSpecifier */:
+      case 281 /* ExportSpecifier */:
         return isIdentifier(name);
       default:
         return isDeclarationName(name);
@@ -185131,8 +169189,8 @@ ${lanes.join("\n")}
         CheckMode3[CheckMode3["SkipContextSensitive"] = 4] = "SkipContextSensitive";
         CheckMode3[CheckMode3["SkipGenericFunctions"] = 8] = "SkipGenericFunctions";
         CheckMode3[CheckMode3["IsForSignatureHelp"] = 16] = "IsForSignatureHelp";
-        CheckMode3[CheckMode3["IsForStringLiteralArgumentCompletions"] = 32] = "IsForStringLiteralArgumentCompletions";
-        CheckMode3[CheckMode3["RestBindingElement"] = 64] = "RestBindingElement";
+        CheckMode3[CheckMode3["RestBindingElement"] = 32] = "RestBindingElement";
+        CheckMode3[CheckMode3["TypeOnly"] = 64] = "TypeOnly";
         return CheckMode3;
       })(CheckMode || {});
       SignatureCheckMode = /* @__PURE__ */ ((SignatureCheckMode3) => {
@@ -185166,13 +169224,13 @@ ${lanes.join("\n")}
         JsxNames2.IntrinsicClassAttributes = "IntrinsicClassAttributes";
         JsxNames2.LibraryManagedAttributes = "LibraryManagedAttributes";
       })(JsxNames || (JsxNames = {}));
-      SymbolTrackerImpl = class {
+      SymbolTrackerImpl = class _SymbolTrackerImpl {
         constructor(context, tracker, moduleResolverHost) {
           this.moduleResolverHost = void 0;
           this.inner = void 0;
           this.disableTrackSymbol = false;
           var _a;
-          while (tracker instanceof SymbolTrackerImpl) {
+          while (tracker instanceof _SymbolTrackerImpl) {
             tracker = tracker.inner;
           }
           this.inner = tracker;
@@ -185181,12 +169239,14 @@ ${lanes.join("\n")}
           this.canTrackSymbol = !!((_a = this.inner) == null ? void 0 : _a.trackSymbol);
         }
         trackSymbol(symbol, enclosingDeclaration, meaning) {
-          var _a;
+          var _a, _b;
           if (((_a = this.inner) == null ? void 0 : _a.trackSymbol) && !this.disableTrackSymbol) {
             if (this.inner.trackSymbol(symbol, enclosingDeclaration, meaning)) {
               this.onDiagnosticReported();
               return true;
             }
+            if (!(symbol.flags & 262144 /* TypeParameter */))
+              ((_b = this.context).trackedSymbols ?? (_b.trackedSymbols = [])).push([symbol, enclosingDeclaration, meaning]);
           }
           return false;
         }
@@ -185260,13 +169320,6 @@ ${lanes.join("\n")}
             this.inner.reportNonSerializableProperty(propertyName);
           }
         }
-        reportImportTypeNodeResolutionModeOverride() {
-          var _a;
-          if ((_a = this.inner) == null ? void 0 : _a.reportImportTypeNodeResolutionModeOverride) {
-            this.onDiagnosticReported();
-            this.inner.reportImportTypeNodeResolutionModeOverride();
-          }
-        }
         onDiagnosticReported() {
           this.context.reportedDiagnostic = true;
         }
@@ -185541,21 +169594,21 @@ ${lanes.join("\n")}
       "use strict";
       init_ts2();
       visitEachChildTable = {
-        [165 /* QualifiedName */]: function visitEachChildOfQualifiedName(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
+        [166 /* QualifiedName */]: function visitEachChildOfQualifiedName(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
           return context.factory.updateQualifiedName(
             node,
             Debug.checkDefined(nodeVisitor(node.left, visitor, isEntityName)),
             Debug.checkDefined(nodeVisitor(node.right, visitor, isIdentifier))
           );
         },
-        [166 /* ComputedPropertyName */]: function visitEachChildOfComputedPropertyName(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
+        [167 /* ComputedPropertyName */]: function visitEachChildOfComputedPropertyName(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
           return context.factory.updateComputedPropertyName(
             node,
             Debug.checkDefined(nodeVisitor(node.expression, visitor, isExpression))
           );
         },
         // Signature elements
-        [167 /* TypeParameter */]: function visitEachChildOfTypeParameterDeclaration(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) {
+        [168 /* TypeParameter */]: function visitEachChildOfTypeParameterDeclaration(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) {
           return context.factory.updateTypeParameterDeclaration(
             node,
             nodesVisitor(node.modifiers, visitor, isModifier),
@@ -185564,7 +169617,7 @@ ${lanes.join("\n")}
             nodeVisitor(node.default, visitor, isTypeNode)
           );
         },
-        [168 /* Parameter */]: function visitEachChildOfParameterDeclaration(node, visitor, context, nodesVisitor, nodeVisitor, tokenVisitor) {
+        [169 /* Parameter */]: function visitEachChildOfParameterDeclaration(node, visitor, context, nodesVisitor, nodeVisitor, tokenVisitor) {
           return context.factory.updateParameterDeclaration(
             node,
             nodesVisitor(node.modifiers, visitor, isModifierLike),
@@ -185575,14 +169628,14 @@ ${lanes.join("\n")}
             nodeVisitor(node.initializer, visitor, isExpression)
           );
         },
-        [169 /* Decorator */]: function visitEachChildOfDecorator(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
+        [170 /* Decorator */]: function visitEachChildOfDecorator(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
           return context.factory.updateDecorator(
             node,
             Debug.checkDefined(nodeVisitor(node.expression, visitor, isExpression))
           );
         },
         // Type elements
-        [170 /* PropertySignature */]: function visitEachChildOfPropertySignature(node, visitor, context, nodesVisitor, nodeVisitor, tokenVisitor) {
+        [171 /* PropertySignature */]: function visitEachChildOfPropertySignature(node, visitor, context, nodesVisitor, nodeVisitor, tokenVisitor) {
           return context.factory.updatePropertySignature(
             node,
             nodesVisitor(node.modifiers, visitor, isModifier),
@@ -185591,7 +169644,7 @@ ${lanes.join("\n")}
             nodeVisitor(node.type, visitor, isTypeNode)
           );
         },
-        [171 /* PropertyDeclaration */]: function visitEachChildOfPropertyDeclaration(node, visitor, context, nodesVisitor, nodeVisitor, tokenVisitor) {
+        [172 /* PropertyDeclaration */]: function visitEachChildOfPropertyDeclaration(node, visitor, context, nodesVisitor, nodeVisitor, tokenVisitor) {
           return context.factory.updatePropertyDeclaration(
             node,
             nodesVisitor(node.modifiers, visitor, isModifierLike),
@@ -185602,7 +169655,7 @@ ${lanes.join("\n")}
             nodeVisitor(node.initializer, visitor, isExpression)
           );
         },
-        [172 /* MethodSignature */]: function visitEachChildOfMethodSignature(node, visitor, context, nodesVisitor, nodeVisitor, tokenVisitor) {
+        [173 /* MethodSignature */]: function visitEachChildOfMethodSignature(node, visitor, context, nodesVisitor, nodeVisitor, tokenVisitor) {
           return context.factory.updateMethodSignature(
             node,
             nodesVisitor(node.modifiers, visitor, isModifier),
@@ -185613,7 +169666,7 @@ ${lanes.join("\n")}
             nodeVisitor(node.type, visitor, isTypeNode)
           );
         },
-        [173 /* MethodDeclaration */]: function visitEachChildOfMethodDeclaration(node, visitor, context, nodesVisitor, nodeVisitor, tokenVisitor) {
+        [174 /* MethodDeclaration */]: function visitEachChildOfMethodDeclaration(node, visitor, context, nodesVisitor, nodeVisitor, tokenVisitor) {
           return context.factory.updateMethodDeclaration(
             node,
             nodesVisitor(node.modifiers, visitor, isModifierLike),
@@ -185626,7 +169679,7 @@ ${lanes.join("\n")}
             visitFunctionBody(node.body, visitor, context, nodeVisitor)
           );
         },
-        [175 /* Constructor */]: function visitEachChildOfConstructorDeclaration(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) {
+        [176 /* Constructor */]: function visitEachChildOfConstructorDeclaration(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) {
           return context.factory.updateConstructorDeclaration(
             node,
             nodesVisitor(node.modifiers, visitor, isModifierLike),
@@ -185634,7 +169687,7 @@ ${lanes.join("\n")}
             visitFunctionBody(node.body, visitor, context, nodeVisitor)
           );
         },
-        [176 /* GetAccessor */]: function visitEachChildOfGetAccessorDeclaration(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) {
+        [177 /* GetAccessor */]: function visitEachChildOfGetAccessorDeclaration(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) {
           return context.factory.updateGetAccessorDeclaration(
             node,
             nodesVisitor(node.modifiers, visitor, isModifierLike),
@@ -185644,7 +169697,7 @@ ${lanes.join("\n")}
             visitFunctionBody(node.body, visitor, context, nodeVisitor)
           );
         },
-        [177 /* SetAccessor */]: function visitEachChildOfSetAccessorDeclaration(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) {
+        [178 /* SetAccessor */]: function visitEachChildOfSetAccessorDeclaration(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) {
           return context.factory.updateSetAccessorDeclaration(
             node,
             nodesVisitor(node.modifiers, visitor, isModifierLike),
@@ -185653,7 +169706,7 @@ ${lanes.join("\n")}
             visitFunctionBody(node.body, visitor, context, nodeVisitor)
           );
         },
-        [174 /* ClassStaticBlockDeclaration */]: function visitEachChildOfClassStaticBlockDeclaration(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
+        [175 /* ClassStaticBlockDeclaration */]: function visitEachChildOfClassStaticBlockDeclaration(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
           context.startLexicalEnvironment();
           context.suspendLexicalEnvironment();
           return context.factory.updateClassStaticBlockDeclaration(
@@ -185661,7 +169714,7 @@ ${lanes.join("\n")}
             visitFunctionBody(node.body, visitor, context, nodeVisitor)
           );
         },
-        [178 /* CallSignature */]: function visitEachChildOfCallSignatureDeclaration(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) {
+        [179 /* CallSignature */]: function visitEachChildOfCallSignatureDeclaration(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) {
           return context.factory.updateCallSignature(
             node,
             nodesVisitor(node.typeParameters, visitor, isTypeParameterDeclaration),
@@ -185669,7 +169722,7 @@ ${lanes.join("\n")}
             nodeVisitor(node.type, visitor, isTypeNode)
           );
         },
-        [179 /* ConstructSignature */]: function visitEachChildOfConstructSignatureDeclaration(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) {
+        [180 /* ConstructSignature */]: function visitEachChildOfConstructSignatureDeclaration(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) {
           return context.factory.updateConstructSignature(
             node,
             nodesVisitor(node.typeParameters, visitor, isTypeParameterDeclaration),
@@ -185677,7 +169730,7 @@ ${lanes.join("\n")}
             nodeVisitor(node.type, visitor, isTypeNode)
           );
         },
-        [180 /* IndexSignature */]: function visitEachChildOfIndexSignatureDeclaration(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) {
+        [181 /* IndexSignature */]: function visitEachChildOfIndexSignatureDeclaration(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) {
           return context.factory.updateIndexSignature(
             node,
             nodesVisitor(node.modifiers, visitor, isModifierLike),
@@ -185686,7 +169739,7 @@ ${lanes.join("\n")}
           );
         },
         // Types
-        [181 /* TypePredicate */]: function visitEachChildOfTypePredicateNode(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
+        [182 /* TypePredicate */]: function visitEachChildOfTypePredicateNode(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
           return context.factory.updateTypePredicateNode(
             node,
             nodeVisitor(node.assertsModifier, visitor, isAssertsKeyword),
@@ -185694,14 +169747,14 @@ ${lanes.join("\n")}
             nodeVisitor(node.type, visitor, isTypeNode)
           );
         },
-        [182 /* TypeReference */]: function visitEachChildOfTypeReferenceNode(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) {
+        [183 /* TypeReference */]: function visitEachChildOfTypeReferenceNode(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) {
           return context.factory.updateTypeReferenceNode(
             node,
             Debug.checkDefined(nodeVisitor(node.typeName, visitor, isEntityName)),
             nodesVisitor(node.typeArguments, visitor, isTypeNode)
           );
         },
-        [183 /* FunctionType */]: function visitEachChildOfFunctionTypeNode(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) {
+        [184 /* FunctionType */]: function visitEachChildOfFunctionTypeNode(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) {
           return context.factory.updateFunctionTypeNode(
             node,
             nodesVisitor(node.typeParameters, visitor, isTypeParameterDeclaration),
@@ -185709,7 +169762,7 @@ ${lanes.join("\n")}
             Debug.checkDefined(nodeVisitor(node.type, visitor, isTypeNode))
           );
         },
-        [184 /* ConstructorType */]: function visitEachChildOfConstructorTypeNode(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) {
+        [185 /* ConstructorType */]: function visitEachChildOfConstructorTypeNode(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) {
           return context.factory.updateConstructorTypeNode(
             node,
             nodesVisitor(node.modifiers, visitor, isModifier),
@@ -185718,56 +169771,56 @@ ${lanes.join("\n")}
             Debug.checkDefined(nodeVisitor(node.type, visitor, isTypeNode))
           );
         },
-        [185 /* TypeQuery */]: function visitEachChildOfTypeQueryNode(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) {
+        [186 /* TypeQuery */]: function visitEachChildOfTypeQueryNode(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) {
           return context.factory.updateTypeQueryNode(
             node,
             Debug.checkDefined(nodeVisitor(node.exprName, visitor, isEntityName)),
             nodesVisitor(node.typeArguments, visitor, isTypeNode)
           );
         },
-        [186 /* TypeLiteral */]: function visitEachChildOfTypeLiteralNode(node, visitor, context, nodesVisitor, _nodeVisitor, _tokenVisitor) {
+        [187 /* TypeLiteral */]: function visitEachChildOfTypeLiteralNode(node, visitor, context, nodesVisitor, _nodeVisitor, _tokenVisitor) {
           return context.factory.updateTypeLiteralNode(
             node,
             nodesVisitor(node.members, visitor, isTypeElement)
           );
         },
-        [187 /* ArrayType */]: function visitEachChildOfArrayTypeNode(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
+        [188 /* ArrayType */]: function visitEachChildOfArrayTypeNode(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
           return context.factory.updateArrayTypeNode(
             node,
             Debug.checkDefined(nodeVisitor(node.elementType, visitor, isTypeNode))
           );
         },
-        [188 /* TupleType */]: function visitEachChildOfTupleTypeNode(node, visitor, context, nodesVisitor, _nodeVisitor, _tokenVisitor) {
+        [189 /* TupleType */]: function visitEachChildOfTupleTypeNode(node, visitor, context, nodesVisitor, _nodeVisitor, _tokenVisitor) {
           return context.factory.updateTupleTypeNode(
             node,
             nodesVisitor(node.elements, visitor, isTypeNode)
           );
         },
-        [189 /* OptionalType */]: function visitEachChildOfOptionalTypeNode(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
+        [190 /* OptionalType */]: function visitEachChildOfOptionalTypeNode(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
           return context.factory.updateOptionalTypeNode(
             node,
             Debug.checkDefined(nodeVisitor(node.type, visitor, isTypeNode))
           );
         },
-        [190 /* RestType */]: function visitEachChildOfRestTypeNode(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
+        [191 /* RestType */]: function visitEachChildOfRestTypeNode(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
           return context.factory.updateRestTypeNode(
             node,
             Debug.checkDefined(nodeVisitor(node.type, visitor, isTypeNode))
           );
         },
-        [191 /* UnionType */]: function visitEachChildOfUnionTypeNode(node, visitor, context, nodesVisitor, _nodeVisitor, _tokenVisitor) {
+        [192 /* UnionType */]: function visitEachChildOfUnionTypeNode(node, visitor, context, nodesVisitor, _nodeVisitor, _tokenVisitor) {
           return context.factory.updateUnionTypeNode(
             node,
             nodesVisitor(node.types, visitor, isTypeNode)
           );
         },
-        [192 /* IntersectionType */]: function visitEachChildOfIntersectionTypeNode(node, visitor, context, nodesVisitor, _nodeVisitor, _tokenVisitor) {
+        [193 /* IntersectionType */]: function visitEachChildOfIntersectionTypeNode(node, visitor, context, nodesVisitor, _nodeVisitor, _tokenVisitor) {
           return context.factory.updateIntersectionTypeNode(
             node,
             nodesVisitor(node.types, visitor, isTypeNode)
           );
         },
-        [193 /* ConditionalType */]: function visitEachChildOfConditionalTypeNode(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
+        [194 /* ConditionalType */]: function visitEachChildOfConditionalTypeNode(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
           return context.factory.updateConditionalTypeNode(
             node,
             Debug.checkDefined(nodeVisitor(node.checkType, visitor, isTypeNode)),
@@ -185776,30 +169829,30 @@ ${lanes.join("\n")}
             Debug.checkDefined(nodeVisitor(node.falseType, visitor, isTypeNode))
           );
         },
-        [194 /* InferType */]: function visitEachChildOfInferTypeNode(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
+        [195 /* InferType */]: function visitEachChildOfInferTypeNode(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
           return context.factory.updateInferTypeNode(
             node,
             Debug.checkDefined(nodeVisitor(node.typeParameter, visitor, isTypeParameterDeclaration))
           );
         },
-        [204 /* ImportType */]: function visitEachChildOfImportTypeNode(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) {
+        [205 /* ImportType */]: function visitEachChildOfImportTypeNode(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) {
           return context.factory.updateImportTypeNode(
             node,
             Debug.checkDefined(nodeVisitor(node.argument, visitor, isTypeNode)),
-            nodeVisitor(node.assertions, visitor, isImportTypeAssertionContainer),
+            nodeVisitor(node.attributes, visitor, isImportAttributes),
             nodeVisitor(node.qualifier, visitor, isEntityName),
             nodesVisitor(node.typeArguments, visitor, isTypeNode),
             node.isTypeOf
           );
         },
-        [301 /* ImportTypeAssertionContainer */]: function visitEachChildOfImportTypeAssertionContainer(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
+        [302 /* ImportTypeAssertionContainer */]: function visitEachChildOfImportTypeAssertionContainer(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
           return context.factory.updateImportTypeAssertionContainer(
             node,
             Debug.checkDefined(nodeVisitor(node.assertClause, visitor, isAssertClause)),
             node.multiLine
           );
         },
-        [201 /* NamedTupleMember */]: function visitEachChildOfNamedTupleMember(node, visitor, context, _nodesVisitor, nodeVisitor, tokenVisitor) {
+        [202 /* NamedTupleMember */]: function visitEachChildOfNamedTupleMember(node, visitor, context, _nodesVisitor, nodeVisitor, tokenVisitor) {
           return context.factory.updateNamedTupleMember(
             node,
             tokenVisitor ? nodeVisitor(node.dotDotDotToken, tokenVisitor, isDotDotDotToken) : node.dotDotDotToken,
@@ -185808,26 +169861,26 @@ ${lanes.join("\n")}
             Debug.checkDefined(nodeVisitor(node.type, visitor, isTypeNode))
           );
         },
-        [195 /* ParenthesizedType */]: function visitEachChildOfParenthesizedType(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
+        [196 /* ParenthesizedType */]: function visitEachChildOfParenthesizedType(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
           return context.factory.updateParenthesizedType(
             node,
             Debug.checkDefined(nodeVisitor(node.type, visitor, isTypeNode))
           );
         },
-        [197 /* TypeOperator */]: function visitEachChildOfTypeOperatorNode(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
+        [198 /* TypeOperator */]: function visitEachChildOfTypeOperatorNode(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
           return context.factory.updateTypeOperatorNode(
             node,
             Debug.checkDefined(nodeVisitor(node.type, visitor, isTypeNode))
           );
         },
-        [198 /* IndexedAccessType */]: function visitEachChildOfIndexedAccessType(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
+        [199 /* IndexedAccessType */]: function visitEachChildOfIndexedAccessType(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
           return context.factory.updateIndexedAccessTypeNode(
             node,
             Debug.checkDefined(nodeVisitor(node.objectType, visitor, isTypeNode)),
             Debug.checkDefined(nodeVisitor(node.indexType, visitor, isTypeNode))
           );
         },
-        [199 /* MappedType */]: function visitEachChildOfMappedType(node, visitor, context, nodesVisitor, nodeVisitor, tokenVisitor) {
+        [200 /* MappedType */]: function visitEachChildOfMappedType(node, visitor, context, nodesVisitor, nodeVisitor, tokenVisitor) {
           return context.factory.updateMappedTypeNode(
             node,
             tokenVisitor ? nodeVisitor(node.readonlyToken, tokenVisitor, isReadonlyKeywordOrPlusOrMinusToken) : node.readonlyToken,
@@ -185838,20 +169891,20 @@ ${lanes.join("\n")}
             nodesVisitor(node.members, visitor, isTypeElement)
           );
         },
-        [200 /* LiteralType */]: function visitEachChildOfLiteralTypeNode(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
+        [201 /* LiteralType */]: function visitEachChildOfLiteralTypeNode(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
           return context.factory.updateLiteralTypeNode(
             node,
             Debug.checkDefined(nodeVisitor(node.literal, visitor, isLiteralTypeLiteral))
           );
         },
-        [202 /* TemplateLiteralType */]: function visitEachChildOfTemplateLiteralType(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) {
+        [203 /* TemplateLiteralType */]: function visitEachChildOfTemplateLiteralType(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) {
           return context.factory.updateTemplateLiteralType(
             node,
             Debug.checkDefined(nodeVisitor(node.head, visitor, isTemplateHead)),
             nodesVisitor(node.templateSpans, visitor, isTemplateLiteralTypeSpan)
           );
         },
-        [203 /* TemplateLiteralTypeSpan */]: function visitEachChildOfTemplateLiteralTypeSpan(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
+        [204 /* TemplateLiteralTypeSpan */]: function visitEachChildOfTemplateLiteralTypeSpan(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
           return context.factory.updateTemplateLiteralTypeSpan(
             node,
             Debug.checkDefined(nodeVisitor(node.type, visitor, isTypeNode)),
@@ -185859,19 +169912,19 @@ ${lanes.join("\n")}
           );
         },
         // Binding patterns
-        [205 /* ObjectBindingPattern */]: function visitEachChildOfObjectBindingPattern(node, visitor, context, nodesVisitor, _nodeVisitor, _tokenVisitor) {
+        [206 /* ObjectBindingPattern */]: function visitEachChildOfObjectBindingPattern(node, visitor, context, nodesVisitor, _nodeVisitor, _tokenVisitor) {
           return context.factory.updateObjectBindingPattern(
             node,
             nodesVisitor(node.elements, visitor, isBindingElement)
           );
         },
-        [206 /* ArrayBindingPattern */]: function visitEachChildOfArrayBindingPattern(node, visitor, context, nodesVisitor, _nodeVisitor, _tokenVisitor) {
+        [207 /* ArrayBindingPattern */]: function visitEachChildOfArrayBindingPattern(node, visitor, context, nodesVisitor, _nodeVisitor, _tokenVisitor) {
           return context.factory.updateArrayBindingPattern(
             node,
             nodesVisitor(node.elements, visitor, isArrayBindingElement)
           );
         },
-        [207 /* BindingElement */]: function visitEachChildOfBindingElement(node, visitor, context, _nodesVisitor, nodeVisitor, tokenVisitor) {
+        [208 /* BindingElement */]: function visitEachChildOfBindingElement(node, visitor, context, _nodesVisitor, nodeVisitor, tokenVisitor) {
           return context.factory.updateBindingElement(
             node,
             tokenVisitor ? nodeVisitor(node.dotDotDotToken, tokenVisitor, isDotDotDotToken) : node.dotDotDotToken,
@@ -185881,19 +169934,19 @@ ${lanes.join("\n")}
           );
         },
         // Expression
-        [208 /* ArrayLiteralExpression */]: function visitEachChildOfArrayLiteralExpression(node, visitor, context, nodesVisitor, _nodeVisitor, _tokenVisitor) {
+        [209 /* ArrayLiteralExpression */]: function visitEachChildOfArrayLiteralExpression(node, visitor, context, nodesVisitor, _nodeVisitor, _tokenVisitor) {
           return context.factory.updateArrayLiteralExpression(
             node,
             nodesVisitor(node.elements, visitor, isExpression)
           );
         },
-        [209 /* ObjectLiteralExpression */]: function visitEachChildOfObjectLiteralExpression(node, visitor, context, nodesVisitor, _nodeVisitor, _tokenVisitor) {
+        [210 /* ObjectLiteralExpression */]: function visitEachChildOfObjectLiteralExpression(node, visitor, context, nodesVisitor, _nodeVisitor, _tokenVisitor) {
           return context.factory.updateObjectLiteralExpression(
             node,
             nodesVisitor(node.properties, visitor, isObjectLiteralElementLike)
           );
         },
-        [210 /* PropertyAccessExpression */]: function visitEachChildOfPropertyAccessExpression(node, visitor, context, _nodesVisitor, nodeVisitor, tokenVisitor) {
+        [211 /* PropertyAccessExpression */]: function visitEachChildOfPropertyAccessExpression(node, visitor, context, _nodesVisitor, nodeVisitor, tokenVisitor) {
           return isPropertyAccessChain(node) ? context.factory.updatePropertyAccessChain(
             node,
             Debug.checkDefined(nodeVisitor(node.expression, visitor, isExpression)),
@@ -185905,7 +169958,7 @@ ${lanes.join("\n")}
             Debug.checkDefined(nodeVisitor(node.name, visitor, isMemberName))
           );
         },
-        [211 /* ElementAccessExpression */]: function visitEachChildOfElementAccessExpression(node, visitor, context, _nodesVisitor, nodeVisitor, tokenVisitor) {
+        [212 /* ElementAccessExpression */]: function visitEachChildOfElementAccessExpression(node, visitor, context, _nodesVisitor, nodeVisitor, tokenVisitor) {
           return isElementAccessChain(node) ? context.factory.updateElementAccessChain(
             node,
             Debug.checkDefined(nodeVisitor(node.expression, visitor, isExpression)),
@@ -185917,7 +169970,7 @@ ${lanes.join("\n")}
             Debug.checkDefined(nodeVisitor(node.argumentExpression, visitor, isExpression))
           );
         },
-        [212 /* CallExpression */]: function visitEachChildOfCallExpression(node, visitor, context, nodesVisitor, nodeVisitor, tokenVisitor) {
+        [213 /* CallExpression */]: function visitEachChildOfCallExpression(node, visitor, context, nodesVisitor, nodeVisitor, tokenVisitor) {
           return isCallChain(node) ? context.factory.updateCallChain(
             node,
             Debug.checkDefined(nodeVisitor(node.expression, visitor, isExpression)),
@@ -185931,7 +169984,7 @@ ${lanes.join("\n")}
             nodesVisitor(node.arguments, visitor, isExpression)
           );
         },
-        [213 /* NewExpression */]: function visitEachChildOfNewExpression(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) {
+        [214 /* NewExpression */]: function visitEachChildOfNewExpression(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) {
           return context.factory.updateNewExpression(
             node,
             Debug.checkDefined(nodeVisitor(node.expression, visitor, isExpression)),
@@ -185939,7 +169992,7 @@ ${lanes.join("\n")}
             nodesVisitor(node.arguments, visitor, isExpression)
           );
         },
-        [214 /* TaggedTemplateExpression */]: function visitEachChildOfTaggedTemplateExpression(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) {
+        [215 /* TaggedTemplateExpression */]: function visitEachChildOfTaggedTemplateExpression(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) {
           return context.factory.updateTaggedTemplateExpression(
             node,
             Debug.checkDefined(nodeVisitor(node.tag, visitor, isExpression)),
@@ -185947,20 +170000,20 @@ ${lanes.join("\n")}
             Debug.checkDefined(nodeVisitor(node.template, visitor, isTemplateLiteral))
           );
         },
-        [215 /* TypeAssertionExpression */]: function visitEachChildOfTypeAssertionExpression(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
+        [216 /* TypeAssertionExpression */]: function visitEachChildOfTypeAssertionExpression(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
           return context.factory.updateTypeAssertion(
             node,
             Debug.checkDefined(nodeVisitor(node.type, visitor, isTypeNode)),
             Debug.checkDefined(nodeVisitor(node.expression, visitor, isExpression))
           );
         },
-        [216 /* ParenthesizedExpression */]: function visitEachChildOfParenthesizedExpression(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
+        [217 /* ParenthesizedExpression */]: function visitEachChildOfParenthesizedExpression(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
           return context.factory.updateParenthesizedExpression(
             node,
             Debug.checkDefined(nodeVisitor(node.expression, visitor, isExpression))
           );
         },
-        [217 /* FunctionExpression */]: function visitEachChildOfFunctionExpression(node, visitor, context, nodesVisitor, nodeVisitor, tokenVisitor) {
+        [218 /* FunctionExpression */]: function visitEachChildOfFunctionExpression(node, visitor, context, nodesVisitor, nodeVisitor, tokenVisitor) {
           return context.factory.updateFunctionExpression(
             node,
             nodesVisitor(node.modifiers, visitor, isModifier),
@@ -185972,7 +170025,7 @@ ${lanes.join("\n")}
             visitFunctionBody(node.body, visitor, context, nodeVisitor)
           );
         },
-        [218 /* ArrowFunction */]: function visitEachChildOfArrowFunction(node, visitor, context, nodesVisitor, nodeVisitor, tokenVisitor) {
+        [219 /* ArrowFunction */]: function visitEachChildOfArrowFunction(node, visitor, context, nodesVisitor, nodeVisitor, tokenVisitor) {
           return context.factory.updateArrowFunction(
             node,
             nodesVisitor(node.modifiers, visitor, isModifier),
@@ -185983,43 +170036,43 @@ ${lanes.join("\n")}
             visitFunctionBody(node.body, visitor, context, nodeVisitor)
           );
         },
-        [219 /* DeleteExpression */]: function visitEachChildOfDeleteExpression(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
+        [220 /* DeleteExpression */]: function visitEachChildOfDeleteExpression(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
           return context.factory.updateDeleteExpression(
             node,
             Debug.checkDefined(nodeVisitor(node.expression, visitor, isExpression))
           );
         },
-        [220 /* TypeOfExpression */]: function visitEachChildOfTypeOfExpression(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
+        [221 /* TypeOfExpression */]: function visitEachChildOfTypeOfExpression(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
           return context.factory.updateTypeOfExpression(
             node,
             Debug.checkDefined(nodeVisitor(node.expression, visitor, isExpression))
           );
         },
-        [221 /* VoidExpression */]: function visitEachChildOfVoidExpression(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
+        [222 /* VoidExpression */]: function visitEachChildOfVoidExpression(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
           return context.factory.updateVoidExpression(
             node,
             Debug.checkDefined(nodeVisitor(node.expression, visitor, isExpression))
           );
         },
-        [222 /* AwaitExpression */]: function visitEachChildOfAwaitExpression(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
+        [223 /* AwaitExpression */]: function visitEachChildOfAwaitExpression(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
           return context.factory.updateAwaitExpression(
             node,
             Debug.checkDefined(nodeVisitor(node.expression, visitor, isExpression))
           );
         },
-        [223 /* PrefixUnaryExpression */]: function visitEachChildOfPrefixUnaryExpression(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
+        [224 /* PrefixUnaryExpression */]: function visitEachChildOfPrefixUnaryExpression(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
           return context.factory.updatePrefixUnaryExpression(
             node,
             Debug.checkDefined(nodeVisitor(node.operand, visitor, isExpression))
           );
         },
-        [224 /* PostfixUnaryExpression */]: function visitEachChildOfPostfixUnaryExpression(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
+        [225 /* PostfixUnaryExpression */]: function visitEachChildOfPostfixUnaryExpression(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
           return context.factory.updatePostfixUnaryExpression(
             node,
             Debug.checkDefined(nodeVisitor(node.operand, visitor, isExpression))
           );
         },
-        [225 /* BinaryExpression */]: function visitEachChildOfBinaryExpression(node, visitor, context, _nodesVisitor, nodeVisitor, tokenVisitor) {
+        [226 /* BinaryExpression */]: function visitEachChildOfBinaryExpression(node, visitor, context, _nodesVisitor, nodeVisitor, tokenVisitor) {
           return context.factory.updateBinaryExpression(
             node,
             Debug.checkDefined(nodeVisitor(node.left, visitor, isExpression)),
@@ -186027,7 +170080,7 @@ ${lanes.join("\n")}
             Debug.checkDefined(nodeVisitor(node.right, visitor, isExpression))
           );
         },
-        [226 /* ConditionalExpression */]: function visitEachChildOfConditionalExpression(node, visitor, context, _nodesVisitor, nodeVisitor, tokenVisitor) {
+        [227 /* ConditionalExpression */]: function visitEachChildOfConditionalExpression(node, visitor, context, _nodesVisitor, nodeVisitor, tokenVisitor) {
           return context.factory.updateConditionalExpression(
             node,
             Debug.checkDefined(nodeVisitor(node.condition, visitor, isExpression)),
@@ -186037,27 +170090,27 @@ ${lanes.join("\n")}
             Debug.checkDefined(nodeVisitor(node.whenFalse, visitor, isExpression))
           );
         },
-        [227 /* TemplateExpression */]: function visitEachChildOfTemplateExpression(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) {
+        [228 /* TemplateExpression */]: function visitEachChildOfTemplateExpression(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) {
           return context.factory.updateTemplateExpression(
             node,
             Debug.checkDefined(nodeVisitor(node.head, visitor, isTemplateHead)),
             nodesVisitor(node.templateSpans, visitor, isTemplateSpan)
           );
         },
-        [228 /* YieldExpression */]: function visitEachChildOfYieldExpression(node, visitor, context, _nodesVisitor, nodeVisitor, tokenVisitor) {
+        [229 /* YieldExpression */]: function visitEachChildOfYieldExpression(node, visitor, context, _nodesVisitor, nodeVisitor, tokenVisitor) {
           return context.factory.updateYieldExpression(
             node,
             tokenVisitor ? nodeVisitor(node.asteriskToken, tokenVisitor, isAsteriskToken) : node.asteriskToken,
             nodeVisitor(node.expression, visitor, isExpression)
           );
         },
-        [229 /* SpreadElement */]: function visitEachChildOfSpreadElement(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
+        [230 /* SpreadElement */]: function visitEachChildOfSpreadElement(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
           return context.factory.updateSpreadElement(
             node,
             Debug.checkDefined(nodeVisitor(node.expression, visitor, isExpression))
           );
         },
-        [230 /* ClassExpression */]: function visitEachChildOfClassExpression(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) {
+        [231 /* ClassExpression */]: function visitEachChildOfClassExpression(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) {
           return context.factory.updateClassExpression(
             node,
             nodesVisitor(node.modifiers, visitor, isModifierLike),
@@ -186067,28 +170120,28 @@ ${lanes.join("\n")}
             nodesVisitor(node.members, visitor, isClassElement)
           );
         },
-        [232 /* ExpressionWithTypeArguments */]: function visitEachChildOfExpressionWithTypeArguments(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) {
+        [233 /* ExpressionWithTypeArguments */]: function visitEachChildOfExpressionWithTypeArguments(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) {
           return context.factory.updateExpressionWithTypeArguments(
             node,
             Debug.checkDefined(nodeVisitor(node.expression, visitor, isExpression)),
             nodesVisitor(node.typeArguments, visitor, isTypeNode)
           );
         },
-        [233 /* AsExpression */]: function visitEachChildOfAsExpression(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
+        [234 /* AsExpression */]: function visitEachChildOfAsExpression(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
           return context.factory.updateAsExpression(
             node,
             Debug.checkDefined(nodeVisitor(node.expression, visitor, isExpression)),
             Debug.checkDefined(nodeVisitor(node.type, visitor, isTypeNode))
           );
         },
-        [237 /* SatisfiesExpression */]: function visitEachChildOfSatisfiesExpression(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
+        [238 /* SatisfiesExpression */]: function visitEachChildOfSatisfiesExpression(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
           return context.factory.updateSatisfiesExpression(
             node,
             Debug.checkDefined(nodeVisitor(node.expression, visitor, isExpression)),
             Debug.checkDefined(nodeVisitor(node.type, visitor, isTypeNode))
           );
         },
-        [234 /* NonNullExpression */]: function visitEachChildOfNonNullExpression(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
+        [235 /* NonNullExpression */]: function visitEachChildOfNonNullExpression(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
           return isOptionalChain(node) ? context.factory.updateNonNullChain(
             node,
             Debug.checkDefined(nodeVisitor(node.expression, visitor, isExpression))
@@ -186097,14 +170150,14 @@ ${lanes.join("\n")}
             Debug.checkDefined(nodeVisitor(node.expression, visitor, isExpression))
           );
         },
-        [235 /* MetaProperty */]: function visitEachChildOfMetaProperty(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
+        [236 /* MetaProperty */]: function visitEachChildOfMetaProperty(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
           return context.factory.updateMetaProperty(
             node,
             Debug.checkDefined(nodeVisitor(node.name, visitor, isIdentifier))
           );
         },
         // Misc
-        [238 /* TemplateSpan */]: function visitEachChildOfTemplateSpan(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
+        [239 /* TemplateSpan */]: function visitEachChildOfTemplateSpan(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
           return context.factory.updateTemplateSpan(
             node,
             Debug.checkDefined(nodeVisitor(node.expression, visitor, isExpression)),
@@ -186112,26 +170165,26 @@ ${lanes.join("\n")}
           );
         },
         // Element
-        [240 /* Block */]: function visitEachChildOfBlock(node, visitor, context, nodesVisitor, _nodeVisitor, _tokenVisitor) {
+        [241 /* Block */]: function visitEachChildOfBlock(node, visitor, context, nodesVisitor, _nodeVisitor, _tokenVisitor) {
           return context.factory.updateBlock(
             node,
             nodesVisitor(node.statements, visitor, isStatement)
           );
         },
-        [242 /* VariableStatement */]: function visitEachChildOfVariableStatement(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) {
+        [243 /* VariableStatement */]: function visitEachChildOfVariableStatement(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) {
           return context.factory.updateVariableStatement(
             node,
             nodesVisitor(node.modifiers, visitor, isModifierLike),
             Debug.checkDefined(nodeVisitor(node.declarationList, visitor, isVariableDeclarationList))
           );
         },
-        [243 /* ExpressionStatement */]: function visitEachChildOfExpressionStatement(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
+        [244 /* ExpressionStatement */]: function visitEachChildOfExpressionStatement(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
           return context.factory.updateExpressionStatement(
             node,
             Debug.checkDefined(nodeVisitor(node.expression, visitor, isExpression))
           );
         },
-        [244 /* IfStatement */]: function visitEachChildOfIfStatement(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
+        [245 /* IfStatement */]: function visitEachChildOfIfStatement(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
           return context.factory.updateIfStatement(
             node,
             Debug.checkDefined(nodeVisitor(node.expression, visitor, isExpression)),
@@ -186139,21 +170192,21 @@ ${lanes.join("\n")}
             nodeVisitor(node.elseStatement, visitor, isStatement, context.factory.liftToBlock)
           );
         },
-        [245 /* DoStatement */]: function visitEachChildOfDoStatement(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
+        [246 /* DoStatement */]: function visitEachChildOfDoStatement(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
           return context.factory.updateDoStatement(
             node,
             visitIterationBody(node.statement, visitor, context, nodeVisitor),
             Debug.checkDefined(nodeVisitor(node.expression, visitor, isExpression))
           );
         },
-        [246 /* WhileStatement */]: function visitEachChildOfWhileStatement(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
+        [247 /* WhileStatement */]: function visitEachChildOfWhileStatement(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
           return context.factory.updateWhileStatement(
             node,
             Debug.checkDefined(nodeVisitor(node.expression, visitor, isExpression)),
             visitIterationBody(node.statement, visitor, context, nodeVisitor)
           );
         },
-        [247 /* ForStatement */]: function visitEachChildOfForStatement(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
+        [248 /* ForStatement */]: function visitEachChildOfForStatement(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
           return context.factory.updateForStatement(
             node,
             nodeVisitor(node.initializer, visitor, isForInitializer),
@@ -186162,7 +170215,7 @@ ${lanes.join("\n")}
             visitIterationBody(node.statement, visitor, context, nodeVisitor)
           );
         },
-        [248 /* ForInStatement */]: function visitEachChildOfForInStatement(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
+        [249 /* ForInStatement */]: function visitEachChildOfForInStatement(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
           return context.factory.updateForInStatement(
             node,
             Debug.checkDefined(nodeVisitor(node.initializer, visitor, isForInitializer)),
@@ -186170,7 +170223,7 @@ ${lanes.join("\n")}
             visitIterationBody(node.statement, visitor, context, nodeVisitor)
           );
         },
-        [249 /* ForOfStatement */]: function visitEachChildOfForOfStatement(node, visitor, context, _nodesVisitor, nodeVisitor, tokenVisitor) {
+        [250 /* ForOfStatement */]: function visitEachChildOfForOfStatement(node, visitor, context, _nodesVisitor, nodeVisitor, tokenVisitor) {
           return context.factory.updateForOfStatement(
             node,
             tokenVisitor ? nodeVisitor(node.awaitModifier, tokenVisitor, isAwaitKeyword) : node.awaitModifier,
@@ -186179,52 +170232,52 @@ ${lanes.join("\n")}
             visitIterationBody(node.statement, visitor, context, nodeVisitor)
           );
         },
-        [250 /* ContinueStatement */]: function visitEachChildOfContinueStatement(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
+        [251 /* ContinueStatement */]: function visitEachChildOfContinueStatement(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
           return context.factory.updateContinueStatement(
             node,
             nodeVisitor(node.label, visitor, isIdentifier)
           );
         },
-        [251 /* BreakStatement */]: function visitEachChildOfBreakStatement(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
+        [252 /* BreakStatement */]: function visitEachChildOfBreakStatement(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
           return context.factory.updateBreakStatement(
             node,
             nodeVisitor(node.label, visitor, isIdentifier)
           );
         },
-        [252 /* ReturnStatement */]: function visitEachChildOfReturnStatement(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
+        [253 /* ReturnStatement */]: function visitEachChildOfReturnStatement(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
           return context.factory.updateReturnStatement(
             node,
             nodeVisitor(node.expression, visitor, isExpression)
           );
         },
-        [253 /* WithStatement */]: function visitEachChildOfWithStatement(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
+        [254 /* WithStatement */]: function visitEachChildOfWithStatement(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
           return context.factory.updateWithStatement(
             node,
             Debug.checkDefined(nodeVisitor(node.expression, visitor, isExpression)),
             Debug.checkDefined(nodeVisitor(node.statement, visitor, isStatement, context.factory.liftToBlock))
           );
         },
-        [254 /* SwitchStatement */]: function visitEachChildOfSwitchStatement(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
+        [255 /* SwitchStatement */]: function visitEachChildOfSwitchStatement(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
           return context.factory.updateSwitchStatement(
             node,
             Debug.checkDefined(nodeVisitor(node.expression, visitor, isExpression)),
             Debug.checkDefined(nodeVisitor(node.caseBlock, visitor, isCaseBlock))
           );
         },
-        [255 /* LabeledStatement */]: function visitEachChildOfLabeledStatement(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
+        [256 /* LabeledStatement */]: function visitEachChildOfLabeledStatement(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
           return context.factory.updateLabeledStatement(
             node,
             Debug.checkDefined(nodeVisitor(node.label, visitor, isIdentifier)),
             Debug.checkDefined(nodeVisitor(node.statement, visitor, isStatement, context.factory.liftToBlock))
           );
         },
-        [256 /* ThrowStatement */]: function visitEachChildOfThrowStatement(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
+        [257 /* ThrowStatement */]: function visitEachChildOfThrowStatement(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
           return context.factory.updateThrowStatement(
             node,
             Debug.checkDefined(nodeVisitor(node.expression, visitor, isExpression))
           );
         },
-        [257 /* TryStatement */]: function visitEachChildOfTryStatement(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
+        [258 /* TryStatement */]: function visitEachChildOfTryStatement(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
           return context.factory.updateTryStatement(
             node,
             Debug.checkDefined(nodeVisitor(node.tryBlock, visitor, isBlock)),
@@ -186232,7 +170285,7 @@ ${lanes.join("\n")}
             nodeVisitor(node.finallyBlock, visitor, isBlock)
           );
         },
-        [259 /* VariableDeclaration */]: function visitEachChildOfVariableDeclaration(node, visitor, context, _nodesVisitor, nodeVisitor, tokenVisitor) {
+        [260 /* VariableDeclaration */]: function visitEachChildOfVariableDeclaration(node, visitor, context, _nodesVisitor, nodeVisitor, tokenVisitor) {
           return context.factory.updateVariableDeclaration(
             node,
             Debug.checkDefined(nodeVisitor(node.name, visitor, isBindingName)),
@@ -186241,13 +170294,13 @@ ${lanes.join("\n")}
             nodeVisitor(node.initializer, visitor, isExpression)
           );
         },
-        [260 /* VariableDeclarationList */]: function visitEachChildOfVariableDeclarationList(node, visitor, context, nodesVisitor, _nodeVisitor, _tokenVisitor) {
+        [261 /* VariableDeclarationList */]: function visitEachChildOfVariableDeclarationList(node, visitor, context, nodesVisitor, _nodeVisitor, _tokenVisitor) {
           return context.factory.updateVariableDeclarationList(
             node,
             nodesVisitor(node.declarations, visitor, isVariableDeclaration)
           );
         },
-        [261 /* FunctionDeclaration */]: function visitEachChildOfFunctionDeclaration(node, visitor, context, nodesVisitor, nodeVisitor, tokenVisitor) {
+        [262 /* FunctionDeclaration */]: function visitEachChildOfFunctionDeclaration(node, visitor, context, nodesVisitor, nodeVisitor, tokenVisitor) {
           return context.factory.updateFunctionDeclaration(
             node,
             nodesVisitor(node.modifiers, visitor, isModifier),
@@ -186259,7 +170312,7 @@ ${lanes.join("\n")}
             visitFunctionBody(node.body, visitor, context, nodeVisitor)
           );
         },
-        [262 /* ClassDeclaration */]: function visitEachChildOfClassDeclaration(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) {
+        [263 /* ClassDeclaration */]: function visitEachChildOfClassDeclaration(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) {
           return context.factory.updateClassDeclaration(
             node,
             nodesVisitor(node.modifiers, visitor, isModifierLike),
@@ -186269,7 +170322,7 @@ ${lanes.join("\n")}
             nodesVisitor(node.members, visitor, isClassElement)
           );
         },
-        [263 /* InterfaceDeclaration */]: function visitEachChildOfInterfaceDeclaration(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) {
+        [264 /* InterfaceDeclaration */]: function visitEachChildOfInterfaceDeclaration(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) {
           return context.factory.updateInterfaceDeclaration(
             node,
             nodesVisitor(node.modifiers, visitor, isModifierLike),
@@ -186279,7 +170332,7 @@ ${lanes.join("\n")}
             nodesVisitor(node.members, visitor, isTypeElement)
           );
         },
-        [264 /* TypeAliasDeclaration */]: function visitEachChildOfTypeAliasDeclaration(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) {
+        [265 /* TypeAliasDeclaration */]: function visitEachChildOfTypeAliasDeclaration(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) {
           return context.factory.updateTypeAliasDeclaration(
             node,
             nodesVisitor(node.modifiers, visitor, isModifierLike),
@@ -186288,7 +170341,7 @@ ${lanes.join("\n")}
             Debug.checkDefined(nodeVisitor(node.type, visitor, isTypeNode))
           );
         },
-        [265 /* EnumDeclaration */]: function visitEachChildOfEnumDeclaration(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) {
+        [266 /* EnumDeclaration */]: function visitEachChildOfEnumDeclaration(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) {
           return context.factory.updateEnumDeclaration(
             node,
             nodesVisitor(node.modifiers, visitor, isModifierLike),
@@ -186296,7 +170349,7 @@ ${lanes.join("\n")}
             nodesVisitor(node.members, visitor, isEnumMember)
           );
         },
-        [266 /* ModuleDeclaration */]: function visitEachChildOfModuleDeclaration(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) {
+        [267 /* ModuleDeclaration */]: function visitEachChildOfModuleDeclaration(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) {
           return context.factory.updateModuleDeclaration(
             node,
             nodesVisitor(node.modifiers, visitor, isModifierLike),
@@ -186304,25 +170357,25 @@ ${lanes.join("\n")}
             nodeVisitor(node.body, visitor, isModuleBody)
           );
         },
-        [267 /* ModuleBlock */]: function visitEachChildOfModuleBlock(node, visitor, context, nodesVisitor, _nodeVisitor, _tokenVisitor) {
+        [268 /* ModuleBlock */]: function visitEachChildOfModuleBlock(node, visitor, context, nodesVisitor, _nodeVisitor, _tokenVisitor) {
           return context.factory.updateModuleBlock(
             node,
             nodesVisitor(node.statements, visitor, isStatement)
           );
         },
-        [268 /* CaseBlock */]: function visitEachChildOfCaseBlock(node, visitor, context, nodesVisitor, _nodeVisitor, _tokenVisitor) {
+        [269 /* CaseBlock */]: function visitEachChildOfCaseBlock(node, visitor, context, nodesVisitor, _nodeVisitor, _tokenVisitor) {
           return context.factory.updateCaseBlock(
             node,
             nodesVisitor(node.clauses, visitor, isCaseOrDefaultClause)
           );
         },
-        [269 /* NamespaceExportDeclaration */]: function visitEachChildOfNamespaceExportDeclaration(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
+        [270 /* NamespaceExportDeclaration */]: function visitEachChildOfNamespaceExportDeclaration(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
           return context.factory.updateNamespaceExportDeclaration(
             node,
             Debug.checkDefined(nodeVisitor(node.name, visitor, isIdentifier))
           );
         },
-        [270 /* ImportEqualsDeclaration */]: function visitEachChildOfImportEqualsDeclaration(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) {
+        [271 /* ImportEqualsDeclaration */]: function visitEachChildOfImportEqualsDeclaration(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) {
           return context.factory.updateImportEqualsDeclaration(
             node,
             nodesVisitor(node.modifiers, visitor, isModifierLike),
@@ -186331,30 +170384,30 @@ ${lanes.join("\n")}
             Debug.checkDefined(nodeVisitor(node.moduleReference, visitor, isModuleReference))
           );
         },
-        [271 /* ImportDeclaration */]: function visitEachChildOfImportDeclaration(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) {
+        [272 /* ImportDeclaration */]: function visitEachChildOfImportDeclaration(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) {
           return context.factory.updateImportDeclaration(
             node,
             nodesVisitor(node.modifiers, visitor, isModifierLike),
             nodeVisitor(node.importClause, visitor, isImportClause),
             Debug.checkDefined(nodeVisitor(node.moduleSpecifier, visitor, isExpression)),
-            nodeVisitor(node.assertClause, visitor, isAssertClause)
+            nodeVisitor(node.attributes, visitor, isImportAttributes)
           );
         },
-        [299 /* AssertClause */]: function visitEachChildOfAssertClause(node, visitor, context, nodesVisitor, _nodeVisitor, _tokenVisitor) {
-          return context.factory.updateAssertClause(
+        [300 /* ImportAttributes */]: function visitEachChildOfImportAttributes(node, visitor, context, nodesVisitor, _nodeVisitor, _tokenVisitor) {
+          return context.factory.updateImportAttributes(
             node,
-            nodesVisitor(node.elements, visitor, isAssertEntry),
+            nodesVisitor(node.elements, visitor, isImportAttribute),
             node.multiLine
           );
         },
-        [300 /* AssertEntry */]: function visitEachChildOfAssertEntry(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
-          return context.factory.updateAssertEntry(
+        [301 /* ImportAttribute */]: function visitEachChildOfImportAttribute(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
+          return context.factory.updateImportAttribute(
             node,
-            Debug.checkDefined(nodeVisitor(node.name, visitor, isAssertionKey)),
+            Debug.checkDefined(nodeVisitor(node.name, visitor, isImportAttributeName)),
             Debug.checkDefined(nodeVisitor(node.value, visitor, isExpression))
           );
         },
-        [272 /* ImportClause */]: function visitEachChildOfImportClause(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
+        [273 /* ImportClause */]: function visitEachChildOfImportClause(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
           return context.factory.updateImportClause(
             node,
             node.isTypeOnly,
@@ -186362,25 +170415,25 @@ ${lanes.join("\n")}
             nodeVisitor(node.namedBindings, visitor, isNamedImportBindings)
           );
         },
-        [273 /* NamespaceImport */]: function visitEachChildOfNamespaceImport(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
+        [274 /* NamespaceImport */]: function visitEachChildOfNamespaceImport(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
           return context.factory.updateNamespaceImport(
             node,
             Debug.checkDefined(nodeVisitor(node.name, visitor, isIdentifier))
           );
         },
-        [279 /* NamespaceExport */]: function visitEachChildOfNamespaceExport(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
+        [280 /* NamespaceExport */]: function visitEachChildOfNamespaceExport(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
           return context.factory.updateNamespaceExport(
             node,
             Debug.checkDefined(nodeVisitor(node.name, visitor, isIdentifier))
           );
         },
-        [274 /* NamedImports */]: function visitEachChildOfNamedImports(node, visitor, context, nodesVisitor, _nodeVisitor, _tokenVisitor) {
+        [275 /* NamedImports */]: function visitEachChildOfNamedImports(node, visitor, context, nodesVisitor, _nodeVisitor, _tokenVisitor) {
           return context.factory.updateNamedImports(
             node,
             nodesVisitor(node.elements, visitor, isImportSpecifier)
           );
         },
-        [275 /* ImportSpecifier */]: function visitEachChildOfImportSpecifier(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
+        [276 /* ImportSpecifier */]: function visitEachChildOfImportSpecifier(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
           return context.factory.updateImportSpecifier(
             node,
             node.isTypeOnly,
@@ -186388,30 +170441,30 @@ ${lanes.join("\n")}
             Debug.checkDefined(nodeVisitor(node.name, visitor, isIdentifier))
           );
         },
-        [276 /* ExportAssignment */]: function visitEachChildOfExportAssignment(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) {
+        [277 /* ExportAssignment */]: function visitEachChildOfExportAssignment(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) {
           return context.factory.updateExportAssignment(
             node,
             nodesVisitor(node.modifiers, visitor, isModifierLike),
             Debug.checkDefined(nodeVisitor(node.expression, visitor, isExpression))
           );
         },
-        [277 /* ExportDeclaration */]: function visitEachChildOfExportDeclaration(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) {
+        [278 /* ExportDeclaration */]: function visitEachChildOfExportDeclaration(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) {
           return context.factory.updateExportDeclaration(
             node,
             nodesVisitor(node.modifiers, visitor, isModifierLike),
             node.isTypeOnly,
             nodeVisitor(node.exportClause, visitor, isNamedExportBindings),
             nodeVisitor(node.moduleSpecifier, visitor, isExpression),
-            nodeVisitor(node.assertClause, visitor, isAssertClause)
+            nodeVisitor(node.attributes, visitor, isImportAttributes)
           );
         },
-        [278 /* NamedExports */]: function visitEachChildOfNamedExports(node, visitor, context, nodesVisitor, _nodeVisitor, _tokenVisitor) {
+        [279 /* NamedExports */]: function visitEachChildOfNamedExports(node, visitor, context, nodesVisitor, _nodeVisitor, _tokenVisitor) {
           return context.factory.updateNamedExports(
             node,
             nodesVisitor(node.elements, visitor, isExportSpecifier)
           );
         },
-        [280 /* ExportSpecifier */]: function visitEachChildOfExportSpecifier(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
+        [281 /* ExportSpecifier */]: function visitEachChildOfExportSpecifier(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
           return context.factory.updateExportSpecifier(
             node,
             node.isTypeOnly,
@@ -186420,14 +170473,14 @@ ${lanes.join("\n")}
           );
         },
         // Module references
-        [282 /* ExternalModuleReference */]: function visitEachChildOfExternalModuleReference(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
+        [283 /* ExternalModuleReference */]: function visitEachChildOfExternalModuleReference(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
           return context.factory.updateExternalModuleReference(
             node,
             Debug.checkDefined(nodeVisitor(node.expression, visitor, isExpression))
           );
         },
         // JSX
-        [283 /* JsxElement */]: function visitEachChildOfJsxElement(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) {
+        [284 /* JsxElement */]: function visitEachChildOfJsxElement(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) {
           return context.factory.updateJsxElement(
             node,
             Debug.checkDefined(nodeVisitor(node.openingElement, visitor, isJsxOpeningElement)),
@@ -186435,7 +170488,7 @@ ${lanes.join("\n")}
             Debug.checkDefined(nodeVisitor(node.closingElement, visitor, isJsxClosingElement))
           );
         },
-        [284 /* JsxSelfClosingElement */]: function visitEachChildOfJsxSelfClosingElement(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) {
+        [285 /* JsxSelfClosingElement */]: function visitEachChildOfJsxSelfClosingElement(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) {
           return context.factory.updateJsxSelfClosingElement(
             node,
             Debug.checkDefined(nodeVisitor(node.tagName, visitor, isJsxTagNameExpression)),
@@ -186443,7 +170496,7 @@ ${lanes.join("\n")}
             Debug.checkDefined(nodeVisitor(node.attributes, visitor, isJsxAttributes))
           );
         },
-        [285 /* JsxOpeningElement */]: function visitEachChildOfJsxOpeningElement(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) {
+        [286 /* JsxOpeningElement */]: function visitEachChildOfJsxOpeningElement(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) {
           return context.factory.updateJsxOpeningElement(
             node,
             Debug.checkDefined(nodeVisitor(node.tagName, visitor, isJsxTagNameExpression)),
@@ -186451,20 +170504,20 @@ ${lanes.join("\n")}
             Debug.checkDefined(nodeVisitor(node.attributes, visitor, isJsxAttributes))
           );
         },
-        [286 /* JsxClosingElement */]: function visitEachChildOfJsxClosingElement(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
+        [287 /* JsxClosingElement */]: function visitEachChildOfJsxClosingElement(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
           return context.factory.updateJsxClosingElement(
             node,
             Debug.checkDefined(nodeVisitor(node.tagName, visitor, isJsxTagNameExpression))
           );
         },
-        [294 /* JsxNamespacedName */]: function forEachChildInJsxNamespacedName2(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
+        [295 /* JsxNamespacedName */]: function forEachChildInJsxNamespacedName2(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
           return context.factory.updateJsxNamespacedName(
             node,
             Debug.checkDefined(nodeVisitor(node.namespace, visitor, isIdentifier)),
             Debug.checkDefined(nodeVisitor(node.name, visitor, isIdentifier))
           );
         },
-        [287 /* JsxFragment */]: function visitEachChildOfJsxFragment(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) {
+        [288 /* JsxFragment */]: function visitEachChildOfJsxFragment(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) {
           return context.factory.updateJsxFragment(
             node,
             Debug.checkDefined(nodeVisitor(node.openingFragment, visitor, isJsxOpeningFragment)),
@@ -186472,52 +170525,52 @@ ${lanes.join("\n")}
             Debug.checkDefined(nodeVisitor(node.closingFragment, visitor, isJsxClosingFragment))
           );
         },
-        [290 /* JsxAttribute */]: function visitEachChildOfJsxAttribute(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
+        [291 /* JsxAttribute */]: function visitEachChildOfJsxAttribute(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
           return context.factory.updateJsxAttribute(
             node,
             Debug.checkDefined(nodeVisitor(node.name, visitor, isJsxAttributeName)),
             nodeVisitor(node.initializer, visitor, isStringLiteralOrJsxExpression)
           );
         },
-        [291 /* JsxAttributes */]: function visitEachChildOfJsxAttributes(node, visitor, context, nodesVisitor, _nodeVisitor, _tokenVisitor) {
+        [292 /* JsxAttributes */]: function visitEachChildOfJsxAttributes(node, visitor, context, nodesVisitor, _nodeVisitor, _tokenVisitor) {
           return context.factory.updateJsxAttributes(
             node,
             nodesVisitor(node.properties, visitor, isJsxAttributeLike)
           );
         },
-        [292 /* JsxSpreadAttribute */]: function visitEachChildOfJsxSpreadAttribute(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
+        [293 /* JsxSpreadAttribute */]: function visitEachChildOfJsxSpreadAttribute(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
           return context.factory.updateJsxSpreadAttribute(
             node,
             Debug.checkDefined(nodeVisitor(node.expression, visitor, isExpression))
           );
         },
-        [293 /* JsxExpression */]: function visitEachChildOfJsxExpression(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
+        [294 /* JsxExpression */]: function visitEachChildOfJsxExpression(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
           return context.factory.updateJsxExpression(
             node,
             nodeVisitor(node.expression, visitor, isExpression)
           );
         },
         // Clauses
-        [295 /* CaseClause */]: function visitEachChildOfCaseClause(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) {
+        [296 /* CaseClause */]: function visitEachChildOfCaseClause(node, visitor, context, nodesVisitor, nodeVisitor, _tokenVisitor) {
           return context.factory.updateCaseClause(
             node,
             Debug.checkDefined(nodeVisitor(node.expression, visitor, isExpression)),
             nodesVisitor(node.statements, visitor, isStatement)
           );
         },
-        [296 /* DefaultClause */]: function visitEachChildOfDefaultClause(node, visitor, context, nodesVisitor, _nodeVisitor, _tokenVisitor) {
+        [297 /* DefaultClause */]: function visitEachChildOfDefaultClause(node, visitor, context, nodesVisitor, _nodeVisitor, _tokenVisitor) {
           return context.factory.updateDefaultClause(
             node,
             nodesVisitor(node.statements, visitor, isStatement)
           );
         },
-        [297 /* HeritageClause */]: function visitEachChildOfHeritageClause(node, visitor, context, nodesVisitor, _nodeVisitor, _tokenVisitor) {
+        [298 /* HeritageClause */]: function visitEachChildOfHeritageClause(node, visitor, context, nodesVisitor, _nodeVisitor, _tokenVisitor) {
           return context.factory.updateHeritageClause(
             node,
             nodesVisitor(node.types, visitor, isExpressionWithTypeArguments)
           );
         },
-        [298 /* CatchClause */]: function visitEachChildOfCatchClause(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
+        [299 /* CatchClause */]: function visitEachChildOfCatchClause(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
           return context.factory.updateCatchClause(
             node,
             nodeVisitor(node.variableDeclaration, visitor, isVariableDeclaration),
@@ -186525,28 +170578,28 @@ ${lanes.join("\n")}
           );
         },
         // Property assignments
-        [302 /* PropertyAssignment */]: function visitEachChildOfPropertyAssignment(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
+        [303 /* PropertyAssignment */]: function visitEachChildOfPropertyAssignment(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
           return context.factory.updatePropertyAssignment(
             node,
             Debug.checkDefined(nodeVisitor(node.name, visitor, isPropertyName)),
             Debug.checkDefined(nodeVisitor(node.initializer, visitor, isExpression))
           );
         },
-        [303 /* ShorthandPropertyAssignment */]: function visitEachChildOfShorthandPropertyAssignment(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
+        [304 /* ShorthandPropertyAssignment */]: function visitEachChildOfShorthandPropertyAssignment(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
           return context.factory.updateShorthandPropertyAssignment(
             node,
             Debug.checkDefined(nodeVisitor(node.name, visitor, isIdentifier)),
             nodeVisitor(node.objectAssignmentInitializer, visitor, isExpression)
           );
         },
-        [304 /* SpreadAssignment */]: function visitEachChildOfSpreadAssignment(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
+        [305 /* SpreadAssignment */]: function visitEachChildOfSpreadAssignment(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
           return context.factory.updateSpreadAssignment(
             node,
             Debug.checkDefined(nodeVisitor(node.expression, visitor, isExpression))
           );
         },
         // Enum
-        [305 /* EnumMember */]: function visitEachChildOfEnumMember(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
+        [306 /* EnumMember */]: function visitEachChildOfEnumMember(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
           return context.factory.updateEnumMember(
             node,
             Debug.checkDefined(nodeVisitor(node.name, visitor, isPropertyName)),
@@ -186554,20 +170607,20 @@ ${lanes.join("\n")}
           );
         },
         // Top-level nodes
-        [311 /* SourceFile */]: function visitEachChildOfSourceFile(node, visitor, context, _nodesVisitor, _nodeVisitor, _tokenVisitor) {
+        [312 /* SourceFile */]: function visitEachChildOfSourceFile(node, visitor, context, _nodesVisitor, _nodeVisitor, _tokenVisitor) {
           return context.factory.updateSourceFile(
             node,
             visitLexicalEnvironment(node.statements, visitor, context)
           );
         },
         // Transformation nodes
-        [359 /* PartiallyEmittedExpression */]: function visitEachChildOfPartiallyEmittedExpression(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
+        [360 /* PartiallyEmittedExpression */]: function visitEachChildOfPartiallyEmittedExpression(node, visitor, context, _nodesVisitor, nodeVisitor, _tokenVisitor) {
           return context.factory.updatePartiallyEmittedExpression(
             node,
             Debug.checkDefined(nodeVisitor(node.expression, visitor, isExpression))
           );
         },
-        [360 /* CommaListExpression */]: function visitEachChildOfCommaListExpression(node, visitor, context, nodesVisitor, _nodeVisitor, _tokenVisitor) {
+        [361 /* CommaListExpression */]: function visitEachChildOfCommaListExpression(node, visitor, context, nodesVisitor, _nodeVisitor, _tokenVisitor) {
           return context.factory.updateCommaListExpression(
             node,
             nodesVisitor(node.elements, visitor, isExpression)
@@ -186829,7 +170882,7 @@ ${lanes.join("\n")}
       const line = lineInfo.getLineText(index);
       const comment = sourceMapCommentRegExp.exec(line);
       if (comment) {
-        return trimStringEnd(comment[1]);
+        return comment[1].trimEnd();
       } else if (!line.match(whitespaceOrMapCommentRegExp)) {
         break;
       }
@@ -186860,13 +170913,13 @@ ${lanes.join("\n")}
     let sourceLine = 0;
     let sourceCharacter = 0;
     let nameIndex = 0;
-    let error;
+    let error2;
     return {
       get pos() {
         return pos;
       },
       get error() {
-        return error;
+        return error2;
       },
       get state() {
         return captureMapping(
@@ -186951,8 +171004,8 @@ ${lanes.join("\n")}
       return { value: void 0, done: true };
     }
     function setError(message) {
-      if (error === void 0) {
-        error = message;
+      if (error2 === void 0) {
+        error2 = message;
       }
     }
     function setErrorAndStopIterating(message) {
@@ -186960,7 +171013,7 @@ ${lanes.join("\n")}
       return stopIterating();
     }
     function hasReportedError() {
-      return error !== void 0;
+      return error2 !== void 0;
     }
     function isSourceMappingSegmentEnd() {
       return pos === mappings.length || mappings.charCodeAt(pos) === 44 /* comma */ || mappings.charCodeAt(pos) === 59 /* semicolon */;
@@ -187168,7 +171221,7 @@ ${lanes.join("\n")}
   function chainBundle(context, transformSourceFile) {
     return transformSourceFileOrBundle;
     function transformSourceFileOrBundle(node) {
-      return node.kind === 311 /* SourceFile */ ? transformSourceFile(node) : transformBundle(node);
+      return node.kind === 312 /* SourceFile */ ? transformSourceFile(node) : transformBundle(node);
     }
     function transformBundle(node) {
       return context.factory.createBundle(map(node.sourceFiles, transformSourceFile), node.prepends);
@@ -187198,9 +171251,11 @@ ${lanes.join("\n")}
   function getImportNeedsImportDefaultHelper(node) {
     return !getImportNeedsImportStarHelper(node) && (isDefaultImport(node) || !!node.importClause && isNamedImports(node.importClause.namedBindings) && containsDefaultReference(node.importClause.namedBindings));
   }
-  function collectExternalModuleInfo(context, sourceFile, resolver, compilerOptions) {
+  function collectExternalModuleInfo(context, sourceFile) {
+    const resolver = context.getEmitResolver();
+    const compilerOptions = context.getCompilerOptions();
     const externalImports = [];
-    const exportSpecifiers = createMultiMap();
+    const exportSpecifiers = new IdentifierNameMultiMap();
     const exportedBindings = [];
     const uniqueExports = /* @__PURE__ */ new Map();
     let exportedNames;
@@ -187211,7 +171266,7 @@ ${lanes.join("\n")}
     let hasImportDefault = false;
     for (const node of sourceFile.statements) {
       switch (node.kind) {
-        case 271 /* ImportDeclaration */:
+        case 272 /* ImportDeclaration */:
           externalImports.push(node);
           if (!hasImportStar && getImportNeedsImportStarHelper(node)) {
             hasImportStar = true;
@@ -187220,12 +171275,12 @@ ${lanes.join("\n")}
             hasImportDefault = true;
           }
           break;
-        case 270 /* ImportEqualsDeclaration */:
-          if (node.moduleReference.kind === 282 /* ExternalModuleReference */) {
+        case 271 /* ImportEqualsDeclaration */:
+          if (node.moduleReference.kind === 283 /* ExternalModuleReference */) {
             externalImports.push(node);
           }
           break;
-        case 277 /* ExportDeclaration */:
+        case 278 /* ExportDeclaration */:
           if (node.moduleSpecifier) {
             if (!node.exportClause) {
               externalImports.push(node);
@@ -187248,21 +171303,21 @@ ${lanes.join("\n")}
             addExportedNamesForExportDeclaration(node);
           }
           break;
-        case 276 /* ExportAssignment */:
+        case 277 /* ExportAssignment */:
           if (node.isExportEquals && !exportEquals) {
             exportEquals = node;
           }
           break;
-        case 242 /* VariableStatement */:
-          if (hasSyntacticModifier(node, 1 /* Export */)) {
+        case 243 /* VariableStatement */:
+          if (hasSyntacticModifier(node, 32 /* Export */)) {
             for (const decl of node.declarationList.declarations) {
               exportedNames = collectExportedVariableInfo(decl, uniqueExports, exportedNames, exportedBindings);
             }
           }
           break;
-        case 261 /* FunctionDeclaration */:
-          if (hasSyntacticModifier(node, 1 /* Export */)) {
-            if (hasSyntacticModifier(node, 1024 /* Default */)) {
+        case 262 /* FunctionDeclaration */:
+          if (hasSyntacticModifier(node, 32 /* Export */)) {
+            if (hasSyntacticModifier(node, 2048 /* Default */)) {
               if (!hasExportDefault) {
                 multiMapSparseArrayAdd(exportedBindings, getOriginalNodeId(node), context.factory.getDeclarationName(node));
                 hasExportDefault = true;
@@ -187277,9 +171332,9 @@ ${lanes.join("\n")}
             }
           }
           break;
-        case 262 /* ClassDeclaration */:
-          if (hasSyntacticModifier(node, 1 /* Export */)) {
-            if (hasSyntacticModifier(node, 1024 /* Default */)) {
+        case 263 /* ClassDeclaration */:
+          if (hasSyntacticModifier(node, 32 /* Export */)) {
+            if (hasSyntacticModifier(node, 2048 /* Default */)) {
               if (!hasExportDefault) {
                 multiMapSparseArrayAdd(exportedBindings, getOriginalNodeId(node), context.factory.getDeclarationName(node));
                 hasExportDefault = true;
@@ -187306,7 +171361,7 @@ ${lanes.join("\n")}
         if (!uniqueExports.get(idText(specifier.name))) {
           const name = specifier.propertyName || specifier.name;
           if (!node.moduleSpecifier) {
-            exportSpecifiers.add(idText(name), specifier);
+            exportSpecifiers.add(name, specifier);
           }
           const decl = resolver.getReferencedImportDeclaration(name) || resolver.getReferencedValueDeclaration(name);
           if (decl) {
@@ -187396,14 +171451,23 @@ ${lanes.join("\n")}
     const expression = skipParentheses(statement.expression);
     return isSuperCall(expression) ? expression : void 0;
   }
-  function findSuperStatementIndex(statements, indexAfterLastPrologueStatement) {
-    for (let i = indexAfterLastPrologueStatement; i < statements.length; i += 1) {
+  function findSuperStatementIndexPathWorker(statements, start, indices) {
+    for (let i = start; i < statements.length; i += 1) {
       const statement = statements[i];
       if (getSuperCallFromStatement(statement)) {
-        return i;
+        indices.unshift(i);
+        return true;
+      } else if (isTryStatement(statement) && findSuperStatementIndexPathWorker(statement.tryBlock.statements, 0, indices)) {
+        indices.unshift(i);
+        return true;
       }
     }
-    return -1;
+    return false;
+  }
+  function findSuperStatementIndexPath(statements, start) {
+    const indices = [];
+    findSuperStatementIndexPathWorker(statements, start, indices);
+    return indices;
   }
   function getProperties(node, requireInitializer, isStatic2) {
     return filter(node.members, (m) => isInitializedOrStaticProperty(m, requireInitializer, isStatic2));
@@ -187421,7 +171485,7 @@ ${lanes.join("\n")}
     return isPropertyDeclaration(member) && hasStaticModifier(member);
   }
   function isInitializedProperty(member) {
-    return member.kind === 171 /* PropertyDeclaration */ && member.initializer !== void 0;
+    return member.kind === 172 /* PropertyDeclaration */ && member.initializer !== void 0;
   }
   function isNonStaticMethodOrAccessorWithPrivateName(member) {
     return !isStatic(member) && (isMethodOrAccessor(member) || isAutoAccessorPropertyDeclaration(member)) && isPrivateIdentifier(member.name);
@@ -187458,15 +171522,15 @@ ${lanes.join("\n")}
   }
   function getAllDecoratorsOfClassElement(member, parent2, useLegacyDecorators) {
     switch (member.kind) {
-      case 176 /* GetAccessor */:
-      case 177 /* SetAccessor */:
+      case 177 /* GetAccessor */:
+      case 178 /* SetAccessor */:
         if (!useLegacyDecorators) {
           return getAllDecoratorsOfMethod(member);
         }
         return getAllDecoratorsOfAccessors(member, parent2);
-      case 173 /* MethodDeclaration */:
+      case 174 /* MethodDeclaration */:
         return getAllDecoratorsOfMethod(member);
-      case 171 /* PropertyDeclaration */:
+      case 172 /* PropertyDeclaration */:
         return getAllDecoratorsOfProperty(member);
       default:
         return void 0;
@@ -187538,10 +171602,90 @@ ${lanes.join("\n")}
   function accessPrivateIdentifier(env, name) {
     return walkUpLexicalEnvironments(env, (env2) => getPrivateIdentifier(env2.privateEnv, name));
   }
+  var IdentifierNameMap, IdentifierNameMultiMap;
   var init_utilities3 = __esm({
     "src/compiler/transformers/utilities.ts"() {
       "use strict";
       init_ts2();
+      IdentifierNameMap = class _IdentifierNameMap {
+        constructor() {
+          this._map = /* @__PURE__ */ new Map();
+        }
+        get size() {
+          return this._map.size;
+        }
+        has(key) {
+          return this._map.has(_IdentifierNameMap.toKey(key));
+        }
+        get(key) {
+          return this._map.get(_IdentifierNameMap.toKey(key));
+        }
+        set(key, value) {
+          this._map.set(_IdentifierNameMap.toKey(key), value);
+          return this;
+        }
+        delete(key) {
+          var _a;
+          return ((_a = this._map) == null ? void 0 : _a.delete(_IdentifierNameMap.toKey(key))) ?? false;
+        }
+        clear() {
+          this._map.clear();
+        }
+        values() {
+          return this._map.values();
+        }
+        static toKey(name) {
+          if (isGeneratedPrivateIdentifier(name) || isGeneratedIdentifier(name)) {
+            const autoGenerate = name.emitNode.autoGenerate;
+            if ((autoGenerate.flags & 7 /* KindMask */) === 4 /* Node */) {
+              const node = getNodeForGeneratedName(name);
+              const baseName = isMemberName(node) && node !== name ? _IdentifierNameMap.toKey(node) : `(generated@${getNodeId(node)})`;
+              return formatGeneratedName(
+                /*privateName*/
+                false,
+                autoGenerate.prefix,
+                baseName,
+                autoGenerate.suffix,
+                _IdentifierNameMap.toKey
+              );
+            } else {
+              const baseName = `(auto@${autoGenerate.id})`;
+              return formatGeneratedName(
+                /*privateName*/
+                false,
+                autoGenerate.prefix,
+                baseName,
+                autoGenerate.suffix,
+                _IdentifierNameMap.toKey
+              );
+            }
+          }
+          if (isPrivateIdentifier(name)) {
+            return idText(name).slice(1);
+          }
+          return idText(name);
+        }
+      };
+      IdentifierNameMultiMap = class extends IdentifierNameMap {
+        add(key, value) {
+          let values = this.get(key);
+          if (values) {
+            values.push(value);
+          } else {
+            this.set(key, values = [value]);
+          }
+          return values;
+        }
+        remove(key, value) {
+          const values = this.get(key);
+          if (values) {
+            unorderedRemoveItem(values, value);
+            if (!values.length) {
+              this.delete(key);
+            }
+          }
+        }
+      };
     }
   });
 
@@ -188013,6 +172157,287 @@ ${lanes.join("\n")}
     }
   });
 
+  // src/compiler/transformers/classThis.ts
+  function createClassThisAssignmentBlock(factory2, classThis, thisExpression = factory2.createThis()) {
+    const expression = factory2.createAssignment(classThis, thisExpression);
+    const statement = factory2.createExpressionStatement(expression);
+    const body = factory2.createBlock(
+      [statement],
+      /*multiLine*/
+      false
+    );
+    const block = factory2.createClassStaticBlockDeclaration(body);
+    getOrCreateEmitNode(block).classThis = classThis;
+    return block;
+  }
+  function isClassThisAssignmentBlock(node) {
+    var _a;
+    if (!isClassStaticBlockDeclaration(node) || node.body.statements.length !== 1) {
+      return false;
+    }
+    const statement = node.body.statements[0];
+    return isExpressionStatement(statement) && isAssignmentExpression(
+      statement.expression,
+      /*excludeCompoundAssignment*/
+      true
+    ) && isIdentifier(statement.expression.left) && ((_a = node.emitNode) == null ? void 0 : _a.classThis) === statement.expression.left && statement.expression.right.kind === 110 /* ThisKeyword */;
+  }
+  function classHasClassThisAssignment(node) {
+    var _a;
+    return !!((_a = node.emitNode) == null ? void 0 : _a.classThis) && some(node.members, isClassThisAssignmentBlock);
+  }
+  function injectClassThisAssignmentIfMissing(factory2, node, classThis, thisExpression) {
+    if (classHasClassThisAssignment(node)) {
+      return node;
+    }
+    const staticBlock = createClassThisAssignmentBlock(factory2, classThis, thisExpression);
+    if (node.name) {
+      setSourceMapRange(staticBlock.body.statements[0], node.name);
+    }
+    const members = factory2.createNodeArray([staticBlock, ...node.members]);
+    setTextRange(members, node.members);
+    const updatedNode = isClassDeclaration(node) ? factory2.updateClassDeclaration(
+      node,
+      node.modifiers,
+      node.name,
+      node.typeParameters,
+      node.heritageClauses,
+      members
+    ) : factory2.updateClassExpression(
+      node,
+      node.modifiers,
+      node.name,
+      node.typeParameters,
+      node.heritageClauses,
+      members
+    );
+    getOrCreateEmitNode(updatedNode).classThis = classThis;
+    return updatedNode;
+  }
+  var init_classThis = __esm({
+    "src/compiler/transformers/classThis.ts"() {
+      "use strict";
+      init_ts2();
+    }
+  });
+
+  // src/compiler/transformers/namedEvaluation.ts
+  function getAssignedNameOfIdentifier(factory2, name, expression) {
+    const original = getOriginalNode(skipOuterExpressions(expression));
+    if ((isClassDeclaration(original) || isFunctionDeclaration(original)) && !original.name && hasSyntacticModifier(original, 2048 /* Default */)) {
+      return factory2.createStringLiteral("default");
+    }
+    return factory2.createStringLiteralFromNode(name);
+  }
+  function getAssignedNameOfPropertyName(context, name, assignedNameText) {
+    const { factory: factory2 } = context;
+    if (assignedNameText !== void 0) {
+      const assignedName2 = factory2.createStringLiteral(assignedNameText);
+      return { assignedName: assignedName2, name };
+    }
+    if (isPropertyNameLiteral(name) || isPrivateIdentifier(name)) {
+      const assignedName2 = factory2.createStringLiteralFromNode(name);
+      return { assignedName: assignedName2, name };
+    }
+    if (isPropertyNameLiteral(name.expression) && !isIdentifier(name.expression)) {
+      const assignedName2 = factory2.createStringLiteralFromNode(name.expression);
+      return { assignedName: assignedName2, name };
+    }
+    const assignedName = factory2.getGeneratedNameForNode(name);
+    context.hoistVariableDeclaration(assignedName);
+    const key = context.getEmitHelperFactory().createPropKeyHelper(name.expression);
+    const assignment = factory2.createAssignment(assignedName, key);
+    const updatedName = factory2.updateComputedPropertyName(name, assignment);
+    return { assignedName, name: updatedName };
+  }
+  function createClassNamedEvaluationHelperBlock(context, assignedName, thisExpression = context.factory.createThis()) {
+    const { factory: factory2 } = context;
+    const expression = context.getEmitHelperFactory().createSetFunctionNameHelper(thisExpression, assignedName);
+    const statement = factory2.createExpressionStatement(expression);
+    const body = factory2.createBlock(
+      [statement],
+      /*multiLine*/
+      false
+    );
+    const block = factory2.createClassStaticBlockDeclaration(body);
+    getOrCreateEmitNode(block).assignedName = assignedName;
+    return block;
+  }
+  function isClassNamedEvaluationHelperBlock(node) {
+    var _a;
+    if (!isClassStaticBlockDeclaration(node) || node.body.statements.length !== 1) {
+      return false;
+    }
+    const statement = node.body.statements[0];
+    return isExpressionStatement(statement) && isCallToHelper(statement.expression, "___setFunctionName") && statement.expression.arguments.length >= 2 && statement.expression.arguments[1] === ((_a = node.emitNode) == null ? void 0 : _a.assignedName);
+  }
+  function classHasExplicitlyAssignedName(node) {
+    var _a;
+    return !!((_a = node.emitNode) == null ? void 0 : _a.assignedName) && some(node.members, isClassNamedEvaluationHelperBlock);
+  }
+  function classHasDeclaredOrExplicitlyAssignedName(node) {
+    return !!node.name || classHasExplicitlyAssignedName(node);
+  }
+  function injectClassNamedEvaluationHelperBlockIfMissing(context, node, assignedName, thisExpression) {
+    if (classHasExplicitlyAssignedName(node)) {
+      return node;
+    }
+    const { factory: factory2 } = context;
+    const namedEvaluationBlock = createClassNamedEvaluationHelperBlock(context, assignedName, thisExpression);
+    if (node.name) {
+      setSourceMapRange(namedEvaluationBlock.body.statements[0], node.name);
+    }
+    const insertionIndex = findIndex(node.members, isClassThisAssignmentBlock) + 1;
+    const leading = node.members.slice(0, insertionIndex);
+    const trailing = node.members.slice(insertionIndex);
+    const members = factory2.createNodeArray([...leading, namedEvaluationBlock, ...trailing]);
+    setTextRange(members, node.members);
+    node = isClassDeclaration(node) ? factory2.updateClassDeclaration(
+      node,
+      node.modifiers,
+      node.name,
+      node.typeParameters,
+      node.heritageClauses,
+      members
+    ) : factory2.updateClassExpression(
+      node,
+      node.modifiers,
+      node.name,
+      node.typeParameters,
+      node.heritageClauses,
+      members
+    );
+    getOrCreateEmitNode(node).assignedName = assignedName;
+    return node;
+  }
+  function finishTransformNamedEvaluation(context, expression, assignedName, ignoreEmptyStringLiteral) {
+    if (ignoreEmptyStringLiteral && isStringLiteral(assignedName) && isEmptyStringLiteral(assignedName)) {
+      return expression;
+    }
+    const { factory: factory2 } = context;
+    const innerExpression = skipOuterExpressions(expression);
+    const updatedExpression = isClassExpression(innerExpression) ? cast(injectClassNamedEvaluationHelperBlockIfMissing(context, innerExpression, assignedName), isClassExpression) : context.getEmitHelperFactory().createSetFunctionNameHelper(innerExpression, assignedName);
+    return factory2.restoreOuterExpressions(expression, updatedExpression);
+  }
+  function transformNamedEvaluationOfPropertyAssignment(context, node, ignoreEmptyStringLiteral, assignedNameText) {
+    const { factory: factory2 } = context;
+    const { assignedName, name } = getAssignedNameOfPropertyName(context, node.name, assignedNameText);
+    const initializer = finishTransformNamedEvaluation(context, node.initializer, assignedName, ignoreEmptyStringLiteral);
+    return factory2.updatePropertyAssignment(
+      node,
+      name,
+      initializer
+    );
+  }
+  function transformNamedEvaluationOfShorthandAssignmentProperty(context, node, ignoreEmptyStringLiteral, assignedNameText) {
+    const { factory: factory2 } = context;
+    const assignedName = assignedNameText !== void 0 ? factory2.createStringLiteral(assignedNameText) : getAssignedNameOfIdentifier(factory2, node.name, node.objectAssignmentInitializer);
+    const objectAssignmentInitializer = finishTransformNamedEvaluation(context, node.objectAssignmentInitializer, assignedName, ignoreEmptyStringLiteral);
+    return factory2.updateShorthandPropertyAssignment(
+      node,
+      node.name,
+      objectAssignmentInitializer
+    );
+  }
+  function transformNamedEvaluationOfVariableDeclaration(context, node, ignoreEmptyStringLiteral, assignedNameText) {
+    const { factory: factory2 } = context;
+    const assignedName = assignedNameText !== void 0 ? factory2.createStringLiteral(assignedNameText) : getAssignedNameOfIdentifier(factory2, node.name, node.initializer);
+    const initializer = finishTransformNamedEvaluation(context, node.initializer, assignedName, ignoreEmptyStringLiteral);
+    return factory2.updateVariableDeclaration(
+      node,
+      node.name,
+      node.exclamationToken,
+      node.type,
+      initializer
+    );
+  }
+  function transformNamedEvaluationOfParameterDeclaration(context, node, ignoreEmptyStringLiteral, assignedNameText) {
+    const { factory: factory2 } = context;
+    const assignedName = assignedNameText !== void 0 ? factory2.createStringLiteral(assignedNameText) : getAssignedNameOfIdentifier(factory2, node.name, node.initializer);
+    const initializer = finishTransformNamedEvaluation(context, node.initializer, assignedName, ignoreEmptyStringLiteral);
+    return factory2.updateParameterDeclaration(
+      node,
+      node.modifiers,
+      node.dotDotDotToken,
+      node.name,
+      node.questionToken,
+      node.type,
+      initializer
+    );
+  }
+  function transformNamedEvaluationOfBindingElement(context, node, ignoreEmptyStringLiteral, assignedNameText) {
+    const { factory: factory2 } = context;
+    const assignedName = assignedNameText !== void 0 ? factory2.createStringLiteral(assignedNameText) : getAssignedNameOfIdentifier(factory2, node.name, node.initializer);
+    const initializer = finishTransformNamedEvaluation(context, node.initializer, assignedName, ignoreEmptyStringLiteral);
+    return factory2.updateBindingElement(
+      node,
+      node.dotDotDotToken,
+      node.propertyName,
+      node.name,
+      initializer
+    );
+  }
+  function transformNamedEvaluationOfPropertyDeclaration(context, node, ignoreEmptyStringLiteral, assignedNameText) {
+    const { factory: factory2 } = context;
+    const { assignedName, name } = getAssignedNameOfPropertyName(context, node.name, assignedNameText);
+    const initializer = finishTransformNamedEvaluation(context, node.initializer, assignedName, ignoreEmptyStringLiteral);
+    return factory2.updatePropertyDeclaration(
+      node,
+      node.modifiers,
+      name,
+      node.questionToken ?? node.exclamationToken,
+      node.type,
+      initializer
+    );
+  }
+  function transformNamedEvaluationOfAssignmentExpression(context, node, ignoreEmptyStringLiteral, assignedNameText) {
+    const { factory: factory2 } = context;
+    const assignedName = assignedNameText !== void 0 ? factory2.createStringLiteral(assignedNameText) : getAssignedNameOfIdentifier(factory2, node.left, node.right);
+    const right = finishTransformNamedEvaluation(context, node.right, assignedName, ignoreEmptyStringLiteral);
+    return factory2.updateBinaryExpression(
+      node,
+      node.left,
+      node.operatorToken,
+      right
+    );
+  }
+  function transformNamedEvaluationOfExportAssignment(context, node, ignoreEmptyStringLiteral, assignedNameText) {
+    const { factory: factory2 } = context;
+    const assignedName = assignedNameText !== void 0 ? factory2.createStringLiteral(assignedNameText) : factory2.createStringLiteral(node.isExportEquals ? "" : "default");
+    const expression = finishTransformNamedEvaluation(context, node.expression, assignedName, ignoreEmptyStringLiteral);
+    return factory2.updateExportAssignment(
+      node,
+      node.modifiers,
+      expression
+    );
+  }
+  function transformNamedEvaluation(context, node, ignoreEmptyStringLiteral, assignedName) {
+    switch (node.kind) {
+      case 303 /* PropertyAssignment */:
+        return transformNamedEvaluationOfPropertyAssignment(context, node, ignoreEmptyStringLiteral, assignedName);
+      case 304 /* ShorthandPropertyAssignment */:
+        return transformNamedEvaluationOfShorthandAssignmentProperty(context, node, ignoreEmptyStringLiteral, assignedName);
+      case 260 /* VariableDeclaration */:
+        return transformNamedEvaluationOfVariableDeclaration(context, node, ignoreEmptyStringLiteral, assignedName);
+      case 169 /* Parameter */:
+        return transformNamedEvaluationOfParameterDeclaration(context, node, ignoreEmptyStringLiteral, assignedName);
+      case 208 /* BindingElement */:
+        return transformNamedEvaluationOfBindingElement(context, node, ignoreEmptyStringLiteral, assignedName);
+      case 172 /* PropertyDeclaration */:
+        return transformNamedEvaluationOfPropertyDeclaration(context, node, ignoreEmptyStringLiteral, assignedName);
+      case 226 /* BinaryExpression */:
+        return transformNamedEvaluationOfAssignmentExpression(context, node, ignoreEmptyStringLiteral, assignedName);
+      case 277 /* ExportAssignment */:
+        return transformNamedEvaluationOfExportAssignment(context, node, ignoreEmptyStringLiteral, assignedName);
+    }
+  }
+  var init_namedEvaluation = __esm({
+    "src/compiler/transformers/namedEvaluation.ts"() {
+      "use strict";
+      init_ts2();
+    }
+  });
+
   // src/compiler/transformers/taggedTemplate.ts
   function processTaggedTemplateExpression(context, node, visitor, currentSourceFile, recordTaggedTemplateString, level) {
     const tag = visitNode(node.tag, visitor, isExpression);
@@ -188067,10 +172492,7 @@ ${lanes.join("\n")}
   function getRawLiteral(factory2, node, currentSourceFile) {
     let text = node.rawText;
     if (text === void 0) {
-      Debug.assertIsDefined(
-        currentSourceFile,
-        "Template literal node is missing 'rawText' and does not have a source file. Possibly bad transform."
-      );
+      Debug.assertIsDefined(currentSourceFile, "Template literal node is missing 'rawText' and does not have a source file. Possibly bad transform.");
       text = getSourceTextOfNodeFromSourceFile(currentSourceFile, node);
       const isLast = node.kind === 15 /* NoSubstitutionTemplateLiteral */ || node.kind === 18 /* TemplateTail */;
       text = text.substring(1, text.length - (isLast ? 1 : 2));
@@ -188111,8 +172533,8 @@ ${lanes.join("\n")}
     const previousOnSubstituteNode = context.onSubstituteNode;
     context.onEmitNode = onEmitNode;
     context.onSubstituteNode = onSubstituteNode;
-    context.enableSubstitution(210 /* PropertyAccessExpression */);
-    context.enableSubstitution(211 /* ElementAccessExpression */);
+    context.enableSubstitution(211 /* PropertyAccessExpression */);
+    context.enableSubstitution(212 /* ElementAccessExpression */);
     let currentSourceFile;
     let currentNamespace;
     let currentNamespaceContainerName;
@@ -188123,18 +172545,21 @@ ${lanes.join("\n")}
     let applicableSubstitutions;
     return transformSourceFileOrBundle;
     function transformSourceFileOrBundle(node) {
-      if (node.kind === 312 /* Bundle */) {
+      if (node.kind === 313 /* Bundle */) {
         return transformBundle(node);
       }
       return transformSourceFile(node);
     }
     function transformBundle(node) {
-      return factory2.createBundle(node.sourceFiles.map(transformSourceFile), mapDefined(node.prepends, (prepend) => {
-        if (prepend.kind === 314 /* InputFiles */) {
-          return createUnparsedSourceFile(prepend, "js");
-        }
-        return prepend;
-      }));
+      return factory2.createBundle(
+        node.sourceFiles.map(transformSourceFile),
+        mapDefined(node.prepends, (prepend) => {
+          if (prepend.kind === 315 /* InputFiles */) {
+            return createUnparsedSourceFile(prepend, "js");
+          }
+          return prepend;
+        })
+      );
     }
     function transformSourceFile(node) {
       if (node.isDeclarationFile) {
@@ -188161,22 +172586,22 @@ ${lanes.join("\n")}
     }
     function onBeforeVisitNode(node) {
       switch (node.kind) {
-        case 311 /* SourceFile */:
-        case 268 /* CaseBlock */:
-        case 267 /* ModuleBlock */:
-        case 240 /* Block */:
+        case 312 /* SourceFile */:
+        case 269 /* CaseBlock */:
+        case 268 /* ModuleBlock */:
+        case 241 /* Block */:
           currentLexicalScope = node;
           currentScopeFirstDeclarationsOfName = void 0;
           break;
-        case 262 /* ClassDeclaration */:
-        case 261 /* FunctionDeclaration */:
-          if (hasSyntacticModifier(node, 2 /* Ambient */)) {
+        case 263 /* ClassDeclaration */:
+        case 262 /* FunctionDeclaration */:
+          if (hasSyntacticModifier(node, 128 /* Ambient */)) {
             break;
           }
           if (node.name) {
             recordEmittedDeclarationInScope(node);
           } else {
-            Debug.assert(node.kind === 262 /* ClassDeclaration */ || hasSyntacticModifier(node, 1024 /* Default */));
+            Debug.assert(node.kind === 263 /* ClassDeclaration */ || hasSyntacticModifier(node, 2048 /* Default */));
           }
           break;
       }
@@ -188195,10 +172620,10 @@ ${lanes.join("\n")}
     }
     function sourceElementVisitorWorker(node) {
       switch (node.kind) {
-        case 271 /* ImportDeclaration */:
-        case 270 /* ImportEqualsDeclaration */:
-        case 276 /* ExportAssignment */:
-        case 277 /* ExportDeclaration */:
+        case 272 /* ImportDeclaration */:
+        case 271 /* ImportEqualsDeclaration */:
+        case 277 /* ExportAssignment */:
+        case 278 /* ExportDeclaration */:
           return visitElidableStatement(node);
         default:
           return visitorWorker(node);
@@ -188213,13 +172638,13 @@ ${lanes.join("\n")}
         return node;
       }
       switch (node.kind) {
-        case 271 /* ImportDeclaration */:
+        case 272 /* ImportDeclaration */:
           return visitImportDeclaration(node);
-        case 270 /* ImportEqualsDeclaration */:
+        case 271 /* ImportEqualsDeclaration */:
           return visitImportEqualsDeclaration(node);
-        case 276 /* ExportAssignment */:
+        case 277 /* ExportAssignment */:
           return visitExportAssignment(node);
-        case 277 /* ExportDeclaration */:
+        case 278 /* ExportDeclaration */:
           return visitExportDeclaration(node);
         default:
           Debug.fail("Unhandled ellided statement");
@@ -188229,9 +172654,9 @@ ${lanes.join("\n")}
       return saveStateAndInvoke(node, namespaceElementVisitorWorker);
     }
     function namespaceElementVisitorWorker(node) {
-      if (node.kind === 277 /* ExportDeclaration */ || node.kind === 271 /* ImportDeclaration */ || node.kind === 272 /* ImportClause */ || node.kind === 270 /* ImportEqualsDeclaration */ && node.moduleReference.kind === 282 /* ExternalModuleReference */) {
+      if (node.kind === 278 /* ExportDeclaration */ || node.kind === 272 /* ImportDeclaration */ || node.kind === 273 /* ImportClause */ || node.kind === 271 /* ImportEqualsDeclaration */ && node.moduleReference.kind === 283 /* ExternalModuleReference */) {
         return void 0;
-      } else if (node.transformFlags & 1 /* ContainsTypeScript */ || hasSyntacticModifier(node, 1 /* Export */)) {
+      } else if (node.transformFlags & 1 /* ContainsTypeScript */ || hasSyntacticModifier(node, 32 /* Export */)) {
         return visitTypeScript(node);
       }
       return node;
@@ -188241,21 +172666,21 @@ ${lanes.join("\n")}
     }
     function classElementVisitorWorker(node, parent2) {
       switch (node.kind) {
-        case 175 /* Constructor */:
+        case 176 /* Constructor */:
           return visitConstructor(node);
-        case 171 /* PropertyDeclaration */:
+        case 172 /* PropertyDeclaration */:
           return visitPropertyDeclaration(node, parent2);
-        case 176 /* GetAccessor */:
+        case 177 /* GetAccessor */:
           return visitGetAccessor(node, parent2);
-        case 177 /* SetAccessor */:
+        case 178 /* SetAccessor */:
           return visitSetAccessor(node, parent2);
-        case 173 /* MethodDeclaration */:
+        case 174 /* MethodDeclaration */:
           return visitMethodDeclaration(node, parent2);
-        case 174 /* ClassStaticBlockDeclaration */:
+        case 175 /* ClassStaticBlockDeclaration */:
           return visitEachChild(node, visitor, context);
-        case 239 /* SemicolonClassElement */:
+        case 240 /* SemicolonClassElement */:
           return node;
-        case 180 /* IndexSignature */:
+        case 181 /* IndexSignature */:
           return;
         default:
           return Debug.failBadSyntaxKind(node);
@@ -188266,15 +172691,15 @@ ${lanes.join("\n")}
     }
     function objectLiteralElementVisitorWorker(node, parent2) {
       switch (node.kind) {
-        case 302 /* PropertyAssignment */:
-        case 303 /* ShorthandPropertyAssignment */:
-        case 304 /* SpreadAssignment */:
+        case 303 /* PropertyAssignment */:
+        case 304 /* ShorthandPropertyAssignment */:
+        case 305 /* SpreadAssignment */:
           return visitor(node);
-        case 176 /* GetAccessor */:
+        case 177 /* GetAccessor */:
           return visitGetAccessor(node, parent2);
-        case 177 /* SetAccessor */:
+        case 178 /* SetAccessor */:
           return visitSetAccessor(node, parent2);
-        case 173 /* MethodDeclaration */:
+        case 174 /* MethodDeclaration */:
           return visitMethodDeclaration(node, parent2);
         default:
           return Debug.failBadSyntaxKind(node);
@@ -188289,7 +172714,7 @@ ${lanes.join("\n")}
     function modifierVisitor(node) {
       if (isDecorator(node))
         return void 0;
-      if (modifierToFlag(node.kind) & 117086 /* TypeScriptModifier */) {
+      if (modifierToFlag(node.kind) & 28895 /* TypeScriptModifier */) {
         return void 0;
       } else if (currentNamespace && node.kind === 95 /* ExportKeyword */) {
         return void 0;
@@ -188297,7 +172722,7 @@ ${lanes.join("\n")}
       return node;
     }
     function visitTypeScript(node) {
-      if (isStatement(node) && hasSyntacticModifier(node, 2 /* Ambient */)) {
+      if (isStatement(node) && hasSyntacticModifier(node, 128 /* Ambient */)) {
         return factory2.createNotEmittedStatement(node);
       }
       switch (node.kind) {
@@ -188308,19 +172733,19 @@ ${lanes.join("\n")}
         case 123 /* PrivateKeyword */:
         case 124 /* ProtectedKeyword */:
         case 128 /* AbstractKeyword */:
-        case 163 /* OverrideKeyword */:
+        case 164 /* OverrideKeyword */:
         case 87 /* ConstKeyword */:
         case 138 /* DeclareKeyword */:
         case 148 /* ReadonlyKeyword */:
         case 103 /* InKeyword */:
         case 147 /* OutKeyword */:
-        case 187 /* ArrayType */:
-        case 188 /* TupleType */:
-        case 189 /* OptionalType */:
-        case 190 /* RestType */:
-        case 186 /* TypeLiteral */:
-        case 181 /* TypePredicate */:
-        case 167 /* TypeParameter */:
+        case 188 /* ArrayType */:
+        case 189 /* TupleType */:
+        case 190 /* OptionalType */:
+        case 191 /* RestType */:
+        case 187 /* TypeLiteral */:
+        case 182 /* TypePredicate */:
+        case 168 /* TypeParameter */:
         case 133 /* AnyKeyword */:
         case 159 /* UnknownKeyword */:
         case 136 /* BooleanKeyword */:
@@ -188329,80 +172754,80 @@ ${lanes.join("\n")}
         case 146 /* NeverKeyword */:
         case 116 /* VoidKeyword */:
         case 155 /* SymbolKeyword */:
-        case 184 /* ConstructorType */:
-        case 183 /* FunctionType */:
-        case 185 /* TypeQuery */:
-        case 182 /* TypeReference */:
-        case 191 /* UnionType */:
-        case 192 /* IntersectionType */:
-        case 193 /* ConditionalType */:
-        case 195 /* ParenthesizedType */:
-        case 196 /* ThisType */:
-        case 197 /* TypeOperator */:
-        case 198 /* IndexedAccessType */:
-        case 199 /* MappedType */:
-        case 200 /* LiteralType */:
-        case 180 /* IndexSignature */:
+        case 185 /* ConstructorType */:
+        case 184 /* FunctionType */:
+        case 186 /* TypeQuery */:
+        case 183 /* TypeReference */:
+        case 192 /* UnionType */:
+        case 193 /* IntersectionType */:
+        case 194 /* ConditionalType */:
+        case 196 /* ParenthesizedType */:
+        case 197 /* ThisType */:
+        case 198 /* TypeOperator */:
+        case 199 /* IndexedAccessType */:
+        case 200 /* MappedType */:
+        case 201 /* LiteralType */:
+        case 181 /* IndexSignature */:
           return void 0;
-        case 264 /* TypeAliasDeclaration */:
+        case 265 /* TypeAliasDeclaration */:
           return factory2.createNotEmittedStatement(node);
-        case 269 /* NamespaceExportDeclaration */:
+        case 270 /* NamespaceExportDeclaration */:
           return void 0;
-        case 263 /* InterfaceDeclaration */:
+        case 264 /* InterfaceDeclaration */:
           return factory2.createNotEmittedStatement(node);
-        case 262 /* ClassDeclaration */:
+        case 263 /* ClassDeclaration */:
           return visitClassDeclaration(node);
-        case 230 /* ClassExpression */:
+        case 231 /* ClassExpression */:
           return visitClassExpression(node);
-        case 297 /* HeritageClause */:
+        case 298 /* HeritageClause */:
           return visitHeritageClause(node);
-        case 232 /* ExpressionWithTypeArguments */:
+        case 233 /* ExpressionWithTypeArguments */:
           return visitExpressionWithTypeArguments(node);
-        case 209 /* ObjectLiteralExpression */:
+        case 210 /* ObjectLiteralExpression */:
           return visitObjectLiteralExpression(node);
-        case 175 /* Constructor */:
-        case 171 /* PropertyDeclaration */:
-        case 173 /* MethodDeclaration */:
-        case 176 /* GetAccessor */:
-        case 177 /* SetAccessor */:
-        case 174 /* ClassStaticBlockDeclaration */:
+        case 176 /* Constructor */:
+        case 172 /* PropertyDeclaration */:
+        case 174 /* MethodDeclaration */:
+        case 177 /* GetAccessor */:
+        case 178 /* SetAccessor */:
+        case 175 /* ClassStaticBlockDeclaration */:
           return Debug.fail("Class and object literal elements must be visited with their respective visitors");
-        case 261 /* FunctionDeclaration */:
+        case 262 /* FunctionDeclaration */:
           return visitFunctionDeclaration(node);
-        case 217 /* FunctionExpression */:
+        case 218 /* FunctionExpression */:
           return visitFunctionExpression(node);
-        case 218 /* ArrowFunction */:
+        case 219 /* ArrowFunction */:
           return visitArrowFunction(node);
-        case 168 /* Parameter */:
+        case 169 /* Parameter */:
           return visitParameter(node);
-        case 216 /* ParenthesizedExpression */:
+        case 217 /* ParenthesizedExpression */:
           return visitParenthesizedExpression(node);
-        case 215 /* TypeAssertionExpression */:
-        case 233 /* AsExpression */:
+        case 216 /* TypeAssertionExpression */:
+        case 234 /* AsExpression */:
           return visitAssertionExpression(node);
-        case 237 /* SatisfiesExpression */:
+        case 238 /* SatisfiesExpression */:
           return visitSatisfiesExpression(node);
-        case 212 /* CallExpression */:
+        case 213 /* CallExpression */:
           return visitCallExpression(node);
-        case 213 /* NewExpression */:
+        case 214 /* NewExpression */:
           return visitNewExpression(node);
-        case 214 /* TaggedTemplateExpression */:
+        case 215 /* TaggedTemplateExpression */:
           return visitTaggedTemplateExpression(node);
-        case 234 /* NonNullExpression */:
+        case 235 /* NonNullExpression */:
           return visitNonNullExpression(node);
-        case 265 /* EnumDeclaration */:
+        case 266 /* EnumDeclaration */:
           return visitEnumDeclaration(node);
-        case 242 /* VariableStatement */:
+        case 243 /* VariableStatement */:
           return visitVariableStatement(node);
-        case 259 /* VariableDeclaration */:
+        case 260 /* VariableDeclaration */:
           return visitVariableDeclaration(node);
-        case 266 /* ModuleDeclaration */:
+        case 267 /* ModuleDeclaration */:
           return visitModuleDeclaration(node);
-        case 270 /* ImportEqualsDeclaration */:
+        case 271 /* ImportEqualsDeclaration */:
           return visitImportEqualsDeclaration(node);
-        case 284 /* JsxSelfClosingElement */:
+        case 285 /* JsxSelfClosingElement */:
           return visitJsxSelfClosingElement(node);
-        case 285 /* JsxOpeningElement */:
+        case 286 /* JsxOpeningElement */:
           return visitJsxJsxOpeningElement(node);
         default:
           return visitEachChild(node, visitor, context);
@@ -188512,25 +172937,25 @@ ${lanes.join("\n")}
         insertStatementsAfterStandardPrologue(statements, context.endLexicalEnvironment());
         const iife = factory2.createImmediatelyInvokedArrowFunction(statements);
         setInternalEmitFlags(iife, 1 /* TypeScriptClassWrapper */);
-        const modifiers2 = facts & 16 /* IsNamedExternalExport */ ? factory2.createModifiersFromModifierFlags(1 /* Export */) : void 0;
+        const varDecl = factory2.createVariableDeclaration(
+          factory2.getLocalName(
+            node,
+            /*allowComments*/
+            false,
+            /*allowSourceMaps*/
+            false
+          ),
+          /*exclamationToken*/
+          void 0,
+          /*type*/
+          void 0,
+          iife
+        );
+        setOriginalNode(varDecl, node);
         const varStatement = factory2.createVariableStatement(
-          modifiers2,
-          factory2.createVariableDeclarationList([
-            factory2.createVariableDeclaration(
-              factory2.getLocalName(
-                node,
-                /*allowComments*/
-                false,
-                /*allowSourceMaps*/
-                false
-              ),
-              /*exclamationToken*/
-              void 0,
-              /*type*/
-              void 0,
-              iife
-            )
-          ], 1 /* Let */)
+          /*modifiers*/
+          void 0,
+          factory2.createVariableDeclarationList([varDecl], 1 /* Let */)
         );
         setOriginalNode(varStatement, node);
         setCommentRange(varStatement, node);
@@ -188559,10 +172984,10 @@ ${lanes.join("\n")}
             ))
           ];
         }
-        if (facts & 16 /* IsNamedExternalExport */ && !promoteToIIFE) {
+        if (facts & 16 /* IsNamedExternalExport */) {
           return [
             statement,
-            factory2.createExternalModuleExport(factory2.getLocalName(
+            factory2.createExternalModuleExport(factory2.getDeclarationName(
               node,
               /*allowComments*/
               false,
@@ -188726,19 +173151,19 @@ ${lanes.join("\n")}
     }
     function shouldAddTypeMetadata(node) {
       const kind = node.kind;
-      return kind === 173 /* MethodDeclaration */ || kind === 176 /* GetAccessor */ || kind === 177 /* SetAccessor */ || kind === 171 /* PropertyDeclaration */;
+      return kind === 174 /* MethodDeclaration */ || kind === 177 /* GetAccessor */ || kind === 178 /* SetAccessor */ || kind === 172 /* PropertyDeclaration */;
     }
     function shouldAddReturnTypeMetadata(node) {
-      return node.kind === 173 /* MethodDeclaration */;
+      return node.kind === 174 /* MethodDeclaration */;
     }
     function shouldAddParamTypesMetadata(node) {
       switch (node.kind) {
-        case 262 /* ClassDeclaration */:
-        case 230 /* ClassExpression */:
+        case 263 /* ClassDeclaration */:
+        case 231 /* ClassExpression */:
           return getFirstConstructorWithBody(node) !== void 0;
-        case 173 /* MethodDeclaration */:
-        case 176 /* GetAccessor */:
-        case 177 /* SetAccessor */:
+        case 174 /* MethodDeclaration */:
+        case 177 /* GetAccessor */:
+        case 178 /* SetAccessor */:
           return true;
       }
       return false;
@@ -188787,7 +173212,7 @@ ${lanes.join("\n")}
       return !nodeIsMissing(node.body);
     }
     function visitPropertyDeclaration(node, parent2) {
-      const isAmbient = node.flags & 16777216 /* Ambient */ || hasSyntacticModifier(node, 256 /* Abstract */);
+      const isAmbient = node.flags & 33554432 /* Ambient */ || hasSyntacticModifier(node, 64 /* Abstract */);
       if (isAmbient && !(legacyDecorators && hasDecorators(node))) {
         return void 0;
       }
@@ -188796,7 +173221,7 @@ ${lanes.join("\n")}
       if (isAmbient) {
         return factory2.updatePropertyDeclaration(
           node,
-          concatenate(modifiers, factory2.createModifiersFromModifierFlags(2 /* Ambient */)),
+          concatenate(modifiers, factory2.createModifiersFromModifierFlags(128 /* Ambient */)),
           Debug.checkDefined(visitNode(node.name, visitor, isPropertyName)),
           /*questionOrExclamationToken*/
           void 0,
@@ -188829,6 +173254,35 @@ ${lanes.join("\n")}
         transformConstructorBody(node.body, node)
       );
     }
+    function transformConstructorBodyWorker(statementsOut, statementsIn, statementOffset, superPath, superPathDepth, initializerStatements) {
+      const superStatementIndex = superPath[superPathDepth];
+      const superStatement = statementsIn[superStatementIndex];
+      addRange(statementsOut, visitNodes2(statementsIn, visitor, isStatement, statementOffset, superStatementIndex - statementOffset));
+      if (isTryStatement(superStatement)) {
+        const tryBlockStatements = [];
+        transformConstructorBodyWorker(
+          tryBlockStatements,
+          superStatement.tryBlock.statements,
+          /*statementOffset*/
+          0,
+          superPath,
+          superPathDepth + 1,
+          initializerStatements
+        );
+        const tryBlockStatementsArray = factory2.createNodeArray(tryBlockStatements);
+        setTextRange(tryBlockStatementsArray, superStatement.tryBlock.statements);
+        statementsOut.push(factory2.updateTryStatement(
+          superStatement,
+          factory2.updateBlock(superStatement.tryBlock, tryBlockStatements),
+          visitNode(superStatement.catchClause, visitor, isCatchClause),
+          visitNode(superStatement.finallyBlock, visitor, isBlock)
+        ));
+      } else {
+        addRange(statementsOut, visitNodes2(statementsIn, visitor, isStatement, superStatementIndex, 1));
+        addRange(statementsOut, initializerStatements);
+      }
+      addRange(statementsOut, visitNodes2(statementsIn, visitor, isStatement, superStatementIndex + 1));
+    }
     function transformConstructorBody(body, constructor) {
       const parametersWithPropertyAssignments = constructor && filter(constructor.parameters, (p) => isParameterPropertyDeclaration(p, constructor));
       if (!some(parametersWithPropertyAssignments)) {
@@ -188843,25 +173297,22 @@ ${lanes.join("\n")}
         false,
         visitor
       );
-      const superStatementIndex = findSuperStatementIndex(body.statements, prologueStatementCount);
-      if (superStatementIndex >= 0) {
-        addRange(
+      const superPath = findSuperStatementIndexPath(body.statements, prologueStatementCount);
+      const parameterPropertyAssignments = mapDefined(parametersWithPropertyAssignments, transformParameterWithPropertyAssignment);
+      if (superPath.length) {
+        transformConstructorBodyWorker(
           statements,
-          visitNodes2(body.statements, visitor, isStatement, prologueStatementCount, superStatementIndex + 1 - prologueStatementCount)
+          body.statements,
+          prologueStatementCount,
+          superPath,
+          /*superPathDepth*/
+          0,
+          parameterPropertyAssignments
         );
-      }
-      const parameterPropertyAssignments = mapDefined(parametersWithPropertyAssignments, transformParameterWithPropertyAssignment);
-      if (superStatementIndex >= 0) {
-        addRange(statements, parameterPropertyAssignments);
       } else {
-        statements = [
-          ...statements.slice(0, prologueStatementCount),
-          ...parameterPropertyAssignments,
-          ...statements.slice(prologueStatementCount)
-        ];
+        addRange(statements, parameterPropertyAssignments);
+        addRange(statements, visitNodes2(body.statements, visitor, isStatement, prologueStatementCount));
       }
-      const start = superStatementIndex >= 0 ? superStatementIndex + 1 : prologueStatementCount;
-      addRange(statements, visitNodes2(body.statements, visitor, isStatement, start));
       statements = factory2.mergeLexicalEnvironment(statements, endLexicalEnvironment());
       const block = factory2.createBlock(
         setTextRange(factory2.createNodeArray(statements), body.statements),
@@ -188933,7 +173384,7 @@ ${lanes.join("\n")}
       );
     }
     function shouldEmitAccessorDeclaration(node) {
-      return !(nodeIsMissing(node.body) && hasSyntacticModifier(node, 256 /* Abstract */));
+      return !(nodeIsMissing(node.body) && hasSyntacticModifier(node, 64 /* Abstract */));
     }
     function visitGetAccessor(node, parent2) {
       if (!(node.transformFlags & 1 /* ContainsTypeScript */)) {
@@ -189357,7 +173808,7 @@ ${lanes.join("\n")}
         /*allowSourceMaps*/
         true
       ));
-      const varFlags = currentLexicalScope.kind === 311 /* SourceFile */ ? 0 /* None */ : 1 /* Let */;
+      const varFlags = currentLexicalScope.kind === 312 /* SourceFile */ ? 0 /* None */ : 1 /* Let */;
       const statement = factory2.createVariableStatement(
         visitNodes2(node.modifiers, modifierVisitor, isModifier),
         factory2.createVariableDeclarationList([varDecl], varFlags)
@@ -189368,7 +173819,7 @@ ${lanes.join("\n")}
       setOriginalNode(statement, node);
       recordEmittedDeclarationInScope(node);
       if (isFirstEmittedDeclarationInScope(node)) {
-        if (node.kind === 265 /* EnumDeclaration */) {
+        if (node.kind === 266 /* EnumDeclaration */) {
           setSourceMapRange(statement.declarationList, node);
         } else {
           setSourceMapRange(statement, node);
@@ -189476,7 +173927,7 @@ ${lanes.join("\n")}
       let statementsLocation;
       let blockLocation;
       if (node.body) {
-        if (node.body.kind === 267 /* ModuleBlock */) {
+        if (node.body.kind === 268 /* ModuleBlock */) {
           saveStateAndInvoke(node.body, (body) => addRange(statements, visitNodes2(body.statements, namespaceElementVisitor, isStatement)));
           statementsLocation = node.body.statements;
           blockLocation = node.body;
@@ -189507,13 +173958,13 @@ ${lanes.join("\n")}
         true
       );
       setTextRange(block, blockLocation);
-      if (!node.body || node.body.kind !== 267 /* ModuleBlock */) {
+      if (!node.body || node.body.kind !== 268 /* ModuleBlock */) {
         setEmitFlags(block, getEmitFlags(block) | 3072 /* NoComments */);
       }
       return block;
     }
     function getInnerMostModuleDeclarationFromDottedModule(moduleDeclaration) {
-      if (moduleDeclaration.body.kind === 266 /* ModuleDeclaration */) {
+      if (moduleDeclaration.body.kind === 267 /* ModuleDeclaration */) {
         const recursiveInnerModule = getInnerMostModuleDeclarationFromDottedModule(moduleDeclaration.body);
         return recursiveInnerModule || moduleDeclaration.body;
       }
@@ -189532,7 +173983,7 @@ ${lanes.join("\n")}
         void 0,
         importClause,
         node.moduleSpecifier,
-        node.assertClause
+        node.attributes
       ) : void 0;
     }
     function visitImportClause(node) {
@@ -189548,7 +173999,7 @@ ${lanes.join("\n")}
       ) : void 0;
     }
     function visitNamedImportBindings(node) {
-      if (node.kind === 273 /* NamespaceImport */) {
+      if (node.kind === 274 /* NamespaceImport */) {
         return shouldEmitAliasDeclaration(node) ? node : void 0;
       } else {
         const allowEmpty = compilerOptions.verbatimModuleSyntax || compilerOptions.preserveValueImports && (compilerOptions.importsNotUsedAsValues === 1 /* Preserve */ || compilerOptions.importsNotUsedAsValues === 2 /* Error */);
@@ -189582,7 +174033,7 @@ ${lanes.join("\n")}
         node.isTypeOnly,
         exportClause,
         node.moduleSpecifier,
-        node.assertClause
+        node.attributes
       ) : void 0;
     }
     function visitNamedExports(node, allowEmpty) {
@@ -189616,7 +174067,7 @@ ${lanes.join("\n")}
                 /*importClause*/
                 void 0,
                 node.moduleReference.expression,
-                /*assertClause*/
+                /*attributes*/
                 void 0
               ),
               node
@@ -189666,16 +174117,16 @@ ${lanes.join("\n")}
       }
     }
     function isExportOfNamespace(node) {
-      return currentNamespace !== void 0 && hasSyntacticModifier(node, 1 /* Export */);
+      return currentNamespace !== void 0 && hasSyntacticModifier(node, 32 /* Export */);
     }
     function isExternalModuleExport(node) {
-      return currentNamespace === void 0 && hasSyntacticModifier(node, 1 /* Export */);
+      return currentNamespace === void 0 && hasSyntacticModifier(node, 32 /* Export */);
     }
     function isNamedExternalModuleExport(node) {
-      return isExternalModuleExport(node) && !hasSyntacticModifier(node, 1024 /* Default */);
+      return isExternalModuleExport(node) && !hasSyntacticModifier(node, 2048 /* Default */);
     }
     function isDefaultExternalModuleExport(node) {
-      return isExternalModuleExport(node) && hasSyntacticModifier(node, 1024 /* Default */);
+      return isExternalModuleExport(node) && hasSyntacticModifier(node, 2048 /* Default */);
     }
     function createExportMemberAssignmentStatement(node) {
       const expression = factory2.createAssignment(
@@ -189746,15 +174197,15 @@ ${lanes.join("\n")}
       if ((enabledSubstitutions & 2 /* NamespaceExports */) === 0) {
         enabledSubstitutions |= 2 /* NamespaceExports */;
         context.enableSubstitution(80 /* Identifier */);
-        context.enableSubstitution(303 /* ShorthandPropertyAssignment */);
-        context.enableEmitNotification(266 /* ModuleDeclaration */);
+        context.enableSubstitution(304 /* ShorthandPropertyAssignment */);
+        context.enableEmitNotification(267 /* ModuleDeclaration */);
       }
     }
     function isTransformedModuleDeclaration(node) {
-      return getOriginalNode(node).kind === 266 /* ModuleDeclaration */;
+      return getOriginalNode(node).kind === 267 /* ModuleDeclaration */;
     }
     function isTransformedEnumDeclaration(node) {
-      return getOriginalNode(node).kind === 265 /* EnumDeclaration */;
+      return getOriginalNode(node).kind === 266 /* EnumDeclaration */;
     }
     function onEmitNode(hint, node, emitCallback) {
       const savedApplicableSubstitutions = applicableSubstitutions;
@@ -189799,9 +174250,9 @@ ${lanes.join("\n")}
       switch (node.kind) {
         case 80 /* Identifier */:
           return substituteExpressionIdentifier(node);
-        case 210 /* PropertyAccessExpression */:
+        case 211 /* PropertyAccessExpression */:
           return substitutePropertyAccessExpression(node);
-        case 211 /* ElementAccessExpression */:
+        case 212 /* ElementAccessExpression */:
           return substituteElementAccessExpression(node);
       }
       return node;
@@ -189816,8 +174267,8 @@ ${lanes.join("\n")}
           /*prefixLocals*/
           false
         );
-        if (container && container.kind !== 311 /* SourceFile */) {
-          const substitute = applicableSubstitutions & 2 /* NamespaceExports */ && container.kind === 266 /* ModuleDeclaration */ || applicableSubstitutions & 8 /* NonQualifiedEnumMembers */ && container.kind === 265 /* EnumDeclaration */;
+        if (container && container.kind !== 312 /* SourceFile */) {
+          const substitute = applicableSubstitutions & 2 /* NamespaceExports */ && container.kind === 267 /* ModuleDeclaration */ || applicableSubstitutions & 8 /* NonQualifiedEnumMembers */ && container.kind === 266 /* EnumDeclaration */;
           if (substitute) {
             return setTextRange(
               factory2.createPropertyAccessExpression(factory2.getGeneratedNameForNode(container), node),
@@ -189842,7 +174293,7 @@ ${lanes.join("\n")}
       const constantValue = tryGetConstEnumValue(node);
       if (constantValue !== void 0) {
         setConstantValue(node, constantValue);
-        const substitute = typeof constantValue === "string" ? factory2.createStringLiteral(constantValue) : factory2.createNumericLiteral(constantValue);
+        const substitute = typeof constantValue === "string" ? factory2.createStringLiteral(constantValue) : constantValue < 0 ? factory2.createPrefixUnaryExpression(41 /* MinusToken */, factory2.createNumericLiteral(Math.abs(constantValue))) : factory2.createNumericLiteral(constantValue);
         if (!compilerOptions.removeComments) {
           const originalNode = getOriginalNode(node, isAccessExpression);
           addSyntheticTrailingComment(substitute, 3 /* MultiLineCommentTrivia */, ` ${safeMultiLineComment(getTextOfNode(originalNode))} `);
@@ -189905,8 +174356,9 @@ ${lanes.join("\n")}
     let pendingStatements;
     let lexicalEnvironment;
     const lexicalEnvironmentMap = /* @__PURE__ */ new Map();
+    const noSubstitution = /* @__PURE__ */ new Set();
     let currentClassContainer;
-    let currentStaticPropertyDeclarationOrStaticBlock;
+    let currentClassElement;
     let shouldSubstituteThisWithClassThis = false;
     let previousShouldSubstituteThisWithClassThis = false;
     return chainBundle(context, transformSourceFile);
@@ -189938,76 +174390,77 @@ ${lanes.join("\n")}
       switch (node.kind) {
         case 129 /* AccessorKeyword */:
           return Debug.fail("Use `modifierVisitor` instead.");
-        case 262 /* ClassDeclaration */:
+        case 263 /* ClassDeclaration */:
           return visitClassDeclaration(node);
-        case 230 /* ClassExpression */:
-          return visitClassExpression(
-            node,
-            /*referencedName*/
-            void 0
-          );
-        case 174 /* ClassStaticBlockDeclaration */:
-        case 171 /* PropertyDeclaration */:
+        case 231 /* ClassExpression */:
+          return visitClassExpression(node);
+        case 175 /* ClassStaticBlockDeclaration */:
+        case 172 /* PropertyDeclaration */:
           return Debug.fail("Use `classElementVisitor` instead.");
-        case 302 /* PropertyAssignment */:
+        case 303 /* PropertyAssignment */:
           return visitPropertyAssignment(node);
-        case 242 /* VariableStatement */:
+        case 243 /* VariableStatement */:
           return visitVariableStatement(node);
-        case 259 /* VariableDeclaration */:
+        case 260 /* VariableDeclaration */:
           return visitVariableDeclaration(node);
-        case 168 /* Parameter */:
+        case 169 /* Parameter */:
           return visitParameterDeclaration(node);
-        case 207 /* BindingElement */:
+        case 208 /* BindingElement */:
           return visitBindingElement(node);
-        case 276 /* ExportAssignment */:
+        case 277 /* ExportAssignment */:
           return visitExportAssignment(node);
         case 81 /* PrivateIdentifier */:
           return visitPrivateIdentifier(node);
-        case 210 /* PropertyAccessExpression */:
+        case 211 /* PropertyAccessExpression */:
           return visitPropertyAccessExpression(node);
-        case 211 /* ElementAccessExpression */:
+        case 212 /* ElementAccessExpression */:
           return visitElementAccessExpression(node);
-        case 223 /* PrefixUnaryExpression */:
-        case 224 /* PostfixUnaryExpression */:
+        case 224 /* PrefixUnaryExpression */:
+        case 225 /* PostfixUnaryExpression */:
           return visitPreOrPostfixUnaryExpression(
             node,
             /*discarded*/
             false
           );
-        case 225 /* BinaryExpression */:
+        case 226 /* BinaryExpression */:
           return visitBinaryExpression(
             node,
             /*discarded*/
             false
           );
-        case 216 /* ParenthesizedExpression */:
+        case 217 /* ParenthesizedExpression */:
           return visitParenthesizedExpression(
             node,
             /*discarded*/
-            false,
-            /*referencedName*/
-            void 0
+            false
           );
-        case 212 /* CallExpression */:
+        case 213 /* CallExpression */:
           return visitCallExpression(node);
-        case 243 /* ExpressionStatement */:
+        case 244 /* ExpressionStatement */:
           return visitExpressionStatement(node);
-        case 214 /* TaggedTemplateExpression */:
+        case 215 /* TaggedTemplateExpression */:
           return visitTaggedTemplateExpression(node);
-        case 247 /* ForStatement */:
+        case 248 /* ForStatement */:
           return visitForStatement(node);
-        case 261 /* FunctionDeclaration */:
-        case 217 /* FunctionExpression */:
-        case 175 /* Constructor */:
-        case 173 /* MethodDeclaration */:
-        case 176 /* GetAccessor */:
-        case 177 /* SetAccessor */: {
-          return setCurrentStaticPropertyDeclarationOrStaticBlockAnd(
-            /*current*/
+        case 110 /* ThisKeyword */:
+          return visitThisExpression(node);
+        case 262 /* FunctionDeclaration */:
+        case 218 /* FunctionExpression */:
+          return setCurrentClassElementAnd(
+            /*classElement*/
             void 0,
             fallbackVisitor,
             node
           );
+        case 176 /* Constructor */:
+        case 174 /* MethodDeclaration */:
+        case 177 /* GetAccessor */:
+        case 178 /* SetAccessor */: {
+          return setCurrentClassElementAnd(
+            node,
+            fallbackVisitor,
+            node
+          );
         }
         default:
           return fallbackVisitor(node);
@@ -190016,56 +174469,32 @@ ${lanes.join("\n")}
     function fallbackVisitor(node) {
       return visitEachChild(node, visitor, context);
     }
-    function namedEvaluationVisitor(node, referencedName) {
-      switch (node.kind) {
-        case 359 /* PartiallyEmittedExpression */:
-          return visitPartiallyEmittedExpression(
-            node,
-            /*discarded*/
-            false,
-            referencedName
-          );
-        case 216 /* ParenthesizedExpression */:
-          return visitParenthesizedExpression(
-            node,
-            /*discarded*/
-            false,
-            referencedName
-          );
-        case 230 /* ClassExpression */:
-          return visitClassExpression(node, referencedName);
-        default:
-          return visitor(node);
-      }
-    }
     function discardedValueVisitor(node) {
       switch (node.kind) {
-        case 223 /* PrefixUnaryExpression */:
-        case 224 /* PostfixUnaryExpression */:
+        case 224 /* PrefixUnaryExpression */:
+        case 225 /* PostfixUnaryExpression */:
           return visitPreOrPostfixUnaryExpression(
             node,
             /*discarded*/
             true
           );
-        case 225 /* BinaryExpression */:
+        case 226 /* BinaryExpression */:
           return visitBinaryExpression(
             node,
             /*discarded*/
             true
           );
-        case 360 /* CommaListExpression */:
+        case 361 /* CommaListExpression */:
           return visitCommaListExpression(
             node,
             /*discarded*/
             true
           );
-        case 216 /* ParenthesizedExpression */:
+        case 217 /* ParenthesizedExpression */:
           return visitParenthesizedExpression(
             node,
             /*discarded*/
-            true,
-            /*referencedName*/
-            void 0
+            true
           );
         default:
           return visitor(node);
@@ -190073,9 +174502,9 @@ ${lanes.join("\n")}
     }
     function heritageClauseVisitor(node) {
       switch (node.kind) {
-        case 297 /* HeritageClause */:
+        case 298 /* HeritageClause */:
           return visitEachChild(node, heritageClauseVisitor, context);
-        case 232 /* ExpressionWithTypeArguments */:
+        case 233 /* ExpressionWithTypeArguments */:
           return visitExpressionWithTypeArgumentsInHeritageClause(node);
         default:
           return visitor(node);
@@ -190083,8 +174512,8 @@ ${lanes.join("\n")}
     }
     function assignmentTargetVisitor(node) {
       switch (node.kind) {
-        case 209 /* ObjectLiteralExpression */:
-        case 208 /* ArrayLiteralExpression */:
+        case 210 /* ObjectLiteralExpression */:
+        case 209 /* ArrayLiteralExpression */:
           return visitAssignmentPattern(node);
         default:
           return visitor(node);
@@ -190092,29 +174521,35 @@ ${lanes.join("\n")}
     }
     function classElementVisitor(node) {
       switch (node.kind) {
-        case 175 /* Constructor */:
-          return visitConstructorDeclaration(node);
-        case 176 /* GetAccessor */:
-        case 177 /* SetAccessor */:
-        case 173 /* MethodDeclaration */:
-          return setCurrentStaticPropertyDeclarationOrStaticBlockAnd(
-            /*current*/
-            void 0,
+        case 176 /* Constructor */:
+          return setCurrentClassElementAnd(
+            node,
+            visitConstructorDeclaration,
+            node
+          );
+        case 177 /* GetAccessor */:
+        case 178 /* SetAccessor */:
+        case 174 /* MethodDeclaration */:
+          return setCurrentClassElementAnd(
+            node,
             visitMethodOrAccessorDeclaration,
             node
           );
-        case 171 /* PropertyDeclaration */:
-          return setCurrentStaticPropertyDeclarationOrStaticBlockAnd(
-            /*current*/
-            void 0,
+        case 172 /* PropertyDeclaration */:
+          return setCurrentClassElementAnd(
+            node,
             visitPropertyDeclaration,
             node
           );
-        case 174 /* ClassStaticBlockDeclaration */:
-          return visitClassStaticBlockDeclaration(node);
-        case 166 /* ComputedPropertyName */:
+        case 175 /* ClassStaticBlockDeclaration */:
+          return setCurrentClassElementAnd(
+            node,
+            visitClassStaticBlockDeclaration,
+            node
+          );
+        case 167 /* ComputedPropertyName */:
           return visitComputedPropertyName(node);
-        case 239 /* SemicolonClassElement */:
+        case 240 /* SemicolonClassElement */:
           return node;
         default:
           return isModifierLike(node) ? modifierVisitor(node) : visitor(node);
@@ -190122,7 +174557,7 @@ ${lanes.join("\n")}
     }
     function propertyNameVisitor(node) {
       switch (node.kind) {
-        case 166 /* ComputedPropertyName */:
+        case 167 /* ComputedPropertyName */:
           return visitComputedPropertyName(node);
         default:
           return visitor(node);
@@ -190130,10 +174565,10 @@ ${lanes.join("\n")}
     }
     function accessorFieldResultVisitor(node) {
       switch (node.kind) {
-        case 171 /* PropertyDeclaration */:
+        case 172 /* PropertyDeclaration */:
           return transformFieldInitializer(node);
-        case 176 /* GetAccessor */:
-        case 177 /* SetAccessor */:
+        case 177 /* GetAccessor */:
+        case 178 /* SetAccessor */:
           return classElementVisitor(node);
         default:
           Debug.assertMissingNode(node, "Expected node to either be a PropertyDeclaration, GetAccessorDeclaration, or SetAccessorDeclaration");
@@ -190162,9 +174597,7 @@ ${lanes.join("\n")}
     }
     function visitPropertyAssignment(node) {
       if (isNamedEvaluation(node, isAnonymousClassNeedingAssignedName)) {
-        const { referencedName, name } = visitReferencedPropertyName(node.name);
-        const initializer = visitNode(node.initializer, (node2) => namedEvaluationVisitor(node2, referencedName), isExpression);
-        return factory2.updatePropertyAssignment(node, name, initializer);
+        node = transformNamedEvaluation(context, node);
       }
       return visitEachChild(node, visitor, context);
     }
@@ -190176,71 +174609,33 @@ ${lanes.join("\n")}
       pendingStatements = savedPendingStatements;
       return statement;
     }
-    function getAssignedNameOfIdentifier(name, initializer) {
-      const originalClass = getOriginalNode(initializer, isClassLike);
-      return originalClass && !originalClass.name && hasSyntacticModifier(originalClass, 1024 /* Default */) ? factory2.createStringLiteral("default") : factory2.createStringLiteralFromNode(name);
-    }
     function visitVariableDeclaration(node) {
       if (isNamedEvaluation(node, isAnonymousClassNeedingAssignedName)) {
-        const assignedName = getAssignedNameOfIdentifier(node.name, node.initializer);
-        const name = visitNode(node.name, visitor, isBindingName);
-        const initializer = visitNode(node.initializer, (node2) => namedEvaluationVisitor(node2, assignedName), isExpression);
-        return factory2.updateVariableDeclaration(
-          node,
-          name,
-          /*exclamationToken*/
-          void 0,
-          /*type*/
-          void 0,
-          initializer
-        );
+        node = transformNamedEvaluation(context, node);
       }
       return visitEachChild(node, visitor, context);
     }
     function visitParameterDeclaration(node) {
       if (isNamedEvaluation(node, isAnonymousClassNeedingAssignedName)) {
-        const assignedName = getAssignedNameOfIdentifier(node.name, node.initializer);
-        const name = visitNode(node.name, visitor, isBindingName);
-        const initializer = visitNode(node.initializer, (node2) => namedEvaluationVisitor(node2, assignedName), isExpression);
-        return factory2.updateParameterDeclaration(
-          node,
-          /*modifiers*/
-          void 0,
-          /*dotDotDotToken*/
-          void 0,
-          name,
-          /*questionToken*/
-          void 0,
-          /*type*/
-          void 0,
-          initializer
-        );
+        node = transformNamedEvaluation(context, node);
       }
       return visitEachChild(node, visitor, context);
     }
     function visitBindingElement(node) {
       if (isNamedEvaluation(node, isAnonymousClassNeedingAssignedName)) {
-        const assignedName = getAssignedNameOfIdentifier(node.name, node.initializer);
-        const propertyName = visitNode(node.propertyName, visitor, isPropertyName);
-        const name = visitNode(node.name, visitor, isBindingName);
-        const initializer = visitNode(node.initializer, (node2) => namedEvaluationVisitor(node2, assignedName), isExpression);
-        return factory2.updateBindingElement(
-          node,
-          /*dotDotDotToken*/
-          void 0,
-          propertyName,
-          name,
-          initializer
-        );
+        node = transformNamedEvaluation(context, node);
       }
       return visitEachChild(node, visitor, context);
     }
     function visitExportAssignment(node) {
       if (isNamedEvaluation(node, isAnonymousClassNeedingAssignedName)) {
-        const assignedName = factory2.createStringLiteral(node.isExportEquals ? "" : "default");
-        const modifiers = visitNodes2(node.modifiers, modifierVisitor, isModifier);
-        const expression = visitNode(node.expression, (node2) => namedEvaluationVisitor(node2, assignedName), isExpression);
-        return factory2.updateExportAssignment(node, modifiers, expression);
+        node = transformNamedEvaluation(
+          context,
+          node,
+          /*ignoreEmptyStringLiteral*/
+          true,
+          node.isExportEquals ? "" : "default"
+        );
       }
       return visitEachChild(node, visitor, context);
     }
@@ -190305,12 +174700,15 @@ ${lanes.join("\n")}
       }
       return void 0;
     }
-    function setCurrentStaticPropertyDeclarationOrStaticBlockAnd(current, visitor2, arg) {
-      const savedCurrentStaticPropertyDeclarationOrStaticBlock = currentStaticPropertyDeclarationOrStaticBlock;
-      currentStaticPropertyDeclarationOrStaticBlock = current;
-      const result = visitor2(arg);
-      currentStaticPropertyDeclarationOrStaticBlock = savedCurrentStaticPropertyDeclarationOrStaticBlock;
-      return result;
+    function setCurrentClassElementAnd(classElement, visitor2, arg) {
+      if (classElement !== currentClassElement) {
+        const savedCurrentClassElement = currentClassElement;
+        currentClassElement = classElement;
+        const result = visitor2(arg);
+        currentClassElement = savedCurrentClassElement;
+        return result;
+      }
+      return visitor2(arg);
     }
     function getHoistedFunctionName(node) {
       Debug.assert(isPrivateIdentifier(node.name));
@@ -190328,6 +174726,11 @@ ${lanes.join("\n")}
         }
       }
     }
+    function getClassThis() {
+      const lex = getClassLexicalEnvironment();
+      const classThis = lex.classThis ?? lex.classConstructor ?? (currentClassContainer == null ? void 0 : currentClassContainer.name);
+      return Debug.checkDefined(classThis);
+    }
     function transformAutoAccessor(node) {
       const commentRange = getCommentRange(node);
       const sourceMapRange = getSourceMapRange(node);
@@ -190354,11 +174757,13 @@ ${lanes.join("\n")}
       setOriginalNode(backingField, node);
       setEmitFlags(backingField, 3072 /* NoComments */);
       setSourceMapRange(backingField, sourceMapRange);
-      const getter = createAccessorPropertyGetRedirector(factory2, node, modifiers, getterName);
+      const receiver = isStatic(node) ? getClassThis() : factory2.createThis();
+      const getter = createAccessorPropertyGetRedirector(factory2, node, modifiers, getterName, receiver);
       setOriginalNode(getter, node);
       setCommentRange(getter, commentRange);
       setSourceMapRange(getter, sourceMapRange);
-      const setter = createAccessorPropertySetRedirector(factory2, node, modifiers, setterName);
+      const setterModifiers = factory2.createModifiersFromModifierFlags(modifiersToFlags(modifiers));
+      const setter = createAccessorPropertySetRedirector(factory2, node, setterModifiers, setterName, receiver);
       setOriginalNode(setter, node);
       setEmitFlags(setter, 3072 /* NoComments */);
       setSourceMapRange(setter, sourceMapRange);
@@ -190397,17 +174802,7 @@ ${lanes.join("\n")}
         );
       }
       if (isNamedEvaluation(node, isAnonymousClassNeedingAssignedName)) {
-        const { referencedName, name } = visitReferencedPropertyName(node.name);
-        return factory2.updatePropertyDeclaration(
-          node,
-          visitNodes2(node.modifiers, modifierVisitor, isModifier),
-          name,
-          /*questionOrExclamationToken*/
-          void 0,
-          /*type*/
-          void 0,
-          visitNode(node.initializer, (child) => namedEvaluationVisitor(child, referencedName), isExpression)
-        );
+        node = transformNamedEvaluation(context, node);
       }
       return factory2.updatePropertyDeclaration(
         node,
@@ -190425,9 +174820,7 @@ ${lanes.join("\n")}
         const expr = getPropertyNameExpressionIfNeeded(
           node.name,
           /*shouldHoist*/
-          !!node.initializer || useDefineForClassFields,
-          /*captureReferencedName*/
-          isNamedEvaluation(node, isAnonymousClassNeedingAssignedName)
+          !!node.initializer || useDefineForClassFields
         );
         if (expr) {
           getPendingExpressions().push(...flattenCommaList(expr));
@@ -190472,8 +174865,21 @@ ${lanes.join("\n")}
       }
       return transformFieldInitializer(node);
     }
+    function shouldForceDynamicThis() {
+      return !!currentClassElement && hasStaticModifier(currentClassElement) && isAccessor(currentClassElement) && isAutoAccessorPropertyDeclaration(getOriginalNode(currentClassElement));
+    }
+    function ensureDynamicThisIfNeeded(node) {
+      if (shouldForceDynamicThis()) {
+        const innerExpression = skipOuterExpressions(node);
+        if (innerExpression.kind === 110 /* ThisKeyword */) {
+          noSubstitution.add(innerExpression);
+        }
+      }
+    }
     function createPrivateIdentifierAccess(info, receiver) {
-      return createPrivateIdentifierAccessHelper(info, visitNode(receiver, visitor, isExpression));
+      receiver = visitNode(receiver, visitor, isExpression);
+      ensureDynamicThisIfNeeded(receiver);
+      return createPrivateIdentifierAccessHelper(info, receiver);
     }
     function createPrivateIdentifierAccessHelper(info, receiver) {
       setCommentRange(receiver, moveRangePos(receiver, -1));
@@ -190518,7 +174924,7 @@ ${lanes.join("\n")}
           );
         }
       }
-      if (shouldTransformSuperInStaticInitializers && isSuperProperty(node) && isIdentifier(node.name) && currentStaticPropertyDeclarationOrStaticBlock && (lexicalEnvironment == null ? void 0 : lexicalEnvironment.data)) {
+      if (shouldTransformSuperInStaticInitializers && currentClassElement && isSuperProperty(node) && isIdentifier(node.name) && isStaticPropertyDeclarationOrClassStaticBlock(currentClassElement) && (lexicalEnvironment == null ? void 0 : lexicalEnvironment.data)) {
         const { classConstructor, superClassReference, facts } = lexicalEnvironment.data;
         if (facts & 1 /* ClassWasDecorated */) {
           return visitInvalidSuperProperty(node);
@@ -190537,7 +174943,7 @@ ${lanes.join("\n")}
       return visitEachChild(node, visitor, context);
     }
     function visitElementAccessExpression(node) {
-      if (shouldTransformSuperInStaticInitializers && isSuperProperty(node) && currentStaticPropertyDeclarationOrStaticBlock && (lexicalEnvironment == null ? void 0 : lexicalEnvironment.data)) {
+      if (shouldTransformSuperInStaticInitializers && currentClassElement && isSuperProperty(node) && isStaticPropertyDeclarationOrClassStaticBlock(currentClassElement) && (lexicalEnvironment == null ? void 0 : lexicalEnvironment.data)) {
         const { classConstructor, superClassReference, facts } = lexicalEnvironment.data;
         if (facts & 1 /* ClassWasDecorated */) {
           return visitInvalidSuperProperty(node);
@@ -190562,6 +174968,7 @@ ${lanes.join("\n")}
           let info;
           if (info = accessPrivateIdentifier2(operand.name)) {
             const receiver = visitNode(operand.expression, visitor, isExpression);
+            ensureDynamicThisIfNeeded(receiver);
             const { readExpression, initializeExpression } = createCopiableReceiverExpr(receiver);
             let expression = createPrivateIdentifierAccess(info, readExpression);
             const temp = isPrefixUnaryExpression(node) || discarded ? void 0 : factory2.createTempVariable(hoistVariableDeclaration);
@@ -190580,7 +174987,7 @@ ${lanes.join("\n")}
             }
             return expression;
           }
-        } else if (shouldTransformSuperInStaticInitializers && isSuperProperty(operand) && currentStaticPropertyDeclarationOrStaticBlock && (lexicalEnvironment == null ? void 0 : lexicalEnvironment.data)) {
+        } else if (shouldTransformSuperInStaticInitializers && currentClassElement && isSuperProperty(operand) && isStaticPropertyDeclarationOrClassStaticBlock(currentClassElement) && (lexicalEnvironment == null ? void 0 : lexicalEnvironment.data)) {
           const { classConstructor, superClassReference, facts } = lexicalEnvironment.data;
           if (facts & 1 /* ClassWasDecorated */) {
             const expression = visitInvalidSuperProperty(operand);
@@ -190637,6 +175044,9 @@ ${lanes.join("\n")}
     }
     function createCopiableReceiverExpr(receiver) {
       const clone2 = nodeIsSynthesized(receiver) ? receiver : factory2.cloneNode(receiver);
+      if (receiver.kind === 110 /* ThisKeyword */ && noSubstitution.has(receiver)) {
+        noSubstitution.add(clone2);
+      }
       if (isSimpleInlineableExpression(receiver)) {
         return { readExpression: clone2, initializeExpression: void 0 };
       }
@@ -190667,7 +175077,7 @@ ${lanes.join("\n")}
           [visitNode(thisArg, visitor, isExpression), ...visitNodes2(node.arguments, visitor, isExpression)]
         );
       }
-      if (shouldTransformSuperInStaticInitializers && isSuperProperty(node.expression) && currentStaticPropertyDeclarationOrStaticBlock && ((_a = lexicalEnvironment == null ? void 0 : lexicalEnvironment.data) == null ? void 0 : _a.classConstructor)) {
+      if (shouldTransformSuperInStaticInitializers && currentClassElement && isSuperProperty(node.expression) && isStaticPropertyDeclarationOrClassStaticBlock(currentClassElement) && ((_a = lexicalEnvironment == null ? void 0 : lexicalEnvironment.data) == null ? void 0 : _a.classConstructor)) {
         const invocation = factory2.createFunctionCallCall(
           visitNode(node.expression, visitor, isExpression),
           lexicalEnvironment.data.classConstructor,
@@ -190696,7 +175106,7 @@ ${lanes.join("\n")}
           visitNode(node.template, visitor, isTemplateLiteral)
         );
       }
-      if (shouldTransformSuperInStaticInitializers && isSuperProperty(node.tag) && currentStaticPropertyDeclarationOrStaticBlock && ((_a = lexicalEnvironment == null ? void 0 : lexicalEnvironment.data) == null ? void 0 : _a.classConstructor)) {
+      if (shouldTransformSuperInStaticInitializers && currentClassElement && isSuperProperty(node.tag) && isStaticPropertyDeclarationOrClassStaticBlock(currentClassElement) && ((_a = lexicalEnvironment == null ? void 0 : lexicalEnvironment.data) == null ? void 0 : _a.classConstructor)) {
         const invocation = factory2.createFunctionBindCall(
           visitNode(node.tag, visitor, isExpression),
           lexicalEnvironment.data.classConstructor,
@@ -190719,30 +175129,40 @@ ${lanes.join("\n")}
         lexicalEnvironmentMap.set(getOriginalNode(node), lexicalEnvironment);
       }
       if (shouldTransformPrivateElementsOrClassStaticBlocks) {
+        if (isClassThisAssignmentBlock(node)) {
+          const result = visitNode(node.body.statements[0].expression, visitor, isExpression);
+          if (isAssignmentExpression(
+            result,
+            /*excludeCompoundAssignment*/
+            true
+          ) && result.left === result.right) {
+            return void 0;
+          }
+          return result;
+        }
+        if (isClassNamedEvaluationHelperBlock(node)) {
+          return visitNode(node.body.statements[0].expression, visitor, isExpression);
+        }
         startLexicalEnvironment();
-        let statements = setCurrentStaticPropertyDeclarationOrStaticBlockAnd(
+        let statements = setCurrentClassElementAnd(
           node,
           (statements2) => visitNodes2(statements2, visitor, isStatement),
           node.body.statements
         );
         statements = factory2.mergeLexicalEnvironment(statements, endLexicalEnvironment());
         const iife = factory2.createImmediatelyInvokedArrowFunction(statements);
+        setOriginalNode(skipParentheses(iife.expression), node);
+        addEmitFlags(skipParentheses(iife.expression), 4 /* AdviseOnEmitNode */);
         setOriginalNode(iife, node);
         setTextRange(iife, node);
-        addEmitFlags(iife, 4 /* AdviseOnEmitNode */);
         return iife;
       }
     }
     function isAnonymousClassNeedingAssignedName(node) {
       if (isClassExpression(node) && !node.name) {
         const staticPropertiesOrClassStaticBlocks = getStaticPropertiesAndClassStaticBlock(node);
-        const classStaticBlock = find(staticPropertiesOrClassStaticBlocks, isClassStaticBlockDeclaration);
-        if (classStaticBlock) {
-          for (const statement of classStaticBlock.body.statements) {
-            if (isExpressionStatement(statement) && isCallToHelper(statement.expression, "___setFunctionName")) {
-              return false;
-            }
-          }
+        if (some(staticPropertiesOrClassStaticBlocks, isClassNamedEvaluationHelperBlock)) {
+          return false;
         }
         const hasTransformableStatics = (shouldTransformPrivateElementsOrClassStaticBlocks || !!(getInternalEmitFlags(node) && 32 /* TransformPrivateStaticElements */)) && some(staticPropertiesOrClassStaticBlocks, (node2) => isClassStaticBlockDeclaration(node2) || isPrivateIdentifierClassElementDeclaration(node2) || shouldTransformInitializers && isInitializedProperty(node2));
         return hasTransformableStatics;
@@ -190765,10 +175185,8 @@ ${lanes.join("\n")}
       }
       if (isAssignmentExpression(node)) {
         if (isNamedEvaluation(node, isAnonymousClassNeedingAssignedName)) {
-          const assignedName = getAssignedNameOfIdentifier(node.left, node.right);
-          const left2 = visitNode(node.left, visitor, isExpression);
-          const right = visitNode(node.right, (node2) => namedEvaluationVisitor(node2, assignedName), isExpression);
-          return factory2.updateBinaryExpression(node, left2, node.operatorToken, right);
+          node = transformNamedEvaluation(context, node);
+          Debug.assertNode(node, isAssignmentExpression);
         }
         const left = skipOuterExpressions(node.left, 8 /* PartiallyEmittedExpressions */ | 1 /* Parentheses */);
         if (isPrivateIdentifierPropertyAccessExpression(left)) {
@@ -190782,7 +175200,7 @@ ${lanes.join("\n")}
               node
             );
           }
-        } else if (shouldTransformSuperInStaticInitializers && isSuperProperty(node.left) && currentStaticPropertyDeclarationOrStaticBlock && (lexicalEnvironment == null ? void 0 : lexicalEnvironment.data)) {
+        } else if (shouldTransformSuperInStaticInitializers && currentClassElement && isSuperProperty(node.left) && isStaticPropertyDeclarationOrClassStaticBlock(currentClassElement) && (lexicalEnvironment == null ? void 0 : lexicalEnvironment.data)) {
           const { classConstructor, superClassReference, facts } = lexicalEnvironment.data;
           if (facts & 1 /* ClassWasDecorated */) {
             return factory2.updateBinaryExpression(
@@ -190847,36 +175265,15 @@ ${lanes.join("\n")}
       const elements = discarded ? visitCommaListElements(node.elements, discardedValueVisitor) : visitCommaListElements(node.elements, visitor, discardedValueVisitor);
       return factory2.updateCommaListExpression(node, elements);
     }
-    function visitParenthesizedExpression(node, discarded, referencedName) {
-      const visitorFunc = discarded ? discardedValueVisitor : referencedName ? (node2) => namedEvaluationVisitor(node2, referencedName) : visitor;
+    function visitParenthesizedExpression(node, discarded) {
+      const visitorFunc = discarded ? discardedValueVisitor : visitor;
       const expression = visitNode(node.expression, visitorFunc, isExpression);
       return factory2.updateParenthesizedExpression(node, expression);
     }
-    function visitPartiallyEmittedExpression(node, discarded, referencedName) {
-      const visitorFunc = discarded ? discardedValueVisitor : referencedName ? (node2) => namedEvaluationVisitor(node2, referencedName) : visitor;
-      const expression = visitNode(node.expression, visitorFunc, isExpression);
-      return factory2.updatePartiallyEmittedExpression(node, expression);
-    }
-    function visitReferencedPropertyName(node) {
-      if (isPropertyNameLiteral(node) || isPrivateIdentifier(node)) {
-        const referencedName2 = factory2.createStringLiteralFromNode(node);
-        const name2 = visitNode(node, visitor, isPropertyName);
-        return { referencedName: referencedName2, name: name2 };
-      }
-      if (isPropertyNameLiteral(node.expression) && !isIdentifier(node.expression)) {
-        const referencedName2 = factory2.createStringLiteralFromNode(node.expression);
-        const name2 = visitNode(node, visitor, isPropertyName);
-        return { referencedName: referencedName2, name: name2 };
-      }
-      const referencedName = factory2.createTempVariable(hoistVariableDeclaration);
-      const key = emitHelpers().createPropKeyHelper(visitNode(node.expression, visitor, isExpression));
-      const assignment = factory2.createAssignment(referencedName, key);
-      const name = factory2.updateComputedPropertyName(node, injectPendingExpressions(assignment));
-      return { referencedName, name };
-    }
     function createPrivateIdentifierAssignment(info, receiver, right, operator) {
       receiver = visitNode(receiver, visitor, isExpression);
       right = visitNode(right, visitor, isExpression);
+      ensureDynamicThisIfNeeded(receiver);
       if (isCompoundAssignment(operator)) {
         const { readExpression, initializeExpression } = createCopiableReceiverExpr(receiver);
         receiver = initializeExpression || readExpression;
@@ -190923,11 +175320,15 @@ ${lanes.join("\n")}
       return filter(node.members, isNonStaticMethodOrAccessorWithPrivateName);
     }
     function getClassFacts(node) {
+      var _a;
       let facts = 0 /* None */;
       const original = getOriginalNode(node);
       if (isClassDeclaration(original) && classOrConstructorParameterIsDecorated(legacyDecorators, original)) {
         facts |= 1 /* ClassWasDecorated */;
       }
+      if (shouldTransformPrivateElementsOrClassStaticBlocks && (classHasClassThisAssignment(node) || classHasExplicitlyAssignedName(node))) {
+        facts |= 2 /* NeedsClassConstructorReference */;
+      }
       let containsPublicInstanceFields = false;
       let containsInitializedPublicInstanceFields = false;
       let containsInstancePrivateElements = false;
@@ -190936,6 +175337,8 @@ ${lanes.join("\n")}
         if (isStatic(member)) {
           if (member.name && (isPrivateIdentifier(member.name) || isAutoAccessorPropertyDeclaration(member)) && shouldTransformPrivateElementsOrClassStaticBlocks) {
             facts |= 2 /* NeedsClassConstructorReference */;
+          } else if (isAutoAccessorPropertyDeclaration(member) && shouldTransformAutoAccessors === -1 /* True */ && !node.name && !((_a = node.emitNode) == null ? void 0 : _a.classThis)) {
+            facts |= 2 /* NeedsClassConstructorReference */;
           }
           if (isPropertyDeclaration(member) || isClassStaticBlockDeclaration(member)) {
             if (shouldTransformThisInStaticInitializers && member.transformFlags & 16384 /* ContainsLexicalThis */) {
@@ -190956,6 +175359,9 @@ ${lanes.join("\n")}
             containsInstancePrivateElements || (containsInstancePrivateElements = isPrivateIdentifierClassElementDeclaration(member));
           } else if (isPrivateIdentifierClassElementDeclaration(member)) {
             containsInstancePrivateElements = true;
+            if (resolver.getNodeCheckFlags(member) & 262144 /* ContainsConstructorReference */) {
+              facts |= 2 /* NeedsClassConstructorReference */;
+            }
           } else if (isPropertyDeclaration(member)) {
             containsPublicInstanceFields = true;
             containsInitializedPublicInstanceFields || (containsInitializedPublicInstanceFields = !!member.initializer);
@@ -190990,7 +175396,8 @@ ${lanes.join("\n")}
       }
       return visitEachChild(node, visitor, context);
     }
-    function visitInNewClassLexicalEnvironment(node, referencedName, visitor2) {
+    function visitInNewClassLexicalEnvironment(node, visitor2) {
+      var _a;
       const savedCurrentClassContainer = currentClassContainer;
       const savedPendingExpressions = pendingExpressions;
       const savedLexicalEnvironment = lexicalEnvironment;
@@ -191002,6 +175409,15 @@ ${lanes.join("\n")}
         const name = getNameOfDeclaration(node);
         if (name && isIdentifier(name)) {
           getPrivateIdentifierEnvironment().data.className = name;
+        } else if ((_a = node.emitNode) == null ? void 0 : _a.assignedName) {
+          if (isStringLiteral(node.emitNode.assignedName)) {
+            if (node.emitNode.assignedName.textSourceNode && isIdentifier(node.emitNode.assignedName.textSourceNode)) {
+              getPrivateIdentifierEnvironment().data.className = node.emitNode.assignedName.textSourceNode;
+            } else if (isIdentifierText(node.emitNode.assignedName.text, languageVersion)) {
+              const prefixName = factory2.createIdentifier(node.emitNode.assignedName.text);
+              getPrivateIdentifierEnvironment().data.className = prefixName;
+            }
+          }
         }
       }
       if (shouldTransformPrivateElementsOrClassStaticBlocks) {
@@ -191020,7 +175436,7 @@ ${lanes.join("\n")}
       if (facts & 8 /* NeedsSubstitutionForThisInClassStaticField */) {
         enableSubstitutionForClassStaticThisOrSuperReference();
       }
-      const result = visitor2(node, facts, referencedName);
+      const result = visitor2(node, facts);
       endClassLexicalEnvironment();
       Debug.assert(lexicalEnvironment === savedLexicalEnvironment);
       currentClassContainer = savedCurrentClassContainer;
@@ -191028,12 +175444,7 @@ ${lanes.join("\n")}
       return result;
     }
     function visitClassDeclaration(node) {
-      return visitInNewClassLexicalEnvironment(
-        node,
-        /*referencedName*/
-        void 0,
-        visitClassDeclarationInNewClassLexicalEnvironment
-      );
+      return visitInNewClassLexicalEnvironment(node, visitClassDeclarationInNewClassLexicalEnvironment);
     }
     function visitClassDeclarationInNewClassLexicalEnvironment(node, facts) {
       var _a, _b;
@@ -191051,12 +175462,13 @@ ${lanes.join("\n")}
           getClassLexicalEnvironment().classConstructor = factory2.cloneNode(temp);
           pendingClassReferenceAssignment = factory2.createAssignment(temp, factory2.getInternalName(node));
         }
-        if ((_b = node.emitNode) == null ? void 0 : _b.classThis) {
-          getClassLexicalEnvironment().classThis = node.emitNode.classThis;
-        }
       }
-      const isExport = hasSyntacticModifier(node, 1 /* Export */);
-      const isDefault = hasSyntacticModifier(node, 1024 /* Default */);
+      if ((_b = node.emitNode) == null ? void 0 : _b.classThis) {
+        getClassLexicalEnvironment().classThis = node.emitNode.classThis;
+      }
+      const isClassWithConstructorReference = resolver.getNodeCheckFlags(node) & 262144 /* ContainsConstructorReference */;
+      const isExport = hasSyntacticModifier(node, 32 /* Export */);
+      const isDefault = hasSyntacticModifier(node, 2048 /* Default */);
       let modifiers = visitNodes2(node.modifiers, modifierVisitor, isModifier);
       const heritageClauses = visitNodes2(node.heritageClauses, heritageClauseVisitor, isHeritageClause);
       const { members, prologue } = transformClassMembers(node);
@@ -191089,6 +175501,11 @@ ${lanes.join("\n")}
           )
         ));
       }
+      const alias = getClassLexicalEnvironment().classConstructor;
+      if (isClassWithConstructorReference && alias) {
+        enableSubstitutionForClassAliases();
+        classAliases[getOriginalNodeId(node)] = alias;
+      }
       const classDecl = factory2.updateClassDeclaration(
         node,
         modifiers,
@@ -191104,24 +175521,27 @@ ${lanes.join("\n")}
       }
       return statements;
     }
-    function visitClassExpression(node, referencedName) {
-      return visitInNewClassLexicalEnvironment(node, referencedName, visitClassExpressionInNewClassLexicalEnvironment);
+    function visitClassExpression(node) {
+      return visitInNewClassLexicalEnvironment(node, visitClassExpressionInNewClassLexicalEnvironment);
     }
-    function visitClassExpressionInNewClassLexicalEnvironment(node, facts, referencedName) {
-      var _a, _b, _c, _d;
+    function visitClassExpressionInNewClassLexicalEnvironment(node, facts) {
+      var _a, _b, _c;
       const isDecoratedClassDeclaration = !!(facts & 1 /* ClassWasDecorated */);
       const staticPropertiesOrClassStaticBlocks = getStaticPropertiesAndClassStaticBlock(node);
-      const isClassWithConstructorReference = resolver.getNodeCheckFlags(node) & 1048576 /* ClassWithConstructorReference */;
+      const classCheckFlags = resolver.getNodeCheckFlags(node);
+      const isClassWithConstructorReference = classCheckFlags & 262144 /* ContainsConstructorReference */;
       let temp;
       function createClassTempVar() {
         var _a2;
         if (shouldTransformPrivateElementsOrClassStaticBlocks && ((_a2 = node.emitNode) == null ? void 0 : _a2.classThis)) {
           return getClassLexicalEnvironment().classConstructor = node.emitNode.classThis;
         }
-        const classCheckFlags = resolver.getNodeCheckFlags(node);
-        const isClassWithConstructorReference2 = classCheckFlags & 1048576 /* ClassWithConstructorReference */;
         const requiresBlockScopedVar = classCheckFlags & 32768 /* BlockScopedBindingInLoop */;
-        const temp2 = factory2.createTempVariable(requiresBlockScopedVar ? addBlockScopedVariable : hoistVariableDeclaration, !!isClassWithConstructorReference2);
+        const temp2 = factory2.createTempVariable(
+          requiresBlockScopedVar ? addBlockScopedVariable : hoistVariableDeclaration,
+          /*reservedInNestedScopes*/
+          true
+        );
         getClassLexicalEnvironment().classConstructor = factory2.cloneNode(temp2);
         return temp2;
       }
@@ -191134,7 +175554,7 @@ ${lanes.join("\n")}
       const modifiers = visitNodes2(node.modifiers, modifierVisitor, isModifier);
       const heritageClauses = visitNodes2(node.heritageClauses, heritageClauseVisitor, isHeritageClause);
       const { members, prologue } = transformClassMembers(node);
-      let classExpression = factory2.updateClassExpression(
+      const classExpression = factory2.updateClassExpression(
         node,
         modifiers,
         node.name,
@@ -191148,41 +175568,18 @@ ${lanes.join("\n")}
         expressions.push(prologue);
       }
       const hasTransformableStatics = (shouldTransformPrivateElementsOrClassStaticBlocks || getInternalEmitFlags(node) & 32 /* TransformPrivateStaticElements */) && some(staticPropertiesOrClassStaticBlocks, (node2) => isClassStaticBlockDeclaration(node2) || isPrivateIdentifierClassElementDeclaration(node2) || shouldTransformInitializers && isInitializedProperty(node2));
-      if (hasTransformableStatics || some(pendingExpressions) || referencedName) {
+      if (hasTransformableStatics || some(pendingExpressions)) {
         if (isDecoratedClassDeclaration) {
           Debug.assertIsDefined(pendingStatements, "Decorated classes transformed by TypeScript are expected to be within a variable declaration.");
           if (some(pendingExpressions)) {
             addRange(pendingStatements, map(pendingExpressions, factory2.createExpressionStatement));
           }
-          if (referencedName) {
-            if (shouldTransformPrivateElementsOrClassStaticBlocks) {
-              const setNameExpression = emitHelpers().createSetFunctionNameHelper(temp ?? ((_b = node.emitNode) == null ? void 0 : _b.classThis) ?? factory2.getInternalName(node), referencedName);
-              pendingStatements.push(factory2.createExpressionStatement(setNameExpression));
-            } else {
-              const setNameExpression = emitHelpers().createSetFunctionNameHelper(factory2.createThis(), referencedName);
-              classExpression = factory2.updateClassExpression(
-                classExpression,
-                classExpression.modifiers,
-                classExpression.name,
-                classExpression.typeParameters,
-                classExpression.heritageClauses,
-                [
-                  factory2.createClassStaticBlockDeclaration(
-                    factory2.createBlock([
-                      factory2.createExpressionStatement(setNameExpression)
-                    ])
-                  ),
-                  ...classExpression.members
-                ]
-              );
-            }
-          }
           if (some(staticPropertiesOrClassStaticBlocks)) {
-            addPropertyOrClassStaticBlockStatements(pendingStatements, staticPropertiesOrClassStaticBlocks, ((_c = node.emitNode) == null ? void 0 : _c.classThis) ?? factory2.getInternalName(node));
+            addPropertyOrClassStaticBlockStatements(pendingStatements, staticPropertiesOrClassStaticBlocks, ((_b = node.emitNode) == null ? void 0 : _b.classThis) ?? factory2.getInternalName(node));
           }
           if (temp) {
             expressions.push(factory2.createAssignment(temp, classExpression));
-          } else if (shouldTransformPrivateElementsOrClassStaticBlocks && ((_d = node.emitNode) == null ? void 0 : _d.classThis)) {
+          } else if (shouldTransformPrivateElementsOrClassStaticBlocks && ((_c = node.emitNode) == null ? void 0 : _c.classThis)) {
             expressions.push(factory2.createAssignment(node.emitNode.classThis, classExpression));
           } else {
             expressions.push(classExpression);
@@ -191197,9 +175594,6 @@ ${lanes.join("\n")}
           }
           expressions.push(factory2.createAssignment(temp, classExpression));
           addRange(expressions, pendingExpressions);
-          if (referencedName) {
-            expressions.push(emitHelpers().createSetFunctionNameHelper(temp, referencedName));
-          }
           addRange(expressions, generateInitializedPropertyExpressionsOrClassStaticBlock(staticPropertiesOrClassStaticBlocks, temp));
           expressions.push(factory2.cloneNode(temp));
         }
@@ -191218,6 +175612,13 @@ ${lanes.join("\n")}
       }
       return void 0;
     }
+    function visitThisExpression(node) {
+      if (shouldTransformThisInStaticInitializers && currentClassElement && isClassStaticBlockDeclaration(currentClassElement) && (lexicalEnvironment == null ? void 0 : lexicalEnvironment.data)) {
+        const { classThis, classConstructor } = lexicalEnvironment.data;
+        return classThis ?? classConstructor ?? node;
+      }
+      return node;
+    }
     function transformClassMembers(node) {
       const shouldTransformPrivateStaticElementsInClass = !!(getInternalEmitFlags(node) & 32 /* TransformPrivateStaticElements */);
       if (shouldTransformPrivateElementsOrClassStaticBlocks || shouldTransformPrivateStaticElementsInFile) {
@@ -191297,9 +175698,14 @@ ${lanes.join("\n")}
       }
       if (syntheticConstructor || syntheticStaticBlock) {
         let membersArray;
+        const classThisAssignmentBlock = find(members, isClassThisAssignmentBlock);
+        const classNamedEvaluationHelperBlock = find(members, isClassNamedEvaluationHelperBlock);
+        membersArray = append(membersArray, classThisAssignmentBlock);
+        membersArray = append(membersArray, classNamedEvaluationHelperBlock);
         membersArray = append(membersArray, syntheticConstructor);
         membersArray = append(membersArray, syntheticStaticBlock);
-        membersArray = addRange(membersArray, members);
+        const remainingMembers = classThisAssignmentBlock || classNamedEvaluationHelperBlock ? filter(members, (member) => member !== classThisAssignmentBlock && member !== classNamedEvaluationHelperBlock) : members;
+        membersArray = addRange(membersArray, remainingMembers);
         members = setTextRange(
           factory2.createNodeArray(membersArray),
           /*location*/
@@ -191360,8 +175766,46 @@ ${lanes.join("\n")}
         )
       );
     }
+    function transformConstructorBodyWorker(statementsOut, statementsIn, statementOffset, superPath, superPathDepth, initializerStatements, constructor) {
+      const superStatementIndex = superPath[superPathDepth];
+      const superStatement = statementsIn[superStatementIndex];
+      addRange(statementsOut, visitNodes2(statementsIn, visitor, isStatement, statementOffset, superStatementIndex - statementOffset));
+      statementOffset = superStatementIndex + 1;
+      if (isTryStatement(superStatement)) {
+        const tryBlockStatements = [];
+        transformConstructorBodyWorker(
+          tryBlockStatements,
+          superStatement.tryBlock.statements,
+          /*statementOffset*/
+          0,
+          superPath,
+          superPathDepth + 1,
+          initializerStatements,
+          constructor
+        );
+        const tryBlockStatementsArray = factory2.createNodeArray(tryBlockStatements);
+        setTextRange(tryBlockStatementsArray, superStatement.tryBlock.statements);
+        statementsOut.push(factory2.updateTryStatement(
+          superStatement,
+          factory2.updateBlock(superStatement.tryBlock, tryBlockStatements),
+          visitNode(superStatement.catchClause, visitor, isCatchClause),
+          visitNode(superStatement.finallyBlock, visitor, isBlock)
+        ));
+      } else {
+        addRange(statementsOut, visitNodes2(statementsIn, visitor, isStatement, superStatementIndex, 1));
+        while (statementOffset < statementsIn.length) {
+          const statement = statementsIn[statementOffset];
+          if (isParameterPropertyDeclaration(getOriginalNode(statement), constructor)) {
+            statementOffset++;
+          } else {
+            break;
+          }
+        }
+        addRange(statementsOut, initializerStatements);
+      }
+      addRange(statementsOut, visitNodes2(statementsIn, visitor, isStatement, statementOffset));
+    }
     function transformConstructorBody(node, constructor, isDerivedClass) {
-      var _a;
       const instanceProperties = getProperties(
         node,
         /*requireInitializer*/
@@ -191385,68 +175829,65 @@ ${lanes.join("\n")}
       }
       resumeLexicalEnvironment();
       const needsSyntheticConstructor = !constructor && isDerivedClass;
-      let indexOfFirstStatementAfterSuperAndPrologue = 0;
-      let prologueStatementCount = 0;
-      let superStatementIndex = -1;
+      let statementOffset = 0;
       let statements = [];
-      if ((_a = constructor == null ? void 0 : constructor.body) == null ? void 0 : _a.statements) {
-        prologueStatementCount = factory2.copyPrologue(
+      const initializerStatements = [];
+      const receiver = factory2.createThis();
+      addInstanceMethodStatements(initializerStatements, privateMethodsAndAccessors, receiver);
+      if (constructor) {
+        const parameterProperties = filter(instanceProperties, (prop) => isParameterPropertyDeclaration(getOriginalNode(prop), constructor));
+        const nonParameterProperties = filter(properties, (prop) => !isParameterPropertyDeclaration(getOriginalNode(prop), constructor));
+        addPropertyOrClassStaticBlockStatements(initializerStatements, parameterProperties, receiver);
+        addPropertyOrClassStaticBlockStatements(initializerStatements, nonParameterProperties, receiver);
+      } else {
+        addPropertyOrClassStaticBlockStatements(initializerStatements, properties, receiver);
+      }
+      if (constructor == null ? void 0 : constructor.body) {
+        statementOffset = factory2.copyPrologue(
           constructor.body.statements,
           statements,
           /*ensureUseStrict*/
           false,
           visitor
         );
-        superStatementIndex = findSuperStatementIndex(constructor.body.statements, prologueStatementCount);
-        if (superStatementIndex >= 0) {
-          indexOfFirstStatementAfterSuperAndPrologue = superStatementIndex + 1;
-          statements = [
-            ...statements.slice(0, prologueStatementCount),
-            ...visitNodes2(constructor.body.statements, visitor, isStatement, prologueStatementCount, indexOfFirstStatementAfterSuperAndPrologue - prologueStatementCount),
-            ...statements.slice(prologueStatementCount)
-          ];
-        } else if (prologueStatementCount >= 0) {
-          indexOfFirstStatementAfterSuperAndPrologue = prologueStatementCount;
-        }
-      }
-      if (needsSyntheticConstructor) {
-        statements.push(
-          factory2.createExpressionStatement(
-            factory2.createCallExpression(
-              factory2.createSuper(),
-              /*typeArguments*/
-              void 0,
-              [factory2.createSpreadElement(factory2.createIdentifier("arguments"))]
-            )
-          )
-        );
-      }
-      let parameterPropertyDeclarationCount = 0;
-      if (constructor == null ? void 0 : constructor.body) {
-        for (let i = indexOfFirstStatementAfterSuperAndPrologue; i < constructor.body.statements.length; i++) {
-          const statement = constructor.body.statements[i];
-          if (isParameterPropertyDeclaration(getOriginalNode(statement), constructor)) {
-            parameterPropertyDeclarationCount++;
-          } else {
-            break;
+        const superStatementIndices = findSuperStatementIndexPath(constructor.body.statements, statementOffset);
+        if (superStatementIndices.length) {
+          transformConstructorBodyWorker(
+            statements,
+            constructor.body.statements,
+            statementOffset,
+            superStatementIndices,
+            /*superPathDepth*/
+            0,
+            initializerStatements,
+            constructor
+          );
+        } else {
+          while (statementOffset < constructor.body.statements.length) {
+            const statement = constructor.body.statements[statementOffset];
+            if (isParameterPropertyDeclaration(getOriginalNode(statement), constructor)) {
+              statementOffset++;
+            } else {
+              break;
+            }
           }
+          addRange(statements, initializerStatements);
+          addRange(statements, visitNodes2(constructor.body.statements, visitor, isStatement, statementOffset));
         }
-        if (parameterPropertyDeclarationCount > 0) {
-          indexOfFirstStatementAfterSuperAndPrologue += parameterPropertyDeclarationCount;
-        }
-      }
-      const receiver = factory2.createThis();
-      addInstanceMethodStatements(statements, privateMethodsAndAccessors, receiver);
-      if (constructor) {
-        const parameterProperties = filter(instanceProperties, (prop) => isParameterPropertyDeclaration(getOriginalNode(prop), constructor));
-        const nonParameterProperties = filter(properties, (prop) => !isParameterPropertyDeclaration(getOriginalNode(prop), constructor));
-        addPropertyOrClassStaticBlockStatements(statements, parameterProperties, receiver);
-        addPropertyOrClassStaticBlockStatements(statements, nonParameterProperties, receiver);
       } else {
-        addPropertyOrClassStaticBlockStatements(statements, properties, receiver);
-      }
-      if (constructor) {
-        addRange(statements, visitNodes2(constructor.body.statements, visitor, isStatement, indexOfFirstStatementAfterSuperAndPrologue));
+        if (needsSyntheticConstructor) {
+          statements.push(
+            factory2.createExpressionStatement(
+              factory2.createCallExpression(
+                factory2.createSuper(),
+                /*typeArguments*/
+                void 0,
+                [factory2.createSpreadElement(factory2.createIdentifier("arguments"))]
+              )
+            )
+          );
+        }
+        addRange(statements, initializerStatements);
       }
       statements = factory2.mergeLexicalEnvironment(statements, endLexicalEnvironment());
       if (statements.length === 0 && !constructor) {
@@ -191479,7 +175920,7 @@ ${lanes.join("\n")}
       }
     }
     function transformPropertyOrClassStaticBlock(property, receiver) {
-      const expression = isClassStaticBlockDeclaration(property) ? transformClassStaticBlockDeclaration(property) : transformProperty(property, receiver);
+      const expression = isClassStaticBlockDeclaration(property) ? setCurrentClassElementAnd(property, transformClassStaticBlockDeclaration, property) : transformProperty(property, receiver);
       if (!expression) {
         return void 0;
       }
@@ -191504,7 +175945,12 @@ ${lanes.join("\n")}
     function generateInitializedPropertyExpressionsOrClassStaticBlock(propertiesOrClassStaticBlocks, receiver) {
       const expressions = [];
       for (const property of propertiesOrClassStaticBlocks) {
-        const expression = isClassStaticBlockDeclaration(property) ? transformClassStaticBlockDeclaration(property) : transformProperty(property, receiver);
+        const expression = isClassStaticBlockDeclaration(property) ? setCurrentClassElementAnd(property, transformClassStaticBlockDeclaration, property) : setCurrentClassElementAnd(
+          property,
+          () => transformProperty(property, receiver),
+          /*arg*/
+          void 0
+        );
         if (!expression) {
           continue;
         }
@@ -191519,7 +175965,7 @@ ${lanes.join("\n")}
     }
     function transformProperty(property, receiver) {
       var _a;
-      const savedCurrentStaticPropertyDeclarationOrStaticBlock = currentStaticPropertyDeclarationOrStaticBlock;
+      const savedCurrentClassElement = currentClassElement;
       const transformed = transformPropertyWorker(property, receiver);
       if (transformed && hasStaticModifier(property) && ((_a = lexicalEnvironment == null ? void 0 : lexicalEnvironment.data) == null ? void 0 : _a.facts)) {
         setOriginalNode(transformed, property);
@@ -191527,26 +175973,18 @@ ${lanes.join("\n")}
         setSourceMapRange(transformed, getSourceMapRange(property.name));
         lexicalEnvironmentMap.set(getOriginalNode(property), lexicalEnvironment);
       }
-      currentStaticPropertyDeclarationOrStaticBlock = savedCurrentStaticPropertyDeclarationOrStaticBlock;
+      currentClassElement = savedCurrentClassElement;
       return transformed;
     }
     function transformPropertyWorker(property, receiver) {
       const emitAssignment = !useDefineForClassFields;
-      let referencedName;
       if (isNamedEvaluation(property, isAnonymousClassNeedingAssignedName)) {
-        if (isPropertyNameLiteral(property.name) || isPrivateIdentifier(property.name)) {
-          referencedName = factory2.createStringLiteralFromNode(property.name);
-        } else if (isPropertyNameLiteral(property.name.expression) && !isIdentifier(property.name.expression)) {
-          referencedName = factory2.createStringLiteralFromNode(property.name.expression);
-        } else {
-          referencedName = factory2.getGeneratedNameForNode(property.name);
-        }
+        property = transformNamedEvaluation(context, property);
       }
       const propertyName = hasAccessorModifier(property) ? factory2.getGeneratedPrivateNameForNode(property.name) : isComputedPropertyName(property.name) && !isSimpleInlineableExpression(property.name.expression) ? factory2.updateComputedPropertyName(property.name, factory2.getGeneratedNameForNode(property.name)) : property.name;
       if (hasStaticModifier(property)) {
-        currentStaticPropertyDeclarationOrStaticBlock = property;
+        currentClassElement = property;
       }
-      const initializerVisitor = referencedName ? (child) => namedEvaluationVisitor(child, referencedName) : visitor;
       if (isPrivateIdentifier(propertyName) && shouldTransformClassElementToWeakMap(property)) {
         const privateIdentifierInfo = accessPrivateIdentifier2(propertyName);
         if (privateIdentifierInfo) {
@@ -191555,14 +175993,14 @@ ${lanes.join("\n")}
               return createPrivateInstanceFieldInitializer(
                 factory2,
                 receiver,
-                visitNode(property.initializer, initializerVisitor, isExpression),
+                visitNode(property.initializer, visitor, isExpression),
                 privateIdentifierInfo.brandCheckIdentifier
               );
             } else {
               return createPrivateStaticFieldInitializer(
                 factory2,
                 privateIdentifierInfo.variableName,
-                visitNode(property.initializer, initializerVisitor, isExpression)
+                visitNode(property.initializer, visitor, isExpression)
               );
             }
           } else {
@@ -191576,10 +176014,10 @@ ${lanes.join("\n")}
         return void 0;
       }
       const propertyOriginalNode = getOriginalNode(property);
-      if (hasSyntacticModifier(propertyOriginalNode, 256 /* Abstract */)) {
+      if (hasSyntacticModifier(propertyOriginalNode, 64 /* Abstract */)) {
         return void 0;
       }
-      let initializer = visitNode(property.initializer, initializerVisitor, isExpression);
+      let initializer = visitNode(property.initializer, visitor, isExpression);
       if (isParameterPropertyDeclaration(propertyOriginalNode, propertyOriginalNode.parent) && isIdentifier(propertyName)) {
         const localName = factory2.cloneNode(propertyName);
         if (initializer) {
@@ -191624,14 +176062,14 @@ ${lanes.join("\n")}
       if ((enabledSubstitutions & 2 /* ClassStaticThisOrSuperReference */) === 0) {
         enabledSubstitutions |= 2 /* ClassStaticThisOrSuperReference */;
         context.enableSubstitution(110 /* ThisKeyword */);
-        context.enableEmitNotification(261 /* FunctionDeclaration */);
-        context.enableEmitNotification(217 /* FunctionExpression */);
-        context.enableEmitNotification(175 /* Constructor */);
-        context.enableEmitNotification(176 /* GetAccessor */);
-        context.enableEmitNotification(177 /* SetAccessor */);
-        context.enableEmitNotification(173 /* MethodDeclaration */);
-        context.enableEmitNotification(171 /* PropertyDeclaration */);
-        context.enableEmitNotification(166 /* ComputedPropertyName */);
+        context.enableEmitNotification(262 /* FunctionDeclaration */);
+        context.enableEmitNotification(218 /* FunctionExpression */);
+        context.enableEmitNotification(176 /* Constructor */);
+        context.enableEmitNotification(177 /* GetAccessor */);
+        context.enableEmitNotification(178 /* SetAccessor */);
+        context.enableEmitNotification(174 /* MethodDeclaration */);
+        context.enableEmitNotification(172 /* PropertyDeclaration */);
+        context.enableEmitNotification(167 /* ComputedPropertyName */);
       }
     }
     function addInstanceMethodStatements(statements, methods, receiver) {
@@ -191657,10 +176095,10 @@ ${lanes.join("\n")}
         visitNode(node.argumentExpression, visitor, isExpression)
       );
     }
-    function getPropertyNameExpressionIfNeeded(name, shouldHoist, captureReferencedName) {
+    function getPropertyNameExpressionIfNeeded(name, shouldHoist) {
       if (isComputedPropertyName(name)) {
         const cacheAssignment = findComputedPropertyNameCacheAssignment(name);
-        let expression = visitNode(name.expression, visitor, isExpression);
+        const expression = visitNode(name.expression, visitor, isExpression);
         const innerExpression = skipPartiallyEmittedExpressions(expression);
         const inlinable = isSimpleInlineableExpression(innerExpression);
         const alreadyTransformed = !!cacheAssignment || isAssignmentExpression(innerExpression) && isGeneratedIdentifier(innerExpression.left);
@@ -191671,9 +176109,6 @@ ${lanes.join("\n")}
           } else {
             hoistVariableDeclaration(generatedName);
           }
-          if (captureReferencedName) {
-            expression = emitHelpers().createPropKeyHelper(expression);
-          }
           return factory2.createAssignment(generatedName, expression);
         }
         return inlinable || isIdentifier(innerExpression) ? void 0 : expression;
@@ -191869,7 +176304,7 @@ ${lanes.join("\n")}
       }
       if (isPrivateIdentifierPropertyAccessExpression(node)) {
         return wrapPrivateIdentifierForDestructuringTarget(node);
-      } else if (shouldTransformSuperInStaticInitializers && isSuperProperty(node) && currentStaticPropertyDeclarationOrStaticBlock && (lexicalEnvironment == null ? void 0 : lexicalEnvironment.data)) {
+      } else if (shouldTransformSuperInStaticInitializers && currentClassElement && isSuperProperty(node) && isStaticPropertyDeclarationOrClassStaticBlock(currentClassElement) && (lexicalEnvironment == null ? void 0 : lexicalEnvironment.data)) {
         const { classConstructor, superClassReference, facts } = lexicalEnvironment.data;
         if (facts & 1 /* ClassWasDecorated */) {
           return visitInvalidSuperProperty(node);
@@ -191896,10 +176331,7 @@ ${lanes.join("\n")}
     }
     function visitAssignmentElement(node) {
       if (isNamedEvaluation(node, isAnonymousClassNeedingAssignedName)) {
-        const left = visitDestructuringAssignmentTarget(node.left);
-        const assignedName = getAssignedNameOfIdentifier(node.left, node.right);
-        const right = visitNode(node.right, (node2) => namedEvaluationVisitor(node2, assignedName), isExpression);
-        return factory2.updateBinaryExpression(node, left, node.operatorToken, right);
+        node = transformNamedEvaluation(context, node);
       }
       if (isAssignmentExpression(
         node,
@@ -191946,9 +176378,7 @@ ${lanes.join("\n")}
     }
     function visitShorthandAssignmentProperty(node) {
       if (isNamedEvaluation(node, isAnonymousClassNeedingAssignedName)) {
-        const assignedName = getAssignedNameOfIdentifier(node.name, node.objectAssignmentInitializer);
-        const objectAssignmentInitializer = visitNode(node.objectAssignmentInitializer, (node2) => namedEvaluationVisitor(node2, assignedName), isExpression);
-        return factory2.updateShorthandPropertyAssignment(node, node.name, objectAssignmentInitializer);
+        node = transformNamedEvaluation(context, node);
       }
       return visitEachChild(node, visitor, context);
     }
@@ -191998,16 +176428,16 @@ ${lanes.join("\n")}
         return;
       }
       switch (node.kind) {
-        case 217 /* FunctionExpression */:
+        case 218 /* FunctionExpression */:
           if (isArrowFunction(original) || getEmitFlags(node) & 524288 /* AsyncFunctionBody */) {
             break;
           }
-        case 261 /* FunctionDeclaration */:
-        case 175 /* Constructor */:
-        case 176 /* GetAccessor */:
-        case 177 /* SetAccessor */:
-        case 173 /* MethodDeclaration */:
-        case 171 /* PropertyDeclaration */: {
+        case 262 /* FunctionDeclaration */:
+        case 176 /* Constructor */:
+        case 177 /* GetAccessor */:
+        case 178 /* SetAccessor */:
+        case 174 /* MethodDeclaration */:
+        case 172 /* PropertyDeclaration */: {
           const savedLexicalEnvironment = lexicalEnvironment;
           const savedPreviousShouldSubstituteThisWithClassThis = previousShouldSubstituteThisWithClassThis;
           lexicalEnvironment = void 0;
@@ -192019,7 +176449,7 @@ ${lanes.join("\n")}
           lexicalEnvironment = savedLexicalEnvironment;
           return;
         }
-        case 166 /* ComputedPropertyName */: {
+        case 167 /* ComputedPropertyName */: {
           const savedLexicalEnvironment = lexicalEnvironment;
           const savedShouldSubstituteThisWithClassThis = shouldSubstituteThisWithClassThis;
           lexicalEnvironment = lexicalEnvironment == null ? void 0 : lexicalEnvironment.previous;
@@ -192049,11 +176479,8 @@ ${lanes.join("\n")}
       return node;
     }
     function substituteThisExpression(node) {
-      if (enabledSubstitutions & 2 /* ClassStaticThisOrSuperReference */ && (lexicalEnvironment == null ? void 0 : lexicalEnvironment.data)) {
+      if (enabledSubstitutions & 2 /* ClassStaticThisOrSuperReference */ && (lexicalEnvironment == null ? void 0 : lexicalEnvironment.data) && !noSubstitution.has(node)) {
         const { facts, classConstructor, classThis } = lexicalEnvironment.data;
-        if (facts & 1 /* ClassWasDecorated */ && legacyDecorators) {
-          return factory2.createParenthesizedExpression(factory2.createVoidZero());
-        }
         const substituteThis = shouldSubstituteThisWithClassThis ? classThis ?? classConstructor : classConstructor;
         if (substituteThis) {
           return setTextRange(
@@ -192064,6 +176491,9 @@ ${lanes.join("\n")}
             node
           );
         }
+        if (facts & 1 /* ClassWasDecorated */ && legacyDecorators) {
+          return factory2.createParenthesizedExpression(factory2.createVoidZero());
+        }
       }
       return node;
     }
@@ -192072,7 +176502,7 @@ ${lanes.join("\n")}
     }
     function trySubstituteClassAlias(node) {
       if (enabledSubstitutions & 1 /* ClassAliases */) {
-        if (resolver.getNodeCheckFlags(node) & 2097152 /* ConstructorReferenceInClass */) {
+        if (resolver.getNodeCheckFlags(node) & 536870912 /* ConstructorReference */) {
           const declaration = resolver.getReferencedValueDeclaration(node);
           if (declaration) {
             const classAlias = classAliases[declaration.id];
@@ -192118,6 +176548,12 @@ ${lanes.join("\n")}
   function isPrivateIdentifierInExpression(node) {
     return isPrivateIdentifier(node.left) && node.operatorToken.kind === 103 /* InKeyword */;
   }
+  function isStaticPropertyDeclaration2(node) {
+    return isPropertyDeclaration(node) && hasStaticModifier(node);
+  }
+  function isStaticPropertyDeclarationOrClassStaticBlock(node) {
+    return isClassStaticBlockDeclaration(node) || isStaticPropertyDeclaration2(node);
+  }
   var init_classFields = __esm({
     "src/compiler/transformers/classFields.ts"() {
       "use strict";
@@ -192159,15 +176595,15 @@ ${lanes.join("\n")}
     }
     function serializeTypeOfNode(node) {
       switch (node.kind) {
-        case 171 /* PropertyDeclaration */:
-        case 168 /* Parameter */:
+        case 172 /* PropertyDeclaration */:
+        case 169 /* Parameter */:
           return serializeTypeNode(node.type);
-        case 177 /* SetAccessor */:
-        case 176 /* GetAccessor */:
+        case 178 /* SetAccessor */:
+        case 177 /* GetAccessor */:
           return serializeTypeNode(getAccessorTypeNode(node));
-        case 262 /* ClassDeclaration */:
-        case 230 /* ClassExpression */:
-        case 173 /* MethodDeclaration */:
+        case 263 /* ClassDeclaration */:
+        case 231 /* ClassExpression */:
+        case 174 /* MethodDeclaration */:
           return factory2.createIdentifier("Function");
         default:
           return factory2.createVoidZero();
@@ -192194,7 +176630,7 @@ ${lanes.join("\n")}
       return factory2.createArrayLiteralExpression(expressions);
     }
     function getParametersOfDecoratedDeclaration(node, container) {
-      if (container && node.kind === 176 /* GetAccessor */) {
+      if (container && node.kind === 177 /* GetAccessor */) {
         const { setAccessor } = getAllAccessorDeclarations(container.members, node);
         if (setAccessor) {
           return setAccessor.parameters;
@@ -192220,72 +176656,72 @@ ${lanes.join("\n")}
         case 157 /* UndefinedKeyword */:
         case 146 /* NeverKeyword */:
           return factory2.createVoidZero();
-        case 183 /* FunctionType */:
-        case 184 /* ConstructorType */:
+        case 184 /* FunctionType */:
+        case 185 /* ConstructorType */:
           return factory2.createIdentifier("Function");
-        case 187 /* ArrayType */:
-        case 188 /* TupleType */:
+        case 188 /* ArrayType */:
+        case 189 /* TupleType */:
           return factory2.createIdentifier("Array");
-        case 181 /* TypePredicate */:
+        case 182 /* TypePredicate */:
           return node.assertsModifier ? factory2.createVoidZero() : factory2.createIdentifier("Boolean");
         case 136 /* BooleanKeyword */:
           return factory2.createIdentifier("Boolean");
-        case 202 /* TemplateLiteralType */:
+        case 203 /* TemplateLiteralType */:
         case 154 /* StringKeyword */:
           return factory2.createIdentifier("String");
         case 151 /* ObjectKeyword */:
           return factory2.createIdentifier("Object");
-        case 200 /* LiteralType */:
+        case 201 /* LiteralType */:
           return serializeLiteralOfLiteralTypeNode(node.literal);
         case 150 /* NumberKeyword */:
           return factory2.createIdentifier("Number");
-        case 162 /* BigIntKeyword */:
+        case 163 /* BigIntKeyword */:
           return getGlobalConstructor("BigInt", 7 /* ES2020 */);
         case 155 /* SymbolKeyword */:
           return getGlobalConstructor("Symbol", 2 /* ES2015 */);
-        case 182 /* TypeReference */:
+        case 183 /* TypeReference */:
           return serializeTypeReferenceNode(node);
-        case 192 /* IntersectionType */:
+        case 193 /* IntersectionType */:
           return serializeUnionOrIntersectionConstituents(
             node.types,
             /*isIntersection*/
             true
           );
-        case 191 /* UnionType */:
+        case 192 /* UnionType */:
           return serializeUnionOrIntersectionConstituents(
             node.types,
             /*isIntersection*/
             false
           );
-        case 193 /* ConditionalType */:
+        case 194 /* ConditionalType */:
           return serializeUnionOrIntersectionConstituents(
             [node.trueType, node.falseType],
             /*isIntersection*/
             false
           );
-        case 197 /* TypeOperator */:
+        case 198 /* TypeOperator */:
           if (node.operator === 148 /* ReadonlyKeyword */) {
             return serializeTypeNode(node.type);
           }
           break;
-        case 185 /* TypeQuery */:
-        case 198 /* IndexedAccessType */:
-        case 199 /* MappedType */:
-        case 186 /* TypeLiteral */:
+        case 186 /* TypeQuery */:
+        case 199 /* IndexedAccessType */:
+        case 200 /* MappedType */:
+        case 187 /* TypeLiteral */:
         case 133 /* AnyKeyword */:
         case 159 /* UnknownKeyword */:
-        case 196 /* ThisType */:
-        case 204 /* ImportType */:
+        case 197 /* ThisType */:
+        case 205 /* ImportType */:
           break;
-        case 318 /* JSDocAllType */:
-        case 319 /* JSDocUnknownType */:
-        case 323 /* JSDocFunctionType */:
-        case 324 /* JSDocVariadicType */:
-        case 325 /* JSDocNamepathType */:
+        case 319 /* JSDocAllType */:
+        case 320 /* JSDocUnknownType */:
+        case 324 /* JSDocFunctionType */:
+        case 325 /* JSDocVariadicType */:
+        case 326 /* JSDocNamepathType */:
           break;
-        case 320 /* JSDocNullableType */:
-        case 321 /* JSDocNonNullableType */:
-        case 322 /* JSDocOptionalType */:
+        case 321 /* JSDocNullableType */:
+        case 322 /* JSDocNonNullableType */:
+        case 323 /* JSDocOptionalType */:
           return serializeTypeNode(node.type);
         default:
           return Debug.failBadSyntaxKind(node);
@@ -192297,7 +176733,7 @@ ${lanes.join("\n")}
         case 11 /* StringLiteral */:
         case 15 /* NoSubstitutionTemplateLiteral */:
           return factory2.createIdentifier("String");
-        case 223 /* PrefixUnaryExpression */: {
+        case 224 /* PrefixUnaryExpression */: {
           const operand = node.operand;
           switch (operand.kind) {
             case 9 /* NumericLiteral */:
@@ -192456,7 +176892,7 @@ ${lanes.join("\n")}
           name.original = void 0;
           setParent(name, getParseTreeNode(currentLexicalScope));
           return name;
-        case 165 /* QualifiedName */:
+        case 166 /* QualifiedName */:
           return serializeQualifiedNameAsExpression(node);
       }
     }
@@ -192512,23 +176948,23 @@ ${lanes.join("\n")}
         return node;
       }
       switch (node.kind) {
-        case 169 /* Decorator */:
+        case 170 /* Decorator */:
           return void 0;
-        case 262 /* ClassDeclaration */:
+        case 263 /* ClassDeclaration */:
           return visitClassDeclaration(node);
-        case 230 /* ClassExpression */:
+        case 231 /* ClassExpression */:
           return visitClassExpression(node);
-        case 175 /* Constructor */:
+        case 176 /* Constructor */:
           return visitConstructorDeclaration(node);
-        case 173 /* MethodDeclaration */:
+        case 174 /* MethodDeclaration */:
           return visitMethodDeclaration(node);
-        case 177 /* SetAccessor */:
+        case 178 /* SetAccessor */:
           return visitSetAccessorDeclaration(node);
-        case 176 /* GetAccessor */:
+        case 177 /* GetAccessor */:
           return visitGetAccessorDeclaration(node);
-        case 171 /* PropertyDeclaration */:
+        case 172 /* PropertyDeclaration */:
           return visitPropertyDeclaration(node);
-        case 168 /* Parameter */:
+        case 169 /* Parameter */:
           return visitParameterDeclaration(node);
         default:
           return visitEachChild(node, visitor, context);
@@ -192591,16 +177027,19 @@ ${lanes.join("\n")}
         true
       );
       if (hasClassElementWithDecoratorContainingPrivateIdentifierInExpression(node)) {
-        members = setTextRange(factory2.createNodeArray([
-          ...members,
-          factory2.createClassStaticBlockDeclaration(
-            factory2.createBlock(
-              decorationStatements,
-              /*multiLine*/
-              true
+        members = setTextRange(
+          factory2.createNodeArray([
+            ...members,
+            factory2.createClassStaticBlockDeclaration(
+              factory2.createBlock(
+                decorationStatements,
+                /*multiLine*/
+                true
+              )
             )
-          )
-        ]), members);
+          ]),
+          members
+        );
         decorationStatements = void 0;
       }
       return { decorationStatements, members };
@@ -192623,8 +177062,8 @@ ${lanes.join("\n")}
       return addRange([updated], decorationStatements);
     }
     function transformClassDeclarationWithClassDecorators(node, name) {
-      const isExport = hasSyntacticModifier(node, 1 /* Export */);
-      const isDefault = hasSyntacticModifier(node, 1024 /* Default */);
+      const isExport = hasSyntacticModifier(node, 32 /* Export */);
+      const isDefault = hasSyntacticModifier(node, 2048 /* Default */);
       const modifiers = visitNodes2(node.modifiers, (node2) => isExportOrDefaultModifier(node2) || isDecorator(node2) ? void 0 : node2, isModifierLike);
       const location = moveRangePastModifiers(node);
       const classAlias = getClassAliasIfNeeded(node);
@@ -192645,18 +177084,21 @@ ${lanes.join("\n")}
       let members = visitNodes2(node.members, visitor, isClassElement);
       let decorationStatements = [];
       ({ members, decorationStatements } = transformDecoratorsOfClassElements(node, members));
-      const assignClassAliasInStaticBlock = languageVersion >= 9 /* ES2022 */ && !!classAlias && some(members, (member) => isPropertyDeclaration(member) && hasSyntacticModifier(member, 32 /* Static */) || isClassStaticBlockDeclaration(member));
+      const assignClassAliasInStaticBlock = languageVersion >= 9 /* ES2022 */ && !!classAlias && some(members, (member) => isPropertyDeclaration(member) && hasSyntacticModifier(member, 256 /* Static */) || isClassStaticBlockDeclaration(member));
       if (assignClassAliasInStaticBlock) {
-        members = setTextRange(factory2.createNodeArray([
-          factory2.createClassStaticBlockDeclaration(
-            factory2.createBlock([
-              factory2.createExpressionStatement(
-                factory2.createAssignment(classAlias, factory2.createThis())
-              )
-            ])
-          ),
-          ...members
-        ]), members);
+        members = setTextRange(
+          factory2.createNodeArray([
+            factory2.createClassStaticBlockDeclaration(
+              factory2.createBlock([
+                factory2.createExpressionStatement(
+                  factory2.createAssignment(classAlias, factory2.createThis())
+                )
+              ])
+            ),
+            ...members
+          ]),
+          members
+        );
       }
       const classExpression = factory2.createClassExpression(
         modifiers,
@@ -192668,39 +177110,36 @@ ${lanes.join("\n")}
       );
       setOriginalNode(classExpression, node);
       setTextRange(classExpression, location);
+      const varInitializer = classAlias && !assignClassAliasInStaticBlock ? factory2.createAssignment(classAlias, classExpression) : classExpression;
       const varDecl = factory2.createVariableDeclaration(
         declName,
         /*exclamationToken*/
         void 0,
         /*type*/
         void 0,
-        classAlias && !assignClassAliasInStaticBlock ? factory2.createAssignment(classAlias, classExpression) : classExpression
+        varInitializer
       );
       setOriginalNode(varDecl, node);
-      let varModifiers;
-      if (isExport && !isDefault) {
-        varModifiers = factory2.createModifiersFromModifierFlags(1 /* Export */);
-      }
-      const statement = factory2.createVariableStatement(
-        varModifiers,
-        factory2.createVariableDeclarationList([
-          varDecl
-        ], 1 /* Let */)
+      const varDeclList = factory2.createVariableDeclarationList([varDecl], 1 /* Let */);
+      const varStatement = factory2.createVariableStatement(
+        /*modifiers*/
+        void 0,
+        varDeclList
       );
-      setOriginalNode(statement, node);
-      setTextRange(statement, location);
-      setCommentRange(statement, node);
-      const statements = [statement];
+      setOriginalNode(varStatement, node);
+      setTextRange(varStatement, location);
+      setCommentRange(varStatement, node);
+      const statements = [varStatement];
       addRange(statements, decorationStatements);
       addConstructorDecorationStatement(statements, node);
-      if (isExport && isDefault) {
-        statements.push(factory2.createExportAssignment(
-          /*modifiers*/
-          void 0,
-          /*isExportEquals*/
-          false,
-          declName
-        ));
+      if (isExport) {
+        if (isDefault) {
+          const exportStatement = factory2.createExportDefault(declName);
+          statements.push(exportStatement);
+        } else {
+          const exportStatement = factory2.createExternalModuleExport(factory2.getDeclarationName(node));
+          statements.push(exportStatement);
+        }
       }
       return statements;
     }
@@ -192731,55 +177170,67 @@ ${lanes.join("\n")}
       return updated;
     }
     function visitMethodDeclaration(node) {
-      return finishClassElement(factory2.updateMethodDeclaration(
-        node,
-        visitNodes2(node.modifiers, modifierVisitor, isModifier),
-        node.asteriskToken,
-        Debug.checkDefined(visitNode(node.name, visitor, isPropertyName)),
-        /*questionToken*/
-        void 0,
-        /*typeParameters*/
-        void 0,
-        visitNodes2(node.parameters, visitor, isParameter),
-        /*type*/
-        void 0,
-        visitNode(node.body, visitor, isBlock)
-      ), node);
+      return finishClassElement(
+        factory2.updateMethodDeclaration(
+          node,
+          visitNodes2(node.modifiers, modifierVisitor, isModifier),
+          node.asteriskToken,
+          Debug.checkDefined(visitNode(node.name, visitor, isPropertyName)),
+          /*questionToken*/
+          void 0,
+          /*typeParameters*/
+          void 0,
+          visitNodes2(node.parameters, visitor, isParameter),
+          /*type*/
+          void 0,
+          visitNode(node.body, visitor, isBlock)
+        ),
+        node
+      );
     }
     function visitGetAccessorDeclaration(node) {
-      return finishClassElement(factory2.updateGetAccessorDeclaration(
-        node,
-        visitNodes2(node.modifiers, modifierVisitor, isModifier),
-        Debug.checkDefined(visitNode(node.name, visitor, isPropertyName)),
-        visitNodes2(node.parameters, visitor, isParameter),
-        /*type*/
-        void 0,
-        visitNode(node.body, visitor, isBlock)
-      ), node);
+      return finishClassElement(
+        factory2.updateGetAccessorDeclaration(
+          node,
+          visitNodes2(node.modifiers, modifierVisitor, isModifier),
+          Debug.checkDefined(visitNode(node.name, visitor, isPropertyName)),
+          visitNodes2(node.parameters, visitor, isParameter),
+          /*type*/
+          void 0,
+          visitNode(node.body, visitor, isBlock)
+        ),
+        node
+      );
     }
     function visitSetAccessorDeclaration(node) {
-      return finishClassElement(factory2.updateSetAccessorDeclaration(
-        node,
-        visitNodes2(node.modifiers, modifierVisitor, isModifier),
-        Debug.checkDefined(visitNode(node.name, visitor, isPropertyName)),
-        visitNodes2(node.parameters, visitor, isParameter),
-        visitNode(node.body, visitor, isBlock)
-      ), node);
+      return finishClassElement(
+        factory2.updateSetAccessorDeclaration(
+          node,
+          visitNodes2(node.modifiers, modifierVisitor, isModifier),
+          Debug.checkDefined(visitNode(node.name, visitor, isPropertyName)),
+          visitNodes2(node.parameters, visitor, isParameter),
+          visitNode(node.body, visitor, isBlock)
+        ),
+        node
+      );
     }
     function visitPropertyDeclaration(node) {
-      if (node.flags & 16777216 /* Ambient */ || hasSyntacticModifier(node, 2 /* Ambient */)) {
+      if (node.flags & 33554432 /* Ambient */ || hasSyntacticModifier(node, 128 /* Ambient */)) {
         return void 0;
       }
-      return finishClassElement(factory2.updatePropertyDeclaration(
-        node,
-        visitNodes2(node.modifiers, modifierVisitor, isModifier),
-        Debug.checkDefined(visitNode(node.name, visitor, isPropertyName)),
-        /*questionOrExclamationToken*/
-        void 0,
-        /*type*/
-        void 0,
-        visitNode(node.initializer, visitor, isExpression)
-      ), node);
+      return finishClassElement(
+        factory2.updatePropertyDeclaration(
+          node,
+          visitNodes2(node.modifiers, modifierVisitor, isModifier),
+          Debug.checkDefined(visitNode(node.name, visitor, isPropertyName)),
+          /*questionOrExclamationToken*/
+          void 0,
+          /*type*/
+          void 0,
+          visitNode(node.initializer, visitor, isExpression)
+        ),
+        node
+      );
     }
     function visitParameterDeclaration(node) {
       const updated = factory2.updateParameterDeclaration(
@@ -192852,7 +177303,7 @@ ${lanes.join("\n")}
       const memberName = getExpressionForPropertyName(
         member,
         /*generateNameForComputedPropertyName*/
-        !hasSyntacticModifier(member, 2 /* Ambient */)
+        !hasSyntacticModifier(member, 128 /* Ambient */)
       );
       const descriptor = languageVersion > 0 /* ES3 */ ? isPropertyDeclaration(member) && !hasAccessorModifier(member) ? factory2.createVoidZero() : factory2.createNull() : void 0;
       const helper = emitHelpers().createDecorateHelper(
@@ -192935,7 +177386,7 @@ ${lanes.join("\n")}
       }
     }
     function getClassAliasIfNeeded(node) {
-      if (resolver.getNodeCheckFlags(node) & 1048576 /* ClassWithConstructorReference */) {
+      if (resolver.getNodeCheckFlags(node) & 262144 /* ContainsConstructorReference */) {
         enableSubstitutionForClassAliases();
         const classAlias = factory2.createUniqueName(node.name && !isGeneratedIdentifier(node.name) ? idText(node.name) : "default");
         classAliases[getOriginalNodeId(node)] = classAlias;
@@ -192968,7 +177419,7 @@ ${lanes.join("\n")}
     }
     function trySubstituteClassAlias(node) {
       if (classAliases) {
-        if (resolver.getNodeCheckFlags(node) & 2097152 /* ConstructorReferenceInClass */) {
+        if (resolver.getNodeCheckFlags(node) & 536870912 /* ConstructorReference */) {
           const declaration = resolver.getReferencedValueDeclaration(node);
           if (declaration) {
             const classAlias = classAliases[declaration.id];
@@ -193000,8 +177451,7 @@ ${lanes.join("\n")}
       endLexicalEnvironment,
       hoistVariableDeclaration
     } = context;
-    const compilerOptions = context.getCompilerOptions();
-    const languageVersion = getEmitScriptTarget(compilerOptions);
+    const languageVersion = getEmitScriptTarget(context.getCompilerOptions());
     let top;
     let classInfo;
     let classThis;
@@ -193113,86 +177563,78 @@ ${lanes.join("\n")}
         return node;
       }
       switch (node.kind) {
-        case 169 /* Decorator */:
+        case 170 /* Decorator */:
           return Debug.fail("Use `modifierVisitor` instead.");
-        case 262 /* ClassDeclaration */:
+        case 263 /* ClassDeclaration */:
           return visitClassDeclaration(node);
-        case 230 /* ClassExpression */:
-          return visitClassExpression(
-            node,
-            /*referencedName*/
-            void 0
-          );
-        case 175 /* Constructor */:
-        case 171 /* PropertyDeclaration */:
-        case 174 /* ClassStaticBlockDeclaration */:
+        case 231 /* ClassExpression */:
+          return visitClassExpression(node);
+        case 176 /* Constructor */:
+        case 172 /* PropertyDeclaration */:
+        case 175 /* ClassStaticBlockDeclaration */:
           return Debug.fail("Not supported outside of a class. Use 'classElementVisitor' instead.");
-        case 168 /* Parameter */:
+        case 169 /* Parameter */:
           return visitParameterDeclaration(node);
-        case 225 /* BinaryExpression */:
+        case 226 /* BinaryExpression */:
           return visitBinaryExpression(
             node,
             /*discarded*/
             false
           );
-        case 302 /* PropertyAssignment */:
+        case 303 /* PropertyAssignment */:
           return visitPropertyAssignment(node);
-        case 259 /* VariableDeclaration */:
+        case 260 /* VariableDeclaration */:
           return visitVariableDeclaration(node);
-        case 207 /* BindingElement */:
+        case 208 /* BindingElement */:
           return visitBindingElement(node);
-        case 276 /* ExportAssignment */:
+        case 277 /* ExportAssignment */:
           return visitExportAssignment(node);
         case 110 /* ThisKeyword */:
           return visitThisExpression(node);
-        case 247 /* ForStatement */:
+        case 248 /* ForStatement */:
           return visitForStatement(node);
-        case 243 /* ExpressionStatement */:
+        case 244 /* ExpressionStatement */:
           return visitExpressionStatement(node);
-        case 360 /* CommaListExpression */:
+        case 361 /* CommaListExpression */:
           return visitCommaListExpression(
             node,
             /*discarded*/
             false
           );
-        case 216 /* ParenthesizedExpression */:
+        case 217 /* ParenthesizedExpression */:
           return visitParenthesizedExpression(
             node,
             /*discarded*/
-            false,
-            /*referencedName*/
-            void 0
+            false
           );
-        case 359 /* PartiallyEmittedExpression */:
+        case 360 /* PartiallyEmittedExpression */:
           return visitPartiallyEmittedExpression(
             node,
             /*discarded*/
-            false,
-            /*referencedName*/
-            void 0
+            false
           );
-        case 212 /* CallExpression */:
+        case 213 /* CallExpression */:
           return visitCallExpression(node);
-        case 214 /* TaggedTemplateExpression */:
+        case 215 /* TaggedTemplateExpression */:
           return visitTaggedTemplateExpression(node);
-        case 223 /* PrefixUnaryExpression */:
-        case 224 /* PostfixUnaryExpression */:
+        case 224 /* PrefixUnaryExpression */:
+        case 225 /* PostfixUnaryExpression */:
           return visitPreOrPostfixUnaryExpression(
             node,
             /*discarded*/
             false
           );
-        case 210 /* PropertyAccessExpression */:
+        case 211 /* PropertyAccessExpression */:
           return visitPropertyAccessExpression(node);
-        case 211 /* ElementAccessExpression */:
+        case 212 /* ElementAccessExpression */:
           return visitElementAccessExpression(node);
-        case 166 /* ComputedPropertyName */:
+        case 167 /* ComputedPropertyName */:
           return visitComputedPropertyName(node);
-        case 173 /* MethodDeclaration */:
-        case 177 /* SetAccessor */:
-        case 176 /* GetAccessor */:
-        case 217 /* FunctionExpression */:
-        case 261 /* FunctionDeclaration */: {
+        case 174 /* MethodDeclaration */:
+        case 178 /* SetAccessor */:
+        case 177 /* GetAccessor */:
+        case 218 /* FunctionExpression */:
+        case 262 /* FunctionDeclaration */: {
           enterOther();
           const result = visitEachChild(node, fallbackVisitor, context);
           exitOther();
@@ -193204,7 +177646,7 @@ ${lanes.join("\n")}
     }
     function fallbackVisitor(node) {
       switch (node.kind) {
-        case 169 /* Decorator */:
+        case 170 /* Decorator */:
           return void 0;
         default:
           return visitor(node);
@@ -193212,7 +177654,7 @@ ${lanes.join("\n")}
     }
     function modifierVisitor(node) {
       switch (node.kind) {
-        case 169 /* Decorator */:
+        case 170 /* Decorator */:
           return void 0;
         default:
           return node;
@@ -193220,72 +177662,48 @@ ${lanes.join("\n")}
     }
     function classElementVisitor(node) {
       switch (node.kind) {
-        case 175 /* Constructor */:
+        case 176 /* Constructor */:
           return visitConstructorDeclaration(node);
-        case 173 /* MethodDeclaration */:
+        case 174 /* MethodDeclaration */:
           return visitMethodDeclaration(node);
-        case 176 /* GetAccessor */:
+        case 177 /* GetAccessor */:
           return visitGetAccessorDeclaration(node);
-        case 177 /* SetAccessor */:
+        case 178 /* SetAccessor */:
           return visitSetAccessorDeclaration(node);
-        case 171 /* PropertyDeclaration */:
+        case 172 /* PropertyDeclaration */:
           return visitPropertyDeclaration(node);
-        case 174 /* ClassStaticBlockDeclaration */:
+        case 175 /* ClassStaticBlockDeclaration */:
           return visitClassStaticBlockDeclaration(node);
         default:
           return visitor(node);
       }
     }
-    function namedEvaluationVisitor(node, referencedName) {
-      switch (node.kind) {
-        case 359 /* PartiallyEmittedExpression */:
-          return visitPartiallyEmittedExpression(
-            node,
-            /*discarded*/
-            false,
-            referencedName
-          );
-        case 216 /* ParenthesizedExpression */:
-          return visitParenthesizedExpression(
-            node,
-            /*discarded*/
-            false,
-            referencedName
-          );
-        case 230 /* ClassExpression */:
-          return visitClassExpression(node, referencedName);
-        default:
-          return visitor(node);
-      }
-    }
     function discardedValueVisitor(node) {
       switch (node.kind) {
-        case 223 /* PrefixUnaryExpression */:
-        case 224 /* PostfixUnaryExpression */:
+        case 224 /* PrefixUnaryExpression */:
+        case 225 /* PostfixUnaryExpression */:
           return visitPreOrPostfixUnaryExpression(
             node,
             /*discarded*/
             true
           );
-        case 225 /* BinaryExpression */:
+        case 226 /* BinaryExpression */:
           return visitBinaryExpression(
             node,
             /*discarded*/
             true
           );
-        case 360 /* CommaListExpression */:
+        case 361 /* CommaListExpression */:
           return visitCommaListExpression(
             node,
             /*discarded*/
             true
           );
-        case 216 /* ParenthesizedExpression */:
+        case 217 /* ParenthesizedExpression */:
           return visitParenthesizedExpression(
             node,
             /*discarded*/
-            true,
-            /*referencedName*/
-            void 0
+            true
           );
         default:
           return visitor(node);
@@ -193323,6 +177741,7 @@ ${lanes.join("\n")}
       );
     }
     function createClassInfo(node) {
+      const metadataReference = factory2.createUniqueName("_metadata", 16 /* Optimistic */ | 32 /* FileLevel */);
       let instanceExtraInitializersName;
       let staticExtraInitializersName;
       let hasStaticInitializers = false;
@@ -193336,13 +177755,15 @@ ${lanes.join("\n")}
           node
         )) {
           if (hasStaticModifier(member)) {
-            staticExtraInitializersName ?? (staticExtraInitializersName = factory2.createUniqueName("_staticExtraInitializers", 16 /* Optimistic */));
+            staticExtraInitializersName ?? (staticExtraInitializersName = factory2.createUniqueName("_staticExtraInitializers", 16 /* Optimistic */ | 32 /* FileLevel */));
           } else {
-            instanceExtraInitializersName ?? (instanceExtraInitializersName = factory2.createUniqueName("_instanceExtraInitializers", 16 /* Optimistic */));
+            instanceExtraInitializersName ?? (instanceExtraInitializersName = factory2.createUniqueName("_instanceExtraInitializers", 16 /* Optimistic */ | 32 /* FileLevel */));
           }
         }
         if (isClassStaticBlockDeclaration(member)) {
-          hasStaticInitializers = true;
+          if (!isClassNamedEvaluationHelperBlock(member)) {
+            hasStaticInitializers = true;
+          }
         } else if (isPropertyDeclaration(member)) {
           if (hasStaticModifier(member)) {
             hasStaticInitializers || (hasStaticInitializers = !!member.initializer || hasDecorators(member));
@@ -193359,6 +177780,7 @@ ${lanes.join("\n")}
       }
       return {
         class: node,
+        metadataReference,
         instanceExtraInitializersName,
         staticExtraInitializersName,
         hasStaticInitializers,
@@ -193366,19 +177788,15 @@ ${lanes.join("\n")}
         hasStaticPrivateClassElements
       };
     }
-    function containsLexicalSuperInStaticInitializer(node) {
-      for (const member of node.members) {
-        if (isClassStaticBlockDeclaration(member) || isPropertyDeclaration(member) && hasStaticModifier(member)) {
-          if (member.transformFlags & 134217728 /* ContainsLexicalSuper */) {
-            return true;
-          }
-        }
-      }
-      return false;
-    }
-    function transformClassLike(node, className) {
-      var _a;
+    function transformClassLike(node) {
       startLexicalEnvironment();
+      if (!classHasDeclaredOrExplicitlyAssignedName(node) && classOrConstructorParameterIsDecorated(
+        /*useLegacyDecorators*/
+        false,
+        node
+      )) {
+        node = injectClassNamedEvaluationHelperBlockIfMissing(context, node, factory2.createStringLiteral(""));
+      }
       const classReference = factory2.getLocalName(
         node,
         /*allowComments*/
@@ -193397,10 +177815,14 @@ ${lanes.join("\n")}
       let shouldTransformPrivateStaticElementsInClass = false;
       const classDecorators = transformAllDecoratorsOfDeclaration(getAllDecoratorsOfClass(node));
       if (classDecorators) {
-        classInfo2.classDecoratorsName = factory2.createUniqueName("_classDecorators", 16 /* Optimistic */);
-        classInfo2.classDescriptorName = factory2.createUniqueName("_classDescriptor", 16 /* Optimistic */);
-        classInfo2.classExtraInitializersName = factory2.createUniqueName("_classExtraInitializers", 16 /* Optimistic */);
-        classInfo2.classThis = factory2.createUniqueName("_classThis", 16 /* Optimistic */);
+        classInfo2.classDecoratorsName = factory2.createUniqueName("_classDecorators", 16 /* Optimistic */ | 32 /* FileLevel */);
+        classInfo2.classDescriptorName = factory2.createUniqueName("_classDescriptor", 16 /* Optimistic */ | 32 /* FileLevel */);
+        classInfo2.classExtraInitializersName = factory2.createUniqueName("_classExtraInitializers", 16 /* Optimistic */ | 32 /* FileLevel */);
+        const needsUniqueClassThis = some(node.members, (member) => (isPrivateIdentifierClassElementDeclaration(member) || isAutoAccessorPropertyDeclaration(member)) && hasStaticModifier(member));
+        classInfo2.classThis = factory2.createUniqueName(
+          "_classThis",
+          needsUniqueClassThis ? 16 /* Optimistic */ | 8 /* ReservedInNestedScopes */ : 16 /* Optimistic */ | 32 /* FileLevel */
+        );
         classDefinitionStatements.push(
           createLet(classInfo2.classDecoratorsName, factory2.createArrayLiteralExpression(classDecorators)),
           createLet(classInfo2.classDescriptorName),
@@ -193412,34 +177834,26 @@ ${lanes.join("\n")}
           shouldTransformPrivateStaticElementsInFile = true;
         }
       }
-      if (classDecorators && containsLexicalSuperInStaticInitializer(node)) {
-        const extendsClause = getHeritageClause(node.heritageClauses, 96 /* ExtendsKeyword */);
-        const extendsElement = extendsClause && firstOrUndefined(extendsClause.types);
-        const extendsExpression = extendsElement && visitNode(extendsElement.expression, visitor, isExpression);
-        if (extendsExpression) {
-          classInfo2.classSuper = factory2.createUniqueName("_classSuper", 16 /* Optimistic */);
-          const unwrapped = skipOuterExpressions(extendsExpression);
-          const safeExtendsExpression = isClassExpression(unwrapped) && !unwrapped.name || isFunctionExpression(unwrapped) && !unwrapped.name || isArrowFunction(unwrapped) ? factory2.createComma(factory2.createNumericLiteral(0), extendsExpression) : extendsExpression;
-          classDefinitionStatements.push(createLet(classInfo2.classSuper, safeExtendsExpression));
-          const updatedExtendsElement = factory2.updateExpressionWithTypeArguments(
-            extendsElement,
-            classInfo2.classSuper,
-            /*typeArguments*/
-            void 0
-          );
-          const updatedExtendsClause = factory2.updateHeritageClause(extendsClause, [updatedExtendsElement]);
-          heritageClauses = factory2.createNodeArray([updatedExtendsClause]);
-        }
-      } else {
-        heritageClauses = visitNodes2(node.heritageClauses, visitor, isHeritageClause);
+      const extendsClause = getHeritageClause(node.heritageClauses, 96 /* ExtendsKeyword */);
+      const extendsElement = extendsClause && firstOrUndefined(extendsClause.types);
+      const extendsExpression = extendsElement && visitNode(extendsElement.expression, visitor, isExpression);
+      if (extendsExpression) {
+        classInfo2.classSuper = factory2.createUniqueName("_classSuper", 16 /* Optimistic */ | 32 /* FileLevel */);
+        const unwrapped = skipOuterExpressions(extendsExpression);
+        const safeExtendsExpression = isClassExpression(unwrapped) && !unwrapped.name || isFunctionExpression(unwrapped) && !unwrapped.name || isArrowFunction(unwrapped) ? factory2.createComma(factory2.createNumericLiteral(0), extendsExpression) : extendsExpression;
+        classDefinitionStatements.push(createLet(classInfo2.classSuper, safeExtendsExpression));
+        const updatedExtendsElement = factory2.updateExpressionWithTypeArguments(
+          extendsElement,
+          classInfo2.classSuper,
+          /*typeArguments*/
+          void 0
+        );
+        const updatedExtendsClause = factory2.updateHeritageClause(extendsClause, [updatedExtendsElement]);
+        heritageClauses = factory2.createNodeArray([updatedExtendsClause]);
       }
       const renamedClassThis = classInfo2.classThis ?? factory2.createThis();
-      const needsSetNameHelper = !((_a = getOriginalNode(node, isClassLike)) == null ? void 0 : _a.name) && (classDecorators || !isStringLiteral(className) || !isEmptyStringLiteral(className));
-      if (needsSetNameHelper) {
-        const setNameExpr = emitHelpers().createSetFunctionNameHelper(factory2.createThis(), className);
-        leadingBlockStatements = append(leadingBlockStatements, factory2.createExpressionStatement(setNameExpr));
-      }
       enterClass(classInfo2);
+      leadingBlockStatements = append(leadingBlockStatements, createMetadata(classInfo2.metadataReference, classInfo2.classSuper));
       let members = visitNodes2(node.members, classElementVisitor, isClassElement);
       if (pendingExpressions) {
         let outerThis;
@@ -193537,15 +177951,15 @@ ${lanes.join("\n")}
       leadingBlockStatements = addRange(leadingBlockStatements, classInfo2.nonStaticFieldDecorationStatements);
       if (classInfo2.classDescriptorName && classInfo2.classDecoratorsName && classInfo2.classExtraInitializersName && classInfo2.classThis) {
         leadingBlockStatements ?? (leadingBlockStatements = []);
-        const valueProperty = factory2.createPropertyAssignment("value", factory2.createThis());
+        const valueProperty = factory2.createPropertyAssignment("value", renamedClassThis);
         const classDescriptor = factory2.createObjectLiteralExpression([valueProperty]);
         const classDescriptorAssignment = factory2.createAssignment(classInfo2.classDescriptorName, classDescriptor);
-        const classNameReference = factory2.createPropertyAccessExpression(factory2.createThis(), "name");
+        const classNameReference = factory2.createPropertyAccessExpression(renamedClassThis, "name");
         const esDecorateHelper2 = emitHelpers().createESDecorateHelper(
           factory2.createNull(),
           classDescriptorAssignment,
           classInfo2.classDecoratorsName,
-          { kind: "class", name: classNameReference },
+          { kind: "class", name: classNameReference, metadata: classInfo2.metadataReference },
           factory2.createNull(),
           classInfo2.classExtraInitializersName
         );
@@ -193557,6 +177971,7 @@ ${lanes.join("\n")}
         const classReferenceAssignment = factory2.createAssignment(classReference, classThisAssignment);
         leadingBlockStatements.push(factory2.createExpressionStatement(classReferenceAssignment));
       }
+      leadingBlockStatements.push(createSymbolMetadata(renamedClassThis, classInfo2.metadataReference));
       if (classInfo2.staticExtraInitializersName) {
         const runStaticInitializersHelper = emitHelpers().createRunInitializersHelper(renamedClassThis, classInfo2.staticExtraInitializersName);
         const runStaticInitializersStatement = factory2.createExpressionStatement(runStaticInitializersHelper);
@@ -193573,32 +177988,35 @@ ${lanes.join("\n")}
         addRange(leadingBlockStatements, trailingBlockStatements);
         trailingBlockStatements = void 0;
       }
-      let newMembers = members;
-      if (leadingBlockStatements) {
-        const leadingStaticBlockBody = factory2.createBlock(
-          leadingBlockStatements,
-          /*multiLine*/
-          true
-        );
-        const leadingStaticBlock = factory2.createClassStaticBlockDeclaration(leadingStaticBlockBody);
-        if (shouldTransformPrivateStaticElementsInClass) {
-          setInternalEmitFlags(leadingStaticBlock, 32 /* TransformPrivateStaticElements */);
-        }
-        newMembers = [leadingStaticBlock, ...newMembers];
-      }
-      if (syntheticConstructor) {
-        newMembers = [...newMembers, syntheticConstructor];
-      }
-      if (trailingBlockStatements) {
-        const trailingStaticBlockBody = factory2.createBlock(
-          trailingBlockStatements,
-          /*multiLine*/
-          true
-        );
-        const trailingStaticBlock = factory2.createClassStaticBlockDeclaration(trailingStaticBlockBody);
-        newMembers = [...newMembers, trailingStaticBlock];
+      const leadingStaticBlock = leadingBlockStatements && factory2.createClassStaticBlockDeclaration(factory2.createBlock(
+        leadingBlockStatements,
+        /*multiLine*/
+        true
+      ));
+      if (leadingStaticBlock && shouldTransformPrivateStaticElementsInClass) {
+        setInternalEmitFlags(leadingStaticBlock, 32 /* TransformPrivateStaticElements */);
       }
-      if (newMembers !== members) {
+      const trailingStaticBlock = trailingBlockStatements && factory2.createClassStaticBlockDeclaration(factory2.createBlock(
+        trailingBlockStatements,
+        /*multiLine*/
+        true
+      ));
+      if (leadingStaticBlock || syntheticConstructor || trailingStaticBlock) {
+        const newMembers = [];
+        const existingNamedEvaluationHelperBlockIndex = members.findIndex(isClassNamedEvaluationHelperBlock);
+        if (leadingStaticBlock) {
+          addRange(newMembers, members, 0, existingNamedEvaluationHelperBlockIndex + 1);
+          newMembers.push(leadingStaticBlock);
+          addRange(newMembers, members, existingNamedEvaluationHelperBlockIndex + 1);
+        } else {
+          addRange(newMembers, members);
+        }
+        if (syntheticConstructor) {
+          newMembers.push(syntheticConstructor);
+        }
+        if (trailingStaticBlock) {
+          newMembers.push(trailingStaticBlock);
+        }
         members = setTextRange(factory2.createNodeArray(newMembers), members);
       }
       const lexicalEnvironment = endLexicalEnvironment();
@@ -193614,6 +178032,9 @@ ${lanes.join("\n")}
           heritageClauses,
           members
         );
+        if (classInfo2.classThis) {
+          classExpression = injectClassThisAssignmentIfMissing(factory2, classExpression, classInfo2.classThis);
+        }
         const classReferenceDeclaration = factory2.createVariableDeclaration(
           classReference,
           /*exclamationToken*/
@@ -193653,7 +178074,6 @@ ${lanes.join("\n")}
         }
       }
       setOriginalNode(classExpression, node);
-      getOrCreateEmitNode(classExpression).classThis = classInfo2.classThis;
       return factory2.createImmediatelyInvokedArrowFunction(factory2.mergeLexicalEnvironment(classDefinitionStatements, lexicalEnvironment));
     }
     function isDecoratedClassLike(node) {
@@ -193669,26 +178089,51 @@ ${lanes.join("\n")}
     }
     function visitClassDeclaration(node) {
       if (isDecoratedClassLike(node)) {
-        if (hasSyntacticModifier(node, 1 /* Export */) && hasSyntacticModifier(node, 1024 /* Default */)) {
-          const originalClass = getOriginalNode(node, isClassLike) ?? node;
-          const className = originalClass.name ? factory2.createStringLiteralFromNode(originalClass.name) : factory2.createStringLiteral("default");
-          const iife = transformClassLike(node, className);
-          const statement = factory2.createExportDefault(iife);
-          setOriginalNode(statement, node);
-          setCommentRange(statement, getCommentRange(node));
-          setSourceMapRange(statement, moveRangePastDecorators(node));
-          return statement;
+        const statements = [];
+        const originalClass = getOriginalNode(node, isClassLike) ?? node;
+        const className = originalClass.name ? factory2.createStringLiteralFromNode(originalClass.name) : factory2.createStringLiteral("default");
+        const isExport = hasSyntacticModifier(node, 32 /* Export */);
+        const isDefault = hasSyntacticModifier(node, 2048 /* Default */);
+        if (!node.name) {
+          node = injectClassNamedEvaluationHelperBlockIfMissing(context, node, className);
+        }
+        if (isExport && isDefault) {
+          const iife = transformClassLike(node);
+          if (node.name) {
+            const varDecl = factory2.createVariableDeclaration(
+              factory2.getLocalName(node),
+              /*exclamationToken*/
+              void 0,
+              /*type*/
+              void 0,
+              iife
+            );
+            setOriginalNode(varDecl, node);
+            const varDecls = factory2.createVariableDeclarationList([varDecl], 1 /* Let */);
+            const varStatement = factory2.createVariableStatement(
+              /*modifiers*/
+              void 0,
+              varDecls
+            );
+            statements.push(varStatement);
+            const exportStatement = factory2.createExportDefault(factory2.getDeclarationName(node));
+            setOriginalNode(exportStatement, node);
+            setCommentRange(exportStatement, getCommentRange(node));
+            setSourceMapRange(exportStatement, moveRangePastDecorators(node));
+            statements.push(exportStatement);
+          } else {
+            const exportStatement = factory2.createExportDefault(iife);
+            setOriginalNode(exportStatement, node);
+            setCommentRange(exportStatement, getCommentRange(node));
+            setSourceMapRange(exportStatement, moveRangePastDecorators(node));
+            statements.push(exportStatement);
+          }
         } else {
           Debug.assertIsDefined(node.name, "A class declaration that is not a default export must have a name.");
-          const iife = transformClassLike(node, factory2.createStringLiteralFromNode(node.name));
-          const modifiers = visitNodes2(node.modifiers, modifierVisitor, isModifier);
-          const declName = languageVersion <= 2 /* ES2015 */ ? factory2.getInternalName(
-            node,
-            /*allowComments*/
-            false,
-            /*allowSourceMaps*/
-            true
-          ) : factory2.getLocalName(
+          const iife = transformClassLike(node);
+          const modifierVisitorNoExport = isExport ? (node2) => isExportModifier(node2) ? void 0 : modifierVisitor(node2) : modifierVisitor;
+          const modifiers = visitNodes2(node.modifiers, modifierVisitorNoExport, isModifier);
+          const declName = factory2.getLocalName(
             node,
             /*allowComments*/
             false,
@@ -193705,11 +178150,17 @@ ${lanes.join("\n")}
           );
           setOriginalNode(varDecl, node);
           const varDecls = factory2.createVariableDeclarationList([varDecl], 1 /* Let */);
-          const statement = factory2.createVariableStatement(modifiers, varDecls);
-          setOriginalNode(statement, node);
-          setCommentRange(statement, getCommentRange(node));
-          return statement;
+          const varStatement = factory2.createVariableStatement(modifiers, varDecls);
+          setOriginalNode(varStatement, node);
+          setCommentRange(varStatement, getCommentRange(node));
+          statements.push(varStatement);
+          if (isExport) {
+            const exportStatement = factory2.createExternalModuleExport(declName);
+            setOriginalNode(exportStatement, node);
+            statements.push(exportStatement);
+          }
         }
+        return singleOrMany(statements);
       } else {
         const modifiers = visitNodes2(node.modifiers, modifierVisitor, isModifier);
         const heritageClauses = visitNodes2(node.heritageClauses, visitor, isHeritageClause);
@@ -193730,10 +178181,9 @@ ${lanes.join("\n")}
         );
       }
     }
-    function visitClassExpression(node, referencedName) {
+    function visitClassExpression(node) {
       if (isDecoratedClassLike(node)) {
-        const className = node.name ? factory2.createStringLiteralFromNode(node.name) : referencedName ?? factory2.createStringLiteral("");
-        const iife = transformClassLike(node, className);
+        const iife = transformClassLike(node);
         setOriginalNode(iife, node);
         return iife;
       } else {
@@ -193770,6 +178220,35 @@ ${lanes.join("\n")}
         return statements;
       }
     }
+    function transformConstructorBodyWorker(statementsOut, statementsIn, statementOffset, superPath, superPathDepth, initializerStatements) {
+      const superStatementIndex = superPath[superPathDepth];
+      const superStatement = statementsIn[superStatementIndex];
+      addRange(statementsOut, visitNodes2(statementsIn, visitor, isStatement, statementOffset, superStatementIndex - statementOffset));
+      if (isTryStatement(superStatement)) {
+        const tryBlockStatements = [];
+        transformConstructorBodyWorker(
+          tryBlockStatements,
+          superStatement.tryBlock.statements,
+          /*statementOffset*/
+          0,
+          superPath,
+          superPathDepth + 1,
+          initializerStatements
+        );
+        const tryBlockStatementsArray = factory2.createNodeArray(tryBlockStatements);
+        setTextRange(tryBlockStatementsArray, superStatement.tryBlock.statements);
+        statementsOut.push(factory2.updateTryStatement(
+          superStatement,
+          factory2.updateBlock(superStatement.tryBlock, tryBlockStatements),
+          visitNode(superStatement.catchClause, visitor, isCatchClause),
+          visitNode(superStatement.finallyBlock, visitor, isBlock)
+        ));
+      } else {
+        addRange(statementsOut, visitNodes2(statementsIn, visitor, isStatement, superStatementIndex, 1));
+        addRange(statementsOut, initializerStatements);
+      }
+      addRange(statementsOut, visitNodes2(statementsIn, visitor, isStatement, superStatementIndex + 1));
+    }
     function visitConstructorDeclaration(node) {
       enterClassElement(node);
       const modifiers = visitNodes2(node.modifiers, modifierVisitor, isModifier);
@@ -193786,11 +178265,9 @@ ${lanes.join("\n")}
             false,
             visitor
           );
-          const superStatementIndex = findSuperStatementIndex(node.body.statements, nonPrologueStart);
-          if (superStatementIndex >= 0) {
-            addRange(statements, visitNodes2(node.body.statements, visitor, isStatement, nonPrologueStart, superStatementIndex + 1 - nonPrologueStart));
-            addRange(statements, initializerStatements);
-            addRange(statements, visitNodes2(node.body.statements, visitor, isStatement, superStatementIndex + 1));
+          const superStatementIndices = findSuperStatementIndexPath(node.body.statements, nonPrologueStart);
+          if (superStatementIndices.length > 0) {
+            transformConstructorBodyWorker(statements, node.body.statements, nonPrologueStart, superStatementIndices, 0, initializerStatements);
           } else {
             addRange(statements, initializerStatements);
             addRange(statements, visitNodes2(node.body.statements, visitor, isStatement));
@@ -193815,7 +178292,7 @@ ${lanes.join("\n")}
       }
       return updated;
     }
-    function partialTransformClassElement(member, useNamedEvaluation, classInfo2, createDescriptor) {
+    function partialTransformClassElement(member, classInfo2, createDescriptor) {
       let referencedName;
       let name;
       let initializersName;
@@ -193824,11 +178301,7 @@ ${lanes.join("\n")}
       if (!classInfo2) {
         const modifiers2 = visitNodes2(member.modifiers, modifierVisitor, isModifier);
         enterName();
-        if (useNamedEvaluation) {
-          ({ referencedName, name } = visitReferencedPropertyName(member.name));
-        } else {
-          name = visitPropertyName(member.name);
-        }
+        name = visitPropertyName(member.name);
         exitName();
         return { modifiers: modifiers2, referencedName, name, initializersName, descriptorName, thisArg };
       }
@@ -193877,9 +178350,10 @@ ${lanes.join("\n")}
             get: isPropertyDeclaration(member) || isGetAccessorDeclaration(member) || isMethodDeclaration(member),
             // 3. If _kind_ is ~field~, ~accessor~, or ~setter~, then ...
             set: isPropertyDeclaration(member) || isSetAccessorDeclaration(member)
-          }
+          },
+          metadata: classInfo2.metadataReference
         };
-        const extraInitializers = isStatic(member) ? classInfo2.staticExtraInitializersName ?? (classInfo2.staticExtraInitializersName = factory2.createUniqueName("_staticExtraInitializers", 16 /* Optimistic */)) : classInfo2.instanceExtraInitializersName ?? (classInfo2.instanceExtraInitializersName = factory2.createUniqueName("_instanceExtraInitializers", 16 /* Optimistic */));
+        const extraInitializers = isStatic(member) ? classInfo2.staticExtraInitializersName ?? (classInfo2.staticExtraInitializersName = factory2.createUniqueName("_staticExtraInitializers", 16 /* Optimistic */ | 32 /* FileLevel */)) : classInfo2.instanceExtraInitializersName ?? (classInfo2.instanceExtraInitializersName = factory2.createUniqueName("_instanceExtraInitializers", 16 /* Optimistic */ | 32 /* FileLevel */));
         if (isMethodOrAccessor(member)) {
           let descriptor;
           if (isPrivateIdentifierClassElementDeclaration(member) && createDescriptor) {
@@ -193921,11 +178395,7 @@ ${lanes.join("\n")}
       }
       if (name === void 0) {
         enterName();
-        if (useNamedEvaluation) {
-          ({ referencedName, name } = visitReferencedPropertyName(member.name));
-        } else {
-          name = visitPropertyName(member.name);
-        }
+        name = visitPropertyName(member.name);
         exitName();
       }
       if (!some(modifiers) && (isMethodDeclaration(member) || isPropertyDeclaration(member))) {
@@ -193935,13 +178405,7 @@ ${lanes.join("\n")}
     }
     function visitMethodDeclaration(node) {
       enterClassElement(node);
-      const { modifiers, name, descriptorName } = partialTransformClassElement(
-        node,
-        /*useNamedEvaluation*/
-        false,
-        classInfo,
-        createMethodDescriptorObject
-      );
+      const { modifiers, name, descriptorName } = partialTransformClassElement(node, classInfo, createMethodDescriptorObject);
       if (descriptorName) {
         exitClassElement();
         return finishClassElement(createMethodDescriptorForwarder(modifiers, name, descriptorName), node);
@@ -193967,13 +178431,7 @@ ${lanes.join("\n")}
     }
     function visitGetAccessorDeclaration(node) {
       enterClassElement(node);
-      const { modifiers, name, descriptorName } = partialTransformClassElement(
-        node,
-        /*useNamedEvaluation*/
-        false,
-        classInfo,
-        createGetAccessorDescriptorObject
-      );
+      const { modifiers, name, descriptorName } = partialTransformClassElement(node, classInfo, createGetAccessorDescriptorObject);
       if (descriptorName) {
         exitClassElement();
         return finishClassElement(createGetAccessorDescriptorForwarder(modifiers, name, descriptorName), node);
@@ -193994,13 +178452,7 @@ ${lanes.join("\n")}
     }
     function visitSetAccessorDeclaration(node) {
       enterClassElement(node);
-      const { modifiers, name, descriptorName } = partialTransformClassElement(
-        node,
-        /*useNamedEvaluation*/
-        false,
-        classInfo,
-        createSetAccessorDescriptorObject
-      );
+      const { modifiers, name, descriptorName } = partialTransformClassElement(node, classInfo, createSetAccessorDescriptorObject);
       if (descriptorName) {
         exitClassElement();
         return finishClassElement(createSetAccessorDescriptorForwarder(modifiers, name, descriptorName), node);
@@ -194013,19 +178465,31 @@ ${lanes.join("\n")}
     }
     function visitClassStaticBlockDeclaration(node) {
       enterClassElement(node);
-      if (classInfo)
-        classInfo.hasStaticInitializers = true;
-      const result = visitEachChild(node, visitor, context);
+      let result;
+      if (isClassNamedEvaluationHelperBlock(node)) {
+        result = visitEachChild(node, visitor, context);
+      } else if (isClassThisAssignmentBlock(node)) {
+        const savedClassThis = classThis;
+        classThis = void 0;
+        result = visitEachChild(node, visitor, context);
+        classThis = savedClassThis;
+      } else {
+        if (classInfo)
+          classInfo.hasStaticInitializers = true;
+        result = visitEachChild(node, visitor, context);
+      }
       exitClassElement();
       return result;
     }
     function visitPropertyDeclaration(node) {
+      if (isNamedEvaluation(node, isAnonymousClassNeedingAssignedName)) {
+        node = transformNamedEvaluation(context, node, canIgnoreEmptyStringLiteralInAssignedName(node.initializer));
+      }
       enterClassElement(node);
       Debug.assert(!isAmbientPropertyDeclaration(node), "Not yet implemented.");
-      const useNamedEvaluation = isNamedEvaluation(node, isAnonymousClassNeedingAssignedName);
-      const { modifiers, name, referencedName, initializersName, descriptorName, thisArg } = partialTransformClassElement(node, useNamedEvaluation, classInfo, hasAccessorModifier(node) ? createAccessorPropertyDescriptorObject : void 0);
+      const { modifiers, name, initializersName, descriptorName, thisArg } = partialTransformClassElement(node, classInfo, hasAccessorModifier(node) ? createAccessorPropertyDescriptorObject : void 0);
       startLexicalEnvironment();
-      let initializer = referencedName ? visitNode(node.initializer, (node2) => namedEvaluationVisitor(node2, referencedName), isExpression) : visitNode(node.initializer, visitor, isExpression);
+      let initializer = visitNode(node.initializer, visitor, isExpression);
       if (initializersName) {
         initializer = emitHelpers().createRunInitializersHelper(
           thisArg ?? factory2.createThis(),
@@ -194155,38 +178619,21 @@ ${lanes.join("\n")}
       return visitEachChild(node, visitor, context);
     }
     function visitParameterDeclaration(node) {
-      let updated;
       if (isNamedEvaluation(node, isAnonymousClassNeedingAssignedName)) {
-        const assignedName = getAssignedNameOfIdentifier(node.name, node.initializer);
-        const name = visitNode(node.name, visitor, isBindingName);
-        const initializer = visitNode(node.initializer, (node2) => namedEvaluationVisitor(node2, assignedName), isExpression);
-        updated = factory2.updateParameterDeclaration(
-          node,
-          /*modifiers*/
-          void 0,
-          /*dotDotDotToken*/
-          void 0,
-          name,
-          /*questionToken*/
-          void 0,
-          /*type*/
-          void 0,
-          initializer
-        );
-      } else {
-        updated = factory2.updateParameterDeclaration(
-          node,
-          /*modifiers*/
-          void 0,
-          node.dotDotDotToken,
-          visitNode(node.name, visitor, isBindingName),
-          /*questionToken*/
-          void 0,
-          /*type*/
-          void 0,
-          visitNode(node.initializer, visitor, isExpression)
-        );
+        node = transformNamedEvaluation(context, node, canIgnoreEmptyStringLiteralInAssignedName(node.initializer));
       }
+      const updated = factory2.updateParameterDeclaration(
+        node,
+        /*modifiers*/
+        void 0,
+        node.dotDotDotToken,
+        visitNode(node.name, visitor, isBindingName),
+        /*questionToken*/
+        void 0,
+        /*type*/
+        void 0,
+        visitNode(node.initializer, visitor, isExpression)
+      );
       if (updated !== node) {
         setCommentRange(updated, node);
         setTextRange(updated, moveRangePastModifiers(node));
@@ -194198,6 +178645,14 @@ ${lanes.join("\n")}
     function isAnonymousClassNeedingAssignedName(node) {
       return isClassExpression(node) && !node.name && isDecoratedClassLike(node);
     }
+    function canIgnoreEmptyStringLiteralInAssignedName(node) {
+      const innerExpression = skipOuterExpressions(node);
+      return isClassExpression(innerExpression) && !innerExpression.name && !classOrConstructorParameterIsDecorated(
+        /*useLegacyDecorators*/
+        false,
+        innerExpression
+      );
+    }
     function visitForStatement(node) {
       return factory2.updateForStatement(
         node,
@@ -194218,10 +178673,8 @@ ${lanes.join("\n")}
       }
       if (isAssignmentExpression(node)) {
         if (isNamedEvaluation(node, isAnonymousClassNeedingAssignedName)) {
-          const assignedName = getAssignedNameOfIdentifier(node.left, node.right);
-          const left = visitNode(node.left, visitor, isExpression);
-          const right = visitNode(node.right, (node2) => namedEvaluationVisitor(node2, assignedName), isExpression);
-          return factory2.updateBinaryExpression(node, left, node.operatorToken, right);
+          node = transformNamedEvaluation(context, node, canIgnoreEmptyStringLiteralInAssignedName(node.right));
+          return visitEachChild(node, visitor, context);
         }
         if (isSuperProperty(node.left) && classThis && classSuper) {
           let setterName = isElementAccessExpression(node.left) ? visitNode(node.left.argumentExpression, visitor, isExpression) : isIdentifier(node.left.name) ? factory2.createStringLiteralFromNode(node.left.name) : void 0;
@@ -194341,43 +178794,19 @@ ${lanes.join("\n")}
     }
     function visitPropertyAssignment(node) {
       if (isNamedEvaluation(node, isAnonymousClassNeedingAssignedName)) {
-        const { referencedName, name } = visitReferencedPropertyName(node.name);
-        const initializer = visitNode(node.initializer, (node2) => namedEvaluationVisitor(node2, referencedName), isExpression);
-        return factory2.updatePropertyAssignment(node, name, initializer);
+        node = transformNamedEvaluation(context, node, canIgnoreEmptyStringLiteralInAssignedName(node.initializer));
       }
       return visitEachChild(node, visitor, context);
     }
     function visitVariableDeclaration(node) {
       if (isNamedEvaluation(node, isAnonymousClassNeedingAssignedName)) {
-        const assignedName = getAssignedNameOfIdentifier(node.name, node.initializer);
-        const name = visitNode(node.name, visitor, isBindingName);
-        const initializer = visitNode(node.initializer, (node2) => namedEvaluationVisitor(node2, assignedName), isExpression);
-        return factory2.updateVariableDeclaration(
-          node,
-          name,
-          /*exclamationToken*/
-          void 0,
-          /*type*/
-          void 0,
-          initializer
-        );
+        node = transformNamedEvaluation(context, node, canIgnoreEmptyStringLiteralInAssignedName(node.initializer));
       }
       return visitEachChild(node, visitor, context);
     }
     function visitBindingElement(node) {
       if (isNamedEvaluation(node, isAnonymousClassNeedingAssignedName)) {
-        const assignedName = getAssignedNameOfIdentifier(node.name, node.initializer);
-        const propertyName = visitNode(node.propertyName, visitor, isPropertyName);
-        const name = visitNode(node.name, visitor, isBindingName);
-        const initializer = visitNode(node.initializer, (node2) => namedEvaluationVisitor(node2, assignedName), isExpression);
-        return factory2.updateBindingElement(
-          node,
-          /*dotDotDotToken*/
-          void 0,
-          propertyName,
-          name,
-          initializer
-        );
+        node = transformNamedEvaluation(context, node, canIgnoreEmptyStringLiteralInAssignedName(node.initializer));
       }
       return visitEachChild(node, visitor, context);
     }
@@ -194414,14 +178843,11 @@ ${lanes.join("\n")}
         /*excludeCompoundAssignment*/
         true
       )) {
-        const assignmentTarget = visitDestructuringAssignmentTarget(node.left);
-        let initializer;
         if (isNamedEvaluation(node, isAnonymousClassNeedingAssignedName)) {
-          const assignedName = getAssignedNameOfIdentifier(node.left, node.right);
-          initializer = visitNode(node.right, (node2) => namedEvaluationVisitor(node2, assignedName), isExpression);
-        } else {
-          initializer = visitNode(node.right, visitor, isExpression);
+          node = transformNamedEvaluation(context, node, canIgnoreEmptyStringLiteralInAssignedName(node.right));
         }
+        const assignmentTarget = visitDestructuringAssignmentTarget(node.left);
+        const initializer = visitNode(node.right, visitor, isExpression);
         return factory2.updateBinaryExpression(node, assignmentTarget, node.operatorToken, initializer);
       } else {
         return visitDestructuringAssignmentTarget(node);
@@ -194460,10 +178886,7 @@ ${lanes.join("\n")}
     }
     function visitShorthandAssignmentProperty(node) {
       if (isNamedEvaluation(node, isAnonymousClassNeedingAssignedName)) {
-        const assignedName = getAssignedNameOfIdentifier(node.name, node.objectAssignmentInitializer);
-        const name = visitNode(node.name, visitor, isIdentifier);
-        const objectAssignmentInitializer = visitNode(node.objectAssignmentInitializer, (node2) => namedEvaluationVisitor(node2, assignedName), isExpression);
-        return factory2.updateShorthandPropertyAssignment(node, name, objectAssignmentInitializer);
+        node = transformNamedEvaluation(context, node, canIgnoreEmptyStringLiteralInAssignedName(node.objectAssignmentInitializer));
       }
       return visitEachChild(node, visitor, context);
     }
@@ -194495,20 +178918,17 @@ ${lanes.join("\n")}
     }
     function visitExportAssignment(node) {
       if (isNamedEvaluation(node, isAnonymousClassNeedingAssignedName)) {
-        const referencedName = factory2.createStringLiteral(node.isExportEquals ? "" : "default");
-        const modifiers = visitNodes2(node.modifiers, modifierVisitor, isModifier);
-        const expression = visitNode(node.expression, (node2) => namedEvaluationVisitor(node2, referencedName), isExpression);
-        return factory2.updateExportAssignment(node, modifiers, expression);
+        node = transformNamedEvaluation(context, node, canIgnoreEmptyStringLiteralInAssignedName(node.expression));
       }
       return visitEachChild(node, visitor, context);
     }
-    function visitParenthesizedExpression(node, discarded, referencedName) {
-      const visitorFunc = discarded ? discardedValueVisitor : referencedName ? (node2) => namedEvaluationVisitor(node2, referencedName) : visitor;
+    function visitParenthesizedExpression(node, discarded) {
+      const visitorFunc = discarded ? discardedValueVisitor : visitor;
       const expression = visitNode(node.expression, visitorFunc, isExpression);
       return factory2.updateParenthesizedExpression(node, expression);
     }
-    function visitPartiallyEmittedExpression(node, discarded, referencedName) {
-      const visitorFunc = discarded ? discardedValueVisitor : referencedName ? (node2) => namedEvaluationVisitor(node2, referencedName) : visitor;
+    function visitPartiallyEmittedExpression(node, discarded) {
+      const visitorFunc = discarded ? discardedValueVisitor : visitor;
       const expression = visitNode(node.expression, visitorFunc, isExpression);
       return factory2.updatePartiallyEmittedExpression(node, expression);
     }
@@ -194536,6 +178956,17 @@ ${lanes.join("\n")}
     function transformDecorator(decorator) {
       const expression = visitNode(decorator.expression, visitor, isExpression);
       setEmitFlags(expression, 3072 /* NoComments */);
+      const innerExpression = skipOuterExpressions(expression);
+      if (isAccessExpression(innerExpression)) {
+        const { target, thisArg } = factory2.createCallBinding(
+          expression,
+          hoistVariableDeclaration,
+          languageVersion,
+          /*cacheIdentifiers*/
+          true
+        );
+        return factory2.restoreOuterExpressions(expression, factory2.createFunctionBindCall(target, thisArg, []));
+      }
       return expression;
     }
     function createDescriptorMethod(original, name, modifiers, asteriskToken, kind, parameters, body) {
@@ -194721,9 +179152,59 @@ ${lanes.join("\n")}
         ])
       );
     }
-    function getAssignedNameOfIdentifier(name, initializer) {
-      const originalClass = getOriginalNode(initializer, isClassLike);
-      return originalClass && !originalClass.name && hasSyntacticModifier(originalClass, 1024 /* Default */) ? factory2.createStringLiteral("default") : factory2.createStringLiteralFromNode(name);
+    function createMetadata(name, classSuper2) {
+      const varDecl = factory2.createVariableDeclaration(
+        name,
+        /*exclamationToken*/
+        void 0,
+        /*type*/
+        void 0,
+        factory2.createConditionalExpression(
+          factory2.createLogicalAnd(
+            factory2.createTypeCheck(factory2.createIdentifier("Symbol"), "function"),
+            factory2.createPropertyAccessExpression(factory2.createIdentifier("Symbol"), "metadata")
+          ),
+          factory2.createToken(58 /* QuestionToken */),
+          factory2.createCallExpression(
+            factory2.createPropertyAccessExpression(factory2.createIdentifier("Object"), "create"),
+            /*typeArguments*/
+            void 0,
+            [classSuper2 ? createSymbolMetadataReference(classSuper2) : factory2.createNull()]
+          ),
+          factory2.createToken(59 /* ColonToken */),
+          factory2.createVoidZero()
+        )
+      );
+      return factory2.createVariableStatement(
+        /*modifiers*/
+        void 0,
+        factory2.createVariableDeclarationList([varDecl], 2 /* Const */)
+      );
+    }
+    function createSymbolMetadata(target, value) {
+      const defineProperty = factory2.createObjectDefinePropertyCall(
+        target,
+        factory2.createPropertyAccessExpression(factory2.createIdentifier("Symbol"), "metadata"),
+        factory2.createPropertyDescriptor(
+          { configurable: true, writable: true, enumerable: true, value },
+          /*singleLine*/
+          true
+        )
+      );
+      return setEmitFlags(
+        factory2.createIfStatement(value, factory2.createExpressionStatement(defineProperty)),
+        1 /* SingleLine */
+      );
+    }
+    function createSymbolMetadataReference(classSuper2) {
+      return factory2.createBinaryExpression(
+        factory2.createElementAccessExpression(
+          classSuper2,
+          factory2.createPropertyAccessExpression(factory2.createIdentifier("Symbol"), "metadata")
+        ),
+        61 /* QuestionQuestionToken */,
+        factory2.createNull()
+      );
     }
   }
   var init_esDecorators = __esm({
@@ -194807,34 +179288,34 @@ ${lanes.join("\n")}
       switch (node.kind) {
         case 134 /* AsyncKeyword */:
           return void 0;
-        case 222 /* AwaitExpression */:
+        case 223 /* AwaitExpression */:
           return visitAwaitExpression(node);
-        case 173 /* MethodDeclaration */:
+        case 174 /* MethodDeclaration */:
           return doWithContext(1 /* NonTopLevel */ | 2 /* HasLexicalThis */, visitMethodDeclaration, node);
-        case 261 /* FunctionDeclaration */:
+        case 262 /* FunctionDeclaration */:
           return doWithContext(1 /* NonTopLevel */ | 2 /* HasLexicalThis */, visitFunctionDeclaration, node);
-        case 217 /* FunctionExpression */:
+        case 218 /* FunctionExpression */:
           return doWithContext(1 /* NonTopLevel */ | 2 /* HasLexicalThis */, visitFunctionExpression, node);
-        case 218 /* ArrowFunction */:
+        case 219 /* ArrowFunction */:
           return doWithContext(1 /* NonTopLevel */, visitArrowFunction, node);
-        case 210 /* PropertyAccessExpression */:
+        case 211 /* PropertyAccessExpression */:
           if (capturedSuperProperties && isPropertyAccessExpression(node) && node.expression.kind === 108 /* SuperKeyword */) {
             capturedSuperProperties.add(node.name.escapedText);
           }
           return visitEachChild(node, visitor, context);
-        case 211 /* ElementAccessExpression */:
+        case 212 /* ElementAccessExpression */:
           if (capturedSuperProperties && node.expression.kind === 108 /* SuperKeyword */) {
             hasSuperElementAccess = true;
           }
           return visitEachChild(node, visitor, context);
-        case 176 /* GetAccessor */:
+        case 177 /* GetAccessor */:
           return doWithContext(1 /* NonTopLevel */ | 2 /* HasLexicalThis */, visitGetAccessorDeclaration, node);
-        case 177 /* SetAccessor */:
+        case 178 /* SetAccessor */:
           return doWithContext(1 /* NonTopLevel */ | 2 /* HasLexicalThis */, visitSetAccessorDeclaration, node);
-        case 175 /* Constructor */:
+        case 176 /* Constructor */:
           return doWithContext(1 /* NonTopLevel */ | 2 /* HasLexicalThis */, visitConstructorDeclaration, node);
-        case 262 /* ClassDeclaration */:
-        case 230 /* ClassExpression */:
+        case 263 /* ClassDeclaration */:
+        case 231 /* ClassExpression */:
           return doWithContext(1 /* NonTopLevel */ | 2 /* HasLexicalThis */, visitDefault, node);
         default:
           return visitEachChild(node, visitor, context);
@@ -194843,27 +179324,27 @@ ${lanes.join("\n")}
     function asyncBodyVisitor(node) {
       if (isNodeWithPossibleHoistedDeclaration(node)) {
         switch (node.kind) {
-          case 242 /* VariableStatement */:
+          case 243 /* VariableStatement */:
             return visitVariableStatementInAsyncBody(node);
-          case 247 /* ForStatement */:
+          case 248 /* ForStatement */:
             return visitForStatementInAsyncBody(node);
-          case 248 /* ForInStatement */:
+          case 249 /* ForInStatement */:
             return visitForInStatementInAsyncBody(node);
-          case 249 /* ForOfStatement */:
+          case 250 /* ForOfStatement */:
             return visitForOfStatementInAsyncBody(node);
-          case 298 /* CatchClause */:
+          case 299 /* CatchClause */:
             return visitCatchClauseInAsyncBody(node);
-          case 240 /* Block */:
-          case 254 /* SwitchStatement */:
-          case 268 /* CaseBlock */:
-          case 295 /* CaseClause */:
-          case 296 /* DefaultClause */:
-          case 257 /* TryStatement */:
-          case 245 /* DoStatement */:
-          case 246 /* WhileStatement */:
-          case 244 /* IfStatement */:
-          case 253 /* WithStatement */:
-          case 255 /* LabeledStatement */:
+          case 241 /* Block */:
+          case 255 /* SwitchStatement */:
+          case 269 /* CaseBlock */:
+          case 296 /* CaseClause */:
+          case 297 /* DefaultClause */:
+          case 258 /* TryStatement */:
+          case 246 /* DoStatement */:
+          case 247 /* WhileStatement */:
+          case 245 /* IfStatement */:
+          case 254 /* WithStatement */:
+          case 256 /* LabeledStatement */:
             return visitEachChild(node, asyncBodyVisitor, context);
           default:
             return Debug.assertNever(node, "Unhandled node.");
@@ -195056,7 +179537,7 @@ ${lanes.join("\n")}
       }
     }
     function isVariableDeclarationListWithCollidingName(node) {
-      return !!node && isVariableDeclarationList(node) && !(node.flags & 3 /* BlockScoped */) && node.declarations.some(collidesWithParameterName);
+      return !!node && isVariableDeclarationList(node) && !(node.flags & 7 /* BlockScoped */) && node.declarations.some(collidesWithParameterName);
     }
     function visitVariableDeclarationListWithCollidingNames(node, hasReceiver) {
       hoistVariableDeclarationList(node);
@@ -195140,7 +179621,7 @@ ${lanes.join("\n")}
       const original = getOriginalNode(node, isFunctionLike);
       const nodeType = original.type;
       const promiseConstructor = languageVersion < 2 /* ES2015 */ ? getPromiseConstructor(nodeType) : void 0;
-      const isArrowFunction2 = node.kind === 218 /* ArrowFunction */;
+      const isArrowFunction2 = node.kind === 219 /* ArrowFunction */;
       const hasLexicalArguments = (resolver.getNodeCheckFlags(node) & 512 /* CaptureArguments */) !== 0;
       const savedEnclosingFunctionParameterNames = enclosingFunctionParameterNames;
       enclosingFunctionParameterNames = /* @__PURE__ */ new Set();
@@ -195239,15 +179720,15 @@ ${lanes.join("\n")}
     function enableSubstitutionForAsyncMethodsWithSuper() {
       if ((enabledSubstitutions & 1 /* AsyncMethodsWithSuper */) === 0) {
         enabledSubstitutions |= 1 /* AsyncMethodsWithSuper */;
-        context.enableSubstitution(212 /* CallExpression */);
-        context.enableSubstitution(210 /* PropertyAccessExpression */);
-        context.enableSubstitution(211 /* ElementAccessExpression */);
-        context.enableEmitNotification(262 /* ClassDeclaration */);
-        context.enableEmitNotification(173 /* MethodDeclaration */);
-        context.enableEmitNotification(176 /* GetAccessor */);
-        context.enableEmitNotification(177 /* SetAccessor */);
-        context.enableEmitNotification(175 /* Constructor */);
-        context.enableEmitNotification(242 /* VariableStatement */);
+        context.enableSubstitution(213 /* CallExpression */);
+        context.enableSubstitution(211 /* PropertyAccessExpression */);
+        context.enableSubstitution(212 /* ElementAccessExpression */);
+        context.enableEmitNotification(263 /* ClassDeclaration */);
+        context.enableEmitNotification(174 /* MethodDeclaration */);
+        context.enableEmitNotification(177 /* GetAccessor */);
+        context.enableEmitNotification(178 /* SetAccessor */);
+        context.enableEmitNotification(176 /* Constructor */);
+        context.enableEmitNotification(243 /* VariableStatement */);
       }
     }
     function onEmitNode(hint, node, emitCallback) {
@@ -195278,11 +179759,11 @@ ${lanes.join("\n")}
     }
     function substituteExpression(node) {
       switch (node.kind) {
-        case 210 /* PropertyAccessExpression */:
+        case 211 /* PropertyAccessExpression */:
           return substitutePropertyAccessExpression(node);
-        case 211 /* ElementAccessExpression */:
+        case 212 /* ElementAccessExpression */:
           return substituteElementAccessExpression(node);
-        case 212 /* CallExpression */:
+        case 213 /* CallExpression */:
           return substituteCallExpression(node);
       }
       return node;
@@ -195326,7 +179807,7 @@ ${lanes.join("\n")}
     }
     function isSuperContainer(node) {
       const kind = node.kind;
-      return kind === 262 /* ClassDeclaration */ || kind === 175 /* Constructor */ || kind === 173 /* MethodDeclaration */ || kind === 176 /* GetAccessor */ || kind === 177 /* SetAccessor */;
+      return kind === 263 /* ClassDeclaration */ || kind === 176 /* Constructor */ || kind === 174 /* MethodDeclaration */ || kind === 177 /* GetAccessor */ || kind === 178 /* SetAccessor */;
     }
     function createSuperElementAccessInAsyncMethod(argumentExpression, location) {
       if (enclosingSuperContainerFlags & 256 /* MethodWithSuperPropertyAssignmentInAsync */) {
@@ -195572,119 +180053,119 @@ ${lanes.join("\n")}
         return node;
       }
       switch (node.kind) {
-        case 222 /* AwaitExpression */:
+        case 223 /* AwaitExpression */:
           return visitAwaitExpression(node);
-        case 228 /* YieldExpression */:
+        case 229 /* YieldExpression */:
           return visitYieldExpression(node);
-        case 252 /* ReturnStatement */:
+        case 253 /* ReturnStatement */:
           return visitReturnStatement(node);
-        case 255 /* LabeledStatement */:
+        case 256 /* LabeledStatement */:
           return visitLabeledStatement(node);
-        case 209 /* ObjectLiteralExpression */:
+        case 210 /* ObjectLiteralExpression */:
           return visitObjectLiteralExpression(node);
-        case 225 /* BinaryExpression */:
+        case 226 /* BinaryExpression */:
           return visitBinaryExpression(node, expressionResultIsUnused2);
-        case 360 /* CommaListExpression */:
+        case 361 /* CommaListExpression */:
           return visitCommaListExpression(node, expressionResultIsUnused2);
-        case 298 /* CatchClause */:
+        case 299 /* CatchClause */:
           return visitCatchClause(node);
-        case 242 /* VariableStatement */:
+        case 243 /* VariableStatement */:
           return visitVariableStatement(node);
-        case 259 /* VariableDeclaration */:
+        case 260 /* VariableDeclaration */:
           return visitVariableDeclaration(node);
-        case 245 /* DoStatement */:
-        case 246 /* WhileStatement */:
-        case 248 /* ForInStatement */:
+        case 246 /* DoStatement */:
+        case 247 /* WhileStatement */:
+        case 249 /* ForInStatement */:
           return doWithHierarchyFacts(
             visitDefault,
             node,
             0 /* IterationStatementExcludes */,
             2 /* IterationStatementIncludes */
           );
-        case 249 /* ForOfStatement */:
+        case 250 /* ForOfStatement */:
           return visitForOfStatement(
             node,
             /*outermostLabeledStatement*/
             void 0
           );
-        case 247 /* ForStatement */:
+        case 248 /* ForStatement */:
           return doWithHierarchyFacts(
             visitForStatement,
             node,
             0 /* IterationStatementExcludes */,
             2 /* IterationStatementIncludes */
           );
-        case 221 /* VoidExpression */:
+        case 222 /* VoidExpression */:
           return visitVoidExpression(node);
-        case 175 /* Constructor */:
+        case 176 /* Constructor */:
           return doWithHierarchyFacts(
             visitConstructorDeclaration,
             node,
             2 /* ClassOrFunctionExcludes */,
             1 /* ClassOrFunctionIncludes */
           );
-        case 173 /* MethodDeclaration */:
+        case 174 /* MethodDeclaration */:
           return doWithHierarchyFacts(
             visitMethodDeclaration,
             node,
             2 /* ClassOrFunctionExcludes */,
             1 /* ClassOrFunctionIncludes */
           );
-        case 176 /* GetAccessor */:
+        case 177 /* GetAccessor */:
           return doWithHierarchyFacts(
             visitGetAccessorDeclaration,
             node,
             2 /* ClassOrFunctionExcludes */,
             1 /* ClassOrFunctionIncludes */
           );
-        case 177 /* SetAccessor */:
+        case 178 /* SetAccessor */:
           return doWithHierarchyFacts(
             visitSetAccessorDeclaration,
             node,
             2 /* ClassOrFunctionExcludes */,
             1 /* ClassOrFunctionIncludes */
           );
-        case 261 /* FunctionDeclaration */:
+        case 262 /* FunctionDeclaration */:
           return doWithHierarchyFacts(
             visitFunctionDeclaration,
             node,
             2 /* ClassOrFunctionExcludes */,
             1 /* ClassOrFunctionIncludes */
           );
-        case 217 /* FunctionExpression */:
+        case 218 /* FunctionExpression */:
           return doWithHierarchyFacts(
             visitFunctionExpression,
             node,
             2 /* ClassOrFunctionExcludes */,
             1 /* ClassOrFunctionIncludes */
           );
-        case 218 /* ArrowFunction */:
+        case 219 /* ArrowFunction */:
           return doWithHierarchyFacts(
             visitArrowFunction,
             node,
             2 /* ArrowFunctionExcludes */,
             0 /* ArrowFunctionIncludes */
           );
-        case 168 /* Parameter */:
+        case 169 /* Parameter */:
           return visitParameter(node);
-        case 243 /* ExpressionStatement */:
+        case 244 /* ExpressionStatement */:
           return visitExpressionStatement(node);
-        case 216 /* ParenthesizedExpression */:
+        case 217 /* ParenthesizedExpression */:
           return visitParenthesizedExpression(node, expressionResultIsUnused2);
-        case 214 /* TaggedTemplateExpression */:
+        case 215 /* TaggedTemplateExpression */:
           return visitTaggedTemplateExpression(node);
-        case 210 /* PropertyAccessExpression */:
+        case 211 /* PropertyAccessExpression */:
           if (capturedSuperProperties && isPropertyAccessExpression(node) && node.expression.kind === 108 /* SuperKeyword */) {
             capturedSuperProperties.add(node.name.escapedText);
           }
           return visitEachChild(node, visitor, context);
-        case 211 /* ElementAccessExpression */:
+        case 212 /* ElementAccessExpression */:
           if (capturedSuperProperties && node.expression.kind === 108 /* SuperKeyword */) {
             hasSuperElementAccess = true;
           }
           return visitEachChild(node, visitor, context);
-        case 262 /* ClassDeclaration */:
-        case 230 /* ClassExpression */:
+        case 263 /* ClassDeclaration */:
+        case 231 /* ClassExpression */:
           return doWithHierarchyFacts(
             visitDefault,
             node,
@@ -195760,16 +180241,19 @@ ${lanes.join("\n")}
     }
     function visitReturnStatement(node) {
       if (enclosingFunctionFlags & 2 /* Async */ && enclosingFunctionFlags & 1 /* Generator */) {
-        return factory2.updateReturnStatement(node, createDownlevelAwait(
-          node.expression ? visitNode(node.expression, visitor, isExpression) : factory2.createVoidZero()
-        ));
+        return factory2.updateReturnStatement(
+          node,
+          createDownlevelAwait(
+            node.expression ? visitNode(node.expression, visitor, isExpression) : factory2.createVoidZero()
+          )
+        );
       }
       return visitEachChild(node, visitor, context);
     }
     function visitLabeledStatement(node) {
       if (enclosingFunctionFlags & 2 /* Async */) {
         const statement = unwrapInnermostStatementOfLabel(node);
-        if (statement.kind === 249 /* ForOfStatement */ && statement.awaitModifier) {
+        if (statement.kind === 250 /* ForOfStatement */ && statement.awaitModifier) {
           return visitForOfStatement(statement, node);
         }
         return factory2.restoreEnclosingLabel(visitNode(statement, visitor, isStatement, factory2.liftToBlock), node);
@@ -195780,7 +180264,7 @@ ${lanes.join("\n")}
       let chunkObject;
       const objects = [];
       for (const e of elements) {
-        if (e.kind === 304 /* SpreadAssignment */) {
+        if (e.kind === 305 /* SpreadAssignment */) {
           if (chunkObject) {
             objects.push(factory2.createObjectLiteralExpression(chunkObject));
             chunkObject = void 0;
@@ -195788,7 +180272,10 @@ ${lanes.join("\n")}
           const target = e.expression;
           objects.push(visitNode(target, visitor, isExpression));
         } else {
-          chunkObject = append(chunkObject, e.kind === 302 /* PropertyAssignment */ ? factory2.createPropertyAssignment(e.name, visitNode(e.initializer, visitor, isExpression)) : visitNode(e, visitor, isObjectLiteralElementLike));
+          chunkObject = append(
+            chunkObject,
+            e.kind === 303 /* PropertyAssignment */ ? factory2.createPropertyAssignment(e.name, visitNode(e.initializer, visitor, isExpression)) : visitNode(e, visitor, isObjectLiteralElementLike)
+          );
         }
       }
       if (chunkObject) {
@@ -195799,7 +180286,7 @@ ${lanes.join("\n")}
     function visitObjectLiteralExpression(node) {
       if (node.transformFlags & 65536 /* ContainsObjectRestOrSpread */) {
         const objects = chunkObjectLiteralElements(node.properties);
-        if (objects.length && objects[0].kind !== 209 /* ObjectLiteralExpression */) {
+        if (objects.length && objects[0].kind !== 210 /* ObjectLiteralExpression */) {
           objects.unshift(factory2.createObjectLiteralExpression());
         }
         let expression = objects[0];
@@ -195827,13 +180314,16 @@ ${lanes.join("\n")}
       );
       exportedVariableStatement = false;
       const visited = visitEachChild(node, visitor, context);
-      const statement = concatenate(visited.statements, taggedTemplateStringDeclarations && [
-        factory2.createVariableStatement(
-          /*modifiers*/
-          void 0,
-          factory2.createVariableDeclarationList(taggedTemplateStringDeclarations)
-        )
-      ]);
+      const statement = concatenate(
+        visited.statements,
+        taggedTemplateStringDeclarations && [
+          factory2.createVariableStatement(
+            /*modifiers*/
+            void 0,
+            factory2.createVariableDeclarationList(taggedTemplateStringDeclarations)
+          )
+        ]
+      );
       const result = factory2.updateSourceFile(visited, setTextRange(factory2.createNodeArray(statement), node.statements));
       exitSubtree(ancestorFacts);
       return result;
@@ -195926,7 +180416,7 @@ ${lanes.join("\n")}
       return visitEachChild(node, visitor, context);
     }
     function visitVariableStatement(node) {
-      if (hasSyntacticModifier(node, 1 /* Export */)) {
+      if (hasSyntacticModifier(node, 32 /* Export */)) {
         const savedExportedVariableStatement = exportedVariableStatement;
         exportedVariableStatement = true;
         const visited = visitEachChild(node, visitor, context);
@@ -196568,15 +181058,15 @@ ${lanes.join("\n")}
     function enableSubstitutionForAsyncMethodsWithSuper() {
       if ((enabledSubstitutions & 1 /* AsyncMethodsWithSuper */) === 0) {
         enabledSubstitutions |= 1 /* AsyncMethodsWithSuper */;
-        context.enableSubstitution(212 /* CallExpression */);
-        context.enableSubstitution(210 /* PropertyAccessExpression */);
-        context.enableSubstitution(211 /* ElementAccessExpression */);
-        context.enableEmitNotification(262 /* ClassDeclaration */);
-        context.enableEmitNotification(173 /* MethodDeclaration */);
-        context.enableEmitNotification(176 /* GetAccessor */);
-        context.enableEmitNotification(177 /* SetAccessor */);
-        context.enableEmitNotification(175 /* Constructor */);
-        context.enableEmitNotification(242 /* VariableStatement */);
+        context.enableSubstitution(213 /* CallExpression */);
+        context.enableSubstitution(211 /* PropertyAccessExpression */);
+        context.enableSubstitution(212 /* ElementAccessExpression */);
+        context.enableEmitNotification(263 /* ClassDeclaration */);
+        context.enableEmitNotification(174 /* MethodDeclaration */);
+        context.enableEmitNotification(177 /* GetAccessor */);
+        context.enableEmitNotification(178 /* SetAccessor */);
+        context.enableEmitNotification(176 /* Constructor */);
+        context.enableEmitNotification(243 /* VariableStatement */);
       }
     }
     function onEmitNode(hint, node, emitCallback) {
@@ -196607,11 +181097,11 @@ ${lanes.join("\n")}
     }
     function substituteExpression(node) {
       switch (node.kind) {
-        case 210 /* PropertyAccessExpression */:
+        case 211 /* PropertyAccessExpression */:
           return substitutePropertyAccessExpression(node);
-        case 211 /* ElementAccessExpression */:
+        case 212 /* ElementAccessExpression */:
           return substituteElementAccessExpression(node);
-        case 212 /* CallExpression */:
+        case 213 /* CallExpression */:
           return substituteCallExpression(node);
       }
       return node;
@@ -196655,7 +181145,7 @@ ${lanes.join("\n")}
     }
     function isSuperContainer(node) {
       const kind = node.kind;
-      return kind === 262 /* ClassDeclaration */ || kind === 175 /* Constructor */ || kind === 173 /* MethodDeclaration */ || kind === 176 /* GetAccessor */ || kind === 177 /* SetAccessor */;
+      return kind === 263 /* ClassDeclaration */ || kind === 176 /* Constructor */ || kind === 174 /* MethodDeclaration */ || kind === 177 /* GetAccessor */ || kind === 178 /* SetAccessor */;
     }
     function createSuperElementAccessInAsyncMethod(argumentExpression, location) {
       if (enclosingSuperContainerFlags & 256 /* MethodWithSuperPropertyAssignmentInAsync */) {
@@ -196706,7 +181196,7 @@ ${lanes.join("\n")}
         return node;
       }
       switch (node.kind) {
-        case 298 /* CatchClause */:
+        case 299 /* CatchClause */:
           return visitCatchClause(node);
         default:
           return visitEachChild(node, visitor, context);
@@ -196751,7 +181241,7 @@ ${lanes.join("\n")}
         return node;
       }
       switch (node.kind) {
-        case 212 /* CallExpression */: {
+        case 213 /* CallExpression */: {
           const updated = visitNonOptionalCallExpression(
             node,
             /*captureThisArg*/
@@ -196760,8 +181250,8 @@ ${lanes.join("\n")}
           Debug.assertNotNode(updated, isSyntheticReference);
           return updated;
         }
-        case 210 /* PropertyAccessExpression */:
-        case 211 /* ElementAccessExpression */:
+        case 211 /* PropertyAccessExpression */:
+        case 212 /* ElementAccessExpression */:
           if (isOptionalChain(node)) {
             const updated = visitOptionalExpression(
               node,
@@ -196774,12 +181264,12 @@ ${lanes.join("\n")}
             return updated;
           }
           return visitEachChild(node, visitor, context);
-        case 225 /* BinaryExpression */:
+        case 226 /* BinaryExpression */:
           if (node.operatorToken.kind === 61 /* QuestionQuestionToken */) {
             return transformNullishCoalescingExpression(node);
           }
           return visitEachChild(node, visitor, context);
-        case 219 /* DeleteExpression */:
+        case 220 /* DeleteExpression */:
           return visitDeleteExpression(node);
         default:
           return visitEachChild(node, visitor, context);
@@ -196817,7 +181307,7 @@ ${lanes.join("\n")}
           thisArg = expression;
         }
       }
-      expression = node.kind === 210 /* PropertyAccessExpression */ ? factory2.updatePropertyAccessExpression(node, expression, visitNode(node.name, visitor, isIdentifier)) : factory2.updateElementAccessExpression(node, expression, visitNode(node.argumentExpression, visitor, isExpression));
+      expression = node.kind === 211 /* PropertyAccessExpression */ ? factory2.updatePropertyAccessExpression(node, expression, visitNode(node.name, visitor, isIdentifier)) : factory2.updateElementAccessExpression(node, expression, visitNode(node.argumentExpression, visitor, isExpression));
       return thisArg ? factory2.createSyntheticReferenceExpression(expression, thisArg) : expression;
     }
     function visitNonOptionalCallExpression(node, captureThisArg) {
@@ -196853,12 +181343,12 @@ ${lanes.join("\n")}
     }
     function visitNonOptionalExpression(node, captureThisArg, isDelete) {
       switch (node.kind) {
-        case 216 /* ParenthesizedExpression */:
+        case 217 /* ParenthesizedExpression */:
           return visitNonOptionalParenthesizedExpression(node, captureThisArg, isDelete);
-        case 210 /* PropertyAccessExpression */:
-        case 211 /* ElementAccessExpression */:
+        case 211 /* PropertyAccessExpression */:
+        case 212 /* ElementAccessExpression */:
           return visitNonOptionalPropertyOrElementAccessExpression(node, captureThisArg, isDelete);
-        case 212 /* CallExpression */:
+        case 213 /* CallExpression */:
           return visitNonOptionalCallExpression(node, captureThisArg);
         default:
           return visitNode(node, visitor, isExpression);
@@ -196884,8 +181374,8 @@ ${lanes.join("\n")}
       for (let i = 0; i < chain.length; i++) {
         const segment = chain[i];
         switch (segment.kind) {
-          case 210 /* PropertyAccessExpression */:
-          case 211 /* ElementAccessExpression */:
+          case 211 /* PropertyAccessExpression */:
+          case 212 /* ElementAccessExpression */:
             if (i === chain.length - 1 && captureThisArg) {
               if (!isSimpleCopiableExpression(rightExpression)) {
                 thisArg = factory2.createTempVariable(hoistVariableDeclaration);
@@ -196894,9 +181384,9 @@ ${lanes.join("\n")}
                 thisArg = rightExpression;
               }
             }
-            rightExpression = segment.kind === 210 /* PropertyAccessExpression */ ? factory2.createPropertyAccessExpression(rightExpression, visitNode(segment.name, visitor, isIdentifier)) : factory2.createElementAccessExpression(rightExpression, visitNode(segment.argumentExpression, visitor, isExpression));
+            rightExpression = segment.kind === 211 /* PropertyAccessExpression */ ? factory2.createPropertyAccessExpression(rightExpression, visitNode(segment.name, visitor, isIdentifier)) : factory2.createElementAccessExpression(rightExpression, visitNode(segment.argumentExpression, visitor, isExpression));
             break;
-          case 212 /* CallExpression */:
+          case 213 /* CallExpression */:
             if (i === 0 && leftThisArg) {
               if (!isGeneratedIdentifier(leftThisArg)) {
                 leftThisArg = factory2.cloneNode(leftThisArg);
@@ -196971,15 +181461,18 @@ ${lanes.join("\n")}
         right = factory2.createTempVariable(hoistVariableDeclaration);
         left = factory2.createAssignment(right, left);
       }
-      return setTextRange(factory2.createConditionalExpression(
-        createNotNullCondition(left, right),
-        /*questionToken*/
-        void 0,
-        right,
-        /*colonToken*/
-        void 0,
-        visitNode(node.right, visitor, isExpression)
-      ), node);
+      return setTextRange(
+        factory2.createConditionalExpression(
+          createNotNullCondition(left, right),
+          /*questionToken*/
+          void 0,
+          right,
+          /*colonToken*/
+          void 0,
+          visitNode(node.right, visitor, isExpression)
+        ),
+        node
+      );
     }
     function visitDeleteExpression(node) {
       return isOptionalChain(skipParentheses(node.expression)) ? setOriginalNode(visitNonOptionalExpression(
@@ -197079,22 +181572,639 @@ ${lanes.join("\n")}
 
   // src/compiler/transformers/esnext.ts
   function transformESNext(context) {
+    const {
+      factory: factory2,
+      getEmitHelperFactory: emitHelpers,
+      hoistVariableDeclaration,
+      startLexicalEnvironment,
+      endLexicalEnvironment
+    } = context;
+    let exportBindings;
+    let exportVars;
+    let defaultExportBinding;
+    let exportEqualsBinding;
     return chainBundle(context, transformSourceFile);
     function transformSourceFile(node) {
       if (node.isDeclarationFile) {
         return node;
       }
-      return visitEachChild(node, visitor, context);
+      const visited = visitNode(node, visitor, isSourceFile);
+      addEmitHelpers(visited, context.readEmitHelpers());
+      exportVars = void 0;
+      exportBindings = void 0;
+      defaultExportBinding = void 0;
+      return visited;
     }
     function visitor(node) {
       if ((node.transformFlags & 4 /* ContainsESNext */) === 0) {
         return node;
       }
       switch (node.kind) {
+        case 312 /* SourceFile */:
+          return visitSourceFile(node);
+        case 241 /* Block */:
+          return visitBlock(node);
+        case 248 /* ForStatement */:
+          return visitForStatement(node);
+        case 250 /* ForOfStatement */:
+          return visitForOfStatement(node);
+        case 255 /* SwitchStatement */:
+          return visitSwitchStatement(node);
         default:
           return visitEachChild(node, visitor, context);
       }
     }
+    function visitSourceFile(node) {
+      const usingKind = getUsingKindOfStatements(node.statements);
+      if (usingKind) {
+        startLexicalEnvironment();
+        exportBindings = new IdentifierNameMap();
+        exportVars = [];
+        const prologueCount = countPrologueStatements(node.statements);
+        const topLevelStatements = [];
+        addRange(topLevelStatements, visitArray(node.statements, visitor, isStatement, 0, prologueCount));
+        let pos = prologueCount;
+        while (pos < node.statements.length) {
+          const statement = node.statements[pos];
+          if (getUsingKind(statement) !== 0 /* None */) {
+            if (pos > prologueCount) {
+              addRange(topLevelStatements, visitNodes2(node.statements, visitor, isStatement, prologueCount, pos - prologueCount));
+            }
+            break;
+          }
+          pos++;
+        }
+        Debug.assert(pos < node.statements.length, "Should have encountered at least one 'using' statement.");
+        const envBinding = createEnvBinding();
+        const bodyStatements = transformUsingDeclarations(node.statements, pos, node.statements.length, envBinding, topLevelStatements);
+        if (exportBindings.size) {
+          append(
+            topLevelStatements,
+            factory2.createExportDeclaration(
+              /*modifiers*/
+              void 0,
+              /*isTypeOnly*/
+              false,
+              factory2.createNamedExports(arrayFrom(exportBindings.values()))
+            )
+          );
+        }
+        addRange(topLevelStatements, endLexicalEnvironment());
+        if (exportVars.length) {
+          topLevelStatements.push(factory2.createVariableStatement(
+            factory2.createModifiersFromModifierFlags(32 /* Export */),
+            factory2.createVariableDeclarationList(
+              exportVars,
+              1 /* Let */
+            )
+          ));
+        }
+        addRange(topLevelStatements, createDownlevelUsingStatements(bodyStatements, envBinding, usingKind === 2 /* Async */));
+        if (exportEqualsBinding) {
+          topLevelStatements.push(factory2.createExportAssignment(
+            /*modifiers*/
+            void 0,
+            /*isExportEquals*/
+            true,
+            exportEqualsBinding
+          ));
+        }
+        return factory2.updateSourceFile(node, topLevelStatements);
+      }
+      return visitEachChild(node, visitor, context);
+    }
+    function visitBlock(node) {
+      const usingKind = getUsingKindOfStatements(node.statements);
+      if (usingKind) {
+        const prologueCount = countPrologueStatements(node.statements);
+        const envBinding = createEnvBinding();
+        return factory2.updateBlock(
+          node,
+          [
+            ...visitArray(node.statements, visitor, isStatement, 0, prologueCount),
+            ...createDownlevelUsingStatements(
+              transformUsingDeclarations(
+                node.statements,
+                prologueCount,
+                node.statements.length,
+                envBinding,
+                /*topLevelStatements*/
+                void 0
+              ),
+              envBinding,
+              usingKind === 2 /* Async */
+            )
+          ]
+        );
+      }
+      return visitEachChild(node, visitor, context);
+    }
+    function visitForStatement(node) {
+      if (node.initializer && isUsingVariableDeclarationList(node.initializer)) {
+        return visitNode(
+          factory2.createBlock([
+            factory2.createVariableStatement(
+              /*modifiers*/
+              void 0,
+              node.initializer
+            ),
+            factory2.updateForStatement(
+              node,
+              /*initializer*/
+              void 0,
+              node.condition,
+              node.incrementor,
+              node.statement
+            )
+          ]),
+          visitor,
+          isStatement
+        );
+      }
+      return visitEachChild(node, visitor, context);
+    }
+    function visitForOfStatement(node) {
+      if (isUsingVariableDeclarationList(node.initializer)) {
+        const forInitializer = node.initializer;
+        Debug.assertNode(forInitializer, isUsingVariableDeclarationList);
+        Debug.assert(forInitializer.declarations.length === 1, "ForInitializer may only have one declaration");
+        const forDecl = forInitializer.declarations[0];
+        Debug.assert(!forDecl.initializer, "ForInitializer may not have an initializer");
+        const isAwaitUsing = getUsingKindOfVariableDeclarationList(forInitializer) === 2 /* Async */;
+        const temp = factory2.getGeneratedNameForNode(forDecl.name);
+        const usingVar = factory2.updateVariableDeclaration(
+          forDecl,
+          forDecl.name,
+          /*exclamationToken*/
+          void 0,
+          /*type*/
+          void 0,
+          temp
+        );
+        const usingVarList = factory2.createVariableDeclarationList([usingVar], isAwaitUsing ? 6 /* AwaitUsing */ : 4 /* Using */);
+        const usingVarStatement = factory2.createVariableStatement(
+          /*modifiers*/
+          void 0,
+          usingVarList
+        );
+        return visitNode(
+          factory2.updateForOfStatement(
+            node,
+            node.awaitModifier,
+            factory2.createVariableDeclarationList([
+              factory2.createVariableDeclaration(temp)
+            ], 2 /* Const */),
+            node.expression,
+            isBlock(node.statement) ? factory2.updateBlock(node.statement, [
+              usingVarStatement,
+              ...node.statement.statements
+            ]) : factory2.createBlock(
+              [
+                usingVarStatement,
+                node.statement
+              ],
+              /*multiLine*/
+              true
+            )
+          ),
+          visitor,
+          isStatement
+        );
+      }
+      return visitEachChild(node, visitor, context);
+    }
+    function visitCaseOrDefaultClause(node, envBinding) {
+      if (getUsingKindOfStatements(node.statements) !== 0 /* None */) {
+        if (isCaseClause(node)) {
+          return factory2.updateCaseClause(
+            node,
+            visitNode(node.expression, visitor, isExpression),
+            transformUsingDeclarations(
+              node.statements,
+              /*start*/
+              0,
+              node.statements.length,
+              envBinding,
+              /*topLevelStatements*/
+              void 0
+            )
+          );
+        } else {
+          return factory2.updateDefaultClause(
+            node,
+            transformUsingDeclarations(
+              node.statements,
+              /*start*/
+              0,
+              node.statements.length,
+              envBinding,
+              /*topLevelStatements*/
+              void 0
+            )
+          );
+        }
+      }
+      return visitEachChild(node, visitor, context);
+    }
+    function visitSwitchStatement(node) {
+      const usingKind = getUsingKindOfCaseOrDefaultClauses(node.caseBlock.clauses);
+      if (usingKind) {
+        const envBinding = createEnvBinding();
+        return createDownlevelUsingStatements(
+          [
+            factory2.updateSwitchStatement(
+              node,
+              visitNode(node.expression, visitor, isExpression),
+              factory2.updateCaseBlock(
+                node.caseBlock,
+                node.caseBlock.clauses.map((clause) => visitCaseOrDefaultClause(clause, envBinding))
+              )
+            )
+          ],
+          envBinding,
+          usingKind === 2 /* Async */
+        );
+      }
+      return visitEachChild(node, visitor, context);
+    }
+    function transformUsingDeclarations(statementsIn, start, end, envBinding, topLevelStatements) {
+      const statements = [];
+      for (let i = start; i < end; i++) {
+        const statement = statementsIn[i];
+        const usingKind = getUsingKind(statement);
+        if (usingKind) {
+          Debug.assertNode(statement, isVariableStatement);
+          const declarations = [];
+          for (let declaration of statement.declarationList.declarations) {
+            if (!isIdentifier(declaration.name)) {
+              declarations.length = 0;
+              break;
+            }
+            if (isNamedEvaluation(declaration)) {
+              declaration = transformNamedEvaluation(context, declaration);
+            }
+            const initializer = visitNode(declaration.initializer, visitor, isExpression) ?? factory2.createVoidZero();
+            declarations.push(factory2.updateVariableDeclaration(
+              declaration,
+              declaration.name,
+              /*exclamationToken*/
+              void 0,
+              /*type*/
+              void 0,
+              emitHelpers().createAddDisposableResourceHelper(
+                envBinding,
+                initializer,
+                usingKind === 2 /* Async */
+              )
+            ));
+          }
+          if (declarations.length) {
+            const varList = factory2.createVariableDeclarationList(declarations, 2 /* Const */);
+            setOriginalNode(varList, statement.declarationList);
+            setTextRange(varList, statement.declarationList);
+            hoistOrAppendNode(factory2.updateVariableStatement(
+              statement,
+              /*modifiers*/
+              void 0,
+              varList
+            ));
+            continue;
+          }
+        }
+        const result = visitor(statement);
+        if (isArray(result)) {
+          result.forEach(hoistOrAppendNode);
+        } else if (result) {
+          hoistOrAppendNode(result);
+        }
+      }
+      return statements;
+      function hoistOrAppendNode(node) {
+        Debug.assertNode(node, isStatement);
+        append(statements, hoist(node));
+      }
+      function hoist(node) {
+        if (!topLevelStatements)
+          return node;
+        switch (node.kind) {
+          case 272 /* ImportDeclaration */:
+          case 271 /* ImportEqualsDeclaration */:
+          case 278 /* ExportDeclaration */:
+          case 262 /* FunctionDeclaration */:
+            return hoistImportOrExportOrHoistedDeclaration(node, topLevelStatements);
+          case 277 /* ExportAssignment */:
+            return hoistExportAssignment(node);
+          case 263 /* ClassDeclaration */:
+            return hoistClassDeclaration(node);
+          case 243 /* VariableStatement */:
+            return hoistVariableStatement(node);
+        }
+        return node;
+      }
+    }
+    function hoistImportOrExportOrHoistedDeclaration(node, topLevelStatements) {
+      topLevelStatements.push(node);
+      return void 0;
+    }
+    function hoistExportAssignment(node) {
+      return node.isExportEquals ? hoistExportEquals(node) : hoistExportDefault(node);
+    }
+    function hoistExportDefault(node) {
+      if (defaultExportBinding) {
+        return node;
+      }
+      defaultExportBinding = factory2.createUniqueName("_default", 8 /* ReservedInNestedScopes */ | 32 /* FileLevel */ | 16 /* Optimistic */);
+      hoistBindingIdentifier(
+        defaultExportBinding,
+        /*isExport*/
+        true,
+        "default",
+        node
+      );
+      let expression = node.expression;
+      let innerExpression = skipOuterExpressions(expression);
+      if (isNamedEvaluation(innerExpression)) {
+        innerExpression = transformNamedEvaluation(
+          context,
+          innerExpression,
+          /*ignoreEmptyStringLiteral*/
+          false,
+          "default"
+        );
+        expression = factory2.restoreOuterExpressions(expression, innerExpression);
+      }
+      const assignment = factory2.createAssignment(defaultExportBinding, expression);
+      return factory2.createExpressionStatement(assignment);
+    }
+    function hoistExportEquals(node) {
+      if (exportEqualsBinding) {
+        return node;
+      }
+      exportEqualsBinding = factory2.createUniqueName("_default", 8 /* ReservedInNestedScopes */ | 32 /* FileLevel */ | 16 /* Optimistic */);
+      hoistVariableDeclaration(exportEqualsBinding);
+      const assignment = factory2.createAssignment(exportEqualsBinding, node.expression);
+      return factory2.createExpressionStatement(assignment);
+    }
+    function hoistClassDeclaration(node) {
+      if (!node.name && defaultExportBinding) {
+        return node;
+      }
+      const isExported2 = hasSyntacticModifier(node, 32 /* Export */);
+      const isDefault = hasSyntacticModifier(node, 2048 /* Default */);
+      let expression = factory2.converters.convertToClassExpression(node);
+      if (node.name) {
+        hoistBindingIdentifier(
+          factory2.getLocalName(node),
+          isExported2 && !isDefault,
+          /*exportAlias*/
+          void 0,
+          node
+        );
+        expression = factory2.createAssignment(factory2.getDeclarationName(node), expression);
+        if (isNamedEvaluation(expression)) {
+          expression = transformNamedEvaluation(
+            context,
+            expression,
+            /*ignoreEmptyStringLiteral*/
+            false
+          );
+        }
+        setOriginalNode(expression, node);
+        setSourceMapRange(expression, node);
+        setCommentRange(expression, node);
+      }
+      if (isDefault && !defaultExportBinding) {
+        defaultExportBinding = factory2.createUniqueName("_default", 8 /* ReservedInNestedScopes */ | 32 /* FileLevel */ | 16 /* Optimistic */);
+        hoistBindingIdentifier(
+          defaultExportBinding,
+          /*isExport*/
+          true,
+          "default",
+          node
+        );
+        expression = factory2.createAssignment(defaultExportBinding, expression);
+        if (isNamedEvaluation(expression)) {
+          expression = transformNamedEvaluation(
+            context,
+            expression,
+            /*ignoreEmptyStringLiteral*/
+            false,
+            "default"
+          );
+        }
+        setOriginalNode(expression, node);
+      }
+      return factory2.createExpressionStatement(expression);
+    }
+    function hoistVariableStatement(node) {
+      let expressions;
+      const isExported2 = hasSyntacticModifier(node, 32 /* Export */);
+      for (const variable of node.declarationList.declarations) {
+        hoistBindingElement(variable, isExported2, variable);
+        if (variable.initializer) {
+          expressions = append(expressions, hoistInitializedVariable(variable));
+        }
+      }
+      if (expressions) {
+        const statement = factory2.createExpressionStatement(factory2.inlineExpressions(expressions));
+        setOriginalNode(statement, node);
+        setCommentRange(statement, node);
+        setSourceMapRange(statement, node);
+        return statement;
+      }
+      return void 0;
+    }
+    function hoistInitializedVariable(node) {
+      Debug.assertIsDefined(node.initializer);
+      let target;
+      if (isIdentifier(node.name)) {
+        target = factory2.cloneNode(node.name);
+        setEmitFlags(target, getEmitFlags(target) & ~(32768 /* LocalName */ | 16384 /* ExportName */ | 65536 /* InternalName */));
+      } else {
+        target = factory2.converters.convertToAssignmentPattern(node.name);
+      }
+      const assignment = factory2.createAssignment(target, node.initializer);
+      setOriginalNode(assignment, node);
+      setCommentRange(assignment, node);
+      setSourceMapRange(assignment, node);
+      return assignment;
+    }
+    function hoistBindingElement(node, isExportedDeclaration, original) {
+      if (isBindingPattern(node.name)) {
+        for (const element of node.name.elements) {
+          if (!isOmittedExpression(element)) {
+            hoistBindingElement(element, isExportedDeclaration, original);
+          }
+        }
+      } else {
+        hoistBindingIdentifier(
+          node.name,
+          isExportedDeclaration,
+          /*exportAlias*/
+          void 0,
+          original
+        );
+      }
+    }
+    function hoistBindingIdentifier(node, isExport, exportAlias, original) {
+      const name = isGeneratedIdentifier(node) ? node : factory2.cloneNode(node);
+      if (isExport) {
+        if (exportAlias === void 0 && !isLocalName(name)) {
+          const varDecl = factory2.createVariableDeclaration(name);
+          if (original) {
+            setOriginalNode(varDecl, original);
+          }
+          exportVars.push(varDecl);
+          return;
+        }
+        const localName = exportAlias !== void 0 ? name : void 0;
+        const exportName = exportAlias !== void 0 ? exportAlias : name;
+        const specifier = factory2.createExportSpecifier(
+          /*isTypeOnly*/
+          false,
+          localName,
+          exportName
+        );
+        if (original) {
+          setOriginalNode(specifier, original);
+        }
+        exportBindings.set(name, specifier);
+      }
+      hoistVariableDeclaration(name);
+    }
+    function createEnvBinding() {
+      return factory2.createUniqueName("env");
+    }
+    function createDownlevelUsingStatements(bodyStatements, envBinding, async) {
+      const statements = [];
+      const envObject = factory2.createObjectLiteralExpression([
+        factory2.createPropertyAssignment("stack", factory2.createArrayLiteralExpression()),
+        factory2.createPropertyAssignment("error", factory2.createVoidZero()),
+        factory2.createPropertyAssignment("hasError", factory2.createFalse())
+      ]);
+      const envVar = factory2.createVariableDeclaration(
+        envBinding,
+        /*exclamationToken*/
+        void 0,
+        /*type*/
+        void 0,
+        envObject
+      );
+      const envVarList = factory2.createVariableDeclarationList([envVar], 2 /* Const */);
+      const envVarStatement = factory2.createVariableStatement(
+        /*modifiers*/
+        void 0,
+        envVarList
+      );
+      statements.push(envVarStatement);
+      const tryBlock = factory2.createBlock(
+        bodyStatements,
+        /*multiLine*/
+        true
+      );
+      const bodyCatchBinding = factory2.createUniqueName("e");
+      const catchClause = factory2.createCatchClause(
+        bodyCatchBinding,
+        factory2.createBlock(
+          [
+            factory2.createExpressionStatement(
+              factory2.createAssignment(
+                factory2.createPropertyAccessExpression(envBinding, "error"),
+                bodyCatchBinding
+              )
+            ),
+            factory2.createExpressionStatement(
+              factory2.createAssignment(
+                factory2.createPropertyAccessExpression(envBinding, "hasError"),
+                factory2.createTrue()
+              )
+            )
+          ],
+          /*multiLine*/
+          true
+        )
+      );
+      let finallyBlock;
+      if (async) {
+        const result = factory2.createUniqueName("result");
+        finallyBlock = factory2.createBlock(
+          [
+            factory2.createVariableStatement(
+              /*modifiers*/
+              void 0,
+              factory2.createVariableDeclarationList([
+                factory2.createVariableDeclaration(
+                  result,
+                  /*exclamationToken*/
+                  void 0,
+                  /*type*/
+                  void 0,
+                  emitHelpers().createDisposeResourcesHelper(envBinding)
+                )
+              ], 2 /* Const */)
+            ),
+            factory2.createIfStatement(result, factory2.createExpressionStatement(factory2.createAwaitExpression(result)))
+          ],
+          /*multiLine*/
+          true
+        );
+      } else {
+        finallyBlock = factory2.createBlock(
+          [
+            factory2.createExpressionStatement(
+              emitHelpers().createDisposeResourcesHelper(envBinding)
+            )
+          ],
+          /*multiLine*/
+          true
+        );
+      }
+      const tryStatement = factory2.createTryStatement(tryBlock, catchClause, finallyBlock);
+      statements.push(tryStatement);
+      return statements;
+    }
+  }
+  function countPrologueStatements(statements) {
+    for (let i = 0; i < statements.length; i++) {
+      if (!isPrologueDirective(statements[i]) && !isCustomPrologue(statements[i])) {
+        return i;
+      }
+    }
+    return 0;
+  }
+  function isUsingVariableDeclarationList(node) {
+    return isVariableDeclarationList(node) && getUsingKindOfVariableDeclarationList(node) !== 0 /* None */;
+  }
+  function getUsingKindOfVariableDeclarationList(node) {
+    return (node.flags & 7 /* BlockScoped */) === 6 /* AwaitUsing */ ? 2 /* Async */ : (node.flags & 7 /* BlockScoped */) === 4 /* Using */ ? 1 /* Sync */ : 0 /* None */;
+  }
+  function getUsingKindOfVariableStatement(node) {
+    return getUsingKindOfVariableDeclarationList(node.declarationList);
+  }
+  function getUsingKind(statement) {
+    return isVariableStatement(statement) ? getUsingKindOfVariableStatement(statement) : 0 /* None */;
+  }
+  function getUsingKindOfStatements(statements) {
+    let result = 0 /* None */;
+    for (const statement of statements) {
+      const usingKind = getUsingKind(statement);
+      if (usingKind === 2 /* Async */)
+        return 2 /* Async */;
+      if (usingKind > result)
+        result = usingKind;
+    }
+    return result;
+  }
+  function getUsingKindOfCaseOrDefaultClauses(clauses) {
+    let result = 0 /* None */;
+    for (const clause of clauses) {
+      const usingKind = getUsingKindOfStatements(clause.statements);
+      if (usingKind === 2 /* Async */)
+        return 2 /* Async */;
+      if (usingKind > result)
+        result = usingKind;
+    }
+    return result;
   }
   var init_esnext = __esm({
     "src/compiler/transformers/esnext.ts"() {
@@ -197195,7 +182305,7 @@ ${lanes.join("\n")}
                 factory2.createNamedImports(arrayFrom(importSpecifiersMap.values()))
               ),
               factory2.createStringLiteral(importSource),
-              /*assertClause*/
+              /*attributes*/
               void 0
             );
             setParentRecursive(
@@ -197254,25 +182364,25 @@ ${lanes.join("\n")}
     }
     function visitorWorker(node) {
       switch (node.kind) {
-        case 283 /* JsxElement */:
+        case 284 /* JsxElement */:
           return visitJsxElement(
             node,
             /*isChild*/
             false
           );
-        case 284 /* JsxSelfClosingElement */:
+        case 285 /* JsxSelfClosingElement */:
           return visitJsxSelfClosingElement(
             node,
             /*isChild*/
             false
           );
-        case 287 /* JsxFragment */:
+        case 288 /* JsxFragment */:
           return visitJsxFragment(
             node,
             /*isChild*/
             false
           );
-        case 293 /* JsxExpression */:
+        case 294 /* JsxExpression */:
           return visitJsxExpression(node);
         default:
           return visitEachChild(node, visitor, context);
@@ -197282,21 +182392,21 @@ ${lanes.join("\n")}
       switch (node.kind) {
         case 12 /* JsxText */:
           return visitJsxText(node);
-        case 293 /* JsxExpression */:
+        case 294 /* JsxExpression */:
           return visitJsxExpression(node);
-        case 283 /* JsxElement */:
+        case 284 /* JsxElement */:
           return visitJsxElement(
             node,
             /*isChild*/
             true
           );
-        case 284 /* JsxSelfClosingElement */:
+        case 285 /* JsxSelfClosingElement */:
           return visitJsxSelfClosingElement(
             node,
             /*isChild*/
             true
           );
-        case 287 /* JsxFragment */:
+        case 288 /* JsxFragment */:
           return visitJsxFragment(
             node,
             /*isChild*/
@@ -197307,7 +182417,9 @@ ${lanes.join("\n")}
       }
     }
     function hasProto(obj) {
-      return obj.properties.some((p) => isPropertyAssignment(p) && (isIdentifier(p.name) && idText(p.name) === "__proto__" || isStringLiteral(p.name) && p.name.text === "__proto__"));
+      return obj.properties.some(
+        (p) => isPropertyAssignment(p) && (isIdentifier(p.name) && idText(p.name) === "__proto__" || isStringLiteral(p.name) && p.name.text === "__proto__")
+      );
     }
     function hasKeyAfterPropsSpread(node) {
       let spread = false;
@@ -197480,7 +182592,7 @@ ${lanes.join("\n")}
     }
     function transformJsxSpreadAttributeToProps(node) {
       if (isObjectLiteralExpression(node.expression) && !hasProto(node.expression)) {
-        return node.expression.properties;
+        return sameMap(node.expression.properties, (p) => Debug.checkDefined(visitNode(p, visitor, isObjectLiteralElementLike)));
       }
       return factory2.createSpreadAssignment(Debug.checkDefined(visitNode(node.expression, visitor, isExpression)));
     }
@@ -197504,10 +182616,10 @@ ${lanes.join("\n")}
             for (const prop of attr.expression.properties) {
               if (isSpreadAssignment(prop)) {
                 finishObjectLiteralIfNeeded();
-                expressions.push(prop.expression);
+                expressions.push(Debug.checkDefined(visitNode(prop.expression, visitor, isExpression)));
                 continue;
               }
-              properties.push(prop);
+              properties.push(Debug.checkDefined(visitNode(prop, visitor)));
             }
             continue;
           }
@@ -197546,7 +182658,7 @@ ${lanes.join("\n")}
         const literal = factory2.createStringLiteral(tryDecodeEntities(node.text) || node.text, singleQuote);
         return setTextRange(literal, node);
       }
-      if (node.kind === 293 /* JsxExpression */) {
+      if (node.kind === 294 /* JsxExpression */) {
         if (node.expression === void 0) {
           return factory2.createTrue();
         }
@@ -197620,7 +182732,7 @@ ${lanes.join("\n")}
       return decoded === text ? void 0 : decoded;
     }
     function getTagName(node) {
-      if (node.kind === 283 /* JsxElement */) {
+      if (node.kind === 284 /* JsxElement */) {
         return getTagName(node.openingElement);
       } else {
         const tagName = node.tagName;
@@ -197927,7 +183039,7 @@ ${lanes.join("\n")}
         return node;
       }
       switch (node.kind) {
-        case 225 /* BinaryExpression */:
+        case 226 /* BinaryExpression */:
           return visitBinaryExpression(node);
         default:
           return visitEachChild(node, visitor, context);
@@ -198061,7 +183173,7 @@ ${lanes.join("\n")}
       hierarchyFacts = (hierarchyFacts & ~excludeFacts | includeFacts) & -32768 /* SubtreeFactsMask */ | ancestorFacts;
     }
     function isReturnVoidStatementInConstructorWithCapturedSuper(node) {
-      return (hierarchyFacts & 8192 /* ConstructorWithCapturedSuper */) !== 0 && node.kind === 252 /* ReturnStatement */ && !node.expression;
+      return (hierarchyFacts & 8192 /* ConstructorWithSuperCall */) !== 0 && node.kind === 253 /* ReturnStatement */ && !node.expression;
     }
     function isOrMayContainReturnCompletion(node) {
       return node.transformFlags & 4194304 /* ContainsHoistedDeclarationOrCompletion */ && (isReturnStatement(node) || isIfStatement(node) || isWithStatement(node) || isSwitchStatement(node) || isCaseBlock(node) || isCaseClause(node) || isDefaultClause(node) || isTryStatement(node) || isCatchClause(node) || isLabeledStatement(node) || isIterationStatement(
@@ -198071,7 +183183,7 @@ ${lanes.join("\n")}
       ) || isBlock(node));
     }
     function shouldVisitNode(node) {
-      return (node.transformFlags & 1024 /* ContainsES2015 */) !== 0 || convertedLoopState !== void 0 || hierarchyFacts & 8192 /* ConstructorWithCapturedSuper */ && isOrMayContainReturnCompletion(node) || isIterationStatement(
+      return (node.transformFlags & 1024 /* ContainsES2015 */) !== 0 || convertedLoopState !== void 0 || hierarchyFacts & 8192 /* ConstructorWithSuperCall */ && isOrMayContainReturnCompletion(node) || isIterationStatement(
         node,
         /*lookInLabeledStatements*/
         false
@@ -198104,7 +183216,7 @@ ${lanes.join("\n")}
             /*expressionResultIsUnused*/
             false
           );
-          exitSubtree(ancestorFacts, 98304 /* FunctionSubtreeExcludes */, 0 /* None */);
+          exitSubtree(ancestorFacts, 229376 /* FunctionSubtreeExcludes */, 0 /* None */);
           return result;
         }
         return visitorWorker(
@@ -198118,6 +183230,7 @@ ${lanes.join("\n")}
     function callExpressionVisitor(node) {
       if (node.kind === 108 /* SuperKeyword */) {
         return visitSuperKeyword(
+          node,
           /*isExpressionOfCall*/
           true
         );
@@ -198128,85 +183241,85 @@ ${lanes.join("\n")}
       switch (node.kind) {
         case 126 /* StaticKeyword */:
           return void 0;
-        case 262 /* ClassDeclaration */:
+        case 263 /* ClassDeclaration */:
           return visitClassDeclaration(node);
-        case 230 /* ClassExpression */:
+        case 231 /* ClassExpression */:
           return visitClassExpression(node);
-        case 168 /* Parameter */:
+        case 169 /* Parameter */:
           return visitParameter(node);
-        case 261 /* FunctionDeclaration */:
+        case 262 /* FunctionDeclaration */:
           return visitFunctionDeclaration(node);
-        case 218 /* ArrowFunction */:
+        case 219 /* ArrowFunction */:
           return visitArrowFunction(node);
-        case 217 /* FunctionExpression */:
+        case 218 /* FunctionExpression */:
           return visitFunctionExpression(node);
-        case 259 /* VariableDeclaration */:
+        case 260 /* VariableDeclaration */:
           return visitVariableDeclaration(node);
         case 80 /* Identifier */:
           return visitIdentifier(node);
-        case 260 /* VariableDeclarationList */:
+        case 261 /* VariableDeclarationList */:
           return visitVariableDeclarationList(node);
-        case 254 /* SwitchStatement */:
+        case 255 /* SwitchStatement */:
           return visitSwitchStatement(node);
-        case 268 /* CaseBlock */:
+        case 269 /* CaseBlock */:
           return visitCaseBlock(node);
-        case 240 /* Block */:
+        case 241 /* Block */:
           return visitBlock(
             node,
             /*isFunctionBody*/
             false
           );
-        case 251 /* BreakStatement */:
-        case 250 /* ContinueStatement */:
+        case 252 /* BreakStatement */:
+        case 251 /* ContinueStatement */:
           return visitBreakOrContinueStatement(node);
-        case 255 /* LabeledStatement */:
+        case 256 /* LabeledStatement */:
           return visitLabeledStatement(node);
-        case 245 /* DoStatement */:
-        case 246 /* WhileStatement */:
+        case 246 /* DoStatement */:
+        case 247 /* WhileStatement */:
           return visitDoOrWhileStatement(
             node,
             /*outermostLabeledStatement*/
             void 0
           );
-        case 247 /* ForStatement */:
+        case 248 /* ForStatement */:
           return visitForStatement(
             node,
             /*outermostLabeledStatement*/
             void 0
           );
-        case 248 /* ForInStatement */:
+        case 249 /* ForInStatement */:
           return visitForInStatement(
             node,
             /*outermostLabeledStatement*/
             void 0
           );
-        case 249 /* ForOfStatement */:
+        case 250 /* ForOfStatement */:
           return visitForOfStatement(
             node,
             /*outermostLabeledStatement*/
             void 0
           );
-        case 243 /* ExpressionStatement */:
+        case 244 /* ExpressionStatement */:
           return visitExpressionStatement(node);
-        case 209 /* ObjectLiteralExpression */:
+        case 210 /* ObjectLiteralExpression */:
           return visitObjectLiteralExpression(node);
-        case 298 /* CatchClause */:
+        case 299 /* CatchClause */:
           return visitCatchClause(node);
-        case 303 /* ShorthandPropertyAssignment */:
+        case 304 /* ShorthandPropertyAssignment */:
           return visitShorthandPropertyAssignment(node);
-        case 166 /* ComputedPropertyName */:
+        case 167 /* ComputedPropertyName */:
           return visitComputedPropertyName(node);
-        case 208 /* ArrayLiteralExpression */:
+        case 209 /* ArrayLiteralExpression */:
           return visitArrayLiteralExpression(node);
-        case 212 /* CallExpression */:
+        case 213 /* CallExpression */:
           return visitCallExpression(node);
-        case 213 /* NewExpression */:
+        case 214 /* NewExpression */:
           return visitNewExpression(node);
-        case 216 /* ParenthesizedExpression */:
+        case 217 /* ParenthesizedExpression */:
           return visitParenthesizedExpression(node, expressionResultIsUnused2);
-        case 225 /* BinaryExpression */:
+        case 226 /* BinaryExpression */:
           return visitBinaryExpression(node, expressionResultIsUnused2);
-        case 360 /* CommaListExpression */:
+        case 361 /* CommaListExpression */:
           return visitCommaListExpression(node, expressionResultIsUnused2);
         case 15 /* NoSubstitutionTemplateLiteral */:
         case 16 /* TemplateHead */:
@@ -198217,33 +183330,34 @@ ${lanes.join("\n")}
           return visitStringLiteral(node);
         case 9 /* NumericLiteral */:
           return visitNumericLiteral(node);
-        case 214 /* TaggedTemplateExpression */:
+        case 215 /* TaggedTemplateExpression */:
           return visitTaggedTemplateExpression(node);
-        case 227 /* TemplateExpression */:
+        case 228 /* TemplateExpression */:
           return visitTemplateExpression(node);
-        case 228 /* YieldExpression */:
+        case 229 /* YieldExpression */:
           return visitYieldExpression(node);
-        case 229 /* SpreadElement */:
+        case 230 /* SpreadElement */:
           return visitSpreadElement(node);
         case 108 /* SuperKeyword */:
           return visitSuperKeyword(
+            node,
             /*isExpressionOfCall*/
             false
           );
         case 110 /* ThisKeyword */:
           return visitThisKeyword(node);
-        case 235 /* MetaProperty */:
+        case 236 /* MetaProperty */:
           return visitMetaProperty(node);
-        case 173 /* MethodDeclaration */:
+        case 174 /* MethodDeclaration */:
           return visitMethodDeclaration(node);
-        case 176 /* GetAccessor */:
-        case 177 /* SetAccessor */:
+        case 177 /* GetAccessor */:
+        case 178 /* SetAccessor */:
           return visitAccessorDeclaration(node);
-        case 242 /* VariableStatement */:
+        case 243 /* VariableStatement */:
           return visitVariableStatement(node);
-        case 252 /* ReturnStatement */:
+        case 253 /* ReturnStatement */:
           return visitReturnStatement(node);
-        case 221 /* VoidExpression */:
+        case 222 /* VoidExpression */:
           return visitVoidExpression(node);
         default:
           return visitEachChild(node, visitor, context);
@@ -198296,7 +183410,10 @@ ${lanes.join("\n")}
       return updated;
     }
     function returnCapturedThis(node) {
-      return setOriginalNode(factory2.createReturnStatement(factory2.createUniqueName("_this", 16 /* Optimistic */ | 32 /* FileLevel */)), node);
+      return setOriginalNode(factory2.createReturnStatement(createCapturedThis()), node);
+    }
+    function createCapturedThis() {
+      return factory2.createUniqueName("_this", 16 /* Optimistic */ | 32 /* FileLevel */);
     }
     function visitReturnStatement(node) {
       if (convertedLoopState) {
@@ -198320,8 +183437,9 @@ ${lanes.join("\n")}
       return visitEachChild(node, visitor, context);
     }
     function visitThisKeyword(node) {
+      hierarchyFacts |= 65536 /* LexicalThis */;
       if (hierarchyFacts & 2 /* ArrowFunction */ && !(hierarchyFacts & 16384 /* StaticInitializer */)) {
-        hierarchyFacts |= 65536 /* CapturedLexicalThis */;
+        hierarchyFacts |= 131072 /* CapturedLexicalThis */;
       }
       if (convertedLoopState) {
         if (hierarchyFacts & 2 /* ArrowFunction */) {
@@ -198341,23 +183459,26 @@ ${lanes.join("\n")}
           return convertedLoopState.argumentsName || (convertedLoopState.argumentsName = factory2.createUniqueName("arguments"));
         }
       }
-      if (node.flags & 128 /* IdentifierHasExtendedUnicodeEscape */) {
-        return setOriginalNode(setTextRange(
-          factory2.createIdentifier(unescapeLeadingUnderscores(node.escapedText)),
+      if (node.flags & 256 /* IdentifierHasExtendedUnicodeEscape */) {
+        return setOriginalNode(
+          setTextRange(
+            factory2.createIdentifier(unescapeLeadingUnderscores(node.escapedText)),
+            node
+          ),
           node
-        ), node);
+        );
       }
       return node;
     }
     function visitBreakOrContinueStatement(node) {
       if (convertedLoopState) {
-        const jump = node.kind === 251 /* BreakStatement */ ? 2 /* Break */ : 4 /* Continue */;
+        const jump = node.kind === 252 /* BreakStatement */ ? 2 /* Break */ : 4 /* Continue */;
         const canUseBreakOrContinue = node.label && convertedLoopState.labels && convertedLoopState.labels.get(idText(node.label)) || !node.label && convertedLoopState.allowedNonLabeledJumps & jump;
         if (!canUseBreakOrContinue) {
           let labelMarker;
           const label = node.label;
           if (!label) {
-            if (node.kind === 251 /* BreakStatement */) {
+            if (node.kind === 252 /* BreakStatement */) {
               convertedLoopState.nonLocalJumps |= 2 /* Break */;
               labelMarker = "break";
             } else {
@@ -198365,7 +183486,7 @@ ${lanes.join("\n")}
               labelMarker = "continue";
             }
           } else {
-            if (node.kind === 251 /* BreakStatement */) {
+            if (node.kind === 252 /* BreakStatement */) {
               labelMarker = `break-${label.escapedText}`;
               setLabeledJump(
                 convertedLoopState,
@@ -198428,8 +183549,8 @@ ${lanes.join("\n")}
       setTextRange(statement, node);
       startOnNewLine(statement);
       statements.push(statement);
-      if (hasSyntacticModifier(node, 1 /* Export */)) {
-        const exportStatement = hasSyntacticModifier(node, 1024 /* Default */) ? factory2.createExportDefault(factory2.getLocalName(node)) : factory2.createExternalModuleExport(factory2.getLocalName(node));
+      if (hasSyntacticModifier(node, 32 /* Export */)) {
+        const exportStatement = hasSyntacticModifier(node, 2048 /* Default */) ? factory2.createExportDefault(factory2.getLocalName(node)) : factory2.createExternalModuleExport(factory2.getLocalName(node));
         setOriginalNode(exportStatement, statement);
         statements.push(exportStatement);
       }
@@ -198457,7 +183578,7 @@ ${lanes.join("\n")}
           void 0,
           /*dotDotDotToken*/
           void 0,
-          factory2.createUniqueName("_super", 16 /* Optimistic */ | 32 /* FileLevel */)
+          createSyntheticSuper()
         )] : [],
         /*type*/
         void 0,
@@ -198547,7 +183668,7 @@ ${lanes.join("\n")}
         setEmitFlags(constructorFunction, 16 /* CapturesThis */);
       }
       statements.push(constructorFunction);
-      exitSubtree(ancestorFacts, 98304 /* FunctionSubtreeExcludes */, 0 /* None */);
+      exitSubtree(ancestorFacts, 229376 /* FunctionSubtreeExcludes */, 0 /* None */);
       convertedLoopState = savedConvertedLoopState;
     }
     function transformConstructorParameters(constructor, hasSynthesizedSuper) {
@@ -198571,6 +183692,36 @@ ${lanes.join("\n")}
       setEmitFlags(block, 3072 /* NoComments */);
       return block;
     }
+    function isUninitializedVariableStatement(node) {
+      return isVariableStatement(node) && every(node.declarationList.declarations, (decl) => isIdentifier(decl.name) && !decl.initializer);
+    }
+    function containsSuperCall(node) {
+      if (isSuperCall(node)) {
+        return true;
+      }
+      if (!(node.transformFlags & 134217728 /* ContainsLexicalSuper */)) {
+        return false;
+      }
+      switch (node.kind) {
+        case 219 /* ArrowFunction */:
+        case 218 /* FunctionExpression */:
+        case 262 /* FunctionDeclaration */:
+        case 176 /* Constructor */:
+        case 175 /* ClassStaticBlockDeclaration */:
+          return false;
+        case 177 /* GetAccessor */:
+        case 178 /* SetAccessor */:
+        case 174 /* MethodDeclaration */:
+        case 172 /* PropertyDeclaration */: {
+          const named = node;
+          if (isComputedPropertyName(named.name)) {
+            return !!forEachChild(named.name, containsSuperCall);
+          }
+          return false;
+        }
+      }
+      return !!forEachChild(node, containsSuperCall);
+    }
     function transformConstructorBody(constructor, node, extendsClauseElement, hasSynthesizedSuper) {
       const isDerivedClass = !!extendsClauseElement && skipOuterExpressions(extendsClauseElement.expression).kind !== 106 /* NullKeyword */;
       if (!constructor)
@@ -198578,82 +183729,34 @@ ${lanes.join("\n")}
       const prologue = [];
       const statements = [];
       resumeLexicalEnvironment();
-      const existingPrologue = takeWhile(constructor.body.statements, isPrologueDirective);
-      const { superCall, superStatementIndex } = findSuperCallAndStatementIndex(constructor.body.statements, existingPrologue);
-      const postSuperStatementsStart = superStatementIndex === -1 ? existingPrologue.length : superStatementIndex + 1;
-      let statementOffset = postSuperStatementsStart;
-      if (!hasSynthesizedSuper)
-        statementOffset = factory2.copyStandardPrologue(
-          constructor.body.statements,
-          prologue,
-          statementOffset,
-          /*ensureUseStrict*/
-          false
-        );
-      if (!hasSynthesizedSuper)
-        statementOffset = factory2.copyCustomPrologue(
-          constructor.body.statements,
-          statements,
-          statementOffset,
-          visitor,
-          /*filter*/
-          void 0
-        );
-      let superCallExpression;
-      if (hasSynthesizedSuper) {
-        superCallExpression = createDefaultSuperCallOrThis();
-      } else if (superCall) {
-        superCallExpression = visitSuperCallInBody(superCall);
-      }
-      if (superCallExpression) {
-        hierarchyFacts |= 8192 /* ConstructorWithCapturedSuper */;
-      }
-      addDefaultValueAssignmentsIfNeeded2(prologue, constructor);
-      addRestParameterIfNeeded(prologue, constructor, hasSynthesizedSuper);
-      addRange(statements, visitNodes2(
+      const standardPrologueEnd = factory2.copyStandardPrologue(
         constructor.body.statements,
-        visitor,
-        isStatement,
-        /*start*/
-        statementOffset
-      ));
-      factory2.mergeLexicalEnvironment(prologue, endLexicalEnvironment());
-      insertCaptureNewTargetIfNeeded(
         prologue,
-        constructor,
-        /*copyOnWrite*/
-        false
+        /*statementOffset*/
+        0
       );
-      if (isDerivedClass || superCallExpression) {
-        if (superCallExpression && postSuperStatementsStart === constructor.body.statements.length && !(constructor.body.transformFlags & 16384 /* ContainsLexicalThis */)) {
-          const superCall2 = cast(cast(superCallExpression, isBinaryExpression).left, isCallExpression);
-          const returnStatement = factory2.createReturnStatement(superCallExpression);
-          setCommentRange(returnStatement, getCommentRange(superCall2));
-          setEmitFlags(superCall2, 3072 /* NoComments */);
-          statements.push(returnStatement);
-        } else {
-          if (superStatementIndex <= existingPrologue.length) {
-            insertCaptureThisForNode(statements, constructor, superCallExpression || createActualThis());
-          } else {
-            insertCaptureThisForNode(prologue, constructor, createActualThis());
-            if (superCallExpression) {
-              insertSuperThisCaptureThisForNode(statements, superCallExpression);
-            }
-          }
-          if (!isSufficientlyCoveredByReturnStatements(constructor.body)) {
-            statements.push(factory2.createReturnStatement(factory2.createUniqueName("_this", 16 /* Optimistic */ | 32 /* FileLevel */)));
-          }
-        }
+      if (hasSynthesizedSuper || containsSuperCall(constructor.body)) {
+        hierarchyFacts |= 8192 /* ConstructorWithSuperCall */;
+      }
+      addRange(statements, visitNodes2(constructor.body.statements, visitor, isStatement, standardPrologueEnd));
+      const mayReplaceThis = isDerivedClass || hierarchyFacts & 8192 /* ConstructorWithSuperCall */;
+      addDefaultValueAssignmentsIfNeeded2(prologue, constructor);
+      addRestParameterIfNeeded(prologue, constructor, hasSynthesizedSuper);
+      insertCaptureNewTargetIfNeeded(prologue, constructor);
+      if (mayReplaceThis) {
+        insertCaptureThisForNode(prologue, constructor, createActualThis());
       } else {
         insertCaptureThisForNodeIfNeeded(prologue, constructor);
       }
+      factory2.mergeLexicalEnvironment(prologue, endLexicalEnvironment());
+      if (mayReplaceThis && !isSufficientlyCoveredByReturnStatements(constructor.body)) {
+        statements.push(factory2.createReturnStatement(createCapturedThis()));
+      }
       const body = factory2.createBlock(
         setTextRange(
           factory2.createNodeArray(
             [
-              ...existingPrologue,
               ...prologue,
-              ...superStatementIndex <= existingPrologue.length ? emptyArray : visitNodes2(constructor.body.statements, visitor, isStatement, existingPrologue.length, superStatementIndex - existingPrologue.length),
               ...statements
             ]
           ),
@@ -198664,31 +183767,241 @@ ${lanes.join("\n")}
         true
       );
       setTextRange(body, constructor.body);
+      return simplifyConstructor(body, constructor.body, hasSynthesizedSuper);
+    }
+    function isCapturedThis(node) {
+      return isGeneratedIdentifier(node) && idText(node) === "_this";
+    }
+    function isSyntheticSuper(node) {
+      return isGeneratedIdentifier(node) && idText(node) === "_super";
+    }
+    function isThisCapturingVariableStatement(node) {
+      return isVariableStatement(node) && node.declarationList.declarations.length === 1 && isThisCapturingVariableDeclaration(node.declarationList.declarations[0]);
+    }
+    function isThisCapturingVariableDeclaration(node) {
+      return isVariableDeclaration(node) && isCapturedThis(node.name) && !!node.initializer;
+    }
+    function isThisCapturingAssignment(node) {
+      return isAssignmentExpression(
+        node,
+        /*excludeCompoundAssignment*/
+        true
+      ) && isCapturedThis(node.left);
+    }
+    function isTransformedSuperCall(node) {
+      return isCallExpression(node) && isPropertyAccessExpression(node.expression) && isSyntheticSuper(node.expression.expression) && isIdentifier(node.expression.name) && (idText(node.expression.name) === "call" || idText(node.expression.name) === "apply") && node.arguments.length >= 1 && node.arguments[0].kind === 110 /* ThisKeyword */;
+    }
+    function isTransformedSuperCallWithFallback(node) {
+      return isBinaryExpression(node) && node.operatorToken.kind === 57 /* BarBarToken */ && node.right.kind === 110 /* ThisKeyword */ && isTransformedSuperCall(node.left);
+    }
+    function isImplicitSuperCall(node) {
+      return isBinaryExpression(node) && node.operatorToken.kind === 56 /* AmpersandAmpersandToken */ && isBinaryExpression(node.left) && node.left.operatorToken.kind === 38 /* ExclamationEqualsEqualsToken */ && isSyntheticSuper(node.left.left) && node.left.right.kind === 106 /* NullKeyword */ && isTransformedSuperCall(node.right) && idText(node.right.expression.name) === "apply";
+    }
+    function isImplicitSuperCallWithFallback(node) {
+      return isBinaryExpression(node) && node.operatorToken.kind === 57 /* BarBarToken */ && node.right.kind === 110 /* ThisKeyword */ && isImplicitSuperCall(node.left);
+    }
+    function isThisCapturingTransformedSuperCallWithFallback(node) {
+      return isThisCapturingAssignment(node) && isTransformedSuperCallWithFallback(node.right);
+    }
+    function isThisCapturingImplicitSuperCallWithFallback(node) {
+      return isThisCapturingAssignment(node) && isImplicitSuperCallWithFallback(node.right);
+    }
+    function isTransformedSuperCallLike(node) {
+      return isTransformedSuperCall(node) || isTransformedSuperCallWithFallback(node) || isThisCapturingTransformedSuperCallWithFallback(node) || isImplicitSuperCall(node) || isImplicitSuperCallWithFallback(node) || isThisCapturingImplicitSuperCallWithFallback(node);
+    }
+    function simplifyConstructorInlineSuperInThisCaptureVariable(body) {
+      for (let i = 0; i < body.statements.length - 1; i++) {
+        const statement = body.statements[i];
+        if (!isThisCapturingVariableStatement(statement)) {
+          continue;
+        }
+        const varDecl = statement.declarationList.declarations[0];
+        if (varDecl.initializer.kind !== 110 /* ThisKeyword */) {
+          continue;
+        }
+        const thisCaptureStatementIndex = i;
+        let superCallIndex = i + 1;
+        while (superCallIndex < body.statements.length) {
+          const statement2 = body.statements[superCallIndex];
+          if (isExpressionStatement(statement2)) {
+            if (isTransformedSuperCallLike(skipOuterExpressions(statement2.expression))) {
+              break;
+            }
+          }
+          if (isUninitializedVariableStatement(statement2)) {
+            superCallIndex++;
+            continue;
+          }
+          return body;
+        }
+        const following = body.statements[superCallIndex];
+        let expression = following.expression;
+        if (isThisCapturingAssignment(expression)) {
+          expression = expression.right;
+        }
+        const newVarDecl = factory2.updateVariableDeclaration(
+          varDecl,
+          varDecl.name,
+          /*exclamationToken*/
+          void 0,
+          /*type*/
+          void 0,
+          expression
+        );
+        const newDeclList = factory2.updateVariableDeclarationList(statement.declarationList, [newVarDecl]);
+        const newVarStatement = factory2.createVariableStatement(statement.modifiers, newDeclList);
+        setOriginalNode(newVarStatement, following);
+        setTextRange(newVarStatement, following);
+        const newStatements = factory2.createNodeArray([
+          ...body.statements.slice(0, thisCaptureStatementIndex),
+          // copy statements preceding to `var _this`
+          ...body.statements.slice(thisCaptureStatementIndex + 1, superCallIndex),
+          // copy intervening temp variables
+          newVarStatement,
+          ...body.statements.slice(superCallIndex + 1)
+          // copy statements following `super.call(this, ...)`
+        ]);
+        setTextRange(newStatements, body.statements);
+        return factory2.updateBlock(body, newStatements);
+      }
       return body;
     }
-    function findSuperCallAndStatementIndex(originalBodyStatements, existingPrologue) {
-      for (let i = existingPrologue.length; i < originalBodyStatements.length; i += 1) {
-        const superCall = getSuperCallFromStatement(originalBodyStatements[i]);
-        if (superCall) {
-          return {
-            superCall,
-            superStatementIndex: i
-          };
+    function simplifyConstructorInlineSuperReturn(body, original) {
+      for (const statement of original.statements) {
+        if (statement.transformFlags & 134217728 /* ContainsLexicalSuper */ && !getSuperCallFromStatement(statement)) {
+          return body;
         }
       }
-      return {
-        superStatementIndex: -1
-      };
+      const canElideThisCapturingVariable = !(original.transformFlags & 16384 /* ContainsLexicalThis */) && !(hierarchyFacts & 65536 /* LexicalThis */) && !(hierarchyFacts & 131072 /* CapturedLexicalThis */);
+      for (let i = body.statements.length - 1; i > 0; i--) {
+        const statement = body.statements[i];
+        if (isReturnStatement(statement) && statement.expression && isCapturedThis(statement.expression)) {
+          const preceding = body.statements[i - 1];
+          let expression;
+          if (isExpressionStatement(preceding) && isThisCapturingTransformedSuperCallWithFallback(skipOuterExpressions(preceding.expression))) {
+            expression = preceding.expression;
+          } else if (canElideThisCapturingVariable && isThisCapturingVariableStatement(preceding)) {
+            const varDecl = preceding.declarationList.declarations[0];
+            if (isTransformedSuperCallLike(skipOuterExpressions(varDecl.initializer))) {
+              expression = factory2.createAssignment(
+                createCapturedThis(),
+                varDecl.initializer
+              );
+            }
+          }
+          if (!expression) {
+            break;
+          }
+          const newReturnStatement = factory2.createReturnStatement(expression);
+          setOriginalNode(newReturnStatement, preceding);
+          setTextRange(newReturnStatement, preceding);
+          const newStatements = factory2.createNodeArray([
+            ...body.statements.slice(0, i - 1),
+            // copy all statements preceding `_super.call(this, ...)`
+            newReturnStatement,
+            ...body.statements.slice(i + 1)
+            // copy all statements following `return _this;`
+          ]);
+          setTextRange(newStatements, body.statements);
+          return factory2.updateBlock(body, newStatements);
+        }
+      }
+      return body;
+    }
+    function elideUnusedThisCaptureWorker(node) {
+      if (isThisCapturingVariableStatement(node)) {
+        const varDecl = node.declarationList.declarations[0];
+        if (varDecl.initializer.kind === 110 /* ThisKeyword */) {
+          return void 0;
+        }
+      } else if (isThisCapturingAssignment(node)) {
+        return factory2.createPartiallyEmittedExpression(node.right, node);
+      }
+      switch (node.kind) {
+        case 219 /* ArrowFunction */:
+        case 218 /* FunctionExpression */:
+        case 262 /* FunctionDeclaration */:
+        case 176 /* Constructor */:
+        case 175 /* ClassStaticBlockDeclaration */:
+          return node;
+        case 177 /* GetAccessor */:
+        case 178 /* SetAccessor */:
+        case 174 /* MethodDeclaration */:
+        case 172 /* PropertyDeclaration */: {
+          const named = node;
+          if (isComputedPropertyName(named.name)) {
+            return factory2.replacePropertyName(named, visitEachChild(named.name, elideUnusedThisCaptureWorker, nullTransformationContext));
+          }
+          return node;
+        }
+      }
+      return visitEachChild(node, elideUnusedThisCaptureWorker, nullTransformationContext);
+    }
+    function simplifyConstructorElideUnusedThisCapture(body, original) {
+      if (original.transformFlags & 16384 /* ContainsLexicalThis */ || hierarchyFacts & 65536 /* LexicalThis */ || hierarchyFacts & 131072 /* CapturedLexicalThis */) {
+        return body;
+      }
+      for (const statement of original.statements) {
+        if (statement.transformFlags & 134217728 /* ContainsLexicalSuper */ && !getSuperCallFromStatement(statement)) {
+          return body;
+        }
+      }
+      return factory2.updateBlock(body, visitNodes2(body.statements, elideUnusedThisCaptureWorker, isStatement));
+    }
+    function injectSuperPresenceCheckWorker(node) {
+      if (isTransformedSuperCall(node) && node.arguments.length === 2 && isIdentifier(node.arguments[1]) && idText(node.arguments[1]) === "arguments") {
+        return factory2.createLogicalAnd(
+          factory2.createStrictInequality(
+            createSyntheticSuper(),
+            factory2.createNull()
+          ),
+          node
+        );
+      }
+      switch (node.kind) {
+        case 219 /* ArrowFunction */:
+        case 218 /* FunctionExpression */:
+        case 262 /* FunctionDeclaration */:
+        case 176 /* Constructor */:
+        case 175 /* ClassStaticBlockDeclaration */:
+          return node;
+        case 177 /* GetAccessor */:
+        case 178 /* SetAccessor */:
+        case 174 /* MethodDeclaration */:
+        case 172 /* PropertyDeclaration */: {
+          const named = node;
+          if (isComputedPropertyName(named.name)) {
+            return factory2.replacePropertyName(named, visitEachChild(named.name, injectSuperPresenceCheckWorker, nullTransformationContext));
+          }
+          return node;
+        }
+      }
+      return visitEachChild(node, injectSuperPresenceCheckWorker, nullTransformationContext);
+    }
+    function complicateConstructorInjectSuperPresenceCheck(body) {
+      return factory2.updateBlock(body, visitNodes2(body.statements, injectSuperPresenceCheckWorker, isStatement));
+    }
+    function simplifyConstructor(body, original, hasSynthesizedSuper) {
+      const inputBody = body;
+      body = simplifyConstructorInlineSuperInThisCaptureVariable(body);
+      body = simplifyConstructorInlineSuperReturn(body, original);
+      if (body !== inputBody) {
+        body = simplifyConstructorElideUnusedThisCapture(body, original);
+      }
+      if (hasSynthesizedSuper) {
+        body = complicateConstructorInjectSuperPresenceCheck(body);
+      }
+      return body;
     }
     function isSufficientlyCoveredByReturnStatements(statement) {
-      if (statement.kind === 252 /* ReturnStatement */) {
+      if (statement.kind === 253 /* ReturnStatement */) {
         return true;
-      } else if (statement.kind === 244 /* IfStatement */) {
+      } else if (statement.kind === 245 /* IfStatement */) {
         const ifStatement = statement;
         if (ifStatement.elseStatement) {
           return isSufficientlyCoveredByReturnStatements(ifStatement.thenStatement) && isSufficientlyCoveredByReturnStatements(ifStatement.elseStatement);
         }
-      } else if (statement.kind === 240 /* Block */) {
+      } else if (statement.kind === 241 /* Block */) {
         const lastStatement = lastOrUndefined(statement.statements);
         if (lastStatement && isSufficientlyCoveredByReturnStatements(lastStatement)) {
           return true;
@@ -198703,11 +184016,11 @@ ${lanes.join("\n")}
       return factory2.createLogicalOr(
         factory2.createLogicalAnd(
           factory2.createStrictInequality(
-            factory2.createUniqueName("_super", 16 /* Optimistic */ | 32 /* FileLevel */),
+            createSyntheticSuper(),
             factory2.createNull()
           ),
           factory2.createFunctionApplyCall(
-            factory2.createUniqueName("_super", 16 /* Optimistic */ | 32 /* FileLevel */),
+            createSyntheticSuper(),
             createActualThis(),
             factory2.createIdentifier("arguments")
           )
@@ -198962,24 +184275,12 @@ ${lanes.join("\n")}
       return true;
     }
     function insertCaptureThisForNodeIfNeeded(statements, node) {
-      if (hierarchyFacts & 65536 /* CapturedLexicalThis */ && node.kind !== 218 /* ArrowFunction */) {
+      if (hierarchyFacts & 131072 /* CapturedLexicalThis */ && node.kind !== 219 /* ArrowFunction */) {
         insertCaptureThisForNode(statements, node, factory2.createThis());
         return true;
       }
       return false;
     }
-    function insertSuperThisCaptureThisForNode(statements, superExpression) {
-      enableSubstitutionsForCapturedThis();
-      const assignSuperExpression = factory2.createExpressionStatement(
-        factory2.createBinaryExpression(
-          factory2.createThis(),
-          64 /* EqualsToken */,
-          superExpression
-        )
-      );
-      insertStatementAfterCustomPrologue(statements, assignSuperExpression);
-      setCommentRange(assignSuperExpression, getOriginalNode(superExpression).parent);
-    }
     function insertCaptureThisForNode(statements, node, initializer) {
       enableSubstitutionsForCapturedThis();
       const captureThisStatement = factory2.createVariableStatement(
@@ -198987,7 +184288,7 @@ ${lanes.join("\n")}
         void 0,
         factory2.createVariableDeclarationList([
           factory2.createVariableDeclaration(
-            factory2.createUniqueName("_this", 16 /* Optimistic */ | 32 /* FileLevel */),
+            createCapturedThis(),
             /*exclamationToken*/
             void 0,
             /*type*/
@@ -199000,25 +184301,25 @@ ${lanes.join("\n")}
       setSourceMapRange(captureThisStatement, node);
       insertStatementAfterCustomPrologue(statements, captureThisStatement);
     }
-    function insertCaptureNewTargetIfNeeded(statements, node, copyOnWrite) {
+    function insertCaptureNewTargetIfNeeded(statements, node) {
       if (hierarchyFacts & 32768 /* NewTarget */) {
         let newTarget;
         switch (node.kind) {
-          case 218 /* ArrowFunction */:
+          case 219 /* ArrowFunction */:
             return statements;
-          case 173 /* MethodDeclaration */:
-          case 176 /* GetAccessor */:
-          case 177 /* SetAccessor */:
+          case 174 /* MethodDeclaration */:
+          case 177 /* GetAccessor */:
+          case 178 /* SetAccessor */:
             newTarget = factory2.createVoidZero();
             break;
-          case 175 /* Constructor */:
+          case 176 /* Constructor */:
             newTarget = factory2.createPropertyAccessExpression(
               setEmitFlags(factory2.createThis(), 8 /* NoSubstitution */),
               "constructor"
             );
             break;
-          case 261 /* FunctionDeclaration */:
-          case 217 /* FunctionExpression */:
+          case 262 /* FunctionDeclaration */:
+          case 218 /* FunctionExpression */:
             newTarget = factory2.createConditionalExpression(
               factory2.createLogicalAnd(
                 setEmitFlags(factory2.createThis(), 8 /* NoSubstitution */),
@@ -199057,9 +184358,6 @@ ${lanes.join("\n")}
           ])
         );
         setEmitFlags(captureNewTargetStatement, 3072 /* NoComments */ | 2097152 /* CustomPrologue */);
-        if (copyOnWrite) {
-          statements = statements.slice();
-        }
         insertStatementAfterCustomPrologue(statements, captureNewTargetStatement);
       }
       return statements;
@@ -199067,21 +184365,21 @@ ${lanes.join("\n")}
     function addClassMembers(statements, node) {
       for (const member of node.members) {
         switch (member.kind) {
-          case 239 /* SemicolonClassElement */:
+          case 240 /* SemicolonClassElement */:
             statements.push(transformSemicolonClassElementToStatement(member));
             break;
-          case 173 /* MethodDeclaration */:
+          case 174 /* MethodDeclaration */:
             statements.push(transformClassMethodDeclarationToStatement(getClassMemberPrefix(node, member), member, node));
             break;
-          case 176 /* GetAccessor */:
-          case 177 /* SetAccessor */:
+          case 177 /* GetAccessor */:
+          case 178 /* SetAccessor */:
             const accessors = getAllAccessorDeclarations(node.members, member);
             if (member === accessors.firstAccessor) {
               statements.push(transformAccessorsToStatement(getClassMemberPrefix(node, member), accessors, node));
             }
             break;
-          case 175 /* Constructor */:
-          case 174 /* ClassStaticBlockDeclaration */:
+          case 176 /* Constructor */:
+          case 175 /* ClassStaticBlockDeclaration */:
             break;
           default:
             Debug.failBadSyntaxKind(member, currentSourceFile && currentSourceFile.fileName);
@@ -199211,7 +184509,7 @@ ${lanes.join("\n")}
     }
     function visitArrowFunction(node) {
       if (node.transformFlags & 16384 /* ContainsLexicalThis */ && !(hierarchyFacts & 16384 /* StaticInitializer */)) {
-        hierarchyFacts |= 65536 /* CapturedLexicalThis */;
+        hierarchyFacts |= 131072 /* CapturedLexicalThis */;
       }
       const savedConvertedLoopState = convertedLoopState;
       convertedLoopState = void 0;
@@ -199244,7 +184542,7 @@ ${lanes.join("\n")}
       const parameters = visitParameterList(node.parameters, visitor, context);
       const body = transformFunctionBody2(node);
       const name = hierarchyFacts & 32768 /* NewTarget */ ? factory2.getLocalName(node) : node.name;
-      exitSubtree(ancestorFacts, 98304 /* FunctionSubtreeExcludes */, 0 /* None */);
+      exitSubtree(ancestorFacts, 229376 /* FunctionSubtreeExcludes */, 0 /* None */);
       convertedLoopState = savedConvertedLoopState;
       return factory2.updateFunctionExpression(
         node,
@@ -199267,7 +184565,7 @@ ${lanes.join("\n")}
       const parameters = visitParameterList(node.parameters, visitor, context);
       const body = transformFunctionBody2(node);
       const name = hierarchyFacts & 32768 /* NewTarget */ ? factory2.getLocalName(node) : node.name;
-      exitSubtree(ancestorFacts, 98304 /* FunctionSubtreeExcludes */, 0 /* None */);
+      exitSubtree(ancestorFacts, 229376 /* FunctionSubtreeExcludes */, 0 /* None */);
       convertedLoopState = savedConvertedLoopState;
       return factory2.updateFunctionDeclaration(
         node,
@@ -199288,10 +184586,10 @@ ${lanes.join("\n")}
       const ancestorFacts = container && isClassLike(container) && !isStatic(node) ? enterSubtree(32670 /* FunctionExcludes */, 65 /* FunctionIncludes */ | 8 /* NonStaticClassElement */) : enterSubtree(32670 /* FunctionExcludes */, 65 /* FunctionIncludes */);
       const parameters = visitParameterList(node.parameters, visitor, context);
       const body = transformFunctionBody2(node);
-      if (hierarchyFacts & 32768 /* NewTarget */ && !name && (node.kind === 261 /* FunctionDeclaration */ || node.kind === 217 /* FunctionExpression */)) {
+      if (hierarchyFacts & 32768 /* NewTarget */ && !name && (node.kind === 262 /* FunctionDeclaration */ || node.kind === 218 /* FunctionExpression */)) {
         name = factory2.getGeneratedNameForNode(node);
       }
-      exitSubtree(ancestorFacts, 98304 /* FunctionSubtreeExcludes */, 0 /* None */);
+      exitSubtree(ancestorFacts, 229376 /* FunctionSubtreeExcludes */, 0 /* None */);
       convertedLoopState = savedConvertedLoopState;
       return setOriginalNode(
         setTextRange(
@@ -199349,7 +184647,7 @@ ${lanes.join("\n")}
           multiLine = true;
         }
       } else {
-        Debug.assert(node.kind === 218 /* ArrowFunction */);
+        Debug.assert(node.kind === 219 /* ArrowFunction */);
         statementsLocation = moveRangeEnd(body, -1);
         const equalsGreaterThanToken = node.equalsGreaterThanToken;
         if (!nodeIsSynthesized(equalsGreaterThanToken) && !nodeIsSynthesized(body)) {
@@ -199368,12 +184666,7 @@ ${lanes.join("\n")}
         closeBraceLocation = body;
       }
       factory2.mergeLexicalEnvironment(prologue, endLexicalEnvironment());
-      insertCaptureNewTargetIfNeeded(
-        prologue,
-        node,
-        /*copyOnWrite*/
-        false
-      );
+      insertCaptureNewTargetIfNeeded(prologue, node);
       insertCaptureThisForNodeIfNeeded(prologue, node);
       if (some(prologue)) {
         multiLine = true;
@@ -199449,9 +184742,9 @@ ${lanes.join("\n")}
       return node.declarationList.declarations.length === 1 && !!node.declarationList.declarations[0].initializer && !!(getInternalEmitFlags(node.declarationList.declarations[0].initializer) & 1 /* TypeScriptClassWrapper */);
     }
     function visitVariableStatement(node) {
-      const ancestorFacts = enterSubtree(0 /* None */, hasSyntacticModifier(node, 1 /* Export */) ? 32 /* ExportedVariableStatement */ : 0 /* None */);
+      const ancestorFacts = enterSubtree(0 /* None */, hasSyntacticModifier(node, 32 /* Export */) ? 32 /* ExportedVariableStatement */ : 0 /* None */);
       let updated;
-      if (convertedLoopState && (node.declarationList.flags & 3 /* BlockScoped */) === 0 && !isVariableStatementOfTypeScriptClassWrapper(node)) {
+      if (convertedLoopState && (node.declarationList.flags & 7 /* BlockScoped */) === 0 && !isVariableStatementOfTypeScriptClassWrapper(node)) {
         let assignments;
         for (const decl of node.declarationList.declarations) {
           hoistVariableDeclarationDeclaredInConvertedLoop(convertedLoopState, decl);
@@ -199483,11 +184776,15 @@ ${lanes.join("\n")}
       return updated;
     }
     function visitVariableDeclarationList(node) {
-      if (node.flags & 3 /* BlockScoped */ || node.transformFlags & 524288 /* ContainsBindingPattern */) {
-        if (node.flags & 3 /* BlockScoped */) {
+      if (node.flags & 7 /* BlockScoped */ || node.transformFlags & 524288 /* ContainsBindingPattern */) {
+        if (node.flags & 7 /* BlockScoped */) {
           enableSubstitutionsForBlockScopedBindings();
         }
-        const declarations = visitNodes2(node.declarations, node.flags & 1 /* Let */ ? visitVariableDeclarationInLetDeclarationList : visitVariableDeclaration, isVariableDeclaration);
+        const declarations = visitNodes2(
+          node.declarations,
+          node.flags & 1 /* Let */ ? visitVariableDeclarationInLetDeclarationList : visitVariableDeclaration,
+          isVariableDeclaration
+        );
         const declarationList = factory2.createVariableDeclarationList(declarations);
         setOriginalNode(declarationList, node);
         setTextRange(declarationList, node);
@@ -199575,14 +184872,14 @@ ${lanes.join("\n")}
     }
     function visitIterationStatement(node, outermostLabeledStatement) {
       switch (node.kind) {
-        case 245 /* DoStatement */:
-        case 246 /* WhileStatement */:
+        case 246 /* DoStatement */:
+        case 247 /* WhileStatement */:
           return visitDoOrWhileStatement(node, outermostLabeledStatement);
-        case 247 /* ForStatement */:
+        case 248 /* ForStatement */:
           return visitForStatement(node, outermostLabeledStatement);
-        case 248 /* ForInStatement */:
+        case 249 /* ForInStatement */:
           return visitForInStatement(node, outermostLabeledStatement);
-        case 249 /* ForOfStatement */:
+        case 250 /* ForOfStatement */:
           return visitForOfStatement(node, outermostLabeledStatement);
       }
     }
@@ -199638,7 +184935,7 @@ ${lanes.join("\n")}
       const statements = [];
       const initializer = node.initializer;
       if (isVariableDeclarationList(initializer)) {
-        if (node.initializer.flags & 3 /* BlockScoped */) {
+        if (node.initializer.flags & 7 /* BlockScoped */) {
           enableSubstitutionsForBlockScopedBindings();
         }
         const firstOriginalDeclaration = firstOrUndefined(initializer.declarations);
@@ -199932,7 +185229,7 @@ ${lanes.join("\n")}
       let numInitialProperties = -1, hasComputed = false;
       for (let i = 0; i < properties.length; i++) {
         const property = properties[i];
-        if (property.transformFlags & 1048576 /* ContainsYield */ && hierarchyFacts & 4 /* AsyncFunctionBody */ || (hasComputed = Debug.checkDefined(property.name).kind === 166 /* ComputedPropertyName */)) {
+        if (property.transformFlags & 1048576 /* ContainsYield */ && hierarchyFacts & 4 /* AsyncFunctionBody */ || (hasComputed = Debug.checkDefined(property.name).kind === 167 /* ComputedPropertyName */)) {
           numInitialProperties = i;
           break;
         }
@@ -200054,15 +185351,15 @@ ${lanes.join("\n")}
     }
     function convertIterationStatementCore(node, initializerFunction, convertedLoopBody) {
       switch (node.kind) {
-        case 247 /* ForStatement */:
+        case 248 /* ForStatement */:
           return convertForStatement(node, initializerFunction, convertedLoopBody);
-        case 248 /* ForInStatement */:
+        case 249 /* ForInStatement */:
           return convertForInStatement(node, convertedLoopBody);
-        case 249 /* ForOfStatement */:
+        case 250 /* ForOfStatement */:
           return convertForOfStatement(node, convertedLoopBody);
-        case 245 /* DoStatement */:
+        case 246 /* DoStatement */:
           return convertDoStatement(node, convertedLoopBody);
-        case 246 /* WhileStatement */:
+        case 247 /* WhileStatement */:
           return convertWhileStatement(node, convertedLoopBody);
         default:
           return Debug.failBadSyntaxKind(node, "IterationStatement expected");
@@ -200114,18 +185411,18 @@ ${lanes.join("\n")}
     function createConvertedLoopState(node) {
       let loopInitializer;
       switch (node.kind) {
-        case 247 /* ForStatement */:
-        case 248 /* ForInStatement */:
-        case 249 /* ForOfStatement */:
+        case 248 /* ForStatement */:
+        case 249 /* ForInStatement */:
+        case 250 /* ForOfStatement */:
           const initializer = node.initializer;
-          if (initializer && initializer.kind === 260 /* VariableDeclarationList */) {
+          if (initializer && initializer.kind === 261 /* VariableDeclarationList */) {
             loopInitializer = initializer;
           }
           break;
       }
       const loopParameters = [];
       const loopOutParameters = [];
-      if (loopInitializer && getCombinedNodeFlags(loopInitializer) & 3 /* BlockScoped */) {
+      if (loopInitializer && getCombinedNodeFlags(loopInitializer) & 7 /* BlockScoped */) {
         const hasCapturedBindingsInForHead = shouldConvertInitializerOfForStatement(node) || shouldConvertConditionOfForStatement(node) || shouldConvertIncrementorOfForStatement(node);
         for (const decl of loopInitializer.declarations) {
           processLoopVariableDeclaration(node, decl, loopParameters, loopOutParameters, hasCapturedBindingsInForHead);
@@ -200533,10 +185830,10 @@ ${lanes.join("\n")}
           name
         ));
         const checkFlags = resolver.getNodeCheckFlags(decl);
-        if (checkFlags & 262144 /* NeedsLoopOutParameter */ || hasCapturedBindingsInForHead) {
+        if (checkFlags & 65536 /* NeedsLoopOutParameter */ || hasCapturedBindingsInForHead) {
           const outParamName = factory2.createUniqueName("out_" + idText(name));
           let flags = 0 /* None */;
-          if (checkFlags & 262144 /* NeedsLoopOutParameter */) {
+          if (checkFlags & 65536 /* NeedsLoopOutParameter */) {
             flags |= 1 /* Body */;
           }
           if (isForStatement(container)) {
@@ -200557,20 +185854,20 @@ ${lanes.join("\n")}
       for (let i = start; i < numProperties; i++) {
         const property = properties[i];
         switch (property.kind) {
-          case 176 /* GetAccessor */:
-          case 177 /* SetAccessor */:
+          case 177 /* GetAccessor */:
+          case 178 /* SetAccessor */:
             const accessors = getAllAccessorDeclarations(node.properties, property);
             if (property === accessors.firstAccessor) {
               expressions.push(transformAccessorsToExpression(receiver, accessors, node, !!node.multiLine));
             }
             break;
-          case 173 /* MethodDeclaration */:
+          case 174 /* MethodDeclaration */:
             expressions.push(transformObjectLiteralMethodDeclarationToExpression(property, receiver, node, node.multiLine));
             break;
-          case 302 /* PropertyAssignment */:
+          case 303 /* PropertyAssignment */:
             expressions.push(transformPropertyAssignmentToExpression(property, receiver, node.multiLine));
             break;
-          case 303 /* ShorthandPropertyAssignment */:
+          case 304 /* ShorthandPropertyAssignment */:
             expressions.push(transformShorthandPropertyAssignmentToExpression(property, receiver, node.multiLine));
             break;
           default:
@@ -200696,12 +185993,12 @@ ${lanes.join("\n")}
       let updated;
       const parameters = visitParameterList(node.parameters, visitor, context);
       const body = transformFunctionBody2(node);
-      if (node.kind === 176 /* GetAccessor */) {
+      if (node.kind === 177 /* GetAccessor */) {
         updated = factory2.updateGetAccessorDeclaration(node, node.modifiers, node.name, parameters, node.type, body);
       } else {
         updated = factory2.updateSetAccessorDeclaration(node, node.modifiers, node.name, parameters, body);
       }
-      exitSubtree(ancestorFacts, 98304 /* FunctionSubtreeExcludes */, 0 /* None */);
+      exitSubtree(ancestorFacts, 229376 /* FunctionSubtreeExcludes */, 0 /* None */);
       convertedLoopState = savedConvertedLoopState;
       return updated;
     }
@@ -200851,13 +186148,6 @@ ${lanes.join("\n")}
         )
       );
     }
-    function visitSuperCallInBody(node) {
-      return visitCallExpressionWithPotentialCapturedThisAssignment(
-        node,
-        /*assignToCapturedThis*/
-        false
-      );
-    }
     function visitCallExpressionWithPotentialCapturedThisAssignment(node, assignToCapturedThis) {
       if (node.transformFlags & 32768 /* ContainsRestOrSpread */ || node.expression.kind === 108 /* SuperKeyword */ || isSuperProperty(skipOuterExpressions(node.expression))) {
         const { target, thisArg } = factory2.createCallBinding(node.expression, hoistVariableDeclaration);
@@ -200894,10 +186184,13 @@ ${lanes.join("\n")}
             resultingCall,
             createActualThis()
           );
-          resultingCall = assignToCapturedThis ? factory2.createAssignment(factory2.createUniqueName("_this", 16 /* Optimistic */ | 32 /* FileLevel */), initializer) : initializer;
+          resultingCall = assignToCapturedThis ? factory2.createAssignment(createCapturedThis(), initializer) : initializer;
         }
         return setOriginalNode(resultingCall, node);
       }
+      if (isSuperCall(node)) {
+        hierarchyFacts |= 131072 /* CapturedLexicalThis */;
+      }
       return visitEachChild(node, visitor, context);
     }
     function visitNewExpression(node) {
@@ -200930,11 +186223,7 @@ ${lanes.join("\n")}
         // As we visit each element, we return one of two functions to use as the "key":
         // - `visitSpanOfSpreads` for one or more contiguous `...` spread expressions, i.e. `...a, ...b` in `[1, 2, ...a, ...b]`
         // - `visitSpanOfNonSpreads` for one or more contiguous non-spread elements, i.e. `1, 2`, in `[1, 2, ...a, ...b]`
-        spanMap(
-          elements,
-          partitionSpread,
-          (partition, visitPartition, _start, end) => visitPartition(partition, multiLine, hasTrailingComma && end === numElements)
-        )
+        spanMap(elements, partitionSpread, (partition, visitPartition, _start, end) => visitPartition(partition, multiLine, hasTrailingComma && end === numElements))
       );
       if (segments.length === 1) {
         const firstSegment = segments[0];
@@ -201028,8 +186317,15 @@ ${lanes.join("\n")}
       }
       return setTextRange(expression, node);
     }
-    function visitSuperKeyword(isExpressionOfCall) {
-      return hierarchyFacts & 8 /* NonStaticClassElement */ && !isExpressionOfCall ? factory2.createPropertyAccessExpression(factory2.createUniqueName("_super", 16 /* Optimistic */ | 32 /* FileLevel */), "prototype") : factory2.createUniqueName("_super", 16 /* Optimistic */ | 32 /* FileLevel */);
+    function createSyntheticSuper() {
+      return factory2.createUniqueName("_super", 16 /* Optimistic */ | 32 /* FileLevel */);
+    }
+    function visitSuperKeyword(node, isExpressionOfCall) {
+      const expression = hierarchyFacts & 8 /* NonStaticClassElement */ && !isExpressionOfCall ? factory2.createPropertyAccessExpression(setOriginalNode(createSyntheticSuper(), node), "prototype") : createSyntheticSuper();
+      setOriginalNode(expression, node);
+      setCommentRange(expression, node);
+      setSourceMapRange(expression, node);
+      return expression;
     }
     function visitMetaProperty(node) {
       if (node.keywordToken === 105 /* NewKeyword */ && node.name.escapedText === "target") {
@@ -201060,13 +186356,13 @@ ${lanes.join("\n")}
       if ((enabledSubstitutions & 1 /* CapturedThis */) === 0) {
         enabledSubstitutions |= 1 /* CapturedThis */;
         context.enableSubstitution(110 /* ThisKeyword */);
-        context.enableEmitNotification(175 /* Constructor */);
-        context.enableEmitNotification(173 /* MethodDeclaration */);
-        context.enableEmitNotification(176 /* GetAccessor */);
-        context.enableEmitNotification(177 /* SetAccessor */);
-        context.enableEmitNotification(218 /* ArrowFunction */);
-        context.enableEmitNotification(217 /* FunctionExpression */);
-        context.enableEmitNotification(261 /* FunctionDeclaration */);
+        context.enableEmitNotification(176 /* Constructor */);
+        context.enableEmitNotification(174 /* MethodDeclaration */);
+        context.enableEmitNotification(177 /* GetAccessor */);
+        context.enableEmitNotification(178 /* SetAccessor */);
+        context.enableEmitNotification(219 /* ArrowFunction */);
+        context.enableEmitNotification(218 /* FunctionExpression */);
+        context.enableEmitNotification(262 /* FunctionDeclaration */);
       }
     }
     function onSubstituteNode(hint, node) {
@@ -201090,10 +186386,10 @@ ${lanes.join("\n")}
     }
     function isNameOfDeclarationWithCollidingName(node) {
       switch (node.parent.kind) {
-        case 207 /* BindingElement */:
-        case 262 /* ClassDeclaration */:
-        case 265 /* EnumDeclaration */:
-        case 259 /* VariableDeclaration */:
+        case 208 /* BindingElement */:
+        case 263 /* ClassDeclaration */:
+        case 266 /* EnumDeclaration */:
+        case 260 /* VariableDeclaration */:
           return node.parent.name === node && resolver.isDeclarationWithCollidingName(node.parent);
       }
       return false;
@@ -201135,7 +186431,7 @@ ${lanes.join("\n")}
     }
     function substituteThisKeyword(node) {
       if (enabledSubstitutions & 1 /* CapturedThis */ && hierarchyFacts & 16 /* CapturesThis */) {
-        return setTextRange(factory2.createUniqueName("_this", 16 /* Optimistic */ | 32 /* FileLevel */), node);
+        return setTextRange(createCapturedThis(), node);
       }
       return node;
     }
@@ -201150,11 +186446,11 @@ ${lanes.join("\n")}
         return false;
       }
       const statement = firstOrUndefined(constructor.body.statements);
-      if (!statement || !nodeIsSynthesized(statement) || statement.kind !== 243 /* ExpressionStatement */) {
+      if (!statement || !nodeIsSynthesized(statement) || statement.kind !== 244 /* ExpressionStatement */) {
         return false;
       }
       const statementExpression = statement.expression;
-      if (!nodeIsSynthesized(statementExpression) || statementExpression.kind !== 212 /* CallExpression */) {
+      if (!nodeIsSynthesized(statementExpression) || statementExpression.kind !== 213 /* CallExpression */) {
         return false;
       }
       const callTarget = statementExpression.expression;
@@ -201162,7 +186458,7 @@ ${lanes.join("\n")}
         return false;
       }
       const callArgument = singleOrUndefined(statementExpression.arguments);
-      if (!callArgument || !nodeIsSynthesized(callArgument) || callArgument.kind !== 229 /* SpreadElement */) {
+      if (!callArgument || !nodeIsSynthesized(callArgument) || callArgument.kind !== 230 /* SpreadElement */) {
         return false;
       }
       const expression = callArgument.expression;
@@ -201185,24 +186481,24 @@ ${lanes.join("\n")}
     if (compilerOptions.jsx === 1 /* Preserve */ || compilerOptions.jsx === 3 /* ReactNative */) {
       previousOnEmitNode = context.onEmitNode;
       context.onEmitNode = onEmitNode;
-      context.enableEmitNotification(285 /* JsxOpeningElement */);
-      context.enableEmitNotification(286 /* JsxClosingElement */);
-      context.enableEmitNotification(284 /* JsxSelfClosingElement */);
+      context.enableEmitNotification(286 /* JsxOpeningElement */);
+      context.enableEmitNotification(287 /* JsxClosingElement */);
+      context.enableEmitNotification(285 /* JsxSelfClosingElement */);
       noSubstitution = [];
     }
     const previousOnSubstituteNode = context.onSubstituteNode;
     context.onSubstituteNode = onSubstituteNode;
-    context.enableSubstitution(210 /* PropertyAccessExpression */);
-    context.enableSubstitution(302 /* PropertyAssignment */);
+    context.enableSubstitution(211 /* PropertyAccessExpression */);
+    context.enableSubstitution(303 /* PropertyAssignment */);
     return chainBundle(context, transformSourceFile);
     function transformSourceFile(node) {
       return node;
     }
     function onEmitNode(hint, node, emitCallback) {
       switch (node.kind) {
-        case 285 /* JsxOpeningElement */:
-        case 286 /* JsxClosingElement */:
-        case 284 /* JsxSelfClosingElement */:
+        case 286 /* JsxOpeningElement */:
+        case 287 /* JsxClosingElement */:
+        case 285 /* JsxSelfClosingElement */:
           const tagName = node.tagName;
           noSubstitution[getOriginalNodeId(tagName)] = true;
           break;
@@ -201334,13 +186630,13 @@ ${lanes.join("\n")}
     }
     function visitJavaScriptInStatementContainingYield(node) {
       switch (node.kind) {
-        case 245 /* DoStatement */:
+        case 246 /* DoStatement */:
           return visitDoStatement(node);
-        case 246 /* WhileStatement */:
+        case 247 /* WhileStatement */:
           return visitWhileStatement(node);
-        case 254 /* SwitchStatement */:
+        case 255 /* SwitchStatement */:
           return visitSwitchStatement(node);
-        case 255 /* LabeledStatement */:
+        case 256 /* LabeledStatement */:
           return visitLabeledStatement(node);
         default:
           return visitJavaScriptInGeneratorFunctionBody(node);
@@ -201348,24 +186644,24 @@ ${lanes.join("\n")}
     }
     function visitJavaScriptInGeneratorFunctionBody(node) {
       switch (node.kind) {
-        case 261 /* FunctionDeclaration */:
+        case 262 /* FunctionDeclaration */:
           return visitFunctionDeclaration(node);
-        case 217 /* FunctionExpression */:
+        case 218 /* FunctionExpression */:
           return visitFunctionExpression(node);
-        case 176 /* GetAccessor */:
-        case 177 /* SetAccessor */:
+        case 177 /* GetAccessor */:
+        case 178 /* SetAccessor */:
           return visitAccessorDeclaration(node);
-        case 242 /* VariableStatement */:
+        case 243 /* VariableStatement */:
           return visitVariableStatement(node);
-        case 247 /* ForStatement */:
+        case 248 /* ForStatement */:
           return visitForStatement(node);
-        case 248 /* ForInStatement */:
+        case 249 /* ForInStatement */:
           return visitForInStatement(node);
-        case 251 /* BreakStatement */:
+        case 252 /* BreakStatement */:
           return visitBreakStatement(node);
-        case 250 /* ContinueStatement */:
+        case 251 /* ContinueStatement */:
           return visitContinueStatement(node);
-        case 252 /* ReturnStatement */:
+        case 253 /* ReturnStatement */:
           return visitReturnStatement(node);
         default:
           if (node.transformFlags & 1048576 /* ContainsYield */) {
@@ -201379,23 +186675,23 @@ ${lanes.join("\n")}
     }
     function visitJavaScriptContainingYield(node) {
       switch (node.kind) {
-        case 225 /* BinaryExpression */:
+        case 226 /* BinaryExpression */:
           return visitBinaryExpression(node);
-        case 360 /* CommaListExpression */:
+        case 361 /* CommaListExpression */:
           return visitCommaListExpression(node);
-        case 226 /* ConditionalExpression */:
+        case 227 /* ConditionalExpression */:
           return visitConditionalExpression(node);
-        case 228 /* YieldExpression */:
+        case 229 /* YieldExpression */:
           return visitYieldExpression(node);
-        case 208 /* ArrayLiteralExpression */:
+        case 209 /* ArrayLiteralExpression */:
           return visitArrayLiteralExpression(node);
-        case 209 /* ObjectLiteralExpression */:
+        case 210 /* ObjectLiteralExpression */:
           return visitObjectLiteralExpression(node);
-        case 211 /* ElementAccessExpression */:
+        case 212 /* ElementAccessExpression */:
           return visitElementAccessExpression(node);
-        case 212 /* CallExpression */:
+        case 213 /* CallExpression */:
           return visitCallExpression(node);
-        case 213 /* NewExpression */:
+        case 214 /* NewExpression */:
           return visitNewExpression(node);
         default:
           return visitEachChild(node, visitor, context);
@@ -201403,9 +186699,9 @@ ${lanes.join("\n")}
     }
     function visitGenerator(node) {
       switch (node.kind) {
-        case 261 /* FunctionDeclaration */:
+        case 262 /* FunctionDeclaration */:
           return visitFunctionDeclaration(node);
-        case 217 /* FunctionExpression */:
+        case 218 /* FunctionExpression */:
           return visitFunctionExpression(node);
         default:
           return Debug.failBadSyntaxKind(node);
@@ -201590,19 +186886,15 @@ ${lanes.join("\n")}
       if (containsYield(right)) {
         let target;
         switch (left.kind) {
-          case 210 /* PropertyAccessExpression */:
+          case 211 /* PropertyAccessExpression */:
             target = factory2.updatePropertyAccessExpression(
               left,
               cacheExpression(Debug.checkDefined(visitNode(left.expression, visitor, isLeftHandSideExpression))),
               left.name
             );
             break;
-          case 211 /* ElementAccessExpression */:
-            target = factory2.updateElementAccessExpression(
-              left,
-              cacheExpression(Debug.checkDefined(visitNode(left.expression, visitor, isLeftHandSideExpression))),
-              cacheExpression(Debug.checkDefined(visitNode(left.argumentExpression, visitor, isExpression)))
-            );
+          case 212 /* ElementAccessExpression */:
+            target = factory2.updateElementAccessExpression(left, cacheExpression(Debug.checkDefined(visitNode(left.expression, visitor, isLeftHandSideExpression))), cacheExpression(Debug.checkDefined(visitNode(left.argumentExpression, visitor, isExpression))));
             break;
           default:
             target = Debug.checkDefined(visitNode(left, visitor, isExpression));
@@ -201637,12 +186929,7 @@ ${lanes.join("\n")}
         } else if (node.operatorToken.kind === 28 /* CommaToken */) {
           return visitCommaExpression(node);
         }
-        return factory2.updateBinaryExpression(
-          node,
-          cacheExpression(Debug.checkDefined(visitNode(node.left, visitor, isExpression))),
-          node.operatorToken,
-          Debug.checkDefined(visitNode(node.right, visitor, isExpression))
-        );
+        return factory2.updateBinaryExpression(node, cacheExpression(Debug.checkDefined(visitNode(node.left, visitor, isExpression))), node.operatorToken, Debug.checkDefined(visitNode(node.right, visitor, isExpression)));
       }
       return visitEachChild(node, visitor, context);
     }
@@ -201850,11 +187137,7 @@ ${lanes.join("\n")}
     }
     function visitElementAccessExpression(node) {
       if (containsYield(node.argumentExpression)) {
-        return factory2.updateElementAccessExpression(
-          node,
-          cacheExpression(Debug.checkDefined(visitNode(node.expression, visitor, isLeftHandSideExpression))),
-          Debug.checkDefined(visitNode(node.argumentExpression, visitor, isExpression))
-        );
+        return factory2.updateElementAccessExpression(node, cacheExpression(Debug.checkDefined(visitNode(node.expression, visitor, isLeftHandSideExpression))), Debug.checkDefined(visitNode(node.argumentExpression, visitor, isExpression)));
       }
       return visitEachChild(node, visitor, context);
     }
@@ -201930,35 +187213,35 @@ ${lanes.join("\n")}
     }
     function transformAndEmitStatementWorker(node) {
       switch (node.kind) {
-        case 240 /* Block */:
+        case 241 /* Block */:
           return transformAndEmitBlock(node);
-        case 243 /* ExpressionStatement */:
+        case 244 /* ExpressionStatement */:
           return transformAndEmitExpressionStatement(node);
-        case 244 /* IfStatement */:
+        case 245 /* IfStatement */:
           return transformAndEmitIfStatement(node);
-        case 245 /* DoStatement */:
+        case 246 /* DoStatement */:
           return transformAndEmitDoStatement(node);
-        case 246 /* WhileStatement */:
+        case 247 /* WhileStatement */:
           return transformAndEmitWhileStatement(node);
-        case 247 /* ForStatement */:
+        case 248 /* ForStatement */:
           return transformAndEmitForStatement(node);
-        case 248 /* ForInStatement */:
+        case 249 /* ForInStatement */:
           return transformAndEmitForInStatement(node);
-        case 250 /* ContinueStatement */:
+        case 251 /* ContinueStatement */:
           return transformAndEmitContinueStatement(node);
-        case 251 /* BreakStatement */:
+        case 252 /* BreakStatement */:
           return transformAndEmitBreakStatement(node);
-        case 252 /* ReturnStatement */:
+        case 253 /* ReturnStatement */:
           return transformAndEmitReturnStatement(node);
-        case 253 /* WithStatement */:
+        case 254 /* WithStatement */:
           return transformAndEmitWithStatement(node);
-        case 254 /* SwitchStatement */:
+        case 255 /* SwitchStatement */:
           return transformAndEmitSwitchStatement(node);
-        case 255 /* LabeledStatement */:
+        case 256 /* LabeledStatement */:
           return transformAndEmitLabeledStatement(node);
-        case 256 /* ThrowStatement */:
+        case 257 /* ThrowStatement */:
           return transformAndEmitThrowStatement(node);
-        case 257 /* TryStatement */:
+        case 258 /* TryStatement */:
           return transformAndEmitTryStatement(node);
         default:
           return emitStatement(visitNode(node, visitor, isStatement));
@@ -202212,12 +187495,7 @@ ${lanes.join("\n")}
         for (const variable of initializer.declarations) {
           hoistVariableDeclaration(variable.name);
         }
-        node = factory2.updateForInStatement(
-          node,
-          initializer.declarations[0].name,
-          Debug.checkDefined(visitNode(node.expression, visitor, isExpression)),
-          Debug.checkDefined(visitNode(node.statement, visitor, isStatement, factory2.liftToBlock))
-        );
+        node = factory2.updateForInStatement(node, initializer.declarations[0].name, Debug.checkDefined(visitNode(node.expression, visitor, isExpression)), Debug.checkDefined(visitNode(node.statement, visitor, isStatement, factory2.liftToBlock)));
       } else {
         node = visitEachChild(node, visitor, context);
       }
@@ -202310,7 +187588,7 @@ ${lanes.join("\n")}
         for (let i = 0; i < numClauses; i++) {
           const clause = caseBlock.clauses[i];
           clauseLabels.push(defineLabel());
-          if (clause.kind === 296 /* DefaultClause */ && defaultClauseIndex === -1) {
+          if (clause.kind === 297 /* DefaultClause */ && defaultClauseIndex === -1) {
             defaultClauseIndex = i;
           }
         }
@@ -202320,7 +187598,7 @@ ${lanes.join("\n")}
           let defaultClausesSkipped = 0;
           for (let i = clausesWritten; i < numClauses; i++) {
             const clause = caseBlock.clauses[i];
-            if (clause.kind === 295 /* CaseClause */) {
+            if (clause.kind === 296 /* CaseClause */) {
               if (containsYield(clause.expression) && pendingClauses.length > 0) {
                 break;
               }
@@ -203293,12 +188571,12 @@ ${lanes.join("\n")}
     const previousOnEmitNode = context.onEmitNode;
     context.onSubstituteNode = onSubstituteNode;
     context.onEmitNode = onEmitNode;
-    context.enableSubstitution(212 /* CallExpression */);
-    context.enableSubstitution(214 /* TaggedTemplateExpression */);
+    context.enableSubstitution(213 /* CallExpression */);
+    context.enableSubstitution(215 /* TaggedTemplateExpression */);
     context.enableSubstitution(80 /* Identifier */);
-    context.enableSubstitution(225 /* BinaryExpression */);
-    context.enableSubstitution(303 /* ShorthandPropertyAssignment */);
-    context.enableEmitNotification(311 /* SourceFile */);
+    context.enableSubstitution(226 /* BinaryExpression */);
+    context.enableSubstitution(304 /* ShorthandPropertyAssignment */);
+    context.enableEmitNotification(312 /* SourceFile */);
     const moduleInfoMap = [];
     let currentSourceFile;
     let currentModuleInfo;
@@ -203310,7 +188588,7 @@ ${lanes.join("\n")}
         return node;
       }
       currentSourceFile = node;
-      currentModuleInfo = collectExternalModuleInfo(context, node, resolver, compilerOptions);
+      currentModuleInfo = collectExternalModuleInfo(context, node);
       moduleInfoMap[getOriginalNodeId(node)] = currentModuleInfo;
       const transformModule2 = getTransformModuleDelegate(moduleKind);
       const updated = transformModule2(node);
@@ -203384,12 +188662,14 @@ ${lanes.join("\n")}
                   // Add the dependency array argument:
                   //
                   //     ["require", "exports", module1", "module2", ...]
-                  factory2.createArrayLiteralExpression(jsonSourceFile ? emptyArray : [
-                    factory2.createStringLiteral("require"),
-                    factory2.createStringLiteral("exports"),
-                    ...aliasedModuleNames,
-                    ...unaliasedModuleNames
-                  ]),
+                  factory2.createArrayLiteralExpression(
+                    jsonSourceFile ? emptyArray : [
+                      factory2.createStringLiteral("require"),
+                      factory2.createStringLiteral("exports"),
+                      ...aliasedModuleNames,
+                      ...unaliasedModuleNames
+                    ]
+                  ),
                   // Add the module body function argument:
                   //
                   //     function (require, exports, module1, module2) ...
@@ -203710,63 +188990,59 @@ ${lanes.join("\n")}
     }
     function topLevelVisitor(node) {
       switch (node.kind) {
-        case 271 /* ImportDeclaration */:
-          return visitImportDeclaration(node);
-        case 270 /* ImportEqualsDeclaration */:
-          return visitImportEqualsDeclaration(node);
-        case 277 /* ExportDeclaration */:
-          return visitExportDeclaration(node);
-        case 276 /* ExportAssignment */:
-          return visitExportAssignment(node);
-        case 261 /* FunctionDeclaration */:
-          return visitFunctionDeclaration(node);
-        case 262 /* ClassDeclaration */:
-          return visitClassDeclaration(node);
+        case 272 /* ImportDeclaration */:
+          return visitTopLevelImportDeclaration(node);
+        case 271 /* ImportEqualsDeclaration */:
+          return visitTopLevelImportEqualsDeclaration(node);
+        case 278 /* ExportDeclaration */:
+          return visitTopLevelExportDeclaration(node);
+        case 277 /* ExportAssignment */:
+          return visitTopLevelExportAssignment(node);
         default:
           return topLevelNestedVisitor(node);
       }
     }
     function topLevelNestedVisitor(node) {
       switch (node.kind) {
-        case 242 /* VariableStatement */:
+        case 243 /* VariableStatement */:
           return visitVariableStatement(node);
-        case 261 /* FunctionDeclaration */:
+        case 262 /* FunctionDeclaration */:
           return visitFunctionDeclaration(node);
-        case 262 /* ClassDeclaration */:
+        case 263 /* ClassDeclaration */:
           return visitClassDeclaration(node);
-        case 247 /* ForStatement */:
+        case 248 /* ForStatement */:
           return visitForStatement(
             node,
             /*isTopLevel*/
             true
           );
-        case 248 /* ForInStatement */:
+        case 249 /* ForInStatement */:
           return visitForInStatement(node);
-        case 249 /* ForOfStatement */:
+        case 250 /* ForOfStatement */:
           return visitForOfStatement(node);
-        case 245 /* DoStatement */:
+        case 246 /* DoStatement */:
           return visitDoStatement(node);
-        case 246 /* WhileStatement */:
+        case 247 /* WhileStatement */:
           return visitWhileStatement(node);
-        case 255 /* LabeledStatement */:
+        case 256 /* LabeledStatement */:
           return visitLabeledStatement(node);
-        case 253 /* WithStatement */:
+        case 254 /* WithStatement */:
           return visitWithStatement(node);
-        case 244 /* IfStatement */:
+        case 245 /* IfStatement */:
           return visitIfStatement(node);
-        case 254 /* SwitchStatement */:
+        case 255 /* SwitchStatement */:
           return visitSwitchStatement(node);
-        case 268 /* CaseBlock */:
+        case 269 /* CaseBlock */:
           return visitCaseBlock(node);
-        case 295 /* CaseClause */:
+        case 296 /* CaseClause */:
           return visitCaseClause(node);
-        case 296 /* DefaultClause */:
+        case 297 /* DefaultClause */:
           return visitDefaultClause(node);
-        case 257 /* TryStatement */:
+        case 258 /* TryStatement */:
           return visitTryStatement(node);
-        case 298 /* CatchClause */:
+        case 299 /* CatchClause */:
           return visitCatchClause(node);
-        case 240 /* Block */:
+        case 241 /* Block */:
           return visitBlock(node);
         default:
           return visitor(node);
@@ -203777,30 +189053,30 @@ ${lanes.join("\n")}
         return node;
       }
       switch (node.kind) {
-        case 247 /* ForStatement */:
+        case 248 /* ForStatement */:
           return visitForStatement(
             node,
             /*isTopLevel*/
             false
           );
-        case 243 /* ExpressionStatement */:
+        case 244 /* ExpressionStatement */:
           return visitExpressionStatement(node);
-        case 216 /* ParenthesizedExpression */:
+        case 217 /* ParenthesizedExpression */:
           return visitParenthesizedExpression(node, valueIsDiscarded);
-        case 359 /* PartiallyEmittedExpression */:
+        case 360 /* PartiallyEmittedExpression */:
           return visitPartiallyEmittedExpression(node, valueIsDiscarded);
-        case 212 /* CallExpression */:
+        case 213 /* CallExpression */:
           if (isImportCall(node) && currentSourceFile.impliedNodeFormat === void 0) {
             return visitImportCallExpression(node);
           }
           break;
-        case 225 /* BinaryExpression */:
+        case 226 /* BinaryExpression */:
           if (isDestructuringAssignment(node)) {
             return visitDestructuringAssignment(node, valueIsDiscarded);
           }
           break;
-        case 223 /* PrefixUnaryExpression */:
-        case 224 /* PostfixUnaryExpression */:
+        case 224 /* PrefixUnaryExpression */:
+        case 225 /* PostfixUnaryExpression */:
           return visitPreOrPostfixUnaryExpression(node, valueIsDiscarded);
       }
       return visitEachChild(node, visitor, context);
@@ -203823,24 +189099,24 @@ ${lanes.join("\n")}
       if (isObjectLiteralExpression(node)) {
         for (const elem of node.properties) {
           switch (elem.kind) {
-            case 302 /* PropertyAssignment */:
+            case 303 /* PropertyAssignment */:
               if (destructuringNeedsFlattening(elem.initializer)) {
                 return true;
               }
               break;
-            case 303 /* ShorthandPropertyAssignment */:
+            case 304 /* ShorthandPropertyAssignment */:
               if (destructuringNeedsFlattening(elem.name)) {
                 return true;
               }
               break;
-            case 304 /* SpreadAssignment */:
+            case 305 /* SpreadAssignment */:
               if (destructuringNeedsFlattening(elem.expression)) {
                 return true;
               }
               break;
-            case 173 /* MethodDeclaration */:
-            case 176 /* GetAccessor */:
-            case 177 /* SetAccessor */:
+            case 174 /* MethodDeclaration */:
+            case 177 /* GetAccessor */:
+            case 178 /* SetAccessor */:
               return false;
             default:
               Debug.assertNever(elem, "Unhandled object member kind");
@@ -203868,7 +189144,7 @@ ${lanes.join("\n")}
       return visitEachChild(node, visitor, context);
     }
     function visitForStatement(node, isTopLevel) {
-      if (isTopLevel && node.initializer && isVariableDeclarationList(node.initializer) && !(node.initializer.flags & 3 /* BlockScoped */)) {
+      if (isTopLevel && node.initializer && isVariableDeclarationList(node.initializer) && !(node.initializer.flags & 7 /* BlockScoped */)) {
         const exportStatements = appendExportsOfVariableDeclarationList(
           /*statements*/
           void 0,
@@ -203909,7 +189185,7 @@ ${lanes.join("\n")}
       );
     }
     function visitForInStatement(node) {
-      if (isVariableDeclarationList(node.initializer) && !(node.initializer.flags & 3 /* BlockScoped */)) {
+      if (isVariableDeclarationList(node.initializer) && !(node.initializer.flags & 7 /* BlockScoped */)) {
         const exportStatements = appendExportsOfVariableDeclarationList(
           /*statements*/
           void 0,
@@ -203937,7 +189213,7 @@ ${lanes.join("\n")}
       );
     }
     function visitForOfStatement(node) {
-      if (isVariableDeclarationList(node.initializer) && !(node.initializer.flags & 3 /* BlockScoped */)) {
+      if (isVariableDeclarationList(node.initializer) && !(node.initializer.flags & 7 /* BlockScoped */)) {
         const exportStatements = appendExportsOfVariableDeclarationList(
           /*statements*/
           void 0,
@@ -204119,22 +189395,25 @@ ${lanes.join("\n")}
         );
       } else {
         const temp = factory2.createTempVariable(hoistVariableDeclaration);
-        return factory2.createComma(factory2.createAssignment(temp, arg), factory2.createConditionalExpression(
-          /*condition*/
-          factory2.createIdentifier("__syncRequire"),
-          /*questionToken*/
-          void 0,
-          /*whenTrue*/
-          createImportCallExpressionCommonJS(
-            temp,
-            /*isInlineable*/
-            true
-          ),
-          /*colonToken*/
-          void 0,
-          /*whenFalse*/
-          createImportCallExpressionAMD(temp, containsLexicalThis)
-        ));
+        return factory2.createComma(
+          factory2.createAssignment(temp, arg),
+          factory2.createConditionalExpression(
+            /*condition*/
+            factory2.createIdentifier("__syncRequire"),
+            /*questionToken*/
+            void 0,
+            /*whenTrue*/
+            createImportCallExpressionCommonJS(
+              temp,
+              /*isInlineable*/
+              true
+            ),
+            /*colonToken*/
+            void 0,
+            /*whenFalse*/
+            createImportCallExpressionAMD(temp, containsLexicalThis)
+          )
+        );
       }
     }
     function createImportCallExpressionAMD(arg, containsLexicalThis) {
@@ -204317,7 +189596,7 @@ ${lanes.join("\n")}
       }
       return innerExpr;
     }
-    function visitImportDeclaration(node) {
+    function visitTopLevelImportDeclaration(node) {
       let statements;
       const namespaceDeclaration = getNamespaceDeclarationNode(node);
       if (moduleKind !== 2 /* AMD */) {
@@ -204426,11 +189705,11 @@ ${lanes.join("\n")}
         args
       );
     }
-    function visitImportEqualsDeclaration(node) {
+    function visitTopLevelImportEqualsDeclaration(node) {
       Debug.assert(isExternalModuleImportEqualsDeclaration(node), "import= for internal module references should be handled in an earlier transformer.");
       let statements;
       if (moduleKind !== 2 /* AMD */) {
-        if (hasSyntacticModifier(node, 1 /* Export */)) {
+        if (hasSyntacticModifier(node, 32 /* Export */)) {
           statements = append(
             statements,
             setOriginalNode(
@@ -204476,7 +189755,7 @@ ${lanes.join("\n")}
           );
         }
       } else {
-        if (hasSyntacticModifier(node, 1 /* Export */)) {
+        if (hasSyntacticModifier(node, 32 /* Export */)) {
           statements = append(
             statements,
             setOriginalNode(
@@ -204494,7 +189773,7 @@ ${lanes.join("\n")}
       statements = appendExportsOfImportEqualsDeclaration(statements, node);
       return singleOrMany(statements);
     }
-    function visitExportDeclaration(node) {
+    function visitTopLevelExportDeclaration(node) {
       if (!node.moduleSpecifier) {
         return void 0;
       }
@@ -204575,7 +189854,10 @@ ${lanes.join("\n")}
               factory2.createExpressionStatement(
                 createExportExpression(
                   factory2.cloneNode(node.exportClause.name),
-                  getHelperExpressionForExport(node, moduleKind !== 2 /* AMD */ ? createRequireCall2(node) : isExportNamespaceAsDefaultDeclaration(node) ? generatedName : factory2.createIdentifier(idText(node.exportClause.name)))
+                  getHelperExpressionForExport(
+                    node,
+                    moduleKind !== 2 /* AMD */ ? createRequireCall2(node) : isExportNamespaceAsDefaultDeclaration(node) ? generatedName : factory2.createIdentifier(idText(node.exportClause.name))
+                  )
                 )
               ),
               node
@@ -204596,7 +189878,7 @@ ${lanes.join("\n")}
         );
       }
     }
-    function visitExportAssignment(node) {
+    function visitTopLevelExportAssignment(node) {
       if (node.isExportEquals) {
         return void 0;
       }
@@ -204611,7 +189893,7 @@ ${lanes.join("\n")}
     }
     function visitFunctionDeclaration(node) {
       let statements;
-      if (hasSyntacticModifier(node, 1 /* Export */)) {
+      if (hasSyntacticModifier(node, 32 /* Export */)) {
         statements = append(
           statements,
           setOriginalNode(
@@ -204648,7 +189930,7 @@ ${lanes.join("\n")}
     }
     function visitClassDeclaration(node) {
       let statements;
-      if (hasSyntacticModifier(node, 1 /* Export */)) {
+      if (hasSyntacticModifier(node, 32 /* Export */)) {
         statements = append(
           statements,
           setOriginalNode(
@@ -204682,7 +189964,7 @@ ${lanes.join("\n")}
       let statements;
       let variables;
       let expressions;
-      if (hasSyntacticModifier(node, 1 /* Export */)) {
+      if (hasSyntacticModifier(node, 32 /* Export */)) {
         let modifiers;
         let removeCommentsOnExpressions = false;
         for (const variable of node.declarationList.declarations) {
@@ -204800,19 +190082,21 @@ ${lanes.join("\n")}
       if (!importClause) {
         return statements;
       }
+      const seen = new IdentifierNameMap();
       if (importClause.name) {
-        statements = appendExportsOfDeclaration(statements, importClause);
+        statements = appendExportsOfDeclaration(statements, seen, importClause);
       }
       const namedBindings = importClause.namedBindings;
       if (namedBindings) {
         switch (namedBindings.kind) {
-          case 273 /* NamespaceImport */:
-            statements = appendExportsOfDeclaration(statements, namedBindings);
+          case 274 /* NamespaceImport */:
+            statements = appendExportsOfDeclaration(statements, seen, namedBindings);
             break;
-          case 274 /* NamedImports */:
+          case 275 /* NamedImports */:
             for (const importBinding of namedBindings.elements) {
               statements = appendExportsOfDeclaration(
                 statements,
+                seen,
                 importBinding,
                 /*liveBinding*/
                 true
@@ -204827,7 +190111,7 @@ ${lanes.join("\n")}
       if (currentModuleInfo.exportEquals) {
         return statements;
       }
-      return appendExportsOfDeclaration(statements, decl);
+      return appendExportsOfDeclaration(statements, new IdentifierNameMap(), decl);
     }
     function appendExportsOfVariableStatement(statements, node) {
       return appendExportsOfVariableDeclarationList(
@@ -204857,7 +190141,7 @@ ${lanes.join("\n")}
           }
         }
       } else if (!isGeneratedIdentifier(decl.name) && (!isVariableDeclaration(decl) || decl.initializer || isForInOrOfInitializer)) {
-        statements = appendExportsOfDeclaration(statements, decl);
+        statements = appendExportsOfDeclaration(statements, new IdentifierNameMap(), decl);
       }
       return statements;
     }
@@ -204865,10 +190149,12 @@ ${lanes.join("\n")}
       if (currentModuleInfo.exportEquals) {
         return statements;
       }
-      if (hasSyntacticModifier(decl, 1 /* Export */)) {
-        const exportName = hasSyntacticModifier(decl, 1024 /* Default */) ? factory2.createIdentifier("default") : factory2.getDeclarationName(decl);
+      const seen = new IdentifierNameMap();
+      if (hasSyntacticModifier(decl, 32 /* Export */)) {
+        const exportName = hasSyntacticModifier(decl, 2048 /* Default */) ? factory2.createIdentifier("default") : factory2.getDeclarationName(decl);
         statements = appendExportStatement(
           statements,
+          seen,
           exportName,
           factory2.getLocalName(decl),
           /*location*/
@@ -204876,17 +190162,18 @@ ${lanes.join("\n")}
         );
       }
       if (decl.name) {
-        statements = appendExportsOfDeclaration(statements, decl);
+        statements = appendExportsOfDeclaration(statements, seen, decl);
       }
       return statements;
     }
-    function appendExportsOfDeclaration(statements, decl, liveBinding) {
+    function appendExportsOfDeclaration(statements, seen, decl, liveBinding) {
       const name = factory2.getDeclarationName(decl);
-      const exportSpecifiers = currentModuleInfo.exportSpecifiers.get(idText(name));
+      const exportSpecifiers = currentModuleInfo.exportSpecifiers.get(name);
       if (exportSpecifiers) {
         for (const exportSpecifier of exportSpecifiers) {
           statements = appendExportStatement(
             statements,
+            seen,
             exportSpecifier.name,
             name,
             /*location*/
@@ -204899,8 +190186,11 @@ ${lanes.join("\n")}
       }
       return statements;
     }
-    function appendExportStatement(statements, exportName, expression, location, allowComments, liveBinding) {
-      statements = append(statements, createExportStatement(exportName, expression, location, allowComments, liveBinding));
+    function appendExportStatement(statements, seen, exportName, expression, location, allowComments, liveBinding) {
+      if (!seen.has(exportName)) {
+        seen.set(exportName, true);
+        statements = append(statements, createExportStatement(exportName, expression, location, allowComments, liveBinding));
+      }
       return statements;
     }
     function createUnderscoreUnderscoreESModule() {
@@ -204959,21 +190249,24 @@ ${lanes.join("\n")}
             factory2.createStringLiteralFromNode(name),
             factory2.createObjectLiteralExpression([
               factory2.createPropertyAssignment("enumerable", factory2.createTrue()),
-              factory2.createPropertyAssignment("get", factory2.createFunctionExpression(
-                /*modifiers*/
-                void 0,
-                /*asteriskToken*/
-                void 0,
-                /*name*/
-                void 0,
-                /*typeParameters*/
-                void 0,
-                /*parameters*/
-                [],
-                /*type*/
-                void 0,
-                factory2.createBlock([factory2.createReturnStatement(value)])
-              ))
+              factory2.createPropertyAssignment(
+                "get",
+                factory2.createFunctionExpression(
+                  /*modifiers*/
+                  void 0,
+                  /*asteriskToken*/
+                  void 0,
+                  /*name*/
+                  void 0,
+                  /*typeParameters*/
+                  void 0,
+                  /*parameters*/
+                  [],
+                  /*type*/
+                  void 0,
+                  factory2.createBlock([factory2.createReturnStatement(value)])
+                )
+              )
             ])
           ]
         ) : factory2.createAssignment(
@@ -204995,7 +190288,7 @@ ${lanes.join("\n")}
       return node;
     }
     function onEmitNode(hint, node, emitCallback) {
-      if (node.kind === 311 /* SourceFile */) {
+      if (node.kind === 312 /* SourceFile */) {
         currentSourceFile = node;
         currentModuleInfo = moduleInfoMap[getOriginalNodeId(currentSourceFile)];
         previousOnEmitNode(hint, node, emitCallback);
@@ -205033,11 +190326,11 @@ ${lanes.join("\n")}
       switch (node.kind) {
         case 80 /* Identifier */:
           return substituteExpressionIdentifier(node);
-        case 212 /* CallExpression */:
+        case 213 /* CallExpression */:
           return substituteCallExpression(node);
-        case 214 /* TaggedTemplateExpression */:
+        case 215 /* TaggedTemplateExpression */:
           return substituteTaggedTemplateExpression(node);
-        case 225 /* BinaryExpression */:
+        case 226 /* BinaryExpression */:
           return substituteBinaryExpression(node);
       }
       return node;
@@ -205090,7 +190383,7 @@ ${lanes.join("\n")}
         return node;
       } else if (!(isGeneratedIdentifier(node) && !(node.emitNode.autoGenerate.flags & 64 /* AllowNameSubstitution */)) && !isLocalName(node)) {
         const exportContainer = resolver.getReferencedExportContainer(node, isExportName(node));
-        if (exportContainer && exportContainer.kind === 311 /* SourceFile */) {
+        if (exportContainer && exportContainer.kind === 312 /* SourceFile */) {
           return setTextRange(
             factory2.createPropertyAccessExpression(
               factory2.createIdentifier("exports"),
@@ -205127,7 +190420,7 @@ ${lanes.join("\n")}
       return node;
     }
     function substituteBinaryExpression(node) {
-      if (isAssignmentOperator(node.operatorToken.kind) && isIdentifier(node.left) && !isGeneratedIdentifier(node.left) && !isLocalName(node.left)) {
+      if (isAssignmentOperator(node.operatorToken.kind) && isIdentifier(node.left) && (!isGeneratedIdentifier(node.left) || isFileLevelReservedGeneratedIdentifier(node.left)) && !isLocalName(node.left)) {
         const exportedNames = getExports(node.left);
         if (exportedNames) {
           let expression = node;
@@ -205166,6 +190459,15 @@ ${lanes.join("\n")}
             return arrayFrom(bindingsSet);
           }
         }
+      } else if (isFileLevelReservedGeneratedIdentifier(name)) {
+        const exportSpecifiers = currentModuleInfo == null ? void 0 : currentModuleInfo.exportSpecifiers.get(name);
+        if (exportSpecifiers) {
+          const exportedNames = [];
+          for (const exportSpecifier of exportSpecifiers) {
+            exportedNames.push(exportSpecifier.name);
+          }
+          return exportedNames;
+        }
       }
     }
   }
@@ -205199,10 +190501,10 @@ ${lanes.join("\n")}
     context.onSubstituteNode = onSubstituteNode;
     context.onEmitNode = onEmitNode;
     context.enableSubstitution(80 /* Identifier */);
-    context.enableSubstitution(303 /* ShorthandPropertyAssignment */);
-    context.enableSubstitution(225 /* BinaryExpression */);
-    context.enableSubstitution(235 /* MetaProperty */);
-    context.enableEmitNotification(311 /* SourceFile */);
+    context.enableSubstitution(304 /* ShorthandPropertyAssignment */);
+    context.enableSubstitution(226 /* BinaryExpression */);
+    context.enableSubstitution(236 /* MetaProperty */);
+    context.enableEmitNotification(312 /* SourceFile */);
     const moduleInfoMap = [];
     const exportFunctionsMap = [];
     const noSubstitutionMap = [];
@@ -205222,7 +190524,7 @@ ${lanes.join("\n")}
       const id = getOriginalNodeId(node);
       currentSourceFile = node;
       enclosingBlockScopedContainer = node;
-      moduleInfo = moduleInfoMap[id] = collectExternalModuleInfo(context, node, resolver, compilerOptions);
+      moduleInfo = moduleInfoMap[id] = collectExternalModuleInfo(context, node);
       exportFunction = factory2.createUniqueName("exports");
       exportFunctionsMap[id] = exportFunction;
       contextObject = contextObjectMap[id] = factory2.createUniqueName("context");
@@ -205343,13 +190645,10 @@ ${lanes.join("\n")}
       addRange(statements, hoistedStatements);
       insertStatementsAfterStandardPrologue(statements, endLexicalEnvironment());
       const exportStarFunction = addExportStarIfNeeded(statements);
-      const modifiers = node.transformFlags & 2097152 /* ContainsAwait */ ? factory2.createModifiersFromModifierFlags(512 /* Async */) : void 0;
+      const modifiers = node.transformFlags & 2097152 /* ContainsAwait */ ? factory2.createModifiersFromModifierFlags(1024 /* Async */) : void 0;
       const moduleObject = factory2.createObjectLiteralExpression(
         [
-          factory2.createPropertyAssignment(
-            "setters",
-            createSettersArray(exportStarFunction, dependencyGroups)
-          ),
+          factory2.createPropertyAssignment("setters", createSettersArray(exportStarFunction, dependencyGroups)),
           factory2.createPropertyAssignment(
             "execute",
             factory2.createFunctionExpression(
@@ -205389,7 +190688,7 @@ ${lanes.join("\n")}
       if (!moduleInfo.exportedNames && moduleInfo.exportSpecifiers.size === 0) {
         let hasExportDeclarationWithExportClause = false;
         for (const externalImport of moduleInfo.externalImports) {
-          if (externalImport.kind === 277 /* ExportDeclaration */ && externalImport.exportClause) {
+          if (externalImport.kind === 278 /* ExportDeclaration */ && externalImport.exportClause) {
             hasExportDeclarationWithExportClause = true;
             break;
           }
@@ -205537,18 +190836,18 @@ ${lanes.join("\n")}
         for (const entry of group2.externalImports) {
           const importVariableName = getLocalNameForExternalImport(factory2, entry, currentSourceFile);
           switch (entry.kind) {
-            case 271 /* ImportDeclaration */:
+            case 272 /* ImportDeclaration */:
               if (!entry.importClause) {
                 break;
               }
-            case 270 /* ImportEqualsDeclaration */:
+            case 271 /* ImportEqualsDeclaration */:
               Debug.assert(importVariableName !== void 0);
               statements.push(
                 factory2.createExpressionStatement(
                   factory2.createAssignment(importVariableName, parameterName)
                 )
               );
-              if (hasSyntacticModifier(entry, 1 /* Export */)) {
+              if (hasSyntacticModifier(entry, 32 /* Export */)) {
                 statements.push(
                   factory2.createExpressionStatement(
                     factory2.createCallExpression(
@@ -205564,7 +190863,7 @@ ${lanes.join("\n")}
                 );
               }
               break;
-            case 277 /* ExportDeclaration */:
+            case 278 /* ExportDeclaration */:
               Debug.assert(importVariableName !== void 0);
               if (entry.exportClause) {
                 if (isNamedExports(entry.exportClause)) {
@@ -205659,13 +190958,13 @@ ${lanes.join("\n")}
     }
     function topLevelVisitor(node) {
       switch (node.kind) {
-        case 271 /* ImportDeclaration */:
+        case 272 /* ImportDeclaration */:
           return visitImportDeclaration(node);
-        case 270 /* ImportEqualsDeclaration */:
+        case 271 /* ImportEqualsDeclaration */:
           return visitImportEqualsDeclaration(node);
-        case 277 /* ExportDeclaration */:
+        case 278 /* ExportDeclaration */:
           return visitExportDeclaration(node);
-        case 276 /* ExportAssignment */:
+        case 277 /* ExportAssignment */:
           return visitExportAssignment(node);
         default:
           return topLevelNestedVisitor(node);
@@ -205701,7 +191000,7 @@ ${lanes.join("\n")}
       );
     }
     function visitFunctionDeclaration(node) {
-      if (hasSyntacticModifier(node, 1 /* Export */)) {
+      if (hasSyntacticModifier(node, 32 /* Export */)) {
         hoistedStatements = append(
           hoistedStatements,
           factory2.updateFunctionDeclaration(
@@ -205762,18 +191061,43 @@ ${lanes.join("\n")}
       if (!shouldHoistVariableDeclarationList(node.declarationList)) {
         return visitNode(node, visitor, isStatement);
       }
-      let expressions;
-      const isExportedDeclaration = hasSyntacticModifier(node, 1 /* Export */);
-      for (const variable of node.declarationList.declarations) {
-        if (variable.initializer) {
-          expressions = append(expressions, transformInitializedVariable(variable, isExportedDeclaration));
-        } else {
-          hoistBindingElement(variable);
-        }
-      }
       let statements;
-      if (expressions) {
-        statements = append(statements, setTextRange(factory2.createExpressionStatement(factory2.inlineExpressions(expressions)), node));
+      if (isVarUsing(node.declarationList) || isVarAwaitUsing(node.declarationList)) {
+        const modifiers = visitNodes2(node.modifiers, modifierVisitor, isModifierLike);
+        const declarations = [];
+        for (const variable of node.declarationList.declarations) {
+          declarations.push(factory2.updateVariableDeclaration(
+            variable,
+            factory2.getGeneratedNameForNode(variable.name),
+            /*exclamationToken*/
+            void 0,
+            /*type*/
+            void 0,
+            transformInitializedVariable(
+              variable,
+              /*isExportedDeclaration*/
+              false
+            )
+          ));
+        }
+        const declarationList = factory2.updateVariableDeclarationList(
+          node.declarationList,
+          declarations
+        );
+        statements = append(statements, factory2.updateVariableStatement(node, modifiers, declarationList));
+      } else {
+        let expressions;
+        const isExportedDeclaration = hasSyntacticModifier(node, 32 /* Export */);
+        for (const variable of node.declarationList.declarations) {
+          if (variable.initializer) {
+            expressions = append(expressions, transformInitializedVariable(variable, isExportedDeclaration));
+          } else {
+            hoistBindingElement(variable);
+          }
+        }
+        if (expressions) {
+          statements = append(statements, setTextRange(factory2.createExpressionStatement(factory2.inlineExpressions(expressions)), node));
+        }
       }
       statements = appendExportsOfVariableStatement(
         statements,
@@ -205795,7 +191119,7 @@ ${lanes.join("\n")}
       }
     }
     function shouldHoistVariableDeclarationList(node) {
-      return (getEmitFlags(node) & 4194304 /* NoHoisting */) === 0 && (enclosingBlockScopedContainer.kind === 311 /* SourceFile */ || (getOriginalNode(node).flags & 3 /* BlockScoped */) === 0);
+      return (getEmitFlags(node) & 4194304 /* NoHoisting */) === 0 && (enclosingBlockScopedContainer.kind === 312 /* SourceFile */ || (getOriginalNode(node).flags & 7 /* BlockScoped */) === 0);
     }
     function transformInitializedVariable(node, isExportedDeclaration) {
       const createAssignment = isExportedDeclaration ? createExportedVariableAssignment : createNonExportedVariableAssignment;
@@ -205845,10 +191169,10 @@ ${lanes.join("\n")}
       const namedBindings = importClause.namedBindings;
       if (namedBindings) {
         switch (namedBindings.kind) {
-          case 273 /* NamespaceImport */:
+          case 274 /* NamespaceImport */:
             statements = appendExportsOfDeclaration(statements, namedBindings);
             break;
-          case 274 /* NamedImports */:
+          case 275 /* NamedImports */:
             for (const importBinding of namedBindings.elements) {
               statements = appendExportsOfDeclaration(statements, importBinding);
             }
@@ -205899,8 +191223,8 @@ ${lanes.join("\n")}
         return statements;
       }
       let excludeName;
-      if (hasSyntacticModifier(decl, 1 /* Export */)) {
-        const exportName = hasSyntacticModifier(decl, 1024 /* Default */) ? factory2.createStringLiteral("default") : decl.name;
+      if (hasSyntacticModifier(decl, 32 /* Export */)) {
+        const exportName = hasSyntacticModifier(decl, 2048 /* Default */) ? factory2.createStringLiteral("default") : decl.name;
         statements = appendExportStatement(statements, exportName, factory2.getLocalName(decl));
         excludeName = getTextOfIdentifierOrLiteral(exportName);
       }
@@ -205914,7 +191238,7 @@ ${lanes.join("\n")}
         return statements;
       }
       const name = factory2.getDeclarationName(decl);
-      const exportSpecifiers = moduleInfo.exportSpecifiers.get(idText(name));
+      const exportSpecifiers = moduleInfo.exportSpecifiers.get(name);
       if (exportSpecifiers) {
         for (const exportSpecifier of exportSpecifiers) {
           if (exportSpecifier.name.escapedText !== excludeName) {
@@ -205948,45 +191272,45 @@ ${lanes.join("\n")}
     }
     function topLevelNestedVisitor(node) {
       switch (node.kind) {
-        case 242 /* VariableStatement */:
+        case 243 /* VariableStatement */:
           return visitVariableStatement(node);
-        case 261 /* FunctionDeclaration */:
+        case 262 /* FunctionDeclaration */:
           return visitFunctionDeclaration(node);
-        case 262 /* ClassDeclaration */:
+        case 263 /* ClassDeclaration */:
           return visitClassDeclaration(node);
-        case 247 /* ForStatement */:
+        case 248 /* ForStatement */:
           return visitForStatement(
             node,
             /*isTopLevel*/
             true
           );
-        case 248 /* ForInStatement */:
+        case 249 /* ForInStatement */:
           return visitForInStatement(node);
-        case 249 /* ForOfStatement */:
+        case 250 /* ForOfStatement */:
           return visitForOfStatement(node);
-        case 245 /* DoStatement */:
+        case 246 /* DoStatement */:
           return visitDoStatement(node);
-        case 246 /* WhileStatement */:
+        case 247 /* WhileStatement */:
           return visitWhileStatement(node);
-        case 255 /* LabeledStatement */:
+        case 256 /* LabeledStatement */:
           return visitLabeledStatement(node);
-        case 253 /* WithStatement */:
+        case 254 /* WithStatement */:
           return visitWithStatement(node);
-        case 244 /* IfStatement */:
+        case 245 /* IfStatement */:
           return visitIfStatement(node);
-        case 254 /* SwitchStatement */:
+        case 255 /* SwitchStatement */:
           return visitSwitchStatement(node);
-        case 268 /* CaseBlock */:
+        case 269 /* CaseBlock */:
           return visitCaseBlock(node);
-        case 295 /* CaseClause */:
+        case 296 /* CaseClause */:
           return visitCaseClause(node);
-        case 296 /* DefaultClause */:
+        case 297 /* DefaultClause */:
           return visitDefaultClause(node);
-        case 257 /* TryStatement */:
+        case 258 /* TryStatement */:
           return visitTryStatement(node);
-        case 298 /* CatchClause */:
+        case 299 /* CatchClause */:
           return visitCatchClause(node);
-        case 240 /* Block */:
+        case 241 /* Block */:
           return visitBlock(node);
         default:
           return visitor(node);
@@ -206140,30 +191464,30 @@ ${lanes.join("\n")}
         return node;
       }
       switch (node.kind) {
-        case 247 /* ForStatement */:
+        case 248 /* ForStatement */:
           return visitForStatement(
             node,
             /*isTopLevel*/
             false
           );
-        case 243 /* ExpressionStatement */:
+        case 244 /* ExpressionStatement */:
           return visitExpressionStatement(node);
-        case 216 /* ParenthesizedExpression */:
+        case 217 /* ParenthesizedExpression */:
           return visitParenthesizedExpression(node, valueIsDiscarded);
-        case 359 /* PartiallyEmittedExpression */:
+        case 360 /* PartiallyEmittedExpression */:
           return visitPartiallyEmittedExpression(node, valueIsDiscarded);
-        case 225 /* BinaryExpression */:
+        case 226 /* BinaryExpression */:
           if (isDestructuringAssignment(node)) {
             return visitDestructuringAssignment(node, valueIsDiscarded);
           }
           break;
-        case 212 /* CallExpression */:
+        case 213 /* CallExpression */:
           if (isImportCall(node)) {
             return visitImportCallExpression(node);
           }
           break;
-        case 223 /* PrefixUnaryExpression */:
-        case 224 /* PostfixUnaryExpression */:
+        case 224 /* PrefixUnaryExpression */:
+        case 225 /* PostfixUnaryExpression */:
           return visitPrefixOrPostfixUnaryExpression(node, valueIsDiscarded);
       }
       return visitEachChild(node, visitor, context);
@@ -206236,7 +191560,7 @@ ${lanes.join("\n")}
         return hasExportedReferenceInDestructuringTarget(node.initializer);
       } else if (isIdentifier(node)) {
         const container = resolver.getReferencedExportContainer(node);
-        return container !== void 0 && container.kind === 311 /* SourceFile */;
+        return container !== void 0 && container.kind === 312 /* SourceFile */;
       } else {
         return false;
       }
@@ -206280,7 +191604,7 @@ ${lanes.join("\n")}
       return node;
     }
     function onEmitNode(hint, node, emitCallback) {
-      if (node.kind === 311 /* SourceFile */) {
+      if (node.kind === 312 /* SourceFile */) {
         const id = getOriginalNodeId(node);
         currentSourceFile = node;
         moduleInfo = moduleInfoMap[id];
@@ -206314,7 +191638,7 @@ ${lanes.join("\n")}
     }
     function substituteUnspecified(node) {
       switch (node.kind) {
-        case 303 /* ShorthandPropertyAssignment */:
+        case 304 /* ShorthandPropertyAssignment */:
           return substituteShorthandPropertyAssignment(node);
       }
       return node;
@@ -206358,9 +191682,9 @@ ${lanes.join("\n")}
       switch (node.kind) {
         case 80 /* Identifier */:
           return substituteExpressionIdentifier(node);
-        case 225 /* BinaryExpression */:
+        case 226 /* BinaryExpression */:
           return substituteBinaryExpression(node);
-        case 235 /* MetaProperty */:
+        case 236 /* MetaProperty */:
           return substituteMetaProperty(node);
       }
       return node;
@@ -206401,7 +191725,7 @@ ${lanes.join("\n")}
       return node;
     }
     function substituteBinaryExpression(node) {
-      if (isAssignmentOperator(node.operatorToken.kind) && isIdentifier(node.left) && !isGeneratedIdentifier(node.left) && !isLocalName(node.left)) {
+      if (isAssignmentOperator(node.operatorToken.kind) && isIdentifier(node.left) && (!isGeneratedIdentifier(node.left) || isFileLevelReservedGeneratedIdentifier(node.left)) && !isLocalName(node.left)) {
         const exportedNames = getExports(node.left);
         if (exportedNames) {
           let expression = node;
@@ -206428,10 +191752,19 @@ ${lanes.join("\n")}
           /*prefixLocals*/
           false
         );
-        if (exportContainer && exportContainer.kind === 311 /* SourceFile */) {
+        if (exportContainer && exportContainer.kind === 312 /* SourceFile */) {
           exportedNames = append(exportedNames, factory2.getDeclarationName(valueDeclaration));
         }
         exportedNames = addRange(exportedNames, moduleInfo == null ? void 0 : moduleInfo.exportedBindings[getOriginalNodeId(valueDeclaration)]);
+      } else if (isGeneratedIdentifier(name) && isFileLevelReservedGeneratedIdentifier(name)) {
+        const exportSpecifiers = moduleInfo == null ? void 0 : moduleInfo.exportSpecifiers.get(name);
+        if (exportSpecifiers) {
+          const exportedNames2 = [];
+          for (const exportSpecifier of exportSpecifiers) {
+            exportedNames2.push(exportSpecifier.name);
+          }
+          return exportedNames2;
+        }
       }
       return exportedNames;
     }
@@ -206484,7 +191817,7 @@ ${lanes.join("\n")}
     const previousOnSubstituteNode = context.onSubstituteNode;
     context.onEmitNode = onEmitNode;
     context.onSubstituteNode = onSubstituteNode;
-    context.enableEmitNotification(311 /* SourceFile */);
+    context.enableEmitNotification(312 /* SourceFile */);
     context.enableSubstitution(80 /* Identifier */);
     let helperNameSubstitutions;
     let currentSourceFile;
@@ -206532,11 +191865,11 @@ ${lanes.join("\n")}
     }
     function visitor(node) {
       switch (node.kind) {
-        case 270 /* ImportEqualsDeclaration */:
+        case 271 /* ImportEqualsDeclaration */:
           return getEmitModuleKind(compilerOptions) >= 100 /* Node16 */ ? visitImportEqualsDeclaration(node) : void 0;
-        case 276 /* ExportAssignment */:
+        case 277 /* ExportAssignment */:
           return visitExportAssignment(node);
-        case 277 /* ExportDeclaration */:
+        case 278 /* ExportDeclaration */:
           const exportDecl = node;
           return visitExportDeclaration(exportDecl);
       }
@@ -206567,7 +191900,9 @@ ${lanes.join("\n")}
               )
             ])
           ),
-          factory2.createStringLiteral("module")
+          factory2.createStringLiteral("module"),
+          /*attributes*/
+          void 0
         );
         const requireHelperName = factory2.createUniqueName("__require", 16 /* Optimistic */ | 32 /* FileLevel */);
         const requireStatement = factory2.createVariableStatement(
@@ -206640,19 +191975,22 @@ ${lanes.join("\n")}
       return singleOrMany(statements);
     }
     function appendExportsOfImportEqualsDeclaration(statements, node) {
-      if (hasSyntacticModifier(node, 1 /* Export */)) {
-        statements = append(statements, factory2.createExportDeclaration(
-          /*modifiers*/
-          void 0,
-          node.isTypeOnly,
-          factory2.createNamedExports([factory2.createExportSpecifier(
-            /*isTypeOnly*/
-            false,
-            /*propertyName*/
+      if (hasSyntacticModifier(node, 32 /* Export */)) {
+        statements = append(
+          statements,
+          factory2.createExportDeclaration(
+            /*modifiers*/
             void 0,
-            idText(node.name)
-          )])
-        ));
+            node.isTypeOnly,
+            factory2.createNamedExports([factory2.createExportSpecifier(
+              /*isTypeOnly*/
+              false,
+              /*propertyName*/
+              void 0,
+              idText(node.name)
+            )])
+          )
+        );
       }
       return statements;
     }
@@ -206681,7 +192019,7 @@ ${lanes.join("\n")}
           )
         ),
         node.moduleSpecifier,
-        node.assertClause
+        node.attributes
       );
       setOriginalNode(importDecl, node.exportClause);
       const exportDecl = isExportNamespaceAsDefaultDeclaration(node) ? factory2.createExportDefault(synthName) : factory2.createExportDeclaration(
@@ -206747,8 +192085,8 @@ ${lanes.join("\n")}
     const cjsOnEmitNode = context.onEmitNode;
     context.onSubstituteNode = onSubstituteNode;
     context.onEmitNode = onEmitNode;
-    context.enableSubstitution(311 /* SourceFile */);
-    context.enableEmitNotification(311 /* SourceFile */);
+    context.enableSubstitution(312 /* SourceFile */);
+    context.enableEmitNotification(312 /* SourceFile */);
     let currentSourceFile;
     return transformSourceFileOrBundle;
     function onSubstituteNode(hint, node) {
@@ -206791,7 +192129,7 @@ ${lanes.join("\n")}
       return result;
     }
     function transformSourceFileOrBundle(node) {
-      return node.kind === 311 /* SourceFile */ ? transformSourceFile(node) : transformBundle(node);
+      return node.kind === 312 /* SourceFile */ ? transformSourceFile(node) : transformBundle(node);
     }
     function transformBundle(node) {
       return context.factory.createBundle(map(node.sourceFiles, transformSourceFile), node.prepends);
@@ -206827,7 +192165,7 @@ ${lanes.join("\n")}
     function getAccessorNameVisibilityDiagnosticMessage(symbolAccessibilityResult) {
       if (isStatic(node)) {
         return symbolAccessibilityResult.errorModuleName ? symbolAccessibilityResult.accessibility === 2 /* CannotBeNamed */ ? Diagnostics.Public_static_property_0_of_exported_class_has_or_is_using_name_1_from_external_module_2_but_cannot_be_named : Diagnostics.Public_static_property_0_of_exported_class_has_or_is_using_name_1_from_private_module_2 : Diagnostics.Public_static_property_0_of_exported_class_has_or_is_using_private_name_1;
-      } else if (node.parent.kind === 262 /* ClassDeclaration */) {
+      } else if (node.parent.kind === 263 /* ClassDeclaration */) {
         return symbolAccessibilityResult.errorModuleName ? symbolAccessibilityResult.accessibility === 2 /* CannotBeNamed */ ? Diagnostics.Public_property_0_of_exported_class_has_or_is_using_name_1_from_external_module_2_but_cannot_be_named : Diagnostics.Public_property_0_of_exported_class_has_or_is_using_name_1_from_private_module_2 : Diagnostics.Public_property_0_of_exported_class_has_or_is_using_private_name_1;
       } else {
         return symbolAccessibilityResult.errorModuleName ? Diagnostics.Property_0_of_exported_interface_has_or_is_using_name_1_from_private_module_2 : Diagnostics.Property_0_of_exported_interface_has_or_is_using_private_name_1;
@@ -206844,7 +192182,7 @@ ${lanes.join("\n")}
     function getMethodNameVisibilityDiagnosticMessage(symbolAccessibilityResult) {
       if (isStatic(node)) {
         return symbolAccessibilityResult.errorModuleName ? symbolAccessibilityResult.accessibility === 2 /* CannotBeNamed */ ? Diagnostics.Public_static_method_0_of_exported_class_has_or_is_using_name_1_from_external_module_2_but_cannot_be_named : Diagnostics.Public_static_method_0_of_exported_class_has_or_is_using_name_1_from_private_module_2 : Diagnostics.Public_static_method_0_of_exported_class_has_or_is_using_private_name_1;
-      } else if (node.parent.kind === 262 /* ClassDeclaration */) {
+      } else if (node.parent.kind === 263 /* ClassDeclaration */) {
         return symbolAccessibilityResult.errorModuleName ? symbolAccessibilityResult.accessibility === 2 /* CannotBeNamed */ ? Diagnostics.Public_method_0_of_exported_class_has_or_is_using_name_1_from_external_module_2_but_cannot_be_named : Diagnostics.Public_method_0_of_exported_class_has_or_is_using_name_1_from_private_module_2 : Diagnostics.Public_method_0_of_exported_class_has_or_is_using_private_name_1;
       } else {
         return symbolAccessibilityResult.errorModuleName ? Diagnostics.Method_0_of_exported_interface_has_or_is_using_name_1_from_private_module_2 : Diagnostics.Method_0_of_exported_interface_has_or_is_using_private_name_1;
@@ -206859,7 +192197,7 @@ ${lanes.join("\n")}
     } else if (isConstructSignatureDeclaration(node) || isCallSignatureDeclaration(node) || isMethodDeclaration(node) || isMethodSignature(node) || isFunctionDeclaration(node) || isIndexSignatureDeclaration(node)) {
       return getReturnTypeVisibilityError;
     } else if (isParameter(node)) {
-      if (isParameterPropertyDeclaration(node, node.parent) && hasSyntacticModifier(node.parent, 8 /* Private */)) {
+      if (isParameterPropertyDeclaration(node, node.parent) && hasSyntacticModifier(node.parent, 2 /* Private */)) {
         return getVariableDeclarationTypeVisibilityError;
       }
       return getParameterDeclarationTypeVisibilityError;
@@ -206875,12 +192213,12 @@ ${lanes.join("\n")}
       return Debug.assertNever(node, `Attempted to set a declaration diagnostic context for unhandled node kind: ${Debug.formatSyntaxKind(node.kind)}`);
     }
     function getVariableDeclarationTypeVisibilityDiagnosticMessage(symbolAccessibilityResult) {
-      if (node.kind === 259 /* VariableDeclaration */ || node.kind === 207 /* BindingElement */) {
+      if (node.kind === 260 /* VariableDeclaration */ || node.kind === 208 /* BindingElement */) {
         return symbolAccessibilityResult.errorModuleName ? symbolAccessibilityResult.accessibility === 2 /* CannotBeNamed */ ? Diagnostics.Exported_variable_0_has_or_is_using_name_1_from_external_module_2_but_cannot_be_named : Diagnostics.Exported_variable_0_has_or_is_using_name_1_from_private_module_2 : Diagnostics.Exported_variable_0_has_or_is_using_private_name_1;
-      } else if (node.kind === 171 /* PropertyDeclaration */ || node.kind === 210 /* PropertyAccessExpression */ || node.kind === 211 /* ElementAccessExpression */ || node.kind === 225 /* BinaryExpression */ || node.kind === 170 /* PropertySignature */ || node.kind === 168 /* Parameter */ && hasSyntacticModifier(node.parent, 8 /* Private */)) {
+      } else if (node.kind === 172 /* PropertyDeclaration */ || node.kind === 211 /* PropertyAccessExpression */ || node.kind === 212 /* ElementAccessExpression */ || node.kind === 226 /* BinaryExpression */ || node.kind === 171 /* PropertySignature */ || node.kind === 169 /* Parameter */ && hasSyntacticModifier(node.parent, 2 /* Private */)) {
         if (isStatic(node)) {
           return symbolAccessibilityResult.errorModuleName ? symbolAccessibilityResult.accessibility === 2 /* CannotBeNamed */ ? Diagnostics.Public_static_property_0_of_exported_class_has_or_is_using_name_1_from_external_module_2_but_cannot_be_named : Diagnostics.Public_static_property_0_of_exported_class_has_or_is_using_name_1_from_private_module_2 : Diagnostics.Public_static_property_0_of_exported_class_has_or_is_using_private_name_1;
-        } else if (node.parent.kind === 262 /* ClassDeclaration */ || node.kind === 168 /* Parameter */) {
+        } else if (node.parent.kind === 263 /* ClassDeclaration */ || node.kind === 169 /* Parameter */) {
           return symbolAccessibilityResult.errorModuleName ? symbolAccessibilityResult.accessibility === 2 /* CannotBeNamed */ ? Diagnostics.Public_property_0_of_exported_class_has_or_is_using_name_1_from_external_module_2_but_cannot_be_named : Diagnostics.Public_property_0_of_exported_class_has_or_is_using_name_1_from_private_module_2 : Diagnostics.Public_property_0_of_exported_class_has_or_is_using_private_name_1;
         } else {
           return symbolAccessibilityResult.errorModuleName ? Diagnostics.Property_0_of_exported_interface_has_or_is_using_name_1_from_private_module_2 : Diagnostics.Property_0_of_exported_interface_has_or_is_using_private_name_1;
@@ -206897,7 +192235,7 @@ ${lanes.join("\n")}
     }
     function getAccessorDeclarationTypeVisibilityError(symbolAccessibilityResult) {
       let diagnosticMessage;
-      if (node.kind === 177 /* SetAccessor */) {
+      if (node.kind === 178 /* SetAccessor */) {
         if (isStatic(node)) {
           diagnosticMessage = symbolAccessibilityResult.errorModuleName ? Diagnostics.Parameter_type_of_public_static_setter_0_from_exported_class_has_or_is_using_name_1_from_private_module_2 : Diagnostics.Parameter_type_of_public_static_setter_0_from_exported_class_has_or_is_using_private_name_1;
         } else {
@@ -206919,26 +192257,26 @@ ${lanes.join("\n")}
     function getReturnTypeVisibilityError(symbolAccessibilityResult) {
       let diagnosticMessage;
       switch (node.kind) {
-        case 179 /* ConstructSignature */:
+        case 180 /* ConstructSignature */:
           diagnosticMessage = symbolAccessibilityResult.errorModuleName ? Diagnostics.Return_type_of_constructor_signature_from_exported_interface_has_or_is_using_name_0_from_private_module_1 : Diagnostics.Return_type_of_constructor_signature_from_exported_interface_has_or_is_using_private_name_0;
           break;
-        case 178 /* CallSignature */:
+        case 179 /* CallSignature */:
           diagnosticMessage = symbolAccessibilityResult.errorModuleName ? Diagnostics.Return_type_of_call_signature_from_exported_interface_has_or_is_using_name_0_from_private_module_1 : Diagnostics.Return_type_of_call_signature_from_exported_interface_has_or_is_using_private_name_0;
           break;
-        case 180 /* IndexSignature */:
+        case 181 /* IndexSignature */:
           diagnosticMessage = symbolAccessibilityResult.errorModuleName ? Diagnostics.Return_type_of_index_signature_from_exported_interface_has_or_is_using_name_0_from_private_module_1 : Diagnostics.Return_type_of_index_signature_from_exported_interface_has_or_is_using_private_name_0;
           break;
-        case 173 /* MethodDeclaration */:
-        case 172 /* MethodSignature */:
+        case 174 /* MethodDeclaration */:
+        case 173 /* MethodSignature */:
           if (isStatic(node)) {
             diagnosticMessage = symbolAccessibilityResult.errorModuleName ? symbolAccessibilityResult.accessibility === 2 /* CannotBeNamed */ ? Diagnostics.Return_type_of_public_static_method_from_exported_class_has_or_is_using_name_0_from_external_module_1_but_cannot_be_named : Diagnostics.Return_type_of_public_static_method_from_exported_class_has_or_is_using_name_0_from_private_module_1 : Diagnostics.Return_type_of_public_static_method_from_exported_class_has_or_is_using_private_name_0;
-          } else if (node.parent.kind === 262 /* ClassDeclaration */) {
+          } else if (node.parent.kind === 263 /* ClassDeclaration */) {
             diagnosticMessage = symbolAccessibilityResult.errorModuleName ? symbolAccessibilityResult.accessibility === 2 /* CannotBeNamed */ ? Diagnostics.Return_type_of_public_method_from_exported_class_has_or_is_using_name_0_from_external_module_1_but_cannot_be_named : Diagnostics.Return_type_of_public_method_from_exported_class_has_or_is_using_name_0_from_private_module_1 : Diagnostics.Return_type_of_public_method_from_exported_class_has_or_is_using_private_name_0;
           } else {
             diagnosticMessage = symbolAccessibilityResult.errorModuleName ? Diagnostics.Return_type_of_method_from_exported_interface_has_or_is_using_name_0_from_private_module_1 : Diagnostics.Return_type_of_method_from_exported_interface_has_or_is_using_private_name_0;
           }
           break;
-        case 261 /* FunctionDeclaration */:
+        case 262 /* FunctionDeclaration */:
           diagnosticMessage = symbolAccessibilityResult.errorModuleName ? symbolAccessibilityResult.accessibility === 2 /* CannotBeNamed */ ? Diagnostics.Return_type_of_exported_function_has_or_is_using_name_0_from_external_module_1_but_cannot_be_named : Diagnostics.Return_type_of_exported_function_has_or_is_using_name_0_from_private_module_1 : Diagnostics.Return_type_of_exported_function_has_or_is_using_private_name_0;
           break;
         default:
@@ -206959,29 +192297,29 @@ ${lanes.join("\n")}
     }
     function getParameterDeclarationTypeVisibilityDiagnosticMessage(symbolAccessibilityResult) {
       switch (node.parent.kind) {
-        case 175 /* Constructor */:
+        case 176 /* Constructor */:
           return symbolAccessibilityResult.errorModuleName ? symbolAccessibilityResult.accessibility === 2 /* CannotBeNamed */ ? Diagnostics.Parameter_0_of_constructor_from_exported_class_has_or_is_using_name_1_from_external_module_2_but_cannot_be_named : Diagnostics.Parameter_0_of_constructor_from_exported_class_has_or_is_using_name_1_from_private_module_2 : Diagnostics.Parameter_0_of_constructor_from_exported_class_has_or_is_using_private_name_1;
-        case 179 /* ConstructSignature */:
-        case 184 /* ConstructorType */:
+        case 180 /* ConstructSignature */:
+        case 185 /* ConstructorType */:
           return symbolAccessibilityResult.errorModuleName ? Diagnostics.Parameter_0_of_constructor_signature_from_exported_interface_has_or_is_using_name_1_from_private_module_2 : Diagnostics.Parameter_0_of_constructor_signature_from_exported_interface_has_or_is_using_private_name_1;
-        case 178 /* CallSignature */:
+        case 179 /* CallSignature */:
           return symbolAccessibilityResult.errorModuleName ? Diagnostics.Parameter_0_of_call_signature_from_exported_interface_has_or_is_using_name_1_from_private_module_2 : Diagnostics.Parameter_0_of_call_signature_from_exported_interface_has_or_is_using_private_name_1;
-        case 180 /* IndexSignature */:
+        case 181 /* IndexSignature */:
           return symbolAccessibilityResult.errorModuleName ? Diagnostics.Parameter_0_of_index_signature_from_exported_interface_has_or_is_using_name_1_from_private_module_2 : Diagnostics.Parameter_0_of_index_signature_from_exported_interface_has_or_is_using_private_name_1;
-        case 173 /* MethodDeclaration */:
-        case 172 /* MethodSignature */:
+        case 174 /* MethodDeclaration */:
+        case 173 /* MethodSignature */:
           if (isStatic(node.parent)) {
             return symbolAccessibilityResult.errorModuleName ? symbolAccessibilityResult.accessibility === 2 /* CannotBeNamed */ ? Diagnostics.Parameter_0_of_public_static_method_from_exported_class_has_or_is_using_name_1_from_external_module_2_but_cannot_be_named : Diagnostics.Parameter_0_of_public_static_method_from_exported_class_has_or_is_using_name_1_from_private_module_2 : Diagnostics.Parameter_0_of_public_static_method_from_exported_class_has_or_is_using_private_name_1;
-          } else if (node.parent.parent.kind === 262 /* ClassDeclaration */) {
+          } else if (node.parent.parent.kind === 263 /* ClassDeclaration */) {
             return symbolAccessibilityResult.errorModuleName ? symbolAccessibilityResult.accessibility === 2 /* CannotBeNamed */ ? Diagnostics.Parameter_0_of_public_method_from_exported_class_has_or_is_using_name_1_from_external_module_2_but_cannot_be_named : Diagnostics.Parameter_0_of_public_method_from_exported_class_has_or_is_using_name_1_from_private_module_2 : Diagnostics.Parameter_0_of_public_method_from_exported_class_has_or_is_using_private_name_1;
           } else {
             return symbolAccessibilityResult.errorModuleName ? Diagnostics.Parameter_0_of_method_from_exported_interface_has_or_is_using_name_1_from_private_module_2 : Diagnostics.Parameter_0_of_method_from_exported_interface_has_or_is_using_private_name_1;
           }
-        case 261 /* FunctionDeclaration */:
-        case 183 /* FunctionType */:
+        case 262 /* FunctionDeclaration */:
+        case 184 /* FunctionType */:
           return symbolAccessibilityResult.errorModuleName ? symbolAccessibilityResult.accessibility === 2 /* CannotBeNamed */ ? Diagnostics.Parameter_0_of_exported_function_has_or_is_using_name_1_from_external_module_2_but_cannot_be_named : Diagnostics.Parameter_0_of_exported_function_has_or_is_using_name_1_from_private_module_2 : Diagnostics.Parameter_0_of_exported_function_has_or_is_using_private_name_1;
-        case 177 /* SetAccessor */:
-        case 176 /* GetAccessor */:
+        case 178 /* SetAccessor */:
+        case 177 /* GetAccessor */:
           return symbolAccessibilityResult.errorModuleName ? symbolAccessibilityResult.accessibility === 2 /* CannotBeNamed */ ? Diagnostics.Parameter_0_of_accessor_has_or_is_using_name_1_from_external_module_2_but_cannot_be_named : Diagnostics.Parameter_0_of_accessor_has_or_is_using_name_1_from_private_module_2 : Diagnostics.Parameter_0_of_accessor_has_or_is_using_private_name_1;
         default:
           return Debug.fail(`Unknown parent for parameter: ${Debug.formatSyntaxKind(node.parent.kind)}`);
@@ -206990,40 +192328,40 @@ ${lanes.join("\n")}
     function getTypeParameterConstraintVisibilityError() {
       let diagnosticMessage;
       switch (node.parent.kind) {
-        case 262 /* ClassDeclaration */:
+        case 263 /* ClassDeclaration */:
           diagnosticMessage = Diagnostics.Type_parameter_0_of_exported_class_has_or_is_using_private_name_1;
           break;
-        case 263 /* InterfaceDeclaration */:
+        case 264 /* InterfaceDeclaration */:
           diagnosticMessage = Diagnostics.Type_parameter_0_of_exported_interface_has_or_is_using_private_name_1;
           break;
-        case 199 /* MappedType */:
+        case 200 /* MappedType */:
           diagnosticMessage = Diagnostics.Type_parameter_0_of_exported_mapped_object_type_is_using_private_name_1;
           break;
-        case 184 /* ConstructorType */:
-        case 179 /* ConstructSignature */:
+        case 185 /* ConstructorType */:
+        case 180 /* ConstructSignature */:
           diagnosticMessage = Diagnostics.Type_parameter_0_of_constructor_signature_from_exported_interface_has_or_is_using_private_name_1;
           break;
-        case 178 /* CallSignature */:
+        case 179 /* CallSignature */:
           diagnosticMessage = Diagnostics.Type_parameter_0_of_call_signature_from_exported_interface_has_or_is_using_private_name_1;
           break;
-        case 173 /* MethodDeclaration */:
-        case 172 /* MethodSignature */:
+        case 174 /* MethodDeclaration */:
+        case 173 /* MethodSignature */:
           if (isStatic(node.parent)) {
             diagnosticMessage = Diagnostics.Type_parameter_0_of_public_static_method_from_exported_class_has_or_is_using_private_name_1;
-          } else if (node.parent.parent.kind === 262 /* ClassDeclaration */) {
+          } else if (node.parent.parent.kind === 263 /* ClassDeclaration */) {
             diagnosticMessage = Diagnostics.Type_parameter_0_of_public_method_from_exported_class_has_or_is_using_private_name_1;
           } else {
             diagnosticMessage = Diagnostics.Type_parameter_0_of_method_from_exported_interface_has_or_is_using_private_name_1;
           }
           break;
-        case 183 /* FunctionType */:
-        case 261 /* FunctionDeclaration */:
+        case 184 /* FunctionType */:
+        case 262 /* FunctionDeclaration */:
           diagnosticMessage = Diagnostics.Type_parameter_0_of_exported_function_has_or_is_using_private_name_1;
           break;
-        case 194 /* InferType */:
+        case 195 /* InferType */:
           diagnosticMessage = Diagnostics.Extends_clause_for_inferred_type_0_has_or_is_using_private_name_1;
           break;
-        case 264 /* TypeAliasDeclaration */:
+        case 265 /* TypeAliasDeclaration */:
           diagnosticMessage = Diagnostics.Type_parameter_0_of_exported_type_alias_has_or_is_using_private_name_1;
           break;
         default:
@@ -207087,11 +192425,11 @@ ${lanes.join("\n")}
   }
   function hasInternalAnnotation(range, currentSourceFile) {
     const comment = currentSourceFile.text.substring(range.pos, range.end);
-    return stringContains(comment, "@internal");
+    return comment.includes("@internal");
   }
   function isInternalDeclaration(node, currentSourceFile) {
     const parseTreeNode = getParseTreeNode(node);
-    if (parseTreeNode && parseTreeNode.kind === 168 /* Parameter */) {
+    if (parseTreeNode && parseTreeNode.kind === 169 /* Parameter */) {
       const paramIdx = parseTreeNode.parent.parameters.indexOf(parseTreeNode);
       const previousSibling = paramIdx > 0 ? parseTreeNode.parent.parameters[paramIdx - 1] : void 0;
       const text = currentSourceFile.text;
@@ -207151,8 +192489,7 @@ ${lanes.join("\n")}
       trackReferencedAmbientModule,
       trackExternalModuleSymbolOfImportTypeNode,
       reportNonlocalAugmentation,
-      reportNonSerializableProperty,
-      reportImportTypeNodeResolutionModeOverride
+      reportNonSerializableProperty
     };
     let errorNameNode;
     let errorFallbackNode;
@@ -207181,6 +192518,17 @@ ${lanes.join("\n")}
       const container = getSourceFileOfNode(node);
       refs.set(getOriginalNodeId(container), container);
     }
+    function trackReferencedAmbientModuleFromImport(node) {
+      const moduleSpecifier = tryGetModuleSpecifierFromDeclaration(node);
+      const symbol = moduleSpecifier && resolver.tryFindAmbientModule(moduleSpecifier);
+      if (symbol == null ? void 0 : symbol.declarations) {
+        for (const decl of symbol.declarations) {
+          if (isAmbientModule(decl) && getSourceFileOfNode(decl) !== currentSourceFile) {
+            trackReferencedAmbientModule(decl, symbol);
+          }
+        }
+      }
+    }
     function handleSymbolAccessibilityError(symbolAccessibilityResult) {
       if (symbolAccessibilityResult.accessibility === 0 /* Accessible */) {
         if (symbolAccessibilityResult && symbolAccessibilityResult.aliasesToMakeVisible) {
@@ -207196,20 +192544,9 @@ ${lanes.join("\n")}
         const errorInfo = getSymbolAccessibilityDiagnostic(symbolAccessibilityResult);
         if (errorInfo) {
           if (errorInfo.typeName) {
-            context.addDiagnostic(createDiagnosticForNode(
-              symbolAccessibilityResult.errorNode || errorInfo.errorNode,
-              errorInfo.diagnosticMessage,
-              getTextOfNode(errorInfo.typeName),
-              symbolAccessibilityResult.errorSymbolName,
-              symbolAccessibilityResult.errorModuleName
-            ));
+            context.addDiagnostic(createDiagnosticForNode(symbolAccessibilityResult.errorNode || errorInfo.errorNode, errorInfo.diagnosticMessage, getTextOfNode(errorInfo.typeName), symbolAccessibilityResult.errorSymbolName, symbolAccessibilityResult.errorModuleName));
           } else {
-            context.addDiagnostic(createDiagnosticForNode(
-              symbolAccessibilityResult.errorNode || errorInfo.errorNode,
-              errorInfo.diagnosticMessage,
-              symbolAccessibilityResult.errorSymbolName,
-              symbolAccessibilityResult.errorModuleName
-            ));
+            context.addDiagnostic(createDiagnosticForNode(symbolAccessibilityResult.errorNode || errorInfo.errorNode, errorInfo.diagnosticMessage, symbolAccessibilityResult.errorSymbolName, symbolAccessibilityResult.errorModuleName));
           }
           return true;
         }
@@ -207246,41 +192583,22 @@ ${lanes.join("\n")}
     }
     function reportInaccessibleUniqueSymbolError() {
       if (errorNameNode || errorFallbackNode) {
-        context.addDiagnostic(createDiagnosticForNode(
-          errorNameNode || errorFallbackNode,
-          Diagnostics.The_inferred_type_of_0_references_an_inaccessible_1_type_A_type_annotation_is_necessary,
-          errorDeclarationNameWithFallback(),
-          "unique symbol"
-        ));
+        context.addDiagnostic(createDiagnosticForNode(errorNameNode || errorFallbackNode, Diagnostics.The_inferred_type_of_0_references_an_inaccessible_1_type_A_type_annotation_is_necessary, errorDeclarationNameWithFallback(), "unique symbol"));
       }
     }
     function reportCyclicStructureError() {
       if (errorNameNode || errorFallbackNode) {
-        context.addDiagnostic(createDiagnosticForNode(
-          errorNameNode || errorFallbackNode,
-          Diagnostics.The_inferred_type_of_0_references_a_type_with_a_cyclic_structure_which_cannot_be_trivially_serialized_A_type_annotation_is_necessary,
-          errorDeclarationNameWithFallback()
-        ));
+        context.addDiagnostic(createDiagnosticForNode(errorNameNode || errorFallbackNode, Diagnostics.The_inferred_type_of_0_references_a_type_with_a_cyclic_structure_which_cannot_be_trivially_serialized_A_type_annotation_is_necessary, errorDeclarationNameWithFallback()));
       }
     }
     function reportInaccessibleThisError() {
       if (errorNameNode || errorFallbackNode) {
-        context.addDiagnostic(createDiagnosticForNode(
-          errorNameNode || errorFallbackNode,
-          Diagnostics.The_inferred_type_of_0_references_an_inaccessible_1_type_A_type_annotation_is_necessary,
-          errorDeclarationNameWithFallback(),
-          "this"
-        ));
+        context.addDiagnostic(createDiagnosticForNode(errorNameNode || errorFallbackNode, Diagnostics.The_inferred_type_of_0_references_an_inaccessible_1_type_A_type_annotation_is_necessary, errorDeclarationNameWithFallback(), "this"));
       }
     }
     function reportLikelyUnsafeImportRequiredError(specifier) {
       if (errorNameNode || errorFallbackNode) {
-        context.addDiagnostic(createDiagnosticForNode(
-          errorNameNode || errorFallbackNode,
-          Diagnostics.The_inferred_type_of_0_cannot_be_named_without_a_reference_to_1_This_is_likely_not_portable_A_type_annotation_is_necessary,
-          errorDeclarationNameWithFallback(),
-          specifier
-        ));
+        context.addDiagnostic(createDiagnosticForNode(errorNameNode || errorFallbackNode, Diagnostics.The_inferred_type_of_0_cannot_be_named_without_a_reference_to_1_This_is_likely_not_portable_A_type_annotation_is_necessary, errorDeclarationNameWithFallback(), specifier));
       }
     }
     function reportTruncationError() {
@@ -207306,11 +192624,6 @@ ${lanes.join("\n")}
         context.addDiagnostic(createDiagnosticForNode(errorNameNode || errorFallbackNode, Diagnostics.The_type_of_this_node_cannot_be_serialized_because_its_property_0_cannot_be_serialized, propertyName));
       }
     }
-    function reportImportTypeNodeResolutionModeOverride() {
-      if (!isNightly() && (errorNameNode || errorFallbackNode)) {
-        context.addDiagnostic(createDiagnosticForNode(errorNameNode || errorFallbackNode, Diagnostics.The_type_of_this_expression_cannot_be_named_without_a_resolution_mode_assertion_which_is_an_unstable_feature_Use_nightly_TypeScript_to_silence_this_error_Try_updating_with_npm_install_D_typescript_next));
-      }
-    }
     function transformDeclarationsForJS(sourceFile, bundled) {
       const oldDiag = getSymbolAccessibilityDiagnostic;
       getSymbolAccessibilityDiagnostic = (s) => s.errorNode && canProduceDiagnostics(s.errorNode) ? createGetSymbolAccessibilityDiagnosticForNode(s.errorNode)(s) : {
@@ -207322,17 +192635,16 @@ ${lanes.join("\n")}
       return result;
     }
     function transformRoot(node) {
-      if (node.kind === 311 /* SourceFile */ && node.isDeclarationFile) {
+      if (node.kind === 312 /* SourceFile */ && node.isDeclarationFile) {
         return node;
       }
-      if (node.kind === 312 /* Bundle */) {
+      if (node.kind === 313 /* Bundle */) {
         isBundledEmit = true;
         refs = /* @__PURE__ */ new Map();
         libs2 = /* @__PURE__ */ new Map();
         let hasNoDefaultLib = false;
-        const bundle = factory2.createBundle(map(
-          node.sourceFiles,
-          (sourceFile) => {
+        const bundle = factory2.createBundle(
+          map(node.sourceFiles, (sourceFile) => {
             if (sourceFile.isDeclarationFile)
               return void 0;
             hasNoDefaultLib = hasNoDefaultLib || sourceFile.hasNoDefaultLib;
@@ -207390,18 +192702,19 @@ ${lanes.join("\n")}
               /*libReferences*/
               []
             );
-          }
-        ), mapDefined(node.prepends, (prepend) => {
-          if (prepend.kind === 314 /* InputFiles */) {
-            const sourceFile = createUnparsedSourceFile(prepend, "dts", stripInternal);
-            hasNoDefaultLib = hasNoDefaultLib || !!sourceFile.hasNoDefaultLib;
-            collectReferences(sourceFile, refs);
-            recordTypeReferenceDirectivesIfNecessary(map(sourceFile.typeReferenceDirectives, (ref) => [ref.fileName, ref.resolutionMode]));
-            collectLibs(sourceFile, libs2);
-            return sourceFile;
-          }
-          return prepend;
-        }));
+          }),
+          mapDefined(node.prepends, (prepend) => {
+            if (prepend.kind === 315 /* InputFiles */) {
+              const sourceFile = createUnparsedSourceFile(prepend, "dts", stripInternal);
+              hasNoDefaultLib = hasNoDefaultLib || !!sourceFile.hasNoDefaultLib;
+              collectReferences(sourceFile, refs);
+              recordTypeReferenceDirectivesIfNecessary(map(sourceFile.typeReferenceDirectives, (ref) => [ref.fileName, ref.resolutionMode]));
+              collectLibs(sourceFile, libs2);
+              return sourceFile;
+            }
+            return prepend;
+          })
+        );
         bundle.syntheticFileReferences = [];
         bundle.syntheticTypeReferences = getFileReferencesForUsedTypeReferences();
         bundle.syntheticLibReferences = getLibReferences();
@@ -207560,16 +192873,19 @@ ${lanes.join("\n")}
       if (name.kind === 80 /* Identifier */) {
         return name;
       } else {
-        if (name.kind === 206 /* ArrayBindingPattern */) {
+        if (name.kind === 207 /* ArrayBindingPattern */) {
           return factory2.updateArrayBindingPattern(name, visitNodes2(name.elements, visitBindingElement, isArrayBindingElement));
         } else {
           return factory2.updateObjectBindingPattern(name, visitNodes2(name.elements, visitBindingElement, isBindingElement));
         }
       }
       function visitBindingElement(elem) {
-        if (elem.kind === 231 /* OmittedExpression */) {
+        if (elem.kind === 232 /* OmittedExpression */) {
           return elem;
         }
+        if (elem.propertyName && isComputedPropertyName(elem.propertyName) && isEntityNameExpression(elem.propertyName.expression)) {
+          checkEntityNameVisibility(elem.propertyName.expression, enclosingDeclaration);
+        }
         if (elem.propertyName && isIdentifier(elem.propertyName) && isIdentifier(elem.name) && !elem.symbol.isReferenced && !isIdentifierANonContextualKeyword(elem.propertyName)) {
           return factory2.updateBindingElement(
             elem,
@@ -207625,20 +192941,20 @@ ${lanes.join("\n")}
       return void 0;
     }
     function ensureType(node, type, ignorePrivate) {
-      if (!ignorePrivate && hasEffectiveModifier(node, 8 /* Private */)) {
+      if (!ignorePrivate && hasEffectiveModifier(node, 2 /* Private */)) {
         return;
       }
       if (shouldPrintWithInitializer(node)) {
         return;
       }
-      const shouldUseResolverType = node.kind === 168 /* Parameter */ && (resolver.isRequiredInitializedParameter(node) || resolver.isOptionalUninitializedParameterProperty(node));
+      const shouldUseResolverType = node.kind === 169 /* Parameter */ && (resolver.isRequiredInitializedParameter(node) || resolver.isOptionalUninitializedParameterProperty(node));
       if (type && !shouldUseResolverType) {
         return visitNode(type, visitDeclarationSubtree, isTypeNode);
       }
       if (!getParseTreeNode(node)) {
         return type ? visitNode(type, visitDeclarationSubtree, isTypeNode) : factory2.createKeywordTypeNode(133 /* AnyKeyword */);
       }
-      if (node.kind === 177 /* SetAccessor */) {
+      if (node.kind === 178 /* SetAccessor */) {
         return factory2.createKeywordTypeNode(133 /* AnyKeyword */);
       }
       errorNameNode = node.name;
@@ -207647,10 +192963,10 @@ ${lanes.join("\n")}
         oldDiag = getSymbolAccessibilityDiagnostic;
         getSymbolAccessibilityDiagnostic = createGetSymbolAccessibilityDiagnosticForNode(node);
       }
-      if (node.kind === 259 /* VariableDeclaration */ || node.kind === 207 /* BindingElement */) {
+      if (node.kind === 260 /* VariableDeclaration */ || node.kind === 208 /* BindingElement */) {
         return cleanup(resolver.createTypeOfDeclaration(node, enclosingDeclaration, declarationEmitNodeBuilderFlags, symbolTracker));
       }
-      if (node.kind === 168 /* Parameter */ || node.kind === 171 /* PropertyDeclaration */ || node.kind === 170 /* PropertySignature */) {
+      if (node.kind === 169 /* Parameter */ || node.kind === 172 /* PropertyDeclaration */ || node.kind === 171 /* PropertySignature */) {
         if (isPropertySignature(node) || !node.initializer)
           return cleanup(resolver.createTypeOfDeclaration(node, enclosingDeclaration, declarationEmitNodeBuilderFlags, symbolTracker, shouldUseResolverType));
         return cleanup(resolver.createTypeOfDeclaration(node, enclosingDeclaration, declarationEmitNodeBuilderFlags, symbolTracker, shouldUseResolverType) || resolver.createTypeOfExpression(node.initializer, enclosingDeclaration, declarationEmitNodeBuilderFlags, symbolTracker));
@@ -207667,21 +192983,21 @@ ${lanes.join("\n")}
     function isDeclarationAndNotVisible(node) {
       node = getParseTreeNode(node);
       switch (node.kind) {
-        case 261 /* FunctionDeclaration */:
-        case 266 /* ModuleDeclaration */:
-        case 263 /* InterfaceDeclaration */:
-        case 262 /* ClassDeclaration */:
-        case 264 /* TypeAliasDeclaration */:
-        case 265 /* EnumDeclaration */:
+        case 262 /* FunctionDeclaration */:
+        case 267 /* ModuleDeclaration */:
+        case 264 /* InterfaceDeclaration */:
+        case 263 /* ClassDeclaration */:
+        case 265 /* TypeAliasDeclaration */:
+        case 266 /* EnumDeclaration */:
           return !resolver.isDeclarationVisible(node);
-        case 259 /* VariableDeclaration */:
+        case 260 /* VariableDeclaration */:
           return !getBindingNameVisible(node);
-        case 270 /* ImportEqualsDeclaration */:
-        case 271 /* ImportDeclaration */:
-        case 277 /* ExportDeclaration */:
-        case 276 /* ExportAssignment */:
+        case 271 /* ImportEqualsDeclaration */:
+        case 272 /* ImportDeclaration */:
+        case 278 /* ExportDeclaration */:
+        case 277 /* ExportAssignment */:
           return false;
-        case 174 /* ClassStaticBlockDeclaration */:
+        case 175 /* ClassStaticBlockDeclaration */:
           return true;
       }
       return false;
@@ -207705,7 +193021,7 @@ ${lanes.join("\n")}
       }
     }
     function updateParamsList(node, params, modifierMask) {
-      if (hasEffectiveModifier(node, 8 /* Private */)) {
+      if (hasEffectiveModifier(node, 2 /* Private */)) {
         return factory2.createNodeArray();
       }
       const newParams = map(params, (p) => ensureParameter(p, modifierMask));
@@ -207750,7 +193066,7 @@ ${lanes.join("\n")}
       return factory2.createNodeArray(newParams || emptyArray);
     }
     function ensureTypeParams(node, params) {
-      return hasEffectiveModifier(node, 8 /* Private */) ? void 0 : visitNodes2(params, visitDeclarationSubtree, isTypeParameterDeclaration);
+      return hasEffectiveModifier(node, 2 /* Private */) ? void 0 : visitNodes2(params, visitDeclarationSubtree, isTypeParameterDeclaration);
     }
     function isEnclosingDeclaration(node) {
       return isSourceFile(node) || isTypeAliasDeclaration(node) || isModuleDeclaration(node) || isClassDeclaration(node) || isInterfaceDeclaration(node) || isFunctionLike(node) || isIndexSignatureDeclaration(node) || isMappedTypeNode(node);
@@ -207769,7 +193085,7 @@ ${lanes.join("\n")}
     function rewriteModuleSpecifier(parent2, input) {
       if (!input)
         return void 0;
-      resultHasExternalModuleIndicator = resultHasExternalModuleIndicator || parent2.kind !== 266 /* ModuleDeclaration */ && parent2.kind !== 204 /* ImportType */;
+      resultHasExternalModuleIndicator = resultHasExternalModuleIndicator || parent2.kind !== 267 /* ModuleDeclaration */ && parent2.kind !== 205 /* ImportType */;
       if (isStringLiteralLike(input)) {
         if (isBundledEmit) {
           const newName = getExternalModuleNameFromDeclaration(context.getEmitHost(), resolver, parent2);
@@ -207788,7 +193104,7 @@ ${lanes.join("\n")}
     function transformImportEqualsDeclaration(decl) {
       if (!resolver.isDeclarationVisible(decl))
         return;
-      if (decl.moduleReference.kind === 282 /* ExternalModuleReference */) {
+      if (decl.moduleReference.kind === 283 /* ExternalModuleReference */) {
         const specifier = getExternalModuleImportEqualsDeclarationExpression(decl);
         return factory2.updateImportEqualsDeclaration(
           decl,
@@ -207812,30 +193128,42 @@ ${lanes.join("\n")}
           decl.modifiers,
           decl.importClause,
           rewriteModuleSpecifier(decl, decl.moduleSpecifier),
-          getResolutionModeOverrideForClauseInNightly(decl.assertClause)
+          tryGetResolutionModeOverride(decl.attributes)
         );
       }
       const visibleDefaultBinding = decl.importClause && decl.importClause.name && resolver.isDeclarationVisible(decl.importClause) ? decl.importClause.name : void 0;
       if (!decl.importClause.namedBindings) {
-        return visibleDefaultBinding && factory2.updateImportDeclaration(decl, decl.modifiers, factory2.updateImportClause(
-          decl.importClause,
-          decl.importClause.isTypeOnly,
-          visibleDefaultBinding,
-          /*namedBindings*/
-          void 0
-        ), rewriteModuleSpecifier(decl, decl.moduleSpecifier), getResolutionModeOverrideForClauseInNightly(decl.assertClause));
+        return visibleDefaultBinding && factory2.updateImportDeclaration(
+          decl,
+          decl.modifiers,
+          factory2.updateImportClause(
+            decl.importClause,
+            decl.importClause.isTypeOnly,
+            visibleDefaultBinding,
+            /*namedBindings*/
+            void 0
+          ),
+          rewriteModuleSpecifier(decl, decl.moduleSpecifier),
+          tryGetResolutionModeOverride(decl.attributes)
+        );
       }
-      if (decl.importClause.namedBindings.kind === 273 /* NamespaceImport */) {
+      if (decl.importClause.namedBindings.kind === 274 /* NamespaceImport */) {
         const namedBindings = resolver.isDeclarationVisible(decl.importClause.namedBindings) ? decl.importClause.namedBindings : (
           /*namedBindings*/
           void 0
         );
-        return visibleDefaultBinding || namedBindings ? factory2.updateImportDeclaration(decl, decl.modifiers, factory2.updateImportClause(
-          decl.importClause,
-          decl.importClause.isTypeOnly,
-          visibleDefaultBinding,
-          namedBindings
-        ), rewriteModuleSpecifier(decl, decl.moduleSpecifier), getResolutionModeOverrideForClauseInNightly(decl.assertClause)) : void 0;
+        return visibleDefaultBinding || namedBindings ? factory2.updateImportDeclaration(
+          decl,
+          decl.modifiers,
+          factory2.updateImportClause(
+            decl.importClause,
+            decl.importClause.isTypeOnly,
+            visibleDefaultBinding,
+            namedBindings
+          ),
+          rewriteModuleSpecifier(decl, decl.moduleSpecifier),
+          tryGetResolutionModeOverride(decl.attributes)
+        ) : void 0;
       }
       const bindingList = mapDefined(decl.importClause.namedBindings.elements, (b) => resolver.isDeclarationVisible(b) ? b : void 0);
       if (bindingList && bindingList.length || visibleDefaultBinding) {
@@ -207849,7 +193177,7 @@ ${lanes.join("\n")}
             bindingList && bindingList.length ? factory2.updateNamedImports(decl.importClause.namedBindings, bindingList) : void 0
           ),
           rewriteModuleSpecifier(decl, decl.moduleSpecifier),
-          getResolutionModeOverrideForClauseInNightly(decl.assertClause)
+          tryGetResolutionModeOverride(decl.attributes)
         );
       }
       if (resolver.isImportRequiredByAugmentation(decl)) {
@@ -207859,19 +193187,13 @@ ${lanes.join("\n")}
           /*importClause*/
           void 0,
           rewriteModuleSpecifier(decl, decl.moduleSpecifier),
-          getResolutionModeOverrideForClauseInNightly(decl.assertClause)
+          tryGetResolutionModeOverride(decl.attributes)
         );
       }
     }
-    function getResolutionModeOverrideForClauseInNightly(assertClause) {
-      const mode = getResolutionModeOverrideForClause(assertClause);
-      if (mode !== void 0) {
-        if (!isNightly()) {
-          context.addDiagnostic(createDiagnosticForNode(assertClause, Diagnostics.resolution_mode_assertions_are_unstable_Use_nightly_TypeScript_to_silence_this_error_Try_updating_with_npm_install_D_typescript_next));
-        }
-        return assertClause;
-      }
-      return void 0;
+    function tryGetResolutionModeOverride(node) {
+      const mode = getResolutionModeOverride(node);
+      return node && mode !== void 0 ? node : void 0;
     }
     function transformAndReplaceLatePaintedStatements(statements) {
       while (length(lateMarkedStatements)) {
@@ -207928,9 +193250,9 @@ ${lanes.join("\n")}
       const oldDiag = getSymbolAccessibilityDiagnostic;
       const canProduceDiagnostic = canProduceDiagnostics(input);
       const oldWithinObjectLiteralType = suppressNewDiagnosticContexts;
-      let shouldEnterSuppressNewDiagnosticsContextContext = (input.kind === 186 /* TypeLiteral */ || input.kind === 199 /* MappedType */) && input.parent.kind !== 264 /* TypeAliasDeclaration */;
+      let shouldEnterSuppressNewDiagnosticsContextContext = (input.kind === 187 /* TypeLiteral */ || input.kind === 200 /* MappedType */) && input.parent.kind !== 265 /* TypeAliasDeclaration */;
       if (isMethodDeclaration(input) || isMethodSignature(input)) {
-        if (hasEffectiveModifier(input, 8 /* Private */)) {
+        if (hasEffectiveModifier(input, 2 /* Private */)) {
           if (input.symbol && input.symbol.declarations && input.symbol.declarations[0] !== input)
             return;
           return cleanup(factory2.createPropertyDeclaration(
@@ -207956,26 +193278,26 @@ ${lanes.join("\n")}
       }
       if (isProcessedComponent(input)) {
         switch (input.kind) {
-          case 232 /* ExpressionWithTypeArguments */: {
+          case 233 /* ExpressionWithTypeArguments */: {
             if (isEntityName(input.expression) || isEntityNameExpression(input.expression)) {
               checkEntityNameVisibility(input.expression, enclosingDeclaration);
             }
             const node = visitEachChild(input, visitDeclarationSubtree, context);
             return cleanup(factory2.updateExpressionWithTypeArguments(node, node.expression, node.typeArguments));
           }
-          case 182 /* TypeReference */: {
+          case 183 /* TypeReference */: {
             checkEntityNameVisibility(input.typeName, enclosingDeclaration);
             const node = visitEachChild(input, visitDeclarationSubtree, context);
             return cleanup(factory2.updateTypeReferenceNode(node, node.typeName, node.typeArguments));
           }
-          case 179 /* ConstructSignature */:
+          case 180 /* ConstructSignature */:
             return cleanup(factory2.updateConstructSignature(
               input,
               ensureTypeParams(input, input.typeParameters),
               updateParamsList(input, input.parameters),
               ensureType(input, input.type)
             ));
-          case 175 /* Constructor */: {
+          case 176 /* Constructor */: {
             const ctor = factory2.createConstructorDeclaration(
               /*modifiers*/
               ensureModifiers(input),
@@ -207985,7 +193307,7 @@ ${lanes.join("\n")}
             );
             return cleanup(ctor);
           }
-          case 173 /* MethodDeclaration */: {
+          case 174 /* MethodDeclaration */: {
             if (isPrivateIdentifier(input.name)) {
               return cleanup(
                 /*returnValue*/
@@ -208006,7 +193328,7 @@ ${lanes.join("\n")}
             );
             return cleanup(sig);
           }
-          case 176 /* GetAccessor */: {
+          case 177 /* GetAccessor */: {
             if (isPrivateIdentifier(input.name)) {
               return cleanup(
                 /*returnValue*/
@@ -208018,13 +193340,13 @@ ${lanes.join("\n")}
               input,
               ensureModifiers(input),
               input.name,
-              updateAccessorParamsList(input, hasEffectiveModifier(input, 8 /* Private */)),
+              updateAccessorParamsList(input, hasEffectiveModifier(input, 2 /* Private */)),
               ensureType(input, accessorType),
               /*body*/
               void 0
             ));
           }
-          case 177 /* SetAccessor */: {
+          case 178 /* SetAccessor */: {
             if (isPrivateIdentifier(input.name)) {
               return cleanup(
                 /*returnValue*/
@@ -208035,12 +193357,12 @@ ${lanes.join("\n")}
               input,
               ensureModifiers(input),
               input.name,
-              updateAccessorParamsList(input, hasEffectiveModifier(input, 8 /* Private */)),
+              updateAccessorParamsList(input, hasEffectiveModifier(input, 2 /* Private */)),
               /*body*/
               void 0
             ));
           }
-          case 171 /* PropertyDeclaration */:
+          case 172 /* PropertyDeclaration */:
             if (isPrivateIdentifier(input.name)) {
               return cleanup(
                 /*returnValue*/
@@ -208055,7 +193377,7 @@ ${lanes.join("\n")}
               ensureType(input, input.type),
               ensureNoInitializer(input)
             ));
-          case 170 /* PropertySignature */:
+          case 171 /* PropertySignature */:
             if (isPrivateIdentifier(input.name)) {
               return cleanup(
                 /*returnValue*/
@@ -208069,7 +193391,7 @@ ${lanes.join("\n")}
               input.questionToken,
               ensureType(input, input.type)
             ));
-          case 172 /* MethodSignature */: {
+          case 173 /* MethodSignature */: {
             if (isPrivateIdentifier(input.name)) {
               return cleanup(
                 /*returnValue*/
@@ -208086,7 +193408,7 @@ ${lanes.join("\n")}
               ensureType(input, input.type)
             ));
           }
-          case 178 /* CallSignature */: {
+          case 179 /* CallSignature */: {
             return cleanup(factory2.updateCallSignature(
               input,
               ensureTypeParams(input, input.typeParameters),
@@ -208094,7 +193416,7 @@ ${lanes.join("\n")}
               ensureType(input, input.type)
             ));
           }
-          case 180 /* IndexSignature */: {
+          case 181 /* IndexSignature */: {
             return cleanup(factory2.updateIndexSignature(
               input,
               ensureModifiers(input),
@@ -208102,7 +193424,7 @@ ${lanes.join("\n")}
               visitNode(input.type, visitDeclarationSubtree, isTypeNode) || factory2.createKeywordTypeNode(133 /* AnyKeyword */)
             ));
           }
-          case 259 /* VariableDeclaration */: {
+          case 260 /* VariableDeclaration */: {
             if (isBindingPattern(input.name)) {
               return recreateBindingPattern(input.name);
             }
@@ -208117,7 +193439,7 @@ ${lanes.join("\n")}
               ensureNoInitializer(input)
             ));
           }
-          case 167 /* TypeParameter */: {
+          case 168 /* TypeParameter */: {
             if (isPrivateMethodTypeParameter(input) && (input.default || input.constraint)) {
               return cleanup(factory2.updateTypeParameterDeclaration(
                 input,
@@ -208131,7 +193453,7 @@ ${lanes.join("\n")}
             }
             return cleanup(visitEachChild(input, visitDeclarationSubtree, context));
           }
-          case 193 /* ConditionalType */: {
+          case 194 /* ConditionalType */: {
             const checkType = visitNode(input.checkType, visitDeclarationSubtree, isTypeNode);
             const extendsType = visitNode(input.extendsType, visitDeclarationSubtree, isTypeNode);
             const oldEnclosingDecl = enclosingDeclaration;
@@ -208145,19 +193467,20 @@ ${lanes.join("\n")}
             Debug.assert(falseType);
             return cleanup(factory2.updateConditionalTypeNode(input, checkType, extendsType, trueType, falseType));
           }
-          case 183 /* FunctionType */: {
+          case 184 /* FunctionType */: {
             return cleanup(factory2.updateFunctionTypeNode(input, visitNodes2(input.typeParameters, visitDeclarationSubtree, isTypeParameterDeclaration), updateParamsList(input, input.parameters), Debug.checkDefined(visitNode(input.type, visitDeclarationSubtree, isTypeNode))));
           }
-          case 184 /* ConstructorType */: {
+          case 185 /* ConstructorType */: {
             return cleanup(factory2.updateConstructorTypeNode(input, ensureModifiers(input), visitNodes2(input.typeParameters, visitDeclarationSubtree, isTypeParameterDeclaration), updateParamsList(input, input.parameters), Debug.checkDefined(visitNode(input.type, visitDeclarationSubtree, isTypeNode))));
           }
-          case 204 /* ImportType */: {
+          case 205 /* ImportType */: {
             if (!isLiteralImportTypeNode(input))
               return cleanup(input);
+            trackReferencedAmbientModuleFromImport(input);
             return cleanup(factory2.updateImportTypeNode(
               input,
               factory2.updateLiteralTypeNode(input.argument, rewriteModuleSpecifier(input, input.argument.literal)),
-              input.assertions,
+              input.attributes,
               input.qualifier,
               visitNodes2(input.typeArguments, visitDeclarationSubtree, isTypeNode),
               input.isTypeOf
@@ -208191,7 +193514,7 @@ ${lanes.join("\n")}
       }
     }
     function isPrivateMethodTypeParameter(node) {
-      return node.parent.kind === 173 /* MethodDeclaration */ && hasEffectiveModifier(node.parent, 8 /* Private */);
+      return node.parent.kind === 174 /* MethodDeclaration */ && hasEffectiveModifier(node.parent, 2 /* Private */);
     }
     function visitDeclarationStatements(input) {
       if (!isPreservedDeclarationStatement(input)) {
@@ -208200,21 +193523,22 @@ ${lanes.join("\n")}
       if (shouldStripInternal(input))
         return;
       switch (input.kind) {
-        case 277 /* ExportDeclaration */: {
+        case 278 /* ExportDeclaration */: {
           if (isSourceFile(input.parent)) {
             resultHasExternalModuleIndicator = true;
           }
           resultHasScopeMarker = true;
+          trackReferencedAmbientModuleFromImport(input);
           return factory2.updateExportDeclaration(
             input,
             input.modifiers,
             input.isTypeOnly,
             input.exportClause,
             rewriteModuleSpecifier(input, input.moduleSpecifier),
-            getResolutionModeOverrideForClause(input.assertClause) ? input.assertClause : void 0
+            tryGetResolutionModeOverride(input.attributes)
           );
         }
-        case 276 /* ExportAssignment */: {
+        case 277 /* ExportAssignment */: {
           if (isSourceFile(input.parent)) {
             resultHasExternalModuleIndicator = true;
           }
@@ -208249,11 +193573,26 @@ ${lanes.join("\n")}
       return input;
     }
     function stripExportModifiers(statement) {
-      if (isImportEqualsDeclaration(statement) || hasEffectiveModifier(statement, 1024 /* Default */) || !canHaveModifiers(statement)) {
+      if (isImportEqualsDeclaration(statement) || hasEffectiveModifier(statement, 2048 /* Default */) || !canHaveModifiers(statement)) {
         return statement;
       }
-      const modifiers = factory2.createModifiersFromModifierFlags(getEffectiveModifierFlags(statement) & (258047 /* All */ ^ 1 /* Export */));
-      return factory2.updateModifiers(statement, modifiers);
+      const modifiers = factory2.createModifiersFromModifierFlags(getEffectiveModifierFlags(statement) & (131071 /* All */ ^ 32 /* Export */));
+      return factory2.replaceModifiers(statement, modifiers);
+    }
+    function updateModuleDeclarationAndKeyword(node, modifiers, name, body) {
+      const updated = factory2.updateModuleDeclaration(node, modifiers, name, body);
+      if (isAmbientModule(updated) || updated.flags & 32 /* Namespace */) {
+        return updated;
+      }
+      const fixed = factory2.createModuleDeclaration(
+        updated.modifiers,
+        updated.name,
+        updated.body,
+        updated.flags | 32 /* Namespace */
+      );
+      setOriginalNode(fixed, updated);
+      setTextRange(fixed, updated);
+      return fixed;
     }
     function transformTopLevelDeclaration(input) {
       if (lateMarkedStatements) {
@@ -208263,11 +193602,19 @@ ${lanes.join("\n")}
       if (shouldStripInternal(input))
         return;
       switch (input.kind) {
-        case 270 /* ImportEqualsDeclaration */: {
-          return transformImportEqualsDeclaration(input);
+        case 271 /* ImportEqualsDeclaration */: {
+          const transformed = transformImportEqualsDeclaration(input);
+          if (transformed) {
+            trackReferencedAmbientModuleFromImport(input);
+          }
+          return transformed;
         }
-        case 271 /* ImportDeclaration */: {
-          return transformImportDeclaration(input);
+        case 272 /* ImportDeclaration */: {
+          const transformed = transformImportDeclaration(input);
+          if (transformed) {
+            trackReferencedAmbientModuleFromImport(input);
+          }
+          return transformed;
         }
       }
       if (isDeclaration(input) && isDeclarationAndNotVisible(input))
@@ -208286,7 +193633,7 @@ ${lanes.join("\n")}
       }
       const previousNeedsDeclare = needsDeclare;
       switch (input.kind) {
-        case 264 /* TypeAliasDeclaration */: {
+        case 265 /* TypeAliasDeclaration */: {
           needsDeclare = false;
           const clean2 = cleanup(factory2.updateTypeAliasDeclaration(
             input,
@@ -208298,7 +193645,7 @@ ${lanes.join("\n")}
           needsDeclare = previousNeedsDeclare;
           return clean2;
         }
-        case 263 /* InterfaceDeclaration */: {
+        case 264 /* InterfaceDeclaration */: {
           return cleanup(factory2.updateInterfaceDeclaration(
             input,
             ensureModifiers(input),
@@ -208308,7 +193655,7 @@ ${lanes.join("\n")}
             visitNodes2(input.members, visitDeclarationSubtree, isTypeElement)
           ));
         }
-        case 261 /* FunctionDeclaration */: {
+        case 262 /* FunctionDeclaration */: {
           const clean2 = cleanup(factory2.updateFunctionDeclaration(
             input,
             ensureModifiers(input),
@@ -208328,14 +193675,14 @@ ${lanes.join("\n")}
               void 0,
               clean2.name || factory2.createIdentifier("_default"),
               factory2.createModuleBlock([]),
-              16 /* Namespace */
+              32 /* Namespace */
             );
             setParent(fakespace, enclosingDeclaration);
             fakespace.locals = createSymbolTable(props);
             fakespace.symbol = props[0].parent;
             const exportMappings = [];
             let declarations = mapDefined(props, (p) => {
-              if (!p.valueDeclaration || !(isPropertyAccessExpression(p.valueDeclaration) || isElementAccessExpression(p.valueDeclaration) || isBinaryExpression(p.valueDeclaration))) {
+              if (!isExpandoPropertyDeclaration(p.valueDeclaration)) {
                 return void 0;
               }
               const nameStr = unescapeLeadingUnderscores(p.escapedName);
@@ -208361,7 +193708,7 @@ ${lanes.join("\n")}
               return factory2.createVariableStatement(isNonContextualKeywordName ? void 0 : [factory2.createToken(95 /* ExportKeyword */)], factory2.createVariableDeclarationList([varDecl]));
             });
             if (!exportMappings.length) {
-              declarations = mapDefined(declarations, (declaration) => factory2.updateModifiers(declaration, 0 /* None */));
+              declarations = mapDefined(declarations, (declaration) => factory2.replaceModifiers(declaration, 0 /* None */));
             } else {
               declarations.push(factory2.createExportDeclaration(
                 /*modifiers*/
@@ -208378,11 +193725,11 @@ ${lanes.join("\n")}
                 }))
               ));
             }
-            const namespaceDecl = factory2.createModuleDeclaration(ensureModifiers(input), input.name, factory2.createModuleBlock(declarations), 16 /* Namespace */);
-            if (!hasEffectiveModifier(clean2, 1024 /* Default */)) {
+            const namespaceDecl = factory2.createModuleDeclaration(ensureModifiers(input), input.name, factory2.createModuleBlock(declarations), 32 /* Namespace */);
+            if (!hasEffectiveModifier(clean2, 2048 /* Default */)) {
               return [clean2, namespaceDecl];
             }
-            const modifiers = factory2.createModifiersFromModifierFlags(getEffectiveModifierFlags(clean2) & ~1025 /* ExportDefault */ | 2 /* Ambient */);
+            const modifiers = factory2.createModifiersFromModifierFlags(getEffectiveModifierFlags(clean2) & ~2080 /* ExportDefault */ | 128 /* Ambient */);
             const cleanDeclaration = factory2.updateFunctionDeclaration(
               clean2,
               modifiers,
@@ -208417,17 +193764,17 @@ ${lanes.join("\n")}
             return clean2;
           }
         }
-        case 266 /* ModuleDeclaration */: {
+        case 267 /* ModuleDeclaration */: {
           needsDeclare = false;
           const inner = input.body;
-          if (inner && inner.kind === 267 /* ModuleBlock */) {
+          if (inner && inner.kind === 268 /* ModuleBlock */) {
             const oldNeedsScopeFix = needsScopeFixMarker;
             const oldHasScopeFix = resultHasScopeMarker;
             resultHasScopeMarker = false;
             needsScopeFixMarker = false;
             const statements = visitNodes2(inner.statements, visitDeclarationStatements, isStatement);
             let lateStatements = transformAndReplaceLatePaintedStatements(statements);
-            if (input.flags & 16777216 /* Ambient */) {
+            if (input.flags & 33554432 /* Ambient */) {
               needsScopeFixMarker = false;
             }
             if (!isGlobalScopeAugmentation(input) && !hasScopeMarker2(lateStatements) && !resultHasScopeMarker) {
@@ -208442,7 +193789,7 @@ ${lanes.join("\n")}
             needsScopeFixMarker = oldNeedsScopeFix;
             resultHasScopeMarker = oldHasScopeFix;
             const mods = ensureModifiers(input);
-            return cleanup(factory2.updateModuleDeclaration(
+            return cleanup(updateModuleDeclarationAndKeyword(
               input,
               mods,
               isExternalModuleAugmentation(input) ? rewriteModuleSpecifier(input, input.name) : input.name,
@@ -208456,7 +193803,7 @@ ${lanes.join("\n")}
             const id = getOriginalNodeId(inner);
             const body = lateStatementReplacementMap.get(id);
             lateStatementReplacementMap.delete(id);
-            return cleanup(factory2.updateModuleDeclaration(
+            return cleanup(updateModuleDeclarationAndKeyword(
               input,
               mods,
               input.name,
@@ -208464,7 +193811,7 @@ ${lanes.join("\n")}
             ));
           }
         }
-        case 262 /* ClassDeclaration */: {
+        case 263 /* ClassDeclaration */: {
           errorNameNode = input.name;
           errorFallbackNode = input;
           const modifiers = factory2.createNodeArray(ensureModifiers(input));
@@ -208474,17 +193821,20 @@ ${lanes.join("\n")}
           if (ctor) {
             const oldDiag2 = getSymbolAccessibilityDiagnostic;
             parameterProperties = compact(flatMap(ctor.parameters, (param) => {
-              if (!hasSyntacticModifier(param, 16476 /* ParameterPropertyModifier */) || shouldStripInternal(param))
+              if (!hasSyntacticModifier(param, 31 /* ParameterPropertyModifier */) || shouldStripInternal(param))
                 return;
               getSymbolAccessibilityDiagnostic = createGetSymbolAccessibilityDiagnosticForNode(param);
               if (param.name.kind === 80 /* Identifier */) {
-                return preserveJsDoc(factory2.createPropertyDeclaration(
-                  ensureModifiers(param),
-                  param.name,
-                  param.questionToken,
-                  ensureType(param, param.type),
-                  ensureNoInitializer(param)
-                ), param);
+                return preserveJsDoc(
+                  factory2.createPropertyDeclaration(
+                    ensureModifiers(param),
+                    param.name,
+                    param.questionToken,
+                    ensureType(param, param.type),
+                    ensureNoInitializer(param)
+                  ),
+                  param
+                );
               } else {
                 return walkBindingPattern(param.name);
               }
@@ -208560,14 +193910,17 @@ ${lanes.join("\n")}
               }
               return factory2.updateHeritageClause(clause, visitNodes2(factory2.createNodeArray(filter(clause.types, (t) => isEntityNameExpression(t.expression) || t.expression.kind === 106 /* NullKeyword */)), visitDeclarationSubtree, isExpressionWithTypeArguments));
             }));
-            return [statement, cleanup(factory2.updateClassDeclaration(
-              input,
-              modifiers,
-              input.name,
-              typeParameters,
-              heritageClauses,
-              members
-            ))];
+            return [
+              statement,
+              cleanup(factory2.updateClassDeclaration(
+                input,
+                modifiers,
+                input.name,
+                typeParameters,
+                heritageClauses,
+                members
+              ))
+            ];
           } else {
             const heritageClauses = transformHeritageClauses(input.heritageClauses);
             return cleanup(factory2.updateClassDeclaration(
@@ -208580,16 +193933,21 @@ ${lanes.join("\n")}
             ));
           }
         }
-        case 242 /* VariableStatement */: {
+        case 243 /* VariableStatement */: {
           return cleanup(transformVariableStatement(input));
         }
-        case 265 /* EnumDeclaration */: {
-          return cleanup(factory2.updateEnumDeclaration(input, factory2.createNodeArray(ensureModifiers(input)), input.name, factory2.createNodeArray(mapDefined(input.members, (m) => {
-            if (shouldStripInternal(m))
-              return;
-            const constValue = resolver.getConstantValue(m);
-            return preserveJsDoc(factory2.updateEnumMember(m, m.name, constValue !== void 0 ? typeof constValue === "string" ? factory2.createStringLiteral(constValue) : factory2.createNumericLiteral(constValue) : void 0), m);
-          }))));
+        case 266 /* EnumDeclaration */: {
+          return cleanup(factory2.updateEnumDeclaration(
+            input,
+            factory2.createNodeArray(ensureModifiers(input)),
+            input.name,
+            factory2.createNodeArray(mapDefined(input.members, (m) => {
+              if (shouldStripInternal(m))
+                return;
+              const constValue = resolver.getConstantValue(m);
+              return preserveJsDoc(factory2.updateEnumMember(m, m.name, constValue !== void 0 ? typeof constValue === "string" ? factory2.createStringLiteral(constValue) : factory2.createNumericLiteral(constValue) : void 0), m);
+            }))
+          ));
         }
       }
       return Debug.assertNever(input, `Unhandled top-level node in declaration emit: ${Debug.formatSyntaxKind(input.kind)}`);
@@ -208600,7 +193958,7 @@ ${lanes.join("\n")}
         if (canProdiceDiagnostic) {
           getSymbolAccessibilityDiagnostic = oldDiag;
         }
-        if (input.kind === 266 /* ModuleDeclaration */) {
+        if (input.kind === 267 /* ModuleDeclaration */) {
           needsDeclare = previousNeedsDeclare;
         }
         if (node === input) {
@@ -208617,13 +193975,23 @@ ${lanes.join("\n")}
       const nodes = visitNodes2(input.declarationList.declarations, visitDeclarationSubtree, isVariableDeclaration);
       if (!length(nodes))
         return;
-      return factory2.updateVariableStatement(input, factory2.createNodeArray(ensureModifiers(input)), factory2.updateVariableDeclarationList(input.declarationList, nodes));
+      const modifiers = factory2.createNodeArray(ensureModifiers(input));
+      let declList;
+      if (isVarUsing(input.declarationList) || isVarAwaitUsing(input.declarationList)) {
+        declList = factory2.createVariableDeclarationList(nodes, 2 /* Const */);
+        setOriginalNode(declList, input.declarationList);
+        setTextRange(declList, input.declarationList);
+        setCommentRange(declList, input.declarationList);
+      } else {
+        declList = factory2.updateVariableDeclarationList(input.declarationList, nodes);
+      }
+      return factory2.updateVariableStatement(input, modifiers, declList);
     }
     function recreateBindingPattern(d) {
       return flatten(mapDefined(d.elements, (e) => recreateBindingElement(e)));
     }
     function recreateBindingElement(e) {
-      if (e.kind === 231 /* OmittedExpression */) {
+      if (e.kind === 232 /* OmittedExpression */) {
         return;
       }
       if (e.name) {
@@ -208681,11 +194049,11 @@ ${lanes.join("\n")}
       return factory2.createModifiersFromModifierFlags(newFlags);
     }
     function ensureModifierFlags(node) {
-      let mask2 = 258047 /* All */ ^ (4 /* Public */ | 512 /* Async */ | 16384 /* Override */);
-      let additions = needsDeclare && !isAlwaysType(node) ? 2 /* Ambient */ : 0 /* None */;
-      const parentIsFile = node.parent.kind === 311 /* SourceFile */;
+      let mask2 = 131071 /* All */ ^ (1 /* Public */ | 1024 /* Async */ | 16 /* Override */);
+      let additions = needsDeclare && !isAlwaysType(node) ? 128 /* Ambient */ : 0 /* None */;
+      const parentIsFile = node.parent.kind === 312 /* SourceFile */;
       if (!parentIsFile || isBundledEmit && parentIsFile && isExternalModule(node.parent)) {
-        mask2 ^= 2 /* Ambient */;
+        mask2 ^= 128 /* Ambient */;
         additions = 0 /* None */;
       }
       return maskModifierFlags(node, mask2, additions);
@@ -208703,13 +194071,23 @@ ${lanes.join("\n")}
       return accessorType;
     }
     function transformHeritageClauses(nodes) {
-      return factory2.createNodeArray(filter(map(nodes, (clause) => factory2.updateHeritageClause(clause, visitNodes2(factory2.createNodeArray(filter(clause.types, (t) => {
-        return isEntityNameExpression(t.expression) || clause.token === 96 /* ExtendsKeyword */ && t.expression.kind === 106 /* NullKeyword */;
-      })), visitDeclarationSubtree, isExpressionWithTypeArguments))), (clause) => clause.types && !!clause.types.length));
+      return factory2.createNodeArray(filter(
+        map(nodes, (clause) => factory2.updateHeritageClause(
+          clause,
+          visitNodes2(
+            factory2.createNodeArray(filter(clause.types, (t) => {
+              return isEntityNameExpression(t.expression) || clause.token === 96 /* ExtendsKeyword */ && t.expression.kind === 106 /* NullKeyword */;
+            })),
+            visitDeclarationSubtree,
+            isExpressionWithTypeArguments
+          )
+        )),
+        (clause) => clause.types && !!clause.types.length
+      ));
     }
   }
   function isAlwaysType(node) {
-    if (node.kind === 263 /* InterfaceDeclaration */) {
+    if (node.kind === 264 /* InterfaceDeclaration */) {
       return true;
     }
     return false;
@@ -208717,69 +194095,69 @@ ${lanes.join("\n")}
   function maskModifiers(factory2, node, modifierMask, modifierAdditions) {
     return factory2.createModifiersFromModifierFlags(maskModifierFlags(node, modifierMask, modifierAdditions));
   }
-  function maskModifierFlags(node, modifierMask = 258047 /* All */ ^ 4 /* Public */, modifierAdditions = 0 /* None */) {
+  function maskModifierFlags(node, modifierMask = 131071 /* All */ ^ 1 /* Public */, modifierAdditions = 0 /* None */) {
     let flags = getEffectiveModifierFlags(node) & modifierMask | modifierAdditions;
-    if (flags & 1024 /* Default */ && !(flags & 1 /* Export */)) {
-      flags ^= 1 /* Export */;
+    if (flags & 2048 /* Default */ && !(flags & 32 /* Export */)) {
+      flags ^= 32 /* Export */;
     }
-    if (flags & 1024 /* Default */ && flags & 2 /* Ambient */) {
-      flags ^= 2 /* Ambient */;
+    if (flags & 2048 /* Default */ && flags & 128 /* Ambient */) {
+      flags ^= 128 /* Ambient */;
     }
     return flags;
   }
   function getTypeAnnotationFromAccessor(accessor) {
     if (accessor) {
-      return accessor.kind === 176 /* GetAccessor */ ? accessor.type : accessor.parameters.length > 0 ? accessor.parameters[0].type : void 0;
+      return accessor.kind === 177 /* GetAccessor */ ? accessor.type : accessor.parameters.length > 0 ? accessor.parameters[0].type : void 0;
     }
   }
   function canHaveLiteralInitializer(node) {
     switch (node.kind) {
-      case 171 /* PropertyDeclaration */:
-      case 170 /* PropertySignature */:
-        return !hasEffectiveModifier(node, 8 /* Private */);
-      case 168 /* Parameter */:
-      case 259 /* VariableDeclaration */:
+      case 172 /* PropertyDeclaration */:
+      case 171 /* PropertySignature */:
+        return !hasEffectiveModifier(node, 2 /* Private */);
+      case 169 /* Parameter */:
+      case 260 /* VariableDeclaration */:
         return true;
     }
     return false;
   }
   function isPreservedDeclarationStatement(node) {
     switch (node.kind) {
-      case 261 /* FunctionDeclaration */:
-      case 266 /* ModuleDeclaration */:
-      case 270 /* ImportEqualsDeclaration */:
-      case 263 /* InterfaceDeclaration */:
-      case 262 /* ClassDeclaration */:
-      case 264 /* TypeAliasDeclaration */:
-      case 265 /* EnumDeclaration */:
-      case 242 /* VariableStatement */:
-      case 271 /* ImportDeclaration */:
-      case 277 /* ExportDeclaration */:
-      case 276 /* ExportAssignment */:
+      case 262 /* FunctionDeclaration */:
+      case 267 /* ModuleDeclaration */:
+      case 271 /* ImportEqualsDeclaration */:
+      case 264 /* InterfaceDeclaration */:
+      case 263 /* ClassDeclaration */:
+      case 265 /* TypeAliasDeclaration */:
+      case 266 /* EnumDeclaration */:
+      case 243 /* VariableStatement */:
+      case 272 /* ImportDeclaration */:
+      case 278 /* ExportDeclaration */:
+      case 277 /* ExportAssignment */:
         return true;
     }
     return false;
   }
   function isProcessedComponent(node) {
     switch (node.kind) {
-      case 179 /* ConstructSignature */:
-      case 175 /* Constructor */:
-      case 173 /* MethodDeclaration */:
-      case 176 /* GetAccessor */:
-      case 177 /* SetAccessor */:
-      case 171 /* PropertyDeclaration */:
-      case 170 /* PropertySignature */:
-      case 172 /* MethodSignature */:
-      case 178 /* CallSignature */:
-      case 180 /* IndexSignature */:
-      case 259 /* VariableDeclaration */:
-      case 167 /* TypeParameter */:
-      case 232 /* ExpressionWithTypeArguments */:
-      case 182 /* TypeReference */:
-      case 193 /* ConditionalType */:
-      case 183 /* FunctionType */:
-      case 184 /* ConstructorType */:
-      case 204 /* ImportType */:
+      case 180 /* ConstructSignature */:
+      case 176 /* Constructor */:
+      case 174 /* MethodDeclaration */:
+      case 177 /* GetAccessor */:
+      case 178 /* SetAccessor */:
+      case 172 /* PropertyDeclaration */:
+      case 171 /* PropertySignature */:
+      case 173 /* MethodSignature */:
+      case 179 /* CallSignature */:
+      case 181 /* IndexSignature */:
+      case 260 /* VariableDeclaration */:
+      case 168 /* TypeParameter */:
+      case 233 /* ExpressionWithTypeArguments */:
+      case 183 /* TypeReference */:
+      case 194 /* ConditionalType */:
+      case 184 /* FunctionType */:
+      case 185 /* ConstructorType */:
+      case 205 /* ImportType */:
         return true;
     }
     return false;
@@ -208828,16 +194206,17 @@ ${lanes.join("\n")}
     transformers.push(transformTypeScript);
     if (compilerOptions.experimentalDecorators) {
       transformers.push(transformLegacyDecorators);
-    } else if (languageVersion < 99 /* ESNext */ || !useDefineForClassFields) {
-      transformers.push(transformESDecorators);
     }
-    transformers.push(transformClassFields);
     if (getJSXTransformEnabled(compilerOptions)) {
       transformers.push(transformJsx);
     }
     if (languageVersion < 99 /* ESNext */) {
       transformers.push(transformESNext);
     }
+    if (!compilerOptions.experimentalDecorators && (languageVersion < 99 /* ESNext */ || !useDefineForClassFields)) {
+      transformers.push(transformESDecorators);
+    }
+    transformers.push(transformClassFields);
     if (languageVersion < 8 /* ES2021 */) {
       transformers.push(transformES2021);
     }
@@ -208896,7 +194275,7 @@ ${lanes.join("\n")}
   }
   function transformNodes(resolver, host, factory2, options, nodes, transformers, allowDtsFiles) {
     var _a, _b;
-    const enabledSyntaxKindFeatures = new Array(362 /* Count */);
+    const enabledSyntaxKindFeatures = new Array(363 /* Count */);
     let lexicalEnvironmentVariableDeclarations;
     let lexicalEnvironmentFunctionDeclarations;
     let lexicalEnvironmentStatements;
@@ -208975,7 +194354,7 @@ ${lanes.join("\n")}
     state = 1 /* Initialized */;
     const transformed = [];
     for (const node of nodes) {
-      (_a = tracing) == null ? void 0 : _a.push(tracing.Phase.Emit, "transformNodes", node.kind === 311 /* SourceFile */ ? { path: node.path } : { kind: node.kind, pos: node.pos, end: node.end });
+      (_a = tracing) == null ? void 0 : _a.push(tracing.Phase.Emit, "transformNodes", node.kind === 312 /* SourceFile */ ? { path: node.path } : { kind: node.kind, pos: node.pos, end: node.end });
       transformed.push((allowDtsFiles ? transformation : transformRoot)(node));
       (_b = tracing) == null ? void 0 : _b.pop();
     }
@@ -209303,7 +194682,7 @@ ${lanes.join("\n")}
   }
   function getOutputPathsFor(sourceFile, host, forceDtsPaths) {
     const options = host.getCompilerOptions();
-    if (sourceFile.kind === 312 /* Bundle */) {
+    if (sourceFile.kind === 313 /* Bundle */) {
       return getOutputPathsForBundle(options, forceDtsPaths);
     } else {
       const ownOutputFilePath = getOwnEmitOutputFilePath(sourceFile.fileName, host, getOutputExtension(sourceFile.fileName, options));
@@ -209639,6 +195018,7 @@ ${lanes.join("\n")}
         inlineSourceMap: compilerOptions.inlineSourceMap,
         extendedDiagnostics: compilerOptions.extendedDiagnostics,
         onlyPrintJsDocStyle: true,
+        omitBraceSourceMapPositions: true,
         writeBundleFileInfo: !!bundleBuildInfo,
         recordInternalSection: !!bundleBuildInfo,
         relativeToBuildInfo
@@ -209695,8 +195075,8 @@ ${lanes.join("\n")}
     }
     function printSourceFileOrBundle(jsFilePath, sourceMapFilePath, transform2, printer, mapOptions) {
       const sourceFileOrBundle = transform2.transformed[0];
-      const bundle = sourceFileOrBundle.kind === 312 /* Bundle */ ? sourceFileOrBundle : void 0;
-      const sourceFile = sourceFileOrBundle.kind === 311 /* SourceFile */ ? sourceFileOrBundle : void 0;
+      const bundle = sourceFileOrBundle.kind === 313 /* Bundle */ ? sourceFileOrBundle : void 0;
+      const sourceFile = sourceFileOrBundle.kind === 312 /* SourceFile */ ? sourceFileOrBundle : void 0;
       const sourceFiles = bundle ? bundle.sourceFiles : [sourceFile];
       let sourceMapGenerator;
       if (shouldEmitSourceMaps(mapOptions, sourceFileOrBundle)) {
@@ -209758,7 +195138,7 @@ ${lanes.join("\n")}
       writer.clear();
     }
     function shouldEmitSourceMaps(mapOptions, sourceFileOrBundle) {
-      return (mapOptions.sourceMap || mapOptions.inlineSourceMap) && (sourceFileOrBundle.kind !== 311 /* SourceFile */ || !fileExtensionIs(sourceFileOrBundle.fileName, ".json" /* Json */));
+      return (mapOptions.sourceMap || mapOptions.inlineSourceMap) && (sourceFileOrBundle.kind !== 312 /* SourceFile */ || !fileExtensionIs(sourceFileOrBundle.fileName, ".json" /* Json */));
     }
     function getSourceRoot(mapOptions) {
       const sourceRoot = normalizeSlashes(mapOptions.sourceRoot || "");
@@ -210001,6 +195381,7 @@ ${lanes.join("\n")}
       onAfterEmitToken
     } = handlers;
     var extendedDiagnostics = !!printerOptions.extendedDiagnostics;
+    var omitBraceSourcePositions = !!printerOptions.omitBraceSourceMapPositions;
     var newLine = getNewLineCharacter(printerOptions);
     var moduleKind = getEmitModuleKind(printerOptions);
     var bundledHelpers = /* @__PURE__ */ new Map();
@@ -210078,11 +195459,11 @@ ${lanes.join("\n")}
           break;
       }
       switch (node.kind) {
-        case 311 /* SourceFile */:
+        case 312 /* SourceFile */:
           return printFile(node);
-        case 312 /* Bundle */:
+        case 313 /* Bundle */:
           return printBundle(node);
-        case 313 /* UnparsedSource */:
+        case 314 /* UnparsedSource */:
           return printUnparsedSource(node);
       }
       writeNode(hint, node, sourceFile, beginPrint());
@@ -210461,301 +195842,301 @@ ${lanes.join("\n")}
             return emitIdentifier(node);
           case 81 /* PrivateIdentifier */:
             return emitPrivateIdentifier(node);
-          case 165 /* QualifiedName */:
+          case 166 /* QualifiedName */:
             return emitQualifiedName(node);
-          case 166 /* ComputedPropertyName */:
+          case 167 /* ComputedPropertyName */:
             return emitComputedPropertyName(node);
-          case 167 /* TypeParameter */:
+          case 168 /* TypeParameter */:
             return emitTypeParameter(node);
-          case 168 /* Parameter */:
+          case 169 /* Parameter */:
             return emitParameter(node);
-          case 169 /* Decorator */:
+          case 170 /* Decorator */:
             return emitDecorator(node);
-          case 170 /* PropertySignature */:
+          case 171 /* PropertySignature */:
             return emitPropertySignature(node);
-          case 171 /* PropertyDeclaration */:
+          case 172 /* PropertyDeclaration */:
             return emitPropertyDeclaration(node);
-          case 172 /* MethodSignature */:
+          case 173 /* MethodSignature */:
             return emitMethodSignature(node);
-          case 173 /* MethodDeclaration */:
+          case 174 /* MethodDeclaration */:
             return emitMethodDeclaration(node);
-          case 174 /* ClassStaticBlockDeclaration */:
+          case 175 /* ClassStaticBlockDeclaration */:
             return emitClassStaticBlockDeclaration(node);
-          case 175 /* Constructor */:
+          case 176 /* Constructor */:
             return emitConstructor(node);
-          case 176 /* GetAccessor */:
-          case 177 /* SetAccessor */:
+          case 177 /* GetAccessor */:
+          case 178 /* SetAccessor */:
             return emitAccessorDeclaration(node);
-          case 178 /* CallSignature */:
+          case 179 /* CallSignature */:
             return emitCallSignature(node);
-          case 179 /* ConstructSignature */:
+          case 180 /* ConstructSignature */:
             return emitConstructSignature(node);
-          case 180 /* IndexSignature */:
+          case 181 /* IndexSignature */:
             return emitIndexSignature(node);
-          case 181 /* TypePredicate */:
+          case 182 /* TypePredicate */:
             return emitTypePredicate(node);
-          case 182 /* TypeReference */:
+          case 183 /* TypeReference */:
             return emitTypeReference(node);
-          case 183 /* FunctionType */:
+          case 184 /* FunctionType */:
             return emitFunctionType(node);
-          case 184 /* ConstructorType */:
+          case 185 /* ConstructorType */:
             return emitConstructorType(node);
-          case 185 /* TypeQuery */:
+          case 186 /* TypeQuery */:
             return emitTypeQuery(node);
-          case 186 /* TypeLiteral */:
+          case 187 /* TypeLiteral */:
             return emitTypeLiteral(node);
-          case 187 /* ArrayType */:
+          case 188 /* ArrayType */:
             return emitArrayType(node);
-          case 188 /* TupleType */:
+          case 189 /* TupleType */:
             return emitTupleType(node);
-          case 189 /* OptionalType */:
+          case 190 /* OptionalType */:
             return emitOptionalType(node);
-          case 191 /* UnionType */:
+          case 192 /* UnionType */:
             return emitUnionType(node);
-          case 192 /* IntersectionType */:
+          case 193 /* IntersectionType */:
             return emitIntersectionType(node);
-          case 193 /* ConditionalType */:
+          case 194 /* ConditionalType */:
             return emitConditionalType(node);
-          case 194 /* InferType */:
+          case 195 /* InferType */:
             return emitInferType(node);
-          case 195 /* ParenthesizedType */:
+          case 196 /* ParenthesizedType */:
             return emitParenthesizedType(node);
-          case 232 /* ExpressionWithTypeArguments */:
+          case 233 /* ExpressionWithTypeArguments */:
             return emitExpressionWithTypeArguments(node);
-          case 196 /* ThisType */:
+          case 197 /* ThisType */:
             return emitThisType();
-          case 197 /* TypeOperator */:
+          case 198 /* TypeOperator */:
             return emitTypeOperator(node);
-          case 198 /* IndexedAccessType */:
+          case 199 /* IndexedAccessType */:
             return emitIndexedAccessType(node);
-          case 199 /* MappedType */:
+          case 200 /* MappedType */:
             return emitMappedType(node);
-          case 200 /* LiteralType */:
+          case 201 /* LiteralType */:
             return emitLiteralType(node);
-          case 201 /* NamedTupleMember */:
+          case 202 /* NamedTupleMember */:
             return emitNamedTupleMember(node);
-          case 202 /* TemplateLiteralType */:
+          case 203 /* TemplateLiteralType */:
             return emitTemplateType(node);
-          case 203 /* TemplateLiteralTypeSpan */:
+          case 204 /* TemplateLiteralTypeSpan */:
             return emitTemplateTypeSpan(node);
-          case 204 /* ImportType */:
+          case 205 /* ImportType */:
             return emitImportTypeNode(node);
-          case 205 /* ObjectBindingPattern */:
+          case 206 /* ObjectBindingPattern */:
             return emitObjectBindingPattern(node);
-          case 206 /* ArrayBindingPattern */:
+          case 207 /* ArrayBindingPattern */:
             return emitArrayBindingPattern(node);
-          case 207 /* BindingElement */:
+          case 208 /* BindingElement */:
             return emitBindingElement(node);
-          case 238 /* TemplateSpan */:
+          case 239 /* TemplateSpan */:
             return emitTemplateSpan(node);
-          case 239 /* SemicolonClassElement */:
+          case 240 /* SemicolonClassElement */:
             return emitSemicolonClassElement();
-          case 240 /* Block */:
+          case 241 /* Block */:
             return emitBlock(node);
-          case 242 /* VariableStatement */:
+          case 243 /* VariableStatement */:
             return emitVariableStatement(node);
-          case 241 /* EmptyStatement */:
+          case 242 /* EmptyStatement */:
             return emitEmptyStatement(
               /*isEmbeddedStatement*/
               false
             );
-          case 243 /* ExpressionStatement */:
+          case 244 /* ExpressionStatement */:
             return emitExpressionStatement(node);
-          case 244 /* IfStatement */:
+          case 245 /* IfStatement */:
             return emitIfStatement(node);
-          case 245 /* DoStatement */:
+          case 246 /* DoStatement */:
             return emitDoStatement(node);
-          case 246 /* WhileStatement */:
+          case 247 /* WhileStatement */:
             return emitWhileStatement(node);
-          case 247 /* ForStatement */:
+          case 248 /* ForStatement */:
             return emitForStatement(node);
-          case 248 /* ForInStatement */:
+          case 249 /* ForInStatement */:
             return emitForInStatement(node);
-          case 249 /* ForOfStatement */:
+          case 250 /* ForOfStatement */:
             return emitForOfStatement(node);
-          case 250 /* ContinueStatement */:
+          case 251 /* ContinueStatement */:
             return emitContinueStatement(node);
-          case 251 /* BreakStatement */:
+          case 252 /* BreakStatement */:
             return emitBreakStatement(node);
-          case 252 /* ReturnStatement */:
+          case 253 /* ReturnStatement */:
             return emitReturnStatement(node);
-          case 253 /* WithStatement */:
+          case 254 /* WithStatement */:
             return emitWithStatement(node);
-          case 254 /* SwitchStatement */:
+          case 255 /* SwitchStatement */:
             return emitSwitchStatement(node);
-          case 255 /* LabeledStatement */:
+          case 256 /* LabeledStatement */:
             return emitLabeledStatement(node);
-          case 256 /* ThrowStatement */:
+          case 257 /* ThrowStatement */:
             return emitThrowStatement(node);
-          case 257 /* TryStatement */:
+          case 258 /* TryStatement */:
             return emitTryStatement(node);
-          case 258 /* DebuggerStatement */:
+          case 259 /* DebuggerStatement */:
             return emitDebuggerStatement(node);
-          case 259 /* VariableDeclaration */:
+          case 260 /* VariableDeclaration */:
             return emitVariableDeclaration(node);
-          case 260 /* VariableDeclarationList */:
+          case 261 /* VariableDeclarationList */:
             return emitVariableDeclarationList(node);
-          case 261 /* FunctionDeclaration */:
+          case 262 /* FunctionDeclaration */:
             return emitFunctionDeclaration(node);
-          case 262 /* ClassDeclaration */:
+          case 263 /* ClassDeclaration */:
             return emitClassDeclaration(node);
-          case 263 /* InterfaceDeclaration */:
+          case 264 /* InterfaceDeclaration */:
             return emitInterfaceDeclaration(node);
-          case 264 /* TypeAliasDeclaration */:
+          case 265 /* TypeAliasDeclaration */:
             return emitTypeAliasDeclaration(node);
-          case 265 /* EnumDeclaration */:
+          case 266 /* EnumDeclaration */:
             return emitEnumDeclaration(node);
-          case 266 /* ModuleDeclaration */:
+          case 267 /* ModuleDeclaration */:
             return emitModuleDeclaration(node);
-          case 267 /* ModuleBlock */:
+          case 268 /* ModuleBlock */:
             return emitModuleBlock(node);
-          case 268 /* CaseBlock */:
+          case 269 /* CaseBlock */:
             return emitCaseBlock(node);
-          case 269 /* NamespaceExportDeclaration */:
+          case 270 /* NamespaceExportDeclaration */:
             return emitNamespaceExportDeclaration(node);
-          case 270 /* ImportEqualsDeclaration */:
+          case 271 /* ImportEqualsDeclaration */:
             return emitImportEqualsDeclaration(node);
-          case 271 /* ImportDeclaration */:
+          case 272 /* ImportDeclaration */:
             return emitImportDeclaration(node);
-          case 272 /* ImportClause */:
+          case 273 /* ImportClause */:
             return emitImportClause(node);
-          case 273 /* NamespaceImport */:
+          case 274 /* NamespaceImport */:
             return emitNamespaceImport(node);
-          case 279 /* NamespaceExport */:
+          case 280 /* NamespaceExport */:
             return emitNamespaceExport(node);
-          case 274 /* NamedImports */:
+          case 275 /* NamedImports */:
             return emitNamedImports(node);
-          case 275 /* ImportSpecifier */:
+          case 276 /* ImportSpecifier */:
             return emitImportSpecifier(node);
-          case 276 /* ExportAssignment */:
+          case 277 /* ExportAssignment */:
             return emitExportAssignment(node);
-          case 277 /* ExportDeclaration */:
+          case 278 /* ExportDeclaration */:
             return emitExportDeclaration(node);
-          case 278 /* NamedExports */:
+          case 279 /* NamedExports */:
             return emitNamedExports(node);
-          case 280 /* ExportSpecifier */:
+          case 281 /* ExportSpecifier */:
             return emitExportSpecifier(node);
-          case 299 /* AssertClause */:
-            return emitAssertClause(node);
-          case 300 /* AssertEntry */:
-            return emitAssertEntry(node);
-          case 281 /* MissingDeclaration */:
+          case 300 /* ImportAttributes */:
+            return emitImportAttributes(node);
+          case 301 /* ImportAttribute */:
+            return emitImportAttribute(node);
+          case 282 /* MissingDeclaration */:
             return;
-          case 282 /* ExternalModuleReference */:
+          case 283 /* ExternalModuleReference */:
             return emitExternalModuleReference(node);
           case 12 /* JsxText */:
             return emitJsxText(node);
-          case 285 /* JsxOpeningElement */:
-          case 288 /* JsxOpeningFragment */:
+          case 286 /* JsxOpeningElement */:
+          case 289 /* JsxOpeningFragment */:
             return emitJsxOpeningElementOrFragment(node);
-          case 286 /* JsxClosingElement */:
-          case 289 /* JsxClosingFragment */:
+          case 287 /* JsxClosingElement */:
+          case 290 /* JsxClosingFragment */:
             return emitJsxClosingElementOrFragment(node);
-          case 290 /* JsxAttribute */:
+          case 291 /* JsxAttribute */:
             return emitJsxAttribute(node);
-          case 291 /* JsxAttributes */:
+          case 292 /* JsxAttributes */:
             return emitJsxAttributes(node);
-          case 292 /* JsxSpreadAttribute */:
+          case 293 /* JsxSpreadAttribute */:
             return emitJsxSpreadAttribute(node);
-          case 293 /* JsxExpression */:
+          case 294 /* JsxExpression */:
             return emitJsxExpression(node);
-          case 294 /* JsxNamespacedName */:
+          case 295 /* JsxNamespacedName */:
             return emitJsxNamespacedName(node);
-          case 295 /* CaseClause */:
+          case 296 /* CaseClause */:
             return emitCaseClause(node);
-          case 296 /* DefaultClause */:
+          case 297 /* DefaultClause */:
             return emitDefaultClause(node);
-          case 297 /* HeritageClause */:
+          case 298 /* HeritageClause */:
             return emitHeritageClause(node);
-          case 298 /* CatchClause */:
+          case 299 /* CatchClause */:
             return emitCatchClause(node);
-          case 302 /* PropertyAssignment */:
+          case 303 /* PropertyAssignment */:
             return emitPropertyAssignment(node);
-          case 303 /* ShorthandPropertyAssignment */:
+          case 304 /* ShorthandPropertyAssignment */:
             return emitShorthandPropertyAssignment(node);
-          case 304 /* SpreadAssignment */:
+          case 305 /* SpreadAssignment */:
             return emitSpreadAssignment(node);
-          case 305 /* EnumMember */:
+          case 306 /* EnumMember */:
             return emitEnumMember(node);
-          case 306 /* UnparsedPrologue */:
+          case 307 /* UnparsedPrologue */:
             return writeUnparsedNode(node);
-          case 313 /* UnparsedSource */:
-          case 307 /* UnparsedPrepend */:
+          case 314 /* UnparsedSource */:
+          case 308 /* UnparsedPrepend */:
             return emitUnparsedSourceOrPrepend(node);
-          case 308 /* UnparsedText */:
-          case 309 /* UnparsedInternalText */:
+          case 309 /* UnparsedText */:
+          case 310 /* UnparsedInternalText */:
             return emitUnparsedTextLike(node);
-          case 310 /* UnparsedSyntheticReference */:
+          case 311 /* UnparsedSyntheticReference */:
             return emitUnparsedSyntheticReference(node);
-          case 311 /* SourceFile */:
+          case 312 /* SourceFile */:
             return emitSourceFile(node);
-          case 312 /* Bundle */:
+          case 313 /* Bundle */:
             return Debug.fail("Bundles should be printed using printBundle");
-          case 314 /* InputFiles */:
+          case 315 /* InputFiles */:
             return Debug.fail("InputFiles should not be printed");
-          case 315 /* JSDocTypeExpression */:
+          case 316 /* JSDocTypeExpression */:
             return emitJSDocTypeExpression(node);
-          case 316 /* JSDocNameReference */:
+          case 317 /* JSDocNameReference */:
             return emitJSDocNameReference(node);
-          case 318 /* JSDocAllType */:
+          case 319 /* JSDocAllType */:
             return writePunctuation("*");
-          case 319 /* JSDocUnknownType */:
+          case 320 /* JSDocUnknownType */:
             return writePunctuation("?");
-          case 320 /* JSDocNullableType */:
+          case 321 /* JSDocNullableType */:
             return emitJSDocNullableType(node);
-          case 321 /* JSDocNonNullableType */:
+          case 322 /* JSDocNonNullableType */:
             return emitJSDocNonNullableType(node);
-          case 322 /* JSDocOptionalType */:
+          case 323 /* JSDocOptionalType */:
             return emitJSDocOptionalType(node);
-          case 323 /* JSDocFunctionType */:
+          case 324 /* JSDocFunctionType */:
             return emitJSDocFunctionType(node);
-          case 190 /* RestType */:
-          case 324 /* JSDocVariadicType */:
+          case 191 /* RestType */:
+          case 325 /* JSDocVariadicType */:
             return emitRestOrJSDocVariadicType(node);
-          case 325 /* JSDocNamepathType */:
+          case 326 /* JSDocNamepathType */:
             return;
-          case 326 /* JSDoc */:
+          case 327 /* JSDoc */:
             return emitJSDoc(node);
-          case 328 /* JSDocTypeLiteral */:
+          case 329 /* JSDocTypeLiteral */:
             return emitJSDocTypeLiteral(node);
-          case 329 /* JSDocSignature */:
+          case 330 /* JSDocSignature */:
             return emitJSDocSignature(node);
-          case 333 /* JSDocTag */:
-          case 338 /* JSDocClassTag */:
-          case 343 /* JSDocOverrideTag */:
+          case 334 /* JSDocTag */:
+          case 339 /* JSDocClassTag */:
+          case 344 /* JSDocOverrideTag */:
             return emitJSDocSimpleTag(node);
-          case 334 /* JSDocAugmentsTag */:
-          case 335 /* JSDocImplementsTag */:
+          case 335 /* JSDocAugmentsTag */:
+          case 336 /* JSDocImplementsTag */:
             return emitJSDocHeritageTag(node);
-          case 336 /* JSDocAuthorTag */:
-          case 337 /* JSDocDeprecatedTag */:
+          case 337 /* JSDocAuthorTag */:
+          case 338 /* JSDocDeprecatedTag */:
             return;
-          case 339 /* JSDocPublicTag */:
-          case 340 /* JSDocPrivateTag */:
-          case 341 /* JSDocProtectedTag */:
-          case 342 /* JSDocReadonlyTag */:
+          case 340 /* JSDocPublicTag */:
+          case 341 /* JSDocPrivateTag */:
+          case 342 /* JSDocProtectedTag */:
+          case 343 /* JSDocReadonlyTag */:
             return;
-          case 344 /* JSDocCallbackTag */:
+          case 345 /* JSDocCallbackTag */:
             return emitJSDocCallbackTag(node);
-          case 345 /* JSDocOverloadTag */:
+          case 346 /* JSDocOverloadTag */:
             return emitJSDocOverloadTag(node);
-          case 347 /* JSDocParameterTag */:
-          case 354 /* JSDocPropertyTag */:
+          case 348 /* JSDocParameterTag */:
+          case 355 /* JSDocPropertyTag */:
             return emitJSDocPropertyLikeTag(node);
-          case 346 /* JSDocEnumTag */:
-          case 348 /* JSDocReturnTag */:
-          case 349 /* JSDocThisTag */:
-          case 350 /* JSDocTypeTag */:
-          case 355 /* JSDocThrowsTag */:
-          case 356 /* JSDocSatisfiesTag */:
+          case 347 /* JSDocEnumTag */:
+          case 349 /* JSDocReturnTag */:
+          case 350 /* JSDocThisTag */:
+          case 351 /* JSDocTypeTag */:
+          case 356 /* JSDocThrowsTag */:
+          case 357 /* JSDocSatisfiesTag */:
             return emitJSDocSimpleTypedTag(node);
-          case 351 /* JSDocTemplateTag */:
+          case 352 /* JSDocTemplateTag */:
             return emitJSDocTemplateTag(node);
-          case 352 /* JSDocTypedefTag */:
+          case 353 /* JSDocTypedefTag */:
             return emitJSDocTypedefTag(node);
-          case 353 /* JSDocSeeTag */:
+          case 354 /* JSDocSeeTag */:
             return emitJSDocSeeTag(node);
-          case 358 /* NotEmittedStatement */:
+          case 359 /* NotEmittedStatement */:
             return;
         }
         if (isExpression(node)) {
@@ -210788,83 +196169,83 @@ ${lanes.join("\n")}
             return emitIdentifier(node);
           case 81 /* PrivateIdentifier */:
             return emitPrivateIdentifier(node);
-          case 208 /* ArrayLiteralExpression */:
+          case 209 /* ArrayLiteralExpression */:
             return emitArrayLiteralExpression(node);
-          case 209 /* ObjectLiteralExpression */:
+          case 210 /* ObjectLiteralExpression */:
             return emitObjectLiteralExpression(node);
-          case 210 /* PropertyAccessExpression */:
+          case 211 /* PropertyAccessExpression */:
             return emitPropertyAccessExpression(node);
-          case 211 /* ElementAccessExpression */:
+          case 212 /* ElementAccessExpression */:
             return emitElementAccessExpression(node);
-          case 212 /* CallExpression */:
+          case 213 /* CallExpression */:
             return emitCallExpression(node);
-          case 213 /* NewExpression */:
+          case 214 /* NewExpression */:
             return emitNewExpression(node);
-          case 214 /* TaggedTemplateExpression */:
+          case 215 /* TaggedTemplateExpression */:
             return emitTaggedTemplateExpression(node);
-          case 215 /* TypeAssertionExpression */:
+          case 216 /* TypeAssertionExpression */:
             return emitTypeAssertionExpression(node);
-          case 216 /* ParenthesizedExpression */:
+          case 217 /* ParenthesizedExpression */:
             return emitParenthesizedExpression(node);
-          case 217 /* FunctionExpression */:
+          case 218 /* FunctionExpression */:
             return emitFunctionExpression(node);
-          case 218 /* ArrowFunction */:
+          case 219 /* ArrowFunction */:
             return emitArrowFunction(node);
-          case 219 /* DeleteExpression */:
+          case 220 /* DeleteExpression */:
             return emitDeleteExpression(node);
-          case 220 /* TypeOfExpression */:
+          case 221 /* TypeOfExpression */:
             return emitTypeOfExpression(node);
-          case 221 /* VoidExpression */:
+          case 222 /* VoidExpression */:
             return emitVoidExpression(node);
-          case 222 /* AwaitExpression */:
+          case 223 /* AwaitExpression */:
             return emitAwaitExpression(node);
-          case 223 /* PrefixUnaryExpression */:
+          case 224 /* PrefixUnaryExpression */:
             return emitPrefixUnaryExpression(node);
-          case 224 /* PostfixUnaryExpression */:
+          case 225 /* PostfixUnaryExpression */:
             return emitPostfixUnaryExpression(node);
-          case 225 /* BinaryExpression */:
+          case 226 /* BinaryExpression */:
             return emitBinaryExpression(node);
-          case 226 /* ConditionalExpression */:
+          case 227 /* ConditionalExpression */:
             return emitConditionalExpression(node);
-          case 227 /* TemplateExpression */:
+          case 228 /* TemplateExpression */:
             return emitTemplateExpression(node);
-          case 228 /* YieldExpression */:
+          case 229 /* YieldExpression */:
             return emitYieldExpression(node);
-          case 229 /* SpreadElement */:
+          case 230 /* SpreadElement */:
             return emitSpreadElement(node);
-          case 230 /* ClassExpression */:
+          case 231 /* ClassExpression */:
             return emitClassExpression(node);
-          case 231 /* OmittedExpression */:
+          case 232 /* OmittedExpression */:
             return;
-          case 233 /* AsExpression */:
+          case 234 /* AsExpression */:
             return emitAsExpression(node);
-          case 234 /* NonNullExpression */:
+          case 235 /* NonNullExpression */:
             return emitNonNullExpression(node);
-          case 232 /* ExpressionWithTypeArguments */:
+          case 233 /* ExpressionWithTypeArguments */:
             return emitExpressionWithTypeArguments(node);
-          case 237 /* SatisfiesExpression */:
+          case 238 /* SatisfiesExpression */:
             return emitSatisfiesExpression(node);
-          case 235 /* MetaProperty */:
+          case 236 /* MetaProperty */:
             return emitMetaProperty(node);
-          case 236 /* SyntheticExpression */:
+          case 237 /* SyntheticExpression */:
             return Debug.fail("SyntheticExpression should never be printed.");
-          case 281 /* MissingDeclaration */:
+          case 282 /* MissingDeclaration */:
             return;
-          case 283 /* JsxElement */:
+          case 284 /* JsxElement */:
             return emitJsxElement(node);
-          case 284 /* JsxSelfClosingElement */:
+          case 285 /* JsxSelfClosingElement */:
             return emitJsxSelfClosingElement(node);
-          case 287 /* JsxFragment */:
+          case 288 /* JsxFragment */:
             return emitJsxFragment(node);
-          case 357 /* SyntaxList */:
+          case 358 /* SyntaxList */:
             return Debug.fail("SyntaxList should not be printed");
-          case 358 /* NotEmittedStatement */:
+          case 359 /* NotEmittedStatement */:
             return;
-          case 359 /* PartiallyEmittedExpression */:
+          case 360 /* PartiallyEmittedExpression */:
             return emitPartiallyEmittedExpression(node);
-          case 360 /* CommaListExpression */:
+          case 361 /* CommaListExpression */:
             return emitCommaList(node);
-          case 361 /* SyntheticReferenceExpression */:
+          case 362 /* SyntheticReferenceExpression */:
             return Debug.fail("SyntheticReferenceExpression should not be printed");
         }
       }
@@ -210910,7 +196291,7 @@ ${lanes.join("\n")}
     }
     function emitHelpers(node) {
       let helpersEmitted = false;
-      const bundle = node.kind === 312 /* Bundle */ ? node : void 0;
+      const bundle = node.kind === 313 /* Bundle */ ? node : void 0;
       if (bundle && moduleKind === 0 /* None */) {
         return;
       }
@@ -210985,7 +196366,7 @@ ${lanes.join("\n")}
         updateOrPushBundleFileTextLike(
           pos,
           writer.getTextPos(),
-          unparsed.kind === 308 /* UnparsedText */ ? "text" /* Text */ : "internal" /* Internal */
+          unparsed.kind === 309 /* UnparsedText */ ? "text" /* Text */ : "internal" /* Internal */
         );
       }
     }
@@ -211020,14 +196401,8 @@ ${lanes.join("\n")}
       nonEscapingWrite(`}`);
     }
     function emitTabStop(hint, node, snippet) {
-      Debug.assert(
-        node.kind === 241 /* EmptyStatement */,
-        `A tab stop cannot be attached to a node of kind ${Debug.formatSyntaxKind(node.kind)}.`
-      );
-      Debug.assert(
-        hint !== 5 /* EmbeddedStatement */,
-        `A tab stop cannot be attached to an embedded statement.`
-      );
+      Debug.assert(node.kind === 242 /* EmptyStatement */, `A tab stop cannot be attached to a node of kind ${Debug.formatSyntaxKind(node.kind)}.`);
+      Debug.assert(hint !== 5 /* EmbeddedStatement */, `A tab stop cannot be attached to an embedded statement.`);
       nonEscapingWrite(`$${snippet.order}`);
     }
     function emitIdentifier(node) {
@@ -211093,7 +196468,7 @@ ${lanes.join("\n")}
       emit(node.dotDotDotToken);
       emitNodeWithWriter(node.name, writeParameter);
       emit(node.questionToken);
-      if (node.parent && node.parent.kind === 323 /* JSDocFunctionType */ && !node.name) {
+      if (node.parent && node.parent.kind === 324 /* JSDocFunctionType */ && !node.name) {
         emit(node.type);
       } else {
         emitTypeAnnotation(node.type);
@@ -211169,7 +196544,7 @@ ${lanes.join("\n")}
         /*allowDecorators*/
         true
       );
-      const token = node.kind === 176 /* GetAccessor */ ? 139 /* GetKeyword */ : 153 /* SetKeyword */;
+      const token = node.kind === 177 /* GetAccessor */ ? 139 /* GetKeyword */ : 153 /* SetKeyword */;
       emitTokenWithComment(token, pos, writeKeyword, node);
       writeSpace();
       emit(node.name);
@@ -211419,16 +196794,16 @@ ${lanes.join("\n")}
       writeKeyword("import");
       writePunctuation("(");
       emit(node.argument);
-      if (node.assertions) {
+      if (node.attributes) {
         writePunctuation(",");
         writeSpace();
         writePunctuation("{");
         writeSpace();
-        writeKeyword("assert");
+        writeKeyword(node.attributes.token === 132 /* AssertKeyword */ ? "assert" : "with");
         writePunctuation(":");
         writeSpace();
-        const elements = node.assertions.assertClause.elements;
-        emitList(node.assertions.assertClause, elements, 526226 /* ImportClauseEntries */);
+        const elements = node.attributes.elements;
+        emitList(node.attributes, elements, 526226 /* ImportAttributes */);
         writeSpace();
         writePunctuation("}");
       }
@@ -211520,10 +196895,10 @@ ${lanes.join("\n")}
           /*jsxAttributeEscape*/
           false
         );
-        return !(expression.numericLiteralFlags & 448 /* WithSpecifier */) && !stringContains(text, tokenToString(25 /* DotToken */)) && !stringContains(text, String.fromCharCode(69 /* E */)) && !stringContains(text, String.fromCharCode(101 /* e */));
+        return !(expression.numericLiteralFlags & 448 /* WithSpecifier */) && !text.includes(tokenToString(25 /* DotToken */)) && !text.includes(String.fromCharCode(69 /* E */)) && !text.includes(String.fromCharCode(101 /* e */));
       } else if (isAccessExpression(expression)) {
         const constantValue = getConstantValue(expression);
-        return typeof constantValue === "number" && isFinite(constantValue) && Math.floor(constantValue) === constantValue;
+        return typeof constantValue === "number" && isFinite(constantValue) && constantValue >= 0 && Math.floor(constantValue) === constantValue;
       }
     }
     function emitElementAccessExpression(node) {
@@ -211634,7 +197009,7 @@ ${lanes.join("\n")}
     }
     function shouldEmitWhitespaceBeforeOperand(node) {
       const operand = node.operand;
-      return operand.kind === 223 /* PrefixUnaryExpression */ && (node.operator === 40 /* PlusToken */ && (operand.operator === 40 /* PlusToken */ || operand.operator === 46 /* PlusPlusToken */) || node.operator === 41 /* MinusToken */ && (operand.operator === 41 /* MinusToken */ || operand.operator === 47 /* MinusMinusToken */));
+      return operand.kind === 224 /* PrefixUnaryExpression */ && (node.operator === 40 /* PlusToken */ && (operand.operator === 40 /* PlusToken */ || operand.operator === 46 /* PlusPlusToken */) || node.operator === 41 /* MinusToken */ && (operand.operator === 41 /* MinusToken */ || operand.operator === 47 /* MinusMinusToken */));
     }
     function emitPostfixUnaryExpression(node) {
       emitExpression(node.operand, parenthesizer.parenthesizeOperandOfPostfixUnary);
@@ -211893,7 +197268,7 @@ ${lanes.join("\n")}
       if (node.elseStatement) {
         writeLineOrSpace(node, node.thenStatement, node.elseStatement);
         emitTokenWithComment(93 /* ElseKeyword */, node.thenStatement.end, writeKeyword, node);
-        if (node.elseStatement.kind === 244 /* IfStatement */) {
+        if (node.elseStatement.kind === 245 /* IfStatement */) {
           writeSpace();
           emit(node.elseStatement);
         } else {
@@ -211960,7 +197335,7 @@ ${lanes.join("\n")}
       emitTokenWithComment(21 /* OpenParenToken */, openParenPos, writePunctuation, node);
       emitForBinding(node.initializer);
       writeSpace();
-      emitTokenWithComment(164 /* OfKeyword */, node.initializer.end, writeKeyword, node);
+      emitTokenWithComment(165 /* OfKeyword */, node.initializer.end, writeKeyword, node);
       writeSpace();
       emitExpression(node.expression);
       emitTokenWithComment(22 /* CloseParenToken */, node.expression.end, writePunctuation, node);
@@ -211968,7 +197343,7 @@ ${lanes.join("\n")}
     }
     function emitForBinding(node) {
       if (node !== void 0) {
-        if (node.kind === 260 /* VariableDeclarationList */) {
+        if (node.kind === 261 /* VariableDeclarationList */) {
           emit(node);
         } else {
           emitExpression(node);
@@ -212002,9 +197377,13 @@ ${lanes.join("\n")}
           decreaseIndent();
         }
       }
-      pos = writeTokenText(token, writer2, pos);
+      if (!omitBraceSourcePositions && (token === 19 /* OpenBraceToken */ || token === 20 /* CloseBraceToken */)) {
+        pos = writeToken(token, pos, writer2, contextNode);
+      } else {
+        pos = writeTokenText(token, writer2, pos);
+      }
       if (isSimilarNode && contextNode.end !== pos) {
-        const isJsxExprContext = contextNode.kind === 293 /* JsxExpression */;
+        const isJsxExprContext = contextNode.kind === 294 /* JsxExpression */;
         emitTrailingCommentsOfPosition(
           pos,
           /*prefixSpace*/
@@ -212116,7 +197495,14 @@ ${lanes.join("\n")}
       emitInitializer(node.initializer, ((_a = node.type) == null ? void 0 : _a.end) ?? ((_c = (_b = node.name.emitNode) == null ? void 0 : _b.typeNode) == null ? void 0 : _c.end) ?? node.name.end, node, parenthesizer.parenthesizeExpressionForDisallowedComma);
     }
     function emitVariableDeclarationList(node) {
-      writeKeyword(isLet(node) ? "let" : isVarConst(node) ? "const" : "var");
+      if (isVarAwaitUsing(node)) {
+        writeKeyword("await");
+        writeSpace();
+        writeKeyword("using");
+      } else {
+        const head = isLet(node) ? "let" : isVarConst(node) ? "const" : isVarUsing(node) ? "using" : "var";
+        writeKeyword(head);
+      }
       writeSpace();
       emitList(node, node.declarations, 528 /* VariableDeclarationList */);
     }
@@ -212325,8 +197711,8 @@ ${lanes.join("\n")}
         /*allowDecorators*/
         false
       );
-      if (~node.flags & 1024 /* GlobalAugmentation */) {
-        writeKeyword(node.flags & 16 /* Namespace */ ? "namespace" : "module");
+      if (~node.flags & 2048 /* GlobalAugmentation */) {
+        writeKeyword(node.flags & 32 /* Namespace */ ? "namespace" : "module");
         writeSpace();
       }
       emit(node.name);
@@ -212402,12 +197788,12 @@ ${lanes.join("\n")}
       if (node.importClause) {
         emit(node.importClause);
         writeSpace();
-        emitTokenWithComment(160 /* FromKeyword */, node.importClause.end, writeKeyword, node);
+        emitTokenWithComment(161 /* FromKeyword */, node.importClause.end, writeKeyword, node);
         writeSpace();
       }
       emitExpression(node.moduleSpecifier);
-      if (node.assertClause) {
-        emitWithLeadingSpace(node.assertClause);
+      if (node.attributes) {
+        emitWithLeadingSpace(node.attributes);
       }
       writeTrailingSemicolon();
     }
@@ -212445,7 +197831,10 @@ ${lanes.join("\n")}
         emitTokenWithComment(90 /* DefaultKeyword */, nextPos, writeKeyword, node);
       }
       writeSpace();
-      emitExpression(node.expression, node.isExportEquals ? parenthesizer.getParenthesizeRightSideOfBinaryForOperator(64 /* EqualsToken */) : parenthesizer.parenthesizeExpressionOfExportDefault);
+      emitExpression(
+        node.expression,
+        node.isExportEquals ? parenthesizer.getParenthesizeRightSideOfBinaryForOperator(64 /* EqualsToken */) : parenthesizer.parenthesizeExpressionOfExportDefault
+      );
       writeTrailingSemicolon();
     }
     function emitExportDeclaration(node) {
@@ -212469,22 +197858,22 @@ ${lanes.join("\n")}
       if (node.moduleSpecifier) {
         writeSpace();
         const fromPos = node.exportClause ? node.exportClause.end : nextPos;
-        emitTokenWithComment(160 /* FromKeyword */, fromPos, writeKeyword, node);
+        emitTokenWithComment(161 /* FromKeyword */, fromPos, writeKeyword, node);
         writeSpace();
         emitExpression(node.moduleSpecifier);
       }
-      if (node.assertClause) {
-        emitWithLeadingSpace(node.assertClause);
+      if (node.attributes) {
+        emitWithLeadingSpace(node.attributes);
       }
       writeTrailingSemicolon();
     }
-    function emitAssertClause(node) {
-      emitTokenWithComment(132 /* AssertKeyword */, node.pos, writeKeyword, node);
+    function emitImportAttributes(node) {
+      emitTokenWithComment(node.token, node.pos, writeKeyword, node);
       writeSpace();
       const elements = node.elements;
-      emitList(node, elements, 526226 /* ImportClauseEntries */);
+      emitList(node, elements, 526226 /* ImportAttributes */);
     }
-    function emitAssertEntry(node) {
+    function emitImportAttribute(node) {
       emit(node.name);
       writePunctuation(":");
       writeSpace();
@@ -212724,7 +198113,7 @@ ${lanes.join("\n")}
         }
       }
       if (node.tags) {
-        if (node.tags.length === 1 && node.tags[0].kind === 350 /* JSDocTypeTag */ && !node.comment) {
+        if (node.tags.length === 1 && node.tags[0].kind === 351 /* JSDocTypeTag */ && !node.comment) {
           writeSpace();
           emit(node.tags[0]);
         } else {
@@ -212768,7 +198157,7 @@ ${lanes.join("\n")}
     function emitJSDocTypedefTag(tag) {
       emitJSDocTagName(tag.tagName);
       if (tag.typeExpression) {
-        if (tag.typeExpression.kind === 315 /* JSDocTypeExpression */) {
+        if (tag.typeExpression.kind === 316 /* JSDocTypeExpression */) {
           emitJSDocTypeExpression(tag.typeExpression);
         } else {
           writeSpace();
@@ -212786,7 +198175,7 @@ ${lanes.join("\n")}
         emit(tag.fullName);
       }
       emitJSDocComment(tag.comment);
-      if (tag.typeExpression && tag.typeExpression.kind === 328 /* JSDocTypeLiteral */) {
+      if (tag.typeExpression && tag.typeExpression.kind === 329 /* JSDocTypeLiteral */) {
         emitJSDocTypeLiteral(tag.typeExpression);
       }
     }
@@ -213343,6 +198732,16 @@ ${lanes.join("\n")}
               increaseIndent();
               shouldDecreaseIndentAfterEmit = true;
             }
+            if (shouldEmitInterveningComments && format & 60 /* DelimitersMask */ && !positionIsSynthesized(child.pos)) {
+              const commentRange = getCommentRange(child);
+              emitTrailingCommentsOfPosition(
+                commentRange.pos,
+                /*prefixSpace*/
+                !!(format & 512 /* SpaceBetweenSiblings */),
+                /*forceNoNewline*/
+                true
+              );
+            }
             writeLine(separatingLineTerminatorCount);
             shouldEmitInterveningComments = false;
           } else if (previousSibling && format & 512 /* SpaceBetweenSiblings */) {
@@ -213669,7 +199068,7 @@ ${lanes.join("\n")}
       return block.statements.length === 0 && (!currentSourceFile || rangeEndIsOnSameLineAsRangeStart(block, block, currentSourceFile));
     }
     function skipSynthesizedParentheses(node) {
-      while (node.kind === 216 /* ParenthesizedExpression */ && nodeIsSynthesized(node)) {
+      while (node.kind === 217 /* ParenthesizedExpression */ && nodeIsSynthesized(node)) {
         node = node.expression;
       }
       return node;
@@ -213756,84 +199155,84 @@ ${lanes.join("\n")}
       if (!node)
         return;
       switch (node.kind) {
-        case 240 /* Block */:
+        case 241 /* Block */:
           forEach(node.statements, generateNames);
           break;
-        case 255 /* LabeledStatement */:
-        case 253 /* WithStatement */:
-        case 245 /* DoStatement */:
-        case 246 /* WhileStatement */:
+        case 256 /* LabeledStatement */:
+        case 254 /* WithStatement */:
+        case 246 /* DoStatement */:
+        case 247 /* WhileStatement */:
           generateNames(node.statement);
           break;
-        case 244 /* IfStatement */:
+        case 245 /* IfStatement */:
           generateNames(node.thenStatement);
           generateNames(node.elseStatement);
           break;
-        case 247 /* ForStatement */:
-        case 249 /* ForOfStatement */:
-        case 248 /* ForInStatement */:
+        case 248 /* ForStatement */:
+        case 250 /* ForOfStatement */:
+        case 249 /* ForInStatement */:
           generateNames(node.initializer);
           generateNames(node.statement);
           break;
-        case 254 /* SwitchStatement */:
+        case 255 /* SwitchStatement */:
           generateNames(node.caseBlock);
           break;
-        case 268 /* CaseBlock */:
+        case 269 /* CaseBlock */:
           forEach(node.clauses, generateNames);
           break;
-        case 295 /* CaseClause */:
-        case 296 /* DefaultClause */:
+        case 296 /* CaseClause */:
+        case 297 /* DefaultClause */:
           forEach(node.statements, generateNames);
           break;
-        case 257 /* TryStatement */:
+        case 258 /* TryStatement */:
           generateNames(node.tryBlock);
           generateNames(node.catchClause);
           generateNames(node.finallyBlock);
           break;
-        case 298 /* CatchClause */:
+        case 299 /* CatchClause */:
           generateNames(node.variableDeclaration);
           generateNames(node.block);
           break;
-        case 242 /* VariableStatement */:
+        case 243 /* VariableStatement */:
           generateNames(node.declarationList);
           break;
-        case 260 /* VariableDeclarationList */:
+        case 261 /* VariableDeclarationList */:
           forEach(node.declarations, generateNames);
           break;
-        case 259 /* VariableDeclaration */:
-        case 168 /* Parameter */:
-        case 207 /* BindingElement */:
-        case 262 /* ClassDeclaration */:
+        case 260 /* VariableDeclaration */:
+        case 169 /* Parameter */:
+        case 208 /* BindingElement */:
+        case 263 /* ClassDeclaration */:
           generateNameIfNeeded(node.name);
           break;
-        case 261 /* FunctionDeclaration */:
+        case 262 /* FunctionDeclaration */:
           generateNameIfNeeded(node.name);
           if (getEmitFlags(node) & 1048576 /* ReuseTempVariableScope */) {
             forEach(node.parameters, generateNames);
             generateNames(node.body);
           }
           break;
-        case 205 /* ObjectBindingPattern */:
-        case 206 /* ArrayBindingPattern */:
+        case 206 /* ObjectBindingPattern */:
+        case 207 /* ArrayBindingPattern */:
           forEach(node.elements, generateNames);
           break;
-        case 271 /* ImportDeclaration */:
+        case 272 /* ImportDeclaration */:
           generateNames(node.importClause);
           break;
-        case 272 /* ImportClause */:
+        case 273 /* ImportClause */:
           generateNameIfNeeded(node.name);
           generateNames(node.namedBindings);
           break;
-        case 273 /* NamespaceImport */:
+        case 274 /* NamespaceImport */:
           generateNameIfNeeded(node.name);
           break;
-        case 279 /* NamespaceExport */:
+        case 280 /* NamespaceExport */:
           generateNameIfNeeded(node.name);
           break;
-        case 274 /* NamedImports */:
+        case 275 /* NamedImports */:
           forEach(node.elements, generateNames);
           break;
-        case 275 /* ImportSpecifier */:
+        case 276 /* ImportSpecifier */:
           generateNameIfNeeded(node.propertyName || node.name);
           break;
       }
@@ -213842,12 +199241,12 @@ ${lanes.join("\n")}
       if (!node)
         return;
       switch (node.kind) {
-        case 302 /* PropertyAssignment */:
-        case 303 /* ShorthandPropertyAssignment */:
-        case 171 /* PropertyDeclaration */:
-        case 173 /* MethodDeclaration */:
-        case 176 /* GetAccessor */:
-        case 177 /* SetAccessor */:
+        case 303 /* PropertyAssignment */:
+        case 304 /* ShorthandPropertyAssignment */:
+        case 172 /* PropertyDeclaration */:
+        case 174 /* MethodDeclaration */:
+        case 177 /* GetAccessor */:
+        case 178 /* SetAccessor */:
           generateNameIfNeeded(node.name);
           break;
       }
@@ -214105,16 +199504,16 @@ ${lanes.join("\n")}
             prefix,
             suffix
           );
-        case 266 /* ModuleDeclaration */:
-        case 265 /* EnumDeclaration */:
+        case 267 /* ModuleDeclaration */:
+        case 266 /* EnumDeclaration */:
           Debug.assert(!prefix && !suffix && !privateName);
           return generateNameForModuleOrEnum(node);
-        case 271 /* ImportDeclaration */:
-        case 277 /* ExportDeclaration */:
+        case 272 /* ImportDeclaration */:
+        case 278 /* ExportDeclaration */:
           Debug.assert(!prefix && !suffix && !privateName);
           return generateNameForImportOrExportDeclaration(node);
-        case 261 /* FunctionDeclaration */:
-        case 262 /* ClassDeclaration */: {
+        case 262 /* FunctionDeclaration */:
+        case 263 /* ClassDeclaration */: {
           Debug.assert(!prefix && !suffix && !privateName);
           const name = node.name;
           if (name && !isGeneratedIdentifier(name)) {
@@ -214129,17 +199528,17 @@ ${lanes.join("\n")}
           }
           return generateNameForExportDefault();
         }
-        case 276 /* ExportAssignment */:
+        case 277 /* ExportAssignment */:
           Debug.assert(!prefix && !suffix && !privateName);
           return generateNameForExportDefault();
-        case 230 /* ClassExpression */:
+        case 231 /* ClassExpression */:
           Debug.assert(!prefix && !suffix && !privateName);
           return generateNameForClassExpression();
-        case 173 /* MethodDeclaration */:
-        case 176 /* GetAccessor */:
-        case 177 /* SetAccessor */:
+        case 174 /* MethodDeclaration */:
+        case 177 /* GetAccessor */:
+        case 178 /* SetAccessor */:
           return generateNameForMethodOrAccessor(node, privateName, prefix, suffix);
-        case 166 /* ComputedPropertyName */:
+        case 167 /* ComputedPropertyName */:
           return makeTempVariableName(
             0 /* Auto */,
             /*reservedInNestedScopes*/
@@ -214233,7 +199632,7 @@ ${lanes.join("\n")}
           emitLeadingComments(
             pos,
             /*isEmittedNode*/
-            node.kind !== 358 /* NotEmittedStatement */
+            node.kind !== 359 /* NotEmittedStatement */
           );
         }
         if (!skipLeadingComments || pos >= 0 && (emitFlags & 1024 /* NoLeadingComments */) !== 0) {
@@ -214241,7 +199640,7 @@ ${lanes.join("\n")}
         }
         if (!skipTrailingComments || end >= 0 && (emitFlags & 2048 /* NoTrailingComments */) !== 0) {
           containerEnd = end;
-          if (node.kind === 260 /* VariableDeclarationList */) {
+          if (node.kind === 261 /* VariableDeclarationList */) {
             declarationListContainerEnd = end;
           }
         }
@@ -214257,7 +199656,7 @@ ${lanes.join("\n")}
         containerPos = savedContainerPos;
         containerEnd = savedContainerEnd;
         declarationListContainerEnd = savedDeclarationListContainerEnd;
-        if (!skipTrailingComments && node.kind !== 358 /* NotEmittedStatement */) {
+        if (!skipTrailingComments && node.kind !== 359 /* NotEmittedStatement */) {
           emitTrailingComments(end);
         }
       }
@@ -214529,7 +199928,7 @@ ${lanes.join("\n")}
         }
       } else {
         const source = sourceMapRange.source || sourceMapSource;
-        if (node.kind !== 358 /* NotEmittedStatement */ && (emitFlags & 32 /* NoLeadingSourceMap */) === 0 && sourceMapRange.pos >= 0) {
+        if (node.kind !== 359 /* NotEmittedStatement */ && (emitFlags & 32 /* NoLeadingSourceMap */) === 0 && sourceMapRange.pos >= 0) {
           emitSourcePos(sourceMapRange.source || sourceMapSource, skipSourceTrivia(source, sourceMapRange.pos));
         }
         if (emitFlags & 128 /* NoNestedSourceMaps */) {
@@ -214544,7 +199943,7 @@ ${lanes.join("\n")}
         if (emitFlags & 128 /* NoNestedSourceMaps */) {
           sourceMapsDisabled = false;
         }
-        if (node.kind !== 358 /* NotEmittedStatement */ && (emitFlags & 64 /* NoTrailingSourceMap */) === 0 && sourceMapRange.end >= 0) {
+        if (node.kind !== 359 /* NotEmittedStatement */ && (emitFlags & 64 /* NoTrailingSourceMap */) === 0 && sourceMapRange.end >= 0) {
           emitSourcePos(sourceMapRange.source || sourceMapSource, sourceMapRange.end);
         }
       }
@@ -214701,7 +200100,8 @@ ${lanes.join("\n")}
         getSymbolOfExternalModuleSpecifier: notImplemented,
         isBindingCapturedByNode: notImplemented,
         getDeclarationStatementsForSourceFile: notImplemented,
-        isImportRequiredByAugmentation: notImplemented
+        isImportRequiredByAugmentation: notImplemented,
+        tryFindAmbientModule: notImplemented
       };
       createPrinterWithDefaults = /* @__PURE__ */ memoize(() => createPrinter({}));
       createPrinterWithRemoveComments = /* @__PURE__ */ memoize(() => createPrinter({ removeComments: true }));
@@ -214711,14 +200111,14 @@ ${lanes.join("\n")}
   });
 
   // src/compiler/watchUtilities.ts
-  function createCachedDirectoryStructureHost(host, currentDirectory, useCaseSensitiveFileNames) {
+  function createCachedDirectoryStructureHost(host, currentDirectory, useCaseSensitiveFileNames2) {
     if (!host.getDirectories || !host.readDirectory) {
       return void 0;
     }
     const cachedReadDirectoryResult = /* @__PURE__ */ new Map();
-    const getCanonicalFileName = createGetCanonicalFileName(useCaseSensitiveFileNames);
+    const getCanonicalFileName = createGetCanonicalFileName(useCaseSensitiveFileNames2);
     return {
-      useCaseSensitiveFileNames,
+      useCaseSensitiveFileNames: useCaseSensitiveFileNames2,
       fileExists,
       readFile: (path, encoding) => host.readFile(path, encoding),
       directoryExists: host.directoryExists && directoryExists,
@@ -214840,7 +200240,7 @@ ${lanes.join("\n")}
       const rootResult = tryReadDirectory2(rootDir, rootDirPath);
       let rootSymLinkResult;
       if (rootResult !== void 0) {
-        return matchFiles(rootDir, extensions, excludes, includes, useCaseSensitiveFileNames, currentDirectory, depth, getFileSystemEntries, realpath);
+        return matchFiles(rootDir, extensions, excludes, includes, useCaseSensitiveFileNames2, currentDirectory, depth, getFileSystemEntries, realpath);
       }
       return host.readDirectory(rootDir, extensions, excludes, includes, depth);
       function getFileSystemEntries(dir) {
@@ -215035,9 +200435,10 @@ ${lanes.join("\n")}
     program,
     extraFileExtensions,
     currentDirectory,
-    useCaseSensitiveFileNames,
+    useCaseSensitiveFileNames: useCaseSensitiveFileNames2,
     writeLog,
-    toPath: toPath3
+    toPath: toPath3,
+    getScriptKind: getScriptKind2
   }) {
     const newPath = removeIgnoredPath(fileOrDirectoryPath);
     if (!newPath) {
@@ -215047,11 +200448,11 @@ ${lanes.join("\n")}
     fileOrDirectoryPath = newPath;
     if (fileOrDirectoryPath === watchedDirPath)
       return false;
-    if (hasExtension(fileOrDirectoryPath) && !isSupportedSourceFileName(fileOrDirectory, options, extraFileExtensions)) {
+    if (hasExtension(fileOrDirectoryPath) && !(isSupportedSourceFileName(fileOrDirectory, options, extraFileExtensions) || isSupportedScriptKind())) {
       writeLog(`Project: ${configFileName} Detected file add/remove of non supported extension: ${fileOrDirectory}`);
       return true;
     }
-    if (isExcludedFile(fileOrDirectory, options.configFile.configFileSpecs, getNormalizedAbsolutePath(getDirectoryPath(configFileName), currentDirectory), useCaseSensitiveFileNames, currentDirectory)) {
+    if (isExcludedFile(fileOrDirectory, options.configFile.configFileSpecs, getNormalizedAbsolutePath(getDirectoryPath(configFileName), currentDirectory), useCaseSensitiveFileNames2, currentDirectory)) {
       writeLog(`Project: ${configFileName} Detected excluded file: ${fileOrDirectory}`);
       return true;
     }
@@ -215076,6 +200477,25 @@ ${lanes.join("\n")}
     function hasSourceFile(file) {
       return realProgram ? !!realProgram.getSourceFileByPath(file) : builderProgram ? builderProgram.getState().fileInfos.has(file) : !!find(program, (rootFile) => toPath3(rootFile) === file);
     }
+    function isSupportedScriptKind() {
+      if (!getScriptKind2)
+        return false;
+      const scriptKind = getScriptKind2(fileOrDirectory);
+      switch (scriptKind) {
+        case 3 /* TS */:
+        case 4 /* TSX */:
+        case 7 /* Deferred */:
+        case 5 /* External */:
+          return true;
+        case 1 /* JS */:
+        case 2 /* JSX */:
+          return getAllowJSCompilerOption(options);
+        case 6 /* JSON */:
+          return getResolveJsonModule(options);
+        case 0 /* Unknown */:
+          return false;
+      }
+    }
   }
   function isBuilderProgram(program) {
     return !!program.getState;
@@ -215086,7 +200506,7 @@ ${lanes.join("\n")}
     }
     return program.isEmittedFile(file);
   }
-  function getWatchFactory(host, watchLogLevel, log, getDetailWatchInfo) {
+  function getWatchFactory(host, watchLogLevel, log, getDetailWatchInfo2) {
     setSysLog(watchLogLevel === 2 /* Verbose */ ? log : noop);
     const plainInvokeFactory = {
       watchFile: (file, callback, pollingInterval, options) => host.watchFile(file, callback, pollingInterval, options),
@@ -215108,7 +200528,7 @@ ${lanes.join("\n")}
     function createExcludeHandlingAddWatch(key) {
       return (file, cb, flags, options, detailInfo1, detailInfo2) => {
         var _a;
-        return !matchesExclude(file, key === "watchFile" ? options == null ? void 0 : options.excludeFiles : options == null ? void 0 : options.excludeDirectories, useCaseSensitiveFileNames(), ((_a = host.getCurrentDirectory) == null ? void 0 : _a.call(host)) || "") ? factory2[key].call(
+        return !matchesExclude(file, key === "watchFile" ? options == null ? void 0 : options.excludeFiles : options == null ? void 0 : options.excludeDirectories, useCaseSensitiveFileNames2(), ((_a = host.getCurrentDirectory) == null ? void 0 : _a.call(host)) || "") ? factory2[key].call(
           /*thisArgs*/
           void 0,
           file,
@@ -215120,27 +200540,27 @@ ${lanes.join("\n")}
         ) : excludeWatcherFactory(file, flags, options, detailInfo1, detailInfo2);
       };
     }
-    function useCaseSensitiveFileNames() {
+    function useCaseSensitiveFileNames2() {
       return typeof host.useCaseSensitiveFileNames === "boolean" ? host.useCaseSensitiveFileNames : host.useCaseSensitiveFileNames();
     }
     function createExcludeWatcherWithLogging(file, flags, options, detailInfo1, detailInfo2) {
-      log(`ExcludeWatcher:: Added:: ${getWatchInfo(file, flags, options, detailInfo1, detailInfo2, getDetailWatchInfo)}`);
+      log(`ExcludeWatcher:: Added:: ${getWatchInfo(file, flags, options, detailInfo1, detailInfo2, getDetailWatchInfo2)}`);
       return {
-        close: () => log(`ExcludeWatcher:: Close:: ${getWatchInfo(file, flags, options, detailInfo1, detailInfo2, getDetailWatchInfo)}`)
+        close: () => log(`ExcludeWatcher:: Close:: ${getWatchInfo(file, flags, options, detailInfo1, detailInfo2, getDetailWatchInfo2)}`)
       };
     }
     function createFileWatcherWithLogging(file, cb, flags, options, detailInfo1, detailInfo2) {
-      log(`FileWatcher:: Added:: ${getWatchInfo(file, flags, options, detailInfo1, detailInfo2, getDetailWatchInfo)}`);
+      log(`FileWatcher:: Added:: ${getWatchInfo(file, flags, options, detailInfo1, detailInfo2, getDetailWatchInfo2)}`);
       const watcher = triggerInvokingFactory.watchFile(file, cb, flags, options, detailInfo1, detailInfo2);
       return {
         close: () => {
-          log(`FileWatcher:: Close:: ${getWatchInfo(file, flags, options, detailInfo1, detailInfo2, getDetailWatchInfo)}`);
+          log(`FileWatcher:: Close:: ${getWatchInfo(file, flags, options, detailInfo1, detailInfo2, getDetailWatchInfo2)}`);
           watcher.close();
         }
       };
     }
     function createDirectoryWatcherWithLogging(file, cb, flags, options, detailInfo1, detailInfo2) {
-      const watchInfo = `DirectoryWatcher:: Added:: ${getWatchInfo(file, flags, options, detailInfo1, detailInfo2, getDetailWatchInfo)}`;
+      const watchInfo = `DirectoryWatcher:: Added:: ${getWatchInfo(file, flags, options, detailInfo1, detailInfo2, getDetailWatchInfo2)}`;
       log(watchInfo);
       const start = timestamp();
       const watcher = triggerInvokingFactory.watchDirectory(file, cb, flags, options, detailInfo1, detailInfo2);
@@ -215148,7 +200568,7 @@ ${lanes.join("\n")}
       log(`Elapsed:: ${elapsed}ms ${watchInfo}`);
       return {
         close: () => {
-          const watchInfo2 = `DirectoryWatcher:: Close:: ${getWatchInfo(file, flags, options, detailInfo1, detailInfo2, getDetailWatchInfo)}`;
+          const watchInfo2 = `DirectoryWatcher:: Close:: ${getWatchInfo(file, flags, options, detailInfo1, detailInfo2, getDetailWatchInfo2)}`;
           log(watchInfo2);
           const start2 = timestamp();
           watcher.close();
@@ -215163,7 +200583,7 @@ ${lanes.join("\n")}
         void 0,
         file,
         (...args) => {
-          const triggerredInfo = `${key === "watchFile" ? "FileWatcher" : "DirectoryWatcher"}:: Triggered with ${args[0]} ${args[1] !== void 0 ? args[1] : ""}:: ${getWatchInfo(file, flags, options, detailInfo1, detailInfo2, getDetailWatchInfo)}`;
+          const triggerredInfo = `${key === "watchFile" ? "FileWatcher" : "DirectoryWatcher"}:: Triggered with ${args[0]} ${args[1] !== void 0 ? args[1] : ""}:: ${getWatchInfo(file, flags, options, detailInfo1, detailInfo2, getDetailWatchInfo2)}`;
           log(triggerredInfo);
           const start = timestamp();
           cb.call(
@@ -215180,8 +200600,8 @@ ${lanes.join("\n")}
         detailInfo2
       );
     }
-    function getWatchInfo(file, flags, options, detailInfo1, detailInfo2, getDetailWatchInfo2) {
-      return `WatchInfo: ${file} ${flags} ${JSON.stringify(options)} ${getDetailWatchInfo2 ? getDetailWatchInfo2(detailInfo1, detailInfo2) : detailInfo2 === void 0 ? detailInfo1 : `${detailInfo1} ${detailInfo2}`}`;
+    function getWatchInfo(file, flags, options, detailInfo1, detailInfo2, getDetailWatchInfo3) {
+      return `WatchInfo: ${file} ${flags} ${JSON.stringify(options)} ${getDetailWatchInfo3 ? getDetailWatchInfo3(detailInfo1, detailInfo2) : detailInfo2 === void 0 ? detailInfo1 : `${detailInfo1} ${detailInfo2}`}`;
     }
   }
   function getFallbackOptions(options) {
@@ -215193,17 +200613,18 @@ ${lanes.join("\n")}
   function closeFileWatcherOf(objWithWatcher) {
     objWithWatcher.watcher.close();
   }
-  var ConfigFileProgramReloadLevel, WatchLogLevel;
+  var ProgramUpdateLevel, WatchLogLevel;
   var init_watchUtilities = __esm({
     "src/compiler/watchUtilities.ts"() {
       "use strict";
       init_ts2();
-      ConfigFileProgramReloadLevel = /* @__PURE__ */ ((ConfigFileProgramReloadLevel2) => {
-        ConfigFileProgramReloadLevel2[ConfigFileProgramReloadLevel2["None"] = 0] = "None";
-        ConfigFileProgramReloadLevel2[ConfigFileProgramReloadLevel2["Partial"] = 1] = "Partial";
-        ConfigFileProgramReloadLevel2[ConfigFileProgramReloadLevel2["Full"] = 2] = "Full";
-        return ConfigFileProgramReloadLevel2;
-      })(ConfigFileProgramReloadLevel || {});
+      ProgramUpdateLevel = /* @__PURE__ */ ((ProgramUpdateLevel2) => {
+        ProgramUpdateLevel2[ProgramUpdateLevel2["Update"] = 0] = "Update";
+        ProgramUpdateLevel2[ProgramUpdateLevel2["RootNamesAndUpdate"] = 1] = "RootNamesAndUpdate";
+        ProgramUpdateLevel2[ProgramUpdateLevel2["Full"] = 2] = "Full";
+        ProgramUpdateLevel2[ProgramUpdateLevel2["Resolutions"] = 3] = "Resolutions";
+        return ProgramUpdateLevel2;
+      })(ProgramUpdateLevel || {});
       WatchLogLevel = /* @__PURE__ */ ((WatchLogLevel2) => {
         WatchLogLevel2[WatchLogLevel2["None"] = 0] = "None";
         WatchLogLevel2[WatchLogLevel2["TriggerOnly"] = 1] = "TriggerOnly";
@@ -215486,7 +200907,7 @@ ${lanes.join("\n")}
   function formatColorAndReset(text, formatStyle) {
     return formatStyle + text + resetEscapeSequence;
   }
-  function formatCodeSpan(file, start, length2, indent2, squiggleColor, host) {
+  function formatCodeSpan(file, start, length2, indent3, squiggleColor, host) {
     const { line: firstLine, character: firstLineChar } = getLineAndCharacterOfPosition(file, start);
     const { line: lastLine, character: lastLineChar } = getLineAndCharacterOfPosition(file, start + length2);
     const lastLineInFile = getLineAndCharacterOfPosition(file, file.text.length).line;
@@ -215499,17 +200920,17 @@ ${lanes.join("\n")}
     for (let i = firstLine; i <= lastLine; i++) {
       context += host.getNewLine();
       if (hasMoreThanFiveLines && firstLine + 1 < i && i < lastLine - 1) {
-        context += indent2 + formatColorAndReset(padLeft(ellipsis, gutterWidth), gutterStyleSequence) + gutterSeparator + host.getNewLine();
+        context += indent3 + formatColorAndReset(ellipsis.padStart(gutterWidth), gutterStyleSequence) + gutterSeparator + host.getNewLine();
         i = lastLine - 1;
       }
       const lineStart = getPositionOfLineAndCharacter(file, i, 0);
       const lineEnd = i < lastLineInFile ? getPositionOfLineAndCharacter(file, i + 1, 0) : file.text.length;
       let lineContent = file.text.slice(lineStart, lineEnd);
-      lineContent = trimStringEnd(lineContent);
+      lineContent = lineContent.trimEnd();
       lineContent = lineContent.replace(/\t/g, " ");
-      context += indent2 + formatColorAndReset(padLeft(i + 1 + "", gutterWidth), gutterStyleSequence) + gutterSeparator;
+      context += indent3 + formatColorAndReset((i + 1 + "").padStart(gutterWidth), gutterStyleSequence) + gutterSeparator;
       context += lineContent + host.getNewLine();
-      context += indent2 + formatColorAndReset(padLeft("", gutterWidth), gutterStyleSequence) + gutterSeparator;
+      context += indent3 + formatColorAndReset("".padStart(gutterWidth), gutterStyleSequence) + gutterSeparator;
       context += squiggleColor;
       if (i === firstLine) {
         const lastCharForLine = i === lastLine ? lastLineChar : void 0;
@@ -215566,24 +200987,24 @@ ${lanes.join("\n")}
     }
     return output;
   }
-  function flattenDiagnosticMessageText(diag2, newLine, indent2 = 0) {
+  function flattenDiagnosticMessageText(diag2, newLine, indent3 = 0) {
     if (isString(diag2)) {
       return diag2;
     } else if (diag2 === void 0) {
       return "";
     }
     let result = "";
-    if (indent2) {
+    if (indent3) {
       result += newLine;
-      for (let i = 0; i < indent2; i++) {
+      for (let i = 0; i < indent3; i++) {
         result += "  ";
       }
     }
     result += diag2.messageText;
-    indent2++;
+    indent3++;
     if (diag2.next) {
       for (const kid of diag2.next) {
-        result += flattenDiagnosticMessageText(kid, newLine, indent2);
+        result += flattenDiagnosticMessageText(kid, newLine, indent3);
       }
     }
     return result;
@@ -215592,8 +201013,6 @@ ${lanes.join("\n")}
     return (isString(ref) ? containingFileMode : ref.resolutionMode) || containingFileMode;
   }
   function getModeForResolutionAtIndex(file, index) {
-    if (file.impliedNodeFormat === void 0)
-      return void 0;
     return getModeForUsageLocation(file, getModuleNameStringLiteralAt(file, index));
   }
   function isExclusivelyTypeOnlyImportOrExport(decl) {
@@ -215607,42 +201026,48 @@ ${lanes.join("\n")}
     return false;
   }
   function getModeForUsageLocation(file, usage) {
-    var _a, _b;
-    if (file.impliedNodeFormat === void 0)
-      return void 0;
+    var _a;
     if (isImportDeclaration(usage.parent) || isExportDeclaration(usage.parent)) {
       const isTypeOnly = isExclusivelyTypeOnlyImportOrExport(usage.parent);
       if (isTypeOnly) {
-        const override = getResolutionModeOverrideForClause(usage.parent.assertClause);
+        const override = getResolutionModeOverride(usage.parent.attributes);
         if (override) {
           return override;
         }
       }
     }
     if (usage.parent.parent && isImportTypeNode(usage.parent.parent)) {
-      const override = getResolutionModeOverrideForClause((_a = usage.parent.parent.assertions) == null ? void 0 : _a.assertClause);
+      const override = getResolutionModeOverride(usage.parent.parent.attributes);
       if (override) {
         return override;
       }
     }
+    if (file.impliedNodeFormat === void 0)
+      return void 0;
     if (file.impliedNodeFormat !== 99 /* ESNext */) {
       return isImportCall(walkUpParenthesizedExpressions(usage.parent)) ? 99 /* ESNext */ : 1 /* CommonJS */;
     }
-    const exprParentParent = (_b = walkUpParenthesizedExpressions(usage.parent)) == null ? void 0 : _b.parent;
+    const exprParentParent = (_a = walkUpParenthesizedExpressions(usage.parent)) == null ? void 0 : _a.parent;
     return exprParentParent && isImportEqualsDeclaration(exprParentParent) ? 1 /* CommonJS */ : 99 /* ESNext */;
   }
-  function getResolutionModeOverrideForClause(clause, grammarErrorOnNode) {
-    if (!clause)
+  function getResolutionModeOverride(node, grammarErrorOnNode) {
+    if (!node)
       return void 0;
-    if (length(clause.elements) !== 1) {
-      grammarErrorOnNode == null ? void 0 : grammarErrorOnNode(clause, Diagnostics.Type_import_assertions_should_have_exactly_one_key_resolution_mode_with_value_import_or_require);
+    if (length(node.elements) !== 1) {
+      grammarErrorOnNode == null ? void 0 : grammarErrorOnNode(
+        node,
+        node.token === 118 /* WithKeyword */ ? Diagnostics.Type_import_attributes_should_have_exactly_one_key_resolution_mode_with_value_import_or_require : Diagnostics.Type_import_assertions_should_have_exactly_one_key_resolution_mode_with_value_import_or_require
+      );
       return void 0;
     }
-    const elem = clause.elements[0];
+    const elem = node.elements[0];
     if (!isStringLiteralLike(elem.name))
       return void 0;
     if (elem.name.text !== "resolution-mode") {
-      grammarErrorOnNode == null ? void 0 : grammarErrorOnNode(elem.name, Diagnostics.resolution_mode_is_the_only_valid_key_for_type_import_assertions);
+      grammarErrorOnNode == null ? void 0 : grammarErrorOnNode(
+        elem.name,
+        node.token === 118 /* WithKeyword */ ? Diagnostics.resolution_mode_is_the_only_valid_key_for_type_import_attributes : Diagnostics.resolution_mode_is_the_only_valid_key_for_type_import_assertions
+      );
       return void 0;
     }
     if (!isStringLiteralLike(elem.value))
@@ -215772,15 +201197,15 @@ ${lanes.join("\n")}
   function isReferenceFileLocation(location) {
     return location.pos !== void 0;
   }
-  function getReferencedFileLocation(getSourceFileByPath, ref) {
-    var _a, _b, _c, _d, _e, _f;
-    const file = Debug.checkDefined(getSourceFileByPath(ref.file));
+  function getReferencedFileLocation(program, ref) {
+    var _a, _b, _c, _d;
+    const file = Debug.checkDefined(program.getSourceFileByPath(ref.file));
     const { kind, index } = ref;
     let pos, end, packageId, resolutionMode;
     switch (kind) {
       case 3 /* Import */:
         const importLiteral = getModuleNameStringLiteralAt(file, index);
-        packageId = (_c = (_b = (_a = file.resolvedModules) == null ? void 0 : _a.get(importLiteral.text, getModeForResolutionAtIndex(file, index))) == null ? void 0 : _b.resolvedModule) == null ? void 0 : _c.packageId;
+        packageId = (_b = (_a = program.getResolvedModule(file, importLiteral.text, getModeForResolutionAtIndex(file, index))) == null ? void 0 : _a.resolvedModule) == null ? void 0 : _b.packageId;
         if (importLiteral.pos === -1)
           return { file, packageId, text: importLiteral.text };
         pos = skipTrivia(file.text, importLiteral.pos);
@@ -215791,7 +201216,7 @@ ${lanes.join("\n")}
         break;
       case 5 /* TypeReferenceDirective */:
         ({ pos, end, resolutionMode } = file.typeReferenceDirectives[index]);
-        packageId = (_f = (_e = (_d = file.resolvedTypeReferenceDirectiveNames) == null ? void 0 : _d.get(toFileNameLowerCase(file.typeReferenceDirectives[index].fileName), resolutionMode || file.impliedNodeFormat)) == null ? void 0 : _e.resolvedTypeReferenceDirective) == null ? void 0 : _f.packageId;
+        packageId = (_d = (_c = program.getResolvedTypeReferenceDirective(file, toFileNameLowerCase(file.typeReferenceDirectives[index].fileName), resolutionMode || file.impliedNodeFormat)) == null ? void 0 : _c.resolvedTypeReferenceDirective) == null ? void 0 : _d.packageId;
         break;
       case 7 /* LibReferenceDirective */:
         ({ pos, end } = file.libReferenceDirectives[index]);
@@ -215912,6 +201337,10 @@ ${lanes.join("\n")}
     let automaticTypeDirectiveResolutions;
     let resolvedLibReferences;
     let resolvedLibProcessing;
+    let resolvedModules;
+    let resolvedModulesProcessing;
+    let resolvedTypeReferenceDirectiveNames;
+    let resolvedTypeReferenceDirectiveNamesProcessing;
     let packageMap;
     const maxNodeModuleJsDepth = typeof options.maxNodeModuleJsDepth === "number" ? options.maxNodeModuleJsDepth : 0;
     let currentNodeModulesDepth = 0;
@@ -215987,7 +201416,8 @@ ${lanes.join("\n")}
         getCanonicalFileName,
         /*options*/
         void 0,
-        moduleResolutionCache == null ? void 0 : moduleResolutionCache.getPackageJsonInfoCache()
+        moduleResolutionCache == null ? void 0 : moduleResolutionCache.getPackageJsonInfoCache(),
+        moduleResolutionCache == null ? void 0 : moduleResolutionCache.optionsToRedirectsKey
       );
       actualResolveTypeReferenceDirectiveNamesWorker = (typeDirectiveNames, containingFile, redirectedReference, options2, containingSourceFile) => loadWithModeAwareCache(
         typeDirectiveNames,
@@ -216175,6 +201605,8 @@ ${lanes.join("\n")}
     }
     oldProgram = void 0;
     resolvedLibProcessing = void 0;
+    resolvedModulesProcessing = void 0;
+    resolvedTypeReferenceDirectiveNamesProcessing = void 0;
     const program = {
       getRootFileNames: () => rootNames,
       getSourceFile,
@@ -216216,7 +201648,13 @@ ${lanes.join("\n")}
       sourceFileToPackageName,
       redirectTargetsMap,
       usesUriStyleNodeCoreModules,
+      resolvedModules,
+      resolvedTypeReferenceDirectiveNames,
       resolvedLibReferences,
+      getResolvedModule,
+      getResolvedTypeReferenceDirective,
+      forEachResolvedModule,
+      forEachResolvedTypeReferenceDirective,
       getCurrentPackagesMap: () => packageMap,
       typesPackageExists,
       packageBundlesTypes,
@@ -216247,7 +201685,7 @@ ${lanes.join("\n")}
         case 1 /* FilePreprocessingFileExplainingDiagnostic */:
           return programDiagnostics.add(createDiagnosticExplainingFile(diagnostic.file && getSourceFileByPath(diagnostic.file), diagnostic.fileProcessingReason, diagnostic.diagnostic, diagnostic.args || emptyArray));
         case 0 /* FilePreprocessingReferencedDiagnostic */:
-          const { file, pos, end } = getReferencedFileLocation(getSourceFileByPath, diagnostic.reason);
+          const { file, pos, end } = getReferencedFileLocation(program, diagnostic.reason);
           return programDiagnostics.add(createFileDiagnostic(file, Debug.checkDefined(pos), Debug.checkDefined(end) - pos, diagnostic.diagnostic, ...diagnostic.args || emptyArray));
         case 2 /* ResolutionDiagnostics */:
           return diagnostic.diagnostics.forEach((d) => programDiagnostics.add(d));
@@ -216260,17 +201698,34 @@ ${lanes.join("\n")}
     measure("Program", "beforeProgram", "afterProgram");
     (_p = tracing) == null ? void 0 : _p.pop();
     return program;
+    function getResolvedModule(file, moduleName, mode) {
+      var _a2;
+      return (_a2 = resolvedModules == null ? void 0 : resolvedModules.get(file.path)) == null ? void 0 : _a2.get(moduleName, mode);
+    }
+    function getResolvedTypeReferenceDirective(file, typeDirectiveName, mode) {
+      var _a2;
+      return (_a2 = resolvedTypeReferenceDirectiveNames == null ? void 0 : resolvedTypeReferenceDirectiveNames.get(file.path)) == null ? void 0 : _a2.get(typeDirectiveName, mode);
+    }
+    function forEachResolvedModule(callback, file) {
+      forEachResolution(resolvedModules, callback, file);
+    }
+    function forEachResolvedTypeReferenceDirective(callback, file) {
+      forEachResolution(resolvedTypeReferenceDirectiveNames, callback, file);
+    }
+    function forEachResolution(resolutionCache, callback, file) {
+      var _a2;
+      if (file)
+        (_a2 = resolutionCache == null ? void 0 : resolutionCache.get(file.path)) == null ? void 0 : _a2.forEach((resolution, name, mode) => callback(resolution, name, mode, file.path));
+      else
+        resolutionCache == null ? void 0 : resolutionCache.forEach((resolutions, filePath) => resolutions.forEach((resolution, name, mode) => callback(resolution, name, mode, filePath)));
+    }
     function getPackagesMap() {
       if (packageMap)
         return packageMap;
       packageMap = /* @__PURE__ */ new Map();
-      files.forEach((sf) => {
-        if (!sf.resolvedModules)
-          return;
-        sf.resolvedModules.forEach(({ resolvedModule }) => {
-          if (resolvedModule == null ? void 0 : resolvedModule.packageId)
-            packageMap.set(resolvedModule.packageId.name, resolvedModule.extension === ".d.ts" /* Dts */ || !!packageMap.get(resolvedModule.packageId.name));
-        });
+      forEachResolvedModule(({ resolvedModule }) => {
+        if (resolvedModule == null ? void 0 : resolvedModule.packageId)
+          packageMap.set(resolvedModule.packageId.name, resolvedModule.extension === ".d.ts" /* Dts */ || !!packageMap.get(resolvedModule.packageId.name));
       });
       return packageMap;
     }
@@ -216337,7 +201792,7 @@ ${lanes.join("\n")}
       const resultFromDts = getRedirectReferenceForResolutionFromSourceOfProject(file.path);
       if (resultFromDts)
         return resultFromDts;
-      if (!host.realpath || !options.preserveSymlinks || !stringContains(file.originalFileName, nodeModulesPathPart))
+      if (!host.realpath || !options.preserveSymlinks || !file.originalFileName.includes(nodeModulesPathPart))
         return void 0;
       const realDeclarationPath = toPath3(host.realpath(file.originalFileName));
       return realDeclarationPath === file.path ? void 0 : getRedirectReferenceForResolutionFromSourceOfProject(realDeclarationPath);
@@ -216403,7 +201858,6 @@ ${lanes.join("\n")}
       return classifiableNames;
     }
     function resolveModuleNamesReusingOldState(moduleNames, file) {
-      var _a2;
       if (structureIsReused === 0 /* Not */ && !file.ambientModuleNames.length) {
         return resolveModuleNamesWorker(
           moduleNames,
@@ -216412,24 +201866,16 @@ ${lanes.join("\n")}
           void 0
         );
       }
-      const oldSourceFile = oldProgram && oldProgram.getSourceFile(file.fileName);
-      if (oldSourceFile !== file && file.resolvedModules) {
-        const result2 = [];
-        for (const moduleName of moduleNames) {
-          const resolvedModule = file.resolvedModules.get(moduleName.text, getModeForUsageLocation(file, moduleName));
-          result2.push(resolvedModule);
-        }
-        return result2;
-      }
       let unknownModuleNames;
       let result;
       let reusedNames;
       const predictedToResolveToAmbientModuleMarker = emptyResolution;
+      const oldSourceFile = oldProgram && oldProgram.getSourceFile(file.fileName);
       for (let i = 0; i < moduleNames.length; i++) {
         const moduleName = moduleNames[i];
-        if (file === oldSourceFile && !hasInvalidatedResolutions(oldSourceFile.path)) {
+        if (file === oldSourceFile && !hasInvalidatedResolutions(file.path)) {
           const mode = getModeForUsageLocation(file, moduleName);
-          const oldResolution = (_a2 = oldSourceFile.resolvedModules) == null ? void 0 : _a2.get(moduleName.text, mode);
+          const oldResolution = oldProgram == null ? void 0 : oldProgram.getResolvedModule(file, moduleName.text, mode);
           if (oldResolution == null ? void 0 : oldResolution.resolvedModule) {
             if (isTraceEnabled(options, host)) {
               trace(
@@ -216476,7 +201922,8 @@ ${lanes.join("\n")}
       Debug.assert(j === resolutions.length);
       return result;
       function moduleNameResolvesToAmbientModuleInNonModifiedFile(moduleName) {
-        const resolutionToFile = getResolvedModule(oldSourceFile, moduleName.text, getModeForUsageLocation(file, moduleName));
+        var _a2;
+        const resolutionToFile = (_a2 = oldProgram == null ? void 0 : oldProgram.getResolvedModule(file, moduleName.text, getModeForUsageLocation(file, moduleName))) == null ? void 0 : _a2.resolvedModule;
         const resolvedFile = resolutionToFile && oldProgram.getSourceFile(resolutionToFile.resolvedFileName);
         if (resolutionToFile && resolvedFile) {
           return false;
@@ -216501,28 +201948,18 @@ ${lanes.join("\n")}
           void 0
         );
       }
-      const oldSourceFile = !isString(containingFile) ? oldProgram && oldProgram.getSourceFile(containingFile.fileName) : void 0;
-      if (!isString(containingFile)) {
-        if (oldSourceFile !== containingFile && containingFile.resolvedTypeReferenceDirectiveNames) {
-          const result2 = [];
-          for (const typeDirectiveName of typeDirectiveNames) {
-            const resolvedTypeReferenceDirective = containingFile.resolvedTypeReferenceDirectiveNames.get(getTypeReferenceResolutionName(typeDirectiveName), getModeForFileReference(typeDirectiveName, containingFile.impliedNodeFormat));
-            result2.push(resolvedTypeReferenceDirective);
-          }
-          return result2;
-        }
-      }
       let unknownTypeReferenceDirectiveNames;
       let result;
       let reusedNames;
       const containingSourceFile = !isString(containingFile) ? containingFile : void 0;
-      const canReuseResolutions = !isString(containingFile) ? containingFile === oldSourceFile && !hasInvalidatedResolutions(oldSourceFile.path) : !hasInvalidatedResolutions(toPath3(containingFile));
+      const oldSourceFile = !isString(containingFile) ? oldProgram && oldProgram.getSourceFile(containingFile.fileName) : void 0;
+      const canReuseResolutions = !isString(containingFile) ? containingFile === oldSourceFile && !hasInvalidatedResolutions(containingFile.path) : !hasInvalidatedResolutions(toPath3(containingFile));
       for (let i = 0; i < typeDirectiveNames.length; i++) {
         const entry = typeDirectiveNames[i];
         if (canReuseResolutions) {
           const typeDirectiveName = getTypeReferenceResolutionName(entry);
           const mode = getModeForFileReference(entry, containingSourceFile == null ? void 0 : containingSourceFile.impliedNodeFormat);
-          const oldResolution = (_a2 = !isString(containingFile) ? oldSourceFile == null ? void 0 : oldSourceFile.resolvedTypeReferenceDirectiveNames : oldProgram == null ? void 0 : oldProgram.getAutomaticTypeDirectiveResolutions()) == null ? void 0 : _a2.get(typeDirectiveName, mode);
+          const oldResolution = !isString(containingFile) ? oldProgram == null ? void 0 : oldProgram.getResolvedTypeReferenceDirective(containingFile, typeDirectiveName, mode) : (_a2 = oldProgram == null ? void 0 : oldProgram.getAutomaticTypeDirectiveResolutions()) == null ? void 0 : _a2.get(typeDirectiveName, mode);
           if (oldResolution == null ? void 0 : oldResolution.resolvedTypeReferenceDirective) {
             if (isTraceEnabled(options, host)) {
               trace(
@@ -216621,13 +202058,13 @@ ${lanes.join("\n")}
           sourceFileOptions,
           /*onError*/
           void 0,
-          shouldCreateNewSourceFile || sourceFileOptions.impliedNodeFormat !== oldSourceFile.impliedNodeFormat
+          shouldCreateNewSourceFile
         ) : host.getSourceFile(
           oldSourceFile.fileName,
           sourceFileOptions,
           /*onError*/
           void 0,
-          shouldCreateNewSourceFile || sourceFileOptions.impliedNodeFormat !== oldSourceFile.impliedNodeFormat
+          shouldCreateNewSourceFile
         );
         if (!newSourceFile) {
           return 0 /* Not */;
@@ -216678,49 +202115,53 @@ ${lanes.join("\n")}
               structureIsReused = 1 /* SafeModules */;
             } else if (!arrayIsEqualTo(oldSourceFile.moduleAugmentations, newSourceFile.moduleAugmentations, moduleNameIsEqualTo)) {
               structureIsReused = 1 /* SafeModules */;
-            } else if ((oldSourceFile.flags & 6291456 /* PermanentlySetIncrementalFlags */) !== (newSourceFile.flags & 6291456 /* PermanentlySetIncrementalFlags */)) {
+            } else if ((oldSourceFile.flags & 12582912 /* PermanentlySetIncrementalFlags */) !== (newSourceFile.flags & 12582912 /* PermanentlySetIncrementalFlags */)) {
               structureIsReused = 1 /* SafeModules */;
             } else if (!arrayIsEqualTo(oldSourceFile.typeReferenceDirectives, newSourceFile.typeReferenceDirectives, fileReferenceIsEqualTo)) {
               structureIsReused = 1 /* SafeModules */;
             }
           }
-          modifiedSourceFiles.push({ oldFile: oldSourceFile, newFile: newSourceFile });
+          modifiedSourceFiles.push(newSourceFile);
         } else if (hasInvalidatedResolutions(oldSourceFile.path)) {
           structureIsReused = 1 /* SafeModules */;
-          modifiedSourceFiles.push({ oldFile: oldSourceFile, newFile: newSourceFile });
+          modifiedSourceFiles.push(newSourceFile);
+        } else {
+          for (const moduleName of oldSourceFile.ambientModuleNames) {
+            ambientModuleNameToUnmodifiedFileName.set(moduleName, oldSourceFile.fileName);
+          }
         }
         newSourceFiles.push(newSourceFile);
       }
       if (structureIsReused !== 2 /* Completely */) {
         return structureIsReused;
       }
-      const modifiedFiles = modifiedSourceFiles.map((f) => f.oldFile);
-      for (const oldFile of oldSourceFiles) {
-        if (!contains(modifiedFiles, oldFile)) {
-          for (const moduleName of oldFile.ambientModuleNames) {
-            ambientModuleNameToUnmodifiedFileName.set(moduleName, oldFile.fileName);
-          }
-        }
-      }
-      for (const { oldFile: oldSourceFile, newFile: newSourceFile } of modifiedSourceFiles) {
+      for (const newSourceFile of modifiedSourceFiles) {
         const moduleNames = getModuleNames(newSourceFile);
         const resolutions = resolveModuleNamesReusingOldState(moduleNames, newSourceFile);
-        const resolutionsChanged = hasChangesInResolutions(moduleNames, newSourceFile, resolutions, oldSourceFile.resolvedModules, moduleResolutionIsEqualTo, moduleResolutionNameAndModeGetter);
-        if (resolutionsChanged) {
+        (resolvedModulesProcessing ?? (resolvedModulesProcessing = /* @__PURE__ */ new Map())).set(newSourceFile.path, resolutions);
+        const resolutionsChanged = hasChangesInResolutions(
+          moduleNames,
+          newSourceFile,
+          resolutions,
+          (name, mode) => oldProgram.getResolvedModule(newSourceFile, name, mode),
+          moduleResolutionIsEqualTo,
+          moduleResolutionNameAndModeGetter
+        );
+        if (resolutionsChanged)
           structureIsReused = 1 /* SafeModules */;
-          newSourceFile.resolvedModules = zipToModeAwareCache(newSourceFile, moduleNames, resolutions, moduleResolutionNameAndModeGetter);
-        } else {
-          newSourceFile.resolvedModules = oldSourceFile.resolvedModules;
-        }
         const typesReferenceDirectives = newSourceFile.typeReferenceDirectives;
         const typeReferenceResolutions = resolveTypeReferenceDirectiveNamesReusingOldState(typesReferenceDirectives, newSourceFile);
-        const typeReferenceResolutionsChanged = hasChangesInResolutions(typesReferenceDirectives, newSourceFile, typeReferenceResolutions, oldSourceFile.resolvedTypeReferenceDirectiveNames, typeDirectiveIsEqualTo, typeReferenceResolutionNameAndModeGetter);
-        if (typeReferenceResolutionsChanged) {
+        (resolvedTypeReferenceDirectiveNamesProcessing ?? (resolvedTypeReferenceDirectiveNamesProcessing = /* @__PURE__ */ new Map())).set(newSourceFile.path, typeReferenceResolutions);
+        const typeReferenceResolutionsChanged = hasChangesInResolutions(
+          typesReferenceDirectives,
+          newSourceFile,
+          typeReferenceResolutions,
+          (name, mode) => oldProgram == null ? void 0 : oldProgram.getResolvedTypeReferenceDirective(newSourceFile, name, mode),
+          typeDirectiveIsEqualTo,
+          typeReferenceResolutionNameAndModeGetter
+        );
+        if (typeReferenceResolutionsChanged)
           structureIsReused = 1 /* SafeModules */;
-          newSourceFile.resolvedTypeReferenceDirectiveNames = zipToModeAwareCache(newSourceFile, typesReferenceDirectives, typeReferenceResolutions, typeReferenceResolutionNameAndModeGetter);
-        } else {
-          newSourceFile.resolvedTypeReferenceDirectiveNames = oldSourceFile.resolvedTypeReferenceDirectiveNames;
-        }
       }
       if (structureIsReused !== 2 /* Completely */) {
         return structureIsReused;
@@ -216767,6 +202208,8 @@ ${lanes.join("\n")}
       sourceFileToPackageName = oldProgram.sourceFileToPackageName;
       redirectTargetsMap = oldProgram.redirectTargetsMap;
       usesUriStyleNodeCoreModules = oldProgram.usesUriStyleNodeCoreModules;
+      resolvedModules = oldProgram.resolvedModules;
+      resolvedTypeReferenceDirectiveNames = oldProgram.resolvedTypeReferenceDirectiveNames;
       resolvedLibReferences = oldProgram.resolvedLibReferences;
       packageMap = oldProgram.getCurrentPackagesMap();
       return 2 /* Completely */;
@@ -217069,89 +202512,97 @@ ${lanes.join("\n")}
         return diagnostics;
         function walk(node, parent2) {
           switch (parent2.kind) {
-            case 168 /* Parameter */:
-            case 171 /* PropertyDeclaration */:
-            case 173 /* MethodDeclaration */:
+            case 169 /* Parameter */:
+            case 172 /* PropertyDeclaration */:
+            case 174 /* MethodDeclaration */:
               if (parent2.questionToken === node) {
                 diagnostics.push(createDiagnosticForNode2(node, Diagnostics.The_0_modifier_can_only_be_used_in_TypeScript_files, "?"));
                 return "skip";
               }
-            case 172 /* MethodSignature */:
-            case 175 /* Constructor */:
-            case 176 /* GetAccessor */:
-            case 177 /* SetAccessor */:
-            case 217 /* FunctionExpression */:
-            case 261 /* FunctionDeclaration */:
-            case 218 /* ArrowFunction */:
-            case 259 /* VariableDeclaration */:
+            case 173 /* MethodSignature */:
+            case 176 /* Constructor */:
+            case 177 /* GetAccessor */:
+            case 178 /* SetAccessor */:
+            case 218 /* FunctionExpression */:
+            case 262 /* FunctionDeclaration */:
+            case 219 /* ArrowFunction */:
+            case 260 /* VariableDeclaration */:
               if (parent2.type === node) {
                 diagnostics.push(createDiagnosticForNode2(node, Diagnostics.Type_annotations_can_only_be_used_in_TypeScript_files));
                 return "skip";
               }
           }
           switch (node.kind) {
-            case 272 /* ImportClause */:
+            case 273 /* ImportClause */:
               if (node.isTypeOnly) {
                 diagnostics.push(createDiagnosticForNode2(parent2, Diagnostics._0_declarations_can_only_be_used_in_TypeScript_files, "import type"));
                 return "skip";
               }
               break;
-            case 277 /* ExportDeclaration */:
+            case 278 /* ExportDeclaration */:
               if (node.isTypeOnly) {
                 diagnostics.push(createDiagnosticForNode2(node, Diagnostics._0_declarations_can_only_be_used_in_TypeScript_files, "export type"));
                 return "skip";
               }
               break;
-            case 275 /* ImportSpecifier */:
-            case 280 /* ExportSpecifier */:
+            case 276 /* ImportSpecifier */:
+            case 281 /* ExportSpecifier */:
               if (node.isTypeOnly) {
                 diagnostics.push(createDiagnosticForNode2(node, Diagnostics._0_declarations_can_only_be_used_in_TypeScript_files, isImportSpecifier(node) ? "import...type" : "export...type"));
                 return "skip";
               }
               break;
-            case 270 /* ImportEqualsDeclaration */:
+            case 271 /* ImportEqualsDeclaration */:
               diagnostics.push(createDiagnosticForNode2(node, Diagnostics.import_can_only_be_used_in_TypeScript_files));
               return "skip";
-            case 276 /* ExportAssignment */:
+            case 277 /* ExportAssignment */:
               if (node.isExportEquals) {
                 diagnostics.push(createDiagnosticForNode2(node, Diagnostics.export_can_only_be_used_in_TypeScript_files));
                 return "skip";
               }
               break;
-            case 297 /* HeritageClause */:
+            case 298 /* HeritageClause */:
               const heritageClause = node;
               if (heritageClause.token === 119 /* ImplementsKeyword */) {
                 diagnostics.push(createDiagnosticForNode2(node, Diagnostics.implements_clauses_can_only_be_used_in_TypeScript_files));
                 return "skip";
               }
               break;
-            case 263 /* InterfaceDeclaration */:
+            case 264 /* InterfaceDeclaration */:
               const interfaceKeyword = tokenToString(120 /* InterfaceKeyword */);
               Debug.assertIsDefined(interfaceKeyword);
               diagnostics.push(createDiagnosticForNode2(node, Diagnostics._0_declarations_can_only_be_used_in_TypeScript_files, interfaceKeyword));
               return "skip";
-            case 266 /* ModuleDeclaration */:
-              const moduleKeyword = node.flags & 16 /* Namespace */ ? tokenToString(145 /* NamespaceKeyword */) : tokenToString(144 /* ModuleKeyword */);
+            case 267 /* ModuleDeclaration */:
+              const moduleKeyword = node.flags & 32 /* Namespace */ ? tokenToString(145 /* NamespaceKeyword */) : tokenToString(144 /* ModuleKeyword */);
               Debug.assertIsDefined(moduleKeyword);
               diagnostics.push(createDiagnosticForNode2(node, Diagnostics._0_declarations_can_only_be_used_in_TypeScript_files, moduleKeyword));
               return "skip";
-            case 264 /* TypeAliasDeclaration */:
+            case 265 /* TypeAliasDeclaration */:
               diagnostics.push(createDiagnosticForNode2(node, Diagnostics.Type_aliases_can_only_be_used_in_TypeScript_files));
               return "skip";
-            case 265 /* EnumDeclaration */:
+            case 176 /* Constructor */:
+            case 174 /* MethodDeclaration */:
+            case 262 /* FunctionDeclaration */:
+              if (!node.body) {
+                diagnostics.push(createDiagnosticForNode2(node, Diagnostics.Signature_declarations_can_only_be_used_in_TypeScript_files));
+                return "skip";
+              }
+              return;
+            case 266 /* EnumDeclaration */:
               const enumKeyword = Debug.checkDefined(tokenToString(94 /* EnumKeyword */));
               diagnostics.push(createDiagnosticForNode2(node, Diagnostics._0_declarations_can_only_be_used_in_TypeScript_files, enumKeyword));
               return "skip";
-            case 234 /* NonNullExpression */:
+            case 235 /* NonNullExpression */:
               diagnostics.push(createDiagnosticForNode2(node, Diagnostics.Non_null_assertions_can_only_be_used_in_TypeScript_files));
               return "skip";
-            case 233 /* AsExpression */:
+            case 234 /* AsExpression */:
               diagnostics.push(createDiagnosticForNode2(node.type, Diagnostics.Type_assertion_expressions_can_only_be_used_in_TypeScript_files));
               return "skip";
-            case 237 /* SatisfiesExpression */:
+            case 238 /* SatisfiesExpression */:
               diagnostics.push(createDiagnosticForNode2(node.type, Diagnostics.Type_satisfaction_expressions_can_only_be_used_in_TypeScript_files));
               return "skip";
-            case 215 /* TypeAssertionExpression */:
+            case 216 /* TypeAssertionExpression */:
               Debug.fail();
           }
         }
@@ -217186,26 +202637,26 @@ ${lanes.join("\n")}
             }
           }
           switch (parent2.kind) {
-            case 262 /* ClassDeclaration */:
-            case 230 /* ClassExpression */:
-            case 173 /* MethodDeclaration */:
-            case 175 /* Constructor */:
-            case 176 /* GetAccessor */:
-            case 177 /* SetAccessor */:
-            case 217 /* FunctionExpression */:
-            case 261 /* FunctionDeclaration */:
-            case 218 /* ArrowFunction */:
+            case 263 /* ClassDeclaration */:
+            case 231 /* ClassExpression */:
+            case 174 /* MethodDeclaration */:
+            case 176 /* Constructor */:
+            case 177 /* GetAccessor */:
+            case 178 /* SetAccessor */:
+            case 218 /* FunctionExpression */:
+            case 262 /* FunctionDeclaration */:
+            case 219 /* ArrowFunction */:
               if (nodes === parent2.typeParameters) {
                 diagnostics.push(createDiagnosticForNodeArray2(nodes, Diagnostics.Type_parameter_declarations_can_only_be_used_in_TypeScript_files));
                 return "skip";
               }
-            case 242 /* VariableStatement */:
+            case 243 /* VariableStatement */:
               if (nodes === parent2.modifiers) {
-                checkModifiers(parent2.modifiers, parent2.kind === 242 /* VariableStatement */);
+                checkModifiers(parent2.modifiers, parent2.kind === 243 /* VariableStatement */);
                 return "skip";
               }
               break;
-            case 171 /* PropertyDeclaration */:
+            case 172 /* PropertyDeclaration */:
               if (nodes === parent2.modifiers) {
                 for (const modifier of nodes) {
                   if (isModifier(modifier) && modifier.kind !== 126 /* StaticKeyword */ && modifier.kind !== 129 /* AccessorKeyword */) {
@@ -217215,18 +202666,18 @@ ${lanes.join("\n")}
                 return "skip";
               }
               break;
-            case 168 /* Parameter */:
+            case 169 /* Parameter */:
               if (nodes === parent2.modifiers && some(nodes, isModifier)) {
                 diagnostics.push(createDiagnosticForNodeArray2(nodes, Diagnostics.Parameter_modifiers_can_only_be_used_in_TypeScript_files));
                 return "skip";
               }
               break;
-            case 212 /* CallExpression */:
-            case 213 /* NewExpression */:
-            case 232 /* ExpressionWithTypeArguments */:
-            case 284 /* JsxSelfClosingElement */:
-            case 285 /* JsxOpeningElement */:
-            case 214 /* TaggedTemplateExpression */:
+            case 213 /* CallExpression */:
+            case 214 /* NewExpression */:
+            case 233 /* ExpressionWithTypeArguments */:
+            case 285 /* JsxSelfClosingElement */:
+            case 286 /* JsxOpeningElement */:
+            case 215 /* TaggedTemplateExpression */:
               if (nodes === parent2.typeArguments) {
                 diagnostics.push(createDiagnosticForNodeArray2(nodes, Diagnostics.Type_arguments_can_only_be_used_in_TypeScript_files));
                 return "skip";
@@ -217247,7 +202698,7 @@ ${lanes.join("\n")}
               case 148 /* ReadonlyKeyword */:
               case 138 /* DeclareKeyword */:
               case 128 /* AbstractKeyword */:
-              case 163 /* OverrideKeyword */:
+              case 164 /* OverrideKeyword */:
               case 103 /* InKeyword */:
               case 147 /* OutKeyword */:
                 diagnostics.push(createDiagnosticForNode2(modifier, Diagnostics.The_0_modifier_can_only_be_used_in_TypeScript_files, tokenToString(modifier.kind)));
@@ -217339,14 +202790,14 @@ ${lanes.join("\n")}
         /*importClause*/
         void 0,
         externalHelpersModuleReference,
-        /*assertClause*/
+        /*attributes*/
         void 0
       );
       addInternalEmitFlags(importDecl, 2 /* NeverApplyImportHelper */);
       setParent(externalHelpersModuleReference, importDecl);
       setParent(importDecl, file);
-      externalHelpersModuleReference.flags &= ~8 /* Synthesized */;
-      importDecl.flags &= ~8 /* Synthesized */;
+      externalHelpersModuleReference.flags &= ~16 /* Synthesized */;
+      importDecl.flags &= ~16 /* Synthesized */;
       return externalHelpersModuleReference;
     }
     function collectExternalModuleReferences(file) {
@@ -217375,7 +202826,7 @@ ${lanes.join("\n")}
         );
       }
       const shouldProcessRequires = isJavaScriptFile && shouldResolveJsRequire(options);
-      if (file.flags & 2097152 /* PossiblyContainsDynamicImport */ || shouldProcessRequires) {
+      if (file.flags & 4194304 /* PossiblyContainsDynamicImport */ || shouldProcessRequires) {
         collectDynamicImportOrRequireCalls(file);
       }
       file.imports = imports || emptyArray;
@@ -217397,7 +202848,7 @@ ${lanes.join("\n")}
             }
           }
         } else if (isModuleDeclaration(node)) {
-          if (isAmbientModule(node) && (inAmbientModule || hasSyntacticModifier(node, 2 /* Ambient */) || file.isDeclarationFile)) {
+          if (isAmbientModule(node) && (inAmbientModule || hasSyntacticModifier(node, 128 /* Ambient */) || file.isDeclarationFile)) {
             node.name.parent = node;
             const nameText = getTextOfIdentifierOrLiteral(node.name);
             if (isExternalModuleFile || inAmbientModule && !isExternalModuleNameRelative(nameText)) {
@@ -217580,14 +203031,14 @@ ${lanes.join("\n")}
       const result = getImpliedNodeFormatForFileWorker(getNormalizedAbsolutePath(fileName, currentDirectory), moduleResolutionCache2 == null ? void 0 : moduleResolutionCache2.getPackageJsonInfoCache(), host2, options2);
       const languageVersion = getEmitScriptTarget(options2);
       const setExternalModuleIndicator2 = getSetExternalModuleIndicator(options2);
-      return typeof result === "object" ? { ...result, languageVersion, setExternalModuleIndicator: setExternalModuleIndicator2 } : { languageVersion, impliedNodeFormat: result, setExternalModuleIndicator: setExternalModuleIndicator2 };
+      return typeof result === "object" ? { ...result, languageVersion, setExternalModuleIndicator: setExternalModuleIndicator2, jsDocParsingMode: host2.jsDocParsingMode } : { languageVersion, impliedNodeFormat: result, setExternalModuleIndicator: setExternalModuleIndicator2, jsDocParsingMode: host2.jsDocParsingMode };
     }
     function findSourceFileWorker(fileName, isDefaultLib, ignoreNoDefaultLib, reason, packageId) {
-      var _a2, _b2;
+      var _a2;
       const path = toPath3(fileName);
       if (useSourceOfProjectReferenceRedirect) {
         let source = getSourceOfProjectReferenceRedirect(path);
-        if (!source && host.realpath && options.preserveSymlinks && isDeclarationFileName(fileName) && stringContains(fileName, nodeModulesPathPart)) {
+        if (!source && host.realpath && options.preserveSymlinks && isDeclarationFileName(fileName) && fileName.includes(nodeModulesPathPart)) {
           const realPath2 = toPath3(host.realpath(fileName));
           if (realPath2 !== path)
             source = getSourceOfProjectReferenceRedirect(realPath2);
@@ -217662,7 +203113,7 @@ ${lanes.join("\n")}
           Diagnostics.Cannot_read_file_0_Colon_1,
           [fileName, hostErrorMessage]
         ),
-        shouldCreateNewSourceFile || ((_a2 = oldProgram == null ? void 0 : oldProgram.getSourceFileByPath(toPath3(fileName))) == null ? void 0 : _a2.impliedNodeFormat) !== sourceFileOptions.impliedNodeFormat
+        shouldCreateNewSourceFile
       );
       if (packageId) {
         const packageIdKey = packageIdToString(packageId);
@@ -217687,7 +203138,7 @@ ${lanes.join("\n")}
         file.path = path;
         file.resolvedPath = toPath3(fileName);
         file.originalFileName = originalFileName;
-        file.packageJsonLocations = ((_b2 = sourceFileOptions.packageJsonLocations) == null ? void 0 : _b2.length) ? sourceFileOptions.packageJsonLocations : void 0;
+        file.packageJsonLocations = ((_a2 = sourceFileOptions.packageJsonLocations) == null ? void 0 : _a2.length) ? sourceFileOptions.packageJsonLocations : void 0;
         file.packageJsonScope = sourceFileOptions.packageJsonScope;
         addFileIncludeReason(file, reason);
         if (host.useCaseSensitiveFileNames()) {
@@ -217804,25 +203255,17 @@ ${lanes.join("\n")}
     }
     function processTypeReferenceDirectives(file) {
       const typeDirectives = file.typeReferenceDirectives;
-      if (!typeDirectives.length) {
-        file.resolvedTypeReferenceDirectiveNames = void 0;
+      if (!typeDirectives.length)
         return;
-      }
-      const resolutions = resolveTypeReferenceDirectiveNamesReusingOldState(typeDirectives, file);
+      const resolutions = (resolvedTypeReferenceDirectiveNamesProcessing == null ? void 0 : resolvedTypeReferenceDirectiveNamesProcessing.get(file.path)) || resolveTypeReferenceDirectiveNamesReusingOldState(typeDirectives, file);
+      const resolutionsInFile = createModeAwareCache();
+      (resolvedTypeReferenceDirectiveNames ?? (resolvedTypeReferenceDirectiveNames = /* @__PURE__ */ new Map())).set(file.path, resolutionsInFile);
       for (let index = 0; index < typeDirectives.length; index++) {
         const ref = file.typeReferenceDirectives[index];
         const resolvedTypeReferenceDirective = resolutions[index];
         const fileName = toFileNameLowerCase(ref.fileName);
-        setResolvedTypeReferenceDirective(file, fileName, resolvedTypeReferenceDirective, getModeForFileReference(ref, file.impliedNodeFormat));
+        resolutionsInFile.set(fileName, getModeForFileReference(ref, file.impliedNodeFormat), resolvedTypeReferenceDirective);
         const mode = ref.resolutionMode || file.impliedNodeFormat;
-        if (mode && getEmitModuleResolutionKind(options) !== 3 /* Node16 */ && getEmitModuleResolutionKind(options) !== 99 /* NodeNext */) {
-          (fileProcessingDiagnostics ?? (fileProcessingDiagnostics = [])).push({
-            kind: 2 /* ResolutionDiagnostics */,
-            diagnostics: [
-              createDiagnosticForRange(file, ref, Diagnostics.resolution_mode_assertions_are_only_supported_when_moduleResolution_is_node16_or_nodenext)
-            ]
-          });
-        }
         processTypeReferenceDirective(fileName, mode, resolvedTypeReferenceDirective, { kind: 5 /* TypeReferenceDirective */, file: file.path, index });
       }
     }
@@ -217977,14 +203420,16 @@ ${lanes.join("\n")}
       collectExternalModuleReferences(file);
       if (file.imports.length || file.moduleAugmentations.length) {
         const moduleNames = getModuleNames(file);
-        const resolutions = resolveModuleNamesReusingOldState(moduleNames, file);
+        const resolutions = (resolvedModulesProcessing == null ? void 0 : resolvedModulesProcessing.get(file.path)) || resolveModuleNamesReusingOldState(moduleNames, file);
         Debug.assert(resolutions.length === moduleNames.length);
         const optionsForFile = (useSourceOfProjectReferenceRedirect ? (_a2 = getRedirectReferenceForResolution(file)) == null ? void 0 : _a2.commandLine.options : void 0) || options;
+        const resolutionsInFile = createModeAwareCache();
+        (resolvedModules ?? (resolvedModules = /* @__PURE__ */ new Map())).set(file.path, resolutionsInFile);
         for (let index = 0; index < moduleNames.length; index++) {
           const resolution = resolutions[index].resolvedModule;
           const moduleName = moduleNames[index].text;
           const mode = getModeForUsageLocation(file, moduleNames[index]);
-          setResolvedModule(file, moduleName, resolutions[index], mode);
+          resolutionsInFile.set(moduleName, mode, resolutions[index]);
           addResolutionDiagnosticsFromResolutionOrCache(file, moduleName, resolutions[index], mode);
           if (!resolution) {
             continue;
@@ -217997,7 +203442,7 @@ ${lanes.join("\n")}
             currentNodeModulesDepth++;
           }
           const elideImport = isJsFileFromNodeModules && currentNodeModulesDepth > maxNodeModuleJsDepth;
-          const shouldAddFile = resolvedFileName && !getResolutionDiagnostic(optionsForFile, resolution, file) && !optionsForFile.noResolve && index < file.imports.length && !elideImport && !(isJsFile && !getAllowJSCompilerOption(optionsForFile)) && (isInJSFile(file.imports[index]) || !(file.imports[index].flags & 8388608 /* JSDoc */));
+          const shouldAddFile = resolvedFileName && !getResolutionDiagnostic(optionsForFile, resolution, file) && !optionsForFile.noResolve && index < file.imports.length && !elideImport && !(isJsFile && !getAllowJSCompilerOption(optionsForFile)) && (isInJSFile(file.imports[index]) || !(file.imports[index].flags & 16777216 /* JSDoc */));
           if (elideImport) {
             modulesWithElidedImports.set(file.path, true);
           } else if (shouldAddFile) {
@@ -218015,8 +203460,6 @@ ${lanes.join("\n")}
             currentNodeModulesDepth--;
           }
         }
-      } else {
-        file.resolvedModules = void 0;
       }
     }
     function checkSourceFilesBelongToPath(sourceFiles, rootDirectory) {
@@ -218356,6 +203799,13 @@ ${lanes.join("\n")}
       if (moduleResolution === 100 /* Bundler */ && !emitModuleKindIsNonNodeESM(moduleKind)) {
         createOptionValueDiagnostic("moduleResolution", Diagnostics.Option_0_can_only_be_used_when_module_is_set_to_es2015_or_later, "bundler");
       }
+      if (ModuleKind[moduleKind] && (100 /* Node16 */ <= moduleKind && moduleKind <= 199 /* NodeNext */) && !(3 /* Node16 */ <= moduleResolution && moduleResolution <= 99 /* NodeNext */)) {
+        const moduleKindName = ModuleKind[moduleKind];
+        createOptionValueDiagnostic("moduleResolution", Diagnostics.Option_moduleResolution_must_be_set_to_0_or_left_unspecified_when_option_module_is_set_to_1, moduleKindName, moduleKindName);
+      } else if (ModuleResolutionKind[moduleResolution] && (3 /* Node16 */ <= moduleResolution && moduleResolution <= 99 /* NodeNext */) && !(100 /* Node16 */ <= moduleKind && moduleKind <= 199 /* NodeNext */)) {
+        const moduleResolutionName = ModuleResolutionKind[moduleResolution];
+        createOptionValueDiagnostic("module", Diagnostics.Option_module_must_be_set_to_0_when_option_moduleResolution_is_set_to_1, moduleResolutionName, moduleResolutionName);
+      }
       if (!options.noEmit && !options.suppressOutputPathCheck) {
         const emitHost = getEmitHost();
         const emitFilesSeen = /* @__PURE__ */ new Set();
@@ -218524,7 +203974,7 @@ ${lanes.join("\n")}
         processReason(fileProcessingReason);
       if (locationReason && (fileIncludeReasons == null ? void 0 : fileIncludeReasons.length) === 1)
         fileIncludeReasons = void 0;
-      const location = locationReason && getReferencedFileLocation(getSourceFileByPath, locationReason);
+      const location = locationReason && getReferencedFileLocation(program, locationReason);
       const fileIncludeReasonDetails = fileIncludeReasons && chainDiagnosticMessages(fileIncludeReasons, Diagnostics.The_file_is_in_the_program_because_Colon);
       const redirectInfo = file && explainIfFileIsRedirectAndImpliedFormat(file);
       const chain = chainDiagnosticMessages(redirectInfo ? fileIncludeReasonDetails ? [fileIncludeReasonDetails, ...redirectInfo] : redirectInfo : fileIncludeReasonDetails, diagnostic, ...args || emptyArray);
@@ -218560,7 +204010,7 @@ ${lanes.join("\n")}
     }
     function fileIncludeReasonToRelatedInformation(reason) {
       if (isReferencedFile(reason)) {
-        const referenceLocation = getReferencedFileLocation(getSourceFileByPath, reason);
+        const referenceLocation = getReferencedFileLocation(program, reason);
         let message2;
         switch (reason.kind) {
           case 3 /* Import */:
@@ -218609,19 +204059,11 @@ ${lanes.join("\n")}
         case 1 /* SourceFromProjectReference */:
         case 2 /* OutputFromProjectReference */:
           const referencedResolvedRef = Debug.checkDefined(resolvedProjectReferences == null ? void 0 : resolvedProjectReferences[reason.index]);
-          const referenceInfo = forEachProjectReference(
-            projectReferences,
-            resolvedProjectReferences,
-            (resolvedRef, parent2, index2) => resolvedRef === referencedResolvedRef ? { sourceFile: (parent2 == null ? void 0 : parent2.sourceFile) || options.configFile, index: index2 } : void 0
-          );
+          const referenceInfo = forEachProjectReference(projectReferences, resolvedProjectReferences, (resolvedRef, parent2, index2) => resolvedRef === referencedResolvedRef ? { sourceFile: (parent2 == null ? void 0 : parent2.sourceFile) || options.configFile, index: index2 } : void 0);
           if (!referenceInfo)
             return void 0;
           const { sourceFile, index } = referenceInfo;
-          const referencesSyntax = forEachTsConfigPropArray(
-            sourceFile,
-            "references",
-            (property) => isArrayLiteralExpression(property.initializer) ? property.initializer : void 0
-          );
+          const referencesSyntax = forEachTsConfigPropArray(sourceFile, "references", (property) => isArrayLiteralExpression(property.initializer) ? property.initializer : void 0);
           return referencesSyntax && referencesSyntax.elements.length > index ? createDiagnosticForNodeInSourceFile(
             sourceFile,
             referencesSyntax.elements[index],
@@ -218761,11 +204203,7 @@ ${lanes.join("\n")}
       );
     }
     function createDiagnosticForReference(sourceFile, index, message, ...args) {
-      const referencesSyntax = forEachTsConfigPropArray(
-        sourceFile || options.configFile,
-        "references",
-        (property) => isArrayLiteralExpression(property.initializer) ? property.initializer : void 0
-      );
+      const referencesSyntax = forEachTsConfigPropArray(sourceFile || options.configFile, "references", (property) => isArrayLiteralExpression(property.initializer) ? property.initializer : void 0);
       if (referencesSyntax && referencesSyntax.elements.length > index) {
         programDiagnostics.add(createDiagnosticForNodeInSourceFile(sourceFile || options.configFile, referencesSyntax.elements[index], message, ...args));
       } else {
@@ -218861,8 +204299,8 @@ ${lanes.join("\n")}
       if (!symlinks) {
         symlinks = createSymlinkCache(currentDirectory, getCanonicalFileName);
       }
-      if (files && automaticTypeDirectiveResolutions && !symlinks.hasProcessedResolutions()) {
-        symlinks.setSymlinksFromResolutions(files, automaticTypeDirectiveResolutions);
+      if (files && !symlinks.hasProcessedResolutions()) {
+        symlinks.setSymlinksFromResolutions(forEachResolvedModule, forEachResolvedTypeReferenceDirective, automaticTypeDirectiveResolutions);
       }
       return symlinks;
     }
@@ -218952,7 +204390,7 @@ ${lanes.join("\n")}
       var _a;
       if (!host.getResolvedProjectReferences() || containsIgnoredPath(directory))
         return;
-      if (!originalRealpath || !stringContains(directory, nodeModulesPathPart))
+      if (!originalRealpath || !directory.includes(nodeModulesPathPart))
         return;
       const symlinkCache = host.getSymlinkCache();
       const directoryPath = ensureTrailingDirectorySeparator(host.toPath(directory));
@@ -218980,7 +204418,7 @@ ${lanes.join("\n")}
       if (!symlinkedDirectories)
         return false;
       const fileOrDirectoryPath = host.toPath(fileOrDirectory);
-      if (!stringContains(fileOrDirectoryPath, nodeModulesPathPart))
+      if (!fileOrDirectoryPath.includes(nodeModulesPathPart))
         return false;
       if (isFile && ((_a = symlinkCache.getSymlinkedFiles()) == null ? void 0 : _a.has(fileOrDirectoryPath)))
         return true;
@@ -219045,6 +204483,9 @@ ${lanes.join("\n")}
         return directoryStructureHost.readDirectory(root, extensions, excludes, includes, depth);
       },
       readFile: (f) => directoryStructureHost.readFile(f),
+      directoryExists: maybeBind(directoryStructureHost, directoryStructureHost.directoryExists),
+      getDirectories: maybeBind(directoryStructureHost, directoryStructureHost.getDirectories),
+      realpath: maybeBind(directoryStructureHost, directoryStructureHost.realpath),
       useCaseSensitiveFileNames: host.useCaseSensitiveFileNames(),
       getCurrentDirectory: () => host.getCurrentDirectory(),
       onUnRecoverableConfigFileDiagnostic: host.onUnRecoverableConfigFileDiagnostic || returnUndefined,
@@ -219220,8 +204661,8 @@ ${lanes.join("\n")}
         Diagnostics.Classes_may_not_have_a_field_named_constructor.code,
         Diagnostics.Did_you_mean_to_use_a_Colon_An_can_only_follow_a_property_name_when_the_containing_object_literal_is_part_of_a_destructuring_pattern.code,
         Diagnostics.Duplicate_label_0.code,
-        Diagnostics.Dynamic_imports_can_only_accept_a_module_specifier_and_an_optional_assertion_as_arguments.code,
-        Diagnostics.For_await_loops_cannot_be_used_inside_a_class_static_block.code,
+        Diagnostics.Dynamic_imports_can_only_accept_a_module_specifier_and_an_optional_set_of_attributes_as_arguments.code,
+        Diagnostics.for_await_loops_cannot_be_used_inside_a_class_static_block.code,
         Diagnostics.JSX_attributes_must_only_be_assigned_a_non_empty_expression.code,
         Diagnostics.JSX_elements_cannot_have_multiple_attributes_with_the_same_name.code,
         Diagnostics.JSX_expressions_may_not_use_the_comma_operator_Did_you_mean_to_write_an_array.code,
@@ -219251,14 +204692,17 @@ ${lanes.join("\n")}
         Diagnostics._0_modifier_cannot_appear_on_class_elements_of_this_kind.code,
         Diagnostics._0_modifier_cannot_be_used_here.code,
         Diagnostics._0_modifier_must_precede_1_modifier.code,
-        Diagnostics.const_declarations_can_only_be_declared_inside_a_block.code,
-        Diagnostics.const_declarations_must_be_initialized.code,
+        Diagnostics._0_declarations_can_only_be_declared_inside_a_block.code,
+        Diagnostics._0_declarations_must_be_initialized.code,
         Diagnostics.extends_clause_already_seen.code,
-        Diagnostics.let_declarations_can_only_be_declared_inside_a_block.code,
         Diagnostics.let_is_not_allowed_to_be_used_as_a_name_in_let_or_const_declarations.code,
         Diagnostics.Class_constructor_may_not_be_a_generator.code,
         Diagnostics.Class_constructor_may_not_be_an_accessor.code,
-        Diagnostics.await_expressions_are_only_allowed_within_async_functions_and_at_the_top_levels_of_modules.code
+        Diagnostics.await_expressions_are_only_allowed_within_async_functions_and_at_the_top_levels_of_modules.code,
+        Diagnostics.await_using_statements_are_only_allowed_within_async_functions_and_at_the_top_levels_of_modules.code,
+        Diagnostics.Private_field_0_must_be_declared_in_an_enclosing_class.code,
+        // Type errors
+        Diagnostics.This_condition_will_always_return_0_since_JavaScript_compares_objects_by_reference_not_value.code
       ]);
       emitSkippedWithNoDiagnostics = { diagnostics: emptyArray, sourceMaps: void 0, emittedFiles: void 0, emitSkipped: true };
     }
@@ -219376,16 +204820,14 @@ ${lanes.join("\n")}
               addReferencedFile(referencedPath);
             }
           }
-          if (sourceFile.resolvedTypeReferenceDirectiveNames) {
-            sourceFile.resolvedTypeReferenceDirectiveNames.forEach(({ resolvedTypeReferenceDirective }) => {
-              if (!resolvedTypeReferenceDirective) {
-                return;
-              }
-              const fileName = resolvedTypeReferenceDirective.resolvedFileName;
-              const typeFilePath = getReferencedFileFromFileName(program, fileName, sourceFileDirectory, getCanonicalFileName);
-              addReferencedFile(typeFilePath);
-            });
-          }
+          program.forEachResolvedTypeReferenceDirective(({ resolvedTypeReferenceDirective }) => {
+            if (!resolvedTypeReferenceDirective) {
+              return;
+            }
+            const fileName = resolvedTypeReferenceDirective.resolvedFileName;
+            const typeFilePath = getReferencedFileFromFileName(program, fileName, sourceFileDirectory, getCanonicalFileName);
+            addReferencedFile(typeFilePath);
+          }, sourceFile);
           if (sourceFile.moduleAugmentations.length) {
             const checker = program.getTypeChecker();
             for (const moduleName of sourceFile.moduleAugmentations) {
@@ -219504,13 +204946,16 @@ ${lanes.join("\n")}
             sourceFile,
             (fileName, text, _writeByteOrderMark, _onError, sourceFiles, data) => {
               Debug.assert(isDeclarationFileName(fileName), `File extension for signature expected to be dts: Got:: ${fileName}`);
-              onNewSignature(computeSignatureWithDiagnostics(
-                programOfThisState,
-                sourceFile,
-                text,
-                host,
-                data
-              ), sourceFiles);
+              onNewSignature(
+                computeSignatureWithDiagnostics(
+                  programOfThisState,
+                  sourceFile,
+                  text,
+                  host,
+                  data
+                ),
+                sourceFiles
+              );
             },
             cancellationToken,
             /*emitOnly*/
@@ -219566,29460 +205011,32734 @@ ${lanes.join("\n")}
             state.exportedModulesMap.deleteKey(sourceFile.resolvedPath);
           }
         }
-        BuilderState2.updateExportedModules = updateExportedModules;
-        function getExportedModules(exportedModulesFromDeclarationEmit) {
-          let exportedModules;
-          exportedModulesFromDeclarationEmit == null ? void 0 : exportedModulesFromDeclarationEmit.forEach(
-            (symbol) => getReferencedFilesFromImportedModuleSymbol(symbol).forEach(
-              (path) => (exportedModules ?? (exportedModules = /* @__PURE__ */ new Set())).add(path)
+        BuilderState2.updateExportedModules = updateExportedModules;
+        function getExportedModules(exportedModulesFromDeclarationEmit) {
+          let exportedModules;
+          exportedModulesFromDeclarationEmit == null ? void 0 : exportedModulesFromDeclarationEmit.forEach(
+            (symbol) => getReferencedFilesFromImportedModuleSymbol(symbol).forEach(
+              (path) => (exportedModules ?? (exportedModules = /* @__PURE__ */ new Set())).add(path)
+            )
+          );
+          return exportedModules;
+        }
+        BuilderState2.getExportedModules = getExportedModules;
+        function getAllDependencies(state, programOfThisState, sourceFile) {
+          const compilerOptions = programOfThisState.getCompilerOptions();
+          if (outFile(compilerOptions)) {
+            return getAllFileNames(state, programOfThisState);
+          }
+          if (!state.referencedMap || isFileAffectingGlobalScope(sourceFile)) {
+            return getAllFileNames(state, programOfThisState);
+          }
+          const seenMap = /* @__PURE__ */ new Set();
+          const queue = [sourceFile.resolvedPath];
+          while (queue.length) {
+            const path = queue.pop();
+            if (!seenMap.has(path)) {
+              seenMap.add(path);
+              const references = state.referencedMap.getValues(path);
+              if (references) {
+                for (const key of references.keys()) {
+                  queue.push(key);
+                }
+              }
+            }
+          }
+          return arrayFrom(mapDefinedIterator(seenMap.keys(), (path) => {
+            var _a;
+            return ((_a = programOfThisState.getSourceFileByPath(path)) == null ? void 0 : _a.fileName) ?? path;
+          }));
+        }
+        BuilderState2.getAllDependencies = getAllDependencies;
+        function getAllFileNames(state, programOfThisState) {
+          if (!state.allFileNames) {
+            const sourceFiles = programOfThisState.getSourceFiles();
+            state.allFileNames = sourceFiles === emptyArray ? emptyArray : sourceFiles.map((file) => file.fileName);
+          }
+          return state.allFileNames;
+        }
+        function getReferencedByPaths(state, referencedFilePath) {
+          const keys = state.referencedMap.getKeys(referencedFilePath);
+          return keys ? arrayFrom(keys.keys()) : [];
+        }
+        BuilderState2.getReferencedByPaths = getReferencedByPaths;
+        function containsOnlyAmbientModules(sourceFile) {
+          for (const statement of sourceFile.statements) {
+            if (!isModuleWithStringLiteralName(statement)) {
+              return false;
+            }
+          }
+          return true;
+        }
+        function containsGlobalScopeAugmentation(sourceFile) {
+          return some(sourceFile.moduleAugmentations, (augmentation) => isGlobalScopeAugmentation(augmentation.parent));
+        }
+        function isFileAffectingGlobalScope(sourceFile) {
+          return containsGlobalScopeAugmentation(sourceFile) || !isExternalOrCommonJsModule(sourceFile) && !isJsonSourceFile(sourceFile) && !containsOnlyAmbientModules(sourceFile);
+        }
+        function getAllFilesExcludingDefaultLibraryFile(state, programOfThisState, firstSourceFile) {
+          if (state.allFilesExcludingDefaultLibraryFile) {
+            return state.allFilesExcludingDefaultLibraryFile;
+          }
+          let result;
+          if (firstSourceFile)
+            addSourceFile(firstSourceFile);
+          for (const sourceFile of programOfThisState.getSourceFiles()) {
+            if (sourceFile !== firstSourceFile) {
+              addSourceFile(sourceFile);
+            }
+          }
+          state.allFilesExcludingDefaultLibraryFile = result || emptyArray;
+          return state.allFilesExcludingDefaultLibraryFile;
+          function addSourceFile(sourceFile) {
+            if (!programOfThisState.isSourceFileDefaultLibrary(sourceFile)) {
+              (result || (result = [])).push(sourceFile);
+            }
+          }
+        }
+        BuilderState2.getAllFilesExcludingDefaultLibraryFile = getAllFilesExcludingDefaultLibraryFile;
+        function getFilesAffectedByUpdatedShapeWhenNonModuleEmit(state, programOfThisState, sourceFileWithUpdatedShape) {
+          const compilerOptions = programOfThisState.getCompilerOptions();
+          if (compilerOptions && outFile(compilerOptions)) {
+            return [sourceFileWithUpdatedShape];
+          }
+          return getAllFilesExcludingDefaultLibraryFile(state, programOfThisState, sourceFileWithUpdatedShape);
+        }
+        function getFilesAffectedByUpdatedShapeWhenModuleEmit(state, programOfThisState, sourceFileWithUpdatedShape, cancellationToken, host) {
+          if (isFileAffectingGlobalScope(sourceFileWithUpdatedShape)) {
+            return getAllFilesExcludingDefaultLibraryFile(state, programOfThisState, sourceFileWithUpdatedShape);
+          }
+          const compilerOptions = programOfThisState.getCompilerOptions();
+          if (compilerOptions && (getIsolatedModules(compilerOptions) || outFile(compilerOptions))) {
+            return [sourceFileWithUpdatedShape];
+          }
+          const seenFileNamesMap = /* @__PURE__ */ new Map();
+          seenFileNamesMap.set(sourceFileWithUpdatedShape.resolvedPath, sourceFileWithUpdatedShape);
+          const queue = getReferencedByPaths(state, sourceFileWithUpdatedShape.resolvedPath);
+          while (queue.length > 0) {
+            const currentPath = queue.pop();
+            if (!seenFileNamesMap.has(currentPath)) {
+              const currentSourceFile = programOfThisState.getSourceFileByPath(currentPath);
+              seenFileNamesMap.set(currentPath, currentSourceFile);
+              if (currentSourceFile && updateShapeSignature(state, programOfThisState, currentSourceFile, cancellationToken, host)) {
+                queue.push(...getReferencedByPaths(state, currentSourceFile.resolvedPath));
+              }
+            }
+          }
+          return arrayFrom(mapDefinedIterator(seenFileNamesMap.values(), (value) => value));
+        }
+      })(BuilderState || (BuilderState = {}));
+    }
+  });
+
+  // src/compiler/builder.ts
+  function getBuilderFileEmit(options) {
+    let result = 1 /* Js */;
+    if (options.sourceMap)
+      result = result | 2 /* JsMap */;
+    if (options.inlineSourceMap)
+      result = result | 4 /* JsInlineMap */;
+    if (getEmitDeclarations(options))
+      result = result | 8 /* Dts */;
+    if (options.declarationMap)
+      result = result | 16 /* DtsMap */;
+    if (options.emitDeclarationOnly)
+      result = result & 24 /* AllDts */;
+    return result;
+  }
+  function getPendingEmitKind(optionsOrEmitKind, oldOptionsOrEmitKind) {
+    const oldEmitKind = oldOptionsOrEmitKind && (isNumber(oldOptionsOrEmitKind) ? oldOptionsOrEmitKind : getBuilderFileEmit(oldOptionsOrEmitKind));
+    const emitKind = isNumber(optionsOrEmitKind) ? optionsOrEmitKind : getBuilderFileEmit(optionsOrEmitKind);
+    if (oldEmitKind === emitKind)
+      return 0 /* None */;
+    if (!oldEmitKind || !emitKind)
+      return emitKind;
+    const diff = oldEmitKind ^ emitKind;
+    let result = 0 /* None */;
+    if (diff & 7 /* AllJs */)
+      result = emitKind & 7 /* AllJs */;
+    if (diff & 24 /* AllDts */)
+      result = result | emitKind & 24 /* AllDts */;
+    return result;
+  }
+  function hasSameKeys(map1, map2) {
+    return map1 === map2 || map1 !== void 0 && map2 !== void 0 && map1.size === map2.size && !forEachKey(map1, (key) => !map2.has(key));
+  }
+  function createBuilderProgramState(newProgram, oldState) {
+    var _a, _b;
+    const state = BuilderState.create(
+      newProgram,
+      oldState,
+      /*disableUseFileVersionAsSignature*/
+      false
+    );
+    state.program = newProgram;
+    const compilerOptions = newProgram.getCompilerOptions();
+    state.compilerOptions = compilerOptions;
+    const outFilePath = outFile(compilerOptions);
+    if (!outFilePath) {
+      state.semanticDiagnosticsPerFile = /* @__PURE__ */ new Map();
+    } else if (compilerOptions.composite && (oldState == null ? void 0 : oldState.outSignature) && outFilePath === outFile(oldState == null ? void 0 : oldState.compilerOptions)) {
+      state.outSignature = oldState.outSignature && getEmitSignatureFromOldSignature(compilerOptions, oldState.compilerOptions, oldState.outSignature);
+    }
+    state.changedFilesSet = /* @__PURE__ */ new Set();
+    state.latestChangedDtsFile = compilerOptions.composite ? oldState == null ? void 0 : oldState.latestChangedDtsFile : void 0;
+    const useOldState = BuilderState.canReuseOldState(state.referencedMap, oldState);
+    const oldCompilerOptions = useOldState ? oldState.compilerOptions : void 0;
+    const canCopySemanticDiagnostics = useOldState && oldState.semanticDiagnosticsPerFile && !!state.semanticDiagnosticsPerFile && !compilerOptionsAffectSemanticDiagnostics(compilerOptions, oldCompilerOptions);
+    const canCopyEmitSignatures = compilerOptions.composite && (oldState == null ? void 0 : oldState.emitSignatures) && !outFilePath && !compilerOptionsAffectDeclarationPath(compilerOptions, oldState.compilerOptions);
+    if (useOldState) {
+      (_a = oldState.changedFilesSet) == null ? void 0 : _a.forEach((value) => state.changedFilesSet.add(value));
+      if (!outFilePath && ((_b = oldState.affectedFilesPendingEmit) == null ? void 0 : _b.size)) {
+        state.affectedFilesPendingEmit = new Map(oldState.affectedFilesPendingEmit);
+        state.seenAffectedFiles = /* @__PURE__ */ new Set();
+      }
+      state.programEmitPending = oldState.programEmitPending;
+    } else {
+      state.buildInfoEmitPending = true;
+    }
+    const referencedMap = state.referencedMap;
+    const oldReferencedMap = useOldState ? oldState.referencedMap : void 0;
+    const copyDeclarationFileDiagnostics = canCopySemanticDiagnostics && !compilerOptions.skipLibCheck === !oldCompilerOptions.skipLibCheck;
+    const copyLibFileDiagnostics = copyDeclarationFileDiagnostics && !compilerOptions.skipDefaultLibCheck === !oldCompilerOptions.skipDefaultLibCheck;
+    state.fileInfos.forEach((info, sourceFilePath) => {
+      let oldInfo;
+      let newReferences;
+      if (!useOldState || // File wasn't present in old state
+      !(oldInfo = oldState.fileInfos.get(sourceFilePath)) || // versions dont match
+      oldInfo.version !== info.version || // Implied formats dont match
+      oldInfo.impliedFormat !== info.impliedFormat || // Referenced files changed
+      !hasSameKeys(newReferences = referencedMap && referencedMap.getValues(sourceFilePath), oldReferencedMap && oldReferencedMap.getValues(sourceFilePath)) || // Referenced file was deleted in the new program
+      newReferences && forEachKey(newReferences, (path) => !state.fileInfos.has(path) && oldState.fileInfos.has(path))) {
+        addFileToChangeSet(state, sourceFilePath);
+      } else if (canCopySemanticDiagnostics) {
+        const sourceFile = newProgram.getSourceFileByPath(sourceFilePath);
+        if (sourceFile.isDeclarationFile && !copyDeclarationFileDiagnostics)
+          return;
+        if (sourceFile.hasNoDefaultLib && !copyLibFileDiagnostics)
+          return;
+        const diagnostics = oldState.semanticDiagnosticsPerFile.get(sourceFilePath);
+        if (diagnostics) {
+          state.semanticDiagnosticsPerFile.set(
+            sourceFilePath,
+            oldState.hasReusableDiagnostic ? convertToDiagnostics(diagnostics, newProgram) : repopulateDiagnostics(diagnostics, newProgram)
+          );
+          if (!state.semanticDiagnosticsFromOldState) {
+            state.semanticDiagnosticsFromOldState = /* @__PURE__ */ new Set();
+          }
+          state.semanticDiagnosticsFromOldState.add(sourceFilePath);
+        }
+      }
+      if (canCopyEmitSignatures) {
+        const oldEmitSignature = oldState.emitSignatures.get(sourceFilePath);
+        if (oldEmitSignature) {
+          (state.emitSignatures ?? (state.emitSignatures = /* @__PURE__ */ new Map())).set(sourceFilePath, getEmitSignatureFromOldSignature(compilerOptions, oldState.compilerOptions, oldEmitSignature));
+        }
+      }
+    });
+    if (useOldState && forEachEntry(oldState.fileInfos, (info, sourceFilePath) => {
+      if (state.fileInfos.has(sourceFilePath))
+        return false;
+      if (outFilePath || info.affectsGlobalScope)
+        return true;
+      state.buildInfoEmitPending = true;
+      return false;
+    })) {
+      BuilderState.getAllFilesExcludingDefaultLibraryFile(
+        state,
+        newProgram,
+        /*firstSourceFile*/
+        void 0
+      ).forEach((file) => addFileToChangeSet(state, file.resolvedPath));
+    } else if (oldCompilerOptions) {
+      const pendingEmitKind = compilerOptionsAffectEmit(compilerOptions, oldCompilerOptions) ? getBuilderFileEmit(compilerOptions) : getPendingEmitKind(compilerOptions, oldCompilerOptions);
+      if (pendingEmitKind !== 0 /* None */) {
+        if (!outFilePath) {
+          newProgram.getSourceFiles().forEach((f) => {
+            if (!state.changedFilesSet.has(f.resolvedPath)) {
+              addToAffectedFilesPendingEmit(
+                state,
+                f.resolvedPath,
+                pendingEmitKind
+              );
+            }
+          });
+          Debug.assert(!state.seenAffectedFiles || !state.seenAffectedFiles.size);
+          state.seenAffectedFiles = state.seenAffectedFiles || /* @__PURE__ */ new Set();
+          state.buildInfoEmitPending = true;
+        } else {
+          state.programEmitPending = state.programEmitPending ? state.programEmitPending | pendingEmitKind : pendingEmitKind;
+        }
+      }
+    }
+    if (outFilePath && !state.changedFilesSet.size) {
+      if (useOldState)
+        state.bundle = oldState.bundle;
+      if (some(newProgram.getProjectReferences(), (ref) => !!ref.prepend))
+        state.programEmitPending = getBuilderFileEmit(compilerOptions);
+    }
+    return state;
+  }
+  function addFileToChangeSet(state, path) {
+    state.changedFilesSet.add(path);
+    state.buildInfoEmitPending = true;
+    state.programEmitPending = void 0;
+  }
+  function getEmitSignatureFromOldSignature(options, oldOptions, oldEmitSignature) {
+    return !!options.declarationMap === !!oldOptions.declarationMap ? (
+      // Use same format of signature
+      oldEmitSignature
+    ) : (
+      // Convert to different format
+      isString(oldEmitSignature) ? [oldEmitSignature] : oldEmitSignature[0]
+    );
+  }
+  function repopulateDiagnostics(diagnostics, newProgram) {
+    if (!diagnostics.length)
+      return diagnostics;
+    return sameMap(diagnostics, (diag2) => {
+      if (isString(diag2.messageText))
+        return diag2;
+      const repopulatedChain = convertOrRepopulateDiagnosticMessageChain(diag2.messageText, diag2.file, newProgram, (chain) => {
+        var _a;
+        return (_a = chain.repopulateInfo) == null ? void 0 : _a.call(chain);
+      });
+      return repopulatedChain === diag2.messageText ? diag2 : { ...diag2, messageText: repopulatedChain };
+    });
+  }
+  function convertOrRepopulateDiagnosticMessageChain(chain, sourceFile, newProgram, repopulateInfo) {
+    const info = repopulateInfo(chain);
+    if (info) {
+      return {
+        ...createModuleNotFoundChain(sourceFile, newProgram, info.moduleReference, info.mode, info.packageName || info.moduleReference),
+        next: convertOrRepopulateDiagnosticMessageChainArray(chain.next, sourceFile, newProgram, repopulateInfo)
+      };
+    }
+    const next = convertOrRepopulateDiagnosticMessageChainArray(chain.next, sourceFile, newProgram, repopulateInfo);
+    return next === chain.next ? chain : { ...chain, next };
+  }
+  function convertOrRepopulateDiagnosticMessageChainArray(array, sourceFile, newProgram, repopulateInfo) {
+    return sameMap(array, (chain) => convertOrRepopulateDiagnosticMessageChain(chain, sourceFile, newProgram, repopulateInfo));
+  }
+  function convertToDiagnostics(diagnostics, newProgram) {
+    if (!diagnostics.length)
+      return emptyArray;
+    let buildInfoDirectory;
+    return diagnostics.map((diagnostic) => {
+      const result = convertToDiagnosticRelatedInformation(diagnostic, newProgram, toPathInBuildInfoDirectory);
+      result.reportsUnnecessary = diagnostic.reportsUnnecessary;
+      result.reportsDeprecated = diagnostic.reportDeprecated;
+      result.source = diagnostic.source;
+      result.skippedOn = diagnostic.skippedOn;
+      const { relatedInformation } = diagnostic;
+      result.relatedInformation = relatedInformation ? relatedInformation.length ? relatedInformation.map((r) => convertToDiagnosticRelatedInformation(r, newProgram, toPathInBuildInfoDirectory)) : [] : void 0;
+      return result;
+    });
+    function toPathInBuildInfoDirectory(path) {
+      buildInfoDirectory ?? (buildInfoDirectory = getDirectoryPath(getNormalizedAbsolutePath(getTsBuildInfoEmitOutputFilePath(newProgram.getCompilerOptions()), newProgram.getCurrentDirectory())));
+      return toPath(path, buildInfoDirectory, newProgram.getCanonicalFileName);
+    }
+  }
+  function convertToDiagnosticRelatedInformation(diagnostic, newProgram, toPath3) {
+    const { file } = diagnostic;
+    const sourceFile = file ? newProgram.getSourceFileByPath(toPath3(file)) : void 0;
+    return {
+      ...diagnostic,
+      file: sourceFile,
+      messageText: isString(diagnostic.messageText) ? diagnostic.messageText : convertOrRepopulateDiagnosticMessageChain(diagnostic.messageText, sourceFile, newProgram, (chain) => chain.info)
+    };
+  }
+  function releaseCache(state) {
+    BuilderState.releaseCache(state);
+    state.program = void 0;
+  }
+  function backupBuilderProgramEmitState(state) {
+    const outFilePath = outFile(state.compilerOptions);
+    Debug.assert(!state.changedFilesSet.size || outFilePath);
+    return {
+      affectedFilesPendingEmit: state.affectedFilesPendingEmit && new Map(state.affectedFilesPendingEmit),
+      seenEmittedFiles: state.seenEmittedFiles && new Map(state.seenEmittedFiles),
+      programEmitPending: state.programEmitPending,
+      emitSignatures: state.emitSignatures && new Map(state.emitSignatures),
+      outSignature: state.outSignature,
+      latestChangedDtsFile: state.latestChangedDtsFile,
+      hasChangedEmitSignature: state.hasChangedEmitSignature,
+      changedFilesSet: outFilePath ? new Set(state.changedFilesSet) : void 0
+    };
+  }
+  function restoreBuilderProgramEmitState(state, savedEmitState) {
+    state.affectedFilesPendingEmit = savedEmitState.affectedFilesPendingEmit;
+    state.seenEmittedFiles = savedEmitState.seenEmittedFiles;
+    state.programEmitPending = savedEmitState.programEmitPending;
+    state.emitSignatures = savedEmitState.emitSignatures;
+    state.outSignature = savedEmitState.outSignature;
+    state.latestChangedDtsFile = savedEmitState.latestChangedDtsFile;
+    state.hasChangedEmitSignature = savedEmitState.hasChangedEmitSignature;
+    if (savedEmitState.changedFilesSet)
+      state.changedFilesSet = savedEmitState.changedFilesSet;
+  }
+  function assertSourceFileOkWithoutNextAffectedCall(state, sourceFile) {
+    Debug.assert(!sourceFile || !state.affectedFiles || state.affectedFiles[state.affectedFilesIndex - 1] !== sourceFile || !state.semanticDiagnosticsPerFile.has(sourceFile.resolvedPath));
+  }
+  function getNextAffectedFile(state, cancellationToken, host) {
+    var _a, _b;
+    while (true) {
+      const { affectedFiles } = state;
+      if (affectedFiles) {
+        const seenAffectedFiles = state.seenAffectedFiles;
+        let affectedFilesIndex = state.affectedFilesIndex;
+        while (affectedFilesIndex < affectedFiles.length) {
+          const affectedFile = affectedFiles[affectedFilesIndex];
+          if (!seenAffectedFiles.has(affectedFile.resolvedPath)) {
+            state.affectedFilesIndex = affectedFilesIndex;
+            addToAffectedFilesPendingEmit(state, affectedFile.resolvedPath, getBuilderFileEmit(state.compilerOptions));
+            handleDtsMayChangeOfAffectedFile(
+              state,
+              affectedFile,
+              cancellationToken,
+              host
+            );
+            return affectedFile;
+          }
+          affectedFilesIndex++;
+        }
+        state.changedFilesSet.delete(state.currentChangedFilePath);
+        state.currentChangedFilePath = void 0;
+        (_a = state.oldSignatures) == null ? void 0 : _a.clear();
+        (_b = state.oldExportedModulesMap) == null ? void 0 : _b.clear();
+        state.affectedFiles = void 0;
+      }
+      const nextKey = state.changedFilesSet.keys().next();
+      if (nextKey.done) {
+        return void 0;
+      }
+      const program = Debug.checkDefined(state.program);
+      const compilerOptions = program.getCompilerOptions();
+      if (outFile(compilerOptions)) {
+        Debug.assert(!state.semanticDiagnosticsPerFile);
+        return program;
+      }
+      state.affectedFiles = BuilderState.getFilesAffectedByWithOldState(
+        state,
+        program,
+        nextKey.value,
+        cancellationToken,
+        host
+      );
+      state.currentChangedFilePath = nextKey.value;
+      state.affectedFilesIndex = 0;
+      if (!state.seenAffectedFiles)
+        state.seenAffectedFiles = /* @__PURE__ */ new Set();
+    }
+  }
+  function clearAffectedFilesPendingEmit(state, emitOnlyDtsFiles) {
+    var _a;
+    if (!((_a = state.affectedFilesPendingEmit) == null ? void 0 : _a.size))
+      return;
+    if (!emitOnlyDtsFiles)
+      return state.affectedFilesPendingEmit = void 0;
+    state.affectedFilesPendingEmit.forEach((emitKind, path) => {
+      const pending = emitKind & 7 /* AllJs */;
+      if (!pending)
+        state.affectedFilesPendingEmit.delete(path);
+      else
+        state.affectedFilesPendingEmit.set(path, pending);
+    });
+  }
+  function getNextAffectedFilePendingEmit(state, emitOnlyDtsFiles) {
+    var _a;
+    if (!((_a = state.affectedFilesPendingEmit) == null ? void 0 : _a.size))
+      return void 0;
+    return forEachEntry(state.affectedFilesPendingEmit, (emitKind, path) => {
+      var _a2;
+      const affectedFile = state.program.getSourceFileByPath(path);
+      if (!affectedFile || !sourceFileMayBeEmitted(affectedFile, state.program)) {
+        state.affectedFilesPendingEmit.delete(path);
+        return void 0;
+      }
+      const seenKind = (_a2 = state.seenEmittedFiles) == null ? void 0 : _a2.get(affectedFile.resolvedPath);
+      let pendingKind = getPendingEmitKind(emitKind, seenKind);
+      if (emitOnlyDtsFiles)
+        pendingKind = pendingKind & 24 /* AllDts */;
+      if (pendingKind)
+        return { affectedFile, emitKind: pendingKind };
+    });
+  }
+  function removeDiagnosticsOfLibraryFiles(state) {
+    if (!state.cleanedDiagnosticsOfLibFiles) {
+      state.cleanedDiagnosticsOfLibFiles = true;
+      const program = Debug.checkDefined(state.program);
+      const options = program.getCompilerOptions();
+      forEach(program.getSourceFiles(), (f) => program.isSourceFileDefaultLibrary(f) && !skipTypeChecking(f, options, program) && removeSemanticDiagnosticsOf(state, f.resolvedPath));
+    }
+  }
+  function handleDtsMayChangeOfAffectedFile(state, affectedFile, cancellationToken, host) {
+    removeSemanticDiagnosticsOf(state, affectedFile.resolvedPath);
+    if (state.allFilesExcludingDefaultLibraryFile === state.affectedFiles) {
+      removeDiagnosticsOfLibraryFiles(state);
+      BuilderState.updateShapeSignature(
+        state,
+        Debug.checkDefined(state.program),
+        affectedFile,
+        cancellationToken,
+        host
+      );
+      return;
+    }
+    if (state.compilerOptions.assumeChangesOnlyAffectDirectDependencies)
+      return;
+    handleDtsMayChangeOfReferencingExportOfAffectedFile(
+      state,
+      affectedFile,
+      cancellationToken,
+      host
+    );
+  }
+  function handleDtsMayChangeOf(state, path, cancellationToken, host) {
+    removeSemanticDiagnosticsOf(state, path);
+    if (!state.changedFilesSet.has(path)) {
+      const program = Debug.checkDefined(state.program);
+      const sourceFile = program.getSourceFileByPath(path);
+      if (sourceFile) {
+        BuilderState.updateShapeSignature(
+          state,
+          program,
+          sourceFile,
+          cancellationToken,
+          host,
+          /*useFileVersionAsSignature*/
+          true
+        );
+        if (getEmitDeclarations(state.compilerOptions)) {
+          addToAffectedFilesPendingEmit(state, path, state.compilerOptions.declarationMap ? 24 /* AllDts */ : 8 /* Dts */);
+        }
+      }
+    }
+  }
+  function removeSemanticDiagnosticsOf(state, path) {
+    if (!state.semanticDiagnosticsFromOldState) {
+      return true;
+    }
+    state.semanticDiagnosticsFromOldState.delete(path);
+    state.semanticDiagnosticsPerFile.delete(path);
+    return !state.semanticDiagnosticsFromOldState.size;
+  }
+  function isChangedSignature(state, path) {
+    const oldSignature = Debug.checkDefined(state.oldSignatures).get(path) || void 0;
+    const newSignature = Debug.checkDefined(state.fileInfos.get(path)).signature;
+    return newSignature !== oldSignature;
+  }
+  function handleDtsMayChangeOfGlobalScope(state, filePath, cancellationToken, host) {
+    var _a;
+    if (!((_a = state.fileInfos.get(filePath)) == null ? void 0 : _a.affectsGlobalScope))
+      return false;
+    BuilderState.getAllFilesExcludingDefaultLibraryFile(
+      state,
+      state.program,
+      /*firstSourceFile*/
+      void 0
+    ).forEach(
+      (file) => handleDtsMayChangeOf(
+        state,
+        file.resolvedPath,
+        cancellationToken,
+        host
+      )
+    );
+    removeDiagnosticsOfLibraryFiles(state);
+    return true;
+  }
+  function handleDtsMayChangeOfReferencingExportOfAffectedFile(state, affectedFile, cancellationToken, host) {
+    var _a;
+    if (!state.exportedModulesMap || !state.changedFilesSet.has(affectedFile.resolvedPath))
+      return;
+    if (!isChangedSignature(state, affectedFile.resolvedPath))
+      return;
+    if (getIsolatedModules(state.compilerOptions)) {
+      const seenFileNamesMap = /* @__PURE__ */ new Map();
+      seenFileNamesMap.set(affectedFile.resolvedPath, true);
+      const queue = BuilderState.getReferencedByPaths(state, affectedFile.resolvedPath);
+      while (queue.length > 0) {
+        const currentPath = queue.pop();
+        if (!seenFileNamesMap.has(currentPath)) {
+          seenFileNamesMap.set(currentPath, true);
+          if (handleDtsMayChangeOfGlobalScope(state, currentPath, cancellationToken, host))
+            return;
+          handleDtsMayChangeOf(state, currentPath, cancellationToken, host);
+          if (isChangedSignature(state, currentPath)) {
+            const currentSourceFile = Debug.checkDefined(state.program).getSourceFileByPath(currentPath);
+            queue.push(...BuilderState.getReferencedByPaths(state, currentSourceFile.resolvedPath));
+          }
+        }
+      }
+    }
+    const seenFileAndExportsOfFile = /* @__PURE__ */ new Set();
+    (_a = state.exportedModulesMap.getKeys(affectedFile.resolvedPath)) == null ? void 0 : _a.forEach((exportedFromPath) => {
+      if (handleDtsMayChangeOfGlobalScope(state, exportedFromPath, cancellationToken, host))
+        return true;
+      const references = state.referencedMap.getKeys(exportedFromPath);
+      return references && forEachKey(references, (filePath) => handleDtsMayChangeOfFileAndExportsOfFile(
+        state,
+        filePath,
+        seenFileAndExportsOfFile,
+        cancellationToken,
+        host
+      ));
+    });
+  }
+  function handleDtsMayChangeOfFileAndExportsOfFile(state, filePath, seenFileAndExportsOfFile, cancellationToken, host) {
+    var _a, _b;
+    if (!tryAddToSet(seenFileAndExportsOfFile, filePath))
+      return void 0;
+    if (handleDtsMayChangeOfGlobalScope(state, filePath, cancellationToken, host))
+      return true;
+    handleDtsMayChangeOf(state, filePath, cancellationToken, host);
+    (_a = state.exportedModulesMap.getKeys(filePath)) == null ? void 0 : _a.forEach(
+      (exportedFromPath) => handleDtsMayChangeOfFileAndExportsOfFile(
+        state,
+        exportedFromPath,
+        seenFileAndExportsOfFile,
+        cancellationToken,
+        host
+      )
+    );
+    (_b = state.referencedMap.getKeys(filePath)) == null ? void 0 : _b.forEach(
+      (referencingFilePath) => !seenFileAndExportsOfFile.has(referencingFilePath) && // Not already removed diagnostic file
+      handleDtsMayChangeOf(
+        // Dont add to seen since this is not yet done with the export removal
+        state,
+        referencingFilePath,
+        cancellationToken,
+        host
+      )
+    );
+    return void 0;
+  }
+  function getSemanticDiagnosticsOfFile(state, sourceFile, cancellationToken) {
+    return concatenate(
+      getBinderAndCheckerDiagnosticsOfFile(state, sourceFile, cancellationToken),
+      Debug.checkDefined(state.program).getProgramDiagnostics(sourceFile)
+    );
+  }
+  function getBinderAndCheckerDiagnosticsOfFile(state, sourceFile, cancellationToken) {
+    const path = sourceFile.resolvedPath;
+    if (state.semanticDiagnosticsPerFile) {
+      const cachedDiagnostics = state.semanticDiagnosticsPerFile.get(path);
+      if (cachedDiagnostics) {
+        return filterSemanticDiagnostics(cachedDiagnostics, state.compilerOptions);
+      }
+    }
+    const diagnostics = Debug.checkDefined(state.program).getBindAndCheckDiagnostics(sourceFile, cancellationToken);
+    if (state.semanticDiagnosticsPerFile) {
+      state.semanticDiagnosticsPerFile.set(path, diagnostics);
+    }
+    return filterSemanticDiagnostics(diagnostics, state.compilerOptions);
+  }
+  function isProgramBundleEmitBuildInfo(info) {
+    return !!outFile(info.options || {});
+  }
+  function getBuildInfo2(state, bundle) {
+    var _a, _b, _c;
+    const currentDirectory = Debug.checkDefined(state.program).getCurrentDirectory();
+    const buildInfoDirectory = getDirectoryPath(getNormalizedAbsolutePath(getTsBuildInfoEmitOutputFilePath(state.compilerOptions), currentDirectory));
+    const latestChangedDtsFile = state.latestChangedDtsFile ? relativeToBuildInfoEnsuringAbsolutePath(state.latestChangedDtsFile) : void 0;
+    const fileNames = [];
+    const fileNameToFileId = /* @__PURE__ */ new Map();
+    const root = [];
+    if (outFile(state.compilerOptions)) {
+      const fileInfos2 = arrayFrom(state.fileInfos.entries(), ([key, value]) => {
+        const fileId = toFileId(key);
+        tryAddRoot(key, fileId);
+        return value.impliedFormat ? { version: value.version, impliedFormat: value.impliedFormat, signature: void 0, affectsGlobalScope: void 0 } : value.version;
+      });
+      const program2 = {
+        fileNames,
+        fileInfos: fileInfos2,
+        root,
+        options: convertToProgramBuildInfoCompilerOptions(state.compilerOptions),
+        outSignature: state.outSignature,
+        latestChangedDtsFile,
+        pendingEmit: !state.programEmitPending ? void 0 : (
+          // Pending is undefined or None is encoded as undefined
+          state.programEmitPending === getBuilderFileEmit(state.compilerOptions) ? false : (
+            // Pending emit is same as deteremined by compilerOptions
+            state.programEmitPending
+          )
+        )
+        // Actual value
+      };
+      const { js, dts, commonSourceDirectory, sourceFiles } = bundle;
+      state.bundle = bundle = {
+        commonSourceDirectory,
+        sourceFiles,
+        js: js || (!state.compilerOptions.emitDeclarationOnly ? (_a = state.bundle) == null ? void 0 : _a.js : void 0),
+        dts: dts || (getEmitDeclarations(state.compilerOptions) ? (_b = state.bundle) == null ? void 0 : _b.dts : void 0)
+      };
+      return createBuildInfo(program2, bundle);
+    }
+    let fileIdsList;
+    let fileNamesToFileIdListId;
+    let emitSignatures;
+    const fileInfos = arrayFrom(state.fileInfos.entries(), ([key, value]) => {
+      var _a2, _b2;
+      const fileId = toFileId(key);
+      tryAddRoot(key, fileId);
+      Debug.assert(fileNames[fileId - 1] === relativeToBuildInfo(key));
+      const oldSignature = (_a2 = state.oldSignatures) == null ? void 0 : _a2.get(key);
+      const actualSignature = oldSignature !== void 0 ? oldSignature || void 0 : value.signature;
+      if (state.compilerOptions.composite) {
+        const file = state.program.getSourceFileByPath(key);
+        if (!isJsonSourceFile(file) && sourceFileMayBeEmitted(file, state.program)) {
+          const emitSignature = (_b2 = state.emitSignatures) == null ? void 0 : _b2.get(key);
+          if (emitSignature !== actualSignature) {
+            (emitSignatures || (emitSignatures = [])).push(
+              emitSignature === void 0 ? fileId : (
+                // There is no emit, encode as false
+                // fileId, signature: emptyArray if signature only differs in dtsMap option than our own compilerOptions otherwise EmitSignature
+                [fileId, !isString(emitSignature) && emitSignature[0] === actualSignature ? emptyArray : emitSignature]
+              )
+            );
+          }
+        }
+      }
+      return value.version === actualSignature ? value.affectsGlobalScope || value.impliedFormat ? (
+        // If file version is same as signature, dont serialize signature
+        { version: value.version, signature: void 0, affectsGlobalScope: value.affectsGlobalScope, impliedFormat: value.impliedFormat }
+      ) : (
+        // If file info only contains version and signature and both are same we can just write string
+        value.version
+      ) : actualSignature !== void 0 ? (
+        // If signature is not same as version, encode signature in the fileInfo
+        oldSignature === void 0 ? (
+          // If we havent computed signature, use fileInfo as is
+          value
+        ) : (
+          // Serialize fileInfo with new updated signature
+          { version: value.version, signature: actualSignature, affectsGlobalScope: value.affectsGlobalScope, impliedFormat: value.impliedFormat }
+        )
+      ) : (
+        // Signature of the FileInfo is undefined, serialize it as false
+        { version: value.version, signature: false, affectsGlobalScope: value.affectsGlobalScope, impliedFormat: value.impliedFormat }
+      );
+    });
+    let referencedMap;
+    if (state.referencedMap) {
+      referencedMap = arrayFrom(state.referencedMap.keys()).sort(compareStringsCaseSensitive).map((key) => [
+        toFileId(key),
+        toFileIdListId(state.referencedMap.getValues(key))
+      ]);
+    }
+    let exportedModulesMap;
+    if (state.exportedModulesMap) {
+      exportedModulesMap = mapDefined(arrayFrom(state.exportedModulesMap.keys()).sort(compareStringsCaseSensitive), (key) => {
+        var _a2;
+        const oldValue = (_a2 = state.oldExportedModulesMap) == null ? void 0 : _a2.get(key);
+        if (oldValue === void 0)
+          return [toFileId(key), toFileIdListId(state.exportedModulesMap.getValues(key))];
+        if (oldValue)
+          return [toFileId(key), toFileIdListId(oldValue)];
+        return void 0;
+      });
+    }
+    let semanticDiagnosticsPerFile;
+    if (state.semanticDiagnosticsPerFile) {
+      for (const key of arrayFrom(state.semanticDiagnosticsPerFile.keys()).sort(compareStringsCaseSensitive)) {
+        const value = state.semanticDiagnosticsPerFile.get(key);
+        (semanticDiagnosticsPerFile || (semanticDiagnosticsPerFile = [])).push(
+          value.length ? [
+            toFileId(key),
+            convertToReusableDiagnostics(value, relativeToBuildInfo)
+          ] : toFileId(key)
+        );
+      }
+    }
+    let affectedFilesPendingEmit;
+    if ((_c = state.affectedFilesPendingEmit) == null ? void 0 : _c.size) {
+      const fullEmitForOptions = getBuilderFileEmit(state.compilerOptions);
+      const seenFiles = /* @__PURE__ */ new Set();
+      for (const path of arrayFrom(state.affectedFilesPendingEmit.keys()).sort(compareStringsCaseSensitive)) {
+        if (tryAddToSet(seenFiles, path)) {
+          const file = state.program.getSourceFileByPath(path);
+          if (!file || !sourceFileMayBeEmitted(file, state.program))
+            continue;
+          const fileId = toFileId(path), pendingEmit = state.affectedFilesPendingEmit.get(path);
+          (affectedFilesPendingEmit || (affectedFilesPendingEmit = [])).push(
+            pendingEmit === fullEmitForOptions ? fileId : (
+              // Pending full emit per options
+              pendingEmit === 8 /* Dts */ ? [fileId] : (
+                // Pending on Dts only
+                [fileId, pendingEmit]
+              )
             )
+            // Anything else
           );
-          return exportedModules;
-        }
-        BuilderState2.getExportedModules = getExportedModules;
-        function getAllDependencies(state, programOfThisState, sourceFile) {
-          const compilerOptions = programOfThisState.getCompilerOptions();
-          if (outFile(compilerOptions)) {
-            return getAllFileNames(state, programOfThisState);
-          }
-          if (!state.referencedMap || isFileAffectingGlobalScope(sourceFile)) {
-            return getAllFileNames(state, programOfThisState);
-          }
-          const seenMap = /* @__PURE__ */ new Set();
-          const queue = [sourceFile.resolvedPath];
-          while (queue.length) {
-            const path = queue.pop();
-            if (!seenMap.has(path)) {
-              seenMap.add(path);
-              const references = state.referencedMap.getValues(path);
-              if (references) {
-                for (const key of references.keys()) {
-                  queue.push(key);
-                }
-              }
-            }
-          }
-          return arrayFrom(mapDefinedIterator(seenMap.keys(), (path) => {
-            var _a;
-            return ((_a = programOfThisState.getSourceFileByPath(path)) == null ? void 0 : _a.fileName) ?? path;
-          }));
-        }
-        BuilderState2.getAllDependencies = getAllDependencies;
-        function getAllFileNames(state, programOfThisState) {
-          if (!state.allFileNames) {
-            const sourceFiles = programOfThisState.getSourceFiles();
-            state.allFileNames = sourceFiles === emptyArray ? emptyArray : sourceFiles.map((file) => file.fileName);
-          }
-          return state.allFileNames;
-        }
-        function getReferencedByPaths(state, referencedFilePath) {
-          const keys = state.referencedMap.getKeys(referencedFilePath);
-          return keys ? arrayFrom(keys.keys()) : [];
-        }
-        BuilderState2.getReferencedByPaths = getReferencedByPaths;
-        function containsOnlyAmbientModules(sourceFile) {
-          for (const statement of sourceFile.statements) {
-            if (!isModuleWithStringLiteralName(statement)) {
-              return false;
-            }
-          }
-          return true;
-        }
-        function containsGlobalScopeAugmentation(sourceFile) {
-          return some(sourceFile.moduleAugmentations, (augmentation) => isGlobalScopeAugmentation(augmentation.parent));
-        }
-        function isFileAffectingGlobalScope(sourceFile) {
-          return containsGlobalScopeAugmentation(sourceFile) || !isExternalOrCommonJsModule(sourceFile) && !isJsonSourceFile(sourceFile) && !containsOnlyAmbientModules(sourceFile);
-        }
-        function getAllFilesExcludingDefaultLibraryFile(state, programOfThisState, firstSourceFile) {
-          if (state.allFilesExcludingDefaultLibraryFile) {
-            return state.allFilesExcludingDefaultLibraryFile;
-          }
-          let result;
-          if (firstSourceFile)
-            addSourceFile(firstSourceFile);
-          for (const sourceFile of programOfThisState.getSourceFiles()) {
-            if (sourceFile !== firstSourceFile) {
-              addSourceFile(sourceFile);
-            }
-          }
-          state.allFilesExcludingDefaultLibraryFile = result || emptyArray;
-          return state.allFilesExcludingDefaultLibraryFile;
-          function addSourceFile(sourceFile) {
-            if (!programOfThisState.isSourceFileDefaultLibrary(sourceFile)) {
-              (result || (result = [])).push(sourceFile);
-            }
-          }
         }
-        BuilderState2.getAllFilesExcludingDefaultLibraryFile = getAllFilesExcludingDefaultLibraryFile;
-        function getFilesAffectedByUpdatedShapeWhenNonModuleEmit(state, programOfThisState, sourceFileWithUpdatedShape) {
-          const compilerOptions = programOfThisState.getCompilerOptions();
-          if (compilerOptions && outFile(compilerOptions)) {
-            return [sourceFileWithUpdatedShape];
-          }
-          return getAllFilesExcludingDefaultLibraryFile(state, programOfThisState, sourceFileWithUpdatedShape);
+      }
+    }
+    let changeFileSet;
+    if (state.changedFilesSet.size) {
+      for (const path of arrayFrom(state.changedFilesSet.keys()).sort(compareStringsCaseSensitive)) {
+        (changeFileSet || (changeFileSet = [])).push(toFileId(path));
+      }
+    }
+    const program = {
+      fileNames,
+      fileInfos,
+      root,
+      options: convertToProgramBuildInfoCompilerOptions(state.compilerOptions),
+      fileIdsList,
+      referencedMap,
+      exportedModulesMap,
+      semanticDiagnosticsPerFile,
+      affectedFilesPendingEmit,
+      changeFileSet,
+      emitSignatures,
+      latestChangedDtsFile
+    };
+    return createBuildInfo(program, bundle);
+    function relativeToBuildInfoEnsuringAbsolutePath(path) {
+      return relativeToBuildInfo(getNormalizedAbsolutePath(path, currentDirectory));
+    }
+    function relativeToBuildInfo(path) {
+      return ensurePathIsNonModuleName(getRelativePathFromDirectory(buildInfoDirectory, path, state.program.getCanonicalFileName));
+    }
+    function toFileId(path) {
+      let fileId = fileNameToFileId.get(path);
+      if (fileId === void 0) {
+        fileNames.push(relativeToBuildInfo(path));
+        fileNameToFileId.set(path, fileId = fileNames.length);
+      }
+      return fileId;
+    }
+    function toFileIdListId(set) {
+      const fileIds = arrayFrom(set.keys(), toFileId).sort(compareValues);
+      const key = fileIds.join();
+      let fileIdListId = fileNamesToFileIdListId == null ? void 0 : fileNamesToFileIdListId.get(key);
+      if (fileIdListId === void 0) {
+        (fileIdsList || (fileIdsList = [])).push(fileIds);
+        (fileNamesToFileIdListId || (fileNamesToFileIdListId = /* @__PURE__ */ new Map())).set(key, fileIdListId = fileIdsList.length);
+      }
+      return fileIdListId;
+    }
+    function tryAddRoot(path, fileId) {
+      const file = state.program.getSourceFile(path);
+      if (!state.program.getFileIncludeReasons().get(file.path).some((r) => r.kind === 0 /* RootFile */))
+        return;
+      if (!root.length)
+        return root.push(fileId);
+      const last2 = root[root.length - 1];
+      const isLastStartEnd = isArray(last2);
+      if (isLastStartEnd && last2[1] === fileId - 1)
+        return last2[1] = fileId;
+      if (isLastStartEnd || root.length === 1 || last2 !== fileId - 1)
+        return root.push(fileId);
+      const lastButOne = root[root.length - 2];
+      if (!isNumber(lastButOne) || lastButOne !== last2 - 1)
+        return root.push(fileId);
+      root[root.length - 2] = [lastButOne, fileId];
+      return root.length = root.length - 1;
+    }
+    function convertToProgramBuildInfoCompilerOptions(options) {
+      let result;
+      const { optionsNameMap } = getOptionsNameMap();
+      for (const name of getOwnKeys(options).sort(compareStringsCaseSensitive)) {
+        const optionInfo = optionsNameMap.get(name.toLowerCase());
+        if (optionInfo == null ? void 0 : optionInfo.affectsBuildInfo) {
+          (result || (result = {}))[name] = convertToReusableCompilerOptionValue(
+            optionInfo,
+            options[name],
+            relativeToBuildInfoEnsuringAbsolutePath
+          );
         }
-        function getFilesAffectedByUpdatedShapeWhenModuleEmit(state, programOfThisState, sourceFileWithUpdatedShape, cancellationToken, host) {
-          if (isFileAffectingGlobalScope(sourceFileWithUpdatedShape)) {
-            return getAllFilesExcludingDefaultLibraryFile(state, programOfThisState, sourceFileWithUpdatedShape);
-          }
-          const compilerOptions = programOfThisState.getCompilerOptions();
-          if (compilerOptions && (getIsolatedModules(compilerOptions) || outFile(compilerOptions))) {
-            return [sourceFileWithUpdatedShape];
-          }
-          const seenFileNamesMap = /* @__PURE__ */ new Map();
-          seenFileNamesMap.set(sourceFileWithUpdatedShape.resolvedPath, sourceFileWithUpdatedShape);
-          const queue = getReferencedByPaths(state, sourceFileWithUpdatedShape.resolvedPath);
-          while (queue.length > 0) {
-            const currentPath = queue.pop();
-            if (!seenFileNamesMap.has(currentPath)) {
-              const currentSourceFile = programOfThisState.getSourceFileByPath(currentPath);
-              seenFileNamesMap.set(currentPath, currentSourceFile);
-              if (currentSourceFile && updateShapeSignature(state, programOfThisState, currentSourceFile, cancellationToken, host)) {
-                queue.push(...getReferencedByPaths(state, currentSourceFile.resolvedPath));
-              }
-            }
-          }
-          return arrayFrom(mapDefinedIterator(seenFileNamesMap.values(), (value) => value));
+      }
+      return result;
+    }
+  }
+  function convertToReusableCompilerOptionValue(option, value, relativeToBuildInfo) {
+    if (option) {
+      Debug.assert(option.type !== "listOrElement");
+      if (option.type === "list") {
+        const values = value;
+        if (option.element.isFilePath && values.length) {
+          return values.map(relativeToBuildInfo);
         }
-      })(BuilderState || (BuilderState = {}));
+      } else if (option.isFilePath) {
+        return relativeToBuildInfo(value);
+      }
     }
-  });
-
-  // src/compiler/builder.ts
-  function getBuilderFileEmit(options) {
-    let result = 1 /* Js */;
-    if (options.sourceMap)
-      result = result | 2 /* JsMap */;
-    if (options.inlineSourceMap)
-      result = result | 4 /* JsInlineMap */;
-    if (getEmitDeclarations(options))
-      result = result | 8 /* Dts */;
-    if (options.declarationMap)
-      result = result | 16 /* DtsMap */;
-    if (options.emitDeclarationOnly)
-      result = result & 24 /* AllDts */;
-    return result;
+    return value;
   }
-  function getPendingEmitKind(optionsOrEmitKind, oldOptionsOrEmitKind) {
-    const oldEmitKind = oldOptionsOrEmitKind && (isNumber(oldOptionsOrEmitKind) ? oldOptionsOrEmitKind : getBuilderFileEmit(oldOptionsOrEmitKind));
-    const emitKind = isNumber(optionsOrEmitKind) ? optionsOrEmitKind : getBuilderFileEmit(optionsOrEmitKind);
-    if (oldEmitKind === emitKind)
-      return 0 /* None */;
-    if (!oldEmitKind || !emitKind)
-      return emitKind;
-    const diff = oldEmitKind ^ emitKind;
-    let result = 0 /* None */;
-    if (diff & 7 /* AllJs */)
-      result = emitKind & 7 /* AllJs */;
-    if (diff & 24 /* AllDts */)
-      result = result | emitKind & 24 /* AllDts */;
-    return result;
+  function convertToReusableDiagnostics(diagnostics, relativeToBuildInfo) {
+    Debug.assert(!!diagnostics.length);
+    return diagnostics.map((diagnostic) => {
+      const result = convertToReusableDiagnosticRelatedInformation(diagnostic, relativeToBuildInfo);
+      result.reportsUnnecessary = diagnostic.reportsUnnecessary;
+      result.reportDeprecated = diagnostic.reportsDeprecated;
+      result.source = diagnostic.source;
+      result.skippedOn = diagnostic.skippedOn;
+      const { relatedInformation } = diagnostic;
+      result.relatedInformation = relatedInformation ? relatedInformation.length ? relatedInformation.map((r) => convertToReusableDiagnosticRelatedInformation(r, relativeToBuildInfo)) : [] : void 0;
+      return result;
+    });
   }
-  function hasSameKeys(map1, map2) {
-    return map1 === map2 || map1 !== void 0 && map2 !== void 0 && map1.size === map2.size && !forEachKey(map1, (key) => !map2.has(key));
+  function convertToReusableDiagnosticRelatedInformation(diagnostic, relativeToBuildInfo) {
+    const { file } = diagnostic;
+    return {
+      ...diagnostic,
+      file: file ? relativeToBuildInfo(file.resolvedPath) : void 0,
+      messageText: isString(diagnostic.messageText) ? diagnostic.messageText : convertToReusableDiagnosticMessageChain(diagnostic.messageText)
+    };
   }
-  function createBuilderProgramState(newProgram, oldState) {
-    var _a, _b;
-    const state = BuilderState.create(
-      newProgram,
-      oldState,
-      /*disableUseFileVersionAsSignature*/
-      false
-    );
-    state.program = newProgram;
-    const compilerOptions = newProgram.getCompilerOptions();
-    state.compilerOptions = compilerOptions;
-    const outFilePath = outFile(compilerOptions);
-    if (!outFilePath) {
-      state.semanticDiagnosticsPerFile = /* @__PURE__ */ new Map();
-    } else if (compilerOptions.composite && (oldState == null ? void 0 : oldState.outSignature) && outFilePath === outFile(oldState == null ? void 0 : oldState.compilerOptions)) {
-      state.outSignature = oldState.outSignature && getEmitSignatureFromOldSignature(compilerOptions, oldState.compilerOptions, oldState.outSignature);
+  function convertToReusableDiagnosticMessageChain(chain) {
+    if (chain.repopulateInfo) {
+      return {
+        info: chain.repopulateInfo(),
+        next: convertToReusableDiagnosticMessageChainArray(chain.next)
+      };
     }
-    state.changedFilesSet = /* @__PURE__ */ new Set();
-    state.latestChangedDtsFile = compilerOptions.composite ? oldState == null ? void 0 : oldState.latestChangedDtsFile : void 0;
-    const useOldState = BuilderState.canReuseOldState(state.referencedMap, oldState);
-    const oldCompilerOptions = useOldState ? oldState.compilerOptions : void 0;
-    const canCopySemanticDiagnostics = useOldState && oldState.semanticDiagnosticsPerFile && !!state.semanticDiagnosticsPerFile && !compilerOptionsAffectSemanticDiagnostics(compilerOptions, oldCompilerOptions);
-    const canCopyEmitSignatures = compilerOptions.composite && (oldState == null ? void 0 : oldState.emitSignatures) && !outFilePath && !compilerOptionsAffectDeclarationPath(compilerOptions, oldState.compilerOptions);
-    if (useOldState) {
-      (_a = oldState.changedFilesSet) == null ? void 0 : _a.forEach((value) => state.changedFilesSet.add(value));
-      if (!outFilePath && ((_b = oldState.affectedFilesPendingEmit) == null ? void 0 : _b.size)) {
-        state.affectedFilesPendingEmit = new Map(oldState.affectedFilesPendingEmit);
-        state.seenAffectedFiles = /* @__PURE__ */ new Set();
+    const next = convertToReusableDiagnosticMessageChainArray(chain.next);
+    return next === chain.next ? chain : { ...chain, next };
+  }
+  function convertToReusableDiagnosticMessageChainArray(array) {
+    if (!array)
+      return array;
+    return forEach(array, (chain, index) => {
+      const reusable = convertToReusableDiagnosticMessageChain(chain);
+      if (chain === reusable)
+        return void 0;
+      const result = index > 0 ? array.slice(0, index - 1) : [];
+      result.push(reusable);
+      for (let i = index + 1; i < array.length; i++) {
+        result.push(convertToReusableDiagnosticMessageChain(array[i]));
       }
-      state.programEmitPending = oldState.programEmitPending;
+      return result;
+    }) || array;
+  }
+  function getBuilderCreationParameters(newProgramOrRootNames, hostOrOptions, oldProgramOrHost, configFileParsingDiagnosticsOrOldProgram, configFileParsingDiagnostics, projectReferences) {
+    let host;
+    let newProgram;
+    let oldProgram;
+    if (newProgramOrRootNames === void 0) {
+      Debug.assert(hostOrOptions === void 0);
+      host = oldProgramOrHost;
+      oldProgram = configFileParsingDiagnosticsOrOldProgram;
+      Debug.assert(!!oldProgram);
+      newProgram = oldProgram.getProgram();
+    } else if (isArray(newProgramOrRootNames)) {
+      oldProgram = configFileParsingDiagnosticsOrOldProgram;
+      newProgram = createProgram({
+        rootNames: newProgramOrRootNames,
+        options: hostOrOptions,
+        host: oldProgramOrHost,
+        oldProgram: oldProgram && oldProgram.getProgramOrUndefined(),
+        configFileParsingDiagnostics,
+        projectReferences
+      });
+      host = oldProgramOrHost;
     } else {
-      state.buildInfoEmitPending = true;
+      newProgram = newProgramOrRootNames;
+      host = hostOrOptions;
+      oldProgram = oldProgramOrHost;
+      configFileParsingDiagnostics = configFileParsingDiagnosticsOrOldProgram;
     }
-    const referencedMap = state.referencedMap;
-    const oldReferencedMap = useOldState ? oldState.referencedMap : void 0;
-    const copyDeclarationFileDiagnostics = canCopySemanticDiagnostics && !compilerOptions.skipLibCheck === !oldCompilerOptions.skipLibCheck;
-    const copyLibFileDiagnostics = copyDeclarationFileDiagnostics && !compilerOptions.skipDefaultLibCheck === !oldCompilerOptions.skipDefaultLibCheck;
-    state.fileInfos.forEach((info, sourceFilePath) => {
-      let oldInfo;
-      let newReferences;
-      if (!useOldState || // File wasn't present in old state
-      !(oldInfo = oldState.fileInfos.get(sourceFilePath)) || // versions dont match
-      oldInfo.version !== info.version || // Implied formats dont match
-      oldInfo.impliedFormat !== info.impliedFormat || // Referenced files changed
-      !hasSameKeys(newReferences = referencedMap && referencedMap.getValues(sourceFilePath), oldReferencedMap && oldReferencedMap.getValues(sourceFilePath)) || // Referenced file was deleted in the new program
-      newReferences && forEachKey(newReferences, (path) => !state.fileInfos.has(path) && oldState.fileInfos.has(path))) {
-        addFileToChangeSet(state, sourceFilePath);
-      } else if (canCopySemanticDiagnostics) {
-        const sourceFile = newProgram.getSourceFileByPath(sourceFilePath);
-        if (sourceFile.isDeclarationFile && !copyDeclarationFileDiagnostics)
-          return;
-        if (sourceFile.hasNoDefaultLib && !copyLibFileDiagnostics)
-          return;
-        const diagnostics = oldState.semanticDiagnosticsPerFile.get(sourceFilePath);
-        if (diagnostics) {
-          state.semanticDiagnosticsPerFile.set(
-            sourceFilePath,
-            oldState.hasReusableDiagnostic ? convertToDiagnostics(diagnostics, newProgram) : repopulateDiagnostics(diagnostics, newProgram)
-          );
-          if (!state.semanticDiagnosticsFromOldState) {
-            state.semanticDiagnosticsFromOldState = /* @__PURE__ */ new Set();
+    return { host, newProgram, oldProgram, configFileParsingDiagnostics: configFileParsingDiagnostics || emptyArray };
+  }
+  function getTextHandlingSourceMapForSignature(text, data) {
+    return (data == null ? void 0 : data.sourceMapUrlPos) !== void 0 ? text.substring(0, data.sourceMapUrlPos) : text;
+  }
+  function computeSignatureWithDiagnostics(program, sourceFile, text, host, data) {
+    var _a;
+    text = getTextHandlingSourceMapForSignature(text, data);
+    let sourceFileDirectory;
+    if ((_a = data == null ? void 0 : data.diagnostics) == null ? void 0 : _a.length) {
+      text += data.diagnostics.map((diagnostic) => `${locationInfo(diagnostic)}${DiagnosticCategory[diagnostic.category]}${diagnostic.code}: ${flattenDiagnosticMessageText2(diagnostic.messageText)}`).join("\n");
+    }
+    return (host.createHash ?? generateDjb2Hash)(text);
+    function flattenDiagnosticMessageText2(diagnostic) {
+      return isString(diagnostic) ? diagnostic : diagnostic === void 0 ? "" : !diagnostic.next ? diagnostic.messageText : diagnostic.messageText + diagnostic.next.map(flattenDiagnosticMessageText2).join("\n");
+    }
+    function locationInfo(diagnostic) {
+      if (diagnostic.file.resolvedPath === sourceFile.resolvedPath)
+        return `(${diagnostic.start},${diagnostic.length})`;
+      if (sourceFileDirectory === void 0)
+        sourceFileDirectory = getDirectoryPath(sourceFile.resolvedPath);
+      return `${ensurePathIsNonModuleName(getRelativePathFromDirectory(
+        sourceFileDirectory,
+        diagnostic.file.resolvedPath,
+        program.getCanonicalFileName
+      ))}(${diagnostic.start},${diagnostic.length})`;
+    }
+  }
+  function computeSignature(text, host, data) {
+    return (host.createHash ?? generateDjb2Hash)(getTextHandlingSourceMapForSignature(text, data));
+  }
+  function createBuilderProgram(kind, { newProgram, host, oldProgram, configFileParsingDiagnostics }) {
+    let oldState = oldProgram && oldProgram.getState();
+    if (oldState && newProgram === oldState.program && configFileParsingDiagnostics === newProgram.getConfigFileParsingDiagnostics()) {
+      newProgram = void 0;
+      oldState = void 0;
+      return oldProgram;
+    }
+    const state = createBuilderProgramState(newProgram, oldState);
+    newProgram.getBuildInfo = (bundle) => getBuildInfo2(state, bundle);
+    newProgram = void 0;
+    oldProgram = void 0;
+    oldState = void 0;
+    const getState = () => state;
+    const builderProgram = createRedirectedBuilderProgram(getState, configFileParsingDiagnostics);
+    builderProgram.getState = getState;
+    builderProgram.saveEmitState = () => backupBuilderProgramEmitState(state);
+    builderProgram.restoreEmitState = (saved) => restoreBuilderProgramEmitState(state, saved);
+    builderProgram.hasChangedEmitSignature = () => !!state.hasChangedEmitSignature;
+    builderProgram.getAllDependencies = (sourceFile) => BuilderState.getAllDependencies(state, Debug.checkDefined(state.program), sourceFile);
+    builderProgram.getSemanticDiagnostics = getSemanticDiagnostics;
+    builderProgram.emit = emit;
+    builderProgram.releaseProgram = () => releaseCache(state);
+    if (kind === 0 /* SemanticDiagnosticsBuilderProgram */) {
+      builderProgram.getSemanticDiagnosticsOfNextAffectedFile = getSemanticDiagnosticsOfNextAffectedFile;
+    } else if (kind === 1 /* EmitAndSemanticDiagnosticsBuilderProgram */) {
+      builderProgram.getSemanticDiagnosticsOfNextAffectedFile = getSemanticDiagnosticsOfNextAffectedFile;
+      builderProgram.emitNextAffectedFile = emitNextAffectedFile;
+      builderProgram.emitBuildInfo = emitBuildInfo;
+    } else {
+      notImplemented();
+    }
+    return builderProgram;
+    function emitBuildInfo(writeFile2, cancellationToken) {
+      if (state.buildInfoEmitPending) {
+        const result = Debug.checkDefined(state.program).emitBuildInfo(writeFile2 || maybeBind(host, host.writeFile), cancellationToken);
+        state.buildInfoEmitPending = false;
+        return result;
+      }
+      return emitSkippedWithNoDiagnostics;
+    }
+    function emitNextAffectedFile(writeFile2, cancellationToken, emitOnlyDtsFiles, customTransformers) {
+      var _a, _b, _c;
+      let affected = getNextAffectedFile(state, cancellationToken, host);
+      const programEmitKind = getBuilderFileEmit(state.compilerOptions);
+      let emitKind = emitOnlyDtsFiles ? programEmitKind & 24 /* AllDts */ : programEmitKind;
+      if (!affected) {
+        if (!outFile(state.compilerOptions)) {
+          const pendingAffectedFile = getNextAffectedFilePendingEmit(state, emitOnlyDtsFiles);
+          if (!pendingAffectedFile) {
+            if (!state.buildInfoEmitPending)
+              return void 0;
+            const affected2 = state.program;
+            const result2 = affected2.emitBuildInfo(writeFile2 || maybeBind(host, host.writeFile), cancellationToken);
+            state.buildInfoEmitPending = false;
+            return { result: result2, affected: affected2 };
           }
-          state.semanticDiagnosticsFromOldState.add(sourceFilePath);
+          ({ affectedFile: affected, emitKind } = pendingAffectedFile);
+        } else {
+          if (!state.programEmitPending)
+            return void 0;
+          emitKind = state.programEmitPending;
+          if (emitOnlyDtsFiles)
+            emitKind = emitKind & 24 /* AllDts */;
+          if (!emitKind)
+            return void 0;
+          affected = state.program;
         }
       }
-      if (canCopyEmitSignatures) {
-        const oldEmitSignature = oldState.emitSignatures.get(sourceFilePath);
-        if (oldEmitSignature) {
-          (state.emitSignatures ?? (state.emitSignatures = /* @__PURE__ */ new Map())).set(sourceFilePath, getEmitSignatureFromOldSignature(compilerOptions, oldState.compilerOptions, oldEmitSignature));
-        }
+      let emitOnly;
+      if (emitKind & 7 /* AllJs */)
+        emitOnly = 0 /* Js */;
+      if (emitKind & 24 /* AllDts */)
+        emitOnly = emitOnly === void 0 ? 1 /* Dts */ : void 0;
+      if (affected === state.program) {
+        state.programEmitPending = state.changedFilesSet.size ? getPendingEmitKind(programEmitKind, emitKind) : state.programEmitPending ? getPendingEmitKind(state.programEmitPending, emitKind) : void 0;
       }
-    });
-    if (useOldState && forEachEntry(oldState.fileInfos, (info, sourceFilePath) => {
-      if (state.fileInfos.has(sourceFilePath))
-        return false;
-      if (outFilePath || info.affectsGlobalScope)
-        return true;
-      state.buildInfoEmitPending = true;
-      return false;
-    })) {
-      BuilderState.getAllFilesExcludingDefaultLibraryFile(
-        state,
-        newProgram,
-        /*firstSourceFile*/
-        void 0
-      ).forEach((file) => addFileToChangeSet(state, file.resolvedPath));
-    } else if (oldCompilerOptions) {
-      const pendingEmitKind = compilerOptionsAffectEmit(compilerOptions, oldCompilerOptions) ? getBuilderFileEmit(compilerOptions) : getPendingEmitKind(compilerOptions, oldCompilerOptions);
-      if (pendingEmitKind !== 0 /* None */) {
-        if (!outFilePath) {
-          newProgram.getSourceFiles().forEach((f) => {
-            if (!state.changedFilesSet.has(f.resolvedPath)) {
-              addToAffectedFilesPendingEmit(
-                state,
-                f.resolvedPath,
-                pendingEmitKind
-              );
+      const result = state.program.emit(
+        affected === state.program ? void 0 : affected,
+        getWriteFileCallback(writeFile2, customTransformers),
+        cancellationToken,
+        emitOnly,
+        customTransformers
+      );
+      if (affected !== state.program) {
+        const affectedSourceFile = affected;
+        state.seenAffectedFiles.add(affectedSourceFile.resolvedPath);
+        if (state.affectedFilesIndex !== void 0)
+          state.affectedFilesIndex++;
+        state.buildInfoEmitPending = true;
+        const existing = ((_a = state.seenEmittedFiles) == null ? void 0 : _a.get(affectedSourceFile.resolvedPath)) || 0 /* None */;
+        (state.seenEmittedFiles ?? (state.seenEmittedFiles = /* @__PURE__ */ new Map())).set(affectedSourceFile.resolvedPath, emitKind | existing);
+        const existingPending = ((_b = state.affectedFilesPendingEmit) == null ? void 0 : _b.get(affectedSourceFile.resolvedPath)) || programEmitKind;
+        const pendingKind = getPendingEmitKind(existingPending, emitKind | existing);
+        if (pendingKind)
+          (state.affectedFilesPendingEmit ?? (state.affectedFilesPendingEmit = /* @__PURE__ */ new Map())).set(affectedSourceFile.resolvedPath, pendingKind);
+        else
+          (_c = state.affectedFilesPendingEmit) == null ? void 0 : _c.delete(affectedSourceFile.resolvedPath);
+      } else {
+        state.changedFilesSet.clear();
+      }
+      return { result, affected };
+    }
+    function getWriteFileCallback(writeFile2, customTransformers) {
+      if (!getEmitDeclarations(state.compilerOptions))
+        return writeFile2 || maybeBind(host, host.writeFile);
+      return (fileName, text, writeByteOrderMark, onError, sourceFiles, data) => {
+        var _a, _b, _c, _d;
+        if (isDeclarationFileName(fileName)) {
+          if (!outFile(state.compilerOptions)) {
+            Debug.assert((sourceFiles == null ? void 0 : sourceFiles.length) === 1);
+            let emitSignature;
+            if (!customTransformers) {
+              const file = sourceFiles[0];
+              const info = state.fileInfos.get(file.resolvedPath);
+              if (info.signature === file.version) {
+                const signature = computeSignatureWithDiagnostics(
+                  state.program,
+                  file,
+                  text,
+                  host,
+                  data
+                );
+                if (!((_a = data == null ? void 0 : data.diagnostics) == null ? void 0 : _a.length))
+                  emitSignature = signature;
+                if (signature !== file.version) {
+                  if (host.storeFilesChangingSignatureDuringEmit)
+                    (state.filesChangingSignature ?? (state.filesChangingSignature = /* @__PURE__ */ new Set())).add(file.resolvedPath);
+                  if (state.exportedModulesMap)
+                    BuilderState.updateExportedModules(state, file, file.exportedModulesFromDeclarationEmit);
+                  if (state.affectedFiles) {
+                    const existing = (_b = state.oldSignatures) == null ? void 0 : _b.get(file.resolvedPath);
+                    if (existing === void 0)
+                      (state.oldSignatures ?? (state.oldSignatures = /* @__PURE__ */ new Map())).set(file.resolvedPath, info.signature || false);
+                    info.signature = signature;
+                  } else {
+                    info.signature = signature;
+                    (_c = state.oldExportedModulesMap) == null ? void 0 : _c.clear();
+                  }
+                }
+              }
             }
-          });
-          Debug.assert(!state.seenAffectedFiles || !state.seenAffectedFiles.size);
-          state.seenAffectedFiles = state.seenAffectedFiles || /* @__PURE__ */ new Set();
+            if (state.compilerOptions.composite) {
+              const filePath = sourceFiles[0].resolvedPath;
+              emitSignature = handleNewSignature((_d = state.emitSignatures) == null ? void 0 : _d.get(filePath), emitSignature);
+              if (!emitSignature)
+                return;
+              (state.emitSignatures ?? (state.emitSignatures = /* @__PURE__ */ new Map())).set(filePath, emitSignature);
+            }
+          } else if (state.compilerOptions.composite) {
+            const newSignature = handleNewSignature(
+              state.outSignature,
+              /*newSignature*/
+              void 0
+            );
+            if (!newSignature)
+              return;
+            state.outSignature = newSignature;
+          }
+        }
+        if (writeFile2)
+          writeFile2(fileName, text, writeByteOrderMark, onError, sourceFiles, data);
+        else if (host.writeFile)
+          host.writeFile(fileName, text, writeByteOrderMark, onError, sourceFiles, data);
+        else
+          state.program.writeFile(fileName, text, writeByteOrderMark, onError, sourceFiles, data);
+        function handleNewSignature(oldSignatureFormat, newSignature) {
+          const oldSignature = !oldSignatureFormat || isString(oldSignatureFormat) ? oldSignatureFormat : oldSignatureFormat[0];
+          newSignature ?? (newSignature = computeSignature(text, host, data));
+          if (newSignature === oldSignature) {
+            if (oldSignatureFormat === oldSignature)
+              return void 0;
+            else if (data)
+              data.differsOnlyInMap = true;
+            else
+              data = { differsOnlyInMap: true };
+          } else {
+            state.hasChangedEmitSignature = true;
+            state.latestChangedDtsFile = fileName;
+          }
+          return newSignature;
+        }
+      };
+    }
+    function emit(targetSourceFile, writeFile2, cancellationToken, emitOnlyDtsFiles, customTransformers) {
+      if (kind === 1 /* EmitAndSemanticDiagnosticsBuilderProgram */) {
+        assertSourceFileOkWithoutNextAffectedCall(state, targetSourceFile);
+      }
+      const result = handleNoEmitOptions(builderProgram, targetSourceFile, writeFile2, cancellationToken);
+      if (result)
+        return result;
+      if (!targetSourceFile) {
+        if (kind === 1 /* EmitAndSemanticDiagnosticsBuilderProgram */) {
+          let sourceMaps = [];
+          let emitSkipped = false;
+          let diagnostics;
+          let emittedFiles = [];
+          let affectedEmitResult;
+          while (affectedEmitResult = emitNextAffectedFile(writeFile2, cancellationToken, emitOnlyDtsFiles, customTransformers)) {
+            emitSkipped = emitSkipped || affectedEmitResult.result.emitSkipped;
+            diagnostics = addRange(diagnostics, affectedEmitResult.result.diagnostics);
+            emittedFiles = addRange(emittedFiles, affectedEmitResult.result.emittedFiles);
+            sourceMaps = addRange(sourceMaps, affectedEmitResult.result.sourceMaps);
+          }
+          return {
+            emitSkipped,
+            diagnostics: diagnostics || emptyArray,
+            emittedFiles,
+            sourceMaps
+          };
+        } else {
+          clearAffectedFilesPendingEmit(state, emitOnlyDtsFiles);
+        }
+      }
+      return Debug.checkDefined(state.program).emit(
+        targetSourceFile,
+        getWriteFileCallback(writeFile2, customTransformers),
+        cancellationToken,
+        emitOnlyDtsFiles,
+        customTransformers
+      );
+    }
+    function getSemanticDiagnosticsOfNextAffectedFile(cancellationToken, ignoreSourceFile) {
+      while (true) {
+        const affected = getNextAffectedFile(state, cancellationToken, host);
+        let result;
+        if (!affected)
+          return void 0;
+        else if (affected !== state.program) {
+          const affectedSourceFile = affected;
+          if (!ignoreSourceFile || !ignoreSourceFile(affectedSourceFile)) {
+            result = getSemanticDiagnosticsOfFile(state, affectedSourceFile, cancellationToken);
+          }
+          state.seenAffectedFiles.add(affectedSourceFile.resolvedPath);
+          state.affectedFilesIndex++;
           state.buildInfoEmitPending = true;
+          if (!result)
+            continue;
         } else {
-          state.programEmitPending = state.programEmitPending ? state.programEmitPending | pendingEmitKind : pendingEmitKind;
+          result = state.program.getSemanticDiagnostics(
+            /*sourceFile*/
+            void 0,
+            cancellationToken
+          );
+          state.changedFilesSet.clear();
+          state.programEmitPending = getBuilderFileEmit(state.compilerOptions);
         }
+        return { result, affected };
       }
     }
-    if (outFilePath && !state.changedFilesSet.size) {
-      if (useOldState)
-        state.bundle = oldState.bundle;
-      if (some(newProgram.getProjectReferences(), (ref) => !!ref.prepend))
-        state.programEmitPending = getBuilderFileEmit(compilerOptions);
+    function getSemanticDiagnostics(sourceFile, cancellationToken) {
+      assertSourceFileOkWithoutNextAffectedCall(state, sourceFile);
+      const compilerOptions = Debug.checkDefined(state.program).getCompilerOptions();
+      if (outFile(compilerOptions)) {
+        Debug.assert(!state.semanticDiagnosticsPerFile);
+        return Debug.checkDefined(state.program).getSemanticDiagnostics(sourceFile, cancellationToken);
+      }
+      if (sourceFile) {
+        return getSemanticDiagnosticsOfFile(state, sourceFile, cancellationToken);
+      }
+      while (getSemanticDiagnosticsOfNextAffectedFile(cancellationToken)) {
+      }
+      let diagnostics;
+      for (const sourceFile2 of Debug.checkDefined(state.program).getSourceFiles()) {
+        diagnostics = addRange(diagnostics, getSemanticDiagnosticsOfFile(state, sourceFile2, cancellationToken));
+      }
+      return diagnostics || emptyArray;
     }
-    return state;
-  }
-  function addFileToChangeSet(state, path) {
-    state.changedFilesSet.add(path);
-    state.buildInfoEmitPending = true;
-    state.programEmitPending = void 0;
   }
-  function getEmitSignatureFromOldSignature(options, oldOptions, oldEmitSignature) {
-    return !!options.declarationMap === !!oldOptions.declarationMap ? (
-      // Use same format of signature
-      oldEmitSignature
-    ) : (
-      // Convert to different format
-      isString(oldEmitSignature) ? [oldEmitSignature] : oldEmitSignature[0]
-    );
+  function addToAffectedFilesPendingEmit(state, affectedFilePendingEmit, kind) {
+    var _a;
+    const existingKind = ((_a = state.affectedFilesPendingEmit) == null ? void 0 : _a.get(affectedFilePendingEmit)) || 0 /* None */;
+    (state.affectedFilesPendingEmit ?? (state.affectedFilesPendingEmit = /* @__PURE__ */ new Map())).set(affectedFilePendingEmit, existingKind | kind);
   }
-  function repopulateDiagnostics(diagnostics, newProgram) {
-    if (!diagnostics.length)
-      return diagnostics;
-    return sameMap(diagnostics, (diag2) => {
-      if (isString(diag2.messageText))
-        return diag2;
-      const repopulatedChain = convertOrRepopulateDiagnosticMessageChain(diag2.messageText, diag2.file, newProgram, (chain) => {
-        var _a;
-        return (_a = chain.repopulateInfo) == null ? void 0 : _a.call(chain);
-      });
-      return repopulatedChain === diag2.messageText ? diag2 : { ...diag2, messageText: repopulatedChain };
-    });
+  function toBuilderStateFileInfoForMultiEmit(fileInfo) {
+    return isString(fileInfo) ? { version: fileInfo, signature: fileInfo, affectsGlobalScope: void 0, impliedFormat: void 0 } : isString(fileInfo.signature) ? fileInfo : { version: fileInfo.version, signature: fileInfo.signature === false ? void 0 : fileInfo.version, affectsGlobalScope: fileInfo.affectsGlobalScope, impliedFormat: fileInfo.impliedFormat };
   }
-  function convertOrRepopulateDiagnosticMessageChain(chain, sourceFile, newProgram, repopulateInfo) {
-    const info = repopulateInfo(chain);
-    if (info) {
-      return {
-        ...createModuleNotFoundChain(sourceFile, newProgram, info.moduleReference, info.mode, info.packageName || info.moduleReference),
-        next: convertOrRepopulateDiagnosticMessageChainArray(chain.next, sourceFile, newProgram, repopulateInfo)
-      };
-    }
-    const next = convertOrRepopulateDiagnosticMessageChainArray(chain.next, sourceFile, newProgram, repopulateInfo);
-    return next === chain.next ? chain : { ...chain, next };
+  function toBuilderFileEmit(value, fullEmitForOptions) {
+    return isNumber(value) ? fullEmitForOptions : value[1] || 8 /* Dts */;
   }
-  function convertOrRepopulateDiagnosticMessageChainArray(array, sourceFile, newProgram, repopulateInfo) {
-    return sameMap(array, (chain) => convertOrRepopulateDiagnosticMessageChain(chain, sourceFile, newProgram, repopulateInfo));
+  function toProgramEmitPending(value, options) {
+    return !value ? getBuilderFileEmit(options || {}) : value;
   }
-  function convertToDiagnostics(diagnostics, newProgram) {
-    if (!diagnostics.length)
-      return emptyArray;
-    let buildInfoDirectory;
-    return diagnostics.map((diagnostic) => {
-      const result = convertToDiagnosticRelatedInformation(diagnostic, newProgram, toPathInBuildInfoDirectory);
-      result.reportsUnnecessary = diagnostic.reportsUnnecessary;
-      result.reportsDeprecated = diagnostic.reportDeprecated;
-      result.source = diagnostic.source;
-      result.skippedOn = diagnostic.skippedOn;
-      const { relatedInformation } = diagnostic;
-      result.relatedInformation = relatedInformation ? relatedInformation.length ? relatedInformation.map((r) => convertToDiagnosticRelatedInformation(r, newProgram, toPathInBuildInfoDirectory)) : [] : void 0;
-      return result;
-    });
-    function toPathInBuildInfoDirectory(path) {
-      buildInfoDirectory ?? (buildInfoDirectory = getDirectoryPath(getNormalizedAbsolutePath(getTsBuildInfoEmitOutputFilePath(newProgram.getCompilerOptions()), newProgram.getCurrentDirectory())));
-      return toPath(path, buildInfoDirectory, newProgram.getCanonicalFileName);
+  function createBuilderProgramUsingProgramBuildInfo(buildInfo, buildInfoPath, host) {
+    var _a, _b, _c, _d;
+    const program = buildInfo.program;
+    const buildInfoDirectory = getDirectoryPath(getNormalizedAbsolutePath(buildInfoPath, host.getCurrentDirectory()));
+    const getCanonicalFileName = createGetCanonicalFileName(host.useCaseSensitiveFileNames());
+    let state;
+    const filePaths = (_a = program.fileNames) == null ? void 0 : _a.map(toPathInBuildInfoDirectory);
+    let filePathsSetList;
+    const latestChangedDtsFile = program.latestChangedDtsFile ? toAbsolutePath(program.latestChangedDtsFile) : void 0;
+    if (isProgramBundleEmitBuildInfo(program)) {
+      const fileInfos = /* @__PURE__ */ new Map();
+      program.fileInfos.forEach((fileInfo, index) => {
+        const path = toFilePath(index + 1);
+        fileInfos.set(path, isString(fileInfo) ? { version: fileInfo, signature: void 0, affectsGlobalScope: void 0, impliedFormat: void 0 } : fileInfo);
+      });
+      state = {
+        fileInfos,
+        compilerOptions: program.options ? convertToOptionsWithAbsolutePaths(program.options, toAbsolutePath) : {},
+        latestChangedDtsFile,
+        outSignature: program.outSignature,
+        programEmitPending: program.pendingEmit === void 0 ? void 0 : toProgramEmitPending(program.pendingEmit, program.options),
+        bundle: buildInfo.bundle
+      };
+    } else {
+      filePathsSetList = (_b = program.fileIdsList) == null ? void 0 : _b.map((fileIds) => new Set(fileIds.map(toFilePath)));
+      const fileInfos = /* @__PURE__ */ new Map();
+      const emitSignatures = ((_c = program.options) == null ? void 0 : _c.composite) && !outFile(program.options) ? /* @__PURE__ */ new Map() : void 0;
+      program.fileInfos.forEach((fileInfo, index) => {
+        const path = toFilePath(index + 1);
+        const stateFileInfo = toBuilderStateFileInfoForMultiEmit(fileInfo);
+        fileInfos.set(path, stateFileInfo);
+        if (emitSignatures && stateFileInfo.signature)
+          emitSignatures.set(path, stateFileInfo.signature);
+      });
+      (_d = program.emitSignatures) == null ? void 0 : _d.forEach((value) => {
+        if (isNumber(value))
+          emitSignatures.delete(toFilePath(value));
+        else {
+          const key = toFilePath(value[0]);
+          emitSignatures.set(
+            key,
+            !isString(value[1]) && !value[1].length ? (
+              // File signature is emit signature but differs in map
+              [emitSignatures.get(key)]
+            ) : value[1]
+          );
+        }
+      });
+      const fullEmitForOptions = program.affectedFilesPendingEmit ? getBuilderFileEmit(program.options || {}) : void 0;
+      state = {
+        fileInfos,
+        compilerOptions: program.options ? convertToOptionsWithAbsolutePaths(program.options, toAbsolutePath) : {},
+        referencedMap: toManyToManyPathMap(program.referencedMap),
+        exportedModulesMap: toManyToManyPathMap(program.exportedModulesMap),
+        semanticDiagnosticsPerFile: program.semanticDiagnosticsPerFile && arrayToMap(program.semanticDiagnosticsPerFile, (value) => toFilePath(isNumber(value) ? value : value[0]), (value) => isNumber(value) ? emptyArray : value[1]),
+        hasReusableDiagnostic: true,
+        affectedFilesPendingEmit: program.affectedFilesPendingEmit && arrayToMap(program.affectedFilesPendingEmit, (value) => toFilePath(isNumber(value) ? value : value[0]), (value) => toBuilderFileEmit(value, fullEmitForOptions)),
+        changedFilesSet: new Set(map(program.changeFileSet, toFilePath)),
+        latestChangedDtsFile,
+        emitSignatures: (emitSignatures == null ? void 0 : emitSignatures.size) ? emitSignatures : void 0
+      };
     }
-  }
-  function convertToDiagnosticRelatedInformation(diagnostic, newProgram, toPath3) {
-    const { file } = diagnostic;
-    const sourceFile = file ? newProgram.getSourceFileByPath(toPath3(file)) : void 0;
     return {
-      ...diagnostic,
-      file: sourceFile,
-      messageText: isString(diagnostic.messageText) ? diagnostic.messageText : convertOrRepopulateDiagnosticMessageChain(diagnostic.messageText, sourceFile, newProgram, (chain) => chain.info)
+      getState: () => state,
+      saveEmitState: noop,
+      restoreEmitState: noop,
+      getProgram: notImplemented,
+      getProgramOrUndefined: returnUndefined,
+      releaseProgram: noop,
+      getCompilerOptions: () => state.compilerOptions,
+      getSourceFile: notImplemented,
+      getSourceFiles: notImplemented,
+      getOptionsDiagnostics: notImplemented,
+      getGlobalDiagnostics: notImplemented,
+      getConfigFileParsingDiagnostics: notImplemented,
+      getSyntacticDiagnostics: notImplemented,
+      getDeclarationDiagnostics: notImplemented,
+      getSemanticDiagnostics: notImplemented,
+      emit: notImplemented,
+      getAllDependencies: notImplemented,
+      getCurrentDirectory: notImplemented,
+      emitNextAffectedFile: notImplemented,
+      getSemanticDiagnosticsOfNextAffectedFile: notImplemented,
+      emitBuildInfo: notImplemented,
+      close: noop,
+      hasChangedEmitSignature: returnFalse
     };
+    function toPathInBuildInfoDirectory(path) {
+      return toPath(path, buildInfoDirectory, getCanonicalFileName);
+    }
+    function toAbsolutePath(path) {
+      return getNormalizedAbsolutePath(path, buildInfoDirectory);
+    }
+    function toFilePath(fileId) {
+      return filePaths[fileId - 1];
+    }
+    function toFilePathsSet(fileIdsListId) {
+      return filePathsSetList[fileIdsListId - 1];
+    }
+    function toManyToManyPathMap(referenceMap) {
+      if (!referenceMap) {
+        return void 0;
+      }
+      const map2 = BuilderState.createManyToManyPathMap();
+      referenceMap.forEach(([fileId, fileIdListId]) => map2.set(toFilePath(fileId), toFilePathsSet(fileIdListId)));
+      return map2;
+    }
   }
-  function releaseCache(state) {
-    BuilderState.releaseCache(state);
-    state.program = void 0;
+  function getBuildInfoFileVersionMap(program, buildInfoPath, host) {
+    const buildInfoDirectory = getDirectoryPath(getNormalizedAbsolutePath(buildInfoPath, host.getCurrentDirectory()));
+    const getCanonicalFileName = createGetCanonicalFileName(host.useCaseSensitiveFileNames());
+    const fileInfos = /* @__PURE__ */ new Map();
+    let rootIndex = 0;
+    const roots = [];
+    program.fileInfos.forEach((fileInfo, index) => {
+      const path = toPath(program.fileNames[index], buildInfoDirectory, getCanonicalFileName);
+      const version2 = isString(fileInfo) ? fileInfo : fileInfo.version;
+      fileInfos.set(path, version2);
+      if (rootIndex < program.root.length) {
+        const current = program.root[rootIndex];
+        const fileId = index + 1;
+        if (isArray(current)) {
+          if (current[0] <= fileId && fileId <= current[1]) {
+            roots.push(path);
+            if (current[1] === fileId)
+              rootIndex++;
+          }
+        } else if (current === fileId) {
+          roots.push(path);
+          rootIndex++;
+        }
+      }
+    });
+    return { fileInfos, roots };
   }
-  function backupBuilderProgramEmitState(state) {
-    const outFilePath = outFile(state.compilerOptions);
-    Debug.assert(!state.changedFilesSet.size || outFilePath);
+  function createRedirectedBuilderProgram(getState, configFileParsingDiagnostics) {
     return {
-      affectedFilesPendingEmit: state.affectedFilesPendingEmit && new Map(state.affectedFilesPendingEmit),
-      seenEmittedFiles: state.seenEmittedFiles && new Map(state.seenEmittedFiles),
-      programEmitPending: state.programEmitPending,
-      emitSignatures: state.emitSignatures && new Map(state.emitSignatures),
-      outSignature: state.outSignature,
-      latestChangedDtsFile: state.latestChangedDtsFile,
-      hasChangedEmitSignature: state.hasChangedEmitSignature,
-      changedFilesSet: outFilePath ? new Set(state.changedFilesSet) : void 0
+      getState: notImplemented,
+      saveEmitState: noop,
+      restoreEmitState: noop,
+      getProgram,
+      getProgramOrUndefined: () => getState().program,
+      releaseProgram: () => getState().program = void 0,
+      getCompilerOptions: () => getState().compilerOptions,
+      getSourceFile: (fileName) => getProgram().getSourceFile(fileName),
+      getSourceFiles: () => getProgram().getSourceFiles(),
+      getOptionsDiagnostics: (cancellationToken) => getProgram().getOptionsDiagnostics(cancellationToken),
+      getGlobalDiagnostics: (cancellationToken) => getProgram().getGlobalDiagnostics(cancellationToken),
+      getConfigFileParsingDiagnostics: () => configFileParsingDiagnostics,
+      getSyntacticDiagnostics: (sourceFile, cancellationToken) => getProgram().getSyntacticDiagnostics(sourceFile, cancellationToken),
+      getDeclarationDiagnostics: (sourceFile, cancellationToken) => getProgram().getDeclarationDiagnostics(sourceFile, cancellationToken),
+      getSemanticDiagnostics: (sourceFile, cancellationToken) => getProgram().getSemanticDiagnostics(sourceFile, cancellationToken),
+      emit: (sourceFile, writeFile2, cancellationToken, emitOnlyDts, customTransformers) => getProgram().emit(sourceFile, writeFile2, cancellationToken, emitOnlyDts, customTransformers),
+      emitBuildInfo: (writeFile2, cancellationToken) => getProgram().emitBuildInfo(writeFile2, cancellationToken),
+      getAllDependencies: notImplemented,
+      getCurrentDirectory: () => getProgram().getCurrentDirectory(),
+      close: noop
     };
+    function getProgram() {
+      return Debug.checkDefined(getState().program);
+    }
+  }
+  var BuilderFileEmit, BuilderProgramKind;
+  var init_builder = __esm({
+    "src/compiler/builder.ts"() {
+      "use strict";
+      init_ts2();
+      BuilderFileEmit = /* @__PURE__ */ ((BuilderFileEmit2) => {
+        BuilderFileEmit2[BuilderFileEmit2["None"] = 0] = "None";
+        BuilderFileEmit2[BuilderFileEmit2["Js"] = 1] = "Js";
+        BuilderFileEmit2[BuilderFileEmit2["JsMap"] = 2] = "JsMap";
+        BuilderFileEmit2[BuilderFileEmit2["JsInlineMap"] = 4] = "JsInlineMap";
+        BuilderFileEmit2[BuilderFileEmit2["Dts"] = 8] = "Dts";
+        BuilderFileEmit2[BuilderFileEmit2["DtsMap"] = 16] = "DtsMap";
+        BuilderFileEmit2[BuilderFileEmit2["AllJs"] = 7] = "AllJs";
+        BuilderFileEmit2[BuilderFileEmit2["AllDts"] = 24] = "AllDts";
+        BuilderFileEmit2[BuilderFileEmit2["All"] = 31] = "All";
+        return BuilderFileEmit2;
+      })(BuilderFileEmit || {});
+      BuilderProgramKind = /* @__PURE__ */ ((BuilderProgramKind2) => {
+        BuilderProgramKind2[BuilderProgramKind2["SemanticDiagnosticsBuilderProgram"] = 0] = "SemanticDiagnosticsBuilderProgram";
+        BuilderProgramKind2[BuilderProgramKind2["EmitAndSemanticDiagnosticsBuilderProgram"] = 1] = "EmitAndSemanticDiagnosticsBuilderProgram";
+        return BuilderProgramKind2;
+      })(BuilderProgramKind || {});
+    }
+  });
+
+  // src/compiler/builderPublic.ts
+  function createSemanticDiagnosticsBuilderProgram(newProgramOrRootNames, hostOrOptions, oldProgramOrHost, configFileParsingDiagnosticsOrOldProgram, configFileParsingDiagnostics, projectReferences) {
+    return createBuilderProgram(0 /* SemanticDiagnosticsBuilderProgram */, getBuilderCreationParameters(newProgramOrRootNames, hostOrOptions, oldProgramOrHost, configFileParsingDiagnosticsOrOldProgram, configFileParsingDiagnostics, projectReferences));
   }
-  function restoreBuilderProgramEmitState(state, savedEmitState) {
-    state.affectedFilesPendingEmit = savedEmitState.affectedFilesPendingEmit;
-    state.seenEmittedFiles = savedEmitState.seenEmittedFiles;
-    state.programEmitPending = savedEmitState.programEmitPending;
-    state.emitSignatures = savedEmitState.emitSignatures;
-    state.outSignature = savedEmitState.outSignature;
-    state.latestChangedDtsFile = savedEmitState.latestChangedDtsFile;
-    state.hasChangedEmitSignature = savedEmitState.hasChangedEmitSignature;
-    if (savedEmitState.changedFilesSet)
-      state.changedFilesSet = savedEmitState.changedFilesSet;
+  function createEmitAndSemanticDiagnosticsBuilderProgram(newProgramOrRootNames, hostOrOptions, oldProgramOrHost, configFileParsingDiagnosticsOrOldProgram, configFileParsingDiagnostics, projectReferences) {
+    return createBuilderProgram(1 /* EmitAndSemanticDiagnosticsBuilderProgram */, getBuilderCreationParameters(newProgramOrRootNames, hostOrOptions, oldProgramOrHost, configFileParsingDiagnosticsOrOldProgram, configFileParsingDiagnostics, projectReferences));
   }
-  function assertSourceFileOkWithoutNextAffectedCall(state, sourceFile) {
-    Debug.assert(!sourceFile || !state.affectedFiles || state.affectedFiles[state.affectedFilesIndex - 1] !== sourceFile || !state.semanticDiagnosticsPerFile.has(sourceFile.resolvedPath));
+  function createAbstractBuilder(newProgramOrRootNames, hostOrOptions, oldProgramOrHost, configFileParsingDiagnosticsOrOldProgram, configFileParsingDiagnostics, projectReferences) {
+    const { newProgram, configFileParsingDiagnostics: newConfigFileParsingDiagnostics } = getBuilderCreationParameters(newProgramOrRootNames, hostOrOptions, oldProgramOrHost, configFileParsingDiagnosticsOrOldProgram, configFileParsingDiagnostics, projectReferences);
+    return createRedirectedBuilderProgram(() => ({ program: newProgram, compilerOptions: newProgram.getCompilerOptions() }), newConfigFileParsingDiagnostics);
   }
-  function getNextAffectedFile(state, cancellationToken, host) {
-    var _a, _b;
-    while (true) {
-      const { affectedFiles } = state;
-      if (affectedFiles) {
-        const seenAffectedFiles = state.seenAffectedFiles;
-        let affectedFilesIndex = state.affectedFilesIndex;
-        while (affectedFilesIndex < affectedFiles.length) {
-          const affectedFile = affectedFiles[affectedFilesIndex];
-          if (!seenAffectedFiles.has(affectedFile.resolvedPath)) {
-            state.affectedFilesIndex = affectedFilesIndex;
-            addToAffectedFilesPendingEmit(state, affectedFile.resolvedPath, getBuilderFileEmit(state.compilerOptions));
-            handleDtsMayChangeOfAffectedFile(
-              state,
-              affectedFile,
-              cancellationToken,
-              host
-            );
-            return affectedFile;
-          }
-          affectedFilesIndex++;
-        }
-        state.changedFilesSet.delete(state.currentChangedFilePath);
-        state.currentChangedFilePath = void 0;
-        (_a = state.oldSignatures) == null ? void 0 : _a.clear();
-        (_b = state.oldExportedModulesMap) == null ? void 0 : _b.clear();
-        state.affectedFiles = void 0;
-      }
-      const nextKey = state.changedFilesSet.keys().next();
-      if (nextKey.done) {
-        return void 0;
-      }
-      const program = Debug.checkDefined(state.program);
-      const compilerOptions = program.getCompilerOptions();
-      if (outFile(compilerOptions)) {
-        Debug.assert(!state.semanticDiagnosticsPerFile);
-        return program;
-      }
-      state.affectedFiles = BuilderState.getFilesAffectedByWithOldState(
-        state,
-        program,
-        nextKey.value,
-        cancellationToken,
-        host
-      );
-      state.currentChangedFilePath = nextKey.value;
-      state.affectedFilesIndex = 0;
-      if (!state.seenAffectedFiles)
-        state.seenAffectedFiles = /* @__PURE__ */ new Set();
+  var init_builderPublic = __esm({
+    "src/compiler/builderPublic.ts"() {
+      "use strict";
+      init_ts2();
+    }
+  });
+
+  // src/compiler/resolutionCache.ts
+  function removeIgnoredPath(path) {
+    if (endsWith(path, "/node_modules/.staging")) {
+      return removeSuffix(path, "/.staging");
     }
+    return some(ignoredPaths, (searchPath) => path.includes(searchPath)) ? void 0 : path;
   }
-  function clearAffectedFilesPendingEmit(state, emitOnlyDtsFiles) {
-    var _a;
-    if (!((_a = state.affectedFilesPendingEmit) == null ? void 0 : _a.size))
-      return;
-    if (!emitOnlyDtsFiles)
-      return state.affectedFilesPendingEmit = void 0;
-    state.affectedFilesPendingEmit.forEach((emitKind, path) => {
-      const pending = emitKind & 7 /* AllJs */;
-      if (!pending)
-        state.affectedFilesPendingEmit.delete(path);
-      else
-        state.affectedFilesPendingEmit.set(path, pending);
-    });
+  function perceivedOsRootLengthForWatching(pathComponents2, length2) {
+    if (length2 <= 1)
+      return 1;
+    let indexAfterOsRoot = 1;
+    let isDosStyle = pathComponents2[0].search(/[a-zA-Z]:/) === 0;
+    if (pathComponents2[0] !== directorySeparator && !isDosStyle && // Non dos style paths
+    pathComponents2[1].search(/[a-zA-Z]\$$/) === 0) {
+      if (length2 === 2)
+        return 2;
+      indexAfterOsRoot = 2;
+      isDosStyle = true;
+    }
+    if (isDosStyle && !pathComponents2[indexAfterOsRoot].match(/^users$/i)) {
+      return indexAfterOsRoot;
+    }
+    if (pathComponents2[indexAfterOsRoot].match(/^workspaces$/i)) {
+      return indexAfterOsRoot + 1;
+    }
+    return indexAfterOsRoot + 2;
   }
-  function getNextAffectedFilePendingEmit(state, emitOnlyDtsFiles) {
-    var _a;
-    if (!((_a = state.affectedFilesPendingEmit) == null ? void 0 : _a.size))
-      return void 0;
-    return forEachEntry(state.affectedFilesPendingEmit, (emitKind, path) => {
-      var _a2;
-      const affectedFile = state.program.getSourceFileByPath(path);
-      if (!affectedFile || !sourceFileMayBeEmitted(affectedFile, state.program)) {
-        state.affectedFilesPendingEmit.delete(path);
-        return void 0;
-      }
-      const seenKind = (_a2 = state.seenEmittedFiles) == null ? void 0 : _a2.get(affectedFile.resolvedPath);
-      let pendingKind = getPendingEmitKind(emitKind, seenKind);
-      if (emitOnlyDtsFiles)
-        pendingKind = pendingKind & 24 /* AllDts */;
-      if (pendingKind)
-        return { affectedFile, emitKind: pendingKind };
-    });
+  function canWatchDirectoryOrFile(pathComponents2, length2) {
+    if (length2 === void 0)
+      length2 = pathComponents2.length;
+    if (length2 <= 2)
+      return false;
+    const perceivedOsRootLength = perceivedOsRootLengthForWatching(pathComponents2, length2);
+    return length2 > perceivedOsRootLength + 1;
   }
-  function removeDiagnosticsOfLibraryFiles(state) {
-    if (!state.cleanedDiagnosticsOfLibFiles) {
-      state.cleanedDiagnosticsOfLibFiles = true;
-      const program = Debug.checkDefined(state.program);
-      const options = program.getCompilerOptions();
-      forEach(
-        program.getSourceFiles(),
-        (f) => program.isSourceFileDefaultLibrary(f) && !skipTypeChecking(f, options, program) && removeSemanticDiagnosticsOf(state, f.resolvedPath)
-      );
+  function canWatchAtTypes(atTypes) {
+    return canWatchAffectedPackageJsonOrNodeModulesOfAtTypes(getDirectoryPath(atTypes));
+  }
+  function isInDirectoryPath(dirComponents, fileOrDirComponents) {
+    if (fileOrDirComponents.length < fileOrDirComponents.length)
+      return false;
+    for (let i = 0; i < dirComponents.length; i++) {
+      if (fileOrDirComponents[i] !== dirComponents[i])
+        return false;
     }
+    return true;
   }
-  function handleDtsMayChangeOfAffectedFile(state, affectedFile, cancellationToken, host) {
-    removeSemanticDiagnosticsOf(state, affectedFile.resolvedPath);
-    if (state.allFilesExcludingDefaultLibraryFile === state.affectedFiles) {
-      removeDiagnosticsOfLibraryFiles(state);
-      BuilderState.updateShapeSignature(
-        state,
-        Debug.checkDefined(state.program),
-        affectedFile,
-        cancellationToken,
-        host
-      );
-      return;
+  function canWatchAffectedPackageJsonOrNodeModulesOfAtTypes(fileOrDirPath) {
+    return canWatchDirectoryOrFile(getPathComponents(fileOrDirPath));
+  }
+  function canWatchAffectingLocation(filePath) {
+    return canWatchAffectedPackageJsonOrNodeModulesOfAtTypes(filePath);
+  }
+  function getDirectoryToWatchFailedLookupLocation(failedLookupLocation, failedLookupLocationPath, rootDir, rootPath, rootPathComponents, getCurrentDirectory) {
+    const failedLookupPathComponents = getPathComponents(failedLookupLocationPath);
+    failedLookupLocation = isRootedDiskPath(failedLookupLocation) ? normalizePath(failedLookupLocation) : getNormalizedAbsolutePath(failedLookupLocation, getCurrentDirectory());
+    const failedLookupComponents = getPathComponents(failedLookupLocation);
+    const perceivedOsRootLength = perceivedOsRootLengthForWatching(failedLookupPathComponents, failedLookupPathComponents.length);
+    if (failedLookupPathComponents.length <= perceivedOsRootLength + 1)
+      return void 0;
+    const nodeModulesIndex = failedLookupPathComponents.indexOf("node_modules");
+    if (nodeModulesIndex !== -1 && nodeModulesIndex + 1 <= perceivedOsRootLength + 1)
+      return void 0;
+    if (isInDirectoryPath(rootPathComponents, failedLookupPathComponents)) {
+      if (failedLookupPathComponents.length > rootPathComponents.length + 1) {
+        return getDirectoryOfFailedLookupWatch(failedLookupComponents, failedLookupPathComponents, Math.max(rootPathComponents.length + 1, perceivedOsRootLength + 1));
+      } else {
+        return {
+          dir: rootDir,
+          dirPath: rootPath,
+          nonRecursive: true
+        };
+      }
     }
-    if (state.compilerOptions.assumeChangesOnlyAffectDirectDependencies)
-      return;
-    handleDtsMayChangeOfReferencingExportOfAffectedFile(
-      state,
-      affectedFile,
-      cancellationToken,
-      host
+    return getDirectoryToWatchFromFailedLookupLocationDirectory(
+      failedLookupComponents,
+      failedLookupPathComponents,
+      failedLookupPathComponents.length - 1,
+      perceivedOsRootLength,
+      nodeModulesIndex,
+      rootPathComponents
     );
   }
-  function handleDtsMayChangeOf(state, path, cancellationToken, host) {
-    removeSemanticDiagnosticsOf(state, path);
-    if (!state.changedFilesSet.has(path)) {
-      const program = Debug.checkDefined(state.program);
-      const sourceFile = program.getSourceFileByPath(path);
-      if (sourceFile) {
-        BuilderState.updateShapeSignature(
-          state,
-          program,
-          sourceFile,
-          cancellationToken,
-          host,
-          /*useFileVersionAsSignature*/
-          true
-        );
-        if (getEmitDeclarations(state.compilerOptions)) {
-          addToAffectedFilesPendingEmit(state, path, state.compilerOptions.declarationMap ? 24 /* AllDts */ : 8 /* Dts */);
-        }
+  function getDirectoryToWatchFromFailedLookupLocationDirectory(dirComponents, dirPathComponents, dirPathComponentsLength, perceivedOsRootLength, nodeModulesIndex, rootPathComponents) {
+    if (nodeModulesIndex !== -1) {
+      return getDirectoryOfFailedLookupWatch(dirComponents, dirPathComponents, nodeModulesIndex + 1);
+    }
+    let nonRecursive = true;
+    let length2 = dirPathComponentsLength;
+    for (let i = 0; i < dirPathComponentsLength; i++) {
+      if (dirPathComponents[i] !== rootPathComponents[i]) {
+        nonRecursive = false;
+        length2 = Math.max(i + 1, perceivedOsRootLength + 1);
+        break;
       }
     }
+    return getDirectoryOfFailedLookupWatch(dirComponents, dirPathComponents, length2, nonRecursive);
   }
-  function removeSemanticDiagnosticsOf(state, path) {
-    if (!state.semanticDiagnosticsFromOldState) {
-      return true;
+  function getDirectoryOfFailedLookupWatch(dirComponents, dirPathComponents, length2, nonRecursive) {
+    return {
+      dir: getPathFromPathComponents(dirComponents, length2),
+      dirPath: getPathFromPathComponents(dirPathComponents, length2),
+      nonRecursive
+    };
+  }
+  function getDirectoryToWatchFailedLookupLocationFromTypeRoot(typeRoot, typeRootPath, rootPath, rootPathComponents, getCurrentDirectory, filterCustomPath) {
+    const typeRootPathComponents = getPathComponents(typeRootPath);
+    if (isInDirectoryPath(rootPathComponents, typeRootPathComponents)) {
+      return rootPath;
     }
-    state.semanticDiagnosticsFromOldState.delete(path);
-    state.semanticDiagnosticsPerFile.delete(path);
-    return !state.semanticDiagnosticsFromOldState.size;
+    typeRoot = isRootedDiskPath(typeRoot) ? normalizePath(typeRoot) : getNormalizedAbsolutePath(typeRoot, getCurrentDirectory());
+    const toWatch = getDirectoryToWatchFromFailedLookupLocationDirectory(
+      getPathComponents(typeRoot),
+      typeRootPathComponents,
+      typeRootPathComponents.length,
+      perceivedOsRootLengthForWatching(typeRootPathComponents, typeRootPathComponents.length),
+      typeRootPathComponents.indexOf("node_modules"),
+      rootPathComponents
+    );
+    return toWatch && filterCustomPath(toWatch.dirPath) ? toWatch.dirPath : void 0;
   }
-  function isChangedSignature(state, path) {
-    const oldSignature = Debug.checkDefined(state.oldSignatures).get(path) || void 0;
-    const newSignature = Debug.checkDefined(state.fileInfos.get(path)).signature;
-    return newSignature !== oldSignature;
+  function getRootDirectoryOfResolutionCache(rootDirForResolution, getCurrentDirectory) {
+    const normalized = getNormalizedAbsolutePath(rootDirForResolution, getCurrentDirectory());
+    return !isDiskPathRoot(normalized) ? removeTrailingDirectorySeparator(normalized) : normalized;
   }
-  function handleDtsMayChangeOfGlobalScope(state, filePath, cancellationToken, host) {
-    var _a;
-    if (!((_a = state.fileInfos.get(filePath)) == null ? void 0 : _a.affectsGlobalScope))
-      return false;
-    BuilderState.getAllFilesExcludingDefaultLibraryFile(
-      state,
-      state.program,
-      /*firstSourceFile*/
-      void 0
-    ).forEach((file) => handleDtsMayChangeOf(
-      state,
-      file.resolvedPath,
-      cancellationToken,
-      host
-    ));
-    removeDiagnosticsOfLibraryFiles(state);
-    return true;
+  function getRootPathSplitLength(rootPath) {
+    return rootPath.split(directorySeparator).length - (hasTrailingDirectorySeparator(rootPath) ? 1 : 0);
   }
-  function handleDtsMayChangeOfReferencingExportOfAffectedFile(state, affectedFile, cancellationToken, host) {
+  function getModuleResolutionHost(resolutionHost) {
     var _a;
-    if (!state.exportedModulesMap || !state.changedFilesSet.has(affectedFile.resolvedPath))
-      return;
-    if (!isChangedSignature(state, affectedFile.resolvedPath))
-      return;
-    if (getIsolatedModules(state.compilerOptions)) {
-      const seenFileNamesMap = /* @__PURE__ */ new Map();
-      seenFileNamesMap.set(affectedFile.resolvedPath, true);
-      const queue = BuilderState.getReferencedByPaths(state, affectedFile.resolvedPath);
-      while (queue.length > 0) {
-        const currentPath = queue.pop();
-        if (!seenFileNamesMap.has(currentPath)) {
-          seenFileNamesMap.set(currentPath, true);
-          if (handleDtsMayChangeOfGlobalScope(state, currentPath, cancellationToken, host))
-            return;
-          handleDtsMayChangeOf(state, currentPath, cancellationToken, host);
-          if (isChangedSignature(state, currentPath)) {
-            const currentSourceFile = Debug.checkDefined(state.program).getSourceFileByPath(currentPath);
-            queue.push(...BuilderState.getReferencedByPaths(state, currentSourceFile.resolvedPath));
-          }
-        }
-      }
+    return ((_a = resolutionHost.getCompilerHost) == null ? void 0 : _a.call(resolutionHost)) || resolutionHost;
+  }
+  function createModuleResolutionLoaderUsingGlobalCache(containingFile, redirectedReference, options, resolutionHost, moduleResolutionCache) {
+    return {
+      nameAndMode: moduleResolutionNameAndModeGetter,
+      resolve: (moduleName, resoluionMode) => resolveModuleNameUsingGlobalCache(
+        resolutionHost,
+        moduleResolutionCache,
+        moduleName,
+        containingFile,
+        options,
+        redirectedReference,
+        resoluionMode
+      )
+    };
+  }
+  function resolveModuleNameUsingGlobalCache(resolutionHost, moduleResolutionCache, moduleName, containingFile, compilerOptions, redirectedReference, mode) {
+    const host = getModuleResolutionHost(resolutionHost);
+    const primaryResult = resolveModuleName(moduleName, containingFile, compilerOptions, host, moduleResolutionCache, redirectedReference, mode);
+    if (!resolutionHost.getGlobalCache) {
+      return primaryResult;
     }
-    const seenFileAndExportsOfFile = /* @__PURE__ */ new Set();
-    (_a = state.exportedModulesMap.getKeys(affectedFile.resolvedPath)) == null ? void 0 : _a.forEach((exportedFromPath) => {
-      if (handleDtsMayChangeOfGlobalScope(state, exportedFromPath, cancellationToken, host))
-        return true;
-      const references = state.referencedMap.getKeys(exportedFromPath);
-      return references && forEachKey(
-        references,
-        (filePath) => handleDtsMayChangeOfFileAndExportsOfFile(
-          state,
-          filePath,
-          seenFileAndExportsOfFile,
-          cancellationToken,
-          host
-        )
+    const globalCache = resolutionHost.getGlobalCache();
+    if (globalCache !== void 0 && !isExternalModuleNameRelative(moduleName) && !(primaryResult.resolvedModule && extensionIsTS(primaryResult.resolvedModule.extension))) {
+      const { resolvedModule, failedLookupLocations, affectingLocations, resolutionDiagnostics } = loadModuleFromGlobalCache(
+        Debug.checkDefined(resolutionHost.globalCacheResolutionModuleName)(moduleName),
+        resolutionHost.projectName,
+        compilerOptions,
+        host,
+        globalCache,
+        moduleResolutionCache
       );
-    });
+      if (resolvedModule) {
+        primaryResult.resolvedModule = resolvedModule;
+        primaryResult.failedLookupLocations = updateResolutionField(primaryResult.failedLookupLocations, failedLookupLocations);
+        primaryResult.affectingLocations = updateResolutionField(primaryResult.affectingLocations, affectingLocations);
+        primaryResult.resolutionDiagnostics = updateResolutionField(primaryResult.resolutionDiagnostics, resolutionDiagnostics);
+        return primaryResult;
+      }
+    }
+    return primaryResult;
   }
-  function handleDtsMayChangeOfFileAndExportsOfFile(state, filePath, seenFileAndExportsOfFile, cancellationToken, host) {
-    var _a, _b;
-    if (!tryAddToSet(seenFileAndExportsOfFile, filePath))
-      return void 0;
-    if (handleDtsMayChangeOfGlobalScope(state, filePath, cancellationToken, host))
-      return true;
-    handleDtsMayChangeOf(state, filePath, cancellationToken, host);
-    (_a = state.exportedModulesMap.getKeys(filePath)) == null ? void 0 : _a.forEach(
-      (exportedFromPath) => handleDtsMayChangeOfFileAndExportsOfFile(
-        state,
-        exportedFromPath,
-        seenFileAndExportsOfFile,
-        cancellationToken,
-        host
-      )
+  function createResolutionCache(resolutionHost, rootDirForResolution, logChangesWhenResolvingModule) {
+    let filesWithChangedSetOfUnresolvedImports;
+    let filesWithInvalidatedResolutions;
+    let filesWithInvalidatedNonRelativeUnresolvedImports;
+    const nonRelativeExternalModuleResolutions = createMultiMap();
+    const resolutionsWithFailedLookups = /* @__PURE__ */ new Set();
+    const resolutionsWithOnlyAffectingLocations = /* @__PURE__ */ new Set();
+    const resolvedFileToResolution = /* @__PURE__ */ new Map();
+    const impliedFormatPackageJsons = /* @__PURE__ */ new Map();
+    let hasChangedAutomaticTypeDirectiveNames = false;
+    let affectingPathChecksForFile;
+    let affectingPathChecks;
+    let failedLookupChecks;
+    let startsWithPathChecks;
+    let isInDirectoryChecks;
+    let allModuleAndTypeResolutionsAreInvalidated = false;
+    const getCurrentDirectory = memoize(() => resolutionHost.getCurrentDirectory());
+    const cachedDirectoryStructureHost = resolutionHost.getCachedDirectoryStructureHost();
+    const resolvedModuleNames = /* @__PURE__ */ new Map();
+    const moduleResolutionCache = createModuleResolutionCache(
+      getCurrentDirectory(),
+      resolutionHost.getCanonicalFileName,
+      resolutionHost.getCompilationSettings()
     );
-    (_b = state.referencedMap.getKeys(filePath)) == null ? void 0 : _b.forEach(
-      (referencingFilePath) => !seenFileAndExportsOfFile.has(referencingFilePath) && // Not already removed diagnostic file
-      handleDtsMayChangeOf(
-        // Dont add to seen since this is not yet done with the export removal
-        state,
-        referencingFilePath,
-        cancellationToken,
-        host
-      )
+    const resolvedTypeReferenceDirectives = /* @__PURE__ */ new Map();
+    const typeReferenceDirectiveResolutionCache = createTypeReferenceDirectiveResolutionCache(
+      getCurrentDirectory(),
+      resolutionHost.getCanonicalFileName,
+      resolutionHost.getCompilationSettings(),
+      moduleResolutionCache.getPackageJsonInfoCache(),
+      moduleResolutionCache.optionsToRedirectsKey
     );
-    return void 0;
-  }
-  function getSemanticDiagnosticsOfFile(state, sourceFile, cancellationToken) {
-    return concatenate(
-      getBinderAndCheckerDiagnosticsOfFile(state, sourceFile, cancellationToken),
-      Debug.checkDefined(state.program).getProgramDiagnostics(sourceFile)
+    const resolvedLibraries = /* @__PURE__ */ new Map();
+    const libraryResolutionCache = createModuleResolutionCache(
+      getCurrentDirectory(),
+      resolutionHost.getCanonicalFileName,
+      getOptionsForLibraryResolution(resolutionHost.getCompilationSettings()),
+      moduleResolutionCache.getPackageJsonInfoCache()
     );
-  }
-  function getBinderAndCheckerDiagnosticsOfFile(state, sourceFile, cancellationToken) {
-    const path = sourceFile.resolvedPath;
-    if (state.semanticDiagnosticsPerFile) {
-      const cachedDiagnostics = state.semanticDiagnosticsPerFile.get(path);
-      if (cachedDiagnostics) {
-        return filterSemanticDiagnostics(cachedDiagnostics, state.compilerOptions);
+    const directoryWatchesOfFailedLookups = /* @__PURE__ */ new Map();
+    const fileWatchesOfAffectingLocations = /* @__PURE__ */ new Map();
+    const rootDir = getRootDirectoryOfResolutionCache(rootDirForResolution, getCurrentDirectory);
+    const rootPath = resolutionHost.toPath(rootDir);
+    const rootPathComponents = getPathComponents(rootPath);
+    const typeRootsWatches = /* @__PURE__ */ new Map();
+    return {
+      rootDirForResolution,
+      resolvedModuleNames,
+      resolvedTypeReferenceDirectives,
+      resolvedLibraries,
+      resolvedFileToResolution,
+      resolutionsWithFailedLookups,
+      resolutionsWithOnlyAffectingLocations,
+      directoryWatchesOfFailedLookups,
+      fileWatchesOfAffectingLocations,
+      watchFailedLookupLocationsOfExternalModuleResolutions,
+      getModuleResolutionCache: () => moduleResolutionCache,
+      startRecordingFilesWithChangedResolutions,
+      finishRecordingFilesWithChangedResolutions,
+      // perDirectoryResolvedModuleNames and perDirectoryResolvedTypeReferenceDirectives could be non empty if there was exception during program update
+      // (between startCachingPerDirectoryResolution and finishCachingPerDirectoryResolution)
+      startCachingPerDirectoryResolution,
+      finishCachingPerDirectoryResolution,
+      resolveModuleNameLiterals,
+      resolveTypeReferenceDirectiveReferences,
+      resolveLibrary: resolveLibrary2,
+      resolveSingleModuleNameWithoutWatching,
+      removeResolutionsFromProjectReferenceRedirects,
+      removeResolutionsOfFile,
+      hasChangedAutomaticTypeDirectiveNames: () => hasChangedAutomaticTypeDirectiveNames,
+      invalidateResolutionOfFile,
+      invalidateResolutionsOfFailedLookupLocations,
+      setFilesWithInvalidatedNonRelativeUnresolvedImports,
+      createHasInvalidatedResolutions,
+      isFileWithInvalidatedNonRelativeUnresolvedImports,
+      updateTypeRootsWatch,
+      closeTypeRootsWatch,
+      clear: clear2,
+      onChangesAffectModuleResolution
+    };
+    function getResolvedModule(resolution) {
+      return resolution.resolvedModule;
+    }
+    function getResolvedTypeReferenceDirective(resolution) {
+      return resolution.resolvedTypeReferenceDirective;
+    }
+    function clear2() {
+      clearMap(directoryWatchesOfFailedLookups, closeFileWatcherOf);
+      clearMap(fileWatchesOfAffectingLocations, closeFileWatcherOf);
+      nonRelativeExternalModuleResolutions.clear();
+      closeTypeRootsWatch();
+      resolvedModuleNames.clear();
+      resolvedTypeReferenceDirectives.clear();
+      resolvedFileToResolution.clear();
+      resolutionsWithFailedLookups.clear();
+      resolutionsWithOnlyAffectingLocations.clear();
+      failedLookupChecks = void 0;
+      startsWithPathChecks = void 0;
+      isInDirectoryChecks = void 0;
+      affectingPathChecks = void 0;
+      affectingPathChecksForFile = void 0;
+      allModuleAndTypeResolutionsAreInvalidated = false;
+      moduleResolutionCache.clear();
+      typeReferenceDirectiveResolutionCache.clear();
+      moduleResolutionCache.update(resolutionHost.getCompilationSettings());
+      typeReferenceDirectiveResolutionCache.update(resolutionHost.getCompilationSettings());
+      libraryResolutionCache.clear();
+      impliedFormatPackageJsons.clear();
+      resolvedLibraries.clear();
+      hasChangedAutomaticTypeDirectiveNames = false;
+    }
+    function onChangesAffectModuleResolution() {
+      allModuleAndTypeResolutionsAreInvalidated = true;
+      moduleResolutionCache.clearAllExceptPackageJsonInfoCache();
+      typeReferenceDirectiveResolutionCache.clearAllExceptPackageJsonInfoCache();
+      moduleResolutionCache.update(resolutionHost.getCompilationSettings());
+      typeReferenceDirectiveResolutionCache.update(resolutionHost.getCompilationSettings());
+    }
+    function startRecordingFilesWithChangedResolutions() {
+      filesWithChangedSetOfUnresolvedImports = [];
+    }
+    function finishRecordingFilesWithChangedResolutions() {
+      const collected = filesWithChangedSetOfUnresolvedImports;
+      filesWithChangedSetOfUnresolvedImports = void 0;
+      return collected;
+    }
+    function isFileWithInvalidatedNonRelativeUnresolvedImports(path) {
+      if (!filesWithInvalidatedNonRelativeUnresolvedImports) {
+        return false;
       }
+      const value = filesWithInvalidatedNonRelativeUnresolvedImports.get(path);
+      return !!value && !!value.length;
     }
-    const diagnostics = Debug.checkDefined(state.program).getBindAndCheckDiagnostics(sourceFile, cancellationToken);
-    if (state.semanticDiagnosticsPerFile) {
-      state.semanticDiagnosticsPerFile.set(path, diagnostics);
+    function createHasInvalidatedResolutions(customHasInvalidatedResolutions, customHasInvalidatedLibResolutions) {
+      invalidateResolutionsOfFailedLookupLocations();
+      const collected = filesWithInvalidatedResolutions;
+      filesWithInvalidatedResolutions = void 0;
+      return {
+        hasInvalidatedResolutions: (path) => customHasInvalidatedResolutions(path) || allModuleAndTypeResolutionsAreInvalidated || !!(collected == null ? void 0 : collected.has(path)) || isFileWithInvalidatedNonRelativeUnresolvedImports(path),
+        hasInvalidatedLibResolutions: (libFileName) => {
+          var _a;
+          return customHasInvalidatedLibResolutions(libFileName) || !!((_a = resolvedLibraries == null ? void 0 : resolvedLibraries.get(libFileName)) == null ? void 0 : _a.isInvalidated);
+        }
+      };
     }
-    return filterSemanticDiagnostics(diagnostics, state.compilerOptions);
-  }
-  function isProgramBundleEmitBuildInfo(info) {
-    return !!outFile(info.options || {});
-  }
-  function getBuildInfo2(state, bundle) {
-    var _a, _b, _c;
-    const currentDirectory = Debug.checkDefined(state.program).getCurrentDirectory();
-    const buildInfoDirectory = getDirectoryPath(getNormalizedAbsolutePath(getTsBuildInfoEmitOutputFilePath(state.compilerOptions), currentDirectory));
-    const latestChangedDtsFile = state.latestChangedDtsFile ? relativeToBuildInfoEnsuringAbsolutePath(state.latestChangedDtsFile) : void 0;
-    const fileNames = [];
-    const fileNameToFileId = /* @__PURE__ */ new Map();
-    const root = [];
-    if (outFile(state.compilerOptions)) {
-      const fileInfos2 = arrayFrom(state.fileInfos.entries(), ([key, value]) => {
-        const fileId = toFileId(key);
-        tryAddRoot(key, fileId);
-        return value.impliedFormat ? { version: value.version, impliedFormat: value.impliedFormat, signature: void 0, affectsGlobalScope: void 0 } : value.version;
+    function startCachingPerDirectoryResolution() {
+      moduleResolutionCache.isReadonly = void 0;
+      typeReferenceDirectiveResolutionCache.isReadonly = void 0;
+      libraryResolutionCache.isReadonly = void 0;
+      moduleResolutionCache.getPackageJsonInfoCache().isReadonly = void 0;
+      moduleResolutionCache.clearAllExceptPackageJsonInfoCache();
+      typeReferenceDirectiveResolutionCache.clearAllExceptPackageJsonInfoCache();
+      libraryResolutionCache.clearAllExceptPackageJsonInfoCache();
+      nonRelativeExternalModuleResolutions.forEach(watchFailedLookupLocationOfNonRelativeModuleResolutions);
+      nonRelativeExternalModuleResolutions.clear();
+    }
+    function cleanupLibResolutionWatching(newProgram) {
+      resolvedLibraries.forEach((resolution, libFileName) => {
+        var _a;
+        if (!((_a = newProgram == null ? void 0 : newProgram.resolvedLibReferences) == null ? void 0 : _a.has(libFileName))) {
+          stopWatchFailedLookupLocationOfResolution(
+            resolution,
+            resolutionHost.toPath(getInferredLibraryNameResolveFrom(resolutionHost.getCompilationSettings(), getCurrentDirectory(), libFileName)),
+            getResolvedModule
+          );
+          resolvedLibraries.delete(libFileName);
+        }
       });
-      const program2 = {
-        fileNames,
-        fileInfos: fileInfos2,
-        root,
-        options: convertToProgramBuildInfoCompilerOptions(state.compilerOptions),
-        outSignature: state.outSignature,
-        latestChangedDtsFile,
-        pendingEmit: !state.programEmitPending ? void 0 : (
-          // Pending is undefined or None is encoded as undefined
-          state.programEmitPending === getBuilderFileEmit(state.compilerOptions) ? false : (
-            // Pending emit is same as deteremined by compilerOptions
-            state.programEmitPending
-          )
-        )
-        // Actual value
-      };
-      const { js, dts, commonSourceDirectory, sourceFiles } = bundle;
-      state.bundle = bundle = {
-        commonSourceDirectory,
-        sourceFiles,
-        js: js || (!state.compilerOptions.emitDeclarationOnly ? (_a = state.bundle) == null ? void 0 : _a.js : void 0),
-        dts: dts || (getEmitDeclarations(state.compilerOptions) ? (_b = state.bundle) == null ? void 0 : _b.dts : void 0)
-      };
-      return createBuildInfo(program2, bundle);
     }
-    let fileIdsList;
-    let fileNamesToFileIdListId;
-    let emitSignatures;
-    const fileInfos = arrayFrom(state.fileInfos.entries(), ([key, value]) => {
-      var _a2, _b2;
-      const fileId = toFileId(key);
-      tryAddRoot(key, fileId);
-      Debug.assert(fileNames[fileId - 1] === relativeToBuildInfo(key));
-      const oldSignature = (_a2 = state.oldSignatures) == null ? void 0 : _a2.get(key);
-      const actualSignature = oldSignature !== void 0 ? oldSignature || void 0 : value.signature;
-      if (state.compilerOptions.composite) {
-        const file = state.program.getSourceFileByPath(key);
-        if (!isJsonSourceFile(file) && sourceFileMayBeEmitted(file, state.program)) {
-          const emitSignature = (_b2 = state.emitSignatures) == null ? void 0 : _b2.get(key);
-          if (emitSignature !== actualSignature) {
-            (emitSignatures || (emitSignatures = [])).push(emitSignature === void 0 ? fileId : (
-              // There is no emit, encode as false
-              // fileId, signature: emptyArray if signature only differs in dtsMap option than our own compilerOptions otherwise EmitSignature
-              [fileId, !isString(emitSignature) && emitSignature[0] === actualSignature ? emptyArray : emitSignature]
-            ));
+    function finishCachingPerDirectoryResolution(newProgram, oldProgram) {
+      filesWithInvalidatedNonRelativeUnresolvedImports = void 0;
+      allModuleAndTypeResolutionsAreInvalidated = false;
+      nonRelativeExternalModuleResolutions.forEach(watchFailedLookupLocationOfNonRelativeModuleResolutions);
+      nonRelativeExternalModuleResolutions.clear();
+      if (newProgram !== oldProgram) {
+        cleanupLibResolutionWatching(newProgram);
+        newProgram == null ? void 0 : newProgram.getSourceFiles().forEach((newFile) => {
+          var _a;
+          const expected = isExternalOrCommonJsModule(newFile) ? ((_a = newFile.packageJsonLocations) == null ? void 0 : _a.length) ?? 0 : 0;
+          const existing = impliedFormatPackageJsons.get(newFile.path) ?? emptyArray;
+          for (let i = existing.length; i < expected; i++) {
+            createFileWatcherOfAffectingLocation(
+              newFile.packageJsonLocations[i],
+              /*forResolution*/
+              false
+            );
+          }
+          if (existing.length > expected) {
+            for (let i = expected; i < existing.length; i++) {
+              fileWatchesOfAffectingLocations.get(existing[i]).files--;
+            }
+          }
+          if (expected)
+            impliedFormatPackageJsons.set(newFile.path, newFile.packageJsonLocations);
+          else
+            impliedFormatPackageJsons.delete(newFile.path);
+        });
+        impliedFormatPackageJsons.forEach((existing, path) => {
+          if (!(newProgram == null ? void 0 : newProgram.getSourceFileByPath(path))) {
+            existing.forEach((location) => fileWatchesOfAffectingLocations.get(location).files--);
+            impliedFormatPackageJsons.delete(path);
+          }
+        });
+      }
+      directoryWatchesOfFailedLookups.forEach(closeDirectoryWatchesOfFailedLookup);
+      fileWatchesOfAffectingLocations.forEach(closeFileWatcherOfAffectingLocation);
+      hasChangedAutomaticTypeDirectiveNames = false;
+      moduleResolutionCache.isReadonly = true;
+      typeReferenceDirectiveResolutionCache.isReadonly = true;
+      libraryResolutionCache.isReadonly = true;
+      moduleResolutionCache.getPackageJsonInfoCache().isReadonly = true;
+    }
+    function closeDirectoryWatchesOfFailedLookup(watcher, path) {
+      if (watcher.refCount === 0) {
+        directoryWatchesOfFailedLookups.delete(path);
+        watcher.watcher.close();
+      }
+    }
+    function closeFileWatcherOfAffectingLocation(watcher, path) {
+      var _a;
+      if (watcher.files === 0 && watcher.resolutions === 0 && !((_a = watcher.symlinks) == null ? void 0 : _a.size)) {
+        fileWatchesOfAffectingLocations.delete(path);
+        watcher.watcher.close();
+      }
+    }
+    function resolveNamesWithLocalCache({
+      entries,
+      containingFile,
+      containingSourceFile,
+      redirectedReference,
+      options,
+      perFileCache,
+      reusedNames,
+      loader,
+      getResolutionWithResolvedFileName,
+      deferWatchingNonRelativeResolution,
+      shouldRetryResolution,
+      logChanges
+    }) {
+      const path = resolutionHost.toPath(containingFile);
+      const resolutionsInFile = perFileCache.get(path) || perFileCache.set(path, createModeAwareCache()).get(path);
+      const resolvedModules = [];
+      const hasInvalidatedNonRelativeUnresolvedImport = logChanges && isFileWithInvalidatedNonRelativeUnresolvedImports(path);
+      const program = resolutionHost.getCurrentProgram();
+      const oldRedirect = program && program.getResolvedProjectReferenceToRedirect(containingFile);
+      const unmatchedRedirects = oldRedirect ? !redirectedReference || redirectedReference.sourceFile.path !== oldRedirect.sourceFile.path : !!redirectedReference;
+      const seenNamesInFile = createModeAwareCache();
+      for (const entry of entries) {
+        const name = loader.nameAndMode.getName(entry);
+        const mode = loader.nameAndMode.getMode(entry, containingSourceFile);
+        let resolution = resolutionsInFile.get(name, mode);
+        if (!seenNamesInFile.has(name, mode) && (allModuleAndTypeResolutionsAreInvalidated || unmatchedRedirects || !resolution || resolution.isInvalidated || // If the name is unresolved import that was invalidated, recalculate
+        hasInvalidatedNonRelativeUnresolvedImport && !isExternalModuleNameRelative(name) && shouldRetryResolution(resolution))) {
+          const existingResolution = resolution;
+          resolution = loader.resolve(name, mode);
+          if (resolutionHost.onDiscoveredSymlink && resolutionIsSymlink(resolution)) {
+            resolutionHost.onDiscoveredSymlink();
+          }
+          resolutionsInFile.set(name, mode, resolution);
+          if (resolution !== existingResolution) {
+            watchFailedLookupLocationsOfExternalModuleResolutions(name, resolution, path, getResolutionWithResolvedFileName, deferWatchingNonRelativeResolution);
+            if (existingResolution) {
+              stopWatchFailedLookupLocationOfResolution(existingResolution, path, getResolutionWithResolvedFileName);
+            }
+          }
+          if (logChanges && filesWithChangedSetOfUnresolvedImports && !resolutionIsEqualTo(existingResolution, resolution)) {
+            filesWithChangedSetOfUnresolvedImports.push(path);
+            logChanges = false;
+          }
+        } else {
+          const host = getModuleResolutionHost(resolutionHost);
+          if (isTraceEnabled(options, host) && !seenNamesInFile.has(name, mode)) {
+            const resolved = getResolutionWithResolvedFileName(resolution);
+            trace(
+              host,
+              perFileCache === resolvedModuleNames ? (resolved == null ? void 0 : resolved.resolvedFileName) ? resolved.packageId ? Diagnostics.Reusing_resolution_of_module_0_from_1_of_old_program_it_was_successfully_resolved_to_2_with_Package_ID_3 : Diagnostics.Reusing_resolution_of_module_0_from_1_of_old_program_it_was_successfully_resolved_to_2 : Diagnostics.Reusing_resolution_of_module_0_from_1_of_old_program_it_was_not_resolved : (resolved == null ? void 0 : resolved.resolvedFileName) ? resolved.packageId ? Diagnostics.Reusing_resolution_of_type_reference_directive_0_from_1_of_old_program_it_was_successfully_resolved_to_2_with_Package_ID_3 : Diagnostics.Reusing_resolution_of_type_reference_directive_0_from_1_of_old_program_it_was_successfully_resolved_to_2 : Diagnostics.Reusing_resolution_of_type_reference_directive_0_from_1_of_old_program_it_was_not_resolved,
+              name,
+              containingFile,
+              resolved == null ? void 0 : resolved.resolvedFileName,
+              (resolved == null ? void 0 : resolved.packageId) && packageIdToString(resolved.packageId)
+            );
           }
         }
+        Debug.assert(resolution !== void 0 && !resolution.isInvalidated);
+        seenNamesInFile.set(name, mode, true);
+        resolvedModules.push(resolution);
       }
-      return value.version === actualSignature ? value.affectsGlobalScope || value.impliedFormat ? (
-        // If file version is same as signature, dont serialize signature
-        { version: value.version, signature: void 0, affectsGlobalScope: value.affectsGlobalScope, impliedFormat: value.impliedFormat }
-      ) : (
-        // If file info only contains version and signature and both are same we can just write string
-        value.version
-      ) : actualSignature !== void 0 ? (
-        // If signature is not same as version, encode signature in the fileInfo
-        oldSignature === void 0 ? (
-          // If we havent computed signature, use fileInfo as is
-          value
-        ) : (
-          // Serialize fileInfo with new updated signature
-          { version: value.version, signature: actualSignature, affectsGlobalScope: value.affectsGlobalScope, impliedFormat: value.impliedFormat }
+      reusedNames == null ? void 0 : reusedNames.forEach(
+        (entry) => seenNamesInFile.set(
+          loader.nameAndMode.getName(entry),
+          loader.nameAndMode.getMode(entry, containingSourceFile),
+          true
         )
-      ) : (
-        // Signature of the FileInfo is undefined, serialize it as false
-        { version: value.version, signature: false, affectsGlobalScope: value.affectsGlobalScope, impliedFormat: value.impliedFormat }
       );
-    });
-    let referencedMap;
-    if (state.referencedMap) {
-      referencedMap = arrayFrom(state.referencedMap.keys()).sort(compareStringsCaseSensitive).map((key) => [
-        toFileId(key),
-        toFileIdListId(state.referencedMap.getValues(key))
-      ]);
+      if (resolutionsInFile.size() !== seenNamesInFile.size()) {
+        resolutionsInFile.forEach((resolution, name, mode) => {
+          if (!seenNamesInFile.has(name, mode)) {
+            stopWatchFailedLookupLocationOfResolution(resolution, path, getResolutionWithResolvedFileName);
+            resolutionsInFile.delete(name, mode);
+          }
+        });
+      }
+      return resolvedModules;
+      function resolutionIsEqualTo(oldResolution, newResolution) {
+        if (oldResolution === newResolution) {
+          return true;
+        }
+        if (!oldResolution || !newResolution) {
+          return false;
+        }
+        const oldResult = getResolutionWithResolvedFileName(oldResolution);
+        const newResult = getResolutionWithResolvedFileName(newResolution);
+        if (oldResult === newResult) {
+          return true;
+        }
+        if (!oldResult || !newResult) {
+          return false;
+        }
+        return oldResult.resolvedFileName === newResult.resolvedFileName;
+      }
     }
-    let exportedModulesMap;
-    if (state.exportedModulesMap) {
-      exportedModulesMap = mapDefined(arrayFrom(state.exportedModulesMap.keys()).sort(compareStringsCaseSensitive), (key) => {
-        var _a2;
-        const oldValue = (_a2 = state.oldExportedModulesMap) == null ? void 0 : _a2.get(key);
-        if (oldValue === void 0)
-          return [toFileId(key), toFileIdListId(state.exportedModulesMap.getValues(key))];
-        if (oldValue)
-          return [toFileId(key), toFileIdListId(oldValue)];
-        return void 0;
+    function resolveTypeReferenceDirectiveReferences(typeDirectiveReferences, containingFile, redirectedReference, options, containingSourceFile, reusedNames) {
+      return resolveNamesWithLocalCache({
+        entries: typeDirectiveReferences,
+        containingFile,
+        containingSourceFile,
+        redirectedReference,
+        options,
+        reusedNames,
+        perFileCache: resolvedTypeReferenceDirectives,
+        loader: createTypeReferenceResolutionLoader(
+          containingFile,
+          redirectedReference,
+          options,
+          getModuleResolutionHost(resolutionHost),
+          typeReferenceDirectiveResolutionCache
+        ),
+        getResolutionWithResolvedFileName: getResolvedTypeReferenceDirective,
+        shouldRetryResolution: (resolution) => resolution.resolvedTypeReferenceDirective === void 0,
+        deferWatchingNonRelativeResolution: false
       });
     }
-    let semanticDiagnosticsPerFile;
-    if (state.semanticDiagnosticsPerFile) {
-      for (const key of arrayFrom(state.semanticDiagnosticsPerFile.keys()).sort(compareStringsCaseSensitive)) {
-        const value = state.semanticDiagnosticsPerFile.get(key);
-        (semanticDiagnosticsPerFile || (semanticDiagnosticsPerFile = [])).push(
-          value.length ? [
-            toFileId(key),
-            convertToReusableDiagnostics(value, relativeToBuildInfo)
-          ] : toFileId(key)
-        );
-      }
+    function resolveModuleNameLiterals(moduleLiterals, containingFile, redirectedReference, options, containingSourceFile, reusedNames) {
+      return resolveNamesWithLocalCache({
+        entries: moduleLiterals,
+        containingFile,
+        containingSourceFile,
+        redirectedReference,
+        options,
+        reusedNames,
+        perFileCache: resolvedModuleNames,
+        loader: createModuleResolutionLoaderUsingGlobalCache(
+          containingFile,
+          redirectedReference,
+          options,
+          resolutionHost,
+          moduleResolutionCache
+        ),
+        getResolutionWithResolvedFileName: getResolvedModule,
+        shouldRetryResolution: (resolution) => !resolution.resolvedModule || !resolutionExtensionIsTSOrJson(resolution.resolvedModule.extension),
+        logChanges: logChangesWhenResolvingModule,
+        deferWatchingNonRelativeResolution: true
+        // Defer non relative resolution watch because we could be using ambient modules
+      });
     }
-    let affectedFilesPendingEmit;
-    if ((_c = state.affectedFilesPendingEmit) == null ? void 0 : _c.size) {
-      const fullEmitForOptions = getBuilderFileEmit(state.compilerOptions);
-      const seenFiles = /* @__PURE__ */ new Set();
-      for (const path of arrayFrom(state.affectedFilesPendingEmit.keys()).sort(compareStringsCaseSensitive)) {
-        if (tryAddToSet(seenFiles, path)) {
-          const file = state.program.getSourceFileByPath(path);
-          if (!file || !sourceFileMayBeEmitted(file, state.program))
-            continue;
-          const fileId = toFileId(path), pendingEmit = state.affectedFilesPendingEmit.get(path);
-          (affectedFilesPendingEmit || (affectedFilesPendingEmit = [])).push(
-            pendingEmit === fullEmitForOptions ? fileId : (
-              // Pending full emit per options
-              pendingEmit === 8 /* Dts */ ? [fileId] : (
-                // Pending on Dts only
-                [fileId, pendingEmit]
-              )
-            )
-            // Anything else
+    function resolveLibrary2(libraryName, resolveFrom, options, libFileName) {
+      const host = getModuleResolutionHost(resolutionHost);
+      let resolution = resolvedLibraries == null ? void 0 : resolvedLibraries.get(libFileName);
+      if (!resolution || resolution.isInvalidated) {
+        const existingResolution = resolution;
+        resolution = resolveLibrary(libraryName, resolveFrom, options, host, libraryResolutionCache);
+        const path = resolutionHost.toPath(resolveFrom);
+        watchFailedLookupLocationsOfExternalModuleResolutions(
+          libraryName,
+          resolution,
+          path,
+          getResolvedModule,
+          /*deferWatchingNonRelativeResolution*/
+          false
+        );
+        resolvedLibraries.set(libFileName, resolution);
+        if (existingResolution) {
+          stopWatchFailedLookupLocationOfResolution(existingResolution, path, getResolvedModule);
+        }
+      } else {
+        if (isTraceEnabled(options, host)) {
+          const resolved = getResolvedModule(resolution);
+          trace(
+            host,
+            (resolved == null ? void 0 : resolved.resolvedFileName) ? resolved.packageId ? Diagnostics.Reusing_resolution_of_module_0_from_1_of_old_program_it_was_successfully_resolved_to_2_with_Package_ID_3 : Diagnostics.Reusing_resolution_of_module_0_from_1_of_old_program_it_was_successfully_resolved_to_2 : Diagnostics.Reusing_resolution_of_module_0_from_1_of_old_program_it_was_not_resolved,
+            libraryName,
+            resolveFrom,
+            resolved == null ? void 0 : resolved.resolvedFileName,
+            (resolved == null ? void 0 : resolved.packageId) && packageIdToString(resolved.packageId)
           );
         }
       }
+      return resolution;
     }
-    let changeFileSet;
-    if (state.changedFilesSet.size) {
-      for (const path of arrayFrom(state.changedFilesSet.keys()).sort(compareStringsCaseSensitive)) {
-        (changeFileSet || (changeFileSet = [])).push(toFileId(path));
-      }
+    function resolveSingleModuleNameWithoutWatching(moduleName, containingFile) {
+      var _a, _b;
+      const path = resolutionHost.toPath(containingFile);
+      const resolutionsInFile = resolvedModuleNames.get(path);
+      const resolution = resolutionsInFile == null ? void 0 : resolutionsInFile.get(
+        moduleName,
+        /*mode*/
+        void 0
+      );
+      if (resolution && !resolution.isInvalidated)
+        return resolution;
+      const data = (_a = resolutionHost.beforeResolveSingleModuleNameWithoutWatching) == null ? void 0 : _a.call(resolutionHost, moduleResolutionCache);
+      const host = getModuleResolutionHost(resolutionHost);
+      const result = resolveModuleName(
+        moduleName,
+        containingFile,
+        resolutionHost.getCompilationSettings(),
+        host,
+        moduleResolutionCache
+      );
+      (_b = resolutionHost.afterResolveSingleModuleNameWithoutWatching) == null ? void 0 : _b.call(resolutionHost, moduleResolutionCache, moduleName, containingFile, result, data);
+      return result;
     }
-    const program = {
-      fileNames,
-      fileInfos,
-      root,
-      options: convertToProgramBuildInfoCompilerOptions(state.compilerOptions),
-      fileIdsList,
-      referencedMap,
-      exportedModulesMap,
-      semanticDiagnosticsPerFile,
-      affectedFilesPendingEmit,
-      changeFileSet,
-      emitSignatures,
-      latestChangedDtsFile
-    };
-    return createBuildInfo(program, bundle);
-    function relativeToBuildInfoEnsuringAbsolutePath(path) {
-      return relativeToBuildInfo(getNormalizedAbsolutePath(path, currentDirectory));
+    function isNodeModulesAtTypesDirectory(dirPath) {
+      return endsWith(dirPath, "/node_modules/@types");
     }
-    function relativeToBuildInfo(path) {
-      return ensurePathIsNonModuleName(getRelativePathFromDirectory(buildInfoDirectory, path, state.program.getCanonicalFileName));
+    function watchFailedLookupLocationsOfExternalModuleResolutions(name, resolution, filePath, getResolutionWithResolvedFileName, deferWatchingNonRelativeResolution) {
+      var _a;
+      if (resolution.refCount) {
+        resolution.refCount++;
+        Debug.assertIsDefined(resolution.files);
+      } else {
+        resolution.refCount = 1;
+        Debug.assert(!((_a = resolution.files) == null ? void 0 : _a.size));
+        if (!deferWatchingNonRelativeResolution || isExternalModuleNameRelative(name)) {
+          watchFailedLookupLocationOfResolution(resolution);
+        } else {
+          nonRelativeExternalModuleResolutions.add(name, resolution);
+        }
+        const resolved = getResolutionWithResolvedFileName(resolution);
+        if (resolved && resolved.resolvedFileName) {
+          const key = resolutionHost.toPath(resolved.resolvedFileName);
+          let resolutions = resolvedFileToResolution.get(key);
+          if (!resolutions)
+            resolvedFileToResolution.set(key, resolutions = /* @__PURE__ */ new Set());
+          resolutions.add(resolution);
+        }
+      }
+      (resolution.files ?? (resolution.files = /* @__PURE__ */ new Set())).add(filePath);
     }
-    function toFileId(path) {
-      let fileId = fileNameToFileId.get(path);
-      if (fileId === void 0) {
-        fileNames.push(relativeToBuildInfo(path));
-        fileNameToFileId.set(path, fileId = fileNames.length);
+    function watchFailedLookupLocation(failedLookupLocation, setAtRoot) {
+      const failedLookupLocationPath = resolutionHost.toPath(failedLookupLocation);
+      const toWatch = getDirectoryToWatchFailedLookupLocation(
+        failedLookupLocation,
+        failedLookupLocationPath,
+        rootDir,
+        rootPath,
+        rootPathComponents,
+        getCurrentDirectory
+      );
+      if (toWatch) {
+        const { dir, dirPath, nonRecursive } = toWatch;
+        if (dirPath === rootPath) {
+          Debug.assert(nonRecursive);
+          setAtRoot = true;
+        } else {
+          setDirectoryWatcher(dir, dirPath, nonRecursive);
+        }
       }
-      return fileId;
+      return setAtRoot;
     }
-    function toFileIdListId(set) {
-      const fileIds = arrayFrom(set.keys(), toFileId).sort(compareValues);
-      const key = fileIds.join();
-      let fileIdListId = fileNamesToFileIdListId == null ? void 0 : fileNamesToFileIdListId.get(key);
-      if (fileIdListId === void 0) {
-        (fileIdsList || (fileIdsList = [])).push(fileIds);
-        (fileNamesToFileIdListId || (fileNamesToFileIdListId = /* @__PURE__ */ new Map())).set(key, fileIdListId = fileIdsList.length);
+    function watchFailedLookupLocationOfResolution(resolution) {
+      Debug.assert(!!resolution.refCount);
+      const { failedLookupLocations, affectingLocations, node10Result } = resolution;
+      if (!(failedLookupLocations == null ? void 0 : failedLookupLocations.length) && !(affectingLocations == null ? void 0 : affectingLocations.length) && !node10Result)
+        return;
+      if ((failedLookupLocations == null ? void 0 : failedLookupLocations.length) || node10Result)
+        resolutionsWithFailedLookups.add(resolution);
+      let setAtRoot = false;
+      if (failedLookupLocations) {
+        for (const failedLookupLocation of failedLookupLocations) {
+          setAtRoot = watchFailedLookupLocation(failedLookupLocation, setAtRoot);
+        }
       }
-      return fileIdListId;
+      if (node10Result)
+        setAtRoot = watchFailedLookupLocation(node10Result, setAtRoot);
+      if (setAtRoot) {
+        setDirectoryWatcher(
+          rootDir,
+          rootPath,
+          /*nonRecursive*/
+          true
+        );
+      }
+      watchAffectingLocationsOfResolution(resolution, !(failedLookupLocations == null ? void 0 : failedLookupLocations.length) && !node10Result);
     }
-    function tryAddRoot(path, fileId) {
-      const file = state.program.getSourceFile(path);
-      if (!state.program.getFileIncludeReasons().get(file.path).some((r) => r.kind === 0 /* RootFile */))
+    function watchAffectingLocationsOfResolution(resolution, addToResolutionsWithOnlyAffectingLocations) {
+      Debug.assert(!!resolution.refCount);
+      const { affectingLocations } = resolution;
+      if (!(affectingLocations == null ? void 0 : affectingLocations.length))
         return;
-      if (!root.length)
-        return root.push(fileId);
-      const last2 = root[root.length - 1];
-      const isLastStartEnd = isArray(last2);
-      if (isLastStartEnd && last2[1] === fileId - 1)
-        return last2[1] = fileId;
-      if (isLastStartEnd || root.length === 1 || last2 !== fileId - 1)
-        return root.push(fileId);
-      const lastButOne = root[root.length - 2];
-      if (!isNumber(lastButOne) || lastButOne !== last2 - 1)
-        return root.push(fileId);
-      root[root.length - 2] = [lastButOne, fileId];
-      return root.length = root.length - 1;
+      if (addToResolutionsWithOnlyAffectingLocations)
+        resolutionsWithOnlyAffectingLocations.add(resolution);
+      for (const affectingLocation of affectingLocations) {
+        createFileWatcherOfAffectingLocation(
+          affectingLocation,
+          /*forResolution*/
+          true
+        );
+      }
     }
-    function convertToProgramBuildInfoCompilerOptions(options) {
-      let result;
-      const { optionsNameMap } = getOptionsNameMap();
-      for (const name of getOwnKeys(options).sort(compareStringsCaseSensitive)) {
-        const optionInfo = optionsNameMap.get(name.toLowerCase());
-        if (optionInfo == null ? void 0 : optionInfo.affectsBuildInfo) {
-          (result || (result = {}))[name] = convertToReusableCompilerOptionValue(
-            optionInfo,
-            options[name],
-            relativeToBuildInfoEnsuringAbsolutePath
-          );
+    function createFileWatcherOfAffectingLocation(affectingLocation, forResolution) {
+      const fileWatcher = fileWatchesOfAffectingLocations.get(affectingLocation);
+      if (fileWatcher) {
+        if (forResolution)
+          fileWatcher.resolutions++;
+        else
+          fileWatcher.files++;
+        return;
+      }
+      let locationToWatch = affectingLocation;
+      let isSymlink = false;
+      let symlinkWatcher;
+      if (resolutionHost.realpath) {
+        locationToWatch = resolutionHost.realpath(affectingLocation);
+        if (affectingLocation !== locationToWatch) {
+          isSymlink = true;
+          symlinkWatcher = fileWatchesOfAffectingLocations.get(locationToWatch);
+        }
+      }
+      const resolutions = forResolution ? 1 : 0;
+      const files = forResolution ? 0 : 1;
+      if (!isSymlink || !symlinkWatcher) {
+        const watcher = {
+          watcher: canWatchAffectingLocation(resolutionHost.toPath(locationToWatch)) ? resolutionHost.watchAffectingFileLocation(locationToWatch, (fileName, eventKind) => {
+            cachedDirectoryStructureHost == null ? void 0 : cachedDirectoryStructureHost.addOrDeleteFile(fileName, resolutionHost.toPath(locationToWatch), eventKind);
+            invalidateAffectingFileWatcher(locationToWatch, moduleResolutionCache.getPackageJsonInfoCache().getInternalMap());
+            resolutionHost.scheduleInvalidateResolutionsOfFailedLookupLocations();
+          }) : noopFileWatcher,
+          resolutions: isSymlink ? 0 : resolutions,
+          files: isSymlink ? 0 : files,
+          symlinks: void 0
+        };
+        fileWatchesOfAffectingLocations.set(locationToWatch, watcher);
+        if (isSymlink)
+          symlinkWatcher = watcher;
+      }
+      if (isSymlink) {
+        Debug.assert(!!symlinkWatcher);
+        const watcher = {
+          watcher: {
+            close: () => {
+              var _a;
+              const symlinkWatcher2 = fileWatchesOfAffectingLocations.get(locationToWatch);
+              if (((_a = symlinkWatcher2 == null ? void 0 : symlinkWatcher2.symlinks) == null ? void 0 : _a.delete(affectingLocation)) && !symlinkWatcher2.symlinks.size && !symlinkWatcher2.resolutions && !symlinkWatcher2.files) {
+                fileWatchesOfAffectingLocations.delete(locationToWatch);
+                symlinkWatcher2.watcher.close();
+              }
+            }
+          },
+          resolutions,
+          files,
+          symlinks: void 0
+        };
+        fileWatchesOfAffectingLocations.set(affectingLocation, watcher);
+        (symlinkWatcher.symlinks ?? (symlinkWatcher.symlinks = /* @__PURE__ */ new Set())).add(affectingLocation);
+      }
+    }
+    function invalidateAffectingFileWatcher(path, packageJsonMap) {
+      var _a;
+      const watcher = fileWatchesOfAffectingLocations.get(path);
+      if (watcher == null ? void 0 : watcher.resolutions)
+        (affectingPathChecks ?? (affectingPathChecks = /* @__PURE__ */ new Set())).add(path);
+      if (watcher == null ? void 0 : watcher.files)
+        (affectingPathChecksForFile ?? (affectingPathChecksForFile = /* @__PURE__ */ new Set())).add(path);
+      (_a = watcher == null ? void 0 : watcher.symlinks) == null ? void 0 : _a.forEach((path2) => invalidateAffectingFileWatcher(path2, packageJsonMap));
+      packageJsonMap == null ? void 0 : packageJsonMap.delete(resolutionHost.toPath(path));
+    }
+    function watchFailedLookupLocationOfNonRelativeModuleResolutions(resolutions, name) {
+      const program = resolutionHost.getCurrentProgram();
+      if (!program || !program.getTypeChecker().tryFindAmbientModuleWithoutAugmentations(name)) {
+        resolutions.forEach(watchFailedLookupLocationOfResolution);
+      } else {
+        resolutions.forEach((resolution) => watchAffectingLocationsOfResolution(
+          resolution,
+          /*addToResolutionsWithOnlyAffectingLocations*/
+          true
+        ));
+      }
+    }
+    function setDirectoryWatcher(dir, dirPath, nonRecursive) {
+      const dirWatcher = directoryWatchesOfFailedLookups.get(dirPath);
+      if (dirWatcher) {
+        Debug.assert(!!nonRecursive === !!dirWatcher.nonRecursive);
+        dirWatcher.refCount++;
+      } else {
+        directoryWatchesOfFailedLookups.set(dirPath, { watcher: createDirectoryWatcher(dir, dirPath, nonRecursive), refCount: 1, nonRecursive });
+      }
+    }
+    function stopWatchFailedLookupLocation(failedLookupLocation, removeAtRoot, syncDirWatcherRemove) {
+      const failedLookupLocationPath = resolutionHost.toPath(failedLookupLocation);
+      const toWatch = getDirectoryToWatchFailedLookupLocation(
+        failedLookupLocation,
+        failedLookupLocationPath,
+        rootDir,
+        rootPath,
+        rootPathComponents,
+        getCurrentDirectory
+      );
+      if (toWatch) {
+        const { dirPath } = toWatch;
+        if (dirPath === rootPath) {
+          removeAtRoot = true;
+        } else {
+          removeDirectoryWatcher(dirPath, syncDirWatcherRemove);
         }
       }
-      return result;
+      return removeAtRoot;
     }
-  }
-  function convertToReusableCompilerOptionValue(option, value, relativeToBuildInfo) {
-    if (option) {
-      Debug.assert(option.type !== "listOrElement");
-      if (option.type === "list") {
-        const values = value;
-        if (option.element.isFilePath && values.length) {
-          return values.map(relativeToBuildInfo);
+    function stopWatchFailedLookupLocationOfResolution(resolution, filePath, getResolutionWithResolvedFileName, syncDirWatcherRemove) {
+      Debug.checkDefined(resolution.files).delete(filePath);
+      resolution.refCount--;
+      if (resolution.refCount) {
+        return;
+      }
+      const resolved = getResolutionWithResolvedFileName(resolution);
+      if (resolved && resolved.resolvedFileName) {
+        const key = resolutionHost.toPath(resolved.resolvedFileName);
+        const resolutions = resolvedFileToResolution.get(key);
+        if ((resolutions == null ? void 0 : resolutions.delete(resolution)) && !resolutions.size)
+          resolvedFileToResolution.delete(key);
+      }
+      const { failedLookupLocations, affectingLocations, node10Result } = resolution;
+      if (resolutionsWithFailedLookups.delete(resolution)) {
+        let removeAtRoot = false;
+        if (failedLookupLocations) {
+          for (const failedLookupLocation of failedLookupLocations) {
+            removeAtRoot = stopWatchFailedLookupLocation(failedLookupLocation, removeAtRoot, syncDirWatcherRemove);
+          }
+        }
+        if (node10Result)
+          removeAtRoot = stopWatchFailedLookupLocation(node10Result, removeAtRoot, syncDirWatcherRemove);
+        if (removeAtRoot)
+          removeDirectoryWatcher(rootPath, syncDirWatcherRemove);
+      } else if (affectingLocations == null ? void 0 : affectingLocations.length) {
+        resolutionsWithOnlyAffectingLocations.delete(resolution);
+      }
+      if (affectingLocations) {
+        for (const affectingLocation of affectingLocations) {
+          const watcher = fileWatchesOfAffectingLocations.get(affectingLocation);
+          watcher.resolutions--;
+          if (syncDirWatcherRemove)
+            closeFileWatcherOfAffectingLocation(watcher, affectingLocation);
         }
-      } else if (option.isFilePath) {
-        return relativeToBuildInfo(value);
       }
     }
-    return value;
-  }
-  function convertToReusableDiagnostics(diagnostics, relativeToBuildInfo) {
-    Debug.assert(!!diagnostics.length);
-    return diagnostics.map((diagnostic) => {
-      const result = convertToReusableDiagnosticRelatedInformation(diagnostic, relativeToBuildInfo);
-      result.reportsUnnecessary = diagnostic.reportsUnnecessary;
-      result.reportDeprecated = diagnostic.reportsDeprecated;
-      result.source = diagnostic.source;
-      result.skippedOn = diagnostic.skippedOn;
-      const { relatedInformation } = diagnostic;
-      result.relatedInformation = relatedInformation ? relatedInformation.length ? relatedInformation.map((r) => convertToReusableDiagnosticRelatedInformation(r, relativeToBuildInfo)) : [] : void 0;
-      return result;
-    });
-  }
-  function convertToReusableDiagnosticRelatedInformation(diagnostic, relativeToBuildInfo) {
-    const { file } = diagnostic;
-    return {
-      ...diagnostic,
-      file: file ? relativeToBuildInfo(file.resolvedPath) : void 0,
-      messageText: isString(diagnostic.messageText) ? diagnostic.messageText : convertToReusableDiagnosticMessageChain(diagnostic.messageText)
-    };
-  }
-  function convertToReusableDiagnosticMessageChain(chain) {
-    if (chain.repopulateInfo) {
-      return {
-        info: chain.repopulateInfo(),
-        next: convertToReusableDiagnosticMessageChainArray(chain.next)
-      };
+    function removeDirectoryWatcher(dirPath, syncDirWatcherRemove) {
+      const dirWatcher = directoryWatchesOfFailedLookups.get(dirPath);
+      dirWatcher.refCount--;
+      if (syncDirWatcherRemove)
+        closeDirectoryWatchesOfFailedLookup(dirWatcher, dirPath);
     }
-    const next = convertToReusableDiagnosticMessageChainArray(chain.next);
-    return next === chain.next ? chain : { ...chain, next };
-  }
-  function convertToReusableDiagnosticMessageChainArray(array) {
-    if (!array)
-      return array;
-    return forEach(array, (chain, index) => {
-      const reusable = convertToReusableDiagnosticMessageChain(chain);
-      if (chain === reusable)
-        return void 0;
-      const result = index > 0 ? array.slice(0, index - 1) : [];
-      result.push(reusable);
-      for (let i = index + 1; i < array.length; i++) {
-        result.push(convertToReusableDiagnosticMessageChain(array[i]));
+    function createDirectoryWatcher(directory, dirPath, nonRecursive) {
+      return resolutionHost.watchDirectoryOfFailedLookupLocation(directory, (fileOrDirectory) => {
+        const fileOrDirectoryPath = resolutionHost.toPath(fileOrDirectory);
+        if (cachedDirectoryStructureHost) {
+          cachedDirectoryStructureHost.addOrDeleteFileOrDirectory(fileOrDirectory, fileOrDirectoryPath);
+        }
+        scheduleInvalidateResolutionOfFailedLookupLocation(fileOrDirectoryPath, dirPath === fileOrDirectoryPath);
+      }, nonRecursive ? 0 /* None */ : 1 /* Recursive */);
+    }
+    function removeResolutionsOfFileFromCache(cache, filePath, getResolutionWithResolvedFileName, syncDirWatcherRemove) {
+      const resolutions = cache.get(filePath);
+      if (resolutions) {
+        resolutions.forEach(
+          (resolution) => stopWatchFailedLookupLocationOfResolution(
+            resolution,
+            filePath,
+            getResolutionWithResolvedFileName,
+            syncDirWatcherRemove
+          )
+        );
+        cache.delete(filePath);
       }
-      return result;
-    }) || array;
-  }
-  function getBuilderCreationParameters(newProgramOrRootNames, hostOrOptions, oldProgramOrHost, configFileParsingDiagnosticsOrOldProgram, configFileParsingDiagnostics, projectReferences) {
-    let host;
-    let newProgram;
-    let oldProgram;
-    if (newProgramOrRootNames === void 0) {
-      Debug.assert(hostOrOptions === void 0);
-      host = oldProgramOrHost;
-      oldProgram = configFileParsingDiagnosticsOrOldProgram;
-      Debug.assert(!!oldProgram);
-      newProgram = oldProgram.getProgram();
-    } else if (isArray(newProgramOrRootNames)) {
-      oldProgram = configFileParsingDiagnosticsOrOldProgram;
-      newProgram = createProgram({
-        rootNames: newProgramOrRootNames,
-        options: hostOrOptions,
-        host: oldProgramOrHost,
-        oldProgram: oldProgram && oldProgram.getProgramOrUndefined(),
-        configFileParsingDiagnostics,
-        projectReferences
-      });
-      host = oldProgramOrHost;
-    } else {
-      newProgram = newProgramOrRootNames;
-      host = hostOrOptions;
-      oldProgram = oldProgramOrHost;
-      configFileParsingDiagnostics = configFileParsingDiagnosticsOrOldProgram;
     }
-    return { host, newProgram, oldProgram, configFileParsingDiagnostics: configFileParsingDiagnostics || emptyArray };
-  }
-  function getTextHandlingSourceMapForSignature(text, data) {
-    return (data == null ? void 0 : data.sourceMapUrlPos) !== void 0 ? text.substring(0, data.sourceMapUrlPos) : text;
-  }
-  function computeSignatureWithDiagnostics(program, sourceFile, text, host, data) {
-    var _a;
-    text = getTextHandlingSourceMapForSignature(text, data);
-    let sourceFileDirectory;
-    if ((_a = data == null ? void 0 : data.diagnostics) == null ? void 0 : _a.length) {
-      text += data.diagnostics.map(
-        (diagnostic) => `${locationInfo(diagnostic)}${DiagnosticCategory[diagnostic.category]}${diagnostic.code}: ${flattenDiagnosticMessageText2(diagnostic.messageText)}`
-      ).join("\n");
+    function removeResolutionsFromProjectReferenceRedirects(filePath) {
+      if (!fileExtensionIs(filePath, ".json" /* Json */))
+        return;
+      const program = resolutionHost.getCurrentProgram();
+      if (!program)
+        return;
+      const resolvedProjectReference = program.getResolvedProjectReferenceByPath(filePath);
+      if (!resolvedProjectReference)
+        return;
+      resolvedProjectReference.commandLine.fileNames.forEach((f) => removeResolutionsOfFile(resolutionHost.toPath(f)));
     }
-    return (host.createHash ?? generateDjb2Hash)(text);
-    function flattenDiagnosticMessageText2(diagnostic) {
-      return isString(diagnostic) ? diagnostic : diagnostic === void 0 ? "" : !diagnostic.next ? diagnostic.messageText : diagnostic.messageText + diagnostic.next.map(flattenDiagnosticMessageText2).join("\n");
+    function removeResolutionsOfFile(filePath, syncDirWatcherRemove) {
+      removeResolutionsOfFileFromCache(resolvedModuleNames, filePath, getResolvedModule, syncDirWatcherRemove);
+      removeResolutionsOfFileFromCache(resolvedTypeReferenceDirectives, filePath, getResolvedTypeReferenceDirective, syncDirWatcherRemove);
     }
-    function locationInfo(diagnostic) {
-      if (diagnostic.file.resolvedPath === sourceFile.resolvedPath)
-        return `(${diagnostic.start},${diagnostic.length})`;
-      if (sourceFileDirectory === void 0)
-        sourceFileDirectory = getDirectoryPath(sourceFile.resolvedPath);
-      return `${ensurePathIsNonModuleName(getRelativePathFromDirectory(
-        sourceFileDirectory,
-        diagnostic.file.resolvedPath,
-        program.getCanonicalFileName
-      ))}(${diagnostic.start},${diagnostic.length})`;
+    function invalidateResolutions(resolutions, canInvalidate) {
+      if (!resolutions)
+        return false;
+      let invalidated = false;
+      resolutions.forEach((resolution) => {
+        if (resolution.isInvalidated || !canInvalidate(resolution))
+          return;
+        resolution.isInvalidated = invalidated = true;
+        for (const containingFilePath of Debug.checkDefined(resolution.files)) {
+          (filesWithInvalidatedResolutions ?? (filesWithInvalidatedResolutions = /* @__PURE__ */ new Set())).add(containingFilePath);
+          hasChangedAutomaticTypeDirectiveNames = hasChangedAutomaticTypeDirectiveNames || endsWith(containingFilePath, inferredTypesContainingFile);
+        }
+      });
+      return invalidated;
     }
-  }
-  function computeSignature(text, host, data) {
-    return (host.createHash ?? generateDjb2Hash)(getTextHandlingSourceMapForSignature(text, data));
-  }
-  function createBuilderProgram(kind, { newProgram, host, oldProgram, configFileParsingDiagnostics }) {
-    let oldState = oldProgram && oldProgram.getState();
-    if (oldState && newProgram === oldState.program && configFileParsingDiagnostics === newProgram.getConfigFileParsingDiagnostics()) {
-      newProgram = void 0;
-      oldState = void 0;
-      return oldProgram;
+    function invalidateResolutionOfFile(filePath) {
+      removeResolutionsOfFile(filePath);
+      const prevHasChangedAutomaticTypeDirectiveNames = hasChangedAutomaticTypeDirectiveNames;
+      if (invalidateResolutions(resolvedFileToResolution.get(filePath), returnTrue) && hasChangedAutomaticTypeDirectiveNames && !prevHasChangedAutomaticTypeDirectiveNames) {
+        resolutionHost.onChangedAutomaticTypeDirectiveNames();
+      }
     }
-    const state = createBuilderProgramState(newProgram, oldState);
-    newProgram.getBuildInfo = (bundle) => getBuildInfo2(state, bundle);
-    newProgram = void 0;
-    oldProgram = void 0;
-    oldState = void 0;
-    const getState = () => state;
-    const builderProgram = createRedirectedBuilderProgram(getState, configFileParsingDiagnostics);
-    builderProgram.getState = getState;
-    builderProgram.saveEmitState = () => backupBuilderProgramEmitState(state);
-    builderProgram.restoreEmitState = (saved) => restoreBuilderProgramEmitState(state, saved);
-    builderProgram.hasChangedEmitSignature = () => !!state.hasChangedEmitSignature;
-    builderProgram.getAllDependencies = (sourceFile) => BuilderState.getAllDependencies(state, Debug.checkDefined(state.program), sourceFile);
-    builderProgram.getSemanticDiagnostics = getSemanticDiagnostics;
-    builderProgram.emit = emit;
-    builderProgram.releaseProgram = () => releaseCache(state);
-    if (kind === 0 /* SemanticDiagnosticsBuilderProgram */) {
-      builderProgram.getSemanticDiagnosticsOfNextAffectedFile = getSemanticDiagnosticsOfNextAffectedFile;
-    } else if (kind === 1 /* EmitAndSemanticDiagnosticsBuilderProgram */) {
-      builderProgram.getSemanticDiagnosticsOfNextAffectedFile = getSemanticDiagnosticsOfNextAffectedFile;
-      builderProgram.emitNextAffectedFile = emitNextAffectedFile;
-      builderProgram.emitBuildInfo = emitBuildInfo;
-    } else {
-      notImplemented();
+    function setFilesWithInvalidatedNonRelativeUnresolvedImports(filesMap) {
+      Debug.assert(filesWithInvalidatedNonRelativeUnresolvedImports === filesMap || filesWithInvalidatedNonRelativeUnresolvedImports === void 0);
+      filesWithInvalidatedNonRelativeUnresolvedImports = filesMap;
     }
-    return builderProgram;
-    function emitBuildInfo(writeFile2, cancellationToken) {
-      if (state.buildInfoEmitPending) {
-        const result = Debug.checkDefined(state.program).emitBuildInfo(writeFile2 || maybeBind(host, host.writeFile), cancellationToken);
-        state.buildInfoEmitPending = false;
-        return result;
+    function scheduleInvalidateResolutionOfFailedLookupLocation(fileOrDirectoryPath, isCreatingWatchedDirectory) {
+      if (isCreatingWatchedDirectory) {
+        (isInDirectoryChecks || (isInDirectoryChecks = /* @__PURE__ */ new Set())).add(fileOrDirectoryPath);
+      } else {
+        const updatedPath = removeIgnoredPath(fileOrDirectoryPath);
+        if (!updatedPath)
+          return false;
+        fileOrDirectoryPath = updatedPath;
+        if (resolutionHost.fileIsOpen(fileOrDirectoryPath)) {
+          return false;
+        }
+        const dirOfFileOrDirectory = getDirectoryPath(fileOrDirectoryPath);
+        if (isNodeModulesAtTypesDirectory(fileOrDirectoryPath) || isNodeModulesDirectory(fileOrDirectoryPath) || isNodeModulesAtTypesDirectory(dirOfFileOrDirectory) || isNodeModulesDirectory(dirOfFileOrDirectory)) {
+          (failedLookupChecks || (failedLookupChecks = /* @__PURE__ */ new Set())).add(fileOrDirectoryPath);
+          (startsWithPathChecks || (startsWithPathChecks = /* @__PURE__ */ new Set())).add(fileOrDirectoryPath);
+        } else {
+          if (isEmittedFileOfProgram(resolutionHost.getCurrentProgram(), fileOrDirectoryPath)) {
+            return false;
+          }
+          if (fileExtensionIs(fileOrDirectoryPath, ".map")) {
+            return false;
+          }
+          (failedLookupChecks || (failedLookupChecks = /* @__PURE__ */ new Set())).add(fileOrDirectoryPath);
+          const packagePath = parseNodeModuleFromPath(
+            fileOrDirectoryPath,
+            /*isFolder*/
+            true
+          );
+          if (packagePath)
+            (startsWithPathChecks || (startsWithPathChecks = /* @__PURE__ */ new Set())).add(packagePath);
+        }
       }
-      return emitSkippedWithNoDiagnostics;
+      resolutionHost.scheduleInvalidateResolutionsOfFailedLookupLocations();
     }
-    function emitNextAffectedFile(writeFile2, cancellationToken, emitOnlyDtsFiles, customTransformers) {
-      var _a, _b, _c;
-      let affected = getNextAffectedFile(state, cancellationToken, host);
-      const programEmitKind = getBuilderFileEmit(state.compilerOptions);
-      let emitKind = emitOnlyDtsFiles ? programEmitKind & 24 /* AllDts */ : programEmitKind;
-      if (!affected) {
-        if (!outFile(state.compilerOptions)) {
-          const pendingAffectedFile = getNextAffectedFilePendingEmit(state, emitOnlyDtsFiles);
-          if (!pendingAffectedFile) {
-            if (!state.buildInfoEmitPending)
-              return void 0;
-            const affected2 = state.program;
-            const result2 = affected2.emitBuildInfo(writeFile2 || maybeBind(host, host.writeFile), cancellationToken);
-            state.buildInfoEmitPending = false;
-            return { result: result2, affected: affected2 };
-          }
-          ({ affectedFile: affected, emitKind } = pendingAffectedFile);
-        } else {
-          if (!state.programEmitPending)
-            return void 0;
-          emitKind = state.programEmitPending;
-          if (emitOnlyDtsFiles)
-            emitKind = emitKind & 24 /* AllDts */;
-          if (!emitKind)
-            return void 0;
-          affected = state.program;
+    function invalidatePackageJsonMap() {
+      const packageJsonMap = moduleResolutionCache.getPackageJsonInfoCache().getInternalMap();
+      if (packageJsonMap && (failedLookupChecks || startsWithPathChecks || isInDirectoryChecks)) {
+        packageJsonMap.forEach((_value, path) => isInvalidatedFailedLookup(path) ? packageJsonMap.delete(path) : void 0);
+      }
+    }
+    function invalidateResolutionsOfFailedLookupLocations() {
+      var _a;
+      if (allModuleAndTypeResolutionsAreInvalidated) {
+        affectingPathChecksForFile = void 0;
+        invalidatePackageJsonMap();
+        if (failedLookupChecks || startsWithPathChecks || isInDirectoryChecks || affectingPathChecks) {
+          invalidateResolutions(resolvedLibraries, canInvalidateFailedLookupResolution);
         }
+        failedLookupChecks = void 0;
+        startsWithPathChecks = void 0;
+        isInDirectoryChecks = void 0;
+        affectingPathChecks = void 0;
+        return true;
       }
-      let emitOnly;
-      if (emitKind & 7 /* AllJs */)
-        emitOnly = 0 /* Js */;
-      if (emitKind & 24 /* AllDts */)
-        emitOnly = emitOnly === void 0 ? 1 /* Dts */ : void 0;
-      if (affected === state.program) {
-        state.programEmitPending = state.changedFilesSet.size ? getPendingEmitKind(programEmitKind, emitKind) : state.programEmitPending ? getPendingEmitKind(state.programEmitPending, emitKind) : void 0;
+      let invalidated = false;
+      if (affectingPathChecksForFile) {
+        (_a = resolutionHost.getCurrentProgram()) == null ? void 0 : _a.getSourceFiles().forEach((f) => {
+          if (some(f.packageJsonLocations, (location) => affectingPathChecksForFile.has(location))) {
+            (filesWithInvalidatedResolutions ?? (filesWithInvalidatedResolutions = /* @__PURE__ */ new Set())).add(f.path);
+            invalidated = true;
+          }
+        });
+        affectingPathChecksForFile = void 0;
       }
-      const result = state.program.emit(
-        affected === state.program ? void 0 : affected,
-        getWriteFileCallback(writeFile2, customTransformers),
-        cancellationToken,
-        emitOnly,
-        customTransformers
-      );
-      if (affected !== state.program) {
-        const affectedSourceFile = affected;
-        state.seenAffectedFiles.add(affectedSourceFile.resolvedPath);
-        if (state.affectedFilesIndex !== void 0)
-          state.affectedFilesIndex++;
-        state.buildInfoEmitPending = true;
-        const existing = ((_a = state.seenEmittedFiles) == null ? void 0 : _a.get(affectedSourceFile.resolvedPath)) || 0 /* None */;
-        (state.seenEmittedFiles ?? (state.seenEmittedFiles = /* @__PURE__ */ new Map())).set(affectedSourceFile.resolvedPath, emitKind | existing);
-        const existingPending = ((_b = state.affectedFilesPendingEmit) == null ? void 0 : _b.get(affectedSourceFile.resolvedPath)) || programEmitKind;
-        const pendingKind = getPendingEmitKind(existingPending, emitKind | existing);
-        if (pendingKind)
-          (state.affectedFilesPendingEmit ?? (state.affectedFilesPendingEmit = /* @__PURE__ */ new Map())).set(affectedSourceFile.resolvedPath, pendingKind);
-        else
-          (_c = state.affectedFilesPendingEmit) == null ? void 0 : _c.delete(affectedSourceFile.resolvedPath);
-      } else {
-        state.changedFilesSet.clear();
+      if (!failedLookupChecks && !startsWithPathChecks && !isInDirectoryChecks && !affectingPathChecks) {
+        return invalidated;
       }
-      return { result, affected };
+      invalidated = invalidateResolutions(resolutionsWithFailedLookups, canInvalidateFailedLookupResolution) || invalidated;
+      invalidatePackageJsonMap();
+      failedLookupChecks = void 0;
+      startsWithPathChecks = void 0;
+      isInDirectoryChecks = void 0;
+      invalidated = invalidateResolutions(resolutionsWithOnlyAffectingLocations, canInvalidatedFailedLookupResolutionWithAffectingLocation) || invalidated;
+      affectingPathChecks = void 0;
+      return invalidated;
     }
-    function getWriteFileCallback(writeFile2, customTransformers) {
-      if (!getEmitDeclarations(state.compilerOptions))
-        return writeFile2 || maybeBind(host, host.writeFile);
-      return (fileName, text, writeByteOrderMark, onError, sourceFiles, data) => {
-        var _a, _b, _c, _d;
-        if (isDeclarationFileName(fileName)) {
-          if (!outFile(state.compilerOptions)) {
-            Debug.assert((sourceFiles == null ? void 0 : sourceFiles.length) === 1);
-            let emitSignature;
-            if (!customTransformers) {
-              const file = sourceFiles[0];
-              const info = state.fileInfos.get(file.resolvedPath);
-              if (info.signature === file.version) {
-                const signature = computeSignatureWithDiagnostics(
-                  state.program,
-                  file,
-                  text,
-                  host,
-                  data
-                );
-                if (!((_a = data == null ? void 0 : data.diagnostics) == null ? void 0 : _a.length))
-                  emitSignature = signature;
-                if (signature !== file.version) {
-                  if (host.storeFilesChangingSignatureDuringEmit)
-                    (state.filesChangingSignature ?? (state.filesChangingSignature = /* @__PURE__ */ new Set())).add(file.resolvedPath);
-                  if (state.exportedModulesMap)
-                    BuilderState.updateExportedModules(state, file, file.exportedModulesFromDeclarationEmit);
-                  if (state.affectedFiles) {
-                    const existing = (_b = state.oldSignatures) == null ? void 0 : _b.get(file.resolvedPath);
-                    if (existing === void 0)
-                      (state.oldSignatures ?? (state.oldSignatures = /* @__PURE__ */ new Map())).set(file.resolvedPath, info.signature || false);
-                    info.signature = signature;
-                  } else {
-                    info.signature = signature;
-                    (_c = state.oldExportedModulesMap) == null ? void 0 : _c.clear();
-                  }
-                }
-              }
-            }
-            if (state.compilerOptions.composite) {
-              const filePath = sourceFiles[0].resolvedPath;
-              emitSignature = handleNewSignature((_d = state.emitSignatures) == null ? void 0 : _d.get(filePath), emitSignature);
-              if (!emitSignature)
-                return;
-              (state.emitSignatures ?? (state.emitSignatures = /* @__PURE__ */ new Map())).set(filePath, emitSignature);
-            }
-          } else if (state.compilerOptions.composite) {
-            const newSignature = handleNewSignature(
-              state.outSignature,
-              /*newSignature*/
-              void 0
-            );
-            if (!newSignature)
-              return;
-            state.outSignature = newSignature;
-          }
+    function canInvalidateFailedLookupResolution(resolution) {
+      var _a;
+      if (canInvalidatedFailedLookupResolutionWithAffectingLocation(resolution))
+        return true;
+      if (!failedLookupChecks && !startsWithPathChecks && !isInDirectoryChecks)
+        return false;
+      return ((_a = resolution.failedLookupLocations) == null ? void 0 : _a.some((location) => isInvalidatedFailedLookup(resolutionHost.toPath(location)))) || !!resolution.node10Result && isInvalidatedFailedLookup(resolutionHost.toPath(resolution.node10Result));
+    }
+    function isInvalidatedFailedLookup(locationPath) {
+      return (failedLookupChecks == null ? void 0 : failedLookupChecks.has(locationPath)) || firstDefinedIterator((startsWithPathChecks == null ? void 0 : startsWithPathChecks.keys()) || [], (fileOrDirectoryPath) => startsWith(locationPath, fileOrDirectoryPath) ? true : void 0) || firstDefinedIterator((isInDirectoryChecks == null ? void 0 : isInDirectoryChecks.keys()) || [], (dirPath) => locationPath.length > dirPath.length && startsWith(locationPath, dirPath) && (isDiskPathRoot(dirPath) || locationPath[dirPath.length] === directorySeparator) ? true : void 0);
+    }
+    function canInvalidatedFailedLookupResolutionWithAffectingLocation(resolution) {
+      var _a;
+      return !!affectingPathChecks && ((_a = resolution.affectingLocations) == null ? void 0 : _a.some((location) => affectingPathChecks.has(location)));
+    }
+    function closeTypeRootsWatch() {
+      clearMap(typeRootsWatches, closeFileWatcher);
+    }
+    function createTypeRootsWatch(typeRootPath, typeRoot) {
+      return canWatchTypeRootPath(typeRootPath) ? resolutionHost.watchTypeRootsDirectory(typeRoot, (fileOrDirectory) => {
+        const fileOrDirectoryPath = resolutionHost.toPath(fileOrDirectory);
+        if (cachedDirectoryStructureHost) {
+          cachedDirectoryStructureHost.addOrDeleteFileOrDirectory(fileOrDirectory, fileOrDirectoryPath);
         }
-        if (writeFile2)
-          writeFile2(fileName, text, writeByteOrderMark, onError, sourceFiles, data);
-        else if (host.writeFile)
-          host.writeFile(fileName, text, writeByteOrderMark, onError, sourceFiles, data);
-        else
-          state.program.writeFile(fileName, text, writeByteOrderMark, onError, sourceFiles, data);
-        function handleNewSignature(oldSignatureFormat, newSignature) {
-          const oldSignature = !oldSignatureFormat || isString(oldSignatureFormat) ? oldSignatureFormat : oldSignatureFormat[0];
-          newSignature ?? (newSignature = computeSignature(text, host, data));
-          if (newSignature === oldSignature) {
-            if (oldSignatureFormat === oldSignature)
-              return void 0;
-            else if (data)
-              data.differsOnlyInMap = true;
-            else
-              data = { differsOnlyInMap: true };
-          } else {
-            state.hasChangedEmitSignature = true;
-            state.latestChangedDtsFile = fileName;
-          }
-          return newSignature;
+        hasChangedAutomaticTypeDirectiveNames = true;
+        resolutionHost.onChangedAutomaticTypeDirectiveNames();
+        const dirPath = getDirectoryToWatchFailedLookupLocationFromTypeRoot(
+          typeRoot,
+          typeRootPath,
+          rootPath,
+          rootPathComponents,
+          getCurrentDirectory,
+          (dirPath2) => directoryWatchesOfFailedLookups.has(dirPath2)
+        );
+        if (dirPath) {
+          scheduleInvalidateResolutionOfFailedLookupLocation(fileOrDirectoryPath, dirPath === fileOrDirectoryPath);
         }
-      };
+      }, 1 /* Recursive */) : noopFileWatcher;
     }
-    function emit(targetSourceFile, writeFile2, cancellationToken, emitOnlyDtsFiles, customTransformers) {
-      if (kind === 1 /* EmitAndSemanticDiagnosticsBuilderProgram */) {
-        assertSourceFileOkWithoutNextAffectedCall(state, targetSourceFile);
+    function updateTypeRootsWatch() {
+      const options = resolutionHost.getCompilationSettings();
+      if (options.types) {
+        closeTypeRootsWatch();
+        return;
       }
-      const result = handleNoEmitOptions(builderProgram, targetSourceFile, writeFile2, cancellationToken);
-      if (result)
-        return result;
-      if (!targetSourceFile) {
-        if (kind === 1 /* EmitAndSemanticDiagnosticsBuilderProgram */) {
-          let sourceMaps = [];
-          let emitSkipped = false;
-          let diagnostics;
-          let emittedFiles = [];
-          let affectedEmitResult;
-          while (affectedEmitResult = emitNextAffectedFile(writeFile2, cancellationToken, emitOnlyDtsFiles, customTransformers)) {
-            emitSkipped = emitSkipped || affectedEmitResult.result.emitSkipped;
-            diagnostics = addRange(diagnostics, affectedEmitResult.result.diagnostics);
-            emittedFiles = addRange(emittedFiles, affectedEmitResult.result.emittedFiles);
-            sourceMaps = addRange(sourceMaps, affectedEmitResult.result.sourceMaps);
+      const typeRoots = getEffectiveTypeRoots(options, { getCurrentDirectory });
+      if (typeRoots) {
+        mutateMap(
+          typeRootsWatches,
+          arrayToMap(typeRoots, (tr) => resolutionHost.toPath(tr)),
+          {
+            createNewValue: createTypeRootsWatch,
+            onDeleteValue: closeFileWatcher
           }
-          return {
-            emitSkipped,
-            diagnostics: diagnostics || emptyArray,
-            emittedFiles,
-            sourceMaps
-          };
-        } else {
-          clearAffectedFilesPendingEmit(state, emitOnlyDtsFiles);
-        }
+        );
+      } else {
+        closeTypeRootsWatch();
       }
-      return Debug.checkDefined(state.program).emit(
-        targetSourceFile,
-        getWriteFileCallback(writeFile2, customTransformers),
-        cancellationToken,
-        emitOnlyDtsFiles,
-        customTransformers
-      );
     }
-    function getSemanticDiagnosticsOfNextAffectedFile(cancellationToken, ignoreSourceFile) {
-      while (true) {
-        const affected = getNextAffectedFile(state, cancellationToken, host);
-        let result;
-        if (!affected)
-          return void 0;
-        else if (affected !== state.program) {
-          const affectedSourceFile = affected;
-          if (!ignoreSourceFile || !ignoreSourceFile(affectedSourceFile)) {
-            result = getSemanticDiagnosticsOfFile(state, affectedSourceFile, cancellationToken);
-          }
-          state.seenAffectedFiles.add(affectedSourceFile.resolvedPath);
-          state.affectedFilesIndex++;
-          state.buildInfoEmitPending = true;
-          if (!result)
-            continue;
-        } else {
-          result = state.program.getSemanticDiagnostics(
-            /*sourceFile*/
-            void 0,
-            cancellationToken
-          );
-          state.changedFilesSet.clear();
-          state.programEmitPending = getBuilderFileEmit(state.compilerOptions);
-        }
-        return { result, affected };
-      }
+    function canWatchTypeRootPath(typeRoot) {
+      if (resolutionHost.getCompilationSettings().typeRoots)
+        return true;
+      return canWatchAtTypes(resolutionHost.toPath(typeRoot));
     }
-    function getSemanticDiagnostics(sourceFile, cancellationToken) {
-      assertSourceFileOkWithoutNextAffectedCall(state, sourceFile);
-      const compilerOptions = Debug.checkDefined(state.program).getCompilerOptions();
-      if (outFile(compilerOptions)) {
-        Debug.assert(!state.semanticDiagnosticsPerFile);
-        return Debug.checkDefined(state.program).getSemanticDiagnostics(sourceFile, cancellationToken);
+  }
+  function resolutionIsSymlink(resolution) {
+    var _a, _b;
+    return !!(((_a = resolution.resolvedModule) == null ? void 0 : _a.originalPath) || ((_b = resolution.resolvedTypeReferenceDirective) == null ? void 0 : _b.originalPath));
+  }
+  var init_resolutionCache = __esm({
+    "src/compiler/resolutionCache.ts"() {
+      "use strict";
+      init_ts2();
+    }
+  });
+
+  // src/compiler/watch.ts
+  function createDiagnosticReporter(system, pretty) {
+    const host = system === sys && sysFormatDiagnosticsHost ? sysFormatDiagnosticsHost : {
+      getCurrentDirectory: () => system.getCurrentDirectory(),
+      getNewLine: () => system.newLine,
+      getCanonicalFileName: createGetCanonicalFileName(system.useCaseSensitiveFileNames)
+    };
+    if (!pretty) {
+      return (diagnostic) => system.write(formatDiagnostic(diagnostic, host));
+    }
+    const diagnostics = new Array(1);
+    return (diagnostic) => {
+      diagnostics[0] = diagnostic;
+      system.write(formatDiagnosticsWithColorAndContext(diagnostics, host) + host.getNewLine());
+      diagnostics[0] = void 0;
+    };
+  }
+  function clearScreenIfNotWatchingForFileChanges(system, diagnostic, options) {
+    if (system.clearScreen && !options.preserveWatchOutput && !options.extendedDiagnostics && !options.diagnostics && contains(screenStartingMessageCodes, diagnostic.code)) {
+      system.clearScreen();
+      return true;
+    }
+    return false;
+  }
+  function getPlainDiagnosticFollowingNewLines(diagnostic, newLine) {
+    return contains(screenStartingMessageCodes, diagnostic.code) ? newLine + newLine : newLine;
+  }
+  function getLocaleTimeString(system) {
+    return !system.now ? (/* @__PURE__ */ new Date()).toLocaleTimeString() : (
+      // On some systems / builds of Node, there's a non-breaking space between the time and AM/PM.
+      // This branch is solely for testing, so just switch it to a normal space for baseline stability.
+      // See:
+      //     - https://github.com/nodejs/node/issues/45171
+      //     - https://github.com/nodejs/node/issues/45753
+      system.now().toLocaleTimeString("en-US", { timeZone: "UTC" }).replace("\u202F", " ")
+    );
+  }
+  function createWatchStatusReporter(system, pretty) {
+    return pretty ? (diagnostic, newLine, options) => {
+      clearScreenIfNotWatchingForFileChanges(system, diagnostic, options);
+      let output = `[${formatColorAndReset(getLocaleTimeString(system), "\x1B[90m" /* Grey */)}] `;
+      output += `${flattenDiagnosticMessageText(diagnostic.messageText, system.newLine)}${newLine + newLine}`;
+      system.write(output);
+    } : (diagnostic, newLine, options) => {
+      let output = "";
+      if (!clearScreenIfNotWatchingForFileChanges(system, diagnostic, options)) {
+        output += newLine;
       }
-      if (sourceFile) {
-        return getSemanticDiagnosticsOfFile(state, sourceFile, cancellationToken);
+      output += `${getLocaleTimeString(system)} - `;
+      output += `${flattenDiagnosticMessageText(diagnostic.messageText, system.newLine)}${getPlainDiagnosticFollowingNewLines(diagnostic, newLine)}`;
+      system.write(output);
+    };
+  }
+  function parseConfigFileWithSystem(configFileName, optionsToExtend, extendedConfigCache, watchOptionsToExtend, system, reportDiagnostic) {
+    const host = system;
+    host.onUnRecoverableConfigFileDiagnostic = (diagnostic) => reportUnrecoverableDiagnostic(system, reportDiagnostic, diagnostic);
+    const result = getParsedCommandLineOfConfigFile(configFileName, optionsToExtend, host, extendedConfigCache, watchOptionsToExtend);
+    host.onUnRecoverableConfigFileDiagnostic = void 0;
+    return result;
+  }
+  function getErrorCountForSummary(diagnostics) {
+    return countWhere(diagnostics, (diagnostic) => diagnostic.category === 1 /* Error */);
+  }
+  function getFilesInErrorForSummary(diagnostics) {
+    const filesInError = filter(diagnostics, (diagnostic) => diagnostic.category === 1 /* Error */).map(
+      (errorDiagnostic) => {
+        if (errorDiagnostic.file === void 0)
+          return;
+        return `${errorDiagnostic.file.fileName}`;
       }
-      while (getSemanticDiagnosticsOfNextAffectedFile(cancellationToken)) {
+    );
+    return filesInError.map((fileName) => {
+      if (fileName === void 0) {
+        return void 0;
       }
-      let diagnostics;
-      for (const sourceFile2 of Debug.checkDefined(state.program).getSourceFiles()) {
-        diagnostics = addRange(diagnostics, getSemanticDiagnosticsOfFile(state, sourceFile2, cancellationToken));
+      const diagnosticForFileName = find(diagnostics, (diagnostic) => diagnostic.file !== void 0 && diagnostic.file.fileName === fileName);
+      if (diagnosticForFileName !== void 0) {
+        const { line } = getLineAndCharacterOfPosition(diagnosticForFileName.file, diagnosticForFileName.start);
+        return {
+          fileName,
+          line: line + 1
+        };
       }
-      return diagnostics || emptyArray;
-    }
+    });
   }
-  function addToAffectedFilesPendingEmit(state, affectedFilePendingEmit, kind) {
-    var _a;
-    const existingKind = ((_a = state.affectedFilesPendingEmit) == null ? void 0 : _a.get(affectedFilePendingEmit)) || 0 /* None */;
-    (state.affectedFilesPendingEmit ?? (state.affectedFilesPendingEmit = /* @__PURE__ */ new Map())).set(affectedFilePendingEmit, existingKind | kind);
+  function getWatchErrorSummaryDiagnosticMessage(errorCount) {
+    return errorCount === 1 ? Diagnostics.Found_1_error_Watching_for_file_changes : Diagnostics.Found_0_errors_Watching_for_file_changes;
   }
-  function toBuilderStateFileInfoForMultiEmit(fileInfo) {
-    return isString(fileInfo) ? { version: fileInfo, signature: fileInfo, affectsGlobalScope: void 0, impliedFormat: void 0 } : isString(fileInfo.signature) ? fileInfo : { version: fileInfo.version, signature: fileInfo.signature === false ? void 0 : fileInfo.version, affectsGlobalScope: fileInfo.affectsGlobalScope, impliedFormat: fileInfo.impliedFormat };
+  function prettyPathForFileError(error2, cwd) {
+    const line = formatColorAndReset(":" + error2.line, "\x1B[90m" /* Grey */);
+    if (pathIsAbsolute(error2.fileName) && pathIsAbsolute(cwd)) {
+      return getRelativePathFromDirectory(
+        cwd,
+        error2.fileName,
+        /*ignoreCase*/
+        false
+      ) + line;
+    }
+    return error2.fileName + line;
   }
-  function toBuilderFileEmit(value, fullEmitForOptions) {
-    return isNumber(value) ? fullEmitForOptions : value[1] || 8 /* Dts */;
+  function getErrorSummaryText(errorCount, filesInError, newLine, host) {
+    if (errorCount === 0)
+      return "";
+    const nonNilFiles = filesInError.filter((fileInError) => fileInError !== void 0);
+    const distinctFileNamesWithLines = nonNilFiles.map((fileInError) => `${fileInError.fileName}:${fileInError.line}`).filter((value, index, self) => self.indexOf(value) === index);
+    const firstFileReference = nonNilFiles[0] && prettyPathForFileError(nonNilFiles[0], host.getCurrentDirectory());
+    let messageAndArgs;
+    if (errorCount === 1) {
+      messageAndArgs = filesInError[0] !== void 0 ? [Diagnostics.Found_1_error_in_0, firstFileReference] : [Diagnostics.Found_1_error];
+    } else {
+      messageAndArgs = distinctFileNamesWithLines.length === 0 ? [Diagnostics.Found_0_errors, errorCount] : distinctFileNamesWithLines.length === 1 ? [Diagnostics.Found_0_errors_in_the_same_file_starting_at_Colon_1, errorCount, firstFileReference] : [Diagnostics.Found_0_errors_in_1_files, errorCount, distinctFileNamesWithLines.length];
+    }
+    const d = createCompilerDiagnostic(...messageAndArgs);
+    const suffix = distinctFileNamesWithLines.length > 1 ? createTabularErrorsDisplay(nonNilFiles, host) : "";
+    return `${newLine}${flattenDiagnosticMessageText(d.messageText, newLine)}${newLine}${newLine}${suffix}`;
   }
-  function toProgramEmitPending(value, options) {
-    return !value ? getBuilderFileEmit(options || {}) : value;
+  function createTabularErrorsDisplay(filesInError, host) {
+    const distinctFiles = filesInError.filter((value, index, self) => index === self.findIndex((file) => (file == null ? void 0 : file.fileName) === (value == null ? void 0 : value.fileName)));
+    if (distinctFiles.length === 0)
+      return "";
+    const numberLength = (num) => Math.log(num) * Math.LOG10E + 1;
+    const fileToErrorCount = distinctFiles.map((file) => [file, countWhere(filesInError, (fileInError) => fileInError.fileName === file.fileName)]);
+    const maxErrors = fileToErrorCount.reduce((acc, value) => Math.max(acc, value[1] || 0), 0);
+    const headerRow = Diagnostics.Errors_Files.message;
+    const leftColumnHeadingLength = headerRow.split(" ")[0].length;
+    const leftPaddingGoal = Math.max(leftColumnHeadingLength, numberLength(maxErrors));
+    const headerPadding = Math.max(numberLength(maxErrors) - leftColumnHeadingLength, 0);
+    let tabularData = "";
+    tabularData += " ".repeat(headerPadding) + headerRow + "\n";
+    fileToErrorCount.forEach((row) => {
+      const [file, errorCount] = row;
+      const errorCountDigitsLength = Math.log(errorCount) * Math.LOG10E + 1 | 0;
+      const leftPadding = errorCountDigitsLength < leftPaddingGoal ? " ".repeat(leftPaddingGoal - errorCountDigitsLength) : "";
+      const fileRef = prettyPathForFileError(file, host.getCurrentDirectory());
+      tabularData += `${leftPadding}${errorCount}  ${fileRef}
+`;
+    });
+    return tabularData;
   }
-  function createBuilderProgramUsingProgramBuildInfo(buildInfo, buildInfoPath, host) {
-    var _a, _b, _c, _d;
-    const program = buildInfo.program;
-    const buildInfoDirectory = getDirectoryPath(getNormalizedAbsolutePath(buildInfoPath, host.getCurrentDirectory()));
-    const getCanonicalFileName = createGetCanonicalFileName(host.useCaseSensitiveFileNames());
-    let state;
-    const filePaths = (_a = program.fileNames) == null ? void 0 : _a.map(toPathInBuildInfoDirectory);
-    let filePathsSetList;
-    const latestChangedDtsFile = program.latestChangedDtsFile ? toAbsolutePath(program.latestChangedDtsFile) : void 0;
-    if (isProgramBundleEmitBuildInfo(program)) {
-      const fileInfos = /* @__PURE__ */ new Map();
-      program.fileInfos.forEach((fileInfo, index) => {
-        const path = toFilePath(index + 1);
-        fileInfos.set(path, isString(fileInfo) ? { version: fileInfo, signature: void 0, affectsGlobalScope: void 0, impliedFormat: void 0 } : fileInfo);
-      });
-      state = {
-        fileInfos,
-        compilerOptions: program.options ? convertToOptionsWithAbsolutePaths(program.options, toAbsolutePath) : {},
-        latestChangedDtsFile,
-        outSignature: program.outSignature,
-        programEmitPending: program.pendingEmit === void 0 ? void 0 : toProgramEmitPending(program.pendingEmit, program.options),
-        bundle: buildInfo.bundle
-      };
-    } else {
-      filePathsSetList = (_b = program.fileIdsList) == null ? void 0 : _b.map((fileIds) => new Set(fileIds.map(toFilePath)));
-      const fileInfos = /* @__PURE__ */ new Map();
-      const emitSignatures = ((_c = program.options) == null ? void 0 : _c.composite) && !outFile(program.options) ? /* @__PURE__ */ new Map() : void 0;
-      program.fileInfos.forEach((fileInfo, index) => {
-        const path = toFilePath(index + 1);
-        const stateFileInfo = toBuilderStateFileInfoForMultiEmit(fileInfo);
-        fileInfos.set(path, stateFileInfo);
-        if (emitSignatures && stateFileInfo.signature)
-          emitSignatures.set(path, stateFileInfo.signature);
-      });
-      (_d = program.emitSignatures) == null ? void 0 : _d.forEach((value) => {
-        if (isNumber(value))
-          emitSignatures.delete(toFilePath(value));
-        else {
-          const key = toFilePath(value[0]);
-          emitSignatures.set(
-            key,
-            !isString(value[1]) && !value[1].length ? (
-              // File signature is emit signature but differs in map
-              [emitSignatures.get(key)]
-            ) : value[1]
-          );
-        }
+  function isBuilderProgram2(program) {
+    return !!program.getState;
+  }
+  function listFiles(program, write) {
+    const options = program.getCompilerOptions();
+    if (options.explainFiles) {
+      explainFiles(isBuilderProgram2(program) ? program.getProgram() : program, write);
+    } else if (options.listFiles || options.listFilesOnly) {
+      forEach(program.getSourceFiles(), (file) => {
+        write(file.fileName);
       });
-      const fullEmitForOptions = program.affectedFilesPendingEmit ? getBuilderFileEmit(program.options || {}) : void 0;
-      state = {
-        fileInfos,
-        compilerOptions: program.options ? convertToOptionsWithAbsolutePaths(program.options, toAbsolutePath) : {},
-        referencedMap: toManyToManyPathMap(program.referencedMap),
-        exportedModulesMap: toManyToManyPathMap(program.exportedModulesMap),
-        semanticDiagnosticsPerFile: program.semanticDiagnosticsPerFile && arrayToMap(program.semanticDiagnosticsPerFile, (value) => toFilePath(isNumber(value) ? value : value[0]), (value) => isNumber(value) ? emptyArray : value[1]),
-        hasReusableDiagnostic: true,
-        affectedFilesPendingEmit: program.affectedFilesPendingEmit && arrayToMap(program.affectedFilesPendingEmit, (value) => toFilePath(isNumber(value) ? value : value[0]), (value) => toBuilderFileEmit(value, fullEmitForOptions)),
-        changedFilesSet: new Set(map(program.changeFileSet, toFilePath)),
-        latestChangedDtsFile,
-        emitSignatures: (emitSignatures == null ? void 0 : emitSignatures.size) ? emitSignatures : void 0
-      };
-    }
-    return {
-      getState: () => state,
-      saveEmitState: noop,
-      restoreEmitState: noop,
-      getProgram: notImplemented,
-      getProgramOrUndefined: returnUndefined,
-      releaseProgram: noop,
-      getCompilerOptions: () => state.compilerOptions,
-      getSourceFile: notImplemented,
-      getSourceFiles: notImplemented,
-      getOptionsDiagnostics: notImplemented,
-      getGlobalDiagnostics: notImplemented,
-      getConfigFileParsingDiagnostics: notImplemented,
-      getSyntacticDiagnostics: notImplemented,
-      getDeclarationDiagnostics: notImplemented,
-      getSemanticDiagnostics: notImplemented,
-      emit: notImplemented,
-      getAllDependencies: notImplemented,
-      getCurrentDirectory: notImplemented,
-      emitNextAffectedFile: notImplemented,
-      getSemanticDiagnosticsOfNextAffectedFile: notImplemented,
-      emitBuildInfo: notImplemented,
-      close: noop,
-      hasChangedEmitSignature: returnFalse
-    };
-    function toPathInBuildInfoDirectory(path) {
-      return toPath(path, buildInfoDirectory, getCanonicalFileName);
     }
-    function toAbsolutePath(path) {
-      return getNormalizedAbsolutePath(path, buildInfoDirectory);
+  }
+  function explainFiles(program, write) {
+    var _a, _b;
+    const reasons = program.getFileIncludeReasons();
+    const relativeFileName = (fileName) => convertToRelativePath(fileName, program.getCurrentDirectory(), program.getCanonicalFileName);
+    for (const file of program.getSourceFiles()) {
+      write(`${toFileName(file, relativeFileName)}`);
+      (_a = reasons.get(file.path)) == null ? void 0 : _a.forEach((reason) => write(`  ${fileIncludeReasonToDiagnostics(program, reason, relativeFileName).messageText}`));
+      (_b = explainIfFileIsRedirectAndImpliedFormat(file, relativeFileName)) == null ? void 0 : _b.forEach((d) => write(`  ${d.messageText}`));
     }
-    function toFilePath(fileId) {
-      return filePaths[fileId - 1];
+  }
+  function explainIfFileIsRedirectAndImpliedFormat(file, fileNameConvertor) {
+    var _a;
+    let result;
+    if (file.path !== file.resolvedPath) {
+      (result ?? (result = [])).push(chainDiagnosticMessages(
+        /*details*/
+        void 0,
+        Diagnostics.File_is_output_of_project_reference_source_0,
+        toFileName(file.originalFileName, fileNameConvertor)
+      ));
     }
-    function toFilePathsSet(fileIdsListId) {
-      return filePathsSetList[fileIdsListId - 1];
+    if (file.redirectInfo) {
+      (result ?? (result = [])).push(chainDiagnosticMessages(
+        /*details*/
+        void 0,
+        Diagnostics.File_redirects_to_file_0,
+        toFileName(file.redirectInfo.redirectTarget, fileNameConvertor)
+      ));
     }
-    function toManyToManyPathMap(referenceMap) {
-      if (!referenceMap) {
-        return void 0;
+    if (isExternalOrCommonJsModule(file)) {
+      switch (file.impliedNodeFormat) {
+        case 99 /* ESNext */:
+          if (file.packageJsonScope) {
+            (result ?? (result = [])).push(chainDiagnosticMessages(
+              /*details*/
+              void 0,
+              Diagnostics.File_is_ECMAScript_module_because_0_has_field_type_with_value_module,
+              toFileName(last(file.packageJsonLocations), fileNameConvertor)
+            ));
+          }
+          break;
+        case 1 /* CommonJS */:
+          if (file.packageJsonScope) {
+            (result ?? (result = [])).push(chainDiagnosticMessages(
+              /*details*/
+              void 0,
+              file.packageJsonScope.contents.packageJsonContent.type ? Diagnostics.File_is_CommonJS_module_because_0_has_field_type_whose_value_is_not_module : Diagnostics.File_is_CommonJS_module_because_0_does_not_have_field_type,
+              toFileName(last(file.packageJsonLocations), fileNameConvertor)
+            ));
+          } else if ((_a = file.packageJsonLocations) == null ? void 0 : _a.length) {
+            (result ?? (result = [])).push(chainDiagnosticMessages(
+              /*details*/
+              void 0,
+              Diagnostics.File_is_CommonJS_module_because_package_json_was_not_found
+            ));
+          }
+          break;
       }
-      const map2 = BuilderState.createManyToManyPathMap();
-      referenceMap.forEach(
-        ([fileId, fileIdListId]) => map2.set(toFilePath(fileId), toFilePathsSet(fileIdListId))
-      );
-      return map2;
     }
+    return result;
   }
-  function getBuildInfoFileVersionMap(program, buildInfoPath, host) {
-    const buildInfoDirectory = getDirectoryPath(getNormalizedAbsolutePath(buildInfoPath, host.getCurrentDirectory()));
-    const getCanonicalFileName = createGetCanonicalFileName(host.useCaseSensitiveFileNames());
-    const fileInfos = /* @__PURE__ */ new Map();
-    let rootIndex = 0;
-    const roots = [];
-    program.fileInfos.forEach((fileInfo, index) => {
-      const path = toPath(program.fileNames[index], buildInfoDirectory, getCanonicalFileName);
-      const version2 = isString(fileInfo) ? fileInfo : fileInfo.version;
-      fileInfos.set(path, version2);
-      if (rootIndex < program.root.length) {
-        const current = program.root[rootIndex];
-        const fileId = index + 1;
-        if (isArray(current)) {
-          if (current[0] <= fileId && fileId <= current[1]) {
-            roots.push(path);
-            if (current[1] === fileId)
-              rootIndex++;
+  function getMatchedFileSpec(program, fileName) {
+    var _a;
+    const configFile = program.getCompilerOptions().configFile;
+    if (!((_a = configFile == null ? void 0 : configFile.configFileSpecs) == null ? void 0 : _a.validatedFilesSpec))
+      return void 0;
+    const filePath = program.getCanonicalFileName(fileName);
+    const basePath = getDirectoryPath(getNormalizedAbsolutePath(configFile.fileName, program.getCurrentDirectory()));
+    return find(configFile.configFileSpecs.validatedFilesSpec, (fileSpec) => program.getCanonicalFileName(getNormalizedAbsolutePath(fileSpec, basePath)) === filePath);
+  }
+  function getMatchedIncludeSpec(program, fileName) {
+    var _a, _b;
+    const configFile = program.getCompilerOptions().configFile;
+    if (!((_a = configFile == null ? void 0 : configFile.configFileSpecs) == null ? void 0 : _a.validatedIncludeSpecs))
+      return void 0;
+    if (configFile.configFileSpecs.isDefaultIncludeSpec)
+      return true;
+    const isJsonFile = fileExtensionIs(fileName, ".json" /* Json */);
+    const basePath = getDirectoryPath(getNormalizedAbsolutePath(configFile.fileName, program.getCurrentDirectory()));
+    const useCaseSensitiveFileNames2 = program.useCaseSensitiveFileNames();
+    return find((_b = configFile == null ? void 0 : configFile.configFileSpecs) == null ? void 0 : _b.validatedIncludeSpecs, (includeSpec) => {
+      if (isJsonFile && !endsWith(includeSpec, ".json" /* Json */))
+        return false;
+      const pattern = getPatternFromSpec(includeSpec, basePath, "files");
+      return !!pattern && getRegexFromPattern(`(${pattern})$`, useCaseSensitiveFileNames2).test(fileName);
+    });
+  }
+  function fileIncludeReasonToDiagnostics(program, reason, fileNameConvertor) {
+    var _a, _b;
+    const options = program.getCompilerOptions();
+    if (isReferencedFile(reason)) {
+      const referenceLocation = getReferencedFileLocation(program, reason);
+      const referenceText = isReferenceFileLocation(referenceLocation) ? referenceLocation.file.text.substring(referenceLocation.pos, referenceLocation.end) : `"${referenceLocation.text}"`;
+      let message;
+      Debug.assert(isReferenceFileLocation(referenceLocation) || reason.kind === 3 /* Import */, "Only synthetic references are imports");
+      switch (reason.kind) {
+        case 3 /* Import */:
+          if (isReferenceFileLocation(referenceLocation)) {
+            message = referenceLocation.packageId ? Diagnostics.Imported_via_0_from_file_1_with_packageId_2 : Diagnostics.Imported_via_0_from_file_1;
+          } else if (referenceLocation.text === externalHelpersModuleNameText) {
+            message = referenceLocation.packageId ? Diagnostics.Imported_via_0_from_file_1_with_packageId_2_to_import_importHelpers_as_specified_in_compilerOptions : Diagnostics.Imported_via_0_from_file_1_to_import_importHelpers_as_specified_in_compilerOptions;
+          } else {
+            message = referenceLocation.packageId ? Diagnostics.Imported_via_0_from_file_1_with_packageId_2_to_import_jsx_and_jsxs_factory_functions : Diagnostics.Imported_via_0_from_file_1_to_import_jsx_and_jsxs_factory_functions;
           }
-        } else if (current === fileId) {
-          roots.push(path);
-          rootIndex++;
-        }
+          break;
+        case 4 /* ReferenceFile */:
+          Debug.assert(!referenceLocation.packageId);
+          message = Diagnostics.Referenced_via_0_from_file_1;
+          break;
+        case 5 /* TypeReferenceDirective */:
+          message = referenceLocation.packageId ? Diagnostics.Type_library_referenced_via_0_from_file_1_with_packageId_2 : Diagnostics.Type_library_referenced_via_0_from_file_1;
+          break;
+        case 7 /* LibReferenceDirective */:
+          Debug.assert(!referenceLocation.packageId);
+          message = Diagnostics.Library_referenced_via_0_from_file_1;
+          break;
+        default:
+          Debug.assertNever(reason);
+      }
+      return chainDiagnosticMessages(
+        /*details*/
+        void 0,
+        message,
+        referenceText,
+        toFileName(referenceLocation.file, fileNameConvertor),
+        referenceLocation.packageId && packageIdToString(referenceLocation.packageId)
+      );
+    }
+    switch (reason.kind) {
+      case 0 /* RootFile */:
+        if (!((_a = options.configFile) == null ? void 0 : _a.configFileSpecs))
+          return chainDiagnosticMessages(
+            /*details*/
+            void 0,
+            Diagnostics.Root_file_specified_for_compilation
+          );
+        const fileName = getNormalizedAbsolutePath(program.getRootFileNames()[reason.index], program.getCurrentDirectory());
+        const matchedByFiles = getMatchedFileSpec(program, fileName);
+        if (matchedByFiles)
+          return chainDiagnosticMessages(
+            /*details*/
+            void 0,
+            Diagnostics.Part_of_files_list_in_tsconfig_json
+          );
+        const matchedByInclude = getMatchedIncludeSpec(program, fileName);
+        return isString(matchedByInclude) ? chainDiagnosticMessages(
+          /*details*/
+          void 0,
+          Diagnostics.Matched_by_include_pattern_0_in_1,
+          matchedByInclude,
+          toFileName(options.configFile, fileNameConvertor)
+        ) : (
+          // Could be additional files specified as roots or matched by default include
+          chainDiagnosticMessages(
+            /*details*/
+            void 0,
+            matchedByInclude ? Diagnostics.Matched_by_default_include_pattern_Asterisk_Asterisk_Slash_Asterisk : Diagnostics.Root_file_specified_for_compilation
+          )
+        );
+      case 1 /* SourceFromProjectReference */:
+      case 2 /* OutputFromProjectReference */:
+        const isOutput = reason.kind === 2 /* OutputFromProjectReference */;
+        const referencedResolvedRef = Debug.checkDefined((_b = program.getResolvedProjectReferences()) == null ? void 0 : _b[reason.index]);
+        return chainDiagnosticMessages(
+          /*details*/
+          void 0,
+          outFile(options) ? isOutput ? Diagnostics.Output_from_referenced_project_0_included_because_1_specified : Diagnostics.Source_from_referenced_project_0_included_because_1_specified : isOutput ? Diagnostics.Output_from_referenced_project_0_included_because_module_is_specified_as_none : Diagnostics.Source_from_referenced_project_0_included_because_module_is_specified_as_none,
+          toFileName(referencedResolvedRef.sourceFile.fileName, fileNameConvertor),
+          options.outFile ? "--outFile" : "--out"
+        );
+      case 8 /* AutomaticTypeDirectiveFile */: {
+        const messageAndArgs = options.types ? reason.packageId ? [Diagnostics.Entry_point_of_type_library_0_specified_in_compilerOptions_with_packageId_1, reason.typeReference, packageIdToString(reason.packageId)] : [Diagnostics.Entry_point_of_type_library_0_specified_in_compilerOptions, reason.typeReference] : reason.packageId ? [Diagnostics.Entry_point_for_implicit_type_library_0_with_packageId_1, reason.typeReference, packageIdToString(reason.packageId)] : [Diagnostics.Entry_point_for_implicit_type_library_0, reason.typeReference];
+        return chainDiagnosticMessages(
+          /*details*/
+          void 0,
+          ...messageAndArgs
+        );
+      }
+      case 6 /* LibFile */: {
+        if (reason.index !== void 0)
+          return chainDiagnosticMessages(
+            /*details*/
+            void 0,
+            Diagnostics.Library_0_specified_in_compilerOptions,
+            options.lib[reason.index]
+          );
+        const target = forEachEntry(targetOptionDeclaration.type, (value, key) => value === getEmitScriptTarget(options) ? key : void 0);
+        const messageAndArgs = target ? [Diagnostics.Default_library_for_target_0, target] : [Diagnostics.Default_library];
+        return chainDiagnosticMessages(
+          /*details*/
+          void 0,
+          ...messageAndArgs
+        );
       }
-    });
-    return { fileInfos, roots };
-  }
-  function createRedirectedBuilderProgram(getState, configFileParsingDiagnostics) {
-    return {
-      getState: notImplemented,
-      saveEmitState: noop,
-      restoreEmitState: noop,
-      getProgram,
-      getProgramOrUndefined: () => getState().program,
-      releaseProgram: () => getState().program = void 0,
-      getCompilerOptions: () => getState().compilerOptions,
-      getSourceFile: (fileName) => getProgram().getSourceFile(fileName),
-      getSourceFiles: () => getProgram().getSourceFiles(),
-      getOptionsDiagnostics: (cancellationToken) => getProgram().getOptionsDiagnostics(cancellationToken),
-      getGlobalDiagnostics: (cancellationToken) => getProgram().getGlobalDiagnostics(cancellationToken),
-      getConfigFileParsingDiagnostics: () => configFileParsingDiagnostics,
-      getSyntacticDiagnostics: (sourceFile, cancellationToken) => getProgram().getSyntacticDiagnostics(sourceFile, cancellationToken),
-      getDeclarationDiagnostics: (sourceFile, cancellationToken) => getProgram().getDeclarationDiagnostics(sourceFile, cancellationToken),
-      getSemanticDiagnostics: (sourceFile, cancellationToken) => getProgram().getSemanticDiagnostics(sourceFile, cancellationToken),
-      emit: (sourceFile, writeFile2, cancellationToken, emitOnlyDts, customTransformers) => getProgram().emit(sourceFile, writeFile2, cancellationToken, emitOnlyDts, customTransformers),
-      emitBuildInfo: (writeFile2, cancellationToken) => getProgram().emitBuildInfo(writeFile2, cancellationToken),
-      getAllDependencies: notImplemented,
-      getCurrentDirectory: () => getProgram().getCurrentDirectory(),
-      close: noop
-    };
-    function getProgram() {
-      return Debug.checkDefined(getState().program);
-    }
-  }
-  var BuilderFileEmit, BuilderProgramKind;
-  var init_builder = __esm({
-    "src/compiler/builder.ts"() {
-      "use strict";
-      init_ts2();
-      BuilderFileEmit = /* @__PURE__ */ ((BuilderFileEmit2) => {
-        BuilderFileEmit2[BuilderFileEmit2["None"] = 0] = "None";
-        BuilderFileEmit2[BuilderFileEmit2["Js"] = 1] = "Js";
-        BuilderFileEmit2[BuilderFileEmit2["JsMap"] = 2] = "JsMap";
-        BuilderFileEmit2[BuilderFileEmit2["JsInlineMap"] = 4] = "JsInlineMap";
-        BuilderFileEmit2[BuilderFileEmit2["Dts"] = 8] = "Dts";
-        BuilderFileEmit2[BuilderFileEmit2["DtsMap"] = 16] = "DtsMap";
-        BuilderFileEmit2[BuilderFileEmit2["AllJs"] = 7] = "AllJs";
-        BuilderFileEmit2[BuilderFileEmit2["AllDts"] = 24] = "AllDts";
-        BuilderFileEmit2[BuilderFileEmit2["All"] = 31] = "All";
-        return BuilderFileEmit2;
-      })(BuilderFileEmit || {});
-      BuilderProgramKind = /* @__PURE__ */ ((BuilderProgramKind2) => {
-        BuilderProgramKind2[BuilderProgramKind2["SemanticDiagnosticsBuilderProgram"] = 0] = "SemanticDiagnosticsBuilderProgram";
-        BuilderProgramKind2[BuilderProgramKind2["EmitAndSemanticDiagnosticsBuilderProgram"] = 1] = "EmitAndSemanticDiagnosticsBuilderProgram";
-        return BuilderProgramKind2;
-      })(BuilderProgramKind || {});
+      default:
+        Debug.assertNever(reason);
     }
-  });
-
-  // src/compiler/builderPublic.ts
-  function createSemanticDiagnosticsBuilderProgram(newProgramOrRootNames, hostOrOptions, oldProgramOrHost, configFileParsingDiagnosticsOrOldProgram, configFileParsingDiagnostics, projectReferences) {
-    return createBuilderProgram(0 /* SemanticDiagnosticsBuilderProgram */, getBuilderCreationParameters(newProgramOrRootNames, hostOrOptions, oldProgramOrHost, configFileParsingDiagnosticsOrOldProgram, configFileParsingDiagnostics, projectReferences));
-  }
-  function createEmitAndSemanticDiagnosticsBuilderProgram(newProgramOrRootNames, hostOrOptions, oldProgramOrHost, configFileParsingDiagnosticsOrOldProgram, configFileParsingDiagnostics, projectReferences) {
-    return createBuilderProgram(1 /* EmitAndSemanticDiagnosticsBuilderProgram */, getBuilderCreationParameters(newProgramOrRootNames, hostOrOptions, oldProgramOrHost, configFileParsingDiagnosticsOrOldProgram, configFileParsingDiagnostics, projectReferences));
   }
-  function createAbstractBuilder(newProgramOrRootNames, hostOrOptions, oldProgramOrHost, configFileParsingDiagnosticsOrOldProgram, configFileParsingDiagnostics, projectReferences) {
-    const { newProgram, configFileParsingDiagnostics: newConfigFileParsingDiagnostics } = getBuilderCreationParameters(newProgramOrRootNames, hostOrOptions, oldProgramOrHost, configFileParsingDiagnosticsOrOldProgram, configFileParsingDiagnostics, projectReferences);
-    return createRedirectedBuilderProgram(() => ({ program: newProgram, compilerOptions: newProgram.getCompilerOptions() }), newConfigFileParsingDiagnostics);
+  function toFileName(file, fileNameConvertor) {
+    const fileName = isString(file) ? file : file.fileName;
+    return fileNameConvertor ? fileNameConvertor(fileName) : fileName;
   }
-  var init_builderPublic = __esm({
-    "src/compiler/builderPublic.ts"() {
-      "use strict";
-      init_ts2();
-    }
-  });
-
-  // src/compiler/resolutionCache.ts
-  function removeIgnoredPath(path) {
-    if (endsWith(path, "/node_modules/.staging")) {
-      return removeSuffix(path, "/.staging");
+  function emitFilesAndReportErrors(program, reportDiagnostic, write, reportSummary, writeFile2, cancellationToken, emitOnlyDtsFiles, customTransformers) {
+    const isListFilesOnly = !!program.getCompilerOptions().listFilesOnly;
+    const allDiagnostics = program.getConfigFileParsingDiagnostics().slice();
+    const configFileParsingDiagnosticsLength = allDiagnostics.length;
+    addRange(allDiagnostics, program.getSyntacticDiagnostics(
+      /*sourceFile*/
+      void 0,
+      cancellationToken
+    ));
+    if (allDiagnostics.length === configFileParsingDiagnosticsLength) {
+      addRange(allDiagnostics, program.getOptionsDiagnostics(cancellationToken));
+      if (!isListFilesOnly) {
+        addRange(allDiagnostics, program.getGlobalDiagnostics(cancellationToken));
+        if (allDiagnostics.length === configFileParsingDiagnosticsLength) {
+          addRange(allDiagnostics, program.getSemanticDiagnostics(
+            /*sourceFile*/
+            void 0,
+            cancellationToken
+          ));
+        }
+      }
     }
-    return some(ignoredPaths, (searchPath) => stringContains(path, searchPath)) ? void 0 : path;
-  }
-  function perceivedOsRootLengthForWatching(pathComponents2, length2) {
-    if (length2 <= 1)
-      return 1;
-    let userCheckIndex = 1;
-    let isDosStyle = pathComponents2[0].search(/[a-zA-Z]:/) === 0;
-    if (pathComponents2[0] !== directorySeparator && !isDosStyle && // Non dos style paths
-    pathComponents2[1].search(/[a-zA-Z]\$$/) === 0) {
-      if (length2 === 2)
-        return 2;
-      userCheckIndex = 2;
-      isDosStyle = true;
+    const emitResult = isListFilesOnly ? { emitSkipped: true, diagnostics: emptyArray } : program.emit(
+      /*targetSourceFile*/
+      void 0,
+      writeFile2,
+      cancellationToken,
+      emitOnlyDtsFiles,
+      customTransformers
+    );
+    const { emittedFiles, diagnostics: emitDiagnostics } = emitResult;
+    addRange(allDiagnostics, emitDiagnostics);
+    const diagnostics = sortAndDeduplicateDiagnostics(allDiagnostics);
+    diagnostics.forEach(reportDiagnostic);
+    if (write) {
+      const currentDir = program.getCurrentDirectory();
+      forEach(emittedFiles, (file) => {
+        const filepath = getNormalizedAbsolutePath(file, currentDir);
+        write(`TSFILE: ${filepath}`);
+      });
+      listFiles(program, write);
     }
-    if (isDosStyle && !pathComponents2[userCheckIndex].match(/^users$/i)) {
-      return userCheckIndex;
+    if (reportSummary) {
+      reportSummary(getErrorCountForSummary(diagnostics), getFilesInErrorForSummary(diagnostics));
     }
-    return userCheckIndex + 2;
-  }
-  function canWatchDirectoryOrFile(pathComponents2, length2) {
-    if (length2 === void 0)
-      length2 = pathComponents2.length;
-    if (length2 <= 2)
-      return false;
-    const perceivedOsRootLength = perceivedOsRootLengthForWatching(pathComponents2, length2);
-    return length2 > perceivedOsRootLength + 1;
-  }
-  function canWatchAtTypes(atTypes) {
-    return canWatchAffectedPackageJsonOrNodeModulesOfAtTypes(getDirectoryPath(atTypes));
+    return {
+      emitResult,
+      diagnostics
+    };
   }
-  function isInDirectoryPath(dirComponents, fileOrDirComponents) {
-    if (fileOrDirComponents.length < fileOrDirComponents.length)
-      return false;
-    for (let i = 0; i < dirComponents.length; i++) {
-      if (fileOrDirComponents[i] !== dirComponents[i])
-        return false;
+  function emitFilesAndReportErrorsAndGetExitStatus(program, reportDiagnostic, write, reportSummary, writeFile2, cancellationToken, emitOnlyDtsFiles, customTransformers) {
+    const { emitResult, diagnostics } = emitFilesAndReportErrors(
+      program,
+      reportDiagnostic,
+      write,
+      reportSummary,
+      writeFile2,
+      cancellationToken,
+      emitOnlyDtsFiles,
+      customTransformers
+    );
+    if (emitResult.emitSkipped && diagnostics.length > 0) {
+      return 1 /* DiagnosticsPresent_OutputsSkipped */;
+    } else if (diagnostics.length > 0) {
+      return 2 /* DiagnosticsPresent_OutputsGenerated */;
     }
-    return true;
+    return 0 /* Success */;
   }
-  function canWatchAffectedPackageJsonOrNodeModulesOfAtTypes(fileOrDirPath) {
-    return canWatchDirectoryOrFile(getPathComponents(fileOrDirPath));
+  function createWatchHost(system = sys, reportWatchStatus2) {
+    const onWatchStatusChange = reportWatchStatus2 || createWatchStatusReporter(system);
+    return {
+      onWatchStatusChange,
+      watchFile: maybeBind(system, system.watchFile) || returnNoopFileWatcher,
+      watchDirectory: maybeBind(system, system.watchDirectory) || returnNoopFileWatcher,
+      setTimeout: maybeBind(system, system.setTimeout) || noop,
+      clearTimeout: maybeBind(system, system.clearTimeout) || noop
+    };
   }
-  function canWatchAffectingLocation(filePath) {
-    return canWatchAffectedPackageJsonOrNodeModulesOfAtTypes(filePath);
+  function createWatchFactory(host, options) {
+    const watchLogLevel = host.trace ? options.extendedDiagnostics ? 2 /* Verbose */ : options.diagnostics ? 1 /* TriggerOnly */ : 0 /* None */ : 0 /* None */;
+    const writeLog = watchLogLevel !== 0 /* None */ ? (s) => host.trace(s) : noop;
+    const result = getWatchFactory(host, watchLogLevel, writeLog);
+    result.writeLog = writeLog;
+    return result;
   }
-  function getDirectoryToWatchFailedLookupLocation(failedLookupLocation, failedLookupLocationPath, rootDir, rootPath, rootPathComponents, getCurrentDirectory) {
-    const failedLookupPathComponents = getPathComponents(failedLookupLocationPath);
-    failedLookupLocation = isRootedDiskPath(failedLookupLocation) ? normalizePath(failedLookupLocation) : getNormalizedAbsolutePath(failedLookupLocation, getCurrentDirectory());
-    const failedLookupComponents = getPathComponents(failedLookupLocation);
-    const perceivedOsRootLength = perceivedOsRootLengthForWatching(failedLookupPathComponents, failedLookupPathComponents.length);
-    if (failedLookupPathComponents.length <= perceivedOsRootLength + 1)
-      return void 0;
-    const nodeModulesIndex = failedLookupPathComponents.indexOf("node_modules");
-    if (nodeModulesIndex !== -1 && nodeModulesIndex + 1 <= perceivedOsRootLength + 1)
-      return void 0;
-    if (isInDirectoryPath(rootPathComponents, failedLookupPathComponents)) {
-      if (failedLookupPathComponents.length > rootPathComponents.length + 1) {
-        return getDirectoryOfFailedLookupWatch(failedLookupComponents, failedLookupPathComponents, Math.max(rootPathComponents.length + 1, perceivedOsRootLength + 1));
-      } else {
-        return {
-          dir: rootDir,
-          dirPath: rootPath,
-          nonRecursive: true
-        };
+  function createCompilerHostFromProgramHost(host, getCompilerOptions, directoryStructureHost = host) {
+    const useCaseSensitiveFileNames2 = host.useCaseSensitiveFileNames();
+    const compilerHost = {
+      getSourceFile: createGetSourceFile(
+        (fileName, encoding) => !encoding ? compilerHost.readFile(fileName) : host.readFile(fileName, encoding),
+        getCompilerOptions,
+        /*setParentNodes*/
+        void 0
+      ),
+      getDefaultLibLocation: maybeBind(host, host.getDefaultLibLocation),
+      getDefaultLibFileName: (options) => host.getDefaultLibFileName(options),
+      writeFile: createWriteFileMeasuringIO(
+        (path, data, writeByteOrderMark) => host.writeFile(path, data, writeByteOrderMark),
+        (path) => host.createDirectory(path),
+        (path) => host.directoryExists(path)
+      ),
+      getCurrentDirectory: memoize(() => host.getCurrentDirectory()),
+      useCaseSensitiveFileNames: () => useCaseSensitiveFileNames2,
+      getCanonicalFileName: createGetCanonicalFileName(useCaseSensitiveFileNames2),
+      getNewLine: () => getNewLineCharacter(getCompilerOptions()),
+      fileExists: (f) => host.fileExists(f),
+      readFile: (f) => host.readFile(f),
+      trace: maybeBind(host, host.trace),
+      directoryExists: maybeBind(directoryStructureHost, directoryStructureHost.directoryExists),
+      getDirectories: maybeBind(directoryStructureHost, directoryStructureHost.getDirectories),
+      realpath: maybeBind(host, host.realpath),
+      getEnvironmentVariable: maybeBind(host, host.getEnvironmentVariable) || (() => ""),
+      createHash: maybeBind(host, host.createHash),
+      readDirectory: maybeBind(host, host.readDirectory),
+      storeFilesChangingSignatureDuringEmit: host.storeFilesChangingSignatureDuringEmit,
+      jsDocParsingMode: host.jsDocParsingMode
+    };
+    return compilerHost;
+  }
+  function getSourceFileVersionAsHashFromText(host, text) {
+    if (text.match(sourceMapCommentRegExpDontCareLineStart)) {
+      let lineEnd = text.length;
+      let lineStart = lineEnd;
+      for (let pos = lineEnd - 1; pos >= 0; pos--) {
+        const ch = text.charCodeAt(pos);
+        switch (ch) {
+          case 10 /* lineFeed */:
+            if (pos && text.charCodeAt(pos - 1) === 13 /* carriageReturn */) {
+              pos--;
+            }
+          case 13 /* carriageReturn */:
+            break;
+          default:
+            if (ch < 127 /* maxAsciiCharacter */ || !isLineBreak(ch)) {
+              lineStart = pos;
+              continue;
+            }
+            break;
+        }
+        const line = text.substring(lineStart, lineEnd);
+        if (line.match(sourceMapCommentRegExp)) {
+          text = text.substring(0, lineStart);
+          break;
+        } else if (!line.match(whitespaceOrMapCommentRegExp)) {
+          break;
+        }
+        lineEnd = lineStart;
       }
     }
-    return getDirectoryToWatchFromFailedLookupLocationDirectory(
-      failedLookupComponents,
-      failedLookupPathComponents,
-      failedLookupPathComponents.length - 1,
-      perceivedOsRootLength,
-      nodeModulesIndex,
-      rootPathComponents
-    );
+    return (host.createHash || generateDjb2Hash)(text);
   }
-  function getDirectoryToWatchFromFailedLookupLocationDirectory(dirComponents, dirPathComponents, dirPathComponentsLength, perceivedOsRootLength, nodeModulesIndex, rootPathComponents) {
-    if (nodeModulesIndex !== -1) {
-      return getDirectoryOfFailedLookupWatch(dirComponents, dirPathComponents, nodeModulesIndex + 1);
-    }
-    let nonRecursive = true;
-    let length2 = dirPathComponentsLength;
-    for (let i = 0; i < dirPathComponentsLength; i++) {
-      if (dirPathComponents[i] !== rootPathComponents[i]) {
-        nonRecursive = false;
-        length2 = Math.max(i + 1, perceivedOsRootLength + 1);
-        break;
+  function setGetSourceFileAsHashVersioned(compilerHost) {
+    const originalGetSourceFile = compilerHost.getSourceFile;
+    compilerHost.getSourceFile = (...args) => {
+      const result = originalGetSourceFile.call(compilerHost, ...args);
+      if (result) {
+        result.version = getSourceFileVersionAsHashFromText(compilerHost, result.text);
       }
-    }
-    return getDirectoryOfFailedLookupWatch(dirComponents, dirPathComponents, length2, nonRecursive);
+      return result;
+    };
   }
-  function getDirectoryOfFailedLookupWatch(dirComponents, dirPathComponents, length2, nonRecursive) {
+  function createProgramHost(system, createProgram2) {
+    const getDefaultLibLocation = memoize(() => getDirectoryPath(normalizePath(system.getExecutingFilePath())));
     return {
-      dir: getPathFromPathComponents(dirComponents, length2),
-      dirPath: getPathFromPathComponents(dirPathComponents, length2),
-      nonRecursive
+      useCaseSensitiveFileNames: () => system.useCaseSensitiveFileNames,
+      getNewLine: () => system.newLine,
+      getCurrentDirectory: memoize(() => system.getCurrentDirectory()),
+      getDefaultLibLocation,
+      getDefaultLibFileName: (options) => combinePaths(getDefaultLibLocation(), getDefaultLibFileName(options)),
+      fileExists: (path) => system.fileExists(path),
+      readFile: (path, encoding) => system.readFile(path, encoding),
+      directoryExists: (path) => system.directoryExists(path),
+      getDirectories: (path) => system.getDirectories(path),
+      readDirectory: (path, extensions, exclude, include, depth) => system.readDirectory(path, extensions, exclude, include, depth),
+      realpath: maybeBind(system, system.realpath),
+      getEnvironmentVariable: maybeBind(system, system.getEnvironmentVariable),
+      trace: (s) => system.write(s + system.newLine),
+      createDirectory: (path) => system.createDirectory(path),
+      writeFile: (path, data, writeByteOrderMark) => system.writeFile(path, data, writeByteOrderMark),
+      createHash: maybeBind(system, system.createHash),
+      createProgram: createProgram2 || createEmitAndSemanticDiagnosticsBuilderProgram,
+      storeFilesChangingSignatureDuringEmit: system.storeFilesChangingSignatureDuringEmit,
+      now: maybeBind(system, system.now)
     };
   }
-  function getDirectoryToWatchFailedLookupLocationFromTypeRoot(typeRoot, typeRootPath, rootPath, rootPathComponents, getCurrentDirectory, filterCustomPath) {
-    const typeRootPathComponents = getPathComponents(typeRootPath);
-    if (isInDirectoryPath(rootPathComponents, typeRootPathComponents)) {
-      return rootPath;
-    }
-    typeRoot = isRootedDiskPath(typeRoot) ? normalizePath(typeRoot) : getNormalizedAbsolutePath(typeRoot, getCurrentDirectory());
-    const toWatch = getDirectoryToWatchFromFailedLookupLocationDirectory(
-      getPathComponents(typeRoot),
-      typeRootPathComponents,
-      typeRootPathComponents.length,
-      perceivedOsRootLengthForWatching(typeRootPathComponents, typeRootPathComponents.length),
-      typeRootPathComponents.indexOf("node_modules"),
-      rootPathComponents
-    );
-    return toWatch && filterCustomPath(toWatch.dirPath) ? toWatch.dirPath : void 0;
+  function createWatchCompilerHost(system = sys, createProgram2, reportDiagnostic, reportWatchStatus2) {
+    const write = (s) => system.write(s + system.newLine);
+    const result = createProgramHost(system, createProgram2);
+    copyProperties(result, createWatchHost(system, reportWatchStatus2));
+    result.afterProgramCreate = (builderProgram) => {
+      const compilerOptions = builderProgram.getCompilerOptions();
+      const newLine = getNewLineCharacter(compilerOptions);
+      emitFilesAndReportErrors(
+        builderProgram,
+        reportDiagnostic,
+        write,
+        (errorCount) => result.onWatchStatusChange(
+          createCompilerDiagnostic(getWatchErrorSummaryDiagnosticMessage(errorCount), errorCount),
+          newLine,
+          compilerOptions,
+          errorCount
+        )
+      );
+    };
+    return result;
   }
-  function getRootDirectoryOfResolutionCache(rootDirForResolution, getCurrentDirectory) {
-    const normalized = getNormalizedAbsolutePath(rootDirForResolution, getCurrentDirectory());
-    return !isDiskPathRoot(normalized) ? removeTrailingDirectorySeparator(normalized) : normalized;
+  function reportUnrecoverableDiagnostic(system, reportDiagnostic, diagnostic) {
+    reportDiagnostic(diagnostic);
+    system.exit(1 /* DiagnosticsPresent_OutputsSkipped */);
   }
-  function getRootPathSplitLength(rootPath) {
-    return rootPath.split(directorySeparator).length - (hasTrailingDirectorySeparator(rootPath) ? 1 : 0);
+  function createWatchCompilerHostOfConfigFile({
+    configFileName,
+    optionsToExtend,
+    watchOptionsToExtend,
+    extraFileExtensions,
+    system,
+    createProgram: createProgram2,
+    reportDiagnostic,
+    reportWatchStatus: reportWatchStatus2
+  }) {
+    const diagnosticReporter = reportDiagnostic || createDiagnosticReporter(system);
+    const host = createWatchCompilerHost(system, createProgram2, diagnosticReporter, reportWatchStatus2);
+    host.onUnRecoverableConfigFileDiagnostic = (diagnostic) => reportUnrecoverableDiagnostic(system, diagnosticReporter, diagnostic);
+    host.configFileName = configFileName;
+    host.optionsToExtend = optionsToExtend;
+    host.watchOptionsToExtend = watchOptionsToExtend;
+    host.extraFileExtensions = extraFileExtensions;
+    return host;
   }
-  function createResolutionCache(resolutionHost, rootDirForResolution, logChangesWhenResolvingModule) {
-    let filesWithChangedSetOfUnresolvedImports;
-    let filesWithInvalidatedResolutions;
-    let filesWithInvalidatedNonRelativeUnresolvedImports;
-    const nonRelativeExternalModuleResolutions = createMultiMap();
-    const resolutionsWithFailedLookups = /* @__PURE__ */ new Set();
-    const resolutionsWithOnlyAffectingLocations = /* @__PURE__ */ new Set();
-    const resolvedFileToResolution = /* @__PURE__ */ new Map();
-    const impliedFormatPackageJsons = /* @__PURE__ */ new Map();
-    let hasChangedAutomaticTypeDirectiveNames = false;
-    let affectingPathChecksForFile;
-    let affectingPathChecks;
-    let failedLookupChecks;
-    let startsWithPathChecks;
-    let isInDirectoryChecks;
-    let allModuleAndTypeResolutionsAreInvalidated = false;
-    const getCurrentDirectory = memoize(() => resolutionHost.getCurrentDirectory());
-    const cachedDirectoryStructureHost = resolutionHost.getCachedDirectoryStructureHost();
-    const resolvedModuleNames = /* @__PURE__ */ new Map();
-    const moduleResolutionCache = createModuleResolutionCache(
-      getCurrentDirectory(),
-      resolutionHost.getCanonicalFileName,
-      resolutionHost.getCompilationSettings()
-    );
-    const resolvedTypeReferenceDirectives = /* @__PURE__ */ new Map();
-    const typeReferenceDirectiveResolutionCache = createTypeReferenceDirectiveResolutionCache(
-      getCurrentDirectory(),
-      resolutionHost.getCanonicalFileName,
-      resolutionHost.getCompilationSettings(),
-      moduleResolutionCache.getPackageJsonInfoCache()
-    );
-    const resolvedLibraries = /* @__PURE__ */ new Map();
-    const libraryResolutionCache = createModuleResolutionCache(
-      getCurrentDirectory(),
-      resolutionHost.getCanonicalFileName,
-      getOptionsForLibraryResolution(resolutionHost.getCompilationSettings()),
-      moduleResolutionCache.getPackageJsonInfoCache()
+  function createWatchCompilerHostOfFilesAndCompilerOptions({
+    rootFiles,
+    options,
+    watchOptions,
+    projectReferences,
+    system,
+    createProgram: createProgram2,
+    reportDiagnostic,
+    reportWatchStatus: reportWatchStatus2
+  }) {
+    const host = createWatchCompilerHost(system, createProgram2, reportDiagnostic || createDiagnosticReporter(system), reportWatchStatus2);
+    host.rootFiles = rootFiles;
+    host.options = options;
+    host.watchOptions = watchOptions;
+    host.projectReferences = projectReferences;
+    return host;
+  }
+  function performIncrementalCompilation(input) {
+    const system = input.system || sys;
+    const host = input.host || (input.host = createIncrementalCompilerHost(input.options, system));
+    const builderProgram = createIncrementalProgram(input);
+    const exitStatus = emitFilesAndReportErrorsAndGetExitStatus(
+      builderProgram,
+      input.reportDiagnostic || createDiagnosticReporter(system),
+      (s) => host.trace && host.trace(s),
+      input.reportErrorSummary || input.options.pretty ? (errorCount, filesInError) => system.write(getErrorSummaryText(errorCount, filesInError, system.newLine, host)) : void 0
     );
-    const directoryWatchesOfFailedLookups = /* @__PURE__ */ new Map();
-    const fileWatchesOfAffectingLocations = /* @__PURE__ */ new Map();
-    const rootDir = getRootDirectoryOfResolutionCache(rootDirForResolution, getCurrentDirectory);
-    const rootPath = resolutionHost.toPath(rootDir);
-    const rootPathComponents = getPathComponents(rootPath);
-    const typeRootsWatches = /* @__PURE__ */ new Map();
-    return {
-      getModuleResolutionCache: () => moduleResolutionCache,
-      startRecordingFilesWithChangedResolutions,
-      finishRecordingFilesWithChangedResolutions,
-      // perDirectoryResolvedModuleNames and perDirectoryResolvedTypeReferenceDirectives could be non empty if there was exception during program update
-      // (between startCachingPerDirectoryResolution and finishCachingPerDirectoryResolution)
-      startCachingPerDirectoryResolution,
-      finishCachingPerDirectoryResolution,
-      resolveModuleNameLiterals,
-      resolveTypeReferenceDirectiveReferences,
-      resolveLibrary: resolveLibrary2,
-      resolveSingleModuleNameWithoutWatching,
-      removeResolutionsFromProjectReferenceRedirects,
-      removeResolutionsOfFile,
-      hasChangedAutomaticTypeDirectiveNames: () => hasChangedAutomaticTypeDirectiveNames,
-      invalidateResolutionOfFile,
-      invalidateResolutionsOfFailedLookupLocations,
-      setFilesWithInvalidatedNonRelativeUnresolvedImports,
-      createHasInvalidatedResolutions,
-      isFileWithInvalidatedNonRelativeUnresolvedImports,
-      updateTypeRootsWatch,
-      closeTypeRootsWatch,
-      clear: clear2,
-      onChangesAffectModuleResolution
-    };
-    function getResolvedModule2(resolution) {
-      return resolution.resolvedModule;
+    if (input.afterProgramEmitAndDiagnostics)
+      input.afterProgramEmitAndDiagnostics(builderProgram);
+    return exitStatus;
+  }
+  var sysFormatDiagnosticsHost, screenStartingMessageCodes, noopFileWatcher, returnNoopFileWatcher, WatchType;
+  var init_watch = __esm({
+    "src/compiler/watch.ts"() {
+      "use strict";
+      init_ts2();
+      sysFormatDiagnosticsHost = sys ? {
+        getCurrentDirectory: () => sys.getCurrentDirectory(),
+        getNewLine: () => sys.newLine,
+        getCanonicalFileName: createGetCanonicalFileName(sys.useCaseSensitiveFileNames)
+      } : void 0;
+      screenStartingMessageCodes = [
+        Diagnostics.Starting_compilation_in_watch_mode.code,
+        Diagnostics.File_change_detected_Starting_incremental_compilation.code
+      ];
+      noopFileWatcher = { close: noop };
+      returnNoopFileWatcher = () => noopFileWatcher;
+      WatchType = {
+        ConfigFile: "Config file",
+        ExtendedConfigFile: "Extended config file",
+        SourceFile: "Source file",
+        MissingFile: "Missing file",
+        WildcardDirectory: "Wild card directory",
+        FailedLookupLocations: "Failed Lookup Locations",
+        AffectingFileLocation: "File location affecting resolution",
+        TypeRoots: "Type roots",
+        ConfigFileOfReferencedProject: "Config file of referened project",
+        ExtendedConfigOfReferencedProject: "Extended config file of referenced project",
+        WildcardDirectoryOfReferencedProject: "Wild card directory of referenced project",
+        PackageJson: "package.json file",
+        ClosedScriptInfo: "Closed Script info",
+        ConfigFileForInferredRoot: "Config file for the inferred project root",
+        NodeModules: "node_modules for closed script infos and package.jsons affecting module specifier cache",
+        MissingSourceMapFile: "Missing source map file",
+        NoopConfigFileForInferredRoot: "Noop Config file for the inferred project root",
+        MissingGeneratedFile: "Missing generated file",
+        NodeModulesForModuleSpecifierCache: "node_modules for module specifier cache invalidation",
+        TypingInstallerLocationFile: "File location for typing installer",
+        TypingInstallerLocationDirectory: "Directory location for typing installer"
+      };
     }
-    function getResolvedTypeReferenceDirective2(resolution) {
-      return resolution.resolvedTypeReferenceDirective;
+  });
+
+  // src/compiler/watchPublic.ts
+  function readBuilderProgram(compilerOptions, host) {
+    const buildInfoPath = getTsBuildInfoEmitOutputFilePath(compilerOptions);
+    if (!buildInfoPath)
+      return void 0;
+    let buildInfo;
+    if (host.getBuildInfo) {
+      buildInfo = host.getBuildInfo(buildInfoPath, compilerOptions.configFilePath);
+    } else {
+      const content = host.readFile(buildInfoPath);
+      if (!content)
+        return void 0;
+      buildInfo = getBuildInfo(buildInfoPath, content);
     }
-    function clear2() {
-      clearMap(directoryWatchesOfFailedLookups, closeFileWatcherOf);
-      clearMap(fileWatchesOfAffectingLocations, closeFileWatcherOf);
-      nonRelativeExternalModuleResolutions.clear();
-      closeTypeRootsWatch();
-      resolvedModuleNames.clear();
-      resolvedTypeReferenceDirectives.clear();
-      resolvedFileToResolution.clear();
-      resolutionsWithFailedLookups.clear();
-      resolutionsWithOnlyAffectingLocations.clear();
-      failedLookupChecks = void 0;
-      startsWithPathChecks = void 0;
-      isInDirectoryChecks = void 0;
-      affectingPathChecks = void 0;
-      affectingPathChecksForFile = void 0;
-      allModuleAndTypeResolutionsAreInvalidated = false;
-      moduleResolutionCache.clear();
-      typeReferenceDirectiveResolutionCache.clear();
-      moduleResolutionCache.update(resolutionHost.getCompilationSettings());
-      typeReferenceDirectiveResolutionCache.update(resolutionHost.getCompilationSettings());
-      libraryResolutionCache.clear();
-      impliedFormatPackageJsons.clear();
-      resolvedLibraries.clear();
-      hasChangedAutomaticTypeDirectiveNames = false;
+    if (!buildInfo || buildInfo.version !== version || !buildInfo.program)
+      return void 0;
+    return createBuilderProgramUsingProgramBuildInfo(buildInfo, buildInfoPath, host);
+  }
+  function createIncrementalCompilerHost(options, system = sys) {
+    const host = createCompilerHostWorker(
+      options,
+      /*setParentNodes*/
+      void 0,
+      system
+    );
+    host.createHash = maybeBind(system, system.createHash);
+    host.storeFilesChangingSignatureDuringEmit = system.storeFilesChangingSignatureDuringEmit;
+    setGetSourceFileAsHashVersioned(host);
+    changeCompilerHostLikeToUseCache(host, (fileName) => toPath(fileName, host.getCurrentDirectory(), host.getCanonicalFileName));
+    return host;
+  }
+  function createIncrementalProgram({
+    rootNames,
+    options,
+    configFileParsingDiagnostics,
+    projectReferences,
+    host,
+    createProgram: createProgram2
+  }) {
+    host = host || createIncrementalCompilerHost(options);
+    createProgram2 = createProgram2 || createEmitAndSemanticDiagnosticsBuilderProgram;
+    const oldProgram = readBuilderProgram(options, host);
+    return createProgram2(rootNames, options, host, oldProgram, configFileParsingDiagnostics, projectReferences);
+  }
+  function createWatchCompilerHost2(rootFilesOrConfigFileName, options, system, createProgram2, reportDiagnostic, reportWatchStatus2, projectReferencesOrWatchOptionsToExtend, watchOptionsOrExtraFileExtensions) {
+    if (isArray(rootFilesOrConfigFileName)) {
+      return createWatchCompilerHostOfFilesAndCompilerOptions({
+        rootFiles: rootFilesOrConfigFileName,
+        options,
+        watchOptions: watchOptionsOrExtraFileExtensions,
+        projectReferences: projectReferencesOrWatchOptionsToExtend,
+        system,
+        createProgram: createProgram2,
+        reportDiagnostic,
+        reportWatchStatus: reportWatchStatus2
+      });
+    } else {
+      return createWatchCompilerHostOfConfigFile({
+        configFileName: rootFilesOrConfigFileName,
+        optionsToExtend: options,
+        watchOptionsToExtend: projectReferencesOrWatchOptionsToExtend,
+        extraFileExtensions: watchOptionsOrExtraFileExtensions,
+        system,
+        createProgram: createProgram2,
+        reportDiagnostic,
+        reportWatchStatus: reportWatchStatus2
+      });
     }
-    function onChangesAffectModuleResolution() {
-      allModuleAndTypeResolutionsAreInvalidated = true;
-      moduleResolutionCache.clearAllExceptPackageJsonInfoCache();
-      typeReferenceDirectiveResolutionCache.clearAllExceptPackageJsonInfoCache();
-      moduleResolutionCache.update(resolutionHost.getCompilationSettings());
-      typeReferenceDirectiveResolutionCache.update(resolutionHost.getCompilationSettings());
+  }
+  function createWatchProgram(host) {
+    let builderProgram;
+    let updateLevel;
+    let missingFilesMap;
+    let watchedWildcardDirectories;
+    let timerToUpdateProgram;
+    let timerToInvalidateFailedLookupResolutions;
+    let parsedConfigs;
+    let sharedExtendedConfigFileWatchers;
+    let extendedConfigCache = host.extendedConfigCache;
+    let reportFileChangeDetectedOnCreateProgram = false;
+    const sourceFilesCache = /* @__PURE__ */ new Map();
+    let missingFilePathsRequestedForRelease;
+    let hasChangedCompilerOptions = false;
+    const useCaseSensitiveFileNames2 = host.useCaseSensitiveFileNames();
+    const currentDirectory = host.getCurrentDirectory();
+    const { configFileName, optionsToExtend: optionsToExtendForConfigFile = {}, watchOptionsToExtend, extraFileExtensions, createProgram: createProgram2 } = host;
+    let { rootFiles: rootFileNames, options: compilerOptions, watchOptions, projectReferences } = host;
+    let wildcardDirectories;
+    let configFileParsingDiagnostics;
+    let canConfigFileJsonReportNoInputFiles = false;
+    let hasChangedConfigFileParsingErrors = false;
+    const cachedDirectoryStructureHost = configFileName === void 0 ? void 0 : createCachedDirectoryStructureHost(host, currentDirectory, useCaseSensitiveFileNames2);
+    const directoryStructureHost = cachedDirectoryStructureHost || host;
+    const parseConfigFileHost = parseConfigHostFromCompilerHostLike(host, directoryStructureHost);
+    let newLine = updateNewLine();
+    if (configFileName && host.configFileParsingResult) {
+      setConfigFileParsingResult(host.configFileParsingResult);
+      newLine = updateNewLine();
     }
-    function startRecordingFilesWithChangedResolutions() {
-      filesWithChangedSetOfUnresolvedImports = [];
+    reportWatchDiagnostic(Diagnostics.Starting_compilation_in_watch_mode);
+    if (configFileName && !host.configFileParsingResult) {
+      newLine = getNewLineCharacter(optionsToExtendForConfigFile);
+      Debug.assert(!rootFileNames);
+      parseConfigFile2();
+      newLine = updateNewLine();
     }
-    function finishRecordingFilesWithChangedResolutions() {
-      const collected = filesWithChangedSetOfUnresolvedImports;
-      filesWithChangedSetOfUnresolvedImports = void 0;
-      return collected;
+    Debug.assert(compilerOptions);
+    Debug.assert(rootFileNames);
+    const { watchFile: watchFile2, watchDirectory, writeLog } = createWatchFactory(host, compilerOptions);
+    const getCanonicalFileName = createGetCanonicalFileName(useCaseSensitiveFileNames2);
+    writeLog(`Current directory: ${currentDirectory} CaseSensitiveFileNames: ${useCaseSensitiveFileNames2}`);
+    let configFileWatcher;
+    if (configFileName) {
+      configFileWatcher = watchFile2(configFileName, scheduleProgramReload, 2e3 /* High */, watchOptions, WatchType.ConfigFile);
     }
-    function isFileWithInvalidatedNonRelativeUnresolvedImports(path) {
-      if (!filesWithInvalidatedNonRelativeUnresolvedImports) {
-        return false;
-      }
-      const value = filesWithInvalidatedNonRelativeUnresolvedImports.get(path);
-      return !!value && !!value.length;
+    let pnpFileWatcher;
+    const pnpApiPath = getPnpApiPath(__filename);
+    if (pnpApiPath) {
+      pnpFileWatcher = watchFile2(pnpApiPath, scheduleResolutionReload, 2e3 /* High */, watchOptions, WatchType.ConfigFile);
     }
-    function createHasInvalidatedResolutions(customHasInvalidatedResolutions, customHasInvalidatedLibResolutions) {
-      invalidateResolutionsOfFailedLookupLocations();
-      const collected = filesWithInvalidatedResolutions;
-      filesWithInvalidatedResolutions = void 0;
-      return {
-        hasInvalidatedResolutions: (path) => customHasInvalidatedResolutions(path) || allModuleAndTypeResolutionsAreInvalidated || !!(collected == null ? void 0 : collected.has(path)) || isFileWithInvalidatedNonRelativeUnresolvedImports(path),
-        hasInvalidatedLibResolutions: (libFileName) => {
-          var _a;
-          return customHasInvalidatedLibResolutions(libFileName) || !!((_a = resolvedLibraries == null ? void 0 : resolvedLibraries.get(libFileName)) == null ? void 0 : _a.isInvalidated);
-        }
-      };
+    const compilerHost = createCompilerHostFromProgramHost(host, () => compilerOptions, directoryStructureHost);
+    setGetSourceFileAsHashVersioned(compilerHost);
+    const getNewSourceFile = compilerHost.getSourceFile;
+    compilerHost.getSourceFile = (fileName, ...args) => getVersionedSourceFileByPath(fileName, toPath3(fileName), ...args);
+    compilerHost.getSourceFileByPath = getVersionedSourceFileByPath;
+    compilerHost.getNewLine = () => newLine;
+    compilerHost.fileExists = fileExists;
+    compilerHost.onReleaseOldSourceFile = onReleaseOldSourceFile;
+    compilerHost.onReleaseParsedCommandLine = onReleaseParsedCommandLine;
+    compilerHost.toPath = toPath3;
+    compilerHost.getCompilationSettings = () => compilerOptions;
+    compilerHost.useSourceOfProjectReferenceRedirect = maybeBind(host, host.useSourceOfProjectReferenceRedirect);
+    compilerHost.watchDirectoryOfFailedLookupLocation = (dir, cb, flags) => watchDirectory(dir, cb, flags, watchOptions, WatchType.FailedLookupLocations);
+    compilerHost.watchAffectingFileLocation = (file, cb) => watchFile2(file, cb, 2e3 /* High */, watchOptions, WatchType.AffectingFileLocation);
+    compilerHost.watchTypeRootsDirectory = (dir, cb, flags) => watchDirectory(dir, cb, flags, watchOptions, WatchType.TypeRoots);
+    compilerHost.getCachedDirectoryStructureHost = () => cachedDirectoryStructureHost;
+    compilerHost.scheduleInvalidateResolutionsOfFailedLookupLocations = scheduleInvalidateResolutionsOfFailedLookupLocations;
+    compilerHost.onInvalidatedResolution = scheduleProgramUpdate;
+    compilerHost.onChangedAutomaticTypeDirectiveNames = scheduleProgramUpdate;
+    compilerHost.fileIsOpen = returnFalse;
+    compilerHost.getCurrentProgram = getCurrentProgram;
+    compilerHost.writeLog = writeLog;
+    compilerHost.getParsedCommandLine = getParsedCommandLine;
+    const resolutionCache = createResolutionCache(
+      compilerHost,
+      configFileName ? getDirectoryPath(getNormalizedAbsolutePath(configFileName, currentDirectory)) : currentDirectory,
+      /*logChangesWhenResolvingModule*/
+      false
+    );
+    compilerHost.resolveModuleNameLiterals = maybeBind(host, host.resolveModuleNameLiterals);
+    compilerHost.resolveModuleNames = maybeBind(host, host.resolveModuleNames);
+    if (!compilerHost.resolveModuleNameLiterals && !compilerHost.resolveModuleNames) {
+      compilerHost.resolveModuleNameLiterals = resolutionCache.resolveModuleNameLiterals.bind(resolutionCache);
     }
-    function startCachingPerDirectoryResolution() {
-      moduleResolutionCache.clearAllExceptPackageJsonInfoCache();
-      typeReferenceDirectiveResolutionCache.clearAllExceptPackageJsonInfoCache();
-      libraryResolutionCache.clearAllExceptPackageJsonInfoCache();
-      nonRelativeExternalModuleResolutions.forEach(watchFailedLookupLocationOfNonRelativeModuleResolutions);
-      nonRelativeExternalModuleResolutions.clear();
+    compilerHost.resolveTypeReferenceDirectiveReferences = maybeBind(host, host.resolveTypeReferenceDirectiveReferences);
+    compilerHost.resolveTypeReferenceDirectives = maybeBind(host, host.resolveTypeReferenceDirectives);
+    if (!compilerHost.resolveTypeReferenceDirectiveReferences && !compilerHost.resolveTypeReferenceDirectives) {
+      compilerHost.resolveTypeReferenceDirectiveReferences = resolutionCache.resolveTypeReferenceDirectiveReferences.bind(resolutionCache);
     }
-    function cleanupLibResolutionWatching(newProgram) {
-      resolvedLibraries.forEach((resolution, libFileName) => {
-        var _a;
-        if (!((_a = newProgram == null ? void 0 : newProgram.resolvedLibReferences) == null ? void 0 : _a.has(libFileName))) {
-          stopWatchFailedLookupLocationOfResolution(
-            resolution,
-            resolutionHost.toPath(getInferredLibraryNameResolveFrom(newProgram.getCompilerOptions(), getCurrentDirectory(), libFileName)),
-            getResolvedModule2
-          );
-          resolvedLibraries.delete(libFileName);
+    compilerHost.resolveLibrary = !host.resolveLibrary ? resolutionCache.resolveLibrary.bind(resolutionCache) : host.resolveLibrary.bind(host);
+    compilerHost.getModuleResolutionCache = host.resolveModuleNameLiterals || host.resolveModuleNames ? maybeBind(host, host.getModuleResolutionCache) : () => resolutionCache.getModuleResolutionCache();
+    const userProvidedResolution = !!host.resolveModuleNameLiterals || !!host.resolveTypeReferenceDirectiveReferences || !!host.resolveModuleNames || !!host.resolveTypeReferenceDirectives;
+    const customHasInvalidatedResolutions = userProvidedResolution ? maybeBind(host, host.hasInvalidatedResolutions) || returnTrue : returnFalse;
+    const customHasInvalidLibResolutions = host.resolveLibrary ? maybeBind(host, host.hasInvalidatedLibResolutions) || returnTrue : returnFalse;
+    builderProgram = readBuilderProgram(compilerOptions, compilerHost);
+    synchronizeProgram();
+    watchConfigFileWildCardDirectories();
+    if (configFileName)
+      updateExtendedConfigFilesWatches(toPath3(configFileName), compilerOptions, watchOptions, WatchType.ExtendedConfigFile);
+    return configFileName ? { getCurrentProgram: getCurrentBuilderProgram, getProgram: updateProgram, close, getResolutionCache } : { getCurrentProgram: getCurrentBuilderProgram, getProgram: updateProgram, updateRootFileNames, close, getResolutionCache };
+    function close() {
+      clearInvalidateResolutionsOfFailedLookupLocations();
+      resolutionCache.clear();
+      clearMap(sourceFilesCache, (value) => {
+        if (value && value.fileWatcher) {
+          value.fileWatcher.close();
+          value.fileWatcher = void 0;
         }
       });
-    }
-    function finishCachingPerDirectoryResolution(newProgram, oldProgram) {
-      filesWithInvalidatedNonRelativeUnresolvedImports = void 0;
-      allModuleAndTypeResolutionsAreInvalidated = false;
-      nonRelativeExternalModuleResolutions.forEach(watchFailedLookupLocationOfNonRelativeModuleResolutions);
-      nonRelativeExternalModuleResolutions.clear();
-      if (newProgram !== oldProgram) {
-        cleanupLibResolutionWatching(newProgram);
-        newProgram == null ? void 0 : newProgram.getSourceFiles().forEach((newFile) => {
-          var _a;
-          const expected = isExternalOrCommonJsModule(newFile) ? ((_a = newFile.packageJsonLocations) == null ? void 0 : _a.length) ?? 0 : 0;
-          const existing = impliedFormatPackageJsons.get(newFile.path) ?? emptyArray;
-          for (let i = existing.length; i < expected; i++) {
-            createFileWatcherOfAffectingLocation(
-              newFile.packageJsonLocations[i],
-              /*forResolution*/
-              false
-            );
-          }
-          if (existing.length > expected) {
-            for (let i = expected; i < existing.length; i++) {
-              fileWatchesOfAffectingLocations.get(existing[i]).files--;
-            }
-          }
-          if (expected)
-            impliedFormatPackageJsons.set(newFile.path, newFile.packageJsonLocations);
-          else
-            impliedFormatPackageJsons.delete(newFile.path);
-        });
-        impliedFormatPackageJsons.forEach((existing, path) => {
-          if (!(newProgram == null ? void 0 : newProgram.getSourceFileByPath(path))) {
-            existing.forEach((location) => fileWatchesOfAffectingLocations.get(location).files--);
-            impliedFormatPackageJsons.delete(path);
-          }
-        });
+      if (configFileWatcher) {
+        configFileWatcher.close();
+        configFileWatcher = void 0;
       }
-      directoryWatchesOfFailedLookups.forEach((watcher, path) => {
-        if (watcher.refCount === 0) {
-          directoryWatchesOfFailedLookups.delete(path);
-          watcher.watcher.close();
-        }
-      });
-      fileWatchesOfAffectingLocations.forEach((watcher, path) => {
-        if (watcher.files === 0 && watcher.resolutions === 0) {
-          fileWatchesOfAffectingLocations.delete(path);
-          watcher.watcher.close();
-        }
-      });
-      hasChangedAutomaticTypeDirectiveNames = false;
-    }
-    function resolveModuleName2(moduleName, containingFile, compilerOptions, redirectedReference, mode) {
-      var _a;
-      const host = ((_a = resolutionHost.getCompilerHost) == null ? void 0 : _a.call(resolutionHost)) || resolutionHost;
-      const primaryResult = resolveModuleName(moduleName, containingFile, compilerOptions, host, moduleResolutionCache, redirectedReference, mode);
-      if (!resolutionHost.getGlobalCache) {
-        return primaryResult;
+      if (pnpFileWatcher) {
+        pnpFileWatcher.close();
+        pnpFileWatcher = void 0;
       }
-      const globalCache = resolutionHost.getGlobalCache();
-      if (globalCache !== void 0 && !isExternalModuleNameRelative(moduleName) && !(primaryResult.resolvedModule && extensionIsTS(primaryResult.resolvedModule.extension))) {
-        const { resolvedModule, failedLookupLocations, affectingLocations, resolutionDiagnostics } = loadModuleFromGlobalCache(
-          Debug.checkDefined(resolutionHost.globalCacheResolutionModuleName)(moduleName),
-          resolutionHost.projectName,
-          compilerOptions,
-          host,
-          globalCache,
-          moduleResolutionCache
-        );
-        if (resolvedModule) {
-          primaryResult.resolvedModule = resolvedModule;
-          primaryResult.failedLookupLocations = updateResolutionField(primaryResult.failedLookupLocations, failedLookupLocations);
-          primaryResult.affectingLocations = updateResolutionField(primaryResult.affectingLocations, affectingLocations);
-          primaryResult.resolutionDiagnostics = updateResolutionField(primaryResult.resolutionDiagnostics, resolutionDiagnostics);
-          return primaryResult;
-        }
+      extendedConfigCache == null ? void 0 : extendedConfigCache.clear();
+      extendedConfigCache = void 0;
+      if (sharedExtendedConfigFileWatchers) {
+        clearMap(sharedExtendedConfigFileWatchers, closeFileWatcherOf);
+        sharedExtendedConfigFileWatchers = void 0;
       }
-      return primaryResult;
-    }
-    function createModuleResolutionLoader2(containingFile, redirectedReference, options) {
-      return {
-        nameAndMode: moduleResolutionNameAndModeGetter,
-        resolve: (moduleName, resoluionMode) => resolveModuleName2(
-          moduleName,
-          containingFile,
-          options,
-          redirectedReference,
-          resoluionMode
-        )
-      };
-    }
-    function resolveNamesWithLocalCache({
-      entries,
-      containingFile,
-      containingSourceFile,
-      redirectedReference,
-      options,
-      perFileCache,
-      reusedNames,
-      loader,
-      getResolutionWithResolvedFileName,
-      deferWatchingNonRelativeResolution,
-      shouldRetryResolution,
-      logChanges
-    }) {
-      var _a;
-      const path = resolutionHost.toPath(containingFile);
-      const resolutionsInFile = perFileCache.get(path) || perFileCache.set(path, createModeAwareCache()).get(path);
-      const resolvedModules = [];
-      const hasInvalidatedNonRelativeUnresolvedImport = logChanges && isFileWithInvalidatedNonRelativeUnresolvedImports(path);
-      const program = resolutionHost.getCurrentProgram();
-      const oldRedirect = program && program.getResolvedProjectReferenceToRedirect(containingFile);
-      const unmatchedRedirects = oldRedirect ? !redirectedReference || redirectedReference.sourceFile.path !== oldRedirect.sourceFile.path : !!redirectedReference;
-      const seenNamesInFile = createModeAwareCache();
-      for (const entry of entries) {
-        const name = loader.nameAndMode.getName(entry);
-        const mode = loader.nameAndMode.getMode(entry, containingSourceFile);
-        let resolution = resolutionsInFile.get(name, mode);
-        if (!seenNamesInFile.has(name, mode) && (allModuleAndTypeResolutionsAreInvalidated || unmatchedRedirects || !resolution || resolution.isInvalidated || // If the name is unresolved import that was invalidated, recalculate
-        hasInvalidatedNonRelativeUnresolvedImport && !isExternalModuleNameRelative(name) && shouldRetryResolution(resolution))) {
-          const existingResolution = resolution;
-          resolution = loader.resolve(name, mode);
-          if (resolutionHost.onDiscoveredSymlink && resolutionIsSymlink(resolution)) {
-            resolutionHost.onDiscoveredSymlink();
-          }
-          resolutionsInFile.set(name, mode, resolution);
-          watchFailedLookupLocationsOfExternalModuleResolutions(name, resolution, path, getResolutionWithResolvedFileName, deferWatchingNonRelativeResolution);
-          if (existingResolution) {
-            stopWatchFailedLookupLocationOfResolution(existingResolution, path, getResolutionWithResolvedFileName);
-          }
-          if (logChanges && filesWithChangedSetOfUnresolvedImports && !resolutionIsEqualTo(existingResolution, resolution)) {
-            filesWithChangedSetOfUnresolvedImports.push(path);
-            logChanges = false;
-          }
-        } else {
-          const host = ((_a = resolutionHost.getCompilerHost) == null ? void 0 : _a.call(resolutionHost)) || resolutionHost;
-          if (isTraceEnabled(options, host) && !seenNamesInFile.has(name, mode)) {
-            const resolved = getResolutionWithResolvedFileName(resolution);
-            trace(
-              host,
-              perFileCache === resolvedModuleNames ? (resolved == null ? void 0 : resolved.resolvedFileName) ? resolved.packageId ? Diagnostics.Reusing_resolution_of_module_0_from_1_of_old_program_it_was_successfully_resolved_to_2_with_Package_ID_3 : Diagnostics.Reusing_resolution_of_module_0_from_1_of_old_program_it_was_successfully_resolved_to_2 : Diagnostics.Reusing_resolution_of_module_0_from_1_of_old_program_it_was_not_resolved : (resolved == null ? void 0 : resolved.resolvedFileName) ? resolved.packageId ? Diagnostics.Reusing_resolution_of_type_reference_directive_0_from_1_of_old_program_it_was_successfully_resolved_to_2_with_Package_ID_3 : Diagnostics.Reusing_resolution_of_type_reference_directive_0_from_1_of_old_program_it_was_successfully_resolved_to_2 : Diagnostics.Reusing_resolution_of_type_reference_directive_0_from_1_of_old_program_it_was_not_resolved,
-              name,
-              containingFile,
-              resolved == null ? void 0 : resolved.resolvedFileName,
-              (resolved == null ? void 0 : resolved.packageId) && packageIdToString(resolved.packageId)
-            );
-          }
-        }
-        Debug.assert(resolution !== void 0 && !resolution.isInvalidated);
-        seenNamesInFile.set(name, mode, true);
-        resolvedModules.push(resolution);
+      if (watchedWildcardDirectories) {
+        clearMap(watchedWildcardDirectories, closeFileWatcherOf);
+        watchedWildcardDirectories = void 0;
       }
-      reusedNames == null ? void 0 : reusedNames.forEach((entry) => seenNamesInFile.set(
-        loader.nameAndMode.getName(entry),
-        loader.nameAndMode.getMode(entry, containingSourceFile),
-        true
-      ));
-      if (resolutionsInFile.size() !== seenNamesInFile.size()) {
-        resolutionsInFile.forEach((resolution, name, mode) => {
-          if (!seenNamesInFile.has(name, mode)) {
-            stopWatchFailedLookupLocationOfResolution(resolution, path, getResolutionWithResolvedFileName);
-            resolutionsInFile.delete(name, mode);
-          }
-        });
+      if (missingFilesMap) {
+        clearMap(missingFilesMap, closeFileWatcher);
+        missingFilesMap = void 0;
       }
-      return resolvedModules;
-      function resolutionIsEqualTo(oldResolution, newResolution) {
-        if (oldResolution === newResolution) {
-          return true;
-        }
-        if (!oldResolution || !newResolution) {
-          return false;
-        }
-        const oldResult = getResolutionWithResolvedFileName(oldResolution);
-        const newResult = getResolutionWithResolvedFileName(newResolution);
-        if (oldResult === newResult) {
-          return true;
-        }
-        if (!oldResult || !newResult) {
-          return false;
-        }
-        return oldResult.resolvedFileName === newResult.resolvedFileName;
+      if (parsedConfigs) {
+        clearMap(parsedConfigs, (config) => {
+          var _a;
+          (_a = config.watcher) == null ? void 0 : _a.close();
+          config.watcher = void 0;
+          if (config.watchedDirectories)
+            clearMap(config.watchedDirectories, closeFileWatcherOf);
+          config.watchedDirectories = void 0;
+        });
+        parsedConfigs = void 0;
       }
     }
-    function resolveTypeReferenceDirectiveReferences(typeDirectiveReferences, containingFile, redirectedReference, options, containingSourceFile, reusedNames) {
-      var _a;
-      return resolveNamesWithLocalCache({
-        entries: typeDirectiveReferences,
-        containingFile,
-        containingSourceFile,
-        redirectedReference,
-        options,
-        reusedNames,
-        perFileCache: resolvedTypeReferenceDirectives,
-        loader: createTypeReferenceResolutionLoader(
-          containingFile,
-          redirectedReference,
-          options,
-          ((_a = resolutionHost.getCompilerHost) == null ? void 0 : _a.call(resolutionHost)) || resolutionHost,
-          typeReferenceDirectiveResolutionCache
-        ),
-        getResolutionWithResolvedFileName: getResolvedTypeReferenceDirective2,
-        shouldRetryResolution: (resolution) => resolution.resolvedTypeReferenceDirective === void 0,
-        deferWatchingNonRelativeResolution: false
-      });
+    function getResolutionCache() {
+      return resolutionCache;
     }
-    function resolveModuleNameLiterals(moduleLiterals, containingFile, redirectedReference, options, containingSourceFile, reusedNames) {
-      return resolveNamesWithLocalCache({
-        entries: moduleLiterals,
-        containingFile,
-        containingSourceFile,
-        redirectedReference,
-        options,
-        reusedNames,
-        perFileCache: resolvedModuleNames,
-        loader: createModuleResolutionLoader2(
-          containingFile,
-          redirectedReference,
-          options
-        ),
-        getResolutionWithResolvedFileName: getResolvedModule2,
-        shouldRetryResolution: (resolution) => !resolution.resolvedModule || !resolutionExtensionIsTSOrJson(resolution.resolvedModule.extension),
-        logChanges: logChangesWhenResolvingModule,
-        deferWatchingNonRelativeResolution: true
-        // Defer non relative resolution watch because we could be using ambient modules
-      });
+    function getCurrentBuilderProgram() {
+      return builderProgram;
     }
-    function resolveLibrary2(libraryName, resolveFrom, options, libFileName) {
-      var _a;
-      const host = ((_a = resolutionHost.getCompilerHost) == null ? void 0 : _a.call(resolutionHost)) || resolutionHost;
-      let resolution = resolvedLibraries == null ? void 0 : resolvedLibraries.get(libFileName);
-      if (!resolution || resolution.isInvalidated) {
-        const existingResolution = resolution;
-        resolution = resolveLibrary(libraryName, resolveFrom, options, host, libraryResolutionCache);
-        const path = resolutionHost.toPath(resolveFrom);
-        watchFailedLookupLocationsOfExternalModuleResolutions(
-          libraryName,
-          resolution,
-          path,
-          getResolvedModule2,
-          /*deferWatchingNonRelativeResolution*/
-          false
-        );
-        resolvedLibraries.set(libFileName, resolution);
-        if (existingResolution) {
-          stopWatchFailedLookupLocationOfResolution(existingResolution, path, getResolvedModule2);
+    function getCurrentProgram() {
+      return builderProgram && builderProgram.getProgramOrUndefined();
+    }
+    function synchronizeProgram(forceAllFilesAsInvalidated = false) {
+      writeLog(`Synchronizing program`);
+      Debug.assert(compilerOptions);
+      Debug.assert(rootFileNames);
+      clearInvalidateResolutionsOfFailedLookupLocations();
+      const program = getCurrentBuilderProgram();
+      if (hasChangedCompilerOptions) {
+        newLine = updateNewLine();
+        if (program && changesAffectModuleResolution(program.getCompilerOptions(), compilerOptions)) {
+          resolutionCache.onChangesAffectModuleResolution();
         }
-      } else {
-        if (isTraceEnabled(options, host)) {
-          const resolved = getResolvedModule2(resolution);
-          trace(
-            host,
-            (resolved == null ? void 0 : resolved.resolvedFileName) ? resolved.packageId ? Diagnostics.Reusing_resolution_of_module_0_from_1_of_old_program_it_was_successfully_resolved_to_2_with_Package_ID_3 : Diagnostics.Reusing_resolution_of_module_0_from_1_of_old_program_it_was_successfully_resolved_to_2 : Diagnostics.Reusing_resolution_of_module_0_from_1_of_old_program_it_was_not_resolved,
-            libraryName,
-            resolveFrom,
-            resolved == null ? void 0 : resolved.resolvedFileName,
-            (resolved == null ? void 0 : resolved.packageId) && packageIdToString(resolved.packageId)
+      }
+      const { hasInvalidatedResolutions, hasInvalidatedLibResolutions } = resolutionCache.createHasInvalidatedResolutions(forceAllFilesAsInvalidated ? returnTrue : customHasInvalidatedResolutions, customHasInvalidLibResolutions);
+      const {
+        originalReadFile,
+        originalFileExists,
+        originalDirectoryExists,
+        originalCreateDirectory,
+        originalWriteFile,
+        readFileWithCache
+      } = changeCompilerHostLikeToUseCache(compilerHost, toPath3);
+      if (isProgramUptoDate(getCurrentProgram(), rootFileNames, compilerOptions, (path) => getSourceVersion(path, readFileWithCache), (fileName) => compilerHost.fileExists(fileName), hasInvalidatedResolutions, hasInvalidatedLibResolutions, hasChangedAutomaticTypeDirectiveNames, getParsedCommandLine, projectReferences)) {
+        if (hasChangedConfigFileParsingErrors) {
+          if (reportFileChangeDetectedOnCreateProgram) {
+            reportWatchDiagnostic(Diagnostics.File_change_detected_Starting_incremental_compilation);
+          }
+          builderProgram = createProgram2(
+            /*rootNames*/
+            void 0,
+            /*options*/
+            void 0,
+            compilerHost,
+            builderProgram,
+            configFileParsingDiagnostics,
+            projectReferences
           );
+          hasChangedConfigFileParsingErrors = false;
+        }
+      } else {
+        if (reportFileChangeDetectedOnCreateProgram) {
+          reportWatchDiagnostic(Diagnostics.File_change_detected_Starting_incremental_compilation);
         }
+        createNewProgram(hasInvalidatedResolutions, hasInvalidatedLibResolutions);
       }
-      return resolution;
+      reportFileChangeDetectedOnCreateProgram = false;
+      if (host.afterProgramCreate && program !== builderProgram) {
+        host.afterProgramCreate(builderProgram);
+      }
+      compilerHost.readFile = originalReadFile;
+      compilerHost.fileExists = originalFileExists;
+      compilerHost.directoryExists = originalDirectoryExists;
+      compilerHost.createDirectory = originalCreateDirectory;
+      compilerHost.writeFile = originalWriteFile;
+      return builderProgram;
     }
-    function resolveSingleModuleNameWithoutWatching(moduleName, containingFile) {
-      const path = resolutionHost.toPath(containingFile);
-      const resolutionsInFile = resolvedModuleNames.get(path);
-      const resolution = resolutionsInFile == null ? void 0 : resolutionsInFile.get(
-        moduleName,
-        /*mode*/
-        void 0
-      );
-      if (resolution && !resolution.isInvalidated)
-        return resolution;
-      return resolveModuleName2(moduleName, containingFile, resolutionHost.getCompilationSettings());
+    function createNewProgram(hasInvalidatedResolutions, hasInvalidatedLibResolutions) {
+      writeLog("CreatingProgramWith::");
+      writeLog(`  roots: ${JSON.stringify(rootFileNames)}`);
+      writeLog(`  options: ${JSON.stringify(compilerOptions)}`);
+      if (projectReferences)
+        writeLog(`  projectReferences: ${JSON.stringify(projectReferences)}`);
+      const needsUpdateInTypeRootWatch = hasChangedCompilerOptions || !getCurrentProgram();
+      hasChangedCompilerOptions = false;
+      hasChangedConfigFileParsingErrors = false;
+      resolutionCache.startCachingPerDirectoryResolution();
+      compilerHost.hasInvalidatedResolutions = hasInvalidatedResolutions;
+      compilerHost.hasInvalidatedLibResolutions = hasInvalidatedLibResolutions;
+      compilerHost.hasChangedAutomaticTypeDirectiveNames = hasChangedAutomaticTypeDirectiveNames;
+      const oldProgram = getCurrentProgram();
+      builderProgram = createProgram2(rootFileNames, compilerOptions, compilerHost, builderProgram, configFileParsingDiagnostics, projectReferences);
+      resolutionCache.finishCachingPerDirectoryResolution(builderProgram.getProgram(), oldProgram);
+      updateMissingFilePathsWatch(builderProgram.getProgram(), missingFilesMap || (missingFilesMap = /* @__PURE__ */ new Map()), watchMissingFilePath);
+      if (needsUpdateInTypeRootWatch) {
+        resolutionCache.updateTypeRootsWatch();
+      }
+      if (missingFilePathsRequestedForRelease) {
+        for (const missingFilePath of missingFilePathsRequestedForRelease) {
+          if (!missingFilesMap.has(missingFilePath)) {
+            sourceFilesCache.delete(missingFilePath);
+          }
+        }
+        missingFilePathsRequestedForRelease = void 0;
+      }
     }
-    function isNodeModulesAtTypesDirectory(dirPath) {
-      return endsWith(dirPath, "/node_modules/@types");
+    function updateRootFileNames(files) {
+      Debug.assert(!configFileName, "Cannot update root file names with config file watch mode");
+      rootFileNames = files;
+      scheduleProgramUpdate();
     }
-    function watchFailedLookupLocationsOfExternalModuleResolutions(name, resolution, filePath, getResolutionWithResolvedFileName, deferWatchingNonRelativeResolution) {
-      var _a;
-      if (resolution.refCount) {
-        resolution.refCount++;
-        Debug.assertIsDefined(resolution.files);
-      } else {
-        resolution.refCount = 1;
-        Debug.assert(!((_a = resolution.files) == null ? void 0 : _a.size));
-        if (!deferWatchingNonRelativeResolution || isExternalModuleNameRelative(name)) {
-          watchFailedLookupLocationOfResolution(resolution);
+    function updateNewLine() {
+      return getNewLineCharacter(compilerOptions || optionsToExtendForConfigFile);
+    }
+    function toPath3(fileName) {
+      return toPath(fileName, currentDirectory, getCanonicalFileName);
+    }
+    function isFileMissingOnHost(hostSourceFile) {
+      return typeof hostSourceFile === "boolean";
+    }
+    function isFilePresenceUnknownOnHost(hostSourceFile) {
+      return typeof hostSourceFile.version === "boolean";
+    }
+    function fileExists(fileName) {
+      const path = toPath3(fileName);
+      if (isFileMissingOnHost(sourceFilesCache.get(path))) {
+        return false;
+      }
+      return directoryStructureHost.fileExists(fileName);
+    }
+    function getVersionedSourceFileByPath(fileName, path, languageVersionOrOptions, onError, shouldCreateNewSourceFile) {
+      const hostSourceFile = sourceFilesCache.get(path);
+      if (isFileMissingOnHost(hostSourceFile)) {
+        return void 0;
+      }
+      const impliedNodeFormat = typeof languageVersionOrOptions === "object" ? languageVersionOrOptions.impliedNodeFormat : void 0;
+      if (hostSourceFile === void 0 || shouldCreateNewSourceFile || isFilePresenceUnknownOnHost(hostSourceFile) || hostSourceFile.sourceFile.impliedNodeFormat !== impliedNodeFormat) {
+        const sourceFile = getNewSourceFile(fileName, languageVersionOrOptions, onError);
+        if (hostSourceFile) {
+          if (sourceFile) {
+            hostSourceFile.sourceFile = sourceFile;
+            hostSourceFile.version = sourceFile.version;
+            if (!hostSourceFile.fileWatcher) {
+              hostSourceFile.fileWatcher = watchFilePath(path, fileName, onSourceFileChange, 250 /* Low */, watchOptions, WatchType.SourceFile);
+            }
+          } else {
+            if (hostSourceFile.fileWatcher) {
+              hostSourceFile.fileWatcher.close();
+            }
+            sourceFilesCache.set(path, false);
+          }
         } else {
-          nonRelativeExternalModuleResolutions.add(name, resolution);
-        }
-        const resolved = getResolutionWithResolvedFileName(resolution);
-        if (resolved && resolved.resolvedFileName) {
-          const key = resolutionHost.toPath(resolved.resolvedFileName);
-          let resolutions = resolvedFileToResolution.get(key);
-          if (!resolutions)
-            resolvedFileToResolution.set(key, resolutions = /* @__PURE__ */ new Set());
-          resolutions.add(resolution);
+          if (sourceFile) {
+            const fileWatcher = watchFilePath(path, fileName, onSourceFileChange, 250 /* Low */, watchOptions, WatchType.SourceFile);
+            sourceFilesCache.set(path, { sourceFile, version: sourceFile.version, fileWatcher });
+          } else {
+            sourceFilesCache.set(path, false);
+          }
         }
+        return sourceFile;
       }
-      (resolution.files ?? (resolution.files = /* @__PURE__ */ new Set())).add(filePath);
+      return hostSourceFile.sourceFile;
     }
-    function watchFailedLookupLocation(failedLookupLocation, setAtRoot) {
-      const failedLookupLocationPath = resolutionHost.toPath(failedLookupLocation);
-      const toWatch = getDirectoryToWatchFailedLookupLocation(
-        failedLookupLocation,
-        failedLookupLocationPath,
-        rootDir,
-        rootPath,
-        rootPathComponents,
-        getCurrentDirectory
-      );
-      if (toWatch) {
-        const { dir, dirPath, nonRecursive } = toWatch;
-        if (dirPath === rootPath) {
-          Debug.assert(nonRecursive);
-          setAtRoot = true;
+    function nextSourceFileVersion(path) {
+      const hostSourceFile = sourceFilesCache.get(path);
+      if (hostSourceFile !== void 0) {
+        if (isFileMissingOnHost(hostSourceFile)) {
+          sourceFilesCache.set(path, { version: false });
         } else {
-          setDirectoryWatcher(dir, dirPath, nonRecursive);
+          hostSourceFile.version = false;
         }
       }
-      return setAtRoot;
     }
-    function watchFailedLookupLocationOfResolution(resolution) {
-      Debug.assert(!!resolution.refCount);
-      const { failedLookupLocations, affectingLocations, node10Result } = resolution;
-      if (!(failedLookupLocations == null ? void 0 : failedLookupLocations.length) && !(affectingLocations == null ? void 0 : affectingLocations.length) && !node10Result)
-        return;
-      if ((failedLookupLocations == null ? void 0 : failedLookupLocations.length) || node10Result)
-        resolutionsWithFailedLookups.add(resolution);
-      let setAtRoot = false;
-      if (failedLookupLocations) {
-        for (const failedLookupLocation of failedLookupLocations) {
-          setAtRoot = watchFailedLookupLocation(failedLookupLocation, setAtRoot);
+    function getSourceVersion(path, readFileWithCache) {
+      const hostSourceFile = sourceFilesCache.get(path);
+      if (!hostSourceFile)
+        return void 0;
+      if (hostSourceFile.version)
+        return hostSourceFile.version;
+      const text = readFileWithCache(path);
+      return text !== void 0 ? getSourceFileVersionAsHashFromText(compilerHost, text) : void 0;
+    }
+    function onReleaseOldSourceFile(oldSourceFile, _oldOptions, hasSourceFileByPath) {
+      const hostSourceFileInfo = sourceFilesCache.get(oldSourceFile.resolvedPath);
+      if (hostSourceFileInfo !== void 0) {
+        if (isFileMissingOnHost(hostSourceFileInfo)) {
+          (missingFilePathsRequestedForRelease || (missingFilePathsRequestedForRelease = [])).push(oldSourceFile.path);
+        } else if (hostSourceFileInfo.sourceFile === oldSourceFile) {
+          if (hostSourceFileInfo.fileWatcher) {
+            hostSourceFileInfo.fileWatcher.close();
+          }
+          sourceFilesCache.delete(oldSourceFile.resolvedPath);
+          if (!hasSourceFileByPath) {
+            resolutionCache.removeResolutionsOfFile(oldSourceFile.path);
+          }
         }
       }
-      if (node10Result)
-        setAtRoot = watchFailedLookupLocation(node10Result, setAtRoot);
-      if (setAtRoot) {
-        setDirectoryWatcher(
-          rootDir,
-          rootPath,
-          /*nonRecursive*/
-          true
-        );
+    }
+    function reportWatchDiagnostic(message) {
+      if (host.onWatchStatusChange) {
+        host.onWatchStatusChange(createCompilerDiagnostic(message), newLine, compilerOptions || optionsToExtendForConfigFile);
       }
-      watchAffectingLocationsOfResolution(resolution, !(failedLookupLocations == null ? void 0 : failedLookupLocations.length) && !node10Result);
     }
-    function watchAffectingLocationsOfResolution(resolution, addToResolutionsWithOnlyAffectingLocations) {
-      Debug.assert(!!resolution.refCount);
-      const { affectingLocations } = resolution;
-      if (!(affectingLocations == null ? void 0 : affectingLocations.length))
-        return;
-      if (addToResolutionsWithOnlyAffectingLocations)
-        resolutionsWithOnlyAffectingLocations.add(resolution);
-      for (const affectingLocation of affectingLocations) {
-        createFileWatcherOfAffectingLocation(
-          affectingLocation,
-          /*forResolution*/
-          true
-        );
+    function hasChangedAutomaticTypeDirectiveNames() {
+      return resolutionCache.hasChangedAutomaticTypeDirectiveNames();
+    }
+    function clearInvalidateResolutionsOfFailedLookupLocations() {
+      if (!timerToInvalidateFailedLookupResolutions)
+        return false;
+      host.clearTimeout(timerToInvalidateFailedLookupResolutions);
+      timerToInvalidateFailedLookupResolutions = void 0;
+      return true;
+    }
+    function scheduleInvalidateResolutionsOfFailedLookupLocations() {
+      if (!host.setTimeout || !host.clearTimeout) {
+        return resolutionCache.invalidateResolutionsOfFailedLookupLocations();
       }
+      const pending = clearInvalidateResolutionsOfFailedLookupLocations();
+      writeLog(`Scheduling invalidateFailedLookup${pending ? ", Cancelled earlier one" : ""}`);
+      timerToInvalidateFailedLookupResolutions = host.setTimeout(invalidateResolutionsOfFailedLookup, 250, "timerToInvalidateFailedLookupResolutions");
     }
-    function createFileWatcherOfAffectingLocation(affectingLocation, forResolution) {
-      const fileWatcher = fileWatchesOfAffectingLocations.get(affectingLocation);
-      if (fileWatcher) {
-        if (forResolution)
-          fileWatcher.resolutions++;
-        else
-          fileWatcher.files++;
+    function invalidateResolutionsOfFailedLookup() {
+      timerToInvalidateFailedLookupResolutions = void 0;
+      if (resolutionCache.invalidateResolutionsOfFailedLookupLocations()) {
+        scheduleProgramUpdate();
+      }
+    }
+    function scheduleProgramUpdate() {
+      if (!host.setTimeout || !host.clearTimeout) {
         return;
       }
-      let locationToWatch = affectingLocation;
-      if (resolutionHost.realpath) {
-        locationToWatch = resolutionHost.realpath(affectingLocation);
-        if (affectingLocation !== locationToWatch) {
-          const fileWatcher2 = fileWatchesOfAffectingLocations.get(locationToWatch);
-          if (fileWatcher2) {
-            if (forResolution)
-              fileWatcher2.resolutions++;
-            else
-              fileWatcher2.files++;
-            fileWatcher2.paths.add(affectingLocation);
-            fileWatchesOfAffectingLocations.set(affectingLocation, fileWatcher2);
-            return;
-          }
-        }
+      if (timerToUpdateProgram) {
+        host.clearTimeout(timerToUpdateProgram);
       }
-      const paths = /* @__PURE__ */ new Set();
-      paths.add(locationToWatch);
-      let actualWatcher = canWatchAffectingLocation(resolutionHost.toPath(locationToWatch)) ? resolutionHost.watchAffectingFileLocation(locationToWatch, (fileName, eventKind) => {
-        cachedDirectoryStructureHost == null ? void 0 : cachedDirectoryStructureHost.addOrDeleteFile(fileName, resolutionHost.toPath(locationToWatch), eventKind);
-        const packageJsonMap = moduleResolutionCache.getPackageJsonInfoCache().getInternalMap();
-        paths.forEach((path) => {
-          if (watcher.resolutions)
-            (affectingPathChecks ?? (affectingPathChecks = /* @__PURE__ */ new Set())).add(path);
-          if (watcher.files)
-            (affectingPathChecksForFile ?? (affectingPathChecksForFile = /* @__PURE__ */ new Set())).add(path);
-          packageJsonMap == null ? void 0 : packageJsonMap.delete(resolutionHost.toPath(path));
-        });
-        resolutionHost.scheduleInvalidateResolutionsOfFailedLookupLocations();
-      }) : noopFileWatcher;
-      const watcher = {
-        watcher: actualWatcher !== noopFileWatcher ? {
-          close: () => {
-            actualWatcher.close();
-            actualWatcher = noopFileWatcher;
-          }
-        } : actualWatcher,
-        resolutions: forResolution ? 1 : 0,
-        files: forResolution ? 0 : 1,
-        paths
-      };
-      fileWatchesOfAffectingLocations.set(locationToWatch, watcher);
-      if (affectingLocation !== locationToWatch) {
-        fileWatchesOfAffectingLocations.set(affectingLocation, watcher);
-        paths.add(affectingLocation);
+      writeLog("Scheduling update");
+      timerToUpdateProgram = host.setTimeout(updateProgramWithWatchStatus, 250, "timerToUpdateProgram");
+    }
+    function scheduleProgramReload() {
+      Debug.assert(!!configFileName);
+      updateLevel = 2 /* Full */;
+      scheduleProgramUpdate();
+    }
+    function scheduleResolutionReload() {
+      writeLog("Clearing resolutions");
+      resolutionCache.clear();
+      updateLevel = 3 /* Resolutions */;
+      scheduleProgramUpdate();
+    }
+    function updateProgramWithWatchStatus() {
+      timerToUpdateProgram = void 0;
+      reportFileChangeDetectedOnCreateProgram = true;
+      updateProgram();
+    }
+    function updateProgram() {
+      var _a, _b, _c, _d, _e;
+      switch (updateLevel) {
+        case 1 /* RootNamesAndUpdate */:
+          (_a = perfLogger) == null ? void 0 : _a.logStartUpdateProgram("PartialConfigReload");
+          reloadFileNamesFromConfigFile();
+          break;
+        case 2 /* Full */:
+          (_b = perfLogger) == null ? void 0 : _b.logStartUpdateProgram("FullConfigReload");
+          reloadConfigFile();
+          break;
+        case 3 /* Resolutions */:
+          (_c = perfLogger) == null ? void 0 : _c.logStartUpdateProgram("SynchronizeProgramWithResolutions");
+          synchronizeProgram(
+            /*forceAllFilesAsInvalidated*/
+            true
+          );
+          break;
+        default:
+          (_d = perfLogger) == null ? void 0 : _d.logStartUpdateProgram("SynchronizeProgram");
+          synchronizeProgram();
+          break;
       }
+      (_e = perfLogger) == null ? void 0 : _e.logStopUpdateProgram("Done");
+      return getCurrentBuilderProgram();
     }
-    function watchFailedLookupLocationOfNonRelativeModuleResolutions(resolutions, name) {
-      const program = resolutionHost.getCurrentProgram();
-      if (!program || !program.getTypeChecker().tryFindAmbientModuleWithoutAugmentations(name)) {
-        resolutions.forEach(watchFailedLookupLocationOfResolution);
-      } else {
-        resolutions.forEach((resolution) => watchAffectingLocationsOfResolution(
-          resolution,
-          /*addToResolutionsWithOnlyAffectingLocations*/
-          true
-        ));
+    function reloadFileNamesFromConfigFile() {
+      writeLog("Reloading new file names and options");
+      Debug.assert(compilerOptions);
+      Debug.assert(configFileName);
+      updateLevel = 0 /* Update */;
+      rootFileNames = getFileNamesFromConfigSpecs(compilerOptions.configFile.configFileSpecs, getNormalizedAbsolutePath(getDirectoryPath(configFileName), currentDirectory), compilerOptions, parseConfigFileHost, extraFileExtensions);
+      if (updateErrorForNoInputFiles(rootFileNames, getNormalizedAbsolutePath(configFileName, currentDirectory), compilerOptions.configFile.configFileSpecs, configFileParsingDiagnostics, canConfigFileJsonReportNoInputFiles)) {
+        hasChangedConfigFileParsingErrors = true;
       }
+      synchronizeProgram();
     }
-    function setDirectoryWatcher(dir, dirPath, nonRecursive) {
-      const dirWatcher = directoryWatchesOfFailedLookups.get(dirPath);
-      if (dirWatcher) {
-        Debug.assert(!!nonRecursive === !!dirWatcher.nonRecursive);
-        dirWatcher.refCount++;
-      } else {
-        directoryWatchesOfFailedLookups.set(dirPath, { watcher: createDirectoryWatcher(dir, dirPath, nonRecursive), refCount: 1, nonRecursive });
+    function reloadConfigFile() {
+      Debug.assert(configFileName);
+      writeLog(`Reloading config file: ${configFileName}`);
+      updateLevel = 0 /* Update */;
+      if (cachedDirectoryStructureHost) {
+        cachedDirectoryStructureHost.clearCache();
       }
+      parseConfigFile2();
+      hasChangedCompilerOptions = true;
+      synchronizeProgram();
+      watchConfigFileWildCardDirectories();
+      updateExtendedConfigFilesWatches(toPath3(configFileName), compilerOptions, watchOptions, WatchType.ExtendedConfigFile);
     }
-    function stopWatchFailedLookupLocation(failedLookupLocation, removeAtRoot) {
-      const failedLookupLocationPath = resolutionHost.toPath(failedLookupLocation);
-      const toWatch = getDirectoryToWatchFailedLookupLocation(
-        failedLookupLocation,
-        failedLookupLocationPath,
-        rootDir,
-        rootPath,
-        rootPathComponents,
-        getCurrentDirectory
+    function parseConfigFile2() {
+      Debug.assert(configFileName);
+      setConfigFileParsingResult(
+        getParsedCommandLineOfConfigFile(
+          configFileName,
+          optionsToExtendForConfigFile,
+          parseConfigFileHost,
+          extendedConfigCache || (extendedConfigCache = /* @__PURE__ */ new Map()),
+          watchOptionsToExtend,
+          extraFileExtensions
+        )
       );
-      if (toWatch) {
-        const { dirPath } = toWatch;
-        if (dirPath === rootPath) {
-          removeAtRoot = true;
-        } else {
-          removeDirectoryWatcher(dirPath);
-        }
-      }
-      return removeAtRoot;
     }
-    function stopWatchFailedLookupLocationOfResolution(resolution, filePath, getResolutionWithResolvedFileName) {
-      Debug.checkDefined(resolution.files).delete(filePath);
-      resolution.refCount--;
-      if (resolution.refCount) {
-        return;
-      }
-      const resolved = getResolutionWithResolvedFileName(resolution);
-      if (resolved && resolved.resolvedFileName) {
-        const key = resolutionHost.toPath(resolved.resolvedFileName);
-        const resolutions = resolvedFileToResolution.get(key);
-        if ((resolutions == null ? void 0 : resolutions.delete(resolution)) && !resolutions.size)
-          resolvedFileToResolution.delete(key);
-      }
-      const { failedLookupLocations, affectingLocations, node10Result } = resolution;
-      if (resolutionsWithFailedLookups.delete(resolution)) {
-        let removeAtRoot = false;
-        if (failedLookupLocations) {
-          for (const failedLookupLocation of failedLookupLocations) {
-            removeAtRoot = stopWatchFailedLookupLocation(failedLookupLocation, removeAtRoot);
-          }
+    function setConfigFileParsingResult(configFileParseResult) {
+      rootFileNames = configFileParseResult.fileNames;
+      compilerOptions = configFileParseResult.options;
+      watchOptions = configFileParseResult.watchOptions;
+      projectReferences = configFileParseResult.projectReferences;
+      wildcardDirectories = configFileParseResult.wildcardDirectories;
+      configFileParsingDiagnostics = getConfigFileParsingDiagnostics(configFileParseResult).slice();
+      canConfigFileJsonReportNoInputFiles = canJsonReportNoInputFiles(configFileParseResult.raw);
+      hasChangedConfigFileParsingErrors = true;
+    }
+    function getParsedCommandLine(configFileName2) {
+      const configPath = toPath3(configFileName2);
+      let config = parsedConfigs == null ? void 0 : parsedConfigs.get(configPath);
+      if (config) {
+        if (!config.updateLevel)
+          return config.parsedCommandLine;
+        if (config.parsedCommandLine && config.updateLevel === 1 /* RootNamesAndUpdate */ && !host.getParsedCommandLine) {
+          writeLog("Reloading new file names and options");
+          Debug.assert(compilerOptions);
+          const fileNames = getFileNamesFromConfigSpecs(
+            config.parsedCommandLine.options.configFile.configFileSpecs,
+            getNormalizedAbsolutePath(getDirectoryPath(configFileName2), currentDirectory),
+            compilerOptions,
+            parseConfigFileHost
+          );
+          config.parsedCommandLine = { ...config.parsedCommandLine, fileNames };
+          config.updateLevel = void 0;
+          return config.parsedCommandLine;
         }
-        if (node10Result)
-          removeAtRoot = stopWatchFailedLookupLocation(node10Result, removeAtRoot);
-        if (removeAtRoot)
-          removeDirectoryWatcher(rootPath);
-      } else if (affectingLocations == null ? void 0 : affectingLocations.length) {
-        resolutionsWithOnlyAffectingLocations.delete(resolution);
       }
-      if (affectingLocations) {
-        for (const affectingLocation of affectingLocations) {
-          const watcher = fileWatchesOfAffectingLocations.get(affectingLocation);
-          watcher.resolutions--;
-        }
+      writeLog(`Loading config file: ${configFileName2}`);
+      const parsedCommandLine = host.getParsedCommandLine ? host.getParsedCommandLine(configFileName2) : getParsedCommandLineFromConfigFileHost(configFileName2);
+      if (config) {
+        config.parsedCommandLine = parsedCommandLine;
+        config.updateLevel = void 0;
+      } else {
+        (parsedConfigs || (parsedConfigs = /* @__PURE__ */ new Map())).set(configPath, config = { parsedCommandLine });
       }
+      watchReferencedProject(configFileName2, configPath, config);
+      return parsedCommandLine;
     }
-    function removeDirectoryWatcher(dirPath) {
-      const dirWatcher = directoryWatchesOfFailedLookups.get(dirPath);
-      dirWatcher.refCount--;
+    function getParsedCommandLineFromConfigFileHost(configFileName2) {
+      const onUnRecoverableConfigFileDiagnostic = parseConfigFileHost.onUnRecoverableConfigFileDiagnostic;
+      parseConfigFileHost.onUnRecoverableConfigFileDiagnostic = noop;
+      const parsedCommandLine = getParsedCommandLineOfConfigFile(
+        configFileName2,
+        /*optionsToExtend*/
+        void 0,
+        parseConfigFileHost,
+        extendedConfigCache || (extendedConfigCache = /* @__PURE__ */ new Map()),
+        watchOptionsToExtend
+      );
+      parseConfigFileHost.onUnRecoverableConfigFileDiagnostic = onUnRecoverableConfigFileDiagnostic;
+      return parsedCommandLine;
     }
-    function createDirectoryWatcher(directory, dirPath, nonRecursive) {
-      return resolutionHost.watchDirectoryOfFailedLookupLocation(directory, (fileOrDirectory) => {
-        const fileOrDirectoryPath = resolutionHost.toPath(fileOrDirectory);
-        if (cachedDirectoryStructureHost) {
-          cachedDirectoryStructureHost.addOrDeleteFileOrDirectory(fileOrDirectory, fileOrDirectoryPath);
-        }
-        scheduleInvalidateResolutionOfFailedLookupLocation(fileOrDirectoryPath, dirPath === fileOrDirectoryPath);
-      }, nonRecursive ? 0 /* None */ : 1 /* Recursive */);
+    function onReleaseParsedCommandLine(fileName) {
+      var _a;
+      const path = toPath3(fileName);
+      const config = parsedConfigs == null ? void 0 : parsedConfigs.get(path);
+      if (!config)
+        return;
+      parsedConfigs.delete(path);
+      if (config.watchedDirectories)
+        clearMap(config.watchedDirectories, closeFileWatcherOf);
+      (_a = config.watcher) == null ? void 0 : _a.close();
+      clearSharedExtendedConfigFileWatcher(path, sharedExtendedConfigFileWatchers);
     }
-    function removeResolutionsOfFileFromCache(cache, filePath, getResolutionWithResolvedFileName) {
-      const resolutions = cache.get(filePath);
-      if (resolutions) {
-        resolutions.forEach((resolution) => stopWatchFailedLookupLocationOfResolution(resolution, filePath, getResolutionWithResolvedFileName));
-        cache.delete(filePath);
-      }
+    function watchFilePath(path, file, callback, pollingInterval, options, watchType) {
+      return watchFile2(file, (fileName, eventKind) => callback(fileName, eventKind, path), pollingInterval, options, watchType);
     }
-    function removeResolutionsFromProjectReferenceRedirects(filePath) {
-      if (!fileExtensionIs(filePath, ".json" /* Json */))
-        return;
-      const program = resolutionHost.getCurrentProgram();
-      if (!program)
-        return;
-      const resolvedProjectReference = program.getResolvedProjectReferenceByPath(filePath);
-      if (!resolvedProjectReference)
-        return;
-      resolvedProjectReference.commandLine.fileNames.forEach((f) => removeResolutionsOfFile(resolutionHost.toPath(f)));
+    function onSourceFileChange(fileName, eventKind, path) {
+      updateCachedSystemWithFile(fileName, path, eventKind);
+      if (eventKind === 2 /* Deleted */ && sourceFilesCache.has(path)) {
+        resolutionCache.invalidateResolutionOfFile(path);
+      }
+      nextSourceFileVersion(path);
+      scheduleProgramUpdate();
     }
-    function removeResolutionsOfFile(filePath) {
-      removeResolutionsOfFileFromCache(resolvedModuleNames, filePath, getResolvedModule2);
-      removeResolutionsOfFileFromCache(resolvedTypeReferenceDirectives, filePath, getResolvedTypeReferenceDirective2);
+    function updateCachedSystemWithFile(fileName, path, eventKind) {
+      if (cachedDirectoryStructureHost) {
+        cachedDirectoryStructureHost.addOrDeleteFile(fileName, path, eventKind);
+      }
     }
-    function invalidateResolutions(resolutions, canInvalidate) {
-      if (!resolutions)
-        return false;
-      let invalidated = false;
-      resolutions.forEach((resolution) => {
-        if (resolution.isInvalidated || !canInvalidate(resolution))
-          return;
-        resolution.isInvalidated = invalidated = true;
-        for (const containingFilePath of Debug.checkDefined(resolution.files)) {
-          (filesWithInvalidatedResolutions ?? (filesWithInvalidatedResolutions = /* @__PURE__ */ new Set())).add(containingFilePath);
-          hasChangedAutomaticTypeDirectiveNames = hasChangedAutomaticTypeDirectiveNames || endsWith(containingFilePath, inferredTypesContainingFile);
-        }
-      });
-      return invalidated;
+    function watchMissingFilePath(missingFilePath) {
+      return (parsedConfigs == null ? void 0 : parsedConfigs.has(missingFilePath)) ? noopFileWatcher : watchFilePath(missingFilePath, missingFilePath, onMissingFileChange, 500 /* Medium */, watchOptions, WatchType.MissingFile);
     }
-    function invalidateResolutionOfFile(filePath) {
-      removeResolutionsOfFile(filePath);
-      const prevHasChangedAutomaticTypeDirectiveNames = hasChangedAutomaticTypeDirectiveNames;
-      if (invalidateResolutions(resolvedFileToResolution.get(filePath), returnTrue) && hasChangedAutomaticTypeDirectiveNames && !prevHasChangedAutomaticTypeDirectiveNames) {
-        resolutionHost.onChangedAutomaticTypeDirectiveNames();
+    function onMissingFileChange(fileName, eventKind, missingFilePath) {
+      updateCachedSystemWithFile(fileName, missingFilePath, eventKind);
+      if (eventKind === 0 /* Created */ && missingFilesMap.has(missingFilePath)) {
+        missingFilesMap.get(missingFilePath).close();
+        missingFilesMap.delete(missingFilePath);
+        nextSourceFileVersion(missingFilePath);
+        scheduleProgramUpdate();
       }
     }
-    function setFilesWithInvalidatedNonRelativeUnresolvedImports(filesMap) {
-      Debug.assert(filesWithInvalidatedNonRelativeUnresolvedImports === filesMap || filesWithInvalidatedNonRelativeUnresolvedImports === void 0);
-      filesWithInvalidatedNonRelativeUnresolvedImports = filesMap;
+    function watchConfigFileWildCardDirectories() {
+      if (wildcardDirectories) {
+        updateWatchingWildcardDirectories(
+          watchedWildcardDirectories || (watchedWildcardDirectories = /* @__PURE__ */ new Map()),
+          new Map(Object.entries(wildcardDirectories)),
+          watchWildcardDirectory
+        );
+      } else if (watchedWildcardDirectories) {
+        clearMap(watchedWildcardDirectories, closeFileWatcherOf);
+      }
     }
-    function scheduleInvalidateResolutionOfFailedLookupLocation(fileOrDirectoryPath, isCreatingWatchedDirectory) {
-      if (isCreatingWatchedDirectory) {
-        (isInDirectoryChecks || (isInDirectoryChecks = /* @__PURE__ */ new Set())).add(fileOrDirectoryPath);
-      } else {
-        const updatedPath = removeIgnoredPath(fileOrDirectoryPath);
-        if (!updatedPath)
-          return false;
-        fileOrDirectoryPath = updatedPath;
-        if (resolutionHost.fileIsOpen(fileOrDirectoryPath)) {
-          return false;
-        }
-        const dirOfFileOrDirectory = getDirectoryPath(fileOrDirectoryPath);
-        if (isNodeModulesAtTypesDirectory(fileOrDirectoryPath) || isNodeModulesDirectory(fileOrDirectoryPath) || isNodeModulesAtTypesDirectory(dirOfFileOrDirectory) || isNodeModulesDirectory(dirOfFileOrDirectory)) {
-          (failedLookupChecks || (failedLookupChecks = /* @__PURE__ */ new Set())).add(fileOrDirectoryPath);
-          (startsWithPathChecks || (startsWithPathChecks = /* @__PURE__ */ new Set())).add(fileOrDirectoryPath);
-        } else {
-          if (isEmittedFileOfProgram(resolutionHost.getCurrentProgram(), fileOrDirectoryPath)) {
-            return false;
-          }
-          if (fileExtensionIs(fileOrDirectoryPath, ".map")) {
-            return false;
+    function watchWildcardDirectory(directory, flags) {
+      return watchDirectory(
+        directory,
+        (fileOrDirectory) => {
+          Debug.assert(configFileName);
+          Debug.assert(compilerOptions);
+          const fileOrDirectoryPath = toPath3(fileOrDirectory);
+          if (cachedDirectoryStructureHost) {
+            cachedDirectoryStructureHost.addOrDeleteFileOrDirectory(fileOrDirectory, fileOrDirectoryPath);
           }
-          (failedLookupChecks || (failedLookupChecks = /* @__PURE__ */ new Set())).add(fileOrDirectoryPath);
-          const packagePath = parseNodeModuleFromPath(
+          nextSourceFileVersion(fileOrDirectoryPath);
+          if (isIgnoredFileFromWildCardWatching({
+            watchedDirPath: toPath3(directory),
+            fileOrDirectory,
             fileOrDirectoryPath,
-            /*isFolder*/
-            true
-          );
-          if (packagePath)
-            (startsWithPathChecks || (startsWithPathChecks = /* @__PURE__ */ new Set())).add(packagePath);
-        }
-      }
-      resolutionHost.scheduleInvalidateResolutionsOfFailedLookupLocations();
+            configFileName,
+            extraFileExtensions,
+            options: compilerOptions,
+            program: getCurrentBuilderProgram() || rootFileNames,
+            currentDirectory,
+            useCaseSensitiveFileNames: useCaseSensitiveFileNames2,
+            writeLog,
+            toPath: toPath3
+          }))
+            return;
+          if (updateLevel !== 2 /* Full */) {
+            updateLevel = 1 /* RootNamesAndUpdate */;
+            scheduleProgramUpdate();
+          }
+        },
+        flags,
+        watchOptions,
+        WatchType.WildcardDirectory
+      );
     }
-    function invalidatePackageJsonMap() {
-      const packageJsonMap = moduleResolutionCache.getPackageJsonInfoCache().getInternalMap();
-      if (packageJsonMap && (failedLookupChecks || startsWithPathChecks || isInDirectoryChecks)) {
-        packageJsonMap.forEach((_value, path) => isInvalidatedFailedLookup(path) ? packageJsonMap.delete(path) : void 0);
-      }
+    function updateExtendedConfigFilesWatches(forProjectPath, options, watchOptions2, watchType) {
+      updateSharedExtendedConfigFileWatcher(
+        forProjectPath,
+        options,
+        sharedExtendedConfigFileWatchers || (sharedExtendedConfigFileWatchers = /* @__PURE__ */ new Map()),
+        (extendedConfigFileName, extendedConfigFilePath) => watchFile2(
+          extendedConfigFileName,
+          (_fileName, eventKind) => {
+            var _a;
+            updateCachedSystemWithFile(extendedConfigFileName, extendedConfigFilePath, eventKind);
+            if (extendedConfigCache)
+              cleanExtendedConfigCache(extendedConfigCache, extendedConfigFilePath, toPath3);
+            const projects = (_a = sharedExtendedConfigFileWatchers.get(extendedConfigFilePath)) == null ? void 0 : _a.projects;
+            if (!(projects == null ? void 0 : projects.size))
+              return;
+            projects.forEach((projectPath) => {
+              if (configFileName && toPath3(configFileName) === projectPath) {
+                updateLevel = 2 /* Full */;
+              } else {
+                const config = parsedConfigs == null ? void 0 : parsedConfigs.get(projectPath);
+                if (config)
+                  config.updateLevel = 2 /* Full */;
+                resolutionCache.removeResolutionsFromProjectReferenceRedirects(projectPath);
+              }
+              scheduleProgramUpdate();
+            });
+          },
+          2e3 /* High */,
+          watchOptions2,
+          watchType
+        ),
+        toPath3
+      );
     }
-    function invalidateResolutionsOfFailedLookupLocations() {
-      var _a;
-      if (allModuleAndTypeResolutionsAreInvalidated) {
-        affectingPathChecksForFile = void 0;
-        invalidatePackageJsonMap();
-        if (failedLookupChecks || startsWithPathChecks || isInDirectoryChecks || affectingPathChecks) {
-          invalidateResolutions(resolvedLibraries, canInvalidateFailedLookupResolution);
-        }
-        failedLookupChecks = void 0;
-        startsWithPathChecks = void 0;
-        isInDirectoryChecks = void 0;
-        affectingPathChecks = void 0;
-        return true;
-      }
-      let invalidated = false;
-      if (affectingPathChecksForFile) {
-        (_a = resolutionHost.getCurrentProgram()) == null ? void 0 : _a.getSourceFiles().forEach((f) => {
-          if (some(f.packageJsonLocations, (location) => affectingPathChecksForFile.has(location))) {
-            (filesWithInvalidatedResolutions ?? (filesWithInvalidatedResolutions = /* @__PURE__ */ new Set())).add(f.path);
-            invalidated = true;
+    function watchReferencedProject(configFileName2, configPath, commandLine) {
+      var _a, _b, _c, _d, _e;
+      commandLine.watcher || (commandLine.watcher = watchFile2(
+        configFileName2,
+        (_fileName, eventKind) => {
+          updateCachedSystemWithFile(configFileName2, configPath, eventKind);
+          const config = parsedConfigs == null ? void 0 : parsedConfigs.get(configPath);
+          if (config)
+            config.updateLevel = 2 /* Full */;
+          resolutionCache.removeResolutionsFromProjectReferenceRedirects(configPath);
+          scheduleProgramUpdate();
+        },
+        2e3 /* High */,
+        ((_a = commandLine.parsedCommandLine) == null ? void 0 : _a.watchOptions) || watchOptions,
+        WatchType.ConfigFileOfReferencedProject
+      ));
+      if ((_b = commandLine.parsedCommandLine) == null ? void 0 : _b.wildcardDirectories) {
+        updateWatchingWildcardDirectories(
+          commandLine.watchedDirectories || (commandLine.watchedDirectories = /* @__PURE__ */ new Map()),
+          new Map(Object.entries((_c = commandLine.parsedCommandLine) == null ? void 0 : _c.wildcardDirectories)),
+          (directory, flags) => {
+            var _a2;
+            return watchDirectory(
+              directory,
+              (fileOrDirectory) => {
+                const fileOrDirectoryPath = toPath3(fileOrDirectory);
+                if (cachedDirectoryStructureHost) {
+                  cachedDirectoryStructureHost.addOrDeleteFileOrDirectory(fileOrDirectory, fileOrDirectoryPath);
+                }
+                nextSourceFileVersion(fileOrDirectoryPath);
+                const config = parsedConfigs == null ? void 0 : parsedConfigs.get(configPath);
+                if (!(config == null ? void 0 : config.parsedCommandLine))
+                  return;
+                if (isIgnoredFileFromWildCardWatching({
+                  watchedDirPath: toPath3(directory),
+                  fileOrDirectory,
+                  fileOrDirectoryPath,
+                  configFileName: configFileName2,
+                  options: config.parsedCommandLine.options,
+                  program: config.parsedCommandLine.fileNames,
+                  currentDirectory,
+                  useCaseSensitiveFileNames: useCaseSensitiveFileNames2,
+                  writeLog,
+                  toPath: toPath3
+                }))
+                  return;
+                if (config.updateLevel !== 2 /* Full */) {
+                  config.updateLevel = 1 /* RootNamesAndUpdate */;
+                  scheduleProgramUpdate();
+                }
+              },
+              flags,
+              ((_a2 = commandLine.parsedCommandLine) == null ? void 0 : _a2.watchOptions) || watchOptions,
+              WatchType.WildcardDirectoryOfReferencedProject
+            );
           }
-        });
-        affectingPathChecksForFile = void 0;
-      }
-      if (!failedLookupChecks && !startsWithPathChecks && !isInDirectoryChecks && !affectingPathChecks) {
-        return invalidated;
+        );
+      } else if (commandLine.watchedDirectories) {
+        clearMap(commandLine.watchedDirectories, closeFileWatcherOf);
+        commandLine.watchedDirectories = void 0;
       }
-      invalidated = invalidateResolutions(resolutionsWithFailedLookups, canInvalidateFailedLookupResolution) || invalidated;
-      invalidatePackageJsonMap();
-      failedLookupChecks = void 0;
-      startsWithPathChecks = void 0;
-      isInDirectoryChecks = void 0;
-      invalidated = invalidateResolutions(resolutionsWithOnlyAffectingLocations, canInvalidatedFailedLookupResolutionWithAffectingLocation) || invalidated;
-      affectingPathChecks = void 0;
-      return invalidated;
+      updateExtendedConfigFilesWatches(
+        configPath,
+        (_d = commandLine.parsedCommandLine) == null ? void 0 : _d.options,
+        ((_e = commandLine.parsedCommandLine) == null ? void 0 : _e.watchOptions) || watchOptions,
+        WatchType.ExtendedConfigOfReferencedProject
+      );
     }
-    function canInvalidateFailedLookupResolution(resolution) {
-      var _a;
-      if (canInvalidatedFailedLookupResolutionWithAffectingLocation(resolution))
-        return true;
-      if (!failedLookupChecks && !startsWithPathChecks && !isInDirectoryChecks)
-        return false;
-      return ((_a = resolution.failedLookupLocations) == null ? void 0 : _a.some((location) => isInvalidatedFailedLookup(resolutionHost.toPath(location)))) || !!resolution.node10Result && isInvalidatedFailedLookup(resolutionHost.toPath(resolution.node10Result));
+  }
+  var init_watchPublic = __esm({
+    "src/compiler/watchPublic.ts"() {
+      "use strict";
+      init_ts2();
+      init_pnp();
     }
-    function isInvalidatedFailedLookup(locationPath) {
-      return (failedLookupChecks == null ? void 0 : failedLookupChecks.has(locationPath)) || firstDefinedIterator((startsWithPathChecks == null ? void 0 : startsWithPathChecks.keys()) || [], (fileOrDirectoryPath) => startsWith(locationPath, fileOrDirectoryPath) ? true : void 0) || firstDefinedIterator((isInDirectoryChecks == null ? void 0 : isInDirectoryChecks.keys()) || [], (dirPath) => locationPath.length > dirPath.length && startsWith(locationPath, dirPath) && (isDiskPathRoot(dirPath) || locationPath[dirPath.length] === directorySeparator) ? true : void 0);
+  });
+
+  // src/compiler/tsbuild.ts
+  function resolveConfigFileProjectName(project) {
+    if (fileExtensionIs(project, ".json" /* Json */)) {
+      return project;
     }
-    function canInvalidatedFailedLookupResolutionWithAffectingLocation(resolution) {
-      var _a;
-      return !!affectingPathChecks && ((_a = resolution.affectingLocations) == null ? void 0 : _a.some((location) => affectingPathChecks.has(location)));
+    return combinePaths(project, "tsconfig.json");
+  }
+  var UpToDateStatusType;
+  var init_tsbuild = __esm({
+    "src/compiler/tsbuild.ts"() {
+      "use strict";
+      init_ts2();
+      UpToDateStatusType = /* @__PURE__ */ ((UpToDateStatusType2) => {
+        UpToDateStatusType2[UpToDateStatusType2["Unbuildable"] = 0] = "Unbuildable";
+        UpToDateStatusType2[UpToDateStatusType2["UpToDate"] = 1] = "UpToDate";
+        UpToDateStatusType2[UpToDateStatusType2["UpToDateWithUpstreamTypes"] = 2] = "UpToDateWithUpstreamTypes";
+        UpToDateStatusType2[UpToDateStatusType2["OutOfDateWithPrepend"] = 3] = "OutOfDateWithPrepend";
+        UpToDateStatusType2[UpToDateStatusType2["OutputMissing"] = 4] = "OutputMissing";
+        UpToDateStatusType2[UpToDateStatusType2["ErrorReadingFile"] = 5] = "ErrorReadingFile";
+        UpToDateStatusType2[UpToDateStatusType2["OutOfDateWithSelf"] = 6] = "OutOfDateWithSelf";
+        UpToDateStatusType2[UpToDateStatusType2["OutOfDateWithUpstream"] = 7] = "OutOfDateWithUpstream";
+        UpToDateStatusType2[UpToDateStatusType2["OutOfDateBuildInfo"] = 8] = "OutOfDateBuildInfo";
+        UpToDateStatusType2[UpToDateStatusType2["OutOfDateOptions"] = 9] = "OutOfDateOptions";
+        UpToDateStatusType2[UpToDateStatusType2["OutOfDateRoots"] = 10] = "OutOfDateRoots";
+        UpToDateStatusType2[UpToDateStatusType2["UpstreamOutOfDate"] = 11] = "UpstreamOutOfDate";
+        UpToDateStatusType2[UpToDateStatusType2["UpstreamBlocked"] = 12] = "UpstreamBlocked";
+        UpToDateStatusType2[UpToDateStatusType2["ComputingUpstream"] = 13] = "ComputingUpstream";
+        UpToDateStatusType2[UpToDateStatusType2["TsVersionOutputOfDate"] = 14] = "TsVersionOutputOfDate";
+        UpToDateStatusType2[UpToDateStatusType2["UpToDateWithInputFileText"] = 15] = "UpToDateWithInputFileText";
+        UpToDateStatusType2[UpToDateStatusType2["ContainerOnly"] = 16] = "ContainerOnly";
+        UpToDateStatusType2[UpToDateStatusType2["ForceBuild"] = 17] = "ForceBuild";
+        return UpToDateStatusType2;
+      })(UpToDateStatusType || {});
     }
-    function closeTypeRootsWatch() {
-      clearMap(typeRootsWatches, closeFileWatcher);
+  });
+
+  // src/compiler/tsbuildPublic.ts
+  function getOrCreateValueFromConfigFileMap(configFileMap, resolved, createT) {
+    const existingValue = configFileMap.get(resolved);
+    let newValue;
+    if (!existingValue) {
+      newValue = createT();
+      configFileMap.set(resolved, newValue);
     }
-    function createTypeRootsWatch(typeRootPath, typeRoot) {
-      return canWatchTypeRootPath(typeRootPath) ? resolutionHost.watchTypeRootsDirectory(typeRoot, (fileOrDirectory) => {
-        const fileOrDirectoryPath = resolutionHost.toPath(fileOrDirectory);
-        if (cachedDirectoryStructureHost) {
-          cachedDirectoryStructureHost.addOrDeleteFileOrDirectory(fileOrDirectory, fileOrDirectoryPath);
-        }
-        hasChangedAutomaticTypeDirectiveNames = true;
-        resolutionHost.onChangedAutomaticTypeDirectiveNames();
-        const dirPath = getDirectoryToWatchFailedLookupLocationFromTypeRoot(
-          typeRoot,
-          typeRootPath,
-          rootPath,
-          rootPathComponents,
-          getCurrentDirectory,
-          (dirPath2) => directoryWatchesOfFailedLookups.has(dirPath2)
-        );
-        if (dirPath) {
-          scheduleInvalidateResolutionOfFailedLookupLocation(fileOrDirectoryPath, dirPath === fileOrDirectoryPath);
+    return existingValue || newValue;
+  }
+  function getOrCreateValueMapFromConfigFileMap(configFileMap, resolved) {
+    return getOrCreateValueFromConfigFileMap(configFileMap, resolved, () => /* @__PURE__ */ new Map());
+  }
+  function getCurrentTime(host) {
+    return host.now ? host.now() : /* @__PURE__ */ new Date();
+  }
+  function isCircularBuildOrder(buildOrder) {
+    return !!buildOrder && !!buildOrder.buildOrder;
+  }
+  function getBuildOrderFromAnyBuildOrder(anyBuildOrder) {
+    return isCircularBuildOrder(anyBuildOrder) ? anyBuildOrder.buildOrder : anyBuildOrder;
+  }
+  function createBuilderStatusReporter(system, pretty) {
+    return (diagnostic) => {
+      let output = pretty ? `[${formatColorAndReset(getLocaleTimeString(system), "\x1B[90m" /* Grey */)}] ` : `${getLocaleTimeString(system)} - `;
+      output += `${flattenDiagnosticMessageText(diagnostic.messageText, system.newLine)}${system.newLine + system.newLine}`;
+      system.write(output);
+    };
+  }
+  function createSolutionBuilderHostBase(system, createProgram2, reportDiagnostic, reportSolutionBuilderStatus) {
+    const host = createProgramHost(system, createProgram2);
+    host.getModifiedTime = system.getModifiedTime ? (path) => system.getModifiedTime(path) : returnUndefined;
+    host.setModifiedTime = system.setModifiedTime ? (path, date) => system.setModifiedTime(path, date) : noop;
+    host.deleteFile = system.deleteFile ? (path) => system.deleteFile(path) : noop;
+    host.reportDiagnostic = reportDiagnostic || createDiagnosticReporter(system);
+    host.reportSolutionBuilderStatus = reportSolutionBuilderStatus || createBuilderStatusReporter(system);
+    host.now = maybeBind(system, system.now);
+    return host;
+  }
+  function createSolutionBuilderHost(system = sys, createProgram2, reportDiagnostic, reportSolutionBuilderStatus, reportErrorSummary2) {
+    const host = createSolutionBuilderHostBase(system, createProgram2, reportDiagnostic, reportSolutionBuilderStatus);
+    host.reportErrorSummary = reportErrorSummary2;
+    return host;
+  }
+  function createSolutionBuilderWithWatchHost(system = sys, createProgram2, reportDiagnostic, reportSolutionBuilderStatus, reportWatchStatus2) {
+    const host = createSolutionBuilderHostBase(system, createProgram2, reportDiagnostic, reportSolutionBuilderStatus);
+    const watchHost = createWatchHost(system, reportWatchStatus2);
+    copyProperties(host, watchHost);
+    return host;
+  }
+  function getCompilerOptionsOfBuildOptions(buildOptions) {
+    const result = {};
+    commonOptionsWithBuild.forEach((option) => {
+      if (hasProperty(buildOptions, option.name))
+        result[option.name] = buildOptions[option.name];
+    });
+    return result;
+  }
+  function createSolutionBuilder(host, rootNames, defaultOptions) {
+    return createSolutionBuilderWorker(
+      /*watch*/
+      false,
+      host,
+      rootNames,
+      defaultOptions
+    );
+  }
+  function createSolutionBuilderWithWatch(host, rootNames, defaultOptions, baseWatchOptions) {
+    return createSolutionBuilderWorker(
+      /*watch*/
+      true,
+      host,
+      rootNames,
+      defaultOptions,
+      baseWatchOptions
+    );
+  }
+  function createSolutionBuilderState(watch, hostOrHostWithWatch, rootNames, options, baseWatchOptions) {
+    const host = hostOrHostWithWatch;
+    const hostWithWatch = hostOrHostWithWatch;
+    const baseCompilerOptions = getCompilerOptionsOfBuildOptions(options);
+    const compilerHost = createCompilerHostFromProgramHost(host, () => state.projectCompilerOptions);
+    setGetSourceFileAsHashVersioned(compilerHost);
+    compilerHost.getParsedCommandLine = (fileName) => parseConfigFile(state, fileName, toResolvedConfigFilePath(state, fileName));
+    compilerHost.resolveModuleNameLiterals = maybeBind(host, host.resolveModuleNameLiterals);
+    compilerHost.resolveTypeReferenceDirectiveReferences = maybeBind(host, host.resolveTypeReferenceDirectiveReferences);
+    compilerHost.resolveLibrary = maybeBind(host, host.resolveLibrary);
+    compilerHost.resolveModuleNames = maybeBind(host, host.resolveModuleNames);
+    compilerHost.resolveTypeReferenceDirectives = maybeBind(host, host.resolveTypeReferenceDirectives);
+    compilerHost.getModuleResolutionCache = maybeBind(host, host.getModuleResolutionCache);
+    let moduleResolutionCache, typeReferenceDirectiveResolutionCache;
+    if (!compilerHost.resolveModuleNameLiterals && !compilerHost.resolveModuleNames) {
+      moduleResolutionCache = createModuleResolutionCache(compilerHost.getCurrentDirectory(), compilerHost.getCanonicalFileName);
+      compilerHost.resolveModuleNameLiterals = (moduleNames, containingFile, redirectedReference, options2, containingSourceFile) => loadWithModeAwareCache(
+        moduleNames,
+        containingFile,
+        redirectedReference,
+        options2,
+        containingSourceFile,
+        host,
+        moduleResolutionCache,
+        createModuleResolutionLoader
+      );
+      compilerHost.getModuleResolutionCache = () => moduleResolutionCache;
+    }
+    if (!compilerHost.resolveTypeReferenceDirectiveReferences && !compilerHost.resolveTypeReferenceDirectives) {
+      typeReferenceDirectiveResolutionCache = createTypeReferenceDirectiveResolutionCache(
+        compilerHost.getCurrentDirectory(),
+        compilerHost.getCanonicalFileName,
+        /*options*/
+        void 0,
+        moduleResolutionCache == null ? void 0 : moduleResolutionCache.getPackageJsonInfoCache(),
+        moduleResolutionCache == null ? void 0 : moduleResolutionCache.optionsToRedirectsKey
+      );
+      compilerHost.resolveTypeReferenceDirectiveReferences = (typeDirectiveNames, containingFile, redirectedReference, options2, containingSourceFile) => loadWithModeAwareCache(
+        typeDirectiveNames,
+        containingFile,
+        redirectedReference,
+        options2,
+        containingSourceFile,
+        host,
+        typeReferenceDirectiveResolutionCache,
+        createTypeReferenceResolutionLoader
+      );
+    }
+    let libraryResolutionCache;
+    if (!compilerHost.resolveLibrary) {
+      libraryResolutionCache = createModuleResolutionCache(
+        compilerHost.getCurrentDirectory(),
+        compilerHost.getCanonicalFileName,
+        /*options*/
+        void 0,
+        moduleResolutionCache == null ? void 0 : moduleResolutionCache.getPackageJsonInfoCache()
+      );
+      compilerHost.resolveLibrary = (libraryName, resolveFrom, options2) => resolveLibrary(
+        libraryName,
+        resolveFrom,
+        options2,
+        host,
+        libraryResolutionCache
+      );
+    }
+    compilerHost.getBuildInfo = (fileName, configFilePath) => getBuildInfo3(
+      state,
+      fileName,
+      toResolvedConfigFilePath(state, configFilePath),
+      /*modifiedTime*/
+      void 0
+    );
+    const { watchFile: watchFile2, watchDirectory, writeLog } = createWatchFactory(hostWithWatch, options);
+    const state = {
+      host,
+      hostWithWatch,
+      parseConfigFileHost: parseConfigHostFromCompilerHostLike(host),
+      write: maybeBind(host, host.trace),
+      // State of solution
+      options,
+      baseCompilerOptions,
+      rootNames,
+      baseWatchOptions,
+      resolvedConfigFilePaths: /* @__PURE__ */ new Map(),
+      configFileCache: /* @__PURE__ */ new Map(),
+      projectStatus: /* @__PURE__ */ new Map(),
+      extendedConfigCache: /* @__PURE__ */ new Map(),
+      buildInfoCache: /* @__PURE__ */ new Map(),
+      outputTimeStamps: /* @__PURE__ */ new Map(),
+      builderPrograms: /* @__PURE__ */ new Map(),
+      diagnostics: /* @__PURE__ */ new Map(),
+      projectPendingBuild: /* @__PURE__ */ new Map(),
+      projectErrorsReported: /* @__PURE__ */ new Map(),
+      compilerHost,
+      moduleResolutionCache,
+      typeReferenceDirectiveResolutionCache,
+      libraryResolutionCache,
+      // Mutable state
+      buildOrder: void 0,
+      readFileWithCache: (f) => host.readFile(f),
+      projectCompilerOptions: baseCompilerOptions,
+      cache: void 0,
+      allProjectBuildPending: true,
+      needsSummary: true,
+      watchAllProjectsPending: watch,
+      // Watch state
+      watch,
+      allWatchedWildcardDirectories: /* @__PURE__ */ new Map(),
+      allWatchedInputFiles: /* @__PURE__ */ new Map(),
+      allWatchedConfigFiles: /* @__PURE__ */ new Map(),
+      allWatchedExtendedConfigFiles: /* @__PURE__ */ new Map(),
+      allWatchedPackageJsonFiles: /* @__PURE__ */ new Map(),
+      filesWatched: /* @__PURE__ */ new Map(),
+      lastCachedPackageJsonLookups: /* @__PURE__ */ new Map(),
+      timerToBuildInvalidatedProject: void 0,
+      reportFileChangeDetected: false,
+      watchFile: watchFile2,
+      watchDirectory,
+      writeLog
+    };
+    return state;
+  }
+  function toPath2(state, fileName) {
+    return toPath(fileName, state.compilerHost.getCurrentDirectory(), state.compilerHost.getCanonicalFileName);
+  }
+  function toResolvedConfigFilePath(state, fileName) {
+    const { resolvedConfigFilePaths } = state;
+    const path = resolvedConfigFilePaths.get(fileName);
+    if (path !== void 0)
+      return path;
+    const resolvedPath = toPath2(state, fileName);
+    resolvedConfigFilePaths.set(fileName, resolvedPath);
+    return resolvedPath;
+  }
+  function isParsedCommandLine(entry) {
+    return !!entry.options;
+  }
+  function getCachedParsedConfigFile(state, configFilePath) {
+    const value = state.configFileCache.get(configFilePath);
+    return value && isParsedCommandLine(value) ? value : void 0;
+  }
+  function parseConfigFile(state, configFileName, configFilePath) {
+    const { configFileCache } = state;
+    const value = configFileCache.get(configFilePath);
+    if (value) {
+      return isParsedCommandLine(value) ? value : void 0;
+    }
+    mark("SolutionBuilder::beforeConfigFileParsing");
+    let diagnostic;
+    const { parseConfigFileHost, baseCompilerOptions, baseWatchOptions, extendedConfigCache, host } = state;
+    let parsed;
+    if (host.getParsedCommandLine) {
+      parsed = host.getParsedCommandLine(configFileName);
+      if (!parsed)
+        diagnostic = createCompilerDiagnostic(Diagnostics.File_0_not_found, configFileName);
+    } else {
+      parseConfigFileHost.onUnRecoverableConfigFileDiagnostic = (d) => diagnostic = d;
+      parsed = getParsedCommandLineOfConfigFile(configFileName, baseCompilerOptions, parseConfigFileHost, extendedConfigCache, baseWatchOptions);
+      parseConfigFileHost.onUnRecoverableConfigFileDiagnostic = noop;
+    }
+    configFileCache.set(configFilePath, parsed || diagnostic);
+    mark("SolutionBuilder::afterConfigFileParsing");
+    measure("SolutionBuilder::Config file parsing", "SolutionBuilder::beforeConfigFileParsing", "SolutionBuilder::afterConfigFileParsing");
+    return parsed;
+  }
+  function resolveProjectName(state, name) {
+    return resolveConfigFileProjectName(resolvePath(state.compilerHost.getCurrentDirectory(), name));
+  }
+  function createBuildOrder(state, roots) {
+    const temporaryMarks = /* @__PURE__ */ new Map();
+    const permanentMarks = /* @__PURE__ */ new Map();
+    const circularityReportStack = [];
+    let buildOrder;
+    let circularDiagnostics;
+    for (const root of roots) {
+      visit(root);
+    }
+    return circularDiagnostics ? { buildOrder: buildOrder || emptyArray, circularDiagnostics } : buildOrder || emptyArray;
+    function visit(configFileName, inCircularContext) {
+      const projPath = toResolvedConfigFilePath(state, configFileName);
+      if (permanentMarks.has(projPath))
+        return;
+      if (temporaryMarks.has(projPath)) {
+        if (!inCircularContext) {
+          (circularDiagnostics || (circularDiagnostics = [])).push(
+            createCompilerDiagnostic(
+              Diagnostics.Project_references_may_not_form_a_circular_graph_Cycle_detected_Colon_0,
+              circularityReportStack.join("\r\n")
+            )
+          );
         }
-      }, 1 /* Recursive */) : noopFileWatcher;
-    }
-    function updateTypeRootsWatch() {
-      const options = resolutionHost.getCompilationSettings();
-      if (options.types) {
-        closeTypeRootsWatch();
         return;
       }
-      const typeRoots = getEffectiveTypeRoots(options, { getCurrentDirectory });
-      if (typeRoots) {
-        mutateMap(
-          typeRootsWatches,
-          arrayToMap(typeRoots, (tr) => resolutionHost.toPath(tr)),
-          {
-            createNewValue: createTypeRootsWatch,
-            onDeleteValue: closeFileWatcher
-          }
-        );
-      } else {
-        closeTypeRootsWatch();
+      temporaryMarks.set(projPath, true);
+      circularityReportStack.push(configFileName);
+      const parsed = parseConfigFile(state, configFileName, projPath);
+      if (parsed && parsed.projectReferences) {
+        for (const ref of parsed.projectReferences) {
+          const resolvedRefPath = resolveProjectName(state, ref.path);
+          visit(resolvedRefPath, inCircularContext || ref.circular);
+        }
       }
-    }
-    function canWatchTypeRootPath(typeRoot) {
-      if (resolutionHost.getCompilationSettings().typeRoots)
-        return true;
-      return canWatchAtTypes(resolutionHost.toPath(typeRoot));
+      circularityReportStack.pop();
+      permanentMarks.set(projPath, true);
+      (buildOrder || (buildOrder = [])).push(configFileName);
     }
   }
-  function resolutionIsSymlink(resolution) {
-    var _a, _b;
-    return !!(((_a = resolution.resolvedModule) == null ? void 0 : _a.originalPath) || ((_b = resolution.resolvedTypeReferenceDirective) == null ? void 0 : _b.originalPath));
+  function getBuildOrder(state) {
+    return state.buildOrder || createStateBuildOrder(state);
   }
-  var init_resolutionCache = __esm({
-    "src/compiler/resolutionCache.ts"() {
-      "use strict";
-      init_ts2();
-    }
-  });
-
-  // src/compiler/watch.ts
-  function createDiagnosticReporter(system, pretty) {
-    const host = system === sys && sysFormatDiagnosticsHost ? sysFormatDiagnosticsHost : {
-      getCurrentDirectory: () => system.getCurrentDirectory(),
-      getNewLine: () => system.newLine,
-      getCanonicalFileName: createGetCanonicalFileName(system.useCaseSensitiveFileNames)
-    };
-    if (!pretty) {
-      return (diagnostic) => system.write(formatDiagnostic(diagnostic, host));
+  function createStateBuildOrder(state) {
+    const buildOrder = createBuildOrder(state, state.rootNames.map((f) => resolveProjectName(state, f)));
+    state.resolvedConfigFilePaths.clear();
+    const currentProjects = new Map(
+      getBuildOrderFromAnyBuildOrder(buildOrder).map(
+        (resolved) => [toResolvedConfigFilePath(state, resolved), true]
+      )
+    );
+    const noopOnDelete = { onDeleteValue: noop };
+    mutateMapSkippingNewValues(state.configFileCache, currentProjects, noopOnDelete);
+    mutateMapSkippingNewValues(state.projectStatus, currentProjects, noopOnDelete);
+    mutateMapSkippingNewValues(state.builderPrograms, currentProjects, noopOnDelete);
+    mutateMapSkippingNewValues(state.diagnostics, currentProjects, noopOnDelete);
+    mutateMapSkippingNewValues(state.projectPendingBuild, currentProjects, noopOnDelete);
+    mutateMapSkippingNewValues(state.projectErrorsReported, currentProjects, noopOnDelete);
+    mutateMapSkippingNewValues(state.buildInfoCache, currentProjects, noopOnDelete);
+    mutateMapSkippingNewValues(state.outputTimeStamps, currentProjects, noopOnDelete);
+    if (state.watch) {
+      mutateMapSkippingNewValues(
+        state.allWatchedConfigFiles,
+        currentProjects,
+        { onDeleteValue: closeFileWatcher }
+      );
+      state.allWatchedExtendedConfigFiles.forEach((watcher) => {
+        watcher.projects.forEach((project) => {
+          if (!currentProjects.has(project)) {
+            watcher.projects.delete(project);
+          }
+        });
+        watcher.close();
+      });
+      mutateMapSkippingNewValues(
+        state.allWatchedWildcardDirectories,
+        currentProjects,
+        { onDeleteValue: (existingMap) => existingMap.forEach(closeFileWatcherOf) }
+      );
+      mutateMapSkippingNewValues(
+        state.allWatchedInputFiles,
+        currentProjects,
+        { onDeleteValue: (existingMap) => existingMap.forEach(closeFileWatcher) }
+      );
+      mutateMapSkippingNewValues(
+        state.allWatchedPackageJsonFiles,
+        currentProjects,
+        { onDeleteValue: (existingMap) => existingMap.forEach(closeFileWatcher) }
+      );
     }
-    const diagnostics = new Array(1);
-    return (diagnostic) => {
-      diagnostics[0] = diagnostic;
-      system.write(formatDiagnosticsWithColorAndContext(diagnostics, host) + host.getNewLine());
-      diagnostics[0] = void 0;
-    };
+    return state.buildOrder = buildOrder;
   }
-  function clearScreenIfNotWatchingForFileChanges(system, diagnostic, options) {
-    if (system.clearScreen && !options.preserveWatchOutput && !options.extendedDiagnostics && !options.diagnostics && contains(screenStartingMessageCodes, diagnostic.code)) {
-      system.clearScreen();
-      return true;
+  function getBuildOrderFor(state, project, onlyReferences) {
+    const resolvedProject = project && resolveProjectName(state, project);
+    const buildOrderFromState = getBuildOrder(state);
+    if (isCircularBuildOrder(buildOrderFromState))
+      return buildOrderFromState;
+    if (resolvedProject) {
+      const projectPath = toResolvedConfigFilePath(state, resolvedProject);
+      const projectIndex = findIndex(
+        buildOrderFromState,
+        (configFileName) => toResolvedConfigFilePath(state, configFileName) === projectPath
+      );
+      if (projectIndex === -1)
+        return void 0;
     }
-    return false;
-  }
-  function getPlainDiagnosticFollowingNewLines(diagnostic, newLine) {
-    return contains(screenStartingMessageCodes, diagnostic.code) ? newLine + newLine : newLine;
+    const buildOrder = resolvedProject ? createBuildOrder(state, [resolvedProject]) : buildOrderFromState;
+    Debug.assert(!isCircularBuildOrder(buildOrder));
+    Debug.assert(!onlyReferences || resolvedProject !== void 0);
+    Debug.assert(!onlyReferences || buildOrder[buildOrder.length - 1] === resolvedProject);
+    return onlyReferences ? buildOrder.slice(0, buildOrder.length - 1) : buildOrder;
   }
-  function getLocaleTimeString(system) {
-    return !system.now ? (/* @__PURE__ */ new Date()).toLocaleTimeString() : (
-      // On some systems / builds of Node, there's a non-breaking space between the time and AM/PM.
-      // This branch is solely for testing, so just switch it to a normal space for baseline stability.
-      // See:
-      //     - https://github.com/nodejs/node/issues/45171
-      //     - https://github.com/nodejs/node/issues/45753
-      system.now().toLocaleTimeString("en-US", { timeZone: "UTC" }).replace("\u202F", " ")
+  function enableCache(state) {
+    if (state.cache) {
+      disableCache(state);
+    }
+    const { compilerHost, host } = state;
+    const originalReadFileWithCache = state.readFileWithCache;
+    const originalGetSourceFile = compilerHost.getSourceFile;
+    const {
+      originalReadFile,
+      originalFileExists,
+      originalDirectoryExists,
+      originalCreateDirectory,
+      originalWriteFile,
+      getSourceFileWithCache,
+      readFileWithCache
+    } = changeCompilerHostLikeToUseCache(
+      host,
+      (fileName) => toPath2(state, fileName),
+      (...args) => originalGetSourceFile.call(compilerHost, ...args)
     );
-  }
-  function createWatchStatusReporter(system, pretty) {
-    return pretty ? (diagnostic, newLine, options) => {
-      clearScreenIfNotWatchingForFileChanges(system, diagnostic, options);
-      let output = `[${formatColorAndReset(getLocaleTimeString(system), "\x1B[90m" /* Grey */)}] `;
-      output += `${flattenDiagnosticMessageText(diagnostic.messageText, system.newLine)}${newLine + newLine}`;
-      system.write(output);
-    } : (diagnostic, newLine, options) => {
-      let output = "";
-      if (!clearScreenIfNotWatchingForFileChanges(system, diagnostic, options)) {
-        output += newLine;
-      }
-      output += `${getLocaleTimeString(system)} - `;
-      output += `${flattenDiagnosticMessageText(diagnostic.messageText, system.newLine)}${getPlainDiagnosticFollowingNewLines(diagnostic, newLine)}`;
-      system.write(output);
+    state.readFileWithCache = readFileWithCache;
+    compilerHost.getSourceFile = getSourceFileWithCache;
+    state.cache = {
+      originalReadFile,
+      originalFileExists,
+      originalDirectoryExists,
+      originalCreateDirectory,
+      originalWriteFile,
+      originalReadFileWithCache,
+      originalGetSourceFile
     };
   }
-  function parseConfigFileWithSystem(configFileName, optionsToExtend, extendedConfigCache, watchOptionsToExtend, system, reportDiagnostic) {
-    const host = system;
-    host.onUnRecoverableConfigFileDiagnostic = (diagnostic) => reportUnrecoverableDiagnostic(system, reportDiagnostic, diagnostic);
-    const result = getParsedCommandLineOfConfigFile(configFileName, optionsToExtend, host, extendedConfigCache, watchOptionsToExtend);
-    host.onUnRecoverableConfigFileDiagnostic = void 0;
-    return result;
-  }
-  function getErrorCountForSummary(diagnostics) {
-    return countWhere(diagnostics, (diagnostic) => diagnostic.category === 1 /* Error */);
-  }
-  function getFilesInErrorForSummary(diagnostics) {
-    const filesInError = filter(diagnostics, (diagnostic) => diagnostic.category === 1 /* Error */).map(
-      (errorDiagnostic) => {
-        if (errorDiagnostic.file === void 0)
-          return;
-        return `${errorDiagnostic.file.fileName}`;
-      }
-    );
-    return filesInError.map((fileName) => {
-      if (fileName === void 0) {
-        return void 0;
-      }
-      const diagnosticForFileName = find(
-        diagnostics,
-        (diagnostic) => diagnostic.file !== void 0 && diagnostic.file.fileName === fileName
-      );
-      if (diagnosticForFileName !== void 0) {
-        const { line } = getLineAndCharacterOfPosition(diagnosticForFileName.file, diagnosticForFileName.start);
-        return {
-          fileName,
-          line: line + 1
-        };
-      }
-    });
+  function disableCache(state) {
+    if (!state.cache)
+      return;
+    const { cache, host, compilerHost, extendedConfigCache, moduleResolutionCache, typeReferenceDirectiveResolutionCache, libraryResolutionCache } = state;
+    host.readFile = cache.originalReadFile;
+    host.fileExists = cache.originalFileExists;
+    host.directoryExists = cache.originalDirectoryExists;
+    host.createDirectory = cache.originalCreateDirectory;
+    host.writeFile = cache.originalWriteFile;
+    compilerHost.getSourceFile = cache.originalGetSourceFile;
+    state.readFileWithCache = cache.originalReadFileWithCache;
+    extendedConfigCache.clear();
+    moduleResolutionCache == null ? void 0 : moduleResolutionCache.clear();
+    typeReferenceDirectiveResolutionCache == null ? void 0 : typeReferenceDirectiveResolutionCache.clear();
+    libraryResolutionCache == null ? void 0 : libraryResolutionCache.clear();
+    state.cache = void 0;
   }
-  function getWatchErrorSummaryDiagnosticMessage(errorCount) {
-    return errorCount === 1 ? Diagnostics.Found_1_error_Watching_for_file_changes : Diagnostics.Found_0_errors_Watching_for_file_changes;
+  function clearProjectStatus(state, resolved) {
+    state.projectStatus.delete(resolved);
+    state.diagnostics.delete(resolved);
   }
-  function prettyPathForFileError(error, cwd) {
-    const line = formatColorAndReset(":" + error.line, "\x1B[90m" /* Grey */);
-    if (pathIsAbsolute(error.fileName) && pathIsAbsolute(cwd)) {
-      return getRelativePathFromDirectory(
-        cwd,
-        error.fileName,
-        /*ignoreCase*/
-        false
-      ) + line;
+  function addProjToQueue({ projectPendingBuild }, proj, updateLevel) {
+    const value = projectPendingBuild.get(proj);
+    if (value === void 0) {
+      projectPendingBuild.set(proj, updateLevel);
+    } else if (value < updateLevel) {
+      projectPendingBuild.set(proj, updateLevel);
     }
-    return error.fileName + line;
   }
-  function getErrorSummaryText(errorCount, filesInError, newLine, host) {
-    if (errorCount === 0)
-      return "";
-    const nonNilFiles = filesInError.filter((fileInError) => fileInError !== void 0);
-    const distinctFileNamesWithLines = nonNilFiles.map((fileInError) => `${fileInError.fileName}:${fileInError.line}`).filter((value, index, self) => self.indexOf(value) === index);
-    const firstFileReference = nonNilFiles[0] && prettyPathForFileError(nonNilFiles[0], host.getCurrentDirectory());
-    let messageAndArgs;
-    if (errorCount === 1) {
-      messageAndArgs = filesInError[0] !== void 0 ? [Diagnostics.Found_1_error_in_0, firstFileReference] : [Diagnostics.Found_1_error];
-    } else {
-      messageAndArgs = distinctFileNamesWithLines.length === 0 ? [Diagnostics.Found_0_errors, errorCount] : distinctFileNamesWithLines.length === 1 ? [Diagnostics.Found_0_errors_in_the_same_file_starting_at_Colon_1, errorCount, firstFileReference] : [Diagnostics.Found_0_errors_in_1_files, errorCount, distinctFileNamesWithLines.length];
+  function setupInitialBuild(state, cancellationToken) {
+    if (!state.allProjectBuildPending)
+      return;
+    state.allProjectBuildPending = false;
+    if (state.options.watch)
+      reportWatchStatus(state, Diagnostics.Starting_compilation_in_watch_mode);
+    enableCache(state);
+    const buildOrder = getBuildOrderFromAnyBuildOrder(getBuildOrder(state));
+    buildOrder.forEach(
+      (configFileName) => state.projectPendingBuild.set(
+        toResolvedConfigFilePath(state, configFileName),
+        0 /* Update */
+      )
+    );
+    if (cancellationToken) {
+      cancellationToken.throwIfCancellationRequested();
     }
-    const d = createCompilerDiagnostic(...messageAndArgs);
-    const suffix = distinctFileNamesWithLines.length > 1 ? createTabularErrorsDisplay(nonNilFiles, host) : "";
-    return `${newLine}${flattenDiagnosticMessageText(d.messageText, newLine)}${newLine}${newLine}${suffix}`;
-  }
-  function createTabularErrorsDisplay(filesInError, host) {
-    const distinctFiles = filesInError.filter((value, index, self) => index === self.findIndex((file) => (file == null ? void 0 : file.fileName) === (value == null ? void 0 : value.fileName)));
-    if (distinctFiles.length === 0)
-      return "";
-    const numberLength = (num) => Math.log(num) * Math.LOG10E + 1;
-    const fileToErrorCount = distinctFiles.map((file) => [file, countWhere(filesInError, (fileInError) => fileInError.fileName === file.fileName)]);
-    const maxErrors = fileToErrorCount.reduce((acc, value) => Math.max(acc, value[1] || 0), 0);
-    const headerRow = Diagnostics.Errors_Files.message;
-    const leftColumnHeadingLength = headerRow.split(" ")[0].length;
-    const leftPaddingGoal = Math.max(leftColumnHeadingLength, numberLength(maxErrors));
-    const headerPadding = Math.max(numberLength(maxErrors) - leftColumnHeadingLength, 0);
-    let tabularData = "";
-    tabularData += " ".repeat(headerPadding) + headerRow + "\n";
-    fileToErrorCount.forEach((row) => {
-      const [file, errorCount] = row;
-      const errorCountDigitsLength = Math.log(errorCount) * Math.LOG10E + 1 | 0;
-      const leftPadding = errorCountDigitsLength < leftPaddingGoal ? " ".repeat(leftPaddingGoal - errorCountDigitsLength) : "";
-      const fileRef = prettyPathForFileError(file, host.getCurrentDirectory());
-      tabularData += `${leftPadding}${errorCount}  ${fileRef}
-`;
-    });
-    return tabularData;
   }
-  function isBuilderProgram2(program) {
-    return !!program.getState;
+  function doneInvalidatedProject(state, projectPath) {
+    state.projectPendingBuild.delete(projectPath);
+    return state.diagnostics.has(projectPath) ? 1 /* DiagnosticsPresent_OutputsSkipped */ : 0 /* Success */;
   }
-  function listFiles(program, write) {
-    const options = program.getCompilerOptions();
-    if (options.explainFiles) {
-      explainFiles(isBuilderProgram2(program) ? program.getProgram() : program, write);
-    } else if (options.listFiles || options.listFilesOnly) {
-      forEach(program.getSourceFiles(), (file) => {
-        write(file.fileName);
-      });
-    }
+  function createUpdateOutputFileStampsProject(state, project, projectPath, config, buildOrder) {
+    let updateOutputFileStampsPending = true;
+    return {
+      kind: 2 /* UpdateOutputFileStamps */,
+      project,
+      projectPath,
+      buildOrder,
+      getCompilerOptions: () => config.options,
+      getCurrentDirectory: () => state.compilerHost.getCurrentDirectory(),
+      updateOutputFileStatmps: () => {
+        updateOutputTimestamps(state, config, projectPath);
+        updateOutputFileStampsPending = false;
+      },
+      done: () => {
+        if (updateOutputFileStampsPending) {
+          updateOutputTimestamps(state, config, projectPath);
+        }
+        mark("SolutionBuilder::Timestamps only updates");
+        return doneInvalidatedProject(state, projectPath);
+      }
+    };
   }
-  function explainFiles(program, write) {
-    var _a, _b;
-    const reasons = program.getFileIncludeReasons();
-    const relativeFileName = (fileName) => convertToRelativePath(fileName, program.getCurrentDirectory(), program.getCanonicalFileName);
-    for (const file of program.getSourceFiles()) {
-      write(`${toFileName(file, relativeFileName)}`);
-      (_a = reasons.get(file.path)) == null ? void 0 : _a.forEach((reason) => write(`  ${fileIncludeReasonToDiagnostics(program, reason, relativeFileName).messageText}`));
-      (_b = explainIfFileIsRedirectAndImpliedFormat(file, relativeFileName)) == null ? void 0 : _b.forEach((d) => write(`  ${d.messageText}`));
+  function createBuildOrUpdateInvalidedProject(kind, state, project, projectPath, projectIndex, config, buildOrder) {
+    let step = kind === 0 /* Build */ ? 0 /* CreateProgram */ : 4 /* EmitBundle */;
+    let program;
+    let buildResult;
+    let invalidatedProjectOfBundle;
+    return kind === 0 /* Build */ ? {
+      kind,
+      project,
+      projectPath,
+      buildOrder,
+      getCompilerOptions: () => config.options,
+      getCurrentDirectory: () => state.compilerHost.getCurrentDirectory(),
+      getBuilderProgram: () => withProgramOrUndefined(identity),
+      getProgram: () => withProgramOrUndefined(
+        (program2) => program2.getProgramOrUndefined()
+      ),
+      getSourceFile: (fileName) => withProgramOrUndefined(
+        (program2) => program2.getSourceFile(fileName)
+      ),
+      getSourceFiles: () => withProgramOrEmptyArray(
+        (program2) => program2.getSourceFiles()
+      ),
+      getOptionsDiagnostics: (cancellationToken) => withProgramOrEmptyArray(
+        (program2) => program2.getOptionsDiagnostics(cancellationToken)
+      ),
+      getGlobalDiagnostics: (cancellationToken) => withProgramOrEmptyArray(
+        (program2) => program2.getGlobalDiagnostics(cancellationToken)
+      ),
+      getConfigFileParsingDiagnostics: () => withProgramOrEmptyArray(
+        (program2) => program2.getConfigFileParsingDiagnostics()
+      ),
+      getSyntacticDiagnostics: (sourceFile, cancellationToken) => withProgramOrEmptyArray(
+        (program2) => program2.getSyntacticDiagnostics(sourceFile, cancellationToken)
+      ),
+      getAllDependencies: (sourceFile) => withProgramOrEmptyArray(
+        (program2) => program2.getAllDependencies(sourceFile)
+      ),
+      getSemanticDiagnostics: (sourceFile, cancellationToken) => withProgramOrEmptyArray(
+        (program2) => program2.getSemanticDiagnostics(sourceFile, cancellationToken)
+      ),
+      getSemanticDiagnosticsOfNextAffectedFile: (cancellationToken, ignoreSourceFile) => withProgramOrUndefined(
+        (program2) => program2.getSemanticDiagnosticsOfNextAffectedFile && program2.getSemanticDiagnosticsOfNextAffectedFile(cancellationToken, ignoreSourceFile)
+      ),
+      emit: (targetSourceFile, writeFile2, cancellationToken, emitOnlyDtsFiles, customTransformers) => {
+        if (targetSourceFile || emitOnlyDtsFiles) {
+          return withProgramOrUndefined(
+            (program2) => {
+              var _a, _b;
+              return program2.emit(targetSourceFile, writeFile2, cancellationToken, emitOnlyDtsFiles, customTransformers || ((_b = (_a = state.host).getCustomTransformers) == null ? void 0 : _b.call(_a, project)));
+            }
+          );
+        }
+        executeSteps(2 /* SemanticDiagnostics */, cancellationToken);
+        if (step === 5 /* EmitBuildInfo */) {
+          return emitBuildInfo(writeFile2, cancellationToken);
+        }
+        if (step !== 3 /* Emit */)
+          return void 0;
+        return emit(writeFile2, cancellationToken, customTransformers);
+      },
+      done
+    } : {
+      kind,
+      project,
+      projectPath,
+      buildOrder,
+      getCompilerOptions: () => config.options,
+      getCurrentDirectory: () => state.compilerHost.getCurrentDirectory(),
+      emit: (writeFile2, customTransformers) => {
+        if (step !== 4 /* EmitBundle */)
+          return invalidatedProjectOfBundle;
+        return emitBundle(writeFile2, customTransformers);
+      },
+      done
+    };
+    function done(cancellationToken, writeFile2, customTransformers) {
+      executeSteps(8 /* Done */, cancellationToken, writeFile2, customTransformers);
+      if (kind === 0 /* Build */)
+        mark("SolutionBuilder::Projects built");
+      else
+        mark("SolutionBuilder::Bundles updated");
+      return doneInvalidatedProject(state, projectPath);
     }
-  }
-  function explainIfFileIsRedirectAndImpliedFormat(file, fileNameConvertor) {
-    var _a;
-    let result;
-    if (file.path !== file.resolvedPath) {
-      (result ?? (result = [])).push(chainDiagnosticMessages(
-        /*details*/
-        void 0,
-        Diagnostics.File_is_output_of_project_reference_source_0,
-        toFileName(file.originalFileName, fileNameConvertor)
-      ));
+    function withProgramOrUndefined(action) {
+      executeSteps(0 /* CreateProgram */);
+      return program && action(program);
     }
-    if (file.redirectInfo) {
-      (result ?? (result = [])).push(chainDiagnosticMessages(
-        /*details*/
-        void 0,
-        Diagnostics.File_redirects_to_file_0,
-        toFileName(file.redirectInfo.redirectTarget, fileNameConvertor)
-      ));
+    function withProgramOrEmptyArray(action) {
+      return withProgramOrUndefined(action) || emptyArray;
     }
-    if (isExternalOrCommonJsModule(file)) {
-      switch (file.impliedNodeFormat) {
-        case 99 /* ESNext */:
-          if (file.packageJsonScope) {
-            (result ?? (result = [])).push(chainDiagnosticMessages(
-              /*details*/
-              void 0,
-              Diagnostics.File_is_ECMAScript_module_because_0_has_field_type_with_value_module,
-              toFileName(last(file.packageJsonLocations), fileNameConvertor)
-            ));
-          }
-          break;
-        case 1 /* CommonJS */:
-          if (file.packageJsonScope) {
-            (result ?? (result = [])).push(chainDiagnosticMessages(
-              /*details*/
-              void 0,
-              file.packageJsonScope.contents.packageJsonContent.type ? Diagnostics.File_is_CommonJS_module_because_0_has_field_type_whose_value_is_not_module : Diagnostics.File_is_CommonJS_module_because_0_does_not_have_field_type,
-              toFileName(last(file.packageJsonLocations), fileNameConvertor)
-            ));
-          } else if ((_a = file.packageJsonLocations) == null ? void 0 : _a.length) {
-            (result ?? (result = [])).push(chainDiagnosticMessages(
-              /*details*/
-              void 0,
-              Diagnostics.File_is_CommonJS_module_because_package_json_was_not_found
-            ));
-          }
-          break;
+    function createProgram2() {
+      var _a, _b;
+      Debug.assert(program === void 0);
+      if (state.options.dry) {
+        reportStatus(state, Diagnostics.A_non_dry_build_would_build_project_0, project);
+        buildResult = 1 /* Success */;
+        step = 7 /* QueueReferencingProjects */;
+        return;
       }
-    }
-    return result;
-  }
-  function getMatchedFileSpec(program, fileName) {
-    var _a;
-    const configFile = program.getCompilerOptions().configFile;
-    if (!((_a = configFile == null ? void 0 : configFile.configFileSpecs) == null ? void 0 : _a.validatedFilesSpec))
-      return void 0;
-    const filePath = program.getCanonicalFileName(fileName);
-    const basePath = getDirectoryPath(getNormalizedAbsolutePath(configFile.fileName, program.getCurrentDirectory()));
-    return find(configFile.configFileSpecs.validatedFilesSpec, (fileSpec) => program.getCanonicalFileName(getNormalizedAbsolutePath(fileSpec, basePath)) === filePath);
-  }
-  function getMatchedIncludeSpec(program, fileName) {
-    var _a, _b;
-    const configFile = program.getCompilerOptions().configFile;
-    if (!((_a = configFile == null ? void 0 : configFile.configFileSpecs) == null ? void 0 : _a.validatedIncludeSpecs))
-      return void 0;
-    if (configFile.configFileSpecs.isDefaultIncludeSpec)
-      return true;
-    const isJsonFile = fileExtensionIs(fileName, ".json" /* Json */);
-    const basePath = getDirectoryPath(getNormalizedAbsolutePath(configFile.fileName, program.getCurrentDirectory()));
-    const useCaseSensitiveFileNames = program.useCaseSensitiveFileNames();
-    return find((_b = configFile == null ? void 0 : configFile.configFileSpecs) == null ? void 0 : _b.validatedIncludeSpecs, (includeSpec) => {
-      if (isJsonFile && !endsWith(includeSpec, ".json" /* Json */))
-        return false;
-      const pattern = getPatternFromSpec(includeSpec, basePath, "files");
-      return !!pattern && getRegexFromPattern(`(${pattern})$`, useCaseSensitiveFileNames).test(fileName);
-    });
-  }
-  function fileIncludeReasonToDiagnostics(program, reason, fileNameConvertor) {
-    var _a, _b;
-    const options = program.getCompilerOptions();
-    if (isReferencedFile(reason)) {
-      const referenceLocation = getReferencedFileLocation((path) => program.getSourceFileByPath(path), reason);
-      const referenceText = isReferenceFileLocation(referenceLocation) ? referenceLocation.file.text.substring(referenceLocation.pos, referenceLocation.end) : `"${referenceLocation.text}"`;
-      let message;
-      Debug.assert(isReferenceFileLocation(referenceLocation) || reason.kind === 3 /* Import */, "Only synthetic references are imports");
-      switch (reason.kind) {
-        case 3 /* Import */:
-          if (isReferenceFileLocation(referenceLocation)) {
-            message = referenceLocation.packageId ? Diagnostics.Imported_via_0_from_file_1_with_packageId_2 : Diagnostics.Imported_via_0_from_file_1;
-          } else if (referenceLocation.text === externalHelpersModuleNameText) {
-            message = referenceLocation.packageId ? Diagnostics.Imported_via_0_from_file_1_with_packageId_2_to_import_importHelpers_as_specified_in_compilerOptions : Diagnostics.Imported_via_0_from_file_1_to_import_importHelpers_as_specified_in_compilerOptions;
-          } else {
-            message = referenceLocation.packageId ? Diagnostics.Imported_via_0_from_file_1_with_packageId_2_to_import_jsx_and_jsxs_factory_functions : Diagnostics.Imported_via_0_from_file_1_to_import_jsx_and_jsxs_factory_functions;
-          }
-          break;
-        case 4 /* ReferenceFile */:
-          Debug.assert(!referenceLocation.packageId);
-          message = Diagnostics.Referenced_via_0_from_file_1;
-          break;
-        case 5 /* TypeReferenceDirective */:
-          message = referenceLocation.packageId ? Diagnostics.Type_library_referenced_via_0_from_file_1_with_packageId_2 : Diagnostics.Type_library_referenced_via_0_from_file_1;
-          break;
-        case 7 /* LibReferenceDirective */:
-          Debug.assert(!referenceLocation.packageId);
-          message = Diagnostics.Library_referenced_via_0_from_file_1;
-          break;
-        default:
-          Debug.assertNever(reason);
+      if (state.options.verbose)
+        reportStatus(state, Diagnostics.Building_project_0, project);
+      if (config.fileNames.length === 0) {
+        reportAndStoreErrors(state, projectPath, getConfigFileParsingDiagnostics(config));
+        buildResult = 0 /* None */;
+        step = 7 /* QueueReferencingProjects */;
+        return;
       }
-      return chainDiagnosticMessages(
-        /*details*/
-        void 0,
-        message,
-        referenceText,
-        toFileName(referenceLocation.file, fileNameConvertor),
-        referenceLocation.packageId && packageIdToString(referenceLocation.packageId)
+      const { host, compilerHost } = state;
+      state.projectCompilerOptions = config.options;
+      (_a = state.moduleResolutionCache) == null ? void 0 : _a.update(config.options);
+      (_b = state.typeReferenceDirectiveResolutionCache) == null ? void 0 : _b.update(config.options);
+      program = host.createProgram(
+        config.fileNames,
+        config.options,
+        compilerHost,
+        getOldProgram(state, projectPath, config),
+        getConfigFileParsingDiagnostics(config),
+        config.projectReferences
       );
-    }
-    switch (reason.kind) {
-      case 0 /* RootFile */:
-        if (!((_a = options.configFile) == null ? void 0 : _a.configFileSpecs))
-          return chainDiagnosticMessages(
-            /*details*/
-            void 0,
-            Diagnostics.Root_file_specified_for_compilation
-          );
-        const fileName = getNormalizedAbsolutePath(program.getRootFileNames()[reason.index], program.getCurrentDirectory());
-        const matchedByFiles = getMatchedFileSpec(program, fileName);
-        if (matchedByFiles)
-          return chainDiagnosticMessages(
-            /*details*/
-            void 0,
-            Diagnostics.Part_of_files_list_in_tsconfig_json
-          );
-        const matchedByInclude = getMatchedIncludeSpec(program, fileName);
-        return isString(matchedByInclude) ? chainDiagnosticMessages(
-          /*details*/
-          void 0,
-          Diagnostics.Matched_by_include_pattern_0_in_1,
-          matchedByInclude,
-          toFileName(options.configFile, fileNameConvertor)
-        ) : (
-          // Could be additional files specified as roots or matched by default include
-          chainDiagnosticMessages(
-            /*details*/
-            void 0,
-            matchedByInclude ? Diagnostics.Matched_by_default_include_pattern_Asterisk_Asterisk_Slash_Asterisk : Diagnostics.Root_file_specified_for_compilation
+      if (state.watch) {
+        state.lastCachedPackageJsonLookups.set(
+          projectPath,
+          state.moduleResolutionCache && map(
+            state.moduleResolutionCache.getPackageJsonInfoCache().entries(),
+            ([path, data]) => [state.host.realpath && data ? toPath2(state, state.host.realpath(path)) : path, data]
           )
         );
-      case 1 /* SourceFromProjectReference */:
-      case 2 /* OutputFromProjectReference */:
-        const isOutput = reason.kind === 2 /* OutputFromProjectReference */;
-        const referencedResolvedRef = Debug.checkDefined((_b = program.getResolvedProjectReferences()) == null ? void 0 : _b[reason.index]);
-        return chainDiagnosticMessages(
-          /*details*/
-          void 0,
-          outFile(options) ? isOutput ? Diagnostics.Output_from_referenced_project_0_included_because_1_specified : Diagnostics.Source_from_referenced_project_0_included_because_1_specified : isOutput ? Diagnostics.Output_from_referenced_project_0_included_because_module_is_specified_as_none : Diagnostics.Source_from_referenced_project_0_included_because_module_is_specified_as_none,
-          toFileName(referencedResolvedRef.sourceFile.fileName, fileNameConvertor),
-          options.outFile ? "--outFile" : "--out"
-        );
-      case 8 /* AutomaticTypeDirectiveFile */: {
-        const messageAndArgs = options.types ? reason.packageId ? [Diagnostics.Entry_point_of_type_library_0_specified_in_compilerOptions_with_packageId_1, reason.typeReference, packageIdToString(reason.packageId)] : [Diagnostics.Entry_point_of_type_library_0_specified_in_compilerOptions, reason.typeReference] : reason.packageId ? [Diagnostics.Entry_point_for_implicit_type_library_0_with_packageId_1, reason.typeReference, packageIdToString(reason.packageId)] : [Diagnostics.Entry_point_for_implicit_type_library_0, reason.typeReference];
-        return chainDiagnosticMessages(
-          /*details*/
-          void 0,
-          ...messageAndArgs
-        );
+        state.builderPrograms.set(projectPath, program);
       }
-      case 6 /* LibFile */: {
-        if (reason.index !== void 0)
-          return chainDiagnosticMessages(
-            /*details*/
-            void 0,
-            Diagnostics.Library_0_specified_in_compilerOptions,
-            options.lib[reason.index]
-          );
-        const target = forEachEntry(targetOptionDeclaration.type, (value, key) => value === getEmitScriptTarget(options) ? key : void 0);
-        const messageAndArgs = target ? [Diagnostics.Default_library_for_target_0, target] : [Diagnostics.Default_library];
-        return chainDiagnosticMessages(
-          /*details*/
-          void 0,
-          ...messageAndArgs
-        );
+      step++;
+    }
+    function handleDiagnostics(diagnostics, errorFlags, errorType) {
+      if (diagnostics.length) {
+        ({ buildResult, step } = buildErrors(
+          state,
+          projectPath,
+          program,
+          config,
+          diagnostics,
+          errorFlags,
+          errorType
+        ));
+      } else {
+        step++;
       }
-      default:
-        Debug.assertNever(reason);
     }
-  }
-  function toFileName(file, fileNameConvertor) {
-    const fileName = isString(file) ? file : file.fileName;
-    return fileNameConvertor ? fileNameConvertor(fileName) : fileName;
-  }
-  function emitFilesAndReportErrors(program, reportDiagnostic, write, reportSummary, writeFile2, cancellationToken, emitOnlyDtsFiles, customTransformers) {
-    const isListFilesOnly = !!program.getCompilerOptions().listFilesOnly;
-    const allDiagnostics = program.getConfigFileParsingDiagnostics().slice();
-    const configFileParsingDiagnosticsLength = allDiagnostics.length;
-    addRange(allDiagnostics, program.getSyntacticDiagnostics(
-      /*sourceFile*/
-      void 0,
-      cancellationToken
-    ));
-    if (allDiagnostics.length === configFileParsingDiagnosticsLength) {
-      addRange(allDiagnostics, program.getOptionsDiagnostics(cancellationToken));
-      if (!isListFilesOnly) {
-        addRange(allDiagnostics, program.getGlobalDiagnostics(cancellationToken));
-        if (allDiagnostics.length === configFileParsingDiagnosticsLength) {
-          addRange(allDiagnostics, program.getSemanticDiagnostics(
+    function getSyntaxDiagnostics(cancellationToken) {
+      Debug.assertIsDefined(program);
+      handleDiagnostics(
+        [
+          ...program.getConfigFileParsingDiagnostics(),
+          ...program.getOptionsDiagnostics(cancellationToken),
+          ...program.getGlobalDiagnostics(cancellationToken),
+          ...program.getSyntacticDiagnostics(
             /*sourceFile*/
             void 0,
             cancellationToken
-          ));
+          )
+        ],
+        8 /* SyntaxErrors */,
+        "Syntactic"
+      );
+    }
+    function getSemanticDiagnostics(cancellationToken) {
+      handleDiagnostics(
+        Debug.checkDefined(program).getSemanticDiagnostics(
+          /*sourceFile*/
+          void 0,
+          cancellationToken
+        ),
+        16 /* TypeErrors */,
+        "Semantic"
+      );
+    }
+    function emit(writeFileCallback, cancellationToken, customTransformers) {
+      var _a, _b, _c;
+      Debug.assertIsDefined(program);
+      Debug.assert(step === 3 /* Emit */);
+      const saved = program.saveEmitState();
+      let declDiagnostics;
+      const reportDeclarationDiagnostics = (d) => (declDiagnostics || (declDiagnostics = [])).push(d);
+      const outputFiles = [];
+      const { emitResult } = emitFilesAndReportErrors(
+        program,
+        reportDeclarationDiagnostics,
+        /*write*/
+        void 0,
+        /*reportSummary*/
+        void 0,
+        (name, text, writeByteOrderMark, _onError, _sourceFiles, data) => outputFiles.push({ name, text, writeByteOrderMark, data }),
+        cancellationToken,
+        /*emitOnlyDtsFiles*/
+        false,
+        customTransformers || ((_b = (_a = state.host).getCustomTransformers) == null ? void 0 : _b.call(_a, project))
+      );
+      if (declDiagnostics) {
+        program.restoreEmitState(saved);
+        ({ buildResult, step } = buildErrors(
+          state,
+          projectPath,
+          program,
+          config,
+          declDiagnostics,
+          32 /* DeclarationEmitErrors */,
+          "Declaration file"
+        ));
+        return {
+          emitSkipped: true,
+          diagnostics: emitResult.diagnostics
+        };
+      }
+      const { host, compilerHost } = state;
+      const resultFlags = ((_c = program.hasChangedEmitSignature) == null ? void 0 : _c.call(program)) ? 0 /* None */ : 2 /* DeclarationOutputUnchanged */;
+      const emitterDiagnostics = createDiagnosticCollection();
+      const emittedOutputs = /* @__PURE__ */ new Map();
+      const options = program.getCompilerOptions();
+      const isIncremental = isIncrementalCompilation(options);
+      let outputTimeStampMap;
+      let now;
+      outputFiles.forEach(({ name, text, writeByteOrderMark, data }) => {
+        const path = toPath2(state, name);
+        emittedOutputs.set(toPath2(state, name), name);
+        if (data == null ? void 0 : data.buildInfo)
+          setBuildInfo(state, data.buildInfo, projectPath, options, resultFlags);
+        const modifiedTime = (data == null ? void 0 : data.differsOnlyInMap) ? getModifiedTime(state.host, name) : void 0;
+        writeFile(writeFileCallback ? { writeFile: writeFileCallback } : compilerHost, emitterDiagnostics, name, text, writeByteOrderMark);
+        if (data == null ? void 0 : data.differsOnlyInMap)
+          state.host.setModifiedTime(name, modifiedTime);
+        else if (!isIncremental && state.watch) {
+          (outputTimeStampMap || (outputTimeStampMap = getOutputTimeStampMap(state, projectPath))).set(path, now || (now = getCurrentTime(state.host)));
         }
+      });
+      finishEmit(
+        emitterDiagnostics,
+        emittedOutputs,
+        outputFiles.length ? outputFiles[0].name : getFirstProjectOutput(config, !host.useCaseSensitiveFileNames()),
+        resultFlags
+      );
+      return emitResult;
+    }
+    function emitBuildInfo(writeFileCallback, cancellationToken) {
+      Debug.assertIsDefined(program);
+      Debug.assert(step === 5 /* EmitBuildInfo */);
+      const emitResult = program.emitBuildInfo((name, text, writeByteOrderMark, onError, sourceFiles, data) => {
+        if (data == null ? void 0 : data.buildInfo)
+          setBuildInfo(state, data.buildInfo, projectPath, program.getCompilerOptions(), 2 /* DeclarationOutputUnchanged */);
+        if (writeFileCallback)
+          writeFileCallback(name, text, writeByteOrderMark, onError, sourceFiles, data);
+        else
+          state.compilerHost.writeFile(name, text, writeByteOrderMark, onError, sourceFiles, data);
+      }, cancellationToken);
+      if (emitResult.diagnostics.length) {
+        reportErrors(state, emitResult.diagnostics);
+        state.diagnostics.set(projectPath, [...state.diagnostics.get(projectPath), ...emitResult.diagnostics]);
+        buildResult = 64 /* EmitErrors */ & buildResult;
+      }
+      if (emitResult.emittedFiles && state.write) {
+        emitResult.emittedFiles.forEach((name) => listEmittedFile(state, config, name));
       }
+      afterProgramDone(state, program, config);
+      step = 7 /* QueueReferencingProjects */;
+      return emitResult;
     }
-    const emitResult = isListFilesOnly ? { emitSkipped: true, diagnostics: emptyArray } : program.emit(
-      /*targetSourceFile*/
-      void 0,
-      writeFile2,
-      cancellationToken,
-      emitOnlyDtsFiles,
-      customTransformers
-    );
-    const { emittedFiles, diagnostics: emitDiagnostics } = emitResult;
-    addRange(allDiagnostics, emitDiagnostics);
-    const diagnostics = sortAndDeduplicateDiagnostics(allDiagnostics);
-    diagnostics.forEach(reportDiagnostic);
-    if (write) {
-      const currentDir = program.getCurrentDirectory();
-      forEach(emittedFiles, (file) => {
-        const filepath = getNormalizedAbsolutePath(file, currentDir);
-        write(`TSFILE: ${filepath}`);
+    function finishEmit(emitterDiagnostics, emittedOutputs, oldestOutputFileName, resultFlags) {
+      const emitDiagnostics = emitterDiagnostics.getDiagnostics();
+      if (emitDiagnostics.length) {
+        ({ buildResult, step } = buildErrors(
+          state,
+          projectPath,
+          program,
+          config,
+          emitDiagnostics,
+          64 /* EmitErrors */,
+          "Emit"
+        ));
+        return emitDiagnostics;
+      }
+      if (state.write) {
+        emittedOutputs.forEach((name) => listEmittedFile(state, config, name));
+      }
+      updateOutputTimestampsWorker(state, config, projectPath, Diagnostics.Updating_unchanged_output_timestamps_of_project_0, emittedOutputs);
+      state.diagnostics.delete(projectPath);
+      state.projectStatus.set(projectPath, {
+        type: 1 /* UpToDate */,
+        oldestOutputFileName
       });
-      listFiles(program, write);
+      afterProgramDone(state, program, config);
+      step = 7 /* QueueReferencingProjects */;
+      buildResult = resultFlags;
+      return emitDiagnostics;
     }
-    if (reportSummary) {
-      reportSummary(getErrorCountForSummary(diagnostics), getFilesInErrorForSummary(diagnostics));
+    function emitBundle(writeFileCallback, customTransformers) {
+      var _a, _b, _c, _d;
+      Debug.assert(kind === 1 /* UpdateBundle */);
+      if (state.options.dry) {
+        reportStatus(state, Diagnostics.A_non_dry_build_would_update_output_of_project_0, project);
+        buildResult = 1 /* Success */;
+        step = 7 /* QueueReferencingProjects */;
+        return void 0;
+      }
+      if (state.options.verbose)
+        reportStatus(state, Diagnostics.Updating_output_of_project_0, project);
+      const { compilerHost } = state;
+      state.projectCompilerOptions = config.options;
+      (_b = (_a = state.host).beforeEmitBundle) == null ? void 0 : _b.call(_a, config);
+      const outputFiles = emitUsingBuildInfo(
+        config,
+        compilerHost,
+        (ref) => {
+          const refName = resolveProjectName(state, ref.path);
+          return parseConfigFile(state, refName, toResolvedConfigFilePath(state, refName));
+        },
+        customTransformers || ((_d = (_c = state.host).getCustomTransformers) == null ? void 0 : _d.call(_c, project))
+      );
+      if (isString(outputFiles)) {
+        reportStatus(state, Diagnostics.Cannot_update_output_of_project_0_because_there_was_error_reading_file_1, project, relName(state, outputFiles));
+        step = 6 /* BuildInvalidatedProjectOfBundle */;
+        return invalidatedProjectOfBundle = createBuildOrUpdateInvalidedProject(
+          0 /* Build */,
+          state,
+          project,
+          projectPath,
+          projectIndex,
+          config,
+          buildOrder
+        );
+      }
+      Debug.assert(!!outputFiles.length);
+      const emitterDiagnostics = createDiagnosticCollection();
+      const emittedOutputs = /* @__PURE__ */ new Map();
+      let resultFlags = 2 /* DeclarationOutputUnchanged */;
+      const existingBuildInfo = state.buildInfoCache.get(projectPath).buildInfo || void 0;
+      outputFiles.forEach(({ name, text, writeByteOrderMark, data }) => {
+        var _a2, _b2;
+        emittedOutputs.set(toPath2(state, name), name);
+        if (data == null ? void 0 : data.buildInfo) {
+          if (((_a2 = data.buildInfo.program) == null ? void 0 : _a2.outSignature) !== ((_b2 = existingBuildInfo == null ? void 0 : existingBuildInfo.program) == null ? void 0 : _b2.outSignature)) {
+            resultFlags &= ~2 /* DeclarationOutputUnchanged */;
+          }
+          setBuildInfo(state, data.buildInfo, projectPath, config.options, resultFlags);
+        }
+        writeFile(writeFileCallback ? { writeFile: writeFileCallback } : compilerHost, emitterDiagnostics, name, text, writeByteOrderMark);
+      });
+      const emitDiagnostics = finishEmit(
+        emitterDiagnostics,
+        emittedOutputs,
+        outputFiles[0].name,
+        resultFlags
+      );
+      return { emitSkipped: false, diagnostics: emitDiagnostics };
     }
-    return {
-      emitResult,
-      diagnostics
-    };
-  }
-  function emitFilesAndReportErrorsAndGetExitStatus(program, reportDiagnostic, write, reportSummary, writeFile2, cancellationToken, emitOnlyDtsFiles, customTransformers) {
-    const { emitResult, diagnostics } = emitFilesAndReportErrors(
-      program,
-      reportDiagnostic,
-      write,
-      reportSummary,
-      writeFile2,
-      cancellationToken,
-      emitOnlyDtsFiles,
-      customTransformers
-    );
-    if (emitResult.emitSkipped && diagnostics.length > 0) {
-      return 1 /* DiagnosticsPresent_OutputsSkipped */;
-    } else if (diagnostics.length > 0) {
-      return 2 /* DiagnosticsPresent_OutputsGenerated */;
+    function executeSteps(till, cancellationToken, writeFile2, customTransformers) {
+      while (step <= till && step < 8 /* Done */) {
+        const currentStep = step;
+        switch (step) {
+          case 0 /* CreateProgram */:
+            createProgram2();
+            break;
+          case 1 /* SyntaxDiagnostics */:
+            getSyntaxDiagnostics(cancellationToken);
+            break;
+          case 2 /* SemanticDiagnostics */:
+            getSemanticDiagnostics(cancellationToken);
+            break;
+          case 3 /* Emit */:
+            emit(writeFile2, cancellationToken, customTransformers);
+            break;
+          case 5 /* EmitBuildInfo */:
+            emitBuildInfo(writeFile2, cancellationToken);
+            break;
+          case 4 /* EmitBundle */:
+            emitBundle(writeFile2, customTransformers);
+            break;
+          case 6 /* BuildInvalidatedProjectOfBundle */:
+            Debug.checkDefined(invalidatedProjectOfBundle).done(cancellationToken, writeFile2, customTransformers);
+            step = 8 /* Done */;
+            break;
+          case 7 /* QueueReferencingProjects */:
+            queueReferencingProjects(state, project, projectPath, projectIndex, config, buildOrder, Debug.checkDefined(buildResult));
+            step++;
+            break;
+          case 8 /* Done */:
+          default:
+            assertType(step);
+        }
+        Debug.assert(step > currentStep);
+      }
     }
-    return 0 /* Success */;
-  }
-  function createWatchHost(system = sys, reportWatchStatus2) {
-    const onWatchStatusChange = reportWatchStatus2 || createWatchStatusReporter(system);
-    return {
-      onWatchStatusChange,
-      watchFile: maybeBind(system, system.watchFile) || returnNoopFileWatcher,
-      watchDirectory: maybeBind(system, system.watchDirectory) || returnNoopFileWatcher,
-      setTimeout: maybeBind(system, system.setTimeout) || noop,
-      clearTimeout: maybeBind(system, system.clearTimeout) || noop
-    };
   }
-  function createWatchFactory(host, options) {
-    const watchLogLevel = host.trace ? options.extendedDiagnostics ? 2 /* Verbose */ : options.diagnostics ? 1 /* TriggerOnly */ : 0 /* None */ : 0 /* None */;
-    const writeLog = watchLogLevel !== 0 /* None */ ? (s) => host.trace(s) : noop;
-    const result = getWatchFactory(host, watchLogLevel, writeLog);
-    result.writeLog = writeLog;
-    return result;
-  }
-  function createCompilerHostFromProgramHost(host, getCompilerOptions, directoryStructureHost = host) {
-    const useCaseSensitiveFileNames = host.useCaseSensitiveFileNames();
-    const compilerHost = {
-      getSourceFile: createGetSourceFile(
-        (fileName, encoding) => !encoding ? compilerHost.readFile(fileName) : host.readFile(fileName, encoding),
-        getCompilerOptions,
-        /*setParentNodes*/
-        void 0
-      ),
-      getDefaultLibLocation: maybeBind(host, host.getDefaultLibLocation),
-      getDefaultLibFileName: (options) => host.getDefaultLibFileName(options),
-      writeFile: createWriteFileMeasuringIO(
-        (path, data, writeByteOrderMark) => host.writeFile(path, data, writeByteOrderMark),
-        (path) => host.createDirectory(path),
-        (path) => host.directoryExists(path)
-      ),
-      getCurrentDirectory: memoize(() => host.getCurrentDirectory()),
-      useCaseSensitiveFileNames: () => useCaseSensitiveFileNames,
-      getCanonicalFileName: createGetCanonicalFileName(useCaseSensitiveFileNames),
-      getNewLine: () => getNewLineCharacter(getCompilerOptions()),
-      fileExists: (f) => host.fileExists(f),
-      readFile: (f) => host.readFile(f),
-      trace: maybeBind(host, host.trace),
-      directoryExists: maybeBind(directoryStructureHost, directoryStructureHost.directoryExists),
-      getDirectories: maybeBind(directoryStructureHost, directoryStructureHost.getDirectories),
-      realpath: maybeBind(host, host.realpath),
-      getEnvironmentVariable: maybeBind(host, host.getEnvironmentVariable) || (() => ""),
-      createHash: maybeBind(host, host.createHash),
-      readDirectory: maybeBind(host, host.readDirectory),
-      storeFilesChangingSignatureDuringEmit: host.storeFilesChangingSignatureDuringEmit
-    };
-    return compilerHost;
+  function needsBuild({ options }, status, config) {
+    if (status.type !== 3 /* OutOfDateWithPrepend */ || options.force)
+      return true;
+    return config.fileNames.length === 0 || !!getConfigFileParsingDiagnostics(config).length || !isIncrementalCompilation(config.options);
   }
-  function getSourceFileVersionAsHashFromText(host, text) {
-    if (text.match(sourceMapCommentRegExpDontCareLineStart)) {
-      let lineEnd = text.length;
-      let lineStart = lineEnd;
-      for (let pos = lineEnd - 1; pos >= 0; pos--) {
-        const ch = text.charCodeAt(pos);
-        switch (ch) {
-          case 10 /* lineFeed */:
-            if (pos && text.charCodeAt(pos - 1) === 13 /* carriageReturn */) {
-              pos--;
-            }
-          case 13 /* carriageReturn */:
-            break;
-          default:
-            if (ch < 127 /* maxAsciiCharacter */ || !isLineBreak(ch)) {
-              lineStart = pos;
-              continue;
-            }
-            break;
+  function getNextInvalidatedProjectCreateInfo(state, buildOrder, reportQueue) {
+    if (!state.projectPendingBuild.size)
+      return void 0;
+    if (isCircularBuildOrder(buildOrder))
+      return void 0;
+    const { options, projectPendingBuild } = state;
+    for (let projectIndex = 0; projectIndex < buildOrder.length; projectIndex++) {
+      const project = buildOrder[projectIndex];
+      const projectPath = toResolvedConfigFilePath(state, project);
+      const updateLevel = state.projectPendingBuild.get(projectPath);
+      if (updateLevel === void 0)
+        continue;
+      if (reportQueue) {
+        reportQueue = false;
+        reportBuildQueue(state, buildOrder);
+      }
+      const config = parseConfigFile(state, project, projectPath);
+      if (!config) {
+        reportParseConfigFileDiagnostic(state, projectPath);
+        projectPendingBuild.delete(projectPath);
+        continue;
+      }
+      if (updateLevel === 2 /* Full */) {
+        watchConfigFile(state, project, projectPath, config);
+        watchExtendedConfigFiles(state, projectPath, config);
+        watchWildCardDirectories(state, project, projectPath, config);
+        watchInputFiles(state, project, projectPath, config);
+        watchPackageJsonFiles(state, project, projectPath, config);
+      } else if (updateLevel === 1 /* RootNamesAndUpdate */) {
+        config.fileNames = getFileNamesFromConfigSpecs(config.options.configFile.configFileSpecs, getDirectoryPath(project), config.options, state.parseConfigFileHost);
+        updateErrorForNoInputFiles(config.fileNames, project, config.options.configFile.configFileSpecs, config.errors, canJsonReportNoInputFiles(config.raw));
+        watchInputFiles(state, project, projectPath, config);
+        watchPackageJsonFiles(state, project, projectPath, config);
+      }
+      const status = getUpToDateStatus(state, config, projectPath);
+      if (!options.force) {
+        if (status.type === 1 /* UpToDate */) {
+          verboseReportProjectStatus(state, project, status);
+          reportAndStoreErrors(state, projectPath, getConfigFileParsingDiagnostics(config));
+          projectPendingBuild.delete(projectPath);
+          if (options.dry) {
+            reportStatus(state, Diagnostics.Project_0_is_up_to_date, project);
+          }
+          continue;
         }
-        const line = text.substring(lineStart, lineEnd);
-        if (line.match(sourceMapCommentRegExp)) {
-          text = text.substring(0, lineStart);
-          break;
-        } else if (!line.match(whitespaceOrMapCommentRegExp)) {
-          break;
+        if (status.type === 2 /* UpToDateWithUpstreamTypes */ || status.type === 15 /* UpToDateWithInputFileText */) {
+          reportAndStoreErrors(state, projectPath, getConfigFileParsingDiagnostics(config));
+          return {
+            kind: 2 /* UpdateOutputFileStamps */,
+            status,
+            project,
+            projectPath,
+            projectIndex,
+            config
+          };
         }
-        lineEnd = lineStart;
       }
+      if (status.type === 12 /* UpstreamBlocked */) {
+        verboseReportProjectStatus(state, project, status);
+        reportAndStoreErrors(state, projectPath, getConfigFileParsingDiagnostics(config));
+        projectPendingBuild.delete(projectPath);
+        if (options.verbose) {
+          reportStatus(
+            state,
+            status.upstreamProjectBlocked ? Diagnostics.Skipping_build_of_project_0_because_its_dependency_1_was_not_built : Diagnostics.Skipping_build_of_project_0_because_its_dependency_1_has_errors,
+            project,
+            status.upstreamProjectName
+          );
+        }
+        continue;
+      }
+      if (status.type === 16 /* ContainerOnly */) {
+        verboseReportProjectStatus(state, project, status);
+        reportAndStoreErrors(state, projectPath, getConfigFileParsingDiagnostics(config));
+        projectPendingBuild.delete(projectPath);
+        continue;
+      }
+      return {
+        kind: needsBuild(state, status, config) ? 0 /* Build */ : 1 /* UpdateBundle */,
+        status,
+        project,
+        projectPath,
+        projectIndex,
+        config
+      };
     }
-    return (host.createHash || generateDjb2Hash)(text);
+    return void 0;
   }
-  function setGetSourceFileAsHashVersioned(compilerHost) {
-    const originalGetSourceFile = compilerHost.getSourceFile;
-    compilerHost.getSourceFile = (...args) => {
-      const result = originalGetSourceFile.call(compilerHost, ...args);
-      if (result) {
-        result.version = getSourceFileVersionAsHashFromText(compilerHost, result.text);
-      }
-      return result;
-    };
+  function createInvalidatedProjectWithInfo(state, info, buildOrder) {
+    verboseReportProjectStatus(state, info.project, info.status);
+    return info.kind !== 2 /* UpdateOutputFileStamps */ ? createBuildOrUpdateInvalidedProject(
+      info.kind,
+      state,
+      info.project,
+      info.projectPath,
+      info.projectIndex,
+      info.config,
+      buildOrder
+    ) : createUpdateOutputFileStampsProject(
+      state,
+      info.project,
+      info.projectPath,
+      info.config,
+      buildOrder
+    );
   }
-  function createProgramHost(system, createProgram2) {
-    const getDefaultLibLocation = memoize(() => getDirectoryPath(normalizePath(system.getExecutingFilePath())));
-    return {
-      useCaseSensitiveFileNames: () => system.useCaseSensitiveFileNames,
-      getNewLine: () => system.newLine,
-      getCurrentDirectory: memoize(() => system.getCurrentDirectory()),
-      getDefaultLibLocation,
-      getDefaultLibFileName: (options) => combinePaths(getDefaultLibLocation(), getDefaultLibFileName(options)),
-      fileExists: (path) => system.fileExists(path),
-      readFile: (path, encoding) => system.readFile(path, encoding),
-      directoryExists: (path) => system.directoryExists(path),
-      getDirectories: (path) => system.getDirectories(path),
-      readDirectory: (path, extensions, exclude, include, depth) => system.readDirectory(path, extensions, exclude, include, depth),
-      realpath: maybeBind(system, system.realpath),
-      getEnvironmentVariable: maybeBind(system, system.getEnvironmentVariable),
-      trace: (s) => system.write(s + system.newLine),
-      createDirectory: (path) => system.createDirectory(path),
-      writeFile: (path, data, writeByteOrderMark) => system.writeFile(path, data, writeByteOrderMark),
-      createHash: maybeBind(system, system.createHash),
-      createProgram: createProgram2 || createEmitAndSemanticDiagnosticsBuilderProgram,
-      storeFilesChangingSignatureDuringEmit: system.storeFilesChangingSignatureDuringEmit,
-      now: maybeBind(system, system.now)
-    };
+  function getNextInvalidatedProject(state, buildOrder, reportQueue) {
+    const info = getNextInvalidatedProjectCreateInfo(state, buildOrder, reportQueue);
+    if (!info)
+      return info;
+    return createInvalidatedProjectWithInfo(state, info, buildOrder);
   }
-  function createWatchCompilerHost(system = sys, createProgram2, reportDiagnostic, reportWatchStatus2) {
-    const write = (s) => system.write(s + system.newLine);
-    const result = createProgramHost(system, createProgram2);
-    copyProperties(result, createWatchHost(system, reportWatchStatus2));
-    result.afterProgramCreate = (builderProgram) => {
-      const compilerOptions = builderProgram.getCompilerOptions();
-      const newLine = getNewLineCharacter(compilerOptions);
-      emitFilesAndReportErrors(
-        builderProgram,
-        reportDiagnostic,
-        write,
-        (errorCount) => result.onWatchStatusChange(
-          createCompilerDiagnostic(getWatchErrorSummaryDiagnosticMessage(errorCount), errorCount),
-          newLine,
-          compilerOptions,
-          errorCount
-        )
-      );
-    };
-    return result;
+  function listEmittedFile({ write }, proj, file) {
+    if (write && proj.options.listEmittedFiles) {
+      write(`TSFILE: ${file}`);
+    }
   }
-  function reportUnrecoverableDiagnostic(system, reportDiagnostic, diagnostic) {
-    reportDiagnostic(diagnostic);
-    system.exit(1 /* DiagnosticsPresent_OutputsSkipped */);
+  function getOldProgram({ options, builderPrograms, compilerHost }, proj, parsed) {
+    if (options.force)
+      return void 0;
+    const value = builderPrograms.get(proj);
+    if (value)
+      return value;
+    return readBuilderProgram(parsed.options, compilerHost);
   }
-  function createWatchCompilerHostOfConfigFile({
-    configFileName,
-    optionsToExtend,
-    watchOptionsToExtend,
-    extraFileExtensions,
-    system,
-    createProgram: createProgram2,
-    reportDiagnostic,
-    reportWatchStatus: reportWatchStatus2
-  }) {
-    const diagnosticReporter = reportDiagnostic || createDiagnosticReporter(system);
-    const host = createWatchCompilerHost(system, createProgram2, diagnosticReporter, reportWatchStatus2);
-    host.onUnRecoverableConfigFileDiagnostic = (diagnostic) => reportUnrecoverableDiagnostic(system, diagnosticReporter, diagnostic);
-    host.configFileName = configFileName;
-    host.optionsToExtend = optionsToExtend;
-    host.watchOptionsToExtend = watchOptionsToExtend;
-    host.extraFileExtensions = extraFileExtensions;
-    return host;
+  function afterProgramDone(state, program, config) {
+    if (program) {
+      if (state.write)
+        listFiles(program, state.write);
+      if (state.host.afterProgramEmitAndDiagnostics) {
+        state.host.afterProgramEmitAndDiagnostics(program);
+      }
+      program.releaseProgram();
+    } else if (state.host.afterEmitBundle) {
+      state.host.afterEmitBundle(config);
+    }
+    state.projectCompilerOptions = state.baseCompilerOptions;
   }
-  function createWatchCompilerHostOfFilesAndCompilerOptions({
-    rootFiles,
-    options,
-    watchOptions,
-    projectReferences,
-    system,
-    createProgram: createProgram2,
-    reportDiagnostic,
-    reportWatchStatus: reportWatchStatus2
-  }) {
-    const host = createWatchCompilerHost(system, createProgram2, reportDiagnostic || createDiagnosticReporter(system), reportWatchStatus2);
-    host.rootFiles = rootFiles;
-    host.options = options;
-    host.watchOptions = watchOptions;
-    host.projectReferences = projectReferences;
-    return host;
+  function buildErrors(state, resolvedPath, program, config, diagnostics, buildResult, errorType) {
+    const canEmitBuildInfo = program && !outFile(program.getCompilerOptions());
+    reportAndStoreErrors(state, resolvedPath, diagnostics);
+    state.projectStatus.set(resolvedPath, { type: 0 /* Unbuildable */, reason: `${errorType} errors` });
+    if (canEmitBuildInfo)
+      return { buildResult, step: 5 /* EmitBuildInfo */ };
+    afterProgramDone(state, program, config);
+    return { buildResult, step: 7 /* QueueReferencingProjects */ };
   }
-  function performIncrementalCompilation(input) {
-    const system = input.system || sys;
-    const host = input.host || (input.host = createIncrementalCompilerHost(input.options, system));
-    const builderProgram = createIncrementalProgram(input);
-    const exitStatus = emitFilesAndReportErrorsAndGetExitStatus(
-      builderProgram,
-      input.reportDiagnostic || createDiagnosticReporter(system),
-      (s) => host.trace && host.trace(s),
-      input.reportErrorSummary || input.options.pretty ? (errorCount, filesInError) => system.write(getErrorSummaryText(errorCount, filesInError, system.newLine, host)) : void 0
-    );
-    if (input.afterProgramEmitAndDiagnostics)
-      input.afterProgramEmitAndDiagnostics(builderProgram);
-    return exitStatus;
+  function isFileWatcherWithModifiedTime(value) {
+    return !!value.watcher;
   }
-  var sysFormatDiagnosticsHost, screenStartingMessageCodes, noopFileWatcher, returnNoopFileWatcher, WatchType;
-  var init_watch = __esm({
-    "src/compiler/watch.ts"() {
-      "use strict";
-      init_ts2();
-      sysFormatDiagnosticsHost = sys ? {
-        getCurrentDirectory: () => sys.getCurrentDirectory(),
-        getNewLine: () => sys.newLine,
-        getCanonicalFileName: createGetCanonicalFileName(sys.useCaseSensitiveFileNames)
-      } : void 0;
-      screenStartingMessageCodes = [
-        Diagnostics.Starting_compilation_in_watch_mode.code,
-        Diagnostics.File_change_detected_Starting_incremental_compilation.code
-      ];
-      noopFileWatcher = { close: noop };
-      returnNoopFileWatcher = () => noopFileWatcher;
-      WatchType = {
-        ConfigFile: "Config file",
-        ExtendedConfigFile: "Extended config file",
-        SourceFile: "Source file",
-        MissingFile: "Missing file",
-        WildcardDirectory: "Wild card directory",
-        FailedLookupLocations: "Failed Lookup Locations",
-        AffectingFileLocation: "File location affecting resolution",
-        TypeRoots: "Type roots",
-        ConfigFileOfReferencedProject: "Config file of referened project",
-        ExtendedConfigOfReferencedProject: "Extended config file of referenced project",
-        WildcardDirectoryOfReferencedProject: "Wild card directory of referenced project",
-        PackageJson: "package.json file",
-        ClosedScriptInfo: "Closed Script info",
-        ConfigFileForInferredRoot: "Config file for the inferred project root",
-        NodeModules: "node_modules for closed script infos and package.jsons affecting module specifier cache",
-        MissingSourceMapFile: "Missing source map file",
-        NoopConfigFileForInferredRoot: "Noop Config file for the inferred project root",
-        MissingGeneratedFile: "Missing generated file",
-        NodeModulesForModuleSpecifierCache: "node_modules for module specifier cache invalidation",
-        TypingInstallerLocationFile: "File location for typing installer",
-        TypingInstallerLocationDirectory: "Directory location for typing installer"
-      };
+  function getModifiedTime2(state, fileName) {
+    const path = toPath2(state, fileName);
+    const existing = state.filesWatched.get(path);
+    if (state.watch && !!existing) {
+      if (!isFileWatcherWithModifiedTime(existing))
+        return existing;
+      if (existing.modifiedTime)
+        return existing.modifiedTime;
     }
-  });
-
-  // src/compiler/watchPublic.ts
-  function readBuilderProgram(compilerOptions, host) {
-    const buildInfoPath = getTsBuildInfoEmitOutputFilePath(compilerOptions);
-    if (!buildInfoPath)
-      return void 0;
-    let buildInfo;
-    if (host.getBuildInfo) {
-      buildInfo = host.getBuildInfo(buildInfoPath, compilerOptions.configFilePath);
-    } else {
-      const content = host.readFile(buildInfoPath);
-      if (!content)
-        return void 0;
-      buildInfo = getBuildInfo(buildInfoPath, content);
+    const result = getModifiedTime(state.host, fileName);
+    if (state.watch) {
+      if (existing)
+        existing.modifiedTime = result;
+      else
+        state.filesWatched.set(path, result);
     }
-    if (!buildInfo || buildInfo.version !== version || !buildInfo.program)
-      return void 0;
-    return createBuilderProgramUsingProgramBuildInfo(buildInfo, buildInfoPath, host);
+    return result;
   }
-  function createIncrementalCompilerHost(options, system = sys) {
-    const host = createCompilerHostWorker(
-      options,
-      /*setParentNodes*/
-      void 0,
-      system
-    );
-    host.createHash = maybeBind(system, system.createHash);
-    host.storeFilesChangingSignatureDuringEmit = system.storeFilesChangingSignatureDuringEmit;
-    setGetSourceFileAsHashVersioned(host);
-    changeCompilerHostLikeToUseCache(host, (fileName) => toPath(fileName, host.getCurrentDirectory(), host.getCanonicalFileName));
-    return host;
+  function watchFile(state, file, callback, pollingInterval, options, watchType, project) {
+    const path = toPath2(state, file);
+    const existing = state.filesWatched.get(path);
+    if (existing && isFileWatcherWithModifiedTime(existing)) {
+      existing.callbacks.push(callback);
+    } else {
+      const watcher = state.watchFile(
+        file,
+        (fileName, eventKind, modifiedTime) => {
+          const existing2 = Debug.checkDefined(state.filesWatched.get(path));
+          Debug.assert(isFileWatcherWithModifiedTime(existing2));
+          existing2.modifiedTime = modifiedTime;
+          existing2.callbacks.forEach((cb) => cb(fileName, eventKind, modifiedTime));
+        },
+        pollingInterval,
+        options,
+        watchType,
+        project
+      );
+      state.filesWatched.set(path, { callbacks: [callback], watcher, modifiedTime: existing });
+    }
+    return {
+      close: () => {
+        const existing2 = Debug.checkDefined(state.filesWatched.get(path));
+        Debug.assert(isFileWatcherWithModifiedTime(existing2));
+        if (existing2.callbacks.length === 1) {
+          state.filesWatched.delete(path);
+          closeFileWatcherOf(existing2);
+        } else {
+          unorderedRemoveItem(existing2.callbacks, callback);
+        }
+      }
+    };
   }
-  function createIncrementalProgram({
-    rootNames,
-    options,
-    configFileParsingDiagnostics,
-    projectReferences,
-    host,
-    createProgram: createProgram2
-  }) {
-    host = host || createIncrementalCompilerHost(options);
-    createProgram2 = createProgram2 || createEmitAndSemanticDiagnosticsBuilderProgram;
-    const oldProgram = readBuilderProgram(options, host);
-    return createProgram2(rootNames, options, host, oldProgram, configFileParsingDiagnostics, projectReferences);
+  function getOutputTimeStampMap(state, resolvedConfigFilePath) {
+    if (!state.watch)
+      return void 0;
+    let result = state.outputTimeStamps.get(resolvedConfigFilePath);
+    if (!result)
+      state.outputTimeStamps.set(resolvedConfigFilePath, result = /* @__PURE__ */ new Map());
+    return result;
   }
-  function createWatchCompilerHost2(rootFilesOrConfigFileName, options, system, createProgram2, reportDiagnostic, reportWatchStatus2, projectReferencesOrWatchOptionsToExtend, watchOptionsOrExtraFileExtensions) {
-    if (isArray(rootFilesOrConfigFileName)) {
-      return createWatchCompilerHostOfFilesAndCompilerOptions({
-        rootFiles: rootFilesOrConfigFileName,
-        options,
-        watchOptions: watchOptionsOrExtraFileExtensions,
-        projectReferences: projectReferencesOrWatchOptionsToExtend,
-        system,
-        createProgram: createProgram2,
-        reportDiagnostic,
-        reportWatchStatus: reportWatchStatus2
-      });
+  function setBuildInfo(state, buildInfo, resolvedConfigPath, options, resultFlags) {
+    const buildInfoPath = getTsBuildInfoEmitOutputFilePath(options);
+    const existing = getBuildInfoCacheEntry(state, buildInfoPath, resolvedConfigPath);
+    const modifiedTime = getCurrentTime(state.host);
+    if (existing) {
+      existing.buildInfo = buildInfo;
+      existing.modifiedTime = modifiedTime;
+      if (!(resultFlags & 2 /* DeclarationOutputUnchanged */))
+        existing.latestChangedDtsTime = modifiedTime;
     } else {
-      return createWatchCompilerHostOfConfigFile({
-        configFileName: rootFilesOrConfigFileName,
-        optionsToExtend: options,
-        watchOptionsToExtend: projectReferencesOrWatchOptionsToExtend,
-        extraFileExtensions: watchOptionsOrExtraFileExtensions,
-        system,
-        createProgram: createProgram2,
-        reportDiagnostic,
-        reportWatchStatus: reportWatchStatus2
+      state.buildInfoCache.set(resolvedConfigPath, {
+        path: toPath2(state, buildInfoPath),
+        buildInfo,
+        modifiedTime,
+        latestChangedDtsTime: resultFlags & 2 /* DeclarationOutputUnchanged */ ? void 0 : modifiedTime
       });
     }
   }
-  function createWatchProgram(host) {
-    let builderProgram;
-    let reloadLevel;
-    let missingFilesMap;
-    let watchedWildcardDirectories;
-    let timerToUpdateProgram;
-    let timerToInvalidateFailedLookupResolutions;
-    let parsedConfigs;
-    let sharedExtendedConfigFileWatchers;
-    let extendedConfigCache = host.extendedConfigCache;
-    let reportFileChangeDetectedOnCreateProgram = false;
-    const sourceFilesCache = /* @__PURE__ */ new Map();
-    let missingFilePathsRequestedForRelease;
-    let hasChangedCompilerOptions = false;
-    const useCaseSensitiveFileNames = host.useCaseSensitiveFileNames();
-    const currentDirectory = host.getCurrentDirectory();
-    const { configFileName, optionsToExtend: optionsToExtendForConfigFile = {}, watchOptionsToExtend, extraFileExtensions, createProgram: createProgram2 } = host;
-    let { rootFiles: rootFileNames, options: compilerOptions, watchOptions, projectReferences } = host;
-    let wildcardDirectories;
-    let configFileParsingDiagnostics;
-    let canConfigFileJsonReportNoInputFiles = false;
-    let hasChangedConfigFileParsingErrors = false;
-    const cachedDirectoryStructureHost = configFileName === void 0 ? void 0 : createCachedDirectoryStructureHost(host, currentDirectory, useCaseSensitiveFileNames);
-    const directoryStructureHost = cachedDirectoryStructureHost || host;
-    const parseConfigFileHost = parseConfigHostFromCompilerHostLike(host, directoryStructureHost);
-    let newLine = updateNewLine();
-    if (configFileName && host.configFileParsingResult) {
-      setConfigFileParsingResult(host.configFileParsingResult);
-      newLine = updateNewLine();
-    }
-    reportWatchDiagnostic(Diagnostics.Starting_compilation_in_watch_mode);
-    if (configFileName && !host.configFileParsingResult) {
-      newLine = getNewLineCharacter(optionsToExtendForConfigFile);
-      Debug.assert(!rootFileNames);
-      parseConfigFile2();
-      newLine = updateNewLine();
-    }
-    Debug.assert(compilerOptions);
-    Debug.assert(rootFileNames);
-    const { watchFile: watchFile2, watchDirectory, writeLog } = createWatchFactory(host, compilerOptions);
-    const getCanonicalFileName = createGetCanonicalFileName(useCaseSensitiveFileNames);
-    writeLog(`Current directory: ${currentDirectory} CaseSensitiveFileNames: ${useCaseSensitiveFileNames}`);
-    let configFileWatcher;
-    if (configFileName) {
-      configFileWatcher = watchFile2(configFileName, scheduleProgramReload, 2e3 /* High */, watchOptions, WatchType.ConfigFile);
+  function getBuildInfoCacheEntry(state, buildInfoPath, resolvedConfigPath) {
+    const path = toPath2(state, buildInfoPath);
+    const existing = state.buildInfoCache.get(resolvedConfigPath);
+    return (existing == null ? void 0 : existing.path) === path ? existing : void 0;
+  }
+  function getBuildInfo3(state, buildInfoPath, resolvedConfigPath, modifiedTime) {
+    const path = toPath2(state, buildInfoPath);
+    const existing = state.buildInfoCache.get(resolvedConfigPath);
+    if (existing !== void 0 && existing.path === path) {
+      return existing.buildInfo || void 0;
     }
-    const compilerHost = createCompilerHostFromProgramHost(host, () => compilerOptions, directoryStructureHost);
-    setGetSourceFileAsHashVersioned(compilerHost);
-    const getNewSourceFile = compilerHost.getSourceFile;
-    compilerHost.getSourceFile = (fileName, ...args) => getVersionedSourceFileByPath(fileName, toPath3(fileName), ...args);
-    compilerHost.getSourceFileByPath = getVersionedSourceFileByPath;
-    compilerHost.getNewLine = () => newLine;
-    compilerHost.fileExists = fileExists;
-    compilerHost.onReleaseOldSourceFile = onReleaseOldSourceFile;
-    compilerHost.onReleaseParsedCommandLine = onReleaseParsedCommandLine;
-    compilerHost.toPath = toPath3;
-    compilerHost.getCompilationSettings = () => compilerOptions;
-    compilerHost.useSourceOfProjectReferenceRedirect = maybeBind(host, host.useSourceOfProjectReferenceRedirect);
-    compilerHost.watchDirectoryOfFailedLookupLocation = (dir, cb, flags) => watchDirectory(dir, cb, flags, watchOptions, WatchType.FailedLookupLocations);
-    compilerHost.watchAffectingFileLocation = (file, cb) => watchFile2(file, cb, 2e3 /* High */, watchOptions, WatchType.AffectingFileLocation);
-    compilerHost.watchTypeRootsDirectory = (dir, cb, flags) => watchDirectory(dir, cb, flags, watchOptions, WatchType.TypeRoots);
-    compilerHost.getCachedDirectoryStructureHost = () => cachedDirectoryStructureHost;
-    compilerHost.scheduleInvalidateResolutionsOfFailedLookupLocations = scheduleInvalidateResolutionsOfFailedLookupLocations;
-    compilerHost.onInvalidatedResolution = scheduleProgramUpdate;
-    compilerHost.onChangedAutomaticTypeDirectiveNames = scheduleProgramUpdate;
-    compilerHost.fileIsOpen = returnFalse;
-    compilerHost.getCurrentProgram = getCurrentProgram;
-    compilerHost.writeLog = writeLog;
-    compilerHost.getParsedCommandLine = getParsedCommandLine;
-    const resolutionCache = createResolutionCache(
-      compilerHost,
-      configFileName ? getDirectoryPath(getNormalizedAbsolutePath(configFileName, currentDirectory)) : currentDirectory,
-      /*logChangesWhenResolvingModule*/
-      false
-    );
-    compilerHost.resolveModuleNameLiterals = maybeBind(host, host.resolveModuleNameLiterals);
-    compilerHost.resolveModuleNames = maybeBind(host, host.resolveModuleNames);
-    if (!compilerHost.resolveModuleNameLiterals && !compilerHost.resolveModuleNames) {
-      compilerHost.resolveModuleNameLiterals = resolutionCache.resolveModuleNameLiterals.bind(resolutionCache);
+    const value = state.readFileWithCache(buildInfoPath);
+    const buildInfo = value ? getBuildInfo(buildInfoPath, value) : void 0;
+    state.buildInfoCache.set(resolvedConfigPath, { path, buildInfo: buildInfo || false, modifiedTime: modifiedTime || missingFileModifiedTime });
+    return buildInfo;
+  }
+  function checkConfigFileUpToDateStatus(state, configFile, oldestOutputFileTime, oldestOutputFileName) {
+    const tsconfigTime = getModifiedTime2(state, configFile);
+    if (oldestOutputFileTime < tsconfigTime) {
+      return {
+        type: 6 /* OutOfDateWithSelf */,
+        outOfDateOutputFileName: oldestOutputFileName,
+        newerInputFileName: configFile
+      };
     }
-    compilerHost.resolveTypeReferenceDirectiveReferences = maybeBind(host, host.resolveTypeReferenceDirectiveReferences);
-    compilerHost.resolveTypeReferenceDirectives = maybeBind(host, host.resolveTypeReferenceDirectives);
-    if (!compilerHost.resolveTypeReferenceDirectiveReferences && !compilerHost.resolveTypeReferenceDirectives) {
-      compilerHost.resolveTypeReferenceDirectiveReferences = resolutionCache.resolveTypeReferenceDirectiveReferences.bind(resolutionCache);
+  }
+  function getUpToDateStatusWorker(state, project, resolvedPath) {
+    var _a, _b;
+    if (!project.fileNames.length && !canJsonReportNoInputFiles(project.raw)) {
+      return {
+        type: 16 /* ContainerOnly */
+      };
     }
-    compilerHost.resolveLibrary = !host.resolveLibrary ? resolutionCache.resolveLibrary.bind(resolutionCache) : host.resolveLibrary.bind(host);
-    compilerHost.getModuleResolutionCache = host.resolveModuleNameLiterals || host.resolveModuleNames ? maybeBind(host, host.getModuleResolutionCache) : () => resolutionCache.getModuleResolutionCache();
-    const userProvidedResolution = !!host.resolveModuleNameLiterals || !!host.resolveTypeReferenceDirectiveReferences || !!host.resolveModuleNames || !!host.resolveTypeReferenceDirectives;
-    const customHasInvalidatedResolutions = userProvidedResolution ? maybeBind(host, host.hasInvalidatedResolutions) || returnTrue : returnFalse;
-    const customHasInvalidLibResolutions = host.resolveLibrary ? maybeBind(host, host.hasInvalidatedLibResolutions) || returnTrue : returnFalse;
-    builderProgram = readBuilderProgram(compilerOptions, compilerHost);
-    synchronizeProgram();
-    watchConfigFileWildCardDirectories();
-    if (configFileName)
-      updateExtendedConfigFilesWatches(toPath3(configFileName), compilerOptions, watchOptions, WatchType.ExtendedConfigFile);
-    return configFileName ? { getCurrentProgram: getCurrentBuilderProgram, getProgram: updateProgram, close } : { getCurrentProgram: getCurrentBuilderProgram, getProgram: updateProgram, updateRootFileNames, close };
-    function close() {
-      clearInvalidateResolutionsOfFailedLookupLocations();
-      resolutionCache.clear();
-      clearMap(sourceFilesCache, (value) => {
-        if (value && value.fileWatcher) {
-          value.fileWatcher.close();
-          value.fileWatcher = void 0;
+    let referenceStatuses;
+    const force = !!state.options.force;
+    if (project.projectReferences) {
+      state.projectStatus.set(resolvedPath, { type: 13 /* ComputingUpstream */ });
+      for (const ref of project.projectReferences) {
+        const resolvedRef = resolveProjectReferencePath(ref);
+        const resolvedRefPath = toResolvedConfigFilePath(state, resolvedRef);
+        const resolvedConfig = parseConfigFile(state, resolvedRef, resolvedRefPath);
+        const refStatus = getUpToDateStatus(state, resolvedConfig, resolvedRefPath);
+        if (refStatus.type === 13 /* ComputingUpstream */ || refStatus.type === 16 /* ContainerOnly */) {
+          continue;
         }
-      });
-      if (configFileWatcher) {
-        configFileWatcher.close();
-        configFileWatcher = void 0;
-      }
-      extendedConfigCache == null ? void 0 : extendedConfigCache.clear();
-      extendedConfigCache = void 0;
-      if (sharedExtendedConfigFileWatchers) {
-        clearMap(sharedExtendedConfigFileWatchers, closeFileWatcherOf);
-        sharedExtendedConfigFileWatchers = void 0;
-      }
-      if (watchedWildcardDirectories) {
-        clearMap(watchedWildcardDirectories, closeFileWatcherOf);
-        watchedWildcardDirectories = void 0;
-      }
-      if (missingFilesMap) {
-        clearMap(missingFilesMap, closeFileWatcher);
-        missingFilesMap = void 0;
-      }
-      if (parsedConfigs) {
-        clearMap(parsedConfigs, (config) => {
-          var _a;
-          (_a = config.watcher) == null ? void 0 : _a.close();
-          config.watcher = void 0;
-          if (config.watchedDirectories)
-            clearMap(config.watchedDirectories, closeFileWatcherOf);
-          config.watchedDirectories = void 0;
-        });
-        parsedConfigs = void 0;
+        if (refStatus.type === 0 /* Unbuildable */ || refStatus.type === 12 /* UpstreamBlocked */) {
+          return {
+            type: 12 /* UpstreamBlocked */,
+            upstreamProjectName: ref.path,
+            upstreamProjectBlocked: refStatus.type === 12 /* UpstreamBlocked */
+          };
+        }
+        if (refStatus.type !== 1 /* UpToDate */) {
+          return {
+            type: 11 /* UpstreamOutOfDate */,
+            upstreamProjectName: ref.path
+          };
+        }
+        if (!force)
+          (referenceStatuses || (referenceStatuses = [])).push({ ref, refStatus, resolvedRefPath, resolvedConfig });
       }
     }
-    function getCurrentBuilderProgram() {
-      return builderProgram;
-    }
-    function getCurrentProgram() {
-      return builderProgram && builderProgram.getProgramOrUndefined();
-    }
-    function synchronizeProgram() {
-      writeLog(`Synchronizing program`);
-      Debug.assert(compilerOptions);
-      Debug.assert(rootFileNames);
-      clearInvalidateResolutionsOfFailedLookupLocations();
-      const program = getCurrentBuilderProgram();
-      if (hasChangedCompilerOptions) {
-        newLine = updateNewLine();
-        if (program && changesAffectModuleResolution(program.getCompilerOptions(), compilerOptions)) {
-          debugger;
-          resolutionCache.onChangesAffectModuleResolution();
+    if (force)
+      return { type: 17 /* ForceBuild */ };
+    const { host } = state;
+    const buildInfoPath = getTsBuildInfoEmitOutputFilePath(project.options);
+    let oldestOutputFileName;
+    let oldestOutputFileTime = maximumDate;
+    let buildInfoTime;
+    let buildInfoProgram;
+    let buildInfoVersionMap;
+    if (buildInfoPath) {
+      const buildInfoCacheEntry2 = getBuildInfoCacheEntry(state, buildInfoPath, resolvedPath);
+      buildInfoTime = (buildInfoCacheEntry2 == null ? void 0 : buildInfoCacheEntry2.modifiedTime) || getModifiedTime(host, buildInfoPath);
+      if (buildInfoTime === missingFileModifiedTime) {
+        if (!buildInfoCacheEntry2) {
+          state.buildInfoCache.set(resolvedPath, {
+            path: toPath2(state, buildInfoPath),
+            buildInfo: false,
+            modifiedTime: buildInfoTime
+          });
         }
+        return {
+          type: 4 /* OutputMissing */,
+          missingOutputFileName: buildInfoPath
+        };
       }
-      const { hasInvalidatedResolutions, hasInvalidatedLibResolutions } = resolutionCache.createHasInvalidatedResolutions(customHasInvalidatedResolutions, customHasInvalidLibResolutions);
-      const {
-        originalReadFile,
-        originalFileExists,
-        originalDirectoryExists,
-        originalCreateDirectory,
-        originalWriteFile,
-        readFileWithCache
-      } = changeCompilerHostLikeToUseCache(compilerHost, toPath3);
-      if (isProgramUptoDate(getCurrentProgram(), rootFileNames, compilerOptions, (path) => getSourceVersion(path, readFileWithCache), (fileName) => compilerHost.fileExists(fileName), hasInvalidatedResolutions, hasInvalidatedLibResolutions, hasChangedAutomaticTypeDirectiveNames, getParsedCommandLine, projectReferences)) {
-        if (hasChangedConfigFileParsingErrors) {
-          if (reportFileChangeDetectedOnCreateProgram) {
-            reportWatchDiagnostic(Diagnostics.File_change_detected_Starting_incremental_compilation);
-          }
-          builderProgram = createProgram2(
-            /*rootNames*/
-            void 0,
-            /*options*/
-            void 0,
-            compilerHost,
-            builderProgram,
-            configFileParsingDiagnostics,
-            projectReferences
-          );
-          hasChangedConfigFileParsingErrors = false;
+      const buildInfo = getBuildInfo3(state, buildInfoPath, resolvedPath, buildInfoTime);
+      if (!buildInfo) {
+        return {
+          type: 5 /* ErrorReadingFile */,
+          fileName: buildInfoPath
+        };
+      }
+      if ((buildInfo.bundle || buildInfo.program) && buildInfo.version !== version) {
+        return {
+          type: 14 /* TsVersionOutputOfDate */,
+          version: buildInfo.version
+        };
+      }
+      if (buildInfo.program) {
+        if (((_a = buildInfo.program.changeFileSet) == null ? void 0 : _a.length) || (!project.options.noEmit ? (_b = buildInfo.program.affectedFilesPendingEmit) == null ? void 0 : _b.length : some(buildInfo.program.semanticDiagnosticsPerFile, isArray))) {
+          return {
+            type: 8 /* OutOfDateBuildInfo */,
+            buildInfoFile: buildInfoPath
+          };
         }
-      } else {
-        if (reportFileChangeDetectedOnCreateProgram) {
-          reportWatchDiagnostic(Diagnostics.File_change_detected_Starting_incremental_compilation);
+        if (!project.options.noEmit && getPendingEmitKind(project.options, buildInfo.program.options || {})) {
+          return {
+            type: 9 /* OutOfDateOptions */,
+            buildInfoFile: buildInfoPath
+          };
         }
-        createNewProgram(hasInvalidatedResolutions, hasInvalidatedLibResolutions);
-      }
-      reportFileChangeDetectedOnCreateProgram = false;
-      if (host.afterProgramCreate && program !== builderProgram) {
-        host.afterProgramCreate(builderProgram);
+        buildInfoProgram = buildInfo.program;
       }
-      compilerHost.readFile = originalReadFile;
-      compilerHost.fileExists = originalFileExists;
-      compilerHost.directoryExists = originalDirectoryExists;
-      compilerHost.createDirectory = originalCreateDirectory;
-      compilerHost.writeFile = originalWriteFile;
-      return builderProgram;
+      oldestOutputFileTime = buildInfoTime;
+      oldestOutputFileName = buildInfoPath;
     }
-    function createNewProgram(hasInvalidatedResolutions, hasInvalidatedLibResolutions) {
-      writeLog("CreatingProgramWith::");
-      writeLog(`  roots: ${JSON.stringify(rootFileNames)}`);
-      writeLog(`  options: ${JSON.stringify(compilerOptions)}`);
-      if (projectReferences)
-        writeLog(`  projectReferences: ${JSON.stringify(projectReferences)}`);
-      const needsUpdateInTypeRootWatch = hasChangedCompilerOptions || !getCurrentProgram();
-      hasChangedCompilerOptions = false;
-      hasChangedConfigFileParsingErrors = false;
-      resolutionCache.startCachingPerDirectoryResolution();
-      compilerHost.hasInvalidatedResolutions = hasInvalidatedResolutions;
-      compilerHost.hasInvalidatedLibResolutions = hasInvalidatedLibResolutions;
-      compilerHost.hasChangedAutomaticTypeDirectiveNames = hasChangedAutomaticTypeDirectiveNames;
-      const oldProgram = getCurrentProgram();
-      builderProgram = createProgram2(rootFileNames, compilerOptions, compilerHost, builderProgram, configFileParsingDiagnostics, projectReferences);
-      resolutionCache.finishCachingPerDirectoryResolution(builderProgram.getProgram(), oldProgram);
-      updateMissingFilePathsWatch(builderProgram.getProgram(), missingFilesMap || (missingFilesMap = /* @__PURE__ */ new Map()), watchMissingFilePath);
-      if (needsUpdateInTypeRootWatch) {
-        resolutionCache.updateTypeRootsWatch();
+    let newestInputFileName = void 0;
+    let newestInputFileTime = minimumDate;
+    let pseudoInputUpToDate = false;
+    const seenRoots = /* @__PURE__ */ new Set();
+    for (const inputFile of project.fileNames) {
+      const inputTime = getModifiedTime2(state, inputFile);
+      if (inputTime === missingFileModifiedTime) {
+        return {
+          type: 0 /* Unbuildable */,
+          reason: `${inputFile} does not exist`
+        };
       }
-      if (missingFilePathsRequestedForRelease) {
-        for (const missingFilePath of missingFilePathsRequestedForRelease) {
-          if (!missingFilesMap.has(missingFilePath)) {
-            sourceFilesCache.delete(missingFilePath);
-          }
+      if (buildInfoTime && buildInfoTime < inputTime) {
+        let version2;
+        let currentVersion;
+        if (buildInfoProgram) {
+          if (!buildInfoVersionMap)
+            buildInfoVersionMap = getBuildInfoFileVersionMap(buildInfoProgram, buildInfoPath, host);
+          version2 = buildInfoVersionMap.fileInfos.get(toPath2(state, inputFile));
+          const text = version2 ? state.readFileWithCache(inputFile) : void 0;
+          currentVersion = text !== void 0 ? getSourceFileVersionAsHashFromText(host, text) : void 0;
+          if (version2 && version2 === currentVersion)
+            pseudoInputUpToDate = true;
+        }
+        if (!version2 || version2 !== currentVersion) {
+          return {
+            type: 6 /* OutOfDateWithSelf */,
+            outOfDateOutputFileName: buildInfoPath,
+            newerInputFileName: inputFile
+          };
         }
-        missingFilePathsRequestedForRelease = void 0;
       }
-    }
-    function updateRootFileNames(files) {
-      Debug.assert(!configFileName, "Cannot update root file names with config file watch mode");
-      rootFileNames = files;
-      scheduleProgramUpdate();
-    }
-    function updateNewLine() {
-      return getNewLineCharacter(compilerOptions || optionsToExtendForConfigFile);
-    }
-    function toPath3(fileName) {
-      return toPath(fileName, currentDirectory, getCanonicalFileName);
-    }
-    function isFileMissingOnHost(hostSourceFile) {
-      return typeof hostSourceFile === "boolean";
-    }
-    function isFilePresenceUnknownOnHost(hostSourceFile) {
-      return typeof hostSourceFile.version === "boolean";
-    }
-    function fileExists(fileName) {
-      const path = toPath3(fileName);
-      if (isFileMissingOnHost(sourceFilesCache.get(path))) {
-        return false;
+      if (inputTime > newestInputFileTime) {
+        newestInputFileName = inputFile;
+        newestInputFileTime = inputTime;
       }
-      return directoryStructureHost.fileExists(fileName);
+      if (buildInfoProgram)
+        seenRoots.add(toPath2(state, inputFile));
     }
-    function getVersionedSourceFileByPath(fileName, path, languageVersionOrOptions, onError, shouldCreateNewSourceFile) {
-      const hostSourceFile = sourceFilesCache.get(path);
-      if (isFileMissingOnHost(hostSourceFile)) {
-        return void 0;
-      }
-      if (hostSourceFile === void 0 || shouldCreateNewSourceFile || isFilePresenceUnknownOnHost(hostSourceFile)) {
-        const sourceFile = getNewSourceFile(fileName, languageVersionOrOptions, onError);
-        if (hostSourceFile) {
-          if (sourceFile) {
-            hostSourceFile.sourceFile = sourceFile;
-            hostSourceFile.version = sourceFile.version;
-            if (!hostSourceFile.fileWatcher) {
-              hostSourceFile.fileWatcher = watchFilePath(path, fileName, onSourceFileChange, 250 /* Low */, watchOptions, WatchType.SourceFile);
-            }
-          } else {
-            if (hostSourceFile.fileWatcher) {
-              hostSourceFile.fileWatcher.close();
-            }
-            sourceFilesCache.set(path, false);
-          }
-        } else {
-          if (sourceFile) {
-            const fileWatcher = watchFilePath(path, fileName, onSourceFileChange, 250 /* Low */, watchOptions, WatchType.SourceFile);
-            sourceFilesCache.set(path, { sourceFile, version: sourceFile.version, fileWatcher });
-          } else {
-            sourceFilesCache.set(path, false);
-          }
+    if (buildInfoProgram) {
+      if (!buildInfoVersionMap)
+        buildInfoVersionMap = getBuildInfoFileVersionMap(buildInfoProgram, buildInfoPath, host);
+      for (const existingRoot of buildInfoVersionMap.roots) {
+        if (!seenRoots.has(existingRoot)) {
+          return {
+            type: 10 /* OutOfDateRoots */,
+            buildInfoFile: buildInfoPath,
+            inputFile: existingRoot
+          };
         }
-        return sourceFile;
       }
-      return hostSourceFile.sourceFile;
     }
-    function nextSourceFileVersion(path) {
-      const hostSourceFile = sourceFilesCache.get(path);
-      if (hostSourceFile !== void 0) {
-        if (isFileMissingOnHost(hostSourceFile)) {
-          sourceFilesCache.set(path, { version: false });
-        } else {
-          hostSourceFile.version = false;
+    if (!buildInfoPath) {
+      const outputs = getAllProjectOutputs(project, !host.useCaseSensitiveFileNames());
+      const outputTimeStampMap = getOutputTimeStampMap(state, resolvedPath);
+      for (const output of outputs) {
+        const path = toPath2(state, output);
+        let outputTime = outputTimeStampMap == null ? void 0 : outputTimeStampMap.get(path);
+        if (!outputTime) {
+          outputTime = getModifiedTime(state.host, output);
+          outputTimeStampMap == null ? void 0 : outputTimeStampMap.set(path, outputTime);
         }
-      }
-    }
-    function getSourceVersion(path, readFileWithCache) {
-      const hostSourceFile = sourceFilesCache.get(path);
-      if (!hostSourceFile)
-        return void 0;
-      if (hostSourceFile.version)
-        return hostSourceFile.version;
-      const text = readFileWithCache(path);
-      return text !== void 0 ? getSourceFileVersionAsHashFromText(compilerHost, text) : void 0;
-    }
-    function onReleaseOldSourceFile(oldSourceFile, _oldOptions, hasSourceFileByPath) {
-      const hostSourceFileInfo = sourceFilesCache.get(oldSourceFile.resolvedPath);
-      if (hostSourceFileInfo !== void 0) {
-        if (isFileMissingOnHost(hostSourceFileInfo)) {
-          (missingFilePathsRequestedForRelease || (missingFilePathsRequestedForRelease = [])).push(oldSourceFile.path);
-        } else if (hostSourceFileInfo.sourceFile === oldSourceFile) {
-          if (hostSourceFileInfo.fileWatcher) {
-            hostSourceFileInfo.fileWatcher.close();
-          }
-          sourceFilesCache.delete(oldSourceFile.resolvedPath);
-          if (!hasSourceFileByPath) {
-            resolutionCache.removeResolutionsOfFile(oldSourceFile.path);
-          }
+        if (outputTime === missingFileModifiedTime) {
+          return {
+            type: 4 /* OutputMissing */,
+            missingOutputFileName: output
+          };
+        }
+        if (outputTime < newestInputFileTime) {
+          return {
+            type: 6 /* OutOfDateWithSelf */,
+            outOfDateOutputFileName: output,
+            newerInputFileName: newestInputFileName
+          };
+        }
+        if (outputTime < oldestOutputFileTime) {
+          oldestOutputFileTime = outputTime;
+          oldestOutputFileName = output;
         }
       }
     }
-    function reportWatchDiagnostic(message) {
-      if (host.onWatchStatusChange) {
-        host.onWatchStatusChange(createCompilerDiagnostic(message), newLine, compilerOptions || optionsToExtendForConfigFile);
+    const buildInfoCacheEntry = state.buildInfoCache.get(resolvedPath);
+    let pseudoUpToDate = false;
+    let usesPrepend = false;
+    let upstreamChangedProject;
+    if (referenceStatuses) {
+      for (const { ref, refStatus, resolvedConfig, resolvedRefPath } of referenceStatuses) {
+        usesPrepend = usesPrepend || !!ref.prepend;
+        if (refStatus.newestInputFileTime && refStatus.newestInputFileTime <= oldestOutputFileTime) {
+          continue;
+        }
+        if (buildInfoCacheEntry && hasSameBuildInfo(state, buildInfoCacheEntry, resolvedRefPath)) {
+          return {
+            type: 7 /* OutOfDateWithUpstream */,
+            outOfDateOutputFileName: buildInfoPath,
+            newerProjectName: ref.path
+          };
+        }
+        const newestDeclarationFileContentChangedTime = getLatestChangedDtsTime(state, resolvedConfig.options, resolvedRefPath);
+        if (newestDeclarationFileContentChangedTime && newestDeclarationFileContentChangedTime <= oldestOutputFileTime) {
+          pseudoUpToDate = true;
+          upstreamChangedProject = ref.path;
+          continue;
+        }
+        Debug.assert(oldestOutputFileName !== void 0, "Should have an oldest output filename here");
+        return {
+          type: 7 /* OutOfDateWithUpstream */,
+          outOfDateOutputFileName: oldestOutputFileName,
+          newerProjectName: ref.path
+        };
       }
     }
-    function hasChangedAutomaticTypeDirectiveNames() {
-      return resolutionCache.hasChangedAutomaticTypeDirectiveNames();
-    }
-    function clearInvalidateResolutionsOfFailedLookupLocations() {
-      if (!timerToInvalidateFailedLookupResolutions)
-        return false;
-      host.clearTimeout(timerToInvalidateFailedLookupResolutions);
-      timerToInvalidateFailedLookupResolutions = void 0;
-      return true;
+    const configStatus = checkConfigFileUpToDateStatus(state, project.options.configFilePath, oldestOutputFileTime, oldestOutputFileName);
+    if (configStatus)
+      return configStatus;
+    const extendedConfigStatus = forEach(project.options.configFile.extendedSourceFiles || emptyArray, (configFile) => checkConfigFileUpToDateStatus(state, configFile, oldestOutputFileTime, oldestOutputFileName));
+    if (extendedConfigStatus)
+      return extendedConfigStatus;
+    const dependentPackageFileStatus = forEach(
+      state.lastCachedPackageJsonLookups.get(resolvedPath) || emptyArray,
+      ([path]) => checkConfigFileUpToDateStatus(state, path, oldestOutputFileTime, oldestOutputFileName)
+    );
+    if (dependentPackageFileStatus)
+      return dependentPackageFileStatus;
+    if (usesPrepend && pseudoUpToDate) {
+      return {
+        type: 3 /* OutOfDateWithPrepend */,
+        outOfDateOutputFileName: oldestOutputFileName,
+        newerProjectName: upstreamChangedProject
+      };
     }
-    function scheduleInvalidateResolutionsOfFailedLookupLocations() {
-      if (!host.setTimeout || !host.clearTimeout) {
-        return resolutionCache.invalidateResolutionsOfFailedLookupLocations();
-      }
-      const pending = clearInvalidateResolutionsOfFailedLookupLocations();
-      writeLog(`Scheduling invalidateFailedLookup${pending ? ", Cancelled earlier one" : ""}`);
-      timerToInvalidateFailedLookupResolutions = host.setTimeout(invalidateResolutionsOfFailedLookup, 250, "timerToInvalidateFailedLookupResolutions");
+    return {
+      type: pseudoUpToDate ? 2 /* UpToDateWithUpstreamTypes */ : pseudoInputUpToDate ? 15 /* UpToDateWithInputFileText */ : 1 /* UpToDate */,
+      newestInputFileTime,
+      newestInputFileName,
+      oldestOutputFileName
+    };
+  }
+  function hasSameBuildInfo(state, buildInfoCacheEntry, resolvedRefPath) {
+    const refBuildInfo = state.buildInfoCache.get(resolvedRefPath);
+    return refBuildInfo.path === buildInfoCacheEntry.path;
+  }
+  function getUpToDateStatus(state, project, resolvedPath) {
+    if (project === void 0) {
+      return { type: 0 /* Unbuildable */, reason: "File deleted mid-build" };
     }
-    function invalidateResolutionsOfFailedLookup() {
-      timerToInvalidateFailedLookupResolutions = void 0;
-      if (resolutionCache.invalidateResolutionsOfFailedLookupLocations()) {
-        scheduleProgramUpdate();
-      }
+    const prior = state.projectStatus.get(resolvedPath);
+    if (prior !== void 0) {
+      return prior;
     }
-    function scheduleProgramUpdate() {
-      if (!host.setTimeout || !host.clearTimeout) {
-        return;
-      }
-      if (timerToUpdateProgram) {
-        host.clearTimeout(timerToUpdateProgram);
+    mark("SolutionBuilder::beforeUpToDateCheck");
+    const actual = getUpToDateStatusWorker(state, project, resolvedPath);
+    mark("SolutionBuilder::afterUpToDateCheck");
+    measure("SolutionBuilder::Up-to-date check", "SolutionBuilder::beforeUpToDateCheck", "SolutionBuilder::afterUpToDateCheck");
+    state.projectStatus.set(resolvedPath, actual);
+    return actual;
+  }
+  function updateOutputTimestampsWorker(state, proj, projectPath, verboseMessage, skipOutputs) {
+    if (proj.options.noEmit)
+      return;
+    let now;
+    const buildInfoPath = getTsBuildInfoEmitOutputFilePath(proj.options);
+    if (buildInfoPath) {
+      if (!(skipOutputs == null ? void 0 : skipOutputs.has(toPath2(state, buildInfoPath)))) {
+        if (!!state.options.verbose)
+          reportStatus(state, verboseMessage, proj.options.configFilePath);
+        state.host.setModifiedTime(buildInfoPath, now = getCurrentTime(state.host));
+        getBuildInfoCacheEntry(state, buildInfoPath, projectPath).modifiedTime = now;
       }
-      writeLog("Scheduling update");
-      timerToUpdateProgram = host.setTimeout(updateProgramWithWatchStatus, 250, "timerToUpdateProgram");
-    }
-    function scheduleProgramReload() {
-      Debug.assert(!!configFileName);
-      reloadLevel = 2 /* Full */;
-      scheduleProgramUpdate();
-    }
-    function updateProgramWithWatchStatus() {
-      timerToUpdateProgram = void 0;
-      reportFileChangeDetectedOnCreateProgram = true;
-      updateProgram();
+      state.outputTimeStamps.delete(projectPath);
+      return;
     }
-    function updateProgram() {
-      var _a, _b, _c, _d;
-      switch (reloadLevel) {
-        case 1 /* Partial */:
-          (_a = perfLogger) == null ? void 0 : _a.logStartUpdateProgram("PartialConfigReload");
-          reloadFileNamesFromConfigFile();
-          break;
-        case 2 /* Full */:
-          (_b = perfLogger) == null ? void 0 : _b.logStartUpdateProgram("FullConfigReload");
-          reloadConfigFile();
-          break;
-        default:
-          (_c = perfLogger) == null ? void 0 : _c.logStartUpdateProgram("SynchronizeProgram");
-          synchronizeProgram();
-          break;
+    const { host } = state;
+    const outputs = getAllProjectOutputs(proj, !host.useCaseSensitiveFileNames());
+    const outputTimeStampMap = getOutputTimeStampMap(state, projectPath);
+    const modifiedOutputs = outputTimeStampMap ? /* @__PURE__ */ new Set() : void 0;
+    if (!skipOutputs || outputs.length !== skipOutputs.size) {
+      let reportVerbose = !!state.options.verbose;
+      for (const file of outputs) {
+        const path = toPath2(state, file);
+        if (skipOutputs == null ? void 0 : skipOutputs.has(path))
+          continue;
+        if (reportVerbose) {
+          reportVerbose = false;
+          reportStatus(state, verboseMessage, proj.options.configFilePath);
+        }
+        host.setModifiedTime(file, now || (now = getCurrentTime(state.host)));
+        if (outputTimeStampMap) {
+          outputTimeStampMap.set(path, now);
+          modifiedOutputs.add(path);
+        }
       }
-      (_d = perfLogger) == null ? void 0 : _d.logStopUpdateProgram("Done");
-      return getCurrentBuilderProgram();
     }
-    function reloadFileNamesFromConfigFile() {
-      writeLog("Reloading new file names and options");
-      Debug.assert(compilerOptions);
-      Debug.assert(configFileName);
-      reloadLevel = 0 /* None */;
-      rootFileNames = getFileNamesFromConfigSpecs(compilerOptions.configFile.configFileSpecs, getNormalizedAbsolutePath(getDirectoryPath(configFileName), currentDirectory), compilerOptions, parseConfigFileHost, extraFileExtensions);
-      if (updateErrorForNoInputFiles(rootFileNames, getNormalizedAbsolutePath(configFileName, currentDirectory), compilerOptions.configFile.configFileSpecs, configFileParsingDiagnostics, canConfigFileJsonReportNoInputFiles)) {
-        hasChangedConfigFileParsingErrors = true;
-      }
-      synchronizeProgram();
+    outputTimeStampMap == null ? void 0 : outputTimeStampMap.forEach((_value, key) => {
+      if (!(skipOutputs == null ? void 0 : skipOutputs.has(key)) && !modifiedOutputs.has(key))
+        outputTimeStampMap.delete(key);
+    });
+  }
+  function getLatestChangedDtsTime(state, options, resolvedConfigPath) {
+    if (!options.composite)
+      return void 0;
+    const entry = Debug.checkDefined(state.buildInfoCache.get(resolvedConfigPath));
+    if (entry.latestChangedDtsTime !== void 0)
+      return entry.latestChangedDtsTime || void 0;
+    const latestChangedDtsTime = entry.buildInfo && entry.buildInfo.program && entry.buildInfo.program.latestChangedDtsFile ? state.host.getModifiedTime(getNormalizedAbsolutePath(entry.buildInfo.program.latestChangedDtsFile, getDirectoryPath(entry.path))) : void 0;
+    entry.latestChangedDtsTime = latestChangedDtsTime || false;
+    return latestChangedDtsTime;
+  }
+  function updateOutputTimestamps(state, proj, resolvedPath) {
+    if (state.options.dry) {
+      return reportStatus(state, Diagnostics.A_non_dry_build_would_update_timestamps_for_output_of_project_0, proj.options.configFilePath);
     }
-    function reloadConfigFile() {
-      Debug.assert(configFileName);
-      writeLog(`Reloading config file: ${configFileName}`);
-      reloadLevel = 0 /* None */;
-      if (cachedDirectoryStructureHost) {
-        cachedDirectoryStructureHost.clearCache();
+    updateOutputTimestampsWorker(state, proj, resolvedPath, Diagnostics.Updating_output_timestamps_of_project_0);
+    state.projectStatus.set(resolvedPath, {
+      type: 1 /* UpToDate */,
+      oldestOutputFileName: getFirstProjectOutput(proj, !state.host.useCaseSensitiveFileNames())
+    });
+  }
+  function queueReferencingProjects(state, project, projectPath, projectIndex, config, buildOrder, buildResult) {
+    if (buildResult & 124 /* AnyErrors */)
+      return;
+    if (!config.options.composite)
+      return;
+    for (let index = projectIndex + 1; index < buildOrder.length; index++) {
+      const nextProject = buildOrder[index];
+      const nextProjectPath = toResolvedConfigFilePath(state, nextProject);
+      if (state.projectPendingBuild.has(nextProjectPath))
+        continue;
+      const nextProjectConfig = parseConfigFile(state, nextProject, nextProjectPath);
+      if (!nextProjectConfig || !nextProjectConfig.projectReferences)
+        continue;
+      for (const ref of nextProjectConfig.projectReferences) {
+        const resolvedRefPath = resolveProjectName(state, ref.path);
+        if (toResolvedConfigFilePath(state, resolvedRefPath) !== projectPath)
+          continue;
+        const status = state.projectStatus.get(nextProjectPath);
+        if (status) {
+          switch (status.type) {
+            case 1 /* UpToDate */:
+              if (buildResult & 2 /* DeclarationOutputUnchanged */) {
+                if (ref.prepend) {
+                  state.projectStatus.set(nextProjectPath, {
+                    type: 3 /* OutOfDateWithPrepend */,
+                    outOfDateOutputFileName: status.oldestOutputFileName,
+                    newerProjectName: project
+                  });
+                } else {
+                  status.type = 2 /* UpToDateWithUpstreamTypes */;
+                }
+                break;
+              }
+            case 15 /* UpToDateWithInputFileText */:
+            case 2 /* UpToDateWithUpstreamTypes */:
+            case 3 /* OutOfDateWithPrepend */:
+              if (!(buildResult & 2 /* DeclarationOutputUnchanged */)) {
+                state.projectStatus.set(nextProjectPath, {
+                  type: 7 /* OutOfDateWithUpstream */,
+                  outOfDateOutputFileName: status.type === 3 /* OutOfDateWithPrepend */ ? status.outOfDateOutputFileName : status.oldestOutputFileName,
+                  newerProjectName: project
+                });
+              }
+              break;
+            case 12 /* UpstreamBlocked */:
+              if (toResolvedConfigFilePath(state, resolveProjectName(state, status.upstreamProjectName)) === projectPath) {
+                clearProjectStatus(state, nextProjectPath);
+              }
+              break;
+          }
+        }
+        addProjToQueue(state, nextProjectPath, 0 /* Update */);
+        break;
       }
-      parseConfigFile2();
-      hasChangedCompilerOptions = true;
-      synchronizeProgram();
-      watchConfigFileWildCardDirectories();
-      updateExtendedConfigFilesWatches(toPath3(configFileName), compilerOptions, watchOptions, WatchType.ExtendedConfigFile);
     }
-    function parseConfigFile2() {
-      Debug.assert(configFileName);
-      setConfigFileParsingResult(getParsedCommandLineOfConfigFile(
-        configFileName,
-        optionsToExtendForConfigFile,
-        parseConfigFileHost,
-        extendedConfigCache || (extendedConfigCache = /* @__PURE__ */ new Map()),
-        watchOptionsToExtend,
-        extraFileExtensions
-      ));
+  }
+  function build(state, project, cancellationToken, writeFile2, getCustomTransformers, onlyReferences) {
+    mark("SolutionBuilder::beforeBuild");
+    const result = buildWorker(state, project, cancellationToken, writeFile2, getCustomTransformers, onlyReferences);
+    mark("SolutionBuilder::afterBuild");
+    measure("SolutionBuilder::Build", "SolutionBuilder::beforeBuild", "SolutionBuilder::afterBuild");
+    return result;
+  }
+  function buildWorker(state, project, cancellationToken, writeFile2, getCustomTransformers, onlyReferences) {
+    const buildOrder = getBuildOrderFor(state, project, onlyReferences);
+    if (!buildOrder)
+      return 3 /* InvalidProject_OutputsSkipped */;
+    setupInitialBuild(state, cancellationToken);
+    let reportQueue = true;
+    let successfulProjects = 0;
+    while (true) {
+      const invalidatedProject = getNextInvalidatedProject(state, buildOrder, reportQueue);
+      if (!invalidatedProject)
+        break;
+      reportQueue = false;
+      invalidatedProject.done(cancellationToken, writeFile2, getCustomTransformers == null ? void 0 : getCustomTransformers(invalidatedProject.project));
+      if (!state.diagnostics.has(invalidatedProject.projectPath))
+        successfulProjects++;
     }
-    function setConfigFileParsingResult(configFileParseResult) {
-      rootFileNames = configFileParseResult.fileNames;
-      compilerOptions = configFileParseResult.options;
-      watchOptions = configFileParseResult.watchOptions;
-      projectReferences = configFileParseResult.projectReferences;
-      wildcardDirectories = configFileParseResult.wildcardDirectories;
-      configFileParsingDiagnostics = getConfigFileParsingDiagnostics(configFileParseResult).slice();
-      canConfigFileJsonReportNoInputFiles = canJsonReportNoInputFiles(configFileParseResult.raw);
-      hasChangedConfigFileParsingErrors = true;
+    disableCache(state);
+    reportErrorSummary(state, buildOrder);
+    startWatching(state, buildOrder);
+    return isCircularBuildOrder(buildOrder) ? 4 /* ProjectReferenceCycle_OutputsSkipped */ : !buildOrder.some((p) => state.diagnostics.has(toResolvedConfigFilePath(state, p))) ? 0 /* Success */ : successfulProjects ? 2 /* DiagnosticsPresent_OutputsGenerated */ : 1 /* DiagnosticsPresent_OutputsSkipped */;
+  }
+  function clean(state, project, onlyReferences) {
+    mark("SolutionBuilder::beforeClean");
+    const result = cleanWorker(state, project, onlyReferences);
+    mark("SolutionBuilder::afterClean");
+    measure("SolutionBuilder::Clean", "SolutionBuilder::beforeClean", "SolutionBuilder::afterClean");
+    return result;
+  }
+  function cleanWorker(state, project, onlyReferences) {
+    const buildOrder = getBuildOrderFor(state, project, onlyReferences);
+    if (!buildOrder)
+      return 3 /* InvalidProject_OutputsSkipped */;
+    if (isCircularBuildOrder(buildOrder)) {
+      reportErrors(state, buildOrder.circularDiagnostics);
+      return 4 /* ProjectReferenceCycle_OutputsSkipped */;
     }
-    function getParsedCommandLine(configFileName2) {
-      const configPath = toPath3(configFileName2);
-      let config = parsedConfigs == null ? void 0 : parsedConfigs.get(configPath);
-      if (config) {
-        if (!config.reloadLevel)
-          return config.parsedCommandLine;
-        if (config.parsedCommandLine && config.reloadLevel === 1 /* Partial */ && !host.getParsedCommandLine) {
-          writeLog("Reloading new file names and options");
-          Debug.assert(compilerOptions);
-          const fileNames = getFileNamesFromConfigSpecs(
-            config.parsedCommandLine.options.configFile.configFileSpecs,
-            getNormalizedAbsolutePath(getDirectoryPath(configFileName2), currentDirectory),
-            compilerOptions,
-            parseConfigFileHost
-          );
-          config.parsedCommandLine = { ...config.parsedCommandLine, fileNames };
-          config.reloadLevel = void 0;
-          return config.parsedCommandLine;
-        }
+    const { options, host } = state;
+    const filesToDelete = options.dry ? [] : void 0;
+    for (const proj of buildOrder) {
+      const resolvedPath = toResolvedConfigFilePath(state, proj);
+      const parsed = parseConfigFile(state, proj, resolvedPath);
+      if (parsed === void 0) {
+        reportParseConfigFileDiagnostic(state, resolvedPath);
+        continue;
       }
-      writeLog(`Loading config file: ${configFileName2}`);
-      const parsedCommandLine = host.getParsedCommandLine ? host.getParsedCommandLine(configFileName2) : getParsedCommandLineFromConfigFileHost(configFileName2);
-      if (config) {
-        config.parsedCommandLine = parsedCommandLine;
-        config.reloadLevel = void 0;
-      } else {
-        (parsedConfigs || (parsedConfigs = /* @__PURE__ */ new Map())).set(configPath, config = { parsedCommandLine });
+      const outputs = getAllProjectOutputs(parsed, !host.useCaseSensitiveFileNames());
+      if (!outputs.length)
+        continue;
+      const inputFileNames = new Set(parsed.fileNames.map((f) => toPath2(state, f)));
+      for (const output of outputs) {
+        if (inputFileNames.has(toPath2(state, output)))
+          continue;
+        if (host.fileExists(output)) {
+          if (filesToDelete) {
+            filesToDelete.push(output);
+          } else {
+            host.deleteFile(output);
+            invalidateProject(state, resolvedPath, 0 /* Update */);
+          }
+        }
       }
-      watchReferencedProject(configFileName2, configPath, config);
-      return parsedCommandLine;
-    }
-    function getParsedCommandLineFromConfigFileHost(configFileName2) {
-      const onUnRecoverableConfigFileDiagnostic = parseConfigFileHost.onUnRecoverableConfigFileDiagnostic;
-      parseConfigFileHost.onUnRecoverableConfigFileDiagnostic = noop;
-      const parsedCommandLine = getParsedCommandLineOfConfigFile(
-        configFileName2,
-        /*optionsToExtend*/
-        void 0,
-        parseConfigFileHost,
-        extendedConfigCache || (extendedConfigCache = /* @__PURE__ */ new Map()),
-        watchOptionsToExtend
-      );
-      parseConfigFileHost.onUnRecoverableConfigFileDiagnostic = onUnRecoverableConfigFileDiagnostic;
-      return parsedCommandLine;
     }
-    function onReleaseParsedCommandLine(fileName) {
-      var _a;
-      const path = toPath3(fileName);
-      const config = parsedConfigs == null ? void 0 : parsedConfigs.get(path);
-      if (!config)
-        return;
-      parsedConfigs.delete(path);
-      if (config.watchedDirectories)
-        clearMap(config.watchedDirectories, closeFileWatcherOf);
-      (_a = config.watcher) == null ? void 0 : _a.close();
-      clearSharedExtendedConfigFileWatcher(path, sharedExtendedConfigFileWatchers);
+    if (filesToDelete) {
+      reportStatus(state, Diagnostics.A_non_dry_build_would_delete_the_following_files_Colon_0, filesToDelete.map((f) => `\r
+ * ${f}`).join(""));
     }
-    function watchFilePath(path, file, callback, pollingInterval, options, watchType) {
-      return watchFile2(file, (fileName, eventKind) => callback(fileName, eventKind, path), pollingInterval, options, watchType);
+    return 0 /* Success */;
+  }
+  function invalidateProject(state, resolved, updateLevel) {
+    if (state.host.getParsedCommandLine && updateLevel === 1 /* RootNamesAndUpdate */) {
+      updateLevel = 2 /* Full */;
     }
-    function onSourceFileChange(fileName, eventKind, path) {
-      updateCachedSystemWithFile(fileName, path, eventKind);
-      if (eventKind === 2 /* Deleted */ && sourceFilesCache.has(path)) {
-        resolutionCache.invalidateResolutionOfFile(path);
-      }
-      nextSourceFileVersion(path);
-      scheduleProgramUpdate();
+    if (updateLevel === 2 /* Full */) {
+      state.configFileCache.delete(resolved);
+      state.buildOrder = void 0;
     }
-    function updateCachedSystemWithFile(fileName, path, eventKind) {
-      if (cachedDirectoryStructureHost) {
-        cachedDirectoryStructureHost.addOrDeleteFile(fileName, path, eventKind);
-      }
+    state.needsSummary = true;
+    clearProjectStatus(state, resolved);
+    addProjToQueue(state, resolved, updateLevel);
+    enableCache(state);
+  }
+  function invalidateProjectAndScheduleBuilds(state, resolvedPath, updateLevel) {
+    state.reportFileChangeDetected = true;
+    invalidateProject(state, resolvedPath, updateLevel);
+    scheduleBuildInvalidatedProject(
+      state,
+      250,
+      /*changeDetected*/
+      true
+    );
+  }
+  function scheduleBuildInvalidatedProject(state, time, changeDetected) {
+    const { hostWithWatch } = state;
+    if (!hostWithWatch.setTimeout || !hostWithWatch.clearTimeout) {
+      return;
     }
-    function watchMissingFilePath(missingFilePath) {
-      return (parsedConfigs == null ? void 0 : parsedConfigs.has(missingFilePath)) ? noopFileWatcher : watchFilePath(missingFilePath, missingFilePath, onMissingFileChange, 500 /* Medium */, watchOptions, WatchType.MissingFile);
+    if (state.timerToBuildInvalidatedProject) {
+      hostWithWatch.clearTimeout(state.timerToBuildInvalidatedProject);
     }
-    function onMissingFileChange(fileName, eventKind, missingFilePath) {
-      updateCachedSystemWithFile(fileName, missingFilePath, eventKind);
-      if (eventKind === 0 /* Created */ && missingFilesMap.has(missingFilePath)) {
-        missingFilesMap.get(missingFilePath).close();
-        missingFilesMap.delete(missingFilePath);
-        nextSourceFileVersion(missingFilePath);
-        scheduleProgramUpdate();
-      }
+    state.timerToBuildInvalidatedProject = hostWithWatch.setTimeout(buildNextInvalidatedProject, time, "timerToBuildInvalidatedProject", state, changeDetected);
+  }
+  function buildNextInvalidatedProject(_timeoutType, state, changeDetected) {
+    mark("SolutionBuilder::beforeBuild");
+    const buildOrder = buildNextInvalidatedProjectWorker(state, changeDetected);
+    mark("SolutionBuilder::afterBuild");
+    measure("SolutionBuilder::Build", "SolutionBuilder::beforeBuild", "SolutionBuilder::afterBuild");
+    if (buildOrder)
+      reportErrorSummary(state, buildOrder);
+  }
+  function buildNextInvalidatedProjectWorker(state, changeDetected) {
+    state.timerToBuildInvalidatedProject = void 0;
+    if (state.reportFileChangeDetected) {
+      state.reportFileChangeDetected = false;
+      state.projectErrorsReported.clear();
+      reportWatchStatus(state, Diagnostics.File_change_detected_Starting_incremental_compilation);
     }
-    function watchConfigFileWildCardDirectories() {
-      if (wildcardDirectories) {
-        updateWatchingWildcardDirectories(
-          watchedWildcardDirectories || (watchedWildcardDirectories = /* @__PURE__ */ new Map()),
-          new Map(Object.entries(wildcardDirectories)),
-          watchWildcardDirectory
+    let projectsBuilt = 0;
+    const buildOrder = getBuildOrder(state);
+    const invalidatedProject = getNextInvalidatedProject(
+      state,
+      buildOrder,
+      /*reportQueue*/
+      false
+    );
+    if (invalidatedProject) {
+      invalidatedProject.done();
+      projectsBuilt++;
+      while (state.projectPendingBuild.size) {
+        if (state.timerToBuildInvalidatedProject)
+          return;
+        const info = getNextInvalidatedProjectCreateInfo(
+          state,
+          buildOrder,
+          /*reportQueue*/
+          false
         );
-      } else if (watchedWildcardDirectories) {
-        clearMap(watchedWildcardDirectories, closeFileWatcherOf);
+        if (!info)
+          break;
+        if (info.kind !== 2 /* UpdateOutputFileStamps */ && (changeDetected || projectsBuilt === 5)) {
+          scheduleBuildInvalidatedProject(
+            state,
+            100,
+            /*changeDetected*/
+            false
+          );
+          return;
+        }
+        const project = createInvalidatedProjectWithInfo(state, info, buildOrder);
+        project.done();
+        if (info.kind !== 2 /* UpdateOutputFileStamps */)
+          projectsBuilt++;
       }
     }
-    function watchWildcardDirectory(directory, flags) {
-      return watchDirectory(
-        directory,
+    disableCache(state);
+    return buildOrder;
+  }
+  function watchConfigFile(state, resolved, resolvedPath, parsed) {
+    if (!state.watch || state.allWatchedConfigFiles.has(resolvedPath))
+      return;
+    state.allWatchedConfigFiles.set(
+      resolvedPath,
+      watchFile(
+        state,
+        resolved,
+        () => invalidateProjectAndScheduleBuilds(state, resolvedPath, 2 /* Full */),
+        2e3 /* High */,
+        parsed == null ? void 0 : parsed.watchOptions,
+        WatchType.ConfigFile,
+        resolved
+      )
+    );
+  }
+  function watchExtendedConfigFiles(state, resolvedPath, parsed) {
+    updateSharedExtendedConfigFileWatcher(
+      resolvedPath,
+      parsed == null ? void 0 : parsed.options,
+      state.allWatchedExtendedConfigFiles,
+      (extendedConfigFileName, extendedConfigFilePath) => watchFile(
+        state,
+        extendedConfigFileName,
+        () => {
+          var _a;
+          return (_a = state.allWatchedExtendedConfigFiles.get(extendedConfigFilePath)) == null ? void 0 : _a.projects.forEach((projectConfigFilePath) => invalidateProjectAndScheduleBuilds(state, projectConfigFilePath, 2 /* Full */));
+        },
+        2e3 /* High */,
+        parsed == null ? void 0 : parsed.watchOptions,
+        WatchType.ExtendedConfigFile
+      ),
+      (fileName) => toPath2(state, fileName)
+    );
+  }
+  function watchWildCardDirectories(state, resolved, resolvedPath, parsed) {
+    if (!state.watch)
+      return;
+    updateWatchingWildcardDirectories(
+      getOrCreateValueMapFromConfigFileMap(state.allWatchedWildcardDirectories, resolvedPath),
+      new Map(Object.entries(parsed.wildcardDirectories)),
+      (dir, flags) => state.watchDirectory(
+        dir,
         (fileOrDirectory) => {
-          Debug.assert(configFileName);
-          Debug.assert(compilerOptions);
-          const fileOrDirectoryPath = toPath3(fileOrDirectory);
-          if (cachedDirectoryStructureHost) {
-            cachedDirectoryStructureHost.addOrDeleteFileOrDirectory(fileOrDirectory, fileOrDirectoryPath);
-          }
-          nextSourceFileVersion(fileOrDirectoryPath);
+          var _a;
           if (isIgnoredFileFromWildCardWatching({
-            watchedDirPath: toPath3(directory),
+            watchedDirPath: toPath2(state, dir),
             fileOrDirectory,
-            fileOrDirectoryPath,
-            configFileName,
-            extraFileExtensions,
-            options: compilerOptions,
-            program: getCurrentBuilderProgram() || rootFileNames,
-            currentDirectory,
-            useCaseSensitiveFileNames,
-            writeLog,
-            toPath: toPath3
+            fileOrDirectoryPath: toPath2(state, fileOrDirectory),
+            configFileName: resolved,
+            currentDirectory: state.compilerHost.getCurrentDirectory(),
+            options: parsed.options,
+            program: state.builderPrograms.get(resolvedPath) || ((_a = getCachedParsedConfigFile(state, resolvedPath)) == null ? void 0 : _a.fileNames),
+            useCaseSensitiveFileNames: state.parseConfigFileHost.useCaseSensitiveFileNames,
+            writeLog: (s) => state.writeLog(s),
+            toPath: (fileName) => toPath2(state, fileName)
           }))
             return;
-          if (reloadLevel !== 2 /* Full */) {
-            reloadLevel = 1 /* Partial */;
-            scheduleProgramUpdate();
-          }
+          invalidateProjectAndScheduleBuilds(state, resolvedPath, 1 /* RootNamesAndUpdate */);
         },
         flags,
-        watchOptions,
-        WatchType.WildcardDirectory
-      );
-    }
-    function updateExtendedConfigFilesWatches(forProjectPath, options, watchOptions2, watchType) {
-      updateSharedExtendedConfigFileWatcher(
-        forProjectPath,
-        options,
-        sharedExtendedConfigFileWatchers || (sharedExtendedConfigFileWatchers = /* @__PURE__ */ new Map()),
-        (extendedConfigFileName, extendedConfigFilePath) => watchFile2(
-          extendedConfigFileName,
-          (_fileName, eventKind) => {
-            var _a;
-            updateCachedSystemWithFile(extendedConfigFileName, extendedConfigFilePath, eventKind);
-            if (extendedConfigCache)
-              cleanExtendedConfigCache(extendedConfigCache, extendedConfigFilePath, toPath3);
-            const projects = (_a = sharedExtendedConfigFileWatchers.get(extendedConfigFilePath)) == null ? void 0 : _a.projects;
-            if (!(projects == null ? void 0 : projects.size))
-              return;
-            projects.forEach((projectPath) => {
-              if (configFileName && toPath3(configFileName) === projectPath) {
-                reloadLevel = 2 /* Full */;
-              } else {
-                const config = parsedConfigs == null ? void 0 : parsedConfigs.get(projectPath);
-                if (config)
-                  config.reloadLevel = 2 /* Full */;
-                resolutionCache.removeResolutionsFromProjectReferenceRedirects(projectPath);
-              }
-              scheduleProgramUpdate();
-            });
-          },
-          2e3 /* High */,
-          watchOptions2,
-          watchType
+        parsed == null ? void 0 : parsed.watchOptions,
+        WatchType.WildcardDirectory,
+        resolved
+      )
+    );
+  }
+  function watchInputFiles(state, resolved, resolvedPath, parsed) {
+    if (!state.watch)
+      return;
+    mutateMap(
+      getOrCreateValueMapFromConfigFileMap(state.allWatchedInputFiles, resolvedPath),
+      arrayToMap(parsed.fileNames, (fileName) => toPath2(state, fileName)),
+      {
+        createNewValue: (_path, input) => watchFile(
+          state,
+          input,
+          () => invalidateProjectAndScheduleBuilds(state, resolvedPath, 0 /* Update */),
+          250 /* Low */,
+          parsed == null ? void 0 : parsed.watchOptions,
+          WatchType.SourceFile,
+          resolved
         ),
-        toPath3
-      );
-    }
-    function watchReferencedProject(configFileName2, configPath, commandLine) {
-      var _a, _b, _c, _d, _e;
-      commandLine.watcher || (commandLine.watcher = watchFile2(
-        configFileName2,
-        (_fileName, eventKind) => {
-          updateCachedSystemWithFile(configFileName2, configPath, eventKind);
-          const config = parsedConfigs == null ? void 0 : parsedConfigs.get(configPath);
-          if (config)
-            config.reloadLevel = 2 /* Full */;
-          resolutionCache.removeResolutionsFromProjectReferenceRedirects(configPath);
-          scheduleProgramUpdate();
-        },
-        2e3 /* High */,
-        ((_a = commandLine.parsedCommandLine) == null ? void 0 : _a.watchOptions) || watchOptions,
-        WatchType.ConfigFileOfReferencedProject
-      ));
-      if ((_b = commandLine.parsedCommandLine) == null ? void 0 : _b.wildcardDirectories) {
-        updateWatchingWildcardDirectories(
-          commandLine.watchedDirectories || (commandLine.watchedDirectories = /* @__PURE__ */ new Map()),
-          new Map(Object.entries((_c = commandLine.parsedCommandLine) == null ? void 0 : _c.wildcardDirectories)),
-          (directory, flags) => {
-            var _a2;
-            return watchDirectory(
-              directory,
-              (fileOrDirectory) => {
-                const fileOrDirectoryPath = toPath3(fileOrDirectory);
-                if (cachedDirectoryStructureHost) {
-                  cachedDirectoryStructureHost.addOrDeleteFileOrDirectory(fileOrDirectory, fileOrDirectoryPath);
-                }
-                nextSourceFileVersion(fileOrDirectoryPath);
-                const config = parsedConfigs == null ? void 0 : parsedConfigs.get(configPath);
-                if (!(config == null ? void 0 : config.parsedCommandLine))
-                  return;
-                if (isIgnoredFileFromWildCardWatching({
-                  watchedDirPath: toPath3(directory),
-                  fileOrDirectory,
-                  fileOrDirectoryPath,
-                  configFileName: configFileName2,
-                  options: config.parsedCommandLine.options,
-                  program: config.parsedCommandLine.fileNames,
-                  currentDirectory,
-                  useCaseSensitiveFileNames,
-                  writeLog,
-                  toPath: toPath3
-                }))
-                  return;
-                if (config.reloadLevel !== 2 /* Full */) {
-                  config.reloadLevel = 1 /* Partial */;
-                  scheduleProgramUpdate();
-                }
-              },
-              flags,
-              ((_a2 = commandLine.parsedCommandLine) == null ? void 0 : _a2.watchOptions) || watchOptions,
-              WatchType.WildcardDirectoryOfReferencedProject
-            );
-          }
-        );
-      } else if (commandLine.watchedDirectories) {
-        clearMap(commandLine.watchedDirectories, closeFileWatcherOf);
-        commandLine.watchedDirectories = void 0;
+        onDeleteValue: closeFileWatcher
       }
-      updateExtendedConfigFilesWatches(
-        configPath,
-        (_d = commandLine.parsedCommandLine) == null ? void 0 : _d.options,
-        ((_e = commandLine.parsedCommandLine) == null ? void 0 : _e.watchOptions) || watchOptions,
-        WatchType.ExtendedConfigOfReferencedProject
-      );
-    }
+    );
   }
-  var init_watchPublic = __esm({
-    "src/compiler/watchPublic.ts"() {
-      "use strict";
-      init_ts2();
-    }
-  });
-
-  // src/compiler/tsbuild.ts
-  function resolveConfigFileProjectName(project) {
-    if (fileExtensionIs(project, ".json" /* Json */)) {
-      return project;
-    }
-    return combinePaths(project, "tsconfig.json");
+  function watchPackageJsonFiles(state, resolved, resolvedPath, parsed) {
+    if (!state.watch || !state.lastCachedPackageJsonLookups)
+      return;
+    mutateMap(
+      getOrCreateValueMapFromConfigFileMap(state.allWatchedPackageJsonFiles, resolvedPath),
+      new Map(state.lastCachedPackageJsonLookups.get(resolvedPath)),
+      {
+        createNewValue: (path, _input) => watchFile(
+          state,
+          path,
+          () => invalidateProjectAndScheduleBuilds(state, resolvedPath, 0 /* Update */),
+          2e3 /* High */,
+          parsed == null ? void 0 : parsed.watchOptions,
+          WatchType.PackageJson,
+          resolved
+        ),
+        onDeleteValue: closeFileWatcher
+      }
+    );
   }
-  var UpToDateStatusType;
-  var init_tsbuild = __esm({
-    "src/compiler/tsbuild.ts"() {
-      "use strict";
-      init_ts2();
-      UpToDateStatusType = /* @__PURE__ */ ((UpToDateStatusType2) => {
-        UpToDateStatusType2[UpToDateStatusType2["Unbuildable"] = 0] = "Unbuildable";
-        UpToDateStatusType2[UpToDateStatusType2["UpToDate"] = 1] = "UpToDate";
-        UpToDateStatusType2[UpToDateStatusType2["UpToDateWithUpstreamTypes"] = 2] = "UpToDateWithUpstreamTypes";
-        UpToDateStatusType2[UpToDateStatusType2["OutOfDateWithPrepend"] = 3] = "OutOfDateWithPrepend";
-        UpToDateStatusType2[UpToDateStatusType2["OutputMissing"] = 4] = "OutputMissing";
-        UpToDateStatusType2[UpToDateStatusType2["ErrorReadingFile"] = 5] = "ErrorReadingFile";
-        UpToDateStatusType2[UpToDateStatusType2["OutOfDateWithSelf"] = 6] = "OutOfDateWithSelf";
-        UpToDateStatusType2[UpToDateStatusType2["OutOfDateWithUpstream"] = 7] = "OutOfDateWithUpstream";
-        UpToDateStatusType2[UpToDateStatusType2["OutOfDateBuildInfo"] = 8] = "OutOfDateBuildInfo";
-        UpToDateStatusType2[UpToDateStatusType2["OutOfDateOptions"] = 9] = "OutOfDateOptions";
-        UpToDateStatusType2[UpToDateStatusType2["OutOfDateRoots"] = 10] = "OutOfDateRoots";
-        UpToDateStatusType2[UpToDateStatusType2["UpstreamOutOfDate"] = 11] = "UpstreamOutOfDate";
-        UpToDateStatusType2[UpToDateStatusType2["UpstreamBlocked"] = 12] = "UpstreamBlocked";
-        UpToDateStatusType2[UpToDateStatusType2["ComputingUpstream"] = 13] = "ComputingUpstream";
-        UpToDateStatusType2[UpToDateStatusType2["TsVersionOutputOfDate"] = 14] = "TsVersionOutputOfDate";
-        UpToDateStatusType2[UpToDateStatusType2["UpToDateWithInputFileText"] = 15] = "UpToDateWithInputFileText";
-        UpToDateStatusType2[UpToDateStatusType2["ContainerOnly"] = 16] = "ContainerOnly";
-        UpToDateStatusType2[UpToDateStatusType2["ForceBuild"] = 17] = "ForceBuild";
-        return UpToDateStatusType2;
-      })(UpToDateStatusType || {});
-    }
-  });
-
-  // src/compiler/tsbuildPublic.ts
-  function getOrCreateValueFromConfigFileMap(configFileMap, resolved, createT) {
-    const existingValue = configFileMap.get(resolved);
-    let newValue;
-    if (!existingValue) {
-      newValue = createT();
-      configFileMap.set(resolved, newValue);
+  function startWatching(state, buildOrder) {
+    if (!state.watchAllProjectsPending)
+      return;
+    mark("SolutionBuilder::beforeWatcherCreation");
+    state.watchAllProjectsPending = false;
+    for (const resolved of getBuildOrderFromAnyBuildOrder(buildOrder)) {
+      const resolvedPath = toResolvedConfigFilePath(state, resolved);
+      const cfg = parseConfigFile(state, resolved, resolvedPath);
+      watchConfigFile(state, resolved, resolvedPath, cfg);
+      watchExtendedConfigFiles(state, resolvedPath, cfg);
+      if (cfg) {
+        watchWildCardDirectories(state, resolved, resolvedPath, cfg);
+        watchInputFiles(state, resolved, resolvedPath, cfg);
+        watchPackageJsonFiles(state, resolved, resolvedPath, cfg);
+      }
     }
-    return existingValue || newValue;
+    mark("SolutionBuilder::afterWatcherCreation");
+    measure("SolutionBuilder::Watcher creation", "SolutionBuilder::beforeWatcherCreation", "SolutionBuilder::afterWatcherCreation");
   }
-  function getOrCreateValueMapFromConfigFileMap(configFileMap, resolved) {
-    return getOrCreateValueFromConfigFileMap(configFileMap, resolved, () => /* @__PURE__ */ new Map());
+  function stopWatching(state) {
+    clearMap(state.allWatchedConfigFiles, closeFileWatcher);
+    clearMap(state.allWatchedExtendedConfigFiles, closeFileWatcherOf);
+    clearMap(state.allWatchedWildcardDirectories, (watchedWildcardDirectories) => clearMap(watchedWildcardDirectories, closeFileWatcherOf));
+    clearMap(state.allWatchedInputFiles, (watchedWildcardDirectories) => clearMap(watchedWildcardDirectories, closeFileWatcher));
+    clearMap(state.allWatchedPackageJsonFiles, (watchedPacageJsonFiles) => clearMap(watchedPacageJsonFiles, closeFileWatcher));
   }
-  function getCurrentTime(host) {
-    return host.now ? host.now() : /* @__PURE__ */ new Date();
+  function createSolutionBuilderWorker(watch, hostOrHostWithWatch, rootNames, options, baseWatchOptions) {
+    const state = createSolutionBuilderState(watch, hostOrHostWithWatch, rootNames, options, baseWatchOptions);
+    return {
+      build: (project, cancellationToken, writeFile2, getCustomTransformers) => build(state, project, cancellationToken, writeFile2, getCustomTransformers),
+      clean: (project) => clean(state, project),
+      buildReferences: (project, cancellationToken, writeFile2, getCustomTransformers) => build(
+        state,
+        project,
+        cancellationToken,
+        writeFile2,
+        getCustomTransformers,
+        /*onlyReferences*/
+        true
+      ),
+      cleanReferences: (project) => clean(
+        state,
+        project,
+        /*onlyReferences*/
+        true
+      ),
+      getNextInvalidatedProject: (cancellationToken) => {
+        setupInitialBuild(state, cancellationToken);
+        return getNextInvalidatedProject(
+          state,
+          getBuildOrder(state),
+          /*reportQueue*/
+          false
+        );
+      },
+      getBuildOrder: () => getBuildOrder(state),
+      getUpToDateStatusOfProject: (project) => {
+        const configFileName = resolveProjectName(state, project);
+        const configFilePath = toResolvedConfigFilePath(state, configFileName);
+        return getUpToDateStatus(state, parseConfigFile(state, configFileName, configFilePath), configFilePath);
+      },
+      invalidateProject: (configFilePath, updateLevel) => invalidateProject(state, configFilePath, updateLevel || 0 /* Update */),
+      close: () => stopWatching(state)
+    };
   }
-  function isCircularBuildOrder(buildOrder) {
-    return !!buildOrder && !!buildOrder.buildOrder;
+  function relName(state, path) {
+    return convertToRelativePath(path, state.compilerHost.getCurrentDirectory(), state.compilerHost.getCanonicalFileName);
   }
-  function getBuildOrderFromAnyBuildOrder(anyBuildOrder) {
-    return isCircularBuildOrder(anyBuildOrder) ? anyBuildOrder.buildOrder : anyBuildOrder;
+  function reportStatus(state, message, ...args) {
+    state.host.reportSolutionBuilderStatus(createCompilerDiagnostic(message, ...args));
   }
-  function createBuilderStatusReporter(system, pretty) {
-    return (diagnostic) => {
-      let output = pretty ? `[${formatColorAndReset(getLocaleTimeString(system), "\x1B[90m" /* Grey */)}] ` : `${getLocaleTimeString(system)} - `;
-      output += `${flattenDiagnosticMessageText(diagnostic.messageText, system.newLine)}${system.newLine + system.newLine}`;
-      system.write(output);
-    };
+  function reportWatchStatus(state, message, ...args) {
+    var _a, _b;
+    (_b = (_a = state.hostWithWatch).onWatchStatusChange) == null ? void 0 : _b.call(_a, createCompilerDiagnostic(message, ...args), state.host.getNewLine(), state.baseCompilerOptions);
   }
-  function createSolutionBuilderHostBase(system, createProgram2, reportDiagnostic, reportSolutionBuilderStatus) {
-    const host = createProgramHost(system, createProgram2);
-    host.getModifiedTime = system.getModifiedTime ? (path) => system.getModifiedTime(path) : returnUndefined;
-    host.setModifiedTime = system.setModifiedTime ? (path, date) => system.setModifiedTime(path, date) : noop;
-    host.deleteFile = system.deleteFile ? (path) => system.deleteFile(path) : noop;
-    host.reportDiagnostic = reportDiagnostic || createDiagnosticReporter(system);
-    host.reportSolutionBuilderStatus = reportSolutionBuilderStatus || createBuilderStatusReporter(system);
-    host.now = maybeBind(system, system.now);
-    return host;
+  function reportErrors({ host }, errors) {
+    errors.forEach((err) => host.reportDiagnostic(err));
   }
-  function createSolutionBuilderHost(system = sys, createProgram2, reportDiagnostic, reportSolutionBuilderStatus, reportErrorSummary2) {
-    const host = createSolutionBuilderHostBase(system, createProgram2, reportDiagnostic, reportSolutionBuilderStatus);
-    host.reportErrorSummary = reportErrorSummary2;
-    return host;
+  function reportAndStoreErrors(state, proj, errors) {
+    reportErrors(state, errors);
+    state.projectErrorsReported.set(proj, true);
+    if (errors.length) {
+      state.diagnostics.set(proj, errors);
+    }
   }
-  function createSolutionBuilderWithWatchHost(system = sys, createProgram2, reportDiagnostic, reportSolutionBuilderStatus, reportWatchStatus2) {
-    const host = createSolutionBuilderHostBase(system, createProgram2, reportDiagnostic, reportSolutionBuilderStatus);
-    const watchHost = createWatchHost(system, reportWatchStatus2);
-    copyProperties(host, watchHost);
-    return host;
+  function reportParseConfigFileDiagnostic(state, proj) {
+    reportAndStoreErrors(state, proj, [state.configFileCache.get(proj)]);
   }
-  function getCompilerOptionsOfBuildOptions(buildOptions) {
-    const result = {};
-    commonOptionsWithBuild.forEach((option) => {
-      if (hasProperty(buildOptions, option.name))
-        result[option.name] = buildOptions[option.name];
-    });
-    return result;
+  function reportErrorSummary(state, buildOrder) {
+    if (!state.needsSummary)
+      return;
+    state.needsSummary = false;
+    const canReportSummary = state.watch || !!state.host.reportErrorSummary;
+    const { diagnostics } = state;
+    let totalErrors = 0;
+    let filesInError = [];
+    if (isCircularBuildOrder(buildOrder)) {
+      reportBuildQueue(state, buildOrder.buildOrder);
+      reportErrors(state, buildOrder.circularDiagnostics);
+      if (canReportSummary)
+        totalErrors += getErrorCountForSummary(buildOrder.circularDiagnostics);
+      if (canReportSummary)
+        filesInError = [...filesInError, ...getFilesInErrorForSummary(buildOrder.circularDiagnostics)];
+    } else {
+      buildOrder.forEach((project) => {
+        const projectPath = toResolvedConfigFilePath(state, project);
+        if (!state.projectErrorsReported.has(projectPath)) {
+          reportErrors(state, diagnostics.get(projectPath) || emptyArray);
+        }
+      });
+      if (canReportSummary)
+        diagnostics.forEach((singleProjectErrors) => totalErrors += getErrorCountForSummary(singleProjectErrors));
+      if (canReportSummary)
+        diagnostics.forEach((singleProjectErrors) => [...filesInError, ...getFilesInErrorForSummary(singleProjectErrors)]);
+    }
+    if (state.watch) {
+      reportWatchStatus(state, getWatchErrorSummaryDiagnosticMessage(totalErrors), totalErrors);
+    } else if (state.host.reportErrorSummary) {
+      state.host.reportErrorSummary(totalErrors, filesInError);
+    }
   }
-  function createSolutionBuilder(host, rootNames, defaultOptions) {
-    return createSolutionBuilderWorker(
-      /*watch*/
-      false,
-      host,
-      rootNames,
-      defaultOptions
-    );
+  function reportBuildQueue(state, buildQueue) {
+    if (state.options.verbose) {
+      reportStatus(state, Diagnostics.Projects_in_this_build_Colon_0, buildQueue.map((s) => "\r\n    * " + relName(state, s)).join(""));
+    }
   }
-  function createSolutionBuilderWithWatch(host, rootNames, defaultOptions, baseWatchOptions) {
-    return createSolutionBuilderWorker(
-      /*watch*/
-      true,
-      host,
-      rootNames,
-      defaultOptions,
-      baseWatchOptions
-    );
+  function reportUpToDateStatus(state, configFileName, status) {
+    switch (status.type) {
+      case 6 /* OutOfDateWithSelf */:
+        return reportStatus(
+          state,
+          Diagnostics.Project_0_is_out_of_date_because_output_1_is_older_than_input_2,
+          relName(state, configFileName),
+          relName(state, status.outOfDateOutputFileName),
+          relName(state, status.newerInputFileName)
+        );
+      case 7 /* OutOfDateWithUpstream */:
+        return reportStatus(
+          state,
+          Diagnostics.Project_0_is_out_of_date_because_output_1_is_older_than_input_2,
+          relName(state, configFileName),
+          relName(state, status.outOfDateOutputFileName),
+          relName(state, status.newerProjectName)
+        );
+      case 4 /* OutputMissing */:
+        return reportStatus(
+          state,
+          Diagnostics.Project_0_is_out_of_date_because_output_file_1_does_not_exist,
+          relName(state, configFileName),
+          relName(state, status.missingOutputFileName)
+        );
+      case 5 /* ErrorReadingFile */:
+        return reportStatus(
+          state,
+          Diagnostics.Project_0_is_out_of_date_because_there_was_error_reading_file_1,
+          relName(state, configFileName),
+          relName(state, status.fileName)
+        );
+      case 8 /* OutOfDateBuildInfo */:
+        return reportStatus(
+          state,
+          Diagnostics.Project_0_is_out_of_date_because_buildinfo_file_1_indicates_that_some_of_the_changes_were_not_emitted,
+          relName(state, configFileName),
+          relName(state, status.buildInfoFile)
+        );
+      case 9 /* OutOfDateOptions */:
+        return reportStatus(
+          state,
+          Diagnostics.Project_0_is_out_of_date_because_buildinfo_file_1_indicates_there_is_change_in_compilerOptions,
+          relName(state, configFileName),
+          relName(state, status.buildInfoFile)
+        );
+      case 10 /* OutOfDateRoots */:
+        return reportStatus(
+          state,
+          Diagnostics.Project_0_is_out_of_date_because_buildinfo_file_1_indicates_that_file_2_was_root_file_of_compilation_but_not_any_more,
+          relName(state, configFileName),
+          relName(state, status.buildInfoFile),
+          relName(state, status.inputFile)
+        );
+      case 1 /* UpToDate */:
+        if (status.newestInputFileTime !== void 0) {
+          return reportStatus(
+            state,
+            Diagnostics.Project_0_is_up_to_date_because_newest_input_1_is_older_than_output_2,
+            relName(state, configFileName),
+            relName(state, status.newestInputFileName || ""),
+            relName(state, status.oldestOutputFileName || "")
+          );
+        }
+        break;
+      case 3 /* OutOfDateWithPrepend */:
+        return reportStatus(
+          state,
+          Diagnostics.Project_0_is_out_of_date_because_output_of_its_dependency_1_has_changed,
+          relName(state, configFileName),
+          relName(state, status.newerProjectName)
+        );
+      case 2 /* UpToDateWithUpstreamTypes */:
+        return reportStatus(
+          state,
+          Diagnostics.Project_0_is_up_to_date_with_d_ts_files_from_its_dependencies,
+          relName(state, configFileName)
+        );
+      case 15 /* UpToDateWithInputFileText */:
+        return reportStatus(
+          state,
+          Diagnostics.Project_0_is_up_to_date_but_needs_to_update_timestamps_of_output_files_that_are_older_than_input_files,
+          relName(state, configFileName)
+        );
+      case 11 /* UpstreamOutOfDate */:
+        return reportStatus(
+          state,
+          Diagnostics.Project_0_is_out_of_date_because_its_dependency_1_is_out_of_date,
+          relName(state, configFileName),
+          relName(state, status.upstreamProjectName)
+        );
+      case 12 /* UpstreamBlocked */:
+        return reportStatus(
+          state,
+          status.upstreamProjectBlocked ? Diagnostics.Project_0_can_t_be_built_because_its_dependency_1_was_not_built : Diagnostics.Project_0_can_t_be_built_because_its_dependency_1_has_errors,
+          relName(state, configFileName),
+          relName(state, status.upstreamProjectName)
+        );
+      case 0 /* Unbuildable */:
+        return reportStatus(
+          state,
+          Diagnostics.Failed_to_parse_file_0_Colon_1,
+          relName(state, configFileName),
+          status.reason
+        );
+      case 14 /* TsVersionOutputOfDate */:
+        return reportStatus(
+          state,
+          Diagnostics.Project_0_is_out_of_date_because_output_for_it_was_generated_with_version_1_that_differs_with_current_version_2,
+          relName(state, configFileName),
+          status.version,
+          version
+        );
+      case 17 /* ForceBuild */:
+        return reportStatus(
+          state,
+          Diagnostics.Project_0_is_being_forcibly_rebuilt,
+          relName(state, configFileName)
+        );
+      case 16 /* ContainerOnly */:
+      case 13 /* ComputingUpstream */:
+        break;
+      default:
+        assertType(status);
+    }
   }
-  function createSolutionBuilderState(watch, hostOrHostWithWatch, rootNames, options, baseWatchOptions) {
-    const host = hostOrHostWithWatch;
-    const hostWithWatch = hostOrHostWithWatch;
-    const baseCompilerOptions = getCompilerOptionsOfBuildOptions(options);
-    const compilerHost = createCompilerHostFromProgramHost(host, () => state.projectCompilerOptions);
-    setGetSourceFileAsHashVersioned(compilerHost);
-    compilerHost.getParsedCommandLine = (fileName) => parseConfigFile(state, fileName, toResolvedConfigFilePath(state, fileName));
-    compilerHost.resolveModuleNameLiterals = maybeBind(host, host.resolveModuleNameLiterals);
-    compilerHost.resolveTypeReferenceDirectiveReferences = maybeBind(host, host.resolveTypeReferenceDirectiveReferences);
-    compilerHost.resolveLibrary = maybeBind(host, host.resolveLibrary);
-    compilerHost.resolveModuleNames = maybeBind(host, host.resolveModuleNames);
-    compilerHost.resolveTypeReferenceDirectives = maybeBind(host, host.resolveTypeReferenceDirectives);
-    compilerHost.getModuleResolutionCache = maybeBind(host, host.getModuleResolutionCache);
-    let moduleResolutionCache, typeReferenceDirectiveResolutionCache;
-    if (!compilerHost.resolveModuleNameLiterals && !compilerHost.resolveModuleNames) {
-      moduleResolutionCache = createModuleResolutionCache(compilerHost.getCurrentDirectory(), compilerHost.getCanonicalFileName);
-      compilerHost.resolveModuleNameLiterals = (moduleNames, containingFile, redirectedReference, options2, containingSourceFile) => loadWithModeAwareCache(
-        moduleNames,
-        containingFile,
-        redirectedReference,
-        options2,
-        containingSourceFile,
-        host,
-        moduleResolutionCache,
-        createModuleResolutionLoader
-      );
-      compilerHost.getModuleResolutionCache = () => moduleResolutionCache;
+  function verboseReportProjectStatus(state, configFileName, status) {
+    if (state.options.verbose) {
+      reportUpToDateStatus(state, configFileName, status);
     }
-    if (!compilerHost.resolveTypeReferenceDirectiveReferences && !compilerHost.resolveTypeReferenceDirectives) {
-      typeReferenceDirectiveResolutionCache = createTypeReferenceDirectiveResolutionCache(
-        compilerHost.getCurrentDirectory(),
-        compilerHost.getCanonicalFileName,
-        /*options*/
-        void 0,
-        moduleResolutionCache == null ? void 0 : moduleResolutionCache.getPackageJsonInfoCache()
-      );
-      compilerHost.resolveTypeReferenceDirectiveReferences = (typeDirectiveNames, containingFile, redirectedReference, options2, containingSourceFile) => loadWithModeAwareCache(
-        typeDirectiveNames,
-        containingFile,
-        redirectedReference,
-        options2,
-        containingSourceFile,
-        host,
-        typeReferenceDirectiveResolutionCache,
-        createTypeReferenceResolutionLoader
-      );
+  }
+  var minimumDate, maximumDate, InvalidatedProjectKind;
+  var init_tsbuildPublic = __esm({
+    "src/compiler/tsbuildPublic.ts"() {
+      "use strict";
+      init_ts2();
+      init_ts_performance();
+      minimumDate = /* @__PURE__ */ new Date(-864e13);
+      maximumDate = /* @__PURE__ */ new Date(864e13);
+      InvalidatedProjectKind = /* @__PURE__ */ ((InvalidatedProjectKind2) => {
+        InvalidatedProjectKind2[InvalidatedProjectKind2["Build"] = 0] = "Build";
+        InvalidatedProjectKind2[InvalidatedProjectKind2["UpdateBundle"] = 1] = "UpdateBundle";
+        InvalidatedProjectKind2[InvalidatedProjectKind2["UpdateOutputFileStamps"] = 2] = "UpdateOutputFileStamps";
+        return InvalidatedProjectKind2;
+      })(InvalidatedProjectKind || {});
     }
-    let libraryResolutionCache;
-    if (!compilerHost.resolveLibrary) {
-      libraryResolutionCache = createModuleResolutionCache(
-        compilerHost.getCurrentDirectory(),
-        compilerHost.getCanonicalFileName,
-        /*options*/
-        void 0,
-        moduleResolutionCache == null ? void 0 : moduleResolutionCache.getPackageJsonInfoCache()
-      );
-      compilerHost.resolveLibrary = (libraryName, resolveFrom, options2) => resolveLibrary(
-        libraryName,
-        resolveFrom,
-        options2,
-        host,
-        libraryResolutionCache
-      );
+  });
+
+  // src/compiler/_namespaces/ts.ts
+  var init_ts2 = __esm({
+    "src/compiler/_namespaces/ts.ts"() {
+      "use strict";
+      init_corePublic();
+      init_core();
+      init_debug();
+      init_semver();
+      init_performanceCore();
+      init_perfLogger();
+      init_tracing();
+      init_types();
+      init_sys();
+      init_path();
+      init_diagnosticInformationMap_generated();
+      init_scanner();
+      init_utilitiesPublic();
+      init_utilities();
+      init_baseNodeFactory();
+      init_parenthesizerRules();
+      init_nodeConverters();
+      init_nodeFactory();
+      init_emitNode();
+      init_emitHelpers();
+      init_nodeTests();
+      init_utilities2();
+      init_utilitiesPublic2();
+      init_parser();
+      init_commandLineParser();
+      init_moduleNameResolver();
+      init_binder();
+      init_symbolWalker();
+      init_checker();
+      init_visitorPublic();
+      init_sourcemap();
+      init_utilities3();
+      init_destructuring();
+      init_classThis();
+      init_namedEvaluation();
+      init_taggedTemplate();
+      init_ts();
+      init_classFields();
+      init_typeSerializer();
+      init_legacyDecorators();
+      init_esDecorators();
+      init_es2017();
+      init_es2018();
+      init_es2019();
+      init_es2020();
+      init_es2021();
+      init_esnext();
+      init_jsx();
+      init_es2016();
+      init_es2015();
+      init_es5();
+      init_generators();
+      init_module();
+      init_system();
+      init_esnextAnd2015();
+      init_node();
+      init_diagnostics();
+      init_declarations();
+      init_transformer();
+      init_emitter();
+      init_watchUtilities();
+      init_program();
+      init_builderStatePublic();
+      init_builderState();
+      init_builder();
+      init_builderPublic();
+      init_resolutionCache();
+      init_watch();
+      init_watchPublic();
+      init_tsbuild();
+      init_tsbuildPublic();
+      init_ts_moduleSpecifiers();
+      init_ts_performance();
     }
-    compilerHost.getBuildInfo = (fileName, configFilePath) => getBuildInfo3(
-      state,
-      fileName,
-      toResolvedConfigFilePath(state, configFilePath),
-      /*modifiedTime*/
-      void 0
-    );
-    const { watchFile: watchFile2, watchDirectory, writeLog } = createWatchFactory(hostWithWatch, options);
-    const state = {
-      host,
-      hostWithWatch,
-      parseConfigFileHost: parseConfigHostFromCompilerHostLike(host),
-      write: maybeBind(host, host.trace),
-      // State of solution
-      options,
-      baseCompilerOptions,
-      rootNames,
-      baseWatchOptions,
-      resolvedConfigFilePaths: /* @__PURE__ */ new Map(),
-      configFileCache: /* @__PURE__ */ new Map(),
-      projectStatus: /* @__PURE__ */ new Map(),
-      extendedConfigCache: /* @__PURE__ */ new Map(),
-      buildInfoCache: /* @__PURE__ */ new Map(),
-      outputTimeStamps: /* @__PURE__ */ new Map(),
-      builderPrograms: /* @__PURE__ */ new Map(),
-      diagnostics: /* @__PURE__ */ new Map(),
-      projectPendingBuild: /* @__PURE__ */ new Map(),
-      projectErrorsReported: /* @__PURE__ */ new Map(),
-      compilerHost,
-      moduleResolutionCache,
-      typeReferenceDirectiveResolutionCache,
-      libraryResolutionCache,
-      // Mutable state
-      buildOrder: void 0,
-      readFileWithCache: (f) => host.readFile(f),
-      projectCompilerOptions: baseCompilerOptions,
-      cache: void 0,
-      allProjectBuildPending: true,
-      needsSummary: true,
-      watchAllProjectsPending: watch,
-      // Watch state
-      watch,
-      allWatchedWildcardDirectories: /* @__PURE__ */ new Map(),
-      allWatchedInputFiles: /* @__PURE__ */ new Map(),
-      allWatchedConfigFiles: /* @__PURE__ */ new Map(),
-      allWatchedExtendedConfigFiles: /* @__PURE__ */ new Map(),
-      allWatchedPackageJsonFiles: /* @__PURE__ */ new Map(),
-      filesWatched: /* @__PURE__ */ new Map(),
-      lastCachedPackageJsonLookups: /* @__PURE__ */ new Map(),
-      timerToBuildInvalidatedProject: void 0,
-      reportFileChangeDetected: false,
-      watchFile: watchFile2,
-      watchDirectory,
-      writeLog
-    };
-    return state;
+  });
+
+  // src/jsTyping/shared.ts
+  function hasArgument(argumentName) {
+    return sys.args.includes(argumentName);
   }
-  function toPath2(state, fileName) {
-    return toPath(fileName, state.compilerHost.getCurrentDirectory(), state.compilerHost.getCanonicalFileName);
+  function findArgument(argumentName) {
+    const index = sys.args.indexOf(argumentName);
+    return index >= 0 && index < sys.args.length - 1 ? sys.args[index + 1] : void 0;
   }
-  function toResolvedConfigFilePath(state, fileName) {
-    const { resolvedConfigFilePaths } = state;
-    const path = resolvedConfigFilePaths.get(fileName);
-    if (path !== void 0)
-      return path;
-    const resolvedPath = toPath2(state, fileName);
-    resolvedConfigFilePaths.set(fileName, resolvedPath);
-    return resolvedPath;
+  function nowString() {
+    const d = /* @__PURE__ */ new Date();
+    return `${d.getHours().toString().padStart(2, "0")}:${d.getMinutes().toString().padStart(2, "0")}:${d.getSeconds().toString().padStart(2, "0")}.${d.getMilliseconds().toString().padStart(3, "0")}`;
   }
-  function isParsedCommandLine(entry) {
-    return !!entry.options;
+  function indent2(str) {
+    return indentStr + str.replace(/\n/g, indentStr);
   }
-  function getCachedParsedConfigFile(state, configFilePath) {
-    const value = state.configFileCache.get(configFilePath);
-    return value && isParsedCommandLine(value) ? value : void 0;
+  function stringifyIndented(json) {
+    return indent2(JSON.stringify(json, void 0, 2));
   }
-  function parseConfigFile(state, configFileName, configFilePath) {
-    const { configFileCache } = state;
-    const value = configFileCache.get(configFilePath);
-    if (value) {
-      return isParsedCommandLine(value) ? value : void 0;
+  var ActionSet, ActionInvalidate, ActionPackageInstalled, EventTypesRegistry, EventBeginInstallTypes, EventEndInstallTypes, EventInitializationFailed, ActionWatchTypingLocations, Arguments, indentStr;
+  var init_shared = __esm({
+    "src/jsTyping/shared.ts"() {
+      "use strict";
+      init_ts3();
+      ActionSet = "action::set";
+      ActionInvalidate = "action::invalidate";
+      ActionPackageInstalled = "action::packageInstalled";
+      EventTypesRegistry = "event::typesRegistry";
+      EventBeginInstallTypes = "event::beginInstallTypes";
+      EventEndInstallTypes = "event::endInstallTypes";
+      EventInitializationFailed = "event::initializationFailed";
+      ActionWatchTypingLocations = "action::watchTypingLocations";
+      ((Arguments2) => {
+        Arguments2.GlobalCacheLocation = "--globalTypingsCacheLocation";
+        Arguments2.LogFile = "--logFile";
+        Arguments2.EnableTelemetry = "--enableTelemetry";
+        Arguments2.TypingSafeListLocation = "--typingSafeListLocation";
+        Arguments2.TypesMapLocation = "--typesMapLocation";
+        Arguments2.NpmLocation = "--npmLocation";
+        Arguments2.ValidateDefaultNpmLocation = "--validateDefaultNpmLocation";
+      })(Arguments || (Arguments = {}));
+      indentStr = "\n    ";
     }
-    mark("SolutionBuilder::beforeConfigFileParsing");
-    let diagnostic;
-    const { parseConfigFileHost, baseCompilerOptions, baseWatchOptions, extendedConfigCache, host } = state;
-    let parsed;
-    if (host.getParsedCommandLine) {
-      parsed = host.getParsedCommandLine(configFileName);
-      if (!parsed)
-        diagnostic = createCompilerDiagnostic(Diagnostics.File_0_not_found, configFileName);
-    } else {
-      parseConfigFileHost.onUnRecoverableConfigFileDiagnostic = (d) => diagnostic = d;
-      parsed = getParsedCommandLineOfConfigFile(configFileName, baseCompilerOptions, parseConfigFileHost, extendedConfigCache, baseWatchOptions);
-      parseConfigFileHost.onUnRecoverableConfigFileDiagnostic = noop;
+  });
+
+  // src/jsTyping/types.ts
+  var init_types2 = __esm({
+    "src/jsTyping/types.ts"() {
+      "use strict";
     }
-    configFileCache.set(configFilePath, parsed || diagnostic);
-    mark("SolutionBuilder::afterConfigFileParsing");
-    measure("SolutionBuilder::Config file parsing", "SolutionBuilder::beforeConfigFileParsing", "SolutionBuilder::afterConfigFileParsing");
-    return parsed;
+  });
+
+  // src/jsTyping/_namespaces/ts.server.ts
+  var init_ts_server = __esm({
+    "src/jsTyping/_namespaces/ts.server.ts"() {
+      "use strict";
+      init_shared();
+      init_types2();
+    }
+  });
+
+  // src/jsTyping/jsTyping.ts
+  function isTypingUpToDate(cachedTyping, availableTypingVersions) {
+    const availableVersion = new Version(getProperty(availableTypingVersions, `ts${versionMajorMinor}`) || getProperty(availableTypingVersions, "latest"));
+    return availableVersion.compareTo(cachedTyping.version) <= 0;
   }
-  function resolveProjectName(state, name) {
-    return resolveConfigFileProjectName(resolvePath(state.compilerHost.getCurrentDirectory(), name));
+  function nonRelativeModuleNameForTypingCache(moduleName) {
+    return nodeCoreModules.has(moduleName) ? "node" : moduleName;
   }
-  function createBuildOrder(state, roots) {
-    const temporaryMarks = /* @__PURE__ */ new Map();
-    const permanentMarks = /* @__PURE__ */ new Map();
-    const circularityReportStack = [];
-    let buildOrder;
-    let circularDiagnostics;
-    for (const root of roots) {
-      visit(root);
+  function loadSafeList(host, safeListPath) {
+    const result = readConfigFile(safeListPath, (path) => host.readFile(path));
+    return new Map(Object.entries(result.config));
+  }
+  function loadTypesMap(host, typesMapPath) {
+    var _a;
+    const result = readConfigFile(typesMapPath, (path) => host.readFile(path));
+    if ((_a = result.config) == null ? void 0 : _a.simpleMap) {
+      return new Map(Object.entries(result.config.simpleMap));
     }
-    return circularDiagnostics ? { buildOrder: buildOrder || emptyArray, circularDiagnostics } : buildOrder || emptyArray;
-    function visit(configFileName, inCircularContext) {
-      const projPath = toResolvedConfigFilePath(state, configFileName);
-      if (permanentMarks.has(projPath))
-        return;
-      if (temporaryMarks.has(projPath)) {
-        if (!inCircularContext) {
-          (circularDiagnostics || (circularDiagnostics = [])).push(
-            createCompilerDiagnostic(
-              Diagnostics.Project_references_may_not_form_a_circular_graph_Cycle_detected_Colon_0,
-              circularityReportStack.join("\r\n")
-            )
-          );
-        }
+    return void 0;
+  }
+  function discoverTypings(host, log, fileNames, projectRootPath, safeList, packageNameToTypingLocation, typeAcquisition, unresolvedImports, typesRegistry, compilerOptions) {
+    if (!typeAcquisition || !typeAcquisition.enable) {
+      return { cachedTypingPaths: [], newTypingNames: [], filesToWatch: [] };
+    }
+    const inferredTypings = /* @__PURE__ */ new Map();
+    fileNames = mapDefined(fileNames, (fileName) => {
+      const path = normalizePath(fileName);
+      if (hasJSFileExtension(path)) {
+        return path;
+      }
+    });
+    const filesToWatch = [];
+    if (typeAcquisition.include)
+      addInferredTypings(typeAcquisition.include, "Explicitly included types");
+    const exclude = typeAcquisition.exclude || [];
+    if (!compilerOptions.types) {
+      const possibleSearchDirs = new Set(fileNames.map(getDirectoryPath));
+      possibleSearchDirs.add(projectRootPath);
+      possibleSearchDirs.forEach((searchDir) => {
+        getTypingNames(searchDir, "bower.json", "bower_components", filesToWatch);
+        getTypingNames(searchDir, "package.json", "node_modules", filesToWatch);
+      });
+    }
+    if (!typeAcquisition.disableFilenameBasedTypeAcquisition) {
+      getTypingNamesFromSourceFileNames(fileNames);
+    }
+    if (unresolvedImports) {
+      const module2 = deduplicate(
+        unresolvedImports.map(nonRelativeModuleNameForTypingCache),
+        equateStringsCaseSensitive,
+        compareStringsCaseSensitive
+      );
+      addInferredTypings(module2, "Inferred typings from unresolved imports");
+    }
+    for (const excludeTypingName of exclude) {
+      const didDelete = inferredTypings.delete(excludeTypingName);
+      if (didDelete && log)
+        log(`Typing for ${excludeTypingName} is in exclude list, will be ignored.`);
+    }
+    packageNameToTypingLocation.forEach((typing, name) => {
+      const registryEntry = typesRegistry.get(name);
+      if (inferredTypings.get(name) === false && registryEntry !== void 0 && isTypingUpToDate(typing, registryEntry)) {
+        inferredTypings.set(name, typing.typingLocation);
+      }
+    });
+    const newTypingNames = [];
+    const cachedTypingPaths = [];
+    inferredTypings.forEach((inferred, typing) => {
+      if (inferred) {
+        cachedTypingPaths.push(inferred);
+      } else {
+        newTypingNames.push(typing);
+      }
+    });
+    const result = { cachedTypingPaths, newTypingNames, filesToWatch };
+    if (log)
+      log(`Finished typings discovery:${stringifyIndented(result)}`);
+    return result;
+    function addInferredTyping(typingName) {
+      if (!inferredTypings.has(typingName)) {
+        inferredTypings.set(typingName, false);
+      }
+    }
+    function addInferredTypings(typingNames, message) {
+      if (log)
+        log(`${message}: ${JSON.stringify(typingNames)}`);
+      forEach(typingNames, addInferredTyping);
+    }
+    function getTypingNames(projectRootPath2, manifestName, modulesDirName, filesToWatch2) {
+      const manifestPath = combinePaths(projectRootPath2, manifestName);
+      let manifest;
+      let manifestTypingNames;
+      if (host.fileExists(manifestPath)) {
+        filesToWatch2.push(manifestPath);
+        manifest = readConfigFile(manifestPath, (path) => host.readFile(path)).config;
+        manifestTypingNames = flatMap([manifest.dependencies, manifest.devDependencies, manifest.optionalDependencies, manifest.peerDependencies], getOwnKeys);
+        addInferredTypings(manifestTypingNames, `Typing names in '${manifestPath}' dependencies`);
+      }
+      const packagesFolderPath = combinePaths(projectRootPath2, modulesDirName);
+      filesToWatch2.push(packagesFolderPath);
+      if (!host.directoryExists(packagesFolderPath)) {
         return;
       }
-      temporaryMarks.set(projPath, true);
-      circularityReportStack.push(configFileName);
-      const parsed = parseConfigFile(state, configFileName, projPath);
-      if (parsed && parsed.projectReferences) {
-        for (const ref of parsed.projectReferences) {
-          const resolvedRefPath = resolveProjectName(state, ref.path);
-          visit(resolvedRefPath, inCircularContext || ref.circular);
+      const packageNames = [];
+      const dependencyManifestNames = manifestTypingNames ? manifestTypingNames.map((typingName) => combinePaths(packagesFolderPath, typingName, manifestName)) : host.readDirectory(
+        packagesFolderPath,
+        [".json" /* Json */],
+        /*excludes*/
+        void 0,
+        /*includes*/
+        void 0,
+        /*depth*/
+        3
+      ).filter((manifestPath2) => {
+        if (getBaseFileName(manifestPath2) !== manifestName) {
+          return false;
+        }
+        const pathComponents2 = getPathComponents(normalizePath(manifestPath2));
+        const isScoped = pathComponents2[pathComponents2.length - 3][0] === "@";
+        return isScoped && toFileNameLowerCase(pathComponents2[pathComponents2.length - 4]) === modulesDirName || // `node_modules/@foo/bar`
+        !isScoped && toFileNameLowerCase(pathComponents2[pathComponents2.length - 3]) === modulesDirName;
+      });
+      if (log)
+        log(`Searching for typing names in ${packagesFolderPath}; all files: ${JSON.stringify(dependencyManifestNames)}`);
+      for (const manifestPath2 of dependencyManifestNames) {
+        const normalizedFileName = normalizePath(manifestPath2);
+        const result2 = readConfigFile(normalizedFileName, (path) => host.readFile(path));
+        const manifest2 = result2.config;
+        if (!manifest2.name) {
+          continue;
+        }
+        const ownTypes = manifest2.types || manifest2.typings;
+        if (ownTypes) {
+          const absolutePath = getNormalizedAbsolutePath(ownTypes, getDirectoryPath(normalizedFileName));
+          if (host.fileExists(absolutePath)) {
+            if (log)
+              log(`    Package '${manifest2.name}' provides its own types.`);
+            inferredTypings.set(manifest2.name, absolutePath);
+          } else {
+            if (log)
+              log(`    Package '${manifest2.name}' provides its own types but they are missing.`);
+          }
+        } else {
+          packageNames.push(manifest2.name);
         }
       }
-      circularityReportStack.pop();
-      permanentMarks.set(projPath, true);
-      (buildOrder || (buildOrder = [])).push(configFileName);
+      addInferredTypings(packageNames, "    Found package names");
     }
-  }
-  function getBuildOrder(state) {
-    return state.buildOrder || createStateBuildOrder(state);
-  }
-  function createStateBuildOrder(state) {
-    const buildOrder = createBuildOrder(state, state.rootNames.map((f) => resolveProjectName(state, f)));
-    state.resolvedConfigFilePaths.clear();
-    const currentProjects = new Map(
-      getBuildOrderFromAnyBuildOrder(buildOrder).map(
-        (resolved) => [toResolvedConfigFilePath(state, resolved), true]
-      )
-    );
-    const noopOnDelete = { onDeleteValue: noop };
-    mutateMapSkippingNewValues(state.configFileCache, currentProjects, noopOnDelete);
-    mutateMapSkippingNewValues(state.projectStatus, currentProjects, noopOnDelete);
-    mutateMapSkippingNewValues(state.builderPrograms, currentProjects, noopOnDelete);
-    mutateMapSkippingNewValues(state.diagnostics, currentProjects, noopOnDelete);
-    mutateMapSkippingNewValues(state.projectPendingBuild, currentProjects, noopOnDelete);
-    mutateMapSkippingNewValues(state.projectErrorsReported, currentProjects, noopOnDelete);
-    mutateMapSkippingNewValues(state.buildInfoCache, currentProjects, noopOnDelete);
-    mutateMapSkippingNewValues(state.outputTimeStamps, currentProjects, noopOnDelete);
-    if (state.watch) {
-      mutateMapSkippingNewValues(
-        state.allWatchedConfigFiles,
-        currentProjects,
-        { onDeleteValue: closeFileWatcher }
-      );
-      state.allWatchedExtendedConfigFiles.forEach((watcher) => {
-        watcher.projects.forEach((project) => {
-          if (!currentProjects.has(project)) {
-            watcher.projects.delete(project);
-          }
-        });
-        watcher.close();
+    function getTypingNamesFromSourceFileNames(fileNames2) {
+      const fromFileNames = mapDefined(fileNames2, (j) => {
+        if (!hasJSFileExtension(j))
+          return void 0;
+        const inferredTypingName = removeFileExtension(toFileNameLowerCase(getBaseFileName(j)));
+        const cleanedTypingName = removeMinAndVersionNumbers(inferredTypingName);
+        return safeList.get(cleanedTypingName);
       });
-      mutateMapSkippingNewValues(
-        state.allWatchedWildcardDirectories,
-        currentProjects,
-        { onDeleteValue: (existingMap) => existingMap.forEach(closeFileWatcherOf) }
-      );
-      mutateMapSkippingNewValues(
-        state.allWatchedInputFiles,
-        currentProjects,
-        { onDeleteValue: (existingMap) => existingMap.forEach(closeFileWatcher) }
-      );
-      mutateMapSkippingNewValues(
-        state.allWatchedPackageJsonFiles,
-        currentProjects,
-        { onDeleteValue: (existingMap) => existingMap.forEach(closeFileWatcher) }
-      );
-    }
-    return state.buildOrder = buildOrder;
-  }
-  function getBuildOrderFor(state, project, onlyReferences) {
-    const resolvedProject = project && resolveProjectName(state, project);
-    const buildOrderFromState = getBuildOrder(state);
-    if (isCircularBuildOrder(buildOrderFromState))
-      return buildOrderFromState;
-    if (resolvedProject) {
-      const projectPath = toResolvedConfigFilePath(state, resolvedProject);
-      const projectIndex = findIndex(
-        buildOrderFromState,
-        (configFileName) => toResolvedConfigFilePath(state, configFileName) === projectPath
-      );
-      if (projectIndex === -1)
-        return void 0;
+      if (fromFileNames.length) {
+        addInferredTypings(fromFileNames, "Inferred typings from file names");
+      }
+      const hasJsxFile = some(fileNames2, (f) => fileExtensionIs(f, ".jsx" /* Jsx */));
+      if (hasJsxFile) {
+        if (log)
+          log(`Inferred 'react' typings due to presence of '.jsx' extension`);
+        addInferredTyping("react");
+      }
     }
-    const buildOrder = resolvedProject ? createBuildOrder(state, [resolvedProject]) : buildOrderFromState;
-    Debug.assert(!isCircularBuildOrder(buildOrder));
-    Debug.assert(!onlyReferences || resolvedProject !== void 0);
-    Debug.assert(!onlyReferences || buildOrder[buildOrder.length - 1] === resolvedProject);
-    return onlyReferences ? buildOrder.slice(0, buildOrder.length - 1) : buildOrder;
   }
-  function enableCache(state) {
-    if (state.cache) {
-      disableCache(state);
-    }
-    const { compilerHost, host } = state;
-    const originalReadFileWithCache = state.readFileWithCache;
-    const originalGetSourceFile = compilerHost.getSourceFile;
-    const {
-      originalReadFile,
-      originalFileExists,
-      originalDirectoryExists,
-      originalCreateDirectory,
-      originalWriteFile,
-      getSourceFileWithCache,
-      readFileWithCache
-    } = changeCompilerHostLikeToUseCache(
-      host,
-      (fileName) => toPath2(state, fileName),
-      (...args) => originalGetSourceFile.call(compilerHost, ...args)
+  function validatePackageName(packageName) {
+    return validatePackageNameWorker(
+      packageName,
+      /*supportScopedPackage*/
+      true
     );
-    state.readFileWithCache = readFileWithCache;
-    compilerHost.getSourceFile = getSourceFileWithCache;
-    state.cache = {
-      originalReadFile,
-      originalFileExists,
-      originalDirectoryExists,
-      originalCreateDirectory,
-      originalWriteFile,
-      originalReadFileWithCache,
-      originalGetSourceFile
-    };
-  }
-  function disableCache(state) {
-    if (!state.cache)
-      return;
-    const { cache, host, compilerHost, extendedConfigCache, moduleResolutionCache, typeReferenceDirectiveResolutionCache, libraryResolutionCache } = state;
-    host.readFile = cache.originalReadFile;
-    host.fileExists = cache.originalFileExists;
-    host.directoryExists = cache.originalDirectoryExists;
-    host.createDirectory = cache.originalCreateDirectory;
-    host.writeFile = cache.originalWriteFile;
-    compilerHost.getSourceFile = cache.originalGetSourceFile;
-    state.readFileWithCache = cache.originalReadFileWithCache;
-    extendedConfigCache.clear();
-    moduleResolutionCache == null ? void 0 : moduleResolutionCache.clear();
-    typeReferenceDirectiveResolutionCache == null ? void 0 : typeReferenceDirectiveResolutionCache.clear();
-    libraryResolutionCache == null ? void 0 : libraryResolutionCache.clear();
-    state.cache = void 0;
-  }
-  function clearProjectStatus(state, resolved) {
-    state.projectStatus.delete(resolved);
-    state.diagnostics.delete(resolved);
   }
-  function addProjToQueue({ projectPendingBuild }, proj, reloadLevel) {
-    const value = projectPendingBuild.get(proj);
-    if (value === void 0) {
-      projectPendingBuild.set(proj, reloadLevel);
-    } else if (value < reloadLevel) {
-      projectPendingBuild.set(proj, reloadLevel);
+  function validatePackageNameWorker(packageName, supportScopedPackage) {
+    if (!packageName) {
+      return 1 /* EmptyName */;
+    }
+    if (packageName.length > maxPackageNameLength) {
+      return 2 /* NameTooLong */;
+    }
+    if (packageName.charCodeAt(0) === 46 /* dot */) {
+      return 3 /* NameStartsWithDot */;
+    }
+    if (packageName.charCodeAt(0) === 95 /* _ */) {
+      return 4 /* NameStartsWithUnderscore */;
+    }
+    if (supportScopedPackage) {
+      const matches = /^@([^/]+)\/([^/]+)$/.exec(packageName);
+      if (matches) {
+        const scopeResult = validatePackageNameWorker(
+          matches[1],
+          /*supportScopedPackage*/
+          false
+        );
+        if (scopeResult !== 0 /* Ok */) {
+          return { name: matches[1], isScopeName: true, result: scopeResult };
+        }
+        const packageResult = validatePackageNameWorker(
+          matches[2],
+          /*supportScopedPackage*/
+          false
+        );
+        if (packageResult !== 0 /* Ok */) {
+          return { name: matches[2], isScopeName: false, result: packageResult };
+        }
+        return 0 /* Ok */;
+      }
+    }
+    if (encodeURIComponent(packageName) !== packageName) {
+      return 5 /* NameContainsNonURISafeCharacters */;
     }
+    return 0 /* Ok */;
   }
-  function setupInitialBuild(state, cancellationToken) {
-    if (!state.allProjectBuildPending)
-      return;
-    state.allProjectBuildPending = false;
-    if (state.options.watch)
-      reportWatchStatus(state, Diagnostics.Starting_compilation_in_watch_mode);
-    enableCache(state);
-    const buildOrder = getBuildOrderFromAnyBuildOrder(getBuildOrder(state));
-    buildOrder.forEach(
-      (configFileName) => state.projectPendingBuild.set(
-        toResolvedConfigFilePath(state, configFileName),
-        0 /* None */
-      )
+  function renderPackageNameValidationFailure(result, typing) {
+    return typeof result === "object" ? renderPackageNameValidationFailureWorker(typing, result.result, result.name, result.isScopeName) : renderPackageNameValidationFailureWorker(
+      typing,
+      result,
+      typing,
+      /*isScopeName*/
+      false
     );
-    if (cancellationToken) {
-      cancellationToken.throwIfCancellationRequested();
-    }
   }
-  function doneInvalidatedProject(state, projectPath) {
-    state.projectPendingBuild.delete(projectPath);
-    return state.diagnostics.has(projectPath) ? 1 /* DiagnosticsPresent_OutputsSkipped */ : 0 /* Success */;
+  function renderPackageNameValidationFailureWorker(typing, result, name, isScopeName) {
+    const kind = isScopeName ? "Scope" : "Package";
+    switch (result) {
+      case 1 /* EmptyName */:
+        return `'${typing}':: ${kind} name '${name}' cannot be empty`;
+      case 2 /* NameTooLong */:
+        return `'${typing}':: ${kind} name '${name}' should be less than ${maxPackageNameLength} characters`;
+      case 3 /* NameStartsWithDot */:
+        return `'${typing}':: ${kind} name '${name}' cannot start with '.'`;
+      case 4 /* NameStartsWithUnderscore */:
+        return `'${typing}':: ${kind} name '${name}' cannot start with '_'`;
+      case 5 /* NameContainsNonURISafeCharacters */:
+        return `'${typing}':: ${kind} name '${name}' contains non URI safe characters`;
+      case 0 /* Ok */:
+        return Debug.fail();
+      default:
+        Debug.assertNever(result);
+    }
   }
-  function createUpdateOutputFileStampsProject(state, project, projectPath, config, buildOrder) {
-    let updateOutputFileStampsPending = true;
+  var unprefixedNodeCoreModuleList, prefixedNodeCoreModuleList, nodeCoreModuleList, nodeCoreModules, NameValidationResult, maxPackageNameLength;
+  var init_jsTyping = __esm({
+    "src/jsTyping/jsTyping.ts"() {
+      "use strict";
+      init_ts3();
+      init_ts_server();
+      unprefixedNodeCoreModuleList = [
+        "assert",
+        "assert/strict",
+        "async_hooks",
+        "buffer",
+        "child_process",
+        "cluster",
+        "console",
+        "constants",
+        "crypto",
+        "dgram",
+        "diagnostics_channel",
+        "dns",
+        "dns/promises",
+        "domain",
+        "events",
+        "fs",
+        "fs/promises",
+        "http",
+        "https",
+        "http2",
+        "inspector",
+        "module",
+        "net",
+        "os",
+        "path",
+        "perf_hooks",
+        "process",
+        "punycode",
+        "querystring",
+        "readline",
+        "repl",
+        "stream",
+        "stream/promises",
+        "string_decoder",
+        "timers",
+        "timers/promises",
+        "tls",
+        "trace_events",
+        "tty",
+        "url",
+        "util",
+        "util/types",
+        "v8",
+        "vm",
+        "wasi",
+        "worker_threads",
+        "zlib"
+      ];
+      prefixedNodeCoreModuleList = unprefixedNodeCoreModuleList.map((name) => `node:${name}`);
+      nodeCoreModuleList = [...unprefixedNodeCoreModuleList, ...prefixedNodeCoreModuleList];
+      nodeCoreModules = new Set(nodeCoreModuleList);
+      NameValidationResult = /* @__PURE__ */ ((NameValidationResult2) => {
+        NameValidationResult2[NameValidationResult2["Ok"] = 0] = "Ok";
+        NameValidationResult2[NameValidationResult2["EmptyName"] = 1] = "EmptyName";
+        NameValidationResult2[NameValidationResult2["NameTooLong"] = 2] = "NameTooLong";
+        NameValidationResult2[NameValidationResult2["NameStartsWithDot"] = 3] = "NameStartsWithDot";
+        NameValidationResult2[NameValidationResult2["NameStartsWithUnderscore"] = 4] = "NameStartsWithUnderscore";
+        NameValidationResult2[NameValidationResult2["NameContainsNonURISafeCharacters"] = 5] = "NameContainsNonURISafeCharacters";
+        return NameValidationResult2;
+      })(NameValidationResult || {});
+      maxPackageNameLength = 214;
+    }
+  });
+
+  // src/jsTyping/_namespaces/ts.JsTyping.ts
+  var ts_JsTyping_exports = {};
+  __export(ts_JsTyping_exports, {
+    NameValidationResult: () => NameValidationResult,
+    discoverTypings: () => discoverTypings,
+    isTypingUpToDate: () => isTypingUpToDate,
+    loadSafeList: () => loadSafeList,
+    loadTypesMap: () => loadTypesMap,
+    nodeCoreModuleList: () => nodeCoreModuleList,
+    nodeCoreModules: () => nodeCoreModules,
+    nonRelativeModuleNameForTypingCache: () => nonRelativeModuleNameForTypingCache,
+    prefixedNodeCoreModuleList: () => prefixedNodeCoreModuleList,
+    renderPackageNameValidationFailure: () => renderPackageNameValidationFailure,
+    validatePackageName: () => validatePackageName
+  });
+  var init_ts_JsTyping = __esm({
+    "src/jsTyping/_namespaces/ts.JsTyping.ts"() {
+      "use strict";
+      init_jsTyping();
+    }
+  });
+
+  // src/jsTyping/_namespaces/ts.ts
+  var init_ts3 = __esm({
+    "src/jsTyping/_namespaces/ts.ts"() {
+      "use strict";
+      init_ts2();
+      init_ts_JsTyping();
+      init_ts_server();
+    }
+  });
+
+  // src/services/types.ts
+  function getDefaultFormatCodeSettings(newLineCharacter) {
     return {
-      kind: 2 /* UpdateOutputFileStamps */,
-      project,
-      projectPath,
-      buildOrder,
-      getCompilerOptions: () => config.options,
-      getCurrentDirectory: () => state.compilerHost.getCurrentDirectory(),
-      updateOutputFileStatmps: () => {
-        updateOutputTimestamps(state, config, projectPath);
-        updateOutputFileStampsPending = false;
-      },
-      done: () => {
-        if (updateOutputFileStampsPending) {
-          updateOutputTimestamps(state, config, projectPath);
-        }
-        mark("SolutionBuilder::Timestamps only updates");
-        return doneInvalidatedProject(state, projectPath);
-      }
+      indentSize: 4,
+      tabSize: 4,
+      newLineCharacter: newLineCharacter || "\n",
+      convertTabsToSpaces: true,
+      indentStyle: 2 /* Smart */,
+      insertSpaceAfterConstructor: false,
+      insertSpaceAfterCommaDelimiter: true,
+      insertSpaceAfterSemicolonInForStatements: true,
+      insertSpaceBeforeAndAfterBinaryOperators: true,
+      insertSpaceAfterKeywordsInControlFlowStatements: true,
+      insertSpaceAfterFunctionKeywordForAnonymousFunctions: false,
+      insertSpaceAfterOpeningAndBeforeClosingNonemptyParenthesis: false,
+      insertSpaceAfterOpeningAndBeforeClosingNonemptyBrackets: false,
+      insertSpaceAfterOpeningAndBeforeClosingNonemptyBraces: true,
+      insertSpaceAfterOpeningAndBeforeClosingTemplateStringBraces: false,
+      insertSpaceAfterOpeningAndBeforeClosingJsxExpressionBraces: false,
+      insertSpaceBeforeFunctionParenthesis: false,
+      placeOpenBraceOnNewLineForFunctions: false,
+      placeOpenBraceOnNewLineForControlBlocks: false,
+      semicolons: "ignore" /* Ignore */,
+      trimTrailingWhitespace: true,
+      indentSwitchCase: true
     };
   }
-  function createBuildOrUpdateInvalidedProject(kind, state, project, projectPath, projectIndex, config, buildOrder) {
-    let step = kind === 0 /* Build */ ? 0 /* CreateProgram */ : 4 /* EmitBundle */;
-    let program;
-    let buildResult;
-    let invalidatedProjectOfBundle;
-    return kind === 0 /* Build */ ? {
-      kind,
-      project,
-      projectPath,
-      buildOrder,
-      getCompilerOptions: () => config.options,
-      getCurrentDirectory: () => state.compilerHost.getCurrentDirectory(),
-      getBuilderProgram: () => withProgramOrUndefined(identity),
-      getProgram: () => withProgramOrUndefined(
-        (program2) => program2.getProgramOrUndefined()
-      ),
-      getSourceFile: (fileName) => withProgramOrUndefined(
-        (program2) => program2.getSourceFile(fileName)
-      ),
-      getSourceFiles: () => withProgramOrEmptyArray(
-        (program2) => program2.getSourceFiles()
-      ),
-      getOptionsDiagnostics: (cancellationToken) => withProgramOrEmptyArray(
-        (program2) => program2.getOptionsDiagnostics(cancellationToken)
-      ),
-      getGlobalDiagnostics: (cancellationToken) => withProgramOrEmptyArray(
-        (program2) => program2.getGlobalDiagnostics(cancellationToken)
-      ),
-      getConfigFileParsingDiagnostics: () => withProgramOrEmptyArray(
-        (program2) => program2.getConfigFileParsingDiagnostics()
-      ),
-      getSyntacticDiagnostics: (sourceFile, cancellationToken) => withProgramOrEmptyArray(
-        (program2) => program2.getSyntacticDiagnostics(sourceFile, cancellationToken)
-      ),
-      getAllDependencies: (sourceFile) => withProgramOrEmptyArray(
-        (program2) => program2.getAllDependencies(sourceFile)
-      ),
-      getSemanticDiagnostics: (sourceFile, cancellationToken) => withProgramOrEmptyArray(
-        (program2) => program2.getSemanticDiagnostics(sourceFile, cancellationToken)
-      ),
-      getSemanticDiagnosticsOfNextAffectedFile: (cancellationToken, ignoreSourceFile) => withProgramOrUndefined(
-        (program2) => program2.getSemanticDiagnosticsOfNextAffectedFile && program2.getSemanticDiagnosticsOfNextAffectedFile(cancellationToken, ignoreSourceFile)
-      ),
-      emit: (targetSourceFile, writeFile2, cancellationToken, emitOnlyDtsFiles, customTransformers) => {
-        if (targetSourceFile || emitOnlyDtsFiles) {
-          return withProgramOrUndefined(
-            (program2) => {
-              var _a, _b;
-              return program2.emit(targetSourceFile, writeFile2, cancellationToken, emitOnlyDtsFiles, customTransformers || ((_b = (_a = state.host).getCustomTransformers) == null ? void 0 : _b.call(_a, project)));
-            }
-          );
+  var ScriptSnapshot, PackageJsonDependencyGroup, PackageJsonAutoImportPreference, LanguageServiceMode, emptyOptions, SemanticClassificationFormat, OrganizeImportsMode, CompletionTriggerKind, InlayHintKind, HighlightSpanKind, IndentStyle, SemicolonPreference, testFormatSettings, SymbolDisplayPartKind, CompletionInfoFlags, OutliningSpanKind, OutputFileType, EndOfLineState, TokenClass, ScriptElementKind, ScriptElementKindModifier, ClassificationTypeNames, ClassificationType;
+  var init_types3 = __esm({
+    "src/services/types.ts"() {
+      "use strict";
+      ((ScriptSnapshot2) => {
+        class StringScriptSnapshot {
+          constructor(text) {
+            this.text = text;
+          }
+          getText(start, end) {
+            return start === 0 && end === this.text.length ? this.text : this.text.substring(start, end);
+          }
+          getLength() {
+            return this.text.length;
+          }
+          getChangeRange() {
+            return void 0;
+          }
         }
-        executeSteps(2 /* SemanticDiagnostics */, cancellationToken);
-        if (step === 5 /* EmitBuildInfo */) {
-          return emitBuildInfo(writeFile2, cancellationToken);
+        function fromString(text) {
+          return new StringScriptSnapshot(text);
         }
-        if (step !== 3 /* Emit */)
-          return void 0;
-        return emit(writeFile2, cancellationToken, customTransformers);
-      },
-      done
-    } : {
-      kind,
-      project,
-      projectPath,
-      buildOrder,
-      getCompilerOptions: () => config.options,
-      getCurrentDirectory: () => state.compilerHost.getCurrentDirectory(),
-      emit: (writeFile2, customTransformers) => {
-        if (step !== 4 /* EmitBundle */)
-          return invalidatedProjectOfBundle;
-        return emitBundle(writeFile2, customTransformers);
-      },
-      done
-    };
-    function done(cancellationToken, writeFile2, customTransformers) {
-      executeSteps(8 /* Done */, cancellationToken, writeFile2, customTransformers);
-      if (kind === 0 /* Build */)
-        mark("SolutionBuilder::Projects built");
-      else
-        mark("SolutionBuilder::Bundles updated");
-      return doneInvalidatedProject(state, projectPath);
-    }
-    function withProgramOrUndefined(action) {
-      executeSteps(0 /* CreateProgram */);
-      return program && action(program);
-    }
-    function withProgramOrEmptyArray(action) {
-      return withProgramOrUndefined(action) || emptyArray;
-    }
-    function createProgram2() {
-      var _a, _b;
-      Debug.assert(program === void 0);
-      if (state.options.dry) {
-        reportStatus(state, Diagnostics.A_non_dry_build_would_build_project_0, project);
-        buildResult = 1 /* Success */;
-        step = 7 /* QueueReferencingProjects */;
-        return;
-      }
-      if (state.options.verbose)
-        reportStatus(state, Diagnostics.Building_project_0, project);
-      if (config.fileNames.length === 0) {
-        reportAndStoreErrors(state, projectPath, getConfigFileParsingDiagnostics(config));
-        buildResult = 0 /* None */;
-        step = 7 /* QueueReferencingProjects */;
-        return;
-      }
-      const { host, compilerHost } = state;
-      state.projectCompilerOptions = config.options;
-      (_a = state.moduleResolutionCache) == null ? void 0 : _a.update(config.options);
-      (_b = state.typeReferenceDirectiveResolutionCache) == null ? void 0 : _b.update(config.options);
-      program = host.createProgram(
-        config.fileNames,
-        config.options,
-        compilerHost,
-        getOldProgram(state, projectPath, config),
-        getConfigFileParsingDiagnostics(config),
-        config.projectReferences
-      );
-      if (state.watch) {
-        state.lastCachedPackageJsonLookups.set(projectPath, state.moduleResolutionCache && map(
-          state.moduleResolutionCache.getPackageJsonInfoCache().entries(),
-          ([path, data]) => [state.host.realpath && data ? toPath2(state, state.host.realpath(path)) : path, data]
-        ));
-        state.builderPrograms.set(projectPath, program);
-      }
-      step++;
+        ScriptSnapshot2.fromString = fromString;
+      })(ScriptSnapshot || (ScriptSnapshot = {}));
+      PackageJsonDependencyGroup = /* @__PURE__ */ ((PackageJsonDependencyGroup2) => {
+        PackageJsonDependencyGroup2[PackageJsonDependencyGroup2["Dependencies"] = 1] = "Dependencies";
+        PackageJsonDependencyGroup2[PackageJsonDependencyGroup2["DevDependencies"] = 2] = "DevDependencies";
+        PackageJsonDependencyGroup2[PackageJsonDependencyGroup2["PeerDependencies"] = 4] = "PeerDependencies";
+        PackageJsonDependencyGroup2[PackageJsonDependencyGroup2["OptionalDependencies"] = 8] = "OptionalDependencies";
+        PackageJsonDependencyGroup2[PackageJsonDependencyGroup2["All"] = 15] = "All";
+        return PackageJsonDependencyGroup2;
+      })(PackageJsonDependencyGroup || {});
+      PackageJsonAutoImportPreference = /* @__PURE__ */ ((PackageJsonAutoImportPreference2) => {
+        PackageJsonAutoImportPreference2[PackageJsonAutoImportPreference2["Off"] = 0] = "Off";
+        PackageJsonAutoImportPreference2[PackageJsonAutoImportPreference2["On"] = 1] = "On";
+        PackageJsonAutoImportPreference2[PackageJsonAutoImportPreference2["Auto"] = 2] = "Auto";
+        return PackageJsonAutoImportPreference2;
+      })(PackageJsonAutoImportPreference || {});
+      LanguageServiceMode = /* @__PURE__ */ ((LanguageServiceMode2) => {
+        LanguageServiceMode2[LanguageServiceMode2["Semantic"] = 0] = "Semantic";
+        LanguageServiceMode2[LanguageServiceMode2["PartialSemantic"] = 1] = "PartialSemantic";
+        LanguageServiceMode2[LanguageServiceMode2["Syntactic"] = 2] = "Syntactic";
+        return LanguageServiceMode2;
+      })(LanguageServiceMode || {});
+      emptyOptions = {};
+      SemanticClassificationFormat = /* @__PURE__ */ ((SemanticClassificationFormat2) => {
+        SemanticClassificationFormat2["Original"] = "original";
+        SemanticClassificationFormat2["TwentyTwenty"] = "2020";
+        return SemanticClassificationFormat2;
+      })(SemanticClassificationFormat || {});
+      OrganizeImportsMode = /* @__PURE__ */ ((OrganizeImportsMode3) => {
+        OrganizeImportsMode3["All"] = "All";
+        OrganizeImportsMode3["SortAndCombine"] = "SortAndCombine";
+        OrganizeImportsMode3["RemoveUnused"] = "RemoveUnused";
+        return OrganizeImportsMode3;
+      })(OrganizeImportsMode || {});
+      CompletionTriggerKind = /* @__PURE__ */ ((CompletionTriggerKind4) => {
+        CompletionTriggerKind4[CompletionTriggerKind4["Invoked"] = 1] = "Invoked";
+        CompletionTriggerKind4[CompletionTriggerKind4["TriggerCharacter"] = 2] = "TriggerCharacter";
+        CompletionTriggerKind4[CompletionTriggerKind4["TriggerForIncompleteCompletions"] = 3] = "TriggerForIncompleteCompletions";
+        return CompletionTriggerKind4;
+      })(CompletionTriggerKind || {});
+      InlayHintKind = /* @__PURE__ */ ((InlayHintKind2) => {
+        InlayHintKind2["Type"] = "Type";
+        InlayHintKind2["Parameter"] = "Parameter";
+        InlayHintKind2["Enum"] = "Enum";
+        return InlayHintKind2;
+      })(InlayHintKind || {});
+      HighlightSpanKind = /* @__PURE__ */ ((HighlightSpanKind2) => {
+        HighlightSpanKind2["none"] = "none";
+        HighlightSpanKind2["definition"] = "definition";
+        HighlightSpanKind2["reference"] = "reference";
+        HighlightSpanKind2["writtenReference"] = "writtenReference";
+        return HighlightSpanKind2;
+      })(HighlightSpanKind || {});
+      IndentStyle = /* @__PURE__ */ ((IndentStyle3) => {
+        IndentStyle3[IndentStyle3["None"] = 0] = "None";
+        IndentStyle3[IndentStyle3["Block"] = 1] = "Block";
+        IndentStyle3[IndentStyle3["Smart"] = 2] = "Smart";
+        return IndentStyle3;
+      })(IndentStyle || {});
+      SemicolonPreference = /* @__PURE__ */ ((SemicolonPreference3) => {
+        SemicolonPreference3["Ignore"] = "ignore";
+        SemicolonPreference3["Insert"] = "insert";
+        SemicolonPreference3["Remove"] = "remove";
+        return SemicolonPreference3;
+      })(SemicolonPreference || {});
+      testFormatSettings = getDefaultFormatCodeSettings("\n");
+      SymbolDisplayPartKind = /* @__PURE__ */ ((SymbolDisplayPartKind2) => {
+        SymbolDisplayPartKind2[SymbolDisplayPartKind2["aliasName"] = 0] = "aliasName";
+        SymbolDisplayPartKind2[SymbolDisplayPartKind2["className"] = 1] = "className";
+        SymbolDisplayPartKind2[SymbolDisplayPartKind2["enumName"] = 2] = "enumName";
+        SymbolDisplayPartKind2[SymbolDisplayPartKind2["fieldName"] = 3] = "fieldName";
+        SymbolDisplayPartKind2[SymbolDisplayPartKind2["interfaceName"] = 4] = "interfaceName";
+        SymbolDisplayPartKind2[SymbolDisplayPartKind2["keyword"] = 5] = "keyword";
+        SymbolDisplayPartKind2[SymbolDisplayPartKind2["lineBreak"] = 6] = "lineBreak";
+        SymbolDisplayPartKind2[SymbolDisplayPartKind2["numericLiteral"] = 7] = "numericLiteral";
+        SymbolDisplayPartKind2[SymbolDisplayPartKind2["stringLiteral"] = 8] = "stringLiteral";
+        SymbolDisplayPartKind2[SymbolDisplayPartKind2["localName"] = 9] = "localName";
+        SymbolDisplayPartKind2[SymbolDisplayPartKind2["methodName"] = 10] = "methodName";
+        SymbolDisplayPartKind2[SymbolDisplayPartKind2["moduleName"] = 11] = "moduleName";
+        SymbolDisplayPartKind2[SymbolDisplayPartKind2["operator"] = 12] = "operator";
+        SymbolDisplayPartKind2[SymbolDisplayPartKind2["parameterName"] = 13] = "parameterName";
+        SymbolDisplayPartKind2[SymbolDisplayPartKind2["propertyName"] = 14] = "propertyName";
+        SymbolDisplayPartKind2[SymbolDisplayPartKind2["punctuation"] = 15] = "punctuation";
+        SymbolDisplayPartKind2[SymbolDisplayPartKind2["space"] = 16] = "space";
+        SymbolDisplayPartKind2[SymbolDisplayPartKind2["text"] = 17] = "text";
+        SymbolDisplayPartKind2[SymbolDisplayPartKind2["typeParameterName"] = 18] = "typeParameterName";
+        SymbolDisplayPartKind2[SymbolDisplayPartKind2["enumMemberName"] = 19] = "enumMemberName";
+        SymbolDisplayPartKind2[SymbolDisplayPartKind2["functionName"] = 20] = "functionName";
+        SymbolDisplayPartKind2[SymbolDisplayPartKind2["regularExpressionLiteral"] = 21] = "regularExpressionLiteral";
+        SymbolDisplayPartKind2[SymbolDisplayPartKind2["link"] = 22] = "link";
+        SymbolDisplayPartKind2[SymbolDisplayPartKind2["linkName"] = 23] = "linkName";
+        SymbolDisplayPartKind2[SymbolDisplayPartKind2["linkText"] = 24] = "linkText";
+        return SymbolDisplayPartKind2;
+      })(SymbolDisplayPartKind || {});
+      CompletionInfoFlags = /* @__PURE__ */ ((CompletionInfoFlags2) => {
+        CompletionInfoFlags2[CompletionInfoFlags2["None"] = 0] = "None";
+        CompletionInfoFlags2[CompletionInfoFlags2["MayIncludeAutoImports"] = 1] = "MayIncludeAutoImports";
+        CompletionInfoFlags2[CompletionInfoFlags2["IsImportStatementCompletion"] = 2] = "IsImportStatementCompletion";
+        CompletionInfoFlags2[CompletionInfoFlags2["IsContinuation"] = 4] = "IsContinuation";
+        CompletionInfoFlags2[CompletionInfoFlags2["ResolvedModuleSpecifiers"] = 8] = "ResolvedModuleSpecifiers";
+        CompletionInfoFlags2[CompletionInfoFlags2["ResolvedModuleSpecifiersBeyondLimit"] = 16] = "ResolvedModuleSpecifiersBeyondLimit";
+        CompletionInfoFlags2[CompletionInfoFlags2["MayIncludeMethodSnippets"] = 32] = "MayIncludeMethodSnippets";
+        return CompletionInfoFlags2;
+      })(CompletionInfoFlags || {});
+      OutliningSpanKind = /* @__PURE__ */ ((OutliningSpanKind2) => {
+        OutliningSpanKind2["Comment"] = "comment";
+        OutliningSpanKind2["Region"] = "region";
+        OutliningSpanKind2["Code"] = "code";
+        OutliningSpanKind2["Imports"] = "imports";
+        return OutliningSpanKind2;
+      })(OutliningSpanKind || {});
+      OutputFileType = /* @__PURE__ */ ((OutputFileType2) => {
+        OutputFileType2[OutputFileType2["JavaScript"] = 0] = "JavaScript";
+        OutputFileType2[OutputFileType2["SourceMap"] = 1] = "SourceMap";
+        OutputFileType2[OutputFileType2["Declaration"] = 2] = "Declaration";
+        return OutputFileType2;
+      })(OutputFileType || {});
+      EndOfLineState = /* @__PURE__ */ ((EndOfLineState2) => {
+        EndOfLineState2[EndOfLineState2["None"] = 0] = "None";
+        EndOfLineState2[EndOfLineState2["InMultiLineCommentTrivia"] = 1] = "InMultiLineCommentTrivia";
+        EndOfLineState2[EndOfLineState2["InSingleQuoteStringLiteral"] = 2] = "InSingleQuoteStringLiteral";
+        EndOfLineState2[EndOfLineState2["InDoubleQuoteStringLiteral"] = 3] = "InDoubleQuoteStringLiteral";
+        EndOfLineState2[EndOfLineState2["InTemplateHeadOrNoSubstitutionTemplate"] = 4] = "InTemplateHeadOrNoSubstitutionTemplate";
+        EndOfLineState2[EndOfLineState2["InTemplateMiddleOrTail"] = 5] = "InTemplateMiddleOrTail";
+        EndOfLineState2[EndOfLineState2["InTemplateSubstitutionPosition"] = 6] = "InTemplateSubstitutionPosition";
+        return EndOfLineState2;
+      })(EndOfLineState || {});
+      TokenClass = /* @__PURE__ */ ((TokenClass2) => {
+        TokenClass2[TokenClass2["Punctuation"] = 0] = "Punctuation";
+        TokenClass2[TokenClass2["Keyword"] = 1] = "Keyword";
+        TokenClass2[TokenClass2["Operator"] = 2] = "Operator";
+        TokenClass2[TokenClass2["Comment"] = 3] = "Comment";
+        TokenClass2[TokenClass2["Whitespace"] = 4] = "Whitespace";
+        TokenClass2[TokenClass2["Identifier"] = 5] = "Identifier";
+        TokenClass2[TokenClass2["NumberLiteral"] = 6] = "NumberLiteral";
+        TokenClass2[TokenClass2["BigIntLiteral"] = 7] = "BigIntLiteral";
+        TokenClass2[TokenClass2["StringLiteral"] = 8] = "StringLiteral";
+        TokenClass2[TokenClass2["RegExpLiteral"] = 9] = "RegExpLiteral";
+        return TokenClass2;
+      })(TokenClass || {});
+      ScriptElementKind = /* @__PURE__ */ ((ScriptElementKind2) => {
+        ScriptElementKind2["unknown"] = "";
+        ScriptElementKind2["warning"] = "warning";
+        ScriptElementKind2["keyword"] = "keyword";
+        ScriptElementKind2["scriptElement"] = "script";
+        ScriptElementKind2["moduleElement"] = "module";
+        ScriptElementKind2["classElement"] = "class";
+        ScriptElementKind2["localClassElement"] = "local class";
+        ScriptElementKind2["interfaceElement"] = "interface";
+        ScriptElementKind2["typeElement"] = "type";
+        ScriptElementKind2["enumElement"] = "enum";
+        ScriptElementKind2["enumMemberElement"] = "enum member";
+        ScriptElementKind2["variableElement"] = "var";
+        ScriptElementKind2["localVariableElement"] = "local var";
+        ScriptElementKind2["variableUsingElement"] = "using";
+        ScriptElementKind2["variableAwaitUsingElement"] = "await using";
+        ScriptElementKind2["functionElement"] = "function";
+        ScriptElementKind2["localFunctionElement"] = "local function";
+        ScriptElementKind2["memberFunctionElement"] = "method";
+        ScriptElementKind2["memberGetAccessorElement"] = "getter";
+        ScriptElementKind2["memberSetAccessorElement"] = "setter";
+        ScriptElementKind2["memberVariableElement"] = "property";
+        ScriptElementKind2["memberAccessorVariableElement"] = "accessor";
+        ScriptElementKind2["constructorImplementationElement"] = "constructor";
+        ScriptElementKind2["callSignatureElement"] = "call";
+        ScriptElementKind2["indexSignatureElement"] = "index";
+        ScriptElementKind2["constructSignatureElement"] = "construct";
+        ScriptElementKind2["parameterElement"] = "parameter";
+        ScriptElementKind2["typeParameterElement"] = "type parameter";
+        ScriptElementKind2["primitiveType"] = "primitive type";
+        ScriptElementKind2["label"] = "label";
+        ScriptElementKind2["alias"] = "alias";
+        ScriptElementKind2["constElement"] = "const";
+        ScriptElementKind2["letElement"] = "let";
+        ScriptElementKind2["directory"] = "directory";
+        ScriptElementKind2["externalModuleName"] = "external module name";
+        ScriptElementKind2["jsxAttribute"] = "JSX attribute";
+        ScriptElementKind2["string"] = "string";
+        ScriptElementKind2["link"] = "link";
+        ScriptElementKind2["linkName"] = "link name";
+        ScriptElementKind2["linkText"] = "link text";
+        return ScriptElementKind2;
+      })(ScriptElementKind || {});
+      ScriptElementKindModifier = /* @__PURE__ */ ((ScriptElementKindModifier2) => {
+        ScriptElementKindModifier2["none"] = "";
+        ScriptElementKindModifier2["publicMemberModifier"] = "public";
+        ScriptElementKindModifier2["privateMemberModifier"] = "private";
+        ScriptElementKindModifier2["protectedMemberModifier"] = "protected";
+        ScriptElementKindModifier2["exportedModifier"] = "export";
+        ScriptElementKindModifier2["ambientModifier"] = "declare";
+        ScriptElementKindModifier2["staticModifier"] = "static";
+        ScriptElementKindModifier2["abstractModifier"] = "abstract";
+        ScriptElementKindModifier2["optionalModifier"] = "optional";
+        ScriptElementKindModifier2["deprecatedModifier"] = "deprecated";
+        ScriptElementKindModifier2["dtsModifier"] = ".d.ts";
+        ScriptElementKindModifier2["tsModifier"] = ".ts";
+        ScriptElementKindModifier2["tsxModifier"] = ".tsx";
+        ScriptElementKindModifier2["jsModifier"] = ".js";
+        ScriptElementKindModifier2["jsxModifier"] = ".jsx";
+        ScriptElementKindModifier2["jsonModifier"] = ".json";
+        ScriptElementKindModifier2["dmtsModifier"] = ".d.mts";
+        ScriptElementKindModifier2["mtsModifier"] = ".mts";
+        ScriptElementKindModifier2["mjsModifier"] = ".mjs";
+        ScriptElementKindModifier2["dctsModifier"] = ".d.cts";
+        ScriptElementKindModifier2["ctsModifier"] = ".cts";
+        ScriptElementKindModifier2["cjsModifier"] = ".cjs";
+        return ScriptElementKindModifier2;
+      })(ScriptElementKindModifier || {});
+      ClassificationTypeNames = /* @__PURE__ */ ((ClassificationTypeNames2) => {
+        ClassificationTypeNames2["comment"] = "comment";
+        ClassificationTypeNames2["identifier"] = "identifier";
+        ClassificationTypeNames2["keyword"] = "keyword";
+        ClassificationTypeNames2["numericLiteral"] = "number";
+        ClassificationTypeNames2["bigintLiteral"] = "bigint";
+        ClassificationTypeNames2["operator"] = "operator";
+        ClassificationTypeNames2["stringLiteral"] = "string";
+        ClassificationTypeNames2["whiteSpace"] = "whitespace";
+        ClassificationTypeNames2["text"] = "text";
+        ClassificationTypeNames2["punctuation"] = "punctuation";
+        ClassificationTypeNames2["className"] = "class name";
+        ClassificationTypeNames2["enumName"] = "enum name";
+        ClassificationTypeNames2["interfaceName"] = "interface name";
+        ClassificationTypeNames2["moduleName"] = "module name";
+        ClassificationTypeNames2["typeParameterName"] = "type parameter name";
+        ClassificationTypeNames2["typeAliasName"] = "type alias name";
+        ClassificationTypeNames2["parameterName"] = "parameter name";
+        ClassificationTypeNames2["docCommentTagName"] = "doc comment tag name";
+        ClassificationTypeNames2["jsxOpenTagName"] = "jsx open tag name";
+        ClassificationTypeNames2["jsxCloseTagName"] = "jsx close tag name";
+        ClassificationTypeNames2["jsxSelfClosingTagName"] = "jsx self closing tag name";
+        ClassificationTypeNames2["jsxAttribute"] = "jsx attribute";
+        ClassificationTypeNames2["jsxText"] = "jsx text";
+        ClassificationTypeNames2["jsxAttributeStringLiteralValue"] = "jsx attribute string literal value";
+        return ClassificationTypeNames2;
+      })(ClassificationTypeNames || {});
+      ClassificationType = /* @__PURE__ */ ((ClassificationType3) => {
+        ClassificationType3[ClassificationType3["comment"] = 1] = "comment";
+        ClassificationType3[ClassificationType3["identifier"] = 2] = "identifier";
+        ClassificationType3[ClassificationType3["keyword"] = 3] = "keyword";
+        ClassificationType3[ClassificationType3["numericLiteral"] = 4] = "numericLiteral";
+        ClassificationType3[ClassificationType3["operator"] = 5] = "operator";
+        ClassificationType3[ClassificationType3["stringLiteral"] = 6] = "stringLiteral";
+        ClassificationType3[ClassificationType3["regularExpressionLiteral"] = 7] = "regularExpressionLiteral";
+        ClassificationType3[ClassificationType3["whiteSpace"] = 8] = "whiteSpace";
+        ClassificationType3[ClassificationType3["text"] = 9] = "text";
+        ClassificationType3[ClassificationType3["punctuation"] = 10] = "punctuation";
+        ClassificationType3[ClassificationType3["className"] = 11] = "className";
+        ClassificationType3[ClassificationType3["enumName"] = 12] = "enumName";
+        ClassificationType3[ClassificationType3["interfaceName"] = 13] = "interfaceName";
+        ClassificationType3[ClassificationType3["moduleName"] = 14] = "moduleName";
+        ClassificationType3[ClassificationType3["typeParameterName"] = 15] = "typeParameterName";
+        ClassificationType3[ClassificationType3["typeAliasName"] = 16] = "typeAliasName";
+        ClassificationType3[ClassificationType3["parameterName"] = 17] = "parameterName";
+        ClassificationType3[ClassificationType3["docCommentTagName"] = 18] = "docCommentTagName";
+        ClassificationType3[ClassificationType3["jsxOpenTagName"] = 19] = "jsxOpenTagName";
+        ClassificationType3[ClassificationType3["jsxCloseTagName"] = 20] = "jsxCloseTagName";
+        ClassificationType3[ClassificationType3["jsxSelfClosingTagName"] = 21] = "jsxSelfClosingTagName";
+        ClassificationType3[ClassificationType3["jsxAttribute"] = 22] = "jsxAttribute";
+        ClassificationType3[ClassificationType3["jsxText"] = 23] = "jsxText";
+        ClassificationType3[ClassificationType3["jsxAttributeStringLiteralValue"] = 24] = "jsxAttributeStringLiteralValue";
+        ClassificationType3[ClassificationType3["bigintLiteral"] = 25] = "bigintLiteral";
+        return ClassificationType3;
+      })(ClassificationType || {});
     }
-    function handleDiagnostics(diagnostics, errorFlags, errorType) {
-      if (diagnostics.length) {
-        ({ buildResult, step } = buildErrors(
-          state,
-          projectPath,
-          program,
-          config,
-          diagnostics,
-          errorFlags,
-          errorType
-        ));
-      } else {
-        step++;
-      }
+  });
+
+  // src/services/utilities.ts
+  function getMeaningFromDeclaration(node) {
+    switch (node.kind) {
+      case 260 /* VariableDeclaration */:
+        return isInJSFile(node) && getJSDocEnumTag(node) ? 7 /* All */ : 1 /* Value */;
+      case 169 /* Parameter */:
+      case 208 /* BindingElement */:
+      case 172 /* PropertyDeclaration */:
+      case 171 /* PropertySignature */:
+      case 303 /* PropertyAssignment */:
+      case 304 /* ShorthandPropertyAssignment */:
+      case 174 /* MethodDeclaration */:
+      case 173 /* MethodSignature */:
+      case 176 /* Constructor */:
+      case 177 /* GetAccessor */:
+      case 178 /* SetAccessor */:
+      case 262 /* FunctionDeclaration */:
+      case 218 /* FunctionExpression */:
+      case 219 /* ArrowFunction */:
+      case 299 /* CatchClause */:
+      case 291 /* JsxAttribute */:
+        return 1 /* Value */;
+      case 168 /* TypeParameter */:
+      case 264 /* InterfaceDeclaration */:
+      case 265 /* TypeAliasDeclaration */:
+      case 187 /* TypeLiteral */:
+        return 2 /* Type */;
+      case 353 /* JSDocTypedefTag */:
+        return node.name === void 0 ? 1 /* Value */ | 2 /* Type */ : 2 /* Type */;
+      case 306 /* EnumMember */:
+      case 263 /* ClassDeclaration */:
+        return 1 /* Value */ | 2 /* Type */;
+      case 267 /* ModuleDeclaration */:
+        if (isAmbientModule(node)) {
+          return 4 /* Namespace */ | 1 /* Value */;
+        } else if (getModuleInstanceState(node) === 1 /* Instantiated */) {
+          return 4 /* Namespace */ | 1 /* Value */;
+        } else {
+          return 4 /* Namespace */;
+        }
+      case 266 /* EnumDeclaration */:
+      case 275 /* NamedImports */:
+      case 276 /* ImportSpecifier */:
+      case 271 /* ImportEqualsDeclaration */:
+      case 272 /* ImportDeclaration */:
+      case 277 /* ExportAssignment */:
+      case 278 /* ExportDeclaration */:
+        return 7 /* All */;
+      case 312 /* SourceFile */:
+        return 4 /* Namespace */ | 1 /* Value */;
     }
-    function getSyntaxDiagnostics(cancellationToken) {
-      Debug.assertIsDefined(program);
-      handleDiagnostics(
-        [
-          ...program.getConfigFileParsingDiagnostics(),
-          ...program.getOptionsDiagnostics(cancellationToken),
-          ...program.getGlobalDiagnostics(cancellationToken),
-          ...program.getSyntacticDiagnostics(
-            /*sourceFile*/
-            void 0,
-            cancellationToken
-          )
-        ],
-        8 /* SyntaxErrors */,
-        "Syntactic"
-      );
+    return 7 /* All */;
+  }
+  function getMeaningFromLocation(node) {
+    node = getAdjustedReferenceLocation(node);
+    const parent2 = node.parent;
+    if (node.kind === 312 /* SourceFile */) {
+      return 1 /* Value */;
+    } else if (isExportAssignment(parent2) || isExportSpecifier(parent2) || isExternalModuleReference(parent2) || isImportSpecifier(parent2) || isImportClause(parent2) || isImportEqualsDeclaration(parent2) && node === parent2.name) {
+      return 7 /* All */;
+    } else if (isInRightSideOfInternalImportEqualsDeclaration(node)) {
+      return getMeaningFromRightHandSideOfImportEquals(node);
+    } else if (isDeclarationName(node)) {
+      return getMeaningFromDeclaration(parent2);
+    } else if (isEntityName(node) && findAncestor(node, or(isJSDocNameReference, isJSDocLinkLike, isJSDocMemberName))) {
+      return 7 /* All */;
+    } else if (isTypeReference(node)) {
+      return 2 /* Type */;
+    } else if (isNamespaceReference(node)) {
+      return 4 /* Namespace */;
+    } else if (isTypeParameterDeclaration(parent2)) {
+      Debug.assert(isJSDocTemplateTag(parent2.parent));
+      return 2 /* Type */;
+    } else if (isLiteralTypeNode(parent2)) {
+      return 2 /* Type */ | 1 /* Value */;
+    } else {
+      return 1 /* Value */;
     }
-    function getSemanticDiagnostics(cancellationToken) {
-      handleDiagnostics(
-        Debug.checkDefined(program).getSemanticDiagnostics(
-          /*sourceFile*/
-          void 0,
-          cancellationToken
-        ),
-        16 /* TypeErrors */,
-        "Semantic"
-      );
+  }
+  function getMeaningFromRightHandSideOfImportEquals(node) {
+    const name = node.kind === 166 /* QualifiedName */ ? node : isQualifiedName(node.parent) && node.parent.right === node ? node.parent : void 0;
+    return name && name.parent.kind === 271 /* ImportEqualsDeclaration */ ? 7 /* All */ : 4 /* Namespace */;
+  }
+  function isInRightSideOfInternalImportEqualsDeclaration(node) {
+    while (node.parent.kind === 166 /* QualifiedName */) {
+      node = node.parent;
     }
-    function emit(writeFileCallback, cancellationToken, customTransformers) {
-      var _a, _b, _c;
-      Debug.assertIsDefined(program);
-      Debug.assert(step === 3 /* Emit */);
-      const saved = program.saveEmitState();
-      let declDiagnostics;
-      const reportDeclarationDiagnostics = (d) => (declDiagnostics || (declDiagnostics = [])).push(d);
-      const outputFiles = [];
-      const { emitResult } = emitFilesAndReportErrors(
-        program,
-        reportDeclarationDiagnostics,
-        /*write*/
-        void 0,
-        /*reportSummary*/
-        void 0,
-        (name, text, writeByteOrderMark, _onError, _sourceFiles, data) => outputFiles.push({ name, text, writeByteOrderMark, data }),
-        cancellationToken,
-        /*emitOnlyDtsFiles*/
-        false,
-        customTransformers || ((_b = (_a = state.host).getCustomTransformers) == null ? void 0 : _b.call(_a, project))
-      );
-      if (declDiagnostics) {
-        program.restoreEmitState(saved);
-        ({ buildResult, step } = buildErrors(
-          state,
-          projectPath,
-          program,
-          config,
-          declDiagnostics,
-          32 /* DeclarationEmitErrors */,
-          "Declaration file"
-        ));
-        return {
-          emitSkipped: true,
-          diagnostics: emitResult.diagnostics
-        };
+    return isInternalModuleImportEqualsDeclaration(node.parent) && node.parent.moduleReference === node;
+  }
+  function isNamespaceReference(node) {
+    return isQualifiedNameNamespaceReference(node) || isPropertyAccessNamespaceReference(node);
+  }
+  function isQualifiedNameNamespaceReference(node) {
+    let root = node;
+    let isLastClause = true;
+    if (root.parent.kind === 166 /* QualifiedName */) {
+      while (root.parent && root.parent.kind === 166 /* QualifiedName */) {
+        root = root.parent;
       }
-      const { host, compilerHost } = state;
-      const resultFlags = ((_c = program.hasChangedEmitSignature) == null ? void 0 : _c.call(program)) ? 0 /* None */ : 2 /* DeclarationOutputUnchanged */;
-      const emitterDiagnostics = createDiagnosticCollection();
-      const emittedOutputs = /* @__PURE__ */ new Map();
-      const options = program.getCompilerOptions();
-      const isIncremental = isIncrementalCompilation(options);
-      let outputTimeStampMap;
-      let now;
-      outputFiles.forEach(({ name, text, writeByteOrderMark, data }) => {
-        const path = toPath2(state, name);
-        emittedOutputs.set(toPath2(state, name), name);
-        if (data == null ? void 0 : data.buildInfo)
-          setBuildInfo(state, data.buildInfo, projectPath, options, resultFlags);
-        const modifiedTime = (data == null ? void 0 : data.differsOnlyInMap) ? getModifiedTime(state.host, name) : void 0;
-        writeFile(writeFileCallback ? { writeFile: writeFileCallback } : compilerHost, emitterDiagnostics, name, text, writeByteOrderMark);
-        if (data == null ? void 0 : data.differsOnlyInMap)
-          state.host.setModifiedTime(name, modifiedTime);
-        else if (!isIncremental && state.watch) {
-          (outputTimeStampMap || (outputTimeStampMap = getOutputTimeStampMap(state, projectPath))).set(path, now || (now = getCurrentTime(state.host)));
-        }
-      });
-      finishEmit(
-        emitterDiagnostics,
-        emittedOutputs,
-        outputFiles.length ? outputFiles[0].name : getFirstProjectOutput(config, !host.useCaseSensitiveFileNames()),
-        resultFlags
-      );
-      return emitResult;
+      isLastClause = root.right === node;
     }
-    function emitBuildInfo(writeFileCallback, cancellationToken) {
-      Debug.assertIsDefined(program);
-      Debug.assert(step === 5 /* EmitBuildInfo */);
-      const emitResult = program.emitBuildInfo((name, text, writeByteOrderMark, onError, sourceFiles, data) => {
-        if (data == null ? void 0 : data.buildInfo)
-          setBuildInfo(state, data.buildInfo, projectPath, program.getCompilerOptions(), 2 /* DeclarationOutputUnchanged */);
-        if (writeFileCallback)
-          writeFileCallback(name, text, writeByteOrderMark, onError, sourceFiles, data);
-        else
-          state.compilerHost.writeFile(name, text, writeByteOrderMark, onError, sourceFiles, data);
-      }, cancellationToken);
-      if (emitResult.diagnostics.length) {
-        reportErrors(state, emitResult.diagnostics);
-        state.diagnostics.set(projectPath, [...state.diagnostics.get(projectPath), ...emitResult.diagnostics]);
-        buildResult = 64 /* EmitErrors */ & buildResult;
-      }
-      if (emitResult.emittedFiles && state.write) {
-        emitResult.emittedFiles.forEach((name) => listEmittedFile(state, config, name));
+    return root.parent.kind === 183 /* TypeReference */ && !isLastClause;
+  }
+  function isPropertyAccessNamespaceReference(node) {
+    let root = node;
+    let isLastClause = true;
+    if (root.parent.kind === 211 /* PropertyAccessExpression */) {
+      while (root.parent && root.parent.kind === 211 /* PropertyAccessExpression */) {
+        root = root.parent;
       }
-      afterProgramDone(state, program, config);
-      step = 7 /* QueueReferencingProjects */;
-      return emitResult;
+      isLastClause = root.name === node;
     }
-    function finishEmit(emitterDiagnostics, emittedOutputs, oldestOutputFileName, resultFlags) {
-      const emitDiagnostics = emitterDiagnostics.getDiagnostics();
-      if (emitDiagnostics.length) {
-        ({ buildResult, step } = buildErrors(
-          state,
-          projectPath,
-          program,
-          config,
-          emitDiagnostics,
-          64 /* EmitErrors */,
-          "Emit"
-        ));
-        return emitDiagnostics;
-      }
-      if (state.write) {
-        emittedOutputs.forEach((name) => listEmittedFile(state, config, name));
-      }
-      updateOutputTimestampsWorker(state, config, projectPath, Diagnostics.Updating_unchanged_output_timestamps_of_project_0, emittedOutputs);
-      state.diagnostics.delete(projectPath);
-      state.projectStatus.set(projectPath, {
-        type: 1 /* UpToDate */,
-        oldestOutputFileName
-      });
-      afterProgramDone(state, program, config);
-      step = 7 /* QueueReferencingProjects */;
-      buildResult = resultFlags;
-      return emitDiagnostics;
+    if (!isLastClause && root.parent.kind === 233 /* ExpressionWithTypeArguments */ && root.parent.parent.kind === 298 /* HeritageClause */) {
+      const decl = root.parent.parent.parent;
+      return decl.kind === 263 /* ClassDeclaration */ && root.parent.parent.token === 119 /* ImplementsKeyword */ || decl.kind === 264 /* InterfaceDeclaration */ && root.parent.parent.token === 96 /* ExtendsKeyword */;
     }
-    function emitBundle(writeFileCallback, customTransformers) {
-      var _a, _b, _c, _d;
-      Debug.assert(kind === 1 /* UpdateBundle */);
-      if (state.options.dry) {
-        reportStatus(state, Diagnostics.A_non_dry_build_would_update_output_of_project_0, project);
-        buildResult = 1 /* Success */;
-        step = 7 /* QueueReferencingProjects */;
-        return void 0;
-      }
-      if (state.options.verbose)
-        reportStatus(state, Diagnostics.Updating_output_of_project_0, project);
-      const { compilerHost } = state;
-      state.projectCompilerOptions = config.options;
-      (_b = (_a = state.host).beforeEmitBundle) == null ? void 0 : _b.call(_a, config);
-      const outputFiles = emitUsingBuildInfo(
-        config,
-        compilerHost,
-        (ref) => {
-          const refName = resolveProjectName(state, ref.path);
-          return parseConfigFile(state, refName, toResolvedConfigFilePath(state, refName));
-        },
-        customTransformers || ((_d = (_c = state.host).getCustomTransformers) == null ? void 0 : _d.call(_c, project))
-      );
-      if (isString(outputFiles)) {
-        reportStatus(state, Diagnostics.Cannot_update_output_of_project_0_because_there_was_error_reading_file_1, project, relName(state, outputFiles));
-        step = 6 /* BuildInvalidatedProjectOfBundle */;
-        return invalidatedProjectOfBundle = createBuildOrUpdateInvalidedProject(
-          0 /* Build */,
-          state,
-          project,
-          projectPath,
-          projectIndex,
-          config,
-          buildOrder
-        );
-      }
-      Debug.assert(!!outputFiles.length);
-      const emitterDiagnostics = createDiagnosticCollection();
-      const emittedOutputs = /* @__PURE__ */ new Map();
-      let resultFlags = 2 /* DeclarationOutputUnchanged */;
-      const existingBuildInfo = state.buildInfoCache.get(projectPath).buildInfo || void 0;
-      outputFiles.forEach(({ name, text, writeByteOrderMark, data }) => {
-        var _a2, _b2;
-        emittedOutputs.set(toPath2(state, name), name);
-        if (data == null ? void 0 : data.buildInfo) {
-          if (((_a2 = data.buildInfo.program) == null ? void 0 : _a2.outSignature) !== ((_b2 = existingBuildInfo == null ? void 0 : existingBuildInfo.program) == null ? void 0 : _b2.outSignature)) {
-            resultFlags &= ~2 /* DeclarationOutputUnchanged */;
-          }
-          setBuildInfo(state, data.buildInfo, projectPath, config.options, resultFlags);
-        }
-        writeFile(writeFileCallback ? { writeFile: writeFileCallback } : compilerHost, emitterDiagnostics, name, text, writeByteOrderMark);
-      });
-      const emitDiagnostics = finishEmit(
-        emitterDiagnostics,
-        emittedOutputs,
-        outputFiles[0].name,
-        resultFlags
-      );
-      return { emitSkipped: false, diagnostics: emitDiagnostics };
+    return false;
+  }
+  function isTypeReference(node) {
+    if (isRightSideOfQualifiedNameOrPropertyAccess(node)) {
+      node = node.parent;
     }
-    function executeSteps(till, cancellationToken, writeFile2, customTransformers) {
-      while (step <= till && step < 8 /* Done */) {
-        const currentStep = step;
-        switch (step) {
-          case 0 /* CreateProgram */:
-            createProgram2();
-            break;
-          case 1 /* SyntaxDiagnostics */:
-            getSyntaxDiagnostics(cancellationToken);
-            break;
-          case 2 /* SemanticDiagnostics */:
-            getSemanticDiagnostics(cancellationToken);
-            break;
-          case 3 /* Emit */:
-            emit(writeFile2, cancellationToken, customTransformers);
-            break;
-          case 5 /* EmitBuildInfo */:
-            emitBuildInfo(writeFile2, cancellationToken);
-            break;
-          case 4 /* EmitBundle */:
-            emitBundle(writeFile2, customTransformers);
-            break;
-          case 6 /* BuildInvalidatedProjectOfBundle */:
-            Debug.checkDefined(invalidatedProjectOfBundle).done(cancellationToken, writeFile2, customTransformers);
-            step = 8 /* Done */;
-            break;
-          case 7 /* QueueReferencingProjects */:
-            queueReferencingProjects(state, project, projectPath, projectIndex, config, buildOrder, Debug.checkDefined(buildResult));
-            step++;
-            break;
-          case 8 /* Done */:
-          default:
-            assertType(step);
-        }
-        Debug.assert(step > currentStep);
-      }
+    switch (node.kind) {
+      case 110 /* ThisKeyword */:
+        return !isExpressionNode(node);
+      case 197 /* ThisType */:
+        return true;
+    }
+    switch (node.parent.kind) {
+      case 183 /* TypeReference */:
+        return true;
+      case 205 /* ImportType */:
+        return !node.parent.isTypeOf;
+      case 233 /* ExpressionWithTypeArguments */:
+        return isPartOfTypeNode(node.parent);
     }
+    return false;
   }
-  function needsBuild({ options }, status, config) {
-    if (status.type !== 3 /* OutOfDateWithPrepend */ || options.force)
-      return true;
-    return config.fileNames.length === 0 || !!getConfigFileParsingDiagnostics(config).length || !isIncrementalCompilation(config.options);
+  function isCallExpressionTarget(node, includeElementAccess = false, skipPastOuterExpressions = false) {
+    return isCalleeWorker(node, isCallExpression, selectExpressionOfCallOrNewExpressionOrDecorator, includeElementAccess, skipPastOuterExpressions);
   }
-  function getNextInvalidatedProjectCreateInfo(state, buildOrder, reportQueue) {
-    if (!state.projectPendingBuild.size)
-      return void 0;
-    if (isCircularBuildOrder(buildOrder))
-      return void 0;
-    const { options, projectPendingBuild } = state;
-    for (let projectIndex = 0; projectIndex < buildOrder.length; projectIndex++) {
-      const project = buildOrder[projectIndex];
-      const projectPath = toResolvedConfigFilePath(state, project);
-      const reloadLevel = state.projectPendingBuild.get(projectPath);
-      if (reloadLevel === void 0)
-        continue;
-      if (reportQueue) {
-        reportQueue = false;
-        reportBuildQueue(state, buildOrder);
-      }
-      const config = parseConfigFile(state, project, projectPath);
-      if (!config) {
-        reportParseConfigFileDiagnostic(state, projectPath);
-        projectPendingBuild.delete(projectPath);
-        continue;
-      }
-      if (reloadLevel === 2 /* Full */) {
-        watchConfigFile(state, project, projectPath, config);
-        watchExtendedConfigFiles(state, projectPath, config);
-        watchWildCardDirectories(state, project, projectPath, config);
-        watchInputFiles(state, project, projectPath, config);
-        watchPackageJsonFiles(state, project, projectPath, config);
-      } else if (reloadLevel === 1 /* Partial */) {
-        config.fileNames = getFileNamesFromConfigSpecs(config.options.configFile.configFileSpecs, getDirectoryPath(project), config.options, state.parseConfigFileHost);
-        updateErrorForNoInputFiles(config.fileNames, project, config.options.configFile.configFileSpecs, config.errors, canJsonReportNoInputFiles(config.raw));
-        watchInputFiles(state, project, projectPath, config);
-        watchPackageJsonFiles(state, project, projectPath, config);
-      }
-      const status = getUpToDateStatus(state, config, projectPath);
-      if (!options.force) {
-        if (status.type === 1 /* UpToDate */) {
-          verboseReportProjectStatus(state, project, status);
-          reportAndStoreErrors(state, projectPath, getConfigFileParsingDiagnostics(config));
-          projectPendingBuild.delete(projectPath);
-          if (options.dry) {
-            reportStatus(state, Diagnostics.Project_0_is_up_to_date, project);
-          }
-          continue;
-        }
-        if (status.type === 2 /* UpToDateWithUpstreamTypes */ || status.type === 15 /* UpToDateWithInputFileText */) {
-          reportAndStoreErrors(state, projectPath, getConfigFileParsingDiagnostics(config));
-          return {
-            kind: 2 /* UpdateOutputFileStamps */,
-            status,
-            project,
-            projectPath,
-            projectIndex,
-            config
-          };
-        }
-      }
-      if (status.type === 12 /* UpstreamBlocked */) {
-        verboseReportProjectStatus(state, project, status);
-        reportAndStoreErrors(state, projectPath, getConfigFileParsingDiagnostics(config));
-        projectPendingBuild.delete(projectPath);
-        if (options.verbose) {
-          reportStatus(
-            state,
-            status.upstreamProjectBlocked ? Diagnostics.Skipping_build_of_project_0_because_its_dependency_1_was_not_built : Diagnostics.Skipping_build_of_project_0_because_its_dependency_1_has_errors,
-            project,
-            status.upstreamProjectName
-          );
-        }
-        continue;
-      }
-      if (status.type === 16 /* ContainerOnly */) {
-        verboseReportProjectStatus(state, project, status);
-        reportAndStoreErrors(state, projectPath, getConfigFileParsingDiagnostics(config));
-        projectPendingBuild.delete(projectPath);
-        continue;
-      }
-      return {
-        kind: needsBuild(state, status, config) ? 0 /* Build */ : 1 /* UpdateBundle */,
-        status,
-        project,
-        projectPath,
-        projectIndex,
-        config
-      };
-    }
-    return void 0;
+  function isNewExpressionTarget(node, includeElementAccess = false, skipPastOuterExpressions = false) {
+    return isCalleeWorker(node, isNewExpression, selectExpressionOfCallOrNewExpressionOrDecorator, includeElementAccess, skipPastOuterExpressions);
   }
-  function createInvalidatedProjectWithInfo(state, info, buildOrder) {
-    verboseReportProjectStatus(state, info.project, info.status);
-    return info.kind !== 2 /* UpdateOutputFileStamps */ ? createBuildOrUpdateInvalidedProject(
-      info.kind,
-      state,
-      info.project,
-      info.projectPath,
-      info.projectIndex,
-      info.config,
-      buildOrder
-    ) : createUpdateOutputFileStampsProject(
-      state,
-      info.project,
-      info.projectPath,
-      info.config,
-      buildOrder
-    );
+  function isCallOrNewExpressionTarget(node, includeElementAccess = false, skipPastOuterExpressions = false) {
+    return isCalleeWorker(node, isCallOrNewExpression, selectExpressionOfCallOrNewExpressionOrDecorator, includeElementAccess, skipPastOuterExpressions);
   }
-  function getNextInvalidatedProject(state, buildOrder, reportQueue) {
-    const info = getNextInvalidatedProjectCreateInfo(state, buildOrder, reportQueue);
-    if (!info)
-      return info;
-    return createInvalidatedProjectWithInfo(state, info, buildOrder);
+  function isTaggedTemplateTag(node, includeElementAccess = false, skipPastOuterExpressions = false) {
+    return isCalleeWorker(node, isTaggedTemplateExpression, selectTagOfTaggedTemplateExpression, includeElementAccess, skipPastOuterExpressions);
   }
-  function listEmittedFile({ write }, proj, file) {
-    if (write && proj.options.listEmittedFiles) {
-      write(`TSFILE: ${file}`);
-    }
+  function isDecoratorTarget(node, includeElementAccess = false, skipPastOuterExpressions = false) {
+    return isCalleeWorker(node, isDecorator, selectExpressionOfCallOrNewExpressionOrDecorator, includeElementAccess, skipPastOuterExpressions);
   }
-  function getOldProgram({ options, builderPrograms, compilerHost }, proj, parsed) {
-    if (options.force)
-      return void 0;
-    const value = builderPrograms.get(proj);
-    if (value)
-      return value;
-    return readBuilderProgram(parsed.options, compilerHost);
+  function isJsxOpeningLikeElementTagName(node, includeElementAccess = false, skipPastOuterExpressions = false) {
+    return isCalleeWorker(node, isJsxOpeningLikeElement, selectTagNameOfJsxOpeningLikeElement, includeElementAccess, skipPastOuterExpressions);
   }
-  function afterProgramDone(state, program, config) {
-    if (program) {
-      if (state.write)
-        listFiles(program, state.write);
-      if (state.host.afterProgramEmitAndDiagnostics) {
-        state.host.afterProgramEmitAndDiagnostics(program);
-      }
-      program.releaseProgram();
-    } else if (state.host.afterEmitBundle) {
-      state.host.afterEmitBundle(config);
-    }
-    state.projectCompilerOptions = state.baseCompilerOptions;
+  function selectExpressionOfCallOrNewExpressionOrDecorator(node) {
+    return node.expression;
   }
-  function buildErrors(state, resolvedPath, program, config, diagnostics, buildResult, errorType) {
-    const canEmitBuildInfo = program && !outFile(program.getCompilerOptions());
-    reportAndStoreErrors(state, resolvedPath, diagnostics);
-    state.projectStatus.set(resolvedPath, { type: 0 /* Unbuildable */, reason: `${errorType} errors` });
-    if (canEmitBuildInfo)
-      return { buildResult, step: 5 /* EmitBuildInfo */ };
-    afterProgramDone(state, program, config);
-    return { buildResult, step: 7 /* QueueReferencingProjects */ };
+  function selectTagOfTaggedTemplateExpression(node) {
+    return node.tag;
   }
-  function isFileWatcherWithModifiedTime(value) {
-    return !!value.watcher;
+  function selectTagNameOfJsxOpeningLikeElement(node) {
+    return node.tagName;
   }
-  function getModifiedTime2(state, fileName) {
-    const path = toPath2(state, fileName);
-    const existing = state.filesWatched.get(path);
-    if (state.watch && !!existing) {
-      if (!isFileWatcherWithModifiedTime(existing))
-        return existing;
-      if (existing.modifiedTime)
-        return existing.modifiedTime;
+  function isCalleeWorker(node, pred, calleeSelector, includeElementAccess, skipPastOuterExpressions) {
+    let target = includeElementAccess ? climbPastPropertyOrElementAccess(node) : climbPastPropertyAccess(node);
+    if (skipPastOuterExpressions) {
+      target = skipOuterExpressions(target);
     }
-    const result = getModifiedTime(state.host, fileName);
-    if (state.watch) {
-      if (existing)
-        existing.modifiedTime = result;
-      else
-        state.filesWatched.set(path, result);
+    return !!target && !!target.parent && pred(target.parent) && calleeSelector(target.parent) === target;
+  }
+  function climbPastPropertyAccess(node) {
+    return isRightSideOfPropertyAccess(node) ? node.parent : node;
+  }
+  function climbPastPropertyOrElementAccess(node) {
+    return isRightSideOfPropertyAccess(node) || isArgumentExpressionOfElementAccess(node) ? node.parent : node;
+  }
+  function getTargetLabel(referenceNode, labelName) {
+    while (referenceNode) {
+      if (referenceNode.kind === 256 /* LabeledStatement */ && referenceNode.label.escapedText === labelName) {
+        return referenceNode.label;
+      }
+      referenceNode = referenceNode.parent;
     }
-    return result;
+    return void 0;
   }
-  function watchFile(state, file, callback, pollingInterval, options, watchType, project) {
-    const path = toPath2(state, file);
-    const existing = state.filesWatched.get(path);
-    if (existing && isFileWatcherWithModifiedTime(existing)) {
-      existing.callbacks.push(callback);
-    } else {
-      const watcher = state.watchFile(
-        file,
-        (fileName, eventKind, modifiedTime) => {
-          const existing2 = Debug.checkDefined(state.filesWatched.get(path));
-          Debug.assert(isFileWatcherWithModifiedTime(existing2));
-          existing2.modifiedTime = modifiedTime;
-          existing2.callbacks.forEach((cb) => cb(fileName, eventKind, modifiedTime));
-        },
-        pollingInterval,
-        options,
-        watchType,
-        project
-      );
-      state.filesWatched.set(path, { callbacks: [callback], watcher, modifiedTime: existing });
+  function hasPropertyAccessExpressionWithName(node, funcName) {
+    if (!isPropertyAccessExpression(node.expression)) {
+      return false;
     }
-    return {
-      close: () => {
-        const existing2 = Debug.checkDefined(state.filesWatched.get(path));
-        Debug.assert(isFileWatcherWithModifiedTime(existing2));
-        if (existing2.callbacks.length === 1) {
-          state.filesWatched.delete(path);
-          closeFileWatcherOf(existing2);
-        } else {
-          unorderedRemoveItem(existing2.callbacks, callback);
-        }
-      }
-    };
+    return node.expression.name.text === funcName;
   }
-  function getOutputTimeStampMap(state, resolvedConfigFilePath) {
-    if (!state.watch)
-      return void 0;
-    let result = state.outputTimeStamps.get(resolvedConfigFilePath);
-    if (!result)
-      state.outputTimeStamps.set(resolvedConfigFilePath, result = /* @__PURE__ */ new Map());
-    return result;
+  function isJumpStatementTarget(node) {
+    var _a;
+    return isIdentifier(node) && ((_a = tryCast(node.parent, isBreakOrContinueStatement)) == null ? void 0 : _a.label) === node;
   }
-  function setBuildInfo(state, buildInfo, resolvedConfigPath, options, resultFlags) {
-    const buildInfoPath = getTsBuildInfoEmitOutputFilePath(options);
-    const existing = getBuildInfoCacheEntry(state, buildInfoPath, resolvedConfigPath);
-    const modifiedTime = getCurrentTime(state.host);
-    if (existing) {
-      existing.buildInfo = buildInfo;
-      existing.modifiedTime = modifiedTime;
-      if (!(resultFlags & 2 /* DeclarationOutputUnchanged */))
-        existing.latestChangedDtsTime = modifiedTime;
-    } else {
-      state.buildInfoCache.set(resolvedConfigPath, {
-        path: toPath2(state, buildInfoPath),
-        buildInfo,
-        modifiedTime,
-        latestChangedDtsTime: resultFlags & 2 /* DeclarationOutputUnchanged */ ? void 0 : modifiedTime
-      });
-    }
+  function isLabelOfLabeledStatement(node) {
+    var _a;
+    return isIdentifier(node) && ((_a = tryCast(node.parent, isLabeledStatement)) == null ? void 0 : _a.label) === node;
   }
-  function getBuildInfoCacheEntry(state, buildInfoPath, resolvedConfigPath) {
-    const path = toPath2(state, buildInfoPath);
-    const existing = state.buildInfoCache.get(resolvedConfigPath);
-    return (existing == null ? void 0 : existing.path) === path ? existing : void 0;
+  function isLabelName(node) {
+    return isLabelOfLabeledStatement(node) || isJumpStatementTarget(node);
   }
-  function getBuildInfo3(state, buildInfoPath, resolvedConfigPath, modifiedTime) {
-    const path = toPath2(state, buildInfoPath);
-    const existing = state.buildInfoCache.get(resolvedConfigPath);
-    if (existing !== void 0 && existing.path === path) {
-      return existing.buildInfo || void 0;
-    }
-    const value = state.readFileWithCache(buildInfoPath);
-    const buildInfo = value ? getBuildInfo(buildInfoPath, value) : void 0;
-    state.buildInfoCache.set(resolvedConfigPath, { path, buildInfo: buildInfo || false, modifiedTime: modifiedTime || missingFileModifiedTime });
-    return buildInfo;
+  function isTagName(node) {
+    var _a;
+    return ((_a = tryCast(node.parent, isJSDocTag)) == null ? void 0 : _a.tagName) === node;
   }
-  function checkConfigFileUpToDateStatus(state, configFile, oldestOutputFileTime, oldestOutputFileName) {
-    const tsconfigTime = getModifiedTime2(state, configFile);
-    if (oldestOutputFileTime < tsconfigTime) {
-      return {
-        type: 6 /* OutOfDateWithSelf */,
-        outOfDateOutputFileName: oldestOutputFileName,
-        newerInputFileName: configFile
-      };
-    }
+  function isRightSideOfQualifiedName(node) {
+    var _a;
+    return ((_a = tryCast(node.parent, isQualifiedName)) == null ? void 0 : _a.right) === node;
   }
-  function getUpToDateStatusWorker(state, project, resolvedPath) {
-    var _a, _b;
-    if (!project.fileNames.length && !canJsonReportNoInputFiles(project.raw)) {
-      return {
-        type: 16 /* ContainerOnly */
-      };
+  function isRightSideOfPropertyAccess(node) {
+    var _a;
+    return ((_a = tryCast(node.parent, isPropertyAccessExpression)) == null ? void 0 : _a.name) === node;
+  }
+  function isArgumentExpressionOfElementAccess(node) {
+    var _a;
+    return ((_a = tryCast(node.parent, isElementAccessExpression)) == null ? void 0 : _a.argumentExpression) === node;
+  }
+  function isNameOfModuleDeclaration(node) {
+    var _a;
+    return ((_a = tryCast(node.parent, isModuleDeclaration)) == null ? void 0 : _a.name) === node;
+  }
+  function isNameOfFunctionDeclaration(node) {
+    var _a;
+    return isIdentifier(node) && ((_a = tryCast(node.parent, isFunctionLike)) == null ? void 0 : _a.name) === node;
+  }
+  function isLiteralNameOfPropertyDeclarationOrIndexAccess(node) {
+    switch (node.parent.kind) {
+      case 172 /* PropertyDeclaration */:
+      case 171 /* PropertySignature */:
+      case 303 /* PropertyAssignment */:
+      case 306 /* EnumMember */:
+      case 174 /* MethodDeclaration */:
+      case 173 /* MethodSignature */:
+      case 177 /* GetAccessor */:
+      case 178 /* SetAccessor */:
+      case 267 /* ModuleDeclaration */:
+        return getNameOfDeclaration(node.parent) === node;
+      case 212 /* ElementAccessExpression */:
+        return node.parent.argumentExpression === node;
+      case 167 /* ComputedPropertyName */:
+        return true;
+      case 201 /* LiteralType */:
+        return node.parent.parent.kind === 199 /* IndexedAccessType */;
+      default:
+        return false;
     }
-    let referenceStatuses;
-    const force = !!state.options.force;
-    if (project.projectReferences) {
-      state.projectStatus.set(resolvedPath, { type: 13 /* ComputingUpstream */ });
-      for (const ref of project.projectReferences) {
-        const resolvedRef = resolveProjectReferencePath(ref);
-        const resolvedRefPath = toResolvedConfigFilePath(state, resolvedRef);
-        const resolvedConfig = parseConfigFile(state, resolvedRef, resolvedRefPath);
-        const refStatus = getUpToDateStatus(state, resolvedConfig, resolvedRefPath);
-        if (refStatus.type === 13 /* ComputingUpstream */ || refStatus.type === 16 /* ContainerOnly */) {
-          continue;
-        }
-        if (refStatus.type === 0 /* Unbuildable */ || refStatus.type === 12 /* UpstreamBlocked */) {
-          return {
-            type: 12 /* UpstreamBlocked */,
-            upstreamProjectName: ref.path,
-            upstreamProjectBlocked: refStatus.type === 12 /* UpstreamBlocked */
-          };
-        }
-        if (refStatus.type !== 1 /* UpToDate */) {
-          return {
-            type: 11 /* UpstreamOutOfDate */,
-            upstreamProjectName: ref.path
-          };
-        }
-        if (!force)
-          (referenceStatuses || (referenceStatuses = [])).push({ ref, refStatus, resolvedRefPath, resolvedConfig });
-      }
+  }
+  function isExpressionOfExternalModuleImportEqualsDeclaration(node) {
+    return isExternalModuleImportEqualsDeclaration(node.parent.parent) && getExternalModuleImportEqualsDeclarationExpression(node.parent.parent) === node;
+  }
+  function getContainerNode(node) {
+    if (isJSDocTypeAlias(node)) {
+      node = node.parent.parent;
     }
-    if (force)
-      return { type: 17 /* ForceBuild */ };
-    const { host } = state;
-    const buildInfoPath = getTsBuildInfoEmitOutputFilePath(project.options);
-    let oldestOutputFileName;
-    let oldestOutputFileTime = maximumDate;
-    let buildInfoTime;
-    let buildInfoProgram;
-    let buildInfoVersionMap;
-    if (buildInfoPath) {
-      const buildInfoCacheEntry2 = getBuildInfoCacheEntry(state, buildInfoPath, resolvedPath);
-      buildInfoTime = (buildInfoCacheEntry2 == null ? void 0 : buildInfoCacheEntry2.modifiedTime) || getModifiedTime(host, buildInfoPath);
-      if (buildInfoTime === missingFileModifiedTime) {
-        if (!buildInfoCacheEntry2) {
-          state.buildInfoCache.set(resolvedPath, {
-            path: toPath2(state, buildInfoPath),
-            buildInfo: false,
-            modifiedTime: buildInfoTime
-          });
-        }
-        return {
-          type: 4 /* OutputMissing */,
-          missingOutputFileName: buildInfoPath
-        };
-      }
-      const buildInfo = getBuildInfo3(state, buildInfoPath, resolvedPath, buildInfoTime);
-      if (!buildInfo) {
-        return {
-          type: 5 /* ErrorReadingFile */,
-          fileName: buildInfoPath
-        };
-      }
-      if ((buildInfo.bundle || buildInfo.program) && buildInfo.version !== version) {
-        return {
-          type: 14 /* TsVersionOutputOfDate */,
-          version: buildInfo.version
-        };
+    while (true) {
+      node = node.parent;
+      if (!node) {
+        return void 0;
       }
-      if (buildInfo.program) {
-        if (((_a = buildInfo.program.changeFileSet) == null ? void 0 : _a.length) || (!project.options.noEmit ? (_b = buildInfo.program.affectedFilesPendingEmit) == null ? void 0 : _b.length : some(buildInfo.program.semanticDiagnosticsPerFile, isArray))) {
-          return {
-            type: 8 /* OutOfDateBuildInfo */,
-            buildInfoFile: buildInfoPath
-          };
-        }
-        if (!project.options.noEmit && getPendingEmitKind(project.options, buildInfo.program.options || {})) {
-          return {
-            type: 9 /* OutOfDateOptions */,
-            buildInfoFile: buildInfoPath
-          };
-        }
-        buildInfoProgram = buildInfo.program;
+      switch (node.kind) {
+        case 312 /* SourceFile */:
+        case 174 /* MethodDeclaration */:
+        case 173 /* MethodSignature */:
+        case 262 /* FunctionDeclaration */:
+        case 218 /* FunctionExpression */:
+        case 177 /* GetAccessor */:
+        case 178 /* SetAccessor */:
+        case 263 /* ClassDeclaration */:
+        case 264 /* InterfaceDeclaration */:
+        case 266 /* EnumDeclaration */:
+        case 267 /* ModuleDeclaration */:
+          return node;
       }
-      oldestOutputFileTime = buildInfoTime;
-      oldestOutputFileName = buildInfoPath;
     }
-    let newestInputFileName = void 0;
-    let newestInputFileTime = minimumDate;
-    let pseudoInputUpToDate = false;
-    const seenRoots = /* @__PURE__ */ new Set();
-    for (const inputFile of project.fileNames) {
-      const inputTime = getModifiedTime2(state, inputFile);
-      if (inputTime === missingFileModifiedTime) {
-        return {
-          type: 0 /* Unbuildable */,
-          reason: `${inputFile} does not exist`
-        };
-      }
-      if (buildInfoTime && buildInfoTime < inputTime) {
-        let version2;
-        let currentVersion;
-        if (buildInfoProgram) {
-          if (!buildInfoVersionMap)
-            buildInfoVersionMap = getBuildInfoFileVersionMap(buildInfoProgram, buildInfoPath, host);
-          version2 = buildInfoVersionMap.fileInfos.get(toPath2(state, inputFile));
-          const text = version2 ? state.readFileWithCache(inputFile) : void 0;
-          currentVersion = text !== void 0 ? getSourceFileVersionAsHashFromText(host, text) : void 0;
-          if (version2 && version2 === currentVersion)
-            pseudoInputUpToDate = true;
-        }
-        if (!version2 || version2 !== currentVersion) {
-          return {
-            type: 6 /* OutOfDateWithSelf */,
-            outOfDateOutputFileName: buildInfoPath,
-            newerInputFileName: inputFile
-          };
+  }
+  function getNodeKind(node) {
+    switch (node.kind) {
+      case 312 /* SourceFile */:
+        return isExternalModule(node) ? "module" /* moduleElement */ : "script" /* scriptElement */;
+      case 267 /* ModuleDeclaration */:
+        return "module" /* moduleElement */;
+      case 263 /* ClassDeclaration */:
+      case 231 /* ClassExpression */:
+        return "class" /* classElement */;
+      case 264 /* InterfaceDeclaration */:
+        return "interface" /* interfaceElement */;
+      case 265 /* TypeAliasDeclaration */:
+      case 345 /* JSDocCallbackTag */:
+      case 353 /* JSDocTypedefTag */:
+        return "type" /* typeElement */;
+      case 266 /* EnumDeclaration */:
+        return "enum" /* enumElement */;
+      case 260 /* VariableDeclaration */:
+        return getKindOfVariableDeclaration(node);
+      case 208 /* BindingElement */:
+        return getKindOfVariableDeclaration(getRootDeclaration(node));
+      case 219 /* ArrowFunction */:
+      case 262 /* FunctionDeclaration */:
+      case 218 /* FunctionExpression */:
+        return "function" /* functionElement */;
+      case 177 /* GetAccessor */:
+        return "getter" /* memberGetAccessorElement */;
+      case 178 /* SetAccessor */:
+        return "setter" /* memberSetAccessorElement */;
+      case 174 /* MethodDeclaration */:
+      case 173 /* MethodSignature */:
+        return "method" /* memberFunctionElement */;
+      case 303 /* PropertyAssignment */:
+        const { initializer } = node;
+        return isFunctionLike(initializer) ? "method" /* memberFunctionElement */ : "property" /* memberVariableElement */;
+      case 172 /* PropertyDeclaration */:
+      case 171 /* PropertySignature */:
+      case 304 /* ShorthandPropertyAssignment */:
+      case 305 /* SpreadAssignment */:
+        return "property" /* memberVariableElement */;
+      case 181 /* IndexSignature */:
+        return "index" /* indexSignatureElement */;
+      case 180 /* ConstructSignature */:
+        return "construct" /* constructSignatureElement */;
+      case 179 /* CallSignature */:
+        return "call" /* callSignatureElement */;
+      case 176 /* Constructor */:
+      case 175 /* ClassStaticBlockDeclaration */:
+        return "constructor" /* constructorImplementationElement */;
+      case 168 /* TypeParameter */:
+        return "type parameter" /* typeParameterElement */;
+      case 306 /* EnumMember */:
+        return "enum member" /* enumMemberElement */;
+      case 169 /* Parameter */:
+        return hasSyntacticModifier(node, 31 /* ParameterPropertyModifier */) ? "property" /* memberVariableElement */ : "parameter" /* parameterElement */;
+      case 271 /* ImportEqualsDeclaration */:
+      case 276 /* ImportSpecifier */:
+      case 281 /* ExportSpecifier */:
+      case 274 /* NamespaceImport */:
+      case 280 /* NamespaceExport */:
+        return "alias" /* alias */;
+      case 226 /* BinaryExpression */:
+        const kind = getAssignmentDeclarationKind(node);
+        const { right } = node;
+        switch (kind) {
+          case 7 /* ObjectDefinePropertyValue */:
+          case 8 /* ObjectDefinePropertyExports */:
+          case 9 /* ObjectDefinePrototypeProperty */:
+          case 0 /* None */:
+            return "" /* unknown */;
+          case 1 /* ExportsProperty */:
+          case 2 /* ModuleExports */:
+            const rightKind = getNodeKind(right);
+            return rightKind === "" /* unknown */ ? "const" /* constElement */ : rightKind;
+          case 3 /* PrototypeProperty */:
+            return isFunctionExpression(right) ? "method" /* memberFunctionElement */ : "property" /* memberVariableElement */;
+          case 4 /* ThisProperty */:
+            return "property" /* memberVariableElement */;
+          case 5 /* Property */:
+            return isFunctionExpression(right) ? "method" /* memberFunctionElement */ : "property" /* memberVariableElement */;
+          case 6 /* Prototype */:
+            return "local class" /* localClassElement */;
+          default: {
+            assertType(kind);
+            return "" /* unknown */;
+          }
         }
-      }
-      if (inputTime > newestInputFileTime) {
-        newestInputFileName = inputFile;
-        newestInputFileTime = inputTime;
-      }
-      if (buildInfoProgram)
-        seenRoots.add(toPath2(state, inputFile));
+      case 80 /* Identifier */:
+        return isImportClause(node.parent) ? "alias" /* alias */ : "" /* unknown */;
+      case 277 /* ExportAssignment */:
+        const scriptKind = getNodeKind(node.expression);
+        return scriptKind === "" /* unknown */ ? "const" /* constElement */ : scriptKind;
+      default:
+        return "" /* unknown */;
     }
-    if (buildInfoProgram) {
-      if (!buildInfoVersionMap)
-        buildInfoVersionMap = getBuildInfoFileVersionMap(buildInfoProgram, buildInfoPath, host);
-      for (const existingRoot of buildInfoVersionMap.roots) {
-        if (!seenRoots.has(existingRoot)) {
-          return {
-            type: 10 /* OutOfDateRoots */,
-            buildInfoFile: buildInfoPath,
-            inputFile: existingRoot
-          };
-        }
-      }
+    function getKindOfVariableDeclaration(v) {
+      return isVarConst(v) ? "const" /* constElement */ : isLet(v) ? "let" /* letElement */ : "var" /* variableElement */;
     }
-    if (!buildInfoPath) {
-      const outputs = getAllProjectOutputs(project, !host.useCaseSensitiveFileNames());
-      const outputTimeStampMap = getOutputTimeStampMap(state, resolvedPath);
-      for (const output of outputs) {
-        const path = toPath2(state, output);
-        let outputTime = outputTimeStampMap == null ? void 0 : outputTimeStampMap.get(path);
-        if (!outputTime) {
-          outputTime = getModifiedTime(state.host, output);
-          outputTimeStampMap == null ? void 0 : outputTimeStampMap.set(path, outputTime);
-        }
-        if (outputTime === missingFileModifiedTime) {
-          return {
-            type: 4 /* OutputMissing */,
-            missingOutputFileName: output
-          };
-        }
-        if (outputTime < newestInputFileTime) {
-          return {
-            type: 6 /* OutOfDateWithSelf */,
-            outOfDateOutputFileName: output,
-            newerInputFileName: newestInputFileName
-          };
+  }
+  function isThis(node) {
+    switch (node.kind) {
+      case 110 /* ThisKeyword */:
+        return true;
+      case 80 /* Identifier */:
+        return identifierIsThisKeyword(node) && node.parent.kind === 169 /* Parameter */;
+      default:
+        return false;
+    }
+  }
+  function getLineStartPositionForPosition(position, sourceFile) {
+    const lineStarts = getLineStarts(sourceFile);
+    const line = sourceFile.getLineAndCharacterOfPosition(position).line;
+    return lineStarts[line];
+  }
+  function rangeContainsRange(r1, r2) {
+    return startEndContainsRange(r1.pos, r1.end, r2);
+  }
+  function rangeContainsRangeExclusive(r1, r2) {
+    return rangeContainsPositionExclusive(r1, r2.pos) && rangeContainsPositionExclusive(r1, r2.end);
+  }
+  function rangeContainsPosition(r, pos) {
+    return r.pos <= pos && pos <= r.end;
+  }
+  function rangeContainsPositionExclusive(r, pos) {
+    return r.pos < pos && pos < r.end;
+  }
+  function startEndContainsRange(start, end, range) {
+    return start <= range.pos && end >= range.end;
+  }
+  function rangeContainsStartEnd(range, start, end) {
+    return range.pos <= start && range.end >= end;
+  }
+  function rangeOverlapsWithStartEnd(r1, start, end) {
+    return startEndOverlapsWithStartEnd(r1.pos, r1.end, start, end);
+  }
+  function nodeOverlapsWithStartEnd(node, sourceFile, start, end) {
+    return startEndOverlapsWithStartEnd(node.getStart(sourceFile), node.end, start, end);
+  }
+  function startEndOverlapsWithStartEnd(start1, end1, start2, end2) {
+    const start = Math.max(start1, start2);
+    const end = Math.min(end1, end2);
+    return start < end;
+  }
+  function positionBelongsToNode(candidate, position, sourceFile) {
+    Debug.assert(candidate.pos <= position);
+    return position < candidate.end || !isCompletedNode(candidate, sourceFile);
+  }
+  function isCompletedNode(n, sourceFile) {
+    if (n === void 0 || nodeIsMissing(n)) {
+      return false;
+    }
+    switch (n.kind) {
+      case 263 /* ClassDeclaration */:
+      case 264 /* InterfaceDeclaration */:
+      case 266 /* EnumDeclaration */:
+      case 210 /* ObjectLiteralExpression */:
+      case 206 /* ObjectBindingPattern */:
+      case 187 /* TypeLiteral */:
+      case 241 /* Block */:
+      case 268 /* ModuleBlock */:
+      case 269 /* CaseBlock */:
+      case 275 /* NamedImports */:
+      case 279 /* NamedExports */:
+        return nodeEndsWith(n, 20 /* CloseBraceToken */, sourceFile);
+      case 299 /* CatchClause */:
+        return isCompletedNode(n.block, sourceFile);
+      case 214 /* NewExpression */:
+        if (!n.arguments) {
+          return true;
         }
-        if (outputTime < oldestOutputFileTime) {
-          oldestOutputFileTime = outputTime;
-          oldestOutputFileName = output;
+      case 213 /* CallExpression */:
+      case 217 /* ParenthesizedExpression */:
+      case 196 /* ParenthesizedType */:
+        return nodeEndsWith(n, 22 /* CloseParenToken */, sourceFile);
+      case 184 /* FunctionType */:
+      case 185 /* ConstructorType */:
+        return isCompletedNode(n.type, sourceFile);
+      case 176 /* Constructor */:
+      case 177 /* GetAccessor */:
+      case 178 /* SetAccessor */:
+      case 262 /* FunctionDeclaration */:
+      case 218 /* FunctionExpression */:
+      case 174 /* MethodDeclaration */:
+      case 173 /* MethodSignature */:
+      case 180 /* ConstructSignature */:
+      case 179 /* CallSignature */:
+      case 219 /* ArrowFunction */:
+        if (n.body) {
+          return isCompletedNode(n.body, sourceFile);
         }
-      }
-    }
-    const buildInfoCacheEntry = state.buildInfoCache.get(resolvedPath);
-    let pseudoUpToDate = false;
-    let usesPrepend = false;
-    let upstreamChangedProject;
-    if (referenceStatuses) {
-      for (const { ref, refStatus, resolvedConfig, resolvedRefPath } of referenceStatuses) {
-        usesPrepend = usesPrepend || !!ref.prepend;
-        if (refStatus.newestInputFileTime && refStatus.newestInputFileTime <= oldestOutputFileTime) {
-          continue;
+        if (n.type) {
+          return isCompletedNode(n.type, sourceFile);
         }
-        if (buildInfoCacheEntry && hasSameBuildInfo(state, buildInfoCacheEntry, resolvedRefPath)) {
-          return {
-            type: 7 /* OutOfDateWithUpstream */,
-            outOfDateOutputFileName: buildInfoPath,
-            newerProjectName: ref.path
-          };
+        return hasChildOfKind(n, 22 /* CloseParenToken */, sourceFile);
+      case 267 /* ModuleDeclaration */:
+        return !!n.body && isCompletedNode(n.body, sourceFile);
+      case 245 /* IfStatement */:
+        if (n.elseStatement) {
+          return isCompletedNode(n.elseStatement, sourceFile);
         }
-        const newestDeclarationFileContentChangedTime = getLatestChangedDtsTime(state, resolvedConfig.options, resolvedRefPath);
-        if (newestDeclarationFileContentChangedTime && newestDeclarationFileContentChangedTime <= oldestOutputFileTime) {
-          pseudoUpToDate = true;
-          upstreamChangedProject = ref.path;
-          continue;
+        return isCompletedNode(n.thenStatement, sourceFile);
+      case 244 /* ExpressionStatement */:
+        return isCompletedNode(n.expression, sourceFile) || hasChildOfKind(n, 27 /* SemicolonToken */, sourceFile);
+      case 209 /* ArrayLiteralExpression */:
+      case 207 /* ArrayBindingPattern */:
+      case 212 /* ElementAccessExpression */:
+      case 167 /* ComputedPropertyName */:
+      case 189 /* TupleType */:
+        return nodeEndsWith(n, 24 /* CloseBracketToken */, sourceFile);
+      case 181 /* IndexSignature */:
+        if (n.type) {
+          return isCompletedNode(n.type, sourceFile);
         }
-        Debug.assert(oldestOutputFileName !== void 0, "Should have an oldest output filename here");
-        return {
-          type: 7 /* OutOfDateWithUpstream */,
-          outOfDateOutputFileName: oldestOutputFileName,
-          newerProjectName: ref.path
-        };
-      }
-    }
-    const configStatus = checkConfigFileUpToDateStatus(state, project.options.configFilePath, oldestOutputFileTime, oldestOutputFileName);
-    if (configStatus)
-      return configStatus;
-    const extendedConfigStatus = forEach(project.options.configFile.extendedSourceFiles || emptyArray, (configFile) => checkConfigFileUpToDateStatus(state, configFile, oldestOutputFileTime, oldestOutputFileName));
-    if (extendedConfigStatus)
-      return extendedConfigStatus;
-    const dependentPackageFileStatus = forEach(
-      state.lastCachedPackageJsonLookups.get(resolvedPath) || emptyArray,
-      ([path]) => checkConfigFileUpToDateStatus(state, path, oldestOutputFileTime, oldestOutputFileName)
-    );
-    if (dependentPackageFileStatus)
-      return dependentPackageFileStatus;
-    if (usesPrepend && pseudoUpToDate) {
-      return {
-        type: 3 /* OutOfDateWithPrepend */,
-        outOfDateOutputFileName: oldestOutputFileName,
-        newerProjectName: upstreamChangedProject
-      };
+        return hasChildOfKind(n, 24 /* CloseBracketToken */, sourceFile);
+      case 296 /* CaseClause */:
+      case 297 /* DefaultClause */:
+        return false;
+      case 248 /* ForStatement */:
+      case 249 /* ForInStatement */:
+      case 250 /* ForOfStatement */:
+      case 247 /* WhileStatement */:
+        return isCompletedNode(n.statement, sourceFile);
+      case 246 /* DoStatement */:
+        return hasChildOfKind(n, 117 /* WhileKeyword */, sourceFile) ? nodeEndsWith(n, 22 /* CloseParenToken */, sourceFile) : isCompletedNode(n.statement, sourceFile);
+      case 186 /* TypeQuery */:
+        return isCompletedNode(n.exprName, sourceFile);
+      case 221 /* TypeOfExpression */:
+      case 220 /* DeleteExpression */:
+      case 222 /* VoidExpression */:
+      case 229 /* YieldExpression */:
+      case 230 /* SpreadElement */:
+        const unaryWordExpression = n;
+        return isCompletedNode(unaryWordExpression.expression, sourceFile);
+      case 215 /* TaggedTemplateExpression */:
+        return isCompletedNode(n.template, sourceFile);
+      case 228 /* TemplateExpression */:
+        const lastSpan = lastOrUndefined(n.templateSpans);
+        return isCompletedNode(lastSpan, sourceFile);
+      case 239 /* TemplateSpan */:
+        return nodeIsPresent(n.literal);
+      case 278 /* ExportDeclaration */:
+      case 272 /* ImportDeclaration */:
+        return nodeIsPresent(n.moduleSpecifier);
+      case 224 /* PrefixUnaryExpression */:
+        return isCompletedNode(n.operand, sourceFile);
+      case 226 /* BinaryExpression */:
+        return isCompletedNode(n.right, sourceFile);
+      case 227 /* ConditionalExpression */:
+        return isCompletedNode(n.whenFalse, sourceFile);
+      default:
+        return true;
+    }
+  }
+  function nodeEndsWith(n, expectedLastToken, sourceFile) {
+    const children = n.getChildren(sourceFile);
+    if (children.length) {
+      const lastChild = last(children);
+      if (lastChild.kind === expectedLastToken) {
+        return true;
+      } else if (lastChild.kind === 27 /* SemicolonToken */ && children.length !== 1) {
+        return children[children.length - 2].kind === expectedLastToken;
+      }
+    }
+    return false;
+  }
+  function findListItemInfo(node) {
+    const list = findContainingList(node);
+    if (!list) {
+      return void 0;
     }
+    const children = list.getChildren();
+    const listItemIndex = indexOfNode(children, node);
     return {
-      type: pseudoUpToDate ? 2 /* UpToDateWithUpstreamTypes */ : pseudoInputUpToDate ? 15 /* UpToDateWithInputFileText */ : 1 /* UpToDate */,
-      newestInputFileTime,
-      newestInputFileName,
-      oldestOutputFileName
+      listItemIndex,
+      list
     };
   }
-  function hasSameBuildInfo(state, buildInfoCacheEntry, resolvedRefPath) {
-    const refBuildInfo = state.buildInfoCache.get(resolvedRefPath);
-    return refBuildInfo.path === buildInfoCacheEntry.path;
+  function hasChildOfKind(n, kind, sourceFile) {
+    return !!findChildOfKind(n, kind, sourceFile);
   }
-  function getUpToDateStatus(state, project, resolvedPath) {
-    if (project === void 0) {
-      return { type: 0 /* Unbuildable */, reason: "File deleted mid-build" };
+  function findChildOfKind(n, kind, sourceFile) {
+    return find(n.getChildren(sourceFile), (c) => c.kind === kind);
+  }
+  function findContainingList(node) {
+    const syntaxList = find(node.parent.getChildren(), (c) => isSyntaxList(c) && rangeContainsRange(c, node));
+    Debug.assert(!syntaxList || contains(syntaxList.getChildren(), node));
+    return syntaxList;
+  }
+  function isDefaultModifier2(node) {
+    return node.kind === 90 /* DefaultKeyword */;
+  }
+  function isClassKeyword(node) {
+    return node.kind === 86 /* ClassKeyword */;
+  }
+  function isFunctionKeyword(node) {
+    return node.kind === 100 /* FunctionKeyword */;
+  }
+  function getAdjustedLocationForClass(node) {
+    if (isNamedDeclaration(node)) {
+      return node.name;
     }
-    const prior = state.projectStatus.get(resolvedPath);
-    if (prior !== void 0) {
-      return prior;
+    if (isClassDeclaration(node)) {
+      const defaultModifier = node.modifiers && find(node.modifiers, isDefaultModifier2);
+      if (defaultModifier)
+        return defaultModifier;
+    }
+    if (isClassExpression(node)) {
+      const classKeyword = find(node.getChildren(), isClassKeyword);
+      if (classKeyword)
+        return classKeyword;
     }
-    mark("SolutionBuilder::beforeUpToDateCheck");
-    const actual = getUpToDateStatusWorker(state, project, resolvedPath);
-    mark("SolutionBuilder::afterUpToDateCheck");
-    measure("SolutionBuilder::Up-to-date check", "SolutionBuilder::beforeUpToDateCheck", "SolutionBuilder::afterUpToDateCheck");
-    state.projectStatus.set(resolvedPath, actual);
-    return actual;
   }
-  function updateOutputTimestampsWorker(state, proj, projectPath, verboseMessage, skipOutputs) {
-    if (proj.options.noEmit)
-      return;
-    let now;
-    const buildInfoPath = getTsBuildInfoEmitOutputFilePath(proj.options);
-    if (buildInfoPath) {
-      if (!(skipOutputs == null ? void 0 : skipOutputs.has(toPath2(state, buildInfoPath)))) {
-        if (!!state.options.verbose)
-          reportStatus(state, verboseMessage, proj.options.configFilePath);
-        state.host.setModifiedTime(buildInfoPath, now = getCurrentTime(state.host));
-        getBuildInfoCacheEntry(state, buildInfoPath, projectPath).modifiedTime = now;
-      }
-      state.outputTimeStamps.delete(projectPath);
-      return;
+  function getAdjustedLocationForFunction(node) {
+    if (isNamedDeclaration(node)) {
+      return node.name;
     }
-    const { host } = state;
-    const outputs = getAllProjectOutputs(proj, !host.useCaseSensitiveFileNames());
-    const outputTimeStampMap = getOutputTimeStampMap(state, projectPath);
-    const modifiedOutputs = outputTimeStampMap ? /* @__PURE__ */ new Set() : void 0;
-    if (!skipOutputs || outputs.length !== skipOutputs.size) {
-      let reportVerbose = !!state.options.verbose;
-      for (const file of outputs) {
-        const path = toPath2(state, file);
-        if (skipOutputs == null ? void 0 : skipOutputs.has(path))
-          continue;
-        if (reportVerbose) {
-          reportVerbose = false;
-          reportStatus(state, verboseMessage, proj.options.configFilePath);
-        }
-        host.setModifiedTime(file, now || (now = getCurrentTime(state.host)));
-        if (outputTimeStampMap) {
-          outputTimeStampMap.set(path, now);
-          modifiedOutputs.add(path);
-        }
-      }
+    if (isFunctionDeclaration(node)) {
+      const defaultModifier = find(node.modifiers, isDefaultModifier2);
+      if (defaultModifier)
+        return defaultModifier;
     }
-    outputTimeStampMap == null ? void 0 : outputTimeStampMap.forEach((_value, key) => {
-      if (!(skipOutputs == null ? void 0 : skipOutputs.has(key)) && !modifiedOutputs.has(key))
-        outputTimeStampMap.delete(key);
+    if (isFunctionExpression(node)) {
+      const functionKeyword = find(node.getChildren(), isFunctionKeyword);
+      if (functionKeyword)
+        return functionKeyword;
+    }
+  }
+  function getAncestorTypeNode(node) {
+    let lastTypeNode;
+    findAncestor(node, (a) => {
+      if (isTypeNode(a)) {
+        lastTypeNode = a;
+      }
+      return !isQualifiedName(a.parent) && !isTypeNode(a.parent) && !isTypeElement(a.parent);
     });
+    return lastTypeNode;
   }
-  function getLatestChangedDtsTime(state, options, resolvedConfigPath) {
-    if (!options.composite)
+  function getContextualTypeFromParentOrAncestorTypeNode(node, checker) {
+    if (node.flags & (16777216 /* JSDoc */ & ~524288 /* JavaScriptFile */))
       return void 0;
-    const entry = Debug.checkDefined(state.buildInfoCache.get(resolvedConfigPath));
-    if (entry.latestChangedDtsTime !== void 0)
-      return entry.latestChangedDtsTime || void 0;
-    const latestChangedDtsTime = entry.buildInfo && entry.buildInfo.program && entry.buildInfo.program.latestChangedDtsFile ? state.host.getModifiedTime(getNormalizedAbsolutePath(entry.buildInfo.program.latestChangedDtsFile, getDirectoryPath(entry.path))) : void 0;
-    entry.latestChangedDtsTime = latestChangedDtsTime || false;
-    return latestChangedDtsTime;
+    const contextualType = getContextualTypeFromParent(node, checker);
+    if (contextualType)
+      return contextualType;
+    const ancestorTypeNode = getAncestorTypeNode(node);
+    return ancestorTypeNode && checker.getTypeAtLocation(ancestorTypeNode);
   }
-  function updateOutputTimestamps(state, proj, resolvedPath) {
-    if (state.options.dry) {
-      return reportStatus(state, Diagnostics.A_non_dry_build_would_update_timestamps_for_output_of_project_0, proj.options.configFilePath);
+  function getAdjustedLocationForDeclaration(node, forRename) {
+    if (!forRename) {
+      switch (node.kind) {
+        case 263 /* ClassDeclaration */:
+        case 231 /* ClassExpression */:
+          return getAdjustedLocationForClass(node);
+        case 262 /* FunctionDeclaration */:
+        case 218 /* FunctionExpression */:
+          return getAdjustedLocationForFunction(node);
+        case 176 /* Constructor */:
+          return node;
+      }
+    }
+    if (isNamedDeclaration(node)) {
+      return node.name;
     }
-    updateOutputTimestampsWorker(state, proj, resolvedPath, Diagnostics.Updating_output_timestamps_of_project_0);
-    state.projectStatus.set(resolvedPath, {
-      type: 1 /* UpToDate */,
-      oldestOutputFileName: getFirstProjectOutput(proj, !state.host.useCaseSensitiveFileNames())
-    });
   }
-  function queueReferencingProjects(state, project, projectPath, projectIndex, config, buildOrder, buildResult) {
-    if (buildResult & 124 /* AnyErrors */)
-      return;
-    if (!config.options.composite)
-      return;
-    for (let index = projectIndex + 1; index < buildOrder.length; index++) {
-      const nextProject = buildOrder[index];
-      const nextProjectPath = toResolvedConfigFilePath(state, nextProject);
-      if (state.projectPendingBuild.has(nextProjectPath))
-        continue;
-      const nextProjectConfig = parseConfigFile(state, nextProject, nextProjectPath);
-      if (!nextProjectConfig || !nextProjectConfig.projectReferences)
-        continue;
-      for (const ref of nextProjectConfig.projectReferences) {
-        const resolvedRefPath = resolveProjectName(state, ref.path);
-        if (toResolvedConfigFilePath(state, resolvedRefPath) !== projectPath)
-          continue;
-        const status = state.projectStatus.get(nextProjectPath);
-        if (status) {
-          switch (status.type) {
-            case 1 /* UpToDate */:
-              if (buildResult & 2 /* DeclarationOutputUnchanged */) {
-                if (ref.prepend) {
-                  state.projectStatus.set(nextProjectPath, {
-                    type: 3 /* OutOfDateWithPrepend */,
-                    outOfDateOutputFileName: status.oldestOutputFileName,
-                    newerProjectName: project
-                  });
-                } else {
-                  status.type = 2 /* UpToDateWithUpstreamTypes */;
-                }
-                break;
-              }
-            case 15 /* UpToDateWithInputFileText */:
-            case 2 /* UpToDateWithUpstreamTypes */:
-            case 3 /* OutOfDateWithPrepend */:
-              if (!(buildResult & 2 /* DeclarationOutputUnchanged */)) {
-                state.projectStatus.set(nextProjectPath, {
-                  type: 7 /* OutOfDateWithUpstream */,
-                  outOfDateOutputFileName: status.type === 3 /* OutOfDateWithPrepend */ ? status.outOfDateOutputFileName : status.oldestOutputFileName,
-                  newerProjectName: project
-                });
-              }
-              break;
-            case 12 /* UpstreamBlocked */:
-              if (toResolvedConfigFilePath(state, resolveProjectName(state, status.upstreamProjectName)) === projectPath) {
-                clearProjectStatus(state, nextProjectPath);
-              }
-              break;
+  function getAdjustedLocationForImportDeclaration(node, forRename) {
+    if (node.importClause) {
+      if (node.importClause.name && node.importClause.namedBindings) {
+        return;
+      }
+      if (node.importClause.name) {
+        return node.importClause.name;
+      }
+      if (node.importClause.namedBindings) {
+        if (isNamedImports(node.importClause.namedBindings)) {
+          const onlyBinding = singleOrUndefined(node.importClause.namedBindings.elements);
+          if (!onlyBinding) {
+            return;
           }
+          return onlyBinding.name;
+        } else if (isNamespaceImport(node.importClause.namedBindings)) {
+          return node.importClause.namedBindings.name;
         }
-        addProjToQueue(state, nextProjectPath, 0 /* None */);
-        break;
       }
     }
+    if (!forRename) {
+      return node.moduleSpecifier;
+    }
   }
-  function build(state, project, cancellationToken, writeFile2, getCustomTransformers, onlyReferences) {
-    mark("SolutionBuilder::beforeBuild");
-    const result = buildWorker(state, project, cancellationToken, writeFile2, getCustomTransformers, onlyReferences);
-    mark("SolutionBuilder::afterBuild");
-    measure("SolutionBuilder::Build", "SolutionBuilder::beforeBuild", "SolutionBuilder::afterBuild");
-    return result;
-  }
-  function buildWorker(state, project, cancellationToken, writeFile2, getCustomTransformers, onlyReferences) {
-    const buildOrder = getBuildOrderFor(state, project, onlyReferences);
-    if (!buildOrder)
-      return 3 /* InvalidProject_OutputsSkipped */;
-    setupInitialBuild(state, cancellationToken);
-    let reportQueue = true;
-    let successfulProjects = 0;
-    while (true) {
-      const invalidatedProject = getNextInvalidatedProject(state, buildOrder, reportQueue);
-      if (!invalidatedProject)
-        break;
-      reportQueue = false;
-      invalidatedProject.done(cancellationToken, writeFile2, getCustomTransformers == null ? void 0 : getCustomTransformers(invalidatedProject.project));
-      if (!state.diagnostics.has(invalidatedProject.projectPath))
-        successfulProjects++;
+  function getAdjustedLocationForExportDeclaration(node, forRename) {
+    if (node.exportClause) {
+      if (isNamedExports(node.exportClause)) {
+        const onlyBinding = singleOrUndefined(node.exportClause.elements);
+        if (!onlyBinding) {
+          return;
+        }
+        return node.exportClause.elements[0].name;
+      } else if (isNamespaceExport(node.exportClause)) {
+        return node.exportClause.name;
+      }
+    }
+    if (!forRename) {
+      return node.moduleSpecifier;
     }
-    disableCache(state);
-    reportErrorSummary(state, buildOrder);
-    startWatching(state, buildOrder);
-    return isCircularBuildOrder(buildOrder) ? 4 /* ProjectReferenceCycle_OutputsSkipped */ : !buildOrder.some((p) => state.diagnostics.has(toResolvedConfigFilePath(state, p))) ? 0 /* Success */ : successfulProjects ? 2 /* DiagnosticsPresent_OutputsGenerated */ : 1 /* DiagnosticsPresent_OutputsSkipped */;
   }
-  function clean(state, project, onlyReferences) {
-    mark("SolutionBuilder::beforeClean");
-    const result = cleanWorker(state, project, onlyReferences);
-    mark("SolutionBuilder::afterClean");
-    measure("SolutionBuilder::Clean", "SolutionBuilder::beforeClean", "SolutionBuilder::afterClean");
-    return result;
+  function getAdjustedLocationForHeritageClause(node) {
+    if (node.types.length === 1) {
+      return node.types[0].expression;
+    }
   }
-  function cleanWorker(state, project, onlyReferences) {
-    const buildOrder = getBuildOrderFor(state, project, onlyReferences);
-    if (!buildOrder)
-      return 3 /* InvalidProject_OutputsSkipped */;
-    if (isCircularBuildOrder(buildOrder)) {
-      reportErrors(state, buildOrder.circularDiagnostics);
-      return 4 /* ProjectReferenceCycle_OutputsSkipped */;
+  function getAdjustedLocation(node, forRename) {
+    const { parent: parent2 } = node;
+    if (isModifier(node) && (forRename || node.kind !== 90 /* DefaultKeyword */) ? canHaveModifiers(parent2) && contains(parent2.modifiers, node) : node.kind === 86 /* ClassKeyword */ ? isClassDeclaration(parent2) || isClassExpression(node) : node.kind === 100 /* FunctionKeyword */ ? isFunctionDeclaration(parent2) || isFunctionExpression(node) : node.kind === 120 /* InterfaceKeyword */ ? isInterfaceDeclaration(parent2) : node.kind === 94 /* EnumKeyword */ ? isEnumDeclaration(parent2) : node.kind === 156 /* TypeKeyword */ ? isTypeAliasDeclaration(parent2) : node.kind === 145 /* NamespaceKeyword */ || node.kind === 144 /* ModuleKeyword */ ? isModuleDeclaration(parent2) : node.kind === 102 /* ImportKeyword */ ? isImportEqualsDeclaration(parent2) : node.kind === 139 /* GetKeyword */ ? isGetAccessorDeclaration(parent2) : node.kind === 153 /* SetKeyword */ && isSetAccessorDeclaration(parent2)) {
+      const location = getAdjustedLocationForDeclaration(parent2, forRename);
+      if (location) {
+        return location;
+      }
     }
-    const { options, host } = state;
-    const filesToDelete = options.dry ? [] : void 0;
-    for (const proj of buildOrder) {
-      const resolvedPath = toResolvedConfigFilePath(state, proj);
-      const parsed = parseConfigFile(state, proj, resolvedPath);
-      if (parsed === void 0) {
-        reportParseConfigFileDiagnostic(state, resolvedPath);
-        continue;
+    if ((node.kind === 115 /* VarKeyword */ || node.kind === 87 /* ConstKeyword */ || node.kind === 121 /* LetKeyword */) && isVariableDeclarationList(parent2) && parent2.declarations.length === 1) {
+      const decl = parent2.declarations[0];
+      if (isIdentifier(decl.name)) {
+        return decl.name;
       }
-      const outputs = getAllProjectOutputs(parsed, !host.useCaseSensitiveFileNames());
-      if (!outputs.length)
-        continue;
-      const inputFileNames = new Set(parsed.fileNames.map((f) => toPath2(state, f)));
-      for (const output of outputs) {
-        if (inputFileNames.has(toPath2(state, output)))
-          continue;
-        if (host.fileExists(output)) {
-          if (filesToDelete) {
-            filesToDelete.push(output);
-          } else {
-            host.deleteFile(output);
-            invalidateProject(state, resolvedPath, 0 /* None */);
-          }
+    }
+    if (node.kind === 156 /* TypeKeyword */) {
+      if (isImportClause(parent2) && parent2.isTypeOnly) {
+        const location = getAdjustedLocationForImportDeclaration(parent2.parent, forRename);
+        if (location) {
+          return location;
+        }
+      }
+      if (isExportDeclaration(parent2) && parent2.isTypeOnly) {
+        const location = getAdjustedLocationForExportDeclaration(parent2, forRename);
+        if (location) {
+          return location;
         }
       }
     }
-    if (filesToDelete) {
-      reportStatus(state, Diagnostics.A_non_dry_build_would_delete_the_following_files_Colon_0, filesToDelete.map((f) => `\r
- * ${f}`).join(""));
+    if (node.kind === 130 /* AsKeyword */) {
+      if (isImportSpecifier(parent2) && parent2.propertyName || isExportSpecifier(parent2) && parent2.propertyName || isNamespaceImport(parent2) || isNamespaceExport(parent2)) {
+        return parent2.name;
+      }
+      if (isExportDeclaration(parent2) && parent2.exportClause && isNamespaceExport(parent2.exportClause)) {
+        return parent2.exportClause.name;
+      }
     }
-    return 0 /* Success */;
-  }
-  function invalidateProject(state, resolved, reloadLevel) {
-    if (state.host.getParsedCommandLine && reloadLevel === 1 /* Partial */) {
-      reloadLevel = 2 /* Full */;
+    if (node.kind === 102 /* ImportKeyword */ && isImportDeclaration(parent2)) {
+      const location = getAdjustedLocationForImportDeclaration(parent2, forRename);
+      if (location) {
+        return location;
+      }
     }
-    if (reloadLevel === 2 /* Full */) {
-      state.configFileCache.delete(resolved);
-      state.buildOrder = void 0;
+    if (node.kind === 95 /* ExportKeyword */) {
+      if (isExportDeclaration(parent2)) {
+        const location = getAdjustedLocationForExportDeclaration(parent2, forRename);
+        if (location) {
+          return location;
+        }
+      }
+      if (isExportAssignment(parent2)) {
+        return skipOuterExpressions(parent2.expression);
+      }
     }
-    state.needsSummary = true;
-    clearProjectStatus(state, resolved);
-    addProjToQueue(state, resolved, reloadLevel);
-    enableCache(state);
-  }
-  function invalidateProjectAndScheduleBuilds(state, resolvedPath, reloadLevel) {
-    state.reportFileChangeDetected = true;
-    invalidateProject(state, resolvedPath, reloadLevel);
-    scheduleBuildInvalidatedProject(
-      state,
-      250,
-      /*changeDetected*/
-      true
-    );
-  }
-  function scheduleBuildInvalidatedProject(state, time, changeDetected) {
-    const { hostWithWatch } = state;
-    if (!hostWithWatch.setTimeout || !hostWithWatch.clearTimeout) {
-      return;
+    if (node.kind === 149 /* RequireKeyword */ && isExternalModuleReference(parent2)) {
+      return parent2.expression;
     }
-    if (state.timerToBuildInvalidatedProject) {
-      hostWithWatch.clearTimeout(state.timerToBuildInvalidatedProject);
+    if (node.kind === 161 /* FromKeyword */ && (isImportDeclaration(parent2) || isExportDeclaration(parent2)) && parent2.moduleSpecifier) {
+      return parent2.moduleSpecifier;
     }
-    state.timerToBuildInvalidatedProject = hostWithWatch.setTimeout(buildNextInvalidatedProject, time, "timerToBuildInvalidatedProject", state, changeDetected);
-  }
-  function buildNextInvalidatedProject(_timeoutType, state, changeDetected) {
-    mark("SolutionBuilder::beforeBuild");
-    const buildOrder = buildNextInvalidatedProjectWorker(state, changeDetected);
-    mark("SolutionBuilder::afterBuild");
-    measure("SolutionBuilder::Build", "SolutionBuilder::beforeBuild", "SolutionBuilder::afterBuild");
-    if (buildOrder)
-      reportErrorSummary(state, buildOrder);
-  }
-  function buildNextInvalidatedProjectWorker(state, changeDetected) {
-    state.timerToBuildInvalidatedProject = void 0;
-    if (state.reportFileChangeDetected) {
-      state.reportFileChangeDetected = false;
-      state.projectErrorsReported.clear();
-      reportWatchStatus(state, Diagnostics.File_change_detected_Starting_incremental_compilation);
+    if ((node.kind === 96 /* ExtendsKeyword */ || node.kind === 119 /* ImplementsKeyword */) && isHeritageClause(parent2) && parent2.token === node.kind) {
+      const location = getAdjustedLocationForHeritageClause(parent2);
+      if (location) {
+        return location;
+      }
     }
-    let projectsBuilt = 0;
-    const buildOrder = getBuildOrder(state);
-    const invalidatedProject = getNextInvalidatedProject(
-      state,
-      buildOrder,
-      /*reportQueue*/
-      false
-    );
-    if (invalidatedProject) {
-      invalidatedProject.done();
-      projectsBuilt++;
-      while (state.projectPendingBuild.size) {
-        if (state.timerToBuildInvalidatedProject)
-          return;
-        const info = getNextInvalidatedProjectCreateInfo(
-          state,
-          buildOrder,
-          /*reportQueue*/
-          false
-        );
-        if (!info)
-          break;
-        if (info.kind !== 2 /* UpdateOutputFileStamps */ && (changeDetected || projectsBuilt === 5)) {
-          scheduleBuildInvalidatedProject(
-            state,
-            100,
-            /*changeDetected*/
-            false
-          );
-          return;
+    if (node.kind === 96 /* ExtendsKeyword */) {
+      if (isTypeParameterDeclaration(parent2) && parent2.constraint && isTypeReferenceNode(parent2.constraint)) {
+        return parent2.constraint.typeName;
+      }
+      if (isConditionalTypeNode(parent2) && isTypeReferenceNode(parent2.extendsType)) {
+        return parent2.extendsType.typeName;
+      }
+    }
+    if (node.kind === 140 /* InferKeyword */ && isInferTypeNode(parent2)) {
+      return parent2.typeParameter.name;
+    }
+    if (node.kind === 103 /* InKeyword */ && isTypeParameterDeclaration(parent2) && isMappedTypeNode(parent2.parent)) {
+      return parent2.name;
+    }
+    if (node.kind === 143 /* KeyOfKeyword */ && isTypeOperatorNode(parent2) && parent2.operator === 143 /* KeyOfKeyword */ && isTypeReferenceNode(parent2.type)) {
+      return parent2.type.typeName;
+    }
+    if (node.kind === 148 /* ReadonlyKeyword */ && isTypeOperatorNode(parent2) && parent2.operator === 148 /* ReadonlyKeyword */ && isArrayTypeNode(parent2.type) && isTypeReferenceNode(parent2.type.elementType)) {
+      return parent2.type.elementType.typeName;
+    }
+    if (!forRename) {
+      if (node.kind === 105 /* NewKeyword */ && isNewExpression(parent2) || node.kind === 116 /* VoidKeyword */ && isVoidExpression(parent2) || node.kind === 114 /* TypeOfKeyword */ && isTypeOfExpression(parent2) || node.kind === 135 /* AwaitKeyword */ && isAwaitExpression(parent2) || node.kind === 127 /* YieldKeyword */ && isYieldExpression(parent2) || node.kind === 91 /* DeleteKeyword */ && isDeleteExpression(parent2)) {
+        if (parent2.expression) {
+          return skipOuterExpressions(parent2.expression);
         }
-        const project = createInvalidatedProjectWithInfo(state, info, buildOrder);
-        project.done();
-        if (info.kind !== 2 /* UpdateOutputFileStamps */)
-          projectsBuilt++;
+      }
+      if ((node.kind === 103 /* InKeyword */ || node.kind === 104 /* InstanceOfKeyword */) && isBinaryExpression(parent2) && parent2.operatorToken === node) {
+        return skipOuterExpressions(parent2.right);
+      }
+      if (node.kind === 130 /* AsKeyword */ && isAsExpression(parent2) && isTypeReferenceNode(parent2.type)) {
+        return parent2.type.typeName;
+      }
+      if (node.kind === 103 /* InKeyword */ && isForInStatement(parent2) || node.kind === 165 /* OfKeyword */ && isForOfStatement(parent2)) {
+        return skipOuterExpressions(parent2.expression);
       }
     }
-    disableCache(state);
-    return buildOrder;
-  }
-  function watchConfigFile(state, resolved, resolvedPath, parsed) {
-    if (!state.watch || state.allWatchedConfigFiles.has(resolvedPath))
-      return;
-    state.allWatchedConfigFiles.set(resolvedPath, watchFile(
-      state,
-      resolved,
-      () => invalidateProjectAndScheduleBuilds(state, resolvedPath, 2 /* Full */),
-      2e3 /* High */,
-      parsed == null ? void 0 : parsed.watchOptions,
-      WatchType.ConfigFile,
-      resolved
-    ));
+    return node;
   }
-  function watchExtendedConfigFiles(state, resolvedPath, parsed) {
-    updateSharedExtendedConfigFileWatcher(
-      resolvedPath,
-      parsed == null ? void 0 : parsed.options,
-      state.allWatchedExtendedConfigFiles,
-      (extendedConfigFileName, extendedConfigFilePath) => watchFile(
-        state,
-        extendedConfigFileName,
-        () => {
-          var _a;
-          return (_a = state.allWatchedExtendedConfigFiles.get(extendedConfigFilePath)) == null ? void 0 : _a.projects.forEach((projectConfigFilePath) => invalidateProjectAndScheduleBuilds(state, projectConfigFilePath, 2 /* Full */));
-        },
-        2e3 /* High */,
-        parsed == null ? void 0 : parsed.watchOptions,
-        WatchType.ExtendedConfigFile
-      ),
-      (fileName) => toPath2(state, fileName)
+  function getAdjustedReferenceLocation(node) {
+    return getAdjustedLocation(
+      node,
+      /*forRename*/
+      false
     );
   }
-  function watchWildCardDirectories(state, resolved, resolvedPath, parsed) {
-    if (!state.watch)
-      return;
-    updateWatchingWildcardDirectories(
-      getOrCreateValueMapFromConfigFileMap(state.allWatchedWildcardDirectories, resolvedPath),
-      new Map(Object.entries(parsed.wildcardDirectories)),
-      (dir, flags) => state.watchDirectory(
-        dir,
-        (fileOrDirectory) => {
-          var _a;
-          if (isIgnoredFileFromWildCardWatching({
-            watchedDirPath: toPath2(state, dir),
-            fileOrDirectory,
-            fileOrDirectoryPath: toPath2(state, fileOrDirectory),
-            configFileName: resolved,
-            currentDirectory: state.compilerHost.getCurrentDirectory(),
-            options: parsed.options,
-            program: state.builderPrograms.get(resolvedPath) || ((_a = getCachedParsedConfigFile(state, resolvedPath)) == null ? void 0 : _a.fileNames),
-            useCaseSensitiveFileNames: state.parseConfigFileHost.useCaseSensitiveFileNames,
-            writeLog: (s) => state.writeLog(s),
-            toPath: (fileName) => toPath2(state, fileName)
-          }))
-            return;
-          invalidateProjectAndScheduleBuilds(state, resolvedPath, 1 /* Partial */);
-        },
-        flags,
-        parsed == null ? void 0 : parsed.watchOptions,
-        WatchType.WildcardDirectory,
-        resolved
-      )
+  function getAdjustedRenameLocation(node) {
+    return getAdjustedLocation(
+      node,
+      /*forRename*/
+      true
     );
   }
-  function watchInputFiles(state, resolved, resolvedPath, parsed) {
-    if (!state.watch)
-      return;
-    mutateMap(
-      getOrCreateValueMapFromConfigFileMap(state.allWatchedInputFiles, resolvedPath),
-      arrayToMap(parsed.fileNames, (fileName) => toPath2(state, fileName)),
-      {
-        createNewValue: (_path, input) => watchFile(
-          state,
-          input,
-          () => invalidateProjectAndScheduleBuilds(state, resolvedPath, 0 /* None */),
-          250 /* Low */,
-          parsed == null ? void 0 : parsed.watchOptions,
-          WatchType.SourceFile,
-          resolved
-        ),
-        onDeleteValue: closeFileWatcher
-      }
+  function getTouchingPropertyName(sourceFile, position) {
+    return getTouchingToken(sourceFile, position, (n) => isPropertyNameLiteral(n) || isKeyword(n.kind) || isPrivateIdentifier(n));
+  }
+  function getTouchingToken(sourceFile, position, includePrecedingTokenAtEndPosition) {
+    return getTokenAtPositionWorker(
+      sourceFile,
+      position,
+      /*allowPositionInLeadingTrivia*/
+      false,
+      includePrecedingTokenAtEndPosition,
+      /*includeEndPosition*/
+      false
     );
   }
-  function watchPackageJsonFiles(state, resolved, resolvedPath, parsed) {
-    if (!state.watch || !state.lastCachedPackageJsonLookups)
-      return;
-    mutateMap(
-      getOrCreateValueMapFromConfigFileMap(state.allWatchedPackageJsonFiles, resolvedPath),
-      new Map(state.lastCachedPackageJsonLookups.get(resolvedPath)),
-      {
-        createNewValue: (path, _input) => watchFile(
-          state,
-          path,
-          () => invalidateProjectAndScheduleBuilds(state, resolvedPath, 0 /* None */),
-          2e3 /* High */,
-          parsed == null ? void 0 : parsed.watchOptions,
-          WatchType.PackageJson,
-          resolved
-        ),
-        onDeleteValue: closeFileWatcher
-      }
+  function getTokenAtPosition(sourceFile, position) {
+    return getTokenAtPositionWorker(
+      sourceFile,
+      position,
+      /*allowPositionInLeadingTrivia*/
+      true,
+      /*includePrecedingTokenAtEndPosition*/
+      void 0,
+      /*includeEndPosition*/
+      false
     );
   }
-  function startWatching(state, buildOrder) {
-    if (!state.watchAllProjectsPending)
-      return;
-    mark("SolutionBuilder::beforeWatcherCreation");
-    state.watchAllProjectsPending = false;
-    for (const resolved of getBuildOrderFromAnyBuildOrder(buildOrder)) {
-      const resolvedPath = toResolvedConfigFilePath(state, resolved);
-      const cfg = parseConfigFile(state, resolved, resolvedPath);
-      watchConfigFile(state, resolved, resolvedPath, cfg);
-      watchExtendedConfigFiles(state, resolvedPath, cfg);
-      if (cfg) {
-        watchWildCardDirectories(state, resolved, resolvedPath, cfg);
-        watchInputFiles(state, resolved, resolvedPath, cfg);
-        watchPackageJsonFiles(state, resolved, resolvedPath, cfg);
+  function getTokenAtPositionWorker(sourceFile, position, allowPositionInLeadingTrivia, includePrecedingTokenAtEndPosition, includeEndPosition) {
+    let current = sourceFile;
+    let foundToken;
+    outer:
+      while (true) {
+        const children = current.getChildren(sourceFile);
+        const i = binarySearchKey(children, position, (_, i2) => i2, (middle, _) => {
+          const end = children[middle].getEnd();
+          if (end < position) {
+            return -1 /* LessThan */;
+          }
+          const start = allowPositionInLeadingTrivia ? children[middle].getFullStart() : children[middle].getStart(
+            sourceFile,
+            /*includeJsDocComment*/
+            true
+          );
+          if (start > position) {
+            return 1 /* GreaterThan */;
+          }
+          if (nodeContainsPosition(children[middle], start, end)) {
+            if (children[middle - 1]) {
+              if (nodeContainsPosition(children[middle - 1])) {
+                return 1 /* GreaterThan */;
+              }
+            }
+            return 0 /* EqualTo */;
+          }
+          if (includePrecedingTokenAtEndPosition && start === position && children[middle - 1] && children[middle - 1].getEnd() === position && nodeContainsPosition(children[middle - 1])) {
+            return 1 /* GreaterThan */;
+          }
+          return -1 /* LessThan */;
+        });
+        if (foundToken) {
+          return foundToken;
+        }
+        if (i >= 0 && children[i]) {
+          current = children[i];
+          continue outer;
+        }
+        return current;
       }
-    }
-    mark("SolutionBuilder::afterWatcherCreation");
-    measure("SolutionBuilder::Watcher creation", "SolutionBuilder::beforeWatcherCreation", "SolutionBuilder::afterWatcherCreation");
-  }
-  function stopWatching(state) {
-    clearMap(state.allWatchedConfigFiles, closeFileWatcher);
-    clearMap(state.allWatchedExtendedConfigFiles, closeFileWatcherOf);
-    clearMap(state.allWatchedWildcardDirectories, (watchedWildcardDirectories) => clearMap(watchedWildcardDirectories, closeFileWatcherOf));
-    clearMap(state.allWatchedInputFiles, (watchedWildcardDirectories) => clearMap(watchedWildcardDirectories, closeFileWatcher));
-    clearMap(state.allWatchedPackageJsonFiles, (watchedPacageJsonFiles) => clearMap(watchedPacageJsonFiles, closeFileWatcher));
-  }
-  function createSolutionBuilderWorker(watch, hostOrHostWithWatch, rootNames, options, baseWatchOptions) {
-    const state = createSolutionBuilderState(watch, hostOrHostWithWatch, rootNames, options, baseWatchOptions);
-    return {
-      build: (project, cancellationToken, writeFile2, getCustomTransformers) => build(state, project, cancellationToken, writeFile2, getCustomTransformers),
-      clean: (project) => clean(state, project),
-      buildReferences: (project, cancellationToken, writeFile2, getCustomTransformers) => build(
-        state,
-        project,
-        cancellationToken,
-        writeFile2,
-        getCustomTransformers,
-        /*onlyReferences*/
-        true
-      ),
-      cleanReferences: (project) => clean(
-        state,
-        project,
-        /*onlyReferences*/
+    function nodeContainsPosition(node, start, end) {
+      end ?? (end = node.getEnd());
+      if (end < position) {
+        return false;
+      }
+      start ?? (start = allowPositionInLeadingTrivia ? node.getFullStart() : node.getStart(
+        sourceFile,
+        /*includeJsDocComment*/
         true
-      ),
-      getNextInvalidatedProject: (cancellationToken) => {
-        setupInitialBuild(state, cancellationToken);
-        return getNextInvalidatedProject(
-          state,
-          getBuildOrder(state),
-          /*reportQueue*/
-          false
-        );
-      },
-      getBuildOrder: () => getBuildOrder(state),
-      getUpToDateStatusOfProject: (project) => {
-        const configFileName = resolveProjectName(state, project);
-        const configFilePath = toResolvedConfigFilePath(state, configFileName);
-        return getUpToDateStatus(state, parseConfigFile(state, configFileName, configFilePath), configFilePath);
-      },
-      invalidateProject: (configFilePath, reloadLevel) => invalidateProject(state, configFilePath, reloadLevel || 0 /* None */),
-      close: () => stopWatching(state)
-    };
-  }
-  function relName(state, path) {
-    return convertToRelativePath(path, state.compilerHost.getCurrentDirectory(), state.compilerHost.getCanonicalFileName);
-  }
-  function reportStatus(state, message, ...args) {
-    state.host.reportSolutionBuilderStatus(createCompilerDiagnostic(message, ...args));
-  }
-  function reportWatchStatus(state, message, ...args) {
-    var _a, _b;
-    (_b = (_a = state.hostWithWatch).onWatchStatusChange) == null ? void 0 : _b.call(_a, createCompilerDiagnostic(message, ...args), state.host.getNewLine(), state.baseCompilerOptions);
-  }
-  function reportErrors({ host }, errors) {
-    errors.forEach((err) => host.reportDiagnostic(err));
-  }
-  function reportAndStoreErrors(state, proj, errors) {
-    reportErrors(state, errors);
-    state.projectErrorsReported.set(proj, true);
-    if (errors.length) {
-      state.diagnostics.set(proj, errors);
-    }
-  }
-  function reportParseConfigFileDiagnostic(state, proj) {
-    reportAndStoreErrors(state, proj, [state.configFileCache.get(proj)]);
-  }
-  function reportErrorSummary(state, buildOrder) {
-    if (!state.needsSummary)
-      return;
-    state.needsSummary = false;
-    const canReportSummary = state.watch || !!state.host.reportErrorSummary;
-    const { diagnostics } = state;
-    let totalErrors = 0;
-    let filesInError = [];
-    if (isCircularBuildOrder(buildOrder)) {
-      reportBuildQueue(state, buildOrder.buildOrder);
-      reportErrors(state, buildOrder.circularDiagnostics);
-      if (canReportSummary)
-        totalErrors += getErrorCountForSummary(buildOrder.circularDiagnostics);
-      if (canReportSummary)
-        filesInError = [...filesInError, ...getFilesInErrorForSummary(buildOrder.circularDiagnostics)];
-    } else {
-      buildOrder.forEach((project) => {
-        const projectPath = toResolvedConfigFilePath(state, project);
-        if (!state.projectErrorsReported.has(projectPath)) {
-          reportErrors(state, diagnostics.get(projectPath) || emptyArray);
+      ));
+      if (start > position) {
+        return false;
+      }
+      if (position < end || position === end && (node.kind === 1 /* EndOfFileToken */ || includeEndPosition)) {
+        return true;
+      } else if (includePrecedingTokenAtEndPosition && end === position) {
+        const previousToken = findPrecedingToken(position, sourceFile, node);
+        if (previousToken && includePrecedingTokenAtEndPosition(previousToken)) {
+          foundToken = previousToken;
+          return true;
         }
-      });
-      if (canReportSummary)
-        diagnostics.forEach((singleProjectErrors) => totalErrors += getErrorCountForSummary(singleProjectErrors));
-      if (canReportSummary)
-        diagnostics.forEach((singleProjectErrors) => [...filesInError, ...getFilesInErrorForSummary(singleProjectErrors)]);
-    }
-    if (state.watch) {
-      reportWatchStatus(state, getWatchErrorSummaryDiagnosticMessage(totalErrors), totalErrors);
-    } else if (state.host.reportErrorSummary) {
-      state.host.reportErrorSummary(totalErrors, filesInError);
+      }
+      return false;
     }
   }
-  function reportBuildQueue(state, buildQueue) {
-    if (state.options.verbose) {
-      reportStatus(state, Diagnostics.Projects_in_this_build_Colon_0, buildQueue.map((s) => "\r\n    * " + relName(state, s)).join(""));
+  function findFirstNonJsxWhitespaceToken(sourceFile, position) {
+    let tokenAtPosition = getTokenAtPosition(sourceFile, position);
+    while (isWhiteSpaceOnlyJsxText(tokenAtPosition)) {
+      const nextToken = findNextToken(tokenAtPosition, tokenAtPosition.parent, sourceFile);
+      if (!nextToken)
+        return;
+      tokenAtPosition = nextToken;
     }
+    return tokenAtPosition;
   }
-  function reportUpToDateStatus(state, configFileName, status) {
-    switch (status.type) {
-      case 6 /* OutOfDateWithSelf */:
-        return reportStatus(
-          state,
-          Diagnostics.Project_0_is_out_of_date_because_output_1_is_older_than_input_2,
-          relName(state, configFileName),
-          relName(state, status.outOfDateOutputFileName),
-          relName(state, status.newerInputFileName)
-        );
-      case 7 /* OutOfDateWithUpstream */:
-        return reportStatus(
-          state,
-          Diagnostics.Project_0_is_out_of_date_because_output_1_is_older_than_input_2,
-          relName(state, configFileName),
-          relName(state, status.outOfDateOutputFileName),
-          relName(state, status.newerProjectName)
-        );
-      case 4 /* OutputMissing */:
-        return reportStatus(
-          state,
-          Diagnostics.Project_0_is_out_of_date_because_output_file_1_does_not_exist,
-          relName(state, configFileName),
-          relName(state, status.missingOutputFileName)
-        );
-      case 5 /* ErrorReadingFile */:
-        return reportStatus(
-          state,
-          Diagnostics.Project_0_is_out_of_date_because_there_was_error_reading_file_1,
-          relName(state, configFileName),
-          relName(state, status.fileName)
-        );
-      case 8 /* OutOfDateBuildInfo */:
-        return reportStatus(
-          state,
-          Diagnostics.Project_0_is_out_of_date_because_buildinfo_file_1_indicates_that_some_of_the_changes_were_not_emitted,
-          relName(state, configFileName),
-          relName(state, status.buildInfoFile)
-        );
-      case 9 /* OutOfDateOptions */:
-        return reportStatus(
-          state,
-          Diagnostics.Project_0_is_out_of_date_because_buildinfo_file_1_indicates_there_is_change_in_compilerOptions,
-          relName(state, configFileName),
-          relName(state, status.buildInfoFile)
-        );
-      case 10 /* OutOfDateRoots */:
-        return reportStatus(
-          state,
-          Diagnostics.Project_0_is_out_of_date_because_buildinfo_file_1_indicates_that_file_2_was_root_file_of_compilation_but_not_any_more,
-          relName(state, configFileName),
-          relName(state, status.buildInfoFile),
-          relName(state, status.inputFile)
-        );
-      case 1 /* UpToDate */:
-        if (status.newestInputFileTime !== void 0) {
-          return reportStatus(
-            state,
-            Diagnostics.Project_0_is_up_to_date_because_newest_input_1_is_older_than_output_2,
-            relName(state, configFileName),
-            relName(state, status.newestInputFileName || ""),
-            relName(state, status.oldestOutputFileName || "")
-          );
-        }
-        break;
-      case 3 /* OutOfDateWithPrepend */:
-        return reportStatus(
-          state,
-          Diagnostics.Project_0_is_out_of_date_because_output_of_its_dependency_1_has_changed,
-          relName(state, configFileName),
-          relName(state, status.newerProjectName)
-        );
-      case 2 /* UpToDateWithUpstreamTypes */:
-        return reportStatus(
-          state,
-          Diagnostics.Project_0_is_up_to_date_with_d_ts_files_from_its_dependencies,
-          relName(state, configFileName)
-        );
-      case 15 /* UpToDateWithInputFileText */:
-        return reportStatus(
-          state,
-          Diagnostics.Project_0_is_up_to_date_but_needs_to_update_timestamps_of_output_files_that_are_older_than_input_files,
-          relName(state, configFileName)
-        );
-      case 11 /* UpstreamOutOfDate */:
-        return reportStatus(
-          state,
-          Diagnostics.Project_0_is_out_of_date_because_its_dependency_1_is_out_of_date,
-          relName(state, configFileName),
-          relName(state, status.upstreamProjectName)
-        );
-      case 12 /* UpstreamBlocked */:
-        return reportStatus(
-          state,
-          status.upstreamProjectBlocked ? Diagnostics.Project_0_can_t_be_built_because_its_dependency_1_was_not_built : Diagnostics.Project_0_can_t_be_built_because_its_dependency_1_has_errors,
-          relName(state, configFileName),
-          relName(state, status.upstreamProjectName)
-        );
-      case 0 /* Unbuildable */:
-        return reportStatus(
-          state,
-          Diagnostics.Failed_to_parse_file_0_Colon_1,
-          relName(state, configFileName),
-          status.reason
-        );
-      case 14 /* TsVersionOutputOfDate */:
-        return reportStatus(
-          state,
-          Diagnostics.Project_0_is_out_of_date_because_output_for_it_was_generated_with_version_1_that_differs_with_current_version_2,
-          relName(state, configFileName),
-          status.version,
-          version
-        );
-      case 17 /* ForceBuild */:
-        return reportStatus(
-          state,
-          Diagnostics.Project_0_is_being_forcibly_rebuilt,
-          relName(state, configFileName)
-        );
-      case 16 /* ContainerOnly */:
-      case 13 /* ComputingUpstream */:
-        break;
-      default:
-        assertType(status);
+  function findTokenOnLeftOfPosition(file, position) {
+    const tokenAtPosition = getTokenAtPosition(file, position);
+    if (isToken(tokenAtPosition) && position > tokenAtPosition.getStart(file) && position < tokenAtPosition.getEnd()) {
+      return tokenAtPosition;
     }
+    return findPrecedingToken(position, file);
   }
-  function verboseReportProjectStatus(state, configFileName, status) {
-    if (state.options.verbose) {
-      reportUpToDateStatus(state, configFileName, status);
+  function findNextToken(previousToken, parent2, sourceFile) {
+    return find2(parent2);
+    function find2(n) {
+      if (isToken(n) && n.pos === previousToken.end) {
+        return n;
+      }
+      return firstDefined(n.getChildren(sourceFile), (child) => {
+        const shouldDiveInChildNode = (
+          // previous token is enclosed somewhere in the child
+          child.pos <= previousToken.pos && child.end > previousToken.end || // previous token ends exactly at the beginning of child
+          child.pos === previousToken.end
+        );
+        return shouldDiveInChildNode && nodeHasTokens(child, sourceFile) ? find2(child) : void 0;
+      });
     }
   }
-  var minimumDate, maximumDate, InvalidatedProjectKind;
-  var init_tsbuildPublic = __esm({
-    "src/compiler/tsbuildPublic.ts"() {
-      "use strict";
-      init_ts2();
-      init_ts_performance();
-      minimumDate = /* @__PURE__ */ new Date(-864e13);
-      maximumDate = /* @__PURE__ */ new Date(864e13);
-      InvalidatedProjectKind = /* @__PURE__ */ ((InvalidatedProjectKind2) => {
-        InvalidatedProjectKind2[InvalidatedProjectKind2["Build"] = 0] = "Build";
-        InvalidatedProjectKind2[InvalidatedProjectKind2["UpdateBundle"] = 1] = "UpdateBundle";
-        InvalidatedProjectKind2[InvalidatedProjectKind2["UpdateOutputFileStamps"] = 2] = "UpdateOutputFileStamps";
-        return InvalidatedProjectKind2;
-      })(InvalidatedProjectKind || {});
-    }
-  });
-
-  // src/compiler/_namespaces/ts.ts
-  var init_ts2 = __esm({
-    "src/compiler/_namespaces/ts.ts"() {
-      "use strict";
-      init_corePublic();
-      init_core();
-      init_debug();
-      init_semver();
-      init_performanceCore();
-      init_perfLogger();
-      init_tracing();
-      init_types();
-      init_sys();
-      init_path();
-      init_diagnosticInformationMap_generated();
-      init_scanner();
-      init_utilitiesPublic();
-      init_utilities();
-      init_baseNodeFactory();
-      init_parenthesizerRules();
-      init_nodeConverters();
-      init_nodeFactory();
-      init_emitNode();
-      init_emitHelpers();
-      init_nodeTests();
-      init_utilities2();
-      init_utilitiesPublic2();
-      init_parser();
-      init_commandLineParser();
-      init_moduleNameResolver();
-      init_binder();
-      init_symbolWalker();
-      init_checker();
-      init_visitorPublic();
-      init_sourcemap();
-      init_utilities3();
-      init_destructuring();
-      init_taggedTemplate();
-      init_ts();
-      init_classFields();
-      init_typeSerializer();
-      init_legacyDecorators();
-      init_esDecorators();
-      init_es2017();
-      init_es2018();
-      init_es2019();
-      init_es2020();
-      init_es2021();
-      init_esnext();
-      init_jsx();
-      init_es2016();
-      init_es2015();
-      init_es5();
-      init_generators();
-      init_module();
-      init_system();
-      init_esnextAnd2015();
-      init_node();
-      init_diagnostics();
-      init_declarations();
-      init_transformer();
-      init_emitter();
-      init_watchUtilities();
-      init_program();
-      init_builderStatePublic();
-      init_builderState();
-      init_builder();
-      init_builderPublic();
-      init_resolutionCache();
-      init_watch();
-      init_watchPublic();
-      init_tsbuild();
-      init_tsbuildPublic();
-      init_ts_moduleSpecifiers();
-      init_ts_performance();
+  function findPrecedingToken(position, sourceFile, startNode2, excludeJsdoc) {
+    const result = find2(startNode2 || sourceFile);
+    Debug.assert(!(result && isWhiteSpaceOnlyJsxText(result)));
+    return result;
+    function find2(n) {
+      if (isNonWhitespaceToken(n) && n.kind !== 1 /* EndOfFileToken */) {
+        return n;
+      }
+      const children = n.getChildren(sourceFile);
+      const i = binarySearchKey(children, position, (_, i2) => i2, (middle, _) => {
+        if (position < children[middle].end) {
+          if (!children[middle - 1] || position >= children[middle - 1].end) {
+            return 0 /* EqualTo */;
+          }
+          return 1 /* GreaterThan */;
+        }
+        return -1 /* LessThan */;
+      });
+      if (i >= 0 && children[i]) {
+        const child = children[i];
+        if (position < child.end) {
+          const start = child.getStart(
+            sourceFile,
+            /*includeJsDoc*/
+            !excludeJsdoc
+          );
+          const lookInPreviousChild = start >= position || // cursor in the leading trivia
+          !nodeHasTokens(child, sourceFile) || isWhiteSpaceOnlyJsxText(child);
+          if (lookInPreviousChild) {
+            const candidate2 = findRightmostChildNodeWithTokens(
+              children,
+              /*exclusiveStartPosition*/
+              i,
+              sourceFile,
+              n.kind
+            );
+            if (candidate2) {
+              if (!excludeJsdoc && isJSDocCommentContainingNode(candidate2) && candidate2.getChildren(sourceFile).length) {
+                return find2(candidate2);
+              }
+              return findRightmostToken(candidate2, sourceFile);
+            }
+            return void 0;
+          } else {
+            return find2(child);
+          }
+        }
+      }
+      Debug.assert(startNode2 !== void 0 || n.kind === 312 /* SourceFile */ || n.kind === 1 /* EndOfFileToken */ || isJSDocCommentContainingNode(n));
+      const candidate = findRightmostChildNodeWithTokens(
+        children,
+        /*exclusiveStartPosition*/
+        children.length,
+        sourceFile,
+        n.kind
+      );
+      return candidate && findRightmostToken(candidate, sourceFile);
     }
-  });
-
-  // src/jsTyping/jsTyping.ts
-  function isTypingUpToDate(cachedTyping, availableTypingVersions) {
-    const availableVersion = new Version(getProperty(availableTypingVersions, `ts${versionMajorMinor}`) || getProperty(availableTypingVersions, "latest"));
-    return availableVersion.compareTo(cachedTyping.version) <= 0;
-  }
-  function nonRelativeModuleNameForTypingCache(moduleName) {
-    return nodeCoreModules.has(moduleName) ? "node" : moduleName;
   }
-  function loadSafeList(host, safeListPath) {
-    const result = readConfigFile(safeListPath, (path) => host.readFile(path));
-    return new Map(Object.entries(result.config));
+  function isNonWhitespaceToken(n) {
+    return isToken(n) && !isWhiteSpaceOnlyJsxText(n);
   }
-  function loadTypesMap(host, typesMapPath) {
-    var _a;
-    const result = readConfigFile(typesMapPath, (path) => host.readFile(path));
-    if ((_a = result.config) == null ? void 0 : _a.simpleMap) {
-      return new Map(Object.entries(result.config.simpleMap));
+  function findRightmostToken(n, sourceFile) {
+    if (isNonWhitespaceToken(n)) {
+      return n;
     }
-    return void 0;
+    const children = n.getChildren(sourceFile);
+    if (children.length === 0) {
+      return n;
+    }
+    const candidate = findRightmostChildNodeWithTokens(
+      children,
+      /*exclusiveStartPosition*/
+      children.length,
+      sourceFile,
+      n.kind
+    );
+    return candidate && findRightmostToken(candidate, sourceFile);
   }
-  function discoverTypings(host, log, fileNames, projectRootPath, safeList, packageNameToTypingLocation, typeAcquisition, unresolvedImports, typesRegistry, compilerOptions) {
-    if (!typeAcquisition || !typeAcquisition.enable) {
-      return { cachedTypingPaths: [], newTypingNames: [], filesToWatch: [] };
+  function findRightmostChildNodeWithTokens(children, exclusiveStartPosition, sourceFile, parentKind) {
+    for (let i = exclusiveStartPosition - 1; i >= 0; i--) {
+      const child = children[i];
+      if (isWhiteSpaceOnlyJsxText(child)) {
+        if (i === 0 && (parentKind === 12 /* JsxText */ || parentKind === 285 /* JsxSelfClosingElement */)) {
+          Debug.fail("`JsxText` tokens should not be the first child of `JsxElement | JsxSelfClosingElement`");
+        }
+      } else if (nodeHasTokens(children[i], sourceFile)) {
+        return children[i];
+      }
     }
-    const inferredTypings = /* @__PURE__ */ new Map();
-    fileNames = mapDefined(fileNames, (fileName) => {
-      const path = normalizePath(fileName);
-      if (hasJSFileExtension(path)) {
-        return path;
+  }
+  function isInString(sourceFile, position, previousToken = findPrecedingToken(position, sourceFile)) {
+    if (previousToken && isStringTextContainingNode(previousToken)) {
+      const start = previousToken.getStart(sourceFile);
+      const end = previousToken.getEnd();
+      if (start < position && position < end) {
+        return true;
+      }
+      if (position === end) {
+        return !!previousToken.isUnterminated;
       }
-    });
-    const filesToWatch = [];
-    if (typeAcquisition.include)
-      addInferredTypings(typeAcquisition.include, "Explicitly included types");
-    const exclude = typeAcquisition.exclude || [];
-    if (!compilerOptions.types) {
-      const possibleSearchDirs = new Set(fileNames.map(getDirectoryPath));
-      possibleSearchDirs.add(projectRootPath);
-      possibleSearchDirs.forEach((searchDir) => {
-        getTypingNames(searchDir, "bower.json", "bower_components", filesToWatch);
-        getTypingNames(searchDir, "package.json", "node_modules", filesToWatch);
-      });
     }
-    if (!typeAcquisition.disableFilenameBasedTypeAcquisition) {
-      getTypingNamesFromSourceFileNames(fileNames);
+    return false;
+  }
+  function isInsideJsxElementOrAttribute(sourceFile, position) {
+    const token = getTokenAtPosition(sourceFile, position);
+    if (!token) {
+      return false;
     }
-    if (unresolvedImports) {
-      const module2 = deduplicate(
-        unresolvedImports.map(nonRelativeModuleNameForTypingCache),
-        equateStringsCaseSensitive,
-        compareStringsCaseSensitive
-      );
-      addInferredTypings(module2, "Inferred typings from unresolved imports");
+    if (token.kind === 12 /* JsxText */) {
+      return true;
     }
-    packageNameToTypingLocation.forEach((typing, name) => {
-      const registryEntry = typesRegistry.get(name);
-      if (inferredTypings.has(name) && inferredTypings.get(name) === void 0 && registryEntry !== void 0 && isTypingUpToDate(typing, registryEntry)) {
-        inferredTypings.set(name, typing.typingLocation);
-      }
-    });
-    for (const excludeTypingName of exclude) {
-      const didDelete = inferredTypings.delete(excludeTypingName);
-      if (didDelete && log)
-        log(`Typing for ${excludeTypingName} is in exclude list, will be ignored.`);
+    if (token.kind === 30 /* LessThanToken */ && token.parent.kind === 12 /* JsxText */) {
+      return true;
     }
-    const newTypingNames = [];
-    const cachedTypingPaths = [];
-    inferredTypings.forEach((inferred, typing) => {
-      if (inferred !== void 0) {
-        cachedTypingPaths.push(inferred);
-      } else {
-        newTypingNames.push(typing);
-      }
-    });
-    const result = { cachedTypingPaths, newTypingNames, filesToWatch };
-    if (log)
-      log(`Result: ${JSON.stringify(result)}`);
-    return result;
-    function addInferredTyping(typingName) {
-      if (!inferredTypings.has(typingName)) {
-        inferredTypings.set(typingName, void 0);
+    if (token.kind === 30 /* LessThanToken */ && token.parent.kind === 294 /* JsxExpression */) {
+      return true;
+    }
+    if (token && token.kind === 20 /* CloseBraceToken */ && token.parent.kind === 294 /* JsxExpression */) {
+      return true;
+    }
+    if (token.kind === 30 /* LessThanToken */ && token.parent.kind === 287 /* JsxClosingElement */) {
+      return true;
+    }
+    return false;
+  }
+  function isWhiteSpaceOnlyJsxText(node) {
+    return isJsxText(node) && node.containsOnlyTriviaWhiteSpaces;
+  }
+  function isInTemplateString(sourceFile, position) {
+    const token = getTokenAtPosition(sourceFile, position);
+    return isTemplateLiteralKind(token.kind) && position > token.getStart(sourceFile);
+  }
+  function isInJSXText(sourceFile, position) {
+    const token = getTokenAtPosition(sourceFile, position);
+    if (isJsxText(token)) {
+      return true;
+    }
+    if (token.kind === 19 /* OpenBraceToken */ && isJsxExpression(token.parent) && isJsxElement(token.parent.parent)) {
+      return true;
+    }
+    if (token.kind === 30 /* LessThanToken */ && isJsxOpeningLikeElement(token.parent) && isJsxElement(token.parent.parent)) {
+      return true;
+    }
+    return false;
+  }
+  function isInsideJsxElement(sourceFile, position) {
+    function isInsideJsxElementTraversal(node) {
+      while (node) {
+        if (node.kind >= 285 /* JsxSelfClosingElement */ && node.kind <= 294 /* JsxExpression */ || node.kind === 12 /* JsxText */ || node.kind === 30 /* LessThanToken */ || node.kind === 32 /* GreaterThanToken */ || node.kind === 80 /* Identifier */ || node.kind === 20 /* CloseBraceToken */ || node.kind === 19 /* OpenBraceToken */ || node.kind === 44 /* SlashToken */) {
+          node = node.parent;
+        } else if (node.kind === 284 /* JsxElement */) {
+          if (position > node.getStart(sourceFile))
+            return true;
+          node = node.parent;
+        } else {
+          return false;
+        }
       }
+      return false;
     }
-    function addInferredTypings(typingNames, message) {
-      if (log)
-        log(`${message}: ${JSON.stringify(typingNames)}`);
-      forEach(typingNames, addInferredTyping);
+    return isInsideJsxElementTraversal(getTokenAtPosition(sourceFile, position));
+  }
+  function findPrecedingMatchingToken(token, matchingTokenKind, sourceFile) {
+    const closeTokenText = tokenToString(token.kind);
+    const matchingTokenText = tokenToString(matchingTokenKind);
+    const tokenFullStart = token.getFullStart();
+    const bestGuessIndex = sourceFile.text.lastIndexOf(matchingTokenText, tokenFullStart);
+    if (bestGuessIndex === -1) {
+      return void 0;
     }
-    function getTypingNames(projectRootPath2, manifestName, modulesDirName, filesToWatch2) {
-      const manifestPath = combinePaths(projectRootPath2, manifestName);
-      let manifest;
-      let manifestTypingNames;
-      if (host.fileExists(manifestPath)) {
-        filesToWatch2.push(manifestPath);
-        manifest = readConfigFile(manifestPath, (path) => host.readFile(path)).config;
-        manifestTypingNames = flatMap([manifest.dependencies, manifest.devDependencies, manifest.optionalDependencies, manifest.peerDependencies], getOwnKeys);
-        addInferredTypings(manifestTypingNames, `Typing names in '${manifestPath}' dependencies`);
+    if (sourceFile.text.lastIndexOf(closeTokenText, tokenFullStart - 1) < bestGuessIndex) {
+      const nodeAtGuess = findPrecedingToken(bestGuessIndex + 1, sourceFile);
+      if (nodeAtGuess && nodeAtGuess.kind === matchingTokenKind) {
+        return nodeAtGuess;
       }
-      const packagesFolderPath = combinePaths(projectRootPath2, modulesDirName);
-      filesToWatch2.push(packagesFolderPath);
-      if (!host.directoryExists(packagesFolderPath)) {
-        return;
+    }
+    const tokenKind = token.kind;
+    let remainingMatchingTokens = 0;
+    while (true) {
+      const preceding = findPrecedingToken(token.getFullStart(), sourceFile);
+      if (!preceding) {
+        return void 0;
       }
-      const packageNames = [];
-      const dependencyManifestNames = manifestTypingNames ? manifestTypingNames.map((typingName) => combinePaths(packagesFolderPath, typingName, manifestName)) : host.readDirectory(
-        packagesFolderPath,
-        [".json" /* Json */],
-        /*excludes*/
-        void 0,
-        /*includes*/
-        void 0,
-        /*depth*/
-        3
-      ).filter((manifestPath2) => {
-        if (getBaseFileName(manifestPath2) !== manifestName) {
-          return false;
-        }
-        const pathComponents2 = getPathComponents(normalizePath(manifestPath2));
-        const isScoped = pathComponents2[pathComponents2.length - 3][0] === "@";
-        return isScoped && toFileNameLowerCase(pathComponents2[pathComponents2.length - 4]) === modulesDirName || // `node_modules/@foo/bar`
-        !isScoped && toFileNameLowerCase(pathComponents2[pathComponents2.length - 3]) === modulesDirName;
-      });
-      if (log)
-        log(`Searching for typing names in ${packagesFolderPath}; all files: ${JSON.stringify(dependencyManifestNames)}`);
-      for (const manifestPath2 of dependencyManifestNames) {
-        const normalizedFileName = normalizePath(manifestPath2);
-        const result2 = readConfigFile(normalizedFileName, (path) => host.readFile(path));
-        const manifest2 = result2.config;
-        if (!manifest2.name) {
-          continue;
-        }
-        const ownTypes = manifest2.types || manifest2.typings;
-        if (ownTypes) {
-          const absolutePath = getNormalizedAbsolutePath(ownTypes, getDirectoryPath(normalizedFileName));
-          if (host.fileExists(absolutePath)) {
-            if (log)
-              log(`    Package '${manifest2.name}' provides its own types.`);
-            inferredTypings.set(manifest2.name, absolutePath);
-          } else {
-            if (log)
-              log(`    Package '${manifest2.name}' provides its own types but they are missing.`);
-          }
-        } else {
-          packageNames.push(manifest2.name);
+      token = preceding;
+      if (token.kind === matchingTokenKind) {
+        if (remainingMatchingTokens === 0) {
+          return token;
         }
+        remainingMatchingTokens--;
+      } else if (token.kind === tokenKind) {
+        remainingMatchingTokens++;
       }
-      addInferredTypings(packageNames, "    Found package names");
     }
-    function getTypingNamesFromSourceFileNames(fileNames2) {
-      const fromFileNames = mapDefined(fileNames2, (j) => {
-        if (!hasJSFileExtension(j))
+  }
+  function removeOptionality(type, isOptionalExpression, isOptionalChain2) {
+    return isOptionalExpression ? type.getNonNullableType() : isOptionalChain2 ? type.getNonOptionalType() : type;
+  }
+  function isPossiblyTypeArgumentPosition(token, sourceFile, checker) {
+    const info = getPossibleTypeArgumentsInfo(token, sourceFile);
+    return info !== void 0 && (isPartOfTypeNode(info.called) || getPossibleGenericSignatures(info.called, info.nTypeArguments, checker).length !== 0 || isPossiblyTypeArgumentPosition(info.called, sourceFile, checker));
+  }
+  function getPossibleGenericSignatures(called, typeArgumentCount, checker) {
+    let type = checker.getTypeAtLocation(called);
+    if (isOptionalChain(called.parent)) {
+      type = removeOptionality(
+        type,
+        isOptionalChainRoot(called.parent),
+        /*isOptionalChain*/
+        true
+      );
+    }
+    const signatures = isNewExpression(called.parent) ? type.getConstructSignatures() : type.getCallSignatures();
+    return signatures.filter((candidate) => !!candidate.typeParameters && candidate.typeParameters.length >= typeArgumentCount);
+  }
+  function getPossibleTypeArgumentsInfo(tokenIn, sourceFile) {
+    if (sourceFile.text.lastIndexOf("<", tokenIn ? tokenIn.pos : sourceFile.text.length) === -1) {
+      return void 0;
+    }
+    let token = tokenIn;
+    let remainingLessThanTokens = 0;
+    let nTypeArguments = 0;
+    while (token) {
+      switch (token.kind) {
+        case 30 /* LessThanToken */:
+          token = findPrecedingToken(token.getFullStart(), sourceFile);
+          if (token && token.kind === 29 /* QuestionDotToken */) {
+            token = findPrecedingToken(token.getFullStart(), sourceFile);
+          }
+          if (!token || !isIdentifier(token))
+            return void 0;
+          if (!remainingLessThanTokens) {
+            return isDeclarationName(token) ? void 0 : { called: token, nTypeArguments };
+          }
+          remainingLessThanTokens--;
+          break;
+        case 50 /* GreaterThanGreaterThanGreaterThanToken */:
+          remainingLessThanTokens = 3;
+          break;
+        case 49 /* GreaterThanGreaterThanToken */:
+          remainingLessThanTokens = 2;
+          break;
+        case 32 /* GreaterThanToken */:
+          remainingLessThanTokens++;
+          break;
+        case 20 /* CloseBraceToken */:
+          token = findPrecedingMatchingToken(token, 19 /* OpenBraceToken */, sourceFile);
+          if (!token)
+            return void 0;
+          break;
+        case 22 /* CloseParenToken */:
+          token = findPrecedingMatchingToken(token, 21 /* OpenParenToken */, sourceFile);
+          if (!token)
+            return void 0;
+          break;
+        case 24 /* CloseBracketToken */:
+          token = findPrecedingMatchingToken(token, 23 /* OpenBracketToken */, sourceFile);
+          if (!token)
+            return void 0;
+          break;
+        case 28 /* CommaToken */:
+          nTypeArguments++;
+          break;
+        case 39 /* EqualsGreaterThanToken */:
+        case 80 /* Identifier */:
+        case 11 /* StringLiteral */:
+        case 9 /* NumericLiteral */:
+        case 10 /* BigIntLiteral */:
+        case 112 /* TrueKeyword */:
+        case 97 /* FalseKeyword */:
+        case 114 /* TypeOfKeyword */:
+        case 96 /* ExtendsKeyword */:
+        case 143 /* KeyOfKeyword */:
+        case 25 /* DotToken */:
+        case 52 /* BarToken */:
+        case 58 /* QuestionToken */:
+        case 59 /* ColonToken */:
+          break;
+        default:
+          if (isTypeNode(token)) {
+            break;
+          }
           return void 0;
-        const inferredTypingName = removeFileExtension(toFileNameLowerCase(getBaseFileName(j)));
-        const cleanedTypingName = removeMinAndVersionNumbers(inferredTypingName);
-        return safeList.get(cleanedTypingName);
-      });
-      if (fromFileNames.length) {
-        addInferredTypings(fromFileNames, "Inferred typings from file names");
-      }
-      const hasJsxFile = some(fileNames2, (f) => fileExtensionIs(f, ".jsx" /* Jsx */));
-      if (hasJsxFile) {
-        if (log)
-          log(`Inferred 'react' typings due to presence of '.jsx' extension`);
-        addInferredTyping("react");
       }
+      token = findPrecedingToken(token.getFullStart(), sourceFile);
     }
+    return void 0;
   }
-  function validatePackageName(packageName) {
-    return validatePackageNameWorker(
-      packageName,
-      /*supportScopedPackage*/
-      true
+  function isInComment(sourceFile, position, tokenAtPosition) {
+    return ts_formatting_exports.getRangeOfEnclosingComment(
+      sourceFile,
+      position,
+      /*precedingToken*/
+      void 0,
+      tokenAtPosition
     );
   }
-  function validatePackageNameWorker(packageName, supportScopedPackage) {
-    if (!packageName) {
-      return 1 /* EmptyName */;
+  function hasDocComment(sourceFile, position) {
+    const token = getTokenAtPosition(sourceFile, position);
+    return !!findAncestor(token, isJSDoc);
+  }
+  function nodeHasTokens(n, sourceFile) {
+    return n.kind === 1 /* EndOfFileToken */ ? !!n.jsDoc : n.getWidth(sourceFile) !== 0;
+  }
+  function getNodeModifiers(node, excludeFlags = 0 /* None */) {
+    const result = [];
+    const flags = isDeclaration(node) ? getCombinedNodeFlagsAlwaysIncludeJSDoc(node) & ~excludeFlags : 0 /* None */;
+    if (flags & 2 /* Private */)
+      result.push("private" /* privateMemberModifier */);
+    if (flags & 4 /* Protected */)
+      result.push("protected" /* protectedMemberModifier */);
+    if (flags & 1 /* Public */)
+      result.push("public" /* publicMemberModifier */);
+    if (flags & 256 /* Static */ || isClassStaticBlockDeclaration(node))
+      result.push("static" /* staticModifier */);
+    if (flags & 64 /* Abstract */)
+      result.push("abstract" /* abstractModifier */);
+    if (flags & 32 /* Export */)
+      result.push("export" /* exportedModifier */);
+    if (flags & 65536 /* Deprecated */)
+      result.push("deprecated" /* deprecatedModifier */);
+    if (node.flags & 33554432 /* Ambient */)
+      result.push("declare" /* ambientModifier */);
+    if (node.kind === 277 /* ExportAssignment */)
+      result.push("export" /* exportedModifier */);
+    return result.length > 0 ? result.join(",") : "" /* none */;
+  }
+  function getTypeArgumentOrTypeParameterList(node) {
+    if (node.kind === 183 /* TypeReference */ || node.kind === 213 /* CallExpression */) {
+      return node.typeArguments;
     }
-    if (packageName.length > maxPackageNameLength) {
-      return 2 /* NameTooLong */;
+    if (isFunctionLike(node) || node.kind === 263 /* ClassDeclaration */ || node.kind === 264 /* InterfaceDeclaration */) {
+      return node.typeParameters;
     }
-    if (packageName.charCodeAt(0) === 46 /* dot */) {
-      return 3 /* NameStartsWithDot */;
+    return void 0;
+  }
+  function isComment(kind) {
+    return kind === 2 /* SingleLineCommentTrivia */ || kind === 3 /* MultiLineCommentTrivia */;
+  }
+  function isStringOrRegularExpressionOrTemplateLiteral(kind) {
+    if (kind === 11 /* StringLiteral */ || kind === 14 /* RegularExpressionLiteral */ || isTemplateLiteralKind(kind)) {
+      return true;
     }
-    if (packageName.charCodeAt(0) === 95 /* _ */) {
-      return 4 /* NameStartsWithUnderscore */;
+    return false;
+  }
+  function areIntersectedTypesAvoidingStringReduction(checker, t1, t2) {
+    return !!(t1.flags & 4 /* String */) && checker.isEmptyAnonymousObjectType(t2);
+  }
+  function isStringAndEmptyAnonymousObjectIntersection(type) {
+    if (!type.isIntersection()) {
+      return false;
     }
-    if (supportScopedPackage) {
-      const matches = /^@([^/]+)\/([^/]+)$/.exec(packageName);
-      if (matches) {
-        const scopeResult = validatePackageNameWorker(
-          matches[1],
-          /*supportScopedPackage*/
-          false
-        );
-        if (scopeResult !== 0 /* Ok */) {
-          return { name: matches[1], isScopeName: true, result: scopeResult };
-        }
-        const packageResult = validatePackageNameWorker(
-          matches[2],
-          /*supportScopedPackage*/
-          false
-        );
-        if (packageResult !== 0 /* Ok */) {
-          return { name: matches[2], isScopeName: false, result: packageResult };
-        }
-        return 0 /* Ok */;
-      }
+    const { types, checker } = type;
+    return types.length === 2 && (areIntersectedTypesAvoidingStringReduction(checker, types[0], types[1]) || areIntersectedTypesAvoidingStringReduction(checker, types[1], types[0]));
+  }
+  function isInsideTemplateLiteral(node, position, sourceFile) {
+    return isTemplateLiteralKind(node.kind) && (node.getStart(sourceFile) < position && position < node.end) || !!node.isUnterminated && position === node.end;
+  }
+  function isAccessibilityModifier(kind) {
+    switch (kind) {
+      case 125 /* PublicKeyword */:
+      case 123 /* PrivateKeyword */:
+      case 124 /* ProtectedKeyword */:
+        return true;
     }
-    if (encodeURIComponent(packageName) !== packageName) {
-      return 5 /* NameContainsNonURISafeCharacters */;
+    return false;
+  }
+  function cloneCompilerOptions(options) {
+    const result = clone(options);
+    setConfigFileInOptions(result, options && options.configFile);
+    return result;
+  }
+  function isArrayLiteralOrObjectLiteralDestructuringPattern(node) {
+    if (node.kind === 209 /* ArrayLiteralExpression */ || node.kind === 210 /* ObjectLiteralExpression */) {
+      if (node.parent.kind === 226 /* BinaryExpression */ && node.parent.left === node && node.parent.operatorToken.kind === 64 /* EqualsToken */) {
+        return true;
+      }
+      if (node.parent.kind === 250 /* ForOfStatement */ && node.parent.initializer === node) {
+        return true;
+      }
+      if (isArrayLiteralOrObjectLiteralDestructuringPattern(node.parent.kind === 303 /* PropertyAssignment */ ? node.parent.parent : node.parent)) {
+        return true;
+      }
     }
-    return 0 /* Ok */;
+    return false;
   }
-  function renderPackageNameValidationFailure(result, typing) {
-    return typeof result === "object" ? renderPackageNameValidationFailureWorker(typing, result.result, result.name, result.isScopeName) : renderPackageNameValidationFailureWorker(
-      typing,
-      result,
-      typing,
-      /*isScopeName*/
+  function isInReferenceComment(sourceFile, position) {
+    return isInReferenceCommentWorker(
+      sourceFile,
+      position,
+      /*shouldBeReference*/
+      true
+    );
+  }
+  function isInNonReferenceComment(sourceFile, position) {
+    return isInReferenceCommentWorker(
+      sourceFile,
+      position,
+      /*shouldBeReference*/
       false
     );
   }
-  function renderPackageNameValidationFailureWorker(typing, result, name, isScopeName) {
-    const kind = isScopeName ? "Scope" : "Package";
-    switch (result) {
-      case 1 /* EmptyName */:
-        return `'${typing}':: ${kind} name '${name}' cannot be empty`;
-      case 2 /* NameTooLong */:
-        return `'${typing}':: ${kind} name '${name}' should be less than ${maxPackageNameLength} characters`;
-      case 3 /* NameStartsWithDot */:
-        return `'${typing}':: ${kind} name '${name}' cannot start with '.'`;
-      case 4 /* NameStartsWithUnderscore */:
-        return `'${typing}':: ${kind} name '${name}' cannot start with '_'`;
-      case 5 /* NameContainsNonURISafeCharacters */:
-        return `'${typing}':: ${kind} name '${name}' contains non URI safe characters`;
-      case 0 /* Ok */:
-        return Debug.fail();
+  function isInReferenceCommentWorker(sourceFile, position, shouldBeReference) {
+    const range = isInComment(
+      sourceFile,
+      position,
+      /*tokenAtPosition*/
+      void 0
+    );
+    return !!range && shouldBeReference === tripleSlashDirectivePrefixRegex.test(sourceFile.text.substring(range.pos, range.end));
+  }
+  function getReplacementSpanForContextToken(contextToken) {
+    if (!contextToken)
+      return void 0;
+    switch (contextToken.kind) {
+      case 11 /* StringLiteral */:
+      case 15 /* NoSubstitutionTemplateLiteral */:
+        return createTextSpanFromStringLiteralLikeContent(contextToken);
       default:
-        Debug.assertNever(result);
+        return createTextSpanFromNode(contextToken);
     }
   }
-  var unprefixedNodeCoreModuleList, prefixedNodeCoreModuleList, nodeCoreModuleList, nodeCoreModules, NameValidationResult, maxPackageNameLength;
-  var init_jsTyping = __esm({
-    "src/jsTyping/jsTyping.ts"() {
-      "use strict";
-      init_ts3();
-      unprefixedNodeCoreModuleList = [
-        "assert",
-        "assert/strict",
-        "async_hooks",
-        "buffer",
-        "child_process",
-        "cluster",
-        "console",
-        "constants",
-        "crypto",
-        "dgram",
-        "diagnostics_channel",
-        "dns",
-        "dns/promises",
-        "domain",
-        "events",
-        "fs",
-        "fs/promises",
-        "http",
-        "https",
-        "http2",
-        "inspector",
-        "module",
-        "net",
-        "os",
-        "path",
-        "perf_hooks",
-        "process",
-        "punycode",
-        "querystring",
-        "readline",
-        "repl",
-        "stream",
-        "stream/promises",
-        "string_decoder",
-        "timers",
-        "timers/promises",
-        "tls",
-        "trace_events",
-        "tty",
-        "url",
-        "util",
-        "util/types",
-        "v8",
-        "vm",
-        "wasi",
-        "worker_threads",
-        "zlib"
-      ];
-      prefixedNodeCoreModuleList = unprefixedNodeCoreModuleList.map((name) => `node:${name}`);
-      nodeCoreModuleList = [...unprefixedNodeCoreModuleList, ...prefixedNodeCoreModuleList];
-      nodeCoreModules = new Set(nodeCoreModuleList);
-      NameValidationResult = /* @__PURE__ */ ((NameValidationResult2) => {
-        NameValidationResult2[NameValidationResult2["Ok"] = 0] = "Ok";
-        NameValidationResult2[NameValidationResult2["EmptyName"] = 1] = "EmptyName";
-        NameValidationResult2[NameValidationResult2["NameTooLong"] = 2] = "NameTooLong";
-        NameValidationResult2[NameValidationResult2["NameStartsWithDot"] = 3] = "NameStartsWithDot";
-        NameValidationResult2[NameValidationResult2["NameStartsWithUnderscore"] = 4] = "NameStartsWithUnderscore";
-        NameValidationResult2[NameValidationResult2["NameContainsNonURISafeCharacters"] = 5] = "NameContainsNonURISafeCharacters";
-        return NameValidationResult2;
-      })(NameValidationResult || {});
-      maxPackageNameLength = 214;
-    }
-  });
-
-  // src/jsTyping/_namespaces/ts.JsTyping.ts
-  var ts_JsTyping_exports = {};
-  __export(ts_JsTyping_exports, {
-    NameValidationResult: () => NameValidationResult,
-    discoverTypings: () => discoverTypings,
-    isTypingUpToDate: () => isTypingUpToDate,
-    loadSafeList: () => loadSafeList,
-    loadTypesMap: () => loadTypesMap,
-    nodeCoreModuleList: () => nodeCoreModuleList,
-    nodeCoreModules: () => nodeCoreModules,
-    nonRelativeModuleNameForTypingCache: () => nonRelativeModuleNameForTypingCache,
-    prefixedNodeCoreModuleList: () => prefixedNodeCoreModuleList,
-    renderPackageNameValidationFailure: () => renderPackageNameValidationFailure,
-    validatePackageName: () => validatePackageName
-  });
-  var init_ts_JsTyping = __esm({
-    "src/jsTyping/_namespaces/ts.JsTyping.ts"() {
-      "use strict";
-      init_jsTyping();
-    }
-  });
-
-  // src/jsTyping/shared.ts
-  function hasArgument(argumentName) {
-    return sys.args.indexOf(argumentName) >= 0;
+  function createTextSpanFromNode(node, sourceFile, endNode2) {
+    return createTextSpanFromBounds(node.getStart(sourceFile), (endNode2 || node).getEnd());
   }
-  function findArgument(argumentName) {
-    const index = sys.args.indexOf(argumentName);
-    return index >= 0 && index < sys.args.length - 1 ? sys.args[index + 1] : void 0;
+  function createTextSpanFromStringLiteralLikeContent(node) {
+    if (node.isUnterminated)
+      return void 0;
+    return createTextSpanFromBounds(node.getStart() + 1, node.getEnd() - 1);
   }
-  function nowString() {
-    const d = /* @__PURE__ */ new Date();
-    return `${padLeft(d.getHours().toString(), 2, "0")}:${padLeft(d.getMinutes().toString(), 2, "0")}:${padLeft(d.getSeconds().toString(), 2, "0")}.${padLeft(d.getMilliseconds().toString(), 3, "0")}`;
+  function createTextRangeFromNode(node, sourceFile) {
+    return createRange(node.getStart(sourceFile), node.end);
   }
-  var ActionSet, ActionInvalidate, ActionPackageInstalled, EventTypesRegistry, EventBeginInstallTypes, EventEndInstallTypes, EventInitializationFailed, ActionWatchTypingLocations, Arguments;
-  var init_shared = __esm({
-    "src/jsTyping/shared.ts"() {
-      "use strict";
-      init_ts3();
-      ActionSet = "action::set";
-      ActionInvalidate = "action::invalidate";
-      ActionPackageInstalled = "action::packageInstalled";
-      EventTypesRegistry = "event::typesRegistry";
-      EventBeginInstallTypes = "event::beginInstallTypes";
-      EventEndInstallTypes = "event::endInstallTypes";
-      EventInitializationFailed = "event::initializationFailed";
-      ActionWatchTypingLocations = "action::watchTypingLocations";
-      ((Arguments2) => {
-        Arguments2.GlobalCacheLocation = "--globalTypingsCacheLocation";
-        Arguments2.LogFile = "--logFile";
-        Arguments2.EnableTelemetry = "--enableTelemetry";
-        Arguments2.TypingSafeListLocation = "--typingSafeListLocation";
-        Arguments2.TypesMapLocation = "--typesMapLocation";
-        Arguments2.NpmLocation = "--npmLocation";
-        Arguments2.ValidateDefaultNpmLocation = "--validateDefaultNpmLocation";
-      })(Arguments || (Arguments = {}));
-    }
-  });
-
-  // src/jsTyping/types.ts
-  var init_types2 = __esm({
-    "src/jsTyping/types.ts"() {
-      "use strict";
-    }
-  });
-
-  // src/jsTyping/_namespaces/ts.server.ts
-  var ts_server_exports = {};
-  __export(ts_server_exports, {
-    ActionInvalidate: () => ActionInvalidate,
-    ActionPackageInstalled: () => ActionPackageInstalled,
-    ActionSet: () => ActionSet,
-    ActionWatchTypingLocations: () => ActionWatchTypingLocations,
-    Arguments: () => Arguments,
-    EventBeginInstallTypes: () => EventBeginInstallTypes,
-    EventEndInstallTypes: () => EventEndInstallTypes,
-    EventInitializationFailed: () => EventInitializationFailed,
-    EventTypesRegistry: () => EventTypesRegistry,
-    findArgument: () => findArgument,
-    hasArgument: () => hasArgument,
-    nowString: () => nowString
-  });
-  var init_ts_server = __esm({
-    "src/jsTyping/_namespaces/ts.server.ts"() {
-      "use strict";
-      init_shared();
-      init_types2();
-    }
-  });
-
-  // src/jsTyping/_namespaces/ts.ts
-  var init_ts3 = __esm({
-    "src/jsTyping/_namespaces/ts.ts"() {
-      "use strict";
-      init_ts2();
-      init_ts_JsTyping();
-      init_ts_server();
-    }
-  });
-
-  // src/services/types.ts
-  function getDefaultFormatCodeSettings(newLineCharacter) {
-    return {
-      indentSize: 4,
-      tabSize: 4,
-      newLineCharacter: newLineCharacter || "\n",
-      convertTabsToSpaces: true,
-      indentStyle: 2 /* Smart */,
-      insertSpaceAfterConstructor: false,
-      insertSpaceAfterCommaDelimiter: true,
-      insertSpaceAfterSemicolonInForStatements: true,
-      insertSpaceBeforeAndAfterBinaryOperators: true,
-      insertSpaceAfterKeywordsInControlFlowStatements: true,
-      insertSpaceAfterFunctionKeywordForAnonymousFunctions: false,
-      insertSpaceAfterOpeningAndBeforeClosingNonemptyParenthesis: false,
-      insertSpaceAfterOpeningAndBeforeClosingNonemptyBrackets: false,
-      insertSpaceAfterOpeningAndBeforeClosingNonemptyBraces: true,
-      insertSpaceAfterOpeningAndBeforeClosingTemplateStringBraces: false,
-      insertSpaceAfterOpeningAndBeforeClosingJsxExpressionBraces: false,
-      insertSpaceBeforeFunctionParenthesis: false,
-      placeOpenBraceOnNewLineForFunctions: false,
-      placeOpenBraceOnNewLineForControlBlocks: false,
-      semicolons: "ignore" /* Ignore */,
-      trimTrailingWhitespace: true,
-      indentSwitchCase: true
-    };
+  function createTextSpanFromRange(range) {
+    return createTextSpanFromBounds(range.pos, range.end);
   }
-  var ScriptSnapshot, PackageJsonDependencyGroup, PackageJsonAutoImportPreference, LanguageServiceMode, emptyOptions, SemanticClassificationFormat, OrganizeImportsMode, CompletionTriggerKind, InlayHintKind, HighlightSpanKind, IndentStyle, SemicolonPreference, testFormatSettings, SymbolDisplayPartKind, CompletionInfoFlags, OutliningSpanKind, OutputFileType, EndOfLineState, TokenClass, ScriptElementKind, ScriptElementKindModifier, ClassificationTypeNames, ClassificationType;
-  var init_types3 = __esm({
-    "src/services/types.ts"() {
-      "use strict";
-      ((ScriptSnapshot2) => {
-        class StringScriptSnapshot {
-          constructor(text) {
-            this.text = text;
-          }
-          getText(start, end) {
-            return start === 0 && end === this.text.length ? this.text : this.text.substring(start, end);
-          }
-          getLength() {
-            return this.text.length;
-          }
-          getChangeRange() {
-            return void 0;
-          }
-        }
-        function fromString(text) {
-          return new StringScriptSnapshot(text);
-        }
-        ScriptSnapshot2.fromString = fromString;
-      })(ScriptSnapshot || (ScriptSnapshot = {}));
-      PackageJsonDependencyGroup = /* @__PURE__ */ ((PackageJsonDependencyGroup2) => {
-        PackageJsonDependencyGroup2[PackageJsonDependencyGroup2["Dependencies"] = 1] = "Dependencies";
-        PackageJsonDependencyGroup2[PackageJsonDependencyGroup2["DevDependencies"] = 2] = "DevDependencies";
-        PackageJsonDependencyGroup2[PackageJsonDependencyGroup2["PeerDependencies"] = 4] = "PeerDependencies";
-        PackageJsonDependencyGroup2[PackageJsonDependencyGroup2["OptionalDependencies"] = 8] = "OptionalDependencies";
-        PackageJsonDependencyGroup2[PackageJsonDependencyGroup2["All"] = 15] = "All";
-        return PackageJsonDependencyGroup2;
-      })(PackageJsonDependencyGroup || {});
-      PackageJsonAutoImportPreference = /* @__PURE__ */ ((PackageJsonAutoImportPreference2) => {
-        PackageJsonAutoImportPreference2[PackageJsonAutoImportPreference2["Off"] = 0] = "Off";
-        PackageJsonAutoImportPreference2[PackageJsonAutoImportPreference2["On"] = 1] = "On";
-        PackageJsonAutoImportPreference2[PackageJsonAutoImportPreference2["Auto"] = 2] = "Auto";
-        return PackageJsonAutoImportPreference2;
-      })(PackageJsonAutoImportPreference || {});
-      LanguageServiceMode = /* @__PURE__ */ ((LanguageServiceMode2) => {
-        LanguageServiceMode2[LanguageServiceMode2["Semantic"] = 0] = "Semantic";
-        LanguageServiceMode2[LanguageServiceMode2["PartialSemantic"] = 1] = "PartialSemantic";
-        LanguageServiceMode2[LanguageServiceMode2["Syntactic"] = 2] = "Syntactic";
-        return LanguageServiceMode2;
-      })(LanguageServiceMode || {});
-      emptyOptions = {};
-      SemanticClassificationFormat = /* @__PURE__ */ ((SemanticClassificationFormat3) => {
-        SemanticClassificationFormat3["Original"] = "original";
-        SemanticClassificationFormat3["TwentyTwenty"] = "2020";
-        return SemanticClassificationFormat3;
-      })(SemanticClassificationFormat || {});
-      OrganizeImportsMode = /* @__PURE__ */ ((OrganizeImportsMode2) => {
-        OrganizeImportsMode2["All"] = "All";
-        OrganizeImportsMode2["SortAndCombine"] = "SortAndCombine";
-        OrganizeImportsMode2["RemoveUnused"] = "RemoveUnused";
-        return OrganizeImportsMode2;
-      })(OrganizeImportsMode || {});
-      CompletionTriggerKind = /* @__PURE__ */ ((CompletionTriggerKind2) => {
-        CompletionTriggerKind2[CompletionTriggerKind2["Invoked"] = 1] = "Invoked";
-        CompletionTriggerKind2[CompletionTriggerKind2["TriggerCharacter"] = 2] = "TriggerCharacter";
-        CompletionTriggerKind2[CompletionTriggerKind2["TriggerForIncompleteCompletions"] = 3] = "TriggerForIncompleteCompletions";
-        return CompletionTriggerKind2;
-      })(CompletionTriggerKind || {});
-      InlayHintKind = /* @__PURE__ */ ((InlayHintKind2) => {
-        InlayHintKind2["Type"] = "Type";
-        InlayHintKind2["Parameter"] = "Parameter";
-        InlayHintKind2["Enum"] = "Enum";
-        return InlayHintKind2;
-      })(InlayHintKind || {});
-      HighlightSpanKind = /* @__PURE__ */ ((HighlightSpanKind2) => {
-        HighlightSpanKind2["none"] = "none";
-        HighlightSpanKind2["definition"] = "definition";
-        HighlightSpanKind2["reference"] = "reference";
-        HighlightSpanKind2["writtenReference"] = "writtenReference";
-        return HighlightSpanKind2;
-      })(HighlightSpanKind || {});
-      IndentStyle = /* @__PURE__ */ ((IndentStyle2) => {
-        IndentStyle2[IndentStyle2["None"] = 0] = "None";
-        IndentStyle2[IndentStyle2["Block"] = 1] = "Block";
-        IndentStyle2[IndentStyle2["Smart"] = 2] = "Smart";
-        return IndentStyle2;
-      })(IndentStyle || {});
-      SemicolonPreference = /* @__PURE__ */ ((SemicolonPreference2) => {
-        SemicolonPreference2["Ignore"] = "ignore";
-        SemicolonPreference2["Insert"] = "insert";
-        SemicolonPreference2["Remove"] = "remove";
-        return SemicolonPreference2;
-      })(SemicolonPreference || {});
-      testFormatSettings = getDefaultFormatCodeSettings("\n");
-      SymbolDisplayPartKind = /* @__PURE__ */ ((SymbolDisplayPartKind2) => {
-        SymbolDisplayPartKind2[SymbolDisplayPartKind2["aliasName"] = 0] = "aliasName";
-        SymbolDisplayPartKind2[SymbolDisplayPartKind2["className"] = 1] = "className";
-        SymbolDisplayPartKind2[SymbolDisplayPartKind2["enumName"] = 2] = "enumName";
-        SymbolDisplayPartKind2[SymbolDisplayPartKind2["fieldName"] = 3] = "fieldName";
-        SymbolDisplayPartKind2[SymbolDisplayPartKind2["interfaceName"] = 4] = "interfaceName";
-        SymbolDisplayPartKind2[SymbolDisplayPartKind2["keyword"] = 5] = "keyword";
-        SymbolDisplayPartKind2[SymbolDisplayPartKind2["lineBreak"] = 6] = "lineBreak";
-        SymbolDisplayPartKind2[SymbolDisplayPartKind2["numericLiteral"] = 7] = "numericLiteral";
-        SymbolDisplayPartKind2[SymbolDisplayPartKind2["stringLiteral"] = 8] = "stringLiteral";
-        SymbolDisplayPartKind2[SymbolDisplayPartKind2["localName"] = 9] = "localName";
-        SymbolDisplayPartKind2[SymbolDisplayPartKind2["methodName"] = 10] = "methodName";
-        SymbolDisplayPartKind2[SymbolDisplayPartKind2["moduleName"] = 11] = "moduleName";
-        SymbolDisplayPartKind2[SymbolDisplayPartKind2["operator"] = 12] = "operator";
-        SymbolDisplayPartKind2[SymbolDisplayPartKind2["parameterName"] = 13] = "parameterName";
-        SymbolDisplayPartKind2[SymbolDisplayPartKind2["propertyName"] = 14] = "propertyName";
-        SymbolDisplayPartKind2[SymbolDisplayPartKind2["punctuation"] = 15] = "punctuation";
-        SymbolDisplayPartKind2[SymbolDisplayPartKind2["space"] = 16] = "space";
-        SymbolDisplayPartKind2[SymbolDisplayPartKind2["text"] = 17] = "text";
-        SymbolDisplayPartKind2[SymbolDisplayPartKind2["typeParameterName"] = 18] = "typeParameterName";
-        SymbolDisplayPartKind2[SymbolDisplayPartKind2["enumMemberName"] = 19] = "enumMemberName";
-        SymbolDisplayPartKind2[SymbolDisplayPartKind2["functionName"] = 20] = "functionName";
-        SymbolDisplayPartKind2[SymbolDisplayPartKind2["regularExpressionLiteral"] = 21] = "regularExpressionLiteral";
-        SymbolDisplayPartKind2[SymbolDisplayPartKind2["link"] = 22] = "link";
-        SymbolDisplayPartKind2[SymbolDisplayPartKind2["linkName"] = 23] = "linkName";
-        SymbolDisplayPartKind2[SymbolDisplayPartKind2["linkText"] = 24] = "linkText";
-        return SymbolDisplayPartKind2;
-      })(SymbolDisplayPartKind || {});
-      CompletionInfoFlags = /* @__PURE__ */ ((CompletionInfoFlags2) => {
-        CompletionInfoFlags2[CompletionInfoFlags2["None"] = 0] = "None";
-        CompletionInfoFlags2[CompletionInfoFlags2["MayIncludeAutoImports"] = 1] = "MayIncludeAutoImports";
-        CompletionInfoFlags2[CompletionInfoFlags2["IsImportStatementCompletion"] = 2] = "IsImportStatementCompletion";
-        CompletionInfoFlags2[CompletionInfoFlags2["IsContinuation"] = 4] = "IsContinuation";
-        CompletionInfoFlags2[CompletionInfoFlags2["ResolvedModuleSpecifiers"] = 8] = "ResolvedModuleSpecifiers";
-        CompletionInfoFlags2[CompletionInfoFlags2["ResolvedModuleSpecifiersBeyondLimit"] = 16] = "ResolvedModuleSpecifiersBeyondLimit";
-        CompletionInfoFlags2[CompletionInfoFlags2["MayIncludeMethodSnippets"] = 32] = "MayIncludeMethodSnippets";
-        return CompletionInfoFlags2;
-      })(CompletionInfoFlags || {});
-      OutliningSpanKind = /* @__PURE__ */ ((OutliningSpanKind2) => {
-        OutliningSpanKind2["Comment"] = "comment";
-        OutliningSpanKind2["Region"] = "region";
-        OutliningSpanKind2["Code"] = "code";
-        OutliningSpanKind2["Imports"] = "imports";
-        return OutliningSpanKind2;
-      })(OutliningSpanKind || {});
-      OutputFileType = /* @__PURE__ */ ((OutputFileType2) => {
-        OutputFileType2[OutputFileType2["JavaScript"] = 0] = "JavaScript";
-        OutputFileType2[OutputFileType2["SourceMap"] = 1] = "SourceMap";
-        OutputFileType2[OutputFileType2["Declaration"] = 2] = "Declaration";
-        return OutputFileType2;
-      })(OutputFileType || {});
-      EndOfLineState = /* @__PURE__ */ ((EndOfLineState3) => {
-        EndOfLineState3[EndOfLineState3["None"] = 0] = "None";
-        EndOfLineState3[EndOfLineState3["InMultiLineCommentTrivia"] = 1] = "InMultiLineCommentTrivia";
-        EndOfLineState3[EndOfLineState3["InSingleQuoteStringLiteral"] = 2] = "InSingleQuoteStringLiteral";
-        EndOfLineState3[EndOfLineState3["InDoubleQuoteStringLiteral"] = 3] = "InDoubleQuoteStringLiteral";
-        EndOfLineState3[EndOfLineState3["InTemplateHeadOrNoSubstitutionTemplate"] = 4] = "InTemplateHeadOrNoSubstitutionTemplate";
-        EndOfLineState3[EndOfLineState3["InTemplateMiddleOrTail"] = 5] = "InTemplateMiddleOrTail";
-        EndOfLineState3[EndOfLineState3["InTemplateSubstitutionPosition"] = 6] = "InTemplateSubstitutionPosition";
-        return EndOfLineState3;
-      })(EndOfLineState || {});
-      TokenClass = /* @__PURE__ */ ((TokenClass2) => {
-        TokenClass2[TokenClass2["Punctuation"] = 0] = "Punctuation";
-        TokenClass2[TokenClass2["Keyword"] = 1] = "Keyword";
-        TokenClass2[TokenClass2["Operator"] = 2] = "Operator";
-        TokenClass2[TokenClass2["Comment"] = 3] = "Comment";
-        TokenClass2[TokenClass2["Whitespace"] = 4] = "Whitespace";
-        TokenClass2[TokenClass2["Identifier"] = 5] = "Identifier";
-        TokenClass2[TokenClass2["NumberLiteral"] = 6] = "NumberLiteral";
-        TokenClass2[TokenClass2["BigIntLiteral"] = 7] = "BigIntLiteral";
-        TokenClass2[TokenClass2["StringLiteral"] = 8] = "StringLiteral";
-        TokenClass2[TokenClass2["RegExpLiteral"] = 9] = "RegExpLiteral";
-        return TokenClass2;
-      })(TokenClass || {});
-      ScriptElementKind = /* @__PURE__ */ ((ScriptElementKind2) => {
-        ScriptElementKind2["unknown"] = "";
-        ScriptElementKind2["warning"] = "warning";
-        ScriptElementKind2["keyword"] = "keyword";
-        ScriptElementKind2["scriptElement"] = "script";
-        ScriptElementKind2["moduleElement"] = "module";
-        ScriptElementKind2["classElement"] = "class";
-        ScriptElementKind2["localClassElement"] = "local class";
-        ScriptElementKind2["interfaceElement"] = "interface";
-        ScriptElementKind2["typeElement"] = "type";
-        ScriptElementKind2["enumElement"] = "enum";
-        ScriptElementKind2["enumMemberElement"] = "enum member";
-        ScriptElementKind2["variableElement"] = "var";
-        ScriptElementKind2["localVariableElement"] = "local var";
-        ScriptElementKind2["functionElement"] = "function";
-        ScriptElementKind2["localFunctionElement"] = "local function";
-        ScriptElementKind2["memberFunctionElement"] = "method";
-        ScriptElementKind2["memberGetAccessorElement"] = "getter";
-        ScriptElementKind2["memberSetAccessorElement"] = "setter";
-        ScriptElementKind2["memberVariableElement"] = "property";
-        ScriptElementKind2["memberAccessorVariableElement"] = "accessor";
-        ScriptElementKind2["constructorImplementationElement"] = "constructor";
-        ScriptElementKind2["callSignatureElement"] = "call";
-        ScriptElementKind2["indexSignatureElement"] = "index";
-        ScriptElementKind2["constructSignatureElement"] = "construct";
-        ScriptElementKind2["parameterElement"] = "parameter";
-        ScriptElementKind2["typeParameterElement"] = "type parameter";
-        ScriptElementKind2["primitiveType"] = "primitive type";
-        ScriptElementKind2["label"] = "label";
-        ScriptElementKind2["alias"] = "alias";
-        ScriptElementKind2["constElement"] = "const";
-        ScriptElementKind2["letElement"] = "let";
-        ScriptElementKind2["directory"] = "directory";
-        ScriptElementKind2["externalModuleName"] = "external module name";
-        ScriptElementKind2["jsxAttribute"] = "JSX attribute";
-        ScriptElementKind2["string"] = "string";
-        ScriptElementKind2["link"] = "link";
-        ScriptElementKind2["linkName"] = "link name";
-        ScriptElementKind2["linkText"] = "link text";
-        return ScriptElementKind2;
-      })(ScriptElementKind || {});
-      ScriptElementKindModifier = /* @__PURE__ */ ((ScriptElementKindModifier2) => {
-        ScriptElementKindModifier2["none"] = "";
-        ScriptElementKindModifier2["publicMemberModifier"] = "public";
-        ScriptElementKindModifier2["privateMemberModifier"] = "private";
-        ScriptElementKindModifier2["protectedMemberModifier"] = "protected";
-        ScriptElementKindModifier2["exportedModifier"] = "export";
-        ScriptElementKindModifier2["ambientModifier"] = "declare";
-        ScriptElementKindModifier2["staticModifier"] = "static";
-        ScriptElementKindModifier2["abstractModifier"] = "abstract";
-        ScriptElementKindModifier2["optionalModifier"] = "optional";
-        ScriptElementKindModifier2["deprecatedModifier"] = "deprecated";
-        ScriptElementKindModifier2["dtsModifier"] = ".d.ts";
-        ScriptElementKindModifier2["tsModifier"] = ".ts";
-        ScriptElementKindModifier2["tsxModifier"] = ".tsx";
-        ScriptElementKindModifier2["jsModifier"] = ".js";
-        ScriptElementKindModifier2["jsxModifier"] = ".jsx";
-        ScriptElementKindModifier2["jsonModifier"] = ".json";
-        ScriptElementKindModifier2["dmtsModifier"] = ".d.mts";
-        ScriptElementKindModifier2["mtsModifier"] = ".mts";
-        ScriptElementKindModifier2["mjsModifier"] = ".mjs";
-        ScriptElementKindModifier2["dctsModifier"] = ".d.cts";
-        ScriptElementKindModifier2["ctsModifier"] = ".cts";
-        ScriptElementKindModifier2["cjsModifier"] = ".cjs";
-        return ScriptElementKindModifier2;
-      })(ScriptElementKindModifier || {});
-      ClassificationTypeNames = /* @__PURE__ */ ((ClassificationTypeNames2) => {
-        ClassificationTypeNames2["comment"] = "comment";
-        ClassificationTypeNames2["identifier"] = "identifier";
-        ClassificationTypeNames2["keyword"] = "keyword";
-        ClassificationTypeNames2["numericLiteral"] = "number";
-        ClassificationTypeNames2["bigintLiteral"] = "bigint";
-        ClassificationTypeNames2["operator"] = "operator";
-        ClassificationTypeNames2["stringLiteral"] = "string";
-        ClassificationTypeNames2["whiteSpace"] = "whitespace";
-        ClassificationTypeNames2["text"] = "text";
-        ClassificationTypeNames2["punctuation"] = "punctuation";
-        ClassificationTypeNames2["className"] = "class name";
-        ClassificationTypeNames2["enumName"] = "enum name";
-        ClassificationTypeNames2["interfaceName"] = "interface name";
-        ClassificationTypeNames2["moduleName"] = "module name";
-        ClassificationTypeNames2["typeParameterName"] = "type parameter name";
-        ClassificationTypeNames2["typeAliasName"] = "type alias name";
-        ClassificationTypeNames2["parameterName"] = "parameter name";
-        ClassificationTypeNames2["docCommentTagName"] = "doc comment tag name";
-        ClassificationTypeNames2["jsxOpenTagName"] = "jsx open tag name";
-        ClassificationTypeNames2["jsxCloseTagName"] = "jsx close tag name";
-        ClassificationTypeNames2["jsxSelfClosingTagName"] = "jsx self closing tag name";
-        ClassificationTypeNames2["jsxAttribute"] = "jsx attribute";
-        ClassificationTypeNames2["jsxText"] = "jsx text";
-        ClassificationTypeNames2["jsxAttributeStringLiteralValue"] = "jsx attribute string literal value";
-        return ClassificationTypeNames2;
-      })(ClassificationTypeNames || {});
-      ClassificationType = /* @__PURE__ */ ((ClassificationType2) => {
-        ClassificationType2[ClassificationType2["comment"] = 1] = "comment";
-        ClassificationType2[ClassificationType2["identifier"] = 2] = "identifier";
-        ClassificationType2[ClassificationType2["keyword"] = 3] = "keyword";
-        ClassificationType2[ClassificationType2["numericLiteral"] = 4] = "numericLiteral";
-        ClassificationType2[ClassificationType2["operator"] = 5] = "operator";
-        ClassificationType2[ClassificationType2["stringLiteral"] = 6] = "stringLiteral";
-        ClassificationType2[ClassificationType2["regularExpressionLiteral"] = 7] = "regularExpressionLiteral";
-        ClassificationType2[ClassificationType2["whiteSpace"] = 8] = "whiteSpace";
-        ClassificationType2[ClassificationType2["text"] = 9] = "text";
-        ClassificationType2[ClassificationType2["punctuation"] = 10] = "punctuation";
-        ClassificationType2[ClassificationType2["className"] = 11] = "className";
-        ClassificationType2[ClassificationType2["enumName"] = 12] = "enumName";
-        ClassificationType2[ClassificationType2["interfaceName"] = 13] = "interfaceName";
-        ClassificationType2[ClassificationType2["moduleName"] = 14] = "moduleName";
-        ClassificationType2[ClassificationType2["typeParameterName"] = 15] = "typeParameterName";
-        ClassificationType2[ClassificationType2["typeAliasName"] = 16] = "typeAliasName";
-        ClassificationType2[ClassificationType2["parameterName"] = 17] = "parameterName";
-        ClassificationType2[ClassificationType2["docCommentTagName"] = 18] = "docCommentTagName";
-        ClassificationType2[ClassificationType2["jsxOpenTagName"] = 19] = "jsxOpenTagName";
-        ClassificationType2[ClassificationType2["jsxCloseTagName"] = 20] = "jsxCloseTagName";
-        ClassificationType2[ClassificationType2["jsxSelfClosingTagName"] = 21] = "jsxSelfClosingTagName";
-        ClassificationType2[ClassificationType2["jsxAttribute"] = 22] = "jsxAttribute";
-        ClassificationType2[ClassificationType2["jsxText"] = 23] = "jsxText";
-        ClassificationType2[ClassificationType2["jsxAttributeStringLiteralValue"] = 24] = "jsxAttributeStringLiteralValue";
-        ClassificationType2[ClassificationType2["bigintLiteral"] = 25] = "bigintLiteral";
-        return ClassificationType2;
-      })(ClassificationType || {});
-    }
-  });
-
-  // src/services/utilities.ts
-  function getMeaningFromDeclaration(node) {
-    switch (node.kind) {
-      case 259 /* VariableDeclaration */:
-        return isInJSFile(node) && getJSDocEnumTag(node) ? 7 /* All */ : 1 /* Value */;
-      case 168 /* Parameter */:
-      case 207 /* BindingElement */:
-      case 171 /* PropertyDeclaration */:
-      case 170 /* PropertySignature */:
-      case 302 /* PropertyAssignment */:
-      case 303 /* ShorthandPropertyAssignment */:
-      case 173 /* MethodDeclaration */:
-      case 172 /* MethodSignature */:
-      case 175 /* Constructor */:
-      case 176 /* GetAccessor */:
-      case 177 /* SetAccessor */:
-      case 261 /* FunctionDeclaration */:
-      case 217 /* FunctionExpression */:
-      case 218 /* ArrowFunction */:
-      case 298 /* CatchClause */:
-      case 290 /* JsxAttribute */:
-        return 1 /* Value */;
-      case 167 /* TypeParameter */:
-      case 263 /* InterfaceDeclaration */:
-      case 264 /* TypeAliasDeclaration */:
-      case 186 /* TypeLiteral */:
-        return 2 /* Type */;
-      case 352 /* JSDocTypedefTag */:
-        return node.name === void 0 ? 1 /* Value */ | 2 /* Type */ : 2 /* Type */;
-      case 305 /* EnumMember */:
-      case 262 /* ClassDeclaration */:
-        return 1 /* Value */ | 2 /* Type */;
-      case 266 /* ModuleDeclaration */:
-        if (isAmbientModule(node)) {
-          return 4 /* Namespace */ | 1 /* Value */;
-        } else if (getModuleInstanceState(node) === 1 /* Instantiated */) {
-          return 4 /* Namespace */ | 1 /* Value */;
-        } else {
-          return 4 /* Namespace */;
-        }
-      case 265 /* EnumDeclaration */:
-      case 274 /* NamedImports */:
-      case 275 /* ImportSpecifier */:
-      case 270 /* ImportEqualsDeclaration */:
-      case 271 /* ImportDeclaration */:
-      case 276 /* ExportAssignment */:
-      case 277 /* ExportDeclaration */:
-        return 7 /* All */;
-      case 311 /* SourceFile */:
-        return 4 /* Namespace */ | 1 /* Value */;
+  function createTextRangeFromSpan(span) {
+    return createRange(span.start, span.start + span.length);
+  }
+  function createTextChangeFromStartLength(start, length2, newText) {
+    return createTextChange(createTextSpan(start, length2), newText);
+  }
+  function createTextChange(span, newText) {
+    return { span, newText };
+  }
+  function isTypeKeyword(kind) {
+    return contains(typeKeywords, kind);
+  }
+  function isTypeKeywordToken(node) {
+    return node.kind === 156 /* TypeKeyword */;
+  }
+  function isTypeKeywordTokenOrIdentifier(node) {
+    return isTypeKeywordToken(node) || isIdentifier(node) && node.text === "type";
+  }
+  function isExternalModuleSymbol(moduleSymbol) {
+    return !!(moduleSymbol.flags & 1536 /* Module */) && moduleSymbol.name.charCodeAt(0) === 34 /* doubleQuote */;
+  }
+  function nodeSeenTracker() {
+    const seen = [];
+    return (node) => {
+      const id = getNodeId(node);
+      return !seen[id] && (seen[id] = true);
+    };
+  }
+  function getSnapshotText(snap) {
+    return snap.getText(0, snap.getLength());
+  }
+  function repeatString(str, count) {
+    let result = "";
+    for (let i = 0; i < count; i++) {
+      result += str;
     }
-    return 7 /* All */;
+    return result;
   }
-  function getMeaningFromLocation(node) {
-    node = getAdjustedReferenceLocation(node);
-    const parent2 = node.parent;
-    if (node.kind === 311 /* SourceFile */) {
-      return 1 /* Value */;
-    } else if (isExportAssignment(parent2) || isExportSpecifier(parent2) || isExternalModuleReference(parent2) || isImportSpecifier(parent2) || isImportClause(parent2) || isImportEqualsDeclaration(parent2) && node === parent2.name) {
-      return 7 /* All */;
-    } else if (isInRightSideOfInternalImportEqualsDeclaration(node)) {
-      return getMeaningFromRightHandSideOfImportEquals(node);
-    } else if (isDeclarationName(node)) {
-      return getMeaningFromDeclaration(parent2);
-    } else if (isEntityName(node) && findAncestor(node, or(isJSDocNameReference, isJSDocLinkLike, isJSDocMemberName))) {
-      return 7 /* All */;
-    } else if (isTypeReference(node)) {
-      return 2 /* Type */;
-    } else if (isNamespaceReference(node)) {
-      return 4 /* Namespace */;
-    } else if (isTypeParameterDeclaration(parent2)) {
-      Debug.assert(isJSDocTemplateTag(parent2.parent));
-      return 2 /* Type */;
-    } else if (isLiteralTypeNode(parent2)) {
-      return 2 /* Type */ | 1 /* Value */;
+  function skipConstraint(type) {
+    return type.isTypeParameter() ? type.getConstraint() || type : type;
+  }
+  function getNameFromPropertyName(name) {
+    return name.kind === 167 /* ComputedPropertyName */ ? isStringOrNumericLiteralLike(name.expression) ? name.expression.text : void 0 : isPrivateIdentifier(name) ? idText(name) : getTextOfIdentifierOrLiteral(name);
+  }
+  function programContainsModules(program) {
+    return program.getSourceFiles().some((s) => !s.isDeclarationFile && !program.isSourceFileFromExternalLibrary(s) && !!(s.externalModuleIndicator || s.commonJsModuleIndicator));
+  }
+  function programContainsEsModules(program) {
+    return program.getSourceFiles().some((s) => !s.isDeclarationFile && !program.isSourceFileFromExternalLibrary(s) && !!s.externalModuleIndicator);
+  }
+  function compilerOptionsIndicateEsModules(compilerOptions) {
+    return !!compilerOptions.module || getEmitScriptTarget(compilerOptions) >= 2 /* ES2015 */ || !!compilerOptions.noEmit;
+  }
+  function createModuleSpecifierResolutionHost(program, host) {
+    return {
+      fileExists: (fileName) => program.fileExists(fileName),
+      getCurrentDirectory: () => host.getCurrentDirectory(),
+      readFile: maybeBind(host, host.readFile),
+      useCaseSensitiveFileNames: maybeBind(host, host.useCaseSensitiveFileNames),
+      getSymlinkCache: maybeBind(host, host.getSymlinkCache) || program.getSymlinkCache,
+      getModuleSpecifierCache: maybeBind(host, host.getModuleSpecifierCache),
+      getPackageJsonInfoCache: () => {
+        var _a;
+        return (_a = program.getModuleResolutionCache()) == null ? void 0 : _a.getPackageJsonInfoCache();
+      },
+      getGlobalTypingsCacheLocation: maybeBind(host, host.getGlobalTypingsCacheLocation),
+      redirectTargetsMap: program.redirectTargetsMap,
+      getProjectReferenceRedirect: (fileName) => program.getProjectReferenceRedirect(fileName),
+      isSourceOfProjectReferenceRedirect: (fileName) => program.isSourceOfProjectReferenceRedirect(fileName),
+      getNearestAncestorDirectoryWithPackageJson: maybeBind(host, host.getNearestAncestorDirectoryWithPackageJson),
+      getFileIncludeReasons: () => program.getFileIncludeReasons()
+    };
+  }
+  function getModuleSpecifierResolverHost(program, host) {
+    return {
+      ...createModuleSpecifierResolutionHost(program, host),
+      getCommonSourceDirectory: () => program.getCommonSourceDirectory()
+    };
+  }
+  function moduleResolutionUsesNodeModules(moduleResolution) {
+    return moduleResolution === 2 /* Node10 */ || moduleResolution >= 3 /* Node16 */ && moduleResolution <= 99 /* NodeNext */ || moduleResolution === 100 /* Bundler */;
+  }
+  function makeImportIfNecessary(defaultImport, namedImports, moduleSpecifier, quotePreference) {
+    return defaultImport || namedImports && namedImports.length ? makeImport(defaultImport, namedImports, moduleSpecifier, quotePreference) : void 0;
+  }
+  function makeImport(defaultImport, namedImports, moduleSpecifier, quotePreference, isTypeOnly) {
+    return factory.createImportDeclaration(
+      /*modifiers*/
+      void 0,
+      defaultImport || namedImports ? factory.createImportClause(!!isTypeOnly, defaultImport, namedImports && namedImports.length ? factory.createNamedImports(namedImports) : void 0) : void 0,
+      typeof moduleSpecifier === "string" ? makeStringLiteral(moduleSpecifier, quotePreference) : moduleSpecifier,
+      /*attributes*/
+      void 0
+    );
+  }
+  function makeStringLiteral(text, quotePreference) {
+    return factory.createStringLiteral(text, quotePreference === 0 /* Single */);
+  }
+  function quotePreferenceFromString(str, sourceFile) {
+    return isStringDoubleQuoted(str, sourceFile) ? 1 /* Double */ : 0 /* Single */;
+  }
+  function getQuotePreference(sourceFile, preferences) {
+    if (preferences.quotePreference && preferences.quotePreference !== "auto") {
+      return preferences.quotePreference === "single" ? 0 /* Single */ : 1 /* Double */;
     } else {
-      return 1 /* Value */;
+      const firstModuleSpecifier = sourceFile.imports && find(sourceFile.imports, (n) => isStringLiteral(n) && !nodeIsSynthesized(n.parent));
+      return firstModuleSpecifier ? quotePreferenceFromString(firstModuleSpecifier, sourceFile) : 1 /* Double */;
     }
   }
-  function getMeaningFromRightHandSideOfImportEquals(node) {
-    const name = node.kind === 165 /* QualifiedName */ ? node : isQualifiedName(node.parent) && node.parent.right === node ? node.parent : void 0;
-    return name && name.parent.kind === 270 /* ImportEqualsDeclaration */ ? 7 /* All */ : 4 /* Namespace */;
+  function getQuoteFromPreference(qp) {
+    switch (qp) {
+      case 0 /* Single */:
+        return "'";
+      case 1 /* Double */:
+        return '"';
+      default:
+        return Debug.assertNever(qp);
+    }
   }
-  function isInRightSideOfInternalImportEqualsDeclaration(node) {
-    while (node.parent.kind === 165 /* QualifiedName */) {
+  function symbolNameNoDefault(symbol) {
+    const escaped = symbolEscapedNameNoDefault(symbol);
+    return escaped === void 0 ? void 0 : unescapeLeadingUnderscores(escaped);
+  }
+  function symbolEscapedNameNoDefault(symbol) {
+    if (symbol.escapedName !== "default" /* Default */) {
+      return symbol.escapedName;
+    }
+    return firstDefined(symbol.declarations, (decl) => {
+      const name = getNameOfDeclaration(decl);
+      return name && name.kind === 80 /* Identifier */ ? name.escapedText : void 0;
+    });
+  }
+  function isModuleSpecifierLike(node) {
+    return isStringLiteralLike(node) && (isExternalModuleReference(node.parent) || isImportDeclaration(node.parent) || isRequireCall(
+      node.parent,
+      /*requireStringLiteralLikeArgument*/
+      false
+    ) && node.parent.arguments[0] === node || isImportCall(node.parent) && node.parent.arguments[0] === node);
+  }
+  function isObjectBindingElementWithoutPropertyName(bindingElement) {
+    return isBindingElement(bindingElement) && isObjectBindingPattern(bindingElement.parent) && isIdentifier(bindingElement.name) && !bindingElement.propertyName;
+  }
+  function getPropertySymbolFromBindingElement(checker, bindingElement) {
+    const typeOfPattern = checker.getTypeAtLocation(bindingElement.parent);
+    return typeOfPattern && checker.getPropertyOfType(typeOfPattern, bindingElement.name.text);
+  }
+  function getParentNodeInSpan(node, file, span) {
+    if (!node)
+      return void 0;
+    while (node.parent) {
+      if (isSourceFile(node.parent) || !spanContainsNode(span, node.parent, file)) {
+        return node;
+      }
       node = node.parent;
     }
-    return isInternalModuleImportEqualsDeclaration(node.parent) && node.parent.moduleReference === node;
   }
-  function isNamespaceReference(node) {
-    return isQualifiedNameNamespaceReference(node) || isPropertyAccessNamespaceReference(node);
+  function spanContainsNode(span, node, file) {
+    return textSpanContainsPosition(span, node.getStart(file)) && node.getEnd() <= textSpanEnd(span);
   }
-  function isQualifiedNameNamespaceReference(node) {
-    let root = node;
-    let isLastClause = true;
-    if (root.parent.kind === 165 /* QualifiedName */) {
-      while (root.parent && root.parent.kind === 165 /* QualifiedName */) {
-        root = root.parent;
+  function findModifier(node, kind) {
+    return canHaveModifiers(node) ? find(node.modifiers, (m) => m.kind === kind) : void 0;
+  }
+  function insertImports(changes, sourceFile, imports, blankLineBetween, preferences) {
+    const decl = isArray(imports) ? imports[0] : imports;
+    const importKindPredicate = decl.kind === 243 /* VariableStatement */ ? isRequireVariableStatement : isAnyImportSyntax;
+    const existingImportStatements = filter(sourceFile.statements, importKindPredicate);
+    let sortKind = isArray(imports) ? ts_OrganizeImports_exports.detectImportDeclarationSorting(imports, preferences) : 3 /* Both */;
+    const comparer = ts_OrganizeImports_exports.getOrganizeImportsComparer(preferences, sortKind === 2 /* CaseInsensitive */);
+    const sortedNewImports = isArray(imports) ? stableSort(imports, (a, b) => ts_OrganizeImports_exports.compareImportsOrRequireStatements(a, b, comparer)) : [imports];
+    if (!existingImportStatements.length) {
+      changes.insertNodesAtTopOfFile(sourceFile, sortedNewImports, blankLineBetween);
+    } else if (existingImportStatements && (sortKind = ts_OrganizeImports_exports.detectImportDeclarationSorting(existingImportStatements, preferences))) {
+      const comparer2 = ts_OrganizeImports_exports.getOrganizeImportsComparer(preferences, sortKind === 2 /* CaseInsensitive */);
+      for (const newImport of sortedNewImports) {
+        const insertionIndex = ts_OrganizeImports_exports.getImportDeclarationInsertionIndex(existingImportStatements, newImport, comparer2);
+        if (insertionIndex === 0) {
+          const options = existingImportStatements[0] === sourceFile.statements[0] ? { leadingTriviaOption: ts_textChanges_exports.LeadingTriviaOption.Exclude } : {};
+          changes.insertNodeBefore(
+            sourceFile,
+            existingImportStatements[0],
+            newImport,
+            /*blankLineBetween*/
+            false,
+            options
+          );
+        } else {
+          const prevImport = existingImportStatements[insertionIndex - 1];
+          changes.insertNodeAfter(sourceFile, prevImport, newImport);
+        }
+      }
+    } else {
+      const lastExistingImport = lastOrUndefined(existingImportStatements);
+      if (lastExistingImport) {
+        changes.insertNodesAfter(sourceFile, lastExistingImport, sortedNewImports);
+      } else {
+        changes.insertNodesAtTopOfFile(sourceFile, sortedNewImports, blankLineBetween);
       }
-      isLastClause = root.right === node;
     }
-    return root.parent.kind === 182 /* TypeReference */ && !isLastClause;
   }
-  function isPropertyAccessNamespaceReference(node) {
-    let root = node;
-    let isLastClause = true;
-    if (root.parent.kind === 210 /* PropertyAccessExpression */) {
-      while (root.parent && root.parent.kind === 210 /* PropertyAccessExpression */) {
-        root = root.parent;
+  function getTypeKeywordOfTypeOnlyImport(importClause, sourceFile) {
+    Debug.assert(importClause.isTypeOnly);
+    return cast(importClause.getChildAt(0, sourceFile), isTypeKeywordToken);
+  }
+  function textSpansEqual(a, b) {
+    return !!a && !!b && a.start === b.start && a.length === b.length;
+  }
+  function documentSpansEqual(a, b) {
+    return a.fileName === b.fileName && textSpansEqual(a.textSpan, b.textSpan);
+  }
+  function forEachUnique(array, callback) {
+    if (array) {
+      for (let i = 0; i < array.length; i++) {
+        if (array.indexOf(array[i]) === i) {
+          const result = callback(array[i], i);
+          if (result) {
+            return result;
+          }
+        }
       }
-      isLastClause = root.name === node;
     }
-    if (!isLastClause && root.parent.kind === 232 /* ExpressionWithTypeArguments */ && root.parent.parent.kind === 297 /* HeritageClause */) {
-      const decl = root.parent.parent.parent;
-      return decl.kind === 262 /* ClassDeclaration */ && root.parent.parent.token === 119 /* ImplementsKeyword */ || decl.kind === 263 /* InterfaceDeclaration */ && root.parent.parent.token === 96 /* ExtendsKeyword */;
+    return void 0;
+  }
+  function isTextWhiteSpaceLike(text, startPos, endPos) {
+    for (let i = startPos; i < endPos; i++) {
+      if (!isWhiteSpaceLike(text.charCodeAt(i))) {
+        return false;
+      }
     }
-    return false;
+    return true;
   }
-  function isTypeReference(node) {
-    if (isRightSideOfQualifiedNameOrPropertyAccess(node)) {
-      node = node.parent;
+  function getMappedLocation(location, sourceMapper, fileExists) {
+    const mapsTo = sourceMapper.tryGetSourcePosition(location);
+    return mapsTo && (!fileExists || fileExists(normalizePath(mapsTo.fileName)) ? mapsTo : void 0);
+  }
+  function getMappedDocumentSpan(documentSpan, sourceMapper, fileExists) {
+    const { fileName, textSpan } = documentSpan;
+    const newPosition = getMappedLocation({ fileName, pos: textSpan.start }, sourceMapper, fileExists);
+    if (!newPosition)
+      return void 0;
+    const newEndPosition = getMappedLocation({ fileName, pos: textSpan.start + textSpan.length }, sourceMapper, fileExists);
+    const newLength = newEndPosition ? newEndPosition.pos - newPosition.pos : textSpan.length;
+    return {
+      fileName: newPosition.fileName,
+      textSpan: {
+        start: newPosition.pos,
+        length: newLength
+      },
+      originalFileName: documentSpan.fileName,
+      originalTextSpan: documentSpan.textSpan,
+      contextSpan: getMappedContextSpan(documentSpan, sourceMapper, fileExists),
+      originalContextSpan: documentSpan.contextSpan
+    };
+  }
+  function getMappedContextSpan(documentSpan, sourceMapper, fileExists) {
+    const contextSpanStart = documentSpan.contextSpan && getMappedLocation(
+      { fileName: documentSpan.fileName, pos: documentSpan.contextSpan.start },
+      sourceMapper,
+      fileExists
+    );
+    const contextSpanEnd = documentSpan.contextSpan && getMappedLocation(
+      { fileName: documentSpan.fileName, pos: documentSpan.contextSpan.start + documentSpan.contextSpan.length },
+      sourceMapper,
+      fileExists
+    );
+    return contextSpanStart && contextSpanEnd ? { start: contextSpanStart.pos, length: contextSpanEnd.pos - contextSpanStart.pos } : void 0;
+  }
+  function isFirstDeclarationOfSymbolParameter(symbol) {
+    const declaration = symbol.declarations ? firstOrUndefined(symbol.declarations) : void 0;
+    return !!findAncestor(declaration, (n) => isParameter(n) ? true : isBindingElement(n) || isObjectBindingPattern(n) || isArrayBindingPattern(n) ? false : "quit");
+  }
+  function getDisplayPartWriter() {
+    const absoluteMaximumLength = defaultMaximumTruncationLength * 10;
+    let displayParts;
+    let lineStart;
+    let indent3;
+    let length2;
+    resetWriter();
+    const unknownWrite = (text) => writeKind(text, 17 /* text */);
+    return {
+      displayParts: () => {
+        const finalText = displayParts.length && displayParts[displayParts.length - 1].text;
+        if (length2 > absoluteMaximumLength && finalText && finalText !== "...") {
+          if (!isWhiteSpaceLike(finalText.charCodeAt(finalText.length - 1))) {
+            displayParts.push(displayPart(" ", 16 /* space */));
+          }
+          displayParts.push(displayPart("...", 15 /* punctuation */));
+        }
+        return displayParts;
+      },
+      writeKeyword: (text) => writeKind(text, 5 /* keyword */),
+      writeOperator: (text) => writeKind(text, 12 /* operator */),
+      writePunctuation: (text) => writeKind(text, 15 /* punctuation */),
+      writeTrailingSemicolon: (text) => writeKind(text, 15 /* punctuation */),
+      writeSpace: (text) => writeKind(text, 16 /* space */),
+      writeStringLiteral: (text) => writeKind(text, 8 /* stringLiteral */),
+      writeParameter: (text) => writeKind(text, 13 /* parameterName */),
+      writeProperty: (text) => writeKind(text, 14 /* propertyName */),
+      writeLiteral: (text) => writeKind(text, 8 /* stringLiteral */),
+      writeSymbol,
+      writeLine,
+      write: unknownWrite,
+      writeComment: unknownWrite,
+      getText: () => "",
+      getTextPos: () => 0,
+      getColumn: () => 0,
+      getLine: () => 0,
+      isAtStartOfLine: () => false,
+      hasTrailingWhitespace: () => false,
+      hasTrailingComment: () => false,
+      rawWrite: notImplemented,
+      getIndent: () => indent3,
+      increaseIndent: () => {
+        indent3++;
+      },
+      decreaseIndent: () => {
+        indent3--;
+      },
+      clear: resetWriter
+    };
+    function writeIndent() {
+      if (length2 > absoluteMaximumLength)
+        return;
+      if (lineStart) {
+        const indentString = getIndentString(indent3);
+        if (indentString) {
+          length2 += indentString.length;
+          displayParts.push(displayPart(indentString, 16 /* space */));
+        }
+        lineStart = false;
+      }
     }
-    switch (node.kind) {
-      case 110 /* ThisKeyword */:
-        return !isExpressionNode(node);
-      case 196 /* ThisType */:
-        return true;
+    function writeKind(text, kind) {
+      if (length2 > absoluteMaximumLength)
+        return;
+      writeIndent();
+      length2 += text.length;
+      displayParts.push(displayPart(text, kind));
     }
-    switch (node.parent.kind) {
-      case 182 /* TypeReference */:
-        return true;
-      case 204 /* ImportType */:
-        return !node.parent.isTypeOf;
-      case 232 /* ExpressionWithTypeArguments */:
-        return isPartOfTypeNode(node.parent);
+    function writeSymbol(text, symbol) {
+      if (length2 > absoluteMaximumLength)
+        return;
+      writeIndent();
+      length2 += text.length;
+      displayParts.push(symbolPart(text, symbol));
+    }
+    function writeLine() {
+      if (length2 > absoluteMaximumLength)
+        return;
+      length2 += 1;
+      displayParts.push(lineBreakPart());
+      lineStart = true;
+    }
+    function resetWriter() {
+      displayParts = [];
+      lineStart = true;
+      indent3 = 0;
+      length2 = 0;
     }
-    return false;
   }
-  function isCallExpressionTarget(node, includeElementAccess = false, skipPastOuterExpressions = false) {
-    return isCalleeWorker(node, isCallExpression, selectExpressionOfCallOrNewExpressionOrDecorator, includeElementAccess, skipPastOuterExpressions);
+  function symbolPart(text, symbol) {
+    return displayPart(text, displayPartKind(symbol));
+    function displayPartKind(symbol2) {
+      const flags = symbol2.flags;
+      if (flags & 3 /* Variable */) {
+        return isFirstDeclarationOfSymbolParameter(symbol2) ? 13 /* parameterName */ : 9 /* localName */;
+      }
+      if (flags & 4 /* Property */)
+        return 14 /* propertyName */;
+      if (flags & 32768 /* GetAccessor */)
+        return 14 /* propertyName */;
+      if (flags & 65536 /* SetAccessor */)
+        return 14 /* propertyName */;
+      if (flags & 8 /* EnumMember */)
+        return 19 /* enumMemberName */;
+      if (flags & 16 /* Function */)
+        return 20 /* functionName */;
+      if (flags & 32 /* Class */)
+        return 1 /* className */;
+      if (flags & 64 /* Interface */)
+        return 4 /* interfaceName */;
+      if (flags & 384 /* Enum */)
+        return 2 /* enumName */;
+      if (flags & 1536 /* Module */)
+        return 11 /* moduleName */;
+      if (flags & 8192 /* Method */)
+        return 10 /* methodName */;
+      if (flags & 262144 /* TypeParameter */)
+        return 18 /* typeParameterName */;
+      if (flags & 524288 /* TypeAlias */)
+        return 0 /* aliasName */;
+      if (flags & 2097152 /* Alias */)
+        return 0 /* aliasName */;
+      return 17 /* text */;
+    }
   }
-  function isNewExpressionTarget(node, includeElementAccess = false, skipPastOuterExpressions = false) {
-    return isCalleeWorker(node, isNewExpression, selectExpressionOfCallOrNewExpressionOrDecorator, includeElementAccess, skipPastOuterExpressions);
+  function displayPart(text, kind) {
+    return { text, kind: SymbolDisplayPartKind[kind] };
   }
-  function isCallOrNewExpressionTarget(node, includeElementAccess = false, skipPastOuterExpressions = false) {
-    return isCalleeWorker(node, isCallOrNewExpression, selectExpressionOfCallOrNewExpressionOrDecorator, includeElementAccess, skipPastOuterExpressions);
+  function spacePart() {
+    return displayPart(" ", 16 /* space */);
   }
-  function isTaggedTemplateTag(node, includeElementAccess = false, skipPastOuterExpressions = false) {
-    return isCalleeWorker(node, isTaggedTemplateExpression, selectTagOfTaggedTemplateExpression, includeElementAccess, skipPastOuterExpressions);
+  function keywordPart(kind) {
+    return displayPart(tokenToString(kind), 5 /* keyword */);
   }
-  function isDecoratorTarget(node, includeElementAccess = false, skipPastOuterExpressions = false) {
-    return isCalleeWorker(node, isDecorator, selectExpressionOfCallOrNewExpressionOrDecorator, includeElementAccess, skipPastOuterExpressions);
+  function punctuationPart(kind) {
+    return displayPart(tokenToString(kind), 15 /* punctuation */);
   }
-  function isJsxOpeningLikeElementTagName(node, includeElementAccess = false, skipPastOuterExpressions = false) {
-    return isCalleeWorker(node, isJsxOpeningLikeElement, selectTagNameOfJsxOpeningLikeElement, includeElementAccess, skipPastOuterExpressions);
+  function operatorPart(kind) {
+    return displayPart(tokenToString(kind), 12 /* operator */);
   }
-  function selectExpressionOfCallOrNewExpressionOrDecorator(node) {
-    return node.expression;
+  function parameterNamePart(text) {
+    return displayPart(text, 13 /* parameterName */);
   }
-  function selectTagOfTaggedTemplateExpression(node) {
-    return node.tag;
+  function propertyNamePart(text) {
+    return displayPart(text, 14 /* propertyName */);
   }
-  function selectTagNameOfJsxOpeningLikeElement(node) {
-    return node.tagName;
+  function textOrKeywordPart(text) {
+    const kind = stringToToken(text);
+    return kind === void 0 ? textPart(text) : keywordPart(kind);
   }
-  function isCalleeWorker(node, pred, calleeSelector, includeElementAccess, skipPastOuterExpressions) {
-    let target = includeElementAccess ? climbPastPropertyOrElementAccess(node) : climbPastPropertyAccess(node);
-    if (skipPastOuterExpressions) {
-      target = skipOuterExpressions(target);
-    }
-    return !!target && !!target.parent && pred(target.parent) && calleeSelector(target.parent) === target;
+  function textPart(text) {
+    return displayPart(text, 17 /* text */);
   }
-  function climbPastPropertyAccess(node) {
-    return isRightSideOfPropertyAccess(node) ? node.parent : node;
+  function typeAliasNamePart(text) {
+    return displayPart(text, 0 /* aliasName */);
   }
-  function climbPastPropertyOrElementAccess(node) {
-    return isRightSideOfPropertyAccess(node) || isArgumentExpressionOfElementAccess(node) ? node.parent : node;
+  function typeParameterNamePart(text) {
+    return displayPart(text, 18 /* typeParameterName */);
   }
-  function getTargetLabel(referenceNode, labelName) {
-    while (referenceNode) {
-      if (referenceNode.kind === 255 /* LabeledStatement */ && referenceNode.label.escapedText === labelName) {
-        return referenceNode.label;
+  function linkTextPart(text) {
+    return displayPart(text, 24 /* linkText */);
+  }
+  function linkNamePart(text, target) {
+    return {
+      text,
+      kind: SymbolDisplayPartKind[23 /* linkName */],
+      target: {
+        fileName: getSourceFileOfNode(target).fileName,
+        textSpan: createTextSpanFromNode(target)
+      }
+    };
+  }
+  function linkPart(text) {
+    return displayPart(text, 22 /* link */);
+  }
+  function buildLinkParts(link, checker) {
+    var _a;
+    const prefix = isJSDocLink(link) ? "link" : isJSDocLinkCode(link) ? "linkcode" : "linkplain";
+    const parts = [linkPart(`{@${prefix} `)];
+    if (!link.name) {
+      if (link.text) {
+        parts.push(linkTextPart(link.text));
+      }
+    } else {
+      const symbol = checker == null ? void 0 : checker.getSymbolAtLocation(link.name);
+      const suffix = findLinkNameEnd(link.text);
+      const name = getTextOfNode(link.name) + link.text.slice(0, suffix);
+      const text = skipSeparatorFromLinkText(link.text.slice(suffix));
+      const decl = (symbol == null ? void 0 : symbol.valueDeclaration) || ((_a = symbol == null ? void 0 : symbol.declarations) == null ? void 0 : _a[0]);
+      if (decl) {
+        parts.push(linkNamePart(name, decl));
+        if (text)
+          parts.push(linkTextPart(text));
+      } else {
+        parts.push(linkTextPart(name + (suffix ? "" : " ") + text));
       }
-      referenceNode = referenceNode.parent;
     }
-    return void 0;
+    parts.push(linkPart("}"));
+    return parts;
   }
-  function hasPropertyAccessExpressionWithName(node, funcName) {
-    if (!isPropertyAccessExpression(node.expression)) {
-      return false;
+  function skipSeparatorFromLinkText(text) {
+    let pos = 0;
+    if (text.charCodeAt(pos++) === 124 /* bar */) {
+      while (pos < text.length && text.charCodeAt(pos) === 32 /* space */)
+        pos++;
+      return text.slice(pos);
     }
-    return node.expression.name.text === funcName;
+    return text;
   }
-  function isJumpStatementTarget(node) {
-    var _a;
-    return isIdentifier(node) && ((_a = tryCast(node.parent, isBreakOrContinueStatement)) == null ? void 0 : _a.label) === node;
+  function findLinkNameEnd(text) {
+    let pos = text.indexOf("://");
+    if (pos === 0) {
+      while (pos < text.length && text.charCodeAt(pos) !== 124 /* bar */)
+        pos++;
+      return pos;
+    }
+    if (text.indexOf("()") === 0)
+      return 2;
+    if (text.charAt(0) === "<") {
+      let brackets2 = 0;
+      let i = 0;
+      while (i < text.length) {
+        if (text[i] === "<")
+          brackets2++;
+        if (text[i] === ">")
+          brackets2--;
+        i++;
+        if (!brackets2)
+          return i;
+      }
+    }
+    return 0;
   }
-  function isLabelOfLabeledStatement(node) {
+  function getNewLineOrDefaultFromHost(host, formatSettings) {
     var _a;
-    return isIdentifier(node) && ((_a = tryCast(node.parent, isLabeledStatement)) == null ? void 0 : _a.label) === node;
+    return (formatSettings == null ? void 0 : formatSettings.newLineCharacter) || ((_a = host.getNewLine) == null ? void 0 : _a.call(host)) || lineFeed2;
   }
-  function isLabelName(node) {
-    return isLabelOfLabeledStatement(node) || isJumpStatementTarget(node);
+  function lineBreakPart() {
+    return displayPart("\n", 6 /* lineBreak */);
   }
-  function isTagName(node) {
-    var _a;
-    return ((_a = tryCast(node.parent, isJSDocTag)) == null ? void 0 : _a.tagName) === node;
+  function mapToDisplayParts(writeDisplayParts) {
+    try {
+      writeDisplayParts(displayPartWriter);
+      return displayPartWriter.displayParts();
+    } finally {
+      displayPartWriter.clear();
+    }
   }
-  function isRightSideOfQualifiedName(node) {
-    var _a;
-    return ((_a = tryCast(node.parent, isQualifiedName)) == null ? void 0 : _a.right) === node;
+  function typeToDisplayParts(typechecker, type, enclosingDeclaration, flags = 0 /* None */) {
+    return mapToDisplayParts((writer) => {
+      typechecker.writeType(type, enclosingDeclaration, flags | 1024 /* MultilineObjectLiterals */ | 16384 /* UseAliasDefinedOutsideCurrentScope */, writer);
+    });
   }
-  function isRightSideOfPropertyAccess(node) {
-    var _a;
-    return ((_a = tryCast(node.parent, isPropertyAccessExpression)) == null ? void 0 : _a.name) === node;
+  function symbolToDisplayParts(typeChecker, symbol, enclosingDeclaration, meaning, flags = 0 /* None */) {
+    return mapToDisplayParts((writer) => {
+      typeChecker.writeSymbol(symbol, enclosingDeclaration, meaning, flags | 8 /* UseAliasDefinedOutsideCurrentScope */, writer);
+    });
   }
-  function isArgumentExpressionOfElementAccess(node) {
-    var _a;
-    return ((_a = tryCast(node.parent, isElementAccessExpression)) == null ? void 0 : _a.argumentExpression) === node;
+  function signatureToDisplayParts(typechecker, signature, enclosingDeclaration, flags = 0 /* None */) {
+    flags |= 16384 /* UseAliasDefinedOutsideCurrentScope */ | 1024 /* MultilineObjectLiterals */ | 32 /* WriteTypeArgumentsOfSignature */ | 8192 /* OmitParameterModifiers */;
+    return mapToDisplayParts((writer) => {
+      typechecker.writeSignature(
+        signature,
+        enclosingDeclaration,
+        flags,
+        /*kind*/
+        void 0,
+        writer
+      );
+    });
   }
-  function isNameOfModuleDeclaration(node) {
-    var _a;
-    return ((_a = tryCast(node.parent, isModuleDeclaration)) == null ? void 0 : _a.name) === node;
+  function nodeToDisplayParts(node, enclosingDeclaration) {
+    const file = enclosingDeclaration.getSourceFile();
+    return mapToDisplayParts((writer) => {
+      const printer = createPrinterWithRemoveCommentsOmitTrailingSemicolon();
+      printer.writeNode(4 /* Unspecified */, node, file, writer);
+    });
   }
-  function isNameOfFunctionDeclaration(node) {
-    var _a;
-    return isIdentifier(node) && ((_a = tryCast(node.parent, isFunctionLike)) == null ? void 0 : _a.name) === node;
+  function isImportOrExportSpecifierName(location) {
+    return !!location.parent && isImportOrExportSpecifier(location.parent) && location.parent.propertyName === location;
   }
-  function isLiteralNameOfPropertyDeclarationOrIndexAccess(node) {
-    switch (node.parent.kind) {
-      case 171 /* PropertyDeclaration */:
-      case 170 /* PropertySignature */:
-      case 302 /* PropertyAssignment */:
-      case 305 /* EnumMember */:
-      case 173 /* MethodDeclaration */:
-      case 172 /* MethodSignature */:
-      case 176 /* GetAccessor */:
-      case 177 /* SetAccessor */:
-      case 266 /* ModuleDeclaration */:
-        return getNameOfDeclaration(node.parent) === node;
-      case 211 /* ElementAccessExpression */:
-        return node.parent.argumentExpression === node;
-      case 166 /* ComputedPropertyName */:
-        return true;
-      case 200 /* LiteralType */:
-        return node.parent.parent.kind === 198 /* IndexedAccessType */;
-      default:
-        return false;
+  function getScriptKind(fileName, host) {
+    return ensureScriptKind(fileName, host.getScriptKind && host.getScriptKind(fileName));
+  }
+  function getSymbolTarget(symbol, checker) {
+    let next = symbol;
+    while (isAliasSymbol(next) || isTransientSymbol(next) && next.links.target) {
+      if (isTransientSymbol(next) && next.links.target) {
+        next = next.links.target;
+      } else {
+        next = skipAlias(next, checker);
+      }
     }
+    return next;
   }
-  function isExpressionOfExternalModuleImportEqualsDeclaration(node) {
-    return isExternalModuleImportEqualsDeclaration(node.parent.parent) && getExternalModuleImportEqualsDeclarationExpression(node.parent.parent) === node;
+  function isAliasSymbol(symbol) {
+    return (symbol.flags & 2097152 /* Alias */) !== 0;
   }
-  function getContainerNode(node) {
-    if (isJSDocTypeAlias(node)) {
-      node = node.parent.parent;
+  function getUniqueSymbolId(symbol, checker) {
+    return getSymbolId(skipAlias(symbol, checker));
+  }
+  function getFirstNonSpaceCharacterPosition(text, position) {
+    while (isWhiteSpaceLike(text.charCodeAt(position))) {
+      position += 1;
     }
-    while (true) {
-      node = node.parent;
-      if (!node) {
-        return void 0;
-      }
-      switch (node.kind) {
-        case 311 /* SourceFile */:
-        case 173 /* MethodDeclaration */:
-        case 172 /* MethodSignature */:
-        case 261 /* FunctionDeclaration */:
-        case 217 /* FunctionExpression */:
-        case 176 /* GetAccessor */:
-        case 177 /* SetAccessor */:
-        case 262 /* ClassDeclaration */:
-        case 263 /* InterfaceDeclaration */:
-        case 265 /* EnumDeclaration */:
-        case 266 /* ModuleDeclaration */:
-          return node;
-      }
+    return position;
+  }
+  function getPrecedingNonSpaceCharacterPosition(text, position) {
+    while (position > -1 && isWhiteSpaceSingleLine(text.charCodeAt(position))) {
+      position -= 1;
     }
+    return position + 1;
   }
-  function getNodeKind(node) {
-    switch (node.kind) {
-      case 311 /* SourceFile */:
-        return isExternalModule(node) ? "module" /* moduleElement */ : "script" /* scriptElement */;
-      case 266 /* ModuleDeclaration */:
-        return "module" /* moduleElement */;
-      case 262 /* ClassDeclaration */:
-      case 230 /* ClassExpression */:
-        return "class" /* classElement */;
-      case 263 /* InterfaceDeclaration */:
-        return "interface" /* interfaceElement */;
-      case 264 /* TypeAliasDeclaration */:
-      case 344 /* JSDocCallbackTag */:
-      case 352 /* JSDocTypedefTag */:
-        return "type" /* typeElement */;
-      case 265 /* EnumDeclaration */:
-        return "enum" /* enumElement */;
-      case 259 /* VariableDeclaration */:
-        return getKindOfVariableDeclaration(node);
-      case 207 /* BindingElement */:
-        return getKindOfVariableDeclaration(getRootDeclaration(node));
-      case 218 /* ArrowFunction */:
-      case 261 /* FunctionDeclaration */:
-      case 217 /* FunctionExpression */:
-        return "function" /* functionElement */;
-      case 176 /* GetAccessor */:
-        return "getter" /* memberGetAccessorElement */;
-      case 177 /* SetAccessor */:
-        return "setter" /* memberSetAccessorElement */;
-      case 173 /* MethodDeclaration */:
-      case 172 /* MethodSignature */:
-        return "method" /* memberFunctionElement */;
-      case 302 /* PropertyAssignment */:
-        const { initializer } = node;
-        return isFunctionLike(initializer) ? "method" /* memberFunctionElement */ : "property" /* memberVariableElement */;
-      case 171 /* PropertyDeclaration */:
-      case 170 /* PropertySignature */:
-      case 303 /* ShorthandPropertyAssignment */:
-      case 304 /* SpreadAssignment */:
-        return "property" /* memberVariableElement */;
-      case 180 /* IndexSignature */:
-        return "index" /* indexSignatureElement */;
-      case 179 /* ConstructSignature */:
-        return "construct" /* constructSignatureElement */;
-      case 178 /* CallSignature */:
-        return "call" /* callSignatureElement */;
-      case 175 /* Constructor */:
-      case 174 /* ClassStaticBlockDeclaration */:
-        return "constructor" /* constructorImplementationElement */;
-      case 167 /* TypeParameter */:
-        return "type parameter" /* typeParameterElement */;
-      case 305 /* EnumMember */:
-        return "enum member" /* enumMemberElement */;
-      case 168 /* Parameter */:
-        return hasSyntacticModifier(node, 16476 /* ParameterPropertyModifier */) ? "property" /* memberVariableElement */ : "parameter" /* parameterElement */;
-      case 270 /* ImportEqualsDeclaration */:
-      case 275 /* ImportSpecifier */:
-      case 280 /* ExportSpecifier */:
-      case 273 /* NamespaceImport */:
-      case 279 /* NamespaceExport */:
-        return "alias" /* alias */;
-      case 225 /* BinaryExpression */:
-        const kind = getAssignmentDeclarationKind(node);
-        const { right } = node;
-        switch (kind) {
-          case 7 /* ObjectDefinePropertyValue */:
-          case 8 /* ObjectDefinePropertyExports */:
-          case 9 /* ObjectDefinePrototypeProperty */:
-          case 0 /* None */:
-            return "" /* unknown */;
-          case 1 /* ExportsProperty */:
-          case 2 /* ModuleExports */:
-            const rightKind = getNodeKind(right);
-            return rightKind === "" /* unknown */ ? "const" /* constElement */ : rightKind;
-          case 3 /* PrototypeProperty */:
-            return isFunctionExpression(right) ? "method" /* memberFunctionElement */ : "property" /* memberVariableElement */;
-          case 4 /* ThisProperty */:
-            return "property" /* memberVariableElement */;
-          case 5 /* Property */:
-            return isFunctionExpression(right) ? "method" /* memberFunctionElement */ : "property" /* memberVariableElement */;
-          case 6 /* Prototype */:
-            return "local class" /* localClassElement */;
-          default: {
-            assertType(kind);
-            return "" /* unknown */;
+  function getSynthesizedDeepClone(node, includeTrivia = true) {
+    const clone2 = node && getSynthesizedDeepCloneWorker(node);
+    if (clone2 && !includeTrivia)
+      suppressLeadingAndTrailingTrivia(clone2);
+    return clone2;
+  }
+  function getSynthesizedDeepCloneWithReplacements(node, includeTrivia, replaceNode) {
+    let clone2 = replaceNode(node);
+    if (clone2) {
+      setOriginalNode(clone2, node);
+    } else {
+      clone2 = getSynthesizedDeepCloneWorker(node, replaceNode);
+    }
+    if (clone2 && !includeTrivia)
+      suppressLeadingAndTrailingTrivia(clone2);
+    return clone2;
+  }
+  function getSynthesizedDeepCloneWorker(node, replaceNode) {
+    const nodeClone = replaceNode ? (n) => getSynthesizedDeepCloneWithReplacements(
+      n,
+      /*includeTrivia*/
+      true,
+      replaceNode
+    ) : getSynthesizedDeepClone;
+    const nodesClone = replaceNode ? (ns) => ns && getSynthesizedDeepClonesWithReplacements(
+      ns,
+      /*includeTrivia*/
+      true,
+      replaceNode
+    ) : (ns) => ns && getSynthesizedDeepClones(ns);
+    const visited = visitEachChild(node, nodeClone, nullTransformationContext, nodesClone, nodeClone);
+    if (visited === node) {
+      const clone2 = isStringLiteral(node) ? setOriginalNode(factory.createStringLiteralFromNode(node), node) : isNumericLiteral(node) ? setOriginalNode(factory.createNumericLiteral(node.text, node.numericLiteralFlags), node) : factory.cloneNode(node);
+      return setTextRange(clone2, node);
+    }
+    visited.parent = void 0;
+    return visited;
+  }
+  function getSynthesizedDeepClones(nodes, includeTrivia = true) {
+    if (nodes) {
+      const cloned = factory.createNodeArray(nodes.map((n) => getSynthesizedDeepClone(n, includeTrivia)), nodes.hasTrailingComma);
+      setTextRange(cloned, nodes);
+      return cloned;
+    }
+    return nodes;
+  }
+  function getSynthesizedDeepClonesWithReplacements(nodes, includeTrivia, replaceNode) {
+    return factory.createNodeArray(nodes.map((n) => getSynthesizedDeepCloneWithReplacements(n, includeTrivia, replaceNode)), nodes.hasTrailingComma);
+  }
+  function suppressLeadingAndTrailingTrivia(node) {
+    suppressLeadingTrivia(node);
+    suppressTrailingTrivia(node);
+  }
+  function suppressLeadingTrivia(node) {
+    addEmitFlagsRecursively(node, 1024 /* NoLeadingComments */, getFirstChild);
+  }
+  function suppressTrailingTrivia(node) {
+    addEmitFlagsRecursively(node, 2048 /* NoTrailingComments */, getLastChild);
+  }
+  function copyComments(sourceNode, targetNode) {
+    const sourceFile = sourceNode.getSourceFile();
+    const text = sourceFile.text;
+    if (hasLeadingLineBreak(sourceNode, text)) {
+      copyLeadingComments(sourceNode, targetNode, sourceFile);
+    } else {
+      copyTrailingAsLeadingComments(sourceNode, targetNode, sourceFile);
+    }
+    copyTrailingComments(sourceNode, targetNode, sourceFile);
+  }
+  function hasLeadingLineBreak(node, text) {
+    const start = node.getFullStart();
+    const end = node.getStart();
+    for (let i = start; i < end; i++) {
+      if (text.charCodeAt(i) === 10 /* lineFeed */)
+        return true;
+    }
+    return false;
+  }
+  function addEmitFlagsRecursively(node, flag, getChild) {
+    addEmitFlags(node, flag);
+    const child = getChild(node);
+    if (child)
+      addEmitFlagsRecursively(child, flag, getChild);
+  }
+  function getFirstChild(node) {
+    return node.forEachChild((child) => child);
+  }
+  function getUniqueName(baseName, sourceFile) {
+    let nameText = baseName;
+    for (let i = 1; !isFileLevelUniqueName(sourceFile, nameText); i++) {
+      nameText = `${baseName}_${i}`;
+    }
+    return nameText;
+  }
+  function getRenameLocation(edits, renameFilename, name, preferLastLocation) {
+    let delta = 0;
+    let lastPos = -1;
+    for (const { fileName, textChanges: textChanges2 } of edits) {
+      Debug.assert(fileName === renameFilename);
+      for (const change of textChanges2) {
+        const { span, newText } = change;
+        const index = indexInTextChange(newText, escapeString(name));
+        if (index !== -1) {
+          lastPos = span.start + delta + index;
+          if (!preferLastLocation) {
+            return lastPos;
           }
         }
-      case 80 /* Identifier */:
-        return isImportClause(node.parent) ? "alias" /* alias */ : "" /* unknown */;
-      case 276 /* ExportAssignment */:
-        const scriptKind = getNodeKind(node.expression);
-        return scriptKind === "" /* unknown */ ? "const" /* constElement */ : scriptKind;
+        delta += newText.length - span.length;
+      }
+    }
+    Debug.assert(preferLastLocation);
+    Debug.assert(lastPos >= 0);
+    return lastPos;
+  }
+  function copyLeadingComments(sourceNode, targetNode, sourceFile, commentKind, hasTrailingNewLine) {
+    forEachLeadingCommentRange(sourceFile.text, sourceNode.pos, getAddCommentsFunction(targetNode, sourceFile, commentKind, hasTrailingNewLine, addSyntheticLeadingComment));
+  }
+  function copyTrailingComments(sourceNode, targetNode, sourceFile, commentKind, hasTrailingNewLine) {
+    forEachTrailingCommentRange(sourceFile.text, sourceNode.end, getAddCommentsFunction(targetNode, sourceFile, commentKind, hasTrailingNewLine, addSyntheticTrailingComment));
+  }
+  function copyTrailingAsLeadingComments(sourceNode, targetNode, sourceFile, commentKind, hasTrailingNewLine) {
+    forEachTrailingCommentRange(sourceFile.text, sourceNode.pos, getAddCommentsFunction(targetNode, sourceFile, commentKind, hasTrailingNewLine, addSyntheticLeadingComment));
+  }
+  function getAddCommentsFunction(targetNode, sourceFile, commentKind, hasTrailingNewLine, cb) {
+    return (pos, end, kind, htnl) => {
+      if (kind === 3 /* MultiLineCommentTrivia */) {
+        pos += 2;
+        end -= 2;
+      } else {
+        pos += 2;
+      }
+      cb(targetNode, commentKind || kind, sourceFile.text.slice(pos, end), hasTrailingNewLine !== void 0 ? hasTrailingNewLine : htnl);
+    };
+  }
+  function indexInTextChange(change, name) {
+    if (startsWith(change, name))
+      return 0;
+    let idx = change.indexOf(" " + name);
+    if (idx === -1)
+      idx = change.indexOf("." + name);
+    if (idx === -1)
+      idx = change.indexOf('"' + name);
+    return idx === -1 ? -1 : idx + 1;
+  }
+  function needsParentheses(expression) {
+    return isBinaryExpression(expression) && expression.operatorToken.kind === 28 /* CommaToken */ || isObjectLiteralExpression(expression) || (isAsExpression(expression) || isSatisfiesExpression(expression)) && isObjectLiteralExpression(expression.expression);
+  }
+  function getContextualTypeFromParent(node, checker, contextFlags) {
+    const parent2 = walkUpParenthesizedExpressions(node.parent);
+    switch (parent2.kind) {
+      case 214 /* NewExpression */:
+        return checker.getContextualType(parent2, contextFlags);
+      case 226 /* BinaryExpression */: {
+        const { left, operatorToken, right } = parent2;
+        return isEqualityOperatorKind(operatorToken.kind) ? checker.getTypeAtLocation(node === right ? left : right) : checker.getContextualType(node, contextFlags);
+      }
+      case 296 /* CaseClause */:
+        return getSwitchedType(parent2, checker);
       default:
-        return "" /* unknown */;
+        return checker.getContextualType(node, contextFlags);
     }
-    function getKindOfVariableDeclaration(v) {
-      return isVarConst(v) ? "const" /* constElement */ : isLet(v) ? "let" /* letElement */ : "var" /* variableElement */;
+  }
+  function quote(sourceFile, preferences, text) {
+    const quotePreference = getQuotePreference(sourceFile, preferences);
+    const quoted = JSON.stringify(text);
+    return quotePreference === 0 /* Single */ ? `'${stripQuotes(quoted).replace(/'/g, "\\'").replace(/\\"/g, '"')}'` : quoted;
+  }
+  function isEqualityOperatorKind(kind) {
+    switch (kind) {
+      case 37 /* EqualsEqualsEqualsToken */:
+      case 35 /* EqualsEqualsToken */:
+      case 38 /* ExclamationEqualsEqualsToken */:
+      case 36 /* ExclamationEqualsToken */:
+        return true;
+      default:
+        return false;
     }
   }
-  function isThis(node) {
+  function isStringLiteralOrTemplate(node) {
     switch (node.kind) {
-      case 110 /* ThisKeyword */:
+      case 11 /* StringLiteral */:
+      case 15 /* NoSubstitutionTemplateLiteral */:
+      case 228 /* TemplateExpression */:
+      case 215 /* TaggedTemplateExpression */:
         return true;
-      case 80 /* Identifier */:
-        return identifierIsThisKeyword(node) && node.parent.kind === 168 /* Parameter */;
       default:
         return false;
     }
   }
-  function getLineStartPositionForPosition(position, sourceFile) {
-    const lineStarts = getLineStarts(sourceFile);
-    const line = sourceFile.getLineAndCharacterOfPosition(position).line;
-    return lineStarts[line];
-  }
-  function rangeContainsRange(r1, r2) {
-    return startEndContainsRange(r1.pos, r1.end, r2);
-  }
-  function rangeContainsRangeExclusive(r1, r2) {
-    return rangeContainsPositionExclusive(r1, r2.pos) && rangeContainsPositionExclusive(r1, r2.end);
-  }
-  function rangeContainsPosition(r, pos) {
-    return r.pos <= pos && pos <= r.end;
-  }
-  function rangeContainsPositionExclusive(r, pos) {
-    return r.pos < pos && pos < r.end;
+  function hasIndexSignature(type) {
+    return !!type.getStringIndexType() || !!type.getNumberIndexType();
   }
-  function startEndContainsRange(start, end, range) {
-    return start <= range.pos && end >= range.end;
+  function getSwitchedType(caseClause, checker) {
+    return checker.getTypeAtLocation(caseClause.parent.parent.expression);
   }
-  function rangeContainsStartEnd(range, start, end) {
-    return range.pos <= start && range.end >= end;
+  function getTypeNodeIfAccessible(type, enclosingScope, program, host) {
+    const checker = program.getTypeChecker();
+    let typeIsAccessible = true;
+    const notAccessible = () => typeIsAccessible = false;
+    const res = checker.typeToTypeNode(type, enclosingScope, 1 /* NoTruncation */, {
+      trackSymbol: (symbol, declaration, meaning) => {
+        typeIsAccessible = typeIsAccessible && checker.isSymbolAccessible(
+          symbol,
+          declaration,
+          meaning,
+          /*shouldComputeAliasToMarkVisible*/
+          false
+        ).accessibility === 0 /* Accessible */;
+        return !typeIsAccessible;
+      },
+      reportInaccessibleThisError: notAccessible,
+      reportPrivateInBaseOfClassExpression: notAccessible,
+      reportInaccessibleUniqueSymbolError: notAccessible,
+      moduleResolverHost: getModuleSpecifierResolverHost(program, host)
+    });
+    return typeIsAccessible ? res : void 0;
   }
-  function rangeOverlapsWithStartEnd(r1, start, end) {
-    return startEndOverlapsWithStartEnd(r1.pos, r1.end, start, end);
+  function syntaxRequiresTrailingCommaOrSemicolonOrASI(kind) {
+    return kind === 179 /* CallSignature */ || kind === 180 /* ConstructSignature */ || kind === 181 /* IndexSignature */ || kind === 171 /* PropertySignature */ || kind === 173 /* MethodSignature */;
   }
-  function nodeOverlapsWithStartEnd(node, sourceFile, start, end) {
-    return startEndOverlapsWithStartEnd(node.getStart(sourceFile), node.end, start, end);
+  function syntaxRequiresTrailingFunctionBlockOrSemicolonOrASI(kind) {
+    return kind === 262 /* FunctionDeclaration */ || kind === 176 /* Constructor */ || kind === 174 /* MethodDeclaration */ || kind === 177 /* GetAccessor */ || kind === 178 /* SetAccessor */;
   }
-  function startEndOverlapsWithStartEnd(start1, end1, start2, end2) {
-    const start = Math.max(start1, start2);
-    const end = Math.min(end1, end2);
-    return start < end;
+  function syntaxRequiresTrailingModuleBlockOrSemicolonOrASI(kind) {
+    return kind === 267 /* ModuleDeclaration */;
   }
-  function positionBelongsToNode(candidate, position, sourceFile) {
-    Debug.assert(candidate.pos <= position);
-    return position < candidate.end || !isCompletedNode(candidate, sourceFile);
+  function syntaxRequiresTrailingSemicolonOrASI(kind) {
+    return kind === 243 /* VariableStatement */ || kind === 244 /* ExpressionStatement */ || kind === 246 /* DoStatement */ || kind === 251 /* ContinueStatement */ || kind === 252 /* BreakStatement */ || kind === 253 /* ReturnStatement */ || kind === 257 /* ThrowStatement */ || kind === 259 /* DebuggerStatement */ || kind === 172 /* PropertyDeclaration */ || kind === 265 /* TypeAliasDeclaration */ || kind === 272 /* ImportDeclaration */ || kind === 271 /* ImportEqualsDeclaration */ || kind === 278 /* ExportDeclaration */ || kind === 270 /* NamespaceExportDeclaration */ || kind === 277 /* ExportAssignment */;
   }
-  function isCompletedNode(n, sourceFile) {
-    if (n === void 0 || nodeIsMissing(n)) {
+  function nodeIsASICandidate(node, sourceFile) {
+    const lastToken = node.getLastToken(sourceFile);
+    if (lastToken && lastToken.kind === 27 /* SemicolonToken */) {
       return false;
     }
-    switch (n.kind) {
-      case 262 /* ClassDeclaration */:
-      case 263 /* InterfaceDeclaration */:
-      case 265 /* EnumDeclaration */:
-      case 209 /* ObjectLiteralExpression */:
-      case 205 /* ObjectBindingPattern */:
-      case 186 /* TypeLiteral */:
-      case 240 /* Block */:
-      case 267 /* ModuleBlock */:
-      case 268 /* CaseBlock */:
-      case 274 /* NamedImports */:
-      case 278 /* NamedExports */:
-        return nodeEndsWith(n, 20 /* CloseBraceToken */, sourceFile);
-      case 298 /* CatchClause */:
-        return isCompletedNode(n.block, sourceFile);
-      case 213 /* NewExpression */:
-        if (!n.arguments) {
-          return true;
-        }
-      case 212 /* CallExpression */:
-      case 216 /* ParenthesizedExpression */:
-      case 195 /* ParenthesizedType */:
-        return nodeEndsWith(n, 22 /* CloseParenToken */, sourceFile);
-      case 183 /* FunctionType */:
-      case 184 /* ConstructorType */:
-        return isCompletedNode(n.type, sourceFile);
-      case 175 /* Constructor */:
-      case 176 /* GetAccessor */:
-      case 177 /* SetAccessor */:
-      case 261 /* FunctionDeclaration */:
-      case 217 /* FunctionExpression */:
-      case 173 /* MethodDeclaration */:
-      case 172 /* MethodSignature */:
-      case 179 /* ConstructSignature */:
-      case 178 /* CallSignature */:
-      case 218 /* ArrowFunction */:
-        if (n.body) {
-          return isCompletedNode(n.body, sourceFile);
-        }
-        if (n.type) {
-          return isCompletedNode(n.type, sourceFile);
-        }
-        return hasChildOfKind(n, 22 /* CloseParenToken */, sourceFile);
-      case 266 /* ModuleDeclaration */:
-        return !!n.body && isCompletedNode(n.body, sourceFile);
-      case 244 /* IfStatement */:
-        if (n.elseStatement) {
-          return isCompletedNode(n.elseStatement, sourceFile);
-        }
-        return isCompletedNode(n.thenStatement, sourceFile);
-      case 243 /* ExpressionStatement */:
-        return isCompletedNode(n.expression, sourceFile) || hasChildOfKind(n, 27 /* SemicolonToken */, sourceFile);
-      case 208 /* ArrayLiteralExpression */:
-      case 206 /* ArrayBindingPattern */:
-      case 211 /* ElementAccessExpression */:
-      case 166 /* ComputedPropertyName */:
-      case 188 /* TupleType */:
-        return nodeEndsWith(n, 24 /* CloseBracketToken */, sourceFile);
-      case 180 /* IndexSignature */:
-        if (n.type) {
-          return isCompletedNode(n.type, sourceFile);
-        }
-        return hasChildOfKind(n, 24 /* CloseBracketToken */, sourceFile);
-      case 295 /* CaseClause */:
-      case 296 /* DefaultClause */:
+    if (syntaxRequiresTrailingCommaOrSemicolonOrASI(node.kind)) {
+      if (lastToken && lastToken.kind === 28 /* CommaToken */) {
         return false;
-      case 247 /* ForStatement */:
-      case 248 /* ForInStatement */:
-      case 249 /* ForOfStatement */:
-      case 246 /* WhileStatement */:
-        return isCompletedNode(n.statement, sourceFile);
-      case 245 /* DoStatement */:
-        return hasChildOfKind(n, 117 /* WhileKeyword */, sourceFile) ? nodeEndsWith(n, 22 /* CloseParenToken */, sourceFile) : isCompletedNode(n.statement, sourceFile);
-      case 185 /* TypeQuery */:
-        return isCompletedNode(n.exprName, sourceFile);
-      case 220 /* TypeOfExpression */:
-      case 219 /* DeleteExpression */:
-      case 221 /* VoidExpression */:
-      case 228 /* YieldExpression */:
-      case 229 /* SpreadElement */:
-        const unaryWordExpression = n;
-        return isCompletedNode(unaryWordExpression.expression, sourceFile);
-      case 214 /* TaggedTemplateExpression */:
-        return isCompletedNode(n.template, sourceFile);
-      case 227 /* TemplateExpression */:
-        const lastSpan = lastOrUndefined(n.templateSpans);
-        return isCompletedNode(lastSpan, sourceFile);
-      case 238 /* TemplateSpan */:
-        return nodeIsPresent(n.literal);
-      case 277 /* ExportDeclaration */:
-      case 271 /* ImportDeclaration */:
-        return nodeIsPresent(n.moduleSpecifier);
-      case 223 /* PrefixUnaryExpression */:
-        return isCompletedNode(n.operand, sourceFile);
-      case 225 /* BinaryExpression */:
-        return isCompletedNode(n.right, sourceFile);
-      case 226 /* ConditionalExpression */:
-        return isCompletedNode(n.whenFalse, sourceFile);
-      default:
-        return true;
+      }
+    } else if (syntaxRequiresTrailingModuleBlockOrSemicolonOrASI(node.kind)) {
+      const lastChild = last(node.getChildren(sourceFile));
+      if (lastChild && isModuleBlock(lastChild)) {
+        return false;
+      }
+    } else if (syntaxRequiresTrailingFunctionBlockOrSemicolonOrASI(node.kind)) {
+      const lastChild = last(node.getChildren(sourceFile));
+      if (lastChild && isFunctionBlock(lastChild)) {
+        return false;
+      }
+    } else if (!syntaxRequiresTrailingSemicolonOrASI(node.kind)) {
+      return false;
+    }
+    if (node.kind === 246 /* DoStatement */) {
+      return true;
+    }
+    const topNode = findAncestor(node, (ancestor) => !ancestor.parent);
+    const nextToken = findNextToken(node, topNode, sourceFile);
+    if (!nextToken || nextToken.kind === 20 /* CloseBraceToken */) {
+      return true;
     }
+    const startLine = sourceFile.getLineAndCharacterOfPosition(node.getEnd()).line;
+    const endLine = sourceFile.getLineAndCharacterOfPosition(nextToken.getStart(sourceFile)).line;
+    return startLine !== endLine;
   }
-  function nodeEndsWith(n, expectedLastToken, sourceFile) {
-    const children = n.getChildren(sourceFile);
-    if (children.length) {
-      const lastChild = last(children);
-      if (lastChild.kind === expectedLastToken) {
+  function positionIsASICandidate(pos, context, sourceFile) {
+    const contextAncestor = findAncestor(context, (ancestor) => {
+      if (ancestor.end !== pos) {
+        return "quit";
+      }
+      return syntaxMayBeASICandidate(ancestor.kind);
+    });
+    return !!contextAncestor && nodeIsASICandidate(contextAncestor, sourceFile);
+  }
+  function probablyUsesSemicolons(sourceFile) {
+    let withSemicolon = 0;
+    let withoutSemicolon = 0;
+    const nStatementsToObserve = 5;
+    forEachChild(sourceFile, function visit(node) {
+      if (syntaxRequiresTrailingSemicolonOrASI(node.kind)) {
+        const lastToken = node.getLastToken(sourceFile);
+        if ((lastToken == null ? void 0 : lastToken.kind) === 27 /* SemicolonToken */) {
+          withSemicolon++;
+        } else {
+          withoutSemicolon++;
+        }
+      } else if (syntaxRequiresTrailingCommaOrSemicolonOrASI(node.kind)) {
+        const lastToken = node.getLastToken(sourceFile);
+        if ((lastToken == null ? void 0 : lastToken.kind) === 27 /* SemicolonToken */) {
+          withSemicolon++;
+        } else if (lastToken && lastToken.kind !== 28 /* CommaToken */) {
+          const lastTokenLine = getLineAndCharacterOfPosition(sourceFile, lastToken.getStart(sourceFile)).line;
+          const nextTokenLine = getLineAndCharacterOfPosition(sourceFile, getSpanOfTokenAtPosition(sourceFile, lastToken.end).start).line;
+          if (lastTokenLine !== nextTokenLine) {
+            withoutSemicolon++;
+          }
+        }
+      }
+      if (withSemicolon + withoutSemicolon >= nStatementsToObserve) {
         return true;
-      } else if (lastChild.kind === 27 /* SemicolonToken */ && children.length !== 1) {
-        return children[children.length - 2].kind === expectedLastToken;
       }
+      return forEachChild(node, visit);
+    });
+    if (withSemicolon === 0 && withoutSemicolon <= 1) {
+      return true;
     }
-    return false;
+    return withSemicolon / withoutSemicolon > 1 / nStatementsToObserve;
   }
-  function findListItemInfo(node) {
-    const list = findContainingList(node);
-    if (!list) {
-      return void 0;
-    }
-    const children = list.getChildren();
-    const listItemIndex = indexOfNode(children, node);
-    return {
-      listItemIndex,
-      list
-    };
+  function tryGetDirectories(host, directoryName) {
+    return tryIOAndConsumeErrors(host, host.getDirectories, directoryName) || [];
   }
-  function hasChildOfKind(n, kind, sourceFile) {
-    return !!findChildOfKind(n, kind, sourceFile);
+  function tryReadDirectory(host, path, extensions, exclude, include) {
+    return tryIOAndConsumeErrors(host, host.readDirectory, path, extensions, exclude, include) || emptyArray;
   }
-  function findChildOfKind(n, kind, sourceFile) {
-    return find(n.getChildren(sourceFile), (c) => c.kind === kind);
+  function tryFileExists(host, path) {
+    return tryIOAndConsumeErrors(host, host.fileExists, path);
   }
-  function findContainingList(node) {
-    const syntaxList = find(node.parent.getChildren(), (c) => isSyntaxList(c) && rangeContainsRange(c, node));
-    Debug.assert(!syntaxList || contains(syntaxList.getChildren(), node));
-    return syntaxList;
+  function tryDirectoryExists(host, path) {
+    return tryAndIgnoreErrors(() => directoryProbablyExists(path, host)) || false;
   }
-  function isDefaultModifier2(node) {
-    return node.kind === 90 /* DefaultKeyword */;
+  function tryAndIgnoreErrors(cb) {
+    try {
+      return cb();
+    } catch {
+      return void 0;
+    }
   }
-  function isClassKeyword(node) {
-    return node.kind === 86 /* ClassKeyword */;
+  function tryIOAndConsumeErrors(host, toApply, ...args) {
+    return tryAndIgnoreErrors(() => toApply && toApply.apply(host, args));
   }
-  function isFunctionKeyword(node) {
-    return node.kind === 100 /* FunctionKeyword */;
+  function findPackageJsons(startDirectory, host, stopDirectory) {
+    const paths = [];
+    forEachAncestorDirectory(startDirectory, (ancestor) => {
+      if (ancestor === stopDirectory) {
+        return true;
+      }
+      const currentConfigPath = combinePaths(ancestor, "package.json");
+      if (tryFileExists(host, currentConfigPath)) {
+        paths.push(currentConfigPath);
+      }
+    });
+    return paths;
   }
-  function getAdjustedLocationForClass(node) {
-    if (isNamedDeclaration(node)) {
-      return node.name;
-    }
-    if (isClassDeclaration(node)) {
-      const defaultModifier = node.modifiers && find(node.modifiers, isDefaultModifier2);
-      if (defaultModifier)
-        return defaultModifier;
-    }
-    if (isClassExpression(node)) {
-      const classKeyword = find(node.getChildren(), isClassKeyword);
-      if (classKeyword)
-        return classKeyword;
-    }
+  function findPackageJson(directory, host) {
+    let packageJson;
+    forEachAncestorDirectory(directory, (ancestor) => {
+      if (ancestor === "node_modules")
+        return true;
+      packageJson = findConfigFile(ancestor, (f) => tryFileExists(host, f), "package.json");
+      if (packageJson) {
+        return true;
+      }
+    });
+    return packageJson;
   }
-  function getAdjustedLocationForFunction(node) {
-    if (isNamedDeclaration(node)) {
-      return node.name;
-    }
-    if (isFunctionDeclaration(node)) {
-      const defaultModifier = find(node.modifiers, isDefaultModifier2);
-      if (defaultModifier)
-        return defaultModifier;
-    }
-    if (isFunctionExpression(node)) {
-      const functionKeyword = find(node.getChildren(), isFunctionKeyword);
-      if (functionKeyword)
-        return functionKeyword;
+  function getPackageJsonsVisibleToFile(fileName, host) {
+    if (!host.fileExists) {
+      return [];
     }
-  }
-  function getAncestorTypeNode(node) {
-    let lastTypeNode;
-    findAncestor(node, (a) => {
-      if (isTypeNode(a)) {
-        lastTypeNode = a;
+    const packageJsons = [];
+    forEachAncestorDirectory(getDirectoryPath(fileName), (ancestor) => {
+      const packageJsonFileName = combinePaths(ancestor, "package.json");
+      if (host.fileExists(packageJsonFileName)) {
+        const info = createPackageJsonInfo(packageJsonFileName, host);
+        if (info) {
+          packageJsons.push(info);
+        }
       }
-      return !isQualifiedName(a.parent) && !isTypeNode(a.parent) && !isTypeElement(a.parent);
     });
-    return lastTypeNode;
+    return packageJsons;
   }
-  function getContextualTypeFromParentOrAncestorTypeNode(node, checker) {
-    if (node.flags & (8388608 /* JSDoc */ & ~262144 /* JavaScriptFile */))
+  function createPackageJsonInfo(fileName, host) {
+    if (!host.readFile) {
       return void 0;
-    const contextualType = getContextualTypeFromParent(node, checker);
-    if (contextualType)
-      return contextualType;
-    const ancestorTypeNode = getAncestorTypeNode(node);
-    return ancestorTypeNode && checker.getTypeAtLocation(ancestorTypeNode);
-  }
-  function getAdjustedLocationForDeclaration(node, forRename) {
-    if (!forRename) {
-      switch (node.kind) {
-        case 262 /* ClassDeclaration */:
-        case 230 /* ClassExpression */:
-          return getAdjustedLocationForClass(node);
-        case 261 /* FunctionDeclaration */:
-        case 217 /* FunctionExpression */:
-          return getAdjustedLocationForFunction(node);
-        case 175 /* Constructor */:
-          return node;
-      }
-    }
-    if (isNamedDeclaration(node)) {
-      return node.name;
     }
-  }
-  function getAdjustedLocationForImportDeclaration(node, forRename) {
-    if (node.importClause) {
-      if (node.importClause.name && node.importClause.namedBindings) {
-        return;
+    const dependencyKeys = ["dependencies", "devDependencies", "optionalDependencies", "peerDependencies"];
+    const stringContent = host.readFile(fileName) || "";
+    const content = tryParseJson(stringContent);
+    const info = {};
+    if (content) {
+      for (const key of dependencyKeys) {
+        const dependencies = content[key];
+        if (!dependencies) {
+          continue;
+        }
+        const dependencyMap = /* @__PURE__ */ new Map();
+        for (const packageName in dependencies) {
+          dependencyMap.set(packageName, dependencies[packageName]);
+        }
+        info[key] = dependencyMap;
       }
-      if (node.importClause.name) {
-        return node.importClause.name;
+    }
+    const dependencyGroups = [
+      [1 /* Dependencies */, info.dependencies],
+      [2 /* DevDependencies */, info.devDependencies],
+      [8 /* OptionalDependencies */, info.optionalDependencies],
+      [4 /* PeerDependencies */, info.peerDependencies]
+    ];
+    return {
+      ...info,
+      parseable: !!content,
+      fileName,
+      get,
+      has(dependencyName, inGroups) {
+        return !!get(dependencyName, inGroups);
       }
-      if (node.importClause.namedBindings) {
-        if (isNamedImports(node.importClause.namedBindings)) {
-          const onlyBinding = singleOrUndefined(node.importClause.namedBindings.elements);
-          if (!onlyBinding) {
-            return;
+    };
+    function get(dependencyName, inGroups = 15 /* All */) {
+      for (const [group2, deps] of dependencyGroups) {
+        if (deps && inGroups & group2) {
+          const dep = deps.get(dependencyName);
+          if (dep !== void 0) {
+            return dep;
           }
-          return onlyBinding.name;
-        } else if (isNamespaceImport(node.importClause.namedBindings)) {
-          return node.importClause.namedBindings.name;
         }
       }
     }
-    if (!forRename) {
-      return node.moduleSpecifier;
-    }
   }
-  function getAdjustedLocationForExportDeclaration(node, forRename) {
-    if (node.exportClause) {
-      if (isNamedExports(node.exportClause)) {
-        const onlyBinding = singleOrUndefined(node.exportClause.elements);
-        if (!onlyBinding) {
-          return;
+  function createPackageJsonImportFilter(fromFile, preferences, host) {
+    const packageJsons = (host.getPackageJsonsVisibleToFile && host.getPackageJsonsVisibleToFile(fromFile.fileName) || getPackageJsonsVisibleToFile(fromFile.fileName, host)).filter((p) => p.parseable);
+    let usesNodeCoreModules;
+    let ambientModuleCache;
+    let sourceFileCache;
+    return {
+      allowsImportingAmbientModule,
+      allowsImportingSourceFile,
+      allowsImportingSpecifier
+    };
+    function moduleSpecifierIsCoveredByPackageJson(specifier) {
+      const packageName = getNodeModuleRootSpecifier(specifier);
+      for (const packageJson of packageJsons) {
+        if (packageJson.has(packageName) || packageJson.has(getTypesPackageName(packageName))) {
+          return true;
         }
-        return node.exportClause.elements[0].name;
-      } else if (isNamespaceExport(node.exportClause)) {
-        return node.exportClause.name;
       }
+      return false;
     }
-    if (!forRename) {
-      return node.moduleSpecifier;
-    }
-  }
-  function getAdjustedLocationForHeritageClause(node) {
-    if (node.types.length === 1) {
-      return node.types[0].expression;
-    }
-  }
-  function getAdjustedLocation(node, forRename) {
-    const { parent: parent2 } = node;
-    if (isModifier(node) && (forRename || node.kind !== 90 /* DefaultKeyword */) ? canHaveModifiers(parent2) && contains(parent2.modifiers, node) : node.kind === 86 /* ClassKeyword */ ? isClassDeclaration(parent2) || isClassExpression(node) : node.kind === 100 /* FunctionKeyword */ ? isFunctionDeclaration(parent2) || isFunctionExpression(node) : node.kind === 120 /* InterfaceKeyword */ ? isInterfaceDeclaration(parent2) : node.kind === 94 /* EnumKeyword */ ? isEnumDeclaration(parent2) : node.kind === 156 /* TypeKeyword */ ? isTypeAliasDeclaration(parent2) : node.kind === 145 /* NamespaceKeyword */ || node.kind === 144 /* ModuleKeyword */ ? isModuleDeclaration(parent2) : node.kind === 102 /* ImportKeyword */ ? isImportEqualsDeclaration(parent2) : node.kind === 139 /* GetKeyword */ ? isGetAccessorDeclaration(parent2) : node.kind === 153 /* SetKeyword */ && isSetAccessorDeclaration(parent2)) {
-      const location = getAdjustedLocationForDeclaration(parent2, forRename);
-      if (location) {
-        return location;
+    function allowsImportingAmbientModule(moduleSymbol, moduleSpecifierResolutionHost) {
+      if (!packageJsons.length || !moduleSymbol.valueDeclaration) {
+        return true;
       }
-    }
-    if ((node.kind === 115 /* VarKeyword */ || node.kind === 87 /* ConstKeyword */ || node.kind === 121 /* LetKeyword */) && isVariableDeclarationList(parent2) && parent2.declarations.length === 1) {
-      const decl = parent2.declarations[0];
-      if (isIdentifier(decl.name)) {
-        return decl.name;
+      if (!ambientModuleCache) {
+        ambientModuleCache = /* @__PURE__ */ new Map();
+      } else {
+        const cached = ambientModuleCache.get(moduleSymbol);
+        if (cached !== void 0) {
+          return cached;
+        }
+      }
+      const declaredModuleSpecifier = stripQuotes(moduleSymbol.getName());
+      if (isAllowedCoreNodeModulesImport(declaredModuleSpecifier)) {
+        ambientModuleCache.set(moduleSymbol, true);
+        return true;
+      }
+      const declaringSourceFile = moduleSymbol.valueDeclaration.getSourceFile();
+      const declaringNodeModuleName = getNodeModulesPackageNameFromFileName(declaringSourceFile.fileName, moduleSpecifierResolutionHost);
+      if (typeof declaringNodeModuleName === "undefined") {
+        ambientModuleCache.set(moduleSymbol, true);
+        return true;
       }
+      const result = moduleSpecifierIsCoveredByPackageJson(declaringNodeModuleName) || moduleSpecifierIsCoveredByPackageJson(declaredModuleSpecifier);
+      ambientModuleCache.set(moduleSymbol, result);
+      return result;
     }
-    if (node.kind === 156 /* TypeKeyword */) {
-      if (isImportClause(parent2) && parent2.isTypeOnly) {
-        const location = getAdjustedLocationForImportDeclaration(parent2.parent, forRename);
-        if (location) {
-          return location;
-        }
+    function allowsImportingSourceFile(sourceFile, moduleSpecifierResolutionHost) {
+      if (!packageJsons.length) {
+        return true;
       }
-      if (isExportDeclaration(parent2) && parent2.isTypeOnly) {
-        const location = getAdjustedLocationForExportDeclaration(parent2, forRename);
-        if (location) {
-          return location;
+      if (!sourceFileCache) {
+        sourceFileCache = /* @__PURE__ */ new Map();
+      } else {
+        const cached = sourceFileCache.get(sourceFile);
+        if (cached !== void 0) {
+          return cached;
         }
       }
+      const moduleSpecifier = getNodeModulesPackageNameFromFileName(sourceFile.fileName, moduleSpecifierResolutionHost);
+      if (!moduleSpecifier) {
+        sourceFileCache.set(sourceFile, true);
+        return true;
+      }
+      const result = moduleSpecifierIsCoveredByPackageJson(moduleSpecifier);
+      sourceFileCache.set(sourceFile, result);
+      return result;
     }
-    if (node.kind === 130 /* AsKeyword */) {
-      if (isImportSpecifier(parent2) && parent2.propertyName || isExportSpecifier(parent2) && parent2.propertyName || isNamespaceImport(parent2) || isNamespaceExport(parent2)) {
-        return parent2.name;
+    function allowsImportingSpecifier(moduleSpecifier) {
+      if (!packageJsons.length || isAllowedCoreNodeModulesImport(moduleSpecifier)) {
+        return true;
       }
-      if (isExportDeclaration(parent2) && parent2.exportClause && isNamespaceExport(parent2.exportClause)) {
-        return parent2.exportClause.name;
+      if (pathIsRelative(moduleSpecifier) || isRootedDiskPath(moduleSpecifier)) {
+        return true;
       }
+      return moduleSpecifierIsCoveredByPackageJson(moduleSpecifier);
     }
-    if (node.kind === 102 /* ImportKeyword */ && isImportDeclaration(parent2)) {
-      const location = getAdjustedLocationForImportDeclaration(parent2, forRename);
-      if (location) {
-        return location;
+    function isAllowedCoreNodeModulesImport(moduleSpecifier) {
+      if (isSourceFileJS(fromFile) && ts_JsTyping_exports.nodeCoreModules.has(moduleSpecifier)) {
+        if (usesNodeCoreModules === void 0) {
+          usesNodeCoreModules = consumesNodeCoreModules(fromFile);
+        }
+        if (usesNodeCoreModules) {
+          return true;
+        }
       }
+      return false;
     }
-    if (node.kind === 95 /* ExportKeyword */) {
-      if (isExportDeclaration(parent2)) {
-        const location = getAdjustedLocationForExportDeclaration(parent2, forRename);
-        if (location) {
-          return location;
+    function getNodeModulesPackageNameFromFileName(importedFileName, moduleSpecifierResolutionHost) {
+      const pnpapi = getPnpApi(importedFileName);
+      if (pnpapi) {
+        const fromLocator = pnpapi.findPackageLocator(fromFile.fileName);
+        const toLocator = pnpapi.findPackageLocator(importedFileName);
+        if (!(fromLocator && toLocator)) {
+          return void 0;
         }
+      } else if (!importedFileName.includes("node_modules")) {
+        return void 0;
       }
-      if (isExportAssignment(parent2)) {
-        return skipOuterExpressions(parent2.expression);
+      const specifier = ts_moduleSpecifiers_exports.getNodeModulesPackageName(
+        host.getCompilationSettings(),
+        fromFile,
+        importedFileName,
+        moduleSpecifierResolutionHost,
+        preferences
+      );
+      if (!specifier) {
+        return void 0;
       }
-    }
-    if (node.kind === 149 /* RequireKeyword */ && isExternalModuleReference(parent2)) {
-      return parent2.expression;
-    }
-    if (node.kind === 160 /* FromKeyword */ && (isImportDeclaration(parent2) || isExportDeclaration(parent2)) && parent2.moduleSpecifier) {
-      return parent2.moduleSpecifier;
-    }
-    if ((node.kind === 96 /* ExtendsKeyword */ || node.kind === 119 /* ImplementsKeyword */) && isHeritageClause(parent2) && parent2.token === node.kind) {
-      const location = getAdjustedLocationForHeritageClause(parent2);
-      if (location) {
-        return location;
+      if (!pathIsRelative(specifier) && !isRootedDiskPath(specifier)) {
+        return getNodeModuleRootSpecifier(specifier);
       }
     }
-    if (node.kind === 96 /* ExtendsKeyword */) {
-      if (isTypeParameterDeclaration(parent2) && parent2.constraint && isTypeReferenceNode(parent2.constraint)) {
-        return parent2.constraint.typeName;
-      }
-      if (isConditionalTypeNode(parent2) && isTypeReferenceNode(parent2.extendsType)) {
-        return parent2.extendsType.typeName;
+    function getNodeModuleRootSpecifier(fullSpecifier) {
+      const components = getPathComponents(getPackageNameFromTypesPackageName(fullSpecifier)).slice(1);
+      if (startsWith(components[0], "@")) {
+        return `${components[0]}/${components[1]}`;
       }
+      return components[0];
     }
-    if (node.kind === 140 /* InferKeyword */ && isInferTypeNode(parent2)) {
-      return parent2.typeParameter.name;
+  }
+  function tryParseJson(text) {
+    try {
+      return JSON.parse(text);
+    } catch {
+      return void 0;
     }
-    if (node.kind === 103 /* InKeyword */ && isTypeParameterDeclaration(parent2) && isMappedTypeNode(parent2.parent)) {
-      return parent2.name;
+  }
+  function consumesNodeCoreModules(sourceFile) {
+    return some(sourceFile.imports, ({ text }) => ts_JsTyping_exports.nodeCoreModules.has(text));
+  }
+  function isInsideNodeModules(fileOrDirectory) {
+    return contains(getPathComponents(fileOrDirectory), "node_modules");
+  }
+  function isDiagnosticWithLocation(diagnostic) {
+    return diagnostic.file !== void 0 && diagnostic.start !== void 0 && diagnostic.length !== void 0;
+  }
+  function findDiagnosticForNode(node, sortedFileDiagnostics) {
+    const span = createTextSpanFromNode(node);
+    const index = binarySearchKey(sortedFileDiagnostics, span, identity, compareTextSpans);
+    if (index >= 0) {
+      const diagnostic = sortedFileDiagnostics[index];
+      Debug.assertEqual(diagnostic.file, node.getSourceFile(), "Diagnostics proided to 'findDiagnosticForNode' must be from a single SourceFile");
+      return cast(diagnostic, isDiagnosticWithLocation);
     }
-    if (node.kind === 143 /* KeyOfKeyword */ && isTypeOperatorNode(parent2) && parent2.operator === 143 /* KeyOfKeyword */ && isTypeReferenceNode(parent2.type)) {
-      return parent2.type.typeName;
+  }
+  function getDiagnosticsWithinSpan(span, sortedFileDiagnostics) {
+    var _a;
+    let index = binarySearchKey(sortedFileDiagnostics, span.start, (diag2) => diag2.start, compareValues);
+    if (index < 0) {
+      index = ~index;
     }
-    if (node.kind === 148 /* ReadonlyKeyword */ && isTypeOperatorNode(parent2) && parent2.operator === 148 /* ReadonlyKeyword */ && isArrayTypeNode(parent2.type) && isTypeReferenceNode(parent2.type.elementType)) {
-      return parent2.type.elementType.typeName;
+    while (((_a = sortedFileDiagnostics[index - 1]) == null ? void 0 : _a.start) === span.start) {
+      index--;
     }
-    if (!forRename) {
-      if (node.kind === 105 /* NewKeyword */ && isNewExpression(parent2) || node.kind === 116 /* VoidKeyword */ && isVoidExpression(parent2) || node.kind === 114 /* TypeOfKeyword */ && isTypeOfExpression(parent2) || node.kind === 135 /* AwaitKeyword */ && isAwaitExpression(parent2) || node.kind === 127 /* YieldKeyword */ && isYieldExpression(parent2) || node.kind === 91 /* DeleteKeyword */ && isDeleteExpression(parent2)) {
-        if (parent2.expression) {
-          return skipOuterExpressions(parent2.expression);
-        }
-      }
-      if ((node.kind === 103 /* InKeyword */ || node.kind === 104 /* InstanceOfKeyword */) && isBinaryExpression(parent2) && parent2.operatorToken === node) {
-        return skipOuterExpressions(parent2.right);
+    const result = [];
+    const end = textSpanEnd(span);
+    while (true) {
+      const diagnostic = tryCast(sortedFileDiagnostics[index], isDiagnosticWithLocation);
+      if (!diagnostic || diagnostic.start > end) {
+        break;
       }
-      if (node.kind === 130 /* AsKeyword */ && isAsExpression(parent2) && isTypeReferenceNode(parent2.type)) {
-        return parent2.type.typeName;
+      if (textSpanContainsTextSpan(span, diagnostic)) {
+        result.push(diagnostic);
       }
-      if (node.kind === 103 /* InKeyword */ && isForInStatement(parent2) || node.kind === 164 /* OfKeyword */ && isForOfStatement(parent2)) {
-        return skipOuterExpressions(parent2.expression);
+      index++;
+    }
+    return result;
+  }
+  function getRefactorContextSpan({ startPosition, endPosition }) {
+    return createTextSpanFromBounds(startPosition, endPosition === void 0 ? startPosition : endPosition);
+  }
+  function getFixableErrorSpanExpression(sourceFile, span) {
+    const token = getTokenAtPosition(sourceFile, span.start);
+    const expression = findAncestor(token, (node) => {
+      if (node.getStart(sourceFile) < span.start || node.getEnd() > textSpanEnd(span)) {
+        return "quit";
       }
+      return isExpression(node) && textSpansEqual(span, createTextSpanFromNode(node, sourceFile));
+    });
+    return expression;
+  }
+  function mapOneOrMany(valueOrArray, f, resultSelector = identity) {
+    return valueOrArray ? isArray(valueOrArray) ? resultSelector(map(valueOrArray, f)) : f(valueOrArray, 0) : void 0;
+  }
+  function firstOrOnly(valueOrArray) {
+    return isArray(valueOrArray) ? first(valueOrArray) : valueOrArray;
+  }
+  function getNamesForExportedSymbol(symbol, scriptTarget) {
+    if (needsNameFromDeclaration(symbol)) {
+      const fromDeclaration = getDefaultLikeExportNameFromDeclaration(symbol);
+      if (fromDeclaration)
+        return fromDeclaration;
+      const fileNameCase = ts_codefix_exports.moduleSymbolToValidIdentifier(
+        getSymbolParentOrFail(symbol),
+        scriptTarget,
+        /*forceCapitalize*/
+        false
+      );
+      const capitalized = ts_codefix_exports.moduleSymbolToValidIdentifier(
+        getSymbolParentOrFail(symbol),
+        scriptTarget,
+        /*forceCapitalize*/
+        true
+      );
+      if (fileNameCase === capitalized)
+        return fileNameCase;
+      return [fileNameCase, capitalized];
     }
-    return node;
+    return symbol.name;
   }
-  function getAdjustedReferenceLocation(node) {
-    return getAdjustedLocation(
-      node,
-      /*forRename*/
-      false
-    );
+  function getNameForExportedSymbol(symbol, scriptTarget, preferCapitalized) {
+    if (needsNameFromDeclaration(symbol)) {
+      return getDefaultLikeExportNameFromDeclaration(symbol) || ts_codefix_exports.moduleSymbolToValidIdentifier(getSymbolParentOrFail(symbol), scriptTarget, !!preferCapitalized);
+    }
+    return symbol.name;
   }
-  function getAdjustedRenameLocation(node) {
-    return getAdjustedLocation(
-      node,
-      /*forRename*/
-      true
-    );
+  function needsNameFromDeclaration(symbol) {
+    return !(symbol.flags & 33554432 /* Transient */) && (symbol.escapedName === "export=" /* ExportEquals */ || symbol.escapedName === "default" /* Default */);
   }
-  function getTouchingPropertyName(sourceFile, position) {
-    return getTouchingToken(sourceFile, position, (n) => isPropertyNameLiteral(n) || isKeyword(n.kind) || isPrivateIdentifier(n));
+  function getDefaultLikeExportNameFromDeclaration(symbol) {
+    return firstDefined(symbol.declarations, (d) => {
+      var _a, _b, _c;
+      if (isExportAssignment(d)) {
+        return (_a = tryCast(skipOuterExpressions(d.expression), isIdentifier)) == null ? void 0 : _a.text;
+      }
+      if (isExportSpecifier(d) && d.symbol.flags === 2097152 /* Alias */) {
+        return (_b = tryCast(d.propertyName, isIdentifier)) == null ? void 0 : _b.text;
+      }
+      return (_c = tryCast(getNameOfDeclaration(d), isIdentifier)) == null ? void 0 : _c.text;
+    });
   }
-  function getTouchingToken(sourceFile, position, includePrecedingTokenAtEndPosition) {
-    return getTokenAtPositionWorker(
-      sourceFile,
-      position,
-      /*allowPositionInLeadingTrivia*/
-      false,
-      includePrecedingTokenAtEndPosition,
-      /*includeEndPosition*/
-      false
+  function getSymbolParentOrFail(symbol) {
+    var _a;
+    return Debug.checkDefined(
+      symbol.parent,
+      `Symbol parent was undefined. Flags: ${Debug.formatSymbolFlags(symbol.flags)}. Declarations: ${(_a = symbol.declarations) == null ? void 0 : _a.map((d) => {
+        const kind = Debug.formatSyntaxKind(d.kind);
+        const inJS = isInJSFile(d);
+        const { expression } = d;
+        return (inJS ? "[JS]" : "") + kind + (expression ? ` (expression: ${Debug.formatSyntaxKind(expression.kind)})` : "");
+      }).join(", ")}.`
     );
   }
-  function getTokenAtPosition(sourceFile, position) {
-    return getTokenAtPositionWorker(
-      sourceFile,
-      position,
-      /*allowPositionInLeadingTrivia*/
-      true,
-      /*includePrecedingTokenAtEndPosition*/
-      void 0,
-      /*includeEndPosition*/
-      false
-    );
+  function stringContainsAt(haystack, needle, startIndex) {
+    const needleLength = needle.length;
+    if (needleLength + startIndex > haystack.length) {
+      return false;
+    }
+    for (let i = 0; i < needleLength; i++) {
+      if (needle.charCodeAt(i) !== haystack.charCodeAt(i + startIndex))
+        return false;
+    }
+    return true;
   }
-  function getTokenAtPositionWorker(sourceFile, position, allowPositionInLeadingTrivia, includePrecedingTokenAtEndPosition, includeEndPosition) {
-    let current = sourceFile;
-    let foundToken;
-    outer:
-      while (true) {
-        const children = current.getChildren(sourceFile);
-        const i = binarySearchKey(children, position, (_, i2) => i2, (middle, _) => {
-          const end = children[middle].getEnd();
-          if (end < position) {
-            return -1 /* LessThan */;
-          }
-          const start = allowPositionInLeadingTrivia ? children[middle].getFullStart() : children[middle].getStart(
-            sourceFile,
-            /*includeJsDocComment*/
-            true
-          );
-          if (start > position) {
-            return 1 /* GreaterThan */;
-          }
-          if (nodeContainsPosition(children[middle], start, end)) {
-            if (children[middle - 1]) {
-              if (nodeContainsPosition(children[middle - 1])) {
-                return 1 /* GreaterThan */;
+  function startsWithUnderscore(name) {
+    return name.charCodeAt(0) === 95 /* _ */;
+  }
+  function isGlobalDeclaration(declaration) {
+    return !isNonGlobalDeclaration(declaration);
+  }
+  function isNonGlobalDeclaration(declaration) {
+    const sourceFile = declaration.getSourceFile();
+    if (!sourceFile.externalModuleIndicator && !sourceFile.commonJsModuleIndicator) {
+      return false;
+    }
+    return isInJSFile(declaration) || !findAncestor(declaration, (d) => isModuleDeclaration(d) && isGlobalScopeAugmentation(d));
+  }
+  function isDeprecatedDeclaration(decl) {
+    return !!(getCombinedNodeFlagsAlwaysIncludeJSDoc(decl) & 65536 /* Deprecated */);
+  }
+  function shouldUseUriStyleNodeCoreModules(file, program) {
+    const decisionFromFile = firstDefined(file.imports, (node) => {
+      if (ts_JsTyping_exports.nodeCoreModules.has(node.text)) {
+        return startsWith(node.text, "node:");
+      }
+    });
+    return decisionFromFile ?? program.usesUriStyleNodeCoreModules;
+  }
+  function getNewLineKind(newLineCharacter) {
+    return newLineCharacter === "\n" ? 1 /* LineFeed */ : 0 /* CarriageReturnLineFeed */;
+  }
+  function diagnosticToString(diag2) {
+    return isArray(diag2) ? formatStringFromArgs(getLocaleSpecificMessage(diag2[0]), diag2.slice(1)) : getLocaleSpecificMessage(diag2);
+  }
+  function getFormatCodeSettingsForWriting({ options }, sourceFile) {
+    const shouldAutoDetectSemicolonPreference = !options.semicolons || options.semicolons === "ignore" /* Ignore */;
+    const shouldRemoveSemicolons = options.semicolons === "remove" /* Remove */ || shouldAutoDetectSemicolonPreference && !probablyUsesSemicolons(sourceFile);
+    return {
+      ...options,
+      semicolons: shouldRemoveSemicolons ? "remove" /* Remove */ : "ignore" /* Ignore */
+    };
+  }
+  function jsxModeNeedsExplicitImport(jsx) {
+    return jsx === 2 /* React */ || jsx === 3 /* ReactNative */;
+  }
+  function isSourceFileFromLibrary(program, node) {
+    return program.isSourceFileFromExternalLibrary(node) || program.isSourceFileDefaultLibrary(node);
+  }
+  function newCaseClauseTracker(checker, clauses) {
+    const existingStrings = /* @__PURE__ */ new Set();
+    const existingNumbers = /* @__PURE__ */ new Set();
+    const existingBigInts = /* @__PURE__ */ new Set();
+    for (const clause of clauses) {
+      if (!isDefaultClause(clause)) {
+        const expression = skipParentheses(clause.expression);
+        if (isLiteralExpression(expression)) {
+          switch (expression.kind) {
+            case 15 /* NoSubstitutionTemplateLiteral */:
+            case 11 /* StringLiteral */:
+              existingStrings.add(expression.text);
+              break;
+            case 9 /* NumericLiteral */:
+              existingNumbers.add(parseInt(expression.text));
+              break;
+            case 10 /* BigIntLiteral */:
+              const parsedBigInt = parseBigInt(endsWith(expression.text, "n") ? expression.text.slice(0, -1) : expression.text);
+              if (parsedBigInt) {
+                existingBigInts.add(pseudoBigIntToString(parsedBigInt));
               }
-            }
-            return 0 /* EqualTo */;
+              break;
           }
-          if (includePrecedingTokenAtEndPosition && start === position && children[middle - 1] && children[middle - 1].getEnd() === position && nodeContainsPosition(children[middle - 1])) {
-            return 1 /* GreaterThan */;
+        } else {
+          const symbol = checker.getSymbolAtLocation(clause.expression);
+          if (symbol && symbol.valueDeclaration && isEnumMember(symbol.valueDeclaration)) {
+            const enumValue = checker.getConstantValue(symbol.valueDeclaration);
+            if (enumValue !== void 0) {
+              addValue(enumValue);
+            }
           }
-          return -1 /* LessThan */;
-        });
-        if (foundToken) {
-          return foundToken;
-        }
-        if (i >= 0 && children[i]) {
-          current = children[i];
-          continue outer;
         }
-        return current;
       }
-    function nodeContainsPosition(node, start, end) {
-      end ?? (end = node.getEnd());
-      if (end < position) {
-        return false;
-      }
-      start ?? (start = allowPositionInLeadingTrivia ? node.getFullStart() : node.getStart(
-        sourceFile,
-        /*includeJsDocComment*/
-        true
-      ));
-      if (start > position) {
-        return false;
+    }
+    return {
+      addValue,
+      hasValue
+    };
+    function addValue(value) {
+      switch (typeof value) {
+        case "string":
+          existingStrings.add(value);
+          break;
+        case "number":
+          existingNumbers.add(value);
       }
-      if (position < end || position === end && (node.kind === 1 /* EndOfFileToken */ || includeEndPosition)) {
-        return true;
-      } else if (includePrecedingTokenAtEndPosition && end === position) {
-        const previousToken = findPrecedingToken(position, sourceFile, node);
-        if (previousToken && includePrecedingTokenAtEndPosition(previousToken)) {
-          foundToken = previousToken;
-          return true;
-        }
+    }
+    function hasValue(value) {
+      switch (typeof value) {
+        case "string":
+          return existingStrings.has(value);
+        case "number":
+          return existingNumbers.has(value);
+        case "object":
+          return existingBigInts.has(pseudoBigIntToString(value));
       }
-      return false;
     }
   }
-  function findFirstNonJsxWhitespaceToken(sourceFile, position) {
-    let tokenAtPosition = getTokenAtPosition(sourceFile, position);
-    while (isWhiteSpaceOnlyJsxText(tokenAtPosition)) {
-      const nextToken = findNextToken(tokenAtPosition, tokenAtPosition.parent, sourceFile);
-      if (!nextToken)
-        return;
-      tokenAtPosition = nextToken;
+  function fileShouldUseJavaScriptRequire(file, program, host, preferRequire) {
+    var _a;
+    const fileName = typeof file === "string" ? file : file.fileName;
+    if (!hasJSFileExtension(fileName)) {
+      return false;
     }
-    return tokenAtPosition;
-  }
-  function findTokenOnLeftOfPosition(file, position) {
-    const tokenAtPosition = getTokenAtPosition(file, position);
-    if (isToken(tokenAtPosition) && position > tokenAtPosition.getStart(file) && position < tokenAtPosition.getEnd()) {
-      return tokenAtPosition;
+    const compilerOptions = program.getCompilerOptions();
+    const moduleKind = getEmitModuleKind(compilerOptions);
+    const impliedNodeFormat = typeof file === "string" ? getImpliedNodeFormatForFile(toPath(file, host.getCurrentDirectory(), hostGetCanonicalFileName(host)), (_a = program.getPackageJsonInfoCache) == null ? void 0 : _a.call(program), host, compilerOptions) : file.impliedNodeFormat;
+    if (impliedNodeFormat === 99 /* ESNext */) {
+      return false;
     }
-    return findPrecedingToken(position, file);
-  }
-  function findNextToken(previousToken, parent2, sourceFile) {
-    return find2(parent2);
-    function find2(n) {
-      if (isToken(n) && n.pos === previousToken.end) {
-        return n;
+    if (impliedNodeFormat === 1 /* CommonJS */) {
+      return true;
+    }
+    if (compilerOptions.verbatimModuleSyntax && moduleKind === 1 /* CommonJS */) {
+      return true;
+    }
+    if (compilerOptions.verbatimModuleSyntax && emitModuleKindIsNonNodeESM(moduleKind)) {
+      return false;
+    }
+    if (typeof file === "object") {
+      if (file.commonJsModuleIndicator) {
+        return true;
+      }
+      if (file.externalModuleIndicator) {
+        return false;
       }
-      return firstDefined(n.getChildren(sourceFile), (child) => {
-        const shouldDiveInChildNode = (
-          // previous token is enclosed somewhere in the child
-          child.pos <= previousToken.pos && child.end > previousToken.end || // previous token ends exactly at the beginning of child
-          child.pos === previousToken.end
-        );
-        return shouldDiveInChildNode && nodeHasTokens(child, sourceFile) ? find2(child) : void 0;
-      });
     }
+    return preferRequire;
   }
-  function findPrecedingToken(position, sourceFile, startNode2, excludeJsdoc) {
-    const result = find2(startNode2 || sourceFile);
-    Debug.assert(!(result && isWhiteSpaceOnlyJsxText(result)));
-    return result;
-    function find2(n) {
-      if (isNonWhitespaceToken(n) && n.kind !== 1 /* EndOfFileToken */) {
-        return n;
-      }
-      const children = n.getChildren(sourceFile);
-      const i = binarySearchKey(children, position, (_, i2) => i2, (middle, _) => {
-        if (position < children[middle].end) {
-          if (!children[middle - 1] || position >= children[middle - 1].end) {
-            return 0 /* EqualTo */;
-          }
-          return 1 /* GreaterThan */;
+  var scanner, SemanticMeaning, tripleSlashDirectivePrefixRegex, typeKeywords, QuotePreference, displayPartWriter, lineFeed2, ANONYMOUS, syntaxMayBeASICandidate;
+  var init_utilities4 = __esm({
+    "src/services/utilities.ts"() {
+      "use strict";
+      init_pnp();
+      init_ts4();
+      scanner = createScanner(
+        99 /* Latest */,
+        /*skipTrivia*/
+        true
+      );
+      SemanticMeaning = /* @__PURE__ */ ((SemanticMeaning3) => {
+        SemanticMeaning3[SemanticMeaning3["None"] = 0] = "None";
+        SemanticMeaning3[SemanticMeaning3["Value"] = 1] = "Value";
+        SemanticMeaning3[SemanticMeaning3["Type"] = 2] = "Type";
+        SemanticMeaning3[SemanticMeaning3["Namespace"] = 4] = "Namespace";
+        SemanticMeaning3[SemanticMeaning3["All"] = 7] = "All";
+        return SemanticMeaning3;
+      })(SemanticMeaning || {});
+      tripleSlashDirectivePrefixRegex = /^\/\/\/\s* {
+        QuotePreference7[QuotePreference7["Single"] = 0] = "Single";
+        QuotePreference7[QuotePreference7["Double"] = 1] = "Double";
+        return QuotePreference7;
+      })(QuotePreference || {});
+      displayPartWriter = getDisplayPartWriter();
+      lineFeed2 = "\n";
+      ANONYMOUS = "anonymous function";
+      syntaxMayBeASICandidate = or(
+        syntaxRequiresTrailingCommaOrSemicolonOrASI,
+        syntaxRequiresTrailingFunctionBlockOrSemicolonOrASI,
+        syntaxRequiresTrailingModuleBlockOrSemicolonOrASI,
+        syntaxRequiresTrailingSemicolonOrASI
+      );
+    }
+  });
+
+  // src/services/exportInfoMap.ts
+  function createCacheableExportInfoMap(host) {
+    let exportInfoId = 1;
+    const exportInfo = createMultiMap();
+    const symbols = /* @__PURE__ */ new Map();
+    const packages = /* @__PURE__ */ new Map();
+    let usableByFileName;
+    const cache = {
+      isUsableByFile: (importingFile) => importingFile === usableByFileName,
+      isEmpty: () => !exportInfo.size,
+      clear: () => {
+        exportInfo.clear();
+        symbols.clear();
+        usableByFileName = void 0;
+      },
+      add: (importingFile, symbol, symbolTableKey, moduleSymbol, moduleFile, exportKind, isFromPackageJson, checker) => {
+        if (importingFile !== usableByFileName) {
+          cache.clear();
+          usableByFileName = importingFile;
         }
-        return -1 /* LessThan */;
-      });
-      if (i >= 0 && children[i]) {
-        const child = children[i];
-        if (position < child.end) {
-          const start = child.getStart(
-            sourceFile,
-            /*includeJsDoc*/
-            !excludeJsdoc
-          );
-          const lookInPreviousChild = start >= position || // cursor in the leading trivia
-          !nodeHasTokens(child, sourceFile) || isWhiteSpaceOnlyJsxText(child);
-          if (lookInPreviousChild) {
-            const candidate2 = findRightmostChildNodeWithTokens(
-              children,
-              /*exclusiveStartPosition*/
-              i,
-              sourceFile,
-              n.kind
-            );
-            if (candidate2) {
-              if (!excludeJsdoc && isJSDocCommentContainingNode(candidate2) && candidate2.getChildren(sourceFile).length) {
-                return find2(candidate2);
+        let packageName;
+        if (moduleFile) {
+          const nodeModulesPathParts = getNodeModulePathParts(moduleFile.fileName);
+          if (nodeModulesPathParts) {
+            const { topLevelNodeModulesIndex, topLevelPackageNameIndex, packageRootIndex } = nodeModulesPathParts;
+            packageName = unmangleScopedPackageName(getPackageNameFromTypesPackageName(moduleFile.fileName.substring(topLevelPackageNameIndex + 1, packageRootIndex)));
+            if (startsWith(importingFile, moduleFile.path.substring(0, topLevelNodeModulesIndex))) {
+              const prevDeepestNodeModulesPath = packages.get(packageName);
+              const nodeModulesPath = moduleFile.fileName.substring(0, topLevelPackageNameIndex + 1);
+              if (prevDeepestNodeModulesPath) {
+                const prevDeepestNodeModulesIndex = prevDeepestNodeModulesPath.indexOf(nodeModulesPathPart);
+                if (topLevelNodeModulesIndex > prevDeepestNodeModulesIndex) {
+                  packages.set(packageName, nodeModulesPath);
+                }
+              } else {
+                packages.set(packageName, nodeModulesPath);
               }
-              return findRightmostToken(candidate2, sourceFile);
             }
-            return void 0;
-          } else {
-            return find2(child);
           }
         }
+        const isDefault = exportKind === 1 /* Default */;
+        const namedSymbol = isDefault && getLocalSymbolForExportDefault(symbol) || symbol;
+        const names = exportKind === 0 /* Named */ || isExternalModuleSymbol(namedSymbol) ? unescapeLeadingUnderscores(symbolTableKey) : getNamesForExportedSymbol(
+          namedSymbol,
+          /*scriptTarget*/
+          void 0
+        );
+        const symbolName2 = typeof names === "string" ? names : names[0];
+        const capitalizedSymbolName = typeof names === "string" ? void 0 : names[1];
+        const moduleName = stripQuotes(moduleSymbol.name);
+        const id = exportInfoId++;
+        const target = skipAlias(symbol, checker);
+        const storedSymbol = symbol.flags & 33554432 /* Transient */ ? void 0 : symbol;
+        const storedModuleSymbol = moduleSymbol.flags & 33554432 /* Transient */ ? void 0 : moduleSymbol;
+        if (!storedSymbol || !storedModuleSymbol)
+          symbols.set(id, [symbol, moduleSymbol]);
+        exportInfo.add(key(symbolName2, symbol, isExternalModuleNameRelative(moduleName) ? void 0 : moduleName, checker), {
+          id,
+          symbolTableKey,
+          symbolName: symbolName2,
+          capitalizedSymbolName,
+          moduleName,
+          moduleFile,
+          moduleFileName: moduleFile == null ? void 0 : moduleFile.fileName,
+          packageName,
+          exportKind,
+          targetFlags: target.flags,
+          isFromPackageJson,
+          symbol: storedSymbol,
+          moduleSymbol: storedModuleSymbol
+        });
+      },
+      get: (importingFile, key2) => {
+        if (importingFile !== usableByFileName)
+          return;
+        const result = exportInfo.get(key2);
+        return result == null ? void 0 : result.map(rehydrateCachedInfo);
+      },
+      search: (importingFile, preferCapitalized, matches, action) => {
+        if (importingFile !== usableByFileName)
+          return;
+        return forEachEntry(exportInfo, (info, key2) => {
+          const { symbolName: symbolName2, ambientModuleName } = parseKey(key2);
+          const name = preferCapitalized && info[0].capitalizedSymbolName || symbolName2;
+          if (matches(name, info[0].targetFlags)) {
+            const rehydrated = info.map(rehydrateCachedInfo);
+            const filtered = rehydrated.filter((r, i) => isNotShadowedByDeeperNodeModulesPackage(r, info[i].packageName));
+            if (filtered.length) {
+              const res = action(filtered, name, !!ambientModuleName, key2);
+              if (res !== void 0)
+                return res;
+            }
+          }
+        });
+      },
+      releaseSymbols: () => {
+        symbols.clear();
+      },
+      onFileChanged: (oldSourceFile, newSourceFile, typeAcquisitionEnabled) => {
+        if (fileIsGlobalOnly(oldSourceFile) && fileIsGlobalOnly(newSourceFile)) {
+          return false;
+        }
+        if (usableByFileName && usableByFileName !== newSourceFile.path || // If ATA is enabled, auto-imports uses existing imports to guess whether you want auto-imports from node.
+        // Adding or removing imports from node could change the outcome of that guess, so could change the suggestions list.
+        typeAcquisitionEnabled && consumesNodeCoreModules(oldSourceFile) !== consumesNodeCoreModules(newSourceFile) || // Module agumentation and ambient module changes can add or remove exports available to be auto-imported.
+        // Changes elsewhere in the file can change the *type* of an export in a module augmentation,
+        // but type info is gathered in getCompletionEntryDetails, which doesn't use the cache.
+        !arrayIsEqualTo(oldSourceFile.moduleAugmentations, newSourceFile.moduleAugmentations) || !ambientModuleDeclarationsAreEqual(oldSourceFile, newSourceFile)) {
+          cache.clear();
+          return true;
+        }
+        usableByFileName = newSourceFile.path;
+        return false;
+      }
+    };
+    if (Debug.isDebugging) {
+      Object.defineProperty(cache, "__cache", { value: exportInfo });
+    }
+    return cache;
+    function rehydrateCachedInfo(info) {
+      if (info.symbol && info.moduleSymbol)
+        return info;
+      const { id, exportKind, targetFlags, isFromPackageJson, moduleFileName } = info;
+      const [cachedSymbol, cachedModuleSymbol] = symbols.get(id) || emptyArray;
+      if (cachedSymbol && cachedModuleSymbol) {
+        return {
+          symbol: cachedSymbol,
+          moduleSymbol: cachedModuleSymbol,
+          moduleFileName,
+          exportKind,
+          targetFlags,
+          isFromPackageJson
+        };
+      }
+      const checker = (isFromPackageJson ? host.getPackageJsonAutoImportProvider() : host.getCurrentProgram()).getTypeChecker();
+      const moduleSymbol = info.moduleSymbol || cachedModuleSymbol || Debug.checkDefined(
+        info.moduleFile ? checker.getMergedSymbol(info.moduleFile.symbol) : checker.tryFindAmbientModule(info.moduleName)
+      );
+      const symbol = info.symbol || cachedSymbol || Debug.checkDefined(
+        exportKind === 2 /* ExportEquals */ ? checker.resolveExternalModuleSymbol(moduleSymbol) : checker.tryGetMemberInModuleExportsAndProperties(unescapeLeadingUnderscores(info.symbolTableKey), moduleSymbol),
+        `Could not find symbol '${info.symbolName}' by key '${info.symbolTableKey}' in module ${moduleSymbol.name}`
+      );
+      symbols.set(id, [symbol, moduleSymbol]);
+      return {
+        symbol,
+        moduleSymbol,
+        moduleFileName,
+        exportKind,
+        targetFlags,
+        isFromPackageJson
+      };
+    }
+    function key(importedName, symbol, ambientModuleName, checker) {
+      const moduleKey = ambientModuleName || "";
+      return `${importedName.length} ${getSymbolId(skipAlias(symbol, checker))} ${importedName} ${moduleKey}`;
+    }
+    function parseKey(key2) {
+      const firstSpace = key2.indexOf(" ");
+      const secondSpace = key2.indexOf(" ", firstSpace + 1);
+      const symbolNameLength = parseInt(key2.substring(0, firstSpace), 10);
+      const data = key2.substring(secondSpace + 1);
+      const symbolName2 = data.substring(0, symbolNameLength);
+      const moduleKey = data.substring(symbolNameLength + 1);
+      const ambientModuleName = moduleKey === "" ? void 0 : moduleKey;
+      return { symbolName: symbolName2, ambientModuleName };
+    }
+    function fileIsGlobalOnly(file) {
+      return !file.commonJsModuleIndicator && !file.externalModuleIndicator && !file.moduleAugmentations && !file.ambientModuleNames;
+    }
+    function ambientModuleDeclarationsAreEqual(oldSourceFile, newSourceFile) {
+      if (!arrayIsEqualTo(oldSourceFile.ambientModuleNames, newSourceFile.ambientModuleNames)) {
+        return false;
+      }
+      let oldFileStatementIndex = -1;
+      let newFileStatementIndex = -1;
+      for (const ambientModuleName of newSourceFile.ambientModuleNames) {
+        const isMatchingModuleDeclaration = (node) => isNonGlobalAmbientModule(node) && node.name.text === ambientModuleName;
+        oldFileStatementIndex = findIndex(oldSourceFile.statements, isMatchingModuleDeclaration, oldFileStatementIndex + 1);
+        newFileStatementIndex = findIndex(newSourceFile.statements, isMatchingModuleDeclaration, newFileStatementIndex + 1);
+        if (oldSourceFile.statements[oldFileStatementIndex] !== newSourceFile.statements[newFileStatementIndex]) {
+          return false;
+        }
+      }
+      return true;
+    }
+    function isNotShadowedByDeeperNodeModulesPackage(info, packageName) {
+      if (!packageName || !info.moduleFileName)
+        return true;
+      const typingsCacheLocation = host.getGlobalTypingsCacheLocation();
+      if (typingsCacheLocation && startsWith(info.moduleFileName, typingsCacheLocation))
+        return true;
+      const packageDeepestNodeModulesPath = packages.get(packageName);
+      return !packageDeepestNodeModulesPath || startsWith(info.moduleFileName, packageDeepestNodeModulesPath);
+    }
+  }
+  function isImportableFile(program, from, to, preferences, packageJsonFilter, moduleSpecifierResolutionHost, moduleSpecifierCache) {
+    var _a;
+    if (from === to)
+      return false;
+    const cachedResult = moduleSpecifierCache == null ? void 0 : moduleSpecifierCache.get(from.path, to.path, preferences, {});
+    if ((cachedResult == null ? void 0 : cachedResult.isBlockedByPackageJsonDependencies) !== void 0) {
+      return !cachedResult.isBlockedByPackageJsonDependencies;
+    }
+    const getCanonicalFileName = hostGetCanonicalFileName(moduleSpecifierResolutionHost);
+    const globalTypingsCache = (_a = moduleSpecifierResolutionHost.getGlobalTypingsCacheLocation) == null ? void 0 : _a.call(moduleSpecifierResolutionHost);
+    const hasImportablePath = !!ts_moduleSpecifiers_exports.forEachFileNameOfModule(
+      from.fileName,
+      to.fileName,
+      moduleSpecifierResolutionHost,
+      /*preferSymlinks*/
+      false,
+      (toPath3) => {
+        const toFile = program.getSourceFile(toPath3);
+        return (toFile === to || !toFile) && isImportablePath(from.fileName, toPath3, getCanonicalFileName, globalTypingsCache);
       }
-      Debug.assert(startNode2 !== void 0 || n.kind === 311 /* SourceFile */ || n.kind === 1 /* EndOfFileToken */ || isJSDocCommentContainingNode(n));
-      const candidate = findRightmostChildNodeWithTokens(
-        children,
-        /*exclusiveStartPosition*/
-        children.length,
-        sourceFile,
-        n.kind
-      );
-      return candidate && findRightmostToken(candidate, sourceFile);
+    );
+    if (packageJsonFilter) {
+      const isAutoImportable = hasImportablePath && packageJsonFilter.allowsImportingSourceFile(to, moduleSpecifierResolutionHost);
+      moduleSpecifierCache == null ? void 0 : moduleSpecifierCache.setBlockedByPackageJsonDependencies(from.path, to.path, preferences, {}, !isAutoImportable);
+      return isAutoImportable;
     }
+    return hasImportablePath;
   }
-  function isNonWhitespaceToken(n) {
-    return isToken(n) && !isWhiteSpaceOnlyJsxText(n);
-  }
-  function findRightmostToken(n, sourceFile) {
-    if (isNonWhitespaceToken(n)) {
-      return n;
-    }
-    const children = n.getChildren(sourceFile);
-    if (children.length === 0) {
-      return n;
+  function isImportablePath(fromPath, toPath3, getCanonicalFileName, globalCachePath) {
+    if (getPnpApi(fromPath)) {
+      return isImportablePathPnp(fromPath, toPath3);
     }
-    const candidate = findRightmostChildNodeWithTokens(
-      children,
-      /*exclusiveStartPosition*/
-      children.length,
-      sourceFile,
-      n.kind
-    );
-    return candidate && findRightmostToken(candidate, sourceFile);
+    const toNodeModules = forEachAncestorDirectory(toPath3, (ancestor) => getBaseFileName(ancestor) === "node_modules" ? ancestor : void 0);
+    const toNodeModulesParent = toNodeModules && getDirectoryPath(getCanonicalFileName(toNodeModules));
+    return toNodeModulesParent === void 0 || startsWith(getCanonicalFileName(fromPath), toNodeModulesParent) || !!globalCachePath && startsWith(getCanonicalFileName(globalCachePath), toNodeModulesParent);
   }
-  function findRightmostChildNodeWithTokens(children, exclusiveStartPosition, sourceFile, parentKind) {
-    for (let i = exclusiveStartPosition - 1; i >= 0; i--) {
-      const child = children[i];
-      if (isWhiteSpaceOnlyJsxText(child)) {
-        if (i === 0 && (parentKind === 12 /* JsxText */ || parentKind === 284 /* JsxSelfClosingElement */)) {
-          Debug.fail("`JsxText` tokens should not be the first child of `JsxElement | JsxSelfClosingElement`");
+  function forEachExternalModuleToImportFrom(program, host, preferences, useAutoImportProvider, cb) {
+    var _a, _b;
+    const useCaseSensitiveFileNames2 = hostUsesCaseSensitiveFileNames(host);
+    const excludePatterns = preferences.autoImportFileExcludePatterns && mapDefined(preferences.autoImportFileExcludePatterns, (spec) => {
+      const pattern = getPatternFromSpec(spec, "", "exclude");
+      return pattern ? getRegexFromPattern(pattern, useCaseSensitiveFileNames2) : void 0;
+    });
+    forEachExternalModule(program.getTypeChecker(), program.getSourceFiles(), excludePatterns, (module2, file) => cb(
+      module2,
+      file,
+      program,
+      /*isFromPackageJson*/
+      false
+    ));
+    const autoImportProvider = useAutoImportProvider && ((_a = host.getPackageJsonAutoImportProvider) == null ? void 0 : _a.call(host));
+    if (autoImportProvider) {
+      const start = timestamp();
+      const checker = program.getTypeChecker();
+      forEachExternalModule(autoImportProvider.getTypeChecker(), autoImportProvider.getSourceFiles(), excludePatterns, (module2, file) => {
+        if (file && !program.getSourceFile(file.fileName) || !file && !checker.resolveName(
+          module2.name,
+          /*location*/
+          void 0,
+          1536 /* Module */,
+          /*excludeGlobals*/
+          false
+        )) {
+          cb(
+            module2,
+            file,
+            autoImportProvider,
+            /*isFromPackageJson*/
+            true
+          );
         }
-      } else if (nodeHasTokens(children[i], sourceFile)) {
-        return children[i];
-      }
+      });
+      (_b = host.log) == null ? void 0 : _b.call(host, `forEachExternalModuleToImportFrom autoImportProvider: ${timestamp() - start}`);
     }
   }
-  function isInString(sourceFile, position, previousToken = findPrecedingToken(position, sourceFile)) {
-    if (previousToken && isStringTextContainingNode(previousToken)) {
-      const start = previousToken.getStart(sourceFile);
-      const end = previousToken.getEnd();
-      if (start < position && position < end) {
-        return true;
+  function forEachExternalModule(checker, allSourceFiles, excludePatterns, cb) {
+    var _a;
+    const isExcluded = excludePatterns && ((fileName) => excludePatterns.some((p) => p.test(fileName)));
+    for (const ambient of checker.getAmbientModules()) {
+      if (!ambient.name.includes("*") && !(excludePatterns && ((_a = ambient.declarations) == null ? void 0 : _a.every((d) => isExcluded(d.getSourceFile().fileName))))) {
+        cb(
+          ambient,
+          /*sourceFile*/
+          void 0
+        );
       }
-      if (position === end) {
-        return !!previousToken.isUnterminated;
+    }
+    for (const sourceFile of allSourceFiles) {
+      if (isExternalOrCommonJsModule(sourceFile) && !(isExcluded == null ? void 0 : isExcluded(sourceFile.fileName))) {
+        cb(checker.getMergedSymbol(sourceFile.symbol), sourceFile);
       }
     }
-    return false;
   }
-  function isInsideJsxElementOrAttribute(sourceFile, position) {
-    const token = getTokenAtPosition(sourceFile, position);
-    if (!token) {
-      return false;
-    }
-    if (token.kind === 12 /* JsxText */) {
-      return true;
-    }
-    if (token.kind === 30 /* LessThanToken */ && token.parent.kind === 12 /* JsxText */) {
-      return true;
-    }
-    if (token.kind === 30 /* LessThanToken */ && token.parent.kind === 293 /* JsxExpression */) {
-      return true;
-    }
-    if (token && token.kind === 20 /* CloseBraceToken */ && token.parent.kind === 293 /* JsxExpression */) {
-      return true;
+  function getExportInfoMap(importingFile, host, program, preferences, cancellationToken) {
+    var _a, _b, _c, _d, _e;
+    const start = timestamp();
+    (_a = host.getPackageJsonAutoImportProvider) == null ? void 0 : _a.call(host);
+    const cache = ((_b = host.getCachedExportInfoMap) == null ? void 0 : _b.call(host)) || createCacheableExportInfoMap({
+      getCurrentProgram: () => program,
+      getPackageJsonAutoImportProvider: () => {
+        var _a2;
+        return (_a2 = host.getPackageJsonAutoImportProvider) == null ? void 0 : _a2.call(host);
+      },
+      getGlobalTypingsCacheLocation: () => {
+        var _a2;
+        return (_a2 = host.getGlobalTypingsCacheLocation) == null ? void 0 : _a2.call(host);
+      }
+    });
+    if (cache.isUsableByFile(importingFile.path)) {
+      (_c = host.log) == null ? void 0 : _c.call(host, "getExportInfoMap: cache hit");
+      return cache;
     }
-    if (token.kind === 30 /* LessThanToken */ && token.parent.kind === 286 /* JsxClosingElement */) {
-      return true;
+    (_d = host.log) == null ? void 0 : _d.call(host, "getExportInfoMap: cache miss or empty; calculating new results");
+    const compilerOptions = program.getCompilerOptions();
+    let moduleCount = 0;
+    try {
+      forEachExternalModuleToImportFrom(
+        program,
+        host,
+        preferences,
+        /*useAutoImportProvider*/
+        true,
+        (moduleSymbol, moduleFile, program2, isFromPackageJson) => {
+          if (++moduleCount % 100 === 0)
+            cancellationToken == null ? void 0 : cancellationToken.throwIfCancellationRequested();
+          const seenExports = /* @__PURE__ */ new Map();
+          const checker = program2.getTypeChecker();
+          const defaultInfo = getDefaultLikeExportInfo(moduleSymbol, checker, compilerOptions);
+          if (defaultInfo && isImportableSymbol(defaultInfo.symbol, checker)) {
+            cache.add(
+              importingFile.path,
+              defaultInfo.symbol,
+              defaultInfo.exportKind === 1 /* Default */ ? "default" /* Default */ : "export=" /* ExportEquals */,
+              moduleSymbol,
+              moduleFile,
+              defaultInfo.exportKind,
+              isFromPackageJson,
+              checker
+            );
+          }
+          checker.forEachExportAndPropertyOfModule(moduleSymbol, (exported, key) => {
+            if (exported !== (defaultInfo == null ? void 0 : defaultInfo.symbol) && isImportableSymbol(exported, checker) && addToSeen(seenExports, key)) {
+              cache.add(
+                importingFile.path,
+                exported,
+                key,
+                moduleSymbol,
+                moduleFile,
+                0 /* Named */,
+                isFromPackageJson,
+                checker
+              );
+            }
+          });
+        }
+      );
+    } catch (err) {
+      cache.clear();
+      throw err;
     }
-    return false;
+    (_e = host.log) == null ? void 0 : _e.call(host, `getExportInfoMap: done in ${timestamp() - start} ms`);
+    return cache;
   }
-  function isWhiteSpaceOnlyJsxText(node) {
-    return isJsxText(node) && node.containsOnlyTriviaWhiteSpaces;
+  function getDefaultLikeExportInfo(moduleSymbol, checker, compilerOptions) {
+    const exported = getDefaultLikeExportWorker(moduleSymbol, checker);
+    if (!exported)
+      return void 0;
+    const { symbol, exportKind } = exported;
+    const info = getDefaultExportInfoWorker(symbol, checker, compilerOptions);
+    return info && { symbol, exportKind, ...info };
   }
-  function isInTemplateString(sourceFile, position) {
-    const token = getTokenAtPosition(sourceFile, position);
-    return isTemplateLiteralKind(token.kind) && position > token.getStart(sourceFile);
+  function isImportableSymbol(symbol, checker) {
+    return !checker.isUndefinedSymbol(symbol) && !checker.isUnknownSymbol(symbol) && !isKnownSymbol(symbol) && !isPrivateIdentifierSymbol(symbol);
   }
-  function isInJSXText(sourceFile, position) {
-    const token = getTokenAtPosition(sourceFile, position);
-    if (isJsxText(token)) {
-      return true;
-    }
-    if (token.kind === 19 /* OpenBraceToken */ && isJsxExpression(token.parent) && isJsxElement(token.parent.parent)) {
-      return true;
+  function getDefaultLikeExportWorker(moduleSymbol, checker) {
+    const exportEquals = checker.resolveExternalModuleSymbol(moduleSymbol);
+    if (exportEquals !== moduleSymbol)
+      return { symbol: exportEquals, exportKind: 2 /* ExportEquals */ };
+    const defaultExport = checker.tryGetMemberInModuleExports("default" /* Default */, moduleSymbol);
+    if (defaultExport)
+      return { symbol: defaultExport, exportKind: 1 /* Default */ };
+  }
+  function getDefaultExportInfoWorker(defaultExport, checker, compilerOptions) {
+    const localSymbol = getLocalSymbolForExportDefault(defaultExport);
+    if (localSymbol)
+      return { resolvedSymbol: localSymbol, name: localSymbol.name };
+    const name = getNameForExportDefault(defaultExport);
+    if (name !== void 0)
+      return { resolvedSymbol: defaultExport, name };
+    if (defaultExport.flags & 2097152 /* Alias */) {
+      const aliased = checker.getImmediateAliasedSymbol(defaultExport);
+      if (aliased && aliased.parent) {
+        return getDefaultExportInfoWorker(aliased, checker, compilerOptions);
+      }
     }
-    if (token.kind === 30 /* LessThanToken */ && isJsxOpeningLikeElement(token.parent) && isJsxElement(token.parent.parent)) {
-      return true;
+    if (defaultExport.escapedName !== "default" /* Default */ && defaultExport.escapedName !== "export=" /* ExportEquals */) {
+      return { resolvedSymbol: defaultExport, name: defaultExport.getName() };
     }
-    return false;
+    return { resolvedSymbol: defaultExport, name: getNameForExportedSymbol(defaultExport, compilerOptions.target) };
   }
-  function isInsideJsxElement(sourceFile, position) {
-    function isInsideJsxElementTraversal(node) {
-      while (node) {
-        if (node.kind >= 284 /* JsxSelfClosingElement */ && node.kind <= 293 /* JsxExpression */ || node.kind === 12 /* JsxText */ || node.kind === 30 /* LessThanToken */ || node.kind === 32 /* GreaterThanToken */ || node.kind === 80 /* Identifier */ || node.kind === 20 /* CloseBraceToken */ || node.kind === 19 /* OpenBraceToken */ || node.kind === 44 /* SlashToken */) {
-          node = node.parent;
-        } else if (node.kind === 283 /* JsxElement */) {
-          if (position > node.getStart(sourceFile))
-            return true;
-          node = node.parent;
-        } else {
-          return false;
-        }
+  function getNameForExportDefault(symbol) {
+    return symbol.declarations && firstDefined(symbol.declarations, (declaration) => {
+      var _a;
+      if (isExportAssignment(declaration)) {
+        return (_a = tryCast(skipOuterExpressions(declaration.expression), isIdentifier)) == null ? void 0 : _a.text;
+      } else if (isExportSpecifier(declaration)) {
+        Debug.assert(declaration.name.text === "default" /* Default */, "Expected the specifier to be a default export");
+        return declaration.propertyName && declaration.propertyName.text;
       }
-      return false;
-    }
-    return isInsideJsxElementTraversal(getTokenAtPosition(sourceFile, position));
+    });
   }
-  function findPrecedingMatchingToken(token, matchingTokenKind, sourceFile) {
-    const closeTokenText = tokenToString(token.kind);
-    const matchingTokenText = tokenToString(matchingTokenKind);
-    const tokenFullStart = token.getFullStart();
-    const bestGuessIndex = sourceFile.text.lastIndexOf(matchingTokenText, tokenFullStart);
-    if (bestGuessIndex === -1) {
-      return void 0;
+  var ImportKind, ExportKind;
+  var init_exportInfoMap = __esm({
+    "src/services/exportInfoMap.ts"() {
+      "use strict";
+      init_pnp();
+      init_ts4();
+      ImportKind = /* @__PURE__ */ ((ImportKind2) => {
+        ImportKind2[ImportKind2["Named"] = 0] = "Named";
+        ImportKind2[ImportKind2["Default"] = 1] = "Default";
+        ImportKind2[ImportKind2["Namespace"] = 2] = "Namespace";
+        ImportKind2[ImportKind2["CommonJS"] = 3] = "CommonJS";
+        return ImportKind2;
+      })(ImportKind || {});
+      ExportKind = /* @__PURE__ */ ((ExportKind3) => {
+        ExportKind3[ExportKind3["Named"] = 0] = "Named";
+        ExportKind3[ExportKind3["Default"] = 1] = "Default";
+        ExportKind3[ExportKind3["ExportEquals"] = 2] = "ExportEquals";
+        ExportKind3[ExportKind3["UMD"] = 3] = "UMD";
+        return ExportKind3;
+      })(ExportKind || {});
     }
-    if (sourceFile.text.lastIndexOf(closeTokenText, tokenFullStart - 1) < bestGuessIndex) {
-      const nodeAtGuess = findPrecedingToken(bestGuessIndex + 1, sourceFile);
-      if (nodeAtGuess && nodeAtGuess.kind === matchingTokenKind) {
-        return nodeAtGuess;
-      }
+  });
+
+  // src/services/classifier.ts
+  function createClassifier() {
+    const scanner2 = createScanner(
+      99 /* Latest */,
+      /*skipTrivia*/
+      false
+    );
+    function getClassificationsForLine(text, lexState, syntacticClassifierAbsent) {
+      return convertClassificationsToResult(getEncodedLexicalClassifications(text, lexState, syntacticClassifierAbsent), text);
     }
-    const tokenKind = token.kind;
-    let remainingMatchingTokens = 0;
-    while (true) {
-      const preceding = findPrecedingToken(token.getFullStart(), sourceFile);
-      if (!preceding) {
-        return void 0;
+    function getEncodedLexicalClassifications(text, lexState, syntacticClassifierAbsent) {
+      let token = 0 /* Unknown */;
+      let lastNonTriviaToken = 0 /* Unknown */;
+      const templateStack = [];
+      const { prefix, pushTemplate } = getPrefixFromLexState(lexState);
+      text = prefix + text;
+      const offset = prefix.length;
+      if (pushTemplate) {
+        templateStack.push(16 /* TemplateHead */);
       }
-      token = preceding;
-      if (token.kind === matchingTokenKind) {
-        if (remainingMatchingTokens === 0) {
-          return token;
+      scanner2.setText(text);
+      let endOfLineState = 0 /* None */;
+      const spans = [];
+      let angleBracketStack = 0;
+      do {
+        token = scanner2.scan();
+        if (!isTrivia(token)) {
+          handleToken();
+          lastNonTriviaToken = token;
+        }
+        const end = scanner2.getTokenEnd();
+        pushEncodedClassification(scanner2.getTokenStart(), end, offset, classFromKind(token), spans);
+        if (end >= text.length) {
+          const end2 = getNewEndOfLineState(scanner2, token, lastOrUndefined(templateStack));
+          if (end2 !== void 0) {
+            endOfLineState = end2;
+          }
+        }
+      } while (token !== 1 /* EndOfFileToken */);
+      function handleToken() {
+        switch (token) {
+          case 44 /* SlashToken */:
+          case 69 /* SlashEqualsToken */:
+            if (!noRegexTable[lastNonTriviaToken] && scanner2.reScanSlashToken() === 14 /* RegularExpressionLiteral */) {
+              token = 14 /* RegularExpressionLiteral */;
+            }
+            break;
+          case 30 /* LessThanToken */:
+            if (lastNonTriviaToken === 80 /* Identifier */) {
+              angleBracketStack++;
+            }
+            break;
+          case 32 /* GreaterThanToken */:
+            if (angleBracketStack > 0) {
+              angleBracketStack--;
+            }
+            break;
+          case 133 /* AnyKeyword */:
+          case 154 /* StringKeyword */:
+          case 150 /* NumberKeyword */:
+          case 136 /* BooleanKeyword */:
+          case 155 /* SymbolKeyword */:
+            if (angleBracketStack > 0 && !syntacticClassifierAbsent) {
+              token = 80 /* Identifier */;
+            }
+            break;
+          case 16 /* TemplateHead */:
+            templateStack.push(token);
+            break;
+          case 19 /* OpenBraceToken */:
+            if (templateStack.length > 0) {
+              templateStack.push(token);
+            }
+            break;
+          case 20 /* CloseBraceToken */:
+            if (templateStack.length > 0) {
+              const lastTemplateStackToken = lastOrUndefined(templateStack);
+              if (lastTemplateStackToken === 16 /* TemplateHead */) {
+                token = scanner2.reScanTemplateToken(
+                  /*isTaggedTemplate*/
+                  false
+                );
+                if (token === 18 /* TemplateTail */) {
+                  templateStack.pop();
+                } else {
+                  Debug.assertEqual(token, 17 /* TemplateMiddle */, "Should have been a template middle.");
+                }
+              } else {
+                Debug.assertEqual(lastTemplateStackToken, 19 /* OpenBraceToken */, "Should have been an open brace");
+                templateStack.pop();
+              }
+            }
+            break;
+          default:
+            if (!isKeyword(token)) {
+              break;
+            }
+            if (lastNonTriviaToken === 25 /* DotToken */) {
+              token = 80 /* Identifier */;
+            } else if (isKeyword(lastNonTriviaToken) && isKeyword(token) && !canFollow(lastNonTriviaToken, token)) {
+              token = 80 /* Identifier */;
+            }
         }
-        remainingMatchingTokens--;
-      } else if (token.kind === tokenKind) {
-        remainingMatchingTokens++;
       }
+      return { endOfLineState, spans };
     }
+    return { getClassificationsForLine, getEncodedLexicalClassifications };
   }
-  function removeOptionality(type, isOptionalExpression, isOptionalChain2) {
-    return isOptionalExpression ? type.getNonNullableType() : isOptionalChain2 ? type.getNonOptionalType() : type;
-  }
-  function isPossiblyTypeArgumentPosition(token, sourceFile, checker) {
-    const info = getPossibleTypeArgumentsInfo(token, sourceFile);
-    return info !== void 0 && (isPartOfTypeNode(info.called) || getPossibleGenericSignatures(info.called, info.nTypeArguments, checker).length !== 0 || isPossiblyTypeArgumentPosition(info.called, sourceFile, checker));
-  }
-  function getPossibleGenericSignatures(called, typeArgumentCount, checker) {
-    let type = checker.getTypeAtLocation(called);
-    if (isOptionalChain(called.parent)) {
-      type = removeOptionality(
-        type,
-        isOptionalChainRoot(called.parent),
-        /*isOptionalChain*/
-        true
-      );
-    }
-    const signatures = isNewExpression(called.parent) ? type.getConstructSignatures() : type.getCallSignatures();
-    return signatures.filter((candidate) => !!candidate.typeParameters && candidate.typeParameters.length >= typeArgumentCount);
-  }
-  function getPossibleTypeArgumentsInfo(tokenIn, sourceFile) {
-    if (sourceFile.text.lastIndexOf("<", tokenIn ? tokenIn.pos : sourceFile.text.length) === -1) {
-      return void 0;
-    }
-    let token = tokenIn;
-    let remainingLessThanTokens = 0;
-    let nTypeArguments = 0;
-    while (token) {
-      switch (token.kind) {
-        case 30 /* LessThanToken */:
-          token = findPrecedingToken(token.getFullStart(), sourceFile);
-          if (token && token.kind === 29 /* QuestionDotToken */) {
-            token = findPrecedingToken(token.getFullStart(), sourceFile);
-          }
-          if (!token || !isIdentifier(token))
+  function getNewEndOfLineState(scanner2, token, lastOnTemplateStack) {
+    switch (token) {
+      case 11 /* StringLiteral */: {
+        if (!scanner2.isUnterminated())
+          return void 0;
+        const tokenText = scanner2.getTokenText();
+        const lastCharIndex = tokenText.length - 1;
+        let numBackslashes = 0;
+        while (tokenText.charCodeAt(lastCharIndex - numBackslashes) === 92 /* backslash */) {
+          numBackslashes++;
+        }
+        if ((numBackslashes & 1) === 0)
+          return void 0;
+        return tokenText.charCodeAt(0) === 34 /* doubleQuote */ ? 3 /* InDoubleQuoteStringLiteral */ : 2 /* InSingleQuoteStringLiteral */;
+      }
+      case 3 /* MultiLineCommentTrivia */:
+        return scanner2.isUnterminated() ? 1 /* InMultiLineCommentTrivia */ : void 0;
+      default:
+        if (isTemplateLiteralKind(token)) {
+          if (!scanner2.isUnterminated()) {
             return void 0;
-          if (!remainingLessThanTokens) {
-            return isDeclarationName(token) ? void 0 : { called: token, nTypeArguments };
           }
-          remainingLessThanTokens--;
-          break;
-        case 50 /* GreaterThanGreaterThanGreaterThanToken */:
-          remainingLessThanTokens = 3;
-          break;
-        case 49 /* GreaterThanGreaterThanToken */:
-          remainingLessThanTokens = 2;
-          break;
-        case 32 /* GreaterThanToken */:
-          remainingLessThanTokens++;
-          break;
-        case 20 /* CloseBraceToken */:
-          token = findPrecedingMatchingToken(token, 19 /* OpenBraceToken */, sourceFile);
-          if (!token)
-            return void 0;
-          break;
-        case 22 /* CloseParenToken */:
-          token = findPrecedingMatchingToken(token, 21 /* OpenParenToken */, sourceFile);
-          if (!token)
-            return void 0;
-          break;
-        case 24 /* CloseBracketToken */:
-          token = findPrecedingMatchingToken(token, 23 /* OpenBracketToken */, sourceFile);
-          if (!token)
-            return void 0;
-          break;
-        case 28 /* CommaToken */:
-          nTypeArguments++;
-          break;
-        case 39 /* EqualsGreaterThanToken */:
-        case 80 /* Identifier */:
-        case 11 /* StringLiteral */:
-        case 9 /* NumericLiteral */:
-        case 10 /* BigIntLiteral */:
-        case 112 /* TrueKeyword */:
-        case 97 /* FalseKeyword */:
-        case 114 /* TypeOfKeyword */:
-        case 96 /* ExtendsKeyword */:
-        case 143 /* KeyOfKeyword */:
-        case 25 /* DotToken */:
-        case 52 /* BarToken */:
-        case 58 /* QuestionToken */:
-        case 59 /* ColonToken */:
-          break;
-        default:
-          if (isTypeNode(token)) {
-            break;
+          switch (token) {
+            case 18 /* TemplateTail */:
+              return 5 /* InTemplateMiddleOrTail */;
+            case 15 /* NoSubstitutionTemplateLiteral */:
+              return 4 /* InTemplateHeadOrNoSubstitutionTemplate */;
+            default:
+              return Debug.fail("Only 'NoSubstitutionTemplateLiteral's and 'TemplateTail's can be unterminated; got SyntaxKind #" + token);
           }
-          return void 0;
-      }
-      token = findPrecedingToken(token.getFullStart(), sourceFile);
+        }
+        return lastOnTemplateStack === 16 /* TemplateHead */ ? 6 /* InTemplateSubstitutionPosition */ : void 0;
     }
-    return void 0;
-  }
-  function isInComment(sourceFile, position, tokenAtPosition) {
-    return ts_formatting_exports.getRangeOfEnclosingComment(
-      sourceFile,
-      position,
-      /*precedingToken*/
-      void 0,
-      tokenAtPosition
-    );
   }
-  function hasDocComment(sourceFile, position) {
-    const token = getTokenAtPosition(sourceFile, position);
-    return !!findAncestor(token, isJSDoc);
-  }
-  function nodeHasTokens(n, sourceFile) {
-    return n.kind === 1 /* EndOfFileToken */ ? !!n.jsDoc : n.getWidth(sourceFile) !== 0;
-  }
-  function getNodeModifiers(node, excludeFlags = 0 /* None */) {
-    const result = [];
-    const flags = isDeclaration(node) ? getCombinedNodeFlagsAlwaysIncludeJSDoc(node) & ~excludeFlags : 0 /* None */;
-    if (flags & 8 /* Private */)
-      result.push("private" /* privateMemberModifier */);
-    if (flags & 16 /* Protected */)
-      result.push("protected" /* protectedMemberModifier */);
-    if (flags & 4 /* Public */)
-      result.push("public" /* publicMemberModifier */);
-    if (flags & 32 /* Static */ || isClassStaticBlockDeclaration(node))
-      result.push("static" /* staticModifier */);
-    if (flags & 256 /* Abstract */)
-      result.push("abstract" /* abstractModifier */);
-    if (flags & 1 /* Export */)
-      result.push("export" /* exportedModifier */);
-    if (flags & 8192 /* Deprecated */)
-      result.push("deprecated" /* deprecatedModifier */);
-    if (node.flags & 16777216 /* Ambient */)
-      result.push("declare" /* ambientModifier */);
-    if (node.kind === 276 /* ExportAssignment */)
-      result.push("export" /* exportedModifier */);
-    return result.length > 0 ? result.join(",") : "" /* none */;
+  function pushEncodedClassification(start, end, offset, classification, result) {
+    if (classification === 8 /* whiteSpace */) {
+      return;
+    }
+    if (start === 0 && offset > 0) {
+      start += offset;
+    }
+    const length2 = end - start;
+    if (length2 > 0) {
+      result.push(start - offset, length2, classification);
+    }
   }
-  function getTypeArgumentOrTypeParameterList(node) {
-    if (node.kind === 182 /* TypeReference */ || node.kind === 212 /* CallExpression */) {
-      return node.typeArguments;
+  function convertClassificationsToResult(classifications, text) {
+    const entries = [];
+    const dense = classifications.spans;
+    let lastEnd = 0;
+    for (let i = 0; i < dense.length; i += 3) {
+      const start = dense[i];
+      const length2 = dense[i + 1];
+      const type = dense[i + 2];
+      if (lastEnd >= 0) {
+        const whitespaceLength2 = start - lastEnd;
+        if (whitespaceLength2 > 0) {
+          entries.push({ length: whitespaceLength2, classification: 4 /* Whitespace */ });
+        }
+      }
+      entries.push({ length: length2, classification: convertClassification(type) });
+      lastEnd = start + length2;
     }
-    if (isFunctionLike(node) || node.kind === 262 /* ClassDeclaration */ || node.kind === 263 /* InterfaceDeclaration */) {
-      return node.typeParameters;
+    const whitespaceLength = text.length - lastEnd;
+    if (whitespaceLength > 0) {
+      entries.push({ length: whitespaceLength, classification: 4 /* Whitespace */ });
     }
-    return void 0;
+    return { entries, finalLexState: classifications.endOfLineState };
   }
-  function isComment(kind) {
-    return kind === 2 /* SingleLineCommentTrivia */ || kind === 3 /* MultiLineCommentTrivia */;
+  function convertClassification(type) {
+    switch (type) {
+      case 1 /* comment */:
+        return 3 /* Comment */;
+      case 3 /* keyword */:
+        return 1 /* Keyword */;
+      case 4 /* numericLiteral */:
+        return 6 /* NumberLiteral */;
+      case 25 /* bigintLiteral */:
+        return 7 /* BigIntLiteral */;
+      case 5 /* operator */:
+        return 2 /* Operator */;
+      case 6 /* stringLiteral */:
+        return 8 /* StringLiteral */;
+      case 8 /* whiteSpace */:
+        return 4 /* Whitespace */;
+      case 10 /* punctuation */:
+        return 0 /* Punctuation */;
+      case 2 /* identifier */:
+      case 11 /* className */:
+      case 12 /* enumName */:
+      case 13 /* interfaceName */:
+      case 14 /* moduleName */:
+      case 15 /* typeParameterName */:
+      case 16 /* typeAliasName */:
+      case 9 /* text */:
+      case 17 /* parameterName */:
+        return 5 /* Identifier */;
+      default:
+        return void 0;
+    }
   }
-  function isStringOrRegularExpressionOrTemplateLiteral(kind) {
-    if (kind === 11 /* StringLiteral */ || kind === 14 /* RegularExpressionLiteral */ || isTemplateLiteralKind(kind)) {
+  function canFollow(keyword1, keyword2) {
+    if (!isAccessibilityModifier(keyword1)) {
       return true;
     }
-    return false;
-  }
-  function areIntersectedTypesAvoidingStringReduction(checker, t1, t2) {
-    return !!(t1.flags & 4 /* String */) && checker.isEmptyAnonymousObjectType(t2);
-  }
-  function isStringAndEmptyAnonymousObjectIntersection(type) {
-    if (!type.isIntersection()) {
-      return false;
+    switch (keyword2) {
+      case 139 /* GetKeyword */:
+      case 153 /* SetKeyword */:
+      case 137 /* ConstructorKeyword */:
+      case 126 /* StaticKeyword */:
+      case 129 /* AccessorKeyword */:
+        return true;
+      default:
+        return false;
     }
-    const { types, checker } = type;
-    return types.length === 2 && (areIntersectedTypesAvoidingStringReduction(checker, types[0], types[1]) || areIntersectedTypesAvoidingStringReduction(checker, types[1], types[0]));
   }
-  function isInsideTemplateLiteral(node, position, sourceFile) {
-    return isTemplateLiteralKind(node.kind) && (node.getStart(sourceFile) < position && position < node.end) || !!node.isUnterminated && position === node.end;
+  function getPrefixFromLexState(lexState) {
+    switch (lexState) {
+      case 3 /* InDoubleQuoteStringLiteral */:
+        return { prefix: '"\\\n' };
+      case 2 /* InSingleQuoteStringLiteral */:
+        return { prefix: "'\\\n" };
+      case 1 /* InMultiLineCommentTrivia */:
+        return { prefix: "/*\n" };
+      case 4 /* InTemplateHeadOrNoSubstitutionTemplate */:
+        return { prefix: "`\n" };
+      case 5 /* InTemplateMiddleOrTail */:
+        return { prefix: "}\n", pushTemplate: true };
+      case 6 /* InTemplateSubstitutionPosition */:
+        return { prefix: "", pushTemplate: true };
+      case 0 /* None */:
+        return { prefix: "" };
+      default:
+        return Debug.assertNever(lexState);
+    }
   }
-  function isAccessibilityModifier(kind) {
-    switch (kind) {
-      case 125 /* PublicKeyword */:
-      case 123 /* PrivateKeyword */:
-      case 124 /* ProtectedKeyword */:
+  function isBinaryExpressionOperatorToken(token) {
+    switch (token) {
+      case 42 /* AsteriskToken */:
+      case 44 /* SlashToken */:
+      case 45 /* PercentToken */:
+      case 40 /* PlusToken */:
+      case 41 /* MinusToken */:
+      case 48 /* LessThanLessThanToken */:
+      case 49 /* GreaterThanGreaterThanToken */:
+      case 50 /* GreaterThanGreaterThanGreaterThanToken */:
+      case 30 /* LessThanToken */:
+      case 32 /* GreaterThanToken */:
+      case 33 /* LessThanEqualsToken */:
+      case 34 /* GreaterThanEqualsToken */:
+      case 104 /* InstanceOfKeyword */:
+      case 103 /* InKeyword */:
+      case 130 /* AsKeyword */:
+      case 152 /* SatisfiesKeyword */:
+      case 35 /* EqualsEqualsToken */:
+      case 36 /* ExclamationEqualsToken */:
+      case 37 /* EqualsEqualsEqualsToken */:
+      case 38 /* ExclamationEqualsEqualsToken */:
+      case 51 /* AmpersandToken */:
+      case 53 /* CaretToken */:
+      case 52 /* BarToken */:
+      case 56 /* AmpersandAmpersandToken */:
+      case 57 /* BarBarToken */:
+      case 75 /* BarEqualsToken */:
+      case 74 /* AmpersandEqualsToken */:
+      case 79 /* CaretEqualsToken */:
+      case 71 /* LessThanLessThanEqualsToken */:
+      case 72 /* GreaterThanGreaterThanEqualsToken */:
+      case 73 /* GreaterThanGreaterThanGreaterThanEqualsToken */:
+      case 65 /* PlusEqualsToken */:
+      case 66 /* MinusEqualsToken */:
+      case 67 /* AsteriskEqualsToken */:
+      case 69 /* SlashEqualsToken */:
+      case 70 /* PercentEqualsToken */:
+      case 64 /* EqualsToken */:
+      case 28 /* CommaToken */:
+      case 61 /* QuestionQuestionToken */:
+      case 76 /* BarBarEqualsToken */:
+      case 77 /* AmpersandAmpersandEqualsToken */:
+      case 78 /* QuestionQuestionEqualsToken */:
         return true;
+      default:
+        return false;
     }
-    return false;
   }
-  function cloneCompilerOptions(options) {
-    const result = clone(options);
-    setConfigFileInOptions(result, options && options.configFile);
-    return result;
-  }
-  function isArrayLiteralOrObjectLiteralDestructuringPattern(node) {
-    if (node.kind === 208 /* ArrayLiteralExpression */ || node.kind === 209 /* ObjectLiteralExpression */) {
-      if (node.parent.kind === 225 /* BinaryExpression */ && node.parent.left === node && node.parent.operatorToken.kind === 64 /* EqualsToken */) {
-        return true;
-      }
-      if (node.parent.kind === 249 /* ForOfStatement */ && node.parent.initializer === node) {
-        return true;
-      }
-      if (isArrayLiteralOrObjectLiteralDestructuringPattern(node.parent.kind === 302 /* PropertyAssignment */ ? node.parent.parent : node.parent)) {
+  function isPrefixUnaryExpressionOperatorToken(token) {
+    switch (token) {
+      case 40 /* PlusToken */:
+      case 41 /* MinusToken */:
+      case 55 /* TildeToken */:
+      case 54 /* ExclamationToken */:
+      case 46 /* PlusPlusToken */:
+      case 47 /* MinusMinusToken */:
         return true;
-      }
+      default:
+        return false;
     }
-    return false;
-  }
-  function isInReferenceComment(sourceFile, position) {
-    return isInReferenceCommentWorker(
-      sourceFile,
-      position,
-      /*shouldBeReference*/
-      true
-    );
-  }
-  function isInNonReferenceComment(sourceFile, position) {
-    return isInReferenceCommentWorker(
-      sourceFile,
-      position,
-      /*shouldBeReference*/
-      false
-    );
-  }
-  function isInReferenceCommentWorker(sourceFile, position, shouldBeReference) {
-    const range = isInComment(
-      sourceFile,
-      position,
-      /*tokenAtPosition*/
-      void 0
-    );
-    return !!range && shouldBeReference === tripleSlashDirectivePrefixRegex.test(sourceFile.text.substring(range.pos, range.end));
   }
-  function getReplacementSpanForContextToken(contextToken) {
-    if (!contextToken)
-      return void 0;
-    switch (contextToken.kind) {
+  function classFromKind(token) {
+    if (isKeyword(token)) {
+      return 3 /* keyword */;
+    } else if (isBinaryExpressionOperatorToken(token) || isPrefixUnaryExpressionOperatorToken(token)) {
+      return 5 /* operator */;
+    } else if (token >= 19 /* FirstPunctuation */ && token <= 79 /* LastPunctuation */) {
+      return 10 /* punctuation */;
+    }
+    switch (token) {
+      case 9 /* NumericLiteral */:
+        return 4 /* numericLiteral */;
+      case 10 /* BigIntLiteral */:
+        return 25 /* bigintLiteral */;
       case 11 /* StringLiteral */:
-      case 15 /* NoSubstitutionTemplateLiteral */:
-        return createTextSpanFromStringLiteralLikeContent(contextToken);
+        return 6 /* stringLiteral */;
+      case 14 /* RegularExpressionLiteral */:
+        return 7 /* regularExpressionLiteral */;
+      case 7 /* ConflictMarkerTrivia */:
+      case 3 /* MultiLineCommentTrivia */:
+      case 2 /* SingleLineCommentTrivia */:
+        return 1 /* comment */;
+      case 5 /* WhitespaceTrivia */:
+      case 4 /* NewLineTrivia */:
+        return 8 /* whiteSpace */;
+      case 80 /* Identifier */:
       default:
-        return createTextSpanFromNode(contextToken);
+        if (isTemplateLiteralKind(token)) {
+          return 6 /* stringLiteral */;
+        }
+        return 2 /* identifier */;
     }
   }
-  function createTextSpanFromNode(node, sourceFile, endNode2) {
-    return createTextSpanFromBounds(node.getStart(sourceFile), (endNode2 || node).getEnd());
-  }
-  function createTextSpanFromStringLiteralLikeContent(node) {
-    if (node.isUnterminated)
-      return void 0;
-    return createTextSpanFromBounds(node.getStart() + 1, node.getEnd() - 1);
-  }
-  function createTextRangeFromNode(node, sourceFile) {
-    return createRange(node.getStart(sourceFile), node.end);
-  }
-  function createTextSpanFromRange(range) {
-    return createTextSpanFromBounds(range.pos, range.end);
-  }
-  function createTextRangeFromSpan(span) {
-    return createRange(span.start, span.start + span.length);
-  }
-  function createTextChangeFromStartLength(start, length2, newText) {
-    return createTextChange(createTextSpan(start, length2), newText);
-  }
-  function createTextChange(span, newText) {
-    return { span, newText };
-  }
-  function isTypeKeyword(kind) {
-    return contains(typeKeywords, kind);
-  }
-  function isTypeKeywordToken(node) {
-    return node.kind === 156 /* TypeKeyword */;
-  }
-  function isTypeKeywordTokenOrIdentifier(node) {
-    return isTypeKeywordToken(node) || isIdentifier(node) && node.text === "type";
-  }
-  function isExternalModuleSymbol(moduleSymbol) {
-    return !!(moduleSymbol.flags & 1536 /* Module */) && moduleSymbol.name.charCodeAt(0) === 34 /* doubleQuote */;
-  }
-  function nodeSeenTracker() {
-    const seen = [];
-    return (node) => {
-      const id = getNodeId(node);
-      return !seen[id] && (seen[id] = true);
-    };
-  }
-  function getSnapshotText(snap) {
-    return snap.getText(0, snap.getLength());
+  function getSemanticClassifications(typeChecker, cancellationToken, sourceFile, classifiableNames, span) {
+    return convertClassificationsToSpans(getEncodedSemanticClassifications(typeChecker, cancellationToken, sourceFile, classifiableNames, span));
   }
-  function repeatString(str, count) {
-    let result = "";
-    for (let i = 0; i < count; i++) {
-      result += str;
+  function checkForClassificationCancellation(cancellationToken, kind) {
+    switch (kind) {
+      case 267 /* ModuleDeclaration */:
+      case 263 /* ClassDeclaration */:
+      case 264 /* InterfaceDeclaration */:
+      case 262 /* FunctionDeclaration */:
+      case 231 /* ClassExpression */:
+      case 218 /* FunctionExpression */:
+      case 219 /* ArrowFunction */:
+        cancellationToken.throwIfCancellationRequested();
     }
-    return result;
-  }
-  function skipConstraint(type) {
-    return type.isTypeParameter() ? type.getConstraint() || type : type;
-  }
-  function getNameFromPropertyName(name) {
-    return name.kind === 166 /* ComputedPropertyName */ ? isStringOrNumericLiteralLike(name.expression) ? name.expression.text : void 0 : isPrivateIdentifier(name) ? idText(name) : getTextOfIdentifierOrLiteral(name);
-  }
-  function programContainsModules(program) {
-    return program.getSourceFiles().some((s) => !s.isDeclarationFile && !program.isSourceFileFromExternalLibrary(s) && !!(s.externalModuleIndicator || s.commonJsModuleIndicator));
-  }
-  function programContainsEsModules(program) {
-    return program.getSourceFiles().some((s) => !s.isDeclarationFile && !program.isSourceFileFromExternalLibrary(s) && !!s.externalModuleIndicator);
-  }
-  function compilerOptionsIndicateEsModules(compilerOptions) {
-    return !!compilerOptions.module || getEmitScriptTarget(compilerOptions) >= 2 /* ES2015 */ || !!compilerOptions.noEmit;
-  }
-  function createModuleSpecifierResolutionHost(program, host) {
-    return {
-      fileExists: (fileName) => program.fileExists(fileName),
-      getCurrentDirectory: () => host.getCurrentDirectory(),
-      readFile: maybeBind(host, host.readFile),
-      useCaseSensitiveFileNames: maybeBind(host, host.useCaseSensitiveFileNames),
-      getSymlinkCache: maybeBind(host, host.getSymlinkCache) || program.getSymlinkCache,
-      getModuleSpecifierCache: maybeBind(host, host.getModuleSpecifierCache),
-      getPackageJsonInfoCache: () => {
-        var _a;
-        return (_a = program.getModuleResolutionCache()) == null ? void 0 : _a.getPackageJsonInfoCache();
-      },
-      getGlobalTypingsCacheLocation: maybeBind(host, host.getGlobalTypingsCacheLocation),
-      redirectTargetsMap: program.redirectTargetsMap,
-      getProjectReferenceRedirect: (fileName) => program.getProjectReferenceRedirect(fileName),
-      isSourceOfProjectReferenceRedirect: (fileName) => program.isSourceOfProjectReferenceRedirect(fileName),
-      getNearestAncestorDirectoryWithPackageJson: maybeBind(host, host.getNearestAncestorDirectoryWithPackageJson),
-      getFileIncludeReasons: () => program.getFileIncludeReasons()
-    };
-  }
-  function getModuleSpecifierResolverHost(program, host) {
-    return {
-      ...createModuleSpecifierResolutionHost(program, host),
-      getCommonSourceDirectory: () => program.getCommonSourceDirectory()
-    };
-  }
-  function moduleResolutionUsesNodeModules(moduleResolution) {
-    return moduleResolution === 2 /* Node10 */ || moduleResolution >= 3 /* Node16 */ && moduleResolution <= 99 /* NodeNext */ || moduleResolution === 100 /* Bundler */;
-  }
-  function makeImportIfNecessary(defaultImport, namedImports, moduleSpecifier, quotePreference) {
-    return defaultImport || namedImports && namedImports.length ? makeImport(defaultImport, namedImports, moduleSpecifier, quotePreference) : void 0;
-  }
-  function makeImport(defaultImport, namedImports, moduleSpecifier, quotePreference, isTypeOnly) {
-    return factory.createImportDeclaration(
-      /*modifiers*/
-      void 0,
-      defaultImport || namedImports ? factory.createImportClause(!!isTypeOnly, defaultImport, namedImports && namedImports.length ? factory.createNamedImports(namedImports) : void 0) : void 0,
-      typeof moduleSpecifier === "string" ? makeStringLiteral(moduleSpecifier, quotePreference) : moduleSpecifier,
-      /*assertClause*/
-      void 0
-    );
-  }
-  function makeStringLiteral(text, quotePreference) {
-    return factory.createStringLiteral(text, quotePreference === 0 /* Single */);
-  }
-  function quotePreferenceFromString(str, sourceFile) {
-    return isStringDoubleQuoted(str, sourceFile) ? 1 /* Double */ : 0 /* Single */;
   }
-  function getQuotePreference(sourceFile, preferences) {
-    if (preferences.quotePreference && preferences.quotePreference !== "auto") {
-      return preferences.quotePreference === "single" ? 0 /* Single */ : 1 /* Double */;
-    } else {
-      const firstModuleSpecifier = sourceFile.imports && find(sourceFile.imports, (n) => isStringLiteral(n) && !nodeIsSynthesized(n.parent));
-      return firstModuleSpecifier ? quotePreferenceFromString(firstModuleSpecifier, sourceFile) : 1 /* Double */;
+  function getEncodedSemanticClassifications(typeChecker, cancellationToken, sourceFile, classifiableNames, span) {
+    const spans = [];
+    sourceFile.forEachChild(function cb(node) {
+      if (!node || !textSpanIntersectsWith(span, node.pos, node.getFullWidth())) {
+        return;
+      }
+      checkForClassificationCancellation(cancellationToken, node.kind);
+      if (isIdentifier(node) && !nodeIsMissing(node) && classifiableNames.has(node.escapedText)) {
+        const symbol = typeChecker.getSymbolAtLocation(node);
+        const type = symbol && classifySymbol(symbol, getMeaningFromLocation(node), typeChecker);
+        if (type) {
+          pushClassification(node.getStart(sourceFile), node.getEnd(), type);
+        }
+      }
+      node.forEachChild(cb);
+    });
+    return { spans, endOfLineState: 0 /* None */ };
+    function pushClassification(start, end, type) {
+      const length2 = end - start;
+      Debug.assert(length2 > 0, `Classification had non-positive length of ${length2}`);
+      spans.push(start);
+      spans.push(length2);
+      spans.push(type);
     }
   }
-  function getQuoteFromPreference(qp) {
-    switch (qp) {
-      case 0 /* Single */:
-        return "'";
-      case 1 /* Double */:
-        return '"';
-      default:
-        return Debug.assertNever(qp);
+  function classifySymbol(symbol, meaningAtPosition, checker) {
+    const flags = symbol.getFlags();
+    if ((flags & 2885600 /* Classifiable */) === 0 /* None */) {
+      return void 0;
+    } else if (flags & 32 /* Class */) {
+      return 11 /* className */;
+    } else if (flags & 384 /* Enum */) {
+      return 12 /* enumName */;
+    } else if (flags & 524288 /* TypeAlias */) {
+      return 16 /* typeAliasName */;
+    } else if (flags & 1536 /* Module */) {
+      return meaningAtPosition & 4 /* Namespace */ || meaningAtPosition & 1 /* Value */ && hasValueSideModule(symbol) ? 14 /* moduleName */ : void 0;
+    } else if (flags & 2097152 /* Alias */) {
+      return classifySymbol(checker.getAliasedSymbol(symbol), meaningAtPosition, checker);
+    } else if (meaningAtPosition & 2 /* Type */) {
+      return flags & 64 /* Interface */ ? 13 /* interfaceName */ : flags & 262144 /* TypeParameter */ ? 15 /* typeParameterName */ : void 0;
+    } else {
+      return void 0;
     }
   }
-  function symbolNameNoDefault(symbol) {
-    const escaped = symbolEscapedNameNoDefault(symbol);
-    return escaped === void 0 ? void 0 : unescapeLeadingUnderscores(escaped);
+  function hasValueSideModule(symbol) {
+    return some(symbol.declarations, (declaration) => isModuleDeclaration(declaration) && getModuleInstanceState(declaration) === 1 /* Instantiated */);
   }
-  function symbolEscapedNameNoDefault(symbol) {
-    if (symbol.escapedName !== "default" /* Default */) {
-      return symbol.escapedName;
+  function getClassificationTypeName(type) {
+    switch (type) {
+      case 1 /* comment */:
+        return "comment" /* comment */;
+      case 2 /* identifier */:
+        return "identifier" /* identifier */;
+      case 3 /* keyword */:
+        return "keyword" /* keyword */;
+      case 4 /* numericLiteral */:
+        return "number" /* numericLiteral */;
+      case 25 /* bigintLiteral */:
+        return "bigint" /* bigintLiteral */;
+      case 5 /* operator */:
+        return "operator" /* operator */;
+      case 6 /* stringLiteral */:
+        return "string" /* stringLiteral */;
+      case 8 /* whiteSpace */:
+        return "whitespace" /* whiteSpace */;
+      case 9 /* text */:
+        return "text" /* text */;
+      case 10 /* punctuation */:
+        return "punctuation" /* punctuation */;
+      case 11 /* className */:
+        return "class name" /* className */;
+      case 12 /* enumName */:
+        return "enum name" /* enumName */;
+      case 13 /* interfaceName */:
+        return "interface name" /* interfaceName */;
+      case 14 /* moduleName */:
+        return "module name" /* moduleName */;
+      case 15 /* typeParameterName */:
+        return "type parameter name" /* typeParameterName */;
+      case 16 /* typeAliasName */:
+        return "type alias name" /* typeAliasName */;
+      case 17 /* parameterName */:
+        return "parameter name" /* parameterName */;
+      case 18 /* docCommentTagName */:
+        return "doc comment tag name" /* docCommentTagName */;
+      case 19 /* jsxOpenTagName */:
+        return "jsx open tag name" /* jsxOpenTagName */;
+      case 20 /* jsxCloseTagName */:
+        return "jsx close tag name" /* jsxCloseTagName */;
+      case 21 /* jsxSelfClosingTagName */:
+        return "jsx self closing tag name" /* jsxSelfClosingTagName */;
+      case 22 /* jsxAttribute */:
+        return "jsx attribute" /* jsxAttribute */;
+      case 23 /* jsxText */:
+        return "jsx text" /* jsxText */;
+      case 24 /* jsxAttributeStringLiteralValue */:
+        return "jsx attribute string literal value" /* jsxAttributeStringLiteralValue */;
+      default:
+        return void 0;
     }
-    return firstDefined(symbol.declarations, (decl) => {
-      const name = getNameOfDeclaration(decl);
-      return name && name.kind === 80 /* Identifier */ ? name.escapedText : void 0;
-    });
-  }
-  function isModuleSpecifierLike(node) {
-    return isStringLiteralLike(node) && (isExternalModuleReference(node.parent) || isImportDeclaration(node.parent) || isRequireCall(
-      node.parent,
-      /*requireStringLiteralLikeArgument*/
-      false
-    ) && node.parent.arguments[0] === node || isImportCall(node.parent) && node.parent.arguments[0] === node);
-  }
-  function isObjectBindingElementWithoutPropertyName(bindingElement) {
-    return isBindingElement(bindingElement) && isObjectBindingPattern(bindingElement.parent) && isIdentifier(bindingElement.name) && !bindingElement.propertyName;
-  }
-  function getPropertySymbolFromBindingElement(checker, bindingElement) {
-    const typeOfPattern = checker.getTypeAtLocation(bindingElement.parent);
-    return typeOfPattern && checker.getPropertyOfType(typeOfPattern, bindingElement.name.text);
   }
-  function getParentNodeInSpan(node, file, span) {
-    if (!node)
-      return void 0;
-    while (node.parent) {
-      if (isSourceFile(node.parent) || !spanContainsNode(span, node.parent, file)) {
-        return node;
-      }
-      node = node.parent;
+  function convertClassificationsToSpans(classifications) {
+    Debug.assert(classifications.spans.length % 3 === 0);
+    const dense = classifications.spans;
+    const result = [];
+    for (let i = 0; i < dense.length; i += 3) {
+      result.push({
+        textSpan: createTextSpan(dense[i], dense[i + 1]),
+        classificationType: getClassificationTypeName(dense[i + 2])
+      });
     }
+    return result;
   }
-  function spanContainsNode(span, node, file) {
-    return textSpanContainsPosition(span, node.getStart(file)) && node.getEnd() <= textSpanEnd(span);
-  }
-  function findModifier(node, kind) {
-    return canHaveModifiers(node) ? find(node.modifiers, (m) => m.kind === kind) : void 0;
+  function getSyntacticClassifications(cancellationToken, sourceFile, span) {
+    return convertClassificationsToSpans(getEncodedSyntacticClassifications(cancellationToken, sourceFile, span));
   }
-  function insertImports(changes, sourceFile, imports, blankLineBetween, preferences) {
-    const decl = isArray(imports) ? imports[0] : imports;
-    const importKindPredicate = decl.kind === 242 /* VariableStatement */ ? isRequireVariableStatement : isAnyImportSyntax;
-    const existingImportStatements = filter(sourceFile.statements, importKindPredicate);
-    let sortKind = isArray(imports) ? ts_OrganizeImports_exports.detectImportDeclarationSorting(imports, preferences) : 3 /* Both */;
-    const comparer = ts_OrganizeImports_exports.getOrganizeImportsComparer(preferences, sortKind === 2 /* CaseInsensitive */);
-    const sortedNewImports = isArray(imports) ? stableSort(imports, (a, b) => ts_OrganizeImports_exports.compareImportsOrRequireStatements(a, b, comparer)) : [imports];
-    if (!existingImportStatements.length) {
-      changes.insertNodesAtTopOfFile(sourceFile, sortedNewImports, blankLineBetween);
-    } else if (existingImportStatements && (sortKind = ts_OrganizeImports_exports.detectImportDeclarationSorting(existingImportStatements, preferences))) {
-      const comparer2 = ts_OrganizeImports_exports.getOrganizeImportsComparer(preferences, sortKind === 2 /* CaseInsensitive */);
-      for (const newImport of sortedNewImports) {
-        const insertionIndex = ts_OrganizeImports_exports.getImportDeclarationInsertionIndex(existingImportStatements, newImport, comparer2);
-        if (insertionIndex === 0) {
-          const options = existingImportStatements[0] === sourceFile.statements[0] ? { leadingTriviaOption: ts_textChanges_exports.LeadingTriviaOption.Exclude } : {};
-          changes.insertNodeBefore(
-            sourceFile,
-            existingImportStatements[0],
-            newImport,
-            /*blankLineBetween*/
-            false,
-            options
-          );
-        } else {
-          const prevImport = existingImportStatements[insertionIndex - 1];
-          changes.insertNodeAfter(sourceFile, prevImport, newImport);
+  function getEncodedSyntacticClassifications(cancellationToken, sourceFile, span) {
+    const spanStart = span.start;
+    const spanLength = span.length;
+    const triviaScanner = createScanner(
+      99 /* Latest */,
+      /*skipTrivia*/
+      false,
+      sourceFile.languageVariant,
+      sourceFile.text
+    );
+    const mergeConflictScanner = createScanner(
+      99 /* Latest */,
+      /*skipTrivia*/
+      false,
+      sourceFile.languageVariant,
+      sourceFile.text
+    );
+    const result = [];
+    processElement(sourceFile);
+    return { spans: result, endOfLineState: 0 /* None */ };
+    function pushClassification(start, length2, type) {
+      result.push(start);
+      result.push(length2);
+      result.push(type);
+    }
+    function classifyLeadingTriviaAndGetTokenStart(token) {
+      triviaScanner.resetTokenState(token.pos);
+      while (true) {
+        const start = triviaScanner.getTokenEnd();
+        if (!couldStartTrivia(sourceFile.text, start)) {
+          return start;
+        }
+        const kind = triviaScanner.scan();
+        const end = triviaScanner.getTokenEnd();
+        const width = end - start;
+        if (!isTrivia(kind)) {
+          return start;
+        }
+        switch (kind) {
+          case 4 /* NewLineTrivia */:
+          case 5 /* WhitespaceTrivia */:
+            continue;
+          case 2 /* SingleLineCommentTrivia */:
+          case 3 /* MultiLineCommentTrivia */:
+            classifyComment(token, kind, start, width);
+            triviaScanner.resetTokenState(end);
+            continue;
+          case 7 /* ConflictMarkerTrivia */:
+            const text = sourceFile.text;
+            const ch = text.charCodeAt(start);
+            if (ch === 60 /* lessThan */ || ch === 62 /* greaterThan */) {
+              pushClassification(start, width, 1 /* comment */);
+              continue;
+            }
+            Debug.assert(ch === 124 /* bar */ || ch === 61 /* equals */);
+            classifyDisabledMergeCode(text, start, end);
+            break;
+          case 6 /* ShebangTrivia */:
+            break;
+          default:
+            Debug.assertNever(kind);
         }
       }
-    } else {
-      const lastExistingImport = lastOrUndefined(existingImportStatements);
-      if (lastExistingImport) {
-        changes.insertNodesAfter(sourceFile, lastExistingImport, sortedNewImports);
-      } else {
-        changes.insertNodesAtTopOfFile(sourceFile, sortedNewImports, blankLineBetween);
+    }
+    function classifyComment(token, kind, start, width) {
+      if (kind === 3 /* MultiLineCommentTrivia */) {
+        const docCommentAndDiagnostics = parseIsolatedJSDocComment(sourceFile.text, start, width);
+        if (docCommentAndDiagnostics && docCommentAndDiagnostics.jsDoc) {
+          setParent(docCommentAndDiagnostics.jsDoc, token);
+          classifyJSDocComment(docCommentAndDiagnostics.jsDoc);
+          return;
+        }
+      } else if (kind === 2 /* SingleLineCommentTrivia */) {
+        if (tryClassifyTripleSlashComment(start, width)) {
+          return;
+        }
       }
+      pushCommentRange(start, width);
     }
-  }
-  function getTypeKeywordOfTypeOnlyImport(importClause, sourceFile) {
-    Debug.assert(importClause.isTypeOnly);
-    return cast(importClause.getChildAt(0, sourceFile), isTypeKeywordToken);
-  }
-  function textSpansEqual(a, b) {
-    return !!a && !!b && a.start === b.start && a.length === b.length;
-  }
-  function documentSpansEqual(a, b) {
-    return a.fileName === b.fileName && textSpansEqual(a.textSpan, b.textSpan);
-  }
-  function forEachUnique(array, callback) {
-    if (array) {
-      for (let i = 0; i < array.length; i++) {
-        if (array.indexOf(array[i]) === i) {
-          const result = callback(array[i], i);
-          if (result) {
-            return result;
+    function pushCommentRange(start, width) {
+      pushClassification(start, width, 1 /* comment */);
+    }
+    function classifyJSDocComment(docComment) {
+      var _a, _b, _c, _d, _e, _f, _g, _h;
+      let pos = docComment.pos;
+      if (docComment.tags) {
+        for (const tag of docComment.tags) {
+          if (tag.pos !== pos) {
+            pushCommentRange(pos, tag.pos - pos);
+          }
+          pushClassification(tag.pos, 1, 10 /* punctuation */);
+          pushClassification(tag.tagName.pos, tag.tagName.end - tag.tagName.pos, 18 /* docCommentTagName */);
+          pos = tag.tagName.end;
+          let commentStart = tag.tagName.end;
+          switch (tag.kind) {
+            case 348 /* JSDocParameterTag */:
+              const param = tag;
+              processJSDocParameterTag(param);
+              commentStart = param.isNameFirst && ((_a = param.typeExpression) == null ? void 0 : _a.end) || param.name.end;
+              break;
+            case 355 /* JSDocPropertyTag */:
+              const prop = tag;
+              commentStart = prop.isNameFirst && ((_b = prop.typeExpression) == null ? void 0 : _b.end) || prop.name.end;
+              break;
+            case 352 /* JSDocTemplateTag */:
+              processJSDocTemplateTag(tag);
+              pos = tag.end;
+              commentStart = tag.typeParameters.end;
+              break;
+            case 353 /* JSDocTypedefTag */:
+              const type = tag;
+              commentStart = ((_c = type.typeExpression) == null ? void 0 : _c.kind) === 316 /* JSDocTypeExpression */ && ((_d = type.fullName) == null ? void 0 : _d.end) || ((_e = type.typeExpression) == null ? void 0 : _e.end) || commentStart;
+              break;
+            case 345 /* JSDocCallbackTag */:
+              commentStart = tag.typeExpression.end;
+              break;
+            case 351 /* JSDocTypeTag */:
+              processElement(tag.typeExpression);
+              pos = tag.end;
+              commentStart = tag.typeExpression.end;
+              break;
+            case 350 /* JSDocThisTag */:
+            case 347 /* JSDocEnumTag */:
+              commentStart = tag.typeExpression.end;
+              break;
+            case 349 /* JSDocReturnTag */:
+              processElement(tag.typeExpression);
+              pos = tag.end;
+              commentStart = ((_f = tag.typeExpression) == null ? void 0 : _f.end) || commentStart;
+              break;
+            case 354 /* JSDocSeeTag */:
+              commentStart = ((_g = tag.name) == null ? void 0 : _g.end) || commentStart;
+              break;
+            case 335 /* JSDocAugmentsTag */:
+            case 336 /* JSDocImplementsTag */:
+              commentStart = tag.class.end;
+              break;
+            case 356 /* JSDocThrowsTag */:
+              processElement(tag.typeExpression);
+              pos = tag.end;
+              commentStart = ((_h = tag.typeExpression) == null ? void 0 : _h.end) || commentStart;
+              break;
           }
+          if (typeof tag.comment === "object") {
+            pushCommentRange(tag.comment.pos, tag.comment.end - tag.comment.pos);
+          } else if (typeof tag.comment === "string") {
+            pushCommentRange(commentStart, tag.end - commentStart);
+          }
+        }
+      }
+      if (pos !== docComment.end) {
+        pushCommentRange(pos, docComment.end - pos);
+      }
+      return;
+      function processJSDocParameterTag(tag) {
+        if (tag.isNameFirst) {
+          pushCommentRange(pos, tag.name.pos - pos);
+          pushClassification(tag.name.pos, tag.name.end - tag.name.pos, 17 /* parameterName */);
+          pos = tag.name.end;
+        }
+        if (tag.typeExpression) {
+          pushCommentRange(pos, tag.typeExpression.pos - pos);
+          processElement(tag.typeExpression);
+          pos = tag.typeExpression.end;
+        }
+        if (!tag.isNameFirst) {
+          pushCommentRange(pos, tag.name.pos - pos);
+          pushClassification(tag.name.pos, tag.name.end - tag.name.pos, 17 /* parameterName */);
+          pos = tag.name.end;
         }
       }
     }
-    return void 0;
-  }
-  function isTextWhiteSpaceLike(text, startPos, endPos) {
-    for (let i = startPos; i < endPos; i++) {
-      if (!isWhiteSpaceLike(text.charCodeAt(i))) {
+    function tryClassifyTripleSlashComment(start, width) {
+      const tripleSlashXMLCommentRegEx = /^(\/\/\/\s*)(<)(?:(\S+)((?:[^/]|\/[^>])*)(\/>)?)?/im;
+      const attributeRegex = /(\s)(\S+)(\s*)(=)(\s*)('[^']+'|"[^"]+")/img;
+      const text = sourceFile.text.substr(start, width);
+      const match = tripleSlashXMLCommentRegEx.exec(text);
+      if (!match) {
         return false;
       }
-    }
-    return true;
-  }
-  function getMappedLocation(location, sourceMapper, fileExists) {
-    const mapsTo = sourceMapper.tryGetSourcePosition(location);
-    return mapsTo && (!fileExists || fileExists(normalizePath(mapsTo.fileName)) ? mapsTo : void 0);
-  }
-  function getMappedDocumentSpan(documentSpan, sourceMapper, fileExists) {
-    const { fileName, textSpan } = documentSpan;
-    const newPosition = getMappedLocation({ fileName, pos: textSpan.start }, sourceMapper, fileExists);
-    if (!newPosition)
-      return void 0;
-    const newEndPosition = getMappedLocation({ fileName, pos: textSpan.start + textSpan.length }, sourceMapper, fileExists);
-    const newLength = newEndPosition ? newEndPosition.pos - newPosition.pos : textSpan.length;
-    return {
-      fileName: newPosition.fileName,
-      textSpan: {
-        start: newPosition.pos,
-        length: newLength
-      },
-      originalFileName: documentSpan.fileName,
-      originalTextSpan: documentSpan.textSpan,
-      contextSpan: getMappedContextSpan(documentSpan, sourceMapper, fileExists),
-      originalContextSpan: documentSpan.contextSpan
-    };
-  }
-  function getMappedContextSpan(documentSpan, sourceMapper, fileExists) {
-    const contextSpanStart = documentSpan.contextSpan && getMappedLocation(
-      { fileName: documentSpan.fileName, pos: documentSpan.contextSpan.start },
-      sourceMapper,
-      fileExists
-    );
-    const contextSpanEnd = documentSpan.contextSpan && getMappedLocation(
-      { fileName: documentSpan.fileName, pos: documentSpan.contextSpan.start + documentSpan.contextSpan.length },
-      sourceMapper,
-      fileExists
-    );
-    return contextSpanStart && contextSpanEnd ? { start: contextSpanStart.pos, length: contextSpanEnd.pos - contextSpanStart.pos } : void 0;
-  }
-  function isFirstDeclarationOfSymbolParameter(symbol) {
-    const declaration = symbol.declarations ? firstOrUndefined(symbol.declarations) : void 0;
-    return !!findAncestor(declaration, (n) => isParameter(n) ? true : isBindingElement(n) || isObjectBindingPattern(n) || isArrayBindingPattern(n) ? false : "quit");
-  }
-  function getDisplayPartWriter() {
-    const absoluteMaximumLength = defaultMaximumTruncationLength * 10;
-    let displayParts;
-    let lineStart;
-    let indent2;
-    let length2;
-    resetWriter();
-    const unknownWrite = (text) => writeKind(text, 17 /* text */);
-    return {
-      displayParts: () => {
-        const finalText = displayParts.length && displayParts[displayParts.length - 1].text;
-        if (length2 > absoluteMaximumLength && finalText && finalText !== "...") {
-          if (!isWhiteSpaceLike(finalText.charCodeAt(finalText.length - 1))) {
-            displayParts.push(displayPart(" ", 16 /* space */));
-          }
-          displayParts.push(displayPart("...", 15 /* punctuation */));
+      if (!match[3] || !(match[3] in commentPragmas)) {
+        return false;
+      }
+      let pos = start;
+      pushCommentRange(pos, match[1].length);
+      pos += match[1].length;
+      pushClassification(pos, match[2].length, 10 /* punctuation */);
+      pos += match[2].length;
+      pushClassification(pos, match[3].length, 21 /* jsxSelfClosingTagName */);
+      pos += match[3].length;
+      const attrText = match[4];
+      let attrPos = pos;
+      while (true) {
+        const attrMatch = attributeRegex.exec(attrText);
+        if (!attrMatch) {
+          break;
         }
-        return displayParts;
-      },
-      writeKeyword: (text) => writeKind(text, 5 /* keyword */),
-      writeOperator: (text) => writeKind(text, 12 /* operator */),
-      writePunctuation: (text) => writeKind(text, 15 /* punctuation */),
-      writeTrailingSemicolon: (text) => writeKind(text, 15 /* punctuation */),
-      writeSpace: (text) => writeKind(text, 16 /* space */),
-      writeStringLiteral: (text) => writeKind(text, 8 /* stringLiteral */),
-      writeParameter: (text) => writeKind(text, 13 /* parameterName */),
-      writeProperty: (text) => writeKind(text, 14 /* propertyName */),
-      writeLiteral: (text) => writeKind(text, 8 /* stringLiteral */),
-      writeSymbol,
-      writeLine,
-      write: unknownWrite,
-      writeComment: unknownWrite,
-      getText: () => "",
-      getTextPos: () => 0,
-      getColumn: () => 0,
-      getLine: () => 0,
-      isAtStartOfLine: () => false,
-      hasTrailingWhitespace: () => false,
-      hasTrailingComment: () => false,
-      rawWrite: notImplemented,
-      getIndent: () => indent2,
-      increaseIndent: () => {
-        indent2++;
-      },
-      decreaseIndent: () => {
-        indent2--;
-      },
-      clear: resetWriter
-    };
-    function writeIndent() {
-      if (length2 > absoluteMaximumLength)
-        return;
-      if (lineStart) {
-        const indentString = getIndentString(indent2);
-        if (indentString) {
-          length2 += indentString.length;
-          displayParts.push(displayPart(indentString, 16 /* space */));
+        const newAttrPos = pos + attrMatch.index + attrMatch[1].length;
+        if (newAttrPos > attrPos) {
+          pushCommentRange(attrPos, newAttrPos - attrPos);
+          attrPos = newAttrPos;
         }
-        lineStart = false;
+        pushClassification(attrPos, attrMatch[2].length, 22 /* jsxAttribute */);
+        attrPos += attrMatch[2].length;
+        if (attrMatch[3].length) {
+          pushCommentRange(attrPos, attrMatch[3].length);
+          attrPos += attrMatch[3].length;
+        }
+        pushClassification(attrPos, attrMatch[4].length, 5 /* operator */);
+        attrPos += attrMatch[4].length;
+        if (attrMatch[5].length) {
+          pushCommentRange(attrPos, attrMatch[5].length);
+          attrPos += attrMatch[5].length;
+        }
+        pushClassification(attrPos, attrMatch[6].length, 24 /* jsxAttributeStringLiteralValue */);
+        attrPos += attrMatch[6].length;
+      }
+      pos += match[4].length;
+      if (pos > attrPos) {
+        pushCommentRange(attrPos, pos - attrPos);
+      }
+      if (match[5]) {
+        pushClassification(pos, match[5].length, 10 /* punctuation */);
+        pos += match[5].length;
+      }
+      const end = start + width;
+      if (pos < end) {
+        pushCommentRange(pos, end - pos);
       }
+      return true;
     }
-    function writeKind(text, kind) {
-      if (length2 > absoluteMaximumLength)
-        return;
-      writeIndent();
-      length2 += text.length;
-      displayParts.push(displayPart(text, kind));
+    function processJSDocTemplateTag(tag) {
+      for (const child of tag.getChildren()) {
+        processElement(child);
+      }
     }
-    function writeSymbol(text, symbol) {
-      if (length2 > absoluteMaximumLength)
-        return;
-      writeIndent();
-      length2 += text.length;
-      displayParts.push(symbolPart(text, symbol));
+    function classifyDisabledMergeCode(text, start, end) {
+      let i;
+      for (i = start; i < end; i++) {
+        if (isLineBreak(text.charCodeAt(i))) {
+          break;
+        }
+      }
+      pushClassification(start, i - start, 1 /* comment */);
+      mergeConflictScanner.resetTokenState(i);
+      while (mergeConflictScanner.getTokenEnd() < end) {
+        classifyDisabledCodeToken();
+      }
     }
-    function writeLine() {
-      if (length2 > absoluteMaximumLength)
-        return;
-      length2 += 1;
-      displayParts.push(lineBreakPart());
-      lineStart = true;
+    function classifyDisabledCodeToken() {
+      const start = mergeConflictScanner.getTokenEnd();
+      const tokenKind = mergeConflictScanner.scan();
+      const end = mergeConflictScanner.getTokenEnd();
+      const type = classifyTokenType(tokenKind);
+      if (type) {
+        pushClassification(start, end - start, type);
+      }
     }
-    function resetWriter() {
-      displayParts = [];
-      lineStart = true;
-      indent2 = 0;
-      length2 = 0;
+    function tryClassifyNode(node) {
+      if (isJSDoc(node)) {
+        return true;
+      }
+      if (nodeIsMissing(node)) {
+        return true;
+      }
+      const classifiedElementName = tryClassifyJsxElementName(node);
+      if (!isToken(node) && node.kind !== 12 /* JsxText */ && classifiedElementName === void 0) {
+        return false;
+      }
+      const tokenStart = node.kind === 12 /* JsxText */ ? node.pos : classifyLeadingTriviaAndGetTokenStart(node);
+      const tokenWidth = node.end - tokenStart;
+      Debug.assert(tokenWidth >= 0);
+      if (tokenWidth > 0) {
+        const type = classifiedElementName || classifyTokenType(node.kind, node);
+        if (type) {
+          pushClassification(tokenStart, tokenWidth, type);
+        }
+      }
+      return true;
     }
-  }
-  function symbolPart(text, symbol) {
-    return displayPart(text, displayPartKind(symbol));
-    function displayPartKind(symbol2) {
-      const flags = symbol2.flags;
-      if (flags & 3 /* Variable */) {
-        return isFirstDeclarationOfSymbolParameter(symbol2) ? 13 /* parameterName */ : 9 /* localName */;
+    function tryClassifyJsxElementName(token) {
+      switch (token.parent && token.parent.kind) {
+        case 286 /* JsxOpeningElement */:
+          if (token.parent.tagName === token) {
+            return 19 /* jsxOpenTagName */;
+          }
+          break;
+        case 287 /* JsxClosingElement */:
+          if (token.parent.tagName === token) {
+            return 20 /* jsxCloseTagName */;
+          }
+          break;
+        case 285 /* JsxSelfClosingElement */:
+          if (token.parent.tagName === token) {
+            return 21 /* jsxSelfClosingTagName */;
+          }
+          break;
+        case 291 /* JsxAttribute */:
+          if (token.parent.name === token) {
+            return 22 /* jsxAttribute */;
+          }
+          break;
       }
-      if (flags & 4 /* Property */)
-        return 14 /* propertyName */;
-      if (flags & 32768 /* GetAccessor */)
-        return 14 /* propertyName */;
-      if (flags & 65536 /* SetAccessor */)
-        return 14 /* propertyName */;
-      if (flags & 8 /* EnumMember */)
-        return 19 /* enumMemberName */;
-      if (flags & 16 /* Function */)
-        return 20 /* functionName */;
-      if (flags & 32 /* Class */)
-        return 1 /* className */;
-      if (flags & 64 /* Interface */)
-        return 4 /* interfaceName */;
-      if (flags & 384 /* Enum */)
-        return 2 /* enumName */;
-      if (flags & 1536 /* Module */)
-        return 11 /* moduleName */;
-      if (flags & 8192 /* Method */)
-        return 10 /* methodName */;
-      if (flags & 262144 /* TypeParameter */)
-        return 18 /* typeParameterName */;
-      if (flags & 524288 /* TypeAlias */)
-        return 0 /* aliasName */;
-      if (flags & 2097152 /* Alias */)
-        return 0 /* aliasName */;
-      return 17 /* text */;
+      return void 0;
     }
-  }
-  function displayPart(text, kind) {
-    return { text, kind: SymbolDisplayPartKind[kind] };
-  }
-  function spacePart() {
-    return displayPart(" ", 16 /* space */);
-  }
-  function keywordPart(kind) {
-    return displayPart(tokenToString(kind), 5 /* keyword */);
-  }
-  function punctuationPart(kind) {
-    return displayPart(tokenToString(kind), 15 /* punctuation */);
-  }
-  function operatorPart(kind) {
-    return displayPart(tokenToString(kind), 12 /* operator */);
-  }
-  function parameterNamePart(text) {
-    return displayPart(text, 13 /* parameterName */);
-  }
-  function propertyNamePart(text) {
-    return displayPart(text, 14 /* propertyName */);
-  }
-  function textOrKeywordPart(text) {
-    const kind = stringToToken(text);
-    return kind === void 0 ? textPart(text) : keywordPart(kind);
-  }
-  function textPart(text) {
-    return displayPart(text, 17 /* text */);
-  }
-  function typeAliasNamePart(text) {
-    return displayPart(text, 0 /* aliasName */);
-  }
-  function typeParameterNamePart(text) {
-    return displayPart(text, 18 /* typeParameterName */);
-  }
-  function linkTextPart(text) {
-    return displayPart(text, 24 /* linkText */);
-  }
-  function linkNamePart(text, target) {
-    return {
-      text,
-      kind: SymbolDisplayPartKind[23 /* linkName */],
-      target: {
-        fileName: getSourceFileOfNode(target).fileName,
-        textSpan: createTextSpanFromNode(target)
+    function classifyTokenType(tokenKind, token) {
+      if (isKeyword(tokenKind)) {
+        return 3 /* keyword */;
       }
-    };
-  }
-  function linkPart(text) {
-    return displayPart(text, 22 /* link */);
-  }
-  function buildLinkParts(link, checker) {
-    var _a;
-    const prefix = isJSDocLink(link) ? "link" : isJSDocLinkCode(link) ? "linkcode" : "linkplain";
-    const parts = [linkPart(`{@${prefix} `)];
-    if (!link.name) {
-      if (link.text) {
-        parts.push(linkTextPart(link.text));
+      if (tokenKind === 30 /* LessThanToken */ || tokenKind === 32 /* GreaterThanToken */) {
+        if (token && getTypeArgumentOrTypeParameterList(token.parent)) {
+          return 10 /* punctuation */;
+        }
       }
-    } else {
-      const symbol = checker == null ? void 0 : checker.getSymbolAtLocation(link.name);
-      const suffix = findLinkNameEnd(link.text);
-      const name = getTextOfNode(link.name) + link.text.slice(0, suffix);
-      const text = skipSeparatorFromLinkText(link.text.slice(suffix));
-      const decl = (symbol == null ? void 0 : symbol.valueDeclaration) || ((_a = symbol == null ? void 0 : symbol.declarations) == null ? void 0 : _a[0]);
-      if (decl) {
-        parts.push(linkNamePart(name, decl));
-        if (text)
-          parts.push(linkTextPart(text));
-      } else {
-        parts.push(linkTextPart(name + (suffix ? "" : " ") + text));
+      if (isPunctuation(tokenKind)) {
+        if (token) {
+          const parent2 = token.parent;
+          if (tokenKind === 64 /* EqualsToken */) {
+            if (parent2.kind === 260 /* VariableDeclaration */ || parent2.kind === 172 /* PropertyDeclaration */ || parent2.kind === 169 /* Parameter */ || parent2.kind === 291 /* JsxAttribute */) {
+              return 5 /* operator */;
+            }
+          }
+          if (parent2.kind === 226 /* BinaryExpression */ || parent2.kind === 224 /* PrefixUnaryExpression */ || parent2.kind === 225 /* PostfixUnaryExpression */ || parent2.kind === 227 /* ConditionalExpression */) {
+            return 5 /* operator */;
+          }
+        }
+        return 10 /* punctuation */;
+      } else if (tokenKind === 9 /* NumericLiteral */) {
+        return 4 /* numericLiteral */;
+      } else if (tokenKind === 10 /* BigIntLiteral */) {
+        return 25 /* bigintLiteral */;
+      } else if (tokenKind === 11 /* StringLiteral */) {
+        return token && token.parent.kind === 291 /* JsxAttribute */ ? 24 /* jsxAttributeStringLiteralValue */ : 6 /* stringLiteral */;
+      } else if (tokenKind === 14 /* RegularExpressionLiteral */) {
+        return 6 /* stringLiteral */;
+      } else if (isTemplateLiteralKind(tokenKind)) {
+        return 6 /* stringLiteral */;
+      } else if (tokenKind === 12 /* JsxText */) {
+        return 23 /* jsxText */;
+      } else if (tokenKind === 80 /* Identifier */) {
+        if (token) {
+          switch (token.parent.kind) {
+            case 263 /* ClassDeclaration */:
+              if (token.parent.name === token) {
+                return 11 /* className */;
+              }
+              return;
+            case 168 /* TypeParameter */:
+              if (token.parent.name === token) {
+                return 15 /* typeParameterName */;
+              }
+              return;
+            case 264 /* InterfaceDeclaration */:
+              if (token.parent.name === token) {
+                return 13 /* interfaceName */;
+              }
+              return;
+            case 266 /* EnumDeclaration */:
+              if (token.parent.name === token) {
+                return 12 /* enumName */;
+              }
+              return;
+            case 267 /* ModuleDeclaration */:
+              if (token.parent.name === token) {
+                return 14 /* moduleName */;
+              }
+              return;
+            case 169 /* Parameter */:
+              if (token.parent.name === token) {
+                return isThisIdentifier(token) ? 3 /* keyword */ : 17 /* parameterName */;
+              }
+              return;
+          }
+          if (isConstTypeReference(token.parent)) {
+            return 3 /* keyword */;
+          }
+        }
+        return 2 /* identifier */;
+      }
+    }
+    function processElement(element) {
+      if (!element) {
+        return;
+      }
+      if (decodedTextSpanIntersectsWith(spanStart, spanLength, element.pos, element.getFullWidth())) {
+        checkForClassificationCancellation(cancellationToken, element.kind);
+        for (const child of element.getChildren(sourceFile)) {
+          if (!tryClassifyNode(child)) {
+            processElement(child);
+          }
+        }
       }
     }
-    parts.push(linkPart("}"));
-    return parts;
   }
-  function skipSeparatorFromLinkText(text) {
-    let pos = 0;
-    if (text.charCodeAt(pos++) === 124 /* bar */) {
-      while (pos < text.length && text.charCodeAt(pos) === 32 /* space */)
-        pos++;
-      return text.slice(pos);
-    }
-    return text;
+  var noRegexTable;
+  var init_classifier = __esm({
+    "src/services/classifier.ts"() {
+      "use strict";
+      init_ts4();
+      noRegexTable = arrayToNumericMap(
+        [
+          80 /* Identifier */,
+          11 /* StringLiteral */,
+          9 /* NumericLiteral */,
+          10 /* BigIntLiteral */,
+          14 /* RegularExpressionLiteral */,
+          110 /* ThisKeyword */,
+          46 /* PlusPlusToken */,
+          47 /* MinusMinusToken */,
+          22 /* CloseParenToken */,
+          24 /* CloseBracketToken */,
+          20 /* CloseBraceToken */,
+          112 /* TrueKeyword */,
+          97 /* FalseKeyword */
+        ],
+        (token) => token,
+        () => true
+      );
+    }
+  });
+
+  // src/services/documentHighlights.ts
+  var DocumentHighlights;
+  var init_documentHighlights = __esm({
+    "src/services/documentHighlights.ts"() {
+      "use strict";
+      init_ts4();
+      ((DocumentHighlights3) => {
+        function getDocumentHighlights(program, cancellationToken, sourceFile, position, sourceFilesToSearch) {
+          const node = getTouchingPropertyName(sourceFile, position);
+          if (node.parent && (isJsxOpeningElement(node.parent) && node.parent.tagName === node || isJsxClosingElement(node.parent))) {
+            const { openingElement, closingElement } = node.parent.parent;
+            const highlightSpans = [openingElement, closingElement].map(({ tagName }) => getHighlightSpanForNode(tagName, sourceFile));
+            return [{ fileName: sourceFile.fileName, highlightSpans }];
+          }
+          return getSemanticDocumentHighlights(position, node, program, cancellationToken, sourceFilesToSearch) || getSyntacticDocumentHighlights(node, sourceFile);
+        }
+        DocumentHighlights3.getDocumentHighlights = getDocumentHighlights;
+        function getHighlightSpanForNode(node, sourceFile) {
+          return {
+            fileName: sourceFile.fileName,
+            textSpan: createTextSpanFromNode(node, sourceFile),
+            kind: "none" /* none */
+          };
+        }
+        function getSemanticDocumentHighlights(position, node, program, cancellationToken, sourceFilesToSearch) {
+          const sourceFilesSet = new Set(sourceFilesToSearch.map((f) => f.fileName));
+          const referenceEntries = ts_FindAllReferences_exports.getReferenceEntriesForNode(
+            position,
+            node,
+            program,
+            sourceFilesToSearch,
+            cancellationToken,
+            /*options*/
+            void 0,
+            sourceFilesSet
+          );
+          if (!referenceEntries)
+            return void 0;
+          const map2 = arrayToMultiMap(referenceEntries.map(ts_FindAllReferences_exports.toHighlightSpan), (e) => e.fileName, (e) => e.span);
+          const getCanonicalFileName = createGetCanonicalFileName(program.useCaseSensitiveFileNames());
+          return arrayFrom(mapDefinedIterator(map2.entries(), ([fileName, highlightSpans]) => {
+            if (!sourceFilesSet.has(fileName)) {
+              if (!program.redirectTargetsMap.has(toPath(fileName, program.getCurrentDirectory(), getCanonicalFileName))) {
+                return void 0;
+              }
+              const redirectTarget = program.getSourceFile(fileName);
+              const redirect = find(sourceFilesToSearch, (f) => !!f.redirectInfo && f.redirectInfo.redirectTarget === redirectTarget);
+              fileName = redirect.fileName;
+              Debug.assert(sourceFilesSet.has(fileName));
+            }
+            return { fileName, highlightSpans };
+          }));
+        }
+        function getSyntacticDocumentHighlights(node, sourceFile) {
+          const highlightSpans = getHighlightSpans(node, sourceFile);
+          return highlightSpans && [{ fileName: sourceFile.fileName, highlightSpans }];
+        }
+        function getHighlightSpans(node, sourceFile) {
+          switch (node.kind) {
+            case 101 /* IfKeyword */:
+            case 93 /* ElseKeyword */:
+              return isIfStatement(node.parent) ? getIfElseOccurrences(node.parent, sourceFile) : void 0;
+            case 107 /* ReturnKeyword */:
+              return useParent(node.parent, isReturnStatement, getReturnOccurrences);
+            case 111 /* ThrowKeyword */:
+              return useParent(node.parent, isThrowStatement, getThrowOccurrences);
+            case 113 /* TryKeyword */:
+            case 85 /* CatchKeyword */:
+            case 98 /* FinallyKeyword */:
+              const tryStatement = node.kind === 85 /* CatchKeyword */ ? node.parent.parent : node.parent;
+              return useParent(tryStatement, isTryStatement, getTryCatchFinallyOccurrences);
+            case 109 /* SwitchKeyword */:
+              return useParent(node.parent, isSwitchStatement, getSwitchCaseDefaultOccurrences);
+            case 84 /* CaseKeyword */:
+            case 90 /* DefaultKeyword */: {
+              if (isDefaultClause(node.parent) || isCaseClause(node.parent)) {
+                return useParent(node.parent.parent.parent, isSwitchStatement, getSwitchCaseDefaultOccurrences);
+              }
+              return void 0;
+            }
+            case 83 /* BreakKeyword */:
+            case 88 /* ContinueKeyword */:
+              return useParent(node.parent, isBreakOrContinueStatement, getBreakOrContinueStatementOccurrences);
+            case 99 /* ForKeyword */:
+            case 117 /* WhileKeyword */:
+            case 92 /* DoKeyword */:
+              return useParent(node.parent, (n) => isIterationStatement(
+                n,
+                /*lookInLabeledStatements*/
+                true
+              ), getLoopBreakContinueOccurrences);
+            case 137 /* ConstructorKeyword */:
+              return getFromAllDeclarations(isConstructorDeclaration, [137 /* ConstructorKeyword */]);
+            case 139 /* GetKeyword */:
+            case 153 /* SetKeyword */:
+              return getFromAllDeclarations(isAccessor, [139 /* GetKeyword */, 153 /* SetKeyword */]);
+            case 135 /* AwaitKeyword */:
+              return useParent(node.parent, isAwaitExpression, getAsyncAndAwaitOccurrences);
+            case 134 /* AsyncKeyword */:
+              return highlightSpans(getAsyncAndAwaitOccurrences(node));
+            case 127 /* YieldKeyword */:
+              return highlightSpans(getYieldOccurrences(node));
+            case 103 /* InKeyword */:
+              return void 0;
+            default:
+              return isModifierKind(node.kind) && (isDeclaration(node.parent) || isVariableStatement(node.parent)) ? highlightSpans(getModifierOccurrences(node.kind, node.parent)) : void 0;
+          }
+          function getFromAllDeclarations(nodeTest, keywords) {
+            return useParent(node.parent, nodeTest, (decl) => {
+              var _a;
+              return mapDefined((_a = tryCast(decl, canHaveSymbol)) == null ? void 0 : _a.symbol.declarations, (d) => nodeTest(d) ? find(d.getChildren(sourceFile), (c) => contains(keywords, c.kind)) : void 0);
+            });
+          }
+          function useParent(node2, nodeTest, getNodes4) {
+            return nodeTest(node2) ? highlightSpans(getNodes4(node2, sourceFile)) : void 0;
+          }
+          function highlightSpans(nodes) {
+            return nodes && nodes.map((node2) => getHighlightSpanForNode(node2, sourceFile));
+          }
+        }
+        function aggregateOwnedThrowStatements(node) {
+          if (isThrowStatement(node)) {
+            return [node];
+          } else if (isTryStatement(node)) {
+            return concatenate(
+              node.catchClause ? aggregateOwnedThrowStatements(node.catchClause) : node.tryBlock && aggregateOwnedThrowStatements(node.tryBlock),
+              node.finallyBlock && aggregateOwnedThrowStatements(node.finallyBlock)
+            );
+          }
+          return isFunctionLike(node) ? void 0 : flatMapChildren(node, aggregateOwnedThrowStatements);
+        }
+        function getThrowStatementOwner(throwStatement) {
+          let child = throwStatement;
+          while (child.parent) {
+            const parent2 = child.parent;
+            if (isFunctionBlock(parent2) || parent2.kind === 312 /* SourceFile */) {
+              return parent2;
+            }
+            if (isTryStatement(parent2) && parent2.tryBlock === child && parent2.catchClause) {
+              return child;
+            }
+            child = parent2;
+          }
+          return void 0;
+        }
+        function aggregateAllBreakAndContinueStatements(node) {
+          return isBreakOrContinueStatement(node) ? [node] : isFunctionLike(node) ? void 0 : flatMapChildren(node, aggregateAllBreakAndContinueStatements);
+        }
+        function flatMapChildren(node, cb) {
+          const result = [];
+          node.forEachChild((child) => {
+            const value = cb(child);
+            if (value !== void 0) {
+              result.push(...toArray(value));
+            }
+          });
+          return result;
+        }
+        function ownsBreakOrContinueStatement(owner, statement) {
+          const actualOwner = getBreakOrContinueOwner(statement);
+          return !!actualOwner && actualOwner === owner;
+        }
+        function getBreakOrContinueOwner(statement) {
+          return findAncestor(statement, (node) => {
+            switch (node.kind) {
+              case 255 /* SwitchStatement */:
+                if (statement.kind === 251 /* ContinueStatement */) {
+                  return false;
+                }
+              case 248 /* ForStatement */:
+              case 249 /* ForInStatement */:
+              case 250 /* ForOfStatement */:
+              case 247 /* WhileStatement */:
+              case 246 /* DoStatement */:
+                return !statement.label || isLabeledBy(node, statement.label.escapedText);
+              default:
+                return isFunctionLike(node) && "quit";
+            }
+          });
+        }
+        function getModifierOccurrences(modifier, declaration) {
+          return mapDefined(getNodesToSearchForModifier(declaration, modifierToFlag(modifier)), (node) => findModifier(node, modifier));
+        }
+        function getNodesToSearchForModifier(declaration, modifierFlag) {
+          const container = declaration.parent;
+          switch (container.kind) {
+            case 268 /* ModuleBlock */:
+            case 312 /* SourceFile */:
+            case 241 /* Block */:
+            case 296 /* CaseClause */:
+            case 297 /* DefaultClause */:
+              if (modifierFlag & 64 /* Abstract */ && isClassDeclaration(declaration)) {
+                return [...declaration.members, declaration];
+              } else {
+                return container.statements;
+              }
+            case 176 /* Constructor */:
+            case 174 /* MethodDeclaration */:
+            case 262 /* FunctionDeclaration */:
+              return [...container.parameters, ...isClassLike(container.parent) ? container.parent.members : []];
+            case 263 /* ClassDeclaration */:
+            case 231 /* ClassExpression */:
+            case 264 /* InterfaceDeclaration */:
+            case 187 /* TypeLiteral */:
+              const nodes = container.members;
+              if (modifierFlag & (7 /* AccessibilityModifier */ | 8 /* Readonly */)) {
+                const constructor = find(container.members, isConstructorDeclaration);
+                if (constructor) {
+                  return [...nodes, ...constructor.parameters];
+                }
+              } else if (modifierFlag & 64 /* Abstract */) {
+                return [...nodes, container];
+              }
+              return nodes;
+            case 210 /* ObjectLiteralExpression */:
+              return void 0;
+            default:
+              Debug.assertNever(container, "Invalid container kind.");
+          }
+        }
+        function pushKeywordIf(keywordList, token, ...expected) {
+          if (token && contains(expected, token.kind)) {
+            keywordList.push(token);
+            return true;
+          }
+          return false;
+        }
+        function getLoopBreakContinueOccurrences(loopNode) {
+          const keywords = [];
+          if (pushKeywordIf(keywords, loopNode.getFirstToken(), 99 /* ForKeyword */, 117 /* WhileKeyword */, 92 /* DoKeyword */)) {
+            if (loopNode.kind === 246 /* DoStatement */) {
+              const loopTokens = loopNode.getChildren();
+              for (let i = loopTokens.length - 1; i >= 0; i--) {
+                if (pushKeywordIf(keywords, loopTokens[i], 117 /* WhileKeyword */)) {
+                  break;
+                }
+              }
+            }
+          }
+          forEach(aggregateAllBreakAndContinueStatements(loopNode.statement), (statement) => {
+            if (ownsBreakOrContinueStatement(loopNode, statement)) {
+              pushKeywordIf(keywords, statement.getFirstToken(), 83 /* BreakKeyword */, 88 /* ContinueKeyword */);
+            }
+          });
+          return keywords;
+        }
+        function getBreakOrContinueStatementOccurrences(breakOrContinueStatement) {
+          const owner = getBreakOrContinueOwner(breakOrContinueStatement);
+          if (owner) {
+            switch (owner.kind) {
+              case 248 /* ForStatement */:
+              case 249 /* ForInStatement */:
+              case 250 /* ForOfStatement */:
+              case 246 /* DoStatement */:
+              case 247 /* WhileStatement */:
+                return getLoopBreakContinueOccurrences(owner);
+              case 255 /* SwitchStatement */:
+                return getSwitchCaseDefaultOccurrences(owner);
+            }
+          }
+          return void 0;
+        }
+        function getSwitchCaseDefaultOccurrences(switchStatement) {
+          const keywords = [];
+          pushKeywordIf(keywords, switchStatement.getFirstToken(), 109 /* SwitchKeyword */);
+          forEach(switchStatement.caseBlock.clauses, (clause) => {
+            pushKeywordIf(keywords, clause.getFirstToken(), 84 /* CaseKeyword */, 90 /* DefaultKeyword */);
+            forEach(aggregateAllBreakAndContinueStatements(clause), (statement) => {
+              if (ownsBreakOrContinueStatement(switchStatement, statement)) {
+                pushKeywordIf(keywords, statement.getFirstToken(), 83 /* BreakKeyword */);
+              }
+            });
+          });
+          return keywords;
+        }
+        function getTryCatchFinallyOccurrences(tryStatement, sourceFile) {
+          const keywords = [];
+          pushKeywordIf(keywords, tryStatement.getFirstToken(), 113 /* TryKeyword */);
+          if (tryStatement.catchClause) {
+            pushKeywordIf(keywords, tryStatement.catchClause.getFirstToken(), 85 /* CatchKeyword */);
+          }
+          if (tryStatement.finallyBlock) {
+            const finallyKeyword = findChildOfKind(tryStatement, 98 /* FinallyKeyword */, sourceFile);
+            pushKeywordIf(keywords, finallyKeyword, 98 /* FinallyKeyword */);
+          }
+          return keywords;
+        }
+        function getThrowOccurrences(throwStatement, sourceFile) {
+          const owner = getThrowStatementOwner(throwStatement);
+          if (!owner) {
+            return void 0;
+          }
+          const keywords = [];
+          forEach(aggregateOwnedThrowStatements(owner), (throwStatement2) => {
+            keywords.push(findChildOfKind(throwStatement2, 111 /* ThrowKeyword */, sourceFile));
+          });
+          if (isFunctionBlock(owner)) {
+            forEachReturnStatement(owner, (returnStatement) => {
+              keywords.push(findChildOfKind(returnStatement, 107 /* ReturnKeyword */, sourceFile));
+            });
+          }
+          return keywords;
+        }
+        function getReturnOccurrences(returnStatement, sourceFile) {
+          const func = getContainingFunction(returnStatement);
+          if (!func) {
+            return void 0;
+          }
+          const keywords = [];
+          forEachReturnStatement(cast(func.body, isBlock), (returnStatement2) => {
+            keywords.push(findChildOfKind(returnStatement2, 107 /* ReturnKeyword */, sourceFile));
+          });
+          forEach(aggregateOwnedThrowStatements(func.body), (throwStatement) => {
+            keywords.push(findChildOfKind(throwStatement, 111 /* ThrowKeyword */, sourceFile));
+          });
+          return keywords;
+        }
+        function getAsyncAndAwaitOccurrences(node) {
+          const func = getContainingFunction(node);
+          if (!func) {
+            return void 0;
+          }
+          const keywords = [];
+          if (func.modifiers) {
+            func.modifiers.forEach((modifier) => {
+              pushKeywordIf(keywords, modifier, 134 /* AsyncKeyword */);
+            });
+          }
+          forEachChild(func, (child) => {
+            traverseWithoutCrossingFunction(child, (node2) => {
+              if (isAwaitExpression(node2)) {
+                pushKeywordIf(keywords, node2.getFirstToken(), 135 /* AwaitKeyword */);
+              }
+            });
+          });
+          return keywords;
+        }
+        function getYieldOccurrences(node) {
+          const func = getContainingFunction(node);
+          if (!func) {
+            return void 0;
+          }
+          const keywords = [];
+          forEachChild(func, (child) => {
+            traverseWithoutCrossingFunction(child, (node2) => {
+              if (isYieldExpression(node2)) {
+                pushKeywordIf(keywords, node2.getFirstToken(), 127 /* YieldKeyword */);
+              }
+            });
+          });
+          return keywords;
+        }
+        function traverseWithoutCrossingFunction(node, cb) {
+          cb(node);
+          if (!isFunctionLike(node) && !isClassLike(node) && !isInterfaceDeclaration(node) && !isModuleDeclaration(node) && !isTypeAliasDeclaration(node) && !isTypeNode(node)) {
+            forEachChild(node, (child) => traverseWithoutCrossingFunction(child, cb));
+          }
+        }
+        function getIfElseOccurrences(ifStatement, sourceFile) {
+          const keywords = getIfElseKeywords(ifStatement, sourceFile);
+          const result = [];
+          for (let i = 0; i < keywords.length; i++) {
+            if (keywords[i].kind === 93 /* ElseKeyword */ && i < keywords.length - 1) {
+              const elseKeyword = keywords[i];
+              const ifKeyword = keywords[i + 1];
+              let shouldCombineElseAndIf = true;
+              for (let j = ifKeyword.getStart(sourceFile) - 1; j >= elseKeyword.end; j--) {
+                if (!isWhiteSpaceSingleLine(sourceFile.text.charCodeAt(j))) {
+                  shouldCombineElseAndIf = false;
+                  break;
+                }
+              }
+              if (shouldCombineElseAndIf) {
+                result.push({
+                  fileName: sourceFile.fileName,
+                  textSpan: createTextSpanFromBounds(elseKeyword.getStart(), ifKeyword.end),
+                  kind: "reference" /* reference */
+                });
+                i++;
+                continue;
+              }
+            }
+            result.push(getHighlightSpanForNode(keywords[i], sourceFile));
+          }
+          return result;
+        }
+        function getIfElseKeywords(ifStatement, sourceFile) {
+          const keywords = [];
+          while (isIfStatement(ifStatement.parent) && ifStatement.parent.elseStatement === ifStatement) {
+            ifStatement = ifStatement.parent;
+          }
+          while (true) {
+            const children = ifStatement.getChildren(sourceFile);
+            pushKeywordIf(keywords, children[0], 101 /* IfKeyword */);
+            for (let i = children.length - 1; i >= 0; i--) {
+              if (pushKeywordIf(keywords, children[i], 93 /* ElseKeyword */)) {
+                break;
+              }
+            }
+            if (!ifStatement.elseStatement || !isIfStatement(ifStatement.elseStatement)) {
+              break;
+            }
+            ifStatement = ifStatement.elseStatement;
+          }
+          return keywords;
+        }
+        function isLabeledBy(node, labelName) {
+          return !!findAncestor(node.parent, (owner) => !isLabeledStatement(owner) ? "quit" : owner.label.escapedText === labelName);
+        }
+      })(DocumentHighlights || (DocumentHighlights = {}));
+    }
+  });
+
+  // src/services/documentRegistry.ts
+  function isDocumentRegistryEntry(entry) {
+    return !!entry.sourceFile;
+  }
+  function createDocumentRegistry(useCaseSensitiveFileNames2, currentDirectory, jsDocParsingMode) {
+    return createDocumentRegistryInternal(useCaseSensitiveFileNames2, currentDirectory, jsDocParsingMode);
   }
-  function findLinkNameEnd(text) {
-    let pos = text.indexOf("://");
-    if (pos === 0) {
-      while (pos < text.length && text.charCodeAt(pos) !== 124 /* bar */)
-        pos++;
-      return pos;
+  function createDocumentRegistryInternal(useCaseSensitiveFileNames2, currentDirectory = "", jsDocParsingMode, externalCache) {
+    const buckets = /* @__PURE__ */ new Map();
+    const getCanonicalFileName = createGetCanonicalFileName(!!useCaseSensitiveFileNames2);
+    function reportStats() {
+      const bucketInfoArray = arrayFrom(buckets.keys()).filter((name) => name && name.charAt(0) === "_").map((name) => {
+        const entries = buckets.get(name);
+        const sourceFiles = [];
+        entries.forEach((entry, name2) => {
+          if (isDocumentRegistryEntry(entry)) {
+            sourceFiles.push({
+              name: name2,
+              scriptKind: entry.sourceFile.scriptKind,
+              refCount: entry.languageServiceRefCount
+            });
+          } else {
+            entry.forEach((value, scriptKind) => sourceFiles.push({ name: name2, scriptKind, refCount: value.languageServiceRefCount }));
+          }
+        });
+        sourceFiles.sort((x, y) => y.refCount - x.refCount);
+        return {
+          bucket: name,
+          sourceFiles
+        };
+      });
+      return JSON.stringify(bucketInfoArray, void 0, 2);
     }
-    if (text.indexOf("()") === 0)
-      return 2;
-    if (text.charAt(0) === "<") {
-      let brackets2 = 0;
-      let i = 0;
-      while (i < text.length) {
-        if (text[i] === "<")
-          brackets2++;
-        if (text[i] === ">")
-          brackets2--;
-        i++;
-        if (!brackets2)
-          return i;
+    function getCompilationSettings(settingsOrHost) {
+      if (typeof settingsOrHost.getCompilationSettings === "function") {
+        return settingsOrHost.getCompilationSettings();
       }
+      return settingsOrHost;
     }
-    return 0;
-  }
-  function getNewLineOrDefaultFromHost(host, formatSettings) {
-    var _a;
-    return (formatSettings == null ? void 0 : formatSettings.newLineCharacter) || ((_a = host.getNewLine) == null ? void 0 : _a.call(host)) || lineFeed2;
-  }
-  function lineBreakPart() {
-    return displayPart("\n", 6 /* lineBreak */);
-  }
-  function mapToDisplayParts(writeDisplayParts) {
-    try {
-      writeDisplayParts(displayPartWriter);
-      return displayPartWriter.displayParts();
-    } finally {
-      displayPartWriter.clear();
+    function acquireDocument(fileName, compilationSettings, scriptSnapshot, version2, scriptKind, languageVersionOrOptions) {
+      const path = toPath(fileName, currentDirectory, getCanonicalFileName);
+      const key = getKeyForCompilationSettings(getCompilationSettings(compilationSettings));
+      return acquireDocumentWithKey(fileName, path, compilationSettings, key, scriptSnapshot, version2, scriptKind, languageVersionOrOptions);
     }
-  }
-  function typeToDisplayParts(typechecker, type, enclosingDeclaration, flags = 0 /* None */) {
-    return mapToDisplayParts((writer) => {
-      typechecker.writeType(type, enclosingDeclaration, flags | 1024 /* MultilineObjectLiterals */ | 16384 /* UseAliasDefinedOutsideCurrentScope */, writer);
-    });
-  }
-  function symbolToDisplayParts(typeChecker, symbol, enclosingDeclaration, meaning, flags = 0 /* None */) {
-    return mapToDisplayParts((writer) => {
-      typeChecker.writeSymbol(symbol, enclosingDeclaration, meaning, flags | 8 /* UseAliasDefinedOutsideCurrentScope */, writer);
-    });
-  }
-  function signatureToDisplayParts(typechecker, signature, enclosingDeclaration, flags = 0 /* None */) {
-    flags |= 16384 /* UseAliasDefinedOutsideCurrentScope */ | 1024 /* MultilineObjectLiterals */ | 32 /* WriteTypeArgumentsOfSignature */ | 8192 /* OmitParameterModifiers */;
-    return mapToDisplayParts((writer) => {
-      typechecker.writeSignature(
-        signature,
-        enclosingDeclaration,
-        flags,
-        /*kind*/
-        void 0,
-        writer
+    function acquireDocumentWithKey(fileName, path, compilationSettings, key, scriptSnapshot, version2, scriptKind, languageVersionOrOptions) {
+      return acquireOrUpdateDocument(
+        fileName,
+        path,
+        compilationSettings,
+        key,
+        scriptSnapshot,
+        version2,
+        /*acquiring*/
+        true,
+        scriptKind,
+        languageVersionOrOptions
       );
-    });
-  }
-  function nodeToDisplayParts(node, enclosingDeclaration) {
-    const file = enclosingDeclaration.getSourceFile();
-    return mapToDisplayParts((writer) => {
-      const printer = createPrinterWithRemoveCommentsOmitTrailingSemicolon();
-      printer.writeNode(4 /* Unspecified */, node, file, writer);
-    });
-  }
-  function isImportOrExportSpecifierName(location) {
-    return !!location.parent && isImportOrExportSpecifier(location.parent) && location.parent.propertyName === location;
-  }
-  function getScriptKind(fileName, host) {
-    return ensureScriptKind(fileName, host.getScriptKind && host.getScriptKind(fileName));
-  }
-  function getSymbolTarget(symbol, checker) {
-    let next = symbol;
-    while (isAliasSymbol(next) || isTransientSymbol(next) && next.links.target) {
-      if (isTransientSymbol(next) && next.links.target) {
-        next = next.links.target;
-      } else {
-        next = skipAlias(next, checker);
-      }
-    }
-    return next;
-  }
-  function isAliasSymbol(symbol) {
-    return (symbol.flags & 2097152 /* Alias */) !== 0;
-  }
-  function getUniqueSymbolId(symbol, checker) {
-    return getSymbolId(skipAlias(symbol, checker));
-  }
-  function getFirstNonSpaceCharacterPosition(text, position) {
-    while (isWhiteSpaceLike(text.charCodeAt(position))) {
-      position += 1;
-    }
-    return position;
-  }
-  function getPrecedingNonSpaceCharacterPosition(text, position) {
-    while (position > -1 && isWhiteSpaceSingleLine(text.charCodeAt(position))) {
-      position -= 1;
-    }
-    return position + 1;
-  }
-  function getSynthesizedDeepClone(node, includeTrivia = true) {
-    const clone2 = node && getSynthesizedDeepCloneWorker(node);
-    if (clone2 && !includeTrivia)
-      suppressLeadingAndTrailingTrivia(clone2);
-    return clone2;
-  }
-  function getSynthesizedDeepCloneWithReplacements(node, includeTrivia, replaceNode) {
-    let clone2 = replaceNode(node);
-    if (clone2) {
-      setOriginalNode(clone2, node);
-    } else {
-      clone2 = getSynthesizedDeepCloneWorker(node, replaceNode);
-    }
-    if (clone2 && !includeTrivia)
-      suppressLeadingAndTrailingTrivia(clone2);
-    return clone2;
-  }
-  function getSynthesizedDeepCloneWorker(node, replaceNode) {
-    const nodeClone = replaceNode ? (n) => getSynthesizedDeepCloneWithReplacements(
-      n,
-      /*includeTrivia*/
-      true,
-      replaceNode
-    ) : getSynthesizedDeepClone;
-    const nodesClone = replaceNode ? (ns) => ns && getSynthesizedDeepClonesWithReplacements(
-      ns,
-      /*includeTrivia*/
-      true,
-      replaceNode
-    ) : (ns) => ns && getSynthesizedDeepClones(ns);
-    const visited = visitEachChild(node, nodeClone, nullTransformationContext, nodesClone, nodeClone);
-    if (visited === node) {
-      const clone2 = isStringLiteral(node) ? setOriginalNode(factory.createStringLiteralFromNode(node), node) : isNumericLiteral(node) ? setOriginalNode(factory.createNumericLiteral(node.text, node.numericLiteralFlags), node) : factory.cloneNode(node);
-      return setTextRange(clone2, node);
-    }
-    visited.parent = void 0;
-    return visited;
-  }
-  function getSynthesizedDeepClones(nodes, includeTrivia = true) {
-    if (nodes) {
-      const cloned = factory.createNodeArray(nodes.map((n) => getSynthesizedDeepClone(n, includeTrivia)), nodes.hasTrailingComma);
-      setTextRange(cloned, nodes);
-      return cloned;
     }
-    return nodes;
-  }
-  function getSynthesizedDeepClonesWithReplacements(nodes, includeTrivia, replaceNode) {
-    return factory.createNodeArray(nodes.map((n) => getSynthesizedDeepCloneWithReplacements(n, includeTrivia, replaceNode)), nodes.hasTrailingComma);
-  }
-  function suppressLeadingAndTrailingTrivia(node) {
-    suppressLeadingTrivia(node);
-    suppressTrailingTrivia(node);
-  }
-  function suppressLeadingTrivia(node) {
-    addEmitFlagsRecursively(node, 1024 /* NoLeadingComments */, getFirstChild);
-  }
-  function suppressTrailingTrivia(node) {
-    addEmitFlagsRecursively(node, 2048 /* NoTrailingComments */, getLastChild);
-  }
-  function copyComments(sourceNode, targetNode) {
-    const sourceFile = sourceNode.getSourceFile();
-    const text = sourceFile.text;
-    if (hasLeadingLineBreak(sourceNode, text)) {
-      copyLeadingComments(sourceNode, targetNode, sourceFile);
-    } else {
-      copyTrailingAsLeadingComments(sourceNode, targetNode, sourceFile);
+    function updateDocument(fileName, compilationSettings, scriptSnapshot, version2, scriptKind, languageVersionOrOptions) {
+      const path = toPath(fileName, currentDirectory, getCanonicalFileName);
+      const key = getKeyForCompilationSettings(getCompilationSettings(compilationSettings));
+      return updateDocumentWithKey(fileName, path, compilationSettings, key, scriptSnapshot, version2, scriptKind, languageVersionOrOptions);
     }
-    copyTrailingComments(sourceNode, targetNode, sourceFile);
-  }
-  function hasLeadingLineBreak(node, text) {
-    const start = node.getFullStart();
-    const end = node.getStart();
-    for (let i = start; i < end; i++) {
-      if (text.charCodeAt(i) === 10 /* lineFeed */)
-        return true;
+    function updateDocumentWithKey(fileName, path, compilationSettings, key, scriptSnapshot, version2, scriptKind, languageVersionOrOptions) {
+      return acquireOrUpdateDocument(
+        fileName,
+        path,
+        getCompilationSettings(compilationSettings),
+        key,
+        scriptSnapshot,
+        version2,
+        /*acquiring*/
+        false,
+        scriptKind,
+        languageVersionOrOptions
+      );
     }
-    return false;
-  }
-  function addEmitFlagsRecursively(node, flag, getChild) {
-    addEmitFlags(node, flag);
-    const child = getChild(node);
-    if (child)
-      addEmitFlagsRecursively(child, flag, getChild);
-  }
-  function getFirstChild(node) {
-    return node.forEachChild((child) => child);
-  }
-  function getUniqueName(baseName, sourceFile) {
-    let nameText = baseName;
-    for (let i = 1; !isFileLevelUniqueName(sourceFile, nameText); i++) {
-      nameText = `${baseName}_${i}`;
+    function getDocumentRegistryEntry(bucketEntry, scriptKind) {
+      const entry = isDocumentRegistryEntry(bucketEntry) ? bucketEntry : bucketEntry.get(Debug.checkDefined(scriptKind, "If there are more than one scriptKind's for same document the scriptKind should be provided"));
+      Debug.assert(scriptKind === void 0 || !entry || entry.sourceFile.scriptKind === scriptKind, `Script kind should match provided ScriptKind:${scriptKind} and sourceFile.scriptKind: ${entry == null ? void 0 : entry.sourceFile.scriptKind}, !entry: ${!entry}`);
+      return entry;
     }
-    return nameText;
-  }
-  function getRenameLocation(edits, renameFilename, name, preferLastLocation) {
-    let delta = 0;
-    let lastPos = -1;
-    for (const { fileName, textChanges: textChanges2 } of edits) {
-      Debug.assert(fileName === renameFilename);
-      for (const change of textChanges2) {
-        const { span, newText } = change;
-        const index = indexInTextChange(newText, escapeString(name));
-        if (index !== -1) {
-          lastPos = span.start + delta + index;
-          if (!preferLastLocation) {
-            return lastPos;
-          }
+    function acquireOrUpdateDocument(fileName, path, compilationSettingsOrHost, key, scriptSnapshot, version2, acquiring, scriptKind, languageVersionOrOptions) {
+      var _a, _b, _c, _d;
+      scriptKind = ensureScriptKind(fileName, scriptKind);
+      const compilationSettings = getCompilationSettings(compilationSettingsOrHost);
+      const host = compilationSettingsOrHost === compilationSettings ? void 0 : compilationSettingsOrHost;
+      const scriptTarget = scriptKind === 6 /* JSON */ ? 100 /* JSON */ : getEmitScriptTarget(compilationSettings);
+      const sourceFileOptions = typeof languageVersionOrOptions === "object" ? languageVersionOrOptions : {
+        languageVersion: scriptTarget,
+        impliedNodeFormat: host && getImpliedNodeFormatForFile(path, (_d = (_c = (_b = (_a = host.getCompilerHost) == null ? void 0 : _a.call(host)) == null ? void 0 : _b.getModuleResolutionCache) == null ? void 0 : _c.call(_b)) == null ? void 0 : _d.getPackageJsonInfoCache(), host, compilationSettings),
+        setExternalModuleIndicator: getSetExternalModuleIndicator(compilationSettings),
+        jsDocParsingMode
+      };
+      sourceFileOptions.languageVersion = scriptTarget;
+      Debug.assertEqual(jsDocParsingMode, sourceFileOptions.jsDocParsingMode);
+      const oldBucketCount = buckets.size;
+      const keyWithMode = getDocumentRegistryBucketKeyWithMode(key, sourceFileOptions.impliedNodeFormat);
+      const bucket = getOrUpdate(buckets, keyWithMode, () => /* @__PURE__ */ new Map());
+      if (tracing) {
+        if (buckets.size > oldBucketCount) {
+          tracing.instant(tracing.Phase.Session, "createdDocumentRegistryBucket", { configFilePath: compilationSettings.configFilePath, key: keyWithMode });
+        }
+        const otherBucketKey = !isDeclarationFileName(path) && forEachEntry(buckets, (bucket2, bucketKey) => bucketKey !== keyWithMode && bucket2.has(path) && bucketKey);
+        if (otherBucketKey) {
+          tracing.instant(tracing.Phase.Session, "documentRegistryBucketOverlap", { path, key1: otherBucketKey, key2: keyWithMode });
         }
-        delta += newText.length - span.length;
-      }
-    }
-    Debug.assert(preferLastLocation);
-    Debug.assert(lastPos >= 0);
-    return lastPos;
-  }
-  function copyLeadingComments(sourceNode, targetNode, sourceFile, commentKind, hasTrailingNewLine) {
-    forEachLeadingCommentRange(sourceFile.text, sourceNode.pos, getAddCommentsFunction(targetNode, sourceFile, commentKind, hasTrailingNewLine, addSyntheticLeadingComment));
-  }
-  function copyTrailingComments(sourceNode, targetNode, sourceFile, commentKind, hasTrailingNewLine) {
-    forEachTrailingCommentRange(sourceFile.text, sourceNode.end, getAddCommentsFunction(targetNode, sourceFile, commentKind, hasTrailingNewLine, addSyntheticTrailingComment));
-  }
-  function copyTrailingAsLeadingComments(sourceNode, targetNode, sourceFile, commentKind, hasTrailingNewLine) {
-    forEachTrailingCommentRange(sourceFile.text, sourceNode.pos, getAddCommentsFunction(targetNode, sourceFile, commentKind, hasTrailingNewLine, addSyntheticLeadingComment));
-  }
-  function getAddCommentsFunction(targetNode, sourceFile, commentKind, hasTrailingNewLine, cb) {
-    return (pos, end, kind, htnl) => {
-      if (kind === 3 /* MultiLineCommentTrivia */) {
-        pos += 2;
-        end -= 2;
-      } else {
-        pos += 2;
-      }
-      cb(targetNode, commentKind || kind, sourceFile.text.slice(pos, end), hasTrailingNewLine !== void 0 ? hasTrailingNewLine : htnl);
-    };
-  }
-  function indexInTextChange(change, name) {
-    if (startsWith(change, name))
-      return 0;
-    let idx = change.indexOf(" " + name);
-    if (idx === -1)
-      idx = change.indexOf("." + name);
-    if (idx === -1)
-      idx = change.indexOf('"' + name);
-    return idx === -1 ? -1 : idx + 1;
-  }
-  function needsParentheses(expression) {
-    return isBinaryExpression(expression) && expression.operatorToken.kind === 28 /* CommaToken */ || isObjectLiteralExpression(expression) || isAsExpression(expression) && isObjectLiteralExpression(expression.expression);
-  }
-  function getContextualTypeFromParent(node, checker, contextFlags) {
-    const parent2 = walkUpParenthesizedExpressions(node.parent);
-    switch (parent2.kind) {
-      case 213 /* NewExpression */:
-        return checker.getContextualType(parent2, contextFlags);
-      case 225 /* BinaryExpression */: {
-        const { left, operatorToken, right } = parent2;
-        return isEqualityOperatorKind(operatorToken.kind) ? checker.getTypeAtLocation(node === right ? left : right) : checker.getContextualType(node, contextFlags);
       }
-      case 295 /* CaseClause */:
-        return getSwitchedType(parent2, checker);
-      default:
-        return checker.getContextualType(node, contextFlags);
-    }
-  }
-  function quote(sourceFile, preferences, text) {
-    const quotePreference = getQuotePreference(sourceFile, preferences);
-    const quoted = JSON.stringify(text);
-    return quotePreference === 0 /* Single */ ? `'${stripQuotes(quoted).replace(/'/g, "\\'").replace(/\\"/g, '"')}'` : quoted;
-  }
-  function isEqualityOperatorKind(kind) {
-    switch (kind) {
-      case 37 /* EqualsEqualsEqualsToken */:
-      case 35 /* EqualsEqualsToken */:
-      case 38 /* ExclamationEqualsEqualsToken */:
-      case 36 /* ExclamationEqualsToken */:
-        return true;
-      default:
-        return false;
-    }
-  }
-  function isStringLiteralOrTemplate(node) {
-    switch (node.kind) {
-      case 11 /* StringLiteral */:
-      case 15 /* NoSubstitutionTemplateLiteral */:
-      case 227 /* TemplateExpression */:
-      case 214 /* TaggedTemplateExpression */:
-        return true;
-      default:
-        return false;
-    }
-  }
-  function hasIndexSignature(type) {
-    return !!type.getStringIndexType() || !!type.getNumberIndexType();
-  }
-  function getSwitchedType(caseClause, checker) {
-    return checker.getTypeAtLocation(caseClause.parent.parent.expression);
-  }
-  function getTypeNodeIfAccessible(type, enclosingScope, program, host) {
-    const checker = program.getTypeChecker();
-    let typeIsAccessible = true;
-    const notAccessible = () => typeIsAccessible = false;
-    const res = checker.typeToTypeNode(type, enclosingScope, 1 /* NoTruncation */, {
-      trackSymbol: (symbol, declaration, meaning) => {
-        typeIsAccessible = typeIsAccessible && checker.isSymbolAccessible(
-          symbol,
-          declaration,
-          meaning,
-          /*shouldComputeAliasToMarkVisible*/
-          false
-        ).accessibility === 0 /* Accessible */;
-        return !typeIsAccessible;
-      },
-      reportInaccessibleThisError: notAccessible,
-      reportPrivateInBaseOfClassExpression: notAccessible,
-      reportInaccessibleUniqueSymbolError: notAccessible,
-      moduleResolverHost: getModuleSpecifierResolverHost(program, host)
-    });
-    return typeIsAccessible ? res : void 0;
-  }
-  function syntaxRequiresTrailingCommaOrSemicolonOrASI(kind) {
-    return kind === 178 /* CallSignature */ || kind === 179 /* ConstructSignature */ || kind === 180 /* IndexSignature */ || kind === 170 /* PropertySignature */ || kind === 172 /* MethodSignature */;
-  }
-  function syntaxRequiresTrailingFunctionBlockOrSemicolonOrASI(kind) {
-    return kind === 261 /* FunctionDeclaration */ || kind === 175 /* Constructor */ || kind === 173 /* MethodDeclaration */ || kind === 176 /* GetAccessor */ || kind === 177 /* SetAccessor */;
-  }
-  function syntaxRequiresTrailingModuleBlockOrSemicolonOrASI(kind) {
-    return kind === 266 /* ModuleDeclaration */;
-  }
-  function syntaxRequiresTrailingSemicolonOrASI(kind) {
-    return kind === 242 /* VariableStatement */ || kind === 243 /* ExpressionStatement */ || kind === 245 /* DoStatement */ || kind === 250 /* ContinueStatement */ || kind === 251 /* BreakStatement */ || kind === 252 /* ReturnStatement */ || kind === 256 /* ThrowStatement */ || kind === 258 /* DebuggerStatement */ || kind === 171 /* PropertyDeclaration */ || kind === 264 /* TypeAliasDeclaration */ || kind === 271 /* ImportDeclaration */ || kind === 270 /* ImportEqualsDeclaration */ || kind === 277 /* ExportDeclaration */ || kind === 269 /* NamespaceExportDeclaration */ || kind === 276 /* ExportAssignment */;
-  }
-  function nodeIsASICandidate(node, sourceFile) {
-    const lastToken = node.getLastToken(sourceFile);
-    if (lastToken && lastToken.kind === 27 /* SemicolonToken */) {
-      return false;
-    }
-    if (syntaxRequiresTrailingCommaOrSemicolonOrASI(node.kind)) {
-      if (lastToken && lastToken.kind === 28 /* CommaToken */) {
-        return false;
+      const bucketEntry = bucket.get(path);
+      let entry = bucketEntry && getDocumentRegistryEntry(bucketEntry, scriptKind);
+      if (!entry && externalCache) {
+        const sourceFile = externalCache.getDocument(keyWithMode, path);
+        if (sourceFile) {
+          Debug.assert(acquiring);
+          entry = {
+            sourceFile,
+            languageServiceRefCount: 0
+          };
+          setBucketEntry();
+        }
       }
-    } else if (syntaxRequiresTrailingModuleBlockOrSemicolonOrASI(node.kind)) {
-      const lastChild = last(node.getChildren(sourceFile));
-      if (lastChild && isModuleBlock(lastChild)) {
-        return false;
+      if (!entry) {
+        const sourceFile = createLanguageServiceSourceFile(
+          fileName,
+          scriptSnapshot,
+          sourceFileOptions,
+          version2,
+          /*setNodeParents*/
+          false,
+          scriptKind
+        );
+        if (externalCache) {
+          externalCache.setDocument(keyWithMode, path, sourceFile);
+        }
+        entry = {
+          sourceFile,
+          languageServiceRefCount: 1
+        };
+        setBucketEntry();
+      } else {
+        if (entry.sourceFile.version !== version2) {
+          entry.sourceFile = updateLanguageServiceSourceFile(entry.sourceFile, scriptSnapshot, version2, scriptSnapshot.getChangeRange(entry.sourceFile.scriptSnapshot));
+          if (externalCache) {
+            externalCache.setDocument(keyWithMode, path, entry.sourceFile);
+          }
+        }
+        if (acquiring) {
+          entry.languageServiceRefCount++;
+        }
       }
-    } else if (syntaxRequiresTrailingFunctionBlockOrSemicolonOrASI(node.kind)) {
-      const lastChild = last(node.getChildren(sourceFile));
-      if (lastChild && isFunctionBlock(lastChild)) {
-        return false;
+      Debug.assert(entry.languageServiceRefCount !== 0);
+      return entry.sourceFile;
+      function setBucketEntry() {
+        if (!bucketEntry) {
+          bucket.set(path, entry);
+        } else if (isDocumentRegistryEntry(bucketEntry)) {
+          const scriptKindMap = /* @__PURE__ */ new Map();
+          scriptKindMap.set(bucketEntry.sourceFile.scriptKind, bucketEntry);
+          scriptKindMap.set(scriptKind, entry);
+          bucket.set(path, scriptKindMap);
+        } else {
+          bucketEntry.set(scriptKind, entry);
+        }
       }
-    } else if (!syntaxRequiresTrailingSemicolonOrASI(node.kind)) {
-      return false;
-    }
-    if (node.kind === 245 /* DoStatement */) {
-      return true;
     }
-    const topNode = findAncestor(node, (ancestor) => !ancestor.parent);
-    const nextToken = findNextToken(node, topNode, sourceFile);
-    if (!nextToken || nextToken.kind === 20 /* CloseBraceToken */) {
-      return true;
+    function releaseDocument(fileName, compilationSettings, scriptKind, impliedNodeFormat) {
+      const path = toPath(fileName, currentDirectory, getCanonicalFileName);
+      const key = getKeyForCompilationSettings(compilationSettings);
+      return releaseDocumentWithKey(path, key, scriptKind, impliedNodeFormat);
     }
-    const startLine = sourceFile.getLineAndCharacterOfPosition(node.getEnd()).line;
-    const endLine = sourceFile.getLineAndCharacterOfPosition(nextToken.getStart(sourceFile)).line;
-    return startLine !== endLine;
-  }
-  function positionIsASICandidate(pos, context, sourceFile) {
-    const contextAncestor = findAncestor(context, (ancestor) => {
-      if (ancestor.end !== pos) {
-        return "quit";
-      }
-      return syntaxMayBeASICandidate(ancestor.kind);
-    });
-    return !!contextAncestor && nodeIsASICandidate(contextAncestor, sourceFile);
-  }
-  function probablyUsesSemicolons(sourceFile) {
-    let withSemicolon = 0;
-    let withoutSemicolon = 0;
-    const nStatementsToObserve = 5;
-    forEachChild(sourceFile, function visit(node) {
-      if (syntaxRequiresTrailingSemicolonOrASI(node.kind)) {
-        const lastToken = node.getLastToken(sourceFile);
-        if ((lastToken == null ? void 0 : lastToken.kind) === 27 /* SemicolonToken */) {
-          withSemicolon++;
+    function releaseDocumentWithKey(path, key, scriptKind, impliedNodeFormat) {
+      const bucket = Debug.checkDefined(buckets.get(getDocumentRegistryBucketKeyWithMode(key, impliedNodeFormat)));
+      const bucketEntry = bucket.get(path);
+      const entry = getDocumentRegistryEntry(bucketEntry, scriptKind);
+      entry.languageServiceRefCount--;
+      Debug.assert(entry.languageServiceRefCount >= 0);
+      if (entry.languageServiceRefCount === 0) {
+        if (isDocumentRegistryEntry(bucketEntry)) {
+          bucket.delete(path);
         } else {
-          withoutSemicolon++;
-        }
-      } else if (syntaxRequiresTrailingCommaOrSemicolonOrASI(node.kind)) {
-        const lastToken = node.getLastToken(sourceFile);
-        if ((lastToken == null ? void 0 : lastToken.kind) === 27 /* SemicolonToken */) {
-          withSemicolon++;
-        } else if (lastToken && lastToken.kind !== 28 /* CommaToken */) {
-          const lastTokenLine = getLineAndCharacterOfPosition(sourceFile, lastToken.getStart(sourceFile)).line;
-          const nextTokenLine = getLineAndCharacterOfPosition(sourceFile, getSpanOfTokenAtPosition(sourceFile, lastToken.end).start).line;
-          if (lastTokenLine !== nextTokenLine) {
-            withoutSemicolon++;
+          bucketEntry.delete(scriptKind);
+          if (bucketEntry.size === 1) {
+            bucket.set(path, firstDefinedIterator(bucketEntry.values(), identity));
           }
         }
       }
-      if (withSemicolon + withoutSemicolon >= nStatementsToObserve) {
-        return true;
-      }
-      return forEachChild(node, visit);
-    });
-    if (withSemicolon === 0 && withoutSemicolon <= 1) {
-      return true;
-    }
-    return withSemicolon / withoutSemicolon > 1 / nStatementsToObserve;
-  }
-  function tryGetDirectories(host, directoryName) {
-    return tryIOAndConsumeErrors(host, host.getDirectories, directoryName) || [];
-  }
-  function tryReadDirectory(host, path, extensions, exclude, include) {
-    return tryIOAndConsumeErrors(host, host.readDirectory, path, extensions, exclude, include) || emptyArray;
-  }
-  function tryFileExists(host, path) {
-    return tryIOAndConsumeErrors(host, host.fileExists, path);
-  }
-  function tryDirectoryExists(host, path) {
-    return tryAndIgnoreErrors(() => directoryProbablyExists(path, host)) || false;
-  }
-  function tryAndIgnoreErrors(cb) {
-    try {
-      return cb();
-    } catch {
-      return void 0;
     }
+    return {
+      acquireDocument,
+      acquireDocumentWithKey,
+      updateDocument,
+      updateDocumentWithKey,
+      releaseDocument,
+      releaseDocumentWithKey,
+      getKeyForCompilationSettings,
+      getDocumentRegistryBucketKeyWithMode,
+      reportStats,
+      getBuckets: () => buckets
+    };
   }
-  function tryIOAndConsumeErrors(host, toApply, ...args) {
-    return tryAndIgnoreErrors(() => toApply && toApply.apply(host, args));
-  }
-  function findPackageJsons(startDirectory, host, stopDirectory) {
-    const paths = [];
-    forEachAncestorDirectory(startDirectory, (ancestor) => {
-      if (ancestor === stopDirectory) {
-        return true;
-      }
-      const currentConfigPath = combinePaths(ancestor, "package.json");
-      if (tryFileExists(host, currentConfigPath)) {
-        paths.push(currentConfigPath);
-      }
-    });
-    return paths;
+  function getKeyForCompilationSettings(settings) {
+    return getKeyForCompilerOptions(settings, sourceFileAffectingCompilerOptions);
   }
-  function findPackageJson(directory, host) {
-    let packageJson;
-    forEachAncestorDirectory(directory, (ancestor) => {
-      if (ancestor === "node_modules")
-        return true;
-      packageJson = findConfigFile(ancestor, (f) => tryFileExists(host, f), "package.json");
-      if (packageJson) {
-        return true;
-      }
-    });
-    return packageJson;
+  function getDocumentRegistryBucketKeyWithMode(key, mode) {
+    return mode ? `${key}|${mode}` : key;
   }
-  function getPackageJsonsVisibleToFile(fileName, host) {
-    if (!host.fileExists) {
-      return [];
+  var init_documentRegistry = __esm({
+    "src/services/documentRegistry.ts"() {
+      "use strict";
+      init_ts4();
     }
-    const packageJsons = [];
-    forEachAncestorDirectory(getDirectoryPath(fileName), (ancestor) => {
-      const packageJsonFileName = combinePaths(ancestor, "package.json");
-      if (host.fileExists(packageJsonFileName)) {
-        const info = createPackageJsonInfo(packageJsonFileName, host);
-        if (info) {
-          packageJsons.push(info);
-        }
-      }
+  });
+
+  // src/services/getEditsForFileRename.ts
+  function getEditsForFileRename(program, oldFileOrDirPath, newFileOrDirPath, host, formatContext, preferences, sourceMapper) {
+    const useCaseSensitiveFileNames2 = hostUsesCaseSensitiveFileNames(host);
+    const getCanonicalFileName = createGetCanonicalFileName(useCaseSensitiveFileNames2);
+    const oldToNew = getPathUpdater(oldFileOrDirPath, newFileOrDirPath, getCanonicalFileName, sourceMapper);
+    const newToOld = getPathUpdater(newFileOrDirPath, oldFileOrDirPath, getCanonicalFileName, sourceMapper);
+    return ts_textChanges_exports.ChangeTracker.with({ host, formatContext, preferences }, (changeTracker) => {
+      updateTsconfigFiles(program, changeTracker, oldToNew, oldFileOrDirPath, newFileOrDirPath, host.getCurrentDirectory(), useCaseSensitiveFileNames2);
+      updateImports(program, changeTracker, oldToNew, newToOld, host, getCanonicalFileName);
     });
-    return packageJsons;
   }
-  function createPackageJsonInfo(fileName, host) {
-    if (!host.readFile) {
-      return void 0;
-    }
-    const dependencyKeys = ["dependencies", "devDependencies", "optionalDependencies", "peerDependencies"];
-    const stringContent = host.readFile(fileName) || "";
-    const content = tryParseJson(stringContent);
-    const info = {};
-    if (content) {
-      for (const key of dependencyKeys) {
-        const dependencies = content[key];
-        if (!dependencies) {
-          continue;
-        }
-        const dependencyMap = /* @__PURE__ */ new Map();
-        for (const packageName in dependencies) {
-          dependencyMap.set(packageName, dependencies[packageName]);
-        }
-        info[key] = dependencyMap;
-      }
-    }
-    const dependencyGroups = [
-      [1 /* Dependencies */, info.dependencies],
-      [2 /* DevDependencies */, info.devDependencies],
-      [8 /* OptionalDependencies */, info.optionalDependencies],
-      [4 /* PeerDependencies */, info.peerDependencies]
-    ];
-    return {
-      ...info,
-      parseable: !!content,
-      fileName,
-      get,
-      has(dependencyName, inGroups) {
-        return !!get(dependencyName, inGroups);
-      }
+  function getPathUpdater(oldFileOrDirPath, newFileOrDirPath, getCanonicalFileName, sourceMapper) {
+    const canonicalOldPath = getCanonicalFileName(oldFileOrDirPath);
+    return (path) => {
+      const originalPath = sourceMapper && sourceMapper.tryGetSourcePosition({ fileName: path, pos: 0 });
+      const updatedPath = getUpdatedPath(originalPath ? originalPath.fileName : path);
+      return originalPath ? updatedPath === void 0 ? void 0 : makeCorrespondingRelativeChange(originalPath.fileName, updatedPath, path, getCanonicalFileName) : updatedPath;
     };
-    function get(dependencyName, inGroups = 15 /* All */) {
-      for (const [group2, deps] of dependencyGroups) {
-        if (deps && inGroups & group2) {
-          const dep = deps.get(dependencyName);
-          if (dep !== void 0) {
-            return dep;
-          }
-        }
-      }
+    function getUpdatedPath(pathToUpdate) {
+      if (getCanonicalFileName(pathToUpdate) === canonicalOldPath)
+        return newFileOrDirPath;
+      const suffix = tryRemoveDirectoryPrefix(pathToUpdate, canonicalOldPath, getCanonicalFileName);
+      return suffix === void 0 ? void 0 : newFileOrDirPath + "/" + suffix;
     }
   }
-  function createPackageJsonImportFilter(fromFile, preferences, host) {
-    const packageJsons = (host.getPackageJsonsVisibleToFile && host.getPackageJsonsVisibleToFile(fromFile.fileName) || getPackageJsonsVisibleToFile(fromFile.fileName, host)).filter((p) => p.parseable);
-    let usesNodeCoreModules;
-    let ambientModuleCache;
-    let sourceFileCache;
-    return {
-      allowsImportingAmbientModule,
-      allowsImportingSourceFile,
-      allowsImportingSpecifier
-    };
-    function moduleSpecifierIsCoveredByPackageJson(specifier) {
-      const packageName = getNodeModuleRootSpecifier(specifier);
-      for (const packageJson of packageJsons) {
-        if (packageJson.has(packageName) || packageJson.has(getTypesPackageName(packageName))) {
-          return true;
-        }
-      }
-      return false;
-    }
-    function allowsImportingAmbientModule(moduleSymbol, moduleSpecifierResolutionHost) {
-      if (!packageJsons.length || !moduleSymbol.valueDeclaration) {
-        return true;
-      }
-      if (!ambientModuleCache) {
-        ambientModuleCache = /* @__PURE__ */ new Map();
-      } else {
-        const cached = ambientModuleCache.get(moduleSymbol);
-        if (cached !== void 0) {
-          return cached;
-        }
-      }
-      const declaredModuleSpecifier = stripQuotes(moduleSymbol.getName());
-      if (isAllowedCoreNodeModulesImport(declaredModuleSpecifier)) {
-        ambientModuleCache.set(moduleSymbol, true);
-        return true;
-      }
-      const declaringSourceFile = moduleSymbol.valueDeclaration.getSourceFile();
-      const declaringNodeModuleName = getNodeModulesPackageNameFromFileName(declaringSourceFile.fileName, moduleSpecifierResolutionHost);
-      if (typeof declaringNodeModuleName === "undefined") {
-        ambientModuleCache.set(moduleSymbol, true);
-        return true;
-      }
-      const result = moduleSpecifierIsCoveredByPackageJson(declaringNodeModuleName) || moduleSpecifierIsCoveredByPackageJson(declaredModuleSpecifier);
-      ambientModuleCache.set(moduleSymbol, result);
-      return result;
-    }
-    function allowsImportingSourceFile(sourceFile, moduleSpecifierResolutionHost) {
-      if (!packageJsons.length) {
-        return true;
-      }
-      if (!sourceFileCache) {
-        sourceFileCache = /* @__PURE__ */ new Map();
-      } else {
-        const cached = sourceFileCache.get(sourceFile);
-        if (cached !== void 0) {
-          return cached;
+  function makeCorrespondingRelativeChange(a0, b0, a1, getCanonicalFileName) {
+    const rel = getRelativePathFromFile(a0, b0, getCanonicalFileName);
+    return combinePathsSafe(getDirectoryPath(a1), rel);
+  }
+  function updateTsconfigFiles(program, changeTracker, oldToNew, oldFileOrDirPath, newFileOrDirPath, currentDirectory, useCaseSensitiveFileNames2) {
+    const { configFile } = program.getCompilerOptions();
+    if (!configFile)
+      return;
+    const configDir = getDirectoryPath(configFile.fileName);
+    const jsonObjectLiteral = getTsConfigObjectLiteralExpression(configFile);
+    if (!jsonObjectLiteral)
+      return;
+    forEachProperty(jsonObjectLiteral, (property, propertyName) => {
+      switch (propertyName) {
+        case "files":
+        case "include":
+        case "exclude": {
+          const foundExactMatch = updatePaths(property);
+          if (foundExactMatch || propertyName !== "include" || !isArrayLiteralExpression(property.initializer))
+            return;
+          const includes = mapDefined(property.initializer.elements, (e) => isStringLiteral(e) ? e.text : void 0);
+          if (includes.length === 0)
+            return;
+          const matchers = getFileMatcherPatterns(
+            configDir,
+            /*excludes*/
+            [],
+            includes,
+            useCaseSensitiveFileNames2,
+            currentDirectory
+          );
+          if (getRegexFromPattern(Debug.checkDefined(matchers.includeFilePattern), useCaseSensitiveFileNames2).test(oldFileOrDirPath) && !getRegexFromPattern(Debug.checkDefined(matchers.includeFilePattern), useCaseSensitiveFileNames2).test(newFileOrDirPath)) {
+            changeTracker.insertNodeAfter(configFile, last(property.initializer.elements), factory.createStringLiteral(relativePath(newFileOrDirPath)));
+          }
+          return;
         }
+        case "compilerOptions":
+          forEachProperty(property.initializer, (property2, propertyName2) => {
+            const option = getOptionFromName(propertyName2);
+            Debug.assert((option == null ? void 0 : option.type) !== "listOrElement");
+            if (option && (option.isFilePath || option.type === "list" && option.element.isFilePath)) {
+              updatePaths(property2);
+            } else if (propertyName2 === "paths") {
+              forEachProperty(property2.initializer, (pathsProperty) => {
+                if (!isArrayLiteralExpression(pathsProperty.initializer))
+                  return;
+                for (const e of pathsProperty.initializer.elements) {
+                  tryUpdateString(e);
+                }
+              });
+            }
+          });
+          return;
       }
-      const moduleSpecifier = getNodeModulesPackageNameFromFileName(sourceFile.fileName, moduleSpecifierResolutionHost);
-      if (!moduleSpecifier) {
-        sourceFileCache.set(sourceFile, true);
-        return true;
+    });
+    function updatePaths(property) {
+      const elements = isArrayLiteralExpression(property.initializer) ? property.initializer.elements : [property.initializer];
+      let foundExactMatch = false;
+      for (const element of elements) {
+        foundExactMatch = tryUpdateString(element) || foundExactMatch;
       }
-      const result = moduleSpecifierIsCoveredByPackageJson(moduleSpecifier);
-      sourceFileCache.set(sourceFile, result);
-      return result;
+      return foundExactMatch;
     }
-    function allowsImportingSpecifier(moduleSpecifier) {
-      if (!packageJsons.length || isAllowedCoreNodeModulesImport(moduleSpecifier)) {
-        return true;
-      }
-      if (pathIsRelative(moduleSpecifier) || isRootedDiskPath(moduleSpecifier)) {
+    function tryUpdateString(element) {
+      if (!isStringLiteral(element))
+        return false;
+      const elementFileName = combinePathsSafe(configDir, element.text);
+      const updated = oldToNew(elementFileName);
+      if (updated !== void 0) {
+        changeTracker.replaceRangeWithText(configFile, createStringRange(element, configFile), relativePath(updated));
         return true;
       }
-      return moduleSpecifierIsCoveredByPackageJson(moduleSpecifier);
-    }
-    function isAllowedCoreNodeModulesImport(moduleSpecifier) {
-      if (isSourceFileJS(fromFile) && ts_JsTyping_exports.nodeCoreModules.has(moduleSpecifier)) {
-        if (usesNodeCoreModules === void 0) {
-          usesNodeCoreModules = consumesNodeCoreModules(fromFile);
-        }
-        if (usesNodeCoreModules) {
-          return true;
-        }
-      }
       return false;
     }
-    function getNodeModulesPackageNameFromFileName(importedFileName, moduleSpecifierResolutionHost) {
-      if (!stringContains(importedFileName, "node_modules")) {
-        return void 0;
-      }
-      const specifier = ts_moduleSpecifiers_exports.getNodeModulesPackageName(
-        host.getCompilationSettings(),
-        fromFile,
-        importedFileName,
-        moduleSpecifierResolutionHost,
-        preferences
+    function relativePath(path) {
+      return getRelativePathFromDirectory(
+        configDir,
+        path,
+        /*ignoreCase*/
+        !useCaseSensitiveFileNames2
       );
-      if (!specifier) {
-        return void 0;
-      }
-      if (!pathIsRelative(specifier) && !isRootedDiskPath(specifier)) {
-        return getNodeModuleRootSpecifier(specifier);
-      }
-    }
-    function getNodeModuleRootSpecifier(fullSpecifier) {
-      const components = getPathComponents(getPackageNameFromTypesPackageName(fullSpecifier)).slice(1);
-      if (startsWith(components[0], "@")) {
-        return `${components[0]}/${components[1]}`;
-      }
-      return components[0];
-    }
-  }
-  function tryParseJson(text) {
-    try {
-      return JSON.parse(text);
-    } catch {
-      return void 0;
-    }
-  }
-  function consumesNodeCoreModules(sourceFile) {
-    return some(sourceFile.imports, ({ text }) => ts_JsTyping_exports.nodeCoreModules.has(text));
-  }
-  function isInsideNodeModules(fileOrDirectory) {
-    return contains(getPathComponents(fileOrDirectory), "node_modules");
-  }
-  function isDiagnosticWithLocation(diagnostic) {
-    return diagnostic.file !== void 0 && diagnostic.start !== void 0 && diagnostic.length !== void 0;
-  }
-  function findDiagnosticForNode(node, sortedFileDiagnostics) {
-    const span = createTextSpanFromNode(node);
-    const index = binarySearchKey(sortedFileDiagnostics, span, identity, compareTextSpans);
-    if (index >= 0) {
-      const diagnostic = sortedFileDiagnostics[index];
-      Debug.assertEqual(diagnostic.file, node.getSourceFile(), "Diagnostics proided to 'findDiagnosticForNode' must be from a single SourceFile");
-      return cast(diagnostic, isDiagnosticWithLocation);
     }
   }
-  function getDiagnosticsWithinSpan(span, sortedFileDiagnostics) {
-    var _a;
-    let index = binarySearchKey(sortedFileDiagnostics, span.start, (diag2) => diag2.start, compareValues);
-    if (index < 0) {
-      index = ~index;
-    }
-    while (((_a = sortedFileDiagnostics[index - 1]) == null ? void 0 : _a.start) === span.start) {
-      index--;
-    }
-    const result = [];
-    const end = textSpanEnd(span);
-    while (true) {
-      const diagnostic = tryCast(sortedFileDiagnostics[index], isDiagnosticWithLocation);
-      if (!diagnostic || diagnostic.start > end) {
-        break;
-      }
-      if (textSpanContainsTextSpan(span, diagnostic)) {
-        result.push(diagnostic);
-      }
-      index++;
+  function updateImports(program, changeTracker, oldToNew, newToOld, host, getCanonicalFileName) {
+    const allFiles = program.getSourceFiles();
+    for (const sourceFile of allFiles) {
+      const newFromOld = oldToNew(sourceFile.fileName);
+      const newImportFromPath = newFromOld ?? sourceFile.fileName;
+      const newImportFromDirectory = getDirectoryPath(newImportFromPath);
+      const oldFromNew = newToOld(sourceFile.fileName);
+      const oldImportFromPath = oldFromNew || sourceFile.fileName;
+      const oldImportFromDirectory = getDirectoryPath(oldImportFromPath);
+      const importingSourceFileMoved = newFromOld !== void 0 || oldFromNew !== void 0;
+      updateImportsWorker(sourceFile, changeTracker, (referenceText) => {
+        if (!pathIsRelative(referenceText))
+          return void 0;
+        const oldAbsolute = combinePathsSafe(oldImportFromDirectory, referenceText);
+        const newAbsolute = oldToNew(oldAbsolute);
+        return newAbsolute === void 0 ? void 0 : ensurePathIsNonModuleName(getRelativePathFromDirectory(newImportFromDirectory, newAbsolute, getCanonicalFileName));
+      }, (importLiteral) => {
+        const importedModuleSymbol = program.getTypeChecker().getSymbolAtLocation(importLiteral);
+        if ((importedModuleSymbol == null ? void 0 : importedModuleSymbol.declarations) && importedModuleSymbol.declarations.some((d) => isAmbientModule(d)))
+          return void 0;
+        const toImport = oldFromNew !== void 0 ? getSourceFileToImportFromResolved(importLiteral, resolveModuleName(importLiteral.text, oldImportFromPath, program.getCompilerOptions(), host), oldToNew, allFiles) : getSourceFileToImport(importedModuleSymbol, importLiteral, sourceFile, program, host, oldToNew);
+        return toImport !== void 0 && (toImport.updated || importingSourceFileMoved && pathIsRelative(importLiteral.text)) ? ts_moduleSpecifiers_exports.updateModuleSpecifier(program.getCompilerOptions(), sourceFile, getCanonicalFileName(newImportFromPath), toImport.newFileName, createModuleSpecifierResolutionHost(program, host), importLiteral.text) : void 0;
+      });
     }
-    return result;
-  }
-  function getRefactorContextSpan({ startPosition, endPosition }) {
-    return createTextSpanFromBounds(startPosition, endPosition === void 0 ? startPosition : endPosition);
-  }
-  function getFixableErrorSpanExpression(sourceFile, span) {
-    const token = getTokenAtPosition(sourceFile, span.start);
-    const expression = findAncestor(token, (node) => {
-      if (node.getStart(sourceFile) < span.start || node.getEnd() > textSpanEnd(span)) {
-        return "quit";
-      }
-      return isExpression(node) && textSpansEqual(span, createTextSpanFromNode(node, sourceFile));
-    });
-    return expression;
   }
-  function mapOneOrMany(valueOrArray, f, resultSelector = identity) {
-    return valueOrArray ? isArray(valueOrArray) ? resultSelector(map(valueOrArray, f)) : f(valueOrArray, 0) : void 0;
+  function combineNormal(pathA, pathB) {
+    return normalizePath(combinePaths(pathA, pathB));
   }
-  function firstOrOnly(valueOrArray) {
-    return isArray(valueOrArray) ? first(valueOrArray) : valueOrArray;
+  function combinePathsSafe(pathA, pathB) {
+    return ensurePathIsNonModuleName(combineNormal(pathA, pathB));
   }
-  function getNamesForExportedSymbol(symbol, scriptTarget) {
-    if (needsNameFromDeclaration(symbol)) {
-      const fromDeclaration = getDefaultLikeExportNameFromDeclaration(symbol);
-      if (fromDeclaration)
-        return fromDeclaration;
-      const fileNameCase = ts_codefix_exports.moduleSymbolToValidIdentifier(
-        getSymbolParentOrFail(symbol),
-        scriptTarget,
-        /*forceCapitalize*/
-        false
-      );
-      const capitalized = ts_codefix_exports.moduleSymbolToValidIdentifier(
-        getSymbolParentOrFail(symbol),
-        scriptTarget,
-        /*forceCapitalize*/
-        true
-      );
-      if (fileNameCase === capitalized)
-        return fileNameCase;
-      return [fileNameCase, capitalized];
+  function getSourceFileToImport(importedModuleSymbol, importLiteral, importingSourceFile, program, host, oldToNew) {
+    if (importedModuleSymbol) {
+      const oldFileName = find(importedModuleSymbol.declarations, isSourceFile).fileName;
+      const newFileName = oldToNew(oldFileName);
+      return newFileName === void 0 ? { newFileName: oldFileName, updated: false } : { newFileName, updated: true };
+    } else {
+      const mode = getModeForUsageLocation(importingSourceFile, importLiteral);
+      const resolved = host.resolveModuleNameLiterals || !host.resolveModuleNames ? program.getResolvedModule(importingSourceFile, importLiteral.text, mode) : host.getResolvedModuleWithFailedLookupLocationsFromCache && host.getResolvedModuleWithFailedLookupLocationsFromCache(importLiteral.text, importingSourceFile.fileName, mode);
+      return getSourceFileToImportFromResolved(importLiteral, resolved, oldToNew, program.getSourceFiles());
     }
-    return symbol.name;
   }
-  function getNameForExportedSymbol(symbol, scriptTarget, preferCapitalized) {
-    if (needsNameFromDeclaration(symbol)) {
-      return getDefaultLikeExportNameFromDeclaration(symbol) || ts_codefix_exports.moduleSymbolToValidIdentifier(getSymbolParentOrFail(symbol), scriptTarget, !!preferCapitalized);
+  function getSourceFileToImportFromResolved(importLiteral, resolved, oldToNew, sourceFiles) {
+    if (!resolved)
+      return void 0;
+    if (resolved.resolvedModule) {
+      const result2 = tryChange(resolved.resolvedModule.resolvedFileName);
+      if (result2)
+        return result2;
     }
-    return symbol.name;
-  }
-  function needsNameFromDeclaration(symbol) {
-    return !(symbol.flags & 33554432 /* Transient */) && (symbol.escapedName === "export=" /* ExportEquals */ || symbol.escapedName === "default" /* Default */);
-  }
-  function getDefaultLikeExportNameFromDeclaration(symbol) {
-    return firstDefined(
-      symbol.declarations,
-      (d) => {
-        var _a, _b;
-        return isExportAssignment(d) ? (_a = tryCast(skipOuterExpressions(d.expression), isIdentifier)) == null ? void 0 : _a.text : (_b = tryCast(getNameOfDeclaration(d), isIdentifier)) == null ? void 0 : _b.text;
-      }
-    );
-  }
-  function getSymbolParentOrFail(symbol) {
-    var _a;
-    return Debug.checkDefined(
-      symbol.parent,
-      `Symbol parent was undefined. Flags: ${Debug.formatSymbolFlags(symbol.flags)}. Declarations: ${(_a = symbol.declarations) == null ? void 0 : _a.map((d) => {
-        const kind = Debug.formatSyntaxKind(d.kind);
-        const inJS = isInJSFile(d);
-        const { expression } = d;
-        return (inJS ? "[JS]" : "") + kind + (expression ? ` (expression: ${Debug.formatSyntaxKind(expression.kind)})` : "");
-      }).join(", ")}.`
-    );
-  }
-  function stringContainsAt(haystack, needle, startIndex) {
-    const needleLength = needle.length;
-    if (needleLength + startIndex > haystack.length) {
-      return false;
+    const result = forEach(resolved.failedLookupLocations, tryChangeWithIgnoringPackageJsonExisting) || pathIsRelative(importLiteral.text) && forEach(resolved.failedLookupLocations, tryChangeWithIgnoringPackageJson);
+    if (result)
+      return result;
+    return resolved.resolvedModule && { newFileName: resolved.resolvedModule.resolvedFileName, updated: false };
+    function tryChangeWithIgnoringPackageJsonExisting(oldFileName) {
+      const newFileName = oldToNew(oldFileName);
+      return newFileName && find(sourceFiles, (src) => src.fileName === newFileName) ? tryChangeWithIgnoringPackageJson(oldFileName) : void 0;
     }
-    for (let i = 0; i < needleLength; i++) {
-      if (needle.charCodeAt(i) !== haystack.charCodeAt(i + startIndex))
-        return false;
+    function tryChangeWithIgnoringPackageJson(oldFileName) {
+      return !endsWith(oldFileName, "/package.json") ? tryChange(oldFileName) : void 0;
+    }
+    function tryChange(oldFileName) {
+      const newFileName = oldToNew(oldFileName);
+      return newFileName && { newFileName, updated: true };
     }
-    return true;
-  }
-  function startsWithUnderscore(name) {
-    return name.charCodeAt(0) === 95 /* _ */;
-  }
-  function isGlobalDeclaration(declaration) {
-    return !isNonGlobalDeclaration(declaration);
   }
-  function isNonGlobalDeclaration(declaration) {
-    const sourceFile = declaration.getSourceFile();
-    if (!sourceFile.externalModuleIndicator && !sourceFile.commonJsModuleIndicator) {
-      return false;
+  function updateImportsWorker(sourceFile, changeTracker, updateRef, updateImport2) {
+    for (const ref of sourceFile.referencedFiles || emptyArray) {
+      const updated = updateRef(ref.fileName);
+      if (updated !== void 0 && updated !== sourceFile.text.slice(ref.pos, ref.end))
+        changeTracker.replaceRangeWithText(sourceFile, ref, updated);
+    }
+    for (const importStringLiteral of sourceFile.imports) {
+      const updated = updateImport2(importStringLiteral);
+      if (updated !== void 0 && updated !== importStringLiteral.text)
+        changeTracker.replaceRangeWithText(sourceFile, createStringRange(importStringLiteral, sourceFile), updated);
     }
-    return isInJSFile(declaration) || !findAncestor(declaration, (d) => isModuleDeclaration(d) && isGlobalScopeAugmentation(d));
   }
-  function isDeprecatedDeclaration(decl) {
-    return !!(getCombinedNodeFlagsAlwaysIncludeJSDoc(decl) & 8192 /* Deprecated */);
+  function createStringRange(node, sourceFile) {
+    return createRange(node.getStart(sourceFile) + 1, node.end - 1);
   }
-  function shouldUseUriStyleNodeCoreModules(file, program) {
-    const decisionFromFile = firstDefined(file.imports, (node) => {
-      if (ts_JsTyping_exports.nodeCoreModules.has(node.text)) {
-        return startsWith(node.text, "node:");
+  function forEachProperty(objectLiteral, cb) {
+    if (!isObjectLiteralExpression(objectLiteral))
+      return;
+    for (const property of objectLiteral.properties) {
+      if (isPropertyAssignment(property) && isStringLiteral(property.name)) {
+        cb(property, property.name.text);
       }
-    });
-    return decisionFromFile ?? program.usesUriStyleNodeCoreModules;
-  }
-  function getNewLineKind(newLineCharacter) {
-    return newLineCharacter === "\n" ? 1 /* LineFeed */ : 0 /* CarriageReturnLineFeed */;
-  }
-  function diagnosticToString(diag2) {
-    return isArray(diag2) ? formatStringFromArgs(getLocaleSpecificMessage(diag2[0]), diag2.slice(1)) : getLocaleSpecificMessage(diag2);
+    }
   }
-  function getFormatCodeSettingsForWriting({ options }, sourceFile) {
-    const shouldAutoDetectSemicolonPreference = !options.semicolons || options.semicolons === "ignore" /* Ignore */;
-    const shouldRemoveSemicolons = options.semicolons === "remove" /* Remove */ || shouldAutoDetectSemicolonPreference && !probablyUsesSemicolons(sourceFile);
+  var init_getEditsForFileRename = __esm({
+    "src/services/getEditsForFileRename.ts"() {
+      "use strict";
+      init_ts4();
+    }
+  });
+
+  // src/services/patternMatcher.ts
+  function createPatternMatch(kind, isCaseSensitive) {
     return {
-      ...options,
-      semicolons: shouldRemoveSemicolons ? "remove" /* Remove */ : "ignore" /* Ignore */
+      kind,
+      isCaseSensitive
     };
   }
-  function jsxModeNeedsExplicitImport(jsx) {
-    return jsx === 2 /* React */ || jsx === 3 /* ReactNative */;
-  }
-  function isSourceFileFromLibrary(program, node) {
-    return program.isSourceFileFromExternalLibrary(node) || program.isSourceFileDefaultLibrary(node);
-  }
-  function newCaseClauseTracker(checker, clauses) {
-    const existingStrings = /* @__PURE__ */ new Set();
-    const existingNumbers = /* @__PURE__ */ new Set();
-    const existingBigInts = /* @__PURE__ */ new Set();
-    for (const clause of clauses) {
-      if (!isDefaultClause(clause)) {
-        const expression = skipParentheses(clause.expression);
-        if (isLiteralExpression(expression)) {
-          switch (expression.kind) {
-            case 15 /* NoSubstitutionTemplateLiteral */:
-            case 11 /* StringLiteral */:
-              existingStrings.add(expression.text);
-              break;
-            case 9 /* NumericLiteral */:
-              existingNumbers.add(parseInt(expression.text));
-              break;
-            case 10 /* BigIntLiteral */:
-              const parsedBigInt = parseBigInt(endsWith(expression.text, "n") ? expression.text.slice(0, -1) : expression.text);
-              if (parsedBigInt) {
-                existingBigInts.add(pseudoBigIntToString(parsedBigInt));
-              }
-              break;
-          }
-        } else {
-          const symbol = checker.getSymbolAtLocation(clause.expression);
-          if (symbol && symbol.valueDeclaration && isEnumMember(symbol.valueDeclaration)) {
-            const enumValue = checker.getConstantValue(symbol.valueDeclaration);
-            if (enumValue !== void 0) {
-              addValue(enumValue);
-            }
-          }
-        }
-      }
+  function createPatternMatcher(pattern) {
+    const stringToWordSpans = /* @__PURE__ */ new Map();
+    const dotSeparatedSegments = pattern.trim().split(".").map((p) => createSegment(p.trim()));
+    if (dotSeparatedSegments.length === 1 && dotSeparatedSegments[0].totalTextChunk.text === "") {
+      return {
+        getMatchForLastSegmentOfPattern: () => createPatternMatch(
+          2 /* substring */,
+          /*isCaseSensitive*/
+          true
+        ),
+        getFullMatch: () => createPatternMatch(
+          2 /* substring */,
+          /*isCaseSensitive*/
+          true
+        ),
+        patternContainsDots: false
+      };
     }
+    if (dotSeparatedSegments.some((segment) => !segment.subWordTextChunks.length))
+      return void 0;
     return {
-      addValue,
-      hasValue
+      getFullMatch: (containers, candidate) => getFullMatch(containers, candidate, dotSeparatedSegments, stringToWordSpans),
+      getMatchForLastSegmentOfPattern: (candidate) => matchSegment(candidate, last(dotSeparatedSegments), stringToWordSpans),
+      patternContainsDots: dotSeparatedSegments.length > 1
     };
-    function addValue(value) {
-      switch (typeof value) {
-        case "string":
-          existingStrings.add(value);
-          break;
-        case "number":
-          existingNumbers.add(value);
-      }
-    }
-    function hasValue(value) {
-      switch (typeof value) {
-        case "string":
-          return existingStrings.has(value);
-        case "number":
-          return existingNumbers.has(value);
-        case "object":
-          return existingBigInts.has(pseudoBigIntToString(value));
-      }
-    }
   }
-  function fileShouldUseJavaScriptRequire(file, program, host, preferRequire) {
-    var _a;
-    const fileName = typeof file === "string" ? file : file.fileName;
-    if (!hasJSFileExtension(fileName)) {
-      return false;
-    }
-    const compilerOptions = program.getCompilerOptions();
-    const moduleKind = getEmitModuleKind(compilerOptions);
-    const impliedNodeFormat = typeof file === "string" ? getImpliedNodeFormatForFile(toPath(file, host.getCurrentDirectory(), hostGetCanonicalFileName(host)), (_a = program.getPackageJsonInfoCache) == null ? void 0 : _a.call(program), host, compilerOptions) : file.impliedNodeFormat;
-    if (impliedNodeFormat === 99 /* ESNext */) {
-      return false;
-    }
-    if (impliedNodeFormat === 1 /* CommonJS */) {
-      return true;
+  function getFullMatch(candidateContainers, candidate, dotSeparatedSegments, stringToWordSpans) {
+    const candidateMatch = matchSegment(candidate, last(dotSeparatedSegments), stringToWordSpans);
+    if (!candidateMatch) {
+      return void 0;
     }
-    if (compilerOptions.verbatimModuleSyntax && moduleKind === 1 /* CommonJS */) {
-      return true;
+    if (dotSeparatedSegments.length - 1 > candidateContainers.length) {
+      return void 0;
     }
-    if (compilerOptions.verbatimModuleSyntax && emitModuleKindIsNonNodeESM(moduleKind)) {
-      return false;
+    let bestMatch;
+    for (let i = dotSeparatedSegments.length - 2, j = candidateContainers.length - 1; i >= 0; i -= 1, j -= 1) {
+      bestMatch = betterMatch(bestMatch, matchSegment(candidateContainers[j], dotSeparatedSegments[i], stringToWordSpans));
     }
-    if (typeof file === "object") {
-      if (file.commonJsModuleIndicator) {
-        return true;
-      }
-      if (file.externalModuleIndicator) {
-        return false;
-      }
+    return bestMatch;
+  }
+  function getWordSpans(word, stringToWordSpans) {
+    let spans = stringToWordSpans.get(word);
+    if (!spans) {
+      stringToWordSpans.set(word, spans = breakIntoWordSpans(word));
     }
-    return preferRequire;
+    return spans;
   }
-  var scanner, SemanticMeaning, tripleSlashDirectivePrefixRegex, typeKeywords, QuotePreference, displayPartWriter, lineFeed2, ANONYMOUS, syntaxMayBeASICandidate;
-  var init_utilities4 = __esm({
-    "src/services/utilities.ts"() {
-      "use strict";
-      init_ts4();
-      scanner = createScanner(
-        99 /* Latest */,
-        /*skipTrivia*/
-        true
-      );
-      SemanticMeaning = /* @__PURE__ */ ((SemanticMeaning3) => {
-        SemanticMeaning3[SemanticMeaning3["None"] = 0] = "None";
-        SemanticMeaning3[SemanticMeaning3["Value"] = 1] = "Value";
-        SemanticMeaning3[SemanticMeaning3["Type"] = 2] = "Type";
-        SemanticMeaning3[SemanticMeaning3["Namespace"] = 4] = "Namespace";
-        SemanticMeaning3[SemanticMeaning3["All"] = 7] = "All";
-        return SemanticMeaning3;
-      })(SemanticMeaning || {});
-      tripleSlashDirectivePrefixRegex = /^\/\/\/\s* {
-        QuotePreference7[QuotePreference7["Single"] = 0] = "Single";
-        QuotePreference7[QuotePreference7["Double"] = 1] = "Double";
-        return QuotePreference7;
-      })(QuotePreference || {});
-      displayPartWriter = getDisplayPartWriter();
-      lineFeed2 = "\n";
-      ANONYMOUS = "anonymous function";
-      syntaxMayBeASICandidate = or(
-        syntaxRequiresTrailingCommaOrSemicolonOrASI,
-        syntaxRequiresTrailingFunctionBlockOrSemicolonOrASI,
-        syntaxRequiresTrailingModuleBlockOrSemicolonOrASI,
-        syntaxRequiresTrailingSemicolonOrASI
+  function matchTextChunk(candidate, chunk, stringToWordSpans) {
+    const index = indexOfIgnoringCase(candidate, chunk.textLowerCase);
+    if (index === 0) {
+      return createPatternMatch(
+        chunk.text.length === candidate.length ? 0 /* exact */ : 1 /* prefix */,
+        /*isCaseSensitive:*/
+        startsWith(candidate, chunk.text)
       );
     }
-  });
-
-  // src/services/exportInfoMap.ts
-  function createCacheableExportInfoMap(host) {
-    let exportInfoId = 1;
-    const exportInfo = createMultiMap();
-    const symbols = /* @__PURE__ */ new Map();
-    const packages = /* @__PURE__ */ new Map();
-    let usableByFileName;
-    const cache = {
-      isUsableByFile: (importingFile) => importingFile === usableByFileName,
-      isEmpty: () => !exportInfo.size,
-      clear: () => {
-        exportInfo.clear();
-        symbols.clear();
-        usableByFileName = void 0;
-      },
-      add: (importingFile, symbol, symbolTableKey, moduleSymbol, moduleFile, exportKind, isFromPackageJson, checker) => {
-        if (importingFile !== usableByFileName) {
-          cache.clear();
-          usableByFileName = importingFile;
-        }
-        let packageName;
-        if (moduleFile) {
-          const nodeModulesPathParts = getNodeModulePathParts(moduleFile.fileName);
-          if (nodeModulesPathParts) {
-            const { topLevelNodeModulesIndex, topLevelPackageNameIndex, packageRootIndex } = nodeModulesPathParts;
-            packageName = unmangleScopedPackageName(getPackageNameFromTypesPackageName(moduleFile.fileName.substring(topLevelPackageNameIndex + 1, packageRootIndex)));
-            if (startsWith(importingFile, moduleFile.path.substring(0, topLevelNodeModulesIndex))) {
-              const prevDeepestNodeModulesPath = packages.get(packageName);
-              const nodeModulesPath = moduleFile.fileName.substring(0, topLevelPackageNameIndex + 1);
-              if (prevDeepestNodeModulesPath) {
-                const prevDeepestNodeModulesIndex = prevDeepestNodeModulesPath.indexOf(nodeModulesPathPart);
-                if (topLevelNodeModulesIndex > prevDeepestNodeModulesIndex) {
-                  packages.set(packageName, nodeModulesPath);
-                }
-              } else {
-                packages.set(packageName, nodeModulesPath);
-              }
-            }
-          }
+    if (chunk.isLowerCase) {
+      if (index === -1)
+        return void 0;
+      const wordSpans = getWordSpans(candidate, stringToWordSpans);
+      for (const span of wordSpans) {
+        if (partStartsWith(
+          candidate,
+          span,
+          chunk.text,
+          /*ignoreCase*/
+          true
+        )) {
+          return createPatternMatch(
+            2 /* substring */,
+            /*isCaseSensitive:*/
+            partStartsWith(
+              candidate,
+              span,
+              chunk.text,
+              /*ignoreCase*/
+              false
+            )
+          );
         }
-        const isDefault = exportKind === 1 /* Default */;
-        const namedSymbol = isDefault && getLocalSymbolForExportDefault(symbol) || symbol;
-        const names = exportKind === 0 /* Named */ || isExternalModuleSymbol(namedSymbol) ? unescapeLeadingUnderscores(symbolTableKey) : getNamesForExportedSymbol(
-          namedSymbol,
-          /*scriptTarget*/
-          void 0
+      }
+      if (chunk.text.length < candidate.length && isUpperCaseLetter(candidate.charCodeAt(index))) {
+        return createPatternMatch(
+          2 /* substring */,
+          /*isCaseSensitive*/
+          false
         );
-        const symbolName2 = typeof names === "string" ? names : names[0];
-        const capitalizedSymbolName = typeof names === "string" ? void 0 : names[1];
-        const moduleName = stripQuotes(moduleSymbol.name);
-        const id = exportInfoId++;
-        const target = skipAlias(symbol, checker);
-        const storedSymbol = symbol.flags & 33554432 /* Transient */ ? void 0 : symbol;
-        const storedModuleSymbol = moduleSymbol.flags & 33554432 /* Transient */ ? void 0 : moduleSymbol;
-        if (!storedSymbol || !storedModuleSymbol)
-          symbols.set(id, [symbol, moduleSymbol]);
-        exportInfo.add(key(symbolName2, symbol, isExternalModuleNameRelative(moduleName) ? void 0 : moduleName, checker), {
-          id,
-          symbolTableKey,
-          symbolName: symbolName2,
-          capitalizedSymbolName,
-          moduleName,
-          moduleFile,
-          moduleFileName: moduleFile == null ? void 0 : moduleFile.fileName,
-          packageName,
-          exportKind,
-          targetFlags: target.flags,
-          isFromPackageJson,
-          symbol: storedSymbol,
-          moduleSymbol: storedModuleSymbol
-        });
-      },
-      get: (importingFile, key2) => {
-        if (importingFile !== usableByFileName)
-          return;
-        const result = exportInfo.get(key2);
-        return result == null ? void 0 : result.map(rehydrateCachedInfo);
-      },
-      search: (importingFile, preferCapitalized, matches, action) => {
-        if (importingFile !== usableByFileName)
-          return;
-        return forEachEntry(exportInfo, (info, key2) => {
-          const { symbolName: symbolName2, ambientModuleName } = parseKey(key2);
-          const name = preferCapitalized && info[0].capitalizedSymbolName || symbolName2;
-          if (matches(name, info[0].targetFlags)) {
-            const rehydrated = info.map(rehydrateCachedInfo);
-            const filtered = rehydrated.filter((r, i) => isNotShadowedByDeeperNodeModulesPackage(r, info[i].packageName));
-            if (filtered.length) {
-              const res = action(filtered, name, !!ambientModuleName, key2);
-              if (res !== void 0)
-                return res;
-            }
-          }
-        });
-      },
-      releaseSymbols: () => {
-        symbols.clear();
-      },
-      onFileChanged: (oldSourceFile, newSourceFile, typeAcquisitionEnabled) => {
-        if (fileIsGlobalOnly(oldSourceFile) && fileIsGlobalOnly(newSourceFile)) {
-          return false;
-        }
-        if (usableByFileName && usableByFileName !== newSourceFile.path || // If ATA is enabled, auto-imports uses existing imports to guess whether you want auto-imports from node.
-        // Adding or removing imports from node could change the outcome of that guess, so could change the suggestions list.
-        typeAcquisitionEnabled && consumesNodeCoreModules(oldSourceFile) !== consumesNodeCoreModules(newSourceFile) || // Module agumentation and ambient module changes can add or remove exports available to be auto-imported.
-        // Changes elsewhere in the file can change the *type* of an export in a module augmentation,
-        // but type info is gathered in getCompletionEntryDetails, which doesn't use the cache.
-        !arrayIsEqualTo(oldSourceFile.moduleAugmentations, newSourceFile.moduleAugmentations) || !ambientModuleDeclarationsAreEqual(oldSourceFile, newSourceFile)) {
-          cache.clear();
-          return true;
-        }
-        usableByFileName = newSourceFile.path;
-        return false;
       }
-    };
-    if (Debug.isDebugging) {
-      Object.defineProperty(cache, "__cache", { get: () => exportInfo });
-    }
-    return cache;
-    function rehydrateCachedInfo(info) {
-      if (info.symbol && info.moduleSymbol)
-        return info;
-      const { id, exportKind, targetFlags, isFromPackageJson, moduleFileName } = info;
-      const [cachedSymbol, cachedModuleSymbol] = symbols.get(id) || emptyArray;
-      if (cachedSymbol && cachedModuleSymbol) {
-        return {
-          symbol: cachedSymbol,
-          moduleSymbol: cachedModuleSymbol,
-          moduleFileName,
-          exportKind,
-          targetFlags,
-          isFromPackageJson
-        };
+    } else {
+      if (candidate.indexOf(chunk.text) > 0) {
+        return createPatternMatch(
+          2 /* substring */,
+          /*isCaseSensitive*/
+          true
+        );
+      }
+      if (chunk.characterSpans.length > 0) {
+        const candidateParts = getWordSpans(candidate, stringToWordSpans);
+        const isCaseSensitive = tryCamelCaseMatch(
+          candidate,
+          candidateParts,
+          chunk,
+          /*ignoreCase*/
+          false
+        ) ? true : tryCamelCaseMatch(
+          candidate,
+          candidateParts,
+          chunk,
+          /*ignoreCase*/
+          true
+        ) ? false : void 0;
+        if (isCaseSensitive !== void 0) {
+          return createPatternMatch(3 /* camelCase */, isCaseSensitive);
+        }
       }
-      const checker = (isFromPackageJson ? host.getPackageJsonAutoImportProvider() : host.getCurrentProgram()).getTypeChecker();
-      const moduleSymbol = info.moduleSymbol || cachedModuleSymbol || Debug.checkDefined(info.moduleFile ? checker.getMergedSymbol(info.moduleFile.symbol) : checker.tryFindAmbientModule(info.moduleName));
-      const symbol = info.symbol || cachedSymbol || Debug.checkDefined(
-        exportKind === 2 /* ExportEquals */ ? checker.resolveExternalModuleSymbol(moduleSymbol) : checker.tryGetMemberInModuleExportsAndProperties(unescapeLeadingUnderscores(info.symbolTableKey), moduleSymbol),
-        `Could not find symbol '${info.symbolName}' by key '${info.symbolTableKey}' in module ${moduleSymbol.name}`
-      );
-      symbols.set(id, [symbol, moduleSymbol]);
-      return {
-        symbol,
-        moduleSymbol,
-        moduleFileName,
-        exportKind,
-        targetFlags,
-        isFromPackageJson
-      };
-    }
-    function key(importedName, symbol, ambientModuleName, checker) {
-      const moduleKey = ambientModuleName || "";
-      return `${importedName}|${getSymbolId(skipAlias(symbol, checker))}|${moduleKey}`;
     }
-    function parseKey(key2) {
-      const symbolName2 = key2.substring(0, key2.indexOf("|"));
-      const moduleKey = key2.substring(key2.lastIndexOf("|") + 1);
-      const ambientModuleName = moduleKey === "" ? void 0 : moduleKey;
-      return { symbolName: symbolName2, ambientModuleName };
+  }
+  function matchSegment(candidate, segment, stringToWordSpans) {
+    if (every2(segment.totalTextChunk.text, (ch) => ch !== 32 /* space */ && ch !== 42 /* asterisk */)) {
+      const match = matchTextChunk(candidate, segment.totalTextChunk, stringToWordSpans);
+      if (match)
+        return match;
     }
-    function fileIsGlobalOnly(file) {
-      return !file.commonJsModuleIndicator && !file.externalModuleIndicator && !file.moduleAugmentations && !file.ambientModuleNames;
+    const subWordTextChunks = segment.subWordTextChunks;
+    let bestMatch;
+    for (const subWordTextChunk of subWordTextChunks) {
+      bestMatch = betterMatch(bestMatch, matchTextChunk(candidate, subWordTextChunk, stringToWordSpans));
     }
-    function ambientModuleDeclarationsAreEqual(oldSourceFile, newSourceFile) {
-      if (!arrayIsEqualTo(oldSourceFile.ambientModuleNames, newSourceFile.ambientModuleNames)) {
+    return bestMatch;
+  }
+  function betterMatch(a, b) {
+    return min([a, b], compareMatches);
+  }
+  function compareMatches(a, b) {
+    return a === void 0 ? 1 /* GreaterThan */ : b === void 0 ? -1 /* LessThan */ : compareValues(a.kind, b.kind) || compareBooleans(!a.isCaseSensitive, !b.isCaseSensitive);
+  }
+  function partStartsWith(candidate, candidateSpan, pattern, ignoreCase, patternSpan = { start: 0, length: pattern.length }) {
+    return patternSpan.length <= candidateSpan.length && everyInRange(0, patternSpan.length, (i) => equalChars(pattern.charCodeAt(patternSpan.start + i), candidate.charCodeAt(candidateSpan.start + i), ignoreCase));
+  }
+  function equalChars(ch1, ch2, ignoreCase) {
+    return ignoreCase ? toLowerCase2(ch1) === toLowerCase2(ch2) : ch1 === ch2;
+  }
+  function tryCamelCaseMatch(candidate, candidateParts, chunk, ignoreCase) {
+    const chunkCharacterSpans = chunk.characterSpans;
+    let currentCandidate = 0;
+    let currentChunkSpan = 0;
+    let firstMatch;
+    let contiguous;
+    while (true) {
+      if (currentChunkSpan === chunkCharacterSpans.length) {
+        return true;
+      } else if (currentCandidate === candidateParts.length) {
         return false;
       }
-      let oldFileStatementIndex = -1;
-      let newFileStatementIndex = -1;
-      for (const ambientModuleName of newSourceFile.ambientModuleNames) {
-        const isMatchingModuleDeclaration = (node) => isNonGlobalAmbientModule(node) && node.name.text === ambientModuleName;
-        oldFileStatementIndex = findIndex(oldSourceFile.statements, isMatchingModuleDeclaration, oldFileStatementIndex + 1);
-        newFileStatementIndex = findIndex(newSourceFile.statements, isMatchingModuleDeclaration, newFileStatementIndex + 1);
-        if (oldSourceFile.statements[oldFileStatementIndex] !== newSourceFile.statements[newFileStatementIndex]) {
-          return false;
+      let candidatePart = candidateParts[currentCandidate];
+      let gotOneMatchThisCandidate = false;
+      for (; currentChunkSpan < chunkCharacterSpans.length; currentChunkSpan++) {
+        const chunkCharacterSpan = chunkCharacterSpans[currentChunkSpan];
+        if (gotOneMatchThisCandidate) {
+          if (!isUpperCaseLetter(chunk.text.charCodeAt(chunkCharacterSpans[currentChunkSpan - 1].start)) || !isUpperCaseLetter(chunk.text.charCodeAt(chunkCharacterSpans[currentChunkSpan].start))) {
+            break;
+          }
         }
+        if (!partStartsWith(candidate, candidatePart, chunk.text, ignoreCase, chunkCharacterSpan)) {
+          break;
+        }
+        gotOneMatchThisCandidate = true;
+        firstMatch = firstMatch === void 0 ? currentCandidate : firstMatch;
+        contiguous = contiguous === void 0 ? true : contiguous;
+        candidatePart = createTextSpan(candidatePart.start + chunkCharacterSpan.length, candidatePart.length - chunkCharacterSpan.length);
+      }
+      if (!gotOneMatchThisCandidate && contiguous !== void 0) {
+        contiguous = false;
       }
+      currentCandidate++;
+    }
+  }
+  function createSegment(text) {
+    return {
+      totalTextChunk: createTextChunk(text),
+      subWordTextChunks: breakPatternIntoTextChunks(text)
+    };
+  }
+  function isUpperCaseLetter(ch) {
+    if (ch >= 65 /* A */ && ch <= 90 /* Z */) {
       return true;
     }
-    function isNotShadowedByDeeperNodeModulesPackage(info, packageName) {
-      if (!packageName || !info.moduleFileName)
-        return true;
-      const typingsCacheLocation = host.getGlobalTypingsCacheLocation();
-      if (typingsCacheLocation && startsWith(info.moduleFileName, typingsCacheLocation))
-        return true;
-      const packageDeepestNodeModulesPath = packages.get(packageName);
-      return !packageDeepestNodeModulesPath || startsWith(info.moduleFileName, packageDeepestNodeModulesPath);
+    if (ch < 127 /* maxAsciiCharacter */ || !isUnicodeIdentifierStart(ch, 99 /* Latest */)) {
+      return false;
     }
+    const str = String.fromCharCode(ch);
+    return str === str.toUpperCase();
   }
-  function isImportableFile(program, from, to, preferences, packageJsonFilter, moduleSpecifierResolutionHost, moduleSpecifierCache) {
-    var _a;
-    if (from === to)
+  function isLowerCaseLetter(ch) {
+    if (ch >= 97 /* a */ && ch <= 122 /* z */) {
+      return true;
+    }
+    if (ch < 127 /* maxAsciiCharacter */ || !isUnicodeIdentifierStart(ch, 99 /* Latest */)) {
       return false;
-    const cachedResult = moduleSpecifierCache == null ? void 0 : moduleSpecifierCache.get(from.path, to.path, preferences, {});
-    if ((cachedResult == null ? void 0 : cachedResult.isBlockedByPackageJsonDependencies) !== void 0) {
-      return !cachedResult.isBlockedByPackageJsonDependencies;
     }
-    const getCanonicalFileName = hostGetCanonicalFileName(moduleSpecifierResolutionHost);
-    const globalTypingsCache = (_a = moduleSpecifierResolutionHost.getGlobalTypingsCacheLocation) == null ? void 0 : _a.call(moduleSpecifierResolutionHost);
-    const hasImportablePath = !!ts_moduleSpecifiers_exports.forEachFileNameOfModule(
-      from.fileName,
-      to.fileName,
-      moduleSpecifierResolutionHost,
-      /*preferSymlinks*/
-      false,
-      (toPath3) => {
-        const toFile = program.getSourceFile(toPath3);
-        return (toFile === to || !toFile) && isImportablePath(from.fileName, toPath3, getCanonicalFileName, globalTypingsCache);
+    const str = String.fromCharCode(ch);
+    return str === str.toLowerCase();
+  }
+  function indexOfIgnoringCase(str, value) {
+    const n = str.length - value.length;
+    for (let start = 0; start <= n; start++) {
+      if (every2(value, (valueChar, i) => toLowerCase2(str.charCodeAt(i + start)) === valueChar)) {
+        return start;
       }
-    );
-    if (packageJsonFilter) {
-      const isAutoImportable = hasImportablePath && packageJsonFilter.allowsImportingSourceFile(to, moduleSpecifierResolutionHost);
-      moduleSpecifierCache == null ? void 0 : moduleSpecifierCache.setBlockedByPackageJsonDependencies(from.path, to.path, preferences, {}, !isAutoImportable);
-      return isAutoImportable;
     }
-    return hasImportablePath;
-  }
-  function isImportablePath(fromPath, toPath3, getCanonicalFileName, globalCachePath) {
-    const toNodeModules = forEachAncestorDirectory(toPath3, (ancestor) => getBaseFileName(ancestor) === "node_modules" ? ancestor : void 0);
-    const toNodeModulesParent = toNodeModules && getDirectoryPath(getCanonicalFileName(toNodeModules));
-    return toNodeModulesParent === void 0 || startsWith(getCanonicalFileName(fromPath), toNodeModulesParent) || !!globalCachePath && startsWith(getCanonicalFileName(globalCachePath), toNodeModulesParent);
+    return -1;
   }
-  function forEachExternalModuleToImportFrom(program, host, preferences, useAutoImportProvider, cb) {
-    var _a, _b;
-    const useCaseSensitiveFileNames = hostUsesCaseSensitiveFileNames(host);
-    const excludePatterns = preferences.autoImportFileExcludePatterns && mapDefined(preferences.autoImportFileExcludePatterns, (spec) => {
-      const pattern = getPatternFromSpec(spec, "", "exclude");
-      return pattern ? getRegexFromPattern(pattern, useCaseSensitiveFileNames) : void 0;
-    });
-    forEachExternalModule(program.getTypeChecker(), program.getSourceFiles(), excludePatterns, (module2, file) => cb(
-      module2,
-      file,
-      program,
-      /*isFromPackageJson*/
-      false
-    ));
-    const autoImportProvider = useAutoImportProvider && ((_a = host.getPackageJsonAutoImportProvider) == null ? void 0 : _a.call(host));
-    if (autoImportProvider) {
-      const start = timestamp();
-      const checker = program.getTypeChecker();
-      forEachExternalModule(autoImportProvider.getTypeChecker(), autoImportProvider.getSourceFiles(), excludePatterns, (module2, file) => {
-        if (file && !program.getSourceFile(file.fileName) || !file && !checker.resolveName(
-          module2.name,
-          /*location*/
-          void 0,
-          1536 /* Module */,
-          /*excludeGlobals*/
-          false
-        )) {
-          cb(
-            module2,
-            file,
-            autoImportProvider,
-            /*isFromPackageJson*/
-            true
-          );
-        }
-      });
-      (_b = host.log) == null ? void 0 : _b.call(host, `forEachExternalModuleToImportFrom autoImportProvider: ${timestamp() - start}`);
+  function toLowerCase2(ch) {
+    if (ch >= 65 /* A */ && ch <= 90 /* Z */) {
+      return 97 /* a */ + (ch - 65 /* A */);
+    }
+    if (ch < 127 /* maxAsciiCharacter */) {
+      return ch;
     }
+    return String.fromCharCode(ch).toLowerCase().charCodeAt(0);
   }
-  function forEachExternalModule(checker, allSourceFiles, excludePatterns, cb) {
-    var _a;
-    const isExcluded = excludePatterns && ((fileName) => excludePatterns.some((p) => p.test(fileName)));
-    for (const ambient of checker.getAmbientModules()) {
-      if (!stringContains(ambient.name, "*") && !(excludePatterns && ((_a = ambient.declarations) == null ? void 0 : _a.every((d) => isExcluded(d.getSourceFile().fileName))))) {
-        cb(
-          ambient,
-          /*sourceFile*/
-          void 0
-        );
+  function isDigit2(ch) {
+    return ch >= 48 /* _0 */ && ch <= 57 /* _9 */;
+  }
+  function isWordChar(ch) {
+    return isUpperCaseLetter(ch) || isLowerCaseLetter(ch) || isDigit2(ch) || ch === 95 /* _ */ || ch === 36 /* $ */;
+  }
+  function breakPatternIntoTextChunks(pattern) {
+    const result = [];
+    let wordStart = 0;
+    let wordLength = 0;
+    for (let i = 0; i < pattern.length; i++) {
+      const ch = pattern.charCodeAt(i);
+      if (isWordChar(ch)) {
+        if (wordLength === 0) {
+          wordStart = i;
+        }
+        wordLength++;
+      } else {
+        if (wordLength > 0) {
+          result.push(createTextChunk(pattern.substr(wordStart, wordLength)));
+          wordLength = 0;
+        }
       }
     }
-    for (const sourceFile of allSourceFiles) {
-      if (isExternalOrCommonJsModule(sourceFile) && !(isExcluded == null ? void 0 : isExcluded(sourceFile.fileName))) {
-        cb(checker.getMergedSymbol(sourceFile.symbol), sourceFile);
-      }
+    if (wordLength > 0) {
+      result.push(createTextChunk(pattern.substr(wordStart, wordLength)));
     }
+    return result;
   }
-  function getExportInfoMap(importingFile, host, program, preferences, cancellationToken) {
-    var _a, _b, _c, _d, _e;
-    const start = timestamp();
-    (_a = host.getPackageJsonAutoImportProvider) == null ? void 0 : _a.call(host);
-    const cache = ((_b = host.getCachedExportInfoMap) == null ? void 0 : _b.call(host)) || createCacheableExportInfoMap({
-      getCurrentProgram: () => program,
-      getPackageJsonAutoImportProvider: () => {
-        var _a2;
-        return (_a2 = host.getPackageJsonAutoImportProvider) == null ? void 0 : _a2.call(host);
-      },
-      getGlobalTypingsCacheLocation: () => {
-        var _a2;
-        return (_a2 = host.getGlobalTypingsCacheLocation) == null ? void 0 : _a2.call(host);
+  function createTextChunk(text) {
+    const textLowerCase = text.toLowerCase();
+    return {
+      text,
+      textLowerCase,
+      isLowerCase: text === textLowerCase,
+      characterSpans: breakIntoCharacterSpans(text)
+    };
+  }
+  function breakIntoCharacterSpans(identifier) {
+    return breakIntoSpans(
+      identifier,
+      /*word*/
+      false
+    );
+  }
+  function breakIntoWordSpans(identifier) {
+    return breakIntoSpans(
+      identifier,
+      /*word*/
+      true
+    );
+  }
+  function breakIntoSpans(identifier, word) {
+    const result = [];
+    let wordStart = 0;
+    for (let i = 1; i < identifier.length; i++) {
+      const lastIsDigit = isDigit2(identifier.charCodeAt(i - 1));
+      const currentIsDigit = isDigit2(identifier.charCodeAt(i));
+      const hasTransitionFromLowerToUpper = transitionFromLowerToUpper(identifier, word, i);
+      const hasTransitionFromUpperToLower = word && transitionFromUpperToLower(identifier, i, wordStart);
+      if (charIsPunctuation(identifier.charCodeAt(i - 1)) || charIsPunctuation(identifier.charCodeAt(i)) || lastIsDigit !== currentIsDigit || hasTransitionFromLowerToUpper || hasTransitionFromUpperToLower) {
+        if (!isAllPunctuation(identifier, wordStart, i)) {
+          result.push(createTextSpan(wordStart, i - wordStart));
+        }
+        wordStart = i;
       }
-    });
-    if (cache.isUsableByFile(importingFile.path)) {
-      (_c = host.log) == null ? void 0 : _c.call(host, "getExportInfoMap: cache hit");
-      return cache;
     }
-    (_d = host.log) == null ? void 0 : _d.call(host, "getExportInfoMap: cache miss or empty; calculating new results");
-    const compilerOptions = program.getCompilerOptions();
-    let moduleCount = 0;
-    try {
-      forEachExternalModuleToImportFrom(
-        program,
-        host,
-        preferences,
-        /*useAutoImportProvider*/
-        true,
-        (moduleSymbol, moduleFile, program2, isFromPackageJson) => {
-          if (++moduleCount % 100 === 0)
-            cancellationToken == null ? void 0 : cancellationToken.throwIfCancellationRequested();
-          const seenExports = /* @__PURE__ */ new Map();
-          const checker = program2.getTypeChecker();
-          const defaultInfo = getDefaultLikeExportInfo(moduleSymbol, checker, compilerOptions);
-          if (defaultInfo && isImportableSymbol(defaultInfo.symbol, checker)) {
-            cache.add(
-              importingFile.path,
-              defaultInfo.symbol,
-              defaultInfo.exportKind === 1 /* Default */ ? "default" /* Default */ : "export=" /* ExportEquals */,
-              moduleSymbol,
-              moduleFile,
-              defaultInfo.exportKind,
-              isFromPackageJson,
-              checker
-            );
-          }
-          checker.forEachExportAndPropertyOfModule(moduleSymbol, (exported, key) => {
-            if (exported !== (defaultInfo == null ? void 0 : defaultInfo.symbol) && isImportableSymbol(exported, checker) && addToSeen(seenExports, key)) {
-              cache.add(
-                importingFile.path,
-                exported,
-                key,
-                moduleSymbol,
-                moduleFile,
-                0 /* Named */,
-                isFromPackageJson,
-                checker
-              );
-            }
-          });
-        }
-      );
-    } catch (err) {
-      cache.clear();
-      throw err;
+    if (!isAllPunctuation(identifier, wordStart, identifier.length)) {
+      result.push(createTextSpan(wordStart, identifier.length - wordStart));
     }
-    (_e = host.log) == null ? void 0 : _e.call(host, `getExportInfoMap: done in ${timestamp() - start} ms`);
-    return cache;
+    return result;
   }
-  function getDefaultLikeExportInfo(moduleSymbol, checker, compilerOptions) {
-    const exported = getDefaultLikeExportWorker(moduleSymbol, checker);
-    if (!exported)
-      return void 0;
-    const { symbol, exportKind } = exported;
-    const info = getDefaultExportInfoWorker(symbol, checker, compilerOptions);
-    return info && { symbol, exportKind, ...info };
+  function charIsPunctuation(ch) {
+    switch (ch) {
+      case 33 /* exclamation */:
+      case 34 /* doubleQuote */:
+      case 35 /* hash */:
+      case 37 /* percent */:
+      case 38 /* ampersand */:
+      case 39 /* singleQuote */:
+      case 40 /* openParen */:
+      case 41 /* closeParen */:
+      case 42 /* asterisk */:
+      case 44 /* comma */:
+      case 45 /* minus */:
+      case 46 /* dot */:
+      case 47 /* slash */:
+      case 58 /* colon */:
+      case 59 /* semicolon */:
+      case 63 /* question */:
+      case 64 /* at */:
+      case 91 /* openBracket */:
+      case 92 /* backslash */:
+      case 93 /* closeBracket */:
+      case 95 /* _ */:
+      case 123 /* openBrace */:
+      case 125 /* closeBrace */:
+        return true;
+    }
+    return false;
   }
-  function isImportableSymbol(symbol, checker) {
-    return !checker.isUndefinedSymbol(symbol) && !checker.isUnknownSymbol(symbol) && !isKnownSymbol(symbol) && !isPrivateIdentifierSymbol(symbol);
+  function isAllPunctuation(identifier, start, end) {
+    return every2(identifier, (ch) => charIsPunctuation(ch) && ch !== 95 /* _ */, start, end);
   }
-  function getDefaultLikeExportWorker(moduleSymbol, checker) {
-    const exportEquals = checker.resolveExternalModuleSymbol(moduleSymbol);
-    if (exportEquals !== moduleSymbol)
-      return { symbol: exportEquals, exportKind: 2 /* ExportEquals */ };
-    const defaultExport = checker.tryGetMemberInModuleExports("default" /* Default */, moduleSymbol);
-    if (defaultExport)
-      return { symbol: defaultExport, exportKind: 1 /* Default */ };
+  function transitionFromUpperToLower(identifier, index, wordStart) {
+    return index !== wordStart && index + 1 < identifier.length && isUpperCaseLetter(identifier.charCodeAt(index)) && isLowerCaseLetter(identifier.charCodeAt(index + 1)) && every2(identifier, isUpperCaseLetter, wordStart, index);
   }
-  function getDefaultExportInfoWorker(defaultExport, checker, compilerOptions) {
-    const localSymbol = getLocalSymbolForExportDefault(defaultExport);
-    if (localSymbol)
-      return { resolvedSymbol: localSymbol, name: localSymbol.name };
-    const name = getNameForExportDefault(defaultExport);
-    if (name !== void 0)
-      return { resolvedSymbol: defaultExport, name };
-    if (defaultExport.flags & 2097152 /* Alias */) {
-      const aliased = checker.getImmediateAliasedSymbol(defaultExport);
-      if (aliased && aliased.parent) {
-        return getDefaultExportInfoWorker(aliased, checker, compilerOptions);
+  function transitionFromLowerToUpper(identifier, word, index) {
+    const lastIsUpper = isUpperCaseLetter(identifier.charCodeAt(index - 1));
+    const currentIsUpper = isUpperCaseLetter(identifier.charCodeAt(index));
+    return currentIsUpper && (!word || !lastIsUpper);
+  }
+  function everyInRange(start, end, pred) {
+    for (let i = start; i < end; i++) {
+      if (!pred(i)) {
+        return false;
       }
     }
-    if (defaultExport.escapedName !== "default" /* Default */ && defaultExport.escapedName !== "export=" /* ExportEquals */) {
-      return { resolvedSymbol: defaultExport, name: defaultExport.getName() };
-    }
-    return { resolvedSymbol: defaultExport, name: getNameForExportedSymbol(defaultExport, compilerOptions.target) };
+    return true;
   }
-  function getNameForExportDefault(symbol) {
-    return symbol.declarations && firstDefined(symbol.declarations, (declaration) => {
-      var _a;
-      if (isExportAssignment(declaration)) {
-        return (_a = tryCast(skipOuterExpressions(declaration.expression), isIdentifier)) == null ? void 0 : _a.text;
-      } else if (isExportSpecifier(declaration)) {
-        Debug.assert(declaration.name.text === "default" /* Default */, "Expected the specifier to be a default export");
-        return declaration.propertyName && declaration.propertyName.text;
-      }
-    });
+  function every2(s, pred, start = 0, end = s.length) {
+    return everyInRange(start, end, (i) => pred(s.charCodeAt(i), i));
   }
-  var ImportKind, ExportKind;
-  var init_exportInfoMap = __esm({
-    "src/services/exportInfoMap.ts"() {
+  var PatternMatchKind;
+  var init_patternMatcher = __esm({
+    "src/services/patternMatcher.ts"() {
       "use strict";
       init_ts4();
-      ImportKind = /* @__PURE__ */ ((ImportKind2) => {
-        ImportKind2[ImportKind2["Named"] = 0] = "Named";
-        ImportKind2[ImportKind2["Default"] = 1] = "Default";
-        ImportKind2[ImportKind2["Namespace"] = 2] = "Namespace";
-        ImportKind2[ImportKind2["CommonJS"] = 3] = "CommonJS";
-        return ImportKind2;
-      })(ImportKind || {});
-      ExportKind = /* @__PURE__ */ ((ExportKind3) => {
-        ExportKind3[ExportKind3["Named"] = 0] = "Named";
-        ExportKind3[ExportKind3["Default"] = 1] = "Default";
-        ExportKind3[ExportKind3["ExportEquals"] = 2] = "ExportEquals";
-        ExportKind3[ExportKind3["UMD"] = 3] = "UMD";
-        return ExportKind3;
-      })(ExportKind || {});
+      PatternMatchKind = /* @__PURE__ */ ((PatternMatchKind2) => {
+        PatternMatchKind2[PatternMatchKind2["exact"] = 0] = "exact";
+        PatternMatchKind2[PatternMatchKind2["prefix"] = 1] = "prefix";
+        PatternMatchKind2[PatternMatchKind2["substring"] = 2] = "substring";
+        PatternMatchKind2[PatternMatchKind2["camelCase"] = 3] = "camelCase";
+        return PatternMatchKind2;
+      })(PatternMatchKind || {});
     }
   });
 
-  // src/services/classifier.ts
-  function createClassifier() {
-    const scanner2 = createScanner(
-      99 /* Latest */,
-      /*skipTrivia*/
-      false
-    );
-    function getClassificationsForLine(text, lexState, syntacticClassifierAbsent) {
-      return convertClassificationsToResult(getEncodedLexicalClassifications(text, lexState, syntacticClassifierAbsent), text);
+  // src/services/preProcess.ts
+  function preProcessFile(sourceText, readImportFiles = true, detectJavaScriptImports = false) {
+    const pragmaContext = {
+      languageVersion: 1 /* ES5 */,
+      // controls whether the token scanner considers unicode identifiers or not - shouldn't matter, since we're only using it for trivia
+      pragmas: void 0,
+      checkJsDirective: void 0,
+      referencedFiles: [],
+      typeReferenceDirectives: [],
+      libReferenceDirectives: [],
+      amdDependencies: [],
+      hasNoDefaultLib: void 0,
+      moduleName: void 0
+    };
+    const importedFiles = [];
+    let ambientExternalModules;
+    let lastToken;
+    let currentToken;
+    let braceNesting = 0;
+    let externalModule = false;
+    function nextToken() {
+      lastToken = currentToken;
+      currentToken = scanner.scan();
+      if (currentToken === 19 /* OpenBraceToken */) {
+        braceNesting++;
+      } else if (currentToken === 20 /* CloseBraceToken */) {
+        braceNesting--;
+      }
+      return currentToken;
     }
-    function getEncodedLexicalClassifications(text, lexState, syntacticClassifierAbsent) {
-      let token = 0 /* Unknown */;
-      let lastNonTriviaToken = 0 /* Unknown */;
-      const templateStack = [];
-      const { prefix, pushTemplate } = getPrefixFromLexState(lexState);
-      text = prefix + text;
-      const offset = prefix.length;
-      if (pushTemplate) {
-        templateStack.push(16 /* TemplateHead */);
+    function getFileReference() {
+      const fileName = scanner.getTokenValue();
+      const pos = scanner.getTokenStart();
+      return { fileName, pos, end: pos + fileName.length };
+    }
+    function recordAmbientExternalModule() {
+      if (!ambientExternalModules) {
+        ambientExternalModules = [];
       }
-      scanner2.setText(text);
-      let endOfLineState = 0 /* None */;
-      const spans = [];
-      let angleBracketStack = 0;
-      do {
-        token = scanner2.scan();
-        if (!isTrivia(token)) {
-          handleToken();
-          lastNonTriviaToken = token;
-        }
-        const end = scanner2.getTokenEnd();
-        pushEncodedClassification(scanner2.getTokenStart(), end, offset, classFromKind(token), spans);
-        if (end >= text.length) {
-          const end2 = getNewEndOfLineState(scanner2, token, lastOrUndefined(templateStack));
-          if (end2 !== void 0) {
-            endOfLineState = end2;
+      ambientExternalModules.push({ ref: getFileReference(), depth: braceNesting });
+    }
+    function recordModuleName() {
+      importedFiles.push(getFileReference());
+      markAsExternalModuleIfTopLevel();
+    }
+    function markAsExternalModuleIfTopLevel() {
+      if (braceNesting === 0) {
+        externalModule = true;
+      }
+    }
+    function tryConsumeDeclare() {
+      let token = scanner.getToken();
+      if (token === 138 /* DeclareKeyword */) {
+        token = nextToken();
+        if (token === 144 /* ModuleKeyword */) {
+          token = nextToken();
+          if (token === 11 /* StringLiteral */) {
+            recordAmbientExternalModule();
           }
         }
-      } while (token !== 1 /* EndOfFileToken */);
-      function handleToken() {
-        switch (token) {
-          case 44 /* SlashToken */:
-          case 69 /* SlashEqualsToken */:
-            if (!noRegexTable[lastNonTriviaToken] && scanner2.reScanSlashToken() === 14 /* RegularExpressionLiteral */) {
-              token = 14 /* RegularExpressionLiteral */;
-            }
-            break;
-          case 30 /* LessThanToken */:
-            if (lastNonTriviaToken === 80 /* Identifier */) {
-              angleBracketStack++;
+        return true;
+      }
+      return false;
+    }
+    function tryConsumeImport() {
+      if (lastToken === 25 /* DotToken */) {
+        return false;
+      }
+      let token = scanner.getToken();
+      if (token === 102 /* ImportKeyword */) {
+        token = nextToken();
+        if (token === 21 /* OpenParenToken */) {
+          token = nextToken();
+          if (token === 11 /* StringLiteral */ || token === 15 /* NoSubstitutionTemplateLiteral */) {
+            recordModuleName();
+            return true;
+          }
+        } else if (token === 11 /* StringLiteral */) {
+          recordModuleName();
+          return true;
+        } else {
+          if (token === 156 /* TypeKeyword */) {
+            const skipTypeKeyword = scanner.lookAhead(() => {
+              const token2 = scanner.scan();
+              return token2 !== 161 /* FromKeyword */ && (token2 === 42 /* AsteriskToken */ || token2 === 19 /* OpenBraceToken */ || token2 === 80 /* Identifier */ || isKeyword(token2));
+            });
+            if (skipTypeKeyword) {
+              token = nextToken();
             }
-            break;
-          case 32 /* GreaterThanToken */:
-            if (angleBracketStack > 0) {
-              angleBracketStack--;
+          }
+          if (token === 80 /* Identifier */ || isKeyword(token)) {
+            token = nextToken();
+            if (token === 161 /* FromKeyword */) {
+              token = nextToken();
+              if (token === 11 /* StringLiteral */) {
+                recordModuleName();
+                return true;
+              }
+            } else if (token === 64 /* EqualsToken */) {
+              if (tryConsumeRequireCall(
+                /*skipCurrentToken*/
+                true
+              )) {
+                return true;
+              }
+            } else if (token === 28 /* CommaToken */) {
+              token = nextToken();
+            } else {
+              return true;
             }
-            break;
-          case 133 /* AnyKeyword */:
-          case 154 /* StringKeyword */:
-          case 150 /* NumberKeyword */:
-          case 136 /* BooleanKeyword */:
-          case 155 /* SymbolKeyword */:
-            if (angleBracketStack > 0 && !syntacticClassifierAbsent) {
-              token = 80 /* Identifier */;
+          }
+          if (token === 19 /* OpenBraceToken */) {
+            token = nextToken();
+            while (token !== 20 /* CloseBraceToken */ && token !== 1 /* EndOfFileToken */) {
+              token = nextToken();
             }
-            break;
-          case 16 /* TemplateHead */:
-            templateStack.push(token);
-            break;
-          case 19 /* OpenBraceToken */:
-            if (templateStack.length > 0) {
-              templateStack.push(token);
+            if (token === 20 /* CloseBraceToken */) {
+              token = nextToken();
+              if (token === 161 /* FromKeyword */) {
+                token = nextToken();
+                if (token === 11 /* StringLiteral */) {
+                  recordModuleName();
+                }
+              }
             }
-            break;
-          case 20 /* CloseBraceToken */:
-            if (templateStack.length > 0) {
-              const lastTemplateStackToken = lastOrUndefined(templateStack);
-              if (lastTemplateStackToken === 16 /* TemplateHead */) {
-                token = scanner2.reScanTemplateToken(
-                  /*isTaggedTemplate*/
-                  false
-                );
-                if (token === 18 /* TemplateTail */) {
-                  templateStack.pop();
-                } else {
-                  Debug.assertEqual(token, 17 /* TemplateMiddle */, "Should have been a template middle.");
+          } else if (token === 42 /* AsteriskToken */) {
+            token = nextToken();
+            if (token === 130 /* AsKeyword */) {
+              token = nextToken();
+              if (token === 80 /* Identifier */ || isKeyword(token)) {
+                token = nextToken();
+                if (token === 161 /* FromKeyword */) {
+                  token = nextToken();
+                  if (token === 11 /* StringLiteral */) {
+                    recordModuleName();
+                  }
                 }
-              } else {
-                Debug.assertEqual(lastTemplateStackToken, 19 /* OpenBraceToken */, "Should have been an open brace");
-                templateStack.pop();
               }
             }
-            break;
-          default:
-            if (!isKeyword(token)) {
-              break;
+          }
+        }
+        return true;
+      }
+      return false;
+    }
+    function tryConsumeExport() {
+      let token = scanner.getToken();
+      if (token === 95 /* ExportKeyword */) {
+        markAsExternalModuleIfTopLevel();
+        token = nextToken();
+        if (token === 156 /* TypeKeyword */) {
+          const skipTypeKeyword = scanner.lookAhead(() => {
+            const token2 = scanner.scan();
+            return token2 === 42 /* AsteriskToken */ || token2 === 19 /* OpenBraceToken */;
+          });
+          if (skipTypeKeyword) {
+            token = nextToken();
+          }
+        }
+        if (token === 19 /* OpenBraceToken */) {
+          token = nextToken();
+          while (token !== 20 /* CloseBraceToken */ && token !== 1 /* EndOfFileToken */) {
+            token = nextToken();
+          }
+          if (token === 20 /* CloseBraceToken */) {
+            token = nextToken();
+            if (token === 161 /* FromKeyword */) {
+              token = nextToken();
+              if (token === 11 /* StringLiteral */) {
+                recordModuleName();
+              }
             }
-            if (lastNonTriviaToken === 25 /* DotToken */) {
-              token = 80 /* Identifier */;
-            } else if (isKeyword(lastNonTriviaToken) && isKeyword(token) && !canFollow(lastNonTriviaToken, token)) {
-              token = 80 /* Identifier */;
+          }
+        } else if (token === 42 /* AsteriskToken */) {
+          token = nextToken();
+          if (token === 161 /* FromKeyword */) {
+            token = nextToken();
+            if (token === 11 /* StringLiteral */) {
+              recordModuleName();
+            }
+          }
+        } else if (token === 102 /* ImportKeyword */) {
+          token = nextToken();
+          if (token === 156 /* TypeKeyword */) {
+            const skipTypeKeyword = scanner.lookAhead(() => {
+              const token2 = scanner.scan();
+              return token2 === 80 /* Identifier */ || isKeyword(token2);
+            });
+            if (skipTypeKeyword) {
+              token = nextToken();
+            }
+          }
+          if (token === 80 /* Identifier */ || isKeyword(token)) {
+            token = nextToken();
+            if (token === 64 /* EqualsToken */) {
+              if (tryConsumeRequireCall(
+                /*skipCurrentToken*/
+                true
+              )) {
+                return true;
+              }
             }
+          }
         }
+        return true;
       }
-      return { endOfLineState, spans };
+      return false;
     }
-    return { getClassificationsForLine, getEncodedLexicalClassifications };
-  }
-  function getNewEndOfLineState(scanner2, token, lastOnTemplateStack) {
-    switch (token) {
-      case 11 /* StringLiteral */: {
-        if (!scanner2.isUnterminated())
-          return void 0;
-        const tokenText = scanner2.getTokenText();
-        const lastCharIndex = tokenText.length - 1;
-        let numBackslashes = 0;
-        while (tokenText.charCodeAt(lastCharIndex - numBackslashes) === 92 /* backslash */) {
-          numBackslashes++;
+    function tryConsumeRequireCall(skipCurrentToken, allowTemplateLiterals = false) {
+      let token = skipCurrentToken ? nextToken() : scanner.getToken();
+      if (token === 149 /* RequireKeyword */) {
+        token = nextToken();
+        if (token === 21 /* OpenParenToken */) {
+          token = nextToken();
+          if (token === 11 /* StringLiteral */ || allowTemplateLiterals && token === 15 /* NoSubstitutionTemplateLiteral */) {
+            recordModuleName();
+          }
         }
-        if ((numBackslashes & 1) === 0)
-          return void 0;
-        return tokenText.charCodeAt(0) === 34 /* doubleQuote */ ? 3 /* InDoubleQuoteStringLiteral */ : 2 /* InSingleQuoteStringLiteral */;
+        return true;
       }
-      case 3 /* MultiLineCommentTrivia */:
-        return scanner2.isUnterminated() ? 1 /* InMultiLineCommentTrivia */ : void 0;
-      default:
-        if (isTemplateLiteralKind(token)) {
-          if (!scanner2.isUnterminated()) {
-            return void 0;
+      return false;
+    }
+    function tryConsumeDefine() {
+      let token = scanner.getToken();
+      if (token === 80 /* Identifier */ && scanner.getTokenValue() === "define") {
+        token = nextToken();
+        if (token !== 21 /* OpenParenToken */) {
+          return true;
+        }
+        token = nextToken();
+        if (token === 11 /* StringLiteral */ || token === 15 /* NoSubstitutionTemplateLiteral */) {
+          token = nextToken();
+          if (token === 28 /* CommaToken */) {
+            token = nextToken();
+          } else {
+            return true;
           }
-          switch (token) {
-            case 18 /* TemplateTail */:
-              return 5 /* InTemplateMiddleOrTail */;
-            case 15 /* NoSubstitutionTemplateLiteral */:
-              return 4 /* InTemplateHeadOrNoSubstitutionTemplate */;
-            default:
-              return Debug.fail("Only 'NoSubstitutionTemplateLiteral's and 'TemplateTail's can be unterminated; got SyntaxKind #" + token);
+        }
+        if (token !== 23 /* OpenBracketToken */) {
+          return true;
+        }
+        token = nextToken();
+        while (token !== 24 /* CloseBracketToken */ && token !== 1 /* EndOfFileToken */) {
+          if (token === 11 /* StringLiteral */ || token === 15 /* NoSubstitutionTemplateLiteral */) {
+            recordModuleName();
           }
+          token = nextToken();
         }
-        return lastOnTemplateStack === 16 /* TemplateHead */ ? 6 /* InTemplateSubstitutionPosition */ : void 0;
+        return true;
+      }
+      return false;
     }
-  }
-  function pushEncodedClassification(start, end, offset, classification, result) {
-    if (classification === 8 /* whiteSpace */) {
-      return;
+    function processImports() {
+      scanner.setText(sourceText);
+      nextToken();
+      while (true) {
+        if (scanner.getToken() === 1 /* EndOfFileToken */) {
+          break;
+        }
+        if (scanner.getToken() === 16 /* TemplateHead */) {
+          const stack = [scanner.getToken()];
+          loop:
+            while (length(stack)) {
+              const token = scanner.scan();
+              switch (token) {
+                case 1 /* EndOfFileToken */:
+                  break loop;
+                case 102 /* ImportKeyword */:
+                  tryConsumeImport();
+                  break;
+                case 16 /* TemplateHead */:
+                  stack.push(token);
+                  break;
+                case 19 /* OpenBraceToken */:
+                  if (length(stack)) {
+                    stack.push(token);
+                  }
+                  break;
+                case 20 /* CloseBraceToken */:
+                  if (length(stack)) {
+                    if (lastOrUndefined(stack) === 16 /* TemplateHead */) {
+                      if (scanner.reScanTemplateToken(
+                        /*isTaggedTemplate*/
+                        false
+                      ) === 18 /* TemplateTail */) {
+                        stack.pop();
+                      }
+                    } else {
+                      stack.pop();
+                    }
+                  }
+                  break;
+              }
+            }
+          nextToken();
+        }
+        if (tryConsumeDeclare() || tryConsumeImport() || tryConsumeExport() || detectJavaScriptImports && (tryConsumeRequireCall(
+          /*skipCurrentToken*/
+          false,
+          /*allowTemplateLiterals*/
+          true
+        ) || tryConsumeDefine())) {
+          continue;
+        } else {
+          nextToken();
+        }
+      }
+      scanner.setText(void 0);
     }
-    if (start === 0 && offset > 0) {
-      start += offset;
+    if (readImportFiles) {
+      processImports();
     }
-    const length2 = end - start;
-    if (length2 > 0) {
-      result.push(start - offset, length2, classification);
+    processCommentPragmas(pragmaContext, sourceText);
+    processPragmasIntoFields(pragmaContext, noop);
+    if (externalModule) {
+      if (ambientExternalModules) {
+        for (const decl of ambientExternalModules) {
+          importedFiles.push(decl.ref);
+        }
+      }
+      return { referencedFiles: pragmaContext.referencedFiles, typeReferenceDirectives: pragmaContext.typeReferenceDirectives, libReferenceDirectives: pragmaContext.libReferenceDirectives, importedFiles, isLibFile: !!pragmaContext.hasNoDefaultLib, ambientExternalModules: void 0 };
+    } else {
+      let ambientModuleNames;
+      if (ambientExternalModules) {
+        for (const decl of ambientExternalModules) {
+          if (decl.depth === 0) {
+            if (!ambientModuleNames) {
+              ambientModuleNames = [];
+            }
+            ambientModuleNames.push(decl.ref.fileName);
+          } else {
+            importedFiles.push(decl.ref);
+          }
+        }
+      }
+      return { referencedFiles: pragmaContext.referencedFiles, typeReferenceDirectives: pragmaContext.typeReferenceDirectives, libReferenceDirectives: pragmaContext.libReferenceDirectives, importedFiles, isLibFile: !!pragmaContext.hasNoDefaultLib, ambientExternalModules: ambientModuleNames };
     }
   }
-  function convertClassificationsToResult(classifications, text) {
-    const entries = [];
-    const dense = classifications.spans;
-    let lastEnd = 0;
-    for (let i = 0; i < dense.length; i += 3) {
-      const start = dense[i];
-      const length2 = dense[i + 1];
-      const type = dense[i + 2];
-      if (lastEnd >= 0) {
-        const whitespaceLength2 = start - lastEnd;
-        if (whitespaceLength2 > 0) {
-          entries.push({ length: whitespaceLength2, classification: 4 /* Whitespace */ });
-        }
+  var init_preProcess = __esm({
+    "src/services/preProcess.ts"() {
+      "use strict";
+      init_ts4();
+    }
+  });
+
+  // src/services/sourcemaps.ts
+  function getSourceMapper(host) {
+    const getCanonicalFileName = createGetCanonicalFileName(host.useCaseSensitiveFileNames());
+    const currentDirectory = host.getCurrentDirectory();
+    const sourceFileLike = /* @__PURE__ */ new Map();
+    const documentPositionMappers = /* @__PURE__ */ new Map();
+    return { tryGetSourcePosition, tryGetGeneratedPosition, toLineColumnOffset, clearCache };
+    function toPath3(fileName) {
+      return toPath(fileName, currentDirectory, getCanonicalFileName);
+    }
+    function getDocumentPositionMapper2(generatedFileName, sourceFileName) {
+      const path = toPath3(generatedFileName);
+      const value = documentPositionMappers.get(path);
+      if (value)
+        return value;
+      let mapper;
+      if (host.getDocumentPositionMapper) {
+        mapper = host.getDocumentPositionMapper(generatedFileName, sourceFileName);
+      } else if (host.readFile) {
+        const file = getSourceFileLike(generatedFileName);
+        mapper = file && getDocumentPositionMapper(
+          { getSourceFileLike, getCanonicalFileName, log: (s) => host.log(s) },
+          generatedFileName,
+          getLineInfo(file.text, getLineStarts(file)),
+          (f) => !host.fileExists || host.fileExists(f) ? host.readFile(f) : void 0
+        );
       }
-      entries.push({ length: length2, classification: convertClassification(type) });
-      lastEnd = start + length2;
+      documentPositionMappers.set(path, mapper || identitySourceMapConsumer);
+      return mapper || identitySourceMapConsumer;
     }
-    const whitespaceLength = text.length - lastEnd;
-    if (whitespaceLength > 0) {
-      entries.push({ length: whitespaceLength, classification: 4 /* Whitespace */ });
+    function tryGetSourcePosition(info) {
+      if (!isDeclarationFileName(info.fileName))
+        return void 0;
+      const file = getSourceFile(info.fileName);
+      if (!file)
+        return void 0;
+      const newLoc = getDocumentPositionMapper2(info.fileName).getSourcePosition(info);
+      return !newLoc || newLoc === info ? void 0 : tryGetSourcePosition(newLoc) || newLoc;
     }
-    return { entries, finalLexState: classifications.endOfLineState };
-  }
-  function convertClassification(type) {
-    switch (type) {
-      case 1 /* comment */:
-        return 3 /* Comment */;
-      case 3 /* keyword */:
-        return 1 /* Keyword */;
-      case 4 /* numericLiteral */:
-        return 6 /* NumberLiteral */;
-      case 25 /* bigintLiteral */:
-        return 7 /* BigIntLiteral */;
-      case 5 /* operator */:
-        return 2 /* Operator */;
-      case 6 /* stringLiteral */:
-        return 8 /* StringLiteral */;
-      case 8 /* whiteSpace */:
-        return 4 /* Whitespace */;
-      case 10 /* punctuation */:
-        return 0 /* Punctuation */;
-      case 2 /* identifier */:
-      case 11 /* className */:
-      case 12 /* enumName */:
-      case 13 /* interfaceName */:
-      case 14 /* moduleName */:
-      case 15 /* typeParameterName */:
-      case 16 /* typeAliasName */:
-      case 9 /* text */:
-      case 17 /* parameterName */:
-        return 5 /* Identifier */;
-      default:
+    function tryGetGeneratedPosition(info) {
+      if (isDeclarationFileName(info.fileName))
+        return void 0;
+      const sourceFile = getSourceFile(info.fileName);
+      if (!sourceFile)
+        return void 0;
+      const program = host.getProgram();
+      if (program.isSourceOfProjectReferenceRedirect(sourceFile.fileName)) {
+        return void 0;
+      }
+      const options = program.getCompilerOptions();
+      const outPath = outFile(options);
+      const declarationPath = outPath ? removeFileExtension(outPath) + ".d.ts" /* Dts */ : getDeclarationEmitOutputFilePathWorker(info.fileName, program.getCompilerOptions(), currentDirectory, program.getCommonSourceDirectory(), getCanonicalFileName);
+      if (declarationPath === void 0)
         return void 0;
+      const newLoc = getDocumentPositionMapper2(declarationPath, info.fileName).getGeneratedPosition(info);
+      return newLoc === info ? void 0 : newLoc;
     }
-  }
-  function canFollow(keyword1, keyword2) {
-    if (!isAccessibilityModifier(keyword1)) {
-      return true;
+    function getSourceFile(fileName) {
+      const program = host.getProgram();
+      if (!program)
+        return void 0;
+      const path = toPath3(fileName);
+      const file = program.getSourceFileByPath(path);
+      return file && file.resolvedPath === path ? file : void 0;
     }
-    switch (keyword2) {
-      case 139 /* GetKeyword */:
-      case 153 /* SetKeyword */:
-      case 137 /* ConstructorKeyword */:
-      case 126 /* StaticKeyword */:
-      case 129 /* AccessorKeyword */:
-        return true;
-      default:
-        return false;
+    function getOrCreateSourceFileLike(fileName) {
+      const path = toPath3(fileName);
+      const fileFromCache = sourceFileLike.get(path);
+      if (fileFromCache !== void 0)
+        return fileFromCache ? fileFromCache : void 0;
+      if (!host.readFile || host.fileExists && !host.fileExists(path)) {
+        sourceFileLike.set(path, false);
+        return void 0;
+      }
+      const text = host.readFile(path);
+      const file = text ? createSourceFileLike(text) : false;
+      sourceFileLike.set(path, file);
+      return file ? file : void 0;
     }
-  }
-  function getPrefixFromLexState(lexState) {
-    switch (lexState) {
-      case 3 /* InDoubleQuoteStringLiteral */:
-        return { prefix: '"\\\n' };
-      case 2 /* InSingleQuoteStringLiteral */:
-        return { prefix: "'\\\n" };
-      case 1 /* InMultiLineCommentTrivia */:
-        return { prefix: "/*\n" };
-      case 4 /* InTemplateHeadOrNoSubstitutionTemplate */:
-        return { prefix: "`\n" };
-      case 5 /* InTemplateMiddleOrTail */:
-        return { prefix: "}\n", pushTemplate: true };
-      case 6 /* InTemplateSubstitutionPosition */:
-        return { prefix: "", pushTemplate: true };
-      case 0 /* None */:
-        return { prefix: "" };
-      default:
-        return Debug.assertNever(lexState);
+    function getSourceFileLike(fileName) {
+      return !host.getSourceFileLike ? getSourceFile(fileName) || getOrCreateSourceFileLike(fileName) : host.getSourceFileLike(fileName);
     }
-  }
-  function isBinaryExpressionOperatorToken(token) {
-    switch (token) {
-      case 42 /* AsteriskToken */:
-      case 44 /* SlashToken */:
-      case 45 /* PercentToken */:
-      case 40 /* PlusToken */:
-      case 41 /* MinusToken */:
-      case 48 /* LessThanLessThanToken */:
-      case 49 /* GreaterThanGreaterThanToken */:
-      case 50 /* GreaterThanGreaterThanGreaterThanToken */:
-      case 30 /* LessThanToken */:
-      case 32 /* GreaterThanToken */:
-      case 33 /* LessThanEqualsToken */:
-      case 34 /* GreaterThanEqualsToken */:
-      case 104 /* InstanceOfKeyword */:
-      case 103 /* InKeyword */:
-      case 130 /* AsKeyword */:
-      case 152 /* SatisfiesKeyword */:
-      case 35 /* EqualsEqualsToken */:
-      case 36 /* ExclamationEqualsToken */:
-      case 37 /* EqualsEqualsEqualsToken */:
-      case 38 /* ExclamationEqualsEqualsToken */:
-      case 51 /* AmpersandToken */:
-      case 53 /* CaretToken */:
-      case 52 /* BarToken */:
-      case 56 /* AmpersandAmpersandToken */:
-      case 57 /* BarBarToken */:
-      case 75 /* BarEqualsToken */:
-      case 74 /* AmpersandEqualsToken */:
-      case 79 /* CaretEqualsToken */:
-      case 71 /* LessThanLessThanEqualsToken */:
-      case 72 /* GreaterThanGreaterThanEqualsToken */:
-      case 73 /* GreaterThanGreaterThanGreaterThanEqualsToken */:
-      case 65 /* PlusEqualsToken */:
-      case 66 /* MinusEqualsToken */:
-      case 67 /* AsteriskEqualsToken */:
-      case 69 /* SlashEqualsToken */:
-      case 70 /* PercentEqualsToken */:
-      case 64 /* EqualsToken */:
-      case 28 /* CommaToken */:
-      case 61 /* QuestionQuestionToken */:
-      case 76 /* BarBarEqualsToken */:
-      case 77 /* AmpersandAmpersandEqualsToken */:
-      case 78 /* QuestionQuestionEqualsToken */:
-        return true;
-      default:
-        return false;
+    function toLineColumnOffset(fileName, position) {
+      const file = getSourceFileLike(fileName);
+      return file.getLineAndCharacterOfPosition(position);
     }
-  }
-  function isPrefixUnaryExpressionOperatorToken(token) {
-    switch (token) {
-      case 40 /* PlusToken */:
-      case 41 /* MinusToken */:
-      case 55 /* TildeToken */:
-      case 54 /* ExclamationToken */:
-      case 46 /* PlusPlusToken */:
-      case 47 /* MinusMinusToken */:
-        return true;
-      default:
-        return false;
+    function clearCache() {
+      sourceFileLike.clear();
+      documentPositionMappers.clear();
     }
   }
-  function classFromKind(token) {
-    if (isKeyword(token)) {
-      return 3 /* keyword */;
-    } else if (isBinaryExpressionOperatorToken(token) || isPrefixUnaryExpressionOperatorToken(token)) {
-      return 5 /* operator */;
-    } else if (token >= 19 /* FirstPunctuation */ && token <= 79 /* LastPunctuation */) {
-      return 10 /* punctuation */;
-    }
-    switch (token) {
-      case 9 /* NumericLiteral */:
-        return 4 /* numericLiteral */;
-      case 10 /* BigIntLiteral */:
-        return 25 /* bigintLiteral */;
-      case 11 /* StringLiteral */:
-        return 6 /* stringLiteral */;
-      case 14 /* RegularExpressionLiteral */:
-        return 7 /* regularExpressionLiteral */;
-      case 7 /* ConflictMarkerTrivia */:
-      case 3 /* MultiLineCommentTrivia */:
-      case 2 /* SingleLineCommentTrivia */:
-        return 1 /* comment */;
-      case 5 /* WhitespaceTrivia */:
-      case 4 /* NewLineTrivia */:
-        return 8 /* whiteSpace */;
-      case 80 /* Identifier */:
-      default:
-        if (isTemplateLiteralKind(token)) {
-          return 6 /* stringLiteral */;
+  function getDocumentPositionMapper(host, generatedFileName, generatedFileLineInfo, readMapFile) {
+    let mapFileName = tryGetSourceMappingURL(generatedFileLineInfo);
+    if (mapFileName) {
+      const match = base64UrlRegExp.exec(mapFileName);
+      if (match) {
+        if (match[1]) {
+          const base64Object = match[1];
+          return convertDocumentToSourceMapper(host, base64decode(sys, base64Object), generatedFileName);
         }
-        return 2 /* identifier */;
+        mapFileName = void 0;
+      }
     }
-  }
-  function getSemanticClassifications(typeChecker, cancellationToken, sourceFile, classifiableNames, span) {
-    return convertClassificationsToSpans(getEncodedSemanticClassifications(typeChecker, cancellationToken, sourceFile, classifiableNames, span));
-  }
-  function checkForClassificationCancellation(cancellationToken, kind) {
-    switch (kind) {
-      case 266 /* ModuleDeclaration */:
-      case 262 /* ClassDeclaration */:
-      case 263 /* InterfaceDeclaration */:
-      case 261 /* FunctionDeclaration */:
-      case 230 /* ClassExpression */:
-      case 217 /* FunctionExpression */:
-      case 218 /* ArrowFunction */:
-        cancellationToken.throwIfCancellationRequested();
+    const possibleMapLocations = [];
+    if (mapFileName) {
+      possibleMapLocations.push(mapFileName);
     }
-  }
-  function getEncodedSemanticClassifications(typeChecker, cancellationToken, sourceFile, classifiableNames, span) {
-    const spans = [];
-    sourceFile.forEachChild(function cb(node) {
-      if (!node || !textSpanIntersectsWith(span, node.pos, node.getFullWidth())) {
-        return;
+    possibleMapLocations.push(generatedFileName + ".map");
+    const originalMapFileName = mapFileName && getNormalizedAbsolutePath(mapFileName, getDirectoryPath(generatedFileName));
+    for (const location of possibleMapLocations) {
+      const mapFileName2 = getNormalizedAbsolutePath(location, getDirectoryPath(generatedFileName));
+      const mapFileContents = readMapFile(mapFileName2, originalMapFileName);
+      if (isString(mapFileContents)) {
+        return convertDocumentToSourceMapper(host, mapFileContents, mapFileName2);
       }
-      checkForClassificationCancellation(cancellationToken, node.kind);
-      if (isIdentifier(node) && !nodeIsMissing(node) && classifiableNames.has(node.escapedText)) {
-        const symbol = typeChecker.getSymbolAtLocation(node);
-        const type = symbol && classifySymbol(symbol, getMeaningFromLocation(node), typeChecker);
-        if (type) {
-          pushClassification(node.getStart(sourceFile), node.getEnd(), type);
-        }
+      if (mapFileContents !== void 0) {
+        return mapFileContents || void 0;
       }
-      node.forEachChild(cb);
-    });
-    return { spans, endOfLineState: 0 /* None */ };
-    function pushClassification(start, end, type) {
-      const length2 = end - start;
-      Debug.assert(length2 > 0, `Classification had non-positive length of ${length2}`);
-      spans.push(start);
-      spans.push(length2);
-      spans.push(type);
     }
+    return void 0;
   }
-  function classifySymbol(symbol, meaningAtPosition, checker) {
-    const flags = symbol.getFlags();
-    if ((flags & 2885600 /* Classifiable */) === 0 /* None */) {
-      return void 0;
-    } else if (flags & 32 /* Class */) {
-      return 11 /* className */;
-    } else if (flags & 384 /* Enum */) {
-      return 12 /* enumName */;
-    } else if (flags & 524288 /* TypeAlias */) {
-      return 16 /* typeAliasName */;
-    } else if (flags & 1536 /* Module */) {
-      return meaningAtPosition & 4 /* Namespace */ || meaningAtPosition & 1 /* Value */ && hasValueSideModule(symbol) ? 14 /* moduleName */ : void 0;
-    } else if (flags & 2097152 /* Alias */) {
-      return classifySymbol(checker.getAliasedSymbol(symbol), meaningAtPosition, checker);
-    } else if (meaningAtPosition & 2 /* Type */) {
-      return flags & 64 /* Interface */ ? 13 /* interfaceName */ : flags & 262144 /* TypeParameter */ ? 15 /* typeParameterName */ : void 0;
-    } else {
+  function convertDocumentToSourceMapper(host, contents, mapFileName) {
+    const map2 = tryParseRawSourceMap(contents);
+    if (!map2 || !map2.sources || !map2.file || !map2.mappings) {
       return void 0;
     }
+    if (map2.sourcesContent && map2.sourcesContent.some(isString))
+      return void 0;
+    return createDocumentPositionMapper(host, map2, mapFileName);
   }
-  function hasValueSideModule(symbol) {
-    return some(symbol.declarations, (declaration) => isModuleDeclaration(declaration) && getModuleInstanceState(declaration) === 1 /* Instantiated */);
+  function createSourceFileLike(text, lineMap) {
+    return {
+      text,
+      lineMap,
+      getLineAndCharacterOfPosition(pos) {
+        return computeLineAndCharacterOfPosition(getLineStarts(this), pos);
+      }
+    };
   }
-  function getClassificationTypeName(type) {
-    switch (type) {
-      case 1 /* comment */:
-        return "comment" /* comment */;
-      case 2 /* identifier */:
-        return "identifier" /* identifier */;
-      case 3 /* keyword */:
-        return "keyword" /* keyword */;
-      case 4 /* numericLiteral */:
-        return "number" /* numericLiteral */;
-      case 25 /* bigintLiteral */:
-        return "bigint" /* bigintLiteral */;
-      case 5 /* operator */:
-        return "operator" /* operator */;
-      case 6 /* stringLiteral */:
-        return "string" /* stringLiteral */;
-      case 8 /* whiteSpace */:
-        return "whitespace" /* whiteSpace */;
-      case 9 /* text */:
-        return "text" /* text */;
-      case 10 /* punctuation */:
-        return "punctuation" /* punctuation */;
-      case 11 /* className */:
-        return "class name" /* className */;
-      case 12 /* enumName */:
-        return "enum name" /* enumName */;
-      case 13 /* interfaceName */:
-        return "interface name" /* interfaceName */;
-      case 14 /* moduleName */:
-        return "module name" /* moduleName */;
-      case 15 /* typeParameterName */:
-        return "type parameter name" /* typeParameterName */;
-      case 16 /* typeAliasName */:
-        return "type alias name" /* typeAliasName */;
-      case 17 /* parameterName */:
-        return "parameter name" /* parameterName */;
-      case 18 /* docCommentTagName */:
-        return "doc comment tag name" /* docCommentTagName */;
-      case 19 /* jsxOpenTagName */:
-        return "jsx open tag name" /* jsxOpenTagName */;
-      case 20 /* jsxCloseTagName */:
-        return "jsx close tag name" /* jsxCloseTagName */;
-      case 21 /* jsxSelfClosingTagName */:
-        return "jsx self closing tag name" /* jsxSelfClosingTagName */;
-      case 22 /* jsxAttribute */:
-        return "jsx attribute" /* jsxAttribute */;
-      case 23 /* jsxText */:
-        return "jsx text" /* jsxText */;
-      case 24 /* jsxAttributeStringLiteralValue */:
-        return "jsx attribute string literal value" /* jsxAttributeStringLiteralValue */;
-      default:
-        return void 0;
+  var base64UrlRegExp;
+  var init_sourcemaps = __esm({
+    "src/services/sourcemaps.ts"() {
+      "use strict";
+      init_ts4();
+      base64UrlRegExp = /^data:(?:application\/json(?:;charset=[uU][tT][fF]-8);base64,([A-Za-z0-9+/=]+)$)?/;
     }
-  }
-  function convertClassificationsToSpans(classifications) {
-    Debug.assert(classifications.spans.length % 3 === 0);
-    const dense = classifications.spans;
-    const result = [];
-    for (let i = 0; i < dense.length; i += 3) {
-      result.push({
-        textSpan: createTextSpan(dense[i], dense[i + 1]),
-        classificationType: getClassificationTypeName(dense[i + 2])
-      });
+  });
+
+  // src/services/suggestionDiagnostics.ts
+  function computeSuggestionDiagnostics(sourceFile, program, cancellationToken) {
+    var _a;
+    program.getSemanticDiagnostics(sourceFile, cancellationToken);
+    const diags = [];
+    const checker = program.getTypeChecker();
+    const isCommonJSFile = sourceFile.impliedNodeFormat === 1 /* CommonJS */ || fileExtensionIsOneOf(sourceFile.fileName, [".cts" /* Cts */, ".cjs" /* Cjs */]);
+    if (!isCommonJSFile && sourceFile.commonJsModuleIndicator && (programContainsEsModules(program) || compilerOptionsIndicateEsModules(program.getCompilerOptions())) && containsTopLevelCommonjs(sourceFile)) {
+      diags.push(createDiagnosticForNode(getErrorNodeFromCommonJsIndicator(sourceFile.commonJsModuleIndicator), Diagnostics.File_is_a_CommonJS_module_it_may_be_converted_to_an_ES_module));
     }
-    return result;
-  }
-  function getSyntacticClassifications(cancellationToken, sourceFile, span) {
-    return convertClassificationsToSpans(getEncodedSyntacticClassifications(cancellationToken, sourceFile, span));
-  }
-  function getEncodedSyntacticClassifications(cancellationToken, sourceFile, span) {
-    const spanStart = span.start;
-    const spanLength = span.length;
-    const triviaScanner = createScanner(
-      99 /* Latest */,
-      /*skipTrivia*/
-      false,
-      sourceFile.languageVariant,
-      sourceFile.text
-    );
-    const mergeConflictScanner = createScanner(
-      99 /* Latest */,
-      /*skipTrivia*/
-      false,
-      sourceFile.languageVariant,
-      sourceFile.text
-    );
-    const result = [];
-    processElement(sourceFile);
-    return { spans: result, endOfLineState: 0 /* None */ };
-    function pushClassification(start, length2, type) {
-      result.push(start);
-      result.push(length2);
-      result.push(type);
+    const isJsFile = isSourceFileJS(sourceFile);
+    visitedNestedConvertibleFunctions.clear();
+    check(sourceFile);
+    if (getAllowSyntheticDefaultImports(program.getCompilerOptions())) {
+      for (const moduleSpecifier of sourceFile.imports) {
+        const importNode = importFromModuleSpecifier(moduleSpecifier);
+        const name = importNameForConvertToDefaultImport(importNode);
+        if (!name)
+          continue;
+        const module2 = (_a = program.getResolvedModule(sourceFile, moduleSpecifier.text, getModeForUsageLocation(sourceFile, moduleSpecifier))) == null ? void 0 : _a.resolvedModule;
+        const resolvedFile = module2 && program.getSourceFile(module2.resolvedFileName);
+        if (resolvedFile && resolvedFile.externalModuleIndicator && resolvedFile.externalModuleIndicator !== true && isExportAssignment(resolvedFile.externalModuleIndicator) && resolvedFile.externalModuleIndicator.isExportEquals) {
+          diags.push(createDiagnosticForNode(name, Diagnostics.Import_may_be_converted_to_a_default_import));
+        }
+      }
     }
-    function classifyLeadingTriviaAndGetTokenStart(token) {
-      triviaScanner.resetTokenState(token.pos);
-      while (true) {
-        const start = triviaScanner.getTokenEnd();
-        if (!couldStartTrivia(sourceFile.text, start)) {
-          return start;
+    addRange(diags, sourceFile.bindSuggestionDiagnostics);
+    addRange(diags, program.getSuggestionDiagnostics(sourceFile, cancellationToken));
+    return diags.sort((d1, d2) => d1.start - d2.start);
+    function check(node) {
+      if (isJsFile) {
+        if (canBeConvertedToClass(node, checker)) {
+          diags.push(createDiagnosticForNode(isVariableDeclaration(node.parent) ? node.parent.name : node, Diagnostics.This_constructor_function_may_be_converted_to_a_class_declaration));
         }
-        const kind = triviaScanner.scan();
-        const end = triviaScanner.getTokenEnd();
-        const width = end - start;
-        if (!isTrivia(kind)) {
-          return start;
+      } else {
+        if (isVariableStatement(node) && node.parent === sourceFile && node.declarationList.flags & 2 /* Const */ && node.declarationList.declarations.length === 1) {
+          const init = node.declarationList.declarations[0].initializer;
+          if (init && isRequireCall(
+            init,
+            /*requireStringLiteralLikeArgument*/
+            true
+          )) {
+            diags.push(createDiagnosticForNode(init, Diagnostics.require_call_may_be_converted_to_an_import));
+          }
         }
-        switch (kind) {
-          case 4 /* NewLineTrivia */:
-          case 5 /* WhitespaceTrivia */:
-            continue;
-          case 2 /* SingleLineCommentTrivia */:
-          case 3 /* MultiLineCommentTrivia */:
-            classifyComment(token, kind, start, width);
-            triviaScanner.resetTokenState(end);
-            continue;
-          case 7 /* ConflictMarkerTrivia */:
-            const text = sourceFile.text;
-            const ch = text.charCodeAt(start);
-            if (ch === 60 /* lessThan */ || ch === 62 /* greaterThan */) {
-              pushClassification(start, width, 1 /* comment */);
-              continue;
-            }
-            Debug.assert(ch === 124 /* bar */ || ch === 61 /* equals */);
-            classifyDisabledMergeCode(text, start, end);
-            break;
-          case 6 /* ShebangTrivia */:
-            break;
-          default:
-            Debug.assertNever(kind);
+        const jsdocTypedefNodes = ts_codefix_exports.getJSDocTypedefNodes(node);
+        for (const jsdocTypedefNode of jsdocTypedefNodes) {
+          diags.push(createDiagnosticForNode(jsdocTypedefNode, Diagnostics.JSDoc_typedef_may_be_converted_to_TypeScript_type));
+        }
+        if (ts_codefix_exports.parameterShouldGetTypeFromJSDoc(node)) {
+          diags.push(createDiagnosticForNode(node.name || node, Diagnostics.JSDoc_types_may_be_moved_to_TypeScript_types));
         }
       }
+      if (canBeConvertedToAsync(node)) {
+        addConvertToAsyncFunctionDiagnostics(node, checker, diags);
+      }
+      node.forEachChild(check);
     }
-    function classifyComment(token, kind, start, width) {
-      if (kind === 3 /* MultiLineCommentTrivia */) {
-        const docCommentAndDiagnostics = parseIsolatedJSDocComment(sourceFile.text, start, width);
-        if (docCommentAndDiagnostics && docCommentAndDiagnostics.jsDoc) {
-          setParent(docCommentAndDiagnostics.jsDoc, token);
-          classifyJSDocComment(docCommentAndDiagnostics.jsDoc);
-          return;
-        }
-      } else if (kind === 2 /* SingleLineCommentTrivia */) {
-        if (tryClassifyTripleSlashComment(start, width)) {
-          return;
+  }
+  function containsTopLevelCommonjs(sourceFile) {
+    return sourceFile.statements.some((statement) => {
+      switch (statement.kind) {
+        case 243 /* VariableStatement */:
+          return statement.declarationList.declarations.some((decl) => !!decl.initializer && isRequireCall(
+            propertyAccessLeftHandSide(decl.initializer),
+            /*requireStringLiteralLikeArgument*/
+            true
+          ));
+        case 244 /* ExpressionStatement */: {
+          const { expression } = statement;
+          if (!isBinaryExpression(expression))
+            return isRequireCall(
+              expression,
+              /*requireStringLiteralLikeArgument*/
+              true
+            );
+          const kind = getAssignmentDeclarationKind(expression);
+          return kind === 1 /* ExportsProperty */ || kind === 2 /* ModuleExports */;
         }
+        default:
+          return false;
       }
-      pushCommentRange(start, width);
+    });
+  }
+  function propertyAccessLeftHandSide(node) {
+    return isPropertyAccessExpression(node) ? propertyAccessLeftHandSide(node.expression) : node;
+  }
+  function importNameForConvertToDefaultImport(node) {
+    switch (node.kind) {
+      case 272 /* ImportDeclaration */:
+        const { importClause, moduleSpecifier } = node;
+        return importClause && !importClause.name && importClause.namedBindings && importClause.namedBindings.kind === 274 /* NamespaceImport */ && isStringLiteral(moduleSpecifier) ? importClause.namedBindings.name : void 0;
+      case 271 /* ImportEqualsDeclaration */:
+        return node.name;
+      default:
+        return void 0;
     }
-    function pushCommentRange(start, width) {
-      pushClassification(start, width, 1 /* comment */);
+  }
+  function addConvertToAsyncFunctionDiagnostics(node, checker, diags) {
+    if (isConvertibleFunction(node, checker) && !visitedNestedConvertibleFunctions.has(getKeyFromNode(node))) {
+      diags.push(createDiagnosticForNode(
+        !node.name && isVariableDeclaration(node.parent) && isIdentifier(node.parent.name) ? node.parent.name : node,
+        Diagnostics.This_may_be_converted_to_an_async_function
+      ));
     }
-    function classifyJSDocComment(docComment) {
-      var _a, _b, _c, _d, _e, _f, _g, _h;
-      let pos = docComment.pos;
-      if (docComment.tags) {
-        for (const tag of docComment.tags) {
-          if (tag.pos !== pos) {
-            pushCommentRange(pos, tag.pos - pos);
-          }
-          pushClassification(tag.pos, 1, 10 /* punctuation */);
-          pushClassification(tag.tagName.pos, tag.tagName.end - tag.tagName.pos, 18 /* docCommentTagName */);
-          pos = tag.tagName.end;
-          let commentStart = tag.tagName.end;
-          switch (tag.kind) {
-            case 347 /* JSDocParameterTag */:
-              const param = tag;
-              processJSDocParameterTag(param);
-              commentStart = param.isNameFirst && ((_a = param.typeExpression) == null ? void 0 : _a.end) || param.name.end;
-              break;
-            case 354 /* JSDocPropertyTag */:
-              const prop = tag;
-              commentStart = prop.isNameFirst && ((_b = prop.typeExpression) == null ? void 0 : _b.end) || prop.name.end;
-              break;
-            case 351 /* JSDocTemplateTag */:
-              processJSDocTemplateTag(tag);
-              pos = tag.end;
-              commentStart = tag.typeParameters.end;
-              break;
-            case 352 /* JSDocTypedefTag */:
-              const type = tag;
-              commentStart = ((_c = type.typeExpression) == null ? void 0 : _c.kind) === 315 /* JSDocTypeExpression */ && ((_d = type.fullName) == null ? void 0 : _d.end) || ((_e = type.typeExpression) == null ? void 0 : _e.end) || commentStart;
-              break;
-            case 344 /* JSDocCallbackTag */:
-              commentStart = tag.typeExpression.end;
-              break;
-            case 350 /* JSDocTypeTag */:
-              processElement(tag.typeExpression);
-              pos = tag.end;
-              commentStart = tag.typeExpression.end;
-              break;
-            case 349 /* JSDocThisTag */:
-            case 346 /* JSDocEnumTag */:
-              commentStart = tag.typeExpression.end;
-              break;
-            case 348 /* JSDocReturnTag */:
-              processElement(tag.typeExpression);
-              pos = tag.end;
-              commentStart = ((_f = tag.typeExpression) == null ? void 0 : _f.end) || commentStart;
-              break;
-            case 353 /* JSDocSeeTag */:
-              commentStart = ((_g = tag.name) == null ? void 0 : _g.end) || commentStart;
-              break;
-            case 334 /* JSDocAugmentsTag */:
-            case 335 /* JSDocImplementsTag */:
-              commentStart = tag.class.end;
-              break;
-            case 355 /* JSDocThrowsTag */:
-              processElement(tag.typeExpression);
-              pos = tag.end;
-              commentStart = ((_h = tag.typeExpression) == null ? void 0 : _h.end) || commentStart;
-              break;
-          }
-          if (typeof tag.comment === "object") {
-            pushCommentRange(tag.comment.pos, tag.comment.end - tag.comment.pos);
-          } else if (typeof tag.comment === "string") {
-            pushCommentRange(commentStart, tag.end - commentStart);
-          }
-        }
-      }
-      if (pos !== docComment.end) {
-        pushCommentRange(pos, docComment.end - pos);
-      }
-      return;
-      function processJSDocParameterTag(tag) {
-        if (tag.isNameFirst) {
-          pushCommentRange(pos, tag.name.pos - pos);
-          pushClassification(tag.name.pos, tag.name.end - tag.name.pos, 17 /* parameterName */);
-          pos = tag.name.end;
-        }
-        if (tag.typeExpression) {
-          pushCommentRange(pos, tag.typeExpression.pos - pos);
-          processElement(tag.typeExpression);
-          pos = tag.typeExpression.end;
-        }
-        if (!tag.isNameFirst) {
-          pushCommentRange(pos, tag.name.pos - pos);
-          pushClassification(tag.name.pos, tag.name.end - tag.name.pos, 17 /* parameterName */);
-          pos = tag.name.end;
+  }
+  function isConvertibleFunction(node, checker) {
+    return !isAsyncFunction(node) && node.body && isBlock(node.body) && hasReturnStatementWithPromiseHandler(node.body, checker) && returnsPromise(node, checker);
+  }
+  function returnsPromise(node, checker) {
+    const signature = checker.getSignatureFromDeclaration(node);
+    const returnType = signature ? checker.getReturnTypeOfSignature(signature) : void 0;
+    return !!returnType && !!checker.getPromisedTypeOfPromise(returnType);
+  }
+  function getErrorNodeFromCommonJsIndicator(commonJsModuleIndicator) {
+    return isBinaryExpression(commonJsModuleIndicator) ? commonJsModuleIndicator.left : commonJsModuleIndicator;
+  }
+  function hasReturnStatementWithPromiseHandler(body, checker) {
+    return !!forEachReturnStatement(body, (statement) => isReturnStatementWithFixablePromiseHandler(statement, checker));
+  }
+  function isReturnStatementWithFixablePromiseHandler(node, checker) {
+    return isReturnStatement(node) && !!node.expression && isFixablePromiseHandler(node.expression, checker);
+  }
+  function isFixablePromiseHandler(node, checker) {
+    if (!isPromiseHandler(node) || !hasSupportedNumberOfArguments(node) || !node.arguments.every((arg) => isFixablePromiseArgument(arg, checker))) {
+      return false;
+    }
+    let currentNode = node.expression.expression;
+    while (isPromiseHandler(currentNode) || isPropertyAccessExpression(currentNode)) {
+      if (isCallExpression(currentNode)) {
+        if (!hasSupportedNumberOfArguments(currentNode) || !currentNode.arguments.every((arg) => isFixablePromiseArgument(arg, checker))) {
+          return false;
         }
+        currentNode = currentNode.expression.expression;
+      } else {
+        currentNode = currentNode.expression;
       }
     }
-    function tryClassifyTripleSlashComment(start, width) {
-      const tripleSlashXMLCommentRegEx = /^(\/\/\/\s*)(<)(?:(\S+)((?:[^/]|\/[^>])*)(\/>)?)?/im;
-      const attributeRegex = /(\s)(\S+)(\s*)(=)(\s*)('[^']+'|"[^"]+")/img;
-      const text = sourceFile.text.substr(start, width);
-      const match = tripleSlashXMLCommentRegEx.exec(text);
-      if (!match) {
-        return false;
-      }
-      if (!match[3] || !(match[3] in commentPragmas)) {
-        return false;
-      }
-      let pos = start;
-      pushCommentRange(pos, match[1].length);
-      pos += match[1].length;
-      pushClassification(pos, match[2].length, 10 /* punctuation */);
-      pos += match[2].length;
-      pushClassification(pos, match[3].length, 21 /* jsxSelfClosingTagName */);
-      pos += match[3].length;
-      const attrText = match[4];
-      let attrPos = pos;
-      while (true) {
-        const attrMatch = attributeRegex.exec(attrText);
-        if (!attrMatch) {
-          break;
-        }
-        const newAttrPos = pos + attrMatch.index + attrMatch[1].length;
-        if (newAttrPos > attrPos) {
-          pushCommentRange(attrPos, newAttrPos - attrPos);
-          attrPos = newAttrPos;
-        }
-        pushClassification(attrPos, attrMatch[2].length, 22 /* jsxAttribute */);
-        attrPos += attrMatch[2].length;
-        if (attrMatch[3].length) {
-          pushCommentRange(attrPos, attrMatch[3].length);
-          attrPos += attrMatch[3].length;
+    return true;
+  }
+  function isPromiseHandler(node) {
+    return isCallExpression(node) && (hasPropertyAccessExpressionWithName(node, "then") || hasPropertyAccessExpressionWithName(node, "catch") || hasPropertyAccessExpressionWithName(node, "finally"));
+  }
+  function hasSupportedNumberOfArguments(node) {
+    const name = node.expression.name.text;
+    const maxArguments = name === "then" ? 2 : name === "catch" ? 1 : name === "finally" ? 1 : 0;
+    if (node.arguments.length > maxArguments)
+      return false;
+    if (node.arguments.length < maxArguments)
+      return true;
+    return maxArguments === 1 || some(node.arguments, (arg) => {
+      return arg.kind === 106 /* NullKeyword */ || isIdentifier(arg) && arg.text === "undefined";
+    });
+  }
+  function isFixablePromiseArgument(arg, checker) {
+    switch (arg.kind) {
+      case 262 /* FunctionDeclaration */:
+      case 218 /* FunctionExpression */:
+        const functionFlags = getFunctionFlags(arg);
+        if (functionFlags & 1 /* Generator */) {
+          return false;
         }
-        pushClassification(attrPos, attrMatch[4].length, 5 /* operator */);
-        attrPos += attrMatch[4].length;
-        if (attrMatch[5].length) {
-          pushCommentRange(attrPos, attrMatch[5].length);
-          attrPos += attrMatch[5].length;
+      case 219 /* ArrowFunction */:
+        visitedNestedConvertibleFunctions.set(getKeyFromNode(arg), true);
+      case 106 /* NullKeyword */:
+        return true;
+      case 80 /* Identifier */:
+      case 211 /* PropertyAccessExpression */: {
+        const symbol = checker.getSymbolAtLocation(arg);
+        if (!symbol) {
+          return false;
         }
-        pushClassification(attrPos, attrMatch[6].length, 24 /* jsxAttributeStringLiteralValue */);
-        attrPos += attrMatch[6].length;
-      }
-      pos += match[4].length;
-      if (pos > attrPos) {
-        pushCommentRange(attrPos, pos - attrPos);
+        return checker.isUndefinedSymbol(symbol) || some(skipAlias(symbol, checker).declarations, (d) => isFunctionLike(d) || hasInitializer(d) && !!d.initializer && isFunctionLike(d.initializer));
       }
-      if (match[5]) {
-        pushClassification(pos, match[5].length, 10 /* punctuation */);
-        pos += match[5].length;
+      default:
+        return false;
+    }
+  }
+  function getKeyFromNode(exp) {
+    return `${exp.pos.toString()}:${exp.end.toString()}`;
+  }
+  function canBeConvertedToClass(node, checker) {
+    var _a, _b, _c, _d;
+    if (isFunctionExpression(node)) {
+      if (isVariableDeclaration(node.parent) && ((_a = node.symbol.members) == null ? void 0 : _a.size)) {
+        return true;
       }
-      const end = start + width;
-      if (pos < end) {
-        pushCommentRange(pos, end - pos);
+      const symbol = checker.getSymbolOfExpando(
+        node,
+        /*allowDeclaration*/
+        false
+      );
+      return !!(symbol && (((_b = symbol.exports) == null ? void 0 : _b.size) || ((_c = symbol.members) == null ? void 0 : _c.size)));
+    }
+    if (isFunctionDeclaration(node)) {
+      return !!((_d = node.symbol.members) == null ? void 0 : _d.size);
+    }
+    return false;
+  }
+  function canBeConvertedToAsync(node) {
+    switch (node.kind) {
+      case 262 /* FunctionDeclaration */:
+      case 174 /* MethodDeclaration */:
+      case 218 /* FunctionExpression */:
+      case 219 /* ArrowFunction */:
+        return true;
+      default:
+        return false;
+    }
+  }
+  var visitedNestedConvertibleFunctions;
+  var init_suggestionDiagnostics = __esm({
+    "src/services/suggestionDiagnostics.ts"() {
+      "use strict";
+      init_ts4();
+      visitedNestedConvertibleFunctions = /* @__PURE__ */ new Map();
+    }
+  });
+
+  // src/services/transpile.ts
+  function transpileModule(input, transpileOptions) {
+    const diagnostics = [];
+    const options = transpileOptions.compilerOptions ? fixupCompilerOptions(transpileOptions.compilerOptions, diagnostics) : {};
+    const defaultOptions = getDefaultCompilerOptions2();
+    for (const key in defaultOptions) {
+      if (hasProperty(defaultOptions, key) && options[key] === void 0) {
+        options[key] = defaultOptions[key];
       }
-      return true;
     }
-    function processJSDocTemplateTag(tag) {
-      for (const child of tag.getChildren()) {
-        processElement(child);
+    for (const option of transpileOptionValueCompilerOptions) {
+      if (options.verbatimModuleSyntax && optionsRedundantWithVerbatimModuleSyntax.has(option.name)) {
+        continue;
       }
+      options[option.name] = option.transpileOptionValue;
     }
-    function classifyDisabledMergeCode(text, start, end) {
-      let i;
-      for (i = start; i < end; i++) {
-        if (isLineBreak(text.charCodeAt(i))) {
-          break;
+    options.suppressOutputPathCheck = true;
+    options.allowNonTsExtensions = true;
+    const newLine = getNewLineCharacter(options);
+    const compilerHost = {
+      getSourceFile: (fileName) => fileName === normalizePath(inputFileName) ? sourceFile : void 0,
+      writeFile: (name, text) => {
+        if (fileExtensionIs(name, ".map")) {
+          Debug.assertEqual(sourceMapText, void 0, "Unexpected multiple source map outputs, file:", name);
+          sourceMapText = text;
+        } else {
+          Debug.assertEqual(outputText, void 0, "Unexpected multiple outputs, file:", name);
+          outputText = text;
         }
+      },
+      getDefaultLibFileName: () => "lib.d.ts",
+      useCaseSensitiveFileNames: () => false,
+      getCanonicalFileName: (fileName) => fileName,
+      getCurrentDirectory: () => "",
+      getNewLine: () => newLine,
+      fileExists: (fileName) => fileName === inputFileName,
+      readFile: () => "",
+      directoryExists: () => true,
+      getDirectories: () => []
+    };
+    const inputFileName = transpileOptions.fileName || (transpileOptions.compilerOptions && transpileOptions.compilerOptions.jsx ? "module.tsx" : "module.ts");
+    const sourceFile = createSourceFile(
+      inputFileName,
+      input,
+      {
+        languageVersion: getEmitScriptTarget(options),
+        impliedNodeFormat: getImpliedNodeFormatForFile(
+          toPath(inputFileName, "", compilerHost.getCanonicalFileName),
+          /*packageJsonInfoCache*/
+          void 0,
+          compilerHost,
+          options
+        ),
+        setExternalModuleIndicator: getSetExternalModuleIndicator(options),
+        jsDocParsingMode: transpileOptions.jsDocParsingMode ?? 0 /* ParseAll */
       }
-      pushClassification(start, i - start, 1 /* comment */);
-      mergeConflictScanner.resetTokenState(i);
-      while (mergeConflictScanner.getTokenEnd() < end) {
-        classifyDisabledCodeToken();
-      }
+    );
+    if (transpileOptions.moduleName) {
+      sourceFile.moduleName = transpileOptions.moduleName;
     }
-    function classifyDisabledCodeToken() {
-      const start = mergeConflictScanner.getTokenEnd();
-      const tokenKind = mergeConflictScanner.scan();
-      const end = mergeConflictScanner.getTokenEnd();
-      const type = classifyTokenType(tokenKind);
-      if (type) {
-        pushClassification(start, end - start, type);
-      }
+    if (transpileOptions.renamedDependencies) {
+      sourceFile.renamedDependencies = new Map(Object.entries(transpileOptions.renamedDependencies));
     }
-    function tryClassifyNode(node) {
-      if (isJSDoc(node)) {
-        return true;
-      }
-      if (nodeIsMissing(node)) {
-        return true;
-      }
-      const classifiedElementName = tryClassifyJsxElementName(node);
-      if (!isToken(node) && node.kind !== 12 /* JsxText */ && classifiedElementName === void 0) {
-        return false;
+    let outputText;
+    let sourceMapText;
+    const program = createProgram([inputFileName], options, compilerHost);
+    if (transpileOptions.reportDiagnostics) {
+      addRange(
+        /*to*/
+        diagnostics,
+        /*from*/
+        program.getSyntacticDiagnostics(sourceFile)
+      );
+      addRange(
+        /*to*/
+        diagnostics,
+        /*from*/
+        program.getOptionsDiagnostics()
+      );
+    }
+    program.emit(
+      /*targetSourceFile*/
+      void 0,
+      /*writeFile*/
+      void 0,
+      /*cancellationToken*/
+      void 0,
+      /*emitOnlyDtsFiles*/
+      void 0,
+      transpileOptions.transformers
+    );
+    if (outputText === void 0)
+      return Debug.fail("Output generation failed");
+    return { outputText, diagnostics, sourceMapText };
+  }
+  function transpile(input, compilerOptions, fileName, diagnostics, moduleName) {
+    const output = transpileModule(input, { compilerOptions, fileName, reportDiagnostics: !!diagnostics, moduleName });
+    addRange(diagnostics, output.diagnostics);
+    return output.outputText;
+  }
+  function fixupCompilerOptions(options, diagnostics) {
+    commandLineOptionsStringToEnum = commandLineOptionsStringToEnum || filter(optionDeclarations, (o) => typeof o.type === "object" && !forEachEntry(o.type, (v) => typeof v !== "number"));
+    options = cloneCompilerOptions(options);
+    for (const opt of commandLineOptionsStringToEnum) {
+      if (!hasProperty(options, opt.name)) {
+        continue;
       }
-      const tokenStart = node.kind === 12 /* JsxText */ ? node.pos : classifyLeadingTriviaAndGetTokenStart(node);
-      const tokenWidth = node.end - tokenStart;
-      Debug.assert(tokenWidth >= 0);
-      if (tokenWidth > 0) {
-        const type = classifiedElementName || classifyTokenType(node.kind, node);
-        if (type) {
-          pushClassification(tokenStart, tokenWidth, type);
+      const value = options[opt.name];
+      if (isString(value)) {
+        options[opt.name] = parseCustomTypeOption(opt, value, diagnostics);
+      } else {
+        if (!forEachEntry(opt.type, (v) => v === value)) {
+          diagnostics.push(createCompilerDiagnosticForInvalidCustomType(opt));
         }
       }
-      return true;
     }
-    function tryClassifyJsxElementName(token) {
-      switch (token.parent && token.parent.kind) {
-        case 285 /* JsxOpeningElement */:
-          if (token.parent.tagName === token) {
-            return 19 /* jsxOpenTagName */;
-          }
-          break;
-        case 286 /* JsxClosingElement */:
-          if (token.parent.tagName === token) {
-            return 20 /* jsxCloseTagName */;
-          }
-          break;
-        case 284 /* JsxSelfClosingElement */:
-          if (token.parent.tagName === token) {
-            return 21 /* jsxSelfClosingTagName */;
-          }
-          break;
-        case 290 /* JsxAttribute */:
-          if (token.parent.name === token) {
-            return 22 /* jsxAttribute */;
-          }
-          break;
-      }
-      return void 0;
+    return options;
+  }
+  var optionsRedundantWithVerbatimModuleSyntax, commandLineOptionsStringToEnum;
+  var init_transpile = __esm({
+    "src/services/transpile.ts"() {
+      "use strict";
+      init_ts4();
+      optionsRedundantWithVerbatimModuleSyntax = /* @__PURE__ */ new Set([
+        "isolatedModules",
+        "preserveValueImports",
+        "importsNotUsedAsValues"
+      ]);
     }
-    function classifyTokenType(tokenKind, token) {
-      if (isKeyword(tokenKind)) {
-        return 3 /* keyword */;
+  });
+
+  // src/services/navigateTo.ts
+  function getNavigateToItems(sourceFiles, checker, cancellationToken, searchValue, maxResultCount, excludeDtsFiles, excludeLibFiles) {
+    const patternMatcher = createPatternMatcher(searchValue);
+    if (!patternMatcher)
+      return emptyArray;
+    const rawItems = [];
+    const singleCurrentFile = sourceFiles.length === 1 ? sourceFiles[0] : void 0;
+    for (const sourceFile of sourceFiles) {
+      cancellationToken.throwIfCancellationRequested();
+      if (excludeDtsFiles && sourceFile.isDeclarationFile) {
+        continue;
       }
-      if (tokenKind === 30 /* LessThanToken */ || tokenKind === 32 /* GreaterThanToken */) {
-        if (token && getTypeArgumentOrTypeParameterList(token.parent)) {
-          return 10 /* punctuation */;
-        }
+      if (shouldExcludeFile(sourceFile, !!excludeLibFiles, singleCurrentFile)) {
+        continue;
       }
-      if (isPunctuation(tokenKind)) {
-        if (token) {
-          const parent2 = token.parent;
-          if (tokenKind === 64 /* EqualsToken */) {
-            if (parent2.kind === 259 /* VariableDeclaration */ || parent2.kind === 171 /* PropertyDeclaration */ || parent2.kind === 168 /* Parameter */ || parent2.kind === 290 /* JsxAttribute */) {
-              return 5 /* operator */;
-            }
-          }
-          if (parent2.kind === 225 /* BinaryExpression */ || parent2.kind === 223 /* PrefixUnaryExpression */ || parent2.kind === 224 /* PostfixUnaryExpression */ || parent2.kind === 226 /* ConditionalExpression */) {
-            return 5 /* operator */;
-          }
-        }
-        return 10 /* punctuation */;
-      } else if (tokenKind === 9 /* NumericLiteral */) {
-        return 4 /* numericLiteral */;
-      } else if (tokenKind === 10 /* BigIntLiteral */) {
-        return 25 /* bigintLiteral */;
-      } else if (tokenKind === 11 /* StringLiteral */) {
-        return token && token.parent.kind === 290 /* JsxAttribute */ ? 24 /* jsxAttributeStringLiteralValue */ : 6 /* stringLiteral */;
-      } else if (tokenKind === 14 /* RegularExpressionLiteral */) {
-        return 6 /* stringLiteral */;
-      } else if (isTemplateLiteralKind(tokenKind)) {
-        return 6 /* stringLiteral */;
-      } else if (tokenKind === 12 /* JsxText */) {
-        return 23 /* jsxText */;
-      } else if (tokenKind === 80 /* Identifier */) {
-        if (token) {
-          switch (token.parent.kind) {
-            case 262 /* ClassDeclaration */:
-              if (token.parent.name === token) {
-                return 11 /* className */;
-              }
-              return;
-            case 167 /* TypeParameter */:
-              if (token.parent.name === token) {
-                return 15 /* typeParameterName */;
-              }
-              return;
-            case 263 /* InterfaceDeclaration */:
-              if (token.parent.name === token) {
-                return 13 /* interfaceName */;
-              }
-              return;
-            case 265 /* EnumDeclaration */:
-              if (token.parent.name === token) {
-                return 12 /* enumName */;
-              }
-              return;
-            case 266 /* ModuleDeclaration */:
-              if (token.parent.name === token) {
-                return 14 /* moduleName */;
-              }
-              return;
-            case 168 /* Parameter */:
-              if (token.parent.name === token) {
-                return isThisIdentifier(token) ? 3 /* keyword */ : 17 /* parameterName */;
-              }
-              return;
-          }
-          if (isConstTypeReference(token.parent)) {
-            return 3 /* keyword */;
-          }
+      sourceFile.getNamedDeclarations().forEach((declarations, name) => {
+        getItemsFromNamedDeclaration(patternMatcher, name, declarations, checker, sourceFile.fileName, !!excludeLibFiles, singleCurrentFile, rawItems);
+      });
+    }
+    rawItems.sort(compareNavigateToItems);
+    return (maxResultCount === void 0 ? rawItems : rawItems.slice(0, maxResultCount)).map(createNavigateToItem);
+  }
+  function shouldExcludeFile(file, excludeLibFiles, singleCurrentFile) {
+    return file !== singleCurrentFile && excludeLibFiles && (isInsideNodeModules(file.path) || file.hasNoDefaultLib);
+  }
+  function getItemsFromNamedDeclaration(patternMatcher, name, declarations, checker, fileName, excludeLibFiles, singleCurrentFile, rawItems) {
+    const match = patternMatcher.getMatchForLastSegmentOfPattern(name);
+    if (!match) {
+      return;
+    }
+    for (const declaration of declarations) {
+      if (!shouldKeepItem(declaration, checker, excludeLibFiles, singleCurrentFile))
+        continue;
+      if (patternMatcher.patternContainsDots) {
+        const fullMatch = patternMatcher.getFullMatch(getContainers(declaration), name);
+        if (fullMatch) {
+          rawItems.push({ name, fileName, matchKind: fullMatch.kind, isCaseSensitive: fullMatch.isCaseSensitive, declaration });
         }
-        return 2 /* identifier */;
+      } else {
+        rawItems.push({ name, fileName, matchKind: match.kind, isCaseSensitive: match.isCaseSensitive, declaration });
       }
     }
-    function processElement(element) {
-      if (!element) {
-        return;
-      }
-      if (decodedTextSpanIntersectsWith(spanStart, spanLength, element.pos, element.getFullWidth())) {
-        checkForClassificationCancellation(cancellationToken, element.kind);
-        for (const child of element.getChildren(sourceFile)) {
-          if (!tryClassifyNode(child)) {
-            processElement(child);
-          }
-        }
+  }
+  function shouldKeepItem(declaration, checker, excludeLibFiles, singleCurrentFile) {
+    var _a;
+    switch (declaration.kind) {
+      case 273 /* ImportClause */:
+      case 276 /* ImportSpecifier */:
+      case 271 /* ImportEqualsDeclaration */:
+        const importer = checker.getSymbolAtLocation(declaration.name);
+        const imported = checker.getAliasedSymbol(importer);
+        return importer.escapedName !== imported.escapedName && !((_a = imported.declarations) == null ? void 0 : _a.every((d) => shouldExcludeFile(d.getSourceFile(), excludeLibFiles, singleCurrentFile)));
+      default:
+        return true;
+    }
+  }
+  function tryAddSingleDeclarationName(declaration, containers) {
+    const name = getNameOfDeclaration(declaration);
+    return !!name && (pushLiteral(name, containers) || name.kind === 167 /* ComputedPropertyName */ && tryAddComputedPropertyName(name.expression, containers));
+  }
+  function tryAddComputedPropertyName(expression, containers) {
+    return pushLiteral(expression, containers) || isPropertyAccessExpression(expression) && (containers.push(expression.name.text), true) && tryAddComputedPropertyName(expression.expression, containers);
+  }
+  function pushLiteral(node, containers) {
+    return isPropertyNameLiteral(node) && (containers.push(getTextOfIdentifierOrLiteral(node)), true);
+  }
+  function getContainers(declaration) {
+    const containers = [];
+    const name = getNameOfDeclaration(declaration);
+    if (name && name.kind === 167 /* ComputedPropertyName */ && !tryAddComputedPropertyName(name.expression, containers)) {
+      return emptyArray;
+    }
+    containers.shift();
+    let container = getContainerNode(declaration);
+    while (container) {
+      if (!tryAddSingleDeclarationName(container, containers)) {
+        return emptyArray;
       }
+      container = getContainerNode(container);
     }
+    return containers.reverse();
   }
-  var noRegexTable;
-  var init_classifier = __esm({
-    "src/services/classifier.ts"() {
+  function compareNavigateToItems(i1, i2) {
+    return compareValues(i1.matchKind, i2.matchKind) || compareStringsCaseSensitiveUI(i1.name, i2.name);
+  }
+  function createNavigateToItem(rawItem) {
+    const declaration = rawItem.declaration;
+    const container = getContainerNode(declaration);
+    const containerName = container && getNameOfDeclaration(container);
+    return {
+      name: rawItem.name,
+      kind: getNodeKind(declaration),
+      kindModifiers: getNodeModifiers(declaration),
+      matchKind: PatternMatchKind[rawItem.matchKind],
+      isCaseSensitive: rawItem.isCaseSensitive,
+      fileName: rawItem.fileName,
+      textSpan: createTextSpanFromNode(declaration),
+      // TODO(jfreeman): What should be the containerName when the container has a computed name?
+      containerName: containerName ? containerName.text : "",
+      containerKind: containerName ? getNodeKind(container) : "" /* unknown */
+    };
+  }
+  var init_navigateTo = __esm({
+    "src/services/navigateTo.ts"() {
       "use strict";
       init_ts4();
-      noRegexTable = arrayToNumericMap([
-        80 /* Identifier */,
-        11 /* StringLiteral */,
-        9 /* NumericLiteral */,
-        10 /* BigIntLiteral */,
-        14 /* RegularExpressionLiteral */,
-        110 /* ThisKeyword */,
-        46 /* PlusPlusToken */,
-        47 /* MinusMinusToken */,
-        22 /* CloseParenToken */,
-        24 /* CloseBracketToken */,
-        20 /* CloseBraceToken */,
-        112 /* TrueKeyword */,
-        97 /* FalseKeyword */
-      ], (token) => token, () => true);
     }
   });
 
-  // src/services/documentHighlights.ts
-  var DocumentHighlights;
-  var init_documentHighlights = __esm({
-    "src/services/documentHighlights.ts"() {
+  // src/services/_namespaces/ts.NavigateTo.ts
+  var ts_NavigateTo_exports = {};
+  __export(ts_NavigateTo_exports, {
+    getNavigateToItems: () => getNavigateToItems
+  });
+  var init_ts_NavigateTo = __esm({
+    "src/services/_namespaces/ts.NavigateTo.ts"() {
       "use strict";
-      init_ts4();
-      ((DocumentHighlights2) => {
-        function getDocumentHighlights(program, cancellationToken, sourceFile, position, sourceFilesToSearch) {
-          const node = getTouchingPropertyName(sourceFile, position);
-          if (node.parent && (isJsxOpeningElement(node.parent) && node.parent.tagName === node || isJsxClosingElement(node.parent))) {
-            const { openingElement, closingElement } = node.parent.parent;
-            const highlightSpans = [openingElement, closingElement].map(({ tagName }) => getHighlightSpanForNode(tagName, sourceFile));
-            return [{ fileName: sourceFile.fileName, highlightSpans }];
+      init_navigateTo();
+    }
+  });
+
+  // src/services/navigationBar.ts
+  function getNavigationBarItems(sourceFile, cancellationToken) {
+    curCancellationToken = cancellationToken;
+    curSourceFile = sourceFile;
+    try {
+      return map(primaryNavBarMenuItems(rootNavigationBarNode(sourceFile)), convertToPrimaryNavBarMenuItem);
+    } finally {
+      reset();
+    }
+  }
+  function getNavigationTree(sourceFile, cancellationToken) {
+    curCancellationToken = cancellationToken;
+    curSourceFile = sourceFile;
+    try {
+      return convertToTree(rootNavigationBarNode(sourceFile));
+    } finally {
+      reset();
+    }
+  }
+  function reset() {
+    curSourceFile = void 0;
+    curCancellationToken = void 0;
+    parentsStack = [];
+    parent = void 0;
+    emptyChildItemArray = [];
+  }
+  function nodeText(node) {
+    return cleanText(node.getText(curSourceFile));
+  }
+  function navigationBarNodeKind(n) {
+    return n.node.kind;
+  }
+  function pushChild(parent2, child) {
+    if (parent2.children) {
+      parent2.children.push(child);
+    } else {
+      parent2.children = [child];
+    }
+  }
+  function rootNavigationBarNode(sourceFile) {
+    Debug.assert(!parentsStack.length);
+    const root = { node: sourceFile, name: void 0, additionalNodes: void 0, parent: void 0, children: void 0, indent: 0 };
+    parent = root;
+    for (const statement of sourceFile.statements) {
+      addChildrenRecursively(statement);
+    }
+    endNode();
+    Debug.assert(!parent && !parentsStack.length);
+    return root;
+  }
+  function addLeafNode(node, name) {
+    pushChild(parent, emptyNavigationBarNode(node, name));
+  }
+  function emptyNavigationBarNode(node, name) {
+    return {
+      node,
+      name: name || (isDeclaration(node) || isExpression(node) ? getNameOfDeclaration(node) : void 0),
+      additionalNodes: void 0,
+      parent,
+      children: void 0,
+      indent: parent.indent + 1
+    };
+  }
+  function addTrackedEs5Class(name) {
+    if (!trackedEs5Classes) {
+      trackedEs5Classes = /* @__PURE__ */ new Map();
+    }
+    trackedEs5Classes.set(name, true);
+  }
+  function endNestedNodes(depth) {
+    for (let i = 0; i < depth; i++)
+      endNode();
+  }
+  function startNestedNodes(targetNode, entityName) {
+    const names = [];
+    while (!isPropertyNameLiteral(entityName)) {
+      const name = getNameOrArgument(entityName);
+      const nameText = getElementOrPropertyAccessName(entityName);
+      entityName = entityName.expression;
+      if (nameText === "prototype" || isPrivateIdentifier(name))
+        continue;
+      names.push(name);
+    }
+    names.push(entityName);
+    for (let i = names.length - 1; i > 0; i--) {
+      const name = names[i];
+      startNode(targetNode, name);
+    }
+    return [names.length - 1, names[0]];
+  }
+  function startNode(node, name) {
+    const navNode = emptyNavigationBarNode(node, name);
+    pushChild(parent, navNode);
+    parentsStack.push(parent);
+    trackedEs5ClassesStack.push(trackedEs5Classes);
+    trackedEs5Classes = void 0;
+    parent = navNode;
+  }
+  function endNode() {
+    if (parent.children) {
+      mergeChildren(parent.children, parent);
+      sortChildren(parent.children);
+    }
+    parent = parentsStack.pop();
+    trackedEs5Classes = trackedEs5ClassesStack.pop();
+  }
+  function addNodeWithRecursiveChild(node, child, name) {
+    startNode(node, name);
+    addChildrenRecursively(child);
+    endNode();
+  }
+  function addNodeWithRecursiveInitializer(node) {
+    if (node.initializer && isFunctionOrClassExpression(node.initializer)) {
+      startNode(node);
+      forEachChild(node.initializer, addChildrenRecursively);
+      endNode();
+    } else {
+      addNodeWithRecursiveChild(node, node.initializer);
+    }
+  }
+  function hasNavigationBarName(node) {
+    const name = getNameOfDeclaration(node);
+    if (name === void 0)
+      return false;
+    if (isComputedPropertyName(name)) {
+      const expression = name.expression;
+      return isEntityNameExpression(expression) || isNumericLiteral(expression) || isStringOrNumericLiteralLike(expression);
+    }
+    return !!name;
+  }
+  function addChildrenRecursively(node) {
+    curCancellationToken.throwIfCancellationRequested();
+    if (!node || isToken(node)) {
+      return;
+    }
+    switch (node.kind) {
+      case 176 /* Constructor */:
+        const ctr = node;
+        addNodeWithRecursiveChild(ctr, ctr.body);
+        for (const param of ctr.parameters) {
+          if (isParameterPropertyDeclaration(param, ctr)) {
+            addLeafNode(param);
           }
-          return getSemanticDocumentHighlights(position, node, program, cancellationToken, sourceFilesToSearch) || getSyntacticDocumentHighlights(node, sourceFile);
-        }
-        DocumentHighlights2.getDocumentHighlights = getDocumentHighlights;
-        function getHighlightSpanForNode(node, sourceFile) {
-          return {
-            fileName: sourceFile.fileName,
-            textSpan: createTextSpanFromNode(node, sourceFile),
-            kind: "none" /* none */
-          };
         }
-        function getSemanticDocumentHighlights(position, node, program, cancellationToken, sourceFilesToSearch) {
-          const sourceFilesSet = new Set(sourceFilesToSearch.map((f) => f.fileName));
-          const referenceEntries = ts_FindAllReferences_exports.getReferenceEntriesForNode(
-            position,
-            node,
-            program,
-            sourceFilesToSearch,
-            cancellationToken,
-            /*options*/
-            void 0,
-            sourceFilesSet
-          );
-          if (!referenceEntries)
-            return void 0;
-          const map2 = arrayToMultiMap(referenceEntries.map(ts_FindAllReferences_exports.toHighlightSpan), (e) => e.fileName, (e) => e.span);
-          const getCanonicalFileName = createGetCanonicalFileName(program.useCaseSensitiveFileNames());
-          return arrayFrom(mapDefinedIterator(map2.entries(), ([fileName, highlightSpans]) => {
-            if (!sourceFilesSet.has(fileName)) {
-              if (!program.redirectTargetsMap.has(toPath(fileName, program.getCurrentDirectory(), getCanonicalFileName))) {
-                return void 0;
-              }
-              const redirectTarget = program.getSourceFile(fileName);
-              const redirect = find(sourceFilesToSearch, (f) => !!f.redirectInfo && f.redirectInfo.redirectTarget === redirectTarget);
-              fileName = redirect.fileName;
-              Debug.assert(sourceFilesSet.has(fileName));
-            }
-            return { fileName, highlightSpans };
-          }));
+        break;
+      case 174 /* MethodDeclaration */:
+      case 177 /* GetAccessor */:
+      case 178 /* SetAccessor */:
+      case 173 /* MethodSignature */:
+        if (hasNavigationBarName(node)) {
+          addNodeWithRecursiveChild(node, node.body);
         }
-        function getSyntacticDocumentHighlights(node, sourceFile) {
-          const highlightSpans = getHighlightSpans(node, sourceFile);
-          return highlightSpans && [{ fileName: sourceFile.fileName, highlightSpans }];
+        break;
+      case 172 /* PropertyDeclaration */:
+        if (hasNavigationBarName(node)) {
+          addNodeWithRecursiveInitializer(node);
         }
-        function getHighlightSpans(node, sourceFile) {
-          switch (node.kind) {
-            case 101 /* IfKeyword */:
-            case 93 /* ElseKeyword */:
-              return isIfStatement(node.parent) ? getIfElseOccurrences(node.parent, sourceFile) : void 0;
-            case 107 /* ReturnKeyword */:
-              return useParent(node.parent, isReturnStatement, getReturnOccurrences);
-            case 111 /* ThrowKeyword */:
-              return useParent(node.parent, isThrowStatement, getThrowOccurrences);
-            case 113 /* TryKeyword */:
-            case 85 /* CatchKeyword */:
-            case 98 /* FinallyKeyword */:
-              const tryStatement = node.kind === 85 /* CatchKeyword */ ? node.parent.parent : node.parent;
-              return useParent(tryStatement, isTryStatement, getTryCatchFinallyOccurrences);
-            case 109 /* SwitchKeyword */:
-              return useParent(node.parent, isSwitchStatement, getSwitchCaseDefaultOccurrences);
-            case 84 /* CaseKeyword */:
-            case 90 /* DefaultKeyword */: {
-              if (isDefaultClause(node.parent) || isCaseClause(node.parent)) {
-                return useParent(node.parent.parent.parent, isSwitchStatement, getSwitchCaseDefaultOccurrences);
-              }
-              return void 0;
-            }
-            case 83 /* BreakKeyword */:
-            case 88 /* ContinueKeyword */:
-              return useParent(node.parent, isBreakOrContinueStatement, getBreakOrContinueStatementOccurrences);
-            case 99 /* ForKeyword */:
-            case 117 /* WhileKeyword */:
-            case 92 /* DoKeyword */:
-              return useParent(node.parent, (n) => isIterationStatement(
-                n,
-                /*lookInLabeledStatements*/
-                true
-              ), getLoopBreakContinueOccurrences);
-            case 137 /* ConstructorKeyword */:
-              return getFromAllDeclarations(isConstructorDeclaration, [137 /* ConstructorKeyword */]);
-            case 139 /* GetKeyword */:
-            case 153 /* SetKeyword */:
-              return getFromAllDeclarations(isAccessor, [139 /* GetKeyword */, 153 /* SetKeyword */]);
-            case 135 /* AwaitKeyword */:
-              return useParent(node.parent, isAwaitExpression, getAsyncAndAwaitOccurrences);
-            case 134 /* AsyncKeyword */:
-              return highlightSpans(getAsyncAndAwaitOccurrences(node));
-            case 127 /* YieldKeyword */:
-              return highlightSpans(getYieldOccurrences(node));
-            case 103 /* InKeyword */:
-              return void 0;
-            default:
-              return isModifierKind(node.kind) && (isDeclaration(node.parent) || isVariableStatement(node.parent)) ? highlightSpans(getModifierOccurrences(node.kind, node.parent)) : void 0;
-          }
-          function getFromAllDeclarations(nodeTest, keywords) {
-            return useParent(node.parent, nodeTest, (decl) => {
-              var _a;
-              return mapDefined((_a = tryCast(decl, canHaveSymbol)) == null ? void 0 : _a.symbol.declarations, (d) => nodeTest(d) ? find(d.getChildren(sourceFile), (c) => contains(keywords, c.kind)) : void 0);
-            });
-          }
-          function useParent(node2, nodeTest, getNodes4) {
-            return nodeTest(node2) ? highlightSpans(getNodes4(node2, sourceFile)) : void 0;
-          }
-          function highlightSpans(nodes) {
-            return nodes && nodes.map((node2) => getHighlightSpanForNode(node2, sourceFile));
-          }
+        break;
+      case 171 /* PropertySignature */:
+        if (hasNavigationBarName(node)) {
+          addLeafNode(node);
         }
-        function aggregateOwnedThrowStatements(node) {
-          if (isThrowStatement(node)) {
-            return [node];
-          } else if (isTryStatement(node)) {
-            return concatenate(
-              node.catchClause ? aggregateOwnedThrowStatements(node.catchClause) : node.tryBlock && aggregateOwnedThrowStatements(node.tryBlock),
-              node.finallyBlock && aggregateOwnedThrowStatements(node.finallyBlock)
-            );
-          }
-          return isFunctionLike(node) ? void 0 : flatMapChildren(node, aggregateOwnedThrowStatements);
+        break;
+      case 273 /* ImportClause */:
+        const importClause = node;
+        if (importClause.name) {
+          addLeafNode(importClause.name);
         }
-        function getThrowStatementOwner(throwStatement) {
-          let child = throwStatement;
-          while (child.parent) {
-            const parent2 = child.parent;
-            if (isFunctionBlock(parent2) || parent2.kind === 311 /* SourceFile */) {
-              return parent2;
-            }
-            if (isTryStatement(parent2) && parent2.tryBlock === child && parent2.catchClause) {
-              return child;
+        const { namedBindings } = importClause;
+        if (namedBindings) {
+          if (namedBindings.kind === 274 /* NamespaceImport */) {
+            addLeafNode(namedBindings);
+          } else {
+            for (const element of namedBindings.elements) {
+              addLeafNode(element);
             }
-            child = parent2;
           }
-          return void 0;
         }
-        function aggregateAllBreakAndContinueStatements(node) {
-          return isBreakOrContinueStatement(node) ? [node] : isFunctionLike(node) ? void 0 : flatMapChildren(node, aggregateAllBreakAndContinueStatements);
-        }
-        function flatMapChildren(node, cb) {
-          const result = [];
-          node.forEachChild((child) => {
-            const value = cb(child);
-            if (value !== void 0) {
-              result.push(...toArray(value));
-            }
-          });
-          return result;
-        }
-        function ownsBreakOrContinueStatement(owner, statement) {
-          const actualOwner = getBreakOrContinueOwner(statement);
-          return !!actualOwner && actualOwner === owner;
-        }
-        function getBreakOrContinueOwner(statement) {
-          return findAncestor(statement, (node) => {
-            switch (node.kind) {
-              case 254 /* SwitchStatement */:
-                if (statement.kind === 250 /* ContinueStatement */) {
-                  return false;
-                }
-              case 247 /* ForStatement */:
-              case 248 /* ForInStatement */:
-              case 249 /* ForOfStatement */:
-              case 246 /* WhileStatement */:
-              case 245 /* DoStatement */:
-                return !statement.label || isLabeledBy(node, statement.label.escapedText);
-              default:
-                return isFunctionLike(node) && "quit";
-            }
-          });
+        break;
+      case 304 /* ShorthandPropertyAssignment */:
+        addNodeWithRecursiveChild(node, node.name);
+        break;
+      case 305 /* SpreadAssignment */:
+        const { expression } = node;
+        isIdentifier(expression) ? addLeafNode(node, expression) : addLeafNode(node);
+        break;
+      case 208 /* BindingElement */:
+      case 303 /* PropertyAssignment */:
+      case 260 /* VariableDeclaration */: {
+        const child = node;
+        if (isBindingPattern(child.name)) {
+          addChildrenRecursively(child.name);
+        } else {
+          addNodeWithRecursiveInitializer(child);
         }
-        function getModifierOccurrences(modifier, declaration) {
-          return mapDefined(getNodesToSearchForModifier(declaration, modifierToFlag(modifier)), (node) => findModifier(node, modifier));
+        break;
+      }
+      case 262 /* FunctionDeclaration */:
+        const nameNode = node.name;
+        if (nameNode && isIdentifier(nameNode)) {
+          addTrackedEs5Class(nameNode.text);
         }
-        function getNodesToSearchForModifier(declaration, modifierFlag) {
-          const container = declaration.parent;
-          switch (container.kind) {
-            case 267 /* ModuleBlock */:
-            case 311 /* SourceFile */:
-            case 240 /* Block */:
-            case 295 /* CaseClause */:
-            case 296 /* DefaultClause */:
-              if (modifierFlag & 256 /* Abstract */ && isClassDeclaration(declaration)) {
-                return [...declaration.members, declaration];
-              } else {
-                return container.statements;
-              }
-            case 175 /* Constructor */:
-            case 173 /* MethodDeclaration */:
-            case 261 /* FunctionDeclaration */:
-              return [...container.parameters, ...isClassLike(container.parent) ? container.parent.members : []];
-            case 262 /* ClassDeclaration */:
-            case 230 /* ClassExpression */:
-            case 263 /* InterfaceDeclaration */:
-            case 186 /* TypeLiteral */:
-              const nodes = container.members;
-              if (modifierFlag & (28 /* AccessibilityModifier */ | 64 /* Readonly */)) {
-                const constructor = find(container.members, isConstructorDeclaration);
-                if (constructor) {
-                  return [...nodes, ...constructor.parameters];
-                }
-              } else if (modifierFlag & 256 /* Abstract */) {
-                return [...nodes, container];
-              }
-              return nodes;
-            case 209 /* ObjectLiteralExpression */:
-              return void 0;
-            default:
-              Debug.assertNever(container, "Invalid container kind.");
+        addNodeWithRecursiveChild(node, node.body);
+        break;
+      case 219 /* ArrowFunction */:
+      case 218 /* FunctionExpression */:
+        addNodeWithRecursiveChild(node, node.body);
+        break;
+      case 266 /* EnumDeclaration */:
+        startNode(node);
+        for (const member of node.members) {
+          if (!isComputedProperty(member)) {
+            addLeafNode(member);
           }
         }
-        function pushKeywordIf(keywordList, token, ...expected) {
-          if (token && contains(expected, token.kind)) {
-            keywordList.push(token);
-            return true;
-          }
-          return false;
+        endNode();
+        break;
+      case 263 /* ClassDeclaration */:
+      case 231 /* ClassExpression */:
+      case 264 /* InterfaceDeclaration */:
+        startNode(node);
+        for (const member of node.members) {
+          addChildrenRecursively(member);
         }
-        function getLoopBreakContinueOccurrences(loopNode) {
-          const keywords = [];
-          if (pushKeywordIf(keywords, loopNode.getFirstToken(), 99 /* ForKeyword */, 117 /* WhileKeyword */, 92 /* DoKeyword */)) {
-            if (loopNode.kind === 245 /* DoStatement */) {
-              const loopTokens = loopNode.getChildren();
-              for (let i = loopTokens.length - 1; i >= 0; i--) {
-                if (pushKeywordIf(keywords, loopTokens[i], 117 /* WhileKeyword */)) {
-                  break;
+        endNode();
+        break;
+      case 267 /* ModuleDeclaration */:
+        addNodeWithRecursiveChild(node, getInteriorModule(node).body);
+        break;
+      case 277 /* ExportAssignment */: {
+        const expression2 = node.expression;
+        const child = isObjectLiteralExpression(expression2) || isCallExpression(expression2) ? expression2 : isArrowFunction(expression2) || isFunctionExpression(expression2) ? expression2.body : void 0;
+        if (child) {
+          startNode(node);
+          addChildrenRecursively(child);
+          endNode();
+        } else {
+          addLeafNode(node);
+        }
+        break;
+      }
+      case 281 /* ExportSpecifier */:
+      case 271 /* ImportEqualsDeclaration */:
+      case 181 /* IndexSignature */:
+      case 179 /* CallSignature */:
+      case 180 /* ConstructSignature */:
+      case 265 /* TypeAliasDeclaration */:
+        addLeafNode(node);
+        break;
+      case 213 /* CallExpression */:
+      case 226 /* BinaryExpression */: {
+        const special = getAssignmentDeclarationKind(node);
+        switch (special) {
+          case 1 /* ExportsProperty */:
+          case 2 /* ModuleExports */:
+            addNodeWithRecursiveChild(node, node.right);
+            return;
+          case 6 /* Prototype */:
+          case 3 /* PrototypeProperty */: {
+            const binaryExpression = node;
+            const assignmentTarget = binaryExpression.left;
+            const prototypeAccess = special === 3 /* PrototypeProperty */ ? assignmentTarget.expression : assignmentTarget;
+            let depth = 0;
+            let className;
+            if (isIdentifier(prototypeAccess.expression)) {
+              addTrackedEs5Class(prototypeAccess.expression.text);
+              className = prototypeAccess.expression;
+            } else {
+              [depth, className] = startNestedNodes(binaryExpression, prototypeAccess.expression);
+            }
+            if (special === 6 /* Prototype */) {
+              if (isObjectLiteralExpression(binaryExpression.right)) {
+                if (binaryExpression.right.properties.length > 0) {
+                  startNode(binaryExpression, className);
+                  forEachChild(binaryExpression.right, addChildrenRecursively);
+                  endNode();
                 }
               }
+            } else if (isFunctionExpression(binaryExpression.right) || isArrowFunction(binaryExpression.right)) {
+              addNodeWithRecursiveChild(node, binaryExpression.right, className);
+            } else {
+              startNode(binaryExpression, className);
+              addNodeWithRecursiveChild(node, binaryExpression.right, assignmentTarget.name);
+              endNode();
             }
+            endNestedNodes(depth);
+            return;
           }
-          forEach(aggregateAllBreakAndContinueStatements(loopNode.statement), (statement) => {
-            if (ownsBreakOrContinueStatement(loopNode, statement)) {
-              pushKeywordIf(keywords, statement.getFirstToken(), 83 /* BreakKeyword */, 88 /* ContinueKeyword */);
-            }
-          });
-          return keywords;
-        }
-        function getBreakOrContinueStatementOccurrences(breakOrContinueStatement) {
-          const owner = getBreakOrContinueOwner(breakOrContinueStatement);
-          if (owner) {
-            switch (owner.kind) {
-              case 247 /* ForStatement */:
-              case 248 /* ForInStatement */:
-              case 249 /* ForOfStatement */:
-              case 245 /* DoStatement */:
-              case 246 /* WhileStatement */:
-                return getLoopBreakContinueOccurrences(owner);
-              case 254 /* SwitchStatement */:
-                return getSwitchCaseDefaultOccurrences(owner);
-            }
+          case 7 /* ObjectDefinePropertyValue */:
+          case 9 /* ObjectDefinePrototypeProperty */: {
+            const defineCall = node;
+            const className = special === 7 /* ObjectDefinePropertyValue */ ? defineCall.arguments[0] : defineCall.arguments[0].expression;
+            const memberName = defineCall.arguments[1];
+            const [depth, classNameIdentifier] = startNestedNodes(node, className);
+            startNode(node, classNameIdentifier);
+            startNode(node, setTextRange(factory.createIdentifier(memberName.text), memberName));
+            addChildrenRecursively(node.arguments[2]);
+            endNode();
+            endNode();
+            endNestedNodes(depth);
+            return;
           }
-          return void 0;
-        }
-        function getSwitchCaseDefaultOccurrences(switchStatement) {
-          const keywords = [];
-          pushKeywordIf(keywords, switchStatement.getFirstToken(), 109 /* SwitchKeyword */);
-          forEach(switchStatement.caseBlock.clauses, (clause) => {
-            pushKeywordIf(keywords, clause.getFirstToken(), 84 /* CaseKeyword */, 90 /* DefaultKeyword */);
-            forEach(aggregateAllBreakAndContinueStatements(clause), (statement) => {
-              if (ownsBreakOrContinueStatement(switchStatement, statement)) {
-                pushKeywordIf(keywords, statement.getFirstToken(), 83 /* BreakKeyword */);
+          case 5 /* Property */: {
+            const binaryExpression = node;
+            const assignmentTarget = binaryExpression.left;
+            const targetFunction = assignmentTarget.expression;
+            if (isIdentifier(targetFunction) && getElementOrPropertyAccessName(assignmentTarget) !== "prototype" && trackedEs5Classes && trackedEs5Classes.has(targetFunction.text)) {
+              if (isFunctionExpression(binaryExpression.right) || isArrowFunction(binaryExpression.right)) {
+                addNodeWithRecursiveChild(node, binaryExpression.right, targetFunction);
+              } else if (isBindableStaticAccessExpression(assignmentTarget)) {
+                startNode(binaryExpression, targetFunction);
+                addNodeWithRecursiveChild(binaryExpression.left, binaryExpression.right, getNameOrArgument(assignmentTarget));
+                endNode();
               }
-            });
-          });
-          return keywords;
-        }
-        function getTryCatchFinallyOccurrences(tryStatement, sourceFile) {
-          const keywords = [];
-          pushKeywordIf(keywords, tryStatement.getFirstToken(), 113 /* TryKeyword */);
-          if (tryStatement.catchClause) {
-            pushKeywordIf(keywords, tryStatement.catchClause.getFirstToken(), 85 /* CatchKeyword */);
-          }
-          if (tryStatement.finallyBlock) {
-            const finallyKeyword = findChildOfKind(tryStatement, 98 /* FinallyKeyword */, sourceFile);
-            pushKeywordIf(keywords, finallyKeyword, 98 /* FinallyKeyword */);
-          }
-          return keywords;
-        }
-        function getThrowOccurrences(throwStatement, sourceFile) {
-          const owner = getThrowStatementOwner(throwStatement);
-          if (!owner) {
-            return void 0;
-          }
-          const keywords = [];
-          forEach(aggregateOwnedThrowStatements(owner), (throwStatement2) => {
-            keywords.push(findChildOfKind(throwStatement2, 111 /* ThrowKeyword */, sourceFile));
-          });
-          if (isFunctionBlock(owner)) {
-            forEachReturnStatement(owner, (returnStatement) => {
-              keywords.push(findChildOfKind(returnStatement, 107 /* ReturnKeyword */, sourceFile));
-            });
-          }
-          return keywords;
-        }
-        function getReturnOccurrences(returnStatement, sourceFile) {
-          const func = getContainingFunction(returnStatement);
-          if (!func) {
-            return void 0;
-          }
-          const keywords = [];
-          forEachReturnStatement(cast(func.body, isBlock), (returnStatement2) => {
-            keywords.push(findChildOfKind(returnStatement2, 107 /* ReturnKeyword */, sourceFile));
-          });
-          forEach(aggregateOwnedThrowStatements(func.body), (throwStatement) => {
-            keywords.push(findChildOfKind(throwStatement, 111 /* ThrowKeyword */, sourceFile));
-          });
-          return keywords;
-        }
-        function getAsyncAndAwaitOccurrences(node) {
-          const func = getContainingFunction(node);
-          if (!func) {
-            return void 0;
-          }
-          const keywords = [];
-          if (func.modifiers) {
-            func.modifiers.forEach((modifier) => {
-              pushKeywordIf(keywords, modifier, 134 /* AsyncKeyword */);
-            });
+              return;
+            }
+            break;
           }
-          forEachChild(func, (child) => {
-            traverseWithoutCrossingFunction(child, (node2) => {
-              if (isAwaitExpression(node2)) {
-                pushKeywordIf(keywords, node2.getFirstToken(), 135 /* AwaitKeyword */);
-              }
-            });
-          });
-          return keywords;
+          case 4 /* ThisProperty */:
+          case 0 /* None */:
+          case 8 /* ObjectDefinePropertyExports */:
+            break;
+          default:
+            Debug.assertNever(special);
         }
-        function getYieldOccurrences(node) {
-          const func = getContainingFunction(node);
-          if (!func) {
-            return void 0;
-          }
-          const keywords = [];
-          forEachChild(func, (child) => {
-            traverseWithoutCrossingFunction(child, (node2) => {
-              if (isYieldExpression(node2)) {
-                pushKeywordIf(keywords, node2.getFirstToken(), 127 /* YieldKeyword */);
+      }
+      default:
+        if (hasJSDocNodes(node)) {
+          forEach(node.jsDoc, (jsDoc) => {
+            forEach(jsDoc.tags, (tag) => {
+              if (isJSDocTypeAlias(tag)) {
+                addLeafNode(tag);
               }
             });
           });
-          return keywords;
-        }
-        function traverseWithoutCrossingFunction(node, cb) {
-          cb(node);
-          if (!isFunctionLike(node) && !isClassLike(node) && !isInterfaceDeclaration(node) && !isModuleDeclaration(node) && !isTypeAliasDeclaration(node) && !isTypeNode(node)) {
-            forEachChild(node, (child) => traverseWithoutCrossingFunction(child, cb));
-          }
         }
-        function getIfElseOccurrences(ifStatement, sourceFile) {
-          const keywords = getIfElseKeywords(ifStatement, sourceFile);
-          const result = [];
-          for (let i = 0; i < keywords.length; i++) {
-            if (keywords[i].kind === 93 /* ElseKeyword */ && i < keywords.length - 1) {
-              const elseKeyword = keywords[i];
-              const ifKeyword = keywords[i + 1];
-              let shouldCombineElseAndIf = true;
-              for (let j = ifKeyword.getStart(sourceFile) - 1; j >= elseKeyword.end; j--) {
-                if (!isWhiteSpaceSingleLine(sourceFile.text.charCodeAt(j))) {
-                  shouldCombineElseAndIf = false;
-                  break;
-                }
-              }
-              if (shouldCombineElseAndIf) {
-                result.push({
-                  fileName: sourceFile.fileName,
-                  textSpan: createTextSpanFromBounds(elseKeyword.getStart(), ifKeyword.end),
-                  kind: "reference" /* reference */
-                });
-                i++;
-                continue;
-              }
-            }
-            result.push(getHighlightSpanForNode(keywords[i], sourceFile));
+        forEachChild(node, addChildrenRecursively);
+    }
+  }
+  function mergeChildren(children, node) {
+    const nameToItems = /* @__PURE__ */ new Map();
+    filterMutate(children, (child, index) => {
+      const declName = child.name || getNameOfDeclaration(child.node);
+      const name = declName && nodeText(declName);
+      if (!name) {
+        return true;
+      }
+      const itemsWithSameName = nameToItems.get(name);
+      if (!itemsWithSameName) {
+        nameToItems.set(name, child);
+        return true;
+      }
+      if (itemsWithSameName instanceof Array) {
+        for (const itemWithSameName of itemsWithSameName) {
+          if (tryMerge(itemWithSameName, child, index, node)) {
+            return false;
           }
-          return result;
         }
-        function getIfElseKeywords(ifStatement, sourceFile) {
-          const keywords = [];
-          while (isIfStatement(ifStatement.parent) && ifStatement.parent.elseStatement === ifStatement) {
-            ifStatement = ifStatement.parent;
-          }
-          while (true) {
-            const children = ifStatement.getChildren(sourceFile);
-            pushKeywordIf(keywords, children[0], 101 /* IfKeyword */);
-            for (let i = children.length - 1; i >= 0; i--) {
-              if (pushKeywordIf(keywords, children[i], 93 /* ElseKeyword */)) {
-                break;
-              }
-            }
-            if (!ifStatement.elseStatement || !isIfStatement(ifStatement.elseStatement)) {
-              break;
+        itemsWithSameName.push(child);
+        return true;
+      } else {
+        const itemWithSameName = itemsWithSameName;
+        if (tryMerge(itemWithSameName, child, index, node)) {
+          return false;
+        }
+        nameToItems.set(name, [itemWithSameName, child]);
+        return true;
+      }
+    });
+  }
+  function tryMergeEs5Class(a, b, bIndex, parent2) {
+    function isPossibleConstructor(node) {
+      return isFunctionExpression(node) || isFunctionDeclaration(node) || isVariableDeclaration(node);
+    }
+    const bAssignmentDeclarationKind = isBinaryExpression(b.node) || isCallExpression(b.node) ? getAssignmentDeclarationKind(b.node) : 0 /* None */;
+    const aAssignmentDeclarationKind = isBinaryExpression(a.node) || isCallExpression(a.node) ? getAssignmentDeclarationKind(a.node) : 0 /* None */;
+    if (isEs5ClassMember[bAssignmentDeclarationKind] && isEs5ClassMember[aAssignmentDeclarationKind] || isPossibleConstructor(a.node) && isEs5ClassMember[bAssignmentDeclarationKind] || isPossibleConstructor(b.node) && isEs5ClassMember[aAssignmentDeclarationKind] || isClassDeclaration(a.node) && isSynthesized(a.node) && isEs5ClassMember[bAssignmentDeclarationKind] || isClassDeclaration(b.node) && isEs5ClassMember[aAssignmentDeclarationKind] || isClassDeclaration(a.node) && isSynthesized(a.node) && isPossibleConstructor(b.node) || isClassDeclaration(b.node) && isPossibleConstructor(a.node) && isSynthesized(a.node)) {
+      let lastANode = a.additionalNodes && lastOrUndefined(a.additionalNodes) || a.node;
+      if (!isClassDeclaration(a.node) && !isClassDeclaration(b.node) || isPossibleConstructor(a.node) || isPossibleConstructor(b.node)) {
+        const ctorFunction = isPossibleConstructor(a.node) ? a.node : isPossibleConstructor(b.node) ? b.node : void 0;
+        if (ctorFunction !== void 0) {
+          const ctorNode = setTextRange(
+            factory.createConstructorDeclaration(
+              /*modifiers*/
+              void 0,
+              [],
+              /*body*/
+              void 0
+            ),
+            ctorFunction
+          );
+          const ctor = emptyNavigationBarNode(ctorNode);
+          ctor.indent = a.indent + 1;
+          ctor.children = a.node === ctorFunction ? a.children : b.children;
+          a.children = a.node === ctorFunction ? concatenate([ctor], b.children || [b]) : concatenate(a.children || [{ ...a }], [ctor]);
+        } else {
+          if (a.children || b.children) {
+            a.children = concatenate(a.children || [{ ...a }], b.children || [b]);
+            if (a.children) {
+              mergeChildren(a.children, a);
+              sortChildren(a.children);
             }
-            ifStatement = ifStatement.elseStatement;
           }
-          return keywords;
         }
-        function isLabeledBy(node, labelName) {
-          return !!findAncestor(node.parent, (owner) => !isLabeledStatement(owner) ? "quit" : owner.label.escapedText === labelName);
+        lastANode = a.node = setTextRange(
+          factory.createClassDeclaration(
+            /*modifiers*/
+            void 0,
+            a.name || factory.createIdentifier("__class__"),
+            /*typeParameters*/
+            void 0,
+            /*heritageClauses*/
+            void 0,
+            []
+          ),
+          a.node
+        );
+      } else {
+        a.children = concatenate(a.children, b.children);
+        if (a.children) {
+          mergeChildren(a.children, a);
         }
-      })(DocumentHighlights || (DocumentHighlights = {}));
+      }
+      const bNode = b.node;
+      if (parent2.children[bIndex - 1].node.end === lastANode.end) {
+        setTextRange(lastANode, { pos: lastANode.pos, end: bNode.end });
+      } else {
+        if (!a.additionalNodes)
+          a.additionalNodes = [];
+        a.additionalNodes.push(setTextRange(
+          factory.createClassDeclaration(
+            /*modifiers*/
+            void 0,
+            a.name || factory.createIdentifier("__class__"),
+            /*typeParameters*/
+            void 0,
+            /*heritageClauses*/
+            void 0,
+            []
+          ),
+          b.node
+        ));
+      }
+      return true;
     }
-  });
-
-  // src/services/documentRegistry.ts
-  function isDocumentRegistryEntry(entry) {
-    return !!entry.sourceFile;
+    return bAssignmentDeclarationKind === 0 /* None */ ? false : true;
   }
-  function createDocumentRegistry(useCaseSensitiveFileNames, currentDirectory) {
-    return createDocumentRegistryInternal(useCaseSensitiveFileNames, currentDirectory);
+  function tryMerge(a, b, bIndex, parent2) {
+    if (tryMergeEs5Class(a, b, bIndex, parent2)) {
+      return true;
+    }
+    if (shouldReallyMerge(a.node, b.node, parent2)) {
+      merge(a, b);
+      return true;
+    }
+    return false;
   }
-  function createDocumentRegistryInternal(useCaseSensitiveFileNames, currentDirectory = "", externalCache) {
-    const buckets = /* @__PURE__ */ new Map();
-    const getCanonicalFileName = createGetCanonicalFileName(!!useCaseSensitiveFileNames);
-    function reportStats() {
-      const bucketInfoArray = arrayFrom(buckets.keys()).filter((name) => name && name.charAt(0) === "_").map((name) => {
-        const entries = buckets.get(name);
-        const sourceFiles = [];
-        entries.forEach((entry, name2) => {
-          if (isDocumentRegistryEntry(entry)) {
-            sourceFiles.push({
-              name: name2,
-              scriptKind: entry.sourceFile.scriptKind,
-              refCount: entry.languageServiceRefCount
-            });
-          } else {
-            entry.forEach((value, scriptKind) => sourceFiles.push({ name: name2, scriptKind, refCount: value.languageServiceRefCount }));
-          }
-        });
-        sourceFiles.sort((x, y) => y.refCount - x.refCount);
-        return {
-          bucket: name,
-          sourceFiles
-        };
-      });
-      return JSON.stringify(bucketInfoArray, void 0, 2);
+  function shouldReallyMerge(a, b, parent2) {
+    if (a.kind !== b.kind || a.parent !== b.parent && !(isOwnChild(a, parent2) && isOwnChild(b, parent2))) {
+      return false;
     }
-    function getCompilationSettings(settingsOrHost) {
-      if (typeof settingsOrHost.getCompilationSettings === "function") {
-        return settingsOrHost.getCompilationSettings();
-      }
-      return settingsOrHost;
+    switch (a.kind) {
+      case 172 /* PropertyDeclaration */:
+      case 174 /* MethodDeclaration */:
+      case 177 /* GetAccessor */:
+      case 178 /* SetAccessor */:
+        return isStatic(a) === isStatic(b);
+      case 267 /* ModuleDeclaration */:
+        return areSameModule(a, b) && getFullyQualifiedModuleName(a) === getFullyQualifiedModuleName(b);
+      default:
+        return true;
     }
-    function acquireDocument(fileName, compilationSettings, scriptSnapshot, version2, scriptKind, languageVersionOrOptions) {
-      const path = toPath(fileName, currentDirectory, getCanonicalFileName);
-      const key = getKeyForCompilationSettings(getCompilationSettings(compilationSettings));
-      return acquireDocumentWithKey(fileName, path, compilationSettings, key, scriptSnapshot, version2, scriptKind, languageVersionOrOptions);
+  }
+  function isSynthesized(node) {
+    return !!(node.flags & 16 /* Synthesized */);
+  }
+  function isOwnChild(n, parent2) {
+    const par = isModuleBlock(n.parent) ? n.parent.parent : n.parent;
+    return par === parent2.node || contains(parent2.additionalNodes, par);
+  }
+  function areSameModule(a, b) {
+    if (!a.body || !b.body) {
+      return a.body === b.body;
     }
-    function acquireDocumentWithKey(fileName, path, compilationSettings, key, scriptSnapshot, version2, scriptKind, languageVersionOrOptions) {
-      return acquireOrUpdateDocument(
-        fileName,
-        path,
-        compilationSettings,
-        key,
-        scriptSnapshot,
-        version2,
-        /*acquiring*/
-        true,
-        scriptKind,
-        languageVersionOrOptions
-      );
+    return a.body.kind === b.body.kind && (a.body.kind !== 267 /* ModuleDeclaration */ || areSameModule(a.body, b.body));
+  }
+  function merge(target, source) {
+    target.additionalNodes = target.additionalNodes || [];
+    target.additionalNodes.push(source.node);
+    if (source.additionalNodes) {
+      target.additionalNodes.push(...source.additionalNodes);
     }
-    function updateDocument(fileName, compilationSettings, scriptSnapshot, version2, scriptKind, languageVersionOrOptions) {
-      const path = toPath(fileName, currentDirectory, getCanonicalFileName);
-      const key = getKeyForCompilationSettings(getCompilationSettings(compilationSettings));
-      return updateDocumentWithKey(fileName, path, compilationSettings, key, scriptSnapshot, version2, scriptKind, languageVersionOrOptions);
+    target.children = concatenate(target.children, source.children);
+    if (target.children) {
+      mergeChildren(target.children, target);
+      sortChildren(target.children);
     }
-    function updateDocumentWithKey(fileName, path, compilationSettings, key, scriptSnapshot, version2, scriptKind, languageVersionOrOptions) {
-      return acquireOrUpdateDocument(
-        fileName,
-        path,
-        getCompilationSettings(compilationSettings),
-        key,
-        scriptSnapshot,
-        version2,
-        /*acquiring*/
-        false,
-        scriptKind,
-        languageVersionOrOptions
-      );
+  }
+  function sortChildren(children) {
+    children.sort(compareChildren);
+  }
+  function compareChildren(child1, child2) {
+    return compareStringsCaseSensitiveUI(tryGetName(child1.node), tryGetName(child2.node)) || compareValues(navigationBarNodeKind(child1), navigationBarNodeKind(child2));
+  }
+  function tryGetName(node) {
+    if (node.kind === 267 /* ModuleDeclaration */) {
+      return getModuleName(node);
     }
-    function getDocumentRegistryEntry(bucketEntry, scriptKind) {
-      const entry = isDocumentRegistryEntry(bucketEntry) ? bucketEntry : bucketEntry.get(Debug.checkDefined(scriptKind, "If there are more than one scriptKind's for same document the scriptKind should be provided"));
-      Debug.assert(scriptKind === void 0 || !entry || entry.sourceFile.scriptKind === scriptKind, `Script kind should match provided ScriptKind:${scriptKind} and sourceFile.scriptKind: ${entry == null ? void 0 : entry.sourceFile.scriptKind}, !entry: ${!entry}`);
-      return entry;
+    const declName = getNameOfDeclaration(node);
+    if (declName && isPropertyName(declName)) {
+      const propertyName = getPropertyNameForPropertyNameNode(declName);
+      return propertyName && unescapeLeadingUnderscores(propertyName);
     }
-    function acquireOrUpdateDocument(fileName, path, compilationSettingsOrHost, key, scriptSnapshot, version2, acquiring, scriptKind, languageVersionOrOptions) {
-      var _a, _b, _c, _d;
-      scriptKind = ensureScriptKind(fileName, scriptKind);
-      const compilationSettings = getCompilationSettings(compilationSettingsOrHost);
-      const host = compilationSettingsOrHost === compilationSettings ? void 0 : compilationSettingsOrHost;
-      const scriptTarget = scriptKind === 6 /* JSON */ ? 100 /* JSON */ : getEmitScriptTarget(compilationSettings);
-      const sourceFileOptions = typeof languageVersionOrOptions === "object" ? languageVersionOrOptions : {
-        languageVersion: scriptTarget,
-        impliedNodeFormat: host && getImpliedNodeFormatForFile(path, (_d = (_c = (_b = (_a = host.getCompilerHost) == null ? void 0 : _a.call(host)) == null ? void 0 : _b.getModuleResolutionCache) == null ? void 0 : _c.call(_b)) == null ? void 0 : _d.getPackageJsonInfoCache(), host, compilationSettings),
-        setExternalModuleIndicator: getSetExternalModuleIndicator(compilationSettings)
-      };
-      sourceFileOptions.languageVersion = scriptTarget;
-      const oldBucketCount = buckets.size;
-      const keyWithMode = getDocumentRegistryBucketKeyWithMode(key, sourceFileOptions.impliedNodeFormat);
-      const bucket = getOrUpdate(buckets, keyWithMode, () => /* @__PURE__ */ new Map());
-      if (tracing) {
-        if (buckets.size > oldBucketCount) {
-          tracing.instant(tracing.Phase.Session, "createdDocumentRegistryBucket", { configFilePath: compilationSettings.configFilePath, key: keyWithMode });
-        }
-        const otherBucketKey = !isDeclarationFileName(path) && forEachEntry(buckets, (bucket2, bucketKey) => bucketKey !== keyWithMode && bucket2.has(path) && bucketKey);
-        if (otherBucketKey) {
-          tracing.instant(tracing.Phase.Session, "documentRegistryBucketOverlap", { path, key1: otherBucketKey, key2: keyWithMode });
-        }
-      }
-      const bucketEntry = bucket.get(path);
-      let entry = bucketEntry && getDocumentRegistryEntry(bucketEntry, scriptKind);
-      if (!entry && externalCache) {
-        const sourceFile = externalCache.getDocument(keyWithMode, path);
-        if (sourceFile) {
-          Debug.assert(acquiring);
-          entry = {
-            sourceFile,
-            languageServiceRefCount: 0
-          };
-          setBucketEntry();
-        }
+    switch (node.kind) {
+      case 218 /* FunctionExpression */:
+      case 219 /* ArrowFunction */:
+      case 231 /* ClassExpression */:
+        return getFunctionOrClassName(node);
+      default:
+        return void 0;
+    }
+  }
+  function getItemName(node, name) {
+    if (node.kind === 267 /* ModuleDeclaration */) {
+      return cleanText(getModuleName(node));
+    }
+    if (name) {
+      const text = isIdentifier(name) ? name.text : isElementAccessExpression(name) ? `[${nodeText(name.argumentExpression)}]` : nodeText(name);
+      if (text.length > 0) {
+        return cleanText(text);
       }
-      if (!entry) {
-        const sourceFile = createLanguageServiceSourceFile(
-          fileName,
-          scriptSnapshot,
-          sourceFileOptions,
-          version2,
-          /*setNodeParents*/
-          false,
-          scriptKind
-        );
-        if (externalCache) {
-          externalCache.setDocument(keyWithMode, path, sourceFile);
+    }
+    switch (node.kind) {
+      case 312 /* SourceFile */:
+        const sourceFile = node;
+        return isExternalModule(sourceFile) ? `"${escapeString(getBaseFileName(removeFileExtension(normalizePath(sourceFile.fileName))))}"` : "";
+      case 277 /* ExportAssignment */:
+        return isExportAssignment(node) && node.isExportEquals ? "export=" /* ExportEquals */ : "default" /* Default */;
+      case 219 /* ArrowFunction */:
+      case 262 /* FunctionDeclaration */:
+      case 218 /* FunctionExpression */:
+      case 263 /* ClassDeclaration */:
+      case 231 /* ClassExpression */:
+        if (getSyntacticModifierFlags(node) & 2048 /* Default */) {
+          return "default";
         }
-        entry = {
-          sourceFile,
-          languageServiceRefCount: 1
-        };
-        setBucketEntry();
-      } else {
-        if (entry.sourceFile.version !== version2) {
-          entry.sourceFile = updateLanguageServiceSourceFile(
-            entry.sourceFile,
-            scriptSnapshot,
-            version2,
-            scriptSnapshot.getChangeRange(entry.sourceFile.scriptSnapshot)
-          );
-          if (externalCache) {
-            externalCache.setDocument(keyWithMode, path, entry.sourceFile);
+        return getFunctionOrClassName(node);
+      case 176 /* Constructor */:
+        return "constructor";
+      case 180 /* ConstructSignature */:
+        return "new()";
+      case 179 /* CallSignature */:
+        return "()";
+      case 181 /* IndexSignature */:
+        return "[]";
+      default:
+        return "";
+    }
+  }
+  function primaryNavBarMenuItems(root) {
+    const primaryNavBarMenuItems2 = [];
+    function recur(item) {
+      if (shouldAppearInPrimaryNavBarMenu(item)) {
+        primaryNavBarMenuItems2.push(item);
+        if (item.children) {
+          for (const child of item.children) {
+            recur(child);
           }
         }
-        if (acquiring) {
-          entry.languageServiceRefCount++;
-        }
       }
-      Debug.assert(entry.languageServiceRefCount !== 0);
-      return entry.sourceFile;
-      function setBucketEntry() {
-        if (!bucketEntry) {
-          bucket.set(path, entry);
-        } else if (isDocumentRegistryEntry(bucketEntry)) {
-          const scriptKindMap = /* @__PURE__ */ new Map();
-          scriptKindMap.set(bucketEntry.sourceFile.scriptKind, bucketEntry);
-          scriptKindMap.set(scriptKind, entry);
-          bucket.set(path, scriptKindMap);
-        } else {
-          bucketEntry.set(scriptKind, entry);
-        }
-      }
-    }
-    function releaseDocument(fileName, compilationSettings, scriptKind, impliedNodeFormat) {
-      const path = toPath(fileName, currentDirectory, getCanonicalFileName);
-      const key = getKeyForCompilationSettings(compilationSettings);
-      return releaseDocumentWithKey(path, key, scriptKind, impliedNodeFormat);
     }
-    function releaseDocumentWithKey(path, key, scriptKind, impliedNodeFormat) {
-      const bucket = Debug.checkDefined(buckets.get(getDocumentRegistryBucketKeyWithMode(key, impliedNodeFormat)));
-      const bucketEntry = bucket.get(path);
-      const entry = getDocumentRegistryEntry(bucketEntry, scriptKind);
-      entry.languageServiceRefCount--;
-      Debug.assert(entry.languageServiceRefCount >= 0);
-      if (entry.languageServiceRefCount === 0) {
-        if (isDocumentRegistryEntry(bucketEntry)) {
-          bucket.delete(path);
-        } else {
-          bucketEntry.delete(scriptKind);
-          if (bucketEntry.size === 1) {
-            bucket.set(path, firstDefinedIterator(bucketEntry.values(), identity));
-          }
+    recur(root);
+    return primaryNavBarMenuItems2;
+    function shouldAppearInPrimaryNavBarMenu(item) {
+      if (item.children) {
+        return true;
+      }
+      switch (navigationBarNodeKind(item)) {
+        case 263 /* ClassDeclaration */:
+        case 231 /* ClassExpression */:
+        case 266 /* EnumDeclaration */:
+        case 264 /* InterfaceDeclaration */:
+        case 267 /* ModuleDeclaration */:
+        case 312 /* SourceFile */:
+        case 265 /* TypeAliasDeclaration */:
+        case 353 /* JSDocTypedefTag */:
+        case 345 /* JSDocCallbackTag */:
+          return true;
+        case 219 /* ArrowFunction */:
+        case 262 /* FunctionDeclaration */:
+        case 218 /* FunctionExpression */:
+          return isTopLevelFunctionDeclaration(item);
+        default:
+          return false;
+      }
+      function isTopLevelFunctionDeclaration(item2) {
+        if (!item2.node.body) {
+          return false;
+        }
+        switch (navigationBarNodeKind(item2.parent)) {
+          case 268 /* ModuleBlock */:
+          case 312 /* SourceFile */:
+          case 174 /* MethodDeclaration */:
+          case 176 /* Constructor */:
+            return true;
+          default:
+            return false;
         }
       }
     }
-    function getLanguageServiceRefCounts(path, scriptKind) {
-      return arrayFrom(buckets.entries(), ([key, bucket]) => {
-        const bucketEntry = bucket.get(path);
-        const entry = bucketEntry && getDocumentRegistryEntry(bucketEntry, scriptKind);
-        return [key, entry && entry.languageServiceRefCount];
-      });
-    }
+  }
+  function convertToTree(n) {
     return {
-      acquireDocument,
-      acquireDocumentWithKey,
-      updateDocument,
-      updateDocumentWithKey,
-      releaseDocument,
-      releaseDocumentWithKey,
-      getLanguageServiceRefCounts,
-      reportStats,
-      getKeyForCompilationSettings
+      text: getItemName(n.node, n.name),
+      kind: getNodeKind(n.node),
+      kindModifiers: getModifiers2(n.node),
+      spans: getSpans(n),
+      nameSpan: n.name && getNodeSpan(n.name),
+      childItems: map(n.children, convertToTree)
     };
   }
-  function getKeyForCompilationSettings(settings) {
-    return getKeyForCompilerOptions(settings, sourceFileAffectingCompilerOptions);
-  }
-  function getDocumentRegistryBucketKeyWithMode(key, mode) {
-    return mode ? `${key}|${mode}` : key;
-  }
-  var init_documentRegistry = __esm({
-    "src/services/documentRegistry.ts"() {
-      "use strict";
-      init_ts4();
-    }
-  });
-
-  // src/services/getEditsForFileRename.ts
-  function getEditsForFileRename(program, oldFileOrDirPath, newFileOrDirPath, host, formatContext, preferences, sourceMapper) {
-    const useCaseSensitiveFileNames = hostUsesCaseSensitiveFileNames(host);
-    const getCanonicalFileName = createGetCanonicalFileName(useCaseSensitiveFileNames);
-    const oldToNew = getPathUpdater(oldFileOrDirPath, newFileOrDirPath, getCanonicalFileName, sourceMapper);
-    const newToOld = getPathUpdater(newFileOrDirPath, oldFileOrDirPath, getCanonicalFileName, sourceMapper);
-    return ts_textChanges_exports.ChangeTracker.with({ host, formatContext, preferences }, (changeTracker) => {
-      updateTsconfigFiles(program, changeTracker, oldToNew, oldFileOrDirPath, newFileOrDirPath, host.getCurrentDirectory(), useCaseSensitiveFileNames);
-      updateImports(program, changeTracker, oldToNew, newToOld, host, getCanonicalFileName);
-    });
-  }
-  function getPathUpdater(oldFileOrDirPath, newFileOrDirPath, getCanonicalFileName, sourceMapper) {
-    const canonicalOldPath = getCanonicalFileName(oldFileOrDirPath);
-    return (path) => {
-      const originalPath = sourceMapper && sourceMapper.tryGetSourcePosition({ fileName: path, pos: 0 });
-      const updatedPath = getUpdatedPath(originalPath ? originalPath.fileName : path);
-      return originalPath ? updatedPath === void 0 ? void 0 : makeCorrespondingRelativeChange(originalPath.fileName, updatedPath, path, getCanonicalFileName) : updatedPath;
+  function convertToPrimaryNavBarMenuItem(n) {
+    return {
+      text: getItemName(n.node, n.name),
+      kind: getNodeKind(n.node),
+      kindModifiers: getModifiers2(n.node),
+      spans: getSpans(n),
+      childItems: map(n.children, convertToSecondaryNavBarMenuItem) || emptyChildItemArray,
+      indent: n.indent,
+      bolded: false,
+      grayed: false
     };
-    function getUpdatedPath(pathToUpdate) {
-      if (getCanonicalFileName(pathToUpdate) === canonicalOldPath)
-        return newFileOrDirPath;
-      const suffix = tryRemoveDirectoryPrefix(pathToUpdate, canonicalOldPath, getCanonicalFileName);
-      return suffix === void 0 ? void 0 : newFileOrDirPath + "/" + suffix;
+    function convertToSecondaryNavBarMenuItem(n2) {
+      return {
+        text: getItemName(n2.node, n2.name),
+        kind: getNodeKind(n2.node),
+        kindModifiers: getNodeModifiers(n2.node),
+        spans: getSpans(n2),
+        childItems: emptyChildItemArray,
+        indent: 0,
+        bolded: false,
+        grayed: false
+      };
     }
   }
-  function makeCorrespondingRelativeChange(a0, b0, a1, getCanonicalFileName) {
-    const rel = getRelativePathFromFile(a0, b0, getCanonicalFileName);
-    return combinePathsSafe(getDirectoryPath(a1), rel);
-  }
-  function updateTsconfigFiles(program, changeTracker, oldToNew, oldFileOrDirPath, newFileOrDirPath, currentDirectory, useCaseSensitiveFileNames) {
-    const { configFile } = program.getCompilerOptions();
-    if (!configFile)
-      return;
-    const configDir = getDirectoryPath(configFile.fileName);
-    const jsonObjectLiteral = getTsConfigObjectLiteralExpression(configFile);
-    if (!jsonObjectLiteral)
-      return;
-    forEachProperty(jsonObjectLiteral, (property, propertyName) => {
-      switch (propertyName) {
-        case "files":
-        case "include":
-        case "exclude": {
-          const foundExactMatch = updatePaths(property);
-          if (foundExactMatch || propertyName !== "include" || !isArrayLiteralExpression(property.initializer))
-            return;
-          const includes = mapDefined(property.initializer.elements, (e) => isStringLiteral(e) ? e.text : void 0);
-          if (includes.length === 0)
-            return;
-          const matchers = getFileMatcherPatterns(
-            configDir,
-            /*excludes*/
-            [],
-            includes,
-            useCaseSensitiveFileNames,
-            currentDirectory
-          );
-          if (getRegexFromPattern(Debug.checkDefined(matchers.includeFilePattern), useCaseSensitiveFileNames).test(oldFileOrDirPath) && !getRegexFromPattern(Debug.checkDefined(matchers.includeFilePattern), useCaseSensitiveFileNames).test(newFileOrDirPath)) {
-            changeTracker.insertNodeAfter(configFile, last(property.initializer.elements), factory.createStringLiteral(relativePath(newFileOrDirPath)));
-          }
-          return;
-        }
-        case "compilerOptions":
-          forEachProperty(property.initializer, (property2, propertyName2) => {
-            const option = getOptionFromName(propertyName2);
-            Debug.assert((option == null ? void 0 : option.type) !== "listOrElement");
-            if (option && (option.isFilePath || option.type === "list" && option.element.isFilePath)) {
-              updatePaths(property2);
-            } else if (propertyName2 === "paths") {
-              forEachProperty(property2.initializer, (pathsProperty) => {
-                if (!isArrayLiteralExpression(pathsProperty.initializer))
-                  return;
-                for (const e of pathsProperty.initializer.elements) {
-                  tryUpdateString(e);
-                }
-              });
-            }
-          });
-          return;
-      }
-    });
-    function updatePaths(property) {
-      const elements = isArrayLiteralExpression(property.initializer) ? property.initializer.elements : [property.initializer];
-      let foundExactMatch = false;
-      for (const element of elements) {
-        foundExactMatch = tryUpdateString(element) || foundExactMatch;
-      }
-      return foundExactMatch;
-    }
-    function tryUpdateString(element) {
-      if (!isStringLiteral(element))
-        return false;
-      const elementFileName = combinePathsSafe(configDir, element.text);
-      const updated = oldToNew(elementFileName);
-      if (updated !== void 0) {
-        changeTracker.replaceRangeWithText(configFile, createStringRange(element, configFile), relativePath(updated));
-        return true;
+  function getSpans(n) {
+    const spans = [getNodeSpan(n.node)];
+    if (n.additionalNodes) {
+      for (const node of n.additionalNodes) {
+        spans.push(getNodeSpan(node));
       }
-      return false;
     }
-    function relativePath(path) {
-      return getRelativePathFromDirectory(
-        configDir,
-        path,
-        /*ignoreCase*/
-        !useCaseSensitiveFileNames
-      );
+    return spans;
+  }
+  function getModuleName(moduleDeclaration) {
+    if (isAmbientModule(moduleDeclaration)) {
+      return getTextOfNode(moduleDeclaration.name);
     }
+    return getFullyQualifiedModuleName(moduleDeclaration);
   }
-  function updateImports(program, changeTracker, oldToNew, newToOld, host, getCanonicalFileName) {
-    const allFiles = program.getSourceFiles();
-    for (const sourceFile of allFiles) {
-      const newFromOld = oldToNew(sourceFile.fileName);
-      const newImportFromPath = newFromOld ?? sourceFile.fileName;
-      const newImportFromDirectory = getDirectoryPath(newImportFromPath);
-      const oldFromNew = newToOld(sourceFile.fileName);
-      const oldImportFromPath = oldFromNew || sourceFile.fileName;
-      const oldImportFromDirectory = getDirectoryPath(oldImportFromPath);
-      const importingSourceFileMoved = newFromOld !== void 0 || oldFromNew !== void 0;
-      updateImportsWorker(
-        sourceFile,
-        changeTracker,
-        (referenceText) => {
-          if (!pathIsRelative(referenceText))
-            return void 0;
-          const oldAbsolute = combinePathsSafe(oldImportFromDirectory, referenceText);
-          const newAbsolute = oldToNew(oldAbsolute);
-          return newAbsolute === void 0 ? void 0 : ensurePathIsNonModuleName(getRelativePathFromDirectory(newImportFromDirectory, newAbsolute, getCanonicalFileName));
-        },
-        (importLiteral) => {
-          const importedModuleSymbol = program.getTypeChecker().getSymbolAtLocation(importLiteral);
-          if ((importedModuleSymbol == null ? void 0 : importedModuleSymbol.declarations) && importedModuleSymbol.declarations.some((d) => isAmbientModule(d)))
-            return void 0;
-          const toImport = oldFromNew !== void 0 ? getSourceFileToImportFromResolved(
-            importLiteral,
-            resolveModuleName(importLiteral.text, oldImportFromPath, program.getCompilerOptions(), host),
-            oldToNew,
-            allFiles
-          ) : getSourceFileToImport(importedModuleSymbol, importLiteral, sourceFile, program, host, oldToNew);
-          return toImport !== void 0 && (toImport.updated || importingSourceFileMoved && pathIsRelative(importLiteral.text)) ? ts_moduleSpecifiers_exports.updateModuleSpecifier(program.getCompilerOptions(), sourceFile, getCanonicalFileName(newImportFromPath), toImport.newFileName, createModuleSpecifierResolutionHost(program, host), importLiteral.text) : void 0;
-        }
-      );
+  function getFullyQualifiedModuleName(moduleDeclaration) {
+    const result = [getTextOfIdentifierOrLiteral(moduleDeclaration.name)];
+    while (moduleDeclaration.body && moduleDeclaration.body.kind === 267 /* ModuleDeclaration */) {
+      moduleDeclaration = moduleDeclaration.body;
+      result.push(getTextOfIdentifierOrLiteral(moduleDeclaration.name));
     }
+    return result.join(".");
   }
-  function combineNormal(pathA, pathB) {
-    return normalizePath(combinePaths(pathA, pathB));
+  function getInteriorModule(decl) {
+    return decl.body && isModuleDeclaration(decl.body) ? getInteriorModule(decl.body) : decl;
   }
-  function combinePathsSafe(pathA, pathB) {
-    return ensurePathIsNonModuleName(combineNormal(pathA, pathB));
+  function isComputedProperty(member) {
+    return !member.name || member.name.kind === 167 /* ComputedPropertyName */;
   }
-  function getSourceFileToImport(importedModuleSymbol, importLiteral, importingSourceFile, program, host, oldToNew) {
-    var _a;
-    if (importedModuleSymbol) {
-      const oldFileName = find(importedModuleSymbol.declarations, isSourceFile).fileName;
-      const newFileName = oldToNew(oldFileName);
-      return newFileName === void 0 ? { newFileName: oldFileName, updated: false } : { newFileName, updated: true };
-    } else {
-      const mode = getModeForUsageLocation(importingSourceFile, importLiteral);
-      const resolved = host.resolveModuleNameLiterals || !host.resolveModuleNames ? (_a = importingSourceFile.resolvedModules) == null ? void 0 : _a.get(importLiteral.text, mode) : host.getResolvedModuleWithFailedLookupLocationsFromCache && host.getResolvedModuleWithFailedLookupLocationsFromCache(importLiteral.text, importingSourceFile.fileName, mode);
-      return getSourceFileToImportFromResolved(importLiteral, resolved, oldToNew, program.getSourceFiles());
-    }
+  function getNodeSpan(node) {
+    return node.kind === 312 /* SourceFile */ ? createTextSpanFromRange(node) : createTextSpanFromNode(node, curSourceFile);
   }
-  function getSourceFileToImportFromResolved(importLiteral, resolved, oldToNew, sourceFiles) {
-    if (!resolved)
-      return void 0;
-    if (resolved.resolvedModule) {
-      const result2 = tryChange(resolved.resolvedModule.resolvedFileName);
-      if (result2)
-        return result2;
+  function getModifiers2(node) {
+    if (node.parent && node.parent.kind === 260 /* VariableDeclaration */) {
+      node = node.parent;
     }
-    const result = forEach(resolved.failedLookupLocations, tryChangeWithIgnoringPackageJsonExisting) || pathIsRelative(importLiteral.text) && forEach(resolved.failedLookupLocations, tryChangeWithIgnoringPackageJson);
-    if (result)
-      return result;
-    return resolved.resolvedModule && { newFileName: resolved.resolvedModule.resolvedFileName, updated: false };
-    function tryChangeWithIgnoringPackageJsonExisting(oldFileName) {
-      const newFileName = oldToNew(oldFileName);
-      return newFileName && find(sourceFiles, (src) => src.fileName === newFileName) ? tryChangeWithIgnoringPackageJson(oldFileName) : void 0;
+    return getNodeModifiers(node);
+  }
+  function getFunctionOrClassName(node) {
+    const { parent: parent2 } = node;
+    if (node.name && getFullWidth(node.name) > 0) {
+      return cleanText(declarationNameToString(node.name));
+    } else if (isVariableDeclaration(parent2)) {
+      return cleanText(declarationNameToString(parent2.name));
+    } else if (isBinaryExpression(parent2) && parent2.operatorToken.kind === 64 /* EqualsToken */) {
+      return nodeText(parent2.left).replace(whiteSpaceRegex, "");
+    } else if (isPropertyAssignment(parent2)) {
+      return nodeText(parent2.name);
+    } else if (getSyntacticModifierFlags(node) & 2048 /* Default */) {
+      return "default";
+    } else if (isClassLike(node)) {
+      return "";
+    } else if (isCallExpression(parent2)) {
+      let name = getCalledExpressionName(parent2.expression);
+      if (name !== void 0) {
+        name = cleanText(name);
+        if (name.length > maxLength) {
+          return `${name} callback`;
+        }
+        const args = cleanText(mapDefined(parent2.arguments, (a) => isStringLiteralLike(a) ? a.getText(curSourceFile) : void 0).join(", "));
+        return `${name}(${args}) callback`;
+      }
     }
-    function tryChangeWithIgnoringPackageJson(oldFileName) {
-      return !endsWith(oldFileName, "/package.json") ? tryChange(oldFileName) : void 0;
+    return "";
+  }
+  function getCalledExpressionName(expr) {
+    if (isIdentifier(expr)) {
+      return expr.text;
+    } else if (isPropertyAccessExpression(expr)) {
+      const left = getCalledExpressionName(expr.expression);
+      const right = expr.name.text;
+      return left === void 0 ? right : `${left}.${right}`;
+    } else {
+      return void 0;
     }
-    function tryChange(oldFileName) {
-      const newFileName = oldToNew(oldFileName);
-      return newFileName && { newFileName, updated: true };
+  }
+  function isFunctionOrClassExpression(node) {
+    switch (node.kind) {
+      case 219 /* ArrowFunction */:
+      case 218 /* FunctionExpression */:
+      case 231 /* ClassExpression */:
+        return true;
+      default:
+        return false;
     }
   }
-  function updateImportsWorker(sourceFile, changeTracker, updateRef, updateImport2) {
-    for (const ref of sourceFile.referencedFiles || emptyArray) {
-      const updated = updateRef(ref.fileName);
-      if (updated !== void 0 && updated !== sourceFile.text.slice(ref.pos, ref.end))
-        changeTracker.replaceRangeWithText(sourceFile, ref, updated);
+  function cleanText(text) {
+    text = text.length > maxLength ? text.substring(0, maxLength) + "..." : text;
+    return text.replace(/\\?(\r?\n|\r|\u2028|\u2029)/g, "");
+  }
+  var whiteSpaceRegex, maxLength, curCancellationToken, curSourceFile, parentsStack, parent, trackedEs5ClassesStack, trackedEs5Classes, emptyChildItemArray, isEs5ClassMember;
+  var init_navigationBar = __esm({
+    "src/services/navigationBar.ts"() {
+      "use strict";
+      init_ts4();
+      whiteSpaceRegex = /\s+/g;
+      maxLength = 150;
+      parentsStack = [];
+      trackedEs5ClassesStack = [];
+      emptyChildItemArray = [];
+      isEs5ClassMember = {
+        [5 /* Property */]: true,
+        [3 /* PrototypeProperty */]: true,
+        [7 /* ObjectDefinePropertyValue */]: true,
+        [9 /* ObjectDefinePrototypeProperty */]: true,
+        [0 /* None */]: false,
+        [1 /* ExportsProperty */]: false,
+        [2 /* ModuleExports */]: false,
+        [8 /* ObjectDefinePropertyExports */]: false,
+        [6 /* Prototype */]: true,
+        [4 /* ThisProperty */]: false
+      };
     }
-    for (const importStringLiteral of sourceFile.imports) {
-      const updated = updateImport2(importStringLiteral);
-      if (updated !== void 0 && updated !== importStringLiteral.text)
-        changeTracker.replaceRangeWithText(sourceFile, createStringRange(importStringLiteral, sourceFile), updated);
+  });
+
+  // src/services/_namespaces/ts.NavigationBar.ts
+  var ts_NavigationBar_exports = {};
+  __export(ts_NavigationBar_exports, {
+    getNavigationBarItems: () => getNavigationBarItems,
+    getNavigationTree: () => getNavigationTree
+  });
+  var init_ts_NavigationBar = __esm({
+    "src/services/_namespaces/ts.NavigationBar.ts"() {
+      "use strict";
+      init_navigationBar();
     }
+  });
+
+  // src/services/refactorProvider.ts
+  function registerRefactor(name, refactor) {
+    refactors.set(name, refactor);
   }
-  function createStringRange(node, sourceFile) {
-    return createRange(node.getStart(sourceFile) + 1, node.end - 1);
+  function getApplicableRefactors(context, includeInteractiveActions) {
+    return arrayFrom(flatMapIterator(refactors.values(), (refactor) => {
+      var _a;
+      return context.cancellationToken && context.cancellationToken.isCancellationRequested() || !((_a = refactor.kinds) == null ? void 0 : _a.some((kind) => refactorKindBeginsWith(kind, context.kind))) ? void 0 : refactor.getAvailableActions(context, includeInteractiveActions);
+    }));
   }
-  function forEachProperty(objectLiteral, cb) {
-    if (!isObjectLiteralExpression(objectLiteral))
-      return;
-    for (const property of objectLiteral.properties) {
-      if (isPropertyAssignment(property) && isStringLiteral(property.name)) {
-        cb(property, property.name.text);
-      }
-    }
+  function getEditsForRefactor(context, refactorName14, actionName2, interactiveRefactorArguments) {
+    const refactor = refactors.get(refactorName14);
+    return refactor && refactor.getEditsForAction(context, actionName2, interactiveRefactorArguments);
   }
-  var init_getEditsForFileRename = __esm({
-    "src/services/getEditsForFileRename.ts"() {
+  var refactors;
+  var init_refactorProvider = __esm({
+    "src/services/refactorProvider.ts"() {
       "use strict";
       init_ts4();
+      init_ts_refactor();
+      refactors = /* @__PURE__ */ new Map();
     }
   });
 
-  // src/services/patternMatcher.ts
-  function createPatternMatch(kind, isCaseSensitive) {
-    return {
-      kind,
-      isCaseSensitive
-    };
-  }
-  function createPatternMatcher(pattern) {
-    const stringToWordSpans = /* @__PURE__ */ new Map();
-    const dotSeparatedSegments = pattern.trim().split(".").map((p) => createSegment(p.trim()));
-    if (dotSeparatedSegments.some((segment) => !segment.subWordTextChunks.length))
-      return void 0;
-    return {
-      getFullMatch: (containers, candidate) => getFullMatch(containers, candidate, dotSeparatedSegments, stringToWordSpans),
-      getMatchForLastSegmentOfPattern: (candidate) => matchSegment(candidate, last(dotSeparatedSegments), stringToWordSpans),
-      patternContainsDots: dotSeparatedSegments.length > 1
-    };
-  }
-  function getFullMatch(candidateContainers, candidate, dotSeparatedSegments, stringToWordSpans) {
-    const candidateMatch = matchSegment(candidate, last(dotSeparatedSegments), stringToWordSpans);
-    if (!candidateMatch) {
-      return void 0;
+  // src/services/refactors/convertExport.ts
+  function getInfo2(context, considerPartialSpans = true) {
+    const { file, program } = context;
+    const span = getRefactorContextSpan(context);
+    const token = getTokenAtPosition(file, span.start);
+    const exportNode = !!(token.parent && getSyntacticModifierFlags(token.parent) & 32 /* Export */) && considerPartialSpans ? token.parent : getParentNodeInSpan(token, file, span);
+    if (!exportNode || !isSourceFile(exportNode.parent) && !(isModuleBlock(exportNode.parent) && isAmbientModule(exportNode.parent.parent))) {
+      return { error: getLocaleSpecificMessage(Diagnostics.Could_not_find_export_statement) };
     }
-    if (dotSeparatedSegments.length - 1 > candidateContainers.length) {
-      return void 0;
+    const checker = program.getTypeChecker();
+    const exportingModuleSymbol = getExportingModuleSymbol(exportNode.parent, checker);
+    const flags = getSyntacticModifierFlags(exportNode) || (isExportAssignment(exportNode) && !exportNode.isExportEquals ? 2080 /* ExportDefault */ : 0 /* None */);
+    const wasDefault = !!(flags & 2048 /* Default */);
+    if (!(flags & 32 /* Export */) || !wasDefault && exportingModuleSymbol.exports.has("default" /* Default */)) {
+      return { error: getLocaleSpecificMessage(Diagnostics.This_file_already_has_a_default_export) };
     }
-    let bestMatch;
-    for (let i = dotSeparatedSegments.length - 2, j = candidateContainers.length - 1; i >= 0; i -= 1, j -= 1) {
-      bestMatch = betterMatch(bestMatch, matchSegment(candidateContainers[j], dotSeparatedSegments[i], stringToWordSpans));
+    const noSymbolError = (id) => isIdentifier(id) && checker.getSymbolAtLocation(id) ? void 0 : { error: getLocaleSpecificMessage(Diagnostics.Can_only_convert_named_export) };
+    switch (exportNode.kind) {
+      case 262 /* FunctionDeclaration */:
+      case 263 /* ClassDeclaration */:
+      case 264 /* InterfaceDeclaration */:
+      case 266 /* EnumDeclaration */:
+      case 265 /* TypeAliasDeclaration */:
+      case 267 /* ModuleDeclaration */: {
+        const node = exportNode;
+        if (!node.name)
+          return void 0;
+        return noSymbolError(node.name) || { exportNode: node, exportName: node.name, wasDefault, exportingModuleSymbol };
+      }
+      case 243 /* VariableStatement */: {
+        const vs = exportNode;
+        if (!(vs.declarationList.flags & 2 /* Const */) || vs.declarationList.declarations.length !== 1) {
+          return void 0;
+        }
+        const decl = first(vs.declarationList.declarations);
+        if (!decl.initializer)
+          return void 0;
+        Debug.assert(!wasDefault, "Can't have a default flag here");
+        return noSymbolError(decl.name) || { exportNode: vs, exportName: decl.name, wasDefault, exportingModuleSymbol };
+      }
+      case 277 /* ExportAssignment */: {
+        const node = exportNode;
+        if (node.isExportEquals)
+          return void 0;
+        return noSymbolError(node.expression) || { exportNode: node, exportName: node.expression, wasDefault, exportingModuleSymbol };
+      }
+      default:
+        return void 0;
     }
-    return bestMatch;
   }
-  function getWordSpans(word, stringToWordSpans) {
-    let spans = stringToWordSpans.get(word);
-    if (!spans) {
-      stringToWordSpans.set(word, spans = breakIntoWordSpans(word));
-    }
-    return spans;
+  function doChange(exportingSourceFile, program, info, changes, cancellationToken) {
+    changeExport(exportingSourceFile, info, changes, program.getTypeChecker());
+    changeImports(program, info, changes, cancellationToken);
   }
-  function matchTextChunk(candidate, chunk, stringToWordSpans) {
-    const index = indexOfIgnoringCase(candidate, chunk.textLowerCase);
-    if (index === 0) {
-      return createPatternMatch(
-        chunk.text.length === candidate.length ? 0 /* exact */ : 1 /* prefix */,
-        /*isCaseSensitive:*/
-        startsWith(candidate, chunk.text)
-      );
+  function changeExport(exportingSourceFile, { wasDefault, exportNode, exportName }, changes, checker) {
+    if (wasDefault) {
+      if (isExportAssignment(exportNode) && !exportNode.isExportEquals) {
+        const exp = exportNode.expression;
+        const spec = makeExportSpecifier(exp.text, exp.text);
+        changes.replaceNode(exportingSourceFile, exportNode, factory.createExportDeclaration(
+          /*modifiers*/
+          void 0,
+          /*isTypeOnly*/
+          false,
+          factory.createNamedExports([spec])
+        ));
+      } else {
+        changes.delete(exportingSourceFile, Debug.checkDefined(findModifier(exportNode, 90 /* DefaultKeyword */), "Should find a default keyword in modifier list"));
+      }
+    } else {
+      const exportKeyword = Debug.checkDefined(findModifier(exportNode, 95 /* ExportKeyword */), "Should find an export keyword in modifier list");
+      switch (exportNode.kind) {
+        case 262 /* FunctionDeclaration */:
+        case 263 /* ClassDeclaration */:
+        case 264 /* InterfaceDeclaration */:
+          changes.insertNodeAfter(exportingSourceFile, exportKeyword, factory.createToken(90 /* DefaultKeyword */));
+          break;
+        case 243 /* VariableStatement */:
+          const decl = first(exportNode.declarationList.declarations);
+          if (!ts_FindAllReferences_exports.Core.isSymbolReferencedInFile(exportName, checker, exportingSourceFile) && !decl.type) {
+            changes.replaceNode(exportingSourceFile, exportNode, factory.createExportDefault(Debug.checkDefined(decl.initializer, "Initializer was previously known to be present")));
+            break;
+          }
+        case 266 /* EnumDeclaration */:
+        case 265 /* TypeAliasDeclaration */:
+        case 267 /* ModuleDeclaration */:
+          changes.deleteModifier(exportingSourceFile, exportKeyword);
+          changes.insertNodeAfter(exportingSourceFile, exportNode, factory.createExportDefault(factory.createIdentifier(exportName.text)));
+          break;
+        default:
+          Debug.fail(`Unexpected exportNode kind ${exportNode.kind}`);
+      }
     }
-    if (chunk.isLowerCase) {
-      if (index === -1)
-        return void 0;
-      const wordSpans = getWordSpans(candidate, stringToWordSpans);
-      for (const span of wordSpans) {
-        if (partStartsWith(
-          candidate,
-          span,
-          chunk.text,
-          /*ignoreCase*/
-          true
-        )) {
-          return createPatternMatch(
-            2 /* substring */,
-            /*isCaseSensitive:*/
-            partStartsWith(
-              candidate,
-              span,
-              chunk.text,
-              /*ignoreCase*/
-              false
-            )
+  }
+  function changeImports(program, { wasDefault, exportName, exportingModuleSymbol }, changes, cancellationToken) {
+    const checker = program.getTypeChecker();
+    const exportSymbol = Debug.checkDefined(checker.getSymbolAtLocation(exportName), "Export name should resolve to a symbol");
+    ts_FindAllReferences_exports.Core.eachExportReference(program.getSourceFiles(), checker, cancellationToken, exportSymbol, exportingModuleSymbol, exportName.text, wasDefault, (ref) => {
+      if (exportName === ref)
+        return;
+      const importingSourceFile = ref.getSourceFile();
+      if (wasDefault) {
+        changeDefaultToNamedImport(importingSourceFile, ref, changes, exportName.text);
+      } else {
+        changeNamedToDefaultImport(importingSourceFile, ref, changes);
+      }
+    });
+  }
+  function changeDefaultToNamedImport(importingSourceFile, ref, changes, exportName) {
+    const { parent: parent2 } = ref;
+    switch (parent2.kind) {
+      case 211 /* PropertyAccessExpression */:
+        changes.replaceNode(importingSourceFile, ref, factory.createIdentifier(exportName));
+        break;
+      case 276 /* ImportSpecifier */:
+      case 281 /* ExportSpecifier */: {
+        const spec = parent2;
+        changes.replaceNode(importingSourceFile, spec, makeImportSpecifier(exportName, spec.name.text));
+        break;
+      }
+      case 273 /* ImportClause */: {
+        const clause = parent2;
+        Debug.assert(clause.name === ref, "Import clause name should match provided ref");
+        const spec = makeImportSpecifier(exportName, ref.text);
+        const { namedBindings } = clause;
+        if (!namedBindings) {
+          changes.replaceNode(importingSourceFile, ref, factory.createNamedImports([spec]));
+        } else if (namedBindings.kind === 274 /* NamespaceImport */) {
+          changes.deleteRange(importingSourceFile, { pos: ref.getStart(importingSourceFile), end: namedBindings.getStart(importingSourceFile) });
+          const quotePreference = isStringLiteral(clause.parent.moduleSpecifier) ? quotePreferenceFromString(clause.parent.moduleSpecifier, importingSourceFile) : 1 /* Double */;
+          const newImport = makeImport(
+            /*defaultImport*/
+            void 0,
+            [makeImportSpecifier(exportName, ref.text)],
+            clause.parent.moduleSpecifier,
+            quotePreference
           );
+          changes.insertNodeAfter(importingSourceFile, clause.parent, newImport);
+        } else {
+          changes.delete(importingSourceFile, ref);
+          changes.insertNodeAtEndOfList(importingSourceFile, namedBindings.elements, spec);
         }
+        break;
       }
-      if (chunk.text.length < candidate.length && isUpperCaseLetter(candidate.charCodeAt(index))) {
-        return createPatternMatch(
-          2 /* substring */,
-          /*isCaseSensitive*/
-          false
-        );
+      case 205 /* ImportType */:
+        const importTypeNode = parent2;
+        changes.replaceNode(importingSourceFile, parent2, factory.createImportTypeNode(importTypeNode.argument, importTypeNode.attributes, factory.createIdentifier(exportName), importTypeNode.typeArguments, importTypeNode.isTypeOf));
+        break;
+      default:
+        Debug.failBadSyntaxKind(parent2);
+    }
+  }
+  function changeNamedToDefaultImport(importingSourceFile, ref, changes) {
+    const parent2 = ref.parent;
+    switch (parent2.kind) {
+      case 211 /* PropertyAccessExpression */:
+        changes.replaceNode(importingSourceFile, ref, factory.createIdentifier("default"));
+        break;
+      case 276 /* ImportSpecifier */: {
+        const defaultImport = factory.createIdentifier(parent2.name.text);
+        if (parent2.parent.elements.length === 1) {
+          changes.replaceNode(importingSourceFile, parent2.parent, defaultImport);
+        } else {
+          changes.delete(importingSourceFile, parent2);
+          changes.insertNodeBefore(importingSourceFile, parent2.parent, defaultImport);
+        }
+        break;
       }
-    } else {
-      if (candidate.indexOf(chunk.text) > 0) {
-        return createPatternMatch(
-          2 /* substring */,
-          /*isCaseSensitive*/
-          true
-        );
+      case 281 /* ExportSpecifier */: {
+        changes.replaceNode(importingSourceFile, parent2, makeExportSpecifier("default", parent2.name.text));
+        break;
       }
-      if (chunk.characterSpans.length > 0) {
-        const candidateParts = getWordSpans(candidate, stringToWordSpans);
-        const isCaseSensitive = tryCamelCaseMatch(
-          candidate,
-          candidateParts,
-          chunk,
-          /*ignoreCase*/
-          false
-        ) ? true : tryCamelCaseMatch(
-          candidate,
-          candidateParts,
-          chunk,
-          /*ignoreCase*/
-          true
-        ) ? false : void 0;
-        if (isCaseSensitive !== void 0) {
-          return createPatternMatch(3 /* camelCase */, isCaseSensitive);
+      default:
+        Debug.assertNever(parent2, `Unexpected parent kind ${parent2.kind}`);
+    }
+  }
+  function makeImportSpecifier(propertyName, name) {
+    return factory.createImportSpecifier(
+      /*isTypeOnly*/
+      false,
+      propertyName === name ? void 0 : factory.createIdentifier(propertyName),
+      factory.createIdentifier(name)
+    );
+  }
+  function makeExportSpecifier(propertyName, name) {
+    return factory.createExportSpecifier(
+      /*isTypeOnly*/
+      false,
+      propertyName === name ? void 0 : factory.createIdentifier(propertyName),
+      factory.createIdentifier(name)
+    );
+  }
+  function getExportingModuleSymbol(parent2, checker) {
+    if (isSourceFile(parent2)) {
+      return parent2.symbol;
+    }
+    const symbol = parent2.parent.symbol;
+    if (symbol.valueDeclaration && isExternalModuleAugmentation(symbol.valueDeclaration)) {
+      return checker.getMergedSymbol(symbol);
+    }
+    return symbol;
+  }
+  var refactorName, defaultToNamedAction, namedToDefaultAction;
+  var init_convertExport = __esm({
+    "src/services/refactors/convertExport.ts"() {
+      "use strict";
+      init_ts4();
+      init_ts_refactor();
+      refactorName = "Convert export";
+      defaultToNamedAction = {
+        name: "Convert default export to named export",
+        description: getLocaleSpecificMessage(Diagnostics.Convert_default_export_to_named_export),
+        kind: "refactor.rewrite.export.named"
+      };
+      namedToDefaultAction = {
+        name: "Convert named export to default export",
+        description: getLocaleSpecificMessage(Diagnostics.Convert_named_export_to_default_export),
+        kind: "refactor.rewrite.export.default"
+      };
+      registerRefactor(refactorName, {
+        kinds: [
+          defaultToNamedAction.kind,
+          namedToDefaultAction.kind
+        ],
+        getAvailableActions: function getRefactorActionsToConvertBetweenNamedAndDefaultExports(context) {
+          const info = getInfo2(context, context.triggerReason === "invoked");
+          if (!info)
+            return emptyArray;
+          if (!isRefactorErrorInfo(info)) {
+            const action = info.wasDefault ? defaultToNamedAction : namedToDefaultAction;
+            return [{ name: refactorName, description: action.description, actions: [action] }];
+          }
+          if (context.preferences.provideRefactorNotApplicableReason) {
+            return [
+              {
+                name: refactorName,
+                description: getLocaleSpecificMessage(Diagnostics.Convert_default_export_to_named_export),
+                actions: [
+                  { ...defaultToNamedAction, notApplicableReason: info.error },
+                  { ...namedToDefaultAction, notApplicableReason: info.error }
+                ]
+              }
+            ];
+          }
+          return emptyArray;
+        },
+        getEditsForAction: function getRefactorEditsToConvertBetweenNamedAndDefaultExports(context, actionName2) {
+          Debug.assert(actionName2 === defaultToNamedAction.name || actionName2 === namedToDefaultAction.name, "Unexpected action name");
+          const info = getInfo2(context);
+          Debug.assert(info && !isRefactorErrorInfo(info), "Expected applicable refactor info");
+          const edits = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange(context.file, context.program, info, t, context.cancellationToken));
+          return { edits, renameFilename: void 0, renameLocation: void 0 };
         }
-      }
+      });
+    }
+  });
+
+  // src/services/refactors/convertImport.ts
+  function getImportConversionInfo(context, considerPartialSpans = true) {
+    const { file } = context;
+    const span = getRefactorContextSpan(context);
+    const token = getTokenAtPosition(file, span.start);
+    const importDecl = considerPartialSpans ? findAncestor(token, isImportDeclaration) : getParentNodeInSpan(token, file, span);
+    if (!importDecl || !isImportDeclaration(importDecl))
+      return { error: "Selection is not an import declaration." };
+    const end = span.start + span.length;
+    const nextToken = findNextToken(importDecl, importDecl.parent, file);
+    if (nextToken && end > nextToken.getStart())
+      return void 0;
+    const { importClause } = importDecl;
+    if (!importClause) {
+      return { error: getLocaleSpecificMessage(Diagnostics.Could_not_find_import_clause) };
     }
-  }
-  function matchSegment(candidate, segment, stringToWordSpans) {
-    if (every2(segment.totalTextChunk.text, (ch) => ch !== 32 /* space */ && ch !== 42 /* asterisk */)) {
-      const match = matchTextChunk(candidate, segment.totalTextChunk, stringToWordSpans);
-      if (match)
-        return match;
+    if (!importClause.namedBindings) {
+      return { error: getLocaleSpecificMessage(Diagnostics.Could_not_find_namespace_import_or_named_imports) };
     }
-    const subWordTextChunks = segment.subWordTextChunks;
-    let bestMatch;
-    for (const subWordTextChunk of subWordTextChunks) {
-      bestMatch = betterMatch(bestMatch, matchTextChunk(candidate, subWordTextChunk, stringToWordSpans));
+    if (importClause.namedBindings.kind === 274 /* NamespaceImport */) {
+      return { convertTo: 0 /* Named */, import: importClause.namedBindings };
     }
-    return bestMatch;
+    const shouldUseDefault = getShouldUseDefault(context.program, importClause);
+    return shouldUseDefault ? { convertTo: 1 /* Default */, import: importClause.namedBindings } : { convertTo: 2 /* Namespace */, import: importClause.namedBindings };
   }
-  function betterMatch(a, b) {
-    return min([a, b], compareMatches);
+  function getShouldUseDefault(program, importClause) {
+    return getAllowSyntheticDefaultImports(program.getCompilerOptions()) && isExportEqualsModule(importClause.parent.moduleSpecifier, program.getTypeChecker());
   }
-  function compareMatches(a, b) {
-    return a === void 0 ? 1 /* GreaterThan */ : b === void 0 ? -1 /* LessThan */ : compareValues(a.kind, b.kind) || compareBooleans(!a.isCaseSensitive, !b.isCaseSensitive);
+  function doChange2(sourceFile, program, changes, info) {
+    const checker = program.getTypeChecker();
+    if (info.convertTo === 0 /* Named */) {
+      doChangeNamespaceToNamed(sourceFile, checker, changes, info.import, getAllowSyntheticDefaultImports(program.getCompilerOptions()));
+    } else {
+      doChangeNamedToNamespaceOrDefault(sourceFile, program, changes, info.import, info.convertTo === 1 /* Default */);
+    }
   }
-  function partStartsWith(candidate, candidateSpan, pattern, ignoreCase, patternSpan = { start: 0, length: pattern.length }) {
-    return patternSpan.length <= candidateSpan.length && everyInRange(0, patternSpan.length, (i) => equalChars(pattern.charCodeAt(patternSpan.start + i), candidate.charCodeAt(candidateSpan.start + i), ignoreCase));
+  function doChangeNamespaceToNamed(sourceFile, checker, changes, toConvert, allowSyntheticDefaultImports) {
+    let usedAsNamespaceOrDefault = false;
+    const nodesToReplace = [];
+    const conflictingNames = /* @__PURE__ */ new Map();
+    ts_FindAllReferences_exports.Core.eachSymbolReferenceInFile(toConvert.name, checker, sourceFile, (id) => {
+      if (!isPropertyAccessOrQualifiedName(id.parent)) {
+        usedAsNamespaceOrDefault = true;
+      } else {
+        const exportName = getRightOfPropertyAccessOrQualifiedName(id.parent).text;
+        if (checker.resolveName(
+          exportName,
+          id,
+          67108863 /* All */,
+          /*excludeGlobals*/
+          true
+        )) {
+          conflictingNames.set(exportName, true);
+        }
+        Debug.assert(getLeftOfPropertyAccessOrQualifiedName(id.parent) === id, "Parent expression should match id");
+        nodesToReplace.push(id.parent);
+      }
+    });
+    const exportNameToImportName = /* @__PURE__ */ new Map();
+    for (const propertyAccessOrQualifiedName of nodesToReplace) {
+      const exportName = getRightOfPropertyAccessOrQualifiedName(propertyAccessOrQualifiedName).text;
+      let importName = exportNameToImportName.get(exportName);
+      if (importName === void 0) {
+        exportNameToImportName.set(exportName, importName = conflictingNames.has(exportName) ? getUniqueName(exportName, sourceFile) : exportName);
+      }
+      changes.replaceNode(sourceFile, propertyAccessOrQualifiedName, factory.createIdentifier(importName));
+    }
+    const importSpecifiers = [];
+    exportNameToImportName.forEach((name, propertyName) => {
+      importSpecifiers.push(factory.createImportSpecifier(
+        /*isTypeOnly*/
+        false,
+        name === propertyName ? void 0 : factory.createIdentifier(propertyName),
+        factory.createIdentifier(name)
+      ));
+    });
+    const importDecl = toConvert.parent.parent;
+    if (usedAsNamespaceOrDefault && !allowSyntheticDefaultImports) {
+      changes.insertNodeAfter(sourceFile, importDecl, updateImport(
+        importDecl,
+        /*defaultImportName*/
+        void 0,
+        importSpecifiers
+      ));
+    } else {
+      changes.replaceNode(sourceFile, importDecl, updateImport(importDecl, usedAsNamespaceOrDefault ? factory.createIdentifier(toConvert.name.text) : void 0, importSpecifiers));
+    }
   }
-  function equalChars(ch1, ch2, ignoreCase) {
-    return ignoreCase ? toLowerCase2(ch1) === toLowerCase2(ch2) : ch1 === ch2;
+  function getRightOfPropertyAccessOrQualifiedName(propertyAccessOrQualifiedName) {
+    return isPropertyAccessExpression(propertyAccessOrQualifiedName) ? propertyAccessOrQualifiedName.name : propertyAccessOrQualifiedName.right;
   }
-  function tryCamelCaseMatch(candidate, candidateParts, chunk, ignoreCase) {
-    const chunkCharacterSpans = chunk.characterSpans;
-    let currentCandidate = 0;
-    let currentChunkSpan = 0;
-    let firstMatch;
-    let contiguous;
-    while (true) {
-      if (currentChunkSpan === chunkCharacterSpans.length) {
-        return true;
-      } else if (currentCandidate === candidateParts.length) {
-        return false;
+  function getLeftOfPropertyAccessOrQualifiedName(propertyAccessOrQualifiedName) {
+    return isPropertyAccessExpression(propertyAccessOrQualifiedName) ? propertyAccessOrQualifiedName.expression : propertyAccessOrQualifiedName.left;
+  }
+  function doChangeNamedToNamespaceOrDefault(sourceFile, program, changes, toConvert, shouldUseDefault = getShouldUseDefault(program, toConvert.parent)) {
+    const checker = program.getTypeChecker();
+    const importDecl = toConvert.parent.parent;
+    const { moduleSpecifier } = importDecl;
+    const toConvertSymbols = /* @__PURE__ */ new Set();
+    toConvert.elements.forEach((namedImport) => {
+      const symbol = checker.getSymbolAtLocation(namedImport.name);
+      if (symbol) {
+        toConvertSymbols.add(symbol);
       }
-      let candidatePart = candidateParts[currentCandidate];
-      let gotOneMatchThisCandidate = false;
-      for (; currentChunkSpan < chunkCharacterSpans.length; currentChunkSpan++) {
-        const chunkCharacterSpan = chunkCharacterSpans[currentChunkSpan];
-        if (gotOneMatchThisCandidate) {
-          if (!isUpperCaseLetter(chunk.text.charCodeAt(chunkCharacterSpans[currentChunkSpan - 1].start)) || !isUpperCaseLetter(chunk.text.charCodeAt(chunkCharacterSpans[currentChunkSpan].start))) {
-            break;
+    });
+    const preferredName = moduleSpecifier && isStringLiteral(moduleSpecifier) ? ts_codefix_exports.moduleSpecifierToValidIdentifier(moduleSpecifier.text, 99 /* ESNext */) : "module";
+    function hasNamespaceNameConflict(namedImport) {
+      return !!ts_FindAllReferences_exports.Core.eachSymbolReferenceInFile(namedImport.name, checker, sourceFile, (id) => {
+        const symbol = checker.resolveName(
+          preferredName,
+          id,
+          67108863 /* All */,
+          /*excludeGlobals*/
+          true
+        );
+        if (symbol) {
+          if (toConvertSymbols.has(symbol)) {
+            return isExportSpecifier(id.parent);
           }
+          return true;
         }
-        if (!partStartsWith(candidate, candidatePart, chunk.text, ignoreCase, chunkCharacterSpan)) {
-          break;
+        return false;
+      });
+    }
+    const namespaceNameConflicts = toConvert.elements.some(hasNamespaceNameConflict);
+    const namespaceImportName = namespaceNameConflicts ? getUniqueName(preferredName, sourceFile) : preferredName;
+    const neededNamedImports = /* @__PURE__ */ new Set();
+    for (const element of toConvert.elements) {
+      const propertyName = (element.propertyName || element.name).text;
+      ts_FindAllReferences_exports.Core.eachSymbolReferenceInFile(element.name, checker, sourceFile, (id) => {
+        const access = factory.createPropertyAccessExpression(factory.createIdentifier(namespaceImportName), propertyName);
+        if (isShorthandPropertyAssignment(id.parent)) {
+          changes.replaceNode(sourceFile, id.parent, factory.createPropertyAssignment(id.text, access));
+        } else if (isExportSpecifier(id.parent)) {
+          neededNamedImports.add(element);
+        } else {
+          changes.replaceNode(sourceFile, id, access);
         }
-        gotOneMatchThisCandidate = true;
-        firstMatch = firstMatch === void 0 ? currentCandidate : firstMatch;
-        contiguous = contiguous === void 0 ? true : contiguous;
-        candidatePart = createTextSpan(candidatePart.start + chunkCharacterSpan.length, candidatePart.length - chunkCharacterSpan.length);
-      }
-      if (!gotOneMatchThisCandidate && contiguous !== void 0) {
-        contiguous = false;
-      }
-      currentCandidate++;
+      });
     }
-  }
-  function createSegment(text) {
-    return {
-      totalTextChunk: createTextChunk(text),
-      subWordTextChunks: breakPatternIntoTextChunks(text)
-    };
-  }
-  function isUpperCaseLetter(ch) {
-    if (ch >= 65 /* A */ && ch <= 90 /* Z */) {
-      return true;
+    changes.replaceNode(
+      sourceFile,
+      toConvert,
+      shouldUseDefault ? factory.createIdentifier(namespaceImportName) : factory.createNamespaceImport(factory.createIdentifier(namespaceImportName))
+    );
+    if (neededNamedImports.size) {
+      const newNamedImports = arrayFrom(neededNamedImports.values(), (element) => factory.createImportSpecifier(element.isTypeOnly, element.propertyName && factory.createIdentifier(element.propertyName.text), factory.createIdentifier(element.name.text)));
+      changes.insertNodeAfter(sourceFile, toConvert.parent.parent, updateImport(
+        importDecl,
+        /*defaultImportName*/
+        void 0,
+        newNamedImports
+      ));
     }
-    if (ch < 127 /* maxAsciiCharacter */ || !isUnicodeIdentifierStart(ch, 99 /* Latest */)) {
+  }
+  function isExportEqualsModule(moduleSpecifier, checker) {
+    const externalModule = checker.resolveExternalModuleName(moduleSpecifier);
+    if (!externalModule)
       return false;
-    }
-    const str = String.fromCharCode(ch);
-    return str === str.toUpperCase();
+    const exportEquals = checker.resolveExternalModuleSymbol(externalModule);
+    return externalModule !== exportEquals;
   }
-  function isLowerCaseLetter(ch) {
-    if (ch >= 97 /* a */ && ch <= 122 /* z */) {
-      return true;
+  function updateImport(old, defaultImportName, elements) {
+    return factory.createImportDeclaration(
+      /*modifiers*/
+      void 0,
+      factory.createImportClause(
+        /*isTypeOnly*/
+        false,
+        defaultImportName,
+        elements && elements.length ? factory.createNamedImports(elements) : void 0
+      ),
+      old.moduleSpecifier,
+      /*attributes*/
+      void 0
+    );
+  }
+  var refactorName2, actions;
+  var init_convertImport = __esm({
+    "src/services/refactors/convertImport.ts"() {
+      "use strict";
+      init_ts4();
+      init_ts_refactor();
+      refactorName2 = "Convert import";
+      actions = {
+        [0 /* Named */]: {
+          name: "Convert namespace import to named imports",
+          description: getLocaleSpecificMessage(Diagnostics.Convert_namespace_import_to_named_imports),
+          kind: "refactor.rewrite.import.named"
+        },
+        [2 /* Namespace */]: {
+          name: "Convert named imports to namespace import",
+          description: getLocaleSpecificMessage(Diagnostics.Convert_named_imports_to_namespace_import),
+          kind: "refactor.rewrite.import.namespace"
+        },
+        [1 /* Default */]: {
+          name: "Convert named imports to default import",
+          description: getLocaleSpecificMessage(Diagnostics.Convert_named_imports_to_default_import),
+          kind: "refactor.rewrite.import.default"
+        }
+      };
+      registerRefactor(refactorName2, {
+        kinds: getOwnValues(actions).map((a) => a.kind),
+        getAvailableActions: function getRefactorActionsToConvertBetweenNamedAndNamespacedImports(context) {
+          const info = getImportConversionInfo(context, context.triggerReason === "invoked");
+          if (!info)
+            return emptyArray;
+          if (!isRefactorErrorInfo(info)) {
+            const action = actions[info.convertTo];
+            return [{ name: refactorName2, description: action.description, actions: [action] }];
+          }
+          if (context.preferences.provideRefactorNotApplicableReason) {
+            return getOwnValues(actions).map((action) => ({
+              name: refactorName2,
+              description: action.description,
+              actions: [{ ...action, notApplicableReason: info.error }]
+            }));
+          }
+          return emptyArray;
+        },
+        getEditsForAction: function getRefactorEditsToConvertBetweenNamedAndNamespacedImports(context, actionName2) {
+          Debug.assert(some(getOwnValues(actions), (action) => action.name === actionName2), "Unexpected action name");
+          const info = getImportConversionInfo(context);
+          Debug.assert(info && !isRefactorErrorInfo(info), "Expected applicable refactor info");
+          const edits = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange2(context.file, context.program, t, info));
+          return { edits, renameFilename: void 0, renameLocation: void 0 };
+        }
+      });
     }
-    if (ch < 127 /* maxAsciiCharacter */ || !isUnicodeIdentifierStart(ch, 99 /* Latest */)) {
-      return false;
+  });
+
+  // src/services/refactors/extractType.ts
+  function getRangeToExtract(context, considerEmptySpans = true) {
+    const { file, startPosition } = context;
+    const isJS = isSourceFileJS(file);
+    const current = getTokenAtPosition(file, startPosition);
+    const range = createTextRangeFromSpan(getRefactorContextSpan(context));
+    const cursorRequest = range.pos === range.end && considerEmptySpans;
+    const overlappingRange = nodeOverlapsWithStartEnd(current, file, range.pos, range.end);
+    const firstType = findAncestor(current, (node) => node.parent && isTypeNode(node) && !rangeContainsSkipTrivia(range, node.parent, file) && (cursorRequest || overlappingRange));
+    if (!firstType || !isTypeNode(firstType))
+      return { error: getLocaleSpecificMessage(Diagnostics.Selection_is_not_a_valid_type_node) };
+    const checker = context.program.getTypeChecker();
+    const enclosingNode = getEnclosingNode(firstType, isJS);
+    if (enclosingNode === void 0)
+      return { error: getLocaleSpecificMessage(Diagnostics.No_type_could_be_extracted_from_this_type_node) };
+    const expandedFirstType = getExpandedSelectionNode(firstType, enclosingNode);
+    if (!isTypeNode(expandedFirstType))
+      return { error: getLocaleSpecificMessage(Diagnostics.Selection_is_not_a_valid_type_node) };
+    const typeList = [];
+    if ((isUnionTypeNode(expandedFirstType.parent) || isIntersectionTypeNode(expandedFirstType.parent)) && range.end > firstType.end) {
+      addRange(
+        typeList,
+        expandedFirstType.parent.types.filter((type) => {
+          return nodeOverlapsWithStartEnd(type, file, range.pos, range.end);
+        })
+      );
     }
-    const str = String.fromCharCode(ch);
-    return str === str.toLowerCase();
+    const selection = typeList.length > 1 ? typeList : expandedFirstType;
+    const typeParameters = collectTypeParameters(checker, selection, enclosingNode, file);
+    if (!typeParameters)
+      return { error: getLocaleSpecificMessage(Diagnostics.No_type_could_be_extracted_from_this_type_node) };
+    const typeElements = flattenTypeLiteralNodeReference(checker, selection);
+    return { isJS, selection, enclosingNode, typeParameters, typeElements };
   }
-  function indexOfIgnoringCase(str, value) {
-    const n = str.length - value.length;
-    for (let start = 0; start <= n; start++) {
-      if (every2(value, (valueChar, i) => toLowerCase2(str.charCodeAt(i + start)) === valueChar)) {
-        return start;
+  function flattenTypeLiteralNodeReference(checker, selection) {
+    if (!selection)
+      return void 0;
+    if (isArray(selection)) {
+      const result = [];
+      for (const type of selection) {
+        const flattenedTypeMembers = flattenTypeLiteralNodeReference(checker, type);
+        if (!flattenedTypeMembers)
+          return void 0;
+        addRange(result, flattenedTypeMembers);
       }
+      return result;
     }
-    return -1;
-  }
-  function toLowerCase2(ch) {
-    if (ch >= 65 /* A */ && ch <= 90 /* Z */) {
-      return 97 /* a */ + (ch - 65 /* A */);
-    }
-    if (ch < 127 /* maxAsciiCharacter */) {
-      return ch;
+    if (isIntersectionTypeNode(selection)) {
+      const result = [];
+      const seen = /* @__PURE__ */ new Map();
+      for (const type of selection.types) {
+        const flattenedTypeMembers = flattenTypeLiteralNodeReference(checker, type);
+        if (!flattenedTypeMembers || !flattenedTypeMembers.every((type2) => type2.name && addToSeen(seen, getNameFromPropertyName(type2.name)))) {
+          return void 0;
+        }
+        addRange(result, flattenedTypeMembers);
+      }
+      return result;
+    } else if (isParenthesizedTypeNode(selection)) {
+      return flattenTypeLiteralNodeReference(checker, selection.type);
+    } else if (isTypeLiteralNode(selection)) {
+      return selection.members;
     }
-    return String.fromCharCode(ch).toLowerCase().charCodeAt(0);
-  }
-  function isDigit2(ch) {
-    return ch >= 48 /* _0 */ && ch <= 57 /* _9 */;
+    return void 0;
   }
-  function isWordChar(ch) {
-    return isUpperCaseLetter(ch) || isLowerCaseLetter(ch) || isDigit2(ch) || ch === 95 /* _ */ || ch === 36 /* $ */;
+  function rangeContainsSkipTrivia(r1, node, file) {
+    return rangeContainsStartEnd(r1, skipTrivia(file.text, node.pos), node.end);
   }
-  function breakPatternIntoTextChunks(pattern) {
+  function collectTypeParameters(checker, selection, enclosingNode, file) {
     const result = [];
-    let wordStart = 0;
-    let wordLength = 0;
-    for (let i = 0; i < pattern.length; i++) {
-      const ch = pattern.charCodeAt(i);
-      if (isWordChar(ch)) {
-        if (wordLength === 0) {
-          wordStart = i;
+    const selectionArray = toArray(selection);
+    const selectionRange = { pos: selectionArray[0].pos, end: selectionArray[selectionArray.length - 1].end };
+    for (const t of selectionArray) {
+      if (visitor(t))
+        return void 0;
+    }
+    return result;
+    function visitor(node) {
+      if (isTypeReferenceNode(node)) {
+        if (isIdentifier(node.typeName)) {
+          const typeName = node.typeName;
+          const symbol = checker.resolveName(
+            typeName.text,
+            typeName,
+            262144 /* TypeParameter */,
+            /*excludeGlobals*/
+            true
+          );
+          for (const decl of (symbol == null ? void 0 : symbol.declarations) || emptyArray) {
+            if (isTypeParameterDeclaration(decl) && decl.getSourceFile() === file) {
+              if (decl.name.escapedText === typeName.escapedText && rangeContainsSkipTrivia(decl, selectionRange, file)) {
+                return true;
+              }
+              if (rangeContainsSkipTrivia(enclosingNode, decl, file) && !rangeContainsSkipTrivia(selectionRange, decl, file)) {
+                pushIfUnique(result, decl);
+                break;
+              }
+            }
+          }
         }
-        wordLength++;
-      } else {
-        if (wordLength > 0) {
-          result.push(createTextChunk(pattern.substr(wordStart, wordLength)));
-          wordLength = 0;
+      } else if (isInferTypeNode(node)) {
+        const conditionalTypeNode = findAncestor(node, (n) => isConditionalTypeNode(n) && rangeContainsSkipTrivia(n.extendsType, node, file));
+        if (!conditionalTypeNode || !rangeContainsSkipTrivia(selectionRange, conditionalTypeNode, file)) {
+          return true;
+        }
+      } else if (isTypePredicateNode(node) || isThisTypeNode(node)) {
+        const functionLikeNode = findAncestor(node.parent, isFunctionLike);
+        if (functionLikeNode && functionLikeNode.type && rangeContainsSkipTrivia(functionLikeNode.type, node, file) && !rangeContainsSkipTrivia(selectionRange, functionLikeNode, file)) {
+          return true;
+        }
+      } else if (isTypeQueryNode(node)) {
+        if (isIdentifier(node.exprName)) {
+          const symbol = checker.resolveName(
+            node.exprName.text,
+            node.exprName,
+            111551 /* Value */,
+            /*excludeGlobals*/
+            false
+          );
+          if ((symbol == null ? void 0 : symbol.valueDeclaration) && rangeContainsSkipTrivia(enclosingNode, symbol.valueDeclaration, file) && !rangeContainsSkipTrivia(selectionRange, symbol.valueDeclaration, file)) {
+            return true;
+          }
+        } else {
+          if (isThisIdentifier(node.exprName.left) && !rangeContainsSkipTrivia(selectionRange, node.parent, file)) {
+            return true;
+          }
         }
       }
+      if (file && isTupleTypeNode(node) && getLineAndCharacterOfPosition(file, node.pos).line === getLineAndCharacterOfPosition(file, node.end).line) {
+        setEmitFlags(node, 1 /* SingleLine */);
+      }
+      return forEachChild(node, visitor);
     }
-    if (wordLength > 0) {
-      result.push(createTextChunk(pattern.substr(wordStart, wordLength)));
-    }
-    return result;
-  }
-  function createTextChunk(text) {
-    const textLowerCase = text.toLowerCase();
-    return {
-      text,
-      textLowerCase,
-      isLowerCase: text === textLowerCase,
-      characterSpans: breakIntoCharacterSpans(text)
-    };
   }
-  function breakIntoCharacterSpans(identifier) {
-    return breakIntoSpans(
-      identifier,
-      /*word*/
-      false
+  function doTypeAliasChange(changes, file, name, info) {
+    const { enclosingNode, typeParameters } = info;
+    const { firstTypeNode, lastTypeNode, newTypeNode } = getNodesToEdit(info);
+    const newTypeDeclaration = factory.createTypeAliasDeclaration(
+      /*modifiers*/
+      void 0,
+      name,
+      typeParameters.map((id) => factory.updateTypeParameterDeclaration(
+        id,
+        id.modifiers,
+        id.name,
+        id.constraint,
+        /*defaultType*/
+        void 0
+      )),
+      newTypeNode
+    );
+    changes.insertNodeBefore(
+      file,
+      enclosingNode,
+      ignoreSourceNewlines(newTypeDeclaration),
+      /*blankLineBetween*/
+      true
     );
+    changes.replaceNodeRange(file, firstTypeNode, lastTypeNode, factory.createTypeReferenceNode(name, typeParameters.map((id) => factory.createTypeReferenceNode(
+      id.name,
+      /*typeArguments*/
+      void 0
+    ))), { leadingTriviaOption: ts_textChanges_exports.LeadingTriviaOption.Exclude, trailingTriviaOption: ts_textChanges_exports.TrailingTriviaOption.ExcludeWhitespace });
   }
-  function breakIntoWordSpans(identifier) {
-    return breakIntoSpans(
-      identifier,
-      /*word*/
+  function doInterfaceChange(changes, file, name, info) {
+    var _a;
+    const { enclosingNode, typeParameters, typeElements } = info;
+    const newTypeNode = factory.createInterfaceDeclaration(
+      /*modifiers*/
+      void 0,
+      name,
+      typeParameters,
+      /*heritageClauses*/
+      void 0,
+      typeElements
+    );
+    setTextRange(newTypeNode, (_a = typeElements[0]) == null ? void 0 : _a.parent);
+    changes.insertNodeBefore(
+      file,
+      enclosingNode,
+      ignoreSourceNewlines(newTypeNode),
+      /*blankLineBetween*/
       true
     );
+    const { firstTypeNode, lastTypeNode } = getNodesToEdit(info);
+    changes.replaceNodeRange(file, firstTypeNode, lastTypeNode, factory.createTypeReferenceNode(name, typeParameters.map((id) => factory.createTypeReferenceNode(
+      id.name,
+      /*typeArguments*/
+      void 0
+    ))), { leadingTriviaOption: ts_textChanges_exports.LeadingTriviaOption.Exclude, trailingTriviaOption: ts_textChanges_exports.TrailingTriviaOption.ExcludeWhitespace });
   }
-  function breakIntoSpans(identifier, word) {
-    const result = [];
-    let wordStart = 0;
-    for (let i = 1; i < identifier.length; i++) {
-      const lastIsDigit = isDigit2(identifier.charCodeAt(i - 1));
-      const currentIsDigit = isDigit2(identifier.charCodeAt(i));
-      const hasTransitionFromLowerToUpper = transitionFromLowerToUpper(identifier, word, i);
-      const hasTransitionFromUpperToLower = word && transitionFromUpperToLower(identifier, i, wordStart);
-      if (charIsPunctuation(identifier.charCodeAt(i - 1)) || charIsPunctuation(identifier.charCodeAt(i)) || lastIsDigit !== currentIsDigit || hasTransitionFromLowerToUpper || hasTransitionFromUpperToLower) {
-        if (!isAllPunctuation(identifier, wordStart, i)) {
-          result.push(createTextSpan(wordStart, i - wordStart));
-        }
-        wordStart = i;
-      }
-    }
-    if (!isAllPunctuation(identifier, wordStart, identifier.length)) {
-      result.push(createTextSpan(wordStart, identifier.length - wordStart));
+  function doTypedefChange(changes, context, file, name, info) {
+    var _a;
+    toArray(info.selection).forEach((typeNode) => {
+      setEmitFlags(typeNode, 3072 /* NoComments */ | 4096 /* NoNestedComments */);
+    });
+    const { enclosingNode, typeParameters } = info;
+    const { firstTypeNode, lastTypeNode, newTypeNode } = getNodesToEdit(info);
+    const node = factory.createJSDocTypedefTag(
+      factory.createIdentifier("typedef"),
+      factory.createJSDocTypeExpression(newTypeNode),
+      factory.createIdentifier(name)
+    );
+    const templates = [];
+    forEach(typeParameters, (typeParameter) => {
+      const constraint = getEffectiveConstraintOfTypeParameter(typeParameter);
+      const parameter = factory.createTypeParameterDeclaration(
+        /*modifiers*/
+        void 0,
+        typeParameter.name
+      );
+      const template = factory.createJSDocTemplateTag(
+        factory.createIdentifier("template"),
+        constraint && cast(constraint, isJSDocTypeExpression),
+        [parameter]
+      );
+      templates.push(template);
+    });
+    const jsDoc = factory.createJSDocComment(
+      /*comment*/
+      void 0,
+      factory.createNodeArray(concatenate(templates, [node]))
+    );
+    if (isJSDoc(enclosingNode)) {
+      const pos = enclosingNode.getStart(file);
+      const newLineCharacter = getNewLineOrDefaultFromHost(context.host, (_a = context.formatContext) == null ? void 0 : _a.options);
+      changes.insertNodeAt(file, enclosingNode.getStart(file), jsDoc, {
+        suffix: newLineCharacter + newLineCharacter + file.text.slice(getPrecedingNonSpaceCharacterPosition(file.text, pos - 1), pos)
+      });
+    } else {
+      changes.insertNodeBefore(
+        file,
+        enclosingNode,
+        jsDoc,
+        /*blankLineBetween*/
+        true
+      );
     }
-    return result;
+    changes.replaceNodeRange(file, firstTypeNode, lastTypeNode, factory.createTypeReferenceNode(name, typeParameters.map((id) => factory.createTypeReferenceNode(
+      id.name,
+      /*typeArguments*/
+      void 0
+    ))));
   }
-  function charIsPunctuation(ch) {
-    switch (ch) {
-      case 33 /* exclamation */:
-      case 34 /* doubleQuote */:
-      case 35 /* hash */:
-      case 37 /* percent */:
-      case 38 /* ampersand */:
-      case 39 /* singleQuote */:
-      case 40 /* openParen */:
-      case 41 /* closeParen */:
-      case 42 /* asterisk */:
-      case 44 /* comma */:
-      case 45 /* minus */:
-      case 46 /* dot */:
-      case 47 /* slash */:
-      case 58 /* colon */:
-      case 59 /* semicolon */:
-      case 63 /* question */:
-      case 64 /* at */:
-      case 91 /* openBracket */:
-      case 92 /* backslash */:
-      case 93 /* closeBracket */:
-      case 95 /* _ */:
-      case 123 /* openBrace */:
-      case 125 /* closeBrace */:
-        return true;
+  function getNodesToEdit(info) {
+    if (isArray(info.selection)) {
+      return {
+        firstTypeNode: info.selection[0],
+        lastTypeNode: info.selection[info.selection.length - 1],
+        newTypeNode: isUnionTypeNode(info.selection[0].parent) ? factory.createUnionTypeNode(info.selection) : factory.createIntersectionTypeNode(info.selection)
+      };
     }
-    return false;
-  }
-  function isAllPunctuation(identifier, start, end) {
-    return every2(identifier, (ch) => charIsPunctuation(ch) && ch !== 95 /* _ */, start, end);
-  }
-  function transitionFromUpperToLower(identifier, index, wordStart) {
-    return index !== wordStart && index + 1 < identifier.length && isUpperCaseLetter(identifier.charCodeAt(index)) && isLowerCaseLetter(identifier.charCodeAt(index + 1)) && every2(identifier, isUpperCaseLetter, wordStart, index);
+    return {
+      firstTypeNode: info.selection,
+      lastTypeNode: info.selection,
+      newTypeNode: info.selection
+    };
   }
-  function transitionFromLowerToUpper(identifier, word, index) {
-    const lastIsUpper = isUpperCaseLetter(identifier.charCodeAt(index - 1));
-    const currentIsUpper = isUpperCaseLetter(identifier.charCodeAt(index));
-    return currentIsUpper && (!word || !lastIsUpper);
+  function getEnclosingNode(node, isJS) {
+    return findAncestor(node, isStatement) || (isJS ? findAncestor(node, isJSDoc) : void 0);
   }
-  function everyInRange(start, end, pred) {
-    for (let i = start; i < end; i++) {
-      if (!pred(i)) {
-        return false;
+  function getExpandedSelectionNode(firstType, enclosingNode) {
+    return findAncestor(firstType, (node) => {
+      if (node === enclosingNode)
+        return "quit";
+      if (isUnionTypeNode(node.parent) || isIntersectionTypeNode(node.parent)) {
+        return true;
       }
-    }
-    return true;
-  }
-  function every2(s, pred, start = 0, end = s.length) {
-    return everyInRange(start, end, (i) => pred(s.charCodeAt(i), i));
+      return false;
+    }) ?? firstType;
   }
-  var PatternMatchKind;
-  var init_patternMatcher = __esm({
-    "src/services/patternMatcher.ts"() {
+  var refactorName3, extractToTypeAliasAction, extractToInterfaceAction, extractToTypeDefAction;
+  var init_extractType = __esm({
+    "src/services/refactors/extractType.ts"() {
       "use strict";
       init_ts4();
-      PatternMatchKind = /* @__PURE__ */ ((PatternMatchKind2) => {
-        PatternMatchKind2[PatternMatchKind2["exact"] = 0] = "exact";
-        PatternMatchKind2[PatternMatchKind2["prefix"] = 1] = "prefix";
-        PatternMatchKind2[PatternMatchKind2["substring"] = 2] = "substring";
-        PatternMatchKind2[PatternMatchKind2["camelCase"] = 3] = "camelCase";
-        return PatternMatchKind2;
-      })(PatternMatchKind || {});
+      init_ts_refactor();
+      refactorName3 = "Extract type";
+      extractToTypeAliasAction = {
+        name: "Extract to type alias",
+        description: getLocaleSpecificMessage(Diagnostics.Extract_to_type_alias),
+        kind: "refactor.extract.type"
+      };
+      extractToInterfaceAction = {
+        name: "Extract to interface",
+        description: getLocaleSpecificMessage(Diagnostics.Extract_to_interface),
+        kind: "refactor.extract.interface"
+      };
+      extractToTypeDefAction = {
+        name: "Extract to typedef",
+        description: getLocaleSpecificMessage(Diagnostics.Extract_to_typedef),
+        kind: "refactor.extract.typedef"
+      };
+      registerRefactor(refactorName3, {
+        kinds: [
+          extractToTypeAliasAction.kind,
+          extractToInterfaceAction.kind,
+          extractToTypeDefAction.kind
+        ],
+        getAvailableActions: function getRefactorActionsToExtractType(context) {
+          const info = getRangeToExtract(context, context.triggerReason === "invoked");
+          if (!info)
+            return emptyArray;
+          if (!isRefactorErrorInfo(info)) {
+            return [{
+              name: refactorName3,
+              description: getLocaleSpecificMessage(Diagnostics.Extract_type),
+              actions: info.isJS ? [extractToTypeDefAction] : append([extractToTypeAliasAction], info.typeElements && extractToInterfaceAction)
+            }];
+          }
+          if (context.preferences.provideRefactorNotApplicableReason) {
+            return [{
+              name: refactorName3,
+              description: getLocaleSpecificMessage(Diagnostics.Extract_type),
+              actions: [
+                { ...extractToTypeDefAction, notApplicableReason: info.error },
+                { ...extractToTypeAliasAction, notApplicableReason: info.error },
+                { ...extractToInterfaceAction, notApplicableReason: info.error }
+              ]
+            }];
+          }
+          return emptyArray;
+        },
+        getEditsForAction: function getRefactorEditsToExtractType(context, actionName2) {
+          const { file } = context;
+          const info = getRangeToExtract(context);
+          Debug.assert(info && !isRefactorErrorInfo(info), "Expected to find a range to extract");
+          const name = getUniqueName("NewType", file);
+          const edits = ts_textChanges_exports.ChangeTracker.with(context, (changes) => {
+            switch (actionName2) {
+              case extractToTypeAliasAction.name:
+                Debug.assert(!info.isJS, "Invalid actionName/JS combo");
+                return doTypeAliasChange(changes, file, name, info);
+              case extractToTypeDefAction.name:
+                Debug.assert(info.isJS, "Invalid actionName/JS combo");
+                return doTypedefChange(changes, context, file, name, info);
+              case extractToInterfaceAction.name:
+                Debug.assert(!info.isJS && !!info.typeElements, "Invalid actionName/JS combo");
+                return doInterfaceChange(changes, file, name, info);
+              default:
+                Debug.fail("Unexpected action name");
+            }
+          });
+          const renameFilename = file.fileName;
+          const renameLocation = getRenameLocation(
+            edits,
+            renameFilename,
+            name,
+            /*preferLastLocation*/
+            false
+          );
+          return { edits, renameFilename, renameLocation };
+        }
+      });
     }
   });
 
-  // src/services/preProcess.ts
-  function preProcessFile(sourceText, readImportFiles = true, detectJavaScriptImports = false) {
-    const pragmaContext = {
-      languageVersion: 1 /* ES5 */,
-      // controls whether the token scanner considers unicode identifiers or not - shouldn't matter, since we're only using it for trivia
-      pragmas: void 0,
-      checkJsDirective: void 0,
-      referencedFiles: [],
-      typeReferenceDirectives: [],
-      libReferenceDirectives: [],
-      amdDependencies: [],
-      hasNoDefaultLib: void 0,
-      moduleName: void 0
-    };
-    const importedFiles = [];
-    let ambientExternalModules;
-    let lastToken;
-    let currentToken;
-    let braceNesting = 0;
-    let externalModule = false;
-    function nextToken() {
-      lastToken = currentToken;
-      currentToken = scanner.scan();
-      if (currentToken === 19 /* OpenBraceToken */) {
-        braceNesting++;
-      } else if (currentToken === 20 /* CloseBraceToken */) {
-        braceNesting--;
-      }
-      return currentToken;
+  // src/services/refactors/helpers.ts
+  function isRefactorErrorInfo(info) {
+    return info.error !== void 0;
+  }
+  function refactorKindBeginsWith(known, requested) {
+    if (!requested)
+      return true;
+    return known.substr(0, requested.length) === requested;
+  }
+  var init_helpers = __esm({
+    "src/services/refactors/helpers.ts"() {
+      "use strict";
     }
-    function getFileReference() {
-      const fileName = scanner.getTokenValue();
-      const pos = scanner.getTokenStart();
-      return { fileName, pos, end: pos + fileName.length };
+  });
+
+  // src/services/refactors/inlineVariable.ts
+  function getInliningInfo(file, startPosition, tryWithReferenceToken, program) {
+    var _a, _b;
+    const checker = program.getTypeChecker();
+    const token = getTouchingPropertyName(file, startPosition);
+    const parent2 = token.parent;
+    if (!isIdentifier(token)) {
+      return void 0;
     }
-    function recordAmbientExternalModule() {
-      if (!ambientExternalModules) {
-        ambientExternalModules = [];
+    if (isInitializedVariable(parent2) && isVariableDeclarationInVariableStatement(parent2) && isIdentifier(parent2.name)) {
+      if (((_a = checker.getMergedSymbol(parent2.symbol).declarations) == null ? void 0 : _a.length) !== 1) {
+        return { error: getLocaleSpecificMessage(Diagnostics.Variables_with_multiple_declarations_cannot_be_inlined) };
       }
-      ambientExternalModules.push({ ref: getFileReference(), depth: braceNesting });
-    }
-    function recordModuleName() {
-      importedFiles.push(getFileReference());
-      markAsExternalModuleIfTopLevel();
+      if (isDeclarationExported(parent2)) {
+        return void 0;
+      }
+      const references = getReferenceNodes(parent2, checker, file);
+      return references && { references, declaration: parent2, replacement: parent2.initializer };
     }
-    function markAsExternalModuleIfTopLevel() {
-      if (braceNesting === 0) {
-        externalModule = true;
+    if (tryWithReferenceToken) {
+      let definition = checker.resolveName(
+        token.text,
+        token,
+        111551 /* Value */,
+        /*excludeGlobals*/
+        false
+      );
+      definition = definition && checker.getMergedSymbol(definition);
+      if (((_b = definition == null ? void 0 : definition.declarations) == null ? void 0 : _b.length) !== 1) {
+        return { error: getLocaleSpecificMessage(Diagnostics.Variables_with_multiple_declarations_cannot_be_inlined) };
+      }
+      const declaration = definition.declarations[0];
+      if (!isInitializedVariable(declaration) || !isVariableDeclarationInVariableStatement(declaration) || !isIdentifier(declaration.name)) {
+        return void 0;
+      }
+      if (isDeclarationExported(declaration)) {
+        return void 0;
       }
+      const references = getReferenceNodes(declaration, checker, file);
+      return references && { references, declaration, replacement: declaration.initializer };
     }
-    function tryConsumeDeclare() {
-      let token = scanner.getToken();
-      if (token === 138 /* DeclareKeyword */) {
-        token = nextToken();
-        if (token === 144 /* ModuleKeyword */) {
-          token = nextToken();
-          if (token === 11 /* StringLiteral */) {
-            recordAmbientExternalModule();
-          }
-        }
+    return { error: getLocaleSpecificMessage(Diagnostics.Could_not_find_variable_to_inline) };
+  }
+  function isDeclarationExported(declaration) {
+    const variableStatement = cast(declaration.parent.parent, isVariableStatement);
+    return some(variableStatement.modifiers, isExportModifier);
+  }
+  function getReferenceNodes(declaration, checker, file) {
+    const references = [];
+    const cannotInline = ts_FindAllReferences_exports.Core.eachSymbolReferenceInFile(declaration.name, checker, file, (ref) => {
+      if (ts_FindAllReferences_exports.isWriteAccessForReference(ref)) {
         return true;
       }
-      return false;
-    }
-    function tryConsumeImport() {
-      if (lastToken === 25 /* DotToken */) {
-        return false;
+      if (isExportSpecifier(ref.parent) || isExportAssignment(ref.parent)) {
+        return true;
       }
-      let token = scanner.getToken();
-      if (token === 102 /* ImportKeyword */) {
-        token = nextToken();
-        if (token === 21 /* OpenParenToken */) {
-          token = nextToken();
-          if (token === 11 /* StringLiteral */ || token === 15 /* NoSubstitutionTemplateLiteral */) {
-            recordModuleName();
-            return true;
-          }
-        } else if (token === 11 /* StringLiteral */) {
-          recordModuleName();
-          return true;
-        } else {
-          if (token === 156 /* TypeKeyword */) {
-            const skipTypeKeyword = scanner.lookAhead(() => {
-              const token2 = scanner.scan();
-              return token2 !== 160 /* FromKeyword */ && (token2 === 42 /* AsteriskToken */ || token2 === 19 /* OpenBraceToken */ || token2 === 80 /* Identifier */ || isKeyword(token2));
-            });
-            if (skipTypeKeyword) {
-              token = nextToken();
-            }
-          }
-          if (token === 80 /* Identifier */ || isKeyword(token)) {
-            token = nextToken();
-            if (token === 160 /* FromKeyword */) {
-              token = nextToken();
-              if (token === 11 /* StringLiteral */) {
-                recordModuleName();
-                return true;
-              }
-            } else if (token === 64 /* EqualsToken */) {
-              if (tryConsumeRequireCall(
-                /*skipCurrentToken*/
-                true
-              )) {
-                return true;
-              }
-            } else if (token === 28 /* CommaToken */) {
-              token = nextToken();
-            } else {
-              return true;
-            }
-          }
-          if (token === 19 /* OpenBraceToken */) {
-            token = nextToken();
-            while (token !== 20 /* CloseBraceToken */ && token !== 1 /* EndOfFileToken */) {
-              token = nextToken();
-            }
-            if (token === 20 /* CloseBraceToken */) {
-              token = nextToken();
-              if (token === 160 /* FromKeyword */) {
-                token = nextToken();
-                if (token === 11 /* StringLiteral */) {
-                  recordModuleName();
-                }
-              }
-            }
-          } else if (token === 42 /* AsteriskToken */) {
-            token = nextToken();
-            if (token === 130 /* AsKeyword */) {
-              token = nextToken();
-              if (token === 80 /* Identifier */ || isKeyword(token)) {
-                token = nextToken();
-                if (token === 160 /* FromKeyword */) {
-                  token = nextToken();
-                  if (token === 11 /* StringLiteral */) {
-                    recordModuleName();
-                  }
-                }
-              }
-            }
-          }
-        }
+      if (isTypeQueryNode(ref.parent)) {
         return true;
       }
-      return false;
+      if (textRangeContainsPositionInclusive(declaration, ref.pos)) {
+        return true;
+      }
+      references.push(ref);
+    });
+    return references.length === 0 || cannotInline ? void 0 : references;
+  }
+  function getReplacementExpression(reference, replacement) {
+    replacement = getSynthesizedDeepClone(replacement);
+    const { parent: parent2 } = reference;
+    if (isExpression(parent2) && (getExpressionPrecedence(replacement) < getExpressionPrecedence(parent2) || needsParentheses(parent2))) {
+      return factory.createParenthesizedExpression(replacement);
     }
-    function tryConsumeExport() {
-      let token = scanner.getToken();
-      if (token === 95 /* ExportKeyword */) {
-        markAsExternalModuleIfTopLevel();
-        token = nextToken();
-        if (token === 156 /* TypeKeyword */) {
-          const skipTypeKeyword = scanner.lookAhead(() => {
-            const token2 = scanner.scan();
-            return token2 === 42 /* AsteriskToken */ || token2 === 19 /* OpenBraceToken */;
-          });
-          if (skipTypeKeyword) {
-            token = nextToken();
-          }
-        }
-        if (token === 19 /* OpenBraceToken */) {
-          token = nextToken();
-          while (token !== 20 /* CloseBraceToken */ && token !== 1 /* EndOfFileToken */) {
-            token = nextToken();
+    if (isFunctionLike(replacement) && (isCallLikeExpression(parent2) || isPropertyAccessExpression(parent2))) {
+      return factory.createParenthesizedExpression(replacement);
+    }
+    if (isPropertyAccessExpression(parent2) && (isNumericLiteral(replacement) || isObjectLiteralExpression(replacement))) {
+      return factory.createParenthesizedExpression(replacement);
+    }
+    return replacement;
+  }
+  var refactorName4, refactorDescription, inlineVariableAction;
+  var init_inlineVariable = __esm({
+    "src/services/refactors/inlineVariable.ts"() {
+      "use strict";
+      init_ts4();
+      init_ts_refactor();
+      refactorName4 = "Inline variable";
+      refactorDescription = getLocaleSpecificMessage(Diagnostics.Inline_variable);
+      inlineVariableAction = {
+        name: refactorName4,
+        description: refactorDescription,
+        kind: "refactor.inline.variable"
+      };
+      registerRefactor(refactorName4, {
+        kinds: [inlineVariableAction.kind],
+        getAvailableActions(context) {
+          const {
+            file,
+            program,
+            preferences,
+            startPosition,
+            triggerReason
+          } = context;
+          const info = getInliningInfo(file, startPosition, triggerReason === "invoked", program);
+          if (!info) {
+            return emptyArray;
           }
-          if (token === 20 /* CloseBraceToken */) {
-            token = nextToken();
-            if (token === 160 /* FromKeyword */) {
-              token = nextToken();
-              if (token === 11 /* StringLiteral */) {
-                recordModuleName();
-              }
-            }
+          if (!ts_refactor_exports.isRefactorErrorInfo(info)) {
+            return [{
+              name: refactorName4,
+              description: refactorDescription,
+              actions: [inlineVariableAction]
+            }];
           }
-        } else if (token === 42 /* AsteriskToken */) {
-          token = nextToken();
-          if (token === 160 /* FromKeyword */) {
-            token = nextToken();
-            if (token === 11 /* StringLiteral */) {
-              recordModuleName();
-            }
+          if (preferences.provideRefactorNotApplicableReason) {
+            return [{
+              name: refactorName4,
+              description: refactorDescription,
+              actions: [{
+                ...inlineVariableAction,
+                notApplicableReason: info.error
+              }]
+            }];
           }
-        } else if (token === 102 /* ImportKeyword */) {
-          token = nextToken();
-          if (token === 156 /* TypeKeyword */) {
-            const skipTypeKeyword = scanner.lookAhead(() => {
-              const token2 = scanner.scan();
-              return token2 === 80 /* Identifier */ || isKeyword(token2);
-            });
-            if (skipTypeKeyword) {
-              token = nextToken();
-            }
+          return emptyArray;
+        },
+        getEditsForAction(context, actionName2) {
+          Debug.assert(actionName2 === refactorName4, "Unexpected refactor invoked");
+          const { file, program, startPosition } = context;
+          const info = getInliningInfo(
+            file,
+            startPosition,
+            /*tryWithReferenceToken*/
+            true,
+            program
+          );
+          if (!info || ts_refactor_exports.isRefactorErrorInfo(info)) {
+            return void 0;
           }
-          if (token === 80 /* Identifier */ || isKeyword(token)) {
-            token = nextToken();
-            if (token === 64 /* EqualsToken */) {
-              if (tryConsumeRequireCall(
-                /*skipCurrentToken*/
-                true
-              )) {
-                return true;
-              }
+          const { references, declaration, replacement } = info;
+          const edits = ts_textChanges_exports.ChangeTracker.with(context, (tracker) => {
+            for (const node of references) {
+              tracker.replaceNode(file, node, getReplacementExpression(node, replacement));
             }
-          }
-        }
-        return true;
-      }
-      return false;
-    }
-    function tryConsumeRequireCall(skipCurrentToken, allowTemplateLiterals = false) {
-      let token = skipCurrentToken ? nextToken() : scanner.getToken();
-      if (token === 149 /* RequireKeyword */) {
-        token = nextToken();
-        if (token === 21 /* OpenParenToken */) {
-          token = nextToken();
-          if (token === 11 /* StringLiteral */ || allowTemplateLiterals && token === 15 /* NoSubstitutionTemplateLiteral */) {
-            recordModuleName();
-          }
+            tracker.delete(file, declaration);
+          });
+          return { edits };
         }
-        return true;
-      }
-      return false;
+      });
     }
-    function tryConsumeDefine() {
-      let token = scanner.getToken();
-      if (token === 80 /* Identifier */ && scanner.getTokenValue() === "define") {
-        token = nextToken();
-        if (token !== 21 /* OpenParenToken */) {
-          return true;
-        }
-        token = nextToken();
-        if (token === 11 /* StringLiteral */ || token === 15 /* NoSubstitutionTemplateLiteral */) {
-          token = nextToken();
-          if (token === 28 /* CommaToken */) {
-            token = nextToken();
-          } else {
-            return true;
-          }
-        }
-        if (token !== 23 /* OpenBracketToken */) {
-          return true;
-        }
-        token = nextToken();
-        while (token !== 24 /* CloseBracketToken */ && token !== 1 /* EndOfFileToken */) {
-          if (token === 11 /* StringLiteral */ || token === 15 /* NoSubstitutionTemplateLiteral */) {
-            recordModuleName();
-          }
-          token = nextToken();
-        }
-        return true;
-      }
-      return false;
+  });
+
+  // src/services/refactors/moveToNewFile.ts
+  function doChange3(oldFile, program, toMove, changes, host, preferences, context) {
+    const checker = program.getTypeChecker();
+    const usage = getUsageInfo(oldFile, toMove.all, checker);
+    const newFilename = createNewFileName(oldFile, program, context, host);
+    changes.createNewFile(oldFile, newFilename, getNewStatementsAndRemoveFromOldFile(oldFile, usage, changes, toMove, program, host, newFilename, preferences));
+    addNewFileToTsconfig(program, changes, oldFile.fileName, newFilename, hostGetCanonicalFileName(host));
+  }
+  function getNewStatementsAndRemoveFromOldFile(oldFile, usage, changes, toMove, program, host, newFilename, preferences) {
+    const checker = program.getTypeChecker();
+    const prologueDirectives = takeWhile(oldFile.statements, isPrologueDirective);
+    if (oldFile.externalModuleIndicator === void 0 && oldFile.commonJsModuleIndicator === void 0 && usage.oldImportsNeededByTargetFile.size === 0) {
+      deleteMovedStatements(oldFile, toMove.ranges, changes);
+      return [...prologueDirectives, ...toMove.all];
     }
-    function processImports() {
-      scanner.setText(sourceText);
-      nextToken();
-      while (true) {
-        if (scanner.getToken() === 1 /* EndOfFileToken */) {
-          break;
-        }
-        if (scanner.getToken() === 16 /* TemplateHead */) {
-          const stack = [scanner.getToken()];
-          loop:
-            while (length(stack)) {
-              const token = scanner.scan();
-              switch (token) {
-                case 1 /* EndOfFileToken */:
-                  break loop;
-                case 102 /* ImportKeyword */:
-                  tryConsumeImport();
-                  break;
-                case 16 /* TemplateHead */:
-                  stack.push(token);
-                  break;
-                case 19 /* OpenBraceToken */:
-                  if (length(stack)) {
-                    stack.push(token);
-                  }
-                  break;
-                case 20 /* CloseBraceToken */:
-                  if (length(stack)) {
-                    if (lastOrUndefined(stack) === 16 /* TemplateHead */) {
-                      if (scanner.reScanTemplateToken(
-                        /*isTaggedTemplate*/
-                        false
-                      ) === 18 /* TemplateTail */) {
-                        stack.pop();
-                      }
-                    } else {
-                      stack.pop();
-                    }
-                  }
-                  break;
-              }
-            }
-          nextToken();
-        }
-        if (tryConsumeDeclare() || tryConsumeImport() || tryConsumeExport() || detectJavaScriptImports && (tryConsumeRequireCall(
-          /*skipCurrentToken*/
-          false,
-          /*allowTemplateLiterals*/
-          true
-        ) || tryConsumeDefine())) {
-          continue;
-        } else {
-          nextToken();
-        }
-      }
-      scanner.setText(void 0);
+    const useEsModuleSyntax = !fileShouldUseJavaScriptRequire(newFilename, program, host, !!oldFile.commonJsModuleIndicator);
+    const quotePreference = getQuotePreference(oldFile, preferences);
+    const importsFromNewFile = createOldFileImportsFromTargetFile(oldFile, usage.oldFileImportsFromTargetFile, newFilename, program, host, useEsModuleSyntax, quotePreference);
+    if (importsFromNewFile) {
+      insertImports(
+        changes,
+        oldFile,
+        importsFromNewFile,
+        /*blankLineBetween*/
+        true,
+        preferences
+      );
     }
-    if (readImportFiles) {
-      processImports();
+    deleteUnusedOldImports(oldFile, toMove.all, changes, usage.unusedImportsFromOldFile, checker);
+    deleteMovedStatements(oldFile, toMove.ranges, changes);
+    updateImportsInOtherFiles(changes, program, host, oldFile, usage.movedSymbols, newFilename, quotePreference);
+    const imports = getNewFileImportsAndAddExportInOldFile(oldFile, usage.oldImportsNeededByTargetFile, usage.targetFileImportsFromOldFile, changes, checker, program, host, useEsModuleSyntax, quotePreference);
+    const body = addExports(oldFile, toMove.all, usage.oldFileImportsFromTargetFile, useEsModuleSyntax);
+    if (imports.length && body.length) {
+      return [
+        ...prologueDirectives,
+        ...imports,
+        4 /* NewLineTrivia */,
+        ...body
+      ];
     }
-    processCommentPragmas(pragmaContext, sourceText);
-    processPragmasIntoFields(pragmaContext, noop);
-    if (externalModule) {
-      if (ambientExternalModules) {
-        for (const decl of ambientExternalModules) {
-          importedFiles.push(decl.ref);
-        }
+    return [
+      ...prologueDirectives,
+      ...imports,
+      ...body
+    ];
+  }
+  function getNewFileImportsAndAddExportInOldFile(oldFile, importsToCopy, newFileImportsFromOldFile, changes, checker, program, host, useEsModuleSyntax, quotePreference) {
+    const copiedOldImports = [];
+    for (const oldStatement of oldFile.statements) {
+      forEachImportInStatement(oldStatement, (i) => {
+        append(copiedOldImports, filterImport(i, moduleSpecifierFromImport(i), (name) => importsToCopy.has(checker.getSymbolAtLocation(name))));
+      });
+    }
+    let oldFileDefault;
+    const oldFileNamedImports = [];
+    const markSeenTop = nodeSeenTracker();
+    newFileImportsFromOldFile.forEach((symbol) => {
+      if (!symbol.declarations) {
+        return;
       }
-      return { referencedFiles: pragmaContext.referencedFiles, typeReferenceDirectives: pragmaContext.typeReferenceDirectives, libReferenceDirectives: pragmaContext.libReferenceDirectives, importedFiles, isLibFile: !!pragmaContext.hasNoDefaultLib, ambientExternalModules: void 0 };
-    } else {
-      let ambientModuleNames;
-      if (ambientExternalModules) {
-        for (const decl of ambientExternalModules) {
-          if (decl.depth === 0) {
-            if (!ambientModuleNames) {
-              ambientModuleNames = [];
-            }
-            ambientModuleNames.push(decl.ref.fileName);
-          } else {
-            importedFiles.push(decl.ref);
-          }
+      for (const decl of symbol.declarations) {
+        if (!isTopLevelDeclaration(decl))
+          continue;
+        const name = nameOfTopLevelDeclaration(decl);
+        if (!name)
+          continue;
+        const top = getTopLevelDeclarationStatement(decl);
+        if (markSeenTop(top)) {
+          addExportToChanges(oldFile, top, name, changes, useEsModuleSyntax);
+        }
+        if (hasSyntacticModifier(decl, 2048 /* Default */)) {
+          oldFileDefault = name;
+        } else {
+          oldFileNamedImports.push(name.text);
         }
       }
-      return { referencedFiles: pragmaContext.referencedFiles, typeReferenceDirectives: pragmaContext.typeReferenceDirectives, libReferenceDirectives: pragmaContext.libReferenceDirectives, importedFiles, isLibFile: !!pragmaContext.hasNoDefaultLib, ambientExternalModules: ambientModuleNames };
-    }
+    });
+    append(copiedOldImports, makeImportOrRequire(oldFile, oldFileDefault, oldFileNamedImports, getBaseFileName(oldFile.fileName), program, host, useEsModuleSyntax, quotePreference));
+    return copiedOldImports;
   }
-  var init_preProcess = __esm({
-    "src/services/preProcess.ts"() {
+  var refactorName5, description, moveToNewFileAction;
+  var init_moveToNewFile = __esm({
+    "src/services/refactors/moveToNewFile.ts"() {
       "use strict";
       init_ts4();
+      init_ts_refactor();
+      refactorName5 = "Move to a new file";
+      description = getLocaleSpecificMessage(Diagnostics.Move_to_a_new_file);
+      moveToNewFileAction = {
+        name: refactorName5,
+        description,
+        kind: "refactor.move.newFile"
+      };
+      registerRefactor(refactorName5, {
+        kinds: [moveToNewFileAction.kind],
+        getAvailableActions: function getRefactorActionsToMoveToNewFile(context) {
+          const statements = getStatementsToMove(context);
+          if (context.preferences.allowTextChangesInNewFiles && statements) {
+            return [{ name: refactorName5, description, actions: [moveToNewFileAction] }];
+          }
+          if (context.preferences.provideRefactorNotApplicableReason) {
+            return [{ name: refactorName5, description, actions: [{ ...moveToNewFileAction, notApplicableReason: getLocaleSpecificMessage(Diagnostics.Selection_is_not_a_valid_statement_or_statements) }] }];
+          }
+          return emptyArray;
+        },
+        getEditsForAction: function getRefactorEditsToMoveToNewFile(context, actionName2) {
+          Debug.assert(actionName2 === refactorName5, "Wrong refactor invoked");
+          const statements = Debug.checkDefined(getStatementsToMove(context));
+          const edits = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange3(context.file, context.program, statements, t, context.host, context.preferences, context));
+          return { edits, renameFilename: void 0, renameLocation: void 0 };
+        }
+      });
     }
   });
 
-  // src/services/sourcemaps.ts
-  function getSourceMapper(host) {
-    const getCanonicalFileName = createGetCanonicalFileName(host.useCaseSensitiveFileNames());
-    const currentDirectory = host.getCurrentDirectory();
-    const sourceFileLike = /* @__PURE__ */ new Map();
-    const documentPositionMappers = /* @__PURE__ */ new Map();
-    return { tryGetSourcePosition, tryGetGeneratedPosition, toLineColumnOffset, clearCache };
-    function toPath3(fileName) {
-      return toPath(fileName, currentDirectory, getCanonicalFileName);
+  // src/services/refactors/moveToFile.ts
+  function error(notApplicableReason) {
+    return { edits: [], renameFilename: void 0, renameLocation: void 0, notApplicableReason };
+  }
+  function doChange4(context, oldFile, targetFile, program, toMove, changes, host, preferences) {
+    const checker = program.getTypeChecker();
+    if (!host.fileExists(targetFile)) {
+      changes.createNewFile(oldFile, targetFile, getNewStatementsAndRemoveFromOldFile2(oldFile, targetFile, getUsageInfo(oldFile, toMove.all, checker), changes, toMove, program, host, preferences));
+      addNewFileToTsconfig(program, changes, oldFile.fileName, targetFile, hostGetCanonicalFileName(host));
+    } else {
+      const targetSourceFile = Debug.checkDefined(program.getSourceFile(targetFile));
+      const importAdder = ts_codefix_exports.createImportAdder(targetSourceFile, context.program, context.preferences, context.host);
+      getNewStatementsAndRemoveFromOldFile2(oldFile, targetSourceFile, getUsageInfo(oldFile, toMove.all, checker, getExistingImports(targetSourceFile, checker)), changes, toMove, program, host, preferences, importAdder);
     }
-    function getDocumentPositionMapper2(generatedFileName, sourceFileName) {
-      const path = toPath3(generatedFileName);
-      const value = documentPositionMappers.get(path);
-      if (value)
-        return value;
-      let mapper;
-      if (host.getDocumentPositionMapper) {
-        mapper = host.getDocumentPositionMapper(generatedFileName, sourceFileName);
-      } else if (host.readFile) {
-        const file = getSourceFileLike(generatedFileName);
-        mapper = file && getDocumentPositionMapper(
-          { getSourceFileLike, getCanonicalFileName, log: (s) => host.log(s) },
-          generatedFileName,
-          getLineInfo(file.text, getLineStarts(file)),
-          (f) => !host.fileExists || host.fileExists(f) ? host.readFile(f) : void 0
+  }
+  function getNewStatementsAndRemoveFromOldFile2(oldFile, targetFile, usage, changes, toMove, program, host, preferences, importAdder) {
+    const checker = program.getTypeChecker();
+    const prologueDirectives = takeWhile(oldFile.statements, isPrologueDirective);
+    if (oldFile.externalModuleIndicator === void 0 && oldFile.commonJsModuleIndicator === void 0 && usage.oldImportsNeededByTargetFile.size === 0 && usage.targetFileImportsFromOldFile.size === 0 && typeof targetFile === "string") {
+      deleteMovedStatements(oldFile, toMove.ranges, changes);
+      return [...prologueDirectives, ...toMove.all];
+    }
+    const targetFileName = typeof targetFile === "string" ? targetFile : targetFile.fileName;
+    const useEsModuleSyntax = !fileShouldUseJavaScriptRequire(targetFileName, program, host, !!oldFile.commonJsModuleIndicator);
+    const quotePreference = getQuotePreference(oldFile, preferences);
+    const importsFromTargetFile = createOldFileImportsFromTargetFile(oldFile, usage.oldFileImportsFromTargetFile, targetFileName, program, host, useEsModuleSyntax, quotePreference);
+    if (importsFromTargetFile) {
+      insertImports(
+        changes,
+        oldFile,
+        importsFromTargetFile,
+        /*blankLineBetween*/
+        true,
+        preferences
+      );
+    }
+    deleteUnusedOldImports(oldFile, toMove.all, changes, usage.unusedImportsFromOldFile, checker);
+    deleteMovedStatements(oldFile, toMove.ranges, changes);
+    updateImportsInOtherFiles(changes, program, host, oldFile, usage.movedSymbols, targetFileName, quotePreference);
+    const imports = getTargetFileImportsAndAddExportInOldFile(oldFile, targetFileName, usage.oldImportsNeededByTargetFile, usage.targetFileImportsFromOldFile, changes, checker, program, host, useEsModuleSyntax, quotePreference, importAdder);
+    const body = addExports(oldFile, toMove.all, usage.oldFileImportsFromTargetFile, useEsModuleSyntax);
+    if (typeof targetFile !== "string") {
+      if (targetFile.statements.length > 0) {
+        moveStatementsToTargetFile(changes, program, body, targetFile, toMove);
+      } else {
+        changes.insertNodesAtEndOfFile(
+          targetFile,
+          body,
+          /*blankLineBetween*/
+          false
+        );
+      }
+      if (imports.length > 0) {
+        insertImports(
+          changes,
+          targetFile,
+          imports,
+          /*blankLineBetween*/
+          true,
+          preferences
         );
       }
-      documentPositionMappers.set(path, mapper || identitySourceMapConsumer);
-      return mapper || identitySourceMapConsumer;
     }
-    function tryGetSourcePosition(info) {
-      if (!isDeclarationFileName(info.fileName))
-        return void 0;
-      const file = getSourceFile(info.fileName);
-      if (!file)
-        return void 0;
-      const newLoc = getDocumentPositionMapper2(info.fileName).getSourcePosition(info);
-      return !newLoc || newLoc === info ? void 0 : tryGetSourcePosition(newLoc) || newLoc;
+    if (importAdder) {
+      importAdder.writeFixes(changes, quotePreference);
     }
-    function tryGetGeneratedPosition(info) {
-      if (isDeclarationFileName(info.fileName))
-        return void 0;
-      const sourceFile = getSourceFile(info.fileName);
-      if (!sourceFile)
-        return void 0;
-      const program = host.getProgram();
-      if (program.isSourceOfProjectReferenceRedirect(sourceFile.fileName)) {
-        return void 0;
-      }
-      const options = program.getCompilerOptions();
-      const outPath = outFile(options);
-      const declarationPath = outPath ? removeFileExtension(outPath) + ".d.ts" /* Dts */ : getDeclarationEmitOutputFilePathWorker(info.fileName, program.getCompilerOptions(), currentDirectory, program.getCommonSourceDirectory(), getCanonicalFileName);
-      if (declarationPath === void 0)
-        return void 0;
-      const newLoc = getDocumentPositionMapper2(declarationPath, info.fileName).getGeneratedPosition(info);
-      return newLoc === info ? void 0 : newLoc;
+    if (imports.length && body.length) {
+      return [
+        ...prologueDirectives,
+        ...imports,
+        4 /* NewLineTrivia */,
+        ...body
+      ];
     }
-    function getSourceFile(fileName) {
-      const program = host.getProgram();
-      if (!program)
-        return void 0;
-      const path = toPath3(fileName);
-      const file = program.getSourceFileByPath(path);
-      return file && file.resolvedPath === path ? file : void 0;
+    return [
+      ...prologueDirectives,
+      ...imports,
+      ...body
+    ];
+  }
+  function getTargetFileImportsAndAddExportInOldFile(oldFile, targetFile, importsToCopy, targetFileImportsFromOldFile, changes, checker, program, host, useEsModuleSyntax, quotePreference, importAdder) {
+    const copiedOldImports = [];
+    if (importAdder) {
+      importsToCopy.forEach((isValidTypeOnlyUseSite, symbol) => {
+        try {
+          importAdder.addImportFromExportedSymbol(skipAlias(symbol, checker), isValidTypeOnlyUseSite);
+        } catch {
+          for (const oldStatement of oldFile.statements) {
+            forEachImportInStatement(oldStatement, (i) => {
+              append(copiedOldImports, filterImport(i, factory.createStringLiteral(moduleSpecifierFromImport(i).text), (name) => importsToCopy.has(checker.getSymbolAtLocation(name))));
+            });
+          }
+        }
+      });
+    } else {
+      const targetSourceFile = program.getSourceFile(targetFile);
+      for (const oldStatement of oldFile.statements) {
+        forEachImportInStatement(oldStatement, (i) => {
+          var _a;
+          const moduleSpecifier = moduleSpecifierFromImport(i);
+          const resolved = program.getResolvedModule(oldFile, moduleSpecifier.text, getModeForUsageLocation(oldFile, moduleSpecifier));
+          const fileName = (_a = resolved == null ? void 0 : resolved.resolvedModule) == null ? void 0 : _a.resolvedFileName;
+          if (fileName && targetSourceFile) {
+            const newModuleSpecifier = getModuleSpecifier(program.getCompilerOptions(), targetSourceFile, targetSourceFile.path, fileName, createModuleSpecifierResolutionHost(program, host));
+            append(copiedOldImports, filterImport(i, makeStringLiteral(newModuleSpecifier, quotePreference), (name) => importsToCopy.has(checker.getSymbolAtLocation(name))));
+          } else {
+            append(copiedOldImports, filterImport(i, factory.createStringLiteral(moduleSpecifierFromImport(i).text), (name) => importsToCopy.has(checker.getSymbolAtLocation(name))));
+          }
+        });
+      }
     }
-    function getOrCreateSourceFileLike(fileName) {
-      const path = toPath3(fileName);
-      const fileFromCache = sourceFileLike.get(path);
-      if (fileFromCache !== void 0)
-        return fileFromCache ? fileFromCache : void 0;
-      if (!host.readFile || host.fileExists && !host.fileExists(path)) {
-        sourceFileLike.set(path, false);
-        return void 0;
+    const targetFileSourceFile = program.getSourceFile(targetFile);
+    let oldFileDefault;
+    const oldFileNamedImports = [];
+    const markSeenTop = nodeSeenTracker();
+    targetFileImportsFromOldFile.forEach((symbol) => {
+      if (!symbol.declarations) {
+        return;
       }
-      const text = host.readFile(path);
-      const file = text ? createSourceFileLike(text) : false;
-      sourceFileLike.set(path, file);
-      return file ? file : void 0;
+      for (const decl of symbol.declarations) {
+        if (!isTopLevelDeclaration(decl))
+          continue;
+        const name = nameOfTopLevelDeclaration(decl);
+        if (!name)
+          continue;
+        const top = getTopLevelDeclarationStatement(decl);
+        if (markSeenTop(top)) {
+          addExportToChanges(oldFile, top, name, changes, useEsModuleSyntax);
+        }
+        if (importAdder && checker.isUnknownSymbol(symbol)) {
+          importAdder.addImportFromExportedSymbol(skipAlias(symbol, checker));
+        } else {
+          if (hasSyntacticModifier(decl, 2048 /* Default */)) {
+            oldFileDefault = name;
+          } else {
+            oldFileNamedImports.push(name.text);
+          }
+        }
+      }
+    });
+    return targetFileSourceFile ? append(copiedOldImports, makeImportOrRequire(targetFileSourceFile, oldFileDefault, oldFileNamedImports, oldFile.fileName, program, host, useEsModuleSyntax, quotePreference)) : append(copiedOldImports, makeImportOrRequire(oldFile, oldFileDefault, oldFileNamedImports, oldFile.fileName, program, host, useEsModuleSyntax, quotePreference));
+  }
+  function addNewFileToTsconfig(program, changes, oldFileName, newFileNameWithExtension, getCanonicalFileName) {
+    const cfg = program.getCompilerOptions().configFile;
+    if (!cfg)
+      return;
+    const newFileAbsolutePath = normalizePath(combinePaths(oldFileName, "..", newFileNameWithExtension));
+    const newFilePath = getRelativePathFromFile(cfg.fileName, newFileAbsolutePath, getCanonicalFileName);
+    const cfgObject = cfg.statements[0] && tryCast(cfg.statements[0].expression, isObjectLiteralExpression);
+    const filesProp = cfgObject && find(cfgObject.properties, (prop) => isPropertyAssignment(prop) && isStringLiteral(prop.name) && prop.name.text === "files");
+    if (filesProp && isArrayLiteralExpression(filesProp.initializer)) {
+      changes.insertNodeInListAfter(cfg, last(filesProp.initializer.elements), factory.createStringLiteral(newFilePath), filesProp.initializer.elements);
     }
-    function getSourceFileLike(fileName) {
-      return !host.getSourceFileLike ? getSourceFile(fileName) || getOrCreateSourceFileLike(fileName) : host.getSourceFileLike(fileName);
+  }
+  function deleteMovedStatements(sourceFile, moved, changes) {
+    for (const { first: first2, afterLast } of moved) {
+      changes.deleteNodeRangeExcludingEnd(sourceFile, first2, afterLast);
     }
-    function toLineColumnOffset(fileName, position) {
-      const file = getSourceFileLike(fileName);
-      return file.getLineAndCharacterOfPosition(position);
+  }
+  function deleteUnusedOldImports(oldFile, toMove, changes, toDelete, checker) {
+    for (const statement of oldFile.statements) {
+      if (contains(toMove, statement))
+        continue;
+      forEachImportInStatement(statement, (i) => deleteUnusedImports(oldFile, i, changes, (name) => toDelete.has(checker.getSymbolAtLocation(name))));
     }
-    function clearCache() {
-      sourceFileLike.clear();
-      documentPositionMappers.clear();
+  }
+  function updateImportsInOtherFiles(changes, program, host, oldFile, movedSymbols, targetFileName, quotePreference) {
+    const checker = program.getTypeChecker();
+    for (const sourceFile of program.getSourceFiles()) {
+      if (sourceFile === oldFile)
+        continue;
+      for (const statement of sourceFile.statements) {
+        forEachImportInStatement(statement, (importNode) => {
+          if (checker.getSymbolAtLocation(moduleSpecifierFromImport(importNode)) !== oldFile.symbol)
+            return;
+          const shouldMove = (name) => {
+            const symbol = isBindingElement(name.parent) ? getPropertySymbolFromBindingElement(checker, name.parent) : skipAlias(checker.getSymbolAtLocation(name), checker);
+            return !!symbol && movedSymbols.has(symbol);
+          };
+          deleteUnusedImports(sourceFile, importNode, changes, shouldMove);
+          const pathToTargetFileWithExtension = resolvePath(getDirectoryPath(oldFile.path), targetFileName);
+          const newModuleSpecifier = getModuleSpecifier(program.getCompilerOptions(), sourceFile, sourceFile.path, pathToTargetFileWithExtension, createModuleSpecifierResolutionHost(program, host));
+          const newImportDeclaration = filterImport(importNode, makeStringLiteral(newModuleSpecifier, quotePreference), shouldMove);
+          if (newImportDeclaration)
+            changes.insertNodeAfter(sourceFile, statement, newImportDeclaration);
+          const ns = getNamespaceLikeImport(importNode);
+          if (ns)
+            updateNamespaceLikeImport(changes, sourceFile, checker, movedSymbols, newModuleSpecifier, ns, importNode, quotePreference);
+        });
+      }
     }
   }
-  function getDocumentPositionMapper(host, generatedFileName, generatedFileLineInfo, readMapFile) {
-    let mapFileName = tryGetSourceMappingURL(generatedFileLineInfo);
-    if (mapFileName) {
-      const match = base64UrlRegExp.exec(mapFileName);
-      if (match) {
-        if (match[1]) {
-          const base64Object = match[1];
-          return convertDocumentToSourceMapper(host, base64decode(sys, base64Object), generatedFileName);
-        }
-        mapFileName = void 0;
+  function getNamespaceLikeImport(node) {
+    switch (node.kind) {
+      case 272 /* ImportDeclaration */:
+        return node.importClause && node.importClause.namedBindings && node.importClause.namedBindings.kind === 274 /* NamespaceImport */ ? node.importClause.namedBindings.name : void 0;
+      case 271 /* ImportEqualsDeclaration */:
+        return node.name;
+      case 260 /* VariableDeclaration */:
+        return tryCast(node.name, isIdentifier);
+      default:
+        return Debug.assertNever(node, `Unexpected node kind ${node.kind}`);
+    }
+  }
+  function updateNamespaceLikeImport(changes, sourceFile, checker, movedSymbols, newModuleSpecifier, oldImportId, oldImportNode, quotePreference) {
+    const preferredNewNamespaceName = ts_codefix_exports.moduleSpecifierToValidIdentifier(newModuleSpecifier, 99 /* ESNext */);
+    let needUniqueName = false;
+    const toChange = [];
+    ts_FindAllReferences_exports.Core.eachSymbolReferenceInFile(oldImportId, checker, sourceFile, (ref) => {
+      if (!isPropertyAccessExpression(ref.parent))
+        return;
+      needUniqueName = needUniqueName || !!checker.resolveName(
+        preferredNewNamespaceName,
+        ref,
+        67108863 /* All */,
+        /*excludeGlobals*/
+        true
+      );
+      if (movedSymbols.has(checker.getSymbolAtLocation(ref.parent.name))) {
+        toChange.push(ref);
+      }
+    });
+    if (toChange.length) {
+      const newNamespaceName = needUniqueName ? getUniqueName(preferredNewNamespaceName, sourceFile) : preferredNewNamespaceName;
+      for (const ref of toChange) {
+        changes.replaceNode(sourceFile, ref, factory.createIdentifier(newNamespaceName));
       }
+      changes.insertNodeAfter(sourceFile, oldImportNode, updateNamespaceLikeImportNode(oldImportNode, preferredNewNamespaceName, newModuleSpecifier, quotePreference));
     }
-    const possibleMapLocations = [];
-    if (mapFileName) {
-      possibleMapLocations.push(mapFileName);
+  }
+  function updateNamespaceLikeImportNode(node, newNamespaceName, newModuleSpecifier, quotePreference) {
+    const newNamespaceId = factory.createIdentifier(newNamespaceName);
+    const newModuleString = makeStringLiteral(newModuleSpecifier, quotePreference);
+    switch (node.kind) {
+      case 272 /* ImportDeclaration */:
+        return factory.createImportDeclaration(
+          /*modifiers*/
+          void 0,
+          factory.createImportClause(
+            /*isTypeOnly*/
+            false,
+            /*name*/
+            void 0,
+            factory.createNamespaceImport(newNamespaceId)
+          ),
+          newModuleString,
+          /*attributes*/
+          void 0
+        );
+      case 271 /* ImportEqualsDeclaration */:
+        return factory.createImportEqualsDeclaration(
+          /*modifiers*/
+          void 0,
+          /*isTypeOnly*/
+          false,
+          newNamespaceId,
+          factory.createExternalModuleReference(newModuleString)
+        );
+      case 260 /* VariableDeclaration */:
+        return factory.createVariableDeclaration(
+          newNamespaceId,
+          /*exclamationToken*/
+          void 0,
+          /*type*/
+          void 0,
+          createRequireCall(newModuleString)
+        );
+      default:
+        return Debug.assertNever(node, `Unexpected node kind ${node.kind}`);
     }
-    possibleMapLocations.push(generatedFileName + ".map");
-    const originalMapFileName = mapFileName && getNormalizedAbsolutePath(mapFileName, getDirectoryPath(generatedFileName));
-    for (const location of possibleMapLocations) {
-      const mapFileName2 = getNormalizedAbsolutePath(location, getDirectoryPath(generatedFileName));
-      const mapFileContents = readMapFile(mapFileName2, originalMapFileName);
-      if (isString(mapFileContents)) {
-        return convertDocumentToSourceMapper(host, mapFileContents, mapFileName2);
+  }
+  function createRequireCall(moduleSpecifier) {
+    return factory.createCallExpression(
+      factory.createIdentifier("require"),
+      /*typeArguments*/
+      void 0,
+      [moduleSpecifier]
+    );
+  }
+  function moduleSpecifierFromImport(i) {
+    return i.kind === 272 /* ImportDeclaration */ ? i.moduleSpecifier : i.kind === 271 /* ImportEqualsDeclaration */ ? i.moduleReference.expression : i.initializer.arguments[0];
+  }
+  function forEachImportInStatement(statement, cb) {
+    if (isImportDeclaration(statement)) {
+      if (isStringLiteral(statement.moduleSpecifier))
+        cb(statement);
+    } else if (isImportEqualsDeclaration(statement)) {
+      if (isExternalModuleReference(statement.moduleReference) && isStringLiteralLike(statement.moduleReference.expression)) {
+        cb(statement);
       }
-      if (mapFileContents !== void 0) {
-        return mapFileContents || void 0;
+    } else if (isVariableStatement(statement)) {
+      for (const decl of statement.declarationList.declarations) {
+        if (decl.initializer && isRequireCall(
+          decl.initializer,
+          /*requireStringLiteralLikeArgument*/
+          true
+        )) {
+          cb(decl);
+        }
       }
     }
-    return void 0;
   }
-  function convertDocumentToSourceMapper(host, contents, mapFileName) {
-    const map2 = tryParseRawSourceMap(contents);
-    if (!map2 || !map2.sources || !map2.file || !map2.mappings) {
-      return void 0;
+  function createOldFileImportsFromTargetFile(sourceFile, targetFileNeedExport, targetFileNameWithExtension, program, host, useEs6Imports, quotePreference) {
+    let defaultImport;
+    const imports = [];
+    targetFileNeedExport.forEach((symbol) => {
+      if (symbol.escapedName === "default" /* Default */) {
+        defaultImport = factory.createIdentifier(symbolNameNoDefault(symbol));
+      } else {
+        imports.push(symbol.name);
+      }
+    });
+    return makeImportOrRequire(sourceFile, defaultImport, imports, targetFileNameWithExtension, program, host, useEs6Imports, quotePreference);
+  }
+  function makeImportOrRequire(sourceFile, defaultImport, imports, targetFileNameWithExtension, program, host, useEs6Imports, quotePreference) {
+    const pathToTargetFile = resolvePath(getDirectoryPath(sourceFile.path), targetFileNameWithExtension);
+    const pathToTargetFileWithCorrectExtension = getModuleSpecifier(program.getCompilerOptions(), sourceFile, sourceFile.path, pathToTargetFile, createModuleSpecifierResolutionHost(program, host));
+    if (useEs6Imports) {
+      const specifiers = imports.map((i) => factory.createImportSpecifier(
+        /*isTypeOnly*/
+        false,
+        /*propertyName*/
+        void 0,
+        factory.createIdentifier(i)
+      ));
+      return makeImportIfNecessary(defaultImport, specifiers, pathToTargetFileWithCorrectExtension, quotePreference);
+    } else {
+      Debug.assert(!defaultImport, "No default import should exist");
+      const bindingElements = imports.map((i) => factory.createBindingElement(
+        /*dotDotDotToken*/
+        void 0,
+        /*propertyName*/
+        void 0,
+        i
+      ));
+      return bindingElements.length ? makeVariableStatement(
+        factory.createObjectBindingPattern(bindingElements),
+        /*type*/
+        void 0,
+        createRequireCall(makeStringLiteral(pathToTargetFileWithCorrectExtension, quotePreference))
+      ) : void 0;
     }
-    if (map2.sourcesContent && map2.sourcesContent.some(isString))
-      return void 0;
-    return createDocumentPositionMapper(host, map2, mapFileName);
   }
-  function createSourceFileLike(text, lineMap) {
-    return {
-      text,
-      lineMap,
-      getLineAndCharacterOfPosition(pos) {
-        return computeLineAndCharacterOfPosition(getLineStarts(this), pos);
+  function makeVariableStatement(name, type, initializer, flags = 2 /* Const */) {
+    return factory.createVariableStatement(
+      /*modifiers*/
+      void 0,
+      factory.createVariableDeclarationList([factory.createVariableDeclaration(
+        name,
+        /*exclamationToken*/
+        void 0,
+        type,
+        initializer
+      )], flags)
+    );
+  }
+  function addExports(sourceFile, toMove, needExport, useEs6Exports) {
+    return flatMap(toMove, (statement) => {
+      if (isTopLevelDeclarationStatement(statement) && !isExported(sourceFile, statement, useEs6Exports) && forEachTopLevelDeclaration(statement, (d) => {
+        var _a;
+        return needExport.has(Debug.checkDefined((_a = tryCast(d, canHaveSymbol)) == null ? void 0 : _a.symbol));
+      })) {
+        const exports = addExport(getSynthesizedDeepClone(statement), useEs6Exports);
+        if (exports)
+          return exports;
       }
-    };
+      return getSynthesizedDeepClone(statement);
+    });
   }
-  var base64UrlRegExp;
-  var init_sourcemaps = __esm({
-    "src/services/sourcemaps.ts"() {
-      "use strict";
-      init_ts4();
-      base64UrlRegExp = /^data:(?:application\/json(?:;charset=[uU][tT][fF]-8);base64,([A-Za-z0-9+\/=]+)$)?/;
+  function isExported(sourceFile, decl, useEs6Exports, name) {
+    var _a;
+    if (useEs6Exports) {
+      return !isExpressionStatement(decl) && hasSyntacticModifier(decl, 32 /* Export */) || !!(name && sourceFile.symbol && ((_a = sourceFile.symbol.exports) == null ? void 0 : _a.has(name.escapedText)));
     }
-  });
-
-  // src/services/suggestionDiagnostics.ts
-  function computeSuggestionDiagnostics(sourceFile, program, cancellationToken) {
-    program.getSemanticDiagnostics(sourceFile, cancellationToken);
-    const diags = [];
-    const checker = program.getTypeChecker();
-    const isCommonJSFile = sourceFile.impliedNodeFormat === 1 /* CommonJS */ || fileExtensionIsOneOf(sourceFile.fileName, [".cts" /* Cts */, ".cjs" /* Cjs */]);
-    if (!isCommonJSFile && sourceFile.commonJsModuleIndicator && (programContainsEsModules(program) || compilerOptionsIndicateEsModules(program.getCompilerOptions())) && containsTopLevelCommonjs(sourceFile)) {
-      diags.push(createDiagnosticForNode(getErrorNodeFromCommonJsIndicator(sourceFile.commonJsModuleIndicator), Diagnostics.File_is_a_CommonJS_module_it_may_be_converted_to_an_ES_module));
+    return !!sourceFile.symbol && !!sourceFile.symbol.exports && getNamesToExportInCommonJS(decl).some((name2) => sourceFile.symbol.exports.has(escapeLeadingUnderscores(name2)));
+  }
+  function deleteUnusedImports(sourceFile, importDecl, changes, isUnused) {
+    switch (importDecl.kind) {
+      case 272 /* ImportDeclaration */:
+        deleteUnusedImportsInDeclaration(sourceFile, importDecl, changes, isUnused);
+        break;
+      case 271 /* ImportEqualsDeclaration */:
+        if (isUnused(importDecl.name)) {
+          changes.delete(sourceFile, importDecl);
+        }
+        break;
+      case 260 /* VariableDeclaration */:
+        deleteUnusedImportsInVariableDeclaration(sourceFile, importDecl, changes, isUnused);
+        break;
+      default:
+        Debug.assertNever(importDecl, `Unexpected import decl kind ${importDecl.kind}`);
     }
-    const isJsFile = isSourceFileJS(sourceFile);
-    visitedNestedConvertibleFunctions.clear();
-    check(sourceFile);
-    if (getAllowSyntheticDefaultImports(program.getCompilerOptions())) {
-      for (const moduleSpecifier of sourceFile.imports) {
-        const importNode = importFromModuleSpecifier(moduleSpecifier);
-        const name = importNameForConvertToDefaultImport(importNode);
-        if (!name)
-          continue;
-        const module2 = getResolvedModule(sourceFile, moduleSpecifier.text, getModeForUsageLocation(sourceFile, moduleSpecifier));
-        const resolvedFile = module2 && program.getSourceFile(module2.resolvedFileName);
-        if (resolvedFile && resolvedFile.externalModuleIndicator && resolvedFile.externalModuleIndicator !== true && isExportAssignment(resolvedFile.externalModuleIndicator) && resolvedFile.externalModuleIndicator.isExportEquals) {
-          diags.push(createDiagnosticForNode(name, Diagnostics.Import_may_be_converted_to_a_default_import));
+  }
+  function deleteUnusedImportsInDeclaration(sourceFile, importDecl, changes, isUnused) {
+    if (!importDecl.importClause)
+      return;
+    const { name, namedBindings } = importDecl.importClause;
+    const defaultUnused = !name || isUnused(name);
+    const namedBindingsUnused = !namedBindings || (namedBindings.kind === 274 /* NamespaceImport */ ? isUnused(namedBindings.name) : namedBindings.elements.length !== 0 && namedBindings.elements.every((e) => isUnused(e.name)));
+    if (defaultUnused && namedBindingsUnused) {
+      changes.delete(sourceFile, importDecl);
+    } else {
+      if (name && defaultUnused) {
+        changes.delete(sourceFile, name);
+      }
+      if (namedBindings) {
+        if (namedBindingsUnused) {
+          changes.replaceNode(
+            sourceFile,
+            importDecl.importClause,
+            factory.updateImportClause(
+              importDecl.importClause,
+              importDecl.importClause.isTypeOnly,
+              name,
+              /*namedBindings*/
+              void 0
+            )
+          );
+        } else if (namedBindings.kind === 275 /* NamedImports */) {
+          for (const element of namedBindings.elements) {
+            if (isUnused(element.name))
+              changes.delete(sourceFile, element);
+          }
         }
       }
     }
-    addRange(diags, sourceFile.bindSuggestionDiagnostics);
-    addRange(diags, program.getSuggestionDiagnostics(sourceFile, cancellationToken));
-    return diags.sort((d1, d2) => d1.start - d2.start);
-    function check(node) {
-      if (isJsFile) {
-        if (canBeConvertedToClass(node, checker)) {
-          diags.push(createDiagnosticForNode(isVariableDeclaration(node.parent) ? node.parent.name : node, Diagnostics.This_constructor_function_may_be_converted_to_a_class_declaration));
-        }
-      } else {
-        if (isVariableStatement(node) && node.parent === sourceFile && node.declarationList.flags & 2 /* Const */ && node.declarationList.declarations.length === 1) {
-          const init = node.declarationList.declarations[0].initializer;
-          if (init && isRequireCall(
-            init,
+  }
+  function deleteUnusedImportsInVariableDeclaration(sourceFile, varDecl, changes, isUnused) {
+    const { name } = varDecl;
+    switch (name.kind) {
+      case 80 /* Identifier */:
+        if (isUnused(name)) {
+          if (varDecl.initializer && isRequireCall(
+            varDecl.initializer,
             /*requireStringLiteralLikeArgument*/
             true
           )) {
-            diags.push(createDiagnosticForNode(init, Diagnostics.require_call_may_be_converted_to_an_import));
+            changes.delete(sourceFile, isVariableDeclarationList(varDecl.parent) && length(varDecl.parent.declarations) === 1 ? varDecl.parent.parent : varDecl);
+          } else {
+            changes.delete(sourceFile, name);
           }
         }
-        const jsdocTypedefNode = ts_codefix_exports.getJSDocTypedefNode(node);
-        if (jsdocTypedefNode) {
-          diags.push(createDiagnosticForNode(jsdocTypedefNode, Diagnostics.JSDoc_typedef_may_be_converted_to_TypeScript_type));
-        }
-        if (ts_codefix_exports.parameterShouldGetTypeFromJSDoc(node)) {
-          diags.push(createDiagnosticForNode(node.name || node, Diagnostics.JSDoc_types_may_be_moved_to_TypeScript_types));
+        break;
+      case 207 /* ArrayBindingPattern */:
+        break;
+      case 206 /* ObjectBindingPattern */:
+        if (name.elements.every((e) => isIdentifier(e.name) && isUnused(e.name))) {
+          changes.delete(sourceFile, isVariableDeclarationList(varDecl.parent) && varDecl.parent.declarations.length === 1 ? varDecl.parent.parent : varDecl);
+        } else {
+          for (const element of name.elements) {
+            if (isIdentifier(element.name) && isUnused(element.name)) {
+              changes.delete(sourceFile, element.name);
+            }
+          }
         }
+        break;
+    }
+  }
+  function isTopLevelDeclarationStatement(node) {
+    Debug.assert(isSourceFile(node.parent), "Node parent should be a SourceFile");
+    return isNonVariableTopLevelDeclaration(node) || isVariableStatement(node);
+  }
+  function addExport(decl, useEs6Exports) {
+    return useEs6Exports ? [addEs6Export(decl)] : addCommonjsExport(decl);
+  }
+  function addEs6Export(d) {
+    const modifiers = canHaveModifiers(d) ? concatenate([factory.createModifier(95 /* ExportKeyword */)], getModifiers(d)) : void 0;
+    switch (d.kind) {
+      case 262 /* FunctionDeclaration */:
+        return factory.updateFunctionDeclaration(d, modifiers, d.asteriskToken, d.name, d.typeParameters, d.parameters, d.type, d.body);
+      case 263 /* ClassDeclaration */:
+        const decorators = canHaveDecorators(d) ? getDecorators(d) : void 0;
+        return factory.updateClassDeclaration(d, concatenate(decorators, modifiers), d.name, d.typeParameters, d.heritageClauses, d.members);
+      case 243 /* VariableStatement */:
+        return factory.updateVariableStatement(d, modifiers, d.declarationList);
+      case 267 /* ModuleDeclaration */:
+        return factory.updateModuleDeclaration(d, modifiers, d.name, d.body);
+      case 266 /* EnumDeclaration */:
+        return factory.updateEnumDeclaration(d, modifiers, d.name, d.members);
+      case 265 /* TypeAliasDeclaration */:
+        return factory.updateTypeAliasDeclaration(d, modifiers, d.name, d.typeParameters, d.type);
+      case 264 /* InterfaceDeclaration */:
+        return factory.updateInterfaceDeclaration(d, modifiers, d.name, d.typeParameters, d.heritageClauses, d.members);
+      case 271 /* ImportEqualsDeclaration */:
+        return factory.updateImportEqualsDeclaration(d, modifiers, d.isTypeOnly, d.name, d.moduleReference);
+      case 244 /* ExpressionStatement */:
+        return Debug.fail();
+      default:
+        return Debug.assertNever(d, `Unexpected declaration kind ${d.kind}`);
+    }
+  }
+  function addCommonjsExport(decl) {
+    return [decl, ...getNamesToExportInCommonJS(decl).map(createExportAssignment)];
+  }
+  function createExportAssignment(name) {
+    return factory.createExpressionStatement(
+      factory.createBinaryExpression(
+        factory.createPropertyAccessExpression(factory.createIdentifier("exports"), factory.createIdentifier(name)),
+        64 /* EqualsToken */,
+        factory.createIdentifier(name)
+      )
+    );
+  }
+  function getNamesToExportInCommonJS(decl) {
+    switch (decl.kind) {
+      case 262 /* FunctionDeclaration */:
+      case 263 /* ClassDeclaration */:
+        return [decl.name.text];
+      case 243 /* VariableStatement */:
+        return mapDefined(decl.declarationList.declarations, (d) => isIdentifier(d.name) ? d.name.text : void 0);
+      case 267 /* ModuleDeclaration */:
+      case 266 /* EnumDeclaration */:
+      case 265 /* TypeAliasDeclaration */:
+      case 264 /* InterfaceDeclaration */:
+      case 271 /* ImportEqualsDeclaration */:
+        return emptyArray;
+      case 244 /* ExpressionStatement */:
+        return Debug.fail("Can't export an ExpressionStatement");
+      default:
+        return Debug.assertNever(decl, `Unexpected decl kind ${decl.kind}`);
+    }
+  }
+  function filterImport(i, moduleSpecifier, keep) {
+    switch (i.kind) {
+      case 272 /* ImportDeclaration */: {
+        const clause = i.importClause;
+        if (!clause)
+          return void 0;
+        const defaultImport = clause.name && keep(clause.name) ? clause.name : void 0;
+        const namedBindings = clause.namedBindings && filterNamedBindings(clause.namedBindings, keep);
+        return defaultImport || namedBindings ? factory.createImportDeclaration(
+          /*modifiers*/
+          void 0,
+          factory.createImportClause(clause.isTypeOnly, defaultImport, namedBindings),
+          getSynthesizedDeepClone(moduleSpecifier),
+          /*attributes*/
+          void 0
+        ) : void 0;
       }
-      if (canBeConvertedToAsync(node)) {
-        addConvertToAsyncFunctionDiagnostics(node, checker, diags);
+      case 271 /* ImportEqualsDeclaration */:
+        return keep(i.name) ? i : void 0;
+      case 260 /* VariableDeclaration */: {
+        const name = filterBindingName(i.name, keep);
+        return name ? makeVariableStatement(name, i.type, createRequireCall(moduleSpecifier), i.parent.flags) : void 0;
       }
-      node.forEachChild(check);
+      default:
+        return Debug.assertNever(i, `Unexpected import kind ${i.kind}`);
     }
   }
-  function containsTopLevelCommonjs(sourceFile) {
-    return sourceFile.statements.some((statement) => {
-      switch (statement.kind) {
-        case 242 /* VariableStatement */:
-          return statement.declarationList.declarations.some((decl) => !!decl.initializer && isRequireCall(
-            propertyAccessLeftHandSide(decl.initializer),
-            /*requireStringLiteralLikeArgument*/
-            true
-          ));
-        case 243 /* ExpressionStatement */: {
-          const { expression } = statement;
-          if (!isBinaryExpression(expression))
-            return isRequireCall(
-              expression,
-              /*requireStringLiteralLikeArgument*/
-              true
-            );
-          const kind = getAssignmentDeclarationKind(expression);
-          return kind === 1 /* ExportsProperty */ || kind === 2 /* ModuleExports */;
-        }
-        default:
-          return false;
+  function filterNamedBindings(namedBindings, keep) {
+    if (namedBindings.kind === 274 /* NamespaceImport */) {
+      return keep(namedBindings.name) ? namedBindings : void 0;
+    } else {
+      const newElements = namedBindings.elements.filter((e) => keep(e.name));
+      return newElements.length ? factory.createNamedImports(newElements) : void 0;
+    }
+  }
+  function filterBindingName(name, keep) {
+    switch (name.kind) {
+      case 80 /* Identifier */:
+        return keep(name) ? name : void 0;
+      case 207 /* ArrayBindingPattern */:
+        return name;
+      case 206 /* ObjectBindingPattern */: {
+        const newElements = name.elements.filter((prop) => prop.propertyName || !isIdentifier(prop.name) || keep(prop.name));
+        return newElements.length ? factory.createObjectBindingPattern(newElements) : void 0;
       }
-    });
+    }
   }
-  function propertyAccessLeftHandSide(node) {
-    return isPropertyAccessExpression(node) ? propertyAccessLeftHandSide(node.expression) : node;
+  function nameOfTopLevelDeclaration(d) {
+    return isExpressionStatement(d) ? tryCast(d.expression.left.name, isIdentifier) : tryCast(d.name, isIdentifier);
   }
-  function importNameForConvertToDefaultImport(node) {
-    switch (node.kind) {
-      case 271 /* ImportDeclaration */:
-        const { importClause, moduleSpecifier } = node;
-        return importClause && !importClause.name && importClause.namedBindings && importClause.namedBindings.kind === 273 /* NamespaceImport */ && isStringLiteral(moduleSpecifier) ? importClause.namedBindings.name : void 0;
-      case 270 /* ImportEqualsDeclaration */:
-        return node.name;
+  function getTopLevelDeclarationStatement(d) {
+    switch (d.kind) {
+      case 260 /* VariableDeclaration */:
+        return d.parent.parent;
+      case 208 /* BindingElement */:
+        return getTopLevelDeclarationStatement(
+          cast(d.parent.parent, (p) => isVariableDeclaration(p) || isBindingElement(p))
+        );
       default:
-        return void 0;
+        return d;
     }
   }
-  function addConvertToAsyncFunctionDiagnostics(node, checker, diags) {
-    if (isConvertibleFunction(node, checker) && !visitedNestedConvertibleFunctions.has(getKeyFromNode(node))) {
-      diags.push(createDiagnosticForNode(
-        !node.name && isVariableDeclaration(node.parent) && isIdentifier(node.parent.name) ? node.parent.name : node,
-        Diagnostics.This_may_be_converted_to_an_async_function
-      ));
+  function addExportToChanges(sourceFile, decl, name, changes, useEs6Exports) {
+    if (isExported(sourceFile, decl, useEs6Exports, name))
+      return;
+    if (useEs6Exports) {
+      if (!isExpressionStatement(decl))
+        changes.insertExportModifier(sourceFile, decl);
+    } else {
+      const names = getNamesToExportInCommonJS(decl);
+      if (names.length !== 0)
+        changes.insertNodesAfter(sourceFile, decl, names.map(createExportAssignment));
     }
   }
-  function isConvertibleFunction(node, checker) {
-    return !isAsyncFunction(node) && node.body && isBlock(node.body) && hasReturnStatementWithPromiseHandler(node.body, checker) && returnsPromise(node, checker);
+  function createNewFileName(oldFile, program, context, host) {
+    const checker = program.getTypeChecker();
+    const toMove = getStatementsToMove(context);
+    let usage;
+    if (toMove) {
+      usage = getUsageInfo(oldFile, toMove.all, checker);
+      const currentDirectory = getDirectoryPath(oldFile.fileName);
+      const extension = extensionFromPath(oldFile.fileName);
+      const newFileName = combinePaths(
+        // new file is always placed in the same directory as the old file
+        currentDirectory,
+        // ensures the filename computed below isn't already taken
+        makeUniqueFilename(
+          // infers a name for the new file from the symbols being moved
+          inferNewFileName(usage.oldFileImportsFromTargetFile, usage.movedSymbols),
+          extension,
+          currentDirectory,
+          host
+        )
+      ) + extension;
+      return newFileName;
+    }
+    return "";
   }
-  function returnsPromise(node, checker) {
-    const signature = checker.getSignatureFromDeclaration(node);
-    const returnType = signature ? checker.getReturnTypeOfSignature(signature) : void 0;
-    return !!returnType && !!checker.getPromisedTypeOfPromise(returnType);
+  function getRangeToMove(context) {
+    const { file } = context;
+    const range = createTextRangeFromSpan(getRefactorContextSpan(context));
+    const { statements } = file;
+    let startNodeIndex = findIndex(statements, (s) => s.end > range.pos);
+    if (startNodeIndex === -1)
+      return void 0;
+    const startStatement = statements[startNodeIndex];
+    const overloadRangeToMove = getOverloadRangeToMove(file, startStatement);
+    if (overloadRangeToMove) {
+      startNodeIndex = overloadRangeToMove.start;
+    }
+    let endNodeIndex = findIndex(statements, (s) => s.end >= range.end, startNodeIndex);
+    if (endNodeIndex !== -1 && range.end <= statements[endNodeIndex].getStart()) {
+      endNodeIndex--;
+    }
+    const endingOverloadRangeToMove = getOverloadRangeToMove(file, statements[endNodeIndex]);
+    if (endingOverloadRangeToMove) {
+      endNodeIndex = endingOverloadRangeToMove.end;
+    }
+    return {
+      toMove: statements.slice(startNodeIndex, endNodeIndex === -1 ? statements.length : endNodeIndex + 1),
+      afterLast: endNodeIndex === -1 ? void 0 : statements[endNodeIndex + 1]
+    };
   }
-  function getErrorNodeFromCommonJsIndicator(commonJsModuleIndicator) {
-    return isBinaryExpression(commonJsModuleIndicator) ? commonJsModuleIndicator.left : commonJsModuleIndicator;
+  function getStatementsToMove(context) {
+    const rangeToMove = getRangeToMove(context);
+    if (rangeToMove === void 0)
+      return void 0;
+    const all = [];
+    const ranges = [];
+    const { toMove, afterLast } = rangeToMove;
+    getRangesWhere(toMove, isAllowedStatementToMove, (start, afterEndIndex) => {
+      for (let i = start; i < afterEndIndex; i++)
+        all.push(toMove[i]);
+      ranges.push({ first: toMove[start], afterLast });
+    });
+    return all.length === 0 ? void 0 : { all, ranges };
   }
-  function hasReturnStatementWithPromiseHandler(body, checker) {
-    return !!forEachReturnStatement(body, (statement) => isReturnStatementWithFixablePromiseHandler(statement, checker));
+  function isAllowedStatementToMove(statement) {
+    return !isPureImport(statement) && !isPrologueDirective(statement);
   }
-  function isReturnStatementWithFixablePromiseHandler(node, checker) {
-    return isReturnStatement(node) && !!node.expression && isFixablePromiseHandler(node.expression, checker);
+  function isPureImport(node) {
+    switch (node.kind) {
+      case 272 /* ImportDeclaration */:
+        return true;
+      case 271 /* ImportEqualsDeclaration */:
+        return !hasSyntacticModifier(node, 32 /* Export */);
+      case 243 /* VariableStatement */:
+        return node.declarationList.declarations.every((d) => !!d.initializer && isRequireCall(
+          d.initializer,
+          /*requireStringLiteralLikeArgument*/
+          true
+        ));
+      default:
+        return false;
+    }
   }
-  function isFixablePromiseHandler(node, checker) {
-    if (!isPromiseHandler(node) || !hasSupportedNumberOfArguments(node) || !node.arguments.every((arg) => isFixablePromiseArgument(arg, checker))) {
-      return false;
+  function getUsageInfo(oldFile, toMove, checker, existingTargetImports = /* @__PURE__ */ new Set()) {
+    const movedSymbols = /* @__PURE__ */ new Set();
+    const oldImportsNeededByTargetFile = /* @__PURE__ */ new Map();
+    const targetFileImportsFromOldFile = /* @__PURE__ */ new Set();
+    const containsJsx = find(toMove, (statement) => !!(statement.transformFlags & 2 /* ContainsJsx */));
+    const jsxNamespaceSymbol = getJsxNamespaceSymbol(containsJsx);
+    if (jsxNamespaceSymbol) {
+      oldImportsNeededByTargetFile.set(jsxNamespaceSymbol, false);
     }
-    let currentNode = node.expression.expression;
-    while (isPromiseHandler(currentNode) || isPropertyAccessExpression(currentNode)) {
-      if (isCallExpression(currentNode)) {
-        if (!hasSupportedNumberOfArguments(currentNode) || !currentNode.arguments.every((arg) => isFixablePromiseArgument(arg, checker))) {
-          return false;
+    for (const statement of toMove) {
+      forEachTopLevelDeclaration(statement, (decl) => {
+        movedSymbols.add(Debug.checkDefined(isExpressionStatement(decl) ? checker.getSymbolAtLocation(decl.expression.left) : decl.symbol, "Need a symbol here"));
+      });
+    }
+    const unusedImportsFromOldFile = /* @__PURE__ */ new Set();
+    for (const statement of toMove) {
+      forEachReference(statement, checker, (symbol, isValidTypeOnlyUseSite) => {
+        if (!symbol.declarations) {
+          return;
         }
-        currentNode = currentNode.expression.expression;
-      } else {
-        currentNode = currentNode.expression;
+        if (existingTargetImports.has(skipAlias(symbol, checker))) {
+          unusedImportsFromOldFile.add(symbol);
+          return;
+        }
+        for (const decl of symbol.declarations) {
+          if (isInImport(decl)) {
+            const prevIsTypeOnly = oldImportsNeededByTargetFile.get(symbol);
+            oldImportsNeededByTargetFile.set(symbol, prevIsTypeOnly === void 0 ? isValidTypeOnlyUseSite : prevIsTypeOnly && isValidTypeOnlyUseSite);
+          } else if (isTopLevelDeclaration(decl) && sourceFileOfTopLevelDeclaration(decl) === oldFile && !movedSymbols.has(symbol)) {
+            targetFileImportsFromOldFile.add(symbol);
+          }
+        }
+      });
+    }
+    for (const unusedImport of oldImportsNeededByTargetFile.keys()) {
+      unusedImportsFromOldFile.add(unusedImport);
+    }
+    const oldFileImportsFromTargetFile = /* @__PURE__ */ new Set();
+    for (const statement of oldFile.statements) {
+      if (contains(toMove, statement))
+        continue;
+      if (jsxNamespaceSymbol && !!(statement.transformFlags & 2 /* ContainsJsx */)) {
+        unusedImportsFromOldFile.delete(jsxNamespaceSymbol);
       }
+      forEachReference(statement, checker, (symbol) => {
+        if (movedSymbols.has(symbol))
+          oldFileImportsFromTargetFile.add(symbol);
+        unusedImportsFromOldFile.delete(symbol);
+      });
+    }
+    return { movedSymbols, targetFileImportsFromOldFile, oldFileImportsFromTargetFile, oldImportsNeededByTargetFile, unusedImportsFromOldFile };
+    function getJsxNamespaceSymbol(containsJsx2) {
+      if (containsJsx2 === void 0) {
+        return void 0;
+      }
+      const jsxNamespace = checker.getJsxNamespace(containsJsx2);
+      const jsxNamespaceSymbol2 = checker.resolveName(
+        jsxNamespace,
+        containsJsx2,
+        1920 /* Namespace */,
+        /*excludeGlobals*/
+        true
+      );
+      return !!jsxNamespaceSymbol2 && some(jsxNamespaceSymbol2.declarations, isInImport) ? jsxNamespaceSymbol2 : void 0;
     }
-    return true;
   }
-  function isPromiseHandler(node) {
-    return isCallExpression(node) && (hasPropertyAccessExpressionWithName(node, "then") || hasPropertyAccessExpressionWithName(node, "catch") || hasPropertyAccessExpressionWithName(node, "finally"));
+  function makeUniqueFilename(proposedFilename, extension, inDirectory, host) {
+    let newFilename = proposedFilename;
+    for (let i = 1; ; i++) {
+      const name = combinePaths(inDirectory, newFilename + extension);
+      if (!host.fileExists(name))
+        return newFilename;
+      newFilename = `${proposedFilename}.${i}`;
+    }
   }
-  function hasSupportedNumberOfArguments(node) {
-    const name = node.expression.name.text;
-    const maxArguments = name === "then" ? 2 : name === "catch" ? 1 : name === "finally" ? 1 : 0;
-    if (node.arguments.length > maxArguments)
-      return false;
-    if (node.arguments.length < maxArguments)
-      return true;
-    return maxArguments === 1 || some(node.arguments, (arg) => {
-      return arg.kind === 106 /* NullKeyword */ || isIdentifier(arg) && arg.text === "undefined";
+  function inferNewFileName(importsFromNewFile, movedSymbols) {
+    return forEachKey(importsFromNewFile, symbolNameNoDefault) || forEachKey(movedSymbols, symbolNameNoDefault) || "newFile";
+  }
+  function forEachReference(node, checker, onReference) {
+    node.forEachChild(function cb(node2) {
+      if (isIdentifier(node2) && !isDeclarationName(node2)) {
+        const sym = checker.getSymbolAtLocation(node2);
+        if (sym)
+          onReference(sym, isValidTypeOnlyAliasUseSite(node2));
+      } else {
+        node2.forEachChild(cb);
+      }
     });
   }
-  function isFixablePromiseArgument(arg, checker) {
-    switch (arg.kind) {
-      case 261 /* FunctionDeclaration */:
-      case 217 /* FunctionExpression */:
-        const functionFlags = getFunctionFlags(arg);
-        if (functionFlags & 1 /* Generator */) {
-          return false;
-        }
-      case 218 /* ArrowFunction */:
-        visitedNestedConvertibleFunctions.set(getKeyFromNode(arg), true);
-      case 106 /* NullKeyword */:
-        return true;
-      case 80 /* Identifier */:
-      case 210 /* PropertyAccessExpression */: {
-        const symbol = checker.getSymbolAtLocation(arg);
-        if (!symbol) {
-          return false;
-        }
-        return checker.isUndefinedSymbol(symbol) || some(skipAlias(symbol, checker).declarations, (d) => isFunctionLike(d) || hasInitializer(d) && !!d.initializer && isFunctionLike(d.initializer));
+  function forEachTopLevelDeclaration(statement, cb) {
+    switch (statement.kind) {
+      case 262 /* FunctionDeclaration */:
+      case 263 /* ClassDeclaration */:
+      case 267 /* ModuleDeclaration */:
+      case 266 /* EnumDeclaration */:
+      case 265 /* TypeAliasDeclaration */:
+      case 264 /* InterfaceDeclaration */:
+      case 271 /* ImportEqualsDeclaration */:
+        return cb(statement);
+      case 243 /* VariableStatement */:
+        return firstDefined(statement.declarationList.declarations, (decl) => forEachTopLevelDeclarationInBindingName(decl.name, cb));
+      case 244 /* ExpressionStatement */: {
+        const { expression } = statement;
+        return isBinaryExpression(expression) && getAssignmentDeclarationKind(expression) === 1 /* ExportsProperty */ ? cb(statement) : void 0;
       }
+    }
+  }
+  function isInImport(decl) {
+    switch (decl.kind) {
+      case 271 /* ImportEqualsDeclaration */:
+      case 276 /* ImportSpecifier */:
+      case 273 /* ImportClause */:
+      case 274 /* NamespaceImport */:
+        return true;
+      case 260 /* VariableDeclaration */:
+        return isVariableDeclarationInImport(decl);
+      case 208 /* BindingElement */:
+        return isVariableDeclaration(decl.parent.parent) && isVariableDeclarationInImport(decl.parent.parent);
       default:
         return false;
     }
   }
-  function getKeyFromNode(exp) {
-    return `${exp.pos.toString()}:${exp.end.toString()}`;
+  function isVariableDeclarationInImport(decl) {
+    return isSourceFile(decl.parent.parent.parent) && !!decl.initializer && isRequireCall(
+      decl.initializer,
+      /*requireStringLiteralLikeArgument*/
+      true
+    );
   }
-  function canBeConvertedToClass(node, checker) {
-    var _a, _b, _c, _d;
-    if (isFunctionExpression(node)) {
-      if (isVariableDeclaration(node.parent) && ((_a = node.symbol.members) == null ? void 0 : _a.size)) {
-        return true;
-      }
-      const symbol = checker.getSymbolOfExpando(
-        node,
-        /*allowDeclaration*/
-        false
-      );
-      return !!(symbol && (((_b = symbol.exports) == null ? void 0 : _b.size) || ((_c = symbol.members) == null ? void 0 : _c.size)));
-    }
-    if (isFunctionDeclaration(node)) {
-      return !!((_d = node.symbol.members) == null ? void 0 : _d.size);
+  function isTopLevelDeclaration(node) {
+    return isNonVariableTopLevelDeclaration(node) && isSourceFile(node.parent) || isVariableDeclaration(node) && isSourceFile(node.parent.parent.parent);
+  }
+  function sourceFileOfTopLevelDeclaration(node) {
+    return isVariableDeclaration(node) ? node.parent.parent.parent : node.parent;
+  }
+  function forEachTopLevelDeclarationInBindingName(name, cb) {
+    switch (name.kind) {
+      case 80 /* Identifier */:
+        return cb(cast(name.parent, (x) => isVariableDeclaration(x) || isBindingElement(x)));
+      case 207 /* ArrayBindingPattern */:
+      case 206 /* ObjectBindingPattern */:
+        return firstDefined(name.elements, (em) => isOmittedExpression(em) ? void 0 : forEachTopLevelDeclarationInBindingName(em.name, cb));
+      default:
+        return Debug.assertNever(name, `Unexpected name kind ${name.kind}`);
     }
-    return false;
   }
-  function canBeConvertedToAsync(node) {
+  function isNonVariableTopLevelDeclaration(node) {
     switch (node.kind) {
-      case 261 /* FunctionDeclaration */:
-      case 173 /* MethodDeclaration */:
-      case 217 /* FunctionExpression */:
-      case 218 /* ArrowFunction */:
+      case 262 /* FunctionDeclaration */:
+      case 263 /* ClassDeclaration */:
+      case 267 /* ModuleDeclaration */:
+      case 266 /* EnumDeclaration */:
+      case 265 /* TypeAliasDeclaration */:
+      case 264 /* InterfaceDeclaration */:
+      case 271 /* ImportEqualsDeclaration */:
         return true;
       default:
         return false;
     }
   }
-  var visitedNestedConvertibleFunctions;
-  var init_suggestionDiagnostics = __esm({
-    "src/services/suggestionDiagnostics.ts"() {
-      "use strict";
-      init_ts4();
-      visitedNestedConvertibleFunctions = /* @__PURE__ */ new Map();
-    }
-  });
-
-  // src/services/transpile.ts
-  function transpileModule(input, transpileOptions) {
-    const diagnostics = [];
-    const options = transpileOptions.compilerOptions ? fixupCompilerOptions(transpileOptions.compilerOptions, diagnostics) : {};
-    const defaultOptions = getDefaultCompilerOptions2();
-    for (const key in defaultOptions) {
-      if (hasProperty(defaultOptions, key) && options[key] === void 0) {
-        options[key] = defaultOptions[key];
-      }
-    }
-    for (const option of transpileOptionValueCompilerOptions) {
-      if (options.verbatimModuleSyntax && optionsRedundantWithVerbatimModuleSyntax.has(option.name)) {
-        continue;
+  function moveStatementsToTargetFile(changes, program, statements, targetFile, toMove) {
+    var _a;
+    const removedExports = /* @__PURE__ */ new Set();
+    const targetExports = (_a = targetFile.symbol) == null ? void 0 : _a.exports;
+    if (targetExports) {
+      const checker = program.getTypeChecker();
+      const targetToSourceExports = /* @__PURE__ */ new Map();
+      for (const node of toMove.all) {
+        if (isTopLevelDeclarationStatement(node) && hasSyntacticModifier(node, 32 /* Export */)) {
+          forEachTopLevelDeclaration(node, (declaration) => {
+            var _a2;
+            const targetDeclarations = canHaveSymbol(declaration) ? (_a2 = targetExports.get(declaration.symbol.escapedName)) == null ? void 0 : _a2.declarations : void 0;
+            const exportDeclaration = firstDefined(targetDeclarations, (d) => isExportDeclaration(d) ? d : isExportSpecifier(d) ? tryCast(d.parent.parent, isExportDeclaration) : void 0);
+            if (exportDeclaration && exportDeclaration.moduleSpecifier) {
+              targetToSourceExports.set(exportDeclaration, (targetToSourceExports.get(exportDeclaration) || /* @__PURE__ */ new Set()).add(declaration));
+            }
+          });
+        }
       }
-      options[option.name] = option.transpileOptionValue;
-    }
-    options.suppressOutputPathCheck = true;
-    options.allowNonTsExtensions = true;
-    const newLine = getNewLineCharacter(options);
-    const compilerHost = {
-      getSourceFile: (fileName) => fileName === normalizePath(inputFileName) ? sourceFile : void 0,
-      writeFile: (name, text) => {
-        if (fileExtensionIs(name, ".map")) {
-          Debug.assertEqual(sourceMapText, void 0, "Unexpected multiple source map outputs, file:", name);
-          sourceMapText = text;
-        } else {
-          Debug.assertEqual(outputText, void 0, "Unexpected multiple outputs, file:", name);
-          outputText = text;
+      for (const [exportDeclaration, topLevelDeclarations] of arrayFrom(targetToSourceExports)) {
+        if (exportDeclaration.exportClause && isNamedExports(exportDeclaration.exportClause) && length(exportDeclaration.exportClause.elements)) {
+          const elements = exportDeclaration.exportClause.elements;
+          const updatedElements = filter(elements, (elem) => find(skipAlias(elem.symbol, checker).declarations, (d) => isTopLevelDeclaration(d) && topLevelDeclarations.has(d)) === void 0);
+          if (length(updatedElements) === 0) {
+            changes.deleteNode(targetFile, exportDeclaration);
+            removedExports.add(exportDeclaration);
+            continue;
+          }
+          if (length(updatedElements) < length(elements)) {
+            changes.replaceNode(targetFile, exportDeclaration, factory.updateExportDeclaration(exportDeclaration, exportDeclaration.modifiers, exportDeclaration.isTypeOnly, factory.updateNamedExports(exportDeclaration.exportClause, factory.createNodeArray(updatedElements, elements.hasTrailingComma)), exportDeclaration.moduleSpecifier, exportDeclaration.attributes));
+          }
         }
-      },
-      getDefaultLibFileName: () => "lib.d.ts",
-      useCaseSensitiveFileNames: () => false,
-      getCanonicalFileName: (fileName) => fileName,
-      getCurrentDirectory: () => "",
-      getNewLine: () => newLine,
-      fileExists: (fileName) => fileName === inputFileName,
-      readFile: () => "",
-      directoryExists: () => true,
-      getDirectories: () => []
-    };
-    const inputFileName = transpileOptions.fileName || (transpileOptions.compilerOptions && transpileOptions.compilerOptions.jsx ? "module.tsx" : "module.ts");
-    const sourceFile = createSourceFile(
-      inputFileName,
-      input,
-      {
-        languageVersion: getEmitScriptTarget(options),
-        impliedNodeFormat: getImpliedNodeFormatForFile(
-          toPath(inputFileName, "", compilerHost.getCanonicalFileName),
-          /*packageJsonInfoCache*/
-          void 0,
-          compilerHost,
-          options
-        ),
-        setExternalModuleIndicator: getSetExternalModuleIndicator(options)
       }
-    );
-    if (transpileOptions.moduleName) {
-      sourceFile.moduleName = transpileOptions.moduleName;
-    }
-    if (transpileOptions.renamedDependencies) {
-      sourceFile.renamedDependencies = new Map(Object.entries(transpileOptions.renamedDependencies));
     }
-    let outputText;
-    let sourceMapText;
-    const program = createProgram([inputFileName], options, compilerHost);
-    if (transpileOptions.reportDiagnostics) {
-      addRange(
-        /*to*/
-        diagnostics,
-        /*from*/
-        program.getSyntacticDiagnostics(sourceFile)
-      );
-      addRange(
-        /*to*/
-        diagnostics,
-        /*from*/
-        program.getOptionsDiagnostics()
+    const lastReExport = findLast(targetFile.statements, (n) => isExportDeclaration(n) && !!n.moduleSpecifier && !removedExports.has(n));
+    if (lastReExport) {
+      changes.insertNodesBefore(
+        targetFile,
+        lastReExport,
+        statements,
+        /*blankLineBetween*/
+        true
       );
+    } else {
+      changes.insertNodesAfter(targetFile, targetFile.statements[targetFile.statements.length - 1], statements);
     }
-    program.emit(
-      /*targetSourceFile*/
-      void 0,
-      /*writeFile*/
-      void 0,
-      /*cancellationToken*/
-      void 0,
-      /*emitOnlyDtsFiles*/
-      void 0,
-      transpileOptions.transformers
-    );
-    if (outputText === void 0)
-      return Debug.fail("Output generation failed");
-    return { outputText, diagnostics, sourceMapText };
   }
-  function transpile(input, compilerOptions, fileName, diagnostics, moduleName) {
-    const output = transpileModule(input, { compilerOptions, fileName, reportDiagnostics: !!diagnostics, moduleName });
-    addRange(diagnostics, output.diagnostics);
-    return output.outputText;
+  function getOverloadRangeToMove(sourceFile, statement) {
+    if (isFunctionLikeDeclaration(statement)) {
+      const declarations = statement.symbol.declarations;
+      if (declarations === void 0 || length(declarations) <= 1 || !contains(declarations, statement)) {
+        return void 0;
+      }
+      const firstDecl = declarations[0];
+      const lastDecl = declarations[length(declarations) - 1];
+      const statementsToMove = mapDefined(declarations, (d) => getSourceFileOfNode(d) === sourceFile && isStatement(d) ? d : void 0);
+      const end = findIndex(sourceFile.statements, (s) => s.end >= lastDecl.end);
+      const start = findIndex(sourceFile.statements, (s) => s.end >= firstDecl.end);
+      return { toMove: statementsToMove, start, end };
+    }
+    return void 0;
   }
-  function fixupCompilerOptions(options, diagnostics) {
-    commandLineOptionsStringToEnum = commandLineOptionsStringToEnum || filter(optionDeclarations, (o) => typeof o.type === "object" && !forEachEntry(o.type, (v) => typeof v !== "number"));
-    options = cloneCompilerOptions(options);
-    for (const opt of commandLineOptionsStringToEnum) {
-      if (!hasProperty(options, opt.name)) {
-        continue;
+  function getExistingImports(sourceFile, checker) {
+    const imports = /* @__PURE__ */ new Set();
+    for (const moduleSpecifier of sourceFile.imports) {
+      const declaration = importFromModuleSpecifier(moduleSpecifier);
+      if (isImportDeclaration(declaration) && declaration.importClause && declaration.importClause.namedBindings && isNamedImports(declaration.importClause.namedBindings)) {
+        for (const e of declaration.importClause.namedBindings.elements) {
+          const symbol = checker.getSymbolAtLocation(e.propertyName || e.name);
+          if (symbol) {
+            imports.add(skipAlias(symbol, checker));
+          }
+        }
       }
-      const value = options[opt.name];
-      if (isString(value)) {
-        options[opt.name] = parseCustomTypeOption(opt, value, diagnostics);
-      } else {
-        if (!forEachEntry(opt.type, (v) => v === value)) {
-          diagnostics.push(createCompilerDiagnosticForInvalidCustomType(opt));
+      if (isVariableDeclarationInitializedToRequire(declaration.parent) && isObjectBindingPattern(declaration.parent.name)) {
+        for (const e of declaration.parent.name.elements) {
+          const symbol = checker.getSymbolAtLocation(e.propertyName || e.name);
+          if (symbol) {
+            imports.add(skipAlias(symbol, checker));
+          }
         }
       }
     }
-    return options;
+    return imports;
   }
-  var optionsRedundantWithVerbatimModuleSyntax, commandLineOptionsStringToEnum;
-  var init_transpile = __esm({
-    "src/services/transpile.ts"() {
+  var refactorNameForMoveToFile, description2, moveToFileAction;
+  var init_moveToFile = __esm({
+    "src/services/refactors/moveToFile.ts"() {
       "use strict";
+      init_moduleSpecifiers();
       init_ts4();
-      optionsRedundantWithVerbatimModuleSyntax = /* @__PURE__ */ new Set([
-        "isolatedModules",
-        "preserveValueImports",
-        "importsNotUsedAsValues"
-      ]);
+      init_refactorProvider();
+      refactorNameForMoveToFile = "Move to file";
+      description2 = getLocaleSpecificMessage(Diagnostics.Move_to_file);
+      moveToFileAction = {
+        name: "Move to file",
+        description: description2,
+        kind: "refactor.move.file"
+      };
+      registerRefactor(refactorNameForMoveToFile, {
+        kinds: [moveToFileAction.kind],
+        getAvailableActions: function getRefactorActionsToMoveToFile(context, interactiveRefactorArguments) {
+          const statements = getStatementsToMove(context);
+          if (!interactiveRefactorArguments) {
+            return emptyArray;
+          }
+          if (context.preferences.allowTextChangesInNewFiles && statements) {
+            return [{ name: refactorNameForMoveToFile, description: description2, actions: [moveToFileAction] }];
+          }
+          if (context.preferences.provideRefactorNotApplicableReason) {
+            return [{ name: refactorNameForMoveToFile, description: description2, actions: [{ ...moveToFileAction, notApplicableReason: getLocaleSpecificMessage(Diagnostics.Selection_is_not_a_valid_statement_or_statements) }] }];
+          }
+          return emptyArray;
+        },
+        getEditsForAction: function getRefactorEditsToMoveToFile(context, actionName2, interactiveRefactorArguments) {
+          Debug.assert(actionName2 === refactorNameForMoveToFile, "Wrong refactor invoked");
+          const statements = Debug.checkDefined(getStatementsToMove(context));
+          const { host, program } = context;
+          Debug.assert(interactiveRefactorArguments, "No interactive refactor arguments available");
+          const targetFile = interactiveRefactorArguments.targetFile;
+          if (hasJSFileExtension(targetFile) || hasTSFileExtension(targetFile)) {
+            if (host.fileExists(targetFile) && program.getSourceFile(targetFile) === void 0) {
+              return error(getLocaleSpecificMessage(Diagnostics.Cannot_move_statements_to_the_selected_file));
+            }
+            const edits = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange4(context, context.file, interactiveRefactorArguments.targetFile, context.program, statements, t, context.host, context.preferences));
+            return { edits, renameFilename: void 0, renameLocation: void 0 };
+          }
+          return error(getLocaleSpecificMessage(Diagnostics.Cannot_move_to_file_selected_file_is_invalid));
+        }
+      });
     }
   });
 
-  // src/services/navigateTo.ts
-  function getNavigateToItems(sourceFiles, checker, cancellationToken, searchValue, maxResultCount, excludeDtsFiles) {
-    const patternMatcher = createPatternMatcher(searchValue);
-    if (!patternMatcher)
+  // src/services/refactors/convertOverloadListToSingleSignature.ts
+  function getRefactorActionsToConvertOverloadsToOneSignature(context) {
+    const { file, startPosition, program } = context;
+    const info = getConvertableOverloadListAtPosition(file, startPosition, program);
+    if (!info)
       return emptyArray;
-    const rawItems = [];
-    for (const sourceFile of sourceFiles) {
-      cancellationToken.throwIfCancellationRequested();
-      if (excludeDtsFiles && sourceFile.isDeclarationFile) {
-        continue;
+    return [{
+      name: refactorName6,
+      description: refactorDescription2,
+      actions: [functionOverloadAction]
+    }];
+  }
+  function getRefactorEditsToConvertOverloadsToOneSignature(context) {
+    const { file, startPosition, program } = context;
+    const signatureDecls = getConvertableOverloadListAtPosition(file, startPosition, program);
+    if (!signatureDecls)
+      return void 0;
+    const checker = program.getTypeChecker();
+    const lastDeclaration = signatureDecls[signatureDecls.length - 1];
+    let updated = lastDeclaration;
+    switch (lastDeclaration.kind) {
+      case 173 /* MethodSignature */: {
+        updated = factory.updateMethodSignature(
+          lastDeclaration,
+          lastDeclaration.modifiers,
+          lastDeclaration.name,
+          lastDeclaration.questionToken,
+          lastDeclaration.typeParameters,
+          getNewParametersForCombinedSignature(signatureDecls),
+          lastDeclaration.type
+        );
+        break;
       }
-      sourceFile.getNamedDeclarations().forEach((declarations, name) => {
-        getItemsFromNamedDeclaration(patternMatcher, name, declarations, checker, sourceFile.fileName, rawItems);
-      });
+      case 174 /* MethodDeclaration */: {
+        updated = factory.updateMethodDeclaration(
+          lastDeclaration,
+          lastDeclaration.modifiers,
+          lastDeclaration.asteriskToken,
+          lastDeclaration.name,
+          lastDeclaration.questionToken,
+          lastDeclaration.typeParameters,
+          getNewParametersForCombinedSignature(signatureDecls),
+          lastDeclaration.type,
+          lastDeclaration.body
+        );
+        break;
+      }
+      case 179 /* CallSignature */: {
+        updated = factory.updateCallSignature(
+          lastDeclaration,
+          lastDeclaration.typeParameters,
+          getNewParametersForCombinedSignature(signatureDecls),
+          lastDeclaration.type
+        );
+        break;
+      }
+      case 176 /* Constructor */: {
+        updated = factory.updateConstructorDeclaration(
+          lastDeclaration,
+          lastDeclaration.modifiers,
+          getNewParametersForCombinedSignature(signatureDecls),
+          lastDeclaration.body
+        );
+        break;
+      }
+      case 180 /* ConstructSignature */: {
+        updated = factory.updateConstructSignature(
+          lastDeclaration,
+          lastDeclaration.typeParameters,
+          getNewParametersForCombinedSignature(signatureDecls),
+          lastDeclaration.type
+        );
+        break;
+      }
+      case 262 /* FunctionDeclaration */: {
+        updated = factory.updateFunctionDeclaration(
+          lastDeclaration,
+          lastDeclaration.modifiers,
+          lastDeclaration.asteriskToken,
+          lastDeclaration.name,
+          lastDeclaration.typeParameters,
+          getNewParametersForCombinedSignature(signatureDecls),
+          lastDeclaration.type,
+          lastDeclaration.body
+        );
+        break;
+      }
+      default:
+        return Debug.failBadSyntaxKind(lastDeclaration, "Unhandled signature kind in overload list conversion refactoring");
     }
-    rawItems.sort(compareNavigateToItems);
-    return (maxResultCount === void 0 ? rawItems : rawItems.slice(0, maxResultCount)).map(createNavigateToItem);
-  }
-  function getItemsFromNamedDeclaration(patternMatcher, name, declarations, checker, fileName, rawItems) {
-    const match = patternMatcher.getMatchForLastSegmentOfPattern(name);
-    if (!match) {
+    if (updated === lastDeclaration) {
       return;
     }
-    for (const declaration of declarations) {
-      if (!shouldKeepItem(declaration, checker))
-        continue;
-      if (patternMatcher.patternContainsDots) {
-        const fullMatch = patternMatcher.getFullMatch(getContainers(declaration), name);
-        if (fullMatch) {
-          rawItems.push({ name, fileName, matchKind: fullMatch.kind, isCaseSensitive: fullMatch.isCaseSensitive, declaration });
+    const edits = ts_textChanges_exports.ChangeTracker.with(context, (t) => {
+      t.replaceNodeRange(file, signatureDecls[0], signatureDecls[signatureDecls.length - 1], updated);
+    });
+    return { renameFilename: void 0, renameLocation: void 0, edits };
+    function getNewParametersForCombinedSignature(signatureDeclarations) {
+      const lastSig = signatureDeclarations[signatureDeclarations.length - 1];
+      if (isFunctionLikeDeclaration(lastSig) && lastSig.body) {
+        signatureDeclarations = signatureDeclarations.slice(0, signatureDeclarations.length - 1);
+      }
+      return factory.createNodeArray([
+        factory.createParameterDeclaration(
+          /*modifiers*/
+          void 0,
+          factory.createToken(26 /* DotDotDotToken */),
+          "args",
+          /*questionToken*/
+          void 0,
+          factory.createUnionTypeNode(map(signatureDeclarations, convertSignatureParametersToTuple))
+        )
+      ]);
+    }
+    function convertSignatureParametersToTuple(decl) {
+      const members = map(decl.parameters, convertParameterToNamedTupleMember);
+      return setEmitFlags(factory.createTupleTypeNode(members), some(members, (m) => !!length(getSyntheticLeadingComments(m))) ? 0 /* None */ : 1 /* SingleLine */);
+    }
+    function convertParameterToNamedTupleMember(p) {
+      Debug.assert(isIdentifier(p.name));
+      const result = setTextRange(
+        factory.createNamedTupleMember(
+          p.dotDotDotToken,
+          p.name,
+          p.questionToken,
+          p.type || factory.createKeywordTypeNode(133 /* AnyKeyword */)
+        ),
+        p
+      );
+      const parameterDocComment = p.symbol && p.symbol.getDocumentationComment(checker);
+      if (parameterDocComment) {
+        const newComment = displayPartsToString(parameterDocComment);
+        if (newComment.length) {
+          setSyntheticLeadingComments(result, [{
+            text: `*
+${newComment.split("\n").map((c) => ` * ${c}`).join("\n")}
+ `,
+            kind: 3 /* MultiLineCommentTrivia */,
+            pos: -1,
+            end: -1,
+            hasTrailingNewLine: true,
+            hasLeadingNewline: true
+          }]);
         }
-      } else {
-        rawItems.push({ name, fileName, matchKind: match.kind, isCaseSensitive: match.isCaseSensitive, declaration });
       }
+      return result;
     }
   }
-  function shouldKeepItem(declaration, checker) {
-    switch (declaration.kind) {
-      case 272 /* ImportClause */:
-      case 275 /* ImportSpecifier */:
-      case 270 /* ImportEqualsDeclaration */:
-        const importer = checker.getSymbolAtLocation(declaration.name);
-        const imported = checker.getAliasedSymbol(importer);
-        return importer.escapedName !== imported.escapedName;
-      default:
+  function isConvertableSignatureDeclaration(d) {
+    switch (d.kind) {
+      case 173 /* MethodSignature */:
+      case 174 /* MethodDeclaration */:
+      case 179 /* CallSignature */:
+      case 176 /* Constructor */:
+      case 180 /* ConstructSignature */:
+      case 262 /* FunctionDeclaration */:
         return true;
     }
+    return false;
   }
-  function tryAddSingleDeclarationName(declaration, containers) {
-    const name = getNameOfDeclaration(declaration);
-    return !!name && (pushLiteral(name, containers) || name.kind === 166 /* ComputedPropertyName */ && tryAddComputedPropertyName(name.expression, containers));
-  }
-  function tryAddComputedPropertyName(expression, containers) {
-    return pushLiteral(expression, containers) || isPropertyAccessExpression(expression) && (containers.push(expression.name.text), true) && tryAddComputedPropertyName(expression.expression, containers);
-  }
-  function pushLiteral(node, containers) {
-    return isPropertyNameLiteral(node) && (containers.push(getTextOfIdentifierOrLiteral(node)), true);
+  function getConvertableOverloadListAtPosition(file, startPosition, program) {
+    const node = getTokenAtPosition(file, startPosition);
+    const containingDecl = findAncestor(node, isConvertableSignatureDeclaration);
+    if (!containingDecl) {
+      return;
+    }
+    if (isFunctionLikeDeclaration(containingDecl) && containingDecl.body && rangeContainsPosition(containingDecl.body, startPosition)) {
+      return;
+    }
+    const checker = program.getTypeChecker();
+    const signatureSymbol = containingDecl.symbol;
+    if (!signatureSymbol) {
+      return;
+    }
+    const decls = signatureSymbol.declarations;
+    if (length(decls) <= 1) {
+      return;
+    }
+    if (!every(decls, (d) => getSourceFileOfNode(d) === file)) {
+      return;
+    }
+    if (!isConvertableSignatureDeclaration(decls[0])) {
+      return;
+    }
+    const kindOne = decls[0].kind;
+    if (!every(decls, (d) => d.kind === kindOne)) {
+      return;
+    }
+    const signatureDecls = decls;
+    if (some(signatureDecls, (d) => !!d.typeParameters || some(d.parameters, (p) => !!p.modifiers || !isIdentifier(p.name)))) {
+      return;
+    }
+    const signatures = mapDefined(signatureDecls, (d) => checker.getSignatureFromDeclaration(d));
+    if (length(signatures) !== length(decls)) {
+      return;
+    }
+    const returnOne = checker.getReturnTypeOfSignature(signatures[0]);
+    if (!every(signatures, (s) => checker.getReturnTypeOfSignature(s) === returnOne)) {
+      return;
+    }
+    return signatureDecls;
   }
-  function getContainers(declaration) {
-    const containers = [];
-    const name = getNameOfDeclaration(declaration);
-    if (name && name.kind === 166 /* ComputedPropertyName */ && !tryAddComputedPropertyName(name.expression, containers)) {
+  var refactorName6, refactorDescription2, functionOverloadAction;
+  var init_convertOverloadListToSingleSignature = __esm({
+    "src/services/refactors/convertOverloadListToSingleSignature.ts"() {
+      "use strict";
+      init_ts4();
+      init_ts_refactor();
+      refactorName6 = "Convert overload list to single signature";
+      refactorDescription2 = getLocaleSpecificMessage(Diagnostics.Convert_overload_list_to_single_signature);
+      functionOverloadAction = {
+        name: refactorName6,
+        description: refactorDescription2,
+        kind: "refactor.rewrite.function.overloadList"
+      };
+      registerRefactor(refactorName6, {
+        kinds: [functionOverloadAction.kind],
+        getEditsForAction: getRefactorEditsToConvertOverloadsToOneSignature,
+        getAvailableActions: getRefactorActionsToConvertOverloadsToOneSignature
+      });
+    }
+  });
+
+  // src/services/refactors/addOrRemoveBracesToArrowFunction.ts
+  function getRefactorActionsToRemoveFunctionBraces(context) {
+    const { file, startPosition, triggerReason } = context;
+    const info = getConvertibleArrowFunctionAtPosition(file, startPosition, triggerReason === "invoked");
+    if (!info)
       return emptyArray;
+    if (!isRefactorErrorInfo(info)) {
+      return [{
+        name: refactorName7,
+        description: refactorDescription3,
+        actions: [
+          info.addBraces ? addBracesAction : removeBracesAction
+        ]
+      }];
     }
-    containers.shift();
-    let container = getContainerNode(declaration);
-    while (container) {
-      if (!tryAddSingleDeclarationName(container, containers)) {
-        return emptyArray;
-      }
-      container = getContainerNode(container);
+    if (context.preferences.provideRefactorNotApplicableReason) {
+      return [{
+        name: refactorName7,
+        description: refactorDescription3,
+        actions: [
+          { ...addBracesAction, notApplicableReason: info.error },
+          { ...removeBracesAction, notApplicableReason: info.error }
+        ]
+      }];
     }
-    return containers.reverse();
+    return emptyArray;
   }
-  function compareNavigateToItems(i1, i2) {
-    return compareValues(i1.matchKind, i2.matchKind) || compareStringsCaseSensitiveUI(i1.name, i2.name);
+  function getRefactorEditsToRemoveFunctionBraces(context, actionName2) {
+    const { file, startPosition } = context;
+    const info = getConvertibleArrowFunctionAtPosition(file, startPosition);
+    Debug.assert(info && !isRefactorErrorInfo(info), "Expected applicable refactor info");
+    const { expression, returnStatement, func } = info;
+    let body;
+    if (actionName2 === addBracesAction.name) {
+      const returnStatement2 = factory.createReturnStatement(expression);
+      body = factory.createBlock(
+        [returnStatement2],
+        /*multiLine*/
+        true
+      );
+      copyLeadingComments(
+        expression,
+        returnStatement2,
+        file,
+        3 /* MultiLineCommentTrivia */,
+        /*hasTrailingNewLine*/
+        true
+      );
+    } else if (actionName2 === removeBracesAction.name && returnStatement) {
+      const actualExpression = expression || factory.createVoidZero();
+      body = needsParentheses(actualExpression) ? factory.createParenthesizedExpression(actualExpression) : actualExpression;
+      copyTrailingAsLeadingComments(
+        returnStatement,
+        body,
+        file,
+        3 /* MultiLineCommentTrivia */,
+        /*hasTrailingNewLine*/
+        false
+      );
+      copyLeadingComments(
+        returnStatement,
+        body,
+        file,
+        3 /* MultiLineCommentTrivia */,
+        /*hasTrailingNewLine*/
+        false
+      );
+      copyTrailingComments(
+        returnStatement,
+        body,
+        file,
+        3 /* MultiLineCommentTrivia */,
+        /*hasTrailingNewLine*/
+        false
+      );
+    } else {
+      Debug.fail("invalid action");
+    }
+    const edits = ts_textChanges_exports.ChangeTracker.with(context, (t) => {
+      t.replaceNode(file, func.body, body);
+    });
+    return { renameFilename: void 0, renameLocation: void 0, edits };
   }
-  function createNavigateToItem(rawItem) {
-    const declaration = rawItem.declaration;
-    const container = getContainerNode(declaration);
-    const containerName = container && getNameOfDeclaration(container);
-    return {
-      name: rawItem.name,
-      kind: getNodeKind(declaration),
-      kindModifiers: getNodeModifiers(declaration),
-      matchKind: PatternMatchKind[rawItem.matchKind],
-      isCaseSensitive: rawItem.isCaseSensitive,
-      fileName: rawItem.fileName,
-      textSpan: createTextSpanFromNode(declaration),
-      // TODO(jfreeman): What should be the containerName when the container has a computed name?
-      containerName: containerName ? containerName.text : "",
-      containerKind: containerName ? getNodeKind(container) : "" /* unknown */
-    };
+  function getConvertibleArrowFunctionAtPosition(file, startPosition, considerFunctionBodies = true, kind) {
+    const node = getTokenAtPosition(file, startPosition);
+    const func = getContainingFunction(node);
+    if (!func) {
+      return {
+        error: getLocaleSpecificMessage(Diagnostics.Could_not_find_a_containing_arrow_function)
+      };
+    }
+    if (!isArrowFunction(func)) {
+      return {
+        error: getLocaleSpecificMessage(Diagnostics.Containing_function_is_not_an_arrow_function)
+      };
+    }
+    if (!rangeContainsRange(func, node) || rangeContainsRange(func.body, node) && !considerFunctionBodies) {
+      return void 0;
+    }
+    if (refactorKindBeginsWith(addBracesAction.kind, kind) && isExpression(func.body)) {
+      return { func, addBraces: true, expression: func.body };
+    } else if (refactorKindBeginsWith(removeBracesAction.kind, kind) && isBlock(func.body) && func.body.statements.length === 1) {
+      const firstStatement = first(func.body.statements);
+      if (isReturnStatement(firstStatement)) {
+        const expression = firstStatement.expression && isObjectLiteralExpression(getLeftmostExpression(
+          firstStatement.expression,
+          /*stopAtCallExpressions*/
+          false
+        )) ? factory.createParenthesizedExpression(firstStatement.expression) : firstStatement.expression;
+        return { func, addBraces: false, expression, returnStatement: firstStatement };
+      }
+    }
+    return void 0;
   }
-  var init_navigateTo = __esm({
-    "src/services/navigateTo.ts"() {
+  var refactorName7, refactorDescription3, addBracesAction, removeBracesAction;
+  var init_addOrRemoveBracesToArrowFunction = __esm({
+    "src/services/refactors/addOrRemoveBracesToArrowFunction.ts"() {
       "use strict";
       init_ts4();
+      init_ts_refactor();
+      refactorName7 = "Add or remove braces in an arrow function";
+      refactorDescription3 = getLocaleSpecificMessage(Diagnostics.Add_or_remove_braces_in_an_arrow_function);
+      addBracesAction = {
+        name: "Add braces to arrow function",
+        description: getLocaleSpecificMessage(Diagnostics.Add_braces_to_arrow_function),
+        kind: "refactor.rewrite.arrow.braces.add"
+      };
+      removeBracesAction = {
+        name: "Remove braces from arrow function",
+        description: getLocaleSpecificMessage(Diagnostics.Remove_braces_from_arrow_function),
+        kind: "refactor.rewrite.arrow.braces.remove"
+      };
+      registerRefactor(refactorName7, {
+        kinds: [removeBracesAction.kind],
+        getEditsForAction: getRefactorEditsToRemoveFunctionBraces,
+        getAvailableActions: getRefactorActionsToRemoveFunctionBraces
+      });
     }
   });
 
-  // src/services/_namespaces/ts.NavigateTo.ts
-  var ts_NavigateTo_exports = {};
-  __export(ts_NavigateTo_exports, {
-    getNavigateToItems: () => getNavigateToItems
-  });
-  var init_ts_NavigateTo = __esm({
-    "src/services/_namespaces/ts.NavigateTo.ts"() {
+  // src/services/_namespaces/ts.refactor.addOrRemoveBracesToArrowFunction.ts
+  var ts_refactor_addOrRemoveBracesToArrowFunction_exports = {};
+  var init_ts_refactor_addOrRemoveBracesToArrowFunction = __esm({
+    "src/services/_namespaces/ts.refactor.addOrRemoveBracesToArrowFunction.ts"() {
       "use strict";
-      init_navigateTo();
+      init_convertOverloadListToSingleSignature();
+      init_addOrRemoveBracesToArrowFunction();
     }
   });
 
-  // src/services/navigationBar.ts
-  function getNavigationBarItems(sourceFile, cancellationToken) {
-    curCancellationToken = cancellationToken;
-    curSourceFile = sourceFile;
-    try {
-      return map(primaryNavBarMenuItems(rootNavigationBarNode(sourceFile)), convertToPrimaryNavBarMenuItem);
-    } finally {
-      reset();
+  // src/services/refactors/convertArrowFunctionOrFunctionExpression.ts
+  function getRefactorActionsToConvertFunctionExpressions(context) {
+    const { file, startPosition, program, kind } = context;
+    const info = getFunctionInfo(file, startPosition, program);
+    if (!info)
+      return emptyArray;
+    const { selectedVariableDeclaration, func } = info;
+    const possibleActions = [];
+    const errors = [];
+    if (refactorKindBeginsWith(toNamedFunctionAction.kind, kind)) {
+      const error2 = selectedVariableDeclaration || isArrowFunction(func) && isVariableDeclaration(func.parent) ? void 0 : getLocaleSpecificMessage(Diagnostics.Could_not_convert_to_named_function);
+      if (error2) {
+        errors.push({ ...toNamedFunctionAction, notApplicableReason: error2 });
+      } else {
+        possibleActions.push(toNamedFunctionAction);
+      }
+    }
+    if (refactorKindBeginsWith(toAnonymousFunctionAction.kind, kind)) {
+      const error2 = !selectedVariableDeclaration && isArrowFunction(func) ? void 0 : getLocaleSpecificMessage(Diagnostics.Could_not_convert_to_anonymous_function);
+      if (error2) {
+        errors.push({ ...toAnonymousFunctionAction, notApplicableReason: error2 });
+      } else {
+        possibleActions.push(toAnonymousFunctionAction);
+      }
+    }
+    if (refactorKindBeginsWith(toArrowFunctionAction.kind, kind)) {
+      const error2 = isFunctionExpression(func) ? void 0 : getLocaleSpecificMessage(Diagnostics.Could_not_convert_to_arrow_function);
+      if (error2) {
+        errors.push({ ...toArrowFunctionAction, notApplicableReason: error2 });
+      } else {
+        possibleActions.push(toArrowFunctionAction);
+      }
     }
+    return [{
+      name: refactorName8,
+      description: refactorDescription4,
+      actions: possibleActions.length === 0 && context.preferences.provideRefactorNotApplicableReason ? errors : possibleActions
+    }];
   }
-  function getNavigationTree(sourceFile, cancellationToken) {
-    curCancellationToken = cancellationToken;
-    curSourceFile = sourceFile;
-    try {
-      return convertToTree(rootNavigationBarNode(sourceFile));
-    } finally {
-      reset();
+  function getRefactorEditsToConvertFunctionExpressions(context, actionName2) {
+    const { file, startPosition, program } = context;
+    const info = getFunctionInfo(file, startPosition, program);
+    if (!info)
+      return void 0;
+    const { func } = info;
+    const edits = [];
+    switch (actionName2) {
+      case toAnonymousFunctionAction.name:
+        edits.push(...getEditInfoForConvertToAnonymousFunction(context, func));
+        break;
+      case toNamedFunctionAction.name:
+        const variableInfo = getVariableInfo(func);
+        if (!variableInfo)
+          return void 0;
+        edits.push(...getEditInfoForConvertToNamedFunction(context, func, variableInfo));
+        break;
+      case toArrowFunctionAction.name:
+        if (!isFunctionExpression(func))
+          return void 0;
+        edits.push(...getEditInfoForConvertToArrowFunction(context, func));
+        break;
+      default:
+        return Debug.fail("invalid action");
     }
+    return { renameFilename: void 0, renameLocation: void 0, edits };
   }
-  function reset() {
-    curSourceFile = void 0;
-    curCancellationToken = void 0;
-    parentsStack = [];
-    parent = void 0;
-    emptyChildItemArray = [];
+  function containingThis(node) {
+    let containsThis = false;
+    node.forEachChild(function checkThis(child) {
+      if (isThis(child)) {
+        containsThis = true;
+        return;
+      }
+      if (!isClassLike(child) && !isFunctionDeclaration(child) && !isFunctionExpression(child)) {
+        forEachChild(child, checkThis);
+      }
+    });
+    return containsThis;
   }
-  function nodeText(node) {
-    return cleanText(node.getText(curSourceFile));
+  function getFunctionInfo(file, startPosition, program) {
+    const token = getTokenAtPosition(file, startPosition);
+    const typeChecker = program.getTypeChecker();
+    const func = tryGetFunctionFromVariableDeclaration(file, typeChecker, token.parent);
+    if (func && !containingThis(func.body) && !typeChecker.containsArgumentsReference(func)) {
+      return { selectedVariableDeclaration: true, func };
+    }
+    const maybeFunc = getContainingFunction(token);
+    if (maybeFunc && (isFunctionExpression(maybeFunc) || isArrowFunction(maybeFunc)) && !rangeContainsRange(maybeFunc.body, token) && !containingThis(maybeFunc.body) && !typeChecker.containsArgumentsReference(maybeFunc)) {
+      if (isFunctionExpression(maybeFunc) && isFunctionReferencedInFile(file, typeChecker, maybeFunc))
+        return void 0;
+      return { selectedVariableDeclaration: false, func: maybeFunc };
+    }
+    return void 0;
   }
-  function navigationBarNodeKind(n) {
-    return n.node.kind;
+  function isSingleVariableDeclaration(parent2) {
+    return isVariableDeclaration(parent2) || isVariableDeclarationList(parent2) && parent2.declarations.length === 1;
   }
-  function pushChild(parent2, child) {
-    if (parent2.children) {
-      parent2.children.push(child);
-    } else {
-      parent2.children = [child];
+  function tryGetFunctionFromVariableDeclaration(sourceFile, typeChecker, parent2) {
+    if (!isSingleVariableDeclaration(parent2)) {
+      return void 0;
+    }
+    const variableDeclaration = isVariableDeclaration(parent2) ? parent2 : first(parent2.declarations);
+    const initializer = variableDeclaration.initializer;
+    if (initializer && (isArrowFunction(initializer) || isFunctionExpression(initializer) && !isFunctionReferencedInFile(sourceFile, typeChecker, initializer))) {
+      return initializer;
     }
+    return void 0;
   }
-  function rootNavigationBarNode(sourceFile) {
-    Debug.assert(!parentsStack.length);
-    const root = { node: sourceFile, name: void 0, additionalNodes: void 0, parent: void 0, children: void 0, indent: 0 };
-    parent = root;
-    for (const statement of sourceFile.statements) {
-      addChildrenRecursively(statement);
+  function convertToBlock(body) {
+    if (isExpression(body)) {
+      const returnStatement = factory.createReturnStatement(body);
+      const file = body.getSourceFile();
+      setTextRange(returnStatement, body);
+      suppressLeadingAndTrailingTrivia(returnStatement);
+      copyTrailingAsLeadingComments(
+        body,
+        returnStatement,
+        file,
+        /*commentKind*/
+        void 0,
+        /*hasTrailingNewLine*/
+        true
+      );
+      return factory.createBlock(
+        [returnStatement],
+        /*multiLine*/
+        true
+      );
+    } else {
+      return body;
     }
-    endNode();
-    Debug.assert(!parent && !parentsStack.length);
-    return root;
   }
-  function addLeafNode(node, name) {
-    pushChild(parent, emptyNavigationBarNode(node, name));
+  function getVariableInfo(func) {
+    const variableDeclaration = func.parent;
+    if (!isVariableDeclaration(variableDeclaration) || !isVariableDeclarationInVariableStatement(variableDeclaration))
+      return void 0;
+    const variableDeclarationList = variableDeclaration.parent;
+    const statement = variableDeclarationList.parent;
+    if (!isVariableDeclarationList(variableDeclarationList) || !isVariableStatement(statement) || !isIdentifier(variableDeclaration.name))
+      return void 0;
+    return { variableDeclaration, variableDeclarationList, statement, name: variableDeclaration.name };
   }
-  function emptyNavigationBarNode(node, name) {
-    return {
-      node,
-      name: name || (isDeclaration(node) || isExpression(node) ? getNameOfDeclaration(node) : void 0),
-      additionalNodes: void 0,
-      parent,
-      children: void 0,
-      indent: parent.indent + 1
-    };
+  function getEditInfoForConvertToAnonymousFunction(context, func) {
+    const { file } = context;
+    const body = convertToBlock(func.body);
+    const newNode = factory.createFunctionExpression(
+      func.modifiers,
+      func.asteriskToken,
+      /*name*/
+      void 0,
+      func.typeParameters,
+      func.parameters,
+      func.type,
+      body
+    );
+    return ts_textChanges_exports.ChangeTracker.with(context, (t) => t.replaceNode(file, func, newNode));
   }
-  function addTrackedEs5Class(name) {
-    if (!trackedEs5Classes) {
-      trackedEs5Classes = /* @__PURE__ */ new Map();
+  function getEditInfoForConvertToNamedFunction(context, func, variableInfo) {
+    const { file } = context;
+    const body = convertToBlock(func.body);
+    const { variableDeclaration, variableDeclarationList, statement, name } = variableInfo;
+    suppressLeadingTrivia(statement);
+    const modifiersFlags = getCombinedModifierFlags(variableDeclaration) & 32 /* Export */ | getEffectiveModifierFlags(func);
+    const modifiers = factory.createModifiersFromModifierFlags(modifiersFlags);
+    const newNode = factory.createFunctionDeclaration(length(modifiers) ? modifiers : void 0, func.asteriskToken, name, func.typeParameters, func.parameters, func.type, body);
+    if (variableDeclarationList.declarations.length === 1) {
+      return ts_textChanges_exports.ChangeTracker.with(context, (t) => t.replaceNode(file, statement, newNode));
+    } else {
+      return ts_textChanges_exports.ChangeTracker.with(context, (t) => {
+        t.delete(file, variableDeclaration);
+        t.insertNodeAfter(file, statement, newNode);
+      });
     }
-    trackedEs5Classes.set(name, true);
   }
-  function endNestedNodes(depth) {
-    for (let i = 0; i < depth; i++)
-      endNode();
-  }
-  function startNestedNodes(targetNode, entityName) {
-    const names = [];
-    while (!isPropertyNameLiteral(entityName)) {
-      const name = getNameOrArgument(entityName);
-      const nameText = getElementOrPropertyAccessName(entityName);
-      entityName = entityName.expression;
-      if (nameText === "prototype" || isPrivateIdentifier(name))
-        continue;
-      names.push(name);
-    }
-    names.push(entityName);
-    for (let i = names.length - 1; i > 0; i--) {
-      const name = names[i];
-      startNode(targetNode, name);
+  function getEditInfoForConvertToArrowFunction(context, func) {
+    const { file } = context;
+    const statements = func.body.statements;
+    const head = statements[0];
+    let body;
+    if (canBeConvertedToExpression(func.body, head)) {
+      body = head.expression;
+      suppressLeadingAndTrailingTrivia(body);
+      copyComments(head, body);
+    } else {
+      body = func.body;
     }
-    return [names.length - 1, names[0]];
-  }
-  function startNode(node, name) {
-    const navNode = emptyNavigationBarNode(node, name);
-    pushChild(parent, navNode);
-    parentsStack.push(parent);
-    trackedEs5ClassesStack.push(trackedEs5Classes);
-    trackedEs5Classes = void 0;
-    parent = navNode;
+    const newNode = factory.createArrowFunction(func.modifiers, func.typeParameters, func.parameters, func.type, factory.createToken(39 /* EqualsGreaterThanToken */), body);
+    return ts_textChanges_exports.ChangeTracker.with(context, (t) => t.replaceNode(file, func, newNode));
   }
-  function endNode() {
-    if (parent.children) {
-      mergeChildren(parent.children, parent);
-      sortChildren(parent.children);
-    }
-    parent = parentsStack.pop();
-    trackedEs5Classes = trackedEs5ClassesStack.pop();
+  function canBeConvertedToExpression(body, head) {
+    return body.statements.length === 1 && (isReturnStatement(head) && !!head.expression);
   }
-  function addNodeWithRecursiveChild(node, child, name) {
-    startNode(node, name);
-    addChildrenRecursively(child);
-    endNode();
+  function isFunctionReferencedInFile(sourceFile, typeChecker, node) {
+    return !!node.name && ts_FindAllReferences_exports.Core.isSymbolReferencedInFile(node.name, typeChecker, sourceFile);
   }
-  function addNodeWithRecursiveInitializer(node) {
-    if (node.initializer && isFunctionOrClassExpression(node.initializer)) {
-      startNode(node);
-      forEachChild(node.initializer, addChildrenRecursively);
-      endNode();
-    } else {
-      addNodeWithRecursiveChild(node, node.initializer);
+  var refactorName8, refactorDescription4, toAnonymousFunctionAction, toNamedFunctionAction, toArrowFunctionAction;
+  var init_convertArrowFunctionOrFunctionExpression = __esm({
+    "src/services/refactors/convertArrowFunctionOrFunctionExpression.ts"() {
+      "use strict";
+      init_ts4();
+      init_ts_refactor();
+      refactorName8 = "Convert arrow function or function expression";
+      refactorDescription4 = getLocaleSpecificMessage(Diagnostics.Convert_arrow_function_or_function_expression);
+      toAnonymousFunctionAction = {
+        name: "Convert to anonymous function",
+        description: getLocaleSpecificMessage(Diagnostics.Convert_to_anonymous_function),
+        kind: "refactor.rewrite.function.anonymous"
+      };
+      toNamedFunctionAction = {
+        name: "Convert to named function",
+        description: getLocaleSpecificMessage(Diagnostics.Convert_to_named_function),
+        kind: "refactor.rewrite.function.named"
+      };
+      toArrowFunctionAction = {
+        name: "Convert to arrow function",
+        description: getLocaleSpecificMessage(Diagnostics.Convert_to_arrow_function),
+        kind: "refactor.rewrite.function.arrow"
+      };
+      registerRefactor(refactorName8, {
+        kinds: [
+          toAnonymousFunctionAction.kind,
+          toNamedFunctionAction.kind,
+          toArrowFunctionAction.kind
+        ],
+        getEditsForAction: getRefactorEditsToConvertFunctionExpressions,
+        getAvailableActions: getRefactorActionsToConvertFunctionExpressions
+      });
+    }
+  });
+
+  // src/services/_namespaces/ts.refactor.convertArrowFunctionOrFunctionExpression.ts
+  var ts_refactor_convertArrowFunctionOrFunctionExpression_exports = {};
+  var init_ts_refactor_convertArrowFunctionOrFunctionExpression = __esm({
+    "src/services/_namespaces/ts.refactor.convertArrowFunctionOrFunctionExpression.ts"() {
+      "use strict";
+      init_convertArrowFunctionOrFunctionExpression();
     }
+  });
+
+  // src/services/refactors/convertParamsToDestructuredObject.ts
+  function getRefactorActionsToConvertParametersToDestructuredObject(context) {
+    const { file, startPosition } = context;
+    const isJSFile = isSourceFileJS(file);
+    if (isJSFile)
+      return emptyArray;
+    const functionDeclaration = getFunctionDeclarationAtPosition(file, startPosition, context.program.getTypeChecker());
+    if (!functionDeclaration)
+      return emptyArray;
+    return [{
+      name: refactorName9,
+      description: refactorDescription5,
+      actions: [toDestructuredAction]
+    }];
   }
-  function hasNavigationBarName(node) {
-    return !hasDynamicName(node) || node.kind !== 225 /* BinaryExpression */ && isPropertyAccessExpression(node.name.expression) && isIdentifier(node.name.expression.expression) && idText(node.name.expression.expression) === "Symbol";
+  function getRefactorEditsToConvertParametersToDestructuredObject(context, actionName2) {
+    Debug.assert(actionName2 === refactorName9, "Unexpected action name");
+    const { file, startPosition, program, cancellationToken, host } = context;
+    const functionDeclaration = getFunctionDeclarationAtPosition(file, startPosition, program.getTypeChecker());
+    if (!functionDeclaration || !cancellationToken)
+      return void 0;
+    const groupedReferences = getGroupedReferences(functionDeclaration, program, cancellationToken);
+    if (groupedReferences.valid) {
+      const edits = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange5(file, program, host, t, functionDeclaration, groupedReferences));
+      return { renameFilename: void 0, renameLocation: void 0, edits };
+    }
+    return { edits: [] };
   }
-  function addChildrenRecursively(node) {
-    curCancellationToken.throwIfCancellationRequested();
-    if (!node || isToken(node)) {
-      return;
+  function doChange5(sourceFile, program, host, changes, functionDeclaration, groupedReferences) {
+    const signature = groupedReferences.signature;
+    const newFunctionDeclarationParams = map(createNewParameters(functionDeclaration, program, host), (param) => getSynthesizedDeepClone(param));
+    if (signature) {
+      const newSignatureParams = map(createNewParameters(signature, program, host), (param) => getSynthesizedDeepClone(param));
+      replaceParameters(signature, newSignatureParams);
     }
-    switch (node.kind) {
-      case 175 /* Constructor */:
-        const ctr = node;
-        addNodeWithRecursiveChild(ctr, ctr.body);
-        for (const param of ctr.parameters) {
-          if (isParameterPropertyDeclaration(param, ctr)) {
-            addLeafNode(param);
-          }
-        }
-        break;
-      case 173 /* MethodDeclaration */:
-      case 176 /* GetAccessor */:
-      case 177 /* SetAccessor */:
-      case 172 /* MethodSignature */:
-        if (hasNavigationBarName(node)) {
-          addNodeWithRecursiveChild(node, node.body);
-        }
-        break;
-      case 171 /* PropertyDeclaration */:
-        if (hasNavigationBarName(node)) {
-          addNodeWithRecursiveInitializer(node);
-        }
-        break;
-      case 170 /* PropertySignature */:
-        if (hasNavigationBarName(node)) {
-          addLeafNode(node);
-        }
-        break;
-      case 272 /* ImportClause */:
-        const importClause = node;
-        if (importClause.name) {
-          addLeafNode(importClause.name);
-        }
-        const { namedBindings } = importClause;
-        if (namedBindings) {
-          if (namedBindings.kind === 273 /* NamespaceImport */) {
-            addLeafNode(namedBindings);
-          } else {
-            for (const element of namedBindings.elements) {
-              addLeafNode(element);
-            }
-          }
-        }
-        break;
-      case 303 /* ShorthandPropertyAssignment */:
-        addNodeWithRecursiveChild(node, node.name);
-        break;
-      case 304 /* SpreadAssignment */:
-        const { expression } = node;
-        isIdentifier(expression) ? addLeafNode(node, expression) : addLeafNode(node);
-        break;
-      case 207 /* BindingElement */:
-      case 302 /* PropertyAssignment */:
-      case 259 /* VariableDeclaration */: {
-        const child = node;
-        if (isBindingPattern(child.name)) {
-          addChildrenRecursively(child.name);
-        } else {
-          addNodeWithRecursiveInitializer(child);
-        }
-        break;
+    replaceParameters(functionDeclaration, newFunctionDeclarationParams);
+    const functionCalls = sortAndDeduplicate(
+      groupedReferences.functionCalls,
+      /*comparer*/
+      (a, b) => compareValues(a.pos, b.pos)
+    );
+    for (const call of functionCalls) {
+      if (call.arguments && call.arguments.length) {
+        const newArgument = getSynthesizedDeepClone(
+          createNewArgument(functionDeclaration, call.arguments),
+          /*includeTrivia*/
+          true
+        );
+        changes.replaceNodeRange(
+          getSourceFileOfNode(call),
+          first(call.arguments),
+          last(call.arguments),
+          newArgument,
+          { leadingTriviaOption: ts_textChanges_exports.LeadingTriviaOption.IncludeAll, trailingTriviaOption: ts_textChanges_exports.TrailingTriviaOption.Include }
+        );
       }
-      case 261 /* FunctionDeclaration */:
-        const nameNode = node.name;
-        if (nameNode && isIdentifier(nameNode)) {
-          addTrackedEs5Class(nameNode.text);
+    }
+    function replaceParameters(declarationOrSignature, parameterDeclarations) {
+      changes.replaceNodeRangeWithNodes(
+        sourceFile,
+        first(declarationOrSignature.parameters),
+        last(declarationOrSignature.parameters),
+        parameterDeclarations,
+        {
+          joiner: ", ",
+          // indentation is set to 0 because otherwise the object parameter will be indented if there is a `this` parameter
+          indentation: 0,
+          leadingTriviaOption: ts_textChanges_exports.LeadingTriviaOption.IncludeAll,
+          trailingTriviaOption: ts_textChanges_exports.TrailingTriviaOption.Include
+        }
+      );
+    }
+  }
+  function getGroupedReferences(functionDeclaration, program, cancellationToken) {
+    const functionNames = getFunctionNames(functionDeclaration);
+    const classNames = isConstructorDeclaration(functionDeclaration) ? getClassNames(functionDeclaration) : [];
+    const names = deduplicate([...functionNames, ...classNames], equateValues);
+    const checker = program.getTypeChecker();
+    const references = flatMap(
+      names,
+      /*mapfn*/
+      (name) => ts_FindAllReferences_exports.getReferenceEntriesForNode(-1, name, program, program.getSourceFiles(), cancellationToken)
+    );
+    const groupedReferences = groupReferences(references);
+    if (!every(
+      groupedReferences.declarations,
+      /*callback*/
+      (decl) => contains(names, decl)
+    )) {
+      groupedReferences.valid = false;
+    }
+    return groupedReferences;
+    function groupReferences(referenceEntries) {
+      const classReferences = { accessExpressions: [], typeUsages: [] };
+      const groupedReferences2 = { functionCalls: [], declarations: [], classReferences, valid: true };
+      const functionSymbols = map(functionNames, getSymbolTargetAtLocation);
+      const classSymbols = map(classNames, getSymbolTargetAtLocation);
+      const isConstructor = isConstructorDeclaration(functionDeclaration);
+      const contextualSymbols = map(functionNames, (name) => getSymbolForContextualType(name, checker));
+      for (const entry of referenceEntries) {
+        if (entry.kind === ts_FindAllReferences_exports.EntryKind.Span) {
+          groupedReferences2.valid = false;
+          continue;
         }
-        addNodeWithRecursiveChild(node, node.body);
-        break;
-      case 218 /* ArrowFunction */:
-      case 217 /* FunctionExpression */:
-        addNodeWithRecursiveChild(node, node.body);
-        break;
-      case 265 /* EnumDeclaration */:
-        startNode(node);
-        for (const member of node.members) {
-          if (!isComputedProperty(member)) {
-            addLeafNode(member);
+        if (contains(contextualSymbols, getSymbolTargetAtLocation(entry.node))) {
+          if (isValidMethodSignature(entry.node.parent)) {
+            groupedReferences2.signature = entry.node.parent;
+            continue;
+          }
+          const call = entryToFunctionCall(entry);
+          if (call) {
+            groupedReferences2.functionCalls.push(call);
+            continue;
           }
         }
-        endNode();
-        break;
-      case 262 /* ClassDeclaration */:
-      case 230 /* ClassExpression */:
-      case 263 /* InterfaceDeclaration */:
-        startNode(node);
-        for (const member of node.members) {
-          addChildrenRecursively(member);
+        const contextualSymbol = getSymbolForContextualType(entry.node, checker);
+        if (contextualSymbol && contains(contextualSymbols, contextualSymbol)) {
+          const decl = entryToDeclaration(entry);
+          if (decl) {
+            groupedReferences2.declarations.push(decl);
+            continue;
+          }
         }
-        endNode();
-        break;
-      case 266 /* ModuleDeclaration */:
-        addNodeWithRecursiveChild(node, getInteriorModule(node).body);
-        break;
-      case 276 /* ExportAssignment */: {
-        const expression2 = node.expression;
-        const child = isObjectLiteralExpression(expression2) || isCallExpression(expression2) ? expression2 : isArrowFunction(expression2) || isFunctionExpression(expression2) ? expression2.body : void 0;
-        if (child) {
-          startNode(node);
-          addChildrenRecursively(child);
-          endNode();
-        } else {
-          addLeafNode(node);
+        if (contains(functionSymbols, getSymbolTargetAtLocation(entry.node)) || isNewExpressionTarget(entry.node)) {
+          const importOrExportReference = entryToImportOrExport(entry);
+          if (importOrExportReference) {
+            continue;
+          }
+          const decl = entryToDeclaration(entry);
+          if (decl) {
+            groupedReferences2.declarations.push(decl);
+            continue;
+          }
+          const call = entryToFunctionCall(entry);
+          if (call) {
+            groupedReferences2.functionCalls.push(call);
+            continue;
+          }
         }
-        break;
-      }
-      case 280 /* ExportSpecifier */:
-      case 270 /* ImportEqualsDeclaration */:
-      case 180 /* IndexSignature */:
-      case 178 /* CallSignature */:
-      case 179 /* ConstructSignature */:
-      case 264 /* TypeAliasDeclaration */:
-        addLeafNode(node);
-        break;
-      case 212 /* CallExpression */:
-      case 225 /* BinaryExpression */: {
-        const special = getAssignmentDeclarationKind(node);
-        switch (special) {
-          case 1 /* ExportsProperty */:
-          case 2 /* ModuleExports */:
-            addNodeWithRecursiveChild(node, node.right);
-            return;
-          case 6 /* Prototype */:
-          case 3 /* PrototypeProperty */: {
-            const binaryExpression = node;
-            const assignmentTarget = binaryExpression.left;
-            const prototypeAccess = special === 3 /* PrototypeProperty */ ? assignmentTarget.expression : assignmentTarget;
-            let depth = 0;
-            let className;
-            if (isIdentifier(prototypeAccess.expression)) {
-              addTrackedEs5Class(prototypeAccess.expression.text);
-              className = prototypeAccess.expression;
-            } else {
-              [depth, className] = startNestedNodes(binaryExpression, prototypeAccess.expression);
-            }
-            if (special === 6 /* Prototype */) {
-              if (isObjectLiteralExpression(binaryExpression.right)) {
-                if (binaryExpression.right.properties.length > 0) {
-                  startNode(binaryExpression, className);
-                  forEachChild(binaryExpression.right, addChildrenRecursively);
-                  endNode();
-                }
-              }
-            } else if (isFunctionExpression(binaryExpression.right) || isArrowFunction(binaryExpression.right)) {
-              addNodeWithRecursiveChild(
-                node,
-                binaryExpression.right,
-                className
-              );
-            } else {
-              startNode(binaryExpression, className);
-              addNodeWithRecursiveChild(node, binaryExpression.right, assignmentTarget.name);
-              endNode();
-            }
-            endNestedNodes(depth);
-            return;
+        if (isConstructor && contains(classSymbols, getSymbolTargetAtLocation(entry.node))) {
+          const importOrExportReference = entryToImportOrExport(entry);
+          if (importOrExportReference) {
+            continue;
           }
-          case 7 /* ObjectDefinePropertyValue */:
-          case 9 /* ObjectDefinePrototypeProperty */: {
-            const defineCall = node;
-            const className = special === 7 /* ObjectDefinePropertyValue */ ? defineCall.arguments[0] : defineCall.arguments[0].expression;
-            const memberName = defineCall.arguments[1];
-            const [depth, classNameIdentifier] = startNestedNodes(node, className);
-            startNode(node, classNameIdentifier);
-            startNode(node, setTextRange(factory.createIdentifier(memberName.text), memberName));
-            addChildrenRecursively(node.arguments[2]);
-            endNode();
-            endNode();
-            endNestedNodes(depth);
-            return;
+          const decl = entryToDeclaration(entry);
+          if (decl) {
+            groupedReferences2.declarations.push(decl);
+            continue;
           }
-          case 5 /* Property */: {
-            const binaryExpression = node;
-            const assignmentTarget = binaryExpression.left;
-            const targetFunction = assignmentTarget.expression;
-            if (isIdentifier(targetFunction) && getElementOrPropertyAccessName(assignmentTarget) !== "prototype" && trackedEs5Classes && trackedEs5Classes.has(targetFunction.text)) {
-              if (isFunctionExpression(binaryExpression.right) || isArrowFunction(binaryExpression.right)) {
-                addNodeWithRecursiveChild(node, binaryExpression.right, targetFunction);
-              } else if (isBindableStaticAccessExpression(assignmentTarget)) {
-                startNode(binaryExpression, targetFunction);
-                addNodeWithRecursiveChild(binaryExpression.left, binaryExpression.right, getNameOrArgument(assignmentTarget));
-                endNode();
-              }
-              return;
+          const accessExpression = entryToAccessExpression(entry);
+          if (accessExpression) {
+            classReferences.accessExpressions.push(accessExpression);
+            continue;
+          }
+          if (isClassDeclaration(functionDeclaration.parent)) {
+            const type = entryToType(entry);
+            if (type) {
+              classReferences.typeUsages.push(type);
+              continue;
             }
-            break;
           }
-          case 4 /* ThisProperty */:
-          case 0 /* None */:
-          case 8 /* ObjectDefinePropertyExports */:
-            break;
-          default:
-            Debug.assertNever(special);
         }
+        groupedReferences2.valid = false;
       }
-      default:
-        if (hasJSDocNodes(node)) {
-          forEach(node.jsDoc, (jsDoc) => {
-            forEach(jsDoc.tags, (tag) => {
-              if (isJSDocTypeAlias(tag)) {
-                addLeafNode(tag);
-              }
-            });
-          });
-        }
-        forEachChild(node, addChildrenRecursively);
+      return groupedReferences2;
+    }
+    function getSymbolTargetAtLocation(node) {
+      const symbol = checker.getSymbolAtLocation(node);
+      return symbol && getSymbolTarget(symbol, checker);
     }
   }
-  function mergeChildren(children, node) {
-    const nameToItems = /* @__PURE__ */ new Map();
-    filterMutate(children, (child, index) => {
-      const declName = child.name || getNameOfDeclaration(child.node);
-      const name = declName && nodeText(declName);
-      if (!name) {
-        return true;
-      }
-      const itemsWithSameName = nameToItems.get(name);
-      if (!itemsWithSameName) {
-        nameToItems.set(name, child);
-        return true;
-      }
-      if (itemsWithSameName instanceof Array) {
-        for (const itemWithSameName of itemsWithSameName) {
-          if (tryMerge(itemWithSameName, child, index, node)) {
-            return false;
-          }
-        }
-        itemsWithSameName.push(child);
-        return true;
-      } else {
-        const itemWithSameName = itemsWithSameName;
-        if (tryMerge(itemWithSameName, child, index, node)) {
-          return false;
-        }
-        nameToItems.set(name, [itemWithSameName, child]);
-        return true;
+  function getSymbolForContextualType(node, checker) {
+    const element = getContainingObjectLiteralElement(node);
+    if (element) {
+      const contextualType = checker.getContextualTypeForObjectLiteralElement(element);
+      const symbol = contextualType == null ? void 0 : contextualType.getSymbol();
+      if (symbol && !(getCheckFlags(symbol) & 6 /* Synthetic */)) {
+        return symbol;
       }
-    });
+    }
   }
-  function tryMergeEs5Class(a, b, bIndex, parent2) {
-    function isPossibleConstructor(node) {
-      return isFunctionExpression(node) || isFunctionDeclaration(node) || isVariableDeclaration(node);
+  function entryToImportOrExport(entry) {
+    const node = entry.node;
+    if (isImportSpecifier(node.parent) || isImportClause(node.parent) || isImportEqualsDeclaration(node.parent) || isNamespaceImport(node.parent)) {
+      return node;
     }
-    const bAssignmentDeclarationKind = isBinaryExpression(b.node) || isCallExpression(b.node) ? getAssignmentDeclarationKind(b.node) : 0 /* None */;
-    const aAssignmentDeclarationKind = isBinaryExpression(a.node) || isCallExpression(a.node) ? getAssignmentDeclarationKind(a.node) : 0 /* None */;
-    if (isEs5ClassMember[bAssignmentDeclarationKind] && isEs5ClassMember[aAssignmentDeclarationKind] || isPossibleConstructor(a.node) && isEs5ClassMember[bAssignmentDeclarationKind] || isPossibleConstructor(b.node) && isEs5ClassMember[aAssignmentDeclarationKind] || isClassDeclaration(a.node) && isSynthesized(a.node) && isEs5ClassMember[bAssignmentDeclarationKind] || isClassDeclaration(b.node) && isEs5ClassMember[aAssignmentDeclarationKind] || isClassDeclaration(a.node) && isSynthesized(a.node) && isPossibleConstructor(b.node) || isClassDeclaration(b.node) && isPossibleConstructor(a.node) && isSynthesized(a.node)) {
-      let lastANode = a.additionalNodes && lastOrUndefined(a.additionalNodes) || a.node;
-      if (!isClassDeclaration(a.node) && !isClassDeclaration(b.node) || isPossibleConstructor(a.node) || isPossibleConstructor(b.node)) {
-        const ctorFunction = isPossibleConstructor(a.node) ? a.node : isPossibleConstructor(b.node) ? b.node : void 0;
-        if (ctorFunction !== void 0) {
-          const ctorNode = setTextRange(
-            factory.createConstructorDeclaration(
-              /*modifiers*/
-              void 0,
-              [],
-              /*body*/
-              void 0
-            ),
-            ctorFunction
-          );
-          const ctor = emptyNavigationBarNode(ctorNode);
-          ctor.indent = a.indent + 1;
-          ctor.children = a.node === ctorFunction ? a.children : b.children;
-          a.children = a.node === ctorFunction ? concatenate([ctor], b.children || [b]) : concatenate(a.children || [{ ...a }], [ctor]);
-        } else {
-          if (a.children || b.children) {
-            a.children = concatenate(a.children || [{ ...a }], b.children || [b]);
-            if (a.children) {
-              mergeChildren(a.children, a);
-              sortChildren(a.children);
+    if (isExportSpecifier(node.parent) || isExportAssignment(node.parent)) {
+      return node;
+    }
+    return void 0;
+  }
+  function entryToDeclaration(entry) {
+    if (isDeclaration(entry.node.parent)) {
+      return entry.node;
+    }
+    return void 0;
+  }
+  function entryToFunctionCall(entry) {
+    if (entry.node.parent) {
+      const functionReference = entry.node;
+      const parent2 = functionReference.parent;
+      switch (parent2.kind) {
+        case 213 /* CallExpression */:
+        case 214 /* NewExpression */:
+          const callOrNewExpression = tryCast(parent2, isCallOrNewExpression);
+          if (callOrNewExpression && callOrNewExpression.expression === functionReference) {
+            return callOrNewExpression;
+          }
+          break;
+        case 211 /* PropertyAccessExpression */:
+          const propertyAccessExpression = tryCast(parent2, isPropertyAccessExpression);
+          if (propertyAccessExpression && propertyAccessExpression.parent && propertyAccessExpression.name === functionReference) {
+            const callOrNewExpression2 = tryCast(propertyAccessExpression.parent, isCallOrNewExpression);
+            if (callOrNewExpression2 && callOrNewExpression2.expression === propertyAccessExpression) {
+              return callOrNewExpression2;
             }
           }
-        }
-        lastANode = a.node = setTextRange(factory.createClassDeclaration(
-          /*modifiers*/
-          void 0,
-          a.name || factory.createIdentifier("__class__"),
-          /*typeParameters*/
-          void 0,
-          /*heritageClauses*/
-          void 0,
-          []
-        ), a.node);
-      } else {
-        a.children = concatenate(a.children, b.children);
-        if (a.children) {
-          mergeChildren(a.children, a);
-        }
+          break;
+        case 212 /* ElementAccessExpression */:
+          const elementAccessExpression = tryCast(parent2, isElementAccessExpression);
+          if (elementAccessExpression && elementAccessExpression.parent && elementAccessExpression.argumentExpression === functionReference) {
+            const callOrNewExpression2 = tryCast(elementAccessExpression.parent, isCallOrNewExpression);
+            if (callOrNewExpression2 && callOrNewExpression2.expression === elementAccessExpression) {
+              return callOrNewExpression2;
+            }
+          }
+          break;
       }
-      const bNode = b.node;
-      if (parent2.children[bIndex - 1].node.end === lastANode.end) {
-        setTextRange(lastANode, { pos: lastANode.pos, end: bNode.end });
-      } else {
-        if (!a.additionalNodes)
-          a.additionalNodes = [];
-        a.additionalNodes.push(setTextRange(factory.createClassDeclaration(
-          /*modifiers*/
-          void 0,
-          a.name || factory.createIdentifier("__class__"),
-          /*typeParameters*/
-          void 0,
-          /*heritageClauses*/
-          void 0,
-          []
-        ), b.node));
+    }
+    return void 0;
+  }
+  function entryToAccessExpression(entry) {
+    if (entry.node.parent) {
+      const reference = entry.node;
+      const parent2 = reference.parent;
+      switch (parent2.kind) {
+        case 211 /* PropertyAccessExpression */:
+          const propertyAccessExpression = tryCast(parent2, isPropertyAccessExpression);
+          if (propertyAccessExpression && propertyAccessExpression.expression === reference) {
+            return propertyAccessExpression;
+          }
+          break;
+        case 212 /* ElementAccessExpression */:
+          const elementAccessExpression = tryCast(parent2, isElementAccessExpression);
+          if (elementAccessExpression && elementAccessExpression.expression === reference) {
+            return elementAccessExpression;
+          }
+          break;
       }
-      return true;
     }
-    return bAssignmentDeclarationKind === 0 /* None */ ? false : true;
+    return void 0;
   }
-  function tryMerge(a, b, bIndex, parent2) {
-    if (tryMergeEs5Class(a, b, bIndex, parent2)) {
-      return true;
+  function entryToType(entry) {
+    const reference = entry.node;
+    if (getMeaningFromLocation(reference) === 2 /* Type */ || isExpressionWithTypeArgumentsInClassExtendsClause(reference.parent)) {
+      return reference;
     }
-    if (shouldReallyMerge(a.node, b.node, parent2)) {
-      merge(a, b);
-      return true;
+    return void 0;
+  }
+  function getFunctionDeclarationAtPosition(file, startPosition, checker) {
+    const node = getTouchingToken(file, startPosition);
+    const functionDeclaration = getContainingFunctionDeclaration(node);
+    if (isTopLevelJSDoc(node))
+      return void 0;
+    if (functionDeclaration && isValidFunctionDeclaration(functionDeclaration, checker) && rangeContainsRange(functionDeclaration, node) && !(functionDeclaration.body && rangeContainsRange(functionDeclaration.body, node)))
+      return functionDeclaration;
+    return void 0;
+  }
+  function isTopLevelJSDoc(node) {
+    const containingJSDoc = findAncestor(node, isJSDocNode);
+    if (containingJSDoc) {
+      const containingNonJSDoc = findAncestor(containingJSDoc, (n) => !isJSDocNode(n));
+      return !!containingNonJSDoc && isFunctionLikeDeclaration(containingNonJSDoc);
     }
     return false;
   }
-  function shouldReallyMerge(a, b, parent2) {
-    if (a.kind !== b.kind || a.parent !== b.parent && !(isOwnChild(a, parent2) && isOwnChild(b, parent2))) {
+  function isValidMethodSignature(node) {
+    return isMethodSignature(node) && (isInterfaceDeclaration(node.parent) || isTypeLiteralNode(node.parent));
+  }
+  function isValidFunctionDeclaration(functionDeclaration, checker) {
+    var _a;
+    if (!isValidParameterNodeArray(functionDeclaration.parameters, checker))
       return false;
+    switch (functionDeclaration.kind) {
+      case 262 /* FunctionDeclaration */:
+        return hasNameOrDefault(functionDeclaration) && isSingleImplementation(functionDeclaration, checker);
+      case 174 /* MethodDeclaration */:
+        if (isObjectLiteralExpression(functionDeclaration.parent)) {
+          const contextualSymbol = getSymbolForContextualType(functionDeclaration.name, checker);
+          return ((_a = contextualSymbol == null ? void 0 : contextualSymbol.declarations) == null ? void 0 : _a.length) === 1 && isSingleImplementation(functionDeclaration, checker);
+        }
+        return isSingleImplementation(functionDeclaration, checker);
+      case 176 /* Constructor */:
+        if (isClassDeclaration(functionDeclaration.parent)) {
+          return hasNameOrDefault(functionDeclaration.parent) && isSingleImplementation(functionDeclaration, checker);
+        } else {
+          return isValidVariableDeclaration(functionDeclaration.parent.parent) && isSingleImplementation(functionDeclaration, checker);
+        }
+      case 218 /* FunctionExpression */:
+      case 219 /* ArrowFunction */:
+        return isValidVariableDeclaration(functionDeclaration.parent);
     }
-    switch (a.kind) {
-      case 171 /* PropertyDeclaration */:
-      case 173 /* MethodDeclaration */:
-      case 176 /* GetAccessor */:
-      case 177 /* SetAccessor */:
-        return isStatic(a) === isStatic(b);
-      case 266 /* ModuleDeclaration */:
-        return areSameModule(a, b) && getFullyQualifiedModuleName(a) === getFullyQualifiedModuleName(b);
-      default:
-        return true;
-    }
-  }
-  function isSynthesized(node) {
-    return !!(node.flags & 8 /* Synthesized */);
+    return false;
   }
-  function isOwnChild(n, parent2) {
-    const par = isModuleBlock(n.parent) ? n.parent.parent : n.parent;
-    return par === parent2.node || contains(parent2.additionalNodes, par);
+  function isSingleImplementation(functionDeclaration, checker) {
+    return !!functionDeclaration.body && !checker.isImplementationOfOverload(functionDeclaration);
   }
-  function areSameModule(a, b) {
-    if (!a.body || !b.body) {
-      return a.body === b.body;
+  function hasNameOrDefault(functionOrClassDeclaration) {
+    if (!functionOrClassDeclaration.name) {
+      const defaultKeyword = findModifier(functionOrClassDeclaration, 90 /* DefaultKeyword */);
+      return !!defaultKeyword;
     }
-    return a.body.kind === b.body.kind && (a.body.kind !== 266 /* ModuleDeclaration */ || areSameModule(a.body, b.body));
+    return true;
   }
-  function merge(target, source) {
-    target.additionalNodes = target.additionalNodes || [];
-    target.additionalNodes.push(source.node);
-    if (source.additionalNodes) {
-      target.additionalNodes.push(...source.additionalNodes);
-    }
-    target.children = concatenate(target.children, source.children);
-    if (target.children) {
-      mergeChildren(target.children, target);
-      sortChildren(target.children);
+  function isValidParameterNodeArray(parameters, checker) {
+    return getRefactorableParametersLength(parameters) >= minimumParameterLength && every(
+      parameters,
+      /*callback*/
+      (paramDecl) => isValidParameterDeclaration(paramDecl, checker)
+    );
+  }
+  function isValidParameterDeclaration(parameterDeclaration, checker) {
+    if (isRestParameter(parameterDeclaration)) {
+      const type = checker.getTypeAtLocation(parameterDeclaration);
+      if (!checker.isArrayType(type) && !checker.isTupleType(type))
+        return false;
     }
+    return !parameterDeclaration.modifiers && isIdentifier(parameterDeclaration.name);
   }
-  function sortChildren(children) {
-    children.sort(compareChildren);
+  function isValidVariableDeclaration(node) {
+    return isVariableDeclaration(node) && isVarConst(node) && isIdentifier(node.name) && !node.type;
   }
-  function compareChildren(child1, child2) {
-    return compareStringsCaseSensitiveUI(tryGetName(child1.node), tryGetName(child2.node)) || compareValues(navigationBarNodeKind(child1), navigationBarNodeKind(child2));
+  function hasThisParameter(parameters) {
+    return parameters.length > 0 && isThis(parameters[0].name);
   }
-  function tryGetName(node) {
-    if (node.kind === 266 /* ModuleDeclaration */) {
-      return getModuleName(node);
-    }
-    const declName = getNameOfDeclaration(node);
-    if (declName && isPropertyName(declName)) {
-      const propertyName = getPropertyNameForPropertyNameNode(declName);
-      return propertyName && unescapeLeadingUnderscores(propertyName);
-    }
-    switch (node.kind) {
-      case 217 /* FunctionExpression */:
-      case 218 /* ArrowFunction */:
-      case 230 /* ClassExpression */:
-        return getFunctionOrClassName(node);
-      default:
-        return void 0;
+  function getRefactorableParametersLength(parameters) {
+    if (hasThisParameter(parameters)) {
+      return parameters.length - 1;
     }
+    return parameters.length;
   }
-  function getItemName(node, name) {
-    if (node.kind === 266 /* ModuleDeclaration */) {
-      return cleanText(getModuleName(node));
+  function getRefactorableParameters(parameters) {
+    if (hasThisParameter(parameters)) {
+      parameters = factory.createNodeArray(parameters.slice(1), parameters.hasTrailingComma);
     }
-    if (name) {
-      const text = isIdentifier(name) ? name.text : isElementAccessExpression(name) ? `[${nodeText(name.argumentExpression)}]` : nodeText(name);
-      if (text.length > 0) {
-        return cleanText(text);
-      }
+    return parameters;
+  }
+  function createPropertyOrShorthandAssignment(name, initializer) {
+    if (isIdentifier(initializer) && getTextOfIdentifierOrLiteral(initializer) === name) {
+      return factory.createShorthandPropertyAssignment(name);
     }
-    switch (node.kind) {
-      case 311 /* SourceFile */:
-        const sourceFile = node;
-        return isExternalModule(sourceFile) ? `"${escapeString(getBaseFileName(removeFileExtension(normalizePath(sourceFile.fileName))))}"` : "";
-      case 276 /* ExportAssignment */:
-        return isExportAssignment(node) && node.isExportEquals ? "export=" /* ExportEquals */ : "default" /* Default */;
-      case 218 /* ArrowFunction */:
-      case 261 /* FunctionDeclaration */:
-      case 217 /* FunctionExpression */:
-      case 262 /* ClassDeclaration */:
-      case 230 /* ClassExpression */:
-        if (getSyntacticModifierFlags(node) & 1024 /* Default */) {
-          return "default";
-        }
-        return getFunctionOrClassName(node);
-      case 175 /* Constructor */:
-        return "constructor";
-      case 179 /* ConstructSignature */:
-        return "new()";
-      case 178 /* CallSignature */:
-        return "()";
-      case 180 /* IndexSignature */:
-        return "[]";
-      default:
-        return "";
+    return factory.createPropertyAssignment(name, initializer);
+  }
+  function createNewArgument(functionDeclaration, functionArguments) {
+    const parameters = getRefactorableParameters(functionDeclaration.parameters);
+    const hasRestParameter2 = isRestParameter(last(parameters));
+    const nonRestArguments = hasRestParameter2 ? functionArguments.slice(0, parameters.length - 1) : functionArguments;
+    const properties = map(nonRestArguments, (arg, i) => {
+      const parameterName = getParameterName(parameters[i]);
+      const property = createPropertyOrShorthandAssignment(parameterName, arg);
+      suppressLeadingAndTrailingTrivia(property.name);
+      if (isPropertyAssignment(property))
+        suppressLeadingAndTrailingTrivia(property.initializer);
+      copyComments(arg, property);
+      return property;
+    });
+    if (hasRestParameter2 && functionArguments.length >= parameters.length) {
+      const restArguments = functionArguments.slice(parameters.length - 1);
+      const restProperty = factory.createPropertyAssignment(getParameterName(last(parameters)), factory.createArrayLiteralExpression(restArguments));
+      properties.push(restProperty);
     }
+    const objectLiteral = factory.createObjectLiteralExpression(
+      properties,
+      /*multiLine*/
+      false
+    );
+    return objectLiteral;
   }
-  function primaryNavBarMenuItems(root) {
-    const primaryNavBarMenuItems2 = [];
-    function recur(item) {
-      if (shouldAppearInPrimaryNavBarMenu(item)) {
-        primaryNavBarMenuItems2.push(item);
-        if (item.children) {
-          for (const child of item.children) {
-            recur(child);
-          }
-        }
-      }
+  function createNewParameters(functionDeclaration, program, host) {
+    const checker = program.getTypeChecker();
+    const refactorableParameters = getRefactorableParameters(functionDeclaration.parameters);
+    const bindingElements = map(refactorableParameters, createBindingElementFromParameterDeclaration);
+    const objectParameterName = factory.createObjectBindingPattern(bindingElements);
+    const objectParameterType = createParameterTypeNode(refactorableParameters);
+    let objectInitializer;
+    if (every(refactorableParameters, isOptionalParameter)) {
+      objectInitializer = factory.createObjectLiteralExpression();
     }
-    recur(root);
-    return primaryNavBarMenuItems2;
-    function shouldAppearInPrimaryNavBarMenu(item) {
-      if (item.children) {
-        return true;
-      }
-      switch (navigationBarNodeKind(item)) {
-        case 262 /* ClassDeclaration */:
-        case 230 /* ClassExpression */:
-        case 265 /* EnumDeclaration */:
-        case 263 /* InterfaceDeclaration */:
-        case 266 /* ModuleDeclaration */:
-        case 311 /* SourceFile */:
-        case 264 /* TypeAliasDeclaration */:
-        case 352 /* JSDocTypedefTag */:
-        case 344 /* JSDocCallbackTag */:
-          return true;
-        case 218 /* ArrowFunction */:
-        case 261 /* FunctionDeclaration */:
-        case 217 /* FunctionExpression */:
-          return isTopLevelFunctionDeclaration(item);
-        default:
-          return false;
+    const objectParameter = factory.createParameterDeclaration(
+      /*modifiers*/
+      void 0,
+      /*dotDotDotToken*/
+      void 0,
+      objectParameterName,
+      /*questionToken*/
+      void 0,
+      objectParameterType,
+      objectInitializer
+    );
+    if (hasThisParameter(functionDeclaration.parameters)) {
+      const thisParameter = functionDeclaration.parameters[0];
+      const newThisParameter = factory.createParameterDeclaration(
+        /*modifiers*/
+        void 0,
+        /*dotDotDotToken*/
+        void 0,
+        thisParameter.name,
+        /*questionToken*/
+        void 0,
+        thisParameter.type
+      );
+      suppressLeadingAndTrailingTrivia(newThisParameter.name);
+      copyComments(thisParameter.name, newThisParameter.name);
+      if (thisParameter.type) {
+        suppressLeadingAndTrailingTrivia(newThisParameter.type);
+        copyComments(thisParameter.type, newThisParameter.type);
       }
-      function isTopLevelFunctionDeclaration(item2) {
-        if (!item2.node.body) {
-          return false;
-        }
-        switch (navigationBarNodeKind(item2.parent)) {
-          case 267 /* ModuleBlock */:
-          case 311 /* SourceFile */:
-          case 173 /* MethodDeclaration */:
-          case 175 /* Constructor */:
-            return true;
-          default:
-            return false;
-        }
+      return factory.createNodeArray([newThisParameter, objectParameter]);
+    }
+    return factory.createNodeArray([objectParameter]);
+    function createBindingElementFromParameterDeclaration(parameterDeclaration) {
+      const element = factory.createBindingElement(
+        /*dotDotDotToken*/
+        void 0,
+        /*propertyName*/
+        void 0,
+        getParameterName(parameterDeclaration),
+        isRestParameter(parameterDeclaration) && isOptionalParameter(parameterDeclaration) ? factory.createArrayLiteralExpression() : parameterDeclaration.initializer
+      );
+      suppressLeadingAndTrailingTrivia(element);
+      if (parameterDeclaration.initializer && element.initializer) {
+        copyComments(parameterDeclaration.initializer, element.initializer);
       }
+      return element;
     }
-  }
-  function convertToTree(n) {
-    return {
-      text: getItemName(n.node, n.name),
-      kind: getNodeKind(n.node),
-      kindModifiers: getModifiers2(n.node),
-      spans: getSpans(n),
-      nameSpan: n.name && getNodeSpan(n.name),
-      childItems: map(n.children, convertToTree)
-    };
-  }
-  function convertToPrimaryNavBarMenuItem(n) {
-    return {
-      text: getItemName(n.node, n.name),
-      kind: getNodeKind(n.node),
-      kindModifiers: getModifiers2(n.node),
-      spans: getSpans(n),
-      childItems: map(n.children, convertToSecondaryNavBarMenuItem) || emptyChildItemArray,
-      indent: n.indent,
-      bolded: false,
-      grayed: false
-    };
-    function convertToSecondaryNavBarMenuItem(n2) {
-      return {
-        text: getItemName(n2.node, n2.name),
-        kind: getNodeKind(n2.node),
-        kindModifiers: getNodeModifiers(n2.node),
-        spans: getSpans(n2),
-        childItems: emptyChildItemArray,
-        indent: 0,
-        bolded: false,
-        grayed: false
-      };
+    function createParameterTypeNode(parameters) {
+      const members = map(parameters, createPropertySignatureFromParameterDeclaration);
+      const typeNode = addEmitFlags(factory.createTypeLiteralNode(members), 1 /* SingleLine */);
+      return typeNode;
     }
-  }
-  function getSpans(n) {
-    const spans = [getNodeSpan(n.node)];
-    if (n.additionalNodes) {
-      for (const node of n.additionalNodes) {
-        spans.push(getNodeSpan(node));
+    function createPropertySignatureFromParameterDeclaration(parameterDeclaration) {
+      let parameterType = parameterDeclaration.type;
+      if (!parameterType && (parameterDeclaration.initializer || isRestParameter(parameterDeclaration))) {
+        parameterType = getTypeNode3(parameterDeclaration);
+      }
+      const propertySignature = factory.createPropertySignature(
+        /*modifiers*/
+        void 0,
+        getParameterName(parameterDeclaration),
+        isOptionalParameter(parameterDeclaration) ? factory.createToken(58 /* QuestionToken */) : parameterDeclaration.questionToken,
+        parameterType
+      );
+      suppressLeadingAndTrailingTrivia(propertySignature);
+      copyComments(parameterDeclaration.name, propertySignature.name);
+      if (parameterDeclaration.type && propertySignature.type) {
+        copyComments(parameterDeclaration.type, propertySignature.type);
       }
+      return propertySignature;
     }
-    return spans;
-  }
-  function getModuleName(moduleDeclaration) {
-    if (isAmbientModule(moduleDeclaration)) {
-      return getTextOfNode(moduleDeclaration.name);
+    function getTypeNode3(node) {
+      const type = checker.getTypeAtLocation(node);
+      return getTypeNodeIfAccessible(type, node, program, host);
     }
-    return getFullyQualifiedModuleName(moduleDeclaration);
-  }
-  function getFullyQualifiedModuleName(moduleDeclaration) {
-    const result = [getTextOfIdentifierOrLiteral(moduleDeclaration.name)];
-    while (moduleDeclaration.body && moduleDeclaration.body.kind === 266 /* ModuleDeclaration */) {
-      moduleDeclaration = moduleDeclaration.body;
-      result.push(getTextOfIdentifierOrLiteral(moduleDeclaration.name));
+    function isOptionalParameter(parameterDeclaration) {
+      if (isRestParameter(parameterDeclaration)) {
+        const type = checker.getTypeAtLocation(parameterDeclaration);
+        return !checker.isTupleType(type);
+      }
+      return checker.isOptionalParameter(parameterDeclaration);
     }
-    return result.join(".");
-  }
-  function getInteriorModule(decl) {
-    return decl.body && isModuleDeclaration(decl.body) ? getInteriorModule(decl.body) : decl;
-  }
-  function isComputedProperty(member) {
-    return !member.name || member.name.kind === 166 /* ComputedPropertyName */;
   }
-  function getNodeSpan(node) {
-    return node.kind === 311 /* SourceFile */ ? createTextSpanFromRange(node) : createTextSpanFromNode(node, curSourceFile);
+  function getParameterName(paramDeclaration) {
+    return getTextOfIdentifierOrLiteral(paramDeclaration.name);
   }
-  function getModifiers2(node) {
-    if (node.parent && node.parent.kind === 259 /* VariableDeclaration */) {
-      node = node.parent;
+  function getClassNames(constructorDeclaration) {
+    switch (constructorDeclaration.parent.kind) {
+      case 263 /* ClassDeclaration */:
+        const classDeclaration = constructorDeclaration.parent;
+        if (classDeclaration.name)
+          return [classDeclaration.name];
+        const defaultModifier = Debug.checkDefined(
+          findModifier(classDeclaration, 90 /* DefaultKeyword */),
+          "Nameless class declaration should be a default export"
+        );
+        return [defaultModifier];
+      case 231 /* ClassExpression */:
+        const classExpression = constructorDeclaration.parent;
+        const variableDeclaration = constructorDeclaration.parent.parent;
+        const className = classExpression.name;
+        if (className)
+          return [className, variableDeclaration.name];
+        return [variableDeclaration.name];
     }
-    return getNodeModifiers(node);
   }
-  function getFunctionOrClassName(node) {
-    const { parent: parent2 } = node;
-    if (node.name && getFullWidth(node.name) > 0) {
-      return cleanText(declarationNameToString(node.name));
-    } else if (isVariableDeclaration(parent2)) {
-      return cleanText(declarationNameToString(parent2.name));
-    } else if (isBinaryExpression(parent2) && parent2.operatorToken.kind === 64 /* EqualsToken */) {
-      return nodeText(parent2.left).replace(whiteSpaceRegex, "");
-    } else if (isPropertyAssignment(parent2)) {
-      return nodeText(parent2.name);
-    } else if (getSyntacticModifierFlags(node) & 1024 /* Default */) {
-      return "default";
-    } else if (isClassLike(node)) {
-      return "";
-    } else if (isCallExpression(parent2)) {
-      let name = getCalledExpressionName(parent2.expression);
-      if (name !== void 0) {
-        name = cleanText(name);
-        if (name.length > maxLength) {
-          return `${name} callback`;
+  function getFunctionNames(functionDeclaration) {
+    switch (functionDeclaration.kind) {
+      case 262 /* FunctionDeclaration */:
+        if (functionDeclaration.name)
+          return [functionDeclaration.name];
+        const defaultModifier = Debug.checkDefined(
+          findModifier(functionDeclaration, 90 /* DefaultKeyword */),
+          "Nameless function declaration should be a default export"
+        );
+        return [defaultModifier];
+      case 174 /* MethodDeclaration */:
+        return [functionDeclaration.name];
+      case 176 /* Constructor */:
+        const ctrKeyword = Debug.checkDefined(
+          findChildOfKind(functionDeclaration, 137 /* ConstructorKeyword */, functionDeclaration.getSourceFile()),
+          "Constructor declaration should have constructor keyword"
+        );
+        if (functionDeclaration.parent.kind === 231 /* ClassExpression */) {
+          const variableDeclaration = functionDeclaration.parent.parent;
+          return [variableDeclaration.name, ctrKeyword];
         }
-        const args = cleanText(mapDefined(parent2.arguments, (a) => isStringLiteralLike(a) ? a.getText(curSourceFile) : void 0).join(", "));
-        return `${name}(${args}) callback`;
-      }
-    }
-    return "";
-  }
-  function getCalledExpressionName(expr) {
-    if (isIdentifier(expr)) {
-      return expr.text;
-    } else if (isPropertyAccessExpression(expr)) {
-      const left = getCalledExpressionName(expr.expression);
-      const right = expr.name.text;
-      return left === void 0 ? right : `${left}.${right}`;
-    } else {
-      return void 0;
-    }
-  }
-  function isFunctionOrClassExpression(node) {
-    switch (node.kind) {
-      case 218 /* ArrowFunction */:
-      case 217 /* FunctionExpression */:
-      case 230 /* ClassExpression */:
-        return true;
+        return [ctrKeyword];
+      case 219 /* ArrowFunction */:
+        return [functionDeclaration.parent.name];
+      case 218 /* FunctionExpression */:
+        if (functionDeclaration.name)
+          return [functionDeclaration.name, functionDeclaration.parent.name];
+        return [functionDeclaration.parent.name];
       default:
-        return false;
+        return Debug.assertNever(functionDeclaration, `Unexpected function declaration kind ${functionDeclaration.kind}`);
     }
   }
-  function cleanText(text) {
-    text = text.length > maxLength ? text.substring(0, maxLength) + "..." : text;
-    return text.replace(/\\?(\r?\n|\r|\u2028|\u2029)/g, "");
-  }
-  var whiteSpaceRegex, maxLength, curCancellationToken, curSourceFile, parentsStack, parent, trackedEs5ClassesStack, trackedEs5Classes, emptyChildItemArray, isEs5ClassMember;
-  var init_navigationBar = __esm({
-    "src/services/navigationBar.ts"() {
+  var refactorName9, minimumParameterLength, refactorDescription5, toDestructuredAction;
+  var init_convertParamsToDestructuredObject = __esm({
+    "src/services/refactors/convertParamsToDestructuredObject.ts"() {
       "use strict";
       init_ts4();
-      whiteSpaceRegex = /\s+/g;
-      maxLength = 150;
-      parentsStack = [];
-      trackedEs5ClassesStack = [];
-      emptyChildItemArray = [];
-      isEs5ClassMember = {
-        [5 /* Property */]: true,
-        [3 /* PrototypeProperty */]: true,
-        [7 /* ObjectDefinePropertyValue */]: true,
-        [9 /* ObjectDefinePrototypeProperty */]: true,
-        [0 /* None */]: false,
-        [1 /* ExportsProperty */]: false,
-        [2 /* ModuleExports */]: false,
-        [8 /* ObjectDefinePropertyExports */]: false,
-        [6 /* Prototype */]: true,
-        [4 /* ThisProperty */]: false
+      init_ts_refactor();
+      refactorName9 = "Convert parameters to destructured object";
+      minimumParameterLength = 1;
+      refactorDescription5 = getLocaleSpecificMessage(Diagnostics.Convert_parameters_to_destructured_object);
+      toDestructuredAction = {
+        name: refactorName9,
+        description: refactorDescription5,
+        kind: "refactor.rewrite.parameters.toDestructured"
       };
+      registerRefactor(refactorName9, {
+        kinds: [toDestructuredAction.kind],
+        getEditsForAction: getRefactorEditsToConvertParametersToDestructuredObject,
+        getAvailableActions: getRefactorActionsToConvertParametersToDestructuredObject
+      });
     }
   });
 
-  // src/services/_namespaces/ts.NavigationBar.ts
-  var ts_NavigationBar_exports = {};
-  __export(ts_NavigationBar_exports, {
-    getNavigationBarItems: () => getNavigationBarItems,
-    getNavigationTree: () => getNavigationTree
-  });
-  var init_ts_NavigationBar = __esm({
-    "src/services/_namespaces/ts.NavigationBar.ts"() {
+  // src/services/_namespaces/ts.refactor.convertParamsToDestructuredObject.ts
+  var ts_refactor_convertParamsToDestructuredObject_exports = {};
+  var init_ts_refactor_convertParamsToDestructuredObject = __esm({
+    "src/services/_namespaces/ts.refactor.convertParamsToDestructuredObject.ts"() {
       "use strict";
-      init_navigationBar();
+      init_convertParamsToDestructuredObject();
     }
   });
 
-  // src/services/refactorProvider.ts
-  function registerRefactor(name, refactor) {
-    refactors.set(name, refactor);
-  }
-  function getApplicableRefactors(context, includeInteractiveActions) {
-    return arrayFrom(flatMapIterator(refactors.values(), (refactor) => {
-      var _a;
-      return context.cancellationToken && context.cancellationToken.isCancellationRequested() || !((_a = refactor.kinds) == null ? void 0 : _a.some((kind) => refactorKindBeginsWith(kind, context.kind))) ? void 0 : refactor.getAvailableActions(context, includeInteractiveActions);
-    }));
-  }
-  function getEditsForRefactor(context, refactorName13, actionName2, interactiveRefactorArguments) {
-    const refactor = refactors.get(refactorName13);
-    return refactor && refactor.getEditsForAction(context, actionName2, interactiveRefactorArguments);
-  }
-  var refactors;
-  var init_refactorProvider = __esm({
-    "src/services/refactorProvider.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_refactor();
-      refactors = /* @__PURE__ */ new Map();
+  // src/services/refactors/convertStringOrTemplateLiteral.ts
+  function getRefactorActionsToConvertToTemplateString(context) {
+    const { file, startPosition } = context;
+    const node = getNodeOrParentOfParentheses(file, startPosition);
+    const maybeBinary = getParentBinaryExpression(node);
+    const nodeIsStringLiteral = isStringLiteral(maybeBinary);
+    const refactorInfo = { name: refactorName10, description: refactorDescription6, actions: [] };
+    if (nodeIsStringLiteral && context.triggerReason !== "invoked") {
+      return emptyArray;
     }
-  });
-
-  // src/services/refactors/convertExport.ts
-  function getInfo2(context, considerPartialSpans = true) {
-    const { file, program } = context;
-    const span = getRefactorContextSpan(context);
-    const token = getTokenAtPosition(file, span.start);
-    const exportNode = !!(token.parent && getSyntacticModifierFlags(token.parent) & 1 /* Export */) && considerPartialSpans ? token.parent : getParentNodeInSpan(token, file, span);
-    if (!exportNode || !isSourceFile(exportNode.parent) && !(isModuleBlock(exportNode.parent) && isAmbientModule(exportNode.parent.parent))) {
-      return { error: getLocaleSpecificMessage(Diagnostics.Could_not_find_export_statement) };
+    if (isExpressionNode(maybeBinary) && (nodeIsStringLiteral || isBinaryExpression(maybeBinary) && treeToArray(maybeBinary).isValidConcatenation)) {
+      refactorInfo.actions.push(convertStringAction);
+      return [refactorInfo];
+    } else if (context.preferences.provideRefactorNotApplicableReason) {
+      refactorInfo.actions.push({ ...convertStringAction, notApplicableReason: getLocaleSpecificMessage(Diagnostics.Can_only_convert_string_concatenations_and_string_literals) });
+      return [refactorInfo];
     }
-    const checker = program.getTypeChecker();
-    const exportingModuleSymbol = getExportingModuleSymbol(exportNode.parent, checker);
-    const flags = getSyntacticModifierFlags(exportNode) || (isExportAssignment(exportNode) && !exportNode.isExportEquals ? 1025 /* ExportDefault */ : 0 /* None */);
-    const wasDefault = !!(flags & 1024 /* Default */);
-    if (!(flags & 1 /* Export */) || !wasDefault && exportingModuleSymbol.exports.has("default" /* Default */)) {
-      return { error: getLocaleSpecificMessage(Diagnostics.This_file_already_has_a_default_export) };
+    return emptyArray;
+  }
+  function getNodeOrParentOfParentheses(file, startPosition) {
+    const node = getTokenAtPosition(file, startPosition);
+    const nestedBinary = getParentBinaryExpression(node);
+    const isNonStringBinary = !treeToArray(nestedBinary).isValidConcatenation;
+    if (isNonStringBinary && isParenthesizedExpression(nestedBinary.parent) && isBinaryExpression(nestedBinary.parent.parent)) {
+      return nestedBinary.parent.parent;
     }
-    const noSymbolError = (id) => isIdentifier(id) && checker.getSymbolAtLocation(id) ? void 0 : { error: getLocaleSpecificMessage(Diagnostics.Can_only_convert_named_export) };
-    switch (exportNode.kind) {
-      case 261 /* FunctionDeclaration */:
-      case 262 /* ClassDeclaration */:
-      case 263 /* InterfaceDeclaration */:
-      case 265 /* EnumDeclaration */:
-      case 264 /* TypeAliasDeclaration */:
-      case 266 /* ModuleDeclaration */: {
-        const node = exportNode;
-        if (!node.name)
-          return void 0;
-        return noSymbolError(node.name) || { exportNode: node, exportName: node.name, wasDefault, exportingModuleSymbol };
-      }
-      case 242 /* VariableStatement */: {
-        const vs = exportNode;
-        if (!(vs.declarationList.flags & 2 /* Const */) || vs.declarationList.declarations.length !== 1) {
-          return void 0;
-        }
-        const decl = first(vs.declarationList.declarations);
-        if (!decl.initializer)
-          return void 0;
-        Debug.assert(!wasDefault, "Can't have a default flag here");
-        return noSymbolError(decl.name) || { exportNode: vs, exportName: decl.name, wasDefault, exportingModuleSymbol };
-      }
-      case 276 /* ExportAssignment */: {
-        const node = exportNode;
-        if (node.isExportEquals)
-          return void 0;
-        return noSymbolError(node.expression) || { exportNode: node, exportName: node.expression, wasDefault, exportingModuleSymbol };
-      }
+    return node;
+  }
+  function getRefactorEditsToConvertToTemplateString(context, actionName2) {
+    const { file, startPosition } = context;
+    const node = getNodeOrParentOfParentheses(file, startPosition);
+    switch (actionName2) {
+      case refactorDescription6:
+        return { edits: getEditsForToTemplateLiteral(context, node) };
       default:
-        return void 0;
+        return Debug.fail("invalid action");
     }
   }
-  function doChange(exportingSourceFile, program, info, changes, cancellationToken) {
-    changeExport(exportingSourceFile, info, changes, program.getTypeChecker());
-    changeImports(program, info, changes, cancellationToken);
-  }
-  function changeExport(exportingSourceFile, { wasDefault, exportNode, exportName }, changes, checker) {
-    if (wasDefault) {
-      if (isExportAssignment(exportNode) && !exportNode.isExportEquals) {
-        const exp = exportNode.expression;
-        const spec = makeExportSpecifier(exp.text, exp.text);
-        changes.replaceNode(exportingSourceFile, exportNode, factory.createExportDeclaration(
-          /*modifiers*/
-          void 0,
-          /*isTypeOnly*/
-          false,
-          factory.createNamedExports([spec])
-        ));
-      } else {
-        changes.delete(exportingSourceFile, Debug.checkDefined(findModifier(exportNode, 90 /* DefaultKeyword */), "Should find a default keyword in modifier list"));
-      }
+  function getEditsForToTemplateLiteral(context, node) {
+    const maybeBinary = getParentBinaryExpression(node);
+    const file = context.file;
+    const templateLiteral = nodesToTemplate(treeToArray(maybeBinary), file);
+    const trailingCommentRanges = getTrailingCommentRanges(file.text, maybeBinary.end);
+    if (trailingCommentRanges) {
+      const lastComment = trailingCommentRanges[trailingCommentRanges.length - 1];
+      const trailingRange = { pos: trailingCommentRanges[0].pos, end: lastComment.end };
+      return ts_textChanges_exports.ChangeTracker.with(context, (t) => {
+        t.deleteRange(file, trailingRange);
+        t.replaceNode(file, maybeBinary, templateLiteral);
+      });
     } else {
-      const exportKeyword = Debug.checkDefined(findModifier(exportNode, 95 /* ExportKeyword */), "Should find an export keyword in modifier list");
-      switch (exportNode.kind) {
-        case 261 /* FunctionDeclaration */:
-        case 262 /* ClassDeclaration */:
-        case 263 /* InterfaceDeclaration */:
-          changes.insertNodeAfter(exportingSourceFile, exportKeyword, factory.createToken(90 /* DefaultKeyword */));
-          break;
-        case 242 /* VariableStatement */:
-          const decl = first(exportNode.declarationList.declarations);
-          if (!ts_FindAllReferences_exports.Core.isSymbolReferencedInFile(exportName, checker, exportingSourceFile) && !decl.type) {
-            changes.replaceNode(exportingSourceFile, exportNode, factory.createExportDefault(Debug.checkDefined(decl.initializer, "Initializer was previously known to be present")));
-            break;
-          }
-        case 265 /* EnumDeclaration */:
-        case 264 /* TypeAliasDeclaration */:
-        case 266 /* ModuleDeclaration */:
-          changes.deleteModifier(exportingSourceFile, exportKeyword);
-          changes.insertNodeAfter(exportingSourceFile, exportNode, factory.createExportDefault(factory.createIdentifier(exportName.text)));
-          break;
-        default:
-          Debug.fail(`Unexpected exportNode kind ${exportNode.kind}`);
-      }
+      return ts_textChanges_exports.ChangeTracker.with(context, (t) => t.replaceNode(file, maybeBinary, templateLiteral));
     }
   }
-  function changeImports(program, { wasDefault, exportName, exportingModuleSymbol }, changes, cancellationToken) {
-    const checker = program.getTypeChecker();
-    const exportSymbol = Debug.checkDefined(checker.getSymbolAtLocation(exportName), "Export name should resolve to a symbol");
-    ts_FindAllReferences_exports.Core.eachExportReference(program.getSourceFiles(), checker, cancellationToken, exportSymbol, exportingModuleSymbol, exportName.text, wasDefault, (ref) => {
-      if (exportName === ref)
-        return;
-      const importingSourceFile = ref.getSourceFile();
-      if (wasDefault) {
-        changeDefaultToNamedImport(importingSourceFile, ref, changes, exportName.text);
-      } else {
-        changeNamedToDefaultImport(importingSourceFile, ref, changes);
+  function isNotEqualsOperator(node) {
+    return !(node.operatorToken.kind === 64 /* EqualsToken */ || node.operatorToken.kind === 65 /* PlusEqualsToken */);
+  }
+  function getParentBinaryExpression(expr) {
+    const container = findAncestor(expr.parent, (n) => {
+      switch (n.kind) {
+        case 211 /* PropertyAccessExpression */:
+        case 212 /* ElementAccessExpression */:
+          return false;
+        case 228 /* TemplateExpression */:
+        case 226 /* BinaryExpression */:
+          return !(isBinaryExpression(n.parent) && isNotEqualsOperator(n.parent));
+        default:
+          return "quit";
       }
     });
+    return container || expr;
   }
-  function changeDefaultToNamedImport(importingSourceFile, ref, changes, exportName) {
-    const { parent: parent2 } = ref;
-    switch (parent2.kind) {
-      case 210 /* PropertyAccessExpression */:
-        changes.replaceNode(importingSourceFile, ref, factory.createIdentifier(exportName));
-        break;
-      case 275 /* ImportSpecifier */:
-      case 280 /* ExportSpecifier */: {
-        const spec = parent2;
-        changes.replaceNode(importingSourceFile, spec, makeImportSpecifier(exportName, spec.name.text));
-        break;
+  function treeToArray(current) {
+    const loop = (current2) => {
+      if (!isBinaryExpression(current2)) {
+        return { nodes: [current2], operators: [], validOperators: true, hasString: isStringLiteral(current2) || isNoSubstitutionTemplateLiteral(current2) };
       }
-      case 272 /* ImportClause */: {
-        const clause = parent2;
-        Debug.assert(clause.name === ref, "Import clause name should match provided ref");
-        const spec = makeImportSpecifier(exportName, ref.text);
-        const { namedBindings } = clause;
-        if (!namedBindings) {
-          changes.replaceNode(importingSourceFile, ref, factory.createNamedImports([spec]));
-        } else if (namedBindings.kind === 273 /* NamespaceImport */) {
-          changes.deleteRange(importingSourceFile, { pos: ref.getStart(importingSourceFile), end: namedBindings.getStart(importingSourceFile) });
-          const quotePreference = isStringLiteral(clause.parent.moduleSpecifier) ? quotePreferenceFromString(clause.parent.moduleSpecifier, importingSourceFile) : 1 /* Double */;
-          const newImport = makeImport(
-            /*defaultImport*/
-            void 0,
-            [makeImportSpecifier(exportName, ref.text)],
-            clause.parent.moduleSpecifier,
-            quotePreference
-          );
-          changes.insertNodeAfter(importingSourceFile, clause.parent, newImport);
-        } else {
-          changes.delete(importingSourceFile, ref);
-          changes.insertNodeAtEndOfList(importingSourceFile, namedBindings.elements, spec);
-        }
-        break;
+      const { nodes: nodes2, operators: operators2, hasString: leftHasString, validOperators: leftOperatorValid } = loop(current2.left);
+      if (!(leftHasString || isStringLiteral(current2.right) || isTemplateExpression(current2.right))) {
+        return { nodes: [current2], operators: [], hasString: false, validOperators: true };
       }
-      case 204 /* ImportType */:
-        const importTypeNode = parent2;
-        changes.replaceNode(importingSourceFile, parent2, factory.createImportTypeNode(importTypeNode.argument, importTypeNode.assertions, factory.createIdentifier(exportName), importTypeNode.typeArguments, importTypeNode.isTypeOf));
-        break;
-      default:
-        Debug.failBadSyntaxKind(parent2);
-    }
+      const currentOperatorValid = current2.operatorToken.kind === 40 /* PlusToken */;
+      const validOperators2 = leftOperatorValid && currentOperatorValid;
+      nodes2.push(current2.right);
+      operators2.push(current2.operatorToken);
+      return { nodes: nodes2, operators: operators2, hasString: true, validOperators: validOperators2 };
+    };
+    const { nodes, operators, validOperators, hasString } = loop(current);
+    return { nodes, operators, isValidConcatenation: validOperators && hasString };
   }
-  function changeNamedToDefaultImport(importingSourceFile, ref, changes) {
-    const parent2 = ref.parent;
-    switch (parent2.kind) {
-      case 210 /* PropertyAccessExpression */:
-        changes.replaceNode(importingSourceFile, ref, factory.createIdentifier("default"));
+  function escapeRawStringForTemplate(s) {
+    return s.replace(/\\.|[$`]/g, (m) => m[0] === "\\" ? m : "\\" + m);
+  }
+  function getRawTextOfTemplate(node) {
+    const rightShaving = isTemplateHead(node) || isTemplateMiddle(node) ? -2 : -1;
+    return getTextOfNode(node).slice(1, rightShaving);
+  }
+  function concatConsecutiveString(index, nodes) {
+    const indexes = [];
+    let text = "", rawText = "";
+    while (index < nodes.length) {
+      const node = nodes[index];
+      if (isStringLiteralLike(node)) {
+        text += node.text;
+        rawText += escapeRawStringForTemplate(getTextOfNode(node).slice(1, -1));
+        indexes.push(index);
+        index++;
+      } else if (isTemplateExpression(node)) {
+        text += node.head.text;
+        rawText += getRawTextOfTemplate(node.head);
         break;
-      case 275 /* ImportSpecifier */: {
-        const defaultImport = factory.createIdentifier(parent2.name.text);
-        if (parent2.parent.elements.length === 1) {
-          changes.replaceNode(importingSourceFile, parent2.parent, defaultImport);
-        } else {
-          changes.delete(importingSourceFile, parent2);
-          changes.insertNodeBefore(importingSourceFile, parent2.parent, defaultImport);
-        }
+      } else {
         break;
       }
-      case 280 /* ExportSpecifier */: {
-        changes.replaceNode(importingSourceFile, parent2, makeExportSpecifier("default", parent2.name.text));
-        break;
+    }
+    return [index, text, rawText, indexes];
+  }
+  function nodesToTemplate({ nodes, operators }, file) {
+    const copyOperatorComments = copyTrailingOperatorComments(operators, file);
+    const copyCommentFromStringLiterals = copyCommentFromMultiNode(nodes, file, copyOperatorComments);
+    const [begin, headText, rawHeadText, headIndexes] = concatConsecutiveString(0, nodes);
+    if (begin === nodes.length) {
+      const noSubstitutionTemplateLiteral = factory.createNoSubstitutionTemplateLiteral(headText, rawHeadText);
+      copyCommentFromStringLiterals(headIndexes, noSubstitutionTemplateLiteral);
+      return noSubstitutionTemplateLiteral;
+    }
+    const templateSpans = [];
+    const templateHead = factory.createTemplateHead(headText, rawHeadText);
+    copyCommentFromStringLiterals(headIndexes, templateHead);
+    for (let i = begin; i < nodes.length; i++) {
+      const currentNode = getExpressionFromParenthesesOrExpression(nodes[i]);
+      copyOperatorComments(i, currentNode);
+      const [newIndex, subsequentText, rawSubsequentText, stringIndexes] = concatConsecutiveString(i + 1, nodes);
+      i = newIndex - 1;
+      const isLast = i === nodes.length - 1;
+      if (isTemplateExpression(currentNode)) {
+        const spans = map(currentNode.templateSpans, (span, index) => {
+          copyExpressionComments(span);
+          const isLastSpan = index === currentNode.templateSpans.length - 1;
+          const text = span.literal.text + (isLastSpan ? subsequentText : "");
+          const rawText = getRawTextOfTemplate(span.literal) + (isLastSpan ? rawSubsequentText : "");
+          return factory.createTemplateSpan(
+            span.expression,
+            isLast && isLastSpan ? factory.createTemplateTail(text, rawText) : factory.createTemplateMiddle(text, rawText)
+          );
+        });
+        templateSpans.push(...spans);
+      } else {
+        const templatePart = isLast ? factory.createTemplateTail(subsequentText, rawSubsequentText) : factory.createTemplateMiddle(subsequentText, rawSubsequentText);
+        copyCommentFromStringLiterals(stringIndexes, templatePart);
+        templateSpans.push(factory.createTemplateSpan(currentNode, templatePart));
       }
-      default:
-        Debug.assertNever(parent2, `Unexpected parent kind ${parent2.kind}`);
     }
+    return factory.createTemplateExpression(templateHead, templateSpans);
   }
-  function makeImportSpecifier(propertyName, name) {
-    return factory.createImportSpecifier(
-      /*isTypeOnly*/
-      false,
-      propertyName === name ? void 0 : factory.createIdentifier(propertyName),
-      factory.createIdentifier(name)
+  function copyExpressionComments(node) {
+    const file = node.getSourceFile();
+    copyTrailingComments(
+      node,
+      node.expression,
+      file,
+      3 /* MultiLineCommentTrivia */,
+      /*hasTrailingNewLine*/
+      false
     );
-  }
-  function makeExportSpecifier(propertyName, name) {
-    return factory.createExportSpecifier(
-      /*isTypeOnly*/
-      false,
-      propertyName === name ? void 0 : factory.createIdentifier(propertyName),
-      factory.createIdentifier(name)
+    copyTrailingAsLeadingComments(
+      node.expression,
+      node.expression,
+      file,
+      3 /* MultiLineCommentTrivia */,
+      /*hasTrailingNewLine*/
+      false
     );
   }
-  function getExportingModuleSymbol(parent2, checker) {
-    if (isSourceFile(parent2)) {
-      return parent2.symbol;
-    }
-    const symbol = parent2.parent.symbol;
-    if (symbol.valueDeclaration && isExternalModuleAugmentation(symbol.valueDeclaration)) {
-      return checker.getMergedSymbol(symbol);
+  function getExpressionFromParenthesesOrExpression(node) {
+    if (isParenthesizedExpression(node)) {
+      copyExpressionComments(node);
+      node = node.expression;
     }
-    return symbol;
+    return node;
   }
-  var refactorName, defaultToNamedAction, namedToDefaultAction;
-  var init_convertExport = __esm({
-    "src/services/refactors/convertExport.ts"() {
+  var refactorName10, refactorDescription6, convertStringAction, copyTrailingOperatorComments, copyCommentFromMultiNode;
+  var init_convertStringOrTemplateLiteral = __esm({
+    "src/services/refactors/convertStringOrTemplateLiteral.ts"() {
       "use strict";
       init_ts4();
       init_ts_refactor();
-      refactorName = "Convert export";
-      defaultToNamedAction = {
-        name: "Convert default export to named export",
-        description: Diagnostics.Convert_default_export_to_named_export.message,
-        kind: "refactor.rewrite.export.named"
+      refactorName10 = "Convert to template string";
+      refactorDescription6 = getLocaleSpecificMessage(Diagnostics.Convert_to_template_string);
+      convertStringAction = {
+        name: refactorName10,
+        description: refactorDescription6,
+        kind: "refactor.rewrite.string"
       };
-      namedToDefaultAction = {
-        name: "Convert named export to default export",
-        description: Diagnostics.Convert_named_export_to_default_export.message,
-        kind: "refactor.rewrite.export.default"
+      registerRefactor(refactorName10, {
+        kinds: [convertStringAction.kind],
+        getEditsForAction: getRefactorEditsToConvertToTemplateString,
+        getAvailableActions: getRefactorActionsToConvertToTemplateString
+      });
+      copyTrailingOperatorComments = (operators, file) => (index, targetNode) => {
+        if (index < operators.length) {
+          copyTrailingComments(
+            operators[index],
+            targetNode,
+            file,
+            3 /* MultiLineCommentTrivia */,
+            /*hasTrailingNewLine*/
+            false
+          );
+        }
       };
-      registerRefactor(refactorName, {
-        kinds: [
-          defaultToNamedAction.kind,
-          namedToDefaultAction.kind
-        ],
-        getAvailableActions: function getRefactorActionsToConvertBetweenNamedAndDefaultExports(context) {
-          const info = getInfo2(context, context.triggerReason === "invoked");
-          if (!info)
-            return emptyArray;
-          if (!isRefactorErrorInfo(info)) {
-            const action = info.wasDefault ? defaultToNamedAction : namedToDefaultAction;
-            return [{ name: refactorName, description: action.description, actions: [action] }];
-          }
-          if (context.preferences.provideRefactorNotApplicableReason) {
-            return [
-              { name: refactorName, description: Diagnostics.Convert_default_export_to_named_export.message, actions: [
-                { ...defaultToNamedAction, notApplicableReason: info.error },
-                { ...namedToDefaultAction, notApplicableReason: info.error }
-              ] }
-            ];
-          }
-          return emptyArray;
-        },
-        getEditsForAction: function getRefactorEditsToConvertBetweenNamedAndDefaultExports(context, actionName2) {
-          Debug.assert(actionName2 === defaultToNamedAction.name || actionName2 === namedToDefaultAction.name, "Unexpected action name");
-          const info = getInfo2(context);
-          Debug.assert(info && !isRefactorErrorInfo(info), "Expected applicable refactor info");
-          const edits = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange(context.file, context.program, info, t, context.cancellationToken));
-          return { edits, renameFilename: void 0, renameLocation: void 0 };
+      copyCommentFromMultiNode = (nodes, file, copyOperatorComments) => (indexes, targetNode) => {
+        while (indexes.length > 0) {
+          const index = indexes.shift();
+          copyTrailingComments(
+            nodes[index],
+            targetNode,
+            file,
+            3 /* MultiLineCommentTrivia */,
+            /*hasTrailingNewLine*/
+            false
+          );
+          copyOperatorComments(index, targetNode);
         }
-      });
+      };
     }
   });
 
-  // src/services/refactors/convertImport.ts
-  function getImportConversionInfo(context, considerPartialSpans = true) {
-    const { file } = context;
-    const span = getRefactorContextSpan(context);
-    const token = getTokenAtPosition(file, span.start);
-    const importDecl = considerPartialSpans ? findAncestor(token, isImportDeclaration) : getParentNodeInSpan(token, file, span);
-    if (!importDecl || !isImportDeclaration(importDecl))
-      return { error: "Selection is not an import declaration." };
-    const end = span.start + span.length;
-    const nextToken = findNextToken(importDecl, importDecl.parent, file);
-    if (nextToken && end > nextToken.getStart())
-      return void 0;
-    const { importClause } = importDecl;
-    if (!importClause) {
-      return { error: getLocaleSpecificMessage(Diagnostics.Could_not_find_import_clause) };
+  // src/services/_namespaces/ts.refactor.convertStringOrTemplateLiteral.ts
+  var ts_refactor_convertStringOrTemplateLiteral_exports = {};
+  var init_ts_refactor_convertStringOrTemplateLiteral = __esm({
+    "src/services/_namespaces/ts.refactor.convertStringOrTemplateLiteral.ts"() {
+      "use strict";
+      init_convertStringOrTemplateLiteral();
     }
-    if (!importClause.namedBindings) {
-      return { error: getLocaleSpecificMessage(Diagnostics.Could_not_find_namespace_import_or_named_imports) };
+  });
+
+  // src/services/refactors/convertToOptionalChainExpression.ts
+  function getRefactorActionsToConvertToOptionalChain(context) {
+    const info = getInfo3(context, context.triggerReason === "invoked");
+    if (!info)
+      return emptyArray;
+    if (!isRefactorErrorInfo(info)) {
+      return [{
+        name: refactorName11,
+        description: convertToOptionalChainExpressionMessage,
+        actions: [toOptionalChainAction]
+      }];
     }
-    if (importClause.namedBindings.kind === 273 /* NamespaceImport */) {
-      return { convertTo: 0 /* Named */, import: importClause.namedBindings };
+    if (context.preferences.provideRefactorNotApplicableReason) {
+      return [{
+        name: refactorName11,
+        description: convertToOptionalChainExpressionMessage,
+        actions: [{ ...toOptionalChainAction, notApplicableReason: info.error }]
+      }];
     }
-    const shouldUseDefault = getShouldUseDefault(context.program, importClause);
-    return shouldUseDefault ? { convertTo: 1 /* Default */, import: importClause.namedBindings } : { convertTo: 2 /* Namespace */, import: importClause.namedBindings };
+    return emptyArray;
   }
-  function getShouldUseDefault(program, importClause) {
-    return getAllowSyntheticDefaultImports(program.getCompilerOptions()) && isExportEqualsModule(importClause.parent.moduleSpecifier, program.getTypeChecker());
+  function getRefactorEditsToConvertToOptionalChain(context, actionName2) {
+    const info = getInfo3(context);
+    Debug.assert(info && !isRefactorErrorInfo(info), "Expected applicable refactor info");
+    const edits = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange6(context.file, context.program.getTypeChecker(), t, info, actionName2));
+    return { edits, renameFilename: void 0, renameLocation: void 0 };
   }
-  function doChange2(sourceFile, program, changes, info) {
+  function isValidExpression(node) {
+    return isBinaryExpression(node) || isConditionalExpression(node);
+  }
+  function isValidStatement(node) {
+    return isExpressionStatement(node) || isReturnStatement(node) || isVariableStatement(node);
+  }
+  function isValidExpressionOrStatement(node) {
+    return isValidExpression(node) || isValidStatement(node);
+  }
+  function getInfo3(context, considerEmptySpans = true) {
+    const { file, program } = context;
+    const span = getRefactorContextSpan(context);
+    const forEmptySpan = span.length === 0;
+    if (forEmptySpan && !considerEmptySpans)
+      return void 0;
+    const startToken = getTokenAtPosition(file, span.start);
+    const endToken = findTokenOnLeftOfPosition(file, span.start + span.length);
+    const adjustedSpan = createTextSpanFromBounds(startToken.pos, endToken && endToken.end >= startToken.pos ? endToken.getEnd() : startToken.getEnd());
+    const parent2 = forEmptySpan ? getValidParentNodeOfEmptySpan(startToken) : getValidParentNodeContainingSpan(startToken, adjustedSpan);
+    const expression = parent2 && isValidExpressionOrStatement(parent2) ? getExpression(parent2) : void 0;
+    if (!expression)
+      return { error: getLocaleSpecificMessage(Diagnostics.Could_not_find_convertible_access_expression) };
     const checker = program.getTypeChecker();
-    if (info.convertTo === 0 /* Named */) {
-      doChangeNamespaceToNamed(sourceFile, checker, changes, info.import, getAllowSyntheticDefaultImports(program.getCompilerOptions()));
-    } else {
-      doChangeNamedToNamespaceOrDefault(sourceFile, program, changes, info.import, info.convertTo === 1 /* Default */);
-    }
+    return isConditionalExpression(expression) ? getConditionalInfo(expression, checker) : getBinaryInfo(expression);
   }
-  function doChangeNamespaceToNamed(sourceFile, checker, changes, toConvert, allowSyntheticDefaultImports) {
-    let usedAsNamespaceOrDefault = false;
-    const nodesToReplace = [];
-    const conflictingNames = /* @__PURE__ */ new Map();
-    ts_FindAllReferences_exports.Core.eachSymbolReferenceInFile(toConvert.name, checker, sourceFile, (id) => {
-      if (!isPropertyAccessOrQualifiedName(id.parent)) {
-        usedAsNamespaceOrDefault = true;
-      } else {
-        const exportName = getRightOfPropertyAccessOrQualifiedName(id.parent).text;
-        if (checker.resolveName(
-          exportName,
-          id,
-          67108863 /* All */,
-          /*excludeGlobals*/
-          true
-        )) {
-          conflictingNames.set(exportName, true);
-        }
-        Debug.assert(getLeftOfPropertyAccessOrQualifiedName(id.parent) === id, "Parent expression should match id");
-        nodesToReplace.push(id.parent);
-      }
-    });
-    const exportNameToImportName = /* @__PURE__ */ new Map();
-    for (const propertyAccessOrQualifiedName of nodesToReplace) {
-      const exportName = getRightOfPropertyAccessOrQualifiedName(propertyAccessOrQualifiedName).text;
-      let importName = exportNameToImportName.get(exportName);
-      if (importName === void 0) {
-        exportNameToImportName.set(exportName, importName = conflictingNames.has(exportName) ? getUniqueName(exportName, sourceFile) : exportName);
-      }
-      changes.replaceNode(sourceFile, propertyAccessOrQualifiedName, factory.createIdentifier(importName));
+  function getConditionalInfo(expression, checker) {
+    const condition = expression.condition;
+    const finalExpression = getFinalExpressionInChain(expression.whenTrue);
+    if (!finalExpression || checker.isNullableType(checker.getTypeAtLocation(finalExpression))) {
+      return { error: getLocaleSpecificMessage(Diagnostics.Could_not_find_convertible_access_expression) };
     }
-    const importSpecifiers = [];
-    exportNameToImportName.forEach((name, propertyName) => {
-      importSpecifiers.push(factory.createImportSpecifier(
-        /*isTypeOnly*/
-        false,
-        name === propertyName ? void 0 : factory.createIdentifier(propertyName),
-        factory.createIdentifier(name)
-      ));
-    });
-    const importDecl = toConvert.parent.parent;
-    if (usedAsNamespaceOrDefault && !allowSyntheticDefaultImports) {
-      changes.insertNodeAfter(sourceFile, importDecl, updateImport(
-        importDecl,
-        /*defaultImportName*/
-        void 0,
-        importSpecifiers
-      ));
-    } else {
-      changes.replaceNode(sourceFile, importDecl, updateImport(importDecl, usedAsNamespaceOrDefault ? factory.createIdentifier(toConvert.name.text) : void 0, importSpecifiers));
+    if ((isPropertyAccessExpression(condition) || isIdentifier(condition)) && getMatchingStart(condition, finalExpression.expression)) {
+      return { finalExpression, occurrences: [condition], expression };
+    } else if (isBinaryExpression(condition)) {
+      const occurrences = getOccurrencesInExpression(finalExpression.expression, condition);
+      return occurrences ? { finalExpression, occurrences, expression } : { error: getLocaleSpecificMessage(Diagnostics.Could_not_find_matching_access_expressions) };
     }
   }
-  function getRightOfPropertyAccessOrQualifiedName(propertyAccessOrQualifiedName) {
-    return isPropertyAccessExpression(propertyAccessOrQualifiedName) ? propertyAccessOrQualifiedName.name : propertyAccessOrQualifiedName.right;
-  }
-  function getLeftOfPropertyAccessOrQualifiedName(propertyAccessOrQualifiedName) {
-    return isPropertyAccessExpression(propertyAccessOrQualifiedName) ? propertyAccessOrQualifiedName.expression : propertyAccessOrQualifiedName.left;
+  function getBinaryInfo(expression) {
+    if (expression.operatorToken.kind !== 56 /* AmpersandAmpersandToken */) {
+      return { error: getLocaleSpecificMessage(Diagnostics.Can_only_convert_logical_AND_access_chains) };
+    }
+    const finalExpression = getFinalExpressionInChain(expression.right);
+    if (!finalExpression)
+      return { error: getLocaleSpecificMessage(Diagnostics.Could_not_find_convertible_access_expression) };
+    const occurrences = getOccurrencesInExpression(finalExpression.expression, expression.left);
+    return occurrences ? { finalExpression, occurrences, expression } : { error: getLocaleSpecificMessage(Diagnostics.Could_not_find_matching_access_expressions) };
   }
-  function doChangeNamedToNamespaceOrDefault(sourceFile, program, changes, toConvert, shouldUseDefault = getShouldUseDefault(program, toConvert.parent)) {
-    const checker = program.getTypeChecker();
-    const importDecl = toConvert.parent.parent;
-    const { moduleSpecifier } = importDecl;
-    const toConvertSymbols = /* @__PURE__ */ new Set();
-    toConvert.elements.forEach((namedImport) => {
-      const symbol = checker.getSymbolAtLocation(namedImport.name);
-      if (symbol) {
-        toConvertSymbols.add(symbol);
+  function getOccurrencesInExpression(matchTo, expression) {
+    const occurrences = [];
+    while (isBinaryExpression(expression) && expression.operatorToken.kind === 56 /* AmpersandAmpersandToken */) {
+      const match = getMatchingStart(skipParentheses(matchTo), skipParentheses(expression.right));
+      if (!match) {
+        break;
       }
-    });
-    const preferredName = moduleSpecifier && isStringLiteral(moduleSpecifier) ? ts_codefix_exports.moduleSpecifierToValidIdentifier(moduleSpecifier.text, 99 /* ESNext */) : "module";
-    function hasNamespaceNameConflict(namedImport) {
-      return !!ts_FindAllReferences_exports.Core.eachSymbolReferenceInFile(namedImport.name, checker, sourceFile, (id) => {
-        const symbol = checker.resolveName(
-          preferredName,
-          id,
-          67108863 /* All */,
-          /*excludeGlobals*/
-          true
-        );
-        if (symbol) {
-          if (toConvertSymbols.has(symbol)) {
-            return isExportSpecifier(id.parent);
-          }
-          return true;
-        }
-        return false;
-      });
-    }
-    const namespaceNameConflicts = toConvert.elements.some(hasNamespaceNameConflict);
-    const namespaceImportName = namespaceNameConflicts ? getUniqueName(preferredName, sourceFile) : preferredName;
-    const neededNamedImports = /* @__PURE__ */ new Set();
-    for (const element of toConvert.elements) {
-      const propertyName = (element.propertyName || element.name).text;
-      ts_FindAllReferences_exports.Core.eachSymbolReferenceInFile(element.name, checker, sourceFile, (id) => {
-        const access = factory.createPropertyAccessExpression(factory.createIdentifier(namespaceImportName), propertyName);
-        if (isShorthandPropertyAssignment(id.parent)) {
-          changes.replaceNode(sourceFile, id.parent, factory.createPropertyAssignment(id.text, access));
-        } else if (isExportSpecifier(id.parent)) {
-          neededNamedImports.add(element);
-        } else {
-          changes.replaceNode(sourceFile, id, access);
-        }
-      });
+      occurrences.push(match);
+      matchTo = match;
+      expression = expression.left;
     }
-    changes.replaceNode(sourceFile, toConvert, shouldUseDefault ? factory.createIdentifier(namespaceImportName) : factory.createNamespaceImport(factory.createIdentifier(namespaceImportName)));
-    if (neededNamedImports.size) {
-      const newNamedImports = arrayFrom(neededNamedImports.values(), (element) => factory.createImportSpecifier(element.isTypeOnly, element.propertyName && factory.createIdentifier(element.propertyName.text), factory.createIdentifier(element.name.text)));
-      changes.insertNodeAfter(sourceFile, toConvert.parent.parent, updateImport(
-        importDecl,
-        /*defaultImportName*/
-        void 0,
-        newNamedImports
-      ));
+    const finalMatch = getMatchingStart(matchTo, expression);
+    if (finalMatch) {
+      occurrences.push(finalMatch);
     }
+    return occurrences.length > 0 ? occurrences : void 0;
   }
-  function isExportEqualsModule(moduleSpecifier, checker) {
-    const externalModule = checker.resolveExternalModuleName(moduleSpecifier);
-    if (!externalModule)
-      return false;
-    const exportEquals = checker.resolveExternalModuleSymbol(externalModule);
-    return externalModule !== exportEquals;
+  function getMatchingStart(chain, subchain) {
+    if (!isIdentifier(subchain) && !isPropertyAccessExpression(subchain) && !isElementAccessExpression(subchain)) {
+      return void 0;
+    }
+    return chainStartsWith(chain, subchain) ? subchain : void 0;
   }
-  function updateImport(old, defaultImportName, elements) {
-    return factory.createImportDeclaration(
-      /*modifiers*/
-      void 0,
-      factory.createImportClause(
-        /*isTypeOnly*/
-        false,
-        defaultImportName,
-        elements && elements.length ? factory.createNamedImports(elements) : void 0
-      ),
-      old.moduleSpecifier,
-      /*assertClause*/
-      void 0
-    );
+  function chainStartsWith(chain, subchain) {
+    while (isCallExpression(chain) || isPropertyAccessExpression(chain) || isElementAccessExpression(chain)) {
+      if (getTextOfChainNode(chain) === getTextOfChainNode(subchain))
+        break;
+      chain = chain.expression;
+    }
+    while (isPropertyAccessExpression(chain) && isPropertyAccessExpression(subchain) || isElementAccessExpression(chain) && isElementAccessExpression(subchain)) {
+      if (getTextOfChainNode(chain) !== getTextOfChainNode(subchain))
+        return false;
+      chain = chain.expression;
+      subchain = subchain.expression;
+    }
+    return isIdentifier(chain) && isIdentifier(subchain) && chain.getText() === subchain.getText();
   }
-  var refactorName2, actions;
-  var init_convertImport = __esm({
-    "src/services/refactors/convertImport.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_refactor();
-      refactorName2 = "Convert import";
-      actions = {
-        [0 /* Named */]: {
-          name: "Convert namespace import to named imports",
-          description: Diagnostics.Convert_namespace_import_to_named_imports.message,
-          kind: "refactor.rewrite.import.named"
-        },
-        [2 /* Namespace */]: {
-          name: "Convert named imports to namespace import",
-          description: Diagnostics.Convert_named_imports_to_namespace_import.message,
-          kind: "refactor.rewrite.import.namespace"
-        },
-        [1 /* Default */]: {
-          name: "Convert named imports to default import",
-          description: Diagnostics.Convert_named_imports_to_default_import.message,
-          kind: "refactor.rewrite.import.default"
-        }
-      };
-      registerRefactor(refactorName2, {
-        kinds: getOwnValues(actions).map((a) => a.kind),
-        getAvailableActions: function getRefactorActionsToConvertBetweenNamedAndNamespacedImports(context) {
-          const info = getImportConversionInfo(context, context.triggerReason === "invoked");
-          if (!info)
-            return emptyArray;
-          if (!isRefactorErrorInfo(info)) {
-            const action = actions[info.convertTo];
-            return [{ name: refactorName2, description: action.description, actions: [action] }];
-          }
-          if (context.preferences.provideRefactorNotApplicableReason) {
-            return getOwnValues(actions).map((action) => ({
-              name: refactorName2,
-              description: action.description,
-              actions: [{ ...action, notApplicableReason: info.error }]
-            }));
-          }
-          return emptyArray;
-        },
-        getEditsForAction: function getRefactorEditsToConvertBetweenNamedAndNamespacedImports(context, actionName2) {
-          Debug.assert(some(getOwnValues(actions), (action) => action.name === actionName2), "Unexpected action name");
-          const info = getImportConversionInfo(context);
-          Debug.assert(info && !isRefactorErrorInfo(info), "Expected applicable refactor info");
-          const edits = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange2(context.file, context.program, t, info));
-          return { edits, renameFilename: void 0, renameLocation: void 0 };
-        }
-      });
+  function getTextOfChainNode(node) {
+    if (isIdentifier(node) || isStringOrNumericLiteralLike(node)) {
+      return node.getText();
     }
-  });
-
-  // src/services/refactors/extractType.ts
-  function getRangeToExtract(context, considerEmptySpans = true) {
-    const { file, startPosition } = context;
-    const isJS = isSourceFileJS(file);
-    const current = getTokenAtPosition(file, startPosition);
-    const range = createTextRangeFromSpan(getRefactorContextSpan(context));
-    const cursorRequest = range.pos === range.end && considerEmptySpans;
-    const selection = findAncestor(current, (node) => node.parent && isTypeNode(node) && !rangeContainsSkipTrivia(range, node.parent, file) && (cursorRequest || nodeOverlapsWithStartEnd(current, file, range.pos, range.end)));
-    if (!selection || !isTypeNode(selection))
-      return { error: getLocaleSpecificMessage(Diagnostics.Selection_is_not_a_valid_type_node) };
-    const checker = context.program.getTypeChecker();
-    const enclosingNode = getEnclosingNode(selection, isJS);
-    if (enclosingNode === void 0)
-      return { error: getLocaleSpecificMessage(Diagnostics.No_type_could_be_extracted_from_this_type_node) };
-    const typeParameters = collectTypeParameters(checker, selection, enclosingNode, file);
-    if (!typeParameters)
-      return { error: getLocaleSpecificMessage(Diagnostics.No_type_could_be_extracted_from_this_type_node) };
-    const typeElements = flattenTypeLiteralNodeReference(checker, selection);
-    return { isJS, selection, enclosingNode, typeParameters, typeElements };
+    if (isPropertyAccessExpression(node)) {
+      return getTextOfChainNode(node.name);
+    }
+    if (isElementAccessExpression(node)) {
+      return getTextOfChainNode(node.argumentExpression);
+    }
+    return void 0;
   }
-  function flattenTypeLiteralNodeReference(checker, node) {
-    if (!node)
-      return void 0;
-    if (isIntersectionTypeNode(node)) {
-      const result = [];
-      const seen = /* @__PURE__ */ new Map();
-      for (const type of node.types) {
-        const flattenedTypeMembers = flattenTypeLiteralNodeReference(checker, type);
-        if (!flattenedTypeMembers || !flattenedTypeMembers.every((type2) => type2.name && addToSeen(seen, getNameFromPropertyName(type2.name)))) {
-          return void 0;
-        }
-        addRange(result, flattenedTypeMembers);
+  function getValidParentNodeContainingSpan(node, span) {
+    while (node.parent) {
+      if (isValidExpressionOrStatement(node) && span.length !== 0 && node.end >= span.start + span.length) {
+        return node;
       }
-      return result;
-    } else if (isParenthesizedTypeNode(node)) {
-      return flattenTypeLiteralNodeReference(checker, node.type);
-    } else if (isTypeLiteralNode(node)) {
-      return node.members;
+      node = node.parent;
     }
     return void 0;
   }
-  function rangeContainsSkipTrivia(r1, node, file) {
-    return rangeContainsStartEnd(r1, skipTrivia(file.text, node.pos), node.end);
-  }
-  function collectTypeParameters(checker, selection, enclosingNode, file) {
-    const result = [];
-    return visitor(selection) ? void 0 : result;
-    function visitor(node) {
-      if (isTypeReferenceNode(node)) {
-        if (isIdentifier(node.typeName)) {
-          const typeName = node.typeName;
-          const symbol = checker.resolveName(
-            typeName.text,
-            typeName,
-            262144 /* TypeParameter */,
-            /*excludeGlobals*/
-            true
-          );
-          for (const decl of (symbol == null ? void 0 : symbol.declarations) || emptyArray) {
-            if (isTypeParameterDeclaration(decl) && decl.getSourceFile() === file) {
-              if (decl.name.escapedText === typeName.escapedText && rangeContainsSkipTrivia(decl, selection, file)) {
-                return true;
-              }
-              if (rangeContainsSkipTrivia(enclosingNode, decl, file) && !rangeContainsSkipTrivia(selection, decl, file)) {
-                pushIfUnique(result, decl);
-                break;
-              }
-            }
-          }
-        }
-      } else if (isInferTypeNode(node)) {
-        const conditionalTypeNode = findAncestor(node, (n) => isConditionalTypeNode(n) && rangeContainsSkipTrivia(n.extendsType, node, file));
-        if (!conditionalTypeNode || !rangeContainsSkipTrivia(selection, conditionalTypeNode, file)) {
-          return true;
-        }
-      } else if (isTypePredicateNode(node) || isThisTypeNode(node)) {
-        const functionLikeNode = findAncestor(node.parent, isFunctionLike);
-        if (functionLikeNode && functionLikeNode.type && rangeContainsSkipTrivia(functionLikeNode.type, node, file) && !rangeContainsSkipTrivia(selection, functionLikeNode, file)) {
-          return true;
-        }
-      } else if (isTypeQueryNode(node)) {
-        if (isIdentifier(node.exprName)) {
-          const symbol = checker.resolveName(
-            node.exprName.text,
-            node.exprName,
-            111551 /* Value */,
-            /*excludeGlobals*/
-            false
-          );
-          if ((symbol == null ? void 0 : symbol.valueDeclaration) && rangeContainsSkipTrivia(enclosingNode, symbol.valueDeclaration, file) && !rangeContainsSkipTrivia(selection, symbol.valueDeclaration, file)) {
-            return true;
-          }
-        } else {
-          if (isThisIdentifier(node.exprName.left) && !rangeContainsSkipTrivia(selection, node.parent, file)) {
-            return true;
-          }
-        }
-      }
-      if (file && isTupleTypeNode(node) && getLineAndCharacterOfPosition(file, node.pos).line === getLineAndCharacterOfPosition(file, node.end).line) {
-        setEmitFlags(node, 1 /* SingleLine */);
+  function getValidParentNodeOfEmptySpan(node) {
+    while (node.parent) {
+      if (isValidExpressionOrStatement(node) && !isValidExpressionOrStatement(node.parent)) {
+        return node;
       }
-      return forEachChild(node, visitor);
+      node = node.parent;
     }
+    return void 0;
   }
-  function doTypeAliasChange(changes, file, name, info) {
-    const { enclosingNode, selection, typeParameters } = info;
-    const newTypeNode = factory.createTypeAliasDeclaration(
-      /*modifiers*/
-      void 0,
-      name,
-      typeParameters.map((id) => factory.updateTypeParameterDeclaration(
-        id,
-        id.modifiers,
-        id.name,
-        id.constraint,
-        /*defaultType*/
-        void 0
-      )),
-      selection
-    );
-    changes.insertNodeBefore(
-      file,
-      enclosingNode,
-      ignoreSourceNewlines(newTypeNode),
-      /*blankLineBetween*/
-      true
-    );
-    changes.replaceNode(file, selection, factory.createTypeReferenceNode(name, typeParameters.map((id) => factory.createTypeReferenceNode(
-      id.name,
-      /*typeArguments*/
-      void 0
-    ))), { leadingTriviaOption: ts_textChanges_exports.LeadingTriviaOption.Exclude, trailingTriviaOption: ts_textChanges_exports.TrailingTriviaOption.ExcludeWhitespace });
+  function getExpression(node) {
+    if (isValidExpression(node)) {
+      return node;
+    }
+    if (isVariableStatement(node)) {
+      const variable = getSingleVariableOfVariableStatement(node);
+      const initializer = variable == null ? void 0 : variable.initializer;
+      return initializer && isValidExpression(initializer) ? initializer : void 0;
+    }
+    return node.expression && isValidExpression(node.expression) ? node.expression : void 0;
   }
-  function doInterfaceChange(changes, file, name, info) {
-    var _a;
-    const { enclosingNode, selection, typeParameters, typeElements } = info;
-    const newTypeNode = factory.createInterfaceDeclaration(
-      /*modifiers*/
-      void 0,
-      name,
-      typeParameters,
-      /*heritageClauses*/
-      void 0,
-      typeElements
-    );
-    setTextRange(newTypeNode, (_a = typeElements[0]) == null ? void 0 : _a.parent);
-    changes.insertNodeBefore(
-      file,
-      enclosingNode,
-      ignoreSourceNewlines(newTypeNode),
-      /*blankLineBetween*/
-      true
-    );
-    changes.replaceNode(file, selection, factory.createTypeReferenceNode(name, typeParameters.map((id) => factory.createTypeReferenceNode(
-      id.name,
-      /*typeArguments*/
-      void 0
-    ))), { leadingTriviaOption: ts_textChanges_exports.LeadingTriviaOption.Exclude, trailingTriviaOption: ts_textChanges_exports.TrailingTriviaOption.ExcludeWhitespace });
+  function getFinalExpressionInChain(node) {
+    node = skipParentheses(node);
+    if (isBinaryExpression(node)) {
+      return getFinalExpressionInChain(node.left);
+    } else if ((isPropertyAccessExpression(node) || isElementAccessExpression(node) || isCallExpression(node)) && !isOptionalChain(node)) {
+      return node;
+    }
+    return void 0;
   }
-  function doTypedefChange(changes, context, file, name, info) {
-    var _a;
-    const { enclosingNode, selection, typeParameters } = info;
-    setEmitFlags(selection, 3072 /* NoComments */ | 4096 /* NoNestedComments */);
-    const node = factory.createJSDocTypedefTag(
-      factory.createIdentifier("typedef"),
-      factory.createJSDocTypeExpression(selection),
-      factory.createIdentifier(name)
-    );
-    const templates = [];
-    forEach(typeParameters, (typeParameter) => {
-      const constraint = getEffectiveConstraintOfTypeParameter(typeParameter);
-      const parameter = factory.createTypeParameterDeclaration(
-        /*modifiers*/
-        void 0,
-        typeParameter.name
-      );
-      const template = factory.createJSDocTemplateTag(
-        factory.createIdentifier("template"),
-        constraint && cast(constraint, isJSDocTypeExpression),
-        [parameter]
-      );
-      templates.push(template);
-    });
-    const jsDoc = factory.createJSDocComment(
-      /*comment*/
-      void 0,
-      factory.createNodeArray(concatenate(templates, [node]))
-    );
-    if (isJSDoc(enclosingNode)) {
-      const pos = enclosingNode.getStart(file);
-      const newLineCharacter = getNewLineOrDefaultFromHost(context.host, (_a = context.formatContext) == null ? void 0 : _a.options);
-      changes.insertNodeAt(file, enclosingNode.getStart(file), jsDoc, {
-        suffix: newLineCharacter + newLineCharacter + file.text.slice(getPrecedingNonSpaceCharacterPosition(file.text, pos - 1), pos)
-      });
-    } else {
-      changes.insertNodeBefore(
-        file,
-        enclosingNode,
-        jsDoc,
-        /*blankLineBetween*/
-        true
-      );
+  function convertOccurrences(checker, toConvert, occurrences) {
+    if (isPropertyAccessExpression(toConvert) || isElementAccessExpression(toConvert) || isCallExpression(toConvert)) {
+      const chain = convertOccurrences(checker, toConvert.expression, occurrences);
+      const lastOccurrence = occurrences.length > 0 ? occurrences[occurrences.length - 1] : void 0;
+      const isOccurrence = (lastOccurrence == null ? void 0 : lastOccurrence.getText()) === toConvert.expression.getText();
+      if (isOccurrence)
+        occurrences.pop();
+      if (isCallExpression(toConvert)) {
+        return isOccurrence ? factory.createCallChain(chain, factory.createToken(29 /* QuestionDotToken */), toConvert.typeArguments, toConvert.arguments) : factory.createCallChain(chain, toConvert.questionDotToken, toConvert.typeArguments, toConvert.arguments);
+      } else if (isPropertyAccessExpression(toConvert)) {
+        return isOccurrence ? factory.createPropertyAccessChain(chain, factory.createToken(29 /* QuestionDotToken */), toConvert.name) : factory.createPropertyAccessChain(chain, toConvert.questionDotToken, toConvert.name);
+      } else if (isElementAccessExpression(toConvert)) {
+        return isOccurrence ? factory.createElementAccessChain(chain, factory.createToken(29 /* QuestionDotToken */), toConvert.argumentExpression) : factory.createElementAccessChain(chain, toConvert.questionDotToken, toConvert.argumentExpression);
+      }
     }
-    changes.replaceNode(file, selection, factory.createTypeReferenceNode(name, typeParameters.map((id) => factory.createTypeReferenceNode(
-      id.name,
-      /*typeArguments*/
-      void 0
-    ))));
+    return toConvert;
   }
-  function getEnclosingNode(node, isJS) {
-    return findAncestor(node, isStatement) || (isJS ? findAncestor(node, isJSDoc) : void 0);
+  function doChange6(sourceFile, checker, changes, info, _actionName) {
+    const { finalExpression, occurrences, expression } = info;
+    const firstOccurrence = occurrences[occurrences.length - 1];
+    const convertedChain = convertOccurrences(checker, finalExpression, occurrences);
+    if (convertedChain && (isPropertyAccessExpression(convertedChain) || isElementAccessExpression(convertedChain) || isCallExpression(convertedChain))) {
+      if (isBinaryExpression(expression)) {
+        changes.replaceNodeRange(sourceFile, firstOccurrence, finalExpression, convertedChain);
+      } else if (isConditionalExpression(expression)) {
+        changes.replaceNode(sourceFile, expression, factory.createBinaryExpression(convertedChain, factory.createToken(61 /* QuestionQuestionToken */), expression.whenFalse));
+      }
+    }
   }
-  var refactorName3, extractToTypeAliasAction, extractToInterfaceAction, extractToTypeDefAction;
-  var init_extractType = __esm({
-    "src/services/refactors/extractType.ts"() {
+  var refactorName11, convertToOptionalChainExpressionMessage, toOptionalChainAction;
+  var init_convertToOptionalChainExpression = __esm({
+    "src/services/refactors/convertToOptionalChainExpression.ts"() {
       "use strict";
       init_ts4();
       init_ts_refactor();
-      refactorName3 = "Extract type";
-      extractToTypeAliasAction = {
-        name: "Extract to type alias",
-        description: getLocaleSpecificMessage(Diagnostics.Extract_to_type_alias),
-        kind: "refactor.extract.type"
-      };
-      extractToInterfaceAction = {
-        name: "Extract to interface",
-        description: getLocaleSpecificMessage(Diagnostics.Extract_to_interface),
-        kind: "refactor.extract.interface"
-      };
-      extractToTypeDefAction = {
-        name: "Extract to typedef",
-        description: getLocaleSpecificMessage(Diagnostics.Extract_to_typedef),
-        kind: "refactor.extract.typedef"
+      refactorName11 = "Convert to optional chain expression";
+      convertToOptionalChainExpressionMessage = getLocaleSpecificMessage(Diagnostics.Convert_to_optional_chain_expression);
+      toOptionalChainAction = {
+        name: refactorName11,
+        description: convertToOptionalChainExpressionMessage,
+        kind: "refactor.rewrite.expression.optionalChain"
       };
-      registerRefactor(refactorName3, {
-        kinds: [
-          extractToTypeAliasAction.kind,
-          extractToInterfaceAction.kind,
-          extractToTypeDefAction.kind
-        ],
-        getAvailableActions: function getRefactorActionsToExtractType(context) {
-          const info = getRangeToExtract(context, context.triggerReason === "invoked");
-          if (!info)
-            return emptyArray;
-          if (!isRefactorErrorInfo(info)) {
-            return [{
-              name: refactorName3,
-              description: getLocaleSpecificMessage(Diagnostics.Extract_type),
-              actions: info.isJS ? [extractToTypeDefAction] : append([extractToTypeAliasAction], info.typeElements && extractToInterfaceAction)
-            }];
-          }
-          if (context.preferences.provideRefactorNotApplicableReason) {
-            return [{
-              name: refactorName3,
-              description: getLocaleSpecificMessage(Diagnostics.Extract_type),
-              actions: [
-                { ...extractToTypeDefAction, notApplicableReason: info.error },
-                { ...extractToTypeAliasAction, notApplicableReason: info.error },
-                { ...extractToInterfaceAction, notApplicableReason: info.error }
-              ]
-            }];
-          }
-          return emptyArray;
-        },
-        getEditsForAction: function getRefactorEditsToExtractType(context, actionName2) {
-          const { file } = context;
-          const info = getRangeToExtract(context);
-          Debug.assert(info && !isRefactorErrorInfo(info), "Expected to find a range to extract");
-          const name = getUniqueName("NewType", file);
-          const edits = ts_textChanges_exports.ChangeTracker.with(context, (changes) => {
-            switch (actionName2) {
-              case extractToTypeAliasAction.name:
-                Debug.assert(!info.isJS, "Invalid actionName/JS combo");
-                return doTypeAliasChange(changes, file, name, info);
-              case extractToTypeDefAction.name:
-                Debug.assert(info.isJS, "Invalid actionName/JS combo");
-                return doTypedefChange(changes, context, file, name, info);
-              case extractToInterfaceAction.name:
-                Debug.assert(!info.isJS && !!info.typeElements, "Invalid actionName/JS combo");
-                return doInterfaceChange(changes, file, name, info);
-              default:
-                Debug.fail("Unexpected action name");
-            }
-          });
-          const renameFilename = file.fileName;
-          const renameLocation = getRenameLocation(
-            edits,
-            renameFilename,
-            name,
-            /*preferLastLocation*/
-            false
-          );
-          return { edits, renameFilename, renameLocation };
-        }
+      registerRefactor(refactorName11, {
+        kinds: [toOptionalChainAction.kind],
+        getEditsForAction: getRefactorEditsToConvertToOptionalChain,
+        getAvailableActions: getRefactorActionsToConvertToOptionalChain
       });
     }
   });
 
-  // src/services/refactors/helpers.ts
-  function isRefactorErrorInfo(info) {
-    return info.error !== void 0;
-  }
-  function refactorKindBeginsWith(known, requested) {
-    if (!requested)
-      return true;
-    return known.substr(0, requested.length) === requested;
-  }
-  var init_helpers = __esm({
-    "src/services/refactors/helpers.ts"() {
+  // src/services/_namespaces/ts.refactor.convertToOptionalChainExpression.ts
+  var ts_refactor_convertToOptionalChainExpression_exports = {};
+  var init_ts_refactor_convertToOptionalChainExpression = __esm({
+    "src/services/_namespaces/ts.refactor.convertToOptionalChainExpression.ts"() {
       "use strict";
+      init_convertToOptionalChainExpression();
     }
   });
 
-  // src/services/refactors/moveToNewFile.ts
-  function doChange3(oldFile, program, toMove, changes, host, preferences, context) {
-    const checker = program.getTypeChecker();
-    const usage = getUsageInfo(oldFile, toMove.all, checker);
-    const newFilename = createNewFileName(oldFile, program, context, host);
-    changes.createNewFile(oldFile, newFilename, getNewStatementsAndRemoveFromOldFile(oldFile, usage, changes, toMove, program, host, newFilename, preferences));
-    addNewFileToTsconfig(program, changes, oldFile.fileName, newFilename, hostGetCanonicalFileName(host));
-  }
-  function getNewStatementsAndRemoveFromOldFile(oldFile, usage, changes, toMove, program, host, newFilename, preferences) {
-    const checker = program.getTypeChecker();
-    const prologueDirectives = takeWhile(oldFile.statements, isPrologueDirective);
-    if (oldFile.externalModuleIndicator === void 0 && oldFile.commonJsModuleIndicator === void 0 && usage.oldImportsNeededByTargetFile.size === 0) {
-      deleteMovedStatements(oldFile, toMove.ranges, changes);
-      return [...prologueDirectives, ...toMove.all];
-    }
-    const useEsModuleSyntax = !fileShouldUseJavaScriptRequire(newFilename, program, host, !!oldFile.commonJsModuleIndicator);
-    const quotePreference = getQuotePreference(oldFile, preferences);
-    const importsFromNewFile = createOldFileImportsFromTargetFile(oldFile, usage.oldFileImportsFromTargetFile, newFilename, program, host, useEsModuleSyntax, quotePreference);
-    if (importsFromNewFile) {
-      insertImports(
-        changes,
-        oldFile,
-        importsFromNewFile,
-        /*blankLineBetween*/
-        true,
-        preferences
-      );
-    }
-    deleteUnusedOldImports(oldFile, toMove.all, changes, usage.unusedImportsFromOldFile, checker);
-    deleteMovedStatements(oldFile, toMove.ranges, changes);
-    updateImportsInOtherFiles(changes, program, host, oldFile, usage.movedSymbols, newFilename, quotePreference);
-    const imports = getNewFileImportsAndAddExportInOldFile(oldFile, usage.oldImportsNeededByTargetFile, usage.targetFileImportsFromOldFile, changes, checker, program, host, useEsModuleSyntax, quotePreference);
-    const body = addExports(oldFile, toMove.all, usage.oldFileImportsFromTargetFile, useEsModuleSyntax);
-    if (imports.length && body.length) {
-      return [
-        ...prologueDirectives,
-        ...imports,
-        4 /* NewLineTrivia */,
-        ...body
-      ];
+  // src/services/refactors/extractSymbol.ts
+  function getRefactorActionsToExtractSymbol(context) {
+    const requestedRefactor = context.kind;
+    const rangeToExtract = getRangeToExtract2(context.file, getRefactorContextSpan(context), context.triggerReason === "invoked");
+    const targetRange = rangeToExtract.targetRange;
+    if (targetRange === void 0) {
+      if (!rangeToExtract.errors || rangeToExtract.errors.length === 0 || !context.preferences.provideRefactorNotApplicableReason) {
+        return emptyArray;
+      }
+      const errors = [];
+      if (refactorKindBeginsWith(extractFunctionAction.kind, requestedRefactor)) {
+        errors.push({
+          name: refactorName12,
+          description: extractFunctionAction.description,
+          actions: [{ ...extractFunctionAction, notApplicableReason: getStringError(rangeToExtract.errors) }]
+        });
+      }
+      if (refactorKindBeginsWith(extractConstantAction.kind, requestedRefactor)) {
+        errors.push({
+          name: refactorName12,
+          description: extractConstantAction.description,
+          actions: [{ ...extractConstantAction, notApplicableReason: getStringError(rangeToExtract.errors) }]
+        });
+      }
+      return errors;
     }
-    return [
-      ...prologueDirectives,
-      ...imports,
-      ...body
-    ];
-  }
-  function getNewFileImportsAndAddExportInOldFile(oldFile, importsToCopy, newFileImportsFromOldFile, changes, checker, program, host, useEsModuleSyntax, quotePreference) {
-    const copiedOldImports = [];
-    for (const oldStatement of oldFile.statements) {
-      forEachImportInStatement(oldStatement, (i) => {
-        append(copiedOldImports, filterImport(i, moduleSpecifierFromImport(i), (name) => importsToCopy.has(checker.getSymbolAtLocation(name))));
-      });
+    const extractions = getPossibleExtractions(targetRange, context);
+    if (extractions === void 0) {
+      return emptyArray;
     }
-    let oldFileDefault;
-    const oldFileNamedImports = [];
-    const markSeenTop = nodeSeenTracker();
-    newFileImportsFromOldFile.forEach((symbol) => {
-      if (!symbol.declarations) {
-        return;
-      }
-      for (const decl of symbol.declarations) {
-        if (!isTopLevelDeclaration(decl))
-          continue;
-        const name = nameOfTopLevelDeclaration(decl);
-        if (!name)
-          continue;
-        const top = getTopLevelDeclarationStatement(decl);
-        if (markSeenTop(top)) {
-          addExportToChanges(oldFile, top, name, changes, useEsModuleSyntax);
-        }
-        if (hasSyntacticModifier(decl, 1024 /* Default */)) {
-          oldFileDefault = name;
-        } else {
-          oldFileNamedImports.push(name.text);
+    const functionActions = [];
+    const usedFunctionNames = /* @__PURE__ */ new Map();
+    let innermostErrorFunctionAction;
+    const constantActions = [];
+    const usedConstantNames = /* @__PURE__ */ new Map();
+    let innermostErrorConstantAction;
+    let i = 0;
+    for (const { functionExtraction, constantExtraction } of extractions) {
+      if (refactorKindBeginsWith(extractFunctionAction.kind, requestedRefactor)) {
+        const description3 = functionExtraction.description;
+        if (functionExtraction.errors.length === 0) {
+          if (!usedFunctionNames.has(description3)) {
+            usedFunctionNames.set(description3, true);
+            functionActions.push({
+              description: description3,
+              name: `function_scope_${i}`,
+              kind: extractFunctionAction.kind
+            });
+          }
+        } else if (!innermostErrorFunctionAction) {
+          innermostErrorFunctionAction = {
+            description: description3,
+            name: `function_scope_${i}`,
+            notApplicableReason: getStringError(functionExtraction.errors),
+            kind: extractFunctionAction.kind
+          };
         }
       }
-    });
-    append(copiedOldImports, makeImportOrRequire(oldFile, oldFileDefault, oldFileNamedImports, getBaseFileName(oldFile.fileName), program, host, useEsModuleSyntax, quotePreference));
-    return copiedOldImports;
-  }
-  var refactorName4, description, moveToNewFileAction;
-  var init_moveToNewFile = __esm({
-    "src/services/refactors/moveToNewFile.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_refactor();
-      refactorName4 = "Move to a new file";
-      description = getLocaleSpecificMessage(Diagnostics.Move_to_a_new_file);
-      moveToNewFileAction = {
-        name: refactorName4,
-        description,
-        kind: "refactor.move.newFile"
-      };
-      registerRefactor(refactorName4, {
-        kinds: [moveToNewFileAction.kind],
-        getAvailableActions: function getRefactorActionsToMoveToNewFile(context) {
-          const statements = getStatementsToMove(context);
-          if (context.preferences.allowTextChangesInNewFiles && statements) {
-            return [{ name: refactorName4, description, actions: [moveToNewFileAction] }];
-          }
-          if (context.preferences.provideRefactorNotApplicableReason) {
-            return [{
-              name: refactorName4,
-              description,
-              actions: [{ ...moveToNewFileAction, notApplicableReason: getLocaleSpecificMessage(Diagnostics.Selection_is_not_a_valid_statement_or_statements) }]
-            }];
+      if (refactorKindBeginsWith(extractConstantAction.kind, requestedRefactor)) {
+        const description3 = constantExtraction.description;
+        if (constantExtraction.errors.length === 0) {
+          if (!usedConstantNames.has(description3)) {
+            usedConstantNames.set(description3, true);
+            constantActions.push({
+              description: description3,
+              name: `constant_scope_${i}`,
+              kind: extractConstantAction.kind
+            });
           }
-          return emptyArray;
-        },
-        getEditsForAction: function getRefactorEditsToMoveToNewFile(context, actionName2) {
-          Debug.assert(actionName2 === refactorName4, "Wrong refactor invoked");
-          const statements = Debug.checkDefined(getStatementsToMove(context));
-          const edits = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange3(context.file, context.program, statements, t, context.host, context.preferences, context));
-          return { edits, renameFilename: void 0, renameLocation: void 0 };
+        } else if (!innermostErrorConstantAction) {
+          innermostErrorConstantAction = {
+            description: description3,
+            name: `constant_scope_${i}`,
+            notApplicableReason: getStringError(constantExtraction.errors),
+            kind: extractConstantAction.kind
+          };
         }
+      }
+      i++;
+    }
+    const infos = [];
+    if (functionActions.length) {
+      infos.push({
+        name: refactorName12,
+        description: getLocaleSpecificMessage(Diagnostics.Extract_function),
+        actions: functionActions
+      });
+    } else if (context.preferences.provideRefactorNotApplicableReason && innermostErrorFunctionAction) {
+      infos.push({
+        name: refactorName12,
+        description: getLocaleSpecificMessage(Diagnostics.Extract_function),
+        actions: [innermostErrorFunctionAction]
       });
     }
-  });
-
-  // src/services/refactors/moveToFile.ts
-  function doChange4(context, oldFile, targetFile, program, toMove, changes, host, preferences) {
-    const checker = program.getTypeChecker();
-    const usage = getUsageInfo(oldFile, toMove.all, checker);
-    if (!host.fileExists(targetFile)) {
-      changes.createNewFile(oldFile, targetFile, getNewStatementsAndRemoveFromOldFile2(oldFile, targetFile, usage, changes, toMove, program, host, preferences));
-      addNewFileToTsconfig(program, changes, oldFile.fileName, targetFile, hostGetCanonicalFileName(host));
-    } else {
-      const targetSourceFile = Debug.checkDefined(program.getSourceFile(targetFile));
-      const importAdder = ts_codefix_exports.createImportAdder(targetSourceFile, context.program, context.preferences, context.host);
-      getNewStatementsAndRemoveFromOldFile2(oldFile, targetSourceFile, usage, changes, toMove, program, host, preferences, importAdder);
+    if (constantActions.length) {
+      infos.push({
+        name: refactorName12,
+        description: getLocaleSpecificMessage(Diagnostics.Extract_constant),
+        actions: constantActions
+      });
+    } else if (context.preferences.provideRefactorNotApplicableReason && innermostErrorConstantAction) {
+      infos.push({
+        name: refactorName12,
+        description: getLocaleSpecificMessage(Diagnostics.Extract_constant),
+        actions: [innermostErrorConstantAction]
+      });
+    }
+    return infos.length ? infos : emptyArray;
+    function getStringError(errors) {
+      let error2 = errors[0].messageText;
+      if (typeof error2 !== "string") {
+        error2 = error2.messageText;
+      }
+      return error2;
+    }
+  }
+  function getRefactorEditsToExtractSymbol(context, actionName2) {
+    const rangeToExtract = getRangeToExtract2(context.file, getRefactorContextSpan(context));
+    const targetRange = rangeToExtract.targetRange;
+    const parsedFunctionIndexMatch = /^function_scope_(\d+)$/.exec(actionName2);
+    if (parsedFunctionIndexMatch) {
+      const index = +parsedFunctionIndexMatch[1];
+      Debug.assert(isFinite(index), "Expected to parse a finite number from the function scope index");
+      return getFunctionExtractionAtIndex(targetRange, context, index);
+    }
+    const parsedConstantIndexMatch = /^constant_scope_(\d+)$/.exec(actionName2);
+    if (parsedConstantIndexMatch) {
+      const index = +parsedConstantIndexMatch[1];
+      Debug.assert(isFinite(index), "Expected to parse a finite number from the constant scope index");
+      return getConstantExtractionAtIndex(targetRange, context, index);
     }
+    Debug.fail("Unrecognized action name");
   }
-  function getNewStatementsAndRemoveFromOldFile2(oldFile, targetFile, usage, changes, toMove, program, host, preferences, importAdder) {
-    const checker = program.getTypeChecker();
-    const prologueDirectives = takeWhile(oldFile.statements, isPrologueDirective);
-    if (oldFile.externalModuleIndicator === void 0 && oldFile.commonJsModuleIndicator === void 0 && usage.oldImportsNeededByTargetFile.size === 0 && usage.targetFileImportsFromOldFile.size === 0 && typeof targetFile === "string") {
-      deleteMovedStatements(oldFile, toMove.ranges, changes);
-      return [...prologueDirectives, ...toMove.all];
+  function getRangeToExtract2(sourceFile, span, invoked = true) {
+    const { length: length2 } = span;
+    if (length2 === 0 && !invoked) {
+      return { errors: [createFileDiagnostic(sourceFile, span.start, length2, Messages.cannotExtractEmpty)] };
     }
-    const targetFileName = typeof targetFile === "string" ? targetFile : targetFile.fileName;
-    const useEsModuleSyntax = !fileShouldUseJavaScriptRequire(targetFileName, program, host, !!oldFile.commonJsModuleIndicator);
-    const quotePreference = getQuotePreference(oldFile, preferences);
-    const importsFromTargetFile = createOldFileImportsFromTargetFile(oldFile, usage.oldFileImportsFromTargetFile, targetFileName, program, host, useEsModuleSyntax, quotePreference);
-    if (importsFromTargetFile) {
-      insertImports(
-        changes,
-        oldFile,
-        importsFromTargetFile,
-        /*blankLineBetween*/
-        true,
-        preferences
-      );
+    const cursorRequest = length2 === 0 && invoked;
+    const startToken = findFirstNonJsxWhitespaceToken(sourceFile, span.start);
+    const endToken = findTokenOnLeftOfPosition(sourceFile, textSpanEnd(span));
+    const adjustedSpan = startToken && endToken && invoked ? getAdjustedSpanFromNodes(startToken, endToken, sourceFile) : span;
+    const start = cursorRequest ? getExtractableParent(startToken) : getParentNodeInSpan(startToken, sourceFile, adjustedSpan);
+    const end = cursorRequest ? start : getParentNodeInSpan(endToken, sourceFile, adjustedSpan);
+    let rangeFacts = 0 /* None */;
+    let thisNode;
+    if (!start || !end) {
+      return { errors: [createFileDiagnostic(sourceFile, span.start, length2, Messages.cannotExtractRange)] };
     }
-    deleteUnusedOldImports(oldFile, toMove.all, changes, usage.unusedImportsFromOldFile, checker);
-    deleteMovedStatements(oldFile, toMove.ranges, changes);
-    updateImportsInOtherFiles(changes, program, host, oldFile, usage.movedSymbols, targetFileName, quotePreference);
-    const imports = getTargetFileImportsAndAddExportInOldFile(oldFile, targetFileName, usage.oldImportsNeededByTargetFile, usage.targetFileImportsFromOldFile, changes, checker, program, host, useEsModuleSyntax, quotePreference, importAdder);
-    const body = addExports(oldFile, toMove.all, usage.oldFileImportsFromTargetFile, useEsModuleSyntax);
-    if (typeof targetFile !== "string") {
-      if (targetFile.statements.length > 0) {
-        changes.insertNodesAfter(targetFile, targetFile.statements[targetFile.statements.length - 1], body);
-      } else {
-        changes.insertNodesAtEndOfFile(
-          targetFile,
-          body,
-          /*blankLineBetween*/
-          false
-        );
+    if (start.flags & 16777216 /* JSDoc */) {
+      return { errors: [createFileDiagnostic(sourceFile, span.start, length2, Messages.cannotExtractJSDoc)] };
+    }
+    if (start.parent !== end.parent) {
+      return { errors: [createFileDiagnostic(sourceFile, span.start, length2, Messages.cannotExtractRange)] };
+    }
+    if (start !== end) {
+      if (!isBlockLike(start.parent)) {
+        return { errors: [createFileDiagnostic(sourceFile, span.start, length2, Messages.cannotExtractRange)] };
       }
-      if (imports.length > 0) {
-        insertImports(
-          changes,
-          targetFile,
-          imports,
-          /*blankLineBetween*/
-          true,
-          preferences
-        );
+      const statements = [];
+      for (const statement of start.parent.statements) {
+        if (statement === start || statements.length) {
+          const errors2 = checkNode(statement);
+          if (errors2) {
+            return { errors: errors2 };
+          }
+          statements.push(statement);
+        }
+        if (statement === end) {
+          break;
+        }
       }
+      if (!statements.length) {
+        return { errors: [createFileDiagnostic(sourceFile, span.start, length2, Messages.cannotExtractRange)] };
+      }
+      return { targetRange: { range: statements, facts: rangeFacts, thisNode } };
     }
-    if (importAdder) {
-      importAdder.writeFixes(changes);
+    if (isReturnStatement(start) && !start.expression) {
+      return { errors: [createFileDiagnostic(sourceFile, span.start, length2, Messages.cannotExtractRange)] };
     }
-    if (imports.length && body.length) {
-      return [
-        ...prologueDirectives,
-        ...imports,
-        4 /* NewLineTrivia */,
-        ...body
-      ];
+    const node = refineNode(start);
+    const errors = checkRootNode(node) || checkNode(node);
+    if (errors) {
+      return { errors };
     }
-    return [
-      ...prologueDirectives,
-      ...imports,
-      ...body
-    ];
-  }
-  function getTargetFileImportsAndAddExportInOldFile(oldFile, targetFile, importsToCopy, targetFileImportsFromOldFile, changes, checker, program, host, useEsModuleSyntax, quotePreference, importAdder) {
-    const copiedOldImports = [];
-    if (importAdder) {
-      importsToCopy.forEach((isValidTypeOnlyUseSite, symbol) => {
-        try {
-          importAdder.addImportFromExportedSymbol(skipAlias(symbol, checker), isValidTypeOnlyUseSite);
-        } catch {
-          for (const oldStatement of oldFile.statements) {
-            forEachImportInStatement(oldStatement, (i) => {
-              append(copiedOldImports, filterImport(i, factory.createStringLiteral(moduleSpecifierFromImport(i).text), (name) => importsToCopy.has(checker.getSymbolAtLocation(name))));
-            });
+    return { targetRange: { range: getStatementOrExpressionRange(node), facts: rangeFacts, thisNode } };
+    function refineNode(node2) {
+      if (isReturnStatement(node2)) {
+        if (node2.expression) {
+          return node2.expression;
+        }
+      } else if (isVariableStatement(node2) || isVariableDeclarationList(node2)) {
+        const declarations = isVariableStatement(node2) ? node2.declarationList.declarations : node2.declarations;
+        let numInitializers = 0;
+        let lastInitializer;
+        for (const declaration of declarations) {
+          if (declaration.initializer) {
+            numInitializers++;
+            lastInitializer = declaration.initializer;
           }
         }
-      });
-    } else {
-      const targetSourceFile = program.getSourceFile(targetFile);
-      for (const oldStatement of oldFile.statements) {
-        forEachImportInStatement(oldStatement, (i) => {
-          var _a, _b;
-          const moduleSpecifier = moduleSpecifierFromImport(i);
-          const resolved = (_a = oldFile.resolvedModules) == null ? void 0 : _a.get(moduleSpecifier.text, getModeForUsageLocation(oldFile, moduleSpecifier));
-          const fileName = (_b = resolved == null ? void 0 : resolved.resolvedModule) == null ? void 0 : _b.resolvedFileName;
-          if (fileName && targetSourceFile) {
-            const newModuleSpecifier = getModuleSpecifier(program.getCompilerOptions(), targetSourceFile, targetSourceFile.path, fileName, createModuleSpecifierResolutionHost(program, host));
-            append(copiedOldImports, filterImport(i, makeStringLiteral(newModuleSpecifier, quotePreference), (name) => importsToCopy.has(checker.getSymbolAtLocation(name))));
-          } else {
-            append(copiedOldImports, filterImport(i, factory.createStringLiteral(moduleSpecifierFromImport(i).text), (name) => importsToCopy.has(checker.getSymbolAtLocation(name))));
+        if (numInitializers === 1) {
+          return lastInitializer;
+        }
+      } else if (isVariableDeclaration(node2)) {
+        if (node2.initializer) {
+          return node2.initializer;
+        }
+      }
+      return node2;
+    }
+    function checkRootNode(node2) {
+      if (isIdentifier(isExpressionStatement(node2) ? node2.expression : node2)) {
+        return [createDiagnosticForNode(node2, Messages.cannotExtractIdentifier)];
+      }
+      return void 0;
+    }
+    function checkForStaticContext(nodeToCheck, containingClass) {
+      let current = nodeToCheck;
+      while (current !== containingClass) {
+        if (current.kind === 172 /* PropertyDeclaration */) {
+          if (isStatic(current)) {
+            rangeFacts |= 32 /* InStaticRegion */;
           }
-        });
+          break;
+        } else if (current.kind === 169 /* Parameter */) {
+          const ctorOrMethod = getContainingFunction(current);
+          if (ctorOrMethod.kind === 176 /* Constructor */) {
+            rangeFacts |= 32 /* InStaticRegion */;
+          }
+          break;
+        } else if (current.kind === 174 /* MethodDeclaration */) {
+          if (isStatic(current)) {
+            rangeFacts |= 32 /* InStaticRegion */;
+          }
+        }
+        current = current.parent;
       }
     }
-    const targetFileSourceFile = program.getSourceFile(targetFile);
-    let oldFileDefault;
-    const oldFileNamedImports = [];
-    const markSeenTop = nodeSeenTracker();
-    targetFileImportsFromOldFile.forEach((symbol) => {
-      if (!symbol.declarations) {
-        return;
+    function checkNode(nodeToCheck) {
+      let PermittedJumps;
+      ((PermittedJumps2) => {
+        PermittedJumps2[PermittedJumps2["None"] = 0] = "None";
+        PermittedJumps2[PermittedJumps2["Break"] = 1] = "Break";
+        PermittedJumps2[PermittedJumps2["Continue"] = 2] = "Continue";
+        PermittedJumps2[PermittedJumps2["Return"] = 4] = "Return";
+      })(PermittedJumps || (PermittedJumps = {}));
+      Debug.assert(nodeToCheck.pos <= nodeToCheck.end, "This failure could trigger https://github.com/Microsoft/TypeScript/issues/20809 (1)");
+      Debug.assert(!positionIsSynthesized(nodeToCheck.pos), "This failure could trigger https://github.com/Microsoft/TypeScript/issues/20809 (2)");
+      if (!isStatement(nodeToCheck) && !(isExpressionNode(nodeToCheck) && isExtractableExpression(nodeToCheck)) && !isStringLiteralJsxAttribute(nodeToCheck)) {
+        return [createDiagnosticForNode(nodeToCheck, Messages.statementOrExpressionExpected)];
       }
-      for (const decl of symbol.declarations) {
-        if (!isTopLevelDeclaration(decl))
-          continue;
-        const name = nameOfTopLevelDeclaration(decl);
-        if (!name)
-          continue;
-        const top = getTopLevelDeclarationStatement(decl);
-        if (markSeenTop(top)) {
-          addExportToChanges(oldFile, top, name, changes, useEsModuleSyntax);
+      if (nodeToCheck.flags & 33554432 /* Ambient */) {
+        return [createDiagnosticForNode(nodeToCheck, Messages.cannotExtractAmbientBlock)];
+      }
+      const containingClass = getContainingClass(nodeToCheck);
+      if (containingClass) {
+        checkForStaticContext(nodeToCheck, containingClass);
+      }
+      let errors2;
+      let permittedJumps = 4 /* Return */;
+      let seenLabels;
+      visit(nodeToCheck);
+      if (rangeFacts & 8 /* UsesThis */) {
+        const container = getThisContainer(
+          nodeToCheck,
+          /*includeArrowFunctions*/
+          false,
+          /*includeClassComputedPropertyName*/
+          false
+        );
+        if (container.kind === 262 /* FunctionDeclaration */ || container.kind === 174 /* MethodDeclaration */ && container.parent.kind === 210 /* ObjectLiteralExpression */ || container.kind === 218 /* FunctionExpression */) {
+          rangeFacts |= 16 /* UsesThisInFunction */;
         }
-        if (importAdder && checker.isUnknownSymbol(symbol)) {
-          importAdder.addImportFromExportedSymbol(skipAlias(symbol, checker));
-        } else {
-          if (hasSyntacticModifier(decl, 1024 /* Default */)) {
-            oldFileDefault = name;
-          } else {
-            oldFileNamedImports.push(name.text);
+      }
+      return errors2;
+      function visit(node2) {
+        if (errors2) {
+          return true;
+        }
+        if (isDeclaration(node2)) {
+          const declaringNode = node2.kind === 260 /* VariableDeclaration */ ? node2.parent.parent : node2;
+          if (hasSyntacticModifier(declaringNode, 32 /* Export */)) {
+            (errors2 || (errors2 = [])).push(createDiagnosticForNode(node2, Messages.cannotExtractExportedEntity));
+            return true;
+          }
+        }
+        switch (node2.kind) {
+          case 272 /* ImportDeclaration */:
+            (errors2 || (errors2 = [])).push(createDiagnosticForNode(node2, Messages.cannotExtractImport));
+            return true;
+          case 277 /* ExportAssignment */:
+            (errors2 || (errors2 = [])).push(createDiagnosticForNode(node2, Messages.cannotExtractExportedEntity));
+            return true;
+          case 108 /* SuperKeyword */:
+            if (node2.parent.kind === 213 /* CallExpression */) {
+              const containingClass2 = getContainingClass(node2);
+              if (containingClass2 === void 0 || containingClass2.pos < span.start || containingClass2.end >= span.start + span.length) {
+                (errors2 || (errors2 = [])).push(createDiagnosticForNode(node2, Messages.cannotExtractSuper));
+                return true;
+              }
+            } else {
+              rangeFacts |= 8 /* UsesThis */;
+              thisNode = node2;
+            }
+            break;
+          case 219 /* ArrowFunction */:
+            forEachChild(node2, function check(n) {
+              if (isThis(n)) {
+                rangeFacts |= 8 /* UsesThis */;
+                thisNode = node2;
+              } else if (isClassLike(n) || isFunctionLike(n) && !isArrowFunction(n)) {
+                return false;
+              } else {
+                forEachChild(n, check);
+              }
+            });
+          case 263 /* ClassDeclaration */:
+          case 262 /* FunctionDeclaration */:
+            if (isSourceFile(node2.parent) && node2.parent.externalModuleIndicator === void 0) {
+              (errors2 || (errors2 = [])).push(createDiagnosticForNode(node2, Messages.functionWillNotBeVisibleInTheNewScope));
+            }
+          case 231 /* ClassExpression */:
+          case 218 /* FunctionExpression */:
+          case 174 /* MethodDeclaration */:
+          case 176 /* Constructor */:
+          case 177 /* GetAccessor */:
+          case 178 /* SetAccessor */:
+            return false;
+        }
+        const savedPermittedJumps = permittedJumps;
+        switch (node2.kind) {
+          case 245 /* IfStatement */:
+            permittedJumps &= ~4 /* Return */;
+            break;
+          case 258 /* TryStatement */:
+            permittedJumps = 0 /* None */;
+            break;
+          case 241 /* Block */:
+            if (node2.parent && node2.parent.kind === 258 /* TryStatement */ && node2.parent.finallyBlock === node2) {
+              permittedJumps = 4 /* Return */;
+            }
+            break;
+          case 297 /* DefaultClause */:
+          case 296 /* CaseClause */:
+            permittedJumps |= 1 /* Break */;
+            break;
+          default:
+            if (isIterationStatement(
+              node2,
+              /*lookInLabeledStatements*/
+              false
+            )) {
+              permittedJumps |= 1 /* Break */ | 2 /* Continue */;
+            }
+            break;
+        }
+        switch (node2.kind) {
+          case 197 /* ThisType */:
+          case 110 /* ThisKeyword */:
+            rangeFacts |= 8 /* UsesThis */;
+            thisNode = node2;
+            break;
+          case 256 /* LabeledStatement */: {
+            const label = node2.label;
+            (seenLabels || (seenLabels = [])).push(label.escapedText);
+            forEachChild(node2, visit);
+            seenLabels.pop();
+            break;
+          }
+          case 252 /* BreakStatement */:
+          case 251 /* ContinueStatement */: {
+            const label = node2.label;
+            if (label) {
+              if (!contains(seenLabels, label.escapedText)) {
+                (errors2 || (errors2 = [])).push(createDiagnosticForNode(node2, Messages.cannotExtractRangeContainingLabeledBreakOrContinueStatementWithTargetOutsideOfTheRange));
+              }
+            } else {
+              if (!(permittedJumps & (node2.kind === 252 /* BreakStatement */ ? 1 /* Break */ : 2 /* Continue */))) {
+                (errors2 || (errors2 = [])).push(createDiagnosticForNode(node2, Messages.cannotExtractRangeContainingConditionalBreakOrContinueStatements));
+              }
+            }
+            break;
           }
+          case 223 /* AwaitExpression */:
+            rangeFacts |= 4 /* IsAsyncFunction */;
+            break;
+          case 229 /* YieldExpression */:
+            rangeFacts |= 2 /* IsGenerator */;
+            break;
+          case 253 /* ReturnStatement */:
+            if (permittedJumps & 4 /* Return */) {
+              rangeFacts |= 1 /* HasReturn */;
+            } else {
+              (errors2 || (errors2 = [])).push(createDiagnosticForNode(node2, Messages.cannotExtractRangeContainingConditionalReturnStatement));
+            }
+            break;
+          default:
+            forEachChild(node2, visit);
+            break;
         }
+        permittedJumps = savedPermittedJumps;
       }
-    });
-    return targetFileSourceFile ? append(copiedOldImports, makeImportOrRequire(targetFileSourceFile, oldFileDefault, oldFileNamedImports, oldFile.fileName, program, host, useEsModuleSyntax, quotePreference)) : append(copiedOldImports, makeImportOrRequire(oldFile, oldFileDefault, oldFileNamedImports, oldFile.fileName, program, host, useEsModuleSyntax, quotePreference));
-  }
-  function addNewFileToTsconfig(program, changes, oldFileName, newFileNameWithExtension, getCanonicalFileName) {
-    const cfg = program.getCompilerOptions().configFile;
-    if (!cfg)
-      return;
-    const newFileAbsolutePath = normalizePath(combinePaths(oldFileName, "..", newFileNameWithExtension));
-    const newFilePath = getRelativePathFromFile(cfg.fileName, newFileAbsolutePath, getCanonicalFileName);
-    const cfgObject = cfg.statements[0] && tryCast(cfg.statements[0].expression, isObjectLiteralExpression);
-    const filesProp = cfgObject && find(cfgObject.properties, (prop) => isPropertyAssignment(prop) && isStringLiteral(prop.name) && prop.name.text === "files");
-    if (filesProp && isArrayLiteralExpression(filesProp.initializer)) {
-      changes.insertNodeInListAfter(cfg, last(filesProp.initializer.elements), factory.createStringLiteral(newFilePath), filesProp.initializer.elements);
     }
   }
-  function deleteMovedStatements(sourceFile, moved, changes) {
-    for (const { first: first2, afterLast } of moved) {
-      changes.deleteNodeRangeExcludingEnd(sourceFile, first2, afterLast);
+  function getAdjustedSpanFromNodes(startNode2, endNode2, sourceFile) {
+    const start = startNode2.getStart(sourceFile);
+    let end = endNode2.getEnd();
+    if (sourceFile.text.charCodeAt(end) === 59 /* semicolon */) {
+      end++;
     }
+    return { start, length: end - start };
   }
-  function deleteUnusedOldImports(oldFile, toMove, changes, toDelete, checker) {
-    for (const statement of oldFile.statements) {
-      if (contains(toMove, statement))
-        continue;
-      forEachImportInStatement(statement, (i) => deleteUnusedImports(oldFile, i, changes, (name) => toDelete.has(checker.getSymbolAtLocation(name))));
+  function getStatementOrExpressionRange(node) {
+    if (isStatement(node)) {
+      return [node];
+    }
+    if (isExpressionNode(node)) {
+      return isExpressionStatement(node.parent) ? [node.parent] : node;
+    }
+    if (isStringLiteralJsxAttribute(node)) {
+      return node;
     }
+    return void 0;
   }
-  function updateImportsInOtherFiles(changes, program, host, oldFile, movedSymbols, targetFileName, quotePreference) {
-    const checker = program.getTypeChecker();
-    for (const sourceFile of program.getSourceFiles()) {
-      if (sourceFile === oldFile)
-        continue;
-      for (const statement of sourceFile.statements) {
-        forEachImportInStatement(statement, (importNode) => {
-          if (checker.getSymbolAtLocation(moduleSpecifierFromImport(importNode)) !== oldFile.symbol)
-            return;
-          const shouldMove = (name) => {
-            const symbol = isBindingElement(name.parent) ? getPropertySymbolFromBindingElement(checker, name.parent) : skipAlias(checker.getSymbolAtLocation(name), checker);
-            return !!symbol && movedSymbols.has(symbol);
-          };
-          deleteUnusedImports(sourceFile, importNode, changes, shouldMove);
-          const pathToTargetFileWithExtension = resolvePath(getDirectoryPath(oldFile.path), targetFileName);
-          const newModuleSpecifier = getModuleSpecifier(program.getCompilerOptions(), sourceFile, sourceFile.path, pathToTargetFileWithExtension, createModuleSpecifierResolutionHost(program, host));
-          const newImportDeclaration = filterImport(importNode, makeStringLiteral(newModuleSpecifier, quotePreference), shouldMove);
-          if (newImportDeclaration)
-            changes.insertNodeAfter(sourceFile, statement, newImportDeclaration);
-          const ns = getNamespaceLikeImport(importNode);
-          if (ns)
-            updateNamespaceLikeImport(changes, sourceFile, checker, movedSymbols, newModuleSpecifier, ns, importNode, quotePreference);
-        });
+  function isScope(node) {
+    return isArrowFunction(node) ? isFunctionBody(node.body) : isFunctionLikeDeclaration(node) || isSourceFile(node) || isModuleBlock(node) || isClassLike(node);
+  }
+  function collectEnclosingScopes(range) {
+    let current = isReadonlyArray(range.range) ? first(range.range) : range.range;
+    if (range.facts & 8 /* UsesThis */ && !(range.facts & 16 /* UsesThisInFunction */)) {
+      const containingClass = getContainingClass(current);
+      if (containingClass) {
+        const containingFunction = findAncestor(current, isFunctionLikeDeclaration);
+        return containingFunction ? [containingFunction, containingClass] : [containingClass];
+      }
+    }
+    const scopes = [];
+    while (true) {
+      current = current.parent;
+      if (current.kind === 169 /* Parameter */) {
+        current = findAncestor(current, (parent2) => isFunctionLikeDeclaration(parent2)).parent;
+      }
+      if (isScope(current)) {
+        scopes.push(current);
+        if (current.kind === 312 /* SourceFile */) {
+          return scopes;
+        }
       }
     }
   }
-  function getNamespaceLikeImport(node) {
-    switch (node.kind) {
-      case 271 /* ImportDeclaration */:
-        return node.importClause && node.importClause.namedBindings && node.importClause.namedBindings.kind === 273 /* NamespaceImport */ ? node.importClause.namedBindings.name : void 0;
-      case 270 /* ImportEqualsDeclaration */:
-        return node.name;
-      case 259 /* VariableDeclaration */:
-        return tryCast(node.name, isIdentifier);
+  function getFunctionExtractionAtIndex(targetRange, context, requestedChangesIndex) {
+    const { scopes, readsAndWrites: { target, usagesPerScope, functionErrorsPerScope, exposedVariableDeclarations } } = getPossibleExtractionsWorker(targetRange, context);
+    Debug.assert(!functionErrorsPerScope[requestedChangesIndex].length, "The extraction went missing? How?");
+    context.cancellationToken.throwIfCancellationRequested();
+    return extractFunctionInScope(target, scopes[requestedChangesIndex], usagesPerScope[requestedChangesIndex], exposedVariableDeclarations, targetRange, context);
+  }
+  function getConstantExtractionAtIndex(targetRange, context, requestedChangesIndex) {
+    const { scopes, readsAndWrites: { target, usagesPerScope, constantErrorsPerScope, exposedVariableDeclarations } } = getPossibleExtractionsWorker(targetRange, context);
+    Debug.assert(!constantErrorsPerScope[requestedChangesIndex].length, "The extraction went missing? How?");
+    Debug.assert(exposedVariableDeclarations.length === 0, "Extract constant accepted a range containing a variable declaration?");
+    context.cancellationToken.throwIfCancellationRequested();
+    const expression = isExpression(target) ? target : target.statements[0].expression;
+    return extractConstantInScope(expression, scopes[requestedChangesIndex], usagesPerScope[requestedChangesIndex], targetRange.facts, context);
+  }
+  function getPossibleExtractions(targetRange, context) {
+    const { scopes, readsAndWrites: { functionErrorsPerScope, constantErrorsPerScope } } = getPossibleExtractionsWorker(targetRange, context);
+    const extractions = scopes.map((scope, i) => {
+      const functionDescriptionPart = getDescriptionForFunctionInScope(scope);
+      const constantDescriptionPart = getDescriptionForConstantInScope(scope);
+      const scopeDescription = isFunctionLikeDeclaration(scope) ? getDescriptionForFunctionLikeDeclaration(scope) : isClassLike(scope) ? getDescriptionForClassLikeDeclaration(scope) : getDescriptionForModuleLikeDeclaration(scope);
+      let functionDescription;
+      let constantDescription;
+      if (scopeDescription === 1 /* Global */) {
+        functionDescription = formatStringFromArgs(getLocaleSpecificMessage(Diagnostics.Extract_to_0_in_1_scope), [functionDescriptionPart, "global"]);
+        constantDescription = formatStringFromArgs(getLocaleSpecificMessage(Diagnostics.Extract_to_0_in_1_scope), [constantDescriptionPart, "global"]);
+      } else if (scopeDescription === 0 /* Module */) {
+        functionDescription = formatStringFromArgs(getLocaleSpecificMessage(Diagnostics.Extract_to_0_in_1_scope), [functionDescriptionPart, "module"]);
+        constantDescription = formatStringFromArgs(getLocaleSpecificMessage(Diagnostics.Extract_to_0_in_1_scope), [constantDescriptionPart, "module"]);
+      } else {
+        functionDescription = formatStringFromArgs(getLocaleSpecificMessage(Diagnostics.Extract_to_0_in_1), [functionDescriptionPart, scopeDescription]);
+        constantDescription = formatStringFromArgs(getLocaleSpecificMessage(Diagnostics.Extract_to_0_in_1), [constantDescriptionPart, scopeDescription]);
+      }
+      if (i === 0 && !isClassLike(scope)) {
+        constantDescription = formatStringFromArgs(getLocaleSpecificMessage(Diagnostics.Extract_to_0_in_enclosing_scope), [constantDescriptionPart]);
+      }
+      return {
+        functionExtraction: {
+          description: functionDescription,
+          errors: functionErrorsPerScope[i]
+        },
+        constantExtraction: {
+          description: constantDescription,
+          errors: constantErrorsPerScope[i]
+        }
+      };
+    });
+    return extractions;
+  }
+  function getPossibleExtractionsWorker(targetRange, context) {
+    const { file: sourceFile } = context;
+    const scopes = collectEnclosingScopes(targetRange);
+    const enclosingTextRange = getEnclosingTextRange(targetRange, sourceFile);
+    const readsAndWrites = collectReadsAndWrites(
+      targetRange,
+      scopes,
+      enclosingTextRange,
+      sourceFile,
+      context.program.getTypeChecker(),
+      context.cancellationToken
+    );
+    return { scopes, readsAndWrites };
+  }
+  function getDescriptionForFunctionInScope(scope) {
+    return isFunctionLikeDeclaration(scope) ? "inner function" : isClassLike(scope) ? "method" : "function";
+  }
+  function getDescriptionForConstantInScope(scope) {
+    return isClassLike(scope) ? "readonly field" : "constant";
+  }
+  function getDescriptionForFunctionLikeDeclaration(scope) {
+    switch (scope.kind) {
+      case 176 /* Constructor */:
+        return "constructor";
+      case 218 /* FunctionExpression */:
+      case 262 /* FunctionDeclaration */:
+        return scope.name ? `function '${scope.name.text}'` : ANONYMOUS;
+      case 219 /* ArrowFunction */:
+        return "arrow function";
+      case 174 /* MethodDeclaration */:
+        return `method '${scope.name.getText()}'`;
+      case 177 /* GetAccessor */:
+        return `'get ${scope.name.getText()}'`;
+      case 178 /* SetAccessor */:
+        return `'set ${scope.name.getText()}'`;
       default:
-        return Debug.assertNever(node, `Unexpected node kind ${node.kind}`);
+        Debug.assertNever(scope, `Unexpected scope kind ${scope.kind}`);
     }
   }
-  function updateNamespaceLikeImport(changes, sourceFile, checker, movedSymbols, newModuleSpecifier, oldImportId, oldImportNode, quotePreference) {
-    const preferredNewNamespaceName = ts_codefix_exports.moduleSpecifierToValidIdentifier(newModuleSpecifier, 99 /* ESNext */);
-    let needUniqueName = false;
-    const toChange = [];
-    ts_FindAllReferences_exports.Core.eachSymbolReferenceInFile(oldImportId, checker, sourceFile, (ref) => {
-      if (!isPropertyAccessExpression(ref.parent))
-        return;
-      needUniqueName = needUniqueName || !!checker.resolveName(
-        preferredNewNamespaceName,
-        ref,
-        67108863 /* All */,
-        /*excludeGlobals*/
-        true
+  function getDescriptionForClassLikeDeclaration(scope) {
+    return scope.kind === 263 /* ClassDeclaration */ ? scope.name ? `class '${scope.name.text}'` : "anonymous class declaration" : scope.name ? `class expression '${scope.name.text}'` : "anonymous class expression";
+  }
+  function getDescriptionForModuleLikeDeclaration(scope) {
+    return scope.kind === 268 /* ModuleBlock */ ? `namespace '${scope.parent.name.getText()}'` : scope.externalModuleIndicator ? 0 /* Module */ : 1 /* Global */;
+  }
+  function extractFunctionInScope(node, scope, { usages: usagesInScope, typeParameterUsages, substitutions }, exposedVariableDeclarations, range, context) {
+    const checker = context.program.getTypeChecker();
+    const scriptTarget = getEmitScriptTarget(context.program.getCompilerOptions());
+    const importAdder = ts_codefix_exports.createImportAdder(context.file, context.program, context.preferences, context.host);
+    const file = scope.getSourceFile();
+    const functionNameText = getUniqueName(isClassLike(scope) ? "newMethod" : "newFunction", file);
+    const isJS = isInJSFile(scope);
+    const functionName = factory.createIdentifier(functionNameText);
+    let returnType;
+    const parameters = [];
+    const callArguments = [];
+    let writes;
+    usagesInScope.forEach((usage, name) => {
+      let typeNode;
+      if (!isJS) {
+        let type = checker.getTypeOfSymbolAtLocation(usage.symbol, usage.node);
+        type = checker.getBaseTypeOfLiteralType(type);
+        typeNode = ts_codefix_exports.typeToAutoImportableTypeNode(checker, importAdder, type, scope, scriptTarget, 1 /* NoTruncation */);
+      }
+      const paramDecl = factory.createParameterDeclaration(
+        /*modifiers*/
+        void 0,
+        /*dotDotDotToken*/
+        void 0,
+        /*name*/
+        name,
+        /*questionToken*/
+        void 0,
+        typeNode
       );
-      if (movedSymbols.has(checker.getSymbolAtLocation(ref.parent.name))) {
-        toChange.push(ref);
+      parameters.push(paramDecl);
+      if (usage.usage === 2 /* Write */) {
+        (writes || (writes = [])).push(usage);
       }
+      callArguments.push(factory.createIdentifier(name));
     });
-    if (toChange.length) {
-      const newNamespaceName = needUniqueName ? getUniqueName(preferredNewNamespaceName, sourceFile) : preferredNewNamespaceName;
-      for (const ref of toChange) {
-        changes.replaceNode(sourceFile, ref, factory.createIdentifier(newNamespaceName));
+    const typeParametersAndDeclarations = arrayFrom(typeParameterUsages.values(), (type) => ({ type, declaration: getFirstDeclarationBeforePosition(type, context.startPosition) }));
+    const sortedTypeParametersAndDeclarations = typeParametersAndDeclarations.sort(compareTypesByDeclarationOrder);
+    const typeParameters = sortedTypeParametersAndDeclarations.length === 0 ? void 0 : mapDefined(sortedTypeParametersAndDeclarations, ({ declaration }) => declaration);
+    const callTypeArguments = typeParameters !== void 0 ? typeParameters.map((decl) => factory.createTypeReferenceNode(
+      decl.name,
+      /*typeArguments*/
+      void 0
+    )) : void 0;
+    if (isExpression(node) && !isJS) {
+      const contextualType = checker.getContextualType(node);
+      returnType = checker.typeToTypeNode(contextualType, scope, 1 /* NoTruncation */);
+    }
+    const { body, returnValueProperty } = transformFunctionBody(node, exposedVariableDeclarations, writes, substitutions, !!(range.facts & 1 /* HasReturn */));
+    suppressLeadingAndTrailingTrivia(body);
+    let newFunction;
+    const callThis = !!(range.facts & 16 /* UsesThisInFunction */);
+    if (isClassLike(scope)) {
+      const modifiers = isJS ? [] : [factory.createModifier(123 /* PrivateKeyword */)];
+      if (range.facts & 32 /* InStaticRegion */) {
+        modifiers.push(factory.createModifier(126 /* StaticKeyword */));
       }
-      changes.insertNodeAfter(sourceFile, oldImportNode, updateNamespaceLikeImportNode(oldImportNode, preferredNewNamespaceName, newModuleSpecifier, quotePreference));
+      if (range.facts & 4 /* IsAsyncFunction */) {
+        modifiers.push(factory.createModifier(134 /* AsyncKeyword */));
+      }
+      newFunction = factory.createMethodDeclaration(
+        modifiers.length ? modifiers : void 0,
+        range.facts & 2 /* IsGenerator */ ? factory.createToken(42 /* AsteriskToken */) : void 0,
+        functionName,
+        /*questionToken*/
+        void 0,
+        typeParameters,
+        parameters,
+        returnType,
+        body
+      );
+    } else {
+      if (callThis) {
+        parameters.unshift(
+          factory.createParameterDeclaration(
+            /*modifiers*/
+            void 0,
+            /*dotDotDotToken*/
+            void 0,
+            /*name*/
+            "this",
+            /*questionToken*/
+            void 0,
+            checker.typeToTypeNode(
+              checker.getTypeAtLocation(range.thisNode),
+              scope,
+              1 /* NoTruncation */
+            ),
+            /*initializer*/
+            void 0
+          )
+        );
+      }
+      newFunction = factory.createFunctionDeclaration(
+        range.facts & 4 /* IsAsyncFunction */ ? [factory.createToken(134 /* AsyncKeyword */)] : void 0,
+        range.facts & 2 /* IsGenerator */ ? factory.createToken(42 /* AsteriskToken */) : void 0,
+        functionName,
+        typeParameters,
+        parameters,
+        returnType,
+        body
+      );
     }
-  }
-  function updateNamespaceLikeImportNode(node, newNamespaceName, newModuleSpecifier, quotePreference) {
-    const newNamespaceId = factory.createIdentifier(newNamespaceName);
-    const newModuleString = makeStringLiteral(newModuleSpecifier, quotePreference);
-    switch (node.kind) {
-      case 271 /* ImportDeclaration */:
-        return factory.createImportDeclaration(
+    const changeTracker = ts_textChanges_exports.ChangeTracker.fromContext(context);
+    const minInsertionPos = (isReadonlyArray(range.range) ? last(range.range) : range.range).end;
+    const nodeToInsertBefore = getNodeToInsertFunctionBefore(minInsertionPos, scope);
+    if (nodeToInsertBefore) {
+      changeTracker.insertNodeBefore(
+        context.file,
+        nodeToInsertBefore,
+        newFunction,
+        /*blankLineBetween*/
+        true
+      );
+    } else {
+      changeTracker.insertNodeAtEndOfScope(context.file, scope, newFunction);
+    }
+    importAdder.writeFixes(changeTracker);
+    const newNodes = [];
+    const called = getCalledExpression(scope, range, functionNameText);
+    if (callThis) {
+      callArguments.unshift(factory.createIdentifier("this"));
+    }
+    let call = factory.createCallExpression(
+      callThis ? factory.createPropertyAccessExpression(
+        called,
+        "call"
+      ) : called,
+      callTypeArguments,
+      // Note that no attempt is made to take advantage of type argument inference
+      callArguments
+    );
+    if (range.facts & 2 /* IsGenerator */) {
+      call = factory.createYieldExpression(factory.createToken(42 /* AsteriskToken */), call);
+    }
+    if (range.facts & 4 /* IsAsyncFunction */) {
+      call = factory.createAwaitExpression(call);
+    }
+    if (isInJSXContent(node)) {
+      call = factory.createJsxExpression(
+        /*dotDotDotToken*/
+        void 0,
+        call
+      );
+    }
+    if (exposedVariableDeclarations.length && !writes) {
+      Debug.assert(!returnValueProperty, "Expected no returnValueProperty");
+      Debug.assert(!(range.facts & 1 /* HasReturn */), "Expected RangeFacts.HasReturn flag to be unset");
+      if (exposedVariableDeclarations.length === 1) {
+        const variableDeclaration = exposedVariableDeclarations[0];
+        newNodes.push(factory.createVariableStatement(
           /*modifiers*/
           void 0,
-          factory.createImportClause(
-            /*isTypeOnly*/
-            false,
+          factory.createVariableDeclarationList(
+            [factory.createVariableDeclaration(
+              getSynthesizedDeepClone(variableDeclaration.name),
+              /*exclamationToken*/
+              void 0,
+              /*type*/
+              getSynthesizedDeepClone(variableDeclaration.type),
+              /*initializer*/
+              call
+            )],
+            variableDeclaration.parent.flags
+          )
+        ));
+      } else {
+        const bindingElements = [];
+        const typeElements = [];
+        let commonNodeFlags = exposedVariableDeclarations[0].parent.flags;
+        let sawExplicitType = false;
+        for (const variableDeclaration of exposedVariableDeclarations) {
+          bindingElements.push(factory.createBindingElement(
+            /*dotDotDotToken*/
+            void 0,
+            /*propertyName*/
+            void 0,
             /*name*/
+            getSynthesizedDeepClone(variableDeclaration.name)
+          ));
+          const variableType = checker.typeToTypeNode(
+            checker.getBaseTypeOfLiteralType(checker.getTypeAtLocation(variableDeclaration)),
+            scope,
+            1 /* NoTruncation */
+          );
+          typeElements.push(factory.createPropertySignature(
+            /*modifiers*/
             void 0,
-            factory.createNamespaceImport(newNamespaceId)
-          ),
-          newModuleString,
-          /*assertClause*/
-          void 0
-        );
-      case 270 /* ImportEqualsDeclaration */:
-        return factory.createImportEqualsDeclaration(
+            /*name*/
+            variableDeclaration.symbol.name,
+            /*questionToken*/
+            void 0,
+            /*type*/
+            variableType
+          ));
+          sawExplicitType = sawExplicitType || variableDeclaration.type !== void 0;
+          commonNodeFlags = commonNodeFlags & variableDeclaration.parent.flags;
+        }
+        const typeLiteral = sawExplicitType ? factory.createTypeLiteralNode(typeElements) : void 0;
+        if (typeLiteral) {
+          setEmitFlags(typeLiteral, 1 /* SingleLine */);
+        }
+        newNodes.push(factory.createVariableStatement(
           /*modifiers*/
           void 0,
-          /*isTypeOnly*/
-          false,
-          newNamespaceId,
-          factory.createExternalModuleReference(newModuleString)
-        );
-      case 259 /* VariableDeclaration */:
-        return factory.createVariableDeclaration(
-          newNamespaceId,
-          /*exclamationToken*/
-          void 0,
-          /*type*/
+          factory.createVariableDeclarationList(
+            [factory.createVariableDeclaration(
+              factory.createObjectBindingPattern(bindingElements),
+              /*exclamationToken*/
+              void 0,
+              /*type*/
+              typeLiteral,
+              /*initializer*/
+              call
+            )],
+            commonNodeFlags
+          )
+        ));
+      }
+    } else if (exposedVariableDeclarations.length || writes) {
+      if (exposedVariableDeclarations.length) {
+        for (const variableDeclaration of exposedVariableDeclarations) {
+          let flags = variableDeclaration.parent.flags;
+          if (flags & 2 /* Const */) {
+            flags = flags & ~2 /* Const */ | 1 /* Let */;
+          }
+          newNodes.push(factory.createVariableStatement(
+            /*modifiers*/
+            void 0,
+            factory.createVariableDeclarationList(
+              [factory.createVariableDeclaration(
+                variableDeclaration.symbol.name,
+                /*exclamationToken*/
+                void 0,
+                getTypeDeepCloneUnionUndefined(variableDeclaration.type)
+              )],
+              flags
+            )
+          ));
+        }
+      }
+      if (returnValueProperty) {
+        newNodes.push(factory.createVariableStatement(
+          /*modifiers*/
           void 0,
-          createRequireCall(newModuleString)
-        );
-      default:
-        return Debug.assertNever(node, `Unexpected node kind ${node.kind}`);
-    }
-  }
-  function createRequireCall(moduleSpecifier) {
-    return factory.createCallExpression(
-      factory.createIdentifier("require"),
-      /*typeArguments*/
-      void 0,
-      [moduleSpecifier]
-    );
-  }
-  function moduleSpecifierFromImport(i) {
-    return i.kind === 271 /* ImportDeclaration */ ? i.moduleSpecifier : i.kind === 270 /* ImportEqualsDeclaration */ ? i.moduleReference.expression : i.initializer.arguments[0];
-  }
-  function forEachImportInStatement(statement, cb) {
-    if (isImportDeclaration(statement)) {
-      if (isStringLiteral(statement.moduleSpecifier))
-        cb(statement);
-    } else if (isImportEqualsDeclaration(statement)) {
-      if (isExternalModuleReference(statement.moduleReference) && isStringLiteralLike(statement.moduleReference.expression)) {
-        cb(statement);
+          factory.createVariableDeclarationList(
+            [factory.createVariableDeclaration(
+              returnValueProperty,
+              /*exclamationToken*/
+              void 0,
+              getTypeDeepCloneUnionUndefined(returnType)
+            )],
+            1 /* Let */
+          )
+        ));
       }
-    } else if (isVariableStatement(statement)) {
-      for (const decl of statement.declarationList.declarations) {
-        if (decl.initializer && isRequireCall(
-          decl.initializer,
-          /*requireStringLiteralLikeArgument*/
-          true
-        )) {
-          cb(decl);
+      const assignments = getPropertyAssignmentsForWritesAndVariableDeclarations(exposedVariableDeclarations, writes);
+      if (returnValueProperty) {
+        assignments.unshift(factory.createShorthandPropertyAssignment(returnValueProperty));
+      }
+      if (assignments.length === 1) {
+        Debug.assert(!returnValueProperty, "Shouldn't have returnValueProperty here");
+        newNodes.push(factory.createExpressionStatement(factory.createAssignment(assignments[0].name, call)));
+        if (range.facts & 1 /* HasReturn */) {
+          newNodes.push(factory.createReturnStatement());
+        }
+      } else {
+        newNodes.push(factory.createExpressionStatement(factory.createAssignment(factory.createObjectLiteralExpression(assignments), call)));
+        if (returnValueProperty) {
+          newNodes.push(factory.createReturnStatement(factory.createIdentifier(returnValueProperty)));
         }
       }
-    }
-  }
-  function createOldFileImportsFromTargetFile(sourceFile, targetFileNeedExport, targetFileNameWithExtension, program, host, useEs6Imports, quotePreference) {
-    let defaultImport;
-    const imports = [];
-    targetFileNeedExport.forEach((symbol) => {
-      if (symbol.escapedName === "default" /* Default */) {
-        defaultImport = factory.createIdentifier(symbolNameNoDefault(symbol));
+    } else {
+      if (range.facts & 1 /* HasReturn */) {
+        newNodes.push(factory.createReturnStatement(call));
+      } else if (isReadonlyArray(range.range)) {
+        newNodes.push(factory.createExpressionStatement(call));
       } else {
-        imports.push(symbol.name);
+        newNodes.push(call);
       }
-    });
-    return makeImportOrRequire(sourceFile, defaultImport, imports, targetFileNameWithExtension, program, host, useEs6Imports, quotePreference);
-  }
-  function makeImportOrRequire(sourceFile, defaultImport, imports, targetFileNameWithExtension, program, host, useEs6Imports, quotePreference) {
-    const pathToTargetFile = resolvePath(getDirectoryPath(sourceFile.path), targetFileNameWithExtension);
-    const pathToTargetFileWithCorrectExtension = getModuleSpecifier(program.getCompilerOptions(), sourceFile, sourceFile.path, pathToTargetFile, createModuleSpecifierResolutionHost(program, host));
-    if (useEs6Imports) {
-      const specifiers = imports.map((i) => factory.createImportSpecifier(
-        /*isTypeOnly*/
-        false,
-        /*propertyName*/
-        void 0,
-        factory.createIdentifier(i)
-      ));
-      return makeImportIfNecessary(defaultImport, specifiers, pathToTargetFileWithCorrectExtension, quotePreference);
+    }
+    if (isReadonlyArray(range.range)) {
+      changeTracker.replaceNodeRangeWithNodes(context.file, first(range.range), last(range.range), newNodes);
     } else {
-      Debug.assert(!defaultImport, "No default import should exist");
-      const bindingElements = imports.map((i) => factory.createBindingElement(
-        /*dotDotDotToken*/
-        void 0,
-        /*propertyName*/
-        void 0,
-        i
-      ));
-      return bindingElements.length ? makeVariableStatement(
-        factory.createObjectBindingPattern(bindingElements),
-        /*type*/
-        void 0,
-        createRequireCall(makeStringLiteral(pathToTargetFileWithCorrectExtension, quotePreference))
-      ) : void 0;
+      changeTracker.replaceNodeWithNodes(context.file, range.range, newNodes);
     }
-  }
-  function makeVariableStatement(name, type, initializer, flags = 2 /* Const */) {
-    return factory.createVariableStatement(
-      /*modifiers*/
-      void 0,
-      factory.createVariableDeclarationList([factory.createVariableDeclaration(
-        name,
-        /*exclamationToken*/
-        void 0,
-        type,
-        initializer
-      )], flags)
+    const edits = changeTracker.getChanges();
+    const renameRange = isReadonlyArray(range.range) ? first(range.range) : range.range;
+    const renameFilename = renameRange.getSourceFile().fileName;
+    const renameLocation = getRenameLocation(
+      edits,
+      renameFilename,
+      functionNameText,
+      /*preferLastLocation*/
+      false
     );
-  }
-  function addExports(sourceFile, toMove, needExport, useEs6Exports) {
-    return flatMap(toMove, (statement) => {
-      if (isTopLevelDeclarationStatement(statement) && !isExported(sourceFile, statement, useEs6Exports) && forEachTopLevelDeclaration(statement, (d) => {
-        var _a;
-        return needExport.has(Debug.checkDefined((_a = tryCast(d, canHaveSymbol)) == null ? void 0 : _a.symbol));
-      })) {
-        const exports = addExport(getSynthesizedDeepClone(statement), useEs6Exports);
-        if (exports)
-          return exports;
+    return { renameFilename, renameLocation, edits };
+    function getTypeDeepCloneUnionUndefined(typeNode) {
+      if (typeNode === void 0) {
+        return void 0;
       }
-      return getSynthesizedDeepClone(statement);
-    });
-  }
-  function isExported(sourceFile, decl, useEs6Exports, name) {
-    var _a;
-    if (useEs6Exports) {
-      return !isExpressionStatement(decl) && hasSyntacticModifier(decl, 1 /* Export */) || !!(name && sourceFile.symbol && ((_a = sourceFile.symbol.exports) == null ? void 0 : _a.has(name.escapedText)));
-    }
-    return !!sourceFile.symbol && !!sourceFile.symbol.exports && getNamesToExportInCommonJS(decl).some((name2) => sourceFile.symbol.exports.has(escapeLeadingUnderscores(name2)));
-  }
-  function deleteUnusedImports(sourceFile, importDecl, changes, isUnused) {
-    switch (importDecl.kind) {
-      case 271 /* ImportDeclaration */:
-        deleteUnusedImportsInDeclaration(sourceFile, importDecl, changes, isUnused);
-        break;
-      case 270 /* ImportEqualsDeclaration */:
-        if (isUnused(importDecl.name)) {
-          changes.delete(sourceFile, importDecl);
-        }
-        break;
-      case 259 /* VariableDeclaration */:
-        deleteUnusedImportsInVariableDeclaration(sourceFile, importDecl, changes, isUnused);
-        break;
-      default:
-        Debug.assertNever(importDecl, `Unexpected import decl kind ${importDecl.kind}`);
+      const clone2 = getSynthesizedDeepClone(typeNode);
+      let withoutParens = clone2;
+      while (isParenthesizedTypeNode(withoutParens)) {
+        withoutParens = withoutParens.type;
+      }
+      return isUnionTypeNode(withoutParens) && find(withoutParens.types, (t) => t.kind === 157 /* UndefinedKeyword */) ? clone2 : factory.createUnionTypeNode([clone2, factory.createKeywordTypeNode(157 /* UndefinedKeyword */)]);
     }
   }
-  function deleteUnusedImportsInDeclaration(sourceFile, importDecl, changes, isUnused) {
-    if (!importDecl.importClause)
-      return;
-    const { name, namedBindings } = importDecl.importClause;
-    const defaultUnused = !name || isUnused(name);
-    const namedBindingsUnused = !namedBindings || (namedBindings.kind === 273 /* NamespaceImport */ ? isUnused(namedBindings.name) : namedBindings.elements.length !== 0 && namedBindings.elements.every((e) => isUnused(e.name)));
-    if (defaultUnused && namedBindingsUnused) {
-      changes.delete(sourceFile, importDecl);
-    } else {
-      if (name && defaultUnused) {
-        changes.delete(sourceFile, name);
+  function extractConstantInScope(node, scope, { substitutions }, rangeFacts, context) {
+    const checker = context.program.getTypeChecker();
+    const file = scope.getSourceFile();
+    const localNameText = isPropertyAccessExpression(node) && !isClassLike(scope) && !checker.resolveName(
+      node.name.text,
+      node,
+      111551 /* Value */,
+      /*excludeGlobals*/
+      false
+    ) && !isPrivateIdentifier(node.name) && !identifierToKeywordKind(node.name) ? node.name.text : getUniqueName(isClassLike(scope) ? "newProperty" : "newLocal", file);
+    const isJS = isInJSFile(scope);
+    let variableType = isJS || !checker.isContextSensitive(node) ? void 0 : checker.typeToTypeNode(checker.getContextualType(node), scope, 1 /* NoTruncation */);
+    let initializer = transformConstantInitializer(skipParentheses(node), substitutions);
+    ({ variableType, initializer } = transformFunctionInitializerAndType(variableType, initializer));
+    suppressLeadingAndTrailingTrivia(initializer);
+    const changeTracker = ts_textChanges_exports.ChangeTracker.fromContext(context);
+    if (isClassLike(scope)) {
+      Debug.assert(!isJS, "Cannot extract to a JS class");
+      const modifiers = [];
+      modifiers.push(factory.createModifier(123 /* PrivateKeyword */));
+      if (rangeFacts & 32 /* InStaticRegion */) {
+        modifiers.push(factory.createModifier(126 /* StaticKeyword */));
       }
-      if (namedBindings) {
-        if (namedBindingsUnused) {
-          changes.replaceNode(
-            sourceFile,
-            importDecl.importClause,
-            factory.updateImportClause(
-              importDecl.importClause,
-              importDecl.importClause.isTypeOnly,
-              name,
-              /*namedBindings*/
-              void 0
-            )
+      modifiers.push(factory.createModifier(148 /* ReadonlyKeyword */));
+      const newVariable = factory.createPropertyDeclaration(
+        modifiers,
+        localNameText,
+        /*questionOrExclamationToken*/
+        void 0,
+        variableType,
+        initializer
+      );
+      let localReference = factory.createPropertyAccessExpression(
+        rangeFacts & 32 /* InStaticRegion */ ? factory.createIdentifier(scope.name.getText()) : factory.createThis(),
+        factory.createIdentifier(localNameText)
+      );
+      if (isInJSXContent(node)) {
+        localReference = factory.createJsxExpression(
+          /*dotDotDotToken*/
+          void 0,
+          localReference
+        );
+      }
+      const maxInsertionPos = node.pos;
+      const nodeToInsertBefore = getNodeToInsertPropertyBefore(maxInsertionPos, scope);
+      changeTracker.insertNodeBefore(
+        context.file,
+        nodeToInsertBefore,
+        newVariable,
+        /*blankLineBetween*/
+        true
+      );
+      changeTracker.replaceNode(context.file, node, localReference);
+    } else {
+      const newVariableDeclaration = factory.createVariableDeclaration(
+        localNameText,
+        /*exclamationToken*/
+        void 0,
+        variableType,
+        initializer
+      );
+      const oldVariableDeclaration = getContainingVariableDeclarationIfInList(node, scope);
+      if (oldVariableDeclaration) {
+        changeTracker.insertNodeBefore(context.file, oldVariableDeclaration, newVariableDeclaration);
+        const localReference = factory.createIdentifier(localNameText);
+        changeTracker.replaceNode(context.file, node, localReference);
+      } else if (node.parent.kind === 244 /* ExpressionStatement */ && scope === findAncestor(node, isScope)) {
+        const newVariableStatement = factory.createVariableStatement(
+          /*modifiers*/
+          void 0,
+          factory.createVariableDeclarationList([newVariableDeclaration], 2 /* Const */)
+        );
+        changeTracker.replaceNode(context.file, node.parent, newVariableStatement);
+      } else {
+        const newVariableStatement = factory.createVariableStatement(
+          /*modifiers*/
+          void 0,
+          factory.createVariableDeclarationList([newVariableDeclaration], 2 /* Const */)
+        );
+        const nodeToInsertBefore = getNodeToInsertConstantBefore(node, scope);
+        if (nodeToInsertBefore.pos === 0) {
+          changeTracker.insertNodeAtTopOfFile(
+            context.file,
+            newVariableStatement,
+            /*blankLineBetween*/
+            false
+          );
+        } else {
+          changeTracker.insertNodeBefore(
+            context.file,
+            nodeToInsertBefore,
+            newVariableStatement,
+            /*blankLineBetween*/
+            false
           );
-        } else if (namedBindings.kind === 274 /* NamedImports */) {
-          for (const element of namedBindings.elements) {
-            if (isUnused(element.name))
-              changes.delete(sourceFile, element);
-          }
         }
-      }
-    }
-  }
-  function deleteUnusedImportsInVariableDeclaration(sourceFile, varDecl, changes, isUnused) {
-    const { name } = varDecl;
-    switch (name.kind) {
-      case 80 /* Identifier */:
-        if (isUnused(name)) {
-          if (varDecl.initializer && isRequireCall(
-            varDecl.initializer,
-            /*requireStringLiteralLikeArgument*/
-            true
-          )) {
-            changes.delete(
-              sourceFile,
-              isVariableDeclarationList(varDecl.parent) && length(varDecl.parent.declarations) === 1 ? varDecl.parent.parent : varDecl
+        if (node.parent.kind === 244 /* ExpressionStatement */) {
+          changeTracker.delete(context.file, node.parent);
+        } else {
+          let localReference = factory.createIdentifier(localNameText);
+          if (isInJSXContent(node)) {
+            localReference = factory.createJsxExpression(
+              /*dotDotDotToken*/
+              void 0,
+              localReference
             );
-          } else {
-            changes.delete(sourceFile, name);
           }
+          changeTracker.replaceNode(context.file, node, localReference);
         }
-        break;
-      case 206 /* ArrayBindingPattern */:
-        break;
-      case 205 /* ObjectBindingPattern */:
-        if (name.elements.every((e) => isIdentifier(e.name) && isUnused(e.name))) {
-          changes.delete(
-            sourceFile,
-            isVariableDeclarationList(varDecl.parent) && varDecl.parent.declarations.length === 1 ? varDecl.parent.parent : varDecl
-          );
+      }
+    }
+    const edits = changeTracker.getChanges();
+    const renameFilename = node.getSourceFile().fileName;
+    const renameLocation = getRenameLocation(
+      edits,
+      renameFilename,
+      localNameText,
+      /*preferLastLocation*/
+      true
+    );
+    return { renameFilename, renameLocation, edits };
+    function transformFunctionInitializerAndType(variableType2, initializer2) {
+      if (variableType2 === void 0)
+        return { variableType: variableType2, initializer: initializer2 };
+      if (!isFunctionExpression(initializer2) && !isArrowFunction(initializer2) || !!initializer2.typeParameters)
+        return { variableType: variableType2, initializer: initializer2 };
+      const functionType = checker.getTypeAtLocation(node);
+      const functionSignature = singleOrUndefined(checker.getSignaturesOfType(functionType, 0 /* Call */));
+      if (!functionSignature)
+        return { variableType: variableType2, initializer: initializer2 };
+      if (!!functionSignature.getTypeParameters())
+        return { variableType: variableType2, initializer: initializer2 };
+      const parameters = [];
+      let hasAny = false;
+      for (const p of initializer2.parameters) {
+        if (p.type) {
+          parameters.push(p);
         } else {
-          for (const element of name.elements) {
-            if (isIdentifier(element.name) && isUnused(element.name)) {
-              changes.delete(sourceFile, element.name);
-            }
+          const paramType = checker.getTypeAtLocation(p);
+          if (paramType === checker.getAnyType())
+            hasAny = true;
+          parameters.push(factory.updateParameterDeclaration(p, p.modifiers, p.dotDotDotToken, p.name, p.questionToken, p.type || checker.typeToTypeNode(paramType, scope, 1 /* NoTruncation */), p.initializer));
+        }
+      }
+      if (hasAny)
+        return { variableType: variableType2, initializer: initializer2 };
+      variableType2 = void 0;
+      if (isArrowFunction(initializer2)) {
+        initializer2 = factory.updateArrowFunction(initializer2, canHaveModifiers(node) ? getModifiers(node) : void 0, initializer2.typeParameters, parameters, initializer2.type || checker.typeToTypeNode(functionSignature.getReturnType(), scope, 1 /* NoTruncation */), initializer2.equalsGreaterThanToken, initializer2.body);
+      } else {
+        if (functionSignature && !!functionSignature.thisParameter) {
+          const firstParameter = firstOrUndefined(parameters);
+          if (!firstParameter || isIdentifier(firstParameter.name) && firstParameter.name.escapedText !== "this") {
+            const thisType = checker.getTypeOfSymbolAtLocation(functionSignature.thisParameter, node);
+            parameters.splice(
+              0,
+              0,
+              factory.createParameterDeclaration(
+                /*modifiers*/
+                void 0,
+                /*dotDotDotToken*/
+                void 0,
+                "this",
+                /*questionToken*/
+                void 0,
+                checker.typeToTypeNode(thisType, scope, 1 /* NoTruncation */)
+              )
+            );
           }
         }
-        break;
+        initializer2 = factory.updateFunctionExpression(initializer2, canHaveModifiers(node) ? getModifiers(node) : void 0, initializer2.asteriskToken, initializer2.name, initializer2.typeParameters, parameters, initializer2.type || checker.typeToTypeNode(functionSignature.getReturnType(), scope, 1 /* NoTruncation */), initializer2.body);
+      }
+      return { variableType: variableType2, initializer: initializer2 };
     }
   }
-  function isTopLevelDeclarationStatement(node) {
-    Debug.assert(isSourceFile(node.parent), "Node parent should be a SourceFile");
-    return isNonVariableTopLevelDeclaration(node) || isVariableStatement(node);
-  }
-  function addExport(decl, useEs6Exports) {
-    return useEs6Exports ? [addEs6Export(decl)] : addCommonjsExport(decl);
-  }
-  function addEs6Export(d) {
-    const modifiers = canHaveModifiers(d) ? concatenate([factory.createModifier(95 /* ExportKeyword */)], getModifiers(d)) : void 0;
-    switch (d.kind) {
-      case 261 /* FunctionDeclaration */:
-        return factory.updateFunctionDeclaration(d, modifiers, d.asteriskToken, d.name, d.typeParameters, d.parameters, d.type, d.body);
-      case 262 /* ClassDeclaration */:
-        const decorators = canHaveDecorators(d) ? getDecorators(d) : void 0;
-        return factory.updateClassDeclaration(d, concatenate(decorators, modifiers), d.name, d.typeParameters, d.heritageClauses, d.members);
-      case 242 /* VariableStatement */:
-        return factory.updateVariableStatement(d, modifiers, d.declarationList);
-      case 266 /* ModuleDeclaration */:
-        return factory.updateModuleDeclaration(d, modifiers, d.name, d.body);
-      case 265 /* EnumDeclaration */:
-        return factory.updateEnumDeclaration(d, modifiers, d.name, d.members);
-      case 264 /* TypeAliasDeclaration */:
-        return factory.updateTypeAliasDeclaration(d, modifiers, d.name, d.typeParameters, d.type);
-      case 263 /* InterfaceDeclaration */:
-        return factory.updateInterfaceDeclaration(d, modifiers, d.name, d.typeParameters, d.heritageClauses, d.members);
-      case 270 /* ImportEqualsDeclaration */:
-        return factory.updateImportEqualsDeclaration(d, modifiers, d.isTypeOnly, d.name, d.moduleReference);
-      case 243 /* ExpressionStatement */:
-        return Debug.fail();
-      default:
-        return Debug.assertNever(d, `Unexpected declaration kind ${d.kind}`);
+  function getContainingVariableDeclarationIfInList(node, scope) {
+    let prevNode;
+    while (node !== void 0 && node !== scope) {
+      if (isVariableDeclaration(node) && node.initializer === prevNode && isVariableDeclarationList(node.parent) && node.parent.declarations.length > 1) {
+        return node;
+      }
+      prevNode = node;
+      node = node.parent;
     }
   }
-  function addCommonjsExport(decl) {
-    return [decl, ...getNamesToExportInCommonJS(decl).map(createExportAssignment)];
+  function getFirstDeclarationBeforePosition(type, position) {
+    let firstDeclaration;
+    const symbol = type.symbol;
+    if (symbol && symbol.declarations) {
+      for (const declaration of symbol.declarations) {
+        if ((firstDeclaration === void 0 || declaration.pos < firstDeclaration.pos) && declaration.pos < position) {
+          firstDeclaration = declaration;
+        }
+      }
+    }
+    return firstDeclaration;
   }
-  function createExportAssignment(name) {
-    return factory.createExpressionStatement(
-      factory.createBinaryExpression(
-        factory.createPropertyAccessExpression(factory.createIdentifier("exports"), factory.createIdentifier(name)),
-        64 /* EqualsToken */,
-        factory.createIdentifier(name)
-      )
-    );
+  function compareTypesByDeclarationOrder({ type: type1, declaration: declaration1 }, { type: type2, declaration: declaration2 }) {
+    return compareProperties(declaration1, declaration2, "pos", compareValues) || compareStringsCaseSensitive(
+      type1.symbol ? type1.symbol.getName() : "",
+      type2.symbol ? type2.symbol.getName() : ""
+    ) || compareValues(type1.id, type2.id);
   }
-  function getNamesToExportInCommonJS(decl) {
-    switch (decl.kind) {
-      case 261 /* FunctionDeclaration */:
-      case 262 /* ClassDeclaration */:
-        return [decl.name.text];
-      case 242 /* VariableStatement */:
-        return mapDefined(decl.declarationList.declarations, (d) => isIdentifier(d.name) ? d.name.text : void 0);
-      case 266 /* ModuleDeclaration */:
-      case 265 /* EnumDeclaration */:
-      case 264 /* TypeAliasDeclaration */:
-      case 263 /* InterfaceDeclaration */:
-      case 270 /* ImportEqualsDeclaration */:
-        return emptyArray;
-      case 243 /* ExpressionStatement */:
-        return Debug.fail("Can't export an ExpressionStatement");
-      default:
-        return Debug.assertNever(decl, `Unexpected decl kind ${decl.kind}`);
+  function getCalledExpression(scope, range, functionNameText) {
+    const functionReference = factory.createIdentifier(functionNameText);
+    if (isClassLike(scope)) {
+      const lhs = range.facts & 32 /* InStaticRegion */ ? factory.createIdentifier(scope.name.text) : factory.createThis();
+      return factory.createPropertyAccessExpression(lhs, functionReference);
+    } else {
+      return functionReference;
     }
   }
-  function filterImport(i, moduleSpecifier, keep) {
-    switch (i.kind) {
-      case 271 /* ImportDeclaration */: {
-        const clause = i.importClause;
-        if (!clause)
-          return void 0;
-        const defaultImport = clause.name && keep(clause.name) ? clause.name : void 0;
-        const namedBindings = clause.namedBindings && filterNamedBindings(clause.namedBindings, keep);
-        return defaultImport || namedBindings ? factory.createImportDeclaration(
-          /*modifiers*/
-          void 0,
-          factory.createImportClause(clause.isTypeOnly, defaultImport, namedBindings),
-          getSynthesizedDeepClone(moduleSpecifier),
-          /*assertClause*/
-          void 0
-        ) : void 0;
+  function transformFunctionBody(body, exposedVariableDeclarations, writes, substitutions, hasReturn2) {
+    const hasWritesOrVariableDeclarations = writes !== void 0 || exposedVariableDeclarations.length > 0;
+    if (isBlock(body) && !hasWritesOrVariableDeclarations && substitutions.size === 0) {
+      return { body: factory.createBlock(
+        body.statements,
+        /*multiLine*/
+        true
+      ), returnValueProperty: void 0 };
+    }
+    let returnValueProperty;
+    let ignoreReturns = false;
+    const statements = factory.createNodeArray(isBlock(body) ? body.statements.slice(0) : [isStatement(body) ? body : factory.createReturnStatement(skipParentheses(body))]);
+    if (hasWritesOrVariableDeclarations || substitutions.size) {
+      const rewrittenStatements = visitNodes2(statements, visitor, isStatement).slice();
+      if (hasWritesOrVariableDeclarations && !hasReturn2 && isStatement(body)) {
+        const assignments = getPropertyAssignmentsForWritesAndVariableDeclarations(exposedVariableDeclarations, writes);
+        if (assignments.length === 1) {
+          rewrittenStatements.push(factory.createReturnStatement(assignments[0].name));
+        } else {
+          rewrittenStatements.push(factory.createReturnStatement(factory.createObjectLiteralExpression(assignments)));
+        }
       }
-      case 270 /* ImportEqualsDeclaration */:
-        return keep(i.name) ? i : void 0;
-      case 259 /* VariableDeclaration */: {
-        const name = filterBindingName(i.name, keep);
-        return name ? makeVariableStatement(name, i.type, createRequireCall(moduleSpecifier), i.parent.flags) : void 0;
+      return { body: factory.createBlock(
+        rewrittenStatements,
+        /*multiLine*/
+        true
+      ), returnValueProperty };
+    } else {
+      return { body: factory.createBlock(
+        statements,
+        /*multiLine*/
+        true
+      ), returnValueProperty: void 0 };
+    }
+    function visitor(node) {
+      if (!ignoreReturns && isReturnStatement(node) && hasWritesOrVariableDeclarations) {
+        const assignments = getPropertyAssignmentsForWritesAndVariableDeclarations(exposedVariableDeclarations, writes);
+        if (node.expression) {
+          if (!returnValueProperty) {
+            returnValueProperty = "__return";
+          }
+          assignments.unshift(factory.createPropertyAssignment(returnValueProperty, visitNode(node.expression, visitor, isExpression)));
+        }
+        if (assignments.length === 1) {
+          return factory.createReturnStatement(assignments[0].name);
+        } else {
+          return factory.createReturnStatement(factory.createObjectLiteralExpression(assignments));
+        }
+      } else {
+        const oldIgnoreReturns = ignoreReturns;
+        ignoreReturns = ignoreReturns || isFunctionLikeDeclaration(node) || isClassLike(node);
+        const substitution = substitutions.get(getNodeId(node).toString());
+        const result = substitution ? getSynthesizedDeepClone(substitution) : visitEachChild(node, visitor, nullTransformationContext);
+        ignoreReturns = oldIgnoreReturns;
+        return result;
       }
-      default:
-        return Debug.assertNever(i, `Unexpected import kind ${i.kind}`);
     }
   }
-  function filterNamedBindings(namedBindings, keep) {
-    if (namedBindings.kind === 273 /* NamespaceImport */) {
-      return keep(namedBindings.name) ? namedBindings : void 0;
-    } else {
-      const newElements = namedBindings.elements.filter((e) => keep(e.name));
-      return newElements.length ? factory.createNamedImports(newElements) : void 0;
+  function transformConstantInitializer(initializer, substitutions) {
+    return substitutions.size ? visitor(initializer) : initializer;
+    function visitor(node) {
+      const substitution = substitutions.get(getNodeId(node).toString());
+      return substitution ? getSynthesizedDeepClone(substitution) : visitEachChild(node, visitor, nullTransformationContext);
     }
   }
-  function filterBindingName(name, keep) {
-    switch (name.kind) {
-      case 80 /* Identifier */:
-        return keep(name) ? name : void 0;
-      case 206 /* ArrayBindingPattern */:
-        return name;
-      case 205 /* ObjectBindingPattern */: {
-        const newElements = name.elements.filter((prop) => prop.propertyName || !isIdentifier(prop.name) || keep(prop.name));
-        return newElements.length ? factory.createObjectBindingPattern(newElements) : void 0;
+  function getStatementsOrClassElements(scope) {
+    if (isFunctionLikeDeclaration(scope)) {
+      const body = scope.body;
+      if (isBlock(body)) {
+        return body.statements;
       }
+    } else if (isModuleBlock(scope) || isSourceFile(scope)) {
+      return scope.statements;
+    } else if (isClassLike(scope)) {
+      return scope.members;
+    } else {
+      assertType(scope);
     }
+    return emptyArray;
   }
-  function nameOfTopLevelDeclaration(d) {
-    return isExpressionStatement(d) ? tryCast(d.expression.left.name, isIdentifier) : tryCast(d.name, isIdentifier);
+  function getNodeToInsertFunctionBefore(minPos, scope) {
+    return find(getStatementsOrClassElements(scope), (child) => child.pos >= minPos && isFunctionLikeDeclaration(child) && !isConstructorDeclaration(child));
   }
-  function getTopLevelDeclarationStatement(d) {
-    switch (d.kind) {
-      case 259 /* VariableDeclaration */:
-        return d.parent.parent;
-      case 207 /* BindingElement */:
-        return getTopLevelDeclarationStatement(
-          cast(d.parent.parent, (p) => isVariableDeclaration(p) || isBindingElement(p))
-        );
-      default:
-        return d;
+  function getNodeToInsertPropertyBefore(maxPos, scope) {
+    const members = scope.members;
+    Debug.assert(members.length > 0, "Found no members");
+    let prevMember;
+    let allProperties = true;
+    for (const member of members) {
+      if (member.pos > maxPos) {
+        return prevMember || members[0];
+      }
+      if (allProperties && !isPropertyDeclaration(member)) {
+        if (prevMember !== void 0) {
+          return member;
+        }
+        allProperties = false;
+      }
+      prevMember = member;
     }
+    if (prevMember === void 0)
+      return Debug.fail();
+    return prevMember;
   }
-  function addExportToChanges(sourceFile, decl, name, changes, useEs6Exports) {
-    if (isExported(sourceFile, decl, useEs6Exports, name))
-      return;
-    if (useEs6Exports) {
-      if (!isExpressionStatement(decl))
-        changes.insertExportModifier(sourceFile, decl);
-    } else {
-      const names = getNamesToExportInCommonJS(decl);
-      if (names.length !== 0)
-        changes.insertNodesAfter(sourceFile, decl, names.map(createExportAssignment));
+  function getNodeToInsertConstantBefore(node, scope) {
+    Debug.assert(!isClassLike(scope));
+    let prevScope;
+    for (let curr = node; curr !== scope; curr = curr.parent) {
+      if (isScope(curr)) {
+        prevScope = curr;
+      }
     }
-  }
-  function createNewFileName(oldFile, program, context, host) {
-    const checker = program.getTypeChecker();
-    const toMove = getStatementsToMove(context);
-    let usage;
-    if (toMove) {
-      usage = getUsageInfo(oldFile, toMove.all, checker);
-      const currentDirectory = getDirectoryPath(oldFile.fileName);
-      const extension = extensionFromPath(oldFile.fileName);
-      const newFileName = combinePaths(
-        // new file is always placed in the same directory as the old file
-        currentDirectory,
-        // ensures the filename computed below isn't already taken
-        makeUniqueFilename(
-          // infers a name for the new file from the symbols being moved
-          inferNewFileName(usage.oldFileImportsFromTargetFile, usage.movedSymbols),
-          extension,
-          currentDirectory,
-          host
-        )
-      ) + extension;
-      return newFileName;
+    for (let curr = (prevScope || node).parent; ; curr = curr.parent) {
+      if (isBlockLike(curr)) {
+        let prevStatement;
+        for (const statement of curr.statements) {
+          if (statement.pos > node.pos) {
+            break;
+          }
+          prevStatement = statement;
+        }
+        if (!prevStatement && isCaseClause(curr)) {
+          Debug.assert(isSwitchStatement(curr.parent.parent), "Grandparent isn't a switch statement");
+          return curr.parent.parent;
+        }
+        return Debug.checkDefined(prevStatement, "prevStatement failed to get set");
+      }
+      Debug.assert(curr !== scope, "Didn't encounter a block-like before encountering scope");
     }
-    return "";
   }
-  function getRangeToMove(context) {
-    const { file } = context;
-    const range = createTextRangeFromSpan(getRefactorContextSpan(context));
-    const { statements } = file;
-    const startNodeIndex = findIndex(statements, (s) => s.end > range.pos);
-    if (startNodeIndex === -1)
-      return void 0;
-    const startStatement = statements[startNodeIndex];
-    if (isNamedDeclaration(startStatement) && startStatement.name && rangeContainsRange(startStatement.name, range)) {
-      return { toMove: [statements[startNodeIndex]], afterLast: statements[startNodeIndex + 1] };
-    }
-    if (range.pos > startStatement.getStart(file))
-      return void 0;
-    const afterEndNodeIndex = findIndex(statements, (s) => s.end > range.end, startNodeIndex);
-    if (afterEndNodeIndex !== -1 && (afterEndNodeIndex === 0 || statements[afterEndNodeIndex].getStart(file) < range.end))
-      return void 0;
-    return {
-      toMove: statements.slice(startNodeIndex, afterEndNodeIndex === -1 ? statements.length : afterEndNodeIndex),
-      afterLast: afterEndNodeIndex === -1 ? void 0 : statements[afterEndNodeIndex]
-    };
+  function getPropertyAssignmentsForWritesAndVariableDeclarations(exposedVariableDeclarations, writes) {
+    const variableAssignments = map(exposedVariableDeclarations, (v) => factory.createShorthandPropertyAssignment(v.symbol.name));
+    const writeAssignments = map(writes, (w) => factory.createShorthandPropertyAssignment(w.symbol.name));
+    return variableAssignments === void 0 ? writeAssignments : writeAssignments === void 0 ? variableAssignments : variableAssignments.concat(writeAssignments);
   }
-  function getStatementsToMove(context) {
-    const rangeToMove = getRangeToMove(context);
-    if (rangeToMove === void 0)
-      return void 0;
-    const all = [];
-    const ranges = [];
-    const { toMove, afterLast } = rangeToMove;
-    getRangesWhere(toMove, isAllowedStatementToMove, (start, afterEndIndex) => {
-      for (let i = start; i < afterEndIndex; i++)
-        all.push(toMove[i]);
-      ranges.push({ first: toMove[start], afterLast });
-    });
-    return all.length === 0 ? void 0 : { all, ranges };
+  function isReadonlyArray(v) {
+    return isArray(v);
   }
-  function isAllowedStatementToMove(statement) {
-    return !isPureImport(statement) && !isPrologueDirective(statement);
+  function getEnclosingTextRange(targetRange, sourceFile) {
+    return isReadonlyArray(targetRange.range) ? { pos: first(targetRange.range).getStart(sourceFile), end: last(targetRange.range).getEnd() } : targetRange.range;
   }
-  function isPureImport(node) {
-    switch (node.kind) {
-      case 271 /* ImportDeclaration */:
-        return true;
-      case 270 /* ImportEqualsDeclaration */:
-        return !hasSyntacticModifier(node, 1 /* Export */);
-      case 242 /* VariableStatement */:
-        return node.declarationList.declarations.every((d) => !!d.initializer && isRequireCall(
-          d.initializer,
-          /*requireStringLiteralLikeArgument*/
-          true
-        ));
-      default:
-        return false;
+  function collectReadsAndWrites(targetRange, scopes, enclosingTextRange, sourceFile, checker, cancellationToken) {
+    const allTypeParameterUsages = /* @__PURE__ */ new Map();
+    const usagesPerScope = [];
+    const substitutionsPerScope = [];
+    const functionErrorsPerScope = [];
+    const constantErrorsPerScope = [];
+    const visibleDeclarationsInExtractedRange = [];
+    const exposedVariableSymbolSet = /* @__PURE__ */ new Map();
+    const exposedVariableDeclarations = [];
+    let firstExposedNonVariableDeclaration;
+    const expression = !isReadonlyArray(targetRange.range) ? targetRange.range : targetRange.range.length === 1 && isExpressionStatement(targetRange.range[0]) ? targetRange.range[0].expression : void 0;
+    let expressionDiagnostic;
+    if (expression === void 0) {
+      const statements = targetRange.range;
+      const start = first(statements).getStart();
+      const end = last(statements).end;
+      expressionDiagnostic = createFileDiagnostic(sourceFile, start, end - start, Messages.expressionExpected);
+    } else if (checker.getTypeAtLocation(expression).flags & (16384 /* Void */ | 131072 /* Never */)) {
+      expressionDiagnostic = createDiagnosticForNode(expression, Messages.uselessConstantType);
     }
-  }
-  function getUsageInfo(oldFile, toMove, checker) {
-    const movedSymbols = /* @__PURE__ */ new Set();
-    const oldImportsNeededByTargetFile = /* @__PURE__ */ new Map();
-    const targetFileImportsFromOldFile = /* @__PURE__ */ new Set();
-    const containsJsx = find(toMove, (statement) => !!(statement.transformFlags & 2 /* ContainsJsx */));
-    const jsxNamespaceSymbol = getJsxNamespaceSymbol(containsJsx);
-    if (jsxNamespaceSymbol) {
-      oldImportsNeededByTargetFile.set(jsxNamespaceSymbol, false);
+    for (const scope of scopes) {
+      usagesPerScope.push({ usages: /* @__PURE__ */ new Map(), typeParameterUsages: /* @__PURE__ */ new Map(), substitutions: /* @__PURE__ */ new Map() });
+      substitutionsPerScope.push(/* @__PURE__ */ new Map());
+      functionErrorsPerScope.push([]);
+      const constantErrors = [];
+      if (expressionDiagnostic) {
+        constantErrors.push(expressionDiagnostic);
+      }
+      if (isClassLike(scope) && isInJSFile(scope)) {
+        constantErrors.push(createDiagnosticForNode(scope, Messages.cannotExtractToJSClass));
+      }
+      if (isArrowFunction(scope) && !isBlock(scope.body)) {
+        constantErrors.push(createDiagnosticForNode(scope, Messages.cannotExtractToExpressionArrowFunction));
+      }
+      constantErrorsPerScope.push(constantErrors);
     }
-    for (const statement of toMove) {
-      forEachTopLevelDeclaration(statement, (decl) => {
-        movedSymbols.add(Debug.checkDefined(isExpressionStatement(decl) ? checker.getSymbolAtLocation(decl.expression.left) : decl.symbol, "Need a symbol here"));
-      });
+    const seenUsages = /* @__PURE__ */ new Map();
+    const target = isReadonlyArray(targetRange.range) ? factory.createBlock(targetRange.range) : targetRange.range;
+    const unmodifiedNode = isReadonlyArray(targetRange.range) ? first(targetRange.range) : targetRange.range;
+    const inGenericContext = isInGenericContext(unmodifiedNode);
+    collectUsages(target);
+    if (inGenericContext && !isReadonlyArray(targetRange.range) && !isJsxAttribute(targetRange.range)) {
+      const contextualType = checker.getContextualType(targetRange.range);
+      recordTypeParameterUsages(contextualType);
     }
-    for (const statement of toMove) {
-      forEachReference(statement, checker, (symbol, isValidTypeOnlyUseSite) => {
-        if (!symbol.declarations)
-          return;
-        for (const decl of symbol.declarations) {
-          if (isInImport(decl)) {
-            const prevIsTypeOnly = oldImportsNeededByTargetFile.get(symbol);
-            oldImportsNeededByTargetFile.set(symbol, prevIsTypeOnly === void 0 ? isValidTypeOnlyUseSite : prevIsTypeOnly && isValidTypeOnlyUseSite);
-          } else if (isTopLevelDeclaration(decl) && sourceFileOfTopLevelDeclaration(decl) === oldFile && !movedSymbols.has(symbol)) {
-            targetFileImportsFromOldFile.add(symbol);
+    if (allTypeParameterUsages.size > 0) {
+      const seenTypeParameterUsages = /* @__PURE__ */ new Map();
+      let i = 0;
+      for (let curr = unmodifiedNode; curr !== void 0 && i < scopes.length; curr = curr.parent) {
+        if (curr === scopes[i]) {
+          seenTypeParameterUsages.forEach((typeParameter, id) => {
+            usagesPerScope[i].typeParameterUsages.set(id, typeParameter);
+          });
+          i++;
+        }
+        if (isDeclarationWithTypeParameters(curr)) {
+          for (const typeParameterDecl of getEffectiveTypeParameterDeclarations(curr)) {
+            const typeParameter = checker.getTypeAtLocation(typeParameterDecl);
+            if (allTypeParameterUsages.has(typeParameter.id.toString())) {
+              seenTypeParameterUsages.set(typeParameter.id.toString(), typeParameter);
+            }
           }
         }
-      });
-    }
-    const unusedImportsFromOldFile = new Set(oldImportsNeededByTargetFile.keys());
-    const oldFileImportsFromTargetFile = /* @__PURE__ */ new Set();
-    for (const statement of oldFile.statements) {
-      if (contains(toMove, statement))
-        continue;
-      if (jsxNamespaceSymbol && !!(statement.transformFlags & 2 /* ContainsJsx */)) {
-        unusedImportsFromOldFile.delete(jsxNamespaceSymbol);
-      }
-      forEachReference(statement, checker, (symbol) => {
-        if (movedSymbols.has(symbol))
-          oldFileImportsFromTargetFile.add(symbol);
-        unusedImportsFromOldFile.delete(symbol);
-      });
-    }
-    return { movedSymbols, targetFileImportsFromOldFile, oldFileImportsFromTargetFile, oldImportsNeededByTargetFile, unusedImportsFromOldFile };
-    function getJsxNamespaceSymbol(containsJsx2) {
-      if (containsJsx2 === void 0) {
-        return void 0;
       }
-      const jsxNamespace = checker.getJsxNamespace(containsJsx2);
-      const jsxNamespaceSymbol2 = checker.resolveName(
-        jsxNamespace,
-        containsJsx2,
-        1920 /* Namespace */,
-        /*excludeGlobals*/
-        true
-      );
-      return !!jsxNamespaceSymbol2 && some(jsxNamespaceSymbol2.declarations, isInImport) ? jsxNamespaceSymbol2 : void 0;
+      Debug.assert(i === scopes.length, "Should have iterated all scopes");
     }
-  }
-  function makeUniqueFilename(proposedFilename, extension, inDirectory, host) {
-    let newFilename = proposedFilename;
-    for (let i = 1; ; i++) {
-      const name = combinePaths(inDirectory, newFilename + extension);
-      if (!host.fileExists(name))
-        return newFilename;
-      newFilename = `${proposedFilename}.${i}`;
+    if (visibleDeclarationsInExtractedRange.length) {
+      const containingLexicalScopeOfExtraction = isBlockScope(scopes[0], scopes[0].parent) ? scopes[0] : getEnclosingBlockScopeContainer(scopes[0]);
+      forEachChild(containingLexicalScopeOfExtraction, checkForUsedDeclarations);
     }
-  }
-  function inferNewFileName(importsFromNewFile, movedSymbols) {
-    return forEachKey(importsFromNewFile, symbolNameNoDefault) || forEachKey(movedSymbols, symbolNameNoDefault) || "newFile";
-  }
-  function forEachReference(node, checker, onReference) {
-    node.forEachChild(function cb(node2) {
-      if (isIdentifier(node2) && !isDeclarationName(node2)) {
-        const sym = checker.getSymbolAtLocation(node2);
-        if (sym)
-          onReference(sym, isValidTypeOnlyAliasUseSite(node2));
-      } else {
-        node2.forEachChild(cb);
+    for (let i = 0; i < scopes.length; i++) {
+      const scopeUsages = usagesPerScope[i];
+      if (i > 0 && (scopeUsages.usages.size > 0 || scopeUsages.typeParameterUsages.size > 0)) {
+        const errorNode = isReadonlyArray(targetRange.range) ? targetRange.range[0] : targetRange.range;
+        constantErrorsPerScope[i].push(createDiagnosticForNode(errorNode, Messages.cannotAccessVariablesFromNestedScopes));
       }
-    });
-  }
-  function forEachTopLevelDeclaration(statement, cb) {
-    switch (statement.kind) {
-      case 261 /* FunctionDeclaration */:
-      case 262 /* ClassDeclaration */:
-      case 266 /* ModuleDeclaration */:
-      case 265 /* EnumDeclaration */:
-      case 264 /* TypeAliasDeclaration */:
-      case 263 /* InterfaceDeclaration */:
-      case 270 /* ImportEqualsDeclaration */:
-        return cb(statement);
-      case 242 /* VariableStatement */:
-        return firstDefined(statement.declarationList.declarations, (decl) => forEachTopLevelDeclarationInBindingName(decl.name, cb));
-      case 243 /* ExpressionStatement */: {
-        const { expression } = statement;
-        return isBinaryExpression(expression) && getAssignmentDeclarationKind(expression) === 1 /* ExportsProperty */ ? cb(statement) : void 0;
+      if (targetRange.facts & 16 /* UsesThisInFunction */ && isClassLike(scopes[i])) {
+        functionErrorsPerScope[i].push(createDiagnosticForNode(targetRange.thisNode, Messages.cannotExtractFunctionsContainingThisToMethod));
+      }
+      let hasWrite = false;
+      let readonlyClassPropertyWrite;
+      usagesPerScope[i].usages.forEach((value) => {
+        if (value.usage === 2 /* Write */) {
+          hasWrite = true;
+          if (value.symbol.flags & 106500 /* ClassMember */ && value.symbol.valueDeclaration && hasEffectiveModifier(value.symbol.valueDeclaration, 8 /* Readonly */)) {
+            readonlyClassPropertyWrite = value.symbol.valueDeclaration;
+          }
+        }
+      });
+      Debug.assert(isReadonlyArray(targetRange.range) || exposedVariableDeclarations.length === 0, "No variable declarations expected if something was extracted");
+      if (hasWrite && !isReadonlyArray(targetRange.range)) {
+        const diag2 = createDiagnosticForNode(targetRange.range, Messages.cannotWriteInExpression);
+        functionErrorsPerScope[i].push(diag2);
+        constantErrorsPerScope[i].push(diag2);
+      } else if (readonlyClassPropertyWrite && i > 0) {
+        const diag2 = createDiagnosticForNode(readonlyClassPropertyWrite, Messages.cannotExtractReadonlyPropertyInitializerOutsideConstructor);
+        functionErrorsPerScope[i].push(diag2);
+        constantErrorsPerScope[i].push(diag2);
+      } else if (firstExposedNonVariableDeclaration) {
+        const diag2 = createDiagnosticForNode(firstExposedNonVariableDeclaration, Messages.cannotExtractExportedEntity);
+        functionErrorsPerScope[i].push(diag2);
+        constantErrorsPerScope[i].push(diag2);
       }
     }
-  }
-  function isInImport(decl) {
-    switch (decl.kind) {
-      case 270 /* ImportEqualsDeclaration */:
-      case 275 /* ImportSpecifier */:
-      case 272 /* ImportClause */:
-      case 273 /* NamespaceImport */:
-        return true;
-      case 259 /* VariableDeclaration */:
-        return isVariableDeclarationInImport(decl);
-      case 207 /* BindingElement */:
-        return isVariableDeclaration(decl.parent.parent) && isVariableDeclarationInImport(decl.parent.parent);
-      default:
-        return false;
+    return { target, usagesPerScope, functionErrorsPerScope, constantErrorsPerScope, exposedVariableDeclarations };
+    function isInGenericContext(node) {
+      return !!findAncestor(node, (n) => isDeclarationWithTypeParameters(n) && getEffectiveTypeParameterDeclarations(n).length !== 0);
     }
-  }
-  function isVariableDeclarationInImport(decl) {
-    return isSourceFile(decl.parent.parent.parent) && !!decl.initializer && isRequireCall(
-      decl.initializer,
-      /*requireStringLiteralLikeArgument*/
-      true
-    );
-  }
-  function isTopLevelDeclaration(node) {
-    return isNonVariableTopLevelDeclaration(node) && isSourceFile(node.parent) || isVariableDeclaration(node) && isSourceFile(node.parent.parent.parent);
-  }
-  function sourceFileOfTopLevelDeclaration(node) {
-    return isVariableDeclaration(node) ? node.parent.parent.parent : node.parent;
-  }
-  function forEachTopLevelDeclarationInBindingName(name, cb) {
-    switch (name.kind) {
-      case 80 /* Identifier */:
-        return cb(cast(name.parent, (x) => isVariableDeclaration(x) || isBindingElement(x)));
-      case 206 /* ArrayBindingPattern */:
-      case 205 /* ObjectBindingPattern */:
-        return firstDefined(name.elements, (em) => isOmittedExpression(em) ? void 0 : forEachTopLevelDeclarationInBindingName(em.name, cb));
-      default:
-        return Debug.assertNever(name, `Unexpected name kind ${name.kind}`);
+    function recordTypeParameterUsages(type) {
+      const symbolWalker = checker.getSymbolWalker(() => (cancellationToken.throwIfCancellationRequested(), true));
+      const { visitedTypes } = symbolWalker.walkType(type);
+      for (const visitedType of visitedTypes) {
+        if (visitedType.isTypeParameter()) {
+          allTypeParameterUsages.set(visitedType.id.toString(), visitedType);
+        }
+      }
     }
-  }
-  function isNonVariableTopLevelDeclaration(node) {
-    switch (node.kind) {
-      case 261 /* FunctionDeclaration */:
-      case 262 /* ClassDeclaration */:
-      case 266 /* ModuleDeclaration */:
-      case 265 /* EnumDeclaration */:
-      case 264 /* TypeAliasDeclaration */:
-      case 263 /* InterfaceDeclaration */:
-      case 270 /* ImportEqualsDeclaration */:
-        return true;
-      default:
-        return false;
+    function collectUsages(node, valueUsage = 1 /* Read */) {
+      if (inGenericContext) {
+        const type = checker.getTypeAtLocation(node);
+        recordTypeParameterUsages(type);
+      }
+      if (isDeclaration(node) && node.symbol) {
+        visibleDeclarationsInExtractedRange.push(node);
+      }
+      if (isAssignmentExpression(node)) {
+        collectUsages(node.left, 2 /* Write */);
+        collectUsages(node.right);
+      } else if (isUnaryExpressionWithWrite(node)) {
+        collectUsages(node.operand, 2 /* Write */);
+      } else if (isPropertyAccessExpression(node) || isElementAccessExpression(node)) {
+        forEachChild(node, collectUsages);
+      } else if (isIdentifier(node)) {
+        if (!node.parent) {
+          return;
+        }
+        if (isQualifiedName(node.parent) && node !== node.parent.left) {
+          return;
+        }
+        if (isPropertyAccessExpression(node.parent) && node !== node.parent.expression) {
+          return;
+        }
+        recordUsage(
+          node,
+          valueUsage,
+          /*isTypeNode*/
+          isPartOfTypeNode(node)
+        );
+      } else {
+        forEachChild(node, collectUsages);
+      }
     }
-  }
-  var refactorNameForMoveToFile, description2, moveToFileAction;
-  var init_moveToFile = __esm({
-    "src/services/refactors/moveToFile.ts"() {
-      "use strict";
-      init_moduleSpecifiers();
-      init_ts4();
-      init_refactorProvider();
-      refactorNameForMoveToFile = "Move to file";
-      description2 = getLocaleSpecificMessage(Diagnostics.Move_to_file);
-      moveToFileAction = {
-        name: "Move to file",
-        description: description2,
-        kind: "refactor.move.file"
-      };
-      registerRefactor(refactorNameForMoveToFile, {
-        kinds: [moveToFileAction.kind],
-        getAvailableActions: function getRefactorActionsToMoveToFile(context, interactiveRefactorArguments) {
-          const statements = getStatementsToMove(context);
-          if (!interactiveRefactorArguments) {
-            return emptyArray;
-          }
-          if (context.preferences.allowTextChangesInNewFiles && statements) {
-            return [{ name: refactorNameForMoveToFile, description: description2, actions: [moveToFileAction] }];
-          }
-          if (context.preferences.provideRefactorNotApplicableReason) {
-            return [{
-              name: refactorNameForMoveToFile,
-              description: description2,
-              actions: [{ ...moveToFileAction, notApplicableReason: getLocaleSpecificMessage(Diagnostics.Selection_is_not_a_valid_statement_or_statements) }]
-            }];
-          }
-          return emptyArray;
-        },
-        getEditsForAction: function getRefactorEditsToMoveToFile(context, actionName2, interactiveRefactorArguments) {
-          Debug.assert(actionName2 === refactorNameForMoveToFile, "Wrong refactor invoked");
-          const statements = Debug.checkDefined(getStatementsToMove(context));
-          Debug.assert(interactiveRefactorArguments, "No interactive refactor arguments available");
-          const targetFile = interactiveRefactorArguments.targetFile;
-          if (hasJSFileExtension(targetFile) || hasTSFileExtension(targetFile)) {
-            const edits = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange4(context, context.file, interactiveRefactorArguments.targetFile, context.program, statements, t, context.host, context.preferences));
-            return { edits, renameFilename: void 0, renameLocation: void 0 };
+    function recordUsage(n, usage, isTypeNode2) {
+      const symbolId = recordUsagebySymbol(n, usage, isTypeNode2);
+      if (symbolId) {
+        for (let i = 0; i < scopes.length; i++) {
+          const substitution = substitutionsPerScope[i].get(symbolId);
+          if (substitution) {
+            usagesPerScope[i].substitutions.set(getNodeId(n).toString(), substitution);
           }
-          return { edits: [], renameFilename: void 0, renameLocation: void 0, notApplicableReason: getLocaleSpecificMessage(Diagnostics.Cannot_move_to_file_selected_file_is_invalid) };
         }
-      });
+      }
     }
-  });
-
-  // src/services/refactors/convertOverloadListToSingleSignature.ts
-  function getRefactorActionsToConvertOverloadsToOneSignature(context) {
-    const { file, startPosition, program } = context;
-    const info = getConvertableOverloadListAtPosition(file, startPosition, program);
-    if (!info)
-      return emptyArray;
-    return [{
-      name: refactorName5,
-      description: refactorDescription,
-      actions: [functionOverloadAction]
-    }];
-  }
-  function getRefactorEditsToConvertOverloadsToOneSignature(context) {
-    const { file, startPosition, program } = context;
-    const signatureDecls = getConvertableOverloadListAtPosition(file, startPosition, program);
-    if (!signatureDecls)
-      return void 0;
-    const checker = program.getTypeChecker();
-    const lastDeclaration = signatureDecls[signatureDecls.length - 1];
-    let updated = lastDeclaration;
-    switch (lastDeclaration.kind) {
-      case 172 /* MethodSignature */: {
-        updated = factory.updateMethodSignature(
-          lastDeclaration,
-          lastDeclaration.modifiers,
-          lastDeclaration.name,
-          lastDeclaration.questionToken,
-          lastDeclaration.typeParameters,
-          getNewParametersForCombinedSignature(signatureDecls),
-          lastDeclaration.type
-        );
-        break;
+    function recordUsagebySymbol(identifier, usage, isTypeName) {
+      const symbol = getSymbolReferencedByIdentifier(identifier);
+      if (!symbol) {
+        return void 0;
       }
-      case 173 /* MethodDeclaration */: {
-        updated = factory.updateMethodDeclaration(
-          lastDeclaration,
-          lastDeclaration.modifiers,
-          lastDeclaration.asteriskToken,
-          lastDeclaration.name,
-          lastDeclaration.questionToken,
-          lastDeclaration.typeParameters,
-          getNewParametersForCombinedSignature(signatureDecls),
-          lastDeclaration.type,
-          lastDeclaration.body
-        );
-        break;
+      const symbolId = getSymbolId(symbol).toString();
+      const lastUsage = seenUsages.get(symbolId);
+      if (lastUsage && lastUsage >= usage) {
+        return symbolId;
       }
-      case 178 /* CallSignature */: {
-        updated = factory.updateCallSignature(
-          lastDeclaration,
-          lastDeclaration.typeParameters,
-          getNewParametersForCombinedSignature(signatureDecls),
-          lastDeclaration.type
-        );
-        break;
+      seenUsages.set(symbolId, usage);
+      if (lastUsage) {
+        for (const perScope of usagesPerScope) {
+          const prevEntry = perScope.usages.get(identifier.text);
+          if (prevEntry) {
+            perScope.usages.set(identifier.text, { usage, symbol, node: identifier });
+          }
+        }
+        return symbolId;
       }
-      case 175 /* Constructor */: {
-        updated = factory.updateConstructorDeclaration(
-          lastDeclaration,
-          lastDeclaration.modifiers,
-          getNewParametersForCombinedSignature(signatureDecls),
-          lastDeclaration.body
-        );
-        break;
+      const decls = symbol.getDeclarations();
+      const declInFile = decls && find(decls, (d) => d.getSourceFile() === sourceFile);
+      if (!declInFile) {
+        return void 0;
       }
-      case 179 /* ConstructSignature */: {
-        updated = factory.updateConstructSignature(
-          lastDeclaration,
-          lastDeclaration.typeParameters,
-          getNewParametersForCombinedSignature(signatureDecls),
-          lastDeclaration.type
-        );
-        break;
+      if (rangeContainsStartEnd(enclosingTextRange, declInFile.getStart(), declInFile.end)) {
+        return void 0;
       }
-      case 261 /* FunctionDeclaration */: {
-        updated = factory.updateFunctionDeclaration(
-          lastDeclaration,
-          lastDeclaration.modifiers,
-          lastDeclaration.asteriskToken,
-          lastDeclaration.name,
-          lastDeclaration.typeParameters,
-          getNewParametersForCombinedSignature(signatureDecls),
-          lastDeclaration.type,
-          lastDeclaration.body
+      if (targetRange.facts & 2 /* IsGenerator */ && usage === 2 /* Write */) {
+        const diag2 = createDiagnosticForNode(identifier, Messages.cannotExtractRangeThatContainsWritesToReferencesLocatedOutsideOfTheTargetRangeInGenerators);
+        for (const errors of functionErrorsPerScope) {
+          errors.push(diag2);
+        }
+        for (const errors of constantErrorsPerScope) {
+          errors.push(diag2);
+        }
+      }
+      for (let i = 0; i < scopes.length; i++) {
+        const scope = scopes[i];
+        const resolvedSymbol = checker.resolveName(
+          symbol.name,
+          scope,
+          symbol.flags,
+          /*excludeGlobals*/
+          false
         );
-        break;
+        if (resolvedSymbol === symbol) {
+          continue;
+        }
+        if (!substitutionsPerScope[i].has(symbolId)) {
+          const substitution = tryReplaceWithQualifiedNameOrPropertyAccess(symbol.exportSymbol || symbol, scope, isTypeName);
+          if (substitution) {
+            substitutionsPerScope[i].set(symbolId, substitution);
+          } else if (isTypeName) {
+            if (!(symbol.flags & 262144 /* TypeParameter */)) {
+              const diag2 = createDiagnosticForNode(identifier, Messages.typeWillNotBeVisibleInTheNewScope);
+              functionErrorsPerScope[i].push(diag2);
+              constantErrorsPerScope[i].push(diag2);
+            }
+          } else {
+            usagesPerScope[i].usages.set(identifier.text, { usage, symbol, node: identifier });
+          }
+        }
       }
-      default:
-        return Debug.failBadSyntaxKind(lastDeclaration, "Unhandled signature kind in overload list conversion refactoring");
-    }
-    if (updated === lastDeclaration) {
-      return;
+      return symbolId;
     }
-    const edits = ts_textChanges_exports.ChangeTracker.with(context, (t) => {
-      t.replaceNodeRange(file, signatureDecls[0], signatureDecls[signatureDecls.length - 1], updated);
-    });
-    return { renameFilename: void 0, renameLocation: void 0, edits };
-    function getNewParametersForCombinedSignature(signatureDeclarations) {
-      const lastSig = signatureDeclarations[signatureDeclarations.length - 1];
-      if (isFunctionLikeDeclaration(lastSig) && lastSig.body) {
-        signatureDeclarations = signatureDeclarations.slice(0, signatureDeclarations.length - 1);
+    function checkForUsedDeclarations(node) {
+      if (node === targetRange.range || isReadonlyArray(targetRange.range) && targetRange.range.includes(node)) {
+        return;
       }
-      return factory.createNodeArray([
-        factory.createParameterDeclaration(
-          /*modifiers*/
-          void 0,
-          factory.createToken(26 /* DotDotDotToken */),
-          "args",
-          /*questionToken*/
-          void 0,
-          factory.createUnionTypeNode(map(signatureDeclarations, convertSignatureParametersToTuple))
-        )
-      ]);
+      const sym = isIdentifier(node) ? getSymbolReferencedByIdentifier(node) : checker.getSymbolAtLocation(node);
+      if (sym) {
+        const decl = find(visibleDeclarationsInExtractedRange, (d) => d.symbol === sym);
+        if (decl) {
+          if (isVariableDeclaration(decl)) {
+            const idString = decl.symbol.id.toString();
+            if (!exposedVariableSymbolSet.has(idString)) {
+              exposedVariableDeclarations.push(decl);
+              exposedVariableSymbolSet.set(idString, true);
+            }
+          } else {
+            firstExposedNonVariableDeclaration = firstExposedNonVariableDeclaration || decl;
+          }
+        }
+      }
+      forEachChild(node, checkForUsedDeclarations);
     }
-    function convertSignatureParametersToTuple(decl) {
-      const members = map(decl.parameters, convertParameterToNamedTupleMember);
-      return setEmitFlags(factory.createTupleTypeNode(members), some(members, (m) => !!length(getSyntheticLeadingComments(m))) ? 0 /* None */ : 1 /* SingleLine */);
+    function getSymbolReferencedByIdentifier(identifier) {
+      return identifier.parent && isShorthandPropertyAssignment(identifier.parent) && identifier.parent.name === identifier ? checker.getShorthandAssignmentValueSymbol(identifier.parent) : checker.getSymbolAtLocation(identifier);
     }
-    function convertParameterToNamedTupleMember(p) {
-      Debug.assert(isIdentifier(p.name));
-      const result = setTextRange(factory.createNamedTupleMember(
-        p.dotDotDotToken,
-        p.name,
-        p.questionToken,
-        p.type || factory.createKeywordTypeNode(133 /* AnyKeyword */)
-      ), p);
-      const parameterDocComment = p.symbol && p.symbol.getDocumentationComment(checker);
-      if (parameterDocComment) {
-        const newComment = displayPartsToString(parameterDocComment);
-        if (newComment.length) {
-          setSyntheticLeadingComments(result, [{
-            text: `*
-${newComment.split("\n").map((c) => ` * ${c}`).join("\n")}
- `,
-            kind: 3 /* MultiLineCommentTrivia */,
-            pos: -1,
-            end: -1,
-            hasTrailingNewLine: true,
-            hasLeadingNewline: true
-          }]);
-        }
+    function tryReplaceWithQualifiedNameOrPropertyAccess(symbol, scopeDecl, isTypeNode2) {
+      if (!symbol) {
+        return void 0;
       }
-      return result;
+      const decls = symbol.getDeclarations();
+      if (decls && decls.some((d) => d.parent === scopeDecl)) {
+        return factory.createIdentifier(symbol.name);
+      }
+      const prefix = tryReplaceWithQualifiedNameOrPropertyAccess(symbol.parent, scopeDecl, isTypeNode2);
+      if (prefix === void 0) {
+        return void 0;
+      }
+      return isTypeNode2 ? factory.createQualifiedName(prefix, factory.createIdentifier(symbol.name)) : factory.createPropertyAccessExpression(prefix, symbol.name);
     }
   }
-  function isConvertableSignatureDeclaration(d) {
-    switch (d.kind) {
-      case 172 /* MethodSignature */:
-      case 173 /* MethodDeclaration */:
-      case 178 /* CallSignature */:
-      case 175 /* Constructor */:
-      case 179 /* ConstructSignature */:
-      case 261 /* FunctionDeclaration */:
-        return true;
-    }
-    return false;
+  function getExtractableParent(node) {
+    return findAncestor(node, (node2) => node2.parent && isExtractableExpression(node2) && !isBinaryExpression(node2.parent));
   }
-  function getConvertableOverloadListAtPosition(file, startPosition, program) {
-    const node = getTokenAtPosition(file, startPosition);
-    const containingDecl = findAncestor(node, isConvertableSignatureDeclaration);
-    if (!containingDecl) {
-      return;
-    }
-    if (isFunctionLikeDeclaration(containingDecl) && containingDecl.body && rangeContainsPosition(containingDecl.body, startPosition)) {
-      return;
-    }
-    const checker = program.getTypeChecker();
-    const signatureSymbol = containingDecl.symbol;
-    if (!signatureSymbol) {
-      return;
-    }
-    const decls = signatureSymbol.declarations;
-    if (length(decls) <= 1) {
-      return;
-    }
-    if (!every(decls, (d) => getSourceFileOfNode(d) === file)) {
-      return;
-    }
-    if (!isConvertableSignatureDeclaration(decls[0])) {
-      return;
+  function isExtractableExpression(node) {
+    const { parent: parent2 } = node;
+    switch (parent2.kind) {
+      case 306 /* EnumMember */:
+        return false;
     }
-    const kindOne = decls[0].kind;
-    if (!every(decls, (d) => d.kind === kindOne)) {
-      return;
+    switch (node.kind) {
+      case 11 /* StringLiteral */:
+        return parent2.kind !== 272 /* ImportDeclaration */ && parent2.kind !== 276 /* ImportSpecifier */;
+      case 230 /* SpreadElement */:
+      case 206 /* ObjectBindingPattern */:
+      case 208 /* BindingElement */:
+        return false;
+      case 80 /* Identifier */:
+        return parent2.kind !== 208 /* BindingElement */ && parent2.kind !== 276 /* ImportSpecifier */ && parent2.kind !== 281 /* ExportSpecifier */;
     }
-    const signatureDecls = decls;
-    if (some(signatureDecls, (d) => !!d.typeParameters || some(d.parameters, (p) => !!p.modifiers || !isIdentifier(p.name)))) {
-      return;
+    return true;
+  }
+  function isBlockLike(node) {
+    switch (node.kind) {
+      case 241 /* Block */:
+      case 312 /* SourceFile */:
+      case 268 /* ModuleBlock */:
+      case 296 /* CaseClause */:
+        return true;
+      default:
+        return false;
     }
-    const signatures = mapDefined(signatureDecls, (d) => checker.getSignatureFromDeclaration(d));
-    if (length(signatures) !== length(decls)) {
-      return;
+  }
+  function isInJSXContent(node) {
+    return isStringLiteralJsxAttribute(node) || (isJsxElement(node) || isJsxSelfClosingElement(node) || isJsxFragment(node)) && (isJsxElement(node.parent) || isJsxFragment(node.parent));
+  }
+  function isStringLiteralJsxAttribute(node) {
+    return isStringLiteral(node) && node.parent && isJsxAttribute(node.parent);
+  }
+  var refactorName12, extractConstantAction, extractFunctionAction, Messages, RangeFacts;
+  var init_extractSymbol = __esm({
+    "src/services/refactors/extractSymbol.ts"() {
+      "use strict";
+      init_ts4();
+      init_ts_refactor();
+      refactorName12 = "Extract Symbol";
+      extractConstantAction = {
+        name: "Extract Constant",
+        description: getLocaleSpecificMessage(Diagnostics.Extract_constant),
+        kind: "refactor.extract.constant"
+      };
+      extractFunctionAction = {
+        name: "Extract Function",
+        description: getLocaleSpecificMessage(Diagnostics.Extract_function),
+        kind: "refactor.extract.function"
+      };
+      registerRefactor(refactorName12, {
+        kinds: [
+          extractConstantAction.kind,
+          extractFunctionAction.kind
+        ],
+        getEditsForAction: getRefactorEditsToExtractSymbol,
+        getAvailableActions: getRefactorActionsToExtractSymbol
+      });
+      ((Messages2) => {
+        function createMessage(message) {
+          return { message, code: 0, category: 3 /* Message */, key: message };
+        }
+        Messages2.cannotExtractRange = createMessage("Cannot extract range.");
+        Messages2.cannotExtractImport = createMessage("Cannot extract import statement.");
+        Messages2.cannotExtractSuper = createMessage("Cannot extract super call.");
+        Messages2.cannotExtractJSDoc = createMessage("Cannot extract JSDoc.");
+        Messages2.cannotExtractEmpty = createMessage("Cannot extract empty range.");
+        Messages2.expressionExpected = createMessage("expression expected.");
+        Messages2.uselessConstantType = createMessage("No reason to extract constant of type.");
+        Messages2.statementOrExpressionExpected = createMessage("Statement or expression expected.");
+        Messages2.cannotExtractRangeContainingConditionalBreakOrContinueStatements = createMessage("Cannot extract range containing conditional break or continue statements.");
+        Messages2.cannotExtractRangeContainingConditionalReturnStatement = createMessage("Cannot extract range containing conditional return statement.");
+        Messages2.cannotExtractRangeContainingLabeledBreakOrContinueStatementWithTargetOutsideOfTheRange = createMessage("Cannot extract range containing labeled break or continue with target outside of the range.");
+        Messages2.cannotExtractRangeThatContainsWritesToReferencesLocatedOutsideOfTheTargetRangeInGenerators = createMessage("Cannot extract range containing writes to references located outside of the target range in generators.");
+        Messages2.typeWillNotBeVisibleInTheNewScope = createMessage("Type will not visible in the new scope.");
+        Messages2.functionWillNotBeVisibleInTheNewScope = createMessage("Function will not visible in the new scope.");
+        Messages2.cannotExtractIdentifier = createMessage("Select more than a single identifier.");
+        Messages2.cannotExtractExportedEntity = createMessage("Cannot extract exported declaration");
+        Messages2.cannotWriteInExpression = createMessage("Cannot write back side-effects when extracting an expression");
+        Messages2.cannotExtractReadonlyPropertyInitializerOutsideConstructor = createMessage("Cannot move initialization of read-only class property outside of the constructor");
+        Messages2.cannotExtractAmbientBlock = createMessage("Cannot extract code from ambient contexts");
+        Messages2.cannotAccessVariablesFromNestedScopes = createMessage("Cannot access variables from nested scopes");
+        Messages2.cannotExtractToJSClass = createMessage("Cannot extract constant to a class scope in JS");
+        Messages2.cannotExtractToExpressionArrowFunction = createMessage("Cannot extract constant to an arrow function without a block");
+        Messages2.cannotExtractFunctionsContainingThisToMethod = createMessage("Cannot extract functions containing this to method");
+      })(Messages || (Messages = {}));
+      RangeFacts = /* @__PURE__ */ ((RangeFacts2) => {
+        RangeFacts2[RangeFacts2["None"] = 0] = "None";
+        RangeFacts2[RangeFacts2["HasReturn"] = 1] = "HasReturn";
+        RangeFacts2[RangeFacts2["IsGenerator"] = 2] = "IsGenerator";
+        RangeFacts2[RangeFacts2["IsAsyncFunction"] = 4] = "IsAsyncFunction";
+        RangeFacts2[RangeFacts2["UsesThis"] = 8] = "UsesThis";
+        RangeFacts2[RangeFacts2["UsesThisInFunction"] = 16] = "UsesThisInFunction";
+        RangeFacts2[RangeFacts2["InStaticRegion"] = 32] = "InStaticRegion";
+        return RangeFacts2;
+      })(RangeFacts || {});
     }
-    const returnOne = checker.getReturnTypeOfSignature(signatures[0]);
-    if (!every(signatures, (s) => checker.getReturnTypeOfSignature(s) === returnOne)) {
-      return;
+  });
+
+  // src/services/_namespaces/ts.refactor.extractSymbol.ts
+  var ts_refactor_extractSymbol_exports = {};
+  __export(ts_refactor_extractSymbol_exports, {
+    Messages: () => Messages,
+    RangeFacts: () => RangeFacts,
+    getRangeToExtract: () => getRangeToExtract2,
+    getRefactorActionsToExtractSymbol: () => getRefactorActionsToExtractSymbol,
+    getRefactorEditsToExtractSymbol: () => getRefactorEditsToExtractSymbol
+  });
+  var init_ts_refactor_extractSymbol = __esm({
+    "src/services/_namespaces/ts.refactor.extractSymbol.ts"() {
+      "use strict";
+      init_extractSymbol();
     }
-    return signatureDecls;
-  }
-  var refactorName5, refactorDescription, functionOverloadAction;
-  var init_convertOverloadListToSingleSignature = __esm({
-    "src/services/refactors/convertOverloadListToSingleSignature.ts"() {
+  });
+
+  // src/services/refactors/generateGetAccessorAndSetAccessor.ts
+  var actionName, actionDescription, generateGetSetAction;
+  var init_generateGetAccessorAndSetAccessor = __esm({
+    "src/services/refactors/generateGetAccessorAndSetAccessor.ts"() {
       "use strict";
       init_ts4();
       init_ts_refactor();
-      refactorName5 = "Convert overload list to single signature";
-      refactorDescription = Diagnostics.Convert_overload_list_to_single_signature.message;
-      functionOverloadAction = {
-        name: refactorName5,
-        description: refactorDescription,
-        kind: "refactor.rewrite.function.overloadList"
+      actionName = "Generate 'get' and 'set' accessors";
+      actionDescription = getLocaleSpecificMessage(Diagnostics.Generate_get_and_set_accessors);
+      generateGetSetAction = {
+        name: actionName,
+        description: actionDescription,
+        kind: "refactor.rewrite.property.generateAccessors"
       };
-      registerRefactor(refactorName5, {
-        kinds: [functionOverloadAction.kind],
-        getEditsForAction: getRefactorEditsToConvertOverloadsToOneSignature,
-        getAvailableActions: getRefactorActionsToConvertOverloadsToOneSignature
+      registerRefactor(actionName, {
+        kinds: [generateGetSetAction.kind],
+        getEditsForAction: function getRefactorActionsToGenerateGetAndSetAccessors(context, actionName2) {
+          if (!context.endPosition)
+            return void 0;
+          const info = ts_codefix_exports.getAccessorConvertiblePropertyAtPosition(context.file, context.program, context.startPosition, context.endPosition);
+          Debug.assert(info && !isRefactorErrorInfo(info), "Expected applicable refactor info");
+          const edits = ts_codefix_exports.generateAccessorFromProperty(context.file, context.program, context.startPosition, context.endPosition, context, actionName2);
+          if (!edits)
+            return void 0;
+          const renameFilename = context.file.fileName;
+          const nameNeedRename = info.renameAccessor ? info.accessorName : info.fieldName;
+          const renameLocationOffset = isIdentifier(nameNeedRename) ? 0 : -1;
+          const renameLocation = renameLocationOffset + getRenameLocation(
+            edits,
+            renameFilename,
+            nameNeedRename.text,
+            /*preferLastLocation*/
+            isParameter(info.declaration)
+          );
+          return { renameFilename, renameLocation, edits };
+        },
+        getAvailableActions(context) {
+          if (!context.endPosition)
+            return emptyArray;
+          const info = ts_codefix_exports.getAccessorConvertiblePropertyAtPosition(context.file, context.program, context.startPosition, context.endPosition, context.triggerReason === "invoked");
+          if (!info)
+            return emptyArray;
+          if (!isRefactorErrorInfo(info)) {
+            return [{
+              name: actionName,
+              description: actionDescription,
+              actions: [generateGetSetAction]
+            }];
+          }
+          if (context.preferences.provideRefactorNotApplicableReason) {
+            return [{
+              name: actionName,
+              description: actionDescription,
+              actions: [{ ...generateGetSetAction, notApplicableReason: info.error }]
+            }];
+          }
+          return emptyArray;
+        }
       });
     }
   });
 
-  // src/services/refactors/addOrRemoveBracesToArrowFunction.ts
-  function getRefactorActionsToRemoveFunctionBraces(context) {
-    const { file, startPosition, triggerReason } = context;
-    const info = getConvertibleArrowFunctionAtPosition(file, startPosition, triggerReason === "invoked");
+  // src/services/_namespaces/ts.refactor.generateGetAccessorAndSetAccessor.ts
+  var ts_refactor_generateGetAccessorAndSetAccessor_exports = {};
+  var init_ts_refactor_generateGetAccessorAndSetAccessor = __esm({
+    "src/services/_namespaces/ts.refactor.generateGetAccessorAndSetAccessor.ts"() {
+      "use strict";
+      init_generateGetAccessorAndSetAccessor();
+    }
+  });
+
+  // src/services/refactors/inferFunctionReturnType.ts
+  function getRefactorEditsToInferReturnType(context) {
+    const info = getInfo4(context);
+    if (info && !isRefactorErrorInfo(info)) {
+      const edits = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange7(context.file, t, info.declaration, info.returnTypeNode));
+      return { renameFilename: void 0, renameLocation: void 0, edits };
+    }
+    return void 0;
+  }
+  function getRefactorActionsToInferReturnType(context) {
+    const info = getInfo4(context);
     if (!info)
       return emptyArray;
     if (!isRefactorErrorInfo(info)) {
       return [{
-        name: refactorName6,
-        description: refactorDescription2,
-        actions: [
-          info.addBraces ? addBracesAction : removeBracesAction
-        ]
+        name: refactorName13,
+        description: refactorDescription7,
+        actions: [inferReturnTypeAction]
       }];
     }
     if (context.preferences.provideRefactorNotApplicableReason) {
       return [{
-        name: refactorName6,
-        description: refactorDescription2,
-        actions: [
-          { ...addBracesAction, notApplicableReason: info.error },
-          { ...removeBracesAction, notApplicableReason: info.error }
-        ]
+        name: refactorName13,
+        description: refactorDescription7,
+        actions: [{ ...inferReturnTypeAction, notApplicableReason: info.error }]
       }];
     }
     return emptyArray;
   }
-  function getRefactorEditsToRemoveFunctionBraces(context, actionName2) {
-    const { file, startPosition } = context;
-    const info = getConvertibleArrowFunctionAtPosition(file, startPosition);
-    Debug.assert(info && !isRefactorErrorInfo(info), "Expected applicable refactor info");
-    const { expression, returnStatement, func } = info;
-    let body;
-    if (actionName2 === addBracesAction.name) {
-      const returnStatement2 = factory.createReturnStatement(expression);
-      body = factory.createBlock(
-        [returnStatement2],
-        /*multiLine*/
-        true
-      );
-      copyLeadingComments(
-        expression,
-        returnStatement2,
-        file,
-        3 /* MultiLineCommentTrivia */,
-        /*hasTrailingNewLine*/
-        true
-      );
-    } else if (actionName2 === removeBracesAction.name && returnStatement) {
-      const actualExpression = expression || factory.createVoidZero();
-      body = needsParentheses(actualExpression) ? factory.createParenthesizedExpression(actualExpression) : actualExpression;
-      copyTrailingAsLeadingComments(
-        returnStatement,
-        body,
-        file,
-        3 /* MultiLineCommentTrivia */,
-        /*hasTrailingNewLine*/
-        false
-      );
-      copyLeadingComments(
-        returnStatement,
-        body,
-        file,
-        3 /* MultiLineCommentTrivia */,
-        /*hasTrailingNewLine*/
-        false
-      );
-      copyTrailingComments(
-        returnStatement,
-        body,
-        file,
-        3 /* MultiLineCommentTrivia */,
-        /*hasTrailingNewLine*/
-        false
-      );
-    } else {
-      Debug.fail("invalid action");
+  function doChange7(sourceFile, changes, declaration, typeNode) {
+    const closeParen = findChildOfKind(declaration, 22 /* CloseParenToken */, sourceFile);
+    const needParens = isArrowFunction(declaration) && closeParen === void 0;
+    const endNode2 = needParens ? first(declaration.parameters) : closeParen;
+    if (endNode2) {
+      if (needParens) {
+        changes.insertNodeBefore(sourceFile, endNode2, factory.createToken(21 /* OpenParenToken */));
+        changes.insertNodeAfter(sourceFile, endNode2, factory.createToken(22 /* CloseParenToken */));
+      }
+      changes.insertNodeAt(sourceFile, endNode2.end, typeNode, { prefix: ": " });
     }
-    const edits = ts_textChanges_exports.ChangeTracker.with(context, (t) => {
-      t.replaceNode(file, func.body, body);
-    });
-    return { renameFilename: void 0, renameLocation: void 0, edits };
   }
-  function getConvertibleArrowFunctionAtPosition(file, startPosition, considerFunctionBodies = true, kind) {
-    const node = getTokenAtPosition(file, startPosition);
-    const func = getContainingFunction(node);
-    if (!func) {
-      return {
-        error: getLocaleSpecificMessage(Diagnostics.Could_not_find_a_containing_arrow_function)
-      };
+  function getInfo4(context) {
+    if (isInJSFile(context.file) || !refactorKindBeginsWith(inferReturnTypeAction.kind, context.kind))
+      return;
+    const token = getTouchingPropertyName(context.file, context.startPosition);
+    const declaration = findAncestor(token, (n) => isBlock(n) || n.parent && isArrowFunction(n.parent) && (n.kind === 39 /* EqualsGreaterThanToken */ || n.parent.body === n) ? "quit" : isConvertibleDeclaration(n));
+    if (!declaration || !declaration.body || declaration.type) {
+      return { error: getLocaleSpecificMessage(Diagnostics.Return_type_must_be_inferred_from_a_function) };
     }
-    if (!isArrowFunction(func)) {
-      return {
-        error: getLocaleSpecificMessage(Diagnostics.Containing_function_is_not_an_arrow_function)
-      };
+    const typeChecker = context.program.getTypeChecker();
+    const returnType = tryGetReturnType(typeChecker, declaration);
+    if (!returnType) {
+      return { error: getLocaleSpecificMessage(Diagnostics.Could_not_determine_function_return_type) };
     }
-    if (!rangeContainsRange(func, node) || rangeContainsRange(func.body, node) && !considerFunctionBodies) {
-      return void 0;
+    const returnTypeNode = typeChecker.typeToTypeNode(returnType, declaration, 1 /* NoTruncation */);
+    if (returnTypeNode) {
+      return { declaration, returnTypeNode };
     }
-    if (refactorKindBeginsWith(addBracesAction.kind, kind) && isExpression(func.body)) {
-      return { func, addBraces: true, expression: func.body };
-    } else if (refactorKindBeginsWith(removeBracesAction.kind, kind) && isBlock(func.body) && func.body.statements.length === 1) {
-      const firstStatement = first(func.body.statements);
-      if (isReturnStatement(firstStatement)) {
-        return { func, addBraces: false, expression: firstStatement.expression, returnStatement: firstStatement };
+  }
+  function isConvertibleDeclaration(node) {
+    switch (node.kind) {
+      case 262 /* FunctionDeclaration */:
+      case 218 /* FunctionExpression */:
+      case 219 /* ArrowFunction */:
+      case 174 /* MethodDeclaration */:
+        return true;
+      default:
+        return false;
+    }
+  }
+  function tryGetReturnType(typeChecker, node) {
+    if (typeChecker.isImplementationOfOverload(node)) {
+      const signatures = typeChecker.getTypeAtLocation(node).getCallSignatures();
+      if (signatures.length > 1) {
+        return typeChecker.getUnionType(mapDefined(signatures, (s) => s.getReturnType()));
       }
     }
-    return void 0;
+    const signature = typeChecker.getSignatureFromDeclaration(node);
+    if (signature) {
+      return typeChecker.getReturnTypeOfSignature(signature);
+    }
   }
-  var refactorName6, refactorDescription2, addBracesAction, removeBracesAction;
-  var init_addOrRemoveBracesToArrowFunction = __esm({
-    "src/services/refactors/addOrRemoveBracesToArrowFunction.ts"() {
+  var refactorName13, refactorDescription7, inferReturnTypeAction;
+  var init_inferFunctionReturnType = __esm({
+    "src/services/refactors/inferFunctionReturnType.ts"() {
       "use strict";
       init_ts4();
       init_ts_refactor();
-      refactorName6 = "Add or remove braces in an arrow function";
-      refactorDescription2 = Diagnostics.Add_or_remove_braces_in_an_arrow_function.message;
-      addBracesAction = {
-        name: "Add braces to arrow function",
-        description: Diagnostics.Add_braces_to_arrow_function.message,
-        kind: "refactor.rewrite.arrow.braces.add"
-      };
-      removeBracesAction = {
-        name: "Remove braces from arrow function",
-        description: Diagnostics.Remove_braces_from_arrow_function.message,
-        kind: "refactor.rewrite.arrow.braces.remove"
+      refactorName13 = "Infer function return type";
+      refactorDescription7 = getLocaleSpecificMessage(Diagnostics.Infer_function_return_type);
+      inferReturnTypeAction = {
+        name: refactorName13,
+        description: refactorDescription7,
+        kind: "refactor.rewrite.function.returnType"
       };
-      registerRefactor(refactorName6, {
-        kinds: [removeBracesAction.kind],
-        getEditsForAction: getRefactorEditsToRemoveFunctionBraces,
-        getAvailableActions: getRefactorActionsToRemoveFunctionBraces
+      registerRefactor(refactorName13, {
+        kinds: [inferReturnTypeAction.kind],
+        getEditsForAction: getRefactorEditsToInferReturnType,
+        getAvailableActions: getRefactorActionsToInferReturnType
       });
     }
   });
 
-  // src/services/_namespaces/ts.refactor.addOrRemoveBracesToArrowFunction.ts
-  var ts_refactor_addOrRemoveBracesToArrowFunction_exports = {};
-  var init_ts_refactor_addOrRemoveBracesToArrowFunction = __esm({
-    "src/services/_namespaces/ts.refactor.addOrRemoveBracesToArrowFunction.ts"() {
+  // src/services/_namespaces/ts.refactor.inferFunctionReturnType.ts
+  var ts_refactor_inferFunctionReturnType_exports = {};
+  var init_ts_refactor_inferFunctionReturnType = __esm({
+    "src/services/_namespaces/ts.refactor.inferFunctionReturnType.ts"() {
       "use strict";
-      init_convertOverloadListToSingleSignature();
-      init_addOrRemoveBracesToArrowFunction();
+      init_inferFunctionReturnType();
     }
   });
 
-  // src/services/refactors/convertArrowFunctionOrFunctionExpression.ts
-  function getRefactorActionsToConvertFunctionExpressions(context) {
-    const { file, startPosition, program, kind } = context;
-    const info = getFunctionInfo(file, startPosition, program);
-    if (!info)
-      return emptyArray;
-    const { selectedVariableDeclaration, func } = info;
-    const possibleActions = [];
-    const errors = [];
-    if (refactorKindBeginsWith(toNamedFunctionAction.kind, kind)) {
-      const error = selectedVariableDeclaration || isArrowFunction(func) && isVariableDeclaration(func.parent) ? void 0 : getLocaleSpecificMessage(Diagnostics.Could_not_convert_to_named_function);
-      if (error) {
-        errors.push({ ...toNamedFunctionAction, notApplicableReason: error });
-      } else {
-        possibleActions.push(toNamedFunctionAction);
-      }
-    }
-    if (refactorKindBeginsWith(toAnonymousFunctionAction.kind, kind)) {
-      const error = !selectedVariableDeclaration && isArrowFunction(func) ? void 0 : getLocaleSpecificMessage(Diagnostics.Could_not_convert_to_anonymous_function);
-      if (error) {
-        errors.push({ ...toAnonymousFunctionAction, notApplicableReason: error });
-      } else {
-        possibleActions.push(toAnonymousFunctionAction);
-      }
+  // src/services/_namespaces/ts.refactor.ts
+  var ts_refactor_exports = {};
+  __export(ts_refactor_exports, {
+    addExportToChanges: () => addExportToChanges,
+    addExports: () => addExports,
+    addNewFileToTsconfig: () => addNewFileToTsconfig,
+    addOrRemoveBracesToArrowFunction: () => ts_refactor_addOrRemoveBracesToArrowFunction_exports,
+    convertArrowFunctionOrFunctionExpression: () => ts_refactor_convertArrowFunctionOrFunctionExpression_exports,
+    convertParamsToDestructuredObject: () => ts_refactor_convertParamsToDestructuredObject_exports,
+    convertStringOrTemplateLiteral: () => ts_refactor_convertStringOrTemplateLiteral_exports,
+    convertToOptionalChainExpression: () => ts_refactor_convertToOptionalChainExpression_exports,
+    createNewFileName: () => createNewFileName,
+    createOldFileImportsFromTargetFile: () => createOldFileImportsFromTargetFile,
+    deleteMovedStatements: () => deleteMovedStatements,
+    deleteUnusedImports: () => deleteUnusedImports,
+    deleteUnusedOldImports: () => deleteUnusedOldImports,
+    doChangeNamedToNamespaceOrDefault: () => doChangeNamedToNamespaceOrDefault,
+    extractSymbol: () => ts_refactor_extractSymbol_exports,
+    filterImport: () => filterImport,
+    forEachImportInStatement: () => forEachImportInStatement,
+    generateGetAccessorAndSetAccessor: () => ts_refactor_generateGetAccessorAndSetAccessor_exports,
+    getApplicableRefactors: () => getApplicableRefactors,
+    getEditsForRefactor: () => getEditsForRefactor,
+    getStatementsToMove: () => getStatementsToMove,
+    getTopLevelDeclarationStatement: () => getTopLevelDeclarationStatement,
+    getUsageInfo: () => getUsageInfo,
+    inferFunctionReturnType: () => ts_refactor_inferFunctionReturnType_exports,
+    isRefactorErrorInfo: () => isRefactorErrorInfo,
+    isTopLevelDeclaration: () => isTopLevelDeclaration,
+    makeImportOrRequire: () => makeImportOrRequire,
+    moduleSpecifierFromImport: () => moduleSpecifierFromImport,
+    nameOfTopLevelDeclaration: () => nameOfTopLevelDeclaration,
+    refactorKindBeginsWith: () => refactorKindBeginsWith,
+    registerRefactor: () => registerRefactor,
+    updateImportsInOtherFiles: () => updateImportsInOtherFiles
+  });
+  var init_ts_refactor = __esm({
+    "src/services/_namespaces/ts.refactor.ts"() {
+      "use strict";
+      init_refactorProvider();
+      init_convertExport();
+      init_convertImport();
+      init_extractType();
+      init_helpers();
+      init_inlineVariable();
+      init_moveToNewFile();
+      init_moveToFile();
+      init_ts_refactor_addOrRemoveBracesToArrowFunction();
+      init_ts_refactor_convertArrowFunctionOrFunctionExpression();
+      init_ts_refactor_convertParamsToDestructuredObject();
+      init_ts_refactor_convertStringOrTemplateLiteral();
+      init_ts_refactor_convertToOptionalChainExpression();
+      init_ts_refactor_extractSymbol();
+      init_ts_refactor_generateGetAccessorAndSetAccessor();
+      init_ts_refactor_inferFunctionReturnType();
     }
-    if (refactorKindBeginsWith(toArrowFunctionAction.kind, kind)) {
-      const error = isFunctionExpression(func) ? void 0 : getLocaleSpecificMessage(Diagnostics.Could_not_convert_to_arrow_function);
-      if (error) {
-        errors.push({ ...toArrowFunctionAction, notApplicableReason: error });
-      } else {
-        possibleActions.push(toArrowFunctionAction);
-      }
+  });
+
+  // src/services/classifier2020.ts
+  function getSemanticClassifications2(program, cancellationToken, sourceFile, span) {
+    const classifications = getEncodedSemanticClassifications2(program, cancellationToken, sourceFile, span);
+    Debug.assert(classifications.spans.length % 3 === 0);
+    const dense = classifications.spans;
+    const result = [];
+    for (let i = 0; i < dense.length; i += 3) {
+      result.push({
+        textSpan: createTextSpan(dense[i], dense[i + 1]),
+        classificationType: dense[i + 2]
+      });
     }
-    return [{
-      name: refactorName7,
-      description: refactorDescription3,
-      actions: possibleActions.length === 0 && context.preferences.provideRefactorNotApplicableReason ? errors : possibleActions
-    }];
+    return result;
   }
-  function getRefactorEditsToConvertFunctionExpressions(context, actionName2) {
-    const { file, startPosition, program } = context;
-    const info = getFunctionInfo(file, startPosition, program);
-    if (!info)
-      return void 0;
-    const { func } = info;
-    const edits = [];
-    switch (actionName2) {
-      case toAnonymousFunctionAction.name:
-        edits.push(...getEditInfoForConvertToAnonymousFunction(context, func));
-        break;
-      case toNamedFunctionAction.name:
-        const variableInfo = getVariableInfo(func);
-        if (!variableInfo)
-          return void 0;
-        edits.push(...getEditInfoForConvertToNamedFunction(context, func, variableInfo));
-        break;
-      case toArrowFunctionAction.name:
-        if (!isFunctionExpression(func))
-          return void 0;
-        edits.push(...getEditInfoForConvertToArrowFunction(context, func));
-        break;
-      default:
-        return Debug.fail("invalid action");
+  function getEncodedSemanticClassifications2(program, cancellationToken, sourceFile, span) {
+    return {
+      spans: getSemanticTokens(program, sourceFile, span, cancellationToken),
+      endOfLineState: 0 /* None */
+    };
+  }
+  function getSemanticTokens(program, sourceFile, span, cancellationToken) {
+    const resultTokens = [];
+    const collector = (node, typeIdx, modifierSet) => {
+      resultTokens.push(node.getStart(sourceFile), node.getWidth(sourceFile), (typeIdx + 1 << 8 /* typeOffset */) + modifierSet);
+    };
+    if (program && sourceFile) {
+      collectTokens(program, sourceFile, span, collector, cancellationToken);
     }
-    return { renameFilename: void 0, renameLocation: void 0, edits };
+    return resultTokens;
   }
-  function containingThis(node) {
-    let containsThis = false;
-    node.forEachChild(function checkThis(child) {
-      if (isThis(child)) {
-        containsThis = true;
+  function collectTokens(program, sourceFile, span, collector, cancellationToken) {
+    const typeChecker = program.getTypeChecker();
+    let inJSXElement = false;
+    function visit(node) {
+      switch (node.kind) {
+        case 267 /* ModuleDeclaration */:
+        case 263 /* ClassDeclaration */:
+        case 264 /* InterfaceDeclaration */:
+        case 262 /* FunctionDeclaration */:
+        case 231 /* ClassExpression */:
+        case 218 /* FunctionExpression */:
+        case 219 /* ArrowFunction */:
+          cancellationToken.throwIfCancellationRequested();
+      }
+      if (!node || !textSpanIntersectsWith(span, node.pos, node.getFullWidth()) || node.getFullWidth() === 0) {
         return;
       }
-      if (!isClassLike(child) && !isFunctionDeclaration(child) && !isFunctionExpression(child)) {
-        forEachChild(child, checkThis);
+      const prevInJSXElement = inJSXElement;
+      if (isJsxElement(node) || isJsxSelfClosingElement(node)) {
+        inJSXElement = true;
       }
-    });
-    return containsThis;
+      if (isJsxExpression(node)) {
+        inJSXElement = false;
+      }
+      if (isIdentifier(node) && !inJSXElement && !inImportClause(node) && !isInfinityOrNaNString(node.escapedText)) {
+        let symbol = typeChecker.getSymbolAtLocation(node);
+        if (symbol) {
+          if (symbol.flags & 2097152 /* Alias */) {
+            symbol = typeChecker.getAliasedSymbol(symbol);
+          }
+          let typeIdx = classifySymbol2(symbol, getMeaningFromLocation(node));
+          if (typeIdx !== void 0) {
+            let modifierSet = 0;
+            if (node.parent) {
+              const parentIsDeclaration = isBindingElement(node.parent) || tokenFromDeclarationMapping.get(node.parent.kind) === typeIdx;
+              if (parentIsDeclaration && node.parent.name === node) {
+                modifierSet = 1 << 0 /* declaration */;
+              }
+            }
+            if (typeIdx === 6 /* parameter */ && isRightSideOfQualifiedNameOrPropertyAccess2(node)) {
+              typeIdx = 9 /* property */;
+            }
+            typeIdx = reclassifyByType(typeChecker, node, typeIdx);
+            const decl = symbol.valueDeclaration;
+            if (decl) {
+              const modifiers = getCombinedModifierFlags(decl);
+              const nodeFlags = getCombinedNodeFlags(decl);
+              if (modifiers & 256 /* Static */) {
+                modifierSet |= 1 << 1 /* static */;
+              }
+              if (modifiers & 1024 /* Async */) {
+                modifierSet |= 1 << 2 /* async */;
+              }
+              if (typeIdx !== 0 /* class */ && typeIdx !== 2 /* interface */) {
+                if (modifiers & 8 /* Readonly */ || nodeFlags & 2 /* Const */ || symbol.getFlags() & 8 /* EnumMember */) {
+                  modifierSet |= 1 << 3 /* readonly */;
+                }
+              }
+              if ((typeIdx === 7 /* variable */ || typeIdx === 10 /* function */) && isLocalDeclaration(decl, sourceFile)) {
+                modifierSet |= 1 << 5 /* local */;
+              }
+              if (program.isSourceFileDefaultLibrary(decl.getSourceFile())) {
+                modifierSet |= 1 << 4 /* defaultLibrary */;
+              }
+            } else if (symbol.declarations && symbol.declarations.some((d) => program.isSourceFileDefaultLibrary(d.getSourceFile()))) {
+              modifierSet |= 1 << 4 /* defaultLibrary */;
+            }
+            collector(node, typeIdx, modifierSet);
+          }
+        }
+      }
+      forEachChild(node, visit);
+      inJSXElement = prevInJSXElement;
+    }
+    visit(sourceFile);
   }
-  function getFunctionInfo(file, startPosition, program) {
-    const token = getTokenAtPosition(file, startPosition);
-    const typeChecker = program.getTypeChecker();
-    const func = tryGetFunctionFromVariableDeclaration(file, typeChecker, token.parent);
-    if (func && !containingThis(func.body) && !typeChecker.containsArgumentsReference(func)) {
-      return { selectedVariableDeclaration: true, func };
+  function classifySymbol2(symbol, meaning) {
+    const flags = symbol.getFlags();
+    if (flags & 32 /* Class */) {
+      return 0 /* class */;
+    } else if (flags & 384 /* Enum */) {
+      return 1 /* enum */;
+    } else if (flags & 524288 /* TypeAlias */) {
+      return 5 /* type */;
+    } else if (flags & 64 /* Interface */) {
+      if (meaning & 2 /* Type */) {
+        return 2 /* interface */;
+      }
+    } else if (flags & 262144 /* TypeParameter */) {
+      return 4 /* typeParameter */;
     }
-    const maybeFunc = getContainingFunction(token);
-    if (maybeFunc && (isFunctionExpression(maybeFunc) || isArrowFunction(maybeFunc)) && !rangeContainsRange(maybeFunc.body, token) && !containingThis(maybeFunc.body) && !typeChecker.containsArgumentsReference(maybeFunc)) {
-      if (isFunctionExpression(maybeFunc) && isFunctionReferencedInFile(file, typeChecker, maybeFunc))
-        return void 0;
-      return { selectedVariableDeclaration: false, func: maybeFunc };
+    let decl = symbol.valueDeclaration || symbol.declarations && symbol.declarations[0];
+    if (decl && isBindingElement(decl)) {
+      decl = getDeclarationForBindingElement(decl);
     }
-    return void 0;
+    return decl && tokenFromDeclarationMapping.get(decl.kind);
   }
-  function isSingleVariableDeclaration(parent2) {
-    return isVariableDeclaration(parent2) || isVariableDeclarationList(parent2) && parent2.declarations.length === 1;
+  function reclassifyByType(typeChecker, node, typeIdx) {
+    if (typeIdx === 7 /* variable */ || typeIdx === 9 /* property */ || typeIdx === 6 /* parameter */) {
+      const type = typeChecker.getTypeAtLocation(node);
+      if (type) {
+        const test = (condition) => {
+          return condition(type) || type.isUnion() && type.types.some(condition);
+        };
+        if (typeIdx !== 6 /* parameter */ && test((t) => t.getConstructSignatures().length > 0)) {
+          return 0 /* class */;
+        }
+        if (test((t) => t.getCallSignatures().length > 0) && !test((t) => t.getProperties().length > 0) || isExpressionInCallExpression(node)) {
+          return typeIdx === 9 /* property */ ? 11 /* member */ : 10 /* function */;
+        }
+      }
+    }
+    return typeIdx;
   }
-  function tryGetFunctionFromVariableDeclaration(sourceFile, typeChecker, parent2) {
-    if (!isSingleVariableDeclaration(parent2)) {
-      return void 0;
+  function isLocalDeclaration(decl, sourceFile) {
+    if (isBindingElement(decl)) {
+      decl = getDeclarationForBindingElement(decl);
     }
-    const variableDeclaration = isVariableDeclaration(parent2) ? parent2 : first(parent2.declarations);
-    const initializer = variableDeclaration.initializer;
-    if (initializer && (isArrowFunction(initializer) || isFunctionExpression(initializer) && !isFunctionReferencedInFile(sourceFile, typeChecker, initializer))) {
-      return initializer;
+    if (isVariableDeclaration(decl)) {
+      return (!isSourceFile(decl.parent.parent.parent) || isCatchClause(decl.parent)) && decl.getSourceFile() === sourceFile;
+    } else if (isFunctionDeclaration(decl)) {
+      return !isSourceFile(decl.parent) && decl.getSourceFile() === sourceFile;
     }
-    return void 0;
+    return false;
   }
-  function convertToBlock(body) {
-    if (isExpression(body)) {
-      const returnStatement = factory.createReturnStatement(body);
-      const file = body.getSourceFile();
-      setTextRange(returnStatement, body);
-      suppressLeadingAndTrailingTrivia(returnStatement);
-      copyTrailingAsLeadingComments(
-        body,
-        returnStatement,
-        file,
-        /*commentKind*/
-        void 0,
-        /*hasTrailingNewLine*/
-        true
-      );
-      return factory.createBlock(
-        [returnStatement],
-        /*multiLine*/
-        true
-      );
-    } else {
-      return body;
+  function getDeclarationForBindingElement(element) {
+    while (true) {
+      if (isBindingElement(element.parent.parent)) {
+        element = element.parent.parent;
+      } else {
+        return element.parent.parent;
+      }
     }
   }
-  function getVariableInfo(func) {
-    const variableDeclaration = func.parent;
-    if (!isVariableDeclaration(variableDeclaration) || !isVariableDeclarationInVariableStatement(variableDeclaration))
-      return void 0;
-    const variableDeclarationList = variableDeclaration.parent;
-    const statement = variableDeclarationList.parent;
-    if (!isVariableDeclarationList(variableDeclarationList) || !isVariableStatement(statement) || !isIdentifier(variableDeclaration.name))
-      return void 0;
-    return { variableDeclaration, variableDeclarationList, statement, name: variableDeclaration.name };
-  }
-  function getEditInfoForConvertToAnonymousFunction(context, func) {
-    const { file } = context;
-    const body = convertToBlock(func.body);
-    const newNode = factory.createFunctionExpression(
-      func.modifiers,
-      func.asteriskToken,
-      /*name*/
-      void 0,
-      func.typeParameters,
-      func.parameters,
-      func.type,
-      body
-    );
-    return ts_textChanges_exports.ChangeTracker.with(context, (t) => t.replaceNode(file, func, newNode));
-  }
-  function getEditInfoForConvertToNamedFunction(context, func, variableInfo) {
-    const { file } = context;
-    const body = convertToBlock(func.body);
-    const { variableDeclaration, variableDeclarationList, statement, name } = variableInfo;
-    suppressLeadingTrivia(statement);
-    const modifiersFlags = getCombinedModifierFlags(variableDeclaration) & 1 /* Export */ | getEffectiveModifierFlags(func);
-    const modifiers = factory.createModifiersFromModifierFlags(modifiersFlags);
-    const newNode = factory.createFunctionDeclaration(length(modifiers) ? modifiers : void 0, func.asteriskToken, name, func.typeParameters, func.parameters, func.type, body);
-    if (variableDeclarationList.declarations.length === 1) {
-      return ts_textChanges_exports.ChangeTracker.with(context, (t) => t.replaceNode(file, statement, newNode));
-    } else {
-      return ts_textChanges_exports.ChangeTracker.with(context, (t) => {
-        t.delete(file, variableDeclaration);
-        t.insertNodeAfter(file, statement, newNode);
-      });
-    }
+  function inImportClause(node) {
+    const parent2 = node.parent;
+    return parent2 && (isImportClause(parent2) || isImportSpecifier(parent2) || isNamespaceImport(parent2));
   }
-  function getEditInfoForConvertToArrowFunction(context, func) {
-    const { file } = context;
-    const statements = func.body.statements;
-    const head = statements[0];
-    let body;
-    if (canBeConvertedToExpression(func.body, head)) {
-      body = head.expression;
-      suppressLeadingAndTrailingTrivia(body);
-      copyComments(head, body);
-    } else {
-      body = func.body;
+  function isExpressionInCallExpression(node) {
+    while (isRightSideOfQualifiedNameOrPropertyAccess2(node)) {
+      node = node.parent;
     }
-    const newNode = factory.createArrowFunction(func.modifiers, func.typeParameters, func.parameters, func.type, factory.createToken(39 /* EqualsGreaterThanToken */), body);
-    return ts_textChanges_exports.ChangeTracker.with(context, (t) => t.replaceNode(file, func, newNode));
-  }
-  function canBeConvertedToExpression(body, head) {
-    return body.statements.length === 1 && (isReturnStatement(head) && !!head.expression);
+    return isCallExpression(node.parent) && node.parent.expression === node;
   }
-  function isFunctionReferencedInFile(sourceFile, typeChecker, node) {
-    return !!node.name && ts_FindAllReferences_exports.Core.isSymbolReferencedInFile(node.name, typeChecker, sourceFile);
+  function isRightSideOfQualifiedNameOrPropertyAccess2(node) {
+    return isQualifiedName(node.parent) && node.parent.right === node || isPropertyAccessExpression(node.parent) && node.parent.name === node;
   }
-  var refactorName7, refactorDescription3, toAnonymousFunctionAction, toNamedFunctionAction, toArrowFunctionAction;
-  var init_convertArrowFunctionOrFunctionExpression = __esm({
-    "src/services/refactors/convertArrowFunctionOrFunctionExpression.ts"() {
+  var TokenEncodingConsts, TokenType, TokenModifier, tokenFromDeclarationMapping;
+  var init_classifier2020 = __esm({
+    "src/services/classifier2020.ts"() {
       "use strict";
       init_ts4();
-      init_ts_refactor();
-      refactorName7 = "Convert arrow function or function expression";
-      refactorDescription3 = getLocaleSpecificMessage(Diagnostics.Convert_arrow_function_or_function_expression);
-      toAnonymousFunctionAction = {
-        name: "Convert to anonymous function",
-        description: getLocaleSpecificMessage(Diagnostics.Convert_to_anonymous_function),
-        kind: "refactor.rewrite.function.anonymous"
-      };
-      toNamedFunctionAction = {
-        name: "Convert to named function",
-        description: getLocaleSpecificMessage(Diagnostics.Convert_to_named_function),
-        kind: "refactor.rewrite.function.named"
-      };
-      toArrowFunctionAction = {
-        name: "Convert to arrow function",
-        description: getLocaleSpecificMessage(Diagnostics.Convert_to_arrow_function),
-        kind: "refactor.rewrite.function.arrow"
-      };
-      registerRefactor(refactorName7, {
-        kinds: [
-          toAnonymousFunctionAction.kind,
-          toNamedFunctionAction.kind,
-          toArrowFunctionAction.kind
-        ],
-        getEditsForAction: getRefactorEditsToConvertFunctionExpressions,
-        getAvailableActions: getRefactorActionsToConvertFunctionExpressions
-      });
-    }
-  });
-
-  // src/services/_namespaces/ts.refactor.convertArrowFunctionOrFunctionExpression.ts
-  var ts_refactor_convertArrowFunctionOrFunctionExpression_exports = {};
-  var init_ts_refactor_convertArrowFunctionOrFunctionExpression = __esm({
-    "src/services/_namespaces/ts.refactor.convertArrowFunctionOrFunctionExpression.ts"() {
-      "use strict";
-      init_convertArrowFunctionOrFunctionExpression();
+      TokenEncodingConsts = /* @__PURE__ */ ((TokenEncodingConsts2) => {
+        TokenEncodingConsts2[TokenEncodingConsts2["typeOffset"] = 8] = "typeOffset";
+        TokenEncodingConsts2[TokenEncodingConsts2["modifierMask"] = 255] = "modifierMask";
+        return TokenEncodingConsts2;
+      })(TokenEncodingConsts || {});
+      TokenType = /* @__PURE__ */ ((TokenType2) => {
+        TokenType2[TokenType2["class"] = 0] = "class";
+        TokenType2[TokenType2["enum"] = 1] = "enum";
+        TokenType2[TokenType2["interface"] = 2] = "interface";
+        TokenType2[TokenType2["namespace"] = 3] = "namespace";
+        TokenType2[TokenType2["typeParameter"] = 4] = "typeParameter";
+        TokenType2[TokenType2["type"] = 5] = "type";
+        TokenType2[TokenType2["parameter"] = 6] = "parameter";
+        TokenType2[TokenType2["variable"] = 7] = "variable";
+        TokenType2[TokenType2["enumMember"] = 8] = "enumMember";
+        TokenType2[TokenType2["property"] = 9] = "property";
+        TokenType2[TokenType2["function"] = 10] = "function";
+        TokenType2[TokenType2["member"] = 11] = "member";
+        return TokenType2;
+      })(TokenType || {});
+      TokenModifier = /* @__PURE__ */ ((TokenModifier2) => {
+        TokenModifier2[TokenModifier2["declaration"] = 0] = "declaration";
+        TokenModifier2[TokenModifier2["static"] = 1] = "static";
+        TokenModifier2[TokenModifier2["async"] = 2] = "async";
+        TokenModifier2[TokenModifier2["readonly"] = 3] = "readonly";
+        TokenModifier2[TokenModifier2["defaultLibrary"] = 4] = "defaultLibrary";
+        TokenModifier2[TokenModifier2["local"] = 5] = "local";
+        return TokenModifier2;
+      })(TokenModifier || {});
+      tokenFromDeclarationMapping = /* @__PURE__ */ new Map([
+        [260 /* VariableDeclaration */, 7 /* variable */],
+        [169 /* Parameter */, 6 /* parameter */],
+        [172 /* PropertyDeclaration */, 9 /* property */],
+        [267 /* ModuleDeclaration */, 3 /* namespace */],
+        [266 /* EnumDeclaration */, 1 /* enum */],
+        [306 /* EnumMember */, 8 /* enumMember */],
+        [263 /* ClassDeclaration */, 0 /* class */],
+        [174 /* MethodDeclaration */, 11 /* member */],
+        [262 /* FunctionDeclaration */, 10 /* function */],
+        [218 /* FunctionExpression */, 10 /* function */],
+        [173 /* MethodSignature */, 11 /* member */],
+        [177 /* GetAccessor */, 9 /* property */],
+        [178 /* SetAccessor */, 9 /* property */],
+        [171 /* PropertySignature */, 9 /* property */],
+        [264 /* InterfaceDeclaration */, 2 /* interface */],
+        [265 /* TypeAliasDeclaration */, 5 /* type */],
+        [168 /* TypeParameter */, 4 /* typeParameter */],
+        [303 /* PropertyAssignment */, 9 /* property */],
+        [304 /* ShorthandPropertyAssignment */, 9 /* property */]
+      ]);
     }
   });
 
-  // src/services/refactors/convertParamsToDestructuredObject.ts
-  function getRefactorActionsToConvertParametersToDestructuredObject(context) {
-    const { file, startPosition } = context;
-    const isJSFile = isSourceFileJS(file);
-    if (isJSFile)
-      return emptyArray;
-    const functionDeclaration = getFunctionDeclarationAtPosition(file, startPosition, context.program.getTypeChecker());
-    if (!functionDeclaration)
-      return emptyArray;
-    return [{
-      name: refactorName8,
-      description: refactorDescription4,
-      actions: [toDestructuredAction]
-    }];
-  }
-  function getRefactorEditsToConvertParametersToDestructuredObject(context, actionName2) {
-    Debug.assert(actionName2 === refactorName8, "Unexpected action name");
-    const { file, startPosition, program, cancellationToken, host } = context;
-    const functionDeclaration = getFunctionDeclarationAtPosition(file, startPosition, program.getTypeChecker());
-    if (!functionDeclaration || !cancellationToken)
-      return void 0;
-    const groupedReferences = getGroupedReferences(functionDeclaration, program, cancellationToken);
-    if (groupedReferences.valid) {
-      const edits = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange5(file, program, host, t, functionDeclaration, groupedReferences));
-      return { renameFilename: void 0, renameLocation: void 0, edits };
-    }
-    return { edits: [] };
+  // src/services/services.ts
+  function createNode(kind, pos, end, parent2) {
+    const node = isNodeKind(kind) ? new NodeObject(kind, pos, end) : kind === 80 /* Identifier */ ? new IdentifierObject(80 /* Identifier */, pos, end) : kind === 81 /* PrivateIdentifier */ ? new PrivateIdentifierObject(81 /* PrivateIdentifier */, pos, end) : new TokenObject(kind, pos, end);
+    node.parent = parent2;
+    node.flags = parent2.flags & 101441536 /* ContextFlags */;
+    return node;
   }
-  function doChange5(sourceFile, program, host, changes, functionDeclaration, groupedReferences) {
-    const signature = groupedReferences.signature;
-    const newFunctionDeclarationParams = map(createNewParameters(functionDeclaration, program, host), (param) => getSynthesizedDeepClone(param));
-    if (signature) {
-      const newSignatureParams = map(createNewParameters(signature, program, host), (param) => getSynthesizedDeepClone(param));
-      replaceParameters(signature, newSignatureParams);
-    }
-    replaceParameters(functionDeclaration, newFunctionDeclarationParams);
-    const functionCalls = sortAndDeduplicate(
-      groupedReferences.functionCalls,
-      /*comparer*/
-      (a, b) => compareValues(a.pos, b.pos)
-    );
-    for (const call of functionCalls) {
-      if (call.arguments && call.arguments.length) {
-        const newArgument = getSynthesizedDeepClone(
-          createNewArgument(functionDeclaration, call.arguments),
-          /*includeTrivia*/
-          true
-        );
-        changes.replaceNodeRange(
-          getSourceFileOfNode(call),
-          first(call.arguments),
-          last(call.arguments),
-          newArgument,
-          { leadingTriviaOption: ts_textChanges_exports.LeadingTriviaOption.IncludeAll, trailingTriviaOption: ts_textChanges_exports.TrailingTriviaOption.Include }
-        );
-      }
+  function createChildren(node, sourceFile) {
+    if (!isNodeKind(node.kind)) {
+      return emptyArray;
     }
-    function replaceParameters(declarationOrSignature, parameterDeclarations) {
-      changes.replaceNodeRangeWithNodes(
-        sourceFile,
-        first(declarationOrSignature.parameters),
-        last(declarationOrSignature.parameters),
-        parameterDeclarations,
-        {
-          joiner: ", ",
-          // indentation is set to 0 because otherwise the object parameter will be indented if there is a `this` parameter
-          indentation: 0,
-          leadingTriviaOption: ts_textChanges_exports.LeadingTriviaOption.IncludeAll,
-          trailingTriviaOption: ts_textChanges_exports.TrailingTriviaOption.Include
-        }
-      );
+    const children = [];
+    if (isJSDocCommentContainingNode(node)) {
+      node.forEachChild((child) => {
+        children.push(child);
+      });
+      return children;
     }
+    scanner.setText((sourceFile || node.getSourceFile()).text);
+    let pos = node.pos;
+    const processNode = (child) => {
+      addSyntheticNodes(children, pos, child.pos, node);
+      children.push(child);
+      pos = child.end;
+    };
+    const processNodes = (nodes) => {
+      addSyntheticNodes(children, pos, nodes.pos, node);
+      children.push(createSyntaxList(nodes, node));
+      pos = nodes.end;
+    };
+    forEach(node.jsDoc, processNode);
+    pos = node.pos;
+    node.forEachChild(processNode, processNodes);
+    addSyntheticNodes(children, pos, node.end, node);
+    scanner.setText(void 0);
+    return children;
   }
-  function getGroupedReferences(functionDeclaration, program, cancellationToken) {
-    const functionNames = getFunctionNames(functionDeclaration);
-    const classNames = isConstructorDeclaration(functionDeclaration) ? getClassNames(functionDeclaration) : [];
-    const names = deduplicate([...functionNames, ...classNames], equateValues);
-    const checker = program.getTypeChecker();
-    const references = flatMap(
-      names,
-      /*mapfn*/
-      (name) => ts_FindAllReferences_exports.getReferenceEntriesForNode(-1, name, program, program.getSourceFiles(), cancellationToken)
-    );
-    const groupedReferences = groupReferences(references);
-    if (!every(
-      groupedReferences.declarations,
-      /*callback*/
-      (decl) => contains(names, decl)
-    )) {
-      groupedReferences.valid = false;
-    }
-    return groupedReferences;
-    function groupReferences(referenceEntries) {
-      const classReferences = { accessExpressions: [], typeUsages: [] };
-      const groupedReferences2 = { functionCalls: [], declarations: [], classReferences, valid: true };
-      const functionSymbols = map(functionNames, getSymbolTargetAtLocation);
-      const classSymbols = map(classNames, getSymbolTargetAtLocation);
-      const isConstructor = isConstructorDeclaration(functionDeclaration);
-      const contextualSymbols = map(functionNames, (name) => getSymbolForContextualType(name, checker));
-      for (const entry of referenceEntries) {
-        if (entry.kind === ts_FindAllReferences_exports.EntryKind.Span) {
-          groupedReferences2.valid = false;
-          continue;
-        }
-        if (contains(contextualSymbols, getSymbolTargetAtLocation(entry.node))) {
-          if (isValidMethodSignature(entry.node.parent)) {
-            groupedReferences2.signature = entry.node.parent;
-            continue;
-          }
-          const call = entryToFunctionCall(entry);
-          if (call) {
-            groupedReferences2.functionCalls.push(call);
-            continue;
-          }
-        }
-        const contextualSymbol = getSymbolForContextualType(entry.node, checker);
-        if (contextualSymbol && contains(contextualSymbols, contextualSymbol)) {
-          const decl = entryToDeclaration(entry);
-          if (decl) {
-            groupedReferences2.declarations.push(decl);
-            continue;
-          }
-        }
-        if (contains(functionSymbols, getSymbolTargetAtLocation(entry.node)) || isNewExpressionTarget(entry.node)) {
-          const importOrExportReference = entryToImportOrExport(entry);
-          if (importOrExportReference) {
-            continue;
-          }
-          const decl = entryToDeclaration(entry);
-          if (decl) {
-            groupedReferences2.declarations.push(decl);
-            continue;
-          }
-          const call = entryToFunctionCall(entry);
-          if (call) {
-            groupedReferences2.functionCalls.push(call);
-            continue;
-          }
-        }
-        if (isConstructor && contains(classSymbols, getSymbolTargetAtLocation(entry.node))) {
-          const importOrExportReference = entryToImportOrExport(entry);
-          if (importOrExportReference) {
-            continue;
-          }
-          const decl = entryToDeclaration(entry);
-          if (decl) {
-            groupedReferences2.declarations.push(decl);
-            continue;
-          }
-          const accessExpression = entryToAccessExpression(entry);
-          if (accessExpression) {
-            classReferences.accessExpressions.push(accessExpression);
+  function addSyntheticNodes(nodes, pos, end, parent2) {
+    scanner.resetTokenState(pos);
+    while (pos < end) {
+      const token = scanner.scan();
+      const textPos = scanner.getTokenEnd();
+      if (textPos <= end) {
+        if (token === 80 /* Identifier */) {
+          if (hasTabstop(parent2)) {
             continue;
           }
-          if (isClassDeclaration(functionDeclaration.parent)) {
-            const type = entryToType(entry);
-            if (type) {
-              classReferences.typeUsages.push(type);
-              continue;
-            }
-          }
+          Debug.fail(`Did not expect ${Debug.formatSyntaxKind(parent2.kind)} to have an Identifier in its trivia`);
         }
-        groupedReferences2.valid = false;
+        nodes.push(createNode(token, pos, textPos, parent2));
       }
-      return groupedReferences2;
-    }
-    function getSymbolTargetAtLocation(node) {
-      const symbol = checker.getSymbolAtLocation(node);
-      return symbol && getSymbolTarget(symbol, checker);
-    }
-  }
-  function getSymbolForContextualType(node, checker) {
-    const element = getContainingObjectLiteralElement(node);
-    if (element) {
-      const contextualType = checker.getContextualTypeForObjectLiteralElement(element);
-      const symbol = contextualType == null ? void 0 : contextualType.getSymbol();
-      if (symbol && !(getCheckFlags(symbol) & 6 /* Synthetic */)) {
-        return symbol;
+      pos = textPos;
+      if (token === 1 /* EndOfFileToken */) {
+        break;
       }
     }
   }
-  function entryToImportOrExport(entry) {
-    const node = entry.node;
-    if (isImportSpecifier(node.parent) || isImportClause(node.parent) || isImportEqualsDeclaration(node.parent) || isNamespaceImport(node.parent)) {
-      return node;
-    }
-    if (isExportSpecifier(node.parent) || isExportAssignment(node.parent)) {
-      return node;
+  function createSyntaxList(nodes, parent2) {
+    const list = createNode(358 /* SyntaxList */, nodes.pos, nodes.end, parent2);
+    list._children = [];
+    let pos = nodes.pos;
+    for (const node of nodes) {
+      addSyntheticNodes(list._children, pos, node.pos, parent2);
+      list._children.push(node);
+      pos = node.end;
     }
-    return void 0;
+    addSyntheticNodes(list._children, pos, nodes.end, parent2);
+    return list;
   }
-  function entryToDeclaration(entry) {
-    if (isDeclaration(entry.node.parent)) {
-      return entry.node;
-    }
-    return void 0;
+  function hasJSDocInheritDocTag(node) {
+    return getJSDocTags(node).some((tag) => tag.tagName.text === "inheritDoc" || tag.tagName.text === "inheritdoc");
   }
-  function entryToFunctionCall(entry) {
-    if (entry.node.parent) {
-      const functionReference = entry.node;
-      const parent2 = functionReference.parent;
-      switch (parent2.kind) {
-        case 212 /* CallExpression */:
-        case 213 /* NewExpression */:
-          const callOrNewExpression = tryCast(parent2, isCallOrNewExpression);
-          if (callOrNewExpression && callOrNewExpression.expression === functionReference) {
-            return callOrNewExpression;
-          }
-          break;
-        case 210 /* PropertyAccessExpression */:
-          const propertyAccessExpression = tryCast(parent2, isPropertyAccessExpression);
-          if (propertyAccessExpression && propertyAccessExpression.parent && propertyAccessExpression.name === functionReference) {
-            const callOrNewExpression2 = tryCast(propertyAccessExpression.parent, isCallOrNewExpression);
-            if (callOrNewExpression2 && callOrNewExpression2.expression === propertyAccessExpression) {
-              return callOrNewExpression2;
-            }
-          }
-          break;
-        case 211 /* ElementAccessExpression */:
-          const elementAccessExpression = tryCast(parent2, isElementAccessExpression);
-          if (elementAccessExpression && elementAccessExpression.parent && elementAccessExpression.argumentExpression === functionReference) {
-            const callOrNewExpression2 = tryCast(elementAccessExpression.parent, isCallOrNewExpression);
-            if (callOrNewExpression2 && callOrNewExpression2.expression === elementAccessExpression) {
-              return callOrNewExpression2;
+  function getJsDocTagsOfDeclarations(declarations, checker) {
+    if (!declarations)
+      return emptyArray;
+    let tags = ts_JsDoc_exports.getJsDocTagsFromDeclarations(declarations, checker);
+    if (checker && (tags.length === 0 || declarations.some(hasJSDocInheritDocTag))) {
+      const seenSymbols = /* @__PURE__ */ new Set();
+      for (const declaration of declarations) {
+        const inheritedTags = findBaseOfDeclaration(checker, declaration, (symbol) => {
+          var _a;
+          if (!seenSymbols.has(symbol)) {
+            seenSymbols.add(symbol);
+            if (declaration.kind === 177 /* GetAccessor */ || declaration.kind === 178 /* SetAccessor */) {
+              return symbol.getContextualJsDocTags(declaration, checker);
             }
+            return ((_a = symbol.declarations) == null ? void 0 : _a.length) === 1 ? symbol.getJsDocTags() : void 0;
           }
-          break;
-      }
-    }
-    return void 0;
-  }
-  function entryToAccessExpression(entry) {
-    if (entry.node.parent) {
-      const reference = entry.node;
-      const parent2 = reference.parent;
-      switch (parent2.kind) {
-        case 210 /* PropertyAccessExpression */:
-          const propertyAccessExpression = tryCast(parent2, isPropertyAccessExpression);
-          if (propertyAccessExpression && propertyAccessExpression.expression === reference) {
-            return propertyAccessExpression;
-          }
-          break;
-        case 211 /* ElementAccessExpression */:
-          const elementAccessExpression = tryCast(parent2, isElementAccessExpression);
-          if (elementAccessExpression && elementAccessExpression.expression === reference) {
-            return elementAccessExpression;
-          }
-          break;
+        });
+        if (inheritedTags) {
+          tags = [...inheritedTags, ...tags];
+        }
       }
     }
-    return void 0;
+    return tags;
   }
-  function entryToType(entry) {
-    const reference = entry.node;
-    if (getMeaningFromLocation(reference) === 2 /* Type */ || isExpressionWithTypeArgumentsInClassExtendsClause(reference.parent)) {
-      return reference;
+  function getDocumentationComment(declarations, checker) {
+    if (!declarations)
+      return emptyArray;
+    let doc = ts_JsDoc_exports.getJsDocCommentsFromDeclarations(declarations, checker);
+    if (checker && (doc.length === 0 || declarations.some(hasJSDocInheritDocTag))) {
+      const seenSymbols = /* @__PURE__ */ new Set();
+      for (const declaration of declarations) {
+        const inheritedDocs = findBaseOfDeclaration(checker, declaration, (symbol) => {
+          if (!seenSymbols.has(symbol)) {
+            seenSymbols.add(symbol);
+            if (declaration.kind === 177 /* GetAccessor */ || declaration.kind === 178 /* SetAccessor */) {
+              return symbol.getContextualDocumentationComment(declaration, checker);
+            }
+            return symbol.getDocumentationComment(checker);
+          }
+        });
+        if (inheritedDocs)
+          doc = doc.length === 0 ? inheritedDocs.slice() : inheritedDocs.concat(lineBreakPart(), doc);
+      }
     }
-    return void 0;
-  }
-  function getFunctionDeclarationAtPosition(file, startPosition, checker) {
-    const node = getTouchingToken(file, startPosition);
-    const functionDeclaration = getContainingFunctionDeclaration(node);
-    if (isTopLevelJSDoc(node))
-      return void 0;
-    if (functionDeclaration && isValidFunctionDeclaration(functionDeclaration, checker) && rangeContainsRange(functionDeclaration, node) && !(functionDeclaration.body && rangeContainsRange(functionDeclaration.body, node)))
-      return functionDeclaration;
-    return void 0;
+    return doc;
   }
-  function isTopLevelJSDoc(node) {
-    const containingJSDoc = findAncestor(node, isJSDocNode);
-    if (containingJSDoc) {
-      const containingNonJSDoc = findAncestor(containingJSDoc, (n) => !isJSDocNode(n));
-      return !!containingNonJSDoc && isFunctionLikeDeclaration(containingNonJSDoc);
-    }
-    return false;
+  function findBaseOfDeclaration(checker, declaration, cb) {
+    var _a;
+    const classOrInterfaceDeclaration = ((_a = declaration.parent) == null ? void 0 : _a.kind) === 176 /* Constructor */ ? declaration.parent.parent : declaration.parent;
+    if (!classOrInterfaceDeclaration)
+      return;
+    const isStaticMember = hasStaticModifier(declaration);
+    return firstDefined(getAllSuperTypeNodes(classOrInterfaceDeclaration), (superTypeNode) => {
+      const baseType = checker.getTypeAtLocation(superTypeNode);
+      const type = isStaticMember && baseType.symbol ? checker.getTypeOfSymbol(baseType.symbol) : baseType;
+      const symbol = checker.getPropertyOfType(type, declaration.symbol.name);
+      return symbol ? cb(symbol) : void 0;
+    });
   }
-  function isValidMethodSignature(node) {
-    return isMethodSignature(node) && (isInterfaceDeclaration(node.parent) || isTypeLiteralNode(node.parent));
+  function getServicesObjectAllocator() {
+    return {
+      getNodeConstructor: () => NodeObject,
+      getTokenConstructor: () => TokenObject,
+      getIdentifierConstructor: () => IdentifierObject,
+      getPrivateIdentifierConstructor: () => PrivateIdentifierObject,
+      getSourceFileConstructor: () => SourceFileObject,
+      getSymbolConstructor: () => SymbolObject,
+      getTypeConstructor: () => TypeObject,
+      getSignatureConstructor: () => SignatureObject,
+      getSourceMapSourceConstructor: () => SourceMapSourceObject
+    };
   }
-  function isValidFunctionDeclaration(functionDeclaration, checker) {
-    var _a;
-    if (!isValidParameterNodeArray(functionDeclaration.parameters, checker))
-      return false;
-    switch (functionDeclaration.kind) {
-      case 261 /* FunctionDeclaration */:
-        return hasNameOrDefault(functionDeclaration) && isSingleImplementation(functionDeclaration, checker);
-      case 173 /* MethodDeclaration */:
-        if (isObjectLiteralExpression(functionDeclaration.parent)) {
-          const contextualSymbol = getSymbolForContextualType(functionDeclaration.name, checker);
-          return ((_a = contextualSymbol == null ? void 0 : contextualSymbol.declarations) == null ? void 0 : _a.length) === 1 && isSingleImplementation(functionDeclaration, checker);
-        }
-        return isSingleImplementation(functionDeclaration, checker);
-      case 175 /* Constructor */:
-        if (isClassDeclaration(functionDeclaration.parent)) {
-          return hasNameOrDefault(functionDeclaration.parent) && isSingleImplementation(functionDeclaration, checker);
-        } else {
-          return isValidVariableDeclaration(functionDeclaration.parent.parent) && isSingleImplementation(functionDeclaration, checker);
-        }
-      case 217 /* FunctionExpression */:
-      case 218 /* ArrowFunction */:
-        return isValidVariableDeclaration(functionDeclaration.parent);
+  function toEditorSettings(optionsAsMap) {
+    let allPropertiesAreCamelCased = true;
+    for (const key in optionsAsMap) {
+      if (hasProperty(optionsAsMap, key) && !isCamelCase(key)) {
+        allPropertiesAreCamelCased = false;
+        break;
+      }
     }
-    return false;
+    if (allPropertiesAreCamelCased) {
+      return optionsAsMap;
+    }
+    const settings = {};
+    for (const key in optionsAsMap) {
+      if (hasProperty(optionsAsMap, key)) {
+        const newKey = isCamelCase(key) ? key : key.charAt(0).toLowerCase() + key.substr(1);
+        settings[newKey] = optionsAsMap[key];
+      }
+    }
+    return settings;
   }
-  function isSingleImplementation(functionDeclaration, checker) {
-    return !!functionDeclaration.body && !checker.isImplementationOfOverload(functionDeclaration);
+  function isCamelCase(s) {
+    return !s.length || s.charAt(0) === s.charAt(0).toLowerCase();
   }
-  function hasNameOrDefault(functionOrClassDeclaration) {
-    if (!functionOrClassDeclaration.name) {
-      const defaultKeyword = findModifier(functionOrClassDeclaration, 90 /* DefaultKeyword */);
-      return !!defaultKeyword;
+  function displayPartsToString(displayParts) {
+    if (displayParts) {
+      return map(displayParts, (displayPart2) => displayPart2.text).join("");
     }
-    return true;
+    return "";
   }
-  function isValidParameterNodeArray(parameters, checker) {
-    return getRefactorableParametersLength(parameters) >= minimumParameterLength && every(
-      parameters,
-      /*callback*/
-      (paramDecl) => isValidParameterDeclaration(paramDecl, checker)
-    );
+  function getDefaultCompilerOptions2() {
+    return {
+      target: 1 /* ES5 */,
+      jsx: 1 /* Preserve */
+    };
   }
-  function isValidParameterDeclaration(parameterDeclaration, checker) {
-    if (isRestParameter(parameterDeclaration)) {
-      const type = checker.getTypeAtLocation(parameterDeclaration);
-      if (!checker.isArrayType(type) && !checker.isTupleType(type))
-        return false;
-    }
-    return !parameterDeclaration.modifiers && isIdentifier(parameterDeclaration.name);
+  function getSupportedCodeFixes() {
+    return ts_codefix_exports.getSupportedErrorCodes();
   }
-  function isValidVariableDeclaration(node) {
-    return isVariableDeclaration(node) && isVarConst(node) && isIdentifier(node.name) && !node.type;
+  function setSourceFileFields(sourceFile, scriptSnapshot, version2) {
+    sourceFile.version = version2;
+    sourceFile.scriptSnapshot = scriptSnapshot;
   }
-  function hasThisParameter(parameters) {
-    return parameters.length > 0 && isThis(parameters[0].name);
+  function createLanguageServiceSourceFile(fileName, scriptSnapshot, scriptTargetOrOptions, version2, setNodeParents, scriptKind) {
+    const sourceFile = createSourceFile(fileName, getSnapshotText(scriptSnapshot), scriptTargetOrOptions, setNodeParents, scriptKind);
+    setSourceFileFields(sourceFile, scriptSnapshot, version2);
+    return sourceFile;
   }
-  function getRefactorableParametersLength(parameters) {
-    if (hasThisParameter(parameters)) {
-      return parameters.length - 1;
+  function updateLanguageServiceSourceFile(sourceFile, scriptSnapshot, version2, textChangeRange, aggressiveChecks) {
+    if (textChangeRange) {
+      if (version2 !== sourceFile.version) {
+        let newText;
+        const prefix = textChangeRange.span.start !== 0 ? sourceFile.text.substr(0, textChangeRange.span.start) : "";
+        const suffix = textSpanEnd(textChangeRange.span) !== sourceFile.text.length ? sourceFile.text.substr(textSpanEnd(textChangeRange.span)) : "";
+        if (textChangeRange.newLength === 0) {
+          newText = prefix && suffix ? prefix + suffix : prefix || suffix;
+        } else {
+          const changedText = scriptSnapshot.getText(textChangeRange.span.start, textChangeRange.span.start + textChangeRange.newLength);
+          newText = prefix && suffix ? prefix + changedText + suffix : prefix ? prefix + changedText : changedText + suffix;
+        }
+        const newSourceFile = updateSourceFile(sourceFile, newText, textChangeRange, aggressiveChecks);
+        setSourceFileFields(newSourceFile, scriptSnapshot, version2);
+        newSourceFile.nameTable = void 0;
+        if (sourceFile !== newSourceFile && sourceFile.scriptSnapshot) {
+          if (sourceFile.scriptSnapshot.dispose) {
+            sourceFile.scriptSnapshot.dispose();
+          }
+          sourceFile.scriptSnapshot = void 0;
+        }
+        return newSourceFile;
+      }
     }
-    return parameters.length;
+    const options = {
+      languageVersion: sourceFile.languageVersion,
+      impliedNodeFormat: sourceFile.impliedNodeFormat,
+      setExternalModuleIndicator: sourceFile.setExternalModuleIndicator,
+      jsDocParsingMode: sourceFile.jsDocParsingMode
+    };
+    return createLanguageServiceSourceFile(
+      sourceFile.fileName,
+      scriptSnapshot,
+      options,
+      version2,
+      /*setNodeParents*/
+      true,
+      sourceFile.scriptKind
+    );
   }
-  function getRefactorableParameters(parameters) {
-    if (hasThisParameter(parameters)) {
-      parameters = factory.createNodeArray(parameters.slice(1), parameters.hasTrailingComma);
+  function createLanguageService(host, documentRegistry = createDocumentRegistry(host.useCaseSensitiveFileNames && host.useCaseSensitiveFileNames(), host.getCurrentDirectory()), syntaxOnlyOrLanguageServiceMode) {
+    var _a;
+    let languageServiceMode;
+    if (syntaxOnlyOrLanguageServiceMode === void 0) {
+      languageServiceMode = 0 /* Semantic */;
+    } else if (typeof syntaxOnlyOrLanguageServiceMode === "boolean") {
+      languageServiceMode = syntaxOnlyOrLanguageServiceMode ? 2 /* Syntactic */ : 0 /* Semantic */;
+    } else {
+      languageServiceMode = syntaxOnlyOrLanguageServiceMode;
     }
-    return parameters;
-  }
-  function createPropertyOrShorthandAssignment(name, initializer) {
-    if (isIdentifier(initializer) && getTextOfIdentifierOrLiteral(initializer) === name) {
-      return factory.createShorthandPropertyAssignment(name);
+    const syntaxTreeCache = new SyntaxTreeCache(host);
+    let program;
+    let lastProjectVersion;
+    let lastTypesRootVersion = 0;
+    const cancellationToken = host.getCancellationToken ? new CancellationTokenObject(host.getCancellationToken()) : NoopCancellationToken;
+    const currentDirectory = host.getCurrentDirectory();
+    maybeSetLocalizedDiagnosticMessages((_a = host.getLocalizedDiagnosticMessages) == null ? void 0 : _a.bind(host));
+    function log(message) {
+      if (host.log) {
+        host.log(message);
+      }
     }
-    return factory.createPropertyAssignment(name, initializer);
-  }
-  function createNewArgument(functionDeclaration, functionArguments) {
-    const parameters = getRefactorableParameters(functionDeclaration.parameters);
-    const hasRestParameter2 = isRestParameter(last(parameters));
-    const nonRestArguments = hasRestParameter2 ? functionArguments.slice(0, parameters.length - 1) : functionArguments;
-    const properties = map(nonRestArguments, (arg, i) => {
-      const parameterName = getParameterName(parameters[i]);
-      const property = createPropertyOrShorthandAssignment(parameterName, arg);
-      suppressLeadingAndTrailingTrivia(property.name);
-      if (isPropertyAssignment(property))
-        suppressLeadingAndTrailingTrivia(property.initializer);
-      copyComments(arg, property);
-      return property;
+    const useCaseSensitiveFileNames2 = hostUsesCaseSensitiveFileNames(host);
+    const getCanonicalFileName = createGetCanonicalFileName(useCaseSensitiveFileNames2);
+    const sourceMapper = getSourceMapper({
+      useCaseSensitiveFileNames: () => useCaseSensitiveFileNames2,
+      getCurrentDirectory: () => currentDirectory,
+      getProgram,
+      fileExists: maybeBind(host, host.fileExists),
+      readFile: maybeBind(host, host.readFile),
+      getDocumentPositionMapper: maybeBind(host, host.getDocumentPositionMapper),
+      getSourceFileLike: maybeBind(host, host.getSourceFileLike),
+      log
     });
-    if (hasRestParameter2 && functionArguments.length >= parameters.length) {
-      const restArguments = functionArguments.slice(parameters.length - 1);
-      const restProperty = factory.createPropertyAssignment(getParameterName(last(parameters)), factory.createArrayLiteralExpression(restArguments));
-      properties.push(restProperty);
-    }
-    const objectLiteral = factory.createObjectLiteralExpression(
-      properties,
-      /*multiLine*/
-      false
-    );
-    return objectLiteral;
-  }
-  function createNewParameters(functionDeclaration, program, host) {
-    const checker = program.getTypeChecker();
-    const refactorableParameters = getRefactorableParameters(functionDeclaration.parameters);
-    const bindingElements = map(refactorableParameters, createBindingElementFromParameterDeclaration);
-    const objectParameterName = factory.createObjectBindingPattern(bindingElements);
-    const objectParameterType = createParameterTypeNode(refactorableParameters);
-    let objectInitializer;
-    if (every(refactorableParameters, isOptionalParameter)) {
-      objectInitializer = factory.createObjectLiteralExpression();
+    function getValidSourceFile(fileName) {
+      const sourceFile = program.getSourceFile(fileName);
+      if (!sourceFile) {
+        const error2 = new Error(`Could not find source file: '${fileName}'.`);
+        error2.ProgramFiles = program.getSourceFiles().map((f) => f.fileName);
+        throw error2;
+      }
+      return sourceFile;
     }
-    const objectParameter = factory.createParameterDeclaration(
-      /*modifiers*/
-      void 0,
-      /*dotDotDotToken*/
-      void 0,
-      objectParameterName,
-      /*questionToken*/
-      void 0,
-      objectParameterType,
-      objectInitializer
-    );
-    if (hasThisParameter(functionDeclaration.parameters)) {
-      const thisParameter = functionDeclaration.parameters[0];
-      const newThisParameter = factory.createParameterDeclaration(
-        /*modifiers*/
-        void 0,
-        /*dotDotDotToken*/
-        void 0,
-        thisParameter.name,
-        /*questionToken*/
-        void 0,
-        thisParameter.type
+    function synchronizeHostData() {
+      var _a2, _b, _c;
+      Debug.assert(languageServiceMode !== 2 /* Syntactic */);
+      if (host.getProjectVersion) {
+        const hostProjectVersion = host.getProjectVersion();
+        if (hostProjectVersion) {
+          if (lastProjectVersion === hostProjectVersion && !((_a2 = host.hasChangedAutomaticTypeDirectiveNames) == null ? void 0 : _a2.call(host))) {
+            return;
+          }
+          lastProjectVersion = hostProjectVersion;
+        }
+      }
+      const typeRootsVersion = host.getTypeRootsVersion ? host.getTypeRootsVersion() : 0;
+      if (lastTypesRootVersion !== typeRootsVersion) {
+        log("TypeRoots version has changed; provide new program");
+        program = void 0;
+        lastTypesRootVersion = typeRootsVersion;
+      }
+      const rootFileNames = host.getScriptFileNames().slice();
+      const newSettings = host.getCompilationSettings() || getDefaultCompilerOptions2();
+      const hasInvalidatedResolutions = host.hasInvalidatedResolutions || returnFalse;
+      const hasInvalidatedLibResolutions = maybeBind(host, host.hasInvalidatedLibResolutions) || returnFalse;
+      const hasChangedAutomaticTypeDirectiveNames = maybeBind(host, host.hasChangedAutomaticTypeDirectiveNames);
+      const projectReferences = (_b = host.getProjectReferences) == null ? void 0 : _b.call(host);
+      let parsedCommandLines;
+      let compilerHost = {
+        getSourceFile: getOrCreateSourceFile,
+        getSourceFileByPath: getOrCreateSourceFileByPath,
+        getCancellationToken: () => cancellationToken,
+        getCanonicalFileName,
+        useCaseSensitiveFileNames: () => useCaseSensitiveFileNames2,
+        getNewLine: () => getNewLineCharacter(newSettings),
+        getDefaultLibFileName: (options2) => host.getDefaultLibFileName(options2),
+        writeFile: noop,
+        getCurrentDirectory: () => currentDirectory,
+        fileExists: (fileName) => host.fileExists(fileName),
+        readFile: (fileName) => host.readFile && host.readFile(fileName),
+        getSymlinkCache: maybeBind(host, host.getSymlinkCache),
+        realpath: maybeBind(host, host.realpath),
+        directoryExists: (directoryName) => {
+          return directoryProbablyExists(directoryName, host);
+        },
+        getDirectories: (path) => {
+          return host.getDirectories ? host.getDirectories(path) : [];
+        },
+        readDirectory: (path, extensions, exclude, include, depth) => {
+          Debug.checkDefined(host.readDirectory, "'LanguageServiceHost.readDirectory' must be implemented to correctly process 'projectReferences'");
+          return host.readDirectory(path, extensions, exclude, include, depth);
+        },
+        onReleaseOldSourceFile,
+        onReleaseParsedCommandLine,
+        hasInvalidatedResolutions,
+        hasInvalidatedLibResolutions,
+        hasChangedAutomaticTypeDirectiveNames,
+        trace: maybeBind(host, host.trace),
+        resolveModuleNames: maybeBind(host, host.resolveModuleNames),
+        getModuleResolutionCache: maybeBind(host, host.getModuleResolutionCache),
+        createHash: maybeBind(host, host.createHash),
+        resolveTypeReferenceDirectives: maybeBind(host, host.resolveTypeReferenceDirectives),
+        resolveModuleNameLiterals: maybeBind(host, host.resolveModuleNameLiterals),
+        resolveTypeReferenceDirectiveReferences: maybeBind(host, host.resolveTypeReferenceDirectiveReferences),
+        resolveLibrary: maybeBind(host, host.resolveLibrary),
+        useSourceOfProjectReferenceRedirect: maybeBind(host, host.useSourceOfProjectReferenceRedirect),
+        getParsedCommandLine,
+        jsDocParsingMode: host.jsDocParsingMode
+      };
+      const originalGetSourceFile = compilerHost.getSourceFile;
+      const { getSourceFileWithCache } = changeCompilerHostLikeToUseCache(
+        compilerHost,
+        (fileName) => toPath(fileName, currentDirectory, getCanonicalFileName),
+        (...args) => originalGetSourceFile.call(compilerHost, ...args)
       );
-      suppressLeadingAndTrailingTrivia(newThisParameter.name);
-      copyComments(thisParameter.name, newThisParameter.name);
-      if (thisParameter.type) {
-        suppressLeadingAndTrailingTrivia(newThisParameter.type);
-        copyComments(thisParameter.type, newThisParameter.type);
+      compilerHost.getSourceFile = getSourceFileWithCache;
+      (_c = host.setCompilerHost) == null ? void 0 : _c.call(host, compilerHost);
+      const parseConfigHost = {
+        useCaseSensitiveFileNames: useCaseSensitiveFileNames2,
+        fileExists: (fileName) => compilerHost.fileExists(fileName),
+        readFile: (fileName) => compilerHost.readFile(fileName),
+        directoryExists: (f) => compilerHost.directoryExists(f),
+        getDirectories: (f) => compilerHost.getDirectories(f),
+        realpath: compilerHost.realpath,
+        readDirectory: (...args) => compilerHost.readDirectory(...args),
+        trace: compilerHost.trace,
+        getCurrentDirectory: compilerHost.getCurrentDirectory,
+        onUnRecoverableConfigFileDiagnostic: noop
+      };
+      const documentRegistryBucketKey = documentRegistry.getKeyForCompilationSettings(newSettings);
+      let releasedScriptKinds = /* @__PURE__ */ new Set();
+      if (isProgramUptoDate(program, rootFileNames, newSettings, (_path, fileName) => host.getScriptVersion(fileName), (fileName) => compilerHost.fileExists(fileName), hasInvalidatedResolutions, hasInvalidatedLibResolutions, hasChangedAutomaticTypeDirectiveNames, getParsedCommandLine, projectReferences)) {
+        compilerHost = void 0;
+        parsedCommandLines = void 0;
+        releasedScriptKinds = void 0;
+        return;
+      }
+      const options = {
+        rootNames: rootFileNames,
+        options: newSettings,
+        host: compilerHost,
+        oldProgram: program,
+        projectReferences
+      };
+      program = createProgram(options);
+      compilerHost = void 0;
+      parsedCommandLines = void 0;
+      releasedScriptKinds = void 0;
+      sourceMapper.clearCache();
+      program.getTypeChecker();
+      return;
+      function getParsedCommandLine(fileName) {
+        const path = toPath(fileName, currentDirectory, getCanonicalFileName);
+        const existing = parsedCommandLines == null ? void 0 : parsedCommandLines.get(path);
+        if (existing !== void 0)
+          return existing || void 0;
+        const result = host.getParsedCommandLine ? host.getParsedCommandLine(fileName) : getParsedCommandLineOfConfigFileUsingSourceFile(fileName);
+        (parsedCommandLines || (parsedCommandLines = /* @__PURE__ */ new Map())).set(path, result || false);
+        return result;
+      }
+      function getParsedCommandLineOfConfigFileUsingSourceFile(configFileName) {
+        const result = getOrCreateSourceFile(configFileName, 100 /* JSON */);
+        if (!result)
+          return void 0;
+        result.path = toPath(configFileName, currentDirectory, getCanonicalFileName);
+        result.resolvedPath = result.path;
+        result.originalFileName = result.fileName;
+        return parseJsonSourceFileConfigFileContent(
+          result,
+          parseConfigHost,
+          getNormalizedAbsolutePath(getDirectoryPath(configFileName), currentDirectory),
+          /*existingOptions*/
+          void 0,
+          getNormalizedAbsolutePath(configFileName, currentDirectory)
+        );
+      }
+      function onReleaseParsedCommandLine(configFileName, oldResolvedRef, oldOptions) {
+        var _a3;
+        if (host.getParsedCommandLine) {
+          (_a3 = host.onReleaseParsedCommandLine) == null ? void 0 : _a3.call(host, configFileName, oldResolvedRef, oldOptions);
+        } else if (oldResolvedRef) {
+          onReleaseOldSourceFile(oldResolvedRef.sourceFile, oldOptions);
+        }
+      }
+      function onReleaseOldSourceFile(oldSourceFile, oldOptions) {
+        const oldSettingsKey = documentRegistry.getKeyForCompilationSettings(oldOptions);
+        documentRegistry.releaseDocumentWithKey(oldSourceFile.resolvedPath, oldSettingsKey, oldSourceFile.scriptKind, oldSourceFile.impliedNodeFormat);
+      }
+      function getOrCreateSourceFile(fileName, languageVersionOrOptions, onError, shouldCreateNewSourceFile) {
+        return getOrCreateSourceFileByPath(fileName, toPath(fileName, currentDirectory, getCanonicalFileName), languageVersionOrOptions, onError, shouldCreateNewSourceFile);
+      }
+      function getOrCreateSourceFileByPath(fileName, path, languageVersionOrOptions, _onError, shouldCreateNewSourceFile) {
+        Debug.assert(compilerHost, "getOrCreateSourceFileByPath called after typical CompilerHost lifetime, check the callstack something with a reference to an old host.");
+        const scriptSnapshot = host.getScriptSnapshot(fileName);
+        if (!scriptSnapshot) {
+          return void 0;
+        }
+        const scriptKind = getScriptKind(fileName, host);
+        const scriptVersion = host.getScriptVersion(fileName);
+        if (!shouldCreateNewSourceFile) {
+          const oldSourceFile = program && program.getSourceFileByPath(path);
+          if (oldSourceFile) {
+            if (scriptKind === oldSourceFile.scriptKind || releasedScriptKinds.has(oldSourceFile.resolvedPath)) {
+              return documentRegistry.updateDocumentWithKey(fileName, path, host, documentRegistryBucketKey, scriptSnapshot, scriptVersion, scriptKind, languageVersionOrOptions);
+            } else {
+              documentRegistry.releaseDocumentWithKey(oldSourceFile.resolvedPath, documentRegistry.getKeyForCompilationSettings(program.getCompilerOptions()), oldSourceFile.scriptKind, oldSourceFile.impliedNodeFormat);
+              releasedScriptKinds.add(oldSourceFile.resolvedPath);
+            }
+          }
+        }
+        return documentRegistry.acquireDocumentWithKey(fileName, path, host, documentRegistryBucketKey, scriptSnapshot, scriptVersion, scriptKind, languageVersionOrOptions);
       }
-      return factory.createNodeArray([newThisParameter, objectParameter]);
     }
-    return factory.createNodeArray([objectParameter]);
-    function createBindingElementFromParameterDeclaration(parameterDeclaration) {
-      const element = factory.createBindingElement(
-        /*dotDotDotToken*/
-        void 0,
-        /*propertyName*/
-        void 0,
-        getParameterName(parameterDeclaration),
-        isRestParameter(parameterDeclaration) && isOptionalParameter(parameterDeclaration) ? factory.createArrayLiteralExpression() : parameterDeclaration.initializer
-      );
-      suppressLeadingAndTrailingTrivia(element);
-      if (parameterDeclaration.initializer && element.initializer) {
-        copyComments(parameterDeclaration.initializer, element.initializer);
+    function getProgram() {
+      if (languageServiceMode === 2 /* Syntactic */) {
+        Debug.assert(program === void 0);
+        return void 0;
       }
-      return element;
+      synchronizeHostData();
+      return program;
     }
-    function createParameterTypeNode(parameters) {
-      const members = map(parameters, createPropertySignatureFromParameterDeclaration);
-      const typeNode = addEmitFlags(factory.createTypeLiteralNode(members), 1 /* SingleLine */);
-      return typeNode;
+    function getAutoImportProvider() {
+      var _a2;
+      return (_a2 = host.getPackageJsonAutoImportProvider) == null ? void 0 : _a2.call(host);
     }
-    function createPropertySignatureFromParameterDeclaration(parameterDeclaration) {
-      let parameterType = parameterDeclaration.type;
-      if (!parameterType && (parameterDeclaration.initializer || isRestParameter(parameterDeclaration))) {
-        parameterType = getTypeNode3(parameterDeclaration);
+    function updateIsDefinitionOfReferencedSymbols(referencedSymbols, knownSymbolSpans) {
+      const checker = program.getTypeChecker();
+      const symbol = getSymbolForProgram();
+      if (!symbol)
+        return false;
+      for (const referencedSymbol of referencedSymbols) {
+        for (const ref of referencedSymbol.references) {
+          const refNode = getNodeForSpan(ref);
+          Debug.assertIsDefined(refNode);
+          if (knownSymbolSpans.has(ref) || ts_FindAllReferences_exports.isDeclarationOfSymbol(refNode, symbol)) {
+            knownSymbolSpans.add(ref);
+            ref.isDefinition = true;
+            const mappedSpan = getMappedDocumentSpan(ref, sourceMapper, maybeBind(host, host.fileExists));
+            if (mappedSpan) {
+              knownSymbolSpans.add(mappedSpan);
+            }
+          } else {
+            ref.isDefinition = false;
+          }
+        }
       }
-      const propertySignature = factory.createPropertySignature(
-        /*modifiers*/
-        void 0,
-        getParameterName(parameterDeclaration),
-        isOptionalParameter(parameterDeclaration) ? factory.createToken(58 /* QuestionToken */) : parameterDeclaration.questionToken,
-        parameterType
-      );
-      suppressLeadingAndTrailingTrivia(propertySignature);
-      copyComments(parameterDeclaration.name, propertySignature.name);
-      if (parameterDeclaration.type && propertySignature.type) {
-        copyComments(parameterDeclaration.type, propertySignature.type);
+      return true;
+      function getSymbolForProgram() {
+        for (const referencedSymbol of referencedSymbols) {
+          for (const ref of referencedSymbol.references) {
+            if (knownSymbolSpans.has(ref)) {
+              const refNode = getNodeForSpan(ref);
+              Debug.assertIsDefined(refNode);
+              return checker.getSymbolAtLocation(refNode);
+            }
+            const mappedSpan = getMappedDocumentSpan(ref, sourceMapper, maybeBind(host, host.fileExists));
+            if (mappedSpan && knownSymbolSpans.has(mappedSpan)) {
+              const refNode = getNodeForSpan(mappedSpan);
+              if (refNode) {
+                return checker.getSymbolAtLocation(refNode);
+              }
+            }
+          }
+        }
+        return void 0;
+      }
+      function getNodeForSpan(docSpan) {
+        const sourceFile = program.getSourceFile(docSpan.fileName);
+        if (!sourceFile)
+          return void 0;
+        const rawNode = getTouchingPropertyName(sourceFile, docSpan.textSpan.start);
+        const adjustedNode = ts_FindAllReferences_exports.Core.getAdjustedNode(rawNode, { use: ts_FindAllReferences_exports.FindReferencesUse.References });
+        return adjustedNode;
       }
-      return propertySignature;
-    }
-    function getTypeNode3(node) {
-      const type = checker.getTypeAtLocation(node);
-      return getTypeNodeIfAccessible(type, node, program, host);
     }
-    function isOptionalParameter(parameterDeclaration) {
-      if (isRestParameter(parameterDeclaration)) {
-        const type = checker.getTypeAtLocation(parameterDeclaration);
-        return !checker.isTupleType(type);
+    function cleanupSemanticCache() {
+      if (program) {
+        const key = documentRegistry.getKeyForCompilationSettings(program.getCompilerOptions());
+        forEach(program.getSourceFiles(), (f) => documentRegistry.releaseDocumentWithKey(f.resolvedPath, key, f.scriptKind, f.impliedNodeFormat));
+        program = void 0;
       }
-      return checker.isOptionalParameter(parameterDeclaration);
     }
-  }
-  function getParameterName(paramDeclaration) {
-    return getTextOfIdentifierOrLiteral(paramDeclaration.name);
-  }
-  function getClassNames(constructorDeclaration) {
-    switch (constructorDeclaration.parent.kind) {
-      case 262 /* ClassDeclaration */:
-        const classDeclaration = constructorDeclaration.parent;
-        if (classDeclaration.name)
-          return [classDeclaration.name];
-        const defaultModifier = Debug.checkDefined(
-          findModifier(classDeclaration, 90 /* DefaultKeyword */),
-          "Nameless class declaration should be a default export"
-        );
-        return [defaultModifier];
-      case 230 /* ClassExpression */:
-        const classExpression = constructorDeclaration.parent;
-        const variableDeclaration = constructorDeclaration.parent.parent;
-        const className = classExpression.name;
-        if (className)
-          return [className, variableDeclaration.name];
-        return [variableDeclaration.name];
+    function dispose() {
+      cleanupSemanticCache();
+      host = void 0;
     }
-  }
-  function getFunctionNames(functionDeclaration) {
-    switch (functionDeclaration.kind) {
-      case 261 /* FunctionDeclaration */:
-        if (functionDeclaration.name)
-          return [functionDeclaration.name];
-        const defaultModifier = Debug.checkDefined(
-          findModifier(functionDeclaration, 90 /* DefaultKeyword */),
-          "Nameless function declaration should be a default export"
-        );
-        return [defaultModifier];
-      case 173 /* MethodDeclaration */:
-        return [functionDeclaration.name];
-      case 175 /* Constructor */:
-        const ctrKeyword = Debug.checkDefined(
-          findChildOfKind(functionDeclaration, 137 /* ConstructorKeyword */, functionDeclaration.getSourceFile()),
-          "Constructor declaration should have constructor keyword"
-        );
-        if (functionDeclaration.parent.kind === 230 /* ClassExpression */) {
-          const variableDeclaration = functionDeclaration.parent.parent;
-          return [variableDeclaration.name, ctrKeyword];
-        }
-        return [ctrKeyword];
-      case 218 /* ArrowFunction */:
-        return [functionDeclaration.parent.name];
-      case 217 /* FunctionExpression */:
-        if (functionDeclaration.name)
-          return [functionDeclaration.name, functionDeclaration.parent.name];
-        return [functionDeclaration.parent.name];
-      default:
-        return Debug.assertNever(functionDeclaration, `Unexpected function declaration kind ${functionDeclaration.kind}`);
+    function getSyntacticDiagnostics(fileName) {
+      synchronizeHostData();
+      return program.getSyntacticDiagnostics(getValidSourceFile(fileName), cancellationToken).slice();
     }
-  }
-  var refactorName8, minimumParameterLength, refactorDescription4, toDestructuredAction;
-  var init_convertParamsToDestructuredObject = __esm({
-    "src/services/refactors/convertParamsToDestructuredObject.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_refactor();
-      refactorName8 = "Convert parameters to destructured object";
-      minimumParameterLength = 1;
-      refactorDescription4 = getLocaleSpecificMessage(Diagnostics.Convert_parameters_to_destructured_object);
-      toDestructuredAction = {
-        name: refactorName8,
-        description: refactorDescription4,
-        kind: "refactor.rewrite.parameters.toDestructured"
-      };
-      registerRefactor(refactorName8, {
-        kinds: [toDestructuredAction.kind],
-        getEditsForAction: getRefactorEditsToConvertParametersToDestructuredObject,
-        getAvailableActions: getRefactorActionsToConvertParametersToDestructuredObject
-      });
+    function getSemanticDiagnostics(fileName) {
+      synchronizeHostData();
+      const targetSourceFile = getValidSourceFile(fileName);
+      const semanticDiagnostics = program.getSemanticDiagnostics(targetSourceFile, cancellationToken);
+      if (!getEmitDeclarations(program.getCompilerOptions())) {
+        return semanticDiagnostics.slice();
+      }
+      const declarationDiagnostics = program.getDeclarationDiagnostics(targetSourceFile, cancellationToken);
+      return [...semanticDiagnostics, ...declarationDiagnostics];
     }
-  });
-
-  // src/services/_namespaces/ts.refactor.convertParamsToDestructuredObject.ts
-  var ts_refactor_convertParamsToDestructuredObject_exports = {};
-  var init_ts_refactor_convertParamsToDestructuredObject = __esm({
-    "src/services/_namespaces/ts.refactor.convertParamsToDestructuredObject.ts"() {
-      "use strict";
-      init_convertParamsToDestructuredObject();
+    function getSuggestionDiagnostics(fileName) {
+      synchronizeHostData();
+      return computeSuggestionDiagnostics(getValidSourceFile(fileName), program, cancellationToken);
     }
-  });
-
-  // src/services/refactors/convertStringOrTemplateLiteral.ts
-  function getRefactorActionsToConvertToTemplateString(context) {
-    const { file, startPosition } = context;
-    const node = getNodeOrParentOfParentheses(file, startPosition);
-    const maybeBinary = getParentBinaryExpression(node);
-    const refactorInfo = { name: refactorName9, description: refactorDescription5, actions: [] };
-    if (isBinaryExpression(maybeBinary) && treeToArray(maybeBinary).isValidConcatenation) {
-      refactorInfo.actions.push(convertStringAction);
-      return [refactorInfo];
-    } else if (context.preferences.provideRefactorNotApplicableReason) {
-      refactorInfo.actions.push({
-        ...convertStringAction,
-        notApplicableReason: getLocaleSpecificMessage(Diagnostics.Can_only_convert_string_concatenation)
-      });
-      return [refactorInfo];
+    function getCompilerOptionsDiagnostics() {
+      synchronizeHostData();
+      return [...program.getOptionsDiagnostics(cancellationToken), ...program.getGlobalDiagnostics(cancellationToken)];
     }
-    return emptyArray;
-  }
-  function getNodeOrParentOfParentheses(file, startPosition) {
-    const node = getTokenAtPosition(file, startPosition);
-    const nestedBinary = getParentBinaryExpression(node);
-    const isNonStringBinary = !treeToArray(nestedBinary).isValidConcatenation;
-    if (isNonStringBinary && isParenthesizedExpression(nestedBinary.parent) && isBinaryExpression(nestedBinary.parent.parent)) {
-      return nestedBinary.parent.parent;
+    function getCompletionsAtPosition2(fileName, position, options = emptyOptions, formattingSettings) {
+      const fullPreferences = {
+        ...identity(options),
+        // avoid excess property check
+        includeCompletionsForModuleExports: options.includeCompletionsForModuleExports || options.includeExternalModuleExports,
+        includeCompletionsWithInsertText: options.includeCompletionsWithInsertText || options.includeInsertTextCompletions
+      };
+      synchronizeHostData();
+      return ts_Completions_exports.getCompletionsAtPosition(
+        host,
+        program,
+        log,
+        getValidSourceFile(fileName),
+        position,
+        fullPreferences,
+        options.triggerCharacter,
+        options.triggerKind,
+        cancellationToken,
+        formattingSettings && ts_formatting_exports.getFormatContext(formattingSettings, host),
+        options.includeSymbol
+      );
     }
-    return node;
-  }
-  function getRefactorEditsToConvertToTemplateString(context, actionName2) {
-    const { file, startPosition } = context;
-    const node = getNodeOrParentOfParentheses(file, startPosition);
-    switch (actionName2) {
-      case refactorDescription5:
-        return { edits: getEditsForToTemplateLiteral(context, node) };
-      default:
-        return Debug.fail("invalid action");
+    function getCompletionEntryDetails2(fileName, position, name, formattingOptions, source, preferences = emptyOptions, data) {
+      synchronizeHostData();
+      return ts_Completions_exports.getCompletionEntryDetails(
+        program,
+        log,
+        getValidSourceFile(fileName),
+        position,
+        { name, source, data },
+        host,
+        formattingOptions && ts_formatting_exports.getFormatContext(formattingOptions, host),
+        // TODO: GH#18217
+        preferences,
+        cancellationToken
+      );
     }
-  }
-  function getEditsForToTemplateLiteral(context, node) {
-    const maybeBinary = getParentBinaryExpression(node);
-    const file = context.file;
-    const templateLiteral = nodesToTemplate(treeToArray(maybeBinary), file);
-    const trailingCommentRanges = getTrailingCommentRanges(file.text, maybeBinary.end);
-    if (trailingCommentRanges) {
-      const lastComment = trailingCommentRanges[trailingCommentRanges.length - 1];
-      const trailingRange = { pos: trailingCommentRanges[0].pos, end: lastComment.end };
-      return ts_textChanges_exports.ChangeTracker.with(context, (t) => {
-        t.deleteRange(file, trailingRange);
-        t.replaceNode(file, maybeBinary, templateLiteral);
-      });
-    } else {
-      return ts_textChanges_exports.ChangeTracker.with(context, (t) => t.replaceNode(file, maybeBinary, templateLiteral));
+    function getCompletionEntrySymbol2(fileName, position, name, source, preferences = emptyOptions) {
+      synchronizeHostData();
+      return ts_Completions_exports.getCompletionEntrySymbol(program, log, getValidSourceFile(fileName), position, { name, source }, host, preferences);
     }
-  }
-  function isNotEqualsOperator(node) {
-    return node.operatorToken.kind !== 64 /* EqualsToken */;
-  }
-  function getParentBinaryExpression(expr) {
-    const container = findAncestor(expr.parent, (n) => {
-      switch (n.kind) {
-        case 210 /* PropertyAccessExpression */:
-        case 211 /* ElementAccessExpression */:
-          return false;
-        case 227 /* TemplateExpression */:
-        case 225 /* BinaryExpression */:
-          return !(isBinaryExpression(n.parent) && isNotEqualsOperator(n.parent));
-        default:
-          return "quit";
+    function getQuickInfoAtPosition(fileName, position) {
+      synchronizeHostData();
+      const sourceFile = getValidSourceFile(fileName);
+      const node = getTouchingPropertyName(sourceFile, position);
+      if (node === sourceFile) {
+        return void 0;
       }
-    });
-    return container || expr;
-  }
-  function treeToArray(current) {
-    const loop = (current2) => {
-      if (!isBinaryExpression(current2)) {
-        return {
-          nodes: [current2],
-          operators: [],
-          validOperators: true,
-          hasString: isStringLiteral(current2) || isNoSubstitutionTemplateLiteral(current2)
+      const typeChecker = program.getTypeChecker();
+      const nodeForQuickInfo = getNodeForQuickInfo(node);
+      const symbol = getSymbolAtLocationForQuickInfo(nodeForQuickInfo, typeChecker);
+      if (!symbol || typeChecker.isUnknownSymbol(symbol)) {
+        const type = shouldGetType(sourceFile, nodeForQuickInfo, position) ? typeChecker.getTypeAtLocation(nodeForQuickInfo) : void 0;
+        return type && {
+          kind: "" /* unknown */,
+          kindModifiers: "" /* none */,
+          textSpan: createTextSpanFromNode(nodeForQuickInfo, sourceFile),
+          displayParts: typeChecker.runWithCancellationToken(cancellationToken, (typeChecker2) => typeToDisplayParts(typeChecker2, type, getContainerNode(nodeForQuickInfo))),
+          documentation: type.symbol ? type.symbol.getDocumentationComment(typeChecker) : void 0,
+          tags: type.symbol ? type.symbol.getJsDocTags(typeChecker) : void 0
         };
       }
-      const { nodes: nodes2, operators: operators2, hasString: leftHasString, validOperators: leftOperatorValid } = loop(current2.left);
-      if (!(leftHasString || isStringLiteral(current2.right) || isTemplateExpression(current2.right))) {
-        return { nodes: [current2], operators: [], hasString: false, validOperators: true };
+      const { symbolKind, displayParts, documentation, tags } = typeChecker.runWithCancellationToken(cancellationToken, (typeChecker2) => ts_SymbolDisplay_exports.getSymbolDisplayPartsDocumentationAndSymbolKind(typeChecker2, symbol, sourceFile, getContainerNode(nodeForQuickInfo), nodeForQuickInfo));
+      return {
+        kind: symbolKind,
+        kindModifiers: ts_SymbolDisplay_exports.getSymbolModifiers(typeChecker, symbol),
+        textSpan: createTextSpanFromNode(nodeForQuickInfo, sourceFile),
+        displayParts,
+        documentation,
+        tags
+      };
+    }
+    function getNodeForQuickInfo(node) {
+      if (isNewExpression(node.parent) && node.pos === node.parent.pos) {
+        return node.parent.expression;
       }
-      const currentOperatorValid = current2.operatorToken.kind === 40 /* PlusToken */;
-      const validOperators2 = leftOperatorValid && currentOperatorValid;
-      nodes2.push(current2.right);
-      operators2.push(current2.operatorToken);
-      return { nodes: nodes2, operators: operators2, hasString: true, validOperators: validOperators2 };
-    };
-    const { nodes, operators, validOperators, hasString } = loop(current);
-    return { nodes, operators, isValidConcatenation: validOperators && hasString };
-  }
-  function escapeRawStringForTemplate(s) {
-    return s.replace(/\\.|[$`]/g, (m) => m[0] === "\\" ? m : "\\" + m);
-  }
-  function getRawTextOfTemplate(node) {
-    const rightShaving = isTemplateHead(node) || isTemplateMiddle(node) ? -2 : -1;
-    return getTextOfNode(node).slice(1, rightShaving);
-  }
-  function concatConsecutiveString(index, nodes) {
-    const indexes = [];
-    let text = "", rawText = "";
-    while (index < nodes.length) {
-      const node = nodes[index];
-      if (isStringLiteralLike(node)) {
-        text += node.text;
-        rawText += escapeRawStringForTemplate(getTextOfNode(node).slice(1, -1));
-        indexes.push(index);
-        index++;
-      } else if (isTemplateExpression(node)) {
-        text += node.head.text;
-        rawText += getRawTextOfTemplate(node.head);
-        break;
-      } else {
-        break;
+      if (isNamedTupleMember(node.parent) && node.pos === node.parent.pos) {
+        return node.parent;
+      }
+      if (isImportMeta(node.parent) && node.parent.name === node) {
+        return node.parent;
       }
+      if (isJsxNamespacedName(node.parent)) {
+        return node.parent;
+      }
+      return node;
     }
-    return [index, text, rawText, indexes];
-  }
-  function nodesToTemplate({ nodes, operators }, file) {
-    const copyOperatorComments = copyTrailingOperatorComments(operators, file);
-    const copyCommentFromStringLiterals = copyCommentFromMultiNode(nodes, file, copyOperatorComments);
-    const [begin, headText, rawHeadText, headIndexes] = concatConsecutiveString(0, nodes);
-    if (begin === nodes.length) {
-      const noSubstitutionTemplateLiteral = factory.createNoSubstitutionTemplateLiteral(headText, rawHeadText);
-      copyCommentFromStringLiterals(headIndexes, noSubstitutionTemplateLiteral);
-      return noSubstitutionTemplateLiteral;
+    function shouldGetType(sourceFile, node, position) {
+      switch (node.kind) {
+        case 80 /* Identifier */:
+          return !isLabelName(node) && !isTagName(node) && !isConstTypeReference(node.parent);
+        case 211 /* PropertyAccessExpression */:
+        case 166 /* QualifiedName */:
+          return !isInComment(sourceFile, position);
+        case 110 /* ThisKeyword */:
+        case 197 /* ThisType */:
+        case 108 /* SuperKeyword */:
+        case 202 /* NamedTupleMember */:
+          return true;
+        case 236 /* MetaProperty */:
+          return isImportMeta(node);
+        default:
+          return false;
+      }
     }
-    const templateSpans = [];
-    const templateHead = factory.createTemplateHead(headText, rawHeadText);
-    copyCommentFromStringLiterals(headIndexes, templateHead);
-    for (let i = begin; i < nodes.length; i++) {
-      const currentNode = getExpressionFromParenthesesOrExpression(nodes[i]);
-      copyOperatorComments(i, currentNode);
-      const [newIndex, subsequentText, rawSubsequentText, stringIndexes] = concatConsecutiveString(i + 1, nodes);
-      i = newIndex - 1;
-      const isLast = i === nodes.length - 1;
-      if (isTemplateExpression(currentNode)) {
-        const spans = map(currentNode.templateSpans, (span, index) => {
-          copyExpressionComments(span);
-          const isLastSpan = index === currentNode.templateSpans.length - 1;
-          const text = span.literal.text + (isLastSpan ? subsequentText : "");
-          const rawText = getRawTextOfTemplate(span.literal) + (isLastSpan ? rawSubsequentText : "");
-          return factory.createTemplateSpan(span.expression, isLast && isLastSpan ? factory.createTemplateTail(text, rawText) : factory.createTemplateMiddle(text, rawText));
+    function getDefinitionAtPosition2(fileName, position, searchOtherFilesOnly, stopAtAlias) {
+      synchronizeHostData();
+      return ts_GoToDefinition_exports.getDefinitionAtPosition(program, getValidSourceFile(fileName), position, searchOtherFilesOnly, stopAtAlias);
+    }
+    function getDefinitionAndBoundSpan2(fileName, position) {
+      synchronizeHostData();
+      return ts_GoToDefinition_exports.getDefinitionAndBoundSpan(program, getValidSourceFile(fileName), position);
+    }
+    function getTypeDefinitionAtPosition2(fileName, position) {
+      synchronizeHostData();
+      return ts_GoToDefinition_exports.getTypeDefinitionAtPosition(program.getTypeChecker(), getValidSourceFile(fileName), position);
+    }
+    function getImplementationAtPosition(fileName, position) {
+      synchronizeHostData();
+      return ts_FindAllReferences_exports.getImplementationsAtPosition(program, cancellationToken, program.getSourceFiles(), getValidSourceFile(fileName), position);
+    }
+    function getDocumentHighlights(fileName, position, filesToSearch) {
+      const normalizedFileName = normalizePath(fileName);
+      Debug.assert(filesToSearch.some((f) => normalizePath(f) === normalizedFileName));
+      synchronizeHostData();
+      const sourceFilesToSearch = mapDefined(filesToSearch, (fileName2) => program.getSourceFile(fileName2));
+      const sourceFile = getValidSourceFile(fileName);
+      return DocumentHighlights.getDocumentHighlights(program, cancellationToken, sourceFile, position, sourceFilesToSearch);
+    }
+    function findRenameLocations(fileName, position, findInStrings, findInComments, preferences) {
+      synchronizeHostData();
+      const sourceFile = getValidSourceFile(fileName);
+      const node = getAdjustedRenameLocation(getTouchingPropertyName(sourceFile, position));
+      if (!ts_Rename_exports.nodeIsEligibleForRename(node))
+        return void 0;
+      if (isIdentifier(node) && (isJsxOpeningElement(node.parent) || isJsxClosingElement(node.parent)) && isIntrinsicJsxName(node.escapedText)) {
+        const { openingElement, closingElement } = node.parent.parent;
+        return [openingElement, closingElement].map((node2) => {
+          const textSpan = createTextSpanFromNode(node2.tagName, sourceFile);
+          return {
+            fileName: sourceFile.fileName,
+            textSpan,
+            ...ts_FindAllReferences_exports.toContextSpan(textSpan, sourceFile, node2.parent)
+          };
         });
-        templateSpans.push(...spans);
       } else {
-        const templatePart = isLast ? factory.createTemplateTail(subsequentText, rawSubsequentText) : factory.createTemplateMiddle(subsequentText, rawSubsequentText);
-        copyCommentFromStringLiterals(stringIndexes, templatePart);
-        templateSpans.push(factory.createTemplateSpan(currentNode, templatePart));
+        const quotePreference = getQuotePreference(sourceFile, preferences ?? emptyOptions);
+        const providePrefixAndSuffixTextForRename = typeof preferences === "boolean" ? preferences : preferences == null ? void 0 : preferences.providePrefixAndSuffixTextForRename;
+        return getReferencesWorker2(node, position, { findInStrings, findInComments, providePrefixAndSuffixTextForRename, use: ts_FindAllReferences_exports.FindReferencesUse.Rename }, (entry, originalNode, checker) => ts_FindAllReferences_exports.toRenameLocation(entry, originalNode, checker, providePrefixAndSuffixTextForRename || false, quotePreference));
       }
     }
-    return factory.createTemplateExpression(templateHead, templateSpans);
-  }
-  function copyExpressionComments(node) {
-    const file = node.getSourceFile();
-    copyTrailingComments(
-      node,
-      node.expression,
-      file,
-      3 /* MultiLineCommentTrivia */,
-      /*hasTrailingNewLine*/
-      false
-    );
-    copyTrailingAsLeadingComments(
-      node.expression,
-      node.expression,
-      file,
-      3 /* MultiLineCommentTrivia */,
-      /*hasTrailingNewLine*/
-      false
-    );
-  }
-  function getExpressionFromParenthesesOrExpression(node) {
-    if (isParenthesizedExpression(node)) {
-      copyExpressionComments(node);
-      node = node.expression;
+    function getReferencesAtPosition(fileName, position) {
+      synchronizeHostData();
+      return getReferencesWorker2(getTouchingPropertyName(getValidSourceFile(fileName), position), position, { use: ts_FindAllReferences_exports.FindReferencesUse.References }, ts_FindAllReferences_exports.toReferenceEntry);
     }
-    return node;
-  }
-  var refactorName9, refactorDescription5, convertStringAction, copyTrailingOperatorComments, copyCommentFromMultiNode;
-  var init_convertStringOrTemplateLiteral = __esm({
-    "src/services/refactors/convertStringOrTemplateLiteral.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_refactor();
-      refactorName9 = "Convert to template string";
-      refactorDescription5 = getLocaleSpecificMessage(Diagnostics.Convert_to_template_string);
-      convertStringAction = {
-        name: refactorName9,
-        description: refactorDescription5,
-        kind: "refactor.rewrite.string"
-      };
-      registerRefactor(refactorName9, {
-        kinds: [convertStringAction.kind],
-        getEditsForAction: getRefactorEditsToConvertToTemplateString,
-        getAvailableActions: getRefactorActionsToConvertToTemplateString
-      });
-      copyTrailingOperatorComments = (operators, file) => (index, targetNode) => {
-        if (index < operators.length) {
-          copyTrailingComments(
-            operators[index],
-            targetNode,
-            file,
-            3 /* MultiLineCommentTrivia */,
-            /*hasTrailingNewLine*/
-            false
-          );
-        }
-      };
-      copyCommentFromMultiNode = (nodes, file, copyOperatorComments) => (indexes, targetNode) => {
-        while (indexes.length > 0) {
-          const index = indexes.shift();
-          copyTrailingComments(
-            nodes[index],
-            targetNode,
-            file,
-            3 /* MultiLineCommentTrivia */,
-            /*hasTrailingNewLine*/
-            false
-          );
-          copyOperatorComments(index, targetNode);
+    function getReferencesWorker2(node, position, options, cb) {
+      synchronizeHostData();
+      const sourceFiles = options && options.use === ts_FindAllReferences_exports.FindReferencesUse.Rename ? program.getSourceFiles().filter((sourceFile) => !program.isSourceFileDefaultLibrary(sourceFile)) : program.getSourceFiles();
+      return ts_FindAllReferences_exports.findReferenceOrRenameEntries(program, cancellationToken, sourceFiles, node, position, options, cb);
+    }
+    function findReferences(fileName, position) {
+      synchronizeHostData();
+      return ts_FindAllReferences_exports.findReferencedSymbols(program, cancellationToken, program.getSourceFiles(), getValidSourceFile(fileName), position);
+    }
+    function getFileReferences(fileName) {
+      synchronizeHostData();
+      return ts_FindAllReferences_exports.Core.getReferencesForFileName(fileName, program, program.getSourceFiles()).map(ts_FindAllReferences_exports.toReferenceEntry);
+    }
+    function getNavigateToItems2(searchValue, maxResultCount, fileName, excludeDtsFiles = false, excludeLibFiles = false) {
+      synchronizeHostData();
+      const sourceFiles = fileName ? [getValidSourceFile(fileName)] : program.getSourceFiles();
+      return getNavigateToItems(sourceFiles, program.getTypeChecker(), cancellationToken, searchValue, maxResultCount, excludeDtsFiles, excludeLibFiles);
+    }
+    function getEmitOutput(fileName, emitOnlyDtsFiles, forceDtsEmit) {
+      synchronizeHostData();
+      const sourceFile = getValidSourceFile(fileName);
+      const customTransformers = host.getCustomTransformers && host.getCustomTransformers();
+      return getFileEmitOutput(program, sourceFile, !!emitOnlyDtsFiles, cancellationToken, customTransformers, forceDtsEmit);
+    }
+    function getSignatureHelpItems2(fileName, position, { triggerReason } = emptyOptions) {
+      synchronizeHostData();
+      const sourceFile = getValidSourceFile(fileName);
+      return ts_SignatureHelp_exports.getSignatureHelpItems(program, sourceFile, position, triggerReason, cancellationToken);
+    }
+    function getNonBoundSourceFile(fileName) {
+      return syntaxTreeCache.getCurrentSourceFile(fileName);
+    }
+    function getNameOrDottedNameSpan(fileName, startPos, _endPos) {
+      const sourceFile = syntaxTreeCache.getCurrentSourceFile(fileName);
+      const node = getTouchingPropertyName(sourceFile, startPos);
+      if (node === sourceFile) {
+        return void 0;
+      }
+      switch (node.kind) {
+        case 211 /* PropertyAccessExpression */:
+        case 166 /* QualifiedName */:
+        case 11 /* StringLiteral */:
+        case 97 /* FalseKeyword */:
+        case 112 /* TrueKeyword */:
+        case 106 /* NullKeyword */:
+        case 108 /* SuperKeyword */:
+        case 110 /* ThisKeyword */:
+        case 197 /* ThisType */:
+        case 80 /* Identifier */:
+          break;
+        default:
+          return void 0;
+      }
+      let nodeForStartPos = node;
+      while (true) {
+        if (isRightSideOfPropertyAccess(nodeForStartPos) || isRightSideOfQualifiedName(nodeForStartPos)) {
+          nodeForStartPos = nodeForStartPos.parent;
+        } else if (isNameOfModuleDeclaration(nodeForStartPos)) {
+          if (nodeForStartPos.parent.parent.kind === 267 /* ModuleDeclaration */ && nodeForStartPos.parent.parent.body === nodeForStartPos.parent) {
+            nodeForStartPos = nodeForStartPos.parent.parent.name;
+          } else {
+            break;
+          }
+        } else {
+          break;
         }
-      };
-    }
-  });
-
-  // src/services/_namespaces/ts.refactor.convertStringOrTemplateLiteral.ts
-  var ts_refactor_convertStringOrTemplateLiteral_exports = {};
-  var init_ts_refactor_convertStringOrTemplateLiteral = __esm({
-    "src/services/_namespaces/ts.refactor.convertStringOrTemplateLiteral.ts"() {
-      "use strict";
-      init_convertStringOrTemplateLiteral();
-    }
-  });
-
-  // src/services/refactors/convertToOptionalChainExpression.ts
-  function getRefactorActionsToConvertToOptionalChain(context) {
-    const info = getInfo3(context, context.triggerReason === "invoked");
-    if (!info)
-      return emptyArray;
-    if (!isRefactorErrorInfo(info)) {
-      return [{
-        name: refactorName10,
-        description: convertToOptionalChainExpressionMessage,
-        actions: [toOptionalChainAction]
-      }];
+      }
+      return createTextSpanFromBounds(nodeForStartPos.getStart(), node.getEnd());
     }
-    if (context.preferences.provideRefactorNotApplicableReason) {
-      return [{
-        name: refactorName10,
-        description: convertToOptionalChainExpressionMessage,
-        actions: [{ ...toOptionalChainAction, notApplicableReason: info.error }]
-      }];
+    function getBreakpointStatementAtPosition(fileName, position) {
+      const sourceFile = syntaxTreeCache.getCurrentSourceFile(fileName);
+      return ts_BreakpointResolver_exports.spanInSourceFileAtLocation(sourceFile, position);
     }
-    return emptyArray;
-  }
-  function getRefactorEditsToConvertToOptionalChain(context, actionName2) {
-    const info = getInfo3(context);
-    Debug.assert(info && !isRefactorErrorInfo(info), "Expected applicable refactor info");
-    const edits = ts_textChanges_exports.ChangeTracker.with(
-      context,
-      (t) => doChange6(context.file, context.program.getTypeChecker(), t, info, actionName2)
-    );
-    return { edits, renameFilename: void 0, renameLocation: void 0 };
-  }
-  function isValidExpression(node) {
-    return isBinaryExpression(node) || isConditionalExpression(node);
-  }
-  function isValidStatement(node) {
-    return isExpressionStatement(node) || isReturnStatement(node) || isVariableStatement(node);
-  }
-  function isValidExpressionOrStatement(node) {
-    return isValidExpression(node) || isValidStatement(node);
-  }
-  function getInfo3(context, considerEmptySpans = true) {
-    const { file, program } = context;
-    const span = getRefactorContextSpan(context);
-    const forEmptySpan = span.length === 0;
-    if (forEmptySpan && !considerEmptySpans)
-      return void 0;
-    const startToken = getTokenAtPosition(file, span.start);
-    const endToken = findTokenOnLeftOfPosition(file, span.start + span.length);
-    const adjustedSpan = createTextSpanFromBounds(startToken.pos, endToken && endToken.end >= startToken.pos ? endToken.getEnd() : startToken.getEnd());
-    const parent2 = forEmptySpan ? getValidParentNodeOfEmptySpan(startToken) : getValidParentNodeContainingSpan(startToken, adjustedSpan);
-    const expression = parent2 && isValidExpressionOrStatement(parent2) ? getExpression(parent2) : void 0;
-    if (!expression)
-      return { error: getLocaleSpecificMessage(Diagnostics.Could_not_find_convertible_access_expression) };
-    const checker = program.getTypeChecker();
-    return isConditionalExpression(expression) ? getConditionalInfo(expression, checker) : getBinaryInfo(expression);
-  }
-  function getConditionalInfo(expression, checker) {
-    const condition = expression.condition;
-    const finalExpression = getFinalExpressionInChain(expression.whenTrue);
-    if (!finalExpression || checker.isNullableType(checker.getTypeAtLocation(finalExpression))) {
-      return { error: getLocaleSpecificMessage(Diagnostics.Could_not_find_convertible_access_expression) };
+    function getNavigationBarItems2(fileName) {
+      return getNavigationBarItems(syntaxTreeCache.getCurrentSourceFile(fileName), cancellationToken);
     }
-    if ((isPropertyAccessExpression(condition) || isIdentifier(condition)) && getMatchingStart(condition, finalExpression.expression)) {
-      return { finalExpression, occurrences: [condition], expression };
-    } else if (isBinaryExpression(condition)) {
-      const occurrences = getOccurrencesInExpression(finalExpression.expression, condition);
-      return occurrences ? { finalExpression, occurrences, expression } : { error: getLocaleSpecificMessage(Diagnostics.Could_not_find_matching_access_expressions) };
+    function getNavigationTree2(fileName) {
+      return getNavigationTree(syntaxTreeCache.getCurrentSourceFile(fileName), cancellationToken);
     }
-  }
-  function getBinaryInfo(expression) {
-    if (expression.operatorToken.kind !== 56 /* AmpersandAmpersandToken */) {
-      return { error: getLocaleSpecificMessage(Diagnostics.Can_only_convert_logical_AND_access_chains) };
+    function getSemanticClassifications3(fileName, span, format) {
+      synchronizeHostData();
+      const responseFormat = format || "original" /* Original */;
+      if (responseFormat === "2020" /* TwentyTwenty */) {
+        return getSemanticClassifications2(program, cancellationToken, getValidSourceFile(fileName), span);
+      } else {
+        return getSemanticClassifications(program.getTypeChecker(), cancellationToken, getValidSourceFile(fileName), program.getClassifiableNames(), span);
+      }
     }
-    const finalExpression = getFinalExpressionInChain(expression.right);
-    if (!finalExpression)
-      return { error: getLocaleSpecificMessage(Diagnostics.Could_not_find_convertible_access_expression) };
-    const occurrences = getOccurrencesInExpression(finalExpression.expression, expression.left);
-    return occurrences ? { finalExpression, occurrences, expression } : { error: getLocaleSpecificMessage(Diagnostics.Could_not_find_matching_access_expressions) };
-  }
-  function getOccurrencesInExpression(matchTo, expression) {
-    const occurrences = [];
-    while (isBinaryExpression(expression) && expression.operatorToken.kind === 56 /* AmpersandAmpersandToken */) {
-      const match = getMatchingStart(skipParentheses(matchTo), skipParentheses(expression.right));
-      if (!match) {
-        break;
+    function getEncodedSemanticClassifications3(fileName, span, format) {
+      synchronizeHostData();
+      const responseFormat = format || "original" /* Original */;
+      if (responseFormat === "original" /* Original */) {
+        return getEncodedSemanticClassifications(program.getTypeChecker(), cancellationToken, getValidSourceFile(fileName), program.getClassifiableNames(), span);
+      } else {
+        return getEncodedSemanticClassifications2(program, cancellationToken, getValidSourceFile(fileName), span);
       }
-      occurrences.push(match);
-      matchTo = match;
-      expression = expression.left;
     }
-    const finalMatch = getMatchingStart(matchTo, expression);
-    if (finalMatch) {
-      occurrences.push(finalMatch);
+    function getSyntacticClassifications2(fileName, span) {
+      return getSyntacticClassifications(cancellationToken, syntaxTreeCache.getCurrentSourceFile(fileName), span);
     }
-    return occurrences.length > 0 ? occurrences : void 0;
-  }
-  function getMatchingStart(chain, subchain) {
-    if (!isIdentifier(subchain) && !isPropertyAccessExpression(subchain) && !isElementAccessExpression(subchain)) {
-      return void 0;
+    function getEncodedSyntacticClassifications2(fileName, span) {
+      return getEncodedSyntacticClassifications(cancellationToken, syntaxTreeCache.getCurrentSourceFile(fileName), span);
     }
-    return chainStartsWith(chain, subchain) ? subchain : void 0;
-  }
-  function chainStartsWith(chain, subchain) {
-    while (isCallExpression(chain) || isPropertyAccessExpression(chain) || isElementAccessExpression(chain)) {
-      if (getTextOfChainNode(chain) === getTextOfChainNode(subchain))
-        break;
-      chain = chain.expression;
+    function getOutliningSpans(fileName) {
+      const sourceFile = syntaxTreeCache.getCurrentSourceFile(fileName);
+      return ts_OutliningElementsCollector_exports.collectElements(sourceFile, cancellationToken);
     }
-    while (isPropertyAccessExpression(chain) && isPropertyAccessExpression(subchain) || isElementAccessExpression(chain) && isElementAccessExpression(subchain)) {
-      if (getTextOfChainNode(chain) !== getTextOfChainNode(subchain))
-        return false;
-      chain = chain.expression;
-      subchain = subchain.expression;
+    const braceMatching = new Map(Object.entries({
+      [19 /* OpenBraceToken */]: 20 /* CloseBraceToken */,
+      [21 /* OpenParenToken */]: 22 /* CloseParenToken */,
+      [23 /* OpenBracketToken */]: 24 /* CloseBracketToken */,
+      [32 /* GreaterThanToken */]: 30 /* LessThanToken */
+    }));
+    braceMatching.forEach((value, key) => braceMatching.set(value.toString(), Number(key)));
+    function getBraceMatchingAtPosition(fileName, position) {
+      const sourceFile = syntaxTreeCache.getCurrentSourceFile(fileName);
+      const token = getTouchingToken(sourceFile, position);
+      const matchKind = token.getStart(sourceFile) === position ? braceMatching.get(token.kind.toString()) : void 0;
+      const match = matchKind && findChildOfKind(token.parent, matchKind, sourceFile);
+      return match ? [createTextSpanFromNode(token, sourceFile), createTextSpanFromNode(match, sourceFile)].sort((a, b) => a.start - b.start) : emptyArray;
     }
-    return isIdentifier(chain) && isIdentifier(subchain) && chain.getText() === subchain.getText();
-  }
-  function getTextOfChainNode(node) {
-    if (isIdentifier(node) || isStringOrNumericLiteralLike(node)) {
-      return node.getText();
+    function getIndentationAtPosition(fileName, position, editorOptions) {
+      let start = timestamp();
+      const settings = toEditorSettings(editorOptions);
+      const sourceFile = syntaxTreeCache.getCurrentSourceFile(fileName);
+      log("getIndentationAtPosition: getCurrentSourceFile: " + (timestamp() - start));
+      start = timestamp();
+      const result = ts_formatting_exports.SmartIndenter.getIndentation(position, sourceFile, settings);
+      log("getIndentationAtPosition: computeIndentation  : " + (timestamp() - start));
+      return result;
     }
-    if (isPropertyAccessExpression(node)) {
-      return getTextOfChainNode(node.name);
+    function getFormattingEditsForRange(fileName, start, end, options) {
+      const sourceFile = syntaxTreeCache.getCurrentSourceFile(fileName);
+      return ts_formatting_exports.formatSelection(start, end, sourceFile, ts_formatting_exports.getFormatContext(toEditorSettings(options), host));
     }
-    if (isElementAccessExpression(node)) {
-      return getTextOfChainNode(node.argumentExpression);
+    function getFormattingEditsForDocument(fileName, options) {
+      return ts_formatting_exports.formatDocument(syntaxTreeCache.getCurrentSourceFile(fileName), ts_formatting_exports.getFormatContext(toEditorSettings(options), host));
     }
-    return void 0;
-  }
-  function getValidParentNodeContainingSpan(node, span) {
-    while (node.parent) {
-      if (isValidExpressionOrStatement(node) && span.length !== 0 && node.end >= span.start + span.length) {
-        return node;
+    function getFormattingEditsAfterKeystroke(fileName, position, key, options) {
+      const sourceFile = syntaxTreeCache.getCurrentSourceFile(fileName);
+      const formatContext = ts_formatting_exports.getFormatContext(toEditorSettings(options), host);
+      if (!isInComment(sourceFile, position)) {
+        switch (key) {
+          case "{":
+            return ts_formatting_exports.formatOnOpeningCurly(position, sourceFile, formatContext);
+          case "}":
+            return ts_formatting_exports.formatOnClosingCurly(position, sourceFile, formatContext);
+          case ";":
+            return ts_formatting_exports.formatOnSemicolon(position, sourceFile, formatContext);
+          case "\n":
+            return ts_formatting_exports.formatOnEnter(position, sourceFile, formatContext);
+        }
       }
-      node = node.parent;
+      return [];
     }
-    return void 0;
-  }
-  function getValidParentNodeOfEmptySpan(node) {
-    while (node.parent) {
-      if (isValidExpressionOrStatement(node) && !isValidExpressionOrStatement(node.parent)) {
-        return node;
-      }
-      node = node.parent;
+    function getCodeFixesAtPosition(fileName, start, end, errorCodes64, formatOptions, preferences = emptyOptions) {
+      synchronizeHostData();
+      const sourceFile = getValidSourceFile(fileName);
+      const span = createTextSpanFromBounds(start, end);
+      const formatContext = ts_formatting_exports.getFormatContext(formatOptions, host);
+      return flatMap(deduplicate(errorCodes64, equateValues, compareValues), (errorCode) => {
+        cancellationToken.throwIfCancellationRequested();
+        return ts_codefix_exports.getFixes({ errorCode, sourceFile, span, program, host, cancellationToken, formatContext, preferences });
+      });
     }
-    return void 0;
-  }
-  function getExpression(node) {
-    if (isValidExpression(node)) {
-      return node;
+    function getCombinedCodeFix(scope, fixId52, formatOptions, preferences = emptyOptions) {
+      synchronizeHostData();
+      Debug.assert(scope.type === "file");
+      const sourceFile = getValidSourceFile(scope.fileName);
+      const formatContext = ts_formatting_exports.getFormatContext(formatOptions, host);
+      return ts_codefix_exports.getAllFixes({ fixId: fixId52, sourceFile, program, host, cancellationToken, formatContext, preferences });
     }
-    if (isVariableStatement(node)) {
-      const variable = getSingleVariableOfVariableStatement(node);
-      const initializer = variable == null ? void 0 : variable.initializer;
-      return initializer && isValidExpression(initializer) ? initializer : void 0;
+    function organizeImports2(args, formatOptions, preferences = emptyOptions) {
+      synchronizeHostData();
+      Debug.assert(args.type === "file");
+      const sourceFile = getValidSourceFile(args.fileName);
+      const formatContext = ts_formatting_exports.getFormatContext(formatOptions, host);
+      const mode = args.mode ?? (args.skipDestructiveCodeActions ? "SortAndCombine" /* SortAndCombine */ : "All" /* All */);
+      return ts_OrganizeImports_exports.organizeImports(sourceFile, formatContext, host, program, preferences, mode);
     }
-    return node.expression && isValidExpression(node.expression) ? node.expression : void 0;
-  }
-  function getFinalExpressionInChain(node) {
-    node = skipParentheses(node);
-    if (isBinaryExpression(node)) {
-      return getFinalExpressionInChain(node.left);
-    } else if ((isPropertyAccessExpression(node) || isElementAccessExpression(node) || isCallExpression(node)) && !isOptionalChain(node)) {
-      return node;
+    function getEditsForFileRename2(oldFilePath, newFilePath, formatOptions, preferences = emptyOptions) {
+      return getEditsForFileRename(getProgram(), oldFilePath, newFilePath, host, ts_formatting_exports.getFormatContext(formatOptions, host), preferences, sourceMapper);
     }
-    return void 0;
-  }
-  function convertOccurrences(checker, toConvert, occurrences) {
-    if (isPropertyAccessExpression(toConvert) || isElementAccessExpression(toConvert) || isCallExpression(toConvert)) {
-      const chain = convertOccurrences(checker, toConvert.expression, occurrences);
-      const lastOccurrence = occurrences.length > 0 ? occurrences[occurrences.length - 1] : void 0;
-      const isOccurrence = (lastOccurrence == null ? void 0 : lastOccurrence.getText()) === toConvert.expression.getText();
-      if (isOccurrence)
-        occurrences.pop();
-      if (isCallExpression(toConvert)) {
-        return isOccurrence ? factory.createCallChain(chain, factory.createToken(29 /* QuestionDotToken */), toConvert.typeArguments, toConvert.arguments) : factory.createCallChain(chain, toConvert.questionDotToken, toConvert.typeArguments, toConvert.arguments);
-      } else if (isPropertyAccessExpression(toConvert)) {
-        return isOccurrence ? factory.createPropertyAccessChain(chain, factory.createToken(29 /* QuestionDotToken */), toConvert.name) : factory.createPropertyAccessChain(chain, toConvert.questionDotToken, toConvert.name);
-      } else if (isElementAccessExpression(toConvert)) {
-        return isOccurrence ? factory.createElementAccessChain(chain, factory.createToken(29 /* QuestionDotToken */), toConvert.argumentExpression) : factory.createElementAccessChain(chain, toConvert.questionDotToken, toConvert.argumentExpression);
-      }
+    function applyCodeActionCommand(fileName, actionOrFormatSettingsOrUndefined) {
+      const action = typeof fileName === "string" ? actionOrFormatSettingsOrUndefined : fileName;
+      return isArray(action) ? Promise.all(action.map((a) => applySingleCodeActionCommand(a))) : applySingleCodeActionCommand(action);
     }
-    return toConvert;
-  }
-  function doChange6(sourceFile, checker, changes, info, _actionName) {
-    const { finalExpression, occurrences, expression } = info;
-    const firstOccurrence = occurrences[occurrences.length - 1];
-    const convertedChain = convertOccurrences(checker, finalExpression, occurrences);
-    if (convertedChain && (isPropertyAccessExpression(convertedChain) || isElementAccessExpression(convertedChain) || isCallExpression(convertedChain))) {
-      if (isBinaryExpression(expression)) {
-        changes.replaceNodeRange(sourceFile, firstOccurrence, finalExpression, convertedChain);
-      } else if (isConditionalExpression(expression)) {
-        changes.replaceNode(
-          sourceFile,
-          expression,
-          factory.createBinaryExpression(convertedChain, factory.createToken(61 /* QuestionQuestionToken */), expression.whenFalse)
-        );
-      }
+    function applySingleCodeActionCommand(action) {
+      const getPath = (path) => toPath(path, currentDirectory, getCanonicalFileName);
+      Debug.assertEqual(action.type, "install package");
+      return host.installPackage ? host.installPackage({ fileName: getPath(action.file), packageName: action.packageName }) : Promise.reject("Host does not implement `installPackage`");
     }
-  }
-  var refactorName10, convertToOptionalChainExpressionMessage, toOptionalChainAction;
-  var init_convertToOptionalChainExpression = __esm({
-    "src/services/refactors/convertToOptionalChainExpression.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_refactor();
-      refactorName10 = "Convert to optional chain expression";
-      convertToOptionalChainExpressionMessage = getLocaleSpecificMessage(Diagnostics.Convert_to_optional_chain_expression);
-      toOptionalChainAction = {
-        name: refactorName10,
-        description: convertToOptionalChainExpressionMessage,
-        kind: "refactor.rewrite.expression.optionalChain"
-      };
-      registerRefactor(refactorName10, {
-        kinds: [toOptionalChainAction.kind],
-        getEditsForAction: getRefactorEditsToConvertToOptionalChain,
-        getAvailableActions: getRefactorActionsToConvertToOptionalChain
-      });
+    function getDocCommentTemplateAtPosition2(fileName, position, options, formatOptions) {
+      const formatSettings = formatOptions ? ts_formatting_exports.getFormatContext(formatOptions, host).options : void 0;
+      return ts_JsDoc_exports.getDocCommentTemplateAtPosition(getNewLineOrDefaultFromHost(host, formatSettings), syntaxTreeCache.getCurrentSourceFile(fileName), position, options);
     }
-  });
-
-  // src/services/_namespaces/ts.refactor.convertToOptionalChainExpression.ts
-  var ts_refactor_convertToOptionalChainExpression_exports = {};
-  var init_ts_refactor_convertToOptionalChainExpression = __esm({
-    "src/services/_namespaces/ts.refactor.convertToOptionalChainExpression.ts"() {
-      "use strict";
-      init_convertToOptionalChainExpression();
+    function isValidBraceCompletionAtPosition(fileName, position, openingBrace) {
+      if (openingBrace === 60 /* lessThan */) {
+        return false;
+      }
+      const sourceFile = syntaxTreeCache.getCurrentSourceFile(fileName);
+      if (isInString(sourceFile, position)) {
+        return false;
+      }
+      if (isInsideJsxElementOrAttribute(sourceFile, position)) {
+        return openingBrace === 123 /* openBrace */;
+      }
+      if (isInTemplateString(sourceFile, position)) {
+        return false;
+      }
+      switch (openingBrace) {
+        case 39 /* singleQuote */:
+        case 34 /* doubleQuote */:
+        case 96 /* backtick */:
+          return !isInComment(sourceFile, position);
+      }
+      return true;
     }
-  });
-
-  // src/services/refactors/extractSymbol.ts
-  function getRefactorActionsToExtractSymbol(context) {
-    const requestedRefactor = context.kind;
-    const rangeToExtract = getRangeToExtract2(context.file, getRefactorContextSpan(context), context.triggerReason === "invoked");
-    const targetRange = rangeToExtract.targetRange;
-    if (targetRange === void 0) {
-      if (!rangeToExtract.errors || rangeToExtract.errors.length === 0 || !context.preferences.provideRefactorNotApplicableReason) {
-        return emptyArray;
+    function getJsxClosingTagAtPosition(fileName, position) {
+      const sourceFile = syntaxTreeCache.getCurrentSourceFile(fileName);
+      const token = findPrecedingToken(position, sourceFile);
+      if (!token)
+        return void 0;
+      const element = token.kind === 32 /* GreaterThanToken */ && isJsxOpeningElement(token.parent) ? token.parent.parent : isJsxText(token) && isJsxElement(token.parent) ? token.parent : void 0;
+      if (element && isUnclosedTag(element)) {
+        return { newText: `` };
       }
-      const errors = [];
-      if (refactorKindBeginsWith(extractFunctionAction.kind, requestedRefactor)) {
-        errors.push({
-          name: refactorName11,
-          description: extractFunctionAction.description,
-          actions: [{ ...extractFunctionAction, notApplicableReason: getStringError(rangeToExtract.errors) }]
-        });
+      const fragment = token.kind === 32 /* GreaterThanToken */ && isJsxOpeningFragment(token.parent) ? token.parent.parent : isJsxText(token) && isJsxFragment(token.parent) ? token.parent : void 0;
+      if (fragment && isUnclosedFragment(fragment)) {
+        return { newText: "" };
       }
-      if (refactorKindBeginsWith(extractConstantAction.kind, requestedRefactor)) {
-        errors.push({
-          name: refactorName11,
-          description: extractConstantAction.description,
-          actions: [{ ...extractConstantAction, notApplicableReason: getStringError(rangeToExtract.errors) }]
+    }
+    function getLinkedEditingRangeAtPosition(fileName, position) {
+      const sourceFile = syntaxTreeCache.getCurrentSourceFile(fileName);
+      const token = findPrecedingToken(position, sourceFile);
+      if (!token || token.parent.kind === 312 /* SourceFile */)
+        return void 0;
+      const jsxTagWordPattern = "[a-zA-Z0-9:\\-\\._$]*";
+      if (isJsxFragment(token.parent.parent)) {
+        const openFragment = token.parent.parent.openingFragment;
+        const closeFragment = token.parent.parent.closingFragment;
+        if (containsParseError(openFragment) || containsParseError(closeFragment))
+          return void 0;
+        const openPos = openFragment.getStart(sourceFile) + 1;
+        const closePos = closeFragment.getStart(sourceFile) + 2;
+        if (position !== openPos && position !== closePos)
+          return void 0;
+        return {
+          ranges: [{ start: openPos, length: 0 }, { start: closePos, length: 0 }],
+          wordPattern: jsxTagWordPattern
+        };
+      } else {
+        const tag = findAncestor(token.parent, (n) => {
+          if (isJsxOpeningElement(n) || isJsxClosingElement(n)) {
+            return true;
+          }
+          return false;
         });
+        if (!tag)
+          return void 0;
+        Debug.assert(isJsxOpeningElement(tag) || isJsxClosingElement(tag), "tag should be opening or closing element");
+        const openTag = tag.parent.openingElement;
+        const closeTag = tag.parent.closingElement;
+        const openTagStart = openTag.tagName.getStart(sourceFile);
+        const openTagEnd = openTag.tagName.end;
+        const closeTagStart = closeTag.tagName.getStart(sourceFile);
+        const closeTagEnd = closeTag.tagName.end;
+        if (!(openTagStart <= position && position <= openTagEnd || closeTagStart <= position && position <= closeTagEnd))
+          return void 0;
+        const openingTagText = openTag.tagName.getText(sourceFile);
+        if (openingTagText !== closeTag.tagName.getText(sourceFile))
+          return void 0;
+        return {
+          ranges: [{ start: openTagStart, length: openTagEnd - openTagStart }, { start: closeTagStart, length: closeTagEnd - closeTagStart }],
+          wordPattern: jsxTagWordPattern
+        };
       }
-      return errors;
     }
-    const extractions = getPossibleExtractions(targetRange, context);
-    if (extractions === void 0) {
-      return emptyArray;
+    function getLinesForRange(sourceFile, textRange) {
+      return {
+        lineStarts: sourceFile.getLineStarts(),
+        firstLine: sourceFile.getLineAndCharacterOfPosition(textRange.pos).line,
+        lastLine: sourceFile.getLineAndCharacterOfPosition(textRange.end).line
+      };
     }
-    const functionActions = [];
-    const usedFunctionNames = /* @__PURE__ */ new Map();
-    let innermostErrorFunctionAction;
-    const constantActions = [];
-    const usedConstantNames = /* @__PURE__ */ new Map();
-    let innermostErrorConstantAction;
-    let i = 0;
-    for (const { functionExtraction, constantExtraction } of extractions) {
-      if (refactorKindBeginsWith(extractFunctionAction.kind, requestedRefactor)) {
-        const description3 = functionExtraction.description;
-        if (functionExtraction.errors.length === 0) {
-          if (!usedFunctionNames.has(description3)) {
-            usedFunctionNames.set(description3, true);
-            functionActions.push({
-              description: description3,
-              name: `function_scope_${i}`,
-              kind: extractFunctionAction.kind
+    function toggleLineComment(fileName, textRange, insertComment) {
+      const sourceFile = syntaxTreeCache.getCurrentSourceFile(fileName);
+      const textChanges2 = [];
+      const { lineStarts, firstLine, lastLine } = getLinesForRange(sourceFile, textRange);
+      let isCommenting = insertComment || false;
+      let leftMostPosition = Number.MAX_VALUE;
+      const lineTextStarts = /* @__PURE__ */ new Map();
+      const firstNonWhitespaceCharacterRegex = new RegExp(/\S/);
+      const isJsx = isInsideJsxElement(sourceFile, lineStarts[firstLine]);
+      const openComment = isJsx ? "{/*" : "//";
+      for (let i = firstLine; i <= lastLine; i++) {
+        const lineText = sourceFile.text.substring(lineStarts[i], sourceFile.getLineEndOfPosition(lineStarts[i]));
+        const regExec = firstNonWhitespaceCharacterRegex.exec(lineText);
+        if (regExec) {
+          leftMostPosition = Math.min(leftMostPosition, regExec.index);
+          lineTextStarts.set(i.toString(), regExec.index);
+          if (lineText.substr(regExec.index, openComment.length) !== openComment) {
+            isCommenting = insertComment === void 0 || insertComment;
+          }
+        }
+      }
+      for (let i = firstLine; i <= lastLine; i++) {
+        if (firstLine !== lastLine && lineStarts[i] === textRange.end) {
+          continue;
+        }
+        const lineTextStart = lineTextStarts.get(i.toString());
+        if (lineTextStart !== void 0) {
+          if (isJsx) {
+            textChanges2.push(...toggleMultilineComment(fileName, { pos: lineStarts[i] + leftMostPosition, end: sourceFile.getLineEndOfPosition(lineStarts[i]) }, isCommenting, isJsx));
+          } else if (isCommenting) {
+            textChanges2.push({
+              newText: openComment,
+              span: {
+                length: 0,
+                start: lineStarts[i] + leftMostPosition
+              }
+            });
+          } else if (sourceFile.text.substr(lineStarts[i] + lineTextStart, openComment.length) === openComment) {
+            textChanges2.push({
+              newText: "",
+              span: {
+                length: openComment.length,
+                start: lineStarts[i] + lineTextStart
+              }
             });
           }
-        } else if (!innermostErrorFunctionAction) {
-          innermostErrorFunctionAction = {
-            description: description3,
-            name: `function_scope_${i}`,
-            notApplicableReason: getStringError(functionExtraction.errors),
-            kind: extractFunctionAction.kind
-          };
         }
       }
-      if (refactorKindBeginsWith(extractConstantAction.kind, requestedRefactor)) {
-        const description3 = constantExtraction.description;
-        if (constantExtraction.errors.length === 0) {
-          if (!usedConstantNames.has(description3)) {
-            usedConstantNames.set(description3, true);
-            constantActions.push({
-              description: description3,
-              name: `constant_scope_${i}`,
-              kind: extractConstantAction.kind
+      return textChanges2;
+    }
+    function toggleMultilineComment(fileName, textRange, insertComment, isInsideJsx) {
+      var _a2;
+      const sourceFile = syntaxTreeCache.getCurrentSourceFile(fileName);
+      const textChanges2 = [];
+      const { text } = sourceFile;
+      let hasComment = false;
+      let isCommenting = insertComment || false;
+      const positions = [];
+      let { pos } = textRange;
+      const isJsx = isInsideJsx !== void 0 ? isInsideJsx : isInsideJsxElement(sourceFile, pos);
+      const openMultiline = isJsx ? "{/*" : "/*";
+      const closeMultiline = isJsx ? "*/}" : "*/";
+      const openMultilineRegex = isJsx ? "\\{\\/\\*" : "\\/\\*";
+      const closeMultilineRegex = isJsx ? "\\*\\/\\}" : "\\*\\/";
+      while (pos <= textRange.end) {
+        const offset = text.substr(pos, openMultiline.length) === openMultiline ? openMultiline.length : 0;
+        const commentRange = isInComment(sourceFile, pos + offset);
+        if (commentRange) {
+          if (isJsx) {
+            commentRange.pos--;
+            commentRange.end++;
+          }
+          positions.push(commentRange.pos);
+          if (commentRange.kind === 3 /* MultiLineCommentTrivia */) {
+            positions.push(commentRange.end);
+          }
+          hasComment = true;
+          pos = commentRange.end + 1;
+        } else {
+          const newPos = text.substring(pos, textRange.end).search(`(${openMultilineRegex})|(${closeMultilineRegex})`);
+          isCommenting = insertComment !== void 0 ? insertComment : isCommenting || !isTextWhiteSpaceLike(text, pos, newPos === -1 ? textRange.end : pos + newPos);
+          pos = newPos === -1 ? textRange.end + 1 : pos + newPos + closeMultiline.length;
+        }
+      }
+      if (isCommenting || !hasComment) {
+        if (((_a2 = isInComment(sourceFile, textRange.pos)) == null ? void 0 : _a2.kind) !== 2 /* SingleLineCommentTrivia */) {
+          insertSorted(positions, textRange.pos, compareValues);
+        }
+        insertSorted(positions, textRange.end, compareValues);
+        const firstPos = positions[0];
+        if (text.substr(firstPos, openMultiline.length) !== openMultiline) {
+          textChanges2.push({
+            newText: openMultiline,
+            span: {
+              length: 0,
+              start: firstPos
+            }
+          });
+        }
+        for (let i = 1; i < positions.length - 1; i++) {
+          if (text.substr(positions[i] - closeMultiline.length, closeMultiline.length) !== closeMultiline) {
+            textChanges2.push({
+              newText: closeMultiline,
+              span: {
+                length: 0,
+                start: positions[i]
+              }
             });
           }
-        } else if (!innermostErrorConstantAction) {
-          innermostErrorConstantAction = {
-            description: description3,
-            name: `constant_scope_${i}`,
-            notApplicableReason: getStringError(constantExtraction.errors),
-            kind: extractConstantAction.kind
-          };
+          if (text.substr(positions[i], openMultiline.length) !== openMultiline) {
+            textChanges2.push({
+              newText: openMultiline,
+              span: {
+                length: 0,
+                start: positions[i]
+              }
+            });
+          }
+        }
+        if (textChanges2.length % 2 !== 0) {
+          textChanges2.push({
+            newText: closeMultiline,
+            span: {
+              length: 0,
+              start: positions[positions.length - 1]
+            }
+          });
+        }
+      } else {
+        for (const pos2 of positions) {
+          const from = pos2 - closeMultiline.length > 0 ? pos2 - closeMultiline.length : 0;
+          const offset = text.substr(from, closeMultiline.length) === closeMultiline ? closeMultiline.length : 0;
+          textChanges2.push({
+            newText: "",
+            span: {
+              length: openMultiline.length,
+              start: pos2 - offset
+            }
+          });
         }
       }
-      i++;
+      return textChanges2;
     }
-    const infos = [];
-    if (functionActions.length) {
-      infos.push({
-        name: refactorName11,
-        description: getLocaleSpecificMessage(Diagnostics.Extract_function),
-        actions: functionActions
-      });
-    } else if (context.preferences.provideRefactorNotApplicableReason && innermostErrorFunctionAction) {
-      infos.push({
-        name: refactorName11,
-        description: getLocaleSpecificMessage(Diagnostics.Extract_function),
-        actions: [innermostErrorFunctionAction]
-      });
+    function commentSelection(fileName, textRange) {
+      const sourceFile = syntaxTreeCache.getCurrentSourceFile(fileName);
+      const { firstLine, lastLine } = getLinesForRange(sourceFile, textRange);
+      return firstLine === lastLine && textRange.pos !== textRange.end ? toggleMultilineComment(
+        fileName,
+        textRange,
+        /*insertComment*/
+        true
+      ) : toggleLineComment(
+        fileName,
+        textRange,
+        /*insertComment*/
+        true
+      );
     }
-    if (constantActions.length) {
-      infos.push({
-        name: refactorName11,
-        description: getLocaleSpecificMessage(Diagnostics.Extract_constant),
-        actions: constantActions
-      });
-    } else if (context.preferences.provideRefactorNotApplicableReason && innermostErrorConstantAction) {
-      infos.push({
-        name: refactorName11,
-        description: getLocaleSpecificMessage(Diagnostics.Extract_constant),
-        actions: [innermostErrorConstantAction]
-      });
+    function uncommentSelection(fileName, textRange) {
+      const sourceFile = syntaxTreeCache.getCurrentSourceFile(fileName);
+      const textChanges2 = [];
+      const { pos } = textRange;
+      let { end } = textRange;
+      if (pos === end) {
+        end += isInsideJsxElement(sourceFile, pos) ? 2 : 1;
+      }
+      for (let i = pos; i <= end; i++) {
+        const commentRange = isInComment(sourceFile, i);
+        if (commentRange) {
+          switch (commentRange.kind) {
+            case 2 /* SingleLineCommentTrivia */:
+              textChanges2.push(...toggleLineComment(
+                fileName,
+                { end: commentRange.end, pos: commentRange.pos + 1 },
+                /*insertComment*/
+                false
+              ));
+              break;
+            case 3 /* MultiLineCommentTrivia */:
+              textChanges2.push(...toggleMultilineComment(
+                fileName,
+                { end: commentRange.end, pos: commentRange.pos + 1 },
+                /*insertComment*/
+                false
+              ));
+          }
+          i = commentRange.end + 1;
+        }
+      }
+      return textChanges2;
     }
-    return infos.length ? infos : emptyArray;
-    function getStringError(errors) {
-      let error = errors[0].messageText;
-      if (typeof error !== "string") {
-        error = error.messageText;
+    function isUnclosedTag({ openingElement, closingElement, parent: parent2 }) {
+      return !tagNamesAreEquivalent(openingElement.tagName, closingElement.tagName) || isJsxElement(parent2) && tagNamesAreEquivalent(openingElement.tagName, parent2.openingElement.tagName) && isUnclosedTag(parent2);
+    }
+    function isUnclosedFragment({ closingFragment, parent: parent2 }) {
+      return !!(closingFragment.flags & 262144 /* ThisNodeHasError */) || isJsxFragment(parent2) && isUnclosedFragment(parent2);
+    }
+    function getSpanOfEnclosingComment(fileName, position, onlyMultiLine) {
+      const sourceFile = syntaxTreeCache.getCurrentSourceFile(fileName);
+      const range = ts_formatting_exports.getRangeOfEnclosingComment(sourceFile, position);
+      return range && (!onlyMultiLine || range.kind === 3 /* MultiLineCommentTrivia */) ? createTextSpanFromRange(range) : void 0;
+    }
+    function getTodoComments(fileName, descriptors) {
+      synchronizeHostData();
+      const sourceFile = getValidSourceFile(fileName);
+      cancellationToken.throwIfCancellationRequested();
+      const fileContents = sourceFile.text;
+      const result = [];
+      if (descriptors.length > 0 && !isNodeModulesFile(sourceFile.fileName)) {
+        const regExp = getTodoCommentsRegExp();
+        let matchArray;
+        while (matchArray = regExp.exec(fileContents)) {
+          cancellationToken.throwIfCancellationRequested();
+          const firstDescriptorCaptureIndex = 3;
+          Debug.assert(matchArray.length === descriptors.length + firstDescriptorCaptureIndex);
+          const preamble = matchArray[1];
+          const matchPosition = matchArray.index + preamble.length;
+          if (!isInComment(sourceFile, matchPosition)) {
+            continue;
+          }
+          let descriptor;
+          for (let i = 0; i < descriptors.length; i++) {
+            if (matchArray[i + firstDescriptorCaptureIndex]) {
+              descriptor = descriptors[i];
+            }
+          }
+          if (descriptor === void 0)
+            return Debug.fail();
+          if (isLetterOrDigit(fileContents.charCodeAt(matchPosition + descriptor.text.length))) {
+            continue;
+          }
+          const message = matchArray[2];
+          result.push({ descriptor, message, position: matchPosition });
+        }
+      }
+      return result;
+      function escapeRegExp(str) {
+        return str.replace(/[-[\]/{}()*+?.\\^$|]/g, "\\$&");
+      }
+      function getTodoCommentsRegExp() {
+        const singleLineCommentStart = /(?:\/\/+\s*)/.source;
+        const multiLineCommentStart = /(?:\/\*+\s*)/.source;
+        const anyNumberOfSpacesAndAsterisksAtStartOfLine = /(?:^(?:\s|\*)*)/.source;
+        const preamble = "(" + anyNumberOfSpacesAndAsterisksAtStartOfLine + "|" + singleLineCommentStart + "|" + multiLineCommentStart + ")";
+        const literals = "(?:" + map(descriptors, (d) => "(" + escapeRegExp(d.text) + ")").join("|") + ")";
+        const endOfLineOrEndOfComment = /(?:$|\*\/)/.source;
+        const messageRemainder = /(?:.*?)/.source;
+        const messagePortion = "(" + literals + messageRemainder + ")";
+        const regExpString = preamble + messagePortion + endOfLineOrEndOfComment;
+        return new RegExp(regExpString, "gim");
+      }
+      function isLetterOrDigit(char) {
+        return char >= 97 /* a */ && char <= 122 /* z */ || char >= 65 /* A */ && char <= 90 /* Z */ || char >= 48 /* _0 */ && char <= 57 /* _9 */;
+      }
+      function isNodeModulesFile(path) {
+        return path.includes("/node_modules/");
       }
-      return error;
     }
-  }
-  function getRefactorEditsToExtractSymbol(context, actionName2) {
-    const rangeToExtract = getRangeToExtract2(context.file, getRefactorContextSpan(context));
-    const targetRange = rangeToExtract.targetRange;
-    const parsedFunctionIndexMatch = /^function_scope_(\d+)$/.exec(actionName2);
-    if (parsedFunctionIndexMatch) {
-      const index = +parsedFunctionIndexMatch[1];
-      Debug.assert(isFinite(index), "Expected to parse a finite number from the function scope index");
-      return getFunctionExtractionAtIndex(targetRange, context, index);
+    function getRenameInfo2(fileName, position, preferences) {
+      synchronizeHostData();
+      return ts_Rename_exports.getRenameInfo(program, getValidSourceFile(fileName), position, preferences || {});
     }
-    const parsedConstantIndexMatch = /^constant_scope_(\d+)$/.exec(actionName2);
-    if (parsedConstantIndexMatch) {
-      const index = +parsedConstantIndexMatch[1];
-      Debug.assert(isFinite(index), "Expected to parse a finite number from the constant scope index");
-      return getConstantExtractionAtIndex(targetRange, context, index);
+    function getRefactorContext(file, positionOrRange, preferences, formatOptions, triggerReason, kind) {
+      const [startPosition, endPosition] = typeof positionOrRange === "number" ? [positionOrRange, void 0] : [positionOrRange.pos, positionOrRange.end];
+      return {
+        file,
+        startPosition,
+        endPosition,
+        program: getProgram(),
+        host,
+        formatContext: ts_formatting_exports.getFormatContext(formatOptions, host),
+        // TODO: GH#18217
+        cancellationToken,
+        preferences,
+        triggerReason,
+        kind
+      };
     }
-    Debug.fail("Unrecognized action name");
-  }
-  function getRangeToExtract2(sourceFile, span, invoked = true) {
-    const { length: length2 } = span;
-    if (length2 === 0 && !invoked) {
-      return { errors: [createFileDiagnostic(sourceFile, span.start, length2, Messages.cannotExtractEmpty)] };
+    function getInlayHintsContext(file, span, preferences) {
+      return {
+        file,
+        program: getProgram(),
+        host,
+        span,
+        preferences,
+        cancellationToken
+      };
     }
-    const cursorRequest = length2 === 0 && invoked;
-    const startToken = findFirstNonJsxWhitespaceToken(sourceFile, span.start);
-    const endToken = findTokenOnLeftOfPosition(sourceFile, textSpanEnd(span));
-    const adjustedSpan = startToken && endToken && invoked ? getAdjustedSpanFromNodes(startToken, endToken, sourceFile) : span;
-    const start = cursorRequest ? getExtractableParent(startToken) : getParentNodeInSpan(startToken, sourceFile, adjustedSpan);
-    const end = cursorRequest ? start : getParentNodeInSpan(endToken, sourceFile, adjustedSpan);
-    let rangeFacts = 0 /* None */;
-    let thisNode;
-    if (!start || !end) {
-      return { errors: [createFileDiagnostic(sourceFile, span.start, length2, Messages.cannotExtractRange)] };
+    function getSmartSelectionRange2(fileName, position) {
+      return ts_SmartSelectionRange_exports.getSmartSelectionRange(position, syntaxTreeCache.getCurrentSourceFile(fileName));
     }
-    if (start.flags & 8388608 /* JSDoc */) {
-      return { errors: [createFileDiagnostic(sourceFile, span.start, length2, Messages.cannotExtractJSDoc)] };
+    function getApplicableRefactors2(fileName, positionOrRange, preferences = emptyOptions, triggerReason, kind, includeInteractiveActions) {
+      synchronizeHostData();
+      const file = getValidSourceFile(fileName);
+      return ts_refactor_exports.getApplicableRefactors(getRefactorContext(file, positionOrRange, preferences, emptyOptions, triggerReason, kind), includeInteractiveActions);
     }
-    if (start.parent !== end.parent) {
-      return { errors: [createFileDiagnostic(sourceFile, span.start, length2, Messages.cannotExtractRange)] };
+    function getMoveToRefactoringFileSuggestions(fileName, positionOrRange, preferences = emptyOptions) {
+      synchronizeHostData();
+      const sourceFile = getValidSourceFile(fileName);
+      const allFiles = Debug.checkDefined(program.getSourceFiles());
+      const extension = extensionFromPath(fileName);
+      const files = mapDefined(allFiles, (file) => !(program == null ? void 0 : program.isSourceFileFromExternalLibrary(sourceFile)) && !(sourceFile === getValidSourceFile(file.fileName) || extension === ".ts" /* Ts */ && extensionFromPath(file.fileName) === ".d.ts" /* Dts */ || extension === ".d.ts" /* Dts */ && startsWith(getBaseFileName(file.fileName), "lib.") && extensionFromPath(file.fileName) === ".d.ts" /* Dts */) && extension === extensionFromPath(file.fileName) ? file.fileName : void 0);
+      const newFileName = createNewFileName(sourceFile, program, getRefactorContext(sourceFile, positionOrRange, preferences, emptyOptions), host);
+      return { newFileName, files };
     }
-    if (start !== end) {
-      if (!isBlockLike(start.parent)) {
-        return { errors: [createFileDiagnostic(sourceFile, span.start, length2, Messages.cannotExtractRange)] };
+    function getEditsForRefactor2(fileName, formatOptions, positionOrRange, refactorName14, actionName2, preferences = emptyOptions, interactiveRefactorArguments) {
+      synchronizeHostData();
+      const file = getValidSourceFile(fileName);
+      return ts_refactor_exports.getEditsForRefactor(getRefactorContext(file, positionOrRange, preferences, formatOptions), refactorName14, actionName2, interactiveRefactorArguments);
+    }
+    function toLineColumnOffset(fileName, position) {
+      if (position === 0) {
+        return { line: 0, character: 0 };
       }
-      const statements = [];
-      for (const statement of start.parent.statements) {
-        if (statement === start || statements.length) {
-          const errors2 = checkNode(statement);
-          if (errors2) {
-            return { errors: errors2 };
+      return sourceMapper.toLineColumnOffset(fileName, position);
+    }
+    function prepareCallHierarchy(fileName, position) {
+      synchronizeHostData();
+      const declarations = ts_CallHierarchy_exports.resolveCallHierarchyDeclaration(program, getTouchingPropertyName(getValidSourceFile(fileName), position));
+      return declarations && mapOneOrMany(declarations, (declaration) => ts_CallHierarchy_exports.createCallHierarchyItem(program, declaration));
+    }
+    function provideCallHierarchyIncomingCalls(fileName, position) {
+      synchronizeHostData();
+      const sourceFile = getValidSourceFile(fileName);
+      const declaration = firstOrOnly(ts_CallHierarchy_exports.resolveCallHierarchyDeclaration(program, position === 0 ? sourceFile : getTouchingPropertyName(sourceFile, position)));
+      return declaration ? ts_CallHierarchy_exports.getIncomingCalls(program, declaration, cancellationToken) : [];
+    }
+    function provideCallHierarchyOutgoingCalls(fileName, position) {
+      synchronizeHostData();
+      const sourceFile = getValidSourceFile(fileName);
+      const declaration = firstOrOnly(ts_CallHierarchy_exports.resolveCallHierarchyDeclaration(program, position === 0 ? sourceFile : getTouchingPropertyName(sourceFile, position)));
+      return declaration ? ts_CallHierarchy_exports.getOutgoingCalls(program, declaration) : [];
+    }
+    function provideInlayHints2(fileName, span, preferences = emptyOptions) {
+      synchronizeHostData();
+      const sourceFile = getValidSourceFile(fileName);
+      return ts_InlayHints_exports.provideInlayHints(getInlayHintsContext(sourceFile, span, preferences));
+    }
+    const ls = {
+      dispose,
+      cleanupSemanticCache,
+      getSyntacticDiagnostics,
+      getSemanticDiagnostics,
+      getSuggestionDiagnostics,
+      getCompilerOptionsDiagnostics,
+      getSyntacticClassifications: getSyntacticClassifications2,
+      getSemanticClassifications: getSemanticClassifications3,
+      getEncodedSyntacticClassifications: getEncodedSyntacticClassifications2,
+      getEncodedSemanticClassifications: getEncodedSemanticClassifications3,
+      getCompletionsAtPosition: getCompletionsAtPosition2,
+      getCompletionEntryDetails: getCompletionEntryDetails2,
+      getCompletionEntrySymbol: getCompletionEntrySymbol2,
+      getSignatureHelpItems: getSignatureHelpItems2,
+      getQuickInfoAtPosition,
+      getDefinitionAtPosition: getDefinitionAtPosition2,
+      getDefinitionAndBoundSpan: getDefinitionAndBoundSpan2,
+      getImplementationAtPosition,
+      getTypeDefinitionAtPosition: getTypeDefinitionAtPosition2,
+      getReferencesAtPosition,
+      findReferences,
+      getFileReferences,
+      getDocumentHighlights,
+      getNameOrDottedNameSpan,
+      getBreakpointStatementAtPosition,
+      getNavigateToItems: getNavigateToItems2,
+      getRenameInfo: getRenameInfo2,
+      getSmartSelectionRange: getSmartSelectionRange2,
+      findRenameLocations,
+      getNavigationBarItems: getNavigationBarItems2,
+      getNavigationTree: getNavigationTree2,
+      getOutliningSpans,
+      getTodoComments,
+      getBraceMatchingAtPosition,
+      getIndentationAtPosition,
+      getFormattingEditsForRange,
+      getFormattingEditsForDocument,
+      getFormattingEditsAfterKeystroke,
+      getDocCommentTemplateAtPosition: getDocCommentTemplateAtPosition2,
+      isValidBraceCompletionAtPosition,
+      getJsxClosingTagAtPosition,
+      getLinkedEditingRangeAtPosition,
+      getSpanOfEnclosingComment,
+      getCodeFixesAtPosition,
+      getCombinedCodeFix,
+      applyCodeActionCommand,
+      organizeImports: organizeImports2,
+      getEditsForFileRename: getEditsForFileRename2,
+      getEmitOutput,
+      getNonBoundSourceFile,
+      getProgram,
+      getCurrentProgram: () => program,
+      getAutoImportProvider,
+      updateIsDefinitionOfReferencedSymbols,
+      getApplicableRefactors: getApplicableRefactors2,
+      getEditsForRefactor: getEditsForRefactor2,
+      getMoveToRefactoringFileSuggestions,
+      toLineColumnOffset,
+      getSourceMapper: () => sourceMapper,
+      clearSourceMapperCache: () => sourceMapper.clearCache(),
+      prepareCallHierarchy,
+      provideCallHierarchyIncomingCalls,
+      provideCallHierarchyOutgoingCalls,
+      toggleLineComment,
+      toggleMultilineComment,
+      commentSelection,
+      uncommentSelection,
+      provideInlayHints: provideInlayHints2,
+      getSupportedCodeFixes
+    };
+    switch (languageServiceMode) {
+      case 0 /* Semantic */:
+        break;
+      case 1 /* PartialSemantic */:
+        invalidOperationsInPartialSemanticMode.forEach(
+          (key) => ls[key] = () => {
+            throw new Error(`LanguageService Operation: ${key} not allowed in LanguageServiceMode.PartialSemantic`);
           }
-          statements.push(statement);
+        );
+        break;
+      case 2 /* Syntactic */:
+        invalidOperationsInSyntacticMode.forEach(
+          (key) => ls[key] = () => {
+            throw new Error(`LanguageService Operation: ${key} not allowed in LanguageServiceMode.Syntactic`);
+          }
+        );
+        break;
+      default:
+        Debug.assertNever(languageServiceMode);
+    }
+    return ls;
+  }
+  function getNameTable(sourceFile) {
+    if (!sourceFile.nameTable) {
+      initializeNameTable(sourceFile);
+    }
+    return sourceFile.nameTable;
+  }
+  function initializeNameTable(sourceFile) {
+    const nameTable = sourceFile.nameTable = /* @__PURE__ */ new Map();
+    sourceFile.forEachChild(function walk(node) {
+      if (isIdentifier(node) && !isTagName(node) && node.escapedText || isStringOrNumericLiteralLike(node) && literalIsName(node)) {
+        const text = getEscapedTextOfIdentifierOrLiteral(node);
+        nameTable.set(text, nameTable.get(text) === void 0 ? node.pos : -1);
+      } else if (isPrivateIdentifier(node)) {
+        const text = node.escapedText;
+        nameTable.set(text, nameTable.get(text) === void 0 ? node.pos : -1);
+      }
+      forEachChild(node, walk);
+      if (hasJSDocNodes(node)) {
+        for (const jsDoc of node.jsDoc) {
+          forEachChild(jsDoc, walk);
+        }
+      }
+    });
+  }
+  function literalIsName(node) {
+    return isDeclarationName(node) || node.parent.kind === 283 /* ExternalModuleReference */ || isArgumentOfElementAccessExpression(node) || isLiteralComputedPropertyDeclarationName(node);
+  }
+  function getContainingObjectLiteralElement(node) {
+    const element = getContainingObjectLiteralElementWorker(node);
+    return element && (isObjectLiteralExpression(element.parent) || isJsxAttributes(element.parent)) ? element : void 0;
+  }
+  function getContainingObjectLiteralElementWorker(node) {
+    switch (node.kind) {
+      case 11 /* StringLiteral */:
+      case 15 /* NoSubstitutionTemplateLiteral */:
+      case 9 /* NumericLiteral */:
+        if (node.parent.kind === 167 /* ComputedPropertyName */) {
+          return isObjectLiteralElement(node.parent.parent) ? node.parent.parent : void 0;
+        }
+      case 80 /* Identifier */:
+        return isObjectLiteralElement(node.parent) && (node.parent.parent.kind === 210 /* ObjectLiteralExpression */ || node.parent.parent.kind === 292 /* JsxAttributes */) && node.parent.name === node ? node.parent : void 0;
+    }
+    return void 0;
+  }
+  function getSymbolAtLocationForQuickInfo(node, checker) {
+    const object = getContainingObjectLiteralElement(node);
+    if (object) {
+      const contextualType = checker.getContextualType(object.parent);
+      const properties = contextualType && getPropertySymbolsFromContextualType(
+        object,
+        checker,
+        contextualType,
+        /*unionSymbolOk*/
+        false
+      );
+      if (properties && properties.length === 1) {
+        return first(properties);
+      }
+    }
+    return checker.getSymbolAtLocation(node);
+  }
+  function getPropertySymbolsFromContextualType(node, checker, contextualType, unionSymbolOk) {
+    const name = getNameFromPropertyName(node.name);
+    if (!name)
+      return emptyArray;
+    if (!contextualType.isUnion()) {
+      const symbol = contextualType.getProperty(name);
+      return symbol ? [symbol] : emptyArray;
+    }
+    const discriminatedPropertySymbols = mapDefined(contextualType.types, (t) => (isObjectLiteralExpression(node.parent) || isJsxAttributes(node.parent)) && checker.isTypeInvalidDueToUnionDiscriminant(t, node.parent) ? void 0 : t.getProperty(name));
+    if (unionSymbolOk && (discriminatedPropertySymbols.length === 0 || discriminatedPropertySymbols.length === contextualType.types.length)) {
+      const symbol = contextualType.getProperty(name);
+      if (symbol)
+        return [symbol];
+    }
+    if (discriminatedPropertySymbols.length === 0) {
+      return mapDefined(contextualType.types, (t) => t.getProperty(name));
+    }
+    return discriminatedPropertySymbols;
+  }
+  function isArgumentOfElementAccessExpression(node) {
+    return node && node.parent && node.parent.kind === 212 /* ElementAccessExpression */ && node.parent.argumentExpression === node;
+  }
+  function getDefaultLibFilePath(options) {
+    if (sys) {
+      return combinePaths(getDirectoryPath(normalizePath(sys.getExecutingFilePath())), getDefaultLibFileName(options));
+    }
+    throw new Error("getDefaultLibFilePath is only supported when consumed as a node module. ");
+  }
+  var servicesVersion, NodeObject, TokenOrIdentifierObject, SymbolObject, TokenObject, IdentifierObject, PrivateIdentifierObject, TypeObject, SignatureObject, SourceFileObject, SourceMapSourceObject, SyntaxTreeCache, NoopCancellationToken, CancellationTokenObject, ThrottledCancellationToken, invalidOperationsInPartialSemanticMode, invalidOperationsInSyntacticMode;
+  var init_services = __esm({
+    "src/services/services.ts"() {
+      "use strict";
+      init_ts4();
+      init_ts_NavigateTo();
+      init_ts_NavigationBar();
+      init_ts_refactor();
+      init_classifier();
+      init_classifier2020();
+      servicesVersion = "0.8";
+      NodeObject = class {
+        constructor(kind, pos, end) {
+          this.pos = pos;
+          this.end = end;
+          this.flags = 0 /* None */;
+          this.modifierFlagsCache = 0 /* None */;
+          this.transformFlags = 0 /* None */;
+          this.parent = void 0;
+          this.kind = kind;
         }
-        if (statement === end) {
-          break;
+        assertHasRealPosition(message) {
+          Debug.assert(!positionIsSynthesized(this.pos) && !positionIsSynthesized(this.end), message || "Node must have a real position for this operation");
         }
-      }
-      if (!statements.length) {
-        return { errors: [createFileDiagnostic(sourceFile, span.start, length2, Messages.cannotExtractRange)] };
-      }
-      return { targetRange: { range: statements, facts: rangeFacts, thisNode } };
-    }
-    if (isReturnStatement(start) && !start.expression) {
-      return { errors: [createFileDiagnostic(sourceFile, span.start, length2, Messages.cannotExtractRange)] };
-    }
-    const node = refineNode(start);
-    const errors = checkRootNode(node) || checkNode(node);
-    if (errors) {
-      return { errors };
-    }
-    return { targetRange: { range: getStatementOrExpressionRange(node), facts: rangeFacts, thisNode } };
-    function refineNode(node2) {
-      if (isReturnStatement(node2)) {
-        if (node2.expression) {
-          return node2.expression;
+        getSourceFile() {
+          return getSourceFileOfNode(this);
         }
-      } else if (isVariableStatement(node2) || isVariableDeclarationList(node2)) {
-        const declarations = isVariableStatement(node2) ? node2.declarationList.declarations : node2.declarations;
-        let numInitializers = 0;
-        let lastInitializer;
-        for (const declaration of declarations) {
-          if (declaration.initializer) {
-            numInitializers++;
-            lastInitializer = declaration.initializer;
+        getStart(sourceFile, includeJsDocComment) {
+          this.assertHasRealPosition();
+          return getTokenPosOfNode(this, sourceFile, includeJsDocComment);
+        }
+        getFullStart() {
+          this.assertHasRealPosition();
+          return this.pos;
+        }
+        getEnd() {
+          this.assertHasRealPosition();
+          return this.end;
+        }
+        getWidth(sourceFile) {
+          this.assertHasRealPosition();
+          return this.getEnd() - this.getStart(sourceFile);
+        }
+        getFullWidth() {
+          this.assertHasRealPosition();
+          return this.end - this.pos;
+        }
+        getLeadingTriviaWidth(sourceFile) {
+          this.assertHasRealPosition();
+          return this.getStart(sourceFile) - this.pos;
+        }
+        getFullText(sourceFile) {
+          this.assertHasRealPosition();
+          return (sourceFile || this.getSourceFile()).text.substring(this.pos, this.end);
+        }
+        getText(sourceFile) {
+          this.assertHasRealPosition();
+          if (!sourceFile) {
+            sourceFile = this.getSourceFile();
           }
+          return sourceFile.text.substring(this.getStart(sourceFile), this.getEnd());
         }
-        if (numInitializers === 1) {
-          return lastInitializer;
+        getChildCount(sourceFile) {
+          return this.getChildren(sourceFile).length;
         }
-      } else if (isVariableDeclaration(node2)) {
-        if (node2.initializer) {
-          return node2.initializer;
+        getChildAt(index, sourceFile) {
+          return this.getChildren(sourceFile)[index];
         }
-      }
-      return node2;
-    }
-    function checkRootNode(node2) {
-      if (isIdentifier(isExpressionStatement(node2) ? node2.expression : node2)) {
-        return [createDiagnosticForNode(node2, Messages.cannotExtractIdentifier)];
-      }
-      return void 0;
-    }
-    function checkForStaticContext(nodeToCheck, containingClass) {
-      let current = nodeToCheck;
-      while (current !== containingClass) {
-        if (current.kind === 171 /* PropertyDeclaration */) {
-          if (isStatic(current)) {
-            rangeFacts |= 32 /* InStaticRegion */;
+        getChildren(sourceFile) {
+          this.assertHasRealPosition("Node without a real position cannot be scanned and thus has no token nodes - use forEachChild and collect the result if that's fine");
+          return this._children || (this._children = createChildren(this, sourceFile));
+        }
+        getFirstToken(sourceFile) {
+          this.assertHasRealPosition();
+          const children = this.getChildren(sourceFile);
+          if (!children.length) {
+            return void 0;
           }
-          break;
-        } else if (current.kind === 168 /* Parameter */) {
-          const ctorOrMethod = getContainingFunction(current);
-          if (ctorOrMethod.kind === 175 /* Constructor */) {
-            rangeFacts |= 32 /* InStaticRegion */;
+          const child = find(children, (kid) => kid.kind < 316 /* FirstJSDocNode */ || kid.kind > 357 /* LastJSDocNode */);
+          return child.kind < 166 /* FirstNode */ ? child : child.getFirstToken(sourceFile);
+        }
+        getLastToken(sourceFile) {
+          this.assertHasRealPosition();
+          const children = this.getChildren(sourceFile);
+          const child = lastOrUndefined(children);
+          if (!child) {
+            return void 0;
           }
-          break;
-        } else if (current.kind === 173 /* MethodDeclaration */) {
-          if (isStatic(current)) {
-            rangeFacts |= 32 /* InStaticRegion */;
+          return child.kind < 166 /* FirstNode */ ? child : child.getLastToken(sourceFile);
+        }
+        forEachChild(cbNode, cbNodeArray) {
+          return forEachChild(this, cbNode, cbNodeArray);
+        }
+      };
+      TokenOrIdentifierObject = class {
+        constructor(pos, end) {
+          this.pos = pos;
+          this.end = end;
+          this.flags = 0 /* None */;
+          this.modifierFlagsCache = 0 /* None */;
+          this.transformFlags = 0 /* None */;
+          this.parent = void 0;
+        }
+        getSourceFile() {
+          return getSourceFileOfNode(this);
+        }
+        getStart(sourceFile, includeJsDocComment) {
+          return getTokenPosOfNode(this, sourceFile, includeJsDocComment);
+        }
+        getFullStart() {
+          return this.pos;
+        }
+        getEnd() {
+          return this.end;
+        }
+        getWidth(sourceFile) {
+          return this.getEnd() - this.getStart(sourceFile);
+        }
+        getFullWidth() {
+          return this.end - this.pos;
+        }
+        getLeadingTriviaWidth(sourceFile) {
+          return this.getStart(sourceFile) - this.pos;
+        }
+        getFullText(sourceFile) {
+          return (sourceFile || this.getSourceFile()).text.substring(this.pos, this.end);
+        }
+        getText(sourceFile) {
+          if (!sourceFile) {
+            sourceFile = this.getSourceFile();
           }
+          return sourceFile.text.substring(this.getStart(sourceFile), this.getEnd());
         }
-        current = current.parent;
-      }
-    }
-    function checkNode(nodeToCheck) {
-      let PermittedJumps;
-      ((PermittedJumps2) => {
-        PermittedJumps2[PermittedJumps2["None"] = 0] = "None";
-        PermittedJumps2[PermittedJumps2["Break"] = 1] = "Break";
-        PermittedJumps2[PermittedJumps2["Continue"] = 2] = "Continue";
-        PermittedJumps2[PermittedJumps2["Return"] = 4] = "Return";
-      })(PermittedJumps || (PermittedJumps = {}));
-      Debug.assert(nodeToCheck.pos <= nodeToCheck.end, "This failure could trigger https://github.com/Microsoft/TypeScript/issues/20809 (1)");
-      Debug.assert(!positionIsSynthesized(nodeToCheck.pos), "This failure could trigger https://github.com/Microsoft/TypeScript/issues/20809 (2)");
-      if (!isStatement(nodeToCheck) && !(isExpressionNode(nodeToCheck) && isExtractableExpression(nodeToCheck)) && !isStringLiteralJsxAttribute(nodeToCheck)) {
-        return [createDiagnosticForNode(nodeToCheck, Messages.statementOrExpressionExpected)];
-      }
-      if (nodeToCheck.flags & 16777216 /* Ambient */) {
-        return [createDiagnosticForNode(nodeToCheck, Messages.cannotExtractAmbientBlock)];
-      }
-      const containingClass = getContainingClass(nodeToCheck);
-      if (containingClass) {
-        checkForStaticContext(nodeToCheck, containingClass);
-      }
-      let errors2;
-      let permittedJumps = 4 /* Return */;
-      let seenLabels;
-      visit(nodeToCheck);
-      if (rangeFacts & 8 /* UsesThis */) {
-        const container = getThisContainer(
-          nodeToCheck,
-          /*includeArrowFunctions*/
-          false,
-          /*includeClassComputedPropertyName*/
-          false
-        );
-        if (container.kind === 261 /* FunctionDeclaration */ || container.kind === 173 /* MethodDeclaration */ && container.parent.kind === 209 /* ObjectLiteralExpression */ || container.kind === 217 /* FunctionExpression */) {
-          rangeFacts |= 16 /* UsesThisInFunction */;
+        getChildCount() {
+          return this.getChildren().length;
         }
-      }
-      return errors2;
-      function visit(node2) {
-        if (errors2) {
-          return true;
+        getChildAt(index) {
+          return this.getChildren()[index];
         }
-        if (isDeclaration(node2)) {
-          const declaringNode = node2.kind === 259 /* VariableDeclaration */ ? node2.parent.parent : node2;
-          if (hasSyntacticModifier(declaringNode, 1 /* Export */)) {
-            (errors2 || (errors2 = [])).push(createDiagnosticForNode(node2, Messages.cannotExtractExportedEntity));
-            return true;
+        getChildren() {
+          return this.kind === 1 /* EndOfFileToken */ ? this.jsDoc || emptyArray : emptyArray;
+        }
+        getFirstToken() {
+          return void 0;
+        }
+        getLastToken() {
+          return void 0;
+        }
+        forEachChild() {
+          return void 0;
+        }
+      };
+      SymbolObject = class {
+        constructor(flags, name) {
+          this.id = 0;
+          this.mergeId = 0;
+          this.flags = flags;
+          this.escapedName = name;
+        }
+        getFlags() {
+          return this.flags;
+        }
+        get name() {
+          return symbolName(this);
+        }
+        getEscapedName() {
+          return this.escapedName;
+        }
+        getName() {
+          return this.name;
+        }
+        getDeclarations() {
+          return this.declarations;
+        }
+        getDocumentationComment(checker) {
+          if (!this.documentationComment) {
+            this.documentationComment = emptyArray;
+            if (!this.declarations && isTransientSymbol(this) && this.links.target && isTransientSymbol(this.links.target) && this.links.target.links.tupleLabelDeclaration) {
+              const labelDecl = this.links.target.links.tupleLabelDeclaration;
+              this.documentationComment = getDocumentationComment([labelDecl], checker);
+            } else {
+              this.documentationComment = getDocumentationComment(this.declarations, checker);
+            }
           }
+          return this.documentationComment;
         }
-        switch (node2.kind) {
-          case 271 /* ImportDeclaration */:
-            (errors2 || (errors2 = [])).push(createDiagnosticForNode(node2, Messages.cannotExtractImport));
-            return true;
-          case 276 /* ExportAssignment */:
-            (errors2 || (errors2 = [])).push(createDiagnosticForNode(node2, Messages.cannotExtractExportedEntity));
-            return true;
-          case 108 /* SuperKeyword */:
-            if (node2.parent.kind === 212 /* CallExpression */) {
-              const containingClass2 = getContainingClass(node2);
-              if (containingClass2 === void 0 || containingClass2.pos < span.start || containingClass2.end >= span.start + span.length) {
-                (errors2 || (errors2 = [])).push(createDiagnosticForNode(node2, Messages.cannotExtractSuper));
-                return true;
+        getContextualDocumentationComment(context, checker) {
+          if (context) {
+            if (isGetAccessor(context)) {
+              if (!this.contextualGetAccessorDocumentationComment) {
+                this.contextualGetAccessorDocumentationComment = getDocumentationComment(filter(this.declarations, isGetAccessor), checker);
+              }
+              if (length(this.contextualGetAccessorDocumentationComment)) {
+                return this.contextualGetAccessorDocumentationComment;
               }
-            } else {
-              rangeFacts |= 8 /* UsesThis */;
-              thisNode = node2;
             }
-            break;
-          case 218 /* ArrowFunction */:
-            forEachChild(node2, function check(n) {
-              if (isThis(n)) {
-                rangeFacts |= 8 /* UsesThis */;
-                thisNode = node2;
-              } else if (isClassLike(n) || isFunctionLike(n) && !isArrowFunction(n)) {
-                return false;
-              } else {
-                forEachChild(n, check);
+            if (isSetAccessor(context)) {
+              if (!this.contextualSetAccessorDocumentationComment) {
+                this.contextualSetAccessorDocumentationComment = getDocumentationComment(filter(this.declarations, isSetAccessor), checker);
+              }
+              if (length(this.contextualSetAccessorDocumentationComment)) {
+                return this.contextualSetAccessorDocumentationComment;
               }
-            });
-          case 262 /* ClassDeclaration */:
-          case 261 /* FunctionDeclaration */:
-            if (isSourceFile(node2.parent) && node2.parent.externalModuleIndicator === void 0) {
-              (errors2 || (errors2 = [])).push(createDiagnosticForNode(node2, Messages.functionWillNotBeVisibleInTheNewScope));
             }
-          case 230 /* ClassExpression */:
-          case 217 /* FunctionExpression */:
-          case 173 /* MethodDeclaration */:
-          case 175 /* Constructor */:
-          case 176 /* GetAccessor */:
-          case 177 /* SetAccessor */:
-            return false;
+          }
+          return this.getDocumentationComment(checker);
         }
-        const savedPermittedJumps = permittedJumps;
-        switch (node2.kind) {
-          case 244 /* IfStatement */:
-            permittedJumps &= ~4 /* Return */;
-            break;
-          case 257 /* TryStatement */:
-            permittedJumps = 0 /* None */;
-            break;
-          case 240 /* Block */:
-            if (node2.parent && node2.parent.kind === 257 /* TryStatement */ && node2.parent.finallyBlock === node2) {
-              permittedJumps = 4 /* Return */;
+        getJsDocTags(checker) {
+          if (this.tags === void 0) {
+            this.tags = getJsDocTagsOfDeclarations(this.declarations, checker);
+          }
+          return this.tags;
+        }
+        getContextualJsDocTags(context, checker) {
+          if (context) {
+            if (isGetAccessor(context)) {
+              if (!this.contextualGetAccessorTags) {
+                this.contextualGetAccessorTags = getJsDocTagsOfDeclarations(filter(this.declarations, isGetAccessor), checker);
+              }
+              if (length(this.contextualGetAccessorTags)) {
+                return this.contextualGetAccessorTags;
+              }
             }
-            break;
-          case 296 /* DefaultClause */:
-          case 295 /* CaseClause */:
-            permittedJumps |= 1 /* Break */;
-            break;
-          default:
-            if (isIterationStatement(
-              node2,
-              /*lookInLabeledStatements*/
-              false
-            )) {
-              permittedJumps |= 1 /* Break */ | 2 /* Continue */;
+            if (isSetAccessor(context)) {
+              if (!this.contextualSetAccessorTags) {
+                this.contextualSetAccessorTags = getJsDocTagsOfDeclarations(filter(this.declarations, isSetAccessor), checker);
+              }
+              if (length(this.contextualSetAccessorTags)) {
+                return this.contextualSetAccessorTags;
+              }
             }
-            break;
+          }
+          return this.getJsDocTags(checker);
         }
-        switch (node2.kind) {
-          case 196 /* ThisType */:
-          case 110 /* ThisKeyword */:
-            rangeFacts |= 8 /* UsesThis */;
-            thisNode = node2;
-            break;
-          case 255 /* LabeledStatement */: {
-            const label = node2.label;
-            (seenLabels || (seenLabels = [])).push(label.escapedText);
-            forEachChild(node2, visit);
-            seenLabels.pop();
-            break;
+      };
+      TokenObject = class extends TokenOrIdentifierObject {
+        constructor(kind, pos, end) {
+          super(pos, end);
+          this.kind = kind;
+        }
+      };
+      IdentifierObject = class extends TokenOrIdentifierObject {
+        constructor(_kind, pos, end) {
+          super(pos, end);
+          this.kind = 80 /* Identifier */;
+        }
+        get text() {
+          return idText(this);
+        }
+      };
+      IdentifierObject.prototype.kind = 80 /* Identifier */;
+      PrivateIdentifierObject = class extends TokenOrIdentifierObject {
+        constructor(_kind, pos, end) {
+          super(pos, end);
+          this.kind = 81 /* PrivateIdentifier */;
+        }
+        get text() {
+          return idText(this);
+        }
+      };
+      PrivateIdentifierObject.prototype.kind = 81 /* PrivateIdentifier */;
+      TypeObject = class {
+        constructor(checker, flags) {
+          this.checker = checker;
+          this.flags = flags;
+        }
+        getFlags() {
+          return this.flags;
+        }
+        getSymbol() {
+          return this.symbol;
+        }
+        getProperties() {
+          return this.checker.getPropertiesOfType(this);
+        }
+        getProperty(propertyName) {
+          return this.checker.getPropertyOfType(this, propertyName);
+        }
+        getApparentProperties() {
+          return this.checker.getAugmentedPropertiesOfType(this);
+        }
+        getCallSignatures() {
+          return this.checker.getSignaturesOfType(this, 0 /* Call */);
+        }
+        getConstructSignatures() {
+          return this.checker.getSignaturesOfType(this, 1 /* Construct */);
+        }
+        getStringIndexType() {
+          return this.checker.getIndexTypeOfType(this, 0 /* String */);
+        }
+        getNumberIndexType() {
+          return this.checker.getIndexTypeOfType(this, 1 /* Number */);
+        }
+        getBaseTypes() {
+          return this.isClassOrInterface() ? this.checker.getBaseTypes(this) : void 0;
+        }
+        isNullableType() {
+          return this.checker.isNullableType(this);
+        }
+        getNonNullableType() {
+          return this.checker.getNonNullableType(this);
+        }
+        getNonOptionalType() {
+          return this.checker.getNonOptionalType(this);
+        }
+        getConstraint() {
+          return this.checker.getBaseConstraintOfType(this);
+        }
+        getDefault() {
+          return this.checker.getDefaultFromTypeParameter(this);
+        }
+        isUnion() {
+          return !!(this.flags & 1048576 /* Union */);
+        }
+        isIntersection() {
+          return !!(this.flags & 2097152 /* Intersection */);
+        }
+        isUnionOrIntersection() {
+          return !!(this.flags & 3145728 /* UnionOrIntersection */);
+        }
+        isLiteral() {
+          return !!(this.flags & (128 /* StringLiteral */ | 256 /* NumberLiteral */ | 2048 /* BigIntLiteral */));
+        }
+        isStringLiteral() {
+          return !!(this.flags & 128 /* StringLiteral */);
+        }
+        isNumberLiteral() {
+          return !!(this.flags & 256 /* NumberLiteral */);
+        }
+        isTypeParameter() {
+          return !!(this.flags & 262144 /* TypeParameter */);
+        }
+        isClassOrInterface() {
+          return !!(getObjectFlags(this) & 3 /* ClassOrInterface */);
+        }
+        isClass() {
+          return !!(getObjectFlags(this) & 1 /* Class */);
+        }
+        isIndexType() {
+          return !!(this.flags & 4194304 /* Index */);
+        }
+        /**
+         * This polyfills `referenceType.typeArguments` for API consumers
+         */
+        get typeArguments() {
+          if (getObjectFlags(this) & 4 /* Reference */) {
+            return this.checker.getTypeArguments(this);
           }
-          case 251 /* BreakStatement */:
-          case 250 /* ContinueStatement */: {
-            const label = node2.label;
-            if (label) {
-              if (!contains(seenLabels, label.escapedText)) {
-                (errors2 || (errors2 = [])).push(createDiagnosticForNode(node2, Messages.cannotExtractRangeContainingLabeledBreakOrContinueStatementWithTargetOutsideOfTheRange));
-              }
-            } else {
-              if (!(permittedJumps & (node2.kind === 251 /* BreakStatement */ ? 1 /* Break */ : 2 /* Continue */))) {
-                (errors2 || (errors2 = [])).push(createDiagnosticForNode(node2, Messages.cannotExtractRangeContainingConditionalBreakOrContinueStatements));
-              }
+          return void 0;
+        }
+      };
+      SignatureObject = class {
+        // same
+        constructor(checker, flags) {
+          this.checker = checker;
+          this.flags = flags;
+        }
+        getDeclaration() {
+          return this.declaration;
+        }
+        getTypeParameters() {
+          return this.typeParameters;
+        }
+        getParameters() {
+          return this.parameters;
+        }
+        getReturnType() {
+          return this.checker.getReturnTypeOfSignature(this);
+        }
+        getTypeParameterAtPosition(pos) {
+          const type = this.checker.getParameterType(this, pos);
+          if (type.isIndexType() && isThisTypeParameter(type.type)) {
+            const constraint = type.type.getConstraint();
+            if (constraint) {
+              return this.checker.getIndexType(constraint);
             }
-            break;
           }
-          case 222 /* AwaitExpression */:
-            rangeFacts |= 4 /* IsAsyncFunction */;
-            break;
-          case 228 /* YieldExpression */:
-            rangeFacts |= 2 /* IsGenerator */;
-            break;
-          case 252 /* ReturnStatement */:
-            if (permittedJumps & 4 /* Return */) {
-              rangeFacts |= 1 /* HasReturn */;
-            } else {
-              (errors2 || (errors2 = [])).push(createDiagnosticForNode(node2, Messages.cannotExtractRangeContainingConditionalReturnStatement));
+          return type;
+        }
+        getDocumentationComment() {
+          return this.documentationComment || (this.documentationComment = getDocumentationComment(singleElementArray(this.declaration), this.checker));
+        }
+        getJsDocTags() {
+          return this.jsDocTags || (this.jsDocTags = getJsDocTagsOfDeclarations(singleElementArray(this.declaration), this.checker));
+        }
+      };
+      SourceFileObject = class extends NodeObject {
+        constructor(kind, pos, end) {
+          super(kind, pos, end);
+          this.kind = 312 /* SourceFile */;
+        }
+        update(newText, textChangeRange) {
+          return updateSourceFile(this, newText, textChangeRange);
+        }
+        getLineAndCharacterOfPosition(position) {
+          return getLineAndCharacterOfPosition(this, position);
+        }
+        getLineStarts() {
+          return getLineStarts(this);
+        }
+        getPositionOfLineAndCharacter(line, character, allowEdits) {
+          return computePositionOfLineAndCharacter(getLineStarts(this), line, character, this.text, allowEdits);
+        }
+        getLineEndOfPosition(pos) {
+          const { line } = this.getLineAndCharacterOfPosition(pos);
+          const lineStarts = this.getLineStarts();
+          let lastCharPos;
+          if (line + 1 >= lineStarts.length) {
+            lastCharPos = this.getEnd();
+          }
+          if (!lastCharPos) {
+            lastCharPos = lineStarts[line + 1] - 1;
+          }
+          const fullText = this.getFullText();
+          return fullText[lastCharPos] === "\n" && fullText[lastCharPos - 1] === "\r" ? lastCharPos - 1 : lastCharPos;
+        }
+        getNamedDeclarations() {
+          if (!this.namedDeclarations) {
+            this.namedDeclarations = this.computeNamedDeclarations();
+          }
+          return this.namedDeclarations;
+        }
+        computeNamedDeclarations() {
+          const result = createMultiMap();
+          this.forEachChild(visit);
+          return result;
+          function addDeclaration(declaration) {
+            const name = getDeclarationName(declaration);
+            if (name) {
+              result.add(name, declaration);
             }
-            break;
-          default:
-            forEachChild(node2, visit);
-            break;
+          }
+          function getDeclarations(name) {
+            let declarations = result.get(name);
+            if (!declarations) {
+              result.set(name, declarations = []);
+            }
+            return declarations;
+          }
+          function getDeclarationName(declaration) {
+            const name = getNonAssignedNameOfDeclaration(declaration);
+            return name && (isComputedPropertyName(name) && isPropertyAccessExpression(name.expression) ? name.expression.name.text : isPropertyName(name) ? getNameFromPropertyName(name) : void 0);
+          }
+          function visit(node) {
+            switch (node.kind) {
+              case 262 /* FunctionDeclaration */:
+              case 218 /* FunctionExpression */:
+              case 174 /* MethodDeclaration */:
+              case 173 /* MethodSignature */:
+                const functionDeclaration = node;
+                const declarationName = getDeclarationName(functionDeclaration);
+                if (declarationName) {
+                  const declarations = getDeclarations(declarationName);
+                  const lastDeclaration = lastOrUndefined(declarations);
+                  if (lastDeclaration && functionDeclaration.parent === lastDeclaration.parent && functionDeclaration.symbol === lastDeclaration.symbol) {
+                    if (functionDeclaration.body && !lastDeclaration.body) {
+                      declarations[declarations.length - 1] = functionDeclaration;
+                    }
+                  } else {
+                    declarations.push(functionDeclaration);
+                  }
+                }
+                forEachChild(node, visit);
+                break;
+              case 263 /* ClassDeclaration */:
+              case 231 /* ClassExpression */:
+              case 264 /* InterfaceDeclaration */:
+              case 265 /* TypeAliasDeclaration */:
+              case 266 /* EnumDeclaration */:
+              case 267 /* ModuleDeclaration */:
+              case 271 /* ImportEqualsDeclaration */:
+              case 281 /* ExportSpecifier */:
+              case 276 /* ImportSpecifier */:
+              case 273 /* ImportClause */:
+              case 274 /* NamespaceImport */:
+              case 177 /* GetAccessor */:
+              case 178 /* SetAccessor */:
+              case 187 /* TypeLiteral */:
+                addDeclaration(node);
+                forEachChild(node, visit);
+                break;
+              case 169 /* Parameter */:
+                if (!hasSyntacticModifier(node, 31 /* ParameterPropertyModifier */)) {
+                  break;
+                }
+              case 260 /* VariableDeclaration */:
+              case 208 /* BindingElement */: {
+                const decl = node;
+                if (isBindingPattern(decl.name)) {
+                  forEachChild(decl.name, visit);
+                  break;
+                }
+                if (decl.initializer) {
+                  visit(decl.initializer);
+                }
+              }
+              case 306 /* EnumMember */:
+              case 172 /* PropertyDeclaration */:
+              case 171 /* PropertySignature */:
+                addDeclaration(node);
+                break;
+              case 278 /* ExportDeclaration */:
+                const exportDeclaration = node;
+                if (exportDeclaration.exportClause) {
+                  if (isNamedExports(exportDeclaration.exportClause)) {
+                    forEach(exportDeclaration.exportClause.elements, visit);
+                  } else {
+                    visit(exportDeclaration.exportClause.name);
+                  }
+                }
+                break;
+              case 272 /* ImportDeclaration */:
+                const importClause = node.importClause;
+                if (importClause) {
+                  if (importClause.name) {
+                    addDeclaration(importClause.name);
+                  }
+                  if (importClause.namedBindings) {
+                    if (importClause.namedBindings.kind === 274 /* NamespaceImport */) {
+                      addDeclaration(importClause.namedBindings);
+                    } else {
+                      forEach(importClause.namedBindings.elements, visit);
+                    }
+                  }
+                }
+                break;
+              case 226 /* BinaryExpression */:
+                if (getAssignmentDeclarationKind(node) !== 0 /* None */) {
+                  addDeclaration(node);
+                }
+              default:
+                forEachChild(node, visit);
+            }
+          }
         }
-        permittedJumps = savedPermittedJumps;
-      }
-    }
-  }
-  function getAdjustedSpanFromNodes(startNode2, endNode2, sourceFile) {
-    const start = startNode2.getStart(sourceFile);
-    let end = endNode2.getEnd();
-    if (sourceFile.text.charCodeAt(end) === 59 /* semicolon */) {
-      end++;
-    }
-    return { start, length: end - start };
-  }
-  function getStatementOrExpressionRange(node) {
-    if (isStatement(node)) {
-      return [node];
-    }
-    if (isExpressionNode(node)) {
-      return isExpressionStatement(node.parent) ? [node.parent] : node;
-    }
-    if (isStringLiteralJsxAttribute(node)) {
-      return node;
-    }
-    return void 0;
-  }
-  function isScope(node) {
-    return isArrowFunction(node) ? isFunctionBody(node.body) : isFunctionLikeDeclaration(node) || isSourceFile(node) || isModuleBlock(node) || isClassLike(node);
-  }
-  function collectEnclosingScopes(range) {
-    let current = isReadonlyArray(range.range) ? first(range.range) : range.range;
-    if (range.facts & 8 /* UsesThis */ && !(range.facts & 16 /* UsesThisInFunction */)) {
-      const containingClass = getContainingClass(current);
-      if (containingClass) {
-        const containingFunction = findAncestor(current, isFunctionLikeDeclaration);
-        return containingFunction ? [containingFunction, containingClass] : [containingClass];
-      }
-    }
-    const scopes = [];
-    while (true) {
-      current = current.parent;
-      if (current.kind === 168 /* Parameter */) {
-        current = findAncestor(current, (parent2) => isFunctionLikeDeclaration(parent2)).parent;
-      }
-      if (isScope(current)) {
-        scopes.push(current);
-        if (current.kind === 311 /* SourceFile */) {
-          return scopes;
+      };
+      SourceMapSourceObject = class {
+        constructor(fileName, text, skipTrivia2) {
+          this.fileName = fileName;
+          this.text = text;
+          this.skipTrivia = skipTrivia2;
         }
-      }
-    }
-  }
-  function getFunctionExtractionAtIndex(targetRange, context, requestedChangesIndex) {
-    const { scopes, readsAndWrites: { target, usagesPerScope, functionErrorsPerScope, exposedVariableDeclarations } } = getPossibleExtractionsWorker(targetRange, context);
-    Debug.assert(!functionErrorsPerScope[requestedChangesIndex].length, "The extraction went missing? How?");
-    context.cancellationToken.throwIfCancellationRequested();
-    return extractFunctionInScope(target, scopes[requestedChangesIndex], usagesPerScope[requestedChangesIndex], exposedVariableDeclarations, targetRange, context);
-  }
-  function getConstantExtractionAtIndex(targetRange, context, requestedChangesIndex) {
-    const { scopes, readsAndWrites: { target, usagesPerScope, constantErrorsPerScope, exposedVariableDeclarations } } = getPossibleExtractionsWorker(targetRange, context);
-    Debug.assert(!constantErrorsPerScope[requestedChangesIndex].length, "The extraction went missing? How?");
-    Debug.assert(exposedVariableDeclarations.length === 0, "Extract constant accepted a range containing a variable declaration?");
-    context.cancellationToken.throwIfCancellationRequested();
-    const expression = isExpression(target) ? target : target.statements[0].expression;
-    return extractConstantInScope(expression, scopes[requestedChangesIndex], usagesPerScope[requestedChangesIndex], targetRange.facts, context);
-  }
-  function getPossibleExtractions(targetRange, context) {
-    const { scopes, readsAndWrites: { functionErrorsPerScope, constantErrorsPerScope } } = getPossibleExtractionsWorker(targetRange, context);
-    const extractions = scopes.map((scope, i) => {
-      const functionDescriptionPart = getDescriptionForFunctionInScope(scope);
-      const constantDescriptionPart = getDescriptionForConstantInScope(scope);
-      const scopeDescription = isFunctionLikeDeclaration(scope) ? getDescriptionForFunctionLikeDeclaration(scope) : isClassLike(scope) ? getDescriptionForClassLikeDeclaration(scope) : getDescriptionForModuleLikeDeclaration(scope);
-      let functionDescription;
-      let constantDescription;
-      if (scopeDescription === 1 /* Global */) {
-        functionDescription = formatStringFromArgs(getLocaleSpecificMessage(Diagnostics.Extract_to_0_in_1_scope), [functionDescriptionPart, "global"]);
-        constantDescription = formatStringFromArgs(getLocaleSpecificMessage(Diagnostics.Extract_to_0_in_1_scope), [constantDescriptionPart, "global"]);
-      } else if (scopeDescription === 0 /* Module */) {
-        functionDescription = formatStringFromArgs(getLocaleSpecificMessage(Diagnostics.Extract_to_0_in_1_scope), [functionDescriptionPart, "module"]);
-        constantDescription = formatStringFromArgs(getLocaleSpecificMessage(Diagnostics.Extract_to_0_in_1_scope), [constantDescriptionPart, "module"]);
-      } else {
-        functionDescription = formatStringFromArgs(getLocaleSpecificMessage(Diagnostics.Extract_to_0_in_1), [functionDescriptionPart, scopeDescription]);
-        constantDescription = formatStringFromArgs(getLocaleSpecificMessage(Diagnostics.Extract_to_0_in_1), [constantDescriptionPart, scopeDescription]);
-      }
-      if (i === 0 && !isClassLike(scope)) {
-        constantDescription = formatStringFromArgs(getLocaleSpecificMessage(Diagnostics.Extract_to_0_in_enclosing_scope), [constantDescriptionPart]);
-      }
-      return {
-        functionExtraction: {
-          description: functionDescription,
-          errors: functionErrorsPerScope[i]
-        },
-        constantExtraction: {
-          description: constantDescription,
-          errors: constantErrorsPerScope[i]
+        getLineAndCharacterOfPosition(pos) {
+          return getLineAndCharacterOfPosition(this, pos);
         }
       };
-    });
-    return extractions;
-  }
-  function getPossibleExtractionsWorker(targetRange, context) {
-    const { file: sourceFile } = context;
-    const scopes = collectEnclosingScopes(targetRange);
-    const enclosingTextRange = getEnclosingTextRange(targetRange, sourceFile);
-    const readsAndWrites = collectReadsAndWrites(
-      targetRange,
-      scopes,
-      enclosingTextRange,
-      sourceFile,
-      context.program.getTypeChecker(),
-      context.cancellationToken
-    );
-    return { scopes, readsAndWrites };
-  }
-  function getDescriptionForFunctionInScope(scope) {
-    return isFunctionLikeDeclaration(scope) ? "inner function" : isClassLike(scope) ? "method" : "function";
-  }
-  function getDescriptionForConstantInScope(scope) {
-    return isClassLike(scope) ? "readonly field" : "constant";
-  }
-  function getDescriptionForFunctionLikeDeclaration(scope) {
-    switch (scope.kind) {
-      case 175 /* Constructor */:
-        return "constructor";
-      case 217 /* FunctionExpression */:
-      case 261 /* FunctionDeclaration */:
-        return scope.name ? `function '${scope.name.text}'` : ANONYMOUS;
-      case 218 /* ArrowFunction */:
-        return "arrow function";
-      case 173 /* MethodDeclaration */:
-        return `method '${scope.name.getText()}'`;
-      case 176 /* GetAccessor */:
-        return `'get ${scope.name.getText()}'`;
-      case 177 /* SetAccessor */:
-        return `'set ${scope.name.getText()}'`;
-      default:
-        Debug.assertNever(scope, `Unexpected scope kind ${scope.kind}`);
+      SyntaxTreeCache = class {
+        constructor(host) {
+          this.host = host;
+        }
+        getCurrentSourceFile(fileName) {
+          var _a, _b, _c, _d, _e, _f, _g, _h;
+          const scriptSnapshot = this.host.getScriptSnapshot(fileName);
+          if (!scriptSnapshot) {
+            throw new Error("Could not find file: '" + fileName + "'.");
+          }
+          const scriptKind = getScriptKind(fileName, this.host);
+          const version2 = this.host.getScriptVersion(fileName);
+          let sourceFile;
+          if (this.currentFileName !== fileName) {
+            const options = {
+              languageVersion: 99 /* Latest */,
+              impliedNodeFormat: getImpliedNodeFormatForFile(
+                toPath(fileName, this.host.getCurrentDirectory(), ((_c = (_b = (_a = this.host).getCompilerHost) == null ? void 0 : _b.call(_a)) == null ? void 0 : _c.getCanonicalFileName) || hostGetCanonicalFileName(this.host)),
+                (_h = (_g = (_f = (_e = (_d = this.host).getCompilerHost) == null ? void 0 : _e.call(_d)) == null ? void 0 : _f.getModuleResolutionCache) == null ? void 0 : _g.call(_f)) == null ? void 0 : _h.getPackageJsonInfoCache(),
+                this.host,
+                this.host.getCompilationSettings()
+              ),
+              setExternalModuleIndicator: getSetExternalModuleIndicator(this.host.getCompilationSettings()),
+              // These files are used to produce syntax-based highlighting, which reads JSDoc, so we must use ParseAll.
+              jsDocParsingMode: 0 /* ParseAll */
+            };
+            sourceFile = createLanguageServiceSourceFile(
+              fileName,
+              scriptSnapshot,
+              options,
+              version2,
+              /*setNodeParents*/
+              true,
+              scriptKind
+            );
+          } else if (this.currentFileVersion !== version2) {
+            const editRange = scriptSnapshot.getChangeRange(this.currentFileScriptSnapshot);
+            sourceFile = updateLanguageServiceSourceFile(this.currentSourceFile, scriptSnapshot, version2, editRange);
+          }
+          if (sourceFile) {
+            this.currentFileVersion = version2;
+            this.currentFileName = fileName;
+            this.currentFileScriptSnapshot = scriptSnapshot;
+            this.currentSourceFile = sourceFile;
+          }
+          return this.currentSourceFile;
+        }
+      };
+      NoopCancellationToken = {
+        isCancellationRequested: returnFalse,
+        throwIfCancellationRequested: noop
+      };
+      CancellationTokenObject = class {
+        constructor(cancellationToken) {
+          this.cancellationToken = cancellationToken;
+        }
+        isCancellationRequested() {
+          return this.cancellationToken.isCancellationRequested();
+        }
+        throwIfCancellationRequested() {
+          var _a;
+          if (this.isCancellationRequested()) {
+            (_a = tracing) == null ? void 0 : _a.instant(tracing.Phase.Session, "cancellationThrown", { kind: "CancellationTokenObject" });
+            throw new OperationCanceledException();
+          }
+        }
+      };
+      ThrottledCancellationToken = class {
+        constructor(hostCancellationToken, throttleWaitMilliseconds = 20) {
+          this.hostCancellationToken = hostCancellationToken;
+          this.throttleWaitMilliseconds = throttleWaitMilliseconds;
+          // Store when we last tried to cancel.  Checking cancellation can be expensive (as we have
+          // to marshall over to the host layer).  So we only bother actually checking once enough
+          // time has passed.
+          this.lastCancellationCheckTime = 0;
+        }
+        isCancellationRequested() {
+          const time = timestamp();
+          const duration = Math.abs(time - this.lastCancellationCheckTime);
+          if (duration >= this.throttleWaitMilliseconds) {
+            this.lastCancellationCheckTime = time;
+            return this.hostCancellationToken.isCancellationRequested();
+          }
+          return false;
+        }
+        throwIfCancellationRequested() {
+          var _a;
+          if (this.isCancellationRequested()) {
+            (_a = tracing) == null ? void 0 : _a.instant(tracing.Phase.Session, "cancellationThrown", { kind: "ThrottledCancellationToken" });
+            throw new OperationCanceledException();
+          }
+        }
+      };
+      invalidOperationsInPartialSemanticMode = [
+        "getSemanticDiagnostics",
+        "getSuggestionDiagnostics",
+        "getCompilerOptionsDiagnostics",
+        "getSemanticClassifications",
+        "getEncodedSemanticClassifications",
+        "getCodeFixesAtPosition",
+        "getCombinedCodeFix",
+        "applyCodeActionCommand",
+        "organizeImports",
+        "getEditsForFileRename",
+        "getEmitOutput",
+        "getApplicableRefactors",
+        "getEditsForRefactor",
+        "prepareCallHierarchy",
+        "provideCallHierarchyIncomingCalls",
+        "provideCallHierarchyOutgoingCalls",
+        "provideInlayHints",
+        "getSupportedCodeFixes"
+      ];
+      invalidOperationsInSyntacticMode = [
+        ...invalidOperationsInPartialSemanticMode,
+        "getCompletionsAtPosition",
+        "getCompletionEntryDetails",
+        "getCompletionEntrySymbol",
+        "getSignatureHelpItems",
+        "getQuickInfoAtPosition",
+        "getDefinitionAtPosition",
+        "getDefinitionAndBoundSpan",
+        "getImplementationAtPosition",
+        "getTypeDefinitionAtPosition",
+        "getReferencesAtPosition",
+        "findReferences",
+        "getDocumentHighlights",
+        "getNavigateToItems",
+        "getRenameInfo",
+        "findRenameLocations",
+        "getApplicableRefactors"
+      ];
+      setObjectAllocator(getServicesObjectAllocator());
     }
+  });
+
+  // src/services/transform.ts
+  function transform(source, transformers, compilerOptions) {
+    const diagnostics = [];
+    compilerOptions = fixupCompilerOptions(compilerOptions, diagnostics);
+    const nodes = isArray(source) ? source : [source];
+    const result = transformNodes(
+      /*resolver*/
+      void 0,
+      /*host*/
+      void 0,
+      factory,
+      compilerOptions,
+      nodes,
+      transformers,
+      /*allowDtsFiles*/
+      true
+    );
+    result.diagnostics = concatenate(result.diagnostics, diagnostics);
+    return result;
   }
-  function getDescriptionForClassLikeDeclaration(scope) {
-    return scope.kind === 262 /* ClassDeclaration */ ? scope.name ? `class '${scope.name.text}'` : "anonymous class declaration" : scope.name ? `class expression '${scope.name.text}'` : "anonymous class expression";
-  }
-  function getDescriptionForModuleLikeDeclaration(scope) {
-    return scope.kind === 267 /* ModuleBlock */ ? `namespace '${scope.parent.name.getText()}'` : scope.externalModuleIndicator ? 0 /* Module */ : 1 /* Global */;
-  }
-  function extractFunctionInScope(node, scope, { usages: usagesInScope, typeParameterUsages, substitutions }, exposedVariableDeclarations, range, context) {
-    const checker = context.program.getTypeChecker();
-    const scriptTarget = getEmitScriptTarget(context.program.getCompilerOptions());
-    const importAdder = ts_codefix_exports.createImportAdder(context.file, context.program, context.preferences, context.host);
-    const file = scope.getSourceFile();
-    const functionNameText = getUniqueName(isClassLike(scope) ? "newMethod" : "newFunction", file);
-    const isJS = isInJSFile(scope);
-    const functionName = factory.createIdentifier(functionNameText);
-    let returnType;
-    const parameters = [];
-    const callArguments = [];
-    let writes;
-    usagesInScope.forEach((usage, name) => {
-      let typeNode;
-      if (!isJS) {
-        let type = checker.getTypeOfSymbolAtLocation(usage.symbol, usage.node);
-        type = checker.getBaseTypeOfLiteralType(type);
-        typeNode = ts_codefix_exports.typeToAutoImportableTypeNode(checker, importAdder, type, scope, scriptTarget, 1 /* NoTruncation */);
-      }
-      const paramDecl = factory.createParameterDeclaration(
-        /*modifiers*/
-        void 0,
-        /*dotDotDotToken*/
-        void 0,
-        /*name*/
-        name,
-        /*questionToken*/
-        void 0,
-        typeNode
-      );
-      parameters.push(paramDecl);
-      if (usage.usage === 2 /* Write */) {
-        (writes || (writes = [])).push(usage);
-      }
-      callArguments.push(factory.createIdentifier(name));
-    });
-    const typeParametersAndDeclarations = arrayFrom(typeParameterUsages.values(), (type) => ({ type, declaration: getFirstDeclarationBeforePosition(type, context.startPosition) }));
-    const sortedTypeParametersAndDeclarations = typeParametersAndDeclarations.sort(compareTypesByDeclarationOrder);
-    const typeParameters = sortedTypeParametersAndDeclarations.length === 0 ? void 0 : mapDefined(sortedTypeParametersAndDeclarations, ({ declaration }) => declaration);
-    const callTypeArguments = typeParameters !== void 0 ? typeParameters.map((decl) => factory.createTypeReferenceNode(
-      decl.name,
-      /*typeArguments*/
-      void 0
-    )) : void 0;
-    if (isExpression(node) && !isJS) {
-      const contextualType = checker.getContextualType(node);
-      returnType = checker.typeToTypeNode(contextualType, scope, 1 /* NoTruncation */);
+  var init_transform = __esm({
+    "src/services/transform.ts"() {
+      "use strict";
+      init_ts4();
     }
-    const { body, returnValueProperty } = transformFunctionBody(node, exposedVariableDeclarations, writes, substitutions, !!(range.facts & 1 /* HasReturn */));
-    suppressLeadingAndTrailingTrivia(body);
-    let newFunction;
-    const callThis = !!(range.facts & 16 /* UsesThisInFunction */);
-    if (isClassLike(scope)) {
-      const modifiers = isJS ? [] : [factory.createModifier(123 /* PrivateKeyword */)];
-      if (range.facts & 32 /* InStaticRegion */) {
-        modifiers.push(factory.createModifier(126 /* StaticKeyword */));
-      }
-      if (range.facts & 4 /* IsAsyncFunction */) {
-        modifiers.push(factory.createModifier(134 /* AsyncKeyword */));
-      }
-      newFunction = factory.createMethodDeclaration(
-        modifiers.length ? modifiers : void 0,
-        range.facts & 2 /* IsGenerator */ ? factory.createToken(42 /* AsteriskToken */) : void 0,
-        functionName,
-        /*questionToken*/
-        void 0,
-        typeParameters,
-        parameters,
-        returnType,
-        body
-      );
-    } else {
-      if (callThis) {
-        parameters.unshift(
-          factory.createParameterDeclaration(
-            /*modifiers*/
-            void 0,
-            /*dotDotDotToken*/
-            void 0,
-            /*name*/
-            "this",
-            /*questionToken*/
-            void 0,
-            checker.typeToTypeNode(
-              checker.getTypeAtLocation(range.thisNode),
-              scope,
-              1 /* NoTruncation */
-            ),
-            /*initializer*/
-            void 0
-          )
-        );
+  });
+
+  // src/services/breakpoints.ts
+  function spanInSourceFileAtLocation(sourceFile, position) {
+    if (sourceFile.isDeclarationFile) {
+      return void 0;
+    }
+    let tokenAtLocation = getTokenAtPosition(sourceFile, position);
+    const lineOfPosition = sourceFile.getLineAndCharacterOfPosition(position).line;
+    if (sourceFile.getLineAndCharacterOfPosition(tokenAtLocation.getStart(sourceFile)).line > lineOfPosition) {
+      const preceding = findPrecedingToken(tokenAtLocation.pos, sourceFile);
+      if (!preceding || sourceFile.getLineAndCharacterOfPosition(preceding.getEnd()).line !== lineOfPosition) {
+        return void 0;
       }
-      newFunction = factory.createFunctionDeclaration(
-        range.facts & 4 /* IsAsyncFunction */ ? [factory.createToken(134 /* AsyncKeyword */)] : void 0,
-        range.facts & 2 /* IsGenerator */ ? factory.createToken(42 /* AsteriskToken */) : void 0,
-        functionName,
-        typeParameters,
-        parameters,
-        returnType,
-        body
-      );
+      tokenAtLocation = preceding;
     }
-    const changeTracker = ts_textChanges_exports.ChangeTracker.fromContext(context);
-    const minInsertionPos = (isReadonlyArray(range.range) ? last(range.range) : range.range).end;
-    const nodeToInsertBefore = getNodeToInsertFunctionBefore(minInsertionPos, scope);
-    if (nodeToInsertBefore) {
-      changeTracker.insertNodeBefore(
-        context.file,
-        nodeToInsertBefore,
-        newFunction,
-        /*blankLineBetween*/
-        true
-      );
-    } else {
-      changeTracker.insertNodeAtEndOfScope(context.file, scope, newFunction);
+    if (tokenAtLocation.flags & 33554432 /* Ambient */) {
+      return void 0;
     }
-    importAdder.writeFixes(changeTracker);
-    const newNodes = [];
-    const called = getCalledExpression(scope, range, functionNameText);
-    if (callThis) {
-      callArguments.unshift(factory.createIdentifier("this"));
+    return spanInNode(tokenAtLocation);
+    function textSpan(startNode2, endNode2) {
+      const lastDecorator = canHaveDecorators(startNode2) ? findLast(startNode2.modifiers, isDecorator) : void 0;
+      const start = lastDecorator ? skipTrivia(sourceFile.text, lastDecorator.end) : startNode2.getStart(sourceFile);
+      return createTextSpanFromBounds(start, (endNode2 || startNode2).getEnd());
     }
-    let call = factory.createCallExpression(
-      callThis ? factory.createPropertyAccessExpression(
-        called,
-        "call"
-      ) : called,
-      callTypeArguments,
-      // Note that no attempt is made to take advantage of type argument inference
-      callArguments
-    );
-    if (range.facts & 2 /* IsGenerator */) {
-      call = factory.createYieldExpression(factory.createToken(42 /* AsteriskToken */), call);
+    function textSpanEndingAtNextToken(startNode2, previousTokenToFindNextEndToken) {
+      return textSpan(startNode2, findNextToken(previousTokenToFindNextEndToken, previousTokenToFindNextEndToken.parent, sourceFile));
     }
-    if (range.facts & 4 /* IsAsyncFunction */) {
-      call = factory.createAwaitExpression(call);
+    function spanInNodeIfStartsOnSameLine(node, otherwiseOnNode) {
+      if (node && lineOfPosition === sourceFile.getLineAndCharacterOfPosition(node.getStart(sourceFile)).line) {
+        return spanInNode(node);
+      }
+      return spanInNode(otherwiseOnNode);
     }
-    if (isInJSXContent(node)) {
-      call = factory.createJsxExpression(
-        /*dotDotDotToken*/
-        void 0,
-        call
-      );
+    function spanInNodeArray(nodeArray, node, match) {
+      if (nodeArray) {
+        const index = nodeArray.indexOf(node);
+        if (index >= 0) {
+          let start = index;
+          let end = index + 1;
+          while (start > 0 && match(nodeArray[start - 1]))
+            start--;
+          while (end < nodeArray.length && match(nodeArray[end]))
+            end++;
+          return createTextSpanFromBounds(skipTrivia(sourceFile.text, nodeArray[start].pos), nodeArray[end - 1].end);
+        }
+      }
+      return textSpan(node);
     }
-    if (exposedVariableDeclarations.length && !writes) {
-      Debug.assert(!returnValueProperty, "Expected no returnValueProperty");
-      Debug.assert(!(range.facts & 1 /* HasReturn */), "Expected RangeFacts.HasReturn flag to be unset");
-      if (exposedVariableDeclarations.length === 1) {
-        const variableDeclaration = exposedVariableDeclarations[0];
-        newNodes.push(factory.createVariableStatement(
-          /*modifiers*/
-          void 0,
-          factory.createVariableDeclarationList(
-            [factory.createVariableDeclaration(
-              getSynthesizedDeepClone(variableDeclaration.name),
-              /*exclamationToken*/
-              void 0,
-              /*type*/
-              getSynthesizedDeepClone(variableDeclaration.type),
-              /*initializer*/
-              call
-            )],
-            variableDeclaration.parent.flags
-          )
-        ));
-      } else {
-        const bindingElements = [];
-        const typeElements = [];
-        let commonNodeFlags = exposedVariableDeclarations[0].parent.flags;
-        let sawExplicitType = false;
-        for (const variableDeclaration of exposedVariableDeclarations) {
-          bindingElements.push(factory.createBindingElement(
-            /*dotDotDotToken*/
-            void 0,
-            /*propertyName*/
-            void 0,
-            /*name*/
-            getSynthesizedDeepClone(variableDeclaration.name)
-          ));
-          const variableType = checker.typeToTypeNode(
-            checker.getBaseTypeOfLiteralType(checker.getTypeAtLocation(variableDeclaration)),
-            scope,
-            1 /* NoTruncation */
-          );
-          typeElements.push(factory.createPropertySignature(
-            /*modifiers*/
-            void 0,
-            /*name*/
-            variableDeclaration.symbol.name,
-            /*questionToken*/
-            void 0,
-            /*type*/
-            variableType
-          ));
-          sawExplicitType = sawExplicitType || variableDeclaration.type !== void 0;
-          commonNodeFlags = commonNodeFlags & variableDeclaration.parent.flags;
+    function spanInPreviousNode(node) {
+      return spanInNode(findPrecedingToken(node.pos, sourceFile));
+    }
+    function spanInNextNode(node) {
+      return spanInNode(findNextToken(node, node.parent, sourceFile));
+    }
+    function spanInNode(node) {
+      if (node) {
+        const { parent: parent2 } = node;
+        switch (node.kind) {
+          case 243 /* VariableStatement */:
+            return spanInVariableDeclaration(node.declarationList.declarations[0]);
+          case 260 /* VariableDeclaration */:
+          case 172 /* PropertyDeclaration */:
+          case 171 /* PropertySignature */:
+            return spanInVariableDeclaration(node);
+          case 169 /* Parameter */:
+            return spanInParameterDeclaration(node);
+          case 262 /* FunctionDeclaration */:
+          case 174 /* MethodDeclaration */:
+          case 173 /* MethodSignature */:
+          case 177 /* GetAccessor */:
+          case 178 /* SetAccessor */:
+          case 176 /* Constructor */:
+          case 218 /* FunctionExpression */:
+          case 219 /* ArrowFunction */:
+            return spanInFunctionDeclaration(node);
+          case 241 /* Block */:
+            if (isFunctionBlock(node)) {
+              return spanInFunctionBlock(node);
+            }
+          case 268 /* ModuleBlock */:
+            return spanInBlock(node);
+          case 299 /* CatchClause */:
+            return spanInBlock(node.block);
+          case 244 /* ExpressionStatement */:
+            return textSpan(node.expression);
+          case 253 /* ReturnStatement */:
+            return textSpan(node.getChildAt(0), node.expression);
+          case 247 /* WhileStatement */:
+            return textSpanEndingAtNextToken(node, node.expression);
+          case 246 /* DoStatement */:
+            return spanInNode(node.statement);
+          case 259 /* DebuggerStatement */:
+            return textSpan(node.getChildAt(0));
+          case 245 /* IfStatement */:
+            return textSpanEndingAtNextToken(node, node.expression);
+          case 256 /* LabeledStatement */:
+            return spanInNode(node.statement);
+          case 252 /* BreakStatement */:
+          case 251 /* ContinueStatement */:
+            return textSpan(node.getChildAt(0), node.label);
+          case 248 /* ForStatement */:
+            return spanInForStatement(node);
+          case 249 /* ForInStatement */:
+            return textSpanEndingAtNextToken(node, node.expression);
+          case 250 /* ForOfStatement */:
+            return spanInInitializerOfForLike(node);
+          case 255 /* SwitchStatement */:
+            return textSpanEndingAtNextToken(node, node.expression);
+          case 296 /* CaseClause */:
+          case 297 /* DefaultClause */:
+            return spanInNode(node.statements[0]);
+          case 258 /* TryStatement */:
+            return spanInBlock(node.tryBlock);
+          case 257 /* ThrowStatement */:
+            return textSpan(node, node.expression);
+          case 277 /* ExportAssignment */:
+            return textSpan(node, node.expression);
+          case 271 /* ImportEqualsDeclaration */:
+            return textSpan(node, node.moduleReference);
+          case 272 /* ImportDeclaration */:
+            return textSpan(node, node.moduleSpecifier);
+          case 278 /* ExportDeclaration */:
+            return textSpan(node, node.moduleSpecifier);
+          case 267 /* ModuleDeclaration */:
+            if (getModuleInstanceState(node) !== 1 /* Instantiated */) {
+              return void 0;
+            }
+          case 263 /* ClassDeclaration */:
+          case 266 /* EnumDeclaration */:
+          case 306 /* EnumMember */:
+          case 208 /* BindingElement */:
+            return textSpan(node);
+          case 254 /* WithStatement */:
+            return spanInNode(node.statement);
+          case 170 /* Decorator */:
+            return spanInNodeArray(parent2.modifiers, node, isDecorator);
+          case 206 /* ObjectBindingPattern */:
+          case 207 /* ArrayBindingPattern */:
+            return spanInBindingPattern(node);
+          case 264 /* InterfaceDeclaration */:
+          case 265 /* TypeAliasDeclaration */:
+            return void 0;
+          case 27 /* SemicolonToken */:
+          case 1 /* EndOfFileToken */:
+            return spanInNodeIfStartsOnSameLine(findPrecedingToken(node.pos, sourceFile));
+          case 28 /* CommaToken */:
+            return spanInPreviousNode(node);
+          case 19 /* OpenBraceToken */:
+            return spanInOpenBraceToken(node);
+          case 20 /* CloseBraceToken */:
+            return spanInCloseBraceToken(node);
+          case 24 /* CloseBracketToken */:
+            return spanInCloseBracketToken(node);
+          case 21 /* OpenParenToken */:
+            return spanInOpenParenToken(node);
+          case 22 /* CloseParenToken */:
+            return spanInCloseParenToken(node);
+          case 59 /* ColonToken */:
+            return spanInColonToken(node);
+          case 32 /* GreaterThanToken */:
+          case 30 /* LessThanToken */:
+            return spanInGreaterThanOrLessThanToken(node);
+          case 117 /* WhileKeyword */:
+            return spanInWhileKeyword(node);
+          case 93 /* ElseKeyword */:
+          case 85 /* CatchKeyword */:
+          case 98 /* FinallyKeyword */:
+            return spanInNextNode(node);
+          case 165 /* OfKeyword */:
+            return spanInOfKeyword(node);
+          default:
+            if (isArrayLiteralOrObjectLiteralDestructuringPattern(node)) {
+              return spanInArrayLiteralOrObjectLiteralDestructuringPattern(node);
+            }
+            if ((node.kind === 80 /* Identifier */ || node.kind === 230 /* SpreadElement */ || node.kind === 303 /* PropertyAssignment */ || node.kind === 304 /* ShorthandPropertyAssignment */) && isArrayLiteralOrObjectLiteralDestructuringPattern(parent2)) {
+              return textSpan(node);
+            }
+            if (node.kind === 226 /* BinaryExpression */) {
+              const { left, operatorToken } = node;
+              if (isArrayLiteralOrObjectLiteralDestructuringPattern(left)) {
+                return spanInArrayLiteralOrObjectLiteralDestructuringPattern(
+                  left
+                );
+              }
+              if (operatorToken.kind === 64 /* EqualsToken */ && isArrayLiteralOrObjectLiteralDestructuringPattern(node.parent)) {
+                return textSpan(node);
+              }
+              if (operatorToken.kind === 28 /* CommaToken */) {
+                return spanInNode(left);
+              }
+            }
+            if (isExpressionNode(node)) {
+              switch (parent2.kind) {
+                case 246 /* DoStatement */:
+                  return spanInPreviousNode(node);
+                case 170 /* Decorator */:
+                  return spanInNode(node.parent);
+                case 248 /* ForStatement */:
+                case 250 /* ForOfStatement */:
+                  return textSpan(node);
+                case 226 /* BinaryExpression */:
+                  if (node.parent.operatorToken.kind === 28 /* CommaToken */) {
+                    return textSpan(node);
+                  }
+                  break;
+                case 219 /* ArrowFunction */:
+                  if (node.parent.body === node) {
+                    return textSpan(node);
+                  }
+                  break;
+              }
+            }
+            switch (node.parent.kind) {
+              case 303 /* PropertyAssignment */:
+                if (node.parent.name === node && !isArrayLiteralOrObjectLiteralDestructuringPattern(node.parent.parent)) {
+                  return spanInNode(node.parent.initializer);
+                }
+                break;
+              case 216 /* TypeAssertionExpression */:
+                if (node.parent.type === node) {
+                  return spanInNextNode(node.parent.type);
+                }
+                break;
+              case 260 /* VariableDeclaration */:
+              case 169 /* Parameter */: {
+                const { initializer, type } = node.parent;
+                if (initializer === node || type === node || isAssignmentOperator(node.kind)) {
+                  return spanInPreviousNode(node);
+                }
+                break;
+              }
+              case 226 /* BinaryExpression */: {
+                const { left } = node.parent;
+                if (isArrayLiteralOrObjectLiteralDestructuringPattern(left) && node !== left) {
+                  return spanInPreviousNode(node);
+                }
+                break;
+              }
+              default:
+                if (isFunctionLike(node.parent) && node.parent.type === node) {
+                  return spanInPreviousNode(node);
+                }
+            }
+            return spanInNode(node.parent);
         }
-        const typeLiteral = sawExplicitType ? factory.createTypeLiteralNode(typeElements) : void 0;
-        if (typeLiteral) {
-          setEmitFlags(typeLiteral, 1 /* SingleLine */);
+      }
+      function textSpanFromVariableDeclaration(variableDeclaration) {
+        if (isVariableDeclarationList(variableDeclaration.parent) && variableDeclaration.parent.declarations[0] === variableDeclaration) {
+          return textSpan(findPrecedingToken(variableDeclaration.pos, sourceFile, variableDeclaration.parent), variableDeclaration);
+        } else {
+          return textSpan(variableDeclaration);
         }
-        newNodes.push(factory.createVariableStatement(
-          /*modifiers*/
-          void 0,
-          factory.createVariableDeclarationList(
-            [factory.createVariableDeclaration(
-              factory.createObjectBindingPattern(bindingElements),
-              /*exclamationToken*/
-              void 0,
-              /*type*/
-              typeLiteral,
-              /*initializer*/
-              call
-            )],
-            commonNodeFlags
-          )
-        ));
       }
-    } else if (exposedVariableDeclarations.length || writes) {
-      if (exposedVariableDeclarations.length) {
-        for (const variableDeclaration of exposedVariableDeclarations) {
-          let flags = variableDeclaration.parent.flags;
-          if (flags & 2 /* Const */) {
-            flags = flags & ~2 /* Const */ | 1 /* Let */;
-          }
-          newNodes.push(factory.createVariableStatement(
-            /*modifiers*/
-            void 0,
-            factory.createVariableDeclarationList(
-              [factory.createVariableDeclaration(
-                variableDeclaration.symbol.name,
-                /*exclamationToken*/
-                void 0,
-                getTypeDeepCloneUnionUndefined(variableDeclaration.type)
-              )],
-              flags
-            )
-          ));
+      function spanInVariableDeclaration(variableDeclaration) {
+        if (variableDeclaration.parent.parent.kind === 249 /* ForInStatement */) {
+          return spanInNode(variableDeclaration.parent.parent);
+        }
+        const parent2 = variableDeclaration.parent;
+        if (isBindingPattern(variableDeclaration.name)) {
+          return spanInBindingPattern(variableDeclaration.name);
+        }
+        if (hasOnlyExpressionInitializer(variableDeclaration) && variableDeclaration.initializer || hasSyntacticModifier(variableDeclaration, 32 /* Export */) || parent2.parent.kind === 250 /* ForOfStatement */) {
+          return textSpanFromVariableDeclaration(variableDeclaration);
+        }
+        if (isVariableDeclarationList(variableDeclaration.parent) && variableDeclaration.parent.declarations[0] !== variableDeclaration) {
+          return spanInNode(findPrecedingToken(variableDeclaration.pos, sourceFile, variableDeclaration.parent));
         }
       }
-      if (returnValueProperty) {
-        newNodes.push(factory.createVariableStatement(
-          /*modifiers*/
-          void 0,
-          factory.createVariableDeclarationList(
-            [factory.createVariableDeclaration(
-              returnValueProperty,
-              /*exclamationToken*/
-              void 0,
-              getTypeDeepCloneUnionUndefined(returnType)
-            )],
-            1 /* Let */
-          )
-        ));
+      function canHaveSpanInParameterDeclaration(parameter) {
+        return !!parameter.initializer || parameter.dotDotDotToken !== void 0 || hasSyntacticModifier(parameter, 1 /* Public */ | 2 /* Private */);
       }
-      const assignments = getPropertyAssignmentsForWritesAndVariableDeclarations(exposedVariableDeclarations, writes);
-      if (returnValueProperty) {
-        assignments.unshift(factory.createShorthandPropertyAssignment(returnValueProperty));
+      function spanInParameterDeclaration(parameter) {
+        if (isBindingPattern(parameter.name)) {
+          return spanInBindingPattern(parameter.name);
+        } else if (canHaveSpanInParameterDeclaration(parameter)) {
+          return textSpan(parameter);
+        } else {
+          const functionDeclaration = parameter.parent;
+          const indexOfParameter = functionDeclaration.parameters.indexOf(parameter);
+          Debug.assert(indexOfParameter !== -1);
+          if (indexOfParameter !== 0) {
+            return spanInParameterDeclaration(functionDeclaration.parameters[indexOfParameter - 1]);
+          } else {
+            return spanInNode(functionDeclaration.body);
+          }
+        }
       }
-      if (assignments.length === 1) {
-        Debug.assert(!returnValueProperty, "Shouldn't have returnValueProperty here");
-        newNodes.push(factory.createExpressionStatement(factory.createAssignment(assignments[0].name, call)));
-        if (range.facts & 1 /* HasReturn */) {
-          newNodes.push(factory.createReturnStatement());
+      function canFunctionHaveSpanInWholeDeclaration(functionDeclaration) {
+        return hasSyntacticModifier(functionDeclaration, 32 /* Export */) || functionDeclaration.parent.kind === 263 /* ClassDeclaration */ && functionDeclaration.kind !== 176 /* Constructor */;
+      }
+      function spanInFunctionDeclaration(functionDeclaration) {
+        if (!functionDeclaration.body) {
+          return void 0;
         }
-      } else {
-        newNodes.push(factory.createExpressionStatement(factory.createAssignment(factory.createObjectLiteralExpression(assignments), call)));
-        if (returnValueProperty) {
-          newNodes.push(factory.createReturnStatement(factory.createIdentifier(returnValueProperty)));
+        if (canFunctionHaveSpanInWholeDeclaration(functionDeclaration)) {
+          return textSpan(functionDeclaration);
         }
+        return spanInNode(functionDeclaration.body);
       }
-    } else {
-      if (range.facts & 1 /* HasReturn */) {
-        newNodes.push(factory.createReturnStatement(call));
-      } else if (isReadonlyArray(range.range)) {
-        newNodes.push(factory.createExpressionStatement(call));
-      } else {
-        newNodes.push(call);
-      }
-    }
-    if (isReadonlyArray(range.range)) {
-      changeTracker.replaceNodeRangeWithNodes(context.file, first(range.range), last(range.range), newNodes);
-    } else {
-      changeTracker.replaceNodeWithNodes(context.file, range.range, newNodes);
-    }
-    const edits = changeTracker.getChanges();
-    const renameRange = isReadonlyArray(range.range) ? first(range.range) : range.range;
-    const renameFilename = renameRange.getSourceFile().fileName;
-    const renameLocation = getRenameLocation(
-      edits,
-      renameFilename,
-      functionNameText,
-      /*preferLastLocation*/
-      false
-    );
-    return { renameFilename, renameLocation, edits };
-    function getTypeDeepCloneUnionUndefined(typeNode) {
-      if (typeNode === void 0) {
-        return void 0;
+      function spanInFunctionBlock(block) {
+        const nodeForSpanInBlock = block.statements.length ? block.statements[0] : block.getLastToken();
+        if (canFunctionHaveSpanInWholeDeclaration(block.parent)) {
+          return spanInNodeIfStartsOnSameLine(block.parent, nodeForSpanInBlock);
+        }
+        return spanInNode(nodeForSpanInBlock);
       }
-      const clone2 = getSynthesizedDeepClone(typeNode);
-      let withoutParens = clone2;
-      while (isParenthesizedTypeNode(withoutParens)) {
-        withoutParens = withoutParens.type;
+      function spanInBlock(block) {
+        switch (block.parent.kind) {
+          case 267 /* ModuleDeclaration */:
+            if (getModuleInstanceState(block.parent) !== 1 /* Instantiated */) {
+              return void 0;
+            }
+          case 247 /* WhileStatement */:
+          case 245 /* IfStatement */:
+          case 249 /* ForInStatement */:
+            return spanInNodeIfStartsOnSameLine(block.parent, block.statements[0]);
+          case 248 /* ForStatement */:
+          case 250 /* ForOfStatement */:
+            return spanInNodeIfStartsOnSameLine(findPrecedingToken(block.pos, sourceFile, block.parent), block.statements[0]);
+        }
+        return spanInNode(block.statements[0]);
       }
-      return isUnionTypeNode(withoutParens) && find(withoutParens.types, (t) => t.kind === 157 /* UndefinedKeyword */) ? clone2 : factory.createUnionTypeNode([clone2, factory.createKeywordTypeNode(157 /* UndefinedKeyword */)]);
-    }
-  }
-  function extractConstantInScope(node, scope, { substitutions }, rangeFacts, context) {
-    const checker = context.program.getTypeChecker();
-    const file = scope.getSourceFile();
-    const localNameText = isPropertyAccessExpression(node) && !isClassLike(scope) && !checker.resolveName(
-      node.name.text,
-      node,
-      111551 /* Value */,
-      /*excludeGlobals*/
-      false
-    ) && !isPrivateIdentifier(node.name) && !identifierToKeywordKind(node.name) ? node.name.text : getUniqueName(isClassLike(scope) ? "newProperty" : "newLocal", file);
-    const isJS = isInJSFile(scope);
-    let variableType = isJS || !checker.isContextSensitive(node) ? void 0 : checker.typeToTypeNode(checker.getContextualType(node), scope, 1 /* NoTruncation */);
-    let initializer = transformConstantInitializer(skipParentheses(node), substitutions);
-    ({ variableType, initializer } = transformFunctionInitializerAndType(variableType, initializer));
-    suppressLeadingAndTrailingTrivia(initializer);
-    const changeTracker = ts_textChanges_exports.ChangeTracker.fromContext(context);
-    if (isClassLike(scope)) {
-      Debug.assert(!isJS, "Cannot extract to a JS class");
-      const modifiers = [];
-      modifiers.push(factory.createModifier(123 /* PrivateKeyword */));
-      if (rangeFacts & 32 /* InStaticRegion */) {
-        modifiers.push(factory.createModifier(126 /* StaticKeyword */));
+      function spanInInitializerOfForLike(forLikeStatement) {
+        if (forLikeStatement.initializer.kind === 261 /* VariableDeclarationList */) {
+          const variableDeclarationList = forLikeStatement.initializer;
+          if (variableDeclarationList.declarations.length > 0) {
+            return spanInNode(variableDeclarationList.declarations[0]);
+          }
+        } else {
+          return spanInNode(forLikeStatement.initializer);
+        }
       }
-      modifiers.push(factory.createModifier(148 /* ReadonlyKeyword */));
-      const newVariable = factory.createPropertyDeclaration(
-        modifiers,
-        localNameText,
-        /*questionOrExclamationToken*/
-        void 0,
-        variableType,
-        initializer
-      );
-      let localReference = factory.createPropertyAccessExpression(
-        rangeFacts & 32 /* InStaticRegion */ ? factory.createIdentifier(scope.name.getText()) : factory.createThis(),
-        factory.createIdentifier(localNameText)
-      );
-      if (isInJSXContent(node)) {
-        localReference = factory.createJsxExpression(
-          /*dotDotDotToken*/
-          void 0,
-          localReference
-        );
+      function spanInForStatement(forStatement) {
+        if (forStatement.initializer) {
+          return spanInInitializerOfForLike(forStatement);
+        }
+        if (forStatement.condition) {
+          return textSpan(forStatement.condition);
+        }
+        if (forStatement.incrementor) {
+          return textSpan(forStatement.incrementor);
+        }
       }
-      const maxInsertionPos = node.pos;
-      const nodeToInsertBefore = getNodeToInsertPropertyBefore(maxInsertionPos, scope);
-      changeTracker.insertNodeBefore(
-        context.file,
-        nodeToInsertBefore,
-        newVariable,
-        /*blankLineBetween*/
-        true
-      );
-      changeTracker.replaceNode(context.file, node, localReference);
-    } else {
-      const newVariableDeclaration = factory.createVariableDeclaration(
-        localNameText,
-        /*exclamationToken*/
-        void 0,
-        variableType,
-        initializer
-      );
-      const oldVariableDeclaration = getContainingVariableDeclarationIfInList(node, scope);
-      if (oldVariableDeclaration) {
-        changeTracker.insertNodeBefore(context.file, oldVariableDeclaration, newVariableDeclaration);
-        const localReference = factory.createIdentifier(localNameText);
-        changeTracker.replaceNode(context.file, node, localReference);
-      } else if (node.parent.kind === 243 /* ExpressionStatement */ && scope === findAncestor(node, isScope)) {
-        const newVariableStatement = factory.createVariableStatement(
-          /*modifiers*/
-          void 0,
-          factory.createVariableDeclarationList([newVariableDeclaration], 2 /* Const */)
-        );
-        changeTracker.replaceNode(context.file, node.parent, newVariableStatement);
-      } else {
-        const newVariableStatement = factory.createVariableStatement(
-          /*modifiers*/
-          void 0,
-          factory.createVariableDeclarationList([newVariableDeclaration], 2 /* Const */)
-        );
-        const nodeToInsertBefore = getNodeToInsertConstantBefore(node, scope);
-        if (nodeToInsertBefore.pos === 0) {
-          changeTracker.insertNodeAtTopOfFile(
-            context.file,
-            newVariableStatement,
-            /*blankLineBetween*/
-            false
-          );
-        } else {
-          changeTracker.insertNodeBefore(
-            context.file,
-            nodeToInsertBefore,
-            newVariableStatement,
-            /*blankLineBetween*/
-            false
-          );
+      function spanInBindingPattern(bindingPattern) {
+        const firstBindingElement = forEach(bindingPattern.elements, (element) => element.kind !== 232 /* OmittedExpression */ ? element : void 0);
+        if (firstBindingElement) {
+          return spanInNode(firstBindingElement);
         }
-        if (node.parent.kind === 243 /* ExpressionStatement */) {
-          changeTracker.delete(context.file, node.parent);
-        } else {
-          let localReference = factory.createIdentifier(localNameText);
-          if (isInJSXContent(node)) {
-            localReference = factory.createJsxExpression(
-              /*dotDotDotToken*/
-              void 0,
-              localReference
-            );
-          }
-          changeTracker.replaceNode(context.file, node, localReference);
+        if (bindingPattern.parent.kind === 208 /* BindingElement */) {
+          return textSpan(bindingPattern.parent);
         }
+        return textSpanFromVariableDeclaration(bindingPattern.parent);
       }
-    }
-    const edits = changeTracker.getChanges();
-    const renameFilename = node.getSourceFile().fileName;
-    const renameLocation = getRenameLocation(
-      edits,
-      renameFilename,
-      localNameText,
-      /*preferLastLocation*/
-      true
-    );
-    return { renameFilename, renameLocation, edits };
-    function transformFunctionInitializerAndType(variableType2, initializer2) {
-      if (variableType2 === void 0)
-        return { variableType: variableType2, initializer: initializer2 };
-      if (!isFunctionExpression(initializer2) && !isArrowFunction(initializer2) || !!initializer2.typeParameters)
-        return { variableType: variableType2, initializer: initializer2 };
-      const functionType = checker.getTypeAtLocation(node);
-      const functionSignature = singleOrUndefined(checker.getSignaturesOfType(functionType, 0 /* Call */));
-      if (!functionSignature)
-        return { variableType: variableType2, initializer: initializer2 };
-      if (!!functionSignature.getTypeParameters())
-        return { variableType: variableType2, initializer: initializer2 };
-      const parameters = [];
-      let hasAny = false;
-      for (const p of initializer2.parameters) {
-        if (p.type) {
-          parameters.push(p);
-        } else {
-          const paramType = checker.getTypeAtLocation(p);
-          if (paramType === checker.getAnyType())
-            hasAny = true;
-          parameters.push(factory.updateParameterDeclaration(
-            p,
-            p.modifiers,
-            p.dotDotDotToken,
-            p.name,
-            p.questionToken,
-            p.type || checker.typeToTypeNode(paramType, scope, 1 /* NoTruncation */),
-            p.initializer
-          ));
+      function spanInArrayLiteralOrObjectLiteralDestructuringPattern(node2) {
+        Debug.assert(node2.kind !== 207 /* ArrayBindingPattern */ && node2.kind !== 206 /* ObjectBindingPattern */);
+        const elements = node2.kind === 209 /* ArrayLiteralExpression */ ? node2.elements : node2.properties;
+        const firstBindingElement = forEach(elements, (element) => element.kind !== 232 /* OmittedExpression */ ? element : void 0);
+        if (firstBindingElement) {
+          return spanInNode(firstBindingElement);
         }
+        return textSpan(node2.parent.kind === 226 /* BinaryExpression */ ? node2.parent : node2);
       }
-      if (hasAny)
-        return { variableType: variableType2, initializer: initializer2 };
-      variableType2 = void 0;
-      if (isArrowFunction(initializer2)) {
-        initializer2 = factory.updateArrowFunction(
-          initializer2,
-          canHaveModifiers(node) ? getModifiers(node) : void 0,
-          initializer2.typeParameters,
-          parameters,
-          initializer2.type || checker.typeToTypeNode(functionSignature.getReturnType(), scope, 1 /* NoTruncation */),
-          initializer2.equalsGreaterThanToken,
-          initializer2.body
-        );
-      } else {
-        if (functionSignature && !!functionSignature.thisParameter) {
-          const firstParameter = firstOrUndefined(parameters);
-          if (!firstParameter || isIdentifier(firstParameter.name) && firstParameter.name.escapedText !== "this") {
-            const thisType = checker.getTypeOfSymbolAtLocation(functionSignature.thisParameter, node);
-            parameters.splice(0, 0, factory.createParameterDeclaration(
-              /*modifiers*/
-              void 0,
-              /*dotDotDotToken*/
-              void 0,
-              "this",
-              /*questionToken*/
-              void 0,
-              checker.typeToTypeNode(thisType, scope, 1 /* NoTruncation */)
-            ));
-          }
+      function spanInOpenBraceToken(node2) {
+        switch (node2.parent.kind) {
+          case 266 /* EnumDeclaration */:
+            const enumDeclaration = node2.parent;
+            return spanInNodeIfStartsOnSameLine(findPrecedingToken(node2.pos, sourceFile, node2.parent), enumDeclaration.members.length ? enumDeclaration.members[0] : enumDeclaration.getLastToken(sourceFile));
+          case 263 /* ClassDeclaration */:
+            const classDeclaration = node2.parent;
+            return spanInNodeIfStartsOnSameLine(findPrecedingToken(node2.pos, sourceFile, node2.parent), classDeclaration.members.length ? classDeclaration.members[0] : classDeclaration.getLastToken(sourceFile));
+          case 269 /* CaseBlock */:
+            return spanInNodeIfStartsOnSameLine(node2.parent.parent, node2.parent.clauses[0]);
         }
-        initializer2 = factory.updateFunctionExpression(
-          initializer2,
-          canHaveModifiers(node) ? getModifiers(node) : void 0,
-          initializer2.asteriskToken,
-          initializer2.name,
-          initializer2.typeParameters,
-          parameters,
-          initializer2.type || checker.typeToTypeNode(functionSignature.getReturnType(), scope, 1 /* NoTruncation */),
-          initializer2.body
-        );
+        return spanInNode(node2.parent);
       }
-      return { variableType: variableType2, initializer: initializer2 };
-    }
-  }
-  function getContainingVariableDeclarationIfInList(node, scope) {
-    let prevNode;
-    while (node !== void 0 && node !== scope) {
-      if (isVariableDeclaration(node) && node.initializer === prevNode && isVariableDeclarationList(node.parent) && node.parent.declarations.length > 1) {
-        return node;
+      function spanInCloseBraceToken(node2) {
+        switch (node2.parent.kind) {
+          case 268 /* ModuleBlock */:
+            if (getModuleInstanceState(node2.parent.parent) !== 1 /* Instantiated */) {
+              return void 0;
+            }
+          case 266 /* EnumDeclaration */:
+          case 263 /* ClassDeclaration */:
+            return textSpan(node2);
+          case 241 /* Block */:
+            if (isFunctionBlock(node2.parent)) {
+              return textSpan(node2);
+            }
+          case 299 /* CatchClause */:
+            return spanInNode(lastOrUndefined(node2.parent.statements));
+          case 269 /* CaseBlock */:
+            const caseBlock = node2.parent;
+            const lastClause = lastOrUndefined(caseBlock.clauses);
+            if (lastClause) {
+              return spanInNode(lastOrUndefined(lastClause.statements));
+            }
+            return void 0;
+          case 206 /* ObjectBindingPattern */:
+            const bindingPattern = node2.parent;
+            return spanInNode(lastOrUndefined(bindingPattern.elements) || bindingPattern);
+          default:
+            if (isArrayLiteralOrObjectLiteralDestructuringPattern(node2.parent)) {
+              const objectLiteral = node2.parent;
+              return textSpan(lastOrUndefined(objectLiteral.properties) || objectLiteral);
+            }
+            return spanInNode(node2.parent);
+        }
       }
-      prevNode = node;
-      node = node.parent;
-    }
-  }
-  function getFirstDeclarationBeforePosition(type, position) {
-    let firstDeclaration;
-    const symbol = type.symbol;
-    if (symbol && symbol.declarations) {
-      for (const declaration of symbol.declarations) {
-        if ((firstDeclaration === void 0 || declaration.pos < firstDeclaration.pos) && declaration.pos < position) {
-          firstDeclaration = declaration;
+      function spanInCloseBracketToken(node2) {
+        switch (node2.parent.kind) {
+          case 207 /* ArrayBindingPattern */:
+            const bindingPattern = node2.parent;
+            return textSpan(lastOrUndefined(bindingPattern.elements) || bindingPattern);
+          default:
+            if (isArrayLiteralOrObjectLiteralDestructuringPattern(node2.parent)) {
+              const arrayLiteral = node2.parent;
+              return textSpan(lastOrUndefined(arrayLiteral.elements) || arrayLiteral);
+            }
+            return spanInNode(node2.parent);
         }
       }
-    }
-    return firstDeclaration;
-  }
-  function compareTypesByDeclarationOrder({ type: type1, declaration: declaration1 }, { type: type2, declaration: declaration2 }) {
-    return compareProperties(declaration1, declaration2, "pos", compareValues) || compareStringsCaseSensitive(
-      type1.symbol ? type1.symbol.getName() : "",
-      type2.symbol ? type2.symbol.getName() : ""
-    ) || compareValues(type1.id, type2.id);
-  }
-  function getCalledExpression(scope, range, functionNameText) {
-    const functionReference = factory.createIdentifier(functionNameText);
-    if (isClassLike(scope)) {
-      const lhs = range.facts & 32 /* InStaticRegion */ ? factory.createIdentifier(scope.name.text) : factory.createThis();
-      return factory.createPropertyAccessExpression(lhs, functionReference);
-    } else {
-      return functionReference;
-    }
-  }
-  function transformFunctionBody(body, exposedVariableDeclarations, writes, substitutions, hasReturn2) {
-    const hasWritesOrVariableDeclarations = writes !== void 0 || exposedVariableDeclarations.length > 0;
-    if (isBlock(body) && !hasWritesOrVariableDeclarations && substitutions.size === 0) {
-      return { body: factory.createBlock(
-        body.statements,
-        /*multiLine*/
-        true
-      ), returnValueProperty: void 0 };
-    }
-    let returnValueProperty;
-    let ignoreReturns = false;
-    const statements = factory.createNodeArray(isBlock(body) ? body.statements.slice(0) : [isStatement(body) ? body : factory.createReturnStatement(skipParentheses(body))]);
-    if (hasWritesOrVariableDeclarations || substitutions.size) {
-      const rewrittenStatements = visitNodes2(statements, visitor, isStatement).slice();
-      if (hasWritesOrVariableDeclarations && !hasReturn2 && isStatement(body)) {
-        const assignments = getPropertyAssignmentsForWritesAndVariableDeclarations(exposedVariableDeclarations, writes);
-        if (assignments.length === 1) {
-          rewrittenStatements.push(factory.createReturnStatement(assignments[0].name));
-        } else {
-          rewrittenStatements.push(factory.createReturnStatement(factory.createObjectLiteralExpression(assignments)));
+      function spanInOpenParenToken(node2) {
+        if (node2.parent.kind === 246 /* DoStatement */ || // Go to while keyword and do action instead
+        node2.parent.kind === 213 /* CallExpression */ || node2.parent.kind === 214 /* NewExpression */) {
+          return spanInPreviousNode(node2);
+        }
+        if (node2.parent.kind === 217 /* ParenthesizedExpression */) {
+          return spanInNextNode(node2);
         }
+        return spanInNode(node2.parent);
       }
-      return { body: factory.createBlock(
-        rewrittenStatements,
-        /*multiLine*/
-        true
-      ), returnValueProperty };
-    } else {
-      return { body: factory.createBlock(
-        statements,
-        /*multiLine*/
-        true
-      ), returnValueProperty: void 0 };
-    }
-    function visitor(node) {
-      if (!ignoreReturns && isReturnStatement(node) && hasWritesOrVariableDeclarations) {
-        const assignments = getPropertyAssignmentsForWritesAndVariableDeclarations(exposedVariableDeclarations, writes);
-        if (node.expression) {
-          if (!returnValueProperty) {
-            returnValueProperty = "__return";
-          }
-          assignments.unshift(factory.createPropertyAssignment(returnValueProperty, visitNode(node.expression, visitor, isExpression)));
+      function spanInCloseParenToken(node2) {
+        switch (node2.parent.kind) {
+          case 218 /* FunctionExpression */:
+          case 262 /* FunctionDeclaration */:
+          case 219 /* ArrowFunction */:
+          case 174 /* MethodDeclaration */:
+          case 173 /* MethodSignature */:
+          case 177 /* GetAccessor */:
+          case 178 /* SetAccessor */:
+          case 176 /* Constructor */:
+          case 247 /* WhileStatement */:
+          case 246 /* DoStatement */:
+          case 248 /* ForStatement */:
+          case 250 /* ForOfStatement */:
+          case 213 /* CallExpression */:
+          case 214 /* NewExpression */:
+          case 217 /* ParenthesizedExpression */:
+            return spanInPreviousNode(node2);
+          default:
+            return spanInNode(node2.parent);
         }
-        if (assignments.length === 1) {
-          return factory.createReturnStatement(assignments[0].name);
-        } else {
-          return factory.createReturnStatement(factory.createObjectLiteralExpression(assignments));
+      }
+      function spanInColonToken(node2) {
+        if (isFunctionLike(node2.parent) || node2.parent.kind === 303 /* PropertyAssignment */ || node2.parent.kind === 169 /* Parameter */) {
+          return spanInPreviousNode(node2);
         }
-      } else {
-        const oldIgnoreReturns = ignoreReturns;
-        ignoreReturns = ignoreReturns || isFunctionLikeDeclaration(node) || isClassLike(node);
-        const substitution = substitutions.get(getNodeId(node).toString());
-        const result = substitution ? getSynthesizedDeepClone(substitution) : visitEachChild(node, visitor, nullTransformationContext);
-        ignoreReturns = oldIgnoreReturns;
-        return result;
+        return spanInNode(node2.parent);
       }
-    }
-  }
-  function transformConstantInitializer(initializer, substitutions) {
-    return substitutions.size ? visitor(initializer) : initializer;
-    function visitor(node) {
-      const substitution = substitutions.get(getNodeId(node).toString());
-      return substitution ? getSynthesizedDeepClone(substitution) : visitEachChild(node, visitor, nullTransformationContext);
-    }
-  }
-  function getStatementsOrClassElements(scope) {
-    if (isFunctionLikeDeclaration(scope)) {
-      const body = scope.body;
-      if (isBlock(body)) {
-        return body.statements;
+      function spanInGreaterThanOrLessThanToken(node2) {
+        if (node2.parent.kind === 216 /* TypeAssertionExpression */) {
+          return spanInNextNode(node2);
+        }
+        return spanInNode(node2.parent);
       }
-    } else if (isModuleBlock(scope) || isSourceFile(scope)) {
-      return scope.statements;
-    } else if (isClassLike(scope)) {
-      return scope.members;
-    } else {
-      assertType(scope);
-    }
-    return emptyArray;
-  }
-  function getNodeToInsertFunctionBefore(minPos, scope) {
-    return find(getStatementsOrClassElements(scope), (child) => child.pos >= minPos && isFunctionLikeDeclaration(child) && !isConstructorDeclaration(child));
-  }
-  function getNodeToInsertPropertyBefore(maxPos, scope) {
-    const members = scope.members;
-    Debug.assert(members.length > 0, "Found no members");
-    let prevMember;
-    let allProperties = true;
-    for (const member of members) {
-      if (member.pos > maxPos) {
-        return prevMember || members[0];
+      function spanInWhileKeyword(node2) {
+        if (node2.parent.kind === 246 /* DoStatement */) {
+          return textSpanEndingAtNextToken(node2, node2.parent.expression);
+        }
+        return spanInNode(node2.parent);
       }
-      if (allProperties && !isPropertyDeclaration(member)) {
-        if (prevMember !== void 0) {
-          return member;
+      function spanInOfKeyword(node2) {
+        if (node2.parent.kind === 250 /* ForOfStatement */) {
+          return spanInNextNode(node2);
         }
-        allProperties = false;
+        return spanInNode(node2.parent);
       }
-      prevMember = member;
     }
-    if (prevMember === void 0)
-      return Debug.fail();
-    return prevMember;
   }
-  function getNodeToInsertConstantBefore(node, scope) {
-    Debug.assert(!isClassLike(scope));
-    let prevScope;
-    for (let curr = node; curr !== scope; curr = curr.parent) {
-      if (isScope(curr)) {
-        prevScope = curr;
-      }
+  var init_breakpoints = __esm({
+    "src/services/breakpoints.ts"() {
+      "use strict";
+      init_ts4();
     }
-    for (let curr = (prevScope || node).parent; ; curr = curr.parent) {
-      if (isBlockLike(curr)) {
-        let prevStatement;
-        for (const statement of curr.statements) {
-          if (statement.pos > node.pos) {
-            break;
-          }
-          prevStatement = statement;
-        }
-        if (!prevStatement && isCaseClause(curr)) {
-          Debug.assert(isSwitchStatement(curr.parent.parent), "Grandparent isn't a switch statement");
-          return curr.parent.parent;
-        }
-        return Debug.checkDefined(prevStatement, "prevStatement failed to get set");
-      }
-      Debug.assert(curr !== scope, "Didn't encounter a block-like before encountering scope");
+  });
+
+  // src/services/_namespaces/ts.BreakpointResolver.ts
+  var ts_BreakpointResolver_exports = {};
+  __export(ts_BreakpointResolver_exports, {
+    spanInSourceFileAtLocation: () => spanInSourceFileAtLocation
+  });
+  var init_ts_BreakpointResolver = __esm({
+    "src/services/_namespaces/ts.BreakpointResolver.ts"() {
+      "use strict";
+      init_breakpoints();
     }
+  });
+
+  // src/services/callHierarchy.ts
+  function isNamedExpression(node) {
+    return (isFunctionExpression(node) || isClassExpression(node)) && isNamedDeclaration(node);
   }
-  function getPropertyAssignmentsForWritesAndVariableDeclarations(exposedVariableDeclarations, writes) {
-    const variableAssignments = map(exposedVariableDeclarations, (v) => factory.createShorthandPropertyAssignment(v.symbol.name));
-    const writeAssignments = map(writes, (w) => factory.createShorthandPropertyAssignment(w.symbol.name));
-    return variableAssignments === void 0 ? writeAssignments : writeAssignments === void 0 ? variableAssignments : variableAssignments.concat(writeAssignments);
+  function isConstNamedExpression(node) {
+    return (isFunctionExpression(node) || isArrowFunction(node) || isClassExpression(node)) && isVariableDeclaration(node.parent) && node === node.parent.initializer && isIdentifier(node.parent.name) && !!(getCombinedNodeFlags(node.parent) & 2 /* Const */);
   }
-  function isReadonlyArray(v) {
-    return isArray(v);
+  function isPossibleCallHierarchyDeclaration(node) {
+    return isSourceFile(node) || isModuleDeclaration(node) || isFunctionDeclaration(node) || isFunctionExpression(node) || isClassDeclaration(node) || isClassExpression(node) || isClassStaticBlockDeclaration(node) || isMethodDeclaration(node) || isMethodSignature(node) || isGetAccessorDeclaration(node) || isSetAccessorDeclaration(node);
   }
-  function getEnclosingTextRange(targetRange, sourceFile) {
-    return isReadonlyArray(targetRange.range) ? { pos: first(targetRange.range).getStart(sourceFile), end: last(targetRange.range).getEnd() } : targetRange.range;
+  function isValidCallHierarchyDeclaration(node) {
+    return isSourceFile(node) || isModuleDeclaration(node) && isIdentifier(node.name) || isFunctionDeclaration(node) || isClassDeclaration(node) || isClassStaticBlockDeclaration(node) || isMethodDeclaration(node) || isMethodSignature(node) || isGetAccessorDeclaration(node) || isSetAccessorDeclaration(node) || isNamedExpression(node) || isConstNamedExpression(node);
   }
-  function collectReadsAndWrites(targetRange, scopes, enclosingTextRange, sourceFile, checker, cancellationToken) {
-    const allTypeParameterUsages = /* @__PURE__ */ new Map();
-    const usagesPerScope = [];
-    const substitutionsPerScope = [];
-    const functionErrorsPerScope = [];
-    const constantErrorsPerScope = [];
-    const visibleDeclarationsInExtractedRange = [];
-    const exposedVariableSymbolSet = /* @__PURE__ */ new Map();
-    const exposedVariableDeclarations = [];
-    let firstExposedNonVariableDeclaration;
-    const expression = !isReadonlyArray(targetRange.range) ? targetRange.range : targetRange.range.length === 1 && isExpressionStatement(targetRange.range[0]) ? targetRange.range[0].expression : void 0;
-    let expressionDiagnostic;
-    if (expression === void 0) {
-      const statements = targetRange.range;
-      const start = first(statements).getStart();
-      const end = last(statements).end;
-      expressionDiagnostic = createFileDiagnostic(sourceFile, start, end - start, Messages.expressionExpected);
-    } else if (checker.getTypeAtLocation(expression).flags & (16384 /* Void */ | 131072 /* Never */)) {
-      expressionDiagnostic = createDiagnosticForNode(expression, Messages.uselessConstantType);
+  function getCallHierarchyDeclarationReferenceNode(node) {
+    if (isSourceFile(node))
+      return node;
+    if (isNamedDeclaration(node))
+      return node.name;
+    if (isConstNamedExpression(node))
+      return node.parent.name;
+    return Debug.checkDefined(node.modifiers && find(node.modifiers, isDefaultModifier3));
+  }
+  function isDefaultModifier3(node) {
+    return node.kind === 90 /* DefaultKeyword */;
+  }
+  function getSymbolOfCallHierarchyDeclaration(typeChecker, node) {
+    const location = getCallHierarchyDeclarationReferenceNode(node);
+    return location && typeChecker.getSymbolAtLocation(location);
+  }
+  function getCallHierarchyItemName(program, node) {
+    if (isSourceFile(node)) {
+      return { text: node.fileName, pos: 0, end: 0 };
     }
-    for (const scope of scopes) {
-      usagesPerScope.push({ usages: /* @__PURE__ */ new Map(), typeParameterUsages: /* @__PURE__ */ new Map(), substitutions: /* @__PURE__ */ new Map() });
-      substitutionsPerScope.push(/* @__PURE__ */ new Map());
-      functionErrorsPerScope.push([]);
-      const constantErrors = [];
-      if (expressionDiagnostic) {
-        constantErrors.push(expressionDiagnostic);
-      }
-      if (isClassLike(scope) && isInJSFile(scope)) {
-        constantErrors.push(createDiagnosticForNode(scope, Messages.cannotExtractToJSClass));
+    if ((isFunctionDeclaration(node) || isClassDeclaration(node)) && !isNamedDeclaration(node)) {
+      const defaultModifier = node.modifiers && find(node.modifiers, isDefaultModifier3);
+      if (defaultModifier) {
+        return { text: "default", pos: defaultModifier.getStart(), end: defaultModifier.getEnd() };
       }
-      if (isArrowFunction(scope) && !isBlock(scope.body)) {
-        constantErrors.push(createDiagnosticForNode(scope, Messages.cannotExtractToExpressionArrowFunction));
+    }
+    if (isClassStaticBlockDeclaration(node)) {
+      const sourceFile = node.getSourceFile();
+      const pos = skipTrivia(sourceFile.text, moveRangePastModifiers(node).pos);
+      const end = pos + 6;
+      const typeChecker = program.getTypeChecker();
+      const symbol = typeChecker.getSymbolAtLocation(node.parent);
+      const prefix = symbol ? `${typeChecker.symbolToString(symbol, node.parent)} ` : "";
+      return { text: `${prefix}static {}`, pos, end };
+    }
+    const declName = isConstNamedExpression(node) ? node.parent.name : Debug.checkDefined(getNameOfDeclaration(node), "Expected call hierarchy item to have a name");
+    let text = isIdentifier(declName) ? idText(declName) : isStringOrNumericLiteralLike(declName) ? declName.text : isComputedPropertyName(declName) ? isStringOrNumericLiteralLike(declName.expression) ? declName.expression.text : void 0 : void 0;
+    if (text === void 0) {
+      const typeChecker = program.getTypeChecker();
+      const symbol = typeChecker.getSymbolAtLocation(declName);
+      if (symbol) {
+        text = typeChecker.symbolToString(symbol, node);
       }
-      constantErrorsPerScope.push(constantErrors);
     }
-    const seenUsages = /* @__PURE__ */ new Map();
-    const target = isReadonlyArray(targetRange.range) ? factory.createBlock(targetRange.range) : targetRange.range;
-    const unmodifiedNode = isReadonlyArray(targetRange.range) ? first(targetRange.range) : targetRange.range;
-    const inGenericContext = isInGenericContext(unmodifiedNode);
-    collectUsages(target);
-    if (inGenericContext && !isReadonlyArray(targetRange.range) && !isJsxAttribute(targetRange.range)) {
-      const contextualType = checker.getContextualType(targetRange.range);
-      recordTypeParameterUsages(contextualType);
+    if (text === void 0) {
+      const printer = createPrinterWithRemoveCommentsOmitTrailingSemicolon();
+      text = usingSingleLineStringWriter((writer) => printer.writeNode(4 /* Unspecified */, node, node.getSourceFile(), writer));
     }
-    if (allTypeParameterUsages.size > 0) {
-      const seenTypeParameterUsages = /* @__PURE__ */ new Map();
-      let i = 0;
-      for (let curr = unmodifiedNode; curr !== void 0 && i < scopes.length; curr = curr.parent) {
-        if (curr === scopes[i]) {
-          seenTypeParameterUsages.forEach((typeParameter, id) => {
-            usagesPerScope[i].typeParameterUsages.set(id, typeParameter);
-          });
-          i++;
+    return { text, pos: declName.getStart(), end: declName.getEnd() };
+  }
+  function getCallHierarchItemContainerName(node) {
+    var _a, _b;
+    if (isConstNamedExpression(node)) {
+      if (isModuleBlock(node.parent.parent.parent.parent) && isIdentifier(node.parent.parent.parent.parent.parent.name)) {
+        return node.parent.parent.parent.parent.parent.name.getText();
+      }
+      return;
+    }
+    switch (node.kind) {
+      case 177 /* GetAccessor */:
+      case 178 /* SetAccessor */:
+      case 174 /* MethodDeclaration */:
+        if (node.parent.kind === 210 /* ObjectLiteralExpression */) {
+          return (_a = getAssignedName(node.parent)) == null ? void 0 : _a.getText();
         }
-        if (isDeclarationWithTypeParameters(curr)) {
-          for (const typeParameterDecl of getEffectiveTypeParameterDeclarations(curr)) {
-            const typeParameter = checker.getTypeAtLocation(typeParameterDecl);
-            if (allTypeParameterUsages.has(typeParameter.id.toString())) {
-              seenTypeParameterUsages.set(typeParameter.id.toString(), typeParameter);
-            }
-          }
+        return (_b = getNameOfDeclaration(node.parent)) == null ? void 0 : _b.getText();
+      case 262 /* FunctionDeclaration */:
+      case 263 /* ClassDeclaration */:
+      case 267 /* ModuleDeclaration */:
+        if (isModuleBlock(node.parent) && isIdentifier(node.parent.parent.name)) {
+          return node.parent.parent.name.getText();
         }
-      }
-      Debug.assert(i === scopes.length, "Should have iterated all scopes");
     }
-    if (visibleDeclarationsInExtractedRange.length) {
-      const containingLexicalScopeOfExtraction = isBlockScope(scopes[0], scopes[0].parent) ? scopes[0] : getEnclosingBlockScopeContainer(scopes[0]);
-      forEachChild(containingLexicalScopeOfExtraction, checkForUsedDeclarations);
+  }
+  function findImplementation(typeChecker, node) {
+    if (node.body) {
+      return node;
     }
-    for (let i = 0; i < scopes.length; i++) {
-      const scopeUsages = usagesPerScope[i];
-      if (i > 0 && (scopeUsages.usages.size > 0 || scopeUsages.typeParameterUsages.size > 0)) {
-        const errorNode = isReadonlyArray(targetRange.range) ? targetRange.range[0] : targetRange.range;
-        constantErrorsPerScope[i].push(createDiagnosticForNode(errorNode, Messages.cannotAccessVariablesFromNestedScopes));
-      }
-      if (targetRange.facts & 16 /* UsesThisInFunction */ && isClassLike(scopes[i])) {
-        functionErrorsPerScope[i].push(createDiagnosticForNode(targetRange.thisNode, Messages.cannotExtractFunctionsContainingThisToMethod));
+    if (isConstructorDeclaration(node)) {
+      return getFirstConstructorWithBody(node.parent);
+    }
+    if (isFunctionDeclaration(node) || isMethodDeclaration(node)) {
+      const symbol = getSymbolOfCallHierarchyDeclaration(typeChecker, node);
+      if (symbol && symbol.valueDeclaration && isFunctionLikeDeclaration(symbol.valueDeclaration) && symbol.valueDeclaration.body) {
+        return symbol.valueDeclaration;
       }
-      let hasWrite = false;
-      let readonlyClassPropertyWrite;
-      usagesPerScope[i].usages.forEach((value) => {
-        if (value.usage === 2 /* Write */) {
-          hasWrite = true;
-          if (value.symbol.flags & 106500 /* ClassMember */ && value.symbol.valueDeclaration && hasEffectiveModifier(value.symbol.valueDeclaration, 64 /* Readonly */)) {
-            readonlyClassPropertyWrite = value.symbol.valueDeclaration;
+      return void 0;
+    }
+    return node;
+  }
+  function findAllInitialDeclarations(typeChecker, node) {
+    const symbol = getSymbolOfCallHierarchyDeclaration(typeChecker, node);
+    let declarations;
+    if (symbol && symbol.declarations) {
+      const indices = indicesOf(symbol.declarations);
+      const keys = map(symbol.declarations, (decl) => ({ file: decl.getSourceFile().fileName, pos: decl.pos }));
+      indices.sort((a, b) => compareStringsCaseSensitive(keys[a].file, keys[b].file) || keys[a].pos - keys[b].pos);
+      const sortedDeclarations = map(indices, (i) => symbol.declarations[i]);
+      let lastDecl;
+      for (const decl of sortedDeclarations) {
+        if (isValidCallHierarchyDeclaration(decl)) {
+          if (!lastDecl || lastDecl.parent !== decl.parent || lastDecl.end !== decl.pos) {
+            declarations = append(declarations, decl);
           }
+          lastDecl = decl;
         }
-      });
-      Debug.assert(isReadonlyArray(targetRange.range) || exposedVariableDeclarations.length === 0, "No variable declarations expected if something was extracted");
-      if (hasWrite && !isReadonlyArray(targetRange.range)) {
-        const diag2 = createDiagnosticForNode(targetRange.range, Messages.cannotWriteInExpression);
-        functionErrorsPerScope[i].push(diag2);
-        constantErrorsPerScope[i].push(diag2);
-      } else if (readonlyClassPropertyWrite && i > 0) {
-        const diag2 = createDiagnosticForNode(readonlyClassPropertyWrite, Messages.cannotExtractReadonlyPropertyInitializerOutsideConstructor);
-        functionErrorsPerScope[i].push(diag2);
-        constantErrorsPerScope[i].push(diag2);
-      } else if (firstExposedNonVariableDeclaration) {
-        const diag2 = createDiagnosticForNode(firstExposedNonVariableDeclaration, Messages.cannotExtractExportedEntity);
-        functionErrorsPerScope[i].push(diag2);
-        constantErrorsPerScope[i].push(diag2);
       }
     }
-    return { target, usagesPerScope, functionErrorsPerScope, constantErrorsPerScope, exposedVariableDeclarations };
-    function isInGenericContext(node) {
-      return !!findAncestor(node, (n) => isDeclarationWithTypeParameters(n) && getEffectiveTypeParameterDeclarations(n).length !== 0);
+    return declarations;
+  }
+  function findImplementationOrAllInitialDeclarations(typeChecker, node) {
+    if (isClassStaticBlockDeclaration(node)) {
+      return node;
     }
-    function recordTypeParameterUsages(type) {
-      const symbolWalker = checker.getSymbolWalker(() => (cancellationToken.throwIfCancellationRequested(), true));
-      const { visitedTypes } = symbolWalker.walkType(type);
-      for (const visitedType of visitedTypes) {
-        if (visitedType.isTypeParameter()) {
-          allTypeParameterUsages.set(visitedType.id.toString(), visitedType);
-        }
-      }
+    if (isFunctionLikeDeclaration(node)) {
+      return findImplementation(typeChecker, node) ?? findAllInitialDeclarations(typeChecker, node) ?? node;
     }
-    function collectUsages(node, valueUsage = 1 /* Read */) {
-      if (inGenericContext) {
-        const type = checker.getTypeAtLocation(node);
-        recordTypeParameterUsages(type);
+    return findAllInitialDeclarations(typeChecker, node) ?? node;
+  }
+  function resolveCallHierarchyDeclaration(program, location) {
+    const typeChecker = program.getTypeChecker();
+    let followingSymbol = false;
+    while (true) {
+      if (isValidCallHierarchyDeclaration(location)) {
+        return findImplementationOrAllInitialDeclarations(typeChecker, location);
       }
-      if (isDeclaration(node) && node.symbol) {
-        visibleDeclarationsInExtractedRange.push(node);
+      if (isPossibleCallHierarchyDeclaration(location)) {
+        const ancestor = findAncestor(location, isValidCallHierarchyDeclaration);
+        return ancestor && findImplementationOrAllInitialDeclarations(typeChecker, ancestor);
       }
-      if (isAssignmentExpression(node)) {
-        collectUsages(node.left, 2 /* Write */);
-        collectUsages(node.right);
-      } else if (isUnaryExpressionWithWrite(node)) {
-        collectUsages(node.operand, 2 /* Write */);
-      } else if (isPropertyAccessExpression(node) || isElementAccessExpression(node)) {
-        forEachChild(node, collectUsages);
-      } else if (isIdentifier(node)) {
-        if (!node.parent) {
-          return;
+      if (isDeclarationName(location)) {
+        if (isValidCallHierarchyDeclaration(location.parent)) {
+          return findImplementationOrAllInitialDeclarations(typeChecker, location.parent);
         }
-        if (isQualifiedName(node.parent) && node !== node.parent.left) {
-          return;
+        if (isPossibleCallHierarchyDeclaration(location.parent)) {
+          const ancestor = findAncestor(location.parent, isValidCallHierarchyDeclaration);
+          return ancestor && findImplementationOrAllInitialDeclarations(typeChecker, ancestor);
         }
-        if (isPropertyAccessExpression(node.parent) && node !== node.parent.expression) {
-          return;
+        if (isVariableDeclaration(location.parent) && location.parent.initializer && isConstNamedExpression(location.parent.initializer)) {
+          return location.parent.initializer;
         }
-        recordUsage(
-          node,
-          valueUsage,
-          /*isTypeNode*/
-          isPartOfTypeNode(node)
-        );
-      } else {
-        forEachChild(node, collectUsages);
+        return void 0;
       }
-    }
-    function recordUsage(n, usage, isTypeNode2) {
-      const symbolId = recordUsagebySymbol(n, usage, isTypeNode2);
-      if (symbolId) {
-        for (let i = 0; i < scopes.length; i++) {
-          const substitution = substitutionsPerScope[i].get(symbolId);
-          if (substitution) {
-            usagesPerScope[i].substitutions.set(getNodeId(n).toString(), substitution);
-          }
+      if (isConstructorDeclaration(location)) {
+        if (isValidCallHierarchyDeclaration(location.parent)) {
+          return location.parent;
         }
-      }
-    }
-    function recordUsagebySymbol(identifier, usage, isTypeName) {
-      const symbol = getSymbolReferencedByIdentifier(identifier);
-      if (!symbol) {
         return void 0;
       }
-      const symbolId = getSymbolId(symbol).toString();
-      const lastUsage = seenUsages.get(symbolId);
-      if (lastUsage && lastUsage >= usage) {
-        return symbolId;
+      if (location.kind === 126 /* StaticKeyword */ && isClassStaticBlockDeclaration(location.parent)) {
+        location = location.parent;
+        continue;
       }
-      seenUsages.set(symbolId, usage);
-      if (lastUsage) {
-        for (const perScope of usagesPerScope) {
-          const prevEntry = perScope.usages.get(identifier.text);
-          if (prevEntry) {
-            perScope.usages.set(identifier.text, { usage, symbol, node: identifier });
+      if (isVariableDeclaration(location) && location.initializer && isConstNamedExpression(location.initializer)) {
+        return location.initializer;
+      }
+      if (!followingSymbol) {
+        let symbol = typeChecker.getSymbolAtLocation(location);
+        if (symbol) {
+          if (symbol.flags & 2097152 /* Alias */) {
+            symbol = typeChecker.getAliasedSymbol(symbol);
+          }
+          if (symbol.valueDeclaration) {
+            followingSymbol = true;
+            location = symbol.valueDeclaration;
+            continue;
           }
         }
-        return symbolId;
       }
-      const decls = symbol.getDeclarations();
-      const declInFile = decls && find(decls, (d) => d.getSourceFile() === sourceFile);
-      if (!declInFile) {
-        return void 0;
-      }
-      if (rangeContainsStartEnd(enclosingTextRange, declInFile.getStart(), declInFile.end)) {
-        return void 0;
-      }
-      if (targetRange.facts & 2 /* IsGenerator */ && usage === 2 /* Write */) {
-        const diag2 = createDiagnosticForNode(identifier, Messages.cannotExtractRangeThatContainsWritesToReferencesLocatedOutsideOfTheTargetRangeInGenerators);
-        for (const errors of functionErrorsPerScope) {
-          errors.push(diag2);
-        }
-        for (const errors of constantErrorsPerScope) {
-          errors.push(diag2);
-        }
+      return void 0;
+    }
+  }
+  function createCallHierarchyItem(program, node) {
+    const sourceFile = node.getSourceFile();
+    const name = getCallHierarchyItemName(program, node);
+    const containerName = getCallHierarchItemContainerName(node);
+    const kind = getNodeKind(node);
+    const kindModifiers = getNodeModifiers(node);
+    const span = createTextSpanFromBounds(skipTrivia(
+      sourceFile.text,
+      node.getFullStart(),
+      /*stopAfterLineBreak*/
+      false,
+      /*stopAtComments*/
+      true
+    ), node.getEnd());
+    const selectionSpan = createTextSpanFromBounds(name.pos, name.end);
+    return { file: sourceFile.fileName, kind, kindModifiers, name: name.text, containerName, span, selectionSpan };
+  }
+  function isDefined(x) {
+    return x !== void 0;
+  }
+  function convertEntryToCallSite(entry) {
+    if (entry.kind === ts_FindAllReferences_exports.EntryKind.Node) {
+      const { node } = entry;
+      if (isCallOrNewExpressionTarget(
+        node,
+        /*includeElementAccess*/
+        true,
+        /*skipPastOuterExpressions*/
+        true
+      ) || isTaggedTemplateTag(
+        node,
+        /*includeElementAccess*/
+        true,
+        /*skipPastOuterExpressions*/
+        true
+      ) || isDecoratorTarget(
+        node,
+        /*includeElementAccess*/
+        true,
+        /*skipPastOuterExpressions*/
+        true
+      ) || isJsxOpeningLikeElementTagName(
+        node,
+        /*includeElementAccess*/
+        true,
+        /*skipPastOuterExpressions*/
+        true
+      ) || isRightSideOfPropertyAccess(node) || isArgumentExpressionOfElementAccess(node)) {
+        const sourceFile = node.getSourceFile();
+        const ancestor = findAncestor(node, isValidCallHierarchyDeclaration) || sourceFile;
+        return { declaration: ancestor, range: createTextRangeFromNode(node, sourceFile) };
       }
-      for (let i = 0; i < scopes.length; i++) {
-        const scope = scopes[i];
-        const resolvedSymbol = checker.resolveName(
-          symbol.name,
-          scope,
-          symbol.flags,
-          /*excludeGlobals*/
-          false
-        );
-        if (resolvedSymbol === symbol) {
-          continue;
-        }
-        if (!substitutionsPerScope[i].has(symbolId)) {
-          const substitution = tryReplaceWithQualifiedNameOrPropertyAccess(symbol.exportSymbol || symbol, scope, isTypeName);
-          if (substitution) {
-            substitutionsPerScope[i].set(symbolId, substitution);
-          } else if (isTypeName) {
-            if (!(symbol.flags & 262144 /* TypeParameter */)) {
-              const diag2 = createDiagnosticForNode(identifier, Messages.typeWillNotBeVisibleInTheNewScope);
-              functionErrorsPerScope[i].push(diag2);
-              constantErrorsPerScope[i].push(diag2);
-            }
-          } else {
-            usagesPerScope[i].usages.set(identifier.text, { usage, symbol, node: identifier });
+    }
+  }
+  function getCallSiteGroupKey(entry) {
+    return getNodeId(entry.declaration);
+  }
+  function createCallHierarchyIncomingCall(from, fromSpans) {
+    return { from, fromSpans };
+  }
+  function convertCallSiteGroupToIncomingCall(program, entries) {
+    return createCallHierarchyIncomingCall(createCallHierarchyItem(program, entries[0].declaration), map(entries, (entry) => createTextSpanFromRange(entry.range)));
+  }
+  function getIncomingCalls(program, declaration, cancellationToken) {
+    if (isSourceFile(declaration) || isModuleDeclaration(declaration) || isClassStaticBlockDeclaration(declaration)) {
+      return [];
+    }
+    const location = getCallHierarchyDeclarationReferenceNode(declaration);
+    const calls = filter(ts_FindAllReferences_exports.findReferenceOrRenameEntries(
+      program,
+      cancellationToken,
+      program.getSourceFiles(),
+      location,
+      /*position*/
+      0,
+      { use: ts_FindAllReferences_exports.FindReferencesUse.References },
+      convertEntryToCallSite
+    ), isDefined);
+    return calls ? group(calls, getCallSiteGroupKey, (entries) => convertCallSiteGroupToIncomingCall(program, entries)) : [];
+  }
+  function createCallSiteCollector(program, callSites) {
+    function recordCallSite(node) {
+      const target = isTaggedTemplateExpression(node) ? node.tag : isJsxOpeningLikeElement(node) ? node.tagName : isAccessExpression(node) ? node : isClassStaticBlockDeclaration(node) ? node : node.expression;
+      const declaration = resolveCallHierarchyDeclaration(program, target);
+      if (declaration) {
+        const range = createTextRangeFromNode(target, node.getSourceFile());
+        if (isArray(declaration)) {
+          for (const decl of declaration) {
+            callSites.push({ declaration: decl, range });
           }
+        } else {
+          callSites.push({ declaration, range });
         }
       }
-      return symbolId;
     }
-    function checkForUsedDeclarations(node) {
-      if (node === targetRange.range || isReadonlyArray(targetRange.range) && targetRange.range.indexOf(node) >= 0) {
+    function collect(node) {
+      if (!node)
+        return;
+      if (node.flags & 33554432 /* Ambient */) {
         return;
       }
-      const sym = isIdentifier(node) ? getSymbolReferencedByIdentifier(node) : checker.getSymbolAtLocation(node);
-      if (sym) {
-        const decl = find(visibleDeclarationsInExtractedRange, (d) => d.symbol === sym);
-        if (decl) {
-          if (isVariableDeclaration(decl)) {
-            const idString = decl.symbol.id.toString();
-            if (!exposedVariableSymbolSet.has(idString)) {
-              exposedVariableDeclarations.push(decl);
-              exposedVariableSymbolSet.set(idString, true);
+      if (isValidCallHierarchyDeclaration(node)) {
+        if (isClassLike(node)) {
+          for (const member of node.members) {
+            if (member.name && isComputedPropertyName(member.name)) {
+              collect(member.name.expression);
             }
-          } else {
-            firstExposedNonVariableDeclaration = firstExposedNonVariableDeclaration || decl;
           }
         }
+        return;
       }
-      forEachChild(node, checkForUsedDeclarations);
-    }
-    function getSymbolReferencedByIdentifier(identifier) {
-      return identifier.parent && isShorthandPropertyAssignment(identifier.parent) && identifier.parent.name === identifier ? checker.getShorthandAssignmentValueSymbol(identifier.parent) : checker.getSymbolAtLocation(identifier);
-    }
-    function tryReplaceWithQualifiedNameOrPropertyAccess(symbol, scopeDecl, isTypeNode2) {
-      if (!symbol) {
-        return void 0;
-      }
-      const decls = symbol.getDeclarations();
-      if (decls && decls.some((d) => d.parent === scopeDecl)) {
-        return factory.createIdentifier(symbol.name);
+      switch (node.kind) {
+        case 80 /* Identifier */:
+        case 271 /* ImportEqualsDeclaration */:
+        case 272 /* ImportDeclaration */:
+        case 278 /* ExportDeclaration */:
+        case 264 /* InterfaceDeclaration */:
+        case 265 /* TypeAliasDeclaration */:
+          return;
+        case 175 /* ClassStaticBlockDeclaration */:
+          recordCallSite(node);
+          return;
+        case 216 /* TypeAssertionExpression */:
+        case 234 /* AsExpression */:
+          collect(node.expression);
+          return;
+        case 260 /* VariableDeclaration */:
+        case 169 /* Parameter */:
+          collect(node.name);
+          collect(node.initializer);
+          return;
+        case 213 /* CallExpression */:
+          recordCallSite(node);
+          collect(node.expression);
+          forEach(node.arguments, collect);
+          return;
+        case 214 /* NewExpression */:
+          recordCallSite(node);
+          collect(node.expression);
+          forEach(node.arguments, collect);
+          return;
+        case 215 /* TaggedTemplateExpression */:
+          recordCallSite(node);
+          collect(node.tag);
+          collect(node.template);
+          return;
+        case 286 /* JsxOpeningElement */:
+        case 285 /* JsxSelfClosingElement */:
+          recordCallSite(node);
+          collect(node.tagName);
+          collect(node.attributes);
+          return;
+        case 170 /* Decorator */:
+          recordCallSite(node);
+          collect(node.expression);
+          return;
+        case 211 /* PropertyAccessExpression */:
+        case 212 /* ElementAccessExpression */:
+          recordCallSite(node);
+          forEachChild(node, collect);
+          break;
+        case 238 /* SatisfiesExpression */:
+          collect(node.expression);
+          return;
       }
-      const prefix = tryReplaceWithQualifiedNameOrPropertyAccess(symbol.parent, scopeDecl, isTypeNode2);
-      if (prefix === void 0) {
-        return void 0;
+      if (isPartOfTypeNode(node)) {
+        return;
       }
-      return isTypeNode2 ? factory.createQualifiedName(prefix, factory.createIdentifier(symbol.name)) : factory.createPropertyAccessExpression(prefix, symbol.name);
+      forEachChild(node, collect);
     }
+    return collect;
   }
-  function getExtractableParent(node) {
-    return findAncestor(node, (node2) => node2.parent && isExtractableExpression(node2) && !isBinaryExpression(node2.parent));
+  function collectCallSitesOfSourceFile(node, collect) {
+    forEach(node.statements, collect);
   }
-  function isExtractableExpression(node) {
-    const { parent: parent2 } = node;
-    switch (parent2.kind) {
-      case 305 /* EnumMember */:
-        return false;
+  function collectCallSitesOfModuleDeclaration(node, collect) {
+    if (!hasSyntacticModifier(node, 128 /* Ambient */) && node.body && isModuleBlock(node.body)) {
+      forEach(node.body.statements, collect);
     }
-    switch (node.kind) {
-      case 11 /* StringLiteral */:
-        return parent2.kind !== 271 /* ImportDeclaration */ && parent2.kind !== 275 /* ImportSpecifier */;
-      case 229 /* SpreadElement */:
-      case 205 /* ObjectBindingPattern */:
-      case 207 /* BindingElement */:
-        return false;
-      case 80 /* Identifier */:
-        return parent2.kind !== 207 /* BindingElement */ && parent2.kind !== 275 /* ImportSpecifier */ && parent2.kind !== 280 /* ExportSpecifier */;
+  }
+  function collectCallSitesOfFunctionLikeDeclaration(typeChecker, node, collect) {
+    const implementation = findImplementation(typeChecker, node);
+    if (implementation) {
+      forEach(implementation.parameters, collect);
+      collect(implementation.body);
     }
-    return true;
   }
-  function isBlockLike(node) {
+  function collectCallSitesOfClassStaticBlockDeclaration(node, collect) {
+    collect(node.body);
+  }
+  function collectCallSitesOfClassLikeDeclaration(node, collect) {
+    forEach(node.modifiers, collect);
+    const heritage = getClassExtendsHeritageElement(node);
+    if (heritage) {
+      collect(heritage.expression);
+    }
+    for (const member of node.members) {
+      if (canHaveModifiers(member)) {
+        forEach(member.modifiers, collect);
+      }
+      if (isPropertyDeclaration(member)) {
+        collect(member.initializer);
+      } else if (isConstructorDeclaration(member) && member.body) {
+        forEach(member.parameters, collect);
+        collect(member.body);
+      } else if (isClassStaticBlockDeclaration(member)) {
+        collect(member);
+      }
+    }
+  }
+  function collectCallSites(program, node) {
+    const callSites = [];
+    const collect = createCallSiteCollector(program, callSites);
     switch (node.kind) {
-      case 240 /* Block */:
-      case 311 /* SourceFile */:
-      case 267 /* ModuleBlock */:
-      case 295 /* CaseClause */:
-        return true;
+      case 312 /* SourceFile */:
+        collectCallSitesOfSourceFile(node, collect);
+        break;
+      case 267 /* ModuleDeclaration */:
+        collectCallSitesOfModuleDeclaration(node, collect);
+        break;
+      case 262 /* FunctionDeclaration */:
+      case 218 /* FunctionExpression */:
+      case 219 /* ArrowFunction */:
+      case 174 /* MethodDeclaration */:
+      case 177 /* GetAccessor */:
+      case 178 /* SetAccessor */:
+        collectCallSitesOfFunctionLikeDeclaration(program.getTypeChecker(), node, collect);
+        break;
+      case 263 /* ClassDeclaration */:
+      case 231 /* ClassExpression */:
+        collectCallSitesOfClassLikeDeclaration(node, collect);
+        break;
+      case 175 /* ClassStaticBlockDeclaration */:
+        collectCallSitesOfClassStaticBlockDeclaration(node, collect);
+        break;
       default:
-        return false;
+        Debug.assertNever(node);
     }
+    return callSites;
   }
-  function isInJSXContent(node) {
-    return isStringLiteralJsxAttribute(node) || (isJsxElement(node) || isJsxSelfClosingElement(node) || isJsxFragment(node)) && (isJsxElement(node.parent) || isJsxFragment(node.parent));
+  function createCallHierarchyOutgoingCall(to, fromSpans) {
+    return { to, fromSpans };
   }
-  function isStringLiteralJsxAttribute(node) {
-    return isStringLiteral(node) && node.parent && isJsxAttribute(node.parent);
+  function convertCallSiteGroupToOutgoingCall(program, entries) {
+    return createCallHierarchyOutgoingCall(createCallHierarchyItem(program, entries[0].declaration), map(entries, (entry) => createTextSpanFromRange(entry.range)));
   }
-  var refactorName11, extractConstantAction, extractFunctionAction, Messages, RangeFacts;
-  var init_extractSymbol = __esm({
-    "src/services/refactors/extractSymbol.ts"() {
+  function getOutgoingCalls(program, declaration) {
+    if (declaration.flags & 33554432 /* Ambient */ || isMethodSignature(declaration)) {
+      return [];
+    }
+    return group(collectCallSites(program, declaration), getCallSiteGroupKey, (entries) => convertCallSiteGroupToOutgoingCall(program, entries));
+  }
+  var init_callHierarchy = __esm({
+    "src/services/callHierarchy.ts"() {
       "use strict";
       init_ts4();
-      init_ts_refactor();
-      refactorName11 = "Extract Symbol";
-      extractConstantAction = {
-        name: "Extract Constant",
-        description: getLocaleSpecificMessage(Diagnostics.Extract_constant),
-        kind: "refactor.extract.constant"
-      };
-      extractFunctionAction = {
-        name: "Extract Function",
-        description: getLocaleSpecificMessage(Diagnostics.Extract_function),
-        kind: "refactor.extract.function"
-      };
-      registerRefactor(refactorName11, {
-        kinds: [
-          extractConstantAction.kind,
-          extractFunctionAction.kind
-        ],
-        getEditsForAction: getRefactorEditsToExtractSymbol,
-        getAvailableActions: getRefactorActionsToExtractSymbol
-      });
-      ((Messages2) => {
-        function createMessage(message) {
-          return { message, code: 0, category: 3 /* Message */, key: message };
-        }
-        Messages2.cannotExtractRange = createMessage("Cannot extract range.");
-        Messages2.cannotExtractImport = createMessage("Cannot extract import statement.");
-        Messages2.cannotExtractSuper = createMessage("Cannot extract super call.");
-        Messages2.cannotExtractJSDoc = createMessage("Cannot extract JSDoc.");
-        Messages2.cannotExtractEmpty = createMessage("Cannot extract empty range.");
-        Messages2.expressionExpected = createMessage("expression expected.");
-        Messages2.uselessConstantType = createMessage("No reason to extract constant of type.");
-        Messages2.statementOrExpressionExpected = createMessage("Statement or expression expected.");
-        Messages2.cannotExtractRangeContainingConditionalBreakOrContinueStatements = createMessage("Cannot extract range containing conditional break or continue statements.");
-        Messages2.cannotExtractRangeContainingConditionalReturnStatement = createMessage("Cannot extract range containing conditional return statement.");
-        Messages2.cannotExtractRangeContainingLabeledBreakOrContinueStatementWithTargetOutsideOfTheRange = createMessage("Cannot extract range containing labeled break or continue with target outside of the range.");
-        Messages2.cannotExtractRangeThatContainsWritesToReferencesLocatedOutsideOfTheTargetRangeInGenerators = createMessage("Cannot extract range containing writes to references located outside of the target range in generators.");
-        Messages2.typeWillNotBeVisibleInTheNewScope = createMessage("Type will not visible in the new scope.");
-        Messages2.functionWillNotBeVisibleInTheNewScope = createMessage("Function will not visible in the new scope.");
-        Messages2.cannotExtractIdentifier = createMessage("Select more than a single identifier.");
-        Messages2.cannotExtractExportedEntity = createMessage("Cannot extract exported declaration");
-        Messages2.cannotWriteInExpression = createMessage("Cannot write back side-effects when extracting an expression");
-        Messages2.cannotExtractReadonlyPropertyInitializerOutsideConstructor = createMessage("Cannot move initialization of read-only class property outside of the constructor");
-        Messages2.cannotExtractAmbientBlock = createMessage("Cannot extract code from ambient contexts");
-        Messages2.cannotAccessVariablesFromNestedScopes = createMessage("Cannot access variables from nested scopes");
-        Messages2.cannotExtractToJSClass = createMessage("Cannot extract constant to a class scope in JS");
-        Messages2.cannotExtractToExpressionArrowFunction = createMessage("Cannot extract constant to an arrow function without a block");
-        Messages2.cannotExtractFunctionsContainingThisToMethod = createMessage("Cannot extract functions containing this to method");
-      })(Messages || (Messages = {}));
-      RangeFacts = /* @__PURE__ */ ((RangeFacts2) => {
-        RangeFacts2[RangeFacts2["None"] = 0] = "None";
-        RangeFacts2[RangeFacts2["HasReturn"] = 1] = "HasReturn";
-        RangeFacts2[RangeFacts2["IsGenerator"] = 2] = "IsGenerator";
-        RangeFacts2[RangeFacts2["IsAsyncFunction"] = 4] = "IsAsyncFunction";
-        RangeFacts2[RangeFacts2["UsesThis"] = 8] = "UsesThis";
-        RangeFacts2[RangeFacts2["UsesThisInFunction"] = 16] = "UsesThisInFunction";
-        RangeFacts2[RangeFacts2["InStaticRegion"] = 32] = "InStaticRegion";
-        return RangeFacts2;
-      })(RangeFacts || {});
     }
   });
 
-  // src/services/_namespaces/ts.refactor.extractSymbol.ts
-  var ts_refactor_extractSymbol_exports = {};
-  __export(ts_refactor_extractSymbol_exports, {
-    Messages: () => Messages,
-    RangeFacts: () => RangeFacts,
-    getRangeToExtract: () => getRangeToExtract2,
-    getRefactorActionsToExtractSymbol: () => getRefactorActionsToExtractSymbol,
-    getRefactorEditsToExtractSymbol: () => getRefactorEditsToExtractSymbol
+  // src/services/_namespaces/ts.CallHierarchy.ts
+  var ts_CallHierarchy_exports = {};
+  __export(ts_CallHierarchy_exports, {
+    createCallHierarchyItem: () => createCallHierarchyItem,
+    getIncomingCalls: () => getIncomingCalls,
+    getOutgoingCalls: () => getOutgoingCalls,
+    resolveCallHierarchyDeclaration: () => resolveCallHierarchyDeclaration
   });
-  var init_ts_refactor_extractSymbol = __esm({
-    "src/services/_namespaces/ts.refactor.extractSymbol.ts"() {
+  var init_ts_CallHierarchy = __esm({
+    "src/services/_namespaces/ts.CallHierarchy.ts"() {
       "use strict";
-      init_extractSymbol();
+      init_callHierarchy();
     }
   });
 
-  // src/services/refactors/generateGetAccessorAndSetAccessor.ts
-  var actionName, actionDescription, generateGetSetAction;
-  var init_generateGetAccessorAndSetAccessor = __esm({
-    "src/services/refactors/generateGetAccessorAndSetAccessor.ts"() {
+  // src/services/_namespaces/ts.classifier.v2020.ts
+  var ts_classifier_v2020_exports = {};
+  __export(ts_classifier_v2020_exports, {
+    TokenEncodingConsts: () => TokenEncodingConsts,
+    TokenModifier: () => TokenModifier,
+    TokenType: () => TokenType,
+    getEncodedSemanticClassifications: () => getEncodedSemanticClassifications2,
+    getSemanticClassifications: () => getSemanticClassifications2
+  });
+  var init_ts_classifier_v2020 = __esm({
+    "src/services/_namespaces/ts.classifier.v2020.ts"() {
+      "use strict";
+      init_classifier2020();
+    }
+  });
+
+  // src/services/_namespaces/ts.classifier.ts
+  var ts_classifier_exports = {};
+  __export(ts_classifier_exports, {
+    v2020: () => ts_classifier_v2020_exports
+  });
+  var init_ts_classifier = __esm({
+    "src/services/_namespaces/ts.classifier.ts"() {
+      "use strict";
+      init_ts_classifier_v2020();
+    }
+  });
+
+  // src/services/codeFixProvider.ts
+  function createCodeFixActionWithoutFixAll(fixName8, changes, description3) {
+    return createCodeFixActionWorker(
+      fixName8,
+      diagnosticToString(description3),
+      changes,
+      /*fixId*/
+      void 0,
+      /*fixAllDescription*/
+      void 0
+    );
+  }
+  function createCodeFixAction(fixName8, changes, description3, fixId52, fixAllDescription, command) {
+    return createCodeFixActionWorker(fixName8, diagnosticToString(description3), changes, fixId52, diagnosticToString(fixAllDescription), command);
+  }
+  function createCodeFixActionMaybeFixAll(fixName8, changes, description3, fixId52, fixAllDescription, command) {
+    return createCodeFixActionWorker(fixName8, diagnosticToString(description3), changes, fixId52, fixAllDescription && diagnosticToString(fixAllDescription), command);
+  }
+  function createCodeFixActionWorker(fixName8, description3, changes, fixId52, fixAllDescription, command) {
+    return { fixName: fixName8, description: description3, changes, fixId: fixId52, fixAllDescription, commands: command ? [command] : void 0 };
+  }
+  function registerCodeFix(reg) {
+    for (const error2 of reg.errorCodes) {
+      errorCodeToFixesArray = void 0;
+      errorCodeToFixes.add(String(error2), reg);
+    }
+    if (reg.fixIds) {
+      for (const fixId52 of reg.fixIds) {
+        Debug.assert(!fixIdToRegistration.has(fixId52));
+        fixIdToRegistration.set(fixId52, reg);
+      }
+    }
+  }
+  function getSupportedErrorCodes() {
+    return errorCodeToFixesArray ?? (errorCodeToFixesArray = arrayFrom(errorCodeToFixes.keys()));
+  }
+  function removeFixIdIfFixAllUnavailable(registration, diagnostics) {
+    const { errorCodes: errorCodes64 } = registration;
+    let maybeFixableDiagnostics = 0;
+    for (const diag2 of diagnostics) {
+      if (contains(errorCodes64, diag2.code))
+        maybeFixableDiagnostics++;
+      if (maybeFixableDiagnostics > 1)
+        break;
+    }
+    const fixAllUnavailable = maybeFixableDiagnostics < 2;
+    return ({ fixId: fixId52, fixAllDescription, ...action }) => {
+      return fixAllUnavailable ? action : { ...action, fixId: fixId52, fixAllDescription };
+    };
+  }
+  function getFixes(context) {
+    const diagnostics = getDiagnostics(context);
+    const registrations = errorCodeToFixes.get(String(context.errorCode));
+    return flatMap(registrations, (f) => map(f.getCodeActions(context), removeFixIdIfFixAllUnavailable(f, diagnostics)));
+  }
+  function getAllFixes(context) {
+    return fixIdToRegistration.get(cast(context.fixId, isString)).getAllCodeActions(context);
+  }
+  function createCombinedCodeActions(changes, commands) {
+    return { changes, commands };
+  }
+  function createFileTextChanges(fileName, textChanges2) {
+    return { fileName, textChanges: textChanges2 };
+  }
+  function codeFixAll(context, errorCodes64, use) {
+    const commands = [];
+    const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => eachDiagnostic(context, errorCodes64, (diag2) => use(t, diag2, commands)));
+    return createCombinedCodeActions(changes, commands.length === 0 ? void 0 : commands);
+  }
+  function eachDiagnostic(context, errorCodes64, cb) {
+    for (const diag2 of getDiagnostics(context)) {
+      if (contains(errorCodes64, diag2.code)) {
+        cb(diag2);
+      }
+    }
+  }
+  function getDiagnostics({ program, sourceFile, cancellationToken }) {
+    return [
+      ...program.getSemanticDiagnostics(sourceFile, cancellationToken),
+      ...program.getSyntacticDiagnostics(sourceFile, cancellationToken),
+      ...computeSuggestionDiagnostics(sourceFile, program, cancellationToken)
+    ];
+  }
+  var errorCodeToFixes, fixIdToRegistration, errorCodeToFixesArray;
+  var init_codeFixProvider = __esm({
+    "src/services/codeFixProvider.ts"() {
       "use strict";
       init_ts4();
-      init_ts_refactor();
-      actionName = "Generate 'get' and 'set' accessors";
-      actionDescription = Diagnostics.Generate_get_and_set_accessors.message;
-      generateGetSetAction = {
-        name: actionName,
-        description: actionDescription,
-        kind: "refactor.rewrite.property.generateAccessors"
-      };
-      registerRefactor(actionName, {
-        kinds: [generateGetSetAction.kind],
-        getEditsForAction: function getRefactorActionsToGenerateGetAndSetAccessors(context, actionName2) {
-          if (!context.endPosition)
-            return void 0;
-          const info = ts_codefix_exports.getAccessorConvertiblePropertyAtPosition(context.file, context.program, context.startPosition, context.endPosition);
-          Debug.assert(info && !isRefactorErrorInfo(info), "Expected applicable refactor info");
-          const edits = ts_codefix_exports.generateAccessorFromProperty(context.file, context.program, context.startPosition, context.endPosition, context, actionName2);
-          if (!edits)
+      errorCodeToFixes = createMultiMap();
+      fixIdToRegistration = /* @__PURE__ */ new Map();
+    }
+  });
+
+  // src/services/codefixes/addConvertToUnknownForNonOverlappingTypes.ts
+  function makeChange(changeTracker, sourceFile, assertion) {
+    const replacement = isAsExpression(assertion) ? factory.createAsExpression(assertion.expression, factory.createKeywordTypeNode(159 /* UnknownKeyword */)) : factory.createTypeAssertion(factory.createKeywordTypeNode(159 /* UnknownKeyword */), assertion.expression);
+    changeTracker.replaceNode(sourceFile, assertion.expression, replacement);
+  }
+  function getAssertion(sourceFile, pos) {
+    if (isInJSFile(sourceFile))
+      return void 0;
+    return findAncestor(getTokenAtPosition(sourceFile, pos), (n) => isAsExpression(n) || isTypeAssertionExpression(n));
+  }
+  var fixId, errorCodes;
+  var init_addConvertToUnknownForNonOverlappingTypes = __esm({
+    "src/services/codefixes/addConvertToUnknownForNonOverlappingTypes.ts"() {
+      "use strict";
+      init_ts4();
+      init_ts_codefix();
+      fixId = "addConvertToUnknownForNonOverlappingTypes";
+      errorCodes = [Diagnostics.Conversion_of_type_0_to_type_1_may_be_a_mistake_because_neither_type_sufficiently_overlaps_with_the_other_If_this_was_intentional_convert_the_expression_to_unknown_first.code];
+      registerCodeFix({
+        errorCodes,
+        getCodeActions: function getCodeActionsToAddConvertToUnknownForNonOverlappingTypes(context) {
+          const assertion = getAssertion(context.sourceFile, context.span.start);
+          if (assertion === void 0)
             return void 0;
-          const renameFilename = context.file.fileName;
-          const nameNeedRename = info.renameAccessor ? info.accessorName : info.fieldName;
-          const renameLocationOffset = isIdentifier(nameNeedRename) ? 0 : -1;
-          const renameLocation = renameLocationOffset + getRenameLocation(
-            edits,
-            renameFilename,
-            nameNeedRename.text,
-            /*preferLastLocation*/
-            isParameter(info.declaration)
-          );
-          return { renameFilename, renameLocation, edits };
+          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => makeChange(t, context.sourceFile, assertion));
+          return [createCodeFixAction(fixId, changes, Diagnostics.Add_unknown_conversion_for_non_overlapping_types, fixId, Diagnostics.Add_unknown_to_all_conversions_of_non_overlapping_types)];
         },
-        getAvailableActions(context) {
-          if (!context.endPosition)
-            return emptyArray;
-          const info = ts_codefix_exports.getAccessorConvertiblePropertyAtPosition(context.file, context.program, context.startPosition, context.endPosition, context.triggerReason === "invoked");
-          if (!info)
-            return emptyArray;
-          if (!isRefactorErrorInfo(info)) {
-            return [{
-              name: actionName,
-              description: actionDescription,
-              actions: [generateGetSetAction]
-            }];
+        fixIds: [fixId],
+        getAllCodeActions: (context) => codeFixAll(context, errorCodes, (changes, diag2) => {
+          const assertion = getAssertion(diag2.file, diag2.start);
+          if (assertion) {
+            makeChange(changes, diag2.file, assertion);
           }
-          if (context.preferences.provideRefactorNotApplicableReason) {
-            return [{
-              name: actionName,
-              description: actionDescription,
-              actions: [{ ...generateGetSetAction, notApplicableReason: info.error }]
-            }];
+        })
+      });
+    }
+  });
+
+  // src/services/codefixes/addEmptyExportDeclaration.ts
+  var init_addEmptyExportDeclaration = __esm({
+    "src/services/codefixes/addEmptyExportDeclaration.ts"() {
+      "use strict";
+      init_ts4();
+      init_ts_codefix();
+      registerCodeFix({
+        errorCodes: [
+          Diagnostics.await_expressions_are_only_allowed_at_the_top_level_of_a_file_when_that_file_is_a_module_but_this_file_has_no_imports_or_exports_Consider_adding_an_empty_export_to_make_this_file_a_module.code,
+          Diagnostics.await_using_statements_are_only_allowed_at_the_top_level_of_a_file_when_that_file_is_a_module_but_this_file_has_no_imports_or_exports_Consider_adding_an_empty_export_to_make_this_file_a_module.code,
+          Diagnostics.for_await_loops_are_only_allowed_at_the_top_level_of_a_file_when_that_file_is_a_module_but_this_file_has_no_imports_or_exports_Consider_adding_an_empty_export_to_make_this_file_a_module.code
+        ],
+        getCodeActions: function getCodeActionsToAddEmptyExportDeclaration(context) {
+          const { sourceFile } = context;
+          const changes = ts_textChanges_exports.ChangeTracker.with(context, (changes2) => {
+            const exportDeclaration = factory.createExportDeclaration(
+              /*modifiers*/
+              void 0,
+              /*isTypeOnly*/
+              false,
+              factory.createNamedExports([]),
+              /*moduleSpecifier*/
+              void 0
+            );
+            changes2.insertNodeAtEndOfScope(sourceFile, sourceFile, exportDeclaration);
+          });
+          return [createCodeFixActionWithoutFixAll("addEmptyExportDeclaration", changes, Diagnostics.Add_export_to_make_this_file_into_a_module)];
+        }
+      });
+    }
+  });
+
+  // src/services/codefixes/addMissingAsync.ts
+  function getFix(context, decl, trackChanges, fixedDeclarations) {
+    const changes = trackChanges((t) => makeChange2(t, context.sourceFile, decl, fixedDeclarations));
+    return createCodeFixAction(fixId2, changes, Diagnostics.Add_async_modifier_to_containing_function, fixId2, Diagnostics.Add_all_missing_async_modifiers);
+  }
+  function makeChange2(changeTracker, sourceFile, insertionSite, fixedDeclarations) {
+    if (fixedDeclarations) {
+      if (fixedDeclarations.has(getNodeId(insertionSite))) {
+        return;
+      }
+    }
+    fixedDeclarations == null ? void 0 : fixedDeclarations.add(getNodeId(insertionSite));
+    const cloneWithModifier = factory.replaceModifiers(
+      getSynthesizedDeepClone(
+        insertionSite,
+        /*includeTrivia*/
+        true
+      ),
+      factory.createNodeArray(factory.createModifiersFromModifierFlags(getSyntacticModifierFlags(insertionSite) | 1024 /* Async */))
+    );
+    changeTracker.replaceNode(
+      sourceFile,
+      insertionSite,
+      cloneWithModifier
+    );
+  }
+  function getFixableErrorSpanDeclaration(sourceFile, span) {
+    if (!span)
+      return void 0;
+    const token = getTokenAtPosition(sourceFile, span.start);
+    const decl = findAncestor(token, (node) => {
+      if (node.getStart(sourceFile) < span.start || node.getEnd() > textSpanEnd(span)) {
+        return "quit";
+      }
+      return (isArrowFunction(node) || isMethodDeclaration(node) || isFunctionExpression(node) || isFunctionDeclaration(node)) && textSpansEqual(span, createTextSpanFromNode(node, sourceFile));
+    });
+    return decl;
+  }
+  function getIsMatchingAsyncError(span, errorCode) {
+    return ({ start, length: length2, relatedInformation, code }) => isNumber(start) && isNumber(length2) && textSpansEqual({ start, length: length2 }, span) && code === errorCode && !!relatedInformation && some(relatedInformation, (related) => related.code === Diagnostics.Did_you_mean_to_mark_this_function_as_async.code);
+  }
+  var fixId2, errorCodes2;
+  var init_addMissingAsync = __esm({
+    "src/services/codefixes/addMissingAsync.ts"() {
+      "use strict";
+      init_ts4();
+      init_ts_codefix();
+      fixId2 = "addMissingAsync";
+      errorCodes2 = [
+        Diagnostics.Argument_of_type_0_is_not_assignable_to_parameter_of_type_1.code,
+        Diagnostics.Type_0_is_not_assignable_to_type_1.code,
+        Diagnostics.Type_0_is_not_comparable_to_type_1.code
+      ];
+      registerCodeFix({
+        fixIds: [fixId2],
+        errorCodes: errorCodes2,
+        getCodeActions: function getCodeActionsToAddMissingAsync(context) {
+          const { sourceFile, errorCode, cancellationToken, program, span } = context;
+          const diagnostic = find(program.getTypeChecker().getDiagnostics(sourceFile, cancellationToken), getIsMatchingAsyncError(span, errorCode));
+          const directSpan = diagnostic && diagnostic.relatedInformation && find(diagnostic.relatedInformation, (r) => r.code === Diagnostics.Did_you_mean_to_mark_this_function_as_async.code);
+          const decl = getFixableErrorSpanDeclaration(sourceFile, directSpan);
+          if (!decl) {
+            return;
           }
-          return emptyArray;
+          const trackChanges = (cb) => ts_textChanges_exports.ChangeTracker.with(context, cb);
+          return [getFix(context, decl, trackChanges)];
+        },
+        getAllCodeActions: (context) => {
+          const { sourceFile } = context;
+          const fixedDeclarations = /* @__PURE__ */ new Set();
+          return codeFixAll(context, errorCodes2, (t, diagnostic) => {
+            const span = diagnostic.relatedInformation && find(diagnostic.relatedInformation, (r) => r.code === Diagnostics.Did_you_mean_to_mark_this_function_as_async.code);
+            const decl = getFixableErrorSpanDeclaration(sourceFile, span);
+            if (!decl) {
+              return;
+            }
+            const trackChanges = (cb) => (cb(t), []);
+            return getFix(context, decl, trackChanges, fixedDeclarations);
+          });
         }
       });
     }
   });
 
-  // src/services/_namespaces/ts.refactor.generateGetAccessorAndSetAccessor.ts
-  var ts_refactor_generateGetAccessorAndSetAccessor_exports = {};
-  var init_ts_refactor_generateGetAccessorAndSetAccessor = __esm({
-    "src/services/_namespaces/ts.refactor.generateGetAccessorAndSetAccessor.ts"() {
+  // src/services/codefixes/addMissingAwait.ts
+  function getAwaitErrorSpanExpression(sourceFile, errorCode, span, cancellationToken, program) {
+    const expression = getFixableErrorSpanExpression(sourceFile, span);
+    return expression && isMissingAwaitError(sourceFile, errorCode, span, cancellationToken, program) && isInsideAwaitableBody(expression) ? expression : void 0;
+  }
+  function getDeclarationSiteFix(context, expression, errorCode, checker, trackChanges, fixedDeclarations) {
+    const { sourceFile, program, cancellationToken } = context;
+    const awaitableInitializers = findAwaitableInitializers(expression, sourceFile, cancellationToken, program, checker);
+    if (awaitableInitializers) {
+      const initializerChanges = trackChanges((t) => {
+        forEach(awaitableInitializers.initializers, ({ expression: expression2 }) => makeChange3(t, errorCode, sourceFile, checker, expression2, fixedDeclarations));
+        if (fixedDeclarations && awaitableInitializers.needsSecondPassForFixAll) {
+          makeChange3(t, errorCode, sourceFile, checker, expression, fixedDeclarations);
+        }
+      });
+      return createCodeFixActionWithoutFixAll(
+        "addMissingAwaitToInitializer",
+        initializerChanges,
+        awaitableInitializers.initializers.length === 1 ? [Diagnostics.Add_await_to_initializer_for_0, awaitableInitializers.initializers[0].declarationSymbol.name] : Diagnostics.Add_await_to_initializers
+      );
+    }
+  }
+  function getUseSiteFix(context, expression, errorCode, checker, trackChanges, fixedDeclarations) {
+    const changes = trackChanges((t) => makeChange3(t, errorCode, context.sourceFile, checker, expression, fixedDeclarations));
+    return createCodeFixAction(fixId3, changes, Diagnostics.Add_await, fixId3, Diagnostics.Fix_all_expressions_possibly_missing_await);
+  }
+  function isMissingAwaitError(sourceFile, errorCode, span, cancellationToken, program) {
+    const checker = program.getTypeChecker();
+    const diagnostics = checker.getDiagnostics(sourceFile, cancellationToken);
+    return some(diagnostics, ({ start, length: length2, relatedInformation, code }) => isNumber(start) && isNumber(length2) && textSpansEqual({ start, length: length2 }, span) && code === errorCode && !!relatedInformation && some(relatedInformation, (related) => related.code === Diagnostics.Did_you_forget_to_use_await.code));
+  }
+  function findAwaitableInitializers(expression, sourceFile, cancellationToken, program, checker) {
+    const identifiers = getIdentifiersFromErrorSpanExpression(expression, checker);
+    if (!identifiers) {
+      return;
+    }
+    let isCompleteFix = identifiers.isCompleteFix;
+    let initializers;
+    for (const identifier of identifiers.identifiers) {
+      const symbol = checker.getSymbolAtLocation(identifier);
+      if (!symbol) {
+        continue;
+      }
+      const declaration = tryCast(symbol.valueDeclaration, isVariableDeclaration);
+      const variableName = declaration && tryCast(declaration.name, isIdentifier);
+      const variableStatement = getAncestor(declaration, 243 /* VariableStatement */);
+      if (!declaration || !variableStatement || declaration.type || !declaration.initializer || variableStatement.getSourceFile() !== sourceFile || hasSyntacticModifier(variableStatement, 32 /* Export */) || !variableName || !isInsideAwaitableBody(declaration.initializer)) {
+        isCompleteFix = false;
+        continue;
+      }
+      const diagnostics = program.getSemanticDiagnostics(sourceFile, cancellationToken);
+      const isUsedElsewhere = ts_FindAllReferences_exports.Core.eachSymbolReferenceInFile(variableName, checker, sourceFile, (reference) => {
+        return identifier !== reference && !symbolReferenceIsAlsoMissingAwait(reference, diagnostics, sourceFile, checker);
+      });
+      if (isUsedElsewhere) {
+        isCompleteFix = false;
+        continue;
+      }
+      (initializers || (initializers = [])).push({
+        expression: declaration.initializer,
+        declarationSymbol: symbol
+      });
+    }
+    return initializers && {
+      initializers,
+      needsSecondPassForFixAll: !isCompleteFix
+    };
+  }
+  function getIdentifiersFromErrorSpanExpression(expression, checker) {
+    if (isPropertyAccessExpression(expression.parent) && isIdentifier(expression.parent.expression)) {
+      return { identifiers: [expression.parent.expression], isCompleteFix: true };
+    }
+    if (isIdentifier(expression)) {
+      return { identifiers: [expression], isCompleteFix: true };
+    }
+    if (isBinaryExpression(expression)) {
+      let sides;
+      let isCompleteFix = true;
+      for (const side of [expression.left, expression.right]) {
+        const type = checker.getTypeAtLocation(side);
+        if (checker.getPromisedTypeOfPromise(type)) {
+          if (!isIdentifier(side)) {
+            isCompleteFix = false;
+            continue;
+          }
+          (sides || (sides = [])).push(side);
+        }
+      }
+      return sides && { identifiers: sides, isCompleteFix };
+    }
+  }
+  function symbolReferenceIsAlsoMissingAwait(reference, diagnostics, sourceFile, checker) {
+    const errorNode = isPropertyAccessExpression(reference.parent) ? reference.parent.name : isBinaryExpression(reference.parent) ? reference.parent : reference;
+    const diagnostic = find(diagnostics, (diagnostic2) => diagnostic2.start === errorNode.getStart(sourceFile) && diagnostic2.start + diagnostic2.length === errorNode.getEnd());
+    return diagnostic && contains(errorCodes3, diagnostic.code) || // A Promise is usually not correct in a binary expression (it's not valid
+    // in an arithmetic expression and an equality comparison seems unusual),
+    // but if the other side of the binary expression has an error, the side
+    // is typed `any` which will squash the error that would identify this
+    // Promise as an invalid operand. So if the whole binary expression is
+    // typed `any` as a result, there is a strong likelihood that this Promise
+    // is accidentally missing `await`.
+    checker.getTypeAtLocation(errorNode).flags & 1 /* Any */;
+  }
+  function isInsideAwaitableBody(node) {
+    return node.flags & 65536 /* AwaitContext */ || !!findAncestor(node, (ancestor) => ancestor.parent && isArrowFunction(ancestor.parent) && ancestor.parent.body === ancestor || isBlock(ancestor) && (ancestor.parent.kind === 262 /* FunctionDeclaration */ || ancestor.parent.kind === 218 /* FunctionExpression */ || ancestor.parent.kind === 219 /* ArrowFunction */ || ancestor.parent.kind === 174 /* MethodDeclaration */));
+  }
+  function makeChange3(changeTracker, errorCode, sourceFile, checker, insertionSite, fixedDeclarations) {
+    if (isForOfStatement(insertionSite.parent) && !insertionSite.parent.awaitModifier) {
+      const exprType = checker.getTypeAtLocation(insertionSite);
+      const asyncIter = checker.getAsyncIterableType();
+      if (asyncIter && checker.isTypeAssignableTo(exprType, asyncIter)) {
+        const forOf = insertionSite.parent;
+        changeTracker.replaceNode(sourceFile, forOf, factory.updateForOfStatement(forOf, factory.createToken(135 /* AwaitKeyword */), forOf.initializer, forOf.expression, forOf.statement));
+        return;
+      }
+    }
+    if (isBinaryExpression(insertionSite)) {
+      for (const side of [insertionSite.left, insertionSite.right]) {
+        if (fixedDeclarations && isIdentifier(side)) {
+          const symbol = checker.getSymbolAtLocation(side);
+          if (symbol && fixedDeclarations.has(getSymbolId(symbol))) {
+            continue;
+          }
+        }
+        const type = checker.getTypeAtLocation(side);
+        const newNode = checker.getPromisedTypeOfPromise(type) ? factory.createAwaitExpression(side) : side;
+        changeTracker.replaceNode(sourceFile, side, newNode);
+      }
+    } else if (errorCode === propertyAccessCode && isPropertyAccessExpression(insertionSite.parent)) {
+      if (fixedDeclarations && isIdentifier(insertionSite.parent.expression)) {
+        const symbol = checker.getSymbolAtLocation(insertionSite.parent.expression);
+        if (symbol && fixedDeclarations.has(getSymbolId(symbol))) {
+          return;
+        }
+      }
+      changeTracker.replaceNode(
+        sourceFile,
+        insertionSite.parent.expression,
+        factory.createParenthesizedExpression(factory.createAwaitExpression(insertionSite.parent.expression))
+      );
+      insertLeadingSemicolonIfNeeded(changeTracker, insertionSite.parent.expression, sourceFile);
+    } else if (contains(callableConstructableErrorCodes, errorCode) && isCallOrNewExpression(insertionSite.parent)) {
+      if (fixedDeclarations && isIdentifier(insertionSite)) {
+        const symbol = checker.getSymbolAtLocation(insertionSite);
+        if (symbol && fixedDeclarations.has(getSymbolId(symbol))) {
+          return;
+        }
+      }
+      changeTracker.replaceNode(sourceFile, insertionSite, factory.createParenthesizedExpression(factory.createAwaitExpression(insertionSite)));
+      insertLeadingSemicolonIfNeeded(changeTracker, insertionSite, sourceFile);
+    } else {
+      if (fixedDeclarations && isVariableDeclaration(insertionSite.parent) && isIdentifier(insertionSite.parent.name)) {
+        const symbol = checker.getSymbolAtLocation(insertionSite.parent.name);
+        if (symbol && !tryAddToSet(fixedDeclarations, getSymbolId(symbol))) {
+          return;
+        }
+      }
+      changeTracker.replaceNode(sourceFile, insertionSite, factory.createAwaitExpression(insertionSite));
+    }
+  }
+  function insertLeadingSemicolonIfNeeded(changeTracker, beforeNode, sourceFile) {
+    const precedingToken = findPrecedingToken(beforeNode.pos, sourceFile);
+    if (precedingToken && positionIsASICandidate(precedingToken.end, precedingToken.parent, sourceFile)) {
+      changeTracker.insertText(sourceFile, beforeNode.getStart(sourceFile), ";");
+    }
+  }
+  var fixId3, propertyAccessCode, callableConstructableErrorCodes, errorCodes3;
+  var init_addMissingAwait = __esm({
+    "src/services/codefixes/addMissingAwait.ts"() {
       "use strict";
-      init_generateGetAccessorAndSetAccessor();
+      init_ts4();
+      init_ts_codefix();
+      fixId3 = "addMissingAwait";
+      propertyAccessCode = Diagnostics.Property_0_does_not_exist_on_type_1.code;
+      callableConstructableErrorCodes = [
+        Diagnostics.This_expression_is_not_callable.code,
+        Diagnostics.This_expression_is_not_constructable.code
+      ];
+      errorCodes3 = [
+        Diagnostics.An_arithmetic_operand_must_be_of_type_any_number_bigint_or_an_enum_type.code,
+        Diagnostics.The_left_hand_side_of_an_arithmetic_operation_must_be_of_type_any_number_bigint_or_an_enum_type.code,
+        Diagnostics.The_right_hand_side_of_an_arithmetic_operation_must_be_of_type_any_number_bigint_or_an_enum_type.code,
+        Diagnostics.Operator_0_cannot_be_applied_to_type_1.code,
+        Diagnostics.Operator_0_cannot_be_applied_to_types_1_and_2.code,
+        Diagnostics.This_comparison_appears_to_be_unintentional_because_the_types_0_and_1_have_no_overlap.code,
+        Diagnostics.This_condition_will_always_return_true_since_this_0_is_always_defined.code,
+        Diagnostics.Type_0_is_not_an_array_type.code,
+        Diagnostics.Type_0_is_not_an_array_type_or_a_string_type.code,
+        Diagnostics.Type_0_can_only_be_iterated_through_when_using_the_downlevelIteration_flag_or_with_a_target_of_es2015_or_higher.code,
+        Diagnostics.Type_0_is_not_an_array_type_or_a_string_type_or_does_not_have_a_Symbol_iterator_method_that_returns_an_iterator.code,
+        Diagnostics.Type_0_is_not_an_array_type_or_does_not_have_a_Symbol_iterator_method_that_returns_an_iterator.code,
+        Diagnostics.Type_0_must_have_a_Symbol_iterator_method_that_returns_an_iterator.code,
+        Diagnostics.Type_0_must_have_a_Symbol_asyncIterator_method_that_returns_an_async_iterator.code,
+        Diagnostics.Argument_of_type_0_is_not_assignable_to_parameter_of_type_1.code,
+        propertyAccessCode,
+        ...callableConstructableErrorCodes
+      ];
+      registerCodeFix({
+        fixIds: [fixId3],
+        errorCodes: errorCodes3,
+        getCodeActions: function getCodeActionsToAddMissingAwait(context) {
+          const { sourceFile, errorCode, span, cancellationToken, program } = context;
+          const expression = getAwaitErrorSpanExpression(sourceFile, errorCode, span, cancellationToken, program);
+          if (!expression) {
+            return;
+          }
+          const checker = context.program.getTypeChecker();
+          const trackChanges = (cb) => ts_textChanges_exports.ChangeTracker.with(context, cb);
+          return compact([
+            getDeclarationSiteFix(context, expression, errorCode, checker, trackChanges),
+            getUseSiteFix(context, expression, errorCode, checker, trackChanges)
+          ]);
+        },
+        getAllCodeActions: (context) => {
+          const { sourceFile, program, cancellationToken } = context;
+          const checker = context.program.getTypeChecker();
+          const fixedDeclarations = /* @__PURE__ */ new Set();
+          return codeFixAll(context, errorCodes3, (t, diagnostic) => {
+            const expression = getAwaitErrorSpanExpression(sourceFile, diagnostic.code, diagnostic, cancellationToken, program);
+            if (!expression) {
+              return;
+            }
+            const trackChanges = (cb) => (cb(t), []);
+            return getDeclarationSiteFix(context, expression, diagnostic.code, checker, trackChanges, fixedDeclarations) || getUseSiteFix(context, expression, diagnostic.code, checker, trackChanges, fixedDeclarations);
+          });
+        }
+      });
     }
   });
 
-  // src/services/refactors/inferFunctionReturnType.ts
-  function getRefactorEditsToInferReturnType(context) {
-    const info = getInfo4(context);
-    if (info && !isRefactorErrorInfo(info)) {
-      const edits = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange7(context.file, t, info.declaration, info.returnTypeNode));
-      return { renameFilename: void 0, renameLocation: void 0, edits };
-    }
-    return void 0;
-  }
-  function getRefactorActionsToInferReturnType(context) {
-    const info = getInfo4(context);
-    if (!info)
-      return emptyArray;
-    if (!isRefactorErrorInfo(info)) {
-      return [{
-        name: refactorName12,
-        description: refactorDescription6,
-        actions: [inferReturnTypeAction]
-      }];
+  // src/services/codefixes/addMissingConst.ts
+  function makeChange4(changeTracker, sourceFile, pos, program, fixedNodes) {
+    const token = getTokenAtPosition(sourceFile, pos);
+    const forInitializer = findAncestor(token, (node) => isForInOrOfStatement(node.parent) ? node.parent.initializer === node : isPossiblyPartOfDestructuring(node) ? false : "quit");
+    if (forInitializer)
+      return applyChange(changeTracker, forInitializer, sourceFile, fixedNodes);
+    const parent2 = token.parent;
+    if (isBinaryExpression(parent2) && parent2.operatorToken.kind === 64 /* EqualsToken */ && isExpressionStatement(parent2.parent)) {
+      return applyChange(changeTracker, token, sourceFile, fixedNodes);
     }
-    if (context.preferences.provideRefactorNotApplicableReason) {
-      return [{
-        name: refactorName12,
-        description: refactorDescription6,
-        actions: [{ ...inferReturnTypeAction, notApplicableReason: info.error }]
-      }];
+    if (isArrayLiteralExpression(parent2)) {
+      const checker = program.getTypeChecker();
+      if (!every(parent2.elements, (element) => arrayElementCouldBeVariableDeclaration(element, checker))) {
+        return;
+      }
+      return applyChange(changeTracker, parent2, sourceFile, fixedNodes);
     }
-    return emptyArray;
-  }
-  function doChange7(sourceFile, changes, declaration, typeNode) {
-    const closeParen = findChildOfKind(declaration, 22 /* CloseParenToken */, sourceFile);
-    const needParens = isArrowFunction(declaration) && closeParen === void 0;
-    const endNode2 = needParens ? first(declaration.parameters) : closeParen;
-    if (endNode2) {
-      if (needParens) {
-        changes.insertNodeBefore(sourceFile, endNode2, factory.createToken(21 /* OpenParenToken */));
-        changes.insertNodeAfter(sourceFile, endNode2, factory.createToken(22 /* CloseParenToken */));
+    const commaExpression = findAncestor(token, (node) => isExpressionStatement(node.parent) ? true : isPossiblyPartOfCommaSeperatedInitializer(node) ? false : "quit");
+    if (commaExpression) {
+      const checker = program.getTypeChecker();
+      if (!expressionCouldBeVariableDeclaration(commaExpression, checker)) {
+        return;
       }
-      changes.insertNodeAt(sourceFile, endNode2.end, typeNode, { prefix: ": " });
+      return applyChange(changeTracker, commaExpression, sourceFile, fixedNodes);
     }
   }
-  function getInfo4(context) {
-    if (isInJSFile(context.file) || !refactorKindBeginsWith(inferReturnTypeAction.kind, context.kind))
-      return;
-    const token = getTokenAtPosition(context.file, context.startPosition);
-    const declaration = findAncestor(token, (n) => isBlock(n) || n.parent && isArrowFunction(n.parent) && (n.kind === 39 /* EqualsGreaterThanToken */ || n.parent.body === n) ? "quit" : isConvertibleDeclaration(n));
-    if (!declaration || !declaration.body || declaration.type) {
-      return { error: getLocaleSpecificMessage(Diagnostics.Return_type_must_be_inferred_from_a_function) };
-    }
-    const typeChecker = context.program.getTypeChecker();
-    const returnType = tryGetReturnType(typeChecker, declaration);
-    if (!returnType) {
-      return { error: getLocaleSpecificMessage(Diagnostics.Could_not_determine_function_return_type) };
+  function applyChange(changeTracker, initializer, sourceFile, fixedNodes) {
+    if (!fixedNodes || tryAddToSet(fixedNodes, initializer)) {
+      changeTracker.insertModifierBefore(sourceFile, 87 /* ConstKeyword */, initializer);
     }
-    const returnTypeNode = typeChecker.typeToTypeNode(returnType, declaration, 1 /* NoTruncation */);
-    if (returnTypeNode) {
-      return { declaration, returnTypeNode };
+  }
+  function isPossiblyPartOfDestructuring(node) {
+    switch (node.kind) {
+      case 80 /* Identifier */:
+      case 209 /* ArrayLiteralExpression */:
+      case 210 /* ObjectLiteralExpression */:
+      case 303 /* PropertyAssignment */:
+      case 304 /* ShorthandPropertyAssignment */:
+        return true;
+      default:
+        return false;
     }
   }
-  function isConvertibleDeclaration(node) {
+  function arrayElementCouldBeVariableDeclaration(expression, checker) {
+    const identifier = isIdentifier(expression) ? expression : isAssignmentExpression(
+      expression,
+      /*excludeCompoundAssignment*/
+      true
+    ) && isIdentifier(expression.left) ? expression.left : void 0;
+    return !!identifier && !checker.getSymbolAtLocation(identifier);
+  }
+  function isPossiblyPartOfCommaSeperatedInitializer(node) {
     switch (node.kind) {
-      case 261 /* FunctionDeclaration */:
-      case 217 /* FunctionExpression */:
-      case 218 /* ArrowFunction */:
-      case 173 /* MethodDeclaration */:
+      case 80 /* Identifier */:
+      case 226 /* BinaryExpression */:
+      case 28 /* CommaToken */:
         return true;
       default:
         return false;
     }
   }
-  function tryGetReturnType(typeChecker, node) {
-    if (typeChecker.isImplementationOfOverload(node)) {
-      const signatures = typeChecker.getTypeAtLocation(node).getCallSignatures();
-      if (signatures.length > 1) {
-        return typeChecker.getUnionType(mapDefined(signatures, (s) => s.getReturnType()));
-      }
+  function expressionCouldBeVariableDeclaration(expression, checker) {
+    if (!isBinaryExpression(expression)) {
+      return false;
     }
-    const signature = typeChecker.getSignatureFromDeclaration(node);
-    if (signature) {
-      return typeChecker.getReturnTypeOfSignature(signature);
+    if (expression.operatorToken.kind === 28 /* CommaToken */) {
+      return every([expression.left, expression.right], (expression2) => expressionCouldBeVariableDeclaration(expression2, checker));
     }
+    return expression.operatorToken.kind === 64 /* EqualsToken */ && isIdentifier(expression.left) && !checker.getSymbolAtLocation(expression.left);
   }
-  var refactorName12, refactorDescription6, inferReturnTypeAction;
-  var init_inferFunctionReturnType = __esm({
-    "src/services/refactors/inferFunctionReturnType.ts"() {
+  var fixId4, errorCodes4;
+  var init_addMissingConst = __esm({
+    "src/services/codefixes/addMissingConst.ts"() {
       "use strict";
       init_ts4();
-      init_ts_refactor();
-      refactorName12 = "Infer function return type";
-      refactorDescription6 = Diagnostics.Infer_function_return_type.message;
-      inferReturnTypeAction = {
-        name: refactorName12,
-        description: refactorDescription6,
-        kind: "refactor.rewrite.function.returnType"
-      };
-      registerRefactor(refactorName12, {
-        kinds: [inferReturnTypeAction.kind],
-        getEditsForAction: getRefactorEditsToInferReturnType,
-        getAvailableActions: getRefactorActionsToInferReturnType
+      init_ts_codefix();
+      fixId4 = "addMissingConst";
+      errorCodes4 = [
+        Diagnostics.Cannot_find_name_0.code,
+        Diagnostics.No_value_exists_in_scope_for_the_shorthand_property_0_Either_declare_one_or_provide_an_initializer.code
+      ];
+      registerCodeFix({
+        errorCodes: errorCodes4,
+        getCodeActions: function getCodeActionsToAddMissingConst(context) {
+          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => makeChange4(t, context.sourceFile, context.span.start, context.program));
+          if (changes.length > 0) {
+            return [createCodeFixAction(fixId4, changes, Diagnostics.Add_const_to_unresolved_variable, fixId4, Diagnostics.Add_const_to_all_unresolved_variables)];
+          }
+        },
+        fixIds: [fixId4],
+        getAllCodeActions: (context) => {
+          const fixedNodes = /* @__PURE__ */ new Set();
+          return codeFixAll(context, errorCodes4, (changes, diag2) => makeChange4(changes, diag2.file, diag2.start, context.program, fixedNodes));
+        }
       });
     }
   });
 
-  // src/services/_namespaces/ts.refactor.inferFunctionReturnType.ts
-  var ts_refactor_inferFunctionReturnType_exports = {};
-  var init_ts_refactor_inferFunctionReturnType = __esm({
-    "src/services/_namespaces/ts.refactor.inferFunctionReturnType.ts"() {
+  // src/services/codefixes/addMissingDeclareProperty.ts
+  function makeChange5(changeTracker, sourceFile, pos, fixedNodes) {
+    const token = getTokenAtPosition(sourceFile, pos);
+    if (!isIdentifier(token)) {
+      return;
+    }
+    const declaration = token.parent;
+    if (declaration.kind === 172 /* PropertyDeclaration */ && (!fixedNodes || tryAddToSet(fixedNodes, declaration))) {
+      changeTracker.insertModifierBefore(sourceFile, 138 /* DeclareKeyword */, declaration);
+    }
+  }
+  var fixId5, errorCodes5;
+  var init_addMissingDeclareProperty = __esm({
+    "src/services/codefixes/addMissingDeclareProperty.ts"() {
       "use strict";
-      init_inferFunctionReturnType();
+      init_ts4();
+      init_ts_codefix();
+      fixId5 = "addMissingDeclareProperty";
+      errorCodes5 = [
+        Diagnostics.Property_0_will_overwrite_the_base_property_in_1_If_this_is_intentional_add_an_initializer_Otherwise_add_a_declare_modifier_or_remove_the_redundant_declaration.code
+      ];
+      registerCodeFix({
+        errorCodes: errorCodes5,
+        getCodeActions: function getCodeActionsToAddMissingDeclareOnProperty(context) {
+          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => makeChange5(t, context.sourceFile, context.span.start));
+          if (changes.length > 0) {
+            return [createCodeFixAction(fixId5, changes, Diagnostics.Prefix_with_declare, fixId5, Diagnostics.Prefix_all_incorrect_property_declarations_with_declare)];
+          }
+        },
+        fixIds: [fixId5],
+        getAllCodeActions: (context) => {
+          const fixedNodes = /* @__PURE__ */ new Set();
+          return codeFixAll(context, errorCodes5, (changes, diag2) => makeChange5(changes, diag2.file, diag2.start, fixedNodes));
+        }
+      });
     }
   });
 
-  // src/services/_namespaces/ts.refactor.ts
-  var ts_refactor_exports = {};
-  __export(ts_refactor_exports, {
-    addExportToChanges: () => addExportToChanges,
-    addExports: () => addExports,
-    addNewFileToTsconfig: () => addNewFileToTsconfig,
-    addOrRemoveBracesToArrowFunction: () => ts_refactor_addOrRemoveBracesToArrowFunction_exports,
-    convertArrowFunctionOrFunctionExpression: () => ts_refactor_convertArrowFunctionOrFunctionExpression_exports,
-    convertParamsToDestructuredObject: () => ts_refactor_convertParamsToDestructuredObject_exports,
-    convertStringOrTemplateLiteral: () => ts_refactor_convertStringOrTemplateLiteral_exports,
-    convertToOptionalChainExpression: () => ts_refactor_convertToOptionalChainExpression_exports,
-    createNewFileName: () => createNewFileName,
-    createOldFileImportsFromTargetFile: () => createOldFileImportsFromTargetFile,
-    deleteMovedStatements: () => deleteMovedStatements,
-    deleteUnusedImports: () => deleteUnusedImports,
-    deleteUnusedOldImports: () => deleteUnusedOldImports,
-    doChangeNamedToNamespaceOrDefault: () => doChangeNamedToNamespaceOrDefault,
-    extractSymbol: () => ts_refactor_extractSymbol_exports,
-    filterImport: () => filterImport,
-    forEachImportInStatement: () => forEachImportInStatement,
-    generateGetAccessorAndSetAccessor: () => ts_refactor_generateGetAccessorAndSetAccessor_exports,
-    getApplicableRefactors: () => getApplicableRefactors,
-    getEditsForRefactor: () => getEditsForRefactor,
-    getStatementsToMove: () => getStatementsToMove,
-    getTopLevelDeclarationStatement: () => getTopLevelDeclarationStatement,
-    getUsageInfo: () => getUsageInfo,
-    inferFunctionReturnType: () => ts_refactor_inferFunctionReturnType_exports,
-    isRefactorErrorInfo: () => isRefactorErrorInfo,
-    isTopLevelDeclaration: () => isTopLevelDeclaration,
-    makeImportOrRequire: () => makeImportOrRequire,
-    moduleSpecifierFromImport: () => moduleSpecifierFromImport,
-    nameOfTopLevelDeclaration: () => nameOfTopLevelDeclaration,
-    refactorKindBeginsWith: () => refactorKindBeginsWith,
-    registerRefactor: () => registerRefactor,
-    updateImportsInOtherFiles: () => updateImportsInOtherFiles
-  });
-  var init_ts_refactor = __esm({
-    "src/services/_namespaces/ts.refactor.ts"() {
+  // src/services/codefixes/addMissingInvocationForDecorator.ts
+  function makeChange6(changeTracker, sourceFile, pos) {
+    const token = getTokenAtPosition(sourceFile, pos);
+    const decorator = findAncestor(token, isDecorator);
+    Debug.assert(!!decorator, "Expected position to be owned by a decorator.");
+    const replacement = factory.createCallExpression(
+      decorator.expression,
+      /*typeArguments*/
+      void 0,
+      /*argumentsArray*/
+      void 0
+    );
+    changeTracker.replaceNode(sourceFile, decorator.expression, replacement);
+  }
+  var fixId6, errorCodes6;
+  var init_addMissingInvocationForDecorator = __esm({
+    "src/services/codefixes/addMissingInvocationForDecorator.ts"() {
       "use strict";
-      init_refactorProvider();
-      init_convertExport();
-      init_convertImport();
-      init_extractType();
-      init_helpers();
-      init_moveToNewFile();
-      init_moveToFile();
-      init_ts_refactor_addOrRemoveBracesToArrowFunction();
-      init_ts_refactor_convertArrowFunctionOrFunctionExpression();
-      init_ts_refactor_convertParamsToDestructuredObject();
-      init_ts_refactor_convertStringOrTemplateLiteral();
-      init_ts_refactor_convertToOptionalChainExpression();
-      init_ts_refactor_extractSymbol();
-      init_ts_refactor_generateGetAccessorAndSetAccessor();
-      init_ts_refactor_inferFunctionReturnType();
+      init_ts4();
+      init_ts_codefix();
+      fixId6 = "addMissingInvocationForDecorator";
+      errorCodes6 = [Diagnostics._0_accepts_too_few_arguments_to_be_used_as_a_decorator_here_Did_you_mean_to_call_it_first_and_write_0.code];
+      registerCodeFix({
+        errorCodes: errorCodes6,
+        getCodeActions: function getCodeActionsToAddMissingInvocationForDecorator(context) {
+          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => makeChange6(t, context.sourceFile, context.span.start));
+          return [createCodeFixAction(fixId6, changes, Diagnostics.Call_decorator_expression, fixId6, Diagnostics.Add_to_all_uncalled_decorators)];
+        },
+        fixIds: [fixId6],
+        getAllCodeActions: (context) => codeFixAll(context, errorCodes6, (changes, diag2) => makeChange6(changes, diag2.file, diag2.start))
+      });
     }
   });
 
-  // src/services/classifier2020.ts
-  function getSemanticClassifications2(program, cancellationToken, sourceFile, span) {
-    const classifications = getEncodedSemanticClassifications2(program, cancellationToken, sourceFile, span);
-    Debug.assert(classifications.spans.length % 3 === 0);
-    const dense = classifications.spans;
-    const result = [];
-    for (let i = 0; i < dense.length; i += 3) {
-      result.push({
-        textSpan: createTextSpan(dense[i], dense[i + 1]),
-        classificationType: dense[i + 2]
-      });
+  // src/services/codefixes/addNameToNamelessParameter.ts
+  function makeChange7(changeTracker, sourceFile, start) {
+    const token = getTokenAtPosition(sourceFile, start);
+    const param = token.parent;
+    if (!isParameter(param)) {
+      return Debug.fail("Tried to add a parameter name to a non-parameter: " + Debug.formatSyntaxKind(token.kind));
     }
-    return result;
+    const i = param.parent.parameters.indexOf(param);
+    Debug.assert(!param.type, "Tried to add a parameter name to a parameter that already had one.");
+    Debug.assert(i > -1, "Parameter not found in parent parameter list.");
+    let end = param.name.getEnd();
+    let typeNode = factory.createTypeReferenceNode(
+      param.name,
+      /*typeArguments*/
+      void 0
+    );
+    let nextParam = tryGetNextParam(sourceFile, param);
+    while (nextParam) {
+      typeNode = factory.createArrayTypeNode(typeNode);
+      end = nextParam.getEnd();
+      nextParam = tryGetNextParam(sourceFile, nextParam);
+    }
+    const replacement = factory.createParameterDeclaration(
+      param.modifiers,
+      param.dotDotDotToken,
+      "arg" + i,
+      param.questionToken,
+      param.dotDotDotToken && !isArrayTypeNode(typeNode) ? factory.createArrayTypeNode(typeNode) : typeNode,
+      param.initializer
+    );
+    changeTracker.replaceRange(sourceFile, createRange(param.getStart(sourceFile), end), replacement);
   }
-  function getEncodedSemanticClassifications2(program, cancellationToken, sourceFile, span) {
-    return {
-      spans: getSemanticTokens(program, sourceFile, span, cancellationToken),
-      endOfLineState: 0 /* None */
-    };
+  function tryGetNextParam(sourceFile, param) {
+    const nextToken = findNextToken(param.name, param.parent, sourceFile);
+    if (nextToken && nextToken.kind === 23 /* OpenBracketToken */ && isArrayBindingPattern(nextToken.parent) && isParameter(nextToken.parent.parent)) {
+      return nextToken.parent.parent;
+    }
+    return void 0;
   }
-  function getSemanticTokens(program, sourceFile, span, cancellationToken) {
-    const resultTokens = [];
-    const collector = (node, typeIdx, modifierSet) => {
-      resultTokens.push(node.getStart(sourceFile), node.getWidth(sourceFile), (typeIdx + 1 << 8 /* typeOffset */) + modifierSet);
-    };
-    if (program && sourceFile) {
-      collectTokens(program, sourceFile, span, collector, cancellationToken);
+  var fixId7, errorCodes7;
+  var init_addNameToNamelessParameter = __esm({
+    "src/services/codefixes/addNameToNamelessParameter.ts"() {
+      "use strict";
+      init_ts4();
+      init_ts_codefix();
+      fixId7 = "addNameToNamelessParameter";
+      errorCodes7 = [Diagnostics.Parameter_has_a_name_but_no_type_Did_you_mean_0_Colon_1.code];
+      registerCodeFix({
+        errorCodes: errorCodes7,
+        getCodeActions: function getCodeActionsToAddNameToNamelessParameter(context) {
+          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => makeChange7(t, context.sourceFile, context.span.start));
+          return [createCodeFixAction(fixId7, changes, Diagnostics.Add_parameter_name, fixId7, Diagnostics.Add_names_to_all_parameters_without_names)];
+        },
+        fixIds: [fixId7],
+        getAllCodeActions: (context) => codeFixAll(context, errorCodes7, (changes, diag2) => makeChange7(changes, diag2.file, diag2.start))
+      });
     }
-    return resultTokens;
+  });
+
+  // src/services/codefixes/addOptionalPropertyUndefined.ts
+  function getPropertiesToAdd(file, span, checker) {
+    var _a, _b;
+    const sourceTarget = getSourceTarget(getFixableErrorSpanExpression(file, span), checker);
+    if (!sourceTarget) {
+      return emptyArray;
+    }
+    const { source: sourceNode, target: targetNode } = sourceTarget;
+    const target = shouldUseParentTypeOfProperty(sourceNode, targetNode, checker) ? checker.getTypeAtLocation(targetNode.expression) : checker.getTypeAtLocation(targetNode);
+    if ((_b = (_a = target.symbol) == null ? void 0 : _a.declarations) == null ? void 0 : _b.some((d) => getSourceFileOfNode(d).fileName.match(/\.d\.ts$/))) {
+      return emptyArray;
+    }
+    return checker.getExactOptionalProperties(target);
   }
-  function collectTokens(program, sourceFile, span, collector, cancellationToken) {
-    const typeChecker = program.getTypeChecker();
-    let inJSXElement = false;
-    function visit(node) {
-      switch (node.kind) {
-        case 266 /* ModuleDeclaration */:
-        case 262 /* ClassDeclaration */:
-        case 263 /* InterfaceDeclaration */:
-        case 261 /* FunctionDeclaration */:
-        case 230 /* ClassExpression */:
-        case 217 /* FunctionExpression */:
-        case 218 /* ArrowFunction */:
-          cancellationToken.throwIfCancellationRequested();
-      }
-      if (!node || !textSpanIntersectsWith(span, node.pos, node.getFullWidth()) || node.getFullWidth() === 0) {
-        return;
-      }
-      const prevInJSXElement = inJSXElement;
-      if (isJsxElement(node) || isJsxSelfClosingElement(node)) {
-        inJSXElement = true;
-      }
-      if (isJsxExpression(node)) {
-        inJSXElement = false;
-      }
-      if (isIdentifier(node) && !inJSXElement && !inImportClause(node) && !isInfinityOrNaNString(node.escapedText)) {
-        let symbol = typeChecker.getSymbolAtLocation(node);
-        if (symbol) {
-          if (symbol.flags & 2097152 /* Alias */) {
-            symbol = typeChecker.getAliasedSymbol(symbol);
-          }
-          let typeIdx = classifySymbol2(symbol, getMeaningFromLocation(node));
-          if (typeIdx !== void 0) {
-            let modifierSet = 0;
-            if (node.parent) {
-              const parentIsDeclaration = isBindingElement(node.parent) || tokenFromDeclarationMapping.get(node.parent.kind) === typeIdx;
-              if (parentIsDeclaration && node.parent.name === node) {
-                modifierSet = 1 << 0 /* declaration */;
-              }
-            }
-            if (typeIdx === 6 /* parameter */ && isRightSideOfQualifiedNameOrPropertyAccess2(node)) {
-              typeIdx = 9 /* property */;
-            }
-            typeIdx = reclassifyByType(typeChecker, node, typeIdx);
-            const decl = symbol.valueDeclaration;
-            if (decl) {
-              const modifiers = getCombinedModifierFlags(decl);
-              const nodeFlags = getCombinedNodeFlags(decl);
-              if (modifiers & 32 /* Static */) {
-                modifierSet |= 1 << 1 /* static */;
-              }
-              if (modifiers & 512 /* Async */) {
-                modifierSet |= 1 << 2 /* async */;
-              }
-              if (typeIdx !== 0 /* class */ && typeIdx !== 2 /* interface */) {
-                if (modifiers & 64 /* Readonly */ || nodeFlags & 2 /* Const */ || symbol.getFlags() & 8 /* EnumMember */) {
-                  modifierSet |= 1 << 3 /* readonly */;
-                }
-              }
-              if ((typeIdx === 7 /* variable */ || typeIdx === 10 /* function */) && isLocalDeclaration(decl, sourceFile)) {
-                modifierSet |= 1 << 5 /* local */;
-              }
-              if (program.isSourceFileDefaultLibrary(decl.getSourceFile())) {
-                modifierSet |= 1 << 4 /* defaultLibrary */;
-              }
-            } else if (symbol.declarations && symbol.declarations.some((d) => program.isSourceFileDefaultLibrary(d.getSourceFile()))) {
-              modifierSet |= 1 << 4 /* defaultLibrary */;
-            }
-            collector(node, typeIdx, modifierSet);
-          }
-        }
-      }
-      forEachChild(node, visit);
-      inJSXElement = prevInJSXElement;
+  function shouldUseParentTypeOfProperty(sourceNode, targetNode, checker) {
+    return isPropertyAccessExpression(targetNode) && !!checker.getExactOptionalProperties(checker.getTypeAtLocation(targetNode.expression)).length && checker.getTypeAtLocation(sourceNode) === checker.getUndefinedType();
+  }
+  function getSourceTarget(errorNode, checker) {
+    var _a;
+    if (!errorNode) {
+      return void 0;
+    } else if (isBinaryExpression(errorNode.parent) && errorNode.parent.operatorToken.kind === 64 /* EqualsToken */) {
+      return { source: errorNode.parent.right, target: errorNode.parent.left };
+    } else if (isVariableDeclaration(errorNode.parent) && errorNode.parent.initializer) {
+      return { source: errorNode.parent.initializer, target: errorNode.parent.name };
+    } else if (isCallExpression(errorNode.parent)) {
+      const n = checker.getSymbolAtLocation(errorNode.parent.expression);
+      if (!(n == null ? void 0 : n.valueDeclaration) || !isFunctionLikeKind(n.valueDeclaration.kind))
+        return void 0;
+      if (!isExpression(errorNode))
+        return void 0;
+      const i = errorNode.parent.arguments.indexOf(errorNode);
+      if (i === -1)
+        return void 0;
+      const name = n.valueDeclaration.parameters[i].name;
+      if (isIdentifier(name))
+        return { source: errorNode, target: name };
+    } else if (isPropertyAssignment(errorNode.parent) && isIdentifier(errorNode.parent.name) || isShorthandPropertyAssignment(errorNode.parent)) {
+      const parentTarget = getSourceTarget(errorNode.parent.parent, checker);
+      if (!parentTarget)
+        return void 0;
+      const prop = checker.getPropertyOfType(checker.getTypeAtLocation(parentTarget.target), errorNode.parent.name.text);
+      const declaration = (_a = prop == null ? void 0 : prop.declarations) == null ? void 0 : _a[0];
+      if (!declaration)
+        return void 0;
+      return {
+        source: isPropertyAssignment(errorNode.parent) ? errorNode.parent.initializer : errorNode.parent.name,
+        target: declaration
+      };
     }
-    visit(sourceFile);
+    return void 0;
   }
-  function classifySymbol2(symbol, meaning) {
-    const flags = symbol.getFlags();
-    if (flags & 32 /* Class */) {
-      return 0 /* class */;
-    } else if (flags & 384 /* Enum */) {
-      return 1 /* enum */;
-    } else if (flags & 524288 /* TypeAlias */) {
-      return 5 /* type */;
-    } else if (flags & 64 /* Interface */) {
-      if (meaning & 2 /* Type */) {
-        return 2 /* interface */;
+  function addUndefinedToOptionalProperty(changes, toAdd) {
+    for (const add of toAdd) {
+      const d = add.valueDeclaration;
+      if (d && (isPropertySignature(d) || isPropertyDeclaration(d)) && d.type) {
+        const t = factory.createUnionTypeNode([
+          ...d.type.kind === 192 /* UnionType */ ? d.type.types : [d.type],
+          factory.createTypeReferenceNode("undefined")
+        ]);
+        changes.replaceNode(d.getSourceFile(), d.type, t);
       }
-    } else if (flags & 262144 /* TypeParameter */) {
-      return 4 /* typeParameter */;
     }
-    let decl = symbol.valueDeclaration || symbol.declarations && symbol.declarations[0];
-    if (decl && isBindingElement(decl)) {
-      decl = getDeclarationForBindingElement(decl);
+  }
+  var addOptionalPropertyUndefined, errorCodes8;
+  var init_addOptionalPropertyUndefined = __esm({
+    "src/services/codefixes/addOptionalPropertyUndefined.ts"() {
+      "use strict";
+      init_ts4();
+      init_ts_codefix();
+      addOptionalPropertyUndefined = "addOptionalPropertyUndefined";
+      errorCodes8 = [
+        Diagnostics.Type_0_is_not_assignable_to_type_1_with_exactOptionalPropertyTypes_Colon_true_Consider_adding_undefined_to_the_type_of_the_target.code,
+        Diagnostics.Type_0_is_not_assignable_to_type_1_with_exactOptionalPropertyTypes_Colon_true_Consider_adding_undefined_to_the_types_of_the_target_s_properties.code,
+        Diagnostics.Argument_of_type_0_is_not_assignable_to_parameter_of_type_1_with_exactOptionalPropertyTypes_Colon_true_Consider_adding_undefined_to_the_types_of_the_target_s_properties.code
+      ];
+      registerCodeFix({
+        errorCodes: errorCodes8,
+        getCodeActions(context) {
+          const typeChecker = context.program.getTypeChecker();
+          const toAdd = getPropertiesToAdd(context.sourceFile, context.span, typeChecker);
+          if (!toAdd.length) {
+            return void 0;
+          }
+          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => addUndefinedToOptionalProperty(t, toAdd));
+          return [createCodeFixActionWithoutFixAll(addOptionalPropertyUndefined, changes, Diagnostics.Add_undefined_to_optional_property_type)];
+        },
+        fixIds: [addOptionalPropertyUndefined]
+      });
     }
-    return decl && tokenFromDeclarationMapping.get(decl.kind);
+  });
+
+  // src/services/codefixes/annotateWithTypeFromJSDoc.ts
+  function getDeclaration(file, pos) {
+    const name = getTokenAtPosition(file, pos);
+    return tryCast(isParameter(name.parent) ? name.parent.parent : name.parent, parameterShouldGetTypeFromJSDoc);
   }
-  function reclassifyByType(typeChecker, node, typeIdx) {
-    if (typeIdx === 7 /* variable */ || typeIdx === 9 /* property */ || typeIdx === 6 /* parameter */) {
-      const type = typeChecker.getTypeAtLocation(node);
-      if (type) {
-        const test = (condition) => {
-          return condition(type) || type.isUnion() && type.types.some(condition);
-        };
-        if (typeIdx !== 6 /* parameter */ && test((t) => t.getConstructSignatures().length > 0)) {
-          return 0 /* class */;
-        }
-        if (test((t) => t.getCallSignatures().length > 0) && !test((t) => t.getProperties().length > 0) || isExpressionInCallExpression(node)) {
-          return typeIdx === 9 /* property */ ? 11 /* member */ : 10 /* function */;
+  function parameterShouldGetTypeFromJSDoc(node) {
+    return isDeclarationWithType(node) && hasUsableJSDoc(node);
+  }
+  function hasUsableJSDoc(decl) {
+    return isFunctionLikeDeclaration(decl) ? decl.parameters.some(hasUsableJSDoc) || !decl.type && !!getJSDocReturnType(decl) : !decl.type && !!getJSDocType(decl);
+  }
+  function doChange8(changes, sourceFile, decl) {
+    if (isFunctionLikeDeclaration(decl) && (getJSDocReturnType(decl) || decl.parameters.some((p) => !!getJSDocType(p)))) {
+      if (!decl.typeParameters) {
+        const typeParameters = getJSDocTypeParameterDeclarations(decl);
+        if (typeParameters.length)
+          changes.insertTypeParameters(sourceFile, decl, typeParameters);
+      }
+      const needParens = isArrowFunction(decl) && !findChildOfKind(decl, 21 /* OpenParenToken */, sourceFile);
+      if (needParens)
+        changes.insertNodeBefore(sourceFile, first(decl.parameters), factory.createToken(21 /* OpenParenToken */));
+      for (const param of decl.parameters) {
+        if (!param.type) {
+          const paramType = getJSDocType(param);
+          if (paramType)
+            changes.tryInsertTypeAnnotation(sourceFile, param, visitNode(paramType, transformJSDocType, isTypeNode));
         }
       }
+      if (needParens)
+        changes.insertNodeAfter(sourceFile, last(decl.parameters), factory.createToken(22 /* CloseParenToken */));
+      if (!decl.type) {
+        const returnType = getJSDocReturnType(decl);
+        if (returnType)
+          changes.tryInsertTypeAnnotation(sourceFile, decl, visitNode(returnType, transformJSDocType, isTypeNode));
+      }
+    } else {
+      const jsdocType = Debug.checkDefined(getJSDocType(decl), "A JSDocType for this declaration should exist");
+      Debug.assert(!decl.type, "The JSDocType decl should have a type");
+      changes.tryInsertTypeAnnotation(sourceFile, decl, visitNode(jsdocType, transformJSDocType, isTypeNode));
     }
-    return typeIdx;
   }
-  function isLocalDeclaration(decl, sourceFile) {
-    if (isBindingElement(decl)) {
-      decl = getDeclarationForBindingElement(decl);
-    }
-    if (isVariableDeclaration(decl)) {
-      return (!isSourceFile(decl.parent.parent.parent) || isCatchClause(decl.parent)) && decl.getSourceFile() === sourceFile;
-    } else if (isFunctionDeclaration(decl)) {
-      return !isSourceFile(decl.parent) && decl.getSourceFile() === sourceFile;
-    }
-    return false;
+  function isDeclarationWithType(node) {
+    return isFunctionLikeDeclaration(node) || node.kind === 260 /* VariableDeclaration */ || node.kind === 171 /* PropertySignature */ || node.kind === 172 /* PropertyDeclaration */;
   }
-  function getDeclarationForBindingElement(element) {
-    while (true) {
-      if (isBindingElement(element.parent.parent)) {
-        element = element.parent.parent;
-      } else {
-        return element.parent.parent;
-      }
+  function transformJSDocType(node) {
+    switch (node.kind) {
+      case 319 /* JSDocAllType */:
+      case 320 /* JSDocUnknownType */:
+        return factory.createTypeReferenceNode("any", emptyArray);
+      case 323 /* JSDocOptionalType */:
+        return transformJSDocOptionalType(node);
+      case 322 /* JSDocNonNullableType */:
+        return transformJSDocType(node.type);
+      case 321 /* JSDocNullableType */:
+        return transformJSDocNullableType(node);
+      case 325 /* JSDocVariadicType */:
+        return transformJSDocVariadicType(node);
+      case 324 /* JSDocFunctionType */:
+        return transformJSDocFunctionType(node);
+      case 183 /* TypeReference */:
+        return transformJSDocTypeReference(node);
+      case 329 /* JSDocTypeLiteral */:
+        return transformJSDocTypeLiteral(node);
+      default:
+        const visited = visitEachChild(node, transformJSDocType, nullTransformationContext);
+        setEmitFlags(visited, 1 /* SingleLine */);
+        return visited;
     }
   }
-  function inImportClause(node) {
-    const parent2 = node.parent;
-    return parent2 && (isImportClause(parent2) || isImportSpecifier(parent2) || isNamespaceImport(parent2));
+  function transformJSDocTypeLiteral(node) {
+    const typeNode = factory.createTypeLiteralNode(map(node.jsDocPropertyTags, (tag) => factory.createPropertySignature(
+      /*modifiers*/
+      void 0,
+      isIdentifier(tag.name) ? tag.name : tag.name.right,
+      isOptionalJSDocPropertyLikeTag(tag) ? factory.createToken(58 /* QuestionToken */) : void 0,
+      tag.typeExpression && visitNode(tag.typeExpression.type, transformJSDocType, isTypeNode) || factory.createKeywordTypeNode(133 /* AnyKeyword */)
+    )));
+    setEmitFlags(typeNode, 1 /* SingleLine */);
+    return typeNode;
   }
-  function isExpressionInCallExpression(node) {
-    while (isRightSideOfQualifiedNameOrPropertyAccess2(node)) {
-      node = node.parent;
+  function transformJSDocOptionalType(node) {
+    return factory.createUnionTypeNode([visitNode(node.type, transformJSDocType, isTypeNode), factory.createTypeReferenceNode("undefined", emptyArray)]);
+  }
+  function transformJSDocNullableType(node) {
+    return factory.createUnionTypeNode([visitNode(node.type, transformJSDocType, isTypeNode), factory.createTypeReferenceNode("null", emptyArray)]);
+  }
+  function transformJSDocVariadicType(node) {
+    return factory.createArrayTypeNode(visitNode(node.type, transformJSDocType, isTypeNode));
+  }
+  function transformJSDocFunctionType(node) {
+    return factory.createFunctionTypeNode(emptyArray, node.parameters.map(transformJSDocParameter), node.type ?? factory.createKeywordTypeNode(133 /* AnyKeyword */));
+  }
+  function transformJSDocParameter(node) {
+    const index = node.parent.parameters.indexOf(node);
+    const isRest = node.type.kind === 325 /* JSDocVariadicType */ && index === node.parent.parameters.length - 1;
+    const name = node.name || (isRest ? "rest" : "arg" + index);
+    const dotdotdot = isRest ? factory.createToken(26 /* DotDotDotToken */) : node.dotDotDotToken;
+    return factory.createParameterDeclaration(node.modifiers, dotdotdot, name, node.questionToken, visitNode(node.type, transformJSDocType, isTypeNode), node.initializer);
+  }
+  function transformJSDocTypeReference(node) {
+    let name = node.typeName;
+    let args = node.typeArguments;
+    if (isIdentifier(node.typeName)) {
+      if (isJSDocIndexSignature(node)) {
+        return transformJSDocIndexSignature(node);
+      }
+      let text = node.typeName.text;
+      switch (node.typeName.text) {
+        case "String":
+        case "Boolean":
+        case "Object":
+        case "Number":
+          text = text.toLowerCase();
+          break;
+        case "array":
+        case "date":
+        case "promise":
+          text = text[0].toUpperCase() + text.slice(1);
+          break;
+      }
+      name = factory.createIdentifier(text);
+      if ((text === "Array" || text === "Promise") && !node.typeArguments) {
+        args = factory.createNodeArray([factory.createTypeReferenceNode("any", emptyArray)]);
+      } else {
+        args = visitNodes2(node.typeArguments, transformJSDocType, isTypeNode);
+      }
     }
-    return isCallExpression(node.parent) && node.parent.expression === node;
+    return factory.createTypeReferenceNode(name, args);
   }
-  function isRightSideOfQualifiedNameOrPropertyAccess2(node) {
-    return isQualifiedName(node.parent) && node.parent.right === node || isPropertyAccessExpression(node.parent) && node.parent.name === node;
+  function transformJSDocIndexSignature(node) {
+    const index = factory.createParameterDeclaration(
+      /*modifiers*/
+      void 0,
+      /*dotDotDotToken*/
+      void 0,
+      node.typeArguments[0].kind === 150 /* NumberKeyword */ ? "n" : "s",
+      /*questionToken*/
+      void 0,
+      factory.createTypeReferenceNode(node.typeArguments[0].kind === 150 /* NumberKeyword */ ? "number" : "string", []),
+      /*initializer*/
+      void 0
+    );
+    const indexSignature = factory.createTypeLiteralNode([factory.createIndexSignature(
+      /*modifiers*/
+      void 0,
+      [index],
+      node.typeArguments[1]
+    )]);
+    setEmitFlags(indexSignature, 1 /* SingleLine */);
+    return indexSignature;
   }
-  var TokenEncodingConsts, TokenType, TokenModifier, tokenFromDeclarationMapping;
-  var init_classifier2020 = __esm({
-    "src/services/classifier2020.ts"() {
+  var fixId8, errorCodes9;
+  var init_annotateWithTypeFromJSDoc = __esm({
+    "src/services/codefixes/annotateWithTypeFromJSDoc.ts"() {
       "use strict";
       init_ts4();
-      TokenEncodingConsts = /* @__PURE__ */ ((TokenEncodingConsts2) => {
-        TokenEncodingConsts2[TokenEncodingConsts2["typeOffset"] = 8] = "typeOffset";
-        TokenEncodingConsts2[TokenEncodingConsts2["modifierMask"] = 255] = "modifierMask";
-        return TokenEncodingConsts2;
-      })(TokenEncodingConsts || {});
-      TokenType = /* @__PURE__ */ ((TokenType2) => {
-        TokenType2[TokenType2["class"] = 0] = "class";
-        TokenType2[TokenType2["enum"] = 1] = "enum";
-        TokenType2[TokenType2["interface"] = 2] = "interface";
-        TokenType2[TokenType2["namespace"] = 3] = "namespace";
-        TokenType2[TokenType2["typeParameter"] = 4] = "typeParameter";
-        TokenType2[TokenType2["type"] = 5] = "type";
-        TokenType2[TokenType2["parameter"] = 6] = "parameter";
-        TokenType2[TokenType2["variable"] = 7] = "variable";
-        TokenType2[TokenType2["enumMember"] = 8] = "enumMember";
-        TokenType2[TokenType2["property"] = 9] = "property";
-        TokenType2[TokenType2["function"] = 10] = "function";
-        TokenType2[TokenType2["member"] = 11] = "member";
-        return TokenType2;
-      })(TokenType || {});
-      TokenModifier = /* @__PURE__ */ ((TokenModifier2) => {
-        TokenModifier2[TokenModifier2["declaration"] = 0] = "declaration";
-        TokenModifier2[TokenModifier2["static"] = 1] = "static";
-        TokenModifier2[TokenModifier2["async"] = 2] = "async";
-        TokenModifier2[TokenModifier2["readonly"] = 3] = "readonly";
-        TokenModifier2[TokenModifier2["defaultLibrary"] = 4] = "defaultLibrary";
-        TokenModifier2[TokenModifier2["local"] = 5] = "local";
-        return TokenModifier2;
-      })(TokenModifier || {});
-      tokenFromDeclarationMapping = /* @__PURE__ */ new Map([
-        [259 /* VariableDeclaration */, 7 /* variable */],
-        [168 /* Parameter */, 6 /* parameter */],
-        [171 /* PropertyDeclaration */, 9 /* property */],
-        [266 /* ModuleDeclaration */, 3 /* namespace */],
-        [265 /* EnumDeclaration */, 1 /* enum */],
-        [305 /* EnumMember */, 8 /* enumMember */],
-        [262 /* ClassDeclaration */, 0 /* class */],
-        [173 /* MethodDeclaration */, 11 /* member */],
-        [261 /* FunctionDeclaration */, 10 /* function */],
-        [217 /* FunctionExpression */, 10 /* function */],
-        [172 /* MethodSignature */, 11 /* member */],
-        [176 /* GetAccessor */, 9 /* property */],
-        [177 /* SetAccessor */, 9 /* property */],
-        [170 /* PropertySignature */, 9 /* property */],
-        [263 /* InterfaceDeclaration */, 2 /* interface */],
-        [264 /* TypeAliasDeclaration */, 5 /* type */],
-        [167 /* TypeParameter */, 4 /* typeParameter */],
-        [302 /* PropertyAssignment */, 9 /* property */],
-        [303 /* ShorthandPropertyAssignment */, 9 /* property */]
-      ]);
+      init_ts_codefix();
+      fixId8 = "annotateWithTypeFromJSDoc";
+      errorCodes9 = [Diagnostics.JSDoc_types_may_be_moved_to_TypeScript_types.code];
+      registerCodeFix({
+        errorCodes: errorCodes9,
+        getCodeActions(context) {
+          const decl = getDeclaration(context.sourceFile, context.span.start);
+          if (!decl)
+            return;
+          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange8(t, context.sourceFile, decl));
+          return [createCodeFixAction(fixId8, changes, Diagnostics.Annotate_with_type_from_JSDoc, fixId8, Diagnostics.Annotate_everything_with_types_from_JSDoc)];
+        },
+        fixIds: [fixId8],
+        getAllCodeActions: (context) => codeFixAll(context, errorCodes9, (changes, diag2) => {
+          const decl = getDeclaration(diag2.file, diag2.start);
+          if (decl)
+            doChange8(changes, diag2.file, decl);
+        })
+      });
     }
   });
 
-  // src/services/services.ts
-  function createNode(kind, pos, end, parent2) {
-    const node = isNodeKind(kind) ? new NodeObject(kind, pos, end) : kind === 80 /* Identifier */ ? new IdentifierObject(80 /* Identifier */, pos, end) : kind === 81 /* PrivateIdentifier */ ? new PrivateIdentifierObject(81 /* PrivateIdentifier */, pos, end) : new TokenObject(kind, pos, end);
-    node.parent = parent2;
-    node.flags = parent2.flags & 50720768 /* ContextFlags */;
-    return node;
-  }
-  function createChildren(node, sourceFile) {
-    if (!isNodeKind(node.kind)) {
-      return emptyArray;
-    }
-    const children = [];
-    if (isJSDocCommentContainingNode(node)) {
-      node.forEachChild((child) => {
-        children.push(child);
-      });
-      return children;
+  // src/services/codefixes/convertFunctionToEs6Class.ts
+  function doChange9(changes, sourceFile, position, checker, preferences, compilerOptions) {
+    const ctorSymbol = checker.getSymbolAtLocation(getTokenAtPosition(sourceFile, position));
+    if (!ctorSymbol || !ctorSymbol.valueDeclaration || !(ctorSymbol.flags & (16 /* Function */ | 3 /* Variable */))) {
+      return void 0;
     }
-    scanner.setText((sourceFile || node.getSourceFile()).text);
-    let pos = node.pos;
-    const processNode = (child) => {
-      addSyntheticNodes(children, pos, child.pos, node);
-      children.push(child);
-      pos = child.end;
-    };
-    const processNodes = (nodes) => {
-      addSyntheticNodes(children, pos, nodes.pos, node);
-      children.push(createSyntaxList(nodes, node));
-      pos = nodes.end;
-    };
-    forEach(node.jsDoc, processNode);
-    pos = node.pos;
-    node.forEachChild(processNode, processNodes);
-    addSyntheticNodes(children, pos, node.end, node);
-    scanner.setText(void 0);
-    return children;
-  }
-  function addSyntheticNodes(nodes, pos, end, parent2) {
-    scanner.resetTokenState(pos);
-    while (pos < end) {
-      const token = scanner.scan();
-      const textPos = scanner.getTokenEnd();
-      if (textPos <= end) {
-        if (token === 80 /* Identifier */) {
-          if (hasTabstop(parent2)) {
-            continue;
-          }
-          Debug.fail(`Did not expect ${Debug.formatSyntaxKind(parent2.kind)} to have an Identifier in its trivia`);
-        }
-        nodes.push(createNode(token, pos, textPos, parent2));
+    const ctorDeclaration = ctorSymbol.valueDeclaration;
+    if (isFunctionDeclaration(ctorDeclaration) || isFunctionExpression(ctorDeclaration)) {
+      changes.replaceNode(sourceFile, ctorDeclaration, createClassFromFunction(ctorDeclaration));
+    } else if (isVariableDeclaration(ctorDeclaration)) {
+      const classDeclaration = createClassFromVariableDeclaration(ctorDeclaration);
+      if (!classDeclaration) {
+        return void 0;
       }
-      pos = textPos;
-      if (token === 1 /* EndOfFileToken */) {
-        break;
+      const ancestor = ctorDeclaration.parent.parent;
+      if (isVariableDeclarationList(ctorDeclaration.parent) && ctorDeclaration.parent.declarations.length > 1) {
+        changes.delete(sourceFile, ctorDeclaration);
+        changes.insertNodeAfter(sourceFile, ancestor, classDeclaration);
+      } else {
+        changes.replaceNode(sourceFile, ancestor, classDeclaration);
       }
     }
-  }
-  function createSyntaxList(nodes, parent2) {
-    const list = createNode(357 /* SyntaxList */, nodes.pos, nodes.end, parent2);
-    list._children = [];
-    let pos = nodes.pos;
-    for (const node of nodes) {
-      addSyntheticNodes(list._children, pos, node.pos, parent2);
-      list._children.push(node);
-      pos = node.end;
-    }
-    addSyntheticNodes(list._children, pos, nodes.end, parent2);
-    return list;
-  }
-  function hasJSDocInheritDocTag(node) {
-    return getJSDocTags(node).some((tag) => tag.tagName.text === "inheritDoc" || tag.tagName.text === "inheritdoc");
-  }
-  function getJsDocTagsOfDeclarations(declarations, checker) {
-    if (!declarations)
-      return emptyArray;
-    let tags = ts_JsDoc_exports.getJsDocTagsFromDeclarations(declarations, checker);
-    if (checker && (tags.length === 0 || declarations.some(hasJSDocInheritDocTag))) {
-      const seenSymbols = /* @__PURE__ */ new Set();
-      for (const declaration of declarations) {
-        const inheritedTags = findBaseOfDeclaration(checker, declaration, (symbol) => {
-          var _a;
-          if (!seenSymbols.has(symbol)) {
-            seenSymbols.add(symbol);
-            if (declaration.kind === 176 /* GetAccessor */ || declaration.kind === 177 /* SetAccessor */) {
-              return symbol.getContextualJsDocTags(declaration, checker);
+    function createClassElementsFromSymbol(symbol) {
+      const memberElements = [];
+      if (symbol.exports) {
+        symbol.exports.forEach((member) => {
+          if (member.name === "prototype" && member.declarations) {
+            const firstDeclaration = member.declarations[0];
+            if (member.declarations.length === 1 && isPropertyAccessExpression(firstDeclaration) && isBinaryExpression(firstDeclaration.parent) && firstDeclaration.parent.operatorToken.kind === 64 /* EqualsToken */ && isObjectLiteralExpression(firstDeclaration.parent.right)) {
+              const prototypes = firstDeclaration.parent.right;
+              createClassElement(
+                prototypes.symbol,
+                /*modifiers*/
+                void 0,
+                memberElements
+              );
             }
-            return ((_a = symbol.declarations) == null ? void 0 : _a.length) === 1 ? symbol.getJsDocTags() : void 0;
+          } else {
+            createClassElement(member, [factory.createToken(126 /* StaticKeyword */)], memberElements);
           }
         });
-        if (inheritedTags) {
-          tags = [...inheritedTags, ...tags];
+      }
+      if (symbol.members) {
+        symbol.members.forEach((member, key) => {
+          var _a, _b, _c, _d;
+          if (key === "constructor" && member.valueDeclaration) {
+            const prototypeAssignment = (_d = (_c = (_b = (_a = symbol.exports) == null ? void 0 : _a.get("prototype")) == null ? void 0 : _b.declarations) == null ? void 0 : _c[0]) == null ? void 0 : _d.parent;
+            if (prototypeAssignment && isBinaryExpression(prototypeAssignment) && isObjectLiteralExpression(prototypeAssignment.right) && some(prototypeAssignment.right.properties, isConstructorAssignment)) {
+            } else {
+              changes.delete(sourceFile, member.valueDeclaration.parent);
+            }
+            return;
+          }
+          createClassElement(
+            member,
+            /*modifiers*/
+            void 0,
+            memberElements
+          );
+        });
+      }
+      return memberElements;
+      function shouldConvertDeclaration(_target, source) {
+        if (isAccessExpression(_target)) {
+          if (isPropertyAccessExpression(_target) && isConstructorAssignment(_target))
+            return true;
+          return isFunctionLike(source);
+        } else {
+          return every(_target.properties, (property) => {
+            if (isMethodDeclaration(property) || isGetOrSetAccessorDeclaration(property))
+              return true;
+            if (isPropertyAssignment(property) && isFunctionExpression(property.initializer) && !!property.name)
+              return true;
+            if (isConstructorAssignment(property))
+              return true;
+            return false;
+          });
+        }
+      }
+      function createClassElement(symbol2, modifiers, members) {
+        if (!(symbol2.flags & 8192 /* Method */) && !(symbol2.flags & 4096 /* ObjectLiteral */)) {
+          return;
+        }
+        const memberDeclaration = symbol2.valueDeclaration;
+        const assignmentBinaryExpression = memberDeclaration.parent;
+        const assignmentExpr = assignmentBinaryExpression.right;
+        if (!shouldConvertDeclaration(memberDeclaration, assignmentExpr)) {
+          return;
+        }
+        if (some(members, (m) => {
+          const name = getNameOfDeclaration(m);
+          if (name && isIdentifier(name) && idText(name) === symbolName(symbol2)) {
+            return true;
+          }
+          return false;
+        })) {
+          return;
+        }
+        const nodeToDelete = assignmentBinaryExpression.parent && assignmentBinaryExpression.parent.kind === 244 /* ExpressionStatement */ ? assignmentBinaryExpression.parent : assignmentBinaryExpression;
+        changes.delete(sourceFile, nodeToDelete);
+        if (!assignmentExpr) {
+          members.push(factory.createPropertyDeclaration(
+            modifiers,
+            symbol2.name,
+            /*questionOrExclamationToken*/
+            void 0,
+            /*type*/
+            void 0,
+            /*initializer*/
+            void 0
+          ));
+          return;
+        }
+        if (isAccessExpression(memberDeclaration) && (isFunctionExpression(assignmentExpr) || isArrowFunction(assignmentExpr))) {
+          const quotePreference = getQuotePreference(sourceFile, preferences);
+          const name = tryGetPropertyName(memberDeclaration, compilerOptions, quotePreference);
+          if (name) {
+            createFunctionLikeExpressionMember(members, assignmentExpr, name);
+          }
+          return;
+        } else if (isObjectLiteralExpression(assignmentExpr)) {
+          forEach(
+            assignmentExpr.properties,
+            (property) => {
+              if (isMethodDeclaration(property) || isGetOrSetAccessorDeclaration(property)) {
+                members.push(property);
+              }
+              if (isPropertyAssignment(property) && isFunctionExpression(property.initializer)) {
+                createFunctionLikeExpressionMember(members, property.initializer, property.name);
+              }
+              if (isConstructorAssignment(property))
+                return;
+              return;
+            }
+          );
+          return;
+        } else {
+          if (isSourceFileJS(sourceFile))
+            return;
+          if (!isPropertyAccessExpression(memberDeclaration))
+            return;
+          const prop = factory.createPropertyDeclaration(
+            modifiers,
+            memberDeclaration.name,
+            /*questionOrExclamationToken*/
+            void 0,
+            /*type*/
+            void 0,
+            assignmentExpr
+          );
+          copyLeadingComments(assignmentBinaryExpression.parent, prop, sourceFile);
+          members.push(prop);
+          return;
+        }
+        function createFunctionLikeExpressionMember(members2, expression, name) {
+          if (isFunctionExpression(expression))
+            return createFunctionExpressionMember(members2, expression, name);
+          else
+            return createArrowFunctionExpressionMember(members2, expression, name);
+        }
+        function createFunctionExpressionMember(members2, functionExpression, name) {
+          const fullModifiers = concatenate(modifiers, getModifierKindFromSource(functionExpression, 134 /* AsyncKeyword */));
+          const method = factory.createMethodDeclaration(
+            fullModifiers,
+            /*asteriskToken*/
+            void 0,
+            name,
+            /*questionToken*/
+            void 0,
+            /*typeParameters*/
+            void 0,
+            functionExpression.parameters,
+            /*type*/
+            void 0,
+            functionExpression.body
+          );
+          copyLeadingComments(assignmentBinaryExpression, method, sourceFile);
+          members2.push(method);
+          return;
+        }
+        function createArrowFunctionExpressionMember(members2, arrowFunction, name) {
+          const arrowFunctionBody = arrowFunction.body;
+          let bodyBlock;
+          if (arrowFunctionBody.kind === 241 /* Block */) {
+            bodyBlock = arrowFunctionBody;
+          } else {
+            bodyBlock = factory.createBlock([factory.createReturnStatement(arrowFunctionBody)]);
+          }
+          const fullModifiers = concatenate(modifiers, getModifierKindFromSource(arrowFunction, 134 /* AsyncKeyword */));
+          const method = factory.createMethodDeclaration(
+            fullModifiers,
+            /*asteriskToken*/
+            void 0,
+            name,
+            /*questionToken*/
+            void 0,
+            /*typeParameters*/
+            void 0,
+            arrowFunction.parameters,
+            /*type*/
+            void 0,
+            bodyBlock
+          );
+          copyLeadingComments(assignmentBinaryExpression, method, sourceFile);
+          members2.push(method);
         }
       }
     }
-    return tags;
-  }
-  function getDocumentationComment(declarations, checker) {
-    if (!declarations)
-      return emptyArray;
-    let doc = ts_JsDoc_exports.getJsDocCommentsFromDeclarations(declarations, checker);
-    if (checker && (doc.length === 0 || declarations.some(hasJSDocInheritDocTag))) {
-      const seenSymbols = /* @__PURE__ */ new Set();
-      for (const declaration of declarations) {
-        const inheritedDocs = findBaseOfDeclaration(checker, declaration, (symbol) => {
-          if (!seenSymbols.has(symbol)) {
-            seenSymbols.add(symbol);
-            if (declaration.kind === 176 /* GetAccessor */ || declaration.kind === 177 /* SetAccessor */) {
-              return symbol.getContextualDocumentationComment(declaration, checker);
-            }
-            return symbol.getDocumentationComment(checker);
-          }
-        });
-        if (inheritedDocs)
-          doc = doc.length === 0 ? inheritedDocs.slice() : inheritedDocs.concat(lineBreakPart(), doc);
+    function createClassFromVariableDeclaration(node) {
+      const initializer = node.initializer;
+      if (!initializer || !isFunctionExpression(initializer) || !isIdentifier(node.name)) {
+        return void 0;
+      }
+      const memberElements = createClassElementsFromSymbol(node.symbol);
+      if (initializer.body) {
+        memberElements.unshift(factory.createConstructorDeclaration(
+          /*modifiers*/
+          void 0,
+          initializer.parameters,
+          initializer.body
+        ));
+      }
+      const modifiers = getModifierKindFromSource(node.parent.parent, 95 /* ExportKeyword */);
+      const cls = factory.createClassDeclaration(
+        modifiers,
+        node.name,
+        /*typeParameters*/
+        void 0,
+        /*heritageClauses*/
+        void 0,
+        memberElements
+      );
+      return cls;
+    }
+    function createClassFromFunction(node) {
+      const memberElements = createClassElementsFromSymbol(ctorSymbol);
+      if (node.body) {
+        memberElements.unshift(factory.createConstructorDeclaration(
+          /*modifiers*/
+          void 0,
+          node.parameters,
+          node.body
+        ));
       }
+      const modifiers = getModifierKindFromSource(node, 95 /* ExportKeyword */);
+      const cls = factory.createClassDeclaration(
+        modifiers,
+        node.name,
+        /*typeParameters*/
+        void 0,
+        /*heritageClauses*/
+        void 0,
+        memberElements
+      );
+      return cls;
     }
-    return doc;
   }
-  function findBaseOfDeclaration(checker, declaration, cb) {
-    var _a;
-    const classOrInterfaceDeclaration = ((_a = declaration.parent) == null ? void 0 : _a.kind) === 175 /* Constructor */ ? declaration.parent.parent : declaration.parent;
-    if (!classOrInterfaceDeclaration)
-      return;
-    const isStaticMember = hasStaticModifier(declaration);
-    return firstDefined(getAllSuperTypeNodes(classOrInterfaceDeclaration), (superTypeNode) => {
-      const baseType = checker.getTypeAtLocation(superTypeNode);
-      const type = isStaticMember && baseType.symbol ? checker.getTypeOfSymbol(baseType.symbol) : baseType;
-      const symbol = checker.getPropertyOfType(type, declaration.symbol.name);
-      return symbol ? cb(symbol) : void 0;
-    });
+  function getModifierKindFromSource(source, kind) {
+    return canHaveModifiers(source) ? filter(source.modifiers, (modifier) => modifier.kind === kind) : void 0;
   }
-  function getServicesObjectAllocator() {
-    return {
-      getNodeConstructor: () => NodeObject,
-      getTokenConstructor: () => TokenObject,
-      getIdentifierConstructor: () => IdentifierObject,
-      getPrivateIdentifierConstructor: () => PrivateIdentifierObject,
-      getSourceFileConstructor: () => SourceFileObject,
-      getSymbolConstructor: () => SymbolObject,
-      getTypeConstructor: () => TypeObject,
-      getSignatureConstructor: () => SignatureObject,
-      getSourceMapSourceConstructor: () => SourceMapSourceObject
-    };
+  function isConstructorAssignment(x) {
+    if (!x.name)
+      return false;
+    if (isIdentifier(x.name) && x.name.text === "constructor")
+      return true;
+    return false;
   }
-  function toEditorSettings(optionsAsMap) {
-    let allPropertiesAreCamelCased = true;
-    for (const key in optionsAsMap) {
-      if (hasProperty(optionsAsMap, key) && !isCamelCase(key)) {
-        allPropertiesAreCamelCased = false;
-        break;
-      }
-    }
-    if (allPropertiesAreCamelCased) {
-      return optionsAsMap;
+  function tryGetPropertyName(node, compilerOptions, quotePreference) {
+    if (isPropertyAccessExpression(node)) {
+      return node.name;
     }
-    const settings = {};
-    for (const key in optionsAsMap) {
-      if (hasProperty(optionsAsMap, key)) {
-        const newKey = isCamelCase(key) ? key : key.charAt(0).toLowerCase() + key.substr(1);
-        settings[newKey] = optionsAsMap[key];
-      }
+    const propName = node.argumentExpression;
+    if (isNumericLiteral(propName)) {
+      return propName;
     }
-    return settings;
-  }
-  function isCamelCase(s) {
-    return !s.length || s.charAt(0) === s.charAt(0).toLowerCase();
-  }
-  function displayPartsToString(displayParts) {
-    if (displayParts) {
-      return map(displayParts, (displayPart2) => displayPart2.text).join("");
+    if (isStringLiteralLike(propName)) {
+      return isIdentifierText(propName.text, getEmitScriptTarget(compilerOptions)) ? factory.createIdentifier(propName.text) : isNoSubstitutionTemplateLiteral(propName) ? factory.createStringLiteral(propName.text, quotePreference === 0 /* Single */) : propName;
     }
-    return "";
-  }
-  function getDefaultCompilerOptions2() {
-    return {
-      target: 1 /* ES5 */,
-      jsx: 1 /* Preserve */
-    };
-  }
-  function getSupportedCodeFixes() {
-    return ts_codefix_exports.getSupportedErrorCodes();
-  }
-  function setSourceFileFields(sourceFile, scriptSnapshot, version2) {
-    sourceFile.version = version2;
-    sourceFile.scriptSnapshot = scriptSnapshot;
-  }
-  function createLanguageServiceSourceFile(fileName, scriptSnapshot, scriptTargetOrOptions, version2, setNodeParents, scriptKind) {
-    const sourceFile = createSourceFile(fileName, getSnapshotText(scriptSnapshot), scriptTargetOrOptions, setNodeParents, scriptKind);
-    setSourceFileFields(sourceFile, scriptSnapshot, version2);
-    return sourceFile;
+    return void 0;
   }
-  function updateLanguageServiceSourceFile(sourceFile, scriptSnapshot, version2, textChangeRange, aggressiveChecks) {
-    if (textChangeRange) {
-      if (version2 !== sourceFile.version) {
-        let newText;
-        const prefix = textChangeRange.span.start !== 0 ? sourceFile.text.substr(0, textChangeRange.span.start) : "";
-        const suffix = textSpanEnd(textChangeRange.span) !== sourceFile.text.length ? sourceFile.text.substr(textSpanEnd(textChangeRange.span)) : "";
-        if (textChangeRange.newLength === 0) {
-          newText = prefix && suffix ? prefix + suffix : prefix || suffix;
-        } else {
-          const changedText = scriptSnapshot.getText(textChangeRange.span.start, textChangeRange.span.start + textChangeRange.newLength);
-          newText = prefix && suffix ? prefix + changedText + suffix : prefix ? prefix + changedText : changedText + suffix;
-        }
-        const newSourceFile = updateSourceFile(sourceFile, newText, textChangeRange, aggressiveChecks);
-        setSourceFileFields(newSourceFile, scriptSnapshot, version2);
-        newSourceFile.nameTable = void 0;
-        if (sourceFile !== newSourceFile && sourceFile.scriptSnapshot) {
-          if (sourceFile.scriptSnapshot.dispose) {
-            sourceFile.scriptSnapshot.dispose();
-          }
-          sourceFile.scriptSnapshot = void 0;
-        }
-        return newSourceFile;
-      }
+  var fixId9, errorCodes10;
+  var init_convertFunctionToEs6Class = __esm({
+    "src/services/codefixes/convertFunctionToEs6Class.ts"() {
+      "use strict";
+      init_ts4();
+      init_ts_codefix();
+      fixId9 = "convertFunctionToEs6Class";
+      errorCodes10 = [Diagnostics.This_constructor_function_may_be_converted_to_a_class_declaration.code];
+      registerCodeFix({
+        errorCodes: errorCodes10,
+        getCodeActions(context) {
+          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange9(t, context.sourceFile, context.span.start, context.program.getTypeChecker(), context.preferences, context.program.getCompilerOptions()));
+          return [createCodeFixAction(fixId9, changes, Diagnostics.Convert_function_to_an_ES2015_class, fixId9, Diagnostics.Convert_all_constructor_functions_to_classes)];
+        },
+        fixIds: [fixId9],
+        getAllCodeActions: (context) => codeFixAll(context, errorCodes10, (changes, err) => doChange9(changes, err.file, err.start, context.program.getTypeChecker(), context.preferences, context.program.getCompilerOptions()))
+      });
     }
-    const options = {
-      languageVersion: sourceFile.languageVersion,
-      impliedNodeFormat: sourceFile.impliedNodeFormat,
-      setExternalModuleIndicator: sourceFile.setExternalModuleIndicator
-    };
-    return createLanguageServiceSourceFile(
-      sourceFile.fileName,
-      scriptSnapshot,
-      options,
-      version2,
-      /*setNodeParents*/
-      true,
-      sourceFile.scriptKind
-    );
-  }
-  function createLanguageService(host, documentRegistry = createDocumentRegistry(host.useCaseSensitiveFileNames && host.useCaseSensitiveFileNames(), host.getCurrentDirectory()), syntaxOnlyOrLanguageServiceMode) {
-    var _a;
-    let languageServiceMode;
-    if (syntaxOnlyOrLanguageServiceMode === void 0) {
-      languageServiceMode = 0 /* Semantic */;
-    } else if (typeof syntaxOnlyOrLanguageServiceMode === "boolean") {
-      languageServiceMode = syntaxOnlyOrLanguageServiceMode ? 2 /* Syntactic */ : 0 /* Semantic */;
+  });
+
+  // src/services/codefixes/convertToAsyncFunction.ts
+  function convertToAsyncFunction(changes, sourceFile, position, checker) {
+    const tokenAtPosition = getTokenAtPosition(sourceFile, position);
+    let functionToConvert;
+    if (isIdentifier(tokenAtPosition) && isVariableDeclaration(tokenAtPosition.parent) && tokenAtPosition.parent.initializer && isFunctionLikeDeclaration(tokenAtPosition.parent.initializer)) {
+      functionToConvert = tokenAtPosition.parent.initializer;
     } else {
-      languageServiceMode = syntaxOnlyOrLanguageServiceMode;
+      functionToConvert = tryCast(getContainingFunction(getTokenAtPosition(sourceFile, position)), canBeConvertedToAsync);
     }
-    const syntaxTreeCache = new SyntaxTreeCache(host);
-    let program;
-    let lastProjectVersion;
-    let lastTypesRootVersion = 0;
-    const cancellationToken = host.getCancellationToken ? new CancellationTokenObject(host.getCancellationToken()) : NoopCancellationToken;
-    const currentDirectory = host.getCurrentDirectory();
-    maybeSetLocalizedDiagnosticMessages((_a = host.getLocalizedDiagnosticMessages) == null ? void 0 : _a.bind(host));
-    function log(message) {
-      if (host.log) {
-        host.log(message);
-      }
+    if (!functionToConvert) {
+      return;
     }
-    const useCaseSensitiveFileNames = hostUsesCaseSensitiveFileNames(host);
-    const getCanonicalFileName = createGetCanonicalFileName(useCaseSensitiveFileNames);
-    const sourceMapper = getSourceMapper({
-      useCaseSensitiveFileNames: () => useCaseSensitiveFileNames,
-      getCurrentDirectory: () => currentDirectory,
-      getProgram,
-      fileExists: maybeBind(host, host.fileExists),
-      readFile: maybeBind(host, host.readFile),
-      getDocumentPositionMapper: maybeBind(host, host.getDocumentPositionMapper),
-      getSourceFileLike: maybeBind(host, host.getSourceFileLike),
-      log
-    });
-    function getValidSourceFile(fileName) {
-      const sourceFile = program.getSourceFile(fileName);
-      if (!sourceFile) {
-        const error = new Error(`Could not find source file: '${fileName}'.`);
-        error.ProgramFiles = program.getSourceFiles().map((f) => f.fileName);
-        throw error;
-      }
-      return sourceFile;
+    const synthNamesMap = /* @__PURE__ */ new Map();
+    const isInJavascript = isInJSFile(functionToConvert);
+    const setOfExpressionsToReturn = getAllPromiseExpressionsToReturn(functionToConvert, checker);
+    const functionToConvertRenamed = renameCollidingVarNames(functionToConvert, checker, synthNamesMap);
+    if (!returnsPromise(functionToConvertRenamed, checker)) {
+      return;
     }
-    function synchronizeHostData() {
-      var _a2, _b, _c;
-      Debug.assert(languageServiceMode !== 2 /* Syntactic */);
-      if (host.getProjectVersion) {
-        const hostProjectVersion = host.getProjectVersion();
-        if (hostProjectVersion) {
-          if (lastProjectVersion === hostProjectVersion && !((_a2 = host.hasChangedAutomaticTypeDirectiveNames) == null ? void 0 : _a2.call(host))) {
-            return;
+    const returnStatements = functionToConvertRenamed.body && isBlock(functionToConvertRenamed.body) ? getReturnStatementsWithPromiseHandlers(functionToConvertRenamed.body, checker) : emptyArray;
+    const transformer = { checker, synthNamesMap, setOfExpressionsToReturn, isInJSFile: isInJavascript };
+    if (!returnStatements.length) {
+      return;
+    }
+    const pos = skipTrivia(sourceFile.text, moveRangePastModifiers(functionToConvert).pos);
+    changes.insertModifierAt(sourceFile, pos, 134 /* AsyncKeyword */, { suffix: " " });
+    for (const returnStatement of returnStatements) {
+      forEachChild(returnStatement, function visit(node) {
+        if (isCallExpression(node)) {
+          const newNodes = transformExpression(
+            node,
+            node,
+            transformer,
+            /*hasContinuation*/
+            false
+          );
+          if (hasFailed()) {
+            return true;
+          }
+          changes.replaceNodeWithNodes(sourceFile, returnStatement, newNodes);
+        } else if (!isFunctionLike(node)) {
+          forEachChild(node, visit);
+          if (hasFailed()) {
+            return true;
           }
-          lastProjectVersion = hostProjectVersion;
         }
-      }
-      const typeRootsVersion = host.getTypeRootsVersion ? host.getTypeRootsVersion() : 0;
-      if (lastTypesRootVersion !== typeRootsVersion) {
-        log("TypeRoots version has changed; provide new program");
-        program = void 0;
-        lastTypesRootVersion = typeRootsVersion;
-      }
-      const rootFileNames = host.getScriptFileNames().slice();
-      const newSettings = host.getCompilationSettings() || getDefaultCompilerOptions2();
-      const hasInvalidatedResolutions = host.hasInvalidatedResolutions || returnFalse;
-      const hasInvalidatedLibResolutions = maybeBind(host, host.hasInvalidatedLibResolutions) || returnFalse;
-      const hasChangedAutomaticTypeDirectiveNames = maybeBind(host, host.hasChangedAutomaticTypeDirectiveNames);
-      const projectReferences = (_b = host.getProjectReferences) == null ? void 0 : _b.call(host);
-      let parsedCommandLines;
-      let compilerHost = {
-        getSourceFile: getOrCreateSourceFile,
-        getSourceFileByPath: getOrCreateSourceFileByPath,
-        getCancellationToken: () => cancellationToken,
-        getCanonicalFileName,
-        useCaseSensitiveFileNames: () => useCaseSensitiveFileNames,
-        getNewLine: () => getNewLineCharacter(newSettings),
-        getDefaultLibFileName: (options2) => host.getDefaultLibFileName(options2),
-        writeFile: noop,
-        getCurrentDirectory: () => currentDirectory,
-        fileExists: (fileName) => host.fileExists(fileName),
-        readFile: (fileName) => host.readFile && host.readFile(fileName),
-        getSymlinkCache: maybeBind(host, host.getSymlinkCache),
-        realpath: maybeBind(host, host.realpath),
-        directoryExists: (directoryName) => {
-          return directoryProbablyExists(directoryName, host);
-        },
-        getDirectories: (path) => {
-          return host.getDirectories ? host.getDirectories(path) : [];
-        },
-        readDirectory: (path, extensions, exclude, include, depth) => {
-          Debug.checkDefined(host.readDirectory, "'LanguageServiceHost.readDirectory' must be implemented to correctly process 'projectReferences'");
-          return host.readDirectory(path, extensions, exclude, include, depth);
-        },
-        onReleaseOldSourceFile,
-        onReleaseParsedCommandLine,
-        hasInvalidatedResolutions,
-        hasInvalidatedLibResolutions,
-        hasChangedAutomaticTypeDirectiveNames,
-        trace: maybeBind(host, host.trace),
-        resolveModuleNames: maybeBind(host, host.resolveModuleNames),
-        getModuleResolutionCache: maybeBind(host, host.getModuleResolutionCache),
-        createHash: maybeBind(host, host.createHash),
-        resolveTypeReferenceDirectives: maybeBind(host, host.resolveTypeReferenceDirectives),
-        resolveModuleNameLiterals: maybeBind(host, host.resolveModuleNameLiterals),
-        resolveTypeReferenceDirectiveReferences: maybeBind(host, host.resolveTypeReferenceDirectiveReferences),
-        resolveLibrary: maybeBind(host, host.resolveLibrary),
-        useSourceOfProjectReferenceRedirect: maybeBind(host, host.useSourceOfProjectReferenceRedirect),
-        getParsedCommandLine
-      };
-      const originalGetSourceFile = compilerHost.getSourceFile;
-      const { getSourceFileWithCache } = changeCompilerHostLikeToUseCache(
-        compilerHost,
-        (fileName) => toPath(fileName, currentDirectory, getCanonicalFileName),
-        (...args) => originalGetSourceFile.call(compilerHost, ...args)
-      );
-      compilerHost.getSourceFile = getSourceFileWithCache;
-      (_c = host.setCompilerHost) == null ? void 0 : _c.call(host, compilerHost);
-      const parseConfigHost = {
-        useCaseSensitiveFileNames,
-        fileExists: (fileName) => compilerHost.fileExists(fileName),
-        readFile: (fileName) => compilerHost.readFile(fileName),
-        readDirectory: (...args) => compilerHost.readDirectory(...args),
-        trace: compilerHost.trace,
-        getCurrentDirectory: compilerHost.getCurrentDirectory,
-        onUnRecoverableConfigFileDiagnostic: noop
-      };
-      const documentRegistryBucketKey = documentRegistry.getKeyForCompilationSettings(newSettings);
-      let releasedScriptKinds = /* @__PURE__ */ new Set();
-      if (isProgramUptoDate(program, rootFileNames, newSettings, (_path, fileName) => host.getScriptVersion(fileName), (fileName) => compilerHost.fileExists(fileName), hasInvalidatedResolutions, hasInvalidatedLibResolutions, hasChangedAutomaticTypeDirectiveNames, getParsedCommandLine, projectReferences)) {
-        compilerHost = void 0;
-        parsedCommandLines = void 0;
-        releasedScriptKinds = void 0;
+      });
+      if (hasFailed()) {
         return;
       }
-      const options = {
-        rootNames: rootFileNames,
-        options: newSettings,
-        host: compilerHost,
-        oldProgram: program,
-        projectReferences
-      };
-      program = createProgram(options);
-      compilerHost = void 0;
-      parsedCommandLines = void 0;
-      releasedScriptKinds = void 0;
-      sourceMapper.clearCache();
-      program.getTypeChecker();
-      return;
-      function getParsedCommandLine(fileName) {
-        const path = toPath(fileName, currentDirectory, getCanonicalFileName);
-        const existing = parsedCommandLines == null ? void 0 : parsedCommandLines.get(path);
-        if (existing !== void 0)
-          return existing || void 0;
-        const result = host.getParsedCommandLine ? host.getParsedCommandLine(fileName) : getParsedCommandLineOfConfigFileUsingSourceFile(fileName);
-        (parsedCommandLines || (parsedCommandLines = /* @__PURE__ */ new Map())).set(path, result || false);
-        return result;
-      }
-      function getParsedCommandLineOfConfigFileUsingSourceFile(configFileName) {
-        const result = getOrCreateSourceFile(configFileName, 100 /* JSON */);
-        if (!result)
-          return void 0;
-        result.path = toPath(configFileName, currentDirectory, getCanonicalFileName);
-        result.resolvedPath = result.path;
-        result.originalFileName = result.fileName;
-        return parseJsonSourceFileConfigFileContent(
-          result,
-          parseConfigHost,
-          getNormalizedAbsolutePath(getDirectoryPath(configFileName), currentDirectory),
-          /*existingOptions*/
-          void 0,
-          getNormalizedAbsolutePath(configFileName, currentDirectory)
-        );
-      }
-      function onReleaseParsedCommandLine(configFileName, oldResolvedRef, oldOptions) {
-        var _a3;
-        if (host.getParsedCommandLine) {
-          (_a3 = host.onReleaseParsedCommandLine) == null ? void 0 : _a3.call(host, configFileName, oldResolvedRef, oldOptions);
-        } else if (oldResolvedRef) {
-          onReleaseOldSourceFile(oldResolvedRef.sourceFile, oldOptions);
-        }
-      }
-      function onReleaseOldSourceFile(oldSourceFile, oldOptions) {
-        const oldSettingsKey = documentRegistry.getKeyForCompilationSettings(oldOptions);
-        documentRegistry.releaseDocumentWithKey(oldSourceFile.resolvedPath, oldSettingsKey, oldSourceFile.scriptKind, oldSourceFile.impliedNodeFormat);
-      }
-      function getOrCreateSourceFile(fileName, languageVersionOrOptions, onError, shouldCreateNewSourceFile) {
-        return getOrCreateSourceFileByPath(fileName, toPath(fileName, currentDirectory, getCanonicalFileName), languageVersionOrOptions, onError, shouldCreateNewSourceFile);
+    }
+  }
+  function getReturnStatementsWithPromiseHandlers(body, checker) {
+    const res = [];
+    forEachReturnStatement(body, (ret) => {
+      if (isReturnStatementWithFixablePromiseHandler(ret, checker))
+        res.push(ret);
+    });
+    return res;
+  }
+  function getAllPromiseExpressionsToReturn(func, checker) {
+    if (!func.body) {
+      return /* @__PURE__ */ new Set();
+    }
+    const setOfExpressionsToReturn = /* @__PURE__ */ new Set();
+    forEachChild(func.body, function visit(node) {
+      if (isPromiseReturningCallExpression(node, checker, "then")) {
+        setOfExpressionsToReturn.add(getNodeId(node));
+        forEach(node.arguments, visit);
+      } else if (isPromiseReturningCallExpression(node, checker, "catch") || isPromiseReturningCallExpression(node, checker, "finally")) {
+        setOfExpressionsToReturn.add(getNodeId(node));
+        forEachChild(node, visit);
+      } else if (isPromiseTypedExpression(node, checker)) {
+        setOfExpressionsToReturn.add(getNodeId(node));
+      } else {
+        forEachChild(node, visit);
       }
-      function getOrCreateSourceFileByPath(fileName, path, languageVersionOrOptions, _onError, shouldCreateNewSourceFile) {
-        Debug.assert(compilerHost, "getOrCreateSourceFileByPath called after typical CompilerHost lifetime, check the callstack something with a reference to an old host.");
-        const scriptSnapshot = host.getScriptSnapshot(fileName);
-        if (!scriptSnapshot) {
-          return void 0;
-        }
-        const scriptKind = getScriptKind(fileName, host);
-        const scriptVersion = host.getScriptVersion(fileName);
-        if (!shouldCreateNewSourceFile) {
-          const oldSourceFile = program && program.getSourceFileByPath(path);
-          if (oldSourceFile) {
-            if (scriptKind === oldSourceFile.scriptKind || releasedScriptKinds.has(oldSourceFile.resolvedPath)) {
-              return documentRegistry.updateDocumentWithKey(fileName, path, host, documentRegistryBucketKey, scriptSnapshot, scriptVersion, scriptKind, languageVersionOrOptions);
-            } else {
-              documentRegistry.releaseDocumentWithKey(oldSourceFile.resolvedPath, documentRegistry.getKeyForCompilationSettings(program.getCompilerOptions()), oldSourceFile.scriptKind, oldSourceFile.impliedNodeFormat);
-              releasedScriptKinds.add(oldSourceFile.resolvedPath);
-            }
-          }
+    });
+    return setOfExpressionsToReturn;
+  }
+  function isPromiseReturningCallExpression(node, checker, name) {
+    if (!isCallExpression(node))
+      return false;
+    const isExpressionOfName = hasPropertyAccessExpressionWithName(node, name);
+    const nodeType = isExpressionOfName && checker.getTypeAtLocation(node);
+    return !!(nodeType && checker.getPromisedTypeOfPromise(nodeType));
+  }
+  function isReferenceToType(type, target) {
+    return (getObjectFlags(type) & 4 /* Reference */) !== 0 && type.target === target;
+  }
+  function getExplicitPromisedTypeOfPromiseReturningCallExpression(node, callback, checker) {
+    if (node.expression.name.escapedText === "finally") {
+      return void 0;
+    }
+    const promiseType = checker.getTypeAtLocation(node.expression.expression);
+    if (isReferenceToType(promiseType, checker.getPromiseType()) || isReferenceToType(promiseType, checker.getPromiseLikeType())) {
+      if (node.expression.name.escapedText === "then") {
+        if (callback === elementAt(node.arguments, 0)) {
+          return elementAt(node.typeArguments, 0);
+        } else if (callback === elementAt(node.arguments, 1)) {
+          return elementAt(node.typeArguments, 1);
         }
-        return documentRegistry.acquireDocumentWithKey(fileName, path, host, documentRegistryBucketKey, scriptSnapshot, scriptVersion, scriptKind, languageVersionOrOptions);
+      } else {
+        return elementAt(node.typeArguments, 0);
       }
     }
-    function getProgram() {
-      if (languageServiceMode === 2 /* Syntactic */) {
-        Debug.assert(program === void 0);
-        return void 0;
+  }
+  function isPromiseTypedExpression(node, checker) {
+    if (!isExpression(node))
+      return false;
+    return !!checker.getPromisedTypeOfPromise(checker.getTypeAtLocation(node));
+  }
+  function renameCollidingVarNames(nodeToRename, checker, synthNamesMap) {
+    const identsToRenameMap = /* @__PURE__ */ new Map();
+    const collidingSymbolMap = createMultiMap();
+    forEachChild(nodeToRename, function visit(node) {
+      if (!isIdentifier(node)) {
+        forEachChild(node, visit);
+        return;
       }
-      synchronizeHostData();
-      return program;
-    }
-    function getAutoImportProvider() {
-      var _a2;
-      return (_a2 = host.getPackageJsonAutoImportProvider) == null ? void 0 : _a2.call(host);
-    }
-    function updateIsDefinitionOfReferencedSymbols(referencedSymbols, knownSymbolSpans) {
-      const checker = program.getTypeChecker();
-      const symbol = getSymbolForProgram();
-      if (!symbol)
-        return false;
-      for (const referencedSymbol of referencedSymbols) {
-        for (const ref of referencedSymbol.references) {
-          const refNode = getNodeForSpan(ref);
-          Debug.assertIsDefined(refNode);
-          if (knownSymbolSpans.has(ref) || ts_FindAllReferences_exports.isDeclarationOfSymbol(refNode, symbol)) {
-            knownSymbolSpans.add(ref);
-            ref.isDefinition = true;
-            const mappedSpan = getMappedDocumentSpan(ref, sourceMapper, maybeBind(host, host.fileExists));
-            if (mappedSpan) {
-              knownSymbolSpans.add(mappedSpan);
-            }
+      const symbol = checker.getSymbolAtLocation(node);
+      if (symbol) {
+        const type = checker.getTypeAtLocation(node);
+        const lastCallSignature = getLastCallSignature(type, checker);
+        const symbolIdString = getSymbolId(symbol).toString();
+        if (lastCallSignature && !isParameter(node.parent) && !isFunctionLikeDeclaration(node.parent) && !synthNamesMap.has(symbolIdString)) {
+          const firstParameter = firstOrUndefined(lastCallSignature.parameters);
+          const ident = (firstParameter == null ? void 0 : firstParameter.valueDeclaration) && isParameter(firstParameter.valueDeclaration) && tryCast(firstParameter.valueDeclaration.name, isIdentifier) || factory.createUniqueName("result", 16 /* Optimistic */);
+          const synthName = getNewNameIfConflict(ident, collidingSymbolMap);
+          synthNamesMap.set(symbolIdString, synthName);
+          collidingSymbolMap.add(ident.text, symbol);
+        } else if (node.parent && (isParameter(node.parent) || isVariableDeclaration(node.parent) || isBindingElement(node.parent))) {
+          const originalName = node.text;
+          const collidingSymbols = collidingSymbolMap.get(originalName);
+          if (collidingSymbols && collidingSymbols.some((prevSymbol) => prevSymbol !== symbol)) {
+            const newName = getNewNameIfConflict(node, collidingSymbolMap);
+            identsToRenameMap.set(symbolIdString, newName.identifier);
+            synthNamesMap.set(symbolIdString, newName);
+            collidingSymbolMap.add(originalName, symbol);
           } else {
-            ref.isDefinition = false;
+            const identifier = getSynthesizedDeepClone(node);
+            synthNamesMap.set(symbolIdString, createSynthIdentifier(identifier));
+            collidingSymbolMap.add(originalName, symbol);
           }
         }
       }
-      return true;
-      function getSymbolForProgram() {
-        for (const referencedSymbol of referencedSymbols) {
-          for (const ref of referencedSymbol.references) {
-            if (knownSymbolSpans.has(ref)) {
-              const refNode = getNodeForSpan(ref);
-              Debug.assertIsDefined(refNode);
-              return checker.getSymbolAtLocation(refNode);
-            }
-            const mappedSpan = getMappedDocumentSpan(ref, sourceMapper, maybeBind(host, host.fileExists));
-            if (mappedSpan && knownSymbolSpans.has(mappedSpan)) {
-              const refNode = getNodeForSpan(mappedSpan);
-              if (refNode) {
-                return checker.getSymbolAtLocation(refNode);
-              }
-            }
+    });
+    return getSynthesizedDeepCloneWithReplacements(
+      nodeToRename,
+      /*includeTrivia*/
+      true,
+      (original) => {
+        if (isBindingElement(original) && isIdentifier(original.name) && isObjectBindingPattern(original.parent)) {
+          const symbol = checker.getSymbolAtLocation(original.name);
+          const renameInfo = symbol && identsToRenameMap.get(String(getSymbolId(symbol)));
+          if (renameInfo && renameInfo.text !== (original.name || original.propertyName).getText()) {
+            return factory.createBindingElement(
+              original.dotDotDotToken,
+              original.propertyName || original.name,
+              renameInfo,
+              original.initializer
+            );
+          }
+        } else if (isIdentifier(original)) {
+          const symbol = checker.getSymbolAtLocation(original);
+          const renameInfo = symbol && identsToRenameMap.get(String(getSymbolId(symbol)));
+          if (renameInfo) {
+            return factory.createIdentifier(renameInfo.text);
           }
         }
-        return void 0;
-      }
-      function getNodeForSpan(docSpan) {
-        const sourceFile = program.getSourceFile(docSpan.fileName);
-        if (!sourceFile)
-          return void 0;
-        const rawNode = getTouchingPropertyName(sourceFile, docSpan.textSpan.start);
-        const adjustedNode = ts_FindAllReferences_exports.Core.getAdjustedNode(rawNode, { use: ts_FindAllReferences_exports.FindReferencesUse.References });
-        return adjustedNode;
       }
+    );
+  }
+  function getNewNameIfConflict(name, originalNames) {
+    const numVarsSameName = (originalNames.get(name.text) || emptyArray).length;
+    const identifier = numVarsSameName === 0 ? name : factory.createIdentifier(name.text + "_" + numVarsSameName);
+    return createSynthIdentifier(identifier);
+  }
+  function hasFailed() {
+    return !codeActionSucceeded;
+  }
+  function silentFail() {
+    codeActionSucceeded = false;
+    return emptyArray;
+  }
+  function transformExpression(returnContextNode, node, transformer, hasContinuation, continuationArgName) {
+    if (isPromiseReturningCallExpression(node, transformer.checker, "then")) {
+      return transformThen(node, elementAt(node.arguments, 0), elementAt(node.arguments, 1), transformer, hasContinuation, continuationArgName);
     }
-    function cleanupSemanticCache() {
-      program = void 0;
+    if (isPromiseReturningCallExpression(node, transformer.checker, "catch")) {
+      return transformCatch(node, elementAt(node.arguments, 0), transformer, hasContinuation, continuationArgName);
     }
-    function dispose() {
-      if (program) {
-        const key = documentRegistry.getKeyForCompilationSettings(program.getCompilerOptions());
-        forEach(program.getSourceFiles(), (f) => documentRegistry.releaseDocumentWithKey(f.resolvedPath, key, f.scriptKind, f.impliedNodeFormat));
-        program = void 0;
-      }
-      host = void 0;
+    if (isPromiseReturningCallExpression(node, transformer.checker, "finally")) {
+      return transformFinally(node, elementAt(node.arguments, 0), transformer, hasContinuation, continuationArgName);
     }
-    function getSyntacticDiagnostics(fileName) {
-      synchronizeHostData();
-      return program.getSyntacticDiagnostics(getValidSourceFile(fileName), cancellationToken).slice();
+    if (isPropertyAccessExpression(node)) {
+      return transformExpression(returnContextNode, node.expression, transformer, hasContinuation, continuationArgName);
     }
-    function getSemanticDiagnostics(fileName) {
-      synchronizeHostData();
-      const targetSourceFile = getValidSourceFile(fileName);
-      const semanticDiagnostics = program.getSemanticDiagnostics(targetSourceFile, cancellationToken);
-      if (!getEmitDeclarations(program.getCompilerOptions())) {
-        return semanticDiagnostics.slice();
-      }
-      const declarationDiagnostics = program.getDeclarationDiagnostics(targetSourceFile, cancellationToken);
-      return [...semanticDiagnostics, ...declarationDiagnostics];
+    const nodeType = transformer.checker.getTypeAtLocation(node);
+    if (nodeType && transformer.checker.getPromisedTypeOfPromise(nodeType)) {
+      Debug.assertNode(getOriginalNode(node).parent, isPropertyAccessExpression);
+      return transformPromiseExpressionOfPropertyAccess(returnContextNode, node, transformer, hasContinuation, continuationArgName);
     }
-    function getSuggestionDiagnostics(fileName) {
-      synchronizeHostData();
-      return computeSuggestionDiagnostics(getValidSourceFile(fileName), program, cancellationToken);
+    return silentFail();
+  }
+  function isNullOrUndefined2({ checker }, node) {
+    if (node.kind === 106 /* NullKeyword */)
+      return true;
+    if (isIdentifier(node) && !isGeneratedIdentifier(node) && idText(node) === "undefined") {
+      const symbol = checker.getSymbolAtLocation(node);
+      return !symbol || checker.isUndefinedSymbol(symbol);
     }
-    function getCompilerOptionsDiagnostics() {
-      synchronizeHostData();
-      return [...program.getOptionsDiagnostics(cancellationToken), ...program.getGlobalDiagnostics(cancellationToken)];
+    return false;
+  }
+  function createUniqueSynthName(prevArgName) {
+    const renamedPrevArg = factory.createUniqueName(prevArgName.identifier.text, 16 /* Optimistic */);
+    return createSynthIdentifier(renamedPrevArg);
+  }
+  function getPossibleNameForVarDecl(node, transformer, continuationArgName) {
+    let possibleNameForVarDecl;
+    if (continuationArgName && !shouldReturn(node, transformer)) {
+      if (isSynthIdentifier(continuationArgName)) {
+        possibleNameForVarDecl = continuationArgName;
+        transformer.synthNamesMap.forEach((val, key) => {
+          if (val.identifier.text === continuationArgName.identifier.text) {
+            const newSynthName = createUniqueSynthName(continuationArgName);
+            transformer.synthNamesMap.set(key, newSynthName);
+          }
+        });
+      } else {
+        possibleNameForVarDecl = createSynthIdentifier(factory.createUniqueName("result", 16 /* Optimistic */), continuationArgName.types);
+      }
+      declareSynthIdentifier(possibleNameForVarDecl);
     }
-    function getCompletionsAtPosition2(fileName, position, options = emptyOptions, formattingSettings) {
-      const fullPreferences = {
-        ...identity(options),
-        // avoid excess property check
-        includeCompletionsForModuleExports: options.includeCompletionsForModuleExports || options.includeExternalModuleExports,
-        includeCompletionsWithInsertText: options.includeCompletionsWithInsertText || options.includeInsertTextCompletions
-      };
-      synchronizeHostData();
-      return ts_Completions_exports.getCompletionsAtPosition(
-        host,
-        program,
-        log,
-        getValidSourceFile(fileName),
-        position,
-        fullPreferences,
-        options.triggerCharacter,
-        options.triggerKind,
-        cancellationToken,
-        formattingSettings && ts_formatting_exports.getFormatContext(formattingSettings, host),
-        options.includeSymbol
+    return possibleNameForVarDecl;
+  }
+  function finishCatchOrFinallyTransform(node, transformer, tryStatement, possibleNameForVarDecl, continuationArgName) {
+    const statements = [];
+    let varDeclIdentifier;
+    if (possibleNameForVarDecl && !shouldReturn(node, transformer)) {
+      varDeclIdentifier = getSynthesizedDeepClone(declareSynthIdentifier(possibleNameForVarDecl));
+      const typeArray = possibleNameForVarDecl.types;
+      const unionType = transformer.checker.getUnionType(typeArray, 2 /* Subtype */);
+      const unionTypeNode = transformer.isInJSFile ? void 0 : transformer.checker.typeToTypeNode(
+        unionType,
+        /*enclosingDeclaration*/
+        void 0,
+        /*flags*/
+        void 0
       );
-    }
-    function getCompletionEntryDetails2(fileName, position, name, formattingOptions, source, preferences = emptyOptions, data) {
-      synchronizeHostData();
-      return ts_Completions_exports.getCompletionEntryDetails(
-        program,
-        log,
-        getValidSourceFile(fileName),
-        position,
-        { name, source, data },
-        host,
-        formattingOptions && ts_formatting_exports.getFormatContext(formattingOptions, host),
-        // TODO: GH#18217
-        preferences,
-        cancellationToken
+      const varDecl = [factory.createVariableDeclaration(
+        varDeclIdentifier,
+        /*exclamationToken*/
+        void 0,
+        unionTypeNode
+      )];
+      const varDeclList = factory.createVariableStatement(
+        /*modifiers*/
+        void 0,
+        factory.createVariableDeclarationList(varDecl, 1 /* Let */)
       );
+      statements.push(varDeclList);
     }
-    function getCompletionEntrySymbol2(fileName, position, name, source, preferences = emptyOptions) {
-      synchronizeHostData();
-      return ts_Completions_exports.getCompletionEntrySymbol(program, log, getValidSourceFile(fileName), position, { name, source }, host, preferences);
+    statements.push(tryStatement);
+    if (continuationArgName && varDeclIdentifier && isSynthBindingPattern(continuationArgName)) {
+      statements.push(factory.createVariableStatement(
+        /*modifiers*/
+        void 0,
+        factory.createVariableDeclarationList([
+          factory.createVariableDeclaration(
+            getSynthesizedDeepClone(declareSynthBindingPattern(continuationArgName)),
+            /*exclamationToken*/
+            void 0,
+            /*type*/
+            void 0,
+            varDeclIdentifier
+          )
+        ], 2 /* Const */)
+      ));
     }
-    function getQuickInfoAtPosition(fileName, position) {
-      synchronizeHostData();
-      const sourceFile = getValidSourceFile(fileName);
-      const node = getTouchingPropertyName(sourceFile, position);
-      if (node === sourceFile) {
-        return void 0;
-      }
-      const typeChecker = program.getTypeChecker();
-      const nodeForQuickInfo = getNodeForQuickInfo(node);
-      const symbol = getSymbolAtLocationForQuickInfo(nodeForQuickInfo, typeChecker);
-      if (!symbol || typeChecker.isUnknownSymbol(symbol)) {
-        const type = shouldGetType(sourceFile, nodeForQuickInfo, position) ? typeChecker.getTypeAtLocation(nodeForQuickInfo) : void 0;
-        return type && {
-          kind: "" /* unknown */,
-          kindModifiers: "" /* none */,
-          textSpan: createTextSpanFromNode(nodeForQuickInfo, sourceFile),
-          displayParts: typeChecker.runWithCancellationToken(cancellationToken, (typeChecker2) => typeToDisplayParts(typeChecker2, type, getContainerNode(nodeForQuickInfo))),
-          documentation: type.symbol ? type.symbol.getDocumentationComment(typeChecker) : void 0,
-          tags: type.symbol ? type.symbol.getJsDocTags(typeChecker) : void 0
-        };
-      }
-      const { symbolKind, displayParts, documentation, tags } = typeChecker.runWithCancellationToken(
-        cancellationToken,
-        (typeChecker2) => ts_SymbolDisplay_exports.getSymbolDisplayPartsDocumentationAndSymbolKind(typeChecker2, symbol, sourceFile, getContainerNode(nodeForQuickInfo), nodeForQuickInfo)
+    return statements;
+  }
+  function transformFinally(node, onFinally, transformer, hasContinuation, continuationArgName) {
+    if (!onFinally || isNullOrUndefined2(transformer, onFinally)) {
+      return transformExpression(
+        /* returnContextNode */
+        node,
+        node.expression.expression,
+        transformer,
+        hasContinuation,
+        continuationArgName
       );
-      return {
-        kind: symbolKind,
-        kindModifiers: ts_SymbolDisplay_exports.getSymbolModifiers(typeChecker, symbol),
-        textSpan: createTextSpanFromNode(nodeForQuickInfo, sourceFile),
-        displayParts,
-        documentation,
-        tags
-      };
     }
-    function getNodeForQuickInfo(node) {
-      if (isNewExpression(node.parent) && node.pos === node.parent.pos) {
-        return node.parent.expression;
-      }
-      if (isNamedTupleMember(node.parent) && node.pos === node.parent.pos) {
-        return node.parent;
-      }
-      if (isImportMeta(node.parent) && node.parent.name === node) {
-        return node.parent;
-      }
-      if (isJsxNamespacedName(node.parent)) {
-        return node.parent;
-      }
-      return node;
+    const possibleNameForVarDecl = getPossibleNameForVarDecl(node, transformer, continuationArgName);
+    const inlinedLeftHandSide = transformExpression(
+      /*returnContextNode*/
+      node,
+      node.expression.expression,
+      transformer,
+      /*hasContinuation*/
+      true,
+      possibleNameForVarDecl
+    );
+    if (hasFailed())
+      return silentFail();
+    const inlinedCallback = transformCallbackArgument(
+      onFinally,
+      hasContinuation,
+      /*continuationArgName*/
+      void 0,
+      /*inputArgName*/
+      void 0,
+      node,
+      transformer
+    );
+    if (hasFailed())
+      return silentFail();
+    const tryBlock = factory.createBlock(inlinedLeftHandSide);
+    const finallyBlock = factory.createBlock(inlinedCallback);
+    const tryStatement = factory.createTryStatement(
+      tryBlock,
+      /*catchClause*/
+      void 0,
+      finallyBlock
+    );
+    return finishCatchOrFinallyTransform(node, transformer, tryStatement, possibleNameForVarDecl, continuationArgName);
+  }
+  function transformCatch(node, onRejected, transformer, hasContinuation, continuationArgName) {
+    if (!onRejected || isNullOrUndefined2(transformer, onRejected)) {
+      return transformExpression(
+        /* returnContextNode */
+        node,
+        node.expression.expression,
+        transformer,
+        hasContinuation,
+        continuationArgName
+      );
     }
-    function shouldGetType(sourceFile, node, position) {
-      switch (node.kind) {
-        case 80 /* Identifier */:
-          return !isLabelName(node) && !isTagName(node) && !isConstTypeReference(node.parent);
-        case 210 /* PropertyAccessExpression */:
-        case 165 /* QualifiedName */:
-          return !isInComment(sourceFile, position);
-        case 110 /* ThisKeyword */:
-        case 196 /* ThisType */:
-        case 108 /* SuperKeyword */:
-        case 201 /* NamedTupleMember */:
-          return true;
-        case 235 /* MetaProperty */:
-          return isImportMeta(node);
-        default:
-          return false;
-      }
+    const inputArgName = getArgBindingName(onRejected, transformer);
+    const possibleNameForVarDecl = getPossibleNameForVarDecl(node, transformer, continuationArgName);
+    const inlinedLeftHandSide = transformExpression(
+      /*returnContextNode*/
+      node,
+      node.expression.expression,
+      transformer,
+      /*hasContinuation*/
+      true,
+      possibleNameForVarDecl
+    );
+    if (hasFailed())
+      return silentFail();
+    const inlinedCallback = transformCallbackArgument(onRejected, hasContinuation, possibleNameForVarDecl, inputArgName, node, transformer);
+    if (hasFailed())
+      return silentFail();
+    const tryBlock = factory.createBlock(inlinedLeftHandSide);
+    const catchClause = factory.createCatchClause(inputArgName && getSynthesizedDeepClone(declareSynthBindingName(inputArgName)), factory.createBlock(inlinedCallback));
+    const tryStatement = factory.createTryStatement(
+      tryBlock,
+      catchClause,
+      /*finallyBlock*/
+      void 0
+    );
+    return finishCatchOrFinallyTransform(node, transformer, tryStatement, possibleNameForVarDecl, continuationArgName);
+  }
+  function transformThen(node, onFulfilled, onRejected, transformer, hasContinuation, continuationArgName) {
+    if (!onFulfilled || isNullOrUndefined2(transformer, onFulfilled)) {
+      return transformCatch(node, onRejected, transformer, hasContinuation, continuationArgName);
     }
-    function getDefinitionAtPosition2(fileName, position, searchOtherFilesOnly, stopAtAlias) {
-      synchronizeHostData();
-      return ts_GoToDefinition_exports.getDefinitionAtPosition(program, getValidSourceFile(fileName), position, searchOtherFilesOnly, stopAtAlias);
+    if (onRejected && !isNullOrUndefined2(transformer, onRejected)) {
+      return silentFail();
     }
-    function getDefinitionAndBoundSpan2(fileName, position) {
-      synchronizeHostData();
-      return ts_GoToDefinition_exports.getDefinitionAndBoundSpan(program, getValidSourceFile(fileName), position);
+    const inputArgName = getArgBindingName(onFulfilled, transformer);
+    const inlinedLeftHandSide = transformExpression(
+      node.expression.expression,
+      node.expression.expression,
+      transformer,
+      /*hasContinuation*/
+      true,
+      inputArgName
+    );
+    if (hasFailed())
+      return silentFail();
+    const inlinedCallback = transformCallbackArgument(onFulfilled, hasContinuation, continuationArgName, inputArgName, node, transformer);
+    if (hasFailed())
+      return silentFail();
+    return concatenate(inlinedLeftHandSide, inlinedCallback);
+  }
+  function transformPromiseExpressionOfPropertyAccess(returnContextNode, node, transformer, hasContinuation, continuationArgName) {
+    if (shouldReturn(returnContextNode, transformer)) {
+      let returnValue = getSynthesizedDeepClone(node);
+      if (hasContinuation) {
+        returnValue = factory.createAwaitExpression(returnValue);
+      }
+      return [factory.createReturnStatement(returnValue)];
     }
-    function getTypeDefinitionAtPosition2(fileName, position) {
-      synchronizeHostData();
-      return ts_GoToDefinition_exports.getTypeDefinitionAtPosition(program.getTypeChecker(), getValidSourceFile(fileName), position);
+    return createVariableOrAssignmentOrExpressionStatement(
+      continuationArgName,
+      factory.createAwaitExpression(node),
+      /*typeAnnotation*/
+      void 0
+    );
+  }
+  function createVariableOrAssignmentOrExpressionStatement(variableName, rightHandSide, typeAnnotation) {
+    if (!variableName || isEmptyBindingName(variableName)) {
+      return [factory.createExpressionStatement(rightHandSide)];
     }
-    function getImplementationAtPosition(fileName, position) {
-      synchronizeHostData();
-      return ts_FindAllReferences_exports.getImplementationsAtPosition(program, cancellationToken, program.getSourceFiles(), getValidSourceFile(fileName), position);
+    if (isSynthIdentifier(variableName) && variableName.hasBeenDeclared) {
+      return [factory.createExpressionStatement(factory.createAssignment(getSynthesizedDeepClone(referenceSynthIdentifier(variableName)), rightHandSide))];
     }
-    function getDocumentHighlights(fileName, position, filesToSearch) {
-      const normalizedFileName = normalizePath(fileName);
-      Debug.assert(filesToSearch.some((f) => normalizePath(f) === normalizedFileName));
-      synchronizeHostData();
-      const sourceFilesToSearch = mapDefined(filesToSearch, (fileName2) => program.getSourceFile(fileName2));
-      const sourceFile = getValidSourceFile(fileName);
-      return DocumentHighlights.getDocumentHighlights(program, cancellationToken, sourceFile, position, sourceFilesToSearch);
+    return [
+      factory.createVariableStatement(
+        /*modifiers*/
+        void 0,
+        factory.createVariableDeclarationList([
+          factory.createVariableDeclaration(
+            getSynthesizedDeepClone(declareSynthBindingName(variableName)),
+            /*exclamationToken*/
+            void 0,
+            typeAnnotation,
+            rightHandSide
+          )
+        ], 2 /* Const */)
+      )
+    ];
+  }
+  function maybeAnnotateAndReturn(expressionToReturn, typeAnnotation) {
+    if (typeAnnotation && expressionToReturn) {
+      const name = factory.createUniqueName("result", 16 /* Optimistic */);
+      return [
+        ...createVariableOrAssignmentOrExpressionStatement(createSynthIdentifier(name), expressionToReturn, typeAnnotation),
+        factory.createReturnStatement(name)
+      ];
     }
-    function findRenameLocations(fileName, position, findInStrings, findInComments, preferences) {
-      synchronizeHostData();
-      const sourceFile = getValidSourceFile(fileName);
-      const node = getAdjustedRenameLocation(getTouchingPropertyName(sourceFile, position));
-      if (!ts_Rename_exports.nodeIsEligibleForRename(node))
-        return void 0;
-      if (isIdentifier(node) && (isJsxOpeningElement(node.parent) || isJsxClosingElement(node.parent)) && isIntrinsicJsxName(node.escapedText)) {
-        const { openingElement, closingElement } = node.parent.parent;
-        return [openingElement, closingElement].map((node2) => {
-          const textSpan = createTextSpanFromNode(node2.tagName, sourceFile);
-          return {
-            fileName: sourceFile.fileName,
-            textSpan,
-            ...ts_FindAllReferences_exports.toContextSpan(textSpan, sourceFile, node2.parent)
-          };
-        });
-      } else {
-        const quotePreference = getQuotePreference(sourceFile, preferences ?? emptyOptions);
-        const providePrefixAndSuffixTextForRename = typeof preferences === "boolean" ? preferences : preferences == null ? void 0 : preferences.providePrefixAndSuffixTextForRename;
-        return getReferencesWorker(
-          node,
-          position,
-          { findInStrings, findInComments, providePrefixAndSuffixTextForRename, use: ts_FindAllReferences_exports.FindReferencesUse.Rename },
-          (entry, originalNode, checker) => ts_FindAllReferences_exports.toRenameLocation(entry, originalNode, checker, providePrefixAndSuffixTextForRename || false, quotePreference)
+    return [factory.createReturnStatement(expressionToReturn)];
+  }
+  function transformCallbackArgument(func, hasContinuation, continuationArgName, inputArgName, parent2, transformer) {
+    var _a;
+    switch (func.kind) {
+      case 106 /* NullKeyword */:
+        break;
+      case 211 /* PropertyAccessExpression */:
+      case 80 /* Identifier */:
+        if (!inputArgName) {
+          break;
+        }
+        const synthCall = factory.createCallExpression(
+          getSynthesizedDeepClone(func),
+          /*typeArguments*/
+          void 0,
+          isSynthIdentifier(inputArgName) ? [referenceSynthIdentifier(inputArgName)] : []
         );
+        if (shouldReturn(parent2, transformer)) {
+          return maybeAnnotateAndReturn(synthCall, getExplicitPromisedTypeOfPromiseReturningCallExpression(parent2, func, transformer.checker));
+        }
+        const type = transformer.checker.getTypeAtLocation(func);
+        const callSignatures = transformer.checker.getSignaturesOfType(type, 0 /* Call */);
+        if (!callSignatures.length) {
+          return silentFail();
+        }
+        const returnType = callSignatures[0].getReturnType();
+        const varDeclOrAssignment = createVariableOrAssignmentOrExpressionStatement(continuationArgName, factory.createAwaitExpression(synthCall), getExplicitPromisedTypeOfPromiseReturningCallExpression(parent2, func, transformer.checker));
+        if (continuationArgName) {
+          continuationArgName.types.push(transformer.checker.getAwaitedType(returnType) || returnType);
+        }
+        return varDeclOrAssignment;
+      case 218 /* FunctionExpression */:
+      case 219 /* ArrowFunction */: {
+        const funcBody = func.body;
+        const returnType2 = (_a = getLastCallSignature(transformer.checker.getTypeAtLocation(func), transformer.checker)) == null ? void 0 : _a.getReturnType();
+        if (isBlock(funcBody)) {
+          let refactoredStmts = [];
+          let seenReturnStatement = false;
+          for (const statement of funcBody.statements) {
+            if (isReturnStatement(statement)) {
+              seenReturnStatement = true;
+              if (isReturnStatementWithFixablePromiseHandler(statement, transformer.checker)) {
+                refactoredStmts = refactoredStmts.concat(transformReturnStatementWithFixablePromiseHandler(transformer, statement, hasContinuation, continuationArgName));
+              } else {
+                const possiblyAwaitedRightHandSide = returnType2 && statement.expression ? getPossiblyAwaitedRightHandSide(transformer.checker, returnType2, statement.expression) : statement.expression;
+                refactoredStmts.push(...maybeAnnotateAndReturn(possiblyAwaitedRightHandSide, getExplicitPromisedTypeOfPromiseReturningCallExpression(parent2, func, transformer.checker)));
+              }
+            } else if (hasContinuation && forEachReturnStatement(statement, returnTrue)) {
+              return silentFail();
+            } else {
+              refactoredStmts.push(statement);
+            }
+          }
+          return shouldReturn(parent2, transformer) ? refactoredStmts.map((s) => getSynthesizedDeepClone(s)) : removeReturns(
+            refactoredStmts,
+            continuationArgName,
+            transformer,
+            seenReturnStatement
+          );
+        } else {
+          const inlinedStatements = isFixablePromiseHandler(funcBody, transformer.checker) ? transformReturnStatementWithFixablePromiseHandler(transformer, factory.createReturnStatement(funcBody), hasContinuation, continuationArgName) : emptyArray;
+          if (inlinedStatements.length > 0) {
+            return inlinedStatements;
+          }
+          if (returnType2) {
+            const possiblyAwaitedRightHandSide = getPossiblyAwaitedRightHandSide(transformer.checker, returnType2, funcBody);
+            if (!shouldReturn(parent2, transformer)) {
+              const transformedStatement = createVariableOrAssignmentOrExpressionStatement(
+                continuationArgName,
+                possiblyAwaitedRightHandSide,
+                /*typeAnnotation*/
+                void 0
+              );
+              if (continuationArgName) {
+                continuationArgName.types.push(transformer.checker.getAwaitedType(returnType2) || returnType2);
+              }
+              return transformedStatement;
+            } else {
+              return maybeAnnotateAndReturn(possiblyAwaitedRightHandSide, getExplicitPromisedTypeOfPromiseReturningCallExpression(parent2, func, transformer.checker));
+            }
+          } else {
+            return silentFail();
+          }
+        }
       }
+      default:
+        return silentFail();
     }
-    function getReferencesAtPosition(fileName, position) {
-      synchronizeHostData();
-      return getReferencesWorker(getTouchingPropertyName(getValidSourceFile(fileName), position), position, { use: ts_FindAllReferences_exports.FindReferencesUse.References }, ts_FindAllReferences_exports.toReferenceEntry);
-    }
-    function getReferencesWorker(node, position, options, cb) {
-      synchronizeHostData();
-      const sourceFiles = options && options.use === ts_FindAllReferences_exports.FindReferencesUse.Rename ? program.getSourceFiles().filter((sourceFile) => !program.isSourceFileDefaultLibrary(sourceFile)) : program.getSourceFiles();
-      return ts_FindAllReferences_exports.findReferenceOrRenameEntries(program, cancellationToken, sourceFiles, node, position, options, cb);
-    }
-    function findReferences(fileName, position) {
-      synchronizeHostData();
-      return ts_FindAllReferences_exports.findReferencedSymbols(program, cancellationToken, program.getSourceFiles(), getValidSourceFile(fileName), position);
-    }
-    function getFileReferences(fileName) {
-      synchronizeHostData();
-      return ts_FindAllReferences_exports.Core.getReferencesForFileName(fileName, program, program.getSourceFiles()).map(ts_FindAllReferences_exports.toReferenceEntry);
-    }
-    function getNavigateToItems2(searchValue, maxResultCount, fileName, excludeDtsFiles = false) {
-      synchronizeHostData();
-      const sourceFiles = fileName ? [getValidSourceFile(fileName)] : program.getSourceFiles();
-      return getNavigateToItems(sourceFiles, program.getTypeChecker(), cancellationToken, searchValue, maxResultCount, excludeDtsFiles);
-    }
-    function getEmitOutput(fileName, emitOnlyDtsFiles, forceDtsEmit) {
-      synchronizeHostData();
-      const sourceFile = getValidSourceFile(fileName);
-      const customTransformers = host.getCustomTransformers && host.getCustomTransformers();
-      return getFileEmitOutput(program, sourceFile, !!emitOnlyDtsFiles, cancellationToken, customTransformers, forceDtsEmit);
-    }
-    function getSignatureHelpItems2(fileName, position, { triggerReason } = emptyOptions) {
-      synchronizeHostData();
-      const sourceFile = getValidSourceFile(fileName);
-      return ts_SignatureHelp_exports.getSignatureHelpItems(program, sourceFile, position, triggerReason, cancellationToken);
-    }
-    function getNonBoundSourceFile(fileName) {
-      return syntaxTreeCache.getCurrentSourceFile(fileName);
-    }
-    function getNameOrDottedNameSpan(fileName, startPos, _endPos) {
-      const sourceFile = syntaxTreeCache.getCurrentSourceFile(fileName);
-      const node = getTouchingPropertyName(sourceFile, startPos);
-      if (node === sourceFile) {
-        return void 0;
-      }
-      switch (node.kind) {
-        case 210 /* PropertyAccessExpression */:
-        case 165 /* QualifiedName */:
-        case 11 /* StringLiteral */:
-        case 97 /* FalseKeyword */:
-        case 112 /* TrueKeyword */:
-        case 106 /* NullKeyword */:
-        case 108 /* SuperKeyword */:
-        case 110 /* ThisKeyword */:
-        case 196 /* ThisType */:
-        case 80 /* Identifier */:
-          break;
-        default:
-          return void 0;
-      }
-      let nodeForStartPos = node;
-      while (true) {
-        if (isRightSideOfPropertyAccess(nodeForStartPos) || isRightSideOfQualifiedName(nodeForStartPos)) {
-          nodeForStartPos = nodeForStartPos.parent;
-        } else if (isNameOfModuleDeclaration(nodeForStartPos)) {
-          if (nodeForStartPos.parent.parent.kind === 266 /* ModuleDeclaration */ && nodeForStartPos.parent.parent.body === nodeForStartPos.parent) {
-            nodeForStartPos = nodeForStartPos.parent.parent.name;
+    return emptyArray;
+  }
+  function getPossiblyAwaitedRightHandSide(checker, type, expr) {
+    const rightHandSide = getSynthesizedDeepClone(expr);
+    return !!checker.getPromisedTypeOfPromise(type) ? factory.createAwaitExpression(rightHandSide) : rightHandSide;
+  }
+  function getLastCallSignature(type, checker) {
+    const callSignatures = checker.getSignaturesOfType(type, 0 /* Call */);
+    return lastOrUndefined(callSignatures);
+  }
+  function removeReturns(stmts, prevArgName, transformer, seenReturnStatement) {
+    const ret = [];
+    for (const stmt of stmts) {
+      if (isReturnStatement(stmt)) {
+        if (stmt.expression) {
+          const possiblyAwaitedExpression = isPromiseTypedExpression(stmt.expression, transformer.checker) ? factory.createAwaitExpression(stmt.expression) : stmt.expression;
+          if (prevArgName === void 0) {
+            ret.push(factory.createExpressionStatement(possiblyAwaitedExpression));
+          } else if (isSynthIdentifier(prevArgName) && prevArgName.hasBeenDeclared) {
+            ret.push(factory.createExpressionStatement(factory.createAssignment(referenceSynthIdentifier(prevArgName), possiblyAwaitedExpression)));
           } else {
-            break;
+            ret.push(factory.createVariableStatement(
+              /*modifiers*/
+              void 0,
+              factory.createVariableDeclarationList([factory.createVariableDeclaration(
+                declareSynthBindingName(prevArgName),
+                /*exclamationToken*/
+                void 0,
+                /*type*/
+                void 0,
+                possiblyAwaitedExpression
+              )], 2 /* Const */)
+            ));
           }
-        } else {
-          break;
         }
+      } else {
+        ret.push(getSynthesizedDeepClone(stmt));
       }
-      return createTextSpanFromBounds(nodeForStartPos.getStart(), node.getEnd());
-    }
-    function getBreakpointStatementAtPosition(fileName, position) {
-      const sourceFile = syntaxTreeCache.getCurrentSourceFile(fileName);
-      return ts_BreakpointResolver_exports.spanInSourceFileAtLocation(sourceFile, position);
-    }
-    function getNavigationBarItems2(fileName) {
-      return getNavigationBarItems(syntaxTreeCache.getCurrentSourceFile(fileName), cancellationToken);
     }
-    function getNavigationTree2(fileName) {
-      return getNavigationTree(syntaxTreeCache.getCurrentSourceFile(fileName), cancellationToken);
+    if (!seenReturnStatement && prevArgName !== void 0) {
+      ret.push(factory.createVariableStatement(
+        /*modifiers*/
+        void 0,
+        factory.createVariableDeclarationList([factory.createVariableDeclaration(
+          declareSynthBindingName(prevArgName),
+          /*exclamationToken*/
+          void 0,
+          /*type*/
+          void 0,
+          factory.createIdentifier("undefined")
+        )], 2 /* Const */)
+      ));
     }
-    function getSemanticClassifications3(fileName, span, format) {
-      synchronizeHostData();
-      const responseFormat = format || "original" /* Original */;
-      if (responseFormat === "2020" /* TwentyTwenty */) {
-        return getSemanticClassifications2(program, cancellationToken, getValidSourceFile(fileName), span);
-      } else {
-        return getSemanticClassifications(program.getTypeChecker(), cancellationToken, getValidSourceFile(fileName), program.getClassifiableNames(), span);
+    return ret;
+  }
+  function transformReturnStatementWithFixablePromiseHandler(transformer, innerRetStmt, hasContinuation, continuationArgName) {
+    let innerCbBody = [];
+    forEachChild(innerRetStmt, function visit(node) {
+      if (isCallExpression(node)) {
+        const temp = transformExpression(node, node, transformer, hasContinuation, continuationArgName);
+        innerCbBody = innerCbBody.concat(temp);
+        if (innerCbBody.length > 0) {
+          return;
+        }
+      } else if (!isFunctionLike(node)) {
+        forEachChild(node, visit);
       }
-    }
-    function getEncodedSemanticClassifications3(fileName, span, format) {
-      synchronizeHostData();
-      const responseFormat = format || "original" /* Original */;
-      if (responseFormat === "original" /* Original */) {
-        return getEncodedSemanticClassifications(program.getTypeChecker(), cancellationToken, getValidSourceFile(fileName), program.getClassifiableNames(), span);
-      } else {
-        return getEncodedSemanticClassifications2(program, cancellationToken, getValidSourceFile(fileName), span);
+    });
+    return innerCbBody;
+  }
+  function getArgBindingName(funcNode, transformer) {
+    const types = [];
+    let name;
+    if (isFunctionLikeDeclaration(funcNode)) {
+      if (funcNode.parameters.length > 0) {
+        const param = funcNode.parameters[0].name;
+        name = getMappedBindingNameOrDefault(param);
       }
+    } else if (isIdentifier(funcNode)) {
+      name = getMapEntryOrDefault(funcNode);
+    } else if (isPropertyAccessExpression(funcNode) && isIdentifier(funcNode.name)) {
+      name = getMapEntryOrDefault(funcNode.name);
     }
-    function getSyntacticClassifications2(fileName, span) {
-      return getSyntacticClassifications(cancellationToken, syntaxTreeCache.getCurrentSourceFile(fileName), span);
+    if (!name || "identifier" in name && name.identifier.text === "undefined") {
+      return void 0;
     }
-    function getEncodedSyntacticClassifications2(fileName, span) {
-      return getEncodedSyntacticClassifications(cancellationToken, syntaxTreeCache.getCurrentSourceFile(fileName), span);
+    return name;
+    function getMappedBindingNameOrDefault(bindingName) {
+      if (isIdentifier(bindingName))
+        return getMapEntryOrDefault(bindingName);
+      const elements = flatMap(bindingName.elements, (element) => {
+        if (isOmittedExpression(element))
+          return [];
+        return [getMappedBindingNameOrDefault(element.name)];
+      });
+      return createSynthBindingPattern(bindingName, elements);
     }
-    function getOutliningSpans(fileName) {
-      const sourceFile = syntaxTreeCache.getCurrentSourceFile(fileName);
-      return ts_OutliningElementsCollector_exports.collectElements(sourceFile, cancellationToken);
+    function getMapEntryOrDefault(identifier) {
+      const originalNode = getOriginalNode2(identifier);
+      const symbol = getSymbol2(originalNode);
+      if (!symbol) {
+        return createSynthIdentifier(identifier, types);
+      }
+      const mapEntry = transformer.synthNamesMap.get(getSymbolId(symbol).toString());
+      return mapEntry || createSynthIdentifier(identifier, types);
     }
-    const braceMatching = new Map(Object.entries({
-      [19 /* OpenBraceToken */]: 20 /* CloseBraceToken */,
-      [21 /* OpenParenToken */]: 22 /* CloseParenToken */,
-      [23 /* OpenBracketToken */]: 24 /* CloseBracketToken */,
-      [32 /* GreaterThanToken */]: 30 /* LessThanToken */
-    }));
-    braceMatching.forEach((value, key) => braceMatching.set(value.toString(), Number(key)));
-    function getBraceMatchingAtPosition(fileName, position) {
-      const sourceFile = syntaxTreeCache.getCurrentSourceFile(fileName);
-      const token = getTouchingToken(sourceFile, position);
-      const matchKind = token.getStart(sourceFile) === position ? braceMatching.get(token.kind.toString()) : void 0;
-      const match = matchKind && findChildOfKind(token.parent, matchKind, sourceFile);
-      return match ? [createTextSpanFromNode(token, sourceFile), createTextSpanFromNode(match, sourceFile)].sort((a, b) => a.start - b.start) : emptyArray;
+    function getSymbol2(node) {
+      var _a;
+      return ((_a = tryCast(node, canHaveSymbol)) == null ? void 0 : _a.symbol) ?? transformer.checker.getSymbolAtLocation(node);
     }
-    function getIndentationAtPosition(fileName, position, editorOptions) {
-      let start = timestamp();
-      const settings = toEditorSettings(editorOptions);
-      const sourceFile = syntaxTreeCache.getCurrentSourceFile(fileName);
-      log("getIndentationAtPosition: getCurrentSourceFile: " + (timestamp() - start));
-      start = timestamp();
-      const result = ts_formatting_exports.SmartIndenter.getIndentation(position, sourceFile, settings);
-      log("getIndentationAtPosition: computeIndentation  : " + (timestamp() - start));
-      return result;
+    function getOriginalNode2(node) {
+      return node.original ? node.original : node;
     }
-    function getFormattingEditsForRange(fileName, start, end, options) {
-      const sourceFile = syntaxTreeCache.getCurrentSourceFile(fileName);
-      return ts_formatting_exports.formatSelection(start, end, sourceFile, ts_formatting_exports.getFormatContext(toEditorSettings(options), host));
+  }
+  function isEmptyBindingName(bindingName) {
+    if (!bindingName) {
+      return true;
     }
-    function getFormattingEditsForDocument(fileName, options) {
-      return ts_formatting_exports.formatDocument(syntaxTreeCache.getCurrentSourceFile(fileName), ts_formatting_exports.getFormatContext(toEditorSettings(options), host));
+    if (isSynthIdentifier(bindingName)) {
+      return !bindingName.identifier.text;
     }
-    function getFormattingEditsAfterKeystroke(fileName, position, key, options) {
-      const sourceFile = syntaxTreeCache.getCurrentSourceFile(fileName);
-      const formatContext = ts_formatting_exports.getFormatContext(toEditorSettings(options), host);
-      if (!isInComment(sourceFile, position)) {
-        switch (key) {
-          case "{":
-            return ts_formatting_exports.formatOnOpeningCurly(position, sourceFile, formatContext);
-          case "}":
-            return ts_formatting_exports.formatOnClosingCurly(position, sourceFile, formatContext);
-          case ";":
-            return ts_formatting_exports.formatOnSemicolon(position, sourceFile, formatContext);
-          case "\n":
-            return ts_formatting_exports.formatOnEnter(position, sourceFile, formatContext);
-        }
-      }
-      return [];
+    return every(bindingName.elements, isEmptyBindingName);
+  }
+  function createSynthIdentifier(identifier, types = []) {
+    return { kind: 0 /* Identifier */, identifier, types, hasBeenDeclared: false, hasBeenReferenced: false };
+  }
+  function createSynthBindingPattern(bindingPattern, elements = emptyArray, types = []) {
+    return { kind: 1 /* BindingPattern */, bindingPattern, elements, types };
+  }
+  function referenceSynthIdentifier(synthId) {
+    synthId.hasBeenReferenced = true;
+    return synthId.identifier;
+  }
+  function declareSynthBindingName(synthName) {
+    return isSynthIdentifier(synthName) ? declareSynthIdentifier(synthName) : declareSynthBindingPattern(synthName);
+  }
+  function declareSynthBindingPattern(synthPattern) {
+    for (const element of synthPattern.elements) {
+      declareSynthBindingName(element);
     }
-    function getCodeFixesAtPosition(fileName, start, end, errorCodes64, formatOptions, preferences = emptyOptions) {
-      synchronizeHostData();
-      const sourceFile = getValidSourceFile(fileName);
-      const span = createTextSpanFromBounds(start, end);
-      const formatContext = ts_formatting_exports.getFormatContext(formatOptions, host);
-      return flatMap(deduplicate(errorCodes64, equateValues, compareValues), (errorCode) => {
-        cancellationToken.throwIfCancellationRequested();
-        return ts_codefix_exports.getFixes({ errorCode, sourceFile, span, program, host, cancellationToken, formatContext, preferences });
+    return synthPattern.bindingPattern;
+  }
+  function declareSynthIdentifier(synthId) {
+    synthId.hasBeenDeclared = true;
+    return synthId.identifier;
+  }
+  function isSynthIdentifier(bindingName) {
+    return bindingName.kind === 0 /* Identifier */;
+  }
+  function isSynthBindingPattern(bindingName) {
+    return bindingName.kind === 1 /* BindingPattern */;
+  }
+  function shouldReturn(expression, transformer) {
+    return !!expression.original && transformer.setOfExpressionsToReturn.has(getNodeId(expression.original));
+  }
+  var fixId10, errorCodes11, codeActionSucceeded;
+  var init_convertToAsyncFunction = __esm({
+    "src/services/codefixes/convertToAsyncFunction.ts"() {
+      "use strict";
+      init_ts4();
+      init_ts_codefix();
+      fixId10 = "convertToAsyncFunction";
+      errorCodes11 = [Diagnostics.This_may_be_converted_to_an_async_function.code];
+      codeActionSucceeded = true;
+      registerCodeFix({
+        errorCodes: errorCodes11,
+        getCodeActions(context) {
+          codeActionSucceeded = true;
+          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => convertToAsyncFunction(t, context.sourceFile, context.span.start, context.program.getTypeChecker()));
+          return codeActionSucceeded ? [createCodeFixAction(fixId10, changes, Diagnostics.Convert_to_async_function, fixId10, Diagnostics.Convert_all_to_async_functions)] : [];
+        },
+        fixIds: [fixId10],
+        getAllCodeActions: (context) => codeFixAll(context, errorCodes11, (changes, err) => convertToAsyncFunction(changes, err.file, err.start, context.program.getTypeChecker()))
       });
     }
-    function getCombinedCodeFix(scope, fixId52, formatOptions, preferences = emptyOptions) {
-      synchronizeHostData();
-      Debug.assert(scope.type === "file");
-      const sourceFile = getValidSourceFile(scope.fileName);
-      const formatContext = ts_formatting_exports.getFormatContext(formatOptions, host);
-      return ts_codefix_exports.getAllFixes({ fixId: fixId52, sourceFile, program, host, cancellationToken, formatContext, preferences });
-    }
-    function organizeImports2(args, formatOptions, preferences = emptyOptions) {
-      synchronizeHostData();
-      Debug.assert(args.type === "file");
-      const sourceFile = getValidSourceFile(args.fileName);
-      const formatContext = ts_formatting_exports.getFormatContext(formatOptions, host);
-      const mode = args.mode ?? (args.skipDestructiveCodeActions ? "SortAndCombine" /* SortAndCombine */ : "All" /* All */);
-      return ts_OrganizeImports_exports.organizeImports(sourceFile, formatContext, host, program, preferences, mode);
-    }
-    function getEditsForFileRename2(oldFilePath, newFilePath, formatOptions, preferences = emptyOptions) {
-      return getEditsForFileRename(getProgram(), oldFilePath, newFilePath, host, ts_formatting_exports.getFormatContext(formatOptions, host), preferences, sourceMapper);
-    }
-    function applyCodeActionCommand(fileName, actionOrFormatSettingsOrUndefined) {
-      const action = typeof fileName === "string" ? actionOrFormatSettingsOrUndefined : fileName;
-      return isArray(action) ? Promise.all(action.map((a) => applySingleCodeActionCommand(a))) : applySingleCodeActionCommand(action);
+  });
+
+  // src/services/codefixes/convertToEsModule.ts
+  function fixImportOfModuleExports(importingFile, exportingFile, program, changes, quotePreference) {
+    var _a;
+    for (const moduleSpecifier of importingFile.imports) {
+      const imported = (_a = program.getResolvedModule(importingFile, moduleSpecifier.text, getModeForUsageLocation(importingFile, moduleSpecifier))) == null ? void 0 : _a.resolvedModule;
+      if (!imported || imported.resolvedFileName !== exportingFile.fileName) {
+        continue;
+      }
+      const importNode = importFromModuleSpecifier(moduleSpecifier);
+      switch (importNode.kind) {
+        case 271 /* ImportEqualsDeclaration */:
+          changes.replaceNode(importingFile, importNode, makeImport(
+            importNode.name,
+            /*namedImports*/
+            void 0,
+            moduleSpecifier,
+            quotePreference
+          ));
+          break;
+        case 213 /* CallExpression */:
+          if (isRequireCall(
+            importNode,
+            /*requireStringLiteralLikeArgument*/
+            false
+          )) {
+            changes.replaceNode(importingFile, importNode, factory.createPropertyAccessExpression(getSynthesizedDeepClone(importNode), "default"));
+          }
+          break;
+      }
     }
-    function applySingleCodeActionCommand(action) {
-      const getPath = (path) => toPath(path, currentDirectory, getCanonicalFileName);
-      Debug.assertEqual(action.type, "install package");
-      return host.installPackage ? host.installPackage({ fileName: getPath(action.file), packageName: action.packageName }) : Promise.reject("Host does not implement `installPackage`");
+  }
+  function convertFileToEsModule(sourceFile, checker, changes, target, quotePreference) {
+    const identifiers = { original: collectFreeIdentifiers(sourceFile), additional: /* @__PURE__ */ new Set() };
+    const exports = collectExportRenames(sourceFile, checker, identifiers);
+    convertExportsAccesses(sourceFile, exports, changes);
+    let moduleExportsChangedToDefault = false;
+    let useSitesToUnqualify;
+    for (const statement of filter(sourceFile.statements, isVariableStatement)) {
+      const newUseSites = convertVariableStatement(sourceFile, statement, changes, checker, identifiers, target, quotePreference);
+      if (newUseSites) {
+        copyEntries(newUseSites, useSitesToUnqualify ?? (useSitesToUnqualify = /* @__PURE__ */ new Map()));
+      }
     }
-    function getDocCommentTemplateAtPosition2(fileName, position, options, formatOptions) {
-      const formatSettings = formatOptions ? ts_formatting_exports.getFormatContext(formatOptions, host).options : void 0;
-      return ts_JsDoc_exports.getDocCommentTemplateAtPosition(getNewLineOrDefaultFromHost(host, formatSettings), syntaxTreeCache.getCurrentSourceFile(fileName), position, options);
+    for (const statement of filter(sourceFile.statements, (s) => !isVariableStatement(s))) {
+      const moduleExportsChanged = convertStatement(sourceFile, statement, checker, changes, identifiers, target, exports, useSitesToUnqualify, quotePreference);
+      moduleExportsChangedToDefault = moduleExportsChangedToDefault || moduleExportsChanged;
     }
-    function isValidBraceCompletionAtPosition(fileName, position, openingBrace) {
-      if (openingBrace === 60 /* lessThan */) {
-        return false;
+    useSitesToUnqualify == null ? void 0 : useSitesToUnqualify.forEach((replacement, original) => {
+      changes.replaceNode(sourceFile, original, replacement);
+    });
+    return moduleExportsChangedToDefault;
+  }
+  function collectExportRenames(sourceFile, checker, identifiers) {
+    const res = /* @__PURE__ */ new Map();
+    forEachExportReference(sourceFile, (node) => {
+      const { text } = node.name;
+      if (!res.has(text) && (isIdentifierANonContextualKeyword(node.name) || checker.resolveName(
+        text,
+        node,
+        111551 /* Value */,
+        /*excludeGlobals*/
+        true
+      ))) {
+        res.set(text, makeUniqueName(`_${text}`, identifiers));
       }
-      const sourceFile = syntaxTreeCache.getCurrentSourceFile(fileName);
-      if (isInString(sourceFile, position)) {
-        return false;
+    });
+    return res;
+  }
+  function convertExportsAccesses(sourceFile, exports, changes) {
+    forEachExportReference(sourceFile, (node, isAssignmentLhs) => {
+      if (isAssignmentLhs) {
+        return;
       }
-      if (isInsideJsxElementOrAttribute(sourceFile, position)) {
-        return openingBrace === 123 /* openBrace */;
+      const { text } = node.name;
+      changes.replaceNode(sourceFile, node, factory.createIdentifier(exports.get(text) || text));
+    });
+  }
+  function forEachExportReference(sourceFile, cb) {
+    sourceFile.forEachChild(function recur(node) {
+      if (isPropertyAccessExpression(node) && isExportsOrModuleExportsOrAlias(sourceFile, node.expression) && isIdentifier(node.name)) {
+        const { parent: parent2 } = node;
+        cb(node, isBinaryExpression(parent2) && parent2.left === node && parent2.operatorToken.kind === 64 /* EqualsToken */);
       }
-      if (isInTemplateString(sourceFile, position)) {
+      node.forEachChild(recur);
+    });
+  }
+  function convertStatement(sourceFile, statement, checker, changes, identifiers, target, exports, useSitesToUnqualify, quotePreference) {
+    switch (statement.kind) {
+      case 243 /* VariableStatement */:
+        convertVariableStatement(sourceFile, statement, changes, checker, identifiers, target, quotePreference);
         return false;
-      }
-      switch (openingBrace) {
-        case 39 /* singleQuote */:
-        case 34 /* doubleQuote */:
-        case 96 /* backtick */:
-          return !isInComment(sourceFile, position);
-      }
-      return true;
-    }
-    function getJsxClosingTagAtPosition(fileName, position) {
-      const sourceFile = syntaxTreeCache.getCurrentSourceFile(fileName);
-      const token = findPrecedingToken(position, sourceFile);
-      if (!token)
-        return void 0;
-      const element = token.kind === 32 /* GreaterThanToken */ && isJsxOpeningElement(token.parent) ? token.parent.parent : isJsxText(token) && isJsxElement(token.parent) ? token.parent : void 0;
-      if (element && isUnclosedTag(element)) {
-        return { newText: `` };
-      }
-      const fragment = token.kind === 32 /* GreaterThanToken */ && isJsxOpeningFragment(token.parent) ? token.parent.parent : isJsxText(token) && isJsxFragment(token.parent) ? token.parent : void 0;
-      if (fragment && isUnclosedFragment(fragment)) {
-        return { newText: "" };
-      }
-    }
-    function getLinkedEditingRangeAtPosition(fileName, position) {
-      const sourceFile = syntaxTreeCache.getCurrentSourceFile(fileName);
-      const token = findPrecedingToken(position, sourceFile);
-      if (!token || token.parent.kind === 311 /* SourceFile */)
-        return void 0;
-      const jsxTagWordPattern = "[a-zA-Z0-9:\\-\\._$]*";
-      if (isJsxFragment(token.parent.parent)) {
-        const openFragment = token.parent.parent.openingFragment;
-        const closeFragment = token.parent.parent.closingFragment;
-        if (containsParseError(openFragment) || containsParseError(closeFragment))
-          return void 0;
-        const openPos = openFragment.getStart(sourceFile) + 1;
-        const closePos = closeFragment.getStart(sourceFile) + 2;
-        if (position !== openPos && position !== closePos)
-          return void 0;
-        return {
-          ranges: [{ start: openPos, length: 0 }, { start: closePos, length: 0 }],
-          wordPattern: jsxTagWordPattern
-        };
-      } else {
-        const tag = findAncestor(
-          token.parent,
-          (n) => {
-            if (isJsxOpeningElement(n) || isJsxClosingElement(n)) {
-              return true;
+      case 244 /* ExpressionStatement */: {
+        const { expression } = statement;
+        switch (expression.kind) {
+          case 213 /* CallExpression */: {
+            if (isRequireCall(
+              expression,
+              /*requireStringLiteralLikeArgument*/
+              true
+            )) {
+              changes.replaceNode(sourceFile, statement, makeImport(
+                /*defaultImport*/
+                void 0,
+                /*namedImports*/
+                void 0,
+                expression.arguments[0],
+                quotePreference
+              ));
             }
             return false;
           }
-        );
-        if (!tag)
-          return void 0;
-        Debug.assert(isJsxOpeningElement(tag) || isJsxClosingElement(tag), "tag should be opening or closing element");
-        const openTag = tag.parent.openingElement;
-        const closeTag = tag.parent.closingElement;
-        const openTagStart = openTag.tagName.getStart(sourceFile);
-        const openTagEnd = openTag.tagName.end;
-        const closeTagStart = closeTag.tagName.getStart(sourceFile);
-        const closeTagEnd = closeTag.tagName.end;
-        if (!(openTagStart <= position && position <= openTagEnd || closeTagStart <= position && position <= closeTagEnd))
-          return void 0;
-        const openingTagText = openTag.tagName.getText(sourceFile);
-        if (openingTagText !== closeTag.tagName.getText(sourceFile))
-          return void 0;
-        return {
-          ranges: [{ start: openTagStart, length: openTagEnd - openTagStart }, { start: closeTagStart, length: closeTagEnd - closeTagStart }],
-          wordPattern: jsxTagWordPattern
-        };
-      }
-    }
-    function getLinesForRange(sourceFile, textRange) {
-      return {
-        lineStarts: sourceFile.getLineStarts(),
-        firstLine: sourceFile.getLineAndCharacterOfPosition(textRange.pos).line,
-        lastLine: sourceFile.getLineAndCharacterOfPosition(textRange.end).line
-      };
-    }
-    function toggleLineComment(fileName, textRange, insertComment) {
-      const sourceFile = syntaxTreeCache.getCurrentSourceFile(fileName);
-      const textChanges2 = [];
-      const { lineStarts, firstLine, lastLine } = getLinesForRange(sourceFile, textRange);
-      let isCommenting = insertComment || false;
-      let leftMostPosition = Number.MAX_VALUE;
-      const lineTextStarts = /* @__PURE__ */ new Map();
-      const firstNonWhitespaceCharacterRegex = new RegExp(/\S/);
-      const isJsx = isInsideJsxElement(sourceFile, lineStarts[firstLine]);
-      const openComment = isJsx ? "{/*" : "//";
-      for (let i = firstLine; i <= lastLine; i++) {
-        const lineText = sourceFile.text.substring(lineStarts[i], sourceFile.getLineEndOfPosition(lineStarts[i]));
-        const regExec = firstNonWhitespaceCharacterRegex.exec(lineText);
-        if (regExec) {
-          leftMostPosition = Math.min(leftMostPosition, regExec.index);
-          lineTextStarts.set(i.toString(), regExec.index);
-          if (lineText.substr(regExec.index, openComment.length) !== openComment) {
-            isCommenting = insertComment === void 0 || insertComment;
-          }
-        }
-      }
-      for (let i = firstLine; i <= lastLine; i++) {
-        if (firstLine !== lastLine && lineStarts[i] === textRange.end) {
-          continue;
-        }
-        const lineTextStart = lineTextStarts.get(i.toString());
-        if (lineTextStart !== void 0) {
-          if (isJsx) {
-            textChanges2.push.apply(textChanges2, toggleMultilineComment(fileName, { pos: lineStarts[i] + leftMostPosition, end: sourceFile.getLineEndOfPosition(lineStarts[i]) }, isCommenting, isJsx));
-          } else if (isCommenting) {
-            textChanges2.push({
-              newText: openComment,
-              span: {
-                length: 0,
-                start: lineStarts[i] + leftMostPosition
-              }
-            });
-          } else if (sourceFile.text.substr(lineStarts[i] + lineTextStart, openComment.length) === openComment) {
-            textChanges2.push({
-              newText: "",
-              span: {
-                length: openComment.length,
-                start: lineStarts[i] + lineTextStart
-              }
-            });
+          case 226 /* BinaryExpression */: {
+            const { operatorToken } = expression;
+            return operatorToken.kind === 64 /* EqualsToken */ && convertAssignment(sourceFile, checker, expression, changes, exports, useSitesToUnqualify);
           }
         }
       }
-      return textChanges2;
+      default:
+        return false;
     }
-    function toggleMultilineComment(fileName, textRange, insertComment, isInsideJsx) {
-      var _a2;
-      const sourceFile = syntaxTreeCache.getCurrentSourceFile(fileName);
-      const textChanges2 = [];
-      const { text } = sourceFile;
-      let hasComment = false;
-      let isCommenting = insertComment || false;
-      const positions = [];
-      let { pos } = textRange;
-      const isJsx = isInsideJsx !== void 0 ? isInsideJsx : isInsideJsxElement(sourceFile, pos);
-      const openMultiline = isJsx ? "{/*" : "/*";
-      const closeMultiline = isJsx ? "*/}" : "*/";
-      const openMultilineRegex = isJsx ? "\\{\\/\\*" : "\\/\\*";
-      const closeMultilineRegex = isJsx ? "\\*\\/\\}" : "\\*\\/";
-      while (pos <= textRange.end) {
-        const offset = text.substr(pos, openMultiline.length) === openMultiline ? openMultiline.length : 0;
-        const commentRange = isInComment(sourceFile, pos + offset);
-        if (commentRange) {
-          if (isJsx) {
-            commentRange.pos--;
-            commentRange.end++;
-          }
-          positions.push(commentRange.pos);
-          if (commentRange.kind === 3 /* MultiLineCommentTrivia */) {
-            positions.push(commentRange.end);
-          }
-          hasComment = true;
-          pos = commentRange.end + 1;
-        } else {
-          const newPos = text.substring(pos, textRange.end).search(`(${openMultilineRegex})|(${closeMultilineRegex})`);
-          isCommenting = insertComment !== void 0 ? insertComment : isCommenting || !isTextWhiteSpaceLike(text, pos, newPos === -1 ? textRange.end : pos + newPos);
-          pos = newPos === -1 ? textRange.end + 1 : pos + newPos + closeMultiline.length;
+  }
+  function convertVariableStatement(sourceFile, statement, changes, checker, identifiers, target, quotePreference) {
+    const { declarationList } = statement;
+    let foundImport = false;
+    const converted = map(declarationList.declarations, (decl) => {
+      const { name, initializer } = decl;
+      if (initializer) {
+        if (isExportsOrModuleExportsOrAlias(sourceFile, initializer)) {
+          foundImport = true;
+          return convertedImports([]);
+        } else if (isRequireCall(
+          initializer,
+          /*requireStringLiteralLikeArgument*/
+          true
+        )) {
+          foundImport = true;
+          return convertSingleImport(name, initializer.arguments[0], checker, identifiers, target, quotePreference);
+        } else if (isPropertyAccessExpression(initializer) && isRequireCall(
+          initializer.expression,
+          /*requireStringLiteralLikeArgument*/
+          true
+        )) {
+          foundImport = true;
+          return convertPropertyAccessImport(name, initializer.name.text, initializer.expression.arguments[0], identifiers, quotePreference);
         }
       }
-      if (isCommenting || !hasComment) {
-        if (((_a2 = isInComment(sourceFile, textRange.pos)) == null ? void 0 : _a2.kind) !== 2 /* SingleLineCommentTrivia */) {
-          insertSorted(positions, textRange.pos, compareValues);
-        }
-        insertSorted(positions, textRange.end, compareValues);
-        const firstPos = positions[0];
-        if (text.substr(firstPos, openMultiline.length) !== openMultiline) {
-          textChanges2.push({
-            newText: openMultiline,
-            span: {
-              length: 0,
-              start: firstPos
-            }
-          });
-        }
-        for (let i = 1; i < positions.length - 1; i++) {
-          if (text.substr(positions[i] - closeMultiline.length, closeMultiline.length) !== closeMultiline) {
-            textChanges2.push({
-              newText: closeMultiline,
-              span: {
-                length: 0,
-                start: positions[i]
-              }
-            });
-          }
-          if (text.substr(positions[i], openMultiline.length) !== openMultiline) {
-            textChanges2.push({
-              newText: openMultiline,
-              span: {
-                length: 0,
-                start: positions[i]
-              }
-            });
-          }
-        }
-        if (textChanges2.length % 2 !== 0) {
-          textChanges2.push({
-            newText: closeMultiline,
-            span: {
-              length: 0,
-              start: positions[positions.length - 1]
-            }
-          });
-        }
-      } else {
-        for (const pos2 of positions) {
-          const from = pos2 - closeMultiline.length > 0 ? pos2 - closeMultiline.length : 0;
-          const offset = text.substr(from, closeMultiline.length) === closeMultiline ? closeMultiline.length : 0;
-          textChanges2.push({
-            newText: "",
-            span: {
-              length: openMultiline.length,
-              start: pos2 - offset
-            }
-          });
+      return convertedImports([factory.createVariableStatement(
+        /*modifiers*/
+        void 0,
+        factory.createVariableDeclarationList([decl], declarationList.flags)
+      )]);
+    });
+    if (foundImport) {
+      changes.replaceNodeWithNodes(sourceFile, statement, flatMap(converted, (c) => c.newImports));
+      let combinedUseSites;
+      forEach(converted, (c) => {
+        if (c.useSitesToUnqualify) {
+          copyEntries(c.useSitesToUnqualify, combinedUseSites ?? (combinedUseSites = /* @__PURE__ */ new Map()));
         }
-      }
-      return textChanges2;
-    }
-    function commentSelection(fileName, textRange) {
-      const sourceFile = syntaxTreeCache.getCurrentSourceFile(fileName);
-      const { firstLine, lastLine } = getLinesForRange(sourceFile, textRange);
-      return firstLine === lastLine && textRange.pos !== textRange.end ? toggleMultilineComment(
-        fileName,
-        textRange,
-        /*insertComment*/
-        true
-      ) : toggleLineComment(
-        fileName,
-        textRange,
-        /*insertComment*/
-        true
-      );
+      });
+      return combinedUseSites;
     }
-    function uncommentSelection(fileName, textRange) {
-      const sourceFile = syntaxTreeCache.getCurrentSourceFile(fileName);
-      const textChanges2 = [];
-      const { pos } = textRange;
-      let { end } = textRange;
-      if (pos === end) {
-        end += isInsideJsxElement(sourceFile, pos) ? 2 : 1;
-      }
-      for (let i = pos; i <= end; i++) {
-        const commentRange = isInComment(sourceFile, i);
-        if (commentRange) {
-          switch (commentRange.kind) {
-            case 2 /* SingleLineCommentTrivia */:
-              textChanges2.push.apply(textChanges2, toggleLineComment(
-                fileName,
-                { end: commentRange.end, pos: commentRange.pos + 1 },
-                /*insertComment*/
-                false
-              ));
-              break;
-            case 3 /* MultiLineCommentTrivia */:
-              textChanges2.push.apply(textChanges2, toggleMultilineComment(
-                fileName,
-                { end: commentRange.end, pos: commentRange.pos + 1 },
-                /*insertComment*/
-                false
-              ));
-          }
-          i = commentRange.end + 1;
-        }
+  }
+  function convertPropertyAccessImport(name, propertyName, moduleSpecifier, identifiers, quotePreference) {
+    switch (name.kind) {
+      case 206 /* ObjectBindingPattern */:
+      case 207 /* ArrayBindingPattern */: {
+        const tmp = makeUniqueName(propertyName, identifiers);
+        return convertedImports([
+          makeSingleImport(tmp, propertyName, moduleSpecifier, quotePreference),
+          makeConst(
+            /*modifiers*/
+            void 0,
+            name,
+            factory.createIdentifier(tmp)
+          )
+        ]);
       }
-      return textChanges2;
-    }
-    function isUnclosedTag({ openingElement, closingElement, parent: parent2 }) {
-      return !tagNamesAreEquivalent(openingElement.tagName, closingElement.tagName) || isJsxElement(parent2) && tagNamesAreEquivalent(openingElement.tagName, parent2.openingElement.tagName) && isUnclosedTag(parent2);
-    }
-    function isUnclosedFragment({ closingFragment, parent: parent2 }) {
-      return !!(closingFragment.flags & 131072 /* ThisNodeHasError */) || isJsxFragment(parent2) && isUnclosedFragment(parent2);
+      case 80 /* Identifier */:
+        return convertedImports([makeSingleImport(name.text, propertyName, moduleSpecifier, quotePreference)]);
+      default:
+        return Debug.assertNever(name, `Convert to ES module got invalid syntax form ${name.kind}`);
     }
-    function getSpanOfEnclosingComment(fileName, position, onlyMultiLine) {
-      const sourceFile = syntaxTreeCache.getCurrentSourceFile(fileName);
-      const range = ts_formatting_exports.getRangeOfEnclosingComment(sourceFile, position);
-      return range && (!onlyMultiLine || range.kind === 3 /* MultiLineCommentTrivia */) ? createTextSpanFromRange(range) : void 0;
+  }
+  function convertAssignment(sourceFile, checker, assignment, changes, exports, useSitesToUnqualify) {
+    const { left, right } = assignment;
+    if (!isPropertyAccessExpression(left)) {
+      return false;
     }
-    function getTodoComments(fileName, descriptors) {
-      synchronizeHostData();
-      const sourceFile = getValidSourceFile(fileName);
-      cancellationToken.throwIfCancellationRequested();
-      const fileContents = sourceFile.text;
-      const result = [];
-      if (descriptors.length > 0 && !isNodeModulesFile(sourceFile.fileName)) {
-        const regExp = getTodoCommentsRegExp();
-        let matchArray;
-        while (matchArray = regExp.exec(fileContents)) {
-          cancellationToken.throwIfCancellationRequested();
-          const firstDescriptorCaptureIndex = 3;
-          Debug.assert(matchArray.length === descriptors.length + firstDescriptorCaptureIndex);
-          const preamble = matchArray[1];
-          const matchPosition = matchArray.index + preamble.length;
-          if (!isInComment(sourceFile, matchPosition)) {
-            continue;
-          }
-          let descriptor;
-          for (let i = 0; i < descriptors.length; i++) {
-            if (matchArray[i + firstDescriptorCaptureIndex]) {
-              descriptor = descriptors[i];
-            }
-          }
-          if (descriptor === void 0)
-            return Debug.fail();
-          if (isLetterOrDigit(fileContents.charCodeAt(matchPosition + descriptor.text.length))) {
-            continue;
-          }
-          const message = matchArray[2];
-          result.push({ descriptor, message, position: matchPosition });
+    if (isExportsOrModuleExportsOrAlias(sourceFile, left)) {
+      if (isExportsOrModuleExportsOrAlias(sourceFile, right)) {
+        changes.delete(sourceFile, assignment.parent);
+      } else {
+        const replacement = isObjectLiteralExpression(right) ? tryChangeModuleExportsObject(right, useSitesToUnqualify) : isRequireCall(
+          right,
+          /*requireStringLiteralLikeArgument*/
+          true
+        ) ? convertReExportAll(right.arguments[0], checker) : void 0;
+        if (replacement) {
+          changes.replaceNodeWithNodes(sourceFile, assignment.parent, replacement[0]);
+          return replacement[1];
+        } else {
+          changes.replaceRangeWithText(sourceFile, createRange(left.getStart(sourceFile), right.pos), "export default");
+          return true;
         }
       }
-      return result;
-      function escapeRegExp(str) {
-        return str.replace(/[\-\[\]\/\{\}\(\)\*\+\?\.\\\^\$\|]/g, "\\$&");
-      }
-      function getTodoCommentsRegExp() {
-        const singleLineCommentStart = /(?:\/\/+\s*)/.source;
-        const multiLineCommentStart = /(?:\/\*+\s*)/.source;
-        const anyNumberOfSpacesAndAsterisksAtStartOfLine = /(?:^(?:\s|\*)*)/.source;
-        const preamble = "(" + anyNumberOfSpacesAndAsterisksAtStartOfLine + "|" + singleLineCommentStart + "|" + multiLineCommentStart + ")";
-        const literals = "(?:" + map(descriptors, (d) => "(" + escapeRegExp(d.text) + ")").join("|") + ")";
-        const endOfLineOrEndOfComment = /(?:$|\*\/)/.source;
-        const messageRemainder = /(?:.*?)/.source;
-        const messagePortion = "(" + literals + messageRemainder + ")";
-        const regExpString = preamble + messagePortion + endOfLineOrEndOfComment;
-        return new RegExp(regExpString, "gim");
-      }
-      function isLetterOrDigit(char) {
-        return char >= 97 /* a */ && char <= 122 /* z */ || char >= 65 /* A */ && char <= 90 /* Z */ || char >= 48 /* _0 */ && char <= 57 /* _9 */;
-      }
-      function isNodeModulesFile(path) {
-        return stringContains(path, "/node_modules/");
-      }
-    }
-    function getRenameInfo2(fileName, position, preferences) {
-      synchronizeHostData();
-      return ts_Rename_exports.getRenameInfo(program, getValidSourceFile(fileName), position, preferences || {});
-    }
-    function getRefactorContext(file, positionOrRange, preferences, formatOptions, triggerReason, kind) {
-      const [startPosition, endPosition] = typeof positionOrRange === "number" ? [positionOrRange, void 0] : [positionOrRange.pos, positionOrRange.end];
-      return {
-        file,
-        startPosition,
-        endPosition,
-        program: getProgram(),
-        host,
-        formatContext: ts_formatting_exports.getFormatContext(formatOptions, host),
-        // TODO: GH#18217
-        cancellationToken,
-        preferences,
-        triggerReason,
-        kind
-      };
-    }
-    function getInlayHintsContext(file, span, preferences) {
-      return {
-        file,
-        program: getProgram(),
-        host,
-        span,
-        preferences,
-        cancellationToken
-      };
-    }
-    function getSmartSelectionRange2(fileName, position) {
-      return ts_SmartSelectionRange_exports.getSmartSelectionRange(position, syntaxTreeCache.getCurrentSourceFile(fileName));
-    }
-    function getApplicableRefactors2(fileName, positionOrRange, preferences = emptyOptions, triggerReason, kind, includeInteractiveActions) {
-      synchronizeHostData();
-      const file = getValidSourceFile(fileName);
-      return ts_refactor_exports.getApplicableRefactors(getRefactorContext(file, positionOrRange, preferences, emptyOptions, triggerReason, kind), includeInteractiveActions);
-    }
-    function getMoveToRefactoringFileSuggestions(fileName, positionOrRange, preferences = emptyOptions) {
-      synchronizeHostData();
-      const sourceFile = getValidSourceFile(fileName);
-      const allFiles = Debug.checkDefined(program.getSourceFiles());
-      const extension = extensionFromPath(fileName);
-      const files = mapDefined(allFiles, (file) => !(program == null ? void 0 : program.isSourceFileFromExternalLibrary(sourceFile)) && !(sourceFile === getValidSourceFile(file.fileName) || extension === ".ts" /* Ts */ && extensionFromPath(file.fileName) === ".d.ts" /* Dts */ || extension === ".d.ts" /* Dts */ && startsWith(getBaseFileName(file.fileName), "lib.") && extensionFromPath(file.fileName) === ".d.ts" /* Dts */) && extension === extensionFromPath(file.fileName) ? file.fileName : void 0);
-      const newFileName = createNewFileName(sourceFile, program, getRefactorContext(sourceFile, positionOrRange, preferences, emptyOptions), host);
-      return { newFileName, files };
-    }
-    function getEditsForRefactor2(fileName, formatOptions, positionOrRange, refactorName13, actionName2, preferences = emptyOptions, interactiveRefactorArguments) {
-      synchronizeHostData();
-      const file = getValidSourceFile(fileName);
-      return ts_refactor_exports.getEditsForRefactor(getRefactorContext(file, positionOrRange, preferences, formatOptions), refactorName13, actionName2, interactiveRefactorArguments);
+    } else if (isExportsOrModuleExportsOrAlias(sourceFile, left.expression)) {
+      convertNamedExport(sourceFile, assignment, changes, exports);
     }
-    function toLineColumnOffset(fileName, position) {
-      if (position === 0) {
-        return { line: 0, character: 0 };
+    return false;
+  }
+  function tryChangeModuleExportsObject(object, useSitesToUnqualify) {
+    const statements = mapAllOrFail(object.properties, (prop) => {
+      switch (prop.kind) {
+        case 177 /* GetAccessor */:
+        case 178 /* SetAccessor */:
+        case 304 /* ShorthandPropertyAssignment */:
+        case 305 /* SpreadAssignment */:
+          return void 0;
+        case 303 /* PropertyAssignment */:
+          return !isIdentifier(prop.name) ? void 0 : convertExportsDotXEquals_replaceNode(prop.name.text, prop.initializer, useSitesToUnqualify);
+        case 174 /* MethodDeclaration */:
+          return !isIdentifier(prop.name) ? void 0 : functionExpressionToDeclaration(prop.name.text, [factory.createToken(95 /* ExportKeyword */)], prop, useSitesToUnqualify);
+        default:
+          Debug.assertNever(prop, `Convert to ES6 got invalid prop kind ${prop.kind}`);
       }
-      return sourceMapper.toLineColumnOffset(fileName, position);
-    }
-    function prepareCallHierarchy(fileName, position) {
-      synchronizeHostData();
-      const declarations = ts_CallHierarchy_exports.resolveCallHierarchyDeclaration(program, getTouchingPropertyName(getValidSourceFile(fileName), position));
-      return declarations && mapOneOrMany(declarations, (declaration) => ts_CallHierarchy_exports.createCallHierarchyItem(program, declaration));
-    }
-    function provideCallHierarchyIncomingCalls(fileName, position) {
-      synchronizeHostData();
-      const sourceFile = getValidSourceFile(fileName);
-      const declaration = firstOrOnly(ts_CallHierarchy_exports.resolveCallHierarchyDeclaration(program, position === 0 ? sourceFile : getTouchingPropertyName(sourceFile, position)));
-      return declaration ? ts_CallHierarchy_exports.getIncomingCalls(program, declaration, cancellationToken) : [];
-    }
-    function provideCallHierarchyOutgoingCalls(fileName, position) {
-      synchronizeHostData();
-      const sourceFile = getValidSourceFile(fileName);
-      const declaration = firstOrOnly(ts_CallHierarchy_exports.resolveCallHierarchyDeclaration(program, position === 0 ? sourceFile : getTouchingPropertyName(sourceFile, position)));
-      return declaration ? ts_CallHierarchy_exports.getOutgoingCalls(program, declaration) : [];
-    }
-    function provideInlayHints2(fileName, span, preferences = emptyOptions) {
-      synchronizeHostData();
-      const sourceFile = getValidSourceFile(fileName);
-      return ts_InlayHints_exports.provideInlayHints(getInlayHintsContext(sourceFile, span, preferences));
-    }
-    const ls = {
-      dispose,
-      cleanupSemanticCache,
-      getSyntacticDiagnostics,
-      getSemanticDiagnostics,
-      getSuggestionDiagnostics,
-      getCompilerOptionsDiagnostics,
-      getSyntacticClassifications: getSyntacticClassifications2,
-      getSemanticClassifications: getSemanticClassifications3,
-      getEncodedSyntacticClassifications: getEncodedSyntacticClassifications2,
-      getEncodedSemanticClassifications: getEncodedSemanticClassifications3,
-      getCompletionsAtPosition: getCompletionsAtPosition2,
-      getCompletionEntryDetails: getCompletionEntryDetails2,
-      getCompletionEntrySymbol: getCompletionEntrySymbol2,
-      getSignatureHelpItems: getSignatureHelpItems2,
-      getQuickInfoAtPosition,
-      getDefinitionAtPosition: getDefinitionAtPosition2,
-      getDefinitionAndBoundSpan: getDefinitionAndBoundSpan2,
-      getImplementationAtPosition,
-      getTypeDefinitionAtPosition: getTypeDefinitionAtPosition2,
-      getReferencesAtPosition,
-      findReferences,
-      getFileReferences,
-      getDocumentHighlights,
-      getNameOrDottedNameSpan,
-      getBreakpointStatementAtPosition,
-      getNavigateToItems: getNavigateToItems2,
-      getRenameInfo: getRenameInfo2,
-      getSmartSelectionRange: getSmartSelectionRange2,
-      findRenameLocations,
-      getNavigationBarItems: getNavigationBarItems2,
-      getNavigationTree: getNavigationTree2,
-      getOutliningSpans,
-      getTodoComments,
-      getBraceMatchingAtPosition,
-      getIndentationAtPosition,
-      getFormattingEditsForRange,
-      getFormattingEditsForDocument,
-      getFormattingEditsAfterKeystroke,
-      getDocCommentTemplateAtPosition: getDocCommentTemplateAtPosition2,
-      isValidBraceCompletionAtPosition,
-      getJsxClosingTagAtPosition,
-      getLinkedEditingRangeAtPosition,
-      getSpanOfEnclosingComment,
-      getCodeFixesAtPosition,
-      getCombinedCodeFix,
-      applyCodeActionCommand,
-      organizeImports: organizeImports2,
-      getEditsForFileRename: getEditsForFileRename2,
-      getEmitOutput,
-      getNonBoundSourceFile,
-      getProgram,
-      getCurrentProgram: () => program,
-      getAutoImportProvider,
-      updateIsDefinitionOfReferencedSymbols,
-      getApplicableRefactors: getApplicableRefactors2,
-      getEditsForRefactor: getEditsForRefactor2,
-      getMoveToRefactoringFileSuggestions,
-      toLineColumnOffset,
-      getSourceMapper: () => sourceMapper,
-      clearSourceMapperCache: () => sourceMapper.clearCache(),
-      prepareCallHierarchy,
-      provideCallHierarchyIncomingCalls,
-      provideCallHierarchyOutgoingCalls,
-      toggleLineComment,
-      toggleMultilineComment,
-      commentSelection,
-      uncommentSelection,
-      provideInlayHints: provideInlayHints2,
-      getSupportedCodeFixes
-    };
-    switch (languageServiceMode) {
-      case 0 /* Semantic */:
-        break;
-      case 1 /* PartialSemantic */:
-        invalidOperationsInPartialSemanticMode.forEach(
-          (key) => ls[key] = () => {
-            throw new Error(`LanguageService Operation: ${key} not allowed in LanguageServiceMode.PartialSemantic`);
-          }
-        );
-        break;
-      case 2 /* Syntactic */:
-        invalidOperationsInSyntacticMode.forEach(
-          (key) => ls[key] = () => {
-            throw new Error(`LanguageService Operation: ${key} not allowed in LanguageServiceMode.Syntactic`);
-          }
-        );
-        break;
-      default:
-        Debug.assertNever(languageServiceMode);
+    });
+    return statements && [statements, false];
+  }
+  function convertNamedExport(sourceFile, assignment, changes, exports) {
+    const { text } = assignment.left.name;
+    const rename = exports.get(text);
+    if (rename !== void 0) {
+      const newNodes = [
+        makeConst(
+          /*modifiers*/
+          void 0,
+          rename,
+          assignment.right
+        ),
+        makeExportDeclaration([factory.createExportSpecifier(
+          /*isTypeOnly*/
+          false,
+          rename,
+          text
+        )])
+      ];
+      changes.replaceNodeWithNodes(sourceFile, assignment.parent, newNodes);
+    } else {
+      convertExportsPropertyAssignment(assignment, sourceFile, changes);
     }
-    return ls;
   }
-  function getNameTable(sourceFile) {
-    if (!sourceFile.nameTable) {
-      initializeNameTable(sourceFile);
+  function convertReExportAll(reExported, checker) {
+    const moduleSpecifier = reExported.text;
+    const moduleSymbol = checker.getSymbolAtLocation(reExported);
+    const exports = moduleSymbol ? moduleSymbol.exports : emptyMap;
+    return exports.has("export=" /* ExportEquals */) ? [[reExportDefault(moduleSpecifier)], true] : !exports.has("default" /* Default */) ? [[reExportStar(moduleSpecifier)], false] : (
+      // If there's some non-default export, must include both `export *` and `export default`.
+      exports.size > 1 ? [[reExportStar(moduleSpecifier), reExportDefault(moduleSpecifier)], true] : [[reExportDefault(moduleSpecifier)], true]
+    );
+  }
+  function reExportStar(moduleSpecifier) {
+    return makeExportDeclaration(
+      /*exportSpecifiers*/
+      void 0,
+      moduleSpecifier
+    );
+  }
+  function reExportDefault(moduleSpecifier) {
+    return makeExportDeclaration([factory.createExportSpecifier(
+      /*isTypeOnly*/
+      false,
+      /*propertyName*/
+      void 0,
+      "default"
+    )], moduleSpecifier);
+  }
+  function convertExportsPropertyAssignment({ left, right, parent: parent2 }, sourceFile, changes) {
+    const name = left.name.text;
+    if ((isFunctionExpression(right) || isArrowFunction(right) || isClassExpression(right)) && (!right.name || right.name.text === name)) {
+      changes.replaceRange(sourceFile, { pos: left.getStart(sourceFile), end: right.getStart(sourceFile) }, factory.createToken(95 /* ExportKeyword */), { suffix: " " });
+      if (!right.name)
+        changes.insertName(sourceFile, right, name);
+      const semi = findChildOfKind(parent2, 27 /* SemicolonToken */, sourceFile);
+      if (semi)
+        changes.delete(sourceFile, semi);
+    } else {
+      changes.replaceNodeRangeWithNodes(sourceFile, left.expression, findChildOfKind(left, 25 /* DotToken */, sourceFile), [factory.createToken(95 /* ExportKeyword */), factory.createToken(87 /* ConstKeyword */)], { joiner: " ", suffix: " " });
     }
-    return sourceFile.nameTable;
   }
-  function initializeNameTable(sourceFile) {
-    const nameTable = sourceFile.nameTable = /* @__PURE__ */ new Map();
-    sourceFile.forEachChild(function walk(node) {
-      if (isIdentifier(node) && !isTagName(node) && node.escapedText || isStringOrNumericLiteralLike(node) && literalIsName(node)) {
-        const text = getEscapedTextOfIdentifierOrLiteral(node);
-        nameTable.set(text, nameTable.get(text) === void 0 ? node.pos : -1);
-      } else if (isPrivateIdentifier(node)) {
-        const text = node.escapedText;
-        nameTable.set(text, nameTable.get(text) === void 0 ? node.pos : -1);
-      }
-      forEachChild(node, walk);
-      if (hasJSDocNodes(node)) {
-        for (const jsDoc of node.jsDoc) {
-          forEachChild(jsDoc, walk);
+  function convertExportsDotXEquals_replaceNode(name, exported, useSitesToUnqualify) {
+    const modifiers = [factory.createToken(95 /* ExportKeyword */)];
+    switch (exported.kind) {
+      case 218 /* FunctionExpression */: {
+        const { name: expressionName } = exported;
+        if (expressionName && expressionName.text !== name) {
+          return exportConst();
         }
       }
-    });
-  }
-  function literalIsName(node) {
-    return isDeclarationName(node) || node.parent.kind === 282 /* ExternalModuleReference */ || isArgumentOfElementAccessExpression(node) || isLiteralComputedPropertyDeclarationName(node);
+      case 219 /* ArrowFunction */:
+        return functionExpressionToDeclaration(name, modifiers, exported, useSitesToUnqualify);
+      case 231 /* ClassExpression */:
+        return classExpressionToDeclaration(name, modifiers, exported, useSitesToUnqualify);
+      default:
+        return exportConst();
+    }
+    function exportConst() {
+      return makeConst(modifiers, factory.createIdentifier(name), replaceImportUseSites(exported, useSitesToUnqualify));
+    }
   }
-  function getContainingObjectLiteralElement(node) {
-    const element = getContainingObjectLiteralElementWorker(node);
-    return element && (isObjectLiteralExpression(element.parent) || isJsxAttributes(element.parent)) ? element : void 0;
+  function replaceImportUseSites(nodeOrNodes, useSitesToUnqualify) {
+    if (!useSitesToUnqualify || !some(arrayFrom(useSitesToUnqualify.keys()), (original) => rangeContainsRange(nodeOrNodes, original))) {
+      return nodeOrNodes;
+    }
+    return isArray(nodeOrNodes) ? getSynthesizedDeepClonesWithReplacements(
+      nodeOrNodes,
+      /*includeTrivia*/
+      true,
+      replaceNode
+    ) : getSynthesizedDeepCloneWithReplacements(
+      nodeOrNodes,
+      /*includeTrivia*/
+      true,
+      replaceNode
+    );
+    function replaceNode(original) {
+      if (original.kind === 211 /* PropertyAccessExpression */) {
+        const replacement = useSitesToUnqualify.get(original);
+        useSitesToUnqualify.delete(original);
+        return replacement;
+      }
+    }
   }
-  function getContainingObjectLiteralElementWorker(node) {
-    switch (node.kind) {
-      case 11 /* StringLiteral */:
-      case 15 /* NoSubstitutionTemplateLiteral */:
-      case 9 /* NumericLiteral */:
-        if (node.parent.kind === 166 /* ComputedPropertyName */) {
-          return isObjectLiteralElement(node.parent.parent) ? node.parent.parent : void 0;
+  function convertSingleImport(name, moduleSpecifier, checker, identifiers, target, quotePreference) {
+    switch (name.kind) {
+      case 206 /* ObjectBindingPattern */: {
+        const importSpecifiers = mapAllOrFail(name.elements, (e) => e.dotDotDotToken || e.initializer || e.propertyName && !isIdentifier(e.propertyName) || !isIdentifier(e.name) ? void 0 : makeImportSpecifier2(e.propertyName && e.propertyName.text, e.name.text));
+        if (importSpecifiers) {
+          return convertedImports([makeImport(
+            /*defaultImport*/
+            void 0,
+            importSpecifiers,
+            moduleSpecifier,
+            quotePreference
+          )]);
         }
+      }
+      case 207 /* ArrayBindingPattern */: {
+        const tmp = makeUniqueName(moduleSpecifierToValidIdentifier(moduleSpecifier.text, target), identifiers);
+        return convertedImports([
+          makeImport(
+            factory.createIdentifier(tmp),
+            /*namedImports*/
+            void 0,
+            moduleSpecifier,
+            quotePreference
+          ),
+          makeConst(
+            /*modifiers*/
+            void 0,
+            getSynthesizedDeepClone(name),
+            factory.createIdentifier(tmp)
+          )
+        ]);
+      }
       case 80 /* Identifier */:
-        return isObjectLiteralElement(node.parent) && (node.parent.parent.kind === 209 /* ObjectLiteralExpression */ || node.parent.parent.kind === 291 /* JsxAttributes */) && node.parent.name === node ? node.parent : void 0;
+        return convertSingleIdentifierImport(name, moduleSpecifier, checker, identifiers, quotePreference);
+      default:
+        return Debug.assertNever(name, `Convert to ES module got invalid name kind ${name.kind}`);
     }
-    return void 0;
   }
-  function getSymbolAtLocationForQuickInfo(node, checker) {
-    const object = getContainingObjectLiteralElement(node);
-    if (object) {
-      const contextualType = checker.getContextualType(object.parent);
-      const properties = contextualType && getPropertySymbolsFromContextualType(
-        object,
-        checker,
-        contextualType,
-        /*unionSymbolOk*/
-        false
-      );
-      if (properties && properties.length === 1) {
-        return first(properties);
+  function convertSingleIdentifierImport(name, moduleSpecifier, checker, identifiers, quotePreference) {
+    const nameSymbol = checker.getSymbolAtLocation(name);
+    const namedBindingsNames = /* @__PURE__ */ new Map();
+    let needDefaultImport = false;
+    let useSitesToUnqualify;
+    for (const use of identifiers.original.get(name.text)) {
+      if (checker.getSymbolAtLocation(use) !== nameSymbol || use === name) {
+        continue;
+      }
+      const { parent: parent2 } = use;
+      if (isPropertyAccessExpression(parent2)) {
+        const { name: { text: propertyName } } = parent2;
+        if (propertyName === "default") {
+          needDefaultImport = true;
+          const importDefaultName = use.getText();
+          (useSitesToUnqualify ?? (useSitesToUnqualify = /* @__PURE__ */ new Map())).set(parent2, factory.createIdentifier(importDefaultName));
+        } else {
+          Debug.assert(parent2.expression === use, "Didn't expect expression === use");
+          let idName = namedBindingsNames.get(propertyName);
+          if (idName === void 0) {
+            idName = makeUniqueName(propertyName, identifiers);
+            namedBindingsNames.set(propertyName, idName);
+          }
+          (useSitesToUnqualify ?? (useSitesToUnqualify = /* @__PURE__ */ new Map())).set(parent2, factory.createIdentifier(idName));
+        }
+      } else {
+        needDefaultImport = true;
       }
     }
-    return checker.getSymbolAtLocation(node);
-  }
-  function getPropertySymbolsFromContextualType(node, checker, contextualType, unionSymbolOk) {
-    const name = getNameFromPropertyName(node.name);
-    if (!name)
-      return emptyArray;
-    if (!contextualType.isUnion()) {
-      const symbol = contextualType.getProperty(name);
-      return symbol ? [symbol] : emptyArray;
-    }
-    const discriminatedPropertySymbols = mapDefined(contextualType.types, (t) => (isObjectLiteralExpression(node.parent) || isJsxAttributes(node.parent)) && checker.isTypeInvalidDueToUnionDiscriminant(t, node.parent) ? void 0 : t.getProperty(name));
-    if (unionSymbolOk && (discriminatedPropertySymbols.length === 0 || discriminatedPropertySymbols.length === contextualType.types.length)) {
-      const symbol = contextualType.getProperty(name);
-      if (symbol)
-        return [symbol];
+    const namedBindings = namedBindingsNames.size === 0 ? void 0 : arrayFrom(mapIterator(namedBindingsNames.entries(), ([propertyName, idName]) => factory.createImportSpecifier(
+      /*isTypeOnly*/
+      false,
+      propertyName === idName ? void 0 : factory.createIdentifier(propertyName),
+      factory.createIdentifier(idName)
+    )));
+    if (!namedBindings) {
+      needDefaultImport = true;
     }
-    if (discriminatedPropertySymbols.length === 0) {
-      return mapDefined(contextualType.types, (t) => t.getProperty(name));
+    return convertedImports(
+      [makeImport(needDefaultImport ? getSynthesizedDeepClone(name) : void 0, namedBindings, moduleSpecifier, quotePreference)],
+      useSitesToUnqualify
+    );
+  }
+  function makeUniqueName(name, identifiers) {
+    while (identifiers.original.has(name) || identifiers.additional.has(name)) {
+      name = `_${name}`;
     }
-    return discriminatedPropertySymbols;
+    identifiers.additional.add(name);
+    return name;
   }
-  function isArgumentOfElementAccessExpression(node) {
-    return node && node.parent && node.parent.kind === 211 /* ElementAccessExpression */ && node.parent.argumentExpression === node;
+  function collectFreeIdentifiers(file) {
+    const map2 = createMultiMap();
+    forEachFreeIdentifier(file, (id) => map2.add(id.text, id));
+    return map2;
   }
-  function getDefaultLibFilePath(options) {
-    if (sys) {
-      return combinePaths(getDirectoryPath(normalizePath(sys.getExecutingFilePath())), getDefaultLibFileName(options));
+  function forEachFreeIdentifier(node, cb) {
+    if (isIdentifier(node) && isFreeIdentifier(node))
+      cb(node);
+    node.forEachChild((child) => forEachFreeIdentifier(child, cb));
+  }
+  function isFreeIdentifier(node) {
+    const { parent: parent2 } = node;
+    switch (parent2.kind) {
+      case 211 /* PropertyAccessExpression */:
+        return parent2.name !== node;
+      case 208 /* BindingElement */:
+        return parent2.propertyName !== node;
+      case 276 /* ImportSpecifier */:
+        return parent2.propertyName !== node;
+      default:
+        return true;
     }
-    throw new Error("getDefaultLibFilePath is only supported when consumed as a node module. ");
   }
-  var servicesVersion, NodeObject, TokenOrIdentifierObject, SymbolObject, TokenObject, IdentifierObject, PrivateIdentifierObject, TypeObject, SignatureObject, SourceFileObject, SourceMapSourceObject, SyntaxTreeCache, NoopCancellationToken, CancellationTokenObject, ThrottledCancellationToken, invalidOperationsInPartialSemanticMode, invalidOperationsInSyntacticMode;
-  var init_services = __esm({
-    "src/services/services.ts"() {
+  function functionExpressionToDeclaration(name, additionalModifiers, fn, useSitesToUnqualify) {
+    return factory.createFunctionDeclaration(
+      concatenate(additionalModifiers, getSynthesizedDeepClones(fn.modifiers)),
+      getSynthesizedDeepClone(fn.asteriskToken),
+      name,
+      getSynthesizedDeepClones(fn.typeParameters),
+      getSynthesizedDeepClones(fn.parameters),
+      getSynthesizedDeepClone(fn.type),
+      factory.converters.convertToFunctionBlock(replaceImportUseSites(fn.body, useSitesToUnqualify))
+    );
+  }
+  function classExpressionToDeclaration(name, additionalModifiers, cls, useSitesToUnqualify) {
+    return factory.createClassDeclaration(
+      concatenate(additionalModifiers, getSynthesizedDeepClones(cls.modifiers)),
+      name,
+      getSynthesizedDeepClones(cls.typeParameters),
+      getSynthesizedDeepClones(cls.heritageClauses),
+      replaceImportUseSites(cls.members, useSitesToUnqualify)
+    );
+  }
+  function makeSingleImport(localName, propertyName, moduleSpecifier, quotePreference) {
+    return propertyName === "default" ? makeImport(
+      factory.createIdentifier(localName),
+      /*namedImports*/
+      void 0,
+      moduleSpecifier,
+      quotePreference
+    ) : makeImport(
+      /*defaultImport*/
+      void 0,
+      [makeImportSpecifier2(propertyName, localName)],
+      moduleSpecifier,
+      quotePreference
+    );
+  }
+  function makeImportSpecifier2(propertyName, name) {
+    return factory.createImportSpecifier(
+      /*isTypeOnly*/
+      false,
+      propertyName !== void 0 && propertyName !== name ? factory.createIdentifier(propertyName) : void 0,
+      factory.createIdentifier(name)
+    );
+  }
+  function makeConst(modifiers, name, init) {
+    return factory.createVariableStatement(
+      modifiers,
+      factory.createVariableDeclarationList(
+        [factory.createVariableDeclaration(
+          name,
+          /*exclamationToken*/
+          void 0,
+          /*type*/
+          void 0,
+          init
+        )],
+        2 /* Const */
+      )
+    );
+  }
+  function makeExportDeclaration(exportSpecifiers, moduleSpecifier) {
+    return factory.createExportDeclaration(
+      /*modifiers*/
+      void 0,
+      /*isTypeOnly*/
+      false,
+      exportSpecifiers && factory.createNamedExports(exportSpecifiers),
+      moduleSpecifier === void 0 ? void 0 : factory.createStringLiteral(moduleSpecifier)
+    );
+  }
+  function convertedImports(newImports, useSitesToUnqualify) {
+    return {
+      newImports,
+      useSitesToUnqualify
+    };
+  }
+  var init_convertToEsModule = __esm({
+    "src/services/codefixes/convertToEsModule.ts"() {
       "use strict";
       init_ts4();
-      init_ts_NavigateTo();
-      init_ts_NavigationBar();
-      init_ts_refactor();
-      init_classifier();
-      init_classifier2020();
-      servicesVersion = "0.8";
-      NodeObject = class {
-        constructor(kind, pos, end) {
-          this.pos = pos;
-          this.end = end;
-          this.flags = 0 /* None */;
-          this.modifierFlagsCache = 0 /* None */;
-          this.transformFlags = 0 /* None */;
-          this.parent = void 0;
-          this.kind = kind;
-        }
-        assertHasRealPosition(message) {
-          Debug.assert(!positionIsSynthesized(this.pos) && !positionIsSynthesized(this.end), message || "Node must have a real position for this operation");
-        }
-        getSourceFile() {
-          return getSourceFileOfNode(this);
-        }
-        getStart(sourceFile, includeJsDocComment) {
-          this.assertHasRealPosition();
-          return getTokenPosOfNode(this, sourceFile, includeJsDocComment);
-        }
-        getFullStart() {
-          this.assertHasRealPosition();
-          return this.pos;
-        }
-        getEnd() {
-          this.assertHasRealPosition();
-          return this.end;
-        }
-        getWidth(sourceFile) {
-          this.assertHasRealPosition();
-          return this.getEnd() - this.getStart(sourceFile);
-        }
-        getFullWidth() {
-          this.assertHasRealPosition();
-          return this.end - this.pos;
-        }
-        getLeadingTriviaWidth(sourceFile) {
-          this.assertHasRealPosition();
-          return this.getStart(sourceFile) - this.pos;
-        }
-        getFullText(sourceFile) {
-          this.assertHasRealPosition();
-          return (sourceFile || this.getSourceFile()).text.substring(this.pos, this.end);
-        }
-        getText(sourceFile) {
-          this.assertHasRealPosition();
-          if (!sourceFile) {
-            sourceFile = this.getSourceFile();
-          }
-          return sourceFile.text.substring(this.getStart(sourceFile), this.getEnd());
-        }
-        getChildCount(sourceFile) {
-          return this.getChildren(sourceFile).length;
-        }
-        getChildAt(index, sourceFile) {
-          return this.getChildren(sourceFile)[index];
-        }
-        getChildren(sourceFile) {
-          this.assertHasRealPosition("Node without a real position cannot be scanned and thus has no token nodes - use forEachChild and collect the result if that's fine");
-          return this._children || (this._children = createChildren(this, sourceFile));
-        }
-        getFirstToken(sourceFile) {
-          this.assertHasRealPosition();
-          const children = this.getChildren(sourceFile);
-          if (!children.length) {
-            return void 0;
-          }
-          const child = find(children, (kid) => kid.kind < 315 /* FirstJSDocNode */ || kid.kind > 356 /* LastJSDocNode */);
-          return child.kind < 165 /* FirstNode */ ? child : child.getFirstToken(sourceFile);
-        }
-        getLastToken(sourceFile) {
-          this.assertHasRealPosition();
-          const children = this.getChildren(sourceFile);
-          const child = lastOrUndefined(children);
-          if (!child) {
-            return void 0;
-          }
-          return child.kind < 165 /* FirstNode */ ? child : child.getLastToken(sourceFile);
-        }
-        forEachChild(cbNode, cbNodeArray) {
-          return forEachChild(this, cbNode, cbNodeArray);
-        }
-      };
-      TokenOrIdentifierObject = class {
-        constructor(pos, end) {
-          this.pos = pos;
-          this.end = end;
-          this.flags = 0 /* None */;
-          this.modifierFlagsCache = 0 /* None */;
-          this.transformFlags = 0 /* None */;
-          this.parent = void 0;
-        }
-        getSourceFile() {
-          return getSourceFileOfNode(this);
-        }
-        getStart(sourceFile, includeJsDocComment) {
-          return getTokenPosOfNode(this, sourceFile, includeJsDocComment);
-        }
-        getFullStart() {
-          return this.pos;
-        }
-        getEnd() {
-          return this.end;
-        }
-        getWidth(sourceFile) {
-          return this.getEnd() - this.getStart(sourceFile);
-        }
-        getFullWidth() {
-          return this.end - this.pos;
-        }
-        getLeadingTriviaWidth(sourceFile) {
-          return this.getStart(sourceFile) - this.pos;
-        }
-        getFullText(sourceFile) {
-          return (sourceFile || this.getSourceFile()).text.substring(this.pos, this.end);
-        }
-        getText(sourceFile) {
-          if (!sourceFile) {
-            sourceFile = this.getSourceFile();
-          }
-          return sourceFile.text.substring(this.getStart(sourceFile), this.getEnd());
-        }
-        getChildCount() {
-          return this.getChildren().length;
-        }
-        getChildAt(index) {
-          return this.getChildren()[index];
-        }
-        getChildren() {
-          return this.kind === 1 /* EndOfFileToken */ ? this.jsDoc || emptyArray : emptyArray;
-        }
-        getFirstToken() {
-          return void 0;
-        }
-        getLastToken() {
-          return void 0;
-        }
-        forEachChild() {
-          return void 0;
-        }
-      };
-      SymbolObject = class {
-        constructor(flags, name) {
-          this.id = 0;
-          this.mergeId = 0;
-          this.flags = flags;
-          this.escapedName = name;
-        }
-        getFlags() {
-          return this.flags;
-        }
-        get name() {
-          return symbolName(this);
-        }
-        getEscapedName() {
-          return this.escapedName;
-        }
-        getName() {
-          return this.name;
-        }
-        getDeclarations() {
-          return this.declarations;
-        }
-        getDocumentationComment(checker) {
-          if (!this.documentationComment) {
-            this.documentationComment = emptyArray;
-            if (!this.declarations && isTransientSymbol(this) && this.links.target && isTransientSymbol(this.links.target) && this.links.target.links.tupleLabelDeclaration) {
-              const labelDecl = this.links.target.links.tupleLabelDeclaration;
-              this.documentationComment = getDocumentationComment([labelDecl], checker);
-            } else {
-              this.documentationComment = getDocumentationComment(this.declarations, checker);
-            }
-          }
-          return this.documentationComment;
-        }
-        getContextualDocumentationComment(context, checker) {
-          if (context) {
-            if (isGetAccessor(context)) {
-              if (!this.contextualGetAccessorDocumentationComment) {
-                this.contextualGetAccessorDocumentationComment = getDocumentationComment(filter(this.declarations, isGetAccessor), checker);
-              }
-              if (length(this.contextualGetAccessorDocumentationComment)) {
-                return this.contextualGetAccessorDocumentationComment;
-              }
-            }
-            if (isSetAccessor(context)) {
-              if (!this.contextualSetAccessorDocumentationComment) {
-                this.contextualSetAccessorDocumentationComment = getDocumentationComment(filter(this.declarations, isSetAccessor), checker);
-              }
-              if (length(this.contextualSetAccessorDocumentationComment)) {
-                return this.contextualSetAccessorDocumentationComment;
-              }
-            }
-          }
-          return this.getDocumentationComment(checker);
-        }
-        getJsDocTags(checker) {
-          if (this.tags === void 0) {
-            this.tags = getJsDocTagsOfDeclarations(this.declarations, checker);
-          }
-          return this.tags;
-        }
-        getContextualJsDocTags(context, checker) {
-          if (context) {
-            if (isGetAccessor(context)) {
-              if (!this.contextualGetAccessorTags) {
-                this.contextualGetAccessorTags = getJsDocTagsOfDeclarations(filter(this.declarations, isGetAccessor), checker);
-              }
-              if (length(this.contextualGetAccessorTags)) {
-                return this.contextualGetAccessorTags;
-              }
-            }
-            if (isSetAccessor(context)) {
-              if (!this.contextualSetAccessorTags) {
-                this.contextualSetAccessorTags = getJsDocTagsOfDeclarations(filter(this.declarations, isSetAccessor), checker);
-              }
-              if (length(this.contextualSetAccessorTags)) {
-                return this.contextualSetAccessorTags;
-              }
-            }
-          }
-          return this.getJsDocTags(checker);
-        }
-      };
-      TokenObject = class extends TokenOrIdentifierObject {
-        constructor(kind, pos, end) {
-          super(pos, end);
-          this.kind = kind;
-        }
-      };
-      IdentifierObject = class extends TokenOrIdentifierObject {
-        constructor(_kind, pos, end) {
-          super(pos, end);
-          this.kind = 80 /* Identifier */;
-        }
-        get text() {
-          return idText(this);
-        }
-      };
-      IdentifierObject.prototype.kind = 80 /* Identifier */;
-      PrivateIdentifierObject = class extends TokenOrIdentifierObject {
-        constructor(_kind, pos, end) {
-          super(pos, end);
-          this.kind = 81 /* PrivateIdentifier */;
-        }
-        get text() {
-          return idText(this);
-        }
-      };
-      PrivateIdentifierObject.prototype.kind = 81 /* PrivateIdentifier */;
-      TypeObject = class {
-        constructor(checker, flags) {
-          this.checker = checker;
-          this.flags = flags;
-        }
-        getFlags() {
-          return this.flags;
-        }
-        getSymbol() {
-          return this.symbol;
-        }
-        getProperties() {
-          return this.checker.getPropertiesOfType(this);
-        }
-        getProperty(propertyName) {
-          return this.checker.getPropertyOfType(this, propertyName);
-        }
-        getApparentProperties() {
-          return this.checker.getAugmentedPropertiesOfType(this);
-        }
-        getCallSignatures() {
-          return this.checker.getSignaturesOfType(this, 0 /* Call */);
-        }
-        getConstructSignatures() {
-          return this.checker.getSignaturesOfType(this, 1 /* Construct */);
-        }
-        getStringIndexType() {
-          return this.checker.getIndexTypeOfType(this, 0 /* String */);
-        }
-        getNumberIndexType() {
-          return this.checker.getIndexTypeOfType(this, 1 /* Number */);
-        }
-        getBaseTypes() {
-          return this.isClassOrInterface() ? this.checker.getBaseTypes(this) : void 0;
-        }
-        isNullableType() {
-          return this.checker.isNullableType(this);
-        }
-        getNonNullableType() {
-          return this.checker.getNonNullableType(this);
-        }
-        getNonOptionalType() {
-          return this.checker.getNonOptionalType(this);
-        }
-        getConstraint() {
-          return this.checker.getBaseConstraintOfType(this);
-        }
-        getDefault() {
-          return this.checker.getDefaultFromTypeParameter(this);
-        }
-        isUnion() {
-          return !!(this.flags & 1048576 /* Union */);
-        }
-        isIntersection() {
-          return !!(this.flags & 2097152 /* Intersection */);
-        }
-        isUnionOrIntersection() {
-          return !!(this.flags & 3145728 /* UnionOrIntersection */);
-        }
-        isLiteral() {
-          return !!(this.flags & (128 /* StringLiteral */ | 256 /* NumberLiteral */ | 2048 /* BigIntLiteral */));
-        }
-        isStringLiteral() {
-          return !!(this.flags & 128 /* StringLiteral */);
-        }
-        isNumberLiteral() {
-          return !!(this.flags & 256 /* NumberLiteral */);
-        }
-        isTypeParameter() {
-          return !!(this.flags & 262144 /* TypeParameter */);
-        }
-        isClassOrInterface() {
-          return !!(getObjectFlags(this) & 3 /* ClassOrInterface */);
-        }
-        isClass() {
-          return !!(getObjectFlags(this) & 1 /* Class */);
-        }
-        isIndexType() {
-          return !!(this.flags & 4194304 /* Index */);
-        }
-        /**
-         * This polyfills `referenceType.typeArguments` for API consumers
-         */
-        get typeArguments() {
-          if (getObjectFlags(this) & 4 /* Reference */) {
-            return this.checker.getTypeArguments(this);
-          }
-          return void 0;
-        }
-      };
-      SignatureObject = class {
-        // same
-        constructor(checker, flags) {
-          this.checker = checker;
-          this.flags = flags;
-        }
-        getDeclaration() {
-          return this.declaration;
-        }
-        getTypeParameters() {
-          return this.typeParameters;
-        }
-        getParameters() {
-          return this.parameters;
-        }
-        getReturnType() {
-          return this.checker.getReturnTypeOfSignature(this);
-        }
-        getTypeParameterAtPosition(pos) {
-          const type = this.checker.getParameterType(this, pos);
-          if (type.isIndexType() && isThisTypeParameter(type.type)) {
-            const constraint = type.type.getConstraint();
-            if (constraint) {
-              return this.checker.getIndexType(constraint);
-            }
-          }
-          return type;
-        }
-        getDocumentationComment() {
-          return this.documentationComment || (this.documentationComment = getDocumentationComment(singleElementArray(this.declaration), this.checker));
-        }
-        getJsDocTags() {
-          return this.jsDocTags || (this.jsDocTags = getJsDocTagsOfDeclarations(singleElementArray(this.declaration), this.checker));
-        }
-      };
-      SourceFileObject = class extends NodeObject {
-        constructor(kind, pos, end) {
-          super(kind, pos, end);
-          this.kind = 311 /* SourceFile */;
-        }
-        update(newText, textChangeRange) {
-          return updateSourceFile(this, newText, textChangeRange);
-        }
-        getLineAndCharacterOfPosition(position) {
-          return getLineAndCharacterOfPosition(this, position);
-        }
-        getLineStarts() {
-          return getLineStarts(this);
-        }
-        getPositionOfLineAndCharacter(line, character, allowEdits) {
-          return computePositionOfLineAndCharacter(getLineStarts(this), line, character, this.text, allowEdits);
-        }
-        getLineEndOfPosition(pos) {
-          const { line } = this.getLineAndCharacterOfPosition(pos);
-          const lineStarts = this.getLineStarts();
-          let lastCharPos;
-          if (line + 1 >= lineStarts.length) {
-            lastCharPos = this.getEnd();
-          }
-          if (!lastCharPos) {
-            lastCharPos = lineStarts[line + 1] - 1;
-          }
-          const fullText = this.getFullText();
-          return fullText[lastCharPos] === "\n" && fullText[lastCharPos - 1] === "\r" ? lastCharPos - 1 : lastCharPos;
-        }
-        getNamedDeclarations() {
-          if (!this.namedDeclarations) {
-            this.namedDeclarations = this.computeNamedDeclarations();
-          }
-          return this.namedDeclarations;
-        }
-        computeNamedDeclarations() {
-          const result = createMultiMap();
-          this.forEachChild(visit);
-          return result;
-          function addDeclaration(declaration) {
-            const name = getDeclarationName(declaration);
-            if (name) {
-              result.add(name, declaration);
-            }
-          }
-          function getDeclarations(name) {
-            let declarations = result.get(name);
-            if (!declarations) {
-              result.set(name, declarations = []);
-            }
-            return declarations;
-          }
-          function getDeclarationName(declaration) {
-            const name = getNonAssignedNameOfDeclaration(declaration);
-            return name && (isComputedPropertyName(name) && isPropertyAccessExpression(name.expression) ? name.expression.name.text : isPropertyName(name) ? getNameFromPropertyName(name) : void 0);
-          }
-          function visit(node) {
-            switch (node.kind) {
-              case 261 /* FunctionDeclaration */:
-              case 217 /* FunctionExpression */:
-              case 173 /* MethodDeclaration */:
-              case 172 /* MethodSignature */:
-                const functionDeclaration = node;
-                const declarationName = getDeclarationName(functionDeclaration);
-                if (declarationName) {
-                  const declarations = getDeclarations(declarationName);
-                  const lastDeclaration = lastOrUndefined(declarations);
-                  if (lastDeclaration && functionDeclaration.parent === lastDeclaration.parent && functionDeclaration.symbol === lastDeclaration.symbol) {
-                    if (functionDeclaration.body && !lastDeclaration.body) {
-                      declarations[declarations.length - 1] = functionDeclaration;
-                    }
-                  } else {
-                    declarations.push(functionDeclaration);
-                  }
-                }
-                forEachChild(node, visit);
-                break;
-              case 262 /* ClassDeclaration */:
-              case 230 /* ClassExpression */:
-              case 263 /* InterfaceDeclaration */:
-              case 264 /* TypeAliasDeclaration */:
-              case 265 /* EnumDeclaration */:
-              case 266 /* ModuleDeclaration */:
-              case 270 /* ImportEqualsDeclaration */:
-              case 280 /* ExportSpecifier */:
-              case 275 /* ImportSpecifier */:
-              case 272 /* ImportClause */:
-              case 273 /* NamespaceImport */:
-              case 176 /* GetAccessor */:
-              case 177 /* SetAccessor */:
-              case 186 /* TypeLiteral */:
-                addDeclaration(node);
-                forEachChild(node, visit);
-                break;
-              case 168 /* Parameter */:
-                if (!hasSyntacticModifier(node, 16476 /* ParameterPropertyModifier */)) {
-                  break;
-                }
-              case 259 /* VariableDeclaration */:
-              case 207 /* BindingElement */: {
-                const decl = node;
-                if (isBindingPattern(decl.name)) {
-                  forEachChild(decl.name, visit);
-                  break;
-                }
-                if (decl.initializer) {
-                  visit(decl.initializer);
-                }
+      init_ts_codefix();
+      registerCodeFix({
+        errorCodes: [Diagnostics.File_is_a_CommonJS_module_it_may_be_converted_to_an_ES_module.code],
+        getCodeActions(context) {
+          const { sourceFile, program, preferences } = context;
+          const changes = ts_textChanges_exports.ChangeTracker.with(context, (changes2) => {
+            const moduleExportsChangedToDefault = convertFileToEsModule(sourceFile, program.getTypeChecker(), changes2, getEmitScriptTarget(program.getCompilerOptions()), getQuotePreference(sourceFile, preferences));
+            if (moduleExportsChangedToDefault) {
+              for (const importingFile of program.getSourceFiles()) {
+                fixImportOfModuleExports(importingFile, sourceFile, program, changes2, getQuotePreference(importingFile, preferences));
               }
-              case 305 /* EnumMember */:
-              case 171 /* PropertyDeclaration */:
-              case 170 /* PropertySignature */:
-                addDeclaration(node);
-                break;
-              case 277 /* ExportDeclaration */:
-                const exportDeclaration = node;
-                if (exportDeclaration.exportClause) {
-                  if (isNamedExports(exportDeclaration.exportClause)) {
-                    forEach(exportDeclaration.exportClause.elements, visit);
-                  } else {
-                    visit(exportDeclaration.exportClause.name);
-                  }
-                }
-                break;
-              case 271 /* ImportDeclaration */:
-                const importClause = node.importClause;
-                if (importClause) {
-                  if (importClause.name) {
-                    addDeclaration(importClause.name);
-                  }
-                  if (importClause.namedBindings) {
-                    if (importClause.namedBindings.kind === 273 /* NamespaceImport */) {
-                      addDeclaration(importClause.namedBindings);
-                    } else {
-                      forEach(importClause.namedBindings.elements, visit);
-                    }
-                  }
-                }
-                break;
-              case 225 /* BinaryExpression */:
-                if (getAssignmentDeclarationKind(node) !== 0 /* None */) {
-                  addDeclaration(node);
-                }
-              default:
-                forEachChild(node, visit);
             }
-          }
-        }
-      };
-      SourceMapSourceObject = class {
-        constructor(fileName, text, skipTrivia2) {
-          this.fileName = fileName;
-          this.text = text;
-          this.skipTrivia = skipTrivia2;
-        }
-        getLineAndCharacterOfPosition(pos) {
-          return getLineAndCharacterOfPosition(this, pos);
-        }
-      };
-      SyntaxTreeCache = class {
-        constructor(host) {
-          this.host = host;
-        }
-        getCurrentSourceFile(fileName) {
-          var _a, _b, _c, _d, _e, _f, _g, _h;
-          const scriptSnapshot = this.host.getScriptSnapshot(fileName);
-          if (!scriptSnapshot) {
-            throw new Error("Could not find file: '" + fileName + "'.");
-          }
-          const scriptKind = getScriptKind(fileName, this.host);
-          const version2 = this.host.getScriptVersion(fileName);
-          let sourceFile;
-          if (this.currentFileName !== fileName) {
-            const options = {
-              languageVersion: 99 /* Latest */,
-              impliedNodeFormat: getImpliedNodeFormatForFile(
-                toPath(fileName, this.host.getCurrentDirectory(), ((_c = (_b = (_a = this.host).getCompilerHost) == null ? void 0 : _b.call(_a)) == null ? void 0 : _c.getCanonicalFileName) || hostGetCanonicalFileName(this.host)),
-                (_h = (_g = (_f = (_e = (_d = this.host).getCompilerHost) == null ? void 0 : _e.call(_d)) == null ? void 0 : _f.getModuleResolutionCache) == null ? void 0 : _g.call(_f)) == null ? void 0 : _h.getPackageJsonInfoCache(),
-                this.host,
-                this.host.getCompilationSettings()
-              ),
-              setExternalModuleIndicator: getSetExternalModuleIndicator(this.host.getCompilationSettings())
-            };
-            sourceFile = createLanguageServiceSourceFile(
-              fileName,
-              scriptSnapshot,
-              options,
-              version2,
-              /*setNodeParents*/
-              true,
-              scriptKind
-            );
-          } else if (this.currentFileVersion !== version2) {
-            const editRange = scriptSnapshot.getChangeRange(this.currentFileScriptSnapshot);
-            sourceFile = updateLanguageServiceSourceFile(this.currentSourceFile, scriptSnapshot, version2, editRange);
-          }
-          if (sourceFile) {
-            this.currentFileVersion = version2;
-            this.currentFileName = fileName;
-            this.currentFileScriptSnapshot = scriptSnapshot;
-            this.currentSourceFile = sourceFile;
-          }
-          return this.currentSourceFile;
-        }
-      };
-      NoopCancellationToken = {
-        isCancellationRequested: returnFalse,
-        throwIfCancellationRequested: noop
-      };
-      CancellationTokenObject = class {
-        constructor(cancellationToken) {
-          this.cancellationToken = cancellationToken;
-        }
-        isCancellationRequested() {
-          return this.cancellationToken.isCancellationRequested();
-        }
-        throwIfCancellationRequested() {
-          var _a;
-          if (this.isCancellationRequested()) {
-            (_a = tracing) == null ? void 0 : _a.instant(tracing.Phase.Session, "cancellationThrown", { kind: "CancellationTokenObject" });
-            throw new OperationCanceledException();
-          }
-        }
-      };
-      ThrottledCancellationToken = class {
-        constructor(hostCancellationToken, throttleWaitMilliseconds = 20) {
-          this.hostCancellationToken = hostCancellationToken;
-          this.throttleWaitMilliseconds = throttleWaitMilliseconds;
-          // Store when we last tried to cancel.  Checking cancellation can be expensive (as we have
-          // to marshall over to the host layer).  So we only bother actually checking once enough
-          // time has passed.
-          this.lastCancellationCheckTime = 0;
-        }
-        isCancellationRequested() {
-          const time = timestamp();
-          const duration = Math.abs(time - this.lastCancellationCheckTime);
-          if (duration >= this.throttleWaitMilliseconds) {
-            this.lastCancellationCheckTime = time;
-            return this.hostCancellationToken.isCancellationRequested();
-          }
-          return false;
-        }
-        throwIfCancellationRequested() {
-          var _a;
-          if (this.isCancellationRequested()) {
-            (_a = tracing) == null ? void 0 : _a.instant(tracing.Phase.Session, "cancellationThrown", { kind: "ThrottledCancellationToken" });
-            throw new OperationCanceledException();
-          }
+          });
+          return [createCodeFixActionWithoutFixAll("convertToEsModule", changes, Diagnostics.Convert_to_ES_module)];
         }
-      };
-      invalidOperationsInPartialSemanticMode = [
-        "getSemanticDiagnostics",
-        "getSuggestionDiagnostics",
-        "getCompilerOptionsDiagnostics",
-        "getSemanticClassifications",
-        "getEncodedSemanticClassifications",
-        "getCodeFixesAtPosition",
-        "getCombinedCodeFix",
-        "applyCodeActionCommand",
-        "organizeImports",
-        "getEditsForFileRename",
-        "getEmitOutput",
-        "getApplicableRefactors",
-        "getEditsForRefactor",
-        "prepareCallHierarchy",
-        "provideCallHierarchyIncomingCalls",
-        "provideCallHierarchyOutgoingCalls",
-        "provideInlayHints",
-        "getSupportedCodeFixes"
-      ];
-      invalidOperationsInSyntacticMode = [
-        ...invalidOperationsInPartialSemanticMode,
-        "getCompletionsAtPosition",
-        "getCompletionEntryDetails",
-        "getCompletionEntrySymbol",
-        "getSignatureHelpItems",
-        "getQuickInfoAtPosition",
-        "getDefinitionAtPosition",
-        "getDefinitionAndBoundSpan",
-        "getImplementationAtPosition",
-        "getTypeDefinitionAtPosition",
-        "getReferencesAtPosition",
-        "findReferences",
-        "getDocumentHighlights",
-        "getNavigateToItems",
-        "getRenameInfo",
-        "findRenameLocations",
-        "getApplicableRefactors"
-      ];
-      setObjectAllocator(getServicesObjectAllocator());
+      });
+    }
+  });
+
+  // src/services/codefixes/correctQualifiedNameToIndexedAccessType.ts
+  function getQualifiedName(sourceFile, pos) {
+    const qualifiedName = findAncestor(getTokenAtPosition(sourceFile, pos), isQualifiedName);
+    Debug.assert(!!qualifiedName, "Expected position to be owned by a qualified name.");
+    return isIdentifier(qualifiedName.left) ? qualifiedName : void 0;
+  }
+  function doChange10(changeTracker, sourceFile, qualifiedName) {
+    const rightText = qualifiedName.right.text;
+    const replacement = factory.createIndexedAccessTypeNode(
+      factory.createTypeReferenceNode(
+        qualifiedName.left,
+        /*typeArguments*/
+        void 0
+      ),
+      factory.createLiteralTypeNode(factory.createStringLiteral(rightText))
+    );
+    changeTracker.replaceNode(sourceFile, qualifiedName, replacement);
+  }
+  var fixId11, errorCodes12;
+  var init_correctQualifiedNameToIndexedAccessType = __esm({
+    "src/services/codefixes/correctQualifiedNameToIndexedAccessType.ts"() {
+      "use strict";
+      init_ts4();
+      init_ts_codefix();
+      fixId11 = "correctQualifiedNameToIndexedAccessType";
+      errorCodes12 = [Diagnostics.Cannot_access_0_1_because_0_is_a_type_but_not_a_namespace_Did_you_mean_to_retrieve_the_type_of_the_property_1_in_0_with_0_1.code];
+      registerCodeFix({
+        errorCodes: errorCodes12,
+        getCodeActions(context) {
+          const qualifiedName = getQualifiedName(context.sourceFile, context.span.start);
+          if (!qualifiedName)
+            return void 0;
+          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange10(t, context.sourceFile, qualifiedName));
+          const newText = `${qualifiedName.left.text}["${qualifiedName.right.text}"]`;
+          return [createCodeFixAction(fixId11, changes, [Diagnostics.Rewrite_as_the_indexed_access_type_0, newText], fixId11, Diagnostics.Rewrite_all_as_indexed_access_types)];
+        },
+        fixIds: [fixId11],
+        getAllCodeActions: (context) => codeFixAll(context, errorCodes12, (changes, diag2) => {
+          const q = getQualifiedName(diag2.file, diag2.start);
+          if (q) {
+            doChange10(changes, diag2.file, q);
+          }
+        })
+      });
     }
   });
 
-  // src/services/transform.ts
-  function transform(source, transformers, compilerOptions) {
-    const diagnostics = [];
-    compilerOptions = fixupCompilerOptions(compilerOptions, diagnostics);
-    const nodes = isArray(source) ? source : [source];
-    const result = transformNodes(
-      /*resolver*/
-      void 0,
-      /*host*/
-      void 0,
-      factory,
-      compilerOptions,
-      nodes,
-      transformers,
-      /*allowDtsFiles*/
-      true
+  // src/services/codefixes/convertToTypeOnlyExport.ts
+  function getExportSpecifierForDiagnosticSpan(span, sourceFile) {
+    return tryCast(getTokenAtPosition(sourceFile, span.start).parent, isExportSpecifier);
+  }
+  function fixSingleExportDeclaration(changes, exportSpecifier, context) {
+    if (!exportSpecifier) {
+      return;
+    }
+    const exportClause = exportSpecifier.parent;
+    const exportDeclaration = exportClause.parent;
+    const typeExportSpecifiers = getTypeExportSpecifiers(exportSpecifier, context);
+    if (typeExportSpecifiers.length === exportClause.elements.length) {
+      changes.insertModifierBefore(context.sourceFile, 156 /* TypeKeyword */, exportClause);
+    } else {
+      const valueExportDeclaration = factory.updateExportDeclaration(
+        exportDeclaration,
+        exportDeclaration.modifiers,
+        /*isTypeOnly*/
+        false,
+        factory.updateNamedExports(exportClause, filter(exportClause.elements, (e) => !contains(typeExportSpecifiers, e))),
+        exportDeclaration.moduleSpecifier,
+        /*attributes*/
+        void 0
+      );
+      const typeExportDeclaration = factory.createExportDeclaration(
+        /*modifiers*/
+        void 0,
+        /*isTypeOnly*/
+        true,
+        factory.createNamedExports(typeExportSpecifiers),
+        exportDeclaration.moduleSpecifier,
+        /*attributes*/
+        void 0
+      );
+      changes.replaceNode(context.sourceFile, exportDeclaration, valueExportDeclaration, {
+        leadingTriviaOption: ts_textChanges_exports.LeadingTriviaOption.IncludeAll,
+        trailingTriviaOption: ts_textChanges_exports.TrailingTriviaOption.Exclude
+      });
+      changes.insertNodeAfter(context.sourceFile, exportDeclaration, typeExportDeclaration);
+    }
+  }
+  function getTypeExportSpecifiers(originExportSpecifier, context) {
+    const exportClause = originExportSpecifier.parent;
+    if (exportClause.elements.length === 1) {
+      return exportClause.elements;
+    }
+    const diagnostics = getDiagnosticsWithinSpan(
+      createTextSpanFromNode(exportClause),
+      context.program.getSemanticDiagnostics(context.sourceFile, context.cancellationToken)
     );
-    result.diagnostics = concatenate(result.diagnostics, diagnostics);
-    return result;
+    return filter(exportClause.elements, (element) => {
+      var _a;
+      return element === originExportSpecifier || ((_a = findDiagnosticForNode(element, diagnostics)) == null ? void 0 : _a.code) === errorCodes13[0];
+    });
   }
-  var init_transform = __esm({
-    "src/services/transform.ts"() {
+  var errorCodes13, fixId12;
+  var init_convertToTypeOnlyExport = __esm({
+    "src/services/codefixes/convertToTypeOnlyExport.ts"() {
       "use strict";
       init_ts4();
+      init_ts_codefix();
+      errorCodes13 = [Diagnostics.Re_exporting_a_type_when_0_is_enabled_requires_using_export_type.code];
+      fixId12 = "convertToTypeOnlyExport";
+      registerCodeFix({
+        errorCodes: errorCodes13,
+        getCodeActions: function getCodeActionsToConvertToTypeOnlyExport(context) {
+          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => fixSingleExportDeclaration(t, getExportSpecifierForDiagnosticSpan(context.span, context.sourceFile), context));
+          if (changes.length) {
+            return [createCodeFixAction(fixId12, changes, Diagnostics.Convert_to_type_only_export, fixId12, Diagnostics.Convert_all_re_exported_types_to_type_only_exports)];
+          }
+        },
+        fixIds: [fixId12],
+        getAllCodeActions: function getAllCodeActionsToConvertToTypeOnlyExport(context) {
+          const fixedExportDeclarations = /* @__PURE__ */ new Map();
+          return codeFixAll(context, errorCodes13, (changes, diag2) => {
+            const exportSpecifier = getExportSpecifierForDiagnosticSpan(diag2, context.sourceFile);
+            if (exportSpecifier && addToSeen(fixedExportDeclarations, getNodeId(exportSpecifier.parent.parent))) {
+              fixSingleExportDeclaration(changes, exportSpecifier, context);
+            }
+          });
+        }
+      });
     }
   });
 
-  // src/services/shims.ts
-  function logInternalError(logger, err) {
-    if (logger) {
-      logger.log("*INTERNAL ERROR* - Exception in typescript services: " + err.message);
+  // src/services/codefixes/convertToTypeOnlyImport.ts
+  function getDeclaration2(sourceFile, pos) {
+    const { parent: parent2 } = getTokenAtPosition(sourceFile, pos);
+    return isImportSpecifier(parent2) || isImportDeclaration(parent2) && parent2.importClause ? parent2 : void 0;
+  }
+  function canConvertImportDeclarationForSpecifier(specifier, sourceFile, program) {
+    if (specifier.parent.parent.name) {
+      return false;
+    }
+    const nonTypeOnlySpecifiers = specifier.parent.elements.filter((e) => !e.isTypeOnly);
+    if (nonTypeOnlySpecifiers.length === 1) {
+      return true;
+    }
+    const checker = program.getTypeChecker();
+    for (const specifier2 of nonTypeOnlySpecifiers) {
+      const isUsedAsValue = ts_FindAllReferences_exports.Core.eachSymbolReferenceInFile(specifier2.name, checker, sourceFile, (usage) => {
+        return !isValidTypeOnlyAliasUseSite(usage);
+      });
+      if (isUsedAsValue) {
+        return false;
+      }
     }
+    return true;
   }
-  function simpleForwardCall(logger, actionDescription2, action, logPerformance) {
-    let start;
-    if (logPerformance) {
-      logger.log(actionDescription2);
-      start = timestamp();
+  function doChange11(changes, sourceFile, declaration) {
+    var _a;
+    if (isImportSpecifier(declaration)) {
+      changes.replaceNode(sourceFile, declaration, factory.updateImportSpecifier(
+        declaration,
+        /*isTypeOnly*/
+        true,
+        declaration.propertyName,
+        declaration.name
+      ));
+    } else {
+      const importClause = declaration.importClause;
+      if (importClause.name && importClause.namedBindings) {
+        changes.replaceNodeWithNodes(sourceFile, declaration, [
+          factory.createImportDeclaration(
+            getSynthesizedDeepClones(
+              declaration.modifiers,
+              /*includeTrivia*/
+              true
+            ),
+            factory.createImportClause(
+              /*isTypeOnly*/
+              true,
+              getSynthesizedDeepClone(
+                importClause.name,
+                /*includeTrivia*/
+                true
+              ),
+              /*namedBindings*/
+              void 0
+            ),
+            getSynthesizedDeepClone(
+              declaration.moduleSpecifier,
+              /*includeTrivia*/
+              true
+            ),
+            getSynthesizedDeepClone(
+              declaration.attributes,
+              /*includeTrivia*/
+              true
+            )
+          ),
+          factory.createImportDeclaration(
+            getSynthesizedDeepClones(
+              declaration.modifiers,
+              /*includeTrivia*/
+              true
+            ),
+            factory.createImportClause(
+              /*isTypeOnly*/
+              true,
+              /*name*/
+              void 0,
+              getSynthesizedDeepClone(
+                importClause.namedBindings,
+                /*includeTrivia*/
+                true
+              )
+            ),
+            getSynthesizedDeepClone(
+              declaration.moduleSpecifier,
+              /*includeTrivia*/
+              true
+            ),
+            getSynthesizedDeepClone(
+              declaration.attributes,
+              /*includeTrivia*/
+              true
+            )
+          )
+        ]);
+      } else {
+        const newNamedBindings = ((_a = importClause.namedBindings) == null ? void 0 : _a.kind) === 275 /* NamedImports */ ? factory.updateNamedImports(
+          importClause.namedBindings,
+          sameMap(importClause.namedBindings.elements, (e) => factory.updateImportSpecifier(
+            e,
+            /*isTypeOnly*/
+            false,
+            e.propertyName,
+            e.name
+          ))
+        ) : importClause.namedBindings;
+        const importDeclaration = factory.updateImportDeclaration(declaration, declaration.modifiers, factory.updateImportClause(
+          importClause,
+          /*isTypeOnly*/
+          true,
+          importClause.name,
+          newNamedBindings
+        ), declaration.moduleSpecifier, declaration.attributes);
+        changes.replaceNode(sourceFile, declaration, importDeclaration);
+      }
     }
-    const result = action();
-    if (logPerformance) {
-      const end = timestamp();
-      logger.log(`${actionDescription2} completed in ${end - start} msec`);
-      if (isString(result)) {
-        let str = result;
-        if (str.length > 128) {
-          str = str.substring(0, 128) + "...";
+  }
+  var errorCodes14, fixId13;
+  var init_convertToTypeOnlyImport = __esm({
+    "src/services/codefixes/convertToTypeOnlyImport.ts"() {
+      "use strict";
+      init_ts4();
+      init_ts_codefix();
+      errorCodes14 = [
+        Diagnostics.This_import_is_never_used_as_a_value_and_must_use_import_type_because_importsNotUsedAsValues_is_set_to_error.code,
+        Diagnostics._0_is_a_type_and_must_be_imported_using_a_type_only_import_when_verbatimModuleSyntax_is_enabled.code
+      ];
+      fixId13 = "convertToTypeOnlyImport";
+      registerCodeFix({
+        errorCodes: errorCodes14,
+        getCodeActions: function getCodeActionsToConvertToTypeOnlyImport(context) {
+          var _a;
+          const declaration = getDeclaration2(context.sourceFile, context.span.start);
+          if (declaration) {
+            const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange11(t, context.sourceFile, declaration));
+            const importDeclarationChanges = declaration.kind === 276 /* ImportSpecifier */ && canConvertImportDeclarationForSpecifier(declaration, context.sourceFile, context.program) ? ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange11(t, context.sourceFile, declaration.parent.parent.parent)) : void 0;
+            const mainAction = createCodeFixAction(
+              fixId13,
+              changes,
+              declaration.kind === 276 /* ImportSpecifier */ ? [Diagnostics.Use_type_0, ((_a = declaration.propertyName) == null ? void 0 : _a.text) ?? declaration.name.text] : Diagnostics.Use_import_type,
+              fixId13,
+              Diagnostics.Fix_all_with_type_only_imports
+            );
+            if (some(importDeclarationChanges)) {
+              return [
+                createCodeFixActionWithoutFixAll(fixId13, importDeclarationChanges, Diagnostics.Use_import_type),
+                mainAction
+              ];
+            }
+            return [mainAction];
+          }
+          return void 0;
+        },
+        fixIds: [fixId13],
+        getAllCodeActions: function getAllCodeActionsToConvertToTypeOnlyImport(context) {
+          const fixedImportDeclarations = /* @__PURE__ */ new Set();
+          return codeFixAll(context, errorCodes14, (changes, diag2) => {
+            const errorDeclaration = getDeclaration2(diag2.file, diag2.start);
+            if ((errorDeclaration == null ? void 0 : errorDeclaration.kind) === 272 /* ImportDeclaration */ && !fixedImportDeclarations.has(errorDeclaration)) {
+              doChange11(changes, diag2.file, errorDeclaration);
+              fixedImportDeclarations.add(errorDeclaration);
+            } else if ((errorDeclaration == null ? void 0 : errorDeclaration.kind) === 276 /* ImportSpecifier */ && !fixedImportDeclarations.has(errorDeclaration.parent.parent.parent) && canConvertImportDeclarationForSpecifier(errorDeclaration, diag2.file, context.program)) {
+              doChange11(changes, diag2.file, errorDeclaration.parent.parent.parent);
+              fixedImportDeclarations.add(errorDeclaration.parent.parent.parent);
+            } else if ((errorDeclaration == null ? void 0 : errorDeclaration.kind) === 276 /* ImportSpecifier */) {
+              doChange11(changes, diag2.file, errorDeclaration);
+            }
+          });
         }
-        logger.log(`  result.length=${str.length}, result='${JSON.stringify(str)}'`);
+      });
+    }
+  });
+
+  // src/services/codefixes/convertTypedefToType.ts
+  function doChange12(changes, node, sourceFile, newLine, fixAll = false) {
+    if (!isJSDocTypedefTag(node))
+      return;
+    const declaration = createDeclaration(node);
+    if (!declaration)
+      return;
+    const commentNode = node.parent;
+    const { leftSibling, rightSibling } = getLeftAndRightSiblings(node);
+    let pos = commentNode.getStart();
+    let prefix = "";
+    if (!leftSibling && commentNode.comment) {
+      pos = findEndOfTextBetween(commentNode, commentNode.getStart(), node.getStart());
+      prefix = `${newLine} */${newLine}`;
+    }
+    if (leftSibling) {
+      if (fixAll && isJSDocTypedefTag(leftSibling)) {
+        pos = node.getStart();
+        prefix = "";
+      } else {
+        pos = findEndOfTextBetween(commentNode, leftSibling.getStart(), node.getStart());
+        prefix = `${newLine} */${newLine}`;
       }
     }
-    return result;
+    let end = commentNode.getEnd();
+    let suffix = "";
+    if (rightSibling) {
+      if (fixAll && isJSDocTypedefTag(rightSibling)) {
+        end = rightSibling.getStart();
+        suffix = `${newLine}${newLine}`;
+      } else {
+        end = rightSibling.getStart();
+        suffix = `${newLine}/**${newLine} * `;
+      }
+    }
+    changes.replaceRange(sourceFile, { pos, end }, declaration, { prefix, suffix });
   }
-  function forwardJSONCall(logger, actionDescription2, action, logPerformance) {
-    return forwardCall(
-      logger,
-      actionDescription2,
-      /*returnJson*/
-      true,
-      action,
-      logPerformance
+  function getLeftAndRightSiblings(typedefNode) {
+    const commentNode = typedefNode.parent;
+    const maxChildIndex = commentNode.getChildCount() - 1;
+    const currentNodeIndex = commentNode.getChildren().findIndex(
+      (n) => n.getStart() === typedefNode.getStart() && n.getEnd() === typedefNode.getEnd()
     );
+    const leftSibling = currentNodeIndex > 0 ? commentNode.getChildAt(currentNodeIndex - 1) : void 0;
+    const rightSibling = currentNodeIndex < maxChildIndex ? commentNode.getChildAt(currentNodeIndex + 1) : void 0;
+    return { leftSibling, rightSibling };
   }
-  function forwardCall(logger, actionDescription2, returnJson, action, logPerformance) {
-    try {
-      const result = simpleForwardCall(logger, actionDescription2, action, logPerformance);
-      return returnJson ? JSON.stringify({ result }) : result;
-    } catch (err) {
-      if (err instanceof OperationCanceledException) {
-        return JSON.stringify({ canceled: true });
+  function findEndOfTextBetween(jsDocComment, from, to) {
+    const comment = jsDocComment.getText().substring(from - jsDocComment.getStart(), to - jsDocComment.getStart());
+    for (let i = comment.length; i > 0; i--) {
+      if (!/[*/\s]/g.test(comment.substring(i - 1, i))) {
+        return from + i;
       }
-      logInternalError(logger, err);
-      err.description = actionDescription2;
-      return JSON.stringify({ error: err });
+    }
+    return to;
+  }
+  function createDeclaration(tag) {
+    var _a;
+    const { typeExpression } = tag;
+    if (!typeExpression)
+      return;
+    const typeName = (_a = tag.name) == null ? void 0 : _a.getText();
+    if (!typeName)
+      return;
+    if (typeExpression.kind === 329 /* JSDocTypeLiteral */) {
+      return createInterfaceForTypeLiteral(typeName, typeExpression);
+    }
+    if (typeExpression.kind === 316 /* JSDocTypeExpression */) {
+      return createTypeAliasForTypeExpression(typeName, typeExpression);
     }
   }
-  function realizeDiagnostics(diagnostics, newLine) {
-    return diagnostics.map((d) => realizeDiagnostic(d, newLine));
+  function createInterfaceForTypeLiteral(typeName, typeLiteral) {
+    const propertySignatures = createSignatureFromTypeLiteral(typeLiteral);
+    if (!some(propertySignatures))
+      return;
+    return factory.createInterfaceDeclaration(
+      /*modifiers*/
+      void 0,
+      typeName,
+      /*typeParameters*/
+      void 0,
+      /*heritageClauses*/
+      void 0,
+      propertySignatures
+    );
   }
-  function realizeDiagnostic(diagnostic, newLine) {
-    return {
-      message: flattenDiagnosticMessageText(diagnostic.messageText, newLine),
-      start: diagnostic.start,
-      // TODO: GH#18217
-      length: diagnostic.length,
-      // TODO: GH#18217
-      category: diagnosticCategoryName(diagnostic),
-      code: diagnostic.code,
-      reportsUnnecessary: diagnostic.reportsUnnecessary,
-      reportsDeprecated: diagnostic.reportsDeprecated
+  function createTypeAliasForTypeExpression(typeName, typeExpression) {
+    const typeReference = getSynthesizedDeepClone(typeExpression.type);
+    if (!typeReference)
+      return;
+    return factory.createTypeAliasDeclaration(
+      /*modifiers*/
+      void 0,
+      factory.createIdentifier(typeName),
+      /*typeParameters*/
+      void 0,
+      typeReference
+    );
+  }
+  function createSignatureFromTypeLiteral(typeLiteral) {
+    const propertyTags = typeLiteral.jsDocPropertyTags;
+    if (!some(propertyTags))
+      return;
+    const getSignature = (tag) => {
+      var _a;
+      const name = getPropertyName(tag);
+      const type = (_a = tag.typeExpression) == null ? void 0 : _a.type;
+      const isOptional = tag.isBracketed;
+      let typeReference;
+      if (type && isJSDocTypeLiteral(type)) {
+        const signatures = createSignatureFromTypeLiteral(type);
+        typeReference = factory.createTypeLiteralNode(signatures);
+      } else if (type) {
+        typeReference = getSynthesizedDeepClone(type);
+      }
+      if (typeReference && name) {
+        const questionToken = isOptional ? factory.createToken(58 /* QuestionToken */) : void 0;
+        return factory.createPropertySignature(
+          /*modifiers*/
+          void 0,
+          name,
+          questionToken,
+          typeReference
+        );
+      }
     };
+    return mapDefined(propertyTags, getSignature);
+  }
+  function getPropertyName(tag) {
+    return tag.name.kind === 80 /* Identifier */ ? tag.name.text : tag.name.right.text;
   }
-  function convertClassifications(classifications) {
-    return { spans: classifications.spans.join(","), endOfLineState: classifications.endOfLineState };
+  function getJSDocTypedefNodes(node) {
+    if (hasJSDocNodes(node)) {
+      return flatMap(node.jsDoc, (doc) => {
+        var _a;
+        return (_a = doc.tags) == null ? void 0 : _a.filter((tag) => isJSDocTypedefTag(tag));
+      });
+    }
+    return [];
   }
-  var debugObjectHost, ScriptSnapshotShimAdapter, LanguageServiceShimHostAdapter, CoreServicesShimHostAdapter, ShimBase, LanguageServiceShimObject, ClassifierShimObject, CoreServicesShimObject, TypeScriptServicesFactory;
-  var init_shims = __esm({
-    "src/services/shims.ts"() {
+  var fixId14, errorCodes15;
+  var init_convertTypedefToType = __esm({
+    "src/services/codefixes/convertTypedefToType.ts"() {
       "use strict";
       init_ts4();
-      debugObjectHost = function() {
-        return this;
-      }();
-      ScriptSnapshotShimAdapter = class {
-        constructor(scriptSnapshotShim) {
-          this.scriptSnapshotShim = scriptSnapshotShim;
-        }
-        getText(start, end) {
-          return this.scriptSnapshotShim.getText(start, end);
-        }
-        getLength() {
-          return this.scriptSnapshotShim.getLength();
-        }
-        getChangeRange(oldSnapshot) {
-          const oldSnapshotShim = oldSnapshot;
-          const encoded = this.scriptSnapshotShim.getChangeRange(oldSnapshotShim.scriptSnapshotShim);
-          if (encoded === null) {
-            return null;
-          }
-          const decoded = JSON.parse(encoded);
-          return createTextChangeRange(
-            createTextSpan(decoded.span.start, decoded.span.length),
-            decoded.newLength
-          );
-        }
-        dispose() {
-          if ("dispose" in this.scriptSnapshotShim) {
-            this.scriptSnapshotShim.dispose();
-          }
-        }
-      };
-      LanguageServiceShimHostAdapter = class {
-        constructor(shimHost) {
-          this.shimHost = shimHost;
-          this.loggingEnabled = false;
-          this.tracingEnabled = false;
-          if ("getModuleResolutionsForFile" in this.shimHost) {
-            this.resolveModuleNames = (moduleNames, containingFile) => {
-              const resolutionsInFile = JSON.parse(this.shimHost.getModuleResolutionsForFile(containingFile));
-              return map(moduleNames, (name) => {
-                const result = getProperty(resolutionsInFile, name);
-                return result ? { resolvedFileName: result, extension: extensionFromPath(result), isExternalLibraryImport: false } : void 0;
-              });
-            };
-          }
-          if ("directoryExists" in this.shimHost) {
-            this.directoryExists = (directoryName) => this.shimHost.directoryExists(directoryName);
-          }
-          if ("getTypeReferenceDirectiveResolutionsForFile" in this.shimHost) {
-            this.resolveTypeReferenceDirectives = (typeDirectiveNames, containingFile) => {
-              const typeDirectivesForFile = JSON.parse(this.shimHost.getTypeReferenceDirectiveResolutionsForFile(containingFile));
-              return map(typeDirectiveNames, (name) => getProperty(typeDirectivesForFile, isString(name) ? name : toFileNameLowerCase(name.fileName)));
-            };
-          }
-        }
-        log(s) {
-          if (this.loggingEnabled) {
-            this.shimHost.log(s);
-          }
-        }
-        trace(s) {
-          if (this.tracingEnabled) {
-            this.shimHost.trace(s);
-          }
-        }
-        error(s) {
-          this.shimHost.error(s);
-        }
-        getProjectVersion() {
-          if (!this.shimHost.getProjectVersion) {
-            return void 0;
-          }
-          return this.shimHost.getProjectVersion();
-        }
-        getTypeRootsVersion() {
-          if (!this.shimHost.getTypeRootsVersion) {
-            return 0;
-          }
-          return this.shimHost.getTypeRootsVersion();
-        }
-        useCaseSensitiveFileNames() {
-          return this.shimHost.useCaseSensitiveFileNames ? this.shimHost.useCaseSensitiveFileNames() : false;
-        }
-        getCompilationSettings() {
-          const settingsJson = this.shimHost.getCompilationSettings();
-          if (settingsJson === null || settingsJson === "") {
-            throw Error("LanguageServiceShimHostAdapter.getCompilationSettings: empty compilationSettings");
-          }
-          const compilerOptions = JSON.parse(settingsJson);
-          compilerOptions.allowNonTsExtensions = true;
-          return compilerOptions;
-        }
-        getScriptFileNames() {
-          const encoded = this.shimHost.getScriptFileNames();
-          return JSON.parse(encoded);
-        }
-        getScriptSnapshot(fileName) {
-          const scriptSnapshot = this.shimHost.getScriptSnapshot(fileName);
-          return scriptSnapshot && new ScriptSnapshotShimAdapter(scriptSnapshot);
-        }
-        getScriptKind(fileName) {
-          if ("getScriptKind" in this.shimHost) {
-            return this.shimHost.getScriptKind(fileName);
-          } else {
-            return 0 /* Unknown */;
-          }
-        }
-        getScriptVersion(fileName) {
-          return this.shimHost.getScriptVersion(fileName);
-        }
-        getLocalizedDiagnosticMessages() {
-          const diagnosticMessagesJson = this.shimHost.getLocalizedDiagnosticMessages();
-          if (diagnosticMessagesJson === null || diagnosticMessagesJson === "") {
-            return null;
-          }
-          try {
-            return JSON.parse(diagnosticMessagesJson);
-          } catch (e) {
-            this.log(e.description || "diagnosticMessages.generated.json has invalid JSON format");
-            return null;
-          }
-        }
-        getCancellationToken() {
-          const hostCancellationToken = this.shimHost.getCancellationToken();
-          return new ThrottledCancellationToken(hostCancellationToken);
-        }
-        getCurrentDirectory() {
-          return this.shimHost.getCurrentDirectory();
-        }
-        getDirectories(path) {
-          return JSON.parse(this.shimHost.getDirectories(path));
-        }
-        getDefaultLibFileName(options) {
-          return this.shimHost.getDefaultLibFileName(JSON.stringify(options));
-        }
-        readDirectory(path, extensions, exclude, include, depth) {
-          const pattern = getFileMatcherPatterns(
-            path,
-            exclude,
-            include,
-            this.shimHost.useCaseSensitiveFileNames(),
-            this.shimHost.getCurrentDirectory()
-          );
-          return JSON.parse(this.shimHost.readDirectory(
-            path,
-            JSON.stringify(extensions),
-            JSON.stringify(pattern.basePaths),
-            pattern.excludePattern,
-            pattern.includeFilePattern,
-            pattern.includeDirectoryPattern,
-            depth
-          ));
-        }
-        readFile(path, encoding) {
-          return this.shimHost.readFile(path, encoding);
-        }
-        fileExists(path) {
-          return this.shimHost.fileExists(path);
-        }
-      };
-      CoreServicesShimHostAdapter = class {
-        constructor(shimHost) {
-          this.shimHost = shimHost;
-          this.useCaseSensitiveFileNames = this.shimHost.useCaseSensitiveFileNames ? this.shimHost.useCaseSensitiveFileNames() : false;
-          if ("directoryExists" in this.shimHost) {
-            this.directoryExists = (directoryName) => this.shimHost.directoryExists(directoryName);
-          } else {
-            this.directoryExists = void 0;
-          }
-          if ("realpath" in this.shimHost) {
-            this.realpath = (path) => this.shimHost.realpath(path);
-          } else {
-            this.realpath = void 0;
-          }
-        }
-        readDirectory(rootDir, extensions, exclude, include, depth) {
-          const pattern = getFileMatcherPatterns(
-            rootDir,
-            exclude,
-            include,
-            this.shimHost.useCaseSensitiveFileNames(),
-            this.shimHost.getCurrentDirectory()
+      init_ts_codefix();
+      fixId14 = "convertTypedefToType";
+      errorCodes15 = [Diagnostics.JSDoc_typedef_may_be_converted_to_TypeScript_type.code];
+      registerCodeFix({
+        fixIds: [fixId14],
+        errorCodes: errorCodes15,
+        getCodeActions(context) {
+          const newLineCharacter = getNewLineOrDefaultFromHost(context.host, context.formatContext.options);
+          const node = getTokenAtPosition(
+            context.sourceFile,
+            context.span.start
           );
-          return JSON.parse(this.shimHost.readDirectory(
-            rootDir,
-            JSON.stringify(extensions),
-            JSON.stringify(pattern.basePaths),
-            pattern.excludePattern,
-            pattern.includeFilePattern,
-            pattern.includeDirectoryPattern,
-            depth
-          ));
-        }
-        fileExists(fileName) {
-          return this.shimHost.fileExists(fileName);
-        }
-        readFile(fileName) {
-          return this.shimHost.readFile(fileName);
-        }
-        getDirectories(path) {
-          return JSON.parse(this.shimHost.getDirectories(path));
-        }
-      };
-      ShimBase = class {
-        constructor(factory2) {
-          this.factory = factory2;
-          factory2.registerShim(this);
-        }
-        dispose(_dummy) {
-          this.factory.unregisterShim(this);
-        }
-      };
-      LanguageServiceShimObject = class extends ShimBase {
-        constructor(factory2, host, languageService) {
-          super(factory2);
-          this.host = host;
-          this.languageService = languageService;
-          this.logPerformance = false;
-          this.logger = this.host;
-        }
-        forwardJSONCall(actionDescription2, action) {
-          return forwardJSONCall(this.logger, actionDescription2, action, this.logPerformance);
-        }
-        /// DISPOSE
-        /**
-         * Ensure (almost) deterministic release of internal Javascript resources when
-         * some external native objects holds onto us (e.g. Com/Interop).
-         */
-        dispose(dummy) {
-          this.logger.log("dispose()");
-          this.languageService.dispose();
-          this.languageService = null;
-          if (debugObjectHost && debugObjectHost.CollectGarbage) {
-            debugObjectHost.CollectGarbage();
-            this.logger.log("CollectGarbage()");
+          if (!node)
+            return;
+          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange12(t, node, context.sourceFile, newLineCharacter));
+          if (changes.length > 0) {
+            return [
+              createCodeFixAction(
+                fixId14,
+                changes,
+                Diagnostics.Convert_typedef_to_TypeScript_type,
+                fixId14,
+                Diagnostics.Convert_all_typedef_to_TypeScript_types
+              )
+            ];
           }
-          this.logger = null;
-          super.dispose(dummy);
-        }
-        /// REFRESH
-        /**
-         * Update the list of scripts known to the compiler
-         */
-        refresh(throwOnError) {
-          this.forwardJSONCall(
-            `refresh(${throwOnError})`,
-            () => null
-            // eslint-disable-line no-null/no-null
-          );
-        }
-        cleanupSemanticCache() {
-          this.forwardJSONCall(
-            "cleanupSemanticCache()",
-            () => {
-              this.languageService.cleanupSemanticCache();
-              return null;
-            }
-          );
-        }
-        realizeDiagnostics(diagnostics) {
-          const newLine = getNewLineOrDefaultFromHost(
-            this.host,
-            /*formatSettings*/
-            void 0
-          );
-          return realizeDiagnostics(diagnostics, newLine);
-        }
-        getSyntacticClassifications(fileName, start, length2) {
-          return this.forwardJSONCall(
-            `getSyntacticClassifications('${fileName}', ${start}, ${length2})`,
-            () => this.languageService.getSyntacticClassifications(fileName, createTextSpan(start, length2))
-          );
-        }
-        getSemanticClassifications(fileName, start, length2) {
-          return this.forwardJSONCall(
-            `getSemanticClassifications('${fileName}', ${start}, ${length2})`,
-            () => this.languageService.getSemanticClassifications(fileName, createTextSpan(start, length2))
-          );
-        }
-        getEncodedSyntacticClassifications(fileName, start, length2) {
-          return this.forwardJSONCall(
-            `getEncodedSyntacticClassifications('${fileName}', ${start}, ${length2})`,
-            // directly serialize the spans out to a string.  This is much faster to decode
-            // on the managed side versus a full JSON array.
-            () => convertClassifications(this.languageService.getEncodedSyntacticClassifications(fileName, createTextSpan(start, length2)))
-          );
-        }
-        getEncodedSemanticClassifications(fileName, start, length2) {
-          return this.forwardJSONCall(
-            `getEncodedSemanticClassifications('${fileName}', ${start}, ${length2})`,
-            // directly serialize the spans out to a string.  This is much faster to decode
-            // on the managed side versus a full JSON array.
-            () => convertClassifications(this.languageService.getEncodedSemanticClassifications(fileName, createTextSpan(start, length2)))
-          );
-        }
-        getSyntacticDiagnostics(fileName) {
-          return this.forwardJSONCall(
-            `getSyntacticDiagnostics('${fileName}')`,
-            () => {
-              const diagnostics = this.languageService.getSyntacticDiagnostics(fileName);
-              return this.realizeDiagnostics(diagnostics);
-            }
-          );
-        }
-        getSemanticDiagnostics(fileName) {
-          return this.forwardJSONCall(
-            `getSemanticDiagnostics('${fileName}')`,
-            () => {
-              const diagnostics = this.languageService.getSemanticDiagnostics(fileName);
-              return this.realizeDiagnostics(diagnostics);
-            }
-          );
-        }
-        getSuggestionDiagnostics(fileName) {
-          return this.forwardJSONCall(`getSuggestionDiagnostics('${fileName}')`, () => this.realizeDiagnostics(this.languageService.getSuggestionDiagnostics(fileName)));
-        }
-        getCompilerOptionsDiagnostics() {
-          return this.forwardJSONCall(
-            "getCompilerOptionsDiagnostics()",
-            () => {
-              const diagnostics = this.languageService.getCompilerOptionsDiagnostics();
-              return this.realizeDiagnostics(diagnostics);
-            }
-          );
-        }
-        /// QUICKINFO
-        /**
-         * Computes a string representation of the type at the requested position
-         * in the active file.
-         */
-        getQuickInfoAtPosition(fileName, position) {
-          return this.forwardJSONCall(
-            `getQuickInfoAtPosition('${fileName}', ${position})`,
-            () => this.languageService.getQuickInfoAtPosition(fileName, position)
-          );
-        }
-        /// NAMEORDOTTEDNAMESPAN
-        /**
-         * Computes span information of the name or dotted name at the requested position
-         * in the active file.
-         */
-        getNameOrDottedNameSpan(fileName, startPos, endPos) {
-          return this.forwardJSONCall(
-            `getNameOrDottedNameSpan('${fileName}', ${startPos}, ${endPos})`,
-            () => this.languageService.getNameOrDottedNameSpan(fileName, startPos, endPos)
-          );
-        }
-        /**
-         * STATEMENTSPAN
-         * Computes span information of statement at the requested position in the active file.
-         */
-        getBreakpointStatementAtPosition(fileName, position) {
-          return this.forwardJSONCall(
-            `getBreakpointStatementAtPosition('${fileName}', ${position})`,
-            () => this.languageService.getBreakpointStatementAtPosition(fileName, position)
-          );
-        }
-        /// SIGNATUREHELP
-        getSignatureHelpItems(fileName, position, options) {
-          return this.forwardJSONCall(
-            `getSignatureHelpItems('${fileName}', ${position})`,
-            () => this.languageService.getSignatureHelpItems(fileName, position, options)
-          );
-        }
-        /// GOTO DEFINITION
-        /**
-         * Computes the definition location and file for the symbol
-         * at the requested position.
-         */
-        getDefinitionAtPosition(fileName, position) {
-          return this.forwardJSONCall(
-            `getDefinitionAtPosition('${fileName}', ${position})`,
-            () => this.languageService.getDefinitionAtPosition(fileName, position)
-          );
-        }
-        /**
-         * Computes the definition location and file for the symbol
-         * at the requested position.
-         */
-        getDefinitionAndBoundSpan(fileName, position) {
-          return this.forwardJSONCall(
-            `getDefinitionAndBoundSpan('${fileName}', ${position})`,
-            () => this.languageService.getDefinitionAndBoundSpan(fileName, position)
-          );
-        }
-        /// GOTO Type
-        /**
-         * Computes the definition location of the type of the symbol
-         * at the requested position.
-         */
-        getTypeDefinitionAtPosition(fileName, position) {
-          return this.forwardJSONCall(
-            `getTypeDefinitionAtPosition('${fileName}', ${position})`,
-            () => this.languageService.getTypeDefinitionAtPosition(fileName, position)
-          );
-        }
-        /// GOTO Implementation
-        /**
-         * Computes the implementation location of the symbol
-         * at the requested position.
-         */
-        getImplementationAtPosition(fileName, position) {
-          return this.forwardJSONCall(
-            `getImplementationAtPosition('${fileName}', ${position})`,
-            () => this.languageService.getImplementationAtPosition(fileName, position)
-          );
-        }
-        getRenameInfo(fileName, position, preferences) {
-          return this.forwardJSONCall(
-            `getRenameInfo('${fileName}', ${position})`,
-            () => this.languageService.getRenameInfo(fileName, position, preferences)
-          );
-        }
-        getSmartSelectionRange(fileName, position) {
-          return this.forwardJSONCall(
-            `getSmartSelectionRange('${fileName}', ${position})`,
-            () => this.languageService.getSmartSelectionRange(fileName, position)
-          );
-        }
-        findRenameLocations(fileName, position, findInStrings, findInComments, preferences) {
-          return this.forwardJSONCall(
-            `findRenameLocations('${fileName}', ${position}, ${findInStrings}, ${findInComments})`,
-            () => this.languageService.findRenameLocations(fileName, position, findInStrings, findInComments, preferences)
-          );
-        }
-        /// GET BRACE MATCHING
-        getBraceMatchingAtPosition(fileName, position) {
-          return this.forwardJSONCall(
-            `getBraceMatchingAtPosition('${fileName}', ${position})`,
-            () => this.languageService.getBraceMatchingAtPosition(fileName, position)
-          );
-        }
-        isValidBraceCompletionAtPosition(fileName, position, openingBrace) {
-          return this.forwardJSONCall(
-            `isValidBraceCompletionAtPosition('${fileName}', ${position}, ${openingBrace})`,
-            () => this.languageService.isValidBraceCompletionAtPosition(fileName, position, openingBrace)
-          );
-        }
-        getSpanOfEnclosingComment(fileName, position, onlyMultiLine) {
-          return this.forwardJSONCall(
-            `getSpanOfEnclosingComment('${fileName}', ${position})`,
-            () => this.languageService.getSpanOfEnclosingComment(fileName, position, onlyMultiLine)
-          );
-        }
-        /// GET SMART INDENT
-        getIndentationAtPosition(fileName, position, options) {
-          return this.forwardJSONCall(
-            `getIndentationAtPosition('${fileName}', ${position})`,
-            () => {
-              const localOptions = JSON.parse(options);
-              return this.languageService.getIndentationAtPosition(fileName, position, localOptions);
-            }
-          );
-        }
-        /// GET REFERENCES
-        getReferencesAtPosition(fileName, position) {
-          return this.forwardJSONCall(
-            `getReferencesAtPosition('${fileName}', ${position})`,
-            () => this.languageService.getReferencesAtPosition(fileName, position)
-          );
-        }
-        findReferences(fileName, position) {
-          return this.forwardJSONCall(
-            `findReferences('${fileName}', ${position})`,
-            () => this.languageService.findReferences(fileName, position)
-          );
-        }
-        getFileReferences(fileName) {
-          return this.forwardJSONCall(
-            `getFileReferences('${fileName})`,
-            () => this.languageService.getFileReferences(fileName)
-          );
-        }
-        getDocumentHighlights(fileName, position, filesToSearch) {
-          return this.forwardJSONCall(
-            `getDocumentHighlights('${fileName}', ${position})`,
-            () => {
-              const results = this.languageService.getDocumentHighlights(fileName, position, JSON.parse(filesToSearch));
-              const normalizedName = toFileNameLowerCase(normalizeSlashes(fileName));
-              return filter(results, (r) => toFileNameLowerCase(normalizeSlashes(r.fileName)) === normalizedName);
-            }
-          );
-        }
-        /// COMPLETION LISTS
-        /**
-         * Get a string based representation of the completions
-         * to provide at the given source position and providing a member completion
-         * list if requested.
-         */
-        getCompletionsAtPosition(fileName, position, preferences, formattingSettings) {
-          return this.forwardJSONCall(
-            `getCompletionsAtPosition('${fileName}', ${position}, ${preferences}, ${formattingSettings})`,
-            () => this.languageService.getCompletionsAtPosition(fileName, position, preferences, formattingSettings)
-          );
-        }
-        /** Get a string based representation of a completion list entry details */
-        getCompletionEntryDetails(fileName, position, entryName, formatOptions, source, preferences, data) {
-          return this.forwardJSONCall(
-            `getCompletionEntryDetails('${fileName}', ${position}, '${entryName}')`,
-            () => {
-              const localOptions = formatOptions === void 0 ? void 0 : JSON.parse(formatOptions);
-              return this.languageService.getCompletionEntryDetails(fileName, position, entryName, localOptions, source, preferences, data);
-            }
-          );
-        }
-        getFormattingEditsForRange(fileName, start, end, options) {
-          return this.forwardJSONCall(
-            `getFormattingEditsForRange('${fileName}', ${start}, ${end})`,
-            () => {
-              const localOptions = JSON.parse(options);
-              return this.languageService.getFormattingEditsForRange(fileName, start, end, localOptions);
-            }
-          );
-        }
-        getFormattingEditsForDocument(fileName, options) {
-          return this.forwardJSONCall(
-            `getFormattingEditsForDocument('${fileName}')`,
-            () => {
-              const localOptions = JSON.parse(options);
-              return this.languageService.getFormattingEditsForDocument(fileName, localOptions);
-            }
-          );
-        }
-        getFormattingEditsAfterKeystroke(fileName, position, key, options) {
-          return this.forwardJSONCall(
-            `getFormattingEditsAfterKeystroke('${fileName}', ${position}, '${key}')`,
-            () => {
-              const localOptions = JSON.parse(options);
-              return this.languageService.getFormattingEditsAfterKeystroke(fileName, position, key, localOptions);
-            }
-          );
-        }
-        getDocCommentTemplateAtPosition(fileName, position, options, formatOptions) {
-          return this.forwardJSONCall(
-            `getDocCommentTemplateAtPosition('${fileName}', ${position})`,
-            () => this.languageService.getDocCommentTemplateAtPosition(fileName, position, options, formatOptions)
-          );
-        }
-        /// NAVIGATE TO
-        /** Return a list of symbols that are interesting to navigate to */
-        getNavigateToItems(searchValue, maxResultCount, fileName) {
-          return this.forwardJSONCall(
-            `getNavigateToItems('${searchValue}', ${maxResultCount}, ${fileName})`,
-            () => this.languageService.getNavigateToItems(searchValue, maxResultCount, fileName)
-          );
-        }
-        getNavigationBarItems(fileName) {
-          return this.forwardJSONCall(
-            `getNavigationBarItems('${fileName}')`,
-            () => this.languageService.getNavigationBarItems(fileName)
-          );
-        }
-        getNavigationTree(fileName) {
-          return this.forwardJSONCall(
-            `getNavigationTree('${fileName}')`,
-            () => this.languageService.getNavigationTree(fileName)
-          );
-        }
-        getOutliningSpans(fileName) {
-          return this.forwardJSONCall(
-            `getOutliningSpans('${fileName}')`,
-            () => this.languageService.getOutliningSpans(fileName)
-          );
-        }
-        getTodoComments(fileName, descriptors) {
-          return this.forwardJSONCall(
-            `getTodoComments('${fileName}')`,
-            () => this.languageService.getTodoComments(fileName, JSON.parse(descriptors))
-          );
-        }
-        /// CALL HIERARCHY
-        prepareCallHierarchy(fileName, position) {
-          return this.forwardJSONCall(
-            `prepareCallHierarchy('${fileName}', ${position})`,
-            () => this.languageService.prepareCallHierarchy(fileName, position)
-          );
-        }
-        provideCallHierarchyIncomingCalls(fileName, position) {
-          return this.forwardJSONCall(
-            `provideCallHierarchyIncomingCalls('${fileName}', ${position})`,
-            () => this.languageService.provideCallHierarchyIncomingCalls(fileName, position)
-          );
-        }
-        provideCallHierarchyOutgoingCalls(fileName, position) {
-          return this.forwardJSONCall(
-            `provideCallHierarchyOutgoingCalls('${fileName}', ${position})`,
-            () => this.languageService.provideCallHierarchyOutgoingCalls(fileName, position)
-          );
-        }
-        provideInlayHints(fileName, span, preference) {
-          return this.forwardJSONCall(
-            `provideInlayHints('${fileName}', '${JSON.stringify(span)}', ${JSON.stringify(preference)})`,
-            () => this.languageService.provideInlayHints(fileName, span, preference)
-          );
-        }
-        /// Emit
-        getEmitOutput(fileName) {
-          return this.forwardJSONCall(
-            `getEmitOutput('${fileName}')`,
-            () => {
-              const { diagnostics, ...rest } = this.languageService.getEmitOutput(fileName);
-              return { ...rest, diagnostics: this.realizeDiagnostics(diagnostics) };
-            }
-          );
-        }
-        getEmitOutputObject(fileName) {
-          return forwardCall(
-            this.logger,
-            `getEmitOutput('${fileName}')`,
-            /*returnJson*/
-            false,
-            () => this.languageService.getEmitOutput(fileName),
-            this.logPerformance
-          );
-        }
-        toggleLineComment(fileName, textRange) {
-          return this.forwardJSONCall(
-            `toggleLineComment('${fileName}', '${JSON.stringify(textRange)}')`,
-            () => this.languageService.toggleLineComment(fileName, textRange)
-          );
-        }
-        toggleMultilineComment(fileName, textRange) {
-          return this.forwardJSONCall(
-            `toggleMultilineComment('${fileName}', '${JSON.stringify(textRange)}')`,
-            () => this.languageService.toggleMultilineComment(fileName, textRange)
-          );
-        }
-        commentSelection(fileName, textRange) {
-          return this.forwardJSONCall(
-            `commentSelection('${fileName}', '${JSON.stringify(textRange)}')`,
-            () => this.languageService.commentSelection(fileName, textRange)
-          );
-        }
-        uncommentSelection(fileName, textRange) {
-          return this.forwardJSONCall(
-            `uncommentSelection('${fileName}', '${JSON.stringify(textRange)}')`,
-            () => this.languageService.uncommentSelection(fileName, textRange)
-          );
-        }
-      };
-      ClassifierShimObject = class extends ShimBase {
-        constructor(factory2, logger) {
-          super(factory2);
-          this.logger = logger;
-          this.logPerformance = false;
-          this.classifier = createClassifier();
-        }
-        getEncodedLexicalClassifications(text, lexState, syntacticClassifierAbsent = false) {
-          return forwardJSONCall(
-            this.logger,
-            "getEncodedLexicalClassifications",
-            () => convertClassifications(this.classifier.getEncodedLexicalClassifications(text, lexState, syntacticClassifierAbsent)),
-            this.logPerformance
-          );
-        }
-        /// COLORIZATION
-        getClassificationsForLine(text, lexState, classifyKeywordsInGenerics = false) {
-          const classification = this.classifier.getClassificationsForLine(text, lexState, classifyKeywordsInGenerics);
-          let result = "";
-          for (const item of classification.entries) {
-            result += item.length + "\n";
-            result += item.classification + "\n";
+        },
+        getAllCodeActions: (context) => codeFixAll(
+          context,
+          errorCodes15,
+          (changes, diag2) => {
+            const newLineCharacter = getNewLineOrDefaultFromHost(context.host, context.formatContext.options);
+            const node = getTokenAtPosition(diag2.file, diag2.start);
+            const fixAll = true;
+            if (node)
+              doChange12(changes, node, diag2.file, newLineCharacter, fixAll);
           }
-          result += classification.finalLexState;
-          return result;
-        }
+        )
+      });
+    }
+  });
+
+  // src/services/codefixes/convertLiteralTypeToMappedType.ts
+  function getInfo5(sourceFile, pos) {
+    const token = getTokenAtPosition(sourceFile, pos);
+    if (isIdentifier(token)) {
+      const propertySignature = cast(token.parent.parent, isPropertySignature);
+      const propertyName = token.getText(sourceFile);
+      return {
+        container: cast(propertySignature.parent, isTypeLiteralNode),
+        typeNode: propertySignature.type,
+        constraint: propertyName,
+        name: propertyName === "K" ? "P" : "K"
       };
-      CoreServicesShimObject = class extends ShimBase {
-        constructor(factory2, logger, host) {
-          super(factory2);
-          this.logger = logger;
-          this.host = host;
-          this.logPerformance = false;
-        }
-        forwardJSONCall(actionDescription2, action) {
-          return forwardJSONCall(this.logger, actionDescription2, action, this.logPerformance);
-        }
-        resolveModuleName(fileName, moduleName, compilerOptionsJson) {
-          return this.forwardJSONCall(`resolveModuleName('${fileName}')`, () => {
-            const compilerOptions = JSON.parse(compilerOptionsJson);
-            const result = resolveModuleName(moduleName, normalizeSlashes(fileName), compilerOptions, this.host);
-            let resolvedFileName = result.resolvedModule ? result.resolvedModule.resolvedFileName : void 0;
-            if (result.resolvedModule && result.resolvedModule.extension !== ".ts" /* Ts */ && result.resolvedModule.extension !== ".tsx" /* Tsx */ && result.resolvedModule.extension !== ".d.ts" /* Dts */) {
-              resolvedFileName = void 0;
-            }
-            return {
-              resolvedFileName,
-              failedLookupLocations: result.failedLookupLocations,
-              affectingLocations: result.affectingLocations
-            };
-          });
-        }
-        resolveTypeReferenceDirective(fileName, typeReferenceDirective, compilerOptionsJson) {
-          return this.forwardJSONCall(`resolveTypeReferenceDirective(${fileName})`, () => {
-            const compilerOptions = JSON.parse(compilerOptionsJson);
-            const result = resolveTypeReferenceDirective(typeReferenceDirective, normalizeSlashes(fileName), compilerOptions, this.host);
-            return {
-              resolvedFileName: result.resolvedTypeReferenceDirective ? result.resolvedTypeReferenceDirective.resolvedFileName : void 0,
-              primary: result.resolvedTypeReferenceDirective ? result.resolvedTypeReferenceDirective.primary : true,
-              failedLookupLocations: result.failedLookupLocations
-            };
-          });
-        }
-        getPreProcessedFileInfo(fileName, sourceTextSnapshot) {
-          return this.forwardJSONCall(
-            `getPreProcessedFileInfo('${fileName}')`,
-            () => {
-              const result = preProcessFile(
-                getSnapshotText(sourceTextSnapshot),
-                /*readImportFiles*/
-                true,
-                /*detectJavaScriptImports*/
-                true
-              );
-              return {
-                referencedFiles: this.convertFileReferences(result.referencedFiles),
-                importedFiles: this.convertFileReferences(result.importedFiles),
-                ambientExternalModules: result.ambientExternalModules,
-                isLibFile: result.isLibFile,
-                typeReferenceDirectives: this.convertFileReferences(result.typeReferenceDirectives),
-                libReferenceDirectives: this.convertFileReferences(result.libReferenceDirectives)
-              };
-            }
-          );
-        }
-        getAutomaticTypeDirectiveNames(compilerOptionsJson) {
-          return this.forwardJSONCall(
-            `getAutomaticTypeDirectiveNames('${compilerOptionsJson}')`,
-            () => {
-              const compilerOptions = JSON.parse(compilerOptionsJson);
-              return getAutomaticTypeDirectiveNames(compilerOptions, this.host);
-            }
-          );
-        }
-        convertFileReferences(refs) {
-          if (!refs) {
+    }
+    return void 0;
+  }
+  function doChange13(changes, sourceFile, { container, typeNode, constraint, name }) {
+    changes.replaceNode(
+      sourceFile,
+      container,
+      factory.createMappedTypeNode(
+        /*readonlyToken*/
+        void 0,
+        factory.createTypeParameterDeclaration(
+          /*modifiers*/
+          void 0,
+          name,
+          factory.createTypeReferenceNode(constraint)
+        ),
+        /*nameType*/
+        void 0,
+        /*questionToken*/
+        void 0,
+        typeNode,
+        /*members*/
+        void 0
+      )
+    );
+  }
+  var fixId15, errorCodes16;
+  var init_convertLiteralTypeToMappedType = __esm({
+    "src/services/codefixes/convertLiteralTypeToMappedType.ts"() {
+      "use strict";
+      init_ts4();
+      init_ts_codefix();
+      fixId15 = "convertLiteralTypeToMappedType";
+      errorCodes16 = [Diagnostics._0_only_refers_to_a_type_but_is_being_used_as_a_value_here_Did_you_mean_to_use_1_in_0.code];
+      registerCodeFix({
+        errorCodes: errorCodes16,
+        getCodeActions: function getCodeActionsToConvertLiteralTypeToMappedType(context) {
+          const { sourceFile, span } = context;
+          const info = getInfo5(sourceFile, span.start);
+          if (!info) {
             return void 0;
           }
-          const result = [];
-          for (const ref of refs) {
-            result.push({
-              path: normalizeSlashes(ref.fileName),
-              position: ref.pos,
-              length: ref.end - ref.pos
-            });
-          }
-          return result;
-        }
-        getTSConfigFileInfo(fileName, sourceTextSnapshot) {
-          return this.forwardJSONCall(
-            `getTSConfigFileInfo('${fileName}')`,
-            () => {
-              const result = parseJsonText(fileName, getSnapshotText(sourceTextSnapshot));
-              const normalizedFileName = normalizeSlashes(fileName);
-              const configFile = parseJsonSourceFileConfigFileContent(
-                result,
-                this.host,
-                getDirectoryPath(normalizedFileName),
-                /*existingOptions*/
-                {},
-                normalizedFileName
-              );
-              return {
-                options: configFile.options,
-                typeAcquisition: configFile.typeAcquisition,
-                files: configFile.fileNames,
-                raw: configFile.raw,
-                errors: realizeDiagnostics([...result.parseDiagnostics, ...configFile.errors], "\r\n")
-              };
-            }
-          );
-        }
-        getDefaultCompilationSettings() {
-          return this.forwardJSONCall(
-            "getDefaultCompilationSettings()",
-            () => getDefaultCompilerOptions2()
-          );
-        }
-        discoverTypings(discoverTypingsJson) {
-          const getCanonicalFileName = createGetCanonicalFileName(
-            /*useCaseSensitiveFileNames*/
-            false
-          );
-          return this.forwardJSONCall("discoverTypings()", () => {
-            const info = JSON.parse(discoverTypingsJson);
-            if (this.safeList === void 0) {
-              this.safeList = ts_JsTyping_exports.loadSafeList(this.host, toPath(info.safeListPath, info.safeListPath, getCanonicalFileName));
-            }
-            return ts_JsTyping_exports.discoverTypings(
-              this.host,
-              (msg) => this.logger.log(msg),
-              info.fileNames,
-              toPath(info.projectRootPath, info.projectRootPath, getCanonicalFileName),
-              this.safeList,
-              info.packageNameToTypingLocation,
-              info.typeAcquisition,
-              info.unresolvedImports,
-              info.typesRegistry,
-              emptyOptions
-            );
-          });
-        }
-      };
-      TypeScriptServicesFactory = class {
-        constructor() {
-          this._shims = [];
-        }
-        /*
-         * Returns script API version.
-         */
-        getServicesVersion() {
-          return servicesVersion;
-        }
-        createLanguageServiceShim(host) {
-          try {
-            if (this.documentRegistry === void 0) {
-              this.documentRegistry = createDocumentRegistry(host.useCaseSensitiveFileNames && host.useCaseSensitiveFileNames(), host.getCurrentDirectory());
-            }
-            const hostAdapter = new LanguageServiceShimHostAdapter(host);
-            const languageService = createLanguageService(
-              hostAdapter,
-              this.documentRegistry,
-              /*syntaxOnlyOrLanguageServiceMode*/
-              false
-            );
-            return new LanguageServiceShimObject(this, host, languageService);
-          } catch (err) {
-            logInternalError(host, err);
-            throw err;
-          }
-        }
-        createClassifierShim(logger) {
-          try {
-            return new ClassifierShimObject(this, logger);
-          } catch (err) {
-            logInternalError(logger, err);
-            throw err;
-          }
-        }
-        createCoreServicesShim(host) {
-          try {
-            const adapter = new CoreServicesShimHostAdapter(host);
-            return new CoreServicesShimObject(this, host, adapter);
-          } catch (err) {
-            logInternalError(host, err);
-            throw err;
-          }
-        }
-        close() {
-          clear(this._shims);
-          this.documentRegistry = void 0;
-        }
-        registerShim(shim) {
-          this._shims.push(shim);
-        }
-        unregisterShim(shim) {
-          for (let i = 0; i < this._shims.length; i++) {
-            if (this._shims[i] === shim) {
-              delete this._shims[i];
-              return;
-            }
+          const { name, constraint } = info;
+          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange13(t, sourceFile, info));
+          return [createCodeFixAction(fixId15, changes, [Diagnostics.Convert_0_to_1_in_0, constraint, name], fixId15, Diagnostics.Convert_all_type_literals_to_mapped_type)];
+        },
+        fixIds: [fixId15],
+        getAllCodeActions: (context) => codeFixAll(context, errorCodes16, (changes, diag2) => {
+          const info = getInfo5(diag2.file, diag2.start);
+          if (info) {
+            doChange13(changes, diag2.file, info);
           }
-          throw new Error("Invalid operation");
-        }
-      };
+        })
+      });
     }
   });
 
-  // src/services/breakpoints.ts
-  function spanInSourceFileAtLocation(sourceFile, position) {
-    if (sourceFile.isDeclarationFile) {
-      return void 0;
-    }
-    let tokenAtLocation = getTokenAtPosition(sourceFile, position);
-    const lineOfPosition = sourceFile.getLineAndCharacterOfPosition(position).line;
-    if (sourceFile.getLineAndCharacterOfPosition(tokenAtLocation.getStart(sourceFile)).line > lineOfPosition) {
-      const preceding = findPrecedingToken(tokenAtLocation.pos, sourceFile);
-      if (!preceding || sourceFile.getLineAndCharacterOfPosition(preceding.getEnd()).line !== lineOfPosition) {
-        return void 0;
-      }
-      tokenAtLocation = preceding;
-    }
-    if (tokenAtLocation.flags & 16777216 /* Ambient */) {
-      return void 0;
-    }
-    return spanInNode(tokenAtLocation);
-    function textSpan(startNode2, endNode2) {
-      const lastDecorator = canHaveDecorators(startNode2) ? findLast(startNode2.modifiers, isDecorator) : void 0;
-      const start = lastDecorator ? skipTrivia(sourceFile.text, lastDecorator.end) : startNode2.getStart(sourceFile);
-      return createTextSpanFromBounds(start, (endNode2 || startNode2).getEnd());
+  // src/services/codefixes/fixClassIncorrectlyImplementsInterface.ts
+  function getClass(sourceFile, pos) {
+    return Debug.checkDefined(getContainingClass(getTokenAtPosition(sourceFile, pos)), "There should be a containing class");
+  }
+  function symbolPointsToNonPrivateMember(symbol) {
+    return !symbol.valueDeclaration || !(getEffectiveModifierFlags(symbol.valueDeclaration) & 2 /* Private */);
+  }
+  function addMissingDeclarations(context, implementedTypeNode, sourceFile, classDeclaration, changeTracker, preferences) {
+    const checker = context.program.getTypeChecker();
+    const maybeHeritageClauseSymbol = getHeritageClauseSymbolTable(classDeclaration, checker);
+    const implementedType = checker.getTypeAtLocation(implementedTypeNode);
+    const implementedTypeSymbols = checker.getPropertiesOfType(implementedType);
+    const nonPrivateAndNotExistedInHeritageClauseMembers = implementedTypeSymbols.filter(and(symbolPointsToNonPrivateMember, (symbol) => !maybeHeritageClauseSymbol.has(symbol.escapedName)));
+    const classType = checker.getTypeAtLocation(classDeclaration);
+    const constructor = find(classDeclaration.members, (m) => isConstructorDeclaration(m));
+    if (!classType.getNumberIndexType()) {
+      createMissingIndexSignatureDeclaration(implementedType, 1 /* Number */);
     }
-    function textSpanEndingAtNextToken(startNode2, previousTokenToFindNextEndToken) {
-      return textSpan(startNode2, findNextToken(previousTokenToFindNextEndToken, previousTokenToFindNextEndToken.parent, sourceFile));
+    if (!classType.getStringIndexType()) {
+      createMissingIndexSignatureDeclaration(implementedType, 0 /* String */);
     }
-    function spanInNodeIfStartsOnSameLine(node, otherwiseOnNode) {
-      if (node && lineOfPosition === sourceFile.getLineAndCharacterOfPosition(node.getStart(sourceFile)).line) {
-        return spanInNode(node);
+    const importAdder = createImportAdder(sourceFile, context.program, preferences, context.host);
+    createMissingMemberNodes(classDeclaration, nonPrivateAndNotExistedInHeritageClauseMembers, sourceFile, context, preferences, importAdder, (member) => insertInterfaceMemberNode(sourceFile, classDeclaration, member));
+    importAdder.writeFixes(changeTracker);
+    function createMissingIndexSignatureDeclaration(type, kind) {
+      const indexInfoOfKind = checker.getIndexInfoOfType(type, kind);
+      if (indexInfoOfKind) {
+        insertInterfaceMemberNode(sourceFile, classDeclaration, checker.indexInfoToIndexSignatureDeclaration(
+          indexInfoOfKind,
+          classDeclaration,
+          /*flags*/
+          void 0,
+          getNoopSymbolTrackerWithResolver(context)
+        ));
       }
-      return spanInNode(otherwiseOnNode);
     }
-    function spanInNodeArray(nodeArray, node, match) {
-      if (nodeArray) {
-        const index = nodeArray.indexOf(node);
-        if (index >= 0) {
-          let start = index;
-          let end = index + 1;
-          while (start > 0 && match(nodeArray[start - 1]))
-            start--;
-          while (end < nodeArray.length && match(nodeArray[end]))
-            end++;
-          return createTextSpanFromBounds(skipTrivia(sourceFile.text, nodeArray[start].pos), nodeArray[end - 1].end);
-        }
+    function insertInterfaceMemberNode(sourceFile2, cls, newElement) {
+      if (constructor) {
+        changeTracker.insertNodeAfter(sourceFile2, constructor, newElement);
+      } else {
+        changeTracker.insertMemberAtStart(sourceFile2, cls, newElement);
       }
-      return textSpan(node);
-    }
-    function spanInPreviousNode(node) {
-      return spanInNode(findPrecedingToken(node.pos, sourceFile));
     }
-    function spanInNextNode(node) {
-      return spanInNode(findNextToken(node, node.parent, sourceFile));
-    }
-    function spanInNode(node) {
-      if (node) {
-        const { parent: parent2 } = node;
-        switch (node.kind) {
-          case 242 /* VariableStatement */:
-            return spanInVariableDeclaration(node.declarationList.declarations[0]);
-          case 259 /* VariableDeclaration */:
-          case 171 /* PropertyDeclaration */:
-          case 170 /* PropertySignature */:
-            return spanInVariableDeclaration(node);
-          case 168 /* Parameter */:
-            return spanInParameterDeclaration(node);
-          case 261 /* FunctionDeclaration */:
-          case 173 /* MethodDeclaration */:
-          case 172 /* MethodSignature */:
-          case 176 /* GetAccessor */:
-          case 177 /* SetAccessor */:
-          case 175 /* Constructor */:
-          case 217 /* FunctionExpression */:
-          case 218 /* ArrowFunction */:
-            return spanInFunctionDeclaration(node);
-          case 240 /* Block */:
-            if (isFunctionBlock(node)) {
-              return spanInFunctionBlock(node);
-            }
-          case 267 /* ModuleBlock */:
-            return spanInBlock(node);
-          case 298 /* CatchClause */:
-            return spanInBlock(node.block);
-          case 243 /* ExpressionStatement */:
-            return textSpan(node.expression);
-          case 252 /* ReturnStatement */:
-            return textSpan(node.getChildAt(0), node.expression);
-          case 246 /* WhileStatement */:
-            return textSpanEndingAtNextToken(node, node.expression);
-          case 245 /* DoStatement */:
-            return spanInNode(node.statement);
-          case 258 /* DebuggerStatement */:
-            return textSpan(node.getChildAt(0));
-          case 244 /* IfStatement */:
-            return textSpanEndingAtNextToken(node, node.expression);
-          case 255 /* LabeledStatement */:
-            return spanInNode(node.statement);
-          case 251 /* BreakStatement */:
-          case 250 /* ContinueStatement */:
-            return textSpan(node.getChildAt(0), node.label);
-          case 247 /* ForStatement */:
-            return spanInForStatement(node);
-          case 248 /* ForInStatement */:
-            return textSpanEndingAtNextToken(node, node.expression);
-          case 249 /* ForOfStatement */:
-            return spanInInitializerOfForLike(node);
-          case 254 /* SwitchStatement */:
-            return textSpanEndingAtNextToken(node, node.expression);
-          case 295 /* CaseClause */:
-          case 296 /* DefaultClause */:
-            return spanInNode(node.statements[0]);
-          case 257 /* TryStatement */:
-            return spanInBlock(node.tryBlock);
-          case 256 /* ThrowStatement */:
-            return textSpan(node, node.expression);
-          case 276 /* ExportAssignment */:
-            return textSpan(node, node.expression);
-          case 270 /* ImportEqualsDeclaration */:
-            return textSpan(node, node.moduleReference);
-          case 271 /* ImportDeclaration */:
-            return textSpan(node, node.moduleSpecifier);
-          case 277 /* ExportDeclaration */:
-            return textSpan(node, node.moduleSpecifier);
-          case 266 /* ModuleDeclaration */:
-            if (getModuleInstanceState(node) !== 1 /* Instantiated */) {
-              return void 0;
-            }
-          case 262 /* ClassDeclaration */:
-          case 265 /* EnumDeclaration */:
-          case 305 /* EnumMember */:
-          case 207 /* BindingElement */:
-            return textSpan(node);
-          case 253 /* WithStatement */:
-            return spanInNode(node.statement);
-          case 169 /* Decorator */:
-            return spanInNodeArray(parent2.modifiers, node, isDecorator);
-          case 205 /* ObjectBindingPattern */:
-          case 206 /* ArrayBindingPattern */:
-            return spanInBindingPattern(node);
-          case 263 /* InterfaceDeclaration */:
-          case 264 /* TypeAliasDeclaration */:
-            return void 0;
-          case 27 /* SemicolonToken */:
-          case 1 /* EndOfFileToken */:
-            return spanInNodeIfStartsOnSameLine(findPrecedingToken(node.pos, sourceFile));
-          case 28 /* CommaToken */:
-            return spanInPreviousNode(node);
-          case 19 /* OpenBraceToken */:
-            return spanInOpenBraceToken(node);
-          case 20 /* CloseBraceToken */:
-            return spanInCloseBraceToken(node);
-          case 24 /* CloseBracketToken */:
-            return spanInCloseBracketToken(node);
-          case 21 /* OpenParenToken */:
-            return spanInOpenParenToken(node);
-          case 22 /* CloseParenToken */:
-            return spanInCloseParenToken(node);
-          case 59 /* ColonToken */:
-            return spanInColonToken(node);
-          case 32 /* GreaterThanToken */:
-          case 30 /* LessThanToken */:
-            return spanInGreaterThanOrLessThanToken(node);
-          case 117 /* WhileKeyword */:
-            return spanInWhileKeyword(node);
-          case 93 /* ElseKeyword */:
-          case 85 /* CatchKeyword */:
-          case 98 /* FinallyKeyword */:
-            return spanInNextNode(node);
-          case 164 /* OfKeyword */:
-            return spanInOfKeyword(node);
-          default:
-            if (isArrayLiteralOrObjectLiteralDestructuringPattern(node)) {
-              return spanInArrayLiteralOrObjectLiteralDestructuringPattern(node);
-            }
-            if ((node.kind === 80 /* Identifier */ || node.kind === 229 /* SpreadElement */ || node.kind === 302 /* PropertyAssignment */ || node.kind === 303 /* ShorthandPropertyAssignment */) && isArrayLiteralOrObjectLiteralDestructuringPattern(parent2)) {
-              return textSpan(node);
-            }
-            if (node.kind === 225 /* BinaryExpression */) {
-              const { left, operatorToken } = node;
-              if (isArrayLiteralOrObjectLiteralDestructuringPattern(left)) {
-                return spanInArrayLiteralOrObjectLiteralDestructuringPattern(
-                  left
-                );
-              }
-              if (operatorToken.kind === 64 /* EqualsToken */ && isArrayLiteralOrObjectLiteralDestructuringPattern(node.parent)) {
-                return textSpan(node);
-              }
-              if (operatorToken.kind === 28 /* CommaToken */) {
-                return spanInNode(left);
-              }
-            }
-            if (isExpressionNode(node)) {
-              switch (parent2.kind) {
-                case 245 /* DoStatement */:
-                  return spanInPreviousNode(node);
-                case 169 /* Decorator */:
-                  return spanInNode(node.parent);
-                case 247 /* ForStatement */:
-                case 249 /* ForOfStatement */:
-                  return textSpan(node);
-                case 225 /* BinaryExpression */:
-                  if (node.parent.operatorToken.kind === 28 /* CommaToken */) {
-                    return textSpan(node);
-                  }
-                  break;
-                case 218 /* ArrowFunction */:
-                  if (node.parent.body === node) {
-                    return textSpan(node);
-                  }
-                  break;
-              }
-            }
-            switch (node.parent.kind) {
-              case 302 /* PropertyAssignment */:
-                if (node.parent.name === node && !isArrayLiteralOrObjectLiteralDestructuringPattern(node.parent.parent)) {
-                  return spanInNode(node.parent.initializer);
-                }
-                break;
-              case 215 /* TypeAssertionExpression */:
-                if (node.parent.type === node) {
-                  return spanInNextNode(node.parent.type);
-                }
-                break;
-              case 259 /* VariableDeclaration */:
-              case 168 /* Parameter */: {
-                const { initializer, type } = node.parent;
-                if (initializer === node || type === node || isAssignmentOperator(node.kind)) {
-                  return spanInPreviousNode(node);
-                }
-                break;
-              }
-              case 225 /* BinaryExpression */: {
-                const { left } = node.parent;
-                if (isArrayLiteralOrObjectLiteralDestructuringPattern(left) && node !== left) {
-                  return spanInPreviousNode(node);
-                }
-                break;
+  }
+  function getHeritageClauseSymbolTable(classDeclaration, checker) {
+    const heritageClauseNode = getEffectiveBaseTypeNode(classDeclaration);
+    if (!heritageClauseNode)
+      return createSymbolTable();
+    const heritageClauseType = checker.getTypeAtLocation(heritageClauseNode);
+    const heritageClauseTypeSymbols = checker.getPropertiesOfType(heritageClauseType);
+    return createSymbolTable(heritageClauseTypeSymbols.filter(symbolPointsToNonPrivateMember));
+  }
+  var errorCodes17, fixId16;
+  var init_fixClassIncorrectlyImplementsInterface = __esm({
+    "src/services/codefixes/fixClassIncorrectlyImplementsInterface.ts"() {
+      "use strict";
+      init_ts4();
+      init_ts_codefix();
+      errorCodes17 = [
+        Diagnostics.Class_0_incorrectly_implements_interface_1.code,
+        Diagnostics.Class_0_incorrectly_implements_class_1_Did_you_mean_to_extend_1_and_inherit_its_members_as_a_subclass.code
+      ];
+      fixId16 = "fixClassIncorrectlyImplementsInterface";
+      registerCodeFix({
+        errorCodes: errorCodes17,
+        getCodeActions(context) {
+          const { sourceFile, span } = context;
+          const classDeclaration = getClass(sourceFile, span.start);
+          return mapDefined(getEffectiveImplementsTypeNodes(classDeclaration), (implementedTypeNode) => {
+            const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => addMissingDeclarations(context, implementedTypeNode, sourceFile, classDeclaration, t, context.preferences));
+            return changes.length === 0 ? void 0 : createCodeFixAction(fixId16, changes, [Diagnostics.Implement_interface_0, implementedTypeNode.getText(sourceFile)], fixId16, Diagnostics.Implement_all_unimplemented_interfaces);
+          });
+        },
+        fixIds: [fixId16],
+        getAllCodeActions(context) {
+          const seenClassDeclarations = /* @__PURE__ */ new Map();
+          return codeFixAll(context, errorCodes17, (changes, diag2) => {
+            const classDeclaration = getClass(diag2.file, diag2.start);
+            if (addToSeen(seenClassDeclarations, getNodeId(classDeclaration))) {
+              for (const implementedTypeNode of getEffectiveImplementsTypeNodes(classDeclaration)) {
+                addMissingDeclarations(context, implementedTypeNode, diag2.file, classDeclaration, changes, context.preferences);
               }
-              default:
-                if (isFunctionLike(node.parent) && node.parent.type === node) {
-                  return spanInPreviousNode(node);
-                }
             }
-            return spanInNode(node.parent);
-        }
-      }
-      function textSpanFromVariableDeclaration(variableDeclaration) {
-        if (isVariableDeclarationList(variableDeclaration.parent) && variableDeclaration.parent.declarations[0] === variableDeclaration) {
-          return textSpan(findPrecedingToken(variableDeclaration.pos, sourceFile, variableDeclaration.parent), variableDeclaration);
-        } else {
-          return textSpan(variableDeclaration);
-        }
-      }
-      function spanInVariableDeclaration(variableDeclaration) {
-        if (variableDeclaration.parent.parent.kind === 248 /* ForInStatement */) {
-          return spanInNode(variableDeclaration.parent.parent);
-        }
-        const parent2 = variableDeclaration.parent;
-        if (isBindingPattern(variableDeclaration.name)) {
-          return spanInBindingPattern(variableDeclaration.name);
-        }
-        if (hasOnlyExpressionInitializer(variableDeclaration) && variableDeclaration.initializer || hasSyntacticModifier(variableDeclaration, 1 /* Export */) || parent2.parent.kind === 249 /* ForOfStatement */) {
-          return textSpanFromVariableDeclaration(variableDeclaration);
-        }
-        if (isVariableDeclarationList(variableDeclaration.parent) && variableDeclaration.parent.declarations[0] !== variableDeclaration) {
-          return spanInNode(findPrecedingToken(variableDeclaration.pos, sourceFile, variableDeclaration.parent));
+          });
         }
+      });
+    }
+  });
+
+  // src/services/codefixes/importFixes.ts
+  function createImportAdder(sourceFile, program, preferences, host, cancellationToken) {
+    return createImportAdderWorker(
+      sourceFile,
+      program,
+      /*useAutoImportProvider*/
+      false,
+      preferences,
+      host,
+      cancellationToken
+    );
+  }
+  function createImportAdderWorker(sourceFile, program, useAutoImportProvider, preferences, host, cancellationToken) {
+    const compilerOptions = program.getCompilerOptions();
+    const addToNamespace = [];
+    const importType = [];
+    const addToExisting = /* @__PURE__ */ new Map();
+    const newImports = /* @__PURE__ */ new Map();
+    return { addImportFromDiagnostic, addImportFromExportedSymbol, writeFixes, hasFixes };
+    function addImportFromDiagnostic(diagnostic, context) {
+      const info = getFixInfos(context, diagnostic.code, diagnostic.start, useAutoImportProvider);
+      if (!info || !info.length)
+        return;
+      addImport(first(info));
+    }
+    function addImportFromExportedSymbol(exportedSymbol, isValidTypeOnlyUseSite) {
+      const moduleSymbol = Debug.checkDefined(exportedSymbol.parent);
+      const symbolName2 = getNameForExportedSymbol(exportedSymbol, getEmitScriptTarget(compilerOptions));
+      const checker = program.getTypeChecker();
+      const symbol = checker.getMergedSymbol(skipAlias(exportedSymbol, checker));
+      const exportInfo = getAllExportInfoForSymbol(
+        sourceFile,
+        symbol,
+        symbolName2,
+        moduleSymbol,
+        /*preferCapitalized*/
+        false,
+        program,
+        host,
+        preferences,
+        cancellationToken
+      );
+      const useRequire = shouldUseRequire(sourceFile, program);
+      const fix = getImportFixForSymbol(
+        sourceFile,
+        Debug.checkDefined(exportInfo),
+        program,
+        /*position*/
+        void 0,
+        !!isValidTypeOnlyUseSite,
+        useRequire,
+        host,
+        preferences
+      );
+      if (fix) {
+        addImport({ fix, symbolName: symbolName2, errorIdentifierText: void 0 });
       }
-      function canHaveSpanInParameterDeclaration(parameter) {
-        return !!parameter.initializer || parameter.dotDotDotToken !== void 0 || hasSyntacticModifier(parameter, 4 /* Public */ | 8 /* Private */);
-      }
-      function spanInParameterDeclaration(parameter) {
-        if (isBindingPattern(parameter.name)) {
-          return spanInBindingPattern(parameter.name);
-        } else if (canHaveSpanInParameterDeclaration(parameter)) {
-          return textSpan(parameter);
-        } else {
-          const functionDeclaration = parameter.parent;
-          const indexOfParameter = functionDeclaration.parameters.indexOf(parameter);
-          Debug.assert(indexOfParameter !== -1);
-          if (indexOfParameter !== 0) {
-            return spanInParameterDeclaration(functionDeclaration.parameters[indexOfParameter - 1]);
+    }
+    function addImport(info) {
+      var _a, _b;
+      const { fix, symbolName: symbolName2 } = info;
+      switch (fix.kind) {
+        case 0 /* UseNamespace */:
+          addToNamespace.push(fix);
+          break;
+        case 1 /* JsdocTypeImport */:
+          importType.push(fix);
+          break;
+        case 2 /* AddToExisting */: {
+          const { importClauseOrBindingPattern, importKind, addAsTypeOnly } = fix;
+          const key = String(getNodeId(importClauseOrBindingPattern));
+          let entry = addToExisting.get(key);
+          if (!entry) {
+            addToExisting.set(key, entry = { importClauseOrBindingPattern, defaultImport: void 0, namedImports: /* @__PURE__ */ new Map() });
+          }
+          if (importKind === 0 /* Named */) {
+            const prevValue = entry == null ? void 0 : entry.namedImports.get(symbolName2);
+            entry.namedImports.set(symbolName2, reduceAddAsTypeOnlyValues(prevValue, addAsTypeOnly));
           } else {
-            return spanInNode(functionDeclaration.body);
+            Debug.assert(entry.defaultImport === void 0 || entry.defaultImport.name === symbolName2, "(Add to Existing) Default import should be missing or match symbolName");
+            entry.defaultImport = {
+              name: symbolName2,
+              addAsTypeOnly: reduceAddAsTypeOnlyValues((_a = entry.defaultImport) == null ? void 0 : _a.addAsTypeOnly, addAsTypeOnly)
+            };
+          }
+          break;
+        }
+        case 3 /* AddNew */: {
+          const { moduleSpecifier, importKind, useRequire, addAsTypeOnly } = fix;
+          const entry = getNewImportEntry(moduleSpecifier, importKind, useRequire, addAsTypeOnly);
+          Debug.assert(entry.useRequire === useRequire, "(Add new) Tried to add an `import` and a `require` for the same module");
+          switch (importKind) {
+            case 1 /* Default */:
+              Debug.assert(entry.defaultImport === void 0 || entry.defaultImport.name === symbolName2, "(Add new) Default import should be missing or match symbolName");
+              entry.defaultImport = { name: symbolName2, addAsTypeOnly: reduceAddAsTypeOnlyValues((_b = entry.defaultImport) == null ? void 0 : _b.addAsTypeOnly, addAsTypeOnly) };
+              break;
+            case 0 /* Named */:
+              const prevValue = (entry.namedImports || (entry.namedImports = /* @__PURE__ */ new Map())).get(symbolName2);
+              entry.namedImports.set(symbolName2, reduceAddAsTypeOnlyValues(prevValue, addAsTypeOnly));
+              break;
+            case 3 /* CommonJS */:
+            case 2 /* Namespace */:
+              Debug.assert(entry.namespaceLikeImport === void 0 || entry.namespaceLikeImport.name === symbolName2, "Namespacelike import shoudl be missing or match symbolName");
+              entry.namespaceLikeImport = { importKind, name: symbolName2, addAsTypeOnly };
+              break;
           }
+          break;
         }
+        case 4 /* PromoteTypeOnly */:
+          break;
+        default:
+          Debug.assertNever(fix, `fix wasn't never - got kind ${fix.kind}`);
       }
-      function canFunctionHaveSpanInWholeDeclaration(functionDeclaration) {
-        return hasSyntacticModifier(functionDeclaration, 1 /* Export */) || functionDeclaration.parent.kind === 262 /* ClassDeclaration */ && functionDeclaration.kind !== 175 /* Constructor */;
+      function reduceAddAsTypeOnlyValues(prevValue, newValue) {
+        return Math.max(prevValue ?? 0, newValue);
       }
-      function spanInFunctionDeclaration(functionDeclaration) {
-        if (!functionDeclaration.body) {
-          return void 0;
+      function getNewImportEntry(moduleSpecifier, importKind, useRequire, addAsTypeOnly) {
+        const typeOnlyKey = newImportsKey(
+          moduleSpecifier,
+          /*topLevelTypeOnly*/
+          true
+        );
+        const nonTypeOnlyKey = newImportsKey(
+          moduleSpecifier,
+          /*topLevelTypeOnly*/
+          false
+        );
+        const typeOnlyEntry = newImports.get(typeOnlyKey);
+        const nonTypeOnlyEntry = newImports.get(nonTypeOnlyKey);
+        const newEntry = {
+          defaultImport: void 0,
+          namedImports: void 0,
+          namespaceLikeImport: void 0,
+          useRequire
+        };
+        if (importKind === 1 /* Default */ && addAsTypeOnly === 2 /* Required */) {
+          if (typeOnlyEntry)
+            return typeOnlyEntry;
+          newImports.set(typeOnlyKey, newEntry);
+          return newEntry;
         }
-        if (canFunctionHaveSpanInWholeDeclaration(functionDeclaration)) {
-          return textSpan(functionDeclaration);
+        if (addAsTypeOnly === 1 /* Allowed */ && (typeOnlyEntry || nonTypeOnlyEntry)) {
+          return typeOnlyEntry || nonTypeOnlyEntry;
         }
-        return spanInNode(functionDeclaration.body);
-      }
-      function spanInFunctionBlock(block) {
-        const nodeForSpanInBlock = block.statements.length ? block.statements[0] : block.getLastToken();
-        if (canFunctionHaveSpanInWholeDeclaration(block.parent)) {
-          return spanInNodeIfStartsOnSameLine(block.parent, nodeForSpanInBlock);
+        if (nonTypeOnlyEntry) {
+          return nonTypeOnlyEntry;
         }
-        return spanInNode(nodeForSpanInBlock);
+        newImports.set(nonTypeOnlyKey, newEntry);
+        return newEntry;
       }
-      function spanInBlock(block) {
-        switch (block.parent.kind) {
-          case 266 /* ModuleDeclaration */:
-            if (getModuleInstanceState(block.parent) !== 1 /* Instantiated */) {
-              return void 0;
-            }
-          case 246 /* WhileStatement */:
-          case 244 /* IfStatement */:
-          case 248 /* ForInStatement */:
-            return spanInNodeIfStartsOnSameLine(block.parent, block.statements[0]);
-          case 247 /* ForStatement */:
-          case 249 /* ForOfStatement */:
-            return spanInNodeIfStartsOnSameLine(findPrecedingToken(block.pos, sourceFile, block.parent), block.statements[0]);
-        }
-        return spanInNode(block.statements[0]);
+      function newImportsKey(moduleSpecifier, topLevelTypeOnly) {
+        return `${topLevelTypeOnly ? 1 : 0}|${moduleSpecifier}`;
       }
-      function spanInInitializerOfForLike(forLikeStatement) {
-        if (forLikeStatement.initializer.kind === 260 /* VariableDeclarationList */) {
-          const variableDeclarationList = forLikeStatement.initializer;
-          if (variableDeclarationList.declarations.length > 0) {
-            return spanInNode(variableDeclarationList.declarations[0]);
-          }
-        } else {
-          return spanInNode(forLikeStatement.initializer);
-        }
+    }
+    function writeFixes(changeTracker, oldFileQuotePreference) {
+      let quotePreference;
+      if (sourceFile.imports.length === 0 && oldFileQuotePreference !== void 0) {
+        quotePreference = oldFileQuotePreference;
+      } else {
+        quotePreference = getQuotePreference(sourceFile, preferences);
       }
-      function spanInForStatement(forStatement) {
-        if (forStatement.initializer) {
-          return spanInInitializerOfForLike(forStatement);
-        }
-        if (forStatement.condition) {
-          return textSpan(forStatement.condition);
-        }
-        if (forStatement.incrementor) {
-          return textSpan(forStatement.incrementor);
-        }
+      for (const fix of addToNamespace) {
+        addNamespaceQualifier(changeTracker, sourceFile, fix);
       }
-      function spanInBindingPattern(bindingPattern) {
-        const firstBindingElement = forEach(
-          bindingPattern.elements,
-          (element) => element.kind !== 231 /* OmittedExpression */ ? element : void 0
-        );
-        if (firstBindingElement) {
-          return spanInNode(firstBindingElement);
-        }
-        if (bindingPattern.parent.kind === 207 /* BindingElement */) {
-          return textSpan(bindingPattern.parent);
-        }
-        return textSpanFromVariableDeclaration(bindingPattern.parent);
+      for (const fix of importType) {
+        addImportType(changeTracker, sourceFile, fix, quotePreference);
       }
-      function spanInArrayLiteralOrObjectLiteralDestructuringPattern(node2) {
-        Debug.assert(node2.kind !== 206 /* ArrayBindingPattern */ && node2.kind !== 205 /* ObjectBindingPattern */);
-        const elements = node2.kind === 208 /* ArrayLiteralExpression */ ? node2.elements : node2.properties;
-        const firstBindingElement = forEach(
-          elements,
-          (element) => element.kind !== 231 /* OmittedExpression */ ? element : void 0
+      addToExisting.forEach(({ importClauseOrBindingPattern, defaultImport, namedImports }) => {
+        doAddExistingFix(
+          changeTracker,
+          sourceFile,
+          importClauseOrBindingPattern,
+          defaultImport,
+          arrayFrom(namedImports.entries(), ([name, addAsTypeOnly]) => ({ addAsTypeOnly, name })),
+          preferences
+        );
+      });
+      let newDeclarations;
+      newImports.forEach(({ useRequire, defaultImport, namedImports, namespaceLikeImport }, key) => {
+        const moduleSpecifier = key.slice(2);
+        const getDeclarations = useRequire ? getNewRequires : getNewImports;
+        const declarations = getDeclarations(
+          moduleSpecifier,
+          quotePreference,
+          defaultImport,
+          namedImports && arrayFrom(namedImports.entries(), ([name, addAsTypeOnly]) => ({ addAsTypeOnly, name })),
+          namespaceLikeImport,
+          compilerOptions,
+          preferences
+        );
+        newDeclarations = combine(newDeclarations, declarations);
+      });
+      if (newDeclarations) {
+        insertImports(
+          changeTracker,
+          sourceFile,
+          newDeclarations,
+          /*blankLineBetween*/
+          true,
+          preferences
         );
-        if (firstBindingElement) {
-          return spanInNode(firstBindingElement);
-        }
-        return textSpan(node2.parent.kind === 225 /* BinaryExpression */ ? node2.parent : node2);
       }
-      function spanInOpenBraceToken(node2) {
-        switch (node2.parent.kind) {
-          case 265 /* EnumDeclaration */:
-            const enumDeclaration = node2.parent;
-            return spanInNodeIfStartsOnSameLine(findPrecedingToken(node2.pos, sourceFile, node2.parent), enumDeclaration.members.length ? enumDeclaration.members[0] : enumDeclaration.getLastToken(sourceFile));
-          case 262 /* ClassDeclaration */:
-            const classDeclaration = node2.parent;
-            return spanInNodeIfStartsOnSameLine(findPrecedingToken(node2.pos, sourceFile, node2.parent), classDeclaration.members.length ? classDeclaration.members[0] : classDeclaration.getLastToken(sourceFile));
-          case 268 /* CaseBlock */:
-            return spanInNodeIfStartsOnSameLine(node2.parent.parent, node2.parent.clauses[0]);
-        }
-        return spanInNode(node2.parent);
+    }
+    function hasFixes() {
+      return addToNamespace.length > 0 || importType.length > 0 || addToExisting.size > 0 || newImports.size > 0;
+    }
+  }
+  function createImportSpecifierResolver(importingFile, program, host, preferences) {
+    const packageJsonImportFilter = createPackageJsonImportFilter(importingFile, preferences, host);
+    const importMap = createExistingImportMap(program.getTypeChecker(), importingFile, program.getCompilerOptions());
+    return { getModuleSpecifierForBestExportInfo };
+    function getModuleSpecifierForBestExportInfo(exportInfo, position, isValidTypeOnlyUseSite, fromCacheOnly) {
+      const { fixes, computedWithoutCacheCount } = getImportFixes(
+        exportInfo,
+        position,
+        isValidTypeOnlyUseSite,
+        /*useRequire*/
+        false,
+        program,
+        importingFile,
+        host,
+        preferences,
+        importMap,
+        fromCacheOnly
+      );
+      const result = getBestFix(fixes, importingFile, program, packageJsonImportFilter, host);
+      return result && { ...result, computedWithoutCacheCount };
+    }
+  }
+  function getImportCompletionAction(targetSymbol, moduleSymbol, exportMapKey, sourceFile, symbolName2, isJsxTagName, host, program, formatContext, position, preferences, cancellationToken) {
+    let exportInfos;
+    if (exportMapKey) {
+      exportInfos = getExportInfoMap(sourceFile, host, program, preferences, cancellationToken).get(sourceFile.path, exportMapKey);
+      Debug.assertIsDefined(exportInfos, "Some exportInfo should match the specified exportMapKey");
+    } else {
+      exportInfos = pathIsBareSpecifier(stripQuotes(moduleSymbol.name)) ? [getSingleExportInfoForSymbol(targetSymbol, symbolName2, moduleSymbol, program, host)] : getAllExportInfoForSymbol(sourceFile, targetSymbol, symbolName2, moduleSymbol, isJsxTagName, program, host, preferences, cancellationToken);
+      Debug.assertIsDefined(exportInfos, "Some exportInfo should match the specified symbol / moduleSymbol");
+    }
+    const useRequire = shouldUseRequire(sourceFile, program);
+    const isValidTypeOnlyUseSite = isValidTypeOnlyAliasUseSite(getTokenAtPosition(sourceFile, position));
+    const fix = Debug.checkDefined(getImportFixForSymbol(sourceFile, exportInfos, program, position, isValidTypeOnlyUseSite, useRequire, host, preferences));
+    return {
+      moduleSpecifier: fix.moduleSpecifier,
+      codeAction: codeFixActionToCodeAction(codeActionForFix(
+        { host, formatContext, preferences },
+        sourceFile,
+        symbolName2,
+        fix,
+        /*includeSymbolNameInDescription*/
+        false,
+        program,
+        preferences
+      ))
+    };
+  }
+  function getPromoteTypeOnlyCompletionAction(sourceFile, symbolToken, program, host, formatContext, preferences) {
+    const compilerOptions = program.getCompilerOptions();
+    const symbolName2 = single(getSymbolNamesToImport(sourceFile, program.getTypeChecker(), symbolToken, compilerOptions));
+    const fix = getTypeOnlyPromotionFix(sourceFile, symbolToken, symbolName2, program);
+    const includeSymbolNameInDescription = symbolName2 !== symbolToken.text;
+    return fix && codeFixActionToCodeAction(codeActionForFix(
+      { host, formatContext, preferences },
+      sourceFile,
+      symbolName2,
+      fix,
+      includeSymbolNameInDescription,
+      program,
+      preferences
+    ));
+  }
+  function getImportFixForSymbol(sourceFile, exportInfos, program, position, isValidTypeOnlyUseSite, useRequire, host, preferences) {
+    const packageJsonImportFilter = createPackageJsonImportFilter(sourceFile, preferences, host);
+    return getBestFix(getImportFixes(exportInfos, position, isValidTypeOnlyUseSite, useRequire, program, sourceFile, host, preferences).fixes, sourceFile, program, packageJsonImportFilter, host);
+  }
+  function codeFixActionToCodeAction({ description: description3, changes, commands }) {
+    return { description: description3, changes, commands };
+  }
+  function getAllExportInfoForSymbol(importingFile, symbol, symbolName2, moduleSymbol, preferCapitalized, program, host, preferences, cancellationToken) {
+    const getChecker = createGetChecker(program, host);
+    return getExportInfoMap(importingFile, host, program, preferences, cancellationToken).search(importingFile.path, preferCapitalized, (name) => name === symbolName2, (info) => {
+      if (skipAlias(info[0].symbol, getChecker(info[0].isFromPackageJson)) === symbol && info.some((i) => i.moduleSymbol === moduleSymbol || i.symbol.parent === moduleSymbol)) {
+        return info;
       }
-      function spanInCloseBraceToken(node2) {
-        switch (node2.parent.kind) {
-          case 267 /* ModuleBlock */:
-            if (getModuleInstanceState(node2.parent.parent) !== 1 /* Instantiated */) {
-              return void 0;
-            }
-          case 265 /* EnumDeclaration */:
-          case 262 /* ClassDeclaration */:
-            return textSpan(node2);
-          case 240 /* Block */:
-            if (isFunctionBlock(node2.parent)) {
-              return textSpan(node2);
-            }
-          case 298 /* CatchClause */:
-            return spanInNode(lastOrUndefined(node2.parent.statements));
-          case 268 /* CaseBlock */:
-            const caseBlock = node2.parent;
-            const lastClause = lastOrUndefined(caseBlock.clauses);
-            if (lastClause) {
-              return spanInNode(lastOrUndefined(lastClause.statements));
-            }
-            return void 0;
-          case 205 /* ObjectBindingPattern */:
-            const bindingPattern = node2.parent;
-            return spanInNode(lastOrUndefined(bindingPattern.elements) || bindingPattern);
-          default:
-            if (isArrayLiteralOrObjectLiteralDestructuringPattern(node2.parent)) {
-              const objectLiteral = node2.parent;
-              return textSpan(lastOrUndefined(objectLiteral.properties) || objectLiteral);
-            }
-            return spanInNode(node2.parent);
-        }
+    });
+  }
+  function getSingleExportInfoForSymbol(symbol, symbolName2, moduleSymbol, program, host) {
+    var _a, _b;
+    const compilerOptions = program.getCompilerOptions();
+    const mainProgramInfo = getInfoWithChecker(
+      program.getTypeChecker(),
+      /*isFromPackageJson*/
+      false
+    );
+    if (mainProgramInfo) {
+      return mainProgramInfo;
+    }
+    const autoImportProvider = (_b = (_a = host.getPackageJsonAutoImportProvider) == null ? void 0 : _a.call(host)) == null ? void 0 : _b.getTypeChecker();
+    return Debug.checkDefined(autoImportProvider && getInfoWithChecker(
+      autoImportProvider,
+      /*isFromPackageJson*/
+      true
+    ), `Could not find symbol in specified module for code actions`);
+    function getInfoWithChecker(checker, isFromPackageJson) {
+      const defaultInfo = getDefaultLikeExportInfo(moduleSymbol, checker, compilerOptions);
+      if (defaultInfo && skipAlias(defaultInfo.symbol, checker) === symbol) {
+        return { symbol: defaultInfo.symbol, moduleSymbol, moduleFileName: void 0, exportKind: defaultInfo.exportKind, targetFlags: skipAlias(symbol, checker).flags, isFromPackageJson };
       }
-      function spanInCloseBracketToken(node2) {
-        switch (node2.parent.kind) {
-          case 206 /* ArrayBindingPattern */:
-            const bindingPattern = node2.parent;
-            return textSpan(lastOrUndefined(bindingPattern.elements) || bindingPattern);
-          default:
-            if (isArrayLiteralOrObjectLiteralDestructuringPattern(node2.parent)) {
-              const arrayLiteral = node2.parent;
-              return textSpan(lastOrUndefined(arrayLiteral.elements) || arrayLiteral);
-            }
-            return spanInNode(node2.parent);
-        }
+      const named = checker.tryGetMemberInModuleExportsAndProperties(symbolName2, moduleSymbol);
+      if (named && skipAlias(named, checker) === symbol) {
+        return { symbol: named, moduleSymbol, moduleFileName: void 0, exportKind: 0 /* Named */, targetFlags: skipAlias(symbol, checker).flags, isFromPackageJson };
       }
-      function spanInOpenParenToken(node2) {
-        if (node2.parent.kind === 245 /* DoStatement */ || // Go to while keyword and do action instead
-        node2.parent.kind === 212 /* CallExpression */ || node2.parent.kind === 213 /* NewExpression */) {
-          return spanInPreviousNode(node2);
-        }
-        if (node2.parent.kind === 216 /* ParenthesizedExpression */) {
-          return spanInNextNode(node2);
-        }
-        return spanInNode(node2.parent);
+    }
+  }
+  function getImportFixes(exportInfos, usagePosition, isValidTypeOnlyUseSite, useRequire, program, sourceFile, host, preferences, importMap = createExistingImportMap(program.getTypeChecker(), sourceFile, program.getCompilerOptions()), fromCacheOnly) {
+    const checker = program.getTypeChecker();
+    const existingImports = flatMap(exportInfos, importMap.getImportsForExportInfo);
+    const useNamespace = usagePosition !== void 0 && tryUseExistingNamespaceImport(existingImports, usagePosition);
+    const addToExisting = tryAddToExistingImport(existingImports, isValidTypeOnlyUseSite, checker, program.getCompilerOptions());
+    if (addToExisting) {
+      return {
+        computedWithoutCacheCount: 0,
+        fixes: [...useNamespace ? [useNamespace] : emptyArray, addToExisting]
+      };
+    }
+    const { fixes, computedWithoutCacheCount = 0 } = getFixesForAddImport(
+      exportInfos,
+      existingImports,
+      program,
+      sourceFile,
+      usagePosition,
+      isValidTypeOnlyUseSite,
+      useRequire,
+      host,
+      preferences,
+      fromCacheOnly
+    );
+    return {
+      computedWithoutCacheCount,
+      fixes: [...useNamespace ? [useNamespace] : emptyArray, ...fixes]
+    };
+  }
+  function tryUseExistingNamespaceImport(existingImports, position) {
+    return firstDefined(existingImports, ({ declaration, importKind }) => {
+      var _a;
+      if (importKind !== 0 /* Named */)
+        return void 0;
+      const namespacePrefix = getNamespaceLikeImportText(declaration);
+      const moduleSpecifier = namespacePrefix && ((_a = tryGetModuleSpecifierFromDeclaration(declaration)) == null ? void 0 : _a.text);
+      if (moduleSpecifier) {
+        return { kind: 0 /* UseNamespace */, namespacePrefix, usagePosition: position, moduleSpecifier };
       }
-      function spanInCloseParenToken(node2) {
-        switch (node2.parent.kind) {
-          case 217 /* FunctionExpression */:
-          case 261 /* FunctionDeclaration */:
-          case 218 /* ArrowFunction */:
-          case 173 /* MethodDeclaration */:
-          case 172 /* MethodSignature */:
-          case 176 /* GetAccessor */:
-          case 177 /* SetAccessor */:
-          case 175 /* Constructor */:
-          case 246 /* WhileStatement */:
-          case 245 /* DoStatement */:
-          case 247 /* ForStatement */:
-          case 249 /* ForOfStatement */:
-          case 212 /* CallExpression */:
-          case 213 /* NewExpression */:
-          case 216 /* ParenthesizedExpression */:
-            return spanInPreviousNode(node2);
-          default:
-            return spanInNode(node2.parent);
-        }
+    });
+  }
+  function getNamespaceLikeImportText(declaration) {
+    var _a, _b, _c;
+    switch (declaration.kind) {
+      case 260 /* VariableDeclaration */:
+        return (_a = tryCast(declaration.name, isIdentifier)) == null ? void 0 : _a.text;
+      case 271 /* ImportEqualsDeclaration */:
+        return declaration.name.text;
+      case 272 /* ImportDeclaration */:
+        return (_c = tryCast((_b = declaration.importClause) == null ? void 0 : _b.namedBindings, isNamespaceImport)) == null ? void 0 : _c.name.text;
+      default:
+        return Debug.assertNever(declaration);
+    }
+  }
+  function getAddAsTypeOnly(isValidTypeOnlyUseSite, isForNewImportDeclaration, symbol, targetFlags, checker, compilerOptions) {
+    if (!isValidTypeOnlyUseSite) {
+      return 4 /* NotAllowed */;
+    }
+    if (isForNewImportDeclaration && compilerOptions.importsNotUsedAsValues === 2 /* Error */) {
+      return 2 /* Required */;
+    }
+    if (importNameElisionDisabled(compilerOptions) && (!(targetFlags & 111551 /* Value */) || !!checker.getTypeOnlyAliasDeclaration(symbol))) {
+      return 2 /* Required */;
+    }
+    return 1 /* Allowed */;
+  }
+  function tryAddToExistingImport(existingImports, isValidTypeOnlyUseSite, checker, compilerOptions) {
+    let best;
+    for (const existingImport of existingImports) {
+      const fix = getAddToExistingImportFix(existingImport);
+      if (!fix)
+        continue;
+      const isTypeOnly = isTypeOnlyImportDeclaration(fix.importClauseOrBindingPattern);
+      if (fix.addAsTypeOnly !== 4 /* NotAllowed */ && isTypeOnly || fix.addAsTypeOnly === 4 /* NotAllowed */ && !isTypeOnly) {
+        return fix;
       }
-      function spanInColonToken(node2) {
-        if (isFunctionLike(node2.parent) || node2.parent.kind === 302 /* PropertyAssignment */ || node2.parent.kind === 168 /* Parameter */) {
-          return spanInPreviousNode(node2);
-        }
-        return spanInNode(node2.parent);
+      best ?? (best = fix);
+    }
+    return best;
+    function getAddToExistingImportFix({ declaration, importKind, symbol, targetFlags }) {
+      if (importKind === 3 /* CommonJS */ || importKind === 2 /* Namespace */ || declaration.kind === 271 /* ImportEqualsDeclaration */) {
+        return void 0;
       }
-      function spanInGreaterThanOrLessThanToken(node2) {
-        if (node2.parent.kind === 215 /* TypeAssertionExpression */) {
-          return spanInNextNode(node2);
-        }
-        return spanInNode(node2.parent);
+      if (declaration.kind === 260 /* VariableDeclaration */) {
+        return (importKind === 0 /* Named */ || importKind === 1 /* Default */) && declaration.name.kind === 206 /* ObjectBindingPattern */ ? { kind: 2 /* AddToExisting */, importClauseOrBindingPattern: declaration.name, importKind, moduleSpecifier: declaration.initializer.arguments[0].text, addAsTypeOnly: 4 /* NotAllowed */ } : void 0;
       }
-      function spanInWhileKeyword(node2) {
-        if (node2.parent.kind === 245 /* DoStatement */) {
-          return textSpanEndingAtNextToken(node2, node2.parent.expression);
-        }
-        return spanInNode(node2.parent);
+      const { importClause } = declaration;
+      if (!importClause || !isStringLiteralLike(declaration.moduleSpecifier)) {
+        return void 0;
       }
-      function spanInOfKeyword(node2) {
-        if (node2.parent.kind === 249 /* ForOfStatement */) {
-          return spanInNextNode(node2);
+      const { name, namedBindings } = importClause;
+      if (importClause.isTypeOnly && !(importKind === 0 /* Named */ && namedBindings)) {
+        return void 0;
+      }
+      const addAsTypeOnly = getAddAsTypeOnly(
+        isValidTypeOnlyUseSite,
+        /*isForNewImportDeclaration*/
+        false,
+        symbol,
+        targetFlags,
+        checker,
+        compilerOptions
+      );
+      if (importKind === 1 /* Default */ && (name || // Cannot add a default import to a declaration that already has one
+      addAsTypeOnly === 2 /* Required */ && namedBindings)) {
+        return void 0;
+      }
+      if (importKind === 0 /* Named */ && (namedBindings == null ? void 0 : namedBindings.kind) === 274 /* NamespaceImport */) {
+        return void 0;
+      }
+      return {
+        kind: 2 /* AddToExisting */,
+        importClauseOrBindingPattern: importClause,
+        importKind,
+        moduleSpecifier: declaration.moduleSpecifier.text,
+        addAsTypeOnly
+      };
+    }
+  }
+  function createExistingImportMap(checker, importingFile, compilerOptions) {
+    let importMap;
+    for (const moduleSpecifier of importingFile.imports) {
+      const i = importFromModuleSpecifier(moduleSpecifier);
+      if (isVariableDeclarationInitializedToRequire(i.parent)) {
+        const moduleSymbol = checker.resolveExternalModuleName(moduleSpecifier);
+        if (moduleSymbol) {
+          (importMap || (importMap = createMultiMap())).add(getSymbolId(moduleSymbol), i.parent);
+        }
+      } else if (i.kind === 272 /* ImportDeclaration */ || i.kind === 271 /* ImportEqualsDeclaration */) {
+        const moduleSymbol = checker.getSymbolAtLocation(moduleSpecifier);
+        if (moduleSymbol) {
+          (importMap || (importMap = createMultiMap())).add(getSymbolId(moduleSymbol), i);
         }
-        return spanInNode(node2.parent);
       }
     }
+    return {
+      getImportsForExportInfo: ({ moduleSymbol, exportKind, targetFlags, symbol }) => {
+        if (!(targetFlags & 111551 /* Value */) && isSourceFileJS(importingFile))
+          return emptyArray;
+        const matchingDeclarations = importMap == null ? void 0 : importMap.get(getSymbolId(moduleSymbol));
+        if (!matchingDeclarations)
+          return emptyArray;
+        const importKind = getImportKind(importingFile, exportKind, compilerOptions);
+        return matchingDeclarations.map((declaration) => ({ declaration, importKind, symbol, targetFlags }));
+      }
+    };
   }
-  var init_breakpoints = __esm({
-    "src/services/breakpoints.ts"() {
-      "use strict";
-      init_ts4();
+  function shouldUseRequire(sourceFile, program) {
+    if (!isSourceFileJS(sourceFile)) {
+      return false;
     }
-  });
-
-  // src/services/_namespaces/ts.BreakpointResolver.ts
-  var ts_BreakpointResolver_exports = {};
-  __export(ts_BreakpointResolver_exports, {
-    spanInSourceFileAtLocation: () => spanInSourceFileAtLocation
-  });
-  var init_ts_BreakpointResolver = __esm({
-    "src/services/_namespaces/ts.BreakpointResolver.ts"() {
-      "use strict";
-      init_breakpoints();
+    if (sourceFile.commonJsModuleIndicator && !sourceFile.externalModuleIndicator)
+      return true;
+    if (sourceFile.externalModuleIndicator && !sourceFile.commonJsModuleIndicator)
+      return false;
+    const compilerOptions = program.getCompilerOptions();
+    if (compilerOptions.configFile) {
+      return getEmitModuleKind(compilerOptions) < 5 /* ES2015 */;
     }
-  });
-
-  // src/services/callHierarchy.ts
-  function isNamedExpression(node) {
-    return (isFunctionExpression(node) || isClassExpression(node)) && isNamedDeclaration(node);
+    if (sourceFile.impliedNodeFormat === 1 /* CommonJS */)
+      return true;
+    if (sourceFile.impliedNodeFormat === 99 /* ESNext */)
+      return false;
+    for (const otherFile of program.getSourceFiles()) {
+      if (otherFile === sourceFile || !isSourceFileJS(otherFile) || program.isSourceFileFromExternalLibrary(otherFile))
+        continue;
+      if (otherFile.commonJsModuleIndicator && !otherFile.externalModuleIndicator)
+        return true;
+      if (otherFile.externalModuleIndicator && !otherFile.commonJsModuleIndicator)
+        return false;
+    }
+    return true;
   }
-  function isConstNamedExpression(node) {
-    return (isFunctionExpression(node) || isArrowFunction(node) || isClassExpression(node)) && isVariableDeclaration(node.parent) && node === node.parent.initializer && isIdentifier(node.parent.name) && !!(getCombinedNodeFlags(node.parent) & 2 /* Const */);
+  function createGetChecker(program, host) {
+    return memoizeOne((isFromPackageJson) => isFromPackageJson ? host.getPackageJsonAutoImportProvider().getTypeChecker() : program.getTypeChecker());
   }
-  function isPossibleCallHierarchyDeclaration(node) {
-    return isSourceFile(node) || isModuleDeclaration(node) || isFunctionDeclaration(node) || isFunctionExpression(node) || isClassDeclaration(node) || isClassExpression(node) || isClassStaticBlockDeclaration(node) || isMethodDeclaration(node) || isMethodSignature(node) || isGetAccessorDeclaration(node) || isSetAccessorDeclaration(node);
+  function getNewImportFixes(program, sourceFile, usagePosition, isValidTypeOnlyUseSite, useRequire, exportInfo, host, preferences, fromCacheOnly) {
+    const isJs = isSourceFileJS(sourceFile);
+    const compilerOptions = program.getCompilerOptions();
+    const moduleSpecifierResolutionHost = createModuleSpecifierResolutionHost(program, host);
+    const getChecker = createGetChecker(program, host);
+    const moduleResolution = getEmitModuleResolutionKind(compilerOptions);
+    const rejectNodeModulesRelativePaths = moduleResolutionUsesNodeModules(moduleResolution);
+    const getModuleSpecifiers2 = fromCacheOnly ? (moduleSymbol) => ({ moduleSpecifiers: ts_moduleSpecifiers_exports.tryGetModuleSpecifiersFromCache(moduleSymbol, sourceFile, moduleSpecifierResolutionHost, preferences), computedWithoutCache: false }) : (moduleSymbol, checker) => ts_moduleSpecifiers_exports.getModuleSpecifiersWithCacheInfo(
+      moduleSymbol,
+      checker,
+      compilerOptions,
+      sourceFile,
+      moduleSpecifierResolutionHost,
+      preferences,
+      /*options*/
+      void 0,
+      /*forAutoImport*/
+      true
+    );
+    let computedWithoutCacheCount = 0;
+    const fixes = flatMap(exportInfo, (exportInfo2, i) => {
+      const checker = getChecker(exportInfo2.isFromPackageJson);
+      const { computedWithoutCache, moduleSpecifiers } = getModuleSpecifiers2(exportInfo2.moduleSymbol, checker);
+      const importedSymbolHasValueMeaning = !!(exportInfo2.targetFlags & 111551 /* Value */);
+      const addAsTypeOnly = getAddAsTypeOnly(
+        isValidTypeOnlyUseSite,
+        /*isForNewImportDeclaration*/
+        true,
+        exportInfo2.symbol,
+        exportInfo2.targetFlags,
+        checker,
+        compilerOptions
+      );
+      computedWithoutCacheCount += computedWithoutCache ? 1 : 0;
+      return mapDefined(moduleSpecifiers, (moduleSpecifier) => {
+        var _a;
+        if (rejectNodeModulesRelativePaths && pathContainsNodeModules(moduleSpecifier)) {
+          return void 0;
+        }
+        if (!importedSymbolHasValueMeaning && isJs && usagePosition !== void 0) {
+          return { kind: 1 /* JsdocTypeImport */, moduleSpecifier, usagePosition, exportInfo: exportInfo2, isReExport: i > 0 };
+        }
+        const importKind = getImportKind(sourceFile, exportInfo2.exportKind, compilerOptions);
+        let qualification;
+        if (usagePosition !== void 0 && importKind === 3 /* CommonJS */ && exportInfo2.exportKind === 0 /* Named */) {
+          const exportEquals = checker.resolveExternalModuleSymbol(exportInfo2.moduleSymbol);
+          let namespacePrefix;
+          if (exportEquals !== exportInfo2.moduleSymbol) {
+            namespacePrefix = (_a = getDefaultExportInfoWorker(exportEquals, checker, compilerOptions)) == null ? void 0 : _a.name;
+          }
+          namespacePrefix || (namespacePrefix = moduleSymbolToValidIdentifier(
+            exportInfo2.moduleSymbol,
+            getEmitScriptTarget(compilerOptions),
+            /*forceCapitalize*/
+            false
+          ));
+          qualification = { namespacePrefix, usagePosition };
+        }
+        return {
+          kind: 3 /* AddNew */,
+          moduleSpecifier,
+          importKind,
+          useRequire,
+          addAsTypeOnly,
+          exportInfo: exportInfo2,
+          isReExport: i > 0,
+          qualification
+        };
+      });
+    });
+    return { computedWithoutCacheCount, fixes };
   }
-  function isValidCallHierarchyDeclaration(node) {
-    return isSourceFile(node) || isModuleDeclaration(node) && isIdentifier(node.name) || isFunctionDeclaration(node) || isClassDeclaration(node) || isClassStaticBlockDeclaration(node) || isMethodDeclaration(node) || isMethodSignature(node) || isGetAccessorDeclaration(node) || isSetAccessorDeclaration(node) || isNamedExpression(node) || isConstNamedExpression(node);
+  function getFixesForAddImport(exportInfos, existingImports, program, sourceFile, usagePosition, isValidTypeOnlyUseSite, useRequire, host, preferences, fromCacheOnly) {
+    const existingDeclaration = firstDefined(existingImports, (info) => newImportInfoFromExistingSpecifier(info, isValidTypeOnlyUseSite, useRequire, program.getTypeChecker(), program.getCompilerOptions()));
+    return existingDeclaration ? { fixes: [existingDeclaration] } : getNewImportFixes(program, sourceFile, usagePosition, isValidTypeOnlyUseSite, useRequire, exportInfos, host, preferences, fromCacheOnly);
   }
-  function getCallHierarchyDeclarationReferenceNode(node) {
-    if (isSourceFile(node))
-      return node;
-    if (isNamedDeclaration(node))
-      return node.name;
-    if (isConstNamedExpression(node))
-      return node.parent.name;
-    return Debug.checkDefined(node.modifiers && find(node.modifiers, isDefaultModifier3));
+  function newImportInfoFromExistingSpecifier({ declaration, importKind, symbol, targetFlags }, isValidTypeOnlyUseSite, useRequire, checker, compilerOptions) {
+    var _a;
+    const moduleSpecifier = (_a = tryGetModuleSpecifierFromDeclaration(declaration)) == null ? void 0 : _a.text;
+    if (moduleSpecifier) {
+      const addAsTypeOnly = useRequire ? 4 /* NotAllowed */ : getAddAsTypeOnly(
+        isValidTypeOnlyUseSite,
+        /*isForNewImportDeclaration*/
+        true,
+        symbol,
+        targetFlags,
+        checker,
+        compilerOptions
+      );
+      return { kind: 3 /* AddNew */, moduleSpecifier, importKind, addAsTypeOnly, useRequire };
+    }
   }
-  function isDefaultModifier3(node) {
-    return node.kind === 90 /* DefaultKeyword */;
+  function getFixInfos(context, errorCode, pos, useAutoImportProvider) {
+    const symbolToken = getTokenAtPosition(context.sourceFile, pos);
+    let info;
+    if (errorCode === Diagnostics._0_refers_to_a_UMD_global_but_the_current_file_is_a_module_Consider_adding_an_import_instead.code) {
+      info = getFixesInfoForUMDImport(context, symbolToken);
+    } else if (!isIdentifier(symbolToken)) {
+      return void 0;
+    } else if (errorCode === Diagnostics._0_cannot_be_used_as_a_value_because_it_was_imported_using_import_type.code) {
+      const symbolName2 = single(getSymbolNamesToImport(context.sourceFile, context.program.getTypeChecker(), symbolToken, context.program.getCompilerOptions()));
+      const fix = getTypeOnlyPromotionFix(context.sourceFile, symbolToken, symbolName2, context.program);
+      return fix && [{ fix, symbolName: symbolName2, errorIdentifierText: symbolToken.text }];
+    } else {
+      info = getFixesInfoForNonUMDImport(context, symbolToken, useAutoImportProvider);
+    }
+    const packageJsonImportFilter = createPackageJsonImportFilter(context.sourceFile, context.preferences, context.host);
+    return info && sortFixInfo(info, context.sourceFile, context.program, packageJsonImportFilter, context.host);
   }
-  function getSymbolOfCallHierarchyDeclaration(typeChecker, node) {
-    const location = getCallHierarchyDeclarationReferenceNode(node);
-    return location && typeChecker.getSymbolAtLocation(location);
+  function sortFixInfo(fixes, sourceFile, program, packageJsonImportFilter, host) {
+    const _toPath = (fileName) => toPath(fileName, host.getCurrentDirectory(), hostGetCanonicalFileName(host));
+    return sort(fixes, (a, b) => compareBooleans(!!a.isJsxNamespaceFix, !!b.isJsxNamespaceFix) || compareValues(a.fix.kind, b.fix.kind) || compareModuleSpecifiers(a.fix, b.fix, sourceFile, program, packageJsonImportFilter.allowsImportingSpecifier, _toPath));
   }
-  function getCallHierarchyItemName(program, node) {
-    if (isSourceFile(node)) {
-      return { text: node.fileName, pos: 0, end: 0 };
+  function getBestFix(fixes, sourceFile, program, packageJsonImportFilter, host) {
+    if (!some(fixes))
+      return;
+    if (fixes[0].kind === 0 /* UseNamespace */ || fixes[0].kind === 2 /* AddToExisting */) {
+      return fixes[0];
     }
-    if ((isFunctionDeclaration(node) || isClassDeclaration(node)) && !isNamedDeclaration(node)) {
-      const defaultModifier = node.modifiers && find(node.modifiers, isDefaultModifier3);
-      if (defaultModifier) {
-        return { text: "default", pos: defaultModifier.getStart(), end: defaultModifier.getEnd() };
-      }
+    return fixes.reduce(
+      (best, fix) => (
+        // Takes true branch of conditional if `fix` is better than `best`
+        compareModuleSpecifiers(
+          fix,
+          best,
+          sourceFile,
+          program,
+          packageJsonImportFilter.allowsImportingSpecifier,
+          (fileName) => toPath(fileName, host.getCurrentDirectory(), hostGetCanonicalFileName(host))
+        ) === -1 /* LessThan */ ? fix : best
+      )
+    );
+  }
+  function compareModuleSpecifiers(a, b, importingFile, program, allowsImportingSpecifier, toPath3) {
+    if (a.kind !== 0 /* UseNamespace */ && b.kind !== 0 /* UseNamespace */) {
+      return compareBooleans(allowsImportingSpecifier(b.moduleSpecifier), allowsImportingSpecifier(a.moduleSpecifier)) || compareNodeCoreModuleSpecifiers(a.moduleSpecifier, b.moduleSpecifier, importingFile, program) || compareBooleans(
+        isFixPossiblyReExportingImportingFile(a, importingFile, program.getCompilerOptions(), toPath3),
+        isFixPossiblyReExportingImportingFile(b, importingFile, program.getCompilerOptions(), toPath3)
+      ) || compareNumberOfDirectorySeparators(a.moduleSpecifier, b.moduleSpecifier);
     }
-    if (isClassStaticBlockDeclaration(node)) {
-      const sourceFile = node.getSourceFile();
-      const pos = skipTrivia(sourceFile.text, moveRangePastModifiers(node).pos);
-      const end = pos + 6;
-      const typeChecker = program.getTypeChecker();
-      const symbol = typeChecker.getSymbolAtLocation(node.parent);
-      const prefix = symbol ? `${typeChecker.symbolToString(symbol, node.parent)} ` : "";
-      return { text: `${prefix}static {}`, pos, end };
+    return 0 /* EqualTo */;
+  }
+  function isFixPossiblyReExportingImportingFile(fix, importingFile, compilerOptions, toPath3) {
+    var _a;
+    if (fix.isReExport && ((_a = fix.exportInfo) == null ? void 0 : _a.moduleFileName) && getEmitModuleResolutionKind(compilerOptions) === 2 /* Node10 */ && isIndexFileName(fix.exportInfo.moduleFileName)) {
+      const reExportDir = toPath3(getDirectoryPath(fix.exportInfo.moduleFileName));
+      return startsWith(importingFile.path, reExportDir);
     }
-    const declName = isConstNamedExpression(node) ? node.parent.name : Debug.checkDefined(getNameOfDeclaration(node), "Expected call hierarchy item to have a name");
-    let text = isIdentifier(declName) ? idText(declName) : isStringOrNumericLiteralLike(declName) ? declName.text : isComputedPropertyName(declName) ? isStringOrNumericLiteralLike(declName.expression) ? declName.expression.text : void 0 : void 0;
-    if (text === void 0) {
-      const typeChecker = program.getTypeChecker();
-      const symbol = typeChecker.getSymbolAtLocation(declName);
-      if (symbol) {
-        text = typeChecker.symbolToString(symbol, node);
+    return false;
+  }
+  function isIndexFileName(fileName) {
+    return getBaseFileName(
+      fileName,
+      [".js", ".jsx", ".d.ts", ".ts", ".tsx"],
+      /*ignoreCase*/
+      true
+    ) === "index";
+  }
+  function compareNodeCoreModuleSpecifiers(a, b, importingFile, program) {
+    if (startsWith(a, "node:") && !startsWith(b, "node:"))
+      return shouldUseUriStyleNodeCoreModules(importingFile, program) ? -1 /* LessThan */ : 1 /* GreaterThan */;
+    if (startsWith(b, "node:") && !startsWith(a, "node:"))
+      return shouldUseUriStyleNodeCoreModules(importingFile, program) ? 1 /* GreaterThan */ : -1 /* LessThan */;
+    return 0 /* EqualTo */;
+  }
+  function getFixesInfoForUMDImport({ sourceFile, program, host, preferences }, token) {
+    const checker = program.getTypeChecker();
+    const umdSymbol = getUmdSymbol(token, checker);
+    if (!umdSymbol)
+      return void 0;
+    const symbol = checker.getAliasedSymbol(umdSymbol);
+    const symbolName2 = umdSymbol.name;
+    const exportInfo = [{ symbol: umdSymbol, moduleSymbol: symbol, moduleFileName: void 0, exportKind: 3 /* UMD */, targetFlags: symbol.flags, isFromPackageJson: false }];
+    const useRequire = shouldUseRequire(sourceFile, program);
+    const fixes = getImportFixes(
+      exportInfo,
+      /*usagePosition*/
+      void 0,
+      /*isValidTypeOnlyUseSite*/
+      false,
+      useRequire,
+      program,
+      sourceFile,
+      host,
+      preferences
+    ).fixes;
+    return fixes.map((fix) => {
+      var _a;
+      return { fix, symbolName: symbolName2, errorIdentifierText: (_a = tryCast(token, isIdentifier)) == null ? void 0 : _a.text };
+    });
+  }
+  function getUmdSymbol(token, checker) {
+    const umdSymbol = isIdentifier(token) ? checker.getSymbolAtLocation(token) : void 0;
+    if (isUMDExportSymbol(umdSymbol))
+      return umdSymbol;
+    const { parent: parent2 } = token;
+    if (isJsxOpeningLikeElement(parent2) && parent2.tagName === token || isJsxOpeningFragment(parent2)) {
+      const parentSymbol = checker.resolveName(
+        checker.getJsxNamespace(parent2),
+        isJsxOpeningLikeElement(parent2) ? token : parent2,
+        111551 /* Value */,
+        /*excludeGlobals*/
+        false
+      );
+      if (isUMDExportSymbol(parentSymbol)) {
+        return parentSymbol;
       }
     }
-    if (text === void 0) {
-      const printer = createPrinterWithRemoveCommentsOmitTrailingSemicolon();
-      text = usingSingleLineStringWriter((writer) => printer.writeNode(4 /* Unspecified */, node, node.getSourceFile(), writer));
+    return void 0;
+  }
+  function getImportKind(importingFile, exportKind, compilerOptions, forceImportKeyword) {
+    if (compilerOptions.verbatimModuleSyntax && (getEmitModuleKind(compilerOptions) === 1 /* CommonJS */ || importingFile.impliedNodeFormat === 1 /* CommonJS */)) {
+      return 3 /* CommonJS */;
+    }
+    switch (exportKind) {
+      case 0 /* Named */:
+        return 0 /* Named */;
+      case 1 /* Default */:
+        return 1 /* Default */;
+      case 2 /* ExportEquals */:
+        return getExportEqualsImportKind(importingFile, compilerOptions, !!forceImportKeyword);
+      case 3 /* UMD */:
+        return getUmdImportKind(importingFile, compilerOptions, !!forceImportKeyword);
+      default:
+        return Debug.assertNever(exportKind);
     }
-    return { text, pos: declName.getStart(), end: declName.getEnd() };
   }
-  function getCallHierarchItemContainerName(node) {
-    var _a, _b;
-    if (isConstNamedExpression(node)) {
-      if (isModuleBlock(node.parent.parent.parent.parent) && isIdentifier(node.parent.parent.parent.parent.parent.name)) {
-        return node.parent.parent.parent.parent.parent.name.getText();
-      }
-      return;
+  function getUmdImportKind(importingFile, compilerOptions, forceImportKeyword) {
+    if (getAllowSyntheticDefaultImports(compilerOptions)) {
+      return 1 /* Default */;
     }
-    switch (node.kind) {
-      case 176 /* GetAccessor */:
-      case 177 /* SetAccessor */:
-      case 173 /* MethodDeclaration */:
-        if (node.parent.kind === 209 /* ObjectLiteralExpression */) {
-          return (_a = getAssignedName(node.parent)) == null ? void 0 : _a.getText();
-        }
-        return (_b = getNameOfDeclaration(node.parent)) == null ? void 0 : _b.getText();
-      case 261 /* FunctionDeclaration */:
-      case 262 /* ClassDeclaration */:
-      case 266 /* ModuleDeclaration */:
-        if (isModuleBlock(node.parent) && isIdentifier(node.parent.parent.name)) {
-          return node.parent.parent.name.getText();
+    const moduleKind = getEmitModuleKind(compilerOptions);
+    switch (moduleKind) {
+      case 2 /* AMD */:
+      case 1 /* CommonJS */:
+      case 3 /* UMD */:
+        if (isInJSFile(importingFile)) {
+          return isExternalModule(importingFile) || forceImportKeyword ? 2 /* Namespace */ : 3 /* CommonJS */;
         }
+        return 3 /* CommonJS */;
+      case 4 /* System */:
+      case 5 /* ES2015 */:
+      case 6 /* ES2020 */:
+      case 7 /* ES2022 */:
+      case 99 /* ESNext */:
+      case 0 /* None */:
+        return 2 /* Namespace */;
+      case 100 /* Node16 */:
+      case 199 /* NodeNext */:
+        return importingFile.impliedNodeFormat === 99 /* ESNext */ ? 2 /* Namespace */ : 3 /* CommonJS */;
+      default:
+        return Debug.assertNever(moduleKind, `Unexpected moduleKind ${moduleKind}`);
     }
   }
-  function findImplementation(typeChecker, node) {
-    if (node.body) {
-      return node;
+  function getFixesInfoForNonUMDImport({ sourceFile, program, cancellationToken, host, preferences }, symbolToken, useAutoImportProvider) {
+    const checker = program.getTypeChecker();
+    const compilerOptions = program.getCompilerOptions();
+    return flatMap(getSymbolNamesToImport(sourceFile, checker, symbolToken, compilerOptions), (symbolName2) => {
+      if (symbolName2 === "default" /* Default */) {
+        return void 0;
+      }
+      const isValidTypeOnlyUseSite = isValidTypeOnlyAliasUseSite(symbolToken);
+      const useRequire = shouldUseRequire(sourceFile, program);
+      const exportInfo = getExportInfos(symbolName2, isJSXTagName(symbolToken), getMeaningFromLocation(symbolToken), cancellationToken, sourceFile, program, useAutoImportProvider, host, preferences);
+      return arrayFrom(
+        flatMapIterator(exportInfo.values(), (exportInfos) => getImportFixes(exportInfos, symbolToken.getStart(sourceFile), isValidTypeOnlyUseSite, useRequire, program, sourceFile, host, preferences).fixes),
+        (fix) => ({ fix, symbolName: symbolName2, errorIdentifierText: symbolToken.text, isJsxNamespaceFix: symbolName2 !== symbolToken.text })
+      );
+    });
+  }
+  function getTypeOnlyPromotionFix(sourceFile, symbolToken, symbolName2, program) {
+    const checker = program.getTypeChecker();
+    const symbol = checker.resolveName(
+      symbolName2,
+      symbolToken,
+      111551 /* Value */,
+      /*excludeGlobals*/
+      true
+    );
+    if (!symbol)
+      return void 0;
+    const typeOnlyAliasDeclaration = checker.getTypeOnlyAliasDeclaration(symbol);
+    if (!typeOnlyAliasDeclaration || getSourceFileOfNode(typeOnlyAliasDeclaration) !== sourceFile)
+      return void 0;
+    return { kind: 4 /* PromoteTypeOnly */, typeOnlyAliasDeclaration };
+  }
+  function getSymbolNamesToImport(sourceFile, checker, symbolToken, compilerOptions) {
+    const parent2 = symbolToken.parent;
+    if ((isJsxOpeningLikeElement(parent2) || isJsxClosingElement(parent2)) && parent2.tagName === symbolToken && jsxModeNeedsExplicitImport(compilerOptions.jsx)) {
+      const jsxNamespace = checker.getJsxNamespace(sourceFile);
+      if (needsJsxNamespaceFix(jsxNamespace, symbolToken, checker)) {
+        const needsComponentNameFix = !isIntrinsicJsxName(symbolToken.text) && !checker.resolveName(
+          symbolToken.text,
+          symbolToken,
+          111551 /* Value */,
+          /*excludeGlobals*/
+          false
+        );
+        return needsComponentNameFix ? [symbolToken.text, jsxNamespace] : [jsxNamespace];
+      }
     }
-    if (isConstructorDeclaration(node)) {
-      return getFirstConstructorWithBody(node.parent);
+    return [symbolToken.text];
+  }
+  function needsJsxNamespaceFix(jsxNamespace, symbolToken, checker) {
+    if (isIntrinsicJsxName(symbolToken.text))
+      return true;
+    const namespaceSymbol = checker.resolveName(
+      jsxNamespace,
+      symbolToken,
+      111551 /* Value */,
+      /*excludeGlobals*/
+      true
+    );
+    return !namespaceSymbol || some(namespaceSymbol.declarations, isTypeOnlyImportOrExportDeclaration) && !(namespaceSymbol.flags & 111551 /* Value */);
+  }
+  function getExportInfos(symbolName2, isJsxTagName, currentTokenMeaning, cancellationToken, fromFile, program, useAutoImportProvider, host, preferences) {
+    var _a;
+    const originalSymbolToExportInfos = createMultiMap();
+    const packageJsonFilter = createPackageJsonImportFilter(fromFile, preferences, host);
+    const moduleSpecifierCache = (_a = host.getModuleSpecifierCache) == null ? void 0 : _a.call(host);
+    const getModuleSpecifierResolutionHost = memoizeOne((isFromPackageJson) => {
+      return createModuleSpecifierResolutionHost(isFromPackageJson ? host.getPackageJsonAutoImportProvider() : program, host);
+    });
+    function addSymbol(moduleSymbol, toFile, exportedSymbol, exportKind, program2, isFromPackageJson) {
+      const moduleSpecifierResolutionHost = getModuleSpecifierResolutionHost(isFromPackageJson);
+      if (toFile && isImportableFile(program2, fromFile, toFile, preferences, packageJsonFilter, moduleSpecifierResolutionHost, moduleSpecifierCache) || !toFile && packageJsonFilter.allowsImportingAmbientModule(moduleSymbol, moduleSpecifierResolutionHost)) {
+        const checker = program2.getTypeChecker();
+        originalSymbolToExportInfos.add(getUniqueSymbolId(exportedSymbol, checker).toString(), { symbol: exportedSymbol, moduleSymbol, moduleFileName: toFile == null ? void 0 : toFile.fileName, exportKind, targetFlags: skipAlias(exportedSymbol, checker).flags, isFromPackageJson });
+      }
     }
-    if (isFunctionDeclaration(node) || isMethodDeclaration(node)) {
-      const symbol = getSymbolOfCallHierarchyDeclaration(typeChecker, node);
-      if (symbol && symbol.valueDeclaration && isFunctionLikeDeclaration(symbol.valueDeclaration) && symbol.valueDeclaration.body) {
-        return symbol.valueDeclaration;
+    forEachExternalModuleToImportFrom(program, host, preferences, useAutoImportProvider, (moduleSymbol, sourceFile, program2, isFromPackageJson) => {
+      const checker = program2.getTypeChecker();
+      cancellationToken.throwIfCancellationRequested();
+      const compilerOptions = program2.getCompilerOptions();
+      const defaultInfo = getDefaultLikeExportInfo(moduleSymbol, checker, compilerOptions);
+      if (defaultInfo && (defaultInfo.name === symbolName2 || moduleSymbolToValidIdentifier(moduleSymbol, getEmitScriptTarget(compilerOptions), isJsxTagName) === symbolName2) && symbolHasMeaning(defaultInfo.resolvedSymbol, currentTokenMeaning)) {
+        addSymbol(moduleSymbol, sourceFile, defaultInfo.symbol, defaultInfo.exportKind, program2, isFromPackageJson);
       }
-      return void 0;
+      const exportSymbolWithIdenticalName = checker.tryGetMemberInModuleExportsAndProperties(symbolName2, moduleSymbol);
+      if (exportSymbolWithIdenticalName && symbolHasMeaning(exportSymbolWithIdenticalName, currentTokenMeaning)) {
+        addSymbol(moduleSymbol, sourceFile, exportSymbolWithIdenticalName, 0 /* Named */, program2, isFromPackageJson);
+      }
+    });
+    return originalSymbolToExportInfos;
+  }
+  function getExportEqualsImportKind(importingFile, compilerOptions, forceImportKeyword) {
+    const allowSyntheticDefaults = getAllowSyntheticDefaultImports(compilerOptions);
+    const isJS = isInJSFile(importingFile);
+    if (!isJS && getEmitModuleKind(compilerOptions) >= 5 /* ES2015 */) {
+      return allowSyntheticDefaults ? 1 /* Default */ : 2 /* Namespace */;
     }
-    return node;
+    if (isJS) {
+      return isExternalModule(importingFile) || forceImportKeyword ? allowSyntheticDefaults ? 1 /* Default */ : 2 /* Namespace */ : 3 /* CommonJS */;
+    }
+    for (const statement of importingFile.statements) {
+      if (isImportEqualsDeclaration(statement) && !nodeIsMissing(statement.moduleReference)) {
+        return 3 /* CommonJS */;
+      }
+    }
+    return allowSyntheticDefaults ? 1 /* Default */ : 3 /* CommonJS */;
   }
-  function findAllInitialDeclarations(typeChecker, node) {
-    const symbol = getSymbolOfCallHierarchyDeclaration(typeChecker, node);
-    let declarations;
-    if (symbol && symbol.declarations) {
-      const indices = indicesOf(symbol.declarations);
-      const keys = map(symbol.declarations, (decl) => ({ file: decl.getSourceFile().fileName, pos: decl.pos }));
-      indices.sort((a, b) => compareStringsCaseSensitive(keys[a].file, keys[b].file) || keys[a].pos - keys[b].pos);
-      const sortedDeclarations = map(indices, (i) => symbol.declarations[i]);
-      let lastDecl;
-      for (const decl of sortedDeclarations) {
-        if (isValidCallHierarchyDeclaration(decl)) {
-          if (!lastDecl || lastDecl.parent !== decl.parent || lastDecl.end !== decl.pos) {
-            declarations = append(declarations, decl);
-          }
-          lastDecl = decl;
+  function codeActionForFix(context, sourceFile, symbolName2, fix, includeSymbolNameInDescription, program, preferences) {
+    let diag2;
+    const changes = ts_textChanges_exports.ChangeTracker.with(context, (tracker) => {
+      diag2 = codeActionForFixWorker(tracker, sourceFile, symbolName2, fix, includeSymbolNameInDescription, program, preferences);
+    });
+    return createCodeFixAction(importFixName, changes, diag2, importFixId, Diagnostics.Add_all_missing_imports);
+  }
+  function codeActionForFixWorker(changes, sourceFile, symbolName2, fix, includeSymbolNameInDescription, program, preferences) {
+    const quotePreference = getQuotePreference(sourceFile, preferences);
+    switch (fix.kind) {
+      case 0 /* UseNamespace */:
+        addNamespaceQualifier(changes, sourceFile, fix);
+        return [Diagnostics.Change_0_to_1, symbolName2, `${fix.namespacePrefix}.${symbolName2}`];
+      case 1 /* JsdocTypeImport */:
+        addImportType(changes, sourceFile, fix, quotePreference);
+        return [Diagnostics.Change_0_to_1, symbolName2, getImportTypePrefix(fix.moduleSpecifier, quotePreference) + symbolName2];
+      case 2 /* AddToExisting */: {
+        const { importClauseOrBindingPattern, importKind, addAsTypeOnly, moduleSpecifier } = fix;
+        doAddExistingFix(
+          changes,
+          sourceFile,
+          importClauseOrBindingPattern,
+          importKind === 1 /* Default */ ? { name: symbolName2, addAsTypeOnly } : void 0,
+          importKind === 0 /* Named */ ? [{ name: symbolName2, addAsTypeOnly }] : emptyArray,
+          preferences
+        );
+        const moduleSpecifierWithoutQuotes = stripQuotes(moduleSpecifier);
+        return includeSymbolNameInDescription ? [Diagnostics.Import_0_from_1, symbolName2, moduleSpecifierWithoutQuotes] : [Diagnostics.Update_import_from_0, moduleSpecifierWithoutQuotes];
+      }
+      case 3 /* AddNew */: {
+        const { importKind, moduleSpecifier, addAsTypeOnly, useRequire, qualification } = fix;
+        const getDeclarations = useRequire ? getNewRequires : getNewImports;
+        const defaultImport = importKind === 1 /* Default */ ? { name: symbolName2, addAsTypeOnly } : void 0;
+        const namedImports = importKind === 0 /* Named */ ? [{ name: symbolName2, addAsTypeOnly }] : void 0;
+        const namespaceLikeImport = importKind === 2 /* Namespace */ || importKind === 3 /* CommonJS */ ? { importKind, name: (qualification == null ? void 0 : qualification.namespacePrefix) || symbolName2, addAsTypeOnly } : void 0;
+        insertImports(
+          changes,
+          sourceFile,
+          getDeclarations(
+            moduleSpecifier,
+            quotePreference,
+            defaultImport,
+            namedImports,
+            namespaceLikeImport,
+            program.getCompilerOptions(),
+            preferences
+          ),
+          /*blankLineBetween*/
+          true,
+          preferences
+        );
+        if (qualification) {
+          addNamespaceQualifier(changes, sourceFile, qualification);
         }
+        return includeSymbolNameInDescription ? [Diagnostics.Import_0_from_1, symbolName2, moduleSpecifier] : [Diagnostics.Add_import_from_0, moduleSpecifier];
       }
+      case 4 /* PromoteTypeOnly */: {
+        const { typeOnlyAliasDeclaration } = fix;
+        const promotedDeclaration = promoteFromTypeOnly(changes, typeOnlyAliasDeclaration, program, sourceFile, preferences);
+        return promotedDeclaration.kind === 276 /* ImportSpecifier */ ? [Diagnostics.Remove_type_from_import_of_0_from_1, symbolName2, getModuleSpecifierText(promotedDeclaration.parent.parent)] : [Diagnostics.Remove_type_from_import_declaration_from_0, getModuleSpecifierText(promotedDeclaration)];
+      }
+      default:
+        return Debug.assertNever(fix, `Unexpected fix kind ${fix.kind}`);
     }
-    return declarations;
   }
-  function findImplementationOrAllInitialDeclarations(typeChecker, node) {
-    if (isClassStaticBlockDeclaration(node)) {
-      return node;
-    }
-    if (isFunctionLikeDeclaration(node)) {
-      return findImplementation(typeChecker, node) ?? findAllInitialDeclarations(typeChecker, node) ?? node;
-    }
-    return findAllInitialDeclarations(typeChecker, node) ?? node;
+  function getModuleSpecifierText(promotedDeclaration) {
+    var _a, _b;
+    return promotedDeclaration.kind === 271 /* ImportEqualsDeclaration */ ? ((_b = tryCast((_a = tryCast(promotedDeclaration.moduleReference, isExternalModuleReference)) == null ? void 0 : _a.expression, isStringLiteralLike)) == null ? void 0 : _b.text) || promotedDeclaration.moduleReference.getText() : cast(promotedDeclaration.parent.moduleSpecifier, isStringLiteral).text;
   }
-  function resolveCallHierarchyDeclaration(program, location) {
-    const typeChecker = program.getTypeChecker();
-    let followingSymbol = false;
-    while (true) {
-      if (isValidCallHierarchyDeclaration(location)) {
-        return findImplementationOrAllInitialDeclarations(typeChecker, location);
-      }
-      if (isPossibleCallHierarchyDeclaration(location)) {
-        const ancestor = findAncestor(location, isValidCallHierarchyDeclaration);
-        return ancestor && findImplementationOrAllInitialDeclarations(typeChecker, ancestor);
-      }
-      if (isDeclarationName(location)) {
-        if (isValidCallHierarchyDeclaration(location.parent)) {
-          return findImplementationOrAllInitialDeclarations(typeChecker, location.parent);
-        }
-        if (isPossibleCallHierarchyDeclaration(location.parent)) {
-          const ancestor = findAncestor(location.parent, isValidCallHierarchyDeclaration);
-          return ancestor && findImplementationOrAllInitialDeclarations(typeChecker, ancestor);
-        }
-        if (isVariableDeclaration(location.parent) && location.parent.initializer && isConstNamedExpression(location.parent.initializer)) {
-          return location.parent.initializer;
+  function promoteFromTypeOnly(changes, aliasDeclaration, program, sourceFile, preferences) {
+    const compilerOptions = program.getCompilerOptions();
+    const convertExistingToTypeOnly = importNameElisionDisabled(compilerOptions);
+    switch (aliasDeclaration.kind) {
+      case 276 /* ImportSpecifier */:
+        if (aliasDeclaration.isTypeOnly) {
+          const sortKind = ts_OrganizeImports_exports.detectImportSpecifierSorting(aliasDeclaration.parent.elements, preferences);
+          if (aliasDeclaration.parent.elements.length > 1 && sortKind) {
+            const newSpecifier = factory.updateImportSpecifier(
+              aliasDeclaration,
+              /*isTypeOnly*/
+              false,
+              aliasDeclaration.propertyName,
+              aliasDeclaration.name
+            );
+            const comparer = ts_OrganizeImports_exports.getOrganizeImportsComparer(preferences, sortKind === 2 /* CaseInsensitive */);
+            const insertionIndex = ts_OrganizeImports_exports.getImportSpecifierInsertionIndex(aliasDeclaration.parent.elements, newSpecifier, comparer);
+            if (aliasDeclaration.parent.elements.indexOf(aliasDeclaration) !== insertionIndex) {
+              changes.delete(sourceFile, aliasDeclaration);
+              changes.insertImportSpecifierAtIndex(sourceFile, newSpecifier, aliasDeclaration.parent, insertionIndex);
+              return aliasDeclaration;
+            }
+          }
+          changes.deleteRange(sourceFile, aliasDeclaration.getFirstToken());
+          return aliasDeclaration;
+        } else {
+          Debug.assert(aliasDeclaration.parent.parent.isTypeOnly);
+          promoteImportClause(aliasDeclaration.parent.parent);
+          return aliasDeclaration.parent.parent;
         }
-        return void 0;
-      }
-      if (isConstructorDeclaration(location)) {
-        if (isValidCallHierarchyDeclaration(location.parent)) {
-          return location.parent;
+      case 273 /* ImportClause */:
+        promoteImportClause(aliasDeclaration);
+        return aliasDeclaration;
+      case 274 /* NamespaceImport */:
+        promoteImportClause(aliasDeclaration.parent);
+        return aliasDeclaration.parent;
+      case 271 /* ImportEqualsDeclaration */:
+        changes.deleteRange(sourceFile, aliasDeclaration.getChildAt(1));
+        return aliasDeclaration;
+      default:
+        Debug.failBadSyntaxKind(aliasDeclaration);
+    }
+    function promoteImportClause(importClause) {
+      var _a;
+      changes.delete(sourceFile, getTypeKeywordOfTypeOnlyImport(importClause, sourceFile));
+      if (!compilerOptions.allowImportingTsExtensions) {
+        const moduleSpecifier = tryGetModuleSpecifierFromDeclaration(importClause.parent);
+        const resolvedModule = moduleSpecifier && ((_a = program.getResolvedModule(sourceFile, moduleSpecifier.text, getModeForUsageLocation(sourceFile, moduleSpecifier))) == null ? void 0 : _a.resolvedModule);
+        if (resolvedModule == null ? void 0 : resolvedModule.resolvedUsingTsExtension) {
+          const changedExtension = changeAnyExtension(moduleSpecifier.text, getOutputExtension(moduleSpecifier.text, compilerOptions));
+          changes.replaceNode(sourceFile, moduleSpecifier, factory.createStringLiteral(changedExtension));
         }
-        return void 0;
-      }
-      if (location.kind === 126 /* StaticKeyword */ && isClassStaticBlockDeclaration(location.parent)) {
-        location = location.parent;
-        continue;
-      }
-      if (isVariableDeclaration(location) && location.initializer && isConstNamedExpression(location.initializer)) {
-        return location.initializer;
       }
-      if (!followingSymbol) {
-        let symbol = typeChecker.getSymbolAtLocation(location);
-        if (symbol) {
-          if (symbol.flags & 2097152 /* Alias */) {
-            symbol = typeChecker.getAliasedSymbol(symbol);
+      if (convertExistingToTypeOnly) {
+        const namedImports = tryCast(importClause.namedBindings, isNamedImports);
+        if (namedImports && namedImports.elements.length > 1) {
+          if (ts_OrganizeImports_exports.detectImportSpecifierSorting(namedImports.elements, preferences) && aliasDeclaration.kind === 276 /* ImportSpecifier */ && namedImports.elements.indexOf(aliasDeclaration) !== 0) {
+            changes.delete(sourceFile, aliasDeclaration);
+            changes.insertImportSpecifierAtIndex(sourceFile, aliasDeclaration, namedImports, 0);
           }
-          if (symbol.valueDeclaration) {
-            followingSymbol = true;
-            location = symbol.valueDeclaration;
-            continue;
+          for (const element of namedImports.elements) {
+            if (element !== aliasDeclaration && !element.isTypeOnly) {
+              changes.insertModifierBefore(sourceFile, 156 /* TypeKeyword */, element);
+            }
           }
         }
       }
-      return void 0;
     }
   }
-  function createCallHierarchyItem(program, node) {
-    const sourceFile = node.getSourceFile();
-    const name = getCallHierarchyItemName(program, node);
-    const containerName = getCallHierarchItemContainerName(node);
-    const kind = getNodeKind(node);
-    const kindModifiers = getNodeModifiers(node);
-    const span = createTextSpanFromBounds(skipTrivia(
-      sourceFile.text,
-      node.getFullStart(),
-      /*stopAfterLineBreak*/
-      false,
-      /*stopAtComments*/
-      true
-    ), node.getEnd());
-    const selectionSpan = createTextSpanFromBounds(name.pos, name.end);
-    return { file: sourceFile.fileName, kind, kindModifiers, name: name.text, containerName, span, selectionSpan };
-  }
-  function isDefined(x) {
-    return x !== void 0;
-  }
-  function convertEntryToCallSite(entry) {
-    if (entry.kind === ts_FindAllReferences_exports.EntryKind.Node) {
-      const { node } = entry;
-      if (isCallOrNewExpressionTarget(
-        node,
-        /*includeElementAccess*/
-        true,
-        /*skipPastOuterExpressions*/
-        true
-      ) || isTaggedTemplateTag(
-        node,
-        /*includeElementAccess*/
-        true,
-        /*skipPastOuterExpressions*/
-        true
-      ) || isDecoratorTarget(
-        node,
-        /*includeElementAccess*/
-        true,
-        /*skipPastOuterExpressions*/
-        true
-      ) || isJsxOpeningLikeElementTagName(
-        node,
-        /*includeElementAccess*/
-        true,
-        /*skipPastOuterExpressions*/
-        true
-      ) || isRightSideOfPropertyAccess(node) || isArgumentExpressionOfElementAccess(node)) {
-        const sourceFile = node.getSourceFile();
-        const ancestor = findAncestor(node, isValidCallHierarchyDeclaration) || sourceFile;
-        return { declaration: ancestor, range: createTextRangeFromNode(node, sourceFile) };
+  function doAddExistingFix(changes, sourceFile, clause, defaultImport, namedImports, preferences) {
+    var _a;
+    if (clause.kind === 206 /* ObjectBindingPattern */) {
+      if (defaultImport) {
+        addElementToBindingPattern(clause, defaultImport.name, "default");
+      }
+      for (const specifier of namedImports) {
+        addElementToBindingPattern(
+          clause,
+          specifier.name,
+          /*propertyName*/
+          void 0
+        );
       }
+      return;
     }
-  }
-  function getCallSiteGroupKey(entry) {
-    return getNodeId(entry.declaration);
-  }
-  function createCallHierarchyIncomingCall(from, fromSpans) {
-    return { from, fromSpans };
-  }
-  function convertCallSiteGroupToIncomingCall(program, entries) {
-    return createCallHierarchyIncomingCall(createCallHierarchyItem(program, entries[0].declaration), map(entries, (entry) => createTextSpanFromRange(entry.range)));
-  }
-  function getIncomingCalls(program, declaration, cancellationToken) {
-    if (isSourceFile(declaration) || isModuleDeclaration(declaration) || isClassStaticBlockDeclaration(declaration)) {
-      return [];
+    const promoteFromTypeOnly2 = clause.isTypeOnly && some([defaultImport, ...namedImports], (i) => (i == null ? void 0 : i.addAsTypeOnly) === 4 /* NotAllowed */);
+    const existingSpecifiers = clause.namedBindings && ((_a = tryCast(clause.namedBindings, isNamedImports)) == null ? void 0 : _a.elements);
+    if (defaultImport) {
+      Debug.assert(!clause.name, "Cannot add a default import to an import clause that already has one");
+      changes.insertNodeAt(sourceFile, clause.getStart(sourceFile), factory.createIdentifier(defaultImport.name), { suffix: ", " });
     }
-    const location = getCallHierarchyDeclarationReferenceNode(declaration);
-    const calls = filter(ts_FindAllReferences_exports.findReferenceOrRenameEntries(
-      program,
-      cancellationToken,
-      program.getSourceFiles(),
-      location,
-      /*position*/
-      0,
-      { use: ts_FindAllReferences_exports.FindReferencesUse.References },
-      convertEntryToCallSite
-    ), isDefined);
-    return calls ? group(calls, getCallSiteGroupKey, (entries) => convertCallSiteGroupToIncomingCall(program, entries)) : [];
-  }
-  function createCallSiteCollector(program, callSites) {
-    function recordCallSite(node) {
-      const target = isTaggedTemplateExpression(node) ? node.tag : isJsxOpeningLikeElement(node) ? node.tagName : isAccessExpression(node) ? node : isClassStaticBlockDeclaration(node) ? node : node.expression;
-      const declaration = resolveCallHierarchyDeclaration(program, target);
-      if (declaration) {
-        const range = createTextRangeFromNode(target, node.getSourceFile());
-        if (isArray(declaration)) {
-          for (const decl of declaration) {
-            callSites.push({ declaration: decl, range });
-          }
-        } else {
-          callSites.push({ declaration, range });
+    if (namedImports.length) {
+      let ignoreCaseForSorting;
+      if (typeof preferences.organizeImportsIgnoreCase === "boolean") {
+        ignoreCaseForSorting = preferences.organizeImportsIgnoreCase;
+      } else if (existingSpecifiers) {
+        const targetImportSorting = ts_OrganizeImports_exports.detectImportSpecifierSorting(existingSpecifiers, preferences);
+        if (targetImportSorting !== 3 /* Both */) {
+          ignoreCaseForSorting = targetImportSorting === 2 /* CaseInsensitive */;
         }
       }
-    }
-    function collect(node) {
-      if (!node)
-        return;
-      if (node.flags & 16777216 /* Ambient */) {
-        return;
+      if (ignoreCaseForSorting === void 0) {
+        ignoreCaseForSorting = ts_OrganizeImports_exports.detectSorting(sourceFile, preferences) === 2 /* CaseInsensitive */;
       }
-      if (isValidCallHierarchyDeclaration(node)) {
-        if (isClassLike(node)) {
-          for (const member of node.members) {
-            if (member.name && isComputedPropertyName(member.name)) {
-              collect(member.name.expression);
-            }
+      const comparer = ts_OrganizeImports_exports.getOrganizeImportsComparer(preferences, ignoreCaseForSorting);
+      const newSpecifiers = stableSort(
+        namedImports.map(
+          (namedImport) => factory.createImportSpecifier(
+            (!clause.isTypeOnly || promoteFromTypeOnly2) && shouldUseTypeOnly(namedImport, preferences),
+            /*propertyName*/
+            void 0,
+            factory.createIdentifier(namedImport.name)
+          )
+        ),
+        (s1, s2) => ts_OrganizeImports_exports.compareImportOrExportSpecifiers(s1, s2, comparer)
+      );
+      const specifierSort = (existingSpecifiers == null ? void 0 : existingSpecifiers.length) && ts_OrganizeImports_exports.detectImportSpecifierSorting(existingSpecifiers, preferences);
+      if (specifierSort && !(ignoreCaseForSorting && specifierSort === 1 /* CaseSensitive */)) {
+        for (const spec of newSpecifiers) {
+          const insertionIndex = promoteFromTypeOnly2 && !spec.isTypeOnly ? 0 : ts_OrganizeImports_exports.getImportSpecifierInsertionIndex(existingSpecifiers, spec, comparer);
+          changes.insertImportSpecifierAtIndex(sourceFile, spec, clause.namedBindings, insertionIndex);
+        }
+      } else if (existingSpecifiers == null ? void 0 : existingSpecifiers.length) {
+        for (const spec of newSpecifiers) {
+          changes.insertNodeInListAfter(sourceFile, last(existingSpecifiers), spec, existingSpecifiers);
+        }
+      } else {
+        if (newSpecifiers.length) {
+          const namedImports2 = factory.createNamedImports(newSpecifiers);
+          if (clause.namedBindings) {
+            changes.replaceNode(sourceFile, clause.namedBindings, namedImports2);
+          } else {
+            changes.insertNodeAfter(sourceFile, Debug.checkDefined(clause.name, "Import clause must have either named imports or a default import"), namedImports2);
           }
         }
-        return;
       }
-      switch (node.kind) {
-        case 80 /* Identifier */:
-        case 270 /* ImportEqualsDeclaration */:
-        case 271 /* ImportDeclaration */:
-        case 277 /* ExportDeclaration */:
-        case 263 /* InterfaceDeclaration */:
-        case 264 /* TypeAliasDeclaration */:
-          return;
-        case 174 /* ClassStaticBlockDeclaration */:
-          recordCallSite(node);
-          return;
-        case 215 /* TypeAssertionExpression */:
-        case 233 /* AsExpression */:
-          collect(node.expression);
-          return;
-        case 259 /* VariableDeclaration */:
-        case 168 /* Parameter */:
-          collect(node.name);
-          collect(node.initializer);
-          return;
-        case 212 /* CallExpression */:
-          recordCallSite(node);
-          collect(node.expression);
-          forEach(node.arguments, collect);
-          return;
-        case 213 /* NewExpression */:
-          recordCallSite(node);
-          collect(node.expression);
-          forEach(node.arguments, collect);
-          return;
-        case 214 /* TaggedTemplateExpression */:
-          recordCallSite(node);
-          collect(node.tag);
-          collect(node.template);
-          return;
-        case 285 /* JsxOpeningElement */:
-        case 284 /* JsxSelfClosingElement */:
-          recordCallSite(node);
-          collect(node.tagName);
-          collect(node.attributes);
-          return;
-        case 169 /* Decorator */:
-          recordCallSite(node);
-          collect(node.expression);
-          return;
-        case 210 /* PropertyAccessExpression */:
-        case 211 /* ElementAccessExpression */:
-          recordCallSite(node);
-          forEachChild(node, collect);
-          break;
-        case 237 /* SatisfiesExpression */:
-          collect(node.expression);
-          return;
+    }
+    if (promoteFromTypeOnly2) {
+      changes.delete(sourceFile, getTypeKeywordOfTypeOnlyImport(clause, sourceFile));
+      if (existingSpecifiers) {
+        for (const specifier of existingSpecifiers) {
+          changes.insertModifierBefore(sourceFile, 156 /* TypeKeyword */, specifier);
+        }
       }
-      if (isPartOfTypeNode(node)) {
-        return;
+    }
+    function addElementToBindingPattern(bindingPattern, name, propertyName) {
+      const element = factory.createBindingElement(
+        /*dotDotDotToken*/
+        void 0,
+        propertyName,
+        name
+      );
+      if (bindingPattern.elements.length) {
+        changes.insertNodeInListAfter(sourceFile, last(bindingPattern.elements), element);
+      } else {
+        changes.replaceNode(sourceFile, bindingPattern, factory.createObjectBindingPattern([element]));
       }
-      forEachChild(node, collect);
     }
-    return collect;
   }
-  function collectCallSitesOfSourceFile(node, collect) {
-    forEach(node.statements, collect);
+  function addNamespaceQualifier(changes, sourceFile, { namespacePrefix, usagePosition }) {
+    changes.insertText(sourceFile, usagePosition, namespacePrefix + ".");
   }
-  function collectCallSitesOfModuleDeclaration(node, collect) {
-    if (!hasSyntacticModifier(node, 2 /* Ambient */) && node.body && isModuleBlock(node.body)) {
-      forEach(node.body.statements, collect);
-    }
+  function addImportType(changes, sourceFile, { moduleSpecifier, usagePosition: position }, quotePreference) {
+    changes.insertText(sourceFile, position, getImportTypePrefix(moduleSpecifier, quotePreference));
   }
-  function collectCallSitesOfFunctionLikeDeclaration(typeChecker, node, collect) {
-    const implementation = findImplementation(typeChecker, node);
-    if (implementation) {
-      forEach(implementation.parameters, collect);
-      collect(implementation.body);
-    }
+  function getImportTypePrefix(moduleSpecifier, quotePreference) {
+    const quote2 = getQuoteFromPreference(quotePreference);
+    return `import(${quote2}${moduleSpecifier}${quote2}).`;
   }
-  function collectCallSitesOfClassStaticBlockDeclaration(node, collect) {
-    collect(node.body);
+  function needsTypeOnly({ addAsTypeOnly }) {
+    return addAsTypeOnly === 2 /* Required */;
   }
-  function collectCallSitesOfClassLikeDeclaration(node, collect) {
-    forEach(node.modifiers, collect);
-    const heritage = getClassExtendsHeritageElement(node);
-    if (heritage) {
-      collect(heritage.expression);
+  function shouldUseTypeOnly(info, preferences) {
+    return needsTypeOnly(info) || !!preferences.preferTypeOnlyAutoImports && info.addAsTypeOnly !== 4 /* NotAllowed */;
+  }
+  function getNewImports(moduleSpecifier, quotePreference, defaultImport, namedImports, namespaceLikeImport, compilerOptions, preferences) {
+    const quotedModuleSpecifier = makeStringLiteral(moduleSpecifier, quotePreference);
+    let statements;
+    if (defaultImport !== void 0 || (namedImports == null ? void 0 : namedImports.length)) {
+      const topLevelTypeOnly = (!defaultImport || needsTypeOnly(defaultImport)) && every(namedImports, needsTypeOnly) || (compilerOptions.verbatimModuleSyntax || preferences.preferTypeOnlyAutoImports) && (defaultImport == null ? void 0 : defaultImport.addAsTypeOnly) !== 4 /* NotAllowed */ && !some(namedImports, (i) => i.addAsTypeOnly === 4 /* NotAllowed */);
+      statements = combine(
+        statements,
+        makeImport(
+          defaultImport && factory.createIdentifier(defaultImport.name),
+          namedImports == null ? void 0 : namedImports.map(
+            (namedImport) => factory.createImportSpecifier(
+              !topLevelTypeOnly && shouldUseTypeOnly(namedImport, preferences),
+              /*propertyName*/
+              void 0,
+              factory.createIdentifier(namedImport.name)
+            )
+          ),
+          moduleSpecifier,
+          quotePreference,
+          topLevelTypeOnly
+        )
+      );
     }
-    for (const member of node.members) {
-      if (canHaveModifiers(member)) {
-        forEach(member.modifiers, collect);
-      }
-      if (isPropertyDeclaration(member)) {
-        collect(member.initializer);
-      } else if (isConstructorDeclaration(member) && member.body) {
-        forEach(member.parameters, collect);
-        collect(member.body);
-      } else if (isClassStaticBlockDeclaration(member)) {
-        collect(member);
-      }
+    if (namespaceLikeImport) {
+      const declaration = namespaceLikeImport.importKind === 3 /* CommonJS */ ? factory.createImportEqualsDeclaration(
+        /*modifiers*/
+        void 0,
+        shouldUseTypeOnly(namespaceLikeImport, preferences),
+        factory.createIdentifier(namespaceLikeImport.name),
+        factory.createExternalModuleReference(quotedModuleSpecifier)
+      ) : factory.createImportDeclaration(
+        /*modifiers*/
+        void 0,
+        factory.createImportClause(
+          shouldUseTypeOnly(namespaceLikeImport, preferences),
+          /*name*/
+          void 0,
+          factory.createNamespaceImport(factory.createIdentifier(namespaceLikeImport.name))
+        ),
+        quotedModuleSpecifier,
+        /*attributes*/
+        void 0
+      );
+      statements = combine(statements, declaration);
     }
+    return Debug.checkDefined(statements);
   }
-  function collectCallSites(program, node) {
-    const callSites = [];
-    const collect = createCallSiteCollector(program, callSites);
-    switch (node.kind) {
-      case 311 /* SourceFile */:
-        collectCallSitesOfSourceFile(node, collect);
-        break;
-      case 266 /* ModuleDeclaration */:
-        collectCallSitesOfModuleDeclaration(node, collect);
-        break;
-      case 261 /* FunctionDeclaration */:
-      case 217 /* FunctionExpression */:
-      case 218 /* ArrowFunction */:
-      case 173 /* MethodDeclaration */:
-      case 176 /* GetAccessor */:
-      case 177 /* SetAccessor */:
-        collectCallSitesOfFunctionLikeDeclaration(program.getTypeChecker(), node, collect);
-        break;
-      case 262 /* ClassDeclaration */:
-      case 230 /* ClassExpression */:
-        collectCallSitesOfClassLikeDeclaration(node, collect);
-        break;
-      case 174 /* ClassStaticBlockDeclaration */:
-        collectCallSitesOfClassStaticBlockDeclaration(node, collect);
-        break;
-      default:
-        Debug.assertNever(node);
+  function getNewRequires(moduleSpecifier, quotePreference, defaultImport, namedImports, namespaceLikeImport) {
+    const quotedModuleSpecifier = makeStringLiteral(moduleSpecifier, quotePreference);
+    let statements;
+    if (defaultImport || (namedImports == null ? void 0 : namedImports.length)) {
+      const bindingElements = (namedImports == null ? void 0 : namedImports.map(({ name }) => factory.createBindingElement(
+        /*dotDotDotToken*/
+        void 0,
+        /*propertyName*/
+        void 0,
+        name
+      ))) || [];
+      if (defaultImport) {
+        bindingElements.unshift(factory.createBindingElement(
+          /*dotDotDotToken*/
+          void 0,
+          "default",
+          defaultImport.name
+        ));
+      }
+      const declaration = createConstEqualsRequireDeclaration(factory.createObjectBindingPattern(bindingElements), quotedModuleSpecifier);
+      statements = combine(statements, declaration);
     }
-    return callSites;
+    if (namespaceLikeImport) {
+      const declaration = createConstEqualsRequireDeclaration(namespaceLikeImport.name, quotedModuleSpecifier);
+      statements = combine(statements, declaration);
+    }
+    return Debug.checkDefined(statements);
   }
-  function createCallHierarchyOutgoingCall(to, fromSpans) {
-    return { to, fromSpans };
+  function createConstEqualsRequireDeclaration(name, quotedModuleSpecifier) {
+    return factory.createVariableStatement(
+      /*modifiers*/
+      void 0,
+      factory.createVariableDeclarationList([
+        factory.createVariableDeclaration(
+          typeof name === "string" ? factory.createIdentifier(name) : name,
+          /*exclamationToken*/
+          void 0,
+          /*type*/
+          void 0,
+          factory.createCallExpression(
+            factory.createIdentifier("require"),
+            /*typeArguments*/
+            void 0,
+            [quotedModuleSpecifier]
+          )
+        )
+      ], 2 /* Const */)
+    );
   }
-  function convertCallSiteGroupToOutgoingCall(program, entries) {
-    return createCallHierarchyOutgoingCall(createCallHierarchyItem(program, entries[0].declaration), map(entries, (entry) => createTextSpanFromRange(entry.range)));
+  function symbolHasMeaning({ declarations }, meaning) {
+    return some(declarations, (decl) => !!(getMeaningFromDeclaration(decl) & meaning));
   }
-  function getOutgoingCalls(program, declaration) {
-    if (declaration.flags & 16777216 /* Ambient */ || isMethodSignature(declaration)) {
-      return [];
+  function moduleSymbolToValidIdentifier(moduleSymbol, target, forceCapitalize) {
+    return moduleSpecifierToValidIdentifier(removeFileExtension(stripQuotes(moduleSymbol.name)), target, forceCapitalize);
+  }
+  function moduleSpecifierToValidIdentifier(moduleSpecifier, target, forceCapitalize) {
+    const baseName = getBaseFileName(removeSuffix(moduleSpecifier, "/index"));
+    let res = "";
+    let lastCharWasValid = true;
+    const firstCharCode = baseName.charCodeAt(0);
+    if (isIdentifierStart(firstCharCode, target)) {
+      res += String.fromCharCode(firstCharCode);
+      if (forceCapitalize) {
+        res = res.toUpperCase();
+      }
+    } else {
+      lastCharWasValid = false;
     }
-    return group(collectCallSites(program, declaration), getCallSiteGroupKey, (entries) => convertCallSiteGroupToOutgoingCall(program, entries));
+    for (let i = 1; i < baseName.length; i++) {
+      const ch = baseName.charCodeAt(i);
+      const isValid = isIdentifierPart(ch, target);
+      if (isValid) {
+        let char = String.fromCharCode(ch);
+        if (!lastCharWasValid) {
+          char = char.toUpperCase();
+        }
+        res += char;
+      }
+      lastCharWasValid = isValid;
+    }
+    return !isStringANonContextualKeyword(res) ? res || "_" : `_${res}`;
   }
-  var init_callHierarchy = __esm({
-    "src/services/callHierarchy.ts"() {
+  var importFixName, importFixId, errorCodes18;
+  var init_importFixes = __esm({
+    "src/services/codefixes/importFixes.ts"() {
       "use strict";
       init_ts4();
+      init_ts_codefix();
+      importFixName = "import";
+      importFixId = "fixMissingImport";
+      errorCodes18 = [
+        Diagnostics.Cannot_find_name_0.code,
+        Diagnostics.Cannot_find_name_0_Did_you_mean_1.code,
+        Diagnostics.Cannot_find_name_0_Did_you_mean_the_instance_member_this_0.code,
+        Diagnostics.Cannot_find_name_0_Did_you_mean_the_static_member_1_0.code,
+        Diagnostics.Cannot_find_namespace_0.code,
+        Diagnostics._0_refers_to_a_UMD_global_but_the_current_file_is_a_module_Consider_adding_an_import_instead.code,
+        Diagnostics._0_only_refers_to_a_type_but_is_being_used_as_a_value_here.code,
+        Diagnostics.No_value_exists_in_scope_for_the_shorthand_property_0_Either_declare_one_or_provide_an_initializer.code,
+        Diagnostics._0_cannot_be_used_as_a_value_because_it_was_imported_using_import_type.code
+      ];
+      registerCodeFix({
+        errorCodes: errorCodes18,
+        getCodeActions(context) {
+          const { errorCode, preferences, sourceFile, span, program } = context;
+          const info = getFixInfos(
+            context,
+            errorCode,
+            span.start,
+            /*useAutoImportProvider*/
+            true
+          );
+          if (!info)
+            return void 0;
+          return info.map(
+            ({ fix, symbolName: symbolName2, errorIdentifierText }) => codeActionForFix(
+              context,
+              sourceFile,
+              symbolName2,
+              fix,
+              /*includeSymbolNameInDescription*/
+              symbolName2 !== errorIdentifierText,
+              program,
+              preferences
+            )
+          );
+        },
+        fixIds: [importFixId],
+        getAllCodeActions: (context) => {
+          const { sourceFile, program, preferences, host, cancellationToken } = context;
+          const importAdder = createImportAdderWorker(
+            sourceFile,
+            program,
+            /*useAutoImportProvider*/
+            true,
+            preferences,
+            host,
+            cancellationToken
+          );
+          eachDiagnostic(context, errorCodes18, (diag2) => importAdder.addImportFromDiagnostic(diag2, context));
+          return createCombinedCodeActions(ts_textChanges_exports.ChangeTracker.with(context, importAdder.writeFixes));
+        }
+      });
     }
   });
 
-  // src/services/_namespaces/ts.CallHierarchy.ts
-  var ts_CallHierarchy_exports = {};
-  __export(ts_CallHierarchy_exports, {
-    createCallHierarchyItem: () => createCallHierarchyItem,
-    getIncomingCalls: () => getIncomingCalls,
-    getOutgoingCalls: () => getOutgoingCalls,
-    resolveCallHierarchyDeclaration: () => resolveCallHierarchyDeclaration
-  });
-  var init_ts_CallHierarchy = __esm({
-    "src/services/_namespaces/ts.CallHierarchy.ts"() {
-      "use strict";
-      init_callHierarchy();
-    }
-  });
-
-  // src/services/_namespaces/ts.classifier.v2020.ts
-  var ts_classifier_v2020_exports = {};
-  __export(ts_classifier_v2020_exports, {
-    TokenEncodingConsts: () => TokenEncodingConsts,
-    TokenModifier: () => TokenModifier,
-    TokenType: () => TokenType,
-    getEncodedSemanticClassifications: () => getEncodedSemanticClassifications2,
-    getSemanticClassifications: () => getSemanticClassifications2
-  });
-  var init_ts_classifier_v2020 = __esm({
-    "src/services/_namespaces/ts.classifier.v2020.ts"() {
-      "use strict";
-      init_classifier2020();
+  // src/services/codefixes/fixAddMissingConstraint.ts
+  function getInfo6(program, sourceFile, span) {
+    const diag2 = find(program.getSemanticDiagnostics(sourceFile), (diag3) => diag3.start === span.start && diag3.length === span.length);
+    if (diag2 === void 0 || diag2.relatedInformation === void 0)
+      return;
+    const related = find(diag2.relatedInformation, (related2) => related2.code === Diagnostics.This_type_parameter_might_need_an_extends_0_constraint.code);
+    if (related === void 0 || related.file === void 0 || related.start === void 0 || related.length === void 0)
+      return;
+    let declaration = findAncestorMatchingSpan(related.file, createTextSpan(related.start, related.length));
+    if (declaration === void 0)
+      return;
+    if (isIdentifier(declaration) && isTypeParameterDeclaration(declaration.parent)) {
+      declaration = declaration.parent;
     }
-  });
-
-  // src/services/_namespaces/ts.classifier.ts
-  var ts_classifier_exports = {};
-  __export(ts_classifier_exports, {
-    v2020: () => ts_classifier_v2020_exports
-  });
-  var init_ts_classifier = __esm({
-    "src/services/_namespaces/ts.classifier.ts"() {
-      "use strict";
-      init_ts_classifier_v2020();
+    if (isTypeParameterDeclaration(declaration)) {
+      if (isMappedTypeNode(declaration.parent))
+        return;
+      const token = getTokenAtPosition(sourceFile, span.start);
+      const checker = program.getTypeChecker();
+      const constraint = tryGetConstraintType(checker, token) || tryGetConstraintFromDiagnosticMessage(related.messageText);
+      return { constraint, declaration, token };
     }
-  });
-
-  // src/services/codeFixProvider.ts
-  function createCodeFixActionWithoutFixAll(fixName8, changes, description3) {
-    return createCodeFixActionWorker(
-      fixName8,
-      diagnosticToString(description3),
-      changes,
-      /*fixId*/
-      void 0,
-      /*fixAllDescription*/
-      void 0
-    );
-  }
-  function createCodeFixAction(fixName8, changes, description3, fixId52, fixAllDescription, command) {
-    return createCodeFixActionWorker(fixName8, diagnosticToString(description3), changes, fixId52, diagnosticToString(fixAllDescription), command);
-  }
-  function createCodeFixActionMaybeFixAll(fixName8, changes, description3, fixId52, fixAllDescription, command) {
-    return createCodeFixActionWorker(fixName8, diagnosticToString(description3), changes, fixId52, fixAllDescription && diagnosticToString(fixAllDescription), command);
-  }
-  function createCodeFixActionWorker(fixName8, description3, changes, fixId52, fixAllDescription, command) {
-    return { fixName: fixName8, description: description3, changes, fixId: fixId52, fixAllDescription, commands: command ? [command] : void 0 };
+    return void 0;
   }
-  function registerCodeFix(reg) {
-    for (const error of reg.errorCodes) {
-      errorCodeToFixesArray = void 0;
-      errorCodeToFixes.add(String(error), reg);
-    }
-    if (reg.fixIds) {
-      for (const fixId52 of reg.fixIds) {
-        Debug.assert(!fixIdToRegistration.has(fixId52));
-        fixIdToRegistration.set(fixId52, reg);
+  function addMissingConstraint(changes, program, preferences, host, sourceFile, info) {
+    const { declaration, constraint } = info;
+    const checker = program.getTypeChecker();
+    if (isString(constraint)) {
+      changes.insertText(sourceFile, declaration.name.end, ` extends ${constraint}`);
+    } else {
+      const scriptTarget = getEmitScriptTarget(program.getCompilerOptions());
+      const tracker = getNoopSymbolTrackerWithResolver({ program, host });
+      const importAdder = createImportAdder(sourceFile, program, preferences, host);
+      const typeNode = typeToAutoImportableTypeNode(
+        checker,
+        importAdder,
+        constraint,
+        /*contextNode*/
+        void 0,
+        scriptTarget,
+        /*flags*/
+        void 0,
+        tracker
+      );
+      if (typeNode) {
+        changes.replaceNode(sourceFile, declaration, factory.updateTypeParameterDeclaration(
+          declaration,
+          /*modifiers*/
+          void 0,
+          declaration.name,
+          typeNode,
+          declaration.default
+        ));
+        importAdder.writeFixes(changes);
       }
     }
   }
-  function getSupportedErrorCodes() {
-    return errorCodeToFixesArray ?? (errorCodeToFixesArray = arrayFrom(errorCodeToFixes.keys()));
-  }
-  function removeFixIdIfFixAllUnavailable(registration, diagnostics) {
-    const { errorCodes: errorCodes64 } = registration;
-    let maybeFixableDiagnostics = 0;
-    for (const diag2 of diagnostics) {
-      if (contains(errorCodes64, diag2.code))
-        maybeFixableDiagnostics++;
-      if (maybeFixableDiagnostics > 1)
-        break;
-    }
-    const fixAllUnavailable = maybeFixableDiagnostics < 2;
-    return ({ fixId: fixId52, fixAllDescription, ...action }) => {
-      return fixAllUnavailable ? action : { ...action, fixId: fixId52, fixAllDescription };
-    };
-  }
-  function getFixes(context) {
-    const diagnostics = getDiagnostics(context);
-    const registrations = errorCodeToFixes.get(String(context.errorCode));
-    return flatMap(registrations, (f) => map(f.getCodeActions(context), removeFixIdIfFixAllUnavailable(f, diagnostics)));
-  }
-  function getAllFixes(context) {
-    return fixIdToRegistration.get(cast(context.fixId, isString)).getAllCodeActions(context);
-  }
-  function createCombinedCodeActions(changes, commands) {
-    return { changes, commands };
-  }
-  function createFileTextChanges(fileName, textChanges2) {
-    return { fileName, textChanges: textChanges2 };
-  }
-  function codeFixAll(context, errorCodes64, use) {
-    const commands = [];
-    const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => eachDiagnostic(context, errorCodes64, (diag2) => use(t, diag2, commands)));
-    return createCombinedCodeActions(changes, commands.length === 0 ? void 0 : commands);
+  function tryGetConstraintFromDiagnosticMessage(messageText) {
+    const [_, constraint] = flattenDiagnosticMessageText(messageText, "\n", 0).match(/`extends (.*)`/) || [];
+    return constraint;
   }
-  function eachDiagnostic(context, errorCodes64, cb) {
-    for (const diag2 of getDiagnostics(context)) {
-      if (contains(errorCodes64, diag2.code)) {
-        cb(diag2);
-      }
+  function tryGetConstraintType(checker, node) {
+    if (isTypeNode(node.parent)) {
+      return checker.getTypeArgumentConstraint(node.parent);
     }
+    const contextualType = isExpression(node) ? checker.getContextualType(node) : void 0;
+    return contextualType || checker.getTypeAtLocation(node);
   }
-  function getDiagnostics({ program, sourceFile, cancellationToken }) {
-    return [
-      ...program.getSemanticDiagnostics(sourceFile, cancellationToken),
-      ...program.getSyntacticDiagnostics(sourceFile, cancellationToken),
-      ...computeSuggestionDiagnostics(sourceFile, program, cancellationToken)
-    ];
-  }
-  var errorCodeToFixes, fixIdToRegistration, errorCodeToFixesArray;
-  var init_codeFixProvider = __esm({
-    "src/services/codeFixProvider.ts"() {
+  var fixId17, errorCodes19;
+  var init_fixAddMissingConstraint = __esm({
+    "src/services/codefixes/fixAddMissingConstraint.ts"() {
       "use strict";
       init_ts4();
-      errorCodeToFixes = createMultiMap();
-      fixIdToRegistration = /* @__PURE__ */ new Map();
+      init_ts_codefix();
+      fixId17 = "addMissingConstraint";
+      errorCodes19 = [
+        // We want errors this could be attached to:
+        // Diagnostics.This_type_parameter_probably_needs_an_extends_0_constraint
+        Diagnostics.Type_0_is_not_comparable_to_type_1.code,
+        Diagnostics.Type_0_is_not_assignable_to_type_1_Two_different_types_with_this_name_exist_but_they_are_unrelated.code,
+        Diagnostics.Type_0_is_not_assignable_to_type_1_with_exactOptionalPropertyTypes_Colon_true_Consider_adding_undefined_to_the_types_of_the_target_s_properties.code,
+        Diagnostics.Type_0_is_not_assignable_to_type_1.code,
+        Diagnostics.Argument_of_type_0_is_not_assignable_to_parameter_of_type_1_with_exactOptionalPropertyTypes_Colon_true_Consider_adding_undefined_to_the_types_of_the_target_s_properties.code,
+        Diagnostics.Property_0_is_incompatible_with_index_signature.code,
+        Diagnostics.Property_0_in_type_1_is_not_assignable_to_type_2.code,
+        Diagnostics.Type_0_does_not_satisfy_the_constraint_1.code
+      ];
+      registerCodeFix({
+        errorCodes: errorCodes19,
+        getCodeActions(context) {
+          const { sourceFile, span, program, preferences, host } = context;
+          const info = getInfo6(program, sourceFile, span);
+          if (info === void 0)
+            return;
+          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => addMissingConstraint(t, program, preferences, host, sourceFile, info));
+          return [createCodeFixAction(fixId17, changes, Diagnostics.Add_extends_constraint, fixId17, Diagnostics.Add_extends_constraint_to_all_type_parameters)];
+        },
+        fixIds: [fixId17],
+        getAllCodeActions: (context) => {
+          const { program, preferences, host } = context;
+          const seen = /* @__PURE__ */ new Map();
+          return createCombinedCodeActions(ts_textChanges_exports.ChangeTracker.with(context, (changes) => {
+            eachDiagnostic(context, errorCodes19, (diag2) => {
+              const info = getInfo6(program, diag2.file, createTextSpan(diag2.start, diag2.length));
+              if (info) {
+                if (addToSeen(seen, getNodeId(info.declaration))) {
+                  return addMissingConstraint(changes, program, preferences, host, diag2.file, info);
+                }
+              }
+              return void 0;
+            });
+          }));
+        }
+      });
     }
   });
 
-  // src/services/codefixes/addConvertToUnknownForNonOverlappingTypes.ts
-  function makeChange(changeTracker, sourceFile, assertion) {
-    const replacement = isAsExpression(assertion) ? factory.createAsExpression(assertion.expression, factory.createKeywordTypeNode(159 /* UnknownKeyword */)) : factory.createTypeAssertion(factory.createKeywordTypeNode(159 /* UnknownKeyword */), assertion.expression);
-    changeTracker.replaceNode(sourceFile, assertion.expression, replacement);
+  // src/services/codefixes/fixOverrideModifier.ts
+  function dispatchChanges(changeTracker, context, errorCode, pos) {
+    switch (errorCode) {
+      case Diagnostics.This_member_must_have_an_override_modifier_because_it_overrides_a_member_in_the_base_class_0.code:
+      case Diagnostics.This_member_must_have_a_JSDoc_comment_with_an_override_tag_because_it_overrides_a_member_in_the_base_class_0.code:
+      case Diagnostics.This_member_must_have_an_override_modifier_because_it_overrides_an_abstract_method_that_is_declared_in_the_base_class_0.code:
+      case Diagnostics.This_parameter_property_must_have_an_override_modifier_because_it_overrides_a_member_in_base_class_0.code:
+      case Diagnostics.This_parameter_property_must_have_a_JSDoc_comment_with_an_override_tag_because_it_overrides_a_member_in_the_base_class_0.code:
+        return doAddOverrideModifierChange(changeTracker, context.sourceFile, pos);
+      case Diagnostics.This_member_cannot_have_an_override_modifier_because_it_is_not_declared_in_the_base_class_0.code:
+      case Diagnostics.This_member_cannot_have_a_JSDoc_comment_with_an_override_tag_because_it_is_not_declared_in_the_base_class_0.code:
+      case Diagnostics.This_member_cannot_have_an_override_modifier_because_its_containing_class_0_does_not_extend_another_class.code:
+      case Diagnostics.This_member_cannot_have_a_JSDoc_comment_with_an_override_tag_because_its_containing_class_0_does_not_extend_another_class.code:
+        return doRemoveOverrideModifierChange(changeTracker, context.sourceFile, pos);
+      default:
+        Debug.fail("Unexpected error code: " + errorCode);
+    }
   }
-  function getAssertion(sourceFile, pos) {
-    if (isInJSFile(sourceFile))
-      return void 0;
-    return findAncestor(getTokenAtPosition(sourceFile, pos), (n) => isAsExpression(n) || isTypeAssertionExpression(n));
+  function doAddOverrideModifierChange(changeTracker, sourceFile, pos) {
+    const classElement = findContainerClassElementLike(sourceFile, pos);
+    if (isSourceFileJS(sourceFile)) {
+      changeTracker.addJSDocTags(sourceFile, classElement, [factory.createJSDocOverrideTag(factory.createIdentifier("override"))]);
+      return;
+    }
+    const modifiers = classElement.modifiers || emptyArray;
+    const staticModifier = find(modifiers, isStaticModifier);
+    const abstractModifier = find(modifiers, isAbstractModifier);
+    const accessibilityModifier = find(modifiers, (m) => isAccessibilityModifier(m.kind));
+    const lastDecorator = findLast(modifiers, isDecorator);
+    const modifierPos = abstractModifier ? abstractModifier.end : staticModifier ? staticModifier.end : accessibilityModifier ? accessibilityModifier.end : lastDecorator ? skipTrivia(sourceFile.text, lastDecorator.end) : classElement.getStart(sourceFile);
+    const options = accessibilityModifier || staticModifier || abstractModifier ? { prefix: " " } : { suffix: " " };
+    changeTracker.insertModifierAt(sourceFile, modifierPos, 164 /* OverrideKeyword */, options);
   }
-  var fixId, errorCodes;
-  var init_addConvertToUnknownForNonOverlappingTypes = __esm({
-    "src/services/codefixes/addConvertToUnknownForNonOverlappingTypes.ts"() {
+  function doRemoveOverrideModifierChange(changeTracker, sourceFile, pos) {
+    const classElement = findContainerClassElementLike(sourceFile, pos);
+    if (isSourceFileJS(sourceFile)) {
+      changeTracker.filterJSDocTags(sourceFile, classElement, not(isJSDocOverrideTag));
+      return;
+    }
+    const overrideModifier = find(classElement.modifiers, isOverrideModifier);
+    Debug.assertIsDefined(overrideModifier);
+    changeTracker.deleteModifier(sourceFile, overrideModifier);
+  }
+  function isClassElementLikeHasJSDoc(node) {
+    switch (node.kind) {
+      case 176 /* Constructor */:
+      case 172 /* PropertyDeclaration */:
+      case 174 /* MethodDeclaration */:
+      case 177 /* GetAccessor */:
+      case 178 /* SetAccessor */:
+        return true;
+      case 169 /* Parameter */:
+        return isParameterPropertyDeclaration(node, node.parent);
+      default:
+        return false;
+    }
+  }
+  function findContainerClassElementLike(sourceFile, pos) {
+    const token = getTokenAtPosition(sourceFile, pos);
+    const classElement = findAncestor(token, (node) => {
+      if (isClassLike(node))
+        return "quit";
+      return isClassElementLikeHasJSDoc(node);
+    });
+    Debug.assert(classElement && isClassElementLikeHasJSDoc(classElement));
+    return classElement;
+  }
+  var fixName, fixAddOverrideId, fixRemoveOverrideId, errorCodes20, errorCodeFixIdMap;
+  var init_fixOverrideModifier = __esm({
+    "src/services/codefixes/fixOverrideModifier.ts"() {
       "use strict";
       init_ts4();
       init_ts_codefix();
-      fixId = "addConvertToUnknownForNonOverlappingTypes";
-      errorCodes = [Diagnostics.Conversion_of_type_0_to_type_1_may_be_a_mistake_because_neither_type_sufficiently_overlaps_with_the_other_If_this_was_intentional_convert_the_expression_to_unknown_first.code];
+      fixName = "fixOverrideModifier";
+      fixAddOverrideId = "fixAddOverrideModifier";
+      fixRemoveOverrideId = "fixRemoveOverrideModifier";
+      errorCodes20 = [
+        Diagnostics.This_member_cannot_have_an_override_modifier_because_it_is_not_declared_in_the_base_class_0.code,
+        Diagnostics.This_member_cannot_have_an_override_modifier_because_its_containing_class_0_does_not_extend_another_class.code,
+        Diagnostics.This_member_must_have_an_override_modifier_because_it_overrides_an_abstract_method_that_is_declared_in_the_base_class_0.code,
+        Diagnostics.This_member_must_have_an_override_modifier_because_it_overrides_a_member_in_the_base_class_0.code,
+        Diagnostics.This_parameter_property_must_have_an_override_modifier_because_it_overrides_a_member_in_base_class_0.code,
+        Diagnostics.This_member_must_have_a_JSDoc_comment_with_an_override_tag_because_it_overrides_a_member_in_the_base_class_0.code,
+        Diagnostics.This_member_cannot_have_a_JSDoc_comment_with_an_override_tag_because_its_containing_class_0_does_not_extend_another_class.code,
+        Diagnostics.This_parameter_property_must_have_a_JSDoc_comment_with_an_override_tag_because_it_overrides_a_member_in_the_base_class_0.code,
+        Diagnostics.This_member_cannot_have_a_JSDoc_comment_with_an_override_tag_because_it_is_not_declared_in_the_base_class_0.code
+      ];
+      errorCodeFixIdMap = {
+        // case #1:
+        [Diagnostics.This_member_must_have_an_override_modifier_because_it_overrides_a_member_in_the_base_class_0.code]: {
+          descriptions: Diagnostics.Add_override_modifier,
+          fixId: fixAddOverrideId,
+          fixAllDescriptions: Diagnostics.Add_all_missing_override_modifiers
+        },
+        [Diagnostics.This_member_must_have_a_JSDoc_comment_with_an_override_tag_because_it_overrides_a_member_in_the_base_class_0.code]: {
+          descriptions: Diagnostics.Add_override_modifier,
+          fixId: fixAddOverrideId,
+          fixAllDescriptions: Diagnostics.Add_all_missing_override_modifiers
+        },
+        // case #2:
+        [Diagnostics.This_member_cannot_have_an_override_modifier_because_its_containing_class_0_does_not_extend_another_class.code]: {
+          descriptions: Diagnostics.Remove_override_modifier,
+          fixId: fixRemoveOverrideId,
+          fixAllDescriptions: Diagnostics.Remove_all_unnecessary_override_modifiers
+        },
+        [Diagnostics.This_member_cannot_have_a_JSDoc_comment_with_an_override_tag_because_its_containing_class_0_does_not_extend_another_class.code]: {
+          descriptions: Diagnostics.Remove_override_modifier,
+          fixId: fixRemoveOverrideId,
+          fixAllDescriptions: Diagnostics.Remove_override_modifier
+        },
+        // case #3:
+        [Diagnostics.This_parameter_property_must_have_an_override_modifier_because_it_overrides_a_member_in_base_class_0.code]: {
+          descriptions: Diagnostics.Add_override_modifier,
+          fixId: fixAddOverrideId,
+          fixAllDescriptions: Diagnostics.Add_all_missing_override_modifiers
+        },
+        [Diagnostics.This_parameter_property_must_have_a_JSDoc_comment_with_an_override_tag_because_it_overrides_a_member_in_the_base_class_0.code]: {
+          descriptions: Diagnostics.Add_override_modifier,
+          fixId: fixAddOverrideId,
+          fixAllDescriptions: Diagnostics.Add_all_missing_override_modifiers
+        },
+        // case #4:
+        [Diagnostics.This_member_must_have_an_override_modifier_because_it_overrides_an_abstract_method_that_is_declared_in_the_base_class_0.code]: {
+          descriptions: Diagnostics.Add_override_modifier,
+          fixId: fixAddOverrideId,
+          fixAllDescriptions: Diagnostics.Remove_all_unnecessary_override_modifiers
+        },
+        // case #5:
+        [Diagnostics.This_member_cannot_have_an_override_modifier_because_it_is_not_declared_in_the_base_class_0.code]: {
+          descriptions: Diagnostics.Remove_override_modifier,
+          fixId: fixRemoveOverrideId,
+          fixAllDescriptions: Diagnostics.Remove_all_unnecessary_override_modifiers
+        },
+        [Diagnostics.This_member_cannot_have_a_JSDoc_comment_with_an_override_tag_because_it_is_not_declared_in_the_base_class_0.code]: {
+          descriptions: Diagnostics.Remove_override_modifier,
+          fixId: fixRemoveOverrideId,
+          fixAllDescriptions: Diagnostics.Remove_all_unnecessary_override_modifiers
+        }
+      };
       registerCodeFix({
-        errorCodes,
-        getCodeActions: function getCodeActionsToAddConvertToUnknownForNonOverlappingTypes(context) {
-          const assertion = getAssertion(context.sourceFile, context.span.start);
-          if (assertion === void 0)
-            return void 0;
-          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => makeChange(t, context.sourceFile, assertion));
-          return [createCodeFixAction(fixId, changes, Diagnostics.Add_unknown_conversion_for_non_overlapping_types, fixId, Diagnostics.Add_unknown_to_all_conversions_of_non_overlapping_types)];
+        errorCodes: errorCodes20,
+        getCodeActions: function getCodeActionsToFixOverrideModifierIssues(context) {
+          const { errorCode, span } = context;
+          const info = errorCodeFixIdMap[errorCode];
+          if (!info)
+            return emptyArray;
+          const { descriptions, fixId: fixId52, fixAllDescriptions } = info;
+          const changes = ts_textChanges_exports.ChangeTracker.with(context, (changes2) => dispatchChanges(changes2, context, errorCode, span.start));
+          return [
+            createCodeFixActionMaybeFixAll(fixName, changes, descriptions, fixId52, fixAllDescriptions)
+          ];
         },
-        fixIds: [fixId],
-        getAllCodeActions: (context) => codeFixAll(context, errorCodes, (changes, diag2) => {
-          const assertion = getAssertion(diag2.file, diag2.start);
-          if (assertion) {
-            makeChange(changes, diag2.file, assertion);
+        fixIds: [fixName, fixAddOverrideId, fixRemoveOverrideId],
+        getAllCodeActions: (context) => codeFixAll(context, errorCodes20, (changes, diag2) => {
+          const { code, start } = diag2;
+          const info = errorCodeFixIdMap[code];
+          if (!info || info.fixId !== context.fixId) {
+            return;
           }
+          dispatchChanges(changes, context, code, start);
         })
       });
     }
   });
 
-  // src/services/codefixes/addEmptyExportDeclaration.ts
-  var init_addEmptyExportDeclaration = __esm({
-    "src/services/codefixes/addEmptyExportDeclaration.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_codefix();
-      registerCodeFix({
-        errorCodes: [
-          Diagnostics.await_expressions_are_only_allowed_at_the_top_level_of_a_file_when_that_file_is_a_module_but_this_file_has_no_imports_or_exports_Consider_adding_an_empty_export_to_make_this_file_a_module.code,
-          Diagnostics.for_await_loops_are_only_allowed_at_the_top_level_of_a_file_when_that_file_is_a_module_but_this_file_has_no_imports_or_exports_Consider_adding_an_empty_export_to_make_this_file_a_module.code
-        ],
-        getCodeActions: function getCodeActionsToAddEmptyExportDeclaration(context) {
-          const { sourceFile } = context;
-          const changes = ts_textChanges_exports.ChangeTracker.with(context, (changes2) => {
-            const exportDeclaration = factory.createExportDeclaration(
-              /*modifiers*/
-              void 0,
-              /*isTypeOnly*/
-              false,
-              factory.createNamedExports([]),
-              /*moduleSpecifier*/
-              void 0
-            );
-            changes2.insertNodeAtEndOfScope(sourceFile, sourceFile, exportDeclaration);
-          });
-          return [createCodeFixActionWithoutFixAll("addEmptyExportDeclaration", changes, Diagnostics.Add_export_to_make_this_file_into_a_module)];
-        }
-      });
-    }
-  });
-
-  // src/services/codefixes/addMissingAsync.ts
-  function getFix(context, decl, trackChanges, fixedDeclarations) {
-    const changes = trackChanges((t) => makeChange2(t, context.sourceFile, decl, fixedDeclarations));
-    return createCodeFixAction(fixId2, changes, Diagnostics.Add_async_modifier_to_containing_function, fixId2, Diagnostics.Add_all_missing_async_modifiers);
-  }
-  function makeChange2(changeTracker, sourceFile, insertionSite, fixedDeclarations) {
-    if (fixedDeclarations) {
-      if (fixedDeclarations.has(getNodeId(insertionSite))) {
-        return;
-      }
-    }
-    fixedDeclarations == null ? void 0 : fixedDeclarations.add(getNodeId(insertionSite));
-    const cloneWithModifier = factory.updateModifiers(
-      getSynthesizedDeepClone(
-        insertionSite,
-        /*includeTrivia*/
-        true
-      ),
-      factory.createNodeArray(factory.createModifiersFromModifierFlags(getSyntacticModifierFlags(insertionSite) | 512 /* Async */))
-    );
-    changeTracker.replaceNode(
+  // src/services/codefixes/fixNoPropertyAccessFromIndexSignature.ts
+  function doChange14(changes, sourceFile, node, preferences) {
+    const quotePreference = getQuotePreference(sourceFile, preferences);
+    const argumentsExpression = factory.createStringLiteral(node.name.text, quotePreference === 0 /* Single */);
+    changes.replaceNode(
       sourceFile,
-      insertionSite,
-      cloneWithModifier
+      node,
+      isPropertyAccessChain(node) ? factory.createElementAccessChain(node.expression, node.questionDotToken, argumentsExpression) : factory.createElementAccessExpression(node.expression, argumentsExpression)
     );
   }
-  function getFixableErrorSpanDeclaration(sourceFile, span) {
-    if (!span)
-      return void 0;
-    const token = getTokenAtPosition(sourceFile, span.start);
-    const decl = findAncestor(token, (node) => {
-      if (node.getStart(sourceFile) < span.start || node.getEnd() > textSpanEnd(span)) {
-        return "quit";
-      }
-      return (isArrowFunction(node) || isMethodDeclaration(node) || isFunctionExpression(node) || isFunctionDeclaration(node)) && textSpansEqual(span, createTextSpanFromNode(node, sourceFile));
-    });
-    return decl;
-  }
-  function getIsMatchingAsyncError(span, errorCode) {
-    return ({ start, length: length2, relatedInformation, code }) => isNumber(start) && isNumber(length2) && textSpansEqual({ start, length: length2 }, span) && code === errorCode && !!relatedInformation && some(relatedInformation, (related) => related.code === Diagnostics.Did_you_mean_to_mark_this_function_as_async.code);
+  function getPropertyAccessExpression(sourceFile, pos) {
+    return cast(getTokenAtPosition(sourceFile, pos).parent, isPropertyAccessExpression);
   }
-  var fixId2, errorCodes2;
-  var init_addMissingAsync = __esm({
-    "src/services/codefixes/addMissingAsync.ts"() {
+  var fixId18, errorCodes21;
+  var init_fixNoPropertyAccessFromIndexSignature = __esm({
+    "src/services/codefixes/fixNoPropertyAccessFromIndexSignature.ts"() {
       "use strict";
       init_ts4();
       init_ts_codefix();
-      fixId2 = "addMissingAsync";
-      errorCodes2 = [
-        Diagnostics.Argument_of_type_0_is_not_assignable_to_parameter_of_type_1.code,
-        Diagnostics.Type_0_is_not_assignable_to_type_1.code,
-        Diagnostics.Type_0_is_not_comparable_to_type_1.code
+      fixId18 = "fixNoPropertyAccessFromIndexSignature";
+      errorCodes21 = [
+        Diagnostics.Property_0_comes_from_an_index_signature_so_it_must_be_accessed_with_0.code
       ];
       registerCodeFix({
-        fixIds: [fixId2],
-        errorCodes: errorCodes2,
-        getCodeActions: function getCodeActionsToAddMissingAsync(context) {
-          const { sourceFile, errorCode, cancellationToken, program, span } = context;
-          const diagnostic = find(program.getTypeChecker().getDiagnostics(sourceFile, cancellationToken), getIsMatchingAsyncError(span, errorCode));
-          const directSpan = diagnostic && diagnostic.relatedInformation && find(diagnostic.relatedInformation, (r) => r.code === Diagnostics.Did_you_mean_to_mark_this_function_as_async.code);
-          const decl = getFixableErrorSpanDeclaration(sourceFile, directSpan);
-          if (!decl) {
-            return;
-          }
-          const trackChanges = (cb) => ts_textChanges_exports.ChangeTracker.with(context, cb);
-          return [getFix(context, decl, trackChanges)];
+        errorCodes: errorCodes21,
+        fixIds: [fixId18],
+        getCodeActions(context) {
+          const { sourceFile, span, preferences } = context;
+          const property = getPropertyAccessExpression(sourceFile, span.start);
+          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange14(t, context.sourceFile, property, preferences));
+          return [createCodeFixAction(fixId18, changes, [Diagnostics.Use_element_access_for_0, property.name.text], fixId18, Diagnostics.Use_element_access_for_all_undeclared_properties)];
         },
-        getAllCodeActions: (context) => {
-          const { sourceFile } = context;
-          const fixedDeclarations = /* @__PURE__ */ new Set();
-          return codeFixAll(context, errorCodes2, (t, diagnostic) => {
-            const span = diagnostic.relatedInformation && find(diagnostic.relatedInformation, (r) => r.code === Diagnostics.Did_you_mean_to_mark_this_function_as_async.code);
-            const decl = getFixableErrorSpanDeclaration(sourceFile, span);
-            if (!decl) {
-              return;
-            }
-            const trackChanges = (cb) => (cb(t), []);
-            return getFix(context, decl, trackChanges, fixedDeclarations);
-          });
-        }
+        getAllCodeActions: (context) => codeFixAll(context, errorCodes21, (changes, diag2) => doChange14(changes, diag2.file, getPropertyAccessExpression(diag2.file, diag2.start), context.preferences))
       });
     }
   });
 
-  // src/services/codefixes/addMissingAwait.ts
-  function getAwaitErrorSpanExpression(sourceFile, errorCode, span, cancellationToken, program) {
-    const expression = getFixableErrorSpanExpression(sourceFile, span);
-    return expression && isMissingAwaitError(sourceFile, errorCode, span, cancellationToken, program) && isInsideAwaitableBody(expression) ? expression : void 0;
-  }
-  function getDeclarationSiteFix(context, expression, errorCode, checker, trackChanges, fixedDeclarations) {
-    const { sourceFile, program, cancellationToken } = context;
-    const awaitableInitializers = findAwaitableInitializers(expression, sourceFile, cancellationToken, program, checker);
-    if (awaitableInitializers) {
-      const initializerChanges = trackChanges((t) => {
-        forEach(awaitableInitializers.initializers, ({ expression: expression2 }) => makeChange3(t, errorCode, sourceFile, checker, expression2, fixedDeclarations));
-        if (fixedDeclarations && awaitableInitializers.needsSecondPassForFixAll) {
-          makeChange3(t, errorCode, sourceFile, checker, expression, fixedDeclarations);
-        }
-      });
-      return createCodeFixActionWithoutFixAll(
-        "addMissingAwaitToInitializer",
-        initializerChanges,
-        awaitableInitializers.initializers.length === 1 ? [Diagnostics.Add_await_to_initializer_for_0, awaitableInitializers.initializers[0].declarationSymbol.name] : Diagnostics.Add_await_to_initializers
-      );
-    }
-  }
-  function getUseSiteFix(context, expression, errorCode, checker, trackChanges, fixedDeclarations) {
-    const changes = trackChanges((t) => makeChange3(t, errorCode, context.sourceFile, checker, expression, fixedDeclarations));
-    return createCodeFixAction(fixId3, changes, Diagnostics.Add_await, fixId3, Diagnostics.Fix_all_expressions_possibly_missing_await);
-  }
-  function isMissingAwaitError(sourceFile, errorCode, span, cancellationToken, program) {
-    const checker = program.getTypeChecker();
-    const diagnostics = checker.getDiagnostics(sourceFile, cancellationToken);
-    return some(diagnostics, ({ start, length: length2, relatedInformation, code }) => isNumber(start) && isNumber(length2) && textSpansEqual({ start, length: length2 }, span) && code === errorCode && !!relatedInformation && some(relatedInformation, (related) => related.code === Diagnostics.Did_you_forget_to_use_await.code));
-  }
-  function findAwaitableInitializers(expression, sourceFile, cancellationToken, program, checker) {
-    const identifiers = getIdentifiersFromErrorSpanExpression(expression, checker);
-    if (!identifiers) {
-      return;
-    }
-    let isCompleteFix = identifiers.isCompleteFix;
-    let initializers;
-    for (const identifier of identifiers.identifiers) {
-      const symbol = checker.getSymbolAtLocation(identifier);
-      if (!symbol) {
-        continue;
-      }
-      const declaration = tryCast(symbol.valueDeclaration, isVariableDeclaration);
-      const variableName = declaration && tryCast(declaration.name, isIdentifier);
-      const variableStatement = getAncestor(declaration, 242 /* VariableStatement */);
-      if (!declaration || !variableStatement || declaration.type || !declaration.initializer || variableStatement.getSourceFile() !== sourceFile || hasSyntacticModifier(variableStatement, 1 /* Export */) || !variableName || !isInsideAwaitableBody(declaration.initializer)) {
-        isCompleteFix = false;
-        continue;
-      }
-      const diagnostics = program.getSemanticDiagnostics(sourceFile, cancellationToken);
-      const isUsedElsewhere = ts_FindAllReferences_exports.Core.eachSymbolReferenceInFile(variableName, checker, sourceFile, (reference) => {
-        return identifier !== reference && !symbolReferenceIsAlsoMissingAwait(reference, diagnostics, sourceFile, checker);
-      });
-      if (isUsedElsewhere) {
-        isCompleteFix = false;
-        continue;
-      }
-      (initializers || (initializers = [])).push({
-        expression: declaration.initializer,
-        declarationSymbol: symbol
-      });
-    }
-    return initializers && {
-      initializers,
-      needsSecondPassForFixAll: !isCompleteFix
-    };
-  }
-  function getIdentifiersFromErrorSpanExpression(expression, checker) {
-    if (isPropertyAccessExpression(expression.parent) && isIdentifier(expression.parent.expression)) {
-      return { identifiers: [expression.parent.expression], isCompleteFix: true };
-    }
-    if (isIdentifier(expression)) {
-      return { identifiers: [expression], isCompleteFix: true };
-    }
-    if (isBinaryExpression(expression)) {
-      let sides;
-      let isCompleteFix = true;
-      for (const side of [expression.left, expression.right]) {
-        const type = checker.getTypeAtLocation(side);
-        if (checker.getPromisedTypeOfPromise(type)) {
-          if (!isIdentifier(side)) {
-            isCompleteFix = false;
-            continue;
-          }
-          (sides || (sides = [])).push(side);
-        }
-      }
-      return sides && { identifiers: sides, isCompleteFix };
-    }
-  }
-  function symbolReferenceIsAlsoMissingAwait(reference, diagnostics, sourceFile, checker) {
-    const errorNode = isPropertyAccessExpression(reference.parent) ? reference.parent.name : isBinaryExpression(reference.parent) ? reference.parent : reference;
-    const diagnostic = find(diagnostics, (diagnostic2) => diagnostic2.start === errorNode.getStart(sourceFile) && diagnostic2.start + diagnostic2.length === errorNode.getEnd());
-    return diagnostic && contains(errorCodes3, diagnostic.code) || // A Promise is usually not correct in a binary expression (it's not valid
-    // in an arithmetic expression and an equality comparison seems unusual),
-    // but if the other side of the binary expression has an error, the side
-    // is typed `any` which will squash the error that would identify this
-    // Promise as an invalid operand. So if the whole binary expression is
-    // typed `any` as a result, there is a strong likelihood that this Promise
-    // is accidentally missing `await`.
-    checker.getTypeAtLocation(errorNode).flags & 1 /* Any */;
-  }
-  function isInsideAwaitableBody(node) {
-    return node.kind & 32768 /* AwaitContext */ || !!findAncestor(node, (ancestor) => ancestor.parent && isArrowFunction(ancestor.parent) && ancestor.parent.body === ancestor || isBlock(ancestor) && (ancestor.parent.kind === 261 /* FunctionDeclaration */ || ancestor.parent.kind === 217 /* FunctionExpression */ || ancestor.parent.kind === 218 /* ArrowFunction */ || ancestor.parent.kind === 173 /* MethodDeclaration */));
-  }
-  function makeChange3(changeTracker, errorCode, sourceFile, checker, insertionSite, fixedDeclarations) {
-    if (isForOfStatement(insertionSite.parent) && !insertionSite.parent.awaitModifier) {
-      const exprType = checker.getTypeAtLocation(insertionSite);
-      const asyncIter = checker.getAsyncIterableType();
-      if (asyncIter && checker.isTypeAssignableTo(exprType, asyncIter)) {
-        const forOf = insertionSite.parent;
-        changeTracker.replaceNode(sourceFile, forOf, factory.updateForOfStatement(forOf, factory.createToken(135 /* AwaitKeyword */), forOf.initializer, forOf.expression, forOf.statement));
-        return;
-      }
-    }
-    if (isBinaryExpression(insertionSite)) {
-      for (const side of [insertionSite.left, insertionSite.right]) {
-        if (fixedDeclarations && isIdentifier(side)) {
-          const symbol = checker.getSymbolAtLocation(side);
-          if (symbol && fixedDeclarations.has(getSymbolId(symbol))) {
-            continue;
-          }
-        }
-        const type = checker.getTypeAtLocation(side);
-        const newNode = checker.getPromisedTypeOfPromise(type) ? factory.createAwaitExpression(side) : side;
-        changeTracker.replaceNode(sourceFile, side, newNode);
-      }
-    } else if (errorCode === propertyAccessCode && isPropertyAccessExpression(insertionSite.parent)) {
-      if (fixedDeclarations && isIdentifier(insertionSite.parent.expression)) {
-        const symbol = checker.getSymbolAtLocation(insertionSite.parent.expression);
-        if (symbol && fixedDeclarations.has(getSymbolId(symbol))) {
-          return;
-        }
-      }
-      changeTracker.replaceNode(
-        sourceFile,
-        insertionSite.parent.expression,
-        factory.createParenthesizedExpression(factory.createAwaitExpression(insertionSite.parent.expression))
-      );
-      insertLeadingSemicolonIfNeeded(changeTracker, insertionSite.parent.expression, sourceFile);
-    } else if (contains(callableConstructableErrorCodes, errorCode) && isCallOrNewExpression(insertionSite.parent)) {
-      if (fixedDeclarations && isIdentifier(insertionSite)) {
-        const symbol = checker.getSymbolAtLocation(insertionSite);
-        if (symbol && fixedDeclarations.has(getSymbolId(symbol))) {
-          return;
+  // src/services/codefixes/fixImplicitThis.ts
+  function doChange15(changes, sourceFile, pos, checker) {
+    const token = getTokenAtPosition(sourceFile, pos);
+    if (!isThis(token))
+      return void 0;
+    const fn = getThisContainer(
+      token,
+      /*includeArrowFunctions*/
+      false,
+      /*includeClassComputedPropertyName*/
+      false
+    );
+    if (!isFunctionDeclaration(fn) && !isFunctionExpression(fn))
+      return void 0;
+    if (!isSourceFile(getThisContainer(
+      fn,
+      /*includeArrowFunctions*/
+      false,
+      /*includeClassComputedPropertyName*/
+      false
+    ))) {
+      const fnKeyword = Debug.checkDefined(findChildOfKind(fn, 100 /* FunctionKeyword */, sourceFile));
+      const { name } = fn;
+      const body = Debug.checkDefined(fn.body);
+      if (isFunctionExpression(fn)) {
+        if (name && ts_FindAllReferences_exports.Core.isSymbolReferencedInFile(name, checker, sourceFile, body)) {
+          return void 0;
         }
-      }
-      changeTracker.replaceNode(sourceFile, insertionSite, factory.createParenthesizedExpression(factory.createAwaitExpression(insertionSite)));
-      insertLeadingSemicolonIfNeeded(changeTracker, insertionSite, sourceFile);
-    } else {
-      if (fixedDeclarations && isVariableDeclaration(insertionSite.parent) && isIdentifier(insertionSite.parent.name)) {
-        const symbol = checker.getSymbolAtLocation(insertionSite.parent.name);
-        if (symbol && !tryAddToSet(fixedDeclarations, getSymbolId(symbol))) {
-          return;
+        changes.delete(sourceFile, fnKeyword);
+        if (name) {
+          changes.delete(sourceFile, name);
         }
+        changes.insertText(sourceFile, body.pos, " =>");
+        return [Diagnostics.Convert_function_expression_0_to_arrow_function, name ? name.text : ANONYMOUS];
+      } else {
+        changes.replaceNode(sourceFile, fnKeyword, factory.createToken(87 /* ConstKeyword */));
+        changes.insertText(sourceFile, name.end, " = ");
+        changes.insertText(sourceFile, body.pos, " =>");
+        return [Diagnostics.Convert_function_declaration_0_to_arrow_function, name.text];
       }
-      changeTracker.replaceNode(sourceFile, insertionSite, factory.createAwaitExpression(insertionSite));
-    }
-  }
-  function insertLeadingSemicolonIfNeeded(changeTracker, beforeNode, sourceFile) {
-    const precedingToken = findPrecedingToken(beforeNode.pos, sourceFile);
-    if (precedingToken && positionIsASICandidate(precedingToken.end, precedingToken.parent, sourceFile)) {
-      changeTracker.insertText(sourceFile, beforeNode.getStart(sourceFile), ";");
     }
   }
-  var fixId3, propertyAccessCode, callableConstructableErrorCodes, errorCodes3;
-  var init_addMissingAwait = __esm({
-    "src/services/codefixes/addMissingAwait.ts"() {
+  var fixId19, errorCodes22;
+  var init_fixImplicitThis = __esm({
+    "src/services/codefixes/fixImplicitThis.ts"() {
       "use strict";
       init_ts4();
       init_ts_codefix();
-      fixId3 = "addMissingAwait";
-      propertyAccessCode = Diagnostics.Property_0_does_not_exist_on_type_1.code;
-      callableConstructableErrorCodes = [
-        Diagnostics.This_expression_is_not_callable.code,
-        Diagnostics.This_expression_is_not_constructable.code
-      ];
-      errorCodes3 = [
-        Diagnostics.An_arithmetic_operand_must_be_of_type_any_number_bigint_or_an_enum_type.code,
-        Diagnostics.The_left_hand_side_of_an_arithmetic_operation_must_be_of_type_any_number_bigint_or_an_enum_type.code,
-        Diagnostics.The_right_hand_side_of_an_arithmetic_operation_must_be_of_type_any_number_bigint_or_an_enum_type.code,
-        Diagnostics.Operator_0_cannot_be_applied_to_type_1.code,
-        Diagnostics.Operator_0_cannot_be_applied_to_types_1_and_2.code,
-        Diagnostics.This_comparison_appears_to_be_unintentional_because_the_types_0_and_1_have_no_overlap.code,
-        Diagnostics.This_condition_will_always_return_true_since_this_0_is_always_defined.code,
-        Diagnostics.Type_0_is_not_an_array_type.code,
-        Diagnostics.Type_0_is_not_an_array_type_or_a_string_type.code,
-        Diagnostics.Type_0_can_only_be_iterated_through_when_using_the_downlevelIteration_flag_or_with_a_target_of_es2015_or_higher.code,
-        Diagnostics.Type_0_is_not_an_array_type_or_a_string_type_or_does_not_have_a_Symbol_iterator_method_that_returns_an_iterator.code,
-        Diagnostics.Type_0_is_not_an_array_type_or_does_not_have_a_Symbol_iterator_method_that_returns_an_iterator.code,
-        Diagnostics.Type_0_must_have_a_Symbol_iterator_method_that_returns_an_iterator.code,
-        Diagnostics.Type_0_must_have_a_Symbol_asyncIterator_method_that_returns_an_async_iterator.code,
-        Diagnostics.Argument_of_type_0_is_not_assignable_to_parameter_of_type_1.code,
-        propertyAccessCode,
-        ...callableConstructableErrorCodes
-      ];
+      fixId19 = "fixImplicitThis";
+      errorCodes22 = [Diagnostics.this_implicitly_has_type_any_because_it_does_not_have_a_type_annotation.code];
       registerCodeFix({
-        fixIds: [fixId3],
-        errorCodes: errorCodes3,
-        getCodeActions: function getCodeActionsToAddMissingAwait(context) {
-          const { sourceFile, errorCode, span, cancellationToken, program } = context;
-          const expression = getAwaitErrorSpanExpression(sourceFile, errorCode, span, cancellationToken, program);
-          if (!expression) {
-            return;
-          }
-          const checker = context.program.getTypeChecker();
-          const trackChanges = (cb) => ts_textChanges_exports.ChangeTracker.with(context, cb);
-          return compact([
-            getDeclarationSiteFix(context, expression, errorCode, checker, trackChanges),
-            getUseSiteFix(context, expression, errorCode, checker, trackChanges)
-          ]);
-        },
-        getAllCodeActions: (context) => {
-          const { sourceFile, program, cancellationToken } = context;
-          const checker = context.program.getTypeChecker();
-          const fixedDeclarations = /* @__PURE__ */ new Set();
-          return codeFixAll(context, errorCodes3, (t, diagnostic) => {
-            const expression = getAwaitErrorSpanExpression(sourceFile, diagnostic.code, diagnostic, cancellationToken, program);
-            if (!expression) {
-              return;
-            }
-            const trackChanges = (cb) => (cb(t), []);
-            return getDeclarationSiteFix(context, expression, diagnostic.code, checker, trackChanges, fixedDeclarations) || getUseSiteFix(context, expression, diagnostic.code, checker, trackChanges, fixedDeclarations);
+        errorCodes: errorCodes22,
+        getCodeActions: function getCodeActionsToFixImplicitThis(context) {
+          const { sourceFile, program, span } = context;
+          let diagnostic;
+          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => {
+            diagnostic = doChange15(t, sourceFile, span.start, program.getTypeChecker());
           });
-        }
+          return diagnostic ? [createCodeFixAction(fixId19, changes, diagnostic, fixId19, Diagnostics.Fix_all_implicit_this_errors)] : emptyArray;
+        },
+        fixIds: [fixId19],
+        getAllCodeActions: (context) => codeFixAll(context, errorCodes22, (changes, diag2) => {
+          doChange15(changes, diag2.file, diag2.start, context.program.getTypeChecker());
+        })
       });
     }
   });
 
-  // src/services/codefixes/addMissingConst.ts
-  function makeChange4(changeTracker, sourceFile, pos, program, fixedNodes) {
+  // src/services/codefixes/fixImportNonExportedMember.ts
+  function getInfo7(sourceFile, pos, program) {
+    var _a, _b;
     const token = getTokenAtPosition(sourceFile, pos);
-    const forInitializer = findAncestor(
-      token,
-      (node) => isForInOrOfStatement(node.parent) ? node.parent.initializer === node : isPossiblyPartOfDestructuring(node) ? false : "quit"
-    );
-    if (forInitializer)
-      return applyChange(changeTracker, forInitializer, sourceFile, fixedNodes);
-    const parent2 = token.parent;
-    if (isBinaryExpression(parent2) && parent2.operatorToken.kind === 64 /* EqualsToken */ && isExpressionStatement(parent2.parent)) {
-      return applyChange(changeTracker, token, sourceFile, fixedNodes);
+    if (isIdentifier(token)) {
+      const importDeclaration = findAncestor(token, isImportDeclaration);
+      if (importDeclaration === void 0)
+        return void 0;
+      const moduleSpecifier = isStringLiteral(importDeclaration.moduleSpecifier) ? importDeclaration.moduleSpecifier.text : void 0;
+      if (moduleSpecifier === void 0)
+        return void 0;
+      const resolvedModule = (_a = program.getResolvedModule(
+        sourceFile,
+        moduleSpecifier,
+        /*mode*/
+        void 0
+      )) == null ? void 0 : _a.resolvedModule;
+      if (resolvedModule === void 0)
+        return void 0;
+      const moduleSourceFile = program.getSourceFile(resolvedModule.resolvedFileName);
+      if (moduleSourceFile === void 0 || isSourceFileFromLibrary(program, moduleSourceFile))
+        return void 0;
+      const moduleSymbol = moduleSourceFile.symbol;
+      const locals = (_b = tryCast(moduleSymbol.valueDeclaration, canHaveLocals)) == null ? void 0 : _b.locals;
+      if (locals === void 0)
+        return void 0;
+      const localSymbol = locals.get(token.escapedText);
+      if (localSymbol === void 0)
+        return void 0;
+      const node = getNodeOfSymbol(localSymbol);
+      if (node === void 0)
+        return void 0;
+      const exportName = { node: token, isTypeOnly: isTypeDeclaration(node) };
+      return { exportName, node, moduleSourceFile, moduleSpecifier };
     }
-    if (isArrayLiteralExpression(parent2)) {
-      const checker = program.getTypeChecker();
-      if (!every(parent2.elements, (element) => arrayElementCouldBeVariableDeclaration(element, checker))) {
-        return;
-      }
-      return applyChange(changeTracker, parent2, sourceFile, fixedNodes);
+    return void 0;
+  }
+  function doChange16(changes, program, { exportName, node, moduleSourceFile }) {
+    const exportDeclaration = tryGetExportDeclaration(moduleSourceFile, exportName.isTypeOnly);
+    if (exportDeclaration) {
+      updateExport(changes, program, moduleSourceFile, exportDeclaration, [exportName]);
+    } else if (canHaveExportModifier(node)) {
+      changes.insertExportModifier(moduleSourceFile, node);
+    } else {
+      createExport(changes, program, moduleSourceFile, [exportName]);
     }
-    const commaExpression = findAncestor(
-      token,
-      (node) => isExpressionStatement(node.parent) ? true : isPossiblyPartOfCommaSeperatedInitializer(node) ? false : "quit"
-    );
-    if (commaExpression) {
-      const checker = program.getTypeChecker();
-      if (!expressionCouldBeVariableDeclaration(commaExpression, checker)) {
-        return;
+  }
+  function doChanges(changes, program, sourceFile, moduleExports, node) {
+    if (length(moduleExports)) {
+      if (node) {
+        updateExport(changes, program, sourceFile, node, moduleExports);
+      } else {
+        createExport(changes, program, sourceFile, moduleExports);
       }
-      return applyChange(changeTracker, commaExpression, sourceFile, fixedNodes);
     }
   }
-  function applyChange(changeTracker, initializer, sourceFile, fixedNodes) {
-    if (!fixedNodes || tryAddToSet(fixedNodes, initializer)) {
-      changeTracker.insertModifierBefore(sourceFile, 87 /* ConstKeyword */, initializer);
-    }
+  function tryGetExportDeclaration(sourceFile, isTypeOnly) {
+    const predicate = (node) => isExportDeclaration(node) && (isTypeOnly && node.isTypeOnly || !node.isTypeOnly);
+    return findLast(sourceFile.statements, predicate);
   }
-  function isPossiblyPartOfDestructuring(node) {
-    switch (node.kind) {
-      case 80 /* Identifier */:
-      case 208 /* ArrayLiteralExpression */:
-      case 209 /* ObjectLiteralExpression */:
-      case 302 /* PropertyAssignment */:
-      case 303 /* ShorthandPropertyAssignment */:
-        return true;
-      default:
-        return false;
-    }
+  function updateExport(changes, program, sourceFile, node, names) {
+    const namedExports = node.exportClause && isNamedExports(node.exportClause) ? node.exportClause.elements : factory.createNodeArray([]);
+    const allowTypeModifier = !node.isTypeOnly && !!(getIsolatedModules(program.getCompilerOptions()) || find(namedExports, (e) => e.isTypeOnly));
+    changes.replaceNode(
+      sourceFile,
+      node,
+      factory.updateExportDeclaration(
+        node,
+        node.modifiers,
+        node.isTypeOnly,
+        factory.createNamedExports(
+          factory.createNodeArray(
+            [...namedExports, ...createExportSpecifiers(names, allowTypeModifier)],
+            /*hasTrailingComma*/
+            namedExports.hasTrailingComma
+          )
+        ),
+        node.moduleSpecifier,
+        node.attributes
+      )
+    );
   }
-  function arrayElementCouldBeVariableDeclaration(expression, checker) {
-    const identifier = isIdentifier(expression) ? expression : isAssignmentExpression(
-      expression,
-      /*excludeCompoundAssignment*/
-      true
-    ) && isIdentifier(expression.left) ? expression.left : void 0;
-    return !!identifier && !checker.getSymbolAtLocation(identifier);
+  function createExport(changes, program, sourceFile, names) {
+    changes.insertNodeAtEndOfScope(sourceFile, sourceFile, factory.createExportDeclaration(
+      /*modifiers*/
+      void 0,
+      /*isTypeOnly*/
+      false,
+      factory.createNamedExports(createExportSpecifiers(
+        names,
+        /*allowTypeModifier*/
+        getIsolatedModules(program.getCompilerOptions())
+      )),
+      /*moduleSpecifier*/
+      void 0,
+      /*attributes*/
+      void 0
+    ));
   }
-  function isPossiblyPartOfCommaSeperatedInitializer(node) {
-    switch (node.kind) {
-      case 80 /* Identifier */:
-      case 225 /* BinaryExpression */:
-      case 28 /* CommaToken */:
-        return true;
-      default:
-        return false;
-    }
+  function createExportSpecifiers(names, allowTypeModifier) {
+    return factory.createNodeArray(map(names, (n) => factory.createExportSpecifier(
+      allowTypeModifier && n.isTypeOnly,
+      /*propertyName*/
+      void 0,
+      n.node
+    )));
   }
-  function expressionCouldBeVariableDeclaration(expression, checker) {
-    if (!isBinaryExpression(expression)) {
-      return false;
-    }
-    if (expression.operatorToken.kind === 28 /* CommaToken */) {
-      return every([expression.left, expression.right], (expression2) => expressionCouldBeVariableDeclaration(expression2, checker));
+  function getNodeOfSymbol(symbol) {
+    if (symbol.valueDeclaration === void 0) {
+      return firstOrUndefined(symbol.declarations);
     }
-    return expression.operatorToken.kind === 64 /* EqualsToken */ && isIdentifier(expression.left) && !checker.getSymbolAtLocation(expression.left);
+    const declaration = symbol.valueDeclaration;
+    const variableStatement = isVariableDeclaration(declaration) ? tryCast(declaration.parent.parent, isVariableStatement) : void 0;
+    return variableStatement && length(variableStatement.declarationList.declarations) === 1 ? variableStatement : declaration;
   }
-  var fixId4, errorCodes4;
-  var init_addMissingConst = __esm({
-    "src/services/codefixes/addMissingConst.ts"() {
+  var fixId20, errorCodes23;
+  var init_fixImportNonExportedMember = __esm({
+    "src/services/codefixes/fixImportNonExportedMember.ts"() {
       "use strict";
       init_ts4();
       init_ts_codefix();
-      fixId4 = "addMissingConst";
-      errorCodes4 = [
-        Diagnostics.Cannot_find_name_0.code,
-        Diagnostics.No_value_exists_in_scope_for_the_shorthand_property_0_Either_declare_one_or_provide_an_initializer.code
+      fixId20 = "fixImportNonExportedMember";
+      errorCodes23 = [
+        Diagnostics.Module_0_declares_1_locally_but_it_is_not_exported.code
       ];
       registerCodeFix({
-        errorCodes: errorCodes4,
-        getCodeActions: function getCodeActionsToAddMissingConst(context) {
-          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => makeChange4(t, context.sourceFile, context.span.start, context.program));
-          if (changes.length > 0) {
-            return [createCodeFixAction(fixId4, changes, Diagnostics.Add_const_to_unresolved_variable, fixId4, Diagnostics.Add_const_to_all_unresolved_variables)];
-          }
+        errorCodes: errorCodes23,
+        fixIds: [fixId20],
+        getCodeActions(context) {
+          const { sourceFile, span, program } = context;
+          const info = getInfo7(sourceFile, span.start, program);
+          if (info === void 0)
+            return void 0;
+          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange16(t, program, info));
+          return [createCodeFixAction(fixId20, changes, [Diagnostics.Export_0_from_module_1, info.exportName.node.text, info.moduleSpecifier], fixId20, Diagnostics.Export_all_referenced_locals)];
         },
-        fixIds: [fixId4],
-        getAllCodeActions: (context) => {
-          const fixedNodes = /* @__PURE__ */ new Set();
-          return codeFixAll(context, errorCodes4, (changes, diag2) => makeChange4(changes, diag2.file, diag2.start, context.program, fixedNodes));
+        getAllCodeActions(context) {
+          const { program } = context;
+          return createCombinedCodeActions(ts_textChanges_exports.ChangeTracker.with(context, (changes) => {
+            const exports = /* @__PURE__ */ new Map();
+            eachDiagnostic(context, errorCodes23, (diag2) => {
+              const info = getInfo7(diag2.file, diag2.start, program);
+              if (info === void 0)
+                return void 0;
+              const { exportName, node, moduleSourceFile } = info;
+              if (tryGetExportDeclaration(moduleSourceFile, exportName.isTypeOnly) === void 0 && canHaveExportModifier(node)) {
+                changes.insertExportModifier(moduleSourceFile, node);
+              } else {
+                const moduleExports = exports.get(moduleSourceFile) || { typeOnlyExports: [], exports: [] };
+                if (exportName.isTypeOnly) {
+                  moduleExports.typeOnlyExports.push(exportName);
+                } else {
+                  moduleExports.exports.push(exportName);
+                }
+                exports.set(moduleSourceFile, moduleExports);
+              }
+            });
+            exports.forEach((moduleExports, moduleSourceFile) => {
+              const exportDeclaration = tryGetExportDeclaration(
+                moduleSourceFile,
+                /*isTypeOnly*/
+                true
+              );
+              if (exportDeclaration && exportDeclaration.isTypeOnly) {
+                doChanges(changes, program, moduleSourceFile, moduleExports.typeOnlyExports, exportDeclaration);
+                doChanges(changes, program, moduleSourceFile, moduleExports.exports, tryGetExportDeclaration(
+                  moduleSourceFile,
+                  /*isTypeOnly*/
+                  false
+                ));
+              } else {
+                doChanges(changes, program, moduleSourceFile, [...moduleExports.exports, ...moduleExports.typeOnlyExports], exportDeclaration);
+              }
+            });
+          }));
         }
       });
     }
   });
 
-  // src/services/codefixes/addMissingDeclareProperty.ts
-  function makeChange5(changeTracker, sourceFile, pos, fixedNodes) {
+  // src/services/codefixes/fixIncorrectNamedTupleSyntax.ts
+  function getNamedTupleMember(sourceFile, pos) {
     const token = getTokenAtPosition(sourceFile, pos);
-    if (!isIdentifier(token)) {
+    return findAncestor(token, (t) => t.kind === 202 /* NamedTupleMember */);
+  }
+  function doChange17(changes, sourceFile, namedTupleMember) {
+    if (!namedTupleMember) {
       return;
     }
-    const declaration = token.parent;
-    if (declaration.kind === 171 /* PropertyDeclaration */ && (!fixedNodes || tryAddToSet(fixedNodes, declaration))) {
-      changeTracker.insertModifierBefore(sourceFile, 138 /* DeclareKeyword */, declaration);
+    let unwrappedType = namedTupleMember.type;
+    let sawOptional = false;
+    let sawRest = false;
+    while (unwrappedType.kind === 190 /* OptionalType */ || unwrappedType.kind === 191 /* RestType */ || unwrappedType.kind === 196 /* ParenthesizedType */) {
+      if (unwrappedType.kind === 190 /* OptionalType */) {
+        sawOptional = true;
+      } else if (unwrappedType.kind === 191 /* RestType */) {
+        sawRest = true;
+      }
+      unwrappedType = unwrappedType.type;
+    }
+    const updated = factory.updateNamedTupleMember(
+      namedTupleMember,
+      namedTupleMember.dotDotDotToken || (sawRest ? factory.createToken(26 /* DotDotDotToken */) : void 0),
+      namedTupleMember.name,
+      namedTupleMember.questionToken || (sawOptional ? factory.createToken(58 /* QuestionToken */) : void 0),
+      unwrappedType
+    );
+    if (updated === namedTupleMember) {
+      return;
     }
+    changes.replaceNode(sourceFile, namedTupleMember, updated);
   }
-  var fixId5, errorCodes5;
-  var init_addMissingDeclareProperty = __esm({
-    "src/services/codefixes/addMissingDeclareProperty.ts"() {
+  var fixId21, errorCodes24;
+  var init_fixIncorrectNamedTupleSyntax = __esm({
+    "src/services/codefixes/fixIncorrectNamedTupleSyntax.ts"() {
       "use strict";
       init_ts4();
       init_ts_codefix();
-      fixId5 = "addMissingDeclareProperty";
-      errorCodes5 = [
-        Diagnostics.Property_0_will_overwrite_the_base_property_in_1_If_this_is_intentional_add_an_initializer_Otherwise_add_a_declare_modifier_or_remove_the_redundant_declaration.code
+      fixId21 = "fixIncorrectNamedTupleSyntax";
+      errorCodes24 = [
+        Diagnostics.A_labeled_tuple_element_is_declared_as_optional_with_a_question_mark_after_the_name_and_before_the_colon_rather_than_after_the_type.code,
+        Diagnostics.A_labeled_tuple_element_is_declared_as_rest_with_a_before_the_name_rather_than_before_the_type.code
       ];
       registerCodeFix({
-        errorCodes: errorCodes5,
-        getCodeActions: function getCodeActionsToAddMissingDeclareOnProperty(context) {
-          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => makeChange5(t, context.sourceFile, context.span.start));
-          if (changes.length > 0) {
-            return [createCodeFixAction(fixId5, changes, Diagnostics.Prefix_with_declare, fixId5, Diagnostics.Prefix_all_incorrect_property_declarations_with_declare)];
-          }
+        errorCodes: errorCodes24,
+        getCodeActions: function getCodeActionsToFixIncorrectNamedTupleSyntax(context) {
+          const { sourceFile, span } = context;
+          const namedTupleMember = getNamedTupleMember(sourceFile, span.start);
+          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange17(t, sourceFile, namedTupleMember));
+          return [createCodeFixAction(fixId21, changes, Diagnostics.Move_labeled_tuple_element_modifiers_to_labels, fixId21, Diagnostics.Move_labeled_tuple_element_modifiers_to_labels)];
         },
-        fixIds: [fixId5],
-        getAllCodeActions: (context) => {
-          const fixedNodes = /* @__PURE__ */ new Set();
-          return codeFixAll(context, errorCodes5, (changes, diag2) => makeChange5(changes, diag2.file, diag2.start, fixedNodes));
-        }
+        fixIds: [fixId21]
       });
     }
   });
 
-  // src/services/codefixes/addMissingInvocationForDecorator.ts
-  function makeChange6(changeTracker, sourceFile, pos) {
-    const token = getTokenAtPosition(sourceFile, pos);
-    const decorator = findAncestor(token, isDecorator);
-    Debug.assert(!!decorator, "Expected position to be owned by a decorator.");
-    const replacement = factory.createCallExpression(
-      decorator.expression,
-      /*typeArguments*/
-      void 0,
-      /*argumentsArray*/
-      void 0
-    );
-    changeTracker.replaceNode(sourceFile, decorator.expression, replacement);
+  // src/services/codefixes/fixSpelling.ts
+  function getInfo8(sourceFile, pos, context, errorCode) {
+    const node = getTokenAtPosition(sourceFile, pos);
+    const parent2 = node.parent;
+    if ((errorCode === Diagnostics.No_overload_matches_this_call.code || errorCode === Diagnostics.Type_0_is_not_assignable_to_type_1.code) && !isJsxAttribute(parent2))
+      return void 0;
+    const checker = context.program.getTypeChecker();
+    let suggestedSymbol;
+    if (isPropertyAccessExpression(parent2) && parent2.name === node) {
+      Debug.assert(isMemberName(node), "Expected an identifier for spelling (property access)");
+      let containingType = checker.getTypeAtLocation(parent2.expression);
+      if (parent2.flags & 64 /* OptionalChain */) {
+        containingType = checker.getNonNullableType(containingType);
+      }
+      suggestedSymbol = checker.getSuggestedSymbolForNonexistentProperty(node, containingType);
+    } else if (isBinaryExpression(parent2) && parent2.operatorToken.kind === 103 /* InKeyword */ && parent2.left === node && isPrivateIdentifier(node)) {
+      const receiverType = checker.getTypeAtLocation(parent2.right);
+      suggestedSymbol = checker.getSuggestedSymbolForNonexistentProperty(node, receiverType);
+    } else if (isQualifiedName(parent2) && parent2.right === node) {
+      const symbol = checker.getSymbolAtLocation(parent2.left);
+      if (symbol && symbol.flags & 1536 /* Module */) {
+        suggestedSymbol = checker.getSuggestedSymbolForNonexistentModule(parent2.right, symbol);
+      }
+    } else if (isImportSpecifier(parent2) && parent2.name === node) {
+      Debug.assertNode(node, isIdentifier, "Expected an identifier for spelling (import)");
+      const importDeclaration = findAncestor(node, isImportDeclaration);
+      const resolvedSourceFile = getResolvedSourceFileFromImportDeclaration(sourceFile, context, importDeclaration);
+      if (resolvedSourceFile && resolvedSourceFile.symbol) {
+        suggestedSymbol = checker.getSuggestedSymbolForNonexistentModule(node, resolvedSourceFile.symbol);
+      }
+    } else if (isJsxAttribute(parent2) && parent2.name === node) {
+      Debug.assertNode(node, isIdentifier, "Expected an identifier for JSX attribute");
+      const tag = findAncestor(node, isJsxOpeningLikeElement);
+      const props = checker.getContextualTypeForArgumentAtIndex(tag, 0);
+      suggestedSymbol = checker.getSuggestedSymbolForNonexistentJSXAttribute(node, props);
+    } else if (hasOverrideModifier(parent2) && isClassElement(parent2) && parent2.name === node) {
+      const baseDeclaration = findAncestor(node, isClassLike);
+      const baseTypeNode = baseDeclaration ? getEffectiveBaseTypeNode(baseDeclaration) : void 0;
+      const baseType = baseTypeNode ? checker.getTypeAtLocation(baseTypeNode) : void 0;
+      if (baseType) {
+        suggestedSymbol = checker.getSuggestedSymbolForNonexistentClassMember(getTextOfNode(node), baseType);
+      }
+    } else {
+      const meaning = getMeaningFromLocation(node);
+      const name = getTextOfNode(node);
+      Debug.assert(name !== void 0, "name should be defined");
+      suggestedSymbol = checker.getSuggestedSymbolForNonexistentSymbol(node, name, convertSemanticMeaningToSymbolFlags(meaning));
+    }
+    return suggestedSymbol === void 0 ? void 0 : { node, suggestedSymbol };
   }
-  var fixId6, errorCodes6;
-  var init_addMissingInvocationForDecorator = __esm({
-    "src/services/codefixes/addMissingInvocationForDecorator.ts"() {
+  function doChange18(changes, sourceFile, node, suggestedSymbol, target) {
+    const suggestion = symbolName(suggestedSymbol);
+    if (!isIdentifierText(suggestion, target) && isPropertyAccessExpression(node.parent)) {
+      const valDecl = suggestedSymbol.valueDeclaration;
+      if (valDecl && isNamedDeclaration(valDecl) && isPrivateIdentifier(valDecl.name)) {
+        changes.replaceNode(sourceFile, node, factory.createIdentifier(suggestion));
+      } else {
+        changes.replaceNode(sourceFile, node.parent, factory.createElementAccessExpression(node.parent.expression, factory.createStringLiteral(suggestion)));
+      }
+    } else {
+      changes.replaceNode(sourceFile, node, factory.createIdentifier(suggestion));
+    }
+  }
+  function convertSemanticMeaningToSymbolFlags(meaning) {
+    let flags = 0;
+    if (meaning & 4 /* Namespace */) {
+      flags |= 1920 /* Namespace */;
+    }
+    if (meaning & 2 /* Type */) {
+      flags |= 788968 /* Type */;
+    }
+    if (meaning & 1 /* Value */) {
+      flags |= 111551 /* Value */;
+    }
+    return flags;
+  }
+  function getResolvedSourceFileFromImportDeclaration(sourceFile, context, importDeclaration) {
+    var _a;
+    if (!importDeclaration || !isStringLiteralLike(importDeclaration.moduleSpecifier))
+      return void 0;
+    const resolvedModule = (_a = context.program.getResolvedModule(sourceFile, importDeclaration.moduleSpecifier.text, getModeForUsageLocation(sourceFile, importDeclaration.moduleSpecifier))) == null ? void 0 : _a.resolvedModule;
+    if (!resolvedModule)
+      return void 0;
+    return context.program.getSourceFile(resolvedModule.resolvedFileName);
+  }
+  var fixId22, errorCodes25;
+  var init_fixSpelling = __esm({
+    "src/services/codefixes/fixSpelling.ts"() {
       "use strict";
       init_ts4();
       init_ts_codefix();
-      fixId6 = "addMissingInvocationForDecorator";
-      errorCodes6 = [Diagnostics._0_accepts_too_few_arguments_to_be_used_as_a_decorator_here_Did_you_mean_to_call_it_first_and_write_0.code];
+      fixId22 = "fixSpelling";
+      errorCodes25 = [
+        Diagnostics.Property_0_does_not_exist_on_type_1_Did_you_mean_2.code,
+        Diagnostics.Property_0_may_not_exist_on_type_1_Did_you_mean_2.code,
+        Diagnostics.Cannot_find_name_0_Did_you_mean_1.code,
+        Diagnostics.Could_not_find_name_0_Did_you_mean_1.code,
+        Diagnostics.Cannot_find_namespace_0_Did_you_mean_1.code,
+        Diagnostics.Cannot_find_name_0_Did_you_mean_the_instance_member_this_0.code,
+        Diagnostics.Cannot_find_name_0_Did_you_mean_the_static_member_1_0.code,
+        Diagnostics._0_has_no_exported_member_named_1_Did_you_mean_2.code,
+        Diagnostics.This_member_cannot_have_an_override_modifier_because_it_is_not_declared_in_the_base_class_0_Did_you_mean_1.code,
+        Diagnostics.This_member_cannot_have_a_JSDoc_comment_with_an_override_tag_because_it_is_not_declared_in_the_base_class_0_Did_you_mean_1.code,
+        // for JSX class components
+        Diagnostics.No_overload_matches_this_call.code,
+        // for JSX FC
+        Diagnostics.Type_0_is_not_assignable_to_type_1.code
+      ];
       registerCodeFix({
-        errorCodes: errorCodes6,
-        getCodeActions: function getCodeActionsToAddMissingInvocationForDecorator(context) {
-          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => makeChange6(t, context.sourceFile, context.span.start));
-          return [createCodeFixAction(fixId6, changes, Diagnostics.Call_decorator_expression, fixId6, Diagnostics.Add_to_all_uncalled_decorators)];
+        errorCodes: errorCodes25,
+        getCodeActions(context) {
+          const { sourceFile, errorCode } = context;
+          const info = getInfo8(sourceFile, context.span.start, context, errorCode);
+          if (!info)
+            return void 0;
+          const { node, suggestedSymbol } = info;
+          const target = getEmitScriptTarget(context.host.getCompilationSettings());
+          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange18(t, sourceFile, node, suggestedSymbol, target));
+          return [createCodeFixAction("spelling", changes, [Diagnostics.Change_spelling_to_0, symbolName(suggestedSymbol)], fixId22, Diagnostics.Fix_all_detected_spelling_errors)];
         },
-        fixIds: [fixId6],
-        getAllCodeActions: (context) => codeFixAll(context, errorCodes6, (changes, diag2) => makeChange6(changes, diag2.file, diag2.start))
+        fixIds: [fixId22],
+        getAllCodeActions: (context) => codeFixAll(context, errorCodes25, (changes, diag2) => {
+          const info = getInfo8(diag2.file, diag2.start, context, diag2.code);
+          const target = getEmitScriptTarget(context.host.getCompilationSettings());
+          if (info)
+            doChange18(changes, context.sourceFile, info.node, info.suggestedSymbol, target);
+        })
       });
     }
   });
 
-  // src/services/codefixes/addNameToNamelessParameter.ts
-  function makeChange7(changeTracker, sourceFile, pos) {
-    const token = getTokenAtPosition(sourceFile, pos);
-    const param = token.parent;
-    if (!isParameter(param)) {
-      return Debug.fail("Tried to add a parameter name to a non-parameter: " + Debug.formatSyntaxKind(token.kind));
-    }
-    const i = param.parent.parameters.indexOf(param);
-    Debug.assert(!param.type, "Tried to add a parameter name to a parameter that already had one.");
-    Debug.assert(i > -1, "Parameter not found in parent parameter list.");
-    const typeNode = factory.createTypeReferenceNode(
-      param.name,
-      /*typeArguments*/
-      void 0
-    );
-    const replacement = factory.createParameterDeclaration(
-      param.modifiers,
-      param.dotDotDotToken,
-      "arg" + i,
-      param.questionToken,
-      param.dotDotDotToken ? factory.createArrayTypeNode(typeNode) : typeNode,
-      param.initializer
+  // src/services/codefixes/returnValueCorrect.ts
+  function createObjectTypeFromLabeledExpression(checker, label, expression) {
+    const member = checker.createSymbol(4 /* Property */, label.escapedText);
+    member.links.type = checker.getTypeAtLocation(expression);
+    const members = createSymbolTable([member]);
+    return checker.createAnonymousType(
+      /*symbol*/
+      void 0,
+      members,
+      [],
+      [],
+      []
     );
-    changeTracker.replaceNode(sourceFile, param, replacement);
   }
-  var fixId7, errorCodes7;
-  var init_addNameToNamelessParameter = __esm({
-    "src/services/codefixes/addNameToNamelessParameter.ts"() {
+  function getFixInfo(checker, declaration, expectType, isFunctionType) {
+    if (!declaration.body || !isBlock(declaration.body) || length(declaration.body.statements) !== 1)
+      return void 0;
+    const firstStatement = first(declaration.body.statements);
+    if (isExpressionStatement(firstStatement) && checkFixedAssignableTo(checker, declaration, checker.getTypeAtLocation(firstStatement.expression), expectType, isFunctionType)) {
+      return {
+        declaration,
+        kind: 0 /* MissingReturnStatement */,
+        expression: firstStatement.expression,
+        statement: firstStatement,
+        commentSource: firstStatement.expression
+      };
+    } else if (isLabeledStatement(firstStatement) && isExpressionStatement(firstStatement.statement)) {
+      const node = factory.createObjectLiteralExpression([factory.createPropertyAssignment(firstStatement.label, firstStatement.statement.expression)]);
+      const nodeType = createObjectTypeFromLabeledExpression(checker, firstStatement.label, firstStatement.statement.expression);
+      if (checkFixedAssignableTo(checker, declaration, nodeType, expectType, isFunctionType)) {
+        return isArrowFunction(declaration) ? {
+          declaration,
+          kind: 1 /* MissingParentheses */,
+          expression: node,
+          statement: firstStatement,
+          commentSource: firstStatement.statement.expression
+        } : {
+          declaration,
+          kind: 0 /* MissingReturnStatement */,
+          expression: node,
+          statement: firstStatement,
+          commentSource: firstStatement.statement.expression
+        };
+      }
+    } else if (isBlock(firstStatement) && length(firstStatement.statements) === 1) {
+      const firstBlockStatement = first(firstStatement.statements);
+      if (isLabeledStatement(firstBlockStatement) && isExpressionStatement(firstBlockStatement.statement)) {
+        const node = factory.createObjectLiteralExpression([factory.createPropertyAssignment(firstBlockStatement.label, firstBlockStatement.statement.expression)]);
+        const nodeType = createObjectTypeFromLabeledExpression(checker, firstBlockStatement.label, firstBlockStatement.statement.expression);
+        if (checkFixedAssignableTo(checker, declaration, nodeType, expectType, isFunctionType)) {
+          return {
+            declaration,
+            kind: 0 /* MissingReturnStatement */,
+            expression: node,
+            statement: firstStatement,
+            commentSource: firstBlockStatement
+          };
+        }
+      }
+    }
+    return void 0;
+  }
+  function checkFixedAssignableTo(checker, declaration, exprType, type, isFunctionType) {
+    if (isFunctionType) {
+      const sig = checker.getSignatureFromDeclaration(declaration);
+      if (sig) {
+        if (hasSyntacticModifier(declaration, 1024 /* Async */)) {
+          exprType = checker.createPromiseType(exprType);
+        }
+        const newSig = checker.createSignature(
+          declaration,
+          sig.typeParameters,
+          sig.thisParameter,
+          sig.parameters,
+          exprType,
+          /*typePredicate*/
+          void 0,
+          sig.minArgumentCount,
+          sig.flags
+        );
+        exprType = checker.createAnonymousType(
+          /*symbol*/
+          void 0,
+          createSymbolTable(),
+          [newSig],
+          [],
+          []
+        );
+      } else {
+        exprType = checker.getAnyType();
+      }
+    }
+    return checker.isTypeAssignableTo(exprType, type);
+  }
+  function getInfo9(checker, sourceFile, position, errorCode) {
+    const node = getTokenAtPosition(sourceFile, position);
+    if (!node.parent)
+      return void 0;
+    const declaration = findAncestor(node.parent, isFunctionLikeDeclaration);
+    switch (errorCode) {
+      case Diagnostics.A_function_whose_declared_type_is_neither_undefined_void_nor_any_must_return_a_value.code:
+        if (!declaration || !declaration.body || !declaration.type || !rangeContainsRange(declaration.type, node))
+          return void 0;
+        return getFixInfo(
+          checker,
+          declaration,
+          checker.getTypeFromTypeNode(declaration.type),
+          /*isFunctionType*/
+          false
+        );
+      case Diagnostics.Argument_of_type_0_is_not_assignable_to_parameter_of_type_1.code:
+        if (!declaration || !isCallExpression(declaration.parent) || !declaration.body)
+          return void 0;
+        const pos = declaration.parent.arguments.indexOf(declaration);
+        if (pos === -1)
+          return void 0;
+        const type = checker.getContextualTypeForArgumentAtIndex(declaration.parent, pos);
+        if (!type)
+          return void 0;
+        return getFixInfo(
+          checker,
+          declaration,
+          type,
+          /*isFunctionType*/
+          true
+        );
+      case Diagnostics.Type_0_is_not_assignable_to_type_1.code:
+        if (!isDeclarationName(node) || !isVariableLike(node.parent) && !isJsxAttribute(node.parent))
+          return void 0;
+        const initializer = getVariableLikeInitializer(node.parent);
+        if (!initializer || !isFunctionLikeDeclaration(initializer) || !initializer.body)
+          return void 0;
+        return getFixInfo(
+          checker,
+          initializer,
+          checker.getTypeAtLocation(node.parent),
+          /*isFunctionType*/
+          true
+        );
+    }
+    return void 0;
+  }
+  function getVariableLikeInitializer(declaration) {
+    switch (declaration.kind) {
+      case 260 /* VariableDeclaration */:
+      case 169 /* Parameter */:
+      case 208 /* BindingElement */:
+      case 172 /* PropertyDeclaration */:
+      case 303 /* PropertyAssignment */:
+        return declaration.initializer;
+      case 291 /* JsxAttribute */:
+        return declaration.initializer && (isJsxExpression(declaration.initializer) ? declaration.initializer.expression : void 0);
+      case 304 /* ShorthandPropertyAssignment */:
+      case 171 /* PropertySignature */:
+      case 306 /* EnumMember */:
+      case 355 /* JSDocPropertyTag */:
+      case 348 /* JSDocParameterTag */:
+        return void 0;
+    }
+  }
+  function addReturnStatement(changes, sourceFile, expression, statement) {
+    suppressLeadingAndTrailingTrivia(expression);
+    const probablyNeedSemi = probablyUsesSemicolons(sourceFile);
+    changes.replaceNode(sourceFile, statement, factory.createReturnStatement(expression), {
+      leadingTriviaOption: ts_textChanges_exports.LeadingTriviaOption.Exclude,
+      trailingTriviaOption: ts_textChanges_exports.TrailingTriviaOption.Exclude,
+      suffix: probablyNeedSemi ? ";" : void 0
+    });
+  }
+  function removeBlockBodyBrace(changes, sourceFile, declaration, expression, commentSource, withParen) {
+    const newBody = withParen || needsParentheses(expression) ? factory.createParenthesizedExpression(expression) : expression;
+    suppressLeadingAndTrailingTrivia(commentSource);
+    copyComments(commentSource, newBody);
+    changes.replaceNode(sourceFile, declaration.body, newBody);
+  }
+  function wrapBlockWithParen(changes, sourceFile, declaration, expression) {
+    changes.replaceNode(sourceFile, declaration.body, factory.createParenthesizedExpression(expression));
+  }
+  function getActionForfixAddReturnStatement(context, expression, statement) {
+    const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => addReturnStatement(t, context.sourceFile, expression, statement));
+    return createCodeFixAction(fixId23, changes, Diagnostics.Add_a_return_statement, fixIdAddReturnStatement, Diagnostics.Add_all_missing_return_statement);
+  }
+  function getActionForFixRemoveBracesFromArrowFunctionBody(context, declaration, expression, commentSource) {
+    const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => removeBlockBodyBrace(
+      t,
+      context.sourceFile,
+      declaration,
+      expression,
+      commentSource,
+      /*withParen*/
+      false
+    ));
+    return createCodeFixAction(fixId23, changes, Diagnostics.Remove_braces_from_arrow_function_body, fixRemoveBracesFromArrowFunctionBody, Diagnostics.Remove_braces_from_all_arrow_function_bodies_with_relevant_issues);
+  }
+  function getActionForfixWrapTheBlockWithParen(context, declaration, expression) {
+    const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => wrapBlockWithParen(t, context.sourceFile, declaration, expression));
+    return createCodeFixAction(fixId23, changes, Diagnostics.Wrap_the_following_body_with_parentheses_which_should_be_an_object_literal, fixIdWrapTheBlockWithParen, Diagnostics.Wrap_all_object_literal_with_parentheses);
+  }
+  var fixId23, fixIdAddReturnStatement, fixRemoveBracesFromArrowFunctionBody, fixIdWrapTheBlockWithParen, errorCodes26;
+  var init_returnValueCorrect = __esm({
+    "src/services/codefixes/returnValueCorrect.ts"() {
       "use strict";
       init_ts4();
       init_ts_codefix();
-      fixId7 = "addNameToNamelessParameter";
-      errorCodes7 = [Diagnostics.Parameter_has_a_name_but_no_type_Did_you_mean_0_Colon_1.code];
+      fixId23 = "returnValueCorrect";
+      fixIdAddReturnStatement = "fixAddReturnStatement";
+      fixRemoveBracesFromArrowFunctionBody = "fixRemoveBracesFromArrowFunctionBody";
+      fixIdWrapTheBlockWithParen = "fixWrapTheBlockWithParen";
+      errorCodes26 = [
+        Diagnostics.A_function_whose_declared_type_is_neither_undefined_void_nor_any_must_return_a_value.code,
+        Diagnostics.Type_0_is_not_assignable_to_type_1.code,
+        Diagnostics.Argument_of_type_0_is_not_assignable_to_parameter_of_type_1.code
+      ];
       registerCodeFix({
-        errorCodes: errorCodes7,
-        getCodeActions: function getCodeActionsToAddNameToNamelessParameter(context) {
-          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => makeChange7(t, context.sourceFile, context.span.start));
-          return [createCodeFixAction(fixId7, changes, Diagnostics.Add_parameter_name, fixId7, Diagnostics.Add_names_to_all_parameters_without_names)];
+        errorCodes: errorCodes26,
+        fixIds: [fixIdAddReturnStatement, fixRemoveBracesFromArrowFunctionBody, fixIdWrapTheBlockWithParen],
+        getCodeActions: function getCodeActionsToCorrectReturnValue(context) {
+          const { program, sourceFile, span: { start }, errorCode } = context;
+          const info = getInfo9(program.getTypeChecker(), sourceFile, start, errorCode);
+          if (!info)
+            return void 0;
+          if (info.kind === 0 /* MissingReturnStatement */) {
+            return append(
+              [getActionForfixAddReturnStatement(context, info.expression, info.statement)],
+              isArrowFunction(info.declaration) ? getActionForFixRemoveBracesFromArrowFunctionBody(context, info.declaration, info.expression, info.commentSource) : void 0
+            );
+          } else {
+            return [getActionForfixWrapTheBlockWithParen(context, info.declaration, info.expression)];
+          }
         },
-        fixIds: [fixId7],
-        getAllCodeActions: (context) => codeFixAll(context, errorCodes7, (changes, diag2) => makeChange7(changes, diag2.file, diag2.start))
+        getAllCodeActions: (context) => codeFixAll(context, errorCodes26, (changes, diag2) => {
+          const info = getInfo9(context.program.getTypeChecker(), diag2.file, diag2.start, diag2.code);
+          if (!info)
+            return void 0;
+          switch (context.fixId) {
+            case fixIdAddReturnStatement:
+              addReturnStatement(changes, diag2.file, info.expression, info.statement);
+              break;
+            case fixRemoveBracesFromArrowFunctionBody:
+              if (!isArrowFunction(info.declaration))
+                return void 0;
+              removeBlockBodyBrace(
+                changes,
+                diag2.file,
+                info.declaration,
+                info.expression,
+                info.commentSource,
+                /*withParen*/
+                false
+              );
+              break;
+            case fixIdWrapTheBlockWithParen:
+              if (!isArrowFunction(info.declaration))
+                return void 0;
+              wrapBlockWithParen(changes, diag2.file, info.declaration, info.expression);
+              break;
+            default:
+              Debug.fail(JSON.stringify(context.fixId));
+          }
+        })
       });
     }
   });
-
-  // src/services/codefixes/addOptionalPropertyUndefined.ts
-  function getPropertiesToAdd(file, span, checker) {
-    var _a, _b;
-    const sourceTarget = getSourceTarget(getFixableErrorSpanExpression(file, span), checker);
-    if (!sourceTarget) {
-      return emptyArray;
-    }
-    const { source: sourceNode, target: targetNode } = sourceTarget;
-    const target = shouldUseParentTypeOfProperty(sourceNode, targetNode, checker) ? checker.getTypeAtLocation(targetNode.expression) : checker.getTypeAtLocation(targetNode);
-    if ((_b = (_a = target.symbol) == null ? void 0 : _a.declarations) == null ? void 0 : _b.some((d) => getSourceFileOfNode(d).fileName.match(/\.d\.ts$/))) {
-      return emptyArray;
-    }
-    return checker.getExactOptionalProperties(target);
-  }
-  function shouldUseParentTypeOfProperty(sourceNode, targetNode, checker) {
-    return isPropertyAccessExpression(targetNode) && !!checker.getExactOptionalProperties(checker.getTypeAtLocation(targetNode.expression)).length && checker.getTypeAtLocation(sourceNode) === checker.getUndefinedType();
-  }
-  function getSourceTarget(errorNode, checker) {
+
+  // src/services/codefixes/fixAddMissingMember.ts
+  function getInfo10(sourceFile, tokenPos, errorCode, checker, program) {
     var _a;
-    if (!errorNode) {
-      return void 0;
-    } else if (isBinaryExpression(errorNode.parent) && errorNode.parent.operatorToken.kind === 64 /* EqualsToken */) {
-      return { source: errorNode.parent.right, target: errorNode.parent.left };
-    } else if (isVariableDeclaration(errorNode.parent) && errorNode.parent.initializer) {
-      return { source: errorNode.parent.initializer, target: errorNode.parent.name };
-    } else if (isCallExpression(errorNode.parent)) {
-      const n = checker.getSymbolAtLocation(errorNode.parent.expression);
-      if (!(n == null ? void 0 : n.valueDeclaration) || !isFunctionLikeKind(n.valueDeclaration.kind))
+    const token = getTokenAtPosition(sourceFile, tokenPos);
+    const parent2 = token.parent;
+    if (errorCode === Diagnostics.Argument_of_type_0_is_not_assignable_to_parameter_of_type_1.code) {
+      if (!(token.kind === 19 /* OpenBraceToken */ && isObjectLiteralExpression(parent2) && isCallExpression(parent2.parent)))
         return void 0;
-      if (!isExpression(errorNode))
+      const argIndex = findIndex(parent2.parent.arguments, (arg) => arg === parent2);
+      if (argIndex < 0)
         return void 0;
-      const i = errorNode.parent.arguments.indexOf(errorNode);
-      if (i === -1)
+      const signature = checker.getResolvedSignature(parent2.parent);
+      if (!(signature && signature.declaration && signature.parameters[argIndex]))
         return void 0;
-      const name = n.valueDeclaration.parameters[i].name;
-      if (isIdentifier(name))
-        return { source: errorNode, target: name };
-    } else if (isPropertyAssignment(errorNode.parent) && isIdentifier(errorNode.parent.name) || isShorthandPropertyAssignment(errorNode.parent)) {
-      const parentTarget = getSourceTarget(errorNode.parent.parent, checker);
-      if (!parentTarget)
+      const param = signature.parameters[argIndex].valueDeclaration;
+      if (!(param && isParameter(param) && isIdentifier(param.name)))
         return void 0;
-      const prop = checker.getPropertyOfType(checker.getTypeAtLocation(parentTarget.target), errorNode.parent.name.text);
-      const declaration = (_a = prop == null ? void 0 : prop.declarations) == null ? void 0 : _a[0];
-      if (!declaration)
+      const properties = arrayFrom(checker.getUnmatchedProperties(
+        checker.getTypeAtLocation(parent2),
+        checker.getParameterType(signature, argIndex),
+        /*requireOptionalProperties*/
+        false,
+        /*matchDiscriminantProperties*/
+        false
+      ));
+      if (!length(properties))
         return void 0;
-      return {
-        source: isPropertyAssignment(errorNode.parent) ? errorNode.parent.initializer : errorNode.parent.name,
-        target: declaration
-      };
+      return { kind: 3 /* ObjectLiteral */, token: param.name, properties, parentDeclaration: parent2 };
     }
-    return void 0;
-  }
-  function addUndefinedToOptionalProperty(changes, toAdd) {
-    for (const add of toAdd) {
-      const d = add.valueDeclaration;
-      if (d && (isPropertySignature(d) || isPropertyDeclaration(d)) && d.type) {
-        const t = factory.createUnionTypeNode([
-          ...d.type.kind === 191 /* UnionType */ ? d.type.types : [d.type],
-          factory.createTypeReferenceNode("undefined")
-        ]);
-        changes.replaceNode(d.getSourceFile(), d.type, t);
+    if (!isMemberName(token))
+      return void 0;
+    if (isIdentifier(token) && hasInitializer(parent2) && parent2.initializer && isObjectLiteralExpression(parent2.initializer)) {
+      const targetType = checker.getContextualType(token) || checker.getTypeAtLocation(token);
+      const properties = arrayFrom(checker.getUnmatchedProperties(
+        checker.getTypeAtLocation(parent2.initializer),
+        targetType,
+        /*requireOptionalProperties*/
+        false,
+        /*matchDiscriminantProperties*/
+        false
+      ));
+      if (!length(properties))
+        return void 0;
+      return { kind: 3 /* ObjectLiteral */, token, properties, parentDeclaration: parent2.initializer };
+    }
+    if (isIdentifier(token) && isJsxOpeningLikeElement(token.parent)) {
+      const target = getEmitScriptTarget(program.getCompilerOptions());
+      const attributes = getUnmatchedAttributes(checker, target, token.parent);
+      if (!length(attributes))
+        return void 0;
+      return { kind: 4 /* JsxAttributes */, token, attributes, parentDeclaration: token.parent };
+    }
+    if (isIdentifier(token)) {
+      const type = (_a = checker.getContextualType(token)) == null ? void 0 : _a.getNonNullableType();
+      if (type && getObjectFlags(type) & 16 /* Anonymous */) {
+        const signature = firstOrUndefined(checker.getSignaturesOfType(type, 0 /* Call */));
+        if (signature === void 0)
+          return void 0;
+        return { kind: 5 /* Signature */, token, signature, sourceFile, parentDeclaration: findScope(token) };
+      }
+      if (isCallExpression(parent2) && parent2.expression === token) {
+        return { kind: 2 /* Function */, token, call: parent2, sourceFile, modifierFlags: 0 /* None */, parentDeclaration: findScope(token) };
       }
     }
-  }
-  var addOptionalPropertyUndefined, errorCodes8;
-  var init_addOptionalPropertyUndefined = __esm({
-    "src/services/codefixes/addOptionalPropertyUndefined.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_codefix();
-      addOptionalPropertyUndefined = "addOptionalPropertyUndefined";
-      errorCodes8 = [
-        Diagnostics.Type_0_is_not_assignable_to_type_1_with_exactOptionalPropertyTypes_Colon_true_Consider_adding_undefined_to_the_type_of_the_target.code,
-        Diagnostics.Type_0_is_not_assignable_to_type_1_with_exactOptionalPropertyTypes_Colon_true_Consider_adding_undefined_to_the_types_of_the_target_s_properties.code,
-        Diagnostics.Argument_of_type_0_is_not_assignable_to_parameter_of_type_1_with_exactOptionalPropertyTypes_Colon_true_Consider_adding_undefined_to_the_types_of_the_target_s_properties.code
-      ];
-      registerCodeFix({
-        errorCodes: errorCodes8,
-        getCodeActions(context) {
-          const typeChecker = context.program.getTypeChecker();
-          const toAdd = getPropertiesToAdd(context.sourceFile, context.span, typeChecker);
-          if (!toAdd.length) {
-            return void 0;
-          }
-          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => addUndefinedToOptionalProperty(t, toAdd));
-          return [createCodeFixActionWithoutFixAll(addOptionalPropertyUndefined, changes, Diagnostics.Add_undefined_to_optional_property_type)];
-        },
-        fixIds: [addOptionalPropertyUndefined]
-      });
+    if (!isPropertyAccessExpression(parent2))
+      return void 0;
+    const leftExpressionType = skipConstraint(checker.getTypeAtLocation(parent2.expression));
+    const symbol = leftExpressionType.symbol;
+    if (!symbol || !symbol.declarations)
+      return void 0;
+    if (isIdentifier(token) && isCallExpression(parent2.parent)) {
+      const moduleDeclaration = find(symbol.declarations, isModuleDeclaration);
+      const moduleDeclarationSourceFile = moduleDeclaration == null ? void 0 : moduleDeclaration.getSourceFile();
+      if (moduleDeclaration && moduleDeclarationSourceFile && !isSourceFileFromLibrary(program, moduleDeclarationSourceFile)) {
+        return { kind: 2 /* Function */, token, call: parent2.parent, sourceFile, modifierFlags: 32 /* Export */, parentDeclaration: moduleDeclaration };
+      }
+      const moduleSourceFile = find(symbol.declarations, isSourceFile);
+      if (sourceFile.commonJsModuleIndicator)
+        return void 0;
+      if (moduleSourceFile && !isSourceFileFromLibrary(program, moduleSourceFile)) {
+        return { kind: 2 /* Function */, token, call: parent2.parent, sourceFile: moduleSourceFile, modifierFlags: 32 /* Export */, parentDeclaration: moduleSourceFile };
+      }
     }
-  });
-
-  // src/services/codefixes/annotateWithTypeFromJSDoc.ts
-  function getDeclaration(file, pos) {
-    const name = getTokenAtPosition(file, pos);
-    return tryCast(isParameter(name.parent) ? name.parent.parent : name.parent, parameterShouldGetTypeFromJSDoc);
+    const classDeclaration = find(symbol.declarations, isClassLike);
+    if (!classDeclaration && isPrivateIdentifier(token))
+      return void 0;
+    const declaration = classDeclaration || find(symbol.declarations, (d) => isInterfaceDeclaration(d) || isTypeLiteralNode(d));
+    if (declaration && !isSourceFileFromLibrary(program, declaration.getSourceFile())) {
+      const makeStatic = !isTypeLiteralNode(declaration) && (leftExpressionType.target || leftExpressionType) !== checker.getDeclaredTypeOfSymbol(symbol);
+      if (makeStatic && (isPrivateIdentifier(token) || isInterfaceDeclaration(declaration)))
+        return void 0;
+      const declSourceFile = declaration.getSourceFile();
+      const modifierFlags = isTypeLiteralNode(declaration) ? 0 /* None */ : (makeStatic ? 256 /* Static */ : 0 /* None */) | (startsWithUnderscore(token.text) ? 2 /* Private */ : 0 /* None */);
+      const isJSFile = isSourceFileJS(declSourceFile);
+      const call = tryCast(parent2.parent, isCallExpression);
+      return { kind: 0 /* TypeLikeDeclaration */, token, call, modifierFlags, parentDeclaration: declaration, declSourceFile, isJSFile };
+    }
+    const enumDeclaration = find(symbol.declarations, isEnumDeclaration);
+    if (enumDeclaration && !(leftExpressionType.flags & 1056 /* EnumLike */) && !isPrivateIdentifier(token) && !isSourceFileFromLibrary(program, enumDeclaration.getSourceFile())) {
+      return { kind: 1 /* Enum */, token, parentDeclaration: enumDeclaration };
+    }
+    return void 0;
   }
-  function parameterShouldGetTypeFromJSDoc(node) {
-    return isDeclarationWithType(node) && hasUsableJSDoc(node);
+  function getActionsForMissingMemberDeclaration(context, info) {
+    return info.isJSFile ? singleElementArray(createActionForAddMissingMemberInJavascriptFile(context, info)) : createActionsForAddMissingMemberInTypeScriptFile(context, info);
   }
-  function hasUsableJSDoc(decl) {
-    return isFunctionLikeDeclaration(decl) ? decl.parameters.some(hasUsableJSDoc) || !decl.type && !!getJSDocReturnType(decl) : !decl.type && !!getJSDocType(decl);
+  function createActionForAddMissingMemberInJavascriptFile(context, { parentDeclaration, declSourceFile, modifierFlags, token }) {
+    if (isInterfaceDeclaration(parentDeclaration) || isTypeLiteralNode(parentDeclaration)) {
+      return void 0;
+    }
+    const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => addMissingMemberInJs(t, declSourceFile, parentDeclaration, token, !!(modifierFlags & 256 /* Static */)));
+    if (changes.length === 0) {
+      return void 0;
+    }
+    const diagnostic = modifierFlags & 256 /* Static */ ? Diagnostics.Initialize_static_property_0 : isPrivateIdentifier(token) ? Diagnostics.Declare_a_private_field_named_0 : Diagnostics.Initialize_property_0_in_the_constructor;
+    return createCodeFixAction(fixMissingMember, changes, [diagnostic, token.text], fixMissingMember, Diagnostics.Add_all_missing_members);
   }
-  function doChange8(changes, sourceFile, decl) {
-    if (isFunctionLikeDeclaration(decl) && (getJSDocReturnType(decl) || decl.parameters.some((p) => !!getJSDocType(p)))) {
-      if (!decl.typeParameters) {
-        const typeParameters = getJSDocTypeParameterDeclarations(decl);
-        if (typeParameters.length)
-          changes.insertTypeParameters(sourceFile, decl, typeParameters);
-      }
-      const needParens = isArrowFunction(decl) && !findChildOfKind(decl, 21 /* OpenParenToken */, sourceFile);
-      if (needParens)
-        changes.insertNodeBefore(sourceFile, first(decl.parameters), factory.createToken(21 /* OpenParenToken */));
-      for (const param of decl.parameters) {
-        if (!param.type) {
-          const paramType = getJSDocType(param);
-          if (paramType)
-            changes.tryInsertTypeAnnotation(sourceFile, param, visitNode(paramType, transformJSDocType, isTypeNode));
-        }
+  function addMissingMemberInJs(changeTracker, sourceFile, classDeclaration, token, makeStatic) {
+    const tokenName = token.text;
+    if (makeStatic) {
+      if (classDeclaration.kind === 231 /* ClassExpression */) {
+        return;
       }
-      if (needParens)
-        changes.insertNodeAfter(sourceFile, last(decl.parameters), factory.createToken(22 /* CloseParenToken */));
-      if (!decl.type) {
-        const returnType = getJSDocReturnType(decl);
-        if (returnType)
-          changes.tryInsertTypeAnnotation(sourceFile, decl, visitNode(returnType, transformJSDocType, isTypeNode));
+      const className = classDeclaration.name.getText();
+      const staticInitialization = initializePropertyToUndefined(factory.createIdentifier(className), tokenName);
+      changeTracker.insertNodeAfter(sourceFile, classDeclaration, staticInitialization);
+    } else if (isPrivateIdentifier(token)) {
+      const property = factory.createPropertyDeclaration(
+        /*modifiers*/
+        void 0,
+        tokenName,
+        /*questionOrExclamationToken*/
+        void 0,
+        /*type*/
+        void 0,
+        /*initializer*/
+        void 0
+      );
+      const lastProp = getNodeToInsertPropertyAfter(classDeclaration);
+      if (lastProp) {
+        changeTracker.insertNodeAfter(sourceFile, lastProp, property);
+      } else {
+        changeTracker.insertMemberAtStart(sourceFile, classDeclaration, property);
       }
     } else {
-      const jsdocType = Debug.checkDefined(getJSDocType(decl), "A JSDocType for this declaration should exist");
-      Debug.assert(!decl.type, "The JSDocType decl should have a type");
-      changes.tryInsertTypeAnnotation(sourceFile, decl, visitNode(jsdocType, transformJSDocType, isTypeNode));
+      const classConstructor = getFirstConstructorWithBody(classDeclaration);
+      if (!classConstructor) {
+        return;
+      }
+      const propertyInitialization = initializePropertyToUndefined(factory.createThis(), tokenName);
+      changeTracker.insertNodeAtConstructorEnd(sourceFile, classConstructor, propertyInitialization);
     }
   }
-  function isDeclarationWithType(node) {
-    return isFunctionLikeDeclaration(node) || node.kind === 259 /* VariableDeclaration */ || node.kind === 170 /* PropertySignature */ || node.kind === 171 /* PropertyDeclaration */;
+  function initializePropertyToUndefined(obj, propertyName) {
+    return factory.createExpressionStatement(factory.createAssignment(factory.createPropertyAccessExpression(obj, propertyName), createUndefined()));
   }
-  function transformJSDocType(node) {
-    switch (node.kind) {
-      case 318 /* JSDocAllType */:
-      case 319 /* JSDocUnknownType */:
-        return factory.createTypeReferenceNode("any", emptyArray);
-      case 322 /* JSDocOptionalType */:
-        return transformJSDocOptionalType(node);
-      case 321 /* JSDocNonNullableType */:
-        return transformJSDocType(node.type);
-      case 320 /* JSDocNullableType */:
-        return transformJSDocNullableType(node);
-      case 324 /* JSDocVariadicType */:
-        return transformJSDocVariadicType(node);
-      case 323 /* JSDocFunctionType */:
-        return transformJSDocFunctionType(node);
-      case 182 /* TypeReference */:
-        return transformJSDocTypeReference(node);
-      case 328 /* JSDocTypeLiteral */:
-        return transformJSDocTypeLiteral(node);
-      default:
-        const visited = visitEachChild(node, transformJSDocType, nullTransformationContext);
-        setEmitFlags(visited, 1 /* SingleLine */);
-        return visited;
+  function createActionsForAddMissingMemberInTypeScriptFile(context, { parentDeclaration, declSourceFile, modifierFlags, token }) {
+    const memberName = token.text;
+    const isStatic2 = modifierFlags & 256 /* Static */;
+    const typeNode = getTypeNode2(context.program.getTypeChecker(), parentDeclaration, token);
+    const addPropertyDeclarationChanges = (modifierFlags2) => ts_textChanges_exports.ChangeTracker.with(context, (t) => addPropertyDeclaration(t, declSourceFile, parentDeclaration, memberName, typeNode, modifierFlags2));
+    const actions2 = [createCodeFixAction(fixMissingMember, addPropertyDeclarationChanges(modifierFlags & 256 /* Static */), [isStatic2 ? Diagnostics.Declare_static_property_0 : Diagnostics.Declare_property_0, memberName], fixMissingMember, Diagnostics.Add_all_missing_members)];
+    if (isStatic2 || isPrivateIdentifier(token)) {
+      return actions2;
+    }
+    if (modifierFlags & 2 /* Private */) {
+      actions2.unshift(createCodeFixActionWithoutFixAll(fixMissingMember, addPropertyDeclarationChanges(2 /* Private */), [Diagnostics.Declare_private_property_0, memberName]));
     }
+    actions2.push(createAddIndexSignatureAction(context, declSourceFile, parentDeclaration, token.text, typeNode));
+    return actions2;
   }
-  function transformJSDocTypeLiteral(node) {
-    const typeNode = factory.createTypeLiteralNode(map(node.jsDocPropertyTags, (tag) => factory.createPropertySignature(
+  function getTypeNode2(checker, node, token) {
+    let typeNode;
+    if (token.parent.parent.kind === 226 /* BinaryExpression */) {
+      const binaryExpression = token.parent.parent;
+      const otherExpression = token.parent === binaryExpression.left ? binaryExpression.right : binaryExpression.left;
+      const widenedType = checker.getWidenedType(checker.getBaseTypeOfLiteralType(checker.getTypeAtLocation(otherExpression)));
+      typeNode = checker.typeToTypeNode(widenedType, node, 1 /* NoTruncation */);
+    } else {
+      const contextualType = checker.getContextualType(token.parent);
+      typeNode = contextualType ? checker.typeToTypeNode(
+        contextualType,
+        /*enclosingDeclaration*/
+        void 0,
+        1 /* NoTruncation */
+      ) : void 0;
+    }
+    return typeNode || factory.createKeywordTypeNode(133 /* AnyKeyword */);
+  }
+  function addPropertyDeclaration(changeTracker, sourceFile, node, tokenName, typeNode, modifierFlags) {
+    const modifiers = modifierFlags ? factory.createNodeArray(factory.createModifiersFromModifierFlags(modifierFlags)) : void 0;
+    const property = isClassLike(node) ? factory.createPropertyDeclaration(
+      modifiers,
+      tokenName,
+      /*questionOrExclamationToken*/
+      void 0,
+      typeNode,
+      /*initializer*/
+      void 0
+    ) : factory.createPropertySignature(
       /*modifiers*/
       void 0,
-      isIdentifier(tag.name) ? tag.name : tag.name.right,
-      isOptionalJSDocPropertyLikeTag(tag) ? factory.createToken(58 /* QuestionToken */) : void 0,
-      tag.typeExpression && visitNode(tag.typeExpression.type, transformJSDocType, isTypeNode) || factory.createKeywordTypeNode(133 /* AnyKeyword */)
-    )));
-    setEmitFlags(typeNode, 1 /* SingleLine */);
-    return typeNode;
-  }
-  function transformJSDocOptionalType(node) {
-    return factory.createUnionTypeNode([visitNode(node.type, transformJSDocType, isTypeNode), factory.createTypeReferenceNode("undefined", emptyArray)]);
-  }
-  function transformJSDocNullableType(node) {
-    return factory.createUnionTypeNode([visitNode(node.type, transformJSDocType, isTypeNode), factory.createTypeReferenceNode("null", emptyArray)]);
-  }
-  function transformJSDocVariadicType(node) {
-    return factory.createArrayTypeNode(visitNode(node.type, transformJSDocType, isTypeNode));
-  }
-  function transformJSDocFunctionType(node) {
-    return factory.createFunctionTypeNode(emptyArray, node.parameters.map(transformJSDocParameter), node.type ?? factory.createKeywordTypeNode(133 /* AnyKeyword */));
-  }
-  function transformJSDocParameter(node) {
-    const index = node.parent.parameters.indexOf(node);
-    const isRest = node.type.kind === 324 /* JSDocVariadicType */ && index === node.parent.parameters.length - 1;
-    const name = node.name || (isRest ? "rest" : "arg" + index);
-    const dotdotdot = isRest ? factory.createToken(26 /* DotDotDotToken */) : node.dotDotDotToken;
-    return factory.createParameterDeclaration(node.modifiers, dotdotdot, name, node.questionToken, visitNode(node.type, transformJSDocType, isTypeNode), node.initializer);
+      tokenName,
+      /*questionToken*/
+      void 0,
+      typeNode
+    );
+    const lastProp = getNodeToInsertPropertyAfter(node);
+    if (lastProp) {
+      changeTracker.insertNodeAfter(sourceFile, lastProp, property);
+    } else {
+      changeTracker.insertMemberAtStart(sourceFile, node, property);
+    }
   }
-  function transformJSDocTypeReference(node) {
-    let name = node.typeName;
-    let args = node.typeArguments;
-    if (isIdentifier(node.typeName)) {
-      if (isJSDocIndexSignature(node)) {
-        return transformJSDocIndexSignature(node);
-      }
-      let text = node.typeName.text;
-      switch (node.typeName.text) {
-        case "String":
-        case "Boolean":
-        case "Object":
-        case "Number":
-          text = text.toLowerCase();
-          break;
-        case "array":
-        case "date":
-        case "promise":
-          text = text[0].toUpperCase() + text.slice(1);
-          break;
-      }
-      name = factory.createIdentifier(text);
-      if ((text === "Array" || text === "Promise") && !node.typeArguments) {
-        args = factory.createNodeArray([factory.createTypeReferenceNode("any", emptyArray)]);
-      } else {
-        args = visitNodes2(node.typeArguments, transformJSDocType, isTypeNode);
-      }
+  function getNodeToInsertPropertyAfter(node) {
+    let res;
+    for (const member of node.members) {
+      if (!isPropertyDeclaration(member))
+        break;
+      res = member;
     }
-    return factory.createTypeReferenceNode(name, args);
+    return res;
   }
-  function transformJSDocIndexSignature(node) {
-    const index = factory.createParameterDeclaration(
+  function createAddIndexSignatureAction(context, sourceFile, node, tokenName, typeNode) {
+    const stringTypeNode = factory.createKeywordTypeNode(154 /* StringKeyword */);
+    const indexingParameter = factory.createParameterDeclaration(
       /*modifiers*/
       void 0,
       /*dotDotDotToken*/
       void 0,
-      node.typeArguments[0].kind === 150 /* NumberKeyword */ ? "n" : "s",
+      "x",
       /*questionToken*/
       void 0,
-      factory.createTypeReferenceNode(node.typeArguments[0].kind === 150 /* NumberKeyword */ ? "number" : "string", []),
+      stringTypeNode,
       /*initializer*/
       void 0
     );
-    const indexSignature = factory.createTypeLiteralNode([factory.createIndexSignature(
+    const indexSignature = factory.createIndexSignature(
       /*modifiers*/
       void 0,
-      [index],
-      node.typeArguments[1]
-    )]);
-    setEmitFlags(indexSignature, 1 /* SingleLine */);
-    return indexSignature;
+      [indexingParameter],
+      typeNode
+    );
+    const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => t.insertMemberAtStart(sourceFile, node, indexSignature));
+    return createCodeFixActionWithoutFixAll(fixMissingMember, changes, [Diagnostics.Add_index_signature_for_property_0, tokenName]);
   }
-  var fixId8, errorCodes9;
-  var init_annotateWithTypeFromJSDoc = __esm({
-    "src/services/codefixes/annotateWithTypeFromJSDoc.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_codefix();
-      fixId8 = "annotateWithTypeFromJSDoc";
-      errorCodes9 = [Diagnostics.JSDoc_types_may_be_moved_to_TypeScript_types.code];
-      registerCodeFix({
-        errorCodes: errorCodes9,
-        getCodeActions(context) {
-          const decl = getDeclaration(context.sourceFile, context.span.start);
-          if (!decl)
-            return;
-          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange8(t, context.sourceFile, decl));
-          return [createCodeFixAction(fixId8, changes, Diagnostics.Annotate_with_type_from_JSDoc, fixId8, Diagnostics.Annotate_everything_with_types_from_JSDoc)];
-        },
-        fixIds: [fixId8],
-        getAllCodeActions: (context) => codeFixAll(context, errorCodes9, (changes, diag2) => {
-          const decl = getDeclaration(diag2.file, diag2.start);
-          if (decl)
-            doChange8(changes, diag2.file, decl);
-        })
-      });
-    }
-  });
-
-  // src/services/codefixes/convertFunctionToEs6Class.ts
-  function doChange9(changes, sourceFile, position, checker, preferences, compilerOptions) {
-    const ctorSymbol = checker.getSymbolAtLocation(getTokenAtPosition(sourceFile, position));
-    if (!ctorSymbol || !ctorSymbol.valueDeclaration || !(ctorSymbol.flags & (16 /* Function */ | 3 /* Variable */))) {
+  function getActionsForMissingMethodDeclaration(context, info) {
+    const { parentDeclaration, declSourceFile, modifierFlags, token, call } = info;
+    if (call === void 0) {
       return void 0;
     }
-    const ctorDeclaration = ctorSymbol.valueDeclaration;
-    if (isFunctionDeclaration(ctorDeclaration) || isFunctionExpression(ctorDeclaration)) {
-      changes.replaceNode(sourceFile, ctorDeclaration, createClassFromFunction(ctorDeclaration));
-    } else if (isVariableDeclaration(ctorDeclaration)) {
-      const classDeclaration = createClassFromVariableDeclaration(ctorDeclaration);
-      if (!classDeclaration) {
-        return void 0;
-      }
-      const ancestor = ctorDeclaration.parent.parent;
-      if (isVariableDeclarationList(ctorDeclaration.parent) && ctorDeclaration.parent.declarations.length > 1) {
-        changes.delete(sourceFile, ctorDeclaration);
-        changes.insertNodeAfter(sourceFile, ancestor, classDeclaration);
-      } else {
-        changes.replaceNode(sourceFile, ancestor, classDeclaration);
-      }
+    const methodName = token.text;
+    const addMethodDeclarationChanges = (modifierFlags2) => ts_textChanges_exports.ChangeTracker.with(context, (t) => addMethodDeclaration(context, t, call, token, modifierFlags2, parentDeclaration, declSourceFile));
+    const actions2 = [createCodeFixAction(fixMissingMember, addMethodDeclarationChanges(modifierFlags & 256 /* Static */), [modifierFlags & 256 /* Static */ ? Diagnostics.Declare_static_method_0 : Diagnostics.Declare_method_0, methodName], fixMissingMember, Diagnostics.Add_all_missing_members)];
+    if (modifierFlags & 2 /* Private */) {
+      actions2.unshift(createCodeFixActionWithoutFixAll(fixMissingMember, addMethodDeclarationChanges(2 /* Private */), [Diagnostics.Declare_private_method_0, methodName]));
     }
-    function createClassElementsFromSymbol(symbol) {
-      const memberElements = [];
-      if (symbol.exports) {
-        symbol.exports.forEach((member) => {
-          if (member.name === "prototype" && member.declarations) {
-            const firstDeclaration = member.declarations[0];
-            if (member.declarations.length === 1 && isPropertyAccessExpression(firstDeclaration) && isBinaryExpression(firstDeclaration.parent) && firstDeclaration.parent.operatorToken.kind === 64 /* EqualsToken */ && isObjectLiteralExpression(firstDeclaration.parent.right)) {
-              const prototypes = firstDeclaration.parent.right;
-              createClassElement(
-                prototypes.symbol,
-                /*modifiers*/
-                void 0,
-                memberElements
-              );
-            }
-          } else {
-            createClassElement(member, [factory.createToken(126 /* StaticKeyword */)], memberElements);
-          }
-        });
-      }
-      if (symbol.members) {
-        symbol.members.forEach((member, key) => {
-          var _a, _b, _c, _d;
-          if (key === "constructor" && member.valueDeclaration) {
-            const prototypeAssignment = (_d = (_c = (_b = (_a = symbol.exports) == null ? void 0 : _a.get("prototype")) == null ? void 0 : _b.declarations) == null ? void 0 : _c[0]) == null ? void 0 : _d.parent;
-            if (prototypeAssignment && isBinaryExpression(prototypeAssignment) && isObjectLiteralExpression(prototypeAssignment.right) && some(prototypeAssignment.right.properties, isConstructorAssignment)) {
-            } else {
-              changes.delete(sourceFile, member.valueDeclaration.parent);
-            }
-            return;
-          }
-          createClassElement(
-            member,
-            /*modifiers*/
-            void 0,
-            memberElements
-          );
-        });
-      }
-      return memberElements;
-      function shouldConvertDeclaration(_target, source) {
-        if (isAccessExpression(_target)) {
-          if (isPropertyAccessExpression(_target) && isConstructorAssignment(_target))
-            return true;
-          return isFunctionLike(source);
-        } else {
-          return every(_target.properties, (property) => {
-            if (isMethodDeclaration(property) || isGetOrSetAccessorDeclaration(property))
-              return true;
-            if (isPropertyAssignment(property) && isFunctionExpression(property.initializer) && !!property.name)
-              return true;
-            if (isConstructorAssignment(property))
-              return true;
-            return false;
-          });
-        }
-      }
-      function createClassElement(symbol2, modifiers, members) {
-        if (!(symbol2.flags & 8192 /* Method */) && !(symbol2.flags & 4096 /* ObjectLiteral */)) {
-          return;
-        }
-        const memberDeclaration = symbol2.valueDeclaration;
-        const assignmentBinaryExpression = memberDeclaration.parent;
-        const assignmentExpr = assignmentBinaryExpression.right;
-        if (!shouldConvertDeclaration(memberDeclaration, assignmentExpr)) {
-          return;
-        }
-        if (some(members, (m) => {
-          const name = getNameOfDeclaration(m);
-          if (name && isIdentifier(name) && idText(name) === symbolName(symbol2)) {
-            return true;
-          }
-          return false;
-        })) {
-          return;
-        }
-        const nodeToDelete = assignmentBinaryExpression.parent && assignmentBinaryExpression.parent.kind === 243 /* ExpressionStatement */ ? assignmentBinaryExpression.parent : assignmentBinaryExpression;
-        changes.delete(sourceFile, nodeToDelete);
-        if (!assignmentExpr) {
-          members.push(factory.createPropertyDeclaration(
-            modifiers,
-            symbol2.name,
-            /*questionOrExclamationToken*/
-            void 0,
-            /*type*/
-            void 0,
-            /*initializer*/
-            void 0
-          ));
-          return;
-        }
-        if (isAccessExpression(memberDeclaration) && (isFunctionExpression(assignmentExpr) || isArrowFunction(assignmentExpr))) {
-          const quotePreference = getQuotePreference(sourceFile, preferences);
-          const name = tryGetPropertyName(memberDeclaration, compilerOptions, quotePreference);
-          if (name) {
-            createFunctionLikeExpressionMember(members, assignmentExpr, name);
-          }
-          return;
-        } else if (isObjectLiteralExpression(assignmentExpr)) {
-          forEach(
-            assignmentExpr.properties,
-            (property) => {
-              if (isMethodDeclaration(property) || isGetOrSetAccessorDeclaration(property)) {
-                members.push(property);
-              }
-              if (isPropertyAssignment(property) && isFunctionExpression(property.initializer)) {
-                createFunctionLikeExpressionMember(members, property.initializer, property.name);
-              }
-              if (isConstructorAssignment(property))
-                return;
-              return;
-            }
-          );
-          return;
-        } else {
-          if (isSourceFileJS(sourceFile))
-            return;
-          if (!isPropertyAccessExpression(memberDeclaration))
-            return;
-          const prop = factory.createPropertyDeclaration(
-            modifiers,
-            memberDeclaration.name,
-            /*questionOrExclamationToken*/
-            void 0,
-            /*type*/
-            void 0,
-            assignmentExpr
-          );
-          copyLeadingComments(assignmentBinaryExpression.parent, prop, sourceFile);
-          members.push(prop);
-          return;
-        }
-        function createFunctionLikeExpressionMember(members2, expression, name) {
-          if (isFunctionExpression(expression))
-            return createFunctionExpressionMember(members2, expression, name);
-          else
-            return createArrowFunctionExpressionMember(members2, expression, name);
-        }
-        function createFunctionExpressionMember(members2, functionExpression, name) {
-          const fullModifiers = concatenate(modifiers, getModifierKindFromSource(functionExpression, 134 /* AsyncKeyword */));
-          const method = factory.createMethodDeclaration(
-            fullModifiers,
-            /*asteriskToken*/
-            void 0,
-            name,
-            /*questionToken*/
-            void 0,
-            /*typeParameters*/
-            void 0,
-            functionExpression.parameters,
-            /*type*/
-            void 0,
-            functionExpression.body
-          );
-          copyLeadingComments(assignmentBinaryExpression, method, sourceFile);
-          members2.push(method);
-          return;
-        }
-        function createArrowFunctionExpressionMember(members2, arrowFunction, name) {
-          const arrowFunctionBody = arrowFunction.body;
-          let bodyBlock;
-          if (arrowFunctionBody.kind === 240 /* Block */) {
-            bodyBlock = arrowFunctionBody;
-          } else {
-            bodyBlock = factory.createBlock([factory.createReturnStatement(arrowFunctionBody)]);
-          }
-          const fullModifiers = concatenate(modifiers, getModifierKindFromSource(arrowFunction, 134 /* AsyncKeyword */));
-          const method = factory.createMethodDeclaration(
-            fullModifiers,
-            /*asteriskToken*/
-            void 0,
-            name,
-            /*questionToken*/
-            void 0,
-            /*typeParameters*/
-            void 0,
-            arrowFunction.parameters,
-            /*type*/
-            void 0,
-            bodyBlock
-          );
-          copyLeadingComments(assignmentBinaryExpression, method, sourceFile);
-          members2.push(method);
-        }
-      }
+    return actions2;
+  }
+  function addMethodDeclaration(context, changes, callExpression, name, modifierFlags, parentDeclaration, sourceFile) {
+    const importAdder = createImportAdder(sourceFile, context.program, context.preferences, context.host);
+    const kind = isClassLike(parentDeclaration) ? 174 /* MethodDeclaration */ : 173 /* MethodSignature */;
+    const signatureDeclaration = createSignatureDeclarationFromCallExpression(kind, context, importAdder, callExpression, name, modifierFlags, parentDeclaration);
+    const containingMethodDeclaration = tryGetContainingMethodDeclaration(parentDeclaration, callExpression);
+    if (containingMethodDeclaration) {
+      changes.insertNodeAfter(sourceFile, containingMethodDeclaration, signatureDeclaration);
+    } else {
+      changes.insertMemberAtStart(sourceFile, parentDeclaration, signatureDeclaration);
     }
-    function createClassFromVariableDeclaration(node) {
-      const initializer = node.initializer;
-      if (!initializer || !isFunctionExpression(initializer) || !isIdentifier(node.name)) {
-        return void 0;
-      }
-      const memberElements = createClassElementsFromSymbol(node.symbol);
-      if (initializer.body) {
-        memberElements.unshift(factory.createConstructorDeclaration(
-          /*modifiers*/
-          void 0,
-          initializer.parameters,
-          initializer.body
-        ));
+    importAdder.writeFixes(changes);
+  }
+  function addEnumMemberDeclaration(changes, checker, { token, parentDeclaration }) {
+    const hasStringInitializer = some(parentDeclaration.members, (member) => {
+      const type = checker.getTypeAtLocation(member);
+      return !!(type && type.flags & 402653316 /* StringLike */);
+    });
+    const enumMember = factory.createEnumMember(token, hasStringInitializer ? factory.createStringLiteral(token.text) : void 0);
+    changes.replaceNode(
+      parentDeclaration.getSourceFile(),
+      parentDeclaration,
+      factory.updateEnumDeclaration(
+        parentDeclaration,
+        parentDeclaration.modifiers,
+        parentDeclaration.name,
+        concatenate(parentDeclaration.members, singleElementArray(enumMember))
+      ),
+      {
+        leadingTriviaOption: ts_textChanges_exports.LeadingTriviaOption.IncludeAll,
+        trailingTriviaOption: ts_textChanges_exports.TrailingTriviaOption.Exclude
       }
-      const modifiers = getModifierKindFromSource(node.parent.parent, 95 /* ExportKeyword */);
-      const cls = factory.createClassDeclaration(
-        modifiers,
-        node.name,
-        /*typeParameters*/
+    );
+  }
+  function addFunctionDeclaration(changes, context, info) {
+    const quotePreference = getQuotePreference(context.sourceFile, context.preferences);
+    const importAdder = createImportAdder(context.sourceFile, context.program, context.preferences, context.host);
+    const functionDeclaration = info.kind === 2 /* Function */ ? createSignatureDeclarationFromCallExpression(262 /* FunctionDeclaration */, context, importAdder, info.call, idText(info.token), info.modifierFlags, info.parentDeclaration) : createSignatureDeclarationFromSignature(
+      262 /* FunctionDeclaration */,
+      context,
+      quotePreference,
+      info.signature,
+      createStubbedBody(Diagnostics.Function_not_implemented.message, quotePreference),
+      info.token,
+      /*modifiers*/
+      void 0,
+      /*optional*/
+      void 0,
+      /*enclosingDeclaration*/
+      void 0,
+      importAdder
+    );
+    if (functionDeclaration === void 0) {
+      Debug.fail("fixMissingFunctionDeclaration codefix got unexpected error.");
+    }
+    isReturnStatement(info.parentDeclaration) ? changes.insertNodeBefore(
+      info.sourceFile,
+      info.parentDeclaration,
+      functionDeclaration,
+      /*blankLineBetween*/
+      true
+    ) : changes.insertNodeAtEndOfScope(info.sourceFile, info.parentDeclaration, functionDeclaration);
+    importAdder.writeFixes(changes);
+  }
+  function addJsxAttributes(changes, context, info) {
+    const importAdder = createImportAdder(context.sourceFile, context.program, context.preferences, context.host);
+    const quotePreference = getQuotePreference(context.sourceFile, context.preferences);
+    const checker = context.program.getTypeChecker();
+    const jsxAttributesNode = info.parentDeclaration.attributes;
+    const hasSpreadAttribute = some(jsxAttributesNode.properties, isJsxSpreadAttribute);
+    const attrs = map(info.attributes, (attr) => {
+      const value = tryGetValueFromType(context, checker, importAdder, quotePreference, checker.getTypeOfSymbol(attr), info.parentDeclaration);
+      const name = factory.createIdentifier(attr.name);
+      const jsxAttribute = factory.createJsxAttribute(name, factory.createJsxExpression(
+        /*dotDotDotToken*/
         void 0,
-        /*heritageClauses*/
+        value
+      ));
+      setParent(name, jsxAttribute);
+      return jsxAttribute;
+    });
+    const jsxAttributes = factory.createJsxAttributes(hasSpreadAttribute ? [...attrs, ...jsxAttributesNode.properties] : [...jsxAttributesNode.properties, ...attrs]);
+    const options = { prefix: jsxAttributesNode.pos === jsxAttributesNode.end ? " " : void 0 };
+    changes.replaceNode(context.sourceFile, jsxAttributesNode, jsxAttributes, options);
+    importAdder.writeFixes(changes);
+  }
+  function addObjectLiteralProperties(changes, context, info) {
+    const importAdder = createImportAdder(context.sourceFile, context.program, context.preferences, context.host);
+    const quotePreference = getQuotePreference(context.sourceFile, context.preferences);
+    const target = getEmitScriptTarget(context.program.getCompilerOptions());
+    const checker = context.program.getTypeChecker();
+    const props = map(info.properties, (prop) => {
+      const initializer = tryGetValueFromType(context, checker, importAdder, quotePreference, checker.getTypeOfSymbol(prop), info.parentDeclaration);
+      return factory.createPropertyAssignment(createPropertyNameFromSymbol(prop, target, quotePreference, checker), initializer);
+    });
+    const options = {
+      leadingTriviaOption: ts_textChanges_exports.LeadingTriviaOption.Exclude,
+      trailingTriviaOption: ts_textChanges_exports.TrailingTriviaOption.Exclude,
+      indentation: info.indentation
+    };
+    changes.replaceNode(context.sourceFile, info.parentDeclaration, factory.createObjectLiteralExpression(
+      [...info.parentDeclaration.properties, ...props],
+      /*multiLine*/
+      true
+    ), options);
+    importAdder.writeFixes(changes);
+  }
+  function tryGetValueFromType(context, checker, importAdder, quotePreference, type, enclosingDeclaration) {
+    if (type.flags & 3 /* AnyOrUnknown */) {
+      return createUndefined();
+    }
+    if (type.flags & (4 /* String */ | 134217728 /* TemplateLiteral */)) {
+      return factory.createStringLiteral(
+        "",
+        /* isSingleQuote */
+        quotePreference === 0 /* Single */
+      );
+    }
+    if (type.flags & 8 /* Number */) {
+      return factory.createNumericLiteral(0);
+    }
+    if (type.flags & 64 /* BigInt */) {
+      return factory.createBigIntLiteral("0n");
+    }
+    if (type.flags & 16 /* Boolean */) {
+      return factory.createFalse();
+    }
+    if (type.flags & 1056 /* EnumLike */) {
+      const enumMember = type.symbol.exports ? firstOrUndefinedIterator(type.symbol.exports.values()) : type.symbol;
+      const name = checker.symbolToExpression(
+        type.symbol.parent ? type.symbol.parent : type.symbol,
+        111551 /* Value */,
+        /*enclosingDeclaration*/
         void 0,
-        memberElements
+        /*flags*/
+        void 0
       );
-      return cls;
+      return enumMember === void 0 || name === void 0 ? factory.createNumericLiteral(0) : factory.createPropertyAccessExpression(name, checker.symbolToString(enumMember));
     }
-    function createClassFromFunction(node) {
-      const memberElements = createClassElementsFromSymbol(ctorSymbol);
-      if (node.body) {
-        memberElements.unshift(factory.createConstructorDeclaration(
-          /*modifiers*/
-          void 0,
-          node.parameters,
-          node.body
-        ));
-      }
-      const modifiers = getModifierKindFromSource(node, 95 /* ExportKeyword */);
-      const cls = factory.createClassDeclaration(
-        modifiers,
-        node.name,
-        /*typeParameters*/
+    if (type.flags & 256 /* NumberLiteral */) {
+      return factory.createNumericLiteral(type.value);
+    }
+    if (type.flags & 2048 /* BigIntLiteral */) {
+      return factory.createBigIntLiteral(type.value);
+    }
+    if (type.flags & 128 /* StringLiteral */) {
+      return factory.createStringLiteral(
+        type.value,
+        /* isSingleQuote */
+        quotePreference === 0 /* Single */
+      );
+    }
+    if (type.flags & 512 /* BooleanLiteral */) {
+      return type === checker.getFalseType() || type === checker.getFalseType(
+        /*fresh*/
+        true
+      ) ? factory.createFalse() : factory.createTrue();
+    }
+    if (type.flags & 65536 /* Null */) {
+      return factory.createNull();
+    }
+    if (type.flags & 1048576 /* Union */) {
+      const expression = firstDefined(type.types, (t) => tryGetValueFromType(context, checker, importAdder, quotePreference, t, enclosingDeclaration));
+      return expression ?? createUndefined();
+    }
+    if (checker.isArrayLikeType(type)) {
+      return factory.createArrayLiteralExpression();
+    }
+    if (isObjectLiteralType(type)) {
+      const props = map(checker.getPropertiesOfType(type), (prop) => {
+        const initializer = tryGetValueFromType(context, checker, importAdder, quotePreference, checker.getTypeOfSymbol(prop), enclosingDeclaration);
+        return factory.createPropertyAssignment(prop.name, initializer);
+      });
+      return factory.createObjectLiteralExpression(
+        props,
+        /*multiLine*/
+        true
+      );
+    }
+    if (getObjectFlags(type) & 16 /* Anonymous */) {
+      const decl = find(type.symbol.declarations || emptyArray, or(isFunctionTypeNode, isMethodSignature, isMethodDeclaration));
+      if (decl === void 0)
+        return createUndefined();
+      const signature = checker.getSignaturesOfType(type, 0 /* Call */);
+      if (signature === void 0)
+        return createUndefined();
+      const func = createSignatureDeclarationFromSignature(
+        218 /* FunctionExpression */,
+        context,
+        quotePreference,
+        signature[0],
+        createStubbedBody(Diagnostics.Function_not_implemented.message, quotePreference),
+        /*name*/
         void 0,
-        /*heritageClauses*/
+        /*modifiers*/
         void 0,
-        memberElements
+        /*optional*/
+        void 0,
+        /*enclosingDeclaration*/
+        enclosingDeclaration,
+        importAdder
+      );
+      return func ?? createUndefined();
+    }
+    if (getObjectFlags(type) & 1 /* Class */) {
+      const classDeclaration = getClassLikeDeclarationOfSymbol(type.symbol);
+      if (classDeclaration === void 0 || hasAbstractModifier(classDeclaration))
+        return createUndefined();
+      const constructorDeclaration = getFirstConstructorWithBody(classDeclaration);
+      if (constructorDeclaration && length(constructorDeclaration.parameters))
+        return createUndefined();
+      return factory.createNewExpression(
+        factory.createIdentifier(type.symbol.name),
+        /*typeArguments*/
+        void 0,
+        /*argumentsArray*/
+        void 0
       );
-      return cls;
     }
+    return createUndefined();
   }
-  function getModifierKindFromSource(source, kind) {
-    return canHaveModifiers(source) ? filter(source.modifiers, (modifier) => modifier.kind === kind) : void 0;
+  function createUndefined() {
+    return factory.createIdentifier("undefined");
   }
-  function isConstructorAssignment(x) {
-    if (!x.name)
-      return false;
-    if (isIdentifier(x.name) && x.name.text === "constructor")
-      return true;
-    return false;
+  function isObjectLiteralType(type) {
+    return type.flags & 524288 /* Object */ && (getObjectFlags(type) & 128 /* ObjectLiteral */ || type.symbol && tryCast(singleOrUndefined(type.symbol.declarations), isTypeLiteralNode));
   }
-  function tryGetPropertyName(node, compilerOptions, quotePreference) {
-    if (isPropertyAccessExpression(node)) {
-      return node.name;
+  function getUnmatchedAttributes(checker, target, source) {
+    const attrsType = checker.getContextualType(source.attributes);
+    if (attrsType === void 0)
+      return emptyArray;
+    const targetProps = attrsType.getProperties();
+    if (!length(targetProps))
+      return emptyArray;
+    const seenNames = /* @__PURE__ */ new Set();
+    for (const sourceProp of source.attributes.properties) {
+      if (isJsxAttribute(sourceProp)) {
+        seenNames.add(getEscapedTextOfJsxAttributeName(sourceProp.name));
+      }
+      if (isJsxSpreadAttribute(sourceProp)) {
+        const type = checker.getTypeAtLocation(sourceProp.expression);
+        for (const prop of type.getProperties()) {
+          seenNames.add(prop.escapedName);
+        }
+      }
     }
-    const propName = node.argumentExpression;
-    if (isNumericLiteral(propName)) {
-      return propName;
+    return filter(targetProps, (targetProp) => isIdentifierText(targetProp.name, target, 1 /* JSX */) && !(targetProp.flags & 16777216 /* Optional */ || getCheckFlags(targetProp) & 48 /* Partial */ || seenNames.has(targetProp.escapedName)));
+  }
+  function tryGetContainingMethodDeclaration(node, callExpression) {
+    if (isTypeLiteralNode(node)) {
+      return void 0;
     }
-    if (isStringLiteralLike(propName)) {
-      return isIdentifierText(propName.text, getEmitScriptTarget(compilerOptions)) ? factory.createIdentifier(propName.text) : isNoSubstitutionTemplateLiteral(propName) ? factory.createStringLiteral(propName.text, quotePreference === 0 /* Single */) : propName;
+    const declaration = findAncestor(callExpression, (n) => isMethodDeclaration(n) || isConstructorDeclaration(n));
+    return declaration && declaration.parent === node ? declaration : void 0;
+  }
+  function createPropertyNameFromSymbol(symbol, target, quotePreference, checker) {
+    if (isTransientSymbol(symbol)) {
+      const prop = checker.symbolToNode(
+        symbol,
+        111551 /* Value */,
+        /*enclosingDeclaration*/
+        void 0,
+        1073741824 /* WriteComputedProps */
+      );
+      if (prop && isComputedPropertyName(prop))
+        return prop;
+    }
+    return createPropertyNameNodeForIdentifierOrLiteral(
+      symbol.name,
+      target,
+      quotePreference === 0 /* Single */,
+      /*stringNamed*/
+      false,
+      /*isMethod*/
+      false
+    );
+  }
+  function findScope(node) {
+    if (findAncestor(node, isJsxExpression)) {
+      const returnStatement = findAncestor(node.parent, isReturnStatement);
+      if (returnStatement)
+        return returnStatement;
+    }
+    return getSourceFileOfNode(node);
+  }
+  var fixMissingMember, fixMissingProperties, fixMissingAttributes, fixMissingFunctionDeclaration, errorCodes27;
+  var init_fixAddMissingMember = __esm({
+    "src/services/codefixes/fixAddMissingMember.ts"() {
+      "use strict";
+      init_ts4();
+      init_ts_codefix();
+      fixMissingMember = "fixMissingMember";
+      fixMissingProperties = "fixMissingProperties";
+      fixMissingAttributes = "fixMissingAttributes";
+      fixMissingFunctionDeclaration = "fixMissingFunctionDeclaration";
+      errorCodes27 = [
+        Diagnostics.Property_0_does_not_exist_on_type_1.code,
+        Diagnostics.Property_0_does_not_exist_on_type_1_Did_you_mean_2.code,
+        Diagnostics.Property_0_is_missing_in_type_1_but_required_in_type_2.code,
+        Diagnostics.Type_0_is_missing_the_following_properties_from_type_1_Colon_2.code,
+        Diagnostics.Type_0_is_missing_the_following_properties_from_type_1_Colon_2_and_3_more.code,
+        Diagnostics.Argument_of_type_0_is_not_assignable_to_parameter_of_type_1.code,
+        Diagnostics.Cannot_find_name_0.code
+      ];
+      registerCodeFix({
+        errorCodes: errorCodes27,
+        getCodeActions(context) {
+          const typeChecker = context.program.getTypeChecker();
+          const info = getInfo10(context.sourceFile, context.span.start, context.errorCode, typeChecker, context.program);
+          if (!info) {
+            return void 0;
+          }
+          if (info.kind === 3 /* ObjectLiteral */) {
+            const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => addObjectLiteralProperties(t, context, info));
+            return [createCodeFixAction(fixMissingProperties, changes, Diagnostics.Add_missing_properties, fixMissingProperties, Diagnostics.Add_all_missing_properties)];
+          }
+          if (info.kind === 4 /* JsxAttributes */) {
+            const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => addJsxAttributes(t, context, info));
+            return [createCodeFixAction(fixMissingAttributes, changes, Diagnostics.Add_missing_attributes, fixMissingAttributes, Diagnostics.Add_all_missing_attributes)];
+          }
+          if (info.kind === 2 /* Function */ || info.kind === 5 /* Signature */) {
+            const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => addFunctionDeclaration(t, context, info));
+            return [createCodeFixAction(fixMissingFunctionDeclaration, changes, [Diagnostics.Add_missing_function_declaration_0, info.token.text], fixMissingFunctionDeclaration, Diagnostics.Add_all_missing_function_declarations)];
+          }
+          if (info.kind === 1 /* Enum */) {
+            const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => addEnumMemberDeclaration(t, context.program.getTypeChecker(), info));
+            return [createCodeFixAction(fixMissingMember, changes, [Diagnostics.Add_missing_enum_member_0, info.token.text], fixMissingMember, Diagnostics.Add_all_missing_members)];
+          }
+          return concatenate(getActionsForMissingMethodDeclaration(context, info), getActionsForMissingMemberDeclaration(context, info));
+        },
+        fixIds: [fixMissingMember, fixMissingFunctionDeclaration, fixMissingProperties, fixMissingAttributes],
+        getAllCodeActions: (context) => {
+          const { program, fixId: fixId52 } = context;
+          const checker = program.getTypeChecker();
+          const seen = /* @__PURE__ */ new Map();
+          const typeDeclToMembers = /* @__PURE__ */ new Map();
+          return createCombinedCodeActions(ts_textChanges_exports.ChangeTracker.with(context, (changes) => {
+            eachDiagnostic(context, errorCodes27, (diag2) => {
+              const info = getInfo10(diag2.file, diag2.start, diag2.code, checker, context.program);
+              if (!info || !addToSeen(seen, getNodeId(info.parentDeclaration) + "#" + info.token.text)) {
+                return;
+              }
+              if (fixId52 === fixMissingFunctionDeclaration && (info.kind === 2 /* Function */ || info.kind === 5 /* Signature */)) {
+                addFunctionDeclaration(changes, context, info);
+              } else if (fixId52 === fixMissingProperties && info.kind === 3 /* ObjectLiteral */) {
+                addObjectLiteralProperties(changes, context, info);
+              } else if (fixId52 === fixMissingAttributes && info.kind === 4 /* JsxAttributes */) {
+                addJsxAttributes(changes, context, info);
+              } else {
+                if (info.kind === 1 /* Enum */) {
+                  addEnumMemberDeclaration(changes, checker, info);
+                }
+                if (info.kind === 0 /* TypeLikeDeclaration */) {
+                  const { parentDeclaration, token } = info;
+                  const infos = getOrUpdate(typeDeclToMembers, parentDeclaration, () => []);
+                  if (!infos.some((i) => i.token.text === token.text)) {
+                    infos.push(info);
+                  }
+                }
+              }
+            });
+            typeDeclToMembers.forEach((infos, declaration) => {
+              const supers = isTypeLiteralNode(declaration) ? void 0 : getAllSupers(declaration, checker);
+              for (const info of infos) {
+                if (supers == null ? void 0 : supers.some((superClassOrInterface) => {
+                  const superInfos = typeDeclToMembers.get(superClassOrInterface);
+                  return !!superInfos && superInfos.some(({ token: token2 }) => token2.text === info.token.text);
+                }))
+                  continue;
+                const { parentDeclaration, declSourceFile, modifierFlags, token, call, isJSFile } = info;
+                if (call && !isPrivateIdentifier(token)) {
+                  addMethodDeclaration(context, changes, call, token, modifierFlags & 256 /* Static */, parentDeclaration, declSourceFile);
+                } else {
+                  if (isJSFile && !isInterfaceDeclaration(parentDeclaration) && !isTypeLiteralNode(parentDeclaration)) {
+                    addMissingMemberInJs(changes, declSourceFile, parentDeclaration, token, !!(modifierFlags & 256 /* Static */));
+                  } else {
+                    const typeNode = getTypeNode2(checker, parentDeclaration, token);
+                    addPropertyDeclaration(changes, declSourceFile, parentDeclaration, token.text, typeNode, modifierFlags & 256 /* Static */);
+                  }
+                }
+              }
+            });
+          }));
+        }
+      });
+    }
+  });
+
+  // src/services/codefixes/fixAddMissingNewOperator.ts
+  function addMissingNewOperator(changes, sourceFile, span) {
+    const call = cast(findAncestorMatchingSpan2(sourceFile, span), isCallExpression);
+    const newExpression = factory.createNewExpression(call.expression, call.typeArguments, call.arguments);
+    changes.replaceNode(sourceFile, call, newExpression);
+  }
+  function findAncestorMatchingSpan2(sourceFile, span) {
+    let token = getTokenAtPosition(sourceFile, span.start);
+    const end = textSpanEnd(span);
+    while (token.end < end) {
+      token = token.parent;
     }
-    return void 0;
+    return token;
   }
-  var fixId9, errorCodes10;
-  var init_convertFunctionToEs6Class = __esm({
-    "src/services/codefixes/convertFunctionToEs6Class.ts"() {
+  var fixId24, errorCodes28;
+  var init_fixAddMissingNewOperator = __esm({
+    "src/services/codefixes/fixAddMissingNewOperator.ts"() {
       "use strict";
       init_ts4();
       init_ts_codefix();
-      fixId9 = "convertFunctionToEs6Class";
-      errorCodes10 = [Diagnostics.This_constructor_function_may_be_converted_to_a_class_declaration.code];
+      fixId24 = "addMissingNewOperator";
+      errorCodes28 = [Diagnostics.Value_of_type_0_is_not_callable_Did_you_mean_to_include_new.code];
       registerCodeFix({
-        errorCodes: errorCodes10,
+        errorCodes: errorCodes28,
         getCodeActions(context) {
-          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange9(t, context.sourceFile, context.span.start, context.program.getTypeChecker(), context.preferences, context.program.getCompilerOptions()));
-          return [createCodeFixAction(fixId9, changes, Diagnostics.Convert_function_to_an_ES2015_class, fixId9, Diagnostics.Convert_all_constructor_functions_to_classes)];
+          const { sourceFile, span } = context;
+          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => addMissingNewOperator(t, sourceFile, span));
+          return [createCodeFixAction(fixId24, changes, Diagnostics.Add_missing_new_operator_to_call, fixId24, Diagnostics.Add_missing_new_operator_to_all_calls)];
         },
-        fixIds: [fixId9],
-        getAllCodeActions: (context) => codeFixAll(context, errorCodes10, (changes, err) => doChange9(changes, err.file, err.start, context.program.getTypeChecker(), context.preferences, context.program.getCompilerOptions()))
+        fixIds: [fixId24],
+        getAllCodeActions: (context) => codeFixAll(context, errorCodes28, (changes, diag2) => addMissingNewOperator(changes, context.sourceFile, diag2))
       });
     }
   });
 
-  // src/services/codefixes/convertToAsyncFunction.ts
-  function convertToAsyncFunction(changes, sourceFile, position, checker) {
-    const tokenAtPosition = getTokenAtPosition(sourceFile, position);
-    let functionToConvert;
-    if (isIdentifier(tokenAtPosition) && isVariableDeclaration(tokenAtPosition.parent) && tokenAtPosition.parent.initializer && isFunctionLikeDeclaration(tokenAtPosition.parent.initializer)) {
-      functionToConvert = tokenAtPosition.parent.initializer;
-    } else {
-      functionToConvert = tryCast(getContainingFunction(getTokenAtPosition(sourceFile, position)), canBeConvertedToAsync);
-    }
-    if (!functionToConvert) {
-      return;
-    }
-    const synthNamesMap = /* @__PURE__ */ new Map();
-    const isInJavascript = isInJSFile(functionToConvert);
-    const setOfExpressionsToReturn = getAllPromiseExpressionsToReturn(functionToConvert, checker);
-    const functionToConvertRenamed = renameCollidingVarNames(functionToConvert, checker, synthNamesMap);
-    if (!returnsPromise(functionToConvertRenamed, checker)) {
-      return;
-    }
-    const returnStatements = functionToConvertRenamed.body && isBlock(functionToConvertRenamed.body) ? getReturnStatementsWithPromiseHandlers(functionToConvertRenamed.body, checker) : emptyArray;
-    const transformer = { checker, synthNamesMap, setOfExpressionsToReturn, isInJSFile: isInJavascript };
-    if (!returnStatements.length) {
-      return;
-    }
-    const pos = skipTrivia(sourceFile.text, moveRangePastModifiers(functionToConvert).pos);
-    changes.insertModifierAt(sourceFile, pos, 134 /* AsyncKeyword */, { suffix: " " });
-    for (const returnStatement of returnStatements) {
-      forEachChild(returnStatement, function visit(node) {
-        if (isCallExpression(node)) {
-          const newNodes = transformExpression(
-            node,
-            node,
-            transformer,
-            /*hasContinuation*/
-            false
-          );
-          if (hasFailed()) {
-            return true;
-          }
-          changes.replaceNodeWithNodes(sourceFile, returnStatement, newNodes);
-        } else if (!isFunctionLike(node)) {
-          forEachChild(node, visit);
-          if (hasFailed()) {
-            return true;
-          }
-        }
-      });
-      if (hasFailed()) {
-        return;
-      }
-    }
-  }
-  function getReturnStatementsWithPromiseHandlers(body, checker) {
-    const res = [];
-    forEachReturnStatement(body, (ret) => {
-      if (isReturnStatementWithFixablePromiseHandler(ret, checker))
-        res.push(ret);
-    });
-    return res;
-  }
-  function getAllPromiseExpressionsToReturn(func, checker) {
-    if (!func.body) {
-      return /* @__PURE__ */ new Set();
-    }
-    const setOfExpressionsToReturn = /* @__PURE__ */ new Set();
-    forEachChild(func.body, function visit(node) {
-      if (isPromiseReturningCallExpression(node, checker, "then")) {
-        setOfExpressionsToReturn.add(getNodeId(node));
-        forEach(node.arguments, visit);
-      } else if (isPromiseReturningCallExpression(node, checker, "catch") || isPromiseReturningCallExpression(node, checker, "finally")) {
-        setOfExpressionsToReturn.add(getNodeId(node));
-        forEachChild(node, visit);
-      } else if (isPromiseTypedExpression(node, checker)) {
-        setOfExpressionsToReturn.add(getNodeId(node));
-      } else {
-        forEachChild(node, visit);
-      }
-    });
-    return setOfExpressionsToReturn;
-  }
-  function isPromiseReturningCallExpression(node, checker, name) {
-    if (!isCallExpression(node))
-      return false;
-    const isExpressionOfName = hasPropertyAccessExpressionWithName(node, name);
-    const nodeType = isExpressionOfName && checker.getTypeAtLocation(node);
-    return !!(nodeType && checker.getPromisedTypeOfPromise(nodeType));
-  }
-  function isReferenceToType(type, target) {
-    return (getObjectFlags(type) & 4 /* Reference */) !== 0 && type.target === target;
+  // src/services/codefixes/fixCannotFindModule.ts
+  function getInstallCommand(fileName, packageName) {
+    return { type: "install package", file: fileName, packageName };
   }
-  function getExplicitPromisedTypeOfPromiseReturningCallExpression(node, callback, checker) {
-    if (node.expression.name.escapedText === "finally") {
+  function tryGetImportedPackageName(sourceFile, pos) {
+    const moduleSpecifierText = tryCast(getTokenAtPosition(sourceFile, pos), isStringLiteral);
+    if (!moduleSpecifierText)
       return void 0;
-    }
-    const promiseType = checker.getTypeAtLocation(node.expression.expression);
-    if (isReferenceToType(promiseType, checker.getPromiseType()) || isReferenceToType(promiseType, checker.getPromiseLikeType())) {
-      if (node.expression.name.escapedText === "then") {
-        if (callback === elementAt(node.arguments, 0)) {
-          return elementAt(node.typeArguments, 0);
-        } else if (callback === elementAt(node.arguments, 1)) {
-          return elementAt(node.typeArguments, 1);
-        }
-      } else {
-        return elementAt(node.typeArguments, 0);
-      }
-    }
+    const moduleName = moduleSpecifierText.text;
+    const { packageName } = parsePackageName(moduleName);
+    return isExternalModuleNameRelative(packageName) ? void 0 : packageName;
   }
-  function isPromiseTypedExpression(node, checker) {
-    if (!isExpression(node))
-      return false;
-    return !!checker.getPromisedTypeOfPromise(checker.getTypeAtLocation(node));
+  function getTypesPackageNameToInstall(packageName, host, diagCode) {
+    var _a;
+    return diagCode === errorCodeCannotFindModule ? ts_JsTyping_exports.nodeCoreModules.has(packageName) ? "@types/node" : void 0 : ((_a = host.isKnownTypesPackageName) == null ? void 0 : _a.call(host, packageName)) ? getTypesPackageName(packageName) : void 0;
   }
-  function renameCollidingVarNames(nodeToRename, checker, synthNamesMap) {
-    const identsToRenameMap = /* @__PURE__ */ new Map();
-    const collidingSymbolMap = createMultiMap();
-    forEachChild(nodeToRename, function visit(node) {
-      if (!isIdentifier(node)) {
-        forEachChild(node, visit);
-        return;
-      }
-      const symbol = checker.getSymbolAtLocation(node);
-      if (symbol) {
-        const type = checker.getTypeAtLocation(node);
-        const lastCallSignature = getLastCallSignature(type, checker);
-        const symbolIdString = getSymbolId(symbol).toString();
-        if (lastCallSignature && !isParameter(node.parent) && !isFunctionLikeDeclaration(node.parent) && !synthNamesMap.has(symbolIdString)) {
-          const firstParameter = firstOrUndefined(lastCallSignature.parameters);
-          const ident = (firstParameter == null ? void 0 : firstParameter.valueDeclaration) && isParameter(firstParameter.valueDeclaration) && tryCast(firstParameter.valueDeclaration.name, isIdentifier) || factory.createUniqueName("result", 16 /* Optimistic */);
-          const synthName = getNewNameIfConflict(ident, collidingSymbolMap);
-          synthNamesMap.set(symbolIdString, synthName);
-          collidingSymbolMap.add(ident.text, symbol);
-        } else if (node.parent && (isParameter(node.parent) || isVariableDeclaration(node.parent) || isBindingElement(node.parent))) {
-          const originalName = node.text;
-          const collidingSymbols = collidingSymbolMap.get(originalName);
-          if (collidingSymbols && collidingSymbols.some((prevSymbol) => prevSymbol !== symbol)) {
-            const newName = getNewNameIfConflict(node, collidingSymbolMap);
-            identsToRenameMap.set(symbolIdString, newName.identifier);
-            synthNamesMap.set(symbolIdString, newName);
-            collidingSymbolMap.add(originalName, symbol);
-          } else {
-            const identifier = getSynthesizedDeepClone(node);
-            synthNamesMap.set(symbolIdString, createSynthIdentifier(identifier));
-            collidingSymbolMap.add(originalName, symbol);
-          }
-        }
-      }
-    });
-    return getSynthesizedDeepCloneWithReplacements(
-      nodeToRename,
-      /*includeTrivia*/
-      true,
-      (original) => {
-        if (isBindingElement(original) && isIdentifier(original.name) && isObjectBindingPattern(original.parent)) {
-          const symbol = checker.getSymbolAtLocation(original.name);
-          const renameInfo = symbol && identsToRenameMap.get(String(getSymbolId(symbol)));
-          if (renameInfo && renameInfo.text !== (original.name || original.propertyName).getText()) {
-            return factory.createBindingElement(
-              original.dotDotDotToken,
-              original.propertyName || original.name,
-              renameInfo,
-              original.initializer
-            );
-          }
-        } else if (isIdentifier(original)) {
-          const symbol = checker.getSymbolAtLocation(original);
-          const renameInfo = symbol && identsToRenameMap.get(String(getSymbolId(symbol)));
-          if (renameInfo) {
-            return factory.createIdentifier(renameInfo.text);
-          }
+  var fixName2, fixIdInstallTypesPackage, errorCodeCannotFindModule, errorCodes29;
+  var init_fixCannotFindModule = __esm({
+    "src/services/codefixes/fixCannotFindModule.ts"() {
+      "use strict";
+      init_ts4();
+      init_ts_codefix();
+      fixName2 = "fixCannotFindModule";
+      fixIdInstallTypesPackage = "installTypesPackage";
+      errorCodeCannotFindModule = Diagnostics.Cannot_find_module_0_or_its_corresponding_type_declarations.code;
+      errorCodes29 = [
+        errorCodeCannotFindModule,
+        Diagnostics.Could_not_find_a_declaration_file_for_module_0_1_implicitly_has_an_any_type.code
+      ];
+      registerCodeFix({
+        errorCodes: errorCodes29,
+        getCodeActions: function getCodeActionsToFixNotFoundModule(context) {
+          const { host, sourceFile, span: { start } } = context;
+          const packageName = tryGetImportedPackageName(sourceFile, start);
+          if (packageName === void 0)
+            return void 0;
+          const typesPackageName = getTypesPackageNameToInstall(packageName, host, context.errorCode);
+          return typesPackageName === void 0 ? [] : [createCodeFixAction(
+            fixName2,
+            /*changes*/
+            [],
+            [Diagnostics.Install_0, typesPackageName],
+            fixIdInstallTypesPackage,
+            Diagnostics.Install_all_missing_types_packages,
+            getInstallCommand(sourceFile.fileName, typesPackageName)
+          )];
+        },
+        fixIds: [fixIdInstallTypesPackage],
+        getAllCodeActions: (context) => {
+          return codeFixAll(context, errorCodes29, (_changes, diag2, commands) => {
+            const packageName = tryGetImportedPackageName(diag2.file, diag2.start);
+            if (packageName === void 0)
+              return void 0;
+            switch (context.fixId) {
+              case fixIdInstallTypesPackage: {
+                const pkg = getTypesPackageNameToInstall(packageName, context.host, diag2.code);
+                if (pkg) {
+                  commands.push(getInstallCommand(diag2.file.fileName, pkg));
+                }
+                break;
+              }
+              default:
+                Debug.fail(`Bad fixId: ${context.fixId}`);
+            }
+          });
         }
-      }
-    );
-  }
-  function getNewNameIfConflict(name, originalNames) {
-    const numVarsSameName = (originalNames.get(name.text) || emptyArray).length;
-    const identifier = numVarsSameName === 0 ? name : factory.createIdentifier(name.text + "_" + numVarsSameName);
-    return createSynthIdentifier(identifier);
-  }
-  function hasFailed() {
-    return !codeActionSucceeded;
+      });
+    }
+  });
+
+  // src/services/codefixes/fixClassDoesntImplementInheritedAbstractMember.ts
+  function getClass2(sourceFile, pos) {
+    const token = getTokenAtPosition(sourceFile, pos);
+    return cast(token.parent, isClassLike);
   }
-  function silentFail() {
-    codeActionSucceeded = false;
-    return emptyArray;
+  function addMissingMembers(classDeclaration, sourceFile, context, changeTracker, preferences) {
+    const extendsNode = getEffectiveBaseTypeNode(classDeclaration);
+    const checker = context.program.getTypeChecker();
+    const instantiatedExtendsType = checker.getTypeAtLocation(extendsNode);
+    const abstractAndNonPrivateExtendsSymbols = checker.getPropertiesOfType(instantiatedExtendsType).filter(symbolPointsToNonPrivateAndAbstractMember);
+    const importAdder = createImportAdder(sourceFile, context.program, preferences, context.host);
+    createMissingMemberNodes(classDeclaration, abstractAndNonPrivateExtendsSymbols, sourceFile, context, preferences, importAdder, (member) => changeTracker.insertMemberAtStart(sourceFile, classDeclaration, member));
+    importAdder.writeFixes(changeTracker);
   }
-  function transformExpression(returnContextNode, node, transformer, hasContinuation, continuationArgName) {
-    if (isPromiseReturningCallExpression(node, transformer.checker, "then")) {
-      return transformThen(node, elementAt(node.arguments, 0), elementAt(node.arguments, 1), transformer, hasContinuation, continuationArgName);
-    }
-    if (isPromiseReturningCallExpression(node, transformer.checker, "catch")) {
-      return transformCatch(node, elementAt(node.arguments, 0), transformer, hasContinuation, continuationArgName);
-    }
-    if (isPromiseReturningCallExpression(node, transformer.checker, "finally")) {
-      return transformFinally(node, elementAt(node.arguments, 0), transformer, hasContinuation, continuationArgName);
-    }
-    if (isPropertyAccessExpression(node)) {
-      return transformExpression(returnContextNode, node.expression, transformer, hasContinuation, continuationArgName);
-    }
-    const nodeType = transformer.checker.getTypeAtLocation(node);
-    if (nodeType && transformer.checker.getPromisedTypeOfPromise(nodeType)) {
-      Debug.assertNode(getOriginalNode(node).parent, isPropertyAccessExpression);
-      return transformPromiseExpressionOfPropertyAccess(returnContextNode, node, transformer, hasContinuation, continuationArgName);
-    }
-    return silentFail();
+  function symbolPointsToNonPrivateAndAbstractMember(symbol) {
+    const flags = getSyntacticModifierFlags(first(symbol.getDeclarations()));
+    return !(flags & 2 /* Private */) && !!(flags & 64 /* Abstract */);
   }
-  function isNullOrUndefined2({ checker }, node) {
-    if (node.kind === 106 /* NullKeyword */)
-      return true;
-    if (isIdentifier(node) && !isGeneratedIdentifier(node) && idText(node) === "undefined") {
-      const symbol = checker.getSymbolAtLocation(node);
-      return !symbol || checker.isUndefinedSymbol(symbol);
+  var errorCodes30, fixId25;
+  var init_fixClassDoesntImplementInheritedAbstractMember = __esm({
+    "src/services/codefixes/fixClassDoesntImplementInheritedAbstractMember.ts"() {
+      "use strict";
+      init_ts4();
+      init_ts_codefix();
+      errorCodes30 = [
+        Diagnostics.Non_abstract_class_0_does_not_implement_all_abstract_members_of_1.code
+      ];
+      fixId25 = "fixClassDoesntImplementInheritedAbstractMember";
+      registerCodeFix({
+        errorCodes: errorCodes30,
+        getCodeActions: function getCodeActionsToFixClassNotImplementingInheritedMembers(context) {
+          const { sourceFile, span } = context;
+          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => addMissingMembers(getClass2(sourceFile, span.start), sourceFile, context, t, context.preferences));
+          return changes.length === 0 ? void 0 : [createCodeFixAction(fixId25, changes, Diagnostics.Implement_inherited_abstract_class, fixId25, Diagnostics.Implement_all_inherited_abstract_classes)];
+        },
+        fixIds: [fixId25],
+        getAllCodeActions: function getAllCodeActionsToFixClassDoesntImplementInheritedAbstractMember(context) {
+          const seenClassDeclarations = /* @__PURE__ */ new Map();
+          return codeFixAll(context, errorCodes30, (changes, diag2) => {
+            const classDeclaration = getClass2(diag2.file, diag2.start);
+            if (addToSeen(seenClassDeclarations, getNodeId(classDeclaration))) {
+              addMissingMembers(classDeclaration, context.sourceFile, context, changes, context.preferences);
+            }
+          });
+        }
+      });
     }
-    return false;
+  });
+
+  // src/services/codefixes/fixClassSuperMustPrecedeThisAccess.ts
+  function doChange19(changes, sourceFile, constructor, superCall) {
+    changes.insertNodeAtConstructorStart(sourceFile, constructor, superCall);
+    changes.delete(sourceFile, superCall);
   }
-  function createUniqueSynthName(prevArgName) {
-    const renamedPrevArg = factory.createUniqueName(prevArgName.identifier.text, 16 /* Optimistic */);
-    return createSynthIdentifier(renamedPrevArg);
+  function getNodes(sourceFile, pos) {
+    const token = getTokenAtPosition(sourceFile, pos);
+    if (token.kind !== 110 /* ThisKeyword */)
+      return void 0;
+    const constructor = getContainingFunction(token);
+    const superCall = findSuperCall(constructor.body);
+    return superCall && !superCall.expression.arguments.some((arg) => isPropertyAccessExpression(arg) && arg.expression === token) ? { constructor, superCall } : void 0;
   }
-  function getPossibleNameForVarDecl(node, transformer, continuationArgName) {
-    let possibleNameForVarDecl;
-    if (continuationArgName && !shouldReturn(node, transformer)) {
-      if (isSynthIdentifier(continuationArgName)) {
-        possibleNameForVarDecl = continuationArgName;
-        transformer.synthNamesMap.forEach((val, key) => {
-          if (val.identifier.text === continuationArgName.identifier.text) {
-            const newSynthName = createUniqueSynthName(continuationArgName);
-            transformer.synthNamesMap.set(key, newSynthName);
-          }
-        });
-      } else {
-        possibleNameForVarDecl = createSynthIdentifier(factory.createUniqueName("result", 16 /* Optimistic */), continuationArgName.types);
-      }
-      declareSynthIdentifier(possibleNameForVarDecl);
-    }
-    return possibleNameForVarDecl;
+  function findSuperCall(n) {
+    return isExpressionStatement(n) && isSuperCall(n.expression) ? n : isFunctionLike(n) ? void 0 : forEachChild(n, findSuperCall);
   }
-  function finishCatchOrFinallyTransform(node, transformer, tryStatement, possibleNameForVarDecl, continuationArgName) {
-    const statements = [];
-    let varDeclIdentifier;
-    if (possibleNameForVarDecl && !shouldReturn(node, transformer)) {
-      varDeclIdentifier = getSynthesizedDeepClone(declareSynthIdentifier(possibleNameForVarDecl));
-      const typeArray = possibleNameForVarDecl.types;
-      const unionType = transformer.checker.getUnionType(typeArray, 2 /* Subtype */);
-      const unionTypeNode = transformer.isInJSFile ? void 0 : transformer.checker.typeToTypeNode(
-        unionType,
-        /*enclosingDeclaration*/
-        void 0,
-        /*flags*/
-        void 0
-      );
-      const varDecl = [factory.createVariableDeclaration(
-        varDeclIdentifier,
-        /*exclamationToken*/
-        void 0,
-        unionTypeNode
-      )];
-      const varDeclList = factory.createVariableStatement(
-        /*modifiers*/
-        void 0,
-        factory.createVariableDeclarationList(varDecl, 1 /* Let */)
-      );
-      statements.push(varDeclList);
-    }
-    statements.push(tryStatement);
-    if (continuationArgName && varDeclIdentifier && isSynthBindingPattern(continuationArgName)) {
-      statements.push(factory.createVariableStatement(
-        /*modifiers*/
-        void 0,
-        factory.createVariableDeclarationList(
-          [
-            factory.createVariableDeclaration(
-              getSynthesizedDeepClone(declareSynthBindingPattern(continuationArgName)),
-              /*exclamationToken*/
-              void 0,
-              /*type*/
-              void 0,
-              varDeclIdentifier
-            )
-          ],
-          2 /* Const */
-        )
-      ));
+  var fixId26, errorCodes31;
+  var init_fixClassSuperMustPrecedeThisAccess = __esm({
+    "src/services/codefixes/fixClassSuperMustPrecedeThisAccess.ts"() {
+      "use strict";
+      init_ts4();
+      init_ts_codefix();
+      fixId26 = "classSuperMustPrecedeThisAccess";
+      errorCodes31 = [Diagnostics.super_must_be_called_before_accessing_this_in_the_constructor_of_a_derived_class.code];
+      registerCodeFix({
+        errorCodes: errorCodes31,
+        getCodeActions(context) {
+          const { sourceFile, span } = context;
+          const nodes = getNodes(sourceFile, span.start);
+          if (!nodes)
+            return void 0;
+          const { constructor, superCall } = nodes;
+          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange19(t, sourceFile, constructor, superCall));
+          return [createCodeFixAction(fixId26, changes, Diagnostics.Make_super_call_the_first_statement_in_the_constructor, fixId26, Diagnostics.Make_all_super_calls_the_first_statement_in_their_constructor)];
+        },
+        fixIds: [fixId26],
+        getAllCodeActions(context) {
+          const { sourceFile } = context;
+          const seenClasses = /* @__PURE__ */ new Map();
+          return codeFixAll(context, errorCodes31, (changes, diag2) => {
+            const nodes = getNodes(diag2.file, diag2.start);
+            if (!nodes)
+              return;
+            const { constructor, superCall } = nodes;
+            if (addToSeen(seenClasses, getNodeId(constructor.parent))) {
+              doChange19(changes, sourceFile, constructor, superCall);
+            }
+          });
+        }
+      });
     }
-    return statements;
+  });
+
+  // src/services/codefixes/fixConstructorForDerivedNeedSuperCall.ts
+  function getNode(sourceFile, pos) {
+    const token = getTokenAtPosition(sourceFile, pos);
+    Debug.assert(isConstructorDeclaration(token.parent), "token should be at the constructor declaration");
+    return token.parent;
   }
-  function transformFinally(node, onFinally, transformer, hasContinuation, continuationArgName) {
-    if (!onFinally || isNullOrUndefined2(transformer, onFinally)) {
-      return transformExpression(
-        /* returnContextNode */
-        node,
-        node.expression.expression,
-        transformer,
-        hasContinuation,
-        continuationArgName
-      );
-    }
-    const possibleNameForVarDecl = getPossibleNameForVarDecl(node, transformer, continuationArgName);
-    const inlinedLeftHandSide = transformExpression(
-      /*returnContextNode*/
-      node,
-      node.expression.expression,
-      transformer,
-      /*hasContinuation*/
-      true,
-      possibleNameForVarDecl
-    );
-    if (hasFailed())
-      return silentFail();
-    const inlinedCallback = transformCallbackArgument(
-      onFinally,
-      hasContinuation,
-      /*continuationArgName*/
-      void 0,
-      /*inputArgName*/
-      void 0,
-      node,
-      transformer
-    );
-    if (hasFailed())
-      return silentFail();
-    const tryBlock = factory.createBlock(inlinedLeftHandSide);
-    const finallyBlock = factory.createBlock(inlinedCallback);
-    const tryStatement = factory.createTryStatement(
-      tryBlock,
-      /*catchClause*/
+  function doChange20(changes, sourceFile, ctr) {
+    const superCall = factory.createExpressionStatement(factory.createCallExpression(
+      factory.createSuper(),
+      /*typeArguments*/
       void 0,
-      finallyBlock
-    );
-    return finishCatchOrFinallyTransform(node, transformer, tryStatement, possibleNameForVarDecl, continuationArgName);
+      /*argumentsArray*/
+      emptyArray
+    ));
+    changes.insertNodeAtConstructorStart(sourceFile, ctr, superCall);
   }
-  function transformCatch(node, onRejected, transformer, hasContinuation, continuationArgName) {
-    if (!onRejected || isNullOrUndefined2(transformer, onRejected)) {
-      return transformExpression(
-        /* returnContextNode */
-        node,
-        node.expression.expression,
-        transformer,
-        hasContinuation,
-        continuationArgName
-      );
+  var fixId27, errorCodes32;
+  var init_fixConstructorForDerivedNeedSuperCall = __esm({
+    "src/services/codefixes/fixConstructorForDerivedNeedSuperCall.ts"() {
+      "use strict";
+      init_ts4();
+      init_ts_codefix();
+      fixId27 = "constructorForDerivedNeedSuperCall";
+      errorCodes32 = [Diagnostics.Constructors_for_derived_classes_must_contain_a_super_call.code];
+      registerCodeFix({
+        errorCodes: errorCodes32,
+        getCodeActions(context) {
+          const { sourceFile, span } = context;
+          const ctr = getNode(sourceFile, span.start);
+          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange20(t, sourceFile, ctr));
+          return [createCodeFixAction(fixId27, changes, Diagnostics.Add_missing_super_call, fixId27, Diagnostics.Add_all_missing_super_calls)];
+        },
+        fixIds: [fixId27],
+        getAllCodeActions: (context) => codeFixAll(context, errorCodes32, (changes, diag2) => doChange20(changes, context.sourceFile, getNode(diag2.file, diag2.start)))
+      });
     }
-    const inputArgName = getArgBindingName(onRejected, transformer);
-    const possibleNameForVarDecl = getPossibleNameForVarDecl(node, transformer, continuationArgName);
-    const inlinedLeftHandSide = transformExpression(
-      /*returnContextNode*/
-      node,
-      node.expression.expression,
-      transformer,
-      /*hasContinuation*/
-      true,
-      possibleNameForVarDecl
-    );
-    if (hasFailed())
-      return silentFail();
-    const inlinedCallback = transformCallbackArgument(onRejected, hasContinuation, possibleNameForVarDecl, inputArgName, node, transformer);
-    if (hasFailed())
-      return silentFail();
-    const tryBlock = factory.createBlock(inlinedLeftHandSide);
-    const catchClause = factory.createCatchClause(inputArgName && getSynthesizedDeepClone(declareSynthBindingName(inputArgName)), factory.createBlock(inlinedCallback));
-    const tryStatement = factory.createTryStatement(
-      tryBlock,
-      catchClause,
-      /*finallyBlock*/
-      void 0
-    );
-    return finishCatchOrFinallyTransform(node, transformer, tryStatement, possibleNameForVarDecl, continuationArgName);
+  });
+
+  // src/services/codefixes/fixEnableJsxFlag.ts
+  function doChange21(changeTracker, configFile) {
+    setJsonCompilerOptionValue(changeTracker, configFile, "jsx", factory.createStringLiteral("react"));
   }
-  function transformThen(node, onFulfilled, onRejected, transformer, hasContinuation, continuationArgName) {
-    if (!onFulfilled || isNullOrUndefined2(transformer, onFulfilled)) {
-      return transformCatch(node, onRejected, transformer, hasContinuation, continuationArgName);
+  var fixID, errorCodes33;
+  var init_fixEnableJsxFlag = __esm({
+    "src/services/codefixes/fixEnableJsxFlag.ts"() {
+      "use strict";
+      init_ts4();
+      init_ts_codefix();
+      fixID = "fixEnableJsxFlag";
+      errorCodes33 = [Diagnostics.Cannot_use_JSX_unless_the_jsx_flag_is_provided.code];
+      registerCodeFix({
+        errorCodes: errorCodes33,
+        getCodeActions: function getCodeActionsToFixEnableJsxFlag(context) {
+          const { configFile } = context.program.getCompilerOptions();
+          if (configFile === void 0) {
+            return void 0;
+          }
+          const changes = ts_textChanges_exports.ChangeTracker.with(context, (changeTracker) => doChange21(changeTracker, configFile));
+          return [
+            createCodeFixActionWithoutFixAll(fixID, changes, Diagnostics.Enable_the_jsx_flag_in_your_configuration_file)
+          ];
+        },
+        fixIds: [fixID],
+        getAllCodeActions: (context) => codeFixAll(context, errorCodes33, (changes) => {
+          const { configFile } = context.program.getCompilerOptions();
+          if (configFile === void 0) {
+            return void 0;
+          }
+          doChange21(changes, configFile);
+        })
+      });
     }
-    if (onRejected && !isNullOrUndefined2(transformer, onRejected)) {
-      return silentFail();
+  });
+
+  // src/services/codefixes/fixNaNEquality.ts
+  function getInfo11(program, sourceFile, span) {
+    const diag2 = find(program.getSemanticDiagnostics(sourceFile), (diag3) => diag3.start === span.start && diag3.length === span.length);
+    if (diag2 === void 0 || diag2.relatedInformation === void 0)
+      return;
+    const related = find(diag2.relatedInformation, (related2) => related2.code === Diagnostics.Did_you_mean_0.code);
+    if (related === void 0 || related.file === void 0 || related.start === void 0 || related.length === void 0)
+      return;
+    const token = findAncestorMatchingSpan(related.file, createTextSpan(related.start, related.length));
+    if (token === void 0)
+      return;
+    if (isExpression(token) && isBinaryExpression(token.parent)) {
+      return { suggestion: getSuggestion(related.messageText), expression: token.parent, arg: token };
     }
-    const inputArgName = getArgBindingName(onFulfilled, transformer);
-    const inlinedLeftHandSide = transformExpression(
-      node.expression.expression,
-      node.expression.expression,
-      transformer,
-      /*hasContinuation*/
-      true,
-      inputArgName
-    );
-    if (hasFailed())
-      return silentFail();
-    const inlinedCallback = transformCallbackArgument(onFulfilled, hasContinuation, continuationArgName, inputArgName, node, transformer);
-    if (hasFailed())
-      return silentFail();
-    return concatenate(inlinedLeftHandSide, inlinedCallback);
+    return void 0;
   }
-  function transformPromiseExpressionOfPropertyAccess(returnContextNode, node, transformer, hasContinuation, continuationArgName) {
-    if (shouldReturn(returnContextNode, transformer)) {
-      let returnValue = getSynthesizedDeepClone(node);
-      if (hasContinuation) {
-        returnValue = factory.createAwaitExpression(returnValue);
-      }
-      return [factory.createReturnStatement(returnValue)];
-    }
-    return createVariableOrAssignmentOrExpressionStatement(
-      continuationArgName,
-      factory.createAwaitExpression(node),
-      /*typeAnnotation*/
-      void 0
+  function doChange22(changes, sourceFile, arg, expression) {
+    const callExpression = factory.createCallExpression(
+      factory.createPropertyAccessExpression(factory.createIdentifier("Number"), factory.createIdentifier("isNaN")),
+      /*typeArguments*/
+      void 0,
+      [arg]
+    );
+    const operator = expression.operatorToken.kind;
+    changes.replaceNode(
+      sourceFile,
+      expression,
+      operator === 38 /* ExclamationEqualsEqualsToken */ || operator === 36 /* ExclamationEqualsToken */ ? factory.createPrefixUnaryExpression(54 /* ExclamationToken */, callExpression) : callExpression
     );
   }
-  function createVariableOrAssignmentOrExpressionStatement(variableName, rightHandSide, typeAnnotation) {
-    if (!variableName || isEmptyBindingName(variableName)) {
-      return [factory.createExpressionStatement(rightHandSide)];
-    }
-    if (isSynthIdentifier(variableName) && variableName.hasBeenDeclared) {
-      return [factory.createExpressionStatement(factory.createAssignment(getSynthesizedDeepClone(referenceSynthIdentifier(variableName)), rightHandSide))];
-    }
-    return [
-      factory.createVariableStatement(
-        /*modifiers*/
-        void 0,
-        factory.createVariableDeclarationList(
-          [
-            factory.createVariableDeclaration(
-              getSynthesizedDeepClone(declareSynthBindingName(variableName)),
-              /*exclamationToken*/
-              void 0,
-              typeAnnotation,
-              rightHandSide
-            )
-          ],
-          2 /* Const */
-        )
-      )
-    ];
+  function getSuggestion(messageText) {
+    const [_, suggestion] = flattenDiagnosticMessageText(messageText, "\n", 0).match(/'(.*)'/) || [];
+    return suggestion;
   }
-  function maybeAnnotateAndReturn(expressionToReturn, typeAnnotation) {
-    if (typeAnnotation && expressionToReturn) {
-      const name = factory.createUniqueName("result", 16 /* Optimistic */);
-      return [
-        ...createVariableOrAssignmentOrExpressionStatement(createSynthIdentifier(name), expressionToReturn, typeAnnotation),
-        factory.createReturnStatement(name)
+  var fixId28, errorCodes34;
+  var init_fixNaNEquality = __esm({
+    "src/services/codefixes/fixNaNEquality.ts"() {
+      "use strict";
+      init_ts4();
+      init_ts_codefix();
+      fixId28 = "fixNaNEquality";
+      errorCodes34 = [
+        Diagnostics.This_condition_will_always_return_0.code
       ];
-    }
-    return [factory.createReturnStatement(expressionToReturn)];
-  }
-  function transformCallbackArgument(func, hasContinuation, continuationArgName, inputArgName, parent2, transformer) {
-    var _a;
-    switch (func.kind) {
-      case 106 /* NullKeyword */:
-        break;
-      case 210 /* PropertyAccessExpression */:
-      case 80 /* Identifier */:
-        if (!inputArgName) {
-          break;
-        }
-        const synthCall = factory.createCallExpression(
-          getSynthesizedDeepClone(func),
-          /*typeArguments*/
-          void 0,
-          isSynthIdentifier(inputArgName) ? [referenceSynthIdentifier(inputArgName)] : []
-        );
-        if (shouldReturn(parent2, transformer)) {
-          return maybeAnnotateAndReturn(synthCall, getExplicitPromisedTypeOfPromiseReturningCallExpression(parent2, func, transformer.checker));
-        }
-        const type = transformer.checker.getTypeAtLocation(func);
-        const callSignatures = transformer.checker.getSignaturesOfType(type, 0 /* Call */);
-        if (!callSignatures.length) {
-          return silentFail();
-        }
-        const returnType = callSignatures[0].getReturnType();
-        const varDeclOrAssignment = createVariableOrAssignmentOrExpressionStatement(continuationArgName, factory.createAwaitExpression(synthCall), getExplicitPromisedTypeOfPromiseReturningCallExpression(parent2, func, transformer.checker));
-        if (continuationArgName) {
-          continuationArgName.types.push(transformer.checker.getAwaitedType(returnType) || returnType);
-        }
-        return varDeclOrAssignment;
-      case 217 /* FunctionExpression */:
-      case 218 /* ArrowFunction */: {
-        const funcBody = func.body;
-        const returnType2 = (_a = getLastCallSignature(transformer.checker.getTypeAtLocation(func), transformer.checker)) == null ? void 0 : _a.getReturnType();
-        if (isBlock(funcBody)) {
-          let refactoredStmts = [];
-          let seenReturnStatement = false;
-          for (const statement of funcBody.statements) {
-            if (isReturnStatement(statement)) {
-              seenReturnStatement = true;
-              if (isReturnStatementWithFixablePromiseHandler(statement, transformer.checker)) {
-                refactoredStmts = refactoredStmts.concat(transformReturnStatementWithFixablePromiseHandler(transformer, statement, hasContinuation, continuationArgName));
-              } else {
-                const possiblyAwaitedRightHandSide = returnType2 && statement.expression ? getPossiblyAwaitedRightHandSide(transformer.checker, returnType2, statement.expression) : statement.expression;
-                refactoredStmts.push(...maybeAnnotateAndReturn(possiblyAwaitedRightHandSide, getExplicitPromisedTypeOfPromiseReturningCallExpression(parent2, func, transformer.checker)));
-              }
-            } else if (hasContinuation && forEachReturnStatement(statement, returnTrue)) {
-              return silentFail();
-            } else {
-              refactoredStmts.push(statement);
+      registerCodeFix({
+        errorCodes: errorCodes34,
+        getCodeActions(context) {
+          const { sourceFile, span, program } = context;
+          const info = getInfo11(program, sourceFile, span);
+          if (info === void 0)
+            return;
+          const { suggestion, expression, arg } = info;
+          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange22(t, sourceFile, arg, expression));
+          return [createCodeFixAction(fixId28, changes, [Diagnostics.Use_0, suggestion], fixId28, Diagnostics.Use_Number_isNaN_in_all_conditions)];
+        },
+        fixIds: [fixId28],
+        getAllCodeActions: (context) => {
+          return codeFixAll(context, errorCodes34, (changes, diag2) => {
+            const info = getInfo11(context.program, diag2.file, createTextSpan(diag2.start, diag2.length));
+            if (info) {
+              doChange22(changes, diag2.file, info.arg, info.expression);
             }
+          });
+        }
+      });
+    }
+  });
+
+  // src/services/codefixes/fixModuleAndTargetOptions.ts
+  var init_fixModuleAndTargetOptions = __esm({
+    "src/services/codefixes/fixModuleAndTargetOptions.ts"() {
+      "use strict";
+      init_ts4();
+      init_ts_codefix();
+      registerCodeFix({
+        errorCodes: [
+          Diagnostics.Top_level_await_expressions_are_only_allowed_when_the_module_option_is_set_to_es2022_esnext_system_node16_or_nodenext_and_the_target_option_is_set_to_es2017_or_higher.code,
+          Diagnostics.Top_level_await_using_statements_are_only_allowed_when_the_module_option_is_set_to_es2022_esnext_system_node16_or_nodenext_and_the_target_option_is_set_to_es2017_or_higher.code,
+          Diagnostics.Top_level_for_await_loops_are_only_allowed_when_the_module_option_is_set_to_es2022_esnext_system_node16_or_nodenext_and_the_target_option_is_set_to_es2017_or_higher.code
+        ],
+        getCodeActions: function getCodeActionsToFixModuleAndTarget(context) {
+          const compilerOptions = context.program.getCompilerOptions();
+          const { configFile } = compilerOptions;
+          if (configFile === void 0) {
+            return void 0;
           }
-          return shouldReturn(parent2, transformer) ? refactoredStmts.map((s) => getSynthesizedDeepClone(s)) : removeReturns(
-            refactoredStmts,
-            continuationArgName,
-            transformer,
-            seenReturnStatement
-          );
-        } else {
-          const inlinedStatements = isFixablePromiseHandler(funcBody, transformer.checker) ? transformReturnStatementWithFixablePromiseHandler(transformer, factory.createReturnStatement(funcBody), hasContinuation, continuationArgName) : emptyArray;
-          if (inlinedStatements.length > 0) {
-            return inlinedStatements;
+          const codeFixes = [];
+          const moduleKind = getEmitModuleKind(compilerOptions);
+          const moduleOutOfRange = moduleKind >= 5 /* ES2015 */ && moduleKind < 99 /* ESNext */;
+          if (moduleOutOfRange) {
+            const changes = ts_textChanges_exports.ChangeTracker.with(context, (changes2) => {
+              setJsonCompilerOptionValue(changes2, configFile, "module", factory.createStringLiteral("esnext"));
+            });
+            codeFixes.push(createCodeFixActionWithoutFixAll("fixModuleOption", changes, [Diagnostics.Set_the_module_option_in_your_configuration_file_to_0, "esnext"]));
           }
-          if (returnType2) {
-            const possiblyAwaitedRightHandSide = getPossiblyAwaitedRightHandSide(transformer.checker, returnType2, funcBody);
-            if (!shouldReturn(parent2, transformer)) {
-              const transformedStatement = createVariableOrAssignmentOrExpressionStatement(
-                continuationArgName,
-                possiblyAwaitedRightHandSide,
-                /*typeAnnotation*/
-                void 0
-              );
-              if (continuationArgName) {
-                continuationArgName.types.push(transformer.checker.getAwaitedType(returnType2) || returnType2);
+          const target = getEmitScriptTarget(compilerOptions);
+          const targetOutOfRange = target < 4 /* ES2017 */ || target > 99 /* ESNext */;
+          if (targetOutOfRange) {
+            const changes = ts_textChanges_exports.ChangeTracker.with(context, (tracker) => {
+              const configObject = getTsConfigObjectLiteralExpression(configFile);
+              if (!configObject)
+                return;
+              const options = [["target", factory.createStringLiteral("es2017")]];
+              if (moduleKind === 1 /* CommonJS */) {
+                options.push(["module", factory.createStringLiteral("commonjs")]);
               }
-              return transformedStatement;
-            } else {
-              return maybeAnnotateAndReturn(possiblyAwaitedRightHandSide, getExplicitPromisedTypeOfPromiseReturningCallExpression(parent2, func, transformer.checker));
-            }
-          } else {
-            return silentFail();
-          }
-        }
-      }
-      default:
-        return silentFail();
-    }
-    return emptyArray;
-  }
-  function getPossiblyAwaitedRightHandSide(checker, type, expr) {
-    const rightHandSide = getSynthesizedDeepClone(expr);
-    return !!checker.getPromisedTypeOfPromise(type) ? factory.createAwaitExpression(rightHandSide) : rightHandSide;
-  }
-  function getLastCallSignature(type, checker) {
-    const callSignatures = checker.getSignaturesOfType(type, 0 /* Call */);
-    return lastOrUndefined(callSignatures);
-  }
-  function removeReturns(stmts, prevArgName, transformer, seenReturnStatement) {
-    const ret = [];
-    for (const stmt of stmts) {
-      if (isReturnStatement(stmt)) {
-        if (stmt.expression) {
-          const possiblyAwaitedExpression = isPromiseTypedExpression(stmt.expression, transformer.checker) ? factory.createAwaitExpression(stmt.expression) : stmt.expression;
-          if (prevArgName === void 0) {
-            ret.push(factory.createExpressionStatement(possiblyAwaitedExpression));
-          } else if (isSynthIdentifier(prevArgName) && prevArgName.hasBeenDeclared) {
-            ret.push(factory.createExpressionStatement(factory.createAssignment(referenceSynthIdentifier(prevArgName), possiblyAwaitedExpression)));
-          } else {
-            ret.push(factory.createVariableStatement(
-              /*modifiers*/
-              void 0,
-              factory.createVariableDeclarationList([factory.createVariableDeclaration(
-                declareSynthBindingName(prevArgName),
-                /*exclamationToken*/
-                void 0,
-                /*type*/
-                void 0,
-                possiblyAwaitedExpression
-              )], 2 /* Const */)
-            ));
+              setJsonCompilerOptionValues(tracker, configFile, options);
+            });
+            codeFixes.push(createCodeFixActionWithoutFixAll("fixTargetOption", changes, [Diagnostics.Set_the_target_option_in_your_configuration_file_to_0, "es2017"]));
           }
+          return codeFixes.length ? codeFixes : void 0;
         }
-      } else {
-        ret.push(getSynthesizedDeepClone(stmt));
-      }
-    }
-    if (!seenReturnStatement && prevArgName !== void 0) {
-      ret.push(factory.createVariableStatement(
-        /*modifiers*/
-        void 0,
-        factory.createVariableDeclarationList([factory.createVariableDeclaration(
-          declareSynthBindingName(prevArgName),
-          /*exclamationToken*/
-          void 0,
-          /*type*/
-          void 0,
-          factory.createIdentifier("undefined")
-        )], 2 /* Const */)
-      ));
+      });
     }
-    return ret;
+  });
+
+  // src/services/codefixes/fixPropertyAssignment.ts
+  function doChange23(changes, sourceFile, node) {
+    changes.replaceNode(sourceFile, node, factory.createPropertyAssignment(node.name, node.objectAssignmentInitializer));
   }
-  function transformReturnStatementWithFixablePromiseHandler(transformer, innerRetStmt, hasContinuation, continuationArgName) {
-    let innerCbBody = [];
-    forEachChild(innerRetStmt, function visit(node) {
-      if (isCallExpression(node)) {
-        const temp = transformExpression(node, node, transformer, hasContinuation, continuationArgName);
-        innerCbBody = innerCbBody.concat(temp);
-        if (innerCbBody.length > 0) {
-          return;
-        }
-      } else if (!isFunctionLike(node)) {
-        forEachChild(node, visit);
-      }
-    });
-    return innerCbBody;
+  function getProperty2(sourceFile, pos) {
+    return cast(getTokenAtPosition(sourceFile, pos).parent, isShorthandPropertyAssignment);
   }
-  function getArgBindingName(funcNode, transformer) {
-    const types = [];
-    let name;
-    if (isFunctionLikeDeclaration(funcNode)) {
-      if (funcNode.parameters.length > 0) {
-        const param = funcNode.parameters[0].name;
-        name = getMappedBindingNameOrDefault(param);
-      }
-    } else if (isIdentifier(funcNode)) {
-      name = getMapEntryOrDefault(funcNode);
-    } else if (isPropertyAccessExpression(funcNode) && isIdentifier(funcNode.name)) {
-      name = getMapEntryOrDefault(funcNode.name);
-    }
-    if (!name || "identifier" in name && name.identifier.text === "undefined") {
-      return void 0;
-    }
-    return name;
-    function getMappedBindingNameOrDefault(bindingName) {
-      if (isIdentifier(bindingName))
-        return getMapEntryOrDefault(bindingName);
-      const elements = flatMap(bindingName.elements, (element) => {
-        if (isOmittedExpression(element))
-          return [];
-        return [getMappedBindingNameOrDefault(element.name)];
+  var fixId29, errorCodes35;
+  var init_fixPropertyAssignment = __esm({
+    "src/services/codefixes/fixPropertyAssignment.ts"() {
+      "use strict";
+      init_ts4();
+      init_ts_codefix();
+      fixId29 = "fixPropertyAssignment";
+      errorCodes35 = [
+        Diagnostics.Did_you_mean_to_use_a_Colon_An_can_only_follow_a_property_name_when_the_containing_object_literal_is_part_of_a_destructuring_pattern.code
+      ];
+      registerCodeFix({
+        errorCodes: errorCodes35,
+        fixIds: [fixId29],
+        getCodeActions(context) {
+          const { sourceFile, span } = context;
+          const property = getProperty2(sourceFile, span.start);
+          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange23(t, context.sourceFile, property));
+          return [createCodeFixAction(fixId29, changes, [Diagnostics.Change_0_to_1, "=", ":"], fixId29, [Diagnostics.Switch_each_misused_0_to_1, "=", ":"])];
+        },
+        getAllCodeActions: (context) => codeFixAll(context, errorCodes35, (changes, diag2) => doChange23(changes, diag2.file, getProperty2(diag2.file, diag2.start)))
       });
-      return createSynthBindingPattern(bindingName, elements);
     }
-    function getMapEntryOrDefault(identifier) {
-      const originalNode = getOriginalNode2(identifier);
-      const symbol = getSymbol2(originalNode);
-      if (!symbol) {
-        return createSynthIdentifier(identifier, types);
+  });
+
+  // src/services/codefixes/fixExtendsInterfaceBecomesImplements.ts
+  function getNodes2(sourceFile, pos) {
+    const token = getTokenAtPosition(sourceFile, pos);
+    const heritageClauses = getContainingClass(token).heritageClauses;
+    const extendsToken = heritageClauses[0].getFirstToken();
+    return extendsToken.kind === 96 /* ExtendsKeyword */ ? { extendsToken, heritageClauses } : void 0;
+  }
+  function doChanges2(changes, sourceFile, extendsToken, heritageClauses) {
+    changes.replaceNode(sourceFile, extendsToken, factory.createToken(119 /* ImplementsKeyword */));
+    if (heritageClauses.length === 2 && heritageClauses[0].token === 96 /* ExtendsKeyword */ && heritageClauses[1].token === 119 /* ImplementsKeyword */) {
+      const implementsToken = heritageClauses[1].getFirstToken();
+      const implementsFullStart = implementsToken.getFullStart();
+      changes.replaceRange(sourceFile, { pos: implementsFullStart, end: implementsFullStart }, factory.createToken(28 /* CommaToken */));
+      const text = sourceFile.text;
+      let end = implementsToken.end;
+      while (end < text.length && isWhiteSpaceSingleLine(text.charCodeAt(end))) {
+        end++;
       }
-      const mapEntry = transformer.synthNamesMap.get(getSymbolId(symbol).toString());
-      return mapEntry || createSynthIdentifier(identifier, types);
-    }
-    function getSymbol2(node) {
-      var _a;
-      return ((_a = tryCast(node, canHaveSymbol)) == null ? void 0 : _a.symbol) ?? transformer.checker.getSymbolAtLocation(node);
-    }
-    function getOriginalNode2(node) {
-      return node.original ? node.original : node;
+      changes.deleteRange(sourceFile, { pos: implementsToken.getStart(), end });
     }
   }
-  function isEmptyBindingName(bindingName) {
-    if (!bindingName) {
-      return true;
+  var fixId30, errorCodes36;
+  var init_fixExtendsInterfaceBecomesImplements = __esm({
+    "src/services/codefixes/fixExtendsInterfaceBecomesImplements.ts"() {
+      "use strict";
+      init_ts4();
+      init_ts_codefix();
+      fixId30 = "extendsInterfaceBecomesImplements";
+      errorCodes36 = [Diagnostics.Cannot_extend_an_interface_0_Did_you_mean_implements.code];
+      registerCodeFix({
+        errorCodes: errorCodes36,
+        getCodeActions(context) {
+          const { sourceFile } = context;
+          const nodes = getNodes2(sourceFile, context.span.start);
+          if (!nodes)
+            return void 0;
+          const { extendsToken, heritageClauses } = nodes;
+          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChanges2(t, sourceFile, extendsToken, heritageClauses));
+          return [createCodeFixAction(fixId30, changes, Diagnostics.Change_extends_to_implements, fixId30, Diagnostics.Change_all_extended_interfaces_to_implements)];
+        },
+        fixIds: [fixId30],
+        getAllCodeActions: (context) => codeFixAll(context, errorCodes36, (changes, diag2) => {
+          const nodes = getNodes2(diag2.file, diag2.start);
+          if (nodes)
+            doChanges2(changes, diag2.file, nodes.extendsToken, nodes.heritageClauses);
+        })
+      });
     }
-    if (isSynthIdentifier(bindingName)) {
-      return !bindingName.identifier.text;
+  });
+
+  // src/services/codefixes/fixForgottenThisPropertyAccess.ts
+  function getInfo12(sourceFile, pos, diagCode) {
+    const node = getTokenAtPosition(sourceFile, pos);
+    if (isIdentifier(node) || isPrivateIdentifier(node)) {
+      return { node, className: diagCode === didYouMeanStaticMemberCode ? getContainingClass(node).name.text : void 0 };
     }
-    return every(bindingName.elements, isEmptyBindingName);
-  }
-  function createSynthIdentifier(identifier, types = []) {
-    return { kind: 0 /* Identifier */, identifier, types, hasBeenDeclared: false, hasBeenReferenced: false };
-  }
-  function createSynthBindingPattern(bindingPattern, elements = emptyArray, types = []) {
-    return { kind: 1 /* BindingPattern */, bindingPattern, elements, types };
   }
-  function referenceSynthIdentifier(synthId) {
-    synthId.hasBeenReferenced = true;
-    return synthId.identifier;
-  }
-  function declareSynthBindingName(synthName) {
-    return isSynthIdentifier(synthName) ? declareSynthIdentifier(synthName) : declareSynthBindingPattern(synthName);
+  function doChange24(changes, sourceFile, { node, className }) {
+    suppressLeadingAndTrailingTrivia(node);
+    changes.replaceNode(sourceFile, node, factory.createPropertyAccessExpression(className ? factory.createIdentifier(className) : factory.createThis(), node));
   }
-  function declareSynthBindingPattern(synthPattern) {
-    for (const element of synthPattern.elements) {
-      declareSynthBindingName(element);
+  var fixId31, didYouMeanStaticMemberCode, errorCodes37;
+  var init_fixForgottenThisPropertyAccess = __esm({
+    "src/services/codefixes/fixForgottenThisPropertyAccess.ts"() {
+      "use strict";
+      init_ts4();
+      init_ts_codefix();
+      fixId31 = "forgottenThisPropertyAccess";
+      didYouMeanStaticMemberCode = Diagnostics.Cannot_find_name_0_Did_you_mean_the_static_member_1_0.code;
+      errorCodes37 = [
+        Diagnostics.Cannot_find_name_0_Did_you_mean_the_instance_member_this_0.code,
+        Diagnostics.Private_identifiers_are_only_allowed_in_class_bodies_and_may_only_be_used_as_part_of_a_class_member_declaration_property_access_or_on_the_left_hand_side_of_an_in_expression.code,
+        didYouMeanStaticMemberCode
+      ];
+      registerCodeFix({
+        errorCodes: errorCodes37,
+        getCodeActions(context) {
+          const { sourceFile } = context;
+          const info = getInfo12(sourceFile, context.span.start, context.errorCode);
+          if (!info) {
+            return void 0;
+          }
+          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange24(t, sourceFile, info));
+          return [createCodeFixAction(fixId31, changes, [Diagnostics.Add_0_to_unresolved_variable, info.className || "this"], fixId31, Diagnostics.Add_qualifier_to_all_unresolved_variables_matching_a_member_name)];
+        },
+        fixIds: [fixId31],
+        getAllCodeActions: (context) => codeFixAll(context, errorCodes37, (changes, diag2) => {
+          const info = getInfo12(diag2.file, diag2.start, diag2.code);
+          if (info)
+            doChange24(changes, context.sourceFile, info);
+        })
+      });
     }
-    return synthPattern.bindingPattern;
-  }
-  function declareSynthIdentifier(synthId) {
-    synthId.hasBeenDeclared = true;
-    return synthId.identifier;
-  }
-  function isSynthIdentifier(bindingName) {
-    return bindingName.kind === 0 /* Identifier */;
-  }
-  function isSynthBindingPattern(bindingName) {
-    return bindingName.kind === 1 /* BindingPattern */;
+  });
+
+  // src/services/codefixes/fixInvalidJsxCharacters.ts
+  function isValidCharacter(character) {
+    return hasProperty(htmlEntity, character);
   }
-  function shouldReturn(expression, transformer) {
-    return !!expression.original && transformer.setOfExpressionsToReturn.has(getNodeId(expression.original));
+  function doChange25(changes, preferences, sourceFile, start, useHtmlEntity) {
+    const character = sourceFile.getText()[start];
+    if (!isValidCharacter(character)) {
+      return;
+    }
+    const replacement = useHtmlEntity ? htmlEntity[character] : `{${quote(sourceFile, preferences, character)}}`;
+    changes.replaceRangeWithText(sourceFile, { pos: start, end: start + 1 }, replacement);
   }
-  var fixId10, errorCodes11, codeActionSucceeded;
-  var init_convertToAsyncFunction = __esm({
-    "src/services/codefixes/convertToAsyncFunction.ts"() {
+  var fixIdExpression, fixIdHtmlEntity, errorCodes38, htmlEntity;
+  var init_fixInvalidJsxCharacters = __esm({
+    "src/services/codefixes/fixInvalidJsxCharacters.ts"() {
       "use strict";
       init_ts4();
       init_ts_codefix();
-      fixId10 = "convertToAsyncFunction";
-      errorCodes11 = [Diagnostics.This_may_be_converted_to_an_async_function.code];
-      codeActionSucceeded = true;
+      fixIdExpression = "fixInvalidJsxCharacters_expression";
+      fixIdHtmlEntity = "fixInvalidJsxCharacters_htmlEntity";
+      errorCodes38 = [
+        Diagnostics.Unexpected_token_Did_you_mean_or_gt.code,
+        Diagnostics.Unexpected_token_Did_you_mean_or_rbrace.code
+      ];
       registerCodeFix({
-        errorCodes: errorCodes11,
+        errorCodes: errorCodes38,
+        fixIds: [fixIdExpression, fixIdHtmlEntity],
         getCodeActions(context) {
-          codeActionSucceeded = true;
-          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => convertToAsyncFunction(t, context.sourceFile, context.span.start, context.program.getTypeChecker()));
-          return codeActionSucceeded ? [createCodeFixAction(fixId10, changes, Diagnostics.Convert_to_async_function, fixId10, Diagnostics.Convert_all_to_async_functions)] : [];
+          const { sourceFile, preferences, span } = context;
+          const changeToExpression = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange25(
+            t,
+            preferences,
+            sourceFile,
+            span.start,
+            /*useHtmlEntity*/
+            false
+          ));
+          const changeToHtmlEntity = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange25(
+            t,
+            preferences,
+            sourceFile,
+            span.start,
+            /*useHtmlEntity*/
+            true
+          ));
+          return [
+            createCodeFixAction(fixIdExpression, changeToExpression, Diagnostics.Wrap_invalid_character_in_an_expression_container, fixIdExpression, Diagnostics.Wrap_all_invalid_characters_in_an_expression_container),
+            createCodeFixAction(fixIdHtmlEntity, changeToHtmlEntity, Diagnostics.Convert_invalid_character_to_its_html_entity_code, fixIdHtmlEntity, Diagnostics.Convert_all_invalid_characters_to_HTML_entity_code)
+          ];
         },
-        fixIds: [fixId10],
-        getAllCodeActions: (context) => codeFixAll(context, errorCodes11, (changes, err) => convertToAsyncFunction(changes, err.file, err.start, context.program.getTypeChecker()))
+        getAllCodeActions(context) {
+          return codeFixAll(context, errorCodes38, (changes, diagnostic) => doChange25(changes, context.preferences, diagnostic.file, diagnostic.start, context.fixId === fixIdHtmlEntity));
+        }
       });
+      htmlEntity = {
+        ">": ">",
+        "}": "}"
+      };
     }
   });
 
-  // src/services/codefixes/convertToEsModule.ts
-  function fixImportOfModuleExports(importingFile, exportingFile, changes, quotePreference) {
-    for (const moduleSpecifier of importingFile.imports) {
-      const imported = getResolvedModule(importingFile, moduleSpecifier.text, getModeForUsageLocation(importingFile, moduleSpecifier));
-      if (!imported || imported.resolvedFileName !== exportingFile.fileName) {
-        continue;
-      }
-      const importNode = importFromModuleSpecifier(moduleSpecifier);
-      switch (importNode.kind) {
-        case 270 /* ImportEqualsDeclaration */:
-          changes.replaceNode(importingFile, importNode, makeImport(
-            importNode.name,
-            /*namedImports*/
-            void 0,
-            moduleSpecifier,
-            quotePreference
-          ));
-          break;
-        case 212 /* CallExpression */:
-          if (isRequireCall(
-            importNode,
-            /*requireStringLiteralLikeArgument*/
-            false
-          )) {
-            changes.replaceNode(importingFile, importNode, factory.createPropertyAccessExpression(getSynthesizedDeepClone(importNode), "default"));
-          }
-          break;
-      }
-    }
+  // src/services/codefixes/fixUnmatchedParameter.ts
+  function getDeleteAction(context, { name, jsDocHost, jsDocParameterTag }) {
+    const changes = ts_textChanges_exports.ChangeTracker.with(context, (changeTracker) => changeTracker.filterJSDocTags(context.sourceFile, jsDocHost, (t) => t !== jsDocParameterTag));
+    return createCodeFixAction(
+      deleteUnmatchedParameter,
+      changes,
+      [Diagnostics.Delete_unused_param_tag_0, name.getText(context.sourceFile)],
+      deleteUnmatchedParameter,
+      Diagnostics.Delete_all_unused_param_tags
+    );
   }
-  function convertFileToEsModule(sourceFile, checker, changes, target, quotePreference) {
-    const identifiers = { original: collectFreeIdentifiers(sourceFile), additional: /* @__PURE__ */ new Set() };
-    const exports = collectExportRenames(sourceFile, checker, identifiers);
-    convertExportsAccesses(sourceFile, exports, changes);
-    let moduleExportsChangedToDefault = false;
-    let useSitesToUnqualify;
-    for (const statement of filter(sourceFile.statements, isVariableStatement)) {
-      const newUseSites = convertVariableStatement(sourceFile, statement, changes, checker, identifiers, target, quotePreference);
-      if (newUseSites) {
-        copyEntries(newUseSites, useSitesToUnqualify ?? (useSitesToUnqualify = /* @__PURE__ */ new Map()));
+  function getRenameAction(context, { name, jsDocHost, signature, jsDocParameterTag }) {
+    if (!length(signature.parameters))
+      return void 0;
+    const sourceFile = context.sourceFile;
+    const tags = getJSDocTags(signature);
+    const names = /* @__PURE__ */ new Set();
+    for (const tag of tags) {
+      if (isJSDocParameterTag(tag) && isIdentifier(tag.name)) {
+        names.add(tag.name.escapedText);
       }
     }
-    for (const statement of filter(sourceFile.statements, (s) => !isVariableStatement(s))) {
-      const moduleExportsChanged = convertStatement(sourceFile, statement, checker, changes, identifiers, target, exports, useSitesToUnqualify, quotePreference);
-      moduleExportsChangedToDefault = moduleExportsChangedToDefault || moduleExportsChanged;
-    }
-    useSitesToUnqualify == null ? void 0 : useSitesToUnqualify.forEach((replacement, original) => {
-      changes.replaceNode(sourceFile, original, replacement);
-    });
-    return moduleExportsChangedToDefault;
-  }
-  function collectExportRenames(sourceFile, checker, identifiers) {
-    const res = /* @__PURE__ */ new Map();
-    forEachExportReference(sourceFile, (node) => {
-      const { text } = node.name;
-      if (!res.has(text) && (isIdentifierANonContextualKeyword(node.name) || checker.resolveName(
-        text,
-        node,
-        111551 /* Value */,
-        /*excludeGlobals*/
-        true
-      ))) {
-        res.set(text, makeUniqueName(`_${text}`, identifiers));
-      }
-    });
-    return res;
-  }
-  function convertExportsAccesses(sourceFile, exports, changes) {
-    forEachExportReference(sourceFile, (node, isAssignmentLhs) => {
-      if (isAssignmentLhs) {
-        return;
-      }
-      const { text } = node.name;
-      changes.replaceNode(sourceFile, node, factory.createIdentifier(exports.get(text) || text));
-    });
-  }
-  function forEachExportReference(sourceFile, cb) {
-    sourceFile.forEachChild(function recur(node) {
-      if (isPropertyAccessExpression(node) && isExportsOrModuleExportsOrAlias(sourceFile, node.expression) && isIdentifier(node.name)) {
-        const { parent: parent2 } = node;
-        cb(node, isBinaryExpression(parent2) && parent2.left === node && parent2.operatorToken.kind === 64 /* EqualsToken */);
-      }
-      node.forEachChild(recur);
-    });
+    const parameterName = firstDefined(signature.parameters, (p) => isIdentifier(p.name) && !names.has(p.name.escapedText) ? p.name.getText(sourceFile) : void 0);
+    if (parameterName === void 0)
+      return void 0;
+    const newJSDocParameterTag = factory.updateJSDocParameterTag(
+      jsDocParameterTag,
+      jsDocParameterTag.tagName,
+      factory.createIdentifier(parameterName),
+      jsDocParameterTag.isBracketed,
+      jsDocParameterTag.typeExpression,
+      jsDocParameterTag.isNameFirst,
+      jsDocParameterTag.comment
+    );
+    const changes = ts_textChanges_exports.ChangeTracker.with(context, (changeTracker) => changeTracker.replaceJSDocComment(sourceFile, jsDocHost, map(tags, (t) => t === jsDocParameterTag ? newJSDocParameterTag : t)));
+    return createCodeFixActionWithoutFixAll(renameUnmatchedParameter, changes, [Diagnostics.Rename_param_tag_name_0_to_1, name.getText(sourceFile), parameterName]);
   }
-  function convertStatement(sourceFile, statement, checker, changes, identifiers, target, exports, useSitesToUnqualify, quotePreference) {
-    switch (statement.kind) {
-      case 242 /* VariableStatement */:
-        convertVariableStatement(sourceFile, statement, changes, checker, identifiers, target, quotePreference);
-        return false;
-      case 243 /* ExpressionStatement */: {
-        const { expression } = statement;
-        switch (expression.kind) {
-          case 212 /* CallExpression */: {
-            if (isRequireCall(
-              expression,
-              /*requireStringLiteralLikeArgument*/
-              true
-            )) {
-              changes.replaceNode(sourceFile, statement, makeImport(
-                /*defaultImport*/
-                void 0,
-                /*namedImports*/
-                void 0,
-                expression.arguments[0],
-                quotePreference
-              ));
-            }
-            return false;
-          }
-          case 225 /* BinaryExpression */: {
-            const { operatorToken } = expression;
-            return operatorToken.kind === 64 /* EqualsToken */ && convertAssignment(sourceFile, checker, expression, changes, exports, useSitesToUnqualify);
-          }
-        }
+  function getInfo13(sourceFile, pos) {
+    const token = getTokenAtPosition(sourceFile, pos);
+    if (token.parent && isJSDocParameterTag(token.parent) && isIdentifier(token.parent.name)) {
+      const jsDocParameterTag = token.parent;
+      const jsDocHost = getJSDocHost(jsDocParameterTag);
+      const signature = getHostSignatureFromJSDoc(jsDocParameterTag);
+      if (jsDocHost && signature) {
+        return { jsDocHost, signature, name: token.parent.name, jsDocParameterTag };
       }
-      default:
-        return false;
     }
+    return void 0;
   }
-  function convertVariableStatement(sourceFile, statement, changes, checker, identifiers, target, quotePreference) {
-    const { declarationList } = statement;
-    let foundImport = false;
-    const converted = map(declarationList.declarations, (decl) => {
-      const { name, initializer } = decl;
-      if (initializer) {
-        if (isExportsOrModuleExportsOrAlias(sourceFile, initializer)) {
-          foundImport = true;
-          return convertedImports([]);
-        } else if (isRequireCall(
-          initializer,
-          /*requireStringLiteralLikeArgument*/
-          true
-        )) {
-          foundImport = true;
-          return convertSingleImport(name, initializer.arguments[0], checker, identifiers, target, quotePreference);
-        } else if (isPropertyAccessExpression(initializer) && isRequireCall(
-          initializer.expression,
-          /*requireStringLiteralLikeArgument*/
-          true
-        )) {
-          foundImport = true;
-          return convertPropertyAccessImport(name, initializer.name.text, initializer.expression.arguments[0], identifiers, quotePreference);
-        }
-      }
-      return convertedImports([factory.createVariableStatement(
-        /*modifiers*/
-        void 0,
-        factory.createVariableDeclarationList([decl], declarationList.flags)
-      )]);
-    });
-    if (foundImport) {
-      changes.replaceNodeWithNodes(sourceFile, statement, flatMap(converted, (c) => c.newImports));
-      let combinedUseSites;
-      forEach(converted, (c) => {
-        if (c.useSitesToUnqualify) {
-          copyEntries(c.useSitesToUnqualify, combinedUseSites ?? (combinedUseSites = /* @__PURE__ */ new Map()));
+  var deleteUnmatchedParameter, renameUnmatchedParameter, errorCodes39;
+  var init_fixUnmatchedParameter = __esm({
+    "src/services/codefixes/fixUnmatchedParameter.ts"() {
+      "use strict";
+      init_ts4();
+      init_ts_codefix();
+      deleteUnmatchedParameter = "deleteUnmatchedParameter";
+      renameUnmatchedParameter = "renameUnmatchedParameter";
+      errorCodes39 = [
+        Diagnostics.JSDoc_param_tag_has_name_0_but_there_is_no_parameter_with_that_name.code
+      ];
+      registerCodeFix({
+        fixIds: [deleteUnmatchedParameter, renameUnmatchedParameter],
+        errorCodes: errorCodes39,
+        getCodeActions: function getCodeActionsToFixUnmatchedParameter(context) {
+          const { sourceFile, span } = context;
+          const actions2 = [];
+          const info = getInfo13(sourceFile, span.start);
+          if (info) {
+            append(actions2, getDeleteAction(context, info));
+            append(actions2, getRenameAction(context, info));
+            return actions2;
+          }
+          return void 0;
+        },
+        getAllCodeActions: function getAllCodeActionsToFixUnmatchedParameter(context) {
+          const tagsToSignature = /* @__PURE__ */ new Map();
+          return createCombinedCodeActions(ts_textChanges_exports.ChangeTracker.with(context, (changes) => {
+            eachDiagnostic(context, errorCodes39, ({ file, start }) => {
+              const info = getInfo13(file, start);
+              if (info) {
+                tagsToSignature.set(info.signature, append(tagsToSignature.get(info.signature), info.jsDocParameterTag));
+              }
+            });
+            tagsToSignature.forEach((tags, signature) => {
+              if (context.fixId === deleteUnmatchedParameter) {
+                const tagsSet = new Set(tags);
+                changes.filterJSDocTags(signature.getSourceFile(), signature, (t) => !tagsSet.has(t));
+              }
+            });
+          }));
         }
       });
-      return combinedUseSites;
     }
+  });
+
+  // src/services/codefixes/fixUnreferenceableDecoratorMetadata.ts
+  function getImportDeclaration(sourceFile, program, start) {
+    const identifier = tryCast(getTokenAtPosition(sourceFile, start), isIdentifier);
+    if (!identifier || identifier.parent.kind !== 183 /* TypeReference */)
+      return;
+    const checker = program.getTypeChecker();
+    const symbol = checker.getSymbolAtLocation(identifier);
+    return find((symbol == null ? void 0 : symbol.declarations) || emptyArray, or(isImportClause, isImportSpecifier, isImportEqualsDeclaration));
   }
-  function convertPropertyAccessImport(name, propertyName, moduleSpecifier, identifiers, quotePreference) {
-    switch (name.kind) {
-      case 205 /* ObjectBindingPattern */:
-      case 206 /* ArrayBindingPattern */: {
-        const tmp = makeUniqueName(propertyName, identifiers);
-        return convertedImports([
-          makeSingleImport(tmp, propertyName, moduleSpecifier, quotePreference),
-          makeConst(
-            /*modifiers*/
-            void 0,
-            name,
-            factory.createIdentifier(tmp)
-          )
-        ]);
-      }
-      case 80 /* Identifier */:
-        return convertedImports([makeSingleImport(name.text, propertyName, moduleSpecifier, quotePreference)]);
-      default:
-        return Debug.assertNever(name, `Convert to ES module got invalid syntax form ${name.kind}`);
+  function doTypeOnlyImportChange(changes, sourceFile, importDeclaration, program) {
+    if (importDeclaration.kind === 271 /* ImportEqualsDeclaration */) {
+      changes.insertModifierBefore(sourceFile, 156 /* TypeKeyword */, importDeclaration.name);
+      return;
     }
-  }
-  function convertAssignment(sourceFile, checker, assignment, changes, exports, useSitesToUnqualify) {
-    const { left, right } = assignment;
-    if (!isPropertyAccessExpression(left)) {
-      return false;
+    const importClause = importDeclaration.kind === 273 /* ImportClause */ ? importDeclaration : importDeclaration.parent.parent;
+    if (importClause.name && importClause.namedBindings) {
+      return;
     }
-    if (isExportsOrModuleExportsOrAlias(sourceFile, left)) {
-      if (isExportsOrModuleExportsOrAlias(sourceFile, right)) {
-        changes.delete(sourceFile, assignment.parent);
-      } else {
-        const replacement = isObjectLiteralExpression(right) ? tryChangeModuleExportsObject(right, useSitesToUnqualify) : isRequireCall(
-          right,
-          /*requireStringLiteralLikeArgument*/
-          true
-        ) ? convertReExportAll(right.arguments[0], checker) : void 0;
-        if (replacement) {
-          changes.replaceNodeWithNodes(sourceFile, assignment.parent, replacement[0]);
-          return replacement[1];
-        } else {
-          changes.replaceRangeWithText(sourceFile, createRange(left.getStart(sourceFile), right.pos), "export default");
-          return true;
-        }
-      }
-    } else if (isExportsOrModuleExportsOrAlias(sourceFile, left.expression)) {
-      convertNamedExport(sourceFile, assignment, changes, exports);
+    const checker = program.getTypeChecker();
+    const importsValue = !!forEachImportClauseDeclaration(importClause, (decl) => {
+      if (skipAlias(decl.symbol, checker).flags & 111551 /* Value */)
+        return true;
+    });
+    if (importsValue) {
+      return;
     }
-    return false;
+    changes.insertModifierBefore(sourceFile, 156 /* TypeKeyword */, importClause);
   }
-  function tryChangeModuleExportsObject(object, useSitesToUnqualify) {
-    const statements = mapAllOrFail(object.properties, (prop) => {
-      switch (prop.kind) {
-        case 176 /* GetAccessor */:
-        case 177 /* SetAccessor */:
-        case 303 /* ShorthandPropertyAssignment */:
-        case 304 /* SpreadAssignment */:
-          return void 0;
-        case 302 /* PropertyAssignment */:
-          return !isIdentifier(prop.name) ? void 0 : convertExportsDotXEquals_replaceNode(prop.name.text, prop.initializer, useSitesToUnqualify);
-        case 173 /* MethodDeclaration */:
-          return !isIdentifier(prop.name) ? void 0 : functionExpressionToDeclaration(prop.name.text, [factory.createToken(95 /* ExportKeyword */)], prop, useSitesToUnqualify);
-        default:
-          Debug.assertNever(prop, `Convert to ES6 got invalid prop kind ${prop.kind}`);
-      }
-    });
-    return statements && [statements, false];
+  function doNamespaceImportChange(changes, sourceFile, importDeclaration, program) {
+    ts_refactor_exports.doChangeNamedToNamespaceOrDefault(sourceFile, program, changes, importDeclaration.parent);
   }
-  function convertNamedExport(sourceFile, assignment, changes, exports) {
-    const { text } = assignment.left.name;
-    const rename = exports.get(text);
-    if (rename !== void 0) {
-      const newNodes = [
-        makeConst(
-          /*modifiers*/
-          void 0,
-          rename,
-          assignment.right
-        ),
-        makeExportDeclaration([factory.createExportSpecifier(
-          /*isTypeOnly*/
-          false,
-          rename,
-          text
-        )])
-      ];
-      changes.replaceNodeWithNodes(sourceFile, assignment.parent, newNodes);
-    } else {
-      convertExportsPropertyAssignment(assignment, sourceFile, changes);
+  var fixId32, errorCodes40;
+  var init_fixUnreferenceableDecoratorMetadata = __esm({
+    "src/services/codefixes/fixUnreferenceableDecoratorMetadata.ts"() {
+      "use strict";
+      init_ts4();
+      init_ts_codefix();
+      fixId32 = "fixUnreferenceableDecoratorMetadata";
+      errorCodes40 = [Diagnostics.A_type_referenced_in_a_decorated_signature_must_be_imported_with_import_type_or_a_namespace_import_when_isolatedModules_and_emitDecoratorMetadata_are_enabled.code];
+      registerCodeFix({
+        errorCodes: errorCodes40,
+        getCodeActions: (context) => {
+          const importDeclaration = getImportDeclaration(context.sourceFile, context.program, context.span.start);
+          if (!importDeclaration)
+            return;
+          const namespaceChanges = ts_textChanges_exports.ChangeTracker.with(context, (t) => importDeclaration.kind === 276 /* ImportSpecifier */ && doNamespaceImportChange(t, context.sourceFile, importDeclaration, context.program));
+          const typeOnlyChanges = ts_textChanges_exports.ChangeTracker.with(context, (t) => doTypeOnlyImportChange(t, context.sourceFile, importDeclaration, context.program));
+          let actions2;
+          if (namespaceChanges.length) {
+            actions2 = append(actions2, createCodeFixActionWithoutFixAll(fixId32, namespaceChanges, Diagnostics.Convert_named_imports_to_namespace_import));
+          }
+          if (typeOnlyChanges.length) {
+            actions2 = append(actions2, createCodeFixActionWithoutFixAll(fixId32, typeOnlyChanges, Diagnostics.Use_import_type));
+          }
+          return actions2;
+        },
+        fixIds: [fixId32]
+      });
     }
+  });
+
+  // src/services/codefixes/fixUnusedIdentifier.ts
+  function changeInferToUnknown(changes, sourceFile, token) {
+    changes.replaceNode(sourceFile, token.parent, factory.createKeywordTypeNode(159 /* UnknownKeyword */));
   }
-  function convertReExportAll(reExported, checker) {
-    const moduleSpecifier = reExported.text;
-    const moduleSymbol = checker.getSymbolAtLocation(reExported);
-    const exports = moduleSymbol ? moduleSymbol.exports : emptyMap;
-    return exports.has("export=" /* ExportEquals */) ? [[reExportDefault(moduleSpecifier)], true] : !exports.has("default" /* Default */) ? [[reExportStar(moduleSpecifier)], false] : (
-      // If there's some non-default export, must include both `export *` and `export default`.
-      exports.size > 1 ? [[reExportStar(moduleSpecifier), reExportDefault(moduleSpecifier)], true] : [[reExportDefault(moduleSpecifier)], true]
-    );
+  function createDeleteFix(changes, diag2) {
+    return createCodeFixAction(fixName3, changes, diag2, fixIdDelete, Diagnostics.Delete_all_unused_declarations);
   }
-  function reExportStar(moduleSpecifier) {
-    return makeExportDeclaration(
-      /*exportSpecifiers*/
-      void 0,
-      moduleSpecifier
-    );
+  function deleteTypeParameters(changes, sourceFile, token) {
+    changes.delete(sourceFile, Debug.checkDefined(cast(token.parent, isDeclarationWithTypeParameterChildren).typeParameters, "The type parameter to delete should exist"));
   }
-  function reExportDefault(moduleSpecifier) {
-    return makeExportDeclaration([factory.createExportSpecifier(
-      /*isTypeOnly*/
-      false,
-      /*propertyName*/
-      void 0,
-      "default"
-    )], moduleSpecifier);
+  function isImport(token) {
+    return token.kind === 102 /* ImportKeyword */ || token.kind === 80 /* Identifier */ && (token.parent.kind === 276 /* ImportSpecifier */ || token.parent.kind === 273 /* ImportClause */);
   }
-  function convertExportsPropertyAssignment({ left, right, parent: parent2 }, sourceFile, changes) {
-    const name = left.name.text;
-    if ((isFunctionExpression(right) || isArrowFunction(right) || isClassExpression(right)) && (!right.name || right.name.text === name)) {
-      changes.replaceRange(sourceFile, { pos: left.getStart(sourceFile), end: right.getStart(sourceFile) }, factory.createToken(95 /* ExportKeyword */), { suffix: " " });
-      if (!right.name)
-        changes.insertName(sourceFile, right, name);
-      const semi = findChildOfKind(parent2, 27 /* SemicolonToken */, sourceFile);
-      if (semi)
-        changes.delete(sourceFile, semi);
-    } else {
-      changes.replaceNodeRangeWithNodes(
-        sourceFile,
-        left.expression,
-        findChildOfKind(left, 25 /* DotToken */, sourceFile),
-        [factory.createToken(95 /* ExportKeyword */), factory.createToken(87 /* ConstKeyword */)],
-        { joiner: " ", suffix: " " }
-      );
-    }
+  function tryGetFullImport(token) {
+    return token.kind === 102 /* ImportKeyword */ ? tryCast(token.parent, isImportDeclaration) : void 0;
   }
-  function convertExportsDotXEquals_replaceNode(name, exported, useSitesToUnqualify) {
-    const modifiers = [factory.createToken(95 /* ExportKeyword */)];
-    switch (exported.kind) {
-      case 217 /* FunctionExpression */: {
-        const { name: expressionName } = exported;
-        if (expressionName && expressionName.text !== name) {
-          return exportConst();
-        }
+  function canDeleteEntireVariableStatement(sourceFile, token) {
+    return isVariableDeclarationList(token.parent) && first(token.parent.getChildren(sourceFile)) === token;
+  }
+  function deleteEntireVariableStatement(changes, sourceFile, node) {
+    changes.delete(sourceFile, node.parent.kind === 243 /* VariableStatement */ ? node.parent : node);
+  }
+  function deleteDestructuringElements(changes, sourceFile, node) {
+    forEach(node.elements, (n) => changes.delete(sourceFile, n));
+  }
+  function deleteDestructuring(context, changes, sourceFile, { parent: parent2 }) {
+    if (isVariableDeclaration(parent2) && parent2.initializer && isCallLikeExpression(parent2.initializer)) {
+      if (isVariableDeclarationList(parent2.parent) && length(parent2.parent.declarations) > 1) {
+        const varStatement = parent2.parent.parent;
+        const pos = varStatement.getStart(sourceFile);
+        const end = varStatement.end;
+        changes.delete(sourceFile, parent2);
+        changes.insertNodeAt(sourceFile, end, parent2.initializer, {
+          prefix: getNewLineOrDefaultFromHost(context.host, context.formatContext.options) + sourceFile.text.slice(getPrecedingNonSpaceCharacterPosition(sourceFile.text, pos - 1), pos),
+          suffix: probablyUsesSemicolons(sourceFile) ? ";" : ""
+        });
+      } else {
+        changes.replaceNode(sourceFile, parent2.parent, parent2.initializer);
       }
-      case 218 /* ArrowFunction */:
-        return functionExpressionToDeclaration(name, modifiers, exported, useSitesToUnqualify);
-      case 230 /* ClassExpression */:
-        return classExpressionToDeclaration(name, modifiers, exported, useSitesToUnqualify);
-      default:
-        return exportConst();
-    }
-    function exportConst() {
-      return makeConst(modifiers, factory.createIdentifier(name), replaceImportUseSites(exported, useSitesToUnqualify));
+    } else {
+      changes.delete(sourceFile, parent2);
     }
   }
-  function replaceImportUseSites(nodeOrNodes, useSitesToUnqualify) {
-    if (!useSitesToUnqualify || !some(arrayFrom(useSitesToUnqualify.keys()), (original) => rangeContainsRange(nodeOrNodes, original))) {
-      return nodeOrNodes;
+  function tryPrefixDeclaration(changes, errorCode, sourceFile, token) {
+    if (errorCode === Diagnostics.Property_0_is_declared_but_its_value_is_never_read.code)
+      return;
+    if (token.kind === 140 /* InferKeyword */) {
+      token = cast(token.parent, isInferTypeNode).typeParameter.name;
     }
-    return isArray(nodeOrNodes) ? getSynthesizedDeepClonesWithReplacements(
-      nodeOrNodes,
-      /*includeTrivia*/
-      true,
-      replaceNode
-    ) : getSynthesizedDeepCloneWithReplacements(
-      nodeOrNodes,
-      /*includeTrivia*/
-      true,
-      replaceNode
-    );
-    function replaceNode(original) {
-      if (original.kind === 210 /* PropertyAccessExpression */) {
-        const replacement = useSitesToUnqualify.get(original);
-        useSitesToUnqualify.delete(original);
-        return replacement;
+    if (isIdentifier(token) && canPrefix(token)) {
+      changes.replaceNode(sourceFile, token, factory.createIdentifier(`_${token.text}`));
+      if (isParameter(token.parent)) {
+        getJSDocParameterTags(token.parent).forEach((tag) => {
+          if (isIdentifier(tag.name)) {
+            changes.replaceNode(sourceFile, tag.name, factory.createIdentifier(`_${tag.name.text}`));
+          }
+        });
       }
     }
   }
-  function convertSingleImport(name, moduleSpecifier, checker, identifiers, target, quotePreference) {
-    switch (name.kind) {
-      case 205 /* ObjectBindingPattern */: {
-        const importSpecifiers = mapAllOrFail(name.elements, (e) => e.dotDotDotToken || e.initializer || e.propertyName && !isIdentifier(e.propertyName) || !isIdentifier(e.name) ? void 0 : makeImportSpecifier2(e.propertyName && e.propertyName.text, e.name.text));
-        if (importSpecifiers) {
-          return convertedImports([makeImport(
-            /*defaultImport*/
-            void 0,
-            importSpecifiers,
-            moduleSpecifier,
-            quotePreference
-          )]);
+  function canPrefix(token) {
+    switch (token.parent.kind) {
+      case 169 /* Parameter */:
+      case 168 /* TypeParameter */:
+        return true;
+      case 260 /* VariableDeclaration */: {
+        const varDecl = token.parent;
+        switch (varDecl.parent.parent.kind) {
+          case 250 /* ForOfStatement */:
+          case 249 /* ForInStatement */:
+            return true;
         }
       }
-      case 206 /* ArrayBindingPattern */: {
-        const tmp = makeUniqueName(moduleSpecifierToValidIdentifier(moduleSpecifier.text, target), identifiers);
-        return convertedImports([
-          makeImport(
-            factory.createIdentifier(tmp),
-            /*namedImports*/
-            void 0,
-            moduleSpecifier,
-            quotePreference
-          ),
-          makeConst(
-            /*modifiers*/
-            void 0,
-            getSynthesizedDeepClone(name),
-            factory.createIdentifier(tmp)
-          )
-        ]);
-      }
-      case 80 /* Identifier */:
-        return convertSingleIdentifierImport(name, moduleSpecifier, checker, identifiers, quotePreference);
-      default:
-        return Debug.assertNever(name, `Convert to ES module got invalid name kind ${name.kind}`);
     }
+    return false;
   }
-  function convertSingleIdentifierImport(name, moduleSpecifier, checker, identifiers, quotePreference) {
-    const nameSymbol = checker.getSymbolAtLocation(name);
-    const namedBindingsNames = /* @__PURE__ */ new Map();
-    let needDefaultImport = false;
-    let useSitesToUnqualify;
-    for (const use of identifiers.original.get(name.text)) {
-      if (checker.getSymbolAtLocation(use) !== nameSymbol || use === name) {
-        continue;
-      }
-      const { parent: parent2 } = use;
-      if (isPropertyAccessExpression(parent2)) {
-        const { name: { text: propertyName } } = parent2;
-        if (propertyName === "default") {
-          needDefaultImport = true;
-          const importDefaultName = use.getText();
-          (useSitesToUnqualify ?? (useSitesToUnqualify = /* @__PURE__ */ new Map())).set(parent2, factory.createIdentifier(importDefaultName));
-        } else {
-          Debug.assert(parent2.expression === use, "Didn't expect expression === use");
-          let idName = namedBindingsNames.get(propertyName);
-          if (idName === void 0) {
-            idName = makeUniqueName(propertyName, identifiers);
-            namedBindingsNames.set(propertyName, idName);
-          }
-          (useSitesToUnqualify ?? (useSitesToUnqualify = /* @__PURE__ */ new Map())).set(parent2, factory.createIdentifier(idName));
+  function tryDeleteDeclaration(sourceFile, token, changes, checker, sourceFiles, program, cancellationToken, isFixAll) {
+    tryDeleteDeclarationWorker(token, changes, sourceFile, checker, sourceFiles, program, cancellationToken, isFixAll);
+    if (isIdentifier(token)) {
+      ts_FindAllReferences_exports.Core.eachSymbolReferenceInFile(token, checker, sourceFile, (ref) => {
+        if (isPropertyAccessExpression(ref.parent) && ref.parent.name === ref)
+          ref = ref.parent;
+        if (!isFixAll && mayDeleteExpression(ref)) {
+          changes.delete(sourceFile, ref.parent.parent);
         }
-      } else {
-        needDefaultImport = true;
-      }
-    }
-    const namedBindings = namedBindingsNames.size === 0 ? void 0 : arrayFrom(mapIterator(namedBindingsNames.entries(), ([propertyName, idName]) => factory.createImportSpecifier(
-      /*isTypeOnly*/
-      false,
-      propertyName === idName ? void 0 : factory.createIdentifier(propertyName),
-      factory.createIdentifier(idName)
-    )));
-    if (!namedBindings) {
-      needDefaultImport = true;
+      });
     }
-    return convertedImports(
-      [makeImport(needDefaultImport ? getSynthesizedDeepClone(name) : void 0, namedBindings, moduleSpecifier, quotePreference)],
-      useSitesToUnqualify
-    );
   }
-  function makeUniqueName(name, identifiers) {
-    while (identifiers.original.has(name) || identifiers.additional.has(name)) {
-      name = `_${name}`;
+  function tryDeleteDeclarationWorker(token, changes, sourceFile, checker, sourceFiles, program, cancellationToken, isFixAll) {
+    const { parent: parent2 } = token;
+    if (isParameter(parent2)) {
+      tryDeleteParameter(changes, sourceFile, parent2, checker, sourceFiles, program, cancellationToken, isFixAll);
+    } else if (!(isFixAll && isIdentifier(token) && ts_FindAllReferences_exports.Core.isSymbolReferencedInFile(token, checker, sourceFile))) {
+      const node = isImportClause(parent2) ? token : isComputedPropertyName(parent2) ? parent2.parent : parent2;
+      Debug.assert(node !== sourceFile, "should not delete whole source file");
+      changes.delete(sourceFile, node);
     }
-    identifiers.additional.add(name);
-    return name;
   }
-  function collectFreeIdentifiers(file) {
-    const map2 = createMultiMap();
-    forEachFreeIdentifier(file, (id) => map2.add(id.text, id));
-    return map2;
+  function tryDeleteParameter(changes, sourceFile, parameter, checker, sourceFiles, program, cancellationToken, isFixAll = false) {
+    if (mayDeleteParameter(checker, sourceFile, parameter, sourceFiles, program, cancellationToken, isFixAll)) {
+      if (parameter.modifiers && parameter.modifiers.length > 0 && (!isIdentifier(parameter.name) || ts_FindAllReferences_exports.Core.isSymbolReferencedInFile(parameter.name, checker, sourceFile))) {
+        for (const modifier of parameter.modifiers) {
+          if (isModifier(modifier)) {
+            changes.deleteModifier(sourceFile, modifier);
+          }
+        }
+      } else if (!parameter.initializer && isNotProvidedArguments(parameter, checker, sourceFiles)) {
+        changes.delete(sourceFile, parameter);
+      }
+    }
   }
-  function forEachFreeIdentifier(node, cb) {
-    if (isIdentifier(node) && isFreeIdentifier(node))
-      cb(node);
-    node.forEachChild((child) => forEachFreeIdentifier(child, cb));
+  function isNotProvidedArguments(parameter, checker, sourceFiles) {
+    const index = parameter.parent.parameters.indexOf(parameter);
+    return !ts_FindAllReferences_exports.Core.someSignatureUsage(parameter.parent, sourceFiles, checker, (_, call) => !call || call.arguments.length > index);
   }
-  function isFreeIdentifier(node) {
-    const { parent: parent2 } = node;
+  function mayDeleteParameter(checker, sourceFile, parameter, sourceFiles, program, cancellationToken, isFixAll) {
+    const { parent: parent2 } = parameter;
     switch (parent2.kind) {
-      case 210 /* PropertyAccessExpression */:
-        return parent2.name !== node;
-      case 207 /* BindingElement */:
-        return parent2.propertyName !== node;
-      case 275 /* ImportSpecifier */:
-        return parent2.propertyName !== node;
-      default:
+      case 174 /* MethodDeclaration */:
+      case 176 /* Constructor */:
+        const index = parent2.parameters.indexOf(parameter);
+        const referent = isMethodDeclaration(parent2) ? parent2.name : parent2;
+        const entries = ts_FindAllReferences_exports.Core.getReferencedSymbolsForNode(parent2.pos, referent, program, sourceFiles, cancellationToken);
+        if (entries) {
+          for (const entry of entries) {
+            for (const reference of entry.references) {
+              if (reference.kind === ts_FindAllReferences_exports.EntryKind.Node) {
+                const isSuperCall2 = isSuperKeyword(reference.node) && isCallExpression(reference.node.parent) && reference.node.parent.arguments.length > index;
+                const isSuperMethodCall = isPropertyAccessExpression(reference.node.parent) && isSuperKeyword(reference.node.parent.expression) && isCallExpression(reference.node.parent.parent) && reference.node.parent.parent.arguments.length > index;
+                const isOverriddenMethod = (isMethodDeclaration(reference.node.parent) || isMethodSignature(reference.node.parent)) && reference.node.parent !== parameter.parent && reference.node.parent.parameters.length > index;
+                if (isSuperCall2 || isSuperMethodCall || isOverriddenMethod)
+                  return false;
+              }
+            }
+          }
+        }
+        return true;
+      case 262 /* FunctionDeclaration */: {
+        if (parent2.name && isCallbackLike(checker, sourceFile, parent2.name)) {
+          return isLastParameter(parent2, parameter, isFixAll);
+        }
         return true;
+      }
+      case 218 /* FunctionExpression */:
+      case 219 /* ArrowFunction */:
+        return isLastParameter(parent2, parameter, isFixAll);
+      case 178 /* SetAccessor */:
+        return false;
+      case 177 /* GetAccessor */:
+        return true;
+      default:
+        return Debug.failBadSyntaxKind(parent2);
     }
   }
-  function functionExpressionToDeclaration(name, additionalModifiers, fn, useSitesToUnqualify) {
-    return factory.createFunctionDeclaration(
-      concatenate(additionalModifiers, getSynthesizedDeepClones(fn.modifiers)),
-      getSynthesizedDeepClone(fn.asteriskToken),
-      name,
-      getSynthesizedDeepClones(fn.typeParameters),
-      getSynthesizedDeepClones(fn.parameters),
-      getSynthesizedDeepClone(fn.type),
-      factory.converters.convertToFunctionBlock(replaceImportUseSites(fn.body, useSitesToUnqualify))
-    );
-  }
-  function classExpressionToDeclaration(name, additionalModifiers, cls, useSitesToUnqualify) {
-    return factory.createClassDeclaration(
-      concatenate(additionalModifiers, getSynthesizedDeepClones(cls.modifiers)),
-      name,
-      getSynthesizedDeepClones(cls.typeParameters),
-      getSynthesizedDeepClones(cls.heritageClauses),
-      replaceImportUseSites(cls.members, useSitesToUnqualify)
-    );
-  }
-  function makeSingleImport(localName, propertyName, moduleSpecifier, quotePreference) {
-    return propertyName === "default" ? makeImport(
-      factory.createIdentifier(localName),
-      /*namedImports*/
-      void 0,
-      moduleSpecifier,
-      quotePreference
-    ) : makeImport(
-      /*defaultImport*/
-      void 0,
-      [makeImportSpecifier2(propertyName, localName)],
-      moduleSpecifier,
-      quotePreference
-    );
-  }
-  function makeImportSpecifier2(propertyName, name) {
-    return factory.createImportSpecifier(
-      /*isTypeOnly*/
-      false,
-      propertyName !== void 0 && propertyName !== name ? factory.createIdentifier(propertyName) : void 0,
-      factory.createIdentifier(name)
-    );
-  }
-  function makeConst(modifiers, name, init) {
-    return factory.createVariableStatement(
-      modifiers,
-      factory.createVariableDeclarationList(
-        [factory.createVariableDeclaration(
-          name,
-          /*exclamationToken*/
-          void 0,
-          /*type*/
-          void 0,
-          init
-        )],
-        2 /* Const */
-      )
-    );
+  function isCallbackLike(checker, sourceFile, name) {
+    return !!ts_FindAllReferences_exports.Core.eachSymbolReferenceInFile(name, checker, sourceFile, (reference) => isIdentifier(reference) && isCallExpression(reference.parent) && reference.parent.arguments.includes(reference));
   }
-  function makeExportDeclaration(exportSpecifiers, moduleSpecifier) {
-    return factory.createExportDeclaration(
-      /*modifiers*/
-      void 0,
-      /*isTypeOnly*/
-      false,
-      exportSpecifiers && factory.createNamedExports(exportSpecifiers),
-      moduleSpecifier === void 0 ? void 0 : factory.createStringLiteral(moduleSpecifier)
-    );
+  function isLastParameter(func, parameter, isFixAll) {
+    const parameters = func.parameters;
+    const index = parameters.indexOf(parameter);
+    Debug.assert(index !== -1, "The parameter should already be in the list");
+    return isFixAll ? parameters.slice(index + 1).every((p) => isIdentifier(p.name) && !p.symbol.isReferenced) : index === parameters.length - 1;
   }
-  function convertedImports(newImports, useSitesToUnqualify) {
-    return {
-      newImports,
-      useSitesToUnqualify
-    };
+  function mayDeleteExpression(node) {
+    return (isBinaryExpression(node.parent) && node.parent.left === node || (isPostfixUnaryExpression(node.parent) || isPrefixUnaryExpression(node.parent)) && node.parent.operand === node) && isExpressionStatement(node.parent.parent);
   }
-  var init_convertToEsModule = __esm({
-    "src/services/codefixes/convertToEsModule.ts"() {
+  var fixName3, fixIdPrefix, fixIdDelete, fixIdDeleteImports, fixIdInfer, errorCodes41;
+  var init_fixUnusedIdentifier = __esm({
+    "src/services/codefixes/fixUnusedIdentifier.ts"() {
       "use strict";
       init_ts4();
       init_ts_codefix();
+      fixName3 = "unusedIdentifier";
+      fixIdPrefix = "unusedIdentifier_prefix";
+      fixIdDelete = "unusedIdentifier_delete";
+      fixIdDeleteImports = "unusedIdentifier_deleteImports";
+      fixIdInfer = "unusedIdentifier_infer";
+      errorCodes41 = [
+        Diagnostics._0_is_declared_but_its_value_is_never_read.code,
+        Diagnostics._0_is_declared_but_never_used.code,
+        Diagnostics.Property_0_is_declared_but_its_value_is_never_read.code,
+        Diagnostics.All_imports_in_import_declaration_are_unused.code,
+        Diagnostics.All_destructured_elements_are_unused.code,
+        Diagnostics.All_variables_are_unused.code,
+        Diagnostics.All_type_parameters_are_unused.code
+      ];
       registerCodeFix({
-        errorCodes: [Diagnostics.File_is_a_CommonJS_module_it_may_be_converted_to_an_ES_module.code],
+        errorCodes: errorCodes41,
         getCodeActions(context) {
-          const { sourceFile, program, preferences } = context;
-          const changes = ts_textChanges_exports.ChangeTracker.with(context, (changes2) => {
-            const moduleExportsChangedToDefault = convertFileToEsModule(sourceFile, program.getTypeChecker(), changes2, getEmitScriptTarget(program.getCompilerOptions()), getQuotePreference(sourceFile, preferences));
-            if (moduleExportsChangedToDefault) {
-              for (const importingFile of program.getSourceFiles()) {
-                fixImportOfModuleExports(importingFile, sourceFile, changes2, getQuotePreference(importingFile, preferences));
-              }
+          const { errorCode, sourceFile, program, cancellationToken } = context;
+          const checker = program.getTypeChecker();
+          const sourceFiles = program.getSourceFiles();
+          const token = getTokenAtPosition(sourceFile, context.span.start);
+          if (isJSDocTemplateTag(token)) {
+            return [createDeleteFix(ts_textChanges_exports.ChangeTracker.with(context, (t) => t.delete(sourceFile, token)), Diagnostics.Remove_template_tag)];
+          }
+          if (token.kind === 30 /* LessThanToken */) {
+            const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => deleteTypeParameters(t, sourceFile, token));
+            return [createDeleteFix(changes, Diagnostics.Remove_type_parameters)];
+          }
+          const importDecl = tryGetFullImport(token);
+          if (importDecl) {
+            const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => t.delete(sourceFile, importDecl));
+            return [createCodeFixAction(fixName3, changes, [Diagnostics.Remove_import_from_0, showModuleSpecifier(importDecl)], fixIdDeleteImports, Diagnostics.Delete_all_unused_imports)];
+          } else if (isImport(token)) {
+            const deletion = ts_textChanges_exports.ChangeTracker.with(context, (t) => tryDeleteDeclaration(
+              sourceFile,
+              token,
+              t,
+              checker,
+              sourceFiles,
+              program,
+              cancellationToken,
+              /*isFixAll*/
+              false
+            ));
+            if (deletion.length) {
+              return [createCodeFixAction(fixName3, deletion, [Diagnostics.Remove_unused_declaration_for_Colon_0, token.getText(sourceFile)], fixIdDeleteImports, Diagnostics.Delete_all_unused_imports)];
             }
-          });
-          return [createCodeFixActionWithoutFixAll("convertToEsModule", changes, Diagnostics.Convert_to_ES_module)];
-        }
-      });
-    }
-  });
-
-  // src/services/codefixes/correctQualifiedNameToIndexedAccessType.ts
-  function getQualifiedName(sourceFile, pos) {
-    const qualifiedName = findAncestor(getTokenAtPosition(sourceFile, pos), isQualifiedName);
-    Debug.assert(!!qualifiedName, "Expected position to be owned by a qualified name.");
-    return isIdentifier(qualifiedName.left) ? qualifiedName : void 0;
-  }
-  function doChange10(changeTracker, sourceFile, qualifiedName) {
-    const rightText = qualifiedName.right.text;
-    const replacement = factory.createIndexedAccessTypeNode(
-      factory.createTypeReferenceNode(
-        qualifiedName.left,
-        /*typeArguments*/
-        void 0
-      ),
-      factory.createLiteralTypeNode(factory.createStringLiteral(rightText))
-    );
-    changeTracker.replaceNode(sourceFile, qualifiedName, replacement);
-  }
-  var fixId11, errorCodes12;
-  var init_correctQualifiedNameToIndexedAccessType = __esm({
-    "src/services/codefixes/correctQualifiedNameToIndexedAccessType.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_codefix();
-      fixId11 = "correctQualifiedNameToIndexedAccessType";
-      errorCodes12 = [Diagnostics.Cannot_access_0_1_because_0_is_a_type_but_not_a_namespace_Did_you_mean_to_retrieve_the_type_of_the_property_1_in_0_with_0_1.code];
-      registerCodeFix({
-        errorCodes: errorCodes12,
-        getCodeActions(context) {
-          const qualifiedName = getQualifiedName(context.sourceFile, context.span.start);
-          if (!qualifiedName)
-            return void 0;
-          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange10(t, context.sourceFile, qualifiedName));
-          const newText = `${qualifiedName.left.text}["${qualifiedName.right.text}"]`;
-          return [createCodeFixAction(fixId11, changes, [Diagnostics.Rewrite_as_the_indexed_access_type_0, newText], fixId11, Diagnostics.Rewrite_all_as_indexed_access_types)];
-        },
-        fixIds: [fixId11],
-        getAllCodeActions: (context) => codeFixAll(context, errorCodes12, (changes, diag2) => {
-          const q = getQualifiedName(diag2.file, diag2.start);
-          if (q) {
-            doChange10(changes, diag2.file, q);
           }
-        })
+          if (isObjectBindingPattern(token.parent) || isArrayBindingPattern(token.parent)) {
+            if (isParameter(token.parent.parent)) {
+              const elements = token.parent.elements;
+              const diagnostic = [
+                elements.length > 1 ? Diagnostics.Remove_unused_declarations_for_Colon_0 : Diagnostics.Remove_unused_declaration_for_Colon_0,
+                map(elements, (e) => e.getText(sourceFile)).join(", ")
+              ];
+              return [
+                createDeleteFix(ts_textChanges_exports.ChangeTracker.with(context, (t) => deleteDestructuringElements(t, sourceFile, token.parent)), diagnostic)
+              ];
+            }
+            return [
+              createDeleteFix(ts_textChanges_exports.ChangeTracker.with(context, (t) => deleteDestructuring(context, t, sourceFile, token.parent)), Diagnostics.Remove_unused_destructuring_declaration)
+            ];
+          }
+          if (canDeleteEntireVariableStatement(sourceFile, token)) {
+            return [
+              createDeleteFix(ts_textChanges_exports.ChangeTracker.with(context, (t) => deleteEntireVariableStatement(t, sourceFile, token.parent)), Diagnostics.Remove_variable_statement)
+            ];
+          }
+          const result = [];
+          if (token.kind === 140 /* InferKeyword */) {
+            const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => changeInferToUnknown(t, sourceFile, token));
+            const name = cast(token.parent, isInferTypeNode).typeParameter.name.text;
+            result.push(createCodeFixAction(fixName3, changes, [Diagnostics.Replace_infer_0_with_unknown, name], fixIdInfer, Diagnostics.Replace_all_unused_infer_with_unknown));
+          } else {
+            const deletion = ts_textChanges_exports.ChangeTracker.with(context, (t) => tryDeleteDeclaration(
+              sourceFile,
+              token,
+              t,
+              checker,
+              sourceFiles,
+              program,
+              cancellationToken,
+              /*isFixAll*/
+              false
+            ));
+            if (deletion.length) {
+              const name = isComputedPropertyName(token.parent) ? token.parent : token;
+              result.push(createDeleteFix(deletion, [Diagnostics.Remove_unused_declaration_for_Colon_0, name.getText(sourceFile)]));
+            }
+          }
+          const prefix = ts_textChanges_exports.ChangeTracker.with(context, (t) => tryPrefixDeclaration(t, errorCode, sourceFile, token));
+          if (prefix.length) {
+            result.push(createCodeFixAction(fixName3, prefix, [Diagnostics.Prefix_0_with_an_underscore, token.getText(sourceFile)], fixIdPrefix, Diagnostics.Prefix_all_unused_declarations_with_where_possible));
+          }
+          return result;
+        },
+        fixIds: [fixIdPrefix, fixIdDelete, fixIdDeleteImports, fixIdInfer],
+        getAllCodeActions: (context) => {
+          const { sourceFile, program, cancellationToken } = context;
+          const checker = program.getTypeChecker();
+          const sourceFiles = program.getSourceFiles();
+          return codeFixAll(context, errorCodes41, (changes, diag2) => {
+            const token = getTokenAtPosition(sourceFile, diag2.start);
+            switch (context.fixId) {
+              case fixIdPrefix:
+                tryPrefixDeclaration(changes, diag2.code, sourceFile, token);
+                break;
+              case fixIdDeleteImports: {
+                const importDecl = tryGetFullImport(token);
+                if (importDecl) {
+                  changes.delete(sourceFile, importDecl);
+                } else if (isImport(token)) {
+                  tryDeleteDeclaration(
+                    sourceFile,
+                    token,
+                    changes,
+                    checker,
+                    sourceFiles,
+                    program,
+                    cancellationToken,
+                    /*isFixAll*/
+                    true
+                  );
+                }
+                break;
+              }
+              case fixIdDelete: {
+                if (token.kind === 140 /* InferKeyword */ || isImport(token)) {
+                  break;
+                } else if (isJSDocTemplateTag(token)) {
+                  changes.delete(sourceFile, token);
+                } else if (token.kind === 30 /* LessThanToken */) {
+                  deleteTypeParameters(changes, sourceFile, token);
+                } else if (isObjectBindingPattern(token.parent)) {
+                  if (token.parent.parent.initializer) {
+                    break;
+                  } else if (!isParameter(token.parent.parent) || isNotProvidedArguments(token.parent.parent, checker, sourceFiles)) {
+                    changes.delete(sourceFile, token.parent.parent);
+                  }
+                } else if (isArrayBindingPattern(token.parent.parent) && token.parent.parent.parent.initializer) {
+                  break;
+                } else if (canDeleteEntireVariableStatement(sourceFile, token)) {
+                  deleteEntireVariableStatement(changes, sourceFile, token.parent);
+                } else {
+                  tryDeleteDeclaration(
+                    sourceFile,
+                    token,
+                    changes,
+                    checker,
+                    sourceFiles,
+                    program,
+                    cancellationToken,
+                    /*isFixAll*/
+                    true
+                  );
+                }
+                break;
+              }
+              case fixIdInfer:
+                if (token.kind === 140 /* InferKeyword */) {
+                  changeInferToUnknown(changes, sourceFile, token);
+                }
+                break;
+              default:
+                Debug.fail(JSON.stringify(context.fixId));
+            }
+          });
+        }
       });
     }
   });
 
-  // src/services/codefixes/convertToTypeOnlyExport.ts
-  function getExportSpecifierForDiagnosticSpan(span, sourceFile) {
-    return tryCast(getTokenAtPosition(sourceFile, span.start).parent, isExportSpecifier);
-  }
-  function fixSingleExportDeclaration(changes, exportSpecifier, context) {
-    if (!exportSpecifier) {
-      return;
+  // src/services/codefixes/fixUnreachableCode.ts
+  function doChange26(changes, sourceFile, start, length2, errorCode) {
+    const token = getTokenAtPosition(sourceFile, start);
+    const statement = findAncestor(token, isStatement);
+    if (statement.getStart(sourceFile) !== token.getStart(sourceFile)) {
+      const logData = JSON.stringify({
+        statementKind: Debug.formatSyntaxKind(statement.kind),
+        tokenKind: Debug.formatSyntaxKind(token.kind),
+        errorCode,
+        start,
+        length: length2
+      });
+      Debug.fail("Token and statement should start at the same point. " + logData);
     }
-    const exportClause = exportSpecifier.parent;
-    const exportDeclaration = exportClause.parent;
-    const typeExportSpecifiers = getTypeExportSpecifiers(exportSpecifier, context);
-    if (typeExportSpecifiers.length === exportClause.elements.length) {
-      changes.insertModifierBefore(context.sourceFile, 156 /* TypeKeyword */, exportClause);
+    const container = (isBlock(statement.parent) ? statement.parent : statement).parent;
+    if (!isBlock(statement.parent) || statement === first(statement.parent.statements)) {
+      switch (container.kind) {
+        case 245 /* IfStatement */:
+          if (container.elseStatement) {
+            if (isBlock(statement.parent)) {
+              break;
+            } else {
+              changes.replaceNode(sourceFile, statement, factory.createBlock(emptyArray));
+            }
+            return;
+          }
+        case 247 /* WhileStatement */:
+        case 248 /* ForStatement */:
+          changes.delete(sourceFile, container);
+          return;
+      }
+    }
+    if (isBlock(statement.parent)) {
+      const end = start + length2;
+      const lastStatement = Debug.checkDefined(lastWhere(sliceAfter(statement.parent.statements, statement), (s) => s.pos < end), "Some statement should be last");
+      changes.deleteNodeRange(sourceFile, statement, lastStatement);
     } else {
-      const valueExportDeclaration = factory.updateExportDeclaration(
-        exportDeclaration,
-        exportDeclaration.modifiers,
-        /*isTypeOnly*/
-        false,
-        factory.updateNamedExports(exportClause, filter(exportClause.elements, (e) => !contains(typeExportSpecifiers, e))),
-        exportDeclaration.moduleSpecifier,
-        /*assertClause*/
-        void 0
-      );
-      const typeExportDeclaration = factory.createExportDeclaration(
-        /*modifiers*/
-        void 0,
-        /*isTypeOnly*/
-        true,
-        factory.createNamedExports(typeExportSpecifiers),
-        exportDeclaration.moduleSpecifier,
-        /*assertClause*/
-        void 0
-      );
-      changes.replaceNode(context.sourceFile, exportDeclaration, valueExportDeclaration, {
-        leadingTriviaOption: ts_textChanges_exports.LeadingTriviaOption.IncludeAll,
-        trailingTriviaOption: ts_textChanges_exports.TrailingTriviaOption.Exclude
-      });
-      changes.insertNodeAfter(context.sourceFile, exportDeclaration, typeExportDeclaration);
+      changes.delete(sourceFile, statement);
     }
   }
-  function getTypeExportSpecifiers(originExportSpecifier, context) {
-    const exportClause = originExportSpecifier.parent;
-    if (exportClause.elements.length === 1) {
-      return exportClause.elements;
+  function lastWhere(a, pred) {
+    let last2;
+    for (const value of a) {
+      if (!pred(value))
+        break;
+      last2 = value;
     }
-    const diagnostics = getDiagnosticsWithinSpan(
-      createTextSpanFromNode(exportClause),
-      context.program.getSemanticDiagnostics(context.sourceFile, context.cancellationToken)
-    );
-    return filter(exportClause.elements, (element) => {
-      var _a;
-      return element === originExportSpecifier || ((_a = findDiagnosticForNode(element, diagnostics)) == null ? void 0 : _a.code) === errorCodes13[0];
-    });
+    return last2;
   }
-  var errorCodes13, fixId12;
-  var init_convertToTypeOnlyExport = __esm({
-    "src/services/codefixes/convertToTypeOnlyExport.ts"() {
+  var fixId33, errorCodes42;
+  var init_fixUnreachableCode = __esm({
+    "src/services/codefixes/fixUnreachableCode.ts"() {
       "use strict";
       init_ts4();
       init_ts_codefix();
-      errorCodes13 = [Diagnostics.Re_exporting_a_type_when_0_is_enabled_requires_using_export_type.code];
-      fixId12 = "convertToTypeOnlyExport";
+      fixId33 = "fixUnreachableCode";
+      errorCodes42 = [Diagnostics.Unreachable_code_detected.code];
       registerCodeFix({
-        errorCodes: errorCodes13,
-        getCodeActions: function getCodeActionsToConvertToTypeOnlyExport(context) {
-          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => fixSingleExportDeclaration(t, getExportSpecifierForDiagnosticSpan(context.span, context.sourceFile), context));
-          if (changes.length) {
-            return [createCodeFixAction(fixId12, changes, Diagnostics.Convert_to_type_only_export, fixId12, Diagnostics.Convert_all_re_exported_types_to_type_only_exports)];
-          }
+        errorCodes: errorCodes42,
+        getCodeActions(context) {
+          const syntacticDiagnostics = context.program.getSyntacticDiagnostics(context.sourceFile, context.cancellationToken);
+          if (syntacticDiagnostics.length)
+            return;
+          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange26(t, context.sourceFile, context.span.start, context.span.length, context.errorCode));
+          return [createCodeFixAction(fixId33, changes, Diagnostics.Remove_unreachable_code, fixId33, Diagnostics.Remove_all_unreachable_code)];
         },
-        fixIds: [fixId12],
-        getAllCodeActions: function getAllCodeActionsToConvertToTypeOnlyExport(context) {
-          const fixedExportDeclarations = /* @__PURE__ */ new Map();
-          return codeFixAll(context, errorCodes13, (changes, diag2) => {
-            const exportSpecifier = getExportSpecifierForDiagnosticSpan(diag2, context.sourceFile);
-            if (exportSpecifier && addToSeen(fixedExportDeclarations, getNodeId(exportSpecifier.parent.parent))) {
-              fixSingleExportDeclaration(changes, exportSpecifier, context);
-            }
-          });
-        }
+        fixIds: [fixId33],
+        getAllCodeActions: (context) => codeFixAll(context, errorCodes42, (changes, diag2) => doChange26(changes, diag2.file, diag2.start, diag2.length, diag2.code))
       });
     }
   });
 
-  // src/services/codefixes/convertToTypeOnlyImport.ts
-  function getDeclaration2(sourceFile, pos) {
-    const { parent: parent2 } = getTokenAtPosition(sourceFile, pos);
-    return isImportSpecifier(parent2) || isImportDeclaration(parent2) && parent2.importClause ? parent2 : void 0;
-  }
-  function doChange11(changes, sourceFile, declaration) {
-    if (isImportSpecifier(declaration)) {
-      changes.replaceNode(sourceFile, declaration, factory.updateImportSpecifier(
-        declaration,
-        /*isTypeOnly*/
-        true,
-        declaration.propertyName,
-        declaration.name
-      ));
-    } else {
-      const importClause = declaration.importClause;
-      if (importClause.name && importClause.namedBindings) {
-        changes.replaceNodeWithNodes(sourceFile, declaration, [
-          factory.createImportDeclaration(
-            getSynthesizedDeepClones(
-              declaration.modifiers,
-              /*includeTrivia*/
-              true
-            ),
-            factory.createImportClause(
-              /*isTypeOnly*/
-              true,
-              getSynthesizedDeepClone(
-                importClause.name,
-                /*includeTrivia*/
-                true
-              ),
-              /*namedBindings*/
-              void 0
-            ),
-            getSynthesizedDeepClone(
-              declaration.moduleSpecifier,
-              /*includeTrivia*/
-              true
-            ),
-            getSynthesizedDeepClone(
-              declaration.assertClause,
-              /*includeTrivia*/
-              true
-            )
-          ),
-          factory.createImportDeclaration(
-            getSynthesizedDeepClones(
-              declaration.modifiers,
-              /*includeTrivia*/
-              true
-            ),
-            factory.createImportClause(
-              /*isTypeOnly*/
-              true,
-              /*name*/
-              void 0,
-              getSynthesizedDeepClone(
-                importClause.namedBindings,
-                /*includeTrivia*/
-                true
-              )
-            ),
-            getSynthesizedDeepClone(
-              declaration.moduleSpecifier,
-              /*includeTrivia*/
-              true
-            ),
-            getSynthesizedDeepClone(
-              declaration.assertClause,
-              /*includeTrivia*/
-              true
-            )
-          )
-        ]);
-      } else {
-        const importDeclaration = factory.updateImportDeclaration(
-          declaration,
-          declaration.modifiers,
-          factory.updateImportClause(
-            importClause,
-            /*isTypeOnly*/
-            true,
-            importClause.name,
-            importClause.namedBindings
-          ),
-          declaration.moduleSpecifier,
-          declaration.assertClause
-        );
-        changes.replaceNode(sourceFile, declaration, importDeclaration);
-      }
-    }
+  // src/services/codefixes/fixUnusedLabel.ts
+  function doChange27(changes, sourceFile, start) {
+    const token = getTokenAtPosition(sourceFile, start);
+    const labeledStatement = cast(token.parent, isLabeledStatement);
+    const pos = token.getStart(sourceFile);
+    const statementPos = labeledStatement.statement.getStart(sourceFile);
+    const end = positionsAreOnSameLine(pos, statementPos, sourceFile) ? statementPos : skipTrivia(
+      sourceFile.text,
+      findChildOfKind(labeledStatement, 59 /* ColonToken */, sourceFile).end,
+      /*stopAfterLineBreak*/
+      true
+    );
+    changes.deleteRange(sourceFile, { pos, end });
   }
-  var errorCodes14, fixId13;
-  var init_convertToTypeOnlyImport = __esm({
-    "src/services/codefixes/convertToTypeOnlyImport.ts"() {
+  var fixId34, errorCodes43;
+  var init_fixUnusedLabel = __esm({
+    "src/services/codefixes/fixUnusedLabel.ts"() {
       "use strict";
       init_ts4();
       init_ts_codefix();
-      errorCodes14 = [
-        Diagnostics.This_import_is_never_used_as_a_value_and_must_use_import_type_because_importsNotUsedAsValues_is_set_to_error.code,
-        Diagnostics._0_is_a_type_and_must_be_imported_using_a_type_only_import_when_verbatimModuleSyntax_is_enabled.code
-      ];
-      fixId13 = "convertToTypeOnlyImport";
+      fixId34 = "fixUnusedLabel";
+      errorCodes43 = [Diagnostics.Unused_label.code];
       registerCodeFix({
-        errorCodes: errorCodes14,
-        getCodeActions: function getCodeActionsToConvertToTypeOnlyImport(context) {
-          const declaration = getDeclaration2(context.sourceFile, context.span.start);
-          if (declaration) {
-            const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange11(t, context.sourceFile, declaration));
-            return [createCodeFixAction(fixId13, changes, Diagnostics.Convert_to_type_only_import, fixId13, Diagnostics.Convert_all_imports_not_used_as_a_value_to_type_only_imports)];
-          }
-          return void 0;
+        errorCodes: errorCodes43,
+        getCodeActions(context) {
+          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange27(t, context.sourceFile, context.span.start));
+          return [createCodeFixAction(fixId34, changes, Diagnostics.Remove_unused_label, fixId34, Diagnostics.Remove_all_unused_labels)];
         },
-        fixIds: [fixId13],
-        getAllCodeActions: function getAllCodeActionsToConvertToTypeOnlyImport(context) {
-          return codeFixAll(context, errorCodes14, (changes, diag2) => {
-            const declaration = getDeclaration2(diag2.file, diag2.start);
-            if (declaration) {
-              doChange11(changes, diag2.file, declaration);
-            }
-          });
-        }
+        fixIds: [fixId34],
+        getAllCodeActions: (context) => codeFixAll(context, errorCodes43, (changes, diag2) => doChange27(changes, diag2.file, diag2.start))
       });
     }
   });
 
-  // src/services/codefixes/convertTypedefToType.ts
-  function doChange12(changes, node, sourceFile) {
-    if (isJSDocTypedefTag(node)) {
-      fixSingleTypeDef(changes, node, sourceFile);
-    }
+  // src/services/codefixes/fixJSDocTypes.ts
+  function doChange28(changes, sourceFile, oldTypeNode, newType, checker) {
+    changes.replaceNode(sourceFile, oldTypeNode, checker.typeToTypeNode(
+      newType,
+      /*enclosingDeclaration*/
+      oldTypeNode,
+      /*flags*/
+      void 0
+    ));
   }
-  function fixSingleTypeDef(changes, typeDefNode, sourceFile) {
-    if (!typeDefNode)
-      return;
-    const declaration = createDeclaration(typeDefNode);
-    if (!declaration)
-      return;
-    const comment = typeDefNode.parent;
-    changes.replaceNode(
-      sourceFile,
-      comment,
-      declaration
-    );
+  function getInfo14(sourceFile, pos, checker) {
+    const decl = findAncestor(getTokenAtPosition(sourceFile, pos), isTypeContainer);
+    const typeNode = decl && decl.type;
+    return typeNode && { typeNode, type: getType(checker, typeNode) };
   }
-  function createDeclaration(tag) {
-    var _a;
-    const { typeExpression } = tag;
-    if (!typeExpression)
-      return;
-    const typeName = (_a = tag.name) == null ? void 0 : _a.getText();
-    if (!typeName)
-      return;
-    if (typeExpression.kind === 328 /* JSDocTypeLiteral */) {
-      return createInterfaceForTypeLiteral(typeName, typeExpression);
-    }
-    if (typeExpression.kind === 315 /* JSDocTypeExpression */) {
-      return createTypeAliasForTypeExpression(typeName, typeExpression);
+  function isTypeContainer(node) {
+    switch (node.kind) {
+      case 234 /* AsExpression */:
+      case 179 /* CallSignature */:
+      case 180 /* ConstructSignature */:
+      case 262 /* FunctionDeclaration */:
+      case 177 /* GetAccessor */:
+      case 181 /* IndexSignature */:
+      case 200 /* MappedType */:
+      case 174 /* MethodDeclaration */:
+      case 173 /* MethodSignature */:
+      case 169 /* Parameter */:
+      case 172 /* PropertyDeclaration */:
+      case 171 /* PropertySignature */:
+      case 178 /* SetAccessor */:
+      case 265 /* TypeAliasDeclaration */:
+      case 216 /* TypeAssertionExpression */:
+      case 260 /* VariableDeclaration */:
+        return true;
+      default:
+        return false;
     }
   }
-  function createInterfaceForTypeLiteral(typeName, typeLiteral) {
-    const propertySignatures = createSignatureFromTypeLiteral(typeLiteral);
-    if (!some(propertySignatures))
-      return;
-    const interfaceDeclaration = factory.createInterfaceDeclaration(
-      /*modifiers*/
-      void 0,
-      typeName,
-      /*typeParameters*/
-      void 0,
-      /*heritageClauses*/
-      void 0,
-      propertySignatures
-    );
-    return interfaceDeclaration;
-  }
-  function createTypeAliasForTypeExpression(typeName, typeExpression) {
-    const typeReference = getSynthesizedDeepClone(typeExpression.type);
-    if (!typeReference)
-      return;
-    const declaration = factory.createTypeAliasDeclaration(
-      /*modifiers*/
-      void 0,
-      factory.createIdentifier(typeName),
-      /*typeParameters*/
-      void 0,
-      typeReference
-    );
-    return declaration;
-  }
-  function createSignatureFromTypeLiteral(typeLiteral) {
-    const propertyTags = typeLiteral.jsDocPropertyTags;
-    if (!some(propertyTags))
-      return;
-    const getSignature = (tag) => {
-      var _a;
-      const name = getPropertyName(tag);
-      const type = (_a = tag.typeExpression) == null ? void 0 : _a.type;
-      const isOptional = tag.isBracketed;
-      let typeReference;
-      if (type && isJSDocTypeLiteral(type)) {
-        const signatures = createSignatureFromTypeLiteral(type);
-        typeReference = factory.createTypeLiteralNode(signatures);
-      } else if (type) {
-        typeReference = getSynthesizedDeepClone(type);
-      }
-      if (typeReference && name) {
-        const questionToken = isOptional ? factory.createToken(58 /* QuestionToken */) : void 0;
-        const prop = factory.createPropertySignature(
-          /*modifiers*/
-          void 0,
-          name,
-          questionToken,
-          typeReference
-        );
-        return prop;
+  function getType(checker, node) {
+    if (isJSDocNullableType(node)) {
+      const type = checker.getTypeFromTypeNode(node.type);
+      if (type === checker.getNeverType() || type === checker.getVoidType()) {
+        return type;
       }
-    };
-    const props = mapDefined(propertyTags, getSignature);
-    return props;
-  }
-  function getPropertyName(tag) {
-    return tag.name.kind === 80 /* Identifier */ ? tag.name.text : tag.name.right.text;
-  }
-  function getJSDocTypedefNode(node) {
-    if (hasJSDocNodes(node)) {
-      return forEach(node.jsDoc, (node2) => {
-        var _a;
-        return (_a = node2.tags) == null ? void 0 : _a.find(isJSDocTypedefTag);
-      });
+      return checker.getUnionType(
+        append([type, checker.getUndefinedType()], node.postfix ? void 0 : checker.getNullType())
+      );
     }
-    return void 0;
+    return checker.getTypeFromTypeNode(node);
   }
-  var fixId14, errorCodes15;
-  var init_convertTypedefToType = __esm({
-    "src/services/codefixes/convertTypedefToType.ts"() {
+  var fixIdPlain, fixIdNullable, errorCodes44;
+  var init_fixJSDocTypes = __esm({
+    "src/services/codefixes/fixJSDocTypes.ts"() {
       "use strict";
       init_ts4();
       init_ts_codefix();
-      fixId14 = "convertTypedefToType";
-      errorCodes15 = [Diagnostics.JSDoc_typedef_may_be_converted_to_TypeScript_type.code];
+      fixIdPlain = "fixJSDocTypes_plain";
+      fixIdNullable = "fixJSDocTypes_nullable";
+      errorCodes44 = [
+        Diagnostics.JSDoc_types_can_only_be_used_inside_documentation_comments.code,
+        Diagnostics._0_at_the_end_of_a_type_is_not_valid_TypeScript_syntax_Did_you_mean_to_write_1.code,
+        Diagnostics._0_at_the_start_of_a_type_is_not_valid_TypeScript_syntax_Did_you_mean_to_write_1.code
+      ];
       registerCodeFix({
-        fixIds: [fixId14],
-        errorCodes: errorCodes15,
+        errorCodes: errorCodes44,
         getCodeActions(context) {
-          const node = getTokenAtPosition(
-            context.sourceFile,
-            context.span.start
-          );
-          if (!node)
-            return;
-          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange12(t, node, context.sourceFile));
-          if (changes.length > 0) {
-            return [
-              createCodeFixAction(
-                fixId14,
-                changes,
-                Diagnostics.Convert_typedef_to_TypeScript_type,
-                fixId14,
-                Diagnostics.Convert_all_typedef_to_TypeScript_types
-              )
-            ];
+          const { sourceFile } = context;
+          const checker = context.program.getTypeChecker();
+          const info = getInfo14(sourceFile, context.span.start, checker);
+          if (!info)
+            return void 0;
+          const { typeNode, type } = info;
+          const original = typeNode.getText(sourceFile);
+          const actions2 = [fix(type, fixIdPlain, Diagnostics.Change_all_jsdoc_style_types_to_TypeScript)];
+          if (typeNode.kind === 321 /* JSDocNullableType */) {
+            actions2.push(fix(type, fixIdNullable, Diagnostics.Change_all_jsdoc_style_types_to_TypeScript_and_add_undefined_to_nullable_types));
+          }
+          return actions2;
+          function fix(type2, fixId52, fixAllDescription) {
+            const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange28(t, sourceFile, typeNode, type2, checker));
+            return createCodeFixAction("jdocTypes", changes, [Diagnostics.Change_0_to_1, original, checker.typeToString(type2)], fixId52, fixAllDescription);
           }
         },
-        getAllCodeActions: (context) => codeFixAll(context, errorCodes15, (changes, diag2) => {
-          const node = getTokenAtPosition(diag2.file, diag2.start);
-          if (node)
-            doChange12(changes, node, diag2.file);
-        })
+        fixIds: [fixIdPlain, fixIdNullable],
+        getAllCodeActions(context) {
+          const { fixId: fixId52, program, sourceFile } = context;
+          const checker = program.getTypeChecker();
+          return codeFixAll(context, errorCodes44, (changes, err) => {
+            const info = getInfo14(err.file, err.start, checker);
+            if (!info)
+              return;
+            const { typeNode, type } = info;
+            const fixedType = typeNode.kind === 321 /* JSDocNullableType */ && fixId52 === fixIdNullable ? checker.getNullableType(type, 32768 /* Undefined */) : type;
+            doChange28(changes, sourceFile, typeNode, fixedType, checker);
+          });
+        }
       });
     }
   });
 
-  // src/services/codefixes/convertLiteralTypeToMappedType.ts
-  function getInfo5(sourceFile, pos) {
-    const token = getTokenAtPosition(sourceFile, pos);
+  // src/services/codefixes/fixMissingCallParentheses.ts
+  function doChange29(changes, sourceFile, name) {
+    changes.replaceNodeWithText(sourceFile, name, `${name.text}()`);
+  }
+  function getCallName(sourceFile, start) {
+    const token = getTokenAtPosition(sourceFile, start);
+    if (isPropertyAccessExpression(token.parent)) {
+      let current = token.parent;
+      while (isPropertyAccessExpression(current.parent)) {
+        current = current.parent;
+      }
+      return current.name;
+    }
     if (isIdentifier(token)) {
-      const propertySignature = cast(token.parent.parent, isPropertySignature);
-      const propertyName = token.getText(sourceFile);
-      return {
-        container: cast(propertySignature.parent, isTypeLiteralNode),
-        typeNode: propertySignature.type,
-        constraint: propertyName,
-        name: propertyName === "K" ? "P" : "K"
-      };
+      return token;
     }
     return void 0;
   }
-  function doChange13(changes, sourceFile, { container, typeNode, constraint, name }) {
-    changes.replaceNode(sourceFile, container, factory.createMappedTypeNode(
-      /*readonlyToken*/
-      void 0,
-      factory.createTypeParameterDeclaration(
-        /*modifiers*/
-        void 0,
-        name,
-        factory.createTypeReferenceNode(constraint)
-      ),
-      /*nameType*/
-      void 0,
-      /*questionToken*/
-      void 0,
-      typeNode,
-      /*members*/
-      void 0
-    ));
-  }
-  var fixId15, errorCodes16;
-  var init_convertLiteralTypeToMappedType = __esm({
-    "src/services/codefixes/convertLiteralTypeToMappedType.ts"() {
+  var fixId35, errorCodes45;
+  var init_fixMissingCallParentheses = __esm({
+    "src/services/codefixes/fixMissingCallParentheses.ts"() {
       "use strict";
       init_ts4();
       init_ts_codefix();
-      fixId15 = "convertLiteralTypeToMappedType";
-      errorCodes16 = [Diagnostics._0_only_refers_to_a_type_but_is_being_used_as_a_value_here_Did_you_mean_to_use_1_in_0.code];
+      fixId35 = "fixMissingCallParentheses";
+      errorCodes45 = [
+        Diagnostics.This_condition_will_always_return_true_since_this_function_is_always_defined_Did_you_mean_to_call_it_instead.code
+      ];
       registerCodeFix({
-        errorCodes: errorCodes16,
-        getCodeActions: function getCodeActionsToConvertLiteralTypeToMappedType(context) {
+        errorCodes: errorCodes45,
+        fixIds: [fixId35],
+        getCodeActions(context) {
           const { sourceFile, span } = context;
-          const info = getInfo5(sourceFile, span.start);
-          if (!info) {
-            return void 0;
-          }
-          const { name, constraint } = info;
-          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange13(t, sourceFile, info));
-          return [createCodeFixAction(fixId15, changes, [Diagnostics.Convert_0_to_1_in_0, constraint, name], fixId15, Diagnostics.Convert_all_type_literals_to_mapped_type)];
+          const callName = getCallName(sourceFile, span.start);
+          if (!callName)
+            return;
+          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange29(t, context.sourceFile, callName));
+          return [createCodeFixAction(fixId35, changes, Diagnostics.Add_missing_call_parentheses, fixId35, Diagnostics.Add_all_missing_call_parentheses)];
         },
-        fixIds: [fixId15],
-        getAllCodeActions: (context) => codeFixAll(context, errorCodes16, (changes, diag2) => {
-          const info = getInfo5(diag2.file, diag2.start);
-          if (info) {
-            doChange13(changes, diag2.file, info);
-          }
+        getAllCodeActions: (context) => codeFixAll(context, errorCodes45, (changes, diag2) => {
+          const callName = getCallName(diag2.file, diag2.start);
+          if (callName)
+            doChange29(changes, diag2.file, callName);
         })
       });
     }
   });
 
-  // src/services/codefixes/fixClassIncorrectlyImplementsInterface.ts
-  function getClass(sourceFile, pos) {
-    return Debug.checkDefined(getContainingClass(getTokenAtPosition(sourceFile, pos)), "There should be a containing class");
-  }
-  function symbolPointsToNonPrivateMember(symbol) {
-    return !symbol.valueDeclaration || !(getEffectiveModifierFlags(symbol.valueDeclaration) & 8 /* Private */);
-  }
-  function addMissingDeclarations(context, implementedTypeNode, sourceFile, classDeclaration, changeTracker, preferences) {
-    const checker = context.program.getTypeChecker();
-    const maybeHeritageClauseSymbol = getHeritageClauseSymbolTable(classDeclaration, checker);
-    const implementedType = checker.getTypeAtLocation(implementedTypeNode);
-    const implementedTypeSymbols = checker.getPropertiesOfType(implementedType);
-    const nonPrivateAndNotExistedInHeritageClauseMembers = implementedTypeSymbols.filter(and(symbolPointsToNonPrivateMember, (symbol) => !maybeHeritageClauseSymbol.has(symbol.escapedName)));
-    const classType = checker.getTypeAtLocation(classDeclaration);
-    const constructor = find(classDeclaration.members, (m) => isConstructorDeclaration(m));
-    if (!classType.getNumberIndexType()) {
-      createMissingIndexSignatureDeclaration(implementedType, 1 /* Number */);
+  // src/services/codefixes/fixAwaitInSyncFunction.ts
+  function getReturnType(expr) {
+    if (expr.type) {
+      return expr.type;
     }
-    if (!classType.getStringIndexType()) {
-      createMissingIndexSignatureDeclaration(implementedType, 0 /* String */);
+    if (isVariableDeclaration(expr.parent) && expr.parent.type && isFunctionTypeNode(expr.parent.type)) {
+      return expr.parent.type.type;
     }
-    const importAdder = createImportAdder(sourceFile, context.program, preferences, context.host);
-    createMissingMemberNodes(classDeclaration, nonPrivateAndNotExistedInHeritageClauseMembers, sourceFile, context, preferences, importAdder, (member) => insertInterfaceMemberNode(sourceFile, classDeclaration, member));
-    importAdder.writeFixes(changeTracker);
-    function createMissingIndexSignatureDeclaration(type, kind) {
-      const indexInfoOfKind = checker.getIndexInfoOfType(type, kind);
-      if (indexInfoOfKind) {
-        insertInterfaceMemberNode(sourceFile, classDeclaration, checker.indexInfoToIndexSignatureDeclaration(
-          indexInfoOfKind,
-          classDeclaration,
-          /*flags*/
-          void 0,
-          getNoopSymbolTrackerWithResolver(context)
-        ));
-      }
+  }
+  function getNodes3(sourceFile, start) {
+    const token = getTokenAtPosition(sourceFile, start);
+    const containingFunction = getContainingFunction(token);
+    if (!containingFunction) {
+      return;
     }
-    function insertInterfaceMemberNode(sourceFile2, cls, newElement) {
-      if (constructor) {
-        changeTracker.insertNodeAfter(sourceFile2, constructor, newElement);
-      } else {
-        changeTracker.insertMemberAtStart(sourceFile2, cls, newElement);
-      }
+    let insertBefore;
+    switch (containingFunction.kind) {
+      case 174 /* MethodDeclaration */:
+        insertBefore = containingFunction.name;
+        break;
+      case 262 /* FunctionDeclaration */:
+      case 218 /* FunctionExpression */:
+        insertBefore = findChildOfKind(containingFunction, 100 /* FunctionKeyword */, sourceFile);
+        break;
+      case 219 /* ArrowFunction */:
+        const kind = containingFunction.typeParameters ? 30 /* LessThanToken */ : 21 /* OpenParenToken */;
+        insertBefore = findChildOfKind(containingFunction, kind, sourceFile) || first(containingFunction.parameters);
+        break;
+      default:
+        return;
     }
+    return insertBefore && {
+      insertBefore,
+      returnType: getReturnType(containingFunction)
+    };
   }
-  function getHeritageClauseSymbolTable(classDeclaration, checker) {
-    const heritageClauseNode = getEffectiveBaseTypeNode(classDeclaration);
-    if (!heritageClauseNode)
-      return createSymbolTable();
-    const heritageClauseType = checker.getTypeAtLocation(heritageClauseNode);
-    const heritageClauseTypeSymbols = checker.getPropertiesOfType(heritageClauseType);
-    return createSymbolTable(heritageClauseTypeSymbols.filter(symbolPointsToNonPrivateMember));
+  function doChange30(changes, sourceFile, { insertBefore, returnType }) {
+    if (returnType) {
+      const entityName = getEntityNameFromTypeNode(returnType);
+      if (!entityName || entityName.kind !== 80 /* Identifier */ || entityName.text !== "Promise") {
+        changes.replaceNode(sourceFile, returnType, factory.createTypeReferenceNode("Promise", factory.createNodeArray([returnType])));
+      }
+    }
+    changes.insertModifierBefore(sourceFile, 134 /* AsyncKeyword */, insertBefore);
   }
-  var errorCodes17, fixId16;
-  var init_fixClassIncorrectlyImplementsInterface = __esm({
-    "src/services/codefixes/fixClassIncorrectlyImplementsInterface.ts"() {
+  var fixId36, errorCodes46;
+  var init_fixAwaitInSyncFunction = __esm({
+    "src/services/codefixes/fixAwaitInSyncFunction.ts"() {
       "use strict";
       init_ts4();
       init_ts_codefix();
-      errorCodes17 = [
-        Diagnostics.Class_0_incorrectly_implements_interface_1.code,
-        Diagnostics.Class_0_incorrectly_implements_class_1_Did_you_mean_to_extend_1_and_inherit_its_members_as_a_subclass.code
+      fixId36 = "fixAwaitInSyncFunction";
+      errorCodes46 = [
+        Diagnostics.await_expressions_are_only_allowed_within_async_functions_and_at_the_top_levels_of_modules.code,
+        Diagnostics.await_using_statements_are_only_allowed_within_async_functions_and_at_the_top_levels_of_modules.code,
+        Diagnostics.for_await_loops_are_only_allowed_within_async_functions_and_at_the_top_levels_of_modules.code,
+        Diagnostics.Cannot_find_name_0_Did_you_mean_to_write_this_in_an_async_function.code
       ];
-      fixId16 = "fixClassIncorrectlyImplementsInterface";
       registerCodeFix({
-        errorCodes: errorCodes17,
+        errorCodes: errorCodes46,
         getCodeActions(context) {
           const { sourceFile, span } = context;
-          const classDeclaration = getClass(sourceFile, span.start);
-          return mapDefined(getEffectiveImplementsTypeNodes(classDeclaration), (implementedTypeNode) => {
-            const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => addMissingDeclarations(context, implementedTypeNode, sourceFile, classDeclaration, t, context.preferences));
-            return changes.length === 0 ? void 0 : createCodeFixAction(fixId16, changes, [Diagnostics.Implement_interface_0, implementedTypeNode.getText(sourceFile)], fixId16, Diagnostics.Implement_all_unimplemented_interfaces);
-          });
+          const nodes = getNodes3(sourceFile, span.start);
+          if (!nodes)
+            return void 0;
+          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange30(t, sourceFile, nodes));
+          return [createCodeFixAction(fixId36, changes, Diagnostics.Add_async_modifier_to_containing_function, fixId36, Diagnostics.Add_all_missing_async_modifiers)];
         },
-        fixIds: [fixId16],
-        getAllCodeActions(context) {
-          const seenClassDeclarations = /* @__PURE__ */ new Map();
-          return codeFixAll(context, errorCodes17, (changes, diag2) => {
-            const classDeclaration = getClass(diag2.file, diag2.start);
-            if (addToSeen(seenClassDeclarations, getNodeId(classDeclaration))) {
-              for (const implementedTypeNode of getEffectiveImplementsTypeNodes(classDeclaration)) {
-                addMissingDeclarations(context, implementedTypeNode, diag2.file, classDeclaration, changes, context.preferences);
-              }
-            }
+        fixIds: [fixId36],
+        getAllCodeActions: function getAllCodeActionsToFixAwaitInSyncFunction(context) {
+          const seen = /* @__PURE__ */ new Map();
+          return codeFixAll(context, errorCodes46, (changes, diag2) => {
+            const nodes = getNodes3(diag2.file, diag2.start);
+            if (!nodes || !addToSeen(seen, getNodeId(nodes.insertBefore)))
+              return;
+            doChange30(changes, context.sourceFile, nodes);
           });
         }
       });
     }
   });
 
-  // src/services/codefixes/importFixes.ts
-  function createImportAdder(sourceFile, program, preferences, host, cancellationToken) {
-    return createImportAdderWorker(
-      sourceFile,
-      program,
-      /*useAutoImportProvider*/
-      false,
-      preferences,
-      host,
-      cancellationToken
-    );
-  }
-  function createImportAdderWorker(sourceFile, program, useAutoImportProvider, preferences, host, cancellationToken) {
-    const compilerOptions = program.getCompilerOptions();
-    const addToNamespace = [];
-    const importType = [];
-    const addToExisting = /* @__PURE__ */ new Map();
-    const newImports = /* @__PURE__ */ new Map();
-    return { addImportFromDiagnostic, addImportFromExportedSymbol, writeFixes, hasFixes };
-    function addImportFromDiagnostic(diagnostic, context) {
-      const info = getFixInfos(context, diagnostic.code, diagnostic.start, useAutoImportProvider);
-      if (!info || !info.length)
-        return;
-      addImport(first(info));
-    }
-    function addImportFromExportedSymbol(exportedSymbol, isValidTypeOnlyUseSite) {
-      const moduleSymbol = Debug.checkDefined(exportedSymbol.parent);
-      const symbolName2 = getNameForExportedSymbol(exportedSymbol, getEmitScriptTarget(compilerOptions));
-      const checker = program.getTypeChecker();
-      const symbol = checker.getMergedSymbol(skipAlias(exportedSymbol, checker));
-      const exportInfo = getAllExportInfoForSymbol(
-        sourceFile,
-        symbol,
-        symbolName2,
-        moduleSymbol,
-        /*preferCapitalized*/
-        false,
-        program,
-        host,
-        preferences,
-        cancellationToken
-      );
-      const useRequire = shouldUseRequire(sourceFile, program);
-      const fix = getImportFixForSymbol(
-        sourceFile,
-        Debug.checkDefined(exportInfo),
-        program,
-        /*position*/
-        void 0,
-        !!isValidTypeOnlyUseSite,
-        useRequire,
-        host,
-        preferences
-      );
-      if (fix) {
-        addImport({ fix, symbolName: symbolName2, errorIdentifierText: void 0 });
-      }
-    }
-    function addImport(info) {
-      var _a, _b;
-      const { fix, symbolName: symbolName2 } = info;
-      switch (fix.kind) {
-        case 0 /* UseNamespace */:
-          addToNamespace.push(fix);
-          break;
-        case 1 /* JsdocTypeImport */:
-          importType.push(fix);
-          break;
-        case 2 /* AddToExisting */: {
-          const { importClauseOrBindingPattern, importKind, addAsTypeOnly } = fix;
-          const key = String(getNodeId(importClauseOrBindingPattern));
-          let entry = addToExisting.get(key);
-          if (!entry) {
-            addToExisting.set(key, entry = { importClauseOrBindingPattern, defaultImport: void 0, namedImports: /* @__PURE__ */ new Map() });
-          }
-          if (importKind === 0 /* Named */) {
-            const prevValue = entry == null ? void 0 : entry.namedImports.get(symbolName2);
-            entry.namedImports.set(symbolName2, reduceAddAsTypeOnlyValues(prevValue, addAsTypeOnly));
-          } else {
-            Debug.assert(entry.defaultImport === void 0 || entry.defaultImport.name === symbolName2, "(Add to Existing) Default import should be missing or match symbolName");
-            entry.defaultImport = {
-              name: symbolName2,
-              addAsTypeOnly: reduceAddAsTypeOnlyValues((_a = entry.defaultImport) == null ? void 0 : _a.addAsTypeOnly, addAsTypeOnly)
-            };
-          }
-          break;
-        }
-        case 3 /* AddNew */: {
-          const { moduleSpecifier, importKind, useRequire, addAsTypeOnly } = fix;
-          const entry = getNewImportEntry(moduleSpecifier, importKind, useRequire, addAsTypeOnly);
-          Debug.assert(entry.useRequire === useRequire, "(Add new) Tried to add an `import` and a `require` for the same module");
-          switch (importKind) {
-            case 1 /* Default */:
-              Debug.assert(entry.defaultImport === void 0 || entry.defaultImport.name === symbolName2, "(Add new) Default import should be missing or match symbolName");
-              entry.defaultImport = { name: symbolName2, addAsTypeOnly: reduceAddAsTypeOnlyValues((_b = entry.defaultImport) == null ? void 0 : _b.addAsTypeOnly, addAsTypeOnly) };
-              break;
-            case 0 /* Named */:
-              const prevValue = (entry.namedImports || (entry.namedImports = /* @__PURE__ */ new Map())).get(symbolName2);
-              entry.namedImports.set(symbolName2, reduceAddAsTypeOnlyValues(prevValue, addAsTypeOnly));
-              break;
-            case 3 /* CommonJS */:
-            case 2 /* Namespace */:
-              Debug.assert(entry.namespaceLikeImport === void 0 || entry.namespaceLikeImport.name === symbolName2, "Namespacelike import shoudl be missing or match symbolName");
-              entry.namespaceLikeImport = { importKind, name: symbolName2, addAsTypeOnly };
-              break;
-          }
-          break;
-        }
-        case 4 /* PromoteTypeOnly */:
-          break;
-        default:
-          Debug.assertNever(fix, `fix wasn't never - got kind ${fix.kind}`);
-      }
-      function reduceAddAsTypeOnlyValues(prevValue, newValue) {
-        return Math.max(prevValue ?? 0, newValue);
-      }
-      function getNewImportEntry(moduleSpecifier, importKind, useRequire, addAsTypeOnly) {
-        const typeOnlyKey = newImportsKey(
-          moduleSpecifier,
-          /*topLevelTypeOnly*/
-          true
-        );
-        const nonTypeOnlyKey = newImportsKey(
-          moduleSpecifier,
-          /*topLevelTypeOnly*/
-          false
-        );
-        const typeOnlyEntry = newImports.get(typeOnlyKey);
-        const nonTypeOnlyEntry = newImports.get(nonTypeOnlyKey);
-        const newEntry = {
-          defaultImport: void 0,
-          namedImports: void 0,
-          namespaceLikeImport: void 0,
-          useRequire
-        };
-        if (importKind === 1 /* Default */ && addAsTypeOnly === 2 /* Required */) {
-          if (typeOnlyEntry)
-            return typeOnlyEntry;
-          newImports.set(typeOnlyKey, newEntry);
-          return newEntry;
-        }
-        if (addAsTypeOnly === 1 /* Allowed */ && (typeOnlyEntry || nonTypeOnlyEntry)) {
-          return typeOnlyEntry || nonTypeOnlyEntry;
-        }
-        if (nonTypeOnlyEntry) {
-          return nonTypeOnlyEntry;
-        }
-        newImports.set(nonTypeOnlyKey, newEntry);
-        return newEntry;
-      }
-      function newImportsKey(moduleSpecifier, topLevelTypeOnly) {
-        return `${topLevelTypeOnly ? 1 : 0}|${moduleSpecifier}`;
-      }
-    }
-    function writeFixes(changeTracker) {
-      const quotePreference = getQuotePreference(sourceFile, preferences);
-      for (const fix of addToNamespace) {
-        addNamespaceQualifier(changeTracker, sourceFile, fix);
-      }
-      for (const fix of importType) {
-        addImportType(changeTracker, sourceFile, fix, quotePreference);
-      }
-      addToExisting.forEach(({ importClauseOrBindingPattern, defaultImport, namedImports }) => {
-        doAddExistingFix(
-          changeTracker,
-          sourceFile,
-          importClauseOrBindingPattern,
-          defaultImport,
-          arrayFrom(namedImports.entries(), ([name, addAsTypeOnly]) => ({ addAsTypeOnly, name })),
-          preferences
-        );
-      });
-      let newDeclarations;
-      newImports.forEach(({ useRequire, defaultImport, namedImports, namespaceLikeImport }, key) => {
-        const moduleSpecifier = key.slice(2);
-        const getDeclarations = useRequire ? getNewRequires : getNewImports;
-        const declarations = getDeclarations(
-          moduleSpecifier,
-          quotePreference,
-          defaultImport,
-          namedImports && arrayFrom(namedImports.entries(), ([name, addAsTypeOnly]) => ({ addAsTypeOnly, name })),
-          namespaceLikeImport,
-          compilerOptions
-        );
-        newDeclarations = combine(newDeclarations, declarations);
-      });
-      if (newDeclarations) {
-        insertImports(
-          changeTracker,
-          sourceFile,
-          newDeclarations,
-          /*blankLineBetween*/
-          true,
-          preferences
-        );
-      }
-    }
-    function hasFixes() {
-      return addToNamespace.length > 0 || importType.length > 0 || addToExisting.size > 0 || newImports.size > 0;
-    }
-  }
-  function createImportSpecifierResolver(importingFile, program, host, preferences) {
-    const packageJsonImportFilter = createPackageJsonImportFilter(importingFile, preferences, host);
-    const importMap = createExistingImportMap(program.getTypeChecker(), importingFile, program.getCompilerOptions());
-    return { getModuleSpecifierForBestExportInfo };
-    function getModuleSpecifierForBestExportInfo(exportInfo, position, isValidTypeOnlyUseSite, fromCacheOnly) {
-      const { fixes, computedWithoutCacheCount } = getImportFixes(
-        exportInfo,
-        position,
-        isValidTypeOnlyUseSite,
-        /*useRequire*/
-        false,
-        program,
-        importingFile,
-        host,
-        preferences,
-        importMap,
-        fromCacheOnly
-      );
-      const result = getBestFix(fixes, importingFile, program, packageJsonImportFilter, host);
-      return result && { ...result, computedWithoutCacheCount };
-    }
-  }
-  function getImportCompletionAction(targetSymbol, moduleSymbol, exportMapKey, sourceFile, symbolName2, isJsxTagName, host, program, formatContext, position, preferences, cancellationToken) {
-    const compilerOptions = program.getCompilerOptions();
-    let exportInfos;
-    if (exportMapKey) {
-      exportInfos = getExportInfoMap(sourceFile, host, program, preferences, cancellationToken).get(sourceFile.path, exportMapKey);
-      Debug.assertIsDefined(exportInfos, "Some exportInfo should match the specified exportMapKey");
+  // src/services/codefixes/fixPropertyOverrideAccessor.ts
+  function doChange31(file, start, length2, code, context) {
+    let startPosition;
+    let endPosition;
+    if (code === Diagnostics._0_is_defined_as_an_accessor_in_class_1_but_is_overridden_here_in_2_as_an_instance_property.code) {
+      startPosition = start;
+      endPosition = start + length2;
+    } else if (code === Diagnostics._0_is_defined_as_a_property_in_class_1_but_is_overridden_here_in_2_as_an_accessor.code) {
+      const checker = context.program.getTypeChecker();
+      const node = getTokenAtPosition(file, start).parent;
+      Debug.assert(isAccessor(node), "error span of fixPropertyOverrideAccessor should only be on an accessor");
+      const containingClass = node.parent;
+      Debug.assert(isClassLike(containingClass), "erroneous accessors should only be inside classes");
+      const base = singleOrUndefined(getAllSupers(containingClass, checker));
+      if (!base)
+        return [];
+      const name = unescapeLeadingUnderscores(getTextOfPropertyName(node.name));
+      const baseProp = checker.getPropertyOfType(checker.getTypeAtLocation(base), name);
+      if (!baseProp || !baseProp.valueDeclaration)
+        return [];
+      startPosition = baseProp.valueDeclaration.pos;
+      endPosition = baseProp.valueDeclaration.end;
+      file = getSourceFileOfNode(baseProp.valueDeclaration);
     } else {
-      exportInfos = pathIsBareSpecifier(stripQuotes(moduleSymbol.name)) ? [getSingleExportInfoForSymbol(targetSymbol, symbolName2, moduleSymbol, program, host)] : getAllExportInfoForSymbol(sourceFile, targetSymbol, symbolName2, moduleSymbol, isJsxTagName, program, host, preferences, cancellationToken);
-      Debug.assertIsDefined(exportInfos, "Some exportInfo should match the specified symbol / moduleSymbol");
-    }
-    const useRequire = shouldUseRequire(sourceFile, program);
-    const isValidTypeOnlyUseSite = isValidTypeOnlyAliasUseSite(getTokenAtPosition(sourceFile, position));
-    const fix = Debug.checkDefined(getImportFixForSymbol(sourceFile, exportInfos, program, position, isValidTypeOnlyUseSite, useRequire, host, preferences));
-    return {
-      moduleSpecifier: fix.moduleSpecifier,
-      codeAction: codeFixActionToCodeAction(codeActionForFix(
-        { host, formatContext, preferences },
-        sourceFile,
-        symbolName2,
-        fix,
-        /*includeSymbolNameInDescription*/
-        false,
-        compilerOptions,
-        preferences
-      ))
-    };
-  }
-  function getPromoteTypeOnlyCompletionAction(sourceFile, symbolToken, program, host, formatContext, preferences) {
-    const compilerOptions = program.getCompilerOptions();
-    const symbolName2 = single(getSymbolNamesToImport(sourceFile, program.getTypeChecker(), symbolToken, compilerOptions));
-    const fix = getTypeOnlyPromotionFix(sourceFile, symbolToken, symbolName2, program);
-    const includeSymbolNameInDescription = symbolName2 !== symbolToken.text;
-    return fix && codeFixActionToCodeAction(codeActionForFix({ host, formatContext, preferences }, sourceFile, symbolName2, fix, includeSymbolNameInDescription, compilerOptions, preferences));
-  }
-  function getImportFixForSymbol(sourceFile, exportInfos, program, position, isValidTypeOnlyUseSite, useRequire, host, preferences) {
-    const packageJsonImportFilter = createPackageJsonImportFilter(sourceFile, preferences, host);
-    return getBestFix(getImportFixes(exportInfos, position, isValidTypeOnlyUseSite, useRequire, program, sourceFile, host, preferences).fixes, sourceFile, program, packageJsonImportFilter, host);
-  }
-  function codeFixActionToCodeAction({ description: description3, changes, commands }) {
-    return { description: description3, changes, commands };
-  }
-  function getAllExportInfoForSymbol(importingFile, symbol, symbolName2, moduleSymbol, preferCapitalized, program, host, preferences, cancellationToken) {
-    const getChecker = createGetChecker(program, host);
-    return getExportInfoMap(importingFile, host, program, preferences, cancellationToken).search(importingFile.path, preferCapitalized, (name) => name === symbolName2, (info) => {
-      if (skipAlias(info[0].symbol, getChecker(info[0].isFromPackageJson)) === symbol && info.some((i) => i.moduleSymbol === moduleSymbol || i.symbol.parent === moduleSymbol)) {
-        return info;
-      }
-    });
-  }
-  function getSingleExportInfoForSymbol(symbol, symbolName2, moduleSymbol, program, host) {
-    var _a, _b;
-    const compilerOptions = program.getCompilerOptions();
-    const mainProgramInfo = getInfoWithChecker(
-      program.getTypeChecker(),
-      /*isFromPackageJson*/
-      false
-    );
-    if (mainProgramInfo) {
-      return mainProgramInfo;
-    }
-    const autoImportProvider = (_b = (_a = host.getPackageJsonAutoImportProvider) == null ? void 0 : _a.call(host)) == null ? void 0 : _b.getTypeChecker();
-    return Debug.checkDefined(autoImportProvider && getInfoWithChecker(
-      autoImportProvider,
-      /*isFromPackageJson*/
-      true
-    ), `Could not find symbol in specified module for code actions`);
-    function getInfoWithChecker(checker, isFromPackageJson) {
-      const defaultInfo = getDefaultLikeExportInfo(moduleSymbol, checker, compilerOptions);
-      if (defaultInfo && skipAlias(defaultInfo.symbol, checker) === symbol) {
-        return { symbol: defaultInfo.symbol, moduleSymbol, moduleFileName: void 0, exportKind: defaultInfo.exportKind, targetFlags: skipAlias(symbol, checker).flags, isFromPackageJson };
-      }
-      const named = checker.tryGetMemberInModuleExportsAndProperties(symbolName2, moduleSymbol);
-      if (named && skipAlias(named, checker) === symbol) {
-        return { symbol: named, moduleSymbol, moduleFileName: void 0, exportKind: 0 /* Named */, targetFlags: skipAlias(symbol, checker).flags, isFromPackageJson };
-      }
-    }
-  }
-  function getImportFixes(exportInfos, usagePosition, isValidTypeOnlyUseSite, useRequire, program, sourceFile, host, preferences, importMap = createExistingImportMap(program.getTypeChecker(), sourceFile, program.getCompilerOptions()), fromCacheOnly) {
-    const checker = program.getTypeChecker();
-    const existingImports = flatMap(exportInfos, importMap.getImportsForExportInfo);
-    const useNamespace = usagePosition !== void 0 && tryUseExistingNamespaceImport(existingImports, usagePosition);
-    const addToExisting = tryAddToExistingImport(existingImports, isValidTypeOnlyUseSite, checker, program.getCompilerOptions());
-    if (addToExisting) {
-      return {
-        computedWithoutCacheCount: 0,
-        fixes: [...useNamespace ? [useNamespace] : emptyArray, addToExisting]
-      };
+      Debug.fail("fixPropertyOverrideAccessor codefix got unexpected error code " + code);
     }
-    const { fixes, computedWithoutCacheCount = 0 } = getFixesForAddImport(
-      exportInfos,
-      existingImports,
-      program,
-      sourceFile,
-      usagePosition,
-      isValidTypeOnlyUseSite,
-      useRequire,
-      host,
-      preferences,
-      fromCacheOnly
-    );
-    return {
-      computedWithoutCacheCount,
-      fixes: [...useNamespace ? [useNamespace] : emptyArray, ...fixes]
-    };
-  }
-  function tryUseExistingNamespaceImport(existingImports, position) {
-    return firstDefined(existingImports, ({ declaration, importKind }) => {
-      var _a;
-      if (importKind !== 0 /* Named */)
-        return void 0;
-      const namespacePrefix = getNamespaceLikeImportText(declaration);
-      const moduleSpecifier = namespacePrefix && ((_a = tryGetModuleSpecifierFromDeclaration(declaration)) == null ? void 0 : _a.text);
-      if (moduleSpecifier) {
-        return { kind: 0 /* UseNamespace */, namespacePrefix, usagePosition: position, moduleSpecifier };
-      }
-    });
+    return generateAccessorFromProperty(file, context.program, startPosition, endPosition, context, Diagnostics.Generate_get_and_set_accessors.message);
   }
-  function getNamespaceLikeImportText(declaration) {
-    var _a, _b, _c;
-    switch (declaration.kind) {
-      case 259 /* VariableDeclaration */:
-        return (_a = tryCast(declaration.name, isIdentifier)) == null ? void 0 : _a.text;
-      case 270 /* ImportEqualsDeclaration */:
-        return declaration.name.text;
-      case 271 /* ImportDeclaration */:
-        return (_c = tryCast((_b = declaration.importClause) == null ? void 0 : _b.namedBindings, isNamespaceImport)) == null ? void 0 : _c.name.text;
+  var errorCodes47, fixId37;
+  var init_fixPropertyOverrideAccessor = __esm({
+    "src/services/codefixes/fixPropertyOverrideAccessor.ts"() {
+      "use strict";
+      init_ts4();
+      init_ts_codefix();
+      errorCodes47 = [
+        Diagnostics._0_is_defined_as_an_accessor_in_class_1_but_is_overridden_here_in_2_as_an_instance_property.code,
+        Diagnostics._0_is_defined_as_a_property_in_class_1_but_is_overridden_here_in_2_as_an_accessor.code
+      ];
+      fixId37 = "fixPropertyOverrideAccessor";
+      registerCodeFix({
+        errorCodes: errorCodes47,
+        getCodeActions(context) {
+          const edits = doChange31(context.sourceFile, context.span.start, context.span.length, context.errorCode, context);
+          if (edits) {
+            return [createCodeFixAction(fixId37, edits, Diagnostics.Generate_get_and_set_accessors, fixId37, Diagnostics.Generate_get_and_set_accessors_for_all_overriding_properties)];
+          }
+        },
+        fixIds: [fixId37],
+        getAllCodeActions: (context) => codeFixAll(context, errorCodes47, (changes, diag2) => {
+          const edits = doChange31(diag2.file, diag2.start, diag2.length, diag2.code, context);
+          if (edits) {
+            for (const edit of edits) {
+              changes.pushRaw(context.sourceFile, edit);
+            }
+          }
+        })
+      });
+    }
+  });
+
+  // src/services/codefixes/inferFromUsage.ts
+  function getDiagnostic(errorCode, token) {
+    switch (errorCode) {
+      case Diagnostics.Parameter_0_implicitly_has_an_1_type.code:
+      case Diagnostics.Parameter_0_implicitly_has_an_1_type_but_a_better_type_may_be_inferred_from_usage.code:
+        return isSetAccessorDeclaration(getContainingFunction(token)) ? Diagnostics.Infer_type_of_0_from_usage : Diagnostics.Infer_parameter_types_from_usage;
+      case Diagnostics.Rest_parameter_0_implicitly_has_an_any_type.code:
+      case Diagnostics.Rest_parameter_0_implicitly_has_an_any_type_but_a_better_type_may_be_inferred_from_usage.code:
+        return Diagnostics.Infer_parameter_types_from_usage;
+      case Diagnostics.this_implicitly_has_type_any_because_it_does_not_have_a_type_annotation.code:
+        return Diagnostics.Infer_this_type_of_0_from_usage;
       default:
-        return Debug.assertNever(declaration);
+        return Diagnostics.Infer_type_of_0_from_usage;
     }
   }
-  function getAddAsTypeOnly(isValidTypeOnlyUseSite, isForNewImportDeclaration, symbol, targetFlags, checker, compilerOptions) {
-    if (!isValidTypeOnlyUseSite) {
-      return 4 /* NotAllowed */;
-    }
-    if (isForNewImportDeclaration && compilerOptions.importsNotUsedAsValues === 2 /* Error */) {
-      return 2 /* Required */;
-    }
-    if (importNameElisionDisabled(compilerOptions) && (!(targetFlags & 111551 /* Value */) || !!checker.getTypeOnlyAliasDeclaration(symbol))) {
-      return 2 /* Required */;
+  function mapSuggestionDiagnostic(errorCode) {
+    switch (errorCode) {
+      case Diagnostics.Variable_0_implicitly_has_type_1_in_some_locations_but_a_better_type_may_be_inferred_from_usage.code:
+        return Diagnostics.Variable_0_implicitly_has_type_1_in_some_locations_where_its_type_cannot_be_determined.code;
+      case Diagnostics.Variable_0_implicitly_has_an_1_type_but_a_better_type_may_be_inferred_from_usage.code:
+        return Diagnostics.Variable_0_implicitly_has_an_1_type.code;
+      case Diagnostics.Parameter_0_implicitly_has_an_1_type_but_a_better_type_may_be_inferred_from_usage.code:
+        return Diagnostics.Parameter_0_implicitly_has_an_1_type.code;
+      case Diagnostics.Rest_parameter_0_implicitly_has_an_any_type_but_a_better_type_may_be_inferred_from_usage.code:
+        return Diagnostics.Rest_parameter_0_implicitly_has_an_any_type.code;
+      case Diagnostics.Property_0_implicitly_has_type_any_but_a_better_type_for_its_get_accessor_may_be_inferred_from_usage.code:
+        return Diagnostics.Property_0_implicitly_has_type_any_because_its_get_accessor_lacks_a_return_type_annotation.code;
+      case Diagnostics._0_implicitly_has_an_1_return_type_but_a_better_type_may_be_inferred_from_usage.code:
+        return Diagnostics._0_which_lacks_return_type_annotation_implicitly_has_an_1_return_type.code;
+      case Diagnostics.Property_0_implicitly_has_type_any_but_a_better_type_for_its_set_accessor_may_be_inferred_from_usage.code:
+        return Diagnostics.Property_0_implicitly_has_type_any_because_its_set_accessor_lacks_a_parameter_type_annotation.code;
+      case Diagnostics.Member_0_implicitly_has_an_1_type_but_a_better_type_may_be_inferred_from_usage.code:
+        return Diagnostics.Member_0_implicitly_has_an_1_type.code;
     }
-    return 1 /* Allowed */;
+    return errorCode;
   }
-  function tryAddToExistingImport(existingImports, isValidTypeOnlyUseSite, checker, compilerOptions) {
-    let best;
-    for (const existingImport of existingImports) {
-      const fix = getAddToExistingImportFix(existingImport);
-      if (!fix)
-        continue;
-      const isTypeOnly = isTypeOnlyImportDeclaration(fix.importClauseOrBindingPattern);
-      if (fix.addAsTypeOnly !== 4 /* NotAllowed */ && isTypeOnly || fix.addAsTypeOnly === 4 /* NotAllowed */ && !isTypeOnly) {
-        return fix;
-      }
-      best ?? (best = fix);
+  function doChange32(changes, sourceFile, token, errorCode, program, cancellationToken, markSeen, host, preferences) {
+    if (!isParameterPropertyModifier(token.kind) && token.kind !== 80 /* Identifier */ && token.kind !== 26 /* DotDotDotToken */ && token.kind !== 110 /* ThisKeyword */) {
+      return void 0;
     }
-    return best;
-    function getAddToExistingImportFix({ declaration, importKind, symbol, targetFlags }) {
-      if (importKind === 3 /* CommonJS */ || importKind === 2 /* Namespace */ || declaration.kind === 270 /* ImportEqualsDeclaration */) {
-        return void 0;
-      }
-      if (declaration.kind === 259 /* VariableDeclaration */) {
-        return (importKind === 0 /* Named */ || importKind === 1 /* Default */) && declaration.name.kind === 205 /* ObjectBindingPattern */ ? { kind: 2 /* AddToExisting */, importClauseOrBindingPattern: declaration.name, importKind, moduleSpecifier: declaration.initializer.arguments[0].text, addAsTypeOnly: 4 /* NotAllowed */ } : void 0;
-      }
-      const { importClause } = declaration;
-      if (!importClause || !isStringLiteralLike(declaration.moduleSpecifier)) {
-        return void 0;
-      }
-      const { name, namedBindings } = importClause;
-      if (importClause.isTypeOnly && !(importKind === 0 /* Named */ && namedBindings)) {
-        return void 0;
-      }
-      const addAsTypeOnly = getAddAsTypeOnly(
-        isValidTypeOnlyUseSite,
-        /*isForNewImportDeclaration*/
-        false,
-        symbol,
-        targetFlags,
-        checker,
-        compilerOptions
-      );
-      if (importKind === 1 /* Default */ && (name || // Cannot add a default import to a declaration that already has one
-      addAsTypeOnly === 2 /* Required */ && namedBindings)) {
+    const { parent: parent2 } = token;
+    const importAdder = createImportAdder(sourceFile, program, preferences, host);
+    errorCode = mapSuggestionDiagnostic(errorCode);
+    switch (errorCode) {
+      case Diagnostics.Member_0_implicitly_has_an_1_type.code:
+      case Diagnostics.Variable_0_implicitly_has_type_1_in_some_locations_where_its_type_cannot_be_determined.code:
+        if (isVariableDeclaration(parent2) && markSeen(parent2) || isPropertyDeclaration(parent2) || isPropertySignature(parent2)) {
+          annotateVariableDeclaration(changes, importAdder, sourceFile, parent2, program, host, cancellationToken);
+          importAdder.writeFixes(changes);
+          return parent2;
+        }
+        if (isPropertyAccessExpression(parent2)) {
+          const type = inferTypeForVariableFromUsage(parent2.name, program, cancellationToken);
+          const typeNode = getTypeNodeIfAccessible(type, parent2, program, host);
+          if (typeNode) {
+            const typeTag = factory.createJSDocTypeTag(
+              /*tagName*/
+              void 0,
+              factory.createJSDocTypeExpression(typeNode),
+              /*comment*/
+              void 0
+            );
+            changes.addJSDocTags(sourceFile, cast(parent2.parent.parent, isExpressionStatement), [typeTag]);
+          }
+          importAdder.writeFixes(changes);
+          return parent2;
+        }
         return void 0;
-      }
-      if (importKind === 0 /* Named */ && (namedBindings == null ? void 0 : namedBindings.kind) === 273 /* NamespaceImport */) {
+      case Diagnostics.Variable_0_implicitly_has_an_1_type.code: {
+        const symbol = program.getTypeChecker().getSymbolAtLocation(token);
+        if (symbol && symbol.valueDeclaration && isVariableDeclaration(symbol.valueDeclaration) && markSeen(symbol.valueDeclaration)) {
+          annotateVariableDeclaration(changes, importAdder, getSourceFileOfNode(symbol.valueDeclaration), symbol.valueDeclaration, program, host, cancellationToken);
+          importAdder.writeFixes(changes);
+          return symbol.valueDeclaration;
+        }
         return void 0;
       }
-      return {
-        kind: 2 /* AddToExisting */,
-        importClauseOrBindingPattern: importClause,
-        importKind,
-        moduleSpecifier: declaration.moduleSpecifier.text,
-        addAsTypeOnly
-      };
     }
-  }
-  function createExistingImportMap(checker, importingFile, compilerOptions) {
-    let importMap;
-    for (const moduleSpecifier of importingFile.imports) {
-      const i = importFromModuleSpecifier(moduleSpecifier);
-      if (isVariableDeclarationInitializedToRequire(i.parent)) {
-        const moduleSymbol = checker.resolveExternalModuleName(moduleSpecifier);
-        if (moduleSymbol) {
-          (importMap || (importMap = createMultiMap())).add(getSymbolId(moduleSymbol), i.parent);
+    const containingFunction = getContainingFunction(token);
+    if (containingFunction === void 0) {
+      return void 0;
+    }
+    let declaration;
+    switch (errorCode) {
+      case Diagnostics.Parameter_0_implicitly_has_an_1_type.code:
+        if (isSetAccessorDeclaration(containingFunction)) {
+          annotateSetAccessor(changes, importAdder, sourceFile, containingFunction, program, host, cancellationToken);
+          declaration = containingFunction;
+          break;
         }
-      } else if (i.kind === 271 /* ImportDeclaration */ || i.kind === 270 /* ImportEqualsDeclaration */) {
-        const moduleSymbol = checker.getSymbolAtLocation(moduleSpecifier);
-        if (moduleSymbol) {
-          (importMap || (importMap = createMultiMap())).add(getSymbolId(moduleSymbol), i);
+      case Diagnostics.Rest_parameter_0_implicitly_has_an_any_type.code:
+        if (markSeen(containingFunction)) {
+          const param = cast(parent2, isParameter);
+          annotateParameters(changes, importAdder, sourceFile, param, containingFunction, program, host, cancellationToken);
+          declaration = param;
         }
-      }
-    }
-    return {
-      getImportsForExportInfo: ({ moduleSymbol, exportKind, targetFlags, symbol }) => {
-        if (!(targetFlags & 111551 /* Value */) && isSourceFileJS(importingFile))
-          return emptyArray;
-        const matchingDeclarations = importMap == null ? void 0 : importMap.get(getSymbolId(moduleSymbol));
-        if (!matchingDeclarations)
-          return emptyArray;
-        const importKind = getImportKind(importingFile, exportKind, compilerOptions);
-        return matchingDeclarations.map((declaration) => ({ declaration, importKind, symbol, targetFlags }));
-      }
-    };
-  }
-  function shouldUseRequire(sourceFile, program) {
-    if (!isSourceFileJS(sourceFile)) {
-      return false;
-    }
-    if (sourceFile.commonJsModuleIndicator && !sourceFile.externalModuleIndicator)
-      return true;
-    if (sourceFile.externalModuleIndicator && !sourceFile.commonJsModuleIndicator)
-      return false;
-    const compilerOptions = program.getCompilerOptions();
-    if (compilerOptions.configFile) {
-      return getEmitModuleKind(compilerOptions) < 5 /* ES2015 */;
-    }
-    for (const otherFile of program.getSourceFiles()) {
-      if (otherFile === sourceFile || !isSourceFileJS(otherFile) || program.isSourceFileFromExternalLibrary(otherFile))
-        continue;
-      if (otherFile.commonJsModuleIndicator && !otherFile.externalModuleIndicator)
-        return true;
-      if (otherFile.externalModuleIndicator && !otherFile.commonJsModuleIndicator)
-        return false;
-    }
-    return true;
-  }
-  function createGetChecker(program, host) {
-    return memoizeOne((isFromPackageJson) => isFromPackageJson ? host.getPackageJsonAutoImportProvider().getTypeChecker() : program.getTypeChecker());
-  }
-  function getNewImportFixes(program, sourceFile, usagePosition, isValidTypeOnlyUseSite, useRequire, exportInfo, host, preferences, fromCacheOnly) {
-    const isJs = isSourceFileJS(sourceFile);
-    const compilerOptions = program.getCompilerOptions();
-    const moduleSpecifierResolutionHost = createModuleSpecifierResolutionHost(program, host);
-    const getChecker = createGetChecker(program, host);
-    const moduleResolution = getEmitModuleResolutionKind(compilerOptions);
-    const rejectNodeModulesRelativePaths = moduleResolutionUsesNodeModules(moduleResolution);
-    const getModuleSpecifiers2 = fromCacheOnly ? (moduleSymbol) => ({ moduleSpecifiers: ts_moduleSpecifiers_exports.tryGetModuleSpecifiersFromCache(moduleSymbol, sourceFile, moduleSpecifierResolutionHost, preferences), computedWithoutCache: false }) : (moduleSymbol, checker) => ts_moduleSpecifiers_exports.getModuleSpecifiersWithCacheInfo(moduleSymbol, checker, compilerOptions, sourceFile, moduleSpecifierResolutionHost, preferences);
-    let computedWithoutCacheCount = 0;
-    const fixes = flatMap(exportInfo, (exportInfo2, i) => {
-      const checker = getChecker(exportInfo2.isFromPackageJson);
-      const { computedWithoutCache, moduleSpecifiers } = getModuleSpecifiers2(exportInfo2.moduleSymbol, checker);
-      const importedSymbolHasValueMeaning = !!(exportInfo2.targetFlags & 111551 /* Value */);
-      const addAsTypeOnly = getAddAsTypeOnly(
-        isValidTypeOnlyUseSite,
-        /*isForNewImportDeclaration*/
-        true,
-        exportInfo2.symbol,
-        exportInfo2.targetFlags,
-        checker,
-        compilerOptions
-      );
-      computedWithoutCacheCount += computedWithoutCache ? 1 : 0;
-      return mapDefined(moduleSpecifiers, (moduleSpecifier) => {
-        var _a;
-        if (rejectNodeModulesRelativePaths && pathContainsNodeModules(moduleSpecifier)) {
-          return void 0;
+        break;
+      case Diagnostics.Property_0_implicitly_has_type_any_because_its_get_accessor_lacks_a_return_type_annotation.code:
+      case Diagnostics._0_which_lacks_return_type_annotation_implicitly_has_an_1_return_type.code:
+        if (isGetAccessorDeclaration(containingFunction) && isIdentifier(containingFunction.name)) {
+          annotate(changes, importAdder, sourceFile, containingFunction, inferTypeForVariableFromUsage(containingFunction.name, program, cancellationToken), program, host);
+          declaration = containingFunction;
         }
-        if (!importedSymbolHasValueMeaning && isJs && usagePosition !== void 0) {
-          return { kind: 1 /* JsdocTypeImport */, moduleSpecifier, usagePosition, exportInfo: exportInfo2, isReExport: i > 0 };
+        break;
+      case Diagnostics.Property_0_implicitly_has_type_any_because_its_set_accessor_lacks_a_parameter_type_annotation.code:
+        if (isSetAccessorDeclaration(containingFunction)) {
+          annotateSetAccessor(changes, importAdder, sourceFile, containingFunction, program, host, cancellationToken);
+          declaration = containingFunction;
         }
-        const importKind = getImportKind(sourceFile, exportInfo2.exportKind, compilerOptions);
-        let qualification;
-        if (usagePosition !== void 0 && importKind === 3 /* CommonJS */ && exportInfo2.exportKind === 0 /* Named */) {
-          const exportEquals = checker.resolveExternalModuleSymbol(exportInfo2.moduleSymbol);
-          let namespacePrefix;
-          if (exportEquals !== exportInfo2.moduleSymbol) {
-            namespacePrefix = (_a = getDefaultExportInfoWorker(exportEquals, checker, compilerOptions)) == null ? void 0 : _a.name;
-          }
-          namespacePrefix || (namespacePrefix = moduleSymbolToValidIdentifier(
-            exportInfo2.moduleSymbol,
-            getEmitScriptTarget(compilerOptions),
-            /*forceCapitalize*/
-            false
-          ));
-          qualification = { namespacePrefix, usagePosition };
+        break;
+      case Diagnostics.this_implicitly_has_type_any_because_it_does_not_have_a_type_annotation.code:
+        if (ts_textChanges_exports.isThisTypeAnnotatable(containingFunction) && markSeen(containingFunction)) {
+          annotateThis(changes, sourceFile, containingFunction, program, host, cancellationToken);
+          declaration = containingFunction;
         }
-        return {
-          kind: 3 /* AddNew */,
-          moduleSpecifier,
-          importKind,
-          useRequire,
-          addAsTypeOnly,
-          exportInfo: exportInfo2,
-          isReExport: i > 0,
-          qualification
-        };
-      });
-    });
-    return { computedWithoutCacheCount, fixes };
-  }
-  function getFixesForAddImport(exportInfos, existingImports, program, sourceFile, usagePosition, isValidTypeOnlyUseSite, useRequire, host, preferences, fromCacheOnly) {
-    const existingDeclaration = firstDefined(existingImports, (info) => newImportInfoFromExistingSpecifier(info, isValidTypeOnlyUseSite, useRequire, program.getTypeChecker(), program.getCompilerOptions()));
-    return existingDeclaration ? { fixes: [existingDeclaration] } : getNewImportFixes(program, sourceFile, usagePosition, isValidTypeOnlyUseSite, useRequire, exportInfos, host, preferences, fromCacheOnly);
+        break;
+      default:
+        return Debug.fail(String(errorCode));
+    }
+    importAdder.writeFixes(changes);
+    return declaration;
   }
-  function newImportInfoFromExistingSpecifier({ declaration, importKind, symbol, targetFlags }, isValidTypeOnlyUseSite, useRequire, checker, compilerOptions) {
-    var _a;
-    const moduleSpecifier = (_a = tryGetModuleSpecifierFromDeclaration(declaration)) == null ? void 0 : _a.text;
-    if (moduleSpecifier) {
-      const addAsTypeOnly = useRequire ? 4 /* NotAllowed */ : getAddAsTypeOnly(
-        isValidTypeOnlyUseSite,
-        /*isForNewImportDeclaration*/
-        true,
-        symbol,
-        targetFlags,
-        checker,
-        compilerOptions
-      );
-      return { kind: 3 /* AddNew */, moduleSpecifier, importKind, addAsTypeOnly, useRequire };
+  function annotateVariableDeclaration(changes, importAdder, sourceFile, declaration, program, host, cancellationToken) {
+    if (isIdentifier(declaration.name)) {
+      annotate(changes, importAdder, sourceFile, declaration, inferTypeForVariableFromUsage(declaration.name, program, cancellationToken), program, host);
     }
   }
-  function getFixInfos(context, errorCode, pos, useAutoImportProvider) {
-    const symbolToken = getTokenAtPosition(context.sourceFile, pos);
-    let info;
-    if (errorCode === Diagnostics._0_refers_to_a_UMD_global_but_the_current_file_is_a_module_Consider_adding_an_import_instead.code) {
-      info = getFixesInfoForUMDImport(context, symbolToken);
-    } else if (!isIdentifier(symbolToken)) {
-      return void 0;
-    } else if (errorCode === Diagnostics._0_cannot_be_used_as_a_value_because_it_was_imported_using_import_type.code) {
-      const symbolName2 = single(getSymbolNamesToImport(context.sourceFile, context.program.getTypeChecker(), symbolToken, context.program.getCompilerOptions()));
-      const fix = getTypeOnlyPromotionFix(context.sourceFile, symbolToken, symbolName2, context.program);
-      return fix && [{ fix, symbolName: symbolName2, errorIdentifierText: symbolToken.text }];
+  function annotateParameters(changes, importAdder, sourceFile, parameterDeclaration, containingFunction, program, host, cancellationToken) {
+    if (!isIdentifier(parameterDeclaration.name)) {
+      return;
+    }
+    const parameterInferences = inferTypeForParametersFromUsage(containingFunction, sourceFile, program, cancellationToken);
+    Debug.assert(containingFunction.parameters.length === parameterInferences.length, "Parameter count and inference count should match");
+    if (isInJSFile(containingFunction)) {
+      annotateJSDocParameters(changes, sourceFile, parameterInferences, program, host);
     } else {
-      info = getFixesInfoForNonUMDImport(context, symbolToken, useAutoImportProvider);
+      const needParens = isArrowFunction(containingFunction) && !findChildOfKind(containingFunction, 21 /* OpenParenToken */, sourceFile);
+      if (needParens)
+        changes.insertNodeBefore(sourceFile, first(containingFunction.parameters), factory.createToken(21 /* OpenParenToken */));
+      for (const { declaration, type } of parameterInferences) {
+        if (declaration && !declaration.type && !declaration.initializer) {
+          annotate(changes, importAdder, sourceFile, declaration, type, program, host);
+        }
+      }
+      if (needParens)
+        changes.insertNodeAfter(sourceFile, last(containingFunction.parameters), factory.createToken(22 /* CloseParenToken */));
     }
-    const packageJsonImportFilter = createPackageJsonImportFilter(context.sourceFile, context.preferences, context.host);
-    return info && sortFixInfo(info, context.sourceFile, context.program, packageJsonImportFilter, context.host);
-  }
-  function sortFixInfo(fixes, sourceFile, program, packageJsonImportFilter, host) {
-    const _toPath = (fileName) => toPath(fileName, host.getCurrentDirectory(), hostGetCanonicalFileName(host));
-    return sort(fixes, (a, b) => compareBooleans(!!a.isJsxNamespaceFix, !!b.isJsxNamespaceFix) || compareValues(a.fix.kind, b.fix.kind) || compareModuleSpecifiers(a.fix, b.fix, sourceFile, program, packageJsonImportFilter.allowsImportingSpecifier, _toPath));
   }
-  function getBestFix(fixes, sourceFile, program, packageJsonImportFilter, host) {
-    if (!some(fixes))
+  function annotateThis(changes, sourceFile, containingFunction, program, host, cancellationToken) {
+    const references = getFunctionReferences(containingFunction, sourceFile, program, cancellationToken);
+    if (!references || !references.length) {
       return;
-    if (fixes[0].kind === 0 /* UseNamespace */ || fixes[0].kind === 2 /* AddToExisting */) {
-      return fixes[0];
     }
-    return fixes.reduce(
-      (best, fix) => (
-        // Takes true branch of conditional if `fix` is better than `best`
-        compareModuleSpecifiers(
-          fix,
-          best,
-          sourceFile,
-          program,
-          packageJsonImportFilter.allowsImportingSpecifier,
-          (fileName) => toPath(fileName, host.getCurrentDirectory(), hostGetCanonicalFileName(host))
-        ) === -1 /* LessThan */ ? fix : best
-      )
-    );
-  }
-  function compareModuleSpecifiers(a, b, importingFile, program, allowsImportingSpecifier, toPath3) {
-    if (a.kind !== 0 /* UseNamespace */ && b.kind !== 0 /* UseNamespace */) {
-      return compareBooleans(allowsImportingSpecifier(b.moduleSpecifier), allowsImportingSpecifier(a.moduleSpecifier)) || compareNodeCoreModuleSpecifiers(a.moduleSpecifier, b.moduleSpecifier, importingFile, program) || compareBooleans(
-        isFixPossiblyReExportingImportingFile(a, importingFile, program.getCompilerOptions(), toPath3),
-        isFixPossiblyReExportingImportingFile(b, importingFile, program.getCompilerOptions(), toPath3)
-      ) || compareNumberOfDirectorySeparators(a.moduleSpecifier, b.moduleSpecifier);
+    const thisInference = inferTypeFromReferences(program, references, cancellationToken).thisParameter();
+    const typeNode = getTypeNodeIfAccessible(thisInference, containingFunction, program, host);
+    if (!typeNode) {
+      return;
     }
-    return 0 /* EqualTo */;
-  }
-  function isFixPossiblyReExportingImportingFile(fix, importingFile, compilerOptions, toPath3) {
-    var _a;
-    if (fix.isReExport && ((_a = fix.exportInfo) == null ? void 0 : _a.moduleFileName) && getEmitModuleResolutionKind(compilerOptions) === 2 /* Node10 */ && isIndexFileName(fix.exportInfo.moduleFileName)) {
-      const reExportDir = toPath3(getDirectoryPath(fix.exportInfo.moduleFileName));
-      return startsWith(importingFile.path, reExportDir);
+    if (isInJSFile(containingFunction)) {
+      annotateJSDocThis(changes, sourceFile, containingFunction, typeNode);
+    } else {
+      changes.tryInsertThisTypeAnnotation(sourceFile, containingFunction, typeNode);
     }
-    return false;
-  }
-  function isIndexFileName(fileName) {
-    return getBaseFileName(
-      fileName,
-      [".js", ".jsx", ".d.ts", ".ts", ".tsx"],
-      /*ignoreCase*/
-      true
-    ) === "index";
-  }
-  function compareNodeCoreModuleSpecifiers(a, b, importingFile, program) {
-    if (startsWith(a, "node:") && !startsWith(b, "node:"))
-      return shouldUseUriStyleNodeCoreModules(importingFile, program) ? -1 /* LessThan */ : 1 /* GreaterThan */;
-    if (startsWith(b, "node:") && !startsWith(a, "node:"))
-      return shouldUseUriStyleNodeCoreModules(importingFile, program) ? 1 /* GreaterThan */ : -1 /* LessThan */;
-    return 0 /* EqualTo */;
   }
-  function getFixesInfoForUMDImport({ sourceFile, program, host, preferences }, token) {
-    const checker = program.getTypeChecker();
-    const umdSymbol = getUmdSymbol(token, checker);
-    if (!umdSymbol)
-      return void 0;
-    const symbol = checker.getAliasedSymbol(umdSymbol);
-    const symbolName2 = umdSymbol.name;
-    const exportInfo = [{ symbol: umdSymbol, moduleSymbol: symbol, moduleFileName: void 0, exportKind: 3 /* UMD */, targetFlags: symbol.flags, isFromPackageJson: false }];
-    const useRequire = shouldUseRequire(sourceFile, program);
-    const fixes = getImportFixes(
-      exportInfo,
-      /*usagePosition*/
-      void 0,
-      /*isValidTypeOnlyUseSite*/
-      false,
-      useRequire,
-      program,
-      sourceFile,
-      host,
-      preferences
-    ).fixes;
-    return fixes.map((fix) => {
-      var _a;
-      return { fix, symbolName: symbolName2, errorIdentifierText: (_a = tryCast(token, isIdentifier)) == null ? void 0 : _a.text };
-    });
+  function annotateJSDocThis(changes, sourceFile, containingFunction, typeNode) {
+    changes.addJSDocTags(sourceFile, containingFunction, [
+      factory.createJSDocThisTag(
+        /*tagName*/
+        void 0,
+        factory.createJSDocTypeExpression(typeNode)
+      )
+    ]);
   }
-  function getUmdSymbol(token, checker) {
-    const umdSymbol = isIdentifier(token) ? checker.getSymbolAtLocation(token) : void 0;
-    if (isUMDExportSymbol(umdSymbol))
-      return umdSymbol;
-    const { parent: parent2 } = token;
-    if (isJsxOpeningLikeElement(parent2) && parent2.tagName === token || isJsxOpeningFragment(parent2)) {
-      const parentSymbol = checker.resolveName(
-        checker.getJsxNamespace(parent2),
-        isJsxOpeningLikeElement(parent2) ? token : parent2,
-        111551 /* Value */,
-        /*excludeGlobals*/
-        false
-      );
-      if (isUMDExportSymbol(parentSymbol)) {
-        return parentSymbol;
+  function annotateSetAccessor(changes, importAdder, sourceFile, setAccessorDeclaration, program, host, cancellationToken) {
+    const param = firstOrUndefined(setAccessorDeclaration.parameters);
+    if (param && isIdentifier(setAccessorDeclaration.name) && isIdentifier(param.name)) {
+      let type = inferTypeForVariableFromUsage(setAccessorDeclaration.name, program, cancellationToken);
+      if (type === program.getTypeChecker().getAnyType()) {
+        type = inferTypeForVariableFromUsage(param.name, program, cancellationToken);
+      }
+      if (isInJSFile(setAccessorDeclaration)) {
+        annotateJSDocParameters(changes, sourceFile, [{ declaration: param, type }], program, host);
+      } else {
+        annotate(changes, importAdder, sourceFile, param, type, program, host);
       }
     }
-    return void 0;
   }
-  function getImportKind(importingFile, exportKind, compilerOptions, forceImportKeyword) {
-    if (compilerOptions.verbatimModuleSyntax && (getEmitModuleKind(compilerOptions) === 1 /* CommonJS */ || importingFile.impliedNodeFormat === 1 /* CommonJS */)) {
-      return 3 /* CommonJS */;
-    }
-    switch (exportKind) {
-      case 0 /* Named */:
-        return 0 /* Named */;
-      case 1 /* Default */:
-        return 1 /* Default */;
-      case 2 /* ExportEquals */:
-        return getExportEqualsImportKind(importingFile, compilerOptions, !!forceImportKeyword);
-      case 3 /* UMD */:
-        return getUmdImportKind(importingFile, compilerOptions, !!forceImportKeyword);
-      default:
-        return Debug.assertNever(exportKind);
+  function annotate(changes, importAdder, sourceFile, declaration, type, program, host) {
+    const typeNode = getTypeNodeIfAccessible(type, declaration, program, host);
+    if (typeNode) {
+      if (isInJSFile(sourceFile) && declaration.kind !== 171 /* PropertySignature */) {
+        const parent2 = isVariableDeclaration(declaration) ? tryCast(declaration.parent.parent, isVariableStatement) : declaration;
+        if (!parent2) {
+          return;
+        }
+        const typeExpression = factory.createJSDocTypeExpression(typeNode);
+        const typeTag = isGetAccessorDeclaration(declaration) ? factory.createJSDocReturnTag(
+          /*tagName*/
+          void 0,
+          typeExpression,
+          /*comment*/
+          void 0
+        ) : factory.createJSDocTypeTag(
+          /*tagName*/
+          void 0,
+          typeExpression,
+          /*comment*/
+          void 0
+        );
+        changes.addJSDocTags(sourceFile, parent2, [typeTag]);
+      } else if (!tryReplaceImportTypeNodeWithAutoImport(typeNode, declaration, sourceFile, changes, importAdder, getEmitScriptTarget(program.getCompilerOptions()))) {
+        changes.tryInsertTypeAnnotation(sourceFile, declaration, typeNode);
+      }
     }
   }
-  function getUmdImportKind(importingFile, compilerOptions, forceImportKeyword) {
-    if (getAllowSyntheticDefaultImports(compilerOptions)) {
-      return 1 /* Default */;
-    }
-    const moduleKind = getEmitModuleKind(compilerOptions);
-    switch (moduleKind) {
-      case 2 /* AMD */:
-      case 1 /* CommonJS */:
-      case 3 /* UMD */:
-        if (isInJSFile(importingFile)) {
-          return isExternalModule(importingFile) || forceImportKeyword ? 2 /* Namespace */ : 3 /* CommonJS */;
-        }
-        return 3 /* CommonJS */;
-      case 4 /* System */:
-      case 5 /* ES2015 */:
-      case 6 /* ES2020 */:
-      case 7 /* ES2022 */:
-      case 99 /* ESNext */:
-      case 0 /* None */:
-        return 2 /* Namespace */;
-      case 100 /* Node16 */:
-      case 199 /* NodeNext */:
-        return importingFile.impliedNodeFormat === 99 /* ESNext */ ? 2 /* Namespace */ : 3 /* CommonJS */;
-      default:
-        return Debug.assertNever(moduleKind, `Unexpected moduleKind ${moduleKind}`);
+  function tryReplaceImportTypeNodeWithAutoImport(typeNode, declaration, sourceFile, changes, importAdder, scriptTarget) {
+    const importableReference = tryGetAutoImportableReferenceFromTypeNode(typeNode, scriptTarget);
+    if (importableReference && changes.tryInsertTypeAnnotation(sourceFile, declaration, importableReference.typeNode)) {
+      forEach(importableReference.symbols, (s) => importAdder.addImportFromExportedSymbol(
+        s,
+        /*isValidTypeOnlyUseSite*/
+        true
+      ));
+      return true;
     }
+    return false;
   }
-  function getFixesInfoForNonUMDImport({ sourceFile, program, cancellationToken, host, preferences }, symbolToken, useAutoImportProvider) {
-    const checker = program.getTypeChecker();
-    const compilerOptions = program.getCompilerOptions();
-    return flatMap(getSymbolNamesToImport(sourceFile, checker, symbolToken, compilerOptions), (symbolName2) => {
-      if (symbolName2 === "default" /* Default */) {
-        return void 0;
+  function annotateJSDocParameters(changes, sourceFile, parameterInferences, program, host) {
+    const signature = parameterInferences.length && parameterInferences[0].declaration.parent;
+    if (!signature) {
+      return;
+    }
+    const inferences = mapDefined(parameterInferences, (inference) => {
+      const param = inference.declaration;
+      if (param.initializer || getJSDocType(param) || !isIdentifier(param.name)) {
+        return;
+      }
+      const typeNode = inference.type && getTypeNodeIfAccessible(inference.type, param, program, host);
+      if (typeNode) {
+        const name = factory.cloneNode(param.name);
+        setEmitFlags(name, 3072 /* NoComments */ | 4096 /* NoNestedComments */);
+        return { name: factory.cloneNode(param.name), param, isOptional: !!inference.isOptional, typeNode };
       }
-      const isValidTypeOnlyUseSite = isValidTypeOnlyAliasUseSite(symbolToken);
-      const useRequire = shouldUseRequire(sourceFile, program);
-      const exportInfo = getExportInfos(symbolName2, isJSXTagName(symbolToken), getMeaningFromLocation(symbolToken), cancellationToken, sourceFile, program, useAutoImportProvider, host, preferences);
-      return arrayFrom(
-        flatMapIterator(exportInfo.values(), (exportInfos) => getImportFixes(exportInfos, symbolToken.getStart(sourceFile), isValidTypeOnlyUseSite, useRequire, program, sourceFile, host, preferences).fixes),
-        (fix) => ({ fix, symbolName: symbolName2, errorIdentifierText: symbolToken.text, isJsxNamespaceFix: symbolName2 !== symbolToken.text })
-      );
     });
-  }
-  function getTypeOnlyPromotionFix(sourceFile, symbolToken, symbolName2, program) {
-    const checker = program.getTypeChecker();
-    const symbol = checker.resolveName(
-      symbolName2,
-      symbolToken,
-      111551 /* Value */,
-      /*excludeGlobals*/
-      true
-    );
-    if (!symbol)
-      return void 0;
-    const typeOnlyAliasDeclaration = checker.getTypeOnlyAliasDeclaration(symbol);
-    if (!typeOnlyAliasDeclaration || getSourceFileOfNode(typeOnlyAliasDeclaration) !== sourceFile)
-      return void 0;
-    return { kind: 4 /* PromoteTypeOnly */, typeOnlyAliasDeclaration };
-  }
-  function getSymbolNamesToImport(sourceFile, checker, symbolToken, compilerOptions) {
-    const parent2 = symbolToken.parent;
-    if ((isJsxOpeningLikeElement(parent2) || isJsxClosingElement(parent2)) && parent2.tagName === symbolToken && jsxModeNeedsExplicitImport(compilerOptions.jsx)) {
-      const jsxNamespace = checker.getJsxNamespace(sourceFile);
-      if (needsJsxNamespaceFix(jsxNamespace, symbolToken, checker)) {
-        const needsComponentNameFix = !isIntrinsicJsxName(symbolToken.text) && !checker.resolveName(
-          symbolToken.text,
-          symbolToken,
-          111551 /* Value */,
-          /*excludeGlobals*/
-          false
+    if (!inferences.length) {
+      return;
+    }
+    if (isArrowFunction(signature) || isFunctionExpression(signature)) {
+      const needParens = isArrowFunction(signature) && !findChildOfKind(signature, 21 /* OpenParenToken */, sourceFile);
+      if (needParens) {
+        changes.insertNodeBefore(sourceFile, first(signature.parameters), factory.createToken(21 /* OpenParenToken */));
+      }
+      forEach(inferences, ({ typeNode, param }) => {
+        const typeTag = factory.createJSDocTypeTag(
+          /*tagName*/
+          void 0,
+          factory.createJSDocTypeExpression(typeNode)
         );
-        return needsComponentNameFix ? [symbolToken.text, jsxNamespace] : [jsxNamespace];
+        const jsDoc = factory.createJSDocComment(
+          /*comment*/
+          void 0,
+          [typeTag]
+        );
+        changes.insertNodeAt(sourceFile, param.getStart(sourceFile), jsDoc, { suffix: " " });
+      });
+      if (needParens) {
+        changes.insertNodeAfter(sourceFile, last(signature.parameters), factory.createToken(22 /* CloseParenToken */));
       }
+    } else {
+      const paramTags = map(inferences, ({ name, typeNode, isOptional }) => factory.createJSDocParameterTag(
+        /*tagName*/
+        void 0,
+        name,
+        /*isBracketed*/
+        !!isOptional,
+        factory.createJSDocTypeExpression(typeNode),
+        /*isNameFirst*/
+        false,
+        /*comment*/
+        void 0
+      ));
+      changes.addJSDocTags(sourceFile, signature, paramTags);
     }
-    return [symbolToken.text];
   }
-  function needsJsxNamespaceFix(jsxNamespace, symbolToken, checker) {
-    if (isIntrinsicJsxName(symbolToken.text))
-      return true;
-    const namespaceSymbol = checker.resolveName(
-      jsxNamespace,
-      symbolToken,
-      111551 /* Value */,
-      /*excludeGlobals*/
-      true
-    );
-    return !namespaceSymbol || some(namespaceSymbol.declarations, isTypeOnlyImportOrExportDeclaration) && !(namespaceSymbol.flags & 111551 /* Value */);
+  function getReferences(token, program, cancellationToken) {
+    return mapDefined(ts_FindAllReferences_exports.getReferenceEntriesForNode(-1, token, program, program.getSourceFiles(), cancellationToken), (entry) => entry.kind !== ts_FindAllReferences_exports.EntryKind.Span ? tryCast(entry.node, isIdentifier) : void 0);
   }
-  function getExportInfos(symbolName2, isJsxTagName, currentTokenMeaning, cancellationToken, fromFile, program, useAutoImportProvider, host, preferences) {
-    var _a;
-    const originalSymbolToExportInfos = createMultiMap();
-    const packageJsonFilter = createPackageJsonImportFilter(fromFile, preferences, host);
-    const moduleSpecifierCache = (_a = host.getModuleSpecifierCache) == null ? void 0 : _a.call(host);
-    const getModuleSpecifierResolutionHost = memoizeOne((isFromPackageJson) => {
-      return createModuleSpecifierResolutionHost(isFromPackageJson ? host.getPackageJsonAutoImportProvider() : program, host);
-    });
-    function addSymbol(moduleSymbol, toFile, exportedSymbol, exportKind, program2, isFromPackageJson) {
-      const moduleSpecifierResolutionHost = getModuleSpecifierResolutionHost(isFromPackageJson);
-      if (toFile && isImportableFile(program2, fromFile, toFile, preferences, packageJsonFilter, moduleSpecifierResolutionHost, moduleSpecifierCache) || !toFile && packageJsonFilter.allowsImportingAmbientModule(moduleSymbol, moduleSpecifierResolutionHost)) {
-        const checker = program2.getTypeChecker();
-        originalSymbolToExportInfos.add(getUniqueSymbolId(exportedSymbol, checker).toString(), { symbol: exportedSymbol, moduleSymbol, moduleFileName: toFile == null ? void 0 : toFile.fileName, exportKind, targetFlags: skipAlias(exportedSymbol, checker).flags, isFromPackageJson });
+  function inferTypeForVariableFromUsage(token, program, cancellationToken) {
+    const references = getReferences(token, program, cancellationToken);
+    return inferTypeFromReferences(program, references, cancellationToken).single();
+  }
+  function inferTypeForParametersFromUsage(func, sourceFile, program, cancellationToken) {
+    const references = getFunctionReferences(func, sourceFile, program, cancellationToken);
+    return references && inferTypeFromReferences(program, references, cancellationToken).parameters(func) || func.parameters.map((p) => ({
+      declaration: p,
+      type: isIdentifier(p.name) ? inferTypeForVariableFromUsage(p.name, program, cancellationToken) : program.getTypeChecker().getAnyType()
+    }));
+  }
+  function getFunctionReferences(containingFunction, sourceFile, program, cancellationToken) {
+    let searchToken;
+    switch (containingFunction.kind) {
+      case 176 /* Constructor */:
+        searchToken = findChildOfKind(containingFunction, 137 /* ConstructorKeyword */, sourceFile);
+        break;
+      case 219 /* ArrowFunction */:
+      case 218 /* FunctionExpression */:
+        const parent2 = containingFunction.parent;
+        searchToken = (isVariableDeclaration(parent2) || isPropertyDeclaration(parent2)) && isIdentifier(parent2.name) ? parent2.name : containingFunction.name;
+        break;
+      case 262 /* FunctionDeclaration */:
+      case 174 /* MethodDeclaration */:
+      case 173 /* MethodSignature */:
+        searchToken = containingFunction.name;
+        break;
+    }
+    if (!searchToken) {
+      return void 0;
+    }
+    return getReferences(searchToken, program, cancellationToken);
+  }
+  function inferTypeFromReferences(program, references, cancellationToken) {
+    const checker = program.getTypeChecker();
+    const builtinConstructors = {
+      string: () => checker.getStringType(),
+      number: () => checker.getNumberType(),
+      Array: (t) => checker.createArrayType(t),
+      Promise: (t) => checker.createPromiseType(t)
+    };
+    const builtins = [
+      checker.getStringType(),
+      checker.getNumberType(),
+      checker.createArrayType(checker.getAnyType()),
+      checker.createPromiseType(checker.getAnyType())
+    ];
+    return {
+      single: single2,
+      parameters,
+      thisParameter
+    };
+    function createEmptyUsage() {
+      return {
+        isNumber: void 0,
+        isString: void 0,
+        isNumberOrString: void 0,
+        candidateTypes: void 0,
+        properties: void 0,
+        calls: void 0,
+        constructs: void 0,
+        numberIndex: void 0,
+        stringIndex: void 0,
+        candidateThisTypes: void 0,
+        inferredTypes: void 0
+      };
+    }
+    function combineUsages(usages) {
+      const combinedProperties = /* @__PURE__ */ new Map();
+      for (const u of usages) {
+        if (u.properties) {
+          u.properties.forEach((p, name) => {
+            if (!combinedProperties.has(name)) {
+              combinedProperties.set(name, []);
+            }
+            combinedProperties.get(name).push(p);
+          });
+        }
       }
+      const properties = /* @__PURE__ */ new Map();
+      combinedProperties.forEach((ps, name) => {
+        properties.set(name, combineUsages(ps));
+      });
+      return {
+        isNumber: usages.some((u) => u.isNumber),
+        isString: usages.some((u) => u.isString),
+        isNumberOrString: usages.some((u) => u.isNumberOrString),
+        candidateTypes: flatMap(usages, (u) => u.candidateTypes),
+        properties,
+        calls: flatMap(usages, (u) => u.calls),
+        constructs: flatMap(usages, (u) => u.constructs),
+        numberIndex: forEach(usages, (u) => u.numberIndex),
+        stringIndex: forEach(usages, (u) => u.stringIndex),
+        candidateThisTypes: flatMap(usages, (u) => u.candidateThisTypes),
+        inferredTypes: void 0
+        // clear type cache
+      };
     }
-    forEachExternalModuleToImportFrom(program, host, preferences, useAutoImportProvider, (moduleSymbol, sourceFile, program2, isFromPackageJson) => {
-      const checker = program2.getTypeChecker();
-      cancellationToken.throwIfCancellationRequested();
-      const compilerOptions = program2.getCompilerOptions();
-      const defaultInfo = getDefaultLikeExportInfo(moduleSymbol, checker, compilerOptions);
-      if (defaultInfo && (defaultInfo.name === symbolName2 || moduleSymbolToValidIdentifier(moduleSymbol, getEmitScriptTarget(compilerOptions), isJsxTagName) === symbolName2) && symbolHasMeaning(defaultInfo.resolvedSymbol, currentTokenMeaning)) {
-        addSymbol(moduleSymbol, sourceFile, defaultInfo.symbol, defaultInfo.exportKind, program2, isFromPackageJson);
+    function single2() {
+      return combineTypes(inferTypesFromReferencesSingle(references));
+    }
+    function parameters(declaration) {
+      if (references.length === 0 || !declaration.parameters) {
+        return void 0;
       }
-      const exportSymbolWithIdenticalName = checker.tryGetMemberInModuleExportsAndProperties(symbolName2, moduleSymbol);
-      if (exportSymbolWithIdenticalName && symbolHasMeaning(exportSymbolWithIdenticalName, currentTokenMeaning)) {
-        addSymbol(moduleSymbol, sourceFile, exportSymbolWithIdenticalName, 0 /* Named */, program2, isFromPackageJson);
+      const usage = createEmptyUsage();
+      for (const reference of references) {
+        cancellationToken.throwIfCancellationRequested();
+        calculateUsageOfNode(reference, usage);
       }
-    });
-    return originalSymbolToExportInfos;
-  }
-  function getExportEqualsImportKind(importingFile, compilerOptions, forceImportKeyword) {
-    const allowSyntheticDefaults = getAllowSyntheticDefaultImports(compilerOptions);
-    const isJS = isInJSFile(importingFile);
-    if (!isJS && getEmitModuleKind(compilerOptions) >= 5 /* ES2015 */) {
-      return allowSyntheticDefaults ? 1 /* Default */ : 2 /* Namespace */;
+      const calls = [...usage.constructs || [], ...usage.calls || []];
+      return declaration.parameters.map((parameter, parameterIndex) => {
+        const types = [];
+        const isRest = isRestParameter(parameter);
+        let isOptional = false;
+        for (const call of calls) {
+          if (call.argumentTypes.length <= parameterIndex) {
+            isOptional = isInJSFile(declaration);
+            types.push(checker.getUndefinedType());
+          } else if (isRest) {
+            for (let i = parameterIndex; i < call.argumentTypes.length; i++) {
+              types.push(checker.getBaseTypeOfLiteralType(call.argumentTypes[i]));
+            }
+          } else {
+            types.push(checker.getBaseTypeOfLiteralType(call.argumentTypes[parameterIndex]));
+          }
+        }
+        if (isIdentifier(parameter.name)) {
+          const inferred = inferTypesFromReferencesSingle(getReferences(parameter.name, program, cancellationToken));
+          types.push(...isRest ? mapDefined(inferred, checker.getElementTypeOfArrayType) : inferred);
+        }
+        const type = combineTypes(types);
+        return {
+          type: isRest ? checker.createArrayType(type) : type,
+          isOptional: isOptional && !isRest,
+          declaration: parameter
+        };
+      });
     }
-    if (isJS) {
-      return isExternalModule(importingFile) || forceImportKeyword ? allowSyntheticDefaults ? 1 /* Default */ : 2 /* Namespace */ : 3 /* CommonJS */;
+    function thisParameter() {
+      const usage = createEmptyUsage();
+      for (const reference of references) {
+        cancellationToken.throwIfCancellationRequested();
+        calculateUsageOfNode(reference, usage);
+      }
+      return combineTypes(usage.candidateThisTypes || emptyArray);
     }
-    for (const statement of importingFile.statements) {
-      if (isImportEqualsDeclaration(statement) && !nodeIsMissing(statement.moduleReference)) {
-        return 3 /* CommonJS */;
+    function inferTypesFromReferencesSingle(references2) {
+      const usage = createEmptyUsage();
+      for (const reference of references2) {
+        cancellationToken.throwIfCancellationRequested();
+        calculateUsageOfNode(reference, usage);
       }
+      return inferTypes(usage);
     }
-    return allowSyntheticDefaults ? 1 /* Default */ : 3 /* CommonJS */;
-  }
-  function codeActionForFix(context, sourceFile, symbolName2, fix, includeSymbolNameInDescription, compilerOptions, preferences) {
-    let diag2;
-    const changes = ts_textChanges_exports.ChangeTracker.with(context, (tracker) => {
-      diag2 = codeActionForFixWorker(tracker, sourceFile, symbolName2, fix, includeSymbolNameInDescription, compilerOptions, preferences);
-    });
-    return createCodeFixAction(importFixName, changes, diag2, importFixId, Diagnostics.Add_all_missing_imports);
-  }
-  function codeActionForFixWorker(changes, sourceFile, symbolName2, fix, includeSymbolNameInDescription, compilerOptions, preferences) {
-    const quotePreference = getQuotePreference(sourceFile, preferences);
-    switch (fix.kind) {
-      case 0 /* UseNamespace */:
-        addNamespaceQualifier(changes, sourceFile, fix);
-        return [Diagnostics.Change_0_to_1, symbolName2, `${fix.namespacePrefix}.${symbolName2}`];
-      case 1 /* JsdocTypeImport */:
-        addImportType(changes, sourceFile, fix, quotePreference);
-        return [Diagnostics.Change_0_to_1, symbolName2, getImportTypePrefix(fix.moduleSpecifier, quotePreference) + symbolName2];
-      case 2 /* AddToExisting */: {
-        const { importClauseOrBindingPattern, importKind, addAsTypeOnly, moduleSpecifier } = fix;
-        doAddExistingFix(
-          changes,
-          sourceFile,
-          importClauseOrBindingPattern,
-          importKind === 1 /* Default */ ? { name: symbolName2, addAsTypeOnly } : void 0,
-          importKind === 0 /* Named */ ? [{ name: symbolName2, addAsTypeOnly }] : emptyArray,
-          preferences
-        );
-        const moduleSpecifierWithoutQuotes = stripQuotes(moduleSpecifier);
-        return includeSymbolNameInDescription ? [Diagnostics.Import_0_from_1, symbolName2, moduleSpecifierWithoutQuotes] : [Diagnostics.Update_import_from_0, moduleSpecifierWithoutQuotes];
+    function calculateUsageOfNode(node, usage) {
+      while (isRightSideOfQualifiedNameOrPropertyAccess(node)) {
+        node = node.parent;
       }
-      case 3 /* AddNew */: {
-        const { importKind, moduleSpecifier, addAsTypeOnly, useRequire, qualification } = fix;
-        const getDeclarations = useRequire ? getNewRequires : getNewImports;
-        const defaultImport = importKind === 1 /* Default */ ? { name: symbolName2, addAsTypeOnly } : void 0;
-        const namedImports = importKind === 0 /* Named */ ? [{ name: symbolName2, addAsTypeOnly }] : void 0;
-        const namespaceLikeImport = importKind === 2 /* Namespace */ || importKind === 3 /* CommonJS */ ? { importKind, name: (qualification == null ? void 0 : qualification.namespacePrefix) || symbolName2, addAsTypeOnly } : void 0;
-        insertImports(
-          changes,
-          sourceFile,
-          getDeclarations(
-            moduleSpecifier,
-            quotePreference,
-            defaultImport,
-            namedImports,
-            namespaceLikeImport,
-            compilerOptions
-          ),
-          /*blankLineBetween*/
-          true,
-          preferences
-        );
-        if (qualification) {
-          addNamespaceQualifier(changes, sourceFile, qualification);
+      switch (node.parent.kind) {
+        case 244 /* ExpressionStatement */:
+          inferTypeFromExpressionStatement(node, usage);
+          break;
+        case 225 /* PostfixUnaryExpression */:
+          usage.isNumber = true;
+          break;
+        case 224 /* PrefixUnaryExpression */:
+          inferTypeFromPrefixUnaryExpression(node.parent, usage);
+          break;
+        case 226 /* BinaryExpression */:
+          inferTypeFromBinaryExpression(node, node.parent, usage);
+          break;
+        case 296 /* CaseClause */:
+        case 297 /* DefaultClause */:
+          inferTypeFromSwitchStatementLabel(node.parent, usage);
+          break;
+        case 213 /* CallExpression */:
+        case 214 /* NewExpression */:
+          if (node.parent.expression === node) {
+            inferTypeFromCallExpression(node.parent, usage);
+          } else {
+            inferTypeFromContextualType(node, usage);
+          }
+          break;
+        case 211 /* PropertyAccessExpression */:
+          inferTypeFromPropertyAccessExpression(node.parent, usage);
+          break;
+        case 212 /* ElementAccessExpression */:
+          inferTypeFromPropertyElementExpression(node.parent, node, usage);
+          break;
+        case 303 /* PropertyAssignment */:
+        case 304 /* ShorthandPropertyAssignment */:
+          inferTypeFromPropertyAssignment(node.parent, usage);
+          break;
+        case 172 /* PropertyDeclaration */:
+          inferTypeFromPropertyDeclaration(node.parent, usage);
+          break;
+        case 260 /* VariableDeclaration */: {
+          const { name, initializer } = node.parent;
+          if (node === name) {
+            if (initializer) {
+              addCandidateType(usage, checker.getTypeAtLocation(initializer));
+            }
+            break;
+          }
         }
-        return includeSymbolNameInDescription ? [Diagnostics.Import_0_from_1, symbolName2, moduleSpecifier] : [Diagnostics.Add_import_from_0, moduleSpecifier];
+        default:
+          return inferTypeFromContextualType(node, usage);
       }
-      case 4 /* PromoteTypeOnly */: {
-        const { typeOnlyAliasDeclaration } = fix;
-        const promotedDeclaration = promoteFromTypeOnly(changes, typeOnlyAliasDeclaration, compilerOptions, sourceFile, preferences);
-        return promotedDeclaration.kind === 275 /* ImportSpecifier */ ? [Diagnostics.Remove_type_from_import_of_0_from_1, symbolName2, getModuleSpecifierText(promotedDeclaration.parent.parent)] : [Diagnostics.Remove_type_from_import_declaration_from_0, getModuleSpecifierText(promotedDeclaration)];
+    }
+    function inferTypeFromContextualType(node, usage) {
+      if (isExpressionNode(node)) {
+        addCandidateType(usage, checker.getContextualType(node));
       }
-      default:
-        return Debug.assertNever(fix, `Unexpected fix kind ${fix.kind}`);
     }
-  }
-  function getModuleSpecifierText(promotedDeclaration) {
-    var _a, _b;
-    return promotedDeclaration.kind === 270 /* ImportEqualsDeclaration */ ? ((_b = tryCast((_a = tryCast(promotedDeclaration.moduleReference, isExternalModuleReference)) == null ? void 0 : _a.expression, isStringLiteralLike)) == null ? void 0 : _b.text) || promotedDeclaration.moduleReference.getText() : cast(promotedDeclaration.parent.moduleSpecifier, isStringLiteral).text;
-  }
-  function promoteFromTypeOnly(changes, aliasDeclaration, compilerOptions, sourceFile, preferences) {
-    const convertExistingToTypeOnly = importNameElisionDisabled(compilerOptions);
-    switch (aliasDeclaration.kind) {
-      case 275 /* ImportSpecifier */:
-        if (aliasDeclaration.isTypeOnly) {
-          const sortKind = ts_OrganizeImports_exports.detectImportSpecifierSorting(aliasDeclaration.parent.elements, preferences);
-          if (aliasDeclaration.parent.elements.length > 1 && sortKind) {
-            changes.delete(sourceFile, aliasDeclaration);
-            const newSpecifier = factory.updateImportSpecifier(
-              aliasDeclaration,
-              /*isTypeOnly*/
-              false,
-              aliasDeclaration.propertyName,
-              aliasDeclaration.name
-            );
-            const comparer = ts_OrganizeImports_exports.getOrganizeImportsComparer(preferences, sortKind === 2 /* CaseInsensitive */);
-            const insertionIndex = ts_OrganizeImports_exports.getImportSpecifierInsertionIndex(aliasDeclaration.parent.elements, newSpecifier, comparer);
-            changes.insertImportSpecifierAtIndex(sourceFile, newSpecifier, aliasDeclaration.parent, insertionIndex);
+    function inferTypeFromExpressionStatement(node, usage) {
+      addCandidateType(usage, isCallExpression(node) ? checker.getVoidType() : checker.getAnyType());
+    }
+    function inferTypeFromPrefixUnaryExpression(node, usage) {
+      switch (node.operator) {
+        case 46 /* PlusPlusToken */:
+        case 47 /* MinusMinusToken */:
+        case 41 /* MinusToken */:
+        case 55 /* TildeToken */:
+          usage.isNumber = true;
+          break;
+        case 40 /* PlusToken */:
+          usage.isNumberOrString = true;
+          break;
+      }
+    }
+    function inferTypeFromBinaryExpression(node, parent2, usage) {
+      switch (parent2.operatorToken.kind) {
+        case 43 /* AsteriskAsteriskToken */:
+        case 42 /* AsteriskToken */:
+        case 44 /* SlashToken */:
+        case 45 /* PercentToken */:
+        case 48 /* LessThanLessThanToken */:
+        case 49 /* GreaterThanGreaterThanToken */:
+        case 50 /* GreaterThanGreaterThanGreaterThanToken */:
+        case 51 /* AmpersandToken */:
+        case 52 /* BarToken */:
+        case 53 /* CaretToken */:
+        case 66 /* MinusEqualsToken */:
+        case 68 /* AsteriskAsteriskEqualsToken */:
+        case 67 /* AsteriskEqualsToken */:
+        case 69 /* SlashEqualsToken */:
+        case 70 /* PercentEqualsToken */:
+        case 74 /* AmpersandEqualsToken */:
+        case 75 /* BarEqualsToken */:
+        case 79 /* CaretEqualsToken */:
+        case 71 /* LessThanLessThanEqualsToken */:
+        case 73 /* GreaterThanGreaterThanGreaterThanEqualsToken */:
+        case 72 /* GreaterThanGreaterThanEqualsToken */:
+        case 41 /* MinusToken */:
+        case 30 /* LessThanToken */:
+        case 33 /* LessThanEqualsToken */:
+        case 32 /* GreaterThanToken */:
+        case 34 /* GreaterThanEqualsToken */:
+          const operandType = checker.getTypeAtLocation(parent2.left === node ? parent2.right : parent2.left);
+          if (operandType.flags & 1056 /* EnumLike */) {
+            addCandidateType(usage, operandType);
           } else {
-            changes.deleteRange(sourceFile, aliasDeclaration.getFirstToken());
+            usage.isNumber = true;
           }
-          return aliasDeclaration;
-        } else {
-          Debug.assert(aliasDeclaration.parent.parent.isTypeOnly);
-          promoteImportClause(aliasDeclaration.parent.parent);
-          return aliasDeclaration.parent.parent;
-        }
-      case 272 /* ImportClause */:
-        promoteImportClause(aliasDeclaration);
-        return aliasDeclaration;
-      case 273 /* NamespaceImport */:
-        promoteImportClause(aliasDeclaration.parent);
-        return aliasDeclaration.parent;
-      case 270 /* ImportEqualsDeclaration */:
-        changes.deleteRange(sourceFile, aliasDeclaration.getChildAt(1));
-        return aliasDeclaration;
-      default:
-        Debug.failBadSyntaxKind(aliasDeclaration);
-    }
-    function promoteImportClause(importClause) {
-      changes.delete(sourceFile, getTypeKeywordOfTypeOnlyImport(importClause, sourceFile));
-      if (convertExistingToTypeOnly) {
-        const namedImports = tryCast(importClause.namedBindings, isNamedImports);
-        if (namedImports && namedImports.elements.length > 1) {
-          if (ts_OrganizeImports_exports.detectImportSpecifierSorting(namedImports.elements, preferences) && aliasDeclaration.kind === 275 /* ImportSpecifier */ && namedImports.elements.indexOf(aliasDeclaration) !== 0) {
-            changes.delete(sourceFile, aliasDeclaration);
-            changes.insertImportSpecifierAtIndex(sourceFile, aliasDeclaration, namedImports, 0);
+          break;
+        case 65 /* PlusEqualsToken */:
+        case 40 /* PlusToken */:
+          const otherOperandType = checker.getTypeAtLocation(parent2.left === node ? parent2.right : parent2.left);
+          if (otherOperandType.flags & 1056 /* EnumLike */) {
+            addCandidateType(usage, otherOperandType);
+          } else if (otherOperandType.flags & 296 /* NumberLike */) {
+            usage.isNumber = true;
+          } else if (otherOperandType.flags & 402653316 /* StringLike */) {
+            usage.isString = true;
+          } else if (otherOperandType.flags & 1 /* Any */) {
+          } else {
+            usage.isNumberOrString = true;
           }
-          for (const element of namedImports.elements) {
-            if (element !== aliasDeclaration && !element.isTypeOnly) {
-              changes.insertModifierBefore(sourceFile, 156 /* TypeKeyword */, element);
-            }
+          break;
+        case 64 /* EqualsToken */:
+        case 35 /* EqualsEqualsToken */:
+        case 37 /* EqualsEqualsEqualsToken */:
+        case 38 /* ExclamationEqualsEqualsToken */:
+        case 36 /* ExclamationEqualsToken */:
+        case 77 /* AmpersandAmpersandEqualsToken */:
+        case 78 /* QuestionQuestionEqualsToken */:
+        case 76 /* BarBarEqualsToken */:
+          addCandidateType(usage, checker.getTypeAtLocation(parent2.left === node ? parent2.right : parent2.left));
+          break;
+        case 103 /* InKeyword */:
+          if (node === parent2.left) {
+            usage.isString = true;
           }
-        }
-      }
-    }
-  }
-  function doAddExistingFix(changes, sourceFile, clause, defaultImport, namedImports, preferences) {
-    var _a;
-    if (clause.kind === 205 /* ObjectBindingPattern */) {
-      if (defaultImport) {
-        addElementToBindingPattern(clause, defaultImport.name, "default");
-      }
-      for (const specifier of namedImports) {
-        addElementToBindingPattern(
-          clause,
-          specifier.name,
-          /*propertyName*/
-          void 0
-        );
+          break;
+        case 57 /* BarBarToken */:
+        case 61 /* QuestionQuestionToken */:
+          if (node === parent2.left && (node.parent.parent.kind === 260 /* VariableDeclaration */ || isAssignmentExpression(
+            node.parent.parent,
+            /*excludeCompoundAssignment*/
+            true
+          ))) {
+            addCandidateType(usage, checker.getTypeAtLocation(parent2.right));
+          }
+          break;
+        case 56 /* AmpersandAmpersandToken */:
+        case 28 /* CommaToken */:
+        case 104 /* InstanceOfKeyword */:
+          break;
       }
-      return;
     }
-    const promoteFromTypeOnly2 = clause.isTypeOnly && some([defaultImport, ...namedImports], (i) => (i == null ? void 0 : i.addAsTypeOnly) === 4 /* NotAllowed */);
-    const existingSpecifiers = clause.namedBindings && ((_a = tryCast(clause.namedBindings, isNamedImports)) == null ? void 0 : _a.elements);
-    if (defaultImport) {
-      Debug.assert(!clause.name, "Cannot add a default import to an import clause that already has one");
-      changes.insertNodeAt(sourceFile, clause.getStart(sourceFile), factory.createIdentifier(defaultImport.name), { suffix: ", " });
+    function inferTypeFromSwitchStatementLabel(parent2, usage) {
+      addCandidateType(usage, checker.getTypeAtLocation(parent2.parent.parent.expression));
     }
-    if (namedImports.length) {
-      let ignoreCaseForSorting;
-      if (typeof preferences.organizeImportsIgnoreCase === "boolean") {
-        ignoreCaseForSorting = preferences.organizeImportsIgnoreCase;
-      } else if (existingSpecifiers) {
-        const targetImportSorting = ts_OrganizeImports_exports.detectImportSpecifierSorting(existingSpecifiers, preferences);
-        if (targetImportSorting !== 3 /* Both */) {
-          ignoreCaseForSorting = targetImportSorting === 2 /* CaseInsensitive */;
+    function inferTypeFromCallExpression(parent2, usage) {
+      const call = {
+        argumentTypes: [],
+        return_: createEmptyUsage()
+      };
+      if (parent2.arguments) {
+        for (const argument of parent2.arguments) {
+          call.argumentTypes.push(checker.getTypeAtLocation(argument));
         }
       }
-      if (ignoreCaseForSorting === void 0) {
-        ignoreCaseForSorting = ts_OrganizeImports_exports.detectSorting(sourceFile, preferences) === 2 /* CaseInsensitive */;
-      }
-      const comparer = ts_OrganizeImports_exports.getOrganizeImportsComparer(preferences, ignoreCaseForSorting);
-      const newSpecifiers = stableSort(
-        namedImports.map((namedImport) => factory.createImportSpecifier(
-          (!clause.isTypeOnly || promoteFromTypeOnly2) && needsTypeOnly(namedImport),
-          /*propertyName*/
-          void 0,
-          factory.createIdentifier(namedImport.name)
-        )),
-        (s1, s2) => ts_OrganizeImports_exports.compareImportOrExportSpecifiers(s1, s2, comparer)
-      );
-      const specifierSort = (existingSpecifiers == null ? void 0 : existingSpecifiers.length) && ts_OrganizeImports_exports.detectImportSpecifierSorting(existingSpecifiers, preferences);
-      if (specifierSort && !(ignoreCaseForSorting && specifierSort === 1 /* CaseSensitive */)) {
-        for (const spec of newSpecifiers) {
-          const insertionIndex = promoteFromTypeOnly2 && !spec.isTypeOnly ? 0 : ts_OrganizeImports_exports.getImportSpecifierInsertionIndex(existingSpecifiers, spec, comparer);
-          changes.insertImportSpecifierAtIndex(sourceFile, spec, clause.namedBindings, insertionIndex);
-        }
-      } else if (existingSpecifiers == null ? void 0 : existingSpecifiers.length) {
-        for (const spec of newSpecifiers) {
-          changes.insertNodeInListAfter(sourceFile, last(existingSpecifiers), spec, existingSpecifiers);
-        }
+      calculateUsageOfNode(parent2, call.return_);
+      if (parent2.kind === 213 /* CallExpression */) {
+        (usage.calls || (usage.calls = [])).push(call);
       } else {
-        if (newSpecifiers.length) {
-          const namedImports2 = factory.createNamedImports(newSpecifiers);
-          if (clause.namedBindings) {
-            changes.replaceNode(sourceFile, clause.namedBindings, namedImports2);
-          } else {
-            changes.insertNodeAfter(sourceFile, Debug.checkDefined(clause.name, "Import clause must have either named imports or a default import"), namedImports2);
-          }
-        }
+        (usage.constructs || (usage.constructs = [])).push(call);
       }
     }
-    if (promoteFromTypeOnly2) {
-      changes.delete(sourceFile, getTypeKeywordOfTypeOnlyImport(clause, sourceFile));
-      if (existingSpecifiers) {
-        for (const specifier of existingSpecifiers) {
-          changes.insertModifierBefore(sourceFile, 156 /* TypeKeyword */, specifier);
-        }
+    function inferTypeFromPropertyAccessExpression(parent2, usage) {
+      const name = escapeLeadingUnderscores(parent2.name.text);
+      if (!usage.properties) {
+        usage.properties = /* @__PURE__ */ new Map();
       }
+      const propertyUsage = usage.properties.get(name) || createEmptyUsage();
+      calculateUsageOfNode(parent2, propertyUsage);
+      usage.properties.set(name, propertyUsage);
     }
-    function addElementToBindingPattern(bindingPattern, name, propertyName) {
-      const element = factory.createBindingElement(
-        /*dotDotDotToken*/
-        void 0,
-        propertyName,
-        name
-      );
-      if (bindingPattern.elements.length) {
-        changes.insertNodeInListAfter(sourceFile, last(bindingPattern.elements), element);
+    function inferTypeFromPropertyElementExpression(parent2, node, usage) {
+      if (node === parent2.argumentExpression) {
+        usage.isNumberOrString = true;
+        return;
       } else {
-        changes.replaceNode(sourceFile, bindingPattern, factory.createObjectBindingPattern([element]));
+        const indexType = checker.getTypeAtLocation(parent2.argumentExpression);
+        const indexUsage = createEmptyUsage();
+        calculateUsageOfNode(parent2, indexUsage);
+        if (indexType.flags & 296 /* NumberLike */) {
+          usage.numberIndex = indexUsage;
+        } else {
+          usage.stringIndex = indexUsage;
+        }
       }
     }
-  }
-  function addNamespaceQualifier(changes, sourceFile, { namespacePrefix, usagePosition }) {
-    changes.insertText(sourceFile, usagePosition, namespacePrefix + ".");
-  }
-  function addImportType(changes, sourceFile, { moduleSpecifier, usagePosition: position }, quotePreference) {
-    changes.insertText(sourceFile, position, getImportTypePrefix(moduleSpecifier, quotePreference));
-  }
-  function getImportTypePrefix(moduleSpecifier, quotePreference) {
-    const quote2 = getQuoteFromPreference(quotePreference);
-    return `import(${quote2}${moduleSpecifier}${quote2}).`;
-  }
-  function needsTypeOnly({ addAsTypeOnly }) {
-    return addAsTypeOnly === 2 /* Required */;
-  }
-  function getNewImports(moduleSpecifier, quotePreference, defaultImport, namedImports, namespaceLikeImport, compilerOptions) {
-    const quotedModuleSpecifier = makeStringLiteral(moduleSpecifier, quotePreference);
-    let statements;
-    if (defaultImport !== void 0 || (namedImports == null ? void 0 : namedImports.length)) {
-      const topLevelTypeOnly = (!defaultImport || needsTypeOnly(defaultImport)) && every(namedImports, needsTypeOnly) || compilerOptions.verbatimModuleSyntax && (defaultImport == null ? void 0 : defaultImport.addAsTypeOnly) !== 4 /* NotAllowed */ && !some(namedImports, (i) => i.addAsTypeOnly === 4 /* NotAllowed */);
-      statements = combine(statements, makeImport(
-        defaultImport && factory.createIdentifier(defaultImport.name),
-        namedImports == null ? void 0 : namedImports.map(({ addAsTypeOnly, name }) => factory.createImportSpecifier(
-          !topLevelTypeOnly && addAsTypeOnly === 2 /* Required */,
-          /*propertyName*/
-          void 0,
-          factory.createIdentifier(name)
-        )),
-        moduleSpecifier,
-        quotePreference,
-        topLevelTypeOnly
-      ));
+    function inferTypeFromPropertyAssignment(assignment, usage) {
+      const nodeWithRealType = isVariableDeclaration(assignment.parent.parent) ? assignment.parent.parent : assignment.parent;
+      addCandidateThisType(usage, checker.getTypeAtLocation(nodeWithRealType));
     }
-    if (namespaceLikeImport) {
-      const declaration = namespaceLikeImport.importKind === 3 /* CommonJS */ ? factory.createImportEqualsDeclaration(
-        /*modifiers*/
-        void 0,
-        needsTypeOnly(namespaceLikeImport),
-        factory.createIdentifier(namespaceLikeImport.name),
-        factory.createExternalModuleReference(quotedModuleSpecifier)
-      ) : factory.createImportDeclaration(
-        /*modifiers*/
-        void 0,
-        factory.createImportClause(
-          needsTypeOnly(namespaceLikeImport),
-          /*name*/
-          void 0,
-          factory.createNamespaceImport(factory.createIdentifier(namespaceLikeImport.name))
-        ),
-        quotedModuleSpecifier,
-        /*assertClause*/
-        void 0
-      );
-      statements = combine(statements, declaration);
+    function inferTypeFromPropertyDeclaration(declaration, usage) {
+      addCandidateThisType(usage, checker.getTypeAtLocation(declaration.parent));
     }
-    return Debug.checkDefined(statements);
-  }
-  function getNewRequires(moduleSpecifier, quotePreference, defaultImport, namedImports, namespaceLikeImport) {
-    const quotedModuleSpecifier = makeStringLiteral(moduleSpecifier, quotePreference);
-    let statements;
-    if (defaultImport || (namedImports == null ? void 0 : namedImports.length)) {
-      const bindingElements = (namedImports == null ? void 0 : namedImports.map(({ name }) => factory.createBindingElement(
-        /*dotDotDotToken*/
-        void 0,
-        /*propertyName*/
-        void 0,
-        name
-      ))) || [];
-      if (defaultImport) {
-        bindingElements.unshift(factory.createBindingElement(
-          /*dotDotDotToken*/
-          void 0,
-          "default",
-          defaultImport.name
-        ));
+    function removeLowPriorityInferences(inferences, priorities) {
+      const toRemove = [];
+      for (const i of inferences) {
+        for (const { high, low } of priorities) {
+          if (high(i)) {
+            Debug.assert(!low(i), "Priority can't have both low and high");
+            toRemove.push(low);
+          }
+        }
       }
-      const declaration = createConstEqualsRequireDeclaration(factory.createObjectBindingPattern(bindingElements), quotedModuleSpecifier);
-      statements = combine(statements, declaration);
-    }
-    if (namespaceLikeImport) {
-      const declaration = createConstEqualsRequireDeclaration(namespaceLikeImport.name, quotedModuleSpecifier);
-      statements = combine(statements, declaration);
+      return inferences.filter((i) => toRemove.every((f) => !f(i)));
     }
-    return Debug.checkDefined(statements);
-  }
-  function createConstEqualsRequireDeclaration(name, quotedModuleSpecifier) {
-    return factory.createVariableStatement(
-      /*modifiers*/
-      void 0,
-      factory.createVariableDeclarationList(
-        [
-          factory.createVariableDeclaration(
-            typeof name === "string" ? factory.createIdentifier(name) : name,
-            /*exclamationToken*/
-            void 0,
-            /*type*/
-            void 0,
-            factory.createCallExpression(
-              factory.createIdentifier("require"),
-              /*typeArguments*/
-              void 0,
-              [quotedModuleSpecifier]
-            )
-          )
-        ],
-        2 /* Const */
-      )
-    );
-  }
-  function symbolHasMeaning({ declarations }, meaning) {
-    return some(declarations, (decl) => !!(getMeaningFromDeclaration(decl) & meaning));
-  }
-  function moduleSymbolToValidIdentifier(moduleSymbol, target, forceCapitalize) {
-    return moduleSpecifierToValidIdentifier(removeFileExtension(stripQuotes(moduleSymbol.name)), target, forceCapitalize);
-  }
-  function moduleSpecifierToValidIdentifier(moduleSpecifier, target, forceCapitalize) {
-    const baseName = getBaseFileName(removeSuffix(moduleSpecifier, "/index"));
-    let res = "";
-    let lastCharWasValid = true;
-    const firstCharCode = baseName.charCodeAt(0);
-    if (isIdentifierStart(firstCharCode, target)) {
-      res += String.fromCharCode(firstCharCode);
-      if (forceCapitalize) {
-        res = res.toUpperCase();
-      }
-    } else {
-      lastCharWasValid = false;
+    function combineFromUsage(usage) {
+      return combineTypes(inferTypes(usage));
     }
-    for (let i = 1; i < baseName.length; i++) {
-      const ch = baseName.charCodeAt(i);
-      const isValid = isIdentifierPart(ch, target);
-      if (isValid) {
-        let char = String.fromCharCode(ch);
-        if (!lastCharWasValid) {
-          char = char.toUpperCase();
+    function combineTypes(inferences) {
+      if (!inferences.length)
+        return checker.getAnyType();
+      const stringNumber = checker.getUnionType([checker.getStringType(), checker.getNumberType()]);
+      const priorities = [
+        {
+          high: (t) => t === checker.getStringType() || t === checker.getNumberType(),
+          low: (t) => t === stringNumber
+        },
+        {
+          high: (t) => !(t.flags & (1 /* Any */ | 16384 /* Void */)),
+          low: (t) => !!(t.flags & (1 /* Any */ | 16384 /* Void */))
+        },
+        {
+          high: (t) => !(t.flags & (98304 /* Nullable */ | 1 /* Any */ | 16384 /* Void */)) && !(getObjectFlags(t) & 16 /* Anonymous */),
+          low: (t) => !!(getObjectFlags(t) & 16 /* Anonymous */)
         }
-        res += char;
+      ];
+      let good = removeLowPriorityInferences(inferences, priorities);
+      const anons = good.filter((i) => getObjectFlags(i) & 16 /* Anonymous */);
+      if (anons.length) {
+        good = good.filter((i) => !(getObjectFlags(i) & 16 /* Anonymous */));
+        good.push(combineAnonymousTypes(anons));
       }
-      lastCharWasValid = isValid;
+      return checker.getWidenedType(checker.getUnionType(good.map(checker.getBaseTypeOfLiteralType), 2 /* Subtype */));
     }
-    return !isStringANonContextualKeyword(res) ? res || "_" : `_${res}`;
-  }
-  var importFixName, importFixId, errorCodes18;
-  var init_importFixes = __esm({
-    "src/services/codefixes/importFixes.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_codefix();
-      importFixName = "import";
-      importFixId = "fixMissingImport";
-      errorCodes18 = [
-        Diagnostics.Cannot_find_name_0.code,
-        Diagnostics.Cannot_find_name_0_Did_you_mean_1.code,
-        Diagnostics.Cannot_find_name_0_Did_you_mean_the_instance_member_this_0.code,
-        Diagnostics.Cannot_find_name_0_Did_you_mean_the_static_member_1_0.code,
-        Diagnostics.Cannot_find_namespace_0.code,
-        Diagnostics._0_refers_to_a_UMD_global_but_the_current_file_is_a_module_Consider_adding_an_import_instead.code,
-        Diagnostics._0_only_refers_to_a_type_but_is_being_used_as_a_value_here.code,
-        Diagnostics.No_value_exists_in_scope_for_the_shorthand_property_0_Either_declare_one_or_provide_an_initializer.code,
-        Diagnostics._0_cannot_be_used_as_a_value_because_it_was_imported_using_import_type.code
-      ];
-      registerCodeFix({
-        errorCodes: errorCodes18,
-        getCodeActions(context) {
-          const { errorCode, preferences, sourceFile, span, program } = context;
-          const info = getFixInfos(
-            context,
-            errorCode,
-            span.start,
-            /*useAutoImportProvider*/
-            true
-          );
-          if (!info)
-            return void 0;
-          return info.map(({ fix, symbolName: symbolName2, errorIdentifierText }) => codeActionForFix(
-            context,
-            sourceFile,
-            symbolName2,
-            fix,
-            /*includeSymbolNameInDescription*/
-            symbolName2 !== errorIdentifierText,
-            program.getCompilerOptions(),
-            preferences
-          ));
-        },
-        fixIds: [importFixId],
-        getAllCodeActions: (context) => {
-          const { sourceFile, program, preferences, host, cancellationToken } = context;
-          const importAdder = createImportAdderWorker(
-            sourceFile,
-            program,
-            /*useAutoImportProvider*/
-            true,
-            preferences,
-            host,
-            cancellationToken
-          );
-          eachDiagnostic(context, errorCodes18, (diag2) => importAdder.addImportFromDiagnostic(diag2, context));
-          return createCombinedCodeActions(ts_textChanges_exports.ChangeTracker.with(context, importAdder.writeFixes));
+    function combineAnonymousTypes(anons) {
+      if (anons.length === 1) {
+        return anons[0];
+      }
+      const calls = [];
+      const constructs = [];
+      const stringIndices = [];
+      const numberIndices = [];
+      let stringIndexReadonly = false;
+      let numberIndexReadonly = false;
+      const props = createMultiMap();
+      for (const anon2 of anons) {
+        for (const p of checker.getPropertiesOfType(anon2)) {
+          props.add(p.escapedName, p.valueDeclaration ? checker.getTypeOfSymbolAtLocation(p, p.valueDeclaration) : checker.getAnyType());
+        }
+        calls.push(...checker.getSignaturesOfType(anon2, 0 /* Call */));
+        constructs.push(...checker.getSignaturesOfType(anon2, 1 /* Construct */));
+        const stringIndexInfo = checker.getIndexInfoOfType(anon2, 0 /* String */);
+        if (stringIndexInfo) {
+          stringIndices.push(stringIndexInfo.type);
+          stringIndexReadonly = stringIndexReadonly || stringIndexInfo.isReadonly;
+        }
+        const numberIndexInfo = checker.getIndexInfoOfType(anon2, 1 /* Number */);
+        if (numberIndexInfo) {
+          numberIndices.push(numberIndexInfo.type);
+          numberIndexReadonly = numberIndexReadonly || numberIndexInfo.isReadonly;
         }
+      }
+      const members = mapEntries(props, (name, types) => {
+        const isOptional = types.length < anons.length ? 16777216 /* Optional */ : 0;
+        const s = checker.createSymbol(4 /* Property */ | isOptional, name);
+        s.links.type = checker.getUnionType(types);
+        return [name, s];
       });
-    }
-  });
-
-  // src/services/codefixes/fixAddMissingConstraint.ts
-  function getInfo6(program, sourceFile, span) {
-    const diag2 = find(program.getSemanticDiagnostics(sourceFile), (diag3) => diag3.start === span.start && diag3.length === span.length);
-    if (diag2 === void 0 || diag2.relatedInformation === void 0)
-      return;
-    const related = find(diag2.relatedInformation, (related2) => related2.code === Diagnostics.This_type_parameter_might_need_an_extends_0_constraint.code);
-    if (related === void 0 || related.file === void 0 || related.start === void 0 || related.length === void 0)
-      return;
-    let declaration = findAncestorMatchingSpan(related.file, createTextSpan(related.start, related.length));
-    if (declaration === void 0)
-      return;
-    if (isIdentifier(declaration) && isTypeParameterDeclaration(declaration.parent)) {
-      declaration = declaration.parent;
-    }
-    if (isTypeParameterDeclaration(declaration)) {
-      if (isMappedTypeNode(declaration.parent))
-        return;
-      const token = getTokenAtPosition(sourceFile, span.start);
-      const checker = program.getTypeChecker();
-      const constraint = tryGetConstraintType(checker, token) || tryGetConstraintFromDiagnosticMessage(related.messageText);
-      return { constraint, declaration, token };
-    }
-    return void 0;
-  }
-  function addMissingConstraint(changes, program, preferences, host, sourceFile, info) {
-    const { declaration, constraint } = info;
-    const checker = program.getTypeChecker();
-    if (isString(constraint)) {
-      changes.insertText(sourceFile, declaration.name.end, ` extends ${constraint}`);
-    } else {
-      const scriptTarget = getEmitScriptTarget(program.getCompilerOptions());
-      const tracker = getNoopSymbolTrackerWithResolver({ program, host });
-      const importAdder = createImportAdder(sourceFile, program, preferences, host);
-      const typeNode = typeToAutoImportableTypeNode(
-        checker,
-        importAdder,
-        constraint,
-        /*contextNode*/
-        void 0,
-        scriptTarget,
-        /*flags*/
-        void 0,
-        tracker
+      const indexInfos = [];
+      if (stringIndices.length)
+        indexInfos.push(checker.createIndexInfo(checker.getStringType(), checker.getUnionType(stringIndices), stringIndexReadonly));
+      if (numberIndices.length)
+        indexInfos.push(checker.createIndexInfo(checker.getNumberType(), checker.getUnionType(numberIndices), numberIndexReadonly));
+      return checker.createAnonymousType(
+        anons[0].symbol,
+        members,
+        calls,
+        constructs,
+        indexInfos
       );
-      if (typeNode) {
-        changes.replaceNode(sourceFile, declaration, factory.updateTypeParameterDeclaration(
-          declaration,
-          /*modifiers*/
-          void 0,
-          declaration.name,
-          typeNode,
-          declaration.default
-        ));
-        importAdder.writeFixes(changes);
-      }
     }
-  }
-  function tryGetConstraintFromDiagnosticMessage(messageText) {
-    const [_, constraint] = flattenDiagnosticMessageText(messageText, "\n", 0).match(/`extends (.*)`/) || [];
-    return constraint;
-  }
-  function tryGetConstraintType(checker, node) {
-    if (isTypeNode(node.parent)) {
-      return checker.getTypeArgumentConstraint(node.parent);
-    }
-    const contextualType = isExpression(node) ? checker.getContextualType(node) : void 0;
-    return contextualType || checker.getTypeAtLocation(node);
-  }
-  var fixId17, errorCodes19;
-  var init_fixAddMissingConstraint = __esm({
-    "src/services/codefixes/fixAddMissingConstraint.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_codefix();
-      fixId17 = "addMissingConstraint";
-      errorCodes19 = [
-        // We want errors this could be attached to:
-        // Diagnostics.This_type_parameter_probably_needs_an_extends_0_constraint
-        Diagnostics.Type_0_is_not_comparable_to_type_1.code,
-        Diagnostics.Type_0_is_not_assignable_to_type_1_Two_different_types_with_this_name_exist_but_they_are_unrelated.code,
-        Diagnostics.Type_0_is_not_assignable_to_type_1_with_exactOptionalPropertyTypes_Colon_true_Consider_adding_undefined_to_the_types_of_the_target_s_properties.code,
-        Diagnostics.Type_0_is_not_assignable_to_type_1.code,
-        Diagnostics.Argument_of_type_0_is_not_assignable_to_parameter_of_type_1_with_exactOptionalPropertyTypes_Colon_true_Consider_adding_undefined_to_the_types_of_the_target_s_properties.code,
-        Diagnostics.Property_0_is_incompatible_with_index_signature.code,
-        Diagnostics.Property_0_in_type_1_is_not_assignable_to_type_2.code,
-        Diagnostics.Type_0_does_not_satisfy_the_constraint_1.code
-      ];
-      registerCodeFix({
-        errorCodes: errorCodes19,
-        getCodeActions(context) {
-          const { sourceFile, span, program, preferences, host } = context;
-          const info = getInfo6(program, sourceFile, span);
-          if (info === void 0)
-            return;
-          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => addMissingConstraint(t, program, preferences, host, sourceFile, info));
-          return [createCodeFixAction(fixId17, changes, Diagnostics.Add_extends_constraint, fixId17, Diagnostics.Add_extends_constraint_to_all_type_parameters)];
-        },
-        fixIds: [fixId17],
-        getAllCodeActions: (context) => {
-          const { program, preferences, host } = context;
-          const seen = /* @__PURE__ */ new Map();
-          return createCombinedCodeActions(ts_textChanges_exports.ChangeTracker.with(context, (changes) => {
-            eachDiagnostic(context, errorCodes19, (diag2) => {
-              const info = getInfo6(program, diag2.file, createTextSpan(diag2.start, diag2.length));
-              if (info) {
-                if (addToSeen(seen, getNodeId(info.declaration))) {
-                  return addMissingConstraint(changes, program, preferences, host, diag2.file, info);
-                }
-              }
-              return void 0;
-            });
-          }));
+    function inferTypes(usage) {
+      var _a, _b, _c;
+      const types = [];
+      if (usage.isNumber) {
+        types.push(checker.getNumberType());
+      }
+      if (usage.isString) {
+        types.push(checker.getStringType());
+      }
+      if (usage.isNumberOrString) {
+        types.push(checker.getUnionType([checker.getStringType(), checker.getNumberType()]));
+      }
+      if (usage.numberIndex) {
+        types.push(checker.createArrayType(combineFromUsage(usage.numberIndex)));
+      }
+      if (((_a = usage.properties) == null ? void 0 : _a.size) || ((_b = usage.constructs) == null ? void 0 : _b.length) || usage.stringIndex) {
+        types.push(inferStructuralType(usage));
+      }
+      const candidateTypes = (usage.candidateTypes || []).map((t) => checker.getBaseTypeOfLiteralType(t));
+      const callsType = ((_c = usage.calls) == null ? void 0 : _c.length) ? inferStructuralType(usage) : void 0;
+      if (callsType && candidateTypes) {
+        types.push(checker.getUnionType([callsType, ...candidateTypes], 2 /* Subtype */));
+      } else {
+        if (callsType) {
+          types.push(callsType);
         }
-      });
-    }
-  });
-
-  // src/services/codefixes/fixOverrideModifier.ts
-  function dispatchChanges(changeTracker, context, errorCode, pos) {
-    switch (errorCode) {
-      case Diagnostics.This_member_must_have_an_override_modifier_because_it_overrides_a_member_in_the_base_class_0.code:
-      case Diagnostics.This_member_must_have_a_JSDoc_comment_with_an_override_tag_because_it_overrides_a_member_in_the_base_class_0.code:
-      case Diagnostics.This_member_must_have_an_override_modifier_because_it_overrides_an_abstract_method_that_is_declared_in_the_base_class_0.code:
-      case Diagnostics.This_parameter_property_must_have_an_override_modifier_because_it_overrides_a_member_in_base_class_0.code:
-      case Diagnostics.This_parameter_property_must_have_a_JSDoc_comment_with_an_override_tag_because_it_overrides_a_member_in_the_base_class_0.code:
-        return doAddOverrideModifierChange(changeTracker, context.sourceFile, pos);
-      case Diagnostics.This_member_cannot_have_an_override_modifier_because_it_is_not_declared_in_the_base_class_0.code:
-      case Diagnostics.This_member_cannot_have_a_JSDoc_comment_with_an_override_tag_because_it_is_not_declared_in_the_base_class_0.code:
-      case Diagnostics.This_member_cannot_have_an_override_modifier_because_its_containing_class_0_does_not_extend_another_class.code:
-      case Diagnostics.This_member_cannot_have_a_JSDoc_comment_with_an_override_tag_because_its_containing_class_0_does_not_extend_another_class.code:
-        return doRemoveOverrideModifierChange(changeTracker, context.sourceFile, pos);
-      default:
-        Debug.fail("Unexpected error code: " + errorCode);
+        if (length(candidateTypes)) {
+          types.push(...candidateTypes);
+        }
+      }
+      types.push(...inferNamedTypesFromProperties(usage));
+      return types;
     }
-  }
-  function doAddOverrideModifierChange(changeTracker, sourceFile, pos) {
-    const classElement = findContainerClassElementLike(sourceFile, pos);
-    if (isSourceFileJS(sourceFile)) {
-      changeTracker.addJSDocTags(sourceFile, classElement, [factory.createJSDocOverrideTag(factory.createIdentifier("override"))]);
-      return;
+    function inferStructuralType(usage) {
+      const members = /* @__PURE__ */ new Map();
+      if (usage.properties) {
+        usage.properties.forEach((u, name) => {
+          const symbol = checker.createSymbol(4 /* Property */, name);
+          symbol.links.type = combineFromUsage(u);
+          members.set(name, symbol);
+        });
+      }
+      const callSignatures = usage.calls ? [getSignatureFromCalls(usage.calls)] : [];
+      const constructSignatures = usage.constructs ? [getSignatureFromCalls(usage.constructs)] : [];
+      const indexInfos = usage.stringIndex ? [checker.createIndexInfo(
+        checker.getStringType(),
+        combineFromUsage(usage.stringIndex),
+        /*isReadonly*/
+        false
+      )] : [];
+      return checker.createAnonymousType(
+        /*symbol*/
+        void 0,
+        members,
+        callSignatures,
+        constructSignatures,
+        indexInfos
+      );
     }
-    const modifiers = classElement.modifiers || emptyArray;
-    const staticModifier = find(modifiers, isStaticModifier);
-    const abstractModifier = find(modifiers, isAbstractModifier);
-    const accessibilityModifier = find(modifiers, (m) => isAccessibilityModifier(m.kind));
-    const lastDecorator = findLast(modifiers, isDecorator);
-    const modifierPos = abstractModifier ? abstractModifier.end : staticModifier ? staticModifier.end : accessibilityModifier ? accessibilityModifier.end : lastDecorator ? skipTrivia(sourceFile.text, lastDecorator.end) : classElement.getStart(sourceFile);
-    const options = accessibilityModifier || staticModifier || abstractModifier ? { prefix: " " } : { suffix: " " };
-    changeTracker.insertModifierAt(sourceFile, modifierPos, 163 /* OverrideKeyword */, options);
-  }
-  function doRemoveOverrideModifierChange(changeTracker, sourceFile, pos) {
-    const classElement = findContainerClassElementLike(sourceFile, pos);
-    if (isSourceFileJS(sourceFile)) {
-      changeTracker.filterJSDocTags(sourceFile, classElement, not(isJSDocOverrideTag));
-      return;
+    function inferNamedTypesFromProperties(usage) {
+      if (!usage.properties || !usage.properties.size)
+        return [];
+      const types = builtins.filter((t) => allPropertiesAreAssignableToUsage(t, usage));
+      if (0 < types.length && types.length < 3) {
+        return types.map((t) => inferInstantiationFromUsage(t, usage));
+      }
+      return [];
     }
-    const overrideModifier = find(classElement.modifiers, isOverrideModifier);
-    Debug.assertIsDefined(overrideModifier);
-    changeTracker.deleteModifier(sourceFile, overrideModifier);
-  }
-  function isClassElementLikeHasJSDoc(node) {
-    switch (node.kind) {
-      case 175 /* Constructor */:
-      case 171 /* PropertyDeclaration */:
-      case 173 /* MethodDeclaration */:
-      case 176 /* GetAccessor */:
-      case 177 /* SetAccessor */:
-        return true;
-      case 168 /* Parameter */:
-        return isParameterPropertyDeclaration(node, node.parent);
-      default:
+    function allPropertiesAreAssignableToUsage(type, usage) {
+      if (!usage.properties)
         return false;
-    }
-  }
-  function findContainerClassElementLike(sourceFile, pos) {
-    const token = getTokenAtPosition(sourceFile, pos);
-    const classElement = findAncestor(token, (node) => {
-      if (isClassLike(node))
-        return "quit";
-      return isClassElementLikeHasJSDoc(node);
-    });
-    Debug.assert(classElement && isClassElementLikeHasJSDoc(classElement));
-    return classElement;
-  }
-  var fixName, fixAddOverrideId, fixRemoveOverrideId, errorCodes20, errorCodeFixIdMap;
-  var init_fixOverrideModifier = __esm({
-    "src/services/codefixes/fixOverrideModifier.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_codefix();
-      fixName = "fixOverrideModifier";
-      fixAddOverrideId = "fixAddOverrideModifier";
-      fixRemoveOverrideId = "fixRemoveOverrideModifier";
-      errorCodes20 = [
-        Diagnostics.This_member_cannot_have_an_override_modifier_because_it_is_not_declared_in_the_base_class_0.code,
-        Diagnostics.This_member_cannot_have_an_override_modifier_because_its_containing_class_0_does_not_extend_another_class.code,
-        Diagnostics.This_member_must_have_an_override_modifier_because_it_overrides_an_abstract_method_that_is_declared_in_the_base_class_0.code,
-        Diagnostics.This_member_must_have_an_override_modifier_because_it_overrides_a_member_in_the_base_class_0.code,
-        Diagnostics.This_parameter_property_must_have_an_override_modifier_because_it_overrides_a_member_in_base_class_0.code,
-        Diagnostics.This_member_must_have_a_JSDoc_comment_with_an_override_tag_because_it_overrides_a_member_in_the_base_class_0.code,
-        Diagnostics.This_member_cannot_have_a_JSDoc_comment_with_an_override_tag_because_its_containing_class_0_does_not_extend_another_class.code,
-        Diagnostics.This_parameter_property_must_have_a_JSDoc_comment_with_an_override_tag_because_it_overrides_a_member_in_the_base_class_0.code,
-        Diagnostics.This_member_cannot_have_a_JSDoc_comment_with_an_override_tag_because_it_is_not_declared_in_the_base_class_0.code
-      ];
-      errorCodeFixIdMap = {
-        // case #1:
-        [Diagnostics.This_member_must_have_an_override_modifier_because_it_overrides_a_member_in_the_base_class_0.code]: {
-          descriptions: Diagnostics.Add_override_modifier,
-          fixId: fixAddOverrideId,
-          fixAllDescriptions: Diagnostics.Add_all_missing_override_modifiers
-        },
-        [Diagnostics.This_member_must_have_a_JSDoc_comment_with_an_override_tag_because_it_overrides_a_member_in_the_base_class_0.code]: {
-          descriptions: Diagnostics.Add_override_modifier,
-          fixId: fixAddOverrideId,
-          fixAllDescriptions: Diagnostics.Add_all_missing_override_modifiers
-        },
-        // case #2:
-        [Diagnostics.This_member_cannot_have_an_override_modifier_because_its_containing_class_0_does_not_extend_another_class.code]: {
-          descriptions: Diagnostics.Remove_override_modifier,
-          fixId: fixRemoveOverrideId,
-          fixAllDescriptions: Diagnostics.Remove_all_unnecessary_override_modifiers
-        },
-        [Diagnostics.This_member_cannot_have_a_JSDoc_comment_with_an_override_tag_because_its_containing_class_0_does_not_extend_another_class.code]: {
-          descriptions: Diagnostics.Remove_override_modifier,
-          fixId: fixRemoveOverrideId,
-          fixAllDescriptions: Diagnostics.Remove_override_modifier
-        },
-        // case #3:
-        [Diagnostics.This_parameter_property_must_have_an_override_modifier_because_it_overrides_a_member_in_base_class_0.code]: {
-          descriptions: Diagnostics.Add_override_modifier,
-          fixId: fixAddOverrideId,
-          fixAllDescriptions: Diagnostics.Add_all_missing_override_modifiers
-        },
-        [Diagnostics.This_parameter_property_must_have_a_JSDoc_comment_with_an_override_tag_because_it_overrides_a_member_in_the_base_class_0.code]: {
-          descriptions: Diagnostics.Add_override_modifier,
-          fixId: fixAddOverrideId,
-          fixAllDescriptions: Diagnostics.Add_all_missing_override_modifiers
-        },
-        // case #4:
-        [Diagnostics.This_member_must_have_an_override_modifier_because_it_overrides_an_abstract_method_that_is_declared_in_the_base_class_0.code]: {
-          descriptions: Diagnostics.Add_override_modifier,
-          fixId: fixAddOverrideId,
-          fixAllDescriptions: Diagnostics.Remove_all_unnecessary_override_modifiers
-        },
-        // case #5:
-        [Diagnostics.This_member_cannot_have_an_override_modifier_because_it_is_not_declared_in_the_base_class_0.code]: {
-          descriptions: Diagnostics.Remove_override_modifier,
-          fixId: fixRemoveOverrideId,
-          fixAllDescriptions: Diagnostics.Remove_all_unnecessary_override_modifiers
-        },
-        [Diagnostics.This_member_cannot_have_a_JSDoc_comment_with_an_override_tag_because_it_is_not_declared_in_the_base_class_0.code]: {
-          descriptions: Diagnostics.Remove_override_modifier,
-          fixId: fixRemoveOverrideId,
-          fixAllDescriptions: Diagnostics.Remove_all_unnecessary_override_modifiers
+      return !forEachEntry(usage.properties, (propUsage, name) => {
+        const source = checker.getTypeOfPropertyOfType(type, name);
+        if (!source) {
+          return true;
+        }
+        if (propUsage.calls) {
+          const sigs = checker.getSignaturesOfType(source, 0 /* Call */);
+          return !sigs.length || !checker.isTypeAssignableTo(source, getFunctionFromCalls(propUsage.calls));
+        } else {
+          return !checker.isTypeAssignableTo(source, combineFromUsage(propUsage));
         }
-      };
-      registerCodeFix({
-        errorCodes: errorCodes20,
-        getCodeActions: function getCodeActionsToFixOverrideModifierIssues(context) {
-          const { errorCode, span } = context;
-          const info = errorCodeFixIdMap[errorCode];
-          if (!info)
-            return emptyArray;
-          const { descriptions, fixId: fixId52, fixAllDescriptions } = info;
-          const changes = ts_textChanges_exports.ChangeTracker.with(context, (changes2) => dispatchChanges(changes2, context, errorCode, span.start));
-          return [
-            createCodeFixActionMaybeFixAll(fixName, changes, descriptions, fixId52, fixAllDescriptions)
-          ];
-        },
-        fixIds: [fixName, fixAddOverrideId, fixRemoveOverrideId],
-        getAllCodeActions: (context) => codeFixAll(context, errorCodes20, (changes, diag2) => {
-          const { code, start } = diag2;
-          const info = errorCodeFixIdMap[code];
-          if (!info || info.fixId !== context.fixId) {
-            return;
-          }
-          dispatchChanges(changes, context, code, start);
-        })
       });
     }
-  });
-
-  // src/services/codefixes/fixNoPropertyAccessFromIndexSignature.ts
-  function doChange14(changes, sourceFile, node, preferences) {
-    const quotePreference = getQuotePreference(sourceFile, preferences);
-    const argumentsExpression = factory.createStringLiteral(node.name.text, quotePreference === 0 /* Single */);
-    changes.replaceNode(
-      sourceFile,
-      node,
-      isPropertyAccessChain(node) ? factory.createElementAccessChain(node.expression, node.questionDotToken, argumentsExpression) : factory.createElementAccessExpression(node.expression, argumentsExpression)
-    );
-  }
-  function getPropertyAccessExpression(sourceFile, pos) {
-    return cast(getTokenAtPosition(sourceFile, pos).parent, isPropertyAccessExpression);
-  }
-  var fixId18, errorCodes21;
-  var init_fixNoPropertyAccessFromIndexSignature = __esm({
-    "src/services/codefixes/fixNoPropertyAccessFromIndexSignature.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_codefix();
-      fixId18 = "fixNoPropertyAccessFromIndexSignature";
-      errorCodes21 = [
-        Diagnostics.Property_0_comes_from_an_index_signature_so_it_must_be_accessed_with_0.code
-      ];
-      registerCodeFix({
-        errorCodes: errorCodes21,
-        fixIds: [fixId18],
-        getCodeActions(context) {
-          const { sourceFile, span, preferences } = context;
-          const property = getPropertyAccessExpression(sourceFile, span.start);
-          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange14(t, context.sourceFile, property, preferences));
-          return [createCodeFixAction(fixId18, changes, [Diagnostics.Use_element_access_for_0, property.name.text], fixId18, Diagnostics.Use_element_access_for_all_undeclared_properties)];
-        },
-        getAllCodeActions: (context) => codeFixAll(context, errorCodes21, (changes, diag2) => doChange14(changes, diag2.file, getPropertyAccessExpression(diag2.file, diag2.start), context.preferences))
+    function inferInstantiationFromUsage(type, usage) {
+      if (!(getObjectFlags(type) & 4 /* Reference */) || !usage.properties) {
+        return type;
+      }
+      const generic = type.target;
+      const singleTypeParameter = singleOrUndefined(generic.typeParameters);
+      if (!singleTypeParameter)
+        return type;
+      const types = [];
+      usage.properties.forEach((propUsage, name) => {
+        const genericPropertyType = checker.getTypeOfPropertyOfType(generic, name);
+        Debug.assert(!!genericPropertyType, "generic should have all the properties of its reference.");
+        types.push(...inferTypeParameters(genericPropertyType, combineFromUsage(propUsage), singleTypeParameter));
       });
+      return builtinConstructors[type.symbol.escapedName](combineTypes(types));
     }
-  });
-
-  // src/services/codefixes/fixImplicitThis.ts
-  function doChange15(changes, sourceFile, pos, checker) {
-    const token = getTokenAtPosition(sourceFile, pos);
-    if (!isThis(token))
-      return void 0;
-    const fn = getThisContainer(
-      token,
-      /*includeArrowFunctions*/
-      false,
-      /*includeClassComputedPropertyName*/
-      false
-    );
-    if (!isFunctionDeclaration(fn) && !isFunctionExpression(fn))
-      return void 0;
-    if (!isSourceFile(getThisContainer(
-      fn,
-      /*includeArrowFunctions*/
-      false,
-      /*includeClassComputedPropertyName*/
-      false
-    ))) {
-      const fnKeyword = Debug.checkDefined(findChildOfKind(fn, 100 /* FunctionKeyword */, sourceFile));
-      const { name } = fn;
-      const body = Debug.checkDefined(fn.body);
-      if (isFunctionExpression(fn)) {
-        if (name && ts_FindAllReferences_exports.Core.isSymbolReferencedInFile(name, checker, sourceFile, body)) {
-          return void 0;
-        }
-        changes.delete(sourceFile, fnKeyword);
-        if (name) {
-          changes.delete(sourceFile, name);
+    function inferTypeParameters(genericType, usageType, typeParameter) {
+      if (genericType === typeParameter) {
+        return [usageType];
+      } else if (genericType.flags & 3145728 /* UnionOrIntersection */) {
+        return flatMap(genericType.types, (t) => inferTypeParameters(t, usageType, typeParameter));
+      } else if (getObjectFlags(genericType) & 4 /* Reference */ && getObjectFlags(usageType) & 4 /* Reference */) {
+        const genericArgs = checker.getTypeArguments(genericType);
+        const usageArgs = checker.getTypeArguments(usageType);
+        const types = [];
+        if (genericArgs && usageArgs) {
+          for (let i = 0; i < genericArgs.length; i++) {
+            if (usageArgs[i]) {
+              types.push(...inferTypeParameters(genericArgs[i], usageArgs[i], typeParameter));
+            }
+          }
         }
-        changes.insertText(sourceFile, body.pos, " =>");
-        return [Diagnostics.Convert_function_expression_0_to_arrow_function, name ? name.text : ANONYMOUS];
-      } else {
-        changes.replaceNode(sourceFile, fnKeyword, factory.createToken(87 /* ConstKeyword */));
-        changes.insertText(sourceFile, name.end, " = ");
-        changes.insertText(sourceFile, body.pos, " =>");
-        return [Diagnostics.Convert_function_declaration_0_to_arrow_function, name.text];
+        return types;
+      }
+      const genericSigs = checker.getSignaturesOfType(genericType, 0 /* Call */);
+      const usageSigs = checker.getSignaturesOfType(usageType, 0 /* Call */);
+      if (genericSigs.length === 1 && usageSigs.length === 1) {
+        return inferFromSignatures(genericSigs[0], usageSigs[0], typeParameter);
       }
+      return [];
     }
-  }
-  var fixId19, errorCodes22;
-  var init_fixImplicitThis = __esm({
-    "src/services/codefixes/fixImplicitThis.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_codefix();
-      fixId19 = "fixImplicitThis";
-      errorCodes22 = [Diagnostics.this_implicitly_has_type_any_because_it_does_not_have_a_type_annotation.code];
-      registerCodeFix({
-        errorCodes: errorCodes22,
-        getCodeActions: function getCodeActionsToFixImplicitThis(context) {
-          const { sourceFile, program, span } = context;
-          let diagnostic;
-          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => {
-            diagnostic = doChange15(t, sourceFile, span.start, program.getTypeChecker());
-          });
-          return diagnostic ? [createCodeFixAction(fixId19, changes, diagnostic, fixId19, Diagnostics.Fix_all_implicit_this_errors)] : emptyArray;
-        },
-        fixIds: [fixId19],
-        getAllCodeActions: (context) => codeFixAll(context, errorCodes22, (changes, diag2) => {
-          doChange15(changes, diag2.file, diag2.start, context.program.getTypeChecker());
-        })
-      });
+    function inferFromSignatures(genericSig, usageSig, typeParameter) {
+      var _a;
+      const types = [];
+      for (let i = 0; i < genericSig.parameters.length; i++) {
+        const genericParam = genericSig.parameters[i];
+        const usageParam = usageSig.parameters[i];
+        const isRest = genericSig.declaration && isRestParameter(genericSig.declaration.parameters[i]);
+        if (!usageParam) {
+          break;
+        }
+        let genericParamType = genericParam.valueDeclaration ? checker.getTypeOfSymbolAtLocation(genericParam, genericParam.valueDeclaration) : checker.getAnyType();
+        const elementType = isRest && checker.getElementTypeOfArrayType(genericParamType);
+        if (elementType) {
+          genericParamType = elementType;
+        }
+        const targetType = ((_a = tryCast(usageParam, isTransientSymbol)) == null ? void 0 : _a.links.type) || (usageParam.valueDeclaration ? checker.getTypeOfSymbolAtLocation(usageParam, usageParam.valueDeclaration) : checker.getAnyType());
+        types.push(...inferTypeParameters(genericParamType, targetType, typeParameter));
+      }
+      const genericReturn = checker.getReturnTypeOfSignature(genericSig);
+      const usageReturn = checker.getReturnTypeOfSignature(usageSig);
+      types.push(...inferTypeParameters(genericReturn, usageReturn, typeParameter));
+      return types;
     }
-  });
-
-  // src/services/codefixes/fixImportNonExportedMember.ts
-  function getInfo7(sourceFile, pos, program) {
-    var _a;
-    const token = getTokenAtPosition(sourceFile, pos);
-    if (isIdentifier(token)) {
-      const importDeclaration = findAncestor(token, isImportDeclaration);
-      if (importDeclaration === void 0)
-        return void 0;
-      const moduleSpecifier = isStringLiteral(importDeclaration.moduleSpecifier) ? importDeclaration.moduleSpecifier.text : void 0;
-      if (moduleSpecifier === void 0)
-        return void 0;
-      const resolvedModule = getResolvedModule(
-        sourceFile,
-        moduleSpecifier,
-        /*mode*/
-        void 0
+    function getFunctionFromCalls(calls) {
+      return checker.createAnonymousType(
+        /*symbol*/
+        void 0,
+        createSymbolTable(),
+        [getSignatureFromCalls(calls)],
+        emptyArray,
+        emptyArray
       );
-      if (resolvedModule === void 0)
-        return void 0;
-      const moduleSourceFile = program.getSourceFile(resolvedModule.resolvedFileName);
-      if (moduleSourceFile === void 0 || isSourceFileFromLibrary(program, moduleSourceFile))
-        return void 0;
-      const moduleSymbol = moduleSourceFile.symbol;
-      const locals = (_a = tryCast(moduleSymbol.valueDeclaration, canHaveLocals)) == null ? void 0 : _a.locals;
-      if (locals === void 0)
-        return void 0;
-      const localSymbol = locals.get(token.escapedText);
-      if (localSymbol === void 0)
-        return void 0;
-      const node = getNodeOfSymbol(localSymbol);
-      if (node === void 0)
-        return void 0;
-      const exportName = { node: token, isTypeOnly: isTypeDeclaration(node) };
-      return { exportName, node, moduleSourceFile, moduleSpecifier };
-    }
-    return void 0;
-  }
-  function doChange16(changes, program, { exportName, node, moduleSourceFile }) {
-    const exportDeclaration = tryGetExportDeclaration(moduleSourceFile, exportName.isTypeOnly);
-    if (exportDeclaration) {
-      updateExport(changes, program, moduleSourceFile, exportDeclaration, [exportName]);
-    } else if (canHaveExportModifier(node)) {
-      changes.insertExportModifier(moduleSourceFile, node);
-    } else {
-      createExport(changes, program, moduleSourceFile, [exportName]);
     }
-  }
-  function doChanges(changes, program, sourceFile, moduleExports, node) {
-    if (length(moduleExports)) {
-      if (node) {
-        updateExport(changes, program, sourceFile, node, moduleExports);
-      } else {
-        createExport(changes, program, sourceFile, moduleExports);
+    function getSignatureFromCalls(calls) {
+      const parameters2 = [];
+      const length2 = Math.max(...calls.map((c) => c.argumentTypes.length));
+      for (let i = 0; i < length2; i++) {
+        const symbol = checker.createSymbol(1 /* FunctionScopedVariable */, escapeLeadingUnderscores(`arg${i}`));
+        symbol.links.type = combineTypes(calls.map((call) => call.argumentTypes[i] || checker.getUndefinedType()));
+        if (calls.some((call) => call.argumentTypes[i] === void 0)) {
+          symbol.flags |= 16777216 /* Optional */;
+        }
+        parameters2.push(symbol);
       }
-    }
-  }
-  function tryGetExportDeclaration(sourceFile, isTypeOnly) {
-    const predicate = (node) => isExportDeclaration(node) && (isTypeOnly && node.isTypeOnly || !node.isTypeOnly);
-    return findLast(sourceFile.statements, predicate);
-  }
-  function updateExport(changes, program, sourceFile, node, names) {
-    const namedExports = node.exportClause && isNamedExports(node.exportClause) ? node.exportClause.elements : factory.createNodeArray([]);
-    const allowTypeModifier = !node.isTypeOnly && !!(getIsolatedModules(program.getCompilerOptions()) || find(namedExports, (e) => e.isTypeOnly));
-    changes.replaceNode(
-      sourceFile,
-      node,
-      factory.updateExportDeclaration(
-        node,
-        node.modifiers,
-        node.isTypeOnly,
-        factory.createNamedExports(
-          factory.createNodeArray(
-            [...namedExports, ...createExportSpecifiers(names, allowTypeModifier)],
-            /*hasTrailingComma*/
-            namedExports.hasTrailingComma
-          )
-        ),
-        node.moduleSpecifier,
-        node.assertClause
-      )
-    );
-  }
-  function createExport(changes, program, sourceFile, names) {
-    changes.insertNodeAtEndOfScope(
-      sourceFile,
-      sourceFile,
-      factory.createExportDeclaration(
-        /*modifiers*/
+      const returnType = combineFromUsage(combineUsages(calls.map((call) => call.return_)));
+      return checker.createSignature(
+        /*declaration*/
         void 0,
-        /*isTypeOnly*/
-        false,
-        factory.createNamedExports(createExportSpecifiers(
-          names,
-          /*allowTypeModifier*/
-          getIsolatedModules(program.getCompilerOptions())
-        )),
-        /*moduleSpecifier*/
+        /*typeParameters*/
         void 0,
-        /*assertClause*/
-        void 0
-      )
-    );
-  }
-  function createExportSpecifiers(names, allowTypeModifier) {
-    return factory.createNodeArray(map(names, (n) => factory.createExportSpecifier(
-      allowTypeModifier && n.isTypeOnly,
-      /*propertyName*/
-      void 0,
-      n.node
-    )));
-  }
-  function getNodeOfSymbol(symbol) {
-    if (symbol.valueDeclaration === void 0) {
-      return firstOrUndefined(symbol.declarations);
+        /*thisParameter*/
+        void 0,
+        parameters2,
+        returnType,
+        /*typePredicate*/
+        void 0,
+        length2,
+        0 /* None */
+      );
+    }
+    function addCandidateType(usage, type) {
+      if (type && !(type.flags & 1 /* Any */) && !(type.flags & 131072 /* Never */)) {
+        (usage.candidateTypes || (usage.candidateTypes = [])).push(type);
+      }
+    }
+    function addCandidateThisType(usage, type) {
+      if (type && !(type.flags & 1 /* Any */) && !(type.flags & 131072 /* Never */)) {
+        (usage.candidateThisTypes || (usage.candidateThisTypes = [])).push(type);
+      }
     }
-    const declaration = symbol.valueDeclaration;
-    const variableStatement = isVariableDeclaration(declaration) ? tryCast(declaration.parent.parent, isVariableStatement) : void 0;
-    return variableStatement && length(variableStatement.declarationList.declarations) === 1 ? variableStatement : declaration;
   }
-  var fixId20, errorCodes23;
-  var init_fixImportNonExportedMember = __esm({
-    "src/services/codefixes/fixImportNonExportedMember.ts"() {
+  var fixId38, errorCodes48;
+  var init_inferFromUsage = __esm({
+    "src/services/codefixes/inferFromUsage.ts"() {
       "use strict";
       init_ts4();
       init_ts_codefix();
-      fixId20 = "fixImportNonExportedMember";
-      errorCodes23 = [
-        Diagnostics.Module_0_declares_1_locally_but_it_is_not_exported.code
+      fixId38 = "inferFromUsage";
+      errorCodes48 = [
+        // Variable declarations
+        Diagnostics.Variable_0_implicitly_has_type_1_in_some_locations_where_its_type_cannot_be_determined.code,
+        // Variable uses
+        Diagnostics.Variable_0_implicitly_has_an_1_type.code,
+        // Parameter declarations
+        Diagnostics.Parameter_0_implicitly_has_an_1_type.code,
+        Diagnostics.Rest_parameter_0_implicitly_has_an_any_type.code,
+        // Get Accessor declarations
+        Diagnostics.Property_0_implicitly_has_type_any_because_its_get_accessor_lacks_a_return_type_annotation.code,
+        Diagnostics._0_which_lacks_return_type_annotation_implicitly_has_an_1_return_type.code,
+        // Set Accessor declarations
+        Diagnostics.Property_0_implicitly_has_type_any_because_its_set_accessor_lacks_a_parameter_type_annotation.code,
+        // Property declarations
+        Diagnostics.Member_0_implicitly_has_an_1_type.code,
+        //// Suggestions
+        // Variable declarations
+        Diagnostics.Variable_0_implicitly_has_type_1_in_some_locations_but_a_better_type_may_be_inferred_from_usage.code,
+        // Variable uses
+        Diagnostics.Variable_0_implicitly_has_an_1_type_but_a_better_type_may_be_inferred_from_usage.code,
+        // Parameter declarations
+        Diagnostics.Parameter_0_implicitly_has_an_1_type_but_a_better_type_may_be_inferred_from_usage.code,
+        Diagnostics.Rest_parameter_0_implicitly_has_an_any_type_but_a_better_type_may_be_inferred_from_usage.code,
+        // Get Accessor declarations
+        Diagnostics.Property_0_implicitly_has_type_any_but_a_better_type_for_its_get_accessor_may_be_inferred_from_usage.code,
+        Diagnostics._0_implicitly_has_an_1_return_type_but_a_better_type_may_be_inferred_from_usage.code,
+        // Set Accessor declarations
+        Diagnostics.Property_0_implicitly_has_type_any_but_a_better_type_for_its_set_accessor_may_be_inferred_from_usage.code,
+        // Property declarations
+        Diagnostics.Member_0_implicitly_has_an_1_type_but_a_better_type_may_be_inferred_from_usage.code,
+        // Function expressions and declarations
+        Diagnostics.this_implicitly_has_type_any_because_it_does_not_have_a_type_annotation.code
       ];
       registerCodeFix({
-        errorCodes: errorCodes23,
-        fixIds: [fixId20],
+        errorCodes: errorCodes48,
         getCodeActions(context) {
-          const { sourceFile, span, program } = context;
-          const info = getInfo7(sourceFile, span.start, program);
-          if (info === void 0)
-            return void 0;
-          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange16(t, program, info));
-          return [createCodeFixAction(fixId20, changes, [Diagnostics.Export_0_from_module_1, info.exportName.node.text, info.moduleSpecifier], fixId20, Diagnostics.Export_all_referenced_locals)];
+          const { sourceFile, program, span: { start }, errorCode, cancellationToken, host, preferences } = context;
+          const token = getTokenAtPosition(sourceFile, start);
+          let declaration;
+          const changes = ts_textChanges_exports.ChangeTracker.with(context, (changes2) => {
+            declaration = doChange32(
+              changes2,
+              sourceFile,
+              token,
+              errorCode,
+              program,
+              cancellationToken,
+              /*markSeen*/
+              returnTrue,
+              host,
+              preferences
+            );
+          });
+          const name = declaration && getNameOfDeclaration(declaration);
+          return !name || changes.length === 0 ? void 0 : [createCodeFixAction(fixId38, changes, [getDiagnostic(errorCode, token), getTextOfNode(name)], fixId38, Diagnostics.Infer_all_types_from_usage)];
         },
+        fixIds: [fixId38],
         getAllCodeActions(context) {
-          const { program } = context;
-          return createCombinedCodeActions(ts_textChanges_exports.ChangeTracker.with(context, (changes) => {
-            const exports = /* @__PURE__ */ new Map();
-            eachDiagnostic(context, errorCodes23, (diag2) => {
-              const info = getInfo7(diag2.file, diag2.start, program);
-              if (info === void 0)
-                return void 0;
-              const { exportName, node, moduleSourceFile } = info;
-              if (tryGetExportDeclaration(moduleSourceFile, exportName.isTypeOnly) === void 0 && canHaveExportModifier(node)) {
-                changes.insertExportModifier(moduleSourceFile, node);
-              } else {
-                const moduleExports = exports.get(moduleSourceFile) || { typeOnlyExports: [], exports: [] };
-                if (exportName.isTypeOnly) {
-                  moduleExports.typeOnlyExports.push(exportName);
-                } else {
-                  moduleExports.exports.push(exportName);
-                }
-                exports.set(moduleSourceFile, moduleExports);
-              }
-            });
-            exports.forEach((moduleExports, moduleSourceFile) => {
-              const exportDeclaration = tryGetExportDeclaration(
-                moduleSourceFile,
-                /*isTypeOnly*/
-                true
-              );
-              if (exportDeclaration && exportDeclaration.isTypeOnly) {
-                doChanges(changes, program, moduleSourceFile, moduleExports.typeOnlyExports, exportDeclaration);
-                doChanges(changes, program, moduleSourceFile, moduleExports.exports, tryGetExportDeclaration(
-                  moduleSourceFile,
-                  /*isTypeOnly*/
-                  false
-                ));
-              } else {
-                doChanges(changes, program, moduleSourceFile, [...moduleExports.exports, ...moduleExports.typeOnlyExports], exportDeclaration);
-              }
-            });
-          }));
+          const { sourceFile, program, cancellationToken, host, preferences } = context;
+          const markSeen = nodeSeenTracker();
+          return codeFixAll(context, errorCodes48, (changes, err) => {
+            doChange32(changes, sourceFile, getTokenAtPosition(err.file, err.start), err.code, program, cancellationToken, markSeen, host, preferences);
+          });
         }
       });
     }
   });
 
-  // src/services/codefixes/fixIncorrectNamedTupleSyntax.ts
-  function getNamedTupleMember(sourceFile, pos) {
-    const token = getTokenAtPosition(sourceFile, pos);
-    return findAncestor(token, (t) => t.kind === 201 /* NamedTupleMember */);
-  }
-  function doChange17(changes, sourceFile, namedTupleMember) {
-    if (!namedTupleMember) {
-      return;
+  // src/services/codefixes/fixReturnTypeInAsyncFunction.ts
+  function getInfo15(sourceFile, checker, pos) {
+    if (isInJSFile(sourceFile)) {
+      return void 0;
     }
-    let unwrappedType = namedTupleMember.type;
-    let sawOptional = false;
-    let sawRest = false;
-    while (unwrappedType.kind === 189 /* OptionalType */ || unwrappedType.kind === 190 /* RestType */ || unwrappedType.kind === 195 /* ParenthesizedType */) {
-      if (unwrappedType.kind === 189 /* OptionalType */) {
-        sawOptional = true;
-      } else if (unwrappedType.kind === 190 /* RestType */) {
-        sawRest = true;
-      }
-      unwrappedType = unwrappedType.type;
+    const token = getTokenAtPosition(sourceFile, pos);
+    const func = findAncestor(token, isFunctionLikeDeclaration);
+    const returnTypeNode = func == null ? void 0 : func.type;
+    if (!returnTypeNode) {
+      return void 0;
     }
-    const updated = factory.updateNamedTupleMember(
-      namedTupleMember,
-      namedTupleMember.dotDotDotToken || (sawRest ? factory.createToken(26 /* DotDotDotToken */) : void 0),
-      namedTupleMember.name,
-      namedTupleMember.questionToken || (sawOptional ? factory.createToken(58 /* QuestionToken */) : void 0),
-      unwrappedType
+    const returnType = checker.getTypeFromTypeNode(returnTypeNode);
+    const promisedType = checker.getAwaitedType(returnType) || checker.getVoidType();
+    const promisedTypeNode = checker.typeToTypeNode(
+      promisedType,
+      /*enclosingDeclaration*/
+      returnTypeNode,
+      /*flags*/
+      void 0
     );
-    if (updated === namedTupleMember) {
-      return;
+    if (promisedTypeNode) {
+      return { returnTypeNode, returnType, promisedTypeNode, promisedType };
     }
-    changes.replaceNode(sourceFile, namedTupleMember, updated);
   }
-  var fixId21, errorCodes24;
-  var init_fixIncorrectNamedTupleSyntax = __esm({
-    "src/services/codefixes/fixIncorrectNamedTupleSyntax.ts"() {
+  function doChange33(changes, sourceFile, returnTypeNode, promisedTypeNode) {
+    changes.replaceNode(sourceFile, returnTypeNode, factory.createTypeReferenceNode("Promise", [promisedTypeNode]));
+  }
+  var fixId39, errorCodes49;
+  var init_fixReturnTypeInAsyncFunction = __esm({
+    "src/services/codefixes/fixReturnTypeInAsyncFunction.ts"() {
       "use strict";
       init_ts4();
       init_ts_codefix();
-      fixId21 = "fixIncorrectNamedTupleSyntax";
-      errorCodes24 = [
-        Diagnostics.A_labeled_tuple_element_is_declared_as_optional_with_a_question_mark_after_the_name_and_before_the_colon_rather_than_after_the_type.code,
-        Diagnostics.A_labeled_tuple_element_is_declared_as_rest_with_a_before_the_name_rather_than_before_the_type.code
+      fixId39 = "fixReturnTypeInAsyncFunction";
+      errorCodes49 = [
+        Diagnostics.The_return_type_of_an_async_function_or_method_must_be_the_global_Promise_T_type_Did_you_mean_to_write_Promise_0.code
       ];
       registerCodeFix({
-        errorCodes: errorCodes24,
-        getCodeActions: function getCodeActionsToFixIncorrectNamedTupleSyntax(context) {
-          const { sourceFile, span } = context;
-          const namedTupleMember = getNamedTupleMember(sourceFile, span.start);
-          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange17(t, sourceFile, namedTupleMember));
-          return [createCodeFixAction(fixId21, changes, Diagnostics.Move_labeled_tuple_element_modifiers_to_labels, fixId21, Diagnostics.Move_labeled_tuple_element_modifiers_to_labels)];
+        errorCodes: errorCodes49,
+        fixIds: [fixId39],
+        getCodeActions: function getCodeActionsToFixReturnTypeInAsyncFunction(context) {
+          const { sourceFile, program, span } = context;
+          const checker = program.getTypeChecker();
+          const info = getInfo15(sourceFile, program.getTypeChecker(), span.start);
+          if (!info) {
+            return void 0;
+          }
+          const { returnTypeNode, returnType, promisedTypeNode, promisedType } = info;
+          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange33(t, sourceFile, returnTypeNode, promisedTypeNode));
+          return [createCodeFixAction(
+            fixId39,
+            changes,
+            [Diagnostics.Replace_0_with_Promise_1, checker.typeToString(returnType), checker.typeToString(promisedType)],
+            fixId39,
+            Diagnostics.Fix_all_incorrect_return_type_of_an_async_functions
+          )];
         },
-        fixIds: [fixId21]
+        getAllCodeActions: (context) => codeFixAll(context, errorCodes49, (changes, diag2) => {
+          const info = getInfo15(diag2.file, context.program.getTypeChecker(), diag2.start);
+          if (info) {
+            doChange33(changes, diag2.file, info.returnTypeNode, info.promisedTypeNode);
+          }
+        })
       });
     }
   });
 
-  // src/services/codefixes/fixSpelling.ts
-  function getInfo8(sourceFile, pos, context, errorCode) {
-    const node = getTokenAtPosition(sourceFile, pos);
-    const parent2 = node.parent;
-    if ((errorCode === Diagnostics.No_overload_matches_this_call.code || errorCode === Diagnostics.Type_0_is_not_assignable_to_type_1.code) && !isJsxAttribute(parent2))
-      return void 0;
-    const checker = context.program.getTypeChecker();
-    let suggestedSymbol;
-    if (isPropertyAccessExpression(parent2) && parent2.name === node) {
-      Debug.assert(isMemberName(node), "Expected an identifier for spelling (property access)");
-      let containingType = checker.getTypeAtLocation(parent2.expression);
-      if (parent2.flags & 32 /* OptionalChain */) {
-        containingType = checker.getNonNullableType(containingType);
-      }
-      suggestedSymbol = checker.getSuggestedSymbolForNonexistentProperty(node, containingType);
-    } else if (isBinaryExpression(parent2) && parent2.operatorToken.kind === 103 /* InKeyword */ && parent2.left === node && isPrivateIdentifier(node)) {
-      const receiverType = checker.getTypeAtLocation(parent2.right);
-      suggestedSymbol = checker.getSuggestedSymbolForNonexistentProperty(node, receiverType);
-    } else if (isQualifiedName(parent2) && parent2.right === node) {
-      const symbol = checker.getSymbolAtLocation(parent2.left);
-      if (symbol && symbol.flags & 1536 /* Module */) {
-        suggestedSymbol = checker.getSuggestedSymbolForNonexistentModule(parent2.right, symbol);
-      }
-    } else if (isImportSpecifier(parent2) && parent2.name === node) {
-      Debug.assertNode(node, isIdentifier, "Expected an identifier for spelling (import)");
-      const importDeclaration = findAncestor(node, isImportDeclaration);
-      const resolvedSourceFile = getResolvedSourceFileFromImportDeclaration(sourceFile, context, importDeclaration);
-      if (resolvedSourceFile && resolvedSourceFile.symbol) {
-        suggestedSymbol = checker.getSuggestedSymbolForNonexistentModule(node, resolvedSourceFile.symbol);
-      }
-    } else if (isJsxAttribute(parent2) && parent2.name === node) {
-      Debug.assertNode(node, isIdentifier, "Expected an identifier for JSX attribute");
-      const tag = findAncestor(node, isJsxOpeningLikeElement);
-      const props = checker.getContextualTypeForArgumentAtIndex(tag, 0);
-      suggestedSymbol = checker.getSuggestedSymbolForNonexistentJSXAttribute(node, props);
-    } else if (hasSyntacticModifier(parent2, 16384 /* Override */) && isClassElement(parent2) && parent2.name === node) {
-      const baseDeclaration = findAncestor(node, isClassLike);
-      const baseTypeNode = baseDeclaration ? getEffectiveBaseTypeNode(baseDeclaration) : void 0;
-      const baseType = baseTypeNode ? checker.getTypeAtLocation(baseTypeNode) : void 0;
-      if (baseType) {
-        suggestedSymbol = checker.getSuggestedSymbolForNonexistentClassMember(getTextOfNode(node), baseType);
-      }
-    } else {
-      const meaning = getMeaningFromLocation(node);
-      const name = getTextOfNode(node);
-      Debug.assert(name !== void 0, "name should be defined");
-      suggestedSymbol = checker.getSuggestedSymbolForNonexistentSymbol(node, name, convertSemanticMeaningToSymbolFlags(meaning));
-    }
-    return suggestedSymbol === void 0 ? void 0 : { node, suggestedSymbol };
-  }
-  function doChange18(changes, sourceFile, node, suggestedSymbol, target) {
-    const suggestion = symbolName(suggestedSymbol);
-    if (!isIdentifierText(suggestion, target) && isPropertyAccessExpression(node.parent)) {
-      const valDecl = suggestedSymbol.valueDeclaration;
-      if (valDecl && isNamedDeclaration(valDecl) && isPrivateIdentifier(valDecl.name)) {
-        changes.replaceNode(sourceFile, node, factory.createIdentifier(suggestion));
-      } else {
-        changes.replaceNode(sourceFile, node.parent, factory.createElementAccessExpression(node.parent.expression, factory.createStringLiteral(suggestion)));
-      }
-    } else {
-      changes.replaceNode(sourceFile, node, factory.createIdentifier(suggestion));
-    }
-  }
-  function convertSemanticMeaningToSymbolFlags(meaning) {
-    let flags = 0;
-    if (meaning & 4 /* Namespace */) {
-      flags |= 1920 /* Namespace */;
-    }
-    if (meaning & 2 /* Type */) {
-      flags |= 788968 /* Type */;
-    }
-    if (meaning & 1 /* Value */) {
-      flags |= 111551 /* Value */;
+  // src/services/codefixes/disableJsDiagnostics.ts
+  function makeChange8(changes, sourceFile, position, seenLines) {
+    const { line: lineNumber } = getLineAndCharacterOfPosition(sourceFile, position);
+    if (!seenLines || tryAddToSet(seenLines, lineNumber)) {
+      changes.insertCommentBeforeLine(sourceFile, lineNumber, position, " @ts-ignore");
     }
-    return flags;
-  }
-  function getResolvedSourceFileFromImportDeclaration(sourceFile, context, importDeclaration) {
-    if (!importDeclaration || !isStringLiteralLike(importDeclaration.moduleSpecifier))
-      return void 0;
-    const resolvedModule = getResolvedModule(sourceFile, importDeclaration.moduleSpecifier.text, getModeForUsageLocation(sourceFile, importDeclaration.moduleSpecifier));
-    if (!resolvedModule)
-      return void 0;
-    return context.program.getSourceFile(resolvedModule.resolvedFileName);
   }
-  var fixId22, errorCodes25;
-  var init_fixSpelling = __esm({
-    "src/services/codefixes/fixSpelling.ts"() {
+  var fixName4, fixId40, errorCodes50;
+  var init_disableJsDiagnostics = __esm({
+    "src/services/codefixes/disableJsDiagnostics.ts"() {
       "use strict";
       init_ts4();
       init_ts_codefix();
-      fixId22 = "fixSpelling";
-      errorCodes25 = [
-        Diagnostics.Property_0_does_not_exist_on_type_1_Did_you_mean_2.code,
-        Diagnostics.Property_0_may_not_exist_on_type_1_Did_you_mean_2.code,
-        Diagnostics.Cannot_find_name_0_Did_you_mean_1.code,
-        Diagnostics.Could_not_find_name_0_Did_you_mean_1.code,
-        Diagnostics.Cannot_find_namespace_0_Did_you_mean_1.code,
-        Diagnostics.Cannot_find_name_0_Did_you_mean_the_instance_member_this_0.code,
-        Diagnostics.Cannot_find_name_0_Did_you_mean_the_static_member_1_0.code,
-        Diagnostics._0_has_no_exported_member_named_1_Did_you_mean_2.code,
-        Diagnostics.This_member_cannot_have_an_override_modifier_because_it_is_not_declared_in_the_base_class_0_Did_you_mean_1.code,
-        Diagnostics.This_member_cannot_have_a_JSDoc_comment_with_an_override_tag_because_it_is_not_declared_in_the_base_class_0_Did_you_mean_1.code,
-        // for JSX class components
-        Diagnostics.No_overload_matches_this_call.code,
-        // for JSX FC
-        Diagnostics.Type_0_is_not_assignable_to_type_1.code
-      ];
+      fixName4 = "disableJsDiagnostics";
+      fixId40 = "disableJsDiagnostics";
+      errorCodes50 = mapDefined(Object.keys(Diagnostics), (key) => {
+        const diag2 = Diagnostics[key];
+        return diag2.category === 1 /* Error */ ? diag2.code : void 0;
+      });
       registerCodeFix({
-        errorCodes: errorCodes25,
-        getCodeActions(context) {
-          const { sourceFile, errorCode } = context;
-          const info = getInfo8(sourceFile, context.span.start, context, errorCode);
-          if (!info)
+        errorCodes: errorCodes50,
+        getCodeActions: function getCodeActionsToDisableJsDiagnostics(context) {
+          const { sourceFile, program, span, host, formatContext } = context;
+          if (!isInJSFile(sourceFile) || !isCheckJsEnabledForFile(sourceFile, program.getCompilerOptions())) {
             return void 0;
-          const { node, suggestedSymbol } = info;
-          const target = getEmitScriptTarget(context.host.getCompilationSettings());
-          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange18(t, sourceFile, node, suggestedSymbol, target));
-          return [createCodeFixAction("spelling", changes, [Diagnostics.Change_spelling_to_0, symbolName(suggestedSymbol)], fixId22, Diagnostics.Fix_all_detected_spelling_errors)];
+          }
+          const newLineCharacter = sourceFile.checkJsDirective ? "" : getNewLineOrDefaultFromHost(host, formatContext.options);
+          const fixes = [
+            // fixId unnecessary because adding `// @ts-nocheck` even once will ignore every error in the file.
+            createCodeFixActionWithoutFixAll(
+              fixName4,
+              [createFileTextChanges(sourceFile.fileName, [
+                createTextChange(
+                  sourceFile.checkJsDirective ? createTextSpanFromBounds(sourceFile.checkJsDirective.pos, sourceFile.checkJsDirective.end) : createTextSpan(0, 0),
+                  `// @ts-nocheck${newLineCharacter}`
+                )
+              ])],
+              Diagnostics.Disable_checking_for_this_file
+            )
+          ];
+          if (ts_textChanges_exports.isValidLocationToAddComment(sourceFile, span.start)) {
+            fixes.unshift(createCodeFixAction(fixName4, ts_textChanges_exports.ChangeTracker.with(context, (t) => makeChange8(t, sourceFile, span.start)), Diagnostics.Ignore_this_error_message, fixId40, Diagnostics.Add_ts_ignore_to_all_error_messages));
+          }
+          return fixes;
         },
-        fixIds: [fixId22],
-        getAllCodeActions: (context) => codeFixAll(context, errorCodes25, (changes, diag2) => {
-          const info = getInfo8(diag2.file, diag2.start, context, diag2.code);
-          const target = getEmitScriptTarget(context.host.getCompilationSettings());
-          if (info)
-            doChange18(changes, context.sourceFile, info.node, info.suggestedSymbol, target);
-        })
+        fixIds: [fixId40],
+        getAllCodeActions: (context) => {
+          const seenLines = /* @__PURE__ */ new Set();
+          return codeFixAll(context, errorCodes50, (changes, diag2) => {
+            if (ts_textChanges_exports.isValidLocationToAddComment(diag2.file, diag2.start)) {
+              makeChange8(changes, diag2.file, diag2.start, seenLines);
+            }
+          });
+        }
       });
     }
   });
 
-  // src/services/codefixes/returnValueCorrect.ts
-  function createObjectTypeFromLabeledExpression(checker, label, expression) {
-    const member = checker.createSymbol(4 /* Property */, label.escapedText);
-    member.links.type = checker.getTypeAtLocation(expression);
-    const members = createSymbolTable([member]);
-    return checker.createAnonymousType(
-      /*symbol*/
-      void 0,
-      members,
-      [],
-      [],
-      []
-    );
-  }
-  function getFixInfo(checker, declaration, expectType, isFunctionType) {
-    if (!declaration.body || !isBlock(declaration.body) || length(declaration.body.statements) !== 1)
-      return void 0;
-    const firstStatement = first(declaration.body.statements);
-    if (isExpressionStatement(firstStatement) && checkFixedAssignableTo(checker, declaration, checker.getTypeAtLocation(firstStatement.expression), expectType, isFunctionType)) {
-      return {
-        declaration,
-        kind: 0 /* MissingReturnStatement */,
-        expression: firstStatement.expression,
-        statement: firstStatement,
-        commentSource: firstStatement.expression
-      };
-    } else if (isLabeledStatement(firstStatement) && isExpressionStatement(firstStatement.statement)) {
-      const node = factory.createObjectLiteralExpression([factory.createPropertyAssignment(firstStatement.label, firstStatement.statement.expression)]);
-      const nodeType = createObjectTypeFromLabeledExpression(checker, firstStatement.label, firstStatement.statement.expression);
-      if (checkFixedAssignableTo(checker, declaration, nodeType, expectType, isFunctionType)) {
-        return isArrowFunction(declaration) ? {
-          declaration,
-          kind: 1 /* MissingParentheses */,
-          expression: node,
-          statement: firstStatement,
-          commentSource: firstStatement.statement.expression
-        } : {
-          declaration,
-          kind: 0 /* MissingReturnStatement */,
-          expression: node,
-          statement: firstStatement,
-          commentSource: firstStatement.statement.expression
-        };
-      }
-    } else if (isBlock(firstStatement) && length(firstStatement.statements) === 1) {
-      const firstBlockStatement = first(firstStatement.statements);
-      if (isLabeledStatement(firstBlockStatement) && isExpressionStatement(firstBlockStatement.statement)) {
-        const node = factory.createObjectLiteralExpression([factory.createPropertyAssignment(firstBlockStatement.label, firstBlockStatement.statement.expression)]);
-        const nodeType = createObjectTypeFromLabeledExpression(checker, firstBlockStatement.label, firstBlockStatement.statement.expression);
-        if (checkFixedAssignableTo(checker, declaration, nodeType, expectType, isFunctionType)) {
-          return {
-            declaration,
-            kind: 0 /* MissingReturnStatement */,
-            expression: node,
-            statement: firstStatement,
-            commentSource: firstBlockStatement
-          };
-        }
+  // src/services/codefixes/helpers.ts
+  function createMissingMemberNodes(classDeclaration, possiblyMissingSymbols, sourceFile, context, preferences, importAdder, addClassElement) {
+    const classMembers = classDeclaration.symbol.members;
+    for (const symbol of possiblyMissingSymbols) {
+      if (!classMembers.has(symbol.escapedName)) {
+        addNewNodeForMemberSymbol(
+          symbol,
+          classDeclaration,
+          sourceFile,
+          context,
+          preferences,
+          importAdder,
+          addClassElement,
+          /*body*/
+          void 0
+        );
       }
     }
-    return void 0;
   }
-  function checkFixedAssignableTo(checker, declaration, exprType, type, isFunctionType) {
-    if (isFunctionType) {
-      const sig = checker.getSignatureFromDeclaration(declaration);
-      if (sig) {
-        if (hasSyntacticModifier(declaration, 512 /* Async */)) {
-          exprType = checker.createPromiseType(exprType);
+  function getNoopSymbolTrackerWithResolver(context) {
+    return {
+      trackSymbol: () => false,
+      moduleResolverHost: getModuleSpecifierResolverHost(context.program, context.host)
+    };
+  }
+  function addNewNodeForMemberSymbol(symbol, enclosingDeclaration, sourceFile, context, preferences, importAdder, addClassElement, body, preserveOptional = 3 /* All */, isAmbient = false) {
+    const declarations = symbol.getDeclarations();
+    const declaration = firstOrUndefined(declarations);
+    const checker = context.program.getTypeChecker();
+    const scriptTarget = getEmitScriptTarget(context.program.getCompilerOptions());
+    const kind = (declaration == null ? void 0 : declaration.kind) ?? 171 /* PropertySignature */;
+    const declarationName = createDeclarationName(symbol, declaration);
+    const effectiveModifierFlags = declaration ? getEffectiveModifierFlags(declaration) : 0 /* None */;
+    let modifierFlags = effectiveModifierFlags & 256 /* Static */;
+    modifierFlags |= effectiveModifierFlags & 1 /* Public */ ? 1 /* Public */ : effectiveModifierFlags & 4 /* Protected */ ? 4 /* Protected */ : 0 /* None */;
+    if (declaration && isAutoAccessorPropertyDeclaration(declaration)) {
+      modifierFlags |= 512 /* Accessor */;
+    }
+    const modifiers = createModifiers();
+    const type = checker.getWidenedType(checker.getTypeOfSymbolAtLocation(symbol, enclosingDeclaration));
+    const optional = !!(symbol.flags & 16777216 /* Optional */);
+    const ambient = !!(enclosingDeclaration.flags & 33554432 /* Ambient */) || isAmbient;
+    const quotePreference = getQuotePreference(sourceFile, preferences);
+    switch (kind) {
+      case 171 /* PropertySignature */:
+      case 172 /* PropertyDeclaration */:
+        const flags = quotePreference === 0 /* Single */ ? 268435456 /* UseSingleQuotesForStringLiteralType */ : void 0;
+        let typeNode = checker.typeToTypeNode(type, enclosingDeclaration, flags, getNoopSymbolTrackerWithResolver(context));
+        if (importAdder) {
+          const importableReference = tryGetAutoImportableReferenceFromTypeNode(typeNode, scriptTarget);
+          if (importableReference) {
+            typeNode = importableReference.typeNode;
+            importSymbols(importAdder, importableReference.symbols);
+          }
         }
-        const newSig = checker.createSignature(
-          declaration,
-          sig.typeParameters,
-          sig.thisParameter,
-          sig.parameters,
-          exprType,
-          /*typePredicate*/
-          void 0,
-          sig.minArgumentCount,
-          sig.flags
-        );
-        exprType = checker.createAnonymousType(
-          /*symbol*/
+        addClassElement(factory.createPropertyDeclaration(
+          modifiers,
+          declaration ? createName(declarationName) : symbol.getName(),
+          optional && preserveOptional & 2 /* Property */ ? factory.createToken(58 /* QuestionToken */) : void 0,
+          typeNode,
+          /*initializer*/
+          void 0
+        ));
+        break;
+      case 177 /* GetAccessor */:
+      case 178 /* SetAccessor */: {
+        Debug.assertIsDefined(declarations);
+        let typeNode2 = checker.typeToTypeNode(
+          type,
+          enclosingDeclaration,
+          /*flags*/
           void 0,
-          createSymbolTable(),
-          [newSig],
-          [],
-          []
+          getNoopSymbolTrackerWithResolver(context)
         );
-      } else {
-        exprType = checker.getAnyType();
+        const allAccessors = getAllAccessorDeclarations(declarations, declaration);
+        const orderedAccessors = allAccessors.secondAccessor ? [allAccessors.firstAccessor, allAccessors.secondAccessor] : [allAccessors.firstAccessor];
+        if (importAdder) {
+          const importableReference = tryGetAutoImportableReferenceFromTypeNode(typeNode2, scriptTarget);
+          if (importableReference) {
+            typeNode2 = importableReference.typeNode;
+            importSymbols(importAdder, importableReference.symbols);
+          }
+        }
+        for (const accessor of orderedAccessors) {
+          if (isGetAccessorDeclaration(accessor)) {
+            addClassElement(factory.createGetAccessorDeclaration(
+              modifiers,
+              createName(declarationName),
+              emptyArray,
+              createTypeNode(typeNode2),
+              createBody(body, quotePreference, ambient)
+            ));
+          } else {
+            Debug.assertNode(accessor, isSetAccessorDeclaration, "The counterpart to a getter should be a setter");
+            const parameter = getSetAccessorValueParameter(accessor);
+            const parameterName = parameter && isIdentifier(parameter.name) ? idText(parameter.name) : void 0;
+            addClassElement(factory.createSetAccessorDeclaration(
+              modifiers,
+              createName(declarationName),
+              createDummyParameters(
+                1,
+                [parameterName],
+                [createTypeNode(typeNode2)],
+                1,
+                /*inJs*/
+                false
+              ),
+              createBody(body, quotePreference, ambient)
+            ));
+          }
+        }
+        break;
       }
+      case 173 /* MethodSignature */:
+      case 174 /* MethodDeclaration */:
+        Debug.assertIsDefined(declarations);
+        const signatures = type.isUnion() ? flatMap(type.types, (t) => t.getCallSignatures()) : type.getCallSignatures();
+        if (!some(signatures)) {
+          break;
+        }
+        if (declarations.length === 1) {
+          Debug.assert(signatures.length === 1, "One declaration implies one signature");
+          const signature = signatures[0];
+          outputMethod(quotePreference, signature, modifiers, createName(declarationName), createBody(body, quotePreference, ambient));
+          break;
+        }
+        for (const signature of signatures) {
+          outputMethod(quotePreference, signature, modifiers, createName(declarationName));
+        }
+        if (!ambient) {
+          if (declarations.length > signatures.length) {
+            const signature = checker.getSignatureFromDeclaration(declarations[declarations.length - 1]);
+            outputMethod(quotePreference, signature, modifiers, createName(declarationName), createBody(body, quotePreference));
+          } else {
+            Debug.assert(declarations.length === signatures.length, "Declarations and signatures should match count");
+            addClassElement(createMethodImplementingSignatures(checker, context, enclosingDeclaration, signatures, createName(declarationName), optional && !!(preserveOptional & 1 /* Method */), modifiers, quotePreference, body));
+          }
+        }
+        break;
     }
-    return checker.isTypeAssignableTo(exprType, type);
-  }
-  function getInfo9(checker, sourceFile, position, errorCode) {
-    const node = getTokenAtPosition(sourceFile, position);
-    if (!node.parent)
-      return void 0;
-    const declaration = findAncestor(node.parent, isFunctionLikeDeclaration);
-    switch (errorCode) {
-      case Diagnostics.A_function_whose_declared_type_is_neither_undefined_void_nor_any_must_return_a_value.code:
-        if (!declaration || !declaration.body || !declaration.type || !rangeContainsRange(declaration.type, node))
-          return void 0;
-        return getFixInfo(
-          checker,
-          declaration,
-          checker.getTypeFromTypeNode(declaration.type),
-          /*isFunctionType*/
-          false
-        );
-      case Diagnostics.Argument_of_type_0_is_not_assignable_to_parameter_of_type_1.code:
-        if (!declaration || !isCallExpression(declaration.parent) || !declaration.body)
-          return void 0;
-        const pos = declaration.parent.arguments.indexOf(declaration);
-        const type = checker.getContextualTypeForArgumentAtIndex(declaration.parent, pos);
-        if (!type)
-          return void 0;
-        return getFixInfo(
-          checker,
-          declaration,
-          type,
-          /*isFunctionType*/
-          true
-        );
-      case Diagnostics.Type_0_is_not_assignable_to_type_1.code:
-        if (!isDeclarationName(node) || !isVariableLike(node.parent) && !isJsxAttribute(node.parent))
-          return void 0;
-        const initializer = getVariableLikeInitializer(node.parent);
-        if (!initializer || !isFunctionLikeDeclaration(initializer) || !initializer.body)
-          return void 0;
-        return getFixInfo(
-          checker,
-          initializer,
-          checker.getTypeAtLocation(node.parent),
-          /*isFunctionType*/
-          true
-        );
+    function outputMethod(quotePreference2, signature, modifiers2, name, body2) {
+      const method = createSignatureDeclarationFromSignature(174 /* MethodDeclaration */, context, quotePreference2, signature, body2, name, modifiers2, optional && !!(preserveOptional & 1 /* Method */), enclosingDeclaration, importAdder);
+      if (method)
+        addClassElement(method);
     }
-    return void 0;
-  }
-  function getVariableLikeInitializer(declaration) {
-    switch (declaration.kind) {
-      case 259 /* VariableDeclaration */:
-      case 168 /* Parameter */:
-      case 207 /* BindingElement */:
-      case 171 /* PropertyDeclaration */:
-      case 302 /* PropertyAssignment */:
-        return declaration.initializer;
-      case 290 /* JsxAttribute */:
-        return declaration.initializer && (isJsxExpression(declaration.initializer) ? declaration.initializer.expression : void 0);
-      case 303 /* ShorthandPropertyAssignment */:
-      case 170 /* PropertySignature */:
-      case 305 /* EnumMember */:
-      case 354 /* JSDocPropertyTag */:
-      case 347 /* JSDocParameterTag */:
-        return void 0;
+    function createModifiers() {
+      let modifiers2;
+      if (modifierFlags) {
+        modifiers2 = combine(modifiers2, factory.createModifiersFromModifierFlags(modifierFlags));
+      }
+      if (shouldAddOverrideKeyword()) {
+        modifiers2 = append(modifiers2, factory.createToken(164 /* OverrideKeyword */));
+      }
+      return modifiers2 && factory.createNodeArray(modifiers2);
+    }
+    function shouldAddOverrideKeyword() {
+      return !!(context.program.getCompilerOptions().noImplicitOverride && declaration && hasAbstractModifier(declaration));
+    }
+    function createName(node) {
+      if (isIdentifier(node) && node.escapedText === "constructor") {
+        return factory.createComputedPropertyName(factory.createStringLiteral(idText(node), quotePreference === 0 /* Single */));
+      }
+      return getSynthesizedDeepClone(
+        node,
+        /*includeTrivia*/
+        false
+      );
+    }
+    function createBody(block, quotePreference2, ambient2) {
+      return ambient2 ? void 0 : getSynthesizedDeepClone(
+        block,
+        /*includeTrivia*/
+        false
+      ) || createStubbedMethodBody(quotePreference2);
+    }
+    function createTypeNode(typeNode) {
+      return getSynthesizedDeepClone(
+        typeNode,
+        /*includeTrivia*/
+        false
+      );
+    }
+    function createDeclarationName(symbol2, declaration2) {
+      if (getCheckFlags(symbol2) & 262144 /* Mapped */) {
+        const nameType = symbol2.links.nameType;
+        if (nameType && isTypeUsableAsPropertyName(nameType)) {
+          return factory.createIdentifier(unescapeLeadingUnderscores(getPropertyNameFromType(nameType)));
+        }
+      }
+      return getSynthesizedDeepClone(
+        getNameOfDeclaration(declaration2),
+        /*includeTrivia*/
+        false
+      );
     }
   }
-  function addReturnStatement(changes, sourceFile, expression, statement) {
-    suppressLeadingAndTrailingTrivia(expression);
-    const probablyNeedSemi = probablyUsesSemicolons(sourceFile);
-    changes.replaceNode(sourceFile, statement, factory.createReturnStatement(expression), {
-      leadingTriviaOption: ts_textChanges_exports.LeadingTriviaOption.Exclude,
-      trailingTriviaOption: ts_textChanges_exports.TrailingTriviaOption.Exclude,
-      suffix: probablyNeedSemi ? ";" : void 0
-    });
-  }
-  function removeBlockBodyBrace(changes, sourceFile, declaration, expression, commentSource, withParen) {
-    const newBody = withParen || needsParentheses(expression) ? factory.createParenthesizedExpression(expression) : expression;
-    suppressLeadingAndTrailingTrivia(commentSource);
-    copyComments(commentSource, newBody);
-    changes.replaceNode(sourceFile, declaration.body, newBody);
-  }
-  function wrapBlockWithParen(changes, sourceFile, declaration, expression) {
-    changes.replaceNode(sourceFile, declaration.body, factory.createParenthesizedExpression(expression));
-  }
-  function getActionForfixAddReturnStatement(context, expression, statement) {
-    const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => addReturnStatement(t, context.sourceFile, expression, statement));
-    return createCodeFixAction(fixId23, changes, Diagnostics.Add_a_return_statement, fixIdAddReturnStatement, Diagnostics.Add_all_missing_return_statement);
-  }
-  function getActionForFixRemoveBracesFromArrowFunctionBody(context, declaration, expression, commentSource) {
-    const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => removeBlockBodyBrace(
-      t,
-      context.sourceFile,
-      declaration,
-      expression,
-      commentSource,
-      /*withParen*/
-      false
-    ));
-    return createCodeFixAction(fixId23, changes, Diagnostics.Remove_braces_from_arrow_function_body, fixRemoveBracesFromArrowFunctionBody, Diagnostics.Remove_braces_from_all_arrow_function_bodies_with_relevant_issues);
-  }
-  function getActionForfixWrapTheBlockWithParen(context, declaration, expression) {
-    const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => wrapBlockWithParen(t, context.sourceFile, declaration, expression));
-    return createCodeFixAction(fixId23, changes, Diagnostics.Wrap_the_following_body_with_parentheses_which_should_be_an_object_literal, fixIdWrapTheBlockWithParen, Diagnostics.Wrap_all_object_literal_with_parentheses);
-  }
-  var fixId23, fixIdAddReturnStatement, fixRemoveBracesFromArrowFunctionBody, fixIdWrapTheBlockWithParen, errorCodes26;
-  var init_returnValueCorrect = __esm({
-    "src/services/codefixes/returnValueCorrect.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_codefix();
-      fixId23 = "returnValueCorrect";
-      fixIdAddReturnStatement = "fixAddReturnStatement";
-      fixRemoveBracesFromArrowFunctionBody = "fixRemoveBracesFromArrowFunctionBody";
-      fixIdWrapTheBlockWithParen = "fixWrapTheBlockWithParen";
-      errorCodes26 = [
-        Diagnostics.A_function_whose_declared_type_is_neither_undefined_void_nor_any_must_return_a_value.code,
-        Diagnostics.Type_0_is_not_assignable_to_type_1.code,
-        Diagnostics.Argument_of_type_0_is_not_assignable_to_parameter_of_type_1.code
-      ];
-      registerCodeFix({
-        errorCodes: errorCodes26,
-        fixIds: [fixIdAddReturnStatement, fixRemoveBracesFromArrowFunctionBody, fixIdWrapTheBlockWithParen],
-        getCodeActions: function getCodeActionsToCorrectReturnValue(context) {
-          const { program, sourceFile, span: { start }, errorCode } = context;
-          const info = getInfo9(program.getTypeChecker(), sourceFile, start, errorCode);
-          if (!info)
-            return void 0;
-          if (info.kind === 0 /* MissingReturnStatement */) {
-            return append(
-              [getActionForfixAddReturnStatement(context, info.expression, info.statement)],
-              isArrowFunction(info.declaration) ? getActionForFixRemoveBracesFromArrowFunctionBody(context, info.declaration, info.expression, info.commentSource) : void 0
-            );
-          } else {
-            return [getActionForfixWrapTheBlockWithParen(context, info.declaration, info.expression)];
+  function createSignatureDeclarationFromSignature(kind, context, quotePreference, signature, body, name, modifiers, optional, enclosingDeclaration, importAdder) {
+    const program = context.program;
+    const checker = program.getTypeChecker();
+    const scriptTarget = getEmitScriptTarget(program.getCompilerOptions());
+    const isJs = isInJSFile(enclosingDeclaration);
+    const flags = 1 /* NoTruncation */ | 256 /* SuppressAnyReturnType */ | 524288 /* AllowEmptyTuple */ | (quotePreference === 0 /* Single */ ? 268435456 /* UseSingleQuotesForStringLiteralType */ : 0 /* None */);
+    const signatureDeclaration = checker.signatureToSignatureDeclaration(signature, kind, enclosingDeclaration, flags, getNoopSymbolTrackerWithResolver(context));
+    if (!signatureDeclaration) {
+      return void 0;
+    }
+    let typeParameters = isJs ? void 0 : signatureDeclaration.typeParameters;
+    let parameters = signatureDeclaration.parameters;
+    let type = isJs ? void 0 : signatureDeclaration.type;
+    if (importAdder) {
+      if (typeParameters) {
+        const newTypeParameters = sameMap(typeParameters, (typeParameterDecl) => {
+          let constraint = typeParameterDecl.constraint;
+          let defaultType = typeParameterDecl.default;
+          if (constraint) {
+            const importableReference = tryGetAutoImportableReferenceFromTypeNode(constraint, scriptTarget);
+            if (importableReference) {
+              constraint = importableReference.typeNode;
+              importSymbols(importAdder, importableReference.symbols);
+            }
           }
-        },
-        getAllCodeActions: (context) => codeFixAll(context, errorCodes26, (changes, diag2) => {
-          const info = getInfo9(context.program.getTypeChecker(), diag2.file, diag2.start, diag2.code);
-          if (!info)
-            return void 0;
-          switch (context.fixId) {
-            case fixIdAddReturnStatement:
-              addReturnStatement(changes, diag2.file, info.expression, info.statement);
-              break;
-            case fixRemoveBracesFromArrowFunctionBody:
-              if (!isArrowFunction(info.declaration))
-                return void 0;
-              removeBlockBodyBrace(
-                changes,
-                diag2.file,
-                info.declaration,
-                info.expression,
-                info.commentSource,
-                /*withParen*/
-                false
-              );
-              break;
-            case fixIdWrapTheBlockWithParen:
-              if (!isArrowFunction(info.declaration))
-                return void 0;
-              wrapBlockWithParen(changes, diag2.file, info.declaration, info.expression);
-              break;
-            default:
-              Debug.fail(JSON.stringify(context.fixId));
+          if (defaultType) {
+            const importableReference = tryGetAutoImportableReferenceFromTypeNode(defaultType, scriptTarget);
+            if (importableReference) {
+              defaultType = importableReference.typeNode;
+              importSymbols(importAdder, importableReference.symbols);
+            }
           }
-        })
+          return factory.updateTypeParameterDeclaration(
+            typeParameterDecl,
+            typeParameterDecl.modifiers,
+            typeParameterDecl.name,
+            constraint,
+            defaultType
+          );
+        });
+        if (typeParameters !== newTypeParameters) {
+          typeParameters = setTextRange(factory.createNodeArray(newTypeParameters, typeParameters.hasTrailingComma), typeParameters);
+        }
+      }
+      const newParameters = sameMap(parameters, (parameterDecl) => {
+        let type2 = isJs ? void 0 : parameterDecl.type;
+        if (type2) {
+          const importableReference = tryGetAutoImportableReferenceFromTypeNode(type2, scriptTarget);
+          if (importableReference) {
+            type2 = importableReference.typeNode;
+            importSymbols(importAdder, importableReference.symbols);
+          }
+        }
+        return factory.updateParameterDeclaration(
+          parameterDecl,
+          parameterDecl.modifiers,
+          parameterDecl.dotDotDotToken,
+          parameterDecl.name,
+          isJs ? void 0 : parameterDecl.questionToken,
+          type2,
+          parameterDecl.initializer
+        );
       });
+      if (parameters !== newParameters) {
+        parameters = setTextRange(factory.createNodeArray(newParameters, parameters.hasTrailingComma), parameters);
+      }
+      if (type) {
+        const importableReference = tryGetAutoImportableReferenceFromTypeNode(type, scriptTarget);
+        if (importableReference) {
+          type = importableReference.typeNode;
+          importSymbols(importAdder, importableReference.symbols);
+        }
+      }
     }
-  });
-
-  // src/services/codefixes/fixAddMissingMember.ts
-  function getInfo10(sourceFile, tokenPos, errorCode, checker, program) {
-    var _a;
-    const token = getTokenAtPosition(sourceFile, tokenPos);
-    const parent2 = token.parent;
-    if (errorCode === Diagnostics.Argument_of_type_0_is_not_assignable_to_parameter_of_type_1.code) {
-      if (!(token.kind === 19 /* OpenBraceToken */ && isObjectLiteralExpression(parent2) && isCallExpression(parent2.parent)))
-        return void 0;
-      const argIndex = findIndex(parent2.parent.arguments, (arg) => arg === parent2);
-      if (argIndex < 0)
-        return void 0;
-      const signature = checker.getResolvedSignature(parent2.parent);
-      if (!(signature && signature.declaration && signature.parameters[argIndex]))
-        return void 0;
-      const param = signature.parameters[argIndex].valueDeclaration;
-      if (!(param && isParameter(param) && isIdentifier(param.name)))
-        return void 0;
-      const properties = arrayFrom(checker.getUnmatchedProperties(
-        checker.getTypeAtLocation(parent2),
-        checker.getParameterType(signature, argIndex),
-        /*requireOptionalProperties*/
-        false,
-        /*matchDiscriminantProperties*/
-        false
-      ));
-      if (!length(properties))
-        return void 0;
-      return { kind: 3 /* ObjectLiteral */, token: param.name, properties, parentDeclaration: parent2 };
+    const questionToken = optional ? factory.createToken(58 /* QuestionToken */) : void 0;
+    const asteriskToken = signatureDeclaration.asteriskToken;
+    if (isFunctionExpression(signatureDeclaration)) {
+      return factory.updateFunctionExpression(signatureDeclaration, modifiers, signatureDeclaration.asteriskToken, tryCast(name, isIdentifier), typeParameters, parameters, type, body ?? signatureDeclaration.body);
     }
-    if (!isMemberName(token))
-      return void 0;
-    if (isIdentifier(token) && hasInitializer(parent2) && parent2.initializer && isObjectLiteralExpression(parent2.initializer)) {
-      const targetType = checker.getContextualType(token) || checker.getTypeAtLocation(token);
-      const properties = arrayFrom(checker.getUnmatchedProperties(
-        checker.getTypeAtLocation(parent2.initializer),
-        targetType,
-        /*requireOptionalProperties*/
-        false,
-        /*matchDiscriminantProperties*/
-        false
-      ));
-      if (!length(properties))
-        return void 0;
-      return { kind: 3 /* ObjectLiteral */, token, properties, parentDeclaration: parent2.initializer };
+    if (isArrowFunction(signatureDeclaration)) {
+      return factory.updateArrowFunction(signatureDeclaration, modifiers, typeParameters, parameters, type, signatureDeclaration.equalsGreaterThanToken, body ?? signatureDeclaration.body);
     }
-    if (isIdentifier(token) && isJsxOpeningLikeElement(token.parent)) {
-      const target = getEmitScriptTarget(program.getCompilerOptions());
-      const attributes = getUnmatchedAttributes(checker, target, token.parent);
-      if (!length(attributes))
-        return void 0;
-      return { kind: 4 /* JsxAttributes */, token, attributes, parentDeclaration: token.parent };
+    if (isMethodDeclaration(signatureDeclaration)) {
+      return factory.updateMethodDeclaration(signatureDeclaration, modifiers, asteriskToken, name ?? factory.createIdentifier(""), questionToken, typeParameters, parameters, type, body);
     }
-    if (isIdentifier(token)) {
-      const type = (_a = checker.getContextualType(token)) == null ? void 0 : _a.getNonNullableType();
-      if (type && getObjectFlags(type) & 16 /* Anonymous */) {
-        const signature = firstOrUndefined(checker.getSignaturesOfType(type, 0 /* Call */));
-        if (signature === void 0)
-          return void 0;
-        return { kind: 5 /* Signature */, token, signature, sourceFile, parentDeclaration: findScope(token) };
-      }
-      if (isCallExpression(parent2) && parent2.expression === token) {
-        return { kind: 2 /* Function */, token, call: parent2, sourceFile, modifierFlags: 0 /* None */, parentDeclaration: findScope(token) };
+    if (isFunctionDeclaration(signatureDeclaration)) {
+      return factory.updateFunctionDeclaration(signatureDeclaration, modifiers, signatureDeclaration.asteriskToken, tryCast(name, isIdentifier), typeParameters, parameters, type, body ?? signatureDeclaration.body);
+    }
+    return void 0;
+  }
+  function createSignatureDeclarationFromCallExpression(kind, context, importAdder, call, name, modifierFlags, contextNode) {
+    const quotePreference = getQuotePreference(context.sourceFile, context.preferences);
+    const scriptTarget = getEmitScriptTarget(context.program.getCompilerOptions());
+    const tracker = getNoopSymbolTrackerWithResolver(context);
+    const checker = context.program.getTypeChecker();
+    const isJs = isInJSFile(contextNode);
+    const { typeArguments, arguments: args, parent: parent2 } = call;
+    const contextualType = isJs ? void 0 : checker.getContextualType(call);
+    const names = map(args, (arg) => isIdentifier(arg) ? arg.text : isPropertyAccessExpression(arg) && isIdentifier(arg.name) ? arg.name.text : void 0);
+    const instanceTypes = isJs ? [] : map(args, (arg) => checker.getTypeAtLocation(arg));
+    const { argumentTypeNodes, argumentTypeParameters } = getArgumentTypesAndTypeParameters(
+      checker,
+      importAdder,
+      instanceTypes,
+      contextNode,
+      scriptTarget,
+      1 /* NoTruncation */,
+      tracker
+    );
+    const modifiers = modifierFlags ? factory.createNodeArray(factory.createModifiersFromModifierFlags(modifierFlags)) : void 0;
+    const asteriskToken = isYieldExpression(parent2) ? factory.createToken(42 /* AsteriskToken */) : void 0;
+    const typeParameters = isJs ? void 0 : createTypeParametersForArguments(checker, argumentTypeParameters, typeArguments);
+    const parameters = createDummyParameters(
+      args.length,
+      names,
+      argumentTypeNodes,
+      /*minArgumentCount*/
+      void 0,
+      isJs
+    );
+    const type = isJs || contextualType === void 0 ? void 0 : checker.typeToTypeNode(
+      contextualType,
+      contextNode,
+      /*flags*/
+      void 0,
+      tracker
+    );
+    switch (kind) {
+      case 174 /* MethodDeclaration */:
+        return factory.createMethodDeclaration(
+          modifiers,
+          asteriskToken,
+          name,
+          /*questionToken*/
+          void 0,
+          typeParameters,
+          parameters,
+          type,
+          createStubbedMethodBody(quotePreference)
+        );
+      case 173 /* MethodSignature */:
+        return factory.createMethodSignature(
+          modifiers,
+          name,
+          /*questionToken*/
+          void 0,
+          typeParameters,
+          parameters,
+          type === void 0 ? factory.createKeywordTypeNode(159 /* UnknownKeyword */) : type
+        );
+      case 262 /* FunctionDeclaration */:
+        Debug.assert(typeof name === "string" || isIdentifier(name), "Unexpected name");
+        return factory.createFunctionDeclaration(
+          modifiers,
+          asteriskToken,
+          name,
+          typeParameters,
+          parameters,
+          type,
+          createStubbedBody(Diagnostics.Function_not_implemented.message, quotePreference)
+        );
+      default:
+        Debug.fail("Unexpected kind");
+    }
+  }
+  function createTypeParametersForArguments(checker, argumentTypeParameters, typeArguments) {
+    const usedNames = new Set(argumentTypeParameters.map((pair) => pair[0]));
+    const constraintsByName = new Map(argumentTypeParameters);
+    if (typeArguments) {
+      const typeArgumentsWithNewTypes = typeArguments.filter((typeArgument) => !argumentTypeParameters.some((pair) => {
+        var _a;
+        return checker.getTypeAtLocation(typeArgument) === ((_a = pair[1]) == null ? void 0 : _a.argumentType);
+      }));
+      const targetSize = usedNames.size + typeArgumentsWithNewTypes.length;
+      for (let i = 0; usedNames.size < targetSize; i += 1) {
+        usedNames.add(createTypeParameterName(i));
       }
     }
-    if (!isPropertyAccessExpression(parent2))
-      return void 0;
-    const leftExpressionType = skipConstraint(checker.getTypeAtLocation(parent2.expression));
-    const symbol = leftExpressionType.symbol;
-    if (!symbol || !symbol.declarations)
-      return void 0;
-    if (isIdentifier(token) && isCallExpression(parent2.parent)) {
-      const moduleDeclaration = find(symbol.declarations, isModuleDeclaration);
-      const moduleDeclarationSourceFile = moduleDeclaration == null ? void 0 : moduleDeclaration.getSourceFile();
-      if (moduleDeclaration && moduleDeclarationSourceFile && !isSourceFileFromLibrary(program, moduleDeclarationSourceFile)) {
-        return { kind: 2 /* Function */, token, call: parent2.parent, sourceFile, modifierFlags: 1 /* Export */, parentDeclaration: moduleDeclaration };
+    return arrayFrom(
+      usedNames.values(),
+      (usedName) => {
+        var _a;
+        return factory.createTypeParameterDeclaration(
+          /*modifiers*/
+          void 0,
+          usedName,
+          (_a = constraintsByName.get(usedName)) == null ? void 0 : _a.constraint
+        );
       }
-      const moduleSourceFile = find(symbol.declarations, isSourceFile);
-      if (sourceFile.commonJsModuleIndicator)
-        return void 0;
-      if (moduleSourceFile && !isSourceFileFromLibrary(program, moduleSourceFile)) {
-        return { kind: 2 /* Function */, token, call: parent2.parent, sourceFile: moduleSourceFile, modifierFlags: 1 /* Export */, parentDeclaration: moduleSourceFile };
+    );
+  }
+  function createTypeParameterName(index) {
+    return 84 /* T */ + index <= 90 /* Z */ ? String.fromCharCode(84 /* T */ + index) : `T${index}`;
+  }
+  function typeToAutoImportableTypeNode(checker, importAdder, type, contextNode, scriptTarget, flags, tracker) {
+    let typeNode = checker.typeToTypeNode(type, contextNode, flags, tracker);
+    if (typeNode && isImportTypeNode(typeNode)) {
+      const importableReference = tryGetAutoImportableReferenceFromTypeNode(typeNode, scriptTarget);
+      if (importableReference) {
+        importSymbols(importAdder, importableReference.symbols);
+        typeNode = importableReference.typeNode;
       }
     }
-    const classDeclaration = find(symbol.declarations, isClassLike);
-    if (!classDeclaration && isPrivateIdentifier(token))
-      return void 0;
-    const declaration = classDeclaration || find(symbol.declarations, (d) => isInterfaceDeclaration(d) || isTypeLiteralNode(d));
-    if (declaration && !isSourceFileFromLibrary(program, declaration.getSourceFile())) {
-      const makeStatic = !isTypeLiteralNode(declaration) && (leftExpressionType.target || leftExpressionType) !== checker.getDeclaredTypeOfSymbol(symbol);
-      if (makeStatic && (isPrivateIdentifier(token) || isInterfaceDeclaration(declaration)))
-        return void 0;
-      const declSourceFile = declaration.getSourceFile();
-      const modifierFlags = isTypeLiteralNode(declaration) ? 0 /* None */ : (makeStatic ? 32 /* Static */ : 0 /* None */) | (startsWithUnderscore(token.text) ? 8 /* Private */ : 0 /* None */);
-      const isJSFile = isSourceFileJS(declSourceFile);
-      const call = tryCast(parent2.parent, isCallExpression);
-      return { kind: 0 /* TypeLikeDeclaration */, token, call, modifierFlags, parentDeclaration: declaration, declSourceFile, isJSFile };
+    return getSynthesizedDeepClone(typeNode);
+  }
+  function typeContainsTypeParameter(type) {
+    if (type.isUnionOrIntersection()) {
+      return type.types.some(typeContainsTypeParameter);
     }
-    const enumDeclaration = find(symbol.declarations, isEnumDeclaration);
-    if (enumDeclaration && !(leftExpressionType.flags & 1056 /* EnumLike */) && !isPrivateIdentifier(token) && !isSourceFileFromLibrary(program, enumDeclaration.getSourceFile())) {
-      return { kind: 1 /* Enum */, token, parentDeclaration: enumDeclaration };
+    return type.flags & 262144 /* TypeParameter */;
+  }
+  function getArgumentTypesAndTypeParameters(checker, importAdder, instanceTypes, contextNode, scriptTarget, flags, tracker) {
+    const argumentTypeNodes = [];
+    const argumentTypeParameters = /* @__PURE__ */ new Map();
+    for (let i = 0; i < instanceTypes.length; i += 1) {
+      const instanceType = instanceTypes[i];
+      if (instanceType.isUnionOrIntersection() && instanceType.types.some(typeContainsTypeParameter)) {
+        const synthesizedTypeParameterName = createTypeParameterName(i);
+        argumentTypeNodes.push(factory.createTypeReferenceNode(synthesizedTypeParameterName));
+        argumentTypeParameters.set(synthesizedTypeParameterName, void 0);
+        continue;
+      }
+      const widenedInstanceType = checker.getBaseTypeOfLiteralType(instanceType);
+      const argumentTypeNode = typeToAutoImportableTypeNode(checker, importAdder, widenedInstanceType, contextNode, scriptTarget, flags, tracker);
+      if (!argumentTypeNode) {
+        continue;
+      }
+      argumentTypeNodes.push(argumentTypeNode);
+      const argumentTypeParameter = getFirstTypeParameterName(instanceType);
+      const instanceTypeConstraint = instanceType.isTypeParameter() && instanceType.constraint && !isAnonymousObjectConstraintType(instanceType.constraint) ? typeToAutoImportableTypeNode(checker, importAdder, instanceType.constraint, contextNode, scriptTarget, flags, tracker) : void 0;
+      if (argumentTypeParameter) {
+        argumentTypeParameters.set(argumentTypeParameter, { argumentType: instanceType, constraint: instanceTypeConstraint });
+      }
     }
-    return void 0;
+    return { argumentTypeNodes, argumentTypeParameters: arrayFrom(argumentTypeParameters.entries()) };
   }
-  function getActionsForMissingMemberDeclaration(context, info) {
-    return info.isJSFile ? singleElementArray(createActionForAddMissingMemberInJavascriptFile(context, info)) : createActionsForAddMissingMemberInTypeScriptFile(context, info);
+  function isAnonymousObjectConstraintType(type) {
+    return type.flags & 524288 /* Object */ && type.objectFlags === 16 /* Anonymous */;
   }
-  function createActionForAddMissingMemberInJavascriptFile(context, { parentDeclaration, declSourceFile, modifierFlags, token }) {
-    if (isInterfaceDeclaration(parentDeclaration) || isTypeLiteralNode(parentDeclaration)) {
-      return void 0;
-    }
-    const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => addMissingMemberInJs(t, declSourceFile, parentDeclaration, token, !!(modifierFlags & 32 /* Static */)));
-    if (changes.length === 0) {
-      return void 0;
+  function getFirstTypeParameterName(type) {
+    var _a;
+    if (type.flags & (1048576 /* Union */ | 2097152 /* Intersection */)) {
+      for (const subType of type.types) {
+        const subTypeName = getFirstTypeParameterName(subType);
+        if (subTypeName) {
+          return subTypeName;
+        }
+      }
     }
-    const diagnostic = modifierFlags & 32 /* Static */ ? Diagnostics.Initialize_static_property_0 : isPrivateIdentifier(token) ? Diagnostics.Declare_a_private_field_named_0 : Diagnostics.Initialize_property_0_in_the_constructor;
-    return createCodeFixAction(fixMissingMember, changes, [diagnostic, token.text], fixMissingMember, Diagnostics.Add_all_missing_members);
+    return type.flags & 262144 /* TypeParameter */ ? (_a = type.getSymbol()) == null ? void 0 : _a.getName() : void 0;
   }
-  function addMissingMemberInJs(changeTracker, sourceFile, classDeclaration, token, makeStatic) {
-    const tokenName = token.text;
-    if (makeStatic) {
-      if (classDeclaration.kind === 230 /* ClassExpression */) {
-        return;
-      }
-      const className = classDeclaration.name.getText();
-      const staticInitialization = initializePropertyToUndefined(factory.createIdentifier(className), tokenName);
-      changeTracker.insertNodeAfter(sourceFile, classDeclaration, staticInitialization);
-    } else if (isPrivateIdentifier(token)) {
-      const property = factory.createPropertyDeclaration(
+  function createDummyParameters(argCount, names, types, minArgumentCount, inJs) {
+    const parameters = [];
+    const parameterNameCounts = /* @__PURE__ */ new Map();
+    for (let i = 0; i < argCount; i++) {
+      const parameterName = (names == null ? void 0 : names[i]) || `arg${i}`;
+      const parameterNameCount = parameterNameCounts.get(parameterName);
+      parameterNameCounts.set(parameterName, (parameterNameCount || 0) + 1);
+      const newParameter = factory.createParameterDeclaration(
         /*modifiers*/
         void 0,
-        tokenName,
-        /*questionOrExclamationToken*/
+        /*dotDotDotToken*/
         void 0,
+        /*name*/
+        parameterName + (parameterNameCount || ""),
+        /*questionToken*/
+        minArgumentCount !== void 0 && i >= minArgumentCount ? factory.createToken(58 /* QuestionToken */) : void 0,
         /*type*/
-        void 0,
+        inJs ? void 0 : (types == null ? void 0 : types[i]) || factory.createKeywordTypeNode(159 /* UnknownKeyword */),
         /*initializer*/
         void 0
       );
-      const lastProp = getNodeToInsertPropertyAfter(classDeclaration);
-      if (lastProp) {
-        changeTracker.insertNodeAfter(sourceFile, lastProp, property);
-      } else {
-        changeTracker.insertMemberAtStart(sourceFile, classDeclaration, property);
-      }
-    } else {
-      const classConstructor = getFirstConstructorWithBody(classDeclaration);
-      if (!classConstructor) {
-        return;
-      }
-      const propertyInitialization = initializePropertyToUndefined(factory.createThis(), tokenName);
-      changeTracker.insertNodeAtConstructorEnd(sourceFile, classConstructor, propertyInitialization);
+      parameters.push(newParameter);
     }
+    return parameters;
   }
-  function initializePropertyToUndefined(obj, propertyName) {
-    return factory.createExpressionStatement(factory.createAssignment(factory.createPropertyAccessExpression(obj, propertyName), createUndefined()));
-  }
-  function createActionsForAddMissingMemberInTypeScriptFile(context, { parentDeclaration, declSourceFile, modifierFlags, token }) {
-    const memberName = token.text;
-    const isStatic2 = modifierFlags & 32 /* Static */;
-    const typeNode = getTypeNode2(context.program.getTypeChecker(), parentDeclaration, token);
-    const addPropertyDeclarationChanges = (modifierFlags2) => ts_textChanges_exports.ChangeTracker.with(context, (t) => addPropertyDeclaration(t, declSourceFile, parentDeclaration, memberName, typeNode, modifierFlags2));
-    const actions2 = [createCodeFixAction(fixMissingMember, addPropertyDeclarationChanges(modifierFlags & 32 /* Static */), [isStatic2 ? Diagnostics.Declare_static_property_0 : Diagnostics.Declare_property_0, memberName], fixMissingMember, Diagnostics.Add_all_missing_members)];
-    if (isStatic2 || isPrivateIdentifier(token)) {
-      return actions2;
-    }
-    if (modifierFlags & 8 /* Private */) {
-      actions2.unshift(createCodeFixActionWithoutFixAll(fixMissingMember, addPropertyDeclarationChanges(8 /* Private */), [Diagnostics.Declare_private_property_0, memberName]));
+  function createMethodImplementingSignatures(checker, context, enclosingDeclaration, signatures, name, optional, modifiers, quotePreference, body) {
+    let maxArgsSignature = signatures[0];
+    let minArgumentCount = signatures[0].minArgumentCount;
+    let someSigHasRestParameter = false;
+    for (const sig of signatures) {
+      minArgumentCount = Math.min(sig.minArgumentCount, minArgumentCount);
+      if (signatureHasRestParameter(sig)) {
+        someSigHasRestParameter = true;
+      }
+      if (sig.parameters.length >= maxArgsSignature.parameters.length && (!signatureHasRestParameter(sig) || signatureHasRestParameter(maxArgsSignature))) {
+        maxArgsSignature = sig;
+      }
     }
-    actions2.push(createAddIndexSignatureAction(context, declSourceFile, parentDeclaration, token.text, typeNode));
-    return actions2;
-  }
-  function getTypeNode2(checker, node, token) {
-    let typeNode;
-    if (token.parent.parent.kind === 225 /* BinaryExpression */) {
-      const binaryExpression = token.parent.parent;
-      const otherExpression = token.parent === binaryExpression.left ? binaryExpression.right : binaryExpression.left;
-      const widenedType = checker.getWidenedType(checker.getBaseTypeOfLiteralType(checker.getTypeAtLocation(otherExpression)));
-      typeNode = checker.typeToTypeNode(widenedType, node, 1 /* NoTruncation */);
-    } else {
-      const contextualType = checker.getContextualType(token.parent);
-      typeNode = contextualType ? checker.typeToTypeNode(
-        contextualType,
-        /*enclosingDeclaration*/
+    const maxNonRestArgs = maxArgsSignature.parameters.length - (signatureHasRestParameter(maxArgsSignature) ? 1 : 0);
+    const maxArgsParameterSymbolNames = maxArgsSignature.parameters.map((symbol) => symbol.name);
+    const parameters = createDummyParameters(
+      maxNonRestArgs,
+      maxArgsParameterSymbolNames,
+      /*types*/
+      void 0,
+      minArgumentCount,
+      /*inJs*/
+      false
+    );
+    if (someSigHasRestParameter) {
+      const restParameter = factory.createParameterDeclaration(
+        /*modifiers*/
         void 0,
-        1 /* NoTruncation */
-      ) : void 0;
+        factory.createToken(26 /* DotDotDotToken */),
+        maxArgsParameterSymbolNames[maxNonRestArgs] || "rest",
+        /*questionToken*/
+        maxNonRestArgs >= minArgumentCount ? factory.createToken(58 /* QuestionToken */) : void 0,
+        factory.createArrayTypeNode(factory.createKeywordTypeNode(159 /* UnknownKeyword */)),
+        /*initializer*/
+        void 0
+      );
+      parameters.push(restParameter);
     }
-    return typeNode || factory.createKeywordTypeNode(133 /* AnyKeyword */);
-  }
-  function addPropertyDeclaration(changeTracker, sourceFile, node, tokenName, typeNode, modifierFlags) {
-    const modifiers = modifierFlags ? factory.createNodeArray(factory.createModifiersFromModifierFlags(modifierFlags)) : void 0;
-    const property = isClassLike(node) ? factory.createPropertyDeclaration(
+    return createStubbedMethod(
       modifiers,
-      tokenName,
-      /*questionOrExclamationToken*/
-      void 0,
-      typeNode,
-      /*initializer*/
-      void 0
-    ) : factory.createPropertySignature(
-      /*modifiers*/
-      void 0,
-      tokenName,
-      /*questionToken*/
+      name,
+      optional,
+      /*typeParameters*/
       void 0,
-      typeNode
+      parameters,
+      getReturnTypeFromSignatures(signatures, checker, context, enclosingDeclaration),
+      quotePreference,
+      body
     );
-    const lastProp = getNodeToInsertPropertyAfter(node);
-    if (lastProp) {
-      changeTracker.insertNodeAfter(sourceFile, lastProp, property);
-    } else {
-      changeTracker.insertMemberAtStart(sourceFile, node, property);
-    }
   }
-  function getNodeToInsertPropertyAfter(node) {
-    let res;
-    for (const member of node.members) {
-      if (!isPropertyDeclaration(member))
-        break;
-      res = member;
+  function getReturnTypeFromSignatures(signatures, checker, context, enclosingDeclaration) {
+    if (length(signatures)) {
+      const type = checker.getUnionType(map(signatures, checker.getReturnTypeOfSignature));
+      return checker.typeToTypeNode(type, enclosingDeclaration, 1 /* NoTruncation */, getNoopSymbolTrackerWithResolver(context));
     }
-    return res;
   }
-  function createAddIndexSignatureAction(context, sourceFile, node, tokenName, typeNode) {
-    const stringTypeNode = factory.createKeywordTypeNode(154 /* StringKeyword */);
-    const indexingParameter = factory.createParameterDeclaration(
-      /*modifiers*/
-      void 0,
-      /*dotDotDotToken*/
-      void 0,
-      "x",
-      /*questionToken*/
+  function createStubbedMethod(modifiers, name, optional, typeParameters, parameters, returnType, quotePreference, body) {
+    return factory.createMethodDeclaration(
+      modifiers,
+      /*asteriskToken*/
       void 0,
-      stringTypeNode,
-      /*initializer*/
-      void 0
+      name,
+      optional ? factory.createToken(58 /* QuestionToken */) : void 0,
+      typeParameters,
+      parameters,
+      returnType,
+      body || createStubbedMethodBody(quotePreference)
     );
-    const indexSignature = factory.createIndexSignature(
-      /*modifiers*/
-      void 0,
-      [indexingParameter],
-      typeNode
+  }
+  function createStubbedMethodBody(quotePreference) {
+    return createStubbedBody(Diagnostics.Method_not_implemented.message, quotePreference);
+  }
+  function createStubbedBody(text, quotePreference) {
+    return factory.createBlock(
+      [factory.createThrowStatement(
+        factory.createNewExpression(
+          factory.createIdentifier("Error"),
+          /*typeArguments*/
+          void 0,
+          // TODO Handle auto quote preference.
+          [factory.createStringLiteral(
+            text,
+            /*isSingleQuote*/
+            quotePreference === 0 /* Single */
+          )]
+        )
+      )],
+      /*multiLine*/
+      true
     );
-    const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => t.insertMemberAtStart(sourceFile, node, indexSignature));
-    return createCodeFixActionWithoutFixAll(fixMissingMember, changes, [Diagnostics.Add_index_signature_for_property_0, tokenName]);
   }
-  function getActionsForMissingMethodDeclaration(context, info) {
-    const { parentDeclaration, declSourceFile, modifierFlags, token, call } = info;
-    if (call === void 0) {
+  function setJsonCompilerOptionValues(changeTracker, configFile, options) {
+    const tsconfigObjectLiteral = getTsConfigObjectLiteralExpression(configFile);
+    if (!tsconfigObjectLiteral)
       return void 0;
+    const compilerOptionsProperty = findJsonProperty(tsconfigObjectLiteral, "compilerOptions");
+    if (compilerOptionsProperty === void 0) {
+      changeTracker.insertNodeAtObjectStart(
+        configFile,
+        tsconfigObjectLiteral,
+        createJsonPropertyAssignment(
+          "compilerOptions",
+          factory.createObjectLiteralExpression(
+            options.map(([optionName, optionValue]) => createJsonPropertyAssignment(optionName, optionValue)),
+            /*multiLine*/
+            true
+          )
+        )
+      );
+      return;
     }
-    if (isPrivateIdentifier(token)) {
-      return void 0;
+    const compilerOptions = compilerOptionsProperty.initializer;
+    if (!isObjectLiteralExpression(compilerOptions)) {
+      return;
     }
-    const methodName = token.text;
-    const addMethodDeclarationChanges = (modifierFlags2) => ts_textChanges_exports.ChangeTracker.with(context, (t) => addMethodDeclaration(context, t, call, token, modifierFlags2, parentDeclaration, declSourceFile));
-    const actions2 = [createCodeFixAction(fixMissingMember, addMethodDeclarationChanges(modifierFlags & 32 /* Static */), [modifierFlags & 32 /* Static */ ? Diagnostics.Declare_static_method_0 : Diagnostics.Declare_method_0, methodName], fixMissingMember, Diagnostics.Add_all_missing_members)];
-    if (modifierFlags & 8 /* Private */) {
-      actions2.unshift(createCodeFixActionWithoutFixAll(fixMissingMember, addMethodDeclarationChanges(8 /* Private */), [Diagnostics.Declare_private_method_0, methodName]));
+    for (const [optionName, optionValue] of options) {
+      const optionProperty = findJsonProperty(compilerOptions, optionName);
+      if (optionProperty === void 0) {
+        changeTracker.insertNodeAtObjectStart(configFile, compilerOptions, createJsonPropertyAssignment(optionName, optionValue));
+      } else {
+        changeTracker.replaceNode(configFile, optionProperty.initializer, optionValue);
+      }
     }
-    return actions2;
   }
-  function addMethodDeclaration(context, changes, callExpression, name, modifierFlags, parentDeclaration, sourceFile) {
-    const importAdder = createImportAdder(sourceFile, context.program, context.preferences, context.host);
-    const kind = isClassLike(parentDeclaration) ? 173 /* MethodDeclaration */ : 172 /* MethodSignature */;
-    const signatureDeclaration = createSignatureDeclarationFromCallExpression(kind, context, importAdder, callExpression, name, modifierFlags, parentDeclaration);
-    const containingMethodDeclaration = tryGetContainingMethodDeclaration(parentDeclaration, callExpression);
-    if (containingMethodDeclaration) {
-      changes.insertNodeAfter(sourceFile, containingMethodDeclaration, signatureDeclaration);
-    } else {
-      changes.insertMemberAtStart(sourceFile, parentDeclaration, signatureDeclaration);
-    }
-    importAdder.writeFixes(changes);
+  function setJsonCompilerOptionValue(changeTracker, configFile, optionName, optionValue) {
+    setJsonCompilerOptionValues(changeTracker, configFile, [[optionName, optionValue]]);
   }
-  function addEnumMemberDeclaration(changes, checker, { token, parentDeclaration }) {
-    const hasStringInitializer = some(parentDeclaration.members, (member) => {
-      const type = checker.getTypeAtLocation(member);
-      return !!(type && type.flags & 402653316 /* StringLike */);
-    });
-    const enumMember = factory.createEnumMember(token, hasStringInitializer ? factory.createStringLiteral(token.text) : void 0);
-    changes.replaceNode(parentDeclaration.getSourceFile(), parentDeclaration, factory.updateEnumDeclaration(
-      parentDeclaration,
-      parentDeclaration.modifiers,
-      parentDeclaration.name,
-      concatenate(parentDeclaration.members, singleElementArray(enumMember))
-    ), {
-      leadingTriviaOption: ts_textChanges_exports.LeadingTriviaOption.IncludeAll,
-      trailingTriviaOption: ts_textChanges_exports.TrailingTriviaOption.Exclude
-    });
+  function createJsonPropertyAssignment(name, initializer) {
+    return factory.createPropertyAssignment(factory.createStringLiteral(name), initializer);
   }
-  function addFunctionDeclaration(changes, context, info) {
-    const quotePreference = getQuotePreference(context.sourceFile, context.preferences);
-    const importAdder = createImportAdder(context.sourceFile, context.program, context.preferences, context.host);
-    const functionDeclaration = info.kind === 2 /* Function */ ? createSignatureDeclarationFromCallExpression(261 /* FunctionDeclaration */, context, importAdder, info.call, idText(info.token), info.modifierFlags, info.parentDeclaration) : createSignatureDeclarationFromSignature(
-      261 /* FunctionDeclaration */,
-      context,
-      quotePreference,
-      info.signature,
-      createStubbedBody(Diagnostics.Function_not_implemented.message, quotePreference),
-      info.token,
-      /*modifiers*/
-      void 0,
-      /*optional*/
-      void 0,
-      /*enclosingDeclaration*/
-      void 0,
-      importAdder
-    );
-    if (functionDeclaration === void 0) {
-      Debug.fail("fixMissingFunctionDeclaration codefix got unexpected error.");
+  function findJsonProperty(obj, name) {
+    return find(obj.properties, (p) => isPropertyAssignment(p) && !!p.name && isStringLiteral(p.name) && p.name.text === name);
+  }
+  function tryGetAutoImportableReferenceFromTypeNode(importTypeNode, scriptTarget) {
+    let symbols;
+    const typeNode = visitNode(importTypeNode, visit, isTypeNode);
+    if (symbols && typeNode) {
+      return { typeNode, symbols };
+    }
+    function visit(node) {
+      if (isLiteralImportTypeNode(node) && node.qualifier) {
+        const firstIdentifier = getFirstIdentifier(node.qualifier);
+        const name = getNameForExportedSymbol(firstIdentifier.symbol, scriptTarget);
+        const qualifier = name !== firstIdentifier.text ? replaceFirstIdentifierOfEntityName(node.qualifier, factory.createIdentifier(name)) : node.qualifier;
+        symbols = append(symbols, firstIdentifier.symbol);
+        const typeArguments = visitNodes2(node.typeArguments, visit, isTypeNode);
+        return factory.createTypeReferenceNode(qualifier, typeArguments);
+      }
+      return visitEachChild(node, visit, nullTransformationContext);
     }
-    isReturnStatement(info.parentDeclaration) ? changes.insertNodeBefore(
-      info.sourceFile,
-      info.parentDeclaration,
-      functionDeclaration,
-      /*blankLineBetween*/
-      true
-    ) : changes.insertNodeAtEndOfScope(info.sourceFile, info.parentDeclaration, functionDeclaration);
-    importAdder.writeFixes(changes);
   }
-  function addJsxAttributes(changes, context, info) {
-    const importAdder = createImportAdder(context.sourceFile, context.program, context.preferences, context.host);
-    const quotePreference = getQuotePreference(context.sourceFile, context.preferences);
-    const checker = context.program.getTypeChecker();
-    const jsxAttributesNode = info.parentDeclaration.attributes;
-    const hasSpreadAttribute = some(jsxAttributesNode.properties, isJsxSpreadAttribute);
-    const attrs = map(info.attributes, (attr) => {
-      const value = tryGetValueFromType(context, checker, importAdder, quotePreference, checker.getTypeOfSymbol(attr), info.parentDeclaration);
-      const name = factory.createIdentifier(attr.name);
-      const jsxAttribute = factory.createJsxAttribute(name, factory.createJsxExpression(
-        /*dotDotDotToken*/
-        void 0,
-        value
-      ));
-      setParent(name, jsxAttribute);
-      return jsxAttribute;
-    });
-    const jsxAttributes = factory.createJsxAttributes(hasSpreadAttribute ? [...attrs, ...jsxAttributesNode.properties] : [...jsxAttributesNode.properties, ...attrs]);
-    const options = { prefix: jsxAttributesNode.pos === jsxAttributesNode.end ? " " : void 0 };
-    changes.replaceNode(context.sourceFile, jsxAttributesNode, jsxAttributes, options);
-    importAdder.writeFixes(changes);
+  function replaceFirstIdentifierOfEntityName(name, newIdentifier) {
+    if (name.kind === 80 /* Identifier */) {
+      return newIdentifier;
+    }
+    return factory.createQualifiedName(replaceFirstIdentifierOfEntityName(name.left, newIdentifier), name.right);
   }
-  function addObjectLiteralProperties(changes, context, info) {
-    const importAdder = createImportAdder(context.sourceFile, context.program, context.preferences, context.host);
-    const quotePreference = getQuotePreference(context.sourceFile, context.preferences);
-    const target = getEmitScriptTarget(context.program.getCompilerOptions());
-    const checker = context.program.getTypeChecker();
-    const props = map(info.properties, (prop) => {
-      const initializer = tryGetValueFromType(context, checker, importAdder, quotePreference, checker.getTypeOfSymbol(prop), info.parentDeclaration);
-      return factory.createPropertyAssignment(createPropertyNameFromSymbol(prop, target, quotePreference, checker), initializer);
-    });
-    const options = {
-      leadingTriviaOption: ts_textChanges_exports.LeadingTriviaOption.Exclude,
-      trailingTriviaOption: ts_textChanges_exports.TrailingTriviaOption.Exclude,
-      indentation: info.indentation
-    };
-    changes.replaceNode(context.sourceFile, info.parentDeclaration, factory.createObjectLiteralExpression(
-      [...info.parentDeclaration.properties, ...props],
-      /*multiLine*/
+  function importSymbols(importAdder, symbols) {
+    symbols.forEach((s) => importAdder.addImportFromExportedSymbol(
+      s,
+      /*isValidTypeOnlyUseSite*/
       true
-    ), options);
-    importAdder.writeFixes(changes);
+    ));
   }
-  function tryGetValueFromType(context, checker, importAdder, quotePreference, type, enclosingDeclaration) {
-    if (type.flags & 3 /* AnyOrUnknown */) {
-      return createUndefined();
-    }
-    if (type.flags & (4 /* String */ | 134217728 /* TemplateLiteral */)) {
-      return factory.createStringLiteral(
-        "",
-        /* isSingleQuote */
-        quotePreference === 0 /* Single */
-      );
-    }
-    if (type.flags & 8 /* Number */) {
-      return factory.createNumericLiteral(0);
-    }
-    if (type.flags & 64 /* BigInt */) {
-      return factory.createBigIntLiteral("0n");
-    }
-    if (type.flags & 16 /* Boolean */) {
-      return factory.createFalse();
-    }
-    if (type.flags & 1056 /* EnumLike */) {
-      const enumMember = type.symbol.exports ? firstOrUndefinedIterator(type.symbol.exports.values()) : type.symbol;
-      const name = checker.symbolToExpression(
-        type.symbol.parent ? type.symbol.parent : type.symbol,
-        111551 /* Value */,
-        /*enclosingDeclaration*/
-        void 0,
-        /*flags*/
-        void 0
-      );
-      return enumMember === void 0 || name === void 0 ? factory.createNumericLiteral(0) : factory.createPropertyAccessExpression(name, checker.symbolToString(enumMember));
+  function findAncestorMatchingSpan(sourceFile, span) {
+    const end = textSpanEnd(span);
+    let token = getTokenAtPosition(sourceFile, span.start);
+    while (token.end < end) {
+      token = token.parent;
     }
-    if (type.flags & 256 /* NumberLiteral */) {
-      return factory.createNumericLiteral(type.value);
+    return token;
+  }
+  var PreserveOptionalFlags;
+  var init_helpers2 = __esm({
+    "src/services/codefixes/helpers.ts"() {
+      "use strict";
+      init_ts4();
+      PreserveOptionalFlags = /* @__PURE__ */ ((PreserveOptionalFlags2) => {
+        PreserveOptionalFlags2[PreserveOptionalFlags2["Method"] = 1] = "Method";
+        PreserveOptionalFlags2[PreserveOptionalFlags2["Property"] = 2] = "Property";
+        PreserveOptionalFlags2[PreserveOptionalFlags2["All"] = 3] = "All";
+        return PreserveOptionalFlags2;
+      })(PreserveOptionalFlags || {});
     }
-    if (type.flags & 2048 /* BigIntLiteral */) {
-      return factory.createBigIntLiteral(type.value);
+  });
+
+  // src/services/codefixes/generateAccessors.ts
+  function generateAccessorFromProperty(file, program, start, end, context, _actionName) {
+    const fieldInfo = getAccessorConvertiblePropertyAtPosition(file, program, start, end);
+    if (!fieldInfo || ts_refactor_exports.isRefactorErrorInfo(fieldInfo))
+      return void 0;
+    const changeTracker = ts_textChanges_exports.ChangeTracker.fromContext(context);
+    const { isStatic: isStatic2, isReadonly, fieldName, accessorName, originalName, type, container, declaration } = fieldInfo;
+    suppressLeadingAndTrailingTrivia(fieldName);
+    suppressLeadingAndTrailingTrivia(accessorName);
+    suppressLeadingAndTrailingTrivia(declaration);
+    suppressLeadingAndTrailingTrivia(container);
+    let accessorModifiers;
+    let fieldModifiers;
+    if (isClassLike(container)) {
+      const modifierFlags = getEffectiveModifierFlags(declaration);
+      if (isSourceFileJS(file)) {
+        const modifiers = factory.createModifiersFromModifierFlags(modifierFlags);
+        accessorModifiers = modifiers;
+        fieldModifiers = modifiers;
+      } else {
+        accessorModifiers = factory.createModifiersFromModifierFlags(prepareModifierFlagsForAccessor(modifierFlags));
+        fieldModifiers = factory.createModifiersFromModifierFlags(prepareModifierFlagsForField(modifierFlags));
+      }
+      if (canHaveDecorators(declaration)) {
+        fieldModifiers = concatenate(getDecorators(declaration), fieldModifiers);
+      }
     }
-    if (type.flags & 128 /* StringLiteral */) {
-      return factory.createStringLiteral(
-        type.value,
-        /* isSingleQuote */
-        quotePreference === 0 /* Single */
-      );
+    updateFieldDeclaration(changeTracker, file, declaration, type, fieldName, fieldModifiers);
+    const getAccessor = generateGetAccessor(fieldName, accessorName, type, accessorModifiers, isStatic2, container);
+    suppressLeadingAndTrailingTrivia(getAccessor);
+    insertAccessor(changeTracker, file, getAccessor, declaration, container);
+    if (isReadonly) {
+      const constructor = getFirstConstructorWithBody(container);
+      if (constructor) {
+        updateReadonlyPropertyInitializerStatementConstructor(changeTracker, file, constructor, fieldName.text, originalName);
+      }
+    } else {
+      const setAccessor = generateSetAccessor(fieldName, accessorName, type, accessorModifiers, isStatic2, container);
+      suppressLeadingAndTrailingTrivia(setAccessor);
+      insertAccessor(changeTracker, file, setAccessor, declaration, container);
     }
-    if (type.flags & 512 /* BooleanLiteral */) {
-      return type === checker.getFalseType() || type === checker.getFalseType(
-        /*fresh*/
-        true
-      ) ? factory.createFalse() : factory.createTrue();
+    return changeTracker.getChanges();
+  }
+  function isConvertibleName(name) {
+    return isIdentifier(name) || isStringLiteral(name);
+  }
+  function isAcceptedDeclaration(node) {
+    return isParameterPropertyDeclaration(node, node.parent) || isPropertyDeclaration(node) || isPropertyAssignment(node);
+  }
+  function createPropertyName(name, originalName) {
+    return isIdentifier(originalName) ? factory.createIdentifier(name) : factory.createStringLiteral(name);
+  }
+  function createAccessorAccessExpression(fieldName, isStatic2, container) {
+    const leftHead = isStatic2 ? container.name : factory.createThis();
+    return isIdentifier(fieldName) ? factory.createPropertyAccessExpression(leftHead, fieldName) : factory.createElementAccessExpression(leftHead, factory.createStringLiteralFromNode(fieldName));
+  }
+  function prepareModifierFlagsForAccessor(modifierFlags) {
+    modifierFlags &= ~8 /* Readonly */;
+    modifierFlags &= ~2 /* Private */;
+    if (!(modifierFlags & 4 /* Protected */)) {
+      modifierFlags |= 1 /* Public */;
     }
-    if (type.flags & 65536 /* Null */) {
-      return factory.createNull();
+    return modifierFlags;
+  }
+  function prepareModifierFlagsForField(modifierFlags) {
+    modifierFlags &= ~1 /* Public */;
+    modifierFlags &= ~4 /* Protected */;
+    modifierFlags |= 2 /* Private */;
+    return modifierFlags;
+  }
+  function getAccessorConvertiblePropertyAtPosition(file, program, start, end, considerEmptySpans = true) {
+    const node = getTokenAtPosition(file, start);
+    const cursorRequest = start === end && considerEmptySpans;
+    const declaration = findAncestor(node.parent, isAcceptedDeclaration);
+    const meaning = 7 /* AccessibilityModifier */ | 256 /* Static */ | 8 /* Readonly */;
+    if (!declaration || !(nodeOverlapsWithStartEnd(declaration.name, file, start, end) || cursorRequest)) {
+      return {
+        error: getLocaleSpecificMessage(Diagnostics.Could_not_find_property_for_which_to_generate_accessor)
+      };
     }
-    if (type.flags & 1048576 /* Union */) {
-      const expression = firstDefined(type.types, (t) => tryGetValueFromType(context, checker, importAdder, quotePreference, t, enclosingDeclaration));
-      return expression ?? createUndefined();
+    if (!isConvertibleName(declaration.name)) {
+      return {
+        error: getLocaleSpecificMessage(Diagnostics.Name_is_not_valid)
+      };
     }
-    if (checker.isArrayLikeType(type)) {
-      return factory.createArrayLiteralExpression();
+    if ((getEffectiveModifierFlags(declaration) & 98303 /* Modifier */ | meaning) !== meaning) {
+      return {
+        error: getLocaleSpecificMessage(Diagnostics.Can_only_convert_property_with_modifier)
+      };
     }
-    if (isObjectLiteralType(type)) {
-      const props = map(checker.getPropertiesOfType(type), (prop) => {
-        const initializer = tryGetValueFromType(context, checker, importAdder, quotePreference, checker.getTypeOfSymbol(prop), enclosingDeclaration);
-        return factory.createPropertyAssignment(prop.name, initializer);
-      });
-      return factory.createObjectLiteralExpression(
-        props,
+    const name = declaration.name.text;
+    const startWithUnderscore = startsWithUnderscore(name);
+    const fieldName = createPropertyName(startWithUnderscore ? name : getUniqueName(`_${name}`, file), declaration.name);
+    const accessorName = createPropertyName(startWithUnderscore ? getUniqueName(name.substring(1), file) : name, declaration.name);
+    return {
+      isStatic: hasStaticModifier(declaration),
+      isReadonly: hasEffectiveReadonlyModifier(declaration),
+      type: getDeclarationType(declaration, program),
+      container: declaration.kind === 169 /* Parameter */ ? declaration.parent.parent : declaration.parent,
+      originalName: declaration.name.text,
+      declaration,
+      fieldName,
+      accessorName,
+      renameAccessor: startWithUnderscore
+    };
+  }
+  function generateGetAccessor(fieldName, accessorName, type, modifiers, isStatic2, container) {
+    return factory.createGetAccessorDeclaration(
+      modifiers,
+      accessorName,
+      [],
+      type,
+      factory.createBlock(
+        [
+          factory.createReturnStatement(
+            createAccessorAccessExpression(fieldName, isStatic2, container)
+          )
+        ],
         /*multiLine*/
         true
-      );
-    }
-    if (getObjectFlags(type) & 16 /* Anonymous */) {
-      const decl = find(type.symbol.declarations || emptyArray, or(isFunctionTypeNode, isMethodSignature, isMethodDeclaration));
-      if (decl === void 0)
-        return createUndefined();
-      const signature = checker.getSignaturesOfType(type, 0 /* Call */);
-      if (signature === void 0)
-        return createUndefined();
-      const func = createSignatureDeclarationFromSignature(
-        217 /* FunctionExpression */,
-        context,
-        quotePreference,
-        signature[0],
-        createStubbedBody(Diagnostics.Function_not_implemented.message, quotePreference),
-        /*name*/
-        void 0,
+      )
+    );
+  }
+  function generateSetAccessor(fieldName, accessorName, type, modifiers, isStatic2, container) {
+    return factory.createSetAccessorDeclaration(
+      modifiers,
+      accessorName,
+      [factory.createParameterDeclaration(
         /*modifiers*/
         void 0,
-        /*optional*/
+        /*dotDotDotToken*/
         void 0,
-        /*enclosingDeclaration*/
-        enclosingDeclaration,
-        importAdder
-      );
-      return func ?? createUndefined();
-    }
-    if (getObjectFlags(type) & 1 /* Class */) {
-      const classDeclaration = getClassLikeDeclarationOfSymbol(type.symbol);
-      if (classDeclaration === void 0 || hasAbstractModifier(classDeclaration))
-        return createUndefined();
-      const constructorDeclaration = getFirstConstructorWithBody(classDeclaration);
-      if (constructorDeclaration && length(constructorDeclaration.parameters))
-        return createUndefined();
-      return factory.createNewExpression(
-        factory.createIdentifier(type.symbol.name),
-        /*typeArguments*/
+        factory.createIdentifier("value"),
+        /*questionToken*/
         void 0,
-        /*argumentsArray*/
-        void 0
-      );
+        type
+      )],
+      factory.createBlock(
+        [
+          factory.createExpressionStatement(
+            factory.createAssignment(
+              createAccessorAccessExpression(fieldName, isStatic2, container),
+              factory.createIdentifier("value")
+            )
+          )
+        ],
+        /*multiLine*/
+        true
+      )
+    );
+  }
+  function updatePropertyDeclaration(changeTracker, file, declaration, type, fieldName, modifiers) {
+    const property = factory.updatePropertyDeclaration(
+      declaration,
+      modifiers,
+      fieldName,
+      declaration.questionToken || declaration.exclamationToken,
+      type,
+      declaration.initializer
+    );
+    changeTracker.replaceNode(file, declaration, property);
+  }
+  function updatePropertyAssignmentDeclaration(changeTracker, file, declaration, fieldName) {
+    let assignment = factory.updatePropertyAssignment(declaration, fieldName, declaration.initializer);
+    if (assignment.modifiers || assignment.questionToken || assignment.exclamationToken) {
+      if (assignment === declaration)
+        assignment = factory.cloneNode(assignment);
+      assignment.modifiers = void 0;
+      assignment.questionToken = void 0;
+      assignment.exclamationToken = void 0;
     }
-    return createUndefined();
+    changeTracker.replacePropertyAssignment(file, declaration, assignment);
   }
-  function createUndefined() {
-    return factory.createIdentifier("undefined");
+  function updateFieldDeclaration(changeTracker, file, declaration, type, fieldName, modifiers) {
+    if (isPropertyDeclaration(declaration)) {
+      updatePropertyDeclaration(changeTracker, file, declaration, type, fieldName, modifiers);
+    } else if (isPropertyAssignment(declaration)) {
+      updatePropertyAssignmentDeclaration(changeTracker, file, declaration, fieldName);
+    } else {
+      changeTracker.replaceNode(file, declaration, factory.updateParameterDeclaration(declaration, modifiers, declaration.dotDotDotToken, cast(fieldName, isIdentifier), declaration.questionToken, declaration.type, declaration.initializer));
+    }
   }
-  function isObjectLiteralType(type) {
-    return type.flags & 524288 /* Object */ && (getObjectFlags(type) & 128 /* ObjectLiteral */ || type.symbol && tryCast(singleOrUndefined(type.symbol.declarations), isTypeLiteralNode));
+  function insertAccessor(changeTracker, file, accessor, declaration, container) {
+    isParameterPropertyDeclaration(declaration, declaration.parent) ? changeTracker.insertMemberAtStart(file, container, accessor) : isPropertyAssignment(declaration) ? changeTracker.insertNodeAfterComma(file, declaration, accessor) : changeTracker.insertNodeAfter(file, declaration, accessor);
   }
-  function getUnmatchedAttributes(checker, target, source) {
-    const attrsType = checker.getContextualType(source.attributes);
-    if (attrsType === void 0)
-      return emptyArray;
-    const targetProps = attrsType.getProperties();
-    if (!length(targetProps))
-      return emptyArray;
-    const seenNames = /* @__PURE__ */ new Set();
-    for (const sourceProp of source.attributes.properties) {
-      if (isJsxAttribute(sourceProp)) {
-        seenNames.add(getEscapedTextOfJsxAttributeName(sourceProp.name));
+  function updateReadonlyPropertyInitializerStatementConstructor(changeTracker, file, constructor, fieldName, originalName) {
+    if (!constructor.body)
+      return;
+    constructor.body.forEachChild(function recur(node) {
+      if (isElementAccessExpression(node) && node.expression.kind === 110 /* ThisKeyword */ && isStringLiteral(node.argumentExpression) && node.argumentExpression.text === originalName && isWriteAccess(node)) {
+        changeTracker.replaceNode(file, node.argumentExpression, factory.createStringLiteral(fieldName));
       }
-      if (isJsxSpreadAttribute(sourceProp)) {
-        const type = checker.getTypeAtLocation(sourceProp.expression);
-        for (const prop of type.getProperties()) {
-          seenNames.add(prop.escapedName);
-        }
+      if (isPropertyAccessExpression(node) && node.expression.kind === 110 /* ThisKeyword */ && node.name.text === originalName && isWriteAccess(node)) {
+        changeTracker.replaceNode(file, node.name, factory.createIdentifier(fieldName));
       }
-    }
-    return filter(targetProps, (targetProp) => isIdentifierText(targetProp.name, target, 1 /* JSX */) && !(targetProp.flags & 16777216 /* Optional */ || getCheckFlags(targetProp) & 48 /* Partial */ || seenNames.has(targetProp.escapedName)));
-  }
-  function tryGetContainingMethodDeclaration(node, callExpression) {
-    if (isTypeLiteralNode(node)) {
-      return void 0;
-    }
-    const declaration = findAncestor(callExpression, (n) => isMethodDeclaration(n) || isConstructorDeclaration(n));
-    return declaration && declaration.parent === node ? declaration : void 0;
+      if (!isFunctionLike(node) && !isClassLike(node)) {
+        node.forEachChild(recur);
+      }
+    });
   }
-  function createPropertyNameFromSymbol(symbol, target, quotePreference, checker) {
-    if (isTransientSymbol(symbol)) {
-      const prop = checker.symbolToNode(
-        symbol,
-        111551 /* Value */,
-        /*enclosingDeclaration*/
-        void 0,
-        1073741824 /* WriteComputedProps */
-      );
-      if (prop && isComputedPropertyName(prop))
-        return prop;
+  function getDeclarationType(declaration, program) {
+    const typeNode = getTypeAnnotationNode(declaration);
+    if (isPropertyDeclaration(declaration) && typeNode && declaration.questionToken) {
+      const typeChecker = program.getTypeChecker();
+      const type = typeChecker.getTypeFromTypeNode(typeNode);
+      if (!typeChecker.isTypeAssignableTo(typeChecker.getUndefinedType(), type)) {
+        const types = isUnionTypeNode(typeNode) ? typeNode.types : [typeNode];
+        return factory.createUnionTypeNode([...types, factory.createKeywordTypeNode(157 /* UndefinedKeyword */)]);
+      }
     }
-    return createPropertyNameNodeForIdentifierOrLiteral(symbol.name, target, quotePreference === 0 /* Single */);
+    return typeNode;
   }
-  function findScope(node) {
-    if (findAncestor(node, isJsxExpression)) {
-      const returnStatement = findAncestor(node.parent, isReturnStatement);
-      if (returnStatement)
-        return returnStatement;
+  function getAllSupers(decl, checker) {
+    const res = [];
+    while (decl) {
+      const superElement = getClassExtendsHeritageElement(decl);
+      const superSymbol = superElement && checker.getSymbolAtLocation(superElement.expression);
+      if (!superSymbol)
+        break;
+      const symbol = superSymbol.flags & 2097152 /* Alias */ ? checker.getAliasedSymbol(superSymbol) : superSymbol;
+      const superDecl = symbol.declarations && find(symbol.declarations, isClassLike);
+      if (!superDecl)
+        break;
+      res.push(superDecl);
+      decl = superDecl;
     }
-    return getSourceFileOfNode(node);
+    return res;
   }
-  var fixMissingMember, fixMissingProperties, fixMissingAttributes, fixMissingFunctionDeclaration, errorCodes27;
-  var init_fixAddMissingMember = __esm({
-    "src/services/codefixes/fixAddMissingMember.ts"() {
+  var init_generateAccessors = __esm({
+    "src/services/codefixes/generateAccessors.ts"() {
       "use strict";
       init_ts4();
-      init_ts_codefix();
-      fixMissingMember = "fixMissingMember";
-      fixMissingProperties = "fixMissingProperties";
-      fixMissingAttributes = "fixMissingAttributes";
-      fixMissingFunctionDeclaration = "fixMissingFunctionDeclaration";
-      errorCodes27 = [
-        Diagnostics.Property_0_does_not_exist_on_type_1.code,
-        Diagnostics.Property_0_does_not_exist_on_type_1_Did_you_mean_2.code,
-        Diagnostics.Property_0_is_missing_in_type_1_but_required_in_type_2.code,
-        Diagnostics.Type_0_is_missing_the_following_properties_from_type_1_Colon_2.code,
-        Diagnostics.Type_0_is_missing_the_following_properties_from_type_1_Colon_2_and_3_more.code,
-        Diagnostics.Argument_of_type_0_is_not_assignable_to_parameter_of_type_1.code,
-        Diagnostics.Cannot_find_name_0.code
-      ];
-      registerCodeFix({
-        errorCodes: errorCodes27,
-        getCodeActions(context) {
-          const typeChecker = context.program.getTypeChecker();
-          const info = getInfo10(context.sourceFile, context.span.start, context.errorCode, typeChecker, context.program);
-          if (!info) {
-            return void 0;
-          }
-          if (info.kind === 3 /* ObjectLiteral */) {
-            const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => addObjectLiteralProperties(t, context, info));
-            return [createCodeFixAction(fixMissingProperties, changes, Diagnostics.Add_missing_properties, fixMissingProperties, Diagnostics.Add_all_missing_properties)];
-          }
-          if (info.kind === 4 /* JsxAttributes */) {
-            const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => addJsxAttributes(t, context, info));
-            return [createCodeFixAction(fixMissingAttributes, changes, Diagnostics.Add_missing_attributes, fixMissingAttributes, Diagnostics.Add_all_missing_attributes)];
-          }
-          if (info.kind === 2 /* Function */ || info.kind === 5 /* Signature */) {
-            const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => addFunctionDeclaration(t, context, info));
-            return [createCodeFixAction(fixMissingFunctionDeclaration, changes, [Diagnostics.Add_missing_function_declaration_0, info.token.text], fixMissingFunctionDeclaration, Diagnostics.Add_all_missing_function_declarations)];
-          }
-          if (info.kind === 1 /* Enum */) {
-            const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => addEnumMemberDeclaration(t, context.program.getTypeChecker(), info));
-            return [createCodeFixAction(fixMissingMember, changes, [Diagnostics.Add_missing_enum_member_0, info.token.text], fixMissingMember, Diagnostics.Add_all_missing_members)];
-          }
-          return concatenate(getActionsForMissingMethodDeclaration(context, info), getActionsForMissingMemberDeclaration(context, info));
-        },
-        fixIds: [fixMissingMember, fixMissingFunctionDeclaration, fixMissingProperties, fixMissingAttributes],
-        getAllCodeActions: (context) => {
-          const { program, fixId: fixId52 } = context;
-          const checker = program.getTypeChecker();
-          const seen = /* @__PURE__ */ new Map();
-          const typeDeclToMembers = /* @__PURE__ */ new Map();
-          return createCombinedCodeActions(ts_textChanges_exports.ChangeTracker.with(context, (changes) => {
-            eachDiagnostic(context, errorCodes27, (diag2) => {
-              const info = getInfo10(diag2.file, diag2.start, diag2.code, checker, context.program);
-              if (!info || !addToSeen(seen, getNodeId(info.parentDeclaration) + "#" + info.token.text)) {
-                return;
-              }
-              if (fixId52 === fixMissingFunctionDeclaration && (info.kind === 2 /* Function */ || info.kind === 5 /* Signature */)) {
-                addFunctionDeclaration(changes, context, info);
-              } else if (fixId52 === fixMissingProperties && info.kind === 3 /* ObjectLiteral */) {
-                addObjectLiteralProperties(changes, context, info);
-              } else if (fixId52 === fixMissingAttributes && info.kind === 4 /* JsxAttributes */) {
-                addJsxAttributes(changes, context, info);
-              } else {
-                if (info.kind === 1 /* Enum */) {
-                  addEnumMemberDeclaration(changes, checker, info);
-                }
-                if (info.kind === 0 /* TypeLikeDeclaration */) {
-                  const { parentDeclaration, token } = info;
-                  const infos = getOrUpdate(typeDeclToMembers, parentDeclaration, () => []);
-                  if (!infos.some((i) => i.token.text === token.text)) {
-                    infos.push(info);
-                  }
-                }
-              }
-            });
-            typeDeclToMembers.forEach((infos, declaration) => {
-              const supers = isTypeLiteralNode(declaration) ? void 0 : getAllSupers(declaration, checker);
-              for (const info of infos) {
-                if (supers == null ? void 0 : supers.some((superClassOrInterface) => {
-                  const superInfos = typeDeclToMembers.get(superClassOrInterface);
-                  return !!superInfos && superInfos.some(({ token: token2 }) => token2.text === info.token.text);
-                }))
-                  continue;
-                const { parentDeclaration, declSourceFile, modifierFlags, token, call, isJSFile } = info;
-                if (call && !isPrivateIdentifier(token)) {
-                  addMethodDeclaration(context, changes, call, token, modifierFlags & 32 /* Static */, parentDeclaration, declSourceFile);
-                } else {
-                  if (isJSFile && !isInterfaceDeclaration(parentDeclaration) && !isTypeLiteralNode(parentDeclaration)) {
-                    addMissingMemberInJs(changes, declSourceFile, parentDeclaration, token, !!(modifierFlags & 32 /* Static */));
-                  } else {
-                    const typeNode = getTypeNode2(checker, parentDeclaration, token);
-                    addPropertyDeclaration(changes, declSourceFile, parentDeclaration, token.text, typeNode, modifierFlags & 32 /* Static */);
-                  }
-                }
-              }
-            });
-          }));
-        }
-      });
     }
   });
 
-  // src/services/codefixes/fixAddMissingNewOperator.ts
-  function addMissingNewOperator(changes, sourceFile, span) {
-    const call = cast(findAncestorMatchingSpan2(sourceFile, span), isCallExpression);
-    const newExpression = factory.createNewExpression(call.expression, call.typeArguments, call.arguments);
-    changes.replaceNode(sourceFile, call, newExpression);
+  // src/services/codefixes/fixInvalidImportSyntax.ts
+  function getCodeFixesForImportDeclaration(context, node) {
+    const sourceFile = getSourceFileOfNode(node);
+    const namespace = getNamespaceDeclarationNode(node);
+    const opts = context.program.getCompilerOptions();
+    const variations = [];
+    variations.push(createAction(context, sourceFile, node, makeImport(
+      namespace.name,
+      /*namedImports*/
+      void 0,
+      node.moduleSpecifier,
+      getQuotePreference(sourceFile, context.preferences)
+    )));
+    if (getEmitModuleKind(opts) === 1 /* CommonJS */) {
+      variations.push(createAction(
+        context,
+        sourceFile,
+        node,
+        factory.createImportEqualsDeclaration(
+          /*modifiers*/
+          void 0,
+          /*isTypeOnly*/
+          false,
+          namespace.name,
+          factory.createExternalModuleReference(node.moduleSpecifier)
+        )
+      ));
+    }
+    return variations;
   }
-  function findAncestorMatchingSpan2(sourceFile, span) {
-    let token = getTokenAtPosition(sourceFile, span.start);
-    const end = textSpanEnd(span);
-    while (token.end < end) {
-      token = token.parent;
+  function createAction(context, sourceFile, node, replacement) {
+    const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => t.replaceNode(sourceFile, node, replacement));
+    return createCodeFixActionWithoutFixAll(fixName5, changes, [Diagnostics.Replace_import_with_0, changes[0].textChanges[0].newText]);
+  }
+  function getActionsForUsageOfInvalidImport(context) {
+    const sourceFile = context.sourceFile;
+    const targetKind = Diagnostics.This_expression_is_not_callable.code === context.errorCode ? 213 /* CallExpression */ : 214 /* NewExpression */;
+    const node = findAncestor(getTokenAtPosition(sourceFile, context.span.start), (a) => a.kind === targetKind);
+    if (!node) {
+      return [];
     }
-    return token;
+    const expr = node.expression;
+    return getImportCodeFixesForExpression(context, expr);
   }
-  var fixId24, errorCodes28;
-  var init_fixAddMissingNewOperator = __esm({
-    "src/services/codefixes/fixAddMissingNewOperator.ts"() {
+  function getActionsForInvalidImportLocation(context) {
+    const sourceFile = context.sourceFile;
+    const node = findAncestor(getTokenAtPosition(sourceFile, context.span.start), (a) => a.getStart() === context.span.start && a.getEnd() === context.span.start + context.span.length);
+    if (!node) {
+      return [];
+    }
+    return getImportCodeFixesForExpression(context, node);
+  }
+  function getImportCodeFixesForExpression(context, expr) {
+    const type = context.program.getTypeChecker().getTypeAtLocation(expr);
+    if (!(type.symbol && isTransientSymbol(type.symbol) && type.symbol.links.originatingImport)) {
+      return [];
+    }
+    const fixes = [];
+    const relatedImport = type.symbol.links.originatingImport;
+    if (!isImportCall(relatedImport)) {
+      addRange(fixes, getCodeFixesForImportDeclaration(context, relatedImport));
+    }
+    if (isExpression(expr) && !(isNamedDeclaration(expr.parent) && expr.parent.name === expr)) {
+      const sourceFile = context.sourceFile;
+      const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => t.replaceNode(sourceFile, expr, factory.createPropertyAccessExpression(expr, "default"), {}));
+      fixes.push(createCodeFixActionWithoutFixAll(fixName5, changes, Diagnostics.Use_synthetic_default_member));
+    }
+    return fixes;
+  }
+  var fixName5;
+  var init_fixInvalidImportSyntax = __esm({
+    "src/services/codefixes/fixInvalidImportSyntax.ts"() {
       "use strict";
       init_ts4();
       init_ts_codefix();
-      fixId24 = "addMissingNewOperator";
-      errorCodes28 = [Diagnostics.Value_of_type_0_is_not_callable_Did_you_mean_to_include_new.code];
+      fixName5 = "invalidImportSyntax";
       registerCodeFix({
-        errorCodes: errorCodes28,
-        getCodeActions(context) {
-          const { sourceFile, span } = context;
-          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => addMissingNewOperator(t, sourceFile, span));
-          return [createCodeFixAction(fixId24, changes, Diagnostics.Add_missing_new_operator_to_call, fixId24, Diagnostics.Add_missing_new_operator_to_all_calls)];
-        },
-        fixIds: [fixId24],
-        getAllCodeActions: (context) => codeFixAll(context, errorCodes28, (changes, diag2) => addMissingNewOperator(changes, context.sourceFile, diag2))
+        errorCodes: [
+          Diagnostics.This_expression_is_not_callable.code,
+          Diagnostics.This_expression_is_not_constructable.code
+        ],
+        getCodeActions: getActionsForUsageOfInvalidImport
       });
+      registerCodeFix({
+        errorCodes: [
+          // The following error codes cover pretty much all assignability errors that could involve an expression
+          Diagnostics.Argument_of_type_0_is_not_assignable_to_parameter_of_type_1.code,
+          Diagnostics.Type_0_does_not_satisfy_the_constraint_1.code,
+          Diagnostics.Type_0_is_not_assignable_to_type_1.code,
+          Diagnostics.Type_0_is_not_assignable_to_type_1_Two_different_types_with_this_name_exist_but_they_are_unrelated.code,
+          Diagnostics.Type_predicate_0_is_not_assignable_to_1.code,
+          Diagnostics.Property_0_of_type_1_is_not_assignable_to_2_index_type_3.code,
+          Diagnostics._0_index_type_1_is_not_assignable_to_2_index_type_3.code,
+          Diagnostics.Property_0_in_type_1_is_not_assignable_to_the_same_property_in_base_type_2.code,
+          Diagnostics.Property_0_in_type_1_is_not_assignable_to_type_2.code,
+          Diagnostics.Property_0_of_JSX_spread_attribute_is_not_assignable_to_target_property.code,
+          Diagnostics.The_this_context_of_type_0_is_not_assignable_to_method_s_this_of_type_1.code
+        ],
+        getCodeActions: getActionsForInvalidImportLocation
+      });
+    }
+  });
+
+  // src/services/codefixes/fixStrictClassInitialization.ts
+  function getInfo16(sourceFile, pos) {
+    const token = getTokenAtPosition(sourceFile, pos);
+    if (isIdentifier(token) && isPropertyDeclaration(token.parent)) {
+      const type = getEffectiveTypeAnnotationNode(token.parent);
+      if (type) {
+        return { type, prop: token.parent, isJs: isInJSFile(token.parent) };
+      }
+    }
+    return void 0;
+  }
+  function getActionForAddMissingDefiniteAssignmentAssertion(context, info) {
+    if (info.isJs)
+      return void 0;
+    const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => addDefiniteAssignmentAssertion(t, context.sourceFile, info.prop));
+    return createCodeFixAction(fixName6, changes, [Diagnostics.Add_definite_assignment_assertion_to_property_0, info.prop.getText()], fixIdAddDefiniteAssignmentAssertions, Diagnostics.Add_definite_assignment_assertions_to_all_uninitialized_properties);
+  }
+  function addDefiniteAssignmentAssertion(changeTracker, propertyDeclarationSourceFile, propertyDeclaration) {
+    suppressLeadingAndTrailingTrivia(propertyDeclaration);
+    const property = factory.updatePropertyDeclaration(
+      propertyDeclaration,
+      propertyDeclaration.modifiers,
+      propertyDeclaration.name,
+      factory.createToken(54 /* ExclamationToken */),
+      propertyDeclaration.type,
+      propertyDeclaration.initializer
+    );
+    changeTracker.replaceNode(propertyDeclarationSourceFile, propertyDeclaration, property);
+  }
+  function getActionForAddMissingUndefinedType(context, info) {
+    const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => addUndefinedType(t, context.sourceFile, info));
+    return createCodeFixAction(fixName6, changes, [Diagnostics.Add_undefined_type_to_property_0, info.prop.name.getText()], fixIdAddUndefinedType, Diagnostics.Add_undefined_type_to_all_uninitialized_properties);
+  }
+  function addUndefinedType(changeTracker, sourceFile, info) {
+    const undefinedTypeNode = factory.createKeywordTypeNode(157 /* UndefinedKeyword */);
+    const types = isUnionTypeNode(info.type) ? info.type.types.concat(undefinedTypeNode) : [info.type, undefinedTypeNode];
+    const unionTypeNode = factory.createUnionTypeNode(types);
+    if (info.isJs) {
+      changeTracker.addJSDocTags(sourceFile, info.prop, [factory.createJSDocTypeTag(
+        /*tagName*/
+        void 0,
+        factory.createJSDocTypeExpression(unionTypeNode)
+      )]);
+    } else {
+      changeTracker.replaceNode(sourceFile, info.type, unionTypeNode);
     }
-  });
-
-  // src/services/codefixes/fixCannotFindModule.ts
-  function getInstallCommand(fileName, packageName) {
-    return { type: "install package", file: fileName, packageName };
   }
-  function tryGetImportedPackageName(sourceFile, pos) {
-    const moduleSpecifierText = tryCast(getTokenAtPosition(sourceFile, pos), isStringLiteral);
-    if (!moduleSpecifierText)
+  function getActionForAddMissingInitializer(context, info) {
+    if (info.isJs)
       return void 0;
-    const moduleName = moduleSpecifierText.text;
-    const { packageName } = parsePackageName(moduleName);
-    return isExternalModuleNameRelative(packageName) ? void 0 : packageName;
+    const checker = context.program.getTypeChecker();
+    const initializer = getInitializer(checker, info.prop);
+    if (!initializer)
+      return void 0;
+    const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => addInitializer(t, context.sourceFile, info.prop, initializer));
+    return createCodeFixAction(fixName6, changes, [Diagnostics.Add_initializer_to_property_0, info.prop.name.getText()], fixIdAddInitializer, Diagnostics.Add_initializers_to_all_uninitialized_properties);
   }
-  function getTypesPackageNameToInstall(packageName, host, diagCode) {
-    var _a;
-    return diagCode === errorCodeCannotFindModule ? ts_JsTyping_exports.nodeCoreModules.has(packageName) ? "@types/node" : void 0 : ((_a = host.isKnownTypesPackageName) == null ? void 0 : _a.call(host, packageName)) ? getTypesPackageName(packageName) : void 0;
+  function addInitializer(changeTracker, propertyDeclarationSourceFile, propertyDeclaration, initializer) {
+    suppressLeadingAndTrailingTrivia(propertyDeclaration);
+    const property = factory.updatePropertyDeclaration(
+      propertyDeclaration,
+      propertyDeclaration.modifiers,
+      propertyDeclaration.name,
+      propertyDeclaration.questionToken,
+      propertyDeclaration.type,
+      initializer
+    );
+    changeTracker.replaceNode(propertyDeclarationSourceFile, propertyDeclaration, property);
   }
-  var fixName2, fixIdInstallTypesPackage, errorCodeCannotFindModule, errorCodes29;
-  var init_fixCannotFindModule = __esm({
-    "src/services/codefixes/fixCannotFindModule.ts"() {
+  function getInitializer(checker, propertyDeclaration) {
+    return getDefaultValueFromType(checker, checker.getTypeFromTypeNode(propertyDeclaration.type));
+  }
+  function getDefaultValueFromType(checker, type) {
+    if (type.flags & 512 /* BooleanLiteral */) {
+      return type === checker.getFalseType() || type === checker.getFalseType(
+        /*fresh*/
+        true
+      ) ? factory.createFalse() : factory.createTrue();
+    } else if (type.isStringLiteral()) {
+      return factory.createStringLiteral(type.value);
+    } else if (type.isNumberLiteral()) {
+      return factory.createNumericLiteral(type.value);
+    } else if (type.flags & 2048 /* BigIntLiteral */) {
+      return factory.createBigIntLiteral(type.value);
+    } else if (type.isUnion()) {
+      return firstDefined(type.types, (t) => getDefaultValueFromType(checker, t));
+    } else if (type.isClass()) {
+      const classDeclaration = getClassLikeDeclarationOfSymbol(type.symbol);
+      if (!classDeclaration || hasSyntacticModifier(classDeclaration, 64 /* Abstract */))
+        return void 0;
+      const constructorDeclaration = getFirstConstructorWithBody(classDeclaration);
+      if (constructorDeclaration && constructorDeclaration.parameters.length)
+        return void 0;
+      return factory.createNewExpression(
+        factory.createIdentifier(type.symbol.name),
+        /*typeArguments*/
+        void 0,
+        /*argumentsArray*/
+        void 0
+      );
+    } else if (checker.isArrayLikeType(type)) {
+      return factory.createArrayLiteralExpression();
+    }
+    return void 0;
+  }
+  var fixName6, fixIdAddDefiniteAssignmentAssertions, fixIdAddUndefinedType, fixIdAddInitializer, errorCodes51;
+  var init_fixStrictClassInitialization = __esm({
+    "src/services/codefixes/fixStrictClassInitialization.ts"() {
       "use strict";
       init_ts4();
       init_ts_codefix();
-      fixName2 = "fixCannotFindModule";
-      fixIdInstallTypesPackage = "installTypesPackage";
-      errorCodeCannotFindModule = Diagnostics.Cannot_find_module_0_or_its_corresponding_type_declarations.code;
-      errorCodes29 = [
-        errorCodeCannotFindModule,
-        Diagnostics.Could_not_find_a_declaration_file_for_module_0_1_implicitly_has_an_any_type.code
-      ];
+      fixName6 = "strictClassInitialization";
+      fixIdAddDefiniteAssignmentAssertions = "addMissingPropertyDefiniteAssignmentAssertions";
+      fixIdAddUndefinedType = "addMissingPropertyUndefinedType";
+      fixIdAddInitializer = "addMissingPropertyInitializer";
+      errorCodes51 = [Diagnostics.Property_0_has_no_initializer_and_is_not_definitely_assigned_in_the_constructor.code];
       registerCodeFix({
-        errorCodes: errorCodes29,
-        getCodeActions: function getCodeActionsToFixNotFoundModule(context) {
-          const { host, sourceFile, span: { start } } = context;
-          const packageName = tryGetImportedPackageName(sourceFile, start);
-          if (packageName === void 0)
-            return void 0;
-          const typesPackageName = getTypesPackageNameToInstall(packageName, host, context.errorCode);
-          return typesPackageName === void 0 ? [] : [createCodeFixAction(
-            fixName2,
-            /*changes*/
-            [],
-            [Diagnostics.Install_0, typesPackageName],
-            fixIdInstallTypesPackage,
-            Diagnostics.Install_all_missing_types_packages,
-            getInstallCommand(sourceFile.fileName, typesPackageName)
-          )];
+        errorCodes: errorCodes51,
+        getCodeActions: function getCodeActionsForStrictClassInitializationErrors(context) {
+          const info = getInfo16(context.sourceFile, context.span.start);
+          if (!info)
+            return;
+          const result = [];
+          append(result, getActionForAddMissingUndefinedType(context, info));
+          append(result, getActionForAddMissingDefiniteAssignmentAssertion(context, info));
+          append(result, getActionForAddMissingInitializer(context, info));
+          return result;
         },
-        fixIds: [fixIdInstallTypesPackage],
+        fixIds: [fixIdAddDefiniteAssignmentAssertions, fixIdAddUndefinedType, fixIdAddInitializer],
         getAllCodeActions: (context) => {
-          return codeFixAll(context, errorCodes29, (_changes, diag2, commands) => {
-            const packageName = tryGetImportedPackageName(diag2.file, diag2.start);
-            if (packageName === void 0)
-              return void 0;
+          return codeFixAll(context, errorCodes51, (changes, diag2) => {
+            const info = getInfo16(diag2.file, diag2.start);
+            if (!info)
+              return;
             switch (context.fixId) {
-              case fixIdInstallTypesPackage: {
-                const pkg = getTypesPackageNameToInstall(packageName, context.host, diag2.code);
-                if (pkg) {
-                  commands.push(getInstallCommand(diag2.file.fileName, pkg));
-                }
+              case fixIdAddDefiniteAssignmentAssertions:
+                addDefiniteAssignmentAssertion(changes, diag2.file, info.prop);
+                break;
+              case fixIdAddUndefinedType:
+                addUndefinedType(changes, diag2.file, info);
+                break;
+              case fixIdAddInitializer:
+                const checker = context.program.getTypeChecker();
+                const initializer = getInitializer(checker, info.prop);
+                if (!initializer)
+                  return;
+                addInitializer(changes, diag2.file, info.prop, initializer);
                 break;
-              }
               default:
-                Debug.fail(`Bad fixId: ${context.fixId}`);
+                Debug.fail(JSON.stringify(context.fixId));
             }
           });
         }
@@ -249027,19711 +237746,30695 @@ ${newComment.split("\n").map((c) => ` * ${c}`).join("\n")}
     }
   });
 
-  // src/services/codefixes/fixClassDoesntImplementInheritedAbstractMember.ts
-  function getClass2(sourceFile, pos) {
-    const token = getTokenAtPosition(sourceFile, pos);
-    return cast(token.parent, isClassLike);
-  }
-  function addMissingMembers(classDeclaration, sourceFile, context, changeTracker, preferences) {
-    const extendsNode = getEffectiveBaseTypeNode(classDeclaration);
-    const checker = context.program.getTypeChecker();
-    const instantiatedExtendsType = checker.getTypeAtLocation(extendsNode);
-    const abstractAndNonPrivateExtendsSymbols = checker.getPropertiesOfType(instantiatedExtendsType).filter(symbolPointsToNonPrivateAndAbstractMember);
-    const importAdder = createImportAdder(sourceFile, context.program, preferences, context.host);
-    createMissingMemberNodes(classDeclaration, abstractAndNonPrivateExtendsSymbols, sourceFile, context, preferences, importAdder, (member) => changeTracker.insertMemberAtStart(sourceFile, classDeclaration, member));
-    importAdder.writeFixes(changeTracker);
-  }
-  function symbolPointsToNonPrivateAndAbstractMember(symbol) {
-    const flags = getSyntacticModifierFlags(first(symbol.getDeclarations()));
-    return !(flags & 8 /* Private */) && !!(flags & 256 /* Abstract */);
+  // src/services/codefixes/requireInTs.ts
+  function doChange34(changes, sourceFile, info) {
+    const { allowSyntheticDefaults, defaultImportName, namedImports, statement, required } = info;
+    changes.replaceNode(
+      sourceFile,
+      statement,
+      defaultImportName && !allowSyntheticDefaults ? factory.createImportEqualsDeclaration(
+        /*modifiers*/
+        void 0,
+        /*isTypeOnly*/
+        false,
+        defaultImportName,
+        factory.createExternalModuleReference(required)
+      ) : factory.createImportDeclaration(
+        /*modifiers*/
+        void 0,
+        factory.createImportClause(
+          /*isTypeOnly*/
+          false,
+          defaultImportName,
+          namedImports
+        ),
+        required,
+        /*attributes*/
+        void 0
+      )
+    );
   }
-  var errorCodes30, fixId25;
-  var init_fixClassDoesntImplementInheritedAbstractMember = __esm({
-    "src/services/codefixes/fixClassDoesntImplementInheritedAbstractMember.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_codefix();
-      errorCodes30 = [
-        Diagnostics.Non_abstract_class_0_does_not_implement_all_abstract_members_of_1.code
-      ];
-      fixId25 = "fixClassDoesntImplementInheritedAbstractMember";
-      registerCodeFix({
-        errorCodes: errorCodes30,
-        getCodeActions: function getCodeActionsToFixClassNotImplementingInheritedMembers(context) {
-          const { sourceFile, span } = context;
-          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => addMissingMembers(getClass2(sourceFile, span.start), sourceFile, context, t, context.preferences));
-          return changes.length === 0 ? void 0 : [createCodeFixAction(fixId25, changes, Diagnostics.Implement_inherited_abstract_class, fixId25, Diagnostics.Implement_all_inherited_abstract_classes)];
-        },
-        fixIds: [fixId25],
-        getAllCodeActions: function getAllCodeActionsToFixClassDoesntImplementInheritedAbstractMember(context) {
-          const seenClassDeclarations = /* @__PURE__ */ new Map();
-          return codeFixAll(context, errorCodes30, (changes, diag2) => {
-            const classDeclaration = getClass2(diag2.file, diag2.start);
-            if (addToSeen(seenClassDeclarations, getNodeId(classDeclaration))) {
-              addMissingMembers(classDeclaration, context.sourceFile, context, changes, context.preferences);
-            }
-          });
-        }
-      });
+  function getInfo17(sourceFile, program, pos) {
+    const { parent: parent2 } = getTokenAtPosition(sourceFile, pos);
+    if (!isRequireCall(
+      parent2,
+      /*requireStringLiteralLikeArgument*/
+      true
+    )) {
+      Debug.failBadSyntaxKind(parent2);
+    }
+    const decl = cast(parent2.parent, isVariableDeclaration);
+    const defaultImportName = tryCast(decl.name, isIdentifier);
+    const namedImports = isObjectBindingPattern(decl.name) ? tryCreateNamedImportsFromObjectBindingPattern(decl.name) : void 0;
+    if (defaultImportName || namedImports) {
+      return {
+        allowSyntheticDefaults: getAllowSyntheticDefaultImports(program.getCompilerOptions()),
+        defaultImportName,
+        namedImports,
+        statement: cast(decl.parent.parent, isVariableStatement),
+        required: first(parent2.arguments)
+      };
     }
-  });
-
-  // src/services/codefixes/fixClassSuperMustPrecedeThisAccess.ts
-  function doChange19(changes, sourceFile, constructor, superCall) {
-    changes.insertNodeAtConstructorStart(sourceFile, constructor, superCall);
-    changes.delete(sourceFile, superCall);
-  }
-  function getNodes(sourceFile, pos) {
-    const token = getTokenAtPosition(sourceFile, pos);
-    if (token.kind !== 110 /* ThisKeyword */)
-      return void 0;
-    const constructor = getContainingFunction(token);
-    const superCall = findSuperCall(constructor.body);
-    return superCall && !superCall.expression.arguments.some((arg) => isPropertyAccessExpression(arg) && arg.expression === token) ? { constructor, superCall } : void 0;
   }
-  function findSuperCall(n) {
-    return isExpressionStatement(n) && isSuperCall(n.expression) ? n : isFunctionLike(n) ? void 0 : forEachChild(n, findSuperCall);
+  function tryCreateNamedImportsFromObjectBindingPattern(node) {
+    const importSpecifiers = [];
+    for (const element of node.elements) {
+      if (!isIdentifier(element.name) || element.initializer) {
+        return void 0;
+      }
+      importSpecifiers.push(factory.createImportSpecifier(
+        /*isTypeOnly*/
+        false,
+        tryCast(element.propertyName, isIdentifier),
+        element.name
+      ));
+    }
+    if (importSpecifiers.length) {
+      return factory.createNamedImports(importSpecifiers);
+    }
   }
-  var fixId26, errorCodes31;
-  var init_fixClassSuperMustPrecedeThisAccess = __esm({
-    "src/services/codefixes/fixClassSuperMustPrecedeThisAccess.ts"() {
+  var fixId41, errorCodes52;
+  var init_requireInTs = __esm({
+    "src/services/codefixes/requireInTs.ts"() {
       "use strict";
       init_ts4();
       init_ts_codefix();
-      fixId26 = "classSuperMustPrecedeThisAccess";
-      errorCodes31 = [Diagnostics.super_must_be_called_before_accessing_this_in_the_constructor_of_a_derived_class.code];
+      fixId41 = "requireInTs";
+      errorCodes52 = [Diagnostics.require_call_may_be_converted_to_an_import.code];
       registerCodeFix({
-        errorCodes: errorCodes31,
+        errorCodes: errorCodes52,
         getCodeActions(context) {
-          const { sourceFile, span } = context;
-          const nodes = getNodes(sourceFile, span.start);
-          if (!nodes)
+          const info = getInfo17(context.sourceFile, context.program, context.span.start);
+          if (!info) {
             return void 0;
-          const { constructor, superCall } = nodes;
-          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange19(t, sourceFile, constructor, superCall));
-          return [createCodeFixAction(fixId26, changes, Diagnostics.Make_super_call_the_first_statement_in_the_constructor, fixId26, Diagnostics.Make_all_super_calls_the_first_statement_in_their_constructor)];
+          }
+          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange34(t, context.sourceFile, info));
+          return [createCodeFixAction(fixId41, changes, Diagnostics.Convert_require_to_import, fixId41, Diagnostics.Convert_all_require_to_import)];
         },
-        fixIds: [fixId26],
-        getAllCodeActions(context) {
-          const { sourceFile } = context;
-          const seenClasses = /* @__PURE__ */ new Map();
-          return codeFixAll(context, errorCodes31, (changes, diag2) => {
-            const nodes = getNodes(diag2.file, diag2.start);
-            if (!nodes)
-              return;
-            const { constructor, superCall } = nodes;
-            if (addToSeen(seenClasses, getNodeId(constructor.parent))) {
-              doChange19(changes, sourceFile, constructor, superCall);
-            }
-          });
-        }
+        fixIds: [fixId41],
+        getAllCodeActions: (context) => codeFixAll(context, errorCodes52, (changes, diag2) => {
+          const info = getInfo17(diag2.file, context.program, diag2.start);
+          if (info) {
+            doChange34(changes, context.sourceFile, info);
+          }
+        })
       });
     }
   });
 
-  // src/services/codefixes/fixConstructorForDerivedNeedSuperCall.ts
-  function getNode(sourceFile, pos) {
-    const token = getTokenAtPosition(sourceFile, pos);
-    Debug.assert(isConstructorDeclaration(token.parent), "token should be at the constructor declaration");
-    return token.parent;
+  // src/services/codefixes/useDefaultImport.ts
+  function getInfo18(sourceFile, pos) {
+    const name = getTokenAtPosition(sourceFile, pos);
+    if (!isIdentifier(name))
+      return void 0;
+    const { parent: parent2 } = name;
+    if (isImportEqualsDeclaration(parent2) && isExternalModuleReference(parent2.moduleReference)) {
+      return { importNode: parent2, name, moduleSpecifier: parent2.moduleReference.expression };
+    } else if (isNamespaceImport(parent2)) {
+      const importNode = parent2.parent.parent;
+      return { importNode, name, moduleSpecifier: importNode.moduleSpecifier };
+    }
   }
-  function doChange20(changes, sourceFile, ctr) {
-    const superCall = factory.createExpressionStatement(factory.createCallExpression(
-      factory.createSuper(),
-      /*typeArguments*/
+  function doChange35(changes, sourceFile, info, preferences) {
+    changes.replaceNode(sourceFile, info.importNode, makeImport(
+      info.name,
+      /*namedImports*/
       void 0,
-      /*argumentsArray*/
-      emptyArray
+      info.moduleSpecifier,
+      getQuotePreference(sourceFile, preferences)
     ));
-    changes.insertNodeAtConstructorStart(sourceFile, ctr, superCall);
   }
-  var fixId27, errorCodes32;
-  var init_fixConstructorForDerivedNeedSuperCall = __esm({
-    "src/services/codefixes/fixConstructorForDerivedNeedSuperCall.ts"() {
+  var fixId42, errorCodes53;
+  var init_useDefaultImport = __esm({
+    "src/services/codefixes/useDefaultImport.ts"() {
       "use strict";
       init_ts4();
       init_ts_codefix();
-      fixId27 = "constructorForDerivedNeedSuperCall";
-      errorCodes32 = [Diagnostics.Constructors_for_derived_classes_must_contain_a_super_call.code];
+      fixId42 = "useDefaultImport";
+      errorCodes53 = [Diagnostics.Import_may_be_converted_to_a_default_import.code];
       registerCodeFix({
-        errorCodes: errorCodes32,
+        errorCodes: errorCodes53,
         getCodeActions(context) {
-          const { sourceFile, span } = context;
-          const ctr = getNode(sourceFile, span.start);
-          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange20(t, sourceFile, ctr));
-          return [createCodeFixAction(fixId27, changes, Diagnostics.Add_missing_super_call, fixId27, Diagnostics.Add_all_missing_super_calls)];
-        },
-        fixIds: [fixId27],
-        getAllCodeActions: (context) => codeFixAll(context, errorCodes32, (changes, diag2) => doChange20(changes, context.sourceFile, getNode(diag2.file, diag2.start)))
-      });
-    }
-  });
-
-  // src/services/codefixes/fixEnableJsxFlag.ts
-  function doChange21(changeTracker, configFile) {
-    setJsonCompilerOptionValue(changeTracker, configFile, "jsx", factory.createStringLiteral("react"));
-  }
-  var fixID, errorCodes33;
-  var init_fixEnableJsxFlag = __esm({
-    "src/services/codefixes/fixEnableJsxFlag.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_codefix();
-      fixID = "fixEnableJsxFlag";
-      errorCodes33 = [Diagnostics.Cannot_use_JSX_unless_the_jsx_flag_is_provided.code];
-      registerCodeFix({
-        errorCodes: errorCodes33,
-        getCodeActions: function getCodeActionsToFixEnableJsxFlag(context) {
-          const { configFile } = context.program.getCompilerOptions();
-          if (configFile === void 0) {
+          const { sourceFile, span: { start } } = context;
+          const info = getInfo18(sourceFile, start);
+          if (!info)
             return void 0;
-          }
-          const changes = ts_textChanges_exports.ChangeTracker.with(
-            context,
-            (changeTracker) => doChange21(changeTracker, configFile)
-          );
-          return [
-            createCodeFixActionWithoutFixAll(fixID, changes, Diagnostics.Enable_the_jsx_flag_in_your_configuration_file)
-          ];
+          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange35(t, sourceFile, info, context.preferences));
+          return [createCodeFixAction(fixId42, changes, Diagnostics.Convert_to_default_import, fixId42, Diagnostics.Convert_all_to_default_imports)];
         },
-        fixIds: [fixID],
-        getAllCodeActions: (context) => codeFixAll(context, errorCodes33, (changes) => {
-          const { configFile } = context.program.getCompilerOptions();
-          if (configFile === void 0) {
-            return void 0;
-          }
-          doChange21(changes, configFile);
+        fixIds: [fixId42],
+        getAllCodeActions: (context) => codeFixAll(context, errorCodes53, (changes, diag2) => {
+          const info = getInfo18(diag2.file, diag2.start);
+          if (info)
+            doChange35(changes, diag2.file, info, context.preferences);
         })
       });
     }
   });
 
-  // src/services/codefixes/fixNaNEquality.ts
-  function getInfo11(program, sourceFile, span) {
-    const diag2 = find(program.getSemanticDiagnostics(sourceFile), (diag3) => diag3.start === span.start && diag3.length === span.length);
-    if (diag2 === void 0 || diag2.relatedInformation === void 0)
-      return;
-    const related = find(diag2.relatedInformation, (related2) => related2.code === Diagnostics.Did_you_mean_0.code);
-    if (related === void 0 || related.file === void 0 || related.start === void 0 || related.length === void 0)
-      return;
-    const token = findAncestorMatchingSpan(related.file, createTextSpan(related.start, related.length));
-    if (token === void 0)
+  // src/services/codefixes/useBigintLiteral.ts
+  function makeChange9(changeTracker, sourceFile, span) {
+    const numericLiteral = tryCast(getTokenAtPosition(sourceFile, span.start), isNumericLiteral);
+    if (!numericLiteral) {
       return;
-    if (isExpression(token) && isBinaryExpression(token.parent)) {
-      return { suggestion: getSuggestion(related.messageText), expression: token.parent, arg: token };
     }
-    return void 0;
-  }
-  function doChange22(changes, sourceFile, arg, expression) {
-    const callExpression = factory.createCallExpression(
-      factory.createPropertyAccessExpression(factory.createIdentifier("Number"), factory.createIdentifier("isNaN")),
-      /*typeArguments*/
-      void 0,
-      [arg]
-    );
-    const operator = expression.operatorToken.kind;
-    changes.replaceNode(
-      sourceFile,
-      expression,
-      operator === 38 /* ExclamationEqualsEqualsToken */ || operator === 36 /* ExclamationEqualsToken */ ? factory.createPrefixUnaryExpression(54 /* ExclamationToken */, callExpression) : callExpression
-    );
-  }
-  function getSuggestion(messageText) {
-    const [_, suggestion] = flattenDiagnosticMessageText(messageText, "\n", 0).match(/\'(.*)\'/) || [];
-    return suggestion;
+    const newText = numericLiteral.getText(sourceFile) + "n";
+    changeTracker.replaceNode(sourceFile, numericLiteral, factory.createBigIntLiteral(newText));
   }
-  var fixId28, errorCodes34;
-  var init_fixNaNEquality = __esm({
-    "src/services/codefixes/fixNaNEquality.ts"() {
+  var fixId43, errorCodes54;
+  var init_useBigintLiteral = __esm({
+    "src/services/codefixes/useBigintLiteral.ts"() {
       "use strict";
       init_ts4();
       init_ts_codefix();
-      fixId28 = "fixNaNEquality";
-      errorCodes34 = [
-        Diagnostics.This_condition_will_always_return_0.code
+      fixId43 = "useBigintLiteral";
+      errorCodes54 = [
+        Diagnostics.Numeric_literals_with_absolute_values_equal_to_2_53_or_greater_are_too_large_to_be_represented_accurately_as_integers.code
       ];
       registerCodeFix({
-        errorCodes: errorCodes34,
-        getCodeActions(context) {
-          const { sourceFile, span, program } = context;
-          const info = getInfo11(program, sourceFile, span);
-          if (info === void 0)
-            return;
-          const { suggestion, expression, arg } = info;
-          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange22(t, sourceFile, arg, expression));
-          return [createCodeFixAction(fixId28, changes, [Diagnostics.Use_0, suggestion], fixId28, Diagnostics.Use_Number_isNaN_in_all_conditions)];
+        errorCodes: errorCodes54,
+        getCodeActions: function getCodeActionsToUseBigintLiteral(context) {
+          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => makeChange9(t, context.sourceFile, context.span));
+          if (changes.length > 0) {
+            return [createCodeFixAction(fixId43, changes, Diagnostics.Convert_to_a_bigint_numeric_literal, fixId43, Diagnostics.Convert_all_to_bigint_numeric_literals)];
+          }
         },
-        fixIds: [fixId28],
+        fixIds: [fixId43],
         getAllCodeActions: (context) => {
-          return codeFixAll(context, errorCodes34, (changes, diag2) => {
-            const info = getInfo11(context.program, diag2.file, createTextSpan(diag2.start, diag2.length));
-            if (info) {
-              doChange22(changes, diag2.file, info.arg, info.expression);
-            }
-          });
+          return codeFixAll(context, errorCodes54, (changes, diag2) => makeChange9(changes, diag2.file, diag2));
         }
       });
     }
   });
 
-  // src/services/codefixes/fixModuleAndTargetOptions.ts
-  var init_fixModuleAndTargetOptions = __esm({
-    "src/services/codefixes/fixModuleAndTargetOptions.ts"() {
+  // src/services/codefixes/fixAddModuleReferTypeMissingTypeof.ts
+  function getImportTypeNode(sourceFile, pos) {
+    const token = getTokenAtPosition(sourceFile, pos);
+    Debug.assert(token.kind === 102 /* ImportKeyword */, "This token should be an ImportKeyword");
+    Debug.assert(token.parent.kind === 205 /* ImportType */, "Token parent should be an ImportType");
+    return token.parent;
+  }
+  function doChange36(changes, sourceFile, importType) {
+    const newTypeNode = factory.updateImportTypeNode(
+      importType,
+      importType.argument,
+      importType.attributes,
+      importType.qualifier,
+      importType.typeArguments,
+      /*isTypeOf*/
+      true
+    );
+    changes.replaceNode(sourceFile, importType, newTypeNode);
+  }
+  var fixIdAddMissingTypeof, fixId44, errorCodes55;
+  var init_fixAddModuleReferTypeMissingTypeof = __esm({
+    "src/services/codefixes/fixAddModuleReferTypeMissingTypeof.ts"() {
       "use strict";
       init_ts4();
       init_ts_codefix();
+      fixIdAddMissingTypeof = "fixAddModuleReferTypeMissingTypeof";
+      fixId44 = fixIdAddMissingTypeof;
+      errorCodes55 = [Diagnostics.Module_0_does_not_refer_to_a_type_but_is_used_as_a_type_here_Did_you_mean_typeof_import_0.code];
       registerCodeFix({
-        errorCodes: [
-          Diagnostics.Top_level_await_expressions_are_only_allowed_when_the_module_option_is_set_to_es2022_esnext_system_node16_or_nodenext_and_the_target_option_is_set_to_es2017_or_higher.code,
-          Diagnostics.Top_level_for_await_loops_are_only_allowed_when_the_module_option_is_set_to_es2022_esnext_system_node16_or_nodenext_and_the_target_option_is_set_to_es2017_or_higher.code
-        ],
-        getCodeActions: function getCodeActionsToFixModuleAndTarget(context) {
-          const compilerOptions = context.program.getCompilerOptions();
-          const { configFile } = compilerOptions;
-          if (configFile === void 0) {
-            return void 0;
-          }
-          const codeFixes = [];
-          const moduleKind = getEmitModuleKind(compilerOptions);
-          const moduleOutOfRange = moduleKind >= 5 /* ES2015 */ && moduleKind < 99 /* ESNext */;
-          if (moduleOutOfRange) {
-            const changes = ts_textChanges_exports.ChangeTracker.with(context, (changes2) => {
-              setJsonCompilerOptionValue(changes2, configFile, "module", factory.createStringLiteral("esnext"));
-            });
-            codeFixes.push(createCodeFixActionWithoutFixAll("fixModuleOption", changes, [Diagnostics.Set_the_module_option_in_your_configuration_file_to_0, "esnext"]));
-          }
-          const target = getEmitScriptTarget(compilerOptions);
-          const targetOutOfRange = target < 4 /* ES2017 */ || target > 99 /* ESNext */;
-          if (targetOutOfRange) {
-            const changes = ts_textChanges_exports.ChangeTracker.with(context, (tracker) => {
-              const configObject = getTsConfigObjectLiteralExpression(configFile);
-              if (!configObject)
-                return;
-              const options = [["target", factory.createStringLiteral("es2017")]];
-              if (moduleKind === 1 /* CommonJS */) {
-                options.push(["module", factory.createStringLiteral("commonjs")]);
-              }
-              setJsonCompilerOptionValues(tracker, configFile, options);
-            });
-            codeFixes.push(createCodeFixActionWithoutFixAll("fixTargetOption", changes, [Diagnostics.Set_the_target_option_in_your_configuration_file_to_0, "es2017"]));
-          }
-          return codeFixes.length ? codeFixes : void 0;
-        }
+        errorCodes: errorCodes55,
+        getCodeActions: function getCodeActionsToAddMissingTypeof(context) {
+          const { sourceFile, span } = context;
+          const importType = getImportTypeNode(sourceFile, span.start);
+          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange36(t, sourceFile, importType));
+          return [createCodeFixAction(fixId44, changes, Diagnostics.Add_missing_typeof, fixId44, Diagnostics.Add_missing_typeof)];
+        },
+        fixIds: [fixId44],
+        getAllCodeActions: (context) => codeFixAll(context, errorCodes55, (changes, diag2) => doChange36(changes, context.sourceFile, getImportTypeNode(diag2.file, diag2.start)))
       });
     }
   });
 
-  // src/services/codefixes/fixPropertyAssignment.ts
-  function doChange23(changes, sourceFile, node) {
-    changes.replaceNode(sourceFile, node, factory.createPropertyAssignment(node.name, node.objectAssignmentInitializer));
+  // src/services/codefixes/wrapJsxInFragment.ts
+  function findNodeToFix(sourceFile, pos) {
+    const lessThanToken = getTokenAtPosition(sourceFile, pos);
+    const firstJsxElementOrOpenElement = lessThanToken.parent;
+    let binaryExpr = firstJsxElementOrOpenElement.parent;
+    if (!isBinaryExpression(binaryExpr)) {
+      binaryExpr = binaryExpr.parent;
+      if (!isBinaryExpression(binaryExpr))
+        return void 0;
+    }
+    if (!nodeIsMissing(binaryExpr.operatorToken))
+      return void 0;
+    return binaryExpr;
   }
-  function getProperty2(sourceFile, pos) {
-    return cast(getTokenAtPosition(sourceFile, pos).parent, isShorthandPropertyAssignment);
+  function doChange37(changeTracker, sf, node) {
+    const jsx = flattenInvalidBinaryExpr(node);
+    if (jsx)
+      changeTracker.replaceNode(sf, node, factory.createJsxFragment(factory.createJsxOpeningFragment(), jsx, factory.createJsxJsxClosingFragment()));
   }
-  var fixId29, errorCodes35;
-  var init_fixPropertyAssignment = __esm({
-    "src/services/codefixes/fixPropertyAssignment.ts"() {
+  function flattenInvalidBinaryExpr(node) {
+    const children = [];
+    let current = node;
+    while (true) {
+      if (isBinaryExpression(current) && nodeIsMissing(current.operatorToken) && current.operatorToken.kind === 28 /* CommaToken */) {
+        children.push(current.left);
+        if (isJsxChild(current.right)) {
+          children.push(current.right);
+          return children;
+        } else if (isBinaryExpression(current.right)) {
+          current = current.right;
+          continue;
+        } else
+          return void 0;
+      } else
+        return void 0;
+    }
+  }
+  var fixID2, errorCodes56;
+  var init_wrapJsxInFragment = __esm({
+    "src/services/codefixes/wrapJsxInFragment.ts"() {
       "use strict";
       init_ts4();
       init_ts_codefix();
-      fixId29 = "fixPropertyAssignment";
-      errorCodes35 = [
-        Diagnostics.Did_you_mean_to_use_a_Colon_An_can_only_follow_a_property_name_when_the_containing_object_literal_is_part_of_a_destructuring_pattern.code
-      ];
+      fixID2 = "wrapJsxInFragment";
+      errorCodes56 = [Diagnostics.JSX_expressions_must_have_one_parent_element.code];
       registerCodeFix({
-        errorCodes: errorCodes35,
-        fixIds: [fixId29],
-        getCodeActions(context) {
+        errorCodes: errorCodes56,
+        getCodeActions: function getCodeActionsToWrapJsxInFragment(context) {
           const { sourceFile, span } = context;
-          const property = getProperty2(sourceFile, span.start);
-          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange23(t, context.sourceFile, property));
-          return [createCodeFixAction(fixId29, changes, [Diagnostics.Change_0_to_1, "=", ":"], fixId29, [Diagnostics.Switch_each_misused_0_to_1, "=", ":"])];
+          const node = findNodeToFix(sourceFile, span.start);
+          if (!node)
+            return void 0;
+          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange37(t, sourceFile, node));
+          return [createCodeFixAction(fixID2, changes, Diagnostics.Wrap_in_JSX_fragment, fixID2, Diagnostics.Wrap_all_unparented_JSX_in_JSX_fragment)];
         },
-        getAllCodeActions: (context) => codeFixAll(context, errorCodes35, (changes, diag2) => doChange23(changes, diag2.file, getProperty2(diag2.file, diag2.start)))
+        fixIds: [fixID2],
+        getAllCodeActions: (context) => codeFixAll(context, errorCodes56, (changes, diag2) => {
+          const node = findNodeToFix(context.sourceFile, diag2.start);
+          if (!node)
+            return void 0;
+          doChange37(changes, context.sourceFile, node);
+        })
       });
     }
   });
 
-  // src/services/codefixes/fixExtendsInterfaceBecomesImplements.ts
-  function getNodes2(sourceFile, pos) {
+  // src/services/codefixes/convertToMappedObjectType.ts
+  function getInfo19(sourceFile, pos) {
     const token = getTokenAtPosition(sourceFile, pos);
-    const heritageClauses = getContainingClass(token).heritageClauses;
-    const extendsToken = heritageClauses[0].getFirstToken();
-    return extendsToken.kind === 96 /* ExtendsKeyword */ ? { extendsToken, heritageClauses } : void 0;
+    const indexSignature = tryCast(token.parent.parent, isIndexSignatureDeclaration);
+    if (!indexSignature)
+      return void 0;
+    const container = isInterfaceDeclaration(indexSignature.parent) ? indexSignature.parent : tryCast(indexSignature.parent.parent, isTypeAliasDeclaration);
+    if (!container)
+      return void 0;
+    return { indexSignature, container };
   }
-  function doChanges2(changes, sourceFile, extendsToken, heritageClauses) {
-    changes.replaceNode(sourceFile, extendsToken, factory.createToken(119 /* ImplementsKeyword */));
-    if (heritageClauses.length === 2 && heritageClauses[0].token === 96 /* ExtendsKeyword */ && heritageClauses[1].token === 119 /* ImplementsKeyword */) {
-      const implementsToken = heritageClauses[1].getFirstToken();
-      const implementsFullStart = implementsToken.getFullStart();
-      changes.replaceRange(sourceFile, { pos: implementsFullStart, end: implementsFullStart }, factory.createToken(28 /* CommaToken */));
-      const text = sourceFile.text;
-      let end = implementsToken.end;
-      while (end < text.length && isWhiteSpaceSingleLine(text.charCodeAt(end))) {
-        end++;
-      }
-      changes.deleteRange(sourceFile, { pos: implementsToken.getStart(), end });
-    }
+  function createTypeAliasFromInterface(declaration, type) {
+    return factory.createTypeAliasDeclaration(declaration.modifiers, declaration.name, declaration.typeParameters, type);
   }
-  var fixId30, errorCodes36;
-  var init_fixExtendsInterfaceBecomesImplements = __esm({
-    "src/services/codefixes/fixExtendsInterfaceBecomesImplements.ts"() {
+  function doChange38(changes, sourceFile, { indexSignature, container }) {
+    const members = isInterfaceDeclaration(container) ? container.members : container.type.members;
+    const otherMembers = members.filter((member) => !isIndexSignatureDeclaration(member));
+    const parameter = first(indexSignature.parameters);
+    const mappedTypeParameter = factory.createTypeParameterDeclaration(
+      /*modifiers*/
+      void 0,
+      cast(parameter.name, isIdentifier),
+      parameter.type
+    );
+    const mappedIntersectionType = factory.createMappedTypeNode(
+      hasEffectiveReadonlyModifier(indexSignature) ? factory.createModifier(148 /* ReadonlyKeyword */) : void 0,
+      mappedTypeParameter,
+      /*nameType*/
+      void 0,
+      indexSignature.questionToken,
+      indexSignature.type,
+      /*members*/
+      void 0
+    );
+    const intersectionType = factory.createIntersectionTypeNode([
+      ...getAllSuperTypeNodes(container),
+      mappedIntersectionType,
+      ...otherMembers.length ? [factory.createTypeLiteralNode(otherMembers)] : emptyArray
+    ]);
+    changes.replaceNode(sourceFile, container, createTypeAliasFromInterface(container, intersectionType));
+  }
+  var fixId45, errorCodes57;
+  var init_convertToMappedObjectType = __esm({
+    "src/services/codefixes/convertToMappedObjectType.ts"() {
       "use strict";
       init_ts4();
       init_ts_codefix();
-      fixId30 = "extendsInterfaceBecomesImplements";
-      errorCodes36 = [Diagnostics.Cannot_extend_an_interface_0_Did_you_mean_implements.code];
+      fixId45 = "fixConvertToMappedObjectType";
+      errorCodes57 = [Diagnostics.An_index_signature_parameter_type_cannot_be_a_literal_type_or_generic_type_Consider_using_a_mapped_object_type_instead.code];
       registerCodeFix({
-        errorCodes: errorCodes36,
-        getCodeActions(context) {
-          const { sourceFile } = context;
-          const nodes = getNodes2(sourceFile, context.span.start);
-          if (!nodes)
+        errorCodes: errorCodes57,
+        getCodeActions: function getCodeActionsToConvertToMappedTypeObject(context) {
+          const { sourceFile, span } = context;
+          const info = getInfo19(sourceFile, span.start);
+          if (!info)
             return void 0;
-          const { extendsToken, heritageClauses } = nodes;
-          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChanges2(t, sourceFile, extendsToken, heritageClauses));
-          return [createCodeFixAction(fixId30, changes, Diagnostics.Change_extends_to_implements, fixId30, Diagnostics.Change_all_extended_interfaces_to_implements)];
+          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange38(t, sourceFile, info));
+          const name = idText(info.container.name);
+          return [createCodeFixAction(fixId45, changes, [Diagnostics.Convert_0_to_mapped_object_type, name], fixId45, [Diagnostics.Convert_0_to_mapped_object_type, name])];
         },
-        fixIds: [fixId30],
-        getAllCodeActions: (context) => codeFixAll(context, errorCodes36, (changes, diag2) => {
-          const nodes = getNodes2(diag2.file, diag2.start);
-          if (nodes)
-            doChanges2(changes, diag2.file, nodes.extendsToken, nodes.heritageClauses);
+        fixIds: [fixId45],
+        getAllCodeActions: (context) => codeFixAll(context, errorCodes57, (changes, diag2) => {
+          const info = getInfo19(diag2.file, diag2.start);
+          if (info)
+            doChange38(changes, diag2.file, info);
         })
       });
     }
   });
 
-  // src/services/codefixes/fixForgottenThisPropertyAccess.ts
-  function getInfo12(sourceFile, pos, diagCode) {
-    const node = getTokenAtPosition(sourceFile, pos);
-    if (isIdentifier(node) || isPrivateIdentifier(node)) {
-      return { node, className: diagCode === didYouMeanStaticMemberCode ? getContainingClass(node).name.text : void 0 };
-    }
-  }
-  function doChange24(changes, sourceFile, { node, className }) {
-    suppressLeadingAndTrailingTrivia(node);
-    changes.replaceNode(sourceFile, node, factory.createPropertyAccessExpression(className ? factory.createIdentifier(className) : factory.createThis(), node));
-  }
-  var fixId31, didYouMeanStaticMemberCode, errorCodes37;
-  var init_fixForgottenThisPropertyAccess = __esm({
-    "src/services/codefixes/fixForgottenThisPropertyAccess.ts"() {
+  // src/services/codefixes/removeAccidentalCallParentheses.ts
+  var fixId46, errorCodes58;
+  var init_removeAccidentalCallParentheses = __esm({
+    "src/services/codefixes/removeAccidentalCallParentheses.ts"() {
       "use strict";
       init_ts4();
       init_ts_codefix();
-      fixId31 = "forgottenThisPropertyAccess";
-      didYouMeanStaticMemberCode = Diagnostics.Cannot_find_name_0_Did_you_mean_the_static_member_1_0.code;
-      errorCodes37 = [
-        Diagnostics.Cannot_find_name_0_Did_you_mean_the_instance_member_this_0.code,
-        Diagnostics.Private_identifiers_are_only_allowed_in_class_bodies_and_may_only_be_used_as_part_of_a_class_member_declaration_property_access_or_on_the_left_hand_side_of_an_in_expression.code,
-        didYouMeanStaticMemberCode
+      fixId46 = "removeAccidentalCallParentheses";
+      errorCodes58 = [
+        Diagnostics.This_expression_is_not_callable_because_it_is_a_get_accessor_Did_you_mean_to_use_it_without.code
       ];
       registerCodeFix({
-        errorCodes: errorCodes37,
+        errorCodes: errorCodes58,
         getCodeActions(context) {
-          const { sourceFile } = context;
-          const info = getInfo12(sourceFile, context.span.start, context.errorCode);
-          if (!info) {
+          const callExpression = findAncestor(getTokenAtPosition(context.sourceFile, context.span.start), isCallExpression);
+          if (!callExpression) {
             return void 0;
           }
-          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange24(t, sourceFile, info));
-          return [createCodeFixAction(fixId31, changes, [Diagnostics.Add_0_to_unresolved_variable, info.className || "this"], fixId31, Diagnostics.Add_qualifier_to_all_unresolved_variables_matching_a_member_name)];
+          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => {
+            t.deleteRange(context.sourceFile, { pos: callExpression.expression.end, end: callExpression.end });
+          });
+          return [createCodeFixActionWithoutFixAll(fixId46, changes, Diagnostics.Remove_parentheses)];
         },
-        fixIds: [fixId31],
-        getAllCodeActions: (context) => codeFixAll(context, errorCodes37, (changes, diag2) => {
-          const info = getInfo12(diag2.file, diag2.start, diag2.code);
-          if (info)
-            doChange24(changes, context.sourceFile, info);
-        })
+        fixIds: [fixId46]
       });
     }
   });
 
-  // src/services/codefixes/fixInvalidJsxCharacters.ts
-  function isValidCharacter(character) {
-    return hasProperty(htmlEntity, character);
-  }
-  function doChange25(changes, preferences, sourceFile, start, useHtmlEntity) {
-    const character = sourceFile.getText()[start];
-    if (!isValidCharacter(character)) {
+  // src/services/codefixes/removeUnnecessaryAwait.ts
+  function makeChange10(changeTracker, sourceFile, span) {
+    const awaitKeyword = tryCast(getTokenAtPosition(sourceFile, span.start), (node) => node.kind === 135 /* AwaitKeyword */);
+    const awaitExpression = awaitKeyword && tryCast(awaitKeyword.parent, isAwaitExpression);
+    if (!awaitExpression) {
       return;
     }
-    const replacement = useHtmlEntity ? htmlEntity[character] : `{${quote(sourceFile, preferences, character)}}`;
-    changes.replaceRangeWithText(sourceFile, { pos: start, end: start + 1 }, replacement);
+    let expressionToReplace = awaitExpression;
+    const hasSurroundingParens = isParenthesizedExpression(awaitExpression.parent);
+    if (hasSurroundingParens) {
+      const leftMostExpression = getLeftmostExpression(
+        awaitExpression.expression,
+        /*stopAtCallExpressions*/
+        false
+      );
+      if (isIdentifier(leftMostExpression)) {
+        const precedingToken = findPrecedingToken(awaitExpression.parent.pos, sourceFile);
+        if (precedingToken && precedingToken.kind !== 105 /* NewKeyword */) {
+          expressionToReplace = awaitExpression.parent;
+        }
+      }
+    }
+    changeTracker.replaceNode(sourceFile, expressionToReplace, awaitExpression.expression);
   }
-  var fixIdExpression, fixIdHtmlEntity, errorCodes38, htmlEntity;
-  var init_fixInvalidJsxCharacters = __esm({
-    "src/services/codefixes/fixInvalidJsxCharacters.ts"() {
+  var fixId47, errorCodes59;
+  var init_removeUnnecessaryAwait = __esm({
+    "src/services/codefixes/removeUnnecessaryAwait.ts"() {
       "use strict";
       init_ts4();
       init_ts_codefix();
-      fixIdExpression = "fixInvalidJsxCharacters_expression";
-      fixIdHtmlEntity = "fixInvalidJsxCharacters_htmlEntity";
-      errorCodes38 = [
-        Diagnostics.Unexpected_token_Did_you_mean_or_gt.code,
-        Diagnostics.Unexpected_token_Did_you_mean_or_rbrace.code
+      fixId47 = "removeUnnecessaryAwait";
+      errorCodes59 = [
+        Diagnostics.await_has_no_effect_on_the_type_of_this_expression.code
       ];
       registerCodeFix({
-        errorCodes: errorCodes38,
-        fixIds: [fixIdExpression, fixIdHtmlEntity],
-        getCodeActions(context) {
-          const { sourceFile, preferences, span } = context;
-          const changeToExpression = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange25(
-            t,
-            preferences,
-            sourceFile,
-            span.start,
-            /*useHtmlEntity*/
-            false
-          ));
-          const changeToHtmlEntity = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange25(
-            t,
-            preferences,
-            sourceFile,
-            span.start,
-            /*useHtmlEntity*/
-            true
-          ));
-          return [
-            createCodeFixAction(fixIdExpression, changeToExpression, Diagnostics.Wrap_invalid_character_in_an_expression_container, fixIdExpression, Diagnostics.Wrap_all_invalid_characters_in_an_expression_container),
-            createCodeFixAction(fixIdHtmlEntity, changeToHtmlEntity, Diagnostics.Convert_invalid_character_to_its_html_entity_code, fixIdHtmlEntity, Diagnostics.Convert_all_invalid_characters_to_HTML_entity_code)
-          ];
+        errorCodes: errorCodes59,
+        getCodeActions: function getCodeActionsToRemoveUnnecessaryAwait(context) {
+          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => makeChange10(t, context.sourceFile, context.span));
+          if (changes.length > 0) {
+            return [createCodeFixAction(fixId47, changes, Diagnostics.Remove_unnecessary_await, fixId47, Diagnostics.Remove_all_unnecessary_uses_of_await)];
+          }
         },
-        getAllCodeActions(context) {
-          return codeFixAll(context, errorCodes38, (changes, diagnostic) => doChange25(changes, context.preferences, diagnostic.file, diagnostic.start, context.fixId === fixIdHtmlEntity));
+        fixIds: [fixId47],
+        getAllCodeActions: (context) => {
+          return codeFixAll(context, errorCodes59, (changes, diag2) => makeChange10(changes, diag2.file, diag2));
         }
       });
-      htmlEntity = {
-        ">": ">",
-        "}": "}"
-      };
     }
   });
 
-  // src/services/codefixes/fixUnmatchedParameter.ts
-  function getDeleteAction(context, { name, jsDocHost, jsDocParameterTag }) {
-    const changes = ts_textChanges_exports.ChangeTracker.with(context, (changeTracker) => changeTracker.filterJSDocTags(context.sourceFile, jsDocHost, (t) => t !== jsDocParameterTag));
-    return createCodeFixAction(
-      deleteUnmatchedParameter,
-      changes,
-      [Diagnostics.Delete_unused_param_tag_0, name.getText(context.sourceFile)],
-      deleteUnmatchedParameter,
-      Diagnostics.Delete_all_unused_param_tags
-    );
+  // src/services/codefixes/splitTypeOnlyImport.ts
+  function getImportDeclaration2(sourceFile, span) {
+    return findAncestor(getTokenAtPosition(sourceFile, span.start), isImportDeclaration);
   }
-  function getRenameAction(context, { name, jsDocHost, signature, jsDocParameterTag }) {
-    if (!length(signature.parameters))
-      return void 0;
-    const sourceFile = context.sourceFile;
-    const tags = getJSDocTags(signature);
-    const names = /* @__PURE__ */ new Set();
-    for (const tag of tags) {
-      if (isJSDocParameterTag(tag) && isIdentifier(tag.name)) {
-        names.add(tag.name.escapedText);
-      }
+  function splitTypeOnlyImport(changes, importDeclaration, context) {
+    if (!importDeclaration) {
+      return;
     }
-    const parameterName = firstDefined(signature.parameters, (p) => isIdentifier(p.name) && !names.has(p.name.escapedText) ? p.name.getText(sourceFile) : void 0);
-    if (parameterName === void 0)
-      return void 0;
-    const newJSDocParameterTag = factory.updateJSDocParameterTag(
-      jsDocParameterTag,
-      jsDocParameterTag.tagName,
-      factory.createIdentifier(parameterName),
-      jsDocParameterTag.isBracketed,
-      jsDocParameterTag.typeExpression,
-      jsDocParameterTag.isNameFirst,
-      jsDocParameterTag.comment
+    const importClause = Debug.checkDefined(importDeclaration.importClause);
+    changes.replaceNode(
+      context.sourceFile,
+      importDeclaration,
+      factory.updateImportDeclaration(
+        importDeclaration,
+        importDeclaration.modifiers,
+        factory.updateImportClause(
+          importClause,
+          importClause.isTypeOnly,
+          importClause.name,
+          /*namedBindings*/
+          void 0
+        ),
+        importDeclaration.moduleSpecifier,
+        importDeclaration.attributes
+      )
+    );
+    changes.insertNodeAfter(
+      context.sourceFile,
+      importDeclaration,
+      factory.createImportDeclaration(
+        /*modifiers*/
+        void 0,
+        factory.updateImportClause(
+          importClause,
+          importClause.isTypeOnly,
+          /*name*/
+          void 0,
+          importClause.namedBindings
+        ),
+        importDeclaration.moduleSpecifier,
+        importDeclaration.attributes
+      )
     );
-    const changes = ts_textChanges_exports.ChangeTracker.with(context, (changeTracker) => changeTracker.replaceJSDocComment(sourceFile, jsDocHost, map(tags, (t) => t === jsDocParameterTag ? newJSDocParameterTag : t)));
-    return createCodeFixActionWithoutFixAll(renameUnmatchedParameter, changes, [Diagnostics.Rename_param_tag_name_0_to_1, name.getText(sourceFile), parameterName]);
   }
-  function getInfo13(sourceFile, pos) {
-    const token = getTokenAtPosition(sourceFile, pos);
-    if (token.parent && isJSDocParameterTag(token.parent) && isIdentifier(token.parent.name)) {
-      const jsDocParameterTag = token.parent;
-      const jsDocHost = getJSDocHost(jsDocParameterTag);
-      const signature = getHostSignatureFromJSDoc(jsDocParameterTag);
-      if (jsDocHost && signature) {
-        return { jsDocHost, signature, name: token.parent.name, jsDocParameterTag };
-      }
+  var errorCodes60, fixId48;
+  var init_splitTypeOnlyImport = __esm({
+    "src/services/codefixes/splitTypeOnlyImport.ts"() {
+      "use strict";
+      init_ts4();
+      init_ts_codefix();
+      errorCodes60 = [Diagnostics.A_type_only_import_can_specify_a_default_import_or_named_bindings_but_not_both.code];
+      fixId48 = "splitTypeOnlyImport";
+      registerCodeFix({
+        errorCodes: errorCodes60,
+        fixIds: [fixId48],
+        getCodeActions: function getCodeActionsToSplitTypeOnlyImport(context) {
+          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => {
+            return splitTypeOnlyImport(t, getImportDeclaration2(context.sourceFile, context.span), context);
+          });
+          if (changes.length) {
+            return [createCodeFixAction(fixId48, changes, Diagnostics.Split_into_two_separate_import_declarations, fixId48, Diagnostics.Split_all_invalid_type_only_imports)];
+          }
+        },
+        getAllCodeActions: (context) => codeFixAll(context, errorCodes60, (changes, error2) => {
+          splitTypeOnlyImport(changes, getImportDeclaration2(context.sourceFile, error2), context);
+        })
+      });
     }
-    return void 0;
+  });
+
+  // src/services/codefixes/convertConstToLet.ts
+  function getInfo20(sourceFile, pos, program) {
+    var _a;
+    const checker = program.getTypeChecker();
+    const symbol = checker.getSymbolAtLocation(getTokenAtPosition(sourceFile, pos));
+    if (symbol === void 0)
+      return;
+    const declaration = tryCast((_a = symbol == null ? void 0 : symbol.valueDeclaration) == null ? void 0 : _a.parent, isVariableDeclarationList);
+    if (declaration === void 0)
+      return;
+    const constToken = findChildOfKind(declaration, 87 /* ConstKeyword */, sourceFile);
+    if (constToken === void 0)
+      return;
+    return { symbol, token: constToken };
   }
-  var deleteUnmatchedParameter, renameUnmatchedParameter, errorCodes39;
-  var init_fixUnmatchedParameter = __esm({
-    "src/services/codefixes/fixUnmatchedParameter.ts"() {
+  function doChange39(changes, sourceFile, token) {
+    changes.replaceNode(sourceFile, token, factory.createToken(121 /* LetKeyword */));
+  }
+  var fixId49, errorCodes61;
+  var init_convertConstToLet = __esm({
+    "src/services/codefixes/convertConstToLet.ts"() {
       "use strict";
       init_ts4();
       init_ts_codefix();
-      deleteUnmatchedParameter = "deleteUnmatchedParameter";
-      renameUnmatchedParameter = "renameUnmatchedParameter";
-      errorCodes39 = [
-        Diagnostics.JSDoc_param_tag_has_name_0_but_there_is_no_parameter_with_that_name.code
-      ];
+      fixId49 = "fixConvertConstToLet";
+      errorCodes61 = [Diagnostics.Cannot_assign_to_0_because_it_is_a_constant.code];
       registerCodeFix({
-        fixIds: [deleteUnmatchedParameter, renameUnmatchedParameter],
-        errorCodes: errorCodes39,
-        getCodeActions: function getCodeActionsToFixUnmatchedParameter(context) {
-          const { sourceFile, span } = context;
-          const actions2 = [];
-          const info = getInfo13(sourceFile, span.start);
-          if (info) {
-            append(actions2, getDeleteAction(context, info));
-            append(actions2, getRenameAction(context, info));
-            return actions2;
-          }
-          return void 0;
+        errorCodes: errorCodes61,
+        getCodeActions: function getCodeActionsToConvertConstToLet(context) {
+          const { sourceFile, span, program } = context;
+          const info = getInfo20(sourceFile, span.start, program);
+          if (info === void 0)
+            return;
+          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange39(t, sourceFile, info.token));
+          return [createCodeFixActionMaybeFixAll(fixId49, changes, Diagnostics.Convert_const_to_let, fixId49, Diagnostics.Convert_all_const_to_let)];
         },
-        getAllCodeActions: function getAllCodeActionsToFixUnmatchedParameter(context) {
-          const tagsToSignature = /* @__PURE__ */ new Map();
+        getAllCodeActions: (context) => {
+          const { program } = context;
+          const seen = /* @__PURE__ */ new Map();
           return createCombinedCodeActions(ts_textChanges_exports.ChangeTracker.with(context, (changes) => {
-            eachDiagnostic(context, errorCodes39, ({ file, start }) => {
-              const info = getInfo13(file, start);
+            eachDiagnostic(context, errorCodes61, (diag2) => {
+              const info = getInfo20(diag2.file, diag2.start, program);
               if (info) {
-                tagsToSignature.set(info.signature, append(tagsToSignature.get(info.signature), info.jsDocParameterTag));
-              }
-            });
-            tagsToSignature.forEach((tags, signature) => {
-              if (context.fixId === deleteUnmatchedParameter) {
-                const tagsSet = new Set(tags);
-                changes.filterJSDocTags(signature.getSourceFile(), signature, (t) => !tagsSet.has(t));
+                if (addToSeen(seen, getSymbolId(info.symbol))) {
+                  return doChange39(changes, diag2.file, info.token);
+                }
               }
+              return void 0;
             });
           }));
-        }
+        },
+        fixIds: [fixId49]
+      });
+    }
+  });
+
+  // src/services/codefixes/fixExpectedComma.ts
+  function getInfo21(sourceFile, pos, _) {
+    const node = getTokenAtPosition(sourceFile, pos);
+    return node.kind === 27 /* SemicolonToken */ && node.parent && (isObjectLiteralExpression(node.parent) || isArrayLiteralExpression(node.parent)) ? { node } : void 0;
+  }
+  function doChange40(changes, sourceFile, { node }) {
+    const newNode = factory.createToken(28 /* CommaToken */);
+    changes.replaceNode(sourceFile, node, newNode);
+  }
+  var fixId50, expectedErrorCode, errorCodes62;
+  var init_fixExpectedComma = __esm({
+    "src/services/codefixes/fixExpectedComma.ts"() {
+      "use strict";
+      init_ts4();
+      init_ts_codefix();
+      fixId50 = "fixExpectedComma";
+      expectedErrorCode = Diagnostics._0_expected.code;
+      errorCodes62 = [expectedErrorCode];
+      registerCodeFix({
+        errorCodes: errorCodes62,
+        getCodeActions(context) {
+          const { sourceFile } = context;
+          const info = getInfo21(sourceFile, context.span.start, context.errorCode);
+          if (!info)
+            return void 0;
+          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange40(t, sourceFile, info));
+          return [createCodeFixAction(
+            fixId50,
+            changes,
+            [Diagnostics.Change_0_to_1, ";", ","],
+            fixId50,
+            [Diagnostics.Change_0_to_1, ";", ","]
+          )];
+        },
+        fixIds: [fixId50],
+        getAllCodeActions: (context) => codeFixAll(context, errorCodes62, (changes, diag2) => {
+          const info = getInfo21(diag2.file, diag2.start, diag2.code);
+          if (info)
+            doChange40(changes, context.sourceFile, info);
+        })
       });
     }
   });
 
-  // src/services/codefixes/fixUnreferenceableDecoratorMetadata.ts
-  function getImportDeclaration(sourceFile, program, start) {
-    const identifier = tryCast(getTokenAtPosition(sourceFile, start), isIdentifier);
-    if (!identifier || identifier.parent.kind !== 182 /* TypeReference */)
+  // src/services/codefixes/fixAddVoidToPromise.ts
+  function makeChange11(changes, sourceFile, span, program, seen) {
+    const node = getTokenAtPosition(sourceFile, span.start);
+    if (!isIdentifier(node) || !isCallExpression(node.parent) || node.parent.expression !== node || node.parent.arguments.length !== 0)
       return;
     const checker = program.getTypeChecker();
-    const symbol = checker.getSymbolAtLocation(identifier);
-    return find((symbol == null ? void 0 : symbol.declarations) || emptyArray, or(isImportClause, isImportSpecifier, isImportEqualsDeclaration));
-  }
-  function doTypeOnlyImportChange(changes, sourceFile, importDeclaration, program) {
-    if (importDeclaration.kind === 270 /* ImportEqualsDeclaration */) {
-      changes.insertModifierBefore(sourceFile, 156 /* TypeKeyword */, importDeclaration.name);
-      return;
-    }
-    const importClause = importDeclaration.kind === 272 /* ImportClause */ ? importDeclaration : importDeclaration.parent.parent;
-    if (importClause.name && importClause.namedBindings) {
+    const symbol = checker.getSymbolAtLocation(node);
+    const decl = symbol == null ? void 0 : symbol.valueDeclaration;
+    if (!decl || !isParameter(decl) || !isNewExpression(decl.parent.parent))
       return;
-    }
-    const checker = program.getTypeChecker();
-    const importsValue = !!forEachImportClauseDeclaration(importClause, (decl) => {
-      if (skipAlias(decl.symbol, checker).flags & 111551 /* Value */)
-        return true;
-    });
-    if (importsValue) {
+    if (seen == null ? void 0 : seen.has(decl))
       return;
+    seen == null ? void 0 : seen.add(decl);
+    const typeArguments = getEffectiveTypeArguments(decl.parent.parent);
+    if (some(typeArguments)) {
+      const typeArgument = typeArguments[0];
+      const needsParens = !isUnionTypeNode(typeArgument) && !isParenthesizedTypeNode(typeArgument) && isParenthesizedTypeNode(factory.createUnionTypeNode([typeArgument, factory.createKeywordTypeNode(116 /* VoidKeyword */)]).types[0]);
+      if (needsParens) {
+        changes.insertText(sourceFile, typeArgument.pos, "(");
+      }
+      changes.insertText(sourceFile, typeArgument.end, needsParens ? ") | void" : " | void");
+    } else {
+      const signature = checker.getResolvedSignature(node.parent);
+      const parameter = signature == null ? void 0 : signature.parameters[0];
+      const parameterType = parameter && checker.getTypeOfSymbolAtLocation(parameter, decl.parent.parent);
+      if (isInJSFile(decl)) {
+        if (!parameterType || parameterType.flags & 3 /* AnyOrUnknown */) {
+          changes.insertText(sourceFile, decl.parent.parent.end, `)`);
+          changes.insertText(sourceFile, skipTrivia(sourceFile.text, decl.parent.parent.pos), `/** @type {Promise} */(`);
+        }
+      } else {
+        if (!parameterType || parameterType.flags & 2 /* Unknown */) {
+          changes.insertText(sourceFile, decl.parent.parent.expression.end, "");
+        }
+      }
     }
-    changes.insertModifierBefore(sourceFile, 156 /* TypeKeyword */, importClause);
   }
-  function doNamespaceImportChange(changes, sourceFile, importDeclaration, program) {
-    ts_refactor_exports.doChangeNamedToNamespaceOrDefault(sourceFile, program, changes, importDeclaration.parent);
+  function getEffectiveTypeArguments(node) {
+    var _a;
+    if (isInJSFile(node)) {
+      if (isParenthesizedExpression(node.parent)) {
+        const jsDocType = (_a = getJSDocTypeTag(node.parent)) == null ? void 0 : _a.typeExpression.type;
+        if (jsDocType && isTypeReferenceNode(jsDocType) && isIdentifier(jsDocType.typeName) && idText(jsDocType.typeName) === "Promise") {
+          return jsDocType.typeArguments;
+        }
+      }
+    } else {
+      return node.typeArguments;
+    }
   }
-  var fixId32, errorCodes40;
-  var init_fixUnreferenceableDecoratorMetadata = __esm({
-    "src/services/codefixes/fixUnreferenceableDecoratorMetadata.ts"() {
+  var fixName7, fixId51, errorCodes63;
+  var init_fixAddVoidToPromise = __esm({
+    "src/services/codefixes/fixAddVoidToPromise.ts"() {
       "use strict";
       init_ts4();
       init_ts_codefix();
-      fixId32 = "fixUnreferenceableDecoratorMetadata";
-      errorCodes40 = [Diagnostics.A_type_referenced_in_a_decorated_signature_must_be_imported_with_import_type_or_a_namespace_import_when_isolatedModules_and_emitDecoratorMetadata_are_enabled.code];
+      fixName7 = "addVoidToPromise";
+      fixId51 = "addVoidToPromise";
+      errorCodes63 = [
+        Diagnostics.Expected_1_argument_but_got_0_new_Promise_needs_a_JSDoc_hint_to_produce_a_resolve_that_can_be_called_without_arguments.code,
+        Diagnostics.Expected_0_arguments_but_got_1_Did_you_forget_to_include_void_in_your_type_argument_to_Promise.code
+      ];
       registerCodeFix({
-        errorCodes: errorCodes40,
-        getCodeActions: (context) => {
-          const importDeclaration = getImportDeclaration(context.sourceFile, context.program, context.span.start);
-          if (!importDeclaration)
-            return;
-          const namespaceChanges = ts_textChanges_exports.ChangeTracker.with(context, (t) => importDeclaration.kind === 275 /* ImportSpecifier */ && doNamespaceImportChange(t, context.sourceFile, importDeclaration, context.program));
-          const typeOnlyChanges = ts_textChanges_exports.ChangeTracker.with(context, (t) => doTypeOnlyImportChange(t, context.sourceFile, importDeclaration, context.program));
-          let actions2;
-          if (namespaceChanges.length) {
-            actions2 = append(actions2, createCodeFixActionWithoutFixAll(fixId32, namespaceChanges, Diagnostics.Convert_named_imports_to_namespace_import));
-          }
-          if (typeOnlyChanges.length) {
-            actions2 = append(actions2, createCodeFixActionWithoutFixAll(fixId32, typeOnlyChanges, Diagnostics.Convert_to_type_only_import));
+        errorCodes: errorCodes63,
+        fixIds: [fixId51],
+        getCodeActions(context) {
+          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => makeChange11(t, context.sourceFile, context.span, context.program));
+          if (changes.length > 0) {
+            return [createCodeFixAction(fixName7, changes, Diagnostics.Add_void_to_Promise_resolved_without_a_value, fixId51, Diagnostics.Add_void_to_all_Promises_resolved_without_a_value)];
           }
-          return actions2;
         },
-        fixIds: [fixId32]
+        getAllCodeActions(context) {
+          return codeFixAll(context, errorCodes63, (changes, diag2) => makeChange11(changes, diag2.file, diag2, context.program, /* @__PURE__ */ new Set()));
+        }
       });
     }
   });
 
-  // src/services/codefixes/fixUnusedIdentifier.ts
-  function changeInferToUnknown(changes, sourceFile, token) {
-    changes.replaceNode(sourceFile, token.parent, factory.createKeywordTypeNode(159 /* UnknownKeyword */));
+  // src/services/_namespaces/ts.codefix.ts
+  var ts_codefix_exports = {};
+  __export(ts_codefix_exports, {
+    PreserveOptionalFlags: () => PreserveOptionalFlags,
+    addNewNodeForMemberSymbol: () => addNewNodeForMemberSymbol,
+    codeFixAll: () => codeFixAll,
+    createCodeFixAction: () => createCodeFixAction,
+    createCodeFixActionMaybeFixAll: () => createCodeFixActionMaybeFixAll,
+    createCodeFixActionWithoutFixAll: () => createCodeFixActionWithoutFixAll,
+    createCombinedCodeActions: () => createCombinedCodeActions,
+    createFileTextChanges: () => createFileTextChanges,
+    createImportAdder: () => createImportAdder,
+    createImportSpecifierResolver: () => createImportSpecifierResolver,
+    createJsonPropertyAssignment: () => createJsonPropertyAssignment,
+    createMissingMemberNodes: () => createMissingMemberNodes,
+    createSignatureDeclarationFromCallExpression: () => createSignatureDeclarationFromCallExpression,
+    createSignatureDeclarationFromSignature: () => createSignatureDeclarationFromSignature,
+    createStubbedBody: () => createStubbedBody,
+    eachDiagnostic: () => eachDiagnostic,
+    findAncestorMatchingSpan: () => findAncestorMatchingSpan,
+    findJsonProperty: () => findJsonProperty,
+    generateAccessorFromProperty: () => generateAccessorFromProperty,
+    getAccessorConvertiblePropertyAtPosition: () => getAccessorConvertiblePropertyAtPosition,
+    getAllFixes: () => getAllFixes,
+    getAllSupers: () => getAllSupers,
+    getArgumentTypesAndTypeParameters: () => getArgumentTypesAndTypeParameters,
+    getFixes: () => getFixes,
+    getImportCompletionAction: () => getImportCompletionAction,
+    getImportKind: () => getImportKind,
+    getJSDocTypedefNodes: () => getJSDocTypedefNodes,
+    getNoopSymbolTrackerWithResolver: () => getNoopSymbolTrackerWithResolver,
+    getPromoteTypeOnlyCompletionAction: () => getPromoteTypeOnlyCompletionAction,
+    getSupportedErrorCodes: () => getSupportedErrorCodes,
+    importFixName: () => importFixName,
+    importSymbols: () => importSymbols,
+    moduleSpecifierToValidIdentifier: () => moduleSpecifierToValidIdentifier,
+    moduleSymbolToValidIdentifier: () => moduleSymbolToValidIdentifier,
+    parameterShouldGetTypeFromJSDoc: () => parameterShouldGetTypeFromJSDoc,
+    registerCodeFix: () => registerCodeFix,
+    setJsonCompilerOptionValue: () => setJsonCompilerOptionValue,
+    setJsonCompilerOptionValues: () => setJsonCompilerOptionValues,
+    tryGetAutoImportableReferenceFromTypeNode: () => tryGetAutoImportableReferenceFromTypeNode,
+    typeToAutoImportableTypeNode: () => typeToAutoImportableTypeNode
+  });
+  var init_ts_codefix = __esm({
+    "src/services/_namespaces/ts.codefix.ts"() {
+      "use strict";
+      init_codeFixProvider();
+      init_addConvertToUnknownForNonOverlappingTypes();
+      init_addEmptyExportDeclaration();
+      init_addMissingAsync();
+      init_addMissingAwait();
+      init_addMissingConst();
+      init_addMissingDeclareProperty();
+      init_addMissingInvocationForDecorator();
+      init_addNameToNamelessParameter();
+      init_addOptionalPropertyUndefined();
+      init_annotateWithTypeFromJSDoc();
+      init_convertFunctionToEs6Class();
+      init_convertToAsyncFunction();
+      init_convertToEsModule();
+      init_correctQualifiedNameToIndexedAccessType();
+      init_convertToTypeOnlyExport();
+      init_convertToTypeOnlyImport();
+      init_convertTypedefToType();
+      init_convertLiteralTypeToMappedType();
+      init_fixClassIncorrectlyImplementsInterface();
+      init_importFixes();
+      init_fixAddMissingConstraint();
+      init_fixOverrideModifier();
+      init_fixNoPropertyAccessFromIndexSignature();
+      init_fixImplicitThis();
+      init_fixImportNonExportedMember();
+      init_fixIncorrectNamedTupleSyntax();
+      init_fixSpelling();
+      init_returnValueCorrect();
+      init_fixAddMissingMember();
+      init_fixAddMissingNewOperator();
+      init_fixCannotFindModule();
+      init_fixClassDoesntImplementInheritedAbstractMember();
+      init_fixClassSuperMustPrecedeThisAccess();
+      init_fixConstructorForDerivedNeedSuperCall();
+      init_fixEnableJsxFlag();
+      init_fixNaNEquality();
+      init_fixModuleAndTargetOptions();
+      init_fixPropertyAssignment();
+      init_fixExtendsInterfaceBecomesImplements();
+      init_fixForgottenThisPropertyAccess();
+      init_fixInvalidJsxCharacters();
+      init_fixUnmatchedParameter();
+      init_fixUnreferenceableDecoratorMetadata();
+      init_fixUnusedIdentifier();
+      init_fixUnreachableCode();
+      init_fixUnusedLabel();
+      init_fixJSDocTypes();
+      init_fixMissingCallParentheses();
+      init_fixAwaitInSyncFunction();
+      init_fixPropertyOverrideAccessor();
+      init_inferFromUsage();
+      init_fixReturnTypeInAsyncFunction();
+      init_disableJsDiagnostics();
+      init_helpers2();
+      init_generateAccessors();
+      init_fixInvalidImportSyntax();
+      init_fixStrictClassInitialization();
+      init_requireInTs();
+      init_useDefaultImport();
+      init_useBigintLiteral();
+      init_fixAddModuleReferTypeMissingTypeof();
+      init_wrapJsxInFragment();
+      init_convertToMappedObjectType();
+      init_removeAccidentalCallParentheses();
+      init_removeUnnecessaryAwait();
+      init_splitTypeOnlyImport();
+      init_convertConstToLet();
+      init_fixExpectedComma();
+      init_fixAddVoidToPromise();
+    }
+  });
+
+  // src/services/completions.ts
+  function originIsThisType(origin) {
+    return !!(origin.kind & 1 /* ThisType */);
   }
-  function createDeleteFix(changes, diag2) {
-    return createCodeFixAction(fixName3, changes, diag2, fixIdDelete, Diagnostics.Delete_all_unused_declarations);
+  function originIsSymbolMember(origin) {
+    return !!(origin.kind & 2 /* SymbolMember */);
   }
-  function deleteTypeParameters(changes, sourceFile, token) {
-    changes.delete(sourceFile, Debug.checkDefined(cast(token.parent, isDeclarationWithTypeParameterChildren).typeParameters, "The type parameter to delete should exist"));
+  function originIsExport(origin) {
+    return !!(origin && origin.kind & 4 /* Export */);
   }
-  function isImport(token) {
-    return token.kind === 102 /* ImportKeyword */ || token.kind === 80 /* Identifier */ && (token.parent.kind === 275 /* ImportSpecifier */ || token.parent.kind === 272 /* ImportClause */);
+  function originIsResolvedExport(origin) {
+    return !!(origin && origin.kind === 32 /* ResolvedExport */);
   }
-  function tryGetFullImport(token) {
-    return token.kind === 102 /* ImportKeyword */ ? tryCast(token.parent, isImportDeclaration) : void 0;
+  function originIncludesSymbolName(origin) {
+    return originIsExport(origin) || originIsResolvedExport(origin) || originIsComputedPropertyName(origin);
   }
-  function canDeleteEntireVariableStatement(sourceFile, token) {
-    return isVariableDeclarationList(token.parent) && first(token.parent.getChildren(sourceFile)) === token;
+  function originIsPackageJsonImport(origin) {
+    return (originIsExport(origin) || originIsResolvedExport(origin)) && !!origin.isFromPackageJson;
   }
-  function deleteEntireVariableStatement(changes, sourceFile, node) {
-    changes.delete(sourceFile, node.parent.kind === 242 /* VariableStatement */ ? node.parent : node);
+  function originIsPromise(origin) {
+    return !!(origin.kind & 8 /* Promise */);
   }
-  function deleteDestructuringElements(changes, sourceFile, node) {
-    forEach(node.elements, (n) => changes.delete(sourceFile, n));
+  function originIsNullableMember(origin) {
+    return !!(origin.kind & 16 /* Nullable */);
   }
-  function deleteDestructuring(context, changes, sourceFile, { parent: parent2 }) {
-    if (isVariableDeclaration(parent2) && parent2.initializer && isCallLikeExpression(parent2.initializer)) {
-      if (isVariableDeclarationList(parent2.parent) && length(parent2.parent.declarations) > 1) {
-        const varStatement = parent2.parent.parent;
-        const pos = varStatement.getStart(sourceFile);
-        const end = varStatement.end;
-        changes.delete(sourceFile, parent2);
-        changes.insertNodeAt(sourceFile, end, parent2.initializer, {
-          prefix: getNewLineOrDefaultFromHost(context.host, context.formatContext.options) + sourceFile.text.slice(getPrecedingNonSpaceCharacterPosition(sourceFile.text, pos - 1), pos),
-          suffix: probablyUsesSemicolons(sourceFile) ? ";" : ""
-        });
-      } else {
-        changes.replaceNode(sourceFile, parent2.parent, parent2.initializer);
+  function originIsTypeOnlyAlias(origin) {
+    return !!(origin && origin.kind & 64 /* TypeOnlyAlias */);
+  }
+  function originIsObjectLiteralMethod(origin) {
+    return !!(origin && origin.kind & 128 /* ObjectLiteralMethod */);
+  }
+  function originIsIgnore(origin) {
+    return !!(origin && origin.kind & 256 /* Ignore */);
+  }
+  function originIsComputedPropertyName(origin) {
+    return !!(origin && origin.kind & 512 /* ComputedPropertyName */);
+  }
+  function resolvingModuleSpecifiers(logPrefix, host, resolver, program, position, preferences, isForImportStatementCompletion, isValidTypeOnlyUseSite, cb) {
+    var _a, _b, _c;
+    const start = timestamp();
+    const needsFullResolution = isForImportStatementCompletion || moduleResolutionSupportsPackageJsonExportsAndImports(getEmitModuleResolutionKind(program.getCompilerOptions()));
+    let skippedAny = false;
+    let ambientCount = 0;
+    let resolvedCount = 0;
+    let resolvedFromCacheCount = 0;
+    let cacheAttemptCount = 0;
+    const result = cb({
+      tryResolve,
+      skippedAny: () => skippedAny,
+      resolvedAny: () => resolvedCount > 0,
+      resolvedBeyondLimit: () => resolvedCount > moduleSpecifierResolutionLimit
+    });
+    const hitRateMessage = cacheAttemptCount ? ` (${(resolvedFromCacheCount / cacheAttemptCount * 100).toFixed(1)}% hit rate)` : "";
+    (_a = host.log) == null ? void 0 : _a.call(host, `${logPrefix}: resolved ${resolvedCount} module specifiers, plus ${ambientCount} ambient and ${resolvedFromCacheCount} from cache${hitRateMessage}`);
+    (_b = host.log) == null ? void 0 : _b.call(host, `${logPrefix}: response is ${skippedAny ? "incomplete" : "complete"}`);
+    (_c = host.log) == null ? void 0 : _c.call(host, `${logPrefix}: ${timestamp() - start}`);
+    return result;
+    function tryResolve(exportInfo, isFromAmbientModule) {
+      if (isFromAmbientModule) {
+        const result3 = resolver.getModuleSpecifierForBestExportInfo(exportInfo, position, isValidTypeOnlyUseSite);
+        if (result3) {
+          ambientCount++;
+        }
+        return result3 || "failed";
       }
-    } else {
-      changes.delete(sourceFile, parent2);
+      const shouldResolveModuleSpecifier = needsFullResolution || preferences.allowIncompleteCompletions && resolvedCount < moduleSpecifierResolutionLimit;
+      const shouldGetModuleSpecifierFromCache = !shouldResolveModuleSpecifier && preferences.allowIncompleteCompletions && cacheAttemptCount < moduleSpecifierResolutionCacheAttemptLimit;
+      const result2 = shouldResolveModuleSpecifier || shouldGetModuleSpecifierFromCache ? resolver.getModuleSpecifierForBestExportInfo(exportInfo, position, isValidTypeOnlyUseSite, shouldGetModuleSpecifierFromCache) : void 0;
+      if (!shouldResolveModuleSpecifier && !shouldGetModuleSpecifierFromCache || shouldGetModuleSpecifierFromCache && !result2) {
+        skippedAny = true;
+      }
+      resolvedCount += (result2 == null ? void 0 : result2.computedWithoutCacheCount) || 0;
+      resolvedFromCacheCount += exportInfo.length - ((result2 == null ? void 0 : result2.computedWithoutCacheCount) || 0);
+      if (shouldGetModuleSpecifierFromCache) {
+        cacheAttemptCount++;
+      }
+      return result2 || (needsFullResolution ? "failed" : "skipped");
     }
   }
-  function tryPrefixDeclaration(changes, errorCode, sourceFile, token) {
-    if (errorCode === Diagnostics.Property_0_is_declared_but_its_value_is_never_read.code)
-      return;
-    if (token.kind === 140 /* InferKeyword */) {
-      token = cast(token.parent, isInferTypeNode).typeParameter.name;
+  function getCompletionsAtPosition(host, program, log, sourceFile, position, preferences, triggerCharacter, completionKind, cancellationToken, formatContext, includeSymbol = false) {
+    var _a;
+    const { previousToken } = getRelevantTokens(position, sourceFile);
+    if (triggerCharacter && !isInString(sourceFile, position, previousToken) && !isValidTrigger(sourceFile, triggerCharacter, previousToken, position)) {
+      return void 0;
     }
-    if (isIdentifier(token) && canPrefix(token)) {
-      changes.replaceNode(sourceFile, token, factory.createIdentifier(`_${token.text}`));
-      if (isParameter(token.parent)) {
-        getJSDocParameterTags(token.parent).forEach((tag) => {
-          if (isIdentifier(tag.name)) {
-            changes.replaceNode(sourceFile, tag.name, factory.createIdentifier(`_${tag.name.text}`));
-          }
-        });
+    if (triggerCharacter === " ") {
+      if (preferences.includeCompletionsForImportStatements && preferences.includeCompletionsWithInsertText) {
+        return { isGlobalCompletion: true, isMemberCompletion: false, isNewIdentifierLocation: true, isIncomplete: true, entries: [] };
       }
+      return void 0;
     }
-  }
-  function canPrefix(token) {
-    switch (token.parent.kind) {
-      case 168 /* Parameter */:
-      case 167 /* TypeParameter */:
-        return true;
-      case 259 /* VariableDeclaration */: {
-        const varDecl = token.parent;
-        switch (varDecl.parent.parent.kind) {
-          case 249 /* ForOfStatement */:
-          case 248 /* ForInStatement */:
-            return true;
-        }
+    const compilerOptions = program.getCompilerOptions();
+    const checker = program.getTypeChecker();
+    const incompleteCompletionsCache = preferences.allowIncompleteCompletions ? (_a = host.getIncompleteCompletionsCache) == null ? void 0 : _a.call(host) : void 0;
+    if (incompleteCompletionsCache && completionKind === 3 /* TriggerForIncompleteCompletions */ && previousToken && isIdentifier(previousToken)) {
+      const incompleteContinuation = continuePreviousIncompleteResponse(incompleteCompletionsCache, sourceFile, previousToken, program, host, preferences, cancellationToken, position);
+      if (incompleteContinuation) {
+        return incompleteContinuation;
       }
+    } else {
+      incompleteCompletionsCache == null ? void 0 : incompleteCompletionsCache.clear();
     }
-    return false;
-  }
-  function tryDeleteDeclaration(sourceFile, token, changes, checker, sourceFiles, program, cancellationToken, isFixAll) {
-    tryDeleteDeclarationWorker(token, changes, sourceFile, checker, sourceFiles, program, cancellationToken, isFixAll);
-    if (isIdentifier(token)) {
-      ts_FindAllReferences_exports.Core.eachSymbolReferenceInFile(token, checker, sourceFile, (ref) => {
-        if (isPropertyAccessExpression(ref.parent) && ref.parent.name === ref)
-          ref = ref.parent;
-        if (!isFixAll && mayDeleteExpression(ref)) {
-          changes.delete(sourceFile, ref.parent.parent);
+    const stringCompletions = ts_Completions_StringCompletions_exports.getStringLiteralCompletions(sourceFile, position, previousToken, compilerOptions, host, program, log, preferences, includeSymbol);
+    if (stringCompletions) {
+      return stringCompletions;
+    }
+    if (previousToken && isBreakOrContinueStatement(previousToken.parent) && (previousToken.kind === 83 /* BreakKeyword */ || previousToken.kind === 88 /* ContinueKeyword */ || previousToken.kind === 80 /* Identifier */)) {
+      return getLabelCompletionAtPosition(previousToken.parent);
+    }
+    const completionData = getCompletionData(
+      program,
+      log,
+      sourceFile,
+      compilerOptions,
+      position,
+      preferences,
+      /*detailsEntryId*/
+      void 0,
+      host,
+      formatContext,
+      cancellationToken
+    );
+    if (!completionData) {
+      return void 0;
+    }
+    switch (completionData.kind) {
+      case 0 /* Data */:
+        const response = completionInfoFromData(sourceFile, host, program, compilerOptions, log, completionData, preferences, formatContext, position, includeSymbol);
+        if (response == null ? void 0 : response.isIncomplete) {
+          incompleteCompletionsCache == null ? void 0 : incompleteCompletionsCache.set(response);
         }
-      });
+        return response;
+      case 1 /* JsDocTagName */:
+        return jsdocCompletionInfo([
+          ...ts_JsDoc_exports.getJSDocTagNameCompletions(),
+          ...getJSDocParameterCompletions(
+            sourceFile,
+            position,
+            checker,
+            compilerOptions,
+            preferences,
+            /*tagNameOnly*/
+            true
+          )
+        ]);
+      case 2 /* JsDocTag */:
+        return jsdocCompletionInfo([
+          ...ts_JsDoc_exports.getJSDocTagCompletions(),
+          ...getJSDocParameterCompletions(
+            sourceFile,
+            position,
+            checker,
+            compilerOptions,
+            preferences,
+            /*tagNameOnly*/
+            false
+          )
+        ]);
+      case 3 /* JsDocParameterName */:
+        return jsdocCompletionInfo(ts_JsDoc_exports.getJSDocParameterNameCompletions(completionData.tag));
+      case 4 /* Keywords */:
+        return specificKeywordCompletionInfo(completionData.keywordCompletions, completionData.isNewIdentifierLocation);
+      default:
+        return Debug.assertNever(completionData);
     }
   }
-  function tryDeleteDeclarationWorker(token, changes, sourceFile, checker, sourceFiles, program, cancellationToken, isFixAll) {
-    const { parent: parent2 } = token;
-    if (isParameter(parent2)) {
-      tryDeleteParameter(changes, sourceFile, parent2, checker, sourceFiles, program, cancellationToken, isFixAll);
-    } else if (!(isFixAll && isIdentifier(token) && ts_FindAllReferences_exports.Core.isSymbolReferencedInFile(token, checker, sourceFile))) {
-      const node = isImportClause(parent2) ? token : isComputedPropertyName(parent2) ? parent2.parent : parent2;
-      Debug.assert(node !== sourceFile, "should not delete whole source file");
-      changes.delete(sourceFile, node);
+  function compareCompletionEntries(entryInArray, entryToInsert) {
+    var _a, _b;
+    let result = compareStringsCaseSensitiveUI(entryInArray.sortText, entryToInsert.sortText);
+    if (result === 0 /* EqualTo */) {
+      result = compareStringsCaseSensitiveUI(entryInArray.name, entryToInsert.name);
+    }
+    if (result === 0 /* EqualTo */ && ((_a = entryInArray.data) == null ? void 0 : _a.moduleSpecifier) && ((_b = entryToInsert.data) == null ? void 0 : _b.moduleSpecifier)) {
+      result = compareNumberOfDirectorySeparators(
+        entryInArray.data.moduleSpecifier,
+        entryToInsert.data.moduleSpecifier
+      );
     }
+    if (result === 0 /* EqualTo */) {
+      return -1 /* LessThan */;
+    }
+    return result;
   }
-  function tryDeleteParameter(changes, sourceFile, parameter, checker, sourceFiles, program, cancellationToken, isFixAll = false) {
-    if (mayDeleteParameter(checker, sourceFile, parameter, sourceFiles, program, cancellationToken, isFixAll)) {
-      if (parameter.modifiers && parameter.modifiers.length > 0 && (!isIdentifier(parameter.name) || ts_FindAllReferences_exports.Core.isSymbolReferencedInFile(parameter.name, checker, sourceFile))) {
-        for (const modifier of parameter.modifiers) {
-          if (isModifier(modifier)) {
-            changes.deleteModifier(sourceFile, modifier);
+  function completionEntryDataIsResolved(data) {
+    return !!(data == null ? void 0 : data.moduleSpecifier);
+  }
+  function continuePreviousIncompleteResponse(cache, file, location, program, host, preferences, cancellationToken, position) {
+    const previousResponse = cache.get();
+    if (!previousResponse)
+      return void 0;
+    const touchNode = getTouchingPropertyName(file, position);
+    const lowerCaseTokenText = location.text.toLowerCase();
+    const exportMap = getExportInfoMap(file, host, program, preferences, cancellationToken);
+    const newEntries = resolvingModuleSpecifiers(
+      "continuePreviousIncompleteResponse",
+      host,
+      ts_codefix_exports.createImportSpecifierResolver(file, program, host, preferences),
+      program,
+      location.getStart(),
+      preferences,
+      /*isForImportStatementCompletion*/
+      false,
+      isValidTypeOnlyAliasUseSite(location),
+      (context) => {
+        const entries = mapDefined(previousResponse.entries, (entry) => {
+          var _a;
+          if (!entry.hasAction || !entry.source || !entry.data || completionEntryDataIsResolved(entry.data)) {
+            return entry;
+          }
+          if (!charactersFuzzyMatchInString(entry.name, lowerCaseTokenText)) {
+            return void 0;
+          }
+          const { origin } = Debug.checkDefined(getAutoImportSymbolFromCompletionEntryData(entry.name, entry.data, program, host));
+          const info = exportMap.get(file.path, entry.data.exportMapKey);
+          const result = info && context.tryResolve(info, !isExternalModuleNameRelative(stripQuotes(origin.moduleSymbol.name)));
+          if (result === "skipped")
+            return entry;
+          if (!result || result === "failed") {
+            (_a = host.log) == null ? void 0 : _a.call(host, `Unexpected failure resolving auto import for '${entry.name}' from '${entry.source}'`);
+            return void 0;
           }
+          const newOrigin = {
+            ...origin,
+            kind: 32 /* ResolvedExport */,
+            moduleSpecifier: result.moduleSpecifier
+          };
+          entry.data = originToCompletionEntryData(newOrigin);
+          entry.source = getSourceFromOrigin(newOrigin);
+          entry.sourceDisplay = [textPart(newOrigin.moduleSpecifier)];
+          return entry;
+        });
+        if (!context.skippedAny()) {
+          previousResponse.isIncomplete = void 0;
         }
-      } else if (!parameter.initializer && isNotProvidedArguments(parameter, checker, sourceFiles)) {
-        changes.delete(sourceFile, parameter);
+        return entries;
       }
+    );
+    previousResponse.entries = newEntries;
+    previousResponse.flags = (previousResponse.flags || 0) | 4 /* IsContinuation */;
+    previousResponse.optionalReplacementSpan = getOptionalReplacementSpan(touchNode);
+    return previousResponse;
+  }
+  function jsdocCompletionInfo(entries) {
+    return { isGlobalCompletion: false, isMemberCompletion: false, isNewIdentifierLocation: false, entries };
+  }
+  function getJSDocParameterCompletions(sourceFile, position, checker, options, preferences, tagNameOnly) {
+    const currentToken = getTokenAtPosition(sourceFile, position);
+    if (!isJSDocTag(currentToken) && !isJSDoc(currentToken)) {
+      return [];
+    }
+    const jsDoc = isJSDoc(currentToken) ? currentToken : currentToken.parent;
+    if (!isJSDoc(jsDoc)) {
+      return [];
+    }
+    const func = jsDoc.parent;
+    if (!isFunctionLike(func)) {
+      return [];
     }
+    const isJs = isSourceFileJS(sourceFile);
+    const isSnippet = preferences.includeCompletionsWithSnippetText || void 0;
+    const paramTagCount = countWhere(jsDoc.tags, (tag) => isJSDocParameterTag(tag) && tag.getEnd() <= position);
+    return mapDefined(func.parameters, (param) => {
+      if (getJSDocParameterTags(param).length) {
+        return void 0;
+      }
+      if (isIdentifier(param.name)) {
+        const tabstopCounter = { tabstop: 1 };
+        const paramName = param.name.text;
+        let displayText = getJSDocParamAnnotation(
+          paramName,
+          param.initializer,
+          param.dotDotDotToken,
+          isJs,
+          /*isObject*/
+          false,
+          /*isSnippet*/
+          false,
+          checker,
+          options,
+          preferences
+        );
+        let snippetText = isSnippet ? getJSDocParamAnnotation(
+          paramName,
+          param.initializer,
+          param.dotDotDotToken,
+          isJs,
+          /*isObject*/
+          false,
+          /*isSnippet*/
+          true,
+          checker,
+          options,
+          preferences,
+          tabstopCounter
+        ) : void 0;
+        if (tagNameOnly) {
+          displayText = displayText.slice(1);
+          if (snippetText)
+            snippetText = snippetText.slice(1);
+        }
+        return {
+          name: displayText,
+          kind: "parameter" /* parameterElement */,
+          sortText: SortText.LocationPriority,
+          insertText: isSnippet ? snippetText : void 0,
+          isSnippet
+        };
+      } else if (param.parent.parameters.indexOf(param) === paramTagCount) {
+        const paramPath = `param${paramTagCount}`;
+        const displayTextResult = generateJSDocParamTagsForDestructuring(
+          paramPath,
+          param.name,
+          param.initializer,
+          param.dotDotDotToken,
+          isJs,
+          /*isSnippet*/
+          false,
+          checker,
+          options,
+          preferences
+        );
+        const snippetTextResult = isSnippet ? generateJSDocParamTagsForDestructuring(
+          paramPath,
+          param.name,
+          param.initializer,
+          param.dotDotDotToken,
+          isJs,
+          /*isSnippet*/
+          true,
+          checker,
+          options,
+          preferences
+        ) : void 0;
+        let displayText = displayTextResult.join(getNewLineCharacter(options) + "* ");
+        let snippetText = snippetTextResult == null ? void 0 : snippetTextResult.join(getNewLineCharacter(options) + "* ");
+        if (tagNameOnly) {
+          displayText = displayText.slice(1);
+          if (snippetText)
+            snippetText = snippetText.slice(1);
+        }
+        return {
+          name: displayText,
+          kind: "parameter" /* parameterElement */,
+          sortText: SortText.LocationPriority,
+          insertText: isSnippet ? snippetText : void 0,
+          isSnippet
+        };
+      }
+    });
   }
-  function isNotProvidedArguments(parameter, checker, sourceFiles) {
-    const index = parameter.parent.parameters.indexOf(parameter);
-    return !ts_FindAllReferences_exports.Core.someSignatureUsage(parameter.parent, sourceFiles, checker, (_, call) => !call || call.arguments.length > index);
+  function generateJSDocParamTagsForDestructuring(path, pattern, initializer, dotDotDotToken, isJs, isSnippet, checker, options, preferences) {
+    if (!isJs) {
+      return [
+        getJSDocParamAnnotation(
+          path,
+          initializer,
+          dotDotDotToken,
+          isJs,
+          /*isObject*/
+          false,
+          isSnippet,
+          checker,
+          options,
+          preferences,
+          { tabstop: 1 }
+        )
+      ];
+    }
+    return patternWorker(path, pattern, initializer, dotDotDotToken, { tabstop: 1 });
+    function patternWorker(path2, pattern2, initializer2, dotDotDotToken2, counter) {
+      if (isObjectBindingPattern(pattern2) && !dotDotDotToken2) {
+        const oldTabstop = counter.tabstop;
+        const childCounter = { tabstop: oldTabstop };
+        const rootParam = getJSDocParamAnnotation(
+          path2,
+          initializer2,
+          dotDotDotToken2,
+          isJs,
+          /*isObject*/
+          true,
+          isSnippet,
+          checker,
+          options,
+          preferences,
+          childCounter
+        );
+        let childTags = [];
+        for (const element of pattern2.elements) {
+          const elementTags = elementWorker(path2, element, childCounter);
+          if (!elementTags) {
+            childTags = void 0;
+            break;
+          } else {
+            childTags.push(...elementTags);
+          }
+        }
+        if (childTags) {
+          counter.tabstop = childCounter.tabstop;
+          return [rootParam, ...childTags];
+        }
+      }
+      return [
+        getJSDocParamAnnotation(
+          path2,
+          initializer2,
+          dotDotDotToken2,
+          isJs,
+          /*isObject*/
+          false,
+          isSnippet,
+          checker,
+          options,
+          preferences,
+          counter
+        )
+      ];
+    }
+    function elementWorker(path2, element, counter) {
+      if (!element.propertyName && isIdentifier(element.name) || isIdentifier(element.name)) {
+        const propertyName = element.propertyName ? tryGetTextOfPropertyName(element.propertyName) : element.name.text;
+        if (!propertyName) {
+          return void 0;
+        }
+        const paramName = `${path2}.${propertyName}`;
+        return [
+          getJSDocParamAnnotation(
+            paramName,
+            element.initializer,
+            element.dotDotDotToken,
+            isJs,
+            /*isObject*/
+            false,
+            isSnippet,
+            checker,
+            options,
+            preferences,
+            counter
+          )
+        ];
+      } else if (element.propertyName) {
+        const propertyName = tryGetTextOfPropertyName(element.propertyName);
+        return propertyName && patternWorker(`${path2}.${propertyName}`, element.name, element.initializer, element.dotDotDotToken, counter);
+      }
+      return void 0;
+    }
   }
-  function mayDeleteParameter(checker, sourceFile, parameter, sourceFiles, program, cancellationToken, isFixAll) {
-    const { parent: parent2 } = parameter;
-    switch (parent2.kind) {
-      case 173 /* MethodDeclaration */:
-      case 175 /* Constructor */:
-        const index = parent2.parameters.indexOf(parameter);
-        const referent = isMethodDeclaration(parent2) ? parent2.name : parent2;
-        const entries = ts_FindAllReferences_exports.Core.getReferencedSymbolsForNode(parent2.pos, referent, program, sourceFiles, cancellationToken);
-        if (entries) {
-          for (const entry of entries) {
-            for (const reference of entry.references) {
-              if (reference.kind === ts_FindAllReferences_exports.EntryKind.Node) {
-                const isSuperCall2 = isSuperKeyword(reference.node) && isCallExpression(reference.node.parent) && reference.node.parent.arguments.length > index;
-                const isSuperMethodCall = isPropertyAccessExpression(reference.node.parent) && isSuperKeyword(reference.node.parent.expression) && isCallExpression(reference.node.parent.parent) && reference.node.parent.parent.arguments.length > index;
-                const isOverriddenMethod = (isMethodDeclaration(reference.node.parent) || isMethodSignature(reference.node.parent)) && reference.node.parent !== parameter.parent && reference.node.parent.parameters.length > index;
-                if (isSuperCall2 || isSuperMethodCall || isOverriddenMethod)
-                  return false;
-              }
+  function getJSDocParamAnnotation(paramName, initializer, dotDotDotToken, isJs, isObject, isSnippet, checker, options, preferences, tabstopCounter) {
+    if (isSnippet) {
+      Debug.assertIsDefined(tabstopCounter);
+    }
+    if (initializer) {
+      paramName = getJSDocParamNameWithInitializer(paramName, initializer);
+    }
+    if (isSnippet) {
+      paramName = escapeSnippetText(paramName);
+    }
+    if (isJs) {
+      let type = "*";
+      if (isObject) {
+        Debug.assert(!dotDotDotToken, `Cannot annotate a rest parameter with type 'Object'.`);
+        type = "Object";
+      } else {
+        if (initializer) {
+          const inferredType = checker.getTypeAtLocation(initializer.parent);
+          if (!(inferredType.flags & (1 /* Any */ | 16384 /* Void */))) {
+            const sourceFile = initializer.getSourceFile();
+            const quotePreference = getQuotePreference(sourceFile, preferences);
+            const builderFlags = quotePreference === 0 /* Single */ ? 268435456 /* UseSingleQuotesForStringLiteralType */ : 0 /* None */;
+            const typeNode = checker.typeToTypeNode(inferredType, findAncestor(initializer, isFunctionLike), builderFlags);
+            if (typeNode) {
+              const printer = isSnippet ? createSnippetPrinter({
+                removeComments: true,
+                module: options.module,
+                target: options.target
+              }) : createPrinter({
+                removeComments: true,
+                module: options.module,
+                target: options.target
+              });
+              setEmitFlags(typeNode, 1 /* SingleLine */);
+              type = printer.printNode(4 /* Unspecified */, typeNode, sourceFile);
             }
           }
         }
-        return true;
-      case 261 /* FunctionDeclaration */: {
-        if (parent2.name && isCallbackLike(checker, sourceFile, parent2.name)) {
-          return isLastParameter(parent2, parameter, isFixAll);
+        if (isSnippet && type === "*") {
+          type = `\${${tabstopCounter.tabstop++}:${type}}`;
         }
-        return true;
       }
-      case 217 /* FunctionExpression */:
-      case 218 /* ArrowFunction */:
-        return isLastParameter(parent2, parameter, isFixAll);
-      case 177 /* SetAccessor */:
-        return false;
-      case 176 /* GetAccessor */:
-        return true;
-      default:
-        return Debug.failBadSyntaxKind(parent2);
+      const dotDotDot = !isObject && dotDotDotToken ? "..." : "";
+      const description3 = isSnippet ? `\${${tabstopCounter.tabstop++}}` : "";
+      return `@param {${dotDotDot}${type}} ${paramName} ${description3}`;
+    } else {
+      const description3 = isSnippet ? `\${${tabstopCounter.tabstop++}}` : "";
+      return `@param ${paramName} ${description3}`;
     }
   }
-  function isCallbackLike(checker, sourceFile, name) {
-    return !!ts_FindAllReferences_exports.Core.eachSymbolReferenceInFile(name, checker, sourceFile, (reference) => isIdentifier(reference) && isCallExpression(reference.parent) && reference.parent.arguments.indexOf(reference) >= 0);
+  function getJSDocParamNameWithInitializer(paramName, initializer) {
+    const initializerText = initializer.getText().trim();
+    if (initializerText.includes("\n") || initializerText.length > 80) {
+      return `[${paramName}]`;
+    }
+    return `[${paramName}=${initializerText}]`;
   }
-  function isLastParameter(func, parameter, isFixAll) {
-    const parameters = func.parameters;
-    const index = parameters.indexOf(parameter);
-    Debug.assert(index !== -1, "The parameter should already be in the list");
-    return isFixAll ? parameters.slice(index + 1).every((p) => isIdentifier(p.name) && !p.symbol.isReferenced) : index === parameters.length - 1;
+  function keywordToCompletionEntry(keyword) {
+    return {
+      name: tokenToString(keyword),
+      kind: "keyword" /* keyword */,
+      kindModifiers: "" /* none */,
+      sortText: SortText.GlobalsOrKeywords
+    };
   }
-  function mayDeleteExpression(node) {
-    return (isBinaryExpression(node.parent) && node.parent.left === node || (isPostfixUnaryExpression(node.parent) || isPrefixUnaryExpression(node.parent)) && node.parent.operand === node) && isExpressionStatement(node.parent.parent);
+  function specificKeywordCompletionInfo(entries, isNewIdentifierLocation) {
+    return {
+      isGlobalCompletion: false,
+      isMemberCompletion: false,
+      isNewIdentifierLocation,
+      entries: entries.slice()
+    };
   }
-  var fixName3, fixIdPrefix, fixIdDelete, fixIdDeleteImports, fixIdInfer, errorCodes41;
-  var init_fixUnusedIdentifier = __esm({
-    "src/services/codefixes/fixUnusedIdentifier.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_codefix();
-      fixName3 = "unusedIdentifier";
-      fixIdPrefix = "unusedIdentifier_prefix";
-      fixIdDelete = "unusedIdentifier_delete";
-      fixIdDeleteImports = "unusedIdentifier_deleteImports";
-      fixIdInfer = "unusedIdentifier_infer";
-      errorCodes41 = [
-        Diagnostics._0_is_declared_but_its_value_is_never_read.code,
-        Diagnostics._0_is_declared_but_never_used.code,
-        Diagnostics.Property_0_is_declared_but_its_value_is_never_read.code,
-        Diagnostics.All_imports_in_import_declaration_are_unused.code,
-        Diagnostics.All_destructured_elements_are_unused.code,
-        Diagnostics.All_variables_are_unused.code,
-        Diagnostics.All_type_parameters_are_unused.code
-      ];
-      registerCodeFix({
-        errorCodes: errorCodes41,
-        getCodeActions(context) {
-          const { errorCode, sourceFile, program, cancellationToken } = context;
-          const checker = program.getTypeChecker();
-          const sourceFiles = program.getSourceFiles();
-          const token = getTokenAtPosition(sourceFile, context.span.start);
-          if (isJSDocTemplateTag(token)) {
-            return [createDeleteFix(ts_textChanges_exports.ChangeTracker.with(context, (t) => t.delete(sourceFile, token)), Diagnostics.Remove_template_tag)];
-          }
-          if (token.kind === 30 /* LessThanToken */) {
-            const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => deleteTypeParameters(t, sourceFile, token));
-            return [createDeleteFix(changes, Diagnostics.Remove_type_parameters)];
-          }
-          const importDecl = tryGetFullImport(token);
-          if (importDecl) {
-            const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => t.delete(sourceFile, importDecl));
-            return [createCodeFixAction(fixName3, changes, [Diagnostics.Remove_import_from_0, showModuleSpecifier(importDecl)], fixIdDeleteImports, Diagnostics.Delete_all_unused_imports)];
-          } else if (isImport(token)) {
-            const deletion = ts_textChanges_exports.ChangeTracker.with(context, (t) => tryDeleteDeclaration(
-              sourceFile,
-              token,
-              t,
-              checker,
-              sourceFiles,
-              program,
-              cancellationToken,
-              /*isFixAll*/
-              false
-            ));
-            if (deletion.length) {
-              return [createCodeFixAction(fixName3, deletion, [Diagnostics.Remove_unused_declaration_for_Colon_0, token.getText(sourceFile)], fixIdDeleteImports, Diagnostics.Delete_all_unused_imports)];
-            }
-          }
-          if (isObjectBindingPattern(token.parent) || isArrayBindingPattern(token.parent)) {
-            if (isParameter(token.parent.parent)) {
-              const elements = token.parent.elements;
-              const diagnostic = [
-                elements.length > 1 ? Diagnostics.Remove_unused_declarations_for_Colon_0 : Diagnostics.Remove_unused_declaration_for_Colon_0,
-                map(elements, (e) => e.getText(sourceFile)).join(", ")
-              ];
-              return [
-                createDeleteFix(ts_textChanges_exports.ChangeTracker.with(context, (t) => deleteDestructuringElements(t, sourceFile, token.parent)), diagnostic)
-              ];
-            }
-            return [
-              createDeleteFix(ts_textChanges_exports.ChangeTracker.with(context, (t) => deleteDestructuring(context, t, sourceFile, token.parent)), Diagnostics.Remove_unused_destructuring_declaration)
-            ];
-          }
-          if (canDeleteEntireVariableStatement(sourceFile, token)) {
-            return [
-              createDeleteFix(ts_textChanges_exports.ChangeTracker.with(context, (t) => deleteEntireVariableStatement(t, sourceFile, token.parent)), Diagnostics.Remove_variable_statement)
-            ];
-          }
-          const result = [];
-          if (token.kind === 140 /* InferKeyword */) {
-            const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => changeInferToUnknown(t, sourceFile, token));
-            const name = cast(token.parent, isInferTypeNode).typeParameter.name.text;
-            result.push(createCodeFixAction(fixName3, changes, [Diagnostics.Replace_infer_0_with_unknown, name], fixIdInfer, Diagnostics.Replace_all_unused_infer_with_unknown));
-          } else {
-            const deletion = ts_textChanges_exports.ChangeTracker.with(context, (t) => tryDeleteDeclaration(
-              sourceFile,
-              token,
-              t,
-              checker,
-              sourceFiles,
-              program,
-              cancellationToken,
-              /*isFixAll*/
-              false
-            ));
-            if (deletion.length) {
-              const name = isComputedPropertyName(token.parent) ? token.parent : token;
-              result.push(createDeleteFix(deletion, [Diagnostics.Remove_unused_declaration_for_Colon_0, name.getText(sourceFile)]));
-            }
-          }
-          const prefix = ts_textChanges_exports.ChangeTracker.with(context, (t) => tryPrefixDeclaration(t, errorCode, sourceFile, token));
-          if (prefix.length) {
-            result.push(createCodeFixAction(fixName3, prefix, [Diagnostics.Prefix_0_with_an_underscore, token.getText(sourceFile)], fixIdPrefix, Diagnostics.Prefix_all_unused_declarations_with_where_possible));
-          }
-          return result;
-        },
-        fixIds: [fixIdPrefix, fixIdDelete, fixIdDeleteImports, fixIdInfer],
-        getAllCodeActions: (context) => {
-          const { sourceFile, program, cancellationToken } = context;
-          const checker = program.getTypeChecker();
-          const sourceFiles = program.getSourceFiles();
-          return codeFixAll(context, errorCodes41, (changes, diag2) => {
-            const token = getTokenAtPosition(sourceFile, diag2.start);
-            switch (context.fixId) {
-              case fixIdPrefix:
-                tryPrefixDeclaration(changes, diag2.code, sourceFile, token);
-                break;
-              case fixIdDeleteImports: {
-                const importDecl = tryGetFullImport(token);
-                if (importDecl) {
-                  changes.delete(sourceFile, importDecl);
-                } else if (isImport(token)) {
-                  tryDeleteDeclaration(
-                    sourceFile,
-                    token,
-                    changes,
-                    checker,
-                    sourceFiles,
-                    program,
-                    cancellationToken,
-                    /*isFixAll*/
-                    true
-                  );
-                }
-                break;
-              }
-              case fixIdDelete: {
-                if (token.kind === 140 /* InferKeyword */ || isImport(token)) {
-                  break;
-                } else if (isJSDocTemplateTag(token)) {
-                  changes.delete(sourceFile, token);
-                } else if (token.kind === 30 /* LessThanToken */) {
-                  deleteTypeParameters(changes, sourceFile, token);
-                } else if (isObjectBindingPattern(token.parent)) {
-                  if (token.parent.parent.initializer) {
-                    break;
-                  } else if (!isParameter(token.parent.parent) || isNotProvidedArguments(token.parent.parent, checker, sourceFiles)) {
-                    changes.delete(sourceFile, token.parent.parent);
-                  }
-                } else if (isArrayBindingPattern(token.parent.parent) && token.parent.parent.parent.initializer) {
-                  break;
-                } else if (canDeleteEntireVariableStatement(sourceFile, token)) {
-                  deleteEntireVariableStatement(changes, sourceFile, token.parent);
-                } else {
-                  tryDeleteDeclaration(
-                    sourceFile,
-                    token,
-                    changes,
-                    checker,
-                    sourceFiles,
-                    program,
-                    cancellationToken,
-                    /*isFixAll*/
-                    true
-                  );
-                }
-                break;
-              }
-              case fixIdInfer:
-                if (token.kind === 140 /* InferKeyword */) {
-                  changeInferToUnknown(changes, sourceFile, token);
-                }
-                break;
-              default:
-                Debug.fail(JSON.stringify(context.fixId));
-            }
-          });
+  function keywordCompletionData(keywordFilters, filterOutTsOnlyKeywords, isNewIdentifierLocation) {
+    return {
+      kind: 4 /* Keywords */,
+      keywordCompletions: getKeywordCompletions(keywordFilters, filterOutTsOnlyKeywords),
+      isNewIdentifierLocation
+    };
+  }
+  function keywordFiltersFromSyntaxKind(keywordCompletion) {
+    switch (keywordCompletion) {
+      case 156 /* TypeKeyword */:
+        return 8 /* TypeKeyword */;
+      default:
+        Debug.fail("Unknown mapping from SyntaxKind to KeywordCompletionFilters");
+    }
+  }
+  function getOptionalReplacementSpan(location) {
+    return (location == null ? void 0 : location.kind) === 80 /* Identifier */ ? createTextSpanFromNode(location) : void 0;
+  }
+  function completionInfoFromData(sourceFile, host, program, compilerOptions, log, completionData, preferences, formatContext, position, includeSymbol) {
+    const {
+      symbols,
+      contextToken,
+      completionKind,
+      isInSnippetScope,
+      isNewIdentifierLocation,
+      location,
+      propertyAccessToConvert,
+      keywordFilters,
+      symbolToOriginInfoMap,
+      recommendedCompletion,
+      isJsxInitializer,
+      isTypeOnlyLocation,
+      isJsxIdentifierExpected,
+      isRightOfOpenTag,
+      isRightOfDotOrQuestionDot,
+      importStatementCompletion,
+      insideJsDocTagTypeExpression,
+      symbolToSortTextMap,
+      hasUnresolvedAutoImports
+    } = completionData;
+    let literals = completionData.literals;
+    const checker = program.getTypeChecker();
+    if (getLanguageVariant(sourceFile.scriptKind) === 1 /* JSX */) {
+      const completionInfo = getJsxClosingTagCompletion(location, sourceFile);
+      if (completionInfo) {
+        return completionInfo;
+      }
+    }
+    const caseClause = findAncestor(contextToken, isCaseClause);
+    if (caseClause && (isCaseKeyword(contextToken) || isNodeDescendantOf(contextToken, caseClause.expression))) {
+      const tracker = newCaseClauseTracker(checker, caseClause.parent.clauses);
+      literals = literals.filter((literal) => !tracker.hasValue(literal));
+      symbols.forEach((symbol, i) => {
+        if (symbol.valueDeclaration && isEnumMember(symbol.valueDeclaration)) {
+          const value = checker.getConstantValue(symbol.valueDeclaration);
+          if (value !== void 0 && tracker.hasValue(value)) {
+            symbolToOriginInfoMap[i] = { kind: 256 /* Ignore */ };
+          }
         }
       });
     }
-  });
-
-  // src/services/codefixes/fixUnreachableCode.ts
-  function doChange26(changes, sourceFile, start, length2, errorCode) {
-    const token = getTokenAtPosition(sourceFile, start);
-    const statement = findAncestor(token, isStatement);
-    if (statement.getStart(sourceFile) !== token.getStart(sourceFile)) {
-      const logData = JSON.stringify({
-        statementKind: Debug.formatSyntaxKind(statement.kind),
-        tokenKind: Debug.formatSyntaxKind(token.kind),
-        errorCode,
-        start,
-        length: length2
-      });
-      Debug.fail("Token and statement should start at the same point. " + logData);
+    const entries = createSortedArray();
+    const isChecked = isCheckedFile(sourceFile, compilerOptions);
+    if (isChecked && !isNewIdentifierLocation && (!symbols || symbols.length === 0) && keywordFilters === 0 /* None */) {
+      return void 0;
     }
-    const container = (isBlock(statement.parent) ? statement.parent : statement).parent;
-    if (!isBlock(statement.parent) || statement === first(statement.parent.statements)) {
-      switch (container.kind) {
-        case 244 /* IfStatement */:
-          if (container.elseStatement) {
-            if (isBlock(statement.parent)) {
-              break;
-            } else {
-              changes.replaceNode(sourceFile, statement, factory.createBlock(emptyArray));
-            }
-            return;
-          }
-        case 246 /* WhileStatement */:
-        case 247 /* ForStatement */:
-          changes.delete(sourceFile, container);
-          return;
+    const uniqueNames = getCompletionEntriesFromSymbols(
+      symbols,
+      entries,
+      /*replacementToken*/
+      void 0,
+      contextToken,
+      location,
+      position,
+      sourceFile,
+      host,
+      program,
+      getEmitScriptTarget(compilerOptions),
+      log,
+      completionKind,
+      preferences,
+      compilerOptions,
+      formatContext,
+      isTypeOnlyLocation,
+      propertyAccessToConvert,
+      isJsxIdentifierExpected,
+      isJsxInitializer,
+      importStatementCompletion,
+      recommendedCompletion,
+      symbolToOriginInfoMap,
+      symbolToSortTextMap,
+      isJsxIdentifierExpected,
+      isRightOfOpenTag,
+      includeSymbol
+    );
+    if (keywordFilters !== 0 /* None */) {
+      for (const keywordEntry of getKeywordCompletions(keywordFilters, !insideJsDocTagTypeExpression && isSourceFileJS(sourceFile))) {
+        if (isTypeOnlyLocation && isTypeKeyword(stringToToken(keywordEntry.name)) || !isTypeOnlyLocation && isContextualKeywordInAutoImportableExpressionSpace(keywordEntry.name) || !uniqueNames.has(keywordEntry.name)) {
+          uniqueNames.add(keywordEntry.name);
+          insertSorted(
+            entries,
+            keywordEntry,
+            compareCompletionEntries,
+            /*allowDuplicates*/
+            true
+          );
+        }
       }
     }
-    if (isBlock(statement.parent)) {
-      const end = start + length2;
-      const lastStatement = Debug.checkDefined(lastWhere(sliceAfter(statement.parent.statements, statement), (s) => s.pos < end), "Some statement should be last");
-      changes.deleteNodeRange(sourceFile, statement, lastStatement);
-    } else {
-      changes.delete(sourceFile, statement);
+    for (const keywordEntry of getContextualKeywords(contextToken, position)) {
+      if (!uniqueNames.has(keywordEntry.name)) {
+        uniqueNames.add(keywordEntry.name);
+        insertSorted(
+          entries,
+          keywordEntry,
+          compareCompletionEntries,
+          /*allowDuplicates*/
+          true
+        );
+      }
     }
-  }
-  function lastWhere(a, pred) {
-    let last2;
-    for (const value of a) {
-      if (!pred(value))
-        break;
-      last2 = value;
+    for (const literal of literals) {
+      const literalEntry = createCompletionEntryForLiteral(sourceFile, preferences, literal);
+      uniqueNames.add(literalEntry.name);
+      insertSorted(
+        entries,
+        literalEntry,
+        compareCompletionEntries,
+        /*allowDuplicates*/
+        true
+      );
     }
-    return last2;
+    if (!isChecked) {
+      getJSCompletionEntries(sourceFile, location.pos, uniqueNames, getEmitScriptTarget(compilerOptions), entries);
+    }
+    let caseBlock;
+    if (preferences.includeCompletionsWithInsertText && contextToken && !isRightOfOpenTag && !isRightOfDotOrQuestionDot && (caseBlock = findAncestor(contextToken, isCaseBlock))) {
+      const cases = getExhaustiveCaseSnippets(caseBlock, sourceFile, preferences, compilerOptions, host, program, formatContext);
+      if (cases) {
+        entries.push(cases.entry);
+      }
+    }
+    return {
+      flags: completionData.flags,
+      isGlobalCompletion: isInSnippetScope,
+      isIncomplete: preferences.allowIncompleteCompletions && hasUnresolvedAutoImports ? true : void 0,
+      isMemberCompletion: isMemberCompletionKind(completionKind),
+      isNewIdentifierLocation,
+      optionalReplacementSpan: getOptionalReplacementSpan(location),
+      entries
+    };
   }
-  var fixId33, errorCodes42;
-  var init_fixUnreachableCode = __esm({
-    "src/services/codefixes/fixUnreachableCode.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_codefix();
-      fixId33 = "fixUnreachableCode";
-      errorCodes42 = [Diagnostics.Unreachable_code_detected.code];
-      registerCodeFix({
-        errorCodes: errorCodes42,
-        getCodeActions(context) {
-          const syntacticDiagnostics = context.program.getSyntacticDiagnostics(context.sourceFile, context.cancellationToken);
-          if (syntacticDiagnostics.length)
-            return;
-          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange26(t, context.sourceFile, context.span.start, context.span.length, context.errorCode));
-          return [createCodeFixAction(fixId33, changes, Diagnostics.Remove_unreachable_code, fixId33, Diagnostics.Remove_all_unreachable_code)];
-        },
-        fixIds: [fixId33],
-        getAllCodeActions: (context) => codeFixAll(context, errorCodes42, (changes, diag2) => doChange26(changes, diag2.file, diag2.start, diag2.length, diag2.code))
+  function isCheckedFile(sourceFile, compilerOptions) {
+    return !isSourceFileJS(sourceFile) || !!isCheckJsEnabledForFile(sourceFile, compilerOptions);
+  }
+  function getExhaustiveCaseSnippets(caseBlock, sourceFile, preferences, options, host, program, formatContext) {
+    const clauses = caseBlock.clauses;
+    const checker = program.getTypeChecker();
+    const switchType = checker.getTypeAtLocation(caseBlock.parent.expression);
+    if (switchType && switchType.isUnion() && every(switchType.types, (type) => type.isLiteral())) {
+      const tracker = newCaseClauseTracker(checker, clauses);
+      const target = getEmitScriptTarget(options);
+      const quotePreference = getQuotePreference(sourceFile, preferences);
+      const importAdder = ts_codefix_exports.createImportAdder(sourceFile, program, preferences, host);
+      const elements = [];
+      for (const type of switchType.types) {
+        if (type.flags & 1024 /* EnumLiteral */) {
+          Debug.assert(type.symbol, "An enum member type should have a symbol");
+          Debug.assert(type.symbol.parent, "An enum member type should have a parent symbol (the enum symbol)");
+          const enumValue = type.symbol.valueDeclaration && checker.getConstantValue(type.symbol.valueDeclaration);
+          if (enumValue !== void 0) {
+            if (tracker.hasValue(enumValue)) {
+              continue;
+            }
+            tracker.addValue(enumValue);
+          }
+          const typeNode = ts_codefix_exports.typeToAutoImportableTypeNode(checker, importAdder, type, caseBlock, target);
+          if (!typeNode) {
+            return void 0;
+          }
+          const expr = typeNodeToExpression(typeNode, target, quotePreference);
+          if (!expr) {
+            return void 0;
+          }
+          elements.push(expr);
+        } else if (!tracker.hasValue(type.value)) {
+          switch (typeof type.value) {
+            case "object":
+              elements.push(type.value.negative ? factory.createPrefixUnaryExpression(41 /* MinusToken */, factory.createBigIntLiteral({ negative: false, base10Value: type.value.base10Value })) : factory.createBigIntLiteral(type.value));
+              break;
+            case "number":
+              elements.push(type.value < 0 ? factory.createPrefixUnaryExpression(41 /* MinusToken */, factory.createNumericLiteral(-type.value)) : factory.createNumericLiteral(type.value));
+              break;
+            case "string":
+              elements.push(factory.createStringLiteral(type.value, quotePreference === 0 /* Single */));
+              break;
+          }
+        }
+      }
+      if (elements.length === 0) {
+        return void 0;
+      }
+      const newClauses = map(elements, (element) => factory.createCaseClause(element, []));
+      const newLineChar = getNewLineOrDefaultFromHost(host, formatContext == null ? void 0 : formatContext.options);
+      const printer = createSnippetPrinter({
+        removeComments: true,
+        module: options.module,
+        target: options.target,
+        newLine: getNewLineKind(newLineChar)
       });
+      const printNode = formatContext ? (node) => printer.printAndFormatNode(4 /* Unspecified */, node, sourceFile, formatContext) : (node) => printer.printNode(4 /* Unspecified */, node, sourceFile);
+      const insertText = map(newClauses, (clause, i) => {
+        if (preferences.includeCompletionsWithSnippetText) {
+          return `${printNode(clause)}$${i + 1}`;
+        }
+        return `${printNode(clause)}`;
+      }).join(newLineChar);
+      const firstClause = printer.printNode(4 /* Unspecified */, newClauses[0], sourceFile);
+      return {
+        entry: {
+          name: `${firstClause} ...`,
+          kind: "" /* unknown */,
+          sortText: SortText.GlobalsOrKeywords,
+          insertText,
+          hasAction: importAdder.hasFixes() || void 0,
+          source: "SwitchCases/" /* SwitchCases */,
+          isSnippet: preferences.includeCompletionsWithSnippetText ? true : void 0
+        },
+        importAdder
+      };
     }
-  });
-
-  // src/services/codefixes/fixUnusedLabel.ts
-  function doChange27(changes, sourceFile, start) {
-    const token = getTokenAtPosition(sourceFile, start);
-    const labeledStatement = cast(token.parent, isLabeledStatement);
-    const pos = token.getStart(sourceFile);
-    const statementPos = labeledStatement.statement.getStart(sourceFile);
-    const end = positionsAreOnSameLine(pos, statementPos, sourceFile) ? statementPos : skipTrivia(
-      sourceFile.text,
-      findChildOfKind(labeledStatement, 59 /* ColonToken */, sourceFile).end,
-      /*stopAfterLineBreak*/
-      true
-    );
-    changes.deleteRange(sourceFile, { pos, end });
+    return void 0;
   }
-  var fixId34, errorCodes43;
-  var init_fixUnusedLabel = __esm({
-    "src/services/codefixes/fixUnusedLabel.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_codefix();
-      fixId34 = "fixUnusedLabel";
-      errorCodes43 = [Diagnostics.Unused_label.code];
-      registerCodeFix({
-        errorCodes: errorCodes43,
-        getCodeActions(context) {
-          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange27(t, context.sourceFile, context.span.start));
-          return [createCodeFixAction(fixId34, changes, Diagnostics.Remove_unused_label, fixId34, Diagnostics.Remove_all_unused_labels)];
-        },
-        fixIds: [fixId34],
-        getAllCodeActions: (context) => codeFixAll(context, errorCodes43, (changes, diag2) => doChange27(changes, diag2.file, diag2.start))
-      });
+  function typeNodeToExpression(typeNode, languageVersion, quotePreference) {
+    switch (typeNode.kind) {
+      case 183 /* TypeReference */:
+        const typeName = typeNode.typeName;
+        return entityNameToExpression(typeName, languageVersion, quotePreference);
+      case 199 /* IndexedAccessType */:
+        const objectExpression = typeNodeToExpression(typeNode.objectType, languageVersion, quotePreference);
+        const indexExpression = typeNodeToExpression(typeNode.indexType, languageVersion, quotePreference);
+        return objectExpression && indexExpression && factory.createElementAccessExpression(objectExpression, indexExpression);
+      case 201 /* LiteralType */:
+        const literal = typeNode.literal;
+        switch (literal.kind) {
+          case 11 /* StringLiteral */:
+            return factory.createStringLiteral(literal.text, quotePreference === 0 /* Single */);
+          case 9 /* NumericLiteral */:
+            return factory.createNumericLiteral(literal.text, literal.numericLiteralFlags);
+        }
+        return void 0;
+      case 196 /* ParenthesizedType */:
+        const exp = typeNodeToExpression(typeNode.type, languageVersion, quotePreference);
+        return exp && (isIdentifier(exp) ? exp : factory.createParenthesizedExpression(exp));
+      case 186 /* TypeQuery */:
+        return entityNameToExpression(typeNode.exprName, languageVersion, quotePreference);
+      case 205 /* ImportType */:
+        Debug.fail(`We should not get an import type after calling 'codefix.typeToAutoImportableTypeNode'.`);
     }
-  });
-
-  // src/services/codefixes/fixJSDocTypes.ts
-  function doChange28(changes, sourceFile, oldTypeNode, newType, checker) {
-    changes.replaceNode(sourceFile, oldTypeNode, checker.typeToTypeNode(
-      newType,
-      /*enclosingDeclaration*/
-      oldTypeNode,
-      /*flags*/
-      void 0
-    ));
+    return void 0;
   }
-  function getInfo14(sourceFile, pos, checker) {
-    const decl = findAncestor(getTokenAtPosition(sourceFile, pos), isTypeContainer);
-    const typeNode = decl && decl.type;
-    return typeNode && { typeNode, type: getType(checker, typeNode) };
+  function entityNameToExpression(entityName, languageVersion, quotePreference) {
+    if (isIdentifier(entityName)) {
+      return entityName;
+    }
+    const unescapedName = unescapeLeadingUnderscores(entityName.right.escapedText);
+    if (canUsePropertyAccess(unescapedName, languageVersion)) {
+      return factory.createPropertyAccessExpression(
+        entityNameToExpression(entityName.left, languageVersion, quotePreference),
+        unescapedName
+      );
+    } else {
+      return factory.createElementAccessExpression(
+        entityNameToExpression(entityName.left, languageVersion, quotePreference),
+        factory.createStringLiteral(unescapedName, quotePreference === 0 /* Single */)
+      );
+    }
   }
-  function isTypeContainer(node) {
-    switch (node.kind) {
-      case 233 /* AsExpression */:
-      case 178 /* CallSignature */:
-      case 179 /* ConstructSignature */:
-      case 261 /* FunctionDeclaration */:
-      case 176 /* GetAccessor */:
-      case 180 /* IndexSignature */:
-      case 199 /* MappedType */:
-      case 173 /* MethodDeclaration */:
-      case 172 /* MethodSignature */:
-      case 168 /* Parameter */:
-      case 171 /* PropertyDeclaration */:
-      case 170 /* PropertySignature */:
-      case 177 /* SetAccessor */:
-      case 264 /* TypeAliasDeclaration */:
-      case 215 /* TypeAssertionExpression */:
-      case 259 /* VariableDeclaration */:
+  function isMemberCompletionKind(kind) {
+    switch (kind) {
+      case 0 /* ObjectPropertyDeclaration */:
+      case 3 /* MemberLike */:
+      case 2 /* PropertyAccess */:
         return true;
       default:
         return false;
     }
   }
-  function getType(checker, node) {
-    if (isJSDocNullableType(node)) {
-      const type = checker.getTypeFromTypeNode(node.type);
-      if (type === checker.getNeverType() || type === checker.getVoidType()) {
-        return type;
+  function getJsxClosingTagCompletion(location, sourceFile) {
+    const jsxClosingElement = findAncestor(location, (node) => {
+      switch (node.kind) {
+        case 287 /* JsxClosingElement */:
+          return true;
+        case 44 /* SlashToken */:
+        case 32 /* GreaterThanToken */:
+        case 80 /* Identifier */:
+        case 211 /* PropertyAccessExpression */:
+          return false;
+        default:
+          return "quit";
       }
-      return checker.getUnionType(
-        append([type, checker.getUndefinedType()], node.postfix ? void 0 : checker.getNullType())
-      );
+    });
+    if (jsxClosingElement) {
+      const hasClosingAngleBracket = !!findChildOfKind(jsxClosingElement, 32 /* GreaterThanToken */, sourceFile);
+      const tagName = jsxClosingElement.parent.openingElement.tagName;
+      const closingTag = tagName.getText(sourceFile);
+      const fullClosingTag = closingTag + (hasClosingAngleBracket ? "" : ">");
+      const replacementSpan = createTextSpanFromNode(jsxClosingElement.tagName);
+      const entry = {
+        name: fullClosingTag,
+        kind: "class" /* classElement */,
+        kindModifiers: void 0,
+        sortText: SortText.LocationPriority
+      };
+      return { isGlobalCompletion: false, isMemberCompletion: true, isNewIdentifierLocation: false, optionalReplacementSpan: replacementSpan, entries: [entry] };
     }
-    return checker.getTypeFromTypeNode(node);
+    return;
   }
-  var fixIdPlain, fixIdNullable, errorCodes44;
-  var init_fixJSDocTypes = __esm({
-    "src/services/codefixes/fixJSDocTypes.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_codefix();
-      fixIdPlain = "fixJSDocTypes_plain";
-      fixIdNullable = "fixJSDocTypes_nullable";
-      errorCodes44 = [
-        Diagnostics.JSDoc_types_can_only_be_used_inside_documentation_comments.code,
-        Diagnostics._0_at_the_end_of_a_type_is_not_valid_TypeScript_syntax_Did_you_mean_to_write_1.code,
-        Diagnostics._0_at_the_start_of_a_type_is_not_valid_TypeScript_syntax_Did_you_mean_to_write_1.code
-      ];
-      registerCodeFix({
-        errorCodes: errorCodes44,
-        getCodeActions(context) {
-          const { sourceFile } = context;
-          const checker = context.program.getTypeChecker();
-          const info = getInfo14(sourceFile, context.span.start, checker);
-          if (!info)
-            return void 0;
-          const { typeNode, type } = info;
-          const original = typeNode.getText(sourceFile);
-          const actions2 = [fix(type, fixIdPlain, Diagnostics.Change_all_jsdoc_style_types_to_TypeScript)];
-          if (typeNode.kind === 320 /* JSDocNullableType */) {
-            actions2.push(fix(type, fixIdNullable, Diagnostics.Change_all_jsdoc_style_types_to_TypeScript_and_add_undefined_to_nullable_types));
-          }
-          return actions2;
-          function fix(type2, fixId52, fixAllDescription) {
-            const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange28(t, sourceFile, typeNode, type2, checker));
-            return createCodeFixAction("jdocTypes", changes, [Diagnostics.Change_0_to_1, original, checker.typeToString(type2)], fixId52, fixAllDescription);
-          }
-        },
-        fixIds: [fixIdPlain, fixIdNullable],
-        getAllCodeActions(context) {
-          const { fixId: fixId52, program, sourceFile } = context;
-          const checker = program.getTypeChecker();
-          return codeFixAll(context, errorCodes44, (changes, err) => {
-            const info = getInfo14(err.file, err.start, checker);
-            if (!info)
-              return;
-            const { typeNode, type } = info;
-            const fixedType = typeNode.kind === 320 /* JSDocNullableType */ && fixId52 === fixIdNullable ? checker.getNullableType(type, 32768 /* Undefined */) : type;
-            doChange28(changes, sourceFile, typeNode, fixedType, checker);
-          });
-        }
-      });
-    }
-  });
-
-  // src/services/codefixes/fixMissingCallParentheses.ts
-  function doChange29(changes, sourceFile, name) {
-    changes.replaceNodeWithText(sourceFile, name, `${name.text}()`);
+  function getJSCompletionEntries(sourceFile, position, uniqueNames, target, entries) {
+    getNameTable(sourceFile).forEach((pos, name) => {
+      if (pos === position) {
+        return;
+      }
+      const realName = unescapeLeadingUnderscores(name);
+      if (!uniqueNames.has(realName) && isIdentifierText(realName, target)) {
+        uniqueNames.add(realName);
+        insertSorted(entries, {
+          name: realName,
+          kind: "warning" /* warning */,
+          kindModifiers: "",
+          sortText: SortText.JavascriptIdentifiers,
+          isFromUncheckedFile: true
+        }, compareCompletionEntries);
+      }
+    });
   }
-  function getCallName(sourceFile, start) {
-    const token = getTokenAtPosition(sourceFile, start);
-    if (isPropertyAccessExpression(token.parent)) {
-      let current = token.parent;
-      while (isPropertyAccessExpression(current.parent)) {
-        current = current.parent;
+  function completionNameForLiteral(sourceFile, preferences, literal) {
+    return typeof literal === "object" ? pseudoBigIntToString(literal) + "n" : isString(literal) ? quote(sourceFile, preferences, literal) : JSON.stringify(literal);
+  }
+  function createCompletionEntryForLiteral(sourceFile, preferences, literal) {
+    return { name: completionNameForLiteral(sourceFile, preferences, literal), kind: "string" /* string */, kindModifiers: "" /* none */, sortText: SortText.LocationPriority };
+  }
+  function createCompletionEntry(symbol, sortText, replacementToken, contextToken, location, position, sourceFile, host, program, name, needsConvertPropertyAccess, origin, recommendedCompletion, propertyAccessToConvert, isJsxInitializer, importStatementCompletion, useSemicolons, options, preferences, completionKind, formatContext, isJsxIdentifierExpected, isRightOfOpenTag, includeSymbol) {
+    var _a, _b;
+    let insertText;
+    let filterText;
+    let replacementSpan = getReplacementSpanForContextToken(replacementToken);
+    let data;
+    let isSnippet;
+    let source = getSourceFromOrigin(origin);
+    let sourceDisplay;
+    let hasAction;
+    let labelDetails;
+    const typeChecker = program.getTypeChecker();
+    const insertQuestionDot = origin && originIsNullableMember(origin);
+    const useBraces = origin && originIsSymbolMember(origin) || needsConvertPropertyAccess;
+    if (origin && originIsThisType(origin)) {
+      insertText = needsConvertPropertyAccess ? `this${insertQuestionDot ? "?." : ""}[${quotePropertyName(sourceFile, preferences, name)}]` : `this${insertQuestionDot ? "?." : "."}${name}`;
+    } else if ((useBraces || insertQuestionDot) && propertyAccessToConvert) {
+      insertText = useBraces ? needsConvertPropertyAccess ? `[${quotePropertyName(sourceFile, preferences, name)}]` : `[${name}]` : name;
+      if (insertQuestionDot || propertyAccessToConvert.questionDotToken) {
+        insertText = `?.${insertText}`;
       }
-      return current.name;
+      const dot = findChildOfKind(propertyAccessToConvert, 25 /* DotToken */, sourceFile) || findChildOfKind(propertyAccessToConvert, 29 /* QuestionDotToken */, sourceFile);
+      if (!dot) {
+        return void 0;
+      }
+      const end = startsWith(name, propertyAccessToConvert.name.text) ? propertyAccessToConvert.name.end : dot.end;
+      replacementSpan = createTextSpanFromBounds(dot.getStart(sourceFile), end);
     }
-    if (isIdentifier(token)) {
-      return token;
+    if (isJsxInitializer) {
+      if (insertText === void 0)
+        insertText = name;
+      insertText = `{${insertText}}`;
+      if (typeof isJsxInitializer !== "boolean") {
+        replacementSpan = createTextSpanFromNode(isJsxInitializer, sourceFile);
+      }
     }
-    return void 0;
-  }
-  var fixId35, errorCodes45;
-  var init_fixMissingCallParentheses = __esm({
-    "src/services/codefixes/fixMissingCallParentheses.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_codefix();
-      fixId35 = "fixMissingCallParentheses";
-      errorCodes45 = [
-        Diagnostics.This_condition_will_always_return_true_since_this_function_is_always_defined_Did_you_mean_to_call_it_instead.code
-      ];
-      registerCodeFix({
-        errorCodes: errorCodes45,
-        fixIds: [fixId35],
-        getCodeActions(context) {
-          const { sourceFile, span } = context;
-          const callName = getCallName(sourceFile, span.start);
-          if (!callName)
-            return;
-          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange29(t, context.sourceFile, callName));
-          return [createCodeFixAction(fixId35, changes, Diagnostics.Add_missing_call_parentheses, fixId35, Diagnostics.Add_all_missing_call_parentheses)];
-        },
-        getAllCodeActions: (context) => codeFixAll(context, errorCodes45, (changes, diag2) => {
-          const callName = getCallName(diag2.file, diag2.start);
-          if (callName)
-            doChange29(changes, diag2.file, callName);
-        })
-      });
+    if (origin && originIsPromise(origin) && propertyAccessToConvert) {
+      if (insertText === void 0)
+        insertText = name;
+      const precedingToken = findPrecedingToken(propertyAccessToConvert.pos, sourceFile);
+      let awaitText = "";
+      if (precedingToken && positionIsASICandidate(precedingToken.end, precedingToken.parent, sourceFile)) {
+        awaitText = ";";
+      }
+      awaitText += `(await ${propertyAccessToConvert.expression.getText()})`;
+      insertText = needsConvertPropertyAccess ? `${awaitText}${insertText}` : `${awaitText}${insertQuestionDot ? "?." : "."}${insertText}`;
+      const isInAwaitExpression = tryCast(propertyAccessToConvert.parent, isAwaitExpression);
+      const wrapNode = isInAwaitExpression ? propertyAccessToConvert.parent : propertyAccessToConvert.expression;
+      replacementSpan = createTextSpanFromBounds(wrapNode.getStart(sourceFile), propertyAccessToConvert.end);
     }
-  });
-
-  // src/services/codefixes/fixAwaitInSyncFunction.ts
-  function getReturnType(expr) {
-    if (expr.type) {
-      return expr.type;
+    if (originIsResolvedExport(origin)) {
+      sourceDisplay = [textPart(origin.moduleSpecifier)];
+      if (importStatementCompletion) {
+        ({ insertText, replacementSpan } = getInsertTextAndReplacementSpanForImportCompletion(name, importStatementCompletion, origin, useSemicolons, sourceFile, options, preferences));
+        isSnippet = preferences.includeCompletionsWithSnippetText ? true : void 0;
+      }
     }
-    if (isVariableDeclaration(expr.parent) && expr.parent.type && isFunctionTypeNode(expr.parent.type)) {
-      return expr.parent.type.type;
+    if ((origin == null ? void 0 : origin.kind) === 64 /* TypeOnlyAlias */) {
+      hasAction = true;
     }
-  }
-  function getNodes3(sourceFile, start) {
-    const token = getTokenAtPosition(sourceFile, start);
-    const containingFunction = getContainingFunction(token);
-    if (!containingFunction) {
-      return;
+    if (completionKind === 0 /* ObjectPropertyDeclaration */ && contextToken && ((_a = findPrecedingToken(contextToken.pos, sourceFile, contextToken)) == null ? void 0 : _a.kind) !== 28 /* CommaToken */) {
+      if (isMethodDeclaration(contextToken.parent.parent) || isGetAccessorDeclaration(contextToken.parent.parent) || isSetAccessorDeclaration(contextToken.parent.parent) || isSpreadAssignment(contextToken.parent) || ((_b = findAncestor(contextToken.parent, isPropertyAssignment)) == null ? void 0 : _b.getLastToken(sourceFile)) === contextToken || isShorthandPropertyAssignment(contextToken.parent) && getLineAndCharacterOfPosition(sourceFile, contextToken.getEnd()).line !== getLineAndCharacterOfPosition(sourceFile, position).line) {
+        source = "ObjectLiteralMemberWithComma/" /* ObjectLiteralMemberWithComma */;
+        hasAction = true;
+      }
     }
-    let insertBefore;
-    switch (containingFunction.kind) {
-      case 173 /* MethodDeclaration */:
-        insertBefore = containingFunction.name;
-        break;
-      case 261 /* FunctionDeclaration */:
-      case 217 /* FunctionExpression */:
-        insertBefore = findChildOfKind(containingFunction, 100 /* FunctionKeyword */, sourceFile);
-        break;
-      case 218 /* ArrowFunction */:
-        const kind = containingFunction.typeParameters ? 30 /* LessThanToken */ : 21 /* OpenParenToken */;
-        insertBefore = findChildOfKind(containingFunction, kind, sourceFile) || first(containingFunction.parameters);
-        break;
-      default:
-        return;
+    if (preferences.includeCompletionsWithClassMemberSnippets && preferences.includeCompletionsWithInsertText && completionKind === 3 /* MemberLike */ && isClassLikeMemberCompletion(symbol, location, sourceFile)) {
+      let importAdder;
+      const memberCompletionEntry = getEntryForMemberCompletion(host, program, options, preferences, name, symbol, location, position, contextToken, formatContext);
+      if (memberCompletionEntry) {
+        ({ insertText, filterText, isSnippet, importAdder } = memberCompletionEntry);
+        if (importAdder == null ? void 0 : importAdder.hasFixes()) {
+          hasAction = true;
+          source = "ClassMemberSnippet/" /* ClassMemberSnippet */;
+        }
+      } else {
+        return void 0;
+      }
     }
-    return insertBefore && {
-      insertBefore,
-      returnType: getReturnType(containingFunction)
+    if (origin && originIsObjectLiteralMethod(origin)) {
+      ({ insertText, isSnippet, labelDetails } = origin);
+      if (!preferences.useLabelDetailsInCompletionEntries) {
+        name = name + labelDetails.detail;
+        labelDetails = void 0;
+      }
+      source = "ObjectLiteralMethodSnippet/" /* ObjectLiteralMethodSnippet */;
+      sortText = SortText.SortBelow(sortText);
+    }
+    if (isJsxIdentifierExpected && !isRightOfOpenTag && preferences.includeCompletionsWithSnippetText && preferences.jsxAttributeCompletionStyle && preferences.jsxAttributeCompletionStyle !== "none" && !(isJsxAttribute(location.parent) && location.parent.initializer)) {
+      let useBraces2 = preferences.jsxAttributeCompletionStyle === "braces";
+      const type = typeChecker.getTypeOfSymbolAtLocation(symbol, location);
+      if (preferences.jsxAttributeCompletionStyle === "auto" && !(type.flags & 528 /* BooleanLike */) && !(type.flags & 1048576 /* Union */ && find(type.types, (type2) => !!(type2.flags & 528 /* BooleanLike */)))) {
+        if (type.flags & 402653316 /* StringLike */ || type.flags & 1048576 /* Union */ && every(type.types, (type2) => !!(type2.flags & (402653316 /* StringLike */ | 32768 /* Undefined */) || isStringAndEmptyAnonymousObjectIntersection(type2)))) {
+          insertText = `${escapeSnippetText(name)}=${quote(sourceFile, preferences, "$1")}`;
+          isSnippet = true;
+        } else {
+          useBraces2 = true;
+        }
+      }
+      if (useBraces2) {
+        insertText = `${escapeSnippetText(name)}={$1}`;
+        isSnippet = true;
+      }
+    }
+    if (insertText !== void 0 && !preferences.includeCompletionsWithInsertText) {
+      return void 0;
+    }
+    if (originIsExport(origin) || originIsResolvedExport(origin)) {
+      data = originToCompletionEntryData(origin);
+      hasAction = !importStatementCompletion;
+    }
+    const parentNamedImportOrExport = findAncestor(location, isNamedImportsOrExports);
+    if ((parentNamedImportOrExport == null ? void 0 : parentNamedImportOrExport.kind) === 275 /* NamedImports */) {
+      const possibleToken = stringToToken(name);
+      if (parentNamedImportOrExport && possibleToken && (possibleToken === 135 /* AwaitKeyword */ || isNonContextualKeyword(possibleToken))) {
+        insertText = `${name} as ${name}_`;
+      }
+    }
+    return {
+      name,
+      kind: ts_SymbolDisplay_exports.getSymbolKind(typeChecker, symbol, location),
+      kindModifiers: ts_SymbolDisplay_exports.getSymbolModifiers(typeChecker, symbol),
+      sortText,
+      source,
+      hasAction: hasAction ? true : void 0,
+      isRecommended: isRecommendedCompletionMatch(symbol, recommendedCompletion, typeChecker) || void 0,
+      insertText,
+      filterText,
+      replacementSpan,
+      sourceDisplay,
+      labelDetails,
+      isSnippet,
+      isPackageJsonImport: originIsPackageJsonImport(origin) || void 0,
+      isImportStatementCompletion: !!importStatementCompletion || void 0,
+      data,
+      ...includeSymbol ? { symbol } : void 0
     };
   }
-  function doChange30(changes, sourceFile, { insertBefore, returnType }) {
-    if (returnType) {
-      const entityName = getEntityNameFromTypeNode(returnType);
-      if (!entityName || entityName.kind !== 80 /* Identifier */ || entityName.text !== "Promise") {
-        changes.replaceNode(sourceFile, returnType, factory.createTypeReferenceNode("Promise", factory.createNodeArray([returnType])));
-      }
+  function isClassLikeMemberCompletion(symbol, location, sourceFile) {
+    if (isInJSFile(location)) {
+      return false;
     }
-    changes.insertModifierBefore(sourceFile, 134 /* AsyncKeyword */, insertBefore);
+    const memberFlags = 106500 /* ClassMember */ & 900095 /* EnumMemberExcludes */;
+    return !!(symbol.flags & memberFlags) && (isClassLike(location) || location.parent && location.parent.parent && isClassElement(location.parent) && location === location.parent.name && location.parent.getLastToken(sourceFile) === location.parent.name && isClassLike(location.parent.parent) || location.parent && isSyntaxList(location) && isClassLike(location.parent));
   }
-  var fixId36, errorCodes46;
-  var init_fixAwaitInSyncFunction = __esm({
-    "src/services/codefixes/fixAwaitInSyncFunction.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_codefix();
-      fixId36 = "fixAwaitInSyncFunction";
-      errorCodes46 = [
-        Diagnostics.await_expressions_are_only_allowed_within_async_functions_and_at_the_top_levels_of_modules.code,
-        Diagnostics.for_await_loops_are_only_allowed_within_async_functions_and_at_the_top_levels_of_modules.code,
-        Diagnostics.Cannot_find_name_0_Did_you_mean_to_write_this_in_an_async_function.code
-      ];
-      registerCodeFix({
-        errorCodes: errorCodes46,
-        getCodeActions(context) {
-          const { sourceFile, span } = context;
-          const nodes = getNodes3(sourceFile, span.start);
-          if (!nodes)
-            return void 0;
-          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange30(t, sourceFile, nodes));
-          return [createCodeFixAction(fixId36, changes, Diagnostics.Add_async_modifier_to_containing_function, fixId36, Diagnostics.Add_all_missing_async_modifiers)];
-        },
-        fixIds: [fixId36],
-        getAllCodeActions: function getAllCodeActionsToFixAwaitInSyncFunction(context) {
-          const seen = /* @__PURE__ */ new Map();
-          return codeFixAll(context, errorCodes46, (changes, diag2) => {
-            const nodes = getNodes3(diag2.file, diag2.start);
-            if (!nodes || !addToSeen(seen, getNodeId(nodes.insertBefore)))
-              return;
-            doChange30(changes, context.sourceFile, nodes);
-          });
-        }
-      });
+  function getEntryForMemberCompletion(host, program, options, preferences, name, symbol, location, position, contextToken, formatContext) {
+    const classLikeDeclaration = findAncestor(location, isClassLike);
+    if (!classLikeDeclaration) {
+      return void 0;
     }
-  });
-
-  // src/services/codefixes/fixPropertyOverrideAccessor.ts
-  function doChange31(file, start, length2, code, context) {
-    let startPosition;
-    let endPosition;
-    if (code === Diagnostics._0_is_defined_as_an_accessor_in_class_1_but_is_overridden_here_in_2_as_an_instance_property.code) {
-      startPosition = start;
-      endPosition = start + length2;
-    } else if (code === Diagnostics._0_is_defined_as_a_property_in_class_1_but_is_overridden_here_in_2_as_an_accessor.code) {
-      const checker = context.program.getTypeChecker();
-      const node = getTokenAtPosition(file, start).parent;
-      Debug.assert(isAccessor(node), "error span of fixPropertyOverrideAccessor should only be on an accessor");
-      const containingClass = node.parent;
-      Debug.assert(isClassLike(containingClass), "erroneous accessors should only be inside classes");
-      const base = singleOrUndefined(getAllSupers(containingClass, checker));
-      if (!base)
-        return [];
-      const name = unescapeLeadingUnderscores(getTextOfPropertyName(node.name));
-      const baseProp = checker.getPropertyOfType(checker.getTypeAtLocation(base), name);
-      if (!baseProp || !baseProp.valueDeclaration)
-        return [];
-      startPosition = baseProp.valueDeclaration.pos;
-      endPosition = baseProp.valueDeclaration.end;
-      file = getSourceFileOfNode(baseProp.valueDeclaration);
+    let isSnippet;
+    let insertText = name;
+    const filterText = name;
+    const checker = program.getTypeChecker();
+    const sourceFile = location.getSourceFile();
+    const printer = createSnippetPrinter({
+      removeComments: true,
+      module: options.module,
+      target: options.target,
+      omitTrailingSemicolon: false,
+      newLine: getNewLineKind(getNewLineOrDefaultFromHost(host, formatContext == null ? void 0 : formatContext.options))
+    });
+    const importAdder = ts_codefix_exports.createImportAdder(sourceFile, program, preferences, host);
+    let body;
+    if (preferences.includeCompletionsWithSnippetText) {
+      isSnippet = true;
+      const emptyStmt = factory.createEmptyStatement();
+      body = factory.createBlock(
+        [emptyStmt],
+        /*multiLine*/
+        true
+      );
+      setSnippetElement(emptyStmt, { kind: 0 /* TabStop */, order: 0 });
     } else {
-      Debug.fail("fixPropertyOverrideAccessor codefix got unexpected error code " + code);
+      body = factory.createBlock(
+        [],
+        /*multiLine*/
+        true
+      );
     }
-    return generateAccessorFromProperty(file, context.program, startPosition, endPosition, context, Diagnostics.Generate_get_and_set_accessors.message);
+    let modifiers = 0 /* None */;
+    const { modifiers: presentModifiers, range: eraseRange, decorators: presentDecorators } = getPresentModifiers(contextToken, sourceFile, position);
+    const isAbstract = presentModifiers & 64 /* Abstract */ && classLikeDeclaration.modifierFlagsCache & 64 /* Abstract */;
+    let completionNodes = [];
+    ts_codefix_exports.addNewNodeForMemberSymbol(
+      symbol,
+      classLikeDeclaration,
+      sourceFile,
+      { program, host },
+      preferences,
+      importAdder,
+      // `addNewNodeForMemberSymbol` calls this callback function for each new member node
+      // it adds for the given member symbol.
+      // We store these member nodes in the `completionNodes` array.
+      // Note: there might be:
+      //  - No nodes if `addNewNodeForMemberSymbol` cannot figure out a node for the member;
+      //  - One node;
+      //  - More than one node if the member is overloaded (e.g. a method with overload signatures).
+      (node) => {
+        let requiredModifiers = 0 /* None */;
+        if (isAbstract) {
+          requiredModifiers |= 64 /* Abstract */;
+        }
+        if (isClassElement(node) && checker.getMemberOverrideModifierStatus(classLikeDeclaration, node, symbol) === 1 /* NeedsOverride */) {
+          requiredModifiers |= 16 /* Override */;
+        }
+        if (!completionNodes.length) {
+          modifiers = node.modifierFlagsCache | requiredModifiers;
+        }
+        node = factory.replaceModifiers(node, modifiers);
+        completionNodes.push(node);
+      },
+      body,
+      ts_codefix_exports.PreserveOptionalFlags.Property,
+      !!isAbstract
+    );
+    if (completionNodes.length) {
+      const isMethod = symbol.flags & 8192 /* Method */;
+      let allowedModifiers = modifiers | 16 /* Override */ | 1 /* Public */;
+      if (!isMethod) {
+        allowedModifiers |= 128 /* Ambient */ | 8 /* Readonly */;
+      } else {
+        allowedModifiers |= 1024 /* Async */;
+      }
+      const allowedAndPresent = presentModifiers & allowedModifiers;
+      if (presentModifiers & ~allowedModifiers) {
+        return void 0;
+      }
+      if (modifiers & 4 /* Protected */ && allowedAndPresent & 1 /* Public */) {
+        modifiers &= ~4 /* Protected */;
+      }
+      if (allowedAndPresent !== 0 /* None */ && !(allowedAndPresent & 1 /* Public */)) {
+        modifiers &= ~1 /* Public */;
+      }
+      modifiers |= allowedAndPresent;
+      completionNodes = completionNodes.map((node) => factory.replaceModifiers(node, modifiers));
+      if (presentDecorators == null ? void 0 : presentDecorators.length) {
+        const lastNode = completionNodes[completionNodes.length - 1];
+        if (canHaveDecorators(lastNode)) {
+          completionNodes[completionNodes.length - 1] = factory.replaceDecoratorsAndModifiers(lastNode, presentDecorators.concat(getModifiers(lastNode) || []));
+        }
+      }
+      const format = 1 /* MultiLine */ | 131072 /* NoTrailingNewLine */;
+      if (formatContext) {
+        insertText = printer.printAndFormatSnippetList(
+          format,
+          factory.createNodeArray(completionNodes),
+          sourceFile,
+          formatContext
+        );
+      } else {
+        insertText = printer.printSnippetList(
+          format,
+          factory.createNodeArray(completionNodes),
+          sourceFile
+        );
+      }
+    }
+    return { insertText, filterText, isSnippet, importAdder, eraseRange };
   }
-  var errorCodes47, fixId37;
-  var init_fixPropertyOverrideAccessor = __esm({
-    "src/services/codefixes/fixPropertyOverrideAccessor.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_codefix();
-      errorCodes47 = [
-        Diagnostics._0_is_defined_as_an_accessor_in_class_1_but_is_overridden_here_in_2_as_an_instance_property.code,
-        Diagnostics._0_is_defined_as_a_property_in_class_1_but_is_overridden_here_in_2_as_an_accessor.code
-      ];
-      fixId37 = "fixPropertyOverrideAccessor";
-      registerCodeFix({
-        errorCodes: errorCodes47,
-        getCodeActions(context) {
-          const edits = doChange31(context.sourceFile, context.span.start, context.span.length, context.errorCode, context);
-          if (edits) {
-            return [createCodeFixAction(fixId37, edits, Diagnostics.Generate_get_and_set_accessors, fixId37, Diagnostics.Generate_get_and_set_accessors_for_all_overriding_properties)];
-          }
-        },
-        fixIds: [fixId37],
-        getAllCodeActions: (context) => codeFixAll(context, errorCodes47, (changes, diag2) => {
-          const edits = doChange31(diag2.file, diag2.start, diag2.length, diag2.code, context);
-          if (edits) {
-            for (const edit of edits) {
-              changes.pushRaw(context.sourceFile, edit);
-            }
-          }
-        })
-      });
+  function getPresentModifiers(contextToken, sourceFile, position) {
+    if (!contextToken || getLineAndCharacterOfPosition(sourceFile, position).line > getLineAndCharacterOfPosition(sourceFile, contextToken.getEnd()).line) {
+      return { modifiers: 0 /* None */ };
     }
-  });
-
-  // src/services/codefixes/inferFromUsage.ts
-  function getDiagnostic(errorCode, token) {
-    switch (errorCode) {
-      case Diagnostics.Parameter_0_implicitly_has_an_1_type.code:
-      case Diagnostics.Parameter_0_implicitly_has_an_1_type_but_a_better_type_may_be_inferred_from_usage.code:
-        return isSetAccessorDeclaration(getContainingFunction(token)) ? Diagnostics.Infer_type_of_0_from_usage : Diagnostics.Infer_parameter_types_from_usage;
-      case Diagnostics.Rest_parameter_0_implicitly_has_an_any_type.code:
-      case Diagnostics.Rest_parameter_0_implicitly_has_an_any_type_but_a_better_type_may_be_inferred_from_usage.code:
-        return Diagnostics.Infer_parameter_types_from_usage;
-      case Diagnostics.this_implicitly_has_type_any_because_it_does_not_have_a_type_annotation.code:
-        return Diagnostics.Infer_this_type_of_0_from_usage;
-      default:
-        return Diagnostics.Infer_type_of_0_from_usage;
+    let modifiers = 0 /* None */;
+    let decorators;
+    let contextMod;
+    const range = { pos: position, end: position };
+    if (isPropertyDeclaration(contextToken.parent) && contextToken.parent.modifiers) {
+      modifiers |= modifiersToFlags(contextToken.parent.modifiers) & 98303 /* Modifier */;
+      decorators = contextToken.parent.modifiers.filter(isDecorator) || [];
+      range.pos = Math.min(range.pos, contextToken.parent.modifiers.pos);
     }
+    if (contextMod = isModifierLike2(contextToken)) {
+      const contextModifierFlag = modifierToFlag(contextMod);
+      if (!(modifiers & contextModifierFlag)) {
+        modifiers |= contextModifierFlag;
+        range.pos = Math.min(range.pos, contextToken.pos);
+      }
+    }
+    return { modifiers, decorators, range: range.pos !== position ? range : void 0 };
   }
-  function mapSuggestionDiagnostic(errorCode) {
-    switch (errorCode) {
-      case Diagnostics.Variable_0_implicitly_has_type_1_in_some_locations_but_a_better_type_may_be_inferred_from_usage.code:
-        return Diagnostics.Variable_0_implicitly_has_type_1_in_some_locations_where_its_type_cannot_be_determined.code;
-      case Diagnostics.Variable_0_implicitly_has_an_1_type_but_a_better_type_may_be_inferred_from_usage.code:
-        return Diagnostics.Variable_0_implicitly_has_an_1_type.code;
-      case Diagnostics.Parameter_0_implicitly_has_an_1_type_but_a_better_type_may_be_inferred_from_usage.code:
-        return Diagnostics.Parameter_0_implicitly_has_an_1_type.code;
-      case Diagnostics.Rest_parameter_0_implicitly_has_an_any_type_but_a_better_type_may_be_inferred_from_usage.code:
-        return Diagnostics.Rest_parameter_0_implicitly_has_an_any_type.code;
-      case Diagnostics.Property_0_implicitly_has_type_any_but_a_better_type_for_its_get_accessor_may_be_inferred_from_usage.code:
-        return Diagnostics.Property_0_implicitly_has_type_any_because_its_get_accessor_lacks_a_return_type_annotation.code;
-      case Diagnostics._0_implicitly_has_an_1_return_type_but_a_better_type_may_be_inferred_from_usage.code:
-        return Diagnostics._0_which_lacks_return_type_annotation_implicitly_has_an_1_return_type.code;
-      case Diagnostics.Property_0_implicitly_has_type_any_but_a_better_type_for_its_set_accessor_may_be_inferred_from_usage.code:
-        return Diagnostics.Property_0_implicitly_has_type_any_because_its_set_accessor_lacks_a_parameter_type_annotation.code;
-      case Diagnostics.Member_0_implicitly_has_an_1_type_but_a_better_type_may_be_inferred_from_usage.code:
-        return Diagnostics.Member_0_implicitly_has_an_1_type.code;
+  function isModifierLike2(node) {
+    if (isModifier(node)) {
+      return node.kind;
     }
-    return errorCode;
+    if (isIdentifier(node)) {
+      const originalKeywordKind = identifierToKeywordKind(node);
+      if (originalKeywordKind && isModifierKind(originalKeywordKind)) {
+        return originalKeywordKind;
+      }
+    }
+    return void 0;
   }
-  function doChange32(changes, sourceFile, token, errorCode, program, cancellationToken, markSeen, host, preferences) {
-    if (!isParameterPropertyModifier(token.kind) && token.kind !== 80 /* Identifier */ && token.kind !== 26 /* DotDotDotToken */ && token.kind !== 110 /* ThisKeyword */) {
+  function getEntryForObjectLiteralMethodCompletion(symbol, name, enclosingDeclaration, program, host, options, preferences, formatContext) {
+    const isSnippet = preferences.includeCompletionsWithSnippetText || void 0;
+    let insertText = name;
+    const sourceFile = enclosingDeclaration.getSourceFile();
+    const method = createObjectLiteralMethod(symbol, enclosingDeclaration, sourceFile, program, host, preferences);
+    if (!method) {
       return void 0;
     }
-    const { parent: parent2 } = token;
-    const importAdder = createImportAdder(sourceFile, program, preferences, host);
-    errorCode = mapSuggestionDiagnostic(errorCode);
-    switch (errorCode) {
-      case Diagnostics.Member_0_implicitly_has_an_1_type.code:
-      case Diagnostics.Variable_0_implicitly_has_type_1_in_some_locations_where_its_type_cannot_be_determined.code:
-        if (isVariableDeclaration(parent2) && markSeen(parent2) || isPropertyDeclaration(parent2) || isPropertySignature(parent2)) {
-          annotateVariableDeclaration(changes, importAdder, sourceFile, parent2, program, host, cancellationToken);
-          importAdder.writeFixes(changes);
-          return parent2;
-        }
-        if (isPropertyAccessExpression(parent2)) {
-          const type = inferTypeForVariableFromUsage(parent2.name, program, cancellationToken);
-          const typeNode = getTypeNodeIfAccessible(type, parent2, program, host);
-          if (typeNode) {
-            const typeTag = factory.createJSDocTypeTag(
-              /*tagName*/
-              void 0,
-              factory.createJSDocTypeExpression(typeNode),
-              /*comment*/
-              void 0
-            );
-            changes.addJSDocTags(sourceFile, cast(parent2.parent.parent, isExpressionStatement), [typeTag]);
+    const printer = createSnippetPrinter({
+      removeComments: true,
+      module: options.module,
+      target: options.target,
+      omitTrailingSemicolon: false,
+      newLine: getNewLineKind(getNewLineOrDefaultFromHost(host, formatContext == null ? void 0 : formatContext.options))
+    });
+    if (formatContext) {
+      insertText = printer.printAndFormatSnippetList(16 /* CommaDelimited */ | 64 /* AllowTrailingComma */, factory.createNodeArray(
+        [method],
+        /*hasTrailingComma*/
+        true
+      ), sourceFile, formatContext);
+    } else {
+      insertText = printer.printSnippetList(16 /* CommaDelimited */ | 64 /* AllowTrailingComma */, factory.createNodeArray(
+        [method],
+        /*hasTrailingComma*/
+        true
+      ), sourceFile);
+    }
+    const signaturePrinter = createPrinter({
+      removeComments: true,
+      module: options.module,
+      target: options.target,
+      omitTrailingSemicolon: true
+    });
+    const methodSignature = factory.createMethodSignature(
+      /*modifiers*/
+      void 0,
+      /*name*/
+      "",
+      method.questionToken,
+      method.typeParameters,
+      method.parameters,
+      method.type
+    );
+    const labelDetails = { detail: signaturePrinter.printNode(4 /* Unspecified */, methodSignature, sourceFile) };
+    return { isSnippet, insertText, labelDetails };
+  }
+  function createObjectLiteralMethod(symbol, enclosingDeclaration, sourceFile, program, host, preferences) {
+    const declarations = symbol.getDeclarations();
+    if (!(declarations && declarations.length)) {
+      return void 0;
+    }
+    const checker = program.getTypeChecker();
+    const declaration = declarations[0];
+    const name = getSynthesizedDeepClone(
+      getNameOfDeclaration(declaration),
+      /*includeTrivia*/
+      false
+    );
+    const type = checker.getWidenedType(checker.getTypeOfSymbolAtLocation(symbol, enclosingDeclaration));
+    const quotePreference = getQuotePreference(sourceFile, preferences);
+    const builderFlags = 33554432 /* OmitThisParameter */ | (quotePreference === 0 /* Single */ ? 268435456 /* UseSingleQuotesForStringLiteralType */ : 0 /* None */);
+    switch (declaration.kind) {
+      case 171 /* PropertySignature */:
+      case 172 /* PropertyDeclaration */:
+      case 173 /* MethodSignature */:
+      case 174 /* MethodDeclaration */: {
+        let effectiveType = type.flags & 1048576 /* Union */ && type.types.length < 10 ? checker.getUnionType(type.types, 2 /* Subtype */) : type;
+        if (effectiveType.flags & 1048576 /* Union */) {
+          const functionTypes = filter(effectiveType.types, (type2) => checker.getSignaturesOfType(type2, 0 /* Call */).length > 0);
+          if (functionTypes.length === 1) {
+            effectiveType = functionTypes[0];
+          } else {
+            return void 0;
           }
-          importAdder.writeFixes(changes);
-          return parent2;
         }
-        return void 0;
-      case Diagnostics.Variable_0_implicitly_has_an_1_type.code: {
-        const symbol = program.getTypeChecker().getSymbolAtLocation(token);
-        if (symbol && symbol.valueDeclaration && isVariableDeclaration(symbol.valueDeclaration) && markSeen(symbol.valueDeclaration)) {
-          annotateVariableDeclaration(changes, importAdder, getSourceFileOfNode(symbol.valueDeclaration), symbol.valueDeclaration, program, host, cancellationToken);
-          importAdder.writeFixes(changes);
-          return symbol.valueDeclaration;
+        const signatures = checker.getSignaturesOfType(effectiveType, 0 /* Call */);
+        if (signatures.length !== 1) {
+          return void 0;
+        }
+        const typeNode = checker.typeToTypeNode(effectiveType, enclosingDeclaration, builderFlags, ts_codefix_exports.getNoopSymbolTrackerWithResolver({ program, host }));
+        if (!typeNode || !isFunctionTypeNode(typeNode)) {
+          return void 0;
+        }
+        let body;
+        if (preferences.includeCompletionsWithSnippetText) {
+          const emptyStmt = factory.createEmptyStatement();
+          body = factory.createBlock(
+            [emptyStmt],
+            /*multiLine*/
+            true
+          );
+          setSnippetElement(emptyStmt, { kind: 0 /* TabStop */, order: 0 });
+        } else {
+          body = factory.createBlock(
+            [],
+            /*multiLine*/
+            true
+          );
         }
+        const parameters = typeNode.parameters.map(
+          (typedParam) => factory.createParameterDeclaration(
+            /*modifiers*/
+            void 0,
+            typedParam.dotDotDotToken,
+            typedParam.name,
+            /*questionToken*/
+            void 0,
+            /*type*/
+            void 0,
+            typedParam.initializer
+          )
+        );
+        return factory.createMethodDeclaration(
+          /*modifiers*/
+          void 0,
+          /*asteriskToken*/
+          void 0,
+          name,
+          /*questionToken*/
+          void 0,
+          /*typeParameters*/
+          void 0,
+          parameters,
+          /*type*/
+          void 0,
+          body
+        );
+      }
+      default:
         return void 0;
+    }
+  }
+  function createSnippetPrinter(printerOptions) {
+    let escapes;
+    const baseWriter = ts_textChanges_exports.createWriter(getNewLineCharacter(printerOptions));
+    const printer = createPrinter(printerOptions, baseWriter);
+    const writer = {
+      ...baseWriter,
+      write: (s) => escapingWrite(s, () => baseWriter.write(s)),
+      nonEscapingWrite: baseWriter.write,
+      writeLiteral: (s) => escapingWrite(s, () => baseWriter.writeLiteral(s)),
+      writeStringLiteral: (s) => escapingWrite(s, () => baseWriter.writeStringLiteral(s)),
+      writeSymbol: (s, symbol) => escapingWrite(s, () => baseWriter.writeSymbol(s, symbol)),
+      writeParameter: (s) => escapingWrite(s, () => baseWriter.writeParameter(s)),
+      writeComment: (s) => escapingWrite(s, () => baseWriter.writeComment(s)),
+      writeProperty: (s) => escapingWrite(s, () => baseWriter.writeProperty(s))
+    };
+    return {
+      printSnippetList,
+      printAndFormatSnippetList,
+      printNode,
+      printAndFormatNode
+    };
+    function escapingWrite(s, write) {
+      const escaped = escapeSnippetText(s);
+      if (escaped !== s) {
+        const start = baseWriter.getTextPos();
+        write();
+        const end = baseWriter.getTextPos();
+        escapes = append(escapes || (escapes = []), { newText: escaped, span: { start, length: end - start } });
+      } else {
+        write();
       }
     }
-    const containingFunction = getContainingFunction(token);
-    if (containingFunction === void 0) {
-      return void 0;
+    function printSnippetList(format, list, sourceFile) {
+      const unescaped = printUnescapedSnippetList(format, list, sourceFile);
+      return escapes ? ts_textChanges_exports.applyChanges(unescaped, escapes) : unescaped;
     }
-    let declaration;
-    switch (errorCode) {
-      case Diagnostics.Parameter_0_implicitly_has_an_1_type.code:
-        if (isSetAccessorDeclaration(containingFunction)) {
-          annotateSetAccessor(changes, importAdder, sourceFile, containingFunction, program, host, cancellationToken);
-          declaration = containingFunction;
-          break;
-        }
-      case Diagnostics.Rest_parameter_0_implicitly_has_an_any_type.code:
-        if (markSeen(containingFunction)) {
-          const param = cast(parent2, isParameter);
-          annotateParameters(changes, importAdder, sourceFile, param, containingFunction, program, host, cancellationToken);
-          declaration = param;
-        }
-        break;
-      case Diagnostics.Property_0_implicitly_has_type_any_because_its_get_accessor_lacks_a_return_type_annotation.code:
-      case Diagnostics._0_which_lacks_return_type_annotation_implicitly_has_an_1_return_type.code:
-        if (isGetAccessorDeclaration(containingFunction) && isIdentifier(containingFunction.name)) {
-          annotate(changes, importAdder, sourceFile, containingFunction, inferTypeForVariableFromUsage(containingFunction.name, program, cancellationToken), program, host);
-          declaration = containingFunction;
-        }
-        break;
-      case Diagnostics.Property_0_implicitly_has_type_any_because_its_set_accessor_lacks_a_parameter_type_annotation.code:
-        if (isSetAccessorDeclaration(containingFunction)) {
-          annotateSetAccessor(changes, importAdder, sourceFile, containingFunction, program, host, cancellationToken);
-          declaration = containingFunction;
+    function printUnescapedSnippetList(format, list, sourceFile) {
+      escapes = void 0;
+      writer.clear();
+      printer.writeList(format, list, sourceFile, writer);
+      return writer.getText();
+    }
+    function printAndFormatSnippetList(format, list, sourceFile, formatContext) {
+      const syntheticFile = {
+        text: printUnescapedSnippetList(
+          format,
+          list,
+          sourceFile
+        ),
+        getLineAndCharacterOfPosition(pos) {
+          return getLineAndCharacterOfPosition(this, pos);
         }
-        break;
-      case Diagnostics.this_implicitly_has_type_any_because_it_does_not_have_a_type_annotation.code:
-        if (ts_textChanges_exports.isThisTypeAnnotatable(containingFunction) && markSeen(containingFunction)) {
-          annotateThis(changes, sourceFile, containingFunction, program, host, cancellationToken);
-          declaration = containingFunction;
+      };
+      const formatOptions = getFormatCodeSettingsForWriting(formatContext, sourceFile);
+      const changes = flatMap(list, (node) => {
+        const nodeWithPos = ts_textChanges_exports.assignPositionsToNode(node);
+        return ts_formatting_exports.formatNodeGivenIndentation(
+          nodeWithPos,
+          syntheticFile,
+          sourceFile.languageVariant,
+          /* indentation */
+          0,
+          /* delta */
+          0,
+          { ...formatContext, options: formatOptions }
+        );
+      });
+      const allChanges = escapes ? stableSort(concatenate(changes, escapes), (a, b) => compareTextSpans(a.span, b.span)) : changes;
+      return ts_textChanges_exports.applyChanges(syntheticFile.text, allChanges);
+    }
+    function printNode(hint, node, sourceFile) {
+      const unescaped = printUnescapedNode(hint, node, sourceFile);
+      return escapes ? ts_textChanges_exports.applyChanges(unescaped, escapes) : unescaped;
+    }
+    function printUnescapedNode(hint, node, sourceFile) {
+      escapes = void 0;
+      writer.clear();
+      printer.writeNode(hint, node, sourceFile, writer);
+      return writer.getText();
+    }
+    function printAndFormatNode(hint, node, sourceFile, formatContext) {
+      const syntheticFile = {
+        text: printUnescapedNode(
+          hint,
+          node,
+          sourceFile
+        ),
+        getLineAndCharacterOfPosition(pos) {
+          return getLineAndCharacterOfPosition(this, pos);
         }
-        break;
-      default:
-        return Debug.fail(String(errorCode));
+      };
+      const formatOptions = getFormatCodeSettingsForWriting(formatContext, sourceFile);
+      const nodeWithPos = ts_textChanges_exports.assignPositionsToNode(node);
+      const changes = ts_formatting_exports.formatNodeGivenIndentation(
+        nodeWithPos,
+        syntheticFile,
+        sourceFile.languageVariant,
+        /* indentation */
+        0,
+        /* delta */
+        0,
+        { ...formatContext, options: formatOptions }
+      );
+      const allChanges = escapes ? stableSort(concatenate(changes, escapes), (a, b) => compareTextSpans(a.span, b.span)) : changes;
+      return ts_textChanges_exports.applyChanges(syntheticFile.text, allChanges);
     }
-    importAdder.writeFixes(changes);
-    return declaration;
   }
-  function annotateVariableDeclaration(changes, importAdder, sourceFile, declaration, program, host, cancellationToken) {
-    if (isIdentifier(declaration.name)) {
-      annotate(changes, importAdder, sourceFile, declaration, inferTypeForVariableFromUsage(declaration.name, program, cancellationToken), program, host);
+  function originToCompletionEntryData(origin) {
+    const ambientModuleName = origin.fileName ? void 0 : stripQuotes(origin.moduleSymbol.name);
+    const isPackageJsonImport = origin.isFromPackageJson ? true : void 0;
+    if (originIsResolvedExport(origin)) {
+      const resolvedData = {
+        exportName: origin.exportName,
+        exportMapKey: origin.exportMapKey,
+        moduleSpecifier: origin.moduleSpecifier,
+        ambientModuleName,
+        fileName: origin.fileName,
+        isPackageJsonImport
+      };
+      return resolvedData;
     }
+    const unresolvedData = {
+      exportName: origin.exportName,
+      exportMapKey: origin.exportMapKey,
+      fileName: origin.fileName,
+      ambientModuleName: origin.fileName ? void 0 : stripQuotes(origin.moduleSymbol.name),
+      isPackageJsonImport: origin.isFromPackageJson ? true : void 0
+    };
+    return unresolvedData;
   }
-  function annotateParameters(changes, importAdder, sourceFile, parameterDeclaration, containingFunction, program, host, cancellationToken) {
-    if (!isIdentifier(parameterDeclaration.name)) {
-      return;
+  function completionEntryDataToSymbolOriginInfo(data, completionName, moduleSymbol) {
+    const isDefaultExport = data.exportName === "default" /* Default */;
+    const isFromPackageJson = !!data.isPackageJsonImport;
+    if (completionEntryDataIsResolved(data)) {
+      const resolvedOrigin = {
+        kind: 32 /* ResolvedExport */,
+        exportName: data.exportName,
+        exportMapKey: data.exportMapKey,
+        moduleSpecifier: data.moduleSpecifier,
+        symbolName: completionName,
+        fileName: data.fileName,
+        moduleSymbol,
+        isDefaultExport,
+        isFromPackageJson
+      };
+      return resolvedOrigin;
     }
-    const parameterInferences = inferTypeForParametersFromUsage(containingFunction, sourceFile, program, cancellationToken);
-    Debug.assert(containingFunction.parameters.length === parameterInferences.length, "Parameter count and inference count should match");
-    if (isInJSFile(containingFunction)) {
-      annotateJSDocParameters(changes, sourceFile, parameterInferences, program, host);
-    } else {
-      const needParens = isArrowFunction(containingFunction) && !findChildOfKind(containingFunction, 21 /* OpenParenToken */, sourceFile);
-      if (needParens)
-        changes.insertNodeBefore(sourceFile, first(containingFunction.parameters), factory.createToken(21 /* OpenParenToken */));
-      for (const { declaration, type } of parameterInferences) {
-        if (declaration && !declaration.type && !declaration.initializer) {
-          annotate(changes, importAdder, sourceFile, declaration, type, program, host);
-        }
-      }
-      if (needParens)
-        changes.insertNodeAfter(sourceFile, last(containingFunction.parameters), factory.createToken(22 /* CloseParenToken */));
+    const unresolvedOrigin = {
+      kind: 4 /* Export */,
+      exportName: data.exportName,
+      exportMapKey: data.exportMapKey,
+      symbolName: completionName,
+      fileName: data.fileName,
+      moduleSymbol,
+      isDefaultExport,
+      isFromPackageJson
+    };
+    return unresolvedOrigin;
+  }
+  function getInsertTextAndReplacementSpanForImportCompletion(name, importStatementCompletion, origin, useSemicolons, sourceFile, options, preferences) {
+    const replacementSpan = importStatementCompletion.replacementSpan;
+    const quotedModuleSpecifier = escapeSnippetText(quote(sourceFile, preferences, origin.moduleSpecifier));
+    const exportKind = origin.isDefaultExport ? 1 /* Default */ : origin.exportName === "export=" /* ExportEquals */ ? 2 /* ExportEquals */ : 0 /* Named */;
+    const tabStop = preferences.includeCompletionsWithSnippetText ? "$1" : "";
+    const importKind = ts_codefix_exports.getImportKind(
+      sourceFile,
+      exportKind,
+      options,
+      /*forceImportKeyword*/
+      true
+    );
+    const isImportSpecifierTypeOnly = importStatementCompletion.couldBeTypeOnlyImportSpecifier;
+    const topLevelTypeOnlyText = importStatementCompletion.isTopLevelTypeOnly ? ` ${tokenToString(156 /* TypeKeyword */)} ` : " ";
+    const importSpecifierTypeOnlyText = isImportSpecifierTypeOnly ? `${tokenToString(156 /* TypeKeyword */)} ` : "";
+    const suffix = useSemicolons ? ";" : "";
+    switch (importKind) {
+      case 3 /* CommonJS */:
+        return { replacementSpan, insertText: `import${topLevelTypeOnlyText}${escapeSnippetText(name)}${tabStop} = require(${quotedModuleSpecifier})${suffix}` };
+      case 1 /* Default */:
+        return { replacementSpan, insertText: `import${topLevelTypeOnlyText}${escapeSnippetText(name)}${tabStop} from ${quotedModuleSpecifier}${suffix}` };
+      case 2 /* Namespace */:
+        return { replacementSpan, insertText: `import${topLevelTypeOnlyText}* as ${escapeSnippetText(name)} from ${quotedModuleSpecifier}${suffix}` };
+      case 0 /* Named */:
+        return { replacementSpan, insertText: `import${topLevelTypeOnlyText}{ ${importSpecifierTypeOnlyText}${escapeSnippetText(name)}${tabStop} } from ${quotedModuleSpecifier}${suffix}` };
     }
   }
-  function annotateThis(changes, sourceFile, containingFunction, program, host, cancellationToken) {
-    const references = getFunctionReferences(containingFunction, sourceFile, program, cancellationToken);
-    if (!references || !references.length) {
-      return;
+  function quotePropertyName(sourceFile, preferences, name) {
+    if (/^\d+$/.test(name)) {
+      return name;
     }
-    const thisInference = inferTypeFromReferences(program, references, cancellationToken).thisParameter();
-    const typeNode = getTypeNodeIfAccessible(thisInference, containingFunction, program, host);
-    if (!typeNode) {
-      return;
+    return quote(sourceFile, preferences, name);
+  }
+  function isRecommendedCompletionMatch(localSymbol, recommendedCompletion, checker) {
+    return localSymbol === recommendedCompletion || !!(localSymbol.flags & 1048576 /* ExportValue */) && checker.getExportSymbolOfSymbol(localSymbol) === recommendedCompletion;
+  }
+  function getSourceFromOrigin(origin) {
+    if (originIsExport(origin)) {
+      return stripQuotes(origin.moduleSymbol.name);
     }
-    if (isInJSFile(containingFunction)) {
-      annotateJSDocThis(changes, sourceFile, containingFunction, typeNode);
-    } else {
-      changes.tryInsertThisTypeAnnotation(sourceFile, containingFunction, typeNode);
+    if (originIsResolvedExport(origin)) {
+      return origin.moduleSpecifier;
+    }
+    if ((origin == null ? void 0 : origin.kind) === 1 /* ThisType */) {
+      return "ThisProperty/" /* ThisProperty */;
+    }
+    if ((origin == null ? void 0 : origin.kind) === 64 /* TypeOnlyAlias */) {
+      return "TypeOnlyAlias/" /* TypeOnlyAlias */;
     }
   }
-  function annotateJSDocThis(changes, sourceFile, containingFunction, typeNode) {
-    changes.addJSDocTags(sourceFile, containingFunction, [
-      factory.createJSDocThisTag(
-        /*tagName*/
-        void 0,
-        factory.createJSDocTypeExpression(typeNode)
-      )
-    ]);
-  }
-  function annotateSetAccessor(changes, importAdder, sourceFile, setAccessorDeclaration, program, host, cancellationToken) {
-    const param = firstOrUndefined(setAccessorDeclaration.parameters);
-    if (param && isIdentifier(setAccessorDeclaration.name) && isIdentifier(param.name)) {
-      let type = inferTypeForVariableFromUsage(setAccessorDeclaration.name, program, cancellationToken);
-      if (type === program.getTypeChecker().getAnyType()) {
-        type = inferTypeForVariableFromUsage(param.name, program, cancellationToken);
+  function getCompletionEntriesFromSymbols(symbols, entries, replacementToken, contextToken, location, position, sourceFile, host, program, target, log, kind, preferences, compilerOptions, formatContext, isTypeOnlyLocation, propertyAccessToConvert, jsxIdentifierExpected, isJsxInitializer, importStatementCompletion, recommendedCompletion, symbolToOriginInfoMap, symbolToSortTextMap, isJsxIdentifierExpected, isRightOfOpenTag, includeSymbol = false) {
+    const start = timestamp();
+    const variableOrParameterDeclaration = getVariableOrParameterDeclaration(contextToken, location);
+    const useSemicolons = probablyUsesSemicolons(sourceFile);
+    const typeChecker = program.getTypeChecker();
+    const uniques = /* @__PURE__ */ new Map();
+    for (let i = 0; i < symbols.length; i++) {
+      const symbol = symbols[i];
+      const origin = symbolToOriginInfoMap == null ? void 0 : symbolToOriginInfoMap[i];
+      const info = getCompletionEntryDisplayNameForSymbol(symbol, target, origin, kind, !!jsxIdentifierExpected);
+      if (!info || uniques.get(info.name) && (!origin || !originIsObjectLiteralMethod(origin)) || kind === 1 /* Global */ && symbolToSortTextMap && !shouldIncludeSymbol(symbol, symbolToSortTextMap)) {
+        continue;
       }
-      if (isInJSFile(setAccessorDeclaration)) {
-        annotateJSDocParameters(changes, sourceFile, [{ declaration: param, type }], program, host);
-      } else {
-        annotate(changes, importAdder, sourceFile, param, type, program, host);
+      const { name, needsConvertPropertyAccess } = info;
+      const originalSortText = (symbolToSortTextMap == null ? void 0 : symbolToSortTextMap[getSymbolId(symbol)]) ?? SortText.LocationPriority;
+      const sortText = isDeprecated(symbol, typeChecker) ? SortText.Deprecated(originalSortText) : originalSortText;
+      const entry = createCompletionEntry(
+        symbol,
+        sortText,
+        replacementToken,
+        contextToken,
+        location,
+        position,
+        sourceFile,
+        host,
+        program,
+        name,
+        needsConvertPropertyAccess,
+        origin,
+        recommendedCompletion,
+        propertyAccessToConvert,
+        isJsxInitializer,
+        importStatementCompletion,
+        useSemicolons,
+        compilerOptions,
+        preferences,
+        kind,
+        formatContext,
+        isJsxIdentifierExpected,
+        isRightOfOpenTag,
+        includeSymbol
+      );
+      if (!entry) {
+        continue;
       }
+      const shouldShadowLaterSymbols = (!origin || originIsTypeOnlyAlias(origin)) && !(symbol.parent === void 0 && !some(symbol.declarations, (d) => d.getSourceFile() === location.getSourceFile()));
+      uniques.set(name, shouldShadowLaterSymbols);
+      insertSorted(
+        entries,
+        entry,
+        compareCompletionEntries,
+        /*allowDuplicates*/
+        true
+      );
     }
-  }
-  function annotate(changes, importAdder, sourceFile, declaration, type, program, host) {
-    const typeNode = getTypeNodeIfAccessible(type, declaration, program, host);
-    if (typeNode) {
-      if (isInJSFile(sourceFile) && declaration.kind !== 170 /* PropertySignature */) {
-        const parent2 = isVariableDeclaration(declaration) ? tryCast(declaration.parent.parent, isVariableStatement) : declaration;
-        if (!parent2) {
-          return;
+    log("getCompletionsAtPosition: getCompletionEntriesFromSymbols: " + (timestamp() - start));
+    return {
+      has: (name) => uniques.has(name),
+      add: (name) => uniques.set(name, true)
+    };
+    function shouldIncludeSymbol(symbol, symbolToSortTextMap2) {
+      var _a;
+      let allFlags = symbol.flags;
+      if (!isSourceFile(location)) {
+        if (isExportAssignment(location.parent)) {
+          return true;
+        }
+        if (tryCast(variableOrParameterDeclaration, isVariableDeclaration) && symbol.valueDeclaration === variableOrParameterDeclaration) {
+          return false;
+        }
+        const symbolDeclaration = symbol.valueDeclaration ?? ((_a = symbol.declarations) == null ? void 0 : _a[0]);
+        if (variableOrParameterDeclaration && symbolDeclaration && (isTypeParameterDeclaration(variableOrParameterDeclaration) && isTypeParameterDeclaration(symbolDeclaration) || isParameter(variableOrParameterDeclaration) && isParameter(symbolDeclaration))) {
+          const symbolDeclarationPos = symbolDeclaration.pos;
+          const parameters = isParameter(variableOrParameterDeclaration) ? variableOrParameterDeclaration.parent.parameters : isInferTypeNode(variableOrParameterDeclaration.parent) ? void 0 : variableOrParameterDeclaration.parent.typeParameters;
+          if (symbolDeclarationPos >= variableOrParameterDeclaration.pos && parameters && symbolDeclarationPos < parameters.end) {
+            return false;
+          }
+        }
+        const symbolOrigin = skipAlias(symbol, typeChecker);
+        if (!!sourceFile.externalModuleIndicator && !compilerOptions.allowUmdGlobalAccess && symbolToSortTextMap2[getSymbolId(symbol)] === SortText.GlobalsOrKeywords && (symbolToSortTextMap2[getSymbolId(symbolOrigin)] === SortText.AutoImportSuggestions || symbolToSortTextMap2[getSymbolId(symbolOrigin)] === SortText.LocationPriority)) {
+          return false;
+        }
+        allFlags |= getCombinedLocalAndExportSymbolFlags(symbolOrigin);
+        if (isInRightSideOfInternalImportEqualsDeclaration(location)) {
+          return !!(allFlags & 1920 /* Namespace */);
+        }
+        if (isTypeOnlyLocation) {
+          return symbolCanBeReferencedAtTypeLocation(symbol, typeChecker);
         }
-        const typeExpression = factory.createJSDocTypeExpression(typeNode);
-        const typeTag = isGetAccessorDeclaration(declaration) ? factory.createJSDocReturnTag(
-          /*tagName*/
-          void 0,
-          typeExpression,
-          /*comment*/
-          void 0
-        ) : factory.createJSDocTypeTag(
-          /*tagName*/
-          void 0,
-          typeExpression,
-          /*comment*/
-          void 0
-        );
-        changes.addJSDocTags(sourceFile, parent2, [typeTag]);
-      } else if (!tryReplaceImportTypeNodeWithAutoImport(typeNode, declaration, sourceFile, changes, importAdder, getEmitScriptTarget(program.getCompilerOptions()))) {
-        changes.tryInsertTypeAnnotation(sourceFile, declaration, typeNode);
       }
+      return !!(allFlags & 111551 /* Value */);
     }
   }
-  function tryReplaceImportTypeNodeWithAutoImport(typeNode, declaration, sourceFile, changes, importAdder, scriptTarget) {
-    const importableReference = tryGetAutoImportableReferenceFromTypeNode(typeNode, scriptTarget);
-    if (importableReference && changes.tryInsertTypeAnnotation(sourceFile, declaration, importableReference.typeNode)) {
-      forEach(importableReference.symbols, (s) => importAdder.addImportFromExportedSymbol(
-        s,
-        /*isValidTypeOnlyUseSite*/
-        true
-      ));
-      return true;
+  function getLabelCompletionAtPosition(node) {
+    const entries = getLabelStatementCompletions(node);
+    if (entries.length) {
+      return { isGlobalCompletion: false, isMemberCompletion: false, isNewIdentifierLocation: false, entries };
     }
-    return false;
   }
-  function annotateJSDocParameters(changes, sourceFile, parameterInferences, program, host) {
-    const signature = parameterInferences.length && parameterInferences[0].declaration.parent;
-    if (!signature) {
-      return;
-    }
-    const inferences = mapDefined(parameterInferences, (inference) => {
-      const param = inference.declaration;
-      if (param.initializer || getJSDocType(param) || !isIdentifier(param.name)) {
-        return;
+  function getLabelStatementCompletions(node) {
+    const entries = [];
+    const uniques = /* @__PURE__ */ new Map();
+    let current = node;
+    while (current) {
+      if (isFunctionLike(current)) {
+        break;
       }
-      const typeNode = inference.type && getTypeNodeIfAccessible(inference.type, param, program, host);
-      if (typeNode) {
-        const name = factory.cloneNode(param.name);
-        setEmitFlags(name, 3072 /* NoComments */ | 4096 /* NoNestedComments */);
-        return { name: factory.cloneNode(param.name), param, isOptional: !!inference.isOptional, typeNode };
+      if (isLabeledStatement(current)) {
+        const name = current.label.text;
+        if (!uniques.has(name)) {
+          uniques.set(name, true);
+          entries.push({
+            name,
+            kindModifiers: "" /* none */,
+            kind: "label" /* label */,
+            sortText: SortText.LocationPriority
+          });
+        }
       }
-    });
-    if (!inferences.length) {
-      return;
+      current = current.parent;
     }
-    if (isArrowFunction(signature) || isFunctionExpression(signature)) {
-      const needParens = isArrowFunction(signature) && !findChildOfKind(signature, 21 /* OpenParenToken */, sourceFile);
-      if (needParens) {
-        changes.insertNodeBefore(sourceFile, first(signature.parameters), factory.createToken(21 /* OpenParenToken */));
-      }
-      forEach(inferences, ({ typeNode, param }) => {
-        const typeTag = factory.createJSDocTypeTag(
-          /*tagName*/
-          void 0,
-          factory.createJSDocTypeExpression(typeNode)
-        );
-        const jsDoc = factory.createJSDocComment(
-          /*comment*/
-          void 0,
-          [typeTag]
-        );
-        changes.insertNodeAt(sourceFile, param.getStart(sourceFile), jsDoc, { suffix: " " });
-      });
-      if (needParens) {
-        changes.insertNodeAfter(sourceFile, last(signature.parameters), factory.createToken(22 /* CloseParenToken */));
+    return entries;
+  }
+  function getSymbolCompletionFromEntryId(program, log, sourceFile, position, entryId, host, preferences) {
+    if (entryId.source === "SwitchCases/" /* SwitchCases */) {
+      return { type: "cases" };
+    }
+    if (entryId.data) {
+      const autoImport = getAutoImportSymbolFromCompletionEntryData(entryId.name, entryId.data, program, host);
+      if (autoImport) {
+        const { contextToken: contextToken2, previousToken: previousToken2 } = getRelevantTokens(position, sourceFile);
+        return {
+          type: "symbol",
+          symbol: autoImport.symbol,
+          location: getTouchingPropertyName(sourceFile, position),
+          previousToken: previousToken2,
+          contextToken: contextToken2,
+          isJsxInitializer: false,
+          isTypeOnlyLocation: false,
+          origin: autoImport.origin
+        };
       }
-    } else {
-      const paramTags = map(inferences, ({ name, typeNode, isOptional }) => factory.createJSDocParameterTag(
-        /*tagName*/
-        void 0,
-        name,
-        /*isBracketed*/
-        !!isOptional,
-        factory.createJSDocTypeExpression(typeNode),
-        /*isNameFirst*/
-        false,
-        /*comment*/
-        void 0
-      ));
-      changes.addJSDocTags(sourceFile, signature, paramTags);
     }
-  }
-  function getReferences(token, program, cancellationToken) {
-    return mapDefined(ts_FindAllReferences_exports.getReferenceEntriesForNode(-1, token, program, program.getSourceFiles(), cancellationToken), (entry) => entry.kind !== ts_FindAllReferences_exports.EntryKind.Span ? tryCast(entry.node, isIdentifier) : void 0);
-  }
-  function inferTypeForVariableFromUsage(token, program, cancellationToken) {
-    const references = getReferences(token, program, cancellationToken);
-    return inferTypeFromReferences(program, references, cancellationToken).single();
-  }
-  function inferTypeForParametersFromUsage(func, sourceFile, program, cancellationToken) {
-    const references = getFunctionReferences(func, sourceFile, program, cancellationToken);
-    return references && inferTypeFromReferences(program, references, cancellationToken).parameters(func) || func.parameters.map((p) => ({
-      declaration: p,
-      type: isIdentifier(p.name) ? inferTypeForVariableFromUsage(p.name, program, cancellationToken) : program.getTypeChecker().getAnyType()
-    }));
-  }
-  function getFunctionReferences(containingFunction, sourceFile, program, cancellationToken) {
-    let searchToken;
-    switch (containingFunction.kind) {
-      case 175 /* Constructor */:
-        searchToken = findChildOfKind(containingFunction, 137 /* ConstructorKeyword */, sourceFile);
-        break;
-      case 218 /* ArrowFunction */:
-      case 217 /* FunctionExpression */:
-        const parent2 = containingFunction.parent;
-        searchToken = (isVariableDeclaration(parent2) || isPropertyDeclaration(parent2)) && isIdentifier(parent2.name) ? parent2.name : containingFunction.name;
-        break;
-      case 261 /* FunctionDeclaration */:
-      case 173 /* MethodDeclaration */:
-      case 172 /* MethodSignature */:
-        searchToken = containingFunction.name;
-        break;
+    const compilerOptions = program.getCompilerOptions();
+    const completionData = getCompletionData(
+      program,
+      log,
+      sourceFile,
+      compilerOptions,
+      position,
+      { includeCompletionsForModuleExports: true, includeCompletionsWithInsertText: true },
+      entryId,
+      host,
+      /*formatContext*/
+      void 0
+    );
+    if (!completionData) {
+      return { type: "none" };
     }
-    if (!searchToken) {
-      return void 0;
+    if (completionData.kind !== 0 /* Data */) {
+      return { type: "request", request: completionData };
     }
-    return getReferences(searchToken, program, cancellationToken);
+    const { symbols, literals, location, completionKind, symbolToOriginInfoMap, contextToken, previousToken, isJsxInitializer, isTypeOnlyLocation } = completionData;
+    const literal = find(literals, (l) => completionNameForLiteral(sourceFile, preferences, l) === entryId.name);
+    if (literal !== void 0)
+      return { type: "literal", literal };
+    return firstDefined(symbols, (symbol, index) => {
+      const origin = symbolToOriginInfoMap[index];
+      const info = getCompletionEntryDisplayNameForSymbol(symbol, getEmitScriptTarget(compilerOptions), origin, completionKind, completionData.isJsxIdentifierExpected);
+      return info && info.name === entryId.name && (entryId.source === "ClassMemberSnippet/" /* ClassMemberSnippet */ && symbol.flags & 106500 /* ClassMember */ || entryId.source === "ObjectLiteralMethodSnippet/" /* ObjectLiteralMethodSnippet */ && symbol.flags & (4 /* Property */ | 8192 /* Method */) || getSourceFromOrigin(origin) === entryId.source || entryId.source === "ObjectLiteralMemberWithComma/" /* ObjectLiteralMemberWithComma */) ? { type: "symbol", symbol, location, origin, contextToken, previousToken, isJsxInitializer, isTypeOnlyLocation } : void 0;
+    }) || { type: "none" };
   }
-  function inferTypeFromReferences(program, references, cancellationToken) {
-    const checker = program.getTypeChecker();
-    const builtinConstructors = {
-      string: () => checker.getStringType(),
-      number: () => checker.getNumberType(),
-      Array: (t) => checker.createArrayType(t),
-      Promise: (t) => checker.createPromiseType(t)
-    };
-    const builtins = [
-      checker.getStringType(),
-      checker.getNumberType(),
-      checker.createArrayType(checker.getAnyType()),
-      checker.createPromiseType(checker.getAnyType())
-    ];
-    return {
-      single: single2,
-      parameters,
-      thisParameter
-    };
-    function createEmptyUsage() {
-      return {
-        isNumber: void 0,
-        isString: void 0,
-        isNumberOrString: void 0,
-        candidateTypes: void 0,
-        properties: void 0,
-        calls: void 0,
-        constructs: void 0,
-        numberIndex: void 0,
-        stringIndex: void 0,
-        candidateThisTypes: void 0,
-        inferredTypes: void 0
-      };
+  function getCompletionEntryDetails(program, log, sourceFile, position, entryId, host, formatContext, preferences, cancellationToken) {
+    const typeChecker = program.getTypeChecker();
+    const compilerOptions = program.getCompilerOptions();
+    const { name, source, data } = entryId;
+    const { previousToken, contextToken } = getRelevantTokens(position, sourceFile);
+    if (isInString(sourceFile, position, previousToken)) {
+      return ts_Completions_StringCompletions_exports.getStringLiteralCompletionDetails(name, sourceFile, position, previousToken, typeChecker, compilerOptions, host, cancellationToken, preferences);
     }
-    function combineUsages(usages) {
-      const combinedProperties = /* @__PURE__ */ new Map();
-      for (const u of usages) {
-        if (u.properties) {
-          u.properties.forEach((p, name) => {
-            if (!combinedProperties.has(name)) {
-              combinedProperties.set(name, []);
-            }
-            combinedProperties.get(name).push(p);
-          });
+    const symbolCompletion = getSymbolCompletionFromEntryId(program, log, sourceFile, position, entryId, host, preferences);
+    switch (symbolCompletion.type) {
+      case "request": {
+        const { request } = symbolCompletion;
+        switch (request.kind) {
+          case 1 /* JsDocTagName */:
+            return ts_JsDoc_exports.getJSDocTagNameCompletionDetails(name);
+          case 2 /* JsDocTag */:
+            return ts_JsDoc_exports.getJSDocTagCompletionDetails(name);
+          case 3 /* JsDocParameterName */:
+            return ts_JsDoc_exports.getJSDocParameterNameCompletionDetails(name);
+          case 4 /* Keywords */:
+            return some(request.keywordCompletions, (c) => c.name === name) ? createSimpleDetails(name, "keyword" /* keyword */, 5 /* keyword */) : void 0;
+          default:
+            return Debug.assertNever(request);
         }
       }
-      const properties = /* @__PURE__ */ new Map();
-      combinedProperties.forEach((ps, name) => {
-        properties.set(name, combineUsages(ps));
-      });
-      return {
-        isNumber: usages.some((u) => u.isNumber),
-        isString: usages.some((u) => u.isString),
-        isNumberOrString: usages.some((u) => u.isNumberOrString),
-        candidateTypes: flatMap(usages, (u) => u.candidateTypes),
-        properties,
-        calls: flatMap(usages, (u) => u.calls),
-        constructs: flatMap(usages, (u) => u.constructs),
-        numberIndex: forEach(usages, (u) => u.numberIndex),
-        stringIndex: forEach(usages, (u) => u.stringIndex),
-        candidateThisTypes: flatMap(usages, (u) => u.candidateThisTypes),
-        inferredTypes: void 0
-        // clear type cache
-      };
-    }
-    function single2() {
-      return combineTypes(inferTypesFromReferencesSingle(references));
-    }
-    function parameters(declaration) {
-      if (references.length === 0 || !declaration.parameters) {
-        return void 0;
+      case "symbol": {
+        const { symbol, location, contextToken: contextToken2, origin, previousToken: previousToken2 } = symbolCompletion;
+        const { codeActions, sourceDisplay } = getCompletionEntryCodeActionsAndSourceDisplay(name, location, contextToken2, origin, symbol, program, host, compilerOptions, sourceFile, position, previousToken2, formatContext, preferences, data, source, cancellationToken);
+        const symbolName2 = originIsComputedPropertyName(origin) ? origin.symbolName : symbol.name;
+        return createCompletionDetailsForSymbol(symbol, symbolName2, typeChecker, sourceFile, location, cancellationToken, codeActions, sourceDisplay);
       }
-      const usage = createEmptyUsage();
-      for (const reference of references) {
-        cancellationToken.throwIfCancellationRequested();
-        calculateUsageOfNode(reference, usage);
+      case "literal": {
+        const { literal } = symbolCompletion;
+        return createSimpleDetails(completionNameForLiteral(sourceFile, preferences, literal), "string" /* string */, typeof literal === "string" ? 8 /* stringLiteral */ : 7 /* numericLiteral */);
       }
-      const calls = [...usage.constructs || [], ...usage.calls || []];
-      return declaration.parameters.map((parameter, parameterIndex) => {
-        const types = [];
-        const isRest = isRestParameter(parameter);
-        let isOptional = false;
-        for (const call of calls) {
-          if (call.argumentTypes.length <= parameterIndex) {
-            isOptional = isInJSFile(declaration);
-            types.push(checker.getUndefinedType());
-          } else if (isRest) {
-            for (let i = parameterIndex; i < call.argumentTypes.length; i++) {
-              types.push(checker.getBaseTypeOfLiteralType(call.argumentTypes[i]));
-            }
-          } else {
-            types.push(checker.getBaseTypeOfLiteralType(call.argumentTypes[parameterIndex]));
-          }
-        }
-        if (isIdentifier(parameter.name)) {
-          const inferred = inferTypesFromReferencesSingle(getReferences(parameter.name, program, cancellationToken));
-          types.push(...isRest ? mapDefined(inferred, checker.getElementTypeOfArrayType) : inferred);
+      case "cases": {
+        const snippets = getExhaustiveCaseSnippets(
+          contextToken.parent,
+          sourceFile,
+          preferences,
+          program.getCompilerOptions(),
+          host,
+          program,
+          /*formatContext*/
+          void 0
+        );
+        if (snippets == null ? void 0 : snippets.importAdder.hasFixes()) {
+          const { entry, importAdder } = snippets;
+          const changes = ts_textChanges_exports.ChangeTracker.with(
+            { host, formatContext, preferences },
+            importAdder.writeFixes
+          );
+          return {
+            name: entry.name,
+            kind: "" /* unknown */,
+            kindModifiers: "",
+            displayParts: [],
+            sourceDisplay: void 0,
+            codeActions: [{
+              changes,
+              description: diagnosticToString([Diagnostics.Includes_imports_of_types_referenced_by_0, name])
+            }]
+          };
         }
-        const type = combineTypes(types);
         return {
-          type: isRest ? checker.createArrayType(type) : type,
-          isOptional: isOptional && !isRest,
-          declaration: parameter
+          name,
+          kind: "" /* unknown */,
+          kindModifiers: "",
+          displayParts: [],
+          sourceDisplay: void 0
         };
-      });
-    }
-    function thisParameter() {
-      const usage = createEmptyUsage();
-      for (const reference of references) {
-        cancellationToken.throwIfCancellationRequested();
-        calculateUsageOfNode(reference, usage);
       }
-      return combineTypes(usage.candidateThisTypes || emptyArray);
+      case "none":
+        return allKeywordsCompletions().some((c) => c.name === name) ? createSimpleDetails(name, "keyword" /* keyword */, 5 /* keyword */) : void 0;
+      default:
+        Debug.assertNever(symbolCompletion);
     }
-    function inferTypesFromReferencesSingle(references2) {
-      const usage = createEmptyUsage();
-      for (const reference of references2) {
-        cancellationToken.throwIfCancellationRequested();
-        calculateUsageOfNode(reference, usage);
+  }
+  function createSimpleDetails(name, kind, kind2) {
+    return createCompletionDetails(name, "" /* none */, kind, [displayPart(name, kind2)]);
+  }
+  function createCompletionDetailsForSymbol(symbol, name, checker, sourceFile, location, cancellationToken, codeActions, sourceDisplay) {
+    const { displayParts, documentation, symbolKind, tags } = checker.runWithCancellationToken(cancellationToken, (checker2) => ts_SymbolDisplay_exports.getSymbolDisplayPartsDocumentationAndSymbolKind(checker2, symbol, sourceFile, location, location, 7 /* All */));
+    return createCompletionDetails(name, ts_SymbolDisplay_exports.getSymbolModifiers(checker, symbol), symbolKind, displayParts, documentation, tags, codeActions, sourceDisplay);
+  }
+  function createCompletionDetails(name, kindModifiers, kind, displayParts, documentation, tags, codeActions, source) {
+    return { name, kindModifiers, kind, displayParts, documentation, tags, codeActions, source, sourceDisplay: source };
+  }
+  function getCompletionEntryCodeActionsAndSourceDisplay(name, location, contextToken, origin, symbol, program, host, compilerOptions, sourceFile, position, previousToken, formatContext, preferences, data, source, cancellationToken) {
+    if (data == null ? void 0 : data.moduleSpecifier) {
+      if (previousToken && getImportStatementCompletionInfo(contextToken || previousToken, sourceFile).replacementSpan) {
+        return { codeActions: void 0, sourceDisplay: [textPart(data.moduleSpecifier)] };
       }
-      return inferTypes(usage);
     }
-    function calculateUsageOfNode(node, usage) {
-      while (isRightSideOfQualifiedNameOrPropertyAccess(node)) {
-        node = node.parent;
-      }
-      switch (node.parent.kind) {
-        case 243 /* ExpressionStatement */:
-          inferTypeFromExpressionStatement(node, usage);
-          break;
-        case 224 /* PostfixUnaryExpression */:
-          usage.isNumber = true;
-          break;
-        case 223 /* PrefixUnaryExpression */:
-          inferTypeFromPrefixUnaryExpression(node.parent, usage);
-          break;
-        case 225 /* BinaryExpression */:
-          inferTypeFromBinaryExpression(node, node.parent, usage);
-          break;
-        case 295 /* CaseClause */:
-        case 296 /* DefaultClause */:
-          inferTypeFromSwitchStatementLabel(node.parent, usage);
-          break;
-        case 212 /* CallExpression */:
-        case 213 /* NewExpression */:
-          if (node.parent.expression === node) {
-            inferTypeFromCallExpression(node.parent, usage);
-          } else {
-            inferTypeFromContextualType(node, usage);
-          }
-          break;
-        case 210 /* PropertyAccessExpression */:
-          inferTypeFromPropertyAccessExpression(node.parent, usage);
-          break;
-        case 211 /* ElementAccessExpression */:
-          inferTypeFromPropertyElementExpression(node.parent, node, usage);
-          break;
-        case 302 /* PropertyAssignment */:
-        case 303 /* ShorthandPropertyAssignment */:
-          inferTypeFromPropertyAssignment(node.parent, usage);
-          break;
-        case 171 /* PropertyDeclaration */:
-          inferTypeFromPropertyDeclaration(node.parent, usage);
-          break;
-        case 259 /* VariableDeclaration */: {
-          const { name, initializer } = node.parent;
-          if (node === name) {
-            if (initializer) {
-              addCandidateType(usage, checker.getTypeAtLocation(initializer));
+    if (source === "ClassMemberSnippet/" /* ClassMemberSnippet */) {
+      const { importAdder, eraseRange } = getEntryForMemberCompletion(
+        host,
+        program,
+        compilerOptions,
+        preferences,
+        name,
+        symbol,
+        location,
+        position,
+        contextToken,
+        formatContext
+      );
+      if (importAdder || eraseRange) {
+        const changes = ts_textChanges_exports.ChangeTracker.with(
+          { host, formatContext, preferences },
+          (tracker) => {
+            if (importAdder) {
+              importAdder.writeFixes(tracker);
+            }
+            if (eraseRange) {
+              tracker.deleteRange(sourceFile, eraseRange);
             }
-            break;
           }
-        }
-        default:
-          return inferTypeFromContextualType(node, usage);
-      }
-    }
-    function inferTypeFromContextualType(node, usage) {
-      if (isExpressionNode(node)) {
-        addCandidateType(usage, checker.getContextualType(node));
+        );
+        return {
+          sourceDisplay: void 0,
+          codeActions: [{
+            changes,
+            description: diagnosticToString([Diagnostics.Includes_imports_of_types_referenced_by_0, name])
+          }]
+        };
       }
     }
-    function inferTypeFromExpressionStatement(node, usage) {
-      addCandidateType(usage, isCallExpression(node) ? checker.getVoidType() : checker.getAnyType());
-    }
-    function inferTypeFromPrefixUnaryExpression(node, usage) {
-      switch (node.operator) {
-        case 46 /* PlusPlusToken */:
-        case 47 /* MinusMinusToken */:
-        case 41 /* MinusToken */:
-        case 55 /* TildeToken */:
-          usage.isNumber = true;
-          break;
-        case 40 /* PlusToken */:
-          usage.isNumberOrString = true;
-          break;
-      }
+    if (originIsTypeOnlyAlias(origin)) {
+      const codeAction2 = ts_codefix_exports.getPromoteTypeOnlyCompletionAction(
+        sourceFile,
+        origin.declaration.name,
+        program,
+        host,
+        formatContext,
+        preferences
+      );
+      Debug.assertIsDefined(codeAction2, "Expected to have a code action for promoting type-only alias");
+      return { codeActions: [codeAction2], sourceDisplay: void 0 };
     }
-    function inferTypeFromBinaryExpression(node, parent2, usage) {
-      switch (parent2.operatorToken.kind) {
-        case 43 /* AsteriskAsteriskToken */:
-        case 42 /* AsteriskToken */:
-        case 44 /* SlashToken */:
-        case 45 /* PercentToken */:
-        case 48 /* LessThanLessThanToken */:
-        case 49 /* GreaterThanGreaterThanToken */:
-        case 50 /* GreaterThanGreaterThanGreaterThanToken */:
-        case 51 /* AmpersandToken */:
-        case 52 /* BarToken */:
-        case 53 /* CaretToken */:
-        case 66 /* MinusEqualsToken */:
-        case 68 /* AsteriskAsteriskEqualsToken */:
-        case 67 /* AsteriskEqualsToken */:
-        case 69 /* SlashEqualsToken */:
-        case 70 /* PercentEqualsToken */:
-        case 74 /* AmpersandEqualsToken */:
-        case 75 /* BarEqualsToken */:
-        case 79 /* CaretEqualsToken */:
-        case 71 /* LessThanLessThanEqualsToken */:
-        case 73 /* GreaterThanGreaterThanGreaterThanEqualsToken */:
-        case 72 /* GreaterThanGreaterThanEqualsToken */:
-        case 41 /* MinusToken */:
-        case 30 /* LessThanToken */:
-        case 33 /* LessThanEqualsToken */:
-        case 32 /* GreaterThanToken */:
-        case 34 /* GreaterThanEqualsToken */:
-          const operandType = checker.getTypeAtLocation(parent2.left === node ? parent2.right : parent2.left);
-          if (operandType.flags & 1056 /* EnumLike */) {
-            addCandidateType(usage, operandType);
-          } else {
-            usage.isNumber = true;
-          }
-          break;
-        case 65 /* PlusEqualsToken */:
-        case 40 /* PlusToken */:
-          const otherOperandType = checker.getTypeAtLocation(parent2.left === node ? parent2.right : parent2.left);
-          if (otherOperandType.flags & 1056 /* EnumLike */) {
-            addCandidateType(usage, otherOperandType);
-          } else if (otherOperandType.flags & 296 /* NumberLike */) {
-            usage.isNumber = true;
-          } else if (otherOperandType.flags & 402653316 /* StringLike */) {
-            usage.isString = true;
-          } else if (otherOperandType.flags & 1 /* Any */) {
-          } else {
-            usage.isNumberOrString = true;
-          }
-          break;
-        case 64 /* EqualsToken */:
-        case 35 /* EqualsEqualsToken */:
-        case 37 /* EqualsEqualsEqualsToken */:
-        case 38 /* ExclamationEqualsEqualsToken */:
-        case 36 /* ExclamationEqualsToken */:
-        case 77 /* AmpersandAmpersandEqualsToken */:
-        case 78 /* QuestionQuestionEqualsToken */:
-        case 76 /* BarBarEqualsToken */:
-          addCandidateType(usage, checker.getTypeAtLocation(parent2.left === node ? parent2.right : parent2.left));
-          break;
-        case 103 /* InKeyword */:
-          if (node === parent2.left) {
-            usage.isString = true;
-          }
-          break;
-        case 57 /* BarBarToken */:
-        case 61 /* QuestionQuestionToken */:
-          if (node === parent2.left && (node.parent.parent.kind === 259 /* VariableDeclaration */ || isAssignmentExpression(
-            node.parent.parent,
-            /*excludeCompoundAssignment*/
-            true
-          ))) {
-            addCandidateType(usage, checker.getTypeAtLocation(parent2.right));
-          }
-          break;
-        case 56 /* AmpersandAmpersandToken */:
-        case 28 /* CommaToken */:
-        case 104 /* InstanceOfKeyword */:
-          break;
+    if (source === "ObjectLiteralMemberWithComma/" /* ObjectLiteralMemberWithComma */ && contextToken) {
+      const changes = ts_textChanges_exports.ChangeTracker.with(
+        { host, formatContext, preferences },
+        (tracker) => tracker.insertText(sourceFile, contextToken.end, ",")
+      );
+      if (changes) {
+        return {
+          sourceDisplay: void 0,
+          codeActions: [{
+            changes,
+            description: diagnosticToString([Diagnostics.Add_missing_comma_for_object_member_completion_0, name])
+          }]
+        };
       }
     }
-    function inferTypeFromSwitchStatementLabel(parent2, usage) {
-      addCandidateType(usage, checker.getTypeAtLocation(parent2.parent.parent.expression));
+    if (!origin || !(originIsExport(origin) || originIsResolvedExport(origin))) {
+      return { codeActions: void 0, sourceDisplay: void 0 };
     }
-    function inferTypeFromCallExpression(parent2, usage) {
-      const call = {
-        argumentTypes: [],
-        return_: createEmptyUsage()
-      };
-      if (parent2.arguments) {
-        for (const argument of parent2.arguments) {
-          call.argumentTypes.push(checker.getTypeAtLocation(argument));
+    const checker = origin.isFromPackageJson ? host.getPackageJsonAutoImportProvider().getTypeChecker() : program.getTypeChecker();
+    const { moduleSymbol } = origin;
+    const targetSymbol = checker.getMergedSymbol(skipAlias(symbol.exportSymbol || symbol, checker));
+    const isJsxOpeningTagName = (contextToken == null ? void 0 : contextToken.kind) === 30 /* LessThanToken */ && isJsxOpeningLikeElement(contextToken.parent);
+    const { moduleSpecifier, codeAction } = ts_codefix_exports.getImportCompletionAction(
+      targetSymbol,
+      moduleSymbol,
+      data == null ? void 0 : data.exportMapKey,
+      sourceFile,
+      name,
+      isJsxOpeningTagName,
+      host,
+      program,
+      formatContext,
+      previousToken && isIdentifier(previousToken) ? previousToken.getStart(sourceFile) : position,
+      preferences,
+      cancellationToken
+    );
+    Debug.assert(!(data == null ? void 0 : data.moduleSpecifier) || moduleSpecifier === data.moduleSpecifier);
+    return { sourceDisplay: [textPart(moduleSpecifier)], codeActions: [codeAction] };
+  }
+  function getCompletionEntrySymbol(program, log, sourceFile, position, entryId, host, preferences) {
+    const completion = getSymbolCompletionFromEntryId(program, log, sourceFile, position, entryId, host, preferences);
+    return completion.type === "symbol" ? completion.symbol : void 0;
+  }
+  function getRecommendedCompletion(previousToken, contextualType, checker) {
+    return firstDefined(contextualType && (contextualType.isUnion() ? contextualType.types : [contextualType]), (type) => {
+      const symbol = type && type.symbol;
+      return symbol && (symbol.flags & (8 /* EnumMember */ | 384 /* Enum */ | 32 /* Class */) && !isAbstractConstructorSymbol(symbol)) ? getFirstSymbolInChain(symbol, previousToken, checker) : void 0;
+    });
+  }
+  function getContextualType(previousToken, position, sourceFile, checker) {
+    const { parent: parent2 } = previousToken;
+    switch (previousToken.kind) {
+      case 80 /* Identifier */:
+        return getContextualTypeFromParent(previousToken, checker);
+      case 64 /* EqualsToken */:
+        switch (parent2.kind) {
+          case 260 /* VariableDeclaration */:
+            return checker.getContextualType(parent2.initializer);
+          case 226 /* BinaryExpression */:
+            return checker.getTypeAtLocation(parent2.left);
+          case 291 /* JsxAttribute */:
+            return checker.getContextualTypeForJsxAttribute(parent2);
+          default:
+            return void 0;
         }
-      }
-      calculateUsageOfNode(parent2, call.return_);
-      if (parent2.kind === 212 /* CallExpression */) {
-        (usage.calls || (usage.calls = [])).push(call);
-      } else {
-        (usage.constructs || (usage.constructs = [])).push(call);
-      }
-    }
-    function inferTypeFromPropertyAccessExpression(parent2, usage) {
-      const name = escapeLeadingUnderscores(parent2.name.text);
-      if (!usage.properties) {
-        usage.properties = /* @__PURE__ */ new Map();
-      }
-      const propertyUsage = usage.properties.get(name) || createEmptyUsage();
-      calculateUsageOfNode(parent2, propertyUsage);
-      usage.properties.set(name, propertyUsage);
+      case 105 /* NewKeyword */:
+        return checker.getContextualType(parent2);
+      case 84 /* CaseKeyword */:
+        const caseClause = tryCast(parent2, isCaseClause);
+        return caseClause ? getSwitchedType(caseClause, checker) : void 0;
+      case 19 /* OpenBraceToken */:
+        return isJsxExpression(parent2) && !isJsxElement(parent2.parent) && !isJsxFragment(parent2.parent) ? checker.getContextualTypeForJsxAttribute(parent2.parent) : void 0;
+      default:
+        const argInfo = ts_SignatureHelp_exports.getArgumentInfoForCompletions(previousToken, position, sourceFile);
+        return argInfo ? (
+          // At `,`, treat this as the next argument after the comma.
+          checker.getContextualTypeForArgumentAtIndex(argInfo.invocation, argInfo.argumentIndex + (previousToken.kind === 28 /* CommaToken */ ? 1 : 0))
+        ) : isEqualityOperatorKind(previousToken.kind) && isBinaryExpression(parent2) && isEqualityOperatorKind(parent2.operatorToken.kind) ? (
+          // completion at `x ===/**/` should be for the right side
+          checker.getTypeAtLocation(parent2.left)
+        ) : checker.getContextualType(previousToken, 4 /* Completions */) || checker.getContextualType(previousToken);
     }
-    function inferTypeFromPropertyElementExpression(parent2, node, usage) {
-      if (node === parent2.argumentExpression) {
-        usage.isNumberOrString = true;
-        return;
-      } else {
-        const indexType = checker.getTypeAtLocation(parent2.argumentExpression);
-        const indexUsage = createEmptyUsage();
-        calculateUsageOfNode(parent2, indexUsage);
-        if (indexType.flags & 296 /* NumberLike */) {
-          usage.numberIndex = indexUsage;
+  }
+  function getFirstSymbolInChain(symbol, enclosingDeclaration, checker) {
+    const chain = checker.getAccessibleSymbolChain(
+      symbol,
+      enclosingDeclaration,
+      /*meaning*/
+      67108863 /* All */,
+      /*useOnlyExternalAliasing*/
+      false
+    );
+    if (chain)
+      return first(chain);
+    return symbol.parent && (isModuleSymbol(symbol.parent) ? symbol : getFirstSymbolInChain(symbol.parent, enclosingDeclaration, checker));
+  }
+  function isModuleSymbol(symbol) {
+    var _a;
+    return !!((_a = symbol.declarations) == null ? void 0 : _a.some((d) => d.kind === 312 /* SourceFile */));
+  }
+  function getCompletionData(program, log, sourceFile, compilerOptions, position, preferences, detailsEntryId, host, formatContext, cancellationToken) {
+    const typeChecker = program.getTypeChecker();
+    const inCheckedFile = isCheckedFile(sourceFile, compilerOptions);
+    let start = timestamp();
+    let currentToken = getTokenAtPosition(sourceFile, position);
+    log("getCompletionData: Get current token: " + (timestamp() - start));
+    start = timestamp();
+    const insideComment = isInComment(sourceFile, position, currentToken);
+    log("getCompletionData: Is inside comment: " + (timestamp() - start));
+    let insideJsDocTagTypeExpression = false;
+    let isInSnippetScope = false;
+    if (insideComment) {
+      if (hasDocComment(sourceFile, position)) {
+        if (sourceFile.text.charCodeAt(position - 1) === 64 /* at */) {
+          return { kind: 1 /* JsDocTagName */ };
         } else {
-          usage.stringIndex = indexUsage;
+          const lineStart = getLineStartPositionForPosition(position, sourceFile);
+          if (!/[^*|\s(/)]/.test(sourceFile.text.substring(lineStart, position))) {
+            return { kind: 2 /* JsDocTag */ };
+          }
         }
       }
-    }
-    function inferTypeFromPropertyAssignment(assignment, usage) {
-      const nodeWithRealType = isVariableDeclaration(assignment.parent.parent) ? assignment.parent.parent : assignment.parent;
-      addCandidateThisType(usage, checker.getTypeAtLocation(nodeWithRealType));
-    }
-    function inferTypeFromPropertyDeclaration(declaration, usage) {
-      addCandidateThisType(usage, checker.getTypeAtLocation(declaration.parent));
-    }
-    function removeLowPriorityInferences(inferences, priorities) {
-      const toRemove = [];
-      for (const i of inferences) {
-        for (const { high, low } of priorities) {
-          if (high(i)) {
-            Debug.assert(!low(i), "Priority can't have both low and high");
-            toRemove.push(low);
+      const tag = getJsDocTagAtPosition(currentToken, position);
+      if (tag) {
+        if (tag.tagName.pos <= position && position <= tag.tagName.end) {
+          return { kind: 1 /* JsDocTagName */ };
+        }
+        const typeExpression = tryGetTypeExpressionFromTag(tag);
+        if (typeExpression) {
+          currentToken = getTokenAtPosition(sourceFile, position);
+          if (!currentToken || !isDeclarationName(currentToken) && (currentToken.parent.kind !== 355 /* JSDocPropertyTag */ || currentToken.parent.name !== currentToken)) {
+            insideJsDocTagTypeExpression = isCurrentlyEditingNode(typeExpression);
           }
         }
+        if (!insideJsDocTagTypeExpression && isJSDocParameterTag(tag) && (nodeIsMissing(tag.name) || tag.name.pos <= position && position <= tag.name.end)) {
+          return { kind: 3 /* JsDocParameterName */, tag };
+        }
+      }
+      if (!insideJsDocTagTypeExpression) {
+        log("Returning an empty list because completion was inside a regular comment or plain text part of a JsDoc comment.");
+        return void 0;
       }
-      return inferences.filter((i) => toRemove.every((f) => !f(i)));
-    }
-    function combineFromUsage(usage) {
-      return combineTypes(inferTypes(usage));
     }
-    function combineTypes(inferences) {
-      if (!inferences.length)
-        return checker.getAnyType();
-      const stringNumber = checker.getUnionType([checker.getStringType(), checker.getNumberType()]);
-      const priorities = [
-        {
-          high: (t) => t === checker.getStringType() || t === checker.getNumberType(),
-          low: (t) => t === stringNumber
-        },
-        {
-          high: (t) => !(t.flags & (1 /* Any */ | 16384 /* Void */)),
-          low: (t) => !!(t.flags & (1 /* Any */ | 16384 /* Void */))
-        },
-        {
-          high: (t) => !(t.flags & (98304 /* Nullable */ | 1 /* Any */ | 16384 /* Void */)) && !(getObjectFlags(t) & 16 /* Anonymous */),
-          low: (t) => !!(getObjectFlags(t) & 16 /* Anonymous */)
+    start = timestamp();
+    const isJsOnlyLocation = !insideJsDocTagTypeExpression && isSourceFileJS(sourceFile);
+    const tokens = getRelevantTokens(position, sourceFile);
+    const previousToken = tokens.previousToken;
+    let contextToken = tokens.contextToken;
+    log("getCompletionData: Get previous token: " + (timestamp() - start));
+    let node = currentToken;
+    let propertyAccessToConvert;
+    let isRightOfDot = false;
+    let isRightOfQuestionDot = false;
+    let isRightOfOpenTag = false;
+    let isStartingCloseTag = false;
+    let isJsxInitializer = false;
+    let isJsxIdentifierExpected = false;
+    let importStatementCompletion;
+    let location = getTouchingPropertyName(sourceFile, position);
+    let keywordFilters = 0 /* None */;
+    let isNewIdentifierLocation = false;
+    let flags = 0 /* None */;
+    if (contextToken) {
+      const importStatementCompletionInfo = getImportStatementCompletionInfo(contextToken, sourceFile);
+      if (importStatementCompletionInfo.keywordCompletion) {
+        if (importStatementCompletionInfo.isKeywordOnlyCompletion) {
+          return {
+            kind: 4 /* Keywords */,
+            keywordCompletions: [keywordToCompletionEntry(importStatementCompletionInfo.keywordCompletion)],
+            isNewIdentifierLocation: importStatementCompletionInfo.isNewIdentifierLocation
+          };
         }
-      ];
-      let good = removeLowPriorityInferences(inferences, priorities);
-      const anons = good.filter((i) => getObjectFlags(i) & 16 /* Anonymous */);
-      if (anons.length) {
-        good = good.filter((i) => !(getObjectFlags(i) & 16 /* Anonymous */));
-        good.push(combineAnonymousTypes(anons));
+        keywordFilters = keywordFiltersFromSyntaxKind(importStatementCompletionInfo.keywordCompletion);
       }
-      return checker.getWidenedType(checker.getUnionType(good.map(checker.getBaseTypeOfLiteralType), 2 /* Subtype */));
-    }
-    function combineAnonymousTypes(anons) {
-      if (anons.length === 1) {
-        return anons[0];
+      if (importStatementCompletionInfo.replacementSpan && preferences.includeCompletionsForImportStatements && preferences.includeCompletionsWithInsertText) {
+        flags |= 2 /* IsImportStatementCompletion */;
+        importStatementCompletion = importStatementCompletionInfo;
+        isNewIdentifierLocation = importStatementCompletionInfo.isNewIdentifierLocation;
       }
-      const calls = [];
-      const constructs = [];
-      const stringIndices = [];
-      const numberIndices = [];
-      let stringIndexReadonly = false;
-      let numberIndexReadonly = false;
-      const props = createMultiMap();
-      for (const anon2 of anons) {
-        for (const p of checker.getPropertiesOfType(anon2)) {
-          props.add(p.escapedName, p.valueDeclaration ? checker.getTypeOfSymbolAtLocation(p, p.valueDeclaration) : checker.getAnyType());
+      if (!importStatementCompletionInfo.replacementSpan && isCompletionListBlocker(contextToken)) {
+        log("Returning an empty list because completion was requested in an invalid position.");
+        return keywordFilters ? keywordCompletionData(keywordFilters, isJsOnlyLocation, isNewIdentifierDefinitionLocation()) : void 0;
+      }
+      let parent2 = contextToken.parent;
+      if (contextToken.kind === 25 /* DotToken */ || contextToken.kind === 29 /* QuestionDotToken */) {
+        isRightOfDot = contextToken.kind === 25 /* DotToken */;
+        isRightOfQuestionDot = contextToken.kind === 29 /* QuestionDotToken */;
+        switch (parent2.kind) {
+          case 211 /* PropertyAccessExpression */:
+            propertyAccessToConvert = parent2;
+            node = propertyAccessToConvert.expression;
+            const leftmostAccessExpression = getLeftmostAccessExpression(propertyAccessToConvert);
+            if (nodeIsMissing(leftmostAccessExpression) || (isCallExpression(node) || isFunctionLike(node)) && node.end === contextToken.pos && node.getChildCount(sourceFile) && last(node.getChildren(sourceFile)).kind !== 22 /* CloseParenToken */) {
+              return void 0;
+            }
+            break;
+          case 166 /* QualifiedName */:
+            node = parent2.left;
+            break;
+          case 267 /* ModuleDeclaration */:
+            node = parent2.name;
+            break;
+          case 205 /* ImportType */:
+            node = parent2;
+            break;
+          case 236 /* MetaProperty */:
+            node = parent2.getFirstToken(sourceFile);
+            Debug.assert(node.kind === 102 /* ImportKeyword */ || node.kind === 105 /* NewKeyword */);
+            break;
+          default:
+            return void 0;
         }
-        calls.push(...checker.getSignaturesOfType(anon2, 0 /* Call */));
-        constructs.push(...checker.getSignaturesOfType(anon2, 1 /* Construct */));
-        const stringIndexInfo = checker.getIndexInfoOfType(anon2, 0 /* String */);
-        if (stringIndexInfo) {
-          stringIndices.push(stringIndexInfo.type);
-          stringIndexReadonly = stringIndexReadonly || stringIndexInfo.isReadonly;
+      } else if (!importStatementCompletion) {
+        if (parent2 && parent2.kind === 211 /* PropertyAccessExpression */) {
+          contextToken = parent2;
+          parent2 = parent2.parent;
         }
-        const numberIndexInfo = checker.getIndexInfoOfType(anon2, 1 /* Number */);
-        if (numberIndexInfo) {
-          numberIndices.push(numberIndexInfo.type);
-          numberIndexReadonly = numberIndexReadonly || numberIndexInfo.isReadonly;
+        if (currentToken.parent === location) {
+          switch (currentToken.kind) {
+            case 32 /* GreaterThanToken */:
+              if (currentToken.parent.kind === 284 /* JsxElement */ || currentToken.parent.kind === 286 /* JsxOpeningElement */) {
+                location = currentToken;
+              }
+              break;
+            case 44 /* SlashToken */:
+              if (currentToken.parent.kind === 285 /* JsxSelfClosingElement */) {
+                location = currentToken;
+              }
+              break;
+          }
+        }
+        switch (parent2.kind) {
+          case 287 /* JsxClosingElement */:
+            if (contextToken.kind === 44 /* SlashToken */) {
+              isStartingCloseTag = true;
+              location = contextToken;
+            }
+            break;
+          case 226 /* BinaryExpression */:
+            if (!binaryExpressionMayBeOpenTag(parent2)) {
+              break;
+            }
+          case 285 /* JsxSelfClosingElement */:
+          case 284 /* JsxElement */:
+          case 286 /* JsxOpeningElement */:
+            isJsxIdentifierExpected = true;
+            if (contextToken.kind === 30 /* LessThanToken */) {
+              isRightOfOpenTag = true;
+              location = contextToken;
+            }
+            break;
+          case 294 /* JsxExpression */:
+          case 293 /* JsxSpreadAttribute */:
+            if (previousToken.kind === 20 /* CloseBraceToken */ || previousToken.kind === 80 /* Identifier */ && previousToken.parent.kind === 291 /* JsxAttribute */) {
+              isJsxIdentifierExpected = true;
+            }
+            break;
+          case 291 /* JsxAttribute */:
+            if (parent2.initializer === previousToken && previousToken.end < position) {
+              isJsxIdentifierExpected = true;
+              break;
+            }
+            switch (previousToken.kind) {
+              case 64 /* EqualsToken */:
+                isJsxInitializer = true;
+                break;
+              case 80 /* Identifier */:
+                isJsxIdentifierExpected = true;
+                if (parent2 !== previousToken.parent && !parent2.initializer && findChildOfKind(parent2, 64 /* EqualsToken */, sourceFile)) {
+                  isJsxInitializer = previousToken;
+                }
+            }
+            break;
         }
       }
-      const members = mapEntries(props, (name, types) => {
-        const isOptional = types.length < anons.length ? 16777216 /* Optional */ : 0;
-        const s = checker.createSymbol(4 /* Property */ | isOptional, name);
-        s.links.type = checker.getUnionType(types);
-        return [name, s];
-      });
-      const indexInfos = [];
-      if (stringIndices.length)
-        indexInfos.push(checker.createIndexInfo(checker.getStringType(), checker.getUnionType(stringIndices), stringIndexReadonly));
-      if (numberIndices.length)
-        indexInfos.push(checker.createIndexInfo(checker.getNumberType(), checker.getUnionType(numberIndices), numberIndexReadonly));
-      return checker.createAnonymousType(
-        anons[0].symbol,
-        members,
-        calls,
-        constructs,
-        indexInfos
-      );
     }
-    function inferTypes(usage) {
-      var _a, _b, _c;
-      const types = [];
-      if (usage.isNumber) {
-        types.push(checker.getNumberType());
-      }
-      if (usage.isString) {
-        types.push(checker.getStringType());
-      }
-      if (usage.isNumberOrString) {
-        types.push(checker.getUnionType([checker.getStringType(), checker.getNumberType()]));
-      }
-      if (usage.numberIndex) {
-        types.push(checker.createArrayType(combineFromUsage(usage.numberIndex)));
-      }
-      if (((_a = usage.properties) == null ? void 0 : _a.size) || ((_b = usage.constructs) == null ? void 0 : _b.length) || usage.stringIndex) {
-        types.push(inferStructuralType(usage));
+    const semanticStart = timestamp();
+    let completionKind = 5 /* None */;
+    let isNonContextualObjectLiteral = false;
+    let hasUnresolvedAutoImports = false;
+    let symbols = [];
+    let importSpecifierResolver;
+    const symbolToOriginInfoMap = [];
+    const symbolToSortTextMap = [];
+    const seenPropertySymbols = /* @__PURE__ */ new Map();
+    const isTypeOnlyLocation = isTypeOnlyCompletion();
+    const getModuleSpecifierResolutionHost = memoizeOne((isFromPackageJson) => {
+      return createModuleSpecifierResolutionHost(isFromPackageJson ? host.getPackageJsonAutoImportProvider() : program, host);
+    });
+    if (isRightOfDot || isRightOfQuestionDot) {
+      getTypeScriptMemberSymbols();
+    } else if (isRightOfOpenTag) {
+      symbols = typeChecker.getJsxIntrinsicTagNamesAt(location);
+      Debug.assertEachIsDefined(symbols, "getJsxIntrinsicTagNames() should all be defined");
+      tryGetGlobalSymbols();
+      completionKind = 1 /* Global */;
+      keywordFilters = 0 /* None */;
+    } else if (isStartingCloseTag) {
+      const tagName = contextToken.parent.parent.openingElement.tagName;
+      const tagSymbol = typeChecker.getSymbolAtLocation(tagName);
+      if (tagSymbol) {
+        symbols = [tagSymbol];
       }
-      const candidateTypes = (usage.candidateTypes || []).map((t) => checker.getBaseTypeOfLiteralType(t));
-      const callsType = ((_c = usage.calls) == null ? void 0 : _c.length) ? inferStructuralType(usage) : void 0;
-      if (callsType && candidateTypes) {
-        types.push(checker.getUnionType([callsType, ...candidateTypes], 2 /* Subtype */));
-      } else {
-        if (callsType) {
-          types.push(callsType);
-        }
-        if (length(candidateTypes)) {
-          types.push(...candidateTypes);
-        }
+      completionKind = 1 /* Global */;
+      keywordFilters = 0 /* None */;
+    } else {
+      if (!tryGetGlobalSymbols()) {
+        return keywordFilters ? keywordCompletionData(keywordFilters, isJsOnlyLocation, isNewIdentifierLocation) : void 0;
       }
-      types.push(...inferNamedTypesFromProperties(usage));
-      return types;
     }
-    function inferStructuralType(usage) {
-      const members = /* @__PURE__ */ new Map();
-      if (usage.properties) {
-        usage.properties.forEach((u, name) => {
-          const symbol = checker.createSymbol(4 /* Property */, name);
-          symbol.links.type = combineFromUsage(u);
-          members.set(name, symbol);
-        });
+    log("getCompletionData: Semantic work: " + (timestamp() - semanticStart));
+    const contextualType = previousToken && getContextualType(previousToken, position, sourceFile, typeChecker);
+    const isLiteralExpected = !tryCast(previousToken, isStringLiteralLike) && !isJsxIdentifierExpected;
+    const literals = !isLiteralExpected ? [] : mapDefined(
+      contextualType && (contextualType.isUnion() ? contextualType.types : [contextualType]),
+      (t) => t.isLiteral() && !(t.flags & 1024 /* EnumLiteral */) ? t.value : void 0
+    );
+    const recommendedCompletion = previousToken && contextualType && getRecommendedCompletion(previousToken, contextualType, typeChecker);
+    return {
+      kind: 0 /* Data */,
+      symbols,
+      completionKind,
+      isInSnippetScope,
+      propertyAccessToConvert,
+      isNewIdentifierLocation,
+      location,
+      keywordFilters,
+      literals,
+      symbolToOriginInfoMap,
+      recommendedCompletion,
+      previousToken,
+      contextToken,
+      isJsxInitializer,
+      insideJsDocTagTypeExpression,
+      symbolToSortTextMap,
+      isTypeOnlyLocation,
+      isJsxIdentifierExpected,
+      isRightOfOpenTag,
+      isRightOfDotOrQuestionDot: isRightOfDot || isRightOfQuestionDot,
+      importStatementCompletion,
+      hasUnresolvedAutoImports,
+      flags
+    };
+    function isTagWithTypeExpression(tag) {
+      switch (tag.kind) {
+        case 348 /* JSDocParameterTag */:
+        case 355 /* JSDocPropertyTag */:
+        case 349 /* JSDocReturnTag */:
+        case 351 /* JSDocTypeTag */:
+        case 353 /* JSDocTypedefTag */:
+        case 356 /* JSDocThrowsTag */:
+        case 357 /* JSDocSatisfiesTag */:
+          return true;
+        case 352 /* JSDocTemplateTag */:
+          return !!tag.constraint;
+        default:
+          return false;
       }
-      const callSignatures = usage.calls ? [getSignatureFromCalls(usage.calls)] : [];
-      const constructSignatures = usage.constructs ? [getSignatureFromCalls(usage.constructs)] : [];
-      const indexInfos = usage.stringIndex ? [checker.createIndexInfo(
-        checker.getStringType(),
-        combineFromUsage(usage.stringIndex),
-        /*isReadonly*/
-        false
-      )] : [];
-      return checker.createAnonymousType(
-        /*symbol*/
-        void 0,
-        members,
-        callSignatures,
-        constructSignatures,
-        indexInfos
-      );
     }
-    function inferNamedTypesFromProperties(usage) {
-      if (!usage.properties || !usage.properties.size)
-        return [];
-      const types = builtins.filter((t) => allPropertiesAreAssignableToUsage(t, usage));
-      if (0 < types.length && types.length < 3) {
-        return types.map((t) => inferInstantiationFromUsage(t, usage));
+    function tryGetTypeExpressionFromTag(tag) {
+      if (isTagWithTypeExpression(tag)) {
+        const typeExpression = isJSDocTemplateTag(tag) ? tag.constraint : tag.typeExpression;
+        return typeExpression && typeExpression.kind === 316 /* JSDocTypeExpression */ ? typeExpression : void 0;
       }
-      return [];
+      if (isJSDocAugmentsTag(tag) || isJSDocImplementsTag(tag)) {
+        return tag.class;
+      }
+      return void 0;
     }
-    function allPropertiesAreAssignableToUsage(type, usage) {
-      if (!usage.properties)
-        return false;
-      return !forEachEntry(usage.properties, (propUsage, name) => {
-        const source = checker.getTypeOfPropertyOfType(type, name);
-        if (!source) {
-          return true;
+    function getTypeScriptMemberSymbols() {
+      completionKind = 2 /* PropertyAccess */;
+      const isImportType = isLiteralImportTypeNode(node);
+      const isTypeLocation = isImportType && !node.isTypeOf || isPartOfTypeNode(node.parent) || isPossiblyTypeArgumentPosition(contextToken, sourceFile, typeChecker);
+      const isRhsOfImportDeclaration = isInRightSideOfInternalImportEqualsDeclaration(node);
+      if (isEntityName(node) || isImportType || isPropertyAccessExpression(node)) {
+        const isNamespaceName = isModuleDeclaration(node.parent);
+        if (isNamespaceName)
+          isNewIdentifierLocation = true;
+        let symbol = typeChecker.getSymbolAtLocation(node);
+        if (symbol) {
+          symbol = skipAlias(symbol, typeChecker);
+          if (symbol.flags & (1536 /* Module */ | 384 /* Enum */)) {
+            const exportedSymbols = typeChecker.getExportsOfModule(symbol);
+            Debug.assertEachIsDefined(exportedSymbols, "getExportsOfModule() should all be defined");
+            const isValidValueAccess = (symbol2) => typeChecker.isValidPropertyAccess(isImportType ? node : node.parent, symbol2.name);
+            const isValidTypeAccess = (symbol2) => symbolCanBeReferencedAtTypeLocation(symbol2, typeChecker);
+            const isValidAccess = isNamespaceName ? (symbol2) => {
+              var _a;
+              return !!(symbol2.flags & 1920 /* Namespace */) && !((_a = symbol2.declarations) == null ? void 0 : _a.every((d) => d.parent === node.parent));
+            } : isRhsOfImportDeclaration ? (
+              // Any kind is allowed when dotting off namespace in internal import equals declaration
+              (symbol2) => isValidTypeAccess(symbol2) || isValidValueAccess(symbol2)
+            ) : isTypeLocation || insideJsDocTagTypeExpression ? isValidTypeAccess : isValidValueAccess;
+            for (const exportedSymbol of exportedSymbols) {
+              if (isValidAccess(exportedSymbol)) {
+                symbols.push(exportedSymbol);
+              }
+            }
+            if (!isTypeLocation && !insideJsDocTagTypeExpression && symbol.declarations && symbol.declarations.some((d) => d.kind !== 312 /* SourceFile */ && d.kind !== 267 /* ModuleDeclaration */ && d.kind !== 266 /* EnumDeclaration */)) {
+              let type = typeChecker.getTypeOfSymbolAtLocation(symbol, node).getNonOptionalType();
+              let insertQuestionDot = false;
+              if (type.isNullableType()) {
+                const canCorrectToQuestionDot = isRightOfDot && !isRightOfQuestionDot && preferences.includeAutomaticOptionalChainCompletions !== false;
+                if (canCorrectToQuestionDot || isRightOfQuestionDot) {
+                  type = type.getNonNullableType();
+                  if (canCorrectToQuestionDot) {
+                    insertQuestionDot = true;
+                  }
+                }
+              }
+              addTypeProperties(type, !!(node.flags & 65536 /* AwaitContext */), insertQuestionDot);
+            }
+            return;
+          }
         }
-        if (propUsage.calls) {
-          const sigs = checker.getSignaturesOfType(source, 0 /* Call */);
-          return !sigs.length || !checker.isTypeAssignableTo(source, getFunctionFromCalls(propUsage.calls));
+      }
+      if (!isTypeLocation || isInTypeQuery(node)) {
+        typeChecker.tryGetThisTypeAt(
+          node,
+          /*includeGlobalThis*/
+          false
+        );
+        let type = typeChecker.getTypeAtLocation(node).getNonOptionalType();
+        if (!isTypeLocation) {
+          let insertQuestionDot = false;
+          if (type.isNullableType()) {
+            const canCorrectToQuestionDot = isRightOfDot && !isRightOfQuestionDot && preferences.includeAutomaticOptionalChainCompletions !== false;
+            if (canCorrectToQuestionDot || isRightOfQuestionDot) {
+              type = type.getNonNullableType();
+              if (canCorrectToQuestionDot) {
+                insertQuestionDot = true;
+              }
+            }
+          }
+          addTypeProperties(type, !!(node.flags & 65536 /* AwaitContext */), insertQuestionDot);
         } else {
-          return !checker.isTypeAssignableTo(source, combineFromUsage(propUsage));
+          addTypeProperties(
+            type.getNonNullableType(),
+            /*insertAwait*/
+            false,
+            /*insertQuestionDot*/
+            false
+          );
         }
-      });
-    }
-    function inferInstantiationFromUsage(type, usage) {
-      if (!(getObjectFlags(type) & 4 /* Reference */) || !usage.properties) {
-        return type;
       }
-      const generic = type.target;
-      const singleTypeParameter = singleOrUndefined(generic.typeParameters);
-      if (!singleTypeParameter)
-        return type;
-      const types = [];
-      usage.properties.forEach((propUsage, name) => {
-        const genericPropertyType = checker.getTypeOfPropertyOfType(generic, name);
-        Debug.assert(!!genericPropertyType, "generic should have all the properties of its reference.");
-        types.push(...inferTypeParameters(genericPropertyType, combineFromUsage(propUsage), singleTypeParameter));
-      });
-      return builtinConstructors[type.symbol.escapedName](combineTypes(types));
     }
-    function inferTypeParameters(genericType, usageType, typeParameter) {
-      if (genericType === typeParameter) {
-        return [usageType];
-      } else if (genericType.flags & 3145728 /* UnionOrIntersection */) {
-        return flatMap(genericType.types, (t) => inferTypeParameters(t, usageType, typeParameter));
-      } else if (getObjectFlags(genericType) & 4 /* Reference */ && getObjectFlags(usageType) & 4 /* Reference */) {
-        const genericArgs = checker.getTypeArguments(genericType);
-        const usageArgs = checker.getTypeArguments(usageType);
-        const types = [];
-        if (genericArgs && usageArgs) {
-          for (let i = 0; i < genericArgs.length; i++) {
-            if (usageArgs[i]) {
-              types.push(...inferTypeParameters(genericArgs[i], usageArgs[i], typeParameter));
-            }
+    function addTypeProperties(type, insertAwait, insertQuestionDot) {
+      isNewIdentifierLocation = !!type.getStringIndexType();
+      if (isRightOfQuestionDot && some(type.getCallSignatures())) {
+        isNewIdentifierLocation = true;
+      }
+      const propertyAccess = node.kind === 205 /* ImportType */ ? node : node.parent;
+      if (inCheckedFile) {
+        for (const symbol of type.getApparentProperties()) {
+          if (typeChecker.isValidPropertyAccessForCompletions(propertyAccess, type, symbol)) {
+            addPropertySymbol(
+              symbol,
+              /*insertAwait*/
+              false,
+              insertQuestionDot
+            );
           }
         }
-        return types;
+      } else {
+        symbols.push(...filter(getPropertiesForCompletion(type, typeChecker), (s) => typeChecker.isValidPropertyAccessForCompletions(propertyAccess, type, s)));
       }
-      const genericSigs = checker.getSignaturesOfType(genericType, 0 /* Call */);
-      const usageSigs = checker.getSignaturesOfType(usageType, 0 /* Call */);
-      if (genericSigs.length === 1 && usageSigs.length === 1) {
-        return inferFromSignatures(genericSigs[0], usageSigs[0], typeParameter);
+      if (insertAwait && preferences.includeCompletionsWithInsertText) {
+        const promiseType = typeChecker.getPromisedTypeOfPromise(type);
+        if (promiseType) {
+          for (const symbol of promiseType.getApparentProperties()) {
+            if (typeChecker.isValidPropertyAccessForCompletions(propertyAccess, promiseType, symbol)) {
+              addPropertySymbol(
+                symbol,
+                /*insertAwait*/
+                true,
+                insertQuestionDot
+              );
+            }
+          }
+        }
       }
-      return [];
     }
-    function inferFromSignatures(genericSig, usageSig, typeParameter) {
+    function addPropertySymbol(symbol, insertAwait, insertQuestionDot) {
       var _a;
-      const types = [];
-      for (let i = 0; i < genericSig.parameters.length; i++) {
-        const genericParam = genericSig.parameters[i];
-        const usageParam = usageSig.parameters[i];
-        const isRest = genericSig.declaration && isRestParameter(genericSig.declaration.parameters[i]);
-        if (!usageParam) {
-          break;
-        }
-        let genericParamType = genericParam.valueDeclaration ? checker.getTypeOfSymbolAtLocation(genericParam, genericParam.valueDeclaration) : checker.getAnyType();
-        const elementType = isRest && checker.getElementTypeOfArrayType(genericParamType);
-        if (elementType) {
-          genericParamType = elementType;
+      const computedPropertyName = firstDefined(symbol.declarations, (decl) => tryCast(getNameOfDeclaration(decl), isComputedPropertyName));
+      if (computedPropertyName) {
+        const leftMostName = getLeftMostName(computedPropertyName.expression);
+        const nameSymbol = leftMostName && typeChecker.getSymbolAtLocation(leftMostName);
+        const firstAccessibleSymbol = nameSymbol && getFirstSymbolInChain(nameSymbol, contextToken, typeChecker);
+        const firstAccessibleSymbolId = firstAccessibleSymbol && getSymbolId(firstAccessibleSymbol);
+        if (firstAccessibleSymbolId && addToSeen(seenPropertySymbols, firstAccessibleSymbolId)) {
+          const index = symbols.length;
+          symbols.push(firstAccessibleSymbol);
+          const moduleSymbol = firstAccessibleSymbol.parent;
+          if (!moduleSymbol || !isExternalModuleSymbol(moduleSymbol) || typeChecker.tryGetMemberInModuleExportsAndProperties(firstAccessibleSymbol.name, moduleSymbol) !== firstAccessibleSymbol) {
+            symbolToOriginInfoMap[index] = { kind: getNullableSymbolOriginInfoKind(2 /* SymbolMemberNoExport */) };
+          } else {
+            const fileName = isExternalModuleNameRelative(stripQuotes(moduleSymbol.name)) ? (_a = getSourceFileOfModule(moduleSymbol)) == null ? void 0 : _a.fileName : void 0;
+            const { moduleSpecifier } = (importSpecifierResolver || (importSpecifierResolver = ts_codefix_exports.createImportSpecifierResolver(sourceFile, program, host, preferences))).getModuleSpecifierForBestExportInfo(
+              [{
+                exportKind: 0 /* Named */,
+                moduleFileName: fileName,
+                isFromPackageJson: false,
+                moduleSymbol,
+                symbol: firstAccessibleSymbol,
+                targetFlags: skipAlias(firstAccessibleSymbol, typeChecker).flags
+              }],
+              position,
+              isValidTypeOnlyAliasUseSite(location)
+            ) || {};
+            if (moduleSpecifier) {
+              const origin = {
+                kind: getNullableSymbolOriginInfoKind(6 /* SymbolMemberExport */),
+                moduleSymbol,
+                isDefaultExport: false,
+                symbolName: firstAccessibleSymbol.name,
+                exportName: firstAccessibleSymbol.name,
+                fileName,
+                moduleSpecifier
+              };
+              symbolToOriginInfoMap[index] = origin;
+            }
+          }
+        } else if (preferences.includeCompletionsWithInsertText) {
+          if (firstAccessibleSymbolId && seenPropertySymbols.has(firstAccessibleSymbolId)) {
+            return;
+          }
+          addSymbolOriginInfo(symbol);
+          addSymbolSortInfo(symbol);
+          symbols.push(symbol);
         }
-        const targetType = ((_a = tryCast(usageParam, isTransientSymbol)) == null ? void 0 : _a.links.type) || (usageParam.valueDeclaration ? checker.getTypeOfSymbolAtLocation(usageParam, usageParam.valueDeclaration) : checker.getAnyType());
-        types.push(...inferTypeParameters(genericParamType, targetType, typeParameter));
+      } else {
+        addSymbolOriginInfo(symbol);
+        addSymbolSortInfo(symbol);
+        symbols.push(symbol);
       }
-      const genericReturn = checker.getReturnTypeOfSignature(genericSig);
-      const usageReturn = checker.getReturnTypeOfSignature(usageSig);
-      types.push(...inferTypeParameters(genericReturn, usageReturn, typeParameter));
-      return types;
-    }
-    function getFunctionFromCalls(calls) {
-      return checker.createAnonymousType(
-        /*symbol*/
-        void 0,
-        createSymbolTable(),
-        [getSignatureFromCalls(calls)],
-        emptyArray,
-        emptyArray
-      );
-    }
-    function getSignatureFromCalls(calls) {
-      const parameters2 = [];
-      const length2 = Math.max(...calls.map((c) => c.argumentTypes.length));
-      for (let i = 0; i < length2; i++) {
-        const symbol = checker.createSymbol(1 /* FunctionScopedVariable */, escapeLeadingUnderscores(`arg${i}`));
-        symbol.links.type = combineTypes(calls.map((call) => call.argumentTypes[i] || checker.getUndefinedType()));
-        if (calls.some((call) => call.argumentTypes[i] === void 0)) {
-          symbol.flags |= 16777216 /* Optional */;
+      function addSymbolSortInfo(symbol2) {
+        if (isStaticProperty(symbol2)) {
+          symbolToSortTextMap[getSymbolId(symbol2)] = SortText.LocalDeclarationPriority;
         }
-        parameters2.push(symbol);
       }
-      const returnType = combineFromUsage(combineUsages(calls.map((call) => call.return_)));
-      return checker.createSignature(
-        /*declaration*/
-        void 0,
-        /*typeParameters*/
-        void 0,
-        /*thisParameter*/
-        void 0,
-        parameters2,
-        returnType,
-        /*typePredicate*/
-        void 0,
-        length2,
-        0 /* None */
-      );
-    }
-    function addCandidateType(usage, type) {
-      if (type && !(type.flags & 1 /* Any */) && !(type.flags & 131072 /* Never */)) {
-        (usage.candidateTypes || (usage.candidateTypes = [])).push(type);
+      function addSymbolOriginInfo(symbol2) {
+        if (preferences.includeCompletionsWithInsertText) {
+          if (insertAwait && addToSeen(seenPropertySymbols, getSymbolId(symbol2))) {
+            symbolToOriginInfoMap[symbols.length] = { kind: getNullableSymbolOriginInfoKind(8 /* Promise */) };
+          } else if (insertQuestionDot) {
+            symbolToOriginInfoMap[symbols.length] = { kind: 16 /* Nullable */ };
+          }
+        }
       }
-    }
-    function addCandidateThisType(usage, type) {
-      if (type && !(type.flags & 1 /* Any */) && !(type.flags & 131072 /* Never */)) {
-        (usage.candidateThisTypes || (usage.candidateThisTypes = [])).push(type);
+      function getNullableSymbolOriginInfoKind(kind) {
+        return insertQuestionDot ? kind | 16 /* Nullable */ : kind;
       }
     }
-  }
-  var fixId38, errorCodes48;
-  var init_inferFromUsage = __esm({
-    "src/services/codefixes/inferFromUsage.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_codefix();
-      fixId38 = "inferFromUsage";
-      errorCodes48 = [
-        // Variable declarations
-        Diagnostics.Variable_0_implicitly_has_type_1_in_some_locations_where_its_type_cannot_be_determined.code,
-        // Variable uses
-        Diagnostics.Variable_0_implicitly_has_an_1_type.code,
-        // Parameter declarations
-        Diagnostics.Parameter_0_implicitly_has_an_1_type.code,
-        Diagnostics.Rest_parameter_0_implicitly_has_an_any_type.code,
-        // Get Accessor declarations
-        Diagnostics.Property_0_implicitly_has_type_any_because_its_get_accessor_lacks_a_return_type_annotation.code,
-        Diagnostics._0_which_lacks_return_type_annotation_implicitly_has_an_1_return_type.code,
-        // Set Accessor declarations
-        Diagnostics.Property_0_implicitly_has_type_any_because_its_set_accessor_lacks_a_parameter_type_annotation.code,
-        // Property declarations
-        Diagnostics.Member_0_implicitly_has_an_1_type.code,
-        //// Suggestions
-        // Variable declarations
-        Diagnostics.Variable_0_implicitly_has_type_1_in_some_locations_but_a_better_type_may_be_inferred_from_usage.code,
-        // Variable uses
-        Diagnostics.Variable_0_implicitly_has_an_1_type_but_a_better_type_may_be_inferred_from_usage.code,
-        // Parameter declarations
-        Diagnostics.Parameter_0_implicitly_has_an_1_type_but_a_better_type_may_be_inferred_from_usage.code,
-        Diagnostics.Rest_parameter_0_implicitly_has_an_any_type_but_a_better_type_may_be_inferred_from_usage.code,
-        // Get Accessor declarations
-        Diagnostics.Property_0_implicitly_has_type_any_but_a_better_type_for_its_get_accessor_may_be_inferred_from_usage.code,
-        Diagnostics._0_implicitly_has_an_1_return_type_but_a_better_type_may_be_inferred_from_usage.code,
-        // Set Accessor declarations
-        Diagnostics.Property_0_implicitly_has_type_any_but_a_better_type_for_its_set_accessor_may_be_inferred_from_usage.code,
-        // Property declarations
-        Diagnostics.Member_0_implicitly_has_an_1_type_but_a_better_type_may_be_inferred_from_usage.code,
-        // Function expressions and declarations
-        Diagnostics.this_implicitly_has_type_any_because_it_does_not_have_a_type_annotation.code
-      ];
-      registerCodeFix({
-        errorCodes: errorCodes48,
-        getCodeActions(context) {
-          const { sourceFile, program, span: { start }, errorCode, cancellationToken, host, preferences } = context;
-          const token = getTokenAtPosition(sourceFile, start);
-          let declaration;
-          const changes = ts_textChanges_exports.ChangeTracker.with(context, (changes2) => {
-            declaration = doChange32(
-              changes2,
-              sourceFile,
-              token,
-              errorCode,
-              program,
-              cancellationToken,
-              /*markSeen*/
-              returnTrue,
-              host,
-              preferences
-            );
-          });
-          const name = declaration && getNameOfDeclaration(declaration);
-          return !name || changes.length === 0 ? void 0 : [createCodeFixAction(fixId38, changes, [getDiagnostic(errorCode, token), getTextOfNode(name)], fixId38, Diagnostics.Infer_all_types_from_usage)];
-        },
-        fixIds: [fixId38],
-        getAllCodeActions(context) {
-          const { sourceFile, program, cancellationToken, host, preferences } = context;
-          const markSeen = nodeSeenTracker();
-          return codeFixAll(context, errorCodes48, (changes, err) => {
-            doChange32(changes, sourceFile, getTokenAtPosition(err.file, err.start), err.code, program, cancellationToken, markSeen, host, preferences);
-          });
-        }
-      });
-    }
-  });
-
-  // src/services/codefixes/fixReturnTypeInAsyncFunction.ts
-  function getInfo15(sourceFile, checker, pos) {
-    if (isInJSFile(sourceFile)) {
-      return void 0;
+    function getLeftMostName(e) {
+      return isIdentifier(e) ? e : isPropertyAccessExpression(e) ? getLeftMostName(e.expression) : void 0;
     }
-    const token = getTokenAtPosition(sourceFile, pos);
-    const func = findAncestor(token, isFunctionLikeDeclaration);
-    const returnTypeNode = func == null ? void 0 : func.type;
-    if (!returnTypeNode) {
-      return void 0;
+    function tryGetGlobalSymbols() {
+      const result = tryGetObjectTypeLiteralInTypeArgumentCompletionSymbols() || tryGetObjectLikeCompletionSymbols() || tryGetImportCompletionSymbols() || tryGetImportOrExportClauseCompletionSymbols() || tryGetLocalNamedExportCompletionSymbols() || tryGetConstructorCompletion() || tryGetClassLikeCompletionSymbols() || tryGetJsxCompletionSymbols() || (getGlobalCompletions(), 1 /* Success */);
+      return result === 1 /* Success */;
     }
-    const returnType = checker.getTypeFromTypeNode(returnTypeNode);
-    const promisedType = checker.getAwaitedType(returnType) || checker.getVoidType();
-    const promisedTypeNode = checker.typeToTypeNode(
-      promisedType,
-      /*enclosingDeclaration*/
-      returnTypeNode,
-      /*flags*/
-      void 0
-    );
-    if (promisedTypeNode) {
-      return { returnTypeNode, returnType, promisedTypeNode, promisedType };
+    function tryGetConstructorCompletion() {
+      if (!tryGetConstructorLikeCompletionContainer(contextToken))
+        return 0 /* Continue */;
+      completionKind = 5 /* None */;
+      isNewIdentifierLocation = true;
+      keywordFilters = 4 /* ConstructorParameterKeywords */;
+      return 1 /* Success */;
     }
-  }
-  function doChange33(changes, sourceFile, returnTypeNode, promisedTypeNode) {
-    changes.replaceNode(sourceFile, returnTypeNode, factory.createTypeReferenceNode("Promise", [promisedTypeNode]));
-  }
-  var fixId39, errorCodes49;
-  var init_fixReturnTypeInAsyncFunction = __esm({
-    "src/services/codefixes/fixReturnTypeInAsyncFunction.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_codefix();
-      fixId39 = "fixReturnTypeInAsyncFunction";
-      errorCodes49 = [
-        Diagnostics.The_return_type_of_an_async_function_or_method_must_be_the_global_Promise_T_type_Did_you_mean_to_write_Promise_0.code
-      ];
-      registerCodeFix({
-        errorCodes: errorCodes49,
-        fixIds: [fixId39],
-        getCodeActions: function getCodeActionsToFixReturnTypeInAsyncFunction(context) {
-          const { sourceFile, program, span } = context;
-          const checker = program.getTypeChecker();
-          const info = getInfo15(sourceFile, program.getTypeChecker(), span.start);
-          if (!info) {
-            return void 0;
-          }
-          const { returnTypeNode, returnType, promisedTypeNode, promisedType } = info;
-          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange33(t, sourceFile, returnTypeNode, promisedTypeNode));
-          return [createCodeFixAction(
-            fixId39,
-            changes,
-            [
-              Diagnostics.Replace_0_with_Promise_1,
-              checker.typeToString(returnType),
-              checker.typeToString(promisedType)
-            ],
-            fixId39,
-            Diagnostics.Fix_all_incorrect_return_type_of_an_async_functions
-          )];
-        },
-        getAllCodeActions: (context) => codeFixAll(context, errorCodes49, (changes, diag2) => {
-          const info = getInfo15(diag2.file, context.program.getTypeChecker(), diag2.start);
-          if (info) {
-            doChange33(changes, diag2.file, info.returnTypeNode, info.promisedTypeNode);
-          }
-        })
-      });
+    function tryGetJsxCompletionSymbols() {
+      const jsxContainer = tryGetContainingJsxElement(contextToken);
+      const attrsType = jsxContainer && typeChecker.getContextualType(jsxContainer.attributes);
+      if (!attrsType)
+        return 0 /* Continue */;
+      const completionsType = jsxContainer && typeChecker.getContextualType(jsxContainer.attributes, 4 /* Completions */);
+      symbols = concatenate(symbols, filterJsxAttributes(getPropertiesForObjectExpression(attrsType, completionsType, jsxContainer.attributes, typeChecker), jsxContainer.attributes.properties));
+      setSortTextToOptionalMember();
+      completionKind = 3 /* MemberLike */;
+      isNewIdentifierLocation = false;
+      return 1 /* Success */;
     }
-  });
-
-  // src/services/codefixes/disableJsDiagnostics.ts
-  function makeChange8(changes, sourceFile, position, seenLines) {
-    const { line: lineNumber } = getLineAndCharacterOfPosition(sourceFile, position);
-    if (!seenLines || tryAddToSet(seenLines, lineNumber)) {
-      changes.insertCommentBeforeLine(sourceFile, lineNumber, position, " @ts-ignore");
+    function tryGetImportCompletionSymbols() {
+      if (!importStatementCompletion)
+        return 0 /* Continue */;
+      isNewIdentifierLocation = true;
+      collectAutoImports();
+      return 1 /* Success */;
     }
-  }
-  var fixName4, fixId40, errorCodes50;
-  var init_disableJsDiagnostics = __esm({
-    "src/services/codefixes/disableJsDiagnostics.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_codefix();
-      fixName4 = "disableJsDiagnostics";
-      fixId40 = "disableJsDiagnostics";
-      errorCodes50 = mapDefined(Object.keys(Diagnostics), (key) => {
-        const diag2 = Diagnostics[key];
-        return diag2.category === 1 /* Error */ ? diag2.code : void 0;
-      });
-      registerCodeFix({
-        errorCodes: errorCodes50,
-        getCodeActions: function getCodeActionsToDisableJsDiagnostics(context) {
-          const { sourceFile, program, span, host, formatContext } = context;
-          if (!isInJSFile(sourceFile) || !isCheckJsEnabledForFile(sourceFile, program.getCompilerOptions())) {
-            return void 0;
+    function getGlobalCompletions() {
+      keywordFilters = tryGetFunctionLikeBodyCompletionContainer(contextToken) ? 5 /* FunctionLikeBodyKeywords */ : 1 /* All */;
+      completionKind = 1 /* Global */;
+      isNewIdentifierLocation = isNewIdentifierDefinitionLocation();
+      if (previousToken !== contextToken) {
+        Debug.assert(!!previousToken, "Expected 'contextToken' to be defined when different from 'previousToken'.");
+      }
+      const adjustedPosition = previousToken !== contextToken ? previousToken.getStart() : position;
+      const scopeNode = getScopeNode(contextToken, adjustedPosition, sourceFile) || sourceFile;
+      isInSnippetScope = isSnippetScope(scopeNode);
+      const symbolMeanings = (isTypeOnlyLocation ? 0 /* None */ : 111551 /* Value */) | 788968 /* Type */ | 1920 /* Namespace */ | 2097152 /* Alias */;
+      const typeOnlyAliasNeedsPromotion = previousToken && !isValidTypeOnlyAliasUseSite(previousToken);
+      symbols = concatenate(symbols, typeChecker.getSymbolsInScope(scopeNode, symbolMeanings));
+      Debug.assertEachIsDefined(symbols, "getSymbolsInScope() should all be defined");
+      for (let i = 0; i < symbols.length; i++) {
+        const symbol = symbols[i];
+        if (!typeChecker.isArgumentsSymbol(symbol) && !some(symbol.declarations, (d) => d.getSourceFile() === sourceFile)) {
+          symbolToSortTextMap[getSymbolId(symbol)] = SortText.GlobalsOrKeywords;
+        }
+        if (typeOnlyAliasNeedsPromotion && !(symbol.flags & 111551 /* Value */)) {
+          const typeOnlyAliasDeclaration = symbol.declarations && find(symbol.declarations, isTypeOnlyImportDeclaration);
+          if (typeOnlyAliasDeclaration) {
+            const origin = { kind: 64 /* TypeOnlyAlias */, declaration: typeOnlyAliasDeclaration };
+            symbolToOriginInfoMap[i] = origin;
           }
-          const newLineCharacter = sourceFile.checkJsDirective ? "" : getNewLineOrDefaultFromHost(host, formatContext.options);
-          const fixes = [
-            // fixId unnecessary because adding `// @ts-nocheck` even once will ignore every error in the file.
-            createCodeFixActionWithoutFixAll(
-              fixName4,
-              [createFileTextChanges(sourceFile.fileName, [
-                createTextChange(sourceFile.checkJsDirective ? createTextSpanFromBounds(sourceFile.checkJsDirective.pos, sourceFile.checkJsDirective.end) : createTextSpan(0, 0), `// @ts-nocheck${newLineCharacter}`)
-              ])],
-              Diagnostics.Disable_checking_for_this_file
-            )
-          ];
-          if (ts_textChanges_exports.isValidLocationToAddComment(sourceFile, span.start)) {
-            fixes.unshift(createCodeFixAction(fixName4, ts_textChanges_exports.ChangeTracker.with(context, (t) => makeChange8(t, sourceFile, span.start)), Diagnostics.Ignore_this_error_message, fixId40, Diagnostics.Add_ts_ignore_to_all_error_messages));
+        }
+      }
+      if (preferences.includeCompletionsWithInsertText && scopeNode.kind !== 312 /* SourceFile */) {
+        const thisType = typeChecker.tryGetThisTypeAt(
+          scopeNode,
+          /*includeGlobalThis*/
+          false,
+          isClassLike(scopeNode.parent) ? scopeNode : void 0
+        );
+        if (thisType && !isProbablyGlobalType(thisType, sourceFile, typeChecker)) {
+          for (const symbol of getPropertiesForCompletion(thisType, typeChecker)) {
+            symbolToOriginInfoMap[symbols.length] = { kind: 1 /* ThisType */ };
+            symbols.push(symbol);
+            symbolToSortTextMap[getSymbolId(symbol)] = SortText.SuggestedClassMembers;
           }
-          return fixes;
-        },
-        fixIds: [fixId40],
-        getAllCodeActions: (context) => {
-          const seenLines = /* @__PURE__ */ new Set();
-          return codeFixAll(context, errorCodes50, (changes, diag2) => {
-            if (ts_textChanges_exports.isValidLocationToAddComment(diag2.file, diag2.start)) {
-              makeChange8(changes, diag2.file, diag2.start, seenLines);
-            }
-          });
         }
-      });
+      }
+      collectAutoImports();
+      if (isTypeOnlyLocation) {
+        keywordFilters = contextToken && isAssertionExpression(contextToken.parent) ? 6 /* TypeAssertionKeywords */ : 7 /* TypeKeywords */;
+      }
     }
-  });
-
-  // src/services/codefixes/helpers.ts
-  function createMissingMemberNodes(classDeclaration, possiblyMissingSymbols, sourceFile, context, preferences, importAdder, addClassElement) {
-    const classMembers = classDeclaration.symbol.members;
-    for (const symbol of possiblyMissingSymbols) {
-      if (!classMembers.has(symbol.escapedName)) {
-        addNewNodeForMemberSymbol(
-          symbol,
-          classDeclaration,
-          sourceFile,
-          context,
-          preferences,
-          importAdder,
-          addClassElement,
-          /*body*/
-          void 0
-        );
+    function shouldOfferImportCompletions() {
+      if (importStatementCompletion)
+        return true;
+      if (isNonContextualObjectLiteral)
+        return false;
+      if (!preferences.includeCompletionsForModuleExports)
+        return false;
+      if (sourceFile.externalModuleIndicator || sourceFile.commonJsModuleIndicator)
+        return true;
+      if (compilerOptionsIndicateEsModules(program.getCompilerOptions()))
+        return true;
+      return programContainsModules(program);
+    }
+    function isSnippetScope(scopeNode) {
+      switch (scopeNode.kind) {
+        case 312 /* SourceFile */:
+        case 228 /* TemplateExpression */:
+        case 294 /* JsxExpression */:
+        case 241 /* Block */:
+          return true;
+        default:
+          return isStatement(scopeNode);
       }
     }
-  }
-  function getNoopSymbolTrackerWithResolver(context) {
-    return {
-      trackSymbol: () => false,
-      moduleResolverHost: getModuleSpecifierResolverHost(context.program, context.host)
-    };
-  }
-  function addNewNodeForMemberSymbol(symbol, enclosingDeclaration, sourceFile, context, preferences, importAdder, addClassElement, body, preserveOptional = 3 /* All */, isAmbient = false) {
-    const declarations = symbol.getDeclarations();
-    const declaration = declarations == null ? void 0 : declarations[0];
-    const checker = context.program.getTypeChecker();
-    const scriptTarget = getEmitScriptTarget(context.program.getCompilerOptions());
-    const kind = (declaration == null ? void 0 : declaration.kind) ?? 170 /* PropertySignature */;
-    const declarationName = getSynthesizedDeepClone(
-      getNameOfDeclaration(declaration),
-      /*includeTrivia*/
-      false
-    );
-    const effectiveModifierFlags = declaration ? getEffectiveModifierFlags(declaration) : 0 /* None */;
-    let modifierFlags = effectiveModifierFlags & 4 /* Public */ ? 4 /* Public */ : effectiveModifierFlags & 16 /* Protected */ ? 16 /* Protected */ : 0 /* None */;
-    if (declaration && isAutoAccessorPropertyDeclaration(declaration)) {
-      modifierFlags |= 128 /* Accessor */;
+    function isTypeOnlyCompletion() {
+      return insideJsDocTagTypeExpression || !!importStatementCompletion && isTypeOnlyImportOrExportDeclaration(location.parent) || !isContextTokenValueLocation(contextToken) && (isPossiblyTypeArgumentPosition(contextToken, sourceFile, typeChecker) || isPartOfTypeNode(location) || isContextTokenTypeLocation(contextToken));
     }
-    const modifiers = createModifiers();
-    const type = checker.getWidenedType(checker.getTypeOfSymbolAtLocation(symbol, enclosingDeclaration));
-    const optional = !!(symbol.flags & 16777216 /* Optional */);
-    const ambient = !!(enclosingDeclaration.flags & 16777216 /* Ambient */) || isAmbient;
-    const quotePreference = getQuotePreference(sourceFile, preferences);
-    switch (kind) {
-      case 170 /* PropertySignature */:
-      case 171 /* PropertyDeclaration */:
-        const flags = quotePreference === 0 /* Single */ ? 268435456 /* UseSingleQuotesForStringLiteralType */ : void 0;
-        let typeNode = checker.typeToTypeNode(type, enclosingDeclaration, flags, getNoopSymbolTrackerWithResolver(context));
-        if (importAdder) {
-          const importableReference = tryGetAutoImportableReferenceFromTypeNode(typeNode, scriptTarget);
-          if (importableReference) {
-            typeNode = importableReference.typeNode;
-            importSymbols(importAdder, importableReference.symbols);
-          }
+    function isContextTokenValueLocation(contextToken2) {
+      return contextToken2 && (contextToken2.kind === 114 /* TypeOfKeyword */ && (contextToken2.parent.kind === 186 /* TypeQuery */ || isTypeOfExpression(contextToken2.parent)) || contextToken2.kind === 131 /* AssertsKeyword */ && contextToken2.parent.kind === 182 /* TypePredicate */);
+    }
+    function isContextTokenTypeLocation(contextToken2) {
+      if (contextToken2) {
+        const parentKind = contextToken2.parent.kind;
+        switch (contextToken2.kind) {
+          case 59 /* ColonToken */:
+            return parentKind === 172 /* PropertyDeclaration */ || parentKind === 171 /* PropertySignature */ || parentKind === 169 /* Parameter */ || parentKind === 260 /* VariableDeclaration */ || isFunctionLikeKind(parentKind);
+          case 64 /* EqualsToken */:
+            return parentKind === 265 /* TypeAliasDeclaration */;
+          case 130 /* AsKeyword */:
+            return parentKind === 234 /* AsExpression */;
+          case 30 /* LessThanToken */:
+            return parentKind === 183 /* TypeReference */ || parentKind === 216 /* TypeAssertionExpression */;
+          case 96 /* ExtendsKeyword */:
+            return parentKind === 168 /* TypeParameter */;
+          case 152 /* SatisfiesKeyword */:
+            return parentKind === 238 /* SatisfiesExpression */;
         }
-        addClassElement(factory.createPropertyDeclaration(
-          modifiers,
-          declaration ? createName(declarationName) : symbol.getName(),
-          optional && preserveOptional & 2 /* Property */ ? factory.createToken(58 /* QuestionToken */) : void 0,
-          typeNode,
-          /*initializer*/
-          void 0
-        ));
-        break;
-      case 176 /* GetAccessor */:
-      case 177 /* SetAccessor */: {
-        Debug.assertIsDefined(declarations);
-        let typeNode2 = checker.typeToTypeNode(
-          type,
-          enclosingDeclaration,
-          /*flags*/
-          void 0,
-          getNoopSymbolTrackerWithResolver(context)
-        );
-        const allAccessors = getAllAccessorDeclarations(declarations, declaration);
-        const orderedAccessors = allAccessors.secondAccessor ? [allAccessors.firstAccessor, allAccessors.secondAccessor] : [allAccessors.firstAccessor];
-        if (importAdder) {
-          const importableReference = tryGetAutoImportableReferenceFromTypeNode(typeNode2, scriptTarget);
-          if (importableReference) {
-            typeNode2 = importableReference.typeNode;
-            importSymbols(importAdder, importableReference.symbols);
-          }
+      }
+      return false;
+    }
+    function collectAutoImports() {
+      var _a, _b;
+      if (!shouldOfferImportCompletions())
+        return;
+      Debug.assert(!(detailsEntryId == null ? void 0 : detailsEntryId.data), "Should not run 'collectAutoImports' when faster path is available via `data`");
+      if (detailsEntryId && !detailsEntryId.source) {
+        return;
+      }
+      flags |= 1 /* MayIncludeAutoImports */;
+      const isAfterTypeOnlyImportSpecifierModifier = previousToken === contextToken && importStatementCompletion;
+      const lowerCaseTokenText = isAfterTypeOnlyImportSpecifierModifier ? "" : previousToken && isIdentifier(previousToken) ? previousToken.text.toLowerCase() : "";
+      const moduleSpecifierCache = (_a = host.getModuleSpecifierCache) == null ? void 0 : _a.call(host);
+      const exportInfo = getExportInfoMap(sourceFile, host, program, preferences, cancellationToken);
+      const packageJsonAutoImportProvider = (_b = host.getPackageJsonAutoImportProvider) == null ? void 0 : _b.call(host);
+      const packageJsonFilter = detailsEntryId ? void 0 : createPackageJsonImportFilter(sourceFile, preferences, host);
+      resolvingModuleSpecifiers(
+        "collectAutoImports",
+        host,
+        importSpecifierResolver || (importSpecifierResolver = ts_codefix_exports.createImportSpecifierResolver(sourceFile, program, host, preferences)),
+        program,
+        position,
+        preferences,
+        !!importStatementCompletion,
+        isValidTypeOnlyAliasUseSite(location),
+        (context) => {
+          exportInfo.search(
+            sourceFile.path,
+            /*preferCapitalized*/
+            isRightOfOpenTag,
+            (symbolName2, targetFlags) => {
+              if (!isIdentifierText(symbolName2, getEmitScriptTarget(host.getCompilationSettings())))
+                return false;
+              if (!detailsEntryId && isStringANonContextualKeyword(symbolName2))
+                return false;
+              if (!isTypeOnlyLocation && !importStatementCompletion && !(targetFlags & 111551 /* Value */))
+                return false;
+              if (isTypeOnlyLocation && !(targetFlags & (1536 /* Module */ | 788968 /* Type */)))
+                return false;
+              const firstChar = symbolName2.charCodeAt(0);
+              if (isRightOfOpenTag && (firstChar < 65 /* A */ || firstChar > 90 /* Z */))
+                return false;
+              if (detailsEntryId)
+                return true;
+              return charactersFuzzyMatchInString(symbolName2, lowerCaseTokenText);
+            },
+            (info, symbolName2, isFromAmbientModule, exportMapKey) => {
+              if (detailsEntryId && !some(info, (i) => detailsEntryId.source === stripQuotes(i.moduleSymbol.name))) {
+                return;
+              }
+              info = filter(info, isImportableExportInfo);
+              if (!info.length) {
+                return;
+              }
+              const result = context.tryResolve(info, isFromAmbientModule) || {};
+              if (result === "failed")
+                return;
+              let exportInfo2 = info[0], moduleSpecifier;
+              if (result !== "skipped") {
+                ({ exportInfo: exportInfo2 = info[0], moduleSpecifier } = result);
+              }
+              const isDefaultExport = exportInfo2.exportKind === 1 /* Default */;
+              const symbol = isDefaultExport && getLocalSymbolForExportDefault(exportInfo2.symbol) || exportInfo2.symbol;
+              pushAutoImportSymbol(symbol, {
+                kind: moduleSpecifier ? 32 /* ResolvedExport */ : 4 /* Export */,
+                moduleSpecifier,
+                symbolName: symbolName2,
+                exportMapKey,
+                exportName: exportInfo2.exportKind === 2 /* ExportEquals */ ? "export=" /* ExportEquals */ : exportInfo2.symbol.name,
+                fileName: exportInfo2.moduleFileName,
+                isDefaultExport,
+                moduleSymbol: exportInfo2.moduleSymbol,
+                isFromPackageJson: exportInfo2.isFromPackageJson
+              });
+            }
+          );
+          hasUnresolvedAutoImports = context.skippedAny();
+          flags |= context.resolvedAny() ? 8 /* ResolvedModuleSpecifiers */ : 0;
+          flags |= context.resolvedBeyondLimit() ? 16 /* ResolvedModuleSpecifiersBeyondLimit */ : 0;
         }
-        for (const accessor of orderedAccessors) {
-          if (isGetAccessorDeclaration(accessor)) {
-            addClassElement(factory.createGetAccessorDeclaration(
-              modifiers,
-              createName(declarationName),
-              emptyArray,
-              createTypeNode(typeNode2),
-              createBody(body, quotePreference, ambient)
-            ));
-          } else {
-            Debug.assertNode(accessor, isSetAccessorDeclaration, "The counterpart to a getter should be a setter");
-            const parameter = getSetAccessorValueParameter(accessor);
-            const parameterName = parameter && isIdentifier(parameter.name) ? idText(parameter.name) : void 0;
-            addClassElement(factory.createSetAccessorDeclaration(
-              modifiers,
-              createName(declarationName),
-              createDummyParameters(
-                1,
-                [parameterName],
-                [createTypeNode(typeNode2)],
-                1,
-                /*inJs*/
-                false
-              ),
-              createBody(body, quotePreference, ambient)
-            ));
+      );
+      function isImportableExportInfo(info) {
+        const moduleFile = tryCast(info.moduleSymbol.valueDeclaration, isSourceFile);
+        if (!moduleFile) {
+          const moduleName = stripQuotes(info.moduleSymbol.name);
+          if (ts_JsTyping_exports.nodeCoreModules.has(moduleName) && startsWith(moduleName, "node:") !== shouldUseUriStyleNodeCoreModules(sourceFile, program)) {
+            return false;
           }
+          return packageJsonFilter ? packageJsonFilter.allowsImportingAmbientModule(info.moduleSymbol, getModuleSpecifierResolutionHost(info.isFromPackageJson)) : true;
         }
-        break;
+        return isImportableFile(
+          info.isFromPackageJson ? packageJsonAutoImportProvider : program,
+          sourceFile,
+          moduleFile,
+          preferences,
+          packageJsonFilter,
+          getModuleSpecifierResolutionHost(info.isFromPackageJson),
+          moduleSpecifierCache
+        );
       }
-      case 172 /* MethodSignature */:
-      case 173 /* MethodDeclaration */:
-        Debug.assertIsDefined(declarations);
-        const signatures = type.isUnion() ? flatMap(type.types, (t) => t.getCallSignatures()) : type.getCallSignatures();
-        if (!some(signatures)) {
-          break;
-        }
-        if (declarations.length === 1) {
-          Debug.assert(signatures.length === 1, "One declaration implies one signature");
-          const signature = signatures[0];
-          outputMethod(quotePreference, signature, modifiers, createName(declarationName), createBody(body, quotePreference, ambient));
-          break;
+    }
+    function pushAutoImportSymbol(symbol, origin) {
+      const symbolId = getSymbolId(symbol);
+      if (symbolToSortTextMap[symbolId] === SortText.GlobalsOrKeywords) {
+        return;
+      }
+      symbolToOriginInfoMap[symbols.length] = origin;
+      symbolToSortTextMap[symbolId] = importStatementCompletion ? SortText.LocationPriority : SortText.AutoImportSuggestions;
+      symbols.push(symbol);
+    }
+    function collectObjectLiteralMethodSymbols(members, enclosingDeclaration) {
+      if (isInJSFile(location)) {
+        return;
+      }
+      members.forEach((member) => {
+        if (!isObjectLiteralMethodSymbol(member)) {
+          return;
         }
-        for (const signature of signatures) {
-          outputMethod(quotePreference, signature, modifiers, createName(declarationName));
+        const displayName = getCompletionEntryDisplayNameForSymbol(
+          member,
+          getEmitScriptTarget(compilerOptions),
+          /*origin*/
+          void 0,
+          0 /* ObjectPropertyDeclaration */,
+          /*jsxIdentifierExpected*/
+          false
+        );
+        if (!displayName) {
+          return;
         }
-        if (!ambient) {
-          if (declarations.length > signatures.length) {
-            const signature = checker.getSignatureFromDeclaration(declarations[declarations.length - 1]);
-            outputMethod(quotePreference, signature, modifiers, createName(declarationName), createBody(body, quotePreference));
-          } else {
-            Debug.assert(declarations.length === signatures.length, "Declarations and signatures should match count");
-            addClassElement(createMethodImplementingSignatures(checker, context, enclosingDeclaration, signatures, createName(declarationName), optional && !!(preserveOptional & 1 /* Method */), modifiers, quotePreference, body));
-          }
+        const { name } = displayName;
+        const entryProps = getEntryForObjectLiteralMethodCompletion(
+          member,
+          name,
+          enclosingDeclaration,
+          program,
+          host,
+          compilerOptions,
+          preferences,
+          formatContext
+        );
+        if (!entryProps) {
+          return;
         }
-        break;
-    }
-    function outputMethod(quotePreference2, signature, modifiers2, name, body2) {
-      const method = createSignatureDeclarationFromSignature(173 /* MethodDeclaration */, context, quotePreference2, signature, body2, name, modifiers2, optional && !!(preserveOptional & 1 /* Method */), enclosingDeclaration, importAdder);
-      if (method)
-        addClassElement(method);
+        const origin = { kind: 128 /* ObjectLiteralMethod */, ...entryProps };
+        flags |= 32 /* MayIncludeMethodSnippets */;
+        symbolToOriginInfoMap[symbols.length] = origin;
+        symbols.push(member);
+      });
     }
-    function createModifiers() {
-      let modifiers2;
-      if (modifierFlags) {
-        modifiers2 = combine(modifiers2, factory.createModifiersFromModifierFlags(modifierFlags));
+    function isObjectLiteralMethodSymbol(symbol) {
+      if (!(symbol.flags & (4 /* Property */ | 8192 /* Method */))) {
+        return false;
       }
-      if (shouldAddOverrideKeyword()) {
-        modifiers2 = append(modifiers2, factory.createToken(163 /* OverrideKeyword */));
+      return true;
+    }
+    function getScopeNode(initialToken, position2, sourceFile2) {
+      let scope = initialToken;
+      while (scope && !positionBelongsToNode(scope, position2, sourceFile2)) {
+        scope = scope.parent;
       }
-      return modifiers2 && factory.createNodeArray(modifiers2);
+      return scope;
     }
-    function shouldAddOverrideKeyword() {
-      return !!(context.program.getCompilerOptions().noImplicitOverride && declaration && hasAbstractModifier(declaration));
+    function isCompletionListBlocker(contextToken2) {
+      const start2 = timestamp();
+      const result = isInStringOrRegularExpressionOrTemplateLiteral(contextToken2) || isSolelyIdentifierDefinitionLocation(contextToken2) || isDotOfNumericLiteral(contextToken2) || isInJsxText(contextToken2) || isBigIntLiteral(contextToken2);
+      log("getCompletionsAtPosition: isCompletionListBlocker: " + (timestamp() - start2));
+      return result;
     }
-    function createName(node) {
-      if (isIdentifier(node) && node.escapedText === "constructor") {
-        return factory.createComputedPropertyName(factory.createStringLiteral(idText(node), quotePreference === 0 /* Single */));
+    function isInJsxText(contextToken2) {
+      if (contextToken2.kind === 12 /* JsxText */) {
+        return true;
       }
-      return getSynthesizedDeepClone(
-        node,
-        /*includeTrivia*/
-        false
-      );
+      if (contextToken2.kind === 32 /* GreaterThanToken */ && contextToken2.parent) {
+        if (location === contextToken2.parent && (location.kind === 286 /* JsxOpeningElement */ || location.kind === 285 /* JsxSelfClosingElement */)) {
+          return false;
+        }
+        if (contextToken2.parent.kind === 286 /* JsxOpeningElement */) {
+          return location.parent.kind !== 286 /* JsxOpeningElement */;
+        }
+        if (contextToken2.parent.kind === 287 /* JsxClosingElement */ || contextToken2.parent.kind === 285 /* JsxSelfClosingElement */) {
+          return !!contextToken2.parent.parent && contextToken2.parent.parent.kind === 284 /* JsxElement */;
+        }
+      }
+      return false;
     }
-    function createBody(block, quotePreference2, ambient2) {
-      return ambient2 ? void 0 : getSynthesizedDeepClone(
-        block,
-        /*includeTrivia*/
-        false
-      ) || createStubbedMethodBody(quotePreference2);
+    function isNewIdentifierDefinitionLocation() {
+      if (contextToken) {
+        const containingNodeKind = contextToken.parent.kind;
+        const tokenKind = keywordForNode(contextToken);
+        switch (tokenKind) {
+          case 28 /* CommaToken */:
+            return containingNodeKind === 213 /* CallExpression */ || containingNodeKind === 176 /* Constructor */ || containingNodeKind === 214 /* NewExpression */ || containingNodeKind === 209 /* ArrayLiteralExpression */ || containingNodeKind === 226 /* BinaryExpression */ || containingNodeKind === 184 /* FunctionType */ || containingNodeKind === 210 /* ObjectLiteralExpression */;
+          case 21 /* OpenParenToken */:
+            return containingNodeKind === 213 /* CallExpression */ || containingNodeKind === 176 /* Constructor */ || containingNodeKind === 214 /* NewExpression */ || containingNodeKind === 217 /* ParenthesizedExpression */ || containingNodeKind === 196 /* ParenthesizedType */;
+          case 23 /* OpenBracketToken */:
+            return containingNodeKind === 209 /* ArrayLiteralExpression */ || containingNodeKind === 181 /* IndexSignature */ || containingNodeKind === 167 /* ComputedPropertyName */;
+          case 144 /* ModuleKeyword */:
+          case 145 /* NamespaceKeyword */:
+          case 102 /* ImportKeyword */:
+            return true;
+          case 25 /* DotToken */:
+            return containingNodeKind === 267 /* ModuleDeclaration */;
+          case 19 /* OpenBraceToken */:
+            return containingNodeKind === 263 /* ClassDeclaration */ || containingNodeKind === 210 /* ObjectLiteralExpression */;
+          case 64 /* EqualsToken */:
+            return containingNodeKind === 260 /* VariableDeclaration */ || containingNodeKind === 226 /* BinaryExpression */;
+          case 16 /* TemplateHead */:
+            return containingNodeKind === 228 /* TemplateExpression */;
+          case 17 /* TemplateMiddle */:
+            return containingNodeKind === 239 /* TemplateSpan */;
+          case 134 /* AsyncKeyword */:
+            return containingNodeKind === 174 /* MethodDeclaration */ || containingNodeKind === 304 /* ShorthandPropertyAssignment */;
+          case 42 /* AsteriskToken */:
+            return containingNodeKind === 174 /* MethodDeclaration */;
+        }
+        if (isClassMemberCompletionKeyword(tokenKind)) {
+          return true;
+        }
+      }
+      return false;
     }
-    function createTypeNode(typeNode) {
-      return getSynthesizedDeepClone(
-        typeNode,
-        /*includeTrivia*/
-        false
-      );
+    function isInStringOrRegularExpressionOrTemplateLiteral(contextToken2) {
+      return (isRegularExpressionLiteral(contextToken2) || isStringTextContainingNode(contextToken2)) && (rangeContainsPositionExclusive(contextToken2, position) || position === contextToken2.end && (!!contextToken2.isUnterminated || isRegularExpressionLiteral(contextToken2)));
     }
-  }
-  function createSignatureDeclarationFromSignature(kind, context, quotePreference, signature, body, name, modifiers, optional, enclosingDeclaration, importAdder) {
-    const program = context.program;
-    const checker = program.getTypeChecker();
-    const scriptTarget = getEmitScriptTarget(program.getCompilerOptions());
-    const isJs = isInJSFile(enclosingDeclaration);
-    const flags = 1 /* NoTruncation */ | 256 /* SuppressAnyReturnType */ | 524288 /* AllowEmptyTuple */ | (quotePreference === 0 /* Single */ ? 268435456 /* UseSingleQuotesForStringLiteralType */ : 0 /* None */);
-    const signatureDeclaration = checker.signatureToSignatureDeclaration(signature, kind, enclosingDeclaration, flags, getNoopSymbolTrackerWithResolver(context));
-    if (!signatureDeclaration) {
-      return void 0;
+    function tryGetObjectTypeLiteralInTypeArgumentCompletionSymbols() {
+      const typeLiteralNode = tryGetTypeLiteralNode(contextToken);
+      if (!typeLiteralNode)
+        return 0 /* Continue */;
+      const intersectionTypeNode = isIntersectionTypeNode(typeLiteralNode.parent) ? typeLiteralNode.parent : void 0;
+      const containerTypeNode = intersectionTypeNode || typeLiteralNode;
+      const containerExpectedType = getConstraintOfTypeArgumentProperty(containerTypeNode, typeChecker);
+      if (!containerExpectedType)
+        return 0 /* Continue */;
+      const containerActualType = typeChecker.getTypeFromTypeNode(containerTypeNode);
+      const members = getPropertiesForCompletion(containerExpectedType, typeChecker);
+      const existingMembers = getPropertiesForCompletion(containerActualType, typeChecker);
+      const existingMemberEscapedNames = /* @__PURE__ */ new Set();
+      existingMembers.forEach((s) => existingMemberEscapedNames.add(s.escapedName));
+      symbols = concatenate(symbols, filter(members, (s) => !existingMemberEscapedNames.has(s.escapedName)));
+      completionKind = 0 /* ObjectPropertyDeclaration */;
+      isNewIdentifierLocation = true;
+      return 1 /* Success */;
     }
-    let typeParameters = isJs ? void 0 : signatureDeclaration.typeParameters;
-    let parameters = signatureDeclaration.parameters;
-    let type = isJs ? void 0 : signatureDeclaration.type;
-    if (importAdder) {
-      if (typeParameters) {
-        const newTypeParameters = sameMap(typeParameters, (typeParameterDecl) => {
-          let constraint = typeParameterDecl.constraint;
-          let defaultType = typeParameterDecl.default;
-          if (constraint) {
-            const importableReference = tryGetAutoImportableReferenceFromTypeNode(constraint, scriptTarget);
-            if (importableReference) {
-              constraint = importableReference.typeNode;
-              importSymbols(importAdder, importableReference.symbols);
-            }
+    function tryGetObjectLikeCompletionSymbols() {
+      const symbolsStartIndex = symbols.length;
+      const objectLikeContainer = tryGetObjectLikeCompletionContainer(contextToken, position, sourceFile);
+      if (!objectLikeContainer)
+        return 0 /* Continue */;
+      completionKind = 0 /* ObjectPropertyDeclaration */;
+      let typeMembers;
+      let existingMembers;
+      if (objectLikeContainer.kind === 210 /* ObjectLiteralExpression */) {
+        const instantiatedType = tryGetObjectLiteralContextualType(objectLikeContainer, typeChecker);
+        if (instantiatedType === void 0) {
+          if (objectLikeContainer.flags & 67108864 /* InWithStatement */) {
+            return 2 /* Fail */;
           }
-          if (defaultType) {
-            const importableReference = tryGetAutoImportableReferenceFromTypeNode(defaultType, scriptTarget);
-            if (importableReference) {
-              defaultType = importableReference.typeNode;
-              importSymbols(importAdder, importableReference.symbols);
-            }
+          isNonContextualObjectLiteral = true;
+          return 0 /* Continue */;
+        }
+        const completionsType = typeChecker.getContextualType(objectLikeContainer, 4 /* Completions */);
+        const hasStringIndexType = (completionsType || instantiatedType).getStringIndexType();
+        const hasNumberIndextype = (completionsType || instantiatedType).getNumberIndexType();
+        isNewIdentifierLocation = !!hasStringIndexType || !!hasNumberIndextype;
+        typeMembers = getPropertiesForObjectExpression(instantiatedType, completionsType, objectLikeContainer, typeChecker);
+        existingMembers = objectLikeContainer.properties;
+        if (typeMembers.length === 0) {
+          if (!hasNumberIndextype) {
+            isNonContextualObjectLiteral = true;
+            return 0 /* Continue */;
           }
-          return factory.updateTypeParameterDeclaration(
-            typeParameterDecl,
-            typeParameterDecl.modifiers,
-            typeParameterDecl.name,
-            constraint,
-            defaultType
-          );
-        });
-        if (typeParameters !== newTypeParameters) {
-          typeParameters = setTextRange(factory.createNodeArray(newTypeParameters, typeParameters.hasTrailingComma), typeParameters);
         }
-      }
-      const newParameters = sameMap(parameters, (parameterDecl) => {
-        let type2 = isJs ? void 0 : parameterDecl.type;
-        if (type2) {
-          const importableReference = tryGetAutoImportableReferenceFromTypeNode(type2, scriptTarget);
-          if (importableReference) {
-            type2 = importableReference.typeNode;
-            importSymbols(importAdder, importableReference.symbols);
+      } else {
+        Debug.assert(objectLikeContainer.kind === 206 /* ObjectBindingPattern */);
+        isNewIdentifierLocation = false;
+        const rootDeclaration = getRootDeclaration(objectLikeContainer.parent);
+        if (!isVariableLike(rootDeclaration))
+          return Debug.fail("Root declaration is not variable-like.");
+        let canGetType = hasInitializer(rootDeclaration) || !!getEffectiveTypeAnnotationNode(rootDeclaration) || rootDeclaration.parent.parent.kind === 250 /* ForOfStatement */;
+        if (!canGetType && rootDeclaration.kind === 169 /* Parameter */) {
+          if (isExpression(rootDeclaration.parent)) {
+            canGetType = !!typeChecker.getContextualType(rootDeclaration.parent);
+          } else if (rootDeclaration.parent.kind === 174 /* MethodDeclaration */ || rootDeclaration.parent.kind === 178 /* SetAccessor */) {
+            canGetType = isExpression(rootDeclaration.parent.parent) && !!typeChecker.getContextualType(rootDeclaration.parent.parent);
           }
         }
-        return factory.updateParameterDeclaration(
-          parameterDecl,
-          parameterDecl.modifiers,
-          parameterDecl.dotDotDotToken,
-          parameterDecl.name,
-          isJs ? void 0 : parameterDecl.questionToken,
-          type2,
-          parameterDecl.initializer
-        );
-      });
-      if (parameters !== newParameters) {
-        parameters = setTextRange(factory.createNodeArray(newParameters, parameters.hasTrailingComma), parameters);
+        if (canGetType) {
+          const typeForObject = typeChecker.getTypeAtLocation(objectLikeContainer);
+          if (!typeForObject)
+            return 2 /* Fail */;
+          typeMembers = typeChecker.getPropertiesOfType(typeForObject).filter((propertySymbol) => {
+            return typeChecker.isPropertyAccessible(
+              objectLikeContainer,
+              /*isSuper*/
+              false,
+              /*isWrite*/
+              false,
+              typeForObject,
+              propertySymbol
+            );
+          });
+          existingMembers = objectLikeContainer.elements;
+        }
       }
-      if (type) {
-        const importableReference = tryGetAutoImportableReferenceFromTypeNode(type, scriptTarget);
-        if (importableReference) {
-          type = importableReference.typeNode;
-          importSymbols(importAdder, importableReference.symbols);
+      if (typeMembers && typeMembers.length > 0) {
+        const filteredMembers = filterObjectMembersList(typeMembers, Debug.checkDefined(existingMembers));
+        symbols = concatenate(symbols, filteredMembers);
+        setSortTextToOptionalMember();
+        if (objectLikeContainer.kind === 210 /* ObjectLiteralExpression */ && preferences.includeCompletionsWithObjectLiteralMethodSnippets && preferences.includeCompletionsWithInsertText) {
+          transformObjectLiteralMembersSortText(symbolsStartIndex);
+          collectObjectLiteralMethodSymbols(filteredMembers, objectLikeContainer);
         }
       }
+      return 1 /* Success */;
     }
-    const questionToken = optional ? factory.createToken(58 /* QuestionToken */) : void 0;
-    const asteriskToken = signatureDeclaration.asteriskToken;
-    if (isFunctionExpression(signatureDeclaration)) {
-      return factory.updateFunctionExpression(signatureDeclaration, modifiers, signatureDeclaration.asteriskToken, tryCast(name, isIdentifier), typeParameters, parameters, type, body ?? signatureDeclaration.body);
-    }
-    if (isArrowFunction(signatureDeclaration)) {
-      return factory.updateArrowFunction(signatureDeclaration, modifiers, typeParameters, parameters, type, signatureDeclaration.equalsGreaterThanToken, body ?? signatureDeclaration.body);
-    }
-    if (isMethodDeclaration(signatureDeclaration)) {
-      return factory.updateMethodDeclaration(signatureDeclaration, modifiers, asteriskToken, name ?? factory.createIdentifier(""), questionToken, typeParameters, parameters, type, body);
-    }
-    if (isFunctionDeclaration(signatureDeclaration)) {
-      return factory.updateFunctionDeclaration(signatureDeclaration, modifiers, signatureDeclaration.asteriskToken, tryCast(name, isIdentifier), typeParameters, parameters, type, body ?? signatureDeclaration.body);
-    }
-    return void 0;
-  }
-  function createSignatureDeclarationFromCallExpression(kind, context, importAdder, call, name, modifierFlags, contextNode) {
-    const quotePreference = getQuotePreference(context.sourceFile, context.preferences);
-    const scriptTarget = getEmitScriptTarget(context.program.getCompilerOptions());
-    const tracker = getNoopSymbolTrackerWithResolver(context);
-    const checker = context.program.getTypeChecker();
-    const isJs = isInJSFile(contextNode);
-    const { typeArguments, arguments: args, parent: parent2 } = call;
-    const contextualType = isJs ? void 0 : checker.getContextualType(call);
-    const names = map(args, (arg) => isIdentifier(arg) ? arg.text : isPropertyAccessExpression(arg) && isIdentifier(arg.name) ? arg.name.text : void 0);
-    const instanceTypes = isJs ? [] : map(args, (arg) => checker.getTypeAtLocation(arg));
-    const { argumentTypeNodes, argumentTypeParameters } = getArgumentTypesAndTypeParameters(
-      checker,
-      importAdder,
-      instanceTypes,
-      contextNode,
-      scriptTarget,
-      /*flags*/
-      void 0,
-      tracker
-    );
-    const modifiers = modifierFlags ? factory.createNodeArray(factory.createModifiersFromModifierFlags(modifierFlags)) : void 0;
-    const asteriskToken = isYieldExpression(parent2) ? factory.createToken(42 /* AsteriskToken */) : void 0;
-    const typeParameters = isJs ? void 0 : createTypeParametersForArguments(checker, argumentTypeParameters, typeArguments);
-    const parameters = createDummyParameters(
-      args.length,
-      names,
-      argumentTypeNodes,
-      /*minArgumentCount*/
-      void 0,
-      isJs
-    );
-    const type = isJs || contextualType === void 0 ? void 0 : checker.typeToTypeNode(
-      contextualType,
-      contextNode,
-      /*flags*/
-      void 0,
-      tracker
-    );
-    switch (kind) {
-      case 173 /* MethodDeclaration */:
-        return factory.createMethodDeclaration(
-          modifiers,
-          asteriskToken,
-          name,
-          /*questionToken*/
-          void 0,
-          typeParameters,
-          parameters,
-          type,
-          createStubbedMethodBody(quotePreference)
-        );
-      case 172 /* MethodSignature */:
-        return factory.createMethodSignature(
-          modifiers,
-          name,
-          /*questionToken*/
-          void 0,
-          typeParameters,
-          parameters,
-          type === void 0 ? factory.createKeywordTypeNode(159 /* UnknownKeyword */) : type
-        );
-      case 261 /* FunctionDeclaration */:
-        return factory.createFunctionDeclaration(
-          modifiers,
-          asteriskToken,
-          name,
-          typeParameters,
-          parameters,
-          type,
-          createStubbedBody(Diagnostics.Function_not_implemented.message, quotePreference)
-        );
-      default:
-        Debug.fail("Unexpected kind");
-    }
-  }
-  function createTypeParametersForArguments(checker, argumentTypeParameters, typeArguments) {
-    const usedNames = new Set(argumentTypeParameters.map((pair) => pair[0]));
-    const constraintsByName = new Map(argumentTypeParameters);
-    if (typeArguments) {
-      const typeArgumentsWithNewTypes = typeArguments.filter((typeArgument) => !argumentTypeParameters.some((pair) => {
-        var _a;
-        return checker.getTypeAtLocation(typeArgument) === ((_a = pair[1]) == null ? void 0 : _a.argumentType);
-      }));
-      const targetSize = usedNames.size + typeArgumentsWithNewTypes.length;
-      for (let i = 0; usedNames.size < targetSize; i += 1) {
-        usedNames.add(createTypeParameterName(i));
+    function tryGetImportOrExportClauseCompletionSymbols() {
+      if (!contextToken)
+        return 0 /* Continue */;
+      const namedImportsOrExports = contextToken.kind === 19 /* OpenBraceToken */ || contextToken.kind === 28 /* CommaToken */ ? tryCast(contextToken.parent, isNamedImportsOrExports) : isTypeKeywordTokenOrIdentifier(contextToken) ? tryCast(contextToken.parent.parent, isNamedImportsOrExports) : void 0;
+      if (!namedImportsOrExports)
+        return 0 /* Continue */;
+      if (!isTypeKeywordTokenOrIdentifier(contextToken)) {
+        keywordFilters = 8 /* TypeKeyword */;
       }
-    }
-    return arrayFrom(
-      usedNames.values(),
-      (usedName) => {
-        var _a;
-        return factory.createTypeParameterDeclaration(
-          /*modifiers*/
-          void 0,
-          usedName,
-          (_a = constraintsByName.get(usedName)) == null ? void 0 : _a.constraint
-        );
+      const { moduleSpecifier } = namedImportsOrExports.kind === 275 /* NamedImports */ ? namedImportsOrExports.parent.parent : namedImportsOrExports.parent;
+      if (!moduleSpecifier) {
+        isNewIdentifierLocation = true;
+        return namedImportsOrExports.kind === 275 /* NamedImports */ ? 2 /* Fail */ : 0 /* Continue */;
       }
-    );
-  }
-  function createTypeParameterName(index) {
-    return 84 /* T */ + index <= 90 /* Z */ ? String.fromCharCode(84 /* T */ + index) : `T${index}`;
-  }
-  function typeToAutoImportableTypeNode(checker, importAdder, type, contextNode, scriptTarget, flags, tracker) {
-    let typeNode = checker.typeToTypeNode(type, contextNode, flags, tracker);
-    if (typeNode && isImportTypeNode(typeNode)) {
-      const importableReference = tryGetAutoImportableReferenceFromTypeNode(typeNode, scriptTarget);
-      if (importableReference) {
-        importSymbols(importAdder, importableReference.symbols);
-        typeNode = importableReference.typeNode;
+      const moduleSpecifierSymbol = typeChecker.getSymbolAtLocation(moduleSpecifier);
+      if (!moduleSpecifierSymbol) {
+        isNewIdentifierLocation = true;
+        return 2 /* Fail */;
+      }
+      completionKind = 3 /* MemberLike */;
+      isNewIdentifierLocation = false;
+      const exports = typeChecker.getExportsAndPropertiesOfModule(moduleSpecifierSymbol);
+      const existing = new Set(namedImportsOrExports.elements.filter((n) => !isCurrentlyEditingNode(n)).map((n) => (n.propertyName || n.name).escapedText));
+      const uniques = exports.filter((e) => e.escapedName !== "default" /* Default */ && !existing.has(e.escapedName));
+      symbols = concatenate(symbols, uniques);
+      if (!uniques.length) {
+        keywordFilters = 0 /* None */;
       }
+      return 1 /* Success */;
     }
-    return getSynthesizedDeepClone(typeNode);
-  }
-  function typeContainsTypeParameter(type) {
-    if (type.isUnionOrIntersection()) {
-      return type.types.some(typeContainsTypeParameter);
+    function tryGetLocalNamedExportCompletionSymbols() {
+      var _a;
+      const namedExports = contextToken && (contextToken.kind === 19 /* OpenBraceToken */ || contextToken.kind === 28 /* CommaToken */) ? tryCast(contextToken.parent, isNamedExports) : void 0;
+      if (!namedExports) {
+        return 0 /* Continue */;
+      }
+      const localsContainer = findAncestor(namedExports, or(isSourceFile, isModuleDeclaration));
+      completionKind = 5 /* None */;
+      isNewIdentifierLocation = false;
+      (_a = localsContainer.locals) == null ? void 0 : _a.forEach((symbol, name) => {
+        var _a2, _b;
+        symbols.push(symbol);
+        if ((_b = (_a2 = localsContainer.symbol) == null ? void 0 : _a2.exports) == null ? void 0 : _b.has(name)) {
+          symbolToSortTextMap[getSymbolId(symbol)] = SortText.OptionalMember;
+        }
+      });
+      return 1 /* Success */;
     }
-    return type.flags & 262144 /* TypeParameter */;
-  }
-  function getArgumentTypesAndTypeParameters(checker, importAdder, instanceTypes, contextNode, scriptTarget, flags, tracker) {
-    const argumentTypeNodes = [];
-    const argumentTypeParameters = /* @__PURE__ */ new Map();
-    for (let i = 0; i < instanceTypes.length; i += 1) {
-      const instanceType = instanceTypes[i];
-      if (instanceType.isUnionOrIntersection() && instanceType.types.some(typeContainsTypeParameter)) {
-        const synthesizedTypeParameterName = createTypeParameterName(i);
-        argumentTypeNodes.push(factory.createTypeReferenceNode(synthesizedTypeParameterName));
-        argumentTypeParameters.set(synthesizedTypeParameterName, void 0);
-        continue;
+    function tryGetClassLikeCompletionSymbols() {
+      const decl = tryGetObjectTypeDeclarationCompletionContainer(sourceFile, contextToken, location, position);
+      if (!decl)
+        return 0 /* Continue */;
+      completionKind = 3 /* MemberLike */;
+      isNewIdentifierLocation = true;
+      keywordFilters = contextToken.kind === 42 /* AsteriskToken */ ? 0 /* None */ : isClassLike(decl) ? 2 /* ClassElementKeywords */ : 3 /* InterfaceElementKeywords */;
+      if (!isClassLike(decl))
+        return 1 /* Success */;
+      const classElement = contextToken.kind === 27 /* SemicolonToken */ ? contextToken.parent.parent : contextToken.parent;
+      let classElementModifierFlags = isClassElement(classElement) ? getEffectiveModifierFlags(classElement) : 0 /* None */;
+      if (contextToken.kind === 80 /* Identifier */ && !isCurrentlyEditingNode(contextToken)) {
+        switch (contextToken.getText()) {
+          case "private":
+            classElementModifierFlags = classElementModifierFlags | 2 /* Private */;
+            break;
+          case "static":
+            classElementModifierFlags = classElementModifierFlags | 256 /* Static */;
+            break;
+          case "override":
+            classElementModifierFlags = classElementModifierFlags | 16 /* Override */;
+            break;
+        }
       }
-      const widenedInstanceType = checker.getBaseTypeOfLiteralType(instanceType);
-      const argumentTypeNode = typeToAutoImportableTypeNode(checker, importAdder, widenedInstanceType, contextNode, scriptTarget, flags, tracker);
-      if (!argumentTypeNode) {
-        continue;
+      if (isClassStaticBlockDeclaration(classElement)) {
+        classElementModifierFlags |= 256 /* Static */;
       }
-      argumentTypeNodes.push(argumentTypeNode);
-      const argumentTypeParameter = getFirstTypeParameterName(instanceType);
-      const instanceTypeConstraint = instanceType.isTypeParameter() && instanceType.constraint && !isAnonymousObjectConstraintType(instanceType.constraint) ? typeToAutoImportableTypeNode(checker, importAdder, instanceType.constraint, contextNode, scriptTarget, flags, tracker) : void 0;
-      if (argumentTypeParameter) {
-        argumentTypeParameters.set(argumentTypeParameter, { argumentType: instanceType, constraint: instanceTypeConstraint });
+      if (!(classElementModifierFlags & 2 /* Private */)) {
+        const baseTypeNodes = isClassLike(decl) && classElementModifierFlags & 16 /* Override */ ? singleElementArray(getEffectiveBaseTypeNode(decl)) : getAllSuperTypeNodes(decl);
+        const baseSymbols = flatMap(baseTypeNodes, (baseTypeNode) => {
+          const type = typeChecker.getTypeAtLocation(baseTypeNode);
+          return classElementModifierFlags & 256 /* Static */ ? (type == null ? void 0 : type.symbol) && typeChecker.getPropertiesOfType(typeChecker.getTypeOfSymbolAtLocation(type.symbol, decl)) : type && typeChecker.getPropertiesOfType(type);
+        });
+        symbols = concatenate(symbols, filterClassMembersList(baseSymbols, decl.members, classElementModifierFlags));
+        forEach(symbols, (symbol, index) => {
+          const declaration = symbol == null ? void 0 : symbol.valueDeclaration;
+          if (declaration && isClassElement(declaration) && declaration.name && isComputedPropertyName(declaration.name)) {
+            const origin = {
+              kind: 512 /* ComputedPropertyName */,
+              symbolName: typeChecker.symbolToString(symbol)
+            };
+            symbolToOriginInfoMap[index] = origin;
+          }
+        });
       }
+      return 1 /* Success */;
     }
-    return { argumentTypeNodes, argumentTypeParameters: arrayFrom(argumentTypeParameters.entries()) };
-  }
-  function isAnonymousObjectConstraintType(type) {
-    return type.flags & 524288 /* Object */ && type.objectFlags === 16 /* Anonymous */;
-  }
-  function getFirstTypeParameterName(type) {
-    var _a;
-    if (type.flags & (1048576 /* Union */ | 2097152 /* Intersection */)) {
-      for (const subType of type.types) {
-        const subTypeName = getFirstTypeParameterName(subType);
-        if (subTypeName) {
-          return subTypeName;
+    function isConstructorParameterCompletion(node2) {
+      return !!node2.parent && isParameter(node2.parent) && isConstructorDeclaration(node2.parent.parent) && (isParameterPropertyModifier(node2.kind) || isDeclarationName(node2));
+    }
+    function tryGetConstructorLikeCompletionContainer(contextToken2) {
+      if (contextToken2) {
+        const parent2 = contextToken2.parent;
+        switch (contextToken2.kind) {
+          case 21 /* OpenParenToken */:
+          case 28 /* CommaToken */:
+            return isConstructorDeclaration(contextToken2.parent) ? contextToken2.parent : void 0;
+          default:
+            if (isConstructorParameterCompletion(contextToken2)) {
+              return parent2.parent;
+            }
         }
       }
+      return void 0;
     }
-    return type.flags & 262144 /* TypeParameter */ ? (_a = type.getSymbol()) == null ? void 0 : _a.getName() : void 0;
-  }
-  function createDummyParameters(argCount, names, types, minArgumentCount, inJs) {
-    const parameters = [];
-    const parameterNameCounts = /* @__PURE__ */ new Map();
-    for (let i = 0; i < argCount; i++) {
-      const parameterName = (names == null ? void 0 : names[i]) || `arg${i}`;
-      const parameterNameCount = parameterNameCounts.get(parameterName);
-      parameterNameCounts.set(parameterName, (parameterNameCount || 0) + 1);
-      const newParameter = factory.createParameterDeclaration(
-        /*modifiers*/
-        void 0,
-        /*dotDotDotToken*/
-        void 0,
-        /*name*/
-        parameterName + (parameterNameCount || ""),
-        /*questionToken*/
-        minArgumentCount !== void 0 && i >= minArgumentCount ? factory.createToken(58 /* QuestionToken */) : void 0,
-        /*type*/
-        inJs ? void 0 : (types == null ? void 0 : types[i]) || factory.createKeywordTypeNode(159 /* UnknownKeyword */),
-        /*initializer*/
-        void 0
-      );
-      parameters.push(newParameter);
-    }
-    return parameters;
-  }
-  function createMethodImplementingSignatures(checker, context, enclosingDeclaration, signatures, name, optional, modifiers, quotePreference, body) {
-    let maxArgsSignature = signatures[0];
-    let minArgumentCount = signatures[0].minArgumentCount;
-    let someSigHasRestParameter = false;
-    for (const sig of signatures) {
-      minArgumentCount = Math.min(sig.minArgumentCount, minArgumentCount);
-      if (signatureHasRestParameter(sig)) {
-        someSigHasRestParameter = true;
-      }
-      if (sig.parameters.length >= maxArgsSignature.parameters.length && (!signatureHasRestParameter(sig) || signatureHasRestParameter(maxArgsSignature))) {
-        maxArgsSignature = sig;
+    function tryGetFunctionLikeBodyCompletionContainer(contextToken2) {
+      if (contextToken2) {
+        let prev;
+        const container = findAncestor(contextToken2.parent, (node2) => {
+          if (isClassLike(node2)) {
+            return "quit";
+          }
+          if (isFunctionLikeDeclaration(node2) && prev === node2.body) {
+            return true;
+          }
+          prev = node2;
+          return false;
+        });
+        return container && container;
       }
     }
-    const maxNonRestArgs = maxArgsSignature.parameters.length - (signatureHasRestParameter(maxArgsSignature) ? 1 : 0);
-    const maxArgsParameterSymbolNames = maxArgsSignature.parameters.map((symbol) => symbol.name);
-    const parameters = createDummyParameters(
-      maxNonRestArgs,
-      maxArgsParameterSymbolNames,
-      /*types*/
-      void 0,
-      minArgumentCount,
-      /*inJs*/
-      false
-    );
-    if (someSigHasRestParameter) {
-      const restParameter = factory.createParameterDeclaration(
-        /*modifiers*/
-        void 0,
-        factory.createToken(26 /* DotDotDotToken */),
-        maxArgsParameterSymbolNames[maxNonRestArgs] || "rest",
-        /*questionToken*/
-        maxNonRestArgs >= minArgumentCount ? factory.createToken(58 /* QuestionToken */) : void 0,
-        factory.createArrayTypeNode(factory.createKeywordTypeNode(159 /* UnknownKeyword */)),
-        /*initializer*/
-        void 0
-      );
-      parameters.push(restParameter);
+    function tryGetContainingJsxElement(contextToken2) {
+      if (contextToken2) {
+        const parent2 = contextToken2.parent;
+        switch (contextToken2.kind) {
+          case 32 /* GreaterThanToken */:
+          case 31 /* LessThanSlashToken */:
+          case 44 /* SlashToken */:
+          case 80 /* Identifier */:
+          case 211 /* PropertyAccessExpression */:
+          case 292 /* JsxAttributes */:
+          case 291 /* JsxAttribute */:
+          case 293 /* JsxSpreadAttribute */:
+            if (parent2 && (parent2.kind === 285 /* JsxSelfClosingElement */ || parent2.kind === 286 /* JsxOpeningElement */)) {
+              if (contextToken2.kind === 32 /* GreaterThanToken */) {
+                const precedingToken = findPrecedingToken(
+                  contextToken2.pos,
+                  sourceFile,
+                  /*startNode*/
+                  void 0
+                );
+                if (!parent2.typeArguments || precedingToken && precedingToken.kind === 44 /* SlashToken */)
+                  break;
+              }
+              return parent2;
+            } else if (parent2.kind === 291 /* JsxAttribute */) {
+              return parent2.parent.parent;
+            }
+            break;
+          case 11 /* StringLiteral */:
+            if (parent2 && (parent2.kind === 291 /* JsxAttribute */ || parent2.kind === 293 /* JsxSpreadAttribute */)) {
+              return parent2.parent.parent;
+            }
+            break;
+          case 20 /* CloseBraceToken */:
+            if (parent2 && parent2.kind === 294 /* JsxExpression */ && parent2.parent && parent2.parent.kind === 291 /* JsxAttribute */) {
+              return parent2.parent.parent.parent;
+            }
+            if (parent2 && parent2.kind === 293 /* JsxSpreadAttribute */) {
+              return parent2.parent.parent;
+            }
+            break;
+        }
+      }
+      return void 0;
     }
-    return createStubbedMethod(
-      modifiers,
-      name,
-      optional,
-      /*typeParameters*/
-      void 0,
-      parameters,
-      getReturnTypeFromSignatures(signatures, checker, context, enclosingDeclaration),
-      quotePreference,
-      body
-    );
-  }
-  function getReturnTypeFromSignatures(signatures, checker, context, enclosingDeclaration) {
-    if (length(signatures)) {
-      const type = checker.getUnionType(map(signatures, checker.getReturnTypeOfSignature));
-      return checker.typeToTypeNode(type, enclosingDeclaration, 1 /* NoTruncation */, getNoopSymbolTrackerWithResolver(context));
+    function isSolelyIdentifierDefinitionLocation(contextToken2) {
+      const parent2 = contextToken2.parent;
+      const containingNodeKind = parent2.kind;
+      switch (contextToken2.kind) {
+        case 28 /* CommaToken */:
+          return containingNodeKind === 260 /* VariableDeclaration */ || isVariableDeclarationListButNotTypeArgument(contextToken2) || containingNodeKind === 243 /* VariableStatement */ || containingNodeKind === 266 /* EnumDeclaration */ || // enum a { foo, |
+          isFunctionLikeButNotConstructor(containingNodeKind) || containingNodeKind === 264 /* InterfaceDeclaration */ || // interface A= contextToken2.pos;
+        case 25 /* DotToken */:
+          return containingNodeKind === 207 /* ArrayBindingPattern */;
+        case 59 /* ColonToken */:
+          return containingNodeKind === 208 /* BindingElement */;
+        case 23 /* OpenBracketToken */:
+          return containingNodeKind === 207 /* ArrayBindingPattern */;
+        case 21 /* OpenParenToken */:
+          return containingNodeKind === 299 /* CatchClause */ || isFunctionLikeButNotConstructor(containingNodeKind);
+        case 19 /* OpenBraceToken */:
+          return containingNodeKind === 266 /* EnumDeclaration */;
+        case 30 /* LessThanToken */:
+          return containingNodeKind === 263 /* ClassDeclaration */ || // class A< |
+          containingNodeKind === 231 /* ClassExpression */ || // var C = class D< |
+          containingNodeKind === 264 /* InterfaceDeclaration */ || // interface A< |
+          containingNodeKind === 265 /* TypeAliasDeclaration */ || // type List< |
+          isFunctionLikeKind(containingNodeKind);
+        case 126 /* StaticKeyword */:
+          return containingNodeKind === 172 /* PropertyDeclaration */ && !isClassLike(parent2.parent);
+        case 26 /* DotDotDotToken */:
+          return containingNodeKind === 169 /* Parameter */ || !!parent2.parent && parent2.parent.kind === 207 /* ArrayBindingPattern */;
+        case 125 /* PublicKeyword */:
+        case 123 /* PrivateKeyword */:
+        case 124 /* ProtectedKeyword */:
+          return containingNodeKind === 169 /* Parameter */ && !isConstructorDeclaration(parent2.parent);
+        case 130 /* AsKeyword */:
+          return containingNodeKind === 276 /* ImportSpecifier */ || containingNodeKind === 281 /* ExportSpecifier */ || containingNodeKind === 274 /* NamespaceImport */;
+        case 139 /* GetKeyword */:
+        case 153 /* SetKeyword */:
+          return !isFromObjectTypeDeclaration(contextToken2);
+        case 80 /* Identifier */:
+          if (containingNodeKind === 276 /* ImportSpecifier */ && contextToken2 === parent2.name && contextToken2.text === "type") {
+            return false;
+          }
+          break;
+        case 86 /* ClassKeyword */:
+        case 94 /* EnumKeyword */:
+        case 120 /* InterfaceKeyword */:
+        case 100 /* FunctionKeyword */:
+        case 115 /* VarKeyword */:
+        case 102 /* ImportKeyword */:
+        case 121 /* LetKeyword */:
+        case 87 /* ConstKeyword */:
+        case 140 /* InferKeyword */:
+          return true;
+        case 156 /* TypeKeyword */:
+          return containingNodeKind !== 276 /* ImportSpecifier */;
+        case 42 /* AsteriskToken */:
+          return isFunctionLike(contextToken2.parent) && !isMethodDeclaration(contextToken2.parent);
+      }
+      if (isClassMemberCompletionKeyword(keywordForNode(contextToken2)) && isFromObjectTypeDeclaration(contextToken2)) {
+        return false;
+      }
+      if (isConstructorParameterCompletion(contextToken2)) {
+        if (!isIdentifier(contextToken2) || isParameterPropertyModifier(keywordForNode(contextToken2)) || isCurrentlyEditingNode(contextToken2)) {
+          return false;
+        }
+      }
+      switch (keywordForNode(contextToken2)) {
+        case 128 /* AbstractKeyword */:
+        case 86 /* ClassKeyword */:
+        case 87 /* ConstKeyword */:
+        case 138 /* DeclareKeyword */:
+        case 94 /* EnumKeyword */:
+        case 100 /* FunctionKeyword */:
+        case 120 /* InterfaceKeyword */:
+        case 121 /* LetKeyword */:
+        case 123 /* PrivateKeyword */:
+        case 124 /* ProtectedKeyword */:
+        case 125 /* PublicKeyword */:
+        case 126 /* StaticKeyword */:
+        case 115 /* VarKeyword */:
+          return true;
+        case 134 /* AsyncKeyword */:
+          return isPropertyDeclaration(contextToken2.parent);
+      }
+      const ancestorClassLike = findAncestor(contextToken2.parent, isClassLike);
+      if (ancestorClassLike && contextToken2 === previousToken && isPreviousPropertyDeclarationTerminated(contextToken2, position)) {
+        return false;
+      }
+      const ancestorPropertyDeclaraion = getAncestor(contextToken2.parent, 172 /* PropertyDeclaration */);
+      if (ancestorPropertyDeclaraion && contextToken2 !== previousToken && isClassLike(previousToken.parent.parent) && position <= previousToken.end) {
+        if (isPreviousPropertyDeclarationTerminated(contextToken2, previousToken.end)) {
+          return false;
+        } else if (contextToken2.kind !== 64 /* EqualsToken */ && (isInitializedProperty(ancestorPropertyDeclaraion) || hasType(ancestorPropertyDeclaraion))) {
+          return true;
+        }
+      }
+      return isDeclarationName(contextToken2) && !isShorthandPropertyAssignment(contextToken2.parent) && !isJsxAttribute(contextToken2.parent) && !((isClassLike(contextToken2.parent) || isInterfaceDeclaration(contextToken2.parent) || isTypeParameterDeclaration(contextToken2.parent)) && (contextToken2 !== previousToken || position > previousToken.end));
     }
-  }
-  function createStubbedMethod(modifiers, name, optional, typeParameters, parameters, returnType, quotePreference, body) {
-    return factory.createMethodDeclaration(
-      modifiers,
-      /*asteriskToken*/
-      void 0,
-      name,
-      optional ? factory.createToken(58 /* QuestionToken */) : void 0,
-      typeParameters,
-      parameters,
-      returnType,
-      body || createStubbedMethodBody(quotePreference)
-    );
-  }
-  function createStubbedMethodBody(quotePreference) {
-    return createStubbedBody(Diagnostics.Method_not_implemented.message, quotePreference);
-  }
-  function createStubbedBody(text, quotePreference) {
-    return factory.createBlock(
-      [factory.createThrowStatement(
-        factory.createNewExpression(
-          factory.createIdentifier("Error"),
-          /*typeArguments*/
-          void 0,
-          // TODO Handle auto quote preference.
-          [factory.createStringLiteral(
-            text,
-            /*isSingleQuote*/
-            quotePreference === 0 /* Single */
-          )]
-        )
-      )],
-      /*multiLine*/
-      true
-    );
-  }
-  function setJsonCompilerOptionValues(changeTracker, configFile, options) {
-    const tsconfigObjectLiteral = getTsConfigObjectLiteralExpression(configFile);
-    if (!tsconfigObjectLiteral)
-      return void 0;
-    const compilerOptionsProperty = findJsonProperty(tsconfigObjectLiteral, "compilerOptions");
-    if (compilerOptionsProperty === void 0) {
-      changeTracker.insertNodeAtObjectStart(configFile, tsconfigObjectLiteral, createJsonPropertyAssignment(
-        "compilerOptions",
-        factory.createObjectLiteralExpression(
-          options.map(([optionName, optionValue]) => createJsonPropertyAssignment(optionName, optionValue)),
-          /*multiLine*/
-          true
-        )
-      ));
-      return;
+    function isPreviousPropertyDeclarationTerminated(contextToken2, position2) {
+      return contextToken2.kind !== 64 /* EqualsToken */ && (contextToken2.kind === 27 /* SemicolonToken */ || !positionsAreOnSameLine(contextToken2.end, position2, sourceFile));
     }
-    const compilerOptions = compilerOptionsProperty.initializer;
-    if (!isObjectLiteralExpression(compilerOptions)) {
-      return;
+    function isFunctionLikeButNotConstructor(kind) {
+      return isFunctionLikeKind(kind) && kind !== 176 /* Constructor */;
     }
-    for (const [optionName, optionValue] of options) {
-      const optionProperty = findJsonProperty(compilerOptions, optionName);
-      if (optionProperty === void 0) {
-        changeTracker.insertNodeAtObjectStart(configFile, compilerOptions, createJsonPropertyAssignment(optionName, optionValue));
-      } else {
-        changeTracker.replaceNode(configFile, optionProperty.initializer, optionValue);
+    function isDotOfNumericLiteral(contextToken2) {
+      if (contextToken2.kind === 9 /* NumericLiteral */) {
+        const text = contextToken2.getFullText();
+        return text.charAt(text.length - 1) === ".";
       }
+      return false;
     }
-  }
-  function setJsonCompilerOptionValue(changeTracker, configFile, optionName, optionValue) {
-    setJsonCompilerOptionValues(changeTracker, configFile, [[optionName, optionValue]]);
-  }
-  function createJsonPropertyAssignment(name, initializer) {
-    return factory.createPropertyAssignment(factory.createStringLiteral(name), initializer);
-  }
-  function findJsonProperty(obj, name) {
-    return find(obj.properties, (p) => isPropertyAssignment(p) && !!p.name && isStringLiteral(p.name) && p.name.text === name);
-  }
-  function tryGetAutoImportableReferenceFromTypeNode(importTypeNode, scriptTarget) {
-    let symbols;
-    const typeNode = visitNode(importTypeNode, visit, isTypeNode);
-    if (symbols && typeNode) {
-      return { typeNode, symbols };
+    function isVariableDeclarationListButNotTypeArgument(node2) {
+      return node2.parent.kind === 261 /* VariableDeclarationList */ && !isPossiblyTypeArgumentPosition(node2, sourceFile, typeChecker);
     }
-    function visit(node) {
-      if (isLiteralImportTypeNode(node) && node.qualifier) {
-        const firstIdentifier = getFirstIdentifier(node.qualifier);
-        const name = getNameForExportedSymbol(firstIdentifier.symbol, scriptTarget);
-        const qualifier = name !== firstIdentifier.text ? replaceFirstIdentifierOfEntityName(node.qualifier, factory.createIdentifier(name)) : node.qualifier;
-        symbols = append(symbols, firstIdentifier.symbol);
-        const typeArguments = visitNodes2(node.typeArguments, visit, isTypeNode);
-        return factory.createTypeReferenceNode(qualifier, typeArguments);
+    function filterObjectMembersList(contextualMemberSymbols, existingMembers) {
+      if (existingMembers.length === 0) {
+        return contextualMemberSymbols;
       }
-      return visitEachChild(node, visit, nullTransformationContext);
-    }
-  }
-  function replaceFirstIdentifierOfEntityName(name, newIdentifier) {
-    if (name.kind === 80 /* Identifier */) {
-      return newIdentifier;
+      const membersDeclaredBySpreadAssignment = /* @__PURE__ */ new Set();
+      const existingMemberNames = /* @__PURE__ */ new Set();
+      for (const m of existingMembers) {
+        if (m.kind !== 303 /* PropertyAssignment */ && m.kind !== 304 /* ShorthandPropertyAssignment */ && m.kind !== 208 /* BindingElement */ && m.kind !== 174 /* MethodDeclaration */ && m.kind !== 177 /* GetAccessor */ && m.kind !== 178 /* SetAccessor */ && m.kind !== 305 /* SpreadAssignment */) {
+          continue;
+        }
+        if (isCurrentlyEditingNode(m)) {
+          continue;
+        }
+        let existingName;
+        if (isSpreadAssignment(m)) {
+          setMembersDeclaredBySpreadAssignment(m, membersDeclaredBySpreadAssignment);
+        } else if (isBindingElement(m) && m.propertyName) {
+          if (m.propertyName.kind === 80 /* Identifier */) {
+            existingName = m.propertyName.escapedText;
+          }
+        } else {
+          const name = getNameOfDeclaration(m);
+          existingName = name && isPropertyNameLiteral(name) ? getEscapedTextOfIdentifierOrLiteral(name) : void 0;
+        }
+        if (existingName !== void 0) {
+          existingMemberNames.add(existingName);
+        }
+      }
+      const filteredSymbols = contextualMemberSymbols.filter((m) => !existingMemberNames.has(m.escapedName));
+      setSortTextToMemberDeclaredBySpreadAssignment(membersDeclaredBySpreadAssignment, filteredSymbols);
+      return filteredSymbols;
     }
-    return factory.createQualifiedName(replaceFirstIdentifierOfEntityName(name.left, newIdentifier), name.right);
-  }
-  function importSymbols(importAdder, symbols) {
-    symbols.forEach((s) => importAdder.addImportFromExportedSymbol(
-      s,
-      /*isValidTypeOnlyUseSite*/
-      true
-    ));
-  }
-  function findAncestorMatchingSpan(sourceFile, span) {
-    const end = textSpanEnd(span);
-    let token = getTokenAtPosition(sourceFile, span.start);
-    while (token.end < end) {
-      token = token.parent;
+    function setMembersDeclaredBySpreadAssignment(declaration, membersDeclaredBySpreadAssignment) {
+      const expression = declaration.expression;
+      const symbol = typeChecker.getSymbolAtLocation(expression);
+      const type = symbol && typeChecker.getTypeOfSymbolAtLocation(symbol, expression);
+      const properties = type && type.properties;
+      if (properties) {
+        properties.forEach((property) => {
+          membersDeclaredBySpreadAssignment.add(property.name);
+        });
+      }
     }
-    return token;
-  }
-  var PreserveOptionalFlags;
-  var init_helpers2 = __esm({
-    "src/services/codefixes/helpers.ts"() {
-      "use strict";
-      init_ts4();
-      PreserveOptionalFlags = /* @__PURE__ */ ((PreserveOptionalFlags2) => {
-        PreserveOptionalFlags2[PreserveOptionalFlags2["Method"] = 1] = "Method";
-        PreserveOptionalFlags2[PreserveOptionalFlags2["Property"] = 2] = "Property";
-        PreserveOptionalFlags2[PreserveOptionalFlags2["All"] = 3] = "All";
-        return PreserveOptionalFlags2;
-      })(PreserveOptionalFlags || {});
+    function setSortTextToOptionalMember() {
+      symbols.forEach((m) => {
+        if (m.flags & 16777216 /* Optional */) {
+          const symbolId = getSymbolId(m);
+          symbolToSortTextMap[symbolId] = symbolToSortTextMap[symbolId] ?? SortText.OptionalMember;
+        }
+      });
     }
-  });
-
-  // src/services/codefixes/generateAccessors.ts
-  function generateAccessorFromProperty(file, program, start, end, context, _actionName) {
-    const fieldInfo = getAccessorConvertiblePropertyAtPosition(file, program, start, end);
-    if (!fieldInfo || ts_refactor_exports.isRefactorErrorInfo(fieldInfo))
-      return void 0;
-    const changeTracker = ts_textChanges_exports.ChangeTracker.fromContext(context);
-    const { isStatic: isStatic2, isReadonly, fieldName, accessorName, originalName, type, container, declaration } = fieldInfo;
-    suppressLeadingAndTrailingTrivia(fieldName);
-    suppressLeadingAndTrailingTrivia(accessorName);
-    suppressLeadingAndTrailingTrivia(declaration);
-    suppressLeadingAndTrailingTrivia(container);
-    let accessorModifiers;
-    let fieldModifiers;
-    if (isClassLike(container)) {
-      const modifierFlags = getEffectiveModifierFlags(declaration);
-      if (isSourceFileJS(file)) {
-        const modifiers = factory.createModifiersFromModifierFlags(modifierFlags);
-        accessorModifiers = modifiers;
-        fieldModifiers = modifiers;
-      } else {
-        accessorModifiers = factory.createModifiersFromModifierFlags(prepareModifierFlagsForAccessor(modifierFlags));
-        fieldModifiers = factory.createModifiersFromModifierFlags(prepareModifierFlagsForField(modifierFlags));
+    function setSortTextToMemberDeclaredBySpreadAssignment(membersDeclaredBySpreadAssignment, contextualMemberSymbols) {
+      if (membersDeclaredBySpreadAssignment.size === 0) {
+        return;
+      }
+      for (const contextualMemberSymbol of contextualMemberSymbols) {
+        if (membersDeclaredBySpreadAssignment.has(contextualMemberSymbol.name)) {
+          symbolToSortTextMap[getSymbolId(contextualMemberSymbol)] = SortText.MemberDeclaredBySpreadAssignment;
+        }
       }
-      if (canHaveDecorators(declaration)) {
-        fieldModifiers = concatenate(getDecorators(declaration), fieldModifiers);
+    }
+    function transformObjectLiteralMembersSortText(start2) {
+      for (let i = start2; i < symbols.length; i++) {
+        const symbol = symbols[i];
+        const symbolId = getSymbolId(symbol);
+        const origin = symbolToOriginInfoMap == null ? void 0 : symbolToOriginInfoMap[i];
+        const target = getEmitScriptTarget(compilerOptions);
+        const displayName = getCompletionEntryDisplayNameForSymbol(
+          symbol,
+          target,
+          origin,
+          0 /* ObjectPropertyDeclaration */,
+          /*jsxIdentifierExpected*/
+          false
+        );
+        if (displayName) {
+          const originalSortText = symbolToSortTextMap[symbolId] ?? SortText.LocationPriority;
+          const { name } = displayName;
+          symbolToSortTextMap[symbolId] = SortText.ObjectLiteralProperty(originalSortText, name);
+        }
       }
     }
-    updateFieldDeclaration(changeTracker, file, declaration, type, fieldName, fieldModifiers);
-    const getAccessor = generateGetAccessor(fieldName, accessorName, type, accessorModifiers, isStatic2, container);
-    suppressLeadingAndTrailingTrivia(getAccessor);
-    insertAccessor(changeTracker, file, getAccessor, declaration, container);
-    if (isReadonly) {
-      const constructor = getFirstConstructorWithBody(container);
-      if (constructor) {
-        updateReadonlyPropertyInitializerStatementConstructor(changeTracker, file, constructor, fieldName.text, originalName);
+    function filterClassMembersList(baseSymbols, existingMembers, currentClassElementModifierFlags) {
+      const existingMemberNames = /* @__PURE__ */ new Set();
+      for (const m of existingMembers) {
+        if (m.kind !== 172 /* PropertyDeclaration */ && m.kind !== 174 /* MethodDeclaration */ && m.kind !== 177 /* GetAccessor */ && m.kind !== 178 /* SetAccessor */) {
+          continue;
+        }
+        if (isCurrentlyEditingNode(m)) {
+          continue;
+        }
+        if (hasEffectiveModifier(m, 2 /* Private */)) {
+          continue;
+        }
+        if (isStatic(m) !== !!(currentClassElementModifierFlags & 256 /* Static */)) {
+          continue;
+        }
+        const existingName = getPropertyNameForPropertyNameNode(m.name);
+        if (existingName) {
+          existingMemberNames.add(existingName);
+        }
       }
-    } else {
-      const setAccessor = generateSetAccessor(fieldName, accessorName, type, accessorModifiers, isStatic2, container);
-      suppressLeadingAndTrailingTrivia(setAccessor);
-      insertAccessor(changeTracker, file, setAccessor, declaration, container);
+      return baseSymbols.filter(
+        (propertySymbol) => !existingMemberNames.has(propertySymbol.escapedName) && !!propertySymbol.declarations && !(getDeclarationModifierFlagsFromSymbol(propertySymbol) & 2 /* Private */) && !(propertySymbol.valueDeclaration && isPrivateIdentifierClassElementDeclaration(propertySymbol.valueDeclaration))
+      );
+    }
+    function filterJsxAttributes(symbols2, attributes) {
+      const seenNames = /* @__PURE__ */ new Set();
+      const membersDeclaredBySpreadAssignment = /* @__PURE__ */ new Set();
+      for (const attr of attributes) {
+        if (isCurrentlyEditingNode(attr)) {
+          continue;
+        }
+        if (attr.kind === 291 /* JsxAttribute */) {
+          seenNames.add(getEscapedTextOfJsxAttributeName(attr.name));
+        } else if (isJsxSpreadAttribute(attr)) {
+          setMembersDeclaredBySpreadAssignment(attr, membersDeclaredBySpreadAssignment);
+        }
+      }
+      const filteredSymbols = symbols2.filter((a) => !seenNames.has(a.escapedName));
+      setSortTextToMemberDeclaredBySpreadAssignment(membersDeclaredBySpreadAssignment, filteredSymbols);
+      return filteredSymbols;
+    }
+    function isCurrentlyEditingNode(node2) {
+      return node2.getStart(sourceFile) <= position && position <= node2.getEnd();
     }
-    return changeTracker.getChanges();
-  }
-  function isConvertibleName(name) {
-    return isIdentifier(name) || isStringLiteral(name);
-  }
-  function isAcceptedDeclaration(node) {
-    return isParameterPropertyDeclaration(node, node.parent) || isPropertyDeclaration(node) || isPropertyAssignment(node);
-  }
-  function createPropertyName(name, originalName) {
-    return isIdentifier(originalName) ? factory.createIdentifier(name) : factory.createStringLiteral(name);
   }
-  function createAccessorAccessExpression(fieldName, isStatic2, container) {
-    const leftHead = isStatic2 ? container.name : factory.createThis();
-    return isIdentifier(fieldName) ? factory.createPropertyAccessExpression(leftHead, fieldName) : factory.createElementAccessExpression(leftHead, factory.createStringLiteralFromNode(fieldName));
+  function tryGetObjectLikeCompletionContainer(contextToken, position, sourceFile) {
+    var _a;
+    if (contextToken) {
+      const { parent: parent2 } = contextToken;
+      switch (contextToken.kind) {
+        case 19 /* OpenBraceToken */:
+        case 28 /* CommaToken */:
+          if (isObjectLiteralExpression(parent2) || isObjectBindingPattern(parent2)) {
+            return parent2;
+          }
+          break;
+        case 42 /* AsteriskToken */:
+          return isMethodDeclaration(parent2) ? tryCast(parent2.parent, isObjectLiteralExpression) : void 0;
+        case 134 /* AsyncKeyword */:
+          return tryCast(parent2.parent, isObjectLiteralExpression);
+        case 80 /* Identifier */:
+          if (contextToken.text === "async" && isShorthandPropertyAssignment(contextToken.parent)) {
+            return contextToken.parent.parent;
+          } else {
+            if (isObjectLiteralExpression(contextToken.parent.parent) && (isSpreadAssignment(contextToken.parent) || isShorthandPropertyAssignment(contextToken.parent) && getLineAndCharacterOfPosition(sourceFile, contextToken.getEnd()).line !== getLineAndCharacterOfPosition(sourceFile, position).line)) {
+              return contextToken.parent.parent;
+            }
+            const ancestorNode2 = findAncestor(parent2, isPropertyAssignment);
+            if ((ancestorNode2 == null ? void 0 : ancestorNode2.getLastToken(sourceFile)) === contextToken && isObjectLiteralExpression(ancestorNode2.parent)) {
+              return ancestorNode2.parent;
+            }
+          }
+          break;
+        default:
+          if (((_a = parent2.parent) == null ? void 0 : _a.parent) && (isMethodDeclaration(parent2.parent) || isGetAccessorDeclaration(parent2.parent) || isSetAccessorDeclaration(parent2.parent)) && isObjectLiteralExpression(parent2.parent.parent)) {
+            return parent2.parent.parent;
+          }
+          if (isSpreadAssignment(parent2) && isObjectLiteralExpression(parent2.parent)) {
+            return parent2.parent;
+          }
+          const ancestorNode = findAncestor(parent2, isPropertyAssignment);
+          if (contextToken.kind !== 59 /* ColonToken */ && (ancestorNode == null ? void 0 : ancestorNode.getLastToken(sourceFile)) === contextToken && isObjectLiteralExpression(ancestorNode.parent)) {
+            return ancestorNode.parent;
+          }
+      }
+    }
+    return void 0;
   }
-  function prepareModifierFlagsForAccessor(modifierFlags) {
-    modifierFlags &= ~64 /* Readonly */;
-    modifierFlags &= ~8 /* Private */;
-    if (!(modifierFlags & 16 /* Protected */)) {
-      modifierFlags |= 4 /* Public */;
+  function getRelevantTokens(position, sourceFile) {
+    const previousToken = findPrecedingToken(position, sourceFile);
+    if (previousToken && position <= previousToken.end && (isMemberName(previousToken) || isKeyword(previousToken.kind))) {
+      const contextToken = findPrecedingToken(
+        previousToken.getFullStart(),
+        sourceFile,
+        /*startNode*/
+        void 0
+      );
+      return { contextToken, previousToken };
     }
-    return modifierFlags;
+    return { contextToken: previousToken, previousToken };
   }
-  function prepareModifierFlagsForField(modifierFlags) {
-    modifierFlags &= ~4 /* Public */;
-    modifierFlags &= ~16 /* Protected */;
-    modifierFlags |= 8 /* Private */;
-    return modifierFlags;
+  function getAutoImportSymbolFromCompletionEntryData(name, data, program, host) {
+    const containingProgram = data.isPackageJsonImport ? host.getPackageJsonAutoImportProvider() : program;
+    const checker = containingProgram.getTypeChecker();
+    const moduleSymbol = data.ambientModuleName ? checker.tryFindAmbientModule(data.ambientModuleName) : data.fileName ? checker.getMergedSymbol(Debug.checkDefined(containingProgram.getSourceFile(data.fileName)).symbol) : void 0;
+    if (!moduleSymbol)
+      return void 0;
+    let symbol = data.exportName === "export=" /* ExportEquals */ ? checker.resolveExternalModuleSymbol(moduleSymbol) : checker.tryGetMemberInModuleExportsAndProperties(data.exportName, moduleSymbol);
+    if (!symbol)
+      return void 0;
+    const isDefaultExport = data.exportName === "default" /* Default */;
+    symbol = isDefaultExport && getLocalSymbolForExportDefault(symbol) || symbol;
+    return { symbol, origin: completionEntryDataToSymbolOriginInfo(data, name, moduleSymbol) };
   }
-  function getAccessorConvertiblePropertyAtPosition(file, program, start, end, considerEmptySpans = true) {
-    const node = getTokenAtPosition(file, start);
-    const cursorRequest = start === end && considerEmptySpans;
-    const declaration = findAncestor(node.parent, isAcceptedDeclaration);
-    const meaning = 28 /* AccessibilityModifier */ | 32 /* Static */ | 64 /* Readonly */;
-    if (!declaration || !(nodeOverlapsWithStartEnd(declaration.name, file, start, end) || cursorRequest)) {
-      return {
-        error: getLocaleSpecificMessage(Diagnostics.Could_not_find_property_for_which_to_generate_accessor)
-      };
-    }
-    if (!isConvertibleName(declaration.name)) {
-      return {
-        error: getLocaleSpecificMessage(Diagnostics.Name_is_not_valid)
-      };
+  function getCompletionEntryDisplayNameForSymbol(symbol, target, origin, kind, jsxIdentifierExpected) {
+    if (originIsIgnore(origin)) {
+      return void 0;
     }
-    if ((getEffectiveModifierFlags(declaration) & 126975 /* Modifier */ | meaning) !== meaning) {
-      return {
-        error: getLocaleSpecificMessage(Diagnostics.Can_only_convert_property_with_modifier)
-      };
+    const name = originIncludesSymbolName(origin) ? origin.symbolName : symbol.name;
+    if (name === void 0 || symbol.flags & 1536 /* Module */ && isSingleOrDoubleQuote(name.charCodeAt(0)) || isKnownSymbol(symbol)) {
+      return void 0;
     }
-    const name = declaration.name.text;
-    const startWithUnderscore = startsWithUnderscore(name);
-    const fieldName = createPropertyName(startWithUnderscore ? name : getUniqueName(`_${name}`, file), declaration.name);
-    const accessorName = createPropertyName(startWithUnderscore ? getUniqueName(name.substring(1), file) : name, declaration.name);
-    return {
-      isStatic: hasStaticModifier(declaration),
-      isReadonly: hasEffectiveReadonlyModifier(declaration),
-      type: getDeclarationType(declaration, program),
-      container: declaration.kind === 168 /* Parameter */ ? declaration.parent.parent : declaration.parent,
-      originalName: declaration.name.text,
-      declaration,
-      fieldName,
-      accessorName,
-      renameAccessor: startWithUnderscore
-    };
-  }
-  function generateGetAccessor(fieldName, accessorName, type, modifiers, isStatic2, container) {
-    return factory.createGetAccessorDeclaration(
-      modifiers,
-      accessorName,
-      [],
-      type,
-      factory.createBlock(
-        [
-          factory.createReturnStatement(
-            createAccessorAccessExpression(fieldName, isStatic2, container)
-          )
-        ],
-        /*multiLine*/
-        true
-      )
-    );
-  }
-  function generateSetAccessor(fieldName, accessorName, type, modifiers, isStatic2, container) {
-    return factory.createSetAccessorDeclaration(
-      modifiers,
-      accessorName,
-      [factory.createParameterDeclaration(
-        /*modifiers*/
-        void 0,
-        /*dotDotDotToken*/
-        void 0,
-        factory.createIdentifier("value"),
-        /*questionToken*/
-        void 0,
-        type
-      )],
-      factory.createBlock(
-        [
-          factory.createExpressionStatement(
-            factory.createAssignment(
-              createAccessorAccessExpression(fieldName, isStatic2, container),
-              factory.createIdentifier("value")
-            )
-          )
-        ],
-        /*multiLine*/
-        true
-      )
-    );
-  }
-  function updatePropertyDeclaration(changeTracker, file, declaration, type, fieldName, modifiers) {
-    const property = factory.updatePropertyDeclaration(
-      declaration,
-      modifiers,
-      fieldName,
-      declaration.questionToken || declaration.exclamationToken,
-      type,
-      declaration.initializer
-    );
-    changeTracker.replaceNode(file, declaration, property);
-  }
-  function updatePropertyAssignmentDeclaration(changeTracker, file, declaration, fieldName) {
-    let assignment = factory.updatePropertyAssignment(declaration, fieldName, declaration.initializer);
-    if (assignment.modifiers || assignment.questionToken || assignment.exclamationToken) {
-      if (assignment === declaration)
-        assignment = factory.cloneNode(assignment);
-      assignment.modifiers = void 0;
-      assignment.questionToken = void 0;
-      assignment.exclamationToken = void 0;
+    const validNameResult = { name, needsConvertPropertyAccess: false };
+    if (isIdentifierText(name, target, jsxIdentifierExpected ? 1 /* JSX */ : 0 /* Standard */) || symbol.valueDeclaration && isPrivateIdentifierClassElementDeclaration(symbol.valueDeclaration)) {
+      return validNameResult;
     }
-    changeTracker.replacePropertyAssignment(file, declaration, assignment);
-  }
-  function updateFieldDeclaration(changeTracker, file, declaration, type, fieldName, modifiers) {
-    if (isPropertyDeclaration(declaration)) {
-      updatePropertyDeclaration(changeTracker, file, declaration, type, fieldName, modifiers);
-    } else if (isPropertyAssignment(declaration)) {
-      updatePropertyAssignmentDeclaration(changeTracker, file, declaration, fieldName);
-    } else {
-      changeTracker.replaceNode(
-        file,
-        declaration,
-        factory.updateParameterDeclaration(declaration, modifiers, declaration.dotDotDotToken, cast(fieldName, isIdentifier), declaration.questionToken, declaration.type, declaration.initializer)
-      );
+    switch (kind) {
+      case 3 /* MemberLike */:
+        return originIsComputedPropertyName(origin) ? { name: origin.symbolName, needsConvertPropertyAccess: false } : void 0;
+      case 0 /* ObjectPropertyDeclaration */:
+        return { name: JSON.stringify(name), needsConvertPropertyAccess: false };
+      case 2 /* PropertyAccess */:
+      case 1 /* Global */:
+        return name.charCodeAt(0) === 32 /* space */ ? void 0 : { name, needsConvertPropertyAccess: true };
+      case 5 /* None */:
+      case 4 /* String */:
+        return validNameResult;
+      default:
+        Debug.assertNever(kind);
     }
   }
-  function insertAccessor(changeTracker, file, accessor, declaration, container) {
-    isParameterPropertyDeclaration(declaration, declaration.parent) ? changeTracker.insertMemberAtStart(file, container, accessor) : isPropertyAssignment(declaration) ? changeTracker.insertNodeAfterComma(file, declaration, accessor) : changeTracker.insertNodeAfter(file, declaration, accessor);
+  function getKeywordCompletions(keywordFilter, filterOutTsOnlyKeywords) {
+    if (!filterOutTsOnlyKeywords)
+      return getTypescriptKeywordCompletions(keywordFilter);
+    const index = keywordFilter + 8 /* Last */ + 1;
+    return _keywordCompletions[index] || (_keywordCompletions[index] = getTypescriptKeywordCompletions(keywordFilter).filter((entry) => !isTypeScriptOnlyKeyword(stringToToken(entry.name))));
   }
-  function updateReadonlyPropertyInitializerStatementConstructor(changeTracker, file, constructor, fieldName, originalName) {
-    if (!constructor.body)
-      return;
-    constructor.body.forEachChild(function recur(node) {
-      if (isElementAccessExpression(node) && node.expression.kind === 110 /* ThisKeyword */ && isStringLiteral(node.argumentExpression) && node.argumentExpression.text === originalName && isWriteAccess(node)) {
-        changeTracker.replaceNode(file, node.argumentExpression, factory.createStringLiteral(fieldName));
-      }
-      if (isPropertyAccessExpression(node) && node.expression.kind === 110 /* ThisKeyword */ && node.name.text === originalName && isWriteAccess(node)) {
-        changeTracker.replaceNode(file, node.name, factory.createIdentifier(fieldName));
-      }
-      if (!isFunctionLike(node) && !isClassLike(node)) {
-        node.forEachChild(recur);
+  function getTypescriptKeywordCompletions(keywordFilter) {
+    return _keywordCompletions[keywordFilter] || (_keywordCompletions[keywordFilter] = allKeywordsCompletions().filter((entry) => {
+      const kind = stringToToken(entry.name);
+      switch (keywordFilter) {
+        case 0 /* None */:
+          return false;
+        case 1 /* All */:
+          return isFunctionLikeBodyKeyword(kind) || kind === 138 /* DeclareKeyword */ || kind === 144 /* ModuleKeyword */ || kind === 156 /* TypeKeyword */ || kind === 145 /* NamespaceKeyword */ || kind === 128 /* AbstractKeyword */ || isTypeKeyword(kind) && kind !== 157 /* UndefinedKeyword */;
+        case 5 /* FunctionLikeBodyKeywords */:
+          return isFunctionLikeBodyKeyword(kind);
+        case 2 /* ClassElementKeywords */:
+          return isClassMemberCompletionKeyword(kind);
+        case 3 /* InterfaceElementKeywords */:
+          return isInterfaceOrTypeLiteralCompletionKeyword(kind);
+        case 4 /* ConstructorParameterKeywords */:
+          return isParameterPropertyModifier(kind);
+        case 6 /* TypeAssertionKeywords */:
+          return isTypeKeyword(kind) || kind === 87 /* ConstKeyword */;
+        case 7 /* TypeKeywords */:
+          return isTypeKeyword(kind);
+        case 8 /* TypeKeyword */:
+          return kind === 156 /* TypeKeyword */;
+        default:
+          return Debug.assertNever(keywordFilter);
       }
-    });
+    }));
   }
-  function getDeclarationType(declaration, program) {
-    const typeNode = getTypeAnnotationNode(declaration);
-    if (isPropertyDeclaration(declaration) && typeNode && declaration.questionToken) {
-      const typeChecker = program.getTypeChecker();
-      const type = typeChecker.getTypeFromTypeNode(typeNode);
-      if (!typeChecker.isTypeAssignableTo(typeChecker.getUndefinedType(), type)) {
-        const types = isUnionTypeNode(typeNode) ? typeNode.types : [typeNode];
-        return factory.createUnionTypeNode([...types, factory.createKeywordTypeNode(157 /* UndefinedKeyword */)]);
-      }
+  function isTypeScriptOnlyKeyword(kind) {
+    switch (kind) {
+      case 128 /* AbstractKeyword */:
+      case 133 /* AnyKeyword */:
+      case 163 /* BigIntKeyword */:
+      case 136 /* BooleanKeyword */:
+      case 138 /* DeclareKeyword */:
+      case 94 /* EnumKeyword */:
+      case 162 /* GlobalKeyword */:
+      case 119 /* ImplementsKeyword */:
+      case 140 /* InferKeyword */:
+      case 120 /* InterfaceKeyword */:
+      case 142 /* IsKeyword */:
+      case 143 /* KeyOfKeyword */:
+      case 144 /* ModuleKeyword */:
+      case 145 /* NamespaceKeyword */:
+      case 146 /* NeverKeyword */:
+      case 150 /* NumberKeyword */:
+      case 151 /* ObjectKeyword */:
+      case 164 /* OverrideKeyword */:
+      case 123 /* PrivateKeyword */:
+      case 124 /* ProtectedKeyword */:
+      case 125 /* PublicKeyword */:
+      case 148 /* ReadonlyKeyword */:
+      case 154 /* StringKeyword */:
+      case 155 /* SymbolKeyword */:
+      case 156 /* TypeKeyword */:
+      case 158 /* UniqueKeyword */:
+      case 159 /* UnknownKeyword */:
+        return true;
+      default:
+        return false;
     }
-    return typeNode;
   }
-  function getAllSupers(decl, checker) {
-    const res = [];
-    while (decl) {
-      const superElement = getClassExtendsHeritageElement(decl);
-      const superSymbol = superElement && checker.getSymbolAtLocation(superElement.expression);
-      if (!superSymbol)
-        break;
-      const symbol = superSymbol.flags & 2097152 /* Alias */ ? checker.getAliasedSymbol(superSymbol) : superSymbol;
-      const superDecl = symbol.declarations && find(symbol.declarations, isClassLike);
-      if (!superDecl)
-        break;
-      res.push(superDecl);
-      decl = superDecl;
-    }
-    return res;
+  function isInterfaceOrTypeLiteralCompletionKeyword(kind) {
+    return kind === 148 /* ReadonlyKeyword */;
   }
-  var init_generateAccessors = __esm({
-    "src/services/codefixes/generateAccessors.ts"() {
-      "use strict";
-      init_ts4();
-    }
-  });
-
-  // src/services/codefixes/fixInvalidImportSyntax.ts
-  function getCodeFixesForImportDeclaration(context, node) {
-    const sourceFile = getSourceFileOfNode(node);
-    const namespace = getNamespaceDeclarationNode(node);
-    const opts = context.program.getCompilerOptions();
-    const variations = [];
-    variations.push(createAction(context, sourceFile, node, makeImport(
-      namespace.name,
-      /*namedImports*/
-      void 0,
-      node.moduleSpecifier,
-      getQuotePreference(sourceFile, context.preferences)
-    )));
-    if (getEmitModuleKind(opts) === 1 /* CommonJS */) {
-      variations.push(createAction(context, sourceFile, node, factory.createImportEqualsDeclaration(
-        /*modifiers*/
-        void 0,
-        /*isTypeOnly*/
-        false,
-        namespace.name,
-        factory.createExternalModuleReference(node.moduleSpecifier)
-      )));
+  function isClassMemberCompletionKeyword(kind) {
+    switch (kind) {
+      case 128 /* AbstractKeyword */:
+      case 129 /* AccessorKeyword */:
+      case 137 /* ConstructorKeyword */:
+      case 139 /* GetKeyword */:
+      case 153 /* SetKeyword */:
+      case 134 /* AsyncKeyword */:
+      case 138 /* DeclareKeyword */:
+      case 164 /* OverrideKeyword */:
+        return true;
+      default:
+        return isClassMemberModifier(kind);
     }
-    return variations;
   }
-  function createAction(context, sourceFile, node, replacement) {
-    const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => t.replaceNode(sourceFile, node, replacement));
-    return createCodeFixActionWithoutFixAll(fixName5, changes, [Diagnostics.Replace_import_with_0, changes[0].textChanges[0].newText]);
+  function isFunctionLikeBodyKeyword(kind) {
+    return kind === 134 /* AsyncKeyword */ || kind === 135 /* AwaitKeyword */ || kind === 130 /* AsKeyword */ || kind === 152 /* SatisfiesKeyword */ || kind === 156 /* TypeKeyword */ || !isContextualKeyword(kind) && !isClassMemberCompletionKeyword(kind);
   }
-  function getActionsForUsageOfInvalidImport(context) {
-    const sourceFile = context.sourceFile;
-    const targetKind = Diagnostics.This_expression_is_not_callable.code === context.errorCode ? 212 /* CallExpression */ : 213 /* NewExpression */;
-    const node = findAncestor(getTokenAtPosition(sourceFile, context.span.start), (a) => a.kind === targetKind);
-    if (!node) {
-      return [];
-    }
-    const expr = node.expression;
-    return getImportCodeFixesForExpression(context, expr);
+  function keywordForNode(node) {
+    return isIdentifier(node) ? identifierToKeywordKind(node) ?? 0 /* Unknown */ : node.kind;
   }
-  function getActionsForInvalidImportLocation(context) {
-    const sourceFile = context.sourceFile;
-    const node = findAncestor(getTokenAtPosition(sourceFile, context.span.start), (a) => a.getStart() === context.span.start && a.getEnd() === context.span.start + context.span.length);
-    if (!node) {
-      return [];
+  function getContextualKeywords(contextToken, position) {
+    const entries = [];
+    if (contextToken) {
+      const file = contextToken.getSourceFile();
+      const parent2 = contextToken.parent;
+      const tokenLine = file.getLineAndCharacterOfPosition(contextToken.end).line;
+      const currentLine = file.getLineAndCharacterOfPosition(position).line;
+      if ((isImportDeclaration(parent2) || isExportDeclaration(parent2) && parent2.moduleSpecifier) && contextToken === parent2.moduleSpecifier && tokenLine === currentLine) {
+        entries.push({
+          name: tokenToString(132 /* AssertKeyword */),
+          kind: "keyword" /* keyword */,
+          kindModifiers: "" /* none */,
+          sortText: SortText.GlobalsOrKeywords
+        });
+      }
     }
-    return getImportCodeFixesForExpression(context, node);
+    return entries;
   }
-  function getImportCodeFixesForExpression(context, expr) {
-    const type = context.program.getTypeChecker().getTypeAtLocation(expr);
-    if (!(type.symbol && isTransientSymbol(type.symbol) && type.symbol.links.originatingImport)) {
-      return [];
-    }
-    const fixes = [];
-    const relatedImport = type.symbol.links.originatingImport;
-    if (!isImportCall(relatedImport)) {
-      addRange(fixes, getCodeFixesForImportDeclaration(context, relatedImport));
-    }
-    if (isExpression(expr) && !(isNamedDeclaration(expr.parent) && expr.parent.name === expr)) {
-      const sourceFile = context.sourceFile;
-      const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => t.replaceNode(sourceFile, expr, factory.createPropertyAccessExpression(expr, "default"), {}));
-      fixes.push(createCodeFixActionWithoutFixAll(fixName5, changes, Diagnostics.Use_synthetic_default_member));
-    }
-    return fixes;
+  function getJsDocTagAtPosition(node, position) {
+    return findAncestor(node, (n) => isJSDocTag(n) && rangeContainsPosition(n, position) ? true : isJSDoc(n) ? "quit" : false);
   }
-  var fixName5;
-  var init_fixInvalidImportSyntax = __esm({
-    "src/services/codefixes/fixInvalidImportSyntax.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_codefix();
-      fixName5 = "invalidImportSyntax";
-      registerCodeFix({
-        errorCodes: [
-          Diagnostics.This_expression_is_not_callable.code,
-          Diagnostics.This_expression_is_not_constructable.code
-        ],
-        getCodeActions: getActionsForUsageOfInvalidImport
-      });
-      registerCodeFix({
-        errorCodes: [
-          // The following error codes cover pretty much all assignability errors that could involve an expression
-          Diagnostics.Argument_of_type_0_is_not_assignable_to_parameter_of_type_1.code,
-          Diagnostics.Type_0_does_not_satisfy_the_constraint_1.code,
-          Diagnostics.Type_0_is_not_assignable_to_type_1.code,
-          Diagnostics.Type_0_is_not_assignable_to_type_1_Two_different_types_with_this_name_exist_but_they_are_unrelated.code,
-          Diagnostics.Type_predicate_0_is_not_assignable_to_1.code,
-          Diagnostics.Property_0_of_type_1_is_not_assignable_to_2_index_type_3.code,
-          Diagnostics._0_index_type_1_is_not_assignable_to_2_index_type_3.code,
-          Diagnostics.Property_0_in_type_1_is_not_assignable_to_the_same_property_in_base_type_2.code,
-          Diagnostics.Property_0_in_type_1_is_not_assignable_to_type_2.code,
-          Diagnostics.Property_0_of_JSX_spread_attribute_is_not_assignable_to_target_property.code,
-          Diagnostics.The_this_context_of_type_0_is_not_assignable_to_method_s_this_of_type_1.code
-        ],
-        getCodeActions: getActionsForInvalidImportLocation
-      });
-    }
-  });
-
-  // src/services/codefixes/fixStrictClassInitialization.ts
-  function getInfo16(sourceFile, pos) {
-    const token = getTokenAtPosition(sourceFile, pos);
-    if (isIdentifier(token) && isPropertyDeclaration(token.parent)) {
-      const type = getEffectiveTypeAnnotationNode(token.parent);
-      if (type) {
-        return { type, prop: token.parent, isJs: isInJSFile(token.parent) };
-      }
+  function getPropertiesForObjectExpression(contextualType, completionsType, obj, checker) {
+    const hasCompletionsType = completionsType && completionsType !== contextualType;
+    const type = hasCompletionsType && !(completionsType.flags & 3 /* AnyOrUnknown */) ? checker.getUnionType([contextualType, completionsType]) : contextualType;
+    const properties = getApparentProperties(type, obj, checker);
+    return type.isClass() && containsNonPublicProperties(properties) ? [] : hasCompletionsType ? filter(properties, hasDeclarationOtherThanSelf) : properties;
+    function hasDeclarationOtherThanSelf(member) {
+      if (!length(member.declarations))
+        return true;
+      return some(member.declarations, (decl) => decl.parent !== obj);
     }
-    return void 0;
   }
-  function getActionForAddMissingDefiniteAssignmentAssertion(context, info) {
-    if (info.isJs)
-      return void 0;
-    const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => addDefiniteAssignmentAssertion(t, context.sourceFile, info.prop));
-    return createCodeFixAction(fixName6, changes, [Diagnostics.Add_definite_assignment_assertion_to_property_0, info.prop.getText()], fixIdAddDefiniteAssignmentAssertions, Diagnostics.Add_definite_assignment_assertions_to_all_uninitialized_properties);
+  function getApparentProperties(type, node, checker) {
+    if (!type.isUnion())
+      return type.getApparentProperties();
+    return checker.getAllPossiblePropertiesOfTypes(filter(type.types, (memberType) => !(memberType.flags & 402784252 /* Primitive */ || checker.isArrayLikeType(memberType) || checker.isTypeInvalidDueToUnionDiscriminant(memberType, node) || checker.typeHasCallOrConstructSignatures(memberType) || memberType.isClass() && containsNonPublicProperties(memberType.getApparentProperties()))));
   }
-  function addDefiniteAssignmentAssertion(changeTracker, propertyDeclarationSourceFile, propertyDeclaration) {
-    suppressLeadingAndTrailingTrivia(propertyDeclaration);
-    const property = factory.updatePropertyDeclaration(
-      propertyDeclaration,
-      propertyDeclaration.modifiers,
-      propertyDeclaration.name,
-      factory.createToken(54 /* ExclamationToken */),
-      propertyDeclaration.type,
-      propertyDeclaration.initializer
-    );
-    changeTracker.replaceNode(propertyDeclarationSourceFile, propertyDeclaration, property);
+  function containsNonPublicProperties(props) {
+    return some(props, (p) => !!(getDeclarationModifierFlagsFromSymbol(p) & 6 /* NonPublicAccessibilityModifier */));
   }
-  function getActionForAddMissingUndefinedType(context, info) {
-    const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => addUndefinedType(t, context.sourceFile, info));
-    return createCodeFixAction(fixName6, changes, [Diagnostics.Add_undefined_type_to_property_0, info.prop.name.getText()], fixIdAddUndefinedType, Diagnostics.Add_undefined_type_to_all_uninitialized_properties);
+  function getPropertiesForCompletion(type, checker) {
+    return type.isUnion() ? Debug.checkEachDefined(checker.getAllPossiblePropertiesOfTypes(type.types), "getAllPossiblePropertiesOfTypes() should all be defined") : Debug.checkEachDefined(type.getApparentProperties(), "getApparentProperties() should all be defined");
   }
-  function addUndefinedType(changeTracker, sourceFile, info) {
-    const undefinedTypeNode = factory.createKeywordTypeNode(157 /* UndefinedKeyword */);
-    const types = isUnionTypeNode(info.type) ? info.type.types.concat(undefinedTypeNode) : [info.type, undefinedTypeNode];
-    const unionTypeNode = factory.createUnionTypeNode(types);
-    if (info.isJs) {
-      changeTracker.addJSDocTags(sourceFile, info.prop, [factory.createJSDocTypeTag(
-        /*tagName*/
-        void 0,
-        factory.createJSDocTypeExpression(unionTypeNode)
-      )]);
-    } else {
-      changeTracker.replaceNode(sourceFile, info.type, unionTypeNode);
+  function tryGetObjectTypeDeclarationCompletionContainer(sourceFile, contextToken, location, position) {
+    switch (location.kind) {
+      case 358 /* SyntaxList */:
+        return tryCast(location.parent, isObjectTypeDeclaration);
+      case 1 /* EndOfFileToken */:
+        const cls = tryCast(lastOrUndefined(cast(location.parent, isSourceFile).statements), isObjectTypeDeclaration);
+        if (cls && !findChildOfKind(cls, 20 /* CloseBraceToken */, sourceFile)) {
+          return cls;
+        }
+        break;
+      case 81 /* PrivateIdentifier */:
+        if (tryCast(location.parent, isPropertyDeclaration)) {
+          return findAncestor(location, isClassLike);
+        }
+        break;
+      case 80 /* Identifier */: {
+        const originalKeywordKind = identifierToKeywordKind(location);
+        if (originalKeywordKind) {
+          return void 0;
+        }
+        if (isPropertyDeclaration(location.parent) && location.parent.initializer === location) {
+          return void 0;
+        }
+        if (isFromObjectTypeDeclaration(location)) {
+          return findAncestor(location, isObjectTypeDeclaration);
+        }
+      }
     }
-  }
-  function getActionForAddMissingInitializer(context, info) {
-    if (info.isJs)
-      return void 0;
-    const checker = context.program.getTypeChecker();
-    const initializer = getInitializer(checker, info.prop);
-    if (!initializer)
+    if (!contextToken)
       return void 0;
-    const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => addInitializer(t, context.sourceFile, info.prop, initializer));
-    return createCodeFixAction(fixName6, changes, [Diagnostics.Add_initializer_to_property_0, info.prop.name.getText()], fixIdAddInitializer, Diagnostics.Add_initializers_to_all_uninitialized_properties);
-  }
-  function addInitializer(changeTracker, propertyDeclarationSourceFile, propertyDeclaration, initializer) {
-    suppressLeadingAndTrailingTrivia(propertyDeclaration);
-    const property = factory.updatePropertyDeclaration(
-      propertyDeclaration,
-      propertyDeclaration.modifiers,
-      propertyDeclaration.name,
-      propertyDeclaration.questionToken,
-      propertyDeclaration.type,
-      initializer
-    );
-    changeTracker.replaceNode(propertyDeclarationSourceFile, propertyDeclaration, property);
-  }
-  function getInitializer(checker, propertyDeclaration) {
-    return getDefaultValueFromType(checker, checker.getTypeFromTypeNode(propertyDeclaration.type));
-  }
-  function getDefaultValueFromType(checker, type) {
-    if (type.flags & 512 /* BooleanLiteral */) {
-      return type === checker.getFalseType() || type === checker.getFalseType(
-        /*fresh*/
-        true
-      ) ? factory.createFalse() : factory.createTrue();
-    } else if (type.isStringLiteral()) {
-      return factory.createStringLiteral(type.value);
-    } else if (type.isNumberLiteral()) {
-      return factory.createNumericLiteral(type.value);
-    } else if (type.flags & 2048 /* BigIntLiteral */) {
-      return factory.createBigIntLiteral(type.value);
-    } else if (type.isUnion()) {
-      return firstDefined(type.types, (t) => getDefaultValueFromType(checker, t));
-    } else if (type.isClass()) {
-      const classDeclaration = getClassLikeDeclarationOfSymbol(type.symbol);
-      if (!classDeclaration || hasSyntacticModifier(classDeclaration, 256 /* Abstract */))
+    if (location.kind === 137 /* ConstructorKeyword */ || isIdentifier(contextToken) && isPropertyDeclaration(contextToken.parent) && isClassLike(location)) {
+      return findAncestor(contextToken, isClassLike);
+    }
+    switch (contextToken.kind) {
+      case 64 /* EqualsToken */:
         return void 0;
-      const constructorDeclaration = getFirstConstructorWithBody(classDeclaration);
-      if (constructorDeclaration && constructorDeclaration.parameters.length)
+      case 27 /* SemicolonToken */:
+      case 20 /* CloseBraceToken */:
+        return isFromObjectTypeDeclaration(location) && location.parent.name === location ? location.parent.parent : tryCast(location, isObjectTypeDeclaration);
+      case 19 /* OpenBraceToken */:
+      case 28 /* CommaToken */:
+        return tryCast(contextToken.parent, isObjectTypeDeclaration);
+      default:
+        if (isObjectTypeDeclaration(location)) {
+          if (getLineAndCharacterOfPosition(sourceFile, contextToken.getEnd()).line !== getLineAndCharacterOfPosition(sourceFile, position).line) {
+            return location;
+          }
+          const isValidKeyword = isClassLike(contextToken.parent.parent) ? isClassMemberCompletionKeyword : isInterfaceOrTypeLiteralCompletionKeyword;
+          return isValidKeyword(contextToken.kind) || contextToken.kind === 42 /* AsteriskToken */ || isIdentifier(contextToken) && isValidKeyword(identifierToKeywordKind(contextToken) ?? 0 /* Unknown */) ? contextToken.parent.parent : void 0;
+        }
         return void 0;
-      return factory.createNewExpression(
-        factory.createIdentifier(type.symbol.name),
-        /*typeArguments*/
-        void 0,
-        /*argumentsArray*/
-        void 0
-      );
-    } else if (checker.isArrayLikeType(type)) {
-      return factory.createArrayLiteralExpression();
     }
-    return void 0;
   }
-  var fixName6, fixIdAddDefiniteAssignmentAssertions, fixIdAddUndefinedType, fixIdAddInitializer, errorCodes51;
-  var init_fixStrictClassInitialization = __esm({
-    "src/services/codefixes/fixStrictClassInitialization.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_codefix();
-      fixName6 = "strictClassInitialization";
-      fixIdAddDefiniteAssignmentAssertions = "addMissingPropertyDefiniteAssignmentAssertions";
-      fixIdAddUndefinedType = "addMissingPropertyUndefinedType";
-      fixIdAddInitializer = "addMissingPropertyInitializer";
-      errorCodes51 = [Diagnostics.Property_0_has_no_initializer_and_is_not_definitely_assigned_in_the_constructor.code];
-      registerCodeFix({
-        errorCodes: errorCodes51,
-        getCodeActions: function getCodeActionsForStrictClassInitializationErrors(context) {
-          const info = getInfo16(context.sourceFile, context.span.start);
-          if (!info)
-            return;
-          const result = [];
-          append(result, getActionForAddMissingUndefinedType(context, info));
-          append(result, getActionForAddMissingDefiniteAssignmentAssertion(context, info));
-          append(result, getActionForAddMissingInitializer(context, info));
-          return result;
-        },
-        fixIds: [fixIdAddDefiniteAssignmentAssertions, fixIdAddUndefinedType, fixIdAddInitializer],
-        getAllCodeActions: (context) => {
-          return codeFixAll(context, errorCodes51, (changes, diag2) => {
-            const info = getInfo16(diag2.file, diag2.start);
-            if (!info)
-              return;
-            switch (context.fixId) {
-              case fixIdAddDefiniteAssignmentAssertions:
-                addDefiniteAssignmentAssertion(changes, diag2.file, info.prop);
-                break;
-              case fixIdAddUndefinedType:
-                addUndefinedType(changes, diag2.file, info);
-                break;
-              case fixIdAddInitializer:
-                const checker = context.program.getTypeChecker();
-                const initializer = getInitializer(checker, info.prop);
-                if (!initializer)
-                  return;
-                addInitializer(changes, diag2.file, info.prop, initializer);
-                break;
-              default:
-                Debug.fail(JSON.stringify(context.fixId));
-            }
-          });
+  function tryGetTypeLiteralNode(node) {
+    if (!node)
+      return void 0;
+    const parent2 = node.parent;
+    switch (node.kind) {
+      case 19 /* OpenBraceToken */:
+        if (isTypeLiteralNode(parent2)) {
+          return parent2;
         }
-      });
+        break;
+      case 27 /* SemicolonToken */:
+      case 28 /* CommaToken */:
+      case 80 /* Identifier */:
+        if (parent2.kind === 171 /* PropertySignature */ && isTypeLiteralNode(parent2.parent)) {
+          return parent2.parent;
+        }
+        break;
     }
-  });
-
-  // src/services/codefixes/requireInTs.ts
-  function doChange34(changes, sourceFile, info) {
-    const { allowSyntheticDefaults, defaultImportName, namedImports, statement, required } = info;
-    changes.replaceNode(sourceFile, statement, defaultImportName && !allowSyntheticDefaults ? factory.createImportEqualsDeclaration(
-      /*modifiers*/
-      void 0,
-      /*isTypeOnly*/
-      false,
-      defaultImportName,
-      factory.createExternalModuleReference(required)
-    ) : factory.createImportDeclaration(
-      /*modifiers*/
-      void 0,
-      factory.createImportClause(
-        /*isTypeOnly*/
-        false,
-        defaultImportName,
-        namedImports
-      ),
-      required,
-      /*assertClause*/
-      void 0
-    ));
+    return void 0;
   }
-  function getInfo17(sourceFile, program, pos) {
-    const { parent: parent2 } = getTokenAtPosition(sourceFile, pos);
-    if (!isRequireCall(
-      parent2,
-      /*requireStringLiteralLikeArgument*/
-      true
-    )) {
-      Debug.failBadSyntaxKind(parent2);
+  function getConstraintOfTypeArgumentProperty(node, checker) {
+    if (!node)
+      return void 0;
+    if (isTypeNode(node) && isTypeReferenceType(node.parent)) {
+      return checker.getTypeArgumentConstraint(node);
     }
-    const decl = cast(parent2.parent, isVariableDeclaration);
-    const defaultImportName = tryCast(decl.name, isIdentifier);
-    const namedImports = isObjectBindingPattern(decl.name) ? tryCreateNamedImportsFromObjectBindingPattern(decl.name) : void 0;
-    if (defaultImportName || namedImports) {
-      return {
-        allowSyntheticDefaults: getAllowSyntheticDefaultImports(program.getCompilerOptions()),
-        defaultImportName,
-        namedImports,
-        statement: cast(decl.parent.parent, isVariableStatement),
-        required: first(parent2.arguments)
-      };
+    const t = getConstraintOfTypeArgumentProperty(node.parent, checker);
+    if (!t)
+      return void 0;
+    switch (node.kind) {
+      case 171 /* PropertySignature */:
+        return checker.getTypeOfPropertyOfContextualType(t, node.symbol.escapedName);
+      case 193 /* IntersectionType */:
+      case 187 /* TypeLiteral */:
+      case 192 /* UnionType */:
+        return t;
     }
   }
-  function tryCreateNamedImportsFromObjectBindingPattern(node) {
-    const importSpecifiers = [];
-    for (const element of node.elements) {
-      if (!isIdentifier(element.name) || element.initializer) {
-        return void 0;
-      }
-      importSpecifiers.push(factory.createImportSpecifier(
-        /*isTypeOnly*/
-        false,
-        tryCast(element.propertyName, isIdentifier),
-        element.name
-      ));
-    }
-    if (importSpecifiers.length) {
-      return factory.createNamedImports(importSpecifiers);
-    }
+  function isFromObjectTypeDeclaration(node) {
+    return node.parent && isClassOrTypeElement(node.parent) && isObjectTypeDeclaration(node.parent.parent);
   }
-  var fixId41, errorCodes52;
-  var init_requireInTs = __esm({
-    "src/services/codefixes/requireInTs.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_codefix();
-      fixId41 = "requireInTs";
-      errorCodes52 = [Diagnostics.require_call_may_be_converted_to_an_import.code];
-      registerCodeFix({
-        errorCodes: errorCodes52,
-        getCodeActions(context) {
-          const info = getInfo17(context.sourceFile, context.program, context.span.start);
-          if (!info) {
-            return void 0;
-          }
-          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange34(t, context.sourceFile, info));
-          return [createCodeFixAction(fixId41, changes, Diagnostics.Convert_require_to_import, fixId41, Diagnostics.Convert_all_require_to_import)];
-        },
-        fixIds: [fixId41],
-        getAllCodeActions: (context) => codeFixAll(context, errorCodes52, (changes, diag2) => {
-          const info = getInfo17(diag2.file, context.program, diag2.start);
-          if (info) {
-            doChange34(changes, context.sourceFile, info);
-          }
-        })
-      });
-    }
-  });
-
-  // src/services/codefixes/useDefaultImport.ts
-  function getInfo18(sourceFile, pos) {
-    const name = getTokenAtPosition(sourceFile, pos);
-    if (!isIdentifier(name))
-      return void 0;
-    const { parent: parent2 } = name;
-    if (isImportEqualsDeclaration(parent2) && isExternalModuleReference(parent2.moduleReference)) {
-      return { importNode: parent2, name, moduleSpecifier: parent2.moduleReference.expression };
-    } else if (isNamespaceImport(parent2)) {
-      const importNode = parent2.parent.parent;
-      return { importNode, name, moduleSpecifier: importNode.moduleSpecifier };
+  function isValidTrigger(sourceFile, triggerCharacter, contextToken, position) {
+    switch (triggerCharacter) {
+      case ".":
+      case "@":
+        return true;
+      case '"':
+      case "'":
+      case "`":
+        return !!contextToken && isStringLiteralOrTemplate(contextToken) && position === contextToken.getStart(sourceFile) + 1;
+      case "#":
+        return !!contextToken && isPrivateIdentifier(contextToken) && !!getContainingClass(contextToken);
+      case "<":
+        return !!contextToken && contextToken.kind === 30 /* LessThanToken */ && (!isBinaryExpression(contextToken.parent) || binaryExpressionMayBeOpenTag(contextToken.parent));
+      case "/":
+        return !!contextToken && (isStringLiteralLike(contextToken) ? !!tryGetImportFromModuleSpecifier(contextToken) : contextToken.kind === 44 /* SlashToken */ && isJsxClosingElement(contextToken.parent));
+      case " ":
+        return !!contextToken && isImportKeyword(contextToken) && contextToken.parent.kind === 312 /* SourceFile */;
+      default:
+        return Debug.assertNever(triggerCharacter);
     }
   }
-  function doChange35(changes, sourceFile, info, preferences) {
-    changes.replaceNode(sourceFile, info.importNode, makeImport(
-      info.name,
-      /*namedImports*/
-      void 0,
-      info.moduleSpecifier,
-      getQuotePreference(sourceFile, preferences)
-    ));
+  function binaryExpressionMayBeOpenTag({ left }) {
+    return nodeIsMissing(left);
   }
-  var fixId42, errorCodes53;
-  var init_useDefaultImport = __esm({
-    "src/services/codefixes/useDefaultImport.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_codefix();
-      fixId42 = "useDefaultImport";
-      errorCodes53 = [Diagnostics.Import_may_be_converted_to_a_default_import.code];
-      registerCodeFix({
-        errorCodes: errorCodes53,
-        getCodeActions(context) {
-          const { sourceFile, span: { start } } = context;
-          const info = getInfo18(sourceFile, start);
-          if (!info)
-            return void 0;
-          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange35(t, sourceFile, info, context.preferences));
-          return [createCodeFixAction(fixId42, changes, Diagnostics.Convert_to_default_import, fixId42, Diagnostics.Convert_all_to_default_imports)];
-        },
-        fixIds: [fixId42],
-        getAllCodeActions: (context) => codeFixAll(context, errorCodes53, (changes, diag2) => {
-          const info = getInfo18(diag2.file, diag2.start);
-          if (info)
-            doChange35(changes, diag2.file, info, context.preferences);
-        })
-      });
+  function isProbablyGlobalType(type, sourceFile, checker) {
+    const selfSymbol = checker.resolveName(
+      "self",
+      /*location*/
+      void 0,
+      111551 /* Value */,
+      /*excludeGlobals*/
+      false
+    );
+    if (selfSymbol && checker.getTypeOfSymbolAtLocation(selfSymbol, sourceFile) === type) {
+      return true;
     }
-  });
-
-  // src/services/codefixes/useBigintLiteral.ts
-  function makeChange9(changeTracker, sourceFile, span) {
-    const numericLiteral = tryCast(getTokenAtPosition(sourceFile, span.start), isNumericLiteral);
-    if (!numericLiteral) {
-      return;
+    const globalSymbol = checker.resolveName(
+      "global",
+      /*location*/
+      void 0,
+      111551 /* Value */,
+      /*excludeGlobals*/
+      false
+    );
+    if (globalSymbol && checker.getTypeOfSymbolAtLocation(globalSymbol, sourceFile) === type) {
+      return true;
     }
-    const newText = numericLiteral.getText(sourceFile) + "n";
-    changeTracker.replaceNode(sourceFile, numericLiteral, factory.createBigIntLiteral(newText));
-  }
-  var fixId43, errorCodes54;
-  var init_useBigintLiteral = __esm({
-    "src/services/codefixes/useBigintLiteral.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_codefix();
-      fixId43 = "useBigintLiteral";
-      errorCodes54 = [
-        Diagnostics.Numeric_literals_with_absolute_values_equal_to_2_53_or_greater_are_too_large_to_be_represented_accurately_as_integers.code
-      ];
-      registerCodeFix({
-        errorCodes: errorCodes54,
-        getCodeActions: function getCodeActionsToUseBigintLiteral(context) {
-          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => makeChange9(t, context.sourceFile, context.span));
-          if (changes.length > 0) {
-            return [createCodeFixAction(fixId43, changes, Diagnostics.Convert_to_a_bigint_numeric_literal, fixId43, Diagnostics.Convert_all_to_bigint_numeric_literals)];
-          }
-        },
-        fixIds: [fixId43],
-        getAllCodeActions: (context) => {
-          return codeFixAll(context, errorCodes54, (changes, diag2) => makeChange9(changes, diag2.file, diag2));
-        }
-      });
+    const globalThisSymbol = checker.resolveName(
+      "globalThis",
+      /*location*/
+      void 0,
+      111551 /* Value */,
+      /*excludeGlobals*/
+      false
+    );
+    if (globalThisSymbol && checker.getTypeOfSymbolAtLocation(globalThisSymbol, sourceFile) === type) {
+      return true;
     }
-  });
-
-  // src/services/codefixes/fixAddModuleReferTypeMissingTypeof.ts
-  function getImportTypeNode(sourceFile, pos) {
-    const token = getTokenAtPosition(sourceFile, pos);
-    Debug.assert(token.kind === 102 /* ImportKeyword */, "This token should be an ImportKeyword");
-    Debug.assert(token.parent.kind === 204 /* ImportType */, "Token parent should be an ImportType");
-    return token.parent;
+    return false;
   }
-  function doChange36(changes, sourceFile, importType) {
-    const newTypeNode = factory.updateImportTypeNode(
-      importType,
-      importType.argument,
-      importType.assertions,
-      importType.qualifier,
-      importType.typeArguments,
-      /*isTypeOf*/
-      true
-    );
-    changes.replaceNode(sourceFile, importType, newTypeNode);
+  function isStaticProperty(symbol) {
+    return !!(symbol.valueDeclaration && getEffectiveModifierFlags(symbol.valueDeclaration) & 256 /* Static */ && isClassLike(symbol.valueDeclaration.parent));
   }
-  var fixIdAddMissingTypeof, fixId44, errorCodes55;
-  var init_fixAddModuleReferTypeMissingTypeof = __esm({
-    "src/services/codefixes/fixAddModuleReferTypeMissingTypeof.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_codefix();
-      fixIdAddMissingTypeof = "fixAddModuleReferTypeMissingTypeof";
-      fixId44 = fixIdAddMissingTypeof;
-      errorCodes55 = [Diagnostics.Module_0_does_not_refer_to_a_type_but_is_used_as_a_type_here_Did_you_mean_typeof_import_0.code];
-      registerCodeFix({
-        errorCodes: errorCodes55,
-        getCodeActions: function getCodeActionsToAddMissingTypeof(context) {
-          const { sourceFile, span } = context;
-          const importType = getImportTypeNode(sourceFile, span.start);
-          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange36(t, sourceFile, importType));
-          return [createCodeFixAction(fixId44, changes, Diagnostics.Add_missing_typeof, fixId44, Diagnostics.Add_missing_typeof)];
-        },
-        fixIds: [fixId44],
-        getAllCodeActions: (context) => codeFixAll(context, errorCodes55, (changes, diag2) => doChange36(changes, context.sourceFile, getImportTypeNode(diag2.file, diag2.start)))
-      });
+  function tryGetObjectLiteralContextualType(node, typeChecker) {
+    const type = typeChecker.getContextualType(node);
+    if (type) {
+      return type;
     }
-  });
-
-  // src/services/codefixes/wrapJsxInFragment.ts
-  function findNodeToFix(sourceFile, pos) {
-    const lessThanToken = getTokenAtPosition(sourceFile, pos);
-    const firstJsxElementOrOpenElement = lessThanToken.parent;
-    let binaryExpr = firstJsxElementOrOpenElement.parent;
-    if (!isBinaryExpression(binaryExpr)) {
-      binaryExpr = binaryExpr.parent;
-      if (!isBinaryExpression(binaryExpr))
-        return void 0;
+    const parent2 = walkUpParenthesizedExpressions(node.parent);
+    if (isBinaryExpression(parent2) && parent2.operatorToken.kind === 64 /* EqualsToken */ && node === parent2.left) {
+      return typeChecker.getTypeAtLocation(parent2);
     }
-    if (!nodeIsMissing(binaryExpr.operatorToken))
-      return void 0;
-    return binaryExpr;
-  }
-  function doChange37(changeTracker, sf, node) {
-    const jsx = flattenInvalidBinaryExpr(node);
-    if (jsx)
-      changeTracker.replaceNode(sf, node, factory.createJsxFragment(factory.createJsxOpeningFragment(), jsx, factory.createJsxJsxClosingFragment()));
+    if (isExpression(parent2)) {
+      return typeChecker.getContextualType(parent2);
+    }
+    return void 0;
   }
-  function flattenInvalidBinaryExpr(node) {
-    const children = [];
-    let current = node;
-    while (true) {
-      if (isBinaryExpression(current) && nodeIsMissing(current.operatorToken) && current.operatorToken.kind === 28 /* CommaToken */) {
-        children.push(current.left);
-        if (isJsxChild(current.right)) {
-          children.push(current.right);
-          return children;
-        } else if (isBinaryExpression(current.right)) {
-          current = current.right;
-          continue;
-        } else
+  function getImportStatementCompletionInfo(contextToken, sourceFile) {
+    var _a, _b, _c;
+    let keywordCompletion;
+    let isKeywordOnlyCompletion = false;
+    const candidate = getCandidate();
+    return {
+      isKeywordOnlyCompletion,
+      keywordCompletion,
+      isNewIdentifierLocation: !!(candidate || keywordCompletion === 156 /* TypeKeyword */),
+      isTopLevelTypeOnly: !!((_b = (_a = tryCast(candidate, isImportDeclaration)) == null ? void 0 : _a.importClause) == null ? void 0 : _b.isTypeOnly) || !!((_c = tryCast(candidate, isImportEqualsDeclaration)) == null ? void 0 : _c.isTypeOnly),
+      couldBeTypeOnlyImportSpecifier: !!candidate && couldBeTypeOnlyImportSpecifier(candidate, contextToken),
+      replacementSpan: getSingleLineReplacementSpanForImportCompletionNode(candidate)
+    };
+    function getCandidate() {
+      const parent2 = contextToken.parent;
+      if (isImportEqualsDeclaration(parent2)) {
+        const lastToken = parent2.getLastToken(sourceFile);
+        if (isIdentifier(contextToken) && lastToken !== contextToken) {
+          keywordCompletion = 161 /* FromKeyword */;
+          isKeywordOnlyCompletion = true;
           return void 0;
-      } else
+        }
+        keywordCompletion = contextToken.kind === 156 /* TypeKeyword */ ? void 0 : 156 /* TypeKeyword */;
+        return isModuleSpecifierMissingOrEmpty(parent2.moduleReference) ? parent2 : void 0;
+      }
+      if (couldBeTypeOnlyImportSpecifier(parent2, contextToken) && canCompleteFromNamedBindings(parent2.parent)) {
+        return parent2;
+      }
+      if (isNamedImports(parent2) || isNamespaceImport(parent2)) {
+        if (!parent2.parent.isTypeOnly && (contextToken.kind === 19 /* OpenBraceToken */ || contextToken.kind === 102 /* ImportKeyword */ || contextToken.kind === 28 /* CommaToken */)) {
+          keywordCompletion = 156 /* TypeKeyword */;
+        }
+        if (canCompleteFromNamedBindings(parent2)) {
+          if (contextToken.kind === 20 /* CloseBraceToken */ || contextToken.kind === 80 /* Identifier */) {
+            isKeywordOnlyCompletion = true;
+            keywordCompletion = 161 /* FromKeyword */;
+          } else {
+            return parent2.parent.parent;
+          }
+        }
         return void 0;
+      }
+      if (isImportKeyword(contextToken) && isSourceFile(parent2)) {
+        keywordCompletion = 156 /* TypeKeyword */;
+        return contextToken;
+      }
+      if (isImportKeyword(contextToken) && isImportDeclaration(parent2)) {
+        keywordCompletion = 156 /* TypeKeyword */;
+        return isModuleSpecifierMissingOrEmpty(parent2.moduleSpecifier) ? parent2 : void 0;
+      }
+      return void 0;
     }
   }
-  var fixID2, errorCodes56;
-  var init_wrapJsxInFragment = __esm({
-    "src/services/codefixes/wrapJsxInFragment.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_codefix();
-      fixID2 = "wrapJsxInFragment";
-      errorCodes56 = [Diagnostics.JSX_expressions_must_have_one_parent_element.code];
-      registerCodeFix({
-        errorCodes: errorCodes56,
-        getCodeActions: function getCodeActionsToWrapJsxInFragment(context) {
-          const { sourceFile, span } = context;
-          const node = findNodeToFix(sourceFile, span.start);
-          if (!node)
-            return void 0;
-          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange37(t, sourceFile, node));
-          return [createCodeFixAction(fixID2, changes, Diagnostics.Wrap_in_JSX_fragment, fixID2, Diagnostics.Wrap_all_unparented_JSX_in_JSX_fragment)];
-        },
-        fixIds: [fixID2],
-        getAllCodeActions: (context) => codeFixAll(context, errorCodes56, (changes, diag2) => {
-          const node = findNodeToFix(context.sourceFile, diag2.start);
-          if (!node)
-            return void 0;
-          doChange37(changes, context.sourceFile, node);
-        })
-      });
-    }
-  });
-
-  // src/services/codefixes/convertToMappedObjectType.ts
-  function getInfo19(sourceFile, pos) {
-    const token = getTokenAtPosition(sourceFile, pos);
-    const indexSignature = tryCast(token.parent.parent, isIndexSignatureDeclaration);
-    if (!indexSignature)
-      return void 0;
-    const container = isInterfaceDeclaration(indexSignature.parent) ? indexSignature.parent : tryCast(indexSignature.parent.parent, isTypeAliasDeclaration);
-    if (!container)
+  function getSingleLineReplacementSpanForImportCompletionNode(node) {
+    var _a;
+    if (!node)
       return void 0;
-    return { indexSignature, container };
-  }
-  function createTypeAliasFromInterface(declaration, type) {
-    return factory.createTypeAliasDeclaration(declaration.modifiers, declaration.name, declaration.typeParameters, type);
+    const top = findAncestor(node, or(isImportDeclaration, isImportEqualsDeclaration)) ?? node;
+    const sourceFile = top.getSourceFile();
+    if (rangeIsOnSingleLine(top, sourceFile)) {
+      return createTextSpanFromNode(top, sourceFile);
+    }
+    Debug.assert(top.kind !== 102 /* ImportKeyword */ && top.kind !== 276 /* ImportSpecifier */);
+    const potentialSplitPoint = top.kind === 272 /* ImportDeclaration */ ? getPotentiallyInvalidImportSpecifier((_a = top.importClause) == null ? void 0 : _a.namedBindings) ?? top.moduleSpecifier : top.moduleReference;
+    const withoutModuleSpecifier = {
+      pos: top.getFirstToken().getStart(),
+      end: potentialSplitPoint.pos
+    };
+    if (rangeIsOnSingleLine(withoutModuleSpecifier, sourceFile)) {
+      return createTextSpanFromRange(withoutModuleSpecifier);
+    }
   }
-  function doChange38(changes, sourceFile, { indexSignature, container }) {
-    const members = isInterfaceDeclaration(container) ? container.members : container.type.members;
-    const otherMembers = members.filter((member) => !isIndexSignatureDeclaration(member));
-    const parameter = first(indexSignature.parameters);
-    const mappedTypeParameter = factory.createTypeParameterDeclaration(
-      /*modifiers*/
-      void 0,
-      cast(parameter.name, isIdentifier),
-      parameter.type
-    );
-    const mappedIntersectionType = factory.createMappedTypeNode(
-      hasEffectiveReadonlyModifier(indexSignature) ? factory.createModifier(148 /* ReadonlyKeyword */) : void 0,
-      mappedTypeParameter,
-      /*nameType*/
-      void 0,
-      indexSignature.questionToken,
-      indexSignature.type,
-      /*members*/
-      void 0
+  function getPotentiallyInvalidImportSpecifier(namedBindings) {
+    var _a;
+    return find(
+      (_a = tryCast(namedBindings, isNamedImports)) == null ? void 0 : _a.elements,
+      (e) => {
+        var _a2;
+        return !e.propertyName && isStringANonContextualKeyword(e.name.text) && ((_a2 = findPrecedingToken(e.name.pos, namedBindings.getSourceFile(), namedBindings)) == null ? void 0 : _a2.kind) !== 28 /* CommaToken */;
+      }
     );
-    const intersectionType = factory.createIntersectionTypeNode([
-      ...getAllSuperTypeNodes(container),
-      mappedIntersectionType,
-      ...otherMembers.length ? [factory.createTypeLiteralNode(otherMembers)] : emptyArray
-    ]);
-    changes.replaceNode(sourceFile, container, createTypeAliasFromInterface(container, intersectionType));
   }
-  var fixId45, errorCodes57;
-  var init_convertToMappedObjectType = __esm({
-    "src/services/codefixes/convertToMappedObjectType.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_codefix();
-      fixId45 = "fixConvertToMappedObjectType";
-      errorCodes57 = [Diagnostics.An_index_signature_parameter_type_cannot_be_a_literal_type_or_generic_type_Consider_using_a_mapped_object_type_instead.code];
-      registerCodeFix({
-        errorCodes: errorCodes57,
-        getCodeActions: function getCodeActionsToConvertToMappedTypeObject(context) {
-          const { sourceFile, span } = context;
-          const info = getInfo19(sourceFile, span.start);
-          if (!info)
-            return void 0;
-          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange38(t, sourceFile, info));
-          const name = idText(info.container.name);
-          return [createCodeFixAction(fixId45, changes, [Diagnostics.Convert_0_to_mapped_object_type, name], fixId45, [Diagnostics.Convert_0_to_mapped_object_type, name])];
-        },
-        fixIds: [fixId45],
-        getAllCodeActions: (context) => codeFixAll(context, errorCodes57, (changes, diag2) => {
-          const info = getInfo19(diag2.file, diag2.start);
-          if (info)
-            doChange38(changes, diag2.file, info);
-        })
-      });
+  function couldBeTypeOnlyImportSpecifier(importSpecifier, contextToken) {
+    return isImportSpecifier(importSpecifier) && (importSpecifier.isTypeOnly || contextToken === importSpecifier.name && isTypeKeywordTokenOrIdentifier(contextToken));
+  }
+  function canCompleteFromNamedBindings(namedBindings) {
+    if (!isModuleSpecifierMissingOrEmpty(namedBindings.parent.parent.moduleSpecifier) || namedBindings.parent.name) {
+      return false;
     }
-  });
-
-  // src/services/codefixes/removeAccidentalCallParentheses.ts
-  var fixId46, errorCodes58;
-  var init_removeAccidentalCallParentheses = __esm({
-    "src/services/codefixes/removeAccidentalCallParentheses.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_codefix();
-      fixId46 = "removeAccidentalCallParentheses";
-      errorCodes58 = [
-        Diagnostics.This_expression_is_not_callable_because_it_is_a_get_accessor_Did_you_mean_to_use_it_without.code
-      ];
-      registerCodeFix({
-        errorCodes: errorCodes58,
-        getCodeActions(context) {
-          const callExpression = findAncestor(getTokenAtPosition(context.sourceFile, context.span.start), isCallExpression);
-          if (!callExpression) {
-            return void 0;
-          }
-          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => {
-            t.deleteRange(context.sourceFile, { pos: callExpression.expression.end, end: callExpression.end });
-          });
-          return [createCodeFixActionWithoutFixAll(fixId46, changes, Diagnostics.Remove_parentheses)];
-        },
-        fixIds: [fixId46]
-      });
+    if (isNamedImports(namedBindings)) {
+      const invalidNamedImport = getPotentiallyInvalidImportSpecifier(namedBindings);
+      const validImports = invalidNamedImport ? namedBindings.elements.indexOf(invalidNamedImport) : namedBindings.elements.length;
+      return validImports < 2;
     }
-  });
-
-  // src/services/codefixes/removeUnnecessaryAwait.ts
-  function makeChange10(changeTracker, sourceFile, span) {
-    const awaitKeyword = tryCast(getTokenAtPosition(sourceFile, span.start), (node) => node.kind === 135 /* AwaitKeyword */);
-    const awaitExpression = awaitKeyword && tryCast(awaitKeyword.parent, isAwaitExpression);
-    if (!awaitExpression) {
+    return true;
+  }
+  function isModuleSpecifierMissingOrEmpty(specifier) {
+    var _a;
+    if (nodeIsMissing(specifier))
+      return true;
+    return !((_a = tryCast(isExternalModuleReference(specifier) ? specifier.expression : specifier, isStringLiteralLike)) == null ? void 0 : _a.text);
+  }
+  function getVariableOrParameterDeclaration(contextToken, location) {
+    if (!contextToken)
       return;
+    const possiblyParameterDeclaration = findAncestor(contextToken, (node) => isFunctionBlock(node) || isArrowFunctionBody(node) || isBindingPattern(node) ? "quit" : (isParameter(node) || isTypeParameterDeclaration(node)) && !isIndexSignatureDeclaration(node.parent));
+    const possiblyVariableDeclaration = findAncestor(location, (node) => isFunctionBlock(node) || isArrowFunctionBody(node) || isBindingPattern(node) ? "quit" : isVariableDeclaration(node));
+    return possiblyParameterDeclaration || possiblyVariableDeclaration;
+  }
+  function isArrowFunctionBody(node) {
+    return node.parent && isArrowFunction(node.parent) && (node.parent.body === node || // const a = () => /**/;
+    node.kind === 39 /* EqualsGreaterThanToken */);
+  }
+  function symbolCanBeReferencedAtTypeLocation(symbol, checker, seenModules = /* @__PURE__ */ new Map()) {
+    return nonAliasCanBeReferencedAtTypeLocation(symbol) || nonAliasCanBeReferencedAtTypeLocation(skipAlias(symbol.exportSymbol || symbol, checker));
+    function nonAliasCanBeReferencedAtTypeLocation(symbol2) {
+      return !!(symbol2.flags & 788968 /* Type */) || checker.isUnknownSymbol(symbol2) || !!(symbol2.flags & 1536 /* Module */) && addToSeen(seenModules, getSymbolId(symbol2)) && checker.getExportsOfModule(symbol2).some((e) => symbolCanBeReferencedAtTypeLocation(e, checker, seenModules));
     }
-    let expressionToReplace = awaitExpression;
-    const hasSurroundingParens = isParenthesizedExpression(awaitExpression.parent);
-    if (hasSurroundingParens) {
-      const leftMostExpression = getLeftmostExpression(
-        awaitExpression.expression,
-        /*stopAtCallExpressions*/
-        false
-      );
-      if (isIdentifier(leftMostExpression)) {
-        const precedingToken = findPrecedingToken(awaitExpression.parent.pos, sourceFile);
-        if (precedingToken && precedingToken.kind !== 105 /* NewKeyword */) {
-          expressionToReplace = awaitExpression.parent;
+  }
+  function isDeprecated(symbol, checker) {
+    const declarations = skipAlias(symbol, checker).declarations;
+    return !!length(declarations) && every(declarations, isDeprecatedDeclaration);
+  }
+  function charactersFuzzyMatchInString(identifierString, lowercaseCharacters) {
+    if (lowercaseCharacters.length === 0) {
+      return true;
+    }
+    let matchedFirstCharacter = false;
+    let prevChar;
+    let characterIndex = 0;
+    const len = identifierString.length;
+    for (let strIndex = 0; strIndex < len; strIndex++) {
+      const strChar = identifierString.charCodeAt(strIndex);
+      const testChar = lowercaseCharacters.charCodeAt(characterIndex);
+      if (strChar === testChar || strChar === toUpperCharCode(testChar)) {
+        matchedFirstCharacter || (matchedFirstCharacter = prevChar === void 0 || // Beginning of word
+        97 /* a */ <= prevChar && prevChar <= 122 /* z */ && 65 /* A */ <= strChar && strChar <= 90 /* Z */ || // camelCase transition
+        prevChar === 95 /* _ */ && strChar !== 95 /* _ */);
+        if (matchedFirstCharacter) {
+          characterIndex++;
+        }
+        if (characterIndex === lowercaseCharacters.length) {
+          return true;
         }
       }
+      prevChar = strChar;
     }
-    changeTracker.replaceNode(sourceFile, expressionToReplace, awaitExpression.expression);
+    return false;
   }
-  var fixId47, errorCodes59;
-  var init_removeUnnecessaryAwait = __esm({
-    "src/services/codefixes/removeUnnecessaryAwait.ts"() {
+  function toUpperCharCode(charCode) {
+    if (97 /* a */ <= charCode && charCode <= 122 /* z */) {
+      return charCode - 32;
+    }
+    return charCode;
+  }
+  function isContextualKeywordInAutoImportableExpressionSpace(keyword) {
+    return keyword === "abstract" || keyword === "async" || keyword === "await" || keyword === "declare" || keyword === "module" || keyword === "namespace" || keyword === "type";
+  }
+  var moduleSpecifierResolutionLimit, moduleSpecifierResolutionCacheAttemptLimit, SortText, CompletionSource, SymbolOriginInfoKind, CompletionKind, _keywordCompletions, allKeywordsCompletions;
+  var init_completions = __esm({
+    "src/services/completions.ts"() {
       "use strict";
       init_ts4();
-      init_ts_codefix();
-      fixId47 = "removeUnnecessaryAwait";
-      errorCodes59 = [
-        Diagnostics.await_has_no_effect_on_the_type_of_this_expression.code
-      ];
-      registerCodeFix({
-        errorCodes: errorCodes59,
-        getCodeActions: function getCodeActionsToRemoveUnnecessaryAwait(context) {
-          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => makeChange10(t, context.sourceFile, context.span));
-          if (changes.length > 0) {
-            return [createCodeFixAction(fixId47, changes, Diagnostics.Remove_unnecessary_await, fixId47, Diagnostics.Remove_all_unnecessary_uses_of_await)];
-          }
+      init_ts_Completions();
+      moduleSpecifierResolutionLimit = 100;
+      moduleSpecifierResolutionCacheAttemptLimit = 1e3;
+      SortText = {
+        // Presets
+        LocalDeclarationPriority: "10",
+        LocationPriority: "11",
+        OptionalMember: "12",
+        MemberDeclaredBySpreadAssignment: "13",
+        SuggestedClassMembers: "14",
+        GlobalsOrKeywords: "15",
+        AutoImportSuggestions: "16",
+        ClassMemberSnippets: "17",
+        JavascriptIdentifiers: "18",
+        // Transformations
+        Deprecated(sortText) {
+          return "z" + sortText;
         },
-        fixIds: [fixId47],
-        getAllCodeActions: (context) => {
-          return codeFixAll(context, errorCodes59, (changes, diag2) => makeChange10(changes, diag2.file, diag2));
+        ObjectLiteralProperty(presetSortText, symbolDisplayName) {
+          return `${presetSortText}\0${symbolDisplayName}\0`;
+        },
+        SortBelow(sortText) {
+          return sortText + "1";
+        }
+      };
+      CompletionSource = /* @__PURE__ */ ((CompletionSource2) => {
+        CompletionSource2["ThisProperty"] = "ThisProperty/";
+        CompletionSource2["ClassMemberSnippet"] = "ClassMemberSnippet/";
+        CompletionSource2["TypeOnlyAlias"] = "TypeOnlyAlias/";
+        CompletionSource2["ObjectLiteralMethodSnippet"] = "ObjectLiteralMethodSnippet/";
+        CompletionSource2["SwitchCases"] = "SwitchCases/";
+        CompletionSource2["ObjectLiteralMemberWithComma"] = "ObjectLiteralMemberWithComma/";
+        return CompletionSource2;
+      })(CompletionSource || {});
+      SymbolOriginInfoKind = /* @__PURE__ */ ((SymbolOriginInfoKind2) => {
+        SymbolOriginInfoKind2[SymbolOriginInfoKind2["ThisType"] = 1] = "ThisType";
+        SymbolOriginInfoKind2[SymbolOriginInfoKind2["SymbolMember"] = 2] = "SymbolMember";
+        SymbolOriginInfoKind2[SymbolOriginInfoKind2["Export"] = 4] = "Export";
+        SymbolOriginInfoKind2[SymbolOriginInfoKind2["Promise"] = 8] = "Promise";
+        SymbolOriginInfoKind2[SymbolOriginInfoKind2["Nullable"] = 16] = "Nullable";
+        SymbolOriginInfoKind2[SymbolOriginInfoKind2["ResolvedExport"] = 32] = "ResolvedExport";
+        SymbolOriginInfoKind2[SymbolOriginInfoKind2["TypeOnlyAlias"] = 64] = "TypeOnlyAlias";
+        SymbolOriginInfoKind2[SymbolOriginInfoKind2["ObjectLiteralMethod"] = 128] = "ObjectLiteralMethod";
+        SymbolOriginInfoKind2[SymbolOriginInfoKind2["Ignore"] = 256] = "Ignore";
+        SymbolOriginInfoKind2[SymbolOriginInfoKind2["ComputedPropertyName"] = 512] = "ComputedPropertyName";
+        SymbolOriginInfoKind2[SymbolOriginInfoKind2["SymbolMemberNoExport"] = 2 /* SymbolMember */] = "SymbolMemberNoExport";
+        SymbolOriginInfoKind2[SymbolOriginInfoKind2["SymbolMemberExport"] = 6] = "SymbolMemberExport";
+        return SymbolOriginInfoKind2;
+      })(SymbolOriginInfoKind || {});
+      CompletionKind = /* @__PURE__ */ ((CompletionKind2) => {
+        CompletionKind2[CompletionKind2["ObjectPropertyDeclaration"] = 0] = "ObjectPropertyDeclaration";
+        CompletionKind2[CompletionKind2["Global"] = 1] = "Global";
+        CompletionKind2[CompletionKind2["PropertyAccess"] = 2] = "PropertyAccess";
+        CompletionKind2[CompletionKind2["MemberLike"] = 3] = "MemberLike";
+        CompletionKind2[CompletionKind2["String"] = 4] = "String";
+        CompletionKind2[CompletionKind2["None"] = 5] = "None";
+        return CompletionKind2;
+      })(CompletionKind || {});
+      _keywordCompletions = [];
+      allKeywordsCompletions = memoize(() => {
+        const res = [];
+        for (let i = 83 /* FirstKeyword */; i <= 165 /* LastKeyword */; i++) {
+          res.push({
+            name: tokenToString(i),
+            kind: "keyword" /* keyword */,
+            kindModifiers: "" /* none */,
+            sortText: SortText.GlobalsOrKeywords
+          });
         }
+        return res;
       });
     }
   });
 
-  // src/services/codefixes/splitTypeOnlyImport.ts
-  function getImportDeclaration2(sourceFile, span) {
-    return findAncestor(getTokenAtPosition(sourceFile, span.start), isImportDeclaration);
+  // src/services/stringCompletions.ts
+  function createNameAndKindSet() {
+    const map2 = /* @__PURE__ */ new Map();
+    function add(value) {
+      const existing = map2.get(value.name);
+      if (!existing || kindPrecedence[existing.kind] < kindPrecedence[value.kind]) {
+        map2.set(value.name, value);
+      }
+    }
+    return {
+      add,
+      has: map2.has.bind(map2),
+      values: map2.values.bind(map2)
+    };
   }
-  function splitTypeOnlyImport(changes, importDeclaration, context) {
-    if (!importDeclaration) {
-      return;
+  function getStringLiteralCompletions(sourceFile, position, contextToken, options, host, program, log, preferences, includeSymbol) {
+    if (isInReferenceComment(sourceFile, position)) {
+      const entries = getTripleSlashReferenceCompletion(sourceFile, position, options, host);
+      return entries && convertPathCompletions(entries);
+    }
+    if (isInString(sourceFile, position, contextToken)) {
+      if (!contextToken || !isStringLiteralLike(contextToken))
+        return void 0;
+      const entries = getStringLiteralCompletionEntries(sourceFile, contextToken, position, program.getTypeChecker(), options, host, preferences);
+      return convertStringLiteralCompletions(entries, contextToken, sourceFile, host, program, log, options, preferences, position, includeSymbol);
     }
-    const importClause = Debug.checkDefined(importDeclaration.importClause);
-    changes.replaceNode(context.sourceFile, importDeclaration, factory.updateImportDeclaration(
-      importDeclaration,
-      importDeclaration.modifiers,
-      factory.updateImportClause(
-        importClause,
-        importClause.isTypeOnly,
-        importClause.name,
-        /*namedBindings*/
-        void 0
-      ),
-      importDeclaration.moduleSpecifier,
-      importDeclaration.assertClause
-    ));
-    changes.insertNodeAfter(context.sourceFile, importDeclaration, factory.createImportDeclaration(
-      /*modifiers*/
-      void 0,
-      factory.updateImportClause(
-        importClause,
-        importClause.isTypeOnly,
-        /*name*/
-        void 0,
-        importClause.namedBindings
-      ),
-      importDeclaration.moduleSpecifier,
-      importDeclaration.assertClause
-    ));
   }
-  var errorCodes60, fixId48;
-  var init_splitTypeOnlyImport = __esm({
-    "src/services/codefixes/splitTypeOnlyImport.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_codefix();
-      errorCodes60 = [Diagnostics.A_type_only_import_can_specify_a_default_import_or_named_bindings_but_not_both.code];
-      fixId48 = "splitTypeOnlyImport";
-      registerCodeFix({
-        errorCodes: errorCodes60,
-        fixIds: [fixId48],
-        getCodeActions: function getCodeActionsToSplitTypeOnlyImport(context) {
-          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => {
-            return splitTypeOnlyImport(t, getImportDeclaration2(context.sourceFile, context.span), context);
-          });
-          if (changes.length) {
-            return [createCodeFixAction(fixId48, changes, Diagnostics.Split_into_two_separate_import_declarations, fixId48, Diagnostics.Split_all_invalid_type_only_imports)];
-          }
-        },
-        getAllCodeActions: (context) => codeFixAll(context, errorCodes60, (changes, error) => {
-          splitTypeOnlyImport(changes, getImportDeclaration2(context.sourceFile, error), context);
-        })
-      });
+  function convertStringLiteralCompletions(completion, contextToken, sourceFile, host, program, log, options, preferences, position, includeSymbol) {
+    if (completion === void 0) {
+      return void 0;
+    }
+    const optionalReplacementSpan = createTextSpanFromStringLiteralLikeContent(contextToken);
+    switch (completion.kind) {
+      case 0 /* Paths */:
+        return convertPathCompletions(completion.paths);
+      case 1 /* Properties */: {
+        const entries = createSortedArray();
+        getCompletionEntriesFromSymbols(
+          completion.symbols,
+          entries,
+          contextToken,
+          contextToken,
+          sourceFile,
+          position,
+          sourceFile,
+          host,
+          program,
+          99 /* ESNext */,
+          log,
+          4 /* String */,
+          preferences,
+          options,
+          /*formatContext*/
+          void 0,
+          /*isTypeOnlyLocation*/
+          void 0,
+          /*propertyAccessToConvert*/
+          void 0,
+          /*jsxIdentifierExpected*/
+          void 0,
+          /*isJsxInitializer*/
+          void 0,
+          /*importStatementCompletion*/
+          void 0,
+          /*recommendedCompletion*/
+          void 0,
+          /*symbolToOriginInfoMap*/
+          void 0,
+          /*symbolToSortTextMap*/
+          void 0,
+          /*isJsxIdentifierExpected*/
+          void 0,
+          /*isRightOfOpenTag*/
+          void 0,
+          includeSymbol
+        );
+        return { isGlobalCompletion: false, isMemberCompletion: true, isNewIdentifierLocation: completion.hasIndexSignature, optionalReplacementSpan, entries };
+      }
+      case 2 /* Types */: {
+        const quoteChar = contextToken.kind === 15 /* NoSubstitutionTemplateLiteral */ ? 96 /* backtick */ : startsWith(getTextOfNode(contextToken), "'") ? 39 /* singleQuote */ : 34 /* doubleQuote */;
+        const entries = completion.types.map((type) => ({
+          name: escapeString(type.value, quoteChar),
+          kindModifiers: "" /* none */,
+          kind: "string" /* string */,
+          sortText: SortText.LocationPriority,
+          replacementSpan: getReplacementSpanForContextToken(contextToken)
+        }));
+        return { isGlobalCompletion: false, isMemberCompletion: false, isNewIdentifierLocation: completion.isNewIdentifier, optionalReplacementSpan, entries };
+      }
+      default:
+        return Debug.assertNever(completion);
     }
-  });
-
-  // src/services/codefixes/convertConstToLet.ts
-  function getInfo20(sourceFile, pos, program) {
-    var _a;
-    const checker = program.getTypeChecker();
-    const symbol = checker.getSymbolAtLocation(getTokenAtPosition(sourceFile, pos));
-    if (symbol === void 0)
-      return;
-    const declaration = tryCast((_a = symbol == null ? void 0 : symbol.valueDeclaration) == null ? void 0 : _a.parent, isVariableDeclarationList);
-    if (declaration === void 0)
-      return;
-    const constToken = findChildOfKind(declaration, 87 /* ConstKeyword */, sourceFile);
-    if (constToken === void 0)
-      return;
-    return { symbol, token: constToken };
   }
-  function doChange39(changes, sourceFile, token) {
-    changes.replaceNode(sourceFile, token, factory.createToken(121 /* LetKeyword */));
+  function getStringLiteralCompletionDetails(name, sourceFile, position, contextToken, checker, options, host, cancellationToken, preferences) {
+    if (!contextToken || !isStringLiteralLike(contextToken))
+      return void 0;
+    const completions = getStringLiteralCompletionEntries(sourceFile, contextToken, position, checker, options, host, preferences);
+    return completions && stringLiteralCompletionDetails(name, contextToken, completions, sourceFile, checker, cancellationToken);
   }
-  var fixId49, errorCodes61;
-  var init_convertConstToLet = __esm({
-    "src/services/codefixes/convertConstToLet.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_codefix();
-      fixId49 = "fixConvertConstToLet";
-      errorCodes61 = [Diagnostics.Cannot_assign_to_0_because_it_is_a_constant.code];
-      registerCodeFix({
-        errorCodes: errorCodes61,
-        getCodeActions: function getCodeActionsToConvertConstToLet(context) {
-          const { sourceFile, span, program } = context;
-          const info = getInfo20(sourceFile, span.start, program);
-          if (info === void 0)
-            return;
-          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange39(t, sourceFile, info.token));
-          return [createCodeFixActionMaybeFixAll(fixId49, changes, Diagnostics.Convert_const_to_let, fixId49, Diagnostics.Convert_all_const_to_let)];
-        },
-        getAllCodeActions: (context) => {
-          const { program } = context;
-          const seen = /* @__PURE__ */ new Map();
-          return createCombinedCodeActions(ts_textChanges_exports.ChangeTracker.with(context, (changes) => {
-            eachDiagnostic(context, errorCodes61, (diag2) => {
-              const info = getInfo20(diag2.file, diag2.start, program);
-              if (info) {
-                if (addToSeen(seen, getSymbolId(info.symbol))) {
-                  return doChange39(changes, diag2.file, info.token);
-                }
-              }
-              return void 0;
-            });
-          }));
-        },
-        fixIds: [fixId49]
-      });
+  function stringLiteralCompletionDetails(name, location, completion, sourceFile, checker, cancellationToken) {
+    switch (completion.kind) {
+      case 0 /* Paths */: {
+        const match = find(completion.paths, (p) => p.name === name);
+        return match && createCompletionDetails(name, kindModifiersFromExtension(match.extension), match.kind, [textPart(name)]);
+      }
+      case 1 /* Properties */: {
+        const match = find(completion.symbols, (s) => s.name === name);
+        return match && createCompletionDetailsForSymbol(match, match.name, checker, sourceFile, location, cancellationToken);
+      }
+      case 2 /* Types */:
+        return find(completion.types, (t) => t.value === name) ? createCompletionDetails(name, "" /* none */, "string" /* string */, [textPart(name)]) : void 0;
+      default:
+        return Debug.assertNever(completion);
     }
-  });
-
-  // src/services/codefixes/fixExpectedComma.ts
-  function getInfo21(sourceFile, pos, _) {
-    const node = getTokenAtPosition(sourceFile, pos);
-    return node.kind === 27 /* SemicolonToken */ && node.parent && (isObjectLiteralExpression(node.parent) || isArrayLiteralExpression(node.parent)) ? { node } : void 0;
   }
-  function doChange40(changes, sourceFile, { node }) {
-    const newNode = factory.createToken(28 /* CommaToken */);
-    changes.replaceNode(sourceFile, node, newNode);
+  function convertPathCompletions(pathCompletions) {
+    const isGlobalCompletion = false;
+    const isNewIdentifierLocation = true;
+    const entries = pathCompletions.map(({ name, kind, span, extension }) => ({ name, kind, kindModifiers: kindModifiersFromExtension(extension), sortText: SortText.LocationPriority, replacementSpan: span }));
+    return { isGlobalCompletion, isMemberCompletion: false, isNewIdentifierLocation, entries };
   }
-  var fixId50, expectedErrorCode, errorCodes62;
-  var init_fixExpectedComma = __esm({
-    "src/services/codefixes/fixExpectedComma.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_codefix();
-      fixId50 = "fixExpectedComma";
-      expectedErrorCode = Diagnostics._0_expected.code;
-      errorCodes62 = [expectedErrorCode];
-      registerCodeFix({
-        errorCodes: errorCodes62,
-        getCodeActions(context) {
-          const { sourceFile } = context;
-          const info = getInfo21(sourceFile, context.span.start, context.errorCode);
-          if (!info)
-            return void 0;
-          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => doChange40(t, sourceFile, info));
-          return [createCodeFixAction(
-            fixId50,
-            changes,
-            [Diagnostics.Change_0_to_1, ";", ","],
-            fixId50,
-            [Diagnostics.Change_0_to_1, ";", ","]
-          )];
-        },
-        fixIds: [fixId50],
-        getAllCodeActions: (context) => codeFixAll(context, errorCodes62, (changes, diag2) => {
-          const info = getInfo21(diag2.file, diag2.start, diag2.code);
-          if (info)
-            doChange40(changes, context.sourceFile, info);
-        })
-      });
+  function kindModifiersFromExtension(extension) {
+    switch (extension) {
+      case ".d.ts" /* Dts */:
+        return ".d.ts" /* dtsModifier */;
+      case ".js" /* Js */:
+        return ".js" /* jsModifier */;
+      case ".json" /* Json */:
+        return ".json" /* jsonModifier */;
+      case ".jsx" /* Jsx */:
+        return ".jsx" /* jsxModifier */;
+      case ".ts" /* Ts */:
+        return ".ts" /* tsModifier */;
+      case ".tsx" /* Tsx */:
+        return ".tsx" /* tsxModifier */;
+      case ".d.mts" /* Dmts */:
+        return ".d.mts" /* dmtsModifier */;
+      case ".mjs" /* Mjs */:
+        return ".mjs" /* mjsModifier */;
+      case ".mts" /* Mts */:
+        return ".mts" /* mtsModifier */;
+      case ".d.cts" /* Dcts */:
+        return ".d.cts" /* dctsModifier */;
+      case ".cjs" /* Cjs */:
+        return ".cjs" /* cjsModifier */;
+      case ".cts" /* Cts */:
+        return ".cts" /* ctsModifier */;
+      case ".tsbuildinfo" /* TsBuildInfo */:
+        return Debug.fail(`Extension ${".tsbuildinfo" /* TsBuildInfo */} is unsupported.`);
+      case void 0:
+        return "" /* none */;
+      default:
+        return Debug.assertNever(extension);
     }
-  });
-
-  // src/services/codefixes/fixAddVoidToPromise.ts
-  function makeChange11(changes, sourceFile, span, program, seen) {
-    const node = getTokenAtPosition(sourceFile, span.start);
-    if (!isIdentifier(node) || !isCallExpression(node.parent) || node.parent.expression !== node || node.parent.arguments.length !== 0)
-      return;
-    const checker = program.getTypeChecker();
-    const symbol = checker.getSymbolAtLocation(node);
-    const decl = symbol == null ? void 0 : symbol.valueDeclaration;
-    if (!decl || !isParameter(decl) || !isNewExpression(decl.parent.parent))
-      return;
-    if (seen == null ? void 0 : seen.has(decl))
-      return;
-    seen == null ? void 0 : seen.add(decl);
-    const typeArguments = getEffectiveTypeArguments(decl.parent.parent);
-    if (some(typeArguments)) {
-      const typeArgument = typeArguments[0];
-      const needsParens = !isUnionTypeNode(typeArgument) && !isParenthesizedTypeNode(typeArgument) && isParenthesizedTypeNode(factory.createUnionTypeNode([typeArgument, factory.createKeywordTypeNode(116 /* VoidKeyword */)]).types[0]);
-      if (needsParens) {
-        changes.insertText(sourceFile, typeArgument.pos, "(");
+  }
+  function getStringLiteralCompletionEntries(sourceFile, node, position, typeChecker, compilerOptions, host, preferences) {
+    const parent2 = walkUpParentheses(node.parent);
+    switch (parent2.kind) {
+      case 201 /* LiteralType */: {
+        const grandParent = walkUpParentheses(parent2.parent);
+        if (grandParent.kind === 205 /* ImportType */) {
+          return { kind: 0 /* Paths */, paths: getStringLiteralCompletionsFromModuleNames(sourceFile, node, compilerOptions, host, typeChecker, preferences) };
+        }
+        return fromUnionableLiteralType(grandParent);
       }
-      changes.insertText(sourceFile, typeArgument.end, needsParens ? ") | void" : " | void");
-    } else {
-      const signature = checker.getResolvedSignature(node.parent);
-      const parameter = signature == null ? void 0 : signature.parameters[0];
-      const parameterType = parameter && checker.getTypeOfSymbolAtLocation(parameter, decl.parent.parent);
-      if (isInJSFile(decl)) {
-        if (!parameterType || parameterType.flags & 3 /* AnyOrUnknown */) {
-          changes.insertText(sourceFile, decl.parent.parent.end, `)`);
-          changes.insertText(sourceFile, skipTrivia(sourceFile.text, decl.parent.parent.pos), `/** @type {Promise} */(`);
+      case 303 /* PropertyAssignment */:
+        if (isObjectLiteralExpression(parent2.parent) && parent2.name === node) {
+          return stringLiteralCompletionsForObjectLiteral(typeChecker, parent2.parent);
         }
-      } else {
-        if (!parameterType || parameterType.flags & 2 /* Unknown */) {
-          changes.insertText(sourceFile, decl.parent.parent.expression.end, "");
+        return fromContextualType() || fromContextualType(0 /* None */);
+      case 212 /* ElementAccessExpression */: {
+        const { expression, argumentExpression } = parent2;
+        if (node === skipParentheses(argumentExpression)) {
+          return stringLiteralCompletionsFromProperties(typeChecker.getTypeAtLocation(expression));
         }
+        return void 0;
       }
-    }
-  }
-  function getEffectiveTypeArguments(node) {
-    var _a;
-    if (isInJSFile(node)) {
-      if (isParenthesizedExpression(node.parent)) {
-        const jsDocType = (_a = getJSDocTypeTag(node.parent)) == null ? void 0 : _a.typeExpression.type;
-        if (jsDocType && isTypeReferenceNode(jsDocType) && isIdentifier(jsDocType.typeName) && idText(jsDocType.typeName) === "Promise") {
-          return jsDocType.typeArguments;
+      case 213 /* CallExpression */:
+      case 214 /* NewExpression */:
+      case 291 /* JsxAttribute */:
+        if (!isRequireCallArgument(node) && !isImportCall(parent2)) {
+          const argumentInfo = ts_SignatureHelp_exports.getArgumentInfoForCompletions(parent2.kind === 291 /* JsxAttribute */ ? parent2.parent : node, position, sourceFile);
+          return argumentInfo && getStringLiteralCompletionsFromSignature(argumentInfo.invocation, node, argumentInfo, typeChecker) || fromContextualType(0 /* None */);
         }
-      }
-    } else {
-      return node.typeArguments;
+      case 272 /* ImportDeclaration */:
+      case 278 /* ExportDeclaration */:
+      case 283 /* ExternalModuleReference */:
+        return { kind: 0 /* Paths */, paths: getStringLiteralCompletionsFromModuleNames(sourceFile, node, compilerOptions, host, typeChecker, preferences) };
+      case 296 /* CaseClause */:
+        const tracker = newCaseClauseTracker(typeChecker, parent2.parent.clauses);
+        const contextualTypes = fromContextualType();
+        if (!contextualTypes) {
+          return;
+        }
+        const literals = contextualTypes.types.filter((literal) => !tracker.hasValue(literal.value));
+        return { kind: 2 /* Types */, types: literals, isNewIdentifier: false };
+      default:
+        return fromContextualType() || fromContextualType(0 /* None */);
     }
-  }
-  var fixName7, fixId51, errorCodes63;
-  var init_fixAddVoidToPromise = __esm({
-    "src/services/codefixes/fixAddVoidToPromise.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_codefix();
-      fixName7 = "addVoidToPromise";
-      fixId51 = "addVoidToPromise";
-      errorCodes63 = [
-        Diagnostics.Expected_1_argument_but_got_0_new_Promise_needs_a_JSDoc_hint_to_produce_a_resolve_that_can_be_called_without_arguments.code,
-        Diagnostics.Expected_0_arguments_but_got_1_Did_you_forget_to_include_void_in_your_type_argument_to_Promise.code
-      ];
-      registerCodeFix({
-        errorCodes: errorCodes63,
-        fixIds: [fixId51],
-        getCodeActions(context) {
-          const changes = ts_textChanges_exports.ChangeTracker.with(context, (t) => makeChange11(t, context.sourceFile, context.span, context.program));
-          if (changes.length > 0) {
-            return [createCodeFixAction(fixName7, changes, Diagnostics.Add_void_to_Promise_resolved_without_a_value, fixId51, Diagnostics.Add_void_to_all_Promises_resolved_without_a_value)];
+    function fromUnionableLiteralType(grandParent) {
+      switch (grandParent.kind) {
+        case 233 /* ExpressionWithTypeArguments */:
+        case 183 /* TypeReference */: {
+          const typeArgument = findAncestor(parent2, (n) => n.parent === grandParent);
+          if (typeArgument) {
+            return { kind: 2 /* Types */, types: getStringLiteralTypes(typeChecker.getTypeArgumentConstraint(typeArgument)), isNewIdentifier: false };
           }
-        },
-        getAllCodeActions(context) {
-          return codeFixAll(context, errorCodes63, (changes, diag2) => makeChange11(changes, diag2.file, diag2, context.program, /* @__PURE__ */ new Set()));
+          return void 0;
         }
-      });
+        case 199 /* IndexedAccessType */:
+          const { indexType, objectType } = grandParent;
+          if (!rangeContainsPosition(indexType, position)) {
+            return void 0;
+          }
+          return stringLiteralCompletionsFromProperties(typeChecker.getTypeFromTypeNode(objectType));
+        case 192 /* UnionType */: {
+          const result = fromUnionableLiteralType(walkUpParentheses(grandParent.parent));
+          if (!result) {
+            return void 0;
+          }
+          const alreadyUsedTypes = getAlreadyUsedTypesInStringLiteralUnion(grandParent, parent2);
+          if (result.kind === 1 /* Properties */) {
+            return { kind: 1 /* Properties */, symbols: result.symbols.filter((sym) => !contains(alreadyUsedTypes, sym.name)), hasIndexSignature: result.hasIndexSignature };
+          }
+          return { kind: 2 /* Types */, types: result.types.filter((t) => !contains(alreadyUsedTypes, t.value)), isNewIdentifier: false };
+        }
+        default:
+          return void 0;
+      }
     }
-  });
-
-  // src/services/_namespaces/ts.codefix.ts
-  var ts_codefix_exports = {};
-  __export(ts_codefix_exports, {
-    PreserveOptionalFlags: () => PreserveOptionalFlags,
-    addNewNodeForMemberSymbol: () => addNewNodeForMemberSymbol,
-    codeFixAll: () => codeFixAll,
-    createCodeFixAction: () => createCodeFixAction,
-    createCodeFixActionMaybeFixAll: () => createCodeFixActionMaybeFixAll,
-    createCodeFixActionWithoutFixAll: () => createCodeFixActionWithoutFixAll,
-    createCombinedCodeActions: () => createCombinedCodeActions,
-    createFileTextChanges: () => createFileTextChanges,
-    createImportAdder: () => createImportAdder,
-    createImportSpecifierResolver: () => createImportSpecifierResolver,
-    createJsonPropertyAssignment: () => createJsonPropertyAssignment,
-    createMissingMemberNodes: () => createMissingMemberNodes,
-    createSignatureDeclarationFromCallExpression: () => createSignatureDeclarationFromCallExpression,
-    createSignatureDeclarationFromSignature: () => createSignatureDeclarationFromSignature,
-    createStubbedBody: () => createStubbedBody,
-    eachDiagnostic: () => eachDiagnostic,
-    findAncestorMatchingSpan: () => findAncestorMatchingSpan,
-    findJsonProperty: () => findJsonProperty,
-    generateAccessorFromProperty: () => generateAccessorFromProperty,
-    getAccessorConvertiblePropertyAtPosition: () => getAccessorConvertiblePropertyAtPosition,
-    getAllFixes: () => getAllFixes,
-    getAllSupers: () => getAllSupers,
-    getArgumentTypesAndTypeParameters: () => getArgumentTypesAndTypeParameters,
-    getFixes: () => getFixes,
-    getImportCompletionAction: () => getImportCompletionAction,
-    getImportKind: () => getImportKind,
-    getJSDocTypedefNode: () => getJSDocTypedefNode,
-    getNoopSymbolTrackerWithResolver: () => getNoopSymbolTrackerWithResolver,
-    getPromoteTypeOnlyCompletionAction: () => getPromoteTypeOnlyCompletionAction,
-    getSupportedErrorCodes: () => getSupportedErrorCodes,
-    importFixName: () => importFixName,
-    importSymbols: () => importSymbols,
-    moduleSpecifierToValidIdentifier: () => moduleSpecifierToValidIdentifier,
-    moduleSymbolToValidIdentifier: () => moduleSymbolToValidIdentifier,
-    parameterShouldGetTypeFromJSDoc: () => parameterShouldGetTypeFromJSDoc,
-    registerCodeFix: () => registerCodeFix,
-    setJsonCompilerOptionValue: () => setJsonCompilerOptionValue,
-    setJsonCompilerOptionValues: () => setJsonCompilerOptionValues,
-    tryGetAutoImportableReferenceFromTypeNode: () => tryGetAutoImportableReferenceFromTypeNode,
-    typeToAutoImportableTypeNode: () => typeToAutoImportableTypeNode
-  });
-  var init_ts_codefix = __esm({
-    "src/services/_namespaces/ts.codefix.ts"() {
-      "use strict";
-      init_codeFixProvider();
-      init_addConvertToUnknownForNonOverlappingTypes();
-      init_addEmptyExportDeclaration();
-      init_addMissingAsync();
-      init_addMissingAwait();
-      init_addMissingConst();
-      init_addMissingDeclareProperty();
-      init_addMissingInvocationForDecorator();
-      init_addNameToNamelessParameter();
-      init_addOptionalPropertyUndefined();
-      init_annotateWithTypeFromJSDoc();
-      init_convertFunctionToEs6Class();
-      init_convertToAsyncFunction();
-      init_convertToEsModule();
-      init_correctQualifiedNameToIndexedAccessType();
-      init_convertToTypeOnlyExport();
-      init_convertToTypeOnlyImport();
-      init_convertTypedefToType();
-      init_convertLiteralTypeToMappedType();
-      init_fixClassIncorrectlyImplementsInterface();
-      init_importFixes();
-      init_fixAddMissingConstraint();
-      init_fixOverrideModifier();
-      init_fixNoPropertyAccessFromIndexSignature();
-      init_fixImplicitThis();
-      init_fixImportNonExportedMember();
-      init_fixIncorrectNamedTupleSyntax();
-      init_fixSpelling();
-      init_returnValueCorrect();
-      init_fixAddMissingMember();
-      init_fixAddMissingNewOperator();
-      init_fixCannotFindModule();
-      init_fixClassDoesntImplementInheritedAbstractMember();
-      init_fixClassSuperMustPrecedeThisAccess();
-      init_fixConstructorForDerivedNeedSuperCall();
-      init_fixEnableJsxFlag();
-      init_fixNaNEquality();
-      init_fixModuleAndTargetOptions();
-      init_fixPropertyAssignment();
-      init_fixExtendsInterfaceBecomesImplements();
-      init_fixForgottenThisPropertyAccess();
-      init_fixInvalidJsxCharacters();
-      init_fixUnmatchedParameter();
-      init_fixUnreferenceableDecoratorMetadata();
-      init_fixUnusedIdentifier();
-      init_fixUnreachableCode();
-      init_fixUnusedLabel();
-      init_fixJSDocTypes();
-      init_fixMissingCallParentheses();
-      init_fixAwaitInSyncFunction();
-      init_fixPropertyOverrideAccessor();
-      init_inferFromUsage();
-      init_fixReturnTypeInAsyncFunction();
-      init_disableJsDiagnostics();
-      init_helpers2();
-      init_generateAccessors();
-      init_fixInvalidImportSyntax();
-      init_fixStrictClassInitialization();
-      init_requireInTs();
-      init_useDefaultImport();
-      init_useBigintLiteral();
-      init_fixAddModuleReferTypeMissingTypeof();
-      init_wrapJsxInFragment();
-      init_convertToMappedObjectType();
-      init_removeAccidentalCallParentheses();
-      init_removeUnnecessaryAwait();
-      init_splitTypeOnlyImport();
-      init_convertConstToLet();
-      init_fixExpectedComma();
-      init_fixAddVoidToPromise();
+    function fromContextualType(contextFlags = 4 /* Completions */) {
+      const types = getStringLiteralTypes(getContextualTypeFromParent(node, typeChecker, contextFlags));
+      if (!types.length) {
+        return;
+      }
+      return { kind: 2 /* Types */, types, isNewIdentifier: false };
     }
-  });
-
-  // src/services/completions.ts
-  function originIsThisType(origin) {
-    return !!(origin.kind & 1 /* ThisType */);
   }
-  function originIsSymbolMember(origin) {
-    return !!(origin.kind & 2 /* SymbolMember */);
+  function walkUpParentheses(node) {
+    switch (node.kind) {
+      case 196 /* ParenthesizedType */:
+        return walkUpParenthesizedTypes(node);
+      case 217 /* ParenthesizedExpression */:
+        return walkUpParenthesizedExpressions(node);
+      default:
+        return node;
+    }
   }
-  function originIsExport(origin) {
-    return !!(origin && origin.kind & 4 /* Export */);
+  function getAlreadyUsedTypesInStringLiteralUnion(union, current) {
+    return mapDefined(union.types, (type) => type !== current && isLiteralTypeNode(type) && isStringLiteral(type.literal) ? type.literal.text : void 0);
   }
-  function originIsResolvedExport(origin) {
-    return !!(origin && origin.kind === 32 /* ResolvedExport */);
+  function getStringLiteralCompletionsFromSignature(call, arg, argumentInfo, checker) {
+    let isNewIdentifier = false;
+    const uniques = /* @__PURE__ */ new Map();
+    const editingArgument = isJsxOpeningLikeElement(call) ? Debug.checkDefined(findAncestor(arg.parent, isJsxAttribute)) : arg;
+    const candidates = checker.getCandidateSignaturesForStringLiteralCompletions(call, editingArgument);
+    const types = flatMap(candidates, (candidate) => {
+      if (!signatureHasRestParameter(candidate) && argumentInfo.argumentCount > candidate.parameters.length)
+        return;
+      let type = candidate.getTypeParameterAtPosition(argumentInfo.argumentIndex);
+      if (isJsxOpeningLikeElement(call)) {
+        const propType = checker.getTypeOfPropertyOfType(type, getTextOfJsxAttributeName(editingArgument.name));
+        if (propType) {
+          type = propType;
+        }
+      }
+      isNewIdentifier = isNewIdentifier || !!(type.flags & 4 /* String */);
+      return getStringLiteralTypes(type, uniques);
+    });
+    return length(types) ? { kind: 2 /* Types */, types, isNewIdentifier } : void 0;
   }
-  function originIncludesSymbolName(origin) {
-    return originIsExport(origin) || originIsResolvedExport(origin) || originIsComputedPropertyName(origin);
+  function stringLiteralCompletionsFromProperties(type) {
+    return type && {
+      kind: 1 /* Properties */,
+      symbols: filter(type.getApparentProperties(), (prop) => !(prop.valueDeclaration && isPrivateIdentifierClassElementDeclaration(prop.valueDeclaration))),
+      hasIndexSignature: hasIndexSignature(type)
+    };
   }
-  function originIsPackageJsonImport(origin) {
-    return (originIsExport(origin) || originIsResolvedExport(origin)) && !!origin.isFromPackageJson;
+  function stringLiteralCompletionsForObjectLiteral(checker, objectLiteralExpression) {
+    const contextualType = checker.getContextualType(objectLiteralExpression);
+    if (!contextualType)
+      return void 0;
+    const completionsType = checker.getContextualType(objectLiteralExpression, 4 /* Completions */);
+    const symbols = getPropertiesForObjectExpression(
+      contextualType,
+      completionsType,
+      objectLiteralExpression,
+      checker
+    );
+    return {
+      kind: 1 /* Properties */,
+      symbols,
+      hasIndexSignature: hasIndexSignature(contextualType)
+    };
   }
-  function originIsPromise(origin) {
-    return !!(origin.kind & 8 /* Promise */);
+  function getStringLiteralTypes(type, uniques = /* @__PURE__ */ new Map()) {
+    if (!type)
+      return emptyArray;
+    type = skipConstraint(type);
+    return type.isUnion() ? flatMap(type.types, (t) => getStringLiteralTypes(t, uniques)) : type.isStringLiteral() && !(type.flags & 1024 /* EnumLiteral */) && addToSeen(uniques, type.value) ? [type] : emptyArray;
   }
-  function originIsNullableMember(origin) {
-    return !!(origin.kind & 16 /* Nullable */);
+  function nameAndKind(name, kind, extension) {
+    return { name, kind, extension };
   }
-  function originIsTypeOnlyAlias(origin) {
-    return !!(origin && origin.kind & 64 /* TypeOnlyAlias */);
+  function directoryResult(name) {
+    return nameAndKind(
+      name,
+      "directory" /* directory */,
+      /*extension*/
+      void 0
+    );
   }
-  function originIsObjectLiteralMethod(origin) {
-    return !!(origin && origin.kind & 128 /* ObjectLiteralMethod */);
+  function addReplacementSpans(text, textStart, names) {
+    const span = getDirectoryFragmentTextSpan(text, textStart);
+    const wholeSpan = text.length === 0 ? void 0 : createTextSpan(textStart, text.length);
+    return names.map(({ name, kind, extension }) => name.includes(directorySeparator) || name.includes(altDirectorySeparator) ? { name, kind, extension, span: wholeSpan } : { name, kind, extension, span });
   }
-  function originIsIgnore(origin) {
-    return !!(origin && origin.kind & 256 /* Ignore */);
+  function getStringLiteralCompletionsFromModuleNames(sourceFile, node, compilerOptions, host, typeChecker, preferences) {
+    return addReplacementSpans(node.text, node.getStart(sourceFile) + 1, getStringLiteralCompletionsFromModuleNamesWorker(sourceFile, node, compilerOptions, host, typeChecker, preferences));
   }
-  function originIsComputedPropertyName(origin) {
-    return !!(origin && origin.kind & 512 /* ComputedPropertyName */);
+  function getStringLiteralCompletionsFromModuleNamesWorker(sourceFile, node, compilerOptions, host, typeChecker, preferences) {
+    const literalValue = normalizeSlashes(node.text);
+    const mode = isStringLiteralLike(node) ? getModeForUsageLocation(sourceFile, node) : void 0;
+    const scriptPath = sourceFile.path;
+    const scriptDirectory = getDirectoryPath(scriptPath);
+    const extensionOptions = getExtensionOptions(compilerOptions, 1 /* ModuleSpecifier */, sourceFile, typeChecker, preferences, mode);
+    return isPathRelativeToScript(literalValue) || !compilerOptions.baseUrl && !compilerOptions.paths && (isRootedDiskPath(literalValue) || isUrl(literalValue)) ? getCompletionEntriesForRelativeModules(literalValue, scriptDirectory, compilerOptions, host, scriptPath, extensionOptions) : getCompletionEntriesForNonRelativeModules(literalValue, scriptDirectory, mode, compilerOptions, host, extensionOptions, typeChecker);
   }
-  function resolvingModuleSpecifiers(logPrefix, host, resolver, program, position, preferences, isForImportStatementCompletion, isValidTypeOnlyUseSite, cb) {
-    var _a, _b, _c;
-    const start = timestamp();
-    const needsFullResolution = isForImportStatementCompletion || moduleResolutionSupportsPackageJsonExportsAndImports(getEmitModuleResolutionKind(program.getCompilerOptions()));
-    let skippedAny = false;
-    let ambientCount = 0;
-    let resolvedCount = 0;
-    let resolvedFromCacheCount = 0;
-    let cacheAttemptCount = 0;
-    const result = cb({
-      tryResolve,
-      skippedAny: () => skippedAny,
-      resolvedAny: () => resolvedCount > 0,
-      resolvedBeyondLimit: () => resolvedCount > moduleSpecifierResolutionLimit
-    });
-    const hitRateMessage = cacheAttemptCount ? ` (${(resolvedFromCacheCount / cacheAttemptCount * 100).toFixed(1)}% hit rate)` : "";
-    (_a = host.log) == null ? void 0 : _a.call(host, `${logPrefix}: resolved ${resolvedCount} module specifiers, plus ${ambientCount} ambient and ${resolvedFromCacheCount} from cache${hitRateMessage}`);
-    (_b = host.log) == null ? void 0 : _b.call(host, `${logPrefix}: response is ${skippedAny ? "incomplete" : "complete"}`);
-    (_c = host.log) == null ? void 0 : _c.call(host, `${logPrefix}: ${timestamp() - start}`);
-    return result;
-    function tryResolve(exportInfo, isFromAmbientModule) {
-      if (isFromAmbientModule) {
-        const result3 = resolver.getModuleSpecifierForBestExportInfo(exportInfo, position, isValidTypeOnlyUseSite);
-        if (result3) {
-          ambientCount++;
-        }
-        return result3 || "failed";
-      }
-      const shouldResolveModuleSpecifier = needsFullResolution || preferences.allowIncompleteCompletions && resolvedCount < moduleSpecifierResolutionLimit;
-      const shouldGetModuleSpecifierFromCache = !shouldResolveModuleSpecifier && preferences.allowIncompleteCompletions && cacheAttemptCount < moduleSpecifierResolutionCacheAttemptLimit;
-      const result2 = shouldResolveModuleSpecifier || shouldGetModuleSpecifierFromCache ? resolver.getModuleSpecifierForBestExportInfo(exportInfo, position, isValidTypeOnlyUseSite, shouldGetModuleSpecifierFromCache) : void 0;
-      if (!shouldResolveModuleSpecifier && !shouldGetModuleSpecifierFromCache || shouldGetModuleSpecifierFromCache && !result2) {
-        skippedAny = true;
-      }
-      resolvedCount += (result2 == null ? void 0 : result2.computedWithoutCacheCount) || 0;
-      resolvedFromCacheCount += exportInfo.length - ((result2 == null ? void 0 : result2.computedWithoutCacheCount) || 0);
-      if (shouldGetModuleSpecifierFromCache) {
-        cacheAttemptCount++;
-      }
-      return result2 || (needsFullResolution ? "failed" : "skipped");
+  function getExtensionOptions(compilerOptions, referenceKind, importingSourceFile, typeChecker, preferences, resolutionMode) {
+    return {
+      extensionsToSearch: flatten(getSupportedExtensionsForModuleResolution(compilerOptions, typeChecker)),
+      referenceKind,
+      importingSourceFile,
+      endingPreference: preferences == null ? void 0 : preferences.importModuleSpecifierEnding,
+      resolutionMode
+    };
+  }
+  function getCompletionEntriesForRelativeModules(literalValue, scriptDirectory, compilerOptions, host, scriptPath, extensionOptions) {
+    if (compilerOptions.rootDirs) {
+      return getCompletionEntriesForDirectoryFragmentWithRootDirs(
+        compilerOptions.rootDirs,
+        literalValue,
+        scriptDirectory,
+        extensionOptions,
+        compilerOptions,
+        host,
+        scriptPath
+      );
+    } else {
+      return arrayFrom(getCompletionEntriesForDirectoryFragment(
+        literalValue,
+        scriptDirectory,
+        extensionOptions,
+        host,
+        /*moduleSpecifierIsRelative*/
+        true,
+        scriptPath
+      ).values());
     }
   }
-  function getCompletionsAtPosition(host, program, log, sourceFile, position, preferences, triggerCharacter, completionKind, cancellationToken, formatContext, includeSymbol = false) {
+  function getSupportedExtensionsForModuleResolution(compilerOptions, typeChecker) {
+    const ambientModulesExtensions = !typeChecker ? [] : mapDefined(typeChecker.getAmbientModules(), (module2) => {
+      const name = module2.name.slice(1, -1);
+      if (!name.startsWith("*.") || name.includes("/"))
+        return;
+      return name.slice(1);
+    });
+    const extensions = [...getSupportedExtensions(compilerOptions), ambientModulesExtensions];
+    const moduleResolution = getEmitModuleResolutionKind(compilerOptions);
+    return moduleResolutionUsesNodeModules(moduleResolution) ? getSupportedExtensionsWithJsonIfResolveJsonModule(compilerOptions, extensions) : extensions;
+  }
+  function getBaseDirectoriesFromRootDirs(rootDirs, basePath, scriptDirectory, ignoreCase) {
+    rootDirs = rootDirs.map((rootDirectory) => ensureTrailingDirectorySeparator(normalizePath(isRootedDiskPath(rootDirectory) ? rootDirectory : combinePaths(basePath, rootDirectory))));
+    const relativeDirectory = firstDefined(rootDirs, (rootDirectory) => containsPath(rootDirectory, scriptDirectory, basePath, ignoreCase) ? scriptDirectory.substr(rootDirectory.length) : void 0);
+    return deduplicate(
+      [...rootDirs.map((rootDirectory) => combinePaths(rootDirectory, relativeDirectory)), scriptDirectory].map((baseDir) => removeTrailingDirectorySeparator(baseDir)),
+      equateStringsCaseSensitive,
+      compareStringsCaseSensitive
+    );
+  }
+  function getCompletionEntriesForDirectoryFragmentWithRootDirs(rootDirs, fragment, scriptDirectory, extensionOptions, compilerOptions, host, exclude) {
+    const basePath = compilerOptions.project || host.getCurrentDirectory();
+    const ignoreCase = !(host.useCaseSensitiveFileNames && host.useCaseSensitiveFileNames());
+    const baseDirectories = getBaseDirectoriesFromRootDirs(rootDirs, basePath, scriptDirectory, ignoreCase);
+    return flatMap(baseDirectories, (baseDirectory) => arrayFrom(getCompletionEntriesForDirectoryFragment(
+      fragment,
+      baseDirectory,
+      extensionOptions,
+      host,
+      /*moduleSpecifierIsRelative*/
+      true,
+      exclude
+    ).values()));
+  }
+  function getCompletionEntriesForDirectoryFragment(fragment, scriptDirectory, extensionOptions, host, moduleSpecifierIsRelative, exclude, result = createNameAndKindSet()) {
     var _a;
-    const { previousToken } = getRelevantTokens(position, sourceFile);
-    if (triggerCharacter && !isInString(sourceFile, position, previousToken) && !isValidTrigger(sourceFile, triggerCharacter, previousToken, position)) {
-      return void 0;
-    }
-    if (triggerCharacter === " ") {
-      if (preferences.includeCompletionsForImportStatements && preferences.includeCompletionsWithInsertText) {
-        return { isGlobalCompletion: true, isMemberCompletion: false, isNewIdentifierLocation: true, isIncomplete: true, entries: [] };
-      }
-      return void 0;
+    if (fragment === void 0) {
+      fragment = "";
     }
-    const compilerOptions = program.getCompilerOptions();
-    const checker = program.getTypeChecker();
-    const incompleteCompletionsCache = preferences.allowIncompleteCompletions ? (_a = host.getIncompleteCompletionsCache) == null ? void 0 : _a.call(host) : void 0;
-    if (incompleteCompletionsCache && completionKind === 3 /* TriggerForIncompleteCompletions */ && previousToken && isIdentifier(previousToken)) {
-      const incompleteContinuation = continuePreviousIncompleteResponse(incompleteCompletionsCache, sourceFile, previousToken, program, host, preferences, cancellationToken, position);
-      if (incompleteContinuation) {
-        return incompleteContinuation;
-      }
-    } else {
-      incompleteCompletionsCache == null ? void 0 : incompleteCompletionsCache.clear();
+    fragment = normalizeSlashes(fragment);
+    if (!hasTrailingDirectorySeparator(fragment)) {
+      fragment = getDirectoryPath(fragment);
     }
-    const stringCompletions = ts_Completions_StringCompletions_exports.getStringLiteralCompletions(sourceFile, position, previousToken, compilerOptions, host, program, log, preferences, includeSymbol);
-    if (stringCompletions) {
-      return stringCompletions;
+    if (fragment === "") {
+      fragment = "." + directorySeparator;
     }
-    if (previousToken && isBreakOrContinueStatement(previousToken.parent) && (previousToken.kind === 83 /* BreakKeyword */ || previousToken.kind === 88 /* ContinueKeyword */ || previousToken.kind === 80 /* Identifier */)) {
-      return getLabelCompletionAtPosition(previousToken.parent);
+    fragment = ensureTrailingDirectorySeparator(fragment);
+    const absolutePath = resolvePath(scriptDirectory, fragment);
+    const baseDirectory = hasTrailingDirectorySeparator(absolutePath) ? absolutePath : getDirectoryPath(absolutePath);
+    if (!moduleSpecifierIsRelative) {
+      const packageJsonPath = findPackageJson(baseDirectory, host);
+      if (packageJsonPath) {
+        const packageJson = readJson(packageJsonPath, host);
+        const typesVersions = packageJson.typesVersions;
+        if (typeof typesVersions === "object") {
+          const versionPaths = (_a = getPackageJsonTypesVersionsPaths(typesVersions)) == null ? void 0 : _a.paths;
+          if (versionPaths) {
+            const packageDirectory = getDirectoryPath(packageJsonPath);
+            const pathInPackage = absolutePath.slice(ensureTrailingDirectorySeparator(packageDirectory).length);
+            if (addCompletionEntriesFromPaths(result, pathInPackage, packageDirectory, extensionOptions, host, versionPaths)) {
+              return result;
+            }
+          }
+        }
+      }
     }
-    const completionData = getCompletionData(
-      program,
-      log,
-      sourceFile,
-      compilerOptions,
-      position,
-      preferences,
-      /*detailsEntryId*/
-      void 0,
+    const ignoreCase = !(host.useCaseSensitiveFileNames && host.useCaseSensitiveFileNames());
+    if (!tryDirectoryExists(host, baseDirectory))
+      return result;
+    const files = tryReadDirectory(
       host,
-      formatContext,
-      cancellationToken
+      baseDirectory,
+      extensionOptions.extensionsToSearch,
+      /*exclude*/
+      void 0,
+      /*include*/
+      ["./*"]
     );
-    if (!completionData) {
-      return void 0;
+    if (files) {
+      for (let filePath of files) {
+        filePath = normalizePath(filePath);
+        if (exclude && comparePaths(filePath, exclude, scriptDirectory, ignoreCase) === 0 /* EqualTo */) {
+          continue;
+        }
+        const { name, extension } = getFilenameWithExtensionOption(getBaseFileName(filePath), host.getCompilationSettings(), extensionOptions);
+        result.add(nameAndKind(name, "script" /* scriptElement */, extension));
+      }
     }
-    switch (completionData.kind) {
-      case 0 /* Data */:
-        const response = completionInfoFromData(sourceFile, host, program, compilerOptions, log, completionData, preferences, formatContext, position, includeSymbol);
-        if (response == null ? void 0 : response.isIncomplete) {
-          incompleteCompletionsCache == null ? void 0 : incompleteCompletionsCache.set(response);
+    const directories = tryGetDirectories(host, baseDirectory);
+    if (directories) {
+      for (const directory of directories) {
+        const directoryName = getBaseFileName(normalizePath(directory));
+        if (directoryName !== "@types") {
+          result.add(directoryResult(directoryName));
         }
-        return response;
-      case 1 /* JsDocTagName */:
-        return jsdocCompletionInfo([
-          ...ts_JsDoc_exports.getJSDocTagNameCompletions(),
-          ...getJSDocParameterCompletions(
-            sourceFile,
-            position,
-            checker,
-            compilerOptions,
-            preferences,
-            /*tagNameOnly*/
-            true
-          )
-        ]);
-      case 2 /* JsDocTag */:
-        return jsdocCompletionInfo([
-          ...ts_JsDoc_exports.getJSDocTagCompletions(),
-          ...getJSDocParameterCompletions(
-            sourceFile,
-            position,
-            checker,
-            compilerOptions,
-            preferences,
-            /*tagNameOnly*/
-            false
-          )
-        ]);
-      case 3 /* JsDocParameterName */:
-        return jsdocCompletionInfo(ts_JsDoc_exports.getJSDocParameterNameCompletions(completionData.tag));
-      case 4 /* Keywords */:
-        return specificKeywordCompletionInfo(completionData.keywordCompletions, completionData.isNewIdentifierLocation);
-      default:
-        return Debug.assertNever(completionData);
+      }
     }
+    return result;
   }
-  function compareCompletionEntries(entryInArray, entryToInsert) {
-    var _a, _b;
-    let result = compareStringsCaseSensitiveUI(entryInArray.sortText, entryToInsert.sortText);
-    if (result === 0 /* EqualTo */) {
-      result = compareStringsCaseSensitiveUI(entryInArray.name, entryToInsert.name);
+  function getFilenameWithExtensionOption(name, compilerOptions, extensionOptions) {
+    const nonJsResult = ts_moduleSpecifiers_exports.tryGetRealFileNameForNonJsDeclarationFileName(name);
+    if (nonJsResult) {
+      return { name: nonJsResult, extension: tryGetExtensionFromPath2(nonJsResult) };
     }
-    if (result === 0 /* EqualTo */ && ((_a = entryInArray.data) == null ? void 0 : _a.moduleSpecifier) && ((_b = entryToInsert.data) == null ? void 0 : _b.moduleSpecifier)) {
-      result = compareNumberOfDirectorySeparators(
-        entryInArray.data.moduleSpecifier,
-        entryToInsert.data.moduleSpecifier
-      );
+    if (extensionOptions.referenceKind === 0 /* Filename */) {
+      return { name, extension: tryGetExtensionFromPath2(name) };
     }
-    if (result === 0 /* EqualTo */) {
-      return -1 /* LessThan */;
+    const endingPreference = getModuleSpecifierEndingPreference(extensionOptions.endingPreference, extensionOptions.resolutionMode, compilerOptions, extensionOptions.importingSourceFile);
+    if (endingPreference === 3 /* TsExtension */) {
+      if (fileExtensionIsOneOf(name, supportedTSImplementationExtensions)) {
+        return { name, extension: tryGetExtensionFromPath2(name) };
+      }
+      const outputExtension2 = ts_moduleSpecifiers_exports.tryGetJSExtensionForFile(name, compilerOptions);
+      return outputExtension2 ? { name: changeExtension(name, outputExtension2), extension: outputExtension2 } : { name, extension: tryGetExtensionFromPath2(name) };
     }
-    return result;
+    if ((endingPreference === 0 /* Minimal */ || endingPreference === 1 /* Index */) && fileExtensionIsOneOf(name, [".js" /* Js */, ".jsx" /* Jsx */, ".ts" /* Ts */, ".tsx" /* Tsx */, ".d.ts" /* Dts */])) {
+      return { name: removeFileExtension(name), extension: tryGetExtensionFromPath2(name) };
+    }
+    const outputExtension = ts_moduleSpecifiers_exports.tryGetJSExtensionForFile(name, compilerOptions);
+    return outputExtension ? { name: changeExtension(name, outputExtension), extension: outputExtension } : { name, extension: tryGetExtensionFromPath2(name) };
   }
-  function completionEntryDataIsResolved(data) {
-    return !!(data == null ? void 0 : data.moduleSpecifier);
+  function addCompletionEntriesFromPaths(result, fragment, baseDirectory, extensionOptions, host, paths) {
+    const getPatternsForKey = (key) => paths[key];
+    const comparePaths2 = (a, b) => {
+      const patternA = tryParsePattern(a);
+      const patternB = tryParsePattern(b);
+      const lengthA = typeof patternA === "object" ? patternA.prefix.length : a.length;
+      const lengthB = typeof patternB === "object" ? patternB.prefix.length : b.length;
+      return compareValues(lengthB, lengthA);
+    };
+    return addCompletionEntriesFromPathsOrExports(result, fragment, baseDirectory, extensionOptions, host, getOwnKeys(paths), getPatternsForKey, comparePaths2);
   }
-  function continuePreviousIncompleteResponse(cache, file, location, program, host, preferences, cancellationToken, position) {
-    const previousResponse = cache.get();
-    if (!previousResponse)
-      return void 0;
-    const touchNode = getTouchingPropertyName(file, position);
-    const lowerCaseTokenText = location.text.toLowerCase();
-    const exportMap = getExportInfoMap(file, host, program, preferences, cancellationToken);
-    const newEntries = resolvingModuleSpecifiers(
-      "continuePreviousIncompleteResponse",
-      host,
-      ts_codefix_exports.createImportSpecifierResolver(file, program, host, preferences),
-      program,
-      location.getStart(),
-      preferences,
-      /*isForImportStatementCompletion*/
-      false,
-      isValidTypeOnlyAliasUseSite(location),
-      (context) => {
-        const entries = mapDefined(previousResponse.entries, (entry) => {
-          var _a;
-          if (!entry.hasAction || !entry.source || !entry.data || completionEntryDataIsResolved(entry.data)) {
-            return entry;
-          }
-          if (!charactersFuzzyMatchInString(entry.name, lowerCaseTokenText)) {
-            return void 0;
-          }
-          const { origin } = Debug.checkDefined(getAutoImportSymbolFromCompletionEntryData(entry.name, entry.data, program, host));
-          const info = exportMap.get(file.path, entry.data.exportMapKey);
-          const result = info && context.tryResolve(info, !isExternalModuleNameRelative(stripQuotes(origin.moduleSymbol.name)));
-          if (result === "skipped")
-            return entry;
-          if (!result || result === "failed") {
-            (_a = host.log) == null ? void 0 : _a.call(host, `Unexpected failure resolving auto import for '${entry.name}' from '${entry.source}'`);
-            return void 0;
-          }
-          const newOrigin = {
-            ...origin,
-            kind: 32 /* ResolvedExport */,
-            moduleSpecifier: result.moduleSpecifier
-          };
-          entry.data = originToCompletionEntryData(newOrigin);
-          entry.source = getSourceFromOrigin(newOrigin);
-          entry.sourceDisplay = [textPart(newOrigin.moduleSpecifier)];
-          return entry;
-        });
-        if (!context.skippedAny()) {
-          previousResponse.isIncomplete = void 0;
+  function addCompletionEntriesFromPathsOrExports(result, fragment, baseDirectory, extensionOptions, host, keys, getPatternsForKey, comparePaths2) {
+    let pathResults = [];
+    let matchedPath;
+    for (const key of keys) {
+      if (key === ".")
+        continue;
+      const keyWithoutLeadingDotSlash = key.replace(/^\.\//, "");
+      const patterns = getPatternsForKey(key);
+      if (patterns) {
+        const pathPattern = tryParsePattern(keyWithoutLeadingDotSlash);
+        if (!pathPattern)
+          continue;
+        const isMatch = typeof pathPattern === "object" && isPatternMatch(pathPattern, fragment);
+        const isLongestMatch = isMatch && (matchedPath === void 0 || comparePaths2(key, matchedPath) === -1 /* LessThan */);
+        if (isLongestMatch) {
+          matchedPath = key;
+          pathResults = pathResults.filter((r) => !r.matchedPattern);
+        }
+        if (typeof pathPattern === "string" || matchedPath === void 0 || comparePaths2(key, matchedPath) !== 1 /* GreaterThan */) {
+          pathResults.push({
+            matchedPattern: isMatch,
+            results: getCompletionsForPathMapping(keyWithoutLeadingDotSlash, patterns, fragment, baseDirectory, extensionOptions, host).map(({ name, kind, extension }) => nameAndKind(name, kind, extension))
+          });
         }
-        return entries;
       }
-    );
-    previousResponse.entries = newEntries;
-    previousResponse.flags = (previousResponse.flags || 0) | 4 /* IsContinuation */;
-    previousResponse.optionalReplacementSpan = getOptionalReplacementSpan(touchNode);
-    return previousResponse;
-  }
-  function jsdocCompletionInfo(entries) {
-    return { isGlobalCompletion: false, isMemberCompletion: false, isNewIdentifierLocation: false, entries };
+    }
+    pathResults.forEach((pathResult) => pathResult.results.forEach((r) => result.add(r)));
+    return matchedPath !== void 0;
   }
-  function getJSDocParameterCompletions(sourceFile, position, checker, options, preferences, tagNameOnly) {
-    const currentToken = getTokenAtPosition(sourceFile, position);
-    if (!isJSDocTag(currentToken) && !isJSDoc(currentToken)) {
-      return [];
+  function getCompletionEntriesForNonRelativeModules(fragment, scriptPath, mode, compilerOptions, host, extensionOptions, typeChecker) {
+    const { baseUrl, paths } = compilerOptions;
+    const result = createNameAndKindSet();
+    const moduleResolution = getEmitModuleResolutionKind(compilerOptions);
+    if (baseUrl) {
+      const absolute = normalizePath(combinePaths(host.getCurrentDirectory(), baseUrl));
+      getCompletionEntriesForDirectoryFragment(
+        fragment,
+        absolute,
+        extensionOptions,
+        host,
+        /*moduleSpecifierIsRelative*/
+        false,
+        /*exclude*/
+        void 0,
+        result
+      );
     }
-    const jsDoc = isJSDoc(currentToken) ? currentToken : currentToken.parent;
-    if (!isJSDoc(jsDoc)) {
-      return [];
+    if (paths) {
+      const absolute = getPathsBasePath(compilerOptions, host);
+      addCompletionEntriesFromPaths(result, fragment, absolute, extensionOptions, host, paths);
     }
-    const func = jsDoc.parent;
-    if (!isFunctionLike(func)) {
-      return [];
+    const fragmentDirectory = getFragmentDirectory(fragment);
+    for (const ambientName of getAmbientModuleCompletions(fragment, fragmentDirectory, typeChecker)) {
+      result.add(nameAndKind(
+        ambientName,
+        "external module name" /* externalModuleName */,
+        /*extension*/
+        void 0
+      ));
     }
-    const isJs = isSourceFileJS(sourceFile);
-    const isSnippet = preferences.includeCompletionsWithSnippetText || void 0;
-    const paramTagCount = countWhere(jsDoc.tags, (tag) => isJSDocParameterTag(tag) && tag.getEnd() <= position);
-    return mapDefined(func.parameters, (param) => {
-      if (getJSDocParameterTags(param).length) {
-        return void 0;
-      }
-      if (isIdentifier(param.name)) {
-        const tabstopCounter = { tabstop: 1 };
-        const paramName = param.name.text;
-        let displayText = getJSDocParamAnnotation(
-          paramName,
-          param.initializer,
-          param.dotDotDotToken,
-          isJs,
-          /*isObject*/
-          false,
-          /*isSnippet*/
-          false,
-          checker,
-          options,
-          preferences
-        );
-        let snippetText = isSnippet ? getJSDocParamAnnotation(
-          paramName,
-          param.initializer,
-          param.dotDotDotToken,
-          isJs,
-          /*isObject*/
-          false,
-          /*isSnippet*/
-          true,
-          checker,
-          options,
-          preferences,
-          tabstopCounter
-        ) : void 0;
-        if (tagNameOnly) {
-          displayText = displayText.slice(1);
-          if (snippetText)
-            snippetText = snippetText.slice(1);
-        }
-        return {
-          name: displayText,
-          kind: "parameter" /* parameterElement */,
-          sortText: SortText.LocationPriority,
-          insertText: isSnippet ? snippetText : void 0,
-          isSnippet
-        };
-      } else if (param.parent.parameters.indexOf(param) === paramTagCount) {
-        const paramPath = `param${paramTagCount}`;
-        const displayTextResult = generateJSDocParamTagsForDestructuring(
-          paramPath,
-          param.name,
-          param.initializer,
-          param.dotDotDotToken,
-          isJs,
-          /*isSnippet*/
-          false,
-          checker,
-          options,
-          preferences
-        );
-        const snippetTextResult = isSnippet ? generateJSDocParamTagsForDestructuring(
-          paramPath,
-          param.name,
-          param.initializer,
-          param.dotDotDotToken,
-          isJs,
-          /*isSnippet*/
-          true,
-          checker,
-          options,
-          preferences
-        ) : void 0;
-        let displayText = displayTextResult.join(getNewLineCharacter(options) + "* ");
-        let snippetText = snippetTextResult == null ? void 0 : snippetTextResult.join(getNewLineCharacter(options) + "* ");
-        if (tagNameOnly) {
-          displayText = displayText.slice(1);
-          if (snippetText)
-            snippetText = snippetText.slice(1);
+    getCompletionEntriesFromTypings(host, compilerOptions, scriptPath, fragmentDirectory, extensionOptions, result);
+    if (moduleResolutionUsesNodeModules(moduleResolution)) {
+      let foundGlobal = false;
+      if (fragmentDirectory === void 0) {
+        for (const moduleName of enumerateNodeModulesVisibleToScript(host, scriptPath)) {
+          const moduleResult = nameAndKind(
+            moduleName,
+            "external module name" /* externalModuleName */,
+            /*extension*/
+            void 0
+          );
+          if (!result.has(moduleResult.name)) {
+            foundGlobal = true;
+            result.add(moduleResult);
+          }
         }
-        return {
-          name: displayText,
-          kind: "parameter" /* parameterElement */,
-          sortText: SortText.LocationPriority,
-          insertText: isSnippet ? snippetText : void 0,
-          isSnippet
-        };
       }
-    });
-  }
-  function generateJSDocParamTagsForDestructuring(path, pattern, initializer, dotDotDotToken, isJs, isSnippet, checker, options, preferences) {
-    if (!isJs) {
-      return [
-        getJSDocParamAnnotation(
-          path,
-          initializer,
-          dotDotDotToken,
-          isJs,
-          /*isObject*/
-          false,
-          isSnippet,
-          checker,
-          options,
-          preferences,
-          { tabstop: 1 }
-        )
-      ];
-    }
-    return patternWorker(path, pattern, initializer, dotDotDotToken, { tabstop: 1 });
-    function patternWorker(path2, pattern2, initializer2, dotDotDotToken2, counter) {
-      if (isObjectBindingPattern(pattern2) && !dotDotDotToken2) {
-        const oldTabstop = counter.tabstop;
-        const childCounter = { tabstop: oldTabstop };
-        const rootParam = getJSDocParamAnnotation(
-          path2,
-          initializer2,
-          dotDotDotToken2,
-          isJs,
-          /*isObject*/
-          true,
-          isSnippet,
-          checker,
-          options,
-          preferences,
-          childCounter
-        );
-        let childTags = [];
-        for (const element of pattern2.elements) {
-          const elementTags = elementWorker(path2, element, childCounter);
-          if (!elementTags) {
-            childTags = void 0;
-            break;
-          } else {
-            childTags.push(...elementTags);
+      if (!foundGlobal) {
+        let ancestorLookup = (ancestor) => {
+          const nodeModules = combinePaths(ancestor, "node_modules");
+          if (tryDirectoryExists(host, nodeModules)) {
+            getCompletionEntriesForDirectoryFragment(
+              fragment,
+              nodeModules,
+              extensionOptions,
+              host,
+              /*moduleSpecifierIsRelative*/
+              false,
+              /*exclude*/
+              void 0,
+              result
+            );
+          }
+        };
+        const checkExports = (packageFile, packageDirectory, fragmentSubpath) => {
+          const packageJson = readJson(packageFile, host);
+          const exports = packageJson.exports;
+          if (exports) {
+            if (typeof exports !== "object" || exports === null) {
+              return true;
+            }
+            const keys = getOwnKeys(exports);
+            const conditions = getConditions(compilerOptions, mode);
+            addCompletionEntriesFromPathsOrExports(
+              result,
+              fragmentSubpath,
+              packageDirectory,
+              extensionOptions,
+              host,
+              keys,
+              (key) => singleElementArray(getPatternFromFirstMatchingCondition(exports[key], conditions)),
+              comparePatternKeys
+            );
+            return true;
           }
+          return false;
+        };
+        const shouldCheckExports = fragmentDirectory && getResolvePackageJsonExports(compilerOptions);
+        if (shouldCheckExports) {
+          const nodeModulesDirectoryLookup = ancestorLookup;
+          ancestorLookup = (ancestor) => {
+            const components = getPathComponents(fragment);
+            components.shift();
+            let packagePath = components.shift();
+            if (!packagePath) {
+              return nodeModulesDirectoryLookup(ancestor);
+            }
+            if (startsWith(packagePath, "@")) {
+              const subName = components.shift();
+              if (!subName) {
+                return nodeModulesDirectoryLookup(ancestor);
+              }
+              packagePath = combinePaths(packagePath, subName);
+            }
+            const packageDirectory = combinePaths(ancestor, "node_modules", packagePath);
+            const packageFile = combinePaths(packageDirectory, "package.json");
+            if (tryFileExists(host, packageFile)) {
+              const fragmentSubpath = components.join("/") + (components.length && hasTrailingDirectorySeparator(fragment) ? "/" : "");
+              if (checkExports(packageFile, packageDirectory, fragmentSubpath)) {
+                return;
+              }
+            }
+            return nodeModulesDirectoryLookup(ancestor);
+          };
         }
-        if (childTags) {
-          counter.tabstop = childCounter.tabstop;
-          return [rootParam, ...childTags];
+        const pnpApi = getPnpApi(scriptPath);
+        if (pnpApi) {
+          const pathRegExp = /^(?![a-zA-Z]:[\\/]|\\\\|\.{0,2}(?:\/|$))((?:@[^/]+\/)?[^/]+)\/*(.*|)$/;
+          const dependencyNameMatch = fragment.match(pathRegExp);
+          if (dependencyNameMatch) {
+            const [, dependencyName, subPath] = dependencyNameMatch;
+            let unqualified;
+            try {
+              unqualified = pnpApi.resolveToUnqualified(dependencyName, scriptPath, { considerBuiltins: false });
+            } catch {
+            }
+            if (unqualified) {
+              const packageDirectory = normalizePath(unqualified);
+              let shouldGetCompletions = true;
+              if (shouldCheckExports) {
+                const packageFile = combinePaths(packageDirectory, "package.json");
+                if (tryFileExists(host, packageFile) && checkExports(packageFile, packageDirectory, subPath)) {
+                  shouldGetCompletions = false;
+                }
+              }
+              if (shouldGetCompletions) {
+                getCompletionEntriesForDirectoryFragment(
+                  subPath,
+                  packageDirectory,
+                  extensionOptions,
+                  host,
+                  /*moduleSpecifierIsRelative*/
+                  false,
+                  /*exclude*/
+                  void 0,
+                  result
+                );
+              }
+            }
+          }
+        } else {
+          forEachAncestorDirectory(scriptPath, ancestorLookup);
         }
       }
-      return [
-        getJSDocParamAnnotation(
-          path2,
-          initializer2,
-          dotDotDotToken2,
-          isJs,
-          /*isObject*/
-          false,
-          isSnippet,
-          checker,
-          options,
-          preferences,
-          counter
-        )
-      ];
     }
-    function elementWorker(path2, element, counter) {
-      if (!element.propertyName && isIdentifier(element.name) || isIdentifier(element.name)) {
-        const propertyName = element.propertyName ? tryGetTextOfPropertyName(element.propertyName) : element.name.text;
-        if (!propertyName) {
-          return void 0;
+    return arrayFrom(result.values());
+  }
+  function getPatternFromFirstMatchingCondition(target, conditions) {
+    if (typeof target === "string") {
+      return target;
+    }
+    if (target && typeof target === "object" && !isArray(target)) {
+      for (const condition in target) {
+        if (condition === "default" || conditions.includes(condition) || isApplicableVersionedTypesKey(conditions, condition)) {
+          const pattern = target[condition];
+          return getPatternFromFirstMatchingCondition(pattern, conditions);
         }
-        const paramName = `${path2}.${propertyName}`;
-        return [
-          getJSDocParamAnnotation(
-            paramName,
-            element.initializer,
-            element.dotDotDotToken,
-            isJs,
-            /*isObject*/
-            false,
-            isSnippet,
-            checker,
-            options,
-            preferences,
-            counter
-          )
-        ];
-      } else if (element.propertyName) {
-        const propertyName = tryGetTextOfPropertyName(element.propertyName);
-        return propertyName && patternWorker(`${path2}.${propertyName}`, element.name, element.initializer, element.dotDotDotToken, counter);
       }
-      return void 0;
     }
   }
-  function getJSDocParamAnnotation(paramName, initializer, dotDotDotToken, isJs, isObject, isSnippet, checker, options, preferences, tabstopCounter) {
-    if (isSnippet) {
-      Debug.assertIsDefined(tabstopCounter);
+  function getFragmentDirectory(fragment) {
+    return containsSlash(fragment) ? hasTrailingDirectorySeparator(fragment) ? fragment : getDirectoryPath(fragment) : void 0;
+  }
+  function getCompletionsForPathMapping(path, patterns, fragment, packageDirectory, extensionOptions, host) {
+    if (!endsWith(path, "*")) {
+      return !path.includes("*") ? justPathMappingName(path, "script" /* scriptElement */) : emptyArray;
     }
-    if (initializer) {
-      paramName = getJSDocParamNameWithInitializer(paramName, initializer);
+    const pathPrefix = path.slice(0, path.length - 1);
+    const remainingFragment = tryRemovePrefix(fragment, pathPrefix);
+    if (remainingFragment === void 0) {
+      const starIsFullPathComponent = path[path.length - 2] === "/";
+      return starIsFullPathComponent ? justPathMappingName(pathPrefix, "directory" /* directory */) : flatMap(patterns, (pattern) => {
+        var _a;
+        return (_a = getModulesForPathsPattern("", packageDirectory, pattern, extensionOptions, host)) == null ? void 0 : _a.map(({ name, ...rest }) => ({ name: pathPrefix + name, ...rest }));
+      });
     }
-    if (isSnippet) {
-      paramName = escapeSnippetText(paramName);
+    return flatMap(patterns, (pattern) => getModulesForPathsPattern(remainingFragment, packageDirectory, pattern, extensionOptions, host));
+    function justPathMappingName(name, kind) {
+      return startsWith(name, fragment) ? [{ name: removeTrailingDirectorySeparator(name), kind, extension: void 0 }] : emptyArray;
     }
-    if (isJs) {
-      let type = "*";
-      if (isObject) {
-        Debug.assert(!dotDotDotToken, `Cannot annotate a rest parameter with type 'Object'.`);
-        type = "Object";
-      } else {
-        if (initializer) {
-          const inferredType = checker.getTypeAtLocation(initializer.parent);
-          if (!(inferredType.flags & (1 /* Any */ | 16384 /* Void */))) {
-            const sourceFile = initializer.getSourceFile();
-            const quotePreference = getQuotePreference(sourceFile, preferences);
-            const builderFlags = quotePreference === 0 /* Single */ ? 268435456 /* UseSingleQuotesForStringLiteralType */ : 0 /* None */;
-            const typeNode = checker.typeToTypeNode(inferredType, findAncestor(initializer, isFunctionLike), builderFlags);
-            if (typeNode) {
-              const printer = isSnippet ? createSnippetPrinter({
-                removeComments: true,
-                module: options.module,
-                target: options.target
-              }) : createPrinter({
-                removeComments: true,
-                module: options.module,
-                target: options.target
-              });
-              setEmitFlags(typeNode, 1 /* SingleLine */);
-              type = printer.printNode(4 /* Unspecified */, typeNode, sourceFile);
-            }
-          }
-        }
-        if (isSnippet && type === "*") {
-          type = `\${${tabstopCounter.tabstop++}:${type}}`;
+  }
+  function getModulesForPathsPattern(fragment, packageDirectory, pattern, extensionOptions, host) {
+    if (!host.readDirectory) {
+      return void 0;
+    }
+    const parsed = tryParsePattern(pattern);
+    if (parsed === void 0 || isString(parsed)) {
+      return void 0;
+    }
+    const normalizedPrefix = resolvePath(parsed.prefix);
+    const normalizedPrefixDirectory = hasTrailingDirectorySeparator(parsed.prefix) ? normalizedPrefix : getDirectoryPath(normalizedPrefix);
+    const normalizedPrefixBase = hasTrailingDirectorySeparator(parsed.prefix) ? "" : getBaseFileName(normalizedPrefix);
+    const fragmentHasPath = containsSlash(fragment);
+    const fragmentDirectory = fragmentHasPath ? hasTrailingDirectorySeparator(fragment) ? fragment : getDirectoryPath(fragment) : void 0;
+    const expandedPrefixDirectory = fragmentHasPath ? combinePaths(normalizedPrefixDirectory, normalizedPrefixBase + fragmentDirectory) : normalizedPrefixDirectory;
+    const normalizedSuffix = normalizePath(parsed.suffix);
+    const declarationExtension = normalizedSuffix && getDeclarationEmitExtensionForPath("_" + normalizedSuffix);
+    const matchingSuffixes = declarationExtension ? [changeExtension(normalizedSuffix, declarationExtension), normalizedSuffix] : [normalizedSuffix];
+    const baseDirectory = normalizePath(combinePaths(packageDirectory, expandedPrefixDirectory));
+    const completePrefix = fragmentHasPath ? baseDirectory : ensureTrailingDirectorySeparator(baseDirectory) + normalizedPrefixBase;
+    const includeGlobs = normalizedSuffix ? matchingSuffixes.map((suffix) => "**/*" + suffix) : ["./*"];
+    const matches = mapDefined(tryReadDirectory(
+      host,
+      baseDirectory,
+      extensionOptions.extensionsToSearch,
+      /*exclude*/
+      void 0,
+      includeGlobs
+    ), (match) => {
+      const trimmedWithPattern = trimPrefixAndSuffix(match);
+      if (trimmedWithPattern) {
+        if (containsSlash(trimmedWithPattern)) {
+          return directoryResult(getPathComponents(removeLeadingDirectorySeparator(trimmedWithPattern))[1]);
         }
+        const { name, extension } = getFilenameWithExtensionOption(trimmedWithPattern, host.getCompilationSettings(), extensionOptions);
+        return nameAndKind(name, "script" /* scriptElement */, extension);
       }
-      const dotDotDot = !isObject && dotDotDotToken ? "..." : "";
-      const description3 = isSnippet ? `\${${tabstopCounter.tabstop++}}` : "";
-      return `@param {${dotDotDot}${type}} ${paramName} ${description3}`;
-    } else {
-      const description3 = isSnippet ? `\${${tabstopCounter.tabstop++}}` : "";
-      return `@param ${paramName} ${description3}`;
-    }
-  }
-  function getJSDocParamNameWithInitializer(paramName, initializer) {
-    const initializerText = initializer.getText().trim();
-    if (initializerText.includes("\n") || initializerText.length > 80) {
-      return `[${paramName}]`;
+    });
+    const directories = normalizedSuffix ? emptyArray : mapDefined(tryGetDirectories(host, baseDirectory), (dir) => dir === "node_modules" ? void 0 : directoryResult(dir));
+    return [...matches, ...directories];
+    function trimPrefixAndSuffix(path) {
+      return firstDefined(matchingSuffixes, (suffix) => {
+        const inner = withoutStartAndEnd(normalizePath(path), completePrefix, suffix);
+        return inner === void 0 ? void 0 : removeLeadingDirectorySeparator(inner);
+      });
     }
-    return `[${paramName}=${initializerText}]`;
-  }
-  function keywordToCompletionEntry(keyword) {
-    return {
-      name: tokenToString(keyword),
-      kind: "keyword" /* keyword */,
-      kindModifiers: "" /* none */,
-      sortText: SortText.GlobalsOrKeywords
-    };
   }
-  function specificKeywordCompletionInfo(entries, isNewIdentifierLocation) {
-    return {
-      isGlobalCompletion: false,
-      isMemberCompletion: false,
-      isNewIdentifierLocation,
-      entries: entries.slice()
-    };
+  function withoutStartAndEnd(s, start, end) {
+    return startsWith(s, start) && endsWith(s, end) ? s.slice(start.length, s.length - end.length) : void 0;
   }
-  function keywordCompletionData(keywordFilters, filterOutTsOnlyKeywords, isNewIdentifierLocation) {
-    return {
-      kind: 4 /* Keywords */,
-      keywordCompletions: getKeywordCompletions(keywordFilters, filterOutTsOnlyKeywords),
-      isNewIdentifierLocation
-    };
+  function removeLeadingDirectorySeparator(path) {
+    return path[0] === directorySeparator ? path.slice(1) : path;
   }
-  function keywordFiltersFromSyntaxKind(keywordCompletion) {
-    switch (keywordCompletion) {
-      case 156 /* TypeKeyword */:
-        return 8 /* TypeKeyword */;
-      default:
-        Debug.fail("Unknown mapping from SyntaxKind to KeywordCompletionFilters");
+  function getAmbientModuleCompletions(fragment, fragmentDirectory, checker) {
+    const ambientModules = checker.getAmbientModules().map((sym) => stripQuotes(sym.name));
+    const nonRelativeModuleNames = ambientModules.filter((moduleName) => startsWith(moduleName, fragment) && !moduleName.includes("*"));
+    if (fragmentDirectory !== void 0) {
+      const moduleNameWithSeparator = ensureTrailingDirectorySeparator(fragmentDirectory);
+      return nonRelativeModuleNames.map((nonRelativeModuleName) => removePrefix(nonRelativeModuleName, moduleNameWithSeparator));
     }
+    return nonRelativeModuleNames;
   }
-  function getOptionalReplacementSpan(location) {
-    return (location == null ? void 0 : location.kind) === 80 /* Identifier */ ? createTextSpanFromNode(location) : void 0;
+  function getTripleSlashReferenceCompletion(sourceFile, position, compilerOptions, host) {
+    const token = getTokenAtPosition(sourceFile, position);
+    const commentRanges = getLeadingCommentRanges(sourceFile.text, token.pos);
+    const range = commentRanges && find(commentRanges, (commentRange) => position >= commentRange.pos && position <= commentRange.end);
+    if (!range) {
+      return void 0;
+    }
+    const text = sourceFile.text.slice(range.pos, position);
+    const match = tripleSlashDirectiveFragmentRegex.exec(text);
+    if (!match) {
+      return void 0;
+    }
+    const [, prefix, kind, toComplete] = match;
+    const scriptPath = getDirectoryPath(sourceFile.path);
+    const names = kind === "path" ? getCompletionEntriesForDirectoryFragment(
+      toComplete,
+      scriptPath,
+      getExtensionOptions(compilerOptions, 0 /* Filename */, sourceFile),
+      host,
+      /*moduleSpecifierIsRelative*/
+      true,
+      sourceFile.path
+    ) : kind === "types" ? getCompletionEntriesFromTypings(host, compilerOptions, scriptPath, getFragmentDirectory(toComplete), getExtensionOptions(compilerOptions, 1 /* ModuleSpecifier */, sourceFile)) : Debug.fail();
+    return addReplacementSpans(toComplete, range.pos + prefix.length, arrayFrom(names.values()));
   }
-  function completionInfoFromData(sourceFile, host, program, compilerOptions, log, completionData, preferences, formatContext, position, includeSymbol) {
-    const {
-      symbols,
-      contextToken,
-      completionKind,
-      isInSnippetScope,
-      isNewIdentifierLocation,
-      location,
-      propertyAccessToConvert,
-      keywordFilters,
-      symbolToOriginInfoMap,
-      recommendedCompletion,
-      isJsxInitializer,
-      isTypeOnlyLocation,
-      isJsxIdentifierExpected,
-      isRightOfOpenTag,
-      isRightOfDotOrQuestionDot,
-      importStatementCompletion,
-      insideJsDocTagTypeExpression,
-      symbolToSortTextMap,
-      hasUnresolvedAutoImports
-    } = completionData;
-    let literals = completionData.literals;
-    const checker = program.getTypeChecker();
-    if (getLanguageVariant(sourceFile.scriptKind) === 1 /* JSX */) {
-      const completionInfo = getJsxClosingTagCompletion(location, sourceFile);
-      if (completionInfo) {
-        return completionInfo;
+  function getCompletionEntriesFromTypings(host, options, scriptPath, fragmentDirectory, extensionOptions, result = createNameAndKindSet()) {
+    const seen = /* @__PURE__ */ new Map();
+    const typeRoots = tryAndIgnoreErrors(() => getEffectiveTypeRoots(options, host)) || emptyArray;
+    for (const root of typeRoots) {
+      getCompletionEntriesFromDirectories(root);
+    }
+    if (getPnpApi(scriptPath)) {
+      for (const root of getPnpTypeRoots(scriptPath)) {
+        getCompletionEntriesFromDirectories(root);
+      }
+    } else {
+      for (const packageJson of findPackageJsons(scriptPath, host)) {
+        const typesDir = combinePaths(getDirectoryPath(packageJson), "node_modules/@types");
+        getCompletionEntriesFromDirectories(typesDir);
       }
     }
-    const caseClause = findAncestor(contextToken, isCaseClause);
-    if (caseClause && (isCaseKeyword(contextToken) || isNodeDescendantOf(contextToken, caseClause.expression))) {
-      const tracker = newCaseClauseTracker(checker, caseClause.parent.clauses);
-      literals = literals.filter((literal) => !tracker.hasValue(literal));
-      symbols.forEach((symbol, i) => {
-        if (symbol.valueDeclaration && isEnumMember(symbol.valueDeclaration)) {
-          const value = checker.getConstantValue(symbol.valueDeclaration);
-          if (value !== void 0 && tracker.hasValue(value)) {
-            symbolToOriginInfoMap[i] = { kind: 256 /* Ignore */ };
+    return result;
+    function getCompletionEntriesFromDirectories(directory) {
+      if (!tryDirectoryExists(host, directory))
+        return;
+      for (const typeDirectoryName of tryGetDirectories(host, directory)) {
+        const packageName = unmangleScopedPackageName(typeDirectoryName);
+        if (options.types && !contains(options.types, packageName))
+          continue;
+        if (fragmentDirectory === void 0) {
+          if (!seen.has(packageName)) {
+            result.add(nameAndKind(
+              packageName,
+              "external module name" /* externalModuleName */,
+              /*extension*/
+              void 0
+            ));
+            seen.set(packageName, true);
+          }
+        } else {
+          const baseDirectory = combinePaths(directory, typeDirectoryName);
+          const remainingFragment = tryRemoveDirectoryPrefix(fragmentDirectory, packageName, hostGetCanonicalFileName(host));
+          if (remainingFragment !== void 0) {
+            getCompletionEntriesForDirectoryFragment(
+              remainingFragment,
+              baseDirectory,
+              extensionOptions,
+              host,
+              /*moduleSpecifierIsRelative*/
+              false,
+              /*exclude*/
+              void 0,
+              result
+            );
           }
         }
-      });
-    }
-    const entries = createSortedArray();
-    const isChecked = isCheckedFile(sourceFile, compilerOptions);
-    if (isChecked && !isNewIdentifierLocation && (!symbols || symbols.length === 0) && keywordFilters === 0 /* None */) {
-      return void 0;
+      }
     }
-    const uniqueNames = getCompletionEntriesFromSymbols(
-      symbols,
-      entries,
-      /*replacementToken*/
-      void 0,
-      contextToken,
-      location,
-      position,
-      sourceFile,
-      host,
-      program,
-      getEmitScriptTarget(compilerOptions),
-      log,
-      completionKind,
-      preferences,
-      compilerOptions,
-      formatContext,
-      isTypeOnlyLocation,
-      propertyAccessToConvert,
-      isJsxIdentifierExpected,
-      isJsxInitializer,
-      importStatementCompletion,
-      recommendedCompletion,
-      symbolToOriginInfoMap,
-      symbolToSortTextMap,
-      isJsxIdentifierExpected,
-      isRightOfOpenTag,
-      includeSymbol
-    );
-    if (keywordFilters !== 0 /* None */) {
-      for (const keywordEntry of getKeywordCompletions(keywordFilters, !insideJsDocTagTypeExpression && isSourceFileJS(sourceFile))) {
-        if (isTypeOnlyLocation && isTypeKeyword(stringToToken(keywordEntry.name)) || !uniqueNames.has(keywordEntry.name)) {
-          uniqueNames.add(keywordEntry.name);
-          insertSorted(
-            entries,
-            keywordEntry,
-            compareCompletionEntries,
-            /*allowDuplicates*/
-            true
-          );
+  }
+  function enumerateNodeModulesVisibleToScript(host, scriptPath) {
+    if (!host.readFile || !host.fileExists)
+      return emptyArray;
+    const result = [];
+    for (const packageJson of findPackageJsons(scriptPath, host)) {
+      const contents = readJson(packageJson, host);
+      for (const key of nodeModulesDependencyKeys) {
+        const dependencies = contents[key];
+        if (!dependencies)
+          continue;
+        for (const dep in dependencies) {
+          if (hasProperty(dependencies, dep) && !startsWith(dep, "@types/")) {
+            result.push(dep);
+          }
         }
       }
     }
-    for (const keywordEntry of getContextualKeywords(contextToken, position)) {
-      if (!uniqueNames.has(keywordEntry.name)) {
-        uniqueNames.add(keywordEntry.name);
-        insertSorted(
-          entries,
-          keywordEntry,
-          compareCompletionEntries,
-          /*allowDuplicates*/
-          true
-        );
-      }
+    return result;
+  }
+  function getDirectoryFragmentTextSpan(text, textStart) {
+    const index = Math.max(text.lastIndexOf(directorySeparator), text.lastIndexOf(altDirectorySeparator));
+    const offset = index !== -1 ? index + 1 : 0;
+    const length2 = text.length - offset;
+    return length2 === 0 || isIdentifierText(text.substr(offset, length2), 99 /* ESNext */) ? void 0 : createTextSpan(textStart + offset, length2);
+  }
+  function isPathRelativeToScript(path) {
+    if (path && path.length >= 2 && path.charCodeAt(0) === 46 /* dot */) {
+      const slashIndex = path.length >= 3 && path.charCodeAt(1) === 46 /* dot */ ? 2 : 1;
+      const slashCharCode = path.charCodeAt(slashIndex);
+      return slashCharCode === 47 /* slash */ || slashCharCode === 92 /* backslash */;
     }
-    for (const literal of literals) {
-      const literalEntry = createCompletionEntryForLiteral(sourceFile, preferences, literal);
-      uniqueNames.add(literalEntry.name);
-      insertSorted(
-        entries,
-        literalEntry,
-        compareCompletionEntries,
-        /*allowDuplicates*/
-        true
-      );
+    return false;
+  }
+  function containsSlash(fragment) {
+    return fragment.includes(directorySeparator);
+  }
+  function isRequireCallArgument(node) {
+    return isCallExpression(node.parent) && firstOrUndefined(node.parent.arguments) === node && isIdentifier(node.parent.expression) && node.parent.expression.escapedText === "require";
+  }
+  var kindPrecedence, tripleSlashDirectiveFragmentRegex, nodeModulesDependencyKeys;
+  var init_stringCompletions = __esm({
+    "src/services/stringCompletions.ts"() {
+      "use strict";
+      init_pnp();
+      init_ts4();
+      init_ts_Completions();
+      kindPrecedence = {
+        ["directory" /* directory */]: 0,
+        ["script" /* scriptElement */]: 1,
+        ["external module name" /* externalModuleName */]: 2
+      };
+      tripleSlashDirectiveFragmentRegex = /^(\/\/\/\s* getStringLiteralCompletionDetails,
+    getStringLiteralCompletions: () => getStringLiteralCompletions
+  });
+  var init_ts_Completions_StringCompletions = __esm({
+    "src/services/_namespaces/ts.Completions.StringCompletions.ts"() {
+      "use strict";
+      init_stringCompletions();
     }
-    let caseBlock;
-    if (preferences.includeCompletionsWithInsertText && contextToken && !isRightOfOpenTag && !isRightOfDotOrQuestionDot && (caseBlock = findAncestor(contextToken, isCaseBlock))) {
-      const cases = getExhaustiveCaseSnippets(caseBlock, sourceFile, preferences, compilerOptions, host, program, formatContext);
-      if (cases) {
-        entries.push(cases.entry);
-      }
+  });
+
+  // src/services/_namespaces/ts.Completions.ts
+  var ts_Completions_exports = {};
+  __export(ts_Completions_exports, {
+    CompletionKind: () => CompletionKind,
+    CompletionSource: () => CompletionSource,
+    SortText: () => SortText,
+    StringCompletions: () => ts_Completions_StringCompletions_exports,
+    SymbolOriginInfoKind: () => SymbolOriginInfoKind,
+    createCompletionDetails: () => createCompletionDetails,
+    createCompletionDetailsForSymbol: () => createCompletionDetailsForSymbol,
+    getCompletionEntriesFromSymbols: () => getCompletionEntriesFromSymbols,
+    getCompletionEntryDetails: () => getCompletionEntryDetails,
+    getCompletionEntrySymbol: () => getCompletionEntrySymbol,
+    getCompletionsAtPosition: () => getCompletionsAtPosition,
+    getPropertiesForObjectExpression: () => getPropertiesForObjectExpression,
+    moduleSpecifierResolutionCacheAttemptLimit: () => moduleSpecifierResolutionCacheAttemptLimit,
+    moduleSpecifierResolutionLimit: () => moduleSpecifierResolutionLimit
+  });
+  var init_ts_Completions = __esm({
+    "src/services/_namespaces/ts.Completions.ts"() {
+      "use strict";
+      init_completions();
+      init_ts_Completions_StringCompletions();
     }
-    return {
-      flags: completionData.flags,
-      isGlobalCompletion: isInSnippetScope,
-      isIncomplete: preferences.allowIncompleteCompletions && hasUnresolvedAutoImports ? true : void 0,
-      isMemberCompletion: isMemberCompletionKind(completionKind),
-      isNewIdentifierLocation,
-      optionalReplacementSpan: getOptionalReplacementSpan(location),
-      entries
+  });
+
+  // src/services/importTracker.ts
+  function createImportTracker(sourceFiles, sourceFilesSet, checker, cancellationToken) {
+    const allDirectImports = getDirectImportsMap(sourceFiles, checker, cancellationToken);
+    return (exportSymbol, exportInfo, isForRename) => {
+      const { directImports, indirectUsers } = getImportersForExport(sourceFiles, sourceFilesSet, allDirectImports, exportInfo, checker, cancellationToken);
+      return { indirectUsers, ...getSearchesFromDirectImports(directImports, exportSymbol, exportInfo.exportKind, checker, isForRename) };
     };
   }
-  function isCheckedFile(sourceFile, compilerOptions) {
-    return !isSourceFileJS(sourceFile) || !!isCheckJsEnabledForFile(sourceFile, compilerOptions);
-  }
-  function getExhaustiveCaseSnippets(caseBlock, sourceFile, preferences, options, host, program, formatContext) {
-    const clauses = caseBlock.clauses;
-    const checker = program.getTypeChecker();
-    const switchType = checker.getTypeAtLocation(caseBlock.parent.expression);
-    if (switchType && switchType.isUnion() && every(switchType.types, (type) => type.isLiteral())) {
-      const tracker = newCaseClauseTracker(checker, clauses);
-      const target = getEmitScriptTarget(options);
-      const quotePreference = getQuotePreference(sourceFile, preferences);
-      const importAdder = ts_codefix_exports.createImportAdder(sourceFile, program, preferences, host);
-      const elements = [];
-      for (const type of switchType.types) {
-        if (type.flags & 1024 /* EnumLiteral */) {
-          Debug.assert(type.symbol, "An enum member type should have a symbol");
-          Debug.assert(type.symbol.parent, "An enum member type should have a parent symbol (the enum symbol)");
-          const enumValue = type.symbol.valueDeclaration && checker.getConstantValue(type.symbol.valueDeclaration);
-          if (enumValue !== void 0) {
-            if (tracker.hasValue(enumValue)) {
-              continue;
-            }
-            tracker.addValue(enumValue);
-          }
-          const typeNode = ts_codefix_exports.typeToAutoImportableTypeNode(checker, importAdder, type, caseBlock, target);
-          if (!typeNode) {
-            return void 0;
+  function getImportersForExport(sourceFiles, sourceFilesSet, allDirectImports, { exportingModuleSymbol, exportKind }, checker, cancellationToken) {
+    const markSeenDirectImport = nodeSeenTracker();
+    const markSeenIndirectUser = nodeSeenTracker();
+    const directImports = [];
+    const isAvailableThroughGlobal = !!exportingModuleSymbol.globalExports;
+    const indirectUserDeclarations = isAvailableThroughGlobal ? void 0 : [];
+    handleDirectImports(exportingModuleSymbol);
+    return { directImports, indirectUsers: getIndirectUsers() };
+    function getIndirectUsers() {
+      if (isAvailableThroughGlobal) {
+        return sourceFiles;
+      }
+      if (exportingModuleSymbol.declarations) {
+        for (const decl of exportingModuleSymbol.declarations) {
+          if (isExternalModuleAugmentation(decl) && sourceFilesSet.has(decl.getSourceFile().fileName)) {
+            addIndirectUser(decl);
           }
-          const expr = typeNodeToExpression(typeNode, target, quotePreference);
-          if (!expr) {
-            return void 0;
+        }
+      }
+      return indirectUserDeclarations.map(getSourceFileOfNode);
+    }
+    function handleDirectImports(exportingModuleSymbol2) {
+      const theseDirectImports = getDirectImports(exportingModuleSymbol2);
+      if (theseDirectImports) {
+        for (const direct of theseDirectImports) {
+          if (!markSeenDirectImport(direct)) {
+            continue;
           }
-          elements.push(expr);
-        } else if (!tracker.hasValue(type.value)) {
-          switch (typeof type.value) {
-            case "object":
-              elements.push(type.value.negative ? factory.createPrefixUnaryExpression(41 /* MinusToken */, factory.createBigIntLiteral({ negative: false, base10Value: type.value.base10Value })) : factory.createBigIntLiteral(type.value));
+          if (cancellationToken)
+            cancellationToken.throwIfCancellationRequested();
+          switch (direct.kind) {
+            case 213 /* CallExpression */:
+              if (isImportCall(direct)) {
+                handleImportCall(direct);
+                break;
+              }
+              if (!isAvailableThroughGlobal) {
+                const parent2 = direct.parent;
+                if (exportKind === 2 /* ExportEquals */ && parent2.kind === 260 /* VariableDeclaration */) {
+                  const { name } = parent2;
+                  if (name.kind === 80 /* Identifier */) {
+                    directImports.push(name);
+                    break;
+                  }
+                }
+              }
               break;
-            case "number":
-              elements.push(type.value < 0 ? factory.createPrefixUnaryExpression(41 /* MinusToken */, factory.createNumericLiteral(-type.value)) : factory.createNumericLiteral(type.value));
+            case 80 /* Identifier */:
               break;
-            case "string":
-              elements.push(factory.createStringLiteral(type.value, quotePreference === 0 /* Single */));
+            case 271 /* ImportEqualsDeclaration */:
+              handleNamespaceImport(
+                direct,
+                direct.name,
+                hasSyntacticModifier(direct, 32 /* Export */),
+                /*alreadyAddedDirect*/
+                false
+              );
+              break;
+            case 272 /* ImportDeclaration */:
+              directImports.push(direct);
+              const namedBindings = direct.importClause && direct.importClause.namedBindings;
+              if (namedBindings && namedBindings.kind === 274 /* NamespaceImport */) {
+                handleNamespaceImport(
+                  direct,
+                  namedBindings.name,
+                  /*isReExport*/
+                  false,
+                  /*alreadyAddedDirect*/
+                  true
+                );
+              } else if (!isAvailableThroughGlobal && isDefaultImport(direct)) {
+                addIndirectUser(getSourceFileLikeForImportDeclaration(direct));
+              }
+              break;
+            case 278 /* ExportDeclaration */:
+              if (!direct.exportClause) {
+                handleDirectImports(getContainingModuleSymbol(direct, checker));
+              } else if (direct.exportClause.kind === 280 /* NamespaceExport */) {
+                addIndirectUser(
+                  getSourceFileLikeForImportDeclaration(direct),
+                  /*addTransitiveDependencies*/
+                  true
+                );
+              } else {
+                directImports.push(direct);
+              }
+              break;
+            case 205 /* ImportType */:
+              if (!isAvailableThroughGlobal && direct.isTypeOf && !direct.qualifier && isExported2(direct)) {
+                addIndirectUser(
+                  direct.getSourceFile(),
+                  /*addTransitiveDependencies*/
+                  true
+                );
+              }
+              directImports.push(direct);
               break;
+            default:
+              Debug.failBadSyntaxKind(direct, "Unexpected import kind.");
           }
         }
       }
-      if (elements.length === 0) {
-        return void 0;
-      }
-      const newClauses = map(elements, (element) => factory.createCaseClause(element, []));
-      const newLineChar = getNewLineOrDefaultFromHost(host, formatContext == null ? void 0 : formatContext.options);
-      const printer = createSnippetPrinter({
-        removeComments: true,
-        module: options.module,
-        target: options.target,
-        newLine: getNewLineKind(newLineChar)
+    }
+    function handleImportCall(importCall) {
+      const top = findAncestor(importCall, isAmbientModuleDeclaration) || importCall.getSourceFile();
+      addIndirectUser(
+        top,
+        /** addTransitiveDependencies */
+        !!isExported2(
+          importCall,
+          /*stopAtAmbientModule*/
+          true
+        )
+      );
+    }
+    function isExported2(node, stopAtAmbientModule = false) {
+      return findAncestor(node, (node2) => {
+        if (stopAtAmbientModule && isAmbientModuleDeclaration(node2))
+          return "quit";
+        return canHaveModifiers(node2) && some(node2.modifiers, isExportModifier);
       });
-      const printNode = formatContext ? (node) => printer.printAndFormatNode(4 /* Unspecified */, node, sourceFile, formatContext) : (node) => printer.printNode(4 /* Unspecified */, node, sourceFile);
-      const insertText = map(newClauses, (clause, i) => {
-        if (preferences.includeCompletionsWithSnippetText) {
-          return `${printNode(clause)}$${i + 1}`;
-        }
-        return `${printNode(clause)}`;
-      }).join(newLineChar);
-      const firstClause = printer.printNode(4 /* Unspecified */, newClauses[0], sourceFile);
-      return {
-        entry: {
-          name: `${firstClause} ...`,
-          kind: "" /* unknown */,
-          sortText: SortText.GlobalsOrKeywords,
-          insertText,
-          hasAction: importAdder.hasFixes() || void 0,
-          source: "SwitchCases/" /* SwitchCases */,
-          isSnippet: preferences.includeCompletionsWithSnippetText ? true : void 0
-        },
-        importAdder
-      };
     }
-    return void 0;
-  }
-  function typeNodeToExpression(typeNode, languageVersion, quotePreference) {
-    switch (typeNode.kind) {
-      case 182 /* TypeReference */:
-        const typeName = typeNode.typeName;
-        return entityNameToExpression(typeName, languageVersion, quotePreference);
-      case 198 /* IndexedAccessType */:
-        const objectExpression = typeNodeToExpression(typeNode.objectType, languageVersion, quotePreference);
-        const indexExpression = typeNodeToExpression(typeNode.indexType, languageVersion, quotePreference);
-        return objectExpression && indexExpression && factory.createElementAccessExpression(objectExpression, indexExpression);
-      case 200 /* LiteralType */:
-        const literal = typeNode.literal;
-        switch (literal.kind) {
-          case 11 /* StringLiteral */:
-            return factory.createStringLiteral(literal.text, quotePreference === 0 /* Single */);
-          case 9 /* NumericLiteral */:
-            return factory.createNumericLiteral(literal.text, literal.numericLiteralFlags);
+    function handleNamespaceImport(importDeclaration, name, isReExport, alreadyAddedDirect) {
+      if (exportKind === 2 /* ExportEquals */) {
+        if (!alreadyAddedDirect)
+          directImports.push(importDeclaration);
+      } else if (!isAvailableThroughGlobal) {
+        const sourceFileLike = getSourceFileLikeForImportDeclaration(importDeclaration);
+        Debug.assert(sourceFileLike.kind === 312 /* SourceFile */ || sourceFileLike.kind === 267 /* ModuleDeclaration */);
+        if (isReExport || findNamespaceReExports(sourceFileLike, name, checker)) {
+          addIndirectUser(
+            sourceFileLike,
+            /*addTransitiveDependencies*/
+            true
+          );
+        } else {
+          addIndirectUser(sourceFileLike);
         }
-        return void 0;
-      case 195 /* ParenthesizedType */:
-        const exp = typeNodeToExpression(typeNode.type, languageVersion, quotePreference);
-        return exp && (isIdentifier(exp) ? exp : factory.createParenthesizedExpression(exp));
-      case 185 /* TypeQuery */:
-        return entityNameToExpression(typeNode.exprName, languageVersion, quotePreference);
-      case 204 /* ImportType */:
-        Debug.fail(`We should not get an import type after calling 'codefix.typeToAutoImportableTypeNode'.`);
+      }
     }
-    return void 0;
-  }
-  function entityNameToExpression(entityName, languageVersion, quotePreference) {
-    if (isIdentifier(entityName)) {
-      return entityName;
+    function addIndirectUser(sourceFileLike, addTransitiveDependencies = false) {
+      Debug.assert(!isAvailableThroughGlobal);
+      const isNew = markSeenIndirectUser(sourceFileLike);
+      if (!isNew)
+        return;
+      indirectUserDeclarations.push(sourceFileLike);
+      if (!addTransitiveDependencies)
+        return;
+      const moduleSymbol = checker.getMergedSymbol(sourceFileLike.symbol);
+      if (!moduleSymbol)
+        return;
+      Debug.assert(!!(moduleSymbol.flags & 1536 /* Module */));
+      const directImports2 = getDirectImports(moduleSymbol);
+      if (directImports2) {
+        for (const directImport of directImports2) {
+          if (!isImportTypeNode(directImport)) {
+            addIndirectUser(
+              getSourceFileLikeForImportDeclaration(directImport),
+              /*addTransitiveDependencies*/
+              true
+            );
+          }
+        }
+      }
     }
-    const unescapedName = unescapeLeadingUnderscores(entityName.right.escapedText);
-    if (canUsePropertyAccess(unescapedName, languageVersion)) {
-      return factory.createPropertyAccessExpression(
-        entityNameToExpression(entityName.left, languageVersion, quotePreference),
-        unescapedName
-      );
-    } else {
-      return factory.createElementAccessExpression(
-        entityNameToExpression(entityName.left, languageVersion, quotePreference),
-        factory.createStringLiteral(unescapedName, quotePreference === 0 /* Single */)
-      );
+    function getDirectImports(moduleSymbol) {
+      return allDirectImports.get(getSymbolId(moduleSymbol).toString());
     }
   }
-  function isMemberCompletionKind(kind) {
-    switch (kind) {
-      case 0 /* ObjectPropertyDeclaration */:
-      case 3 /* MemberLike */:
-      case 2 /* PropertyAccess */:
-        return true;
-      default:
-        return false;
+  function getSearchesFromDirectImports(directImports, exportSymbol, exportKind, checker, isForRename) {
+    const importSearches = [];
+    const singleReferences = [];
+    function addSearch(location, symbol) {
+      importSearches.push([location, symbol]);
     }
-  }
-  function getJsxClosingTagCompletion(location, sourceFile) {
-    const jsxClosingElement = findAncestor(location, (node) => {
-      switch (node.kind) {
-        case 286 /* JsxClosingElement */:
-          return true;
-        case 44 /* SlashToken */:
-        case 32 /* GreaterThanToken */:
-        case 80 /* Identifier */:
-        case 210 /* PropertyAccessExpression */:
-          return false;
-        default:
-          return "quit";
+    if (directImports) {
+      for (const decl of directImports) {
+        handleImport(decl);
       }
-    });
-    if (jsxClosingElement) {
-      const hasClosingAngleBracket = !!findChildOfKind(jsxClosingElement, 32 /* GreaterThanToken */, sourceFile);
-      const tagName = jsxClosingElement.parent.openingElement.tagName;
-      const closingTag = tagName.getText(sourceFile);
-      const fullClosingTag = closingTag + (hasClosingAngleBracket ? "" : ">");
-      const replacementSpan = createTextSpanFromNode(jsxClosingElement.tagName);
-      const entry = {
-        name: fullClosingTag,
-        kind: "class" /* classElement */,
-        kindModifiers: void 0,
-        sortText: SortText.LocationPriority
-      };
-      return { isGlobalCompletion: false, isMemberCompletion: true, isNewIdentifierLocation: false, optionalReplacementSpan: replacementSpan, entries: [entry] };
     }
-    return;
-  }
-  function getJSCompletionEntries(sourceFile, position, uniqueNames, target, entries) {
-    getNameTable(sourceFile).forEach((pos, name) => {
-      if (pos === position) {
+    return { importSearches, singleReferences };
+    function handleImport(decl) {
+      if (decl.kind === 271 /* ImportEqualsDeclaration */) {
+        if (isExternalModuleImportEquals(decl)) {
+          handleNamespaceImportLike(decl.name);
+        }
         return;
       }
-      const realName = unescapeLeadingUnderscores(name);
-      if (!uniqueNames.has(realName) && isIdentifierText(realName, target)) {
-        uniqueNames.add(realName);
-        insertSorted(entries, {
-          name: realName,
-          kind: "warning" /* warning */,
-          kindModifiers: "",
-          sortText: SortText.JavascriptIdentifiers,
-          isFromUncheckedFile: true
-        }, compareCompletionEntries);
+      if (decl.kind === 80 /* Identifier */) {
+        handleNamespaceImportLike(decl);
+        return;
       }
-    });
-  }
-  function completionNameForLiteral(sourceFile, preferences, literal) {
-    return typeof literal === "object" ? pseudoBigIntToString(literal) + "n" : isString(literal) ? quote(sourceFile, preferences, literal) : JSON.stringify(literal);
-  }
-  function createCompletionEntryForLiteral(sourceFile, preferences, literal) {
-    return { name: completionNameForLiteral(sourceFile, preferences, literal), kind: "string" /* string */, kindModifiers: "" /* none */, sortText: SortText.LocationPriority };
-  }
-  function createCompletionEntry(symbol, sortText, replacementToken, contextToken, location, position, sourceFile, host, program, name, needsConvertPropertyAccess, origin, recommendedCompletion, propertyAccessToConvert, isJsxInitializer, importStatementCompletion, useSemicolons, options, preferences, completionKind, formatContext, isJsxIdentifierExpected, isRightOfOpenTag, includeSymbol) {
-    let insertText;
-    let replacementSpan = getReplacementSpanForContextToken(replacementToken);
-    let data;
-    let isSnippet;
-    let source = getSourceFromOrigin(origin);
-    let sourceDisplay;
-    let hasAction;
-    let labelDetails;
-    const typeChecker = program.getTypeChecker();
-    const insertQuestionDot = origin && originIsNullableMember(origin);
-    const useBraces = origin && originIsSymbolMember(origin) || needsConvertPropertyAccess;
-    if (origin && originIsThisType(origin)) {
-      insertText = needsConvertPropertyAccess ? `this${insertQuestionDot ? "?." : ""}[${quotePropertyName(sourceFile, preferences, name)}]` : `this${insertQuestionDot ? "?." : "."}${name}`;
-    } else if ((useBraces || insertQuestionDot) && propertyAccessToConvert) {
-      insertText = useBraces ? needsConvertPropertyAccess ? `[${quotePropertyName(sourceFile, preferences, name)}]` : `[${name}]` : name;
-      if (insertQuestionDot || propertyAccessToConvert.questionDotToken) {
-        insertText = `?.${insertText}`;
+      if (decl.kind === 205 /* ImportType */) {
+        if (decl.qualifier) {
+          const firstIdentifier = getFirstIdentifier(decl.qualifier);
+          if (firstIdentifier.escapedText === symbolName(exportSymbol)) {
+            singleReferences.push(firstIdentifier);
+          }
+        } else if (exportKind === 2 /* ExportEquals */) {
+          singleReferences.push(decl.argument.literal);
+        }
+        return;
       }
-      const dot = findChildOfKind(propertyAccessToConvert, 25 /* DotToken */, sourceFile) || findChildOfKind(propertyAccessToConvert, 29 /* QuestionDotToken */, sourceFile);
-      if (!dot) {
-        return void 0;
+      if (decl.moduleSpecifier.kind !== 11 /* StringLiteral */) {
+        return;
       }
-      const end = startsWith(name, propertyAccessToConvert.name.text) ? propertyAccessToConvert.name.end : dot.end;
-      replacementSpan = createTextSpanFromBounds(dot.getStart(sourceFile), end);
-    }
-    if (isJsxInitializer) {
-      if (insertText === void 0)
-        insertText = name;
-      insertText = `{${insertText}}`;
-      if (typeof isJsxInitializer !== "boolean") {
-        replacementSpan = createTextSpanFromNode(isJsxInitializer, sourceFile);
+      if (decl.kind === 278 /* ExportDeclaration */) {
+        if (decl.exportClause && isNamedExports(decl.exportClause)) {
+          searchForNamedImport(decl.exportClause);
+        }
+        return;
       }
-    }
-    if (origin && originIsPromise(origin) && propertyAccessToConvert) {
-      if (insertText === void 0)
-        insertText = name;
-      const precedingToken = findPrecedingToken(propertyAccessToConvert.pos, sourceFile);
-      let awaitText = "";
-      if (precedingToken && positionIsASICandidate(precedingToken.end, precedingToken.parent, sourceFile)) {
-        awaitText = ";";
+      const { name, namedBindings } = decl.importClause || { name: void 0, namedBindings: void 0 };
+      if (namedBindings) {
+        switch (namedBindings.kind) {
+          case 274 /* NamespaceImport */:
+            handleNamespaceImportLike(namedBindings.name);
+            break;
+          case 275 /* NamedImports */:
+            if (exportKind === 0 /* Named */ || exportKind === 1 /* Default */) {
+              searchForNamedImport(namedBindings);
+            }
+            break;
+          default:
+            Debug.assertNever(namedBindings);
+        }
       }
-      awaitText += `(await ${propertyAccessToConvert.expression.getText()})`;
-      insertText = needsConvertPropertyAccess ? `${awaitText}${insertText}` : `${awaitText}${insertQuestionDot ? "?." : "."}${insertText}`;
-      const isInAwaitExpression = tryCast(propertyAccessToConvert.parent, isAwaitExpression);
-      const wrapNode = isInAwaitExpression ? propertyAccessToConvert.parent : propertyAccessToConvert.expression;
-      replacementSpan = createTextSpanFromBounds(wrapNode.getStart(sourceFile), propertyAccessToConvert.end);
-    }
-    if (originIsResolvedExport(origin)) {
-      sourceDisplay = [textPart(origin.moduleSpecifier)];
-      if (importStatementCompletion) {
-        ({ insertText, replacementSpan } = getInsertTextAndReplacementSpanForImportCompletion(name, importStatementCompletion, origin, useSemicolons, sourceFile, options, preferences));
-        isSnippet = preferences.includeCompletionsWithSnippetText ? true : void 0;
+      if (name && (exportKind === 1 /* Default */ || exportKind === 2 /* ExportEquals */) && (!isForRename || name.escapedText === symbolEscapedNameNoDefault(exportSymbol))) {
+        const defaultImportAlias = checker.getSymbolAtLocation(name);
+        addSearch(name, defaultImportAlias);
       }
     }
-    if ((origin == null ? void 0 : origin.kind) === 64 /* TypeOnlyAlias */) {
-      hasAction = true;
-    }
-    if (preferences.includeCompletionsWithClassMemberSnippets && preferences.includeCompletionsWithInsertText && completionKind === 3 /* MemberLike */ && isClassLikeMemberCompletion(symbol, location, sourceFile)) {
-      let importAdder;
-      ({ insertText, isSnippet, importAdder, replacementSpan } = getEntryForMemberCompletion(host, program, options, preferences, name, symbol, location, position, contextToken, formatContext));
-      sortText = SortText.ClassMemberSnippets;
-      if (importAdder == null ? void 0 : importAdder.hasFixes()) {
-        hasAction = true;
-        source = "ClassMemberSnippet/" /* ClassMemberSnippet */;
+    function handleNamespaceImportLike(importName) {
+      if (exportKind === 2 /* ExportEquals */ && (!isForRename || isNameMatch(importName.escapedText))) {
+        addSearch(importName, checker.getSymbolAtLocation(importName));
       }
     }
-    if (origin && originIsObjectLiteralMethod(origin)) {
-      ({ insertText, isSnippet, labelDetails } = origin);
-      if (!preferences.useLabelDetailsInCompletionEntries) {
-        name = name + labelDetails.detail;
-        labelDetails = void 0;
+    function searchForNamedImport(namedBindings) {
+      if (!namedBindings) {
+        return;
       }
-      source = "ObjectLiteralMethodSnippet/" /* ObjectLiteralMethodSnippet */;
-      sortText = SortText.SortBelow(sortText);
-    }
-    if (isJsxIdentifierExpected && !isRightOfOpenTag && preferences.includeCompletionsWithSnippetText && preferences.jsxAttributeCompletionStyle && preferences.jsxAttributeCompletionStyle !== "none" && !(isJsxAttribute(location.parent) && location.parent.initializer)) {
-      let useBraces2 = preferences.jsxAttributeCompletionStyle === "braces";
-      const type = typeChecker.getTypeOfSymbolAtLocation(symbol, location);
-      if (preferences.jsxAttributeCompletionStyle === "auto" && !(type.flags & 528 /* BooleanLike */) && !(type.flags & 1048576 /* Union */ && find(type.types, (type2) => !!(type2.flags & 528 /* BooleanLike */)))) {
-        if (type.flags & 402653316 /* StringLike */ || type.flags & 1048576 /* Union */ && every(type.types, (type2) => !!(type2.flags & (402653316 /* StringLike */ | 32768 /* Undefined */) || isStringAndEmptyAnonymousObjectIntersection(type2)))) {
-          insertText = `${escapeSnippetText(name)}=${quote(sourceFile, preferences, "$1")}`;
-          isSnippet = true;
+      for (const element of namedBindings.elements) {
+        const { name, propertyName } = element;
+        if (!isNameMatch((propertyName || name).escapedText)) {
+          continue;
+        }
+        if (propertyName) {
+          singleReferences.push(propertyName);
+          if (!isForRename || name.escapedText === exportSymbol.escapedName) {
+            addSearch(name, checker.getSymbolAtLocation(name));
+          }
         } else {
-          useBraces2 = true;
+          const localSymbol = element.kind === 281 /* ExportSpecifier */ && element.propertyName ? checker.getExportSpecifierLocalTargetSymbol(element) : checker.getSymbolAtLocation(name);
+          addSearch(name, localSymbol);
         }
       }
-      if (useBraces2) {
-        insertText = `${escapeSnippetText(name)}={$1}`;
-        isSnippet = true;
-      }
-    }
-    if (insertText !== void 0 && !preferences.includeCompletionsWithInsertText) {
-      return void 0;
     }
-    if (originIsExport(origin) || originIsResolvedExport(origin)) {
-      data = originToCompletionEntryData(origin);
-      hasAction = !importStatementCompletion;
+    function isNameMatch(name) {
+      return name === exportSymbol.escapedName || exportKind !== 0 /* Named */ && name === "default" /* Default */;
     }
-    return {
-      name,
-      kind: ts_SymbolDisplay_exports.getSymbolKind(typeChecker, symbol, location),
-      kindModifiers: ts_SymbolDisplay_exports.getSymbolModifiers(typeChecker, symbol),
-      sortText,
-      source,
-      hasAction: hasAction ? true : void 0,
-      isRecommended: isRecommendedCompletionMatch(symbol, recommendedCompletion, typeChecker) || void 0,
-      insertText,
-      replacementSpan,
-      sourceDisplay,
-      labelDetails,
-      isSnippet,
-      isPackageJsonImport: originIsPackageJsonImport(origin) || void 0,
-      isImportStatementCompletion: !!importStatementCompletion || void 0,
-      data,
-      ...includeSymbol ? { symbol } : void 0
-    };
   }
-  function isClassLikeMemberCompletion(symbol, location, sourceFile) {
-    if (isInJSFile(location)) {
-      return false;
-    }
-    const memberFlags = 106500 /* ClassMember */ & 900095 /* EnumMemberExcludes */;
-    return !!(symbol.flags & memberFlags) && (isClassLike(location) || location.parent && location.parent.parent && isClassElement(location.parent) && location === location.parent.name && location.parent.getLastToken(sourceFile) === location.parent.name && isClassLike(location.parent.parent) || location.parent && isSyntaxList(location) && isClassLike(location.parent));
+  function findNamespaceReExports(sourceFileLike, name, checker) {
+    const namespaceImportSymbol = checker.getSymbolAtLocation(name);
+    return !!forEachPossibleImportOrExportStatement(sourceFileLike, (statement) => {
+      if (!isExportDeclaration(statement))
+        return;
+      const { exportClause, moduleSpecifier } = statement;
+      return !moduleSpecifier && exportClause && isNamedExports(exportClause) && exportClause.elements.some((element) => checker.getExportSpecifierLocalTargetSymbol(element) === namespaceImportSymbol);
+    });
   }
-  function getEntryForMemberCompletion(host, program, options, preferences, name, symbol, location, position, contextToken, formatContext) {
-    const classLikeDeclaration = findAncestor(location, isClassLike);
-    if (!classLikeDeclaration) {
-      return { insertText: name };
-    }
-    let isSnippet;
-    let replacementSpan;
-    let insertText = name;
+  function findModuleReferences(program, sourceFiles, searchModuleSymbol) {
+    var _a;
+    const refs = [];
     const checker = program.getTypeChecker();
-    const sourceFile = location.getSourceFile();
-    const printer = createSnippetPrinter({
-      removeComments: true,
-      module: options.module,
-      target: options.target,
-      omitTrailingSemicolon: false,
-      newLine: getNewLineKind(getNewLineOrDefaultFromHost(host, formatContext == null ? void 0 : formatContext.options))
-    });
-    const importAdder = ts_codefix_exports.createImportAdder(sourceFile, program, preferences, host);
-    let body;
-    if (preferences.includeCompletionsWithSnippetText) {
-      isSnippet = true;
-      const emptyStmt = factory.createEmptyStatement();
-      body = factory.createBlock(
-        [emptyStmt],
-        /*multiLine*/
-        true
-      );
-      setSnippetElement(emptyStmt, { kind: 0 /* TabStop */, order: 0 });
-    } else {
-      body = factory.createBlock(
-        [],
-        /*multiLine*/
-        true
-      );
-    }
-    let modifiers = 0 /* None */;
-    const { modifiers: presentModifiers, span: modifiersSpan } = getPresentModifiers(contextToken, sourceFile, position);
-    const isAbstract = !!(presentModifiers & 256 /* Abstract */);
-    const completionNodes = [];
-    ts_codefix_exports.addNewNodeForMemberSymbol(
-      symbol,
-      classLikeDeclaration,
-      sourceFile,
-      { program, host },
-      preferences,
-      importAdder,
-      // `addNewNodeForMemberSymbol` calls this callback function for each new member node
-      // it adds for the given member symbol.
-      // We store these member nodes in the `completionNodes` array.
-      // Note: there might be:
-      //  - No nodes if `addNewNodeForMemberSymbol` cannot figure out a node for the member;
-      //  - One node;
-      //  - More than one node if the member is overloaded (e.g. a method with overload signatures).
-      (node) => {
-        let requiredModifiers = 0 /* None */;
-        if (isAbstract) {
-          requiredModifiers |= 256 /* Abstract */;
-        }
-        if (isClassElement(node) && checker.getMemberOverrideModifierStatus(classLikeDeclaration, node, symbol) === 1 /* NeedsOverride */) {
-          requiredModifiers |= 16384 /* Override */;
+    for (const referencingFile of sourceFiles) {
+      const searchSourceFile = searchModuleSymbol.valueDeclaration;
+      if ((searchSourceFile == null ? void 0 : searchSourceFile.kind) === 312 /* SourceFile */) {
+        for (const ref of referencingFile.referencedFiles) {
+          if (program.getSourceFileFromReference(referencingFile, ref) === searchSourceFile) {
+            refs.push({ kind: "reference", referencingFile, ref });
+          }
         }
-        if (!completionNodes.length) {
-          modifiers = node.modifierFlagsCache | requiredModifiers | presentModifiers;
+        for (const ref of referencingFile.typeReferenceDirectives) {
+          const referenced = (_a = program.getResolvedTypeReferenceDirectives().get(ref.fileName, ref.resolutionMode || referencingFile.impliedNodeFormat)) == null ? void 0 : _a.resolvedTypeReferenceDirective;
+          if (referenced !== void 0 && referenced.resolvedFileName === searchSourceFile.fileName) {
+            refs.push({ kind: "reference", referencingFile, ref });
+          }
         }
-        node = factory.updateModifiers(node, modifiers);
-        completionNodes.push(node);
-      },
-      body,
-      ts_codefix_exports.PreserveOptionalFlags.Property,
-      isAbstract
-    );
-    if (completionNodes.length) {
-      const format = 1 /* MultiLine */ | 131072 /* NoTrailingNewLine */;
-      replacementSpan = modifiersSpan;
-      if (formatContext) {
-        insertText = printer.printAndFormatSnippetList(
-          format,
-          factory.createNodeArray(completionNodes),
-          sourceFile,
-          formatContext
-        );
-      } else {
-        insertText = printer.printSnippetList(
-          format,
-          factory.createNodeArray(completionNodes),
-          sourceFile
-        );
       }
+      forEachImport(referencingFile, (importDecl, moduleSpecifier) => {
+        const moduleSymbol = checker.getSymbolAtLocation(moduleSpecifier);
+        if (moduleSymbol === searchModuleSymbol) {
+          refs.push(nodeIsSynthesized(importDecl) ? { kind: "implicit", literal: moduleSpecifier, referencingFile } : { kind: "import", literal: moduleSpecifier });
+        }
+      });
     }
-    return { insertText, isSnippet, importAdder, replacementSpan };
+    return refs;
   }
-  function getPresentModifiers(contextToken, sourceFile, position) {
-    if (!contextToken || getLineAndCharacterOfPosition(sourceFile, position).line > getLineAndCharacterOfPosition(sourceFile, contextToken.getEnd()).line) {
-      return { modifiers: 0 /* None */ };
-    }
-    let modifiers = 0 /* None */;
-    let span;
-    let contextMod;
-    if (contextMod = isModifierLike2(contextToken)) {
-      modifiers |= modifierToFlag(contextMod);
-      span = createTextSpanFromNode(contextToken);
-    }
-    if (isPropertyDeclaration(contextToken.parent)) {
-      modifiers |= modifiersToFlags(contextToken.parent.modifiers) & 126975 /* Modifier */;
-      span = createTextSpanFromNode(contextToken.parent);
+  function getDirectImportsMap(sourceFiles, checker, cancellationToken) {
+    const map2 = /* @__PURE__ */ new Map();
+    for (const sourceFile of sourceFiles) {
+      if (cancellationToken)
+        cancellationToken.throwIfCancellationRequested();
+      forEachImport(sourceFile, (importDecl, moduleSpecifier) => {
+        const moduleSymbol = checker.getSymbolAtLocation(moduleSpecifier);
+        if (moduleSymbol) {
+          const id = getSymbolId(moduleSymbol).toString();
+          let imports = map2.get(id);
+          if (!imports) {
+            map2.set(id, imports = []);
+          }
+          imports.push(importDecl);
+        }
+      });
     }
-    return { modifiers, span };
+    return map2;
   }
-  function isModifierLike2(node) {
-    if (isModifier(node)) {
-      return node.kind;
-    }
-    if (isIdentifier(node)) {
-      const originalKeywordKind = identifierToKeywordKind(node);
-      if (originalKeywordKind && isModifierKind(originalKeywordKind)) {
-        return originalKeywordKind;
-      }
-    }
-    return void 0;
+  function forEachPossibleImportOrExportStatement(sourceFileLike, action) {
+    return forEach(sourceFileLike.kind === 312 /* SourceFile */ ? sourceFileLike.statements : sourceFileLike.body.statements, (statement) => (
+      // TODO: GH#18217
+      action(statement) || isAmbientModuleDeclaration(statement) && forEach(statement.body && statement.body.statements, action)
+    ));
   }
-  function getEntryForObjectLiteralMethodCompletion(symbol, name, enclosingDeclaration, program, host, options, preferences, formatContext) {
-    const isSnippet = preferences.includeCompletionsWithSnippetText || void 0;
-    let insertText = name;
-    const sourceFile = enclosingDeclaration.getSourceFile();
-    const method = createObjectLiteralMethod(symbol, enclosingDeclaration, sourceFile, program, host, preferences);
-    if (!method) {
-      return void 0;
-    }
-    const printer = createSnippetPrinter({
-      removeComments: true,
-      module: options.module,
-      target: options.target,
-      omitTrailingSemicolon: false,
-      newLine: getNewLineKind(getNewLineOrDefaultFromHost(host, formatContext == null ? void 0 : formatContext.options))
-    });
-    if (formatContext) {
-      insertText = printer.printAndFormatSnippetList(16 /* CommaDelimited */ | 64 /* AllowTrailingComma */, factory.createNodeArray(
-        [method],
-        /*hasTrailingComma*/
-        true
-      ), sourceFile, formatContext);
+  function forEachImport(sourceFile, action) {
+    if (sourceFile.externalModuleIndicator || sourceFile.imports !== void 0) {
+      for (const i of sourceFile.imports) {
+        action(importFromModuleSpecifier(i), i);
+      }
     } else {
-      insertText = printer.printSnippetList(16 /* CommaDelimited */ | 64 /* AllowTrailingComma */, factory.createNodeArray(
-        [method],
-        /*hasTrailingComma*/
-        true
-      ), sourceFile);
+      forEachPossibleImportOrExportStatement(sourceFile, (statement) => {
+        switch (statement.kind) {
+          case 278 /* ExportDeclaration */:
+          case 272 /* ImportDeclaration */: {
+            const decl = statement;
+            if (decl.moduleSpecifier && isStringLiteral(decl.moduleSpecifier)) {
+              action(decl, decl.moduleSpecifier);
+            }
+            break;
+          }
+          case 271 /* ImportEqualsDeclaration */: {
+            const decl = statement;
+            if (isExternalModuleImportEquals(decl)) {
+              action(decl, decl.moduleReference.expression);
+            }
+            break;
+          }
+        }
+      });
     }
-    const signaturePrinter = createPrinter({
-      removeComments: true,
-      module: options.module,
-      target: options.target,
-      omitTrailingSemicolon: true
-    });
-    const methodSignature = factory.createMethodSignature(
-      /*modifiers*/
-      void 0,
-      /*name*/
-      "",
-      method.questionToken,
-      method.typeParameters,
-      method.parameters,
-      method.type
-    );
-    const labelDetails = { detail: signaturePrinter.printNode(4 /* Unspecified */, methodSignature, sourceFile) };
-    return { isSnippet, insertText, labelDetails };
   }
-  function createObjectLiteralMethod(symbol, enclosingDeclaration, sourceFile, program, host, preferences) {
-    const declarations = symbol.getDeclarations();
-    if (!(declarations && declarations.length)) {
-      return void 0;
-    }
-    const checker = program.getTypeChecker();
-    const declaration = declarations[0];
-    const name = getSynthesizedDeepClone(
-      getNameOfDeclaration(declaration),
-      /*includeTrivia*/
-      false
-    );
-    const type = checker.getWidenedType(checker.getTypeOfSymbolAtLocation(symbol, enclosingDeclaration));
-    const quotePreference = getQuotePreference(sourceFile, preferences);
-    const builderFlags = 33554432 /* OmitThisParameter */ | (quotePreference === 0 /* Single */ ? 268435456 /* UseSingleQuotesForStringLiteralType */ : 0 /* None */);
-    switch (declaration.kind) {
-      case 170 /* PropertySignature */:
-      case 171 /* PropertyDeclaration */:
-      case 172 /* MethodSignature */:
-      case 173 /* MethodDeclaration */: {
-        let effectiveType = type.flags & 1048576 /* Union */ && type.types.length < 10 ? checker.getUnionType(type.types, 2 /* Subtype */) : type;
-        if (effectiveType.flags & 1048576 /* Union */) {
-          const functionTypes = filter(effectiveType.types, (type2) => checker.getSignaturesOfType(type2, 0 /* Call */).length > 0);
-          if (functionTypes.length === 1) {
-            effectiveType = functionTypes[0];
+  function getImportOrExportSymbol(node, symbol, checker, comingFromExport) {
+    return comingFromExport ? getExport() : getExport() || getImport();
+    function getExport() {
+      var _a;
+      const { parent: parent2 } = node;
+      const grandparent = parent2.parent;
+      if (symbol.exportSymbol) {
+        if (parent2.kind === 211 /* PropertyAccessExpression */) {
+          return ((_a = symbol.declarations) == null ? void 0 : _a.some((d) => d === parent2)) && isBinaryExpression(grandparent) ? getSpecialPropertyExport(
+            grandparent,
+            /*useLhsSymbol*/
+            false
+          ) : void 0;
+        } else {
+          return exportInfo(symbol.exportSymbol, getExportKindForDeclaration(parent2));
+        }
+      } else {
+        const exportNode = getExportNode(parent2, node);
+        if (exportNode && hasSyntacticModifier(exportNode, 32 /* Export */)) {
+          if (isImportEqualsDeclaration(exportNode) && exportNode.moduleReference === node) {
+            if (comingFromExport) {
+              return void 0;
+            }
+            const lhsSymbol = checker.getSymbolAtLocation(exportNode.name);
+            return { kind: 0 /* Import */, symbol: lhsSymbol };
           } else {
-            return void 0;
+            return exportInfo(symbol, getExportKindForDeclaration(exportNode));
           }
-        }
-        const signatures = checker.getSignaturesOfType(effectiveType, 0 /* Call */);
-        if (signatures.length !== 1) {
-          return void 0;
-        }
-        const typeNode = checker.typeToTypeNode(effectiveType, enclosingDeclaration, builderFlags, ts_codefix_exports.getNoopSymbolTrackerWithResolver({ program, host }));
-        if (!typeNode || !isFunctionTypeNode(typeNode)) {
-          return void 0;
-        }
-        let body;
-        if (preferences.includeCompletionsWithSnippetText) {
-          const emptyStmt = factory.createEmptyStatement();
-          body = factory.createBlock(
-            [emptyStmt],
-            /*multiLine*/
+        } else if (isNamespaceExport(parent2)) {
+          return exportInfo(symbol, 0 /* Named */);
+        } else if (isExportAssignment(parent2)) {
+          return getExportAssignmentExport(parent2);
+        } else if (isExportAssignment(grandparent)) {
+          return getExportAssignmentExport(grandparent);
+        } else if (isBinaryExpression(parent2)) {
+          return getSpecialPropertyExport(
+            parent2,
+            /*useLhsSymbol*/
             true
           );
-          setSnippetElement(emptyStmt, { kind: 0 /* TabStop */, order: 0 });
-        } else {
-          body = factory.createBlock(
-            [],
-            /*multiLine*/
+        } else if (isBinaryExpression(grandparent)) {
+          return getSpecialPropertyExport(
+            grandparent,
+            /*useLhsSymbol*/
             true
           );
+        } else if (isJSDocTypedefTag(parent2) || isJSDocCallbackTag(parent2)) {
+          return exportInfo(symbol, 0 /* Named */);
         }
-        const parameters = typeNode.parameters.map((typedParam) => factory.createParameterDeclaration(
-          /*modifiers*/
-          void 0,
-          typedParam.dotDotDotToken,
-          typedParam.name,
-          /*questionToken*/
-          void 0,
-          /*type*/
-          void 0,
-          typedParam.initializer
-        ));
-        return factory.createMethodDeclaration(
-          /*modifiers*/
-          void 0,
-          /*asteriskToken*/
-          void 0,
-          name,
-          /*questionToken*/
-          void 0,
-          /*typeParameters*/
-          void 0,
-          parameters,
-          /*type*/
-          void 0,
-          body
-        );
       }
-      default:
-        return void 0;
-    }
-  }
-  function createSnippetPrinter(printerOptions) {
-    let escapes;
-    const baseWriter = ts_textChanges_exports.createWriter(getNewLineCharacter(printerOptions));
-    const printer = createPrinter(printerOptions, baseWriter);
-    const writer = {
-      ...baseWriter,
-      write: (s) => escapingWrite(s, () => baseWriter.write(s)),
-      nonEscapingWrite: baseWriter.write,
-      writeLiteral: (s) => escapingWrite(s, () => baseWriter.writeLiteral(s)),
-      writeStringLiteral: (s) => escapingWrite(s, () => baseWriter.writeStringLiteral(s)),
-      writeSymbol: (s, symbol) => escapingWrite(s, () => baseWriter.writeSymbol(s, symbol)),
-      writeParameter: (s) => escapingWrite(s, () => baseWriter.writeParameter(s)),
-      writeComment: (s) => escapingWrite(s, () => baseWriter.writeComment(s)),
-      writeProperty: (s) => escapingWrite(s, () => baseWriter.writeProperty(s))
-    };
-    return {
-      printSnippetList,
-      printAndFormatSnippetList,
-      printNode,
-      printAndFormatNode
-    };
-    function escapingWrite(s, write) {
-      const escaped = escapeSnippetText(s);
-      if (escaped !== s) {
-        const start = baseWriter.getTextPos();
-        write();
-        const end = baseWriter.getTextPos();
-        escapes = append(escapes || (escapes = []), { newText: escaped, span: { start, length: end - start } });
-      } else {
-        write();
+      function getExportAssignmentExport(ex) {
+        if (!ex.symbol.parent)
+          return void 0;
+        const exportKind = ex.isExportEquals ? 2 /* ExportEquals */ : 1 /* Default */;
+        return { kind: 1 /* Export */, symbol, exportInfo: { exportingModuleSymbol: ex.symbol.parent, exportKind } };
       }
-    }
-    function printSnippetList(format, list, sourceFile) {
-      const unescaped = printUnescapedSnippetList(format, list, sourceFile);
-      return escapes ? ts_textChanges_exports.applyChanges(unescaped, escapes) : unescaped;
-    }
-    function printUnescapedSnippetList(format, list, sourceFile) {
-      escapes = void 0;
-      writer.clear();
-      printer.writeList(format, list, sourceFile, writer);
-      return writer.getText();
-    }
-    function printAndFormatSnippetList(format, list, sourceFile, formatContext) {
-      const syntheticFile = {
-        text: printUnescapedSnippetList(
-          format,
-          list,
-          sourceFile
-        ),
-        getLineAndCharacterOfPosition(pos) {
-          return getLineAndCharacterOfPosition(this, pos);
+      function getSpecialPropertyExport(node2, useLhsSymbol) {
+        let kind;
+        switch (getAssignmentDeclarationKind(node2)) {
+          case 1 /* ExportsProperty */:
+            kind = 0 /* Named */;
+            break;
+          case 2 /* ModuleExports */:
+            kind = 2 /* ExportEquals */;
+            break;
+          default:
+            return void 0;
         }
-      };
-      const formatOptions = getFormatCodeSettingsForWriting(formatContext, sourceFile);
-      const changes = flatMap(list, (node) => {
-        const nodeWithPos = ts_textChanges_exports.assignPositionsToNode(node);
-        return ts_formatting_exports.formatNodeGivenIndentation(
-          nodeWithPos,
-          syntheticFile,
-          sourceFile.languageVariant,
-          /* indentation */
-          0,
-          /* delta */
-          0,
-          { ...formatContext, options: formatOptions }
-        );
-      });
-      const allChanges = escapes ? stableSort(concatenate(changes, escapes), (a, b) => compareTextSpans(a.span, b.span)) : changes;
-      return ts_textChanges_exports.applyChanges(syntheticFile.text, allChanges);
+        const sym = useLhsSymbol ? checker.getSymbolAtLocation(getNameOfAccessExpression(cast(node2.left, isAccessExpression))) : symbol;
+        return sym && exportInfo(sym, kind);
+      }
     }
-    function printNode(hint, node, sourceFile) {
-      const unescaped = printUnescapedNode(hint, node, sourceFile);
-      return escapes ? ts_textChanges_exports.applyChanges(unescaped, escapes) : unescaped;
+    function getImport() {
+      const isImport3 = isNodeImport(node);
+      if (!isImport3)
+        return void 0;
+      let importedSymbol = checker.getImmediateAliasedSymbol(symbol);
+      if (!importedSymbol)
+        return void 0;
+      importedSymbol = skipExportSpecifierSymbol(importedSymbol, checker);
+      if (importedSymbol.escapedName === "export=") {
+        importedSymbol = getExportEqualsLocalSymbol(importedSymbol, checker);
+        if (importedSymbol === void 0)
+          return void 0;
+      }
+      const importedName = symbolEscapedNameNoDefault(importedSymbol);
+      if (importedName === void 0 || importedName === "default" /* Default */ || importedName === symbol.escapedName) {
+        return { kind: 0 /* Import */, symbol: importedSymbol };
+      }
     }
-    function printUnescapedNode(hint, node, sourceFile) {
-      escapes = void 0;
-      writer.clear();
-      printer.writeNode(hint, node, sourceFile, writer);
-      return writer.getText();
+    function exportInfo(symbol2, kind) {
+      const exportInfo2 = getExportInfo(symbol2, kind, checker);
+      return exportInfo2 && { kind: 1 /* Export */, symbol: symbol2, exportInfo: exportInfo2 };
     }
-    function printAndFormatNode(hint, node, sourceFile, formatContext) {
-      const syntheticFile = {
-        text: printUnescapedNode(
-          hint,
-          node,
-          sourceFile
-        ),
-        getLineAndCharacterOfPosition(pos) {
-          return getLineAndCharacterOfPosition(this, pos);
-        }
-      };
-      const formatOptions = getFormatCodeSettingsForWriting(formatContext, sourceFile);
-      const nodeWithPos = ts_textChanges_exports.assignPositionsToNode(node);
-      const changes = ts_formatting_exports.formatNodeGivenIndentation(
-        nodeWithPos,
-        syntheticFile,
-        sourceFile.languageVariant,
-        /* indentation */
-        0,
-        /* delta */
-        0,
-        { ...formatContext, options: formatOptions }
-      );
-      const allChanges = escapes ? stableSort(concatenate(changes, escapes), (a, b) => compareTextSpans(a.span, b.span)) : changes;
-      return ts_textChanges_exports.applyChanges(syntheticFile.text, allChanges);
+    function getExportKindForDeclaration(node2) {
+      return hasSyntacticModifier(node2, 2048 /* Default */) ? 1 /* Default */ : 0 /* Named */;
     }
   }
-  function originToCompletionEntryData(origin) {
-    const ambientModuleName = origin.fileName ? void 0 : stripQuotes(origin.moduleSymbol.name);
-    const isPackageJsonImport = origin.isFromPackageJson ? true : void 0;
-    if (originIsResolvedExport(origin)) {
-      const resolvedData = {
-        exportName: origin.exportName,
-        exportMapKey: origin.exportMapKey,
-        moduleSpecifier: origin.moduleSpecifier,
-        ambientModuleName,
-        fileName: origin.fileName,
-        isPackageJsonImport
-      };
-      return resolvedData;
+  function getExportEqualsLocalSymbol(importedSymbol, checker) {
+    var _a, _b;
+    if (importedSymbol.flags & 2097152 /* Alias */) {
+      return checker.getImmediateAliasedSymbol(importedSymbol);
     }
-    const unresolvedData = {
-      exportName: origin.exportName,
-      exportMapKey: origin.exportMapKey,
-      fileName: origin.fileName,
-      ambientModuleName: origin.fileName ? void 0 : stripQuotes(origin.moduleSymbol.name),
-      isPackageJsonImport: origin.isFromPackageJson ? true : void 0
-    };
-    return unresolvedData;
-  }
-  function completionEntryDataToSymbolOriginInfo(data, completionName, moduleSymbol) {
-    const isDefaultExport = data.exportName === "default" /* Default */;
-    const isFromPackageJson = !!data.isPackageJsonImport;
-    if (completionEntryDataIsResolved(data)) {
-      const resolvedOrigin = {
-        kind: 32 /* ResolvedExport */,
-        exportName: data.exportName,
-        exportMapKey: data.exportMapKey,
-        moduleSpecifier: data.moduleSpecifier,
-        symbolName: completionName,
-        fileName: data.fileName,
-        moduleSymbol,
-        isDefaultExport,
-        isFromPackageJson
-      };
-      return resolvedOrigin;
+    const decl = Debug.checkDefined(importedSymbol.valueDeclaration);
+    if (isExportAssignment(decl)) {
+      return (_a = tryCast(decl.expression, canHaveSymbol)) == null ? void 0 : _a.symbol;
+    } else if (isBinaryExpression(decl)) {
+      return (_b = tryCast(decl.right, canHaveSymbol)) == null ? void 0 : _b.symbol;
+    } else if (isSourceFile(decl)) {
+      return decl.symbol;
     }
-    const unresolvedOrigin = {
-      kind: 4 /* Export */,
-      exportName: data.exportName,
-      exportMapKey: data.exportMapKey,
-      symbolName: completionName,
-      fileName: data.fileName,
-      moduleSymbol,
-      isDefaultExport,
-      isFromPackageJson
-    };
-    return unresolvedOrigin;
+    return void 0;
   }
-  function getInsertTextAndReplacementSpanForImportCompletion(name, importStatementCompletion, origin, useSemicolons, sourceFile, options, preferences) {
-    const replacementSpan = importStatementCompletion.replacementSpan;
-    const quotedModuleSpecifier = escapeSnippetText(quote(sourceFile, preferences, origin.moduleSpecifier));
-    const exportKind = origin.isDefaultExport ? 1 /* Default */ : origin.exportName === "export=" /* ExportEquals */ ? 2 /* ExportEquals */ : 0 /* Named */;
-    const tabStop = preferences.includeCompletionsWithSnippetText ? "$1" : "";
-    const importKind = ts_codefix_exports.getImportKind(
-      sourceFile,
-      exportKind,
-      options,
-      /*forceImportKeyword*/
-      true
-    );
-    const isImportSpecifierTypeOnly = importStatementCompletion.couldBeTypeOnlyImportSpecifier;
-    const topLevelTypeOnlyText = importStatementCompletion.isTopLevelTypeOnly ? ` ${tokenToString(156 /* TypeKeyword */)} ` : " ";
-    const importSpecifierTypeOnlyText = isImportSpecifierTypeOnly ? `${tokenToString(156 /* TypeKeyword */)} ` : "";
-    const suffix = useSemicolons ? ";" : "";
-    switch (importKind) {
-      case 3 /* CommonJS */:
-        return { replacementSpan, insertText: `import${topLevelTypeOnlyText}${escapeSnippetText(name)}${tabStop} = require(${quotedModuleSpecifier})${suffix}` };
-      case 1 /* Default */:
-        return { replacementSpan, insertText: `import${topLevelTypeOnlyText}${escapeSnippetText(name)}${tabStop} from ${quotedModuleSpecifier}${suffix}` };
-      case 2 /* Namespace */:
-        return { replacementSpan, insertText: `import${topLevelTypeOnlyText}* as ${escapeSnippetText(name)} from ${quotedModuleSpecifier}${suffix}` };
-      case 0 /* Named */:
-        return { replacementSpan, insertText: `import${topLevelTypeOnlyText}{ ${importSpecifierTypeOnlyText}${escapeSnippetText(name)}${tabStop} } from ${quotedModuleSpecifier}${suffix}` };
+  function getExportNode(parent2, node) {
+    const declaration = isVariableDeclaration(parent2) ? parent2 : isBindingElement(parent2) ? walkUpBindingElementsAndPatterns(parent2) : void 0;
+    if (declaration) {
+      return parent2.name !== node ? void 0 : isCatchClause(declaration.parent) ? void 0 : isVariableStatement(declaration.parent.parent) ? declaration.parent.parent : void 0;
+    } else {
+      return parent2;
     }
   }
-  function quotePropertyName(sourceFile, preferences, name) {
-    if (/^\d+$/.test(name)) {
-      return name;
+  function isNodeImport(node) {
+    const { parent: parent2 } = node;
+    switch (parent2.kind) {
+      case 271 /* ImportEqualsDeclaration */:
+        return parent2.name === node && isExternalModuleImportEquals(parent2);
+      case 276 /* ImportSpecifier */:
+        return !parent2.propertyName;
+      case 273 /* ImportClause */:
+      case 274 /* NamespaceImport */:
+        Debug.assert(parent2.name === node);
+        return true;
+      case 208 /* BindingElement */:
+        return isInJSFile(node) && isVariableDeclarationInitializedToBareOrAccessedRequire(parent2.parent.parent);
+      default:
+        return false;
     }
-    return quote(sourceFile, preferences, name);
   }
-  function isRecommendedCompletionMatch(localSymbol, recommendedCompletion, checker) {
-    return localSymbol === recommendedCompletion || !!(localSymbol.flags & 1048576 /* ExportValue */) && checker.getExportSymbolOfSymbol(localSymbol) === recommendedCompletion;
+  function getExportInfo(exportSymbol, exportKind, checker) {
+    const moduleSymbol = exportSymbol.parent;
+    if (!moduleSymbol)
+      return void 0;
+    const exportingModuleSymbol = checker.getMergedSymbol(moduleSymbol);
+    return isExternalModuleSymbol(exportingModuleSymbol) ? { exportingModuleSymbol, exportKind } : void 0;
   }
-  function getSourceFromOrigin(origin) {
-    if (originIsExport(origin)) {
-      return stripQuotes(origin.moduleSymbol.name);
-    }
-    if (originIsResolvedExport(origin)) {
-      return origin.moduleSpecifier;
+  function skipExportSpecifierSymbol(symbol, checker) {
+    if (symbol.declarations) {
+      for (const declaration of symbol.declarations) {
+        if (isExportSpecifier(declaration) && !declaration.propertyName && !declaration.parent.parent.moduleSpecifier) {
+          return checker.getExportSpecifierLocalTargetSymbol(declaration) || symbol;
+        } else if (isPropertyAccessExpression(declaration) && isModuleExportsAccessExpression(declaration.expression) && !isPrivateIdentifier(declaration.name)) {
+          return checker.getSymbolAtLocation(declaration);
+        } else if (isShorthandPropertyAssignment(declaration) && isBinaryExpression(declaration.parent.parent) && getAssignmentDeclarationKind(declaration.parent.parent) === 2 /* ModuleExports */) {
+          return checker.getExportSpecifierLocalTargetSymbol(declaration.name);
+        }
+      }
     }
-    if ((origin == null ? void 0 : origin.kind) === 1 /* ThisType */) {
-      return "ThisProperty/" /* ThisProperty */;
+    return symbol;
+  }
+  function getContainingModuleSymbol(importer, checker) {
+    return checker.getMergedSymbol(getSourceFileLikeForImportDeclaration(importer).symbol);
+  }
+  function getSourceFileLikeForImportDeclaration(node) {
+    if (node.kind === 213 /* CallExpression */) {
+      return node.getSourceFile();
     }
-    if ((origin == null ? void 0 : origin.kind) === 64 /* TypeOnlyAlias */) {
-      return "TypeOnlyAlias/" /* TypeOnlyAlias */;
+    const { parent: parent2 } = node;
+    if (parent2.kind === 312 /* SourceFile */) {
+      return parent2;
     }
+    Debug.assert(parent2.kind === 268 /* ModuleBlock */);
+    return cast(parent2.parent, isAmbientModuleDeclaration);
   }
-  function getCompletionEntriesFromSymbols(symbols, entries, replacementToken, contextToken, location, position, sourceFile, host, program, target, log, kind, preferences, compilerOptions, formatContext, isTypeOnlyLocation, propertyAccessToConvert, jsxIdentifierExpected, isJsxInitializer, importStatementCompletion, recommendedCompletion, symbolToOriginInfoMap, symbolToSortTextMap, isJsxIdentifierExpected, isRightOfOpenTag, includeSymbol = false) {
-    const start = timestamp();
-    const variableOrParameterDeclaration = getVariableOrParameterDeclaration(contextToken, location);
-    const useSemicolons = probablyUsesSemicolons(sourceFile);
-    const typeChecker = program.getTypeChecker();
-    const uniques = /* @__PURE__ */ new Map();
-    for (let i = 0; i < symbols.length; i++) {
-      const symbol = symbols[i];
-      const origin = symbolToOriginInfoMap == null ? void 0 : symbolToOriginInfoMap[i];
-      const info = getCompletionEntryDisplayNameForSymbol(symbol, target, origin, kind, !!jsxIdentifierExpected);
-      if (!info || uniques.get(info.name) && (!origin || !originIsObjectLiteralMethod(origin)) || kind === 1 /* Global */ && symbolToSortTextMap && !shouldIncludeSymbol(symbol, symbolToSortTextMap)) {
-        continue;
-      }
-      const { name, needsConvertPropertyAccess } = info;
-      const originalSortText = (symbolToSortTextMap == null ? void 0 : symbolToSortTextMap[getSymbolId(symbol)]) ?? SortText.LocationPriority;
-      const sortText = isDeprecated(symbol, typeChecker) ? SortText.Deprecated(originalSortText) : originalSortText;
-      const entry = createCompletionEntry(
-        symbol,
-        sortText,
-        replacementToken,
-        contextToken,
-        location,
-        position,
-        sourceFile,
-        host,
-        program,
-        name,
-        needsConvertPropertyAccess,
-        origin,
-        recommendedCompletion,
-        propertyAccessToConvert,
-        isJsxInitializer,
-        importStatementCompletion,
-        useSemicolons,
-        compilerOptions,
-        preferences,
-        kind,
-        formatContext,
-        isJsxIdentifierExpected,
-        isRightOfOpenTag,
-        includeSymbol
-      );
-      if (!entry) {
-        continue;
-      }
-      const shouldShadowLaterSymbols = (!origin || originIsTypeOnlyAlias(origin)) && !(symbol.parent === void 0 && !some(symbol.declarations, (d) => d.getSourceFile() === location.getSourceFile()));
-      uniques.set(name, shouldShadowLaterSymbols);
-      insertSorted(
-        entries,
-        entry,
-        compareCompletionEntries,
-        /*allowDuplicates*/
-        true
-      );
+  function isAmbientModuleDeclaration(node) {
+    return node.kind === 267 /* ModuleDeclaration */ && node.name.kind === 11 /* StringLiteral */;
+  }
+  function isExternalModuleImportEquals(eq) {
+    return eq.moduleReference.kind === 283 /* ExternalModuleReference */ && eq.moduleReference.expression.kind === 11 /* StringLiteral */;
+  }
+  var ExportKind2, ImportExport;
+  var init_importTracker = __esm({
+    "src/services/importTracker.ts"() {
+      "use strict";
+      init_ts4();
+      ExportKind2 = /* @__PURE__ */ ((ExportKind3) => {
+        ExportKind3[ExportKind3["Named"] = 0] = "Named";
+        ExportKind3[ExportKind3["Default"] = 1] = "Default";
+        ExportKind3[ExportKind3["ExportEquals"] = 2] = "ExportEquals";
+        return ExportKind3;
+      })(ExportKind2 || {});
+      ImportExport = /* @__PURE__ */ ((ImportExport2) => {
+        ImportExport2[ImportExport2["Import"] = 0] = "Import";
+        ImportExport2[ImportExport2["Export"] = 1] = "Export";
+        return ImportExport2;
+      })(ImportExport || {});
     }
-    log("getCompletionsAtPosition: getCompletionEntriesFromSymbols: " + (timestamp() - start));
+  });
+
+  // src/services/findAllReferences.ts
+  function nodeEntry(node, kind = 1 /* Node */) {
     return {
-      has: (name) => uniques.has(name),
-      add: (name) => uniques.set(name, true)
+      kind,
+      node: node.name || node,
+      context: getContextNodeForNodeEntry(node)
     };
-    function shouldIncludeSymbol(symbol, symbolToSortTextMap2) {
-      var _a;
-      let allFlags = symbol.flags;
-      if (!isSourceFile(location)) {
-        if (isExportAssignment(location.parent)) {
-          return true;
-        }
-        if (tryCast(variableOrParameterDeclaration, isVariableDeclaration) && symbol.valueDeclaration === variableOrParameterDeclaration) {
-          return false;
-        }
-        const symbolDeclaration = symbol.valueDeclaration ?? ((_a = symbol.declarations) == null ? void 0 : _a[0]);
-        if (variableOrParameterDeclaration && symbolDeclaration && (isTypeParameterDeclaration(variableOrParameterDeclaration) && isTypeParameterDeclaration(symbolDeclaration) || isParameter(variableOrParameterDeclaration) && isParameter(symbolDeclaration))) {
-          const symbolDeclarationPos = symbolDeclaration.pos;
-          const parameters = isParameter(variableOrParameterDeclaration) ? variableOrParameterDeclaration.parent.parameters : isInferTypeNode(variableOrParameterDeclaration.parent) ? void 0 : variableOrParameterDeclaration.parent.typeParameters;
-          if (symbolDeclarationPos >= variableOrParameterDeclaration.pos && parameters && symbolDeclarationPos < parameters.end) {
-            return false;
-          }
-        }
-        const symbolOrigin = skipAlias(symbol, typeChecker);
-        if (!!sourceFile.externalModuleIndicator && !compilerOptions.allowUmdGlobalAccess && symbolToSortTextMap2[getSymbolId(symbol)] === SortText.GlobalsOrKeywords && (symbolToSortTextMap2[getSymbolId(symbolOrigin)] === SortText.AutoImportSuggestions || symbolToSortTextMap2[getSymbolId(symbolOrigin)] === SortText.LocationPriority)) {
-          return false;
-        }
-        allFlags |= getCombinedLocalAndExportSymbolFlags(symbolOrigin);
-        if (isInRightSideOfInternalImportEqualsDeclaration(location)) {
-          return !!(allFlags & 1920 /* Namespace */);
+  }
+  function isContextWithStartAndEndNode(node) {
+    return node && node.kind === void 0;
+  }
+  function getContextNodeForNodeEntry(node) {
+    if (isDeclaration(node)) {
+      return getContextNode(node);
+    }
+    if (!node.parent)
+      return void 0;
+    if (!isDeclaration(node.parent) && !isExportAssignment(node.parent)) {
+      if (isInJSFile(node)) {
+        const binaryExpression = isBinaryExpression(node.parent) ? node.parent : isAccessExpression(node.parent) && isBinaryExpression(node.parent.parent) && node.parent.parent.left === node.parent ? node.parent.parent : void 0;
+        if (binaryExpression && getAssignmentDeclarationKind(binaryExpression) !== 0 /* None */) {
+          return getContextNode(binaryExpression);
         }
-        if (isTypeOnlyLocation) {
-          return symbolCanBeReferencedAtTypeLocation(symbol, typeChecker);
+      }
+      if (isJsxOpeningElement(node.parent) || isJsxClosingElement(node.parent)) {
+        return node.parent.parent;
+      } else if (isJsxSelfClosingElement(node.parent) || isLabeledStatement(node.parent) || isBreakOrContinueStatement(node.parent)) {
+        return node.parent;
+      } else if (isStringLiteralLike(node)) {
+        const validImport = tryGetImportFromModuleSpecifier(node);
+        if (validImport) {
+          const declOrStatement = findAncestor(validImport, (node2) => isDeclaration(node2) || isStatement(node2) || isJSDocTag(node2));
+          return isDeclaration(declOrStatement) ? getContextNode(declOrStatement) : declOrStatement;
         }
       }
-      return !!(allFlags & 111551 /* Value */);
+      const propertyName = findAncestor(node, isComputedPropertyName);
+      return propertyName ? getContextNode(propertyName.parent) : void 0;
+    }
+    if (node.parent.name === node || // node is name of declaration, use parent
+    isConstructorDeclaration(node.parent) || isExportAssignment(node.parent) || // Property name of the import export specifier or binding pattern, use parent
+    (isImportOrExportSpecifier(node.parent) || isBindingElement(node.parent)) && node.parent.propertyName === node || // Is default export
+    node.kind === 90 /* DefaultKeyword */ && hasSyntacticModifier(node.parent, 2080 /* ExportDefault */)) {
+      return getContextNode(node.parent);
     }
+    return void 0;
   }
-  function getLabelCompletionAtPosition(node) {
-    const entries = getLabelStatementCompletions(node);
-    if (entries.length) {
-      return { isGlobalCompletion: false, isMemberCompletion: false, isNewIdentifierLocation: false, entries };
+  function getContextNode(node) {
+    if (!node)
+      return void 0;
+    switch (node.kind) {
+      case 260 /* VariableDeclaration */:
+        return !isVariableDeclarationList(node.parent) || node.parent.declarations.length !== 1 ? node : isVariableStatement(node.parent.parent) ? node.parent.parent : isForInOrOfStatement(node.parent.parent) ? getContextNode(node.parent.parent) : node.parent;
+      case 208 /* BindingElement */:
+        return getContextNode(node.parent.parent);
+      case 276 /* ImportSpecifier */:
+        return node.parent.parent.parent;
+      case 281 /* ExportSpecifier */:
+      case 274 /* NamespaceImport */:
+        return node.parent.parent;
+      case 273 /* ImportClause */:
+      case 280 /* NamespaceExport */:
+        return node.parent;
+      case 226 /* BinaryExpression */:
+        return isExpressionStatement(node.parent) ? node.parent : node;
+      case 250 /* ForOfStatement */:
+      case 249 /* ForInStatement */:
+        return {
+          start: node.initializer,
+          end: node.expression
+        };
+      case 303 /* PropertyAssignment */:
+      case 304 /* ShorthandPropertyAssignment */:
+        return isArrayLiteralOrObjectLiteralDestructuringPattern(node.parent) ? getContextNode(
+          findAncestor(node.parent, (node2) => isBinaryExpression(node2) || isForInOrOfStatement(node2))
+        ) : node;
+      default:
+        return node;
     }
   }
-  function getLabelStatementCompletions(node) {
-    const entries = [];
-    const uniques = /* @__PURE__ */ new Map();
-    let current = node;
-    while (current) {
-      if (isFunctionLike(current)) {
-        break;
+  function toContextSpan(textSpan, sourceFile, context) {
+    if (!context)
+      return void 0;
+    const contextSpan = isContextWithStartAndEndNode(context) ? getTextSpan(context.start, sourceFile, context.end) : getTextSpan(context, sourceFile);
+    return contextSpan.start !== textSpan.start || contextSpan.length !== textSpan.length ? { contextSpan } : void 0;
+  }
+  function findReferencedSymbols(program, cancellationToken, sourceFiles, sourceFile, position) {
+    const node = getTouchingPropertyName(sourceFile, position);
+    const options = { use: 1 /* References */ };
+    const referencedSymbols = Core.getReferencedSymbolsForNode(position, node, program, sourceFiles, cancellationToken, options);
+    const checker = program.getTypeChecker();
+    const adjustedNode = Core.getAdjustedNode(node, options);
+    const symbol = isDefinitionForReference(adjustedNode) ? checker.getSymbolAtLocation(adjustedNode) : void 0;
+    return !referencedSymbols || !referencedSymbols.length ? void 0 : mapDefined(referencedSymbols, ({ definition, references }) => (
+      // Only include referenced symbols that have a valid definition.
+      definition && {
+        definition: checker.runWithCancellationToken(cancellationToken, (checker2) => definitionToReferencedSymbolDefinitionInfo(definition, checker2, node)),
+        references: references.map((r) => toReferencedSymbolEntry(r, symbol))
       }
-      if (isLabeledStatement(current)) {
-        const name = current.label.text;
-        if (!uniques.has(name)) {
-          uniques.set(name, true);
-          entries.push({
-            name,
-            kindModifiers: "" /* none */,
-            kind: "label" /* label */,
-            sortText: SortText.LocationPriority
-          });
+    ));
+  }
+  function isDefinitionForReference(node) {
+    return node.kind === 90 /* DefaultKeyword */ || !!getDeclarationFromName(node) || isLiteralComputedPropertyDeclarationName(node) || node.kind === 137 /* ConstructorKeyword */ && isConstructorDeclaration(node.parent);
+  }
+  function getImplementationsAtPosition(program, cancellationToken, sourceFiles, sourceFile, position) {
+    const node = getTouchingPropertyName(sourceFile, position);
+    let referenceEntries;
+    const entries = getImplementationReferenceEntries(program, cancellationToken, sourceFiles, node, position);
+    if (node.parent.kind === 211 /* PropertyAccessExpression */ || node.parent.kind === 208 /* BindingElement */ || node.parent.kind === 212 /* ElementAccessExpression */ || node.kind === 108 /* SuperKeyword */) {
+      referenceEntries = entries && [...entries];
+    } else if (entries) {
+      const queue = createQueue(entries);
+      const seenNodes = /* @__PURE__ */ new Map();
+      while (!queue.isEmpty()) {
+        const entry = queue.dequeue();
+        if (!addToSeen(seenNodes, getNodeId(entry.node))) {
+          continue;
+        }
+        referenceEntries = append(referenceEntries, entry);
+        const entries2 = getImplementationReferenceEntries(program, cancellationToken, sourceFiles, entry.node, entry.node.pos);
+        if (entries2) {
+          queue.enqueue(...entries2);
         }
       }
-      current = current.parent;
     }
-    return entries;
+    const checker = program.getTypeChecker();
+    return map(referenceEntries, (entry) => toImplementationLocation(entry, checker));
   }
-  function getSymbolCompletionFromEntryId(program, log, sourceFile, position, entryId, host, preferences) {
-    if (entryId.source === "SwitchCases/" /* SwitchCases */) {
-      return { type: "cases" };
-    }
-    if (entryId.data) {
-      const autoImport = getAutoImportSymbolFromCompletionEntryData(entryId.name, entryId.data, program, host);
-      if (autoImport) {
-        const { contextToken: contextToken2, previousToken: previousToken2 } = getRelevantTokens(position, sourceFile);
-        return {
-          type: "symbol",
-          symbol: autoImport.symbol,
-          location: getTouchingPropertyName(sourceFile, position),
-          previousToken: previousToken2,
-          contextToken: contextToken2,
-          isJsxInitializer: false,
-          isTypeOnlyLocation: false,
-          origin: autoImport.origin
-        };
-      }
-    }
-    const compilerOptions = program.getCompilerOptions();
-    const completionData = getCompletionData(
-      program,
-      log,
-      sourceFile,
-      compilerOptions,
-      position,
-      { includeCompletionsForModuleExports: true, includeCompletionsWithInsertText: true },
-      entryId,
-      host,
-      /*formatContext*/
-      void 0
-    );
-    if (!completionData) {
-      return { type: "none" };
+  function getImplementationReferenceEntries(program, cancellationToken, sourceFiles, node, position) {
+    if (node.kind === 312 /* SourceFile */) {
+      return void 0;
     }
-    if (completionData.kind !== 0 /* Data */) {
-      return { type: "request", request: completionData };
+    const checker = program.getTypeChecker();
+    if (node.parent.kind === 304 /* ShorthandPropertyAssignment */) {
+      const result = [];
+      Core.getReferenceEntriesForShorthandPropertyAssignment(node, checker, (node2) => result.push(nodeEntry(node2)));
+      return result;
+    } else if (node.kind === 108 /* SuperKeyword */ || isSuperProperty(node.parent)) {
+      const symbol = checker.getSymbolAtLocation(node);
+      return symbol.valueDeclaration && [nodeEntry(symbol.valueDeclaration)];
+    } else {
+      return getReferenceEntriesForNode(position, node, program, sourceFiles, cancellationToken, { implementations: true, use: 1 /* References */ });
     }
-    const { symbols, literals, location, completionKind, symbolToOriginInfoMap, contextToken, previousToken, isJsxInitializer, isTypeOnlyLocation } = completionData;
-    const literal = find(literals, (l) => completionNameForLiteral(sourceFile, preferences, l) === entryId.name);
-    if (literal !== void 0)
-      return { type: "literal", literal };
-    return firstDefined(symbols, (symbol, index) => {
-      const origin = symbolToOriginInfoMap[index];
-      const info = getCompletionEntryDisplayNameForSymbol(symbol, getEmitScriptTarget(compilerOptions), origin, completionKind, completionData.isJsxIdentifierExpected);
-      return info && info.name === entryId.name && (entryId.source === "ClassMemberSnippet/" /* ClassMemberSnippet */ && symbol.flags & 106500 /* ClassMember */ || entryId.source === "ObjectLiteralMethodSnippet/" /* ObjectLiteralMethodSnippet */ && symbol.flags & (4 /* Property */ | 8192 /* Method */) || getSourceFromOrigin(origin) === entryId.source) ? { type: "symbol", symbol, location, origin, contextToken, previousToken, isJsxInitializer, isTypeOnlyLocation } : void 0;
-    }) || { type: "none" };
   }
-  function getCompletionEntryDetails(program, log, sourceFile, position, entryId, host, formatContext, preferences, cancellationToken) {
-    const typeChecker = program.getTypeChecker();
-    const compilerOptions = program.getCompilerOptions();
-    const { name, source, data } = entryId;
-    const { previousToken, contextToken } = getRelevantTokens(position, sourceFile);
-    if (isInString(sourceFile, position, previousToken)) {
-      return ts_Completions_StringCompletions_exports.getStringLiteralCompletionDetails(name, sourceFile, position, previousToken, typeChecker, compilerOptions, host, cancellationToken, preferences);
-    }
-    const symbolCompletion = getSymbolCompletionFromEntryId(program, log, sourceFile, position, entryId, host, preferences);
-    switch (symbolCompletion.type) {
-      case "request": {
-        const { request } = symbolCompletion;
-        switch (request.kind) {
-          case 1 /* JsDocTagName */:
-            return ts_JsDoc_exports.getJSDocTagNameCompletionDetails(name);
-          case 2 /* JsDocTag */:
-            return ts_JsDoc_exports.getJSDocTagCompletionDetails(name);
-          case 3 /* JsDocParameterName */:
-            return ts_JsDoc_exports.getJSDocParameterNameCompletionDetails(name);
-          case 4 /* Keywords */:
-            return some(request.keywordCompletions, (c) => c.name === name) ? createSimpleDetails(name, "keyword" /* keyword */, 5 /* keyword */) : void 0;
-          default:
-            return Debug.assertNever(request);
+  function findReferenceOrRenameEntries(program, cancellationToken, sourceFiles, node, position, options, convertEntry) {
+    return map(flattenEntries(Core.getReferencedSymbolsForNode(position, node, program, sourceFiles, cancellationToken, options)), (entry) => convertEntry(entry, node, program.getTypeChecker()));
+  }
+  function getReferenceEntriesForNode(position, node, program, sourceFiles, cancellationToken, options = {}, sourceFilesSet = new Set(sourceFiles.map((f) => f.fileName))) {
+    return flattenEntries(Core.getReferencedSymbolsForNode(position, node, program, sourceFiles, cancellationToken, options, sourceFilesSet));
+  }
+  function flattenEntries(referenceSymbols) {
+    return referenceSymbols && flatMap(referenceSymbols, (r) => r.references);
+  }
+  function definitionToReferencedSymbolDefinitionInfo(def, checker, originalNode) {
+    const info = (() => {
+      switch (def.type) {
+        case 0 /* Symbol */: {
+          const { symbol } = def;
+          const { displayParts: displayParts2, kind: kind2 } = getDefinitionKindAndDisplayParts(symbol, checker, originalNode);
+          const name2 = displayParts2.map((p) => p.text).join("");
+          const declaration = symbol.declarations && firstOrUndefined(symbol.declarations);
+          const node = declaration ? getNameOfDeclaration(declaration) || declaration : originalNode;
+          return {
+            ...getFileAndTextSpanFromNode(node),
+            name: name2,
+            kind: kind2,
+            displayParts: displayParts2,
+            context: getContextNode(declaration)
+          };
         }
-      }
-      case "symbol": {
-        const { symbol, location, contextToken: contextToken2, origin, previousToken: previousToken2 } = symbolCompletion;
-        const { codeActions, sourceDisplay } = getCompletionEntryCodeActionsAndSourceDisplay(name, location, contextToken2, origin, symbol, program, host, compilerOptions, sourceFile, position, previousToken2, formatContext, preferences, data, source, cancellationToken);
-        const symbolName2 = originIsComputedPropertyName(origin) ? origin.symbolName : symbol.name;
-        return createCompletionDetailsForSymbol(symbol, symbolName2, typeChecker, sourceFile, location, cancellationToken, codeActions, sourceDisplay);
-      }
-      case "literal": {
-        const { literal } = symbolCompletion;
-        return createSimpleDetails(completionNameForLiteral(sourceFile, preferences, literal), "string" /* string */, typeof literal === "string" ? 8 /* stringLiteral */ : 7 /* numericLiteral */);
-      }
-      case "cases": {
-        const { entry, importAdder } = getExhaustiveCaseSnippets(
-          contextToken.parent,
-          sourceFile,
-          preferences,
-          program.getCompilerOptions(),
-          host,
-          program,
-          /*formatContext*/
-          void 0
-        );
-        if (importAdder.hasFixes()) {
-          const changes = ts_textChanges_exports.ChangeTracker.with(
-            { host, formatContext, preferences },
-            importAdder.writeFixes
-          );
+        case 1 /* Label */: {
+          const { node } = def;
+          return { ...getFileAndTextSpanFromNode(node), name: node.text, kind: "label" /* label */, displayParts: [displayPart(node.text, 17 /* text */)] };
+        }
+        case 2 /* Keyword */: {
+          const { node } = def;
+          const name2 = tokenToString(node.kind);
+          return { ...getFileAndTextSpanFromNode(node), name: name2, kind: "keyword" /* keyword */, displayParts: [{ text: name2, kind: "keyword" /* keyword */ }] };
+        }
+        case 3 /* This */: {
+          const { node } = def;
+          const symbol = checker.getSymbolAtLocation(node);
+          const displayParts2 = symbol && ts_SymbolDisplay_exports.getSymbolDisplayPartsDocumentationAndSymbolKind(
+            checker,
+            symbol,
+            node.getSourceFile(),
+            getContainerNode(node),
+            node
+          ).displayParts || [textPart("this")];
+          return { ...getFileAndTextSpanFromNode(node), name: "this", kind: "var" /* variableElement */, displayParts: displayParts2 };
+        }
+        case 4 /* String */: {
+          const { node } = def;
           return {
-            name: entry.name,
-            kind: "" /* unknown */,
-            kindModifiers: "",
-            displayParts: [],
-            sourceDisplay: void 0,
-            codeActions: [{
-              changes,
-              description: diagnosticToString([Diagnostics.Includes_imports_of_types_referenced_by_0, name])
-            }]
+            ...getFileAndTextSpanFromNode(node),
+            name: node.text,
+            kind: "var" /* variableElement */,
+            displayParts: [displayPart(getTextOfNode(node), 8 /* stringLiteral */)]
           };
         }
-        return {
-          name: entry.name,
-          kind: "" /* unknown */,
-          kindModifiers: "",
-          displayParts: [],
-          sourceDisplay: void 0
-        };
+        case 5 /* TripleSlashReference */: {
+          return {
+            textSpan: createTextSpanFromRange(def.reference),
+            sourceFile: def.file,
+            name: def.reference.fileName,
+            kind: "string" /* string */,
+            displayParts: [displayPart(`"${def.reference.fileName}"`, 8 /* stringLiteral */)]
+          };
+        }
+        default:
+          return Debug.assertNever(def);
       }
-      case "none":
-        return allKeywordsCompletions().some((c) => c.name === name) ? createSimpleDetails(name, "keyword" /* keyword */, 5 /* keyword */) : void 0;
-      default:
-        Debug.assertNever(symbolCompletion);
-    }
+    })();
+    const { sourceFile, textSpan, name, kind, displayParts, context } = info;
+    return {
+      containerKind: "" /* unknown */,
+      containerName: "",
+      fileName: sourceFile.fileName,
+      kind,
+      name,
+      textSpan,
+      displayParts,
+      ...toContextSpan(textSpan, sourceFile, context)
+    };
   }
-  function createSimpleDetails(name, kind, kind2) {
-    return createCompletionDetails(name, "" /* none */, kind, [displayPart(name, kind2)]);
+  function getFileAndTextSpanFromNode(node) {
+    const sourceFile = node.getSourceFile();
+    return {
+      sourceFile,
+      textSpan: getTextSpan(isComputedPropertyName(node) ? node.expression : node, sourceFile)
+    };
   }
-  function createCompletionDetailsForSymbol(symbol, name, checker, sourceFile, location, cancellationToken, codeActions, sourceDisplay) {
-    const { displayParts, documentation, symbolKind, tags } = checker.runWithCancellationToken(
-      cancellationToken,
-      (checker2) => ts_SymbolDisplay_exports.getSymbolDisplayPartsDocumentationAndSymbolKind(checker2, symbol, sourceFile, location, location, 7 /* All */)
-    );
-    return createCompletionDetails(name, ts_SymbolDisplay_exports.getSymbolModifiers(checker, symbol), symbolKind, displayParts, documentation, tags, codeActions, sourceDisplay);
+  function getDefinitionKindAndDisplayParts(symbol, checker, node) {
+    const meaning = Core.getIntersectingMeaningFromDeclarations(node, symbol);
+    const enclosingDeclaration = symbol.declarations && firstOrUndefined(symbol.declarations) || node;
+    const { displayParts, symbolKind } = ts_SymbolDisplay_exports.getSymbolDisplayPartsDocumentationAndSymbolKind(checker, symbol, enclosingDeclaration.getSourceFile(), enclosingDeclaration, enclosingDeclaration, meaning);
+    return { displayParts, kind: symbolKind };
   }
-  function createCompletionDetails(name, kindModifiers, kind, displayParts, documentation, tags, codeActions, source) {
-    return { name, kindModifiers, kind, displayParts, documentation, tags, codeActions, source, sourceDisplay: source };
+  function toRenameLocation(entry, originalNode, checker, providePrefixAndSuffixText, quotePreference) {
+    return { ...entryToDocumentSpan(entry), ...providePrefixAndSuffixText && getPrefixAndSuffixText(entry, originalNode, checker, quotePreference) };
   }
-  function getCompletionEntryCodeActionsAndSourceDisplay(name, location, contextToken, origin, symbol, program, host, compilerOptions, sourceFile, position, previousToken, formatContext, preferences, data, source, cancellationToken) {
-    if (data == null ? void 0 : data.moduleSpecifier) {
-      if (previousToken && getImportStatementCompletionInfo(contextToken || previousToken).replacementSpan) {
-        return { codeActions: void 0, sourceDisplay: [textPart(data.moduleSpecifier)] };
-      }
+  function toReferencedSymbolEntry(entry, symbol) {
+    const referenceEntry = toReferenceEntry(entry);
+    if (!symbol)
+      return referenceEntry;
+    return {
+      ...referenceEntry,
+      isDefinition: entry.kind !== 0 /* Span */ && isDeclarationOfSymbol(entry.node, symbol)
+    };
+  }
+  function toReferenceEntry(entry) {
+    const documentSpan = entryToDocumentSpan(entry);
+    if (entry.kind === 0 /* Span */) {
+      return { ...documentSpan, isWriteAccess: false };
     }
-    if (source === "ClassMemberSnippet/" /* ClassMemberSnippet */) {
-      const { importAdder } = getEntryForMemberCompletion(
-        host,
-        program,
-        compilerOptions,
-        preferences,
-        name,
-        symbol,
-        location,
-        position,
-        contextToken,
-        formatContext
-      );
-      if (importAdder) {
-        const changes = ts_textChanges_exports.ChangeTracker.with(
-          { host, formatContext, preferences },
-          importAdder.writeFixes
-        );
-        return {
-          sourceDisplay: void 0,
-          codeActions: [{
-            changes,
-            description: diagnosticToString([Diagnostics.Includes_imports_of_types_referenced_by_0, name])
-          }]
-        };
-      }
+    const { kind, node } = entry;
+    return {
+      ...documentSpan,
+      isWriteAccess: isWriteAccessForReference(node),
+      isInString: kind === 2 /* StringLiteral */ ? true : void 0
+    };
+  }
+  function entryToDocumentSpan(entry) {
+    if (entry.kind === 0 /* Span */) {
+      return { textSpan: entry.textSpan, fileName: entry.fileName };
+    } else {
+      const sourceFile = entry.node.getSourceFile();
+      const textSpan = getTextSpan(entry.node, sourceFile);
+      return {
+        textSpan,
+        fileName: sourceFile.fileName,
+        ...toContextSpan(textSpan, sourceFile, entry.context)
+      };
     }
-    if (originIsTypeOnlyAlias(origin)) {
-      const codeAction2 = ts_codefix_exports.getPromoteTypeOnlyCompletionAction(
-        sourceFile,
-        origin.declaration.name,
-        program,
-        host,
-        formatContext,
-        preferences
-      );
-      Debug.assertIsDefined(codeAction2, "Expected to have a code action for promoting type-only alias");
-      return { codeActions: [codeAction2], sourceDisplay: void 0 };
+  }
+  function getPrefixAndSuffixText(entry, originalNode, checker, quotePreference) {
+    if (entry.kind !== 0 /* Span */ && isIdentifier(originalNode)) {
+      const { node, kind } = entry;
+      const parent2 = node.parent;
+      const name = originalNode.text;
+      const isShorthandAssignment = isShorthandPropertyAssignment(parent2);
+      if (isShorthandAssignment || isObjectBindingElementWithoutPropertyName(parent2) && parent2.name === node && parent2.dotDotDotToken === void 0) {
+        const prefixColon = { prefixText: name + ": " };
+        const suffixColon = { suffixText: ": " + name };
+        if (kind === 3 /* SearchedLocalFoundProperty */) {
+          return prefixColon;
+        }
+        if (kind === 4 /* SearchedPropertyFoundLocal */) {
+          return suffixColon;
+        }
+        if (isShorthandAssignment) {
+          const grandParent = parent2.parent;
+          if (isObjectLiteralExpression(grandParent) && isBinaryExpression(grandParent.parent) && isModuleExportsAccessExpression(grandParent.parent.left)) {
+            return prefixColon;
+          }
+          return suffixColon;
+        } else {
+          return prefixColon;
+        }
+      } else if (isImportSpecifier(parent2) && !parent2.propertyName) {
+        const originalSymbol = isExportSpecifier(originalNode.parent) ? checker.getExportSpecifierLocalTargetSymbol(originalNode.parent) : checker.getSymbolAtLocation(originalNode);
+        return contains(originalSymbol.declarations, parent2) ? { prefixText: name + " as " } : emptyOptions;
+      } else if (isExportSpecifier(parent2) && !parent2.propertyName) {
+        return originalNode === entry.node || checker.getSymbolAtLocation(originalNode) === checker.getSymbolAtLocation(entry.node) ? { prefixText: name + " as " } : { suffixText: " as " + name };
+      }
     }
-    if (!origin || !(originIsExport(origin) || originIsResolvedExport(origin))) {
-      return { codeActions: void 0, sourceDisplay: void 0 };
+    if (entry.kind !== 0 /* Span */ && isNumericLiteral(entry.node) && isAccessExpression(entry.node.parent)) {
+      const quote2 = getQuoteFromPreference(quotePreference);
+      return { prefixText: quote2, suffixText: quote2 };
     }
-    const checker = origin.isFromPackageJson ? host.getPackageJsonAutoImportProvider().getTypeChecker() : program.getTypeChecker();
-    const { moduleSymbol } = origin;
-    const targetSymbol = checker.getMergedSymbol(skipAlias(symbol.exportSymbol || symbol, checker));
-    const isJsxOpeningTagName = (contextToken == null ? void 0 : contextToken.kind) === 30 /* LessThanToken */ && isJsxOpeningLikeElement(contextToken.parent);
-    const { moduleSpecifier, codeAction } = ts_codefix_exports.getImportCompletionAction(
-      targetSymbol,
-      moduleSymbol,
-      data == null ? void 0 : data.exportMapKey,
-      sourceFile,
-      name,
-      isJsxOpeningTagName,
-      host,
-      program,
-      formatContext,
-      previousToken && isIdentifier(previousToken) ? previousToken.getStart(sourceFile) : position,
-      preferences,
-      cancellationToken
-    );
-    Debug.assert(!(data == null ? void 0 : data.moduleSpecifier) || moduleSpecifier === data.moduleSpecifier);
-    return { sourceDisplay: [textPart(moduleSpecifier)], codeActions: [codeAction] };
+    return emptyOptions;
   }
-  function getCompletionEntrySymbol(program, log, sourceFile, position, entryId, host, preferences) {
-    const completion = getSymbolCompletionFromEntryId(program, log, sourceFile, position, entryId, host, preferences);
-    return completion.type === "symbol" ? completion.symbol : void 0;
+  function toImplementationLocation(entry, checker) {
+    const documentSpan = entryToDocumentSpan(entry);
+    if (entry.kind !== 0 /* Span */) {
+      const { node } = entry;
+      return {
+        ...documentSpan,
+        ...implementationKindDisplayParts(node, checker)
+      };
+    } else {
+      return { ...documentSpan, kind: "" /* unknown */, displayParts: [] };
+    }
   }
-  function getRecommendedCompletion(previousToken, contextualType, checker) {
-    return firstDefined(contextualType && (contextualType.isUnion() ? contextualType.types : [contextualType]), (type) => {
-      const symbol = type && type.symbol;
-      return symbol && (symbol.flags & (8 /* EnumMember */ | 384 /* Enum */ | 32 /* Class */) && !isAbstractConstructorSymbol(symbol)) ? getFirstSymbolInChain(symbol, previousToken, checker) : void 0;
-    });
+  function implementationKindDisplayParts(node, checker) {
+    const symbol = checker.getSymbolAtLocation(isDeclaration(node) && node.name ? node.name : node);
+    if (symbol) {
+      return getDefinitionKindAndDisplayParts(symbol, checker, node);
+    } else if (node.kind === 210 /* ObjectLiteralExpression */) {
+      return {
+        kind: "interface" /* interfaceElement */,
+        displayParts: [punctuationPart(21 /* OpenParenToken */), textPart("object literal"), punctuationPart(22 /* CloseParenToken */)]
+      };
+    } else if (node.kind === 231 /* ClassExpression */) {
+      return {
+        kind: "local class" /* localClassElement */,
+        displayParts: [punctuationPart(21 /* OpenParenToken */), textPart("anonymous local class"), punctuationPart(22 /* CloseParenToken */)]
+      };
+    } else {
+      return { kind: getNodeKind(node), displayParts: [] };
+    }
   }
-  function getContextualType(previousToken, position, sourceFile, checker) {
-    const { parent: parent2 } = previousToken;
-    switch (previousToken.kind) {
-      case 80 /* Identifier */:
-        return getContextualTypeFromParent(previousToken, checker);
-      case 64 /* EqualsToken */:
-        switch (parent2.kind) {
-          case 259 /* VariableDeclaration */:
-            return checker.getContextualType(parent2.initializer);
-          case 225 /* BinaryExpression */:
-            return checker.getTypeAtLocation(parent2.left);
-          case 290 /* JsxAttribute */:
-            return checker.getContextualTypeForJsxAttribute(parent2);
-          default:
-            return void 0;
+  function toHighlightSpan(entry) {
+    const documentSpan = entryToDocumentSpan(entry);
+    if (entry.kind === 0 /* Span */) {
+      return {
+        fileName: documentSpan.fileName,
+        span: {
+          textSpan: documentSpan.textSpan,
+          kind: "reference" /* reference */
         }
-      case 105 /* NewKeyword */:
-        return checker.getContextualType(parent2);
-      case 84 /* CaseKeyword */:
-        const caseClause = tryCast(parent2, isCaseClause);
-        return caseClause ? getSwitchedType(caseClause, checker) : void 0;
-      case 19 /* OpenBraceToken */:
-        return isJsxExpression(parent2) && !isJsxElement(parent2.parent) && !isJsxFragment(parent2.parent) ? checker.getContextualTypeForJsxAttribute(parent2.parent) : void 0;
-      default:
-        const argInfo = ts_SignatureHelp_exports.getArgumentInfoForCompletions(previousToken, position, sourceFile);
-        return argInfo ? (
-          // At `,`, treat this as the next argument after the comma.
-          checker.getContextualTypeForArgumentAtIndex(argInfo.invocation, argInfo.argumentIndex + (previousToken.kind === 28 /* CommaToken */ ? 1 : 0))
-        ) : isEqualityOperatorKind(previousToken.kind) && isBinaryExpression(parent2) && isEqualityOperatorKind(parent2.operatorToken.kind) ? (
-          // completion at `x ===/**/` should be for the right side
-          checker.getTypeAtLocation(parent2.left)
-        ) : checker.getContextualType(previousToken, 4 /* Completions */) || checker.getContextualType(previousToken);
+      };
+    }
+    const writeAccess = isWriteAccessForReference(entry.node);
+    const span = {
+      textSpan: documentSpan.textSpan,
+      kind: writeAccess ? "writtenReference" /* writtenReference */ : "reference" /* reference */,
+      isInString: entry.kind === 2 /* StringLiteral */ ? true : void 0,
+      ...documentSpan.contextSpan && { contextSpan: documentSpan.contextSpan }
+    };
+    return { fileName: documentSpan.fileName, span };
+  }
+  function getTextSpan(node, sourceFile, endNode2) {
+    let start = node.getStart(sourceFile);
+    let end = (endNode2 || node).getEnd();
+    if (isStringLiteralLike(node) && end - start > 2) {
+      Debug.assert(endNode2 === void 0);
+      start += 1;
+      end -= 1;
     }
+    return createTextSpanFromBounds(start, end);
   }
-  function getFirstSymbolInChain(symbol, enclosingDeclaration, checker) {
-    const chain = checker.getAccessibleSymbolChain(
-      symbol,
-      enclosingDeclaration,
-      /*meaning*/
-      67108863 /* All */,
-      /*useOnlyExternalAliasing*/
-      false
-    );
-    if (chain)
-      return first(chain);
-    return symbol.parent && (isModuleSymbol(symbol.parent) ? symbol : getFirstSymbolInChain(symbol.parent, enclosingDeclaration, checker));
+  function getTextSpanOfEntry(entry) {
+    return entry.kind === 0 /* Span */ ? entry.textSpan : getTextSpan(entry.node, entry.node.getSourceFile());
   }
-  function isModuleSymbol(symbol) {
+  function isWriteAccessForReference(node) {
+    const decl = getDeclarationFromName(node);
+    return !!decl && declarationIsWriteAccess(decl) || node.kind === 90 /* DefaultKeyword */ || isWriteAccess(node);
+  }
+  function isDeclarationOfSymbol(node, target) {
     var _a;
-    return !!((_a = symbol.declarations) == null ? void 0 : _a.some((d) => d.kind === 311 /* SourceFile */));
+    if (!target)
+      return false;
+    const source = getDeclarationFromName(node) || (node.kind === 90 /* DefaultKeyword */ ? node.parent : isLiteralComputedPropertyDeclarationName(node) ? node.parent.parent : node.kind === 137 /* ConstructorKeyword */ && isConstructorDeclaration(node.parent) ? node.parent.parent : void 0);
+    const commonjsSource = source && isBinaryExpression(source) ? source.left : void 0;
+    return !!(source && ((_a = target.declarations) == null ? void 0 : _a.some((d) => d === source || d === commonjsSource)));
   }
-  function getCompletionData(program, log, sourceFile, compilerOptions, position, preferences, detailsEntryId, host, formatContext, cancellationToken) {
-    const typeChecker = program.getTypeChecker();
-    const inCheckedFile = isCheckedFile(sourceFile, compilerOptions);
-    let start = timestamp();
-    let currentToken = getTokenAtPosition(sourceFile, position);
-    log("getCompletionData: Get current token: " + (timestamp() - start));
-    start = timestamp();
-    const insideComment = isInComment(sourceFile, position, currentToken);
-    log("getCompletionData: Is inside comment: " + (timestamp() - start));
-    let insideJsDocTagTypeExpression = false;
-    let isInSnippetScope = false;
-    if (insideComment) {
-      if (hasDocComment(sourceFile, position)) {
-        if (sourceFile.text.charCodeAt(position - 1) === 64 /* at */) {
-          return { kind: 1 /* JsDocTagName */ };
-        } else {
-          const lineStart = getLineStartPositionForPosition(position, sourceFile);
-          if (!/[^\*|\s(/)]/.test(sourceFile.text.substring(lineStart, position))) {
-            return { kind: 2 /* JsDocTag */ };
+  function declarationIsWriteAccess(decl) {
+    if (!!(decl.flags & 33554432 /* Ambient */))
+      return true;
+    switch (decl.kind) {
+      case 226 /* BinaryExpression */:
+      case 208 /* BindingElement */:
+      case 263 /* ClassDeclaration */:
+      case 231 /* ClassExpression */:
+      case 90 /* DefaultKeyword */:
+      case 266 /* EnumDeclaration */:
+      case 306 /* EnumMember */:
+      case 281 /* ExportSpecifier */:
+      case 273 /* ImportClause */:
+      case 271 /* ImportEqualsDeclaration */:
+      case 276 /* ImportSpecifier */:
+      case 264 /* InterfaceDeclaration */:
+      case 345 /* JSDocCallbackTag */:
+      case 353 /* JSDocTypedefTag */:
+      case 291 /* JsxAttribute */:
+      case 267 /* ModuleDeclaration */:
+      case 270 /* NamespaceExportDeclaration */:
+      case 274 /* NamespaceImport */:
+      case 280 /* NamespaceExport */:
+      case 169 /* Parameter */:
+      case 304 /* ShorthandPropertyAssignment */:
+      case 265 /* TypeAliasDeclaration */:
+      case 168 /* TypeParameter */:
+        return true;
+      case 303 /* PropertyAssignment */:
+        return !isArrayLiteralOrObjectLiteralDestructuringPattern(decl.parent);
+      case 262 /* FunctionDeclaration */:
+      case 218 /* FunctionExpression */:
+      case 176 /* Constructor */:
+      case 174 /* MethodDeclaration */:
+      case 177 /* GetAccessor */:
+      case 178 /* SetAccessor */:
+        return !!decl.body;
+      case 260 /* VariableDeclaration */:
+      case 172 /* PropertyDeclaration */:
+        return !!decl.initializer || isCatchClause(decl.parent);
+      case 173 /* MethodSignature */:
+      case 171 /* PropertySignature */:
+      case 355 /* JSDocPropertyTag */:
+      case 348 /* JSDocParameterTag */:
+        return false;
+      default:
+        return Debug.failBadSyntaxKind(decl);
+    }
+  }
+  var DefinitionKind, EntryKind, FindReferencesUse, Core;
+  var init_findAllReferences = __esm({
+    "src/services/findAllReferences.ts"() {
+      "use strict";
+      init_ts4();
+      init_ts_FindAllReferences();
+      DefinitionKind = /* @__PURE__ */ ((DefinitionKind2) => {
+        DefinitionKind2[DefinitionKind2["Symbol"] = 0] = "Symbol";
+        DefinitionKind2[DefinitionKind2["Label"] = 1] = "Label";
+        DefinitionKind2[DefinitionKind2["Keyword"] = 2] = "Keyword";
+        DefinitionKind2[DefinitionKind2["This"] = 3] = "This";
+        DefinitionKind2[DefinitionKind2["String"] = 4] = "String";
+        DefinitionKind2[DefinitionKind2["TripleSlashReference"] = 5] = "TripleSlashReference";
+        return DefinitionKind2;
+      })(DefinitionKind || {});
+      EntryKind = /* @__PURE__ */ ((EntryKind2) => {
+        EntryKind2[EntryKind2["Span"] = 0] = "Span";
+        EntryKind2[EntryKind2["Node"] = 1] = "Node";
+        EntryKind2[EntryKind2["StringLiteral"] = 2] = "StringLiteral";
+        EntryKind2[EntryKind2["SearchedLocalFoundProperty"] = 3] = "SearchedLocalFoundProperty";
+        EntryKind2[EntryKind2["SearchedPropertyFoundLocal"] = 4] = "SearchedPropertyFoundLocal";
+        return EntryKind2;
+      })(EntryKind || {});
+      FindReferencesUse = /* @__PURE__ */ ((FindReferencesUse2) => {
+        FindReferencesUse2[FindReferencesUse2["Other"] = 0] = "Other";
+        FindReferencesUse2[FindReferencesUse2["References"] = 1] = "References";
+        FindReferencesUse2[FindReferencesUse2["Rename"] = 2] = "Rename";
+        return FindReferencesUse2;
+      })(FindReferencesUse || {});
+      ((Core2) => {
+        function getReferencedSymbolsForNode(position, node, program, sourceFiles, cancellationToken, options = {}, sourceFilesSet = new Set(sourceFiles.map((f) => f.fileName))) {
+          var _a, _b;
+          node = getAdjustedNode2(node, options);
+          if (isSourceFile(node)) {
+            const resolvedRef = ts_GoToDefinition_exports.getReferenceAtPosition(node, position, program);
+            if (!(resolvedRef == null ? void 0 : resolvedRef.file)) {
+              return void 0;
+            }
+            const moduleSymbol = program.getTypeChecker().getMergedSymbol(resolvedRef.file.symbol);
+            if (moduleSymbol) {
+              return getReferencedSymbolsForModule(
+                program,
+                moduleSymbol,
+                /*excludeImportTypeOfExportEquals*/
+                false,
+                sourceFiles,
+                sourceFilesSet
+              );
+            }
+            const fileIncludeReasons = program.getFileIncludeReasons();
+            if (!fileIncludeReasons) {
+              return void 0;
+            }
+            return [{
+              definition: { type: 5 /* TripleSlashReference */, reference: resolvedRef.reference, file: node },
+              references: getReferencesForNonModule(resolvedRef.file, fileIncludeReasons, program) || emptyArray
+            }];
+          }
+          if (!options.implementations) {
+            const special = getReferencedSymbolsSpecial(node, sourceFiles, cancellationToken);
+            if (special) {
+              return special;
+            }
+          }
+          const checker = program.getTypeChecker();
+          const symbol = checker.getSymbolAtLocation(isConstructorDeclaration(node) && node.parent.name || node);
+          if (!symbol) {
+            if (!options.implementations && isStringLiteralLike(node)) {
+              if (isModuleSpecifierLike(node)) {
+                const fileIncludeReasons = program.getFileIncludeReasons();
+                const referencedFileName = (_b = (_a = program.getResolvedModule(node.getSourceFile(), node.text, getModeForUsageLocation(node.getSourceFile(), node))) == null ? void 0 : _a.resolvedModule) == null ? void 0 : _b.resolvedFileName;
+                const referencedFile = referencedFileName ? program.getSourceFile(referencedFileName) : void 0;
+                if (referencedFile) {
+                  return [{ definition: { type: 4 /* String */, node }, references: getReferencesForNonModule(referencedFile, fileIncludeReasons, program) || emptyArray }];
+                }
+              }
+              return getReferencesForStringLiteral(node, sourceFiles, checker, cancellationToken);
+            }
+            return void 0;
+          }
+          if (symbol.escapedName === "export=" /* ExportEquals */) {
+            return getReferencedSymbolsForModule(
+              program,
+              symbol.parent,
+              /*excludeImportTypeOfExportEquals*/
+              false,
+              sourceFiles,
+              sourceFilesSet
+            );
+          }
+          const moduleReferences = getReferencedSymbolsForModuleIfDeclaredBySourceFile(symbol, program, sourceFiles, cancellationToken, options, sourceFilesSet);
+          if (moduleReferences && !(symbol.flags & 33554432 /* Transient */)) {
+            return moduleReferences;
+          }
+          const aliasedSymbol = getMergedAliasedSymbolOfNamespaceExportDeclaration(node, symbol, checker);
+          const moduleReferencesOfExportTarget = aliasedSymbol && getReferencedSymbolsForModuleIfDeclaredBySourceFile(aliasedSymbol, program, sourceFiles, cancellationToken, options, sourceFilesSet);
+          const references = getReferencedSymbolsForSymbol(symbol, node, sourceFiles, sourceFilesSet, checker, cancellationToken, options);
+          return mergeReferences(program, moduleReferences, references, moduleReferencesOfExportTarget);
+        }
+        Core2.getReferencedSymbolsForNode = getReferencedSymbolsForNode;
+        function getAdjustedNode2(node, options) {
+          if (options.use === 1 /* References */) {
+            node = getAdjustedReferenceLocation(node);
+          } else if (options.use === 2 /* Rename */) {
+            node = getAdjustedRenameLocation(node);
+          }
+          return node;
+        }
+        Core2.getAdjustedNode = getAdjustedNode2;
+        function getReferencesForFileName(fileName, program, sourceFiles, sourceFilesSet = new Set(sourceFiles.map((f) => f.fileName))) {
+          var _a, _b;
+          const moduleSymbol = (_a = program.getSourceFile(fileName)) == null ? void 0 : _a.symbol;
+          if (moduleSymbol) {
+            return ((_b = getReferencedSymbolsForModule(
+              program,
+              moduleSymbol,
+              /*excludeImportTypeOfExportEquals*/
+              false,
+              sourceFiles,
+              sourceFilesSet
+            )[0]) == null ? void 0 : _b.references) || emptyArray;
+          }
+          const fileIncludeReasons = program.getFileIncludeReasons();
+          const referencedFile = program.getSourceFile(fileName);
+          return referencedFile && fileIncludeReasons && getReferencesForNonModule(referencedFile, fileIncludeReasons, program) || emptyArray;
+        }
+        Core2.getReferencesForFileName = getReferencesForFileName;
+        function getReferencesForNonModule(referencedFile, refFileMap, program) {
+          let entries;
+          const references = refFileMap.get(referencedFile.path) || emptyArray;
+          for (const ref of references) {
+            if (isReferencedFile(ref)) {
+              const referencingFile = program.getSourceFileByPath(ref.file);
+              const location = getReferencedFileLocation(program, ref);
+              if (isReferenceFileLocation(location)) {
+                entries = append(entries, {
+                  kind: 0 /* Span */,
+                  fileName: referencingFile.fileName,
+                  textSpan: createTextSpanFromRange(location)
+                });
+              }
+            }
+          }
+          return entries;
+        }
+        function getMergedAliasedSymbolOfNamespaceExportDeclaration(node, symbol, checker) {
+          if (node.parent && isNamespaceExportDeclaration(node.parent)) {
+            const aliasedSymbol = checker.getAliasedSymbol(symbol);
+            const targetSymbol = checker.getMergedSymbol(aliasedSymbol);
+            if (aliasedSymbol !== targetSymbol) {
+              return targetSymbol;
+            }
+          }
+          return void 0;
+        }
+        function getReferencedSymbolsForModuleIfDeclaredBySourceFile(symbol, program, sourceFiles, cancellationToken, options, sourceFilesSet) {
+          const moduleSourceFile = symbol.flags & 1536 /* Module */ && symbol.declarations && find(symbol.declarations, isSourceFile);
+          if (!moduleSourceFile)
+            return void 0;
+          const exportEquals = symbol.exports.get("export=" /* ExportEquals */);
+          const moduleReferences = getReferencedSymbolsForModule(program, symbol, !!exportEquals, sourceFiles, sourceFilesSet);
+          if (!exportEquals || !sourceFilesSet.has(moduleSourceFile.fileName))
+            return moduleReferences;
+          const checker = program.getTypeChecker();
+          symbol = skipAlias(exportEquals, checker);
+          return mergeReferences(program, moduleReferences, getReferencedSymbolsForSymbol(
+            symbol,
+            /*node*/
+            void 0,
+            sourceFiles,
+            sourceFilesSet,
+            checker,
+            cancellationToken,
+            options
+          ));
+        }
+        function mergeReferences(program, ...referencesToMerge) {
+          let result;
+          for (const references of referencesToMerge) {
+            if (!references || !references.length)
+              continue;
+            if (!result) {
+              result = references;
+              continue;
+            }
+            for (const entry of references) {
+              if (!entry.definition || entry.definition.type !== 0 /* Symbol */) {
+                result.push(entry);
+                continue;
+              }
+              const symbol = entry.definition.symbol;
+              const refIndex = findIndex(result, (ref) => !!ref.definition && ref.definition.type === 0 /* Symbol */ && ref.definition.symbol === symbol);
+              if (refIndex === -1) {
+                result.push(entry);
+                continue;
+              }
+              const reference = result[refIndex];
+              result[refIndex] = {
+                definition: reference.definition,
+                references: reference.references.concat(entry.references).sort((entry1, entry2) => {
+                  const entry1File = getSourceFileIndexOfEntry(program, entry1);
+                  const entry2File = getSourceFileIndexOfEntry(program, entry2);
+                  if (entry1File !== entry2File) {
+                    return compareValues(entry1File, entry2File);
+                  }
+                  const entry1Span = getTextSpanOfEntry(entry1);
+                  const entry2Span = getTextSpanOfEntry(entry2);
+                  return entry1Span.start !== entry2Span.start ? compareValues(entry1Span.start, entry2Span.start) : compareValues(entry1Span.length, entry2Span.length);
+                })
+              };
+            }
+          }
+          return result;
+        }
+        function getSourceFileIndexOfEntry(program, entry) {
+          const sourceFile = entry.kind === 0 /* Span */ ? program.getSourceFile(entry.fileName) : entry.node.getSourceFile();
+          return program.getSourceFiles().indexOf(sourceFile);
+        }
+        function getReferencedSymbolsForModule(program, symbol, excludeImportTypeOfExportEquals, sourceFiles, sourceFilesSet) {
+          Debug.assert(!!symbol.valueDeclaration);
+          const references = mapDefined(findModuleReferences(program, sourceFiles, symbol), (reference) => {
+            if (reference.kind === "import") {
+              const parent2 = reference.literal.parent;
+              if (isLiteralTypeNode(parent2)) {
+                const importType = cast(parent2.parent, isImportTypeNode);
+                if (excludeImportTypeOfExportEquals && !importType.qualifier) {
+                  return void 0;
+                }
+              }
+              return nodeEntry(reference.literal);
+            } else if (reference.kind === "implicit") {
+              const range = reference.literal.text !== externalHelpersModuleNameText && forEachChildRecursively(
+                reference.referencingFile,
+                (n) => !(n.transformFlags & 2 /* ContainsJsx */) ? "skip" : isJsxElement(n) || isJsxSelfClosingElement(n) || isJsxFragment(n) ? n : void 0
+              ) || reference.referencingFile.statements[0] || reference.referencingFile;
+              return nodeEntry(range);
+            } else {
+              return {
+                kind: 0 /* Span */,
+                fileName: reference.referencingFile.fileName,
+                textSpan: createTextSpanFromRange(reference.ref)
+              };
+            }
+          });
+          if (symbol.declarations) {
+            for (const decl of symbol.declarations) {
+              switch (decl.kind) {
+                case 312 /* SourceFile */:
+                  break;
+                case 267 /* ModuleDeclaration */:
+                  if (sourceFilesSet.has(decl.getSourceFile().fileName)) {
+                    references.push(nodeEntry(decl.name));
+                  }
+                  break;
+                default:
+                  Debug.assert(!!(symbol.flags & 33554432 /* Transient */), "Expected a module symbol to be declared by a SourceFile or ModuleDeclaration.");
+              }
+            }
+          }
+          const exported = symbol.exports.get("export=" /* ExportEquals */);
+          if (exported == null ? void 0 : exported.declarations) {
+            for (const decl of exported.declarations) {
+              const sourceFile = decl.getSourceFile();
+              if (sourceFilesSet.has(sourceFile.fileName)) {
+                const node = isBinaryExpression(decl) && isPropertyAccessExpression(decl.left) ? decl.left.expression : isExportAssignment(decl) ? Debug.checkDefined(findChildOfKind(decl, 95 /* ExportKeyword */, sourceFile)) : getNameOfDeclaration(decl) || decl;
+                references.push(nodeEntry(node));
+              }
+            }
           }
+          return references.length ? [{ definition: { type: 0 /* Symbol */, symbol }, references }] : emptyArray;
         }
-      }
-      const tag = getJsDocTagAtPosition(currentToken, position);
-      if (tag) {
-        if (tag.tagName.pos <= position && position <= tag.tagName.end) {
-          return { kind: 1 /* JsDocTagName */ };
+        function isReadonlyTypeOperator(node) {
+          return node.kind === 148 /* ReadonlyKeyword */ && isTypeOperatorNode(node.parent) && node.parent.operator === 148 /* ReadonlyKeyword */;
         }
-        const typeExpression = tryGetTypeExpressionFromTag(tag);
-        if (typeExpression) {
-          currentToken = getTokenAtPosition(sourceFile, position);
-          if (!currentToken || !isDeclarationName(currentToken) && (currentToken.parent.kind !== 354 /* JSDocPropertyTag */ || currentToken.parent.name !== currentToken)) {
-            insideJsDocTagTypeExpression = isCurrentlyEditingNode(typeExpression);
+        function getReferencedSymbolsSpecial(node, sourceFiles, cancellationToken) {
+          if (isTypeKeyword(node.kind)) {
+            if (node.kind === 116 /* VoidKeyword */ && isVoidExpression(node.parent)) {
+              return void 0;
+            }
+            if (node.kind === 148 /* ReadonlyKeyword */ && !isReadonlyTypeOperator(node)) {
+              return void 0;
+            }
+            return getAllReferencesForKeyword(
+              sourceFiles,
+              node.kind,
+              cancellationToken,
+              node.kind === 148 /* ReadonlyKeyword */ ? isReadonlyTypeOperator : void 0
+            );
+          }
+          if (isImportMeta(node.parent) && node.parent.name === node) {
+            return getAllReferencesForImportMeta(sourceFiles, cancellationToken);
+          }
+          if (isStaticModifier(node) && isClassStaticBlockDeclaration(node.parent)) {
+            return [{ definition: { type: 2 /* Keyword */, node }, references: [nodeEntry(node)] }];
+          }
+          if (isJumpStatementTarget(node)) {
+            const labelDefinition = getTargetLabel(node.parent, node.text);
+            return labelDefinition && getLabelReferencesInNode(labelDefinition.parent, labelDefinition);
+          } else if (isLabelOfLabeledStatement(node)) {
+            return getLabelReferencesInNode(node.parent, node);
+          }
+          if (isThis(node)) {
+            return getReferencesForThisKeyword(node, sourceFiles, cancellationToken);
+          }
+          if (node.kind === 108 /* SuperKeyword */) {
+            return getReferencesForSuperKeyword(node);
           }
+          return void 0;
         }
-        if (!insideJsDocTagTypeExpression && isJSDocParameterTag(tag) && (nodeIsMissing(tag.name) || tag.name.pos <= position && position <= tag.name.end)) {
-          return { kind: 3 /* JsDocParameterName */, tag };
+        function getReferencedSymbolsForSymbol(originalSymbol, node, sourceFiles, sourceFilesSet, checker, cancellationToken, options) {
+          const symbol = node && skipPastExportOrImportSpecifierOrUnion(
+            originalSymbol,
+            node,
+            checker,
+            /*useLocalSymbolForExportSpecifier*/
+            !isForRenameWithPrefixAndSuffixText(options)
+          ) || originalSymbol;
+          const searchMeaning = node ? getIntersectingMeaningFromDeclarations(node, symbol) : 7 /* All */;
+          const result = [];
+          const state = new State(sourceFiles, sourceFilesSet, node ? getSpecialSearchKind(node) : 0 /* None */, checker, cancellationToken, searchMeaning, options, result);
+          const exportSpecifier = !isForRenameWithPrefixAndSuffixText(options) || !symbol.declarations ? void 0 : find(symbol.declarations, isExportSpecifier);
+          if (exportSpecifier) {
+            getReferencesAtExportSpecifier(
+              exportSpecifier.name,
+              symbol,
+              exportSpecifier,
+              state.createSearch(
+                node,
+                originalSymbol,
+                /*comingFrom*/
+                void 0
+              ),
+              state,
+              /*addReferencesHere*/
+              true,
+              /*alwaysGetReferences*/
+              true
+            );
+          } else if (node && node.kind === 90 /* DefaultKeyword */ && symbol.escapedName === "default" /* Default */ && symbol.parent) {
+            addReference(node, symbol, state);
+            searchForImportsOfExport(node, symbol, { exportingModuleSymbol: symbol.parent, exportKind: 1 /* Default */ }, state);
+          } else {
+            const search = state.createSearch(
+              node,
+              symbol,
+              /*comingFrom*/
+              void 0,
+              { allSearchSymbols: node ? populateSearchSymbolSet(symbol, node, checker, options.use === 2 /* Rename */, !!options.providePrefixAndSuffixTextForRename, !!options.implementations) : [symbol] }
+            );
+            getReferencesInContainerOrFiles(symbol, state, search);
+          }
+          return result;
         }
-      }
-      if (!insideJsDocTagTypeExpression) {
-        log("Returning an empty list because completion was inside a regular comment or plain text part of a JsDoc comment.");
-        return void 0;
-      }
-    }
-    start = timestamp();
-    const isJsOnlyLocation = !insideJsDocTagTypeExpression && isSourceFileJS(sourceFile);
-    const tokens = getRelevantTokens(position, sourceFile);
-    const previousToken = tokens.previousToken;
-    let contextToken = tokens.contextToken;
-    log("getCompletionData: Get previous token: " + (timestamp() - start));
-    let node = currentToken;
-    let propertyAccessToConvert;
-    let isRightOfDot = false;
-    let isRightOfQuestionDot = false;
-    let isRightOfOpenTag = false;
-    let isStartingCloseTag = false;
-    let isJsxInitializer = false;
-    let isJsxIdentifierExpected = false;
-    let importStatementCompletion;
-    let location = getTouchingPropertyName(sourceFile, position);
-    let keywordFilters = 0 /* None */;
-    let isNewIdentifierLocation = false;
-    let flags = 0 /* None */;
-    if (contextToken) {
-      const importStatementCompletionInfo = getImportStatementCompletionInfo(contextToken);
-      if (importStatementCompletionInfo.keywordCompletion) {
-        if (importStatementCompletionInfo.isKeywordOnlyCompletion) {
-          return {
-            kind: 4 /* Keywords */,
-            keywordCompletions: [keywordToCompletionEntry(importStatementCompletionInfo.keywordCompletion)],
-            isNewIdentifierLocation: importStatementCompletionInfo.isNewIdentifierLocation
-          };
+        function getReferencesInContainerOrFiles(symbol, state, search) {
+          const scope = getSymbolScope(symbol);
+          if (scope) {
+            getReferencesInContainer(
+              scope,
+              scope.getSourceFile(),
+              search,
+              state,
+              /*addReferencesHere*/
+              !(isSourceFile(scope) && !contains(state.sourceFiles, scope))
+            );
+          } else {
+            for (const sourceFile of state.sourceFiles) {
+              state.cancellationToken.throwIfCancellationRequested();
+              searchForName(sourceFile, search, state);
+            }
+          }
         }
-        keywordFilters = keywordFiltersFromSyntaxKind(importStatementCompletionInfo.keywordCompletion);
-      }
-      if (importStatementCompletionInfo.replacementSpan && preferences.includeCompletionsForImportStatements && preferences.includeCompletionsWithInsertText) {
-        flags |= 2 /* IsImportStatementCompletion */;
-        importStatementCompletion = importStatementCompletionInfo;
-        isNewIdentifierLocation = importStatementCompletionInfo.isNewIdentifierLocation;
-      }
-      if (!importStatementCompletionInfo.replacementSpan && isCompletionListBlocker(contextToken)) {
-        log("Returning an empty list because completion was requested in an invalid position.");
-        return keywordFilters ? keywordCompletionData(keywordFilters, isJsOnlyLocation, isNewIdentifierDefinitionLocation()) : void 0;
-      }
-      let parent2 = contextToken.parent;
-      if (contextToken.kind === 25 /* DotToken */ || contextToken.kind === 29 /* QuestionDotToken */) {
-        isRightOfDot = contextToken.kind === 25 /* DotToken */;
-        isRightOfQuestionDot = contextToken.kind === 29 /* QuestionDotToken */;
-        switch (parent2.kind) {
-          case 210 /* PropertyAccessExpression */:
-            propertyAccessToConvert = parent2;
-            node = propertyAccessToConvert.expression;
-            const leftmostAccessExpression = getLeftmostAccessExpression(propertyAccessToConvert);
-            if (nodeIsMissing(leftmostAccessExpression) || (isCallExpression(node) || isFunctionLike(node)) && node.end === contextToken.pos && node.getChildCount(sourceFile) && last(node.getChildren(sourceFile)).kind !== 22 /* CloseParenToken */) {
-              return void 0;
+        function getSpecialSearchKind(node) {
+          switch (node.kind) {
+            case 176 /* Constructor */:
+            case 137 /* ConstructorKeyword */:
+              return 1 /* Constructor */;
+            case 80 /* Identifier */:
+              if (isClassLike(node.parent)) {
+                Debug.assert(node.parent.name === node);
+                return 2 /* Class */;
+              }
+            default:
+              return 0 /* None */;
+          }
+        }
+        function skipPastExportOrImportSpecifierOrUnion(symbol, node, checker, useLocalSymbolForExportSpecifier) {
+          const { parent: parent2 } = node;
+          if (isExportSpecifier(parent2) && useLocalSymbolForExportSpecifier) {
+            return getLocalSymbolForExportSpecifier(node, symbol, parent2, checker);
+          }
+          return firstDefined(symbol.declarations, (decl) => {
+            if (!decl.parent) {
+              if (symbol.flags & 33554432 /* Transient */)
+                return void 0;
+              Debug.fail(`Unexpected symbol at ${Debug.formatSyntaxKind(node.kind)}: ${Debug.formatSymbol(symbol)}`);
             }
-            break;
-          case 165 /* QualifiedName */:
-            node = parent2.left;
-            break;
-          case 266 /* ModuleDeclaration */:
-            node = parent2.name;
-            break;
-          case 204 /* ImportType */:
-            node = parent2;
-            break;
-          case 235 /* MetaProperty */:
-            node = parent2.getFirstToken(sourceFile);
-            Debug.assert(node.kind === 102 /* ImportKeyword */ || node.kind === 105 /* NewKeyword */);
-            break;
-          default:
+            return isTypeLiteralNode(decl.parent) && isUnionTypeNode(decl.parent.parent) ? checker.getPropertyOfType(checker.getTypeFromTypeNode(decl.parent.parent), symbol.name) : void 0;
+          });
+        }
+        let SpecialSearchKind;
+        ((SpecialSearchKind2) => {
+          SpecialSearchKind2[SpecialSearchKind2["None"] = 0] = "None";
+          SpecialSearchKind2[SpecialSearchKind2["Constructor"] = 1] = "Constructor";
+          SpecialSearchKind2[SpecialSearchKind2["Class"] = 2] = "Class";
+        })(SpecialSearchKind || (SpecialSearchKind = {}));
+        function getNonModuleSymbolOfMergedModuleSymbol(symbol) {
+          if (!(symbol.flags & (1536 /* Module */ | 33554432 /* Transient */)))
             return void 0;
+          const decl = symbol.declarations && find(symbol.declarations, (d) => !isSourceFile(d) && !isModuleDeclaration(d));
+          return decl && decl.symbol;
         }
-      } else if (!importStatementCompletion) {
-        if (parent2 && parent2.kind === 210 /* PropertyAccessExpression */) {
-          contextToken = parent2;
-          parent2 = parent2.parent;
+        class State {
+          constructor(sourceFiles, sourceFilesSet, specialSearchKind, checker, cancellationToken, searchMeaning, options, result) {
+            this.sourceFiles = sourceFiles;
+            this.sourceFilesSet = sourceFilesSet;
+            this.specialSearchKind = specialSearchKind;
+            this.checker = checker;
+            this.cancellationToken = cancellationToken;
+            this.searchMeaning = searchMeaning;
+            this.options = options;
+            this.result = result;
+            /** Cache for `explicitlyinheritsFrom`. */
+            this.inheritsFromCache = /* @__PURE__ */ new Map();
+            /**
+             * Type nodes can contain multiple references to the same type. For example:
+             *      let x: Foo & (Foo & Bar) = ...
+             * Because we are returning the implementation locations and not the identifier locations,
+             * duplicate entries would be returned here as each of the type references is part of
+             * the same implementation. For that reason, check before we add a new entry.
+             */
+            this.markSeenContainingTypeReference = nodeSeenTracker();
+            /**
+             * It's possible that we will encounter the right side of `export { foo as bar } from "x";` more than once.
+             * For example:
+             *     // b.ts
+             *     export { foo as bar } from "./a";
+             *     import { bar } from "./b";
+             *
+             * Normally at `foo as bar` we directly add `foo` and do not locally search for it (since it doesn't declare a local).
+             * But another reference to it may appear in the same source file.
+             * See `tests/cases/fourslash/transitiveExportImports3.ts`.
+             */
+            this.markSeenReExportRHS = nodeSeenTracker();
+            this.symbolIdToReferences = [];
+            // Source file ID -> symbol ID -> Whether the symbol has been searched for in the source file.
+            this.sourceFileToSeenSymbols = [];
+          }
+          includesSourceFile(sourceFile) {
+            return this.sourceFilesSet.has(sourceFile.fileName);
+          }
+          /** Gets every place to look for references of an exported symbols. See `ImportsResult` in `importTracker.ts` for more documentation. */
+          getImportSearches(exportSymbol, exportInfo) {
+            if (!this.importTracker)
+              this.importTracker = createImportTracker(this.sourceFiles, this.sourceFilesSet, this.checker, this.cancellationToken);
+            return this.importTracker(exportSymbol, exportInfo, this.options.use === 2 /* Rename */);
+          }
+          /** @param allSearchSymbols set of additional symbols for use by `includes`. */
+          createSearch(location, symbol, comingFrom, searchOptions = {}) {
+            const {
+              text = stripQuotes(symbolName(getLocalSymbolForExportDefault(symbol) || getNonModuleSymbolOfMergedModuleSymbol(symbol) || symbol)),
+              allSearchSymbols = [symbol]
+            } = searchOptions;
+            const escapedText = escapeLeadingUnderscores(text);
+            const parents = this.options.implementations && location ? getParentSymbolsOfPropertyAccess(location, symbol, this.checker) : void 0;
+            return { symbol, comingFrom, text, escapedText, parents, allSearchSymbols, includes: (sym) => contains(allSearchSymbols, sym) };
+          }
+          /**
+           * Callback to add references for a particular searched symbol.
+           * This initializes a reference group, so only call this if you will add at least one reference.
+           */
+          referenceAdder(searchSymbol) {
+            const symbolId = getSymbolId(searchSymbol);
+            let references = this.symbolIdToReferences[symbolId];
+            if (!references) {
+              references = this.symbolIdToReferences[symbolId] = [];
+              this.result.push({ definition: { type: 0 /* Symbol */, symbol: searchSymbol }, references });
+            }
+            return (node, kind) => references.push(nodeEntry(node, kind));
+          }
+          /** Add a reference with no associated definition. */
+          addStringOrCommentReference(fileName, textSpan) {
+            this.result.push({
+              definition: void 0,
+              references: [{ kind: 0 /* Span */, fileName, textSpan }]
+            });
+          }
+          /** Returns `true` the first time we search for a symbol in a file and `false` afterwards. */
+          markSearchedSymbols(sourceFile, symbols) {
+            const sourceId = getNodeId(sourceFile);
+            const seenSymbols = this.sourceFileToSeenSymbols[sourceId] || (this.sourceFileToSeenSymbols[sourceId] = /* @__PURE__ */ new Set());
+            let anyNewSymbols = false;
+            for (const sym of symbols) {
+              anyNewSymbols = tryAddToSet(seenSymbols, getSymbolId(sym)) || anyNewSymbols;
+            }
+            return anyNewSymbols;
+          }
         }
-        if (currentToken.parent === location) {
-          switch (currentToken.kind) {
-            case 32 /* GreaterThanToken */:
-              if (currentToken.parent.kind === 283 /* JsxElement */ || currentToken.parent.kind === 285 /* JsxOpeningElement */) {
-                location = currentToken;
+        function searchForImportsOfExport(exportLocation, exportSymbol, exportInfo, state) {
+          const { importSearches, singleReferences, indirectUsers } = state.getImportSearches(exportSymbol, exportInfo);
+          if (singleReferences.length) {
+            const addRef = state.referenceAdder(exportSymbol);
+            for (const singleRef of singleReferences) {
+              if (shouldAddSingleReference(singleRef, state))
+                addRef(singleRef);
+            }
+          }
+          for (const [importLocation, importSymbol] of importSearches) {
+            getReferencesInSourceFile(importLocation.getSourceFile(), state.createSearch(importLocation, importSymbol, 1 /* Export */), state);
+          }
+          if (indirectUsers.length) {
+            let indirectSearch;
+            switch (exportInfo.exportKind) {
+              case 0 /* Named */:
+                indirectSearch = state.createSearch(exportLocation, exportSymbol, 1 /* Export */);
+                break;
+              case 1 /* Default */:
+                indirectSearch = state.options.use === 2 /* Rename */ ? void 0 : state.createSearch(exportLocation, exportSymbol, 1 /* Export */, { text: "default" });
+                break;
+              case 2 /* ExportEquals */:
+                break;
+            }
+            if (indirectSearch) {
+              for (const indirectUser of indirectUsers) {
+                searchForName(indirectUser, indirectSearch, state);
               }
-              break;
-            case 44 /* SlashToken */:
-              if (currentToken.parent.kind === 284 /* JsxSelfClosingElement */) {
-                location = currentToken;
+            }
+          }
+        }
+        function eachExportReference(sourceFiles, checker, cancellationToken, exportSymbol, exportingModuleSymbol, exportName, isDefaultExport, cb) {
+          const importTracker = createImportTracker(sourceFiles, new Set(sourceFiles.map((f) => f.fileName)), checker, cancellationToken);
+          const { importSearches, indirectUsers, singleReferences } = importTracker(
+            exportSymbol,
+            { exportKind: isDefaultExport ? 1 /* Default */ : 0 /* Named */, exportingModuleSymbol },
+            /*isForRename*/
+            false
+          );
+          for (const [importLocation] of importSearches) {
+            cb(importLocation);
+          }
+          for (const singleReference of singleReferences) {
+            if (isIdentifier(singleReference) && isImportTypeNode(singleReference.parent)) {
+              cb(singleReference);
+            }
+          }
+          for (const indirectUser of indirectUsers) {
+            for (const node of getPossibleSymbolReferenceNodes(indirectUser, isDefaultExport ? "default" : exportName)) {
+              const symbol = checker.getSymbolAtLocation(node);
+              const hasExportAssignmentDeclaration = some(symbol == null ? void 0 : symbol.declarations, (d) => tryCast(d, isExportAssignment) ? true : false);
+              if (isIdentifier(node) && !isImportOrExportSpecifier(node.parent) && (symbol === exportSymbol || hasExportAssignmentDeclaration)) {
+                cb(node);
               }
-              break;
+            }
           }
         }
-        switch (parent2.kind) {
-          case 286 /* JsxClosingElement */:
-            if (contextToken.kind === 44 /* SlashToken */) {
-              isStartingCloseTag = true;
-              location = contextToken;
+        Core2.eachExportReference = eachExportReference;
+        function shouldAddSingleReference(singleRef, state) {
+          if (!hasMatchingMeaning(singleRef, state))
+            return false;
+          if (state.options.use !== 2 /* Rename */)
+            return true;
+          if (!isIdentifier(singleRef))
+            return false;
+          return !(isImportOrExportSpecifier(singleRef.parent) && singleRef.escapedText === "default" /* Default */);
+        }
+        function searchForImportedSymbol(symbol, state) {
+          if (!symbol.declarations)
+            return;
+          for (const declaration of symbol.declarations) {
+            const exportingFile = declaration.getSourceFile();
+            getReferencesInSourceFile(exportingFile, state.createSearch(declaration, symbol, 0 /* Import */), state, state.includesSourceFile(exportingFile));
+          }
+        }
+        function searchForName(sourceFile, search, state) {
+          if (getNameTable(sourceFile).get(search.escapedText) !== void 0) {
+            getReferencesInSourceFile(sourceFile, search, state);
+          }
+        }
+        function getPropertySymbolOfDestructuringAssignment(location, checker) {
+          return isArrayLiteralOrObjectLiteralDestructuringPattern(location.parent.parent) ? checker.getPropertySymbolOfDestructuringAssignment(location) : void 0;
+        }
+        function getSymbolScope(symbol) {
+          const { declarations, flags, parent: parent2, valueDeclaration } = symbol;
+          if (valueDeclaration && (valueDeclaration.kind === 218 /* FunctionExpression */ || valueDeclaration.kind === 231 /* ClassExpression */)) {
+            return valueDeclaration;
+          }
+          if (!declarations) {
+            return void 0;
+          }
+          if (flags & (4 /* Property */ | 8192 /* Method */)) {
+            const privateDeclaration = find(declarations, (d) => hasEffectiveModifier(d, 2 /* Private */) || isPrivateIdentifierClassElementDeclaration(d));
+            if (privateDeclaration) {
+              return getAncestor(privateDeclaration, 263 /* ClassDeclaration */);
             }
-            break;
-          case 225 /* BinaryExpression */:
-            if (!binaryExpressionMayBeOpenTag(parent2)) {
-              break;
+            return void 0;
+          }
+          if (declarations.some(isObjectBindingElementWithoutPropertyName)) {
+            return void 0;
+          }
+          const exposedByParent = parent2 && !(symbol.flags & 262144 /* TypeParameter */);
+          if (exposedByParent && !(isExternalModuleSymbol(parent2) && !parent2.globalExports)) {
+            return void 0;
+          }
+          let scope;
+          for (const declaration of declarations) {
+            const container = getContainerNode(declaration);
+            if (scope && scope !== container) {
+              return void 0;
             }
-          case 284 /* JsxSelfClosingElement */:
-          case 283 /* JsxElement */:
-          case 285 /* JsxOpeningElement */:
-            isJsxIdentifierExpected = true;
-            if (contextToken.kind === 30 /* LessThanToken */) {
-              isRightOfOpenTag = true;
-              location = contextToken;
+            if (!container || container.kind === 312 /* SourceFile */ && !isExternalOrCommonJsModule(container)) {
+              return void 0;
             }
-            break;
-          case 293 /* JsxExpression */:
-          case 292 /* JsxSpreadAttribute */:
-            if (previousToken.kind === 20 /* CloseBraceToken */ || previousToken.kind === 80 /* Identifier */ && previousToken.parent.kind === 290 /* JsxAttribute */) {
-              isJsxIdentifierExpected = true;
+            scope = container;
+            if (isFunctionExpression(scope)) {
+              let next;
+              while (next = getNextJSDocCommentLocation(scope)) {
+                scope = next;
+              }
             }
-            break;
-          case 290 /* JsxAttribute */:
-            if (parent2.initializer === previousToken && previousToken.end < position) {
-              isJsxIdentifierExpected = true;
-              break;
+          }
+          return exposedByParent ? scope.getSourceFile() : scope;
+        }
+        function isSymbolReferencedInFile(definition, checker, sourceFile, searchContainer = sourceFile) {
+          return eachSymbolReferenceInFile(definition, checker, sourceFile, () => true, searchContainer) || false;
+        }
+        Core2.isSymbolReferencedInFile = isSymbolReferencedInFile;
+        function eachSymbolReferenceInFile(definition, checker, sourceFile, cb, searchContainer = sourceFile) {
+          const symbol = isParameterPropertyDeclaration(definition.parent, definition.parent.parent) ? first(checker.getSymbolsOfParameterPropertyDeclaration(definition.parent, definition.text)) : checker.getSymbolAtLocation(definition);
+          if (!symbol)
+            return void 0;
+          for (const token of getPossibleSymbolReferenceNodes(sourceFile, symbol.name, searchContainer)) {
+            if (!isIdentifier(token) || token === definition || token.escapedText !== definition.escapedText)
+              continue;
+            const referenceSymbol = checker.getSymbolAtLocation(token);
+            if (referenceSymbol === symbol || checker.getShorthandAssignmentValueSymbol(token.parent) === symbol || isExportSpecifier(token.parent) && getLocalSymbolForExportSpecifier(token, referenceSymbol, token.parent, checker) === symbol) {
+              const res = cb(token);
+              if (res)
+                return res;
             }
-            switch (previousToken.kind) {
-              case 64 /* EqualsToken */:
-                isJsxInitializer = true;
-                break;
-              case 80 /* Identifier */:
-                isJsxIdentifierExpected = true;
-                if (parent2 !== previousToken.parent && !parent2.initializer && findChildOfKind(parent2, 64 /* EqualsToken */, sourceFile)) {
-                  isJsxInitializer = previousToken;
-                }
+          }
+        }
+        Core2.eachSymbolReferenceInFile = eachSymbolReferenceInFile;
+        function getTopMostDeclarationNamesInFile(declarationName, sourceFile) {
+          const candidates = filter(getPossibleSymbolReferenceNodes(sourceFile, declarationName), (name) => !!getDeclarationFromName(name));
+          return candidates.reduce((topMost, decl) => {
+            const depth = getDepth(decl);
+            if (!some(topMost.declarationNames) || depth === topMost.depth) {
+              topMost.declarationNames.push(decl);
+              topMost.depth = depth;
+            } else if (depth < topMost.depth) {
+              topMost.declarationNames = [decl];
+              topMost.depth = depth;
             }
-            break;
+            return topMost;
+          }, { depth: Infinity, declarationNames: [] }).declarationNames;
+          function getDepth(declaration) {
+            let depth = 0;
+            while (declaration) {
+              declaration = getContainerNode(declaration);
+              depth++;
+            }
+            return depth;
+          }
         }
-      }
-    }
-    const semanticStart = timestamp();
-    let completionKind = 5 /* None */;
-    let isNonContextualObjectLiteral = false;
-    let hasUnresolvedAutoImports = false;
-    let symbols = [];
-    let importSpecifierResolver;
-    const symbolToOriginInfoMap = [];
-    const symbolToSortTextMap = [];
-    const seenPropertySymbols = /* @__PURE__ */ new Map();
-    const isTypeOnlyLocation = isTypeOnlyCompletion();
-    const getModuleSpecifierResolutionHost = memoizeOne((isFromPackageJson) => {
-      return createModuleSpecifierResolutionHost(isFromPackageJson ? host.getPackageJsonAutoImportProvider() : program, host);
-    });
-    if (isRightOfDot || isRightOfQuestionDot) {
-      getTypeScriptMemberSymbols();
-    } else if (isRightOfOpenTag) {
-      symbols = typeChecker.getJsxIntrinsicTagNamesAt(location);
-      Debug.assertEachIsDefined(symbols, "getJsxIntrinsicTagNames() should all be defined");
-      tryGetGlobalSymbols();
-      completionKind = 1 /* Global */;
-      keywordFilters = 0 /* None */;
-    } else if (isStartingCloseTag) {
-      const tagName = contextToken.parent.parent.openingElement.tagName;
-      const tagSymbol = typeChecker.getSymbolAtLocation(tagName);
-      if (tagSymbol) {
-        symbols = [tagSymbol];
-      }
-      completionKind = 1 /* Global */;
-      keywordFilters = 0 /* None */;
-    } else {
-      if (!tryGetGlobalSymbols()) {
-        return keywordFilters ? keywordCompletionData(keywordFilters, isJsOnlyLocation, isNewIdentifierLocation) : void 0;
-      }
-    }
-    log("getCompletionData: Semantic work: " + (timestamp() - semanticStart));
-    const contextualType = previousToken && getContextualType(previousToken, position, sourceFile, typeChecker);
-    const isLiteralExpected = !tryCast(previousToken, isStringLiteralLike) && !isJsxIdentifierExpected;
-    const literals = !isLiteralExpected ? [] : mapDefined(
-      contextualType && (contextualType.isUnion() ? contextualType.types : [contextualType]),
-      (t) => t.isLiteral() && !(t.flags & 1024 /* EnumLiteral */) ? t.value : void 0
-    );
-    const recommendedCompletion = previousToken && contextualType && getRecommendedCompletion(previousToken, contextualType, typeChecker);
-    return {
-      kind: 0 /* Data */,
-      symbols,
-      completionKind,
-      isInSnippetScope,
-      propertyAccessToConvert,
-      isNewIdentifierLocation,
-      location,
-      keywordFilters,
-      literals,
-      symbolToOriginInfoMap,
-      recommendedCompletion,
-      previousToken,
-      contextToken,
-      isJsxInitializer,
-      insideJsDocTagTypeExpression,
-      symbolToSortTextMap,
-      isTypeOnlyLocation,
-      isJsxIdentifierExpected,
-      isRightOfOpenTag,
-      isRightOfDotOrQuestionDot: isRightOfDot || isRightOfQuestionDot,
-      importStatementCompletion,
-      hasUnresolvedAutoImports,
-      flags
-    };
-    function isTagWithTypeExpression(tag) {
-      switch (tag.kind) {
-        case 347 /* JSDocParameterTag */:
-        case 354 /* JSDocPropertyTag */:
-        case 348 /* JSDocReturnTag */:
-        case 350 /* JSDocTypeTag */:
-        case 352 /* JSDocTypedefTag */:
-        case 355 /* JSDocThrowsTag */:
-        case 356 /* JSDocSatisfiesTag */:
-          return true;
-        case 351 /* JSDocTemplateTag */:
-          return !!tag.constraint;
-        default:
-          return false;
-      }
-    }
-    function tryGetTypeExpressionFromTag(tag) {
-      if (isTagWithTypeExpression(tag)) {
-        const typeExpression = isJSDocTemplateTag(tag) ? tag.constraint : tag.typeExpression;
-        return typeExpression && typeExpression.kind === 315 /* JSDocTypeExpression */ ? typeExpression : void 0;
-      }
-      if (isJSDocAugmentsTag(tag) || isJSDocImplementsTag(tag)) {
-        return tag.class;
-      }
-      return void 0;
-    }
-    function getTypeScriptMemberSymbols() {
-      completionKind = 2 /* PropertyAccess */;
-      const isImportType = isLiteralImportTypeNode(node);
-      const isTypeLocation = isImportType && !node.isTypeOf || isPartOfTypeNode(node.parent) || isPossiblyTypeArgumentPosition(contextToken, sourceFile, typeChecker);
-      const isRhsOfImportDeclaration = isInRightSideOfInternalImportEqualsDeclaration(node);
-      if (isEntityName(node) || isImportType || isPropertyAccessExpression(node)) {
-        const isNamespaceName = isModuleDeclaration(node.parent);
-        if (isNamespaceName)
-          isNewIdentifierLocation = true;
-        let symbol = typeChecker.getSymbolAtLocation(node);
-        if (symbol) {
-          symbol = skipAlias(symbol, typeChecker);
-          if (symbol.flags & (1536 /* Module */ | 384 /* Enum */)) {
-            const exportedSymbols = typeChecker.getExportsOfModule(symbol);
-            Debug.assertEachIsDefined(exportedSymbols, "getExportsOfModule() should all be defined");
-            const isValidValueAccess = (symbol2) => typeChecker.isValidPropertyAccess(isImportType ? node : node.parent, symbol2.name);
-            const isValidTypeAccess = (symbol2) => symbolCanBeReferencedAtTypeLocation(symbol2, typeChecker);
-            const isValidAccess = isNamespaceName ? (symbol2) => {
-              var _a;
-              return !!(symbol2.flags & 1920 /* Namespace */) && !((_a = symbol2.declarations) == null ? void 0 : _a.every((d) => d.parent === node.parent));
-            } : isRhsOfImportDeclaration ? (
-              // Any kind is allowed when dotting off namespace in internal import equals declaration
-              (symbol2) => isValidTypeAccess(symbol2) || isValidValueAccess(symbol2)
-            ) : isTypeLocation || insideJsDocTagTypeExpression ? isValidTypeAccess : isValidValueAccess;
-            for (const exportedSymbol of exportedSymbols) {
-              if (isValidAccess(exportedSymbol)) {
-                symbols.push(exportedSymbol);
+        Core2.getTopMostDeclarationNamesInFile = getTopMostDeclarationNamesInFile;
+        function someSignatureUsage(signature, sourceFiles, checker, cb) {
+          if (!signature.name || !isIdentifier(signature.name))
+            return false;
+          const symbol = Debug.checkDefined(checker.getSymbolAtLocation(signature.name));
+          for (const sourceFile of sourceFiles) {
+            for (const name of getPossibleSymbolReferenceNodes(sourceFile, symbol.name)) {
+              if (!isIdentifier(name) || name === signature.name || name.escapedText !== signature.name.escapedText)
+                continue;
+              const called = climbPastPropertyAccess(name);
+              const call = isCallExpression(called.parent) && called.parent.expression === called ? called.parent : void 0;
+              const referenceSymbol = checker.getSymbolAtLocation(name);
+              if (referenceSymbol && checker.getRootSymbols(referenceSymbol).some((s) => s === symbol)) {
+                if (cb(name, call)) {
+                  return true;
+                }
               }
             }
-            if (!isTypeLocation && !insideJsDocTagTypeExpression && symbol.declarations && symbol.declarations.some((d) => d.kind !== 311 /* SourceFile */ && d.kind !== 266 /* ModuleDeclaration */ && d.kind !== 265 /* EnumDeclaration */)) {
-              let type = typeChecker.getTypeOfSymbolAtLocation(symbol, node).getNonOptionalType();
-              let insertQuestionDot = false;
-              if (type.isNullableType()) {
-                const canCorrectToQuestionDot = isRightOfDot && !isRightOfQuestionDot && preferences.includeAutomaticOptionalChainCompletions !== false;
-                if (canCorrectToQuestionDot || isRightOfQuestionDot) {
-                  type = type.getNonNullableType();
-                  if (canCorrectToQuestionDot) {
-                    insertQuestionDot = true;
-                  }
-                }
+          }
+          return false;
+        }
+        Core2.someSignatureUsage = someSignatureUsage;
+        function getPossibleSymbolReferenceNodes(sourceFile, symbolName2, container = sourceFile) {
+          return mapDefined(getPossibleSymbolReferencePositions(sourceFile, symbolName2, container), (pos) => {
+            const referenceLocation = getTouchingPropertyName(sourceFile, pos);
+            return referenceLocation === sourceFile ? void 0 : referenceLocation;
+          });
+        }
+        function getPossibleSymbolReferencePositions(sourceFile, symbolName2, container = sourceFile) {
+          const positions = [];
+          if (!symbolName2 || !symbolName2.length) {
+            return positions;
+          }
+          const text = sourceFile.text;
+          const sourceLength = text.length;
+          const symbolNameLength = symbolName2.length;
+          let position = text.indexOf(symbolName2, container.pos);
+          while (position >= 0) {
+            if (position > container.end)
+              break;
+            const endPosition = position + symbolNameLength;
+            if ((position === 0 || !isIdentifierPart(text.charCodeAt(position - 1), 99 /* Latest */)) && (endPosition === sourceLength || !isIdentifierPart(text.charCodeAt(endPosition), 99 /* Latest */))) {
+              positions.push(position);
+            }
+            position = text.indexOf(symbolName2, position + symbolNameLength + 1);
+          }
+          return positions;
+        }
+        function getLabelReferencesInNode(container, targetLabel) {
+          const sourceFile = container.getSourceFile();
+          const labelName = targetLabel.text;
+          const references = mapDefined(getPossibleSymbolReferenceNodes(sourceFile, labelName, container), (node) => (
+            // Only pick labels that are either the target label, or have a target that is the target label
+            node === targetLabel || isJumpStatementTarget(node) && getTargetLabel(node, labelName) === targetLabel ? nodeEntry(node) : void 0
+          ));
+          return [{ definition: { type: 1 /* Label */, node: targetLabel }, references }];
+        }
+        function isValidReferencePosition(node, searchSymbolName) {
+          switch (node.kind) {
+            case 81 /* PrivateIdentifier */:
+              if (isJSDocMemberName(node.parent)) {
+                return true;
               }
-              addTypeProperties(type, !!(node.flags & 32768 /* AwaitContext */), insertQuestionDot);
+            case 80 /* Identifier */:
+              return node.text.length === searchSymbolName.length;
+            case 15 /* NoSubstitutionTemplateLiteral */:
+            case 11 /* StringLiteral */: {
+              const str = node;
+              return (isLiteralNameOfPropertyDeclarationOrIndexAccess(str) || isNameOfModuleDeclaration(node) || isExpressionOfExternalModuleImportEqualsDeclaration(node) || isCallExpression(node.parent) && isBindableObjectDefinePropertyCall(node.parent) && node.parent.arguments[1] === node) && str.text.length === searchSymbolName.length;
             }
+            case 9 /* NumericLiteral */:
+              return isLiteralNameOfPropertyDeclarationOrIndexAccess(node) && node.text.length === searchSymbolName.length;
+            case 90 /* DefaultKeyword */:
+              return "default".length === searchSymbolName.length;
+            default:
+              return false;
+          }
+        }
+        function getAllReferencesForImportMeta(sourceFiles, cancellationToken) {
+          const references = flatMap(sourceFiles, (sourceFile) => {
+            cancellationToken.throwIfCancellationRequested();
+            return mapDefined(getPossibleSymbolReferenceNodes(sourceFile, "meta", sourceFile), (node) => {
+              const parent2 = node.parent;
+              if (isImportMeta(parent2)) {
+                return nodeEntry(parent2);
+              }
+            });
+          });
+          return references.length ? [{ definition: { type: 2 /* Keyword */, node: references[0].node }, references }] : void 0;
+        }
+        function getAllReferencesForKeyword(sourceFiles, keywordKind, cancellationToken, filter2) {
+          const references = flatMap(sourceFiles, (sourceFile) => {
+            cancellationToken.throwIfCancellationRequested();
+            return mapDefined(getPossibleSymbolReferenceNodes(sourceFile, tokenToString(keywordKind), sourceFile), (referenceLocation) => {
+              if (referenceLocation.kind === keywordKind && (!filter2 || filter2(referenceLocation))) {
+                return nodeEntry(referenceLocation);
+              }
+            });
+          });
+          return references.length ? [{ definition: { type: 2 /* Keyword */, node: references[0].node }, references }] : void 0;
+        }
+        function getReferencesInSourceFile(sourceFile, search, state, addReferencesHere = true) {
+          state.cancellationToken.throwIfCancellationRequested();
+          return getReferencesInContainer(sourceFile, sourceFile, search, state, addReferencesHere);
+        }
+        function getReferencesInContainer(container, sourceFile, search, state, addReferencesHere) {
+          if (!state.markSearchedSymbols(sourceFile, search.allSearchSymbols)) {
             return;
           }
+          for (const position of getPossibleSymbolReferencePositions(sourceFile, search.text, container)) {
+            getReferencesAtLocation(sourceFile, position, search, state, addReferencesHere);
+          }
         }
-      }
-      if (!isTypeLocation) {
-        typeChecker.tryGetThisTypeAt(
-          node,
-          /*includeGlobalThis*/
-          false
-        );
-        let type = typeChecker.getTypeAtLocation(node).getNonOptionalType();
-        let insertQuestionDot = false;
-        if (type.isNullableType()) {
-          const canCorrectToQuestionDot = isRightOfDot && !isRightOfQuestionDot && preferences.includeAutomaticOptionalChainCompletions !== false;
-          if (canCorrectToQuestionDot || isRightOfQuestionDot) {
-            type = type.getNonNullableType();
-            if (canCorrectToQuestionDot) {
-              insertQuestionDot = true;
+        function hasMatchingMeaning(referenceLocation, state) {
+          return !!(getMeaningFromLocation(referenceLocation) & state.searchMeaning);
+        }
+        function getReferencesAtLocation(sourceFile, position, search, state, addReferencesHere) {
+          const referenceLocation = getTouchingPropertyName(sourceFile, position);
+          if (!isValidReferencePosition(referenceLocation, search.text)) {
+            if (!state.options.implementations && (state.options.findInStrings && isInString(sourceFile, position) || state.options.findInComments && isInNonReferenceComment(sourceFile, position))) {
+              state.addStringOrCommentReference(sourceFile.fileName, createTextSpan(position, search.text.length));
             }
+            return;
           }
-        }
-        addTypeProperties(type, !!(node.flags & 32768 /* AwaitContext */), insertQuestionDot);
-      }
-    }
-    function addTypeProperties(type, insertAwait, insertQuestionDot) {
-      isNewIdentifierLocation = !!type.getStringIndexType();
-      if (isRightOfQuestionDot && some(type.getCallSignatures())) {
-        isNewIdentifierLocation = true;
-      }
-      const propertyAccess = node.kind === 204 /* ImportType */ ? node : node.parent;
-      if (inCheckedFile) {
-        for (const symbol of type.getApparentProperties()) {
-          if (typeChecker.isValidPropertyAccessForCompletions(propertyAccess, type, symbol)) {
-            addPropertySymbol(
-              symbol,
-              /*insertAwait*/
-              false,
-              insertQuestionDot
-            );
+          if (!hasMatchingMeaning(referenceLocation, state))
+            return;
+          let referenceSymbol = state.checker.getSymbolAtLocation(referenceLocation);
+          if (!referenceSymbol) {
+            return;
+          }
+          const parent2 = referenceLocation.parent;
+          if (isImportSpecifier(parent2) && parent2.propertyName === referenceLocation) {
+            return;
+          }
+          if (isExportSpecifier(parent2)) {
+            Debug.assert(referenceLocation.kind === 80 /* Identifier */);
+            getReferencesAtExportSpecifier(referenceLocation, referenceSymbol, parent2, search, state, addReferencesHere);
+            return;
+          }
+          const relatedSymbol = getRelatedSymbol(search, referenceSymbol, referenceLocation, state);
+          if (!relatedSymbol) {
+            getReferenceForShorthandProperty(referenceSymbol, search, state);
+            return;
+          }
+          switch (state.specialSearchKind) {
+            case 0 /* None */:
+              if (addReferencesHere)
+                addReference(referenceLocation, relatedSymbol, state);
+              break;
+            case 1 /* Constructor */:
+              addConstructorReferences(referenceLocation, sourceFile, search, state);
+              break;
+            case 2 /* Class */:
+              addClassStaticThisReferences(referenceLocation, search, state);
+              break;
+            default:
+              Debug.assertNever(state.specialSearchKind);
+          }
+          if (isInJSFile(referenceLocation) && isBindingElement(referenceLocation.parent) && isVariableDeclarationInitializedToBareOrAccessedRequire(referenceLocation.parent.parent.parent)) {
+            referenceSymbol = referenceLocation.parent.symbol;
+            if (!referenceSymbol)
+              return;
           }
+          getImportOrExportReferences(referenceLocation, referenceSymbol, search, state);
         }
-      } else {
-        symbols.push(...filter(getPropertiesForCompletion(type, typeChecker), (s) => typeChecker.isValidPropertyAccessForCompletions(propertyAccess, type, s)));
-      }
-      if (insertAwait && preferences.includeCompletionsWithInsertText) {
-        const promiseType = typeChecker.getPromisedTypeOfPromise(type);
-        if (promiseType) {
-          for (const symbol of promiseType.getApparentProperties()) {
-            if (typeChecker.isValidPropertyAccessForCompletions(propertyAccess, promiseType, symbol)) {
-              addPropertySymbol(
-                symbol,
-                /*insertAwait*/
-                true,
-                insertQuestionDot
-              );
+        function getReferencesAtExportSpecifier(referenceLocation, referenceSymbol, exportSpecifier, search, state, addReferencesHere, alwaysGetReferences) {
+          Debug.assert(!alwaysGetReferences || !!state.options.providePrefixAndSuffixTextForRename, "If alwaysGetReferences is true, then prefix/suffix text must be enabled");
+          const { parent: parent2, propertyName, name } = exportSpecifier;
+          const exportDeclaration = parent2.parent;
+          const localSymbol = getLocalSymbolForExportSpecifier(referenceLocation, referenceSymbol, exportSpecifier, state.checker);
+          if (!alwaysGetReferences && !search.includes(localSymbol)) {
+            return;
+          }
+          if (!propertyName) {
+            if (!(state.options.use === 2 /* Rename */ && name.escapedText === "default" /* Default */)) {
+              addRef();
+            }
+          } else if (referenceLocation === propertyName) {
+            if (!exportDeclaration.moduleSpecifier) {
+              addRef();
+            }
+            if (addReferencesHere && state.options.use !== 2 /* Rename */ && state.markSeenReExportRHS(name)) {
+              addReference(name, Debug.checkDefined(exportSpecifier.symbol), state);
+            }
+          } else {
+            if (state.markSeenReExportRHS(referenceLocation)) {
+              addRef();
+            }
+          }
+          if (!isForRenameWithPrefixAndSuffixText(state.options) || alwaysGetReferences) {
+            const isDefaultExport = referenceLocation.escapedText === "default" || exportSpecifier.name.escapedText === "default";
+            const exportKind = isDefaultExport ? 1 /* Default */ : 0 /* Named */;
+            const exportSymbol = Debug.checkDefined(exportSpecifier.symbol);
+            const exportInfo = getExportInfo(exportSymbol, exportKind, state.checker);
+            if (exportInfo) {
+              searchForImportsOfExport(referenceLocation, exportSymbol, exportInfo, state);
             }
           }
+          if (search.comingFrom !== 1 /* Export */ && exportDeclaration.moduleSpecifier && !propertyName && !isForRenameWithPrefixAndSuffixText(state.options)) {
+            const imported = state.checker.getExportSpecifierLocalTargetSymbol(exportSpecifier);
+            if (imported)
+              searchForImportedSymbol(imported, state);
+          }
+          function addRef() {
+            if (addReferencesHere)
+              addReference(referenceLocation, localSymbol, state);
+          }
         }
-      }
-    }
-    function addPropertySymbol(symbol, insertAwait, insertQuestionDot) {
-      var _a;
-      const computedPropertyName = firstDefined(symbol.declarations, (decl) => tryCast(getNameOfDeclaration(decl), isComputedPropertyName));
-      if (computedPropertyName) {
-        const leftMostName = getLeftMostName(computedPropertyName.expression);
-        const nameSymbol = leftMostName && typeChecker.getSymbolAtLocation(leftMostName);
-        const firstAccessibleSymbol = nameSymbol && getFirstSymbolInChain(nameSymbol, contextToken, typeChecker);
-        if (firstAccessibleSymbol && addToSeen(seenPropertySymbols, getSymbolId(firstAccessibleSymbol))) {
-          const index = symbols.length;
-          symbols.push(firstAccessibleSymbol);
-          const moduleSymbol = firstAccessibleSymbol.parent;
-          if (!moduleSymbol || !isExternalModuleSymbol(moduleSymbol) || typeChecker.tryGetMemberInModuleExportsAndProperties(firstAccessibleSymbol.name, moduleSymbol) !== firstAccessibleSymbol) {
-            symbolToOriginInfoMap[index] = { kind: getNullableSymbolOriginInfoKind(2 /* SymbolMemberNoExport */) };
+        function getLocalSymbolForExportSpecifier(referenceLocation, referenceSymbol, exportSpecifier, checker) {
+          return isExportSpecifierAlias(referenceLocation, exportSpecifier) && checker.getExportSpecifierLocalTargetSymbol(exportSpecifier) || referenceSymbol;
+        }
+        function isExportSpecifierAlias(referenceLocation, exportSpecifier) {
+          const { parent: parent2, propertyName, name } = exportSpecifier;
+          Debug.assert(propertyName === referenceLocation || name === referenceLocation);
+          if (propertyName) {
+            return propertyName === referenceLocation;
           } else {
-            const fileName = isExternalModuleNameRelative(stripQuotes(moduleSymbol.name)) ? (_a = getSourceFileOfModule(moduleSymbol)) == null ? void 0 : _a.fileName : void 0;
-            const { moduleSpecifier } = (importSpecifierResolver || (importSpecifierResolver = ts_codefix_exports.createImportSpecifierResolver(sourceFile, program, host, preferences))).getModuleSpecifierForBestExportInfo([{
-              exportKind: 0 /* Named */,
-              moduleFileName: fileName,
-              isFromPackageJson: false,
-              moduleSymbol,
-              symbol: firstAccessibleSymbol,
-              targetFlags: skipAlias(firstAccessibleSymbol, typeChecker).flags
-            }], position, isValidTypeOnlyAliasUseSite(location)) || {};
-            if (moduleSpecifier) {
-              const origin = {
-                kind: getNullableSymbolOriginInfoKind(6 /* SymbolMemberExport */),
-                moduleSymbol,
-                isDefaultExport: false,
-                symbolName: firstAccessibleSymbol.name,
-                exportName: firstAccessibleSymbol.name,
-                fileName,
-                moduleSpecifier
-              };
-              symbolToOriginInfoMap[index] = origin;
+            return !parent2.parent.moduleSpecifier;
+          }
+        }
+        function getImportOrExportReferences(referenceLocation, referenceSymbol, search, state) {
+          const importOrExport = getImportOrExportSymbol(referenceLocation, referenceSymbol, state.checker, search.comingFrom === 1 /* Export */);
+          if (!importOrExport)
+            return;
+          const { symbol } = importOrExport;
+          if (importOrExport.kind === 0 /* Import */) {
+            if (!isForRenameWithPrefixAndSuffixText(state.options)) {
+              searchForImportedSymbol(symbol, state);
             }
+          } else {
+            searchForImportsOfExport(referenceLocation, symbol, importOrExport.exportInfo, state);
           }
-        } else if (preferences.includeCompletionsWithInsertText) {
-          addSymbolOriginInfo(symbol);
-          addSymbolSortInfo(symbol);
-          symbols.push(symbol);
         }
-      } else {
-        addSymbolOriginInfo(symbol);
-        addSymbolSortInfo(symbol);
-        symbols.push(symbol);
-      }
-      function addSymbolSortInfo(symbol2) {
-        if (isStaticProperty(symbol2)) {
-          symbolToSortTextMap[getSymbolId(symbol2)] = SortText.LocalDeclarationPriority;
+        function getReferenceForShorthandProperty({ flags, valueDeclaration }, search, state) {
+          const shorthandValueSymbol = state.checker.getShorthandAssignmentValueSymbol(valueDeclaration);
+          const name = valueDeclaration && getNameOfDeclaration(valueDeclaration);
+          if (!(flags & 33554432 /* Transient */) && name && search.includes(shorthandValueSymbol)) {
+            addReference(name, shorthandValueSymbol, state);
+          }
         }
-      }
-      function addSymbolOriginInfo(symbol2) {
-        if (preferences.includeCompletionsWithInsertText) {
-          if (insertAwait && addToSeen(seenPropertySymbols, getSymbolId(symbol2))) {
-            symbolToOriginInfoMap[symbols.length] = { kind: getNullableSymbolOriginInfoKind(8 /* Promise */) };
-          } else if (insertQuestionDot) {
-            symbolToOriginInfoMap[symbols.length] = { kind: 16 /* Nullable */ };
+        function addReference(referenceLocation, relatedSymbol, state) {
+          const { kind, symbol } = "kind" in relatedSymbol ? relatedSymbol : { kind: void 0, symbol: relatedSymbol };
+          if (state.options.use === 2 /* Rename */ && referenceLocation.kind === 90 /* DefaultKeyword */) {
+            return;
+          }
+          const addRef = state.referenceAdder(symbol);
+          if (state.options.implementations) {
+            addImplementationReferences(referenceLocation, addRef, state);
+          } else {
+            addRef(referenceLocation, kind);
           }
         }
-      }
-      function getNullableSymbolOriginInfoKind(kind) {
-        return insertQuestionDot ? kind | 16 /* Nullable */ : kind;
-      }
-    }
-    function getLeftMostName(e) {
-      return isIdentifier(e) ? e : isPropertyAccessExpression(e) ? getLeftMostName(e.expression) : void 0;
-    }
-    function tryGetGlobalSymbols() {
-      const result = tryGetObjectTypeLiteralInTypeArgumentCompletionSymbols() || tryGetObjectLikeCompletionSymbols() || tryGetImportCompletionSymbols() || tryGetImportOrExportClauseCompletionSymbols() || tryGetLocalNamedExportCompletionSymbols() || tryGetConstructorCompletion() || tryGetClassLikeCompletionSymbols() || tryGetJsxCompletionSymbols() || (getGlobalCompletions(), 1 /* Success */);
-      return result === 1 /* Success */;
-    }
-    function tryGetConstructorCompletion() {
-      if (!tryGetConstructorLikeCompletionContainer(contextToken))
-        return 0 /* Continue */;
-      completionKind = 5 /* None */;
-      isNewIdentifierLocation = true;
-      keywordFilters = 4 /* ConstructorParameterKeywords */;
-      return 1 /* Success */;
-    }
-    function tryGetJsxCompletionSymbols() {
-      const jsxContainer = tryGetContainingJsxElement(contextToken);
-      const attrsType = jsxContainer && typeChecker.getContextualType(jsxContainer.attributes);
-      if (!attrsType)
-        return 0 /* Continue */;
-      const completionsType = jsxContainer && typeChecker.getContextualType(jsxContainer.attributes, 4 /* Completions */);
-      symbols = concatenate(symbols, filterJsxAttributes(getPropertiesForObjectExpression(attrsType, completionsType, jsxContainer.attributes, typeChecker), jsxContainer.attributes.properties));
-      setSortTextToOptionalMember();
-      completionKind = 3 /* MemberLike */;
-      isNewIdentifierLocation = false;
-      return 1 /* Success */;
-    }
-    function tryGetImportCompletionSymbols() {
-      if (!importStatementCompletion)
-        return 0 /* Continue */;
-      isNewIdentifierLocation = true;
-      collectAutoImports();
-      return 1 /* Success */;
-    }
-    function getGlobalCompletions() {
-      keywordFilters = tryGetFunctionLikeBodyCompletionContainer(contextToken) ? 5 /* FunctionLikeBodyKeywords */ : 1 /* All */;
-      completionKind = 1 /* Global */;
-      isNewIdentifierLocation = isNewIdentifierDefinitionLocation();
-      if (previousToken !== contextToken) {
-        Debug.assert(!!previousToken, "Expected 'contextToken' to be defined when different from 'previousToken'.");
-      }
-      const adjustedPosition = previousToken !== contextToken ? previousToken.getStart() : position;
-      const scopeNode = getScopeNode(contextToken, adjustedPosition, sourceFile) || sourceFile;
-      isInSnippetScope = isSnippetScope(scopeNode);
-      const symbolMeanings = (isTypeOnlyLocation ? 0 /* None */ : 111551 /* Value */) | 788968 /* Type */ | 1920 /* Namespace */ | 2097152 /* Alias */;
-      const typeOnlyAliasNeedsPromotion = previousToken && !isValidTypeOnlyAliasUseSite(previousToken);
-      symbols = concatenate(symbols, typeChecker.getSymbolsInScope(scopeNode, symbolMeanings));
-      Debug.assertEachIsDefined(symbols, "getSymbolsInScope() should all be defined");
-      for (let i = 0; i < symbols.length; i++) {
-        const symbol = symbols[i];
-        if (!typeChecker.isArgumentsSymbol(symbol) && !some(symbol.declarations, (d) => d.getSourceFile() === sourceFile)) {
-          symbolToSortTextMap[getSymbolId(symbol)] = SortText.GlobalsOrKeywords;
+        function addConstructorReferences(referenceLocation, sourceFile, search, state) {
+          if (isNewExpressionTarget(referenceLocation)) {
+            addReference(referenceLocation, search.symbol, state);
+          }
+          const pusher = () => state.referenceAdder(search.symbol);
+          if (isClassLike(referenceLocation.parent)) {
+            Debug.assert(referenceLocation.kind === 90 /* DefaultKeyword */ || referenceLocation.parent.name === referenceLocation);
+            findOwnConstructorReferences(search.symbol, sourceFile, pusher());
+          } else {
+            const classExtending = tryGetClassByExtendingIdentifier(referenceLocation);
+            if (classExtending) {
+              findSuperConstructorAccesses(classExtending, pusher());
+              findInheritedConstructorReferences(classExtending, state);
+            }
+          }
         }
-        if (typeOnlyAliasNeedsPromotion && !(symbol.flags & 111551 /* Value */)) {
-          const typeOnlyAliasDeclaration = symbol.declarations && find(symbol.declarations, isTypeOnlyImportDeclaration);
-          if (typeOnlyAliasDeclaration) {
-            const origin = { kind: 64 /* TypeOnlyAlias */, declaration: typeOnlyAliasDeclaration };
-            symbolToOriginInfoMap[i] = origin;
+        function addClassStaticThisReferences(referenceLocation, search, state) {
+          addReference(referenceLocation, search.symbol, state);
+          const classLike = referenceLocation.parent;
+          if (state.options.use === 2 /* Rename */ || !isClassLike(classLike))
+            return;
+          Debug.assert(classLike.name === referenceLocation);
+          const addRef = state.referenceAdder(search.symbol);
+          for (const member of classLike.members) {
+            if (!(isMethodOrAccessor(member) && isStatic(member))) {
+              continue;
+            }
+            if (member.body) {
+              member.body.forEachChild(function cb(node) {
+                if (node.kind === 110 /* ThisKeyword */) {
+                  addRef(node);
+                } else if (!isFunctionLike(node) && !isClassLike(node)) {
+                  node.forEachChild(cb);
+                }
+              });
+            }
           }
         }
-      }
-      if (preferences.includeCompletionsWithInsertText && scopeNode.kind !== 311 /* SourceFile */) {
-        const thisType = typeChecker.tryGetThisTypeAt(
-          scopeNode,
-          /*includeGlobalThis*/
-          false,
-          isClassLike(scopeNode.parent) ? scopeNode : void 0
-        );
-        if (thisType && !isProbablyGlobalType(thisType, sourceFile, typeChecker)) {
-          for (const symbol of getPropertiesForCompletion(thisType, typeChecker)) {
-            symbolToOriginInfoMap[symbols.length] = { kind: 1 /* ThisType */ };
-            symbols.push(symbol);
-            symbolToSortTextMap[getSymbolId(symbol)] = SortText.SuggestedClassMembers;
+        function findOwnConstructorReferences(classSymbol, sourceFile, addNode) {
+          const constructorSymbol = getClassConstructorSymbol(classSymbol);
+          if (constructorSymbol && constructorSymbol.declarations) {
+            for (const decl of constructorSymbol.declarations) {
+              const ctrKeyword = findChildOfKind(decl, 137 /* ConstructorKeyword */, sourceFile);
+              Debug.assert(decl.kind === 176 /* Constructor */ && !!ctrKeyword);
+              addNode(ctrKeyword);
+            }
+          }
+          if (classSymbol.exports) {
+            classSymbol.exports.forEach((member) => {
+              const decl = member.valueDeclaration;
+              if (decl && decl.kind === 174 /* MethodDeclaration */) {
+                const body = decl.body;
+                if (body) {
+                  forEachDescendantOfKind(body, 110 /* ThisKeyword */, (thisKeyword) => {
+                    if (isNewExpressionTarget(thisKeyword)) {
+                      addNode(thisKeyword);
+                    }
+                  });
+                }
+              }
+            });
           }
         }
-      }
-      collectAutoImports();
-      if (isTypeOnlyLocation) {
-        keywordFilters = contextToken && isAssertionExpression(contextToken.parent) ? 6 /* TypeAssertionKeywords */ : 7 /* TypeKeywords */;
-      }
-    }
-    function shouldOfferImportCompletions() {
-      if (importStatementCompletion)
-        return true;
-      if (isNonContextualObjectLiteral)
-        return false;
-      if (!preferences.includeCompletionsForModuleExports)
-        return false;
-      if (sourceFile.externalModuleIndicator || sourceFile.commonJsModuleIndicator)
-        return true;
-      if (compilerOptionsIndicateEsModules(program.getCompilerOptions()))
-        return true;
-      return programContainsModules(program);
-    }
-    function isSnippetScope(scopeNode) {
-      switch (scopeNode.kind) {
-        case 311 /* SourceFile */:
-        case 227 /* TemplateExpression */:
-        case 293 /* JsxExpression */:
-        case 240 /* Block */:
-          return true;
-        default:
-          return isStatement(scopeNode);
-      }
-    }
-    function isTypeOnlyCompletion() {
-      return insideJsDocTagTypeExpression || !!importStatementCompletion && isTypeOnlyImportOrExportDeclaration(location.parent) || !isContextTokenValueLocation(contextToken) && (isPossiblyTypeArgumentPosition(contextToken, sourceFile, typeChecker) || isPartOfTypeNode(location) || isContextTokenTypeLocation(contextToken));
-    }
-    function isContextTokenValueLocation(contextToken2) {
-      return contextToken2 && (contextToken2.kind === 114 /* TypeOfKeyword */ && (contextToken2.parent.kind === 185 /* TypeQuery */ || isTypeOfExpression(contextToken2.parent)) || contextToken2.kind === 131 /* AssertsKeyword */ && contextToken2.parent.kind === 181 /* TypePredicate */);
-    }
-    function isContextTokenTypeLocation(contextToken2) {
-      if (contextToken2) {
-        const parentKind = contextToken2.parent.kind;
-        switch (contextToken2.kind) {
-          case 59 /* ColonToken */:
-            return parentKind === 171 /* PropertyDeclaration */ || parentKind === 170 /* PropertySignature */ || parentKind === 168 /* Parameter */ || parentKind === 259 /* VariableDeclaration */ || isFunctionLikeKind(parentKind);
-          case 64 /* EqualsToken */:
-            return parentKind === 264 /* TypeAliasDeclaration */;
-          case 130 /* AsKeyword */:
-            return parentKind === 233 /* AsExpression */;
-          case 30 /* LessThanToken */:
-            return parentKind === 182 /* TypeReference */ || parentKind === 215 /* TypeAssertionExpression */;
-          case 96 /* ExtendsKeyword */:
-            return parentKind === 167 /* TypeParameter */;
-          case 152 /* SatisfiesKeyword */:
-            return parentKind === 237 /* SatisfiesExpression */;
+        function getClassConstructorSymbol(classSymbol) {
+          return classSymbol.members && classSymbol.members.get("__constructor" /* Constructor */);
         }
-      }
-      return false;
-    }
-    function collectAutoImports() {
-      var _a, _b;
-      if (!shouldOfferImportCompletions())
-        return;
-      Debug.assert(!(detailsEntryId == null ? void 0 : detailsEntryId.data), "Should not run 'collectAutoImports' when faster path is available via `data`");
-      if (detailsEntryId && !detailsEntryId.source) {
-        return;
-      }
-      flags |= 1 /* MayIncludeAutoImports */;
-      const isAfterTypeOnlyImportSpecifierModifier = previousToken === contextToken && importStatementCompletion;
-      const lowerCaseTokenText = isAfterTypeOnlyImportSpecifierModifier ? "" : previousToken && isIdentifier(previousToken) ? previousToken.text.toLowerCase() : "";
-      const moduleSpecifierCache = (_a = host.getModuleSpecifierCache) == null ? void 0 : _a.call(host);
-      const exportInfo = getExportInfoMap(sourceFile, host, program, preferences, cancellationToken);
-      const packageJsonAutoImportProvider = (_b = host.getPackageJsonAutoImportProvider) == null ? void 0 : _b.call(host);
-      const packageJsonFilter = detailsEntryId ? void 0 : createPackageJsonImportFilter(sourceFile, preferences, host);
-      resolvingModuleSpecifiers(
-        "collectAutoImports",
-        host,
-        importSpecifierResolver || (importSpecifierResolver = ts_codefix_exports.createImportSpecifierResolver(sourceFile, program, host, preferences)),
-        program,
-        position,
-        preferences,
-        !!importStatementCompletion,
-        isValidTypeOnlyAliasUseSite(location),
-        (context) => {
-          exportInfo.search(
-            sourceFile.path,
-            /*preferCapitalized*/
-            isRightOfOpenTag,
-            (symbolName2, targetFlags) => {
-              if (!isIdentifierText(symbolName2, getEmitScriptTarget(host.getCompilationSettings())))
-                return false;
-              if (!detailsEntryId && isStringANonContextualKeyword(symbolName2))
-                return false;
-              if (!isTypeOnlyLocation && !importStatementCompletion && !(targetFlags & 111551 /* Value */))
-                return false;
-              if (isTypeOnlyLocation && !(targetFlags & (1536 /* Module */ | 788968 /* Type */)))
-                return false;
-              const firstChar = symbolName2.charCodeAt(0);
-              if (isRightOfOpenTag && (firstChar < 65 /* A */ || firstChar > 90 /* Z */))
-                return false;
-              if (detailsEntryId)
-                return true;
-              return charactersFuzzyMatchInString(symbolName2, lowerCaseTokenText);
-            },
-            (info, symbolName2, isFromAmbientModule, exportMapKey) => {
-              if (detailsEntryId && !some(info, (i) => detailsEntryId.source === stripQuotes(i.moduleSymbol.name))) {
-                return;
-              }
-              info = filter(info, isImportableExportInfo);
-              if (!info.length) {
-                return;
-              }
-              const result = context.tryResolve(info, isFromAmbientModule) || {};
-              if (result === "failed")
-                return;
-              let exportInfo2 = info[0], moduleSpecifier;
-              if (result !== "skipped") {
-                ({ exportInfo: exportInfo2 = info[0], moduleSpecifier } = result);
-              }
-              const isDefaultExport = exportInfo2.exportKind === 1 /* Default */;
-              const symbol = isDefaultExport && getLocalSymbolForExportDefault(exportInfo2.symbol) || exportInfo2.symbol;
-              pushAutoImportSymbol(symbol, {
-                kind: moduleSpecifier ? 32 /* ResolvedExport */ : 4 /* Export */,
-                moduleSpecifier,
-                symbolName: symbolName2,
-                exportMapKey,
-                exportName: exportInfo2.exportKind === 2 /* ExportEquals */ ? "export=" /* ExportEquals */ : exportInfo2.symbol.name,
-                fileName: exportInfo2.moduleFileName,
-                isDefaultExport,
-                moduleSymbol: exportInfo2.moduleSymbol,
-                isFromPackageJson: exportInfo2.isFromPackageJson
+        function findSuperConstructorAccesses(classDeclaration, addNode) {
+          const constructor = getClassConstructorSymbol(classDeclaration.symbol);
+          if (!(constructor && constructor.declarations)) {
+            return;
+          }
+          for (const decl of constructor.declarations) {
+            Debug.assert(decl.kind === 176 /* Constructor */);
+            const body = decl.body;
+            if (body) {
+              forEachDescendantOfKind(body, 108 /* SuperKeyword */, (node) => {
+                if (isCallExpressionTarget(node)) {
+                  addNode(node);
+                }
               });
             }
-          );
-          hasUnresolvedAutoImports = context.skippedAny();
-          flags |= context.resolvedAny() ? 8 /* ResolvedModuleSpecifiers */ : 0;
-          flags |= context.resolvedBeyondLimit() ? 16 /* ResolvedModuleSpecifiersBeyondLimit */ : 0;
-        }
-      );
-      function isImportableExportInfo(info) {
-        const moduleFile = tryCast(info.moduleSymbol.valueDeclaration, isSourceFile);
-        if (!moduleFile) {
-          const moduleName = stripQuotes(info.moduleSymbol.name);
-          if (ts_JsTyping_exports.nodeCoreModules.has(moduleName) && startsWith(moduleName, "node:") !== shouldUseUriStyleNodeCoreModules(sourceFile, program)) {
-            return false;
           }
-          return packageJsonFilter ? packageJsonFilter.allowsImportingAmbientModule(info.moduleSymbol, getModuleSpecifierResolutionHost(info.isFromPackageJson)) : true;
-        }
-        return isImportableFile(
-          info.isFromPackageJson ? packageJsonAutoImportProvider : program,
-          sourceFile,
-          moduleFile,
-          preferences,
-          packageJsonFilter,
-          getModuleSpecifierResolutionHost(info.isFromPackageJson),
-          moduleSpecifierCache
-        );
-      }
-    }
-    function pushAutoImportSymbol(symbol, origin) {
-      const symbolId = getSymbolId(symbol);
-      if (symbolToSortTextMap[symbolId] === SortText.GlobalsOrKeywords) {
-        return;
-      }
-      symbolToOriginInfoMap[symbols.length] = origin;
-      symbolToSortTextMap[symbolId] = importStatementCompletion ? SortText.LocationPriority : SortText.AutoImportSuggestions;
-      symbols.push(symbol);
-    }
-    function collectObjectLiteralMethodSymbols(members, enclosingDeclaration) {
-      if (isInJSFile(location)) {
-        return;
-      }
-      members.forEach((member) => {
-        if (!isObjectLiteralMethodSymbol(member)) {
-          return;
         }
-        const displayName = getCompletionEntryDisplayNameForSymbol(
-          member,
-          getEmitScriptTarget(compilerOptions),
-          /*origin*/
-          void 0,
-          0 /* ObjectPropertyDeclaration */,
-          /*jsxIdentifierExpected*/
-          false
-        );
-        if (!displayName) {
-          return;
+        function hasOwnConstructor(classDeclaration) {
+          return !!getClassConstructorSymbol(classDeclaration.symbol);
         }
-        const { name } = displayName;
-        const entryProps = getEntryForObjectLiteralMethodCompletion(
-          member,
-          name,
-          enclosingDeclaration,
-          program,
-          host,
-          compilerOptions,
-          preferences,
-          formatContext
-        );
-        if (!entryProps) {
-          return;
+        function findInheritedConstructorReferences(classDeclaration, state) {
+          if (hasOwnConstructor(classDeclaration))
+            return;
+          const classSymbol = classDeclaration.symbol;
+          const search = state.createSearch(
+            /*location*/
+            void 0,
+            classSymbol,
+            /*comingFrom*/
+            void 0
+          );
+          getReferencesInContainerOrFiles(classSymbol, state, search);
         }
-        const origin = { kind: 128 /* ObjectLiteralMethod */, ...entryProps };
-        flags |= 32 /* MayIncludeMethodSnippets */;
-        symbolToOriginInfoMap[symbols.length] = origin;
-        symbols.push(member);
-      });
-    }
-    function isObjectLiteralMethodSymbol(symbol) {
-      if (!(symbol.flags & (4 /* Property */ | 8192 /* Method */))) {
-        return false;
-      }
-      return true;
-    }
-    function getScopeNode(initialToken, position2, sourceFile2) {
-      let scope = initialToken;
-      while (scope && !positionBelongsToNode(scope, position2, sourceFile2)) {
-        scope = scope.parent;
-      }
-      return scope;
-    }
-    function isCompletionListBlocker(contextToken2) {
-      const start2 = timestamp();
-      const result = isInStringOrRegularExpressionOrTemplateLiteral(contextToken2) || isSolelyIdentifierDefinitionLocation(contextToken2) || isDotOfNumericLiteral(contextToken2) || isInJsxText(contextToken2) || isBigIntLiteral(contextToken2);
-      log("getCompletionsAtPosition: isCompletionListBlocker: " + (timestamp() - start2));
-      return result;
-    }
-    function isInJsxText(contextToken2) {
-      if (contextToken2.kind === 12 /* JsxText */) {
-        return true;
-      }
-      if (contextToken2.kind === 32 /* GreaterThanToken */ && contextToken2.parent) {
-        if (location === contextToken2.parent && (location.kind === 285 /* JsxOpeningElement */ || location.kind === 284 /* JsxSelfClosingElement */)) {
-          return false;
+        function addImplementationReferences(refNode, addReference2, state) {
+          if (isDeclarationName(refNode) && isImplementation(refNode.parent)) {
+            addReference2(refNode);
+            return;
+          }
+          if (refNode.kind !== 80 /* Identifier */) {
+            return;
+          }
+          if (refNode.parent.kind === 304 /* ShorthandPropertyAssignment */) {
+            getReferenceEntriesForShorthandPropertyAssignment(refNode, state.checker, addReference2);
+          }
+          const containingNode = getContainingNodeIfInHeritageClause(refNode);
+          if (containingNode) {
+            addReference2(containingNode);
+            return;
+          }
+          const typeNode = findAncestor(refNode, (a) => !isQualifiedName(a.parent) && !isTypeNode(a.parent) && !isTypeElement(a.parent));
+          const typeHavingNode = typeNode.parent;
+          if (hasType(typeHavingNode) && typeHavingNode.type === typeNode && state.markSeenContainingTypeReference(typeHavingNode)) {
+            if (hasInitializer(typeHavingNode)) {
+              addIfImplementation(typeHavingNode.initializer);
+            } else if (isFunctionLike(typeHavingNode) && typeHavingNode.body) {
+              const body = typeHavingNode.body;
+              if (body.kind === 241 /* Block */) {
+                forEachReturnStatement(body, (returnStatement) => {
+                  if (returnStatement.expression)
+                    addIfImplementation(returnStatement.expression);
+                });
+              } else {
+                addIfImplementation(body);
+              }
+            } else if (isAssertionExpression(typeHavingNode)) {
+              addIfImplementation(typeHavingNode.expression);
+            }
+          }
+          function addIfImplementation(e) {
+            if (isImplementationExpression(e))
+              addReference2(e);
+          }
         }
-        if (contextToken2.parent.kind === 285 /* JsxOpeningElement */) {
-          return location.parent.kind !== 285 /* JsxOpeningElement */;
+        function getContainingNodeIfInHeritageClause(node) {
+          return isIdentifier(node) || isPropertyAccessExpression(node) ? getContainingNodeIfInHeritageClause(node.parent) : isExpressionWithTypeArguments(node) ? tryCast(node.parent.parent, or(isClassLike, isInterfaceDeclaration)) : void 0;
         }
-        if (contextToken2.parent.kind === 286 /* JsxClosingElement */ || contextToken2.parent.kind === 284 /* JsxSelfClosingElement */) {
-          return !!contextToken2.parent.parent && contextToken2.parent.parent.kind === 283 /* JsxElement */;
+        function isImplementationExpression(node) {
+          switch (node.kind) {
+            case 217 /* ParenthesizedExpression */:
+              return isImplementationExpression(node.expression);
+            case 219 /* ArrowFunction */:
+            case 218 /* FunctionExpression */:
+            case 210 /* ObjectLiteralExpression */:
+            case 231 /* ClassExpression */:
+            case 209 /* ArrayLiteralExpression */:
+              return true;
+            default:
+              return false;
+          }
         }
-      }
-      return false;
-    }
-    function isNewIdentifierDefinitionLocation() {
-      if (contextToken) {
-        const containingNodeKind = contextToken.parent.kind;
-        const tokenKind = keywordForNode(contextToken);
-        switch (tokenKind) {
-          case 28 /* CommaToken */:
-            return containingNodeKind === 212 /* CallExpression */ || containingNodeKind === 175 /* Constructor */ || containingNodeKind === 213 /* NewExpression */ || containingNodeKind === 208 /* ArrayLiteralExpression */ || containingNodeKind === 225 /* BinaryExpression */ || containingNodeKind === 183 /* FunctionType */ || containingNodeKind === 209 /* ObjectLiteralExpression */;
-          case 21 /* OpenParenToken */:
-            return containingNodeKind === 212 /* CallExpression */ || containingNodeKind === 175 /* Constructor */ || containingNodeKind === 213 /* NewExpression */ || containingNodeKind === 216 /* ParenthesizedExpression */ || containingNodeKind === 195 /* ParenthesizedType */;
-          case 23 /* OpenBracketToken */:
-            return containingNodeKind === 208 /* ArrayLiteralExpression */ || containingNodeKind === 180 /* IndexSignature */ || containingNodeKind === 166 /* ComputedPropertyName */;
-          case 144 /* ModuleKeyword */:
-          case 145 /* NamespaceKeyword */:
-          case 102 /* ImportKeyword */:
+        function explicitlyInheritsFrom(symbol, parent2, cachedResults, checker) {
+          if (symbol === parent2) {
             return true;
-          case 25 /* DotToken */:
-            return containingNodeKind === 266 /* ModuleDeclaration */;
-          case 19 /* OpenBraceToken */:
-            return containingNodeKind === 262 /* ClassDeclaration */ || containingNodeKind === 209 /* ObjectLiteralExpression */;
-          case 64 /* EqualsToken */:
-            return containingNodeKind === 259 /* VariableDeclaration */ || containingNodeKind === 225 /* BinaryExpression */;
-          case 16 /* TemplateHead */:
-            return containingNodeKind === 227 /* TemplateExpression */;
-          case 17 /* TemplateMiddle */:
-            return containingNodeKind === 238 /* TemplateSpan */;
-          case 134 /* AsyncKeyword */:
-            return containingNodeKind === 173 /* MethodDeclaration */ || containingNodeKind === 303 /* ShorthandPropertyAssignment */;
-          case 42 /* AsteriskToken */:
-            return containingNodeKind === 173 /* MethodDeclaration */;
-        }
-        if (isClassMemberCompletionKeyword(tokenKind)) {
-          return true;
-        }
-      }
-      return false;
-    }
-    function isInStringOrRegularExpressionOrTemplateLiteral(contextToken2) {
-      return (isRegularExpressionLiteral(contextToken2) || isStringTextContainingNode(contextToken2)) && (rangeContainsPositionExclusive(contextToken2, position) || position === contextToken2.end && (!!contextToken2.isUnterminated || isRegularExpressionLiteral(contextToken2)));
-    }
-    function tryGetObjectTypeLiteralInTypeArgumentCompletionSymbols() {
-      const typeLiteralNode = tryGetTypeLiteralNode(contextToken);
-      if (!typeLiteralNode)
-        return 0 /* Continue */;
-      const intersectionTypeNode = isIntersectionTypeNode(typeLiteralNode.parent) ? typeLiteralNode.parent : void 0;
-      const containerTypeNode = intersectionTypeNode || typeLiteralNode;
-      const containerExpectedType = getConstraintOfTypeArgumentProperty(containerTypeNode, typeChecker);
-      if (!containerExpectedType)
-        return 0 /* Continue */;
-      const containerActualType = typeChecker.getTypeFromTypeNode(containerTypeNode);
-      const members = getPropertiesForCompletion(containerExpectedType, typeChecker);
-      const existingMembers = getPropertiesForCompletion(containerActualType, typeChecker);
-      const existingMemberEscapedNames = /* @__PURE__ */ new Set();
-      existingMembers.forEach((s) => existingMemberEscapedNames.add(s.escapedName));
-      symbols = concatenate(symbols, filter(members, (s) => !existingMemberEscapedNames.has(s.escapedName)));
-      completionKind = 0 /* ObjectPropertyDeclaration */;
-      isNewIdentifierLocation = true;
-      return 1 /* Success */;
-    }
-    function tryGetObjectLikeCompletionSymbols() {
-      const symbolsStartIndex = symbols.length;
-      const objectLikeContainer = tryGetObjectLikeCompletionContainer(contextToken);
-      if (!objectLikeContainer)
-        return 0 /* Continue */;
-      completionKind = 0 /* ObjectPropertyDeclaration */;
-      let typeMembers;
-      let existingMembers;
-      if (objectLikeContainer.kind === 209 /* ObjectLiteralExpression */) {
-        const instantiatedType = tryGetObjectLiteralContextualType(objectLikeContainer, typeChecker);
-        if (instantiatedType === void 0) {
-          if (objectLikeContainer.flags & 33554432 /* InWithStatement */) {
-            return 2 /* Fail */;
           }
-          isNonContextualObjectLiteral = true;
-          return 0 /* Continue */;
-        }
-        const completionsType = typeChecker.getContextualType(objectLikeContainer, 4 /* Completions */);
-        const hasStringIndexType = (completionsType || instantiatedType).getStringIndexType();
-        const hasNumberIndextype = (completionsType || instantiatedType).getNumberIndexType();
-        isNewIdentifierLocation = !!hasStringIndexType || !!hasNumberIndextype;
-        typeMembers = getPropertiesForObjectExpression(instantiatedType, completionsType, objectLikeContainer, typeChecker);
-        existingMembers = objectLikeContainer.properties;
-        if (typeMembers.length === 0) {
-          if (!hasNumberIndextype) {
-            isNonContextualObjectLiteral = true;
-            return 0 /* Continue */;
+          const key = getSymbolId(symbol) + "," + getSymbolId(parent2);
+          const cached = cachedResults.get(key);
+          if (cached !== void 0) {
+            return cached;
           }
+          cachedResults.set(key, false);
+          const inherits = !!symbol.declarations && symbol.declarations.some(
+            (declaration) => getAllSuperTypeNodes(declaration).some((typeReference) => {
+              const type = checker.getTypeAtLocation(typeReference);
+              return !!type && !!type.symbol && explicitlyInheritsFrom(type.symbol, parent2, cachedResults, checker);
+            })
+          );
+          cachedResults.set(key, inherits);
+          return inherits;
         }
-      } else {
-        Debug.assert(objectLikeContainer.kind === 205 /* ObjectBindingPattern */);
-        isNewIdentifierLocation = false;
-        const rootDeclaration = getRootDeclaration(objectLikeContainer.parent);
-        if (!isVariableLike(rootDeclaration))
-          return Debug.fail("Root declaration is not variable-like.");
-        let canGetType = hasInitializer(rootDeclaration) || !!getEffectiveTypeAnnotationNode(rootDeclaration) || rootDeclaration.parent.parent.kind === 249 /* ForOfStatement */;
-        if (!canGetType && rootDeclaration.kind === 168 /* Parameter */) {
-          if (isExpression(rootDeclaration.parent)) {
-            canGetType = !!typeChecker.getContextualType(rootDeclaration.parent);
-          } else if (rootDeclaration.parent.kind === 173 /* MethodDeclaration */ || rootDeclaration.parent.kind === 177 /* SetAccessor */) {
-            canGetType = isExpression(rootDeclaration.parent.parent) && !!typeChecker.getContextualType(rootDeclaration.parent.parent);
+        function getReferencesForSuperKeyword(superKeyword) {
+          let searchSpaceNode = getSuperContainer(
+            superKeyword,
+            /*stopOnFunctions*/
+            false
+          );
+          if (!searchSpaceNode) {
+            return void 0;
           }
-        }
-        if (canGetType) {
-          const typeForObject = typeChecker.getTypeAtLocation(objectLikeContainer);
-          if (!typeForObject)
-            return 2 /* Fail */;
-          typeMembers = typeChecker.getPropertiesOfType(typeForObject).filter((propertySymbol) => {
-            return typeChecker.isPropertyAccessible(
-              objectLikeContainer,
-              /*isSuper*/
-              false,
-              /*isWrite*/
-              false,
-              typeForObject,
-              propertySymbol
+          let staticFlag = 256 /* Static */;
+          switch (searchSpaceNode.kind) {
+            case 172 /* PropertyDeclaration */:
+            case 171 /* PropertySignature */:
+            case 174 /* MethodDeclaration */:
+            case 173 /* MethodSignature */:
+            case 176 /* Constructor */:
+            case 177 /* GetAccessor */:
+            case 178 /* SetAccessor */:
+              staticFlag &= getSyntacticModifierFlags(searchSpaceNode);
+              searchSpaceNode = searchSpaceNode.parent;
+              break;
+            default:
+              return void 0;
+          }
+          const sourceFile = searchSpaceNode.getSourceFile();
+          const references = mapDefined(getPossibleSymbolReferenceNodes(sourceFile, "super", searchSpaceNode), (node) => {
+            if (node.kind !== 108 /* SuperKeyword */) {
+              return;
+            }
+            const container = getSuperContainer(
+              node,
+              /*stopOnFunctions*/
+              false
             );
+            return container && isStatic(container) === !!staticFlag && container.parent.symbol === searchSpaceNode.symbol ? nodeEntry(node) : void 0;
           });
-          existingMembers = objectLikeContainer.elements;
+          return [{ definition: { type: 0 /* Symbol */, symbol: searchSpaceNode.symbol }, references }];
         }
-      }
-      if (typeMembers && typeMembers.length > 0) {
-        const filteredMembers = filterObjectMembersList(typeMembers, Debug.checkDefined(existingMembers));
-        symbols = concatenate(symbols, filteredMembers);
-        setSortTextToOptionalMember();
-        if (objectLikeContainer.kind === 209 /* ObjectLiteralExpression */ && preferences.includeCompletionsWithObjectLiteralMethodSnippets && preferences.includeCompletionsWithInsertText) {
-          transformObjectLiteralMembersSortText(symbolsStartIndex);
-          collectObjectLiteralMethodSymbols(filteredMembers, objectLikeContainer);
+        function isParameterName(node) {
+          return node.kind === 80 /* Identifier */ && node.parent.kind === 169 /* Parameter */ && node.parent.name === node;
         }
-      }
-      return 1 /* Success */;
-    }
-    function tryGetImportOrExportClauseCompletionSymbols() {
-      if (!contextToken)
-        return 0 /* Continue */;
-      const namedImportsOrExports = contextToken.kind === 19 /* OpenBraceToken */ || contextToken.kind === 28 /* CommaToken */ ? tryCast(contextToken.parent, isNamedImportsOrExports) : isTypeKeywordTokenOrIdentifier(contextToken) ? tryCast(contextToken.parent.parent, isNamedImportsOrExports) : void 0;
-      if (!namedImportsOrExports)
-        return 0 /* Continue */;
-      if (!isTypeKeywordTokenOrIdentifier(contextToken)) {
-        keywordFilters = 8 /* TypeKeyword */;
-      }
-      const { moduleSpecifier } = namedImportsOrExports.kind === 274 /* NamedImports */ ? namedImportsOrExports.parent.parent : namedImportsOrExports.parent;
-      if (!moduleSpecifier) {
-        isNewIdentifierLocation = true;
-        return namedImportsOrExports.kind === 274 /* NamedImports */ ? 2 /* Fail */ : 0 /* Continue */;
-      }
-      const moduleSpecifierSymbol = typeChecker.getSymbolAtLocation(moduleSpecifier);
-      if (!moduleSpecifierSymbol) {
-        isNewIdentifierLocation = true;
-        return 2 /* Fail */;
-      }
-      completionKind = 3 /* MemberLike */;
-      isNewIdentifierLocation = false;
-      const exports = typeChecker.getExportsAndPropertiesOfModule(moduleSpecifierSymbol);
-      const existing = new Set(namedImportsOrExports.elements.filter((n) => !isCurrentlyEditingNode(n)).map((n) => (n.propertyName || n.name).escapedText));
-      const uniques = exports.filter((e) => e.escapedName !== "default" /* Default */ && !existing.has(e.escapedName));
-      symbols = concatenate(symbols, uniques);
-      if (!uniques.length) {
-        keywordFilters = 0 /* None */;
-      }
-      return 1 /* Success */;
-    }
-    function tryGetLocalNamedExportCompletionSymbols() {
-      var _a;
-      const namedExports = contextToken && (contextToken.kind === 19 /* OpenBraceToken */ || contextToken.kind === 28 /* CommaToken */) ? tryCast(contextToken.parent, isNamedExports) : void 0;
-      if (!namedExports) {
-        return 0 /* Continue */;
-      }
-      const localsContainer = findAncestor(namedExports, or(isSourceFile, isModuleDeclaration));
-      completionKind = 5 /* None */;
-      isNewIdentifierLocation = false;
-      (_a = localsContainer.locals) == null ? void 0 : _a.forEach((symbol, name) => {
-        var _a2, _b;
-        symbols.push(symbol);
-        if ((_b = (_a2 = localsContainer.symbol) == null ? void 0 : _a2.exports) == null ? void 0 : _b.has(name)) {
-          symbolToSortTextMap[getSymbolId(symbol)] = SortText.OptionalMember;
+        function getReferencesForThisKeyword(thisOrSuperKeyword, sourceFiles, cancellationToken) {
+          let searchSpaceNode = getThisContainer(
+            thisOrSuperKeyword,
+            /*includeArrowFunctions*/
+            false,
+            /*includeClassComputedPropertyName*/
+            false
+          );
+          let staticFlag = 256 /* Static */;
+          switch (searchSpaceNode.kind) {
+            case 174 /* MethodDeclaration */:
+            case 173 /* MethodSignature */:
+              if (isObjectLiteralMethod(searchSpaceNode)) {
+                staticFlag &= getSyntacticModifierFlags(searchSpaceNode);
+                searchSpaceNode = searchSpaceNode.parent;
+                break;
+              }
+            case 172 /* PropertyDeclaration */:
+            case 171 /* PropertySignature */:
+            case 176 /* Constructor */:
+            case 177 /* GetAccessor */:
+            case 178 /* SetAccessor */:
+              staticFlag &= getSyntacticModifierFlags(searchSpaceNode);
+              searchSpaceNode = searchSpaceNode.parent;
+              break;
+            case 312 /* SourceFile */:
+              if (isExternalModule(searchSpaceNode) || isParameterName(thisOrSuperKeyword)) {
+                return void 0;
+              }
+            case 262 /* FunctionDeclaration */:
+            case 218 /* FunctionExpression */:
+              break;
+            default:
+              return void 0;
+          }
+          const references = flatMap(searchSpaceNode.kind === 312 /* SourceFile */ ? sourceFiles : [searchSpaceNode.getSourceFile()], (sourceFile) => {
+            cancellationToken.throwIfCancellationRequested();
+            return getPossibleSymbolReferenceNodes(sourceFile, "this", isSourceFile(searchSpaceNode) ? sourceFile : searchSpaceNode).filter((node) => {
+              if (!isThis(node)) {
+                return false;
+              }
+              const container = getThisContainer(
+                node,
+                /*includeArrowFunctions*/
+                false,
+                /*includeClassComputedPropertyName*/
+                false
+              );
+              if (!canHaveSymbol(container))
+                return false;
+              switch (searchSpaceNode.kind) {
+                case 218 /* FunctionExpression */:
+                case 262 /* FunctionDeclaration */:
+                  return searchSpaceNode.symbol === container.symbol;
+                case 174 /* MethodDeclaration */:
+                case 173 /* MethodSignature */:
+                  return isObjectLiteralMethod(searchSpaceNode) && searchSpaceNode.symbol === container.symbol;
+                case 231 /* ClassExpression */:
+                case 263 /* ClassDeclaration */:
+                case 210 /* ObjectLiteralExpression */:
+                  return container.parent && canHaveSymbol(container.parent) && searchSpaceNode.symbol === container.parent.symbol && isStatic(container) === !!staticFlag;
+                case 312 /* SourceFile */:
+                  return container.kind === 312 /* SourceFile */ && !isExternalModule(container) && !isParameterName(node);
+              }
+            });
+          }).map((n) => nodeEntry(n));
+          const thisParameter = firstDefined(references, (r) => isParameter(r.node.parent) ? r.node : void 0);
+          return [{
+            definition: { type: 3 /* This */, node: thisParameter || thisOrSuperKeyword },
+            references
+          }];
         }
-      });
-      return 1 /* Success */;
-    }
-    function tryGetClassLikeCompletionSymbols() {
-      const decl = tryGetObjectTypeDeclarationCompletionContainer(sourceFile, contextToken, location, position);
-      if (!decl)
-        return 0 /* Continue */;
-      completionKind = 3 /* MemberLike */;
-      isNewIdentifierLocation = true;
-      keywordFilters = contextToken.kind === 42 /* AsteriskToken */ ? 0 /* None */ : isClassLike(decl) ? 2 /* ClassElementKeywords */ : 3 /* InterfaceElementKeywords */;
-      if (!isClassLike(decl))
-        return 1 /* Success */;
-      const classElement = contextToken.kind === 27 /* SemicolonToken */ ? contextToken.parent.parent : contextToken.parent;
-      let classElementModifierFlags = isClassElement(classElement) ? getEffectiveModifierFlags(classElement) : 0 /* None */;
-      if (contextToken.kind === 80 /* Identifier */ && !isCurrentlyEditingNode(contextToken)) {
-        switch (contextToken.getText()) {
-          case "private":
-            classElementModifierFlags = classElementModifierFlags | 8 /* Private */;
-            break;
-          case "static":
-            classElementModifierFlags = classElementModifierFlags | 32 /* Static */;
-            break;
-          case "override":
-            classElementModifierFlags = classElementModifierFlags | 16384 /* Override */;
-            break;
+        function getReferencesForStringLiteral(node, sourceFiles, checker, cancellationToken) {
+          const type = getContextualTypeFromParentOrAncestorTypeNode(node, checker);
+          const references = flatMap(sourceFiles, (sourceFile) => {
+            cancellationToken.throwIfCancellationRequested();
+            return mapDefined(getPossibleSymbolReferenceNodes(sourceFile, node.text), (ref) => {
+              if (isStringLiteralLike(ref) && ref.text === node.text) {
+                if (type) {
+                  const refType = getContextualTypeFromParentOrAncestorTypeNode(ref, checker);
+                  if (type !== checker.getStringType() && type === refType) {
+                    return nodeEntry(ref, 2 /* StringLiteral */);
+                  }
+                } else {
+                  return isNoSubstitutionTemplateLiteral(ref) && !rangeIsOnSingleLine(ref, sourceFile) ? void 0 : nodeEntry(ref, 2 /* StringLiteral */);
+                }
+              }
+            });
+          });
+          return [{
+            definition: { type: 4 /* String */, node },
+            references
+          }];
         }
-      }
-      if (isClassStaticBlockDeclaration(classElement)) {
-        classElementModifierFlags |= 32 /* Static */;
-      }
-      if (!(classElementModifierFlags & 8 /* Private */)) {
-        const baseTypeNodes = isClassLike(decl) && classElementModifierFlags & 16384 /* Override */ ? singleElementArray(getEffectiveBaseTypeNode(decl)) : getAllSuperTypeNodes(decl);
-        const baseSymbols = flatMap(baseTypeNodes, (baseTypeNode) => {
-          const type = typeChecker.getTypeAtLocation(baseTypeNode);
-          return classElementModifierFlags & 32 /* Static */ ? (type == null ? void 0 : type.symbol) && typeChecker.getPropertiesOfType(typeChecker.getTypeOfSymbolAtLocation(type.symbol, decl)) : type && typeChecker.getPropertiesOfType(type);
-        });
-        symbols = concatenate(symbols, filterClassMembersList(baseSymbols, decl.members, classElementModifierFlags));
-        forEach(symbols, (symbol, index) => {
-          const declaration = symbol == null ? void 0 : symbol.valueDeclaration;
-          if (declaration && isClassElement(declaration) && declaration.name && isComputedPropertyName(declaration.name)) {
-            const origin = {
-              kind: 512 /* ComputedPropertyName */,
-              symbolName: typeChecker.symbolToString(symbol)
-            };
-            symbolToOriginInfoMap[index] = origin;
-          }
-        });
-      }
-      return 1 /* Success */;
-    }
-    function isConstructorParameterCompletion(node2) {
-      return !!node2.parent && isParameter(node2.parent) && isConstructorDeclaration(node2.parent.parent) && (isParameterPropertyModifier(node2.kind) || isDeclarationName(node2));
-    }
-    function tryGetConstructorLikeCompletionContainer(contextToken2) {
-      if (contextToken2) {
-        const parent2 = contextToken2.parent;
-        switch (contextToken2.kind) {
-          case 21 /* OpenParenToken */:
-          case 28 /* CommaToken */:
-            return isConstructorDeclaration(contextToken2.parent) ? contextToken2.parent : void 0;
-          default:
-            if (isConstructorParameterCompletion(contextToken2)) {
-              return parent2.parent;
-            }
+        function populateSearchSymbolSet(symbol, location, checker, isForRename, providePrefixAndSuffixText, implementations) {
+          const result = [];
+          forEachRelatedSymbol(
+            symbol,
+            location,
+            checker,
+            isForRename,
+            !(isForRename && providePrefixAndSuffixText),
+            (sym, root, base) => {
+              if (base) {
+                if (isStaticSymbol(symbol) !== isStaticSymbol(base)) {
+                  base = void 0;
+                }
+              }
+              result.push(base || root || sym);
+            },
+            // when try to find implementation, implementations is true, and not allowed to find base class
+            /*allowBaseTypes*/
+            () => !implementations
+          );
+          return result;
         }
-      }
-      return void 0;
-    }
-    function tryGetFunctionLikeBodyCompletionContainer(contextToken2) {
-      if (contextToken2) {
-        let prev;
-        const container = findAncestor(contextToken2.parent, (node2) => {
-          if (isClassLike(node2)) {
-            return "quit";
+        function forEachRelatedSymbol(symbol, location, checker, isForRenamePopulateSearchSymbolSet, onlyIncludeBindingElementAtReferenceLocation, cbSymbol, allowBaseTypes) {
+          const containingObjectLiteralElement = getContainingObjectLiteralElement(location);
+          if (containingObjectLiteralElement) {
+            const shorthandValueSymbol = checker.getShorthandAssignmentValueSymbol(location.parent);
+            if (shorthandValueSymbol && isForRenamePopulateSearchSymbolSet) {
+              return cbSymbol(
+                shorthandValueSymbol,
+                /*rootSymbol*/
+                void 0,
+                /*baseSymbol*/
+                void 0,
+                3 /* SearchedLocalFoundProperty */
+              );
+            }
+            const contextualType = checker.getContextualType(containingObjectLiteralElement.parent);
+            const res2 = contextualType && firstDefined(
+              getPropertySymbolsFromContextualType(
+                containingObjectLiteralElement,
+                checker,
+                contextualType,
+                /*unionSymbolOk*/
+                true
+              ),
+              (sym) => fromRoot(sym, 4 /* SearchedPropertyFoundLocal */)
+            );
+            if (res2)
+              return res2;
+            const propertySymbol = getPropertySymbolOfDestructuringAssignment(location, checker);
+            const res1 = propertySymbol && cbSymbol(
+              propertySymbol,
+              /*rootSymbol*/
+              void 0,
+              /*baseSymbol*/
+              void 0,
+              4 /* SearchedPropertyFoundLocal */
+            );
+            if (res1)
+              return res1;
+            const res22 = shorthandValueSymbol && cbSymbol(
+              shorthandValueSymbol,
+              /*rootSymbol*/
+              void 0,
+              /*baseSymbol*/
+              void 0,
+              3 /* SearchedLocalFoundProperty */
+            );
+            if (res22)
+              return res22;
           }
-          if (isFunctionLikeDeclaration(node2) && prev === node2.body) {
-            return true;
+          const aliasedSymbol = getMergedAliasedSymbolOfNamespaceExportDeclaration(location, symbol, checker);
+          if (aliasedSymbol) {
+            const res2 = cbSymbol(
+              aliasedSymbol,
+              /*rootSymbol*/
+              void 0,
+              /*baseSymbol*/
+              void 0,
+              1 /* Node */
+            );
+            if (res2)
+              return res2;
           }
-          prev = node2;
-          return false;
-        });
-        return container && container;
-      }
-    }
-    function tryGetContainingJsxElement(contextToken2) {
-      if (contextToken2) {
-        const parent2 = contextToken2.parent;
-        switch (contextToken2.kind) {
-          case 32 /* GreaterThanToken */:
-          case 31 /* LessThanSlashToken */:
-          case 44 /* SlashToken */:
-          case 80 /* Identifier */:
-          case 210 /* PropertyAccessExpression */:
-          case 291 /* JsxAttributes */:
-          case 290 /* JsxAttribute */:
-          case 292 /* JsxSpreadAttribute */:
-            if (parent2 && (parent2.kind === 284 /* JsxSelfClosingElement */ || parent2.kind === 285 /* JsxOpeningElement */)) {
-              if (contextToken2.kind === 32 /* GreaterThanToken */) {
-                const precedingToken = findPrecedingToken(
-                  contextToken2.pos,
-                  sourceFile,
-                  /*startNode*/
-                  void 0
-                );
-                if (!parent2.typeArguments || precedingToken && precedingToken.kind === 44 /* SlashToken */)
-                  break;
-              }
-              return parent2;
-            } else if (parent2.kind === 290 /* JsxAttribute */) {
-              return parent2.parent.parent;
-            }
-            break;
-          case 11 /* StringLiteral */:
-            if (parent2 && (parent2.kind === 290 /* JsxAttribute */ || parent2.kind === 292 /* JsxSpreadAttribute */)) {
-              return parent2.parent.parent;
+          const res = fromRoot(symbol);
+          if (res)
+            return res;
+          if (symbol.valueDeclaration && isParameterPropertyDeclaration(symbol.valueDeclaration, symbol.valueDeclaration.parent)) {
+            const paramProps = checker.getSymbolsOfParameterPropertyDeclaration(cast(symbol.valueDeclaration, isParameter), symbol.name);
+            Debug.assert(paramProps.length === 2 && !!(paramProps[0].flags & 1 /* FunctionScopedVariable */) && !!(paramProps[1].flags & 4 /* Property */));
+            return fromRoot(symbol.flags & 1 /* FunctionScopedVariable */ ? paramProps[1] : paramProps[0]);
+          }
+          const exportSpecifier = getDeclarationOfKind(symbol, 281 /* ExportSpecifier */);
+          if (!isForRenamePopulateSearchSymbolSet || exportSpecifier && !exportSpecifier.propertyName) {
+            const localSymbol = exportSpecifier && checker.getExportSpecifierLocalTargetSymbol(exportSpecifier);
+            if (localSymbol) {
+              const res2 = cbSymbol(
+                localSymbol,
+                /*rootSymbol*/
+                void 0,
+                /*baseSymbol*/
+                void 0,
+                1 /* Node */
+              );
+              if (res2)
+                return res2;
             }
-            break;
-          case 20 /* CloseBraceToken */:
-            if (parent2 && parent2.kind === 293 /* JsxExpression */ && parent2.parent && parent2.parent.kind === 290 /* JsxAttribute */) {
-              return parent2.parent.parent.parent;
+          }
+          if (!isForRenamePopulateSearchSymbolSet) {
+            let bindingElementPropertySymbol;
+            if (onlyIncludeBindingElementAtReferenceLocation) {
+              bindingElementPropertySymbol = isObjectBindingElementWithoutPropertyName(location.parent) ? getPropertySymbolFromBindingElement(checker, location.parent) : void 0;
+            } else {
+              bindingElementPropertySymbol = getPropertySymbolOfObjectBindingPatternWithoutPropertyName(symbol, checker);
             }
-            if (parent2 && parent2.kind === 292 /* JsxSpreadAttribute */) {
-              return parent2.parent.parent;
+            return bindingElementPropertySymbol && fromRoot(bindingElementPropertySymbol, 4 /* SearchedPropertyFoundLocal */);
+          }
+          Debug.assert(isForRenamePopulateSearchSymbolSet);
+          const includeOriginalSymbolOfBindingElement = onlyIncludeBindingElementAtReferenceLocation;
+          if (includeOriginalSymbolOfBindingElement) {
+            const bindingElementPropertySymbol = getPropertySymbolOfObjectBindingPatternWithoutPropertyName(symbol, checker);
+            return bindingElementPropertySymbol && fromRoot(bindingElementPropertySymbol, 4 /* SearchedPropertyFoundLocal */);
+          }
+          function fromRoot(sym, kind) {
+            return firstDefined(checker.getRootSymbols(sym), (rootSymbol) => cbSymbol(
+              sym,
+              rootSymbol,
+              /*baseSymbol*/
+              void 0,
+              kind
+            ) || (rootSymbol.parent && rootSymbol.parent.flags & (32 /* Class */ | 64 /* Interface */) && allowBaseTypes(rootSymbol) ? getPropertySymbolsFromBaseTypes(rootSymbol.parent, rootSymbol.name, checker, (base) => cbSymbol(sym, rootSymbol, base, kind)) : void 0));
+          }
+          function getPropertySymbolOfObjectBindingPatternWithoutPropertyName(symbol2, checker2) {
+            const bindingElement = getDeclarationOfKind(symbol2, 208 /* BindingElement */);
+            if (bindingElement && isObjectBindingElementWithoutPropertyName(bindingElement)) {
+              return getPropertySymbolFromBindingElement(checker2, bindingElement);
             }
-            break;
+          }
         }
-      }
-      return void 0;
-    }
-    function isSolelyIdentifierDefinitionLocation(contextToken2) {
-      const parent2 = contextToken2.parent;
-      const containingNodeKind = parent2.kind;
-      switch (contextToken2.kind) {
-        case 28 /* CommaToken */:
-          return containingNodeKind === 259 /* VariableDeclaration */ || isVariableDeclarationListButNotTypeArgument(contextToken2) || containingNodeKind === 242 /* VariableStatement */ || containingNodeKind === 265 /* EnumDeclaration */ || // enum a { foo, |
-          isFunctionLikeButNotConstructor(containingNodeKind) || containingNodeKind === 263 /* InterfaceDeclaration */ || // interface A= contextToken2.pos;
-        case 25 /* DotToken */:
-          return containingNodeKind === 206 /* ArrayBindingPattern */;
-        case 59 /* ColonToken */:
-          return containingNodeKind === 207 /* BindingElement */;
-        case 23 /* OpenBracketToken */:
-          return containingNodeKind === 206 /* ArrayBindingPattern */;
-        case 21 /* OpenParenToken */:
-          return containingNodeKind === 298 /* CatchClause */ || isFunctionLikeButNotConstructor(containingNodeKind);
-        case 19 /* OpenBraceToken */:
-          return containingNodeKind === 265 /* EnumDeclaration */;
-        case 30 /* LessThanToken */:
-          return containingNodeKind === 262 /* ClassDeclaration */ || // class A< |
-          containingNodeKind === 230 /* ClassExpression */ || // var C = class D< |
-          containingNodeKind === 263 /* InterfaceDeclaration */ || // interface A< |
-          containingNodeKind === 264 /* TypeAliasDeclaration */ || // type List< |
-          isFunctionLikeKind(containingNodeKind);
-        case 126 /* StaticKeyword */:
-          return containingNodeKind === 171 /* PropertyDeclaration */ && !isClassLike(parent2.parent);
-        case 26 /* DotDotDotToken */:
-          return containingNodeKind === 168 /* Parameter */ || !!parent2.parent && parent2.parent.kind === 206 /* ArrayBindingPattern */;
-        case 125 /* PublicKeyword */:
-        case 123 /* PrivateKeyword */:
-        case 124 /* ProtectedKeyword */:
-          return containingNodeKind === 168 /* Parameter */ && !isConstructorDeclaration(parent2.parent);
-        case 130 /* AsKeyword */:
-          return containingNodeKind === 275 /* ImportSpecifier */ || containingNodeKind === 280 /* ExportSpecifier */ || containingNodeKind === 273 /* NamespaceImport */;
-        case 139 /* GetKeyword */:
-        case 153 /* SetKeyword */:
-          return !isFromObjectTypeDeclaration(contextToken2);
-        case 80 /* Identifier */:
-          if (containingNodeKind === 275 /* ImportSpecifier */ && contextToken2 === parent2.name && contextToken2.text === "type") {
+        function getPropertySymbolsFromBaseTypes(symbol, propertyName, checker, cb) {
+          const seen = /* @__PURE__ */ new Map();
+          return recur(symbol);
+          function recur(symbol2) {
+            if (!(symbol2.flags & (32 /* Class */ | 64 /* Interface */)) || !addToSeen(seen, getSymbolId(symbol2)))
+              return;
+            return firstDefined(symbol2.declarations, (declaration) => firstDefined(getAllSuperTypeNodes(declaration), (typeReference) => {
+              const type = checker.getTypeAtLocation(typeReference);
+              const propertySymbol = type && type.symbol && checker.getPropertyOfType(type, propertyName);
+              return type && propertySymbol && (firstDefined(checker.getRootSymbols(propertySymbol), cb) || recur(type.symbol));
+            }));
+          }
+        }
+        function isStaticSymbol(symbol) {
+          if (!symbol.valueDeclaration)
             return false;
+          const modifierFlags = getEffectiveModifierFlags(symbol.valueDeclaration);
+          return !!(modifierFlags & 256 /* Static */);
+        }
+        function getRelatedSymbol(search, referenceSymbol, referenceLocation, state) {
+          const { checker } = state;
+          return forEachRelatedSymbol(
+            referenceSymbol,
+            referenceLocation,
+            checker,
+            /*isForRenamePopulateSearchSymbolSet*/
+            false,
+            /*onlyIncludeBindingElementAtReferenceLocation*/
+            state.options.use !== 2 /* Rename */ || !!state.options.providePrefixAndSuffixTextForRename,
+            (sym, rootSymbol, baseSymbol, kind) => {
+              if (baseSymbol) {
+                if (isStaticSymbol(referenceSymbol) !== isStaticSymbol(baseSymbol)) {
+                  baseSymbol = void 0;
+                }
+              }
+              return search.includes(baseSymbol || rootSymbol || sym) ? { symbol: rootSymbol && !(getCheckFlags(sym) & 6 /* Synthetic */) ? rootSymbol : sym, kind } : void 0;
+            },
+            /*allowBaseTypes*/
+            (rootSymbol) => !(search.parents && !search.parents.some((parent2) => explicitlyInheritsFrom(rootSymbol.parent, parent2, state.inheritsFromCache, checker)))
+          );
+        }
+        function getIntersectingMeaningFromDeclarations(node, symbol) {
+          let meaning = getMeaningFromLocation(node);
+          const { declarations } = symbol;
+          if (declarations) {
+            let lastIterationMeaning;
+            do {
+              lastIterationMeaning = meaning;
+              for (const declaration of declarations) {
+                const declarationMeaning = getMeaningFromDeclaration(declaration);
+                if (declarationMeaning & meaning) {
+                  meaning |= declarationMeaning;
+                }
+              }
+            } while (meaning !== lastIterationMeaning);
           }
-          break;
-        case 86 /* ClassKeyword */:
-        case 94 /* EnumKeyword */:
-        case 120 /* InterfaceKeyword */:
-        case 100 /* FunctionKeyword */:
-        case 115 /* VarKeyword */:
-        case 102 /* ImportKeyword */:
-        case 121 /* LetKeyword */:
-        case 87 /* ConstKeyword */:
-        case 140 /* InferKeyword */:
-          return true;
-        case 156 /* TypeKeyword */:
-          return containingNodeKind !== 275 /* ImportSpecifier */;
-        case 42 /* AsteriskToken */:
-          return isFunctionLike(contextToken2.parent) && !isMethodDeclaration(contextToken2.parent);
-      }
-      if (isClassMemberCompletionKeyword(keywordForNode(contextToken2)) && isFromObjectTypeDeclaration(contextToken2)) {
-        return false;
-      }
-      if (isConstructorParameterCompletion(contextToken2)) {
-        if (!isIdentifier(contextToken2) || isParameterPropertyModifier(keywordForNode(contextToken2)) || isCurrentlyEditingNode(contextToken2)) {
-          return false;
+          return meaning;
         }
-      }
-      switch (keywordForNode(contextToken2)) {
-        case 128 /* AbstractKeyword */:
-        case 86 /* ClassKeyword */:
-        case 87 /* ConstKeyword */:
-        case 138 /* DeclareKeyword */:
-        case 94 /* EnumKeyword */:
-        case 100 /* FunctionKeyword */:
-        case 120 /* InterfaceKeyword */:
-        case 121 /* LetKeyword */:
-        case 123 /* PrivateKeyword */:
-        case 124 /* ProtectedKeyword */:
-        case 125 /* PublicKeyword */:
-        case 126 /* StaticKeyword */:
-        case 115 /* VarKeyword */:
-          return true;
-        case 134 /* AsyncKeyword */:
-          return isPropertyDeclaration(contextToken2.parent);
-      }
-      const ancestorClassLike = findAncestor(contextToken2.parent, isClassLike);
-      if (ancestorClassLike && contextToken2 === previousToken && isPreviousPropertyDeclarationTerminated(contextToken2, position)) {
-        return false;
-      }
-      const ancestorPropertyDeclaraion = getAncestor(contextToken2.parent, 171 /* PropertyDeclaration */);
-      if (ancestorPropertyDeclaraion && contextToken2 !== previousToken && isClassLike(previousToken.parent.parent) && position <= previousToken.end) {
-        if (isPreviousPropertyDeclarationTerminated(contextToken2, previousToken.end)) {
-          return false;
-        } else if (contextToken2.kind !== 64 /* EqualsToken */ && (isInitializedProperty(ancestorPropertyDeclaraion) || hasType(ancestorPropertyDeclaraion))) {
-          return true;
+        Core2.getIntersectingMeaningFromDeclarations = getIntersectingMeaningFromDeclarations;
+        function isImplementation(node) {
+          return !!(node.flags & 33554432 /* Ambient */) ? !(isInterfaceDeclaration(node) || isTypeAliasDeclaration(node)) : isVariableLike(node) ? hasInitializer(node) : isFunctionLikeDeclaration(node) ? !!node.body : isClassLike(node) || isModuleOrEnumDeclaration(node);
         }
-      }
-      return isDeclarationName(contextToken2) && !isShorthandPropertyAssignment(contextToken2.parent) && !isJsxAttribute(contextToken2.parent) && !((isClassLike(contextToken2.parent) || isInterfaceDeclaration(contextToken2.parent) || isTypeParameterDeclaration(contextToken2.parent)) && (contextToken2 !== previousToken || position > previousToken.end));
+        function getReferenceEntriesForShorthandPropertyAssignment(node, checker, addReference2) {
+          const refSymbol = checker.getSymbolAtLocation(node);
+          const shorthandSymbol = checker.getShorthandAssignmentValueSymbol(refSymbol.valueDeclaration);
+          if (shorthandSymbol) {
+            for (const declaration of shorthandSymbol.getDeclarations()) {
+              if (getMeaningFromDeclaration(declaration) & 1 /* Value */) {
+                addReference2(declaration);
+              }
+            }
+          }
+        }
+        Core2.getReferenceEntriesForShorthandPropertyAssignment = getReferenceEntriesForShorthandPropertyAssignment;
+        function forEachDescendantOfKind(node, kind, action) {
+          forEachChild(node, (child) => {
+            if (child.kind === kind) {
+              action(child);
+            }
+            forEachDescendantOfKind(child, kind, action);
+          });
+        }
+        function tryGetClassByExtendingIdentifier(node) {
+          return tryGetClassExtendingExpressionWithTypeArguments(climbPastPropertyAccess(node).parent);
+        }
+        function getParentSymbolsOfPropertyAccess(location, symbol, checker) {
+          const propertyAccessExpression = isRightSideOfPropertyAccess(location) ? location.parent : void 0;
+          const lhsType = propertyAccessExpression && checker.getTypeAtLocation(propertyAccessExpression.expression);
+          const res = mapDefined(lhsType && (lhsType.isUnionOrIntersection() ? lhsType.types : lhsType.symbol === symbol.parent ? void 0 : [lhsType]), (t) => t.symbol && t.symbol.flags & (32 /* Class */ | 64 /* Interface */) ? t.symbol : void 0);
+          return res.length === 0 ? void 0 : res;
+        }
+        function isForRenameWithPrefixAndSuffixText(options) {
+          return options.use === 2 /* Rename */ && options.providePrefixAndSuffixTextForRename;
+        }
+      })(Core || (Core = {}));
+    }
+  });
+
+  // src/services/_namespaces/ts.FindAllReferences.ts
+  var ts_FindAllReferences_exports = {};
+  __export(ts_FindAllReferences_exports, {
+    Core: () => Core,
+    DefinitionKind: () => DefinitionKind,
+    EntryKind: () => EntryKind,
+    ExportKind: () => ExportKind2,
+    FindReferencesUse: () => FindReferencesUse,
+    ImportExport: () => ImportExport,
+    createImportTracker: () => createImportTracker,
+    findModuleReferences: () => findModuleReferences,
+    findReferenceOrRenameEntries: () => findReferenceOrRenameEntries,
+    findReferencedSymbols: () => findReferencedSymbols,
+    getContextNode: () => getContextNode,
+    getExportInfo: () => getExportInfo,
+    getImplementationsAtPosition: () => getImplementationsAtPosition,
+    getImportOrExportSymbol: () => getImportOrExportSymbol,
+    getReferenceEntriesForNode: () => getReferenceEntriesForNode,
+    getTextSpanOfEntry: () => getTextSpanOfEntry,
+    isContextWithStartAndEndNode: () => isContextWithStartAndEndNode,
+    isDeclarationOfSymbol: () => isDeclarationOfSymbol,
+    isWriteAccessForReference: () => isWriteAccessForReference,
+    nodeEntry: () => nodeEntry,
+    toContextSpan: () => toContextSpan,
+    toHighlightSpan: () => toHighlightSpan,
+    toReferenceEntry: () => toReferenceEntry,
+    toRenameLocation: () => toRenameLocation
+  });
+  var init_ts_FindAllReferences = __esm({
+    "src/services/_namespaces/ts.FindAllReferences.ts"() {
+      "use strict";
+      init_importTracker();
+      init_findAllReferences();
+    }
+  });
+
+  // src/services/goToDefinition.ts
+  function getDefinitionAtPosition(program, sourceFile, position, searchOtherFilesOnly, stopAtAlias) {
+    var _a;
+    const resolvedRef = getReferenceAtPosition(sourceFile, position, program);
+    const fileReferenceDefinition = resolvedRef && [getDefinitionInfoForFileReference(resolvedRef.reference.fileName, resolvedRef.fileName, resolvedRef.unverified)] || emptyArray;
+    if (resolvedRef == null ? void 0 : resolvedRef.file) {
+      return fileReferenceDefinition;
     }
-    function isPreviousPropertyDeclarationTerminated(contextToken2, position2) {
-      return contextToken2.kind !== 64 /* EqualsToken */ && (contextToken2.kind === 27 /* SemicolonToken */ || !positionsAreOnSameLine(contextToken2.end, position2, sourceFile));
+    const node = getTouchingPropertyName(sourceFile, position);
+    if (node === sourceFile) {
+      return void 0;
     }
-    function isFunctionLikeButNotConstructor(kind) {
-      return isFunctionLikeKind(kind) && kind !== 175 /* Constructor */;
+    const { parent: parent2 } = node;
+    const typeChecker = program.getTypeChecker();
+    if (node.kind === 164 /* OverrideKeyword */ || isIdentifier(node) && isJSDocOverrideTag(parent2) && parent2.tagName === node) {
+      return getDefinitionFromOverriddenMember(typeChecker, node) || emptyArray;
     }
-    function isDotOfNumericLiteral(contextToken2) {
-      if (contextToken2.kind === 9 /* NumericLiteral */) {
-        const text = contextToken2.getFullText();
-        return text.charAt(text.length - 1) === ".";
-      }
-      return false;
+    if (isJumpStatementTarget(node)) {
+      const label = getTargetLabel(node.parent, node.text);
+      return label ? [createDefinitionInfoFromName(
+        typeChecker,
+        label,
+        "label" /* label */,
+        node.text,
+        /*containerName*/
+        void 0
+      )] : void 0;
     }
-    function isVariableDeclarationListButNotTypeArgument(node2) {
-      return node2.parent.kind === 260 /* VariableDeclarationList */ && !isPossiblyTypeArgumentPosition(node2, sourceFile, typeChecker);
+    if (node.kind === 107 /* ReturnKeyword */) {
+      const functionDeclaration = findAncestor(node.parent, (n) => isClassStaticBlockDeclaration(n) ? "quit" : isFunctionLikeDeclaration(n));
+      return functionDeclaration ? [createDefinitionFromSignatureDeclaration(typeChecker, functionDeclaration)] : void 0;
     }
-    function filterObjectMembersList(contextualMemberSymbols, existingMembers) {
-      if (existingMembers.length === 0) {
-        return contextualMemberSymbols;
-      }
-      const membersDeclaredBySpreadAssignment = /* @__PURE__ */ new Set();
-      const existingMemberNames = /* @__PURE__ */ new Set();
-      for (const m of existingMembers) {
-        if (m.kind !== 302 /* PropertyAssignment */ && m.kind !== 303 /* ShorthandPropertyAssignment */ && m.kind !== 207 /* BindingElement */ && m.kind !== 173 /* MethodDeclaration */ && m.kind !== 176 /* GetAccessor */ && m.kind !== 177 /* SetAccessor */ && m.kind !== 304 /* SpreadAssignment */) {
-          continue;
-        }
-        if (isCurrentlyEditingNode(m)) {
-          continue;
-        }
-        let existingName;
-        if (isSpreadAssignment(m)) {
-          setMembersDeclaredBySpreadAssignment(m, membersDeclaredBySpreadAssignment);
-        } else if (isBindingElement(m) && m.propertyName) {
-          if (m.propertyName.kind === 80 /* Identifier */) {
-            existingName = m.propertyName.escapedText;
-          }
-        } else {
-          const name = getNameOfDeclaration(m);
-          existingName = name && isPropertyNameLiteral(name) ? getEscapedTextOfIdentifierOrLiteral(name) : void 0;
-        }
-        if (existingName !== void 0) {
-          existingMemberNames.add(existingName);
-        }
-      }
-      const filteredSymbols = contextualMemberSymbols.filter((m) => !existingMemberNames.has(m.escapedName));
-      setSortTextToMemberDeclaredBySpreadAssignment(membersDeclaredBySpreadAssignment, filteredSymbols);
-      return filteredSymbols;
+    if (node.kind === 135 /* AwaitKeyword */) {
+      const functionDeclaration = findAncestor(node, (n) => isFunctionLikeDeclaration(n));
+      const isAsyncFunction2 = functionDeclaration && some(functionDeclaration.modifiers, (node2) => node2.kind === 134 /* AsyncKeyword */);
+      return isAsyncFunction2 ? [createDefinitionFromSignatureDeclaration(typeChecker, functionDeclaration)] : void 0;
     }
-    function setMembersDeclaredBySpreadAssignment(declaration, membersDeclaredBySpreadAssignment) {
-      const expression = declaration.expression;
-      const symbol = typeChecker.getSymbolAtLocation(expression);
-      const type = symbol && typeChecker.getTypeOfSymbolAtLocation(symbol, expression);
-      const properties = type && type.properties;
-      if (properties) {
-        properties.forEach((property) => {
-          membersDeclaredBySpreadAssignment.add(property.name);
-        });
-      }
+    if (node.kind === 127 /* YieldKeyword */) {
+      const functionDeclaration = findAncestor(node, (n) => isFunctionLikeDeclaration(n));
+      const isGeneratorFunction = functionDeclaration && functionDeclaration.asteriskToken;
+      return isGeneratorFunction ? [createDefinitionFromSignatureDeclaration(typeChecker, functionDeclaration)] : void 0;
     }
-    function setSortTextToOptionalMember() {
-      symbols.forEach((m) => {
-        if (m.flags & 16777216 /* Optional */) {
-          const symbolId = getSymbolId(m);
-          symbolToSortTextMap[symbolId] = symbolToSortTextMap[symbolId] ?? SortText.OptionalMember;
-        }
+    if (isStaticModifier(node) && isClassStaticBlockDeclaration(node.parent)) {
+      const classDecl = node.parent.parent;
+      const { symbol: symbol2, failedAliasResolution: failedAliasResolution2 } = getSymbol(classDecl, typeChecker, stopAtAlias);
+      const staticBlocks = filter(classDecl.members, isClassStaticBlockDeclaration);
+      const containerName = symbol2 ? typeChecker.symbolToString(symbol2, classDecl) : "";
+      const sourceFile2 = node.getSourceFile();
+      return map(staticBlocks, (staticBlock) => {
+        let { pos } = moveRangePastModifiers(staticBlock);
+        pos = skipTrivia(sourceFile2.text, pos);
+        return createDefinitionInfoFromName(
+          typeChecker,
+          staticBlock,
+          "constructor" /* constructorImplementationElement */,
+          "static {}",
+          containerName,
+          /*unverified*/
+          false,
+          failedAliasResolution2,
+          { start: pos, length: "static".length }
+        );
       });
     }
-    function setSortTextToMemberDeclaredBySpreadAssignment(membersDeclaredBySpreadAssignment, contextualMemberSymbols) {
-      if (membersDeclaredBySpreadAssignment.size === 0) {
-        return;
-      }
-      for (const contextualMemberSymbol of contextualMemberSymbols) {
-        if (membersDeclaredBySpreadAssignment.has(contextualMemberSymbol.name)) {
-          symbolToSortTextMap[getSymbolId(contextualMemberSymbol)] = SortText.MemberDeclaredBySpreadAssignment;
-        }
+    let { symbol, failedAliasResolution } = getSymbol(node, typeChecker, stopAtAlias);
+    let fallbackNode = node;
+    if (searchOtherFilesOnly && failedAliasResolution) {
+      const importDeclaration = forEach([node, ...(symbol == null ? void 0 : symbol.declarations) || emptyArray], (n) => findAncestor(n, isAnyImportOrBareOrAccessedRequire));
+      const moduleSpecifier = importDeclaration && tryGetModuleSpecifierFromDeclaration(importDeclaration);
+      if (moduleSpecifier) {
+        ({ symbol, failedAliasResolution } = getSymbol(moduleSpecifier, typeChecker, stopAtAlias));
+        fallbackNode = moduleSpecifier;
       }
     }
-    function transformObjectLiteralMembersSortText(start2) {
-      for (let i = start2; i < symbols.length; i++) {
-        const symbol = symbols[i];
-        const symbolId = getSymbolId(symbol);
-        const origin = symbolToOriginInfoMap == null ? void 0 : symbolToOriginInfoMap[i];
-        const target = getEmitScriptTarget(compilerOptions);
-        const displayName = getCompletionEntryDisplayNameForSymbol(
-          symbol,
-          target,
-          origin,
-          0 /* ObjectPropertyDeclaration */,
-          /*jsxIdentifierExpected*/
-          false
-        );
-        if (displayName) {
-          const originalSortText = symbolToSortTextMap[symbolId] ?? SortText.LocationPriority;
-          const { name } = displayName;
-          symbolToSortTextMap[symbolId] = SortText.ObjectLiteralProperty(originalSortText, name);
-        }
+    if (!symbol && isModuleSpecifierLike(fallbackNode)) {
+      const ref = (_a = program.getResolvedModule(sourceFile, fallbackNode.text, getModeForUsageLocation(sourceFile, fallbackNode))) == null ? void 0 : _a.resolvedModule;
+      if (ref) {
+        return [{
+          name: fallbackNode.text,
+          fileName: ref.resolvedFileName,
+          containerName: void 0,
+          containerKind: void 0,
+          kind: "script" /* scriptElement */,
+          textSpan: createTextSpan(0, 0),
+          failedAliasResolution,
+          isAmbient: isDeclarationFileName(ref.resolvedFileName),
+          unverified: fallbackNode !== node
+        }];
       }
     }
-    function filterClassMembersList(baseSymbols, existingMembers, currentClassElementModifierFlags) {
-      const existingMemberNames = /* @__PURE__ */ new Set();
-      for (const m of existingMembers) {
-        if (m.kind !== 171 /* PropertyDeclaration */ && m.kind !== 173 /* MethodDeclaration */ && m.kind !== 176 /* GetAccessor */ && m.kind !== 177 /* SetAccessor */) {
-          continue;
-        }
-        if (isCurrentlyEditingNode(m)) {
-          continue;
-        }
-        if (hasEffectiveModifier(m, 8 /* Private */)) {
-          continue;
-        }
-        if (isStatic(m) !== !!(currentClassElementModifierFlags & 32 /* Static */)) {
-          continue;
-        }
-        const existingName = getPropertyNameForPropertyNameNode(m.name);
-        if (existingName) {
-          existingMemberNames.add(existingName);
-        }
-      }
-      return baseSymbols.filter((propertySymbol) => !existingMemberNames.has(propertySymbol.escapedName) && !!propertySymbol.declarations && !(getDeclarationModifierFlagsFromSymbol(propertySymbol) & 8 /* Private */) && !(propertySymbol.valueDeclaration && isPrivateIdentifierClassElementDeclaration(propertySymbol.valueDeclaration)));
+    if (!symbol) {
+      return concatenate(fileReferenceDefinition, getDefinitionInfoForIndexSignatures(node, typeChecker));
     }
-    function filterJsxAttributes(symbols2, attributes) {
-      const seenNames = /* @__PURE__ */ new Set();
-      const membersDeclaredBySpreadAssignment = /* @__PURE__ */ new Set();
-      for (const attr of attributes) {
-        if (isCurrentlyEditingNode(attr)) {
-          continue;
-        }
-        if (attr.kind === 290 /* JsxAttribute */) {
-          seenNames.add(getEscapedTextOfJsxAttributeName(attr.name));
-        } else if (isJsxSpreadAttribute(attr)) {
-          setMembersDeclaredBySpreadAssignment(attr, membersDeclaredBySpreadAssignment);
-        }
+    if (searchOtherFilesOnly && every(symbol.declarations, (d) => d.getSourceFile().fileName === sourceFile.fileName))
+      return void 0;
+    const calledDeclaration = tryGetSignatureDeclaration(typeChecker, node);
+    if (calledDeclaration && !(isJsxOpeningLikeElement(node.parent) && isConstructorLike(calledDeclaration))) {
+      const sigInfo = createDefinitionFromSignatureDeclaration(typeChecker, calledDeclaration, failedAliasResolution);
+      if (typeChecker.getRootSymbols(symbol).some((s) => symbolMatchesSignature(s, calledDeclaration))) {
+        return [sigInfo];
+      } else {
+        const defs = getDefinitionFromSymbol(typeChecker, symbol, node, failedAliasResolution, calledDeclaration) || emptyArray;
+        return node.kind === 108 /* SuperKeyword */ ? [sigInfo, ...defs] : [...defs, sigInfo];
       }
-      const filteredSymbols = symbols2.filter((a) => !seenNames.has(a.escapedName));
-      setSortTextToMemberDeclaredBySpreadAssignment(membersDeclaredBySpreadAssignment, filteredSymbols);
-      return filteredSymbols;
     }
-    function isCurrentlyEditingNode(node2) {
-      return node2.getStart(sourceFile) <= position && position <= node2.getEnd();
+    if (node.parent.kind === 304 /* ShorthandPropertyAssignment */) {
+      const shorthandSymbol = typeChecker.getShorthandAssignmentValueSymbol(symbol.valueDeclaration);
+      const definitions = (shorthandSymbol == null ? void 0 : shorthandSymbol.declarations) ? shorthandSymbol.declarations.map((decl) => createDefinitionInfo(
+        decl,
+        typeChecker,
+        shorthandSymbol,
+        node,
+        /*unverified*/
+        false,
+        failedAliasResolution
+      )) : emptyArray;
+      return concatenate(definitions, getDefinitionFromObjectLiteralElement(typeChecker, node));
     }
-  }
-  function tryGetObjectLikeCompletionContainer(contextToken) {
-    if (contextToken) {
-      const { parent: parent2 } = contextToken;
-      switch (contextToken.kind) {
-        case 19 /* OpenBraceToken */:
-        case 28 /* CommaToken */:
-          if (isObjectLiteralExpression(parent2) || isObjectBindingPattern(parent2)) {
-            return parent2;
-          }
-          break;
-        case 42 /* AsteriskToken */:
-          return isMethodDeclaration(parent2) ? tryCast(parent2.parent, isObjectLiteralExpression) : void 0;
-        case 134 /* AsyncKeyword */:
-          return tryCast(parent2.parent, isObjectLiteralExpression);
-        case 80 /* Identifier */:
-          return contextToken.text === "async" && isShorthandPropertyAssignment(contextToken.parent) ? contextToken.parent.parent : void 0;
-      }
+    if (isPropertyName(node) && isBindingElement(parent2) && isObjectBindingPattern(parent2.parent) && node === (parent2.propertyName || parent2.name)) {
+      const name = getNameFromPropertyName(node);
+      const type = typeChecker.getTypeAtLocation(parent2.parent);
+      return name === void 0 ? emptyArray : flatMap(type.isUnion() ? type.types : [type], (t) => {
+        const prop = t.getProperty(name);
+        return prop && getDefinitionFromSymbol(typeChecker, prop, node);
+      });
     }
-    return void 0;
+    const objectLiteralElementDefinition = getDefinitionFromObjectLiteralElement(typeChecker, node);
+    return concatenate(fileReferenceDefinition, objectLiteralElementDefinition.length ? objectLiteralElementDefinition : getDefinitionFromSymbol(typeChecker, symbol, node, failedAliasResolution));
   }
-  function getRelevantTokens(position, sourceFile) {
-    const previousToken = findPrecedingToken(position, sourceFile);
-    if (previousToken && position <= previousToken.end && (isMemberName(previousToken) || isKeyword(previousToken.kind))) {
-      const contextToken = findPrecedingToken(
-        previousToken.getFullStart(),
-        sourceFile,
-        /*startNode*/
-        void 0
-      );
-      return { contextToken, previousToken };
+  function symbolMatchesSignature(s, calledDeclaration) {
+    var _a;
+    return s === calledDeclaration.symbol || s === calledDeclaration.symbol.parent || isAssignmentExpression(calledDeclaration.parent) || !isCallLikeExpression(calledDeclaration.parent) && s === ((_a = tryCast(calledDeclaration.parent, canHaveSymbol)) == null ? void 0 : _a.symbol);
+  }
+  function getDefinitionFromObjectLiteralElement(typeChecker, node) {
+    const element = getContainingObjectLiteralElement(node);
+    if (element) {
+      const contextualType = element && typeChecker.getContextualType(element.parent);
+      if (contextualType) {
+        return flatMap(getPropertySymbolsFromContextualType(
+          element,
+          typeChecker,
+          contextualType,
+          /*unionSymbolOk*/
+          false
+        ), (propertySymbol) => getDefinitionFromSymbol(typeChecker, propertySymbol, node));
+      }
     }
-    return { contextToken: previousToken, previousToken };
+    return emptyArray;
   }
-  function getAutoImportSymbolFromCompletionEntryData(name, data, program, host) {
-    const containingProgram = data.isPackageJsonImport ? host.getPackageJsonAutoImportProvider() : program;
-    const checker = containingProgram.getTypeChecker();
-    const moduleSymbol = data.ambientModuleName ? checker.tryFindAmbientModule(data.ambientModuleName) : data.fileName ? checker.getMergedSymbol(Debug.checkDefined(containingProgram.getSourceFile(data.fileName)).symbol) : void 0;
-    if (!moduleSymbol)
-      return void 0;
-    let symbol = data.exportName === "export=" /* ExportEquals */ ? checker.resolveExternalModuleSymbol(moduleSymbol) : checker.tryGetMemberInModuleExportsAndProperties(data.exportName, moduleSymbol);
+  function getDefinitionFromOverriddenMember(typeChecker, node) {
+    const classElement = findAncestor(node, isClassElement);
+    if (!(classElement && classElement.name))
+      return;
+    const baseDeclaration = findAncestor(classElement, isClassLike);
+    if (!baseDeclaration)
+      return;
+    const baseTypeNode = getEffectiveBaseTypeNode(baseDeclaration);
+    if (!baseTypeNode)
+      return;
+    const expression = skipParentheses(baseTypeNode.expression);
+    const base = isClassExpression(expression) ? expression.symbol : typeChecker.getSymbolAtLocation(expression);
+    if (!base)
+      return;
+    const name = unescapeLeadingUnderscores(getTextOfPropertyName(classElement.name));
+    const symbol = hasStaticModifier(classElement) ? typeChecker.getPropertyOfType(typeChecker.getTypeOfSymbol(base), name) : typeChecker.getPropertyOfType(typeChecker.getDeclaredTypeOfSymbol(base), name);
     if (!symbol)
-      return void 0;
-    const isDefaultExport = data.exportName === "default" /* Default */;
-    symbol = isDefaultExport && getLocalSymbolForExportDefault(symbol) || symbol;
-    return { symbol, origin: completionEntryDataToSymbolOriginInfo(data, name, moduleSymbol) };
+      return;
+    return getDefinitionFromSymbol(typeChecker, symbol, node);
   }
-  function getCompletionEntryDisplayNameForSymbol(symbol, target, origin, kind, jsxIdentifierExpected) {
-    if (originIsIgnore(origin)) {
-      return void 0;
+  function getReferenceAtPosition(sourceFile, position, program) {
+    var _a, _b;
+    const referencePath = findReferenceInPosition(sourceFile.referencedFiles, position);
+    if (referencePath) {
+      const file = program.getSourceFileFromReference(sourceFile, referencePath);
+      return file && { reference: referencePath, fileName: file.fileName, file, unverified: false };
     }
-    const name = originIncludesSymbolName(origin) ? origin.symbolName : symbol.name;
-    if (name === void 0 || symbol.flags & 1536 /* Module */ && isSingleOrDoubleQuote(name.charCodeAt(0)) || isKnownSymbol(symbol)) {
-      return void 0;
+    const typeReferenceDirective = findReferenceInPosition(sourceFile.typeReferenceDirectives, position);
+    if (typeReferenceDirective) {
+      const reference = (_a = program.getResolvedTypeReferenceDirectives().get(typeReferenceDirective.fileName, typeReferenceDirective.resolutionMode || sourceFile.impliedNodeFormat)) == null ? void 0 : _a.resolvedTypeReferenceDirective;
+      const file = reference && program.getSourceFile(reference.resolvedFileName);
+      return file && { reference: typeReferenceDirective, fileName: file.fileName, file, unverified: false };
     }
-    const validNameResult = { name, needsConvertPropertyAccess: false };
-    if (isIdentifierText(name, target, jsxIdentifierExpected ? 1 /* JSX */ : 0 /* Standard */) || symbol.valueDeclaration && isPrivateIdentifierClassElementDeclaration(symbol.valueDeclaration)) {
-      return validNameResult;
+    const libReferenceDirective = findReferenceInPosition(sourceFile.libReferenceDirectives, position);
+    if (libReferenceDirective) {
+      const file = program.getLibFileFromReference(libReferenceDirective);
+      return file && { reference: libReferenceDirective, fileName: file.fileName, file, unverified: false };
     }
-    switch (kind) {
-      case 3 /* MemberLike */:
-        return originIsComputedPropertyName(origin) ? { name: origin.symbolName, needsConvertPropertyAccess: false } : void 0;
-      case 0 /* ObjectPropertyDeclaration */:
-        return { name: JSON.stringify(name), needsConvertPropertyAccess: false };
-      case 2 /* PropertyAccess */:
-      case 1 /* Global */:
-        return name.charCodeAt(0) === 32 /* space */ ? void 0 : { name, needsConvertPropertyAccess: true };
-      case 5 /* None */:
-      case 4 /* String */:
-        return validNameResult;
-      default:
-        Debug.assertNever(kind);
+    if (sourceFile.imports.length || sourceFile.moduleAugmentations.length) {
+      const node = getTouchingToken(sourceFile, position);
+      let resolution;
+      if (isModuleSpecifierLike(node) && isExternalModuleNameRelative(node.text) && (resolution = program.getResolvedModule(sourceFile, node.text, getModeForUsageLocation(sourceFile, node)))) {
+        const verifiedFileName = (_b = resolution.resolvedModule) == null ? void 0 : _b.resolvedFileName;
+        const fileName = verifiedFileName || resolvePath(getDirectoryPath(sourceFile.fileName), node.text);
+        return {
+          file: program.getSourceFile(fileName),
+          fileName,
+          reference: {
+            pos: node.getStart(),
+            end: node.getEnd(),
+            fileName: node.text
+          },
+          unverified: !verifiedFileName
+        };
+      }
     }
+    return void 0;
   }
-  function getKeywordCompletions(keywordFilter, filterOutTsOnlyKeywords) {
-    if (!filterOutTsOnlyKeywords)
-      return getTypescriptKeywordCompletions(keywordFilter);
-    const index = keywordFilter + 8 /* Last */ + 1;
-    return _keywordCompletions[index] || (_keywordCompletions[index] = getTypescriptKeywordCompletions(keywordFilter).filter((entry) => !isTypeScriptOnlyKeyword(stringToToken(entry.name))));
+  function shouldUnwrapFirstTypeArgumentTypeDefinitionFromTypeReference(typeChecker, type) {
+    const referenceName = type.symbol.name;
+    if (!typesWithUnwrappedTypeArguments.has(referenceName)) {
+      return false;
+    }
+    const globalType = typeChecker.resolveName(
+      referenceName,
+      /*location*/
+      void 0,
+      788968 /* Type */,
+      /*excludeGlobals*/
+      false
+    );
+    return !!globalType && globalType === type.target.symbol;
   }
-  function getTypescriptKeywordCompletions(keywordFilter) {
-    return _keywordCompletions[keywordFilter] || (_keywordCompletions[keywordFilter] = allKeywordsCompletions().filter((entry) => {
-      const kind = stringToToken(entry.name);
-      switch (keywordFilter) {
-        case 0 /* None */:
-          return false;
-        case 1 /* All */:
-          return isFunctionLikeBodyKeyword(kind) || kind === 138 /* DeclareKeyword */ || kind === 144 /* ModuleKeyword */ || kind === 156 /* TypeKeyword */ || kind === 145 /* NamespaceKeyword */ || kind === 128 /* AbstractKeyword */ || isTypeKeyword(kind) && kind !== 157 /* UndefinedKeyword */;
-        case 5 /* FunctionLikeBodyKeywords */:
-          return isFunctionLikeBodyKeyword(kind);
-        case 2 /* ClassElementKeywords */:
-          return isClassMemberCompletionKeyword(kind);
-        case 3 /* InterfaceElementKeywords */:
-          return isInterfaceOrTypeLiteralCompletionKeyword(kind);
-        case 4 /* ConstructorParameterKeywords */:
-          return isParameterPropertyModifier(kind);
-        case 6 /* TypeAssertionKeywords */:
-          return isTypeKeyword(kind) || kind === 87 /* ConstKeyword */;
-        case 7 /* TypeKeywords */:
-          return isTypeKeyword(kind);
-        case 8 /* TypeKeyword */:
-          return kind === 156 /* TypeKeyword */;
-        default:
-          return Debug.assertNever(keywordFilter);
+  function shouldUnwrapFirstTypeArgumentTypeDefinitionFromAlias(typeChecker, type) {
+    if (!type.aliasSymbol) {
+      return false;
+    }
+    const referenceName = type.aliasSymbol.name;
+    if (!typesWithUnwrappedTypeArguments.has(referenceName)) {
+      return false;
+    }
+    const globalType = typeChecker.resolveName(
+      referenceName,
+      /*location*/
+      void 0,
+      788968 /* Type */,
+      /*excludeGlobals*/
+      false
+    );
+    return !!globalType && globalType === type.aliasSymbol;
+  }
+  function getFirstTypeArgumentDefinitions(typeChecker, type, node, failedAliasResolution) {
+    var _a, _b;
+    if (!!(getObjectFlags(type) & 4 /* Reference */) && shouldUnwrapFirstTypeArgumentTypeDefinitionFromTypeReference(typeChecker, type)) {
+      return definitionFromType(typeChecker.getTypeArguments(type)[0], typeChecker, node, failedAliasResolution);
+    }
+    if (shouldUnwrapFirstTypeArgumentTypeDefinitionFromAlias(typeChecker, type) && type.aliasTypeArguments) {
+      return definitionFromType(type.aliasTypeArguments[0], typeChecker, node, failedAliasResolution);
+    }
+    if (getObjectFlags(type) & 32 /* Mapped */ && type.target && shouldUnwrapFirstTypeArgumentTypeDefinitionFromAlias(typeChecker, type.target)) {
+      const declaration = (_b = (_a = type.aliasSymbol) == null ? void 0 : _a.declarations) == null ? void 0 : _b[0];
+      if (declaration && isTypeAliasDeclaration(declaration) && isTypeReferenceNode(declaration.type) && declaration.type.typeArguments) {
+        return definitionFromType(typeChecker.getTypeAtLocation(declaration.type.typeArguments[0]), typeChecker, node, failedAliasResolution);
       }
-    }));
+    }
+    return [];
   }
-  function isTypeScriptOnlyKeyword(kind) {
-    switch (kind) {
-      case 128 /* AbstractKeyword */:
-      case 133 /* AnyKeyword */:
-      case 162 /* BigIntKeyword */:
-      case 136 /* BooleanKeyword */:
-      case 138 /* DeclareKeyword */:
-      case 94 /* EnumKeyword */:
-      case 161 /* GlobalKeyword */:
-      case 119 /* ImplementsKeyword */:
-      case 140 /* InferKeyword */:
-      case 120 /* InterfaceKeyword */:
-      case 142 /* IsKeyword */:
-      case 143 /* KeyOfKeyword */:
-      case 144 /* ModuleKeyword */:
-      case 145 /* NamespaceKeyword */:
-      case 146 /* NeverKeyword */:
-      case 150 /* NumberKeyword */:
-      case 151 /* ObjectKeyword */:
-      case 163 /* OverrideKeyword */:
-      case 123 /* PrivateKeyword */:
-      case 124 /* ProtectedKeyword */:
-      case 125 /* PublicKeyword */:
-      case 148 /* ReadonlyKeyword */:
-      case 154 /* StringKeyword */:
-      case 155 /* SymbolKeyword */:
-      case 156 /* TypeKeyword */:
-      case 158 /* UniqueKeyword */:
-      case 159 /* UnknownKeyword */:
-        return true;
-      default:
-        return false;
+  function getTypeDefinitionAtPosition(typeChecker, sourceFile, position) {
+    const node = getTouchingPropertyName(sourceFile, position);
+    if (node === sourceFile) {
+      return void 0;
+    }
+    if (isImportMeta(node.parent) && node.parent.name === node) {
+      return definitionFromType(
+        typeChecker.getTypeAtLocation(node.parent),
+        typeChecker,
+        node.parent,
+        /*failedAliasResolution*/
+        false
+      );
     }
+    const { symbol, failedAliasResolution } = getSymbol(
+      node,
+      typeChecker,
+      /*stopAtAlias*/
+      false
+    );
+    if (!symbol)
+      return void 0;
+    const typeAtLocation = typeChecker.getTypeOfSymbolAtLocation(symbol, node);
+    const returnType = tryGetReturnTypeOfFunction(symbol, typeAtLocation, typeChecker);
+    const fromReturnType = returnType && definitionFromType(returnType, typeChecker, node, failedAliasResolution);
+    const [resolvedType, typeDefinitions] = fromReturnType && fromReturnType.length !== 0 ? [returnType, fromReturnType] : [typeAtLocation, definitionFromType(typeAtLocation, typeChecker, node, failedAliasResolution)];
+    return typeDefinitions.length ? [...getFirstTypeArgumentDefinitions(typeChecker, resolvedType, node, failedAliasResolution), ...typeDefinitions] : !(symbol.flags & 111551 /* Value */) && symbol.flags & 788968 /* Type */ ? getDefinitionFromSymbol(typeChecker, skipAlias(symbol, typeChecker), node, failedAliasResolution) : void 0;
   }
-  function isInterfaceOrTypeLiteralCompletionKeyword(kind) {
-    return kind === 148 /* ReadonlyKeyword */;
+  function definitionFromType(type, checker, node, failedAliasResolution) {
+    return flatMap(type.isUnion() && !(type.flags & 32 /* Enum */) ? type.types : [type], (t) => t.symbol && getDefinitionFromSymbol(checker, t.symbol, node, failedAliasResolution));
   }
-  function isClassMemberCompletionKeyword(kind) {
-    switch (kind) {
-      case 128 /* AbstractKeyword */:
-      case 129 /* AccessorKeyword */:
-      case 137 /* ConstructorKeyword */:
-      case 139 /* GetKeyword */:
-      case 153 /* SetKeyword */:
-      case 134 /* AsyncKeyword */:
-      case 138 /* DeclareKeyword */:
-      case 163 /* OverrideKeyword */:
-        return true;
-      default:
-        return isClassMemberModifier(kind);
+  function tryGetReturnTypeOfFunction(symbol, type, checker) {
+    if (type.symbol === symbol || // At `const f = () => {}`, the symbol is `f` and the type symbol is at `() => {}`
+    symbol.valueDeclaration && type.symbol && isVariableDeclaration(symbol.valueDeclaration) && symbol.valueDeclaration.initializer === type.symbol.valueDeclaration) {
+      const sigs = type.getCallSignatures();
+      if (sigs.length === 1)
+        return checker.getReturnTypeOfSignature(first(sigs));
     }
+    return void 0;
   }
-  function isFunctionLikeBodyKeyword(kind) {
-    return kind === 134 /* AsyncKeyword */ || kind === 135 /* AwaitKeyword */ || kind === 130 /* AsKeyword */ || kind === 152 /* SatisfiesKeyword */ || kind === 156 /* TypeKeyword */ || !isContextualKeyword(kind) && !isClassMemberCompletionKeyword(kind);
+  function getDefinitionAndBoundSpan(program, sourceFile, position) {
+    const definitions = getDefinitionAtPosition(program, sourceFile, position);
+    if (!definitions || definitions.length === 0) {
+      return void 0;
+    }
+    const comment = findReferenceInPosition(sourceFile.referencedFiles, position) || findReferenceInPosition(sourceFile.typeReferenceDirectives, position) || findReferenceInPosition(sourceFile.libReferenceDirectives, position);
+    if (comment) {
+      return { definitions, textSpan: createTextSpanFromRange(comment) };
+    }
+    const node = getTouchingPropertyName(sourceFile, position);
+    const textSpan = createTextSpan(node.getStart(), node.getWidth());
+    return { definitions, textSpan };
   }
-  function keywordForNode(node) {
-    return isIdentifier(node) ? identifierToKeywordKind(node) ?? 0 /* Unknown */ : node.kind;
+  function getDefinitionInfoForIndexSignatures(node, checker) {
+    return mapDefined(checker.getIndexInfosAtLocation(node), (info) => info.declaration && createDefinitionFromSignatureDeclaration(checker, info.declaration));
   }
-  function getContextualKeywords(contextToken, position) {
-    const entries = [];
-    if (contextToken) {
-      const file = contextToken.getSourceFile();
-      const parent2 = contextToken.parent;
-      const tokenLine = file.getLineAndCharacterOfPosition(contextToken.end).line;
-      const currentLine = file.getLineAndCharacterOfPosition(position).line;
-      if ((isImportDeclaration(parent2) || isExportDeclaration(parent2) && parent2.moduleSpecifier) && contextToken === parent2.moduleSpecifier && tokenLine === currentLine) {
-        entries.push({
-          name: tokenToString(132 /* AssertKeyword */),
-          kind: "keyword" /* keyword */,
-          kindModifiers: "" /* none */,
-          sortText: SortText.GlobalsOrKeywords
-        });
+  function getSymbol(node, checker, stopAtAlias) {
+    const symbol = checker.getSymbolAtLocation(node);
+    let failedAliasResolution = false;
+    if ((symbol == null ? void 0 : symbol.declarations) && symbol.flags & 2097152 /* Alias */ && !stopAtAlias && shouldSkipAlias(node, symbol.declarations[0])) {
+      const aliased = checker.getAliasedSymbol(symbol);
+      if (aliased.declarations) {
+        return { symbol: aliased };
+      } else {
+        failedAliasResolution = true;
       }
     }
-    return entries;
-  }
-  function getJsDocTagAtPosition(node, position) {
-    return findAncestor(node, (n) => isJSDocTag(n) && rangeContainsPosition(n, position) ? true : isJSDoc(n) ? "quit" : false);
+    return { symbol, failedAliasResolution };
   }
-  function getPropertiesForObjectExpression(contextualType, completionsType, obj, checker) {
-    const hasCompletionsType = completionsType && completionsType !== contextualType;
-    const type = hasCompletionsType && !(completionsType.flags & 3 /* AnyOrUnknown */) ? checker.getUnionType([contextualType, completionsType]) : contextualType;
-    const properties = getApparentProperties(type, obj, checker);
-    return type.isClass() && containsNonPublicProperties(properties) ? [] : hasCompletionsType ? filter(properties, hasDeclarationOtherThanSelf) : properties;
-    function hasDeclarationOtherThanSelf(member) {
-      if (!length(member.declarations))
-        return true;
-      return some(member.declarations, (decl) => decl.parent !== obj);
+  function shouldSkipAlias(node, declaration) {
+    if (node.kind !== 80 /* Identifier */) {
+      return false;
     }
+    if (node.parent === declaration) {
+      return true;
+    }
+    if (declaration.kind === 274 /* NamespaceImport */) {
+      return false;
+    }
+    return true;
   }
-  function getApparentProperties(type, node, checker) {
-    if (!type.isUnion())
-      return type.getApparentProperties();
-    return checker.getAllPossiblePropertiesOfTypes(filter(type.types, (memberType) => !(memberType.flags & 402784252 /* Primitive */ || checker.isArrayLikeType(memberType) || checker.isTypeInvalidDueToUnionDiscriminant(memberType, node) || checker.typeHasCallOrConstructSignatures(memberType) || memberType.isClass() && containsNonPublicProperties(memberType.getApparentProperties()))));
-  }
-  function containsNonPublicProperties(props) {
-    return some(props, (p) => !!(getDeclarationModifierFlagsFromSymbol(p) & 24 /* NonPublicAccessibilityModifier */));
-  }
-  function getPropertiesForCompletion(type, checker) {
-    return type.isUnion() ? Debug.checkEachDefined(checker.getAllPossiblePropertiesOfTypes(type.types), "getAllPossiblePropertiesOfTypes() should all be defined") : Debug.checkEachDefined(type.getApparentProperties(), "getApparentProperties() should all be defined");
+  function isExpandoDeclaration(node) {
+    if (!isAssignmentDeclaration(node))
+      return false;
+    const containingAssignment = findAncestor(node, (p) => {
+      if (isAssignmentExpression(p))
+        return true;
+      if (!isAssignmentDeclaration(p))
+        return "quit";
+      return false;
+    });
+    return !!containingAssignment && getAssignmentDeclarationKind(containingAssignment) === 5 /* Property */;
   }
-  function tryGetObjectTypeDeclarationCompletionContainer(sourceFile, contextToken, location, position) {
-    switch (location.kind) {
-      case 357 /* SyntaxList */:
-        return tryCast(location.parent, isObjectTypeDeclaration);
-      case 1 /* EndOfFileToken */:
-        const cls = tryCast(lastOrUndefined(cast(location.parent, isSourceFile).statements), isObjectTypeDeclaration);
-        if (cls && !findChildOfKind(cls, 20 /* CloseBraceToken */, sourceFile)) {
-          return cls;
-        }
-        break;
-      case 80 /* Identifier */: {
-        const originalKeywordKind = identifierToKeywordKind(location);
-        if (originalKeywordKind) {
-          return void 0;
-        }
-        if (isPropertyDeclaration(location.parent) && location.parent.initializer === location) {
-          return void 0;
-        }
-        if (isFromObjectTypeDeclaration(location)) {
-          return findAncestor(location, isObjectTypeDeclaration);
-        }
+  function getDefinitionFromSymbol(typeChecker, symbol, node, failedAliasResolution, excludeDeclaration) {
+    const filteredDeclarations = filter(symbol.declarations, (d) => d !== excludeDeclaration);
+    const withoutExpandos = filter(filteredDeclarations, (d) => !isExpandoDeclaration(d));
+    const results = some(withoutExpandos) ? withoutExpandos : filteredDeclarations;
+    return getConstructSignatureDefinition() || getCallSignatureDefinition() || map(results, (declaration) => createDefinitionInfo(
+      declaration,
+      typeChecker,
+      symbol,
+      node,
+      /*unverified*/
+      false,
+      failedAliasResolution
+    ));
+    function getConstructSignatureDefinition() {
+      if (symbol.flags & 32 /* Class */ && !(symbol.flags & (16 /* Function */ | 3 /* Variable */)) && (isNewExpressionTarget(node) || node.kind === 137 /* ConstructorKeyword */)) {
+        const cls = find(filteredDeclarations, isClassLike) || Debug.fail("Expected declaration to have at least one class-like declaration");
+        return getSignatureDefinition(
+          cls.members,
+          /*selectConstructors*/
+          true
+        );
       }
     }
-    if (!contextToken)
-      return void 0;
-    if (location.kind === 137 /* ConstructorKeyword */ || isIdentifier(contextToken) && isPropertyDeclaration(contextToken.parent) && isClassLike(location)) {
-      return findAncestor(contextToken, isClassLike);
+    function getCallSignatureDefinition() {
+      return isCallOrNewExpressionTarget(node) || isNameOfFunctionDeclaration(node) ? getSignatureDefinition(
+        filteredDeclarations,
+        /*selectConstructors*/
+        false
+      ) : void 0;
     }
-    switch (contextToken.kind) {
-      case 64 /* EqualsToken */:
-        return void 0;
-      case 27 /* SemicolonToken */:
-      case 20 /* CloseBraceToken */:
-        return isFromObjectTypeDeclaration(location) && location.parent.name === location ? location.parent.parent : tryCast(location, isObjectTypeDeclaration);
-      case 19 /* OpenBraceToken */:
-      case 28 /* CommaToken */:
-        return tryCast(contextToken.parent, isObjectTypeDeclaration);
-      default:
-        if (isObjectTypeDeclaration(location)) {
-          if (getLineAndCharacterOfPosition(sourceFile, contextToken.getEnd()).line !== getLineAndCharacterOfPosition(sourceFile, position).line) {
-            return location;
-          }
-          const isValidKeyword = isClassLike(contextToken.parent.parent) ? isClassMemberCompletionKeyword : isInterfaceOrTypeLiteralCompletionKeyword;
-          return isValidKeyword(contextToken.kind) || contextToken.kind === 42 /* AsteriskToken */ || isIdentifier(contextToken) && isValidKeyword(identifierToKeywordKind(contextToken) ?? 0 /* Unknown */) ? contextToken.parent.parent : void 0;
-        }
+    function getSignatureDefinition(signatureDeclarations, selectConstructors) {
+      if (!signatureDeclarations) {
         return void 0;
+      }
+      const declarations = signatureDeclarations.filter(selectConstructors ? isConstructorDeclaration : isFunctionLike);
+      const declarationsWithBody = declarations.filter((d) => !!d.body);
+      return declarations.length ? declarationsWithBody.length !== 0 ? declarationsWithBody.map((x) => createDefinitionInfo(x, typeChecker, symbol, node)) : [createDefinitionInfo(
+        last(declarations),
+        typeChecker,
+        symbol,
+        node,
+        /*unverified*/
+        false,
+        failedAliasResolution
+      )] : void 0;
     }
   }
-  function tryGetTypeLiteralNode(node) {
-    if (!node)
-      return void 0;
-    const parent2 = node.parent;
-    switch (node.kind) {
-      case 19 /* OpenBraceToken */:
-        if (isTypeLiteralNode(parent2)) {
-          return parent2;
-        }
-        break;
-      case 27 /* SemicolonToken */:
-      case 28 /* CommaToken */:
-      case 80 /* Identifier */:
-        if (parent2.kind === 170 /* PropertySignature */ && isTypeLiteralNode(parent2.parent)) {
-          return parent2.parent;
-        }
-        break;
-    }
-    return void 0;
+  function createDefinitionInfo(declaration, checker, symbol, node, unverified, failedAliasResolution) {
+    const symbolName2 = checker.symbolToString(symbol);
+    const symbolKind = ts_SymbolDisplay_exports.getSymbolKind(checker, symbol, node);
+    const containerName = symbol.parent ? checker.symbolToString(symbol.parent, node) : "";
+    return createDefinitionInfoFromName(checker, declaration, symbolKind, symbolName2, containerName, unverified, failedAliasResolution);
   }
-  function getConstraintOfTypeArgumentProperty(node, checker) {
-    if (!node)
-      return void 0;
-    if (isTypeNode(node) && isTypeReferenceType(node.parent)) {
-      return checker.getTypeArgumentConstraint(node);
+  function createDefinitionInfoFromName(checker, declaration, symbolKind, symbolName2, containerName, unverified, failedAliasResolution, textSpan) {
+    const sourceFile = declaration.getSourceFile();
+    if (!textSpan) {
+      const name = getNameOfDeclaration(declaration) || declaration;
+      textSpan = createTextSpanFromNode(name, sourceFile);
     }
-    const t = getConstraintOfTypeArgumentProperty(node.parent, checker);
-    if (!t)
-      return void 0;
-    switch (node.kind) {
-      case 170 /* PropertySignature */:
-        return checker.getTypeOfPropertyOfContextualType(t, node.symbol.escapedName);
-      case 192 /* IntersectionType */:
-      case 186 /* TypeLiteral */:
-      case 191 /* UnionType */:
-        return t;
+    return {
+      fileName: sourceFile.fileName,
+      textSpan,
+      kind: symbolKind,
+      name: symbolName2,
+      containerKind: void 0,
+      // TODO: GH#18217
+      containerName,
+      ...ts_FindAllReferences_exports.toContextSpan(
+        textSpan,
+        sourceFile,
+        ts_FindAllReferences_exports.getContextNode(declaration)
+      ),
+      isLocal: !isDefinitionVisible(checker, declaration),
+      isAmbient: !!(declaration.flags & 33554432 /* Ambient */),
+      unverified,
+      failedAliasResolution
+    };
+  }
+  function isDefinitionVisible(checker, declaration) {
+    if (checker.isDeclarationVisible(declaration))
+      return true;
+    if (!declaration.parent)
+      return false;
+    if (hasInitializer(declaration.parent) && declaration.parent.initializer === declaration)
+      return isDefinitionVisible(checker, declaration.parent);
+    switch (declaration.kind) {
+      case 172 /* PropertyDeclaration */:
+      case 177 /* GetAccessor */:
+      case 178 /* SetAccessor */:
+      case 174 /* MethodDeclaration */:
+        if (hasEffectiveModifier(declaration, 2 /* Private */))
+          return false;
+      case 176 /* Constructor */:
+      case 303 /* PropertyAssignment */:
+      case 304 /* ShorthandPropertyAssignment */:
+      case 210 /* ObjectLiteralExpression */:
+      case 231 /* ClassExpression */:
+      case 219 /* ArrowFunction */:
+      case 218 /* FunctionExpression */:
+        return isDefinitionVisible(checker, declaration.parent);
+      default:
+        return false;
     }
   }
-  function isFromObjectTypeDeclaration(node) {
-    return node.parent && isClassOrTypeElement(node.parent) && isObjectTypeDeclaration(node.parent.parent);
+  function createDefinitionFromSignatureDeclaration(typeChecker, decl, failedAliasResolution) {
+    return createDefinitionInfo(
+      decl,
+      typeChecker,
+      decl.symbol,
+      decl,
+      /*unverified*/
+      false,
+      failedAliasResolution
+    );
   }
-  function isValidTrigger(sourceFile, triggerCharacter, contextToken, position) {
-    switch (triggerCharacter) {
-      case ".":
-      case "@":
+  function findReferenceInPosition(refs, pos) {
+    return find(refs, (ref) => textRangeContainsPositionInclusive(ref, pos));
+  }
+  function getDefinitionInfoForFileReference(name, targetFileName, unverified) {
+    return {
+      fileName: targetFileName,
+      textSpan: createTextSpanFromBounds(0, 0),
+      kind: "script" /* scriptElement */,
+      name,
+      containerName: void 0,
+      containerKind: void 0,
+      // TODO: GH#18217
+      unverified
+    };
+  }
+  function getAncestorCallLikeExpression(node) {
+    const target = findAncestor(node, (n) => !isRightSideOfPropertyAccess(n));
+    const callLike = target == null ? void 0 : target.parent;
+    return callLike && isCallLikeExpression(callLike) && getInvokedExpression(callLike) === target ? callLike : void 0;
+  }
+  function tryGetSignatureDeclaration(typeChecker, node) {
+    const callLike = getAncestorCallLikeExpression(node);
+    const signature = callLike && typeChecker.getResolvedSignature(callLike);
+    return tryCast(signature && signature.declaration, (d) => isFunctionLike(d) && !isFunctionTypeNode(d));
+  }
+  function isConstructorLike(node) {
+    switch (node.kind) {
+      case 176 /* Constructor */:
+      case 185 /* ConstructorType */:
+      case 180 /* ConstructSignature */:
         return true;
-      case '"':
-      case "'":
-      case "`":
-        return !!contextToken && isStringLiteralOrTemplate(contextToken) && position === contextToken.getStart(sourceFile) + 1;
-      case "#":
-        return !!contextToken && isPrivateIdentifier(contextToken) && !!getContainingClass(contextToken);
-      case "<":
-        return !!contextToken && contextToken.kind === 30 /* LessThanToken */ && (!isBinaryExpression(contextToken.parent) || binaryExpressionMayBeOpenTag(contextToken.parent));
-      case "/":
-        return !!contextToken && (isStringLiteralLike(contextToken) ? !!tryGetImportFromModuleSpecifier(contextToken) : contextToken.kind === 44 /* SlashToken */ && isJsxClosingElement(contextToken.parent));
-      case " ":
-        return !!contextToken && isImportKeyword(contextToken) && contextToken.parent.kind === 311 /* SourceFile */;
       default:
-        return Debug.assertNever(triggerCharacter);
+        return false;
     }
   }
-  function binaryExpressionMayBeOpenTag({ left }) {
-    return nodeIsMissing(left);
-  }
-  function isProbablyGlobalType(type, sourceFile, checker) {
-    const selfSymbol = checker.resolveName(
-      "self",
-      /*location*/
-      void 0,
-      111551 /* Value */,
-      /*excludeGlobals*/
-      false
-    );
-    if (selfSymbol && checker.getTypeOfSymbolAtLocation(selfSymbol, sourceFile) === type) {
-      return true;
-    }
-    const globalSymbol = checker.resolveName(
-      "global",
-      /*location*/
-      void 0,
-      111551 /* Value */,
-      /*excludeGlobals*/
-      false
-    );
-    if (globalSymbol && checker.getTypeOfSymbolAtLocation(globalSymbol, sourceFile) === type) {
-      return true;
+  var typesWithUnwrappedTypeArguments;
+  var init_goToDefinition = __esm({
+    "src/services/goToDefinition.ts"() {
+      "use strict";
+      init_ts4();
+      typesWithUnwrappedTypeArguments = /* @__PURE__ */ new Set([
+        "Array",
+        "ArrayLike",
+        "ReadonlyArray",
+        "Promise",
+        "PromiseLike",
+        "Iterable",
+        "IterableIterator",
+        "AsyncIterable",
+        "Set",
+        "WeakSet",
+        "ReadonlySet",
+        "Map",
+        "WeakMap",
+        "ReadonlyMap",
+        "Partial",
+        "Required",
+        "Readonly",
+        "Pick",
+        "Omit"
+      ]);
     }
-    const globalThisSymbol = checker.resolveName(
-      "globalThis",
-      /*location*/
-      void 0,
-      111551 /* Value */,
-      /*excludeGlobals*/
-      false
-    );
-    if (globalThisSymbol && checker.getTypeOfSymbolAtLocation(globalThisSymbol, sourceFile) === type) {
-      return true;
+  });
+
+  // src/services/_namespaces/ts.GoToDefinition.ts
+  var ts_GoToDefinition_exports = {};
+  __export(ts_GoToDefinition_exports, {
+    createDefinitionInfo: () => createDefinitionInfo,
+    findReferenceInPosition: () => findReferenceInPosition,
+    getDefinitionAndBoundSpan: () => getDefinitionAndBoundSpan,
+    getDefinitionAtPosition: () => getDefinitionAtPosition,
+    getReferenceAtPosition: () => getReferenceAtPosition,
+    getTypeDefinitionAtPosition: () => getTypeDefinitionAtPosition
+  });
+  var init_ts_GoToDefinition = __esm({
+    "src/services/_namespaces/ts.GoToDefinition.ts"() {
+      "use strict";
+      init_goToDefinition();
     }
-    return false;
+  });
+
+  // src/services/inlayHints.ts
+  function shouldShowParameterNameHints(preferences) {
+    return preferences.includeInlayParameterNameHints === "literals" || preferences.includeInlayParameterNameHints === "all";
   }
-  function isStaticProperty(symbol) {
-    return !!(symbol.valueDeclaration && getEffectiveModifierFlags(symbol.valueDeclaration) & 32 /* Static */ && isClassLike(symbol.valueDeclaration.parent));
+  function shouldShowLiteralParameterNameHintsOnly(preferences) {
+    return preferences.includeInlayParameterNameHints === "literals";
   }
-  function tryGetObjectLiteralContextualType(node, typeChecker) {
-    const type = typeChecker.getContextualType(node);
-    if (type) {
-      return type;
+  function shouldUseInteractiveInlayHints(preferences) {
+    return preferences.interactiveInlayHints === true;
+  }
+  function provideInlayHints(context) {
+    const { file, program, span, cancellationToken, preferences } = context;
+    const sourceFileText = file.text;
+    const compilerOptions = program.getCompilerOptions();
+    const quotePreference = getQuotePreference(file, preferences);
+    const checker = program.getTypeChecker();
+    const result = [];
+    visitor(file);
+    return result;
+    function visitor(node) {
+      if (!node || node.getFullWidth() === 0) {
+        return;
+      }
+      switch (node.kind) {
+        case 267 /* ModuleDeclaration */:
+        case 263 /* ClassDeclaration */:
+        case 264 /* InterfaceDeclaration */:
+        case 262 /* FunctionDeclaration */:
+        case 231 /* ClassExpression */:
+        case 218 /* FunctionExpression */:
+        case 174 /* MethodDeclaration */:
+        case 219 /* ArrowFunction */:
+          cancellationToken.throwIfCancellationRequested();
+      }
+      if (!textSpanIntersectsWith(span, node.pos, node.getFullWidth())) {
+        return;
+      }
+      if (isTypeNode(node) && !isExpressionWithTypeArguments(node)) {
+        return;
+      }
+      if (preferences.includeInlayVariableTypeHints && isVariableDeclaration(node)) {
+        visitVariableLikeDeclaration(node);
+      } else if (preferences.includeInlayPropertyDeclarationTypeHints && isPropertyDeclaration(node)) {
+        visitVariableLikeDeclaration(node);
+      } else if (preferences.includeInlayEnumMemberValueHints && isEnumMember(node)) {
+        visitEnumMember(node);
+      } else if (shouldShowParameterNameHints(preferences) && (isCallExpression(node) || isNewExpression(node))) {
+        visitCallOrNewExpression(node);
+      } else {
+        if (preferences.includeInlayFunctionParameterTypeHints && isFunctionLikeDeclaration(node) && hasContextSensitiveParameters(node)) {
+          visitFunctionLikeForParameterType(node);
+        }
+        if (preferences.includeInlayFunctionLikeReturnTypeHints && isSignatureSupportingReturnAnnotation(node)) {
+          visitFunctionDeclarationLikeForReturnType(node);
+        }
+      }
+      return forEachChild(node, visitor);
     }
-    const parent2 = walkUpParenthesizedExpressions(node.parent);
-    if (isBinaryExpression(parent2) && parent2.operatorToken.kind === 64 /* EqualsToken */ && node === parent2.left) {
-      return typeChecker.getTypeAtLocation(parent2);
+    function isSignatureSupportingReturnAnnotation(node) {
+      return isArrowFunction(node) || isFunctionExpression(node) || isFunctionDeclaration(node) || isMethodDeclaration(node) || isGetAccessorDeclaration(node);
     }
-    if (isExpression(parent2)) {
-      return typeChecker.getContextualType(parent2);
+    function addParameterHints(text, parameter, position, isFirstVariadicArgument) {
+      let hintText = `${isFirstVariadicArgument ? "..." : ""}${text}`;
+      let displayParts;
+      if (shouldUseInteractiveInlayHints(preferences)) {
+        displayParts = [getNodeDisplayPart(hintText, parameter), { text: ":" }];
+        hintText = "";
+      } else {
+        hintText += ":";
+      }
+      result.push({
+        text: hintText,
+        position,
+        kind: "Parameter" /* Parameter */,
+        whitespaceAfter: true,
+        displayParts
+      });
     }
-    return void 0;
-  }
-  function getImportStatementCompletionInfo(contextToken) {
-    var _a, _b, _c;
-    let keywordCompletion;
-    let isKeywordOnlyCompletion = false;
-    const candidate = getCandidate();
-    return {
-      isKeywordOnlyCompletion,
-      keywordCompletion,
-      isNewIdentifierLocation: !!(candidate || keywordCompletion === 156 /* TypeKeyword */),
-      isTopLevelTypeOnly: !!((_b = (_a = tryCast(candidate, isImportDeclaration)) == null ? void 0 : _a.importClause) == null ? void 0 : _b.isTypeOnly) || !!((_c = tryCast(candidate, isImportEqualsDeclaration)) == null ? void 0 : _c.isTypeOnly),
-      couldBeTypeOnlyImportSpecifier: !!candidate && couldBeTypeOnlyImportSpecifier(candidate, contextToken),
-      replacementSpan: getSingleLineReplacementSpanForImportCompletionNode(candidate)
-    };
-    function getCandidate() {
-      const parent2 = contextToken.parent;
-      if (isImportEqualsDeclaration(parent2)) {
-        keywordCompletion = contextToken.kind === 156 /* TypeKeyword */ ? void 0 : 156 /* TypeKeyword */;
-        return isModuleSpecifierMissingOrEmpty(parent2.moduleReference) ? parent2 : void 0;
+    function addTypeHints(hintText, position) {
+      result.push({
+        text: typeof hintText === "string" ? `: ${hintText}` : "",
+        displayParts: typeof hintText === "string" ? void 0 : [{ text: ": " }, ...hintText],
+        position,
+        kind: "Type" /* Type */,
+        whitespaceBefore: true
+      });
+    }
+    function addEnumMemberValueHints(text, position) {
+      result.push({
+        text: `= ${text}`,
+        position,
+        kind: "Enum" /* Enum */,
+        whitespaceBefore: true
+      });
+    }
+    function visitEnumMember(member) {
+      if (member.initializer) {
+        return;
       }
-      if (couldBeTypeOnlyImportSpecifier(parent2, contextToken) && canCompleteFromNamedBindings(parent2.parent)) {
-        return parent2;
+      const enumValue = checker.getConstantValue(member);
+      if (enumValue !== void 0) {
+        addEnumMemberValueHints(enumValue.toString(), member.end);
       }
-      if (isNamedImports(parent2) || isNamespaceImport(parent2)) {
-        if (!parent2.parent.isTypeOnly && (contextToken.kind === 19 /* OpenBraceToken */ || contextToken.kind === 102 /* ImportKeyword */ || contextToken.kind === 28 /* CommaToken */)) {
-          keywordCompletion = 156 /* TypeKeyword */;
+    }
+    function isModuleReferenceType(type) {
+      return type.symbol && type.symbol.flags & 1536 /* Module */;
+    }
+    function visitVariableLikeDeclaration(decl) {
+      if (!decl.initializer || isBindingPattern(decl.name) || isVariableDeclaration(decl) && !isHintableDeclaration(decl)) {
+        return;
+      }
+      const effectiveTypeAnnotation = getEffectiveTypeAnnotationNode(decl);
+      if (effectiveTypeAnnotation) {
+        return;
+      }
+      const declarationType = checker.getTypeAtLocation(decl);
+      if (isModuleReferenceType(declarationType)) {
+        return;
+      }
+      const hintParts = typeToInlayHintParts(declarationType);
+      if (hintParts) {
+        const hintText = typeof hintParts === "string" ? hintParts : hintParts.map((part) => part.text).join("");
+        const isVariableNameMatchesType = preferences.includeInlayVariableTypeHintsWhenTypeMatchesName === false && equateStringsCaseInsensitive(decl.name.getText(), hintText);
+        if (isVariableNameMatchesType) {
+          return;
         }
-        if (canCompleteFromNamedBindings(parent2)) {
-          if (contextToken.kind === 20 /* CloseBraceToken */ || contextToken.kind === 80 /* Identifier */) {
-            isKeywordOnlyCompletion = true;
-            keywordCompletion = 160 /* FromKeyword */;
-          } else {
-            return parent2.parent.parent;
+        addTypeHints(hintParts, decl.name.end);
+      }
+    }
+    function visitCallOrNewExpression(expr) {
+      const args = expr.arguments;
+      if (!args || !args.length) {
+        return;
+      }
+      const candidates = [];
+      const signature = checker.getResolvedSignatureForSignatureHelp(expr, candidates);
+      if (!signature || !candidates.length) {
+        return;
+      }
+      let signatureParamPos = 0;
+      for (const originalArg of args) {
+        const arg = skipParentheses(originalArg);
+        if (shouldShowLiteralParameterNameHintsOnly(preferences) && !isHintableLiteral(arg)) {
+          signatureParamPos++;
+          continue;
+        }
+        let spreadArgs = 0;
+        if (isSpreadElement(arg)) {
+          const spreadType = checker.getTypeAtLocation(arg.expression);
+          if (checker.isTupleType(spreadType)) {
+            const { elementFlags, fixedLength } = spreadType.target;
+            if (fixedLength === 0) {
+              continue;
+            }
+            const firstOptionalIndex = findIndex(elementFlags, (f) => !(f & 1 /* Required */));
+            const requiredArgs = firstOptionalIndex < 0 ? fixedLength : firstOptionalIndex;
+            if (requiredArgs > 0) {
+              spreadArgs = firstOptionalIndex < 0 ? fixedLength : firstOptionalIndex;
+            }
+          }
+        }
+        const identifierInfo = checker.getParameterIdentifierInfoAtPosition(signature, signatureParamPos);
+        signatureParamPos = signatureParamPos + (spreadArgs || 1);
+        if (identifierInfo) {
+          const { parameter, parameterName, isRestParameter: isFirstVariadicArgument } = identifierInfo;
+          const isParameterNameNotSameAsArgument = preferences.includeInlayParameterNameHintsWhenArgumentMatchesName || !identifierOrAccessExpressionPostfixMatchesParameterName(arg, parameterName);
+          if (!isParameterNameNotSameAsArgument && !isFirstVariadicArgument) {
+            continue;
+          }
+          const name = unescapeLeadingUnderscores(parameterName);
+          if (leadingCommentsContainsParameterName(arg, name)) {
+            continue;
           }
+          addParameterHints(name, parameter, originalArg.getStart(), isFirstVariadicArgument);
+        }
+      }
+    }
+    function identifierOrAccessExpressionPostfixMatchesParameterName(expr, parameterName) {
+      if (isIdentifier(expr)) {
+        return expr.text === parameterName;
+      }
+      if (isPropertyAccessExpression(expr)) {
+        return expr.name.text === parameterName;
+      }
+      return false;
+    }
+    function leadingCommentsContainsParameterName(node, name) {
+      if (!isIdentifierText(name, compilerOptions.target, getLanguageVariant(file.scriptKind))) {
+        return false;
+      }
+      const ranges = getLeadingCommentRanges(sourceFileText, node.pos);
+      if (!(ranges == null ? void 0 : ranges.length)) {
+        return false;
+      }
+      const regex = leadingParameterNameCommentRegexFactory(name);
+      return some(ranges, (range) => regex.test(sourceFileText.substring(range.pos, range.end)));
+    }
+    function isHintableLiteral(node) {
+      switch (node.kind) {
+        case 224 /* PrefixUnaryExpression */: {
+          const operand = node.operand;
+          return isLiteralExpression(operand) || isIdentifier(operand) && isInfinityOrNaNString(operand.escapedText);
+        }
+        case 112 /* TrueKeyword */:
+        case 97 /* FalseKeyword */:
+        case 106 /* NullKeyword */:
+        case 15 /* NoSubstitutionTemplateLiteral */:
+        case 228 /* TemplateExpression */:
+          return true;
+        case 80 /* Identifier */: {
+          const name = node.escapedText;
+          return isUndefined(name) || isInfinityOrNaNString(name);
+        }
+      }
+      return isLiteralExpression(node);
+    }
+    function visitFunctionDeclarationLikeForReturnType(decl) {
+      if (isArrowFunction(decl)) {
+        if (!findChildOfKind(decl, 21 /* OpenParenToken */, file)) {
+          return;
         }
-        return void 0;
       }
-      if (isImportKeyword(contextToken) && isSourceFile(parent2)) {
-        keywordCompletion = 156 /* TypeKeyword */;
-        return contextToken;
+      const effectiveTypeAnnotation = getEffectiveReturnTypeNode(decl);
+      if (effectiveTypeAnnotation || !decl.body) {
+        return;
       }
-      if (isImportKeyword(contextToken) && isImportDeclaration(parent2)) {
-        keywordCompletion = 156 /* TypeKeyword */;
-        return isModuleSpecifierMissingOrEmpty(parent2.moduleSpecifier) ? parent2 : void 0;
+      const signature = checker.getSignatureFromDeclaration(decl);
+      if (!signature) {
+        return;
+      }
+      const returnType = checker.getReturnTypeOfSignature(signature);
+      if (isModuleReferenceType(returnType)) {
+        return;
+      }
+      const hintParts = typeToInlayHintParts(returnType);
+      if (hintParts) {
+        addTypeHints(hintParts, getTypeAnnotationPosition(decl));
       }
-      return void 0;
-    }
-  }
-  function getSingleLineReplacementSpanForImportCompletionNode(node) {
-    var _a;
-    if (!node)
-      return void 0;
-    const top = findAncestor(node, or(isImportDeclaration, isImportEqualsDeclaration)) ?? node;
-    const sourceFile = top.getSourceFile();
-    if (rangeIsOnSingleLine(top, sourceFile)) {
-      return createTextSpanFromNode(top, sourceFile);
-    }
-    Debug.assert(top.kind !== 102 /* ImportKeyword */ && top.kind !== 275 /* ImportSpecifier */);
-    const potentialSplitPoint = top.kind === 271 /* ImportDeclaration */ ? getPotentiallyInvalidImportSpecifier((_a = top.importClause) == null ? void 0 : _a.namedBindings) ?? top.moduleSpecifier : top.moduleReference;
-    const withoutModuleSpecifier = {
-      pos: top.getFirstToken().getStart(),
-      end: potentialSplitPoint.pos
-    };
-    if (rangeIsOnSingleLine(withoutModuleSpecifier, sourceFile)) {
-      return createTextSpanFromRange(withoutModuleSpecifier);
     }
-  }
-  function getPotentiallyInvalidImportSpecifier(namedBindings) {
-    var _a;
-    return find(
-      (_a = tryCast(namedBindings, isNamedImports)) == null ? void 0 : _a.elements,
-      (e) => {
-        var _a2;
-        return !e.propertyName && isStringANonContextualKeyword(e.name.text) && ((_a2 = findPrecedingToken(e.name.pos, namedBindings.getSourceFile(), namedBindings)) == null ? void 0 : _a2.kind) !== 28 /* CommaToken */;
+    function getTypeAnnotationPosition(decl) {
+      const closeParenToken = findChildOfKind(decl, 22 /* CloseParenToken */, file);
+      if (closeParenToken) {
+        return closeParenToken.end;
       }
-    );
-  }
-  function couldBeTypeOnlyImportSpecifier(importSpecifier, contextToken) {
-    return isImportSpecifier(importSpecifier) && (importSpecifier.isTypeOnly || contextToken === importSpecifier.name && isTypeKeywordTokenOrIdentifier(contextToken));
-  }
-  function canCompleteFromNamedBindings(namedBindings) {
-    if (!isModuleSpecifierMissingOrEmpty(namedBindings.parent.parent.moduleSpecifier) || namedBindings.parent.name) {
-      return false;
+      return decl.parameters.end;
     }
-    if (isNamedImports(namedBindings)) {
-      const invalidNamedImport = getPotentiallyInvalidImportSpecifier(namedBindings);
-      const validImports = invalidNamedImport ? namedBindings.elements.indexOf(invalidNamedImport) : namedBindings.elements.length;
-      return validImports < 2;
+    function visitFunctionLikeForParameterType(node) {
+      const signature = checker.getSignatureFromDeclaration(node);
+      if (!signature) {
+        return;
+      }
+      for (let i = 0; i < node.parameters.length && i < signature.parameters.length; ++i) {
+        const param = node.parameters[i];
+        if (!isHintableDeclaration(param)) {
+          continue;
+        }
+        const effectiveTypeAnnotation = getEffectiveTypeAnnotationNode(param);
+        if (effectiveTypeAnnotation) {
+          continue;
+        }
+        const typeHints = getParameterDeclarationTypeHints(signature.parameters[i]);
+        if (!typeHints) {
+          continue;
+        }
+        addTypeHints(typeHints, param.questionToken ? param.questionToken.end : param.name.end);
+      }
     }
-    return true;
-  }
-  function isModuleSpecifierMissingOrEmpty(specifier) {
-    var _a;
-    if (nodeIsMissing(specifier))
-      return true;
-    return !((_a = tryCast(isExternalModuleReference(specifier) ? specifier.expression : specifier, isStringLiteralLike)) == null ? void 0 : _a.text);
-  }
-  function getVariableOrParameterDeclaration(contextToken, location) {
-    if (!contextToken)
-      return;
-    const possiblyParameterDeclaration = findAncestor(contextToken, (node) => isFunctionBlock(node) || isArrowFunctionBody(node) || isBindingPattern(node) ? "quit" : (isParameter(node) || isTypeParameterDeclaration(node)) && !isIndexSignatureDeclaration(node.parent));
-    const possiblyVariableDeclaration = findAncestor(location, (node) => isFunctionBlock(node) || isArrowFunctionBody(node) || isBindingPattern(node) ? "quit" : isVariableDeclaration(node));
-    return possiblyParameterDeclaration || possiblyVariableDeclaration;
-  }
-  function isArrowFunctionBody(node) {
-    return node.parent && isArrowFunction(node.parent) && (node.parent.body === node || // const a = () => /**/;
-    node.kind === 39 /* EqualsGreaterThanToken */);
-  }
-  function symbolCanBeReferencedAtTypeLocation(symbol, checker, seenModules = /* @__PURE__ */ new Map()) {
-    return nonAliasCanBeReferencedAtTypeLocation(symbol) || nonAliasCanBeReferencedAtTypeLocation(skipAlias(symbol.exportSymbol || symbol, checker));
-    function nonAliasCanBeReferencedAtTypeLocation(symbol2) {
-      return !!(symbol2.flags & 788968 /* Type */) || checker.isUnknownSymbol(symbol2) || !!(symbol2.flags & 1536 /* Module */) && addToSeen(seenModules, getSymbolId(symbol2)) && checker.getExportsOfModule(symbol2).some((e) => symbolCanBeReferencedAtTypeLocation(e, checker, seenModules));
+    function getParameterDeclarationTypeHints(symbol) {
+      const valueDeclaration = symbol.valueDeclaration;
+      if (!valueDeclaration || !isParameter(valueDeclaration)) {
+        return void 0;
+      }
+      const signatureParamType = checker.getTypeOfSymbolAtLocation(symbol, valueDeclaration);
+      if (isModuleReferenceType(signatureParamType)) {
+        return void 0;
+      }
+      return typeToInlayHintParts(signatureParamType);
     }
-  }
-  function isDeprecated(symbol, checker) {
-    const declarations = skipAlias(symbol, checker).declarations;
-    return !!length(declarations) && every(declarations, isDeprecatedDeclaration);
-  }
-  function charactersFuzzyMatchInString(identifierString, lowercaseCharacters) {
-    if (lowercaseCharacters.length === 0) {
-      return true;
+    function printTypeInSingleLine(type) {
+      const flags = 70221824 /* IgnoreErrors */ | 1048576 /* AllowUniqueESSymbolType */ | 16384 /* UseAliasDefinedOutsideCurrentScope */;
+      const printer = createPrinterWithRemoveComments();
+      return usingSingleLineStringWriter((writer) => {
+        const typeNode = checker.typeToTypeNode(
+          type,
+          /*enclosingDeclaration*/
+          void 0,
+          flags
+        );
+        Debug.assertIsDefined(typeNode, "should always get typenode");
+        printer.writeNode(
+          4 /* Unspecified */,
+          typeNode,
+          /*sourceFile*/
+          file,
+          writer
+        );
+      });
     }
-    let matchedFirstCharacter = false;
-    let prevChar;
-    let characterIndex = 0;
-    const len = identifierString.length;
-    for (let strIndex = 0; strIndex < len; strIndex++) {
-      const strChar = identifierString.charCodeAt(strIndex);
-      const testChar = lowercaseCharacters.charCodeAt(characterIndex);
-      if (strChar === testChar || strChar === toUpperCharCode(testChar)) {
-        matchedFirstCharacter || (matchedFirstCharacter = prevChar === void 0 || // Beginning of word
-        97 /* a */ <= prevChar && prevChar <= 122 /* z */ && 65 /* A */ <= strChar && strChar <= 90 /* Z */ || // camelCase transition
-        prevChar === 95 /* _ */ && strChar !== 95 /* _ */);
-        if (matchedFirstCharacter) {
-          characterIndex++;
+    function typeToInlayHintParts(type) {
+      if (!shouldUseInteractiveInlayHints(preferences)) {
+        return printTypeInSingleLine(type);
+      }
+      const flags = 70221824 /* IgnoreErrors */ | 1048576 /* AllowUniqueESSymbolType */ | 16384 /* UseAliasDefinedOutsideCurrentScope */;
+      const typeNode = checker.typeToTypeNode(
+        type,
+        /*enclosingDeclaration*/
+        void 0,
+        flags
+      );
+      Debug.assertIsDefined(typeNode, "should always get typenode");
+      const parts = [];
+      visitForDisplayParts(typeNode);
+      return parts;
+      function visitForDisplayParts(node) {
+        if (!node) {
+          return;
         }
-        if (characterIndex === lowercaseCharacters.length) {
-          return true;
+        const tokenString = tokenToString(node.kind);
+        if (tokenString) {
+          parts.push({ text: tokenString });
+          return;
+        }
+        if (isLiteralExpression(node)) {
+          parts.push({ text: getLiteralText2(node) });
+          return;
+        }
+        switch (node.kind) {
+          case 80 /* Identifier */:
+            const identifier = node;
+            const identifierText = idText(identifier);
+            const name = identifier.symbol && identifier.symbol.declarations && identifier.symbol.declarations.length && getNameOfDeclaration(identifier.symbol.declarations[0]);
+            if (name) {
+              parts.push(getNodeDisplayPart(identifierText, name));
+            } else {
+              parts.push({ text: identifierText });
+            }
+            break;
+          case 166 /* QualifiedName */:
+            const qualifiedName = node;
+            visitForDisplayParts(qualifiedName.left);
+            parts.push({ text: "." });
+            visitForDisplayParts(qualifiedName.right);
+            break;
+          case 182 /* TypePredicate */:
+            const predicate = node;
+            if (predicate.assertsModifier) {
+              parts.push({ text: "asserts " });
+            }
+            visitForDisplayParts(predicate.parameterName);
+            if (predicate.type) {
+              parts.push({ text: " is " });
+              visitForDisplayParts(predicate.type);
+            }
+            break;
+          case 183 /* TypeReference */:
+            const typeReference = node;
+            visitForDisplayParts(typeReference.typeName);
+            if (typeReference.typeArguments) {
+              parts.push({ text: "<" });
+              visitDisplayPartList(typeReference.typeArguments, ", ");
+              parts.push({ text: ">" });
+            }
+            break;
+          case 168 /* TypeParameter */:
+            const typeParameter = node;
+            if (typeParameter.modifiers) {
+              visitDisplayPartList(typeParameter.modifiers, " ");
+            }
+            visitForDisplayParts(typeParameter.name);
+            if (typeParameter.constraint) {
+              parts.push({ text: " extends " });
+              visitForDisplayParts(typeParameter.constraint);
+            }
+            if (typeParameter.default) {
+              parts.push({ text: " = " });
+              visitForDisplayParts(typeParameter.default);
+            }
+            break;
+          case 169 /* Parameter */:
+            const parameter = node;
+            if (parameter.modifiers) {
+              visitDisplayPartList(parameter.modifiers, " ");
+            }
+            if (parameter.dotDotDotToken) {
+              parts.push({ text: "..." });
+            }
+            visitForDisplayParts(parameter.name);
+            if (parameter.questionToken) {
+              parts.push({ text: "?" });
+            }
+            if (parameter.type) {
+              parts.push({ text: ": " });
+              visitForDisplayParts(parameter.type);
+            }
+            break;
+          case 185 /* ConstructorType */:
+            const constructorType = node;
+            parts.push({ text: "new " });
+            if (constructorType.typeParameters) {
+              parts.push({ text: "<" });
+              visitDisplayPartList(constructorType.typeParameters, ", ");
+              parts.push({ text: ">" });
+            }
+            parts.push({ text: "(" });
+            visitDisplayPartList(constructorType.parameters, ", ");
+            parts.push({ text: ")" });
+            parts.push({ text: " => " });
+            visitForDisplayParts(constructorType.type);
+            break;
+          case 186 /* TypeQuery */:
+            const typeQuery = node;
+            parts.push({ text: "typeof " });
+            visitForDisplayParts(typeQuery.exprName);
+            if (typeQuery.typeArguments) {
+              parts.push({ text: "<" });
+              visitDisplayPartList(typeQuery.typeArguments, ", ");
+              parts.push({ text: ">" });
+            }
+            break;
+          case 187 /* TypeLiteral */:
+            const typeLiteral = node;
+            parts.push({ text: "{" });
+            if (typeLiteral.members.length) {
+              parts.push({ text: " " });
+              visitDisplayPartList(typeLiteral.members, "; ");
+              parts.push({ text: " " });
+            }
+            parts.push({ text: "}" });
+            break;
+          case 188 /* ArrayType */:
+            visitForDisplayParts(node.elementType);
+            parts.push({ text: "[]" });
+            break;
+          case 189 /* TupleType */:
+            parts.push({ text: "[" });
+            visitDisplayPartList(node.elements, ", ");
+            parts.push({ text: "]" });
+            break;
+          case 202 /* NamedTupleMember */:
+            const member = node;
+            if (member.dotDotDotToken) {
+              parts.push({ text: "..." });
+            }
+            visitForDisplayParts(member.name);
+            if (member.questionToken) {
+              parts.push({ text: "?" });
+            }
+            parts.push({ text: ": " });
+            visitForDisplayParts(member.type);
+            break;
+          case 190 /* OptionalType */:
+            visitForDisplayParts(node.type);
+            parts.push({ text: "?" });
+            break;
+          case 191 /* RestType */:
+            parts.push({ text: "..." });
+            visitForDisplayParts(node.type);
+            break;
+          case 192 /* UnionType */:
+            visitDisplayPartList(node.types, " | ");
+            break;
+          case 193 /* IntersectionType */:
+            visitDisplayPartList(node.types, " & ");
+            break;
+          case 194 /* ConditionalType */:
+            const conditionalType = node;
+            visitForDisplayParts(conditionalType.checkType);
+            parts.push({ text: " extends " });
+            visitForDisplayParts(conditionalType.extendsType);
+            parts.push({ text: " ? " });
+            visitForDisplayParts(conditionalType.trueType);
+            parts.push({ text: " : " });
+            visitForDisplayParts(conditionalType.falseType);
+            break;
+          case 195 /* InferType */:
+            parts.push({ text: "infer " });
+            visitForDisplayParts(node.typeParameter);
+            break;
+          case 196 /* ParenthesizedType */:
+            parts.push({ text: "(" });
+            visitForDisplayParts(node.type);
+            parts.push({ text: ")" });
+            break;
+          case 198 /* TypeOperator */:
+            const typeOperator = node;
+            parts.push({ text: `${tokenToString(typeOperator.operator)} ` });
+            visitForDisplayParts(typeOperator.type);
+            break;
+          case 199 /* IndexedAccessType */:
+            const indexedAccess = node;
+            visitForDisplayParts(indexedAccess.objectType);
+            parts.push({ text: "[" });
+            visitForDisplayParts(indexedAccess.indexType);
+            parts.push({ text: "]" });
+            break;
+          case 200 /* MappedType */:
+            const mappedType = node;
+            parts.push({ text: "{ " });
+            if (mappedType.readonlyToken) {
+              if (mappedType.readonlyToken.kind === 40 /* PlusToken */) {
+                parts.push({ text: "+" });
+              } else if (mappedType.readonlyToken.kind === 41 /* MinusToken */) {
+                parts.push({ text: "-" });
+              }
+              parts.push({ text: "readonly " });
+            }
+            parts.push({ text: "[" });
+            visitForDisplayParts(mappedType.typeParameter);
+            if (mappedType.nameType) {
+              parts.push({ text: " as " });
+              visitForDisplayParts(mappedType.nameType);
+            }
+            parts.push({ text: "]" });
+            if (mappedType.questionToken) {
+              if (mappedType.questionToken.kind === 40 /* PlusToken */) {
+                parts.push({ text: "+" });
+              } else if (mappedType.questionToken.kind === 41 /* MinusToken */) {
+                parts.push({ text: "-" });
+              }
+              parts.push({ text: "?" });
+            }
+            parts.push({ text: ": " });
+            if (mappedType.type) {
+              visitForDisplayParts(mappedType.type);
+            }
+            parts.push({ text: "; }" });
+            break;
+          case 201 /* LiteralType */:
+            visitForDisplayParts(node.literal);
+            break;
+          case 184 /* FunctionType */:
+            const functionType = node;
+            if (functionType.typeParameters) {
+              parts.push({ text: "<" });
+              visitDisplayPartList(functionType.typeParameters, ", ");
+              parts.push({ text: ">" });
+            }
+            parts.push({ text: "(" });
+            visitDisplayPartList(functionType.parameters, ", ");
+            parts.push({ text: ")" });
+            parts.push({ text: " => " });
+            visitForDisplayParts(functionType.type);
+            break;
+          case 205 /* ImportType */:
+            const importType = node;
+            if (importType.isTypeOf) {
+              parts.push({ text: "typeof " });
+            }
+            parts.push({ text: "import(" });
+            visitForDisplayParts(importType.argument);
+            if (importType.assertions) {
+              parts.push({ text: ", { assert: " });
+              visitDisplayPartList(importType.assertions.assertClause.elements, ", ");
+              parts.push({ text: " }" });
+            }
+            parts.push({ text: ")" });
+            if (importType.qualifier) {
+              parts.push({ text: "." });
+              visitForDisplayParts(importType.qualifier);
+            }
+            if (importType.typeArguments) {
+              parts.push({ text: "<" });
+              visitDisplayPartList(importType.typeArguments, ", ");
+              parts.push({ text: ">" });
+            }
+            break;
+          case 171 /* PropertySignature */:
+            const propertySignature = node;
+            if (propertySignature.modifiers) {
+              visitDisplayPartList(propertySignature.modifiers, " ");
+            }
+            visitForDisplayParts(propertySignature.name);
+            if (propertySignature.questionToken) {
+              parts.push({ text: "?" });
+            }
+            if (propertySignature.type) {
+              parts.push({ text: ": " });
+              visitForDisplayParts(propertySignature.type);
+            }
+            break;
+          default:
+            Debug.failBadSyntaxKind(node);
         }
       }
-      prevChar = strChar;
+      function visitDisplayPartList(nodes, separator) {
+        nodes.forEach((node, index) => {
+          if (index > 0) {
+            parts.push({ text: separator });
+          }
+          visitForDisplayParts(node);
+        });
+      }
+      function getLiteralText2(node) {
+        if (isStringLiteral(node)) {
+          return quotePreference === 0 /* Single */ ? `'${escapeString(node.text, 39 /* singleQuote */)}'` : `"${escapeString(node.text, 34 /* doubleQuote */)}"`;
+        }
+        return node.text;
+      }
     }
-    return false;
-  }
-  function toUpperCharCode(charCode) {
-    if (97 /* a */ <= charCode && charCode <= 122 /* z */) {
-      return charCode - 32;
+    function isUndefined(name) {
+      return name === "undefined";
+    }
+    function isHintableDeclaration(node) {
+      if ((isParameterDeclaration(node) || isVariableDeclaration(node) && isVarConst(node)) && node.initializer) {
+        const initializer = skipParentheses(node.initializer);
+        return !(isHintableLiteral(initializer) || isNewExpression(initializer) || isObjectLiteralExpression(initializer) || isAssertionExpression(initializer));
+      }
+      return true;
+    }
+    function getNodeDisplayPart(text, node) {
+      const sourceFile = node.getSourceFile();
+      return {
+        text,
+        span: createTextSpanFromNode(node, sourceFile),
+        file: sourceFile.fileName
+      };
     }
-    return charCode;
   }
-  var moduleSpecifierResolutionLimit, moduleSpecifierResolutionCacheAttemptLimit, SortText, CompletionSource, SymbolOriginInfoKind, CompletionKind, _keywordCompletions, allKeywordsCompletions;
-  var init_completions = __esm({
-    "src/services/completions.ts"() {
+  var leadingParameterNameCommentRegexFactory;
+  var init_inlayHints = __esm({
+    "src/services/inlayHints.ts"() {
       "use strict";
       init_ts4();
-      init_ts_Completions();
-      moduleSpecifierResolutionLimit = 100;
-      moduleSpecifierResolutionCacheAttemptLimit = 1e3;
-      SortText = {
-        // Presets
-        LocalDeclarationPriority: "10",
-        LocationPriority: "11",
-        OptionalMember: "12",
-        MemberDeclaredBySpreadAssignment: "13",
-        SuggestedClassMembers: "14",
-        GlobalsOrKeywords: "15",
-        AutoImportSuggestions: "16",
-        ClassMemberSnippets: "17",
-        JavascriptIdentifiers: "18",
-        // Transformations
-        Deprecated(sortText) {
-          return "z" + sortText;
-        },
-        ObjectLiteralProperty(presetSortText, symbolDisplayName) {
-          return `${presetSortText}\0${symbolDisplayName}\0`;
-        },
-        SortBelow(sortText) {
-          return sortText + "1";
-        }
+      leadingParameterNameCommentRegexFactory = (name) => {
+        return new RegExp(`^\\s?/\\*\\*?\\s?${name}\\s?\\*\\/\\s?$`);
       };
-      CompletionSource = /* @__PURE__ */ ((CompletionSource2) => {
-        CompletionSource2["ThisProperty"] = "ThisProperty/";
-        CompletionSource2["ClassMemberSnippet"] = "ClassMemberSnippet/";
-        CompletionSource2["TypeOnlyAlias"] = "TypeOnlyAlias/";
-        CompletionSource2["ObjectLiteralMethodSnippet"] = "ObjectLiteralMethodSnippet/";
-        CompletionSource2["SwitchCases"] = "SwitchCases/";
-        return CompletionSource2;
-      })(CompletionSource || {});
-      SymbolOriginInfoKind = /* @__PURE__ */ ((SymbolOriginInfoKind2) => {
-        SymbolOriginInfoKind2[SymbolOriginInfoKind2["ThisType"] = 1] = "ThisType";
-        SymbolOriginInfoKind2[SymbolOriginInfoKind2["SymbolMember"] = 2] = "SymbolMember";
-        SymbolOriginInfoKind2[SymbolOriginInfoKind2["Export"] = 4] = "Export";
-        SymbolOriginInfoKind2[SymbolOriginInfoKind2["Promise"] = 8] = "Promise";
-        SymbolOriginInfoKind2[SymbolOriginInfoKind2["Nullable"] = 16] = "Nullable";
-        SymbolOriginInfoKind2[SymbolOriginInfoKind2["ResolvedExport"] = 32] = "ResolvedExport";
-        SymbolOriginInfoKind2[SymbolOriginInfoKind2["TypeOnlyAlias"] = 64] = "TypeOnlyAlias";
-        SymbolOriginInfoKind2[SymbolOriginInfoKind2["ObjectLiteralMethod"] = 128] = "ObjectLiteralMethod";
-        SymbolOriginInfoKind2[SymbolOriginInfoKind2["Ignore"] = 256] = "Ignore";
-        SymbolOriginInfoKind2[SymbolOriginInfoKind2["ComputedPropertyName"] = 512] = "ComputedPropertyName";
-        SymbolOriginInfoKind2[SymbolOriginInfoKind2["SymbolMemberNoExport"] = 2 /* SymbolMember */] = "SymbolMemberNoExport";
-        SymbolOriginInfoKind2[SymbolOriginInfoKind2["SymbolMemberExport"] = 6] = "SymbolMemberExport";
-        return SymbolOriginInfoKind2;
-      })(SymbolOriginInfoKind || {});
-      CompletionKind = /* @__PURE__ */ ((CompletionKind2) => {
-        CompletionKind2[CompletionKind2["ObjectPropertyDeclaration"] = 0] = "ObjectPropertyDeclaration";
-        CompletionKind2[CompletionKind2["Global"] = 1] = "Global";
-        CompletionKind2[CompletionKind2["PropertyAccess"] = 2] = "PropertyAccess";
-        CompletionKind2[CompletionKind2["MemberLike"] = 3] = "MemberLike";
-        CompletionKind2[CompletionKind2["String"] = 4] = "String";
-        CompletionKind2[CompletionKind2["None"] = 5] = "None";
-        return CompletionKind2;
-      })(CompletionKind || {});
-      _keywordCompletions = [];
-      allKeywordsCompletions = memoize(() => {
-        const res = [];
-        for (let i = 83 /* FirstKeyword */; i <= 164 /* LastKeyword */; i++) {
-          res.push({
-            name: tokenToString(i),
-            kind: "keyword" /* keyword */,
-            kindModifiers: "" /* none */,
-            sortText: SortText.GlobalsOrKeywords
-          });
-        }
-        return res;
-      });
     }
   });
 
-  // src/services/stringCompletions.ts
-  function createNameAndKindSet() {
-    const map2 = /* @__PURE__ */ new Map();
-    function add(value) {
-      const existing = map2.get(value.name);
-      if (!existing || kindPrecedence[existing.kind] < kindPrecedence[value.kind]) {
-        map2.set(value.name, value);
-      }
+  // src/services/_namespaces/ts.InlayHints.ts
+  var ts_InlayHints_exports = {};
+  __export(ts_InlayHints_exports, {
+    provideInlayHints: () => provideInlayHints
+  });
+  var init_ts_InlayHints = __esm({
+    "src/services/_namespaces/ts.InlayHints.ts"() {
+      "use strict";
+      init_inlayHints();
     }
-    return {
-      add,
-      has: map2.has.bind(map2),
-      values: map2.values.bind(map2)
-    };
+  });
+
+  // src/services/jsDoc.ts
+  function getJsDocCommentsFromDeclarations(declarations, checker) {
+    const parts = [];
+    forEachUnique(declarations, (declaration) => {
+      for (const jsdoc of getCommentHavingNodes(declaration)) {
+        const inheritDoc = isJSDoc(jsdoc) && jsdoc.tags && find(jsdoc.tags, (t) => t.kind === 334 /* JSDocTag */ && (t.tagName.escapedText === "inheritDoc" || t.tagName.escapedText === "inheritdoc"));
+        if (jsdoc.comment === void 0 && !inheritDoc || isJSDoc(jsdoc) && declaration.kind !== 353 /* JSDocTypedefTag */ && declaration.kind !== 345 /* JSDocCallbackTag */ && jsdoc.tags && jsdoc.tags.some((t) => t.kind === 353 /* JSDocTypedefTag */ || t.kind === 345 /* JSDocCallbackTag */) && !jsdoc.tags.some((t) => t.kind === 348 /* JSDocParameterTag */ || t.kind === 349 /* JSDocReturnTag */)) {
+          continue;
+        }
+        let newparts = jsdoc.comment ? getDisplayPartsFromComment(jsdoc.comment, checker) : [];
+        if (inheritDoc && inheritDoc.comment) {
+          newparts = newparts.concat(getDisplayPartsFromComment(inheritDoc.comment, checker));
+        }
+        if (!contains(parts, newparts, isIdenticalListOfDisplayParts)) {
+          parts.push(newparts);
+        }
+      }
+    });
+    return flatten(intersperse(parts, [lineBreakPart()]));
   }
-  function getStringLiteralCompletions(sourceFile, position, contextToken, options, host, program, log, preferences, includeSymbol) {
-    if (isInReferenceComment(sourceFile, position)) {
-      const entries = getTripleSlashReferenceCompletion(sourceFile, position, options, host);
-      return entries && convertPathCompletions(entries);
-    }
-    if (isInString(sourceFile, position, contextToken)) {
-      if (!contextToken || !isStringLiteralLike(contextToken))
-        return void 0;
-      const entries = getStringLiteralCompletionEntries(sourceFile, contextToken, position, program.getTypeChecker(), options, host, preferences);
-      return convertStringLiteralCompletions(entries, contextToken, sourceFile, host, program, log, options, preferences, position, includeSymbol);
-    }
+  function isIdenticalListOfDisplayParts(parts1, parts2) {
+    return arraysEqual(parts1, parts2, (p1, p2) => p1.kind === p2.kind && p1.text === p2.text);
   }
-  function convertStringLiteralCompletions(completion, contextToken, sourceFile, host, program, log, options, preferences, position, includeSymbol) {
-    if (completion === void 0) {
-      return void 0;
-    }
-    const optionalReplacementSpan = createTextSpanFromStringLiteralLikeContent(contextToken);
-    switch (completion.kind) {
-      case 0 /* Paths */:
-        return convertPathCompletions(completion.paths);
-      case 1 /* Properties */: {
-        const entries = createSortedArray();
-        getCompletionEntriesFromSymbols(
-          completion.symbols,
-          entries,
-          contextToken,
-          contextToken,
-          sourceFile,
-          position,
-          sourceFile,
-          host,
-          program,
-          99 /* ESNext */,
-          log,
-          4 /* String */,
-          preferences,
-          options,
-          /*formatContext*/
-          void 0,
-          /*isTypeOnlyLocation*/
-          void 0,
-          /*propertyAccessToConvert*/
-          void 0,
-          /*jsxIdentifierExpected*/
-          void 0,
-          /*isJsxInitializer*/
-          void 0,
-          /*importStatementCompletion*/
-          void 0,
-          /*recommendedCompletion*/
-          void 0,
-          /*symbolToOriginInfoMap*/
-          void 0,
-          /*symbolToSortTextMap*/
-          void 0,
-          /*isJsxIdentifierExpected*/
-          void 0,
-          /*isRightOfOpenTag*/
-          void 0,
-          includeSymbol
-        );
-        return { isGlobalCompletion: false, isMemberCompletion: true, isNewIdentifierLocation: completion.hasIndexSignature, optionalReplacementSpan, entries };
-      }
-      case 2 /* Types */: {
-        const entries = completion.types.map((type) => ({
-          name: type.value,
-          kindModifiers: "" /* none */,
-          kind: "string" /* string */,
-          sortText: SortText.LocationPriority,
-          replacementSpan: getReplacementSpanForContextToken(contextToken)
-        }));
-        return { isGlobalCompletion: false, isMemberCompletion: false, isNewIdentifierLocation: completion.isNewIdentifier, optionalReplacementSpan, entries };
-      }
+  function getCommentHavingNodes(declaration) {
+    switch (declaration.kind) {
+      case 348 /* JSDocParameterTag */:
+      case 355 /* JSDocPropertyTag */:
+        return [declaration];
+      case 345 /* JSDocCallbackTag */:
+      case 353 /* JSDocTypedefTag */:
+        return [declaration, declaration.parent];
+      case 330 /* JSDocSignature */:
+        if (isJSDocOverloadTag(declaration.parent)) {
+          return [declaration.parent.parent];
+        }
       default:
-        return Debug.assertNever(completion);
+        return getJSDocCommentsAndTags(declaration);
     }
   }
-  function getStringLiteralCompletionDetails(name, sourceFile, position, contextToken, checker, options, host, cancellationToken, preferences) {
-    if (!contextToken || !isStringLiteralLike(contextToken))
-      return void 0;
-    const completions = getStringLiteralCompletionEntries(sourceFile, contextToken, position, checker, options, host, preferences);
-    return completions && stringLiteralCompletionDetails(name, contextToken, completions, sourceFile, checker, cancellationToken);
-  }
-  function stringLiteralCompletionDetails(name, location, completion, sourceFile, checker, cancellationToken) {
-    switch (completion.kind) {
-      case 0 /* Paths */: {
-        const match = find(completion.paths, (p) => p.name === name);
-        return match && createCompletionDetails(name, kindModifiersFromExtension(match.extension), match.kind, [textPart(name)]);
+  function getJsDocTagsFromDeclarations(declarations, checker) {
+    const infos = [];
+    forEachUnique(declarations, (declaration) => {
+      const tags = getJSDocTags(declaration);
+      if (tags.some((t) => t.kind === 353 /* JSDocTypedefTag */ || t.kind === 345 /* JSDocCallbackTag */) && !tags.some((t) => t.kind === 348 /* JSDocParameterTag */ || t.kind === 349 /* JSDocReturnTag */)) {
+        return;
       }
-      case 1 /* Properties */: {
-        const match = find(completion.symbols, (s) => s.name === name);
-        return match && createCompletionDetailsForSymbol(match, match.name, checker, sourceFile, location, cancellationToken);
+      for (const tag of tags) {
+        infos.push({ name: tag.tagName.text, text: getCommentDisplayParts(tag, checker) });
+        if (isJSDocPropertyLikeTag(tag) && tag.isNameFirst && tag.typeExpression && isJSDocTypeLiteral(tag.typeExpression.type)) {
+          forEach(tag.typeExpression.type.jsDocPropertyTags, (propTag) => {
+            infos.push({ name: propTag.tagName.text, text: getCommentDisplayParts(propTag, checker) });
+          });
+        }
       }
-      case 2 /* Types */:
-        return find(completion.types, (t) => t.value === name) ? createCompletionDetails(name, "" /* none */, "string" /* string */, [textPart(name)]) : void 0;
-      default:
-        return Debug.assertNever(completion);
-    }
-  }
-  function convertPathCompletions(pathCompletions) {
-    const isGlobalCompletion = false;
-    const isNewIdentifierLocation = true;
-    const entries = pathCompletions.map(({ name, kind, span, extension }) => ({ name, kind, kindModifiers: kindModifiersFromExtension(extension), sortText: SortText.LocationPriority, replacementSpan: span }));
-    return { isGlobalCompletion, isMemberCompletion: false, isNewIdentifierLocation, entries };
+    });
+    return infos;
   }
-  function kindModifiersFromExtension(extension) {
-    switch (extension) {
-      case ".d.ts" /* Dts */:
-        return ".d.ts" /* dtsModifier */;
-      case ".js" /* Js */:
-        return ".js" /* jsModifier */;
-      case ".json" /* Json */:
-        return ".json" /* jsonModifier */;
-      case ".jsx" /* Jsx */:
-        return ".jsx" /* jsxModifier */;
-      case ".ts" /* Ts */:
-        return ".ts" /* tsModifier */;
-      case ".tsx" /* Tsx */:
-        return ".tsx" /* tsxModifier */;
-      case ".d.mts" /* Dmts */:
-        return ".d.mts" /* dmtsModifier */;
-      case ".mjs" /* Mjs */:
-        return ".mjs" /* mjsModifier */;
-      case ".mts" /* Mts */:
-        return ".mts" /* mtsModifier */;
-      case ".d.cts" /* Dcts */:
-        return ".d.cts" /* dctsModifier */;
-      case ".cjs" /* Cjs */:
-        return ".cjs" /* cjsModifier */;
-      case ".cts" /* Cts */:
-        return ".cts" /* ctsModifier */;
-      case ".tsbuildinfo" /* TsBuildInfo */:
-        return Debug.fail(`Extension ${".tsbuildinfo" /* TsBuildInfo */} is unsupported.`);
-      case void 0:
-        return "" /* none */;
-      default:
-        return Debug.assertNever(extension);
+  function getDisplayPartsFromComment(comment, checker) {
+    if (typeof comment === "string") {
+      return [textPart(comment)];
     }
+    return flatMap(
+      comment,
+      (node) => node.kind === 328 /* JSDocText */ ? [textPart(node.text)] : buildLinkParts(node, checker)
+    );
   }
-  function getStringLiteralCompletionEntries(sourceFile, node, position, typeChecker, compilerOptions, host, preferences) {
-    const parent2 = walkUpParentheses(node.parent);
-    switch (parent2.kind) {
-      case 200 /* LiteralType */: {
-        const grandParent = walkUpParentheses(parent2.parent);
-        if (grandParent.kind === 204 /* ImportType */) {
-          return { kind: 0 /* Paths */, paths: getStringLiteralCompletionsFromModuleNames(sourceFile, node, compilerOptions, host, typeChecker, preferences) };
-        }
-        return fromUnionableLiteralType(grandParent);
-      }
-      case 302 /* PropertyAssignment */:
-        if (isObjectLiteralExpression(parent2.parent) && parent2.name === node) {
-          return stringLiteralCompletionsForObjectLiteral(typeChecker, parent2.parent);
-        }
-        return fromContextualType() || fromContextualType(0 /* None */);
-      case 211 /* ElementAccessExpression */: {
-        const { expression, argumentExpression } = parent2;
-        if (node === skipParentheses(argumentExpression)) {
-          return stringLiteralCompletionsFromProperties(typeChecker.getTypeAtLocation(expression));
+  function getCommentDisplayParts(tag, checker) {
+    const { comment, kind } = tag;
+    const namePart = getTagNameDisplayPart(kind);
+    switch (kind) {
+      case 356 /* JSDocThrowsTag */:
+        const typeExpression = tag.typeExpression;
+        return typeExpression ? withNode(typeExpression) : comment === void 0 ? void 0 : getDisplayPartsFromComment(comment, checker);
+      case 336 /* JSDocImplementsTag */:
+        return withNode(tag.class);
+      case 335 /* JSDocAugmentsTag */:
+        return withNode(tag.class);
+      case 352 /* JSDocTemplateTag */:
+        const templateTag = tag;
+        const displayParts = [];
+        if (templateTag.constraint) {
+          displayParts.push(textPart(templateTag.constraint.getText()));
         }
-        return void 0;
-      }
-      case 212 /* CallExpression */:
-      case 213 /* NewExpression */:
-      case 290 /* JsxAttribute */:
-        if (!isRequireCallArgument(node) && !isImportCall(parent2)) {
-          const argumentInfo = ts_SignatureHelp_exports.getArgumentInfoForCompletions(parent2.kind === 290 /* JsxAttribute */ ? parent2.parent : node, position, sourceFile);
-          return argumentInfo && getStringLiteralCompletionsFromSignature(argumentInfo.invocation, node, argumentInfo, typeChecker) || fromContextualType(0 /* None */);
+        if (length(templateTag.typeParameters)) {
+          if (length(displayParts)) {
+            displayParts.push(spacePart());
+          }
+          const lastTypeParameter = templateTag.typeParameters[templateTag.typeParameters.length - 1];
+          forEach(templateTag.typeParameters, (tp) => {
+            displayParts.push(namePart(tp.getText()));
+            if (lastTypeParameter !== tp) {
+              displayParts.push(...[punctuationPart(28 /* CommaToken */), spacePart()]);
+            }
+          });
         }
-      case 271 /* ImportDeclaration */:
-      case 277 /* ExportDeclaration */:
-      case 282 /* ExternalModuleReference */:
-        return { kind: 0 /* Paths */, paths: getStringLiteralCompletionsFromModuleNames(sourceFile, node, compilerOptions, host, typeChecker, preferences) };
-      case 295 /* CaseClause */:
-        const tracker = newCaseClauseTracker(typeChecker, parent2.parent.clauses);
-        const contextualTypes = fromContextualType();
-        if (!contextualTypes) {
-          return;
+        if (comment) {
+          displayParts.push(...[spacePart(), ...getDisplayPartsFromComment(comment, checker)]);
         }
-        const literals = contextualTypes.types.filter((literal) => !tracker.hasValue(literal.value));
-        return { kind: 2 /* Types */, types: literals, isNewIdentifier: false };
+        return displayParts;
+      case 351 /* JSDocTypeTag */:
+      case 357 /* JSDocSatisfiesTag */:
+        return withNode(tag.typeExpression);
+      case 353 /* JSDocTypedefTag */:
+      case 345 /* JSDocCallbackTag */:
+      case 355 /* JSDocPropertyTag */:
+      case 348 /* JSDocParameterTag */:
+      case 354 /* JSDocSeeTag */:
+        const { name } = tag;
+        return name ? withNode(name) : comment === void 0 ? void 0 : getDisplayPartsFromComment(comment, checker);
       default:
-        return fromContextualType() || fromContextualType(0 /* None */);
+        return comment === void 0 ? void 0 : getDisplayPartsFromComment(comment, checker);
     }
-    function fromUnionableLiteralType(grandParent) {
-      switch (grandParent.kind) {
-        case 232 /* ExpressionWithTypeArguments */:
-        case 182 /* TypeReference */: {
-          const typeArgument = findAncestor(parent2, (n) => n.parent === grandParent);
-          if (typeArgument) {
-            return { kind: 2 /* Types */, types: getStringLiteralTypes(typeChecker.getTypeArgumentConstraint(typeArgument)), isNewIdentifier: false };
-          }
-          return void 0;
-        }
-        case 198 /* IndexedAccessType */:
-          const { indexType, objectType } = grandParent;
-          if (!rangeContainsPosition(indexType, position)) {
-            return void 0;
-          }
-          return stringLiteralCompletionsFromProperties(typeChecker.getTypeFromTypeNode(objectType));
-        case 191 /* UnionType */: {
-          const result = fromUnionableLiteralType(walkUpParentheses(grandParent.parent));
-          if (!result) {
-            return void 0;
-          }
-          const alreadyUsedTypes = getAlreadyUsedTypesInStringLiteralUnion(grandParent, parent2);
-          if (result.kind === 1 /* Properties */) {
-            return { kind: 1 /* Properties */, symbols: result.symbols.filter((sym) => !contains(alreadyUsedTypes, sym.name)), hasIndexSignature: result.hasIndexSignature };
-          }
-          return { kind: 2 /* Types */, types: result.types.filter((t) => !contains(alreadyUsedTypes, t.value)), isNewIdentifier: false };
-        }
-        default:
-          return void 0;
-      }
+    function withNode(node) {
+      return addComment(node.getText());
     }
-    function fromContextualType(contextFlags = 4 /* Completions */) {
-      const types = getStringLiteralTypes(getContextualTypeFromParent(node, typeChecker, contextFlags));
-      if (!types.length) {
-        return;
+    function addComment(s) {
+      if (comment) {
+        if (s.match(/^https?$/)) {
+          return [textPart(s), ...getDisplayPartsFromComment(comment, checker)];
+        } else {
+          return [namePart(s), spacePart(), ...getDisplayPartsFromComment(comment, checker)];
+        }
+      } else {
+        return [textPart(s)];
       }
-      return { kind: 2 /* Types */, types, isNewIdentifier: false };
     }
   }
-  function walkUpParentheses(node) {
-    switch (node.kind) {
-      case 195 /* ParenthesizedType */:
-        return walkUpParenthesizedTypes(node);
-      case 216 /* ParenthesizedExpression */:
-        return walkUpParenthesizedExpressions(node);
+  function getTagNameDisplayPart(kind) {
+    switch (kind) {
+      case 348 /* JSDocParameterTag */:
+        return parameterNamePart;
+      case 355 /* JSDocPropertyTag */:
+        return propertyNamePart;
+      case 352 /* JSDocTemplateTag */:
+        return typeParameterNamePart;
+      case 353 /* JSDocTypedefTag */:
+      case 345 /* JSDocCallbackTag */:
+        return typeAliasNamePart;
       default:
-        return node;
+        return textPart;
     }
   }
-  function getAlreadyUsedTypesInStringLiteralUnion(union, current) {
-    return mapDefined(union.types, (type) => type !== current && isLiteralTypeNode(type) && isStringLiteral(type.literal) ? type.literal.text : void 0);
-  }
-  function getStringLiteralCompletionsFromSignature(call, arg, argumentInfo, checker) {
-    let isNewIdentifier = false;
-    const uniques = /* @__PURE__ */ new Map();
-    const candidates = [];
-    const editingArgument = isJsxOpeningLikeElement(call) ? Debug.checkDefined(findAncestor(arg.parent, isJsxAttribute)) : arg;
-    checker.getResolvedSignatureForStringLiteralCompletions(call, editingArgument, candidates);
-    const types = flatMap(candidates, (candidate) => {
-      if (!signatureHasRestParameter(candidate) && argumentInfo.argumentCount > candidate.parameters.length)
-        return;
-      let type = candidate.getTypeParameterAtPosition(argumentInfo.argumentIndex);
-      if (isJsxOpeningLikeElement(call)) {
-        const propType = checker.getTypeOfPropertyOfType(type, getTextOfJsxAttributeName(editingArgument.name));
-        if (propType) {
-          type = propType;
-        }
-      }
-      isNewIdentifier = isNewIdentifier || !!(type.flags & 4 /* String */);
-      return getStringLiteralTypes(type, uniques);
-    });
-    return length(types) ? { kind: 2 /* Types */, types, isNewIdentifier } : void 0;
+  function getJSDocTagNameCompletions() {
+    return jsDocTagNameCompletionEntries || (jsDocTagNameCompletionEntries = map(jsDocTagNames, (tagName) => {
+      return {
+        name: tagName,
+        kind: "keyword" /* keyword */,
+        kindModifiers: "",
+        sortText: ts_Completions_exports.SortText.LocationPriority
+      };
+    }));
   }
-  function stringLiteralCompletionsFromProperties(type) {
-    return type && {
-      kind: 1 /* Properties */,
-      symbols: filter(type.getApparentProperties(), (prop) => !(prop.valueDeclaration && isPrivateIdentifierClassElementDeclaration(prop.valueDeclaration))),
-      hasIndexSignature: hasIndexSignature(type)
-    };
+  function getJSDocTagCompletions() {
+    return jsDocTagCompletionEntries || (jsDocTagCompletionEntries = map(jsDocTagNames, (tagName) => {
+      return {
+        name: `@${tagName}`,
+        kind: "keyword" /* keyword */,
+        kindModifiers: "",
+        sortText: ts_Completions_exports.SortText.LocationPriority
+      };
+    }));
   }
-  function stringLiteralCompletionsForObjectLiteral(checker, objectLiteralExpression) {
-    const contextualType = checker.getContextualType(objectLiteralExpression);
-    if (!contextualType)
-      return void 0;
-    const completionsType = checker.getContextualType(objectLiteralExpression, 4 /* Completions */);
-    const symbols = getPropertiesForObjectExpression(
-      contextualType,
-      completionsType,
-      objectLiteralExpression,
-      checker
-    );
+  function getJSDocTagCompletionDetails(name) {
     return {
-      kind: 1 /* Properties */,
-      symbols,
-      hasIndexSignature: hasIndexSignature(contextualType)
+      name,
+      kind: "" /* unknown */,
+      // TODO: should have its own kind?
+      kindModifiers: "",
+      displayParts: [textPart(name)],
+      documentation: emptyArray,
+      tags: void 0,
+      codeActions: void 0
     };
   }
-  function getStringLiteralTypes(type, uniques = /* @__PURE__ */ new Map()) {
-    if (!type)
+  function getJSDocParameterNameCompletions(tag) {
+    if (!isIdentifier(tag.name)) {
       return emptyArray;
-    type = skipConstraint(type);
-    return type.isUnion() ? flatMap(type.types, (t) => getStringLiteralTypes(t, uniques)) : type.isStringLiteral() && !(type.flags & 1024 /* EnumLiteral */) && addToSeen(uniques, type.value) ? [type] : emptyArray;
-  }
-  function nameAndKind(name, kind, extension) {
-    return { name, kind, extension };
+    }
+    const nameThusFar = tag.name.text;
+    const jsdoc = tag.parent;
+    const fn = jsdoc.parent;
+    if (!isFunctionLike(fn))
+      return [];
+    return mapDefined(fn.parameters, (param) => {
+      if (!isIdentifier(param.name))
+        return void 0;
+      const name = param.name.text;
+      if (jsdoc.tags.some((t) => t !== tag && isJSDocParameterTag(t) && isIdentifier(t.name) && t.name.escapedText === name) || nameThusFar !== void 0 && !startsWith(name, nameThusFar)) {
+        return void 0;
+      }
+      return { name, kind: "parameter" /* parameterElement */, kindModifiers: "", sortText: ts_Completions_exports.SortText.LocationPriority };
+    });
   }
-  function directoryResult(name) {
-    return nameAndKind(
+  function getJSDocParameterNameCompletionDetails(name) {
+    return {
       name,
-      "directory" /* directory */,
-      /*extension*/
-      void 0
-    );
+      kind: "parameter" /* parameterElement */,
+      kindModifiers: "",
+      displayParts: [textPart(name)],
+      documentation: emptyArray,
+      tags: void 0,
+      codeActions: void 0
+    };
   }
-  function addReplacementSpans(text, textStart, names) {
-    const span = getDirectoryFragmentTextSpan(text, textStart);
-    const wholeSpan = text.length === 0 ? void 0 : createTextSpan(textStart, text.length);
-    return names.map(({ name, kind, extension }) => Math.max(name.indexOf(directorySeparator), name.indexOf(altDirectorySeparator)) !== -1 ? { name, kind, extension, span: wholeSpan } : { name, kind, extension, span });
+  function getDocCommentTemplateAtPosition(newLine, sourceFile, position, options) {
+    const tokenAtPos = getTokenAtPosition(sourceFile, position);
+    const existingDocComment = findAncestor(tokenAtPos, isJSDoc);
+    if (existingDocComment && (existingDocComment.comment !== void 0 || length(existingDocComment.tags))) {
+      return void 0;
+    }
+    const tokenStart = tokenAtPos.getStart(sourceFile);
+    if (!existingDocComment && tokenStart < position) {
+      return void 0;
+    }
+    const commentOwnerInfo = getCommentOwnerInfo(tokenAtPos, options);
+    if (!commentOwnerInfo) {
+      return void 0;
+    }
+    const { commentOwner, parameters, hasReturn: hasReturn2 } = commentOwnerInfo;
+    const commentOwnerJsDoc = hasJSDocNodes(commentOwner) && commentOwner.jsDoc ? commentOwner.jsDoc : void 0;
+    const lastJsDoc = lastOrUndefined(commentOwnerJsDoc);
+    if (commentOwner.getStart(sourceFile) < position || lastJsDoc && existingDocComment && lastJsDoc !== existingDocComment) {
+      return void 0;
+    }
+    const indentationStr = getIndentationStringAtPosition(sourceFile, position);
+    const isJavaScriptFile = hasJSFileExtension(sourceFile.fileName);
+    const tags = (parameters ? parameterDocComments(parameters || [], isJavaScriptFile, indentationStr, newLine) : "") + (hasReturn2 ? returnsDocComment(indentationStr, newLine) : "");
+    const openComment = "/**";
+    const closeComment = " */";
+    const hasTag = length(getJSDocTags(commentOwner)) > 0;
+    if (tags && !hasTag) {
+      const preamble = openComment + newLine + indentationStr + " * ";
+      const endLine = tokenStart === position ? newLine + indentationStr : "";
+      const result = preamble + newLine + tags + indentationStr + closeComment + endLine;
+      return { newText: result, caretOffset: preamble.length };
+    }
+    return { newText: openComment + closeComment, caretOffset: 3 };
   }
-  function getStringLiteralCompletionsFromModuleNames(sourceFile, node, compilerOptions, host, typeChecker, preferences) {
-    return addReplacementSpans(node.text, node.getStart(sourceFile) + 1, getStringLiteralCompletionsFromModuleNamesWorker(sourceFile, node, compilerOptions, host, typeChecker, preferences));
+  function getIndentationStringAtPosition(sourceFile, position) {
+    const { text } = sourceFile;
+    const lineStart = getLineStartPositionForPosition(position, sourceFile);
+    let pos = lineStart;
+    for (; pos <= position && isWhiteSpaceSingleLine(text.charCodeAt(pos)); pos++)
+      ;
+    return text.slice(lineStart, pos);
   }
-  function getStringLiteralCompletionsFromModuleNamesWorker(sourceFile, node, compilerOptions, host, typeChecker, preferences) {
-    const literalValue = normalizeSlashes(node.text);
-    const mode = isStringLiteralLike(node) ? getModeForUsageLocation(sourceFile, node) : void 0;
-    const scriptPath = sourceFile.path;
-    const scriptDirectory = getDirectoryPath(scriptPath);
-    const extensionOptions = getExtensionOptions(compilerOptions, 1 /* ModuleSpecifier */, sourceFile, typeChecker, preferences, mode);
-    return isPathRelativeToScript(literalValue) || !compilerOptions.baseUrl && !compilerOptions.paths && (isRootedDiskPath(literalValue) || isUrl(literalValue)) ? getCompletionEntriesForRelativeModules(literalValue, scriptDirectory, compilerOptions, host, scriptPath, extensionOptions) : getCompletionEntriesForNonRelativeModules(literalValue, scriptDirectory, mode, compilerOptions, host, extensionOptions, typeChecker);
+  function parameterDocComments(parameters, isJavaScriptFile, indentationStr, newLine) {
+    return parameters.map(({ name, dotDotDotToken }, i) => {
+      const paramName = name.kind === 80 /* Identifier */ ? name.text : "param" + i;
+      const type = isJavaScriptFile ? dotDotDotToken ? "{...any} " : "{any} " : "";
+      return `${indentationStr} * @param ${type}${paramName}${newLine}`;
+    }).join("");
   }
-  function getExtensionOptions(compilerOptions, referenceKind, importingSourceFile, typeChecker, preferences, resolutionMode) {
-    return {
-      extensionsToSearch: flatten(getSupportedExtensionsForModuleResolution(compilerOptions, typeChecker)),
-      referenceKind,
-      importingSourceFile,
-      endingPreference: preferences == null ? void 0 : preferences.importModuleSpecifierEnding,
-      resolutionMode
-    };
+  function returnsDocComment(indentationStr, newLine) {
+    return `${indentationStr} * @returns${newLine}`;
   }
-  function getCompletionEntriesForRelativeModules(literalValue, scriptDirectory, compilerOptions, host, scriptPath, extensionOptions) {
-    if (compilerOptions.rootDirs) {
-      return getCompletionEntriesForDirectoryFragmentWithRootDirs(
-        compilerOptions.rootDirs,
-        literalValue,
-        scriptDirectory,
-        extensionOptions,
-        compilerOptions,
-        host,
-        scriptPath
-      );
-    } else {
-      return arrayFrom(getCompletionEntriesForDirectoryFragment(
-        literalValue,
-        scriptDirectory,
-        extensionOptions,
-        host,
-        /*moduleSpecifierIsRelative*/
-        false,
-        scriptPath
-      ).values());
-    }
+  function getCommentOwnerInfo(tokenAtPos, options) {
+    return forEachAncestor(tokenAtPos, (n) => getCommentOwnerInfoWorker(n, options));
   }
-  function getSupportedExtensionsForModuleResolution(compilerOptions, typeChecker) {
-    const ambientModulesExtensions = !typeChecker ? [] : mapDefined(
-      typeChecker.getAmbientModules(),
-      (module2) => {
-        const name = module2.name.slice(1, -1);
-        if (!name.startsWith("*.") || name.includes("/"))
-          return;
-        return name.slice(1);
+  function getCommentOwnerInfoWorker(commentOwner, options) {
+    switch (commentOwner.kind) {
+      case 262 /* FunctionDeclaration */:
+      case 218 /* FunctionExpression */:
+      case 174 /* MethodDeclaration */:
+      case 176 /* Constructor */:
+      case 173 /* MethodSignature */:
+      case 219 /* ArrowFunction */:
+        const host = commentOwner;
+        return { commentOwner, parameters: host.parameters, hasReturn: hasReturn(host, options) };
+      case 303 /* PropertyAssignment */:
+        return getCommentOwnerInfoWorker(commentOwner.initializer, options);
+      case 263 /* ClassDeclaration */:
+      case 264 /* InterfaceDeclaration */:
+      case 266 /* EnumDeclaration */:
+      case 306 /* EnumMember */:
+      case 265 /* TypeAliasDeclaration */:
+        return { commentOwner };
+      case 171 /* PropertySignature */: {
+        const host2 = commentOwner;
+        return host2.type && isFunctionTypeNode(host2.type) ? { commentOwner, parameters: host2.type.parameters, hasReturn: hasReturn(host2.type, options) } : { commentOwner };
       }
-    );
-    const extensions = [...getSupportedExtensions(compilerOptions), ambientModulesExtensions];
-    const moduleResolution = getEmitModuleResolutionKind(compilerOptions);
-    return moduleResolutionUsesNodeModules(moduleResolution) ? getSupportedExtensionsWithJsonIfResolveJsonModule(compilerOptions, extensions) : extensions;
+      case 243 /* VariableStatement */: {
+        const varStatement = commentOwner;
+        const varDeclarations = varStatement.declarationList.declarations;
+        const host2 = varDeclarations.length === 1 && varDeclarations[0].initializer ? getRightHandSideOfAssignment(varDeclarations[0].initializer) : void 0;
+        return host2 ? { commentOwner, parameters: host2.parameters, hasReturn: hasReturn(host2, options) } : { commentOwner };
+      }
+      case 312 /* SourceFile */:
+        return "quit";
+      case 267 /* ModuleDeclaration */:
+        return commentOwner.parent.kind === 267 /* ModuleDeclaration */ ? void 0 : { commentOwner };
+      case 244 /* ExpressionStatement */:
+        return getCommentOwnerInfoWorker(commentOwner.expression, options);
+      case 226 /* BinaryExpression */: {
+        const be = commentOwner;
+        if (getAssignmentDeclarationKind(be) === 0 /* None */) {
+          return "quit";
+        }
+        return isFunctionLike(be.right) ? { commentOwner, parameters: be.right.parameters, hasReturn: hasReturn(be.right, options) } : { commentOwner };
+      }
+      case 172 /* PropertyDeclaration */:
+        const init = commentOwner.initializer;
+        if (init && (isFunctionExpression(init) || isArrowFunction(init))) {
+          return { commentOwner, parameters: init.parameters, hasReturn: hasReturn(init, options) };
+        }
+    }
   }
-  function getBaseDirectoriesFromRootDirs(rootDirs, basePath, scriptDirectory, ignoreCase) {
-    rootDirs = rootDirs.map((rootDirectory) => normalizePath(isRootedDiskPath(rootDirectory) ? rootDirectory : combinePaths(basePath, rootDirectory)));
-    const relativeDirectory = firstDefined(rootDirs, (rootDirectory) => containsPath(rootDirectory, scriptDirectory, basePath, ignoreCase) ? scriptDirectory.substr(rootDirectory.length) : void 0);
-    return deduplicate(
-      [...rootDirs.map((rootDirectory) => combinePaths(rootDirectory, relativeDirectory)), scriptDirectory],
-      equateStringsCaseSensitive,
-      compareStringsCaseSensitive
-    );
+  function hasReturn(node, options) {
+    return !!(options == null ? void 0 : options.generateReturnInDocTemplate) && (isFunctionTypeNode(node) || isArrowFunction(node) && isExpression(node.body) || isFunctionLikeDeclaration(node) && node.body && isBlock(node.body) && !!forEachReturnStatement(node.body, (n) => n));
   }
-  function getCompletionEntriesForDirectoryFragmentWithRootDirs(rootDirs, fragment, scriptDirectory, extensionOptions, compilerOptions, host, exclude) {
-    const basePath = compilerOptions.project || host.getCurrentDirectory();
-    const ignoreCase = !(host.useCaseSensitiveFileNames && host.useCaseSensitiveFileNames());
-    const baseDirectories = getBaseDirectoriesFromRootDirs(rootDirs, basePath, scriptDirectory, ignoreCase);
-    return flatMap(baseDirectories, (baseDirectory) => arrayFrom(getCompletionEntriesForDirectoryFragment(
-      fragment,
-      baseDirectory,
-      extensionOptions,
-      host,
-      /*moduleSpecifierIsRelative*/
-      true,
-      exclude
-    ).values()));
+  function getRightHandSideOfAssignment(rightHandSide) {
+    while (rightHandSide.kind === 217 /* ParenthesizedExpression */) {
+      rightHandSide = rightHandSide.expression;
+    }
+    switch (rightHandSide.kind) {
+      case 218 /* FunctionExpression */:
+      case 219 /* ArrowFunction */:
+        return rightHandSide;
+      case 231 /* ClassExpression */:
+        return find(rightHandSide.members, isConstructorDeclaration);
+    }
   }
-  function getCompletionEntriesForDirectoryFragment(fragment, scriptDirectory, extensionOptions, host, moduleSpecifierIsRelative, exclude, result = createNameAndKindSet()) {
-    var _a;
-    if (fragment === void 0) {
-      fragment = "";
+  var jsDocTagNames, jsDocTagNameCompletionEntries, jsDocTagCompletionEntries, getJSDocTagNameCompletionDetails;
+  var init_jsDoc = __esm({
+    "src/services/jsDoc.ts"() {
+      "use strict";
+      init_ts4();
+      jsDocTagNames = [
+        "abstract",
+        "access",
+        "alias",
+        "argument",
+        "async",
+        "augments",
+        "author",
+        "borrows",
+        "callback",
+        "class",
+        "classdesc",
+        "constant",
+        "constructor",
+        "constructs",
+        "copyright",
+        "default",
+        "deprecated",
+        "description",
+        "emits",
+        "enum",
+        "event",
+        "example",
+        "exports",
+        "extends",
+        "external",
+        "field",
+        "file",
+        "fileoverview",
+        "fires",
+        "function",
+        "generator",
+        "global",
+        "hideconstructor",
+        "host",
+        "ignore",
+        "implements",
+        "inheritdoc",
+        "inner",
+        "instance",
+        "interface",
+        "kind",
+        "lends",
+        "license",
+        "link",
+        "linkcode",
+        "linkplain",
+        "listens",
+        "member",
+        "memberof",
+        "method",
+        "mixes",
+        "module",
+        "name",
+        "namespace",
+        "overload",
+        "override",
+        "package",
+        "param",
+        "private",
+        "prop",
+        "property",
+        "protected",
+        "public",
+        "readonly",
+        "requires",
+        "returns",
+        "satisfies",
+        "see",
+        "since",
+        "static",
+        "summary",
+        "template",
+        "this",
+        "throws",
+        "todo",
+        "tutorial",
+        "type",
+        "typedef",
+        "var",
+        "variation",
+        "version",
+        "virtual",
+        "yields"
+      ];
+      getJSDocTagNameCompletionDetails = getJSDocTagCompletionDetails;
     }
-    fragment = normalizeSlashes(fragment);
-    if (!hasTrailingDirectorySeparator(fragment)) {
-      fragment = getDirectoryPath(fragment);
+  });
+
+  // src/services/_namespaces/ts.JsDoc.ts
+  var ts_JsDoc_exports = {};
+  __export(ts_JsDoc_exports, {
+    getDocCommentTemplateAtPosition: () => getDocCommentTemplateAtPosition,
+    getJSDocParameterNameCompletionDetails: () => getJSDocParameterNameCompletionDetails,
+    getJSDocParameterNameCompletions: () => getJSDocParameterNameCompletions,
+    getJSDocTagCompletionDetails: () => getJSDocTagCompletionDetails,
+    getJSDocTagCompletions: () => getJSDocTagCompletions,
+    getJSDocTagNameCompletionDetails: () => getJSDocTagNameCompletionDetails,
+    getJSDocTagNameCompletions: () => getJSDocTagNameCompletions,
+    getJsDocCommentsFromDeclarations: () => getJsDocCommentsFromDeclarations,
+    getJsDocTagsFromDeclarations: () => getJsDocTagsFromDeclarations
+  });
+  var init_ts_JsDoc = __esm({
+    "src/services/_namespaces/ts.JsDoc.ts"() {
+      "use strict";
+      init_jsDoc();
+    }
+  });
+
+  // src/services/organizeImports.ts
+  function organizeImports(sourceFile, formatContext, host, program, preferences, mode) {
+    const changeTracker = ts_textChanges_exports.ChangeTracker.fromContext({ host, formatContext, preferences });
+    const shouldSort = mode === "SortAndCombine" /* SortAndCombine */ || mode === "All" /* All */;
+    const shouldCombine = shouldSort;
+    const shouldRemove = mode === "RemoveUnused" /* RemoveUnused */ || mode === "All" /* All */;
+    const topLevelImportGroupDecls = groupByNewlineContiguous(sourceFile, sourceFile.statements.filter(isImportDeclaration));
+    const comparer = getOrganizeImportsComparerWithDetection(preferences, shouldSort ? () => detectSortingWorker(topLevelImportGroupDecls, preferences) === 2 /* CaseInsensitive */ : void 0);
+    const processImportsOfSameModuleSpecifier = (importGroup) => {
+      if (shouldRemove)
+        importGroup = removeUnusedImports(importGroup, sourceFile, program);
+      if (shouldCombine)
+        importGroup = coalesceImportsWorker(importGroup, comparer, sourceFile);
+      if (shouldSort)
+        importGroup = stableSort(importGroup, (s1, s2) => compareImportsOrRequireStatements(s1, s2, comparer));
+      return importGroup;
+    };
+    topLevelImportGroupDecls.forEach((importGroupDecl) => organizeImportsWorker(importGroupDecl, processImportsOfSameModuleSpecifier));
+    if (mode !== "RemoveUnused" /* RemoveUnused */) {
+      getTopLevelExportGroups(sourceFile).forEach((exportGroupDecl) => organizeImportsWorker(exportGroupDecl, (group2) => coalesceExportsWorker(group2, comparer)));
     }
-    if (fragment === "") {
-      fragment = "." + directorySeparator;
+    for (const ambientModule of sourceFile.statements.filter(isAmbientModule)) {
+      if (!ambientModule.body)
+        continue;
+      const ambientModuleImportGroupDecls = groupByNewlineContiguous(sourceFile, ambientModule.body.statements.filter(isImportDeclaration));
+      ambientModuleImportGroupDecls.forEach((importGroupDecl) => organizeImportsWorker(importGroupDecl, processImportsOfSameModuleSpecifier));
+      if (mode !== "RemoveUnused" /* RemoveUnused */) {
+        const ambientModuleExportDecls = ambientModule.body.statements.filter(isExportDeclaration);
+        organizeImportsWorker(ambientModuleExportDecls, (group2) => coalesceExportsWorker(group2, comparer));
+      }
     }
-    fragment = ensureTrailingDirectorySeparator(fragment);
-    const absolutePath = resolvePath(scriptDirectory, fragment);
-    const baseDirectory = hasTrailingDirectorySeparator(absolutePath) ? absolutePath : getDirectoryPath(absolutePath);
-    if (!moduleSpecifierIsRelative) {
-      const packageJsonPath = findPackageJson(baseDirectory, host);
-      if (packageJsonPath) {
-        const packageJson = readJson(packageJsonPath, host);
-        const typesVersions = packageJson.typesVersions;
-        if (typeof typesVersions === "object") {
-          const versionPaths = (_a = getPackageJsonTypesVersionsPaths(typesVersions)) == null ? void 0 : _a.paths;
-          if (versionPaths) {
-            const packageDirectory = getDirectoryPath(packageJsonPath);
-            const pathInPackage = absolutePath.slice(ensureTrailingDirectorySeparator(packageDirectory).length);
-            if (addCompletionEntriesFromPaths(result, pathInPackage, packageDirectory, extensionOptions, host, versionPaths)) {
-              return result;
-            }
-          }
-        }
+    return changeTracker.getChanges();
+    function organizeImportsWorker(oldImportDecls, coalesce) {
+      if (length(oldImportDecls) === 0) {
+        return;
+      }
+      setEmitFlags(oldImportDecls[0], 1024 /* NoLeadingComments */);
+      const oldImportGroups = shouldCombine ? group(oldImportDecls, (importDecl) => getExternalModuleName2(importDecl.moduleSpecifier)) : [oldImportDecls];
+      const sortedImportGroups = shouldSort ? stableSort(oldImportGroups, (group1, group2) => compareModuleSpecifiersWorker(group1[0].moduleSpecifier, group2[0].moduleSpecifier, comparer)) : oldImportGroups;
+      const newImportDecls = flatMap(sortedImportGroups, (importGroup) => getExternalModuleName2(importGroup[0].moduleSpecifier) || importGroup[0].moduleSpecifier === void 0 ? coalesce(importGroup) : importGroup);
+      if (newImportDecls.length === 0) {
+        changeTracker.deleteNodes(
+          sourceFile,
+          oldImportDecls,
+          {
+            leadingTriviaOption: ts_textChanges_exports.LeadingTriviaOption.Exclude,
+            trailingTriviaOption: ts_textChanges_exports.TrailingTriviaOption.Include
+          },
+          /*hasTrailingComment*/
+          true
+        );
+      } else {
+        const replaceOptions = {
+          leadingTriviaOption: ts_textChanges_exports.LeadingTriviaOption.Exclude,
+          // Leave header comment in place
+          trailingTriviaOption: ts_textChanges_exports.TrailingTriviaOption.Include,
+          suffix: getNewLineOrDefaultFromHost(host, formatContext.options)
+        };
+        changeTracker.replaceNodeWithNodes(sourceFile, oldImportDecls[0], newImportDecls, replaceOptions);
+        const hasTrailingComment = changeTracker.nodeHasTrailingComment(sourceFile, oldImportDecls[0], replaceOptions);
+        changeTracker.deleteNodes(sourceFile, oldImportDecls.slice(1), {
+          trailingTriviaOption: ts_textChanges_exports.TrailingTriviaOption.Include
+        }, hasTrailingComment);
       }
     }
-    const ignoreCase = !(host.useCaseSensitiveFileNames && host.useCaseSensitiveFileNames());
-    if (!tryDirectoryExists(host, baseDirectory))
-      return result;
-    const files = tryReadDirectory(
-      host,
-      baseDirectory,
-      extensionOptions.extensionsToSearch,
-      /*exclude*/
-      void 0,
-      /*include*/
-      ["./*"]
+  }
+  function groupByNewlineContiguous(sourceFile, decls) {
+    const scanner2 = createScanner(
+      sourceFile.languageVersion,
+      /*skipTrivia*/
+      false,
+      sourceFile.languageVariant
     );
-    if (files) {
-      for (let filePath of files) {
-        filePath = normalizePath(filePath);
-        if (exclude && comparePaths(filePath, exclude, scriptDirectory, ignoreCase) === 0 /* EqualTo */) {
-          continue;
-        }
-        const { name, extension } = getFilenameWithExtensionOption(getBaseFileName(filePath), host.getCompilationSettings(), extensionOptions);
-        result.add(nameAndKind(name, "script" /* scriptElement */, extension));
+    const group2 = [];
+    let groupIndex = 0;
+    for (const decl of decls) {
+      if (group2[groupIndex] && isNewGroup(sourceFile, decl, scanner2)) {
+        groupIndex++;
       }
-    }
-    const directories = tryGetDirectories(host, baseDirectory);
-    if (directories) {
-      for (const directory of directories) {
-        const directoryName = getBaseFileName(normalizePath(directory));
-        if (directoryName !== "@types") {
-          result.add(directoryResult(directoryName));
-        }
+      if (!group2[groupIndex]) {
+        group2[groupIndex] = [];
       }
+      group2[groupIndex].push(decl);
     }
-    return result;
+    return group2;
   }
-  function getFilenameWithExtensionOption(name, compilerOptions, extensionOptions) {
-    const nonJsResult = ts_moduleSpecifiers_exports.tryGetRealFileNameForNonJsDeclarationFileName(name);
-    if (nonJsResult) {
-      return { name: nonJsResult, extension: tryGetExtensionFromPath2(nonJsResult) };
-    }
-    if (extensionOptions.referenceKind === 0 /* Filename */) {
-      return { name, extension: tryGetExtensionFromPath2(name) };
-    }
-    const endingPreference = getModuleSpecifierEndingPreference(extensionOptions.endingPreference, extensionOptions.resolutionMode, compilerOptions, extensionOptions.importingSourceFile);
-    if (endingPreference === 3 /* TsExtension */) {
-      if (fileExtensionIsOneOf(name, supportedTSImplementationExtensions)) {
-        return { name, extension: tryGetExtensionFromPath2(name) };
+  function isNewGroup(sourceFile, decl, scanner2) {
+    const startPos = decl.getFullStart();
+    const endPos = decl.getStart();
+    scanner2.setText(sourceFile.text, startPos, endPos - startPos);
+    let numberOfNewLines = 0;
+    while (scanner2.getTokenStart() < endPos) {
+      const tokenKind = scanner2.scan();
+      if (tokenKind === 4 /* NewLineTrivia */) {
+        numberOfNewLines++;
+        if (numberOfNewLines >= 2) {
+          return true;
+        }
       }
-      const outputExtension2 = ts_moduleSpecifiers_exports.tryGetJSExtensionForFile(name, compilerOptions);
-      return outputExtension2 ? { name: changeExtension(name, outputExtension2), extension: outputExtension2 } : { name, extension: tryGetExtensionFromPath2(name) };
-    }
-    if ((endingPreference === 0 /* Minimal */ || endingPreference === 1 /* Index */) && fileExtensionIsOneOf(name, [".js" /* Js */, ".jsx" /* Jsx */, ".ts" /* Ts */, ".tsx" /* Tsx */, ".d.ts" /* Dts */])) {
-      return { name: removeFileExtension(name), extension: tryGetExtensionFromPath2(name) };
     }
-    const outputExtension = ts_moduleSpecifiers_exports.tryGetJSExtensionForFile(name, compilerOptions);
-    return outputExtension ? { name: changeExtension(name, outputExtension), extension: outputExtension } : { name, extension: tryGetExtensionFromPath2(name) };
-  }
-  function addCompletionEntriesFromPaths(result, fragment, baseDirectory, extensionOptions, host, paths) {
-    const getPatternsForKey = (key) => paths[key];
-    const comparePaths2 = (a, b) => {
-      const patternA = tryParsePattern(a);
-      const patternB = tryParsePattern(b);
-      const lengthA = typeof patternA === "object" ? patternA.prefix.length : a.length;
-      const lengthB = typeof patternB === "object" ? patternB.prefix.length : b.length;
-      return compareValues(lengthB, lengthA);
-    };
-    return addCompletionEntriesFromPathsOrExports(result, fragment, baseDirectory, extensionOptions, host, getOwnKeys(paths), getPatternsForKey, comparePaths2);
+    return false;
   }
-  function addCompletionEntriesFromPathsOrExports(result, fragment, baseDirectory, extensionOptions, host, keys, getPatternsForKey, comparePaths2) {
-    let pathResults = [];
-    let matchedPath;
-    for (const key of keys) {
-      if (key === ".")
+  function removeUnusedImports(oldImports, sourceFile, program) {
+    const typeChecker = program.getTypeChecker();
+    const compilerOptions = program.getCompilerOptions();
+    const jsxNamespace = typeChecker.getJsxNamespace(sourceFile);
+    const jsxFragmentFactory = typeChecker.getJsxFragmentFactory(sourceFile);
+    const jsxElementsPresent = !!(sourceFile.transformFlags & 2 /* ContainsJsx */);
+    const usedImports = [];
+    for (const importDecl of oldImports) {
+      const { importClause, moduleSpecifier } = importDecl;
+      if (!importClause) {
+        usedImports.push(importDecl);
         continue;
-      const keyWithoutLeadingDotSlash = key.replace(/^\.\//, "");
-      const patterns = getPatternsForKey(key);
-      if (patterns) {
-        const pathPattern = tryParsePattern(keyWithoutLeadingDotSlash);
-        if (!pathPattern)
-          continue;
-        const isMatch = typeof pathPattern === "object" && isPatternMatch(pathPattern, fragment);
-        const isLongestMatch = isMatch && (matchedPath === void 0 || comparePaths2(key, matchedPath) === -1 /* LessThan */);
-        if (isLongestMatch) {
-          matchedPath = key;
-          pathResults = pathResults.filter((r) => !r.matchedPattern);
+      }
+      let { name, namedBindings } = importClause;
+      if (name && !isDeclarationUsed(name)) {
+        name = void 0;
+      }
+      if (namedBindings) {
+        if (isNamespaceImport(namedBindings)) {
+          if (!isDeclarationUsed(namedBindings.name)) {
+            namedBindings = void 0;
+          }
+        } else {
+          const newElements = namedBindings.elements.filter((e) => isDeclarationUsed(e.name));
+          if (newElements.length < namedBindings.elements.length) {
+            namedBindings = newElements.length ? factory.updateNamedImports(namedBindings, newElements) : void 0;
+          }
         }
-        if (typeof pathPattern === "string" || matchedPath === void 0 || comparePaths2(key, matchedPath) !== 1 /* GreaterThan */) {
-          pathResults.push({
-            matchedPattern: isMatch,
-            results: getCompletionsForPathMapping(keyWithoutLeadingDotSlash, patterns, fragment, baseDirectory, extensionOptions, host).map(({ name, kind, extension }) => nameAndKind(name, kind, extension))
-          });
+      }
+      if (name || namedBindings) {
+        usedImports.push(updateImportDeclarationAndClause(importDecl, name, namedBindings));
+      } else if (hasModuleDeclarationMatchingSpecifier(sourceFile, moduleSpecifier)) {
+        if (sourceFile.isDeclarationFile) {
+          usedImports.push(factory.createImportDeclaration(
+            importDecl.modifiers,
+            /*importClause*/
+            void 0,
+            moduleSpecifier,
+            /*attributes*/
+            void 0
+          ));
+        } else {
+          usedImports.push(importDecl);
         }
       }
     }
-    pathResults.forEach((pathResult) => pathResult.results.forEach((r) => result.add(r)));
-    return matchedPath !== void 0;
-  }
-  function getCompletionEntriesForNonRelativeModules(fragment, scriptPath, mode, compilerOptions, host, extensionOptions, typeChecker) {
-    const { baseUrl, paths } = compilerOptions;
-    const result = createNameAndKindSet();
-    const moduleResolution = getEmitModuleResolutionKind(compilerOptions);
-    if (baseUrl) {
-      const absolute = normalizePath(combinePaths(host.getCurrentDirectory(), baseUrl));
-      getCompletionEntriesForDirectoryFragment(
-        fragment,
-        absolute,
-        extensionOptions,
-        host,
-        /*moduleSpecifierIsRelative*/
-        false,
-        /*exclude*/
-        void 0,
-        result
-      );
+    return usedImports;
+    function isDeclarationUsed(identifier) {
+      return jsxElementsPresent && (identifier.text === jsxNamespace || jsxFragmentFactory && identifier.text === jsxFragmentFactory) && jsxModeNeedsExplicitImport(compilerOptions.jsx) || ts_FindAllReferences_exports.Core.isSymbolReferencedInFile(identifier, typeChecker, sourceFile);
     }
-    if (paths) {
-      const absolute = getPathsBasePath(compilerOptions, host);
-      addCompletionEntriesFromPaths(result, fragment, absolute, extensionOptions, host, paths);
+  }
+  function hasModuleDeclarationMatchingSpecifier(sourceFile, moduleSpecifier) {
+    const moduleSpecifierText = isStringLiteral(moduleSpecifier) && moduleSpecifier.text;
+    return isString(moduleSpecifierText) && some(sourceFile.moduleAugmentations, (moduleName) => isStringLiteral(moduleName) && moduleName.text === moduleSpecifierText);
+  }
+  function getExternalModuleName2(specifier) {
+    return specifier !== void 0 && isStringLiteralLike(specifier) ? specifier.text : void 0;
+  }
+  function coalesceImports(importGroup, ignoreCase, sourceFile) {
+    const comparer = getOrganizeImportsOrdinalStringComparer(ignoreCase);
+    return coalesceImportsWorker(importGroup, comparer, sourceFile);
+  }
+  function coalesceImportsWorker(importGroup, comparer, sourceFile) {
+    if (importGroup.length === 0) {
+      return importGroup;
     }
-    const fragmentDirectory = getFragmentDirectory(fragment);
-    for (const ambientName of getAmbientModuleCompletions(fragment, fragmentDirectory, typeChecker)) {
-      result.add(nameAndKind(
-        ambientName,
-        "external module name" /* externalModuleName */,
-        /*extension*/
-        void 0
-      ));
+    const { importWithoutClause, typeOnlyImports, regularImports } = getCategorizedImports(importGroup);
+    const coalescedImports = [];
+    if (importWithoutClause) {
+      coalescedImports.push(importWithoutClause);
     }
-    getCompletionEntriesFromTypings(host, compilerOptions, scriptPath, fragmentDirectory, extensionOptions, result);
-    if (moduleResolutionUsesNodeModules(moduleResolution)) {
-      let foundGlobal = false;
-      if (fragmentDirectory === void 0) {
-        for (const moduleName of enumerateNodeModulesVisibleToScript(host, scriptPath)) {
-          const moduleResult = nameAndKind(
-            moduleName,
-            "external module name" /* externalModuleName */,
-            /*extension*/
-            void 0
-          );
-          if (!result.has(moduleResult.name)) {
-            foundGlobal = true;
-            result.add(moduleResult);
-          }
-        }
+    for (const group2 of [regularImports, typeOnlyImports]) {
+      const isTypeOnly = group2 === typeOnlyImports;
+      const { defaultImports, namespaceImports, namedImports } = group2;
+      if (!isTypeOnly && defaultImports.length === 1 && namespaceImports.length === 1 && namedImports.length === 0) {
+        const defaultImport = defaultImports[0];
+        coalescedImports.push(
+          updateImportDeclarationAndClause(defaultImport, defaultImport.importClause.name, namespaceImports[0].importClause.namedBindings)
+        );
+        continue;
       }
-      if (!foundGlobal) {
-        let ancestorLookup = (ancestor) => {
-          const nodeModules = combinePaths(ancestor, "node_modules");
-          if (tryDirectoryExists(host, nodeModules)) {
-            getCompletionEntriesForDirectoryFragment(
-              fragment,
-              nodeModules,
-              extensionOptions,
-              host,
-              /*moduleSpecifierIsRelative*/
+      const sortedNamespaceImports = stableSort(namespaceImports, (i1, i2) => comparer(i1.importClause.namedBindings.name.text, i2.importClause.namedBindings.name.text));
+      for (const namespaceImport of sortedNamespaceImports) {
+        coalescedImports.push(
+          updateImportDeclarationAndClause(
+            namespaceImport,
+            /*name*/
+            void 0,
+            namespaceImport.importClause.namedBindings
+          )
+        );
+      }
+      const firstDefaultImport = firstOrUndefined(defaultImports);
+      const firstNamedImport = firstOrUndefined(namedImports);
+      const importDecl = firstDefaultImport ?? firstNamedImport;
+      if (!importDecl) {
+        continue;
+      }
+      let newDefaultImport;
+      const newImportSpecifiers = [];
+      if (defaultImports.length === 1) {
+        newDefaultImport = defaultImports[0].importClause.name;
+      } else {
+        for (const defaultImport of defaultImports) {
+          newImportSpecifiers.push(
+            factory.createImportSpecifier(
+              /*isTypeOnly*/
               false,
-              /*exclude*/
-              void 0,
-              result
-            );
-          }
-        };
-        if (fragmentDirectory && getResolvePackageJsonExports(compilerOptions)) {
-          const nodeModulesDirectoryLookup = ancestorLookup;
-          ancestorLookup = (ancestor) => {
-            const components = getPathComponents(fragment);
-            components.shift();
-            let packagePath = components.shift();
-            if (!packagePath) {
-              return nodeModulesDirectoryLookup(ancestor);
-            }
-            if (startsWith(packagePath, "@")) {
-              const subName = components.shift();
-              if (!subName) {
-                return nodeModulesDirectoryLookup(ancestor);
-              }
-              packagePath = combinePaths(packagePath, subName);
-            }
-            const packageDirectory = combinePaths(ancestor, "node_modules", packagePath);
-            const packageFile = combinePaths(packageDirectory, "package.json");
-            if (tryFileExists(host, packageFile)) {
-              const packageJson = readJson(packageFile, host);
-              const exports = packageJson.exports;
-              if (exports) {
-                if (typeof exports !== "object" || exports === null) {
-                  return;
-                }
-                const keys = getOwnKeys(exports);
-                const fragmentSubpath = components.join("/") + (components.length && hasTrailingDirectorySeparator(fragment) ? "/" : "");
-                const conditions = mode === 99 /* ESNext */ ? ["node", "import", "types"] : ["node", "require", "types"];
-                addCompletionEntriesFromPathsOrExports(
-                  result,
-                  fragmentSubpath,
-                  packageDirectory,
-                  extensionOptions,
-                  host,
-                  keys,
-                  (key) => singleElementArray(getPatternFromFirstMatchingCondition(exports[key], conditions)),
-                  comparePatternKeys
-                );
-                return;
-              }
-            }
-            return nodeModulesDirectoryLookup(ancestor);
-          };
+              factory.createIdentifier("default"),
+              defaultImport.importClause.name
+            )
+          );
         }
-        forEachAncestorDirectory(scriptPath, ancestorLookup);
+      }
+      newImportSpecifiers.push(...getNewImportSpecifiers(namedImports));
+      const sortedImportSpecifiers = factory.createNodeArray(
+        sortSpecifiers(newImportSpecifiers, comparer),
+        firstNamedImport == null ? void 0 : firstNamedImport.importClause.namedBindings.elements.hasTrailingComma
+      );
+      const newNamedImports = sortedImportSpecifiers.length === 0 ? newDefaultImport ? void 0 : factory.createNamedImports(emptyArray) : firstNamedImport ? factory.updateNamedImports(firstNamedImport.importClause.namedBindings, sortedImportSpecifiers) : factory.createNamedImports(sortedImportSpecifiers);
+      if (sourceFile && newNamedImports && (firstNamedImport == null ? void 0 : firstNamedImport.importClause.namedBindings) && !rangeIsOnSingleLine(firstNamedImport.importClause.namedBindings, sourceFile)) {
+        setEmitFlags(newNamedImports, 2 /* MultiLine */);
+      }
+      if (isTypeOnly && newDefaultImport && newNamedImports) {
+        coalescedImports.push(
+          updateImportDeclarationAndClause(
+            importDecl,
+            newDefaultImport,
+            /*namedBindings*/
+            void 0
+          )
+        );
+        coalescedImports.push(
+          updateImportDeclarationAndClause(
+            firstNamedImport ?? importDecl,
+            /*name*/
+            void 0,
+            newNamedImports
+          )
+        );
+      } else {
+        coalescedImports.push(
+          updateImportDeclarationAndClause(importDecl, newDefaultImport, newNamedImports)
+        );
       }
     }
-    return arrayFrom(result.values());
+    return coalescedImports;
   }
-  function getPatternFromFirstMatchingCondition(target, conditions) {
-    if (typeof target === "string") {
-      return target;
-    }
-    if (target && typeof target === "object" && !isArray(target)) {
-      for (const condition in target) {
-        if (condition === "default" || conditions.indexOf(condition) > -1 || isApplicableVersionedTypesKey(conditions, condition)) {
-          const pattern = target[condition];
-          return getPatternFromFirstMatchingCondition(pattern, conditions);
+  function getCategorizedImports(importGroup) {
+    let importWithoutClause;
+    const typeOnlyImports = { defaultImports: [], namespaceImports: [], namedImports: [] };
+    const regularImports = { defaultImports: [], namespaceImports: [], namedImports: [] };
+    for (const importDeclaration of importGroup) {
+      if (importDeclaration.importClause === void 0) {
+        importWithoutClause = importWithoutClause || importDeclaration;
+        continue;
+      }
+      const group2 = importDeclaration.importClause.isTypeOnly ? typeOnlyImports : regularImports;
+      const { name, namedBindings } = importDeclaration.importClause;
+      if (name) {
+        group2.defaultImports.push(importDeclaration);
+      }
+      if (namedBindings) {
+        if (isNamespaceImport(namedBindings)) {
+          group2.namespaceImports.push(importDeclaration);
+        } else {
+          group2.namedImports.push(importDeclaration);
         }
       }
     }
+    return {
+      importWithoutClause,
+      typeOnlyImports,
+      regularImports
+    };
   }
-  function getFragmentDirectory(fragment) {
-    return containsSlash(fragment) ? hasTrailingDirectorySeparator(fragment) ? fragment : getDirectoryPath(fragment) : void 0;
+  function coalesceExports(exportGroup, ignoreCase) {
+    const comparer = getOrganizeImportsOrdinalStringComparer(ignoreCase);
+    return coalesceExportsWorker(exportGroup, comparer);
   }
-  function getCompletionsForPathMapping(path, patterns, fragment, packageDirectory, extensionOptions, host) {
-    if (!endsWith(path, "*")) {
-      return !stringContains(path, "*") ? justPathMappingName(path, "script" /* scriptElement */) : emptyArray;
-    }
-    const pathPrefix = path.slice(0, path.length - 1);
-    const remainingFragment = tryRemovePrefix(fragment, pathPrefix);
-    if (remainingFragment === void 0) {
-      const starIsFullPathComponent = path[path.length - 2] === "/";
-      return starIsFullPathComponent ? justPathMappingName(pathPrefix, "directory" /* directory */) : flatMap(patterns, (pattern) => {
-        var _a;
-        return (_a = getModulesForPathsPattern("", packageDirectory, pattern, extensionOptions, host)) == null ? void 0 : _a.map(({ name, ...rest }) => ({ name: pathPrefix + name, ...rest }));
-      });
-    }
-    return flatMap(patterns, (pattern) => getModulesForPathsPattern(remainingFragment, packageDirectory, pattern, extensionOptions, host));
-    function justPathMappingName(name, kind) {
-      return startsWith(name, fragment) ? [{ name: removeTrailingDirectorySeparator(name), kind, extension: void 0 }] : emptyArray;
+  function coalesceExportsWorker(exportGroup, comparer) {
+    if (exportGroup.length === 0) {
+      return exportGroup;
     }
-  }
-  function getModulesForPathsPattern(fragment, packageDirectory, pattern, extensionOptions, host) {
-    if (!host.readDirectory) {
-      return void 0;
+    const { exportWithoutClause, namedExports, typeOnlyExports } = getCategorizedExports(exportGroup);
+    const coalescedExports = [];
+    if (exportWithoutClause) {
+      coalescedExports.push(exportWithoutClause);
     }
-    const parsed = tryParsePattern(pattern);
-    if (parsed === void 0 || isString(parsed)) {
-      return void 0;
+    for (const exportGroup2 of [namedExports, typeOnlyExports]) {
+      if (exportGroup2.length === 0) {
+        continue;
+      }
+      const newExportSpecifiers = [];
+      newExportSpecifiers.push(...flatMap(exportGroup2, (i) => i.exportClause && isNamedExports(i.exportClause) ? i.exportClause.elements : emptyArray));
+      const sortedExportSpecifiers = sortSpecifiers(newExportSpecifiers, comparer);
+      const exportDecl = exportGroup2[0];
+      coalescedExports.push(
+        factory.updateExportDeclaration(
+          exportDecl,
+          exportDecl.modifiers,
+          exportDecl.isTypeOnly,
+          exportDecl.exportClause && (isNamedExports(exportDecl.exportClause) ? factory.updateNamedExports(exportDecl.exportClause, sortedExportSpecifiers) : factory.updateNamespaceExport(exportDecl.exportClause, exportDecl.exportClause.name)),
+          exportDecl.moduleSpecifier,
+          exportDecl.attributes
+        )
+      );
     }
-    const normalizedPrefix = resolvePath(parsed.prefix);
-    const normalizedPrefixDirectory = hasTrailingDirectorySeparator(parsed.prefix) ? normalizedPrefix : getDirectoryPath(normalizedPrefix);
-    const normalizedPrefixBase = hasTrailingDirectorySeparator(parsed.prefix) ? "" : getBaseFileName(normalizedPrefix);
-    const fragmentHasPath = containsSlash(fragment);
-    const fragmentDirectory = fragmentHasPath ? hasTrailingDirectorySeparator(fragment) ? fragment : getDirectoryPath(fragment) : void 0;
-    const expandedPrefixDirectory = fragmentHasPath ? combinePaths(normalizedPrefixDirectory, normalizedPrefixBase + fragmentDirectory) : normalizedPrefixDirectory;
-    const normalizedSuffix = normalizePath(parsed.suffix);
-    const baseDirectory = normalizePath(combinePaths(packageDirectory, expandedPrefixDirectory));
-    const completePrefix = fragmentHasPath ? baseDirectory : ensureTrailingDirectorySeparator(baseDirectory) + normalizedPrefixBase;
-    const includeGlob = normalizedSuffix ? "**/*" + normalizedSuffix : "./*";
-    const matches = mapDefined(tryReadDirectory(
-      host,
-      baseDirectory,
-      extensionOptions.extensionsToSearch,
-      /*exclude*/
-      void 0,
-      [includeGlob]
-    ), (match) => {
-      const trimmedWithPattern = trimPrefixAndSuffix(match);
-      if (trimmedWithPattern) {
-        if (containsSlash(trimmedWithPattern)) {
-          return directoryResult(getPathComponents(removeLeadingDirectorySeparator(trimmedWithPattern))[1]);
+    return coalescedExports;
+    function getCategorizedExports(exportGroup2) {
+      let exportWithoutClause2;
+      const namedExports2 = [];
+      const typeOnlyExports2 = [];
+      for (const exportDeclaration of exportGroup2) {
+        if (exportDeclaration.exportClause === void 0) {
+          exportWithoutClause2 = exportWithoutClause2 || exportDeclaration;
+        } else if (exportDeclaration.isTypeOnly) {
+          typeOnlyExports2.push(exportDeclaration);
+        } else {
+          namedExports2.push(exportDeclaration);
         }
-        const { name, extension } = getFilenameWithExtensionOption(trimmedWithPattern, host.getCompilationSettings(), extensionOptions);
-        return nameAndKind(name, "script" /* scriptElement */, extension);
       }
-    });
-    const directories = normalizedSuffix ? emptyArray : mapDefined(tryGetDirectories(host, baseDirectory), (dir) => dir === "node_modules" ? void 0 : directoryResult(dir));
-    return [...matches, ...directories];
-    function trimPrefixAndSuffix(path) {
-      const inner = withoutStartAndEnd(normalizePath(path), completePrefix, normalizedSuffix);
-      return inner === void 0 ? void 0 : removeLeadingDirectorySeparator(inner);
+      return {
+        exportWithoutClause: exportWithoutClause2,
+        namedExports: namedExports2,
+        typeOnlyExports: typeOnlyExports2
+      };
     }
   }
-  function withoutStartAndEnd(s, start, end) {
-    return startsWith(s, start) && endsWith(s, end) ? s.slice(start.length, s.length - end.length) : void 0;
+  function updateImportDeclarationAndClause(importDeclaration, name, namedBindings) {
+    return factory.updateImportDeclaration(
+      importDeclaration,
+      importDeclaration.modifiers,
+      factory.updateImportClause(importDeclaration.importClause, importDeclaration.importClause.isTypeOnly, name, namedBindings),
+      // TODO: GH#18217
+      importDeclaration.moduleSpecifier,
+      importDeclaration.attributes
+    );
   }
-  function removeLeadingDirectorySeparator(path) {
-    return path[0] === directorySeparator ? path.slice(1) : path;
+  function sortSpecifiers(specifiers, comparer) {
+    return stableSort(specifiers, (s1, s2) => compareImportOrExportSpecifiers(s1, s2, comparer));
   }
-  function getAmbientModuleCompletions(fragment, fragmentDirectory, checker) {
-    const ambientModules = checker.getAmbientModules().map((sym) => stripQuotes(sym.name));
-    const nonRelativeModuleNames = ambientModules.filter((moduleName) => startsWith(moduleName, fragment) && moduleName.indexOf("*") < 0);
-    if (fragmentDirectory !== void 0) {
-      const moduleNameWithSeparator = ensureTrailingDirectorySeparator(fragmentDirectory);
-      return nonRelativeModuleNames.map((nonRelativeModuleName) => removePrefix(nonRelativeModuleName, moduleNameWithSeparator));
-    }
-    return nonRelativeModuleNames;
+  function compareImportOrExportSpecifiers(s1, s2, comparer) {
+    return compareBooleans(s1.isTypeOnly, s2.isTypeOnly) || comparer(s1.name.text, s2.name.text);
   }
-  function getTripleSlashReferenceCompletion(sourceFile, position, compilerOptions, host) {
-    const token = getTokenAtPosition(sourceFile, position);
-    const commentRanges = getLeadingCommentRanges(sourceFile.text, token.pos);
-    const range = commentRanges && find(commentRanges, (commentRange) => position >= commentRange.pos && position <= commentRange.end);
-    if (!range) {
-      return void 0;
-    }
-    const text = sourceFile.text.slice(range.pos, position);
-    const match = tripleSlashDirectiveFragmentRegex.exec(text);
-    if (!match) {
-      return void 0;
-    }
-    const [, prefix, kind, toComplete] = match;
-    const scriptPath = getDirectoryPath(sourceFile.path);
-    const names = kind === "path" ? getCompletionEntriesForDirectoryFragment(
-      toComplete,
-      scriptPath,
-      getExtensionOptions(compilerOptions, 0 /* Filename */, sourceFile),
-      host,
-      /*moduleSpecifierIsRelative*/
-      true,
-      sourceFile.path
-    ) : kind === "types" ? getCompletionEntriesFromTypings(host, compilerOptions, scriptPath, getFragmentDirectory(toComplete), getExtensionOptions(compilerOptions, 1 /* ModuleSpecifier */, sourceFile)) : Debug.fail();
-    return addReplacementSpans(toComplete, range.pos + prefix.length, arrayFrom(names.values()));
+  function compareModuleSpecifiers2(m1, m2, ignoreCase) {
+    const comparer = getOrganizeImportsOrdinalStringComparer(!!ignoreCase);
+    return compareModuleSpecifiersWorker(m1, m2, comparer);
   }
-  function getCompletionEntriesFromTypings(host, options, scriptPath, fragmentDirectory, extensionOptions, result = createNameAndKindSet()) {
-    const seen = /* @__PURE__ */ new Map();
-    const typeRoots = tryAndIgnoreErrors(() => getEffectiveTypeRoots(options, host)) || emptyArray;
-    for (const root of typeRoots) {
-      getCompletionEntriesFromDirectories(root);
-    }
-    for (const packageJson of findPackageJsons(scriptPath, host)) {
-      const typesDir = combinePaths(getDirectoryPath(packageJson), "node_modules/@types");
-      getCompletionEntriesFromDirectories(typesDir);
+  function compareModuleSpecifiersWorker(m1, m2, comparer) {
+    const name1 = m1 === void 0 ? void 0 : getExternalModuleName2(m1);
+    const name2 = m2 === void 0 ? void 0 : getExternalModuleName2(m2);
+    return compareBooleans(name1 === void 0, name2 === void 0) || compareBooleans(isExternalModuleNameRelative(name1), isExternalModuleNameRelative(name2)) || comparer(name1, name2);
+  }
+  function getModuleSpecifierExpression(declaration) {
+    var _a;
+    switch (declaration.kind) {
+      case 271 /* ImportEqualsDeclaration */:
+        return (_a = tryCast(declaration.moduleReference, isExternalModuleReference)) == null ? void 0 : _a.expression;
+      case 272 /* ImportDeclaration */:
+        return declaration.moduleSpecifier;
+      case 243 /* VariableStatement */:
+        return declaration.declarationList.declarations[0].initializer.arguments[0];
     }
-    return result;
-    function getCompletionEntriesFromDirectories(directory) {
-      if (!tryDirectoryExists(host, directory))
-        return;
-      for (const typeDirectoryName of tryGetDirectories(host, directory)) {
-        const packageName = unmangleScopedPackageName(typeDirectoryName);
-        if (options.types && !contains(options.types, packageName))
-          continue;
-        if (fragmentDirectory === void 0) {
-          if (!seen.has(packageName)) {
-            result.add(nameAndKind(
-              packageName,
-              "external module name" /* externalModuleName */,
-              /*extension*/
-              void 0
-            ));
-            seen.set(packageName, true);
-          }
-        } else {
-          const baseDirectory = combinePaths(directory, typeDirectoryName);
-          const remainingFragment = tryRemoveDirectoryPrefix(fragmentDirectory, packageName, hostGetCanonicalFileName(host));
-          if (remainingFragment !== void 0) {
-            getCompletionEntriesForDirectoryFragment(
-              remainingFragment,
-              baseDirectory,
-              extensionOptions,
-              host,
-              /*moduleSpecifierIsRelative*/
-              false,
-              /*exclude*/
-              void 0,
-              result
-            );
-          }
+  }
+  function detectSorting(sourceFile, preferences) {
+    return detectSortingWorker(
+      groupByNewlineContiguous(sourceFile, sourceFile.statements.filter(isImportDeclaration)),
+      preferences
+    );
+  }
+  function detectSortingWorker(importGroups, preferences) {
+    const collateCaseSensitive = getOrganizeImportsComparer(
+      preferences,
+      /*ignoreCase*/
+      false
+    );
+    const collateCaseInsensitive = getOrganizeImportsComparer(
+      preferences,
+      /*ignoreCase*/
+      true
+    );
+    let sortState = 3 /* Both */;
+    let seenUnsortedGroup = false;
+    for (const importGroup of importGroups) {
+      if (importGroup.length > 1) {
+        const moduleSpecifierSort = detectSortCaseSensitivity(
+          importGroup,
+          (i) => {
+            var _a;
+            return ((_a = tryCast(i.moduleSpecifier, isStringLiteral)) == null ? void 0 : _a.text) ?? "";
+          },
+          collateCaseSensitive,
+          collateCaseInsensitive
+        );
+        if (moduleSpecifierSort) {
+          sortState &= moduleSpecifierSort;
+          seenUnsortedGroup = true;
+        }
+        if (!sortState) {
+          return sortState;
         }
       }
-    }
-  }
-  function enumerateNodeModulesVisibleToScript(host, scriptPath) {
-    if (!host.readFile || !host.fileExists)
-      return emptyArray;
-    const result = [];
-    for (const packageJson of findPackageJsons(scriptPath, host)) {
-      const contents = readJson(packageJson, host);
-      for (const key of nodeModulesDependencyKeys) {
-        const dependencies = contents[key];
-        if (!dependencies)
-          continue;
-        for (const dep in dependencies) {
-          if (hasProperty(dependencies, dep) && !startsWith(dep, "@types/")) {
-            result.push(dep);
-          }
+      const declarationWithNamedImports = find(
+        importGroup,
+        (i) => {
+          var _a, _b;
+          return ((_b = tryCast((_a = i.importClause) == null ? void 0 : _a.namedBindings, isNamedImports)) == null ? void 0 : _b.elements.length) > 1;
+        }
+      );
+      if (declarationWithNamedImports) {
+        const namedImportSort = detectImportSpecifierSorting(declarationWithNamedImports.importClause.namedBindings.elements, preferences);
+        if (namedImportSort) {
+          sortState &= namedImportSort;
+          seenUnsortedGroup = true;
+        }
+        if (!sortState) {
+          return sortState;
         }
       }
+      if (sortState !== 3 /* Both */) {
+        return sortState;
+      }
     }
-    return result;
+    return seenUnsortedGroup ? 0 /* None */ : sortState;
   }
-  function getDirectoryFragmentTextSpan(text, textStart) {
-    const index = Math.max(text.lastIndexOf(directorySeparator), text.lastIndexOf(altDirectorySeparator));
-    const offset = index !== -1 ? index + 1 : 0;
-    const length2 = text.length - offset;
-    return length2 === 0 || isIdentifierText(text.substr(offset, length2), 99 /* ESNext */) ? void 0 : createTextSpan(textStart + offset, length2);
+  function detectImportDeclarationSorting(imports, preferences) {
+    const collateCaseSensitive = getOrganizeImportsComparer(
+      preferences,
+      /*ignoreCase*/
+      false
+    );
+    const collateCaseInsensitive = getOrganizeImportsComparer(
+      preferences,
+      /*ignoreCase*/
+      true
+    );
+    return detectSortCaseSensitivity(
+      imports,
+      (s) => getExternalModuleName2(getModuleSpecifierExpression(s)) || "",
+      collateCaseSensitive,
+      collateCaseInsensitive
+    );
   }
-  function isPathRelativeToScript(path) {
-    if (path && path.length >= 2 && path.charCodeAt(0) === 46 /* dot */) {
-      const slashIndex = path.length >= 3 && path.charCodeAt(1) === 46 /* dot */ ? 2 : 1;
-      const slashCharCode = path.charCodeAt(slashIndex);
-      return slashCharCode === 47 /* slash */ || slashCharCode === 92 /* backslash */;
-    }
-    return false;
+  function getImportDeclarationInsertionIndex(sortedImports, newImport, comparer) {
+    const index = binarySearch(sortedImports, newImport, identity, (a, b) => compareImportsOrRequireStatements(a, b, comparer));
+    return index < 0 ? ~index : index;
   }
-  function containsSlash(fragment) {
-    return stringContains(fragment, directorySeparator);
+  function getImportSpecifierInsertionIndex(sortedImports, newImport, comparer) {
+    const index = binarySearch(sortedImports, newImport, identity, (s1, s2) => compareImportOrExportSpecifiers(s1, s2, comparer));
+    return index < 0 ? ~index : index;
   }
-  function isRequireCallArgument(node) {
-    return isCallExpression(node.parent) && firstOrUndefined(node.parent.arguments) === node && isIdentifier(node.parent.expression) && node.parent.expression.escapedText === "require";
+  function compareImportsOrRequireStatements(s1, s2, comparer) {
+    return compareModuleSpecifiersWorker(getModuleSpecifierExpression(s1), getModuleSpecifierExpression(s2), comparer) || compareImportKind(s1, s2);
   }
-  var kindPrecedence, tripleSlashDirectiveFragmentRegex, nodeModulesDependencyKeys;
-  var init_stringCompletions = __esm({
-    "src/services/stringCompletions.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_Completions();
-      kindPrecedence = {
-        ["directory" /* directory */]: 0,
-        ["script" /* scriptElement */]: 1,
-        ["external module name" /* externalModuleName */]: 2
-      };
-      tripleSlashDirectiveFragmentRegex = /^(\/\/\/\s* getStringLiteralCompletionDetails,
-    getStringLiteralCompletions: () => getStringLiteralCompletions
-  });
-  var init_ts_Completions_StringCompletions = __esm({
-    "src/services/_namespaces/ts.Completions.StringCompletions.ts"() {
-      "use strict";
-      init_stringCompletions();
-    }
-  });
-
-  // src/services/_namespaces/ts.Completions.ts
-  var ts_Completions_exports = {};
-  __export(ts_Completions_exports, {
-    CompletionKind: () => CompletionKind,
-    CompletionSource: () => CompletionSource,
-    SortText: () => SortText,
-    StringCompletions: () => ts_Completions_StringCompletions_exports,
-    SymbolOriginInfoKind: () => SymbolOriginInfoKind,
-    createCompletionDetails: () => createCompletionDetails,
-    createCompletionDetailsForSymbol: () => createCompletionDetailsForSymbol,
-    getCompletionEntriesFromSymbols: () => getCompletionEntriesFromSymbols,
-    getCompletionEntryDetails: () => getCompletionEntryDetails,
-    getCompletionEntrySymbol: () => getCompletionEntrySymbol,
-    getCompletionsAtPosition: () => getCompletionsAtPosition,
-    getPropertiesForObjectExpression: () => getPropertiesForObjectExpression,
-    moduleSpecifierResolutionCacheAttemptLimit: () => moduleSpecifierResolutionCacheAttemptLimit,
-    moduleSpecifierResolutionLimit: () => moduleSpecifierResolutionLimit
-  });
-  var init_ts_Completions = __esm({
-    "src/services/_namespaces/ts.Completions.ts"() {
-      "use strict";
-      init_completions();
-      init_ts_Completions_StringCompletions();
-    }
-  });
-
-  // src/services/importTracker.ts
-  function createImportTracker(sourceFiles, sourceFilesSet, checker, cancellationToken) {
-    const allDirectImports = getDirectImportsMap(sourceFiles, checker, cancellationToken);
-    return (exportSymbol, exportInfo, isForRename) => {
-      const { directImports, indirectUsers } = getImportersForExport(sourceFiles, sourceFilesSet, allDirectImports, exportInfo, checker, cancellationToken);
-      return { indirectUsers, ...getSearchesFromDirectImports(directImports, exportSymbol, exportInfo.exportKind, checker, isForRename) };
-    };
+  function compareImportKind(s1, s2) {
+    return compareValues(getImportKindOrder(s1), getImportKindOrder(s2));
   }
-  function getImportersForExport(sourceFiles, sourceFilesSet, allDirectImports, { exportingModuleSymbol, exportKind }, checker, cancellationToken) {
-    const markSeenDirectImport = nodeSeenTracker();
-    const markSeenIndirectUser = nodeSeenTracker();
-    const directImports = [];
-    const isAvailableThroughGlobal = !!exportingModuleSymbol.globalExports;
-    const indirectUserDeclarations = isAvailableThroughGlobal ? void 0 : [];
-    handleDirectImports(exportingModuleSymbol);
-    return { directImports, indirectUsers: getIndirectUsers() };
-    function getIndirectUsers() {
-      if (isAvailableThroughGlobal) {
-        return sourceFiles;
-      }
-      if (exportingModuleSymbol.declarations) {
-        for (const decl of exportingModuleSymbol.declarations) {
-          if (isExternalModuleAugmentation(decl) && sourceFilesSet.has(decl.getSourceFile().fileName)) {
-            addIndirectUser(decl);
-          }
-        }
-      }
-      return indirectUserDeclarations.map(getSourceFileOfNode);
+  function getImportKindOrder(s1) {
+    var _a;
+    switch (s1.kind) {
+      case 272 /* ImportDeclaration */:
+        if (!s1.importClause)
+          return 0;
+        if (s1.importClause.isTypeOnly)
+          return 1;
+        if (((_a = s1.importClause.namedBindings) == null ? void 0 : _a.kind) === 274 /* NamespaceImport */)
+          return 2;
+        if (s1.importClause.name)
+          return 3;
+        return 4;
+      case 271 /* ImportEqualsDeclaration */:
+        return 5;
+      case 243 /* VariableStatement */:
+        return 6;
     }
-    function handleDirectImports(exportingModuleSymbol2) {
-      const theseDirectImports = getDirectImports(exportingModuleSymbol2);
-      if (theseDirectImports) {
-        for (const direct of theseDirectImports) {
-          if (!markSeenDirectImport(direct)) {
-            continue;
-          }
-          if (cancellationToken)
-            cancellationToken.throwIfCancellationRequested();
-          switch (direct.kind) {
-            case 212 /* CallExpression */:
-              if (isImportCall(direct)) {
-                handleImportCall(direct);
-                break;
-              }
-              if (!isAvailableThroughGlobal) {
-                const parent2 = direct.parent;
-                if (exportKind === 2 /* ExportEquals */ && parent2.kind === 259 /* VariableDeclaration */) {
-                  const { name } = parent2;
-                  if (name.kind === 80 /* Identifier */) {
-                    directImports.push(name);
-                    break;
-                  }
-                }
-              }
-              break;
-            case 80 /* Identifier */:
-              break;
-            case 270 /* ImportEqualsDeclaration */:
-              handleNamespaceImport(
-                direct,
-                direct.name,
-                hasSyntacticModifier(direct, 1 /* Export */),
-                /*alreadyAddedDirect*/
-                false
-              );
-              break;
-            case 271 /* ImportDeclaration */:
-              directImports.push(direct);
-              const namedBindings = direct.importClause && direct.importClause.namedBindings;
-              if (namedBindings && namedBindings.kind === 273 /* NamespaceImport */) {
-                handleNamespaceImport(
-                  direct,
-                  namedBindings.name,
-                  /*isReExport*/
-                  false,
-                  /*alreadyAddedDirect*/
-                  true
-                );
-              } else if (!isAvailableThroughGlobal && isDefaultImport(direct)) {
-                addIndirectUser(getSourceFileLikeForImportDeclaration(direct));
-              }
-              break;
-            case 277 /* ExportDeclaration */:
-              if (!direct.exportClause) {
-                handleDirectImports(getContainingModuleSymbol(direct, checker));
-              } else if (direct.exportClause.kind === 279 /* NamespaceExport */) {
-                addIndirectUser(
-                  getSourceFileLikeForImportDeclaration(direct),
-                  /*addTransitiveDependencies*/
-                  true
-                );
-              } else {
-                directImports.push(direct);
-              }
-              break;
-            case 204 /* ImportType */:
-              if (!isAvailableThroughGlobal && direct.isTypeOf && !direct.qualifier && isExported2(direct)) {
-                addIndirectUser(
-                  direct.getSourceFile(),
-                  /*addTransitiveDependencies*/
-                  true
-                );
-              }
-              directImports.push(direct);
-              break;
-            default:
-              Debug.failBadSyntaxKind(direct, "Unexpected import kind.");
-          }
+  }
+  function getNewImportSpecifiers(namedImports) {
+    return flatMap(namedImports, (namedImport) => map(tryGetNamedBindingElements(namedImport), (importSpecifier) => importSpecifier.name && importSpecifier.propertyName && importSpecifier.name.escapedText === importSpecifier.propertyName.escapedText ? factory.updateImportSpecifier(
+      importSpecifier,
+      importSpecifier.isTypeOnly,
+      /*propertyName*/
+      void 0,
+      importSpecifier.name
+    ) : importSpecifier));
+  }
+  function tryGetNamedBindingElements(namedImport) {
+    var _a;
+    return ((_a = namedImport.importClause) == null ? void 0 : _a.namedBindings) && isNamedImports(namedImport.importClause.namedBindings) ? namedImport.importClause.namedBindings.elements : void 0;
+  }
+  function getOrganizeImportsOrdinalStringComparer(ignoreCase) {
+    return ignoreCase ? compareStringsCaseInsensitiveEslintCompatible : compareStringsCaseSensitive;
+  }
+  function getOrganizeImportsUnicodeStringComparer(ignoreCase, preferences) {
+    const resolvedLocale = getOrganizeImportsLocale(preferences);
+    const caseFirst = preferences.organizeImportsCaseFirst ?? false;
+    const numeric = preferences.organizeImportsNumericCollation ?? false;
+    const accents = preferences.organizeImportsAccentCollation ?? true;
+    const sensitivity = ignoreCase ? accents ? "accent" : "base" : accents ? "variant" : "case";
+    const collator = new Intl.Collator(resolvedLocale, {
+      usage: "sort",
+      caseFirst: caseFirst || "false",
+      sensitivity,
+      numeric
+    });
+    return collator.compare;
+  }
+  function getOrganizeImportsLocale(preferences) {
+    let locale = preferences.organizeImportsLocale;
+    if (locale === "auto")
+      locale = getUILocale();
+    if (locale === void 0)
+      locale = "en";
+    const supportedLocales = Intl.Collator.supportedLocalesOf(locale);
+    const resolvedLocale = supportedLocales.length ? supportedLocales[0] : "en";
+    return resolvedLocale;
+  }
+  function getOrganizeImportsComparer(preferences, ignoreCase) {
+    const collation = preferences.organizeImportsCollation ?? "ordinal";
+    return collation === "unicode" ? getOrganizeImportsUnicodeStringComparer(ignoreCase, preferences) : getOrganizeImportsOrdinalStringComparer(ignoreCase);
+  }
+  function getOrganizeImportsComparerWithDetection(preferences, detectIgnoreCase) {
+    const ignoreCase = typeof preferences.organizeImportsIgnoreCase === "boolean" ? preferences.organizeImportsIgnoreCase : (detectIgnoreCase == null ? void 0 : detectIgnoreCase()) ?? false;
+    return getOrganizeImportsComparer(preferences, ignoreCase);
+  }
+  function getTopLevelExportGroups(sourceFile) {
+    const topLevelExportGroups = [];
+    const statements = sourceFile.statements;
+    const len = length(statements);
+    let i = 0;
+    let groupIndex = 0;
+    while (i < len) {
+      if (isExportDeclaration(statements[i])) {
+        if (topLevelExportGroups[groupIndex] === void 0) {
+          topLevelExportGroups[groupIndex] = [];
         }
-      }
-    }
-    function handleImportCall(importCall) {
-      const top = findAncestor(importCall, isAmbientModuleDeclaration) || importCall.getSourceFile();
-      addIndirectUser(
-        top,
-        /** addTransitiveDependencies */
-        !!isExported2(
-          importCall,
-          /*stopAtAmbientModule*/
-          true
-        )
-      );
-    }
-    function isExported2(node, stopAtAmbientModule = false) {
-      return findAncestor(node, (node2) => {
-        if (stopAtAmbientModule && isAmbientModuleDeclaration(node2))
-          return "quit";
-        return canHaveModifiers(node2) && some(node2.modifiers, isExportModifier);
-      });
-    }
-    function handleNamespaceImport(importDeclaration, name, isReExport, alreadyAddedDirect) {
-      if (exportKind === 2 /* ExportEquals */) {
-        if (!alreadyAddedDirect)
-          directImports.push(importDeclaration);
-      } else if (!isAvailableThroughGlobal) {
-        const sourceFileLike = getSourceFileLikeForImportDeclaration(importDeclaration);
-        Debug.assert(sourceFileLike.kind === 311 /* SourceFile */ || sourceFileLike.kind === 266 /* ModuleDeclaration */);
-        if (isReExport || findNamespaceReExports(sourceFileLike, name, checker)) {
-          addIndirectUser(
-            sourceFileLike,
-            /*addTransitiveDependencies*/
-            true
-          );
+        const exportDecl = statements[i];
+        if (exportDecl.moduleSpecifier) {
+          topLevelExportGroups[groupIndex].push(exportDecl);
+          i++;
         } else {
-          addIndirectUser(sourceFileLike);
-        }
-      }
-    }
-    function addIndirectUser(sourceFileLike, addTransitiveDependencies = false) {
-      Debug.assert(!isAvailableThroughGlobal);
-      const isNew = markSeenIndirectUser(sourceFileLike);
-      if (!isNew)
-        return;
-      indirectUserDeclarations.push(sourceFileLike);
-      if (!addTransitiveDependencies)
-        return;
-      const moduleSymbol = checker.getMergedSymbol(sourceFileLike.symbol);
-      if (!moduleSymbol)
-        return;
-      Debug.assert(!!(moduleSymbol.flags & 1536 /* Module */));
-      const directImports2 = getDirectImports(moduleSymbol);
-      if (directImports2) {
-        for (const directImport of directImports2) {
-          if (!isImportTypeNode(directImport)) {
-            addIndirectUser(
-              getSourceFileLikeForImportDeclaration(directImport),
-              /*addTransitiveDependencies*/
-              true
-            );
+          while (i < len && isExportDeclaration(statements[i])) {
+            topLevelExportGroups[groupIndex].push(statements[i++]);
           }
+          groupIndex++;
         }
+      } else {
+        i++;
       }
     }
-    function getDirectImports(moduleSymbol) {
-      return allDirectImports.get(getSymbolId(moduleSymbol).toString());
-    }
+    return flatMap(topLevelExportGroups, (exportGroupDecls) => groupByNewlineContiguous(sourceFile, exportGroupDecls));
   }
-  function getSearchesFromDirectImports(directImports, exportSymbol, exportKind, checker, isForRename) {
-    const importSearches = [];
-    const singleReferences = [];
-    function addSearch(location, symbol) {
-      importSearches.push([location, symbol]);
+  var ImportSpecifierSortingCache, detectImportSpecifierSorting;
+  var init_organizeImports = __esm({
+    "src/services/organizeImports.ts"() {
+      "use strict";
+      init_ts4();
+      ImportSpecifierSortingCache = class {
+        has([specifiers, preferences]) {
+          if (this._lastPreferences !== preferences || !this._cache)
+            return false;
+          return this._cache.has(specifiers);
+        }
+        get([specifiers, preferences]) {
+          if (this._lastPreferences !== preferences || !this._cache)
+            return void 0;
+          return this._cache.get(specifiers);
+        }
+        set([specifiers, preferences], value) {
+          if (this._lastPreferences !== preferences) {
+            this._lastPreferences = preferences;
+            this._cache = void 0;
+          }
+          this._cache ?? (this._cache = /* @__PURE__ */ new WeakMap());
+          this._cache.set(specifiers, value);
+        }
+      };
+      detectImportSpecifierSorting = memoizeCached((specifiers, preferences) => {
+        if (!arrayIsSorted(specifiers, (s1, s2) => compareBooleans(s1.isTypeOnly, s2.isTypeOnly))) {
+          return 0 /* None */;
+        }
+        const collateCaseSensitive = getOrganizeImportsComparer(
+          preferences,
+          /*ignoreCase*/
+          false
+        );
+        const collateCaseInsensitive = getOrganizeImportsComparer(
+          preferences,
+          /*ignoreCase*/
+          true
+        );
+        return detectSortCaseSensitivity(specifiers, (specifier) => specifier.name.text, collateCaseSensitive, collateCaseInsensitive);
+      }, new ImportSpecifierSortingCache());
     }
-    if (directImports) {
-      for (const decl of directImports) {
-        handleImport(decl);
-      }
+  });
+
+  // src/services/_namespaces/ts.OrganizeImports.ts
+  var ts_OrganizeImports_exports = {};
+  __export(ts_OrganizeImports_exports, {
+    coalesceExports: () => coalesceExports,
+    coalesceImports: () => coalesceImports,
+    compareImportOrExportSpecifiers: () => compareImportOrExportSpecifiers,
+    compareImportsOrRequireStatements: () => compareImportsOrRequireStatements,
+    compareModuleSpecifiers: () => compareModuleSpecifiers2,
+    detectImportDeclarationSorting: () => detectImportDeclarationSorting,
+    detectImportSpecifierSorting: () => detectImportSpecifierSorting,
+    detectSorting: () => detectSorting,
+    getImportDeclarationInsertionIndex: () => getImportDeclarationInsertionIndex,
+    getImportSpecifierInsertionIndex: () => getImportSpecifierInsertionIndex,
+    getOrganizeImportsComparer: () => getOrganizeImportsComparer,
+    organizeImports: () => organizeImports
+  });
+  var init_ts_OrganizeImports = __esm({
+    "src/services/_namespaces/ts.OrganizeImports.ts"() {
+      "use strict";
+      init_organizeImports();
     }
-    return { importSearches, singleReferences };
-    function handleImport(decl) {
-      if (decl.kind === 270 /* ImportEqualsDeclaration */) {
-        if (isExternalModuleImportEquals(decl)) {
-          handleNamespaceImportLike(decl.name);
-        }
-        return;
+  });
+
+  // src/services/outliningElementsCollector.ts
+  function collectElements(sourceFile, cancellationToken) {
+    const res = [];
+    addNodeOutliningSpans(sourceFile, cancellationToken, res);
+    addRegionOutliningSpans(sourceFile, res);
+    return res.sort((span1, span2) => span1.textSpan.start - span2.textSpan.start);
+  }
+  function addNodeOutliningSpans(sourceFile, cancellationToken, out) {
+    let depthRemaining = 40;
+    let current = 0;
+    const statements = [...sourceFile.statements, sourceFile.endOfFileToken];
+    const n = statements.length;
+    while (current < n) {
+      while (current < n && !isAnyImportSyntax(statements[current])) {
+        visitNode3(statements[current]);
+        current++;
       }
-      if (decl.kind === 80 /* Identifier */) {
-        handleNamespaceImportLike(decl);
-        return;
+      if (current === n)
+        break;
+      const firstImport = current;
+      while (current < n && isAnyImportSyntax(statements[current])) {
+        visitNode3(statements[current]);
+        current++;
       }
-      if (decl.kind === 204 /* ImportType */) {
-        if (decl.qualifier) {
-          const firstIdentifier = getFirstIdentifier(decl.qualifier);
-          if (firstIdentifier.escapedText === symbolName(exportSymbol)) {
-            singleReferences.push(firstIdentifier);
-          }
-        } else if (exportKind === 2 /* ExportEquals */) {
-          singleReferences.push(decl.argument.literal);
-        }
-        return;
+      const lastImport = current - 1;
+      if (lastImport !== firstImport) {
+        out.push(createOutliningSpanFromBounds(findChildOfKind(statements[firstImport], 102 /* ImportKeyword */, sourceFile).getStart(sourceFile), statements[lastImport].getEnd(), "imports" /* Imports */));
       }
-      if (decl.moduleSpecifier.kind !== 11 /* StringLiteral */) {
+    }
+    function visitNode3(n2) {
+      var _a;
+      if (depthRemaining === 0)
         return;
+      cancellationToken.throwIfCancellationRequested();
+      if (isDeclaration(n2) || isVariableStatement(n2) || isReturnStatement(n2) || isCallOrNewExpression(n2) || n2.kind === 1 /* EndOfFileToken */) {
+        addOutliningForLeadingCommentsForNode(n2, sourceFile, cancellationToken, out);
       }
-      if (decl.kind === 277 /* ExportDeclaration */) {
-        if (decl.exportClause && isNamedExports(decl.exportClause)) {
-          searchForNamedImport(decl.exportClause);
-        }
-        return;
+      if (isFunctionLike(n2) && isBinaryExpression(n2.parent) && isPropertyAccessExpression(n2.parent.left)) {
+        addOutliningForLeadingCommentsForNode(n2.parent.left, sourceFile, cancellationToken, out);
       }
-      const { name, namedBindings } = decl.importClause || { name: void 0, namedBindings: void 0 };
-      if (namedBindings) {
-        switch (namedBindings.kind) {
-          case 273 /* NamespaceImport */:
-            handleNamespaceImportLike(namedBindings.name);
-            break;
-          case 274 /* NamedImports */:
-            if (exportKind === 0 /* Named */ || exportKind === 1 /* Default */) {
-              searchForNamedImport(namedBindings);
-            }
-            break;
-          default:
-            Debug.assertNever(namedBindings);
-        }
+      if (isBlock(n2) || isModuleBlock(n2)) {
+        addOutliningForLeadingCommentsForPos(n2.statements.end, sourceFile, cancellationToken, out);
       }
-      if (name && (exportKind === 1 /* Default */ || exportKind === 2 /* ExportEquals */) && (!isForRename || name.escapedText === symbolEscapedNameNoDefault(exportSymbol))) {
-        const defaultImportAlias = checker.getSymbolAtLocation(name);
-        addSearch(name, defaultImportAlias);
+      if (isClassLike(n2) || isInterfaceDeclaration(n2)) {
+        addOutliningForLeadingCommentsForPos(n2.members.end, sourceFile, cancellationToken, out);
       }
-    }
-    function handleNamespaceImportLike(importName) {
-      if (exportKind === 2 /* ExportEquals */ && (!isForRename || isNameMatch(importName.escapedText))) {
-        addSearch(importName, checker.getSymbolAtLocation(importName));
+      const span = getOutliningSpanForNode(n2, sourceFile);
+      if (span)
+        out.push(span);
+      depthRemaining--;
+      if (isCallExpression(n2)) {
+        depthRemaining++;
+        visitNode3(n2.expression);
+        depthRemaining--;
+        n2.arguments.forEach(visitNode3);
+        (_a = n2.typeArguments) == null ? void 0 : _a.forEach(visitNode3);
+      } else if (isIfStatement(n2) && n2.elseStatement && isIfStatement(n2.elseStatement)) {
+        visitNode3(n2.expression);
+        visitNode3(n2.thenStatement);
+        depthRemaining++;
+        visitNode3(n2.elseStatement);
+        depthRemaining--;
+      } else {
+        n2.forEachChild(visitNode3);
       }
+      depthRemaining++;
     }
-    function searchForNamedImport(namedBindings) {
-      if (!namedBindings) {
-        return;
+  }
+  function addRegionOutliningSpans(sourceFile, out) {
+    const regions = [];
+    const lineStarts = sourceFile.getLineStarts();
+    for (const currentLineStart of lineStarts) {
+      const lineEnd = sourceFile.getLineEndOfPosition(currentLineStart);
+      const lineText = sourceFile.text.substring(currentLineStart, lineEnd);
+      const result = isRegionDelimiter(lineText);
+      if (!result || isInComment(sourceFile, currentLineStart)) {
+        continue;
       }
-      for (const element of namedBindings.elements) {
-        const { name, propertyName } = element;
-        if (!isNameMatch((propertyName || name).escapedText)) {
-          continue;
-        }
-        if (propertyName) {
-          singleReferences.push(propertyName);
-          if (!isForRename || name.escapedText === exportSymbol.escapedName) {
-            addSearch(name, checker.getSymbolAtLocation(name));
-          }
-        } else {
-          const localSymbol = element.kind === 280 /* ExportSpecifier */ && element.propertyName ? checker.getExportSpecifierLocalTargetSymbol(element) : checker.getSymbolAtLocation(name);
-          addSearch(name, localSymbol);
+      if (!result[1]) {
+        const span = createTextSpanFromBounds(sourceFile.text.indexOf("//", currentLineStart), lineEnd);
+        regions.push(createOutliningSpan(
+          span,
+          "region" /* Region */,
+          span,
+          /*autoCollapse*/
+          false,
+          result[2] || "#region"
+        ));
+      } else {
+        const region = regions.pop();
+        if (region) {
+          region.textSpan.length = lineEnd - region.textSpan.start;
+          region.hintSpan.length = lineEnd - region.textSpan.start;
+          out.push(region);
         }
       }
     }
-    function isNameMatch(name) {
-      return name === exportSymbol.escapedName || exportKind !== 0 /* Named */ && name === "default" /* Default */;
-    }
   }
-  function findNamespaceReExports(sourceFileLike, name, checker) {
-    const namespaceImportSymbol = checker.getSymbolAtLocation(name);
-    return !!forEachPossibleImportOrExportStatement(sourceFileLike, (statement) => {
-      if (!isExportDeclaration(statement))
-        return;
-      const { exportClause, moduleSpecifier } = statement;
-      return !moduleSpecifier && exportClause && isNamedExports(exportClause) && exportClause.elements.some((element) => checker.getExportSpecifierLocalTargetSymbol(element) === namespaceImportSymbol);
-    });
+  function isRegionDelimiter(lineText) {
+    lineText = lineText.trimStart();
+    if (!startsWith(lineText, "//")) {
+      return null;
+    }
+    lineText = lineText.slice(2).trim();
+    return regionDelimiterRegExp.exec(lineText);
   }
-  function findModuleReferences(program, sourceFiles, searchModuleSymbol) {
-    var _a;
-    const refs = [];
-    const checker = program.getTypeChecker();
-    for (const referencingFile of sourceFiles) {
-      const searchSourceFile = searchModuleSymbol.valueDeclaration;
-      if ((searchSourceFile == null ? void 0 : searchSourceFile.kind) === 311 /* SourceFile */) {
-        for (const ref of referencingFile.referencedFiles) {
-          if (program.getSourceFileFromReference(referencingFile, ref) === searchSourceFile) {
-            refs.push({ kind: "reference", referencingFile, ref });
+  function addOutliningForLeadingCommentsForPos(pos, sourceFile, cancellationToken, out) {
+    const comments = getLeadingCommentRanges(sourceFile.text, pos);
+    if (!comments)
+      return;
+    let firstSingleLineCommentStart = -1;
+    let lastSingleLineCommentEnd = -1;
+    let singleLineCommentCount = 0;
+    const sourceText = sourceFile.getFullText();
+    for (const { kind, pos: pos2, end } of comments) {
+      cancellationToken.throwIfCancellationRequested();
+      switch (kind) {
+        case 2 /* SingleLineCommentTrivia */:
+          const commentText = sourceText.slice(pos2, end);
+          if (isRegionDelimiter(commentText)) {
+            combineAndAddMultipleSingleLineComments();
+            singleLineCommentCount = 0;
+            break;
           }
-        }
-        for (const ref of referencingFile.typeReferenceDirectives) {
-          const referenced = (_a = program.getResolvedTypeReferenceDirectives().get(ref.fileName, ref.resolutionMode || referencingFile.impliedNodeFormat)) == null ? void 0 : _a.resolvedTypeReferenceDirective;
-          if (referenced !== void 0 && referenced.resolvedFileName === searchSourceFile.fileName) {
-            refs.push({ kind: "reference", referencingFile, ref });
+          if (singleLineCommentCount === 0) {
+            firstSingleLineCommentStart = pos2;
           }
-        }
+          lastSingleLineCommentEnd = end;
+          singleLineCommentCount++;
+          break;
+        case 3 /* MultiLineCommentTrivia */:
+          combineAndAddMultipleSingleLineComments();
+          out.push(createOutliningSpanFromBounds(pos2, end, "comment" /* Comment */));
+          singleLineCommentCount = 0;
+          break;
+        default:
+          Debug.assertNever(kind);
       }
-      forEachImport(referencingFile, (importDecl, moduleSpecifier) => {
-        const moduleSymbol = checker.getSymbolAtLocation(moduleSpecifier);
-        if (moduleSymbol === searchModuleSymbol) {
-          refs.push(nodeIsSynthesized(importDecl) ? { kind: "implicit", literal: moduleSpecifier, referencingFile } : { kind: "import", literal: moduleSpecifier });
-        }
-      });
     }
-    return refs;
-  }
-  function getDirectImportsMap(sourceFiles, checker, cancellationToken) {
-    const map2 = /* @__PURE__ */ new Map();
-    for (const sourceFile of sourceFiles) {
-      if (cancellationToken)
-        cancellationToken.throwIfCancellationRequested();
-      forEachImport(sourceFile, (importDecl, moduleSpecifier) => {
-        const moduleSymbol = checker.getSymbolAtLocation(moduleSpecifier);
-        if (moduleSymbol) {
-          const id = getSymbolId(moduleSymbol).toString();
-          let imports = map2.get(id);
-          if (!imports) {
-            map2.set(id, imports = []);
-          }
-          imports.push(importDecl);
-        }
-      });
+    combineAndAddMultipleSingleLineComments();
+    function combineAndAddMultipleSingleLineComments() {
+      if (singleLineCommentCount > 1) {
+        out.push(createOutliningSpanFromBounds(firstSingleLineCommentStart, lastSingleLineCommentEnd, "comment" /* Comment */));
+      }
     }
-    return map2;
   }
-  function forEachPossibleImportOrExportStatement(sourceFileLike, action) {
-    return forEach(sourceFileLike.kind === 311 /* SourceFile */ ? sourceFileLike.statements : sourceFileLike.body.statements, (statement) => (
-      // TODO: GH#18217
-      action(statement) || isAmbientModuleDeclaration(statement) && forEach(statement.body && statement.body.statements, action)
-    ));
+  function addOutliningForLeadingCommentsForNode(n, sourceFile, cancellationToken, out) {
+    if (isJsxText(n))
+      return;
+    addOutliningForLeadingCommentsForPos(n.pos, sourceFile, cancellationToken, out);
   }
-  function forEachImport(sourceFile, action) {
-    if (sourceFile.externalModuleIndicator || sourceFile.imports !== void 0) {
-      for (const i of sourceFile.imports) {
-        action(importFromModuleSpecifier(i), i);
-      }
-    } else {
-      forEachPossibleImportOrExportStatement(sourceFile, (statement) => {
-        switch (statement.kind) {
-          case 277 /* ExportDeclaration */:
-          case 271 /* ImportDeclaration */: {
-            const decl = statement;
-            if (decl.moduleSpecifier && isStringLiteral(decl.moduleSpecifier)) {
-              action(decl, decl.moduleSpecifier);
-            }
-            break;
-          }
-          case 270 /* ImportEqualsDeclaration */: {
-            const decl = statement;
-            if (isExternalModuleImportEquals(decl)) {
-              action(decl, decl.moduleReference.expression);
-            }
-            break;
-          }
-        }
-      });
-    }
+  function createOutliningSpanFromBounds(pos, end, kind) {
+    return createOutliningSpan(createTextSpanFromBounds(pos, end), kind);
   }
-  function getImportOrExportSymbol(node, symbol, checker, comingFromExport) {
-    return comingFromExport ? getExport() : getExport() || getImport();
-    function getExport() {
-      var _a;
-      const { parent: parent2 } = node;
-      const grandparent = parent2.parent;
-      if (symbol.exportSymbol) {
-        if (parent2.kind === 210 /* PropertyAccessExpression */) {
-          return ((_a = symbol.declarations) == null ? void 0 : _a.some((d) => d === parent2)) && isBinaryExpression(grandparent) ? getSpecialPropertyExport(
-            grandparent,
-            /*useLhsSymbol*/
-            false
-          ) : void 0;
-        } else {
-          return exportInfo(symbol.exportSymbol, getExportKindForDeclaration(parent2));
+  function getOutliningSpanForNode(n, sourceFile) {
+    switch (n.kind) {
+      case 241 /* Block */:
+        if (isFunctionLike(n.parent)) {
+          return functionSpan(n.parent, n, sourceFile);
         }
-      } else {
-        const exportNode = getExportNode(parent2, node);
-        if (exportNode && hasSyntacticModifier(exportNode, 1 /* Export */)) {
-          if (isImportEqualsDeclaration(exportNode) && exportNode.moduleReference === node) {
-            if (comingFromExport) {
-              return void 0;
+        switch (n.parent.kind) {
+          case 246 /* DoStatement */:
+          case 249 /* ForInStatement */:
+          case 250 /* ForOfStatement */:
+          case 248 /* ForStatement */:
+          case 245 /* IfStatement */:
+          case 247 /* WhileStatement */:
+          case 254 /* WithStatement */:
+          case 299 /* CatchClause */:
+            return spanForNode(n.parent);
+          case 258 /* TryStatement */:
+            const tryStatement = n.parent;
+            if (tryStatement.tryBlock === n) {
+              return spanForNode(n.parent);
+            } else if (tryStatement.finallyBlock === n) {
+              const node = findChildOfKind(tryStatement, 98 /* FinallyKeyword */, sourceFile);
+              if (node)
+                return spanForNode(node);
             }
-            const lhsSymbol = checker.getSymbolAtLocation(exportNode.name);
-            return { kind: 0 /* Import */, symbol: lhsSymbol };
-          } else {
-            return exportInfo(symbol, getExportKindForDeclaration(exportNode));
-          }
-        } else if (isNamespaceExport(parent2)) {
-          return exportInfo(symbol, 0 /* Named */);
-        } else if (isExportAssignment(parent2)) {
-          return getExportAssignmentExport(parent2);
-        } else if (isExportAssignment(grandparent)) {
-          return getExportAssignmentExport(grandparent);
-        } else if (isBinaryExpression(parent2)) {
-          return getSpecialPropertyExport(
-            parent2,
-            /*useLhsSymbol*/
-            true
-          );
-        } else if (isBinaryExpression(grandparent)) {
-          return getSpecialPropertyExport(
-            grandparent,
-            /*useLhsSymbol*/
-            true
-          );
-        } else if (isJSDocTypedefTag(parent2) || isJSDocCallbackTag(parent2)) {
-          return exportInfo(symbol, 0 /* Named */);
+          default:
+            return createOutliningSpan(createTextSpanFromNode(n, sourceFile), "code" /* Code */);
         }
+      case 268 /* ModuleBlock */:
+        return spanForNode(n.parent);
+      case 263 /* ClassDeclaration */:
+      case 231 /* ClassExpression */:
+      case 264 /* InterfaceDeclaration */:
+      case 266 /* EnumDeclaration */:
+      case 269 /* CaseBlock */:
+      case 187 /* TypeLiteral */:
+      case 206 /* ObjectBindingPattern */:
+        return spanForNode(n);
+      case 189 /* TupleType */:
+        return spanForNode(
+          n,
+          /*autoCollapse*/
+          false,
+          /*useFullStart*/
+          !isTupleTypeNode(n.parent),
+          23 /* OpenBracketToken */
+        );
+      case 296 /* CaseClause */:
+      case 297 /* DefaultClause */:
+        return spanForNodeArray(n.statements);
+      case 210 /* ObjectLiteralExpression */:
+        return spanForObjectOrArrayLiteral(n);
+      case 209 /* ArrayLiteralExpression */:
+        return spanForObjectOrArrayLiteral(n, 23 /* OpenBracketToken */);
+      case 284 /* JsxElement */:
+        return spanForJSXElement(n);
+      case 288 /* JsxFragment */:
+        return spanForJSXFragment(n);
+      case 285 /* JsxSelfClosingElement */:
+      case 286 /* JsxOpeningElement */:
+        return spanForJSXAttributes(n.attributes);
+      case 228 /* TemplateExpression */:
+      case 15 /* NoSubstitutionTemplateLiteral */:
+        return spanForTemplateLiteral(n);
+      case 207 /* ArrayBindingPattern */:
+        return spanForNode(
+          n,
+          /*autoCollapse*/
+          false,
+          /*useFullStart*/
+          !isBindingElement(n.parent),
+          23 /* OpenBracketToken */
+        );
+      case 219 /* ArrowFunction */:
+        return spanForArrowFunction(n);
+      case 213 /* CallExpression */:
+        return spanForCallExpression(n);
+      case 217 /* ParenthesizedExpression */:
+        return spanForParenthesizedExpression(n);
+      case 275 /* NamedImports */:
+      case 279 /* NamedExports */:
+      case 300 /* ImportAttributes */:
+        return spanForImportExportElements(n);
+    }
+    function spanForImportExportElements(node) {
+      if (!node.elements.length) {
+        return void 0;
       }
-      function getExportAssignmentExport(ex) {
-        if (!ex.symbol.parent)
-          return void 0;
-        const exportKind = ex.isExportEquals ? 2 /* ExportEquals */ : 1 /* Default */;
-        return { kind: 1 /* Export */, symbol, exportInfo: { exportingModuleSymbol: ex.symbol.parent, exportKind } };
+      const openToken = findChildOfKind(node, 19 /* OpenBraceToken */, sourceFile);
+      const closeToken = findChildOfKind(node, 20 /* CloseBraceToken */, sourceFile);
+      if (!openToken || !closeToken || positionsAreOnSameLine(openToken.pos, closeToken.pos, sourceFile)) {
+        return void 0;
       }
-      function getSpecialPropertyExport(node2, useLhsSymbol) {
-        let kind;
-        switch (getAssignmentDeclarationKind(node2)) {
-          case 1 /* ExportsProperty */:
-            kind = 0 /* Named */;
-            break;
-          case 2 /* ModuleExports */:
-            kind = 2 /* ExportEquals */;
-            break;
-          default:
-            return void 0;
-        }
-        const sym = useLhsSymbol ? checker.getSymbolAtLocation(getNameOfAccessExpression(cast(node2.left, isAccessExpression))) : symbol;
-        return sym && exportInfo(sym, kind);
+      return spanBetweenTokens(
+        openToken,
+        closeToken,
+        node,
+        sourceFile,
+        /*autoCollapse*/
+        false,
+        /*useFullStart*/
+        false
+      );
+    }
+    function spanForCallExpression(node) {
+      if (!node.arguments.length) {
+        return void 0;
+      }
+      const openToken = findChildOfKind(node, 21 /* OpenParenToken */, sourceFile);
+      const closeToken = findChildOfKind(node, 22 /* CloseParenToken */, sourceFile);
+      if (!openToken || !closeToken || positionsAreOnSameLine(openToken.pos, closeToken.pos, sourceFile)) {
+        return void 0;
       }
+      return spanBetweenTokens(
+        openToken,
+        closeToken,
+        node,
+        sourceFile,
+        /*autoCollapse*/
+        false,
+        /*useFullStart*/
+        true
+      );
     }
-    function getImport() {
-      const isImport3 = isNodeImport(node);
-      if (!isImport3)
+    function spanForArrowFunction(node) {
+      if (isBlock(node.body) || isParenthesizedExpression(node.body) || positionsAreOnSameLine(node.body.getFullStart(), node.body.getEnd(), sourceFile)) {
         return void 0;
-      let importedSymbol = checker.getImmediateAliasedSymbol(symbol);
-      if (!importedSymbol)
+      }
+      const textSpan = createTextSpanFromBounds(node.body.getFullStart(), node.body.getEnd());
+      return createOutliningSpan(textSpan, "code" /* Code */, createTextSpanFromNode(node));
+    }
+    function spanForJSXElement(node) {
+      const textSpan = createTextSpanFromBounds(node.openingElement.getStart(sourceFile), node.closingElement.getEnd());
+      const tagName = node.openingElement.tagName.getText(sourceFile);
+      const bannerText = "<" + tagName + ">...";
+      return createOutliningSpan(
+        textSpan,
+        "code" /* Code */,
+        textSpan,
+        /*autoCollapse*/
+        false,
+        bannerText
+      );
+    }
+    function spanForJSXFragment(node) {
+      const textSpan = createTextSpanFromBounds(node.openingFragment.getStart(sourceFile), node.closingFragment.getEnd());
+      const bannerText = "<>...";
+      return createOutliningSpan(
+        textSpan,
+        "code" /* Code */,
+        textSpan,
+        /*autoCollapse*/
+        false,
+        bannerText
+      );
+    }
+    function spanForJSXAttributes(node) {
+      if (node.properties.length === 0) {
         return void 0;
-      importedSymbol = skipExportSpecifierSymbol(importedSymbol, checker);
-      if (importedSymbol.escapedName === "export=") {
-        importedSymbol = getExportEqualsLocalSymbol(importedSymbol, checker);
-        if (importedSymbol === void 0)
-          return void 0;
       }
-      const importedName = symbolEscapedNameNoDefault(importedSymbol);
-      if (importedName === void 0 || importedName === "default" /* Default */ || importedName === symbol.escapedName) {
-        return { kind: 0 /* Import */, symbol: importedSymbol };
+      return createOutliningSpanFromBounds(node.getStart(sourceFile), node.getEnd(), "code" /* Code */);
+    }
+    function spanForTemplateLiteral(node) {
+      if (node.kind === 15 /* NoSubstitutionTemplateLiteral */ && node.text.length === 0) {
+        return void 0;
       }
+      return createOutliningSpanFromBounds(node.getStart(sourceFile), node.getEnd(), "code" /* Code */);
     }
-    function exportInfo(symbol2, kind) {
-      const exportInfo2 = getExportInfo(symbol2, kind, checker);
-      return exportInfo2 && { kind: 1 /* Export */, symbol: symbol2, exportInfo: exportInfo2 };
+    function spanForObjectOrArrayLiteral(node, open = 19 /* OpenBraceToken */) {
+      return spanForNode(
+        node,
+        /*autoCollapse*/
+        false,
+        /*useFullStart*/
+        !isArrayLiteralExpression(node.parent) && !isCallExpression(node.parent),
+        open
+      );
     }
-    function getExportKindForDeclaration(node2) {
-      return hasSyntacticModifier(node2, 1024 /* Default */) ? 1 /* Default */ : 0 /* Named */;
+    function spanForNode(hintSpanNode, autoCollapse = false, useFullStart = true, open = 19 /* OpenBraceToken */, close = open === 19 /* OpenBraceToken */ ? 20 /* CloseBraceToken */ : 24 /* CloseBracketToken */) {
+      const openToken = findChildOfKind(n, open, sourceFile);
+      const closeToken = findChildOfKind(n, close, sourceFile);
+      return openToken && closeToken && spanBetweenTokens(openToken, closeToken, hintSpanNode, sourceFile, autoCollapse, useFullStart);
     }
-  }
-  function getExportEqualsLocalSymbol(importedSymbol, checker) {
-    var _a, _b;
-    if (importedSymbol.flags & 2097152 /* Alias */) {
-      return checker.getImmediateAliasedSymbol(importedSymbol);
+    function spanForNodeArray(nodeArray) {
+      return nodeArray.length ? createOutliningSpan(createTextSpanFromRange(nodeArray), "code" /* Code */) : void 0;
     }
-    const decl = Debug.checkDefined(importedSymbol.valueDeclaration);
-    if (isExportAssignment(decl)) {
-      return (_a = tryCast(decl.expression, canHaveSymbol)) == null ? void 0 : _a.symbol;
-    } else if (isBinaryExpression(decl)) {
-      return (_b = tryCast(decl.right, canHaveSymbol)) == null ? void 0 : _b.symbol;
-    } else if (isSourceFile(decl)) {
-      return decl.symbol;
+    function spanForParenthesizedExpression(node) {
+      if (positionsAreOnSameLine(node.getStart(), node.getEnd(), sourceFile))
+        return void 0;
+      const textSpan = createTextSpanFromBounds(node.getStart(), node.getEnd());
+      return createOutliningSpan(textSpan, "code" /* Code */, createTextSpanFromNode(node));
     }
-    return void 0;
   }
-  function getExportNode(parent2, node) {
-    const declaration = isVariableDeclaration(parent2) ? parent2 : isBindingElement(parent2) ? walkUpBindingElementsAndPatterns(parent2) : void 0;
-    if (declaration) {
-      return parent2.name !== node ? void 0 : isCatchClause(declaration.parent) ? void 0 : isVariableStatement(declaration.parent.parent) ? declaration.parent.parent : void 0;
-    } else {
-      return parent2;
+  function functionSpan(node, body, sourceFile) {
+    const openToken = tryGetFunctionOpenToken(node, body, sourceFile);
+    const closeToken = findChildOfKind(body, 20 /* CloseBraceToken */, sourceFile);
+    return openToken && closeToken && spanBetweenTokens(
+      openToken,
+      closeToken,
+      node,
+      sourceFile,
+      /*autoCollapse*/
+      node.kind !== 219 /* ArrowFunction */
+    );
+  }
+  function spanBetweenTokens(openToken, closeToken, hintSpanNode, sourceFile, autoCollapse = false, useFullStart = true) {
+    const textSpan = createTextSpanFromBounds(useFullStart ? openToken.getFullStart() : openToken.getStart(sourceFile), closeToken.getEnd());
+    return createOutliningSpan(textSpan, "code" /* Code */, createTextSpanFromNode(hintSpanNode, sourceFile), autoCollapse);
+  }
+  function createOutliningSpan(textSpan, kind, hintSpan = textSpan, autoCollapse = false, bannerText = "...") {
+    return { textSpan, kind, hintSpan, bannerText, autoCollapse };
+  }
+  function tryGetFunctionOpenToken(node, body, sourceFile) {
+    if (isNodeArrayMultiLine(node.parameters, sourceFile)) {
+      const openParenToken = findChildOfKind(node, 21 /* OpenParenToken */, sourceFile);
+      if (openParenToken) {
+        return openParenToken;
+      }
     }
+    return findChildOfKind(body, 19 /* OpenBraceToken */, sourceFile);
   }
-  function isNodeImport(node) {
-    const { parent: parent2 } = node;
-    switch (parent2.kind) {
-      case 270 /* ImportEqualsDeclaration */:
-        return parent2.name === node && isExternalModuleImportEquals(parent2);
-      case 275 /* ImportSpecifier */:
-        return !parent2.propertyName;
-      case 272 /* ImportClause */:
-      case 273 /* NamespaceImport */:
-        Debug.assert(parent2.name === node);
-        return true;
-      case 207 /* BindingElement */:
-        return isInJSFile(node) && isVariableDeclarationInitializedToBareOrAccessedRequire(parent2.parent.parent);
-      default:
-        return false;
+  var regionDelimiterRegExp;
+  var init_outliningElementsCollector = __esm({
+    "src/services/outliningElementsCollector.ts"() {
+      "use strict";
+      init_ts4();
+      regionDelimiterRegExp = /^#(end)?region(?:\s+(.*))?(?:\r)?$/;
+    }
+  });
+
+  // src/services/_namespaces/ts.OutliningElementsCollector.ts
+  var ts_OutliningElementsCollector_exports = {};
+  __export(ts_OutliningElementsCollector_exports, {
+    collectElements: () => collectElements
+  });
+  var init_ts_OutliningElementsCollector = __esm({
+    "src/services/_namespaces/ts.OutliningElementsCollector.ts"() {
+      "use strict";
+      init_outliningElementsCollector();
+    }
+  });
+
+  // src/services/rename.ts
+  function getRenameInfo(program, sourceFile, position, preferences) {
+    const node = getAdjustedRenameLocation(getTouchingPropertyName(sourceFile, position));
+    if (nodeIsEligibleForRename(node)) {
+      const renameInfo = getRenameInfoForNode(node, program.getTypeChecker(), sourceFile, program, preferences);
+      if (renameInfo) {
+        return renameInfo;
+      }
     }
+    return getRenameInfoError(Diagnostics.You_cannot_rename_this_element);
   }
-  function getExportInfo(exportSymbol, exportKind, checker) {
-    const moduleSymbol = exportSymbol.parent;
-    if (!moduleSymbol)
+  function getRenameInfoForNode(node, typeChecker, sourceFile, program, preferences) {
+    const symbol = typeChecker.getSymbolAtLocation(node);
+    if (!symbol) {
+      if (isStringLiteralLike(node)) {
+        const type = getContextualTypeFromParentOrAncestorTypeNode(node, typeChecker);
+        if (type && (type.flags & 128 /* StringLiteral */ || type.flags & 1048576 /* Union */ && every(type.types, (type2) => !!(type2.flags & 128 /* StringLiteral */)))) {
+          return getRenameInfoSuccess(node.text, node.text, "string" /* string */, "", node, sourceFile);
+        }
+      } else if (isLabelName(node)) {
+        const name = getTextOfNode(node);
+        return getRenameInfoSuccess(name, name, "label" /* label */, "" /* none */, node, sourceFile);
+      }
       return void 0;
-    const exportingModuleSymbol = checker.getMergedSymbol(moduleSymbol);
-    return isExternalModuleSymbol(exportingModuleSymbol) ? { exportingModuleSymbol, exportKind } : void 0;
+    }
+    const { declarations } = symbol;
+    if (!declarations || declarations.length === 0)
+      return;
+    if (declarations.some((declaration) => isDefinedInLibraryFile(program, declaration))) {
+      return getRenameInfoError(Diagnostics.You_cannot_rename_elements_that_are_defined_in_the_standard_TypeScript_library);
+    }
+    if (isIdentifier(node) && node.escapedText === "default" && symbol.parent && symbol.parent.flags & 1536 /* Module */) {
+      return void 0;
+    }
+    if (isStringLiteralLike(node) && tryGetImportFromModuleSpecifier(node)) {
+      return preferences.allowRenameOfImportPath ? getRenameInfoForModule(node, sourceFile, symbol) : void 0;
+    }
+    const wouldRenameNodeModules = wouldRenameInOtherNodeModules(sourceFile, symbol, typeChecker, preferences);
+    if (wouldRenameNodeModules) {
+      return getRenameInfoError(wouldRenameNodeModules);
+    }
+    const kind = ts_SymbolDisplay_exports.getSymbolKind(typeChecker, symbol, node);
+    const specifierName = isImportOrExportSpecifierName(node) || isStringOrNumericLiteralLike(node) && node.parent.kind === 167 /* ComputedPropertyName */ ? stripQuotes(getTextOfIdentifierOrLiteral(node)) : void 0;
+    const displayName = specifierName || typeChecker.symbolToString(symbol);
+    const fullDisplayName = specifierName || typeChecker.getFullyQualifiedName(symbol);
+    return getRenameInfoSuccess(displayName, fullDisplayName, kind, ts_SymbolDisplay_exports.getSymbolModifiers(typeChecker, symbol), node, sourceFile);
   }
-  function skipExportSpecifierSymbol(symbol, checker) {
-    if (symbol.declarations) {
-      for (const declaration of symbol.declarations) {
-        if (isExportSpecifier(declaration) && !declaration.propertyName && !declaration.parent.parent.moduleSpecifier) {
-          return checker.getExportSpecifierLocalTargetSymbol(declaration) || symbol;
-        } else if (isPropertyAccessExpression(declaration) && isModuleExportsAccessExpression(declaration.expression) && !isPrivateIdentifier(declaration.name)) {
-          return checker.getSymbolAtLocation(declaration);
-        } else if (isShorthandPropertyAssignment(declaration) && isBinaryExpression(declaration.parent.parent) && getAssignmentDeclarationKind(declaration.parent.parent) === 2 /* ModuleExports */) {
-          return checker.getExportSpecifierLocalTargetSymbol(declaration.name);
+  function isDefinedInLibraryFile(program, declaration) {
+    const sourceFile = declaration.getSourceFile();
+    return program.isSourceFileDefaultLibrary(sourceFile) && fileExtensionIs(sourceFile.fileName, ".d.ts" /* Dts */);
+  }
+  function wouldRenameInOtherNodeModules(originalFile, symbol, checker, preferences) {
+    if (!preferences.providePrefixAndSuffixTextForRename && symbol.flags & 2097152 /* Alias */) {
+      const importSpecifier = symbol.declarations && find(symbol.declarations, (decl) => isImportSpecifier(decl));
+      if (importSpecifier && !importSpecifier.propertyName) {
+        symbol = checker.getAliasedSymbol(symbol);
+      }
+    }
+    const { declarations } = symbol;
+    if (!declarations) {
+      return void 0;
+    }
+    const originalPackage = getPackagePathComponents(originalFile.path);
+    if (originalPackage === void 0) {
+      if (some(declarations, (declaration) => isInsideNodeModules(declaration.getSourceFile().path))) {
+        return Diagnostics.You_cannot_rename_elements_that_are_defined_in_a_node_modules_folder;
+      } else {
+        return void 0;
+      }
+    }
+    for (const declaration of declarations) {
+      const declPackage = getPackagePathComponents(declaration.getSourceFile().path);
+      if (declPackage) {
+        const length2 = Math.min(originalPackage.length, declPackage.length);
+        for (let i = 0; i <= length2; i++) {
+          if (compareStringsCaseSensitive(originalPackage[i], declPackage[i]) !== 0 /* EqualTo */) {
+            return Diagnostics.You_cannot_rename_elements_that_are_defined_in_another_node_modules_folder;
+          }
         }
       }
     }
-    return symbol;
-  }
-  function getContainingModuleSymbol(importer, checker) {
-    return checker.getMergedSymbol(getSourceFileLikeForImportDeclaration(importer).symbol);
+    return void 0;
   }
-  function getSourceFileLikeForImportDeclaration(node) {
-    if (node.kind === 212 /* CallExpression */) {
-      return node.getSourceFile();
+  function getPackagePathComponents(filePath) {
+    const components = getPathComponents(filePath);
+    const nodeModulesIdx = components.lastIndexOf("node_modules");
+    if (nodeModulesIdx === -1) {
+      return void 0;
     }
-    const { parent: parent2 } = node;
-    if (parent2.kind === 311 /* SourceFile */) {
-      return parent2;
+    return components.slice(0, nodeModulesIdx + 2);
+  }
+  function getRenameInfoForModule(node, sourceFile, moduleSymbol) {
+    if (!isExternalModuleNameRelative(node.text)) {
+      return getRenameInfoError(Diagnostics.You_cannot_rename_a_module_via_a_global_import);
     }
-    Debug.assert(parent2.kind === 267 /* ModuleBlock */);
-    return cast(parent2.parent, isAmbientModuleDeclaration);
+    const moduleSourceFile = moduleSymbol.declarations && find(moduleSymbol.declarations, isSourceFile);
+    if (!moduleSourceFile)
+      return void 0;
+    const withoutIndex = endsWith(node.text, "/index") || endsWith(node.text, "/index.js") ? void 0 : tryRemoveSuffix(removeFileExtension(moduleSourceFile.fileName), "/index");
+    const name = withoutIndex === void 0 ? moduleSourceFile.fileName : withoutIndex;
+    const kind = withoutIndex === void 0 ? "module" /* moduleElement */ : "directory" /* directory */;
+    const indexAfterLastSlash = node.text.lastIndexOf("/") + 1;
+    const triggerSpan = createTextSpan(node.getStart(sourceFile) + 1 + indexAfterLastSlash, node.text.length - indexAfterLastSlash);
+    return {
+      canRename: true,
+      fileToRename: name,
+      kind,
+      displayName: name,
+      fullDisplayName: name,
+      kindModifiers: "" /* none */,
+      triggerSpan
+    };
   }
-  function isAmbientModuleDeclaration(node) {
-    return node.kind === 266 /* ModuleDeclaration */ && node.name.kind === 11 /* StringLiteral */;
+  function getRenameInfoSuccess(displayName, fullDisplayName, kind, kindModifiers, node, sourceFile) {
+    return {
+      canRename: true,
+      fileToRename: void 0,
+      kind,
+      displayName,
+      fullDisplayName,
+      kindModifiers,
+      triggerSpan: createTriggerSpanForNode(node, sourceFile)
+    };
   }
-  function isExternalModuleImportEquals(eq) {
-    return eq.moduleReference.kind === 282 /* ExternalModuleReference */ && eq.moduleReference.expression.kind === 11 /* StringLiteral */;
+  function getRenameInfoError(diagnostic) {
+    return { canRename: false, localizedErrorMessage: getLocaleSpecificMessage(diagnostic) };
   }
-  var ExportKind2, ImportExport;
-  var init_importTracker = __esm({
-    "src/services/importTracker.ts"() {
+  function createTriggerSpanForNode(node, sourceFile) {
+    let start = node.getStart(sourceFile);
+    let width = node.getWidth(sourceFile);
+    if (isStringLiteralLike(node)) {
+      start += 1;
+      width -= 2;
+    }
+    return createTextSpan(start, width);
+  }
+  function nodeIsEligibleForRename(node) {
+    switch (node.kind) {
+      case 80 /* Identifier */:
+      case 81 /* PrivateIdentifier */:
+      case 11 /* StringLiteral */:
+      case 15 /* NoSubstitutionTemplateLiteral */:
+      case 110 /* ThisKeyword */:
+        return true;
+      case 9 /* NumericLiteral */:
+        return isLiteralNameOfPropertyDeclarationOrIndexAccess(node);
+      default:
+        return false;
+    }
+  }
+  var init_rename = __esm({
+    "src/services/rename.ts"() {
       "use strict";
       init_ts4();
-      ExportKind2 = /* @__PURE__ */ ((ExportKind3) => {
-        ExportKind3[ExportKind3["Named"] = 0] = "Named";
-        ExportKind3[ExportKind3["Default"] = 1] = "Default";
-        ExportKind3[ExportKind3["ExportEquals"] = 2] = "ExportEquals";
-        return ExportKind3;
-      })(ExportKind2 || {});
-      ImportExport = /* @__PURE__ */ ((ImportExport2) => {
-        ImportExport2[ImportExport2["Import"] = 0] = "Import";
-        ImportExport2[ImportExport2["Export"] = 1] = "Export";
-        return ImportExport2;
-      })(ImportExport || {});
     }
   });
 
-  // src/services/findAllReferences.ts
-  function nodeEntry(node, kind = 1 /* Node */) {
-    return {
-      kind,
-      node: node.name || node,
-      context: getContextNodeForNodeEntry(node)
-    };
-  }
-  function isContextWithStartAndEndNode(node) {
-    return node && node.kind === void 0;
-  }
-  function getContextNodeForNodeEntry(node) {
-    if (isDeclaration(node)) {
-      return getContextNode(node);
+  // src/services/_namespaces/ts.Rename.ts
+  var ts_Rename_exports = {};
+  __export(ts_Rename_exports, {
+    getRenameInfo: () => getRenameInfo,
+    nodeIsEligibleForRename: () => nodeIsEligibleForRename
+  });
+  var init_ts_Rename = __esm({
+    "src/services/_namespaces/ts.Rename.ts"() {
+      "use strict";
+      init_rename();
     }
-    if (!node.parent)
+  });
+
+  // src/services/signatureHelp.ts
+  function getSignatureHelpItems(program, sourceFile, position, triggerReason, cancellationToken) {
+    const typeChecker = program.getTypeChecker();
+    const startingToken = findTokenOnLeftOfPosition(sourceFile, position);
+    if (!startingToken) {
       return void 0;
-    if (!isDeclaration(node.parent) && !isExportAssignment(node.parent)) {
-      if (isInJSFile(node)) {
-        const binaryExpression = isBinaryExpression(node.parent) ? node.parent : isAccessExpression(node.parent) && isBinaryExpression(node.parent.parent) && node.parent.parent.left === node.parent ? node.parent.parent : void 0;
-        if (binaryExpression && getAssignmentDeclarationKind(binaryExpression) !== 0 /* None */) {
-          return getContextNode(binaryExpression);
+    }
+    const onlyUseSyntacticOwners = !!triggerReason && triggerReason.kind === "characterTyped";
+    if (onlyUseSyntacticOwners && (isInString(sourceFile, position, startingToken) || isInComment(sourceFile, position))) {
+      return void 0;
+    }
+    const isManuallyInvoked = !!triggerReason && triggerReason.kind === "invoked";
+    const argumentInfo = getContainingArgumentInfo(startingToken, position, sourceFile, typeChecker, isManuallyInvoked);
+    if (!argumentInfo)
+      return void 0;
+    cancellationToken.throwIfCancellationRequested();
+    const candidateInfo = getCandidateOrTypeInfo(argumentInfo, typeChecker, sourceFile, startingToken, onlyUseSyntacticOwners);
+    cancellationToken.throwIfCancellationRequested();
+    if (!candidateInfo) {
+      return isSourceFileJS(sourceFile) ? createJSSignatureHelpItems(argumentInfo, program, cancellationToken) : void 0;
+    }
+    return typeChecker.runWithCancellationToken(cancellationToken, (typeChecker2) => candidateInfo.kind === 0 /* Candidate */ ? createSignatureHelpItems(candidateInfo.candidates, candidateInfo.resolvedSignature, argumentInfo, sourceFile, typeChecker2) : createTypeHelpItems(candidateInfo.symbol, argumentInfo, sourceFile, typeChecker2));
+  }
+  function getCandidateOrTypeInfo({ invocation, argumentCount }, checker, sourceFile, startingToken, onlyUseSyntacticOwners) {
+    switch (invocation.kind) {
+      case 0 /* Call */: {
+        if (onlyUseSyntacticOwners && !isSyntacticOwner(startingToken, invocation.node, sourceFile)) {
+          return void 0;
         }
+        const candidates = [];
+        const resolvedSignature = checker.getResolvedSignatureForSignatureHelp(invocation.node, candidates, argumentCount);
+        return candidates.length === 0 ? void 0 : { kind: 0 /* Candidate */, candidates, resolvedSignature };
       }
-      if (isJsxOpeningElement(node.parent) || isJsxClosingElement(node.parent)) {
-        return node.parent.parent;
-      } else if (isJsxSelfClosingElement(node.parent) || isLabeledStatement(node.parent) || isBreakOrContinueStatement(node.parent)) {
-        return node.parent;
-      } else if (isStringLiteralLike(node)) {
-        const validImport = tryGetImportFromModuleSpecifier(node);
-        if (validImport) {
-          const declOrStatement = findAncestor(
-            validImport,
-            (node2) => isDeclaration(node2) || isStatement(node2) || isJSDocTag(node2)
-          );
-          return isDeclaration(declOrStatement) ? getContextNode(declOrStatement) : declOrStatement;
+      case 1 /* TypeArgs */: {
+        const { called } = invocation;
+        if (onlyUseSyntacticOwners && !containsPrecedingToken(startingToken, sourceFile, isIdentifier(called) ? called.parent : called)) {
+          return void 0;
         }
+        const candidates = getPossibleGenericSignatures(called, argumentCount, checker);
+        if (candidates.length !== 0)
+          return { kind: 0 /* Candidate */, candidates, resolvedSignature: first(candidates) };
+        const symbol = checker.getSymbolAtLocation(called);
+        return symbol && { kind: 1 /* Type */, symbol };
       }
-      const propertyName = findAncestor(node, isComputedPropertyName);
-      return propertyName ? getContextNode(propertyName.parent) : void 0;
-    }
-    if (node.parent.name === node || // node is name of declaration, use parent
-    isConstructorDeclaration(node.parent) || isExportAssignment(node.parent) || // Property name of the import export specifier or binding pattern, use parent
-    (isImportOrExportSpecifier(node.parent) || isBindingElement(node.parent)) && node.parent.propertyName === node || // Is default export
-    node.kind === 90 /* DefaultKeyword */ && hasSyntacticModifier(node.parent, 1025 /* ExportDefault */)) {
-      return getContextNode(node.parent);
+      case 2 /* Contextual */:
+        return { kind: 0 /* Candidate */, candidates: [invocation.signature], resolvedSignature: invocation.signature };
+      default:
+        return Debug.assertNever(invocation);
     }
-    return void 0;
   }
-  function getContextNode(node) {
-    if (!node)
-      return void 0;
-    switch (node.kind) {
-      case 259 /* VariableDeclaration */:
-        return !isVariableDeclarationList(node.parent) || node.parent.declarations.length !== 1 ? node : isVariableStatement(node.parent.parent) ? node.parent.parent : isForInOrOfStatement(node.parent.parent) ? getContextNode(node.parent.parent) : node.parent;
-      case 207 /* BindingElement */:
-        return getContextNode(node.parent.parent);
-      case 275 /* ImportSpecifier */:
-        return node.parent.parent.parent;
-      case 280 /* ExportSpecifier */:
-      case 273 /* NamespaceImport */:
-        return node.parent.parent;
-      case 272 /* ImportClause */:
-      case 279 /* NamespaceExport */:
-        return node.parent;
-      case 225 /* BinaryExpression */:
-        return isExpressionStatement(node.parent) ? node.parent : node;
-      case 249 /* ForOfStatement */:
-      case 248 /* ForInStatement */:
-        return {
-          start: node.initializer,
-          end: node.expression
-        };
-      case 302 /* PropertyAssignment */:
-      case 303 /* ShorthandPropertyAssignment */:
-        return isArrayLiteralOrObjectLiteralDestructuringPattern(node.parent) ? getContextNode(
-          findAncestor(
-            node.parent,
-            (node2) => isBinaryExpression(node2) || isForInOrOfStatement(node2)
-          )
-        ) : node;
+  function isSyntacticOwner(startingToken, node, sourceFile) {
+    if (!isCallOrNewExpression(node))
+      return false;
+    const invocationChildren = node.getChildren(sourceFile);
+    switch (startingToken.kind) {
+      case 21 /* OpenParenToken */:
+        return contains(invocationChildren, startingToken);
+      case 28 /* CommaToken */: {
+        const containingList = findContainingList(startingToken);
+        return !!containingList && contains(invocationChildren, containingList);
+      }
+      case 30 /* LessThanToken */:
+        return containsPrecedingToken(startingToken, sourceFile, node.expression);
       default:
-        return node;
+        return false;
     }
   }
-  function toContextSpan(textSpan, sourceFile, context) {
-    if (!context)
+  function createJSSignatureHelpItems(argumentInfo, program, cancellationToken) {
+    if (argumentInfo.invocation.kind === 2 /* Contextual */)
       return void 0;
-    const contextSpan = isContextWithStartAndEndNode(context) ? getTextSpan(context.start, sourceFile, context.end) : getTextSpan(context, sourceFile);
-    return contextSpan.start !== textSpan.start || contextSpan.length !== textSpan.length ? { contextSpan } : void 0;
-  }
-  function findReferencedSymbols(program, cancellationToken, sourceFiles, sourceFile, position) {
-    const node = getTouchingPropertyName(sourceFile, position);
-    const options = { use: 1 /* References */ };
-    const referencedSymbols = Core.getReferencedSymbolsForNode(position, node, program, sourceFiles, cancellationToken, options);
-    const checker = program.getTypeChecker();
-    const adjustedNode = Core.getAdjustedNode(node, options);
-    const symbol = isDefinitionForReference(adjustedNode) ? checker.getSymbolAtLocation(adjustedNode) : void 0;
-    return !referencedSymbols || !referencedSymbols.length ? void 0 : mapDefined(referencedSymbols, ({ definition, references }) => (
-      // Only include referenced symbols that have a valid definition.
-      definition && {
-        definition: checker.runWithCancellationToken(cancellationToken, (checker2) => definitionToReferencedSymbolDefinitionInfo(definition, checker2, node)),
-        references: references.map((r) => toReferencedSymbolEntry(r, symbol))
+    const expression = getExpressionFromInvocation(argumentInfo.invocation);
+    const name = isPropertyAccessExpression(expression) ? expression.name.text : void 0;
+    const typeChecker = program.getTypeChecker();
+    return name === void 0 ? void 0 : firstDefined(program.getSourceFiles(), (sourceFile) => firstDefined(sourceFile.getNamedDeclarations().get(name), (declaration) => {
+      const type = declaration.symbol && typeChecker.getTypeOfSymbolAtLocation(declaration.symbol, declaration);
+      const callSignatures = type && type.getCallSignatures();
+      if (callSignatures && callSignatures.length) {
+        return typeChecker.runWithCancellationToken(
+          cancellationToken,
+          (typeChecker2) => createSignatureHelpItems(
+            callSignatures,
+            callSignatures[0],
+            argumentInfo,
+            sourceFile,
+            typeChecker2,
+            /*useFullPrefix*/
+            true
+          )
+        );
       }
-    ));
-  }
-  function isDefinitionForReference(node) {
-    return node.kind === 90 /* DefaultKeyword */ || !!getDeclarationFromName(node) || isLiteralComputedPropertyDeclarationName(node) || node.kind === 137 /* ConstructorKeyword */ && isConstructorDeclaration(node.parent);
+    }));
   }
-  function getImplementationsAtPosition(program, cancellationToken, sourceFiles, sourceFile, position) {
-    const node = getTouchingPropertyName(sourceFile, position);
-    let referenceEntries;
-    const entries = getImplementationReferenceEntries(program, cancellationToken, sourceFiles, node, position);
-    if (node.parent.kind === 210 /* PropertyAccessExpression */ || node.parent.kind === 207 /* BindingElement */ || node.parent.kind === 211 /* ElementAccessExpression */ || node.kind === 108 /* SuperKeyword */) {
-      referenceEntries = entries && [...entries];
-    } else if (entries) {
-      const queue = createQueue(entries);
-      const seenNodes = /* @__PURE__ */ new Map();
-      while (!queue.isEmpty()) {
-        const entry = queue.dequeue();
-        if (!addToSeen(seenNodes, getNodeId(entry.node))) {
-          continue;
-        }
-        referenceEntries = append(referenceEntries, entry);
-        const entries2 = getImplementationReferenceEntries(program, cancellationToken, sourceFiles, entry.node, entry.node.pos);
-        if (entries2) {
-          queue.enqueue(...entries2);
-        }
+  function containsPrecedingToken(startingToken, sourceFile, container) {
+    const pos = startingToken.getFullStart();
+    let currentParent = startingToken.parent;
+    while (currentParent) {
+      const precedingToken = findPrecedingToken(
+        pos,
+        sourceFile,
+        currentParent,
+        /*excludeJsdoc*/
+        true
+      );
+      if (precedingToken) {
+        return rangeContainsRange(container, precedingToken);
       }
+      currentParent = currentParent.parent;
     }
-    const checker = program.getTypeChecker();
-    return map(referenceEntries, (entry) => toImplementationLocation(entry, checker));
+    return Debug.fail("Could not find preceding token");
+  }
+  function getArgumentInfoForCompletions(node, position, sourceFile) {
+    const info = getImmediatelyContainingArgumentInfo(node, position, sourceFile);
+    return !info || info.isTypeParameterList || info.invocation.kind !== 0 /* Call */ ? void 0 : { invocation: info.invocation.node, argumentCount: info.argumentCount, argumentIndex: info.argumentIndex };
   }
-  function getImplementationReferenceEntries(program, cancellationToken, sourceFiles, node, position) {
-    if (node.kind === 311 /* SourceFile */) {
+  function getArgumentOrParameterListInfo(node, position, sourceFile) {
+    const info = getArgumentOrParameterListAndIndex(node, sourceFile);
+    if (!info)
       return void 0;
+    const { list, argumentIndex } = info;
+    const argumentCount = getArgumentCount(
+      list,
+      /*ignoreTrailingComma*/
+      isInString(sourceFile, position, node)
+    );
+    if (argumentIndex !== 0) {
+      Debug.assertLessThan(argumentIndex, argumentCount);
     }
-    const checker = program.getTypeChecker();
-    if (node.parent.kind === 303 /* ShorthandPropertyAssignment */) {
-      const result = [];
-      Core.getReferenceEntriesForShorthandPropertyAssignment(node, checker, (node2) => result.push(nodeEntry(node2)));
-      return result;
-    } else if (node.kind === 108 /* SuperKeyword */ || isSuperProperty(node.parent)) {
-      const symbol = checker.getSymbolAtLocation(node);
-      return symbol.valueDeclaration && [nodeEntry(symbol.valueDeclaration)];
+    const argumentsSpan = getApplicableSpanForArguments(list, sourceFile);
+    return { list, argumentIndex, argumentCount, argumentsSpan };
+  }
+  function getArgumentOrParameterListAndIndex(node, sourceFile) {
+    if (node.kind === 30 /* LessThanToken */ || node.kind === 21 /* OpenParenToken */) {
+      return { list: getChildListThatStartsWithOpenerToken(node.parent, node, sourceFile), argumentIndex: 0 };
     } else {
-      return getReferenceEntriesForNode(position, node, program, sourceFiles, cancellationToken, { implementations: true, use: 1 /* References */ });
+      const list = findContainingList(node);
+      return list && { list, argumentIndex: getArgumentIndex(list, node) };
     }
   }
-  function findReferenceOrRenameEntries(program, cancellationToken, sourceFiles, node, position, options, convertEntry) {
-    return map(flattenEntries(Core.getReferencedSymbolsForNode(position, node, program, sourceFiles, cancellationToken, options)), (entry) => convertEntry(entry, node, program.getTypeChecker()));
-  }
-  function getReferenceEntriesForNode(position, node, program, sourceFiles, cancellationToken, options = {}, sourceFilesSet = new Set(sourceFiles.map((f) => f.fileName))) {
-    return flattenEntries(Core.getReferencedSymbolsForNode(position, node, program, sourceFiles, cancellationToken, options, sourceFilesSet));
-  }
-  function flattenEntries(referenceSymbols) {
-    return referenceSymbols && flatMap(referenceSymbols, (r) => r.references);
-  }
-  function definitionToReferencedSymbolDefinitionInfo(def, checker, originalNode) {
-    const info = (() => {
-      switch (def.type) {
-        case 0 /* Symbol */: {
-          const { symbol } = def;
-          const { displayParts: displayParts2, kind: kind2 } = getDefinitionKindAndDisplayParts(symbol, checker, originalNode);
-          const name2 = displayParts2.map((p) => p.text).join("");
-          const declaration = symbol.declarations && firstOrUndefined(symbol.declarations);
-          const node = declaration ? getNameOfDeclaration(declaration) || declaration : originalNode;
-          return {
-            ...getFileAndTextSpanFromNode(node),
-            name: name2,
-            kind: kind2,
-            displayParts: displayParts2,
-            context: getContextNode(declaration)
-          };
-        }
-        case 1 /* Label */: {
-          const { node } = def;
-          return { ...getFileAndTextSpanFromNode(node), name: node.text, kind: "label" /* label */, displayParts: [displayPart(node.text, 17 /* text */)] };
-        }
-        case 2 /* Keyword */: {
-          const { node } = def;
-          const name2 = tokenToString(node.kind);
-          return { ...getFileAndTextSpanFromNode(node), name: name2, kind: "keyword" /* keyword */, displayParts: [{ text: name2, kind: "keyword" /* keyword */ }] };
-        }
-        case 3 /* This */: {
-          const { node } = def;
-          const symbol = checker.getSymbolAtLocation(node);
-          const displayParts2 = symbol && ts_SymbolDisplay_exports.getSymbolDisplayPartsDocumentationAndSymbolKind(
-            checker,
-            symbol,
-            node.getSourceFile(),
-            getContainerNode(node),
-            node
-          ).displayParts || [textPart("this")];
-          return { ...getFileAndTextSpanFromNode(node), name: "this", kind: "var" /* variableElement */, displayParts: displayParts2 };
-        }
-        case 4 /* String */: {
-          const { node } = def;
-          return {
-            ...getFileAndTextSpanFromNode(node),
-            name: node.text,
-            kind: "var" /* variableElement */,
-            displayParts: [displayPart(getTextOfNode(node), 8 /* stringLiteral */)]
-          };
-        }
-        case 5 /* TripleSlashReference */: {
-          return {
-            textSpan: createTextSpanFromRange(def.reference),
-            sourceFile: def.file,
-            name: def.reference.fileName,
-            kind: "string" /* string */,
-            displayParts: [displayPart(`"${def.reference.fileName}"`, 8 /* stringLiteral */)]
-          };
-        }
-        default:
-          return Debug.assertNever(def);
+  function getImmediatelyContainingArgumentInfo(node, position, sourceFile) {
+    const { parent: parent2 } = node;
+    if (isCallOrNewExpression(parent2)) {
+      const invocation = parent2;
+      const info = getArgumentOrParameterListInfo(node, position, sourceFile);
+      if (!info)
+        return void 0;
+      const { list, argumentIndex, argumentCount, argumentsSpan } = info;
+      const isTypeParameterList = !!parent2.typeArguments && parent2.typeArguments.pos === list.pos;
+      return { isTypeParameterList, invocation: { kind: 0 /* Call */, node: invocation }, argumentsSpan, argumentIndex, argumentCount };
+    } else if (isNoSubstitutionTemplateLiteral(node) && isTaggedTemplateExpression(parent2)) {
+      if (isInsideTemplateLiteral(node, position, sourceFile)) {
+        return getArgumentListInfoForTemplate(
+          parent2,
+          /*argumentIndex*/
+          0,
+          sourceFile
+        );
       }
-    })();
-    const { sourceFile, textSpan, name, kind, displayParts, context } = info;
-    return {
-      containerKind: "" /* unknown */,
-      containerName: "",
-      fileName: sourceFile.fileName,
-      kind,
-      name,
-      textSpan,
-      displayParts,
-      ...toContextSpan(textSpan, sourceFile, context)
-    };
+      return void 0;
+    } else if (isTemplateHead(node) && parent2.parent.kind === 215 /* TaggedTemplateExpression */) {
+      const templateExpression = parent2;
+      const tagExpression = templateExpression.parent;
+      Debug.assert(templateExpression.kind === 228 /* TemplateExpression */);
+      const argumentIndex = isInsideTemplateLiteral(node, position, sourceFile) ? 0 : 1;
+      return getArgumentListInfoForTemplate(tagExpression, argumentIndex, sourceFile);
+    } else if (isTemplateSpan(parent2) && isTaggedTemplateExpression(parent2.parent.parent)) {
+      const templateSpan = parent2;
+      const tagExpression = parent2.parent.parent;
+      if (isTemplateTail(node) && !isInsideTemplateLiteral(node, position, sourceFile)) {
+        return void 0;
+      }
+      const spanIndex = templateSpan.parent.templateSpans.indexOf(templateSpan);
+      const argumentIndex = getArgumentIndexForTemplatePiece(spanIndex, node, position, sourceFile);
+      return getArgumentListInfoForTemplate(tagExpression, argumentIndex, sourceFile);
+    } else if (isJsxOpeningLikeElement(parent2)) {
+      const attributeSpanStart = parent2.attributes.pos;
+      const attributeSpanEnd = skipTrivia(
+        sourceFile.text,
+        parent2.attributes.end,
+        /*stopAfterLineBreak*/
+        false
+      );
+      return {
+        isTypeParameterList: false,
+        invocation: { kind: 0 /* Call */, node: parent2 },
+        argumentsSpan: createTextSpan(attributeSpanStart, attributeSpanEnd - attributeSpanStart),
+        argumentIndex: 0,
+        argumentCount: 1
+      };
+    } else {
+      const typeArgInfo = getPossibleTypeArgumentsInfo(node, sourceFile);
+      if (typeArgInfo) {
+        const { called, nTypeArguments } = typeArgInfo;
+        const invocation = { kind: 1 /* TypeArgs */, called };
+        const argumentsSpan = createTextSpanFromBounds(called.getStart(sourceFile), node.end);
+        return { isTypeParameterList: true, invocation, argumentsSpan, argumentIndex: nTypeArguments, argumentCount: nTypeArguments + 1 };
+      }
+      return void 0;
+    }
   }
-  function getFileAndTextSpanFromNode(node) {
-    const sourceFile = node.getSourceFile();
-    return {
-      sourceFile,
-      textSpan: getTextSpan(isComputedPropertyName(node) ? node.expression : node, sourceFile)
-    };
+  function getImmediatelyContainingArgumentOrContextualParameterInfo(node, position, sourceFile, checker) {
+    return tryGetParameterInfo(node, position, sourceFile, checker) || getImmediatelyContainingArgumentInfo(node, position, sourceFile);
   }
-  function getDefinitionKindAndDisplayParts(symbol, checker, node) {
-    const meaning = Core.getIntersectingMeaningFromDeclarations(node, symbol);
-    const enclosingDeclaration = symbol.declarations && firstOrUndefined(symbol.declarations) || node;
-    const { displayParts, symbolKind } = ts_SymbolDisplay_exports.getSymbolDisplayPartsDocumentationAndSymbolKind(checker, symbol, enclosingDeclaration.getSourceFile(), enclosingDeclaration, enclosingDeclaration, meaning);
-    return { displayParts, kind: symbolKind };
+  function getHighestBinary(b) {
+    return isBinaryExpression(b.parent) ? getHighestBinary(b.parent) : b;
   }
-  function toRenameLocation(entry, originalNode, checker, providePrefixAndSuffixText, quotePreference) {
-    return { ...entryToDocumentSpan(entry), ...providePrefixAndSuffixText && getPrefixAndSuffixText(entry, originalNode, checker, quotePreference) };
+  function countBinaryExpressionParameters(b) {
+    return isBinaryExpression(b.left) ? countBinaryExpressionParameters(b.left) + 1 : 2;
   }
-  function toReferencedSymbolEntry(entry, symbol) {
-    const referenceEntry = toReferenceEntry(entry);
-    if (!symbol)
-      return referenceEntry;
-    return {
-      ...referenceEntry,
-      isDefinition: entry.kind !== 0 /* Span */ && isDeclarationOfSymbol(entry.node, symbol)
-    };
+  function tryGetParameterInfo(startingToken, position, sourceFile, checker) {
+    const node = getAdjustedNode(startingToken);
+    if (node === void 0)
+      return void 0;
+    const info = getContextualSignatureLocationInfo(node, sourceFile, position, checker);
+    if (info === void 0)
+      return void 0;
+    const { contextualType, argumentIndex, argumentCount, argumentsSpan } = info;
+    const nonNullableContextualType = contextualType.getNonNullableType();
+    const symbol = nonNullableContextualType.symbol;
+    if (symbol === void 0)
+      return void 0;
+    const signature = lastOrUndefined(nonNullableContextualType.getCallSignatures());
+    if (signature === void 0)
+      return void 0;
+    const invocation = { kind: 2 /* Contextual */, signature, node: startingToken, symbol: chooseBetterSymbol(symbol) };
+    return { isTypeParameterList: false, invocation, argumentsSpan, argumentIndex, argumentCount };
   }
-  function toReferenceEntry(entry) {
-    const documentSpan = entryToDocumentSpan(entry);
-    if (entry.kind === 0 /* Span */) {
-      return { ...documentSpan, isWriteAccess: false };
+  function getAdjustedNode(node) {
+    switch (node.kind) {
+      case 21 /* OpenParenToken */:
+      case 28 /* CommaToken */:
+        return node;
+      default:
+        return findAncestor(node.parent, (n) => isParameter(n) ? true : isBindingElement(n) || isObjectBindingPattern(n) || isArrayBindingPattern(n) ? false : "quit");
     }
-    const { kind, node } = entry;
-    return {
-      ...documentSpan,
-      isWriteAccess: isWriteAccessForReference(node),
-      isInString: kind === 2 /* StringLiteral */ ? true : void 0
-    };
   }
-  function entryToDocumentSpan(entry) {
-    if (entry.kind === 0 /* Span */) {
-      return { textSpan: entry.textSpan, fileName: entry.fileName };
-    } else {
-      const sourceFile = entry.node.getSourceFile();
-      const textSpan = getTextSpan(entry.node, sourceFile);
-      return {
-        textSpan,
-        fileName: sourceFile.fileName,
-        ...toContextSpan(textSpan, sourceFile, entry.context)
-      };
+  function getContextualSignatureLocationInfo(node, sourceFile, position, checker) {
+    const { parent: parent2 } = node;
+    switch (parent2.kind) {
+      case 217 /* ParenthesizedExpression */:
+      case 174 /* MethodDeclaration */:
+      case 218 /* FunctionExpression */:
+      case 219 /* ArrowFunction */:
+        const info = getArgumentOrParameterListInfo(node, position, sourceFile);
+        if (!info)
+          return void 0;
+        const { argumentIndex, argumentCount, argumentsSpan } = info;
+        const contextualType = isMethodDeclaration(parent2) ? checker.getContextualTypeForObjectLiteralElement(parent2) : checker.getContextualType(parent2);
+        return contextualType && { contextualType, argumentIndex, argumentCount, argumentsSpan };
+      case 226 /* BinaryExpression */: {
+        const highestBinary = getHighestBinary(parent2);
+        const contextualType2 = checker.getContextualType(highestBinary);
+        const argumentIndex2 = node.kind === 21 /* OpenParenToken */ ? 0 : countBinaryExpressionParameters(parent2) - 1;
+        const argumentCount2 = countBinaryExpressionParameters(highestBinary);
+        return contextualType2 && { contextualType: contextualType2, argumentIndex: argumentIndex2, argumentCount: argumentCount2, argumentsSpan: createTextSpanFromNode(parent2) };
+      }
+      default:
+        return void 0;
     }
   }
-  function getPrefixAndSuffixText(entry, originalNode, checker, quotePreference) {
-    if (entry.kind !== 0 /* Span */ && isIdentifier(originalNode)) {
-      const { node, kind } = entry;
-      const parent2 = node.parent;
-      const name = originalNode.text;
-      const isShorthandAssignment = isShorthandPropertyAssignment(parent2);
-      if (isShorthandAssignment || isObjectBindingElementWithoutPropertyName(parent2) && parent2.name === node && parent2.dotDotDotToken === void 0) {
-        const prefixColon = { prefixText: name + ": " };
-        const suffixColon = { suffixText: ": " + name };
-        if (kind === 3 /* SearchedLocalFoundProperty */) {
-          return prefixColon;
-        }
-        if (kind === 4 /* SearchedPropertyFoundLocal */) {
-          return suffixColon;
-        }
-        if (isShorthandAssignment) {
-          const grandParent = parent2.parent;
-          if (isObjectLiteralExpression(grandParent) && isBinaryExpression(grandParent.parent) && isModuleExportsAccessExpression(grandParent.parent.left)) {
-            return prefixColon;
-          }
-          return suffixColon;
-        } else {
-          return prefixColon;
-        }
-      } else if (isImportSpecifier(parent2) && !parent2.propertyName) {
-        const originalSymbol = isExportSpecifier(originalNode.parent) ? checker.getExportSpecifierLocalTargetSymbol(originalNode.parent) : checker.getSymbolAtLocation(originalNode);
-        return contains(originalSymbol.declarations, parent2) ? { prefixText: name + " as " } : emptyOptions;
-      } else if (isExportSpecifier(parent2) && !parent2.propertyName) {
-        return originalNode === entry.node || checker.getSymbolAtLocation(originalNode) === checker.getSymbolAtLocation(entry.node) ? { prefixText: name + " as " } : { suffixText: " as " + name };
+  function chooseBetterSymbol(s) {
+    return s.name === "__type" /* Type */ ? firstDefined(s.declarations, (d) => {
+      var _a;
+      return isFunctionTypeNode(d) ? (_a = tryCast(d.parent, canHaveSymbol)) == null ? void 0 : _a.symbol : void 0;
+    }) || s : s;
+  }
+  function getArgumentIndex(argumentsList, node) {
+    let argumentIndex = 0;
+    for (const child of argumentsList.getChildren()) {
+      if (child === node) {
+        break;
+      }
+      if (child.kind !== 28 /* CommaToken */) {
+        argumentIndex++;
       }
     }
-    if (entry.kind !== 0 /* Span */ && isNumericLiteral(entry.node) && isAccessExpression(entry.node.parent)) {
-      const quote2 = getQuoteFromPreference(quotePreference);
-      return { prefixText: quote2, suffixText: quote2 };
-    }
-    return emptyOptions;
+    return argumentIndex;
   }
-  function toImplementationLocation(entry, checker) {
-    const documentSpan = entryToDocumentSpan(entry);
-    if (entry.kind !== 0 /* Span */) {
-      const { node } = entry;
-      return {
-        ...documentSpan,
-        ...implementationKindDisplayParts(node, checker)
-      };
-    } else {
-      return { ...documentSpan, kind: "" /* unknown */, displayParts: [] };
+  function getArgumentCount(argumentsList, ignoreTrailingComma) {
+    const listChildren = argumentsList.getChildren();
+    let argumentCount = countWhere(listChildren, (arg) => arg.kind !== 28 /* CommaToken */);
+    if (!ignoreTrailingComma && listChildren.length > 0 && last(listChildren).kind === 28 /* CommaToken */) {
+      argumentCount++;
     }
+    return argumentCount;
   }
-  function implementationKindDisplayParts(node, checker) {
-    const symbol = checker.getSymbolAtLocation(isDeclaration(node) && node.name ? node.name : node);
-    if (symbol) {
-      return getDefinitionKindAndDisplayParts(symbol, checker, node);
-    } else if (node.kind === 209 /* ObjectLiteralExpression */) {
-      return {
-        kind: "interface" /* interfaceElement */,
-        displayParts: [punctuationPart(21 /* OpenParenToken */), textPart("object literal"), punctuationPart(22 /* CloseParenToken */)]
-      };
-    } else if (node.kind === 230 /* ClassExpression */) {
-      return {
-        kind: "local class" /* localClassElement */,
-        displayParts: [punctuationPart(21 /* OpenParenToken */), textPart("anonymous local class"), punctuationPart(22 /* CloseParenToken */)]
-      };
-    } else {
-      return { kind: getNodeKind(node), displayParts: [] };
+  function getArgumentIndexForTemplatePiece(spanIndex, node, position, sourceFile) {
+    Debug.assert(position >= node.getStart(), "Assumed 'position' could not occur before node.");
+    if (isTemplateLiteralToken(node)) {
+      if (isInsideTemplateLiteral(node, position, sourceFile)) {
+        return 0;
+      }
+      return spanIndex + 2;
     }
+    return spanIndex + 1;
   }
-  function toHighlightSpan(entry) {
-    const documentSpan = entryToDocumentSpan(entry);
-    if (entry.kind === 0 /* Span */) {
-      return {
-        fileName: documentSpan.fileName,
-        span: {
-          textSpan: documentSpan.textSpan,
-          kind: "reference" /* reference */
-        }
-      };
+  function getArgumentListInfoForTemplate(tagExpression, argumentIndex, sourceFile) {
+    const argumentCount = isNoSubstitutionTemplateLiteral(tagExpression.template) ? 1 : tagExpression.template.templateSpans.length + 1;
+    if (argumentIndex !== 0) {
+      Debug.assertLessThan(argumentIndex, argumentCount);
     }
-    const writeAccess = isWriteAccessForReference(entry.node);
-    const span = {
-      textSpan: documentSpan.textSpan,
-      kind: writeAccess ? "writtenReference" /* writtenReference */ : "reference" /* reference */,
-      isInString: entry.kind === 2 /* StringLiteral */ ? true : void 0,
-      ...documentSpan.contextSpan && { contextSpan: documentSpan.contextSpan }
+    return {
+      isTypeParameterList: false,
+      invocation: { kind: 0 /* Call */, node: tagExpression },
+      argumentsSpan: getApplicableSpanForTaggedTemplate(tagExpression, sourceFile),
+      argumentIndex,
+      argumentCount
     };
-    return { fileName: documentSpan.fileName, span };
-  }
-  function getTextSpan(node, sourceFile, endNode2) {
-    let start = node.getStart(sourceFile);
-    let end = (endNode2 || node).getEnd();
-    if (isStringLiteralLike(node) && end - start > 2) {
-      Debug.assert(endNode2 === void 0);
-      start += 1;
-      end -= 1;
-    }
-    return createTextSpanFromBounds(start, end);
-  }
-  function getTextSpanOfEntry(entry) {
-    return entry.kind === 0 /* Span */ ? entry.textSpan : getTextSpan(entry.node, entry.node.getSourceFile());
   }
-  function isWriteAccessForReference(node) {
-    const decl = getDeclarationFromName(node);
-    return !!decl && declarationIsWriteAccess(decl) || node.kind === 90 /* DefaultKeyword */ || isWriteAccess(node);
+  function getApplicableSpanForArguments(argumentsList, sourceFile) {
+    const applicableSpanStart = argumentsList.getFullStart();
+    const applicableSpanEnd = skipTrivia(
+      sourceFile.text,
+      argumentsList.getEnd(),
+      /*stopAfterLineBreak*/
+      false
+    );
+    return createTextSpan(applicableSpanStart, applicableSpanEnd - applicableSpanStart);
   }
-  function isDeclarationOfSymbol(node, target) {
-    var _a;
-    if (!target)
-      return false;
-    const source = getDeclarationFromName(node) || (node.kind === 90 /* DefaultKeyword */ ? node.parent : isLiteralComputedPropertyDeclarationName(node) ? node.parent.parent : node.kind === 137 /* ConstructorKeyword */ && isConstructorDeclaration(node.parent) ? node.parent.parent : void 0);
-    const commonjsSource = source && isBinaryExpression(source) ? source.left : void 0;
-    return !!(source && ((_a = target.declarations) == null ? void 0 : _a.some((d) => d === source || d === commonjsSource)));
+  function getApplicableSpanForTaggedTemplate(taggedTemplate, sourceFile) {
+    const template = taggedTemplate.template;
+    const applicableSpanStart = template.getStart();
+    let applicableSpanEnd = template.getEnd();
+    if (template.kind === 228 /* TemplateExpression */) {
+      const lastSpan = last(template.templateSpans);
+      if (lastSpan.literal.getFullWidth() === 0) {
+        applicableSpanEnd = skipTrivia(
+          sourceFile.text,
+          applicableSpanEnd,
+          /*stopAfterLineBreak*/
+          false
+        );
+      }
+    }
+    return createTextSpan(applicableSpanStart, applicableSpanEnd - applicableSpanStart);
   }
-  function declarationIsWriteAccess(decl) {
-    if (!!(decl.flags & 16777216 /* Ambient */))
-      return true;
-    switch (decl.kind) {
-      case 225 /* BinaryExpression */:
-      case 207 /* BindingElement */:
-      case 262 /* ClassDeclaration */:
-      case 230 /* ClassExpression */:
-      case 90 /* DefaultKeyword */:
-      case 265 /* EnumDeclaration */:
-      case 305 /* EnumMember */:
-      case 280 /* ExportSpecifier */:
-      case 272 /* ImportClause */:
-      case 270 /* ImportEqualsDeclaration */:
-      case 275 /* ImportSpecifier */:
-      case 263 /* InterfaceDeclaration */:
-      case 344 /* JSDocCallbackTag */:
-      case 352 /* JSDocTypedefTag */:
-      case 290 /* JsxAttribute */:
-      case 266 /* ModuleDeclaration */:
-      case 269 /* NamespaceExportDeclaration */:
-      case 273 /* NamespaceImport */:
-      case 279 /* NamespaceExport */:
-      case 168 /* Parameter */:
-      case 303 /* ShorthandPropertyAssignment */:
-      case 264 /* TypeAliasDeclaration */:
-      case 167 /* TypeParameter */:
-        return true;
-      case 302 /* PropertyAssignment */:
-        return !isArrayLiteralOrObjectLiteralDestructuringPattern(decl.parent);
-      case 261 /* FunctionDeclaration */:
-      case 217 /* FunctionExpression */:
-      case 175 /* Constructor */:
-      case 173 /* MethodDeclaration */:
-      case 176 /* GetAccessor */:
-      case 177 /* SetAccessor */:
-        return !!decl.body;
-      case 259 /* VariableDeclaration */:
-      case 171 /* PropertyDeclaration */:
-        return !!decl.initializer || isCatchClause(decl.parent);
-      case 172 /* MethodSignature */:
-      case 170 /* PropertySignature */:
-      case 354 /* JSDocPropertyTag */:
-      case 347 /* JSDocParameterTag */:
-        return false;
-      default:
-        return Debug.failBadSyntaxKind(decl);
+  function getContainingArgumentInfo(node, position, sourceFile, checker, isManuallyInvoked) {
+    for (let n = node; !isSourceFile(n) && (isManuallyInvoked || !isBlock(n)); n = n.parent) {
+      Debug.assert(rangeContainsRange(n.parent, n), "Not a subspan", () => `Child: ${Debug.formatSyntaxKind(n.kind)}, parent: ${Debug.formatSyntaxKind(n.parent.kind)}`);
+      const argumentInfo = getImmediatelyContainingArgumentOrContextualParameterInfo(n, position, sourceFile, checker);
+      if (argumentInfo) {
+        return argumentInfo;
+      }
     }
+    return void 0;
   }
-  var DefinitionKind, EntryKind, FindReferencesUse, Core;
-  var init_findAllReferences = __esm({
-    "src/services/findAllReferences.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_FindAllReferences();
-      DefinitionKind = /* @__PURE__ */ ((DefinitionKind2) => {
-        DefinitionKind2[DefinitionKind2["Symbol"] = 0] = "Symbol";
-        DefinitionKind2[DefinitionKind2["Label"] = 1] = "Label";
-        DefinitionKind2[DefinitionKind2["Keyword"] = 2] = "Keyword";
-        DefinitionKind2[DefinitionKind2["This"] = 3] = "This";
-        DefinitionKind2[DefinitionKind2["String"] = 4] = "String";
-        DefinitionKind2[DefinitionKind2["TripleSlashReference"] = 5] = "TripleSlashReference";
-        return DefinitionKind2;
-      })(DefinitionKind || {});
-      EntryKind = /* @__PURE__ */ ((EntryKind2) => {
-        EntryKind2[EntryKind2["Span"] = 0] = "Span";
-        EntryKind2[EntryKind2["Node"] = 1] = "Node";
-        EntryKind2[EntryKind2["StringLiteral"] = 2] = "StringLiteral";
-        EntryKind2[EntryKind2["SearchedLocalFoundProperty"] = 3] = "SearchedLocalFoundProperty";
-        EntryKind2[EntryKind2["SearchedPropertyFoundLocal"] = 4] = "SearchedPropertyFoundLocal";
-        return EntryKind2;
-      })(EntryKind || {});
-      FindReferencesUse = /* @__PURE__ */ ((FindReferencesUse2) => {
-        FindReferencesUse2[FindReferencesUse2["Other"] = 0] = "Other";
-        FindReferencesUse2[FindReferencesUse2["References"] = 1] = "References";
-        FindReferencesUse2[FindReferencesUse2["Rename"] = 2] = "Rename";
-        return FindReferencesUse2;
-      })(FindReferencesUse || {});
-      ((Core2) => {
-        function getReferencedSymbolsForNode(position, node, program, sourceFiles, cancellationToken, options = {}, sourceFilesSet = new Set(sourceFiles.map((f) => f.fileName))) {
-          var _a, _b, _c;
-          node = getAdjustedNode2(node, options);
-          if (isSourceFile(node)) {
-            const resolvedRef = ts_GoToDefinition_exports.getReferenceAtPosition(node, position, program);
-            if (!(resolvedRef == null ? void 0 : resolvedRef.file)) {
-              return void 0;
-            }
-            const moduleSymbol = program.getTypeChecker().getMergedSymbol(resolvedRef.file.symbol);
-            if (moduleSymbol) {
-              return getReferencedSymbolsForModule(
-                program,
-                moduleSymbol,
-                /*excludeImportTypeOfExportEquals*/
-                false,
-                sourceFiles,
-                sourceFilesSet
-              );
-            }
-            const fileIncludeReasons = program.getFileIncludeReasons();
-            if (!fileIncludeReasons) {
-              return void 0;
-            }
-            return [{
-              definition: { type: 5 /* TripleSlashReference */, reference: resolvedRef.reference, file: node },
-              references: getReferencesForNonModule(resolvedRef.file, fileIncludeReasons, program) || emptyArray
-            }];
-          }
-          if (!options.implementations) {
-            const special = getReferencedSymbolsSpecial(node, sourceFiles, cancellationToken);
-            if (special) {
-              return special;
-            }
-          }
-          const checker = program.getTypeChecker();
-          const symbol = checker.getSymbolAtLocation(isConstructorDeclaration(node) && node.parent.name || node);
-          if (!symbol) {
-            if (!options.implementations && isStringLiteralLike(node)) {
-              if (isModuleSpecifierLike(node)) {
-                const fileIncludeReasons = program.getFileIncludeReasons();
-                const referencedFileName = (_c = (_b = (_a = node.getSourceFile().resolvedModules) == null ? void 0 : _a.get(node.text, getModeForUsageLocation(node.getSourceFile(), node))) == null ? void 0 : _b.resolvedModule) == null ? void 0 : _c.resolvedFileName;
-                const referencedFile = referencedFileName ? program.getSourceFile(referencedFileName) : void 0;
-                if (referencedFile) {
-                  return [{ definition: { type: 4 /* String */, node }, references: getReferencesForNonModule(referencedFile, fileIncludeReasons, program) || emptyArray }];
-                }
-              }
-              return getReferencesForStringLiteral(node, sourceFiles, checker, cancellationToken);
-            }
-            return void 0;
-          }
-          if (symbol.escapedName === "export=" /* ExportEquals */) {
-            return getReferencedSymbolsForModule(
-              program,
-              symbol.parent,
-              /*excludeImportTypeOfExportEquals*/
-              false,
-              sourceFiles,
-              sourceFilesSet
-            );
-          }
-          const moduleReferences = getReferencedSymbolsForModuleIfDeclaredBySourceFile(symbol, program, sourceFiles, cancellationToken, options, sourceFilesSet);
-          if (moduleReferences && !(symbol.flags & 33554432 /* Transient */)) {
-            return moduleReferences;
-          }
-          const aliasedSymbol = getMergedAliasedSymbolOfNamespaceExportDeclaration(node, symbol, checker);
-          const moduleReferencesOfExportTarget = aliasedSymbol && getReferencedSymbolsForModuleIfDeclaredBySourceFile(aliasedSymbol, program, sourceFiles, cancellationToken, options, sourceFilesSet);
-          const references = getReferencedSymbolsForSymbol(symbol, node, sourceFiles, sourceFilesSet, checker, cancellationToken, options);
-          return mergeReferences(program, moduleReferences, references, moduleReferencesOfExportTarget);
-        }
-        Core2.getReferencedSymbolsForNode = getReferencedSymbolsForNode;
-        function getAdjustedNode2(node, options) {
-          if (options.use === 1 /* References */) {
-            node = getAdjustedReferenceLocation(node);
-          } else if (options.use === 2 /* Rename */) {
-            node = getAdjustedRenameLocation(node);
-          }
-          return node;
-        }
-        Core2.getAdjustedNode = getAdjustedNode2;
-        function getReferencesForFileName(fileName, program, sourceFiles, sourceFilesSet = new Set(sourceFiles.map((f) => f.fileName))) {
-          var _a, _b;
-          const moduleSymbol = (_a = program.getSourceFile(fileName)) == null ? void 0 : _a.symbol;
-          if (moduleSymbol) {
-            return ((_b = getReferencedSymbolsForModule(
-              program,
-              moduleSymbol,
-              /*excludeImportTypeOfExportEquals*/
-              false,
-              sourceFiles,
-              sourceFilesSet
-            )[0]) == null ? void 0 : _b.references) || emptyArray;
-          }
-          const fileIncludeReasons = program.getFileIncludeReasons();
-          const referencedFile = program.getSourceFile(fileName);
-          return referencedFile && fileIncludeReasons && getReferencesForNonModule(referencedFile, fileIncludeReasons, program) || emptyArray;
-        }
-        Core2.getReferencesForFileName = getReferencesForFileName;
-        function getReferencesForNonModule(referencedFile, refFileMap, program) {
-          let entries;
-          const references = refFileMap.get(referencedFile.path) || emptyArray;
-          for (const ref of references) {
-            if (isReferencedFile(ref)) {
-              const referencingFile = program.getSourceFileByPath(ref.file);
-              const location = getReferencedFileLocation(program.getSourceFileByPath, ref);
-              if (isReferenceFileLocation(location)) {
-                entries = append(entries, {
-                  kind: 0 /* Span */,
-                  fileName: referencingFile.fileName,
-                  textSpan: createTextSpanFromRange(location)
-                });
-              }
-            }
-          }
-          return entries;
-        }
-        function getMergedAliasedSymbolOfNamespaceExportDeclaration(node, symbol, checker) {
-          if (node.parent && isNamespaceExportDeclaration(node.parent)) {
-            const aliasedSymbol = checker.getAliasedSymbol(symbol);
-            const targetSymbol = checker.getMergedSymbol(aliasedSymbol);
-            if (aliasedSymbol !== targetSymbol) {
-              return targetSymbol;
-            }
-          }
-          return void 0;
-        }
-        function getReferencedSymbolsForModuleIfDeclaredBySourceFile(symbol, program, sourceFiles, cancellationToken, options, sourceFilesSet) {
-          const moduleSourceFile = symbol.flags & 1536 /* Module */ && symbol.declarations && find(symbol.declarations, isSourceFile);
-          if (!moduleSourceFile)
-            return void 0;
-          const exportEquals = symbol.exports.get("export=" /* ExportEquals */);
-          const moduleReferences = getReferencedSymbolsForModule(program, symbol, !!exportEquals, sourceFiles, sourceFilesSet);
-          if (!exportEquals || !sourceFilesSet.has(moduleSourceFile.fileName))
-            return moduleReferences;
-          const checker = program.getTypeChecker();
-          symbol = skipAlias(exportEquals, checker);
-          return mergeReferences(program, moduleReferences, getReferencedSymbolsForSymbol(
-            symbol,
-            /*node*/
-            void 0,
-            sourceFiles,
-            sourceFilesSet,
-            checker,
-            cancellationToken,
-            options
-          ));
-        }
-        function mergeReferences(program, ...referencesToMerge) {
-          let result;
-          for (const references of referencesToMerge) {
-            if (!references || !references.length)
-              continue;
-            if (!result) {
-              result = references;
-              continue;
-            }
-            for (const entry of references) {
-              if (!entry.definition || entry.definition.type !== 0 /* Symbol */) {
-                result.push(entry);
-                continue;
-              }
-              const symbol = entry.definition.symbol;
-              const refIndex = findIndex(result, (ref) => !!ref.definition && ref.definition.type === 0 /* Symbol */ && ref.definition.symbol === symbol);
-              if (refIndex === -1) {
-                result.push(entry);
-                continue;
-              }
-              const reference = result[refIndex];
-              result[refIndex] = {
-                definition: reference.definition,
-                references: reference.references.concat(entry.references).sort((entry1, entry2) => {
-                  const entry1File = getSourceFileIndexOfEntry(program, entry1);
-                  const entry2File = getSourceFileIndexOfEntry(program, entry2);
-                  if (entry1File !== entry2File) {
-                    return compareValues(entry1File, entry2File);
-                  }
-                  const entry1Span = getTextSpanOfEntry(entry1);
-                  const entry2Span = getTextSpanOfEntry(entry2);
-                  return entry1Span.start !== entry2Span.start ? compareValues(entry1Span.start, entry2Span.start) : compareValues(entry1Span.length, entry2Span.length);
-                })
-              };
-            }
-          }
-          return result;
-        }
-        function getSourceFileIndexOfEntry(program, entry) {
-          const sourceFile = entry.kind === 0 /* Span */ ? program.getSourceFile(entry.fileName) : entry.node.getSourceFile();
-          return program.getSourceFiles().indexOf(sourceFile);
-        }
-        function getReferencedSymbolsForModule(program, symbol, excludeImportTypeOfExportEquals, sourceFiles, sourceFilesSet) {
-          Debug.assert(!!symbol.valueDeclaration);
-          const references = mapDefined(findModuleReferences(program, sourceFiles, symbol), (reference) => {
-            if (reference.kind === "import") {
-              const parent2 = reference.literal.parent;
-              if (isLiteralTypeNode(parent2)) {
-                const importType = cast(parent2.parent, isImportTypeNode);
-                if (excludeImportTypeOfExportEquals && !importType.qualifier) {
-                  return void 0;
-                }
-              }
-              return nodeEntry(reference.literal);
-            } else if (reference.kind === "implicit") {
-              const range = reference.literal.text !== externalHelpersModuleNameText && forEachChildRecursively(
-                reference.referencingFile,
-                (n) => !(n.transformFlags & 2 /* ContainsJsx */) ? "skip" : isJsxElement(n) || isJsxSelfClosingElement(n) || isJsxFragment(n) ? n : void 0
-              ) || reference.referencingFile.statements[0] || reference.referencingFile;
-              return nodeEntry(range);
-            } else {
-              return {
-                kind: 0 /* Span */,
-                fileName: reference.referencingFile.fileName,
-                textSpan: createTextSpanFromRange(reference.ref)
-              };
-            }
-          });
-          if (symbol.declarations) {
-            for (const decl of symbol.declarations) {
-              switch (decl.kind) {
-                case 311 /* SourceFile */:
-                  break;
-                case 266 /* ModuleDeclaration */:
-                  if (sourceFilesSet.has(decl.getSourceFile().fileName)) {
-                    references.push(nodeEntry(decl.name));
-                  }
-                  break;
-                default:
-                  Debug.assert(!!(symbol.flags & 33554432 /* Transient */), "Expected a module symbol to be declared by a SourceFile or ModuleDeclaration.");
-              }
-            }
-          }
-          const exported = symbol.exports.get("export=" /* ExportEquals */);
-          if (exported == null ? void 0 : exported.declarations) {
-            for (const decl of exported.declarations) {
-              const sourceFile = decl.getSourceFile();
-              if (sourceFilesSet.has(sourceFile.fileName)) {
-                const node = isBinaryExpression(decl) && isPropertyAccessExpression(decl.left) ? decl.left.expression : isExportAssignment(decl) ? Debug.checkDefined(findChildOfKind(decl, 95 /* ExportKeyword */, sourceFile)) : getNameOfDeclaration(decl) || decl;
-                references.push(nodeEntry(node));
-              }
-            }
-          }
-          return references.length ? [{ definition: { type: 0 /* Symbol */, symbol }, references }] : emptyArray;
-        }
-        function isReadonlyTypeOperator(node) {
-          return node.kind === 148 /* ReadonlyKeyword */ && isTypeOperatorNode(node.parent) && node.parent.operator === 148 /* ReadonlyKeyword */;
-        }
-        function getReferencedSymbolsSpecial(node, sourceFiles, cancellationToken) {
-          if (isTypeKeyword(node.kind)) {
-            if (node.kind === 116 /* VoidKeyword */ && isVoidExpression(node.parent)) {
-              return void 0;
-            }
-            if (node.kind === 148 /* ReadonlyKeyword */ && !isReadonlyTypeOperator(node)) {
-              return void 0;
-            }
-            return getAllReferencesForKeyword(
-              sourceFiles,
-              node.kind,
-              cancellationToken,
-              node.kind === 148 /* ReadonlyKeyword */ ? isReadonlyTypeOperator : void 0
-            );
-          }
-          if (isImportMeta(node.parent) && node.parent.name === node) {
-            return getAllReferencesForImportMeta(sourceFiles, cancellationToken);
-          }
-          if (isStaticModifier(node) && isClassStaticBlockDeclaration(node.parent)) {
-            return [{ definition: { type: 2 /* Keyword */, node }, references: [nodeEntry(node)] }];
-          }
-          if (isJumpStatementTarget(node)) {
-            const labelDefinition = getTargetLabel(node.parent, node.text);
-            return labelDefinition && getLabelReferencesInNode(labelDefinition.parent, labelDefinition);
-          } else if (isLabelOfLabeledStatement(node)) {
-            return getLabelReferencesInNode(node.parent, node);
-          }
-          if (isThis(node)) {
-            return getReferencesForThisKeyword(node, sourceFiles, cancellationToken);
-          }
-          if (node.kind === 108 /* SuperKeyword */) {
-            return getReferencesForSuperKeyword(node);
-          }
-          return void 0;
-        }
-        function getReferencedSymbolsForSymbol(originalSymbol, node, sourceFiles, sourceFilesSet, checker, cancellationToken, options) {
-          const symbol = node && skipPastExportOrImportSpecifierOrUnion(
-            originalSymbol,
-            node,
-            checker,
-            /*useLocalSymbolForExportSpecifier*/
-            !isForRenameWithPrefixAndSuffixText(options)
-          ) || originalSymbol;
-          const searchMeaning = node ? getIntersectingMeaningFromDeclarations(node, symbol) : 7 /* All */;
-          const result = [];
-          const state = new State(sourceFiles, sourceFilesSet, node ? getSpecialSearchKind(node) : 0 /* None */, checker, cancellationToken, searchMeaning, options, result);
-          const exportSpecifier = !isForRenameWithPrefixAndSuffixText(options) || !symbol.declarations ? void 0 : find(symbol.declarations, isExportSpecifier);
-          if (exportSpecifier) {
-            getReferencesAtExportSpecifier(
-              exportSpecifier.name,
-              symbol,
-              exportSpecifier,
-              state.createSearch(
-                node,
-                originalSymbol,
-                /*comingFrom*/
-                void 0
-              ),
-              state,
-              /*addReferencesHere*/
-              true,
-              /*alwaysGetReferences*/
-              true
-            );
-          } else if (node && node.kind === 90 /* DefaultKeyword */ && symbol.escapedName === "default" /* Default */ && symbol.parent) {
-            addReference(node, symbol, state);
-            searchForImportsOfExport(node, symbol, { exportingModuleSymbol: symbol.parent, exportKind: 1 /* Default */ }, state);
-          } else {
-            const search = state.createSearch(
-              node,
-              symbol,
-              /*comingFrom*/
-              void 0,
-              { allSearchSymbols: node ? populateSearchSymbolSet(symbol, node, checker, options.use === 2 /* Rename */, !!options.providePrefixAndSuffixTextForRename, !!options.implementations) : [symbol] }
-            );
-            getReferencesInContainerOrFiles(symbol, state, search);
-          }
-          return result;
-        }
-        function getReferencesInContainerOrFiles(symbol, state, search) {
-          const scope = getSymbolScope(symbol);
-          if (scope) {
-            getReferencesInContainer(
-              scope,
-              scope.getSourceFile(),
-              search,
-              state,
-              /*addReferencesHere*/
-              !(isSourceFile(scope) && !contains(state.sourceFiles, scope))
-            );
-          } else {
-            for (const sourceFile of state.sourceFiles) {
-              state.cancellationToken.throwIfCancellationRequested();
-              searchForName(sourceFile, search, state);
-            }
-          }
-        }
-        function getSpecialSearchKind(node) {
-          switch (node.kind) {
-            case 175 /* Constructor */:
-            case 137 /* ConstructorKeyword */:
-              return 1 /* Constructor */;
-            case 80 /* Identifier */:
-              if (isClassLike(node.parent)) {
-                Debug.assert(node.parent.name === node);
-                return 2 /* Class */;
-              }
-            default:
-              return 0 /* None */;
-          }
-        }
-        function skipPastExportOrImportSpecifierOrUnion(symbol, node, checker, useLocalSymbolForExportSpecifier) {
-          const { parent: parent2 } = node;
-          if (isExportSpecifier(parent2) && useLocalSymbolForExportSpecifier) {
-            return getLocalSymbolForExportSpecifier(node, symbol, parent2, checker);
-          }
-          return firstDefined(symbol.declarations, (decl) => {
-            if (!decl.parent) {
-              if (symbol.flags & 33554432 /* Transient */)
-                return void 0;
-              Debug.fail(`Unexpected symbol at ${Debug.formatSyntaxKind(node.kind)}: ${Debug.formatSymbol(symbol)}`);
-            }
-            return isTypeLiteralNode(decl.parent) && isUnionTypeNode(decl.parent.parent) ? checker.getPropertyOfType(checker.getTypeFromTypeNode(decl.parent.parent), symbol.name) : void 0;
-          });
-        }
-        let SpecialSearchKind;
-        ((SpecialSearchKind2) => {
-          SpecialSearchKind2[SpecialSearchKind2["None"] = 0] = "None";
-          SpecialSearchKind2[SpecialSearchKind2["Constructor"] = 1] = "Constructor";
-          SpecialSearchKind2[SpecialSearchKind2["Class"] = 2] = "Class";
-        })(SpecialSearchKind || (SpecialSearchKind = {}));
-        function getNonModuleSymbolOfMergedModuleSymbol(symbol) {
-          if (!(symbol.flags & (1536 /* Module */ | 33554432 /* Transient */)))
-            return void 0;
-          const decl = symbol.declarations && find(symbol.declarations, (d) => !isSourceFile(d) && !isModuleDeclaration(d));
-          return decl && decl.symbol;
-        }
-        class State {
-          constructor(sourceFiles, sourceFilesSet, specialSearchKind, checker, cancellationToken, searchMeaning, options, result) {
-            this.sourceFiles = sourceFiles;
-            this.sourceFilesSet = sourceFilesSet;
-            this.specialSearchKind = specialSearchKind;
-            this.checker = checker;
-            this.cancellationToken = cancellationToken;
-            this.searchMeaning = searchMeaning;
-            this.options = options;
-            this.result = result;
-            /** Cache for `explicitlyinheritsFrom`. */
-            this.inheritsFromCache = /* @__PURE__ */ new Map();
-            /**
-             * Type nodes can contain multiple references to the same type. For example:
-             *      let x: Foo & (Foo & Bar) = ...
-             * Because we are returning the implementation locations and not the identifier locations,
-             * duplicate entries would be returned here as each of the type references is part of
-             * the same implementation. For that reason, check before we add a new entry.
-             */
-            this.markSeenContainingTypeReference = nodeSeenTracker();
-            /**
-             * It's possible that we will encounter the right side of `export { foo as bar } from "x";` more than once.
-             * For example:
-             *     // b.ts
-             *     export { foo as bar } from "./a";
-             *     import { bar } from "./b";
-             *
-             * Normally at `foo as bar` we directly add `foo` and do not locally search for it (since it doesn't declare a local).
-             * But another reference to it may appear in the same source file.
-             * See `tests/cases/fourslash/transitiveExportImports3.ts`.
-             */
-            this.markSeenReExportRHS = nodeSeenTracker();
-            this.symbolIdToReferences = [];
-            // Source file ID -> symbol ID -> Whether the symbol has been searched for in the source file.
-            this.sourceFileToSeenSymbols = [];
-          }
-          includesSourceFile(sourceFile) {
-            return this.sourceFilesSet.has(sourceFile.fileName);
-          }
-          /** Gets every place to look for references of an exported symbols. See `ImportsResult` in `importTracker.ts` for more documentation. */
-          getImportSearches(exportSymbol, exportInfo) {
-            if (!this.importTracker)
-              this.importTracker = createImportTracker(this.sourceFiles, this.sourceFilesSet, this.checker, this.cancellationToken);
-            return this.importTracker(exportSymbol, exportInfo, this.options.use === 2 /* Rename */);
-          }
-          /** @param allSearchSymbols set of additional symbols for use by `includes`. */
-          createSearch(location, symbol, comingFrom, searchOptions = {}) {
-            const {
-              text = stripQuotes(symbolName(getLocalSymbolForExportDefault(symbol) || getNonModuleSymbolOfMergedModuleSymbol(symbol) || symbol)),
-              allSearchSymbols = [symbol]
-            } = searchOptions;
-            const escapedText = escapeLeadingUnderscores(text);
-            const parents = this.options.implementations && location ? getParentSymbolsOfPropertyAccess(location, symbol, this.checker) : void 0;
-            return { symbol, comingFrom, text, escapedText, parents, allSearchSymbols, includes: (sym) => contains(allSearchSymbols, sym) };
-          }
-          /**
-           * Callback to add references for a particular searched symbol.
-           * This initializes a reference group, so only call this if you will add at least one reference.
-           */
-          referenceAdder(searchSymbol) {
-            const symbolId = getSymbolId(searchSymbol);
-            let references = this.symbolIdToReferences[symbolId];
-            if (!references) {
-              references = this.symbolIdToReferences[symbolId] = [];
-              this.result.push({ definition: { type: 0 /* Symbol */, symbol: searchSymbol }, references });
-            }
-            return (node, kind) => references.push(nodeEntry(node, kind));
-          }
-          /** Add a reference with no associated definition. */
-          addStringOrCommentReference(fileName, textSpan) {
-            this.result.push({
-              definition: void 0,
-              references: [{ kind: 0 /* Span */, fileName, textSpan }]
-            });
-          }
-          /** Returns `true` the first time we search for a symbol in a file and `false` afterwards. */
-          markSearchedSymbols(sourceFile, symbols) {
-            const sourceId = getNodeId(sourceFile);
-            const seenSymbols = this.sourceFileToSeenSymbols[sourceId] || (this.sourceFileToSeenSymbols[sourceId] = /* @__PURE__ */ new Set());
-            let anyNewSymbols = false;
-            for (const sym of symbols) {
-              anyNewSymbols = tryAddToSet(seenSymbols, getSymbolId(sym)) || anyNewSymbols;
-            }
-            return anyNewSymbols;
-          }
-        }
-        function searchForImportsOfExport(exportLocation, exportSymbol, exportInfo, state) {
-          const { importSearches, singleReferences, indirectUsers } = state.getImportSearches(exportSymbol, exportInfo);
-          if (singleReferences.length) {
-            const addRef = state.referenceAdder(exportSymbol);
-            for (const singleRef of singleReferences) {
-              if (shouldAddSingleReference(singleRef, state))
-                addRef(singleRef);
-            }
-          }
-          for (const [importLocation, importSymbol] of importSearches) {
-            getReferencesInSourceFile(importLocation.getSourceFile(), state.createSearch(importLocation, importSymbol, 1 /* Export */), state);
-          }
-          if (indirectUsers.length) {
-            let indirectSearch;
-            switch (exportInfo.exportKind) {
-              case 0 /* Named */:
-                indirectSearch = state.createSearch(exportLocation, exportSymbol, 1 /* Export */);
-                break;
-              case 1 /* Default */:
-                indirectSearch = state.options.use === 2 /* Rename */ ? void 0 : state.createSearch(exportLocation, exportSymbol, 1 /* Export */, { text: "default" });
-                break;
-              case 2 /* ExportEquals */:
-                break;
-            }
-            if (indirectSearch) {
-              for (const indirectUser of indirectUsers) {
-                searchForName(indirectUser, indirectSearch, state);
-              }
-            }
-          }
-        }
-        function eachExportReference(sourceFiles, checker, cancellationToken, exportSymbol, exportingModuleSymbol, exportName, isDefaultExport, cb) {
-          const importTracker = createImportTracker(sourceFiles, new Set(sourceFiles.map((f) => f.fileName)), checker, cancellationToken);
-          const { importSearches, indirectUsers, singleReferences } = importTracker(
-            exportSymbol,
-            { exportKind: isDefaultExport ? 1 /* Default */ : 0 /* Named */, exportingModuleSymbol },
-            /*isForRename*/
-            false
-          );
-          for (const [importLocation] of importSearches) {
-            cb(importLocation);
-          }
-          for (const singleReference of singleReferences) {
-            if (isIdentifier(singleReference) && isImportTypeNode(singleReference.parent)) {
-              cb(singleReference);
-            }
-          }
-          for (const indirectUser of indirectUsers) {
-            for (const node of getPossibleSymbolReferenceNodes(indirectUser, isDefaultExport ? "default" : exportName)) {
-              const symbol = checker.getSymbolAtLocation(node);
-              const hasExportAssignmentDeclaration = some(symbol == null ? void 0 : symbol.declarations, (d) => tryCast(d, isExportAssignment) ? true : false);
-              if (isIdentifier(node) && !isImportOrExportSpecifier(node.parent) && (symbol === exportSymbol || hasExportAssignmentDeclaration)) {
-                cb(node);
-              }
-            }
-          }
-        }
-        Core2.eachExportReference = eachExportReference;
-        function shouldAddSingleReference(singleRef, state) {
-          if (!hasMatchingMeaning(singleRef, state))
-            return false;
-          if (state.options.use !== 2 /* Rename */)
-            return true;
-          if (!isIdentifier(singleRef))
-            return false;
-          return !(isImportOrExportSpecifier(singleRef.parent) && singleRef.escapedText === "default" /* Default */);
-        }
-        function searchForImportedSymbol(symbol, state) {
-          if (!symbol.declarations)
-            return;
-          for (const declaration of symbol.declarations) {
-            const exportingFile = declaration.getSourceFile();
-            getReferencesInSourceFile(exportingFile, state.createSearch(declaration, symbol, 0 /* Import */), state, state.includesSourceFile(exportingFile));
-          }
-        }
-        function searchForName(sourceFile, search, state) {
-          if (getNameTable(sourceFile).get(search.escapedText) !== void 0) {
-            getReferencesInSourceFile(sourceFile, search, state);
-          }
-        }
-        function getPropertySymbolOfDestructuringAssignment(location, checker) {
-          return isArrayLiteralOrObjectLiteralDestructuringPattern(location.parent.parent) ? checker.getPropertySymbolOfDestructuringAssignment(location) : void 0;
-        }
-        function getSymbolScope(symbol) {
-          const { declarations, flags, parent: parent2, valueDeclaration } = symbol;
-          if (valueDeclaration && (valueDeclaration.kind === 217 /* FunctionExpression */ || valueDeclaration.kind === 230 /* ClassExpression */)) {
-            return valueDeclaration;
-          }
-          if (!declarations) {
-            return void 0;
-          }
-          if (flags & (4 /* Property */ | 8192 /* Method */)) {
-            const privateDeclaration = find(declarations, (d) => hasEffectiveModifier(d, 8 /* Private */) || isPrivateIdentifierClassElementDeclaration(d));
-            if (privateDeclaration) {
-              return getAncestor(privateDeclaration, 262 /* ClassDeclaration */);
+  function getChildListThatStartsWithOpenerToken(parent2, openerToken, sourceFile) {
+    const children = parent2.getChildren(sourceFile);
+    const indexOfOpenerToken = children.indexOf(openerToken);
+    Debug.assert(indexOfOpenerToken >= 0 && children.length > indexOfOpenerToken + 1);
+    return children[indexOfOpenerToken + 1];
+  }
+  function getExpressionFromInvocation(invocation) {
+    return invocation.kind === 0 /* Call */ ? getInvokedExpression(invocation.node) : invocation.called;
+  }
+  function getEnclosingDeclarationFromInvocation(invocation) {
+    return invocation.kind === 0 /* Call */ ? invocation.node : invocation.kind === 1 /* TypeArgs */ ? invocation.called : invocation.node;
+  }
+  function createSignatureHelpItems(candidates, resolvedSignature, { isTypeParameterList, argumentCount, argumentsSpan: applicableSpan, invocation, argumentIndex }, sourceFile, typeChecker, useFullPrefix) {
+    var _a;
+    const enclosingDeclaration = getEnclosingDeclarationFromInvocation(invocation);
+    const callTargetSymbol = invocation.kind === 2 /* Contextual */ ? invocation.symbol : typeChecker.getSymbolAtLocation(getExpressionFromInvocation(invocation)) || useFullPrefix && ((_a = resolvedSignature.declaration) == null ? void 0 : _a.symbol);
+    const callTargetDisplayParts = callTargetSymbol ? symbolToDisplayParts(
+      typeChecker,
+      callTargetSymbol,
+      useFullPrefix ? sourceFile : void 0,
+      /*meaning*/
+      void 0
+    ) : emptyArray;
+    const items = map(candidates, (candidateSignature) => getSignatureHelpItem(candidateSignature, callTargetDisplayParts, isTypeParameterList, typeChecker, enclosingDeclaration, sourceFile));
+    if (argumentIndex !== 0) {
+      Debug.assertLessThan(argumentIndex, argumentCount);
+    }
+    let selectedItemIndex = 0;
+    let itemsSeen = 0;
+    for (let i = 0; i < items.length; i++) {
+      const item = items[i];
+      if (candidates[i] === resolvedSignature) {
+        selectedItemIndex = itemsSeen;
+        if (item.length > 1) {
+          let count = 0;
+          for (const i2 of item) {
+            if (i2.isVariadic || i2.parameters.length >= argumentCount) {
+              selectedItemIndex = itemsSeen + count;
+              break;
             }
-            return void 0;
+            count++;
           }
-          if (declarations.some(isObjectBindingElementWithoutPropertyName)) {
-            return void 0;
+        }
+      }
+      itemsSeen += item.length;
+    }
+    Debug.assert(selectedItemIndex !== -1);
+    const help = { items: flatMapToMutable(items, identity), applicableSpan, selectedItemIndex, argumentIndex, argumentCount };
+    const selected = help.items[selectedItemIndex];
+    if (selected.isVariadic) {
+      const firstRest = findIndex(selected.parameters, (p) => !!p.isRest);
+      if (-1 < firstRest && firstRest < selected.parameters.length - 1) {
+        help.argumentIndex = selected.parameters.length;
+      } else {
+        help.argumentIndex = Math.min(help.argumentIndex, selected.parameters.length - 1);
+      }
+    }
+    return help;
+  }
+  function createTypeHelpItems(symbol, { argumentCount, argumentsSpan: applicableSpan, invocation, argumentIndex }, sourceFile, checker) {
+    const typeParameters = checker.getLocalTypeParametersOfClassOrInterfaceOrTypeAlias(symbol);
+    if (!typeParameters)
+      return void 0;
+    const items = [getTypeHelpItem(symbol, typeParameters, checker, getEnclosingDeclarationFromInvocation(invocation), sourceFile)];
+    return { items, applicableSpan, selectedItemIndex: 0, argumentIndex, argumentCount };
+  }
+  function getTypeHelpItem(symbol, typeParameters, checker, enclosingDeclaration, sourceFile) {
+    const typeSymbolDisplay = symbolToDisplayParts(checker, symbol);
+    const printer = createPrinterWithRemoveComments();
+    const parameters = typeParameters.map((t) => createSignatureHelpParameterForTypeParameter(t, checker, enclosingDeclaration, sourceFile, printer));
+    const documentation = symbol.getDocumentationComment(checker);
+    const tags = symbol.getJsDocTags(checker);
+    const prefixDisplayParts = [...typeSymbolDisplay, punctuationPart(30 /* LessThanToken */)];
+    return { isVariadic: false, prefixDisplayParts, suffixDisplayParts: [punctuationPart(32 /* GreaterThanToken */)], separatorDisplayParts, parameters, documentation, tags };
+  }
+  function getSignatureHelpItem(candidateSignature, callTargetDisplayParts, isTypeParameterList, checker, enclosingDeclaration, sourceFile) {
+    const infos = (isTypeParameterList ? itemInfoForTypeParameters : itemInfoForParameters)(candidateSignature, checker, enclosingDeclaration, sourceFile);
+    return map(infos, ({ isVariadic, parameters, prefix, suffix }) => {
+      const prefixDisplayParts = [...callTargetDisplayParts, ...prefix];
+      const suffixDisplayParts = [...suffix, ...returnTypeToDisplayParts(candidateSignature, enclosingDeclaration, checker)];
+      const documentation = candidateSignature.getDocumentationComment(checker);
+      const tags = candidateSignature.getJsDocTags();
+      return { isVariadic, prefixDisplayParts, suffixDisplayParts, separatorDisplayParts, parameters, documentation, tags };
+    });
+  }
+  function returnTypeToDisplayParts(candidateSignature, enclosingDeclaration, checker) {
+    return mapToDisplayParts((writer) => {
+      writer.writePunctuation(":");
+      writer.writeSpace(" ");
+      const predicate = checker.getTypePredicateOfSignature(candidateSignature);
+      if (predicate) {
+        checker.writeTypePredicate(
+          predicate,
+          enclosingDeclaration,
+          /*flags*/
+          void 0,
+          writer
+        );
+      } else {
+        checker.writeType(
+          checker.getReturnTypeOfSignature(candidateSignature),
+          enclosingDeclaration,
+          /*flags*/
+          void 0,
+          writer
+        );
+      }
+    });
+  }
+  function itemInfoForTypeParameters(candidateSignature, checker, enclosingDeclaration, sourceFile) {
+    const typeParameters = (candidateSignature.target || candidateSignature).typeParameters;
+    const printer = createPrinterWithRemoveComments();
+    const parameters = (typeParameters || emptyArray).map((t) => createSignatureHelpParameterForTypeParameter(t, checker, enclosingDeclaration, sourceFile, printer));
+    const thisParameter = candidateSignature.thisParameter ? [checker.symbolToParameterDeclaration(candidateSignature.thisParameter, enclosingDeclaration, signatureHelpNodeBuilderFlags)] : [];
+    return checker.getExpandedParameters(candidateSignature).map((paramList) => {
+      const params = factory.createNodeArray([...thisParameter, ...map(paramList, (param) => checker.symbolToParameterDeclaration(param, enclosingDeclaration, signatureHelpNodeBuilderFlags))]);
+      const parameterParts = mapToDisplayParts((writer) => {
+        printer.writeList(2576 /* CallExpressionArguments */, params, sourceFile, writer);
+      });
+      return { isVariadic: false, parameters, prefix: [punctuationPart(30 /* LessThanToken */)], suffix: [punctuationPart(32 /* GreaterThanToken */), ...parameterParts] };
+    });
+  }
+  function itemInfoForParameters(candidateSignature, checker, enclosingDeclaration, sourceFile) {
+    const printer = createPrinterWithRemoveComments();
+    const typeParameterParts = mapToDisplayParts((writer) => {
+      if (candidateSignature.typeParameters && candidateSignature.typeParameters.length) {
+        const args = factory.createNodeArray(candidateSignature.typeParameters.map((p) => checker.typeParameterToDeclaration(p, enclosingDeclaration, signatureHelpNodeBuilderFlags)));
+        printer.writeList(53776 /* TypeParameters */, args, sourceFile, writer);
+      }
+    });
+    const lists = checker.getExpandedParameters(candidateSignature);
+    const isVariadic = !checker.hasEffectiveRestParameter(candidateSignature) ? (_) => false : lists.length === 1 ? (_) => true : (pList) => {
+      var _a;
+      return !!(pList.length && ((_a = tryCast(pList[pList.length - 1], isTransientSymbol)) == null ? void 0 : _a.links.checkFlags) & 32768 /* RestParameter */);
+    };
+    return lists.map((parameterList) => ({
+      isVariadic: isVariadic(parameterList),
+      parameters: parameterList.map((p) => createSignatureHelpParameterForParameter(p, checker, enclosingDeclaration, sourceFile, printer)),
+      prefix: [...typeParameterParts, punctuationPart(21 /* OpenParenToken */)],
+      suffix: [punctuationPart(22 /* CloseParenToken */)]
+    }));
+  }
+  function createSignatureHelpParameterForParameter(parameter, checker, enclosingDeclaration, sourceFile, printer) {
+    const displayParts = mapToDisplayParts((writer) => {
+      const param = checker.symbolToParameterDeclaration(parameter, enclosingDeclaration, signatureHelpNodeBuilderFlags);
+      printer.writeNode(4 /* Unspecified */, param, sourceFile, writer);
+    });
+    const isOptional = checker.isOptionalParameter(parameter.valueDeclaration);
+    const isRest = isTransientSymbol(parameter) && !!(parameter.links.checkFlags & 32768 /* RestParameter */);
+    return { name: parameter.name, documentation: parameter.getDocumentationComment(checker), displayParts, isOptional, isRest };
+  }
+  function createSignatureHelpParameterForTypeParameter(typeParameter, checker, enclosingDeclaration, sourceFile, printer) {
+    const displayParts = mapToDisplayParts((writer) => {
+      const param = checker.typeParameterToDeclaration(typeParameter, enclosingDeclaration, signatureHelpNodeBuilderFlags);
+      printer.writeNode(4 /* Unspecified */, param, sourceFile, writer);
+    });
+    return { name: typeParameter.symbol.name, documentation: typeParameter.symbol.getDocumentationComment(checker), displayParts, isOptional: false, isRest: false };
+  }
+  var signatureHelpNodeBuilderFlags, separatorDisplayParts;
+  var init_signatureHelp = __esm({
+    "src/services/signatureHelp.ts"() {
+      "use strict";
+      init_ts4();
+      signatureHelpNodeBuilderFlags = 8192 /* OmitParameterModifiers */ | 70221824 /* IgnoreErrors */ | 16384 /* UseAliasDefinedOutsideCurrentScope */;
+      separatorDisplayParts = [punctuationPart(28 /* CommaToken */), spacePart()];
+    }
+  });
+
+  // src/services/_namespaces/ts.SignatureHelp.ts
+  var ts_SignatureHelp_exports = {};
+  __export(ts_SignatureHelp_exports, {
+    getArgumentInfoForCompletions: () => getArgumentInfoForCompletions,
+    getSignatureHelpItems: () => getSignatureHelpItems
+  });
+  var init_ts_SignatureHelp = __esm({
+    "src/services/_namespaces/ts.SignatureHelp.ts"() {
+      "use strict";
+      init_signatureHelp();
+    }
+  });
+
+  // src/services/smartSelection.ts
+  function getSmartSelectionRange(pos, sourceFile) {
+    var _a, _b;
+    let selectionRange = {
+      textSpan: createTextSpanFromBounds(sourceFile.getFullStart(), sourceFile.getEnd())
+    };
+    let parentNode = sourceFile;
+    outer:
+      while (true) {
+        const children = getSelectionChildren(parentNode);
+        if (!children.length)
+          break;
+        for (let i = 0; i < children.length; i++) {
+          const prevNode = children[i - 1];
+          const node = children[i];
+          const nextNode = children[i + 1];
+          if (getTokenPosOfNode(
+            node,
+            sourceFile,
+            /*includeJsDoc*/
+            true
+          ) > pos) {
+            break outer;
           }
-          const exposedByParent = parent2 && !(symbol.flags & 262144 /* TypeParameter */);
-          if (exposedByParent && !(isExternalModuleSymbol(parent2) && !parent2.globalExports)) {
-            return void 0;
+          const comment = singleOrUndefined(getTrailingCommentRanges(sourceFile.text, node.end));
+          if (comment && comment.kind === 2 /* SingleLineCommentTrivia */) {
+            pushSelectionCommentRange(comment.pos, comment.end);
           }
-          let scope;
-          for (const declaration of declarations) {
-            const container = getContainerNode(declaration);
-            if (scope && scope !== container) {
-              return void 0;
-            }
-            if (!container || container.kind === 311 /* SourceFile */ && !isExternalOrCommonJsModule(container)) {
-              return void 0;
-            }
-            scope = container;
-            if (isFunctionExpression(scope)) {
-              let next;
-              while (next = getNextJSDocCommentLocation(scope)) {
-                scope = next;
-              }
+          if (positionShouldSnapToNode(sourceFile, pos, node)) {
+            if (isFunctionBody(node) && isFunctionLikeDeclaration(parentNode) && !positionsAreOnSameLine(node.getStart(sourceFile), node.getEnd(), sourceFile)) {
+              pushSelectionRange(node.getStart(sourceFile), node.getEnd());
             }
-          }
-          return exposedByParent ? scope.getSourceFile() : scope;
-        }
-        function isSymbolReferencedInFile(definition, checker, sourceFile, searchContainer = sourceFile) {
-          return eachSymbolReferenceInFile(definition, checker, sourceFile, () => true, searchContainer) || false;
-        }
-        Core2.isSymbolReferencedInFile = isSymbolReferencedInFile;
-        function eachSymbolReferenceInFile(definition, checker, sourceFile, cb, searchContainer = sourceFile) {
-          const symbol = isParameterPropertyDeclaration(definition.parent, definition.parent.parent) ? first(checker.getSymbolsOfParameterPropertyDeclaration(definition.parent, definition.text)) : checker.getSymbolAtLocation(definition);
-          if (!symbol)
-            return void 0;
-          for (const token of getPossibleSymbolReferenceNodes(sourceFile, symbol.name, searchContainer)) {
-            if (!isIdentifier(token) || token === definition || token.escapedText !== definition.escapedText)
-              continue;
-            const referenceSymbol = checker.getSymbolAtLocation(token);
-            if (referenceSymbol === symbol || checker.getShorthandAssignmentValueSymbol(token.parent) === symbol || isExportSpecifier(token.parent) && getLocalSymbolForExportSpecifier(token, referenceSymbol, token.parent, checker) === symbol) {
-              const res = cb(token);
-              if (res)
-                return res;
+            if (isBlock(node) || isTemplateSpan(node) || isTemplateHead(node) || isTemplateTail(node) || prevNode && isTemplateHead(prevNode) || isVariableDeclarationList(node) && isVariableStatement(parentNode) || isSyntaxList(node) && isVariableDeclarationList(parentNode) || isVariableDeclaration(node) && isSyntaxList(parentNode) && children.length === 1 || isJSDocTypeExpression(node) || isJSDocSignature(node) || isJSDocTypeLiteral(node)) {
+              parentNode = node;
+              break;
             }
-          }
-        }
-        Core2.eachSymbolReferenceInFile = eachSymbolReferenceInFile;
-        function getTopMostDeclarationNamesInFile(declarationName, sourceFile) {
-          const candidates = filter(getPossibleSymbolReferenceNodes(sourceFile, declarationName), (name) => !!getDeclarationFromName(name));
-          return candidates.reduce((topMost, decl) => {
-            const depth = getDepth(decl);
-            if (!some(topMost.declarationNames) || depth === topMost.depth) {
-              topMost.declarationNames.push(decl);
-              topMost.depth = depth;
-            } else if (depth < topMost.depth) {
-              topMost.declarationNames = [decl];
-              topMost.depth = depth;
+            if (isTemplateSpan(parentNode) && nextNode && isTemplateMiddleOrTemplateTail(nextNode)) {
+              const start2 = node.getFullStart() - "${".length;
+              const end2 = nextNode.getStart() + "}".length;
+              pushSelectionRange(start2, end2);
             }
-            return topMost;
-          }, { depth: Infinity, declarationNames: [] }).declarationNames;
-          function getDepth(declaration) {
-            let depth = 0;
-            while (declaration) {
-              declaration = getContainerNode(declaration);
-              depth++;
+            const isBetweenMultiLineBookends = isSyntaxList(node) && isListOpener(prevNode) && isListCloser(nextNode) && !positionsAreOnSameLine(prevNode.getStart(), nextNode.getStart(), sourceFile);
+            let start = isBetweenMultiLineBookends ? prevNode.getEnd() : node.getStart();
+            const end = isBetweenMultiLineBookends ? nextNode.getStart() : getEndPos(sourceFile, node);
+            if (hasJSDocNodes(node) && ((_a = node.jsDoc) == null ? void 0 : _a.length)) {
+              pushSelectionRange(first(node.jsDoc).getStart(), end);
             }
-            return depth;
-          }
-        }
-        Core2.getTopMostDeclarationNamesInFile = getTopMostDeclarationNamesInFile;
-        function someSignatureUsage(signature, sourceFiles, checker, cb) {
-          if (!signature.name || !isIdentifier(signature.name))
-            return false;
-          const symbol = Debug.checkDefined(checker.getSymbolAtLocation(signature.name));
-          for (const sourceFile of sourceFiles) {
-            for (const name of getPossibleSymbolReferenceNodes(sourceFile, symbol.name)) {
-              if (!isIdentifier(name) || name === signature.name || name.escapedText !== signature.name.escapedText)
-                continue;
-              const called = climbPastPropertyAccess(name);
-              const call = isCallExpression(called.parent) && called.parent.expression === called ? called.parent : void 0;
-              const referenceSymbol = checker.getSymbolAtLocation(name);
-              if (referenceSymbol && checker.getRootSymbols(referenceSymbol).some((s) => s === symbol)) {
-                if (cb(name, call)) {
-                  return true;
-                }
+            if (isSyntaxList(node)) {
+              const firstChild = node.getChildren()[0];
+              if (firstChild && hasJSDocNodes(firstChild) && ((_b = firstChild.jsDoc) == null ? void 0 : _b.length) && firstChild.getStart() !== node.pos) {
+                start = Math.min(start, first(firstChild.jsDoc).getStart());
               }
             }
-          }
-          return false;
-        }
-        Core2.someSignatureUsage = someSignatureUsage;
-        function getPossibleSymbolReferenceNodes(sourceFile, symbolName2, container = sourceFile) {
-          return getPossibleSymbolReferencePositions(sourceFile, symbolName2, container).map((pos) => getTouchingPropertyName(sourceFile, pos));
-        }
-        function getPossibleSymbolReferencePositions(sourceFile, symbolName2, container = sourceFile) {
-          const positions = [];
-          if (!symbolName2 || !symbolName2.length) {
-            return positions;
-          }
-          const text = sourceFile.text;
-          const sourceLength = text.length;
-          const symbolNameLength = symbolName2.length;
-          let position = text.indexOf(symbolName2, container.pos);
-          while (position >= 0) {
-            if (position > container.end)
-              break;
-            const endPosition = position + symbolNameLength;
-            if ((position === 0 || !isIdentifierPart(text.charCodeAt(position - 1), 99 /* Latest */)) && (endPosition === sourceLength || !isIdentifierPart(text.charCodeAt(endPosition), 99 /* Latest */))) {
-              positions.push(position);
+            pushSelectionRange(start, end);
+            if (isStringLiteral(node) || isTemplateLiteral(node)) {
+              pushSelectionRange(start + 1, end - 1);
             }
-            position = text.indexOf(symbolName2, position + symbolNameLength + 1);
+            parentNode = node;
+            break;
           }
-          return positions;
-        }
-        function getLabelReferencesInNode(container, targetLabel) {
-          const sourceFile = container.getSourceFile();
-          const labelName = targetLabel.text;
-          const references = mapDefined(getPossibleSymbolReferenceNodes(sourceFile, labelName, container), (node) => (
-            // Only pick labels that are either the target label, or have a target that is the target label
-            node === targetLabel || isJumpStatementTarget(node) && getTargetLabel(node, labelName) === targetLabel ? nodeEntry(node) : void 0
-          ));
-          return [{ definition: { type: 1 /* Label */, node: targetLabel }, references }];
-        }
-        function isValidReferencePosition(node, searchSymbolName) {
-          switch (node.kind) {
-            case 81 /* PrivateIdentifier */:
-              if (isJSDocMemberName(node.parent)) {
-                return true;
-              }
-            case 80 /* Identifier */:
-              return node.text.length === searchSymbolName.length;
-            case 15 /* NoSubstitutionTemplateLiteral */:
-            case 11 /* StringLiteral */: {
-              const str = node;
-              return (isLiteralNameOfPropertyDeclarationOrIndexAccess(str) || isNameOfModuleDeclaration(node) || isExpressionOfExternalModuleImportEqualsDeclaration(node) || isCallExpression(node.parent) && isBindableObjectDefinePropertyCall(node.parent) && node.parent.arguments[1] === node) && str.text.length === searchSymbolName.length;
-            }
-            case 9 /* NumericLiteral */:
-              return isLiteralNameOfPropertyDeclarationOrIndexAccess(node) && node.text.length === searchSymbolName.length;
-            case 90 /* DefaultKeyword */:
-              return "default".length === searchSymbolName.length;
-            default:
-              return false;
+          if (i === children.length - 1) {
+            break outer;
           }
         }
-        function getAllReferencesForImportMeta(sourceFiles, cancellationToken) {
-          const references = flatMap(sourceFiles, (sourceFile) => {
-            cancellationToken.throwIfCancellationRequested();
-            return mapDefined(getPossibleSymbolReferenceNodes(sourceFile, "meta", sourceFile), (node) => {
-              const parent2 = node.parent;
-              if (isImportMeta(parent2)) {
-                return nodeEntry(parent2);
-              }
-            });
-          });
-          return references.length ? [{ definition: { type: 2 /* Keyword */, node: references[0].node }, references }] : void 0;
-        }
-        function getAllReferencesForKeyword(sourceFiles, keywordKind, cancellationToken, filter2) {
-          const references = flatMap(sourceFiles, (sourceFile) => {
-            cancellationToken.throwIfCancellationRequested();
-            return mapDefined(getPossibleSymbolReferenceNodes(sourceFile, tokenToString(keywordKind), sourceFile), (referenceLocation) => {
-              if (referenceLocation.kind === keywordKind && (!filter2 || filter2(referenceLocation))) {
-                return nodeEntry(referenceLocation);
-              }
-            });
-          });
-          return references.length ? [{ definition: { type: 2 /* Keyword */, node: references[0].node }, references }] : void 0;
+      }
+    return selectionRange;
+    function pushSelectionRange(start, end) {
+      if (start !== end) {
+        const textSpan = createTextSpanFromBounds(start, end);
+        if (!selectionRange || // Skip ranges that are identical to the parent
+        !textSpansEqual(textSpan, selectionRange.textSpan) && // Skip ranges that don't contain the original position
+        textSpanIntersectsWithPosition(textSpan, pos)) {
+          selectionRange = { textSpan, ...selectionRange && { parent: selectionRange } };
         }
-        function getReferencesInSourceFile(sourceFile, search, state, addReferencesHere = true) {
-          state.cancellationToken.throwIfCancellationRequested();
-          return getReferencesInContainer(sourceFile, sourceFile, search, state, addReferencesHere);
+      }
+    }
+    function pushSelectionCommentRange(start, end) {
+      pushSelectionRange(start, end);
+      let pos2 = start;
+      while (sourceFile.text.charCodeAt(pos2) === 47 /* slash */) {
+        pos2++;
+      }
+      pushSelectionRange(pos2, end);
+    }
+  }
+  function positionShouldSnapToNode(sourceFile, pos, node) {
+    Debug.assert(node.pos <= pos);
+    if (pos < node.end) {
+      return true;
+    }
+    const nodeEnd = node.getEnd();
+    if (nodeEnd === pos) {
+      return getTouchingPropertyName(sourceFile, pos).pos < node.end;
+    }
+    return false;
+  }
+  function getSelectionChildren(node) {
+    var _a;
+    if (isSourceFile(node)) {
+      return groupChildren(node.getChildAt(0).getChildren(), isImport2);
+    }
+    if (isMappedTypeNode(node)) {
+      const [openBraceToken, ...children] = node.getChildren();
+      const closeBraceToken = Debug.checkDefined(children.pop());
+      Debug.assertEqual(openBraceToken.kind, 19 /* OpenBraceToken */);
+      Debug.assertEqual(closeBraceToken.kind, 20 /* CloseBraceToken */);
+      const groupedWithPlusMinusTokens = groupChildren(children, (child) => child === node.readonlyToken || child.kind === 148 /* ReadonlyKeyword */ || child === node.questionToken || child.kind === 58 /* QuestionToken */);
+      const groupedWithBrackets = groupChildren(groupedWithPlusMinusTokens, ({ kind }) => kind === 23 /* OpenBracketToken */ || kind === 168 /* TypeParameter */ || kind === 24 /* CloseBracketToken */);
+      return [
+        openBraceToken,
+        // Pivot on `:`
+        createSyntaxList2(splitChildren(groupedWithBrackets, ({ kind }) => kind === 59 /* ColonToken */)),
+        closeBraceToken
+      ];
+    }
+    if (isPropertySignature(node)) {
+      const children = groupChildren(node.getChildren(), (child) => child === node.name || contains(node.modifiers, child));
+      const firstJSDocChild = ((_a = children[0]) == null ? void 0 : _a.kind) === 327 /* JSDoc */ ? children[0] : void 0;
+      const withJSDocSeparated = firstJSDocChild ? children.slice(1) : children;
+      const splittedChildren = splitChildren(withJSDocSeparated, ({ kind }) => kind === 59 /* ColonToken */);
+      return firstJSDocChild ? [firstJSDocChild, createSyntaxList2(splittedChildren)] : splittedChildren;
+    }
+    if (isParameter(node)) {
+      const groupedDotDotDotAndName = groupChildren(node.getChildren(), (child) => child === node.dotDotDotToken || child === node.name);
+      const groupedWithQuestionToken = groupChildren(groupedDotDotDotAndName, (child) => child === groupedDotDotDotAndName[0] || child === node.questionToken);
+      return splitChildren(groupedWithQuestionToken, ({ kind }) => kind === 64 /* EqualsToken */);
+    }
+    if (isBindingElement(node)) {
+      return splitChildren(node.getChildren(), ({ kind }) => kind === 64 /* EqualsToken */);
+    }
+    return node.getChildren();
+  }
+  function groupChildren(children, groupOn) {
+    const result = [];
+    let group2;
+    for (const child of children) {
+      if (groupOn(child)) {
+        group2 = group2 || [];
+        group2.push(child);
+      } else {
+        if (group2) {
+          result.push(createSyntaxList2(group2));
+          group2 = void 0;
         }
-        function getReferencesInContainer(container, sourceFile, search, state, addReferencesHere) {
-          if (!state.markSearchedSymbols(sourceFile, search.allSearchSymbols)) {
-            return;
+        result.push(child);
+      }
+    }
+    if (group2) {
+      result.push(createSyntaxList2(group2));
+    }
+    return result;
+  }
+  function splitChildren(children, pivotOn, separateTrailingSemicolon = true) {
+    if (children.length < 2) {
+      return children;
+    }
+    const splitTokenIndex = findIndex(children, pivotOn);
+    if (splitTokenIndex === -1) {
+      return children;
+    }
+    const leftChildren = children.slice(0, splitTokenIndex);
+    const splitToken = children[splitTokenIndex];
+    const lastToken = last(children);
+    const separateLastToken = separateTrailingSemicolon && lastToken.kind === 27 /* SemicolonToken */;
+    const rightChildren = children.slice(splitTokenIndex + 1, separateLastToken ? children.length - 1 : void 0);
+    const result = compact([
+      leftChildren.length ? createSyntaxList2(leftChildren) : void 0,
+      splitToken,
+      rightChildren.length ? createSyntaxList2(rightChildren) : void 0
+    ]);
+    return separateLastToken ? result.concat(lastToken) : result;
+  }
+  function createSyntaxList2(children) {
+    Debug.assertGreaterThanOrEqual(children.length, 1);
+    return setTextRangePosEnd(parseNodeFactory.createSyntaxList(children), children[0].pos, last(children).end);
+  }
+  function isListOpener(token) {
+    const kind = token && token.kind;
+    return kind === 19 /* OpenBraceToken */ || kind === 23 /* OpenBracketToken */ || kind === 21 /* OpenParenToken */ || kind === 286 /* JsxOpeningElement */;
+  }
+  function isListCloser(token) {
+    const kind = token && token.kind;
+    return kind === 20 /* CloseBraceToken */ || kind === 24 /* CloseBracketToken */ || kind === 22 /* CloseParenToken */ || kind === 287 /* JsxClosingElement */;
+  }
+  function getEndPos(sourceFile, node) {
+    switch (node.kind) {
+      case 348 /* JSDocParameterTag */:
+      case 345 /* JSDocCallbackTag */:
+      case 355 /* JSDocPropertyTag */:
+      case 353 /* JSDocTypedefTag */:
+      case 350 /* JSDocThisTag */:
+        return sourceFile.getLineEndOfPosition(node.getStart());
+      default:
+        return node.getEnd();
+    }
+  }
+  var isImport2;
+  var init_smartSelection = __esm({
+    "src/services/smartSelection.ts"() {
+      "use strict";
+      init_ts4();
+      isImport2 = or(isImportDeclaration, isImportEqualsDeclaration);
+    }
+  });
+
+  // src/services/_namespaces/ts.SmartSelectionRange.ts
+  var ts_SmartSelectionRange_exports = {};
+  __export(ts_SmartSelectionRange_exports, {
+    getSmartSelectionRange: () => getSmartSelectionRange
+  });
+  var init_ts_SmartSelectionRange = __esm({
+    "src/services/_namespaces/ts.SmartSelectionRange.ts"() {
+      "use strict";
+      init_smartSelection();
+    }
+  });
+
+  // src/services/symbolDisplay.ts
+  function getSymbolKind(typeChecker, symbol, location) {
+    const result = getSymbolKindOfConstructorPropertyMethodAccessorFunctionOrVar(typeChecker, symbol, location);
+    if (result !== "" /* unknown */) {
+      return result;
+    }
+    const flags = getCombinedLocalAndExportSymbolFlags(symbol);
+    if (flags & 32 /* Class */) {
+      return getDeclarationOfKind(symbol, 231 /* ClassExpression */) ? "local class" /* localClassElement */ : "class" /* classElement */;
+    }
+    if (flags & 384 /* Enum */)
+      return "enum" /* enumElement */;
+    if (flags & 524288 /* TypeAlias */)
+      return "type" /* typeElement */;
+    if (flags & 64 /* Interface */)
+      return "interface" /* interfaceElement */;
+    if (flags & 262144 /* TypeParameter */)
+      return "type parameter" /* typeParameterElement */;
+    if (flags & 8 /* EnumMember */)
+      return "enum member" /* enumMemberElement */;
+    if (flags & 2097152 /* Alias */)
+      return "alias" /* alias */;
+    if (flags & 1536 /* Module */)
+      return "module" /* moduleElement */;
+    return result;
+  }
+  function getSymbolKindOfConstructorPropertyMethodAccessorFunctionOrVar(typeChecker, symbol, location) {
+    const roots = typeChecker.getRootSymbols(symbol);
+    if (roots.length === 1 && first(roots).flags & 8192 /* Method */ && typeChecker.getTypeOfSymbolAtLocation(symbol, location).getNonNullableType().getCallSignatures().length !== 0) {
+      return "method" /* memberFunctionElement */;
+    }
+    if (typeChecker.isUndefinedSymbol(symbol)) {
+      return "var" /* variableElement */;
+    }
+    if (typeChecker.isArgumentsSymbol(symbol)) {
+      return "local var" /* localVariableElement */;
+    }
+    if (location.kind === 110 /* ThisKeyword */ && isExpression(location) || isThisInTypeQuery(location)) {
+      return "parameter" /* parameterElement */;
+    }
+    const flags = getCombinedLocalAndExportSymbolFlags(symbol);
+    if (flags & 3 /* Variable */) {
+      if (isFirstDeclarationOfSymbolParameter(symbol)) {
+        return "parameter" /* parameterElement */;
+      } else if (symbol.valueDeclaration && isVarConst(symbol.valueDeclaration)) {
+        return "const" /* constElement */;
+      } else if (symbol.valueDeclaration && isVarUsing(symbol.valueDeclaration)) {
+        return "using" /* variableUsingElement */;
+      } else if (symbol.valueDeclaration && isVarAwaitUsing(symbol.valueDeclaration)) {
+        return "await using" /* variableAwaitUsingElement */;
+      } else if (forEach(symbol.declarations, isLet)) {
+        return "let" /* letElement */;
+      }
+      return isLocalVariableOrFunction(symbol) ? "local var" /* localVariableElement */ : "var" /* variableElement */;
+    }
+    if (flags & 16 /* Function */)
+      return isLocalVariableOrFunction(symbol) ? "local function" /* localFunctionElement */ : "function" /* functionElement */;
+    if (flags & 32768 /* GetAccessor */)
+      return "getter" /* memberGetAccessorElement */;
+    if (flags & 65536 /* SetAccessor */)
+      return "setter" /* memberSetAccessorElement */;
+    if (flags & 8192 /* Method */)
+      return "method" /* memberFunctionElement */;
+    if (flags & 16384 /* Constructor */)
+      return "constructor" /* constructorImplementationElement */;
+    if (flags & 131072 /* Signature */)
+      return "index" /* indexSignatureElement */;
+    if (flags & 4 /* Property */) {
+      if (flags & 33554432 /* Transient */ && symbol.links.checkFlags & 6 /* Synthetic */) {
+        const unionPropertyKind = forEach(typeChecker.getRootSymbols(symbol), (rootSymbol) => {
+          const rootSymbolFlags = rootSymbol.getFlags();
+          if (rootSymbolFlags & (98308 /* PropertyOrAccessor */ | 3 /* Variable */)) {
+            return "property" /* memberVariableElement */;
           }
-          for (const position of getPossibleSymbolReferencePositions(sourceFile, search.text, container)) {
-            getReferencesAtLocation(sourceFile, position, search, state, addReferencesHere);
+        });
+        if (!unionPropertyKind) {
+          const typeOfUnionProperty = typeChecker.getTypeOfSymbolAtLocation(symbol, location);
+          if (typeOfUnionProperty.getCallSignatures().length) {
+            return "method" /* memberFunctionElement */;
           }
+          return "property" /* memberVariableElement */;
         }
-        function hasMatchingMeaning(referenceLocation, state) {
-          return !!(getMeaningFromLocation(referenceLocation) & state.searchMeaning);
-        }
-        function getReferencesAtLocation(sourceFile, position, search, state, addReferencesHere) {
-          const referenceLocation = getTouchingPropertyName(sourceFile, position);
-          if (!isValidReferencePosition(referenceLocation, search.text)) {
-            if (!state.options.implementations && (state.options.findInStrings && isInString(sourceFile, position) || state.options.findInComments && isInNonReferenceComment(sourceFile, position))) {
-              state.addStringOrCommentReference(sourceFile.fileName, createTextSpan(position, search.text.length));
-            }
-            return;
-          }
-          if (!hasMatchingMeaning(referenceLocation, state))
-            return;
-          let referenceSymbol = state.checker.getSymbolAtLocation(referenceLocation);
-          if (!referenceSymbol) {
-            return;
-          }
-          const parent2 = referenceLocation.parent;
-          if (isImportSpecifier(parent2) && parent2.propertyName === referenceLocation) {
-            return;
-          }
-          if (isExportSpecifier(parent2)) {
-            Debug.assert(referenceLocation.kind === 80 /* Identifier */);
-            getReferencesAtExportSpecifier(referenceLocation, referenceSymbol, parent2, search, state, addReferencesHere);
-            return;
-          }
-          const relatedSymbol = getRelatedSymbol(search, referenceSymbol, referenceLocation, state);
-          if (!relatedSymbol) {
-            getReferenceForShorthandProperty(referenceSymbol, search, state);
-            return;
-          }
-          switch (state.specialSearchKind) {
-            case 0 /* None */:
-              if (addReferencesHere)
-                addReference(referenceLocation, relatedSymbol, state);
+        return unionPropertyKind;
+      }
+      return "property" /* memberVariableElement */;
+    }
+    return "" /* unknown */;
+  }
+  function getNormalizedSymbolModifiers(symbol) {
+    if (symbol.declarations && symbol.declarations.length) {
+      const [declaration, ...declarations] = symbol.declarations;
+      const excludeFlags = length(declarations) && isDeprecatedDeclaration(declaration) && some(declarations, (d) => !isDeprecatedDeclaration(d)) ? 65536 /* Deprecated */ : 0 /* None */;
+      const modifiers = getNodeModifiers(declaration, excludeFlags);
+      if (modifiers) {
+        return modifiers.split(",");
+      }
+    }
+    return [];
+  }
+  function getSymbolModifiers(typeChecker, symbol) {
+    if (!symbol) {
+      return "" /* none */;
+    }
+    const modifiers = new Set(getNormalizedSymbolModifiers(symbol));
+    if (symbol.flags & 2097152 /* Alias */) {
+      const resolvedSymbol = typeChecker.getAliasedSymbol(symbol);
+      if (resolvedSymbol !== symbol) {
+        forEach(getNormalizedSymbolModifiers(resolvedSymbol), (modifier) => {
+          modifiers.add(modifier);
+        });
+      }
+    }
+    if (symbol.flags & 16777216 /* Optional */) {
+      modifiers.add("optional" /* optionalModifier */);
+    }
+    return modifiers.size > 0 ? arrayFrom(modifiers.values()).join(",") : "" /* none */;
+  }
+  function getSymbolDisplayPartsDocumentationAndSymbolKindWorker(typeChecker, symbol, sourceFile, enclosingDeclaration, location, type, semanticMeaning, alias) {
+    var _a;
+    const displayParts = [];
+    let documentation = [];
+    let tags = [];
+    const symbolFlags = getCombinedLocalAndExportSymbolFlags(symbol);
+    let symbolKind = semanticMeaning & 1 /* Value */ ? getSymbolKindOfConstructorPropertyMethodAccessorFunctionOrVar(typeChecker, symbol, location) : "" /* unknown */;
+    let hasAddedSymbolInfo = false;
+    const isThisExpression = location.kind === 110 /* ThisKeyword */ && isInExpressionContext(location) || isThisInTypeQuery(location);
+    let documentationFromAlias;
+    let tagsFromAlias;
+    let hasMultipleSignatures = false;
+    if (location.kind === 110 /* ThisKeyword */ && !isThisExpression) {
+      return { displayParts: [keywordPart(110 /* ThisKeyword */)], documentation: [], symbolKind: "primitive type" /* primitiveType */, tags: void 0 };
+    }
+    if (symbolKind !== "" /* unknown */ || symbolFlags & 32 /* Class */ || symbolFlags & 2097152 /* Alias */) {
+      if (symbolKind === "getter" /* memberGetAccessorElement */ || symbolKind === "setter" /* memberSetAccessorElement */) {
+        const declaration = find(symbol.declarations, (declaration2) => declaration2.name === location);
+        if (declaration) {
+          switch (declaration.kind) {
+            case 177 /* GetAccessor */:
+              symbolKind = "getter" /* memberGetAccessorElement */;
               break;
-            case 1 /* Constructor */:
-              addConstructorReferences(referenceLocation, sourceFile, search, state);
+            case 178 /* SetAccessor */:
+              symbolKind = "setter" /* memberSetAccessorElement */;
               break;
-            case 2 /* Class */:
-              addClassStaticThisReferences(referenceLocation, search, state);
+            case 172 /* PropertyDeclaration */:
+              symbolKind = "accessor" /* memberAccessorVariableElement */;
               break;
             default:
-              Debug.assertNever(state.specialSearchKind);
-          }
-          if (isInJSFile(referenceLocation) && isBindingElement(referenceLocation.parent) && isVariableDeclarationInitializedToBareOrAccessedRequire(referenceLocation.parent.parent.parent)) {
-            referenceSymbol = referenceLocation.parent.symbol;
-            if (!referenceSymbol)
-              return;
-          }
-          getImportOrExportReferences(referenceLocation, referenceSymbol, search, state);
-        }
-        function getReferencesAtExportSpecifier(referenceLocation, referenceSymbol, exportSpecifier, search, state, addReferencesHere, alwaysGetReferences) {
-          Debug.assert(!alwaysGetReferences || !!state.options.providePrefixAndSuffixTextForRename, "If alwaysGetReferences is true, then prefix/suffix text must be enabled");
-          const { parent: parent2, propertyName, name } = exportSpecifier;
-          const exportDeclaration = parent2.parent;
-          const localSymbol = getLocalSymbolForExportSpecifier(referenceLocation, referenceSymbol, exportSpecifier, state.checker);
-          if (!alwaysGetReferences && !search.includes(localSymbol)) {
-            return;
-          }
-          if (!propertyName) {
-            if (!(state.options.use === 2 /* Rename */ && name.escapedText === "default" /* Default */)) {
-              addRef();
-            }
-          } else if (referenceLocation === propertyName) {
-            if (!exportDeclaration.moduleSpecifier) {
-              addRef();
-            }
-            if (addReferencesHere && state.options.use !== 2 /* Rename */ && state.markSeenReExportRHS(name)) {
-              addReference(name, Debug.checkDefined(exportSpecifier.symbol), state);
-            }
-          } else {
-            if (state.markSeenReExportRHS(referenceLocation)) {
-              addRef();
-            }
-          }
-          if (!isForRenameWithPrefixAndSuffixText(state.options) || alwaysGetReferences) {
-            const isDefaultExport = referenceLocation.escapedText === "default" || exportSpecifier.name.escapedText === "default";
-            const exportKind = isDefaultExport ? 1 /* Default */ : 0 /* Named */;
-            const exportSymbol = Debug.checkDefined(exportSpecifier.symbol);
-            const exportInfo = getExportInfo(exportSymbol, exportKind, state.checker);
-            if (exportInfo) {
-              searchForImportsOfExport(referenceLocation, exportSymbol, exportInfo, state);
-            }
-          }
-          if (search.comingFrom !== 1 /* Export */ && exportDeclaration.moduleSpecifier && !propertyName && !isForRenameWithPrefixAndSuffixText(state.options)) {
-            const imported = state.checker.getExportSpecifierLocalTargetSymbol(exportSpecifier);
-            if (imported)
-              searchForImportedSymbol(imported, state);
-          }
-          function addRef() {
-            if (addReferencesHere)
-              addReference(referenceLocation, localSymbol, state);
-          }
-        }
-        function getLocalSymbolForExportSpecifier(referenceLocation, referenceSymbol, exportSpecifier, checker) {
-          return isExportSpecifierAlias(referenceLocation, exportSpecifier) && checker.getExportSpecifierLocalTargetSymbol(exportSpecifier) || referenceSymbol;
-        }
-        function isExportSpecifierAlias(referenceLocation, exportSpecifier) {
-          const { parent: parent2, propertyName, name } = exportSpecifier;
-          Debug.assert(propertyName === referenceLocation || name === referenceLocation);
-          if (propertyName) {
-            return propertyName === referenceLocation;
-          } else {
-            return !parent2.parent.moduleSpecifier;
-          }
-        }
-        function getImportOrExportReferences(referenceLocation, referenceSymbol, search, state) {
-          const importOrExport = getImportOrExportSymbol(referenceLocation, referenceSymbol, state.checker, search.comingFrom === 1 /* Export */);
-          if (!importOrExport)
-            return;
-          const { symbol } = importOrExport;
-          if (importOrExport.kind === 0 /* Import */) {
-            if (!isForRenameWithPrefixAndSuffixText(state.options)) {
-              searchForImportedSymbol(symbol, state);
-            }
-          } else {
-            searchForImportsOfExport(referenceLocation, symbol, importOrExport.exportInfo, state);
-          }
-        }
-        function getReferenceForShorthandProperty({ flags, valueDeclaration }, search, state) {
-          const shorthandValueSymbol = state.checker.getShorthandAssignmentValueSymbol(valueDeclaration);
-          const name = valueDeclaration && getNameOfDeclaration(valueDeclaration);
-          if (!(flags & 33554432 /* Transient */) && name && search.includes(shorthandValueSymbol)) {
-            addReference(name, shorthandValueSymbol, state);
-          }
-        }
-        function addReference(referenceLocation, relatedSymbol, state) {
-          const { kind, symbol } = "kind" in relatedSymbol ? relatedSymbol : { kind: void 0, symbol: relatedSymbol };
-          if (state.options.use === 2 /* Rename */ && referenceLocation.kind === 90 /* DefaultKeyword */) {
-            return;
-          }
-          const addRef = state.referenceAdder(symbol);
-          if (state.options.implementations) {
-            addImplementationReferences(referenceLocation, addRef, state);
-          } else {
-            addRef(referenceLocation, kind);
-          }
-        }
-        function addConstructorReferences(referenceLocation, sourceFile, search, state) {
-          if (isNewExpressionTarget(referenceLocation)) {
-            addReference(referenceLocation, search.symbol, state);
-          }
-          const pusher = () => state.referenceAdder(search.symbol);
-          if (isClassLike(referenceLocation.parent)) {
-            Debug.assert(referenceLocation.kind === 90 /* DefaultKeyword */ || referenceLocation.parent.name === referenceLocation);
-            findOwnConstructorReferences(search.symbol, sourceFile, pusher());
-          } else {
-            const classExtending = tryGetClassByExtendingIdentifier(referenceLocation);
-            if (classExtending) {
-              findSuperConstructorAccesses(classExtending, pusher());
-              findInheritedConstructorReferences(classExtending, state);
-            }
-          }
-        }
-        function addClassStaticThisReferences(referenceLocation, search, state) {
-          addReference(referenceLocation, search.symbol, state);
-          const classLike = referenceLocation.parent;
-          if (state.options.use === 2 /* Rename */ || !isClassLike(classLike))
-            return;
-          Debug.assert(classLike.name === referenceLocation);
-          const addRef = state.referenceAdder(search.symbol);
-          for (const member of classLike.members) {
-            if (!(isMethodOrAccessor(member) && isStatic(member))) {
-              continue;
-            }
-            if (member.body) {
-              member.body.forEachChild(function cb(node) {
-                if (node.kind === 110 /* ThisKeyword */) {
-                  addRef(node);
-                } else if (!isFunctionLike(node) && !isClassLike(node)) {
-                  node.forEachChild(cb);
-                }
-              });
-            }
-          }
-        }
-        function findOwnConstructorReferences(classSymbol, sourceFile, addNode) {
-          const constructorSymbol = getClassConstructorSymbol(classSymbol);
-          if (constructorSymbol && constructorSymbol.declarations) {
-            for (const decl of constructorSymbol.declarations) {
-              const ctrKeyword = findChildOfKind(decl, 137 /* ConstructorKeyword */, sourceFile);
-              Debug.assert(decl.kind === 175 /* Constructor */ && !!ctrKeyword);
-              addNode(ctrKeyword);
-            }
-          }
-          if (classSymbol.exports) {
-            classSymbol.exports.forEach((member) => {
-              const decl = member.valueDeclaration;
-              if (decl && decl.kind === 173 /* MethodDeclaration */) {
-                const body = decl.body;
-                if (body) {
-                  forEachDescendantOfKind(body, 110 /* ThisKeyword */, (thisKeyword) => {
-                    if (isNewExpressionTarget(thisKeyword)) {
-                      addNode(thisKeyword);
-                    }
-                  });
-                }
-              }
-            });
-          }
-        }
-        function getClassConstructorSymbol(classSymbol) {
-          return classSymbol.members && classSymbol.members.get("__constructor" /* Constructor */);
-        }
-        function findSuperConstructorAccesses(classDeclaration, addNode) {
-          const constructor = getClassConstructorSymbol(classDeclaration.symbol);
-          if (!(constructor && constructor.declarations)) {
-            return;
-          }
-          for (const decl of constructor.declarations) {
-            Debug.assert(decl.kind === 175 /* Constructor */);
-            const body = decl.body;
-            if (body) {
-              forEachDescendantOfKind(body, 108 /* SuperKeyword */, (node) => {
-                if (isCallExpressionTarget(node)) {
-                  addNode(node);
-                }
-              });
-            }
+              Debug.assertNever(declaration);
           }
+        } else {
+          symbolKind = "property" /* memberVariableElement */;
         }
-        function hasOwnConstructor(classDeclaration) {
-          return !!getClassConstructorSymbol(classDeclaration.symbol);
+      }
+      let signature;
+      type ?? (type = isThisExpression ? typeChecker.getTypeAtLocation(location) : typeChecker.getTypeOfSymbolAtLocation(symbol, location));
+      if (location.parent && location.parent.kind === 211 /* PropertyAccessExpression */) {
+        const right = location.parent.name;
+        if (right === location || right && right.getFullWidth() === 0) {
+          location = location.parent;
         }
-        function findInheritedConstructorReferences(classDeclaration, state) {
-          if (hasOwnConstructor(classDeclaration))
-            return;
-          const classSymbol = classDeclaration.symbol;
-          const search = state.createSearch(
-            /*location*/
-            void 0,
-            classSymbol,
-            /*comingFrom*/
-            void 0
-          );
-          getReferencesInContainerOrFiles(classSymbol, state, search);
+      }
+      let callExpressionLike;
+      if (isCallOrNewExpression(location)) {
+        callExpressionLike = location;
+      } else if (isCallExpressionTarget(location) || isNewExpressionTarget(location)) {
+        callExpressionLike = location.parent;
+      } else if (location.parent && (isJsxOpeningLikeElement(location.parent) || isTaggedTemplateExpression(location.parent)) && isFunctionLike(symbol.valueDeclaration)) {
+        callExpressionLike = location.parent;
+      }
+      if (callExpressionLike) {
+        signature = typeChecker.getResolvedSignature(callExpressionLike);
+        const useConstructSignatures = callExpressionLike.kind === 214 /* NewExpression */ || isCallExpression(callExpressionLike) && callExpressionLike.expression.kind === 108 /* SuperKeyword */;
+        const allSignatures = useConstructSignatures ? type.getConstructSignatures() : type.getCallSignatures();
+        if (signature && !contains(allSignatures, signature.target) && !contains(allSignatures, signature)) {
+          signature = allSignatures.length ? allSignatures[0] : void 0;
         }
-        function addImplementationReferences(refNode, addReference2, state) {
-          if (isDeclarationName(refNode) && isImplementation(refNode.parent)) {
-            addReference2(refNode);
-            return;
-          }
-          if (refNode.kind !== 80 /* Identifier */) {
-            return;
-          }
-          if (refNode.parent.kind === 303 /* ShorthandPropertyAssignment */) {
-            getReferenceEntriesForShorthandPropertyAssignment(refNode, state.checker, addReference2);
-          }
-          const containingClass = getContainingClassIfInHeritageClause(refNode);
-          if (containingClass) {
-            addReference2(containingClass);
-            return;
-          }
-          const typeNode = findAncestor(refNode, (a) => !isQualifiedName(a.parent) && !isTypeNode(a.parent) && !isTypeElement(a.parent));
-          const typeHavingNode = typeNode.parent;
-          if (hasType(typeHavingNode) && typeHavingNode.type === typeNode && state.markSeenContainingTypeReference(typeHavingNode)) {
-            if (hasInitializer(typeHavingNode)) {
-              addIfImplementation(typeHavingNode.initializer);
-            } else if (isFunctionLike(typeHavingNode) && typeHavingNode.body) {
-              const body = typeHavingNode.body;
-              if (body.kind === 240 /* Block */) {
-                forEachReturnStatement(body, (returnStatement) => {
-                  if (returnStatement.expression)
-                    addIfImplementation(returnStatement.expression);
-                });
-              } else {
-                addIfImplementation(body);
+        if (signature) {
+          if (useConstructSignatures && symbolFlags & 32 /* Class */) {
+            symbolKind = "constructor" /* constructorImplementationElement */;
+            addPrefixForAnyFunctionOrVar(type.symbol, symbolKind);
+          } else if (symbolFlags & 2097152 /* Alias */) {
+            symbolKind = "alias" /* alias */;
+            pushSymbolKind(symbolKind);
+            displayParts.push(spacePart());
+            if (useConstructSignatures) {
+              if (signature.flags & 4 /* Abstract */) {
+                displayParts.push(keywordPart(128 /* AbstractKeyword */));
+                displayParts.push(spacePart());
               }
-            } else if (isAssertionExpression(typeHavingNode)) {
-              addIfImplementation(typeHavingNode.expression);
+              displayParts.push(keywordPart(105 /* NewKeyword */));
+              displayParts.push(spacePart());
             }
+            addFullSymbolName(symbol);
+          } else {
+            addPrefixForAnyFunctionOrVar(symbol, symbolKind);
           }
-          function addIfImplementation(e) {
-            if (isImplementationExpression(e))
-              addReference2(e);
-          }
-        }
-        function getContainingClassIfInHeritageClause(node) {
-          return isIdentifier(node) || isPropertyAccessExpression(node) ? getContainingClassIfInHeritageClause(node.parent) : isExpressionWithTypeArguments(node) ? tryCast(node.parent.parent, isClassLike) : void 0;
-        }
-        function isImplementationExpression(node) {
-          switch (node.kind) {
-            case 216 /* ParenthesizedExpression */:
-              return isImplementationExpression(node.expression);
-            case 218 /* ArrowFunction */:
-            case 217 /* FunctionExpression */:
-            case 209 /* ObjectLiteralExpression */:
-            case 230 /* ClassExpression */:
-            case 208 /* ArrayLiteralExpression */:
-              return true;
-            default:
-              return false;
-          }
-        }
-        function explicitlyInheritsFrom(symbol, parent2, cachedResults, checker) {
-          if (symbol === parent2) {
-            return true;
-          }
-          const key = getSymbolId(symbol) + "," + getSymbolId(parent2);
-          const cached = cachedResults.get(key);
-          if (cached !== void 0) {
-            return cached;
-          }
-          cachedResults.set(key, false);
-          const inherits = !!symbol.declarations && symbol.declarations.some((declaration) => getAllSuperTypeNodes(declaration).some((typeReference) => {
-            const type = checker.getTypeAtLocation(typeReference);
-            return !!type && !!type.symbol && explicitlyInheritsFrom(type.symbol, parent2, cachedResults, checker);
-          }));
-          cachedResults.set(key, inherits);
-          return inherits;
-        }
-        function getReferencesForSuperKeyword(superKeyword) {
-          let searchSpaceNode = getSuperContainer(
-            superKeyword,
-            /*stopOnFunctions*/
-            false
-          );
-          if (!searchSpaceNode) {
-            return void 0;
-          }
-          let staticFlag = 32 /* Static */;
-          switch (searchSpaceNode.kind) {
-            case 171 /* PropertyDeclaration */:
-            case 170 /* PropertySignature */:
-            case 173 /* MethodDeclaration */:
-            case 172 /* MethodSignature */:
-            case 175 /* Constructor */:
-            case 176 /* GetAccessor */:
-            case 177 /* SetAccessor */:
-              staticFlag &= getSyntacticModifierFlags(searchSpaceNode);
-              searchSpaceNode = searchSpaceNode.parent;
-              break;
-            default:
-              return void 0;
-          }
-          const sourceFile = searchSpaceNode.getSourceFile();
-          const references = mapDefined(getPossibleSymbolReferenceNodes(sourceFile, "super", searchSpaceNode), (node) => {
-            if (node.kind !== 108 /* SuperKeyword */) {
-              return;
-            }
-            const container = getSuperContainer(
-              node,
-              /*stopOnFunctions*/
-              false
-            );
-            return container && isStatic(container) === !!staticFlag && container.parent.symbol === searchSpaceNode.symbol ? nodeEntry(node) : void 0;
-          });
-          return [{ definition: { type: 0 /* Symbol */, symbol: searchSpaceNode.symbol }, references }];
-        }
-        function isParameterName(node) {
-          return node.kind === 80 /* Identifier */ && node.parent.kind === 168 /* Parameter */ && node.parent.name === node;
-        }
-        function getReferencesForThisKeyword(thisOrSuperKeyword, sourceFiles, cancellationToken) {
-          let searchSpaceNode = getThisContainer(
-            thisOrSuperKeyword,
-            /*includeArrowFunctions*/
-            false,
-            /*includeClassComputedPropertyName*/
-            false
-          );
-          let staticFlag = 32 /* Static */;
-          switch (searchSpaceNode.kind) {
-            case 173 /* MethodDeclaration */:
-            case 172 /* MethodSignature */:
-              if (isObjectLiteralMethod(searchSpaceNode)) {
-                staticFlag &= getSyntacticModifierFlags(searchSpaceNode);
-                searchSpaceNode = searchSpaceNode.parent;
-                break;
+          switch (symbolKind) {
+            case "JSX attribute" /* jsxAttribute */:
+            case "property" /* memberVariableElement */:
+            case "var" /* variableElement */:
+            case "const" /* constElement */:
+            case "let" /* letElement */:
+            case "parameter" /* parameterElement */:
+            case "local var" /* localVariableElement */:
+              displayParts.push(punctuationPart(59 /* ColonToken */));
+              displayParts.push(spacePart());
+              if (!(getObjectFlags(type) & 16 /* Anonymous */) && type.symbol) {
+                addRange(displayParts, symbolToDisplayParts(
+                  typeChecker,
+                  type.symbol,
+                  enclosingDeclaration,
+                  /*meaning*/
+                  void 0,
+                  4 /* AllowAnyNodeKind */ | 1 /* WriteTypeParametersOrArguments */
+                ));
+                displayParts.push(lineBreakPart());
               }
-            case 171 /* PropertyDeclaration */:
-            case 170 /* PropertySignature */:
-            case 175 /* Constructor */:
-            case 176 /* GetAccessor */:
-            case 177 /* SetAccessor */:
-              staticFlag &= getSyntacticModifierFlags(searchSpaceNode);
-              searchSpaceNode = searchSpaceNode.parent;
-              break;
-            case 311 /* SourceFile */:
-              if (isExternalModule(searchSpaceNode) || isParameterName(thisOrSuperKeyword)) {
-                return void 0;
+              if (useConstructSignatures) {
+                if (signature.flags & 4 /* Abstract */) {
+                  displayParts.push(keywordPart(128 /* AbstractKeyword */));
+                  displayParts.push(spacePart());
+                }
+                displayParts.push(keywordPart(105 /* NewKeyword */));
+                displayParts.push(spacePart());
               }
-            case 261 /* FunctionDeclaration */:
-            case 217 /* FunctionExpression */:
+              addSignatureDisplayParts(signature, allSignatures, 262144 /* WriteArrowStyleSignature */);
               break;
             default:
-              return void 0;
+              addSignatureDisplayParts(signature, allSignatures);
           }
-          const references = flatMap(searchSpaceNode.kind === 311 /* SourceFile */ ? sourceFiles : [searchSpaceNode.getSourceFile()], (sourceFile) => {
-            cancellationToken.throwIfCancellationRequested();
-            return getPossibleSymbolReferenceNodes(sourceFile, "this", isSourceFile(searchSpaceNode) ? sourceFile : searchSpaceNode).filter((node) => {
-              if (!isThis(node)) {
-                return false;
-              }
-              const container = getThisContainer(
-                node,
-                /*includeArrowFunctions*/
-                false,
-                /*includeClassComputedPropertyName*/
-                false
-              );
-              if (!canHaveSymbol(container))
-                return false;
-              switch (searchSpaceNode.kind) {
-                case 217 /* FunctionExpression */:
-                case 261 /* FunctionDeclaration */:
-                  return searchSpaceNode.symbol === container.symbol;
-                case 173 /* MethodDeclaration */:
-                case 172 /* MethodSignature */:
-                  return isObjectLiteralMethod(searchSpaceNode) && searchSpaceNode.symbol === container.symbol;
-                case 230 /* ClassExpression */:
-                case 262 /* ClassDeclaration */:
-                case 209 /* ObjectLiteralExpression */:
-                  return container.parent && canHaveSymbol(container.parent) && searchSpaceNode.symbol === container.parent.symbol && isStatic(container) === !!staticFlag;
-                case 311 /* SourceFile */:
-                  return container.kind === 311 /* SourceFile */ && !isExternalModule(container) && !isParameterName(node);
-              }
-            });
-          }).map((n) => nodeEntry(n));
-          const thisParameter = firstDefined(references, (r) => isParameter(r.node.parent) ? r.node : void 0);
-          return [{
-            definition: { type: 3 /* This */, node: thisParameter || thisOrSuperKeyword },
-            references
-          }];
-        }
-        function getReferencesForStringLiteral(node, sourceFiles, checker, cancellationToken) {
-          const type = getContextualTypeFromParentOrAncestorTypeNode(node, checker);
-          const references = flatMap(sourceFiles, (sourceFile) => {
-            cancellationToken.throwIfCancellationRequested();
-            return mapDefined(getPossibleSymbolReferenceNodes(sourceFile, node.text), (ref) => {
-              if (isStringLiteralLike(ref) && ref.text === node.text) {
-                if (type) {
-                  const refType = getContextualTypeFromParentOrAncestorTypeNode(ref, checker);
-                  if (type !== checker.getStringType() && type === refType) {
-                    return nodeEntry(ref, 2 /* StringLiteral */);
-                  }
-                } else {
-                  return isNoSubstitutionTemplateLiteral(ref) && !rangeIsOnSingleLine(ref, sourceFile) ? void 0 : nodeEntry(ref, 2 /* StringLiteral */);
-                }
-              }
-            });
-          });
-          return [{
-            definition: { type: 4 /* String */, node },
-            references
-          }];
-        }
-        function populateSearchSymbolSet(symbol, location, checker, isForRename, providePrefixAndSuffixText, implementations) {
-          const result = [];
-          forEachRelatedSymbol(
-            symbol,
-            location,
-            checker,
-            isForRename,
-            !(isForRename && providePrefixAndSuffixText),
-            (sym, root, base) => {
-              if (base) {
-                if (isStaticSymbol(symbol) !== isStaticSymbol(base)) {
-                  base = void 0;
-                }
-              }
-              result.push(base || root || sym);
-            },
-            // when try to find implementation, implementations is true, and not allowed to find base class
-            /*allowBaseTypes*/
-            () => !implementations
-          );
-          return result;
+          hasAddedSymbolInfo = true;
+          hasMultipleSignatures = allSignatures.length > 1;
         }
-        function forEachRelatedSymbol(symbol, location, checker, isForRenamePopulateSearchSymbolSet, onlyIncludeBindingElementAtReferenceLocation, cbSymbol, allowBaseTypes) {
-          const containingObjectLiteralElement = getContainingObjectLiteralElement(location);
-          if (containingObjectLiteralElement) {
-            const shorthandValueSymbol = checker.getShorthandAssignmentValueSymbol(location.parent);
-            if (shorthandValueSymbol && isForRenamePopulateSearchSymbolSet) {
-              return cbSymbol(
-                shorthandValueSymbol,
-                /*rootSymbol*/
-                void 0,
-                /*baseSymbol*/
-                void 0,
-                3 /* SearchedLocalFoundProperty */
-              );
-            }
-            const contextualType = checker.getContextualType(containingObjectLiteralElement.parent);
-            const res2 = contextualType && firstDefined(
-              getPropertySymbolsFromContextualType(
-                containingObjectLiteralElement,
-                checker,
-                contextualType,
-                /*unionSymbolOk*/
-                true
-              ),
-              (sym) => fromRoot(sym, 4 /* SearchedPropertyFoundLocal */)
-            );
-            if (res2)
-              return res2;
-            const propertySymbol = getPropertySymbolOfDestructuringAssignment(location, checker);
-            const res1 = propertySymbol && cbSymbol(
-              propertySymbol,
-              /*rootSymbol*/
-              void 0,
-              /*baseSymbol*/
-              void 0,
-              4 /* SearchedPropertyFoundLocal */
-            );
-            if (res1)
-              return res1;
-            const res22 = shorthandValueSymbol && cbSymbol(
-              shorthandValueSymbol,
-              /*rootSymbol*/
-              void 0,
-              /*baseSymbol*/
-              void 0,
-              3 /* SearchedLocalFoundProperty */
-            );
-            if (res22)
-              return res22;
+      } else if (isNameOfFunctionDeclaration(location) && !(symbolFlags & 98304 /* Accessor */) || // name of function declaration
+      location.kind === 137 /* ConstructorKeyword */ && location.parent.kind === 176 /* Constructor */) {
+        const functionDeclaration = location.parent;
+        const locationIsSymbolDeclaration = symbol.declarations && find(symbol.declarations, (declaration) => declaration === (location.kind === 137 /* ConstructorKeyword */ ? functionDeclaration.parent : functionDeclaration));
+        if (locationIsSymbolDeclaration) {
+          const allSignatures = functionDeclaration.kind === 176 /* Constructor */ ? type.getNonNullableType().getConstructSignatures() : type.getNonNullableType().getCallSignatures();
+          if (!typeChecker.isImplementationOfOverload(functionDeclaration)) {
+            signature = typeChecker.getSignatureFromDeclaration(functionDeclaration);
+          } else {
+            signature = allSignatures[0];
           }
-          const aliasedSymbol = getMergedAliasedSymbolOfNamespaceExportDeclaration(location, symbol, checker);
-          if (aliasedSymbol) {
-            const res2 = cbSymbol(
-              aliasedSymbol,
-              /*rootSymbol*/
-              void 0,
-              /*baseSymbol*/
-              void 0,
-              1 /* Node */
+          if (functionDeclaration.kind === 176 /* Constructor */) {
+            symbolKind = "constructor" /* constructorImplementationElement */;
+            addPrefixForAnyFunctionOrVar(type.symbol, symbolKind);
+          } else {
+            addPrefixForAnyFunctionOrVar(
+              functionDeclaration.kind === 179 /* CallSignature */ && !(type.symbol.flags & 2048 /* TypeLiteral */ || type.symbol.flags & 4096 /* ObjectLiteral */) ? type.symbol : symbol,
+              symbolKind
             );
-            if (res2)
-              return res2;
-          }
-          const res = fromRoot(symbol);
-          if (res)
-            return res;
-          if (symbol.valueDeclaration && isParameterPropertyDeclaration(symbol.valueDeclaration, symbol.valueDeclaration.parent)) {
-            const paramProps = checker.getSymbolsOfParameterPropertyDeclaration(cast(symbol.valueDeclaration, isParameter), symbol.name);
-            Debug.assert(paramProps.length === 2 && !!(paramProps[0].flags & 1 /* FunctionScopedVariable */) && !!(paramProps[1].flags & 4 /* Property */));
-            return fromRoot(symbol.flags & 1 /* FunctionScopedVariable */ ? paramProps[1] : paramProps[0]);
-          }
-          const exportSpecifier = getDeclarationOfKind(symbol, 280 /* ExportSpecifier */);
-          if (!isForRenamePopulateSearchSymbolSet || exportSpecifier && !exportSpecifier.propertyName) {
-            const localSymbol = exportSpecifier && checker.getExportSpecifierLocalTargetSymbol(exportSpecifier);
-            if (localSymbol) {
-              const res2 = cbSymbol(
-                localSymbol,
-                /*rootSymbol*/
-                void 0,
-                /*baseSymbol*/
-                void 0,
-                1 /* Node */
-              );
-              if (res2)
-                return res2;
-            }
-          }
-          if (!isForRenamePopulateSearchSymbolSet) {
-            let bindingElementPropertySymbol;
-            if (onlyIncludeBindingElementAtReferenceLocation) {
-              bindingElementPropertySymbol = isObjectBindingElementWithoutPropertyName(location.parent) ? getPropertySymbolFromBindingElement(checker, location.parent) : void 0;
-            } else {
-              bindingElementPropertySymbol = getPropertySymbolOfObjectBindingPatternWithoutPropertyName(symbol, checker);
-            }
-            return bindingElementPropertySymbol && fromRoot(bindingElementPropertySymbol, 4 /* SearchedPropertyFoundLocal */);
-          }
-          Debug.assert(isForRenamePopulateSearchSymbolSet);
-          const includeOriginalSymbolOfBindingElement = onlyIncludeBindingElementAtReferenceLocation;
-          if (includeOriginalSymbolOfBindingElement) {
-            const bindingElementPropertySymbol = getPropertySymbolOfObjectBindingPatternWithoutPropertyName(symbol, checker);
-            return bindingElementPropertySymbol && fromRoot(bindingElementPropertySymbol, 4 /* SearchedPropertyFoundLocal */);
-          }
-          function fromRoot(sym, kind) {
-            return firstDefined(checker.getRootSymbols(sym), (rootSymbol) => cbSymbol(
-              sym,
-              rootSymbol,
-              /*baseSymbol*/
-              void 0,
-              kind
-            ) || (rootSymbol.parent && rootSymbol.parent.flags & (32 /* Class */ | 64 /* Interface */) && allowBaseTypes(rootSymbol) ? getPropertySymbolsFromBaseTypes(rootSymbol.parent, rootSymbol.name, checker, (base) => cbSymbol(sym, rootSymbol, base, kind)) : void 0));
           }
-          function getPropertySymbolOfObjectBindingPatternWithoutPropertyName(symbol2, checker2) {
-            const bindingElement = getDeclarationOfKind(symbol2, 207 /* BindingElement */);
-            if (bindingElement && isObjectBindingElementWithoutPropertyName(bindingElement)) {
-              return getPropertySymbolFromBindingElement(checker2, bindingElement);
-            }
+          if (signature) {
+            addSignatureDisplayParts(signature, allSignatures);
           }
+          hasAddedSymbolInfo = true;
+          hasMultipleSignatures = allSignatures.length > 1;
         }
-        function getPropertySymbolsFromBaseTypes(symbol, propertyName, checker, cb) {
-          const seen = /* @__PURE__ */ new Map();
-          return recur(symbol);
-          function recur(symbol2) {
-            if (!(symbol2.flags & (32 /* Class */ | 64 /* Interface */)) || !addToSeen(seen, getSymbolId(symbol2)))
-              return;
-            return firstDefined(symbol2.declarations, (declaration) => firstDefined(getAllSuperTypeNodes(declaration), (typeReference) => {
-              const type = checker.getTypeAtLocation(typeReference);
-              const propertySymbol = type && type.symbol && checker.getPropertyOfType(type, propertyName);
-              return type && propertySymbol && (firstDefined(checker.getRootSymbols(propertySymbol), cb) || recur(type.symbol));
-            }));
+      }
+    }
+    if (symbolFlags & 32 /* Class */ && !hasAddedSymbolInfo && !isThisExpression) {
+      addAliasPrefixIfNecessary();
+      if (getDeclarationOfKind(symbol, 231 /* ClassExpression */)) {
+        pushSymbolKind("local class" /* localClassElement */);
+      } else {
+        displayParts.push(keywordPart(86 /* ClassKeyword */));
+      }
+      displayParts.push(spacePart());
+      addFullSymbolName(symbol);
+      writeTypeParametersOfSymbol(symbol, sourceFile);
+    }
+    if (symbolFlags & 64 /* Interface */ && semanticMeaning & 2 /* Type */) {
+      prefixNextMeaning();
+      displayParts.push(keywordPart(120 /* InterfaceKeyword */));
+      displayParts.push(spacePart());
+      addFullSymbolName(symbol);
+      writeTypeParametersOfSymbol(symbol, sourceFile);
+    }
+    if (symbolFlags & 524288 /* TypeAlias */ && semanticMeaning & 2 /* Type */) {
+      prefixNextMeaning();
+      displayParts.push(keywordPart(156 /* TypeKeyword */));
+      displayParts.push(spacePart());
+      addFullSymbolName(symbol);
+      writeTypeParametersOfSymbol(symbol, sourceFile);
+      displayParts.push(spacePart());
+      displayParts.push(operatorPart(64 /* EqualsToken */));
+      displayParts.push(spacePart());
+      addRange(displayParts, typeToDisplayParts(typeChecker, location.parent && isConstTypeReference(location.parent) ? typeChecker.getTypeAtLocation(location.parent) : typeChecker.getDeclaredTypeOfSymbol(symbol), enclosingDeclaration, 8388608 /* InTypeAlias */));
+    }
+    if (symbolFlags & 384 /* Enum */) {
+      prefixNextMeaning();
+      if (some(symbol.declarations, (d) => isEnumDeclaration(d) && isEnumConst(d))) {
+        displayParts.push(keywordPart(87 /* ConstKeyword */));
+        displayParts.push(spacePart());
+      }
+      displayParts.push(keywordPart(94 /* EnumKeyword */));
+      displayParts.push(spacePart());
+      addFullSymbolName(symbol);
+    }
+    if (symbolFlags & 1536 /* Module */ && !isThisExpression) {
+      prefixNextMeaning();
+      const declaration = getDeclarationOfKind(symbol, 267 /* ModuleDeclaration */);
+      const isNamespace = declaration && declaration.name && declaration.name.kind === 80 /* Identifier */;
+      displayParts.push(keywordPart(isNamespace ? 145 /* NamespaceKeyword */ : 144 /* ModuleKeyword */));
+      displayParts.push(spacePart());
+      addFullSymbolName(symbol);
+    }
+    if (symbolFlags & 262144 /* TypeParameter */ && semanticMeaning & 2 /* Type */) {
+      prefixNextMeaning();
+      displayParts.push(punctuationPart(21 /* OpenParenToken */));
+      displayParts.push(textPart("type parameter"));
+      displayParts.push(punctuationPart(22 /* CloseParenToken */));
+      displayParts.push(spacePart());
+      addFullSymbolName(symbol);
+      if (symbol.parent) {
+        addInPrefix();
+        addFullSymbolName(symbol.parent, enclosingDeclaration);
+        writeTypeParametersOfSymbol(symbol.parent, enclosingDeclaration);
+      } else {
+        const decl = getDeclarationOfKind(symbol, 168 /* TypeParameter */);
+        if (decl === void 0)
+          return Debug.fail();
+        const declaration = decl.parent;
+        if (declaration) {
+          if (isFunctionLike(declaration)) {
+            addInPrefix();
+            const signature = typeChecker.getSignatureFromDeclaration(declaration);
+            if (declaration.kind === 180 /* ConstructSignature */) {
+              displayParts.push(keywordPart(105 /* NewKeyword */));
+              displayParts.push(spacePart());
+            } else if (declaration.kind !== 179 /* CallSignature */ && declaration.name) {
+              addFullSymbolName(declaration.symbol);
+            }
+            addRange(displayParts, signatureToDisplayParts(typeChecker, signature, sourceFile, 32 /* WriteTypeArgumentsOfSignature */));
+          } else if (isTypeAliasDeclaration(declaration)) {
+            addInPrefix();
+            displayParts.push(keywordPart(156 /* TypeKeyword */));
+            displayParts.push(spacePart());
+            addFullSymbolName(declaration.symbol);
+            writeTypeParametersOfSymbol(declaration.symbol, sourceFile);
           }
         }
-        function isStaticSymbol(symbol) {
-          if (!symbol.valueDeclaration)
-            return false;
-          const modifierFlags = getEffectiveModifierFlags(symbol.valueDeclaration);
-          return !!(modifierFlags & 32 /* Static */);
-        }
-        function getRelatedSymbol(search, referenceSymbol, referenceLocation, state) {
-          const { checker } = state;
-          return forEachRelatedSymbol(
-            referenceSymbol,
-            referenceLocation,
-            checker,
-            /*isForRenamePopulateSearchSymbolSet*/
-            false,
-            /*onlyIncludeBindingElementAtReferenceLocation*/
-            state.options.use !== 2 /* Rename */ || !!state.options.providePrefixAndSuffixTextForRename,
-            (sym, rootSymbol, baseSymbol, kind) => {
-              if (baseSymbol) {
-                if (isStaticSymbol(referenceSymbol) !== isStaticSymbol(baseSymbol)) {
-                  baseSymbol = void 0;
-                }
-              }
-              return search.includes(baseSymbol || rootSymbol || sym) ? { symbol: rootSymbol && !(getCheckFlags(sym) & 6 /* Synthetic */) ? rootSymbol : sym, kind } : void 0;
-            },
-            /*allowBaseTypes*/
-            (rootSymbol) => !(search.parents && !search.parents.some((parent2) => explicitlyInheritsFrom(rootSymbol.parent, parent2, state.inheritsFromCache, checker)))
-          );
+      }
+    }
+    if (symbolFlags & 8 /* EnumMember */) {
+      symbolKind = "enum member" /* enumMemberElement */;
+      addPrefixForAnyFunctionOrVar(symbol, "enum member");
+      const declaration = (_a = symbol.declarations) == null ? void 0 : _a[0];
+      if ((declaration == null ? void 0 : declaration.kind) === 306 /* EnumMember */) {
+        const constantValue = typeChecker.getConstantValue(declaration);
+        if (constantValue !== void 0) {
+          displayParts.push(spacePart());
+          displayParts.push(operatorPart(64 /* EqualsToken */));
+          displayParts.push(spacePart());
+          displayParts.push(displayPart(getTextOfConstantValue(constantValue), typeof constantValue === "number" ? 7 /* numericLiteral */ : 8 /* stringLiteral */));
         }
-        function getIntersectingMeaningFromDeclarations(node, symbol) {
-          let meaning = getMeaningFromLocation(node);
-          const { declarations } = symbol;
-          if (declarations) {
-            let lastIterationMeaning;
-            do {
-              lastIterationMeaning = meaning;
-              for (const declaration of declarations) {
-                const declarationMeaning = getMeaningFromDeclaration(declaration);
-                if (declarationMeaning & meaning) {
-                  meaning |= declarationMeaning;
-                }
-              }
-            } while (meaning !== lastIterationMeaning);
+      }
+    }
+    if (symbol.flags & 2097152 /* Alias */) {
+      prefixNextMeaning();
+      if (!hasAddedSymbolInfo || documentation.length === 0 && tags.length === 0) {
+        const resolvedSymbol = typeChecker.getAliasedSymbol(symbol);
+        if (resolvedSymbol !== symbol && resolvedSymbol.declarations && resolvedSymbol.declarations.length > 0) {
+          const resolvedNode = resolvedSymbol.declarations[0];
+          const declarationName = getNameOfDeclaration(resolvedNode);
+          if (declarationName && !hasAddedSymbolInfo) {
+            const isExternalModuleDeclaration = isModuleWithStringLiteralName(resolvedNode) && hasSyntacticModifier(resolvedNode, 128 /* Ambient */);
+            const shouldUseAliasName = symbol.name !== "default" && !isExternalModuleDeclaration;
+            const resolvedInfo = getSymbolDisplayPartsDocumentationAndSymbolKindWorker(
+              typeChecker,
+              resolvedSymbol,
+              getSourceFileOfNode(resolvedNode),
+              resolvedNode,
+              declarationName,
+              type,
+              semanticMeaning,
+              shouldUseAliasName ? symbol : resolvedSymbol
+            );
+            displayParts.push(...resolvedInfo.displayParts);
+            displayParts.push(lineBreakPart());
+            documentationFromAlias = resolvedInfo.documentation;
+            tagsFromAlias = resolvedInfo.tags;
+          } else {
+            documentationFromAlias = resolvedSymbol.getContextualDocumentationComment(resolvedNode, typeChecker);
+            tagsFromAlias = resolvedSymbol.getJsDocTags(typeChecker);
           }
-          return meaning;
         }
-        Core2.getIntersectingMeaningFromDeclarations = getIntersectingMeaningFromDeclarations;
-        function isImplementation(node) {
-          return !!(node.flags & 16777216 /* Ambient */) ? !(isInterfaceDeclaration(node) || isTypeAliasDeclaration(node)) : isVariableLike(node) ? hasInitializer(node) : isFunctionLikeDeclaration(node) ? !!node.body : isClassLike(node) || isModuleOrEnumDeclaration(node);
+      }
+      if (symbol.declarations) {
+        switch (symbol.declarations[0].kind) {
+          case 270 /* NamespaceExportDeclaration */:
+            displayParts.push(keywordPart(95 /* ExportKeyword */));
+            displayParts.push(spacePart());
+            displayParts.push(keywordPart(145 /* NamespaceKeyword */));
+            break;
+          case 277 /* ExportAssignment */:
+            displayParts.push(keywordPart(95 /* ExportKeyword */));
+            displayParts.push(spacePart());
+            displayParts.push(keywordPart(symbol.declarations[0].isExportEquals ? 64 /* EqualsToken */ : 90 /* DefaultKeyword */));
+            break;
+          case 281 /* ExportSpecifier */:
+            displayParts.push(keywordPart(95 /* ExportKeyword */));
+            break;
+          default:
+            displayParts.push(keywordPart(102 /* ImportKeyword */));
         }
-        function getReferenceEntriesForShorthandPropertyAssignment(node, checker, addReference2) {
-          const refSymbol = checker.getSymbolAtLocation(node);
-          const shorthandSymbol = checker.getShorthandAssignmentValueSymbol(refSymbol.valueDeclaration);
-          if (shorthandSymbol) {
-            for (const declaration of shorthandSymbol.getDeclarations()) {
-              if (getMeaningFromDeclaration(declaration) & 1 /* Value */) {
-                addReference2(declaration);
-              }
+      }
+      displayParts.push(spacePart());
+      addFullSymbolName(symbol);
+      forEach(symbol.declarations, (declaration) => {
+        if (declaration.kind === 271 /* ImportEqualsDeclaration */) {
+          const importEqualsDeclaration = declaration;
+          if (isExternalModuleImportEqualsDeclaration(importEqualsDeclaration)) {
+            displayParts.push(spacePart());
+            displayParts.push(operatorPart(64 /* EqualsToken */));
+            displayParts.push(spacePart());
+            displayParts.push(keywordPart(149 /* RequireKeyword */));
+            displayParts.push(punctuationPart(21 /* OpenParenToken */));
+            displayParts.push(displayPart(getTextOfNode(getExternalModuleImportEqualsDeclarationExpression(importEqualsDeclaration)), 8 /* stringLiteral */));
+            displayParts.push(punctuationPart(22 /* CloseParenToken */));
+          } else {
+            const internalAliasSymbol = typeChecker.getSymbolAtLocation(importEqualsDeclaration.moduleReference);
+            if (internalAliasSymbol) {
+              displayParts.push(spacePart());
+              displayParts.push(operatorPart(64 /* EqualsToken */));
+              displayParts.push(spacePart());
+              addFullSymbolName(internalAliasSymbol, enclosingDeclaration);
             }
           }
+          return true;
         }
-        Core2.getReferenceEntriesForShorthandPropertyAssignment = getReferenceEntriesForShorthandPropertyAssignment;
-        function forEachDescendantOfKind(node, kind, action) {
-          forEachChild(node, (child) => {
-            if (child.kind === kind) {
-              action(child);
+      });
+    }
+    if (!hasAddedSymbolInfo) {
+      if (symbolKind !== "" /* unknown */) {
+        if (type) {
+          if (isThisExpression) {
+            prefixNextMeaning();
+            displayParts.push(keywordPart(110 /* ThisKeyword */));
+          } else {
+            addPrefixForAnyFunctionOrVar(symbol, symbolKind);
+          }
+          if (symbolKind === "property" /* memberVariableElement */ || symbolKind === "accessor" /* memberAccessorVariableElement */ || symbolKind === "getter" /* memberGetAccessorElement */ || symbolKind === "setter" /* memberSetAccessorElement */ || symbolKind === "JSX attribute" /* jsxAttribute */ || symbolFlags & 3 /* Variable */ || symbolKind === "local var" /* localVariableElement */ || symbolKind === "index" /* indexSignatureElement */ || symbolKind === "using" /* variableUsingElement */ || symbolKind === "await using" /* variableAwaitUsingElement */ || isThisExpression) {
+            displayParts.push(punctuationPart(59 /* ColonToken */));
+            displayParts.push(spacePart());
+            if (type.symbol && type.symbol.flags & 262144 /* TypeParameter */ && symbolKind !== "index" /* indexSignatureElement */) {
+              const typeParameterParts = mapToDisplayParts((writer) => {
+                const param = typeChecker.typeParameterToDeclaration(type, enclosingDeclaration, symbolDisplayNodeBuilderFlags);
+                getPrinter().writeNode(4 /* Unspecified */, param, getSourceFileOfNode(getParseTreeNode(enclosingDeclaration)), writer);
+              });
+              addRange(displayParts, typeParameterParts);
+            } else {
+              addRange(displayParts, typeToDisplayParts(typeChecker, type, enclosingDeclaration));
             }
-            forEachDescendantOfKind(child, kind, action);
-          });
+            if (isTransientSymbol(symbol) && symbol.links.target && isTransientSymbol(symbol.links.target) && symbol.links.target.links.tupleLabelDeclaration) {
+              const labelDecl = symbol.links.target.links.tupleLabelDeclaration;
+              Debug.assertNode(labelDecl.name, isIdentifier);
+              displayParts.push(spacePart());
+              displayParts.push(punctuationPart(21 /* OpenParenToken */));
+              displayParts.push(textPart(idText(labelDecl.name)));
+              displayParts.push(punctuationPart(22 /* CloseParenToken */));
+            }
+          } else if (symbolFlags & 16 /* Function */ || symbolFlags & 8192 /* Method */ || symbolFlags & 16384 /* Constructor */ || symbolFlags & 131072 /* Signature */ || symbolFlags & 98304 /* Accessor */ || symbolKind === "method" /* memberFunctionElement */) {
+            const allSignatures = type.getNonNullableType().getCallSignatures();
+            if (allSignatures.length) {
+              addSignatureDisplayParts(allSignatures[0], allSignatures);
+              hasMultipleSignatures = allSignatures.length > 1;
+            }
+          }
         }
-        function tryGetClassByExtendingIdentifier(node) {
-          return tryGetClassExtendingExpressionWithTypeArguments(climbPastPropertyAccess(node).parent);
+      } else {
+        symbolKind = getSymbolKind(typeChecker, symbol, location);
+      }
+    }
+    if (documentation.length === 0 && !hasMultipleSignatures) {
+      documentation = symbol.getContextualDocumentationComment(enclosingDeclaration, typeChecker);
+    }
+    if (documentation.length === 0 && symbolFlags & 4 /* Property */) {
+      if (symbol.parent && symbol.declarations && forEach(symbol.parent.declarations, (declaration) => declaration.kind === 312 /* SourceFile */)) {
+        for (const declaration of symbol.declarations) {
+          if (!declaration.parent || declaration.parent.kind !== 226 /* BinaryExpression */) {
+            continue;
+          }
+          const rhsSymbol = typeChecker.getSymbolAtLocation(declaration.parent.right);
+          if (!rhsSymbol) {
+            continue;
+          }
+          documentation = rhsSymbol.getDocumentationComment(typeChecker);
+          tags = rhsSymbol.getJsDocTags(typeChecker);
+          if (documentation.length > 0) {
+            break;
+          }
         }
-        function getParentSymbolsOfPropertyAccess(location, symbol, checker) {
-          const propertyAccessExpression = isRightSideOfPropertyAccess(location) ? location.parent : void 0;
-          const lhsType = propertyAccessExpression && checker.getTypeAtLocation(propertyAccessExpression.expression);
-          const res = mapDefined(lhsType && (lhsType.isUnionOrIntersection() ? lhsType.types : lhsType.symbol === symbol.parent ? void 0 : [lhsType]), (t) => t.symbol && t.symbol.flags & (32 /* Class */ | 64 /* Interface */) ? t.symbol : void 0);
-          return res.length === 0 ? void 0 : res;
+      }
+    }
+    if (documentation.length === 0 && isIdentifier(location) && symbol.valueDeclaration && isBindingElement(symbol.valueDeclaration)) {
+      const declaration = symbol.valueDeclaration;
+      const parent2 = declaration.parent;
+      const name = declaration.propertyName || declaration.name;
+      if (isIdentifier(name) && isObjectBindingPattern(parent2)) {
+        const propertyName = getTextOfIdentifierOrLiteral(name);
+        const objectType = typeChecker.getTypeAtLocation(parent2);
+        documentation = firstDefined(objectType.isUnion() ? objectType.types : [objectType], (t) => {
+          const prop = t.getProperty(propertyName);
+          return prop ? prop.getDocumentationComment(typeChecker) : void 0;
+        }) || emptyArray;
+      }
+    }
+    if (tags.length === 0 && !hasMultipleSignatures) {
+      tags = symbol.getContextualJsDocTags(enclosingDeclaration, typeChecker);
+    }
+    if (documentation.length === 0 && documentationFromAlias) {
+      documentation = documentationFromAlias;
+    }
+    if (tags.length === 0 && tagsFromAlias) {
+      tags = tagsFromAlias;
+    }
+    return { displayParts, documentation, symbolKind, tags: tags.length === 0 ? void 0 : tags };
+    function getPrinter() {
+      return createPrinterWithRemoveComments();
+    }
+    function prefixNextMeaning() {
+      if (displayParts.length) {
+        displayParts.push(lineBreakPart());
+      }
+      addAliasPrefixIfNecessary();
+    }
+    function addAliasPrefixIfNecessary() {
+      if (alias) {
+        pushSymbolKind("alias" /* alias */);
+        displayParts.push(spacePart());
+      }
+    }
+    function addInPrefix() {
+      displayParts.push(spacePart());
+      displayParts.push(keywordPart(103 /* InKeyword */));
+      displayParts.push(spacePart());
+    }
+    function addFullSymbolName(symbolToDisplay, enclosingDeclaration2) {
+      let indexInfos;
+      if (alias && symbolToDisplay === symbol) {
+        symbolToDisplay = alias;
+      }
+      if (symbolKind === "index" /* indexSignatureElement */) {
+        indexInfos = typeChecker.getIndexInfosOfIndexSymbol(symbolToDisplay);
+      }
+      let fullSymbolDisplayParts = [];
+      if (symbolToDisplay.flags & 131072 /* Signature */ && indexInfos) {
+        if (symbolToDisplay.parent) {
+          fullSymbolDisplayParts = symbolToDisplayParts(typeChecker, symbolToDisplay.parent);
         }
-        function isForRenameWithPrefixAndSuffixText(options) {
-          return options.use === 2 /* Rename */ && options.providePrefixAndSuffixTextForRename;
+        fullSymbolDisplayParts.push(punctuationPart(23 /* OpenBracketToken */));
+        indexInfos.forEach((info, i) => {
+          fullSymbolDisplayParts.push(...typeToDisplayParts(typeChecker, info.keyType));
+          if (i !== indexInfos.length - 1) {
+            fullSymbolDisplayParts.push(spacePart());
+            fullSymbolDisplayParts.push(punctuationPart(52 /* BarToken */));
+            fullSymbolDisplayParts.push(spacePart());
+          }
+        });
+        fullSymbolDisplayParts.push(punctuationPart(24 /* CloseBracketToken */));
+      } else {
+        fullSymbolDisplayParts = symbolToDisplayParts(
+          typeChecker,
+          symbolToDisplay,
+          enclosingDeclaration2 || sourceFile,
+          /*meaning*/
+          void 0,
+          1 /* WriteTypeParametersOrArguments */ | 2 /* UseOnlyExternalAliasing */ | 4 /* AllowAnyNodeKind */
+        );
+      }
+      addRange(displayParts, fullSymbolDisplayParts);
+      if (symbol.flags & 16777216 /* Optional */) {
+        displayParts.push(punctuationPart(58 /* QuestionToken */));
+      }
+    }
+    function addPrefixForAnyFunctionOrVar(symbol2, symbolKind2) {
+      prefixNextMeaning();
+      if (symbolKind2) {
+        pushSymbolKind(symbolKind2);
+        if (symbol2 && !some(symbol2.declarations, (d) => isArrowFunction(d) || (isFunctionExpression(d) || isClassExpression(d)) && !d.name)) {
+          displayParts.push(spacePart());
+          addFullSymbolName(symbol2);
         }
-      })(Core || (Core = {}));
+      }
+    }
+    function pushSymbolKind(symbolKind2) {
+      switch (symbolKind2) {
+        case "var" /* variableElement */:
+        case "function" /* functionElement */:
+        case "let" /* letElement */:
+        case "const" /* constElement */:
+        case "constructor" /* constructorImplementationElement */:
+        case "using" /* variableUsingElement */:
+        case "await using" /* variableAwaitUsingElement */:
+          displayParts.push(textOrKeywordPart(symbolKind2));
+          return;
+        default:
+          displayParts.push(punctuationPart(21 /* OpenParenToken */));
+          displayParts.push(textOrKeywordPart(symbolKind2));
+          displayParts.push(punctuationPart(22 /* CloseParenToken */));
+          return;
+      }
+    }
+    function addSignatureDisplayParts(signature, allSignatures, flags = 0 /* None */) {
+      addRange(displayParts, signatureToDisplayParts(typeChecker, signature, enclosingDeclaration, flags | 32 /* WriteTypeArgumentsOfSignature */));
+      if (allSignatures.length > 1) {
+        displayParts.push(spacePart());
+        displayParts.push(punctuationPart(21 /* OpenParenToken */));
+        displayParts.push(operatorPart(40 /* PlusToken */));
+        displayParts.push(displayPart((allSignatures.length - 1).toString(), 7 /* numericLiteral */));
+        displayParts.push(spacePart());
+        displayParts.push(textPart(allSignatures.length === 2 ? "overload" : "overloads"));
+        displayParts.push(punctuationPart(22 /* CloseParenToken */));
+      }
+      documentation = signature.getDocumentationComment(typeChecker);
+      tags = signature.getJsDocTags();
+      if (allSignatures.length > 1 && documentation.length === 0 && tags.length === 0) {
+        documentation = allSignatures[0].getDocumentationComment(typeChecker);
+        tags = allSignatures[0].getJsDocTags().filter((tag) => tag.name !== "deprecated");
+      }
+    }
+    function writeTypeParametersOfSymbol(symbol2, enclosingDeclaration2) {
+      const typeParameterParts = mapToDisplayParts((writer) => {
+        const params = typeChecker.symbolToTypeParameterDeclarations(symbol2, enclosingDeclaration2, symbolDisplayNodeBuilderFlags);
+        getPrinter().writeList(53776 /* TypeParameters */, params, getSourceFileOfNode(getParseTreeNode(enclosingDeclaration2)), writer);
+      });
+      addRange(displayParts, typeParameterParts);
+    }
+  }
+  function getSymbolDisplayPartsDocumentationAndSymbolKind(typeChecker, symbol, sourceFile, enclosingDeclaration, location, semanticMeaning = getMeaningFromLocation(location), alias) {
+    return getSymbolDisplayPartsDocumentationAndSymbolKindWorker(
+      typeChecker,
+      symbol,
+      sourceFile,
+      enclosingDeclaration,
+      location,
+      /*type*/
+      void 0,
+      semanticMeaning,
+      alias
+    );
+  }
+  function isLocalVariableOrFunction(symbol) {
+    if (symbol.parent) {
+      return false;
+    }
+    return forEach(symbol.declarations, (declaration) => {
+      if (declaration.kind === 218 /* FunctionExpression */) {
+        return true;
+      }
+      if (declaration.kind !== 260 /* VariableDeclaration */ && declaration.kind !== 262 /* FunctionDeclaration */) {
+        return false;
+      }
+      for (let parent2 = declaration.parent; !isFunctionBlock(parent2); parent2 = parent2.parent) {
+        if (parent2.kind === 312 /* SourceFile */ || parent2.kind === 268 /* ModuleBlock */) {
+          return false;
+        }
+      }
+      return true;
+    });
+  }
+  var symbolDisplayNodeBuilderFlags;
+  var init_symbolDisplay = __esm({
+    "src/services/symbolDisplay.ts"() {
+      "use strict";
+      init_ts4();
+      symbolDisplayNodeBuilderFlags = 8192 /* OmitParameterModifiers */ | 70221824 /* IgnoreErrors */ | 16384 /* UseAliasDefinedOutsideCurrentScope */;
     }
   });
 
-  // src/services/_namespaces/ts.FindAllReferences.ts
-  var ts_FindAllReferences_exports = {};
-  __export(ts_FindAllReferences_exports, {
-    Core: () => Core,
-    DefinitionKind: () => DefinitionKind,
-    EntryKind: () => EntryKind,
-    ExportKind: () => ExportKind2,
-    FindReferencesUse: () => FindReferencesUse,
-    ImportExport: () => ImportExport,
-    createImportTracker: () => createImportTracker,
-    findModuleReferences: () => findModuleReferences,
-    findReferenceOrRenameEntries: () => findReferenceOrRenameEntries,
-    findReferencedSymbols: () => findReferencedSymbols,
-    getContextNode: () => getContextNode,
-    getExportInfo: () => getExportInfo,
-    getImplementationsAtPosition: () => getImplementationsAtPosition,
-    getImportOrExportSymbol: () => getImportOrExportSymbol,
-    getReferenceEntriesForNode: () => getReferenceEntriesForNode,
-    getTextSpanOfEntry: () => getTextSpanOfEntry,
-    isContextWithStartAndEndNode: () => isContextWithStartAndEndNode,
-    isDeclarationOfSymbol: () => isDeclarationOfSymbol,
-    nodeEntry: () => nodeEntry,
-    toContextSpan: () => toContextSpan,
-    toHighlightSpan: () => toHighlightSpan,
-    toReferenceEntry: () => toReferenceEntry,
-    toRenameLocation: () => toRenameLocation
+  // src/services/_namespaces/ts.SymbolDisplay.ts
+  var ts_SymbolDisplay_exports = {};
+  __export(ts_SymbolDisplay_exports, {
+    getSymbolDisplayPartsDocumentationAndSymbolKind: () => getSymbolDisplayPartsDocumentationAndSymbolKind,
+    getSymbolKind: () => getSymbolKind,
+    getSymbolModifiers: () => getSymbolModifiers
   });
-  var init_ts_FindAllReferences = __esm({
-    "src/services/_namespaces/ts.FindAllReferences.ts"() {
+  var init_ts_SymbolDisplay = __esm({
+    "src/services/_namespaces/ts.SymbolDisplay.ts"() {
       "use strict";
-      init_importTracker();
-      init_findAllReferences();
+      init_symbolDisplay();
     }
   });
 
-  // src/services/goToDefinition.ts
-  function getDefinitionAtPosition(program, sourceFile, position, searchOtherFilesOnly, stopAtAlias) {
+  // src/services/textChanges.ts
+  function getPos2(n) {
+    const result = n.__pos;
+    Debug.assert(typeof result === "number");
+    return result;
+  }
+  function setPos(n, pos) {
+    Debug.assert(typeof pos === "number");
+    n.__pos = pos;
+  }
+  function getEnd(n) {
+    const result = n.__end;
+    Debug.assert(typeof result === "number");
+    return result;
+  }
+  function setEnd(n, end) {
+    Debug.assert(typeof end === "number");
+    n.__end = end;
+  }
+  function skipWhitespacesAndLineBreaks(text, start) {
+    return skipTrivia(
+      text,
+      start,
+      /*stopAfterLineBreak*/
+      false,
+      /*stopAtComments*/
+      true
+    );
+  }
+  function hasCommentsBeforeLineBreak(text, start) {
+    let i = start;
+    while (i < text.length) {
+      const ch = text.charCodeAt(i);
+      if (isWhiteSpaceSingleLine(ch)) {
+        i++;
+        continue;
+      }
+      return ch === 47 /* slash */;
+    }
+    return false;
+  }
+  function getAdjustedRange(sourceFile, startNode2, endNode2, options) {
+    return { pos: getAdjustedStartPosition(sourceFile, startNode2, options), end: getAdjustedEndPosition(sourceFile, endNode2, options) };
+  }
+  function getAdjustedStartPosition(sourceFile, node, options, hasTrailingComment = false) {
     var _a, _b;
-    const resolvedRef = getReferenceAtPosition(sourceFile, position, program);
-    const fileReferenceDefinition = resolvedRef && [getDefinitionInfoForFileReference(resolvedRef.reference.fileName, resolvedRef.fileName, resolvedRef.unverified)] || emptyArray;
-    if (resolvedRef == null ? void 0 : resolvedRef.file) {
-      return fileReferenceDefinition;
+    const { leadingTriviaOption } = options;
+    if (leadingTriviaOption === 0 /* Exclude */) {
+      return node.getStart(sourceFile);
     }
-    const node = getTouchingPropertyName(sourceFile, position);
-    if (node === sourceFile) {
+    if (leadingTriviaOption === 3 /* StartLine */) {
+      const startPos = node.getStart(sourceFile);
+      const pos = getLineStartPositionForPosition(startPos, sourceFile);
+      return rangeContainsPosition(node, pos) ? pos : startPos;
+    }
+    if (leadingTriviaOption === 2 /* JSDoc */) {
+      const JSDocComments = getJSDocCommentRanges(node, sourceFile.text);
+      if (JSDocComments == null ? void 0 : JSDocComments.length) {
+        return getLineStartPositionForPosition(JSDocComments[0].pos, sourceFile);
+      }
+    }
+    const fullStart = node.getFullStart();
+    const start = node.getStart(sourceFile);
+    if (fullStart === start) {
+      return start;
+    }
+    const fullStartLine = getLineStartPositionForPosition(fullStart, sourceFile);
+    const startLine = getLineStartPositionForPosition(start, sourceFile);
+    if (startLine === fullStartLine) {
+      return leadingTriviaOption === 1 /* IncludeAll */ ? fullStart : start;
+    }
+    if (hasTrailingComment) {
+      const comment = ((_a = getLeadingCommentRanges(sourceFile.text, fullStart)) == null ? void 0 : _a[0]) || ((_b = getTrailingCommentRanges(sourceFile.text, fullStart)) == null ? void 0 : _b[0]);
+      if (comment) {
+        return skipTrivia(
+          sourceFile.text,
+          comment.end,
+          /*stopAfterLineBreak*/
+          true,
+          /*stopAtComments*/
+          true
+        );
+      }
+    }
+    const nextLineStart = fullStart > 0 ? 1 : 0;
+    let adjustedStartPosition = getStartPositionOfLine(getLineOfLocalPosition(sourceFile, fullStartLine) + nextLineStart, sourceFile);
+    adjustedStartPosition = skipWhitespacesAndLineBreaks(sourceFile.text, adjustedStartPosition);
+    return getStartPositionOfLine(getLineOfLocalPosition(sourceFile, adjustedStartPosition), sourceFile);
+  }
+  function getEndPositionOfMultilineTrailingComment(sourceFile, node, options) {
+    const { end } = node;
+    const { trailingTriviaOption } = options;
+    if (trailingTriviaOption === 2 /* Include */) {
+      const comments = getTrailingCommentRanges(sourceFile.text, end);
+      if (comments) {
+        const nodeEndLine = getLineOfLocalPosition(sourceFile, node.end);
+        for (const comment of comments) {
+          if (comment.kind === 2 /* SingleLineCommentTrivia */ || getLineOfLocalPosition(sourceFile, comment.pos) > nodeEndLine) {
+            break;
+          }
+          const commentEndLine = getLineOfLocalPosition(sourceFile, comment.end);
+          if (commentEndLine > nodeEndLine) {
+            return skipTrivia(
+              sourceFile.text,
+              comment.end,
+              /*stopAfterLineBreak*/
+              true,
+              /*stopAtComments*/
+              true
+            );
+          }
+        }
+      }
+    }
+    return void 0;
+  }
+  function getAdjustedEndPosition(sourceFile, node, options) {
+    var _a;
+    const { end } = node;
+    const { trailingTriviaOption } = options;
+    if (trailingTriviaOption === 0 /* Exclude */) {
+      return end;
+    }
+    if (trailingTriviaOption === 1 /* ExcludeWhitespace */) {
+      const comments = concatenate(getTrailingCommentRanges(sourceFile.text, end), getLeadingCommentRanges(sourceFile.text, end));
+      const realEnd = (_a = comments == null ? void 0 : comments[comments.length - 1]) == null ? void 0 : _a.end;
+      if (realEnd) {
+        return realEnd;
+      }
+      return end;
+    }
+    const multilineEndPosition = getEndPositionOfMultilineTrailingComment(sourceFile, node, options);
+    if (multilineEndPosition) {
+      return multilineEndPosition;
+    }
+    const newEnd = skipTrivia(
+      sourceFile.text,
+      end,
+      /*stopAfterLineBreak*/
+      true
+    );
+    return newEnd !== end && (trailingTriviaOption === 2 /* Include */ || isLineBreak(sourceFile.text.charCodeAt(newEnd - 1))) ? newEnd : end;
+  }
+  function isSeparator(node, candidate) {
+    return !!candidate && !!node.parent && (candidate.kind === 28 /* CommaToken */ || candidate.kind === 27 /* SemicolonToken */ && node.parent.kind === 210 /* ObjectLiteralExpression */);
+  }
+  function isThisTypeAnnotatable(containingFunction) {
+    return isFunctionExpression(containingFunction) || isFunctionDeclaration(containingFunction);
+  }
+  function updateJSDocHost(parent2) {
+    if (parent2.kind !== 219 /* ArrowFunction */) {
+      return parent2;
+    }
+    const jsDocNode = parent2.parent.kind === 172 /* PropertyDeclaration */ ? parent2.parent : parent2.parent.parent;
+    jsDocNode.jsDoc = parent2.jsDoc;
+    return jsDocNode;
+  }
+  function tryMergeJsdocTags(oldTag, newTag) {
+    if (oldTag.kind !== newTag.kind) {
       return void 0;
     }
-    const { parent: parent2 } = node;
-    const typeChecker = program.getTypeChecker();
-    if (node.kind === 163 /* OverrideKeyword */ || isIdentifier(node) && isJSDocOverrideTag(parent2) && parent2.tagName === node) {
-      return getDefinitionFromOverriddenMember(typeChecker, node) || emptyArray;
+    switch (oldTag.kind) {
+      case 348 /* JSDocParameterTag */: {
+        const oldParam = oldTag;
+        const newParam = newTag;
+        return isIdentifier(oldParam.name) && isIdentifier(newParam.name) && oldParam.name.escapedText === newParam.name.escapedText ? factory.createJSDocParameterTag(
+          /*tagName*/
+          void 0,
+          newParam.name,
+          /*isBracketed*/
+          false,
+          newParam.typeExpression,
+          newParam.isNameFirst,
+          oldParam.comment
+        ) : void 0;
+      }
+      case 349 /* JSDocReturnTag */:
+        return factory.createJSDocReturnTag(
+          /*tagName*/
+          void 0,
+          newTag.typeExpression,
+          oldTag.comment
+        );
+      case 351 /* JSDocTypeTag */:
+        return factory.createJSDocTypeTag(
+          /*tagName*/
+          void 0,
+          newTag.typeExpression,
+          oldTag.comment
+        );
     }
-    if (isJumpStatementTarget(node)) {
-      const label = getTargetLabel(node.parent, node.text);
-      return label ? [createDefinitionInfoFromName(
-        typeChecker,
-        label,
-        "label" /* label */,
-        node.text,
-        /*containerName*/
-        void 0
-      )] : void 0;
+  }
+  function startPositionToDeleteNodeInList(sourceFile, node) {
+    return skipTrivia(
+      sourceFile.text,
+      getAdjustedStartPosition(sourceFile, node, { leadingTriviaOption: 1 /* IncludeAll */ }),
+      /*stopAfterLineBreak*/
+      false,
+      /*stopAtComments*/
+      true
+    );
+  }
+  function endPositionToDeleteNodeInList(sourceFile, node, prevNode, nextNode) {
+    const end = startPositionToDeleteNodeInList(sourceFile, nextNode);
+    if (prevNode === void 0 || positionsAreOnSameLine(getAdjustedEndPosition(sourceFile, node, {}), end, sourceFile)) {
+      return end;
     }
-    if (node.kind === 107 /* ReturnKeyword */) {
-      const functionDeclaration = findAncestor(node.parent, (n) => isClassStaticBlockDeclaration(n) ? "quit" : isFunctionLikeDeclaration(n));
-      return functionDeclaration ? [createDefinitionFromSignatureDeclaration(typeChecker, functionDeclaration)] : void 0;
+    const token = findPrecedingToken(nextNode.getStart(sourceFile), sourceFile);
+    if (isSeparator(node, token)) {
+      const prevToken = findPrecedingToken(node.getStart(sourceFile), sourceFile);
+      if (isSeparator(prevNode, prevToken)) {
+        const pos = skipTrivia(
+          sourceFile.text,
+          token.getEnd(),
+          /*stopAfterLineBreak*/
+          true,
+          /*stopAtComments*/
+          true
+        );
+        if (positionsAreOnSameLine(prevToken.getStart(sourceFile), token.getStart(sourceFile), sourceFile)) {
+          return isLineBreak(sourceFile.text.charCodeAt(pos - 1)) ? pos - 1 : pos;
+        }
+        if (isLineBreak(sourceFile.text.charCodeAt(pos))) {
+          return pos;
+        }
+      }
+    }
+    return end;
+  }
+  function getClassOrObjectBraceEnds(cls, sourceFile) {
+    const open = findChildOfKind(cls, 19 /* OpenBraceToken */, sourceFile);
+    const close = findChildOfKind(cls, 20 /* CloseBraceToken */, sourceFile);
+    return [open == null ? void 0 : open.end, close == null ? void 0 : close.end];
+  }
+  function getMembersOrProperties(node) {
+    return isObjectLiteralExpression(node) ? node.properties : node.members;
+  }
+  function applyChanges(text, changes) {
+    for (let i = changes.length - 1; i >= 0; i--) {
+      const { span, newText } = changes[i];
+      text = `${text.substring(0, span.start)}${newText}${text.substring(textSpanEnd(span))}`;
+    }
+    return text;
+  }
+  function isTrivia2(s) {
+    return skipTrivia(s, 0) === s.length;
+  }
+  function assignPositionsToNode(node) {
+    const visited = visitEachChild(node, assignPositionsToNode, textChangesTransformationContext, assignPositionsToNodeArray, assignPositionsToNode);
+    const newNode = nodeIsSynthesized(visited) ? visited : Object.create(visited);
+    setTextRangePosEnd(newNode, getPos2(node), getEnd(node));
+    return newNode;
+  }
+  function assignPositionsToNodeArray(nodes, visitor, test, start, count) {
+    const visited = visitNodes2(nodes, visitor, test, start, count);
+    if (!visited) {
+      return visited;
+    }
+    Debug.assert(nodes);
+    const nodeArray = visited === nodes ? factory.createNodeArray(visited.slice(0)) : visited;
+    setTextRangePosEnd(nodeArray, getPos2(nodes), getEnd(nodes));
+    return nodeArray;
+  }
+  function createWriter(newLine) {
+    let lastNonTriviaPosition = 0;
+    const writer = createTextWriter(newLine);
+    const onBeforeEmitNode = (node) => {
+      if (node) {
+        setPos(node, lastNonTriviaPosition);
+      }
+    };
+    const onAfterEmitNode = (node) => {
+      if (node) {
+        setEnd(node, lastNonTriviaPosition);
+      }
+    };
+    const onBeforeEmitNodeArray = (nodes) => {
+      if (nodes) {
+        setPos(nodes, lastNonTriviaPosition);
+      }
+    };
+    const onAfterEmitNodeArray = (nodes) => {
+      if (nodes) {
+        setEnd(nodes, lastNonTriviaPosition);
+      }
+    };
+    const onBeforeEmitToken = (node) => {
+      if (node) {
+        setPos(node, lastNonTriviaPosition);
+      }
+    };
+    const onAfterEmitToken = (node) => {
+      if (node) {
+        setEnd(node, lastNonTriviaPosition);
+      }
+    };
+    function setLastNonTriviaPosition(s, force) {
+      if (force || !isTrivia2(s)) {
+        lastNonTriviaPosition = writer.getTextPos();
+        let i = 0;
+        while (isWhiteSpaceLike(s.charCodeAt(s.length - i - 1))) {
+          i++;
+        }
+        lastNonTriviaPosition -= i;
+      }
     }
-    if (node.kind === 135 /* AwaitKeyword */) {
-      const functionDeclaration = findAncestor(node, (n) => isFunctionLikeDeclaration(n));
-      const isAsyncFunction2 = functionDeclaration && some(functionDeclaration.modifiers, (node2) => node2.kind === 134 /* AsyncKeyword */);
-      return isAsyncFunction2 ? [createDefinitionFromSignatureDeclaration(typeChecker, functionDeclaration)] : void 0;
+    function write(s) {
+      writer.write(s);
+      setLastNonTriviaPosition(
+        s,
+        /*force*/
+        false
+      );
     }
-    if (node.kind === 127 /* YieldKeyword */) {
-      const functionDeclaration = findAncestor(node, (n) => isFunctionLikeDeclaration(n));
-      const isGeneratorFunction = functionDeclaration && functionDeclaration.asteriskToken;
-      return isGeneratorFunction ? [createDefinitionFromSignatureDeclaration(typeChecker, functionDeclaration)] : void 0;
+    function writeComment(s) {
+      writer.writeComment(s);
     }
-    if (isStaticModifier(node) && isClassStaticBlockDeclaration(node.parent)) {
-      const classDecl = node.parent.parent;
-      const { symbol: symbol2, failedAliasResolution: failedAliasResolution2 } = getSymbol(classDecl, typeChecker, stopAtAlias);
-      const staticBlocks = filter(classDecl.members, isClassStaticBlockDeclaration);
-      const containerName = symbol2 ? typeChecker.symbolToString(symbol2, classDecl) : "";
-      const sourceFile2 = node.getSourceFile();
-      return map(staticBlocks, (staticBlock) => {
-        let { pos } = moveRangePastModifiers(staticBlock);
-        pos = skipTrivia(sourceFile2.text, pos);
-        return createDefinitionInfoFromName(
-          typeChecker,
-          staticBlock,
-          "constructor" /* constructorImplementationElement */,
-          "static {}",
-          containerName,
-          /*unverified*/
-          false,
-          failedAliasResolution2,
-          { start: pos, length: "static".length }
-        );
-      });
+    function writeKeyword(s) {
+      writer.writeKeyword(s);
+      setLastNonTriviaPosition(
+        s,
+        /*force*/
+        false
+      );
     }
-    let { symbol, failedAliasResolution } = getSymbol(node, typeChecker, stopAtAlias);
-    let fallbackNode = node;
-    if (searchOtherFilesOnly && failedAliasResolution) {
-      const importDeclaration = forEach([node, ...(symbol == null ? void 0 : symbol.declarations) || emptyArray], (n) => findAncestor(n, isAnyImportOrBareOrAccessedRequire));
-      const moduleSpecifier = importDeclaration && tryGetModuleSpecifierFromDeclaration(importDeclaration);
-      if (moduleSpecifier) {
-        ({ symbol, failedAliasResolution } = getSymbol(moduleSpecifier, typeChecker, stopAtAlias));
-        fallbackNode = moduleSpecifier;
-      }
+    function writeOperator(s) {
+      writer.writeOperator(s);
+      setLastNonTriviaPosition(
+        s,
+        /*force*/
+        false
+      );
     }
-    if (!symbol && isModuleSpecifierLike(fallbackNode)) {
-      const ref = (_b = (_a = sourceFile.resolvedModules) == null ? void 0 : _a.get(fallbackNode.text, getModeForUsageLocation(sourceFile, fallbackNode))) == null ? void 0 : _b.resolvedModule;
-      if (ref) {
-        return [{
-          name: fallbackNode.text,
-          fileName: ref.resolvedFileName,
-          containerName: void 0,
-          containerKind: void 0,
-          kind: "script" /* scriptElement */,
-          textSpan: createTextSpan(0, 0),
-          failedAliasResolution,
-          isAmbient: isDeclarationFileName(ref.resolvedFileName),
-          unverified: fallbackNode !== node
-        }];
-      }
+    function writePunctuation(s) {
+      writer.writePunctuation(s);
+      setLastNonTriviaPosition(
+        s,
+        /*force*/
+        false
+      );
     }
-    if (!symbol) {
-      return concatenate(fileReferenceDefinition, getDefinitionInfoForIndexSignatures(node, typeChecker));
+    function writeTrailingSemicolon(s) {
+      writer.writeTrailingSemicolon(s);
+      setLastNonTriviaPosition(
+        s,
+        /*force*/
+        false
+      );
     }
-    if (searchOtherFilesOnly && every(symbol.declarations, (d) => d.getSourceFile().fileName === sourceFile.fileName))
-      return void 0;
-    const calledDeclaration = tryGetSignatureDeclaration(typeChecker, node);
-    if (calledDeclaration && !(isJsxOpeningLikeElement(node.parent) && isConstructorLike(calledDeclaration))) {
-      const sigInfo = createDefinitionFromSignatureDeclaration(typeChecker, calledDeclaration, failedAliasResolution);
-      if (typeChecker.getRootSymbols(symbol).some((s) => symbolMatchesSignature(s, calledDeclaration))) {
-        return [sigInfo];
-      } else {
-        const defs = getDefinitionFromSymbol(typeChecker, symbol, node, failedAliasResolution, calledDeclaration) || emptyArray;
-        return node.kind === 108 /* SuperKeyword */ ? [sigInfo, ...defs] : [...defs, sigInfo];
-      }
+    function writeParameter(s) {
+      writer.writeParameter(s);
+      setLastNonTriviaPosition(
+        s,
+        /*force*/
+        false
+      );
     }
-    if (node.parent.kind === 303 /* ShorthandPropertyAssignment */) {
-      const shorthandSymbol = typeChecker.getShorthandAssignmentValueSymbol(symbol.valueDeclaration);
-      const definitions = (shorthandSymbol == null ? void 0 : shorthandSymbol.declarations) ? shorthandSymbol.declarations.map((decl) => createDefinitionInfo(
-        decl,
-        typeChecker,
-        shorthandSymbol,
-        node,
-        /*unverified*/
-        false,
-        failedAliasResolution
-      )) : emptyArray;
-      return concatenate(definitions, getDefinitionFromObjectLiteralElement(typeChecker, node));
+    function writeProperty(s) {
+      writer.writeProperty(s);
+      setLastNonTriviaPosition(
+        s,
+        /*force*/
+        false
+      );
     }
-    if (isPropertyName(node) && isBindingElement(parent2) && isObjectBindingPattern(parent2.parent) && node === (parent2.propertyName || parent2.name)) {
-      const name = getNameFromPropertyName(node);
-      const type = typeChecker.getTypeAtLocation(parent2.parent);
-      return name === void 0 ? emptyArray : flatMap(type.isUnion() ? type.types : [type], (t) => {
-        const prop = t.getProperty(name);
-        return prop && getDefinitionFromSymbol(typeChecker, prop, node);
-      });
+    function writeSpace(s) {
+      writer.writeSpace(s);
+      setLastNonTriviaPosition(
+        s,
+        /*force*/
+        false
+      );
     }
-    const objectLiteralElementDefinition = getDefinitionFromObjectLiteralElement(typeChecker, node);
-    return concatenate(fileReferenceDefinition, objectLiteralElementDefinition.length ? objectLiteralElementDefinition : getDefinitionFromSymbol(typeChecker, symbol, node, failedAliasResolution));
-  }
-  function symbolMatchesSignature(s, calledDeclaration) {
-    var _a;
-    return s === calledDeclaration.symbol || s === calledDeclaration.symbol.parent || isAssignmentExpression(calledDeclaration.parent) || !isCallLikeExpression(calledDeclaration.parent) && s === ((_a = tryCast(calledDeclaration.parent, canHaveSymbol)) == null ? void 0 : _a.symbol);
-  }
-  function getDefinitionFromObjectLiteralElement(typeChecker, node) {
-    const element = getContainingObjectLiteralElement(node);
-    if (element) {
-      const contextualType = element && typeChecker.getContextualType(element.parent);
-      if (contextualType) {
-        return flatMap(getPropertySymbolsFromContextualType(
-          element,
-          typeChecker,
-          contextualType,
-          /*unionSymbolOk*/
-          false
-        ), (propertySymbol) => getDefinitionFromSymbol(typeChecker, propertySymbol, node));
-      }
+    function writeStringLiteral(s) {
+      writer.writeStringLiteral(s);
+      setLastNonTriviaPosition(
+        s,
+        /*force*/
+        false
+      );
     }
-    return emptyArray;
-  }
-  function getDefinitionFromOverriddenMember(typeChecker, node) {
-    const classElement = findAncestor(node, isClassElement);
-    if (!(classElement && classElement.name))
-      return;
-    const baseDeclaration = findAncestor(classElement, isClassLike);
-    if (!baseDeclaration)
-      return;
-    const baseTypeNode = getEffectiveBaseTypeNode(baseDeclaration);
-    if (!baseTypeNode)
-      return;
-    const expression = skipParentheses(baseTypeNode.expression);
-    const base = isClassExpression(expression) ? expression.symbol : typeChecker.getSymbolAtLocation(expression);
-    if (!base)
-      return;
-    const name = unescapeLeadingUnderscores(getTextOfPropertyName(classElement.name));
-    const symbol = hasStaticModifier(classElement) ? typeChecker.getPropertyOfType(typeChecker.getTypeOfSymbol(base), name) : typeChecker.getPropertyOfType(typeChecker.getDeclaredTypeOfSymbol(base), name);
-    if (!symbol)
-      return;
-    return getDefinitionFromSymbol(typeChecker, symbol, node);
-  }
-  function getReferenceAtPosition(sourceFile, position, program) {
-    var _a, _b, _c, _d;
-    const referencePath = findReferenceInPosition(sourceFile.referencedFiles, position);
-    if (referencePath) {
-      const file = program.getSourceFileFromReference(sourceFile, referencePath);
-      return file && { reference: referencePath, fileName: file.fileName, file, unverified: false };
+    function writeSymbol(s, sym) {
+      writer.writeSymbol(s, sym);
+      setLastNonTriviaPosition(
+        s,
+        /*force*/
+        false
+      );
     }
-    const typeReferenceDirective = findReferenceInPosition(sourceFile.typeReferenceDirectives, position);
-    if (typeReferenceDirective) {
-      const reference = (_a = program.getResolvedTypeReferenceDirectives().get(typeReferenceDirective.fileName, typeReferenceDirective.resolutionMode || sourceFile.impliedNodeFormat)) == null ? void 0 : _a.resolvedTypeReferenceDirective;
-      const file = reference && program.getSourceFile(reference.resolvedFileName);
-      return file && { reference: typeReferenceDirective, fileName: file.fileName, file, unverified: false };
+    function writeLine(force) {
+      writer.writeLine(force);
     }
-    const libReferenceDirective = findReferenceInPosition(sourceFile.libReferenceDirectives, position);
-    if (libReferenceDirective) {
-      const file = program.getLibFileFromReference(libReferenceDirective);
-      return file && { reference: libReferenceDirective, fileName: file.fileName, file, unverified: false };
+    function increaseIndent() {
+      writer.increaseIndent();
     }
-    if ((_b = sourceFile.resolvedModules) == null ? void 0 : _b.size()) {
-      const node = getTouchingToken(sourceFile, position);
-      if (isModuleSpecifierLike(node) && isExternalModuleNameRelative(node.text) && sourceFile.resolvedModules.has(node.text, getModeForUsageLocation(sourceFile, node))) {
-        const verifiedFileName = (_d = (_c = sourceFile.resolvedModules.get(node.text, getModeForUsageLocation(sourceFile, node))) == null ? void 0 : _c.resolvedModule) == null ? void 0 : _d.resolvedFileName;
-        const fileName = verifiedFileName || resolvePath(getDirectoryPath(sourceFile.fileName), node.text);
-        return {
-          file: program.getSourceFile(fileName),
-          fileName,
-          reference: {
-            pos: node.getStart(),
-            end: node.getEnd(),
-            fileName: node.text
-          },
-          unverified: !verifiedFileName
-        };
-      }
+    function decreaseIndent() {
+      writer.decreaseIndent();
     }
-    return void 0;
-  }
-  function getTypeDefinitionAtPosition(typeChecker, sourceFile, position) {
-    const node = getTouchingPropertyName(sourceFile, position);
-    if (node === sourceFile) {
-      return void 0;
+    function getText() {
+      return writer.getText();
     }
-    if (isImportMeta(node.parent) && node.parent.name === node) {
-      return definitionFromType(
-        typeChecker.getTypeAtLocation(node.parent),
-        typeChecker,
-        node.parent,
-        /*failedAliasResolution*/
+    function rawWrite(s) {
+      writer.rawWrite(s);
+      setLastNonTriviaPosition(
+        s,
+        /*force*/
         false
       );
     }
-    const { symbol, failedAliasResolution } = getSymbol(
-      node,
-      typeChecker,
-      /*stopAtAlias*/
-      false
-    );
-    if (!symbol)
-      return void 0;
-    const typeAtLocation = typeChecker.getTypeOfSymbolAtLocation(symbol, node);
-    const returnType = tryGetReturnTypeOfFunction(symbol, typeAtLocation, typeChecker);
-    const fromReturnType = returnType && definitionFromType(returnType, typeChecker, node, failedAliasResolution);
-    const typeDefinitions = fromReturnType && fromReturnType.length !== 0 ? fromReturnType : definitionFromType(typeAtLocation, typeChecker, node, failedAliasResolution);
-    return typeDefinitions.length ? typeDefinitions : !(symbol.flags & 111551 /* Value */) && symbol.flags & 788968 /* Type */ ? getDefinitionFromSymbol(typeChecker, skipAlias(symbol, typeChecker), node, failedAliasResolution) : void 0;
-  }
-  function definitionFromType(type, checker, node, failedAliasResolution) {
-    return flatMap(type.isUnion() && !(type.flags & 32 /* Enum */) ? type.types : [type], (t) => t.symbol && getDefinitionFromSymbol(checker, t.symbol, node, failedAliasResolution));
-  }
-  function tryGetReturnTypeOfFunction(symbol, type, checker) {
-    if (type.symbol === symbol || // At `const f = () => {}`, the symbol is `f` and the type symbol is at `() => {}`
-    symbol.valueDeclaration && type.symbol && isVariableDeclaration(symbol.valueDeclaration) && symbol.valueDeclaration.initializer === type.symbol.valueDeclaration) {
-      const sigs = type.getCallSignatures();
-      if (sigs.length === 1)
-        return checker.getReturnTypeOfSignature(first(sigs));
+    function writeLiteral(s) {
+      writer.writeLiteral(s);
+      setLastNonTriviaPosition(
+        s,
+        /*force*/
+        true
+      );
     }
-    return void 0;
-  }
-  function getDefinitionAndBoundSpan(program, sourceFile, position) {
-    const definitions = getDefinitionAtPosition(program, sourceFile, position);
-    if (!definitions || definitions.length === 0) {
-      return void 0;
+    function getTextPos() {
+      return writer.getTextPos();
     }
-    const comment = findReferenceInPosition(sourceFile.referencedFiles, position) || findReferenceInPosition(sourceFile.typeReferenceDirectives, position) || findReferenceInPosition(sourceFile.libReferenceDirectives, position);
-    if (comment) {
-      return { definitions, textSpan: createTextSpanFromRange(comment) };
+    function getLine() {
+      return writer.getLine();
     }
-    const node = getTouchingPropertyName(sourceFile, position);
-    const textSpan = createTextSpan(node.getStart(), node.getWidth());
-    return { definitions, textSpan };
-  }
-  function getDefinitionInfoForIndexSignatures(node, checker) {
-    return mapDefined(checker.getIndexInfosAtLocation(node), (info) => info.declaration && createDefinitionFromSignatureDeclaration(checker, info.declaration));
-  }
-  function getSymbol(node, checker, stopAtAlias) {
-    const symbol = checker.getSymbolAtLocation(node);
-    let failedAliasResolution = false;
-    if ((symbol == null ? void 0 : symbol.declarations) && symbol.flags & 2097152 /* Alias */ && !stopAtAlias && shouldSkipAlias(node, symbol.declarations[0])) {
-      const aliased = checker.getAliasedSymbol(symbol);
-      if (aliased.declarations) {
-        return { symbol: aliased };
-      } else {
-        failedAliasResolution = true;
-      }
+    function getColumn() {
+      return writer.getColumn();
     }
-    return { symbol, failedAliasResolution };
-  }
-  function shouldSkipAlias(node, declaration) {
-    if (node.kind !== 80 /* Identifier */) {
-      return false;
+    function getIndent() {
+      return writer.getIndent();
     }
-    if (node.parent === declaration) {
-      return true;
+    function isAtStartOfLine() {
+      return writer.isAtStartOfLine();
     }
-    if (declaration.kind === 273 /* NamespaceImport */) {
-      return false;
+    function clear2() {
+      writer.clear();
+      lastNonTriviaPosition = 0;
     }
-    return true;
-  }
-  function isExpandoDeclaration(node) {
-    if (!isAssignmentDeclaration(node))
-      return false;
-    const containingAssignment = findAncestor(node, (p) => {
-      if (isAssignmentExpression(p))
-        return true;
-      if (!isAssignmentDeclaration(p))
-        return "quit";
-      return false;
-    });
-    return !!containingAssignment && getAssignmentDeclarationKind(containingAssignment) === 5 /* Property */;
+    return {
+      onBeforeEmitNode,
+      onAfterEmitNode,
+      onBeforeEmitNodeArray,
+      onAfterEmitNodeArray,
+      onBeforeEmitToken,
+      onAfterEmitToken,
+      write,
+      writeComment,
+      writeKeyword,
+      writeOperator,
+      writePunctuation,
+      writeTrailingSemicolon,
+      writeParameter,
+      writeProperty,
+      writeSpace,
+      writeStringLiteral,
+      writeSymbol,
+      writeLine,
+      increaseIndent,
+      decreaseIndent,
+      getText,
+      rawWrite,
+      writeLiteral,
+      getTextPos,
+      getLine,
+      getColumn,
+      getIndent,
+      isAtStartOfLine,
+      hasTrailingComment: () => writer.hasTrailingComment(),
+      hasTrailingWhitespace: () => writer.hasTrailingWhitespace(),
+      clear: clear2
+    };
   }
-  function getDefinitionFromSymbol(typeChecker, symbol, node, failedAliasResolution, excludeDeclaration) {
-    const filteredDeclarations = filter(symbol.declarations, (d) => d !== excludeDeclaration);
-    const withoutExpandos = filter(filteredDeclarations, (d) => !isExpandoDeclaration(d));
-    const results = some(withoutExpandos) ? withoutExpandos : filteredDeclarations;
-    return getConstructSignatureDefinition() || getCallSignatureDefinition() || map(results, (declaration) => createDefinitionInfo(
-      declaration,
-      typeChecker,
-      symbol,
-      node,
-      /*unverified*/
-      false,
-      failedAliasResolution
-    ));
-    function getConstructSignatureDefinition() {
-      if (symbol.flags & 32 /* Class */ && !(symbol.flags & (16 /* Function */ | 3 /* Variable */)) && (isNewExpressionTarget(node) || node.kind === 137 /* ConstructorKeyword */)) {
-        const cls = find(filteredDeclarations, isClassLike) || Debug.fail("Expected declaration to have at least one class-like declaration");
-        return getSignatureDefinition(
-          cls.members,
-          /*selectConstructors*/
-          true
-        );
+  function getInsertionPositionAtSourceFileTop(sourceFile) {
+    let lastPrologue;
+    for (const node of sourceFile.statements) {
+      if (isPrologueDirective(node)) {
+        lastPrologue = node;
+      } else {
+        break;
       }
     }
-    function getCallSignatureDefinition() {
-      return isCallOrNewExpressionTarget(node) || isNameOfFunctionDeclaration(node) ? getSignatureDefinition(
-        filteredDeclarations,
-        /*selectConstructors*/
-        false
-      ) : void 0;
+    let position = 0;
+    const text = sourceFile.text;
+    if (lastPrologue) {
+      position = lastPrologue.end;
+      advancePastLineBreak();
+      return position;
     }
-    function getSignatureDefinition(signatureDeclarations, selectConstructors) {
-      if (!signatureDeclarations) {
-        return void 0;
+    const shebang = getShebang(text);
+    if (shebang !== void 0) {
+      position = shebang.length;
+      advancePastLineBreak();
+    }
+    const ranges = getLeadingCommentRanges(text, position);
+    if (!ranges)
+      return position;
+    let lastComment;
+    let firstNodeLine;
+    for (const range of ranges) {
+      if (range.kind === 3 /* MultiLineCommentTrivia */) {
+        if (isPinnedComment(text, range.pos)) {
+          lastComment = { range, pinnedOrTripleSlash: true };
+          continue;
+        }
+      } else if (isRecognizedTripleSlashComment(text, range.pos, range.end)) {
+        lastComment = { range, pinnedOrTripleSlash: true };
+        continue;
       }
-      const declarations = signatureDeclarations.filter(selectConstructors ? isConstructorDeclaration : isFunctionLike);
-      const declarationsWithBody = declarations.filter((d) => !!d.body);
-      return declarations.length ? declarationsWithBody.length !== 0 ? declarationsWithBody.map((x) => createDefinitionInfo(x, typeChecker, symbol, node)) : [createDefinitionInfo(
-        last(declarations),
-        typeChecker,
-        symbol,
-        node,
-        /*unverified*/
-        false,
-        failedAliasResolution
-      )] : void 0;
+      if (lastComment) {
+        if (lastComment.pinnedOrTripleSlash)
+          break;
+        const commentLine = sourceFile.getLineAndCharacterOfPosition(range.pos).line;
+        const lastCommentEndLine = sourceFile.getLineAndCharacterOfPosition(lastComment.range.end).line;
+        if (commentLine >= lastCommentEndLine + 2)
+          break;
+      }
+      if (sourceFile.statements.length) {
+        if (firstNodeLine === void 0)
+          firstNodeLine = sourceFile.getLineAndCharacterOfPosition(sourceFile.statements[0].getStart()).line;
+        const commentEndLine = sourceFile.getLineAndCharacterOfPosition(range.end).line;
+        if (firstNodeLine < commentEndLine + 2)
+          break;
+      }
+      lastComment = { range, pinnedOrTripleSlash: false };
     }
-  }
-  function createDefinitionInfo(declaration, checker, symbol, node, unverified, failedAliasResolution) {
-    const symbolName2 = checker.symbolToString(symbol);
-    const symbolKind = ts_SymbolDisplay_exports.getSymbolKind(checker, symbol, node);
-    const containerName = symbol.parent ? checker.symbolToString(symbol.parent, node) : "";
-    return createDefinitionInfoFromName(checker, declaration, symbolKind, symbolName2, containerName, unverified, failedAliasResolution);
-  }
-  function createDefinitionInfoFromName(checker, declaration, symbolKind, symbolName2, containerName, unverified, failedAliasResolution, textSpan) {
-    const sourceFile = declaration.getSourceFile();
-    if (!textSpan) {
-      const name = getNameOfDeclaration(declaration) || declaration;
-      textSpan = createTextSpanFromNode(name, sourceFile);
+    if (lastComment) {
+      position = lastComment.range.end;
+      advancePastLineBreak();
     }
-    return {
-      fileName: sourceFile.fileName,
-      textSpan,
-      kind: symbolKind,
-      name: symbolName2,
-      containerKind: void 0,
-      // TODO: GH#18217
-      containerName,
-      ...ts_FindAllReferences_exports.toContextSpan(
-        textSpan,
-        sourceFile,
-        ts_FindAllReferences_exports.getContextNode(declaration)
-      ),
-      isLocal: !isDefinitionVisible(checker, declaration),
-      isAmbient: !!(declaration.flags & 16777216 /* Ambient */),
-      unverified,
-      failedAliasResolution
-    };
-  }
-  function isDefinitionVisible(checker, declaration) {
-    if (checker.isDeclarationVisible(declaration))
-      return true;
-    if (!declaration.parent)
-      return false;
-    if (hasInitializer(declaration.parent) && declaration.parent.initializer === declaration)
-      return isDefinitionVisible(checker, declaration.parent);
-    switch (declaration.kind) {
-      case 171 /* PropertyDeclaration */:
-      case 176 /* GetAccessor */:
-      case 177 /* SetAccessor */:
-      case 173 /* MethodDeclaration */:
-        if (hasEffectiveModifier(declaration, 8 /* Private */))
-          return false;
-      case 175 /* Constructor */:
-      case 302 /* PropertyAssignment */:
-      case 303 /* ShorthandPropertyAssignment */:
-      case 209 /* ObjectLiteralExpression */:
-      case 230 /* ClassExpression */:
-      case 218 /* ArrowFunction */:
-      case 217 /* FunctionExpression */:
-        return isDefinitionVisible(checker, declaration.parent);
-      default:
-        return false;
+    return position;
+    function advancePastLineBreak() {
+      if (position < text.length) {
+        const charCode = text.charCodeAt(position);
+        if (isLineBreak(charCode)) {
+          position++;
+          if (position < text.length && charCode === 13 /* carriageReturn */ && text.charCodeAt(position) === 10 /* lineFeed */) {
+            position++;
+          }
+        }
+      }
     }
   }
-  function createDefinitionFromSignatureDeclaration(typeChecker, decl, failedAliasResolution) {
-    return createDefinitionInfo(
-      decl,
-      typeChecker,
-      decl.symbol,
-      decl,
-      /*unverified*/
-      false,
-      failedAliasResolution
-    );
-  }
-  function findReferenceInPosition(refs, pos) {
-    return find(refs, (ref) => textRangeContainsPositionInclusive(ref, pos));
+  function isValidLocationToAddComment(sourceFile, position) {
+    return !isInComment(sourceFile, position) && !isInString(sourceFile, position) && !isInTemplateString(sourceFile, position) && !isInJSXText(sourceFile, position);
   }
-  function getDefinitionInfoForFileReference(name, targetFileName, unverified) {
-    return {
-      fileName: targetFileName,
-      textSpan: createTextSpanFromBounds(0, 0),
-      kind: "script" /* scriptElement */,
-      name,
-      containerName: void 0,
-      containerKind: void 0,
-      // TODO: GH#18217
-      unverified
-    };
+  function needSemicolonBetween(a, b) {
+    return (isPropertySignature(a) || isPropertyDeclaration(a)) && isClassOrTypeElement(b) && b.name.kind === 167 /* ComputedPropertyName */ || isStatementButNotDeclaration(a) && isStatementButNotDeclaration(b);
   }
-  function getAncestorCallLikeExpression(node) {
-    const target = findAncestor(node, (n) => !isRightSideOfPropertyAccess(n));
-    const callLike = target == null ? void 0 : target.parent;
-    return callLike && isCallLikeExpression(callLike) && getInvokedExpression(callLike) === target ? callLike : void 0;
+  function deleteNode(changes, sourceFile, node, options = { leadingTriviaOption: 1 /* IncludeAll */ }) {
+    const startPosition = getAdjustedStartPosition(sourceFile, node, options);
+    const endPosition = getAdjustedEndPosition(sourceFile, node, options);
+    changes.deleteRange(sourceFile, { pos: startPosition, end: endPosition });
   }
-  function tryGetSignatureDeclaration(typeChecker, node) {
-    const callLike = getAncestorCallLikeExpression(node);
-    const signature = callLike && typeChecker.getResolvedSignature(callLike);
-    return tryCast(signature && signature.declaration, (d) => isFunctionLike(d) && !isFunctionTypeNode(d));
+  function deleteNodeInList(changes, deletedNodesInLists, sourceFile, node) {
+    const containingList = Debug.checkDefined(ts_formatting_exports.SmartIndenter.getContainingList(node, sourceFile));
+    const index = indexOfNode(containingList, node);
+    Debug.assert(index !== -1);
+    if (containingList.length === 1) {
+      deleteNode(changes, sourceFile, node);
+      return;
+    }
+    Debug.assert(!deletedNodesInLists.has(node), "Deleting a node twice");
+    deletedNodesInLists.add(node);
+    changes.deleteRange(sourceFile, {
+      pos: startPositionToDeleteNodeInList(sourceFile, node),
+      end: index === containingList.length - 1 ? getAdjustedEndPosition(sourceFile, node, {}) : endPositionToDeleteNodeInList(sourceFile, node, containingList[index - 1], containingList[index + 1])
+    });
   }
-  function isConstructorLike(node) {
-    switch (node.kind) {
-      case 175 /* Constructor */:
-      case 184 /* ConstructorType */:
-      case 179 /* ConstructSignature */:
-        return true;
-      default:
-        return false;
+  var LeadingTriviaOption, TrailingTriviaOption, useNonAdjustedPositions, ChangeTracker, changesToText, textChangesTransformationContext, deleteDeclaration;
+  var init_textChanges = __esm({
+    "src/services/textChanges.ts"() {
+      "use strict";
+      init_ts4();
+      LeadingTriviaOption = /* @__PURE__ */ ((LeadingTriviaOption2) => {
+        LeadingTriviaOption2[LeadingTriviaOption2["Exclude"] = 0] = "Exclude";
+        LeadingTriviaOption2[LeadingTriviaOption2["IncludeAll"] = 1] = "IncludeAll";
+        LeadingTriviaOption2[LeadingTriviaOption2["JSDoc"] = 2] = "JSDoc";
+        LeadingTriviaOption2[LeadingTriviaOption2["StartLine"] = 3] = "StartLine";
+        return LeadingTriviaOption2;
+      })(LeadingTriviaOption || {});
+      TrailingTriviaOption = /* @__PURE__ */ ((TrailingTriviaOption2) => {
+        TrailingTriviaOption2[TrailingTriviaOption2["Exclude"] = 0] = "Exclude";
+        TrailingTriviaOption2[TrailingTriviaOption2["ExcludeWhitespace"] = 1] = "ExcludeWhitespace";
+        TrailingTriviaOption2[TrailingTriviaOption2["Include"] = 2] = "Include";
+        return TrailingTriviaOption2;
+      })(TrailingTriviaOption || {});
+      useNonAdjustedPositions = {
+        leadingTriviaOption: 0 /* Exclude */,
+        trailingTriviaOption: 0 /* Exclude */
+      };
+      ChangeTracker = class _ChangeTracker {
+        /** Public for tests only. Other callers should use `ChangeTracker.with`. */
+        constructor(newLineCharacter, formatContext) {
+          this.newLineCharacter = newLineCharacter;
+          this.formatContext = formatContext;
+          this.changes = [];
+          this.classesWithNodesInsertedAtStart = /* @__PURE__ */ new Map();
+          // Set implemented as Map
+          this.deletedNodes = [];
+        }
+        static fromContext(context) {
+          return new _ChangeTracker(getNewLineOrDefaultFromHost(context.host, context.formatContext.options), context.formatContext);
+        }
+        static with(context, cb) {
+          const tracker = _ChangeTracker.fromContext(context);
+          cb(tracker);
+          return tracker.getChanges();
+        }
+        pushRaw(sourceFile, change) {
+          Debug.assertEqual(sourceFile.fileName, change.fileName);
+          for (const c of change.textChanges) {
+            this.changes.push({
+              kind: 3 /* Text */,
+              sourceFile,
+              text: c.newText,
+              range: createTextRangeFromSpan(c.span)
+            });
+          }
+        }
+        deleteRange(sourceFile, range) {
+          this.changes.push({ kind: 0 /* Remove */, sourceFile, range });
+        }
+        delete(sourceFile, node) {
+          this.deletedNodes.push({ sourceFile, node });
+        }
+        /** Stop! Consider using `delete` instead, which has logic for deleting nodes from delimited lists. */
+        deleteNode(sourceFile, node, options = { leadingTriviaOption: 1 /* IncludeAll */ }) {
+          this.deleteRange(sourceFile, getAdjustedRange(sourceFile, node, node, options));
+        }
+        deleteNodes(sourceFile, nodes, options = { leadingTriviaOption: 1 /* IncludeAll */ }, hasTrailingComment) {
+          for (const node of nodes) {
+            const pos = getAdjustedStartPosition(sourceFile, node, options, hasTrailingComment);
+            const end = getAdjustedEndPosition(sourceFile, node, options);
+            this.deleteRange(sourceFile, { pos, end });
+            hasTrailingComment = !!getEndPositionOfMultilineTrailingComment(sourceFile, node, options);
+          }
+        }
+        deleteModifier(sourceFile, modifier) {
+          this.deleteRange(sourceFile, { pos: modifier.getStart(sourceFile), end: skipTrivia(
+            sourceFile.text,
+            modifier.end,
+            /*stopAfterLineBreak*/
+            true
+          ) });
+        }
+        deleteNodeRange(sourceFile, startNode2, endNode2, options = { leadingTriviaOption: 1 /* IncludeAll */ }) {
+          const startPosition = getAdjustedStartPosition(sourceFile, startNode2, options);
+          const endPosition = getAdjustedEndPosition(sourceFile, endNode2, options);
+          this.deleteRange(sourceFile, { pos: startPosition, end: endPosition });
+        }
+        deleteNodeRangeExcludingEnd(sourceFile, startNode2, afterEndNode, options = { leadingTriviaOption: 1 /* IncludeAll */ }) {
+          const startPosition = getAdjustedStartPosition(sourceFile, startNode2, options);
+          const endPosition = afterEndNode === void 0 ? sourceFile.text.length : getAdjustedStartPosition(sourceFile, afterEndNode, options);
+          this.deleteRange(sourceFile, { pos: startPosition, end: endPosition });
+        }
+        replaceRange(sourceFile, range, newNode, options = {}) {
+          this.changes.push({ kind: 1 /* ReplaceWithSingleNode */, sourceFile, range, options, node: newNode });
+        }
+        replaceNode(sourceFile, oldNode, newNode, options = useNonAdjustedPositions) {
+          this.replaceRange(sourceFile, getAdjustedRange(sourceFile, oldNode, oldNode, options), newNode, options);
+        }
+        replaceNodeRange(sourceFile, startNode2, endNode2, newNode, options = useNonAdjustedPositions) {
+          this.replaceRange(sourceFile, getAdjustedRange(sourceFile, startNode2, endNode2, options), newNode, options);
+        }
+        replaceRangeWithNodes(sourceFile, range, newNodes, options = {}) {
+          this.changes.push({ kind: 2 /* ReplaceWithMultipleNodes */, sourceFile, range, options, nodes: newNodes });
+        }
+        replaceNodeWithNodes(sourceFile, oldNode, newNodes, options = useNonAdjustedPositions) {
+          this.replaceRangeWithNodes(sourceFile, getAdjustedRange(sourceFile, oldNode, oldNode, options), newNodes, options);
+        }
+        replaceNodeWithText(sourceFile, oldNode, text) {
+          this.replaceRangeWithText(sourceFile, getAdjustedRange(sourceFile, oldNode, oldNode, useNonAdjustedPositions), text);
+        }
+        replaceNodeRangeWithNodes(sourceFile, startNode2, endNode2, newNodes, options = useNonAdjustedPositions) {
+          this.replaceRangeWithNodes(sourceFile, getAdjustedRange(sourceFile, startNode2, endNode2, options), newNodes, options);
+        }
+        nodeHasTrailingComment(sourceFile, oldNode, configurableEnd = useNonAdjustedPositions) {
+          return !!getEndPositionOfMultilineTrailingComment(sourceFile, oldNode, configurableEnd);
+        }
+        nextCommaToken(sourceFile, node) {
+          const next = findNextToken(node, node.parent, sourceFile);
+          return next && next.kind === 28 /* CommaToken */ ? next : void 0;
+        }
+        replacePropertyAssignment(sourceFile, oldNode, newNode) {
+          const suffix = this.nextCommaToken(sourceFile, oldNode) ? "" : "," + this.newLineCharacter;
+          this.replaceNode(sourceFile, oldNode, newNode, { suffix });
+        }
+        insertNodeAt(sourceFile, pos, newNode, options = {}) {
+          this.replaceRange(sourceFile, createRange(pos), newNode, options);
+        }
+        insertNodesAt(sourceFile, pos, newNodes, options = {}) {
+          this.replaceRangeWithNodes(sourceFile, createRange(pos), newNodes, options);
+        }
+        insertNodeAtTopOfFile(sourceFile, newNode, blankLineBetween) {
+          this.insertAtTopOfFile(sourceFile, newNode, blankLineBetween);
+        }
+        insertNodesAtTopOfFile(sourceFile, newNodes, blankLineBetween) {
+          this.insertAtTopOfFile(sourceFile, newNodes, blankLineBetween);
+        }
+        insertAtTopOfFile(sourceFile, insert, blankLineBetween) {
+          const pos = getInsertionPositionAtSourceFileTop(sourceFile);
+          const options = {
+            prefix: pos === 0 ? void 0 : this.newLineCharacter,
+            suffix: (isLineBreak(sourceFile.text.charCodeAt(pos)) ? "" : this.newLineCharacter) + (blankLineBetween ? this.newLineCharacter : "")
+          };
+          if (isArray(insert)) {
+            this.insertNodesAt(sourceFile, pos, insert, options);
+          } else {
+            this.insertNodeAt(sourceFile, pos, insert, options);
+          }
+        }
+        insertNodesAtEndOfFile(sourceFile, newNodes, blankLineBetween) {
+          this.insertAtEndOfFile(sourceFile, newNodes, blankLineBetween);
+        }
+        insertAtEndOfFile(sourceFile, insert, blankLineBetween) {
+          const pos = sourceFile.end + 1;
+          const options = {
+            prefix: this.newLineCharacter,
+            suffix: this.newLineCharacter + (blankLineBetween ? this.newLineCharacter : "")
+          };
+          this.insertNodesAt(sourceFile, pos, insert, options);
+        }
+        insertStatementsInNewFile(fileName, statements, oldFile) {
+          if (!this.newFileChanges) {
+            this.newFileChanges = createMultiMap();
+          }
+          this.newFileChanges.add(fileName, { oldFile, statements });
+        }
+        insertFirstParameter(sourceFile, parameters, newParam) {
+          const p0 = firstOrUndefined(parameters);
+          if (p0) {
+            this.insertNodeBefore(sourceFile, p0, newParam);
+          } else {
+            this.insertNodeAt(sourceFile, parameters.pos, newParam);
+          }
+        }
+        insertNodeBefore(sourceFile, before, newNode, blankLineBetween = false, options = {}) {
+          this.insertNodeAt(sourceFile, getAdjustedStartPosition(sourceFile, before, options), newNode, this.getOptionsForInsertNodeBefore(before, newNode, blankLineBetween));
+        }
+        insertNodesBefore(sourceFile, before, newNodes, blankLineBetween = false, options = {}) {
+          this.insertNodesAt(sourceFile, getAdjustedStartPosition(sourceFile, before, options), newNodes, this.getOptionsForInsertNodeBefore(before, first(newNodes), blankLineBetween));
+        }
+        insertModifierAt(sourceFile, pos, modifier, options = {}) {
+          this.insertNodeAt(sourceFile, pos, factory.createToken(modifier), options);
+        }
+        insertModifierBefore(sourceFile, modifier, before) {
+          return this.insertModifierAt(sourceFile, before.getStart(sourceFile), modifier, { suffix: " " });
+        }
+        insertCommentBeforeLine(sourceFile, lineNumber, position, commentText) {
+          const lineStartPosition = getStartPositionOfLine(lineNumber, sourceFile);
+          const startPosition = getFirstNonSpaceCharacterPosition(sourceFile.text, lineStartPosition);
+          const insertAtLineStart = isValidLocationToAddComment(sourceFile, startPosition);
+          const token = getTouchingToken(sourceFile, insertAtLineStart ? startPosition : position);
+          const indent3 = sourceFile.text.slice(lineStartPosition, startPosition);
+          const text = `${insertAtLineStart ? "" : this.newLineCharacter}//${commentText}${this.newLineCharacter}${indent3}`;
+          this.insertText(sourceFile, token.getStart(sourceFile), text);
+        }
+        insertJsdocCommentBefore(sourceFile, node, tag) {
+          const fnStart = node.getStart(sourceFile);
+          if (node.jsDoc) {
+            for (const jsdoc of node.jsDoc) {
+              this.deleteRange(sourceFile, {
+                pos: getLineStartPositionForPosition(jsdoc.getStart(sourceFile), sourceFile),
+                end: getAdjustedEndPosition(
+                  sourceFile,
+                  jsdoc,
+                  /*options*/
+                  {}
+                )
+              });
+            }
+          }
+          const startPosition = getPrecedingNonSpaceCharacterPosition(sourceFile.text, fnStart - 1);
+          const indent3 = sourceFile.text.slice(startPosition, fnStart);
+          this.insertNodeAt(sourceFile, fnStart, tag, { suffix: this.newLineCharacter + indent3 });
+        }
+        createJSDocText(sourceFile, node) {
+          const comments = flatMap(node.jsDoc, (jsDoc2) => isString(jsDoc2.comment) ? factory.createJSDocText(jsDoc2.comment) : jsDoc2.comment);
+          const jsDoc = singleOrUndefined(node.jsDoc);
+          return jsDoc && positionsAreOnSameLine(jsDoc.pos, jsDoc.end, sourceFile) && length(comments) === 0 ? void 0 : factory.createNodeArray(intersperse(comments, factory.createJSDocText("\n")));
+        }
+        replaceJSDocComment(sourceFile, node, tags) {
+          this.insertJsdocCommentBefore(sourceFile, updateJSDocHost(node), factory.createJSDocComment(this.createJSDocText(sourceFile, node), factory.createNodeArray(tags)));
+        }
+        addJSDocTags(sourceFile, parent2, newTags) {
+          const oldTags = flatMapToMutable(parent2.jsDoc, (j) => j.tags);
+          const unmergedNewTags = newTags.filter(
+            (newTag) => !oldTags.some((tag, i) => {
+              const merged = tryMergeJsdocTags(tag, newTag);
+              if (merged)
+                oldTags[i] = merged;
+              return !!merged;
+            })
+          );
+          this.replaceJSDocComment(sourceFile, parent2, [...oldTags, ...unmergedNewTags]);
+        }
+        filterJSDocTags(sourceFile, parent2, predicate) {
+          this.replaceJSDocComment(sourceFile, parent2, filter(flatMapToMutable(parent2.jsDoc, (j) => j.tags), predicate));
+        }
+        replaceRangeWithText(sourceFile, range, text) {
+          this.changes.push({ kind: 3 /* Text */, sourceFile, range, text });
+        }
+        insertText(sourceFile, pos, text) {
+          this.replaceRangeWithText(sourceFile, createRange(pos), text);
+        }
+        /** Prefer this over replacing a node with another that has a type annotation, as it avoids reformatting the other parts of the node. */
+        tryInsertTypeAnnotation(sourceFile, node, type) {
+          let endNode2;
+          if (isFunctionLike(node)) {
+            endNode2 = findChildOfKind(node, 22 /* CloseParenToken */, sourceFile);
+            if (!endNode2) {
+              if (!isArrowFunction(node))
+                return false;
+              endNode2 = first(node.parameters);
+            }
+          } else {
+            endNode2 = (node.kind === 260 /* VariableDeclaration */ ? node.exclamationToken : node.questionToken) ?? node.name;
+          }
+          this.insertNodeAt(sourceFile, endNode2.end, type, { prefix: ": " });
+          return true;
+        }
+        tryInsertThisTypeAnnotation(sourceFile, node, type) {
+          const start = findChildOfKind(node, 21 /* OpenParenToken */, sourceFile).getStart(sourceFile) + 1;
+          const suffix = node.parameters.length ? ", " : "";
+          this.insertNodeAt(sourceFile, start, type, { prefix: "this: ", suffix });
+        }
+        insertTypeParameters(sourceFile, node, typeParameters) {
+          const start = (findChildOfKind(node, 21 /* OpenParenToken */, sourceFile) || first(node.parameters)).getStart(sourceFile);
+          this.insertNodesAt(sourceFile, start, typeParameters, { prefix: "<", suffix: ">", joiner: ", " });
+        }
+        getOptionsForInsertNodeBefore(before, inserted, blankLineBetween) {
+          if (isStatement(before) || isClassElement(before)) {
+            return { suffix: blankLineBetween ? this.newLineCharacter + this.newLineCharacter : this.newLineCharacter };
+          } else if (isVariableDeclaration(before)) {
+            return { suffix: ", " };
+          } else if (isParameter(before)) {
+            return isParameter(inserted) ? { suffix: ", " } : {};
+          } else if (isStringLiteral(before) && isImportDeclaration(before.parent) || isNamedImports(before)) {
+            return { suffix: ", " };
+          } else if (isImportSpecifier(before)) {
+            return { suffix: "," + (blankLineBetween ? this.newLineCharacter : " ") };
+          }
+          return Debug.failBadSyntaxKind(before);
+        }
+        insertNodeAtConstructorStart(sourceFile, ctr, newStatement) {
+          const firstStatement = firstOrUndefined(ctr.body.statements);
+          if (!firstStatement || !ctr.body.multiLine) {
+            this.replaceConstructorBody(sourceFile, ctr, [newStatement, ...ctr.body.statements]);
+          } else {
+            this.insertNodeBefore(sourceFile, firstStatement, newStatement);
+          }
+        }
+        insertNodeAtConstructorStartAfterSuperCall(sourceFile, ctr, newStatement) {
+          const superCallStatement = find(ctr.body.statements, (stmt) => isExpressionStatement(stmt) && isSuperCall(stmt.expression));
+          if (!superCallStatement || !ctr.body.multiLine) {
+            this.replaceConstructorBody(sourceFile, ctr, [...ctr.body.statements, newStatement]);
+          } else {
+            this.insertNodeAfter(sourceFile, superCallStatement, newStatement);
+          }
+        }
+        insertNodeAtConstructorEnd(sourceFile, ctr, newStatement) {
+          const lastStatement = lastOrUndefined(ctr.body.statements);
+          if (!lastStatement || !ctr.body.multiLine) {
+            this.replaceConstructorBody(sourceFile, ctr, [...ctr.body.statements, newStatement]);
+          } else {
+            this.insertNodeAfter(sourceFile, lastStatement, newStatement);
+          }
+        }
+        replaceConstructorBody(sourceFile, ctr, statements) {
+          this.replaceNode(sourceFile, ctr.body, factory.createBlock(
+            statements,
+            /*multiLine*/
+            true
+          ));
+        }
+        insertNodeAtEndOfScope(sourceFile, scope, newNode) {
+          const pos = getAdjustedStartPosition(sourceFile, scope.getLastToken(), {});
+          this.insertNodeAt(sourceFile, pos, newNode, {
+            prefix: isLineBreak(sourceFile.text.charCodeAt(scope.getLastToken().pos)) ? this.newLineCharacter : this.newLineCharacter + this.newLineCharacter,
+            suffix: this.newLineCharacter
+          });
+        }
+        insertMemberAtStart(sourceFile, node, newElement) {
+          this.insertNodeAtStartWorker(sourceFile, node, newElement);
+        }
+        insertNodeAtObjectStart(sourceFile, obj, newElement) {
+          this.insertNodeAtStartWorker(sourceFile, obj, newElement);
+        }
+        insertNodeAtStartWorker(sourceFile, node, newElement) {
+          const indentation = this.guessIndentationFromExistingMembers(sourceFile, node) ?? this.computeIndentationForNewMember(sourceFile, node);
+          this.insertNodeAt(sourceFile, getMembersOrProperties(node).pos, newElement, this.getInsertNodeAtStartInsertOptions(sourceFile, node, indentation));
+        }
+        /**
+         * Tries to guess the indentation from the existing members of a class/interface/object. All members must be on
+         * new lines and must share the same indentation.
+         */
+        guessIndentationFromExistingMembers(sourceFile, node) {
+          let indentation;
+          let lastRange = node;
+          for (const member of getMembersOrProperties(node)) {
+            if (rangeStartPositionsAreOnSameLine(lastRange, member, sourceFile)) {
+              return void 0;
+            }
+            const memberStart = member.getStart(sourceFile);
+            const memberIndentation = ts_formatting_exports.SmartIndenter.findFirstNonWhitespaceColumn(getLineStartPositionForPosition(memberStart, sourceFile), memberStart, sourceFile, this.formatContext.options);
+            if (indentation === void 0) {
+              indentation = memberIndentation;
+            } else if (memberIndentation !== indentation) {
+              return void 0;
+            }
+            lastRange = member;
+          }
+          return indentation;
+        }
+        computeIndentationForNewMember(sourceFile, node) {
+          const nodeStart = node.getStart(sourceFile);
+          return ts_formatting_exports.SmartIndenter.findFirstNonWhitespaceColumn(getLineStartPositionForPosition(nodeStart, sourceFile), nodeStart, sourceFile, this.formatContext.options) + (this.formatContext.options.indentSize ?? 4);
+        }
+        getInsertNodeAtStartInsertOptions(sourceFile, node, indentation) {
+          const members = getMembersOrProperties(node);
+          const isEmpty = members.length === 0;
+          const isFirstInsertion = addToSeen(this.classesWithNodesInsertedAtStart, getNodeId(node), { node, sourceFile });
+          const insertTrailingComma = isObjectLiteralExpression(node) && (!isJsonSourceFile(sourceFile) || !isEmpty);
+          const insertLeadingComma = isObjectLiteralExpression(node) && isJsonSourceFile(sourceFile) && isEmpty && !isFirstInsertion;
+          return {
+            indentation,
+            prefix: (insertLeadingComma ? "," : "") + this.newLineCharacter,
+            suffix: insertTrailingComma ? "," : isInterfaceDeclaration(node) && isEmpty ? ";" : ""
+          };
+        }
+        insertNodeAfterComma(sourceFile, after, newNode) {
+          const endPosition = this.insertNodeAfterWorker(sourceFile, this.nextCommaToken(sourceFile, after) || after, newNode);
+          this.insertNodeAt(sourceFile, endPosition, newNode, this.getInsertNodeAfterOptions(sourceFile, after));
+        }
+        insertNodeAfter(sourceFile, after, newNode) {
+          const endPosition = this.insertNodeAfterWorker(sourceFile, after, newNode);
+          this.insertNodeAt(sourceFile, endPosition, newNode, this.getInsertNodeAfterOptions(sourceFile, after));
+        }
+        insertNodeAtEndOfList(sourceFile, list, newNode) {
+          this.insertNodeAt(sourceFile, list.end, newNode, { prefix: ", " });
+        }
+        insertNodesAfter(sourceFile, after, newNodes) {
+          const endPosition = this.insertNodeAfterWorker(sourceFile, after, first(newNodes));
+          this.insertNodesAt(sourceFile, endPosition, newNodes, this.getInsertNodeAfterOptions(sourceFile, after));
+        }
+        insertNodeAfterWorker(sourceFile, after, newNode) {
+          if (needSemicolonBetween(after, newNode)) {
+            if (sourceFile.text.charCodeAt(after.end - 1) !== 59 /* semicolon */) {
+              this.replaceRange(sourceFile, createRange(after.end), factory.createToken(27 /* SemicolonToken */));
+            }
+          }
+          const endPosition = getAdjustedEndPosition(sourceFile, after, {});
+          return endPosition;
+        }
+        getInsertNodeAfterOptions(sourceFile, after) {
+          const options = this.getInsertNodeAfterOptionsWorker(after);
+          return {
+            ...options,
+            prefix: after.end === sourceFile.end && isStatement(after) ? options.prefix ? `
+${options.prefix}` : "\n" : options.prefix
+          };
+        }
+        getInsertNodeAfterOptionsWorker(node) {
+          switch (node.kind) {
+            case 263 /* ClassDeclaration */:
+            case 267 /* ModuleDeclaration */:
+              return { prefix: this.newLineCharacter, suffix: this.newLineCharacter };
+            case 260 /* VariableDeclaration */:
+            case 11 /* StringLiteral */:
+            case 80 /* Identifier */:
+              return { prefix: ", " };
+            case 303 /* PropertyAssignment */:
+              return { suffix: "," + this.newLineCharacter };
+            case 95 /* ExportKeyword */:
+              return { prefix: " " };
+            case 169 /* Parameter */:
+              return {};
+            default:
+              Debug.assert(isStatement(node) || isClassOrTypeElement(node));
+              return { suffix: this.newLineCharacter };
+          }
+        }
+        insertName(sourceFile, node, name) {
+          Debug.assert(!node.name);
+          if (node.kind === 219 /* ArrowFunction */) {
+            const arrow = findChildOfKind(node, 39 /* EqualsGreaterThanToken */, sourceFile);
+            const lparen = findChildOfKind(node, 21 /* OpenParenToken */, sourceFile);
+            if (lparen) {
+              this.insertNodesAt(sourceFile, lparen.getStart(sourceFile), [factory.createToken(100 /* FunctionKeyword */), factory.createIdentifier(name)], { joiner: " " });
+              deleteNode(this, sourceFile, arrow);
+            } else {
+              this.insertText(sourceFile, first(node.parameters).getStart(sourceFile), `function ${name}(`);
+              this.replaceRange(sourceFile, arrow, factory.createToken(22 /* CloseParenToken */));
+            }
+            if (node.body.kind !== 241 /* Block */) {
+              this.insertNodesAt(sourceFile, node.body.getStart(sourceFile), [factory.createToken(19 /* OpenBraceToken */), factory.createToken(107 /* ReturnKeyword */)], { joiner: " ", suffix: " " });
+              this.insertNodesAt(sourceFile, node.body.end, [factory.createToken(27 /* SemicolonToken */), factory.createToken(20 /* CloseBraceToken */)], { joiner: " " });
+            }
+          } else {
+            const pos = findChildOfKind(node, node.kind === 218 /* FunctionExpression */ ? 100 /* FunctionKeyword */ : 86 /* ClassKeyword */, sourceFile).end;
+            this.insertNodeAt(sourceFile, pos, factory.createIdentifier(name), { prefix: " " });
+          }
+        }
+        insertExportModifier(sourceFile, node) {
+          this.insertText(sourceFile, node.getStart(sourceFile), "export ");
+        }
+        insertImportSpecifierAtIndex(sourceFile, importSpecifier, namedImports, index) {
+          const prevSpecifier = namedImports.elements[index - 1];
+          if (prevSpecifier) {
+            this.insertNodeInListAfter(sourceFile, prevSpecifier, importSpecifier);
+          } else {
+            this.insertNodeBefore(
+              sourceFile,
+              namedImports.elements[0],
+              importSpecifier,
+              !positionsAreOnSameLine(namedImports.elements[0].getStart(), namedImports.parent.parent.getStart(), sourceFile)
+            );
+          }
+        }
+        /**
+         * This function should be used to insert nodes in lists when nodes don't carry separators as the part of the node range,
+         * i.e. arguments in arguments lists, parameters in parameter lists etc.
+         * Note that separators are part of the node in statements and class elements.
+         */
+        insertNodeInListAfter(sourceFile, after, newNode, containingList = ts_formatting_exports.SmartIndenter.getContainingList(after, sourceFile)) {
+          if (!containingList) {
+            Debug.fail("node is not a list element");
+            return;
+          }
+          const index = indexOfNode(containingList, after);
+          if (index < 0) {
+            return;
+          }
+          const end = after.getEnd();
+          if (index !== containingList.length - 1) {
+            const nextToken = getTokenAtPosition(sourceFile, after.end);
+            if (nextToken && isSeparator(after, nextToken)) {
+              const nextNode = containingList[index + 1];
+              const startPos = skipWhitespacesAndLineBreaks(sourceFile.text, nextNode.getFullStart());
+              const suffix = `${tokenToString(nextToken.kind)}${sourceFile.text.substring(nextToken.end, startPos)}`;
+              this.insertNodesAt(sourceFile, startPos, [newNode], { suffix });
+            }
+          } else {
+            const afterStart = after.getStart(sourceFile);
+            const afterStartLinePosition = getLineStartPositionForPosition(afterStart, sourceFile);
+            let separator;
+            let multilineList = false;
+            if (containingList.length === 1) {
+              separator = 28 /* CommaToken */;
+            } else {
+              const tokenBeforeInsertPosition = findPrecedingToken(after.pos, sourceFile);
+              separator = isSeparator(after, tokenBeforeInsertPosition) ? tokenBeforeInsertPosition.kind : 28 /* CommaToken */;
+              const afterMinusOneStartLinePosition = getLineStartPositionForPosition(containingList[index - 1].getStart(sourceFile), sourceFile);
+              multilineList = afterMinusOneStartLinePosition !== afterStartLinePosition;
+            }
+            if (hasCommentsBeforeLineBreak(sourceFile.text, after.end)) {
+              multilineList = true;
+            }
+            if (multilineList) {
+              this.replaceRange(sourceFile, createRange(end), factory.createToken(separator));
+              const indentation = ts_formatting_exports.SmartIndenter.findFirstNonWhitespaceColumn(afterStartLinePosition, afterStart, sourceFile, this.formatContext.options);
+              let insertPos = skipTrivia(
+                sourceFile.text,
+                end,
+                /*stopAfterLineBreak*/
+                true,
+                /*stopAtComments*/
+                false
+              );
+              while (insertPos !== end && isLineBreak(sourceFile.text.charCodeAt(insertPos - 1))) {
+                insertPos--;
+              }
+              this.replaceRange(sourceFile, createRange(insertPos), newNode, { indentation, prefix: this.newLineCharacter });
+            } else {
+              this.replaceRange(sourceFile, createRange(end), newNode, { prefix: `${tokenToString(separator)} ` });
+            }
+          }
+        }
+        parenthesizeExpression(sourceFile, expression) {
+          this.replaceRange(sourceFile, rangeOfNode(expression), factory.createParenthesizedExpression(expression));
+        }
+        finishClassesWithNodesInsertedAtStart() {
+          this.classesWithNodesInsertedAtStart.forEach(({ node, sourceFile }) => {
+            const [openBraceEnd, closeBraceEnd] = getClassOrObjectBraceEnds(node, sourceFile);
+            if (openBraceEnd !== void 0 && closeBraceEnd !== void 0) {
+              const isEmpty = getMembersOrProperties(node).length === 0;
+              const isSingleLine = positionsAreOnSameLine(openBraceEnd, closeBraceEnd, sourceFile);
+              if (isEmpty && isSingleLine && openBraceEnd !== closeBraceEnd - 1) {
+                this.deleteRange(sourceFile, createRange(openBraceEnd, closeBraceEnd - 1));
+              }
+              if (isSingleLine) {
+                this.insertText(sourceFile, closeBraceEnd - 1, this.newLineCharacter);
+              }
+            }
+          });
+        }
+        finishDeleteDeclarations() {
+          const deletedNodesInLists = /* @__PURE__ */ new Set();
+          for (const { sourceFile, node } of this.deletedNodes) {
+            if (!this.deletedNodes.some((d) => d.sourceFile === sourceFile && rangeContainsRangeExclusive(d.node, node))) {
+              if (isArray(node)) {
+                this.deleteRange(sourceFile, rangeOfTypeParameters(sourceFile, node));
+              } else {
+                deleteDeclaration.deleteDeclaration(this, deletedNodesInLists, sourceFile, node);
+              }
+            }
+          }
+          deletedNodesInLists.forEach((node) => {
+            const sourceFile = node.getSourceFile();
+            const list = ts_formatting_exports.SmartIndenter.getContainingList(node, sourceFile);
+            if (node !== last(list))
+              return;
+            const lastNonDeletedIndex = findLastIndex(list, (n) => !deletedNodesInLists.has(n), list.length - 2);
+            if (lastNonDeletedIndex !== -1) {
+              this.deleteRange(sourceFile, { pos: list[lastNonDeletedIndex].end, end: startPositionToDeleteNodeInList(sourceFile, list[lastNonDeletedIndex + 1]) });
+            }
+          });
+        }
+        /**
+         * Note: after calling this, the TextChanges object must be discarded!
+         * @param validate only for tests
+         *    The reason we must validate as part of this method is that `getNonFormattedText` changes the node's positions,
+         *    so we can only call this once and can't get the non-formatted text separately.
+         */
+        getChanges(validate) {
+          this.finishDeleteDeclarations();
+          this.finishClassesWithNodesInsertedAtStart();
+          const changes = changesToText.getTextChangesFromChanges(this.changes, this.newLineCharacter, this.formatContext, validate);
+          if (this.newFileChanges) {
+            this.newFileChanges.forEach((insertions, fileName) => {
+              changes.push(changesToText.newFileChanges(fileName, insertions, this.newLineCharacter, this.formatContext));
+            });
+          }
+          return changes;
+        }
+        createNewFile(oldFile, fileName, statements) {
+          this.insertStatementsInNewFile(fileName, statements, oldFile);
+        }
+      };
+      ((changesToText2) => {
+        function getTextChangesFromChanges(changes, newLineCharacter, formatContext, validate) {
+          return mapDefined(group(changes, (c) => c.sourceFile.path), (changesInFile) => {
+            const sourceFile = changesInFile[0].sourceFile;
+            const normalized = stableSort(changesInFile, (a, b) => a.range.pos - b.range.pos || a.range.end - b.range.end);
+            for (let i = 0; i < normalized.length - 1; i++) {
+              Debug.assert(normalized[i].range.end <= normalized[i + 1].range.pos, "Changes overlap", () => `${JSON.stringify(normalized[i].range)} and ${JSON.stringify(normalized[i + 1].range)}`);
+            }
+            const textChanges2 = mapDefined(normalized, (c) => {
+              const span = createTextSpanFromRange(c.range);
+              const targetSourceFile = c.kind === 1 /* ReplaceWithSingleNode */ ? getSourceFileOfNode(getOriginalNode(c.node)) ?? c.sourceFile : c.kind === 2 /* ReplaceWithMultipleNodes */ ? getSourceFileOfNode(getOriginalNode(c.nodes[0])) ?? c.sourceFile : c.sourceFile;
+              const newText = computeNewText(c, targetSourceFile, sourceFile, newLineCharacter, formatContext, validate);
+              if (span.length === newText.length && stringContainsAt(targetSourceFile.text, newText, span.start)) {
+                return void 0;
+              }
+              return createTextChange(span, newText);
+            });
+            return textChanges2.length > 0 ? { fileName: sourceFile.fileName, textChanges: textChanges2 } : void 0;
+          });
+        }
+        changesToText2.getTextChangesFromChanges = getTextChangesFromChanges;
+        function newFileChanges(fileName, insertions, newLineCharacter, formatContext) {
+          const text = newFileChangesWorker(getScriptKindFromFileName(fileName), insertions, newLineCharacter, formatContext);
+          return { fileName, textChanges: [createTextChange(createTextSpan(0, 0), text)], isNewFile: true };
+        }
+        changesToText2.newFileChanges = newFileChanges;
+        function newFileChangesWorker(scriptKind, insertions, newLineCharacter, formatContext) {
+          const nonFormattedText = flatMap(insertions, (insertion) => insertion.statements.map((s) => s === 4 /* NewLineTrivia */ ? "" : getNonformattedText(s, insertion.oldFile, newLineCharacter).text)).join(newLineCharacter);
+          const sourceFile = createSourceFile(
+            "any file name",
+            nonFormattedText,
+            { languageVersion: 99 /* ESNext */, jsDocParsingMode: 1 /* ParseNone */ },
+            /*setParentNodes*/
+            true,
+            scriptKind
+          );
+          const changes = ts_formatting_exports.formatDocument(sourceFile, formatContext);
+          return applyChanges(nonFormattedText, changes) + newLineCharacter;
+        }
+        changesToText2.newFileChangesWorker = newFileChangesWorker;
+        function computeNewText(change, targetSourceFile, sourceFile, newLineCharacter, formatContext, validate) {
+          var _a;
+          if (change.kind === 0 /* Remove */) {
+            return "";
+          }
+          if (change.kind === 3 /* Text */) {
+            return change.text;
+          }
+          const { options = {}, range: { pos } } = change;
+          const format = (n) => getFormattedTextOfNode(n, targetSourceFile, sourceFile, pos, options, newLineCharacter, formatContext, validate);
+          const text = change.kind === 2 /* ReplaceWithMultipleNodes */ ? change.nodes.map((n) => removeSuffix(format(n), newLineCharacter)).join(((_a = change.options) == null ? void 0 : _a.joiner) || newLineCharacter) : format(change.node);
+          const noIndent = options.indentation !== void 0 || getLineStartPositionForPosition(pos, targetSourceFile) === pos ? text : text.replace(/^\s+/, "");
+          return (options.prefix || "") + noIndent + (!options.suffix || endsWith(noIndent, options.suffix) ? "" : options.suffix);
+        }
+        function getFormattedTextOfNode(nodeIn, targetSourceFile, sourceFile, pos, { indentation, prefix, delta }, newLineCharacter, formatContext, validate) {
+          const { node, text } = getNonformattedText(nodeIn, targetSourceFile, newLineCharacter);
+          if (validate)
+            validate(node, text);
+          const formatOptions = getFormatCodeSettingsForWriting(formatContext, targetSourceFile);
+          const initialIndentation = indentation !== void 0 ? indentation : ts_formatting_exports.SmartIndenter.getIndentation(pos, sourceFile, formatOptions, prefix === newLineCharacter || getLineStartPositionForPosition(pos, targetSourceFile) === pos);
+          if (delta === void 0) {
+            delta = ts_formatting_exports.SmartIndenter.shouldIndentChildNode(formatOptions, nodeIn) ? formatOptions.indentSize || 0 : 0;
+          }
+          const file = {
+            text,
+            getLineAndCharacterOfPosition(pos2) {
+              return getLineAndCharacterOfPosition(this, pos2);
+            }
+          };
+          const changes = ts_formatting_exports.formatNodeGivenIndentation(node, file, targetSourceFile.languageVariant, initialIndentation, delta, { ...formatContext, options: formatOptions });
+          return applyChanges(text, changes);
+        }
+        function getNonformattedText(node, sourceFile, newLineCharacter) {
+          const writer = createWriter(newLineCharacter);
+          const newLine = getNewLineKind(newLineCharacter);
+          createPrinter({
+            newLine,
+            neverAsciiEscape: true,
+            preserveSourceNewlines: true,
+            terminateUnterminatedLiterals: true
+          }, writer).writeNode(4 /* Unspecified */, node, sourceFile, writer);
+          return { text: writer.getText(), node: assignPositionsToNode(node) };
+        }
+        changesToText2.getNonformattedText = getNonformattedText;
+      })(changesToText || (changesToText = {}));
+      textChangesTransformationContext = {
+        ...nullTransformationContext,
+        factory: createNodeFactory(
+          nullTransformationContext.factory.flags | 1 /* NoParenthesizerRules */,
+          nullTransformationContext.factory.baseFactory
+        )
+      };
+      ((_deleteDeclaration) => {
+        function deleteDeclaration2(changes, deletedNodesInLists, sourceFile, node) {
+          switch (node.kind) {
+            case 169 /* Parameter */: {
+              const oldFunction = node.parent;
+              if (isArrowFunction(oldFunction) && oldFunction.parameters.length === 1 && !findChildOfKind(oldFunction, 21 /* OpenParenToken */, sourceFile)) {
+                changes.replaceNodeWithText(sourceFile, node, "()");
+              } else {
+                deleteNodeInList(changes, deletedNodesInLists, sourceFile, node);
+              }
+              break;
+            }
+            case 272 /* ImportDeclaration */:
+            case 271 /* ImportEqualsDeclaration */:
+              const isFirstImport = sourceFile.imports.length && node === first(sourceFile.imports).parent || node === find(sourceFile.statements, isAnyImportSyntax);
+              deleteNode(changes, sourceFile, node, {
+                leadingTriviaOption: isFirstImport ? 0 /* Exclude */ : hasJSDocNodes(node) ? 2 /* JSDoc */ : 3 /* StartLine */
+              });
+              break;
+            case 208 /* BindingElement */:
+              const pattern = node.parent;
+              const preserveComma = pattern.kind === 207 /* ArrayBindingPattern */ && node !== last(pattern.elements);
+              if (preserveComma) {
+                deleteNode(changes, sourceFile, node);
+              } else {
+                deleteNodeInList(changes, deletedNodesInLists, sourceFile, node);
+              }
+              break;
+            case 260 /* VariableDeclaration */:
+              deleteVariableDeclaration(changes, deletedNodesInLists, sourceFile, node);
+              break;
+            case 168 /* TypeParameter */:
+              deleteNodeInList(changes, deletedNodesInLists, sourceFile, node);
+              break;
+            case 276 /* ImportSpecifier */:
+              const namedImports = node.parent;
+              if (namedImports.elements.length === 1) {
+                deleteImportBinding(changes, sourceFile, namedImports);
+              } else {
+                deleteNodeInList(changes, deletedNodesInLists, sourceFile, node);
+              }
+              break;
+            case 274 /* NamespaceImport */:
+              deleteImportBinding(changes, sourceFile, node);
+              break;
+            case 27 /* SemicolonToken */:
+              deleteNode(changes, sourceFile, node, { trailingTriviaOption: 0 /* Exclude */ });
+              break;
+            case 100 /* FunctionKeyword */:
+              deleteNode(changes, sourceFile, node, { leadingTriviaOption: 0 /* Exclude */ });
+              break;
+            case 263 /* ClassDeclaration */:
+            case 262 /* FunctionDeclaration */:
+              deleteNode(changes, sourceFile, node, { leadingTriviaOption: hasJSDocNodes(node) ? 2 /* JSDoc */ : 3 /* StartLine */ });
+              break;
+            default:
+              if (!node.parent) {
+                deleteNode(changes, sourceFile, node);
+              } else if (isImportClause(node.parent) && node.parent.name === node) {
+                deleteDefaultImport(changes, sourceFile, node.parent);
+              } else if (isCallExpression(node.parent) && contains(node.parent.arguments, node)) {
+                deleteNodeInList(changes, deletedNodesInLists, sourceFile, node);
+              } else {
+                deleteNode(changes, sourceFile, node);
+              }
+          }
+        }
+        _deleteDeclaration.deleteDeclaration = deleteDeclaration2;
+        function deleteDefaultImport(changes, sourceFile, importClause) {
+          if (!importClause.namedBindings) {
+            deleteNode(changes, sourceFile, importClause.parent);
+          } else {
+            const start = importClause.name.getStart(sourceFile);
+            const nextToken = getTokenAtPosition(sourceFile, importClause.name.end);
+            if (nextToken && nextToken.kind === 28 /* CommaToken */) {
+              const end = skipTrivia(
+                sourceFile.text,
+                nextToken.end,
+                /*stopAfterLineBreak*/
+                false,
+                /*stopAtComments*/
+                true
+              );
+              changes.deleteRange(sourceFile, { pos: start, end });
+            } else {
+              deleteNode(changes, sourceFile, importClause.name);
+            }
+          }
+        }
+        function deleteImportBinding(changes, sourceFile, node) {
+          if (node.parent.name) {
+            const previousToken = Debug.checkDefined(getTokenAtPosition(sourceFile, node.pos - 1));
+            changes.deleteRange(sourceFile, { pos: previousToken.getStart(sourceFile), end: node.end });
+          } else {
+            const importDecl = getAncestor(node, 272 /* ImportDeclaration */);
+            deleteNode(changes, sourceFile, importDecl);
+          }
+        }
+        function deleteVariableDeclaration(changes, deletedNodesInLists, sourceFile, node) {
+          const { parent: parent2 } = node;
+          if (parent2.kind === 299 /* CatchClause */) {
+            changes.deleteNodeRange(sourceFile, findChildOfKind(parent2, 21 /* OpenParenToken */, sourceFile), findChildOfKind(parent2, 22 /* CloseParenToken */, sourceFile));
+            return;
+          }
+          if (parent2.declarations.length !== 1) {
+            deleteNodeInList(changes, deletedNodesInLists, sourceFile, node);
+            return;
+          }
+          const gp = parent2.parent;
+          switch (gp.kind) {
+            case 250 /* ForOfStatement */:
+            case 249 /* ForInStatement */:
+              changes.replaceNode(sourceFile, node, factory.createObjectLiteralExpression());
+              break;
+            case 248 /* ForStatement */:
+              deleteNode(changes, sourceFile, parent2);
+              break;
+            case 243 /* VariableStatement */:
+              deleteNode(changes, sourceFile, gp, { leadingTriviaOption: hasJSDocNodes(gp) ? 2 /* JSDoc */ : 3 /* StartLine */ });
+              break;
+            default:
+              Debug.assertNever(gp);
+          }
+        }
+      })(deleteDeclaration || (deleteDeclaration = {}));
     }
-  }
-  var init_goToDefinition = __esm({
-    "src/services/goToDefinition.ts"() {
+  });
+
+  // src/services/_namespaces/ts.textChanges.ts
+  var ts_textChanges_exports = {};
+  __export(ts_textChanges_exports, {
+    ChangeTracker: () => ChangeTracker,
+    LeadingTriviaOption: () => LeadingTriviaOption,
+    TrailingTriviaOption: () => TrailingTriviaOption,
+    applyChanges: () => applyChanges,
+    assignPositionsToNode: () => assignPositionsToNode,
+    createWriter: () => createWriter,
+    deleteNode: () => deleteNode,
+    isThisTypeAnnotatable: () => isThisTypeAnnotatable,
+    isValidLocationToAddComment: () => isValidLocationToAddComment
+  });
+  var init_ts_textChanges = __esm({
+    "src/services/_namespaces/ts.textChanges.ts"() {
       "use strict";
-      init_ts4();
+      init_textChanges();
     }
   });
 
-  // src/services/_namespaces/ts.GoToDefinition.ts
-  var ts_GoToDefinition_exports = {};
-  __export(ts_GoToDefinition_exports, {
-    createDefinitionInfo: () => createDefinitionInfo,
-    findReferenceInPosition: () => findReferenceInPosition,
-    getDefinitionAndBoundSpan: () => getDefinitionAndBoundSpan,
-    getDefinitionAtPosition: () => getDefinitionAtPosition,
-    getReferenceAtPosition: () => getReferenceAtPosition,
-    getTypeDefinitionAtPosition: () => getTypeDefinitionAtPosition
-  });
-  var init_ts_GoToDefinition = __esm({
-    "src/services/_namespaces/ts.GoToDefinition.ts"() {
+  // src/services/formatting/formattingContext.ts
+  var FormattingRequestKind, FormattingContext;
+  var init_formattingContext = __esm({
+    "src/services/formatting/formattingContext.ts"() {
       "use strict";
-      init_goToDefinition();
+      init_ts4();
+      FormattingRequestKind = /* @__PURE__ */ ((FormattingRequestKind2) => {
+        FormattingRequestKind2[FormattingRequestKind2["FormatDocument"] = 0] = "FormatDocument";
+        FormattingRequestKind2[FormattingRequestKind2["FormatSelection"] = 1] = "FormatSelection";
+        FormattingRequestKind2[FormattingRequestKind2["FormatOnEnter"] = 2] = "FormatOnEnter";
+        FormattingRequestKind2[FormattingRequestKind2["FormatOnSemicolon"] = 3] = "FormatOnSemicolon";
+        FormattingRequestKind2[FormattingRequestKind2["FormatOnOpeningCurlyBrace"] = 4] = "FormatOnOpeningCurlyBrace";
+        FormattingRequestKind2[FormattingRequestKind2["FormatOnClosingCurlyBrace"] = 5] = "FormatOnClosingCurlyBrace";
+        return FormattingRequestKind2;
+      })(FormattingRequestKind || {});
+      FormattingContext = class {
+        constructor(sourceFile, formattingRequestKind, options) {
+          this.sourceFile = sourceFile;
+          this.formattingRequestKind = formattingRequestKind;
+          this.options = options;
+        }
+        updateContext(currentRange, currentTokenParent, nextRange, nextTokenParent, commonParent) {
+          this.currentTokenSpan = Debug.checkDefined(currentRange);
+          this.currentTokenParent = Debug.checkDefined(currentTokenParent);
+          this.nextTokenSpan = Debug.checkDefined(nextRange);
+          this.nextTokenParent = Debug.checkDefined(nextTokenParent);
+          this.contextNode = Debug.checkDefined(commonParent);
+          this.contextNodeAllOnSameLine = void 0;
+          this.nextNodeAllOnSameLine = void 0;
+          this.tokensAreOnSameLine = void 0;
+          this.contextNodeBlockIsOnOneLine = void 0;
+          this.nextNodeBlockIsOnOneLine = void 0;
+        }
+        ContextNodeAllOnSameLine() {
+          if (this.contextNodeAllOnSameLine === void 0) {
+            this.contextNodeAllOnSameLine = this.NodeIsOnOneLine(this.contextNode);
+          }
+          return this.contextNodeAllOnSameLine;
+        }
+        NextNodeAllOnSameLine() {
+          if (this.nextNodeAllOnSameLine === void 0) {
+            this.nextNodeAllOnSameLine = this.NodeIsOnOneLine(this.nextTokenParent);
+          }
+          return this.nextNodeAllOnSameLine;
+        }
+        TokensAreOnSameLine() {
+          if (this.tokensAreOnSameLine === void 0) {
+            const startLine = this.sourceFile.getLineAndCharacterOfPosition(this.currentTokenSpan.pos).line;
+            const endLine = this.sourceFile.getLineAndCharacterOfPosition(this.nextTokenSpan.pos).line;
+            this.tokensAreOnSameLine = startLine === endLine;
+          }
+          return this.tokensAreOnSameLine;
+        }
+        ContextNodeBlockIsOnOneLine() {
+          if (this.contextNodeBlockIsOnOneLine === void 0) {
+            this.contextNodeBlockIsOnOneLine = this.BlockIsOnOneLine(this.contextNode);
+          }
+          return this.contextNodeBlockIsOnOneLine;
+        }
+        NextNodeBlockIsOnOneLine() {
+          if (this.nextNodeBlockIsOnOneLine === void 0) {
+            this.nextNodeBlockIsOnOneLine = this.BlockIsOnOneLine(this.nextTokenParent);
+          }
+          return this.nextNodeBlockIsOnOneLine;
+        }
+        NodeIsOnOneLine(node) {
+          const startLine = this.sourceFile.getLineAndCharacterOfPosition(node.getStart(this.sourceFile)).line;
+          const endLine = this.sourceFile.getLineAndCharacterOfPosition(node.getEnd()).line;
+          return startLine === endLine;
+        }
+        BlockIsOnOneLine(node) {
+          const openBrace = findChildOfKind(node, 19 /* OpenBraceToken */, this.sourceFile);
+          const closeBrace = findChildOfKind(node, 20 /* CloseBraceToken */, this.sourceFile);
+          if (openBrace && closeBrace) {
+            const startLine = this.sourceFile.getLineAndCharacterOfPosition(openBrace.getEnd()).line;
+            const endLine = this.sourceFile.getLineAndCharacterOfPosition(closeBrace.getStart(this.sourceFile)).line;
+            return startLine === endLine;
+          }
+          return false;
+        }
+      };
     }
   });
 
-  // src/services/inlayHints.ts
-  function shouldShowParameterNameHints(preferences) {
-    return preferences.includeInlayParameterNameHints === "literals" || preferences.includeInlayParameterNameHints === "all";
-  }
-  function shouldShowLiteralParameterNameHintsOnly(preferences) {
-    return preferences.includeInlayParameterNameHints === "literals";
-  }
-  function provideInlayHints(context) {
-    const { file, program, span, cancellationToken, preferences } = context;
-    const sourceFileText = file.text;
-    const compilerOptions = program.getCompilerOptions();
-    const checker = program.getTypeChecker();
-    const result = [];
-    visitor(file);
-    return result;
-    function visitor(node) {
-      if (!node || node.getFullWidth() === 0) {
-        return;
-      }
-      switch (node.kind) {
-        case 266 /* ModuleDeclaration */:
-        case 262 /* ClassDeclaration */:
-        case 263 /* InterfaceDeclaration */:
-        case 261 /* FunctionDeclaration */:
-        case 230 /* ClassExpression */:
-        case 217 /* FunctionExpression */:
-        case 173 /* MethodDeclaration */:
-        case 218 /* ArrowFunction */:
-          cancellationToken.throwIfCancellationRequested();
+  // src/services/formatting/formattingScanner.ts
+  function getFormattingScanner(text, languageVariant, startPos, endPos, cb) {
+    const scanner2 = languageVariant === 1 /* JSX */ ? jsxScanner : standardScanner;
+    scanner2.setText(text);
+    scanner2.resetTokenState(startPos);
+    let wasNewLine = true;
+    let leadingTrivia;
+    let trailingTrivia;
+    let savedPos;
+    let lastScanAction;
+    let lastTokenInfo;
+    const res = cb({
+      advance,
+      readTokenInfo,
+      readEOFTokenRange,
+      isOnToken,
+      isOnEOF,
+      getCurrentLeadingTrivia: () => leadingTrivia,
+      lastTrailingTriviaWasNewLine: () => wasNewLine,
+      skipToEndOf,
+      skipToStartOf,
+      getTokenFullStart: () => (lastTokenInfo == null ? void 0 : lastTokenInfo.token.pos) ?? scanner2.getTokenStart(),
+      getStartPos: () => (lastTokenInfo == null ? void 0 : lastTokenInfo.token.pos) ?? scanner2.getTokenStart()
+    });
+    lastTokenInfo = void 0;
+    scanner2.setText(void 0);
+    return res;
+    function advance() {
+      lastTokenInfo = void 0;
+      const isStarted = scanner2.getTokenFullStart() !== startPos;
+      if (isStarted) {
+        wasNewLine = !!trailingTrivia && last(trailingTrivia).kind === 4 /* NewLineTrivia */;
+      } else {
+        scanner2.scan();
       }
-      if (!textSpanIntersectsWith(span, node.pos, node.getFullWidth())) {
-        return;
+      leadingTrivia = void 0;
+      trailingTrivia = void 0;
+      let pos = scanner2.getTokenFullStart();
+      while (pos < endPos) {
+        const t = scanner2.getToken();
+        if (!isTrivia(t)) {
+          break;
+        }
+        scanner2.scan();
+        const item = {
+          pos,
+          end: scanner2.getTokenFullStart(),
+          kind: t
+        };
+        pos = scanner2.getTokenFullStart();
+        leadingTrivia = append(leadingTrivia, item);
       }
-      if (isTypeNode(node) && !isExpressionWithTypeArguments(node)) {
-        return;
+      savedPos = scanner2.getTokenFullStart();
+    }
+    function shouldRescanGreaterThanToken(node) {
+      switch (node.kind) {
+        case 34 /* GreaterThanEqualsToken */:
+        case 72 /* GreaterThanGreaterThanEqualsToken */:
+        case 73 /* GreaterThanGreaterThanGreaterThanEqualsToken */:
+        case 50 /* GreaterThanGreaterThanGreaterThanToken */:
+        case 49 /* GreaterThanGreaterThanToken */:
+          return true;
       }
-      if (preferences.includeInlayVariableTypeHints && isVariableDeclaration(node)) {
-        visitVariableLikeDeclaration(node);
-      } else if (preferences.includeInlayPropertyDeclarationTypeHints && isPropertyDeclaration(node)) {
-        visitVariableLikeDeclaration(node);
-      } else if (preferences.includeInlayEnumMemberValueHints && isEnumMember(node)) {
-        visitEnumMember(node);
-      } else if (shouldShowParameterNameHints(preferences) && (isCallExpression(node) || isNewExpression(node))) {
-        visitCallOrNewExpression(node);
-      } else {
-        if (preferences.includeInlayFunctionParameterTypeHints && isFunctionLikeDeclaration(node) && hasContextSensitiveParameters(node)) {
-          visitFunctionLikeForParameterType(node);
-        }
-        if (preferences.includeInlayFunctionLikeReturnTypeHints && isSignatureSupportingReturnAnnotation(node)) {
-          visitFunctionDeclarationLikeForReturnType(node);
+      return false;
+    }
+    function shouldRescanJsxIdentifier(node) {
+      if (node.parent) {
+        switch (node.parent.kind) {
+          case 291 /* JsxAttribute */:
+          case 286 /* JsxOpeningElement */:
+          case 287 /* JsxClosingElement */:
+          case 285 /* JsxSelfClosingElement */:
+            return isKeyword(node.kind) || node.kind === 80 /* Identifier */;
         }
       }
-      return forEachChild(node, visitor);
-    }
-    function isSignatureSupportingReturnAnnotation(node) {
-      return isArrowFunction(node) || isFunctionExpression(node) || isFunctionDeclaration(node) || isMethodDeclaration(node) || isGetAccessorDeclaration(node);
+      return false;
     }
-    function addParameterHints(text, position, isFirstVariadicArgument) {
-      result.push({
-        text: `${isFirstVariadicArgument ? "..." : ""}${truncation(text, maxHintsLength)}:`,
-        position,
-        kind: "Parameter" /* Parameter */,
-        whitespaceAfter: true
-      });
+    function shouldRescanJsxText(node) {
+      return isJsxText(node) || isJsxElement(node) && (lastTokenInfo == null ? void 0 : lastTokenInfo.token.kind) === 12 /* JsxText */;
     }
-    function addTypeHints(text, position) {
-      result.push({
-        text: `: ${truncation(text, maxHintsLength)}`,
-        position,
-        kind: "Type" /* Type */,
-        whitespaceBefore: true
-      });
+    function shouldRescanSlashToken(container) {
+      return container.kind === 14 /* RegularExpressionLiteral */;
     }
-    function addEnumMemberValueHints(text, position) {
-      result.push({
-        text: `= ${truncation(text, maxHintsLength)}`,
-        position,
-        kind: "Enum" /* Enum */,
-        whitespaceBefore: true
-      });
+    function shouldRescanTemplateToken(container) {
+      return container.kind === 17 /* TemplateMiddle */ || container.kind === 18 /* TemplateTail */;
     }
-    function visitEnumMember(member) {
-      if (member.initializer) {
-        return;
-      }
-      const enumValue = checker.getConstantValue(member);
-      if (enumValue !== void 0) {
-        addEnumMemberValueHints(enumValue.toString(), member.end);
-      }
+    function shouldRescanJsxAttributeValue(node) {
+      return node.parent && isJsxAttribute(node.parent) && node.parent.initializer === node;
     }
-    function isModuleReferenceType(type) {
-      return type.symbol && type.symbol.flags & 1536 /* Module */;
+    function startsWithSlashToken(t) {
+      return t === 44 /* SlashToken */ || t === 69 /* SlashEqualsToken */;
     }
-    function visitVariableLikeDeclaration(decl) {
-      if (!decl.initializer || isBindingPattern(decl.name) || isVariableDeclaration(decl) && !isHintableDeclaration(decl)) {
-        return;
+    function readTokenInfo(n) {
+      Debug.assert(isOnToken());
+      const expectedScanAction = shouldRescanGreaterThanToken(n) ? 1 /* RescanGreaterThanToken */ : shouldRescanSlashToken(n) ? 2 /* RescanSlashToken */ : shouldRescanTemplateToken(n) ? 3 /* RescanTemplateToken */ : shouldRescanJsxIdentifier(n) ? 4 /* RescanJsxIdentifier */ : shouldRescanJsxText(n) ? 5 /* RescanJsxText */ : shouldRescanJsxAttributeValue(n) ? 6 /* RescanJsxAttributeValue */ : 0 /* Scan */;
+      if (lastTokenInfo && expectedScanAction === lastScanAction) {
+        return fixTokenKind(lastTokenInfo, n);
       }
-      const effectiveTypeAnnotation = getEffectiveTypeAnnotationNode(decl);
-      if (effectiveTypeAnnotation) {
-        return;
+      if (scanner2.getTokenFullStart() !== savedPos) {
+        Debug.assert(lastTokenInfo !== void 0);
+        scanner2.resetTokenState(savedPos);
+        scanner2.scan();
       }
-      const declarationType = checker.getTypeAtLocation(decl);
-      if (isModuleReferenceType(declarationType)) {
-        return;
+      let currentToken = getNextToken(n, expectedScanAction);
+      const token = createTextRangeWithKind(
+        scanner2.getTokenFullStart(),
+        scanner2.getTokenEnd(),
+        currentToken
+      );
+      if (trailingTrivia) {
+        trailingTrivia = void 0;
       }
-      const typeDisplayString = printTypeInSingleLine(declarationType);
-      if (typeDisplayString) {
-        const isVariableNameMatchesType = preferences.includeInlayVariableTypeHintsWhenTypeMatchesName === false && equateStringsCaseInsensitive(decl.name.getText(), typeDisplayString);
-        if (isVariableNameMatchesType) {
-          return;
+      while (scanner2.getTokenFullStart() < endPos) {
+        currentToken = scanner2.scan();
+        if (!isTrivia(currentToken)) {
+          break;
+        }
+        const trivia = createTextRangeWithKind(
+          scanner2.getTokenFullStart(),
+          scanner2.getTokenEnd(),
+          currentToken
+        );
+        if (!trailingTrivia) {
+          trailingTrivia = [];
+        }
+        trailingTrivia.push(trivia);
+        if (currentToken === 4 /* NewLineTrivia */) {
+          scanner2.scan();
+          break;
         }
-        addTypeHints(typeDisplayString, decl.name.end);
       }
+      lastTokenInfo = { leadingTrivia, trailingTrivia, token };
+      return fixTokenKind(lastTokenInfo, n);
     }
-    function visitCallOrNewExpression(expr) {
-      const args = expr.arguments;
-      if (!args || !args.length) {
-        return;
-      }
-      const candidates = [];
-      const signature = checker.getResolvedSignatureForSignatureHelp(expr, candidates);
-      if (!signature || !candidates.length) {
-        return;
-      }
-      for (let i = 0; i < args.length; ++i) {
-        const originalArg = args[i];
-        const arg = skipParentheses(originalArg);
-        if (shouldShowLiteralParameterNameHintsOnly(preferences) && !isHintableLiteral(arg)) {
-          continue;
-        }
-        const identifierNameInfo = checker.getParameterIdentifierNameAtPosition(signature, i);
-        if (identifierNameInfo) {
-          const [parameterName, isFirstVariadicArgument] = identifierNameInfo;
-          const isParameterNameNotSameAsArgument = preferences.includeInlayParameterNameHintsWhenArgumentMatchesName || !identifierOrAccessExpressionPostfixMatchesParameterName(arg, parameterName);
-          if (!isParameterNameNotSameAsArgument && !isFirstVariadicArgument) {
-            continue;
+    function getNextToken(n, expectedScanAction) {
+      const token = scanner2.getToken();
+      lastScanAction = 0 /* Scan */;
+      switch (expectedScanAction) {
+        case 1 /* RescanGreaterThanToken */:
+          if (token === 32 /* GreaterThanToken */) {
+            lastScanAction = 1 /* RescanGreaterThanToken */;
+            const newToken = scanner2.reScanGreaterToken();
+            Debug.assert(n.kind === newToken);
+            return newToken;
           }
-          const name = unescapeLeadingUnderscores(parameterName);
-          if (leadingCommentsContainsParameterName(arg, name)) {
-            continue;
+          break;
+        case 2 /* RescanSlashToken */:
+          if (startsWithSlashToken(token)) {
+            lastScanAction = 2 /* RescanSlashToken */;
+            const newToken = scanner2.reScanSlashToken();
+            Debug.assert(n.kind === newToken);
+            return newToken;
           }
-          addParameterHints(name, originalArg.getStart(), isFirstVariadicArgument);
-        }
+          break;
+        case 3 /* RescanTemplateToken */:
+          if (token === 20 /* CloseBraceToken */) {
+            lastScanAction = 3 /* RescanTemplateToken */;
+            return scanner2.reScanTemplateToken(
+              /*isTaggedTemplate*/
+              false
+            );
+          }
+          break;
+        case 4 /* RescanJsxIdentifier */:
+          lastScanAction = 4 /* RescanJsxIdentifier */;
+          return scanner2.scanJsxIdentifier();
+        case 5 /* RescanJsxText */:
+          lastScanAction = 5 /* RescanJsxText */;
+          return scanner2.reScanJsxToken(
+            /*allowMultilineJsxText*/
+            false
+          );
+        case 6 /* RescanJsxAttributeValue */:
+          lastScanAction = 6 /* RescanJsxAttributeValue */;
+          return scanner2.reScanJsxAttributeValue();
+        case 0 /* Scan */:
+          break;
+        default:
+          Debug.assertNever(expectedScanAction);
       }
+      return token;
     }
-    function identifierOrAccessExpressionPostfixMatchesParameterName(expr, parameterName) {
-      if (isIdentifier(expr)) {
-        return expr.text === parameterName;
-      }
-      if (isPropertyAccessExpression(expr)) {
-        return expr.name.text === parameterName;
-      }
-      return false;
+    function readEOFTokenRange() {
+      Debug.assert(isOnEOF());
+      return createTextRangeWithKind(scanner2.getTokenFullStart(), scanner2.getTokenEnd(), 1 /* EndOfFileToken */);
     }
-    function leadingCommentsContainsParameterName(node, name) {
-      if (!isIdentifierText(name, compilerOptions.target, getLanguageVariant(file.scriptKind))) {
-        return false;
-      }
-      const ranges = getLeadingCommentRanges(sourceFileText, node.pos);
-      if (!(ranges == null ? void 0 : ranges.length)) {
-        return false;
-      }
-      const regex = leadingParameterNameCommentRegexFactory(name);
-      return some(ranges, (range) => regex.test(sourceFileText.substring(range.pos, range.end)));
+    function isOnToken() {
+      const current = lastTokenInfo ? lastTokenInfo.token.kind : scanner2.getToken();
+      return current !== 1 /* EndOfFileToken */ && !isTrivia(current);
     }
-    function isHintableLiteral(node) {
-      switch (node.kind) {
-        case 223 /* PrefixUnaryExpression */: {
-          const operand = node.operand;
-          return isLiteralExpression(operand) || isIdentifier(operand) && isInfinityOrNaNString(operand.escapedText);
-        }
-        case 112 /* TrueKeyword */:
-        case 97 /* FalseKeyword */:
-        case 106 /* NullKeyword */:
-        case 15 /* NoSubstitutionTemplateLiteral */:
-        case 227 /* TemplateExpression */:
-          return true;
-        case 80 /* Identifier */: {
-          const name = node.escapedText;
-          return isUndefined(name) || isInfinityOrNaNString(name);
-        }
-      }
-      return isLiteralExpression(node);
+    function isOnEOF() {
+      const current = lastTokenInfo ? lastTokenInfo.token.kind : scanner2.getToken();
+      return current === 1 /* EndOfFileToken */;
     }
-    function visitFunctionDeclarationLikeForReturnType(decl) {
-      if (isArrowFunction(decl)) {
-        if (!findChildOfKind(decl, 21 /* OpenParenToken */, file)) {
-          return;
-        }
-      }
-      const effectiveTypeAnnotation = getEffectiveReturnTypeNode(decl);
-      if (effectiveTypeAnnotation || !decl.body) {
-        return;
-      }
-      const signature = checker.getSignatureFromDeclaration(decl);
-      if (!signature) {
-        return;
-      }
-      const returnType = checker.getReturnTypeOfSignature(signature);
-      if (isModuleReferenceType(returnType)) {
-        return;
-      }
-      const typeDisplayString = printTypeInSingleLine(returnType);
-      if (!typeDisplayString) {
-        return;
+    function fixTokenKind(tokenInfo, container) {
+      if (isToken(container) && tokenInfo.token.kind !== container.kind) {
+        tokenInfo.token.kind = container.kind;
       }
-      addTypeHints(typeDisplayString, getTypeAnnotationPosition(decl));
+      return tokenInfo;
     }
-    function getTypeAnnotationPosition(decl) {
-      const closeParenToken = findChildOfKind(decl, 22 /* CloseParenToken */, file);
-      if (closeParenToken) {
-        return closeParenToken.end;
-      }
-      return decl.parameters.end;
+    function skipToEndOf(node) {
+      scanner2.resetTokenState(node.end);
+      savedPos = scanner2.getTokenFullStart();
+      lastScanAction = void 0;
+      lastTokenInfo = void 0;
+      wasNewLine = false;
+      leadingTrivia = void 0;
+      trailingTrivia = void 0;
     }
-    function visitFunctionLikeForParameterType(node) {
-      const signature = checker.getSignatureFromDeclaration(node);
-      if (!signature) {
-        return;
-      }
-      for (let i = 0; i < node.parameters.length && i < signature.parameters.length; ++i) {
-        const param = node.parameters[i];
-        if (!isHintableDeclaration(param)) {
-          continue;
-        }
-        const effectiveTypeAnnotation = getEffectiveTypeAnnotationNode(param);
-        if (effectiveTypeAnnotation) {
-          continue;
-        }
-        const typeDisplayString = getParameterDeclarationTypeDisplayString(signature.parameters[i]);
-        if (!typeDisplayString) {
-          continue;
-        }
-        addTypeHints(typeDisplayString, param.questionToken ? param.questionToken.end : param.name.end);
-      }
+    function skipToStartOf(node) {
+      scanner2.resetTokenState(node.pos);
+      savedPos = scanner2.getTokenFullStart();
+      lastScanAction = void 0;
+      lastTokenInfo = void 0;
+      wasNewLine = false;
+      leadingTrivia = void 0;
+      trailingTrivia = void 0;
     }
-    function getParameterDeclarationTypeDisplayString(symbol) {
-      const valueDeclaration = symbol.valueDeclaration;
-      if (!valueDeclaration || !isParameter(valueDeclaration)) {
-        return void 0;
-      }
-      const signatureParamType = checker.getTypeOfSymbolAtLocation(symbol, valueDeclaration);
-      if (isModuleReferenceType(signatureParamType)) {
-        return void 0;
+  }
+  var standardScanner, jsxScanner;
+  var init_formattingScanner = __esm({
+    "src/services/formatting/formattingScanner.ts"() {
+      "use strict";
+      init_ts4();
+      init_ts_formatting();
+      standardScanner = createScanner(
+        99 /* Latest */,
+        /*skipTrivia*/
+        false,
+        0 /* Standard */
+      );
+      jsxScanner = createScanner(
+        99 /* Latest */,
+        /*skipTrivia*/
+        false,
+        1 /* JSX */
+      );
+    }
+  });
+
+  // src/services/formatting/rule.ts
+  var anyContext, RuleAction, RuleFlags;
+  var init_rule = __esm({
+    "src/services/formatting/rule.ts"() {
+      "use strict";
+      init_ts4();
+      anyContext = emptyArray;
+      RuleAction = /* @__PURE__ */ ((RuleAction2) => {
+        RuleAction2[RuleAction2["None"] = 0] = "None";
+        RuleAction2[RuleAction2["StopProcessingSpaceActions"] = 1] = "StopProcessingSpaceActions";
+        RuleAction2[RuleAction2["StopProcessingTokenActions"] = 2] = "StopProcessingTokenActions";
+        RuleAction2[RuleAction2["InsertSpace"] = 4] = "InsertSpace";
+        RuleAction2[RuleAction2["InsertNewLine"] = 8] = "InsertNewLine";
+        RuleAction2[RuleAction2["DeleteSpace"] = 16] = "DeleteSpace";
+        RuleAction2[RuleAction2["DeleteToken"] = 32] = "DeleteToken";
+        RuleAction2[RuleAction2["InsertTrailingSemicolon"] = 64] = "InsertTrailingSemicolon";
+        RuleAction2[RuleAction2["StopAction"] = 3] = "StopAction";
+        RuleAction2[RuleAction2["ModifySpaceAction"] = 28] = "ModifySpaceAction";
+        RuleAction2[RuleAction2["ModifyTokenAction"] = 96] = "ModifyTokenAction";
+        return RuleAction2;
+      })(RuleAction || {});
+      RuleFlags = /* @__PURE__ */ ((RuleFlags2) => {
+        RuleFlags2[RuleFlags2["None"] = 0] = "None";
+        RuleFlags2[RuleFlags2["CanDeleteNewLines"] = 1] = "CanDeleteNewLines";
+        return RuleFlags2;
+      })(RuleFlags || {});
+    }
+  });
+
+  // src/services/formatting/rules.ts
+  function getAllRules() {
+    const allTokens = [];
+    for (let token = 0 /* FirstToken */; token <= 165 /* LastToken */; token++) {
+      if (token !== 1 /* EndOfFileToken */) {
+        allTokens.push(token);
       }
-      return printTypeInSingleLine(signatureParamType);
     }
-    function truncation(text, maxLength2) {
-      if (text.length > maxLength2) {
-        return text.substr(0, maxLength2 - "...".length) + "...";
+    function anyTokenExcept(...tokens) {
+      return { tokens: allTokens.filter((t) => !tokens.some((t2) => t2 === t)), isSpecific: false };
+    }
+    const anyToken = { tokens: allTokens, isSpecific: false };
+    const anyTokenIncludingMultilineComments = tokenRangeFrom([...allTokens, 3 /* MultiLineCommentTrivia */]);
+    const anyTokenIncludingEOF = tokenRangeFrom([...allTokens, 1 /* EndOfFileToken */]);
+    const keywords = tokenRangeFromRange(83 /* FirstKeyword */, 165 /* LastKeyword */);
+    const binaryOperators = tokenRangeFromRange(30 /* FirstBinaryOperator */, 79 /* LastBinaryOperator */);
+    const binaryKeywordOperators = [
+      103 /* InKeyword */,
+      104 /* InstanceOfKeyword */,
+      165 /* OfKeyword */,
+      130 /* AsKeyword */,
+      142 /* IsKeyword */,
+      152 /* SatisfiesKeyword */
+    ];
+    const unaryPrefixOperators = [46 /* PlusPlusToken */, 47 /* MinusMinusToken */, 55 /* TildeToken */, 54 /* ExclamationToken */];
+    const unaryPrefixExpressions = [
+      9 /* NumericLiteral */,
+      10 /* BigIntLiteral */,
+      80 /* Identifier */,
+      21 /* OpenParenToken */,
+      23 /* OpenBracketToken */,
+      19 /* OpenBraceToken */,
+      110 /* ThisKeyword */,
+      105 /* NewKeyword */
+    ];
+    const unaryPreincrementExpressions = [80 /* Identifier */, 21 /* OpenParenToken */, 110 /* ThisKeyword */, 105 /* NewKeyword */];
+    const unaryPostincrementExpressions = [80 /* Identifier */, 22 /* CloseParenToken */, 24 /* CloseBracketToken */, 105 /* NewKeyword */];
+    const unaryPredecrementExpressions = [80 /* Identifier */, 21 /* OpenParenToken */, 110 /* ThisKeyword */, 105 /* NewKeyword */];
+    const unaryPostdecrementExpressions = [80 /* Identifier */, 22 /* CloseParenToken */, 24 /* CloseBracketToken */, 105 /* NewKeyword */];
+    const comments = [2 /* SingleLineCommentTrivia */, 3 /* MultiLineCommentTrivia */];
+    const typeNames = [80 /* Identifier */, ...typeKeywords];
+    const functionOpenBraceLeftTokenRange = anyTokenIncludingMultilineComments;
+    const typeScriptOpenBraceLeftTokenRange = tokenRangeFrom([80 /* Identifier */, 3 /* MultiLineCommentTrivia */, 86 /* ClassKeyword */, 95 /* ExportKeyword */, 102 /* ImportKeyword */]);
+    const controlOpenBraceLeftTokenRange = tokenRangeFrom([22 /* CloseParenToken */, 3 /* MultiLineCommentTrivia */, 92 /* DoKeyword */, 113 /* TryKeyword */, 98 /* FinallyKeyword */, 93 /* ElseKeyword */]);
+    const highPriorityCommonRules = [
+      // Leave comments alone
+      rule("IgnoreBeforeComment", anyToken, comments, anyContext, 1 /* StopProcessingSpaceActions */),
+      rule("IgnoreAfterLineComment", 2 /* SingleLineCommentTrivia */, anyToken, anyContext, 1 /* StopProcessingSpaceActions */),
+      rule("NotSpaceBeforeColon", anyToken, 59 /* ColonToken */, [isNonJsxSameLineTokenContext, isNotBinaryOpContext, isNotTypeAnnotationContext], 16 /* DeleteSpace */),
+      rule("SpaceAfterColon", 59 /* ColonToken */, anyToken, [isNonJsxSameLineTokenContext, isNotBinaryOpContext, isNextTokenParentNotJsxNamespacedName], 4 /* InsertSpace */),
+      rule("NoSpaceBeforeQuestionMark", anyToken, 58 /* QuestionToken */, [isNonJsxSameLineTokenContext, isNotBinaryOpContext, isNotTypeAnnotationContext], 16 /* DeleteSpace */),
+      // insert space after '?' only when it is used in conditional operator
+      rule("SpaceAfterQuestionMarkInConditionalOperator", 58 /* QuestionToken */, anyToken, [isNonJsxSameLineTokenContext, isConditionalOperatorContext], 4 /* InsertSpace */),
+      // in other cases there should be no space between '?' and next token
+      rule("NoSpaceAfterQuestionMark", 58 /* QuestionToken */, anyToken, [isNonJsxSameLineTokenContext, isNonOptionalPropertyContext], 16 /* DeleteSpace */),
+      rule("NoSpaceBeforeDot", anyToken, [25 /* DotToken */, 29 /* QuestionDotToken */], [isNonJsxSameLineTokenContext, isNotPropertyAccessOnIntegerLiteral], 16 /* DeleteSpace */),
+      rule("NoSpaceAfterDot", [25 /* DotToken */, 29 /* QuestionDotToken */], anyToken, [isNonJsxSameLineTokenContext], 16 /* DeleteSpace */),
+      rule("NoSpaceBetweenImportParenInImportType", 102 /* ImportKeyword */, 21 /* OpenParenToken */, [isNonJsxSameLineTokenContext, isImportTypeContext], 16 /* DeleteSpace */),
+      // Special handling of unary operators.
+      // Prefix operators generally shouldn't have a space between
+      // them and their target unary expression.
+      rule("NoSpaceAfterUnaryPrefixOperator", unaryPrefixOperators, unaryPrefixExpressions, [isNonJsxSameLineTokenContext, isNotBinaryOpContext], 16 /* DeleteSpace */),
+      rule("NoSpaceAfterUnaryPreincrementOperator", 46 /* PlusPlusToken */, unaryPreincrementExpressions, [isNonJsxSameLineTokenContext], 16 /* DeleteSpace */),
+      rule("NoSpaceAfterUnaryPredecrementOperator", 47 /* MinusMinusToken */, unaryPredecrementExpressions, [isNonJsxSameLineTokenContext], 16 /* DeleteSpace */),
+      rule("NoSpaceBeforeUnaryPostincrementOperator", unaryPostincrementExpressions, 46 /* PlusPlusToken */, [isNonJsxSameLineTokenContext, isNotStatementConditionContext], 16 /* DeleteSpace */),
+      rule("NoSpaceBeforeUnaryPostdecrementOperator", unaryPostdecrementExpressions, 47 /* MinusMinusToken */, [isNonJsxSameLineTokenContext, isNotStatementConditionContext], 16 /* DeleteSpace */),
+      // More unary operator special-casing.
+      // DevDiv 181814: Be careful when removing leading whitespace
+      // around unary operators.  Examples:
+      //      1 - -2  --X--> 1--2
+      //      a + ++b --X--> a+++b
+      rule("SpaceAfterPostincrementWhenFollowedByAdd", 46 /* PlusPlusToken */, 40 /* PlusToken */, [isNonJsxSameLineTokenContext, isBinaryOpContext], 4 /* InsertSpace */),
+      rule("SpaceAfterAddWhenFollowedByUnaryPlus", 40 /* PlusToken */, 40 /* PlusToken */, [isNonJsxSameLineTokenContext, isBinaryOpContext], 4 /* InsertSpace */),
+      rule("SpaceAfterAddWhenFollowedByPreincrement", 40 /* PlusToken */, 46 /* PlusPlusToken */, [isNonJsxSameLineTokenContext, isBinaryOpContext], 4 /* InsertSpace */),
+      rule("SpaceAfterPostdecrementWhenFollowedBySubtract", 47 /* MinusMinusToken */, 41 /* MinusToken */, [isNonJsxSameLineTokenContext, isBinaryOpContext], 4 /* InsertSpace */),
+      rule("SpaceAfterSubtractWhenFollowedByUnaryMinus", 41 /* MinusToken */, 41 /* MinusToken */, [isNonJsxSameLineTokenContext, isBinaryOpContext], 4 /* InsertSpace */),
+      rule("SpaceAfterSubtractWhenFollowedByPredecrement", 41 /* MinusToken */, 47 /* MinusMinusToken */, [isNonJsxSameLineTokenContext, isBinaryOpContext], 4 /* InsertSpace */),
+      rule("NoSpaceAfterCloseBrace", 20 /* CloseBraceToken */, [28 /* CommaToken */, 27 /* SemicolonToken */], [isNonJsxSameLineTokenContext], 16 /* DeleteSpace */),
+      // For functions and control block place } on a new line [multi-line rule]
+      rule("NewLineBeforeCloseBraceInBlockContext", anyTokenIncludingMultilineComments, 20 /* CloseBraceToken */, [isMultilineBlockContext], 8 /* InsertNewLine */),
+      // Space/new line after }.
+      rule("SpaceAfterCloseBrace", 20 /* CloseBraceToken */, anyTokenExcept(22 /* CloseParenToken */), [isNonJsxSameLineTokenContext, isAfterCodeBlockContext], 4 /* InsertSpace */),
+      // Special case for (}, else) and (}, while) since else & while tokens are not part of the tree which makes SpaceAfterCloseBrace rule not applied
+      // Also should not apply to })
+      rule("SpaceBetweenCloseBraceAndElse", 20 /* CloseBraceToken */, 93 /* ElseKeyword */, [isNonJsxSameLineTokenContext], 4 /* InsertSpace */),
+      rule("SpaceBetweenCloseBraceAndWhile", 20 /* CloseBraceToken */, 117 /* WhileKeyword */, [isNonJsxSameLineTokenContext], 4 /* InsertSpace */),
+      rule("NoSpaceBetweenEmptyBraceBrackets", 19 /* OpenBraceToken */, 20 /* CloseBraceToken */, [isNonJsxSameLineTokenContext, isObjectContext], 16 /* DeleteSpace */),
+      // Add a space after control dec context if the next character is an open bracket ex: 'if (false)[a, b] = [1, 2];' -> 'if (false) [a, b] = [1, 2];'
+      rule("SpaceAfterConditionalClosingParen", 22 /* CloseParenToken */, 23 /* OpenBracketToken */, [isControlDeclContext], 4 /* InsertSpace */),
+      rule("NoSpaceBetweenFunctionKeywordAndStar", 100 /* FunctionKeyword */, 42 /* AsteriskToken */, [isFunctionDeclarationOrFunctionExpressionContext], 16 /* DeleteSpace */),
+      rule("SpaceAfterStarInGeneratorDeclaration", 42 /* AsteriskToken */, 80 /* Identifier */, [isFunctionDeclarationOrFunctionExpressionContext], 4 /* InsertSpace */),
+      rule("SpaceAfterFunctionInFuncDecl", 100 /* FunctionKeyword */, anyToken, [isFunctionDeclContext], 4 /* InsertSpace */),
+      // Insert new line after { and before } in multi-line contexts.
+      rule("NewLineAfterOpenBraceInBlockContext", 19 /* OpenBraceToken */, anyToken, [isMultilineBlockContext], 8 /* InsertNewLine */),
+      // For get/set members, we check for (identifier,identifier) since get/set don't have tokens and they are represented as just an identifier token.
+      // Though, we do extra check on the context to make sure we are dealing with get/set node. Example:
+      //      get x() {}
+      //      set x(val) {}
+      rule("SpaceAfterGetSetInMember", [139 /* GetKeyword */, 153 /* SetKeyword */], 80 /* Identifier */, [isFunctionDeclContext], 4 /* InsertSpace */),
+      rule("NoSpaceBetweenYieldKeywordAndStar", 127 /* YieldKeyword */, 42 /* AsteriskToken */, [isNonJsxSameLineTokenContext, isYieldOrYieldStarWithOperand], 16 /* DeleteSpace */),
+      rule("SpaceBetweenYieldOrYieldStarAndOperand", [127 /* YieldKeyword */, 42 /* AsteriskToken */], anyToken, [isNonJsxSameLineTokenContext, isYieldOrYieldStarWithOperand], 4 /* InsertSpace */),
+      rule("NoSpaceBetweenReturnAndSemicolon", 107 /* ReturnKeyword */, 27 /* SemicolonToken */, [isNonJsxSameLineTokenContext], 16 /* DeleteSpace */),
+      rule("SpaceAfterCertainKeywords", [115 /* VarKeyword */, 111 /* ThrowKeyword */, 105 /* NewKeyword */, 91 /* DeleteKeyword */, 107 /* ReturnKeyword */, 114 /* TypeOfKeyword */, 135 /* AwaitKeyword */], anyToken, [isNonJsxSameLineTokenContext], 4 /* InsertSpace */),
+      rule("SpaceAfterLetConstInVariableDeclaration", [121 /* LetKeyword */, 87 /* ConstKeyword */], anyToken, [isNonJsxSameLineTokenContext, isStartOfVariableDeclarationList], 4 /* InsertSpace */),
+      rule("NoSpaceBeforeOpenParenInFuncCall", anyToken, 21 /* OpenParenToken */, [isNonJsxSameLineTokenContext, isFunctionCallOrNewContext, isPreviousTokenNotComma], 16 /* DeleteSpace */),
+      // Special case for binary operators (that are keywords). For these we have to add a space and shouldn't follow any user options.
+      rule("SpaceBeforeBinaryKeywordOperator", anyToken, binaryKeywordOperators, [isNonJsxSameLineTokenContext, isBinaryOpContext], 4 /* InsertSpace */),
+      rule("SpaceAfterBinaryKeywordOperator", binaryKeywordOperators, anyToken, [isNonJsxSameLineTokenContext, isBinaryOpContext], 4 /* InsertSpace */),
+      rule("SpaceAfterVoidOperator", 116 /* VoidKeyword */, anyToken, [isNonJsxSameLineTokenContext, isVoidOpContext], 4 /* InsertSpace */),
+      // Async-await
+      rule("SpaceBetweenAsyncAndOpenParen", 134 /* AsyncKeyword */, 21 /* OpenParenToken */, [isArrowFunctionContext, isNonJsxSameLineTokenContext], 4 /* InsertSpace */),
+      rule("SpaceBetweenAsyncAndFunctionKeyword", 134 /* AsyncKeyword */, [100 /* FunctionKeyword */, 80 /* Identifier */], [isNonJsxSameLineTokenContext], 4 /* InsertSpace */),
+      // Template string
+      rule("NoSpaceBetweenTagAndTemplateString", [80 /* Identifier */, 22 /* CloseParenToken */], [15 /* NoSubstitutionTemplateLiteral */, 16 /* TemplateHead */], [isNonJsxSameLineTokenContext], 16 /* DeleteSpace */),
+      // JSX opening elements
+      rule("SpaceBeforeJsxAttribute", anyToken, 80 /* Identifier */, [isNextTokenParentJsxAttribute, isNonJsxSameLineTokenContext], 4 /* InsertSpace */),
+      rule("SpaceBeforeSlashInJsxOpeningElement", anyToken, 44 /* SlashToken */, [isJsxSelfClosingElementContext, isNonJsxSameLineTokenContext], 4 /* InsertSpace */),
+      rule("NoSpaceBeforeGreaterThanTokenInJsxOpeningElement", 44 /* SlashToken */, 32 /* GreaterThanToken */, [isJsxSelfClosingElementContext, isNonJsxSameLineTokenContext], 16 /* DeleteSpace */),
+      rule("NoSpaceBeforeEqualInJsxAttribute", anyToken, 64 /* EqualsToken */, [isJsxAttributeContext, isNonJsxSameLineTokenContext], 16 /* DeleteSpace */),
+      rule("NoSpaceAfterEqualInJsxAttribute", 64 /* EqualsToken */, anyToken, [isJsxAttributeContext, isNonJsxSameLineTokenContext], 16 /* DeleteSpace */),
+      rule("NoSpaceBeforeJsxNamespaceColon", 80 /* Identifier */, 59 /* ColonToken */, [isNextTokenParentJsxNamespacedName], 16 /* DeleteSpace */),
+      rule("NoSpaceAfterJsxNamespaceColon", 59 /* ColonToken */, 80 /* Identifier */, [isNextTokenParentJsxNamespacedName], 16 /* DeleteSpace */),
+      // TypeScript-specific rules
+      // Use of module as a function call. e.g.: import m2 = module("m2");
+      rule("NoSpaceAfterModuleImport", [144 /* ModuleKeyword */, 149 /* RequireKeyword */], 21 /* OpenParenToken */, [isNonJsxSameLineTokenContext], 16 /* DeleteSpace */),
+      // Add a space around certain TypeScript keywords
+      rule(
+        "SpaceAfterCertainTypeScriptKeywords",
+        [
+          128 /* AbstractKeyword */,
+          129 /* AccessorKeyword */,
+          86 /* ClassKeyword */,
+          138 /* DeclareKeyword */,
+          90 /* DefaultKeyword */,
+          94 /* EnumKeyword */,
+          95 /* ExportKeyword */,
+          96 /* ExtendsKeyword */,
+          139 /* GetKeyword */,
+          119 /* ImplementsKeyword */,
+          102 /* ImportKeyword */,
+          120 /* InterfaceKeyword */,
+          144 /* ModuleKeyword */,
+          145 /* NamespaceKeyword */,
+          123 /* PrivateKeyword */,
+          125 /* PublicKeyword */,
+          124 /* ProtectedKeyword */,
+          148 /* ReadonlyKeyword */,
+          153 /* SetKeyword */,
+          126 /* StaticKeyword */,
+          156 /* TypeKeyword */,
+          161 /* FromKeyword */,
+          143 /* KeyOfKeyword */,
+          140 /* InferKeyword */
+        ],
+        anyToken,
+        [isNonJsxSameLineTokenContext],
+        4 /* InsertSpace */
+      ),
+      rule(
+        "SpaceBeforeCertainTypeScriptKeywords",
+        anyToken,
+        [96 /* ExtendsKeyword */, 119 /* ImplementsKeyword */, 161 /* FromKeyword */],
+        [isNonJsxSameLineTokenContext],
+        4 /* InsertSpace */
+      ),
+      // Treat string literals in module names as identifiers, and add a space between the literal and the opening Brace braces, e.g.: module "m2" {
+      rule("SpaceAfterModuleName", 11 /* StringLiteral */, 19 /* OpenBraceToken */, [isModuleDeclContext], 4 /* InsertSpace */),
+      // Lambda expressions
+      rule("SpaceBeforeArrow", anyToken, 39 /* EqualsGreaterThanToken */, [isNonJsxSameLineTokenContext], 4 /* InsertSpace */),
+      rule("SpaceAfterArrow", 39 /* EqualsGreaterThanToken */, anyToken, [isNonJsxSameLineTokenContext], 4 /* InsertSpace */),
+      // Optional parameters and let args
+      rule("NoSpaceAfterEllipsis", 26 /* DotDotDotToken */, 80 /* Identifier */, [isNonJsxSameLineTokenContext], 16 /* DeleteSpace */),
+      rule("NoSpaceAfterOptionalParameters", 58 /* QuestionToken */, [22 /* CloseParenToken */, 28 /* CommaToken */], [isNonJsxSameLineTokenContext, isNotBinaryOpContext], 16 /* DeleteSpace */),
+      // Remove spaces in empty interface literals. e.g.: x: {}
+      rule("NoSpaceBetweenEmptyInterfaceBraceBrackets", 19 /* OpenBraceToken */, 20 /* CloseBraceToken */, [isNonJsxSameLineTokenContext, isObjectTypeContext], 16 /* DeleteSpace */),
+      // generics and type assertions
+      rule("NoSpaceBeforeOpenAngularBracket", typeNames, 30 /* LessThanToken */, [isNonJsxSameLineTokenContext, isTypeArgumentOrParameterOrAssertionContext], 16 /* DeleteSpace */),
+      rule("NoSpaceBetweenCloseParenAndAngularBracket", 22 /* CloseParenToken */, 30 /* LessThanToken */, [isNonJsxSameLineTokenContext, isTypeArgumentOrParameterOrAssertionContext], 16 /* DeleteSpace */),
+      rule("NoSpaceAfterOpenAngularBracket", 30 /* LessThanToken */, anyToken, [isNonJsxSameLineTokenContext, isTypeArgumentOrParameterOrAssertionContext], 16 /* DeleteSpace */),
+      rule("NoSpaceBeforeCloseAngularBracket", anyToken, 32 /* GreaterThanToken */, [isNonJsxSameLineTokenContext, isTypeArgumentOrParameterOrAssertionContext], 16 /* DeleteSpace */),
+      rule("NoSpaceAfterCloseAngularBracket", 32 /* GreaterThanToken */, [21 /* OpenParenToken */, 23 /* OpenBracketToken */, 32 /* GreaterThanToken */, 28 /* CommaToken */], [
+        isNonJsxSameLineTokenContext,
+        isTypeArgumentOrParameterOrAssertionContext,
+        isNotFunctionDeclContext,
+        /*To prevent an interference with the SpaceBeforeOpenParenInFuncDecl rule*/
+        isNonTypeAssertionContext
+      ], 16 /* DeleteSpace */),
+      // decorators
+      rule("SpaceBeforeAt", [22 /* CloseParenToken */, 80 /* Identifier */], 60 /* AtToken */, [isNonJsxSameLineTokenContext], 4 /* InsertSpace */),
+      rule("NoSpaceAfterAt", 60 /* AtToken */, anyToken, [isNonJsxSameLineTokenContext], 16 /* DeleteSpace */),
+      // Insert space after @ in decorator
+      rule(
+        "SpaceAfterDecorator",
+        anyToken,
+        [
+          128 /* AbstractKeyword */,
+          80 /* Identifier */,
+          95 /* ExportKeyword */,
+          90 /* DefaultKeyword */,
+          86 /* ClassKeyword */,
+          126 /* StaticKeyword */,
+          125 /* PublicKeyword */,
+          123 /* PrivateKeyword */,
+          124 /* ProtectedKeyword */,
+          139 /* GetKeyword */,
+          153 /* SetKeyword */,
+          23 /* OpenBracketToken */,
+          42 /* AsteriskToken */
+        ],
+        [isEndOfDecoratorContextOnSameLine],
+        4 /* InsertSpace */
+      ),
+      rule("NoSpaceBeforeNonNullAssertionOperator", anyToken, 54 /* ExclamationToken */, [isNonJsxSameLineTokenContext, isNonNullAssertionContext], 16 /* DeleteSpace */),
+      rule("NoSpaceAfterNewKeywordOnConstructorSignature", 105 /* NewKeyword */, 21 /* OpenParenToken */, [isNonJsxSameLineTokenContext, isConstructorSignatureContext], 16 /* DeleteSpace */),
+      rule("SpaceLessThanAndNonJSXTypeAnnotation", 30 /* LessThanToken */, 30 /* LessThanToken */, [isNonJsxSameLineTokenContext], 4 /* InsertSpace */)
+    ];
+    const userConfigurableRules = [
+      // Treat constructor as an identifier in a function declaration, and remove spaces between constructor and following left parentheses
+      rule("SpaceAfterConstructor", 137 /* ConstructorKeyword */, 21 /* OpenParenToken */, [isOptionEnabled("insertSpaceAfterConstructor"), isNonJsxSameLineTokenContext], 4 /* InsertSpace */),
+      rule("NoSpaceAfterConstructor", 137 /* ConstructorKeyword */, 21 /* OpenParenToken */, [isOptionDisabledOrUndefined("insertSpaceAfterConstructor"), isNonJsxSameLineTokenContext], 16 /* DeleteSpace */),
+      rule("SpaceAfterComma", 28 /* CommaToken */, anyToken, [isOptionEnabled("insertSpaceAfterCommaDelimiter"), isNonJsxSameLineTokenContext, isNonJsxElementOrFragmentContext, isNextTokenNotCloseBracket, isNextTokenNotCloseParen], 4 /* InsertSpace */),
+      rule("NoSpaceAfterComma", 28 /* CommaToken */, anyToken, [isOptionDisabledOrUndefined("insertSpaceAfterCommaDelimiter"), isNonJsxSameLineTokenContext, isNonJsxElementOrFragmentContext], 16 /* DeleteSpace */),
+      // Insert space after function keyword for anonymous functions
+      rule("SpaceAfterAnonymousFunctionKeyword", [100 /* FunctionKeyword */, 42 /* AsteriskToken */], 21 /* OpenParenToken */, [isOptionEnabled("insertSpaceAfterFunctionKeywordForAnonymousFunctions"), isFunctionDeclContext], 4 /* InsertSpace */),
+      rule("NoSpaceAfterAnonymousFunctionKeyword", [100 /* FunctionKeyword */, 42 /* AsteriskToken */], 21 /* OpenParenToken */, [isOptionDisabledOrUndefined("insertSpaceAfterFunctionKeywordForAnonymousFunctions"), isFunctionDeclContext], 16 /* DeleteSpace */),
+      // Insert space after keywords in control flow statements
+      rule("SpaceAfterKeywordInControl", keywords, 21 /* OpenParenToken */, [isOptionEnabled("insertSpaceAfterKeywordsInControlFlowStatements"), isControlDeclContext], 4 /* InsertSpace */),
+      rule("NoSpaceAfterKeywordInControl", keywords, 21 /* OpenParenToken */, [isOptionDisabledOrUndefined("insertSpaceAfterKeywordsInControlFlowStatements"), isControlDeclContext], 16 /* DeleteSpace */),
+      // Insert space after opening and before closing nonempty parenthesis
+      rule("SpaceAfterOpenParen", 21 /* OpenParenToken */, anyToken, [isOptionEnabled("insertSpaceAfterOpeningAndBeforeClosingNonemptyParenthesis"), isNonJsxSameLineTokenContext], 4 /* InsertSpace */),
+      rule("SpaceBeforeCloseParen", anyToken, 22 /* CloseParenToken */, [isOptionEnabled("insertSpaceAfterOpeningAndBeforeClosingNonemptyParenthesis"), isNonJsxSameLineTokenContext], 4 /* InsertSpace */),
+      rule("SpaceBetweenOpenParens", 21 /* OpenParenToken */, 21 /* OpenParenToken */, [isOptionEnabled("insertSpaceAfterOpeningAndBeforeClosingNonemptyParenthesis"), isNonJsxSameLineTokenContext], 4 /* InsertSpace */),
+      rule("NoSpaceBetweenParens", 21 /* OpenParenToken */, 22 /* CloseParenToken */, [isNonJsxSameLineTokenContext], 16 /* DeleteSpace */),
+      rule("NoSpaceAfterOpenParen", 21 /* OpenParenToken */, anyToken, [isOptionDisabledOrUndefined("insertSpaceAfterOpeningAndBeforeClosingNonemptyParenthesis"), isNonJsxSameLineTokenContext], 16 /* DeleteSpace */),
+      rule("NoSpaceBeforeCloseParen", anyToken, 22 /* CloseParenToken */, [isOptionDisabledOrUndefined("insertSpaceAfterOpeningAndBeforeClosingNonemptyParenthesis"), isNonJsxSameLineTokenContext], 16 /* DeleteSpace */),
+      // Insert space after opening and before closing nonempty brackets
+      rule("SpaceAfterOpenBracket", 23 /* OpenBracketToken */, anyToken, [isOptionEnabled("insertSpaceAfterOpeningAndBeforeClosingNonemptyBrackets"), isNonJsxSameLineTokenContext], 4 /* InsertSpace */),
+      rule("SpaceBeforeCloseBracket", anyToken, 24 /* CloseBracketToken */, [isOptionEnabled("insertSpaceAfterOpeningAndBeforeClosingNonemptyBrackets"), isNonJsxSameLineTokenContext], 4 /* InsertSpace */),
+      rule("NoSpaceBetweenBrackets", 23 /* OpenBracketToken */, 24 /* CloseBracketToken */, [isNonJsxSameLineTokenContext], 16 /* DeleteSpace */),
+      rule("NoSpaceAfterOpenBracket", 23 /* OpenBracketToken */, anyToken, [isOptionDisabledOrUndefined("insertSpaceAfterOpeningAndBeforeClosingNonemptyBrackets"), isNonJsxSameLineTokenContext], 16 /* DeleteSpace */),
+      rule("NoSpaceBeforeCloseBracket", anyToken, 24 /* CloseBracketToken */, [isOptionDisabledOrUndefined("insertSpaceAfterOpeningAndBeforeClosingNonemptyBrackets"), isNonJsxSameLineTokenContext], 16 /* DeleteSpace */),
+      // Insert a space after { and before } in single-line contexts, but remove space from empty object literals {}.
+      rule("SpaceAfterOpenBrace", 19 /* OpenBraceToken */, anyToken, [isOptionEnabledOrUndefined("insertSpaceAfterOpeningAndBeforeClosingNonemptyBraces"), isBraceWrappedContext], 4 /* InsertSpace */),
+      rule("SpaceBeforeCloseBrace", anyToken, 20 /* CloseBraceToken */, [isOptionEnabledOrUndefined("insertSpaceAfterOpeningAndBeforeClosingNonemptyBraces"), isBraceWrappedContext], 4 /* InsertSpace */),
+      rule("NoSpaceBetweenEmptyBraceBrackets", 19 /* OpenBraceToken */, 20 /* CloseBraceToken */, [isNonJsxSameLineTokenContext, isObjectContext], 16 /* DeleteSpace */),
+      rule("NoSpaceAfterOpenBrace", 19 /* OpenBraceToken */, anyToken, [isOptionDisabled("insertSpaceAfterOpeningAndBeforeClosingNonemptyBraces"), isNonJsxSameLineTokenContext], 16 /* DeleteSpace */),
+      rule("NoSpaceBeforeCloseBrace", anyToken, 20 /* CloseBraceToken */, [isOptionDisabled("insertSpaceAfterOpeningAndBeforeClosingNonemptyBraces"), isNonJsxSameLineTokenContext], 16 /* DeleteSpace */),
+      // Insert a space after opening and before closing empty brace brackets
+      rule("SpaceBetweenEmptyBraceBrackets", 19 /* OpenBraceToken */, 20 /* CloseBraceToken */, [isOptionEnabled("insertSpaceAfterOpeningAndBeforeClosingEmptyBraces")], 4 /* InsertSpace */),
+      rule("NoSpaceBetweenEmptyBraceBrackets", 19 /* OpenBraceToken */, 20 /* CloseBraceToken */, [isOptionDisabled("insertSpaceAfterOpeningAndBeforeClosingEmptyBraces"), isNonJsxSameLineTokenContext], 16 /* DeleteSpace */),
+      // Insert space after opening and before closing template string braces
+      rule("SpaceAfterTemplateHeadAndMiddle", [16 /* TemplateHead */, 17 /* TemplateMiddle */], anyToken, [isOptionEnabled("insertSpaceAfterOpeningAndBeforeClosingTemplateStringBraces"), isNonJsxTextContext], 4 /* InsertSpace */, 1 /* CanDeleteNewLines */),
+      rule("SpaceBeforeTemplateMiddleAndTail", anyToken, [17 /* TemplateMiddle */, 18 /* TemplateTail */], [isOptionEnabled("insertSpaceAfterOpeningAndBeforeClosingTemplateStringBraces"), isNonJsxSameLineTokenContext], 4 /* InsertSpace */),
+      rule("NoSpaceAfterTemplateHeadAndMiddle", [16 /* TemplateHead */, 17 /* TemplateMiddle */], anyToken, [isOptionDisabledOrUndefined("insertSpaceAfterOpeningAndBeforeClosingTemplateStringBraces"), isNonJsxTextContext], 16 /* DeleteSpace */, 1 /* CanDeleteNewLines */),
+      rule("NoSpaceBeforeTemplateMiddleAndTail", anyToken, [17 /* TemplateMiddle */, 18 /* TemplateTail */], [isOptionDisabledOrUndefined("insertSpaceAfterOpeningAndBeforeClosingTemplateStringBraces"), isNonJsxSameLineTokenContext], 16 /* DeleteSpace */),
+      // No space after { and before } in JSX expression
+      rule("SpaceAfterOpenBraceInJsxExpression", 19 /* OpenBraceToken */, anyToken, [isOptionEnabled("insertSpaceAfterOpeningAndBeforeClosingJsxExpressionBraces"), isNonJsxSameLineTokenContext, isJsxExpressionContext], 4 /* InsertSpace */),
+      rule("SpaceBeforeCloseBraceInJsxExpression", anyToken, 20 /* CloseBraceToken */, [isOptionEnabled("insertSpaceAfterOpeningAndBeforeClosingJsxExpressionBraces"), isNonJsxSameLineTokenContext, isJsxExpressionContext], 4 /* InsertSpace */),
+      rule("NoSpaceAfterOpenBraceInJsxExpression", 19 /* OpenBraceToken */, anyToken, [isOptionDisabledOrUndefined("insertSpaceAfterOpeningAndBeforeClosingJsxExpressionBraces"), isNonJsxSameLineTokenContext, isJsxExpressionContext], 16 /* DeleteSpace */),
+      rule("NoSpaceBeforeCloseBraceInJsxExpression", anyToken, 20 /* CloseBraceToken */, [isOptionDisabledOrUndefined("insertSpaceAfterOpeningAndBeforeClosingJsxExpressionBraces"), isNonJsxSameLineTokenContext, isJsxExpressionContext], 16 /* DeleteSpace */),
+      // Insert space after semicolon in for statement
+      rule("SpaceAfterSemicolonInFor", 27 /* SemicolonToken */, anyToken, [isOptionEnabled("insertSpaceAfterSemicolonInForStatements"), isNonJsxSameLineTokenContext, isForContext], 4 /* InsertSpace */),
+      rule("NoSpaceAfterSemicolonInFor", 27 /* SemicolonToken */, anyToken, [isOptionDisabledOrUndefined("insertSpaceAfterSemicolonInForStatements"), isNonJsxSameLineTokenContext, isForContext], 16 /* DeleteSpace */),
+      // Insert space before and after binary operators
+      rule("SpaceBeforeBinaryOperator", anyToken, binaryOperators, [isOptionEnabled("insertSpaceBeforeAndAfterBinaryOperators"), isNonJsxSameLineTokenContext, isBinaryOpContext], 4 /* InsertSpace */),
+      rule("SpaceAfterBinaryOperator", binaryOperators, anyToken, [isOptionEnabled("insertSpaceBeforeAndAfterBinaryOperators"), isNonJsxSameLineTokenContext, isBinaryOpContext], 4 /* InsertSpace */),
+      rule("NoSpaceBeforeBinaryOperator", anyToken, binaryOperators, [isOptionDisabledOrUndefined("insertSpaceBeforeAndAfterBinaryOperators"), isNonJsxSameLineTokenContext, isBinaryOpContext], 16 /* DeleteSpace */),
+      rule("NoSpaceAfterBinaryOperator", binaryOperators, anyToken, [isOptionDisabledOrUndefined("insertSpaceBeforeAndAfterBinaryOperators"), isNonJsxSameLineTokenContext, isBinaryOpContext], 16 /* DeleteSpace */),
+      rule("SpaceBeforeOpenParenInFuncDecl", anyToken, 21 /* OpenParenToken */, [isOptionEnabled("insertSpaceBeforeFunctionParenthesis"), isNonJsxSameLineTokenContext, isFunctionDeclContext], 4 /* InsertSpace */),
+      rule("NoSpaceBeforeOpenParenInFuncDecl", anyToken, 21 /* OpenParenToken */, [isOptionDisabledOrUndefined("insertSpaceBeforeFunctionParenthesis"), isNonJsxSameLineTokenContext, isFunctionDeclContext], 16 /* DeleteSpace */),
+      // Open Brace braces after control block
+      rule("NewLineBeforeOpenBraceInControl", controlOpenBraceLeftTokenRange, 19 /* OpenBraceToken */, [isOptionEnabled("placeOpenBraceOnNewLineForControlBlocks"), isControlDeclContext, isBeforeMultilineBlockContext], 8 /* InsertNewLine */, 1 /* CanDeleteNewLines */),
+      // Open Brace braces after function
+      // TypeScript: Function can have return types, which can be made of tons of different token kinds
+      rule("NewLineBeforeOpenBraceInFunction", functionOpenBraceLeftTokenRange, 19 /* OpenBraceToken */, [isOptionEnabled("placeOpenBraceOnNewLineForFunctions"), isFunctionDeclContext, isBeforeMultilineBlockContext], 8 /* InsertNewLine */, 1 /* CanDeleteNewLines */),
+      // Open Brace braces after TypeScript module/class/interface
+      rule("NewLineBeforeOpenBraceInTypeScriptDeclWithBlock", typeScriptOpenBraceLeftTokenRange, 19 /* OpenBraceToken */, [isOptionEnabled("placeOpenBraceOnNewLineForFunctions"), isTypeScriptDeclWithBlockContext, isBeforeMultilineBlockContext], 8 /* InsertNewLine */, 1 /* CanDeleteNewLines */),
+      rule("SpaceAfterTypeAssertion", 32 /* GreaterThanToken */, anyToken, [isOptionEnabled("insertSpaceAfterTypeAssertion"), isNonJsxSameLineTokenContext, isTypeAssertionContext], 4 /* InsertSpace */),
+      rule("NoSpaceAfterTypeAssertion", 32 /* GreaterThanToken */, anyToken, [isOptionDisabledOrUndefined("insertSpaceAfterTypeAssertion"), isNonJsxSameLineTokenContext, isTypeAssertionContext], 16 /* DeleteSpace */),
+      rule("SpaceBeforeTypeAnnotation", anyToken, [58 /* QuestionToken */, 59 /* ColonToken */], [isOptionEnabled("insertSpaceBeforeTypeAnnotation"), isNonJsxSameLineTokenContext, isTypeAnnotationContext], 4 /* InsertSpace */),
+      rule("NoSpaceBeforeTypeAnnotation", anyToken, [58 /* QuestionToken */, 59 /* ColonToken */], [isOptionDisabledOrUndefined("insertSpaceBeforeTypeAnnotation"), isNonJsxSameLineTokenContext, isTypeAnnotationContext], 16 /* DeleteSpace */),
+      rule("NoOptionalSemicolon", 27 /* SemicolonToken */, anyTokenIncludingEOF, [optionEquals("semicolons", "remove" /* Remove */), isSemicolonDeletionContext], 32 /* DeleteToken */),
+      rule("OptionalSemicolon", anyToken, anyTokenIncludingEOF, [optionEquals("semicolons", "insert" /* Insert */), isSemicolonInsertionContext], 64 /* InsertTrailingSemicolon */)
+    ];
+    const lowPriorityCommonRules = [
+      // Space after keyword but not before ; or : or ?
+      rule("NoSpaceBeforeSemicolon", anyToken, 27 /* SemicolonToken */, [isNonJsxSameLineTokenContext], 16 /* DeleteSpace */),
+      rule("SpaceBeforeOpenBraceInControl", controlOpenBraceLeftTokenRange, 19 /* OpenBraceToken */, [isOptionDisabledOrUndefinedOrTokensOnSameLine("placeOpenBraceOnNewLineForControlBlocks"), isControlDeclContext, isNotFormatOnEnter, isSameLineTokenOrBeforeBlockContext], 4 /* InsertSpace */, 1 /* CanDeleteNewLines */),
+      rule("SpaceBeforeOpenBraceInFunction", functionOpenBraceLeftTokenRange, 19 /* OpenBraceToken */, [isOptionDisabledOrUndefinedOrTokensOnSameLine("placeOpenBraceOnNewLineForFunctions"), isFunctionDeclContext, isBeforeBlockContext, isNotFormatOnEnter, isSameLineTokenOrBeforeBlockContext], 4 /* InsertSpace */, 1 /* CanDeleteNewLines */),
+      rule("SpaceBeforeOpenBraceInTypeScriptDeclWithBlock", typeScriptOpenBraceLeftTokenRange, 19 /* OpenBraceToken */, [isOptionDisabledOrUndefinedOrTokensOnSameLine("placeOpenBraceOnNewLineForFunctions"), isTypeScriptDeclWithBlockContext, isNotFormatOnEnter, isSameLineTokenOrBeforeBlockContext], 4 /* InsertSpace */, 1 /* CanDeleteNewLines */),
+      rule("NoSpaceBeforeComma", anyToken, 28 /* CommaToken */, [isNonJsxSameLineTokenContext], 16 /* DeleteSpace */),
+      // No space before and after indexer `x[]`
+      rule("NoSpaceBeforeOpenBracket", anyTokenExcept(134 /* AsyncKeyword */, 84 /* CaseKeyword */), 23 /* OpenBracketToken */, [isNonJsxSameLineTokenContext], 16 /* DeleteSpace */),
+      rule("NoSpaceAfterCloseBracket", 24 /* CloseBracketToken */, anyToken, [isNonJsxSameLineTokenContext, isNotBeforeBlockInFunctionDeclarationContext], 16 /* DeleteSpace */),
+      rule("SpaceAfterSemicolon", 27 /* SemicolonToken */, anyToken, [isNonJsxSameLineTokenContext], 4 /* InsertSpace */),
+      // Remove extra space between for and await
+      rule("SpaceBetweenForAndAwaitKeyword", 99 /* ForKeyword */, 135 /* AwaitKeyword */, [isNonJsxSameLineTokenContext], 4 /* InsertSpace */),
+      // Add a space between statements. All keywords except (do,else,case) has open/close parens after them.
+      // So, we have a rule to add a space for [),Any], [do,Any], [else,Any], and [case,Any]
+      rule(
+        "SpaceBetweenStatements",
+        [22 /* CloseParenToken */, 92 /* DoKeyword */, 93 /* ElseKeyword */, 84 /* CaseKeyword */],
+        anyToken,
+        [isNonJsxSameLineTokenContext, isNonJsxElementOrFragmentContext, isNotForContext],
+        4 /* InsertSpace */
+      ),
+      // This low-pri rule takes care of "try {", "catch {" and "finally {" in case the rule SpaceBeforeOpenBraceInControl didn't execute on FormatOnEnter.
+      rule("SpaceAfterTryCatchFinally", [113 /* TryKeyword */, 85 /* CatchKeyword */, 98 /* FinallyKeyword */], 19 /* OpenBraceToken */, [isNonJsxSameLineTokenContext], 4 /* InsertSpace */)
+    ];
+    return [
+      ...highPriorityCommonRules,
+      ...userConfigurableRules,
+      ...lowPriorityCommonRules
+    ];
+  }
+  function rule(debugName, left, right, context, action, flags = 0 /* None */) {
+    return { leftTokenRange: toTokenRange(left), rightTokenRange: toTokenRange(right), rule: { debugName, context, action, flags } };
+  }
+  function tokenRangeFrom(tokens) {
+    return { tokens, isSpecific: true };
+  }
+  function toTokenRange(arg) {
+    return typeof arg === "number" ? tokenRangeFrom([arg]) : isArray(arg) ? tokenRangeFrom(arg) : arg;
+  }
+  function tokenRangeFromRange(from, to, except = []) {
+    const tokens = [];
+    for (let token = from; token <= to; token++) {
+      if (!contains(except, token)) {
+        tokens.push(token);
       }
-      return text;
-    }
-    function printTypeInSingleLine(type) {
-      const flags = 70221824 /* IgnoreErrors */ | 1048576 /* AllowUniqueESSymbolType */ | 16384 /* UseAliasDefinedOutsideCurrentScope */;
-      const printer = createPrinterWithRemoveComments();
-      return usingSingleLineStringWriter((writer) => {
-        const typeNode = checker.typeToTypeNode(
-          type,
-          /*enclosingDeclaration*/
-          void 0,
-          flags
-        );
-        Debug.assertIsDefined(typeNode, "should always get typenode");
-        printer.writeNode(
-          4 /* Unspecified */,
-          typeNode,
-          /*sourceFile*/
-          file,
-          writer
-        );
-      });
     }
-    function isUndefined(name) {
-      return name === "undefined";
+    return tokenRangeFrom(tokens);
+  }
+  function optionEquals(optionName, optionValue) {
+    return (context) => context.options && context.options[optionName] === optionValue;
+  }
+  function isOptionEnabled(optionName) {
+    return (context) => context.options && hasProperty(context.options, optionName) && !!context.options[optionName];
+  }
+  function isOptionDisabled(optionName) {
+    return (context) => context.options && hasProperty(context.options, optionName) && !context.options[optionName];
+  }
+  function isOptionDisabledOrUndefined(optionName) {
+    return (context) => !context.options || !hasProperty(context.options, optionName) || !context.options[optionName];
+  }
+  function isOptionDisabledOrUndefinedOrTokensOnSameLine(optionName) {
+    return (context) => !context.options || !hasProperty(context.options, optionName) || !context.options[optionName] || context.TokensAreOnSameLine();
+  }
+  function isOptionEnabledOrUndefined(optionName) {
+    return (context) => !context.options || !hasProperty(context.options, optionName) || !!context.options[optionName];
+  }
+  function isForContext(context) {
+    return context.contextNode.kind === 248 /* ForStatement */;
+  }
+  function isNotForContext(context) {
+    return !isForContext(context);
+  }
+  function isBinaryOpContext(context) {
+    switch (context.contextNode.kind) {
+      case 226 /* BinaryExpression */:
+        return context.contextNode.operatorToken.kind !== 28 /* CommaToken */;
+      case 227 /* ConditionalExpression */:
+      case 194 /* ConditionalType */:
+      case 234 /* AsExpression */:
+      case 281 /* ExportSpecifier */:
+      case 276 /* ImportSpecifier */:
+      case 182 /* TypePredicate */:
+      case 192 /* UnionType */:
+      case 193 /* IntersectionType */:
+      case 238 /* SatisfiesExpression */:
+        return true;
+      case 208 /* BindingElement */:
+      case 265 /* TypeAliasDeclaration */:
+      case 271 /* ImportEqualsDeclaration */:
+      case 277 /* ExportAssignment */:
+      case 260 /* VariableDeclaration */:
+      case 169 /* Parameter */:
+      case 306 /* EnumMember */:
+      case 172 /* PropertyDeclaration */:
+      case 171 /* PropertySignature */:
+        return context.currentTokenSpan.kind === 64 /* EqualsToken */ || context.nextTokenSpan.kind === 64 /* EqualsToken */;
+      case 249 /* ForInStatement */:
+      case 168 /* TypeParameter */:
+        return context.currentTokenSpan.kind === 103 /* InKeyword */ || context.nextTokenSpan.kind === 103 /* InKeyword */ || context.currentTokenSpan.kind === 64 /* EqualsToken */ || context.nextTokenSpan.kind === 64 /* EqualsToken */;
+      case 250 /* ForOfStatement */:
+        return context.currentTokenSpan.kind === 165 /* OfKeyword */ || context.nextTokenSpan.kind === 165 /* OfKeyword */;
     }
-    function isHintableDeclaration(node) {
-      if ((isParameterDeclaration(node) || isVariableDeclaration(node) && isVarConst(node)) && node.initializer) {
-        const initializer = skipParentheses(node.initializer);
-        return !(isHintableLiteral(initializer) || isNewExpression(initializer) || isObjectLiteralExpression(initializer) || isAssertionExpression(initializer));
-      }
+    return false;
+  }
+  function isNotBinaryOpContext(context) {
+    return !isBinaryOpContext(context);
+  }
+  function isNotTypeAnnotationContext(context) {
+    return !isTypeAnnotationContext(context);
+  }
+  function isTypeAnnotationContext(context) {
+    const contextKind = context.contextNode.kind;
+    return contextKind === 172 /* PropertyDeclaration */ || contextKind === 171 /* PropertySignature */ || contextKind === 169 /* Parameter */ || contextKind === 260 /* VariableDeclaration */ || isFunctionLikeKind(contextKind);
+  }
+  function isOptionalPropertyContext(context) {
+    return isPropertyDeclaration(context.contextNode) && context.contextNode.questionToken;
+  }
+  function isNonOptionalPropertyContext(context) {
+    return !isOptionalPropertyContext(context);
+  }
+  function isConditionalOperatorContext(context) {
+    return context.contextNode.kind === 227 /* ConditionalExpression */ || context.contextNode.kind === 194 /* ConditionalType */;
+  }
+  function isSameLineTokenOrBeforeBlockContext(context) {
+    return context.TokensAreOnSameLine() || isBeforeBlockContext(context);
+  }
+  function isBraceWrappedContext(context) {
+    return context.contextNode.kind === 206 /* ObjectBindingPattern */ || context.contextNode.kind === 200 /* MappedType */ || isSingleLineBlockContext(context);
+  }
+  function isBeforeMultilineBlockContext(context) {
+    return isBeforeBlockContext(context) && !(context.NextNodeAllOnSameLine() || context.NextNodeBlockIsOnOneLine());
+  }
+  function isMultilineBlockContext(context) {
+    return isBlockContext(context) && !(context.ContextNodeAllOnSameLine() || context.ContextNodeBlockIsOnOneLine());
+  }
+  function isSingleLineBlockContext(context) {
+    return isBlockContext(context) && (context.ContextNodeAllOnSameLine() || context.ContextNodeBlockIsOnOneLine());
+  }
+  function isBlockContext(context) {
+    return nodeIsBlockContext(context.contextNode);
+  }
+  function isBeforeBlockContext(context) {
+    return nodeIsBlockContext(context.nextTokenParent);
+  }
+  function nodeIsBlockContext(node) {
+    if (nodeIsTypeScriptDeclWithBlockContext(node)) {
       return true;
     }
-  }
-  var maxHintsLength, leadingParameterNameCommentRegexFactory;
-  var init_inlayHints = __esm({
-    "src/services/inlayHints.ts"() {
-      "use strict";
-      init_ts4();
-      maxHintsLength = 30;
-      leadingParameterNameCommentRegexFactory = (name) => {
-        return new RegExp(`^\\s?/\\*\\*?\\s?${name}\\s?\\*\\/\\s?$`);
-      };
+    switch (node.kind) {
+      case 241 /* Block */:
+      case 269 /* CaseBlock */:
+      case 210 /* ObjectLiteralExpression */:
+      case 268 /* ModuleBlock */:
+        return true;
     }
-  });
-
-  // src/services/_namespaces/ts.InlayHints.ts
-  var ts_InlayHints_exports = {};
-  __export(ts_InlayHints_exports, {
-    provideInlayHints: () => provideInlayHints
-  });
-  var init_ts_InlayHints = __esm({
-    "src/services/_namespaces/ts.InlayHints.ts"() {
-      "use strict";
-      init_inlayHints();
+    return false;
+  }
+  function isFunctionDeclContext(context) {
+    switch (context.contextNode.kind) {
+      case 262 /* FunctionDeclaration */:
+      case 174 /* MethodDeclaration */:
+      case 173 /* MethodSignature */:
+      case 177 /* GetAccessor */:
+      case 178 /* SetAccessor */:
+      case 179 /* CallSignature */:
+      case 218 /* FunctionExpression */:
+      case 176 /* Constructor */:
+      case 219 /* ArrowFunction */:
+      case 264 /* InterfaceDeclaration */:
+        return true;
     }
-  });
-
-  // src/services/jsDoc.ts
-  function getJsDocCommentsFromDeclarations(declarations, checker) {
-    const parts = [];
-    forEachUnique(declarations, (declaration) => {
-      for (const jsdoc of getCommentHavingNodes(declaration)) {
-        const inheritDoc = isJSDoc(jsdoc) && jsdoc.tags && find(jsdoc.tags, (t) => t.kind === 333 /* JSDocTag */ && (t.tagName.escapedText === "inheritDoc" || t.tagName.escapedText === "inheritdoc"));
-        if (jsdoc.comment === void 0 && !inheritDoc || isJSDoc(jsdoc) && declaration.kind !== 352 /* JSDocTypedefTag */ && declaration.kind !== 344 /* JSDocCallbackTag */ && jsdoc.tags && jsdoc.tags.some((t) => t.kind === 352 /* JSDocTypedefTag */ || t.kind === 344 /* JSDocCallbackTag */) && !jsdoc.tags.some((t) => t.kind === 347 /* JSDocParameterTag */ || t.kind === 348 /* JSDocReturnTag */)) {
-          continue;
-        }
-        let newparts = jsdoc.comment ? getDisplayPartsFromComment(jsdoc.comment, checker) : [];
-        if (inheritDoc && inheritDoc.comment) {
-          newparts = newparts.concat(getDisplayPartsFromComment(inheritDoc.comment, checker));
-        }
-        if (!contains(parts, newparts, isIdenticalListOfDisplayParts)) {
-          parts.push(newparts);
-        }
-      }
-    });
-    return flatten(intersperse(parts, [lineBreakPart()]));
+    return false;
   }
-  function isIdenticalListOfDisplayParts(parts1, parts2) {
-    return arraysEqual(parts1, parts2, (p1, p2) => p1.kind === p2.kind && p1.text === p2.text);
+  function isNotFunctionDeclContext(context) {
+    return !isFunctionDeclContext(context);
   }
-  function getCommentHavingNodes(declaration) {
-    switch (declaration.kind) {
-      case 347 /* JSDocParameterTag */:
-      case 354 /* JSDocPropertyTag */:
-        return [declaration];
-      case 344 /* JSDocCallbackTag */:
-      case 352 /* JSDocTypedefTag */:
-        return [declaration, declaration.parent];
-      default:
-        return getJSDocCommentsAndTags(declaration);
-    }
+  function isFunctionDeclarationOrFunctionExpressionContext(context) {
+    return context.contextNode.kind === 262 /* FunctionDeclaration */ || context.contextNode.kind === 218 /* FunctionExpression */;
   }
-  function getJsDocTagsFromDeclarations(declarations, checker) {
-    const infos = [];
-    forEachUnique(declarations, (declaration) => {
-      const tags = getJSDocTags(declaration);
-      if (tags.some((t) => t.kind === 352 /* JSDocTypedefTag */ || t.kind === 344 /* JSDocCallbackTag */) && !tags.some((t) => t.kind === 347 /* JSDocParameterTag */ || t.kind === 348 /* JSDocReturnTag */)) {
-        return;
-      }
-      for (const tag of tags) {
-        infos.push({ name: tag.tagName.text, text: getCommentDisplayParts(tag, checker) });
-      }
-    });
-    return infos;
+  function isTypeScriptDeclWithBlockContext(context) {
+    return nodeIsTypeScriptDeclWithBlockContext(context.contextNode);
   }
-  function getDisplayPartsFromComment(comment, checker) {
-    if (typeof comment === "string") {
-      return [textPart(comment)];
+  function nodeIsTypeScriptDeclWithBlockContext(node) {
+    switch (node.kind) {
+      case 263 /* ClassDeclaration */:
+      case 231 /* ClassExpression */:
+      case 264 /* InterfaceDeclaration */:
+      case 266 /* EnumDeclaration */:
+      case 187 /* TypeLiteral */:
+      case 267 /* ModuleDeclaration */:
+      case 278 /* ExportDeclaration */:
+      case 279 /* NamedExports */:
+      case 272 /* ImportDeclaration */:
+      case 275 /* NamedImports */:
+        return true;
     }
-    return flatMap(
-      comment,
-      (node) => node.kind === 327 /* JSDocText */ ? [textPart(node.text)] : buildLinkParts(node, checker)
-    );
+    return false;
   }
-  function getCommentDisplayParts(tag, checker) {
-    const { comment, kind } = tag;
-    const namePart = getTagNameDisplayPart(kind);
-    switch (kind) {
-      case 355 /* JSDocThrowsTag */:
-        const typeExpression = tag.typeExpression;
-        return typeExpression ? withNode(typeExpression) : comment === void 0 ? void 0 : getDisplayPartsFromComment(comment, checker);
-      case 335 /* JSDocImplementsTag */:
-        return withNode(tag.class);
-      case 334 /* JSDocAugmentsTag */:
-        return withNode(tag.class);
-      case 351 /* JSDocTemplateTag */:
-        const templateTag = tag;
-        const displayParts = [];
-        if (templateTag.constraint) {
-          displayParts.push(textPart(templateTag.constraint.getText()));
-        }
-        if (length(templateTag.typeParameters)) {
-          if (length(displayParts)) {
-            displayParts.push(spacePart());
-          }
-          const lastTypeParameter = templateTag.typeParameters[templateTag.typeParameters.length - 1];
-          forEach(templateTag.typeParameters, (tp) => {
-            displayParts.push(namePart(tp.getText()));
-            if (lastTypeParameter !== tp) {
-              displayParts.push(...[punctuationPart(28 /* CommaToken */), spacePart()]);
-            }
-          });
-        }
-        if (comment) {
-          displayParts.push(...[spacePart(), ...getDisplayPartsFromComment(comment, checker)]);
-        }
-        return displayParts;
-      case 350 /* JSDocTypeTag */:
-      case 356 /* JSDocSatisfiesTag */:
-        return withNode(tag.typeExpression);
-      case 352 /* JSDocTypedefTag */:
-      case 344 /* JSDocCallbackTag */:
-      case 354 /* JSDocPropertyTag */:
-      case 347 /* JSDocParameterTag */:
-      case 353 /* JSDocSeeTag */:
-        const { name } = tag;
-        return name ? withNode(name) : comment === void 0 ? void 0 : getDisplayPartsFromComment(comment, checker);
-      default:
-        return comment === void 0 ? void 0 : getDisplayPartsFromComment(comment, checker);
-    }
-    function withNode(node) {
-      return addComment(node.getText());
-    }
-    function addComment(s) {
-      if (comment) {
-        if (s.match(/^https?$/)) {
-          return [textPart(s), ...getDisplayPartsFromComment(comment, checker)];
-        } else {
-          return [namePart(s), spacePart(), ...getDisplayPartsFromComment(comment, checker)];
+  function isAfterCodeBlockContext(context) {
+    switch (context.currentTokenParent.kind) {
+      case 263 /* ClassDeclaration */:
+      case 267 /* ModuleDeclaration */:
+      case 266 /* EnumDeclaration */:
+      case 299 /* CatchClause */:
+      case 268 /* ModuleBlock */:
+      case 255 /* SwitchStatement */:
+        return true;
+      case 241 /* Block */: {
+        const blockParent = context.currentTokenParent.parent;
+        if (!blockParent || blockParent.kind !== 219 /* ArrowFunction */ && blockParent.kind !== 218 /* FunctionExpression */) {
+          return true;
         }
-      } else {
-        return [textPart(s)];
       }
     }
+    return false;
   }
-  function getTagNameDisplayPart(kind) {
-    switch (kind) {
-      case 347 /* JSDocParameterTag */:
-        return parameterNamePart;
-      case 354 /* JSDocPropertyTag */:
-        return propertyNamePart;
-      case 351 /* JSDocTemplateTag */:
-        return typeParameterNamePart;
-      case 352 /* JSDocTypedefTag */:
-      case 344 /* JSDocCallbackTag */:
-        return typeAliasNamePart;
+  function isControlDeclContext(context) {
+    switch (context.contextNode.kind) {
+      case 245 /* IfStatement */:
+      case 255 /* SwitchStatement */:
+      case 248 /* ForStatement */:
+      case 249 /* ForInStatement */:
+      case 250 /* ForOfStatement */:
+      case 247 /* WhileStatement */:
+      case 258 /* TryStatement */:
+      case 246 /* DoStatement */:
+      case 254 /* WithStatement */:
+      case 299 /* CatchClause */:
+        return true;
       default:
-        return textPart;
+        return false;
     }
   }
-  function getJSDocTagNameCompletions() {
-    return jsDocTagNameCompletionEntries || (jsDocTagNameCompletionEntries = map(jsDocTagNames, (tagName) => {
-      return {
-        name: tagName,
-        kind: "keyword" /* keyword */,
-        kindModifiers: "",
-        sortText: ts_Completions_exports.SortText.LocationPriority
-      };
-    }));
+  function isObjectContext(context) {
+    return context.contextNode.kind === 210 /* ObjectLiteralExpression */;
   }
-  function getJSDocTagCompletions() {
-    return jsDocTagCompletionEntries || (jsDocTagCompletionEntries = map(jsDocTagNames, (tagName) => {
-      return {
-        name: `@${tagName}`,
-        kind: "keyword" /* keyword */,
-        kindModifiers: "",
-        sortText: ts_Completions_exports.SortText.LocationPriority
-      };
-    }));
+  function isFunctionCallContext(context) {
+    return context.contextNode.kind === 213 /* CallExpression */;
   }
-  function getJSDocTagCompletionDetails(name) {
-    return {
-      name,
-      kind: "" /* unknown */,
-      // TODO: should have its own kind?
-      kindModifiers: "",
-      displayParts: [textPart(name)],
-      documentation: emptyArray,
-      tags: void 0,
-      codeActions: void 0
-    };
+  function isNewContext(context) {
+    return context.contextNode.kind === 214 /* NewExpression */;
   }
-  function getJSDocParameterNameCompletions(tag) {
-    if (!isIdentifier(tag.name)) {
-      return emptyArray;
-    }
-    const nameThusFar = tag.name.text;
-    const jsdoc = tag.parent;
-    const fn = jsdoc.parent;
-    if (!isFunctionLike(fn))
-      return [];
-    return mapDefined(fn.parameters, (param) => {
-      if (!isIdentifier(param.name))
-        return void 0;
-      const name = param.name.text;
-      if (jsdoc.tags.some((t) => t !== tag && isJSDocParameterTag(t) && isIdentifier(t.name) && t.name.escapedText === name) || nameThusFar !== void 0 && !startsWith(name, nameThusFar)) {
-        return void 0;
-      }
-      return { name, kind: "parameter" /* parameterElement */, kindModifiers: "", sortText: ts_Completions_exports.SortText.LocationPriority };
-    });
+  function isFunctionCallOrNewContext(context) {
+    return isFunctionCallContext(context) || isNewContext(context);
   }
-  function getJSDocParameterNameCompletionDetails(name) {
-    return {
-      name,
-      kind: "parameter" /* parameterElement */,
-      kindModifiers: "",
-      displayParts: [textPart(name)],
-      documentation: emptyArray,
-      tags: void 0,
-      codeActions: void 0
-    };
+  function isPreviousTokenNotComma(context) {
+    return context.currentTokenSpan.kind !== 28 /* CommaToken */;
   }
-  function getDocCommentTemplateAtPosition(newLine, sourceFile, position, options) {
-    const tokenAtPos = getTokenAtPosition(sourceFile, position);
-    const existingDocComment = findAncestor(tokenAtPos, isJSDoc);
-    if (existingDocComment && (existingDocComment.comment !== void 0 || length(existingDocComment.tags))) {
-      return void 0;
-    }
-    const tokenStart = tokenAtPos.getStart(sourceFile);
-    if (!existingDocComment && tokenStart < position) {
-      return void 0;
-    }
-    const commentOwnerInfo = getCommentOwnerInfo(tokenAtPos, options);
-    if (!commentOwnerInfo) {
-      return void 0;
+  function isNextTokenNotCloseBracket(context) {
+    return context.nextTokenSpan.kind !== 24 /* CloseBracketToken */;
+  }
+  function isNextTokenNotCloseParen(context) {
+    return context.nextTokenSpan.kind !== 22 /* CloseParenToken */;
+  }
+  function isArrowFunctionContext(context) {
+    return context.contextNode.kind === 219 /* ArrowFunction */;
+  }
+  function isImportTypeContext(context) {
+    return context.contextNode.kind === 205 /* ImportType */;
+  }
+  function isNonJsxSameLineTokenContext(context) {
+    return context.TokensAreOnSameLine() && context.contextNode.kind !== 12 /* JsxText */;
+  }
+  function isNonJsxTextContext(context) {
+    return context.contextNode.kind !== 12 /* JsxText */;
+  }
+  function isNonJsxElementOrFragmentContext(context) {
+    return context.contextNode.kind !== 284 /* JsxElement */ && context.contextNode.kind !== 288 /* JsxFragment */;
+  }
+  function isJsxExpressionContext(context) {
+    return context.contextNode.kind === 294 /* JsxExpression */ || context.contextNode.kind === 293 /* JsxSpreadAttribute */;
+  }
+  function isNextTokenParentJsxAttribute(context) {
+    return context.nextTokenParent.kind === 291 /* JsxAttribute */ || context.nextTokenParent.kind === 295 /* JsxNamespacedName */ && context.nextTokenParent.parent.kind === 291 /* JsxAttribute */;
+  }
+  function isJsxAttributeContext(context) {
+    return context.contextNode.kind === 291 /* JsxAttribute */;
+  }
+  function isNextTokenParentNotJsxNamespacedName(context) {
+    return context.nextTokenParent.kind !== 295 /* JsxNamespacedName */;
+  }
+  function isNextTokenParentJsxNamespacedName(context) {
+    return context.nextTokenParent.kind === 295 /* JsxNamespacedName */;
+  }
+  function isJsxSelfClosingElementContext(context) {
+    return context.contextNode.kind === 285 /* JsxSelfClosingElement */;
+  }
+  function isNotBeforeBlockInFunctionDeclarationContext(context) {
+    return !isFunctionDeclContext(context) && !isBeforeBlockContext(context);
+  }
+  function isEndOfDecoratorContextOnSameLine(context) {
+    return context.TokensAreOnSameLine() && hasDecorators(context.contextNode) && nodeIsInDecoratorContext(context.currentTokenParent) && !nodeIsInDecoratorContext(context.nextTokenParent);
+  }
+  function nodeIsInDecoratorContext(node) {
+    while (node && isExpression(node)) {
+      node = node.parent;
     }
-    const { commentOwner, parameters, hasReturn: hasReturn2 } = commentOwnerInfo;
-    const commentOwnerJsDoc = hasJSDocNodes(commentOwner) && commentOwner.jsDoc ? commentOwner.jsDoc : void 0;
-    const lastJsDoc = lastOrUndefined(commentOwnerJsDoc);
-    if (commentOwner.getStart(sourceFile) < position || lastJsDoc && existingDocComment && lastJsDoc !== existingDocComment) {
-      return void 0;
+    return node && node.kind === 170 /* Decorator */;
+  }
+  function isStartOfVariableDeclarationList(context) {
+    return context.currentTokenParent.kind === 261 /* VariableDeclarationList */ && context.currentTokenParent.getStart(context.sourceFile) === context.currentTokenSpan.pos;
+  }
+  function isNotFormatOnEnter(context) {
+    return context.formattingRequestKind !== 2 /* FormatOnEnter */;
+  }
+  function isModuleDeclContext(context) {
+    return context.contextNode.kind === 267 /* ModuleDeclaration */;
+  }
+  function isObjectTypeContext(context) {
+    return context.contextNode.kind === 187 /* TypeLiteral */;
+  }
+  function isConstructorSignatureContext(context) {
+    return context.contextNode.kind === 180 /* ConstructSignature */;
+  }
+  function isTypeArgumentOrParameterOrAssertion(token, parent2) {
+    if (token.kind !== 30 /* LessThanToken */ && token.kind !== 32 /* GreaterThanToken */) {
+      return false;
     }
-    const indentationStr = getIndentationStringAtPosition(sourceFile, position);
-    const isJavaScriptFile = hasJSFileExtension(sourceFile.fileName);
-    const tags = (parameters ? parameterDocComments(parameters || [], isJavaScriptFile, indentationStr, newLine) : "") + (hasReturn2 ? returnsDocComment(indentationStr, newLine) : "");
-    const openComment = "/**";
-    const closeComment = " */";
-    const hasTag = (commentOwnerJsDoc || []).some((jsDoc) => !!jsDoc.tags);
-    if (tags && !hasTag) {
-      const preamble = openComment + newLine + indentationStr + " * ";
-      const endLine = tokenStart === position ? newLine + indentationStr : "";
-      const result = preamble + newLine + tags + indentationStr + closeComment + endLine;
-      return { newText: result, caretOffset: preamble.length };
+    switch (parent2.kind) {
+      case 183 /* TypeReference */:
+      case 216 /* TypeAssertionExpression */:
+      case 265 /* TypeAliasDeclaration */:
+      case 263 /* ClassDeclaration */:
+      case 231 /* ClassExpression */:
+      case 264 /* InterfaceDeclaration */:
+      case 262 /* FunctionDeclaration */:
+      case 218 /* FunctionExpression */:
+      case 219 /* ArrowFunction */:
+      case 174 /* MethodDeclaration */:
+      case 173 /* MethodSignature */:
+      case 179 /* CallSignature */:
+      case 180 /* ConstructSignature */:
+      case 213 /* CallExpression */:
+      case 214 /* NewExpression */:
+      case 233 /* ExpressionWithTypeArguments */:
+        return true;
+      default:
+        return false;
     }
-    return { newText: openComment + closeComment, caretOffset: 3 };
   }
-  function getIndentationStringAtPosition(sourceFile, position) {
-    const { text } = sourceFile;
-    const lineStart = getLineStartPositionForPosition(position, sourceFile);
-    let pos = lineStart;
-    for (; pos <= position && isWhiteSpaceSingleLine(text.charCodeAt(pos)); pos++)
-      ;
-    return text.slice(lineStart, pos);
+  function isTypeArgumentOrParameterOrAssertionContext(context) {
+    return isTypeArgumentOrParameterOrAssertion(context.currentTokenSpan, context.currentTokenParent) || isTypeArgumentOrParameterOrAssertion(context.nextTokenSpan, context.nextTokenParent);
   }
-  function parameterDocComments(parameters, isJavaScriptFile, indentationStr, newLine) {
-    return parameters.map(({ name, dotDotDotToken }, i) => {
-      const paramName = name.kind === 80 /* Identifier */ ? name.text : "param" + i;
-      const type = isJavaScriptFile ? dotDotDotToken ? "{...any} " : "{any} " : "";
-      return `${indentationStr} * @param ${type}${paramName}${newLine}`;
-    }).join("");
+  function isTypeAssertionContext(context) {
+    return context.contextNode.kind === 216 /* TypeAssertionExpression */;
   }
-  function returnsDocComment(indentationStr, newLine) {
-    return `${indentationStr} * @returns${newLine}`;
+  function isNonTypeAssertionContext(context) {
+    return !isTypeAssertionContext(context);
   }
-  function getCommentOwnerInfo(tokenAtPos, options) {
-    return forEachAncestor(tokenAtPos, (n) => getCommentOwnerInfoWorker(n, options));
+  function isVoidOpContext(context) {
+    return context.currentTokenSpan.kind === 116 /* VoidKeyword */ && context.currentTokenParent.kind === 222 /* VoidExpression */;
   }
-  function getCommentOwnerInfoWorker(commentOwner, options) {
-    switch (commentOwner.kind) {
-      case 261 /* FunctionDeclaration */:
-      case 217 /* FunctionExpression */:
-      case 173 /* MethodDeclaration */:
-      case 175 /* Constructor */:
-      case 172 /* MethodSignature */:
-      case 218 /* ArrowFunction */:
-        const host = commentOwner;
-        return { commentOwner, parameters: host.parameters, hasReturn: hasReturn(host, options) };
-      case 302 /* PropertyAssignment */:
-        return getCommentOwnerInfoWorker(commentOwner.initializer, options);
-      case 262 /* ClassDeclaration */:
-      case 263 /* InterfaceDeclaration */:
-      case 265 /* EnumDeclaration */:
-      case 305 /* EnumMember */:
-      case 264 /* TypeAliasDeclaration */:
-        return { commentOwner };
-      case 170 /* PropertySignature */: {
-        const host2 = commentOwner;
-        return host2.type && isFunctionTypeNode(host2.type) ? { commentOwner, parameters: host2.type.parameters, hasReturn: hasReturn(host2.type, options) } : { commentOwner };
-      }
-      case 242 /* VariableStatement */: {
-        const varStatement = commentOwner;
-        const varDeclarations = varStatement.declarationList.declarations;
-        const host2 = varDeclarations.length === 1 && varDeclarations[0].initializer ? getRightHandSideOfAssignment(varDeclarations[0].initializer) : void 0;
-        return host2 ? { commentOwner, parameters: host2.parameters, hasReturn: hasReturn(host2, options) } : { commentOwner };
-      }
-      case 311 /* SourceFile */:
-        return "quit";
-      case 266 /* ModuleDeclaration */:
-        return commentOwner.parent.kind === 266 /* ModuleDeclaration */ ? void 0 : { commentOwner };
-      case 243 /* ExpressionStatement */:
-        return getCommentOwnerInfoWorker(commentOwner.expression, options);
-      case 225 /* BinaryExpression */: {
-        const be = commentOwner;
-        if (getAssignmentDeclarationKind(be) === 0 /* None */) {
-          return "quit";
-        }
-        return isFunctionLike(be.right) ? { commentOwner, parameters: be.right.parameters, hasReturn: hasReturn(be.right, options) } : { commentOwner };
-      }
-      case 171 /* PropertyDeclaration */:
-        const init = commentOwner.initializer;
-        if (init && (isFunctionExpression(init) || isArrowFunction(init))) {
-          return { commentOwner, parameters: init.parameters, hasReturn: hasReturn(init, options) };
-        }
-    }
+  function isYieldOrYieldStarWithOperand(context) {
+    return context.contextNode.kind === 229 /* YieldExpression */ && context.contextNode.expression !== void 0;
   }
-  function hasReturn(node, options) {
-    return !!(options == null ? void 0 : options.generateReturnInDocTemplate) && (isFunctionTypeNode(node) || isArrowFunction(node) && isExpression(node.body) || isFunctionLikeDeclaration(node) && node.body && isBlock(node.body) && !!forEachReturnStatement(node.body, (n) => n));
+  function isNonNullAssertionContext(context) {
+    return context.contextNode.kind === 235 /* NonNullExpression */;
   }
-  function getRightHandSideOfAssignment(rightHandSide) {
-    while (rightHandSide.kind === 216 /* ParenthesizedExpression */) {
-      rightHandSide = rightHandSide.expression;
-    }
-    switch (rightHandSide.kind) {
-      case 217 /* FunctionExpression */:
-      case 218 /* ArrowFunction */:
-        return rightHandSide;
-      case 230 /* ClassExpression */:
-        return find(rightHandSide.members, isConstructorDeclaration);
+  function isNotStatementConditionContext(context) {
+    return !isStatementConditionContext(context);
+  }
+  function isStatementConditionContext(context) {
+    switch (context.contextNode.kind) {
+      case 245 /* IfStatement */:
+      case 248 /* ForStatement */:
+      case 249 /* ForInStatement */:
+      case 250 /* ForOfStatement */:
+      case 246 /* DoStatement */:
+      case 247 /* WhileStatement */:
+        return true;
+      default:
+        return false;
     }
   }
-  var jsDocTagNames, jsDocTagNameCompletionEntries, jsDocTagCompletionEntries, getJSDocTagNameCompletionDetails;
-  var init_jsDoc = __esm({
-    "src/services/jsDoc.ts"() {
-      "use strict";
-      init_ts4();
-      jsDocTagNames = [
-        "abstract",
-        "access",
-        "alias",
-        "argument",
-        "async",
-        "augments",
-        "author",
-        "borrows",
-        "callback",
-        "class",
-        "classdesc",
-        "constant",
-        "constructor",
-        "constructs",
-        "copyright",
-        "default",
-        "deprecated",
-        "description",
-        "emits",
-        "enum",
-        "event",
-        "example",
-        "exports",
-        "extends",
-        "external",
-        "field",
-        "file",
-        "fileoverview",
-        "fires",
-        "function",
-        "generator",
-        "global",
-        "hideconstructor",
-        "host",
-        "ignore",
-        "implements",
-        "inheritdoc",
-        "inner",
-        "instance",
-        "interface",
-        "kind",
-        "lends",
-        "license",
-        "link",
-        "linkcode",
-        "linkplain",
-        "listens",
-        "member",
-        "memberof",
-        "method",
-        "mixes",
-        "module",
-        "name",
-        "namespace",
-        "overload",
-        "override",
-        "package",
-        "param",
-        "private",
-        "prop",
-        "property",
-        "protected",
-        "public",
-        "readonly",
-        "requires",
-        "returns",
-        "satisfies",
-        "see",
-        "since",
-        "static",
-        "summary",
-        "template",
-        "this",
-        "throws",
-        "todo",
-        "tutorial",
-        "type",
-        "typedef",
-        "var",
-        "variation",
-        "version",
-        "virtual",
-        "yields"
-      ];
-      getJSDocTagNameCompletionDetails = getJSDocTagCompletionDetails;
+  function isSemicolonDeletionContext(context) {
+    let nextTokenKind = context.nextTokenSpan.kind;
+    let nextTokenStart = context.nextTokenSpan.pos;
+    if (isTrivia(nextTokenKind)) {
+      const nextRealToken = context.nextTokenParent === context.currentTokenParent ? findNextToken(
+        context.currentTokenParent,
+        findAncestor(context.currentTokenParent, (a) => !a.parent),
+        context.sourceFile
+      ) : context.nextTokenParent.getFirstToken(context.sourceFile);
+      if (!nextRealToken) {
+        return true;
+      }
+      nextTokenKind = nextRealToken.kind;
+      nextTokenStart = nextRealToken.getStart(context.sourceFile);
     }
-  });
-
-  // src/services/_namespaces/ts.JsDoc.ts
-  var ts_JsDoc_exports = {};
-  __export(ts_JsDoc_exports, {
-    getDocCommentTemplateAtPosition: () => getDocCommentTemplateAtPosition,
-    getJSDocParameterNameCompletionDetails: () => getJSDocParameterNameCompletionDetails,
-    getJSDocParameterNameCompletions: () => getJSDocParameterNameCompletions,
-    getJSDocTagCompletionDetails: () => getJSDocTagCompletionDetails,
-    getJSDocTagCompletions: () => getJSDocTagCompletions,
-    getJSDocTagNameCompletionDetails: () => getJSDocTagNameCompletionDetails,
-    getJSDocTagNameCompletions: () => getJSDocTagNameCompletions,
-    getJsDocCommentsFromDeclarations: () => getJsDocCommentsFromDeclarations,
-    getJsDocTagsFromDeclarations: () => getJsDocTagsFromDeclarations
-  });
-  var init_ts_JsDoc = __esm({
-    "src/services/_namespaces/ts.JsDoc.ts"() {
-      "use strict";
-      init_jsDoc();
+    const startLine = context.sourceFile.getLineAndCharacterOfPosition(context.currentTokenSpan.pos).line;
+    const endLine = context.sourceFile.getLineAndCharacterOfPosition(nextTokenStart).line;
+    if (startLine === endLine) {
+      return nextTokenKind === 20 /* CloseBraceToken */ || nextTokenKind === 1 /* EndOfFileToken */;
     }
-  });
-
-  // src/services/organizeImports.ts
-  function organizeImports(sourceFile, formatContext, host, program, preferences, mode) {
-    const changeTracker = ts_textChanges_exports.ChangeTracker.fromContext({ host, formatContext, preferences });
-    const shouldSort = mode === "SortAndCombine" /* SortAndCombine */ || mode === "All" /* All */;
-    const shouldCombine = shouldSort;
-    const shouldRemove = mode === "RemoveUnused" /* RemoveUnused */ || mode === "All" /* All */;
-    const topLevelImportGroupDecls = groupByNewlineContiguous(sourceFile, sourceFile.statements.filter(isImportDeclaration));
-    const comparer = getOrganizeImportsComparerWithDetection(preferences, shouldSort ? () => detectSortingWorker(topLevelImportGroupDecls, preferences) === 2 /* CaseInsensitive */ : void 0);
-    const processImportsOfSameModuleSpecifier = (importGroup) => {
-      if (shouldRemove)
-        importGroup = removeUnusedImports(importGroup, sourceFile, program);
-      if (shouldCombine)
-        importGroup = coalesceImportsWorker(importGroup, comparer, sourceFile);
-      if (shouldSort)
-        importGroup = stableSort(importGroup, (s1, s2) => compareImportsOrRequireStatements(s1, s2, comparer));
-      return importGroup;
-    };
-    topLevelImportGroupDecls.forEach((importGroupDecl) => organizeImportsWorker(importGroupDecl, processImportsOfSameModuleSpecifier));
-    if (mode !== "RemoveUnused" /* RemoveUnused */) {
-      getTopLevelExportGroups(sourceFile).forEach((exportGroupDecl) => organizeImportsWorker(exportGroupDecl, (group2) => coalesceExportsWorker(group2, comparer)));
+    if (nextTokenKind === 240 /* SemicolonClassElement */ || nextTokenKind === 27 /* SemicolonToken */) {
+      return false;
     }
-    for (const ambientModule of sourceFile.statements.filter(isAmbientModule)) {
-      if (!ambientModule.body)
-        continue;
-      const ambientModuleImportGroupDecls = groupByNewlineContiguous(sourceFile, ambientModule.body.statements.filter(isImportDeclaration));
-      ambientModuleImportGroupDecls.forEach((importGroupDecl) => organizeImportsWorker(importGroupDecl, processImportsOfSameModuleSpecifier));
-      if (mode !== "RemoveUnused" /* RemoveUnused */) {
-        const ambientModuleExportDecls = ambientModule.body.statements.filter(isExportDeclaration);
-        organizeImportsWorker(ambientModuleExportDecls, (group2) => coalesceExportsWorker(group2, comparer));
-      }
+    if (context.contextNode.kind === 264 /* InterfaceDeclaration */ || context.contextNode.kind === 265 /* TypeAliasDeclaration */) {
+      return !isPropertySignature(context.currentTokenParent) || !!context.currentTokenParent.type || nextTokenKind !== 21 /* OpenParenToken */;
     }
-    return changeTracker.getChanges();
-    function organizeImportsWorker(oldImportDecls, coalesce) {
-      if (length(oldImportDecls) === 0) {
-        return;
-      }
-      suppressLeadingTrivia(oldImportDecls[0]);
-      const oldImportGroups = shouldCombine ? group(oldImportDecls, (importDecl) => getExternalModuleName2(importDecl.moduleSpecifier)) : [oldImportDecls];
-      const sortedImportGroups = shouldSort ? stableSort(oldImportGroups, (group1, group2) => compareModuleSpecifiersWorker(group1[0].moduleSpecifier, group2[0].moduleSpecifier, comparer)) : oldImportGroups;
-      const newImportDecls = flatMap(sortedImportGroups, (importGroup) => getExternalModuleName2(importGroup[0].moduleSpecifier) || importGroup[0].moduleSpecifier === void 0 ? coalesce(importGroup) : importGroup);
-      if (newImportDecls.length === 0) {
-        changeTracker.deleteNodes(
-          sourceFile,
-          oldImportDecls,
-          {
-            leadingTriviaOption: ts_textChanges_exports.LeadingTriviaOption.Exclude,
-            trailingTriviaOption: ts_textChanges_exports.TrailingTriviaOption.Include
-          },
-          /*hasTrailingComment*/
-          true
-        );
-      } else {
-        const replaceOptions = {
-          leadingTriviaOption: ts_textChanges_exports.LeadingTriviaOption.Exclude,
-          // Leave header comment in place
-          trailingTriviaOption: ts_textChanges_exports.TrailingTriviaOption.Include,
-          suffix: getNewLineOrDefaultFromHost(host, formatContext.options)
-        };
-        changeTracker.replaceNodeWithNodes(sourceFile, oldImportDecls[0], newImportDecls, replaceOptions);
-        const hasTrailingComment = changeTracker.nodeHasTrailingComment(sourceFile, oldImportDecls[0], replaceOptions);
-        changeTracker.deleteNodes(sourceFile, oldImportDecls.slice(1), {
-          trailingTriviaOption: ts_textChanges_exports.TrailingTriviaOption.Include
-        }, hasTrailingComment);
-      }
+    if (isPropertyDeclaration(context.currentTokenParent)) {
+      return !context.currentTokenParent.initializer;
     }
+    return context.currentTokenParent.kind !== 248 /* ForStatement */ && context.currentTokenParent.kind !== 242 /* EmptyStatement */ && context.currentTokenParent.kind !== 240 /* SemicolonClassElement */ && nextTokenKind !== 23 /* OpenBracketToken */ && nextTokenKind !== 21 /* OpenParenToken */ && nextTokenKind !== 40 /* PlusToken */ && nextTokenKind !== 41 /* MinusToken */ && nextTokenKind !== 44 /* SlashToken */ && nextTokenKind !== 14 /* RegularExpressionLiteral */ && nextTokenKind !== 28 /* CommaToken */ && nextTokenKind !== 228 /* TemplateExpression */ && nextTokenKind !== 16 /* TemplateHead */ && nextTokenKind !== 15 /* NoSubstitutionTemplateLiteral */ && nextTokenKind !== 25 /* DotToken */;
   }
-  function groupByNewlineContiguous(sourceFile, decls) {
-    const scanner2 = createScanner(
-      sourceFile.languageVersion,
-      /*skipTrivia*/
-      false,
-      sourceFile.languageVariant
-    );
-    const group2 = [];
-    let groupIndex = 0;
-    for (const decl of decls) {
-      if (group2[groupIndex] && isNewGroup(sourceFile, decl, scanner2)) {
-        groupIndex++;
-      }
-      if (!group2[groupIndex]) {
-        group2[groupIndex] = [];
-      }
-      group2[groupIndex].push(decl);
-    }
-    return group2;
+  function isSemicolonInsertionContext(context) {
+    return positionIsASICandidate(context.currentTokenSpan.end, context.currentTokenParent, context.sourceFile);
   }
-  function isNewGroup(sourceFile, decl, scanner2) {
-    const startPos = decl.getFullStart();
-    const endPos = decl.getStart();
-    scanner2.setText(sourceFile.text, startPos, endPos - startPos);
-    let numberOfNewLines = 0;
-    while (scanner2.getTokenStart() < endPos) {
-      const tokenKind = scanner2.scan();
-      if (tokenKind === 4 /* NewLineTrivia */) {
-        numberOfNewLines++;
-        if (numberOfNewLines >= 2) {
-          return true;
-        }
-      }
-    }
-    return false;
+  function isNotPropertyAccessOnIntegerLiteral(context) {
+    return !isPropertyAccessExpression(context.contextNode) || !isNumericLiteral(context.contextNode.expression) || context.contextNode.expression.getText().includes(".");
   }
-  function removeUnusedImports(oldImports, sourceFile, program) {
-    const typeChecker = program.getTypeChecker();
-    const compilerOptions = program.getCompilerOptions();
-    const jsxNamespace = typeChecker.getJsxNamespace(sourceFile);
-    const jsxFragmentFactory = typeChecker.getJsxFragmentFactory(sourceFile);
-    const jsxElementsPresent = !!(sourceFile.transformFlags & 2 /* ContainsJsx */);
-    const usedImports = [];
-    for (const importDecl of oldImports) {
-      const { importClause, moduleSpecifier } = importDecl;
-      if (!importClause) {
-        usedImports.push(importDecl);
-        continue;
-      }
-      let { name, namedBindings } = importClause;
-      if (name && !isDeclarationUsed(name)) {
-        name = void 0;
-      }
-      if (namedBindings) {
-        if (isNamespaceImport(namedBindings)) {
-          if (!isDeclarationUsed(namedBindings.name)) {
-            namedBindings = void 0;
-          }
-        } else {
-          const newElements = namedBindings.elements.filter((e) => isDeclarationUsed(e.name));
-          if (newElements.length < namedBindings.elements.length) {
-            namedBindings = newElements.length ? factory.updateNamedImports(namedBindings, newElements) : void 0;
-          }
-        }
-      }
-      if (name || namedBindings) {
-        usedImports.push(updateImportDeclarationAndClause(importDecl, name, namedBindings));
-      } else if (hasModuleDeclarationMatchingSpecifier(sourceFile, moduleSpecifier)) {
-        if (sourceFile.isDeclarationFile) {
-          usedImports.push(factory.createImportDeclaration(
-            importDecl.modifiers,
-            /*importClause*/
-            void 0,
-            moduleSpecifier,
-            /*assertClause*/
-            void 0
-          ));
-        } else {
-          usedImports.push(importDecl);
-        }
-      }
-    }
-    return usedImports;
-    function isDeclarationUsed(identifier) {
-      return jsxElementsPresent && (identifier.text === jsxNamespace || jsxFragmentFactory && identifier.text === jsxFragmentFactory) && jsxModeNeedsExplicitImport(compilerOptions.jsx) || ts_FindAllReferences_exports.Core.isSymbolReferencedInFile(identifier, typeChecker, sourceFile);
+  var init_rules = __esm({
+    "src/services/formatting/rules.ts"() {
+      "use strict";
+      init_ts4();
+      init_ts_formatting();
     }
+  });
+
+  // src/services/formatting/rulesMap.ts
+  function getFormatContext(options, host) {
+    return { options, getRules: getRulesMap(), host };
   }
-  function hasModuleDeclarationMatchingSpecifier(sourceFile, moduleSpecifier) {
-    const moduleSpecifierText = isStringLiteral(moduleSpecifier) && moduleSpecifier.text;
-    return isString(moduleSpecifierText) && some(sourceFile.moduleAugmentations, (moduleName) => isStringLiteral(moduleName) && moduleName.text === moduleSpecifierText);
-  }
-  function getExternalModuleName2(specifier) {
-    return specifier !== void 0 && isStringLiteralLike(specifier) ? specifier.text : void 0;
-  }
-  function coalesceImports(importGroup, ignoreCase, sourceFile) {
-    const comparer = getOrganizeImportsOrdinalStringComparer(ignoreCase);
-    return coalesceImportsWorker(importGroup, comparer, sourceFile);
+  function getRulesMap() {
+    if (rulesMapCache === void 0) {
+      rulesMapCache = createRulesMap(getAllRules());
+    }
+    return rulesMapCache;
   }
-  function coalesceImportsWorker(importGroup, comparer, sourceFile) {
-    if (importGroup.length === 0) {
-      return importGroup;
+  function getRuleActionExclusion(ruleAction) {
+    let mask2 = 0 /* None */;
+    if (ruleAction & 1 /* StopProcessingSpaceActions */) {
+      mask2 |= 28 /* ModifySpaceAction */;
     }
-    const { importWithoutClause, typeOnlyImports, regularImports } = getCategorizedImports(importGroup);
-    const coalescedImports = [];
-    if (importWithoutClause) {
-      coalescedImports.push(importWithoutClause);
+    if (ruleAction & 2 /* StopProcessingTokenActions */) {
+      mask2 |= 96 /* ModifyTokenAction */;
     }
-    for (const group2 of [regularImports, typeOnlyImports]) {
-      const isTypeOnly = group2 === typeOnlyImports;
-      const { defaultImports, namespaceImports, namedImports } = group2;
-      if (!isTypeOnly && defaultImports.length === 1 && namespaceImports.length === 1 && namedImports.length === 0) {
-        const defaultImport = defaultImports[0];
-        coalescedImports.push(
-          updateImportDeclarationAndClause(defaultImport, defaultImport.importClause.name, namespaceImports[0].importClause.namedBindings)
-        );
-        continue;
-      }
-      const sortedNamespaceImports = stableSort(namespaceImports, (i1, i2) => comparer(i1.importClause.namedBindings.name.text, i2.importClause.namedBindings.name.text));
-      for (const namespaceImport of sortedNamespaceImports) {
-        coalescedImports.push(
-          updateImportDeclarationAndClause(
-            namespaceImport,
-            /*name*/
-            void 0,
-            namespaceImport.importClause.namedBindings
-          )
-        );
-      }
-      const firstDefaultImport = firstOrUndefined(defaultImports);
-      const firstNamedImport = firstOrUndefined(namedImports);
-      const importDecl = firstDefaultImport ?? firstNamedImport;
-      if (!importDecl) {
-        continue;
-      }
-      let newDefaultImport;
-      const newImportSpecifiers = [];
-      if (defaultImports.length === 1) {
-        newDefaultImport = defaultImports[0].importClause.name;
-      } else {
-        for (const defaultImport of defaultImports) {
-          newImportSpecifiers.push(
-            factory.createImportSpecifier(
-              /*isTypeOnly*/
-              false,
-              factory.createIdentifier("default"),
-              defaultImport.importClause.name
-            )
-          );
-        }
-      }
-      newImportSpecifiers.push(...getNewImportSpecifiers(namedImports));
-      const sortedImportSpecifiers = factory.createNodeArray(
-        sortSpecifiers(newImportSpecifiers, comparer),
-        firstNamedImport == null ? void 0 : firstNamedImport.importClause.namedBindings.elements.hasTrailingComma
-      );
-      const newNamedImports = sortedImportSpecifiers.length === 0 ? newDefaultImport ? void 0 : factory.createNamedImports(emptyArray) : firstNamedImport ? factory.updateNamedImports(firstNamedImport.importClause.namedBindings, sortedImportSpecifiers) : factory.createNamedImports(sortedImportSpecifiers);
-      if (sourceFile && newNamedImports && (firstNamedImport == null ? void 0 : firstNamedImport.importClause.namedBindings) && !rangeIsOnSingleLine(firstNamedImport.importClause.namedBindings, sourceFile)) {
-        setEmitFlags(newNamedImports, 2 /* MultiLine */);
-      }
-      if (isTypeOnly && newDefaultImport && newNamedImports) {
-        coalescedImports.push(
-          updateImportDeclarationAndClause(
-            importDecl,
-            newDefaultImport,
-            /*namedBindings*/
-            void 0
-          )
-        );
-        coalescedImports.push(
-          updateImportDeclarationAndClause(
-            firstNamedImport ?? importDecl,
-            /*name*/
-            void 0,
-            newNamedImports
-          )
-        );
-      } else {
-        coalescedImports.push(
-          updateImportDeclarationAndClause(importDecl, newDefaultImport, newNamedImports)
-        );
-      }
+    if (ruleAction & 28 /* ModifySpaceAction */) {
+      mask2 |= 28 /* ModifySpaceAction */;
     }
-    return coalescedImports;
+    if (ruleAction & 96 /* ModifyTokenAction */) {
+      mask2 |= 96 /* ModifyTokenAction */;
+    }
+    return mask2;
   }
-  function getCategorizedImports(importGroup) {
-    let importWithoutClause;
-    const typeOnlyImports = { defaultImports: [], namespaceImports: [], namedImports: [] };
-    const regularImports = { defaultImports: [], namespaceImports: [], namedImports: [] };
-    for (const importDeclaration of importGroup) {
-      if (importDeclaration.importClause === void 0) {
-        importWithoutClause = importWithoutClause || importDeclaration;
-        continue;
-      }
-      const group2 = importDeclaration.importClause.isTypeOnly ? typeOnlyImports : regularImports;
-      const { name, namedBindings } = importDeclaration.importClause;
-      if (name) {
-        group2.defaultImports.push(importDeclaration);
-      }
-      if (namedBindings) {
-        if (isNamespaceImport(namedBindings)) {
-          group2.namespaceImports.push(importDeclaration);
-        } else {
-          group2.namedImports.push(importDeclaration);
+  function createRulesMap(rules) {
+    const map2 = buildMap(rules);
+    return (context) => {
+      const bucket = map2[getRuleBucketIndex(context.currentTokenSpan.kind, context.nextTokenSpan.kind)];
+      if (bucket) {
+        const rules2 = [];
+        let ruleActionMask = 0;
+        for (const rule2 of bucket) {
+          const acceptRuleActions = ~getRuleActionExclusion(ruleActionMask);
+          if (rule2.action & acceptRuleActions && every(rule2.context, (c) => c(context))) {
+            rules2.push(rule2);
+            ruleActionMask |= rule2.action;
+          }
+        }
+        if (rules2.length) {
+          return rules2;
         }
       }
-    }
-    return {
-      importWithoutClause,
-      typeOnlyImports,
-      regularImports
     };
   }
-  function coalesceExports(exportGroup, ignoreCase) {
-    const comparer = getOrganizeImportsOrdinalStringComparer(ignoreCase);
-    return coalesceExportsWorker(exportGroup, comparer);
+  function buildMap(rules) {
+    const map2 = new Array(mapRowLength * mapRowLength);
+    const rulesBucketConstructionStateList = new Array(map2.length);
+    for (const rule2 of rules) {
+      const specificRule = rule2.leftTokenRange.isSpecific && rule2.rightTokenRange.isSpecific;
+      for (const left of rule2.leftTokenRange.tokens) {
+        for (const right of rule2.rightTokenRange.tokens) {
+          const index = getRuleBucketIndex(left, right);
+          let rulesBucket = map2[index];
+          if (rulesBucket === void 0) {
+            rulesBucket = map2[index] = [];
+          }
+          addRule(rulesBucket, rule2.rule, specificRule, rulesBucketConstructionStateList, index);
+        }
+      }
+    }
+    return map2;
   }
-  function coalesceExportsWorker(exportGroup, comparer) {
-    if (exportGroup.length === 0) {
-      return exportGroup;
+  function getRuleBucketIndex(row, column) {
+    Debug.assert(row <= 165 /* LastKeyword */ && column <= 165 /* LastKeyword */, "Must compute formatting context from tokens");
+    return row * mapRowLength + column;
+  }
+  function addRule(rules, rule2, specificTokens, constructionState, rulesBucketIndex) {
+    const position = rule2.action & 3 /* StopAction */ ? specificTokens ? 0 /* StopRulesSpecific */ : RulesPosition.StopRulesAny : rule2.context !== anyContext ? specificTokens ? RulesPosition.ContextRulesSpecific : RulesPosition.ContextRulesAny : specificTokens ? RulesPosition.NoContextRulesSpecific : RulesPosition.NoContextRulesAny;
+    const state = constructionState[rulesBucketIndex] || 0;
+    rules.splice(getInsertionIndex(state, position), 0, rule2);
+    constructionState[rulesBucketIndex] = increaseInsertionIndex(state, position);
+  }
+  function getInsertionIndex(indexBitmap, maskPosition) {
+    let index = 0;
+    for (let pos = 0; pos <= maskPosition; pos += maskBitSize) {
+      index += indexBitmap & mask;
+      indexBitmap >>= maskBitSize;
     }
-    const { exportWithoutClause, namedExports, typeOnlyExports } = getCategorizedExports(exportGroup);
-    const coalescedExports = [];
-    if (exportWithoutClause) {
-      coalescedExports.push(exportWithoutClause);
+    return index;
+  }
+  function increaseInsertionIndex(indexBitmap, maskPosition) {
+    const value = (indexBitmap >> maskPosition & mask) + 1;
+    Debug.assert((value & mask) === value, "Adding more rules into the sub-bucket than allowed. Maximum allowed is 32 rules.");
+    return indexBitmap & ~(mask << maskPosition) | value << maskPosition;
+  }
+  var rulesMapCache, maskBitSize, mask, mapRowLength, RulesPosition;
+  var init_rulesMap = __esm({
+    "src/services/formatting/rulesMap.ts"() {
+      "use strict";
+      init_ts4();
+      init_ts_formatting();
+      maskBitSize = 5;
+      mask = 31;
+      mapRowLength = 165 /* LastToken */ + 1;
+      RulesPosition = ((RulesPosition2) => {
+        RulesPosition2[RulesPosition2["StopRulesSpecific"] = 0] = "StopRulesSpecific";
+        RulesPosition2[RulesPosition2["StopRulesAny"] = maskBitSize * 1] = "StopRulesAny";
+        RulesPosition2[RulesPosition2["ContextRulesSpecific"] = maskBitSize * 2] = "ContextRulesSpecific";
+        RulesPosition2[RulesPosition2["ContextRulesAny"] = maskBitSize * 3] = "ContextRulesAny";
+        RulesPosition2[RulesPosition2["NoContextRulesSpecific"] = maskBitSize * 4] = "NoContextRulesSpecific";
+        RulesPosition2[RulesPosition2["NoContextRulesAny"] = maskBitSize * 5] = "NoContextRulesAny";
+        return RulesPosition2;
+      })(RulesPosition || {});
     }
-    for (const exportGroup2 of [namedExports, typeOnlyExports]) {
-      if (exportGroup2.length === 0) {
-        continue;
-      }
-      const newExportSpecifiers = [];
-      newExportSpecifiers.push(...flatMap(exportGroup2, (i) => i.exportClause && isNamedExports(i.exportClause) ? i.exportClause.elements : emptyArray));
-      const sortedExportSpecifiers = sortSpecifiers(newExportSpecifiers, comparer);
-      const exportDecl = exportGroup2[0];
-      coalescedExports.push(
-        factory.updateExportDeclaration(
-          exportDecl,
-          exportDecl.modifiers,
-          exportDecl.isTypeOnly,
-          exportDecl.exportClause && (isNamedExports(exportDecl.exportClause) ? factory.updateNamedExports(exportDecl.exportClause, sortedExportSpecifiers) : factory.updateNamespaceExport(exportDecl.exportClause, exportDecl.exportClause.name)),
-          exportDecl.moduleSpecifier,
-          exportDecl.assertClause
-        )
-      );
+  });
+
+  // src/services/formatting/formatting.ts
+  function createTextRangeWithKind(pos, end, kind) {
+    const textRangeWithKind = { pos, end, kind };
+    if (Debug.isDebugging) {
+      Object.defineProperty(textRangeWithKind, "__debugKind", {
+        get: () => Debug.formatSyntaxKind(kind)
+      });
     }
-    return coalescedExports;
-    function getCategorizedExports(exportGroup2) {
-      let exportWithoutClause2;
-      const namedExports2 = [];
-      const typeOnlyExports2 = [];
-      for (const exportDeclaration of exportGroup2) {
-        if (exportDeclaration.exportClause === void 0) {
-          exportWithoutClause2 = exportWithoutClause2 || exportDeclaration;
-        } else if (exportDeclaration.isTypeOnly) {
-          typeOnlyExports2.push(exportDeclaration);
-        } else {
-          namedExports2.push(exportDeclaration);
-        }
-      }
-      return {
-        exportWithoutClause: exportWithoutClause2,
-        namedExports: namedExports2,
-        typeOnlyExports: typeOnlyExports2
-      };
+    return textRangeWithKind;
+  }
+  function formatOnEnter(position, sourceFile, formatContext) {
+    const line = sourceFile.getLineAndCharacterOfPosition(position).line;
+    if (line === 0) {
+      return [];
+    }
+    let endOfFormatSpan = getEndLinePosition(line, sourceFile);
+    while (isWhiteSpaceSingleLine(sourceFile.text.charCodeAt(endOfFormatSpan))) {
+      endOfFormatSpan--;
+    }
+    if (isLineBreak(sourceFile.text.charCodeAt(endOfFormatSpan))) {
+      endOfFormatSpan--;
     }
+    const span = {
+      // get start position for the previous line
+      pos: getStartPositionOfLine(line - 1, sourceFile),
+      // end value is exclusive so add 1 to the result
+      end: endOfFormatSpan + 1
+    };
+    return formatSpan(span, sourceFile, formatContext, 2 /* FormatOnEnter */);
   }
-  function updateImportDeclarationAndClause(importDeclaration, name, namedBindings) {
-    return factory.updateImportDeclaration(
-      importDeclaration,
-      importDeclaration.modifiers,
-      factory.updateImportClause(importDeclaration.importClause, importDeclaration.importClause.isTypeOnly, name, namedBindings),
+  function formatOnSemicolon(position, sourceFile, formatContext) {
+    const semicolon = findImmediatelyPrecedingTokenOfKind(position, 27 /* SemicolonToken */, sourceFile);
+    return formatNodeLines(findOutermostNodeWithinListLevel(semicolon), sourceFile, formatContext, 3 /* FormatOnSemicolon */);
+  }
+  function formatOnOpeningCurly(position, sourceFile, formatContext) {
+    const openingCurly = findImmediatelyPrecedingTokenOfKind(position, 19 /* OpenBraceToken */, sourceFile);
+    if (!openingCurly) {
+      return [];
+    }
+    const curlyBraceRange = openingCurly.parent;
+    const outermostNode = findOutermostNodeWithinListLevel(curlyBraceRange);
+    const textRange = {
+      pos: getLineStartPositionForPosition(outermostNode.getStart(sourceFile), sourceFile),
       // TODO: GH#18217
-      importDeclaration.moduleSpecifier,
-      importDeclaration.assertClause
-    );
+      end: position
+    };
+    return formatSpan(textRange, sourceFile, formatContext, 4 /* FormatOnOpeningCurlyBrace */);
   }
-  function sortSpecifiers(specifiers, comparer) {
-    return stableSort(specifiers, (s1, s2) => compareImportOrExportSpecifiers(s1, s2, comparer));
+  function formatOnClosingCurly(position, sourceFile, formatContext) {
+    const precedingToken = findImmediatelyPrecedingTokenOfKind(position, 20 /* CloseBraceToken */, sourceFile);
+    return formatNodeLines(findOutermostNodeWithinListLevel(precedingToken), sourceFile, formatContext, 5 /* FormatOnClosingCurlyBrace */);
   }
-  function compareImportOrExportSpecifiers(s1, s2, comparer) {
-    return compareBooleans(s1.isTypeOnly, s2.isTypeOnly) || comparer(s1.name.text, s2.name.text);
+  function formatDocument(sourceFile, formatContext) {
+    const span = {
+      pos: 0,
+      end: sourceFile.text.length
+    };
+    return formatSpan(span, sourceFile, formatContext, 0 /* FormatDocument */);
   }
-  function compareModuleSpecifiers2(m1, m2, ignoreCase) {
-    const comparer = getOrganizeImportsOrdinalStringComparer(!!ignoreCase);
-    return compareModuleSpecifiersWorker(m1, m2, comparer);
+  function formatSelection(start, end, sourceFile, formatContext) {
+    const span = {
+      pos: getLineStartPositionForPosition(start, sourceFile),
+      end
+    };
+    return formatSpan(span, sourceFile, formatContext, 1 /* FormatSelection */);
   }
-  function compareModuleSpecifiersWorker(m1, m2, comparer) {
-    const name1 = m1 === void 0 ? void 0 : getExternalModuleName2(m1);
-    const name2 = m2 === void 0 ? void 0 : getExternalModuleName2(m2);
-    return compareBooleans(name1 === void 0, name2 === void 0) || compareBooleans(isExternalModuleNameRelative(name1), isExternalModuleNameRelative(name2)) || comparer(name1, name2);
+  function findImmediatelyPrecedingTokenOfKind(end, expectedTokenKind, sourceFile) {
+    const precedingToken = findPrecedingToken(end, sourceFile);
+    return precedingToken && precedingToken.kind === expectedTokenKind && end === precedingToken.getEnd() ? precedingToken : void 0;
   }
-  function getModuleSpecifierExpression(declaration) {
-    var _a;
-    switch (declaration.kind) {
-      case 270 /* ImportEqualsDeclaration */:
-        return (_a = tryCast(declaration.moduleReference, isExternalModuleReference)) == null ? void 0 : _a.expression;
-      case 271 /* ImportDeclaration */:
-        return declaration.moduleSpecifier;
-      case 242 /* VariableStatement */:
-        return declaration.declarationList.declarations[0].initializer.arguments[0];
+  function findOutermostNodeWithinListLevel(node) {
+    let current = node;
+    while (current && current.parent && current.parent.end === node.end && !isListElement(current.parent, current)) {
+      current = current.parent;
     }
+    return current;
   }
-  function detectSorting(sourceFile, preferences) {
-    return detectSortingWorker(
-      groupByNewlineContiguous(sourceFile, sourceFile.statements.filter(isImportDeclaration)),
-      preferences
-    );
+  function isListElement(parent2, node) {
+    switch (parent2.kind) {
+      case 263 /* ClassDeclaration */:
+      case 264 /* InterfaceDeclaration */:
+        return rangeContainsRange(parent2.members, node);
+      case 267 /* ModuleDeclaration */:
+        const body = parent2.body;
+        return !!body && body.kind === 268 /* ModuleBlock */ && rangeContainsRange(body.statements, node);
+      case 312 /* SourceFile */:
+      case 241 /* Block */:
+      case 268 /* ModuleBlock */:
+        return rangeContainsRange(parent2.statements, node);
+      case 299 /* CatchClause */:
+        return rangeContainsRange(parent2.block.statements, node);
+    }
+    return false;
   }
-  function detectSortingWorker(importGroups, preferences) {
-    const collateCaseSensitive = getOrganizeImportsComparer(
-      preferences,
-      /*ignoreCase*/
-      false
-    );
-    const collateCaseInsensitive = getOrganizeImportsComparer(
-      preferences,
-      /*ignoreCase*/
-      true
-    );
-    let sortState = 3 /* Both */;
-    let seenUnsortedGroup = false;
-    for (const importGroup of importGroups) {
-      if (importGroup.length > 1) {
-        const moduleSpecifierSort = detectSortCaseSensitivity(
-          importGroup,
-          (i) => {
-            var _a;
-            return ((_a = tryCast(i.moduleSpecifier, isStringLiteral)) == null ? void 0 : _a.text) ?? "";
-          },
-          collateCaseSensitive,
-          collateCaseInsensitive
-        );
-        if (moduleSpecifierSort) {
-          sortState &= moduleSpecifierSort;
-          seenUnsortedGroup = true;
-        }
-        if (!sortState) {
-          return sortState;
+  function findEnclosingNode(range, sourceFile) {
+    return find2(sourceFile);
+    function find2(n) {
+      const candidate = forEachChild(n, (c) => startEndContainsRange(c.getStart(sourceFile), c.end, range) && c);
+      if (candidate) {
+        const result = find2(candidate);
+        if (result) {
+          return result;
         }
       }
-      const declarationWithNamedImports = find(
-        importGroup,
-        (i) => {
-          var _a, _b;
-          return ((_b = tryCast((_a = i.importClause) == null ? void 0 : _a.namedBindings, isNamedImports)) == null ? void 0 : _b.elements.length) > 1;
+      return n;
+    }
+  }
+  function prepareRangeContainsErrorFunction(errors, originalRange) {
+    if (!errors.length) {
+      return rangeHasNoErrors;
+    }
+    const sorted = errors.filter((d) => rangeOverlapsWithStartEnd(originalRange, d.start, d.start + d.length)).sort((e1, e2) => e1.start - e2.start);
+    if (!sorted.length) {
+      return rangeHasNoErrors;
+    }
+    let index = 0;
+    return (r) => {
+      while (true) {
+        if (index >= sorted.length) {
+          return false;
         }
-      );
-      if (declarationWithNamedImports) {
-        const namedImportSort = detectImportSpecifierSorting(declarationWithNamedImports.importClause.namedBindings.elements, preferences);
-        if (namedImportSort) {
-          sortState &= namedImportSort;
-          seenUnsortedGroup = true;
+        const error2 = sorted[index];
+        if (r.end <= error2.start) {
+          return false;
         }
-        if (!sortState) {
-          return sortState;
+        if (startEndOverlapsWithStartEnd(r.pos, r.end, error2.start, error2.start + error2.length)) {
+          return true;
         }
+        index++;
       }
-      if (sortState !== 3 /* Both */) {
-        return sortState;
-      }
+    };
+    function rangeHasNoErrors() {
+      return false;
     }
-    return seenUnsortedGroup ? 0 /* None */ : sortState;
-  }
-  function detectImportDeclarationSorting(imports, preferences) {
-    const collateCaseSensitive = getOrganizeImportsComparer(
-      preferences,
-      /*ignoreCase*/
-      false
-    );
-    const collateCaseInsensitive = getOrganizeImportsComparer(
-      preferences,
-      /*ignoreCase*/
-      true
-    );
-    return detectSortCaseSensitivity(
-      imports,
-      (s) => getExternalModuleName2(getModuleSpecifierExpression(s)) || "",
-      collateCaseSensitive,
-      collateCaseInsensitive
-    );
-  }
-  function getImportDeclarationInsertionIndex(sortedImports, newImport, comparer) {
-    const index = binarySearch(sortedImports, newImport, identity, (a, b) => compareImportsOrRequireStatements(a, b, comparer));
-    return index < 0 ? ~index : index;
   }
-  function getImportSpecifierInsertionIndex(sortedImports, newImport, comparer) {
-    const index = binarySearch(sortedImports, newImport, identity, (s1, s2) => compareImportOrExportSpecifiers(s1, s2, comparer));
-    return index < 0 ? ~index : index;
+  function getScanStartPosition(enclosingNode, originalRange, sourceFile) {
+    const start = enclosingNode.getStart(sourceFile);
+    if (start === originalRange.pos && enclosingNode.end === originalRange.end) {
+      return start;
+    }
+    const precedingToken = findPrecedingToken(originalRange.pos, sourceFile);
+    if (!precedingToken) {
+      return enclosingNode.pos;
+    }
+    if (precedingToken.end >= originalRange.pos) {
+      return enclosingNode.pos;
+    }
+    return precedingToken.end;
   }
-  function compareImportsOrRequireStatements(s1, s2, comparer) {
-    return compareModuleSpecifiersWorker(getModuleSpecifierExpression(s1), getModuleSpecifierExpression(s2), comparer) || compareImportKind(s1, s2);
+  function getOwnOrInheritedDelta(n, options, sourceFile) {
+    let previousLine = -1 /* Unknown */;
+    let child;
+    while (n) {
+      const line = sourceFile.getLineAndCharacterOfPosition(n.getStart(sourceFile)).line;
+      if (previousLine !== -1 /* Unknown */ && line !== previousLine) {
+        break;
+      }
+      if (SmartIndenter.shouldIndentChildNode(options, n, child, sourceFile)) {
+        return options.indentSize;
+      }
+      previousLine = line;
+      child = n;
+      n = n.parent;
+    }
+    return 0;
   }
-  function compareImportKind(s1, s2) {
-    return compareValues(getImportKindOrder(s1), getImportKindOrder(s2));
+  function formatNodeGivenIndentation(node, sourceFileLike, languageVariant, initialIndentation, delta, formatContext) {
+    const range = { pos: node.pos, end: node.end };
+    return getFormattingScanner(sourceFileLike.text, languageVariant, range.pos, range.end, (scanner2) => formatSpanWorker(
+      range,
+      node,
+      initialIndentation,
+      delta,
+      scanner2,
+      formatContext,
+      1 /* FormatSelection */,
+      (_) => false,
+      // assume that node does not have any errors
+      sourceFileLike
+    ));
   }
-  function getImportKindOrder(s1) {
-    var _a;
-    switch (s1.kind) {
-      case 271 /* ImportDeclaration */:
-        if (!s1.importClause)
-          return 0;
-        if (s1.importClause.isTypeOnly)
-          return 1;
-        if (((_a = s1.importClause.namedBindings) == null ? void 0 : _a.kind) === 273 /* NamespaceImport */)
-          return 2;
-        if (s1.importClause.name)
-          return 3;
-        return 4;
-      case 270 /* ImportEqualsDeclaration */:
-        return 5;
-      case 242 /* VariableStatement */:
-        return 6;
+  function formatNodeLines(node, sourceFile, formatContext, requestKind) {
+    if (!node) {
+      return [];
     }
+    const span = {
+      pos: getLineStartPositionForPosition(node.getStart(sourceFile), sourceFile),
+      end: node.end
+    };
+    return formatSpan(span, sourceFile, formatContext, requestKind);
   }
-  function getNewImportSpecifiers(namedImports) {
-    return flatMap(
-      namedImports,
-      (namedImport) => map(
-        tryGetNamedBindingElements(namedImport),
-        (importSpecifier) => importSpecifier.name && importSpecifier.propertyName && importSpecifier.name.escapedText === importSpecifier.propertyName.escapedText ? factory.updateImportSpecifier(
-          importSpecifier,
-          importSpecifier.isTypeOnly,
-          /*propertyName*/
-          void 0,
-          importSpecifier.name
-        ) : importSpecifier
+  function formatSpan(originalRange, sourceFile, formatContext, requestKind) {
+    const enclosingNode = findEnclosingNode(originalRange, sourceFile);
+    return getFormattingScanner(
+      sourceFile.text,
+      sourceFile.languageVariant,
+      getScanStartPosition(enclosingNode, originalRange, sourceFile),
+      originalRange.end,
+      (scanner2) => formatSpanWorker(
+        originalRange,
+        enclosingNode,
+        SmartIndenter.getIndentationForNode(enclosingNode, originalRange, sourceFile, formatContext.options),
+        getOwnOrInheritedDelta(enclosingNode, formatContext.options, sourceFile),
+        scanner2,
+        formatContext,
+        requestKind,
+        prepareRangeContainsErrorFunction(sourceFile.parseDiagnostics, originalRange),
+        sourceFile
       )
     );
   }
-  function tryGetNamedBindingElements(namedImport) {
+  function formatSpanWorker(originalRange, enclosingNode, initialIndentation, delta, formattingScanner, { options, getRules, host }, requestKind, rangeContainsError, sourceFile) {
     var _a;
-    return ((_a = namedImport.importClause) == null ? void 0 : _a.namedBindings) && isNamedImports(namedImport.importClause.namedBindings) ? namedImport.importClause.namedBindings.elements : void 0;
-  }
-  function getOrganizeImportsOrdinalStringComparer(ignoreCase) {
-    return ignoreCase ? compareStringsCaseInsensitiveEslintCompatible : compareStringsCaseSensitive;
-  }
-  function getOrganizeImportsUnicodeStringComparer(ignoreCase, preferences) {
-    const resolvedLocale = getOrganizeImportsLocale(preferences);
-    const caseFirst = preferences.organizeImportsCaseFirst ?? false;
-    const numeric = preferences.organizeImportsNumericCollation ?? false;
-    const accents = preferences.organizeImportsAccentCollation ?? true;
-    const sensitivity = ignoreCase ? accents ? "accent" : "base" : accents ? "variant" : "case";
-    const collator = new Intl.Collator(resolvedLocale, {
-      usage: "sort",
-      caseFirst: caseFirst || "false",
-      sensitivity,
-      numeric
-    });
-    return collator.compare;
-  }
-  function getOrganizeImportsLocale(preferences) {
-    let locale = preferences.organizeImportsLocale;
-    if (locale === "auto")
-      locale = getUILocale();
-    if (locale === void 0)
-      locale = "en";
-    const supportedLocales = Intl.Collator.supportedLocalesOf(locale);
-    const resolvedLocale = supportedLocales.length ? supportedLocales[0] : "en";
-    return resolvedLocale;
-  }
-  function getOrganizeImportsComparer(preferences, ignoreCase) {
-    const collation = preferences.organizeImportsCollation ?? "ordinal";
-    return collation === "unicode" ? getOrganizeImportsUnicodeStringComparer(ignoreCase, preferences) : getOrganizeImportsOrdinalStringComparer(ignoreCase);
-  }
-  function getOrganizeImportsComparerWithDetection(preferences, detectIgnoreCase) {
-    const ignoreCase = typeof preferences.organizeImportsIgnoreCase === "boolean" ? preferences.organizeImportsIgnoreCase : (detectIgnoreCase == null ? void 0 : detectIgnoreCase()) ?? false;
-    return getOrganizeImportsComparer(preferences, ignoreCase);
-  }
-  function getTopLevelExportGroups(sourceFile) {
-    const topLevelExportGroups = [];
-    const statements = sourceFile.statements;
-    const len = length(statements);
-    let i = 0;
-    let groupIndex = 0;
-    while (i < len) {
-      if (isExportDeclaration(statements[i])) {
-        if (topLevelExportGroups[groupIndex] === void 0) {
-          topLevelExportGroups[groupIndex] = [];
+    const formattingContext = new FormattingContext(sourceFile, requestKind, options);
+    let previousRangeTriviaEnd;
+    let previousRange;
+    let previousParent;
+    let previousRangeStartLine;
+    let lastIndentedLine;
+    let indentationOnLastIndentedLine = -1 /* Unknown */;
+    const edits = [];
+    formattingScanner.advance();
+    if (formattingScanner.isOnToken()) {
+      const startLine = sourceFile.getLineAndCharacterOfPosition(enclosingNode.getStart(sourceFile)).line;
+      let undecoratedStartLine = startLine;
+      if (hasDecorators(enclosingNode)) {
+        undecoratedStartLine = sourceFile.getLineAndCharacterOfPosition(getNonDecoratorTokenPosOfNode(enclosingNode, sourceFile)).line;
+      }
+      processNode(enclosingNode, enclosingNode, startLine, undecoratedStartLine, initialIndentation, delta);
+    }
+    const remainingTrivia = formattingScanner.getCurrentLeadingTrivia();
+    if (remainingTrivia) {
+      const indentation = SmartIndenter.nodeWillIndentChild(
+        options,
+        enclosingNode,
+        /*child*/
+        void 0,
+        sourceFile,
+        /*indentByDefault*/
+        false
+      ) ? initialIndentation + options.indentSize : initialIndentation;
+      indentTriviaItems(
+        remainingTrivia,
+        indentation,
+        /*indentNextTokenOrTrivia*/
+        true,
+        (item) => {
+          processRange(
+            item,
+            sourceFile.getLineAndCharacterOfPosition(item.pos),
+            enclosingNode,
+            enclosingNode,
+            /*dynamicIndentation*/
+            void 0
+          );
+          insertIndentation(
+            item.pos,
+            indentation,
+            /*lineAdded*/
+            false
+          );
         }
-        const exportDecl = statements[i];
-        if (exportDecl.moduleSpecifier) {
-          topLevelExportGroups[groupIndex].push(exportDecl);
-          i++;
+      );
+      if (options.trimTrailingWhitespace !== false) {
+        trimTrailingWhitespacesForRemainingRange(remainingTrivia);
+      }
+    }
+    if (previousRange && formattingScanner.getTokenFullStart() >= originalRange.end) {
+      const tokenInfo = formattingScanner.isOnEOF() ? formattingScanner.readEOFTokenRange() : formattingScanner.isOnToken() ? formattingScanner.readTokenInfo(enclosingNode).token : void 0;
+      if (tokenInfo && tokenInfo.pos === previousRangeTriviaEnd) {
+        const parent2 = ((_a = findPrecedingToken(tokenInfo.end, sourceFile, enclosingNode)) == null ? void 0 : _a.parent) || previousParent;
+        processPair(
+          tokenInfo,
+          sourceFile.getLineAndCharacterOfPosition(tokenInfo.pos).line,
+          parent2,
+          previousRange,
+          previousRangeStartLine,
+          previousParent,
+          parent2,
+          /*dynamicIndentation*/
+          void 0
+        );
+      }
+    }
+    return edits;
+    function tryComputeIndentationForListItem(startPos, endPos, parentStartLine, range, inheritedIndentation) {
+      if (rangeOverlapsWithStartEnd(range, startPos, endPos) || rangeContainsStartEnd(range, startPos, endPos)) {
+        if (inheritedIndentation !== -1 /* Unknown */) {
+          return inheritedIndentation;
+        }
+      } else {
+        const startLine = sourceFile.getLineAndCharacterOfPosition(startPos).line;
+        const startLinePosition = getLineStartPositionForPosition(startPos, sourceFile);
+        const column = SmartIndenter.findFirstNonWhitespaceColumn(startLinePosition, startPos, sourceFile, options);
+        if (startLine !== parentStartLine || startPos === column) {
+          const baseIndentSize = SmartIndenter.getBaseIndentation(options);
+          return baseIndentSize > column ? baseIndentSize : column;
+        }
+      }
+      return -1 /* Unknown */;
+    }
+    function computeIndentation(node, startLine, inheritedIndentation, parent2, parentDynamicIndentation, effectiveParentStartLine) {
+      const delta2 = SmartIndenter.shouldIndentChildNode(options, node) ? options.indentSize : 0;
+      if (effectiveParentStartLine === startLine) {
+        return {
+          indentation: startLine === lastIndentedLine ? indentationOnLastIndentedLine : parentDynamicIndentation.getIndentation(),
+          delta: Math.min(options.indentSize, parentDynamicIndentation.getDelta(node) + delta2)
+        };
+      } else if (inheritedIndentation === -1 /* Unknown */) {
+        if (node.kind === 21 /* OpenParenToken */ && startLine === lastIndentedLine) {
+          return { indentation: indentationOnLastIndentedLine, delta: parentDynamicIndentation.getDelta(node) };
+        } else if (SmartIndenter.childStartsOnTheSameLineWithElseInIfStatement(parent2, node, startLine, sourceFile) || SmartIndenter.childIsUnindentedBranchOfConditionalExpression(parent2, node, startLine, sourceFile) || SmartIndenter.argumentStartsOnSameLineAsPreviousArgument(parent2, node, startLine, sourceFile)) {
+          return { indentation: parentDynamicIndentation.getIndentation(), delta: delta2 };
         } else {
-          while (i < len && isExportDeclaration(statements[i])) {
-            topLevelExportGroups[groupIndex].push(statements[i++]);
-          }
-          groupIndex++;
+          return { indentation: parentDynamicIndentation.getIndentation() + parentDynamicIndentation.getDelta(node), delta: delta2 };
         }
       } else {
-        i++;
+        return { indentation: inheritedIndentation, delta: delta2 };
       }
     }
-    return flatMap(topLevelExportGroups, (exportGroupDecls) => groupByNewlineContiguous(sourceFile, exportGroupDecls));
-  }
-  var ImportSpecifierSortingCache, detectImportSpecifierSorting;
-  var init_organizeImports = __esm({
-    "src/services/organizeImports.ts"() {
-      "use strict";
-      init_ts4();
-      ImportSpecifierSortingCache = class {
-        has([specifiers, preferences]) {
-          if (this._lastPreferences !== preferences || !this._cache)
+    function getFirstNonDecoratorTokenOfNode(node) {
+      if (canHaveModifiers(node)) {
+        const modifier = find(node.modifiers, isModifier, findIndex(node.modifiers, isDecorator));
+        if (modifier)
+          return modifier.kind;
+      }
+      switch (node.kind) {
+        case 263 /* ClassDeclaration */:
+          return 86 /* ClassKeyword */;
+        case 264 /* InterfaceDeclaration */:
+          return 120 /* InterfaceKeyword */;
+        case 262 /* FunctionDeclaration */:
+          return 100 /* FunctionKeyword */;
+        case 266 /* EnumDeclaration */:
+          return 266 /* EnumDeclaration */;
+        case 177 /* GetAccessor */:
+          return 139 /* GetKeyword */;
+        case 178 /* SetAccessor */:
+          return 153 /* SetKeyword */;
+        case 174 /* MethodDeclaration */:
+          if (node.asteriskToken) {
+            return 42 /* AsteriskToken */;
+          }
+        case 172 /* PropertyDeclaration */:
+        case 169 /* Parameter */:
+          const name = getNameOfDeclaration(node);
+          if (name) {
+            return name.kind;
+          }
+      }
+    }
+    function getDynamicIndentation(node, nodeStartLine, indentation, delta2) {
+      return {
+        getIndentationForComment: (kind, tokenIndentation, container) => {
+          switch (kind) {
+            case 20 /* CloseBraceToken */:
+            case 24 /* CloseBracketToken */:
+            case 22 /* CloseParenToken */:
+              return indentation + getDelta(container);
+          }
+          return tokenIndentation !== -1 /* Unknown */ ? tokenIndentation : indentation;
+        },
+        // if list end token is LessThanToken '>' then its delta should be explicitly suppressed
+        // so that LessThanToken as a binary operator can still be indented.
+        // foo.then
+        //     <
+        //         number,
+        //         string,
+        //     >();
+        // vs
+        // var a = xValue
+        //     > yValue;
+        getIndentationForToken: (line, kind, container, suppressDelta) => !suppressDelta && shouldAddDelta(line, kind, container) ? indentation + getDelta(container) : indentation,
+        getIndentation: () => indentation,
+        getDelta,
+        recomputeIndentation: (lineAdded, parent2) => {
+          if (SmartIndenter.shouldIndentChildNode(options, parent2, node, sourceFile)) {
+            indentation += lineAdded ? options.indentSize : -options.indentSize;
+            delta2 = SmartIndenter.shouldIndentChildNode(options, node) ? options.indentSize : 0;
+          }
+        }
+      };
+      function shouldAddDelta(line, kind, container) {
+        switch (kind) {
+          case 19 /* OpenBraceToken */:
+          case 20 /* CloseBraceToken */:
+          case 22 /* CloseParenToken */:
+          case 93 /* ElseKeyword */:
+          case 117 /* WhileKeyword */:
+          case 60 /* AtToken */:
             return false;
-          return this._cache.has(specifiers);
+          case 44 /* SlashToken */:
+          case 32 /* GreaterThanToken */:
+            switch (container.kind) {
+              case 286 /* JsxOpeningElement */:
+              case 287 /* JsxClosingElement */:
+              case 285 /* JsxSelfClosingElement */:
+                return false;
+            }
+            break;
+          case 23 /* OpenBracketToken */:
+          case 24 /* CloseBracketToken */:
+            if (container.kind !== 200 /* MappedType */) {
+              return false;
+            }
+            break;
         }
-        get([specifiers, preferences]) {
-          if (this._lastPreferences !== preferences || !this._cache)
-            return void 0;
-          return this._cache.get(specifiers);
+        return nodeStartLine !== line && !(hasDecorators(node) && kind === getFirstNonDecoratorTokenOfNode(node));
+      }
+      function getDelta(child) {
+        return SmartIndenter.nodeWillIndentChild(
+          options,
+          node,
+          child,
+          sourceFile,
+          /*indentByDefault*/
+          true
+        ) ? delta2 : 0;
+      }
+    }
+    function processNode(node, contextNode, nodeStartLine, undecoratedNodeStartLine, indentation, delta2) {
+      if (!rangeOverlapsWithStartEnd(originalRange, node.getStart(sourceFile), node.getEnd())) {
+        return;
+      }
+      const nodeDynamicIndentation = getDynamicIndentation(node, nodeStartLine, indentation, delta2);
+      let childContextNode = contextNode;
+      forEachChild(
+        node,
+        (child) => {
+          processChildNode(
+            child,
+            /*inheritedIndentation*/
+            -1 /* Unknown */,
+            node,
+            nodeDynamicIndentation,
+            nodeStartLine,
+            undecoratedNodeStartLine,
+            /*isListItem*/
+            false
+          );
+        },
+        (nodes) => {
+          processChildNodes(nodes, node, nodeStartLine, nodeDynamicIndentation);
         }
-        set([specifiers, preferences], value) {
-          if (this._lastPreferences !== preferences) {
-            this._lastPreferences = preferences;
-            this._cache = void 0;
+      );
+      while (formattingScanner.isOnToken() && formattingScanner.getTokenFullStart() < originalRange.end) {
+        const tokenInfo = formattingScanner.readTokenInfo(node);
+        if (tokenInfo.token.end > Math.min(node.end, originalRange.end)) {
+          break;
+        }
+        consumeTokenAndAdvanceScanner(tokenInfo, node, nodeDynamicIndentation, node);
+      }
+      function processChildNode(child, inheritedIndentation, parent2, parentDynamicIndentation, parentStartLine, undecoratedParentStartLine, isListItem, isFirstListItem) {
+        Debug.assert(!nodeIsSynthesized(child));
+        if (nodeIsMissing(child) || isGrammarError(parent2, child)) {
+          return inheritedIndentation;
+        }
+        const childStartPos = child.getStart(sourceFile);
+        const childStartLine = sourceFile.getLineAndCharacterOfPosition(childStartPos).line;
+        let undecoratedChildStartLine = childStartLine;
+        if (hasDecorators(child)) {
+          undecoratedChildStartLine = sourceFile.getLineAndCharacterOfPosition(getNonDecoratorTokenPosOfNode(child, sourceFile)).line;
+        }
+        let childIndentationAmount = -1 /* Unknown */;
+        if (isListItem && rangeContainsRange(originalRange, parent2)) {
+          childIndentationAmount = tryComputeIndentationForListItem(childStartPos, child.end, parentStartLine, originalRange, inheritedIndentation);
+          if (childIndentationAmount !== -1 /* Unknown */) {
+            inheritedIndentation = childIndentationAmount;
           }
-          this._cache ?? (this._cache = /* @__PURE__ */ new WeakMap());
-          this._cache.set(specifiers, value);
         }
-      };
-      detectImportSpecifierSorting = memoizeCached((specifiers, preferences) => {
-        if (!arrayIsSorted(specifiers, (s1, s2) => compareBooleans(s1.isTypeOnly, s2.isTypeOnly))) {
-          return 0 /* None */;
+        if (!rangeOverlapsWithStartEnd(originalRange, child.pos, child.end)) {
+          if (child.end < originalRange.pos) {
+            formattingScanner.skipToEndOf(child);
+          }
+          return inheritedIndentation;
         }
-        const collateCaseSensitive = getOrganizeImportsComparer(
-          preferences,
-          /*ignoreCase*/
-          false
-        );
-        const collateCaseInsensitive = getOrganizeImportsComparer(
-          preferences,
-          /*ignoreCase*/
-          true
-        );
-        return detectSortCaseSensitivity(specifiers, (specifier) => specifier.name.text, collateCaseSensitive, collateCaseInsensitive);
-      }, new ImportSpecifierSortingCache());
+        if (child.getFullWidth() === 0) {
+          return inheritedIndentation;
+        }
+        while (formattingScanner.isOnToken() && formattingScanner.getTokenFullStart() < originalRange.end) {
+          const tokenInfo = formattingScanner.readTokenInfo(node);
+          if (tokenInfo.token.end > originalRange.end) {
+            return inheritedIndentation;
+          }
+          if (tokenInfo.token.end > childStartPos) {
+            if (tokenInfo.token.pos > childStartPos) {
+              formattingScanner.skipToStartOf(child);
+            }
+            break;
+          }
+          consumeTokenAndAdvanceScanner(tokenInfo, node, parentDynamicIndentation, node);
+        }
+        if (!formattingScanner.isOnToken() || formattingScanner.getTokenFullStart() >= originalRange.end) {
+          return inheritedIndentation;
+        }
+        if (isToken(child)) {
+          const tokenInfo = formattingScanner.readTokenInfo(child);
+          if (child.kind !== 12 /* JsxText */) {
+            Debug.assert(tokenInfo.token.end === child.end, "Token end is child end");
+            consumeTokenAndAdvanceScanner(tokenInfo, node, parentDynamicIndentation, child);
+            return inheritedIndentation;
+          }
+        }
+        const effectiveParentStartLine = child.kind === 170 /* Decorator */ ? childStartLine : undecoratedParentStartLine;
+        const childIndentation = computeIndentation(child, childStartLine, childIndentationAmount, node, parentDynamicIndentation, effectiveParentStartLine);
+        processNode(child, childContextNode, childStartLine, undecoratedChildStartLine, childIndentation.indentation, childIndentation.delta);
+        childContextNode = node;
+        if (isFirstListItem && parent2.kind === 209 /* ArrayLiteralExpression */ && inheritedIndentation === -1 /* Unknown */) {
+          inheritedIndentation = childIndentation.indentation;
+        }
+        return inheritedIndentation;
+      }
+      function processChildNodes(nodes, parent2, parentStartLine, parentDynamicIndentation) {
+        Debug.assert(isNodeArray(nodes));
+        Debug.assert(!nodeIsSynthesized(nodes));
+        const listStartToken = getOpenTokenForList(parent2, nodes);
+        let listDynamicIndentation = parentDynamicIndentation;
+        let startLine = parentStartLine;
+        if (!rangeOverlapsWithStartEnd(originalRange, nodes.pos, nodes.end)) {
+          if (nodes.end < originalRange.pos) {
+            formattingScanner.skipToEndOf(nodes);
+          }
+          return;
+        }
+        if (listStartToken !== 0 /* Unknown */) {
+          while (formattingScanner.isOnToken() && formattingScanner.getTokenFullStart() < originalRange.end) {
+            const tokenInfo = formattingScanner.readTokenInfo(parent2);
+            if (tokenInfo.token.end > nodes.pos) {
+              break;
+            } else if (tokenInfo.token.kind === listStartToken) {
+              startLine = sourceFile.getLineAndCharacterOfPosition(tokenInfo.token.pos).line;
+              consumeTokenAndAdvanceScanner(tokenInfo, parent2, parentDynamicIndentation, parent2);
+              let indentationOnListStartToken;
+              if (indentationOnLastIndentedLine !== -1 /* Unknown */) {
+                indentationOnListStartToken = indentationOnLastIndentedLine;
+              } else {
+                const startLinePosition = getLineStartPositionForPosition(tokenInfo.token.pos, sourceFile);
+                indentationOnListStartToken = SmartIndenter.findFirstNonWhitespaceColumn(startLinePosition, tokenInfo.token.pos, sourceFile, options);
+              }
+              listDynamicIndentation = getDynamicIndentation(parent2, parentStartLine, indentationOnListStartToken, options.indentSize);
+            } else {
+              consumeTokenAndAdvanceScanner(tokenInfo, parent2, parentDynamicIndentation, parent2);
+            }
+          }
+        }
+        let inheritedIndentation = -1 /* Unknown */;
+        for (let i = 0; i < nodes.length; i++) {
+          const child = nodes[i];
+          inheritedIndentation = processChildNode(
+            child,
+            inheritedIndentation,
+            node,
+            listDynamicIndentation,
+            startLine,
+            startLine,
+            /*isListItem*/
+            true,
+            /*isFirstListItem*/
+            i === 0
+          );
+        }
+        const listEndToken = getCloseTokenForOpenToken(listStartToken);
+        if (listEndToken !== 0 /* Unknown */ && formattingScanner.isOnToken() && formattingScanner.getTokenFullStart() < originalRange.end) {
+          let tokenInfo = formattingScanner.readTokenInfo(parent2);
+          if (tokenInfo.token.kind === 28 /* CommaToken */) {
+            consumeTokenAndAdvanceScanner(tokenInfo, parent2, listDynamicIndentation, parent2);
+            tokenInfo = formattingScanner.isOnToken() ? formattingScanner.readTokenInfo(parent2) : void 0;
+          }
+          if (tokenInfo && tokenInfo.token.kind === listEndToken && rangeContainsRange(parent2, tokenInfo.token)) {
+            consumeTokenAndAdvanceScanner(
+              tokenInfo,
+              parent2,
+              listDynamicIndentation,
+              parent2,
+              /*isListEndToken*/
+              true
+            );
+          }
+        }
+      }
+      function consumeTokenAndAdvanceScanner(currentTokenInfo, parent2, dynamicIndentation, container, isListEndToken) {
+        Debug.assert(rangeContainsRange(parent2, currentTokenInfo.token));
+        const lastTriviaWasNewLine = formattingScanner.lastTrailingTriviaWasNewLine();
+        let indentToken = false;
+        if (currentTokenInfo.leadingTrivia) {
+          processTrivia(currentTokenInfo.leadingTrivia, parent2, childContextNode, dynamicIndentation);
+        }
+        let lineAction = 0 /* None */;
+        const isTokenInRange = rangeContainsRange(originalRange, currentTokenInfo.token);
+        const tokenStart = sourceFile.getLineAndCharacterOfPosition(currentTokenInfo.token.pos);
+        if (isTokenInRange) {
+          const rangeHasError = rangeContainsError(currentTokenInfo.token);
+          const savePreviousRange = previousRange;
+          lineAction = processRange(currentTokenInfo.token, tokenStart, parent2, childContextNode, dynamicIndentation);
+          if (!rangeHasError) {
+            if (lineAction === 0 /* None */) {
+              const prevEndLine = savePreviousRange && sourceFile.getLineAndCharacterOfPosition(savePreviousRange.end).line;
+              indentToken = lastTriviaWasNewLine && tokenStart.line !== prevEndLine;
+            } else {
+              indentToken = lineAction === 1 /* LineAdded */;
+            }
+          }
+        }
+        if (currentTokenInfo.trailingTrivia) {
+          previousRangeTriviaEnd = last(currentTokenInfo.trailingTrivia).end;
+          processTrivia(currentTokenInfo.trailingTrivia, parent2, childContextNode, dynamicIndentation);
+        }
+        if (indentToken) {
+          const tokenIndentation = isTokenInRange && !rangeContainsError(currentTokenInfo.token) ? dynamicIndentation.getIndentationForToken(tokenStart.line, currentTokenInfo.token.kind, container, !!isListEndToken) : -1 /* Unknown */;
+          let indentNextTokenOrTrivia = true;
+          if (currentTokenInfo.leadingTrivia) {
+            const commentIndentation = dynamicIndentation.getIndentationForComment(currentTokenInfo.token.kind, tokenIndentation, container);
+            indentNextTokenOrTrivia = indentTriviaItems(currentTokenInfo.leadingTrivia, commentIndentation, indentNextTokenOrTrivia, (item) => insertIndentation(
+              item.pos,
+              commentIndentation,
+              /*lineAdded*/
+              false
+            ));
+          }
+          if (tokenIndentation !== -1 /* Unknown */ && indentNextTokenOrTrivia) {
+            insertIndentation(currentTokenInfo.token.pos, tokenIndentation, lineAction === 1 /* LineAdded */);
+            lastIndentedLine = tokenStart.line;
+            indentationOnLastIndentedLine = tokenIndentation;
+          }
+        }
+        formattingScanner.advance();
+        childContextNode = parent2;
+      }
     }
-  });
-
-  // src/services/_namespaces/ts.OrganizeImports.ts
-  var ts_OrganizeImports_exports = {};
-  __export(ts_OrganizeImports_exports, {
-    coalesceExports: () => coalesceExports,
-    coalesceImports: () => coalesceImports,
-    compareImportOrExportSpecifiers: () => compareImportOrExportSpecifiers,
-    compareImportsOrRequireStatements: () => compareImportsOrRequireStatements,
-    compareModuleSpecifiers: () => compareModuleSpecifiers2,
-    detectImportDeclarationSorting: () => detectImportDeclarationSorting,
-    detectImportSpecifierSorting: () => detectImportSpecifierSorting,
-    detectSorting: () => detectSorting,
-    getImportDeclarationInsertionIndex: () => getImportDeclarationInsertionIndex,
-    getImportSpecifierInsertionIndex: () => getImportSpecifierInsertionIndex,
-    getOrganizeImportsComparer: () => getOrganizeImportsComparer,
-    organizeImports: () => organizeImports
-  });
-  var init_ts_OrganizeImports = __esm({
-    "src/services/_namespaces/ts.OrganizeImports.ts"() {
-      "use strict";
-      init_organizeImports();
+    function indentTriviaItems(trivia, commentIndentation, indentNextTokenOrTrivia, indentSingleLine) {
+      for (const triviaItem of trivia) {
+        const triviaInRange = rangeContainsRange(originalRange, triviaItem);
+        switch (triviaItem.kind) {
+          case 3 /* MultiLineCommentTrivia */:
+            if (triviaInRange) {
+              indentMultilineComment(
+                triviaItem,
+                commentIndentation,
+                /*firstLineIsIndented*/
+                !indentNextTokenOrTrivia
+              );
+            }
+            indentNextTokenOrTrivia = false;
+            break;
+          case 2 /* SingleLineCommentTrivia */:
+            if (indentNextTokenOrTrivia && triviaInRange) {
+              indentSingleLine(triviaItem);
+            }
+            indentNextTokenOrTrivia = false;
+            break;
+          case 4 /* NewLineTrivia */:
+            indentNextTokenOrTrivia = true;
+            break;
+        }
+      }
+      return indentNextTokenOrTrivia;
     }
-  });
-
-  // src/services/outliningElementsCollector.ts
-  function collectElements(sourceFile, cancellationToken) {
-    const res = [];
-    addNodeOutliningSpans(sourceFile, cancellationToken, res);
-    addRegionOutliningSpans(sourceFile, res);
-    return res.sort((span1, span2) => span1.textSpan.start - span2.textSpan.start);
-  }
-  function addNodeOutliningSpans(sourceFile, cancellationToken, out) {
-    let depthRemaining = 40;
-    let current = 0;
-    const statements = [...sourceFile.statements, sourceFile.endOfFileToken];
-    const n = statements.length;
-    while (current < n) {
-      while (current < n && !isAnyImportSyntax(statements[current])) {
-        visitNode3(statements[current]);
-        current++;
+    function processTrivia(trivia, parent2, contextNode, dynamicIndentation) {
+      for (const triviaItem of trivia) {
+        if (isComment(triviaItem.kind) && rangeContainsRange(originalRange, triviaItem)) {
+          const triviaItemStart = sourceFile.getLineAndCharacterOfPosition(triviaItem.pos);
+          processRange(triviaItem, triviaItemStart, parent2, contextNode, dynamicIndentation);
+        }
       }
-      if (current === n)
-        break;
-      const firstImport = current;
-      while (current < n && isAnyImportSyntax(statements[current])) {
-        visitNode3(statements[current]);
-        current++;
+    }
+    function processRange(range, rangeStart, parent2, contextNode, dynamicIndentation) {
+      const rangeHasError = rangeContainsError(range);
+      let lineAction = 0 /* None */;
+      if (!rangeHasError) {
+        if (!previousRange) {
+          const originalStart = sourceFile.getLineAndCharacterOfPosition(originalRange.pos);
+          trimTrailingWhitespacesForLines(originalStart.line, rangeStart.line);
+        } else {
+          lineAction = processPair(range, rangeStart.line, parent2, previousRange, previousRangeStartLine, previousParent, contextNode, dynamicIndentation);
+        }
       }
-      const lastImport = current - 1;
-      if (lastImport !== firstImport) {
-        out.push(createOutliningSpanFromBounds(findChildOfKind(statements[firstImport], 102 /* ImportKeyword */, sourceFile).getStart(sourceFile), statements[lastImport].getEnd(), "imports" /* Imports */));
+      previousRange = range;
+      previousRangeTriviaEnd = range.end;
+      previousParent = parent2;
+      previousRangeStartLine = rangeStart.line;
+      return lineAction;
+    }
+    function processPair(currentItem, currentStartLine, currentParent, previousItem, previousStartLine, previousParent2, contextNode, dynamicIndentation) {
+      formattingContext.updateContext(previousItem, previousParent2, currentItem, currentParent, contextNode);
+      const rules = getRules(formattingContext);
+      let trimTrailingWhitespaces = formattingContext.options.trimTrailingWhitespace !== false;
+      let lineAction = 0 /* None */;
+      if (rules) {
+        forEachRight(rules, (rule2) => {
+          lineAction = applyRuleEdits(rule2, previousItem, previousStartLine, currentItem, currentStartLine);
+          if (dynamicIndentation) {
+            switch (lineAction) {
+              case 2 /* LineRemoved */:
+                if (currentParent.getStart(sourceFile) === currentItem.pos) {
+                  dynamicIndentation.recomputeIndentation(
+                    /*lineAddedByFormatting*/
+                    false,
+                    contextNode
+                  );
+                }
+                break;
+              case 1 /* LineAdded */:
+                if (currentParent.getStart(sourceFile) === currentItem.pos) {
+                  dynamicIndentation.recomputeIndentation(
+                    /*lineAddedByFormatting*/
+                    true,
+                    contextNode
+                  );
+                }
+                break;
+              default:
+                Debug.assert(lineAction === 0 /* None */);
+            }
+          }
+          trimTrailingWhitespaces = trimTrailingWhitespaces && !(rule2.action & 16 /* DeleteSpace */) && rule2.flags !== 1 /* CanDeleteNewLines */;
+        });
+      } else {
+        trimTrailingWhitespaces = trimTrailingWhitespaces && currentItem.kind !== 1 /* EndOfFileToken */;
+      }
+      if (currentStartLine !== previousStartLine && trimTrailingWhitespaces) {
+        trimTrailingWhitespacesForLines(previousStartLine, currentStartLine, previousItem);
+      }
+      return lineAction;
+    }
+    function insertIndentation(pos, indentation, lineAdded) {
+      const indentationString = getIndentationString(indentation, options);
+      if (lineAdded) {
+        recordReplace(pos, 0, indentationString);
+      } else {
+        const tokenStart = sourceFile.getLineAndCharacterOfPosition(pos);
+        const startLinePosition = getStartPositionOfLine(tokenStart.line, sourceFile);
+        if (indentation !== characterToColumn(startLinePosition, tokenStart.character) || indentationIsDifferent(indentationString, startLinePosition)) {
+          recordReplace(startLinePosition, tokenStart.character, indentationString);
+        }
+      }
+    }
+    function characterToColumn(startLinePosition, characterInLine) {
+      let column = 0;
+      for (let i = 0; i < characterInLine; i++) {
+        if (sourceFile.text.charCodeAt(startLinePosition + i) === 9 /* tab */) {
+          column += options.tabSize - column % options.tabSize;
+        } else {
+          column++;
+        }
       }
+      return column;
     }
-    function visitNode3(n2) {
-      var _a;
-      if (depthRemaining === 0)
+    function indentationIsDifferent(indentationString, startLinePosition) {
+      return indentationString !== sourceFile.text.substr(startLinePosition, indentationString.length);
+    }
+    function indentMultilineComment(commentRange, indentation, firstLineIsIndented, indentFinalLine = true) {
+      let startLine = sourceFile.getLineAndCharacterOfPosition(commentRange.pos).line;
+      const endLine = sourceFile.getLineAndCharacterOfPosition(commentRange.end).line;
+      if (startLine === endLine) {
+        if (!firstLineIsIndented) {
+          insertIndentation(
+            commentRange.pos,
+            indentation,
+            /*lineAdded*/
+            false
+          );
+        }
         return;
-      cancellationToken.throwIfCancellationRequested();
-      if (isDeclaration(n2) || isVariableStatement(n2) || isReturnStatement(n2) || isCallOrNewExpression(n2) || n2.kind === 1 /* EndOfFileToken */) {
-        addOutliningForLeadingCommentsForNode(n2, sourceFile, cancellationToken, out);
       }
-      if (isFunctionLike(n2) && isBinaryExpression(n2.parent) && isPropertyAccessExpression(n2.parent.left)) {
-        addOutliningForLeadingCommentsForNode(n2.parent.left, sourceFile, cancellationToken, out);
+      const parts = [];
+      let startPos = commentRange.pos;
+      for (let line = startLine; line < endLine; line++) {
+        const endOfLine = getEndLinePosition(line, sourceFile);
+        parts.push({ pos: startPos, end: endOfLine });
+        startPos = getStartPositionOfLine(line + 1, sourceFile);
       }
-      if (isBlock(n2) || isModuleBlock(n2)) {
-        addOutliningForLeadingCommentsForPos(n2.statements.end, sourceFile, cancellationToken, out);
+      if (indentFinalLine) {
+        parts.push({ pos: startPos, end: commentRange.end });
       }
-      if (isClassLike(n2) || isInterfaceDeclaration(n2)) {
-        addOutliningForLeadingCommentsForPos(n2.members.end, sourceFile, cancellationToken, out);
+      if (parts.length === 0)
+        return;
+      const startLinePos = getStartPositionOfLine(startLine, sourceFile);
+      const nonWhitespaceColumnInFirstPart = SmartIndenter.findFirstNonWhitespaceCharacterAndColumn(startLinePos, parts[0].pos, sourceFile, options);
+      let startIndex = 0;
+      if (firstLineIsIndented) {
+        startIndex = 1;
+        startLine++;
       }
-      const span = getOutliningSpanForNode(n2, sourceFile);
-      if (span)
-        out.push(span);
-      depthRemaining--;
-      if (isCallExpression(n2)) {
-        depthRemaining++;
-        visitNode3(n2.expression);
-        depthRemaining--;
-        n2.arguments.forEach(visitNode3);
-        (_a = n2.typeArguments) == null ? void 0 : _a.forEach(visitNode3);
-      } else if (isIfStatement(n2) && n2.elseStatement && isIfStatement(n2.elseStatement)) {
-        visitNode3(n2.expression);
-        visitNode3(n2.thenStatement);
-        depthRemaining++;
-        visitNode3(n2.elseStatement);
-        depthRemaining--;
-      } else {
-        n2.forEachChild(visitNode3);
+      const delta2 = indentation - nonWhitespaceColumnInFirstPart.column;
+      for (let i = startIndex; i < parts.length; i++, startLine++) {
+        const startLinePos2 = getStartPositionOfLine(startLine, sourceFile);
+        const nonWhitespaceCharacterAndColumn = i === 0 ? nonWhitespaceColumnInFirstPart : SmartIndenter.findFirstNonWhitespaceCharacterAndColumn(parts[i].pos, parts[i].end, sourceFile, options);
+        const newIndentation = nonWhitespaceCharacterAndColumn.column + delta2;
+        if (newIndentation > 0) {
+          const indentationString = getIndentationString(newIndentation, options);
+          recordReplace(startLinePos2, nonWhitespaceCharacterAndColumn.character, indentationString);
+        } else {
+          recordDelete(startLinePos2, nonWhitespaceCharacterAndColumn.character);
+        }
       }
-      depthRemaining++;
     }
-  }
-  function addRegionOutliningSpans(sourceFile, out) {
-    const regions = [];
-    const lineStarts = sourceFile.getLineStarts();
-    for (const currentLineStart of lineStarts) {
-      const lineEnd = sourceFile.getLineEndOfPosition(currentLineStart);
-      const lineText = sourceFile.text.substring(currentLineStart, lineEnd);
-      const result = isRegionDelimiter(lineText);
-      if (!result || isInComment(sourceFile, currentLineStart)) {
-        continue;
+    function trimTrailingWhitespacesForLines(line1, line2, range) {
+      for (let line = line1; line < line2; line++) {
+        const lineStartPosition = getStartPositionOfLine(line, sourceFile);
+        const lineEndPosition = getEndLinePosition(line, sourceFile);
+        if (range && (isComment(range.kind) || isStringOrRegularExpressionOrTemplateLiteral(range.kind)) && range.pos <= lineEndPosition && range.end > lineEndPosition) {
+          continue;
+        }
+        const whitespaceStart = getTrailingWhitespaceStartPosition(lineStartPosition, lineEndPosition);
+        if (whitespaceStart !== -1) {
+          Debug.assert(whitespaceStart === lineStartPosition || !isWhiteSpaceSingleLine(sourceFile.text.charCodeAt(whitespaceStart - 1)));
+          recordDelete(whitespaceStart, lineEndPosition + 1 - whitespaceStart);
+        }
       }
-      if (!result[1]) {
-        const span = createTextSpanFromBounds(sourceFile.text.indexOf("//", currentLineStart), lineEnd);
-        regions.push(createOutliningSpan(
-          span,
-          "region" /* Region */,
-          span,
-          /*autoCollapse*/
-          false,
-          result[2] || "#region"
-        ));
-      } else {
-        const region = regions.pop();
-        if (region) {
-          region.textSpan.length = lineEnd - region.textSpan.start;
-          region.hintSpan.length = lineEnd - region.textSpan.start;
-          out.push(region);
+    }
+    function getTrailingWhitespaceStartPosition(start, end) {
+      let pos = end;
+      while (pos >= start && isWhiteSpaceSingleLine(sourceFile.text.charCodeAt(pos))) {
+        pos--;
+      }
+      if (pos !== end) {
+        return pos + 1;
+      }
+      return -1;
+    }
+    function trimTrailingWhitespacesForRemainingRange(trivias) {
+      let startPos = previousRange ? previousRange.end : originalRange.pos;
+      for (const trivia of trivias) {
+        if (isComment(trivia.kind)) {
+          if (startPos < trivia.pos) {
+            trimTrailingWitespacesForPositions(startPos, trivia.pos - 1, previousRange);
+          }
+          startPos = trivia.end + 1;
         }
       }
+      if (startPos < originalRange.end) {
+        trimTrailingWitespacesForPositions(startPos, originalRange.end, previousRange);
+      }
     }
-  }
-  function isRegionDelimiter(lineText) {
-    lineText = trimStringStart(lineText);
-    if (!startsWith(lineText, "//")) {
-      return null;
+    function trimTrailingWitespacesForPositions(startPos, endPos, previousRange2) {
+      const startLine = sourceFile.getLineAndCharacterOfPosition(startPos).line;
+      const endLine = sourceFile.getLineAndCharacterOfPosition(endPos).line;
+      trimTrailingWhitespacesForLines(startLine, endLine + 1, previousRange2);
     }
-    lineText = trimString(lineText.slice(2));
-    return regionDelimiterRegExp.exec(lineText);
-  }
-  function addOutliningForLeadingCommentsForPos(pos, sourceFile, cancellationToken, out) {
-    const comments = getLeadingCommentRanges(sourceFile.text, pos);
-    if (!comments)
-      return;
-    let firstSingleLineCommentStart = -1;
-    let lastSingleLineCommentEnd = -1;
-    let singleLineCommentCount = 0;
-    const sourceText = sourceFile.getFullText();
-    for (const { kind, pos: pos2, end } of comments) {
-      cancellationToken.throwIfCancellationRequested();
-      switch (kind) {
-        case 2 /* SingleLineCommentTrivia */:
-          const commentText = sourceText.slice(pos2, end);
-          if (isRegionDelimiter(commentText)) {
-            combineAndAddMultipleSingleLineComments();
-            singleLineCommentCount = 0;
-            break;
+    function recordDelete(start, len) {
+      if (len) {
+        edits.push(createTextChangeFromStartLength(start, len, ""));
+      }
+    }
+    function recordReplace(start, len, newText) {
+      if (len || newText) {
+        edits.push(createTextChangeFromStartLength(start, len, newText));
+      }
+    }
+    function recordInsert(start, text) {
+      if (text) {
+        edits.push(createTextChangeFromStartLength(start, 0, text));
+      }
+    }
+    function applyRuleEdits(rule2, previousRange2, previousStartLine, currentRange, currentStartLine) {
+      const onLaterLine = currentStartLine !== previousStartLine;
+      switch (rule2.action) {
+        case 1 /* StopProcessingSpaceActions */:
+          return 0 /* None */;
+        case 16 /* DeleteSpace */:
+          if (previousRange2.end !== currentRange.pos) {
+            recordDelete(previousRange2.end, currentRange.pos - previousRange2.end);
+            return onLaterLine ? 2 /* LineRemoved */ : 0 /* None */;
           }
-          if (singleLineCommentCount === 0) {
-            firstSingleLineCommentStart = pos2;
+          break;
+        case 32 /* DeleteToken */:
+          recordDelete(previousRange2.pos, previousRange2.end - previousRange2.pos);
+          break;
+        case 8 /* InsertNewLine */:
+          if (rule2.flags !== 1 /* CanDeleteNewLines */ && previousStartLine !== currentStartLine) {
+            return 0 /* None */;
+          }
+          const lineDelta = currentStartLine - previousStartLine;
+          if (lineDelta !== 1) {
+            recordReplace(previousRange2.end, currentRange.pos - previousRange2.end, getNewLineOrDefaultFromHost(host, options));
+            return onLaterLine ? 0 /* None */ : 1 /* LineAdded */;
           }
-          lastSingleLineCommentEnd = end;
-          singleLineCommentCount++;
           break;
-        case 3 /* MultiLineCommentTrivia */:
-          combineAndAddMultipleSingleLineComments();
-          out.push(createOutliningSpanFromBounds(pos2, end, "comment" /* Comment */));
-          singleLineCommentCount = 0;
+        case 4 /* InsertSpace */:
+          if (rule2.flags !== 1 /* CanDeleteNewLines */ && previousStartLine !== currentStartLine) {
+            return 0 /* None */;
+          }
+          const posDelta = currentRange.pos - previousRange2.end;
+          if (posDelta !== 1 || sourceFile.text.charCodeAt(previousRange2.end) !== 32 /* space */) {
+            recordReplace(previousRange2.end, currentRange.pos - previousRange2.end, " ");
+            return onLaterLine ? 2 /* LineRemoved */ : 0 /* None */;
+          }
           break;
-        default:
-          Debug.assertNever(kind);
-      }
-    }
-    combineAndAddMultipleSingleLineComments();
-    function combineAndAddMultipleSingleLineComments() {
-      if (singleLineCommentCount > 1) {
-        out.push(createOutliningSpanFromBounds(firstSingleLineCommentStart, lastSingleLineCommentEnd, "comment" /* Comment */));
+        case 64 /* InsertTrailingSemicolon */:
+          recordInsert(previousRange2.end, ";");
       }
+      return 0 /* None */;
     }
   }
-  function addOutliningForLeadingCommentsForNode(n, sourceFile, cancellationToken, out) {
-    if (isJsxText(n))
-      return;
-    addOutliningForLeadingCommentsForPos(n.pos, sourceFile, cancellationToken, out);
-  }
-  function createOutliningSpanFromBounds(pos, end, kind) {
-    return createOutliningSpan(createTextSpanFromBounds(pos, end), kind);
+  function getRangeOfEnclosingComment(sourceFile, position, precedingToken, tokenAtPosition = getTokenAtPosition(sourceFile, position)) {
+    const jsdoc = findAncestor(tokenAtPosition, isJSDoc);
+    if (jsdoc)
+      tokenAtPosition = jsdoc.parent;
+    const tokenStart = tokenAtPosition.getStart(sourceFile);
+    if (tokenStart <= position && position < tokenAtPosition.getEnd()) {
+      return void 0;
+    }
+    precedingToken = precedingToken === null ? void 0 : precedingToken === void 0 ? findPrecedingToken(position, sourceFile) : precedingToken;
+    const trailingRangesOfPreviousToken = precedingToken && getTrailingCommentRanges(sourceFile.text, precedingToken.end);
+    const leadingCommentRangesOfNextToken = getLeadingCommentRangesOfNode(tokenAtPosition, sourceFile);
+    const commentRanges = concatenate(trailingRangesOfPreviousToken, leadingCommentRangesOfNextToken);
+    return commentRanges && find(commentRanges, (range) => rangeContainsPositionExclusive(range, position) || // The end marker of a single-line comment does not include the newline character.
+    // With caret at `^`, in the following case, we are inside a comment (^ denotes the cursor position):
+    //
+    //    // asdf   ^\n
+    //
+    // But for closed multi-line comments, we don't want to be inside the comment in the following case:
+    //
+    //    /* asdf */^
+    //
+    // However, unterminated multi-line comments *do* contain their end.
+    //
+    // Internally, we represent the end of the comment at the newline and closing '/', respectively.
+    //
+    position === range.end && (range.kind === 2 /* SingleLineCommentTrivia */ || position === sourceFile.getFullWidth()));
   }
-  function getOutliningSpanForNode(n, sourceFile) {
-    switch (n.kind) {
-      case 240 /* Block */:
-        if (isFunctionLike(n.parent)) {
-          return functionSpan(n.parent, n, sourceFile);
+  function getOpenTokenForList(node, list) {
+    switch (node.kind) {
+      case 176 /* Constructor */:
+      case 262 /* FunctionDeclaration */:
+      case 218 /* FunctionExpression */:
+      case 174 /* MethodDeclaration */:
+      case 173 /* MethodSignature */:
+      case 219 /* ArrowFunction */:
+      case 179 /* CallSignature */:
+      case 180 /* ConstructSignature */:
+      case 184 /* FunctionType */:
+      case 185 /* ConstructorType */:
+      case 177 /* GetAccessor */:
+      case 178 /* SetAccessor */:
+        if (node.typeParameters === list) {
+          return 30 /* LessThanToken */;
+        } else if (node.parameters === list) {
+          return 21 /* OpenParenToken */;
         }
-        switch (n.parent.kind) {
-          case 245 /* DoStatement */:
-          case 248 /* ForInStatement */:
-          case 249 /* ForOfStatement */:
-          case 247 /* ForStatement */:
-          case 244 /* IfStatement */:
-          case 246 /* WhileStatement */:
-          case 253 /* WithStatement */:
-          case 298 /* CatchClause */:
-            return spanForNode(n.parent);
-          case 257 /* TryStatement */:
-            const tryStatement = n.parent;
-            if (tryStatement.tryBlock === n) {
-              return spanForNode(n.parent);
-            } else if (tryStatement.finallyBlock === n) {
-              const node = findChildOfKind(tryStatement, 98 /* FinallyKeyword */, sourceFile);
-              if (node)
-                return spanForNode(node);
-            }
-          default:
-            return createOutliningSpan(createTextSpanFromNode(n, sourceFile), "code" /* Code */);
+        break;
+      case 213 /* CallExpression */:
+      case 214 /* NewExpression */:
+        if (node.typeArguments === list) {
+          return 30 /* LessThanToken */;
+        } else if (node.arguments === list) {
+          return 21 /* OpenParenToken */;
         }
-      case 267 /* ModuleBlock */:
-        return spanForNode(n.parent);
-      case 262 /* ClassDeclaration */:
-      case 230 /* ClassExpression */:
-      case 263 /* InterfaceDeclaration */:
-      case 265 /* EnumDeclaration */:
-      case 268 /* CaseBlock */:
-      case 186 /* TypeLiteral */:
-      case 205 /* ObjectBindingPattern */:
-        return spanForNode(n);
-      case 188 /* TupleType */:
-        return spanForNode(
-          n,
-          /*autoCollapse*/
-          false,
-          /*useFullStart*/
-          !isTupleTypeNode(n.parent),
-          23 /* OpenBracketToken */
-        );
-      case 295 /* CaseClause */:
-      case 296 /* DefaultClause */:
-        return spanForNodeArray(n.statements);
-      case 209 /* ObjectLiteralExpression */:
-        return spanForObjectOrArrayLiteral(n);
-      case 208 /* ArrayLiteralExpression */:
-        return spanForObjectOrArrayLiteral(n, 23 /* OpenBracketToken */);
-      case 283 /* JsxElement */:
-        return spanForJSXElement(n);
-      case 287 /* JsxFragment */:
-        return spanForJSXFragment(n);
-      case 284 /* JsxSelfClosingElement */:
-      case 285 /* JsxOpeningElement */:
-        return spanForJSXAttributes(n.attributes);
-      case 227 /* TemplateExpression */:
-      case 15 /* NoSubstitutionTemplateLiteral */:
-        return spanForTemplateLiteral(n);
-      case 206 /* ArrayBindingPattern */:
-        return spanForNode(
-          n,
-          /*autoCollapse*/
-          false,
-          /*useFullStart*/
-          !isBindingElement(n.parent),
-          23 /* OpenBracketToken */
-        );
-      case 218 /* ArrowFunction */:
-        return spanForArrowFunction(n);
-      case 212 /* CallExpression */:
-        return spanForCallExpression(n);
-      case 216 /* ParenthesizedExpression */:
-        return spanForParenthesizedExpression(n);
-      case 274 /* NamedImports */:
-      case 278 /* NamedExports */:
-      case 299 /* AssertClause */:
-        return spanForNamedImportsOrExportsOrAssertClause(n);
+        break;
+      case 263 /* ClassDeclaration */:
+      case 231 /* ClassExpression */:
+      case 264 /* InterfaceDeclaration */:
+      case 265 /* TypeAliasDeclaration */:
+        if (node.typeParameters === list) {
+          return 30 /* LessThanToken */;
+        }
+        break;
+      case 183 /* TypeReference */:
+      case 215 /* TaggedTemplateExpression */:
+      case 186 /* TypeQuery */:
+      case 233 /* ExpressionWithTypeArguments */:
+      case 205 /* ImportType */:
+        if (node.typeArguments === list) {
+          return 30 /* LessThanToken */;
+        }
+        break;
+      case 187 /* TypeLiteral */:
+        return 19 /* OpenBraceToken */;
     }
-    function spanForNamedImportsOrExportsOrAssertClause(node) {
-      if (!node.elements.length) {
-        return void 0;
-      }
-      const openToken = findChildOfKind(node, 19 /* OpenBraceToken */, sourceFile);
-      const closeToken = findChildOfKind(node, 20 /* CloseBraceToken */, sourceFile);
-      if (!openToken || !closeToken || positionsAreOnSameLine(openToken.pos, closeToken.pos, sourceFile)) {
-        return void 0;
-      }
-      return spanBetweenTokens(
-        openToken,
-        closeToken,
-        node,
-        sourceFile,
-        /*autoCollapse*/
-        false,
-        /*useFullStart*/
-        false
-      );
+    return 0 /* Unknown */;
+  }
+  function getCloseTokenForOpenToken(kind) {
+    switch (kind) {
+      case 21 /* OpenParenToken */:
+        return 22 /* CloseParenToken */;
+      case 30 /* LessThanToken */:
+        return 32 /* GreaterThanToken */;
+      case 19 /* OpenBraceToken */:
+        return 20 /* CloseBraceToken */;
     }
-    function spanForCallExpression(node) {
-      if (!node.arguments.length) {
-        return void 0;
-      }
-      const openToken = findChildOfKind(node, 21 /* OpenParenToken */, sourceFile);
-      const closeToken = findChildOfKind(node, 22 /* CloseParenToken */, sourceFile);
-      if (!openToken || !closeToken || positionsAreOnSameLine(openToken.pos, closeToken.pos, sourceFile)) {
-        return void 0;
-      }
-      return spanBetweenTokens(
-        openToken,
-        closeToken,
-        node,
-        sourceFile,
-        /*autoCollapse*/
-        false,
-        /*useFullStart*/
-        true
-      );
+    return 0 /* Unknown */;
+  }
+  function getIndentationString(indentation, options) {
+    const resetInternedStrings = !internedSizes || (internedSizes.tabSize !== options.tabSize || internedSizes.indentSize !== options.indentSize);
+    if (resetInternedStrings) {
+      internedSizes = { tabSize: options.tabSize, indentSize: options.indentSize };
+      internedTabsIndentation = internedSpacesIndentation = void 0;
     }
-    function spanForArrowFunction(node) {
-      if (isBlock(node.body) || isParenthesizedExpression(node.body) || positionsAreOnSameLine(node.body.getFullStart(), node.body.getEnd(), sourceFile)) {
-        return void 0;
+    if (!options.convertTabsToSpaces) {
+      const tabs = Math.floor(indentation / options.tabSize);
+      const spaces = indentation - tabs * options.tabSize;
+      let tabString;
+      if (!internedTabsIndentation) {
+        internedTabsIndentation = [];
       }
-      const textSpan = createTextSpanFromBounds(node.body.getFullStart(), node.body.getEnd());
-      return createOutliningSpan(textSpan, "code" /* Code */, createTextSpanFromNode(node));
-    }
-    function spanForJSXElement(node) {
-      const textSpan = createTextSpanFromBounds(node.openingElement.getStart(sourceFile), node.closingElement.getEnd());
-      const tagName = node.openingElement.tagName.getText(sourceFile);
-      const bannerText = "<" + tagName + ">...";
-      return createOutliningSpan(
-        textSpan,
-        "code" /* Code */,
-        textSpan,
-        /*autoCollapse*/
-        false,
-        bannerText
-      );
-    }
-    function spanForJSXFragment(node) {
-      const textSpan = createTextSpanFromBounds(node.openingFragment.getStart(sourceFile), node.closingFragment.getEnd());
-      const bannerText = "<>...";
-      return createOutliningSpan(
-        textSpan,
-        "code" /* Code */,
-        textSpan,
-        /*autoCollapse*/
-        false,
-        bannerText
-      );
-    }
-    function spanForJSXAttributes(node) {
-      if (node.properties.length === 0) {
-        return void 0;
+      if (internedTabsIndentation[tabs] === void 0) {
+        internedTabsIndentation[tabs] = tabString = repeatString("	", tabs);
+      } else {
+        tabString = internedTabsIndentation[tabs];
       }
-      return createOutliningSpanFromBounds(node.getStart(sourceFile), node.getEnd(), "code" /* Code */);
-    }
-    function spanForTemplateLiteral(node) {
-      if (node.kind === 15 /* NoSubstitutionTemplateLiteral */ && node.text.length === 0) {
-        return void 0;
+      return spaces ? tabString + repeatString(" ", spaces) : tabString;
+    } else {
+      let spacesString;
+      const quotient = Math.floor(indentation / options.indentSize);
+      const remainder = indentation % options.indentSize;
+      if (!internedSpacesIndentation) {
+        internedSpacesIndentation = [];
       }
-      return createOutliningSpanFromBounds(node.getStart(sourceFile), node.getEnd(), "code" /* Code */);
+      if (internedSpacesIndentation[quotient] === void 0) {
+        spacesString = repeatString(" ", options.indentSize * quotient);
+        internedSpacesIndentation[quotient] = spacesString;
+      } else {
+        spacesString = internedSpacesIndentation[quotient];
+      }
+      return remainder ? spacesString + repeatString(" ", remainder) : spacesString;
     }
-    function spanForObjectOrArrayLiteral(node, open = 19 /* OpenBraceToken */) {
-      return spanForNode(
-        node,
-        /*autoCollapse*/
-        false,
-        /*useFullStart*/
-        !isArrayLiteralExpression(node.parent) && !isCallExpression(node.parent),
-        open
-      );
+  }
+  var internedSizes, internedTabsIndentation, internedSpacesIndentation;
+  var init_formatting = __esm({
+    "src/services/formatting/formatting.ts"() {
+      "use strict";
+      init_ts4();
+      init_ts_formatting();
     }
-    function spanForNode(hintSpanNode, autoCollapse = false, useFullStart = true, open = 19 /* OpenBraceToken */, close = open === 19 /* OpenBraceToken */ ? 20 /* CloseBraceToken */ : 24 /* CloseBracketToken */) {
-      const openToken = findChildOfKind(n, open, sourceFile);
-      const closeToken = findChildOfKind(n, close, sourceFile);
-      return openToken && closeToken && spanBetweenTokens(openToken, closeToken, hintSpanNode, sourceFile, autoCollapse, useFullStart);
+  });
+
+  // src/services/formatting/smartIndenter.ts
+  var SmartIndenter;
+  var init_smartIndenter = __esm({
+    "src/services/formatting/smartIndenter.ts"() {
+      "use strict";
+      init_ts4();
+      init_ts_formatting();
+      ((SmartIndenter2) => {
+        let Value;
+        ((Value2) => {
+          Value2[Value2["Unknown"] = -1] = "Unknown";
+        })(Value || (Value = {}));
+        function getIndentation(position, sourceFile, options, assumeNewLineBeforeCloseBrace = false) {
+          if (position > sourceFile.text.length) {
+            return getBaseIndentation(options);
+          }
+          if (options.indentStyle === 0 /* None */) {
+            return 0;
+          }
+          const precedingToken = findPrecedingToken(
+            position,
+            sourceFile,
+            /*startNode*/
+            void 0,
+            /*excludeJsdoc*/
+            true
+          );
+          const enclosingCommentRange = getRangeOfEnclosingComment(sourceFile, position, precedingToken || null);
+          if (enclosingCommentRange && enclosingCommentRange.kind === 3 /* MultiLineCommentTrivia */) {
+            return getCommentIndent(sourceFile, position, options, enclosingCommentRange);
+          }
+          if (!precedingToken) {
+            return getBaseIndentation(options);
+          }
+          const precedingTokenIsLiteral = isStringOrRegularExpressionOrTemplateLiteral(precedingToken.kind);
+          if (precedingTokenIsLiteral && precedingToken.getStart(sourceFile) <= position && position < precedingToken.end) {
+            return 0;
+          }
+          const lineAtPosition = sourceFile.getLineAndCharacterOfPosition(position).line;
+          const currentToken = getTokenAtPosition(sourceFile, position);
+          const isObjectLiteral = currentToken.kind === 19 /* OpenBraceToken */ && currentToken.parent.kind === 210 /* ObjectLiteralExpression */;
+          if (options.indentStyle === 1 /* Block */ || isObjectLiteral) {
+            return getBlockIndent(sourceFile, position, options);
+          }
+          if (precedingToken.kind === 28 /* CommaToken */ && precedingToken.parent.kind !== 226 /* BinaryExpression */) {
+            const actualIndentation = getActualIndentationForListItemBeforeComma(precedingToken, sourceFile, options);
+            if (actualIndentation !== -1 /* Unknown */) {
+              return actualIndentation;
+            }
+          }
+          const containerList = getListByPosition(position, precedingToken.parent, sourceFile);
+          if (containerList && !rangeContainsRange(containerList, precedingToken)) {
+            const useTheSameBaseIndentation = [218 /* FunctionExpression */, 219 /* ArrowFunction */].includes(currentToken.parent.kind);
+            const indentSize = useTheSameBaseIndentation ? 0 : options.indentSize;
+            return getActualIndentationForListStartLine(containerList, sourceFile, options) + indentSize;
+          }
+          return getSmartIndent(sourceFile, position, precedingToken, lineAtPosition, assumeNewLineBeforeCloseBrace, options);
+        }
+        SmartIndenter2.getIndentation = getIndentation;
+        function getCommentIndent(sourceFile, position, options, enclosingCommentRange) {
+          const previousLine = getLineAndCharacterOfPosition(sourceFile, position).line - 1;
+          const commentStartLine = getLineAndCharacterOfPosition(sourceFile, enclosingCommentRange.pos).line;
+          Debug.assert(commentStartLine >= 0);
+          if (previousLine <= commentStartLine) {
+            return findFirstNonWhitespaceColumn(getStartPositionOfLine(commentStartLine, sourceFile), position, sourceFile, options);
+          }
+          const startPositionOfLine = getStartPositionOfLine(previousLine, sourceFile);
+          const { column, character } = findFirstNonWhitespaceCharacterAndColumn(startPositionOfLine, position, sourceFile, options);
+          if (column === 0) {
+            return column;
+          }
+          const firstNonWhitespaceCharacterCode = sourceFile.text.charCodeAt(startPositionOfLine + character);
+          return firstNonWhitespaceCharacterCode === 42 /* asterisk */ ? column - 1 : column;
+        }
+        function getBlockIndent(sourceFile, position, options) {
+          let current = position;
+          while (current > 0) {
+            const char = sourceFile.text.charCodeAt(current);
+            if (!isWhiteSpaceLike(char)) {
+              break;
+            }
+            current--;
+          }
+          const lineStart = getLineStartPositionForPosition(current, sourceFile);
+          return findFirstNonWhitespaceColumn(lineStart, current, sourceFile, options);
+        }
+        function getSmartIndent(sourceFile, position, precedingToken, lineAtPosition, assumeNewLineBeforeCloseBrace, options) {
+          let previous;
+          let current = precedingToken;
+          while (current) {
+            if (positionBelongsToNode(current, position, sourceFile) && shouldIndentChildNode(
+              options,
+              current,
+              previous,
+              sourceFile,
+              /*isNextChild*/
+              true
+            )) {
+              const currentStart = getStartLineAndCharacterForNode(current, sourceFile);
+              const nextTokenKind = nextTokenIsCurlyBraceOnSameLineAsCursor(precedingToken, current, lineAtPosition, sourceFile);
+              const indentationDelta = nextTokenKind !== 0 /* Unknown */ ? assumeNewLineBeforeCloseBrace && nextTokenKind === 2 /* CloseBrace */ ? options.indentSize : 0 : lineAtPosition !== currentStart.line ? options.indentSize : 0;
+              return getIndentationForNodeWorker(
+                current,
+                currentStart,
+                /*ignoreActualIndentationRange*/
+                void 0,
+                indentationDelta,
+                sourceFile,
+                /*isNextChild*/
+                true,
+                options
+              );
+            }
+            const actualIndentation = getActualIndentationForListItem(
+              current,
+              sourceFile,
+              options,
+              /*listIndentsChild*/
+              true
+            );
+            if (actualIndentation !== -1 /* Unknown */) {
+              return actualIndentation;
+            }
+            previous = current;
+            current = current.parent;
+          }
+          return getBaseIndentation(options);
+        }
+        function getIndentationForNode(n, ignoreActualIndentationRange, sourceFile, options) {
+          const start = sourceFile.getLineAndCharacterOfPosition(n.getStart(sourceFile));
+          return getIndentationForNodeWorker(
+            n,
+            start,
+            ignoreActualIndentationRange,
+            /*indentationDelta*/
+            0,
+            sourceFile,
+            /*isNextChild*/
+            false,
+            options
+          );
+        }
+        SmartIndenter2.getIndentationForNode = getIndentationForNode;
+        function getBaseIndentation(options) {
+          return options.baseIndentSize || 0;
+        }
+        SmartIndenter2.getBaseIndentation = getBaseIndentation;
+        function getIndentationForNodeWorker(current, currentStart, ignoreActualIndentationRange, indentationDelta, sourceFile, isNextChild, options) {
+          var _a;
+          let parent2 = current.parent;
+          while (parent2) {
+            let useActualIndentation = true;
+            if (ignoreActualIndentationRange) {
+              const start = current.getStart(sourceFile);
+              useActualIndentation = start < ignoreActualIndentationRange.pos || start > ignoreActualIndentationRange.end;
+            }
+            const containingListOrParentStart = getContainingListOrParentStart(parent2, current, sourceFile);
+            const parentAndChildShareLine = containingListOrParentStart.line === currentStart.line || childStartsOnTheSameLineWithElseInIfStatement(parent2, current, currentStart.line, sourceFile);
+            if (useActualIndentation) {
+              const firstListChild = (_a = getContainingList(current, sourceFile)) == null ? void 0 : _a[0];
+              const listIndentsChild = !!firstListChild && getStartLineAndCharacterForNode(firstListChild, sourceFile).line > containingListOrParentStart.line;
+              let actualIndentation = getActualIndentationForListItem(current, sourceFile, options, listIndentsChild);
+              if (actualIndentation !== -1 /* Unknown */) {
+                return actualIndentation + indentationDelta;
+              }
+              actualIndentation = getActualIndentationForNode(current, parent2, currentStart, parentAndChildShareLine, sourceFile, options);
+              if (actualIndentation !== -1 /* Unknown */) {
+                return actualIndentation + indentationDelta;
+              }
+            }
+            if (shouldIndentChildNode(options, parent2, current, sourceFile, isNextChild) && !parentAndChildShareLine) {
+              indentationDelta += options.indentSize;
+            }
+            const useTrueStart = isArgumentAndStartLineOverlapsExpressionBeingCalled(parent2, current, currentStart.line, sourceFile);
+            current = parent2;
+            parent2 = current.parent;
+            currentStart = useTrueStart ? sourceFile.getLineAndCharacterOfPosition(current.getStart(sourceFile)) : containingListOrParentStart;
+          }
+          return indentationDelta + getBaseIndentation(options);
+        }
+        function getContainingListOrParentStart(parent2, child, sourceFile) {
+          const containingList = getContainingList(child, sourceFile);
+          const startPos = containingList ? containingList.pos : parent2.getStart(sourceFile);
+          return sourceFile.getLineAndCharacterOfPosition(startPos);
+        }
+        function getActualIndentationForListItemBeforeComma(commaToken, sourceFile, options) {
+          const commaItemInfo = findListItemInfo(commaToken);
+          if (commaItemInfo && commaItemInfo.listItemIndex > 0) {
+            return deriveActualIndentationFromList(commaItemInfo.list.getChildren(), commaItemInfo.listItemIndex - 1, sourceFile, options);
+          } else {
+            return -1 /* Unknown */;
+          }
+        }
+        function getActualIndentationForNode(current, parent2, currentLineAndChar, parentAndChildShareLine, sourceFile, options) {
+          const useActualIndentation = (isDeclaration(current) || isStatementButNotDeclaration(current)) && (parent2.kind === 312 /* SourceFile */ || !parentAndChildShareLine);
+          if (!useActualIndentation) {
+            return -1 /* Unknown */;
+          }
+          return findColumnForFirstNonWhitespaceCharacterInLine(currentLineAndChar, sourceFile, options);
+        }
+        let NextTokenKind;
+        ((NextTokenKind2) => {
+          NextTokenKind2[NextTokenKind2["Unknown"] = 0] = "Unknown";
+          NextTokenKind2[NextTokenKind2["OpenBrace"] = 1] = "OpenBrace";
+          NextTokenKind2[NextTokenKind2["CloseBrace"] = 2] = "CloseBrace";
+        })(NextTokenKind || (NextTokenKind = {}));
+        function nextTokenIsCurlyBraceOnSameLineAsCursor(precedingToken, current, lineAtPosition, sourceFile) {
+          const nextToken = findNextToken(precedingToken, current, sourceFile);
+          if (!nextToken) {
+            return 0 /* Unknown */;
+          }
+          if (nextToken.kind === 19 /* OpenBraceToken */) {
+            return 1 /* OpenBrace */;
+          } else if (nextToken.kind === 20 /* CloseBraceToken */) {
+            const nextTokenStartLine = getStartLineAndCharacterForNode(nextToken, sourceFile).line;
+            return lineAtPosition === nextTokenStartLine ? 2 /* CloseBrace */ : 0 /* Unknown */;
+          }
+          return 0 /* Unknown */;
+        }
+        function getStartLineAndCharacterForNode(n, sourceFile) {
+          return sourceFile.getLineAndCharacterOfPosition(n.getStart(sourceFile));
+        }
+        function isArgumentAndStartLineOverlapsExpressionBeingCalled(parent2, child, childStartLine, sourceFile) {
+          if (!(isCallExpression(parent2) && contains(parent2.arguments, child))) {
+            return false;
+          }
+          const expressionOfCallExpressionEnd = parent2.expression.getEnd();
+          const expressionOfCallExpressionEndLine = getLineAndCharacterOfPosition(sourceFile, expressionOfCallExpressionEnd).line;
+          return expressionOfCallExpressionEndLine === childStartLine;
+        }
+        SmartIndenter2.isArgumentAndStartLineOverlapsExpressionBeingCalled = isArgumentAndStartLineOverlapsExpressionBeingCalled;
+        function childStartsOnTheSameLineWithElseInIfStatement(parent2, child, childStartLine, sourceFile) {
+          if (parent2.kind === 245 /* IfStatement */ && parent2.elseStatement === child) {
+            const elseKeyword = findChildOfKind(parent2, 93 /* ElseKeyword */, sourceFile);
+            Debug.assert(elseKeyword !== void 0);
+            const elseKeywordStartLine = getStartLineAndCharacterForNode(elseKeyword, sourceFile).line;
+            return elseKeywordStartLine === childStartLine;
+          }
+          return false;
+        }
+        SmartIndenter2.childStartsOnTheSameLineWithElseInIfStatement = childStartsOnTheSameLineWithElseInIfStatement;
+        function childIsUnindentedBranchOfConditionalExpression(parent2, child, childStartLine, sourceFile) {
+          if (isConditionalExpression(parent2) && (child === parent2.whenTrue || child === parent2.whenFalse)) {
+            const conditionEndLine = getLineAndCharacterOfPosition(sourceFile, parent2.condition.end).line;
+            if (child === parent2.whenTrue) {
+              return childStartLine === conditionEndLine;
+            } else {
+              const trueStartLine = getStartLineAndCharacterForNode(parent2.whenTrue, sourceFile).line;
+              const trueEndLine = getLineAndCharacterOfPosition(sourceFile, parent2.whenTrue.end).line;
+              return conditionEndLine === trueStartLine && trueEndLine === childStartLine;
+            }
+          }
+          return false;
+        }
+        SmartIndenter2.childIsUnindentedBranchOfConditionalExpression = childIsUnindentedBranchOfConditionalExpression;
+        function argumentStartsOnSameLineAsPreviousArgument(parent2, child, childStartLine, sourceFile) {
+          if (isCallOrNewExpression(parent2)) {
+            if (!parent2.arguments)
+              return false;
+            const currentNode = find(parent2.arguments, (arg) => arg.pos === child.pos);
+            if (!currentNode)
+              return false;
+            const currentIndex = parent2.arguments.indexOf(currentNode);
+            if (currentIndex === 0)
+              return false;
+            const previousNode = parent2.arguments[currentIndex - 1];
+            const lineOfPreviousNode = getLineAndCharacterOfPosition(sourceFile, previousNode.getEnd()).line;
+            if (childStartLine === lineOfPreviousNode) {
+              return true;
+            }
+          }
+          return false;
+        }
+        SmartIndenter2.argumentStartsOnSameLineAsPreviousArgument = argumentStartsOnSameLineAsPreviousArgument;
+        function getContainingList(node, sourceFile) {
+          return node.parent && getListByRange(node.getStart(sourceFile), node.getEnd(), node.parent, sourceFile);
+        }
+        SmartIndenter2.getContainingList = getContainingList;
+        function getListByPosition(pos, node, sourceFile) {
+          return node && getListByRange(pos, pos, node, sourceFile);
+        }
+        function getListByRange(start, end, node, sourceFile) {
+          switch (node.kind) {
+            case 183 /* TypeReference */:
+              return getList(node.typeArguments);
+            case 210 /* ObjectLiteralExpression */:
+              return getList(node.properties);
+            case 209 /* ArrayLiteralExpression */:
+              return getList(node.elements);
+            case 187 /* TypeLiteral */:
+              return getList(node.members);
+            case 262 /* FunctionDeclaration */:
+            case 218 /* FunctionExpression */:
+            case 219 /* ArrowFunction */:
+            case 174 /* MethodDeclaration */:
+            case 173 /* MethodSignature */:
+            case 179 /* CallSignature */:
+            case 176 /* Constructor */:
+            case 185 /* ConstructorType */:
+            case 180 /* ConstructSignature */:
+              return getList(node.typeParameters) || getList(node.parameters);
+            case 177 /* GetAccessor */:
+              return getList(node.parameters);
+            case 263 /* ClassDeclaration */:
+            case 231 /* ClassExpression */:
+            case 264 /* InterfaceDeclaration */:
+            case 265 /* TypeAliasDeclaration */:
+            case 352 /* JSDocTemplateTag */:
+              return getList(node.typeParameters);
+            case 214 /* NewExpression */:
+            case 213 /* CallExpression */:
+              return getList(node.typeArguments) || getList(node.arguments);
+            case 261 /* VariableDeclarationList */:
+              return getList(node.declarations);
+            case 275 /* NamedImports */:
+            case 279 /* NamedExports */:
+              return getList(node.elements);
+            case 206 /* ObjectBindingPattern */:
+            case 207 /* ArrayBindingPattern */:
+              return getList(node.elements);
+          }
+          function getList(list) {
+            return list && rangeContainsStartEnd(getVisualListRange(node, list, sourceFile), start, end) ? list : void 0;
+          }
+        }
+        function getVisualListRange(node, list, sourceFile) {
+          const children = node.getChildren(sourceFile);
+          for (let i = 1; i < children.length - 1; i++) {
+            if (children[i].pos === list.pos && children[i].end === list.end) {
+              return { pos: children[i - 1].end, end: children[i + 1].getStart(sourceFile) };
+            }
+          }
+          return list;
+        }
+        function getActualIndentationForListStartLine(list, sourceFile, options) {
+          if (!list) {
+            return -1 /* Unknown */;
+          }
+          return findColumnForFirstNonWhitespaceCharacterInLine(sourceFile.getLineAndCharacterOfPosition(list.pos), sourceFile, options);
+        }
+        function getActualIndentationForListItem(node, sourceFile, options, listIndentsChild) {
+          if (node.parent && node.parent.kind === 261 /* VariableDeclarationList */) {
+            return -1 /* Unknown */;
+          }
+          const containingList = getContainingList(node, sourceFile);
+          if (containingList) {
+            const index = containingList.indexOf(node);
+            if (index !== -1) {
+              const result = deriveActualIndentationFromList(containingList, index, sourceFile, options);
+              if (result !== -1 /* Unknown */) {
+                return result;
+              }
+            }
+            return getActualIndentationForListStartLine(containingList, sourceFile, options) + (listIndentsChild ? options.indentSize : 0);
+          }
+          return -1 /* Unknown */;
+        }
+        function deriveActualIndentationFromList(list, index, sourceFile, options) {
+          Debug.assert(index >= 0 && index < list.length);
+          const node = list[index];
+          let lineAndCharacter = getStartLineAndCharacterForNode(node, sourceFile);
+          for (let i = index - 1; i >= 0; i--) {
+            if (list[i].kind === 28 /* CommaToken */) {
+              continue;
+            }
+            const prevEndLine = sourceFile.getLineAndCharacterOfPosition(list[i].end).line;
+            if (prevEndLine !== lineAndCharacter.line) {
+              return findColumnForFirstNonWhitespaceCharacterInLine(lineAndCharacter, sourceFile, options);
+            }
+            lineAndCharacter = getStartLineAndCharacterForNode(list[i], sourceFile);
+          }
+          return -1 /* Unknown */;
+        }
+        function findColumnForFirstNonWhitespaceCharacterInLine(lineAndCharacter, sourceFile, options) {
+          const lineStart = sourceFile.getPositionOfLineAndCharacter(lineAndCharacter.line, 0);
+          return findFirstNonWhitespaceColumn(lineStart, lineStart + lineAndCharacter.character, sourceFile, options);
+        }
+        function findFirstNonWhitespaceCharacterAndColumn(startPos, endPos, sourceFile, options) {
+          let character = 0;
+          let column = 0;
+          for (let pos = startPos; pos < endPos; pos++) {
+            const ch = sourceFile.text.charCodeAt(pos);
+            if (!isWhiteSpaceSingleLine(ch)) {
+              break;
+            }
+            if (ch === 9 /* tab */) {
+              column += options.tabSize + column % options.tabSize;
+            } else {
+              column++;
+            }
+            character++;
+          }
+          return { column, character };
+        }
+        SmartIndenter2.findFirstNonWhitespaceCharacterAndColumn = findFirstNonWhitespaceCharacterAndColumn;
+        function findFirstNonWhitespaceColumn(startPos, endPos, sourceFile, options) {
+          return findFirstNonWhitespaceCharacterAndColumn(startPos, endPos, sourceFile, options).column;
+        }
+        SmartIndenter2.findFirstNonWhitespaceColumn = findFirstNonWhitespaceColumn;
+        function nodeWillIndentChild(settings, parent2, child, sourceFile, indentByDefault) {
+          const childKind = child ? child.kind : 0 /* Unknown */;
+          switch (parent2.kind) {
+            case 244 /* ExpressionStatement */:
+            case 263 /* ClassDeclaration */:
+            case 231 /* ClassExpression */:
+            case 264 /* InterfaceDeclaration */:
+            case 266 /* EnumDeclaration */:
+            case 265 /* TypeAliasDeclaration */:
+            case 209 /* ArrayLiteralExpression */:
+            case 241 /* Block */:
+            case 268 /* ModuleBlock */:
+            case 210 /* ObjectLiteralExpression */:
+            case 187 /* TypeLiteral */:
+            case 200 /* MappedType */:
+            case 189 /* TupleType */:
+            case 217 /* ParenthesizedExpression */:
+            case 211 /* PropertyAccessExpression */:
+            case 213 /* CallExpression */:
+            case 214 /* NewExpression */:
+            case 243 /* VariableStatement */:
+            case 277 /* ExportAssignment */:
+            case 253 /* ReturnStatement */:
+            case 227 /* ConditionalExpression */:
+            case 207 /* ArrayBindingPattern */:
+            case 206 /* ObjectBindingPattern */:
+            case 286 /* JsxOpeningElement */:
+            case 289 /* JsxOpeningFragment */:
+            case 285 /* JsxSelfClosingElement */:
+            case 294 /* JsxExpression */:
+            case 173 /* MethodSignature */:
+            case 179 /* CallSignature */:
+            case 180 /* ConstructSignature */:
+            case 169 /* Parameter */:
+            case 184 /* FunctionType */:
+            case 185 /* ConstructorType */:
+            case 196 /* ParenthesizedType */:
+            case 215 /* TaggedTemplateExpression */:
+            case 223 /* AwaitExpression */:
+            case 279 /* NamedExports */:
+            case 275 /* NamedImports */:
+            case 281 /* ExportSpecifier */:
+            case 276 /* ImportSpecifier */:
+            case 172 /* PropertyDeclaration */:
+            case 296 /* CaseClause */:
+            case 297 /* DefaultClause */:
+              return true;
+            case 269 /* CaseBlock */:
+              return settings.indentSwitchCase ?? true;
+            case 260 /* VariableDeclaration */:
+            case 303 /* PropertyAssignment */:
+            case 226 /* BinaryExpression */:
+              if (!settings.indentMultiLineObjectLiteralBeginningOnBlankLine && sourceFile && childKind === 210 /* ObjectLiteralExpression */) {
+                return rangeIsOnOneLine(sourceFile, child);
+              }
+              if (parent2.kind === 226 /* BinaryExpression */ && sourceFile && child && childKind === 284 /* JsxElement */) {
+                const parentStartLine = sourceFile.getLineAndCharacterOfPosition(skipTrivia(sourceFile.text, parent2.pos)).line;
+                const childStartLine = sourceFile.getLineAndCharacterOfPosition(skipTrivia(sourceFile.text, child.pos)).line;
+                return parentStartLine !== childStartLine;
+              }
+              if (parent2.kind !== 226 /* BinaryExpression */) {
+                return true;
+              }
+              break;
+            case 246 /* DoStatement */:
+            case 247 /* WhileStatement */:
+            case 249 /* ForInStatement */:
+            case 250 /* ForOfStatement */:
+            case 248 /* ForStatement */:
+            case 245 /* IfStatement */:
+            case 262 /* FunctionDeclaration */:
+            case 218 /* FunctionExpression */:
+            case 174 /* MethodDeclaration */:
+            case 176 /* Constructor */:
+            case 177 /* GetAccessor */:
+            case 178 /* SetAccessor */:
+              return childKind !== 241 /* Block */;
+            case 219 /* ArrowFunction */:
+              if (sourceFile && childKind === 217 /* ParenthesizedExpression */) {
+                return rangeIsOnOneLine(sourceFile, child);
+              }
+              return childKind !== 241 /* Block */;
+            case 278 /* ExportDeclaration */:
+              return childKind !== 279 /* NamedExports */;
+            case 272 /* ImportDeclaration */:
+              return childKind !== 273 /* ImportClause */ || !!child.namedBindings && child.namedBindings.kind !== 275 /* NamedImports */;
+            case 284 /* JsxElement */:
+              return childKind !== 287 /* JsxClosingElement */;
+            case 288 /* JsxFragment */:
+              return childKind !== 290 /* JsxClosingFragment */;
+            case 193 /* IntersectionType */:
+            case 192 /* UnionType */:
+              if (childKind === 187 /* TypeLiteral */ || childKind === 189 /* TupleType */) {
+                return false;
+              }
+              break;
+          }
+          return indentByDefault;
+        }
+        SmartIndenter2.nodeWillIndentChild = nodeWillIndentChild;
+        function isControlFlowEndingStatement(kind, parent2) {
+          switch (kind) {
+            case 253 /* ReturnStatement */:
+            case 257 /* ThrowStatement */:
+            case 251 /* ContinueStatement */:
+            case 252 /* BreakStatement */:
+              return parent2.kind !== 241 /* Block */;
+            default:
+              return false;
+          }
+        }
+        function shouldIndentChildNode(settings, parent2, child, sourceFile, isNextChild = false) {
+          return nodeWillIndentChild(
+            settings,
+            parent2,
+            child,
+            sourceFile,
+            /*indentByDefault*/
+            false
+          ) && !(isNextChild && child && isControlFlowEndingStatement(child.kind, parent2));
+        }
+        SmartIndenter2.shouldIndentChildNode = shouldIndentChildNode;
+        function rangeIsOnOneLine(sourceFile, range) {
+          const rangeStart = skipTrivia(sourceFile.text, range.pos);
+          const startLine = sourceFile.getLineAndCharacterOfPosition(rangeStart).line;
+          const endLine = sourceFile.getLineAndCharacterOfPosition(range.end).line;
+          return startLine === endLine;
+        }
+      })(SmartIndenter || (SmartIndenter = {}));
     }
-    function spanForNodeArray(nodeArray) {
-      return nodeArray.length ? createOutliningSpan(createTextSpanFromRange(nodeArray), "code" /* Code */) : void 0;
+  });
+
+  // src/services/_namespaces/ts.formatting.ts
+  var ts_formatting_exports = {};
+  __export(ts_formatting_exports, {
+    FormattingContext: () => FormattingContext,
+    FormattingRequestKind: () => FormattingRequestKind,
+    RuleAction: () => RuleAction,
+    RuleFlags: () => RuleFlags,
+    SmartIndenter: () => SmartIndenter,
+    anyContext: () => anyContext,
+    createTextRangeWithKind: () => createTextRangeWithKind,
+    formatDocument: () => formatDocument,
+    formatNodeGivenIndentation: () => formatNodeGivenIndentation,
+    formatOnClosingCurly: () => formatOnClosingCurly,
+    formatOnEnter: () => formatOnEnter,
+    formatOnOpeningCurly: () => formatOnOpeningCurly,
+    formatOnSemicolon: () => formatOnSemicolon,
+    formatSelection: () => formatSelection,
+    getAllRules: () => getAllRules,
+    getFormatContext: () => getFormatContext,
+    getFormattingScanner: () => getFormattingScanner,
+    getIndentationString: () => getIndentationString,
+    getRangeOfEnclosingComment: () => getRangeOfEnclosingComment
+  });
+  var init_ts_formatting = __esm({
+    "src/services/_namespaces/ts.formatting.ts"() {
+      "use strict";
+      init_formattingContext();
+      init_formattingScanner();
+      init_rule();
+      init_rules();
+      init_rulesMap();
+      init_formatting();
+      init_smartIndenter();
     }
-    function spanForParenthesizedExpression(node) {
-      if (positionsAreOnSameLine(node.getStart(), node.getEnd(), sourceFile))
-        return void 0;
-      const textSpan = createTextSpanFromBounds(node.getStart(), node.getEnd());
-      return createOutliningSpan(textSpan, "code" /* Code */, createTextSpanFromNode(node));
+  });
+
+  // src/services/_namespaces/ts.ts
+  var init_ts4 = __esm({
+    "src/services/_namespaces/ts.ts"() {
+      "use strict";
+      init_ts2();
+      init_ts3();
+      init_types3();
+      init_utilities4();
+      init_exportInfoMap();
+      init_classifier();
+      init_documentHighlights();
+      init_documentRegistry();
+      init_getEditsForFileRename();
+      init_patternMatcher();
+      init_preProcess();
+      init_sourcemaps();
+      init_suggestionDiagnostics();
+      init_transpile();
+      init_services();
+      init_transform();
+      init_ts_BreakpointResolver();
+      init_ts_CallHierarchy();
+      init_ts_classifier();
+      init_ts_codefix();
+      init_ts_Completions();
+      init_ts_FindAllReferences();
+      init_ts_GoToDefinition();
+      init_ts_InlayHints();
+      init_ts_JsDoc();
+      init_ts_NavigateTo();
+      init_ts_NavigationBar();
+      init_ts_OrganizeImports();
+      init_ts_OutliningElementsCollector();
+      init_ts_refactor();
+      init_ts_Rename();
+      init_ts_SignatureHelp();
+      init_ts_SmartSelectionRange();
+      init_ts_SymbolDisplay();
+      init_ts_textChanges();
+      init_ts_formatting();
     }
+  });
+
+  // src/deprecatedCompat/deprecate.ts
+  function getTypeScriptVersion() {
+    return typeScriptVersion2 ?? (typeScriptVersion2 = new Version(version));
   }
-  function functionSpan(node, body, sourceFile) {
-    const openToken = tryGetFunctionOpenToken(node, body, sourceFile);
-    const closeToken = findChildOfKind(body, 20 /* CloseBraceToken */, sourceFile);
-    return openToken && closeToken && spanBetweenTokens(
-      openToken,
-      closeToken,
-      node,
-      sourceFile,
-      /*autoCollapse*/
-      node.kind !== 218 /* ArrowFunction */
+  function formatDeprecationMessage(name, error2, errorAfter, since, message) {
+    let deprecationMessage = error2 ? "DeprecationError: " : "DeprecationWarning: ";
+    deprecationMessage += `'${name}' `;
+    deprecationMessage += since ? `has been deprecated since v${since}` : "is deprecated";
+    deprecationMessage += error2 ? " and can no longer be used." : errorAfter ? ` and will no longer be usable after v${errorAfter}.` : ".";
+    deprecationMessage += message ? ` ${formatStringFromArgs(message, [name])}` : "";
+    return deprecationMessage;
+  }
+  function createErrorDeprecation(name, errorAfter, since, message) {
+    const deprecationMessage = formatDeprecationMessage(
+      name,
+      /*error*/
+      true,
+      errorAfter,
+      since,
+      message
     );
+    return () => {
+      throw new TypeError(deprecationMessage);
+    };
   }
-  function spanBetweenTokens(openToken, closeToken, hintSpanNode, sourceFile, autoCollapse = false, useFullStart = true) {
-    const textSpan = createTextSpanFromBounds(useFullStart ? openToken.getFullStart() : openToken.getStart(sourceFile), closeToken.getEnd());
-    return createOutliningSpan(textSpan, "code" /* Code */, createTextSpanFromNode(hintSpanNode, sourceFile), autoCollapse);
+  function createWarningDeprecation(name, errorAfter, since, message) {
+    let hasWrittenDeprecation = false;
+    return () => {
+      if (enableDeprecationWarnings && !hasWrittenDeprecation) {
+        Debug.log.warn(formatDeprecationMessage(
+          name,
+          /*error*/
+          false,
+          errorAfter,
+          since,
+          message
+        ));
+        hasWrittenDeprecation = true;
+      }
+    };
+  }
+  function createDeprecation(name, options = {}) {
+    const version2 = typeof options.typeScriptVersion === "string" ? new Version(options.typeScriptVersion) : options.typeScriptVersion ?? getTypeScriptVersion();
+    const errorAfter = typeof options.errorAfter === "string" ? new Version(options.errorAfter) : options.errorAfter;
+    const warnAfter = typeof options.warnAfter === "string" ? new Version(options.warnAfter) : options.warnAfter;
+    const since = typeof options.since === "string" ? new Version(options.since) : options.since ?? warnAfter;
+    const error2 = options.error || errorAfter && version2.compareTo(errorAfter) >= 0;
+    const warn = !warnAfter || version2.compareTo(warnAfter) >= 0;
+    return error2 ? createErrorDeprecation(name, errorAfter, since, options.message) : warn ? createWarningDeprecation(name, errorAfter, since, options.message) : noop;
   }
-  function createOutliningSpan(textSpan, kind, hintSpan = textSpan, autoCollapse = false, bannerText = "...") {
-    return { textSpan, kind, hintSpan, bannerText, autoCollapse };
+  function wrapFunction(deprecation, func) {
+    return function() {
+      deprecation();
+      return func.apply(this, arguments);
+    };
   }
-  function tryGetFunctionOpenToken(node, body, sourceFile) {
-    if (isNodeArrayMultiLine(node.parameters, sourceFile)) {
-      const openParenToken = findChildOfKind(node, 21 /* OpenParenToken */, sourceFile);
-      if (openParenToken) {
-        return openParenToken;
-      }
-    }
-    return findChildOfKind(body, 19 /* OpenBraceToken */, sourceFile);
+  function deprecate(func, options) {
+    const deprecation = createDeprecation((options == null ? void 0 : options.name) ?? Debug.getFunctionName(func), options);
+    return wrapFunction(deprecation, func);
   }
-  var regionDelimiterRegExp;
-  var init_outliningElementsCollector = __esm({
-    "src/services/outliningElementsCollector.ts"() {
-      "use strict";
-      init_ts4();
-      regionDelimiterRegExp = /^#(end)?region(?:\s+(.*))?(?:\r)?$/;
-    }
-  });
-
-  // src/services/_namespaces/ts.OutliningElementsCollector.ts
-  var ts_OutliningElementsCollector_exports = {};
-  __export(ts_OutliningElementsCollector_exports, {
-    collectElements: () => collectElements
-  });
-  var init_ts_OutliningElementsCollector = __esm({
-    "src/services/_namespaces/ts.OutliningElementsCollector.ts"() {
+  var enableDeprecationWarnings, typeScriptVersion2;
+  var init_deprecate = __esm({
+    "src/deprecatedCompat/deprecate.ts"() {
       "use strict";
-      init_outliningElementsCollector();
+      init_ts5();
+      enableDeprecationWarnings = true;
     }
   });
 
-  // src/services/rename.ts
-  function getRenameInfo(program, sourceFile, position, preferences) {
-    const node = getAdjustedRenameLocation(getTouchingPropertyName(sourceFile, position));
-    if (nodeIsEligibleForRename(node)) {
-      const renameInfo = getRenameInfoForNode(node, program.getTypeChecker(), sourceFile, program, preferences);
-      if (renameInfo) {
-        return renameInfo;
-      }
-    }
-    return getRenameInfoError(Diagnostics.You_cannot_rename_this_element);
-  }
-  function getRenameInfoForNode(node, typeChecker, sourceFile, program, preferences) {
-    const symbol = typeChecker.getSymbolAtLocation(node);
-    if (!symbol) {
-      if (isStringLiteralLike(node)) {
-        const type = getContextualTypeFromParentOrAncestorTypeNode(node, typeChecker);
-        if (type && (type.flags & 128 /* StringLiteral */ || type.flags & 1048576 /* Union */ && every(type.types, (type2) => !!(type2.flags & 128 /* StringLiteral */)))) {
-          return getRenameInfoSuccess(node.text, node.text, "string" /* string */, "", node, sourceFile);
+  // src/deprecatedCompat/deprecations.ts
+  function createOverload(name, overloads, binder2, deprecations) {
+    Object.defineProperty(call, "name", { ...Object.getOwnPropertyDescriptor(call, "name"), value: name });
+    if (deprecations) {
+      for (const key of Object.keys(deprecations)) {
+        const index = +key;
+        if (!isNaN(index) && hasProperty(overloads, `${index}`)) {
+          overloads[index] = deprecate(overloads[index], { ...deprecations[index], name });
         }
-      } else if (isLabelName(node)) {
-        const name = getTextOfNode(node);
-        return getRenameInfoSuccess(name, name, "label" /* label */, "" /* none */, node, sourceFile);
-      }
-      return void 0;
-    }
-    const { declarations } = symbol;
-    if (!declarations || declarations.length === 0)
-      return;
-    if (declarations.some((declaration) => isDefinedInLibraryFile(program, declaration))) {
-      return getRenameInfoError(Diagnostics.You_cannot_rename_elements_that_are_defined_in_the_standard_TypeScript_library);
-    }
-    if (isIdentifier(node) && node.escapedText === "default" && symbol.parent && symbol.parent.flags & 1536 /* Module */) {
-      return void 0;
-    }
-    if (isStringLiteralLike(node) && tryGetImportFromModuleSpecifier(node)) {
-      return preferences.allowRenameOfImportPath ? getRenameInfoForModule(node, sourceFile, symbol) : void 0;
-    }
-    const wouldRenameNodeModules = wouldRenameInOtherNodeModules(sourceFile, symbol, typeChecker, preferences);
-    if (wouldRenameNodeModules) {
-      return getRenameInfoError(wouldRenameNodeModules);
-    }
-    const kind = ts_SymbolDisplay_exports.getSymbolKind(typeChecker, symbol, node);
-    const specifierName = isImportOrExportSpecifierName(node) || isStringOrNumericLiteralLike(node) && node.parent.kind === 166 /* ComputedPropertyName */ ? stripQuotes(getTextOfIdentifierOrLiteral(node)) : void 0;
-    const displayName = specifierName || typeChecker.symbolToString(symbol);
-    const fullDisplayName = specifierName || typeChecker.getFullyQualifiedName(symbol);
-    return getRenameInfoSuccess(displayName, fullDisplayName, kind, ts_SymbolDisplay_exports.getSymbolModifiers(typeChecker, symbol), node, sourceFile);
-  }
-  function isDefinedInLibraryFile(program, declaration) {
-    const sourceFile = declaration.getSourceFile();
-    return program.isSourceFileDefaultLibrary(sourceFile) && fileExtensionIs(sourceFile.fileName, ".d.ts" /* Dts */);
-  }
-  function wouldRenameInOtherNodeModules(originalFile, symbol, checker, preferences) {
-    if (!preferences.providePrefixAndSuffixTextForRename && symbol.flags & 2097152 /* Alias */) {
-      const importSpecifier = symbol.declarations && find(symbol.declarations, (decl) => isImportSpecifier(decl));
-      if (importSpecifier && !importSpecifier.propertyName) {
-        symbol = checker.getAliasedSymbol(symbol);
       }
     }
-    const { declarations } = symbol;
-    if (!declarations) {
-      return void 0;
-    }
-    const originalPackage = getPackagePathComponents(originalFile.path);
-    if (originalPackage === void 0) {
-      if (some(declarations, (declaration) => isInsideNodeModules(declaration.getSourceFile().path))) {
-        return Diagnostics.You_cannot_rename_elements_that_are_defined_in_a_node_modules_folder;
-      } else {
-        return void 0;
+    const bind = createBinder2(overloads, binder2);
+    return call;
+    function call(...args) {
+      const index = bind(args);
+      const fn = index !== void 0 ? overloads[index] : void 0;
+      if (typeof fn === "function") {
+        return fn(...args);
       }
+      throw new TypeError("Invalid arguments");
     }
-    for (const declaration of declarations) {
-      const declPackage = getPackagePathComponents(declaration.getSourceFile().path);
-      if (declPackage) {
-        const length2 = Math.min(originalPackage.length, declPackage.length);
-        for (let i = 0; i <= length2; i++) {
-          if (compareStringsCaseSensitive(originalPackage[i], declPackage[i]) !== 0 /* EqualTo */) {
-            return Diagnostics.You_cannot_rename_elements_that_are_defined_in_another_node_modules_folder;
-          }
+  }
+  function createBinder2(overloads, binder2) {
+    return (args) => {
+      for (let i = 0; hasProperty(overloads, `${i}`) && hasProperty(binder2, `${i}`); i++) {
+        const fn = binder2[i];
+        if (fn(args)) {
+          return i;
         }
       }
-    }
-    return void 0;
-  }
-  function getPackagePathComponents(filePath) {
-    const components = getPathComponents(filePath);
-    const nodeModulesIdx = components.lastIndexOf("node_modules");
-    if (nodeModulesIdx === -1) {
-      return void 0;
-    }
-    return components.slice(0, nodeModulesIdx + 2);
-  }
-  function getRenameInfoForModule(node, sourceFile, moduleSymbol) {
-    if (!isExternalModuleNameRelative(node.text)) {
-      return getRenameInfoError(Diagnostics.You_cannot_rename_a_module_via_a_global_import);
-    }
-    const moduleSourceFile = moduleSymbol.declarations && find(moduleSymbol.declarations, isSourceFile);
-    if (!moduleSourceFile)
-      return void 0;
-    const withoutIndex = endsWith(node.text, "/index") || endsWith(node.text, "/index.js") ? void 0 : tryRemoveSuffix(removeFileExtension(moduleSourceFile.fileName), "/index");
-    const name = withoutIndex === void 0 ? moduleSourceFile.fileName : withoutIndex;
-    const kind = withoutIndex === void 0 ? "module" /* moduleElement */ : "directory" /* directory */;
-    const indexAfterLastSlash = node.text.lastIndexOf("/") + 1;
-    const triggerSpan = createTextSpan(node.getStart(sourceFile) + 1 + indexAfterLastSlash, node.text.length - indexAfterLastSlash);
-    return {
-      canRename: true,
-      fileToRename: name,
-      kind,
-      displayName: name,
-      fullDisplayName: name,
-      kindModifiers: "" /* none */,
-      triggerSpan
     };
   }
-  function getRenameInfoSuccess(displayName, fullDisplayName, kind, kindModifiers, node, sourceFile) {
+  function buildOverload(name) {
     return {
-      canRename: true,
-      fileToRename: void 0,
-      kind,
-      displayName,
-      fullDisplayName,
-      kindModifiers,
-      triggerSpan: createTriggerSpanForNode(node, sourceFile)
+      overload: (overloads) => ({
+        bind: (binder2) => ({
+          finish: () => createOverload(name, overloads, binder2),
+          deprecate: (deprecations) => ({
+            finish: () => createOverload(name, overloads, binder2, deprecations)
+          })
+        })
+      })
     };
   }
-  function getRenameInfoError(diagnostic) {
-    return { canRename: false, localizedErrorMessage: getLocaleSpecificMessage(diagnostic) };
-  }
-  function createTriggerSpanForNode(node, sourceFile) {
-    let start = node.getStart(sourceFile);
-    let width = node.getWidth(sourceFile);
-    if (isStringLiteralLike(node)) {
-      start += 1;
-      width -= 2;
-    }
-    return createTextSpan(start, width);
-  }
-  function nodeIsEligibleForRename(node) {
-    switch (node.kind) {
-      case 80 /* Identifier */:
-      case 81 /* PrivateIdentifier */:
-      case 11 /* StringLiteral */:
-      case 15 /* NoSubstitutionTemplateLiteral */:
-      case 110 /* ThisKeyword */:
-        return true;
-      case 9 /* NumericLiteral */:
-        return isLiteralNameOfPropertyDeclarationOrIndexAccess(node);
-      default:
-        return false;
-    }
-  }
-  var init_rename = __esm({
-    "src/services/rename.ts"() {
+  var init_deprecations = __esm({
+    "src/deprecatedCompat/deprecations.ts"() {
       "use strict";
-      init_ts4();
+      init_ts5();
+      init_deprecate();
     }
   });
 
-  // src/services/_namespaces/ts.Rename.ts
-  var ts_Rename_exports = {};
-  __export(ts_Rename_exports, {
-    getRenameInfo: () => getRenameInfo,
-    nodeIsEligibleForRename: () => nodeIsEligibleForRename
-  });
-  var init_ts_Rename = __esm({
-    "src/services/_namespaces/ts.Rename.ts"() {
+  // src/deprecatedCompat/5.0/identifierProperties.ts
+  var init_identifierProperties = __esm({
+    "src/deprecatedCompat/5.0/identifierProperties.ts"() {
       "use strict";
-      init_rename();
+      init_ts5();
+      init_deprecate();
+      addObjectAllocatorPatcher((objectAllocator2) => {
+        const Identifier78 = objectAllocator2.getIdentifierConstructor();
+        if (!hasProperty(Identifier78.prototype, "originalKeywordKind")) {
+          Object.defineProperty(Identifier78.prototype, "originalKeywordKind", {
+            get: deprecate(function() {
+              return identifierToKeywordKind(this);
+            }, {
+              name: "originalKeywordKind",
+              since: "5.0",
+              warnAfter: "5.1",
+              errorAfter: "5.2",
+              message: "Use 'identifierToKeywordKind(identifier)' instead."
+            })
+          });
+        }
+        if (!hasProperty(Identifier78.prototype, "isInJSDocNamespace")) {
+          Object.defineProperty(Identifier78.prototype, "isInJSDocNamespace", {
+            get: deprecate(function() {
+              return this.flags & 4096 /* IdentifierIsInJSDocNamespace */ ? true : void 0;
+            }, {
+              name: "isInJSDocNamespace",
+              since: "5.0",
+              warnAfter: "5.1",
+              errorAfter: "5.2",
+              message: "Use '.parent' or the surrounding context to determine this instead."
+            })
+          });
+        }
+      });
     }
   });
 
-  // src/services/signatureHelp.ts
-  function getSignatureHelpItems(program, sourceFile, position, triggerReason, cancellationToken) {
-    const typeChecker = program.getTypeChecker();
-    const startingToken = findTokenOnLeftOfPosition(sourceFile, position);
-    if (!startingToken) {
-      return void 0;
+  // src/deprecatedCompat/_namespaces/ts.ts
+  var init_ts5 = __esm({
+    "src/deprecatedCompat/_namespaces/ts.ts"() {
+      "use strict";
+      init_ts2();
+      init_deprecations();
+      init_identifierProperties();
     }
-    const onlyUseSyntacticOwners = !!triggerReason && triggerReason.kind === "characterTyped";
-    if (onlyUseSyntacticOwners && (isInString(sourceFile, position, startingToken) || isInComment(sourceFile, position))) {
-      return void 0;
+  });
+
+  // src/typingsInstallerCore/_namespaces/ts.ts
+  var init_ts6 = __esm({
+    "src/typingsInstallerCore/_namespaces/ts.ts"() {
+      "use strict";
+      init_ts2();
+      init_ts3();
+      init_ts_server2();
     }
-    const isManuallyInvoked = !!triggerReason && triggerReason.kind === "invoked";
-    const argumentInfo = getContainingArgumentInfo(startingToken, position, sourceFile, typeChecker, isManuallyInvoked);
-    if (!argumentInfo)
+  });
+
+  // src/typingsInstallerCore/typingsInstaller.ts
+  function typingToFileName(cachePath, packageName, installTypingHost, log) {
+    try {
+      const result = resolveModuleName(packageName, combinePaths(cachePath, "index.d.ts"), { moduleResolution: 2 /* Node10 */ }, installTypingHost);
+      return result.resolvedModule && result.resolvedModule.resolvedFileName;
+    } catch (e) {
+      if (log.isEnabled()) {
+        log.writeLine(`Failed to resolve ${packageName} in folder '${cachePath}': ${e.message}`);
+      }
       return void 0;
-    cancellationToken.throwIfCancellationRequested();
-    const candidateInfo = getCandidateOrTypeInfo(argumentInfo, typeChecker, sourceFile, startingToken, onlyUseSyntacticOwners);
-    cancellationToken.throwIfCancellationRequested();
-    if (!candidateInfo) {
-      return isSourceFileJS(sourceFile) ? createJSSignatureHelpItems(argumentInfo, program, cancellationToken) : void 0;
     }
-    return typeChecker.runWithCancellationToken(cancellationToken, (typeChecker2) => candidateInfo.kind === 0 /* Candidate */ ? createSignatureHelpItems(candidateInfo.candidates, candidateInfo.resolvedSignature, argumentInfo, sourceFile, typeChecker2) : createTypeHelpItems(candidateInfo.symbol, argumentInfo, sourceFile, typeChecker2));
   }
-  function getCandidateOrTypeInfo({ invocation, argumentCount }, checker, sourceFile, startingToken, onlyUseSyntacticOwners) {
-    switch (invocation.kind) {
-      case 0 /* Call */: {
-        if (onlyUseSyntacticOwners && !isSyntacticOwner(startingToken, invocation.node, sourceFile)) {
-          return void 0;
-        }
-        const candidates = [];
-        const resolvedSignature = checker.getResolvedSignatureForSignatureHelp(invocation.node, candidates, argumentCount);
-        return candidates.length === 0 ? void 0 : { kind: 0 /* Candidate */, candidates, resolvedSignature };
-      }
-      case 1 /* TypeArgs */: {
-        const { called } = invocation;
-        if (onlyUseSyntacticOwners && !containsPrecedingToken(startingToken, sourceFile, isIdentifier(called) ? called.parent : called)) {
-          return void 0;
-        }
-        const candidates = getPossibleGenericSignatures(called, argumentCount, checker);
-        if (candidates.length !== 0)
-          return { kind: 0 /* Candidate */, candidates, resolvedSignature: first(candidates) };
-        const symbol = checker.getSymbolAtLocation(called);
-        return symbol && { kind: 1 /* Type */, symbol };
-      }
-      case 2 /* Contextual */:
-        return { kind: 0 /* Candidate */, candidates: [invocation.signature], resolvedSignature: invocation.signature };
-      default:
-        return Debug.assertNever(invocation);
+  function installNpmPackages(npmPath, tsVersion, packageNames, install) {
+    let hasError = false;
+    for (let remaining = packageNames.length; remaining > 0; ) {
+      const result = getNpmCommandForInstallation(npmPath, tsVersion, packageNames, remaining);
+      remaining = result.remaining;
+      hasError = install(result.command) || hasError;
     }
+    return hasError;
   }
-  function isSyntacticOwner(startingToken, node, sourceFile) {
-    if (!isCallOrNewExpression(node))
-      return false;
-    const invocationChildren = node.getChildren(sourceFile);
-    switch (startingToken.kind) {
-      case 21 /* OpenParenToken */:
-        return contains(invocationChildren, startingToken);
-      case 28 /* CommaToken */: {
-        const containingList = findContainingList(startingToken);
-        return !!containingList && contains(invocationChildren, containingList);
+  function getNpmCommandForInstallation(npmPath, tsVersion, packageNames, remaining) {
+    const sliceStart = packageNames.length - remaining;
+    let command, toSlice = remaining;
+    while (true) {
+      command = `${npmPath} install --ignore-scripts ${(toSlice === packageNames.length ? packageNames : packageNames.slice(sliceStart, sliceStart + toSlice)).join(" ")} --save-dev --user-agent="typesInstaller/${tsVersion}"`;
+      if (command.length < 8e3) {
+        break;
       }
-      case 30 /* LessThanToken */:
-        return containsPrecedingToken(startingToken, sourceFile, node.expression);
-      default:
-        return false;
+      toSlice = toSlice - Math.floor(toSlice / 2);
     }
+    return { command, remaining: remaining - toSlice };
   }
-  function createJSSignatureHelpItems(argumentInfo, program, cancellationToken) {
-    if (argumentInfo.invocation.kind === 2 /* Contextual */)
-      return void 0;
-    const expression = getExpressionFromInvocation(argumentInfo.invocation);
-    const name = isPropertyAccessExpression(expression) ? expression.name.text : void 0;
-    const typeChecker = program.getTypeChecker();
-    return name === void 0 ? void 0 : firstDefined(program.getSourceFiles(), (sourceFile) => firstDefined(sourceFile.getNamedDeclarations().get(name), (declaration) => {
-      const type = declaration.symbol && typeChecker.getTypeOfSymbolAtLocation(declaration.symbol, declaration);
-      const callSignatures = type && type.getCallSignatures();
-      if (callSignatures && callSignatures.length) {
-        return typeChecker.runWithCancellationToken(
-          cancellationToken,
-          (typeChecker2) => createSignatureHelpItems(
-            callSignatures,
-            callSignatures[0],
-            argumentInfo,
-            sourceFile,
-            typeChecker2,
-            /*useFullPrefix*/
-            true
-          )
-        );
-      }
-    }));
+  function typingsName(packageName) {
+    return `@types/${packageName}@ts${versionMajorMinor}`;
   }
-  function containsPrecedingToken(startingToken, sourceFile, container) {
-    const pos = startingToken.getFullStart();
-    let currentParent = startingToken.parent;
-    while (currentParent) {
-      const precedingToken = findPrecedingToken(
-        pos,
-        sourceFile,
-        currentParent,
-        /*excludeJsdoc*/
-        true
-      );
-      if (precedingToken) {
-        return rangeContainsRange(container, precedingToken);
-      }
-      currentParent = currentParent.parent;
+  var nullLog, TypingsInstaller;
+  var init_typingsInstaller = __esm({
+    "src/typingsInstallerCore/typingsInstaller.ts"() {
+      "use strict";
+      init_ts6();
+      init_ts_server2();
+      nullLog = {
+        isEnabled: () => false,
+        writeLine: noop
+      };
+      TypingsInstaller = class {
+        constructor(installTypingHost, globalCachePath, safeListPath, typesMapLocation, throttleLimit, log = nullLog) {
+          this.installTypingHost = installTypingHost;
+          this.globalCachePath = globalCachePath;
+          this.safeListPath = safeListPath;
+          this.typesMapLocation = typesMapLocation;
+          this.throttleLimit = throttleLimit;
+          this.log = log;
+          this.packageNameToTypingLocation = /* @__PURE__ */ new Map();
+          this.missingTypingsSet = /* @__PURE__ */ new Set();
+          this.knownCachesSet = /* @__PURE__ */ new Set();
+          this.projectWatchers = /* @__PURE__ */ new Map();
+          /** @internal */
+          this.pendingRunRequests = [];
+          this.installRunCount = 1;
+          this.inFlightRequestCount = 0;
+          this.latestDistTag = "latest";
+          const isLoggingEnabled = this.log.isEnabled();
+          if (isLoggingEnabled) {
+            this.log.writeLine(`Global cache location '${globalCachePath}', safe file path '${safeListPath}', types map path ${typesMapLocation}`);
+          }
+          this.processCacheLocation(this.globalCachePath);
+        }
+        closeProject(req) {
+          this.closeWatchers(req.projectName);
+        }
+        closeWatchers(projectName) {
+          if (this.log.isEnabled()) {
+            this.log.writeLine(`Closing file watchers for project '${projectName}'`);
+          }
+          const watchers = this.projectWatchers.get(projectName);
+          if (!watchers) {
+            if (this.log.isEnabled()) {
+              this.log.writeLine(`No watchers are registered for project '${projectName}'`);
+            }
+            return;
+          }
+          this.projectWatchers.delete(projectName);
+          this.sendResponse({ kind: ActionWatchTypingLocations, projectName, files: [] });
+          if (this.log.isEnabled()) {
+            this.log.writeLine(`Closing file watchers for project '${projectName}' - done.`);
+          }
+        }
+        install(req) {
+          if (this.log.isEnabled()) {
+            this.log.writeLine(`Got install request${stringifyIndented(req)}`);
+          }
+          if (req.cachePath) {
+            if (this.log.isEnabled()) {
+              this.log.writeLine(`Request specifies cache path '${req.cachePath}', loading cached information...`);
+            }
+            this.processCacheLocation(req.cachePath);
+          }
+          if (this.safeList === void 0) {
+            this.initializeSafeList();
+          }
+          const discoverTypingsResult = ts_JsTyping_exports.discoverTypings(
+            this.installTypingHost,
+            this.log.isEnabled() ? (s) => this.log.writeLine(s) : void 0,
+            req.fileNames,
+            req.projectRootPath,
+            this.safeList,
+            this.packageNameToTypingLocation,
+            req.typeAcquisition,
+            req.unresolvedImports,
+            this.typesRegistry,
+            req.compilerOptions
+          );
+          this.watchFiles(req.projectName, discoverTypingsResult.filesToWatch);
+          if (discoverTypingsResult.newTypingNames.length) {
+            this.installTypings(req, req.cachePath || this.globalCachePath, discoverTypingsResult.cachedTypingPaths, discoverTypingsResult.newTypingNames);
+          } else {
+            this.sendResponse(this.createSetTypings(req, discoverTypingsResult.cachedTypingPaths));
+            if (this.log.isEnabled()) {
+              this.log.writeLine(`No new typings were requested as a result of typings discovery`);
+            }
+          }
+        }
+        initializeSafeList() {
+          if (this.typesMapLocation) {
+            const safeListFromMap = ts_JsTyping_exports.loadTypesMap(this.installTypingHost, this.typesMapLocation);
+            if (safeListFromMap) {
+              this.log.writeLine(`Loaded safelist from types map file '${this.typesMapLocation}'`);
+              this.safeList = safeListFromMap;
+              return;
+            }
+            this.log.writeLine(`Failed to load safelist from types map file '${this.typesMapLocation}'`);
+          }
+          this.safeList = ts_JsTyping_exports.loadSafeList(this.installTypingHost, this.safeListPath);
+        }
+        processCacheLocation(cacheLocation) {
+          if (this.log.isEnabled()) {
+            this.log.writeLine(`Processing cache location '${cacheLocation}'`);
+          }
+          if (this.knownCachesSet.has(cacheLocation)) {
+            if (this.log.isEnabled()) {
+              this.log.writeLine(`Cache location was already processed...`);
+            }
+            return;
+          }
+          const packageJson = combinePaths(cacheLocation, "package.json");
+          const packageLockJson = combinePaths(cacheLocation, "package-lock.json");
+          if (this.log.isEnabled()) {
+            this.log.writeLine(`Trying to find '${packageJson}'...`);
+          }
+          if (this.installTypingHost.fileExists(packageJson) && this.installTypingHost.fileExists(packageLockJson)) {
+            const npmConfig = JSON.parse(this.installTypingHost.readFile(packageJson));
+            const npmLock = JSON.parse(this.installTypingHost.readFile(packageLockJson));
+            if (this.log.isEnabled()) {
+              this.log.writeLine(`Loaded content of '${packageJson}':${stringifyIndented(npmConfig)}`);
+              this.log.writeLine(`Loaded content of '${packageLockJson}':${stringifyIndented(npmLock)}`);
+            }
+            if (npmConfig.devDependencies && npmLock.dependencies) {
+              for (const key in npmConfig.devDependencies) {
+                if (!hasProperty(npmLock.dependencies, key)) {
+                  continue;
+                }
+                const packageName = getBaseFileName(key);
+                if (!packageName) {
+                  continue;
+                }
+                const typingFile = typingToFileName(cacheLocation, packageName, this.installTypingHost, this.log);
+                if (!typingFile) {
+                  this.missingTypingsSet.add(packageName);
+                  continue;
+                }
+                const existingTypingFile = this.packageNameToTypingLocation.get(packageName);
+                if (existingTypingFile) {
+                  if (existingTypingFile.typingLocation === typingFile) {
+                    continue;
+                  }
+                  if (this.log.isEnabled()) {
+                    this.log.writeLine(`New typing for package ${packageName} from '${typingFile}' conflicts with existing typing file '${existingTypingFile}'`);
+                  }
+                }
+                if (this.log.isEnabled()) {
+                  this.log.writeLine(`Adding entry into typings cache: '${packageName}' => '${typingFile}'`);
+                }
+                const info = getProperty(npmLock.dependencies, key);
+                const version2 = info && info.version;
+                if (!version2) {
+                  continue;
+                }
+                const newTyping = { typingLocation: typingFile, version: new Version(version2) };
+                this.packageNameToTypingLocation.set(packageName, newTyping);
+              }
+            }
+          }
+          if (this.log.isEnabled()) {
+            this.log.writeLine(`Finished processing cache location '${cacheLocation}'`);
+          }
+          this.knownCachesSet.add(cacheLocation);
+        }
+        filterTypings(typingsToInstall) {
+          return mapDefined(typingsToInstall, (typing) => {
+            const typingKey = mangleScopedPackageName(typing);
+            if (this.missingTypingsSet.has(typingKey)) {
+              if (this.log.isEnabled())
+                this.log.writeLine(`'${typing}':: '${typingKey}' is in missingTypingsSet - skipping...`);
+              return void 0;
+            }
+            const validationResult = ts_JsTyping_exports.validatePackageName(typing);
+            if (validationResult !== ts_JsTyping_exports.NameValidationResult.Ok) {
+              this.missingTypingsSet.add(typingKey);
+              if (this.log.isEnabled())
+                this.log.writeLine(ts_JsTyping_exports.renderPackageNameValidationFailure(validationResult, typing));
+              return void 0;
+            }
+            if (!this.typesRegistry.has(typingKey)) {
+              if (this.log.isEnabled())
+                this.log.writeLine(`'${typing}':: Entry for package '${typingKey}' does not exist in local types registry - skipping...`);
+              return void 0;
+            }
+            if (this.packageNameToTypingLocation.get(typingKey) && ts_JsTyping_exports.isTypingUpToDate(this.packageNameToTypingLocation.get(typingKey), this.typesRegistry.get(typingKey))) {
+              if (this.log.isEnabled())
+                this.log.writeLine(`'${typing}':: '${typingKey}' already has an up-to-date typing - skipping...`);
+              return void 0;
+            }
+            return typingKey;
+          });
+        }
+        ensurePackageDirectoryExists(directory) {
+          const npmConfigPath = combinePaths(directory, "package.json");
+          if (this.log.isEnabled()) {
+            this.log.writeLine(`Npm config file: ${npmConfigPath}`);
+          }
+          if (!this.installTypingHost.fileExists(npmConfigPath)) {
+            if (this.log.isEnabled()) {
+              this.log.writeLine(`Npm config file: '${npmConfigPath}' is missing, creating new one...`);
+            }
+            this.ensureDirectoryExists(directory, this.installTypingHost);
+            this.installTypingHost.writeFile(npmConfigPath, '{ "private": true }');
+          }
+        }
+        installTypings(req, cachePath, currentlyCachedTypings, typingsToInstall) {
+          if (this.log.isEnabled()) {
+            this.log.writeLine(`Installing typings ${JSON.stringify(typingsToInstall)}`);
+          }
+          const filteredTypings = this.filterTypings(typingsToInstall);
+          if (filteredTypings.length === 0) {
+            if (this.log.isEnabled()) {
+              this.log.writeLine(`All typings are known to be missing or invalid - no need to install more typings`);
+            }
+            this.sendResponse(this.createSetTypings(req, currentlyCachedTypings));
+            return;
+          }
+          this.ensurePackageDirectoryExists(cachePath);
+          const requestId = this.installRunCount;
+          this.installRunCount++;
+          this.sendResponse({
+            kind: EventBeginInstallTypes,
+            eventId: requestId,
+            typingsInstallerVersion: version,
+            projectName: req.projectName
+          });
+          const scopedTypings = filteredTypings.map(typingsName);
+          this.installTypingsAsync(requestId, scopedTypings, cachePath, (ok) => {
+            try {
+              if (!ok) {
+                if (this.log.isEnabled()) {
+                  this.log.writeLine(`install request failed, marking packages as missing to prevent repeated requests: ${JSON.stringify(filteredTypings)}`);
+                }
+                for (const typing of filteredTypings) {
+                  this.missingTypingsSet.add(typing);
+                }
+                return;
+              }
+              if (this.log.isEnabled()) {
+                this.log.writeLine(`Installed typings ${JSON.stringify(scopedTypings)}`);
+              }
+              const installedTypingFiles = [];
+              for (const packageName of filteredTypings) {
+                const typingFile = typingToFileName(cachePath, packageName, this.installTypingHost, this.log);
+                if (!typingFile) {
+                  this.missingTypingsSet.add(packageName);
+                  continue;
+                }
+                const distTags = this.typesRegistry.get(packageName);
+                const newVersion = new Version(distTags[`ts${versionMajorMinor}`] || distTags[this.latestDistTag]);
+                const newTyping = { typingLocation: typingFile, version: newVersion };
+                this.packageNameToTypingLocation.set(packageName, newTyping);
+                installedTypingFiles.push(typingFile);
+              }
+              if (this.log.isEnabled()) {
+                this.log.writeLine(`Installed typing files ${JSON.stringify(installedTypingFiles)}`);
+              }
+              this.sendResponse(this.createSetTypings(req, currentlyCachedTypings.concat(installedTypingFiles)));
+            } finally {
+              const response = {
+                kind: EventEndInstallTypes,
+                eventId: requestId,
+                projectName: req.projectName,
+                packagesToInstall: scopedTypings,
+                installSuccess: ok,
+                typingsInstallerVersion: version
+              };
+              this.sendResponse(response);
+            }
+          });
+        }
+        ensureDirectoryExists(directory, host) {
+          const directoryName = getDirectoryPath(directory);
+          if (!host.directoryExists(directoryName)) {
+            this.ensureDirectoryExists(directoryName, host);
+          }
+          if (!host.directoryExists(directory)) {
+            host.createDirectory(directory);
+          }
+        }
+        watchFiles(projectName, files) {
+          if (!files.length) {
+            this.closeWatchers(projectName);
+            return;
+          }
+          const existing = this.projectWatchers.get(projectName);
+          const newSet = new Set(files);
+          if (!existing || forEachKey(newSet, (s) => !existing.has(s)) || forEachKey(existing, (s) => !newSet.has(s))) {
+            this.projectWatchers.set(projectName, newSet);
+            this.sendResponse({ kind: ActionWatchTypingLocations, projectName, files });
+          } else {
+            this.sendResponse({ kind: ActionWatchTypingLocations, projectName, files: void 0 });
+          }
+        }
+        createSetTypings(request, typings) {
+          return {
+            projectName: request.projectName,
+            typeAcquisition: request.typeAcquisition,
+            compilerOptions: request.compilerOptions,
+            typings,
+            unresolvedImports: request.unresolvedImports,
+            kind: ActionSet
+          };
+        }
+        installTypingsAsync(requestId, packageNames, cwd, onRequestCompleted) {
+          this.pendingRunRequests.unshift({ requestId, packageNames, cwd, onRequestCompleted });
+          this.executeWithThrottling();
+        }
+        executeWithThrottling() {
+          while (this.inFlightRequestCount < this.throttleLimit && this.pendingRunRequests.length) {
+            this.inFlightRequestCount++;
+            const request = this.pendingRunRequests.pop();
+            this.installWorker(request.requestId, request.packageNames, request.cwd, (ok) => {
+              this.inFlightRequestCount--;
+              request.onRequestCompleted(ok);
+              this.executeWithThrottling();
+            });
+          }
+        }
+      };
     }
-    return Debug.fail("Could not find preceding token");
-  }
-  function getArgumentInfoForCompletions(node, position, sourceFile) {
-    const info = getImmediatelyContainingArgumentInfo(node, position, sourceFile);
-    return !info || info.isTypeParameterList || info.invocation.kind !== 0 /* Call */ ? void 0 : { invocation: info.invocation.node, argumentCount: info.argumentCount, argumentIndex: info.argumentIndex };
-  }
-  function getArgumentOrParameterListInfo(node, position, sourceFile) {
-    const info = getArgumentOrParameterListAndIndex(node, sourceFile);
-    if (!info)
-      return void 0;
-    const { list, argumentIndex } = info;
-    const argumentCount = getArgumentCount(
-      list,
-      /*ignoreTrailingComma*/
-      isInString(sourceFile, position, node)
-    );
-    if (argumentIndex !== 0) {
-      Debug.assertLessThan(argumentIndex, argumentCount);
+  });
+
+  // src/typingsInstallerCore/_namespaces/ts.server.typingsInstaller.ts
+  var ts_server_typingsInstaller_exports = {};
+  __export(ts_server_typingsInstaller_exports, {
+    TypingsInstaller: () => TypingsInstaller,
+    getNpmCommandForInstallation: () => getNpmCommandForInstallation,
+    installNpmPackages: () => installNpmPackages,
+    typingsName: () => typingsName
+  });
+  var init_ts_server_typingsInstaller = __esm({
+    "src/typingsInstallerCore/_namespaces/ts.server.typingsInstaller.ts"() {
+      "use strict";
+      init_typingsInstaller();
     }
-    const argumentsSpan = getApplicableSpanForArguments(list, sourceFile);
-    return { list, argumentIndex, argumentCount, argumentsSpan };
-  }
-  function getArgumentOrParameterListAndIndex(node, sourceFile) {
-    if (node.kind === 30 /* LessThanToken */ || node.kind === 21 /* OpenParenToken */) {
-      return { list: getChildListThatStartsWithOpenerToken(node.parent, node, sourceFile), argumentIndex: 0 };
-    } else {
-      const list = findContainingList(node);
-      return list && { list, argumentIndex: getArgumentIndex(list, node) };
+  });
+
+  // src/typingsInstallerCore/_namespaces/ts.server.ts
+  var init_ts_server2 = __esm({
+    "src/typingsInstallerCore/_namespaces/ts.server.ts"() {
+      "use strict";
+      init_ts_server();
+      init_ts_server_typingsInstaller();
     }
-  }
-  function getImmediatelyContainingArgumentInfo(node, position, sourceFile) {
-    const { parent: parent2 } = node;
-    if (isCallOrNewExpression(parent2)) {
-      const invocation = parent2;
-      const info = getArgumentOrParameterListInfo(node, position, sourceFile);
-      if (!info)
-        return void 0;
-      const { list, argumentIndex, argumentCount, argumentsSpan } = info;
-      const isTypeParameterList = !!parent2.typeArguments && parent2.typeArguments.pos === list.pos;
-      return { isTypeParameterList, invocation: { kind: 0 /* Call */, node: invocation }, argumentsSpan, argumentIndex, argumentCount };
-    } else if (isNoSubstitutionTemplateLiteral(node) && isTaggedTemplateExpression(parent2)) {
-      if (isInsideTemplateLiteral(node, position, sourceFile)) {
-        return getArgumentListInfoForTemplate(
-          parent2,
-          /*argumentIndex*/
-          0,
-          sourceFile
-        );
-      }
-      return void 0;
-    } else if (isTemplateHead(node) && parent2.parent.kind === 214 /* TaggedTemplateExpression */) {
-      const templateExpression = parent2;
-      const tagExpression = templateExpression.parent;
-      Debug.assert(templateExpression.kind === 227 /* TemplateExpression */);
-      const argumentIndex = isInsideTemplateLiteral(node, position, sourceFile) ? 0 : 1;
-      return getArgumentListInfoForTemplate(tagExpression, argumentIndex, sourceFile);
-    } else if (isTemplateSpan(parent2) && isTaggedTemplateExpression(parent2.parent.parent)) {
-      const templateSpan = parent2;
-      const tagExpression = parent2.parent.parent;
-      if (isTemplateTail(node) && !isInsideTemplateLiteral(node, position, sourceFile)) {
-        return void 0;
-      }
-      const spanIndex = templateSpan.parent.templateSpans.indexOf(templateSpan);
-      const argumentIndex = getArgumentIndexForTemplatePiece(spanIndex, node, position, sourceFile);
-      return getArgumentListInfoForTemplate(tagExpression, argumentIndex, sourceFile);
-    } else if (isJsxOpeningLikeElement(parent2)) {
-      const attributeSpanStart = parent2.attributes.pos;
-      const attributeSpanEnd = skipTrivia(
-        sourceFile.text,
-        parent2.attributes.end,
-        /*stopAfterLineBreak*/
-        false
-      );
-      return {
-        isTypeParameterList: false,
-        invocation: { kind: 0 /* Call */, node: parent2 },
-        argumentsSpan: createTextSpan(attributeSpanStart, attributeSpanEnd - attributeSpanStart),
-        argumentIndex: 0,
-        argumentCount: 1
-      };
-    } else {
-      const typeArgInfo = getPossibleTypeArgumentsInfo(node, sourceFile);
-      if (typeArgInfo) {
-        const { called, nTypeArguments } = typeArgInfo;
-        const invocation = { kind: 1 /* TypeArgs */, called };
-        const argumentsSpan = createTextSpanFromBounds(called.getStart(sourceFile), node.end);
-        return { isTypeParameterList: true, invocation, argumentsSpan, argumentIndex: nTypeArguments, argumentCount: nTypeArguments + 1 };
-      }
-      return void 0;
+  });
+
+  // src/server/types.ts
+  var init_types4 = __esm({
+    "src/server/types.ts"() {
+      "use strict";
     }
+  });
+
+  // src/server/utilitiesPublic.ts
+  function createInstallTypingsRequest(project, typeAcquisition, unresolvedImports, cachePath) {
+    return {
+      projectName: project.getProjectName(),
+      fileNames: project.getFileNames(
+        /*excludeFilesFromExternalLibraries*/
+        true,
+        /*excludeConfigFiles*/
+        true
+      ).concat(project.getExcludedFiles()),
+      compilerOptions: project.getCompilationSettings(),
+      typeAcquisition,
+      unresolvedImports,
+      projectRootPath: project.getCurrentDirectory(),
+      cachePath,
+      kind: "discover"
+    };
   }
-  function getImmediatelyContainingArgumentOrContextualParameterInfo(node, position, sourceFile, checker) {
-    return tryGetParameterInfo(node, position, sourceFile, checker) || getImmediatelyContainingArgumentInfo(node, position, sourceFile);
+  function toNormalizedPath(fileName) {
+    return normalizePath(fileName);
   }
-  function getHighestBinary(b) {
-    return isBinaryExpression(b.parent) ? getHighestBinary(b.parent) : b;
+  function normalizedPathToPath(normalizedPath, currentDirectory, getCanonicalFileName) {
+    const f = isRootedDiskPath(normalizedPath) ? normalizedPath : getNormalizedAbsolutePath(normalizedPath, currentDirectory);
+    return getCanonicalFileName(f);
   }
-  function countBinaryExpressionParameters(b) {
-    return isBinaryExpression(b.left) ? countBinaryExpressionParameters(b.left) + 1 : 2;
+  function asNormalizedPath(fileName) {
+    return fileName;
   }
-  function tryGetParameterInfo(startingToken, position, sourceFile, checker) {
-    const node = getAdjustedNode(startingToken);
-    if (node === void 0)
-      return void 0;
-    const info = getContextualSignatureLocationInfo(node, sourceFile, position, checker);
-    if (info === void 0)
-      return void 0;
-    const { contextualType, argumentIndex, argumentCount, argumentsSpan } = info;
-    const nonNullableContextualType = contextualType.getNonNullableType();
-    const symbol = nonNullableContextualType.symbol;
-    if (symbol === void 0)
-      return void 0;
-    const signature = lastOrUndefined(nonNullableContextualType.getCallSignatures());
-    if (signature === void 0)
-      return void 0;
-    const invocation = { kind: 2 /* Contextual */, signature, node: startingToken, symbol: chooseBetterSymbol(symbol) };
-    return { isTypeParameterList: false, invocation, argumentsSpan, argumentIndex, argumentCount };
+  function createNormalizedPathMap() {
+    const map2 = /* @__PURE__ */ new Map();
+    return {
+      get(path) {
+        return map2.get(path);
+      },
+      set(path, value) {
+        map2.set(path, value);
+      },
+      contains(path) {
+        return map2.has(path);
+      },
+      remove(path) {
+        map2.delete(path);
+      }
+    };
   }
-  function getAdjustedNode(node) {
-    switch (node.kind) {
-      case 21 /* OpenParenToken */:
-      case 28 /* CommaToken */:
-        return node;
-      default:
-        return findAncestor(node.parent, (n) => isParameter(n) ? true : isBindingElement(n) || isObjectBindingPattern(n) || isArrayBindingPattern(n) ? false : "quit");
-    }
+  function isInferredProjectName(name) {
+    return /dev\/null\/inferredProject\d+\*/.test(name);
   }
-  function getContextualSignatureLocationInfo(node, sourceFile, position, checker) {
-    const { parent: parent2 } = node;
-    switch (parent2.kind) {
-      case 216 /* ParenthesizedExpression */:
-      case 173 /* MethodDeclaration */:
-      case 217 /* FunctionExpression */:
-      case 218 /* ArrowFunction */:
-        const info = getArgumentOrParameterListInfo(node, position, sourceFile);
-        if (!info)
-          return void 0;
-        const { argumentIndex, argumentCount, argumentsSpan } = info;
-        const contextualType = isMethodDeclaration(parent2) ? checker.getContextualTypeForObjectLiteralElement(parent2) : checker.getContextualType(parent2);
-        return contextualType && { contextualType, argumentIndex, argumentCount, argumentsSpan };
-      case 225 /* BinaryExpression */: {
-        const highestBinary = getHighestBinary(parent2);
-        const contextualType2 = checker.getContextualType(highestBinary);
-        const argumentIndex2 = node.kind === 21 /* OpenParenToken */ ? 0 : countBinaryExpressionParameters(parent2) - 1;
-        const argumentCount2 = countBinaryExpressionParameters(highestBinary);
-        return contextualType2 && { contextualType: contextualType2, argumentIndex: argumentIndex2, argumentCount: argumentCount2, argumentsSpan: createTextSpanFromNode(parent2) };
-      }
-      default:
-        return void 0;
-    }
+  function makeInferredProjectName(counter) {
+    return `/dev/null/inferredProject${counter}*`;
   }
-  function chooseBetterSymbol(s) {
-    return s.name === "__type" /* Type */ ? firstDefined(s.declarations, (d) => {
-      var _a;
-      return isFunctionTypeNode(d) ? (_a = tryCast(d.parent, canHaveSymbol)) == null ? void 0 : _a.symbol : void 0;
-    }) || s : s;
+  function makeAutoImportProviderProjectName(counter) {
+    return `/dev/null/autoImportProviderProject${counter}*`;
   }
-  function getArgumentIndex(argumentsList, node) {
-    let argumentIndex = 0;
-    for (const child of argumentsList.getChildren()) {
-      if (child === node) {
-        break;
-      }
-      if (child.kind !== 28 /* CommaToken */) {
-        argumentIndex++;
-      }
-    }
-    return argumentIndex;
+  function makeAuxiliaryProjectName(counter) {
+    return `/dev/null/auxiliaryProject${counter}*`;
   }
-  function getArgumentCount(argumentsList, ignoreTrailingComma) {
-    const listChildren = argumentsList.getChildren();
-    let argumentCount = countWhere(listChildren, (arg) => arg.kind !== 28 /* CommaToken */);
-    if (!ignoreTrailingComma && listChildren.length > 0 && last(listChildren).kind === 28 /* CommaToken */) {
-      argumentCount++;
-    }
-    return argumentCount;
+  function createSortedArray2() {
+    return [];
   }
-  function getArgumentIndexForTemplatePiece(spanIndex, node, position, sourceFile) {
-    Debug.assert(position >= node.getStart(), "Assumed 'position' could not occur before node.");
-    if (isTemplateLiteralToken(node)) {
-      if (isInsideTemplateLiteral(node, position, sourceFile)) {
-        return 0;
-      }
-      return spanIndex + 2;
+  var LogLevel2, emptyArray2, Msg, Errors;
+  var init_utilitiesPublic3 = __esm({
+    "src/server/utilitiesPublic.ts"() {
+      "use strict";
+      init_ts7();
+      LogLevel2 = /* @__PURE__ */ ((LogLevel3) => {
+        LogLevel3[LogLevel3["terse"] = 0] = "terse";
+        LogLevel3[LogLevel3["normal"] = 1] = "normal";
+        LogLevel3[LogLevel3["requestTime"] = 2] = "requestTime";
+        LogLevel3[LogLevel3["verbose"] = 3] = "verbose";
+        return LogLevel3;
+      })(LogLevel2 || {});
+      emptyArray2 = createSortedArray2();
+      Msg = /* @__PURE__ */ ((Msg2) => {
+        Msg2["Err"] = "Err";
+        Msg2["Info"] = "Info";
+        Msg2["Perf"] = "Perf";
+        return Msg2;
+      })(Msg || {});
+      ((Errors2) => {
+        function ThrowNoProject() {
+          throw new Error("No Project.");
+        }
+        Errors2.ThrowNoProject = ThrowNoProject;
+        function ThrowProjectLanguageServiceDisabled() {
+          throw new Error("The project's language service is disabled.");
+        }
+        Errors2.ThrowProjectLanguageServiceDisabled = ThrowProjectLanguageServiceDisabled;
+        function ThrowProjectDoesNotContainDocument(fileName, project) {
+          throw new Error(`Project '${project.getProjectName()}' does not contain document '${fileName}'`);
+        }
+        Errors2.ThrowProjectDoesNotContainDocument = ThrowProjectDoesNotContainDocument;
+      })(Errors || (Errors = {}));
     }
-    return spanIndex + 1;
+  });
+
+  // src/server/utilities.ts
+  function getBaseConfigFileName(configFilePath) {
+    const base = getBaseFileName(configFilePath);
+    return base === "tsconfig.json" || base === "jsconfig.json" ? base : void 0;
   }
-  function getArgumentListInfoForTemplate(tagExpression, argumentIndex, sourceFile) {
-    const argumentCount = isNoSubstitutionTemplateLiteral(tagExpression.template) ? 1 : tagExpression.template.templateSpans.length + 1;
-    if (argumentIndex !== 0) {
-      Debug.assertLessThan(argumentIndex, argumentCount);
+  function removeSorted(array, remove, compare) {
+    if (!array || array.length === 0) {
+      return;
     }
-    return {
-      isTypeParameterList: false,
-      invocation: { kind: 0 /* Call */, node: tagExpression },
-      argumentsSpan: getApplicableSpanForTaggedTemplate(tagExpression, sourceFile),
-      argumentIndex,
-      argumentCount
-    };
-  }
-  function getApplicableSpanForArguments(argumentsList, sourceFile) {
-    const applicableSpanStart = argumentsList.getFullStart();
-    const applicableSpanEnd = skipTrivia(
-      sourceFile.text,
-      argumentsList.getEnd(),
-      /*stopAfterLineBreak*/
-      false
-    );
-    return createTextSpan(applicableSpanStart, applicableSpanEnd - applicableSpanStart);
-  }
-  function getApplicableSpanForTaggedTemplate(taggedTemplate, sourceFile) {
-    const template = taggedTemplate.template;
-    const applicableSpanStart = template.getStart();
-    let applicableSpanEnd = template.getEnd();
-    if (template.kind === 227 /* TemplateExpression */) {
-      const lastSpan = last(template.templateSpans);
-      if (lastSpan.literal.getFullWidth() === 0) {
-        applicableSpanEnd = skipTrivia(
-          sourceFile.text,
-          applicableSpanEnd,
-          /*stopAfterLineBreak*/
-          false
-        );
-      }
+    if (array[0] === remove) {
+      array.splice(0, 1);
+      return;
     }
-    return createTextSpan(applicableSpanStart, applicableSpanEnd - applicableSpanStart);
-  }
-  function getContainingArgumentInfo(node, position, sourceFile, checker, isManuallyInvoked) {
-    for (let n = node; !isSourceFile(n) && (isManuallyInvoked || !isBlock(n)); n = n.parent) {
-      Debug.assert(rangeContainsRange(n.parent, n), "Not a subspan", () => `Child: ${Debug.formatSyntaxKind(n.kind)}, parent: ${Debug.formatSyntaxKind(n.parent.kind)}`);
-      const argumentInfo = getImmediatelyContainingArgumentOrContextualParameterInfo(n, position, sourceFile, checker);
-      if (argumentInfo) {
-        return argumentInfo;
-      }
+    const removeIndex = binarySearch(array, remove, identity, compare);
+    if (removeIndex >= 0) {
+      array.splice(removeIndex, 1);
     }
-    return void 0;
-  }
-  function getChildListThatStartsWithOpenerToken(parent2, openerToken, sourceFile) {
-    const children = parent2.getChildren(sourceFile);
-    const indexOfOpenerToken = children.indexOf(openerToken);
-    Debug.assert(indexOfOpenerToken >= 0 && children.length > indexOfOpenerToken + 1);
-    return children[indexOfOpenerToken + 1];
-  }
-  function getExpressionFromInvocation(invocation) {
-    return invocation.kind === 0 /* Call */ ? getInvokedExpression(invocation.node) : invocation.called;
-  }
-  function getEnclosingDeclarationFromInvocation(invocation) {
-    return invocation.kind === 0 /* Call */ ? invocation.node : invocation.kind === 1 /* TypeArgs */ ? invocation.called : invocation.node;
   }
-  function createSignatureHelpItems(candidates, resolvedSignature, { isTypeParameterList, argumentCount, argumentsSpan: applicableSpan, invocation, argumentIndex }, sourceFile, typeChecker, useFullPrefix) {
-    var _a;
-    const enclosingDeclaration = getEnclosingDeclarationFromInvocation(invocation);
-    const callTargetSymbol = invocation.kind === 2 /* Contextual */ ? invocation.symbol : typeChecker.getSymbolAtLocation(getExpressionFromInvocation(invocation)) || useFullPrefix && ((_a = resolvedSignature.declaration) == null ? void 0 : _a.symbol);
-    const callTargetDisplayParts = callTargetSymbol ? symbolToDisplayParts(
-      typeChecker,
-      callTargetSymbol,
-      useFullPrefix ? sourceFile : void 0,
-      /*meaning*/
-      void 0
-    ) : emptyArray;
-    const items = map(candidates, (candidateSignature) => getSignatureHelpItem(candidateSignature, callTargetDisplayParts, isTypeParameterList, typeChecker, enclosingDeclaration, sourceFile));
-    if (argumentIndex !== 0) {
-      Debug.assertLessThan(argumentIndex, argumentCount);
-    }
-    let selectedItemIndex = 0;
-    let itemsSeen = 0;
-    for (let i = 0; i < items.length; i++) {
-      const item = items[i];
-      if (candidates[i] === resolvedSignature) {
-        selectedItemIndex = itemsSeen;
-        if (item.length > 1) {
-          let count = 0;
-          for (const i2 of item) {
-            if (i2.isVariadic || i2.parameters.length >= argumentCount) {
-              selectedItemIndex = itemsSeen + count;
-              break;
-            }
-            count++;
+  var ThrottledOperations, GcTimer;
+  var init_utilities5 = __esm({
+    "src/server/utilities.ts"() {
+      "use strict";
+      init_ts7();
+      init_ts_server3();
+      ThrottledOperations = class _ThrottledOperations {
+        constructor(host, logger) {
+          this.host = host;
+          this.pendingTimeouts = /* @__PURE__ */ new Map();
+          this.logger = logger.hasLevel(3 /* verbose */) ? logger : void 0;
+        }
+        /**
+         * Wait `number` milliseconds and then invoke `cb`.  If, while waiting, schedule
+         * is called again with the same `operationId`, cancel this operation in favor
+         * of the new one.  (Note that the amount of time the canceled operation had been
+         * waiting does not affect the amount of time that the new operation waits.)
+         */
+        schedule(operationId, delay, cb) {
+          const pendingTimeout = this.pendingTimeouts.get(operationId);
+          if (pendingTimeout) {
+            this.host.clearTimeout(pendingTimeout);
+          }
+          this.pendingTimeouts.set(operationId, this.host.setTimeout(_ThrottledOperations.run, delay, operationId, this, cb));
+          if (this.logger) {
+            this.logger.info(`Scheduled: ${operationId}${pendingTimeout ? ", Cancelled earlier one" : ""}`);
           }
         }
-      }
-      itemsSeen += item.length;
-    }
-    Debug.assert(selectedItemIndex !== -1);
-    const help = { items: flatMapToMutable(items, identity), applicableSpan, selectedItemIndex, argumentIndex, argumentCount };
-    const selected = help.items[selectedItemIndex];
-    if (selected.isVariadic) {
-      const firstRest = findIndex(selected.parameters, (p) => !!p.isRest);
-      if (-1 < firstRest && firstRest < selected.parameters.length - 1) {
-        help.argumentIndex = selected.parameters.length;
-      } else {
-        help.argumentIndex = Math.min(help.argumentIndex, selected.parameters.length - 1);
-      }
+        cancel(operationId) {
+          const pendingTimeout = this.pendingTimeouts.get(operationId);
+          if (!pendingTimeout)
+            return false;
+          this.host.clearTimeout(pendingTimeout);
+          return this.pendingTimeouts.delete(operationId);
+        }
+        static run(operationId, self, cb) {
+          var _a, _b;
+          (_a = perfLogger) == null ? void 0 : _a.logStartScheduledOperation(operationId);
+          self.pendingTimeouts.delete(operationId);
+          if (self.logger) {
+            self.logger.info(`Running: ${operationId}`);
+          }
+          cb();
+          (_b = perfLogger) == null ? void 0 : _b.logStopScheduledOperation();
+        }
+      };
+      GcTimer = class _GcTimer {
+        constructor(host, delay, logger) {
+          this.host = host;
+          this.delay = delay;
+          this.logger = logger;
+        }
+        scheduleCollect() {
+          if (!this.host.gc || this.timerId !== void 0) {
+            return;
+          }
+          this.timerId = this.host.setTimeout(_GcTimer.run, this.delay, this);
+        }
+        static run(self) {
+          var _a, _b;
+          self.timerId = void 0;
+          (_a = perfLogger) == null ? void 0 : _a.logStartScheduledOperation("GC collect");
+          const log = self.logger.hasLevel(2 /* requestTime */);
+          const before = log && self.host.getMemoryUsage();
+          self.host.gc();
+          if (log) {
+            const after = self.host.getMemoryUsage();
+            self.logger.perftrc(`GC::before ${before}, after ${after}`);
+          }
+          (_b = perfLogger) == null ? void 0 : _b.logStopScheduledOperation();
+        }
+      };
     }
-    return help;
-  }
-  function createTypeHelpItems(symbol, { argumentCount, argumentsSpan: applicableSpan, invocation, argumentIndex }, sourceFile, checker) {
-    const typeParameters = checker.getLocalTypeParametersOfClassOrInterfaceOrTypeAlias(symbol);
-    if (!typeParameters)
-      return void 0;
-    const items = [getTypeHelpItem(symbol, typeParameters, checker, getEnclosingDeclarationFromInvocation(invocation), sourceFile)];
-    return { items, applicableSpan, selectedItemIndex: 0, argumentIndex, argumentCount };
-  }
-  function getTypeHelpItem(symbol, typeParameters, checker, enclosingDeclaration, sourceFile) {
-    const typeSymbolDisplay = symbolToDisplayParts(checker, symbol);
-    const printer = createPrinterWithRemoveComments();
-    const parameters = typeParameters.map((t) => createSignatureHelpParameterForTypeParameter(t, checker, enclosingDeclaration, sourceFile, printer));
-    const documentation = symbol.getDocumentationComment(checker);
-    const tags = symbol.getJsDocTags(checker);
-    const prefixDisplayParts = [...typeSymbolDisplay, punctuationPart(30 /* LessThanToken */)];
-    return { isVariadic: false, prefixDisplayParts, suffixDisplayParts: [punctuationPart(32 /* GreaterThanToken */)], separatorDisplayParts, parameters, documentation, tags };
-  }
-  function getSignatureHelpItem(candidateSignature, callTargetDisplayParts, isTypeParameterList, checker, enclosingDeclaration, sourceFile) {
-    const infos = (isTypeParameterList ? itemInfoForTypeParameters : itemInfoForParameters)(candidateSignature, checker, enclosingDeclaration, sourceFile);
-    return map(infos, ({ isVariadic, parameters, prefix, suffix }) => {
-      const prefixDisplayParts = [...callTargetDisplayParts, ...prefix];
-      const suffixDisplayParts = [...suffix, ...returnTypeToDisplayParts(candidateSignature, enclosingDeclaration, checker)];
-      const documentation = candidateSignature.getDocumentationComment(checker);
-      const tags = candidateSignature.getJsDocTags();
-      return { isVariadic, prefixDisplayParts, suffixDisplayParts, separatorDisplayParts, parameters, documentation, tags };
-    });
-  }
-  function returnTypeToDisplayParts(candidateSignature, enclosingDeclaration, checker) {
-    return mapToDisplayParts((writer) => {
-      writer.writePunctuation(":");
-      writer.writeSpace(" ");
-      const predicate = checker.getTypePredicateOfSignature(candidateSignature);
-      if (predicate) {
-        checker.writeTypePredicate(
-          predicate,
-          enclosingDeclaration,
-          /*flags*/
-          void 0,
-          writer
-        );
-      } else {
-        checker.writeType(
-          checker.getReturnTypeOfSignature(candidateSignature),
-          enclosingDeclaration,
-          /*flags*/
-          void 0,
-          writer
-        );
-      }
-    });
-  }
-  function itemInfoForTypeParameters(candidateSignature, checker, enclosingDeclaration, sourceFile) {
-    const typeParameters = (candidateSignature.target || candidateSignature).typeParameters;
-    const printer = createPrinterWithRemoveComments();
-    const parameters = (typeParameters || emptyArray).map((t) => createSignatureHelpParameterForTypeParameter(t, checker, enclosingDeclaration, sourceFile, printer));
-    const thisParameter = candidateSignature.thisParameter ? [checker.symbolToParameterDeclaration(candidateSignature.thisParameter, enclosingDeclaration, signatureHelpNodeBuilderFlags)] : [];
-    return checker.getExpandedParameters(candidateSignature).map((paramList) => {
-      const params = factory.createNodeArray([...thisParameter, ...map(paramList, (param) => checker.symbolToParameterDeclaration(param, enclosingDeclaration, signatureHelpNodeBuilderFlags))]);
-      const parameterParts = mapToDisplayParts((writer) => {
-        printer.writeList(2576 /* CallExpressionArguments */, params, sourceFile, writer);
-      });
-      return { isVariadic: false, parameters, prefix: [punctuationPart(30 /* LessThanToken */)], suffix: [punctuationPart(32 /* GreaterThanToken */), ...parameterParts] };
-    });
-  }
-  function itemInfoForParameters(candidateSignature, checker, enclosingDeclaration, sourceFile) {
-    const printer = createPrinterWithRemoveComments();
-    const typeParameterParts = mapToDisplayParts((writer) => {
-      if (candidateSignature.typeParameters && candidateSignature.typeParameters.length) {
-        const args = factory.createNodeArray(candidateSignature.typeParameters.map((p) => checker.typeParameterToDeclaration(p, enclosingDeclaration, signatureHelpNodeBuilderFlags)));
-        printer.writeList(53776 /* TypeParameters */, args, sourceFile, writer);
-      }
-    });
-    const lists = checker.getExpandedParameters(candidateSignature);
-    const isVariadic = !checker.hasEffectiveRestParameter(candidateSignature) ? (_) => false : lists.length === 1 ? (_) => true : (pList) => {
-      var _a;
-      return !!(pList.length && ((_a = tryCast(pList[pList.length - 1], isTransientSymbol)) == null ? void 0 : _a.links.checkFlags) & 32768 /* RestParameter */);
-    };
-    return lists.map((parameterList) => ({
-      isVariadic: isVariadic(parameterList),
-      parameters: parameterList.map((p) => createSignatureHelpParameterForParameter(p, checker, enclosingDeclaration, sourceFile, printer)),
-      prefix: [...typeParameterParts, punctuationPart(21 /* OpenParenToken */)],
-      suffix: [punctuationPart(22 /* CloseParenToken */)]
-    }));
-  }
-  function createSignatureHelpParameterForParameter(parameter, checker, enclosingDeclaration, sourceFile, printer) {
-    const displayParts = mapToDisplayParts((writer) => {
-      const param = checker.symbolToParameterDeclaration(parameter, enclosingDeclaration, signatureHelpNodeBuilderFlags);
-      printer.writeNode(4 /* Unspecified */, param, sourceFile, writer);
-    });
-    const isOptional = checker.isOptionalParameter(parameter.valueDeclaration);
-    const isRest = isTransientSymbol(parameter) && !!(parameter.links.checkFlags & 32768 /* RestParameter */);
-    return { name: parameter.name, documentation: parameter.getDocumentationComment(checker), displayParts, isOptional, isRest };
-  }
-  function createSignatureHelpParameterForTypeParameter(typeParameter, checker, enclosingDeclaration, sourceFile, printer) {
-    const displayParts = mapToDisplayParts((writer) => {
-      const param = checker.typeParameterToDeclaration(typeParameter, enclosingDeclaration, signatureHelpNodeBuilderFlags);
-      printer.writeNode(4 /* Unspecified */, param, sourceFile, writer);
-    });
-    return { name: typeParameter.symbol.name, documentation: typeParameter.symbol.getDocumentationComment(checker), displayParts, isOptional: false, isRest: false };
-  }
-  var signatureHelpNodeBuilderFlags, separatorDisplayParts;
-  var init_signatureHelp = __esm({
-    "src/services/signatureHelp.ts"() {
+  });
+
+  // src/server/protocol.ts
+  var CommandTypes, OrganizeImportsMode2, WatchFileKind2, WatchDirectoryKind2, PollingWatchKind2, CompletionTriggerKind2, IndentStyle2, SemicolonPreference2, JsxEmit2, ModuleKind2, ModuleResolutionKind2, NewLineKind2, ScriptTarget10, ClassificationType2;
+  var init_protocol = __esm({
+    "src/server/protocol.ts"() {
       "use strict";
-      init_ts4();
-      signatureHelpNodeBuilderFlags = 8192 /* OmitParameterModifiers */ | 70221824 /* IgnoreErrors */ | 16384 /* UseAliasDefinedOutsideCurrentScope */;
-      separatorDisplayParts = [punctuationPart(28 /* CommaToken */), spacePart()];
+      CommandTypes = /* @__PURE__ */ ((CommandTypes2) => {
+        CommandTypes2["JsxClosingTag"] = "jsxClosingTag";
+        CommandTypes2["LinkedEditingRange"] = "linkedEditingRange";
+        CommandTypes2["Brace"] = "brace";
+        CommandTypes2["BraceFull"] = "brace-full";
+        CommandTypes2["BraceCompletion"] = "braceCompletion";
+        CommandTypes2["GetSpanOfEnclosingComment"] = "getSpanOfEnclosingComment";
+        CommandTypes2["Change"] = "change";
+        CommandTypes2["Close"] = "close";
+        CommandTypes2["Completions"] = "completions";
+        CommandTypes2["CompletionInfo"] = "completionInfo";
+        CommandTypes2["CompletionsFull"] = "completions-full";
+        CommandTypes2["CompletionDetails"] = "completionEntryDetails";
+        CommandTypes2["CompletionDetailsFull"] = "completionEntryDetails-full";
+        CommandTypes2["CompileOnSaveAffectedFileList"] = "compileOnSaveAffectedFileList";
+        CommandTypes2["CompileOnSaveEmitFile"] = "compileOnSaveEmitFile";
+        CommandTypes2["Configure"] = "configure";
+        CommandTypes2["Definition"] = "definition";
+        CommandTypes2["DefinitionFull"] = "definition-full";
+        CommandTypes2["DefinitionAndBoundSpan"] = "definitionAndBoundSpan";
+        CommandTypes2["DefinitionAndBoundSpanFull"] = "definitionAndBoundSpan-full";
+        CommandTypes2["Implementation"] = "implementation";
+        CommandTypes2["ImplementationFull"] = "implementation-full";
+        CommandTypes2["EmitOutput"] = "emit-output";
+        CommandTypes2["Exit"] = "exit";
+        CommandTypes2["FileReferences"] = "fileReferences";
+        CommandTypes2["FileReferencesFull"] = "fileReferences-full";
+        CommandTypes2["Format"] = "format";
+        CommandTypes2["Formatonkey"] = "formatonkey";
+        CommandTypes2["FormatFull"] = "format-full";
+        CommandTypes2["FormatonkeyFull"] = "formatonkey-full";
+        CommandTypes2["FormatRangeFull"] = "formatRange-full";
+        CommandTypes2["Geterr"] = "geterr";
+        CommandTypes2["GeterrForProject"] = "geterrForProject";
+        CommandTypes2["SemanticDiagnosticsSync"] = "semanticDiagnosticsSync";
+        CommandTypes2["SyntacticDiagnosticsSync"] = "syntacticDiagnosticsSync";
+        CommandTypes2["SuggestionDiagnosticsSync"] = "suggestionDiagnosticsSync";
+        CommandTypes2["NavBar"] = "navbar";
+        CommandTypes2["NavBarFull"] = "navbar-full";
+        CommandTypes2["Navto"] = "navto";
+        CommandTypes2["NavtoFull"] = "navto-full";
+        CommandTypes2["NavTree"] = "navtree";
+        CommandTypes2["NavTreeFull"] = "navtree-full";
+        CommandTypes2["DocumentHighlights"] = "documentHighlights";
+        CommandTypes2["DocumentHighlightsFull"] = "documentHighlights-full";
+        CommandTypes2["Open"] = "open";
+        CommandTypes2["Quickinfo"] = "quickinfo";
+        CommandTypes2["QuickinfoFull"] = "quickinfo-full";
+        CommandTypes2["References"] = "references";
+        CommandTypes2["ReferencesFull"] = "references-full";
+        CommandTypes2["Reload"] = "reload";
+        CommandTypes2["Rename"] = "rename";
+        CommandTypes2["RenameInfoFull"] = "rename-full";
+        CommandTypes2["RenameLocationsFull"] = "renameLocations-full";
+        CommandTypes2["Saveto"] = "saveto";
+        CommandTypes2["SignatureHelp"] = "signatureHelp";
+        CommandTypes2["SignatureHelpFull"] = "signatureHelp-full";
+        CommandTypes2["FindSourceDefinition"] = "findSourceDefinition";
+        CommandTypes2["Status"] = "status";
+        CommandTypes2["TypeDefinition"] = "typeDefinition";
+        CommandTypes2["ProjectInfo"] = "projectInfo";
+        CommandTypes2["ReloadProjects"] = "reloadProjects";
+        CommandTypes2["Unknown"] = "unknown";
+        CommandTypes2["OpenExternalProject"] = "openExternalProject";
+        CommandTypes2["OpenExternalProjects"] = "openExternalProjects";
+        CommandTypes2["CloseExternalProject"] = "closeExternalProject";
+        CommandTypes2["SynchronizeProjectList"] = "synchronizeProjectList";
+        CommandTypes2["ApplyChangedToOpenFiles"] = "applyChangedToOpenFiles";
+        CommandTypes2["UpdateOpen"] = "updateOpen";
+        CommandTypes2["EncodedSyntacticClassificationsFull"] = "encodedSyntacticClassifications-full";
+        CommandTypes2["EncodedSemanticClassificationsFull"] = "encodedSemanticClassifications-full";
+        CommandTypes2["Cleanup"] = "cleanup";
+        CommandTypes2["GetOutliningSpans"] = "getOutliningSpans";
+        CommandTypes2["GetOutliningSpansFull"] = "outliningSpans";
+        CommandTypes2["TodoComments"] = "todoComments";
+        CommandTypes2["Indentation"] = "indentation";
+        CommandTypes2["DocCommentTemplate"] = "docCommentTemplate";
+        CommandTypes2["CompilerOptionsDiagnosticsFull"] = "compilerOptionsDiagnostics-full";
+        CommandTypes2["NameOrDottedNameSpan"] = "nameOrDottedNameSpan";
+        CommandTypes2["BreakpointStatement"] = "breakpointStatement";
+        CommandTypes2["CompilerOptionsForInferredProjects"] = "compilerOptionsForInferredProjects";
+        CommandTypes2["GetCodeFixes"] = "getCodeFixes";
+        CommandTypes2["GetCodeFixesFull"] = "getCodeFixes-full";
+        CommandTypes2["GetCombinedCodeFix"] = "getCombinedCodeFix";
+        CommandTypes2["GetCombinedCodeFixFull"] = "getCombinedCodeFix-full";
+        CommandTypes2["ApplyCodeActionCommand"] = "applyCodeActionCommand";
+        CommandTypes2["GetSupportedCodeFixes"] = "getSupportedCodeFixes";
+        CommandTypes2["GetApplicableRefactors"] = "getApplicableRefactors";
+        CommandTypes2["GetEditsForRefactor"] = "getEditsForRefactor";
+        CommandTypes2["GetMoveToRefactoringFileSuggestions"] = "getMoveToRefactoringFileSuggestions";
+        CommandTypes2["GetEditsForRefactorFull"] = "getEditsForRefactor-full";
+        CommandTypes2["OrganizeImports"] = "organizeImports";
+        CommandTypes2["OrganizeImportsFull"] = "organizeImports-full";
+        CommandTypes2["GetEditsForFileRename"] = "getEditsForFileRename";
+        CommandTypes2["GetEditsForFileRenameFull"] = "getEditsForFileRename-full";
+        CommandTypes2["ConfigurePlugin"] = "configurePlugin";
+        CommandTypes2["SelectionRange"] = "selectionRange";
+        CommandTypes2["SelectionRangeFull"] = "selectionRange-full";
+        CommandTypes2["ToggleLineComment"] = "toggleLineComment";
+        CommandTypes2["ToggleLineCommentFull"] = "toggleLineComment-full";
+        CommandTypes2["ToggleMultilineComment"] = "toggleMultilineComment";
+        CommandTypes2["ToggleMultilineCommentFull"] = "toggleMultilineComment-full";
+        CommandTypes2["CommentSelection"] = "commentSelection";
+        CommandTypes2["CommentSelectionFull"] = "commentSelection-full";
+        CommandTypes2["UncommentSelection"] = "uncommentSelection";
+        CommandTypes2["UncommentSelectionFull"] = "uncommentSelection-full";
+        CommandTypes2["PrepareCallHierarchy"] = "prepareCallHierarchy";
+        CommandTypes2["ProvideCallHierarchyIncomingCalls"] = "provideCallHierarchyIncomingCalls";
+        CommandTypes2["ProvideCallHierarchyOutgoingCalls"] = "provideCallHierarchyOutgoingCalls";
+        CommandTypes2["ProvideInlayHints"] = "provideInlayHints";
+        CommandTypes2["WatchChange"] = "watchChange";
+        return CommandTypes2;
+      })(CommandTypes || {});
+      OrganizeImportsMode2 = /* @__PURE__ */ ((OrganizeImportsMode3) => {
+        OrganizeImportsMode3["All"] = "All";
+        OrganizeImportsMode3["SortAndCombine"] = "SortAndCombine";
+        OrganizeImportsMode3["RemoveUnused"] = "RemoveUnused";
+        return OrganizeImportsMode3;
+      })(OrganizeImportsMode2 || {});
+      WatchFileKind2 = /* @__PURE__ */ ((WatchFileKind3) => {
+        WatchFileKind3["FixedPollingInterval"] = "FixedPollingInterval";
+        WatchFileKind3["PriorityPollingInterval"] = "PriorityPollingInterval";
+        WatchFileKind3["DynamicPriorityPolling"] = "DynamicPriorityPolling";
+        WatchFileKind3["FixedChunkSizePolling"] = "FixedChunkSizePolling";
+        WatchFileKind3["UseFsEvents"] = "UseFsEvents";
+        WatchFileKind3["UseFsEventsOnParentDirectory"] = "UseFsEventsOnParentDirectory";
+        return WatchFileKind3;
+      })(WatchFileKind2 || {});
+      WatchDirectoryKind2 = /* @__PURE__ */ ((WatchDirectoryKind3) => {
+        WatchDirectoryKind3["UseFsEvents"] = "UseFsEvents";
+        WatchDirectoryKind3["FixedPollingInterval"] = "FixedPollingInterval";
+        WatchDirectoryKind3["DynamicPriorityPolling"] = "DynamicPriorityPolling";
+        WatchDirectoryKind3["FixedChunkSizePolling"] = "FixedChunkSizePolling";
+        return WatchDirectoryKind3;
+      })(WatchDirectoryKind2 || {});
+      PollingWatchKind2 = /* @__PURE__ */ ((PollingWatchKind3) => {
+        PollingWatchKind3["FixedInterval"] = "FixedInterval";
+        PollingWatchKind3["PriorityInterval"] = "PriorityInterval";
+        PollingWatchKind3["DynamicPriority"] = "DynamicPriority";
+        PollingWatchKind3["FixedChunkSize"] = "FixedChunkSize";
+        return PollingWatchKind3;
+      })(PollingWatchKind2 || {});
+      CompletionTriggerKind2 = /* @__PURE__ */ ((CompletionTriggerKind4) => {
+        CompletionTriggerKind4[CompletionTriggerKind4["Invoked"] = 1] = "Invoked";
+        CompletionTriggerKind4[CompletionTriggerKind4["TriggerCharacter"] = 2] = "TriggerCharacter";
+        CompletionTriggerKind4[CompletionTriggerKind4["TriggerForIncompleteCompletions"] = 3] = "TriggerForIncompleteCompletions";
+        return CompletionTriggerKind4;
+      })(CompletionTriggerKind2 || {});
+      IndentStyle2 = /* @__PURE__ */ ((IndentStyle3) => {
+        IndentStyle3["None"] = "None";
+        IndentStyle3["Block"] = "Block";
+        IndentStyle3["Smart"] = "Smart";
+        return IndentStyle3;
+      })(IndentStyle2 || {});
+      SemicolonPreference2 = /* @__PURE__ */ ((SemicolonPreference3) => {
+        SemicolonPreference3["Ignore"] = "ignore";
+        SemicolonPreference3["Insert"] = "insert";
+        SemicolonPreference3["Remove"] = "remove";
+        return SemicolonPreference3;
+      })(SemicolonPreference2 || {});
+      JsxEmit2 = /* @__PURE__ */ ((JsxEmit3) => {
+        JsxEmit3["None"] = "None";
+        JsxEmit3["Preserve"] = "Preserve";
+        JsxEmit3["ReactNative"] = "ReactNative";
+        JsxEmit3["React"] = "React";
+        return JsxEmit3;
+      })(JsxEmit2 || {});
+      ModuleKind2 = /* @__PURE__ */ ((ModuleKind3) => {
+        ModuleKind3["None"] = "None";
+        ModuleKind3["CommonJS"] = "CommonJS";
+        ModuleKind3["AMD"] = "AMD";
+        ModuleKind3["UMD"] = "UMD";
+        ModuleKind3["System"] = "System";
+        ModuleKind3["ES6"] = "ES6";
+        ModuleKind3["ES2015"] = "ES2015";
+        ModuleKind3["ESNext"] = "ESNext";
+        return ModuleKind3;
+      })(ModuleKind2 || {});
+      ModuleResolutionKind2 = /* @__PURE__ */ ((ModuleResolutionKind3) => {
+        ModuleResolutionKind3["Classic"] = "Classic";
+        ModuleResolutionKind3["Node"] = "Node";
+        return ModuleResolutionKind3;
+      })(ModuleResolutionKind2 || {});
+      NewLineKind2 = /* @__PURE__ */ ((NewLineKind3) => {
+        NewLineKind3["Crlf"] = "Crlf";
+        NewLineKind3["Lf"] = "Lf";
+        return NewLineKind3;
+      })(NewLineKind2 || {});
+      ScriptTarget10 = /* @__PURE__ */ ((ScriptTarget11) => {
+        ScriptTarget11["ES3"] = "ES3";
+        ScriptTarget11["ES5"] = "ES5";
+        ScriptTarget11["ES6"] = "ES6";
+        ScriptTarget11["ES2015"] = "ES2015";
+        ScriptTarget11["ES2016"] = "ES2016";
+        ScriptTarget11["ES2017"] = "ES2017";
+        ScriptTarget11["ES2018"] = "ES2018";
+        ScriptTarget11["ES2019"] = "ES2019";
+        ScriptTarget11["ES2020"] = "ES2020";
+        ScriptTarget11["ES2021"] = "ES2021";
+        ScriptTarget11["ES2022"] = "ES2022";
+        ScriptTarget11["ESNext"] = "ESNext";
+        return ScriptTarget11;
+      })(ScriptTarget10 || {});
+      ClassificationType2 = /* @__PURE__ */ ((ClassificationType3) => {
+        ClassificationType3[ClassificationType3["comment"] = 1] = "comment";
+        ClassificationType3[ClassificationType3["identifier"] = 2] = "identifier";
+        ClassificationType3[ClassificationType3["keyword"] = 3] = "keyword";
+        ClassificationType3[ClassificationType3["numericLiteral"] = 4] = "numericLiteral";
+        ClassificationType3[ClassificationType3["operator"] = 5] = "operator";
+        ClassificationType3[ClassificationType3["stringLiteral"] = 6] = "stringLiteral";
+        ClassificationType3[ClassificationType3["regularExpressionLiteral"] = 7] = "regularExpressionLiteral";
+        ClassificationType3[ClassificationType3["whiteSpace"] = 8] = "whiteSpace";
+        ClassificationType3[ClassificationType3["text"] = 9] = "text";
+        ClassificationType3[ClassificationType3["punctuation"] = 10] = "punctuation";
+        ClassificationType3[ClassificationType3["className"] = 11] = "className";
+        ClassificationType3[ClassificationType3["enumName"] = 12] = "enumName";
+        ClassificationType3[ClassificationType3["interfaceName"] = 13] = "interfaceName";
+        ClassificationType3[ClassificationType3["moduleName"] = 14] = "moduleName";
+        ClassificationType3[ClassificationType3["typeParameterName"] = 15] = "typeParameterName";
+        ClassificationType3[ClassificationType3["typeAliasName"] = 16] = "typeAliasName";
+        ClassificationType3[ClassificationType3["parameterName"] = 17] = "parameterName";
+        ClassificationType3[ClassificationType3["docCommentTagName"] = 18] = "docCommentTagName";
+        ClassificationType3[ClassificationType3["jsxOpenTagName"] = 19] = "jsxOpenTagName";
+        ClassificationType3[ClassificationType3["jsxCloseTagName"] = 20] = "jsxCloseTagName";
+        ClassificationType3[ClassificationType3["jsxSelfClosingTagName"] = 21] = "jsxSelfClosingTagName";
+        ClassificationType3[ClassificationType3["jsxAttribute"] = 22] = "jsxAttribute";
+        ClassificationType3[ClassificationType3["jsxText"] = 23] = "jsxText";
+        ClassificationType3[ClassificationType3["jsxAttributeStringLiteralValue"] = 24] = "jsxAttributeStringLiteralValue";
+        ClassificationType3[ClassificationType3["bigintLiteral"] = 25] = "bigintLiteral";
+        return ClassificationType3;
+      })(ClassificationType2 || {});
     }
   });
 
-  // src/services/_namespaces/ts.SignatureHelp.ts
-  var ts_SignatureHelp_exports = {};
-  __export(ts_SignatureHelp_exports, {
-    getArgumentInfoForCompletions: () => getArgumentInfoForCompletions,
-    getSignatureHelpItems: () => getSignatureHelpItems
+  // src/server/_namespaces/ts.server.protocol.ts
+  var ts_server_protocol_exports = {};
+  __export(ts_server_protocol_exports, {
+    ClassificationType: () => ClassificationType2,
+    CommandTypes: () => CommandTypes,
+    CompletionTriggerKind: () => CompletionTriggerKind2,
+    IndentStyle: () => IndentStyle2,
+    JsxEmit: () => JsxEmit2,
+    ModuleKind: () => ModuleKind2,
+    ModuleResolutionKind: () => ModuleResolutionKind2,
+    NewLineKind: () => NewLineKind2,
+    OrganizeImportsMode: () => OrganizeImportsMode2,
+    PollingWatchKind: () => PollingWatchKind2,
+    ScriptTarget: () => ScriptTarget10,
+    SemicolonPreference: () => SemicolonPreference2,
+    WatchDirectoryKind: () => WatchDirectoryKind2,
+    WatchFileKind: () => WatchFileKind2
   });
-  var init_ts_SignatureHelp = __esm({
-    "src/services/_namespaces/ts.SignatureHelp.ts"() {
+  var init_ts_server_protocol = __esm({
+    "src/server/_namespaces/ts.server.protocol.ts"() {
       "use strict";
-      init_signatureHelp();
+      init_protocol();
     }
   });
 
-  // src/services/smartSelection.ts
-  function getSmartSelectionRange(pos, sourceFile) {
-    var _a, _b;
-    let selectionRange = {
-      textSpan: createTextSpanFromBounds(sourceFile.getFullStart(), sourceFile.getEnd())
-    };
-    let parentNode = sourceFile;
-    outer:
-      while (true) {
-        const children = getSelectionChildren(parentNode);
-        if (!children.length)
-          break;
-        for (let i = 0; i < children.length; i++) {
-          const prevNode = children[i - 1];
-          const node = children[i];
-          const nextNode = children[i + 1];
-          if (getTokenPosOfNode(
-            node,
-            sourceFile,
-            /*includeJsDoc*/
-            true
-          ) > pos) {
-            break outer;
+  // src/server/scriptInfo.ts
+  function isDynamicFileName(fileName) {
+    return fileName[0] === "^" || (fileName.includes("walkThroughSnippet:/") || fileName.includes("untitled:/")) && getBaseFileName(fileName)[0] === "^" || fileName.includes(":^") && !fileName.includes(directorySeparator);
+  }
+  function ensurePrimaryProjectKind(project) {
+    if (!project || isBackgroundProject(project)) {
+      return Errors.ThrowNoProject();
+    }
+    return project;
+  }
+  function failIfInvalidPosition(position) {
+    Debug.assert(typeof position === "number", `Expected position ${position} to be a number.`);
+    Debug.assert(position >= 0, `Expected position to be non-negative.`);
+  }
+  function failIfInvalidLocation(location) {
+    Debug.assert(typeof location.line === "number", `Expected line ${location.line} to be a number.`);
+    Debug.assert(typeof location.offset === "number", `Expected offset ${location.offset} to be a number.`);
+    Debug.assert(location.line > 0, `Expected line to be non-${location.line === 0 ? "zero" : "negative"}`);
+    Debug.assert(location.offset > 0, `Expected offset to be non-${location.offset === 0 ? "zero" : "negative"}`);
+  }
+  var TextStorage, ScriptInfo;
+  var init_scriptInfo = __esm({
+    "src/server/scriptInfo.ts"() {
+      "use strict";
+      init_ts7();
+      init_ts_server3();
+      TextStorage = class {
+        constructor(host, info, initialVersion) {
+          this.host = host;
+          this.info = info;
+          /**
+           * True if the text is for the file thats open in the editor
+           */
+          this.isOpen = false;
+          /**
+           * True if the text present is the text from the file on the disk
+           */
+          this.ownFileText = false;
+          /**
+           * True when reloading contents of file from the disk is pending
+           */
+          this.pendingReloadFromDisk = false;
+          this.version = initialVersion || 0;
+        }
+        getVersion() {
+          return this.svc ? `SVC-${this.version}-${this.svc.getSnapshotVersion()}` : `Text-${this.version}`;
+        }
+        hasScriptVersionCache_TestOnly() {
+          return this.svc !== void 0;
+        }
+        resetSourceMapInfo() {
+          this.info.sourceFileLike = void 0;
+          this.info.closeSourceMapFileWatcher();
+          this.info.sourceMapFilePath = void 0;
+          this.info.declarationInfoPath = void 0;
+          this.info.sourceInfos = void 0;
+          this.info.documentPositionMapper = void 0;
+        }
+        /** Public for testing */
+        useText(newText) {
+          this.svc = void 0;
+          this.text = newText;
+          this.textSnapshot = void 0;
+          this.lineMap = void 0;
+          this.fileSize = void 0;
+          this.resetSourceMapInfo();
+          this.version++;
+        }
+        edit(start, end, newText) {
+          this.switchToScriptVersionCache().edit(start, end - start, newText);
+          this.ownFileText = false;
+          this.text = void 0;
+          this.textSnapshot = void 0;
+          this.lineMap = void 0;
+          this.fileSize = void 0;
+          this.resetSourceMapInfo();
+        }
+        /**
+         * Set the contents as newText
+         * returns true if text changed
+         */
+        reload(newText) {
+          Debug.assert(newText !== void 0);
+          this.pendingReloadFromDisk = false;
+          if (!this.text && this.svc) {
+            this.text = getSnapshotText(this.svc.getSnapshot());
+          }
+          if (this.text !== newText) {
+            this.useText(newText);
+            this.ownFileText = false;
+            return true;
           }
-          const comment = singleOrUndefined(getTrailingCommentRanges(sourceFile.text, node.end));
-          if (comment && comment.kind === 2 /* SingleLineCommentTrivia */) {
-            pushSelectionCommentRange(comment.pos, comment.end);
+          return false;
+        }
+        /**
+         * Reads the contents from tempFile(if supplied) or own file and sets it as contents
+         * returns true if text changed
+         */
+        reloadWithFileText(tempFileName) {
+          const { text: newText, fileSize } = tempFileName || !this.info.isDynamicOrHasMixedContent() ? this.getFileTextAndSize(tempFileName) : { text: "", fileSize: void 0 };
+          const reloaded = this.reload(newText);
+          this.fileSize = fileSize;
+          this.ownFileText = !tempFileName || tempFileName === this.info.fileName;
+          return reloaded;
+        }
+        /**
+         * Schedule reload from the disk if its not already scheduled and its not own text
+         * returns true when scheduling reload
+         */
+        scheduleReloadIfNeeded() {
+          return !this.pendingReloadFromDisk && !this.ownFileText ? this.pendingReloadFromDisk = true : false;
+        }
+        delayReloadFromFileIntoText() {
+          this.pendingReloadFromDisk = true;
+        }
+        /**
+         * For telemetry purposes, we would like to be able to report the size of the file.
+         * However, we do not want telemetry to require extra file I/O so we report a size
+         * that may be stale (e.g. may not reflect change made on disk since the last reload).
+         * NB: Will read from disk if the file contents have never been loaded because
+         * telemetry falsely indicating size 0 would be counter-productive.
+         */
+        getTelemetryFileSize() {
+          return !!this.fileSize ? this.fileSize : !!this.text ? this.text.length : !!this.svc ? this.svc.getSnapshot().getLength() : this.getSnapshot().getLength();
+        }
+        getSnapshot() {
+          var _a;
+          return ((_a = this.tryUseScriptVersionCache()) == null ? void 0 : _a.getSnapshot()) || (this.textSnapshot ?? (this.textSnapshot = ScriptSnapshot.fromString(Debug.checkDefined(this.text))));
+        }
+        getAbsolutePositionAndLineText(oneBasedLine) {
+          const svc = this.tryUseScriptVersionCache();
+          if (svc)
+            return svc.getAbsolutePositionAndLineText(oneBasedLine);
+          const lineMap = this.getLineMap();
+          return oneBasedLine <= lineMap.length ? {
+            absolutePosition: lineMap[oneBasedLine - 1],
+            lineText: this.text.substring(lineMap[oneBasedLine - 1], lineMap[oneBasedLine])
+          } : {
+            absolutePosition: this.text.length,
+            lineText: void 0
+          };
+        }
+        /**
+         *  @param line 0 based index
+         */
+        lineToTextSpan(line) {
+          const svc = this.tryUseScriptVersionCache();
+          if (svc)
+            return svc.lineToTextSpan(line);
+          const lineMap = this.getLineMap();
+          const start = lineMap[line];
+          const end = line + 1 < lineMap.length ? lineMap[line + 1] : this.text.length;
+          return createTextSpanFromBounds(start, end);
+        }
+        /**
+         * @param line 1 based index
+         * @param offset 1 based index
+         */
+        lineOffsetToPosition(line, offset, allowEdits) {
+          const svc = this.tryUseScriptVersionCache();
+          return svc ? svc.lineOffsetToPosition(line, offset) : computePositionOfLineAndCharacter(this.getLineMap(), line - 1, offset - 1, this.text, allowEdits);
+        }
+        positionToLineOffset(position) {
+          const svc = this.tryUseScriptVersionCache();
+          if (svc)
+            return svc.positionToLineOffset(position);
+          const { line, character } = computeLineAndCharacterOfPosition(this.getLineMap(), position);
+          return { line: line + 1, offset: character + 1 };
+        }
+        getFileTextAndSize(tempFileName) {
+          let text;
+          const fileName = tempFileName || this.info.fileName;
+          const getText = () => text === void 0 ? text = this.host.readFile(fileName) || "" : text;
+          if (!hasTSFileExtension(this.info.fileName)) {
+            const fileSize = this.host.getFileSize ? this.host.getFileSize(fileName) : getText().length;
+            if (fileSize > maxFileSize) {
+              Debug.assert(!!this.info.containingProjects.length);
+              const service = this.info.containingProjects[0].projectService;
+              service.logger.info(`Skipped loading contents of large file ${fileName} for info ${this.info.fileName}: fileSize: ${fileSize}`);
+              this.info.containingProjects[0].projectService.sendLargeFileReferencedEvent(fileName, fileSize);
+              return { text: "", fileSize };
+            }
+          }
+          return { text: getText() };
+        }
+        /** @internal */
+        switchToScriptVersionCache() {
+          if (!this.svc || this.pendingReloadFromDisk) {
+            this.svc = ScriptVersionCache.fromString(this.getOrLoadText());
+            this.textSnapshot = void 0;
+            this.version++;
           }
-          if (positionShouldSnapToNode(sourceFile, pos, node)) {
-            if (isFunctionBody(node) && isFunctionLikeDeclaration(parentNode) && !positionsAreOnSameLine(node.getStart(sourceFile), node.getEnd(), sourceFile)) {
-              pushSelectionRange(node.getStart(sourceFile), node.getEnd());
+          return this.svc;
+        }
+        tryUseScriptVersionCache() {
+          if (!this.svc || this.pendingReloadFromDisk) {
+            this.getOrLoadText();
+          }
+          if (this.isOpen) {
+            if (!this.svc && !this.textSnapshot) {
+              this.svc = ScriptVersionCache.fromString(Debug.checkDefined(this.text));
+              this.textSnapshot = void 0;
             }
-            if (isBlock(node) || isTemplateSpan(node) || isTemplateHead(node) || isTemplateTail(node) || prevNode && isTemplateHead(prevNode) || isVariableDeclarationList(node) && isVariableStatement(parentNode) || isSyntaxList(node) && isVariableDeclarationList(parentNode) || isVariableDeclaration(node) && isSyntaxList(parentNode) && children.length === 1 || isJSDocTypeExpression(node) || isJSDocSignature(node) || isJSDocTypeLiteral(node)) {
-              parentNode = node;
-              break;
+            return this.svc;
+          }
+          return this.svc;
+        }
+        getOrLoadText() {
+          if (this.text === void 0 || this.pendingReloadFromDisk) {
+            Debug.assert(!this.svc || this.pendingReloadFromDisk, "ScriptVersionCache should not be set when reloading from disk");
+            this.reloadWithFileText();
+          }
+          return this.text;
+        }
+        getLineMap() {
+          Debug.assert(!this.svc, "ScriptVersionCache should not be set");
+          return this.lineMap || (this.lineMap = computeLineStarts(Debug.checkDefined(this.text)));
+        }
+        getLineInfo() {
+          const svc = this.tryUseScriptVersionCache();
+          if (svc) {
+            return {
+              getLineCount: () => svc.getLineCount(),
+              getLineText: (line) => svc.getAbsolutePositionAndLineText(line + 1).lineText
+            };
+          }
+          const lineMap = this.getLineMap();
+          return getLineInfo(this.text, lineMap);
+        }
+      };
+      ScriptInfo = class {
+        constructor(host, fileName, scriptKind, hasMixedContent, path, initialVersion) {
+          this.host = host;
+          this.fileName = fileName;
+          this.scriptKind = scriptKind;
+          this.hasMixedContent = hasMixedContent;
+          this.path = path;
+          /**
+           * All projects that include this file
+           */
+          this.containingProjects = [];
+          this.isDynamic = isDynamicFileName(fileName);
+          this.textStorage = new TextStorage(host, this, initialVersion);
+          if (hasMixedContent || this.isDynamic) {
+            this.realpath = this.path;
+          }
+          this.scriptKind = scriptKind ? scriptKind : getScriptKindFromFileName(fileName);
+        }
+        /** @internal */
+        isDynamicOrHasMixedContent() {
+          return this.hasMixedContent || this.isDynamic;
+        }
+        isScriptOpen() {
+          return this.textStorage.isOpen;
+        }
+        open(newText) {
+          this.textStorage.isOpen = true;
+          if (newText !== void 0 && this.textStorage.reload(newText)) {
+            this.markContainingProjectsAsDirty();
+          }
+        }
+        close(fileExists = true) {
+          this.textStorage.isOpen = false;
+          if (fileExists && this.textStorage.scheduleReloadIfNeeded()) {
+            this.markContainingProjectsAsDirty();
+          }
+        }
+        getSnapshot() {
+          return this.textStorage.getSnapshot();
+        }
+        ensureRealPath() {
+          if (this.realpath === void 0) {
+            this.realpath = this.path;
+            if (this.host.realpath) {
+              Debug.assert(!!this.containingProjects.length);
+              const project = this.containingProjects[0];
+              const realpath = this.host.realpath(this.path);
+              if (realpath) {
+                this.realpath = project.toPath(realpath);
+                if (this.realpath !== this.path) {
+                  project.projectService.realpathToScriptInfos.add(this.realpath, this);
+                }
+              }
             }
-            if (isTemplateSpan(parentNode) && nextNode && isTemplateMiddleOrTemplateTail(nextNode)) {
-              const start2 = node.getFullStart() - "${".length;
-              const end2 = nextNode.getStart() + "}".length;
-              pushSelectionRange(start2, end2);
+          }
+        }
+        /** @internal */
+        getRealpathIfDifferent() {
+          return this.realpath && this.realpath !== this.path ? this.realpath : void 0;
+        }
+        /**
+         * @internal
+         * Does not compute realpath; uses precomputed result. Use `ensureRealPath`
+         * first if a definite result is needed.
+         */
+        isSymlink() {
+          return this.realpath && this.realpath !== this.path;
+        }
+        getFormatCodeSettings() {
+          return this.formatSettings;
+        }
+        getPreferences() {
+          return this.preferences;
+        }
+        attachToProject(project) {
+          const isNew = !this.isAttached(project);
+          if (isNew) {
+            this.containingProjects.push(project);
+            if (!project.getCompilerOptions().preserveSymlinks) {
+              this.ensureRealPath();
             }
-            const isBetweenMultiLineBookends = isSyntaxList(node) && isListOpener(prevNode) && isListCloser(nextNode) && !positionsAreOnSameLine(prevNode.getStart(), nextNode.getStart(), sourceFile);
-            let start = isBetweenMultiLineBookends ? prevNode.getEnd() : node.getStart();
-            const end = isBetweenMultiLineBookends ? nextNode.getStart() : getEndPos(sourceFile, node);
-            if (hasJSDocNodes(node) && ((_a = node.jsDoc) == null ? void 0 : _a.length)) {
-              pushSelectionRange(first(node.jsDoc).getStart(), end);
+            project.onFileAddedOrRemoved(this.isSymlink());
+          }
+          return isNew;
+        }
+        isAttached(project) {
+          switch (this.containingProjects.length) {
+            case 0:
+              return false;
+            case 1:
+              return this.containingProjects[0] === project;
+            case 2:
+              return this.containingProjects[0] === project || this.containingProjects[1] === project;
+            default:
+              return contains(this.containingProjects, project);
+          }
+        }
+        detachFromProject(project) {
+          switch (this.containingProjects.length) {
+            case 0:
+              return;
+            case 1:
+              if (this.containingProjects[0] === project) {
+                project.onFileAddedOrRemoved(this.isSymlink());
+                this.containingProjects.pop();
+              }
+              break;
+            case 2:
+              if (this.containingProjects[0] === project) {
+                project.onFileAddedOrRemoved(this.isSymlink());
+                this.containingProjects[0] = this.containingProjects.pop();
+              } else if (this.containingProjects[1] === project) {
+                project.onFileAddedOrRemoved(this.isSymlink());
+                this.containingProjects.pop();
+              }
+              break;
+            default:
+              if (unorderedRemoveItem(this.containingProjects, project)) {
+                project.onFileAddedOrRemoved(this.isSymlink());
+              }
+              break;
+          }
+        }
+        detachAllProjects() {
+          for (const p of this.containingProjects) {
+            if (isConfiguredProject(p)) {
+              p.getCachedDirectoryStructureHost().addOrDeleteFile(this.fileName, this.path, 2 /* Deleted */);
+            }
+            const existingRoot = p.getRootFilesMap().get(this.path);
+            p.removeFile(
+              this,
+              /*fileExists*/
+              false,
+              /*detachFromProject*/
+              false
+            );
+            p.onFileAddedOrRemoved(this.isSymlink());
+            if (existingRoot && !isInferredProject(p)) {
+              p.addMissingFileRoot(existingRoot.fileName);
             }
-            if (isSyntaxList(node)) {
-              const firstChild = node.getChildren()[0];
-              if (firstChild && hasJSDocNodes(firstChild) && ((_b = firstChild.jsDoc) == null ? void 0 : _b.length) && firstChild.getStart() !== node.pos) {
-                start = Math.min(start, first(firstChild.jsDoc).getStart());
+          }
+          clear(this.containingProjects);
+        }
+        getDefaultProject() {
+          switch (this.containingProjects.length) {
+            case 0:
+              return Errors.ThrowNoProject();
+            case 1:
+              return ensurePrimaryProjectKind(this.containingProjects[0]);
+            default:
+              let firstExternalProject;
+              let firstConfiguredProject;
+              let firstInferredProject;
+              let firstNonSourceOfProjectReferenceRedirect;
+              let defaultConfiguredProject;
+              for (let index = 0; index < this.containingProjects.length; index++) {
+                const project = this.containingProjects[index];
+                if (isConfiguredProject(project)) {
+                  if (!project.isSourceOfProjectReferenceRedirect(this.fileName)) {
+                    if (defaultConfiguredProject === void 0 && index !== this.containingProjects.length - 1) {
+                      defaultConfiguredProject = project.projectService.findDefaultConfiguredProject(this) || false;
+                    }
+                    if (defaultConfiguredProject === project)
+                      return project;
+                    if (!firstNonSourceOfProjectReferenceRedirect)
+                      firstNonSourceOfProjectReferenceRedirect = project;
+                  }
+                  if (!firstConfiguredProject)
+                    firstConfiguredProject = project;
+                } else if (!firstExternalProject && isExternalProject(project)) {
+                  firstExternalProject = project;
+                } else if (!firstInferredProject && isInferredProject(project)) {
+                  firstInferredProject = project;
+                }
               }
+              return ensurePrimaryProjectKind(
+                defaultConfiguredProject || firstNonSourceOfProjectReferenceRedirect || firstConfiguredProject || firstExternalProject || firstInferredProject
+              );
+          }
+        }
+        registerFileUpdate() {
+          for (const p of this.containingProjects) {
+            p.registerFileUpdate(this.path);
+          }
+        }
+        setOptions(formatSettings, preferences) {
+          if (formatSettings) {
+            if (!this.formatSettings) {
+              this.formatSettings = getDefaultFormatCodeSettings(this.host.newLine);
+              assign(this.formatSettings, formatSettings);
+            } else {
+              this.formatSettings = { ...this.formatSettings, ...formatSettings };
             }
-            pushSelectionRange(start, end);
-            if (isStringLiteral(node) || isTemplateLiteral(node)) {
-              pushSelectionRange(start + 1, end - 1);
+          }
+          if (preferences) {
+            if (!this.preferences) {
+              this.preferences = emptyOptions;
             }
-            parentNode = node;
-            break;
+            this.preferences = { ...this.preferences, ...preferences };
           }
-          if (i === children.length - 1) {
-            break outer;
+        }
+        getLatestVersion() {
+          this.textStorage.getSnapshot();
+          return this.textStorage.getVersion();
+        }
+        saveTo(fileName) {
+          this.host.writeFile(fileName, getSnapshotText(this.textStorage.getSnapshot()));
+        }
+        /** @internal */
+        delayReloadNonMixedContentFile() {
+          Debug.assert(!this.isDynamicOrHasMixedContent());
+          this.textStorage.delayReloadFromFileIntoText();
+          this.markContainingProjectsAsDirty();
+        }
+        reloadFromFile(tempFileName) {
+          if (this.textStorage.reloadWithFileText(tempFileName)) {
+            this.markContainingProjectsAsDirty();
+            return true;
           }
+          return false;
         }
-      }
-    return selectionRange;
-    function pushSelectionRange(start, end) {
-      if (start !== end) {
-        const textSpan = createTextSpanFromBounds(start, end);
-        if (!selectionRange || // Skip ranges that are identical to the parent
-        !textSpansEqual(textSpan, selectionRange.textSpan) && // Skip ranges that don't contain the original position
-        textSpanIntersectsWithPosition(textSpan, pos)) {
-          selectionRange = { textSpan, ...selectionRange && { parent: selectionRange } };
+        editContent(start, end, newText) {
+          this.textStorage.edit(start, end, newText);
+          this.markContainingProjectsAsDirty();
         }
-      }
-    }
-    function pushSelectionCommentRange(start, end) {
-      pushSelectionRange(start, end);
-      let pos2 = start;
-      while (sourceFile.text.charCodeAt(pos2) === 47 /* slash */) {
-        pos2++;
-      }
-      pushSelectionRange(pos2, end);
+        markContainingProjectsAsDirty() {
+          for (const p of this.containingProjects) {
+            p.markFileAsDirty(this.path);
+          }
+        }
+        isOrphan() {
+          return !forEach(this.containingProjects, (p) => !p.isOrphan());
+        }
+        /** @internal */
+        isContainedByBackgroundProject() {
+          return some(
+            this.containingProjects,
+            isBackgroundProject
+          );
+        }
+        /**
+         *  @param line 1 based index
+         */
+        lineToTextSpan(line) {
+          return this.textStorage.lineToTextSpan(line);
+        }
+        // eslint-disable-line @typescript-eslint/unified-signatures
+        lineOffsetToPosition(line, offset, allowEdits) {
+          return this.textStorage.lineOffsetToPosition(line, offset, allowEdits);
+        }
+        positionToLineOffset(position) {
+          failIfInvalidPosition(position);
+          const location = this.textStorage.positionToLineOffset(position);
+          failIfInvalidLocation(location);
+          return location;
+        }
+        isJavaScript() {
+          return this.scriptKind === 1 /* JS */ || this.scriptKind === 2 /* JSX */;
+        }
+        /** @internal */
+        closeSourceMapFileWatcher() {
+          if (this.sourceMapFilePath && !isString(this.sourceMapFilePath)) {
+            closeFileWatcherOf(this.sourceMapFilePath);
+            this.sourceMapFilePath = void 0;
+          }
+        }
+      };
     }
-  }
-  function positionShouldSnapToNode(sourceFile, pos, node) {
-    Debug.assert(node.pos <= pos);
-    if (pos < node.end) {
+  });
+
+  // src/server/typingsCache.ts
+  function setIsEqualTo(arr1, arr2) {
+    if (arr1 === arr2) {
       return true;
     }
-    const nodeEnd = node.getEnd();
-    if (nodeEnd === pos) {
-      return getTouchingPropertyName(sourceFile, pos).pos < node.end;
-    }
-    return false;
-  }
-  function getSelectionChildren(node) {
-    var _a;
-    if (isSourceFile(node)) {
-      return groupChildren(node.getChildAt(0).getChildren(), isImport2);
-    }
-    if (isMappedTypeNode(node)) {
-      const [openBraceToken, ...children] = node.getChildren();
-      const closeBraceToken = Debug.checkDefined(children.pop());
-      Debug.assertEqual(openBraceToken.kind, 19 /* OpenBraceToken */);
-      Debug.assertEqual(closeBraceToken.kind, 20 /* CloseBraceToken */);
-      const groupedWithPlusMinusTokens = groupChildren(children, (child) => child === node.readonlyToken || child.kind === 148 /* ReadonlyKeyword */ || child === node.questionToken || child.kind === 58 /* QuestionToken */);
-      const groupedWithBrackets = groupChildren(
-        groupedWithPlusMinusTokens,
-        ({ kind }) => kind === 23 /* OpenBracketToken */ || kind === 167 /* TypeParameter */ || kind === 24 /* CloseBracketToken */
-      );
-      return [
-        openBraceToken,
-        // Pivot on `:`
-        createSyntaxList2(splitChildren(groupedWithBrackets, ({ kind }) => kind === 59 /* ColonToken */)),
-        closeBraceToken
-      ];
+    if ((arr1 || emptyArray2).length === 0 && (arr2 || emptyArray2).length === 0) {
+      return true;
     }
-    if (isPropertySignature(node)) {
-      const children = groupChildren(node.getChildren(), (child) => child === node.name || contains(node.modifiers, child));
-      const firstJSDocChild = ((_a = children[0]) == null ? void 0 : _a.kind) === 326 /* JSDoc */ ? children[0] : void 0;
-      const withJSDocSeparated = firstJSDocChild ? children.slice(1) : children;
-      const splittedChildren = splitChildren(withJSDocSeparated, ({ kind }) => kind === 59 /* ColonToken */);
-      return firstJSDocChild ? [firstJSDocChild, createSyntaxList2(splittedChildren)] : splittedChildren;
+    const set = /* @__PURE__ */ new Map();
+    let unique = 0;
+    for (const v of arr1) {
+      if (set.get(v) !== true) {
+        set.set(v, true);
+        unique++;
+      }
     }
-    if (isParameter(node)) {
-      const groupedDotDotDotAndName = groupChildren(node.getChildren(), (child) => child === node.dotDotDotToken || child === node.name);
-      const groupedWithQuestionToken = groupChildren(groupedDotDotDotAndName, (child) => child === groupedDotDotDotAndName[0] || child === node.questionToken);
-      return splitChildren(groupedWithQuestionToken, ({ kind }) => kind === 64 /* EqualsToken */);
+    for (const v of arr2) {
+      const isSet = set.get(v);
+      if (isSet === void 0) {
+        return false;
+      }
+      if (isSet === true) {
+        set.set(v, false);
+        unique--;
+      }
     }
-    if (isBindingElement(node)) {
-      return splitChildren(node.getChildren(), ({ kind }) => kind === 64 /* EqualsToken */);
+    return unique === 0;
+  }
+  function typeAcquisitionChanged(opt1, opt2) {
+    return opt1.enable !== opt2.enable || !setIsEqualTo(opt1.include, opt2.include) || !setIsEqualTo(opt1.exclude, opt2.exclude);
+  }
+  function compilerOptionsChanged(opt1, opt2) {
+    return getAllowJSCompilerOption(opt1) !== getAllowJSCompilerOption(opt2);
+  }
+  function unresolvedImportsChanged(imports1, imports2) {
+    if (imports1 === imports2) {
+      return false;
     }
-    return node.getChildren();
+    return !arrayIsEqualTo(imports1, imports2);
   }
-  function groupChildren(children, groupOn) {
-    const result = [];
-    let group2;
-    for (const child of children) {
-      if (groupOn(child)) {
-        group2 = group2 || [];
-        group2.push(child);
-      } else {
-        if (group2) {
-          result.push(createSyntaxList2(group2));
-          group2 = void 0;
+  var nullTypingsInstaller, TypingsCache;
+  var init_typingsCache = __esm({
+    "src/server/typingsCache.ts"() {
+      "use strict";
+      init_ts7();
+      init_ts_server3();
+      nullTypingsInstaller = {
+        isKnownTypesPackageName: returnFalse,
+        // Should never be called because we never provide a types registry.
+        installPackage: notImplemented,
+        enqueueInstallTypingsRequest: noop,
+        attach: noop,
+        onProjectClosed: noop,
+        globalTypingsCacheLocation: void 0
+        // TODO: GH#18217
+      };
+      TypingsCache = class {
+        constructor(installer) {
+          this.installer = installer;
+          this.perProjectCache = /* @__PURE__ */ new Map();
         }
-        result.push(child);
-      }
+        isKnownTypesPackageName(name) {
+          return this.installer.isKnownTypesPackageName(name);
+        }
+        installPackage(options) {
+          return this.installer.installPackage(options);
+        }
+        enqueueInstallTypingsForProject(project, unresolvedImports, forceRefresh) {
+          const typeAcquisition = project.getTypeAcquisition();
+          if (!typeAcquisition || !typeAcquisition.enable) {
+            return;
+          }
+          const entry = this.perProjectCache.get(project.getProjectName());
+          if (forceRefresh || !entry || typeAcquisitionChanged(typeAcquisition, entry.typeAcquisition) || compilerOptionsChanged(project.getCompilationSettings(), entry.compilerOptions) || unresolvedImportsChanged(unresolvedImports, entry.unresolvedImports)) {
+            this.perProjectCache.set(project.getProjectName(), {
+              compilerOptions: project.getCompilationSettings(),
+              typeAcquisition,
+              typings: entry ? entry.typings : emptyArray2,
+              unresolvedImports,
+              poisoned: true
+            });
+            this.installer.enqueueInstallTypingsRequest(project, typeAcquisition, unresolvedImports);
+          }
+        }
+        updateTypingsForProject(projectName, compilerOptions, typeAcquisition, unresolvedImports, newTypings) {
+          const typings = sort(newTypings);
+          this.perProjectCache.set(projectName, {
+            compilerOptions,
+            typeAcquisition,
+            typings,
+            unresolvedImports,
+            poisoned: false
+          });
+          return !typeAcquisition || !typeAcquisition.enable ? emptyArray2 : typings;
+        }
+        onProjectClosed(project) {
+          this.perProjectCache.delete(project.getProjectName());
+          this.installer.onProjectClosed(project);
+        }
+      };
     }
-    if (group2) {
-      result.push(createSyntaxList2(group2));
+  });
+
+  // src/server/project.ts
+  function countEachFileTypes(infos, includeSizes = false) {
+    const result = {
+      js: 0,
+      jsSize: 0,
+      jsx: 0,
+      jsxSize: 0,
+      ts: 0,
+      tsSize: 0,
+      tsx: 0,
+      tsxSize: 0,
+      dts: 0,
+      dtsSize: 0,
+      deferred: 0,
+      deferredSize: 0
+    };
+    for (const info of infos) {
+      const fileSize = includeSizes ? info.textStorage.getTelemetryFileSize() : 0;
+      switch (info.scriptKind) {
+        case 1 /* JS */:
+          result.js += 1;
+          result.jsSize += fileSize;
+          break;
+        case 2 /* JSX */:
+          result.jsx += 1;
+          result.jsxSize += fileSize;
+          break;
+        case 3 /* TS */:
+          if (isDeclarationFileName(info.fileName)) {
+            result.dts += 1;
+            result.dtsSize += fileSize;
+          } else {
+            result.ts += 1;
+            result.tsSize += fileSize;
+          }
+          break;
+        case 4 /* TSX */:
+          result.tsx += 1;
+          result.tsxSize += fileSize;
+          break;
+        case 7 /* Deferred */:
+          result.deferred += 1;
+          result.deferredSize += fileSize;
+          break;
+      }
     }
     return result;
   }
-  function splitChildren(children, pivotOn, separateTrailingSemicolon = true) {
-    if (children.length < 2) {
-      return children;
-    }
-    const splitTokenIndex = findIndex(children, pivotOn);
-    if (splitTokenIndex === -1) {
-      return children;
-    }
-    const leftChildren = children.slice(0, splitTokenIndex);
-    const splitToken = children[splitTokenIndex];
-    const lastToken = last(children);
-    const separateLastToken = separateTrailingSemicolon && lastToken.kind === 27 /* SemicolonToken */;
-    const rightChildren = children.slice(splitTokenIndex + 1, separateLastToken ? children.length - 1 : void 0);
-    const result = compact([
-      leftChildren.length ? createSyntaxList2(leftChildren) : void 0,
-      splitToken,
-      rightChildren.length ? createSyntaxList2(rightChildren) : void 0
-    ]);
-    return separateLastToken ? result.concat(lastToken) : result;
+  function hasOneOrMoreJsAndNoTsFiles(project) {
+    const counts2 = countEachFileTypes(project.getScriptInfos());
+    return counts2.js > 0 && counts2.ts === 0 && counts2.tsx === 0;
   }
-  function createSyntaxList2(children) {
-    Debug.assertGreaterThanOrEqual(children.length, 1);
-    return setTextRangePosEnd(parseNodeFactory.createSyntaxList(children), children[0].pos, last(children).end);
+  function allRootFilesAreJsOrDts(project) {
+    const counts2 = countEachFileTypes(project.getRootScriptInfos());
+    return counts2.ts === 0 && counts2.tsx === 0;
   }
-  function isListOpener(token) {
-    const kind = token && token.kind;
-    return kind === 19 /* OpenBraceToken */ || kind === 23 /* OpenBracketToken */ || kind === 21 /* OpenParenToken */ || kind === 285 /* JsxOpeningElement */;
+  function allFilesAreJsOrDts(project) {
+    const counts2 = countEachFileTypes(project.getScriptInfos());
+    return counts2.ts === 0 && counts2.tsx === 0;
   }
-  function isListCloser(token) {
-    const kind = token && token.kind;
-    return kind === 20 /* CloseBraceToken */ || kind === 24 /* CloseBracketToken */ || kind === 22 /* CloseParenToken */ || kind === 286 /* JsxClosingElement */;
+  function hasNoTypeScriptSource(fileNames) {
+    return !fileNames.some((fileName) => fileExtensionIs(fileName, ".ts" /* Ts */) && !isDeclarationFileName(fileName) || fileExtensionIs(fileName, ".tsx" /* Tsx */));
   }
-  function getEndPos(sourceFile, node) {
-    switch (node.kind) {
-      case 347 /* JSDocParameterTag */:
-      case 344 /* JSDocCallbackTag */:
-      case 354 /* JSDocPropertyTag */:
-      case 352 /* JSDocTypedefTag */:
-      case 349 /* JSDocThisTag */:
-        return sourceFile.getLineEndOfPosition(node.getStart());
-      default:
-        return node.getEnd();
-    }
+  function isGeneratedFileWatcher(watch) {
+    return watch.generatedFilePath !== void 0;
   }
-  var isImport2;
-  var init_smartSelection = __esm({
-    "src/services/smartSelection.ts"() {
-      "use strict";
-      init_ts4();
-      isImport2 = or(isImportDeclaration, isImportEqualsDeclaration);
-    }
-  });
-
-  // src/services/_namespaces/ts.SmartSelectionRange.ts
-  var ts_SmartSelectionRange_exports = {};
-  __export(ts_SmartSelectionRange_exports, {
-    getSmartSelectionRange: () => getSmartSelectionRange
-  });
-  var init_ts_SmartSelectionRange = __esm({
-    "src/services/_namespaces/ts.SmartSelectionRange.ts"() {
-      "use strict";
-      init_smartSelection();
-    }
-  });
-
-  // src/services/symbolDisplay.ts
-  function getSymbolKind(typeChecker, symbol, location) {
-    const result = getSymbolKindOfConstructorPropertyMethodAccessorFunctionOrVar(typeChecker, symbol, location);
-    if (result !== "" /* unknown */) {
-      return result;
-    }
-    const flags = getCombinedLocalAndExportSymbolFlags(symbol);
-    if (flags & 32 /* Class */) {
-      return getDeclarationOfKind(symbol, 230 /* ClassExpression */) ? "local class" /* localClassElement */ : "class" /* classElement */;
-    }
-    if (flags & 384 /* Enum */)
-      return "enum" /* enumElement */;
-    if (flags & 524288 /* TypeAlias */)
-      return "type" /* typeElement */;
-    if (flags & 64 /* Interface */)
-      return "interface" /* interfaceElement */;
-    if (flags & 262144 /* TypeParameter */)
-      return "type parameter" /* typeParameterElement */;
-    if (flags & 8 /* EnumMember */)
-      return "enum member" /* enumMemberElement */;
-    if (flags & 2097152 /* Alias */)
-      return "alias" /* alias */;
-    if (flags & 1536 /* Module */)
-      return "module" /* moduleElement */;
+  function getUnresolvedImports(program, cachedUnresolvedImportsPerFile) {
+    var _a, _b;
+    const sourceFiles = program.getSourceFiles();
+    (_a = tracing) == null ? void 0 : _a.push(tracing.Phase.Session, "getUnresolvedImports", { count: sourceFiles.length });
+    const ambientModules = program.getTypeChecker().getAmbientModules().map((mod) => stripQuotes(mod.getName()));
+    const result = sortAndDeduplicate(flatMap(sourceFiles, (sourceFile) => extractUnresolvedImportsFromSourceFile(
+      program,
+      sourceFile,
+      ambientModules,
+      cachedUnresolvedImportsPerFile
+    )));
+    (_b = tracing) == null ? void 0 : _b.pop();
     return result;
   }
-  function getSymbolKindOfConstructorPropertyMethodAccessorFunctionOrVar(typeChecker, symbol, location) {
-    const roots = typeChecker.getRootSymbols(symbol);
-    if (roots.length === 1 && first(roots).flags & 8192 /* Method */ && typeChecker.getTypeOfSymbolAtLocation(symbol, location).getNonNullableType().getCallSignatures().length !== 0) {
-      return "method" /* memberFunctionElement */;
-    }
-    if (typeChecker.isUndefinedSymbol(symbol)) {
-      return "var" /* variableElement */;
-    }
-    if (typeChecker.isArgumentsSymbol(symbol)) {
-      return "local var" /* localVariableElement */;
-    }
-    if (location.kind === 110 /* ThisKeyword */ && isExpression(location) || isThisInTypeQuery(location)) {
-      return "parameter" /* parameterElement */;
-    }
-    const flags = getCombinedLocalAndExportSymbolFlags(symbol);
-    if (flags & 3 /* Variable */) {
-      if (isFirstDeclarationOfSymbolParameter(symbol)) {
-        return "parameter" /* parameterElement */;
-      } else if (symbol.valueDeclaration && isVarConst(symbol.valueDeclaration)) {
-        return "const" /* constElement */;
-      } else if (forEach(symbol.declarations, isLet)) {
-        return "let" /* letElement */;
-      }
-      return isLocalVariableOrFunction(symbol) ? "local var" /* localVariableElement */ : "var" /* variableElement */;
-    }
-    if (flags & 16 /* Function */)
-      return isLocalVariableOrFunction(symbol) ? "local function" /* localFunctionElement */ : "function" /* functionElement */;
-    if (flags & 32768 /* GetAccessor */)
-      return "getter" /* memberGetAccessorElement */;
-    if (flags & 65536 /* SetAccessor */)
-      return "setter" /* memberSetAccessorElement */;
-    if (flags & 8192 /* Method */)
-      return "method" /* memberFunctionElement */;
-    if (flags & 16384 /* Constructor */)
-      return "constructor" /* constructorImplementationElement */;
-    if (flags & 131072 /* Signature */)
-      return "index" /* indexSignatureElement */;
-    if (flags & 4 /* Property */) {
-      if (flags & 33554432 /* Transient */ && symbol.links.checkFlags & 6 /* Synthetic */) {
-        const unionPropertyKind = forEach(typeChecker.getRootSymbols(symbol), (rootSymbol) => {
-          const rootSymbolFlags = rootSymbol.getFlags();
-          if (rootSymbolFlags & (98308 /* PropertyOrAccessor */ | 3 /* Variable */)) {
-            return "property" /* memberVariableElement */;
-          }
-        });
-        if (!unionPropertyKind) {
-          const typeOfUnionProperty = typeChecker.getTypeOfSymbolAtLocation(symbol, location);
-          if (typeOfUnionProperty.getCallSignatures().length) {
-            return "method" /* memberFunctionElement */;
-          }
-          return "property" /* memberVariableElement */;
+  function extractUnresolvedImportsFromSourceFile(program, file, ambientModules, cachedUnresolvedImportsPerFile) {
+    return getOrUpdate(cachedUnresolvedImportsPerFile, file.path, () => {
+      let unresolvedImports;
+      program.forEachResolvedModule(({ resolvedModule }, name) => {
+        if ((!resolvedModule || !resolutionExtensionIsTSOrJson(resolvedModule.extension)) && !isExternalModuleNameRelative(name) && !ambientModules.some((m) => m === name)) {
+          unresolvedImports = append(unresolvedImports, parsePackageName(name).packageName);
         }
-        return unionPropertyKind;
-      }
-      return "property" /* memberVariableElement */;
-    }
-    return "" /* unknown */;
+      }, file);
+      return unresolvedImports || emptyArray2;
+    });
   }
-  function getNormalizedSymbolModifiers(symbol) {
-    if (symbol.declarations && symbol.declarations.length) {
-      const [declaration, ...declarations] = symbol.declarations;
-      const excludeFlags = length(declarations) && isDeprecatedDeclaration(declaration) && some(declarations, (d) => !isDeprecatedDeclaration(d)) ? 8192 /* Deprecated */ : 0 /* None */;
-      const modifiers = getNodeModifiers(declaration, excludeFlags);
-      if (modifiers) {
-        return modifiers.split(",");
-      }
-    }
-    return [];
+  function isInferredProject(project) {
+    return project.projectKind === 0 /* Inferred */;
   }
-  function getSymbolModifiers(typeChecker, symbol) {
-    if (!symbol) {
-      return "" /* none */;
-    }
-    const modifiers = new Set(getNormalizedSymbolModifiers(symbol));
-    if (symbol.flags & 2097152 /* Alias */) {
-      const resolvedSymbol = typeChecker.getAliasedSymbol(symbol);
-      if (resolvedSymbol !== symbol) {
-        forEach(getNormalizedSymbolModifiers(resolvedSymbol), (modifier) => {
-          modifiers.add(modifier);
-        });
-      }
-    }
-    if (symbol.flags & 16777216 /* Optional */) {
-      modifiers.add("optional" /* optionalModifier */);
-    }
-    return modifiers.size > 0 ? arrayFrom(modifiers.values()).join(",") : "" /* none */;
+  function isConfiguredProject(project) {
+    return project.projectKind === 1 /* Configured */;
   }
-  function getSymbolDisplayPartsDocumentationAndSymbolKind(typeChecker, symbol, sourceFile, enclosingDeclaration, location, semanticMeaning = getMeaningFromLocation(location), alias) {
-    var _a;
-    const displayParts = [];
-    let documentation = [];
-    let tags = [];
-    const symbolFlags = getCombinedLocalAndExportSymbolFlags(symbol);
-    let symbolKind = semanticMeaning & 1 /* Value */ ? getSymbolKindOfConstructorPropertyMethodAccessorFunctionOrVar(typeChecker, symbol, location) : "" /* unknown */;
-    let hasAddedSymbolInfo = false;
-    const isThisExpression = location.kind === 110 /* ThisKeyword */ && isInExpressionContext(location) || isThisInTypeQuery(location);
-    let type;
-    let documentationFromAlias;
-    let tagsFromAlias;
-    let hasMultipleSignatures = false;
-    if (location.kind === 110 /* ThisKeyword */ && !isThisExpression) {
-      return { displayParts: [keywordPart(110 /* ThisKeyword */)], documentation: [], symbolKind: "primitive type" /* primitiveType */, tags: void 0 };
-    }
-    if (symbolKind !== "" /* unknown */ || symbolFlags & 32 /* Class */ || symbolFlags & 2097152 /* Alias */) {
-      if (symbolKind === "getter" /* memberGetAccessorElement */ || symbolKind === "setter" /* memberSetAccessorElement */) {
-        const declaration = find(symbol.declarations, (declaration2) => declaration2.name === location);
-        if (declaration) {
-          switch (declaration.kind) {
-            case 176 /* GetAccessor */:
-              symbolKind = "getter" /* memberGetAccessorElement */;
+  function isExternalProject(project) {
+    return project.projectKind === 2 /* External */;
+  }
+  function isBackgroundProject(project) {
+    return project.projectKind === 3 /* AutoImportProvider */ || project.projectKind === 4 /* Auxiliary */;
+  }
+  var ProjectKind, Project3, InferredProject2, AuxiliaryProject, _AutoImportProviderProject, AutoImportProviderProject, ConfiguredProject2, ExternalProject2;
+  var init_project = __esm({
+    "src/server/project.ts"() {
+      "use strict";
+      init_pnp();
+      init_ts7();
+      init_ts7();
+      init_ts_server3();
+      ProjectKind = /* @__PURE__ */ ((ProjectKind2) => {
+        ProjectKind2[ProjectKind2["Inferred"] = 0] = "Inferred";
+        ProjectKind2[ProjectKind2["Configured"] = 1] = "Configured";
+        ProjectKind2[ProjectKind2["External"] = 2] = "External";
+        ProjectKind2[ProjectKind2["AutoImportProvider"] = 3] = "AutoImportProvider";
+        ProjectKind2[ProjectKind2["Auxiliary"] = 4] = "Auxiliary";
+        return ProjectKind2;
+      })(ProjectKind || {});
+      Project3 = class _Project {
+        /** @internal */
+        constructor(projectName, projectKind, projectService, documentRegistry, hasExplicitListOfFiles, lastFileExceededProgramSize, compilerOptions, compileOnSaveEnabled, watchOptions, directoryStructureHost, currentDirectory) {
+          this.projectKind = projectKind;
+          this.projectService = projectService;
+          this.documentRegistry = documentRegistry;
+          this.compilerOptions = compilerOptions;
+          this.compileOnSaveEnabled = compileOnSaveEnabled;
+          this.watchOptions = watchOptions;
+          this.rootFiles = [];
+          this.rootFilesMap = /* @__PURE__ */ new Map();
+          /** @internal */
+          this.plugins = [];
+          /**
+           * This is map from files to unresolved imports in it
+           * Maop does not contain entries for files that do not have unresolved imports
+           * This helps in containing the set of files to invalidate
+           *
+           * @internal
+           */
+          this.cachedUnresolvedImportsPerFile = /* @__PURE__ */ new Map();
+          /** @internal */
+          this.hasAddedorRemovedFiles = false;
+          /** @internal */
+          this.hasAddedOrRemovedSymlinks = false;
+          /**
+           * Last version that was reported.
+           */
+          this.lastReportedVersion = 0;
+          /**
+           * Current project's program version. (incremented everytime new program is created that is not complete reuse from the old one)
+           * This property is changed in 'updateGraph' based on the set of files in program
+           */
+          this.projectProgramVersion = 0;
+          /**
+           * Current version of the project state. It is changed when:
+           * - new root file was added/removed
+           * - edit happen in some file that is currently included in the project.
+           * This property is different from projectStructureVersion since in most cases edits don't affect set of files in the project
+           */
+          this.projectStateVersion = 0;
+          this.isInitialLoadPending = returnFalse;
+          /** @internal */
+          this.dirty = false;
+          /** @internal */
+          this.typingFiles = emptyArray2;
+          /** @internal */
+          this.moduleSpecifierCache = createModuleSpecifierCache(this);
+          /** @internal */
+          this.createHash = maybeBind(this.projectService.host, this.projectService.host.createHash);
+          /** @internal */
+          this.globalCacheResolutionModuleName = ts_JsTyping_exports.nonRelativeModuleNameForTypingCache;
+          this.projectName = projectName;
+          this.directoryStructureHost = directoryStructureHost;
+          this.currentDirectory = this.projectService.getNormalizedAbsolutePath(currentDirectory);
+          this.getCanonicalFileName = this.projectService.toCanonicalFileName;
+          this.jsDocParsingMode = this.projectService.jsDocParsingMode;
+          this.cancellationToken = new ThrottledCancellationToken(this.projectService.cancellationToken, this.projectService.throttleWaitMilliseconds);
+          if (!this.compilerOptions) {
+            this.compilerOptions = getDefaultCompilerOptions2();
+            this.compilerOptions.allowNonTsExtensions = true;
+            this.compilerOptions.allowJs = true;
+          } else if (hasExplicitListOfFiles || getAllowJSCompilerOption(this.compilerOptions) || this.projectService.hasDeferredExtension()) {
+            this.compilerOptions.allowNonTsExtensions = true;
+          }
+          switch (projectService.serverMode) {
+            case 0 /* Semantic */:
+              this.languageServiceEnabled = true;
               break;
-            case 177 /* SetAccessor */:
-              symbolKind = "setter" /* memberSetAccessorElement */;
+            case 1 /* PartialSemantic */:
+              this.languageServiceEnabled = true;
+              this.compilerOptions.noResolve = true;
+              this.compilerOptions.types = [];
               break;
-            case 171 /* PropertyDeclaration */:
-              symbolKind = "accessor" /* memberAccessorVariableElement */;
+            case 2 /* Syntactic */:
+              this.languageServiceEnabled = false;
+              this.compilerOptions.noResolve = true;
+              this.compilerOptions.types = [];
               break;
             default:
-              Debug.assertNever(declaration);
+              Debug.assertNever(projectService.serverMode);
+          }
+          this.setInternalCompilerOptionsForEmittingJsFiles();
+          const host = this.projectService.host;
+          if (this.projectService.logger.loggingEnabled()) {
+            this.trace = (s) => this.writeLog(s);
+          } else if (host.trace) {
+            this.trace = (s) => host.trace(s);
+          }
+          this.realpath = maybeBind(host, host.realpath);
+          this.resolutionCache = createResolutionCache(
+            this,
+            this.currentDirectory,
+            /*logChangesWhenResolvingModule*/
+            true
+          );
+          this.languageService = createLanguageService(this, this.documentRegistry, this.projectService.serverMode);
+          if (lastFileExceededProgramSize) {
+            this.disableLanguageService(lastFileExceededProgramSize);
           }
-        } else {
-          symbolKind = "property" /* memberVariableElement */;
+          this.markAsDirty();
+          if (!isBackgroundProject(this)) {
+            this.projectService.pendingEnsureProjectForOpenFiles = true;
+          }
+          this.projectService.onProjectCreation(this);
         }
-      }
-      let signature;
-      type = isThisExpression ? typeChecker.getTypeAtLocation(location) : typeChecker.getTypeOfSymbolAtLocation(symbol, location);
-      if (location.parent && location.parent.kind === 210 /* PropertyAccessExpression */) {
-        const right = location.parent.name;
-        if (right === location || right && right.getFullWidth() === 0) {
-          location = location.parent;
+        /** @internal */
+        getResolvedProjectReferenceToRedirect(_fileName) {
+          return void 0;
         }
-      }
-      let callExpressionLike;
-      if (isCallOrNewExpression(location)) {
-        callExpressionLike = location;
-      } else if (isCallExpressionTarget(location) || isNewExpressionTarget(location)) {
-        callExpressionLike = location.parent;
-      } else if (location.parent && (isJsxOpeningLikeElement(location.parent) || isTaggedTemplateExpression(location.parent)) && isFunctionLike(symbol.valueDeclaration)) {
-        callExpressionLike = location.parent;
-      }
-      if (callExpressionLike) {
-        signature = typeChecker.getResolvedSignature(callExpressionLike);
-        const useConstructSignatures = callExpressionLike.kind === 213 /* NewExpression */ || isCallExpression(callExpressionLike) && callExpressionLike.expression.kind === 108 /* SuperKeyword */;
-        const allSignatures = useConstructSignatures ? type.getConstructSignatures() : type.getCallSignatures();
-        if (signature && !contains(allSignatures, signature.target) && !contains(allSignatures, signature)) {
-          signature = allSignatures.length ? allSignatures[0] : void 0;
+        isNonTsProject() {
+          updateProjectIfDirty(this);
+          return allFilesAreJsOrDts(this);
         }
-        if (signature) {
-          if (useConstructSignatures && symbolFlags & 32 /* Class */) {
-            symbolKind = "constructor" /* constructorImplementationElement */;
-            addPrefixForAnyFunctionOrVar(type.symbol, symbolKind);
-          } else if (symbolFlags & 2097152 /* Alias */) {
-            symbolKind = "alias" /* alias */;
-            pushSymbolKind(symbolKind);
-            displayParts.push(spacePart());
-            if (useConstructSignatures) {
-              if (signature.flags & 4 /* Abstract */) {
-                displayParts.push(keywordPart(128 /* AbstractKeyword */));
-                displayParts.push(spacePart());
+        isJsOnlyProject() {
+          updateProjectIfDirty(this);
+          return hasOneOrMoreJsAndNoTsFiles(this);
+        }
+        static resolveModule(moduleName, initialDir, host, log) {
+          return _Project.importServicePluginSync({ name: moduleName }, [initialDir], host, log).resolvedModule;
+        }
+        /** @internal */
+        static importServicePluginSync(pluginConfigEntry, searchPaths, host, log) {
+          Debug.assertIsDefined(host.require);
+          let errorLogs;
+          let resolvedModule;
+          for (const initialDir of searchPaths) {
+            const resolvedPath = normalizeSlashes(host.resolvePath(combinePaths(initialDir, "node_modules")));
+            log(`Loading ${pluginConfigEntry.name} from ${initialDir} (resolved to ${resolvedPath})`);
+            const result = host.require(resolvedPath, pluginConfigEntry.name);
+            if (!result.error) {
+              resolvedModule = result.module;
+              break;
+            }
+            const err = result.error.stack || result.error.message || JSON.stringify(result.error);
+            (errorLogs ?? (errorLogs = [])).push(`Failed to load module '${pluginConfigEntry.name}' from ${resolvedPath}: ${err}`);
+          }
+          return { pluginConfigEntry, resolvedModule, errorLogs };
+        }
+        /** @internal */
+        static async importServicePluginAsync(pluginConfigEntry, searchPaths, host, log) {
+          Debug.assertIsDefined(host.importPlugin);
+          let errorLogs;
+          let resolvedModule;
+          for (const initialDir of searchPaths) {
+            const resolvedPath = combinePaths(initialDir, "node_modules");
+            log(`Dynamically importing ${pluginConfigEntry.name} from ${initialDir} (resolved to ${resolvedPath})`);
+            let result;
+            try {
+              result = await host.importPlugin(resolvedPath, pluginConfigEntry.name);
+            } catch (e) {
+              result = { module: void 0, error: e };
+            }
+            if (!result.error) {
+              resolvedModule = result.module;
+              break;
+            }
+            const err = result.error.stack || result.error.message || JSON.stringify(result.error);
+            (errorLogs ?? (errorLogs = [])).push(`Failed to dynamically import module '${pluginConfigEntry.name}' from ${resolvedPath}: ${err}`);
+          }
+          return { pluginConfigEntry, resolvedModule, errorLogs };
+        }
+        isKnownTypesPackageName(name) {
+          return this.typingsCache.isKnownTypesPackageName(name);
+        }
+        installPackage(options) {
+          return this.typingsCache.installPackage({ ...options, projectName: this.projectName, projectRootPath: this.toPath(this.currentDirectory) });
+        }
+        /** @internal */
+        getGlobalTypingsCacheLocation() {
+          return this.getGlobalCache();
+        }
+        get typingsCache() {
+          return this.projectService.typingsCache;
+        }
+        /** @internal */
+        getSymlinkCache() {
+          if (!this.symlinks) {
+            this.symlinks = createSymlinkCache(this.getCurrentDirectory(), this.getCanonicalFileName);
+          }
+          if (this.program && !this.symlinks.hasProcessedResolutions()) {
+            this.symlinks.setSymlinksFromResolutions(
+              this.program.forEachResolvedModule,
+              this.program.forEachResolvedTypeReferenceDirective,
+              this.program.getAutomaticTypeDirectiveResolutions()
+            );
+          }
+          return this.symlinks;
+        }
+        // Method of LanguageServiceHost
+        getCompilationSettings() {
+          return this.compilerOptions;
+        }
+        // Method to support public API
+        getCompilerOptions() {
+          return this.getCompilationSettings();
+        }
+        getNewLine() {
+          return this.projectService.host.newLine;
+        }
+        getProjectVersion() {
+          return this.projectStateVersion.toString();
+        }
+        getProjectReferences() {
+          return void 0;
+        }
+        getScriptFileNames() {
+          if (!this.rootFiles) {
+            return emptyArray;
+          }
+          let result;
+          this.rootFilesMap.forEach((value) => {
+            if (this.languageServiceEnabled || value.info && value.info.isScriptOpen()) {
+              (result || (result = [])).push(value.fileName);
+            }
+          });
+          return addRange(result, this.typingFiles) || emptyArray;
+        }
+        getOrCreateScriptInfoAndAttachToProject(fileName) {
+          const scriptInfo = this.projectService.getOrCreateScriptInfoNotOpenedByClient(fileName, this.currentDirectory, this.directoryStructureHost);
+          if (scriptInfo) {
+            const existingValue = this.rootFilesMap.get(scriptInfo.path);
+            if (existingValue && existingValue.info !== scriptInfo) {
+              this.rootFiles.push(scriptInfo);
+              existingValue.info = scriptInfo;
+            }
+            scriptInfo.attachToProject(this);
+          }
+          return scriptInfo;
+        }
+        getScriptKind(fileName) {
+          const info = this.projectService.getScriptInfoForPath(this.toPath(fileName));
+          return info && info.scriptKind;
+        }
+        getScriptVersion(filename) {
+          const info = this.projectService.getOrCreateScriptInfoNotOpenedByClient(filename, this.currentDirectory, this.directoryStructureHost);
+          return info && info.getLatestVersion();
+        }
+        getScriptSnapshot(filename) {
+          const scriptInfo = this.getOrCreateScriptInfoAndAttachToProject(filename);
+          if (scriptInfo) {
+            return scriptInfo.getSnapshot();
+          }
+        }
+        getCancellationToken() {
+          return this.cancellationToken;
+        }
+        getCurrentDirectory() {
+          return this.currentDirectory;
+        }
+        getDefaultLibFileName() {
+          const nodeModuleBinDir = getDirectoryPath(normalizePath(this.projectService.getExecutingFilePath()));
+          return combinePaths(nodeModuleBinDir, getDefaultLibFileName(this.compilerOptions));
+        }
+        useCaseSensitiveFileNames() {
+          return this.projectService.host.useCaseSensitiveFileNames;
+        }
+        readDirectory(path, extensions, exclude, include, depth) {
+          return this.directoryStructureHost.readDirectory(path, extensions, exclude, include, depth);
+        }
+        readFile(fileName) {
+          return this.projectService.host.readFile(fileName);
+        }
+        writeFile(fileName, content) {
+          return this.projectService.host.writeFile(fileName, content);
+        }
+        fileExists(file) {
+          const path = this.toPath(file);
+          return !this.isWatchedMissingFile(path) && this.directoryStructureHost.fileExists(file);
+        }
+        /** @internal */
+        resolveModuleNameLiterals(moduleLiterals, containingFile, redirectedReference, options, containingSourceFile, reusedNames) {
+          return this.resolutionCache.resolveModuleNameLiterals(moduleLiterals, containingFile, redirectedReference, options, containingSourceFile, reusedNames);
+        }
+        /** @internal */
+        getModuleResolutionCache() {
+          return this.resolutionCache.getModuleResolutionCache();
+        }
+        /** @internal */
+        resolveTypeReferenceDirectiveReferences(typeDirectiveReferences, containingFile, redirectedReference, options, containingSourceFile, reusedNames) {
+          return this.resolutionCache.resolveTypeReferenceDirectiveReferences(
+            typeDirectiveReferences,
+            containingFile,
+            redirectedReference,
+            options,
+            containingSourceFile,
+            reusedNames
+          );
+        }
+        /** @internal */
+        resolveLibrary(libraryName, resolveFrom, options, libFileName) {
+          return this.resolutionCache.resolveLibrary(libraryName, resolveFrom, options, libFileName);
+        }
+        directoryExists(path) {
+          return this.directoryStructureHost.directoryExists(path);
+        }
+        getDirectories(path) {
+          return this.directoryStructureHost.getDirectories(path);
+        }
+        /** @internal */
+        getCachedDirectoryStructureHost() {
+          return void 0;
+        }
+        /** @internal */
+        toPath(fileName) {
+          return toPath(fileName, this.currentDirectory, this.projectService.toCanonicalFileName);
+        }
+        /** @internal */
+        watchDirectoryOfFailedLookupLocation(directory, cb, flags) {
+          return this.projectService.watchFactory.watchDirectory(
+            directory,
+            cb,
+            flags,
+            this.projectService.getWatchOptions(this),
+            WatchType.FailedLookupLocations,
+            this
+          );
+        }
+        /** @internal */
+        watchAffectingFileLocation(file, cb) {
+          return this.projectService.watchFactory.watchFile(
+            file,
+            cb,
+            2e3 /* High */,
+            this.projectService.getWatchOptions(this),
+            WatchType.AffectingFileLocation,
+            this
+          );
+        }
+        /** @internal */
+        clearInvalidateResolutionOfFailedLookupTimer() {
+          return this.projectService.throttledOperations.cancel(`${this.getProjectName()}FailedLookupInvalidation`);
+        }
+        /** @internal */
+        scheduleInvalidateResolutionsOfFailedLookupLocations() {
+          this.projectService.throttledOperations.schedule(
+            `${this.getProjectName()}FailedLookupInvalidation`,
+            /*delay*/
+            1e3,
+            () => {
+              if (this.resolutionCache.invalidateResolutionsOfFailedLookupLocations()) {
+                this.projectService.delayUpdateProjectGraphAndEnsureProjectStructureForOpenFiles(this);
               }
-              displayParts.push(keywordPart(105 /* NewKeyword */));
-              displayParts.push(spacePart());
             }
-            addFullSymbolName(symbol);
+          );
+        }
+        /** @internal */
+        invalidateResolutionsOfFailedLookupLocations() {
+          if (this.clearInvalidateResolutionOfFailedLookupTimer() && this.resolutionCache.invalidateResolutionsOfFailedLookupLocations()) {
+            this.markAsDirty();
+            this.projectService.delayEnsureProjectForOpenFiles();
+          }
+        }
+        /** @internal */
+        onInvalidatedResolution() {
+          this.projectService.delayUpdateProjectGraphAndEnsureProjectStructureForOpenFiles(this);
+        }
+        /** @internal */
+        watchTypeRootsDirectory(directory, cb, flags) {
+          return this.projectService.watchFactory.watchDirectory(
+            directory,
+            cb,
+            flags,
+            this.projectService.getWatchOptions(this),
+            WatchType.TypeRoots,
+            this
+          );
+        }
+        /** @internal */
+        hasChangedAutomaticTypeDirectiveNames() {
+          return this.resolutionCache.hasChangedAutomaticTypeDirectiveNames();
+        }
+        /** @internal */
+        onChangedAutomaticTypeDirectiveNames() {
+          this.projectService.delayUpdateProjectGraphAndEnsureProjectStructureForOpenFiles(this);
+        }
+        /** @internal */
+        getGlobalCache() {
+          return this.getTypeAcquisition().enable ? this.projectService.typingsInstaller.globalTypingsCacheLocation : void 0;
+        }
+        /** @internal */
+        fileIsOpen(filePath) {
+          return this.projectService.openFiles.has(filePath);
+        }
+        /** @internal */
+        writeLog(s) {
+          this.projectService.logger.info(s);
+        }
+        log(s) {
+          this.writeLog(s);
+        }
+        error(s) {
+          this.projectService.logger.msg(s, "Err" /* Err */);
+        }
+        setInternalCompilerOptionsForEmittingJsFiles() {
+          if (this.projectKind === 0 /* Inferred */ || this.projectKind === 2 /* External */) {
+            this.compilerOptions.noEmitForJsFiles = true;
+          }
+        }
+        /**
+         * Get the errors that dont have any file name associated
+         */
+        getGlobalProjectErrors() {
+          return filter(this.projectErrors, (diagnostic) => !diagnostic.file) || emptyArray2;
+        }
+        /**
+         * Get all the project errors
+         */
+        getAllProjectErrors() {
+          return this.projectErrors || emptyArray2;
+        }
+        setProjectErrors(projectErrors) {
+          this.projectErrors = projectErrors;
+        }
+        getLanguageService(ensureSynchronized = true) {
+          if (ensureSynchronized) {
+            updateProjectIfDirty(this);
+          }
+          return this.languageService;
+        }
+        /** @internal */
+        getSourceMapper() {
+          return this.getLanguageService().getSourceMapper();
+        }
+        /** @internal */
+        clearSourceMapperCache() {
+          this.languageService.clearSourceMapperCache();
+        }
+        /** @internal */
+        getDocumentPositionMapper(generatedFileName, sourceFileName) {
+          return this.projectService.getDocumentPositionMapper(this, generatedFileName, sourceFileName);
+        }
+        /** @internal */
+        getSourceFileLike(fileName) {
+          return this.projectService.getSourceFileLike(fileName, this);
+        }
+        /** @internal */
+        shouldEmitFile(scriptInfo) {
+          return scriptInfo && !scriptInfo.isDynamicOrHasMixedContent() && !this.program.isSourceOfProjectReferenceRedirect(scriptInfo.path);
+        }
+        getCompileOnSaveAffectedFileList(scriptInfo) {
+          if (!this.languageServiceEnabled) {
+            return [];
+          }
+          updateProjectIfDirty(this);
+          this.builderState = BuilderState.create(
+            this.program,
+            this.builderState,
+            /*disableUseFileVersionAsSignature*/
+            true
+          );
+          return mapDefined(
+            BuilderState.getFilesAffectedBy(
+              this.builderState,
+              this.program,
+              scriptInfo.path,
+              this.cancellationToken,
+              this.projectService.host
+            ),
+            (sourceFile) => this.shouldEmitFile(this.projectService.getScriptInfoForPath(sourceFile.path)) ? sourceFile.fileName : void 0
+          );
+        }
+        /**
+         * Returns true if emit was conducted
+         */
+        emitFile(scriptInfo, writeFile2) {
+          if (!this.languageServiceEnabled || !this.shouldEmitFile(scriptInfo)) {
+            return { emitSkipped: true, diagnostics: emptyArray2 };
+          }
+          const { emitSkipped, diagnostics, outputFiles } = this.getLanguageService().getEmitOutput(scriptInfo.fileName);
+          if (!emitSkipped) {
+            for (const outputFile of outputFiles) {
+              const outputFileAbsoluteFileName = getNormalizedAbsolutePath(outputFile.name, this.currentDirectory);
+              writeFile2(outputFileAbsoluteFileName, outputFile.text, outputFile.writeByteOrderMark);
+            }
+            if (this.builderState && getEmitDeclarations(this.compilerOptions)) {
+              const dtsFiles = outputFiles.filter((f) => isDeclarationFileName(f.name));
+              if (dtsFiles.length === 1) {
+                const sourceFile = this.program.getSourceFile(scriptInfo.fileName);
+                const signature = this.projectService.host.createHash ? this.projectService.host.createHash(dtsFiles[0].text) : generateDjb2Hash(dtsFiles[0].text);
+                BuilderState.updateSignatureOfFile(this.builderState, signature, sourceFile.resolvedPath);
+              }
+            }
+          }
+          return { emitSkipped, diagnostics };
+        }
+        enableLanguageService() {
+          if (this.languageServiceEnabled || this.projectService.serverMode === 2 /* Syntactic */) {
+            return;
+          }
+          this.languageServiceEnabled = true;
+          this.lastFileExceededProgramSize = void 0;
+          this.projectService.onUpdateLanguageServiceStateForProject(
+            this,
+            /*languageServiceEnabled*/
+            true
+          );
+        }
+        /** @internal */
+        cleanupProgram() {
+          if (this.program) {
+            for (const f of this.program.getSourceFiles()) {
+              this.detachScriptInfoIfNotRoot(f.fileName);
+            }
+            this.program.forEachResolvedProjectReference((ref) => this.detachScriptInfoFromProject(ref.sourceFile.fileName));
+            this.program = void 0;
+          }
+        }
+        disableLanguageService(lastFileExceededProgramSize) {
+          if (!this.languageServiceEnabled) {
+            return;
+          }
+          Debug.assert(this.projectService.serverMode !== 2 /* Syntactic */);
+          this.languageService.cleanupSemanticCache();
+          this.languageServiceEnabled = false;
+          this.cleanupProgram();
+          this.lastFileExceededProgramSize = lastFileExceededProgramSize;
+          this.builderState = void 0;
+          if (this.autoImportProviderHost) {
+            this.autoImportProviderHost.close();
+          }
+          this.autoImportProviderHost = void 0;
+          this.resolutionCache.closeTypeRootsWatch();
+          this.clearGeneratedFileWatch();
+          this.projectService.verifyDocumentRegistry();
+          this.projectService.onUpdateLanguageServiceStateForProject(
+            this,
+            /*languageServiceEnabled*/
+            false
+          );
+        }
+        getProjectName() {
+          return this.projectName;
+        }
+        removeLocalTypingsFromTypeAcquisition(newTypeAcquisition) {
+          if (!newTypeAcquisition || !newTypeAcquisition.include) {
+            return newTypeAcquisition;
+          }
+          return { ...newTypeAcquisition, include: this.removeExistingTypings(newTypeAcquisition.include) };
+        }
+        getExternalFiles(updateLevel) {
+          return sort(flatMap(this.plugins, (plugin) => {
+            if (typeof plugin.module.getExternalFiles !== "function")
+              return;
+            try {
+              return plugin.module.getExternalFiles(this, updateLevel || 0 /* Update */);
+            } catch (e) {
+              this.projectService.logger.info(`A plugin threw an exception in getExternalFiles: ${e}`);
+              if (e.stack) {
+                this.projectService.logger.info(e.stack);
+              }
+            }
+          }));
+        }
+        getSourceFile(path) {
+          if (!this.program) {
+            return void 0;
+          }
+          return this.program.getSourceFileByPath(path);
+        }
+        /** @internal */
+        getSourceFileOrConfigFile(path) {
+          const options = this.program.getCompilerOptions();
+          return path === options.configFilePath ? options.configFile : this.getSourceFile(path);
+        }
+        close() {
+          this.projectService.typingsCache.onProjectClosed(this);
+          this.closeWatchingTypingLocations();
+          this.cleanupProgram();
+          forEach(this.externalFiles, (externalFile) => this.detachScriptInfoIfNotRoot(externalFile));
+          for (const root of this.rootFiles) {
+            root.detachFromProject(this);
+          }
+          this.projectService.pendingEnsureProjectForOpenFiles = true;
+          this.rootFiles = void 0;
+          this.rootFilesMap = void 0;
+          this.externalFiles = void 0;
+          this.program = void 0;
+          this.builderState = void 0;
+          this.resolutionCache.clear();
+          this.resolutionCache = void 0;
+          this.cachedUnresolvedImportsPerFile = void 0;
+          this.moduleSpecifierCache = void 0;
+          this.directoryStructureHost = void 0;
+          this.exportMapCache = void 0;
+          this.projectErrors = void 0;
+          this.plugins.length = 0;
+          if (this.missingFilesMap) {
+            clearMap(this.missingFilesMap, closeFileWatcher);
+            this.missingFilesMap = void 0;
+          }
+          this.clearGeneratedFileWatch();
+          this.clearInvalidateResolutionOfFailedLookupTimer();
+          if (this.autoImportProviderHost) {
+            this.autoImportProviderHost.close();
+          }
+          this.autoImportProviderHost = void 0;
+          if (this.noDtsResolutionProject) {
+            this.noDtsResolutionProject.close();
+          }
+          this.noDtsResolutionProject = void 0;
+          this.languageService.dispose();
+          this.languageService = void 0;
+        }
+        detachScriptInfoIfNotRoot(uncheckedFilename) {
+          const info = this.projectService.getScriptInfo(uncheckedFilename);
+          if (info && !this.isRoot(info)) {
+            info.detachFromProject(this);
+          }
+        }
+        isClosed() {
+          return this.rootFiles === void 0;
+        }
+        hasRoots() {
+          return this.rootFiles && this.rootFiles.length > 0;
+        }
+        /** @internal */
+        isOrphan() {
+          return false;
+        }
+        getRootFiles() {
+          return this.rootFiles && this.rootFiles.map((info) => info.fileName);
+        }
+        /** @internal */
+        getRootFilesMap() {
+          return this.rootFilesMap;
+        }
+        getRootScriptInfos() {
+          return this.rootFiles;
+        }
+        getScriptInfos() {
+          if (!this.languageServiceEnabled) {
+            return this.rootFiles;
+          }
+          return map(this.program.getSourceFiles(), (sourceFile) => {
+            const scriptInfo = this.projectService.getScriptInfoForPath(sourceFile.resolvedPath);
+            Debug.assert(!!scriptInfo, "getScriptInfo", () => `scriptInfo for a file '${sourceFile.fileName}' Path: '${sourceFile.path}' / '${sourceFile.resolvedPath}' is missing.`);
+            return scriptInfo;
+          });
+        }
+        getExcludedFiles() {
+          return emptyArray2;
+        }
+        getFileNames(excludeFilesFromExternalLibraries, excludeConfigFiles) {
+          if (!this.program) {
+            return [];
+          }
+          if (!this.languageServiceEnabled) {
+            let rootFiles = this.getRootFiles();
+            if (this.compilerOptions) {
+              const defaultLibrary = getDefaultLibFilePath(this.compilerOptions);
+              if (defaultLibrary) {
+                (rootFiles || (rootFiles = [])).push(asNormalizedPath(defaultLibrary));
+              }
+            }
+            return rootFiles;
+          }
+          const result = [];
+          for (const f of this.program.getSourceFiles()) {
+            if (excludeFilesFromExternalLibraries && this.program.isSourceFileFromExternalLibrary(f)) {
+              continue;
+            }
+            result.push(asNormalizedPath(f.fileName));
+          }
+          if (!excludeConfigFiles) {
+            const configFile = this.program.getCompilerOptions().configFile;
+            if (configFile) {
+              result.push(asNormalizedPath(configFile.fileName));
+              if (configFile.extendedSourceFiles) {
+                for (const f of configFile.extendedSourceFiles) {
+                  result.push(asNormalizedPath(f));
+                }
+              }
+            }
+          }
+          return result;
+        }
+        /** @internal */
+        getFileNamesWithRedirectInfo(includeProjectReferenceRedirectInfo) {
+          return this.getFileNames().map((fileName) => ({
+            fileName,
+            isSourceOfProjectReferenceRedirect: includeProjectReferenceRedirectInfo && this.isSourceOfProjectReferenceRedirect(fileName)
+          }));
+        }
+        hasConfigFile(configFilePath) {
+          if (this.program && this.languageServiceEnabled) {
+            const configFile = this.program.getCompilerOptions().configFile;
+            if (configFile) {
+              if (configFilePath === asNormalizedPath(configFile.fileName)) {
+                return true;
+              }
+              if (configFile.extendedSourceFiles) {
+                for (const f of configFile.extendedSourceFiles) {
+                  if (configFilePath === asNormalizedPath(f)) {
+                    return true;
+                  }
+                }
+              }
+            }
+          }
+          return false;
+        }
+        containsScriptInfo(info) {
+          if (this.isRoot(info))
+            return true;
+          if (!this.program)
+            return false;
+          const file = this.program.getSourceFileByPath(info.path);
+          return !!file && file.resolvedPath === info.path;
+        }
+        containsFile(filename, requireOpen) {
+          const info = this.projectService.getScriptInfoForNormalizedPath(filename);
+          if (info && (info.isScriptOpen() || !requireOpen)) {
+            return this.containsScriptInfo(info);
+          }
+          return false;
+        }
+        isRoot(info) {
+          var _a;
+          return this.rootFilesMap && ((_a = this.rootFilesMap.get(info.path)) == null ? void 0 : _a.info) === info;
+        }
+        // add a root file to project
+        addRoot(info, fileName) {
+          Debug.assert(!this.isRoot(info));
+          this.rootFiles.push(info);
+          this.rootFilesMap.set(info.path, { fileName: fileName || info.fileName, info });
+          info.attachToProject(this);
+          this.markAsDirty();
+        }
+        // add a root file that doesnt exist on host
+        addMissingFileRoot(fileName) {
+          const path = this.projectService.toPath(fileName);
+          this.rootFilesMap.set(path, { fileName });
+          this.markAsDirty();
+        }
+        removeFile(info, fileExists, detachFromProject) {
+          if (this.isRoot(info)) {
+            this.removeRoot(info);
+          }
+          if (fileExists) {
+            this.resolutionCache.removeResolutionsOfFile(info.path);
           } else {
-            addPrefixForAnyFunctionOrVar(symbol, symbolKind);
+            this.resolutionCache.invalidateResolutionOfFile(info.path);
           }
-          switch (symbolKind) {
-            case "JSX attribute" /* jsxAttribute */:
-            case "property" /* memberVariableElement */:
-            case "var" /* variableElement */:
-            case "const" /* constElement */:
-            case "let" /* letElement */:
-            case "parameter" /* parameterElement */:
-            case "local var" /* localVariableElement */:
-              displayParts.push(punctuationPart(59 /* ColonToken */));
-              displayParts.push(spacePart());
-              if (!(getObjectFlags(type) & 16 /* Anonymous */) && type.symbol) {
-                addRange(displayParts, symbolToDisplayParts(
-                  typeChecker,
-                  type.symbol,
-                  enclosingDeclaration,
-                  /*meaning*/
-                  void 0,
-                  4 /* AllowAnyNodeKind */ | 1 /* WriteTypeParametersOrArguments */
-                ));
-                displayParts.push(lineBreakPart());
+          this.cachedUnresolvedImportsPerFile.delete(info.path);
+          if (detachFromProject) {
+            info.detachFromProject(this);
+          }
+          this.markAsDirty();
+        }
+        registerFileUpdate(fileName) {
+          (this.updatedFileNames || (this.updatedFileNames = /* @__PURE__ */ new Set())).add(fileName);
+        }
+        /** @internal */
+        markFileAsDirty(changedFile) {
+          this.markAsDirty();
+          if (this.exportMapCache && !this.exportMapCache.isEmpty()) {
+            (this.changedFilesForExportMapCache || (this.changedFilesForExportMapCache = /* @__PURE__ */ new Set())).add(changedFile);
+          }
+        }
+        markAsDirty() {
+          if (!this.dirty) {
+            this.projectStateVersion++;
+            this.dirty = true;
+          }
+        }
+        /** @internal */
+        onAutoImportProviderSettingsChanged() {
+          var _a;
+          if (this.autoImportProviderHost === false) {
+            this.autoImportProviderHost = void 0;
+          } else {
+            (_a = this.autoImportProviderHost) == null ? void 0 : _a.markAsDirty();
+          }
+        }
+        /** @internal */
+        onPackageJsonChange(packageJsonPath) {
+          var _a;
+          if ((_a = this.packageJsonsForAutoImport) == null ? void 0 : _a.has(packageJsonPath)) {
+            this.moduleSpecifierCache.clear();
+            if (this.autoImportProviderHost) {
+              this.autoImportProviderHost.markAsDirty();
+            }
+          }
+        }
+        /** @internal */
+        onFileAddedOrRemoved(isSymlink) {
+          this.hasAddedorRemovedFiles = true;
+          if (isSymlink) {
+            this.hasAddedOrRemovedSymlinks = true;
+          }
+        }
+        /** @internal */
+        onDiscoveredSymlink() {
+          this.hasAddedOrRemovedSymlinks = true;
+        }
+        /**
+         * Updates set of files that contribute to this project
+         * @returns: true if set of files in the project stays the same and false - otherwise.
+         */
+        updateGraph() {
+          var _a, _b, _c, _d, _e;
+          (_a = tracing) == null ? void 0 : _a.push(tracing.Phase.Session, "updateGraph", { name: this.projectName, kind: ProjectKind[this.projectKind] });
+          (_b = perfLogger) == null ? void 0 : _b.logStartUpdateGraph();
+          this.resolutionCache.startRecordingFilesWithChangedResolutions();
+          const hasNewProgram = this.updateGraphWorker();
+          const hasAddedorRemovedFiles = this.hasAddedorRemovedFiles;
+          this.hasAddedorRemovedFiles = false;
+          this.hasAddedOrRemovedSymlinks = false;
+          const changedFiles = this.resolutionCache.finishRecordingFilesWithChangedResolutions() || emptyArray2;
+          for (const file of changedFiles) {
+            this.cachedUnresolvedImportsPerFile.delete(file);
+          }
+          if (this.languageServiceEnabled && this.projectService.serverMode === 0 /* Semantic */) {
+            if (hasNewProgram || changedFiles.length) {
+              this.lastCachedUnresolvedImportsList = getUnresolvedImports(this.program, this.cachedUnresolvedImportsPerFile);
+            }
+            this.projectService.typingsCache.enqueueInstallTypingsForProject(this, this.lastCachedUnresolvedImportsList, hasAddedorRemovedFiles);
+          } else {
+            this.lastCachedUnresolvedImportsList = void 0;
+          }
+          const isFirstProgramLoad = this.projectProgramVersion === 0 && hasNewProgram;
+          if (hasNewProgram) {
+            this.projectProgramVersion++;
+          }
+          if (hasAddedorRemovedFiles) {
+            if (!this.autoImportProviderHost)
+              this.autoImportProviderHost = void 0;
+            (_c = this.autoImportProviderHost) == null ? void 0 : _c.markAsDirty();
+          }
+          if (isFirstProgramLoad) {
+            this.getPackageJsonAutoImportProvider();
+          }
+          (_d = perfLogger) == null ? void 0 : _d.logStopUpdateGraph();
+          (_e = tracing) == null ? void 0 : _e.pop();
+          return !hasNewProgram;
+        }
+        /** @internal */
+        updateTypingFiles(typingFiles) {
+          if (enumerateInsertsAndDeletes(
+            typingFiles,
+            this.typingFiles,
+            getStringComparer(!this.useCaseSensitiveFileNames()),
+            /*inserted*/
+            noop,
+            (removed) => this.detachScriptInfoFromProject(removed)
+          )) {
+            this.typingFiles = typingFiles;
+            this.resolutionCache.setFilesWithInvalidatedNonRelativeUnresolvedImports(this.cachedUnresolvedImportsPerFile);
+            this.projectService.delayUpdateProjectGraphAndEnsureProjectStructureForOpenFiles(this);
+          }
+        }
+        /** @internal */
+        closeWatchingTypingLocations() {
+          if (this.typingWatchers)
+            clearMap(this.typingWatchers, closeFileWatcher);
+          this.typingWatchers = void 0;
+        }
+        /** @internal */
+        onTypingInstallerWatchInvoke() {
+          this.typingWatchers.isInvoked = true;
+          this.projectService.updateTypingsForProject({ projectName: this.getProjectName(), kind: ActionInvalidate });
+        }
+        /** @internal */
+        watchTypingLocations(files) {
+          if (!files) {
+            this.typingWatchers.isInvoked = false;
+            return;
+          }
+          if (!files.length) {
+            this.closeWatchingTypingLocations();
+            return;
+          }
+          const toRemove = new Map(this.typingWatchers);
+          if (!this.typingWatchers)
+            this.typingWatchers = /* @__PURE__ */ new Map();
+          this.typingWatchers.isInvoked = false;
+          const createProjectWatcher = (path, typingsWatcherType) => {
+            const canonicalPath = this.toPath(path);
+            toRemove.delete(canonicalPath);
+            if (!this.typingWatchers.has(canonicalPath)) {
+              this.typingWatchers.set(
+                canonicalPath,
+                typingsWatcherType === "FileWatcher" /* FileWatcher */ ? this.projectService.watchFactory.watchFile(
+                  path,
+                  () => !this.typingWatchers.isInvoked ? this.onTypingInstallerWatchInvoke() : this.writeLog(`TypingWatchers already invoked`),
+                  2e3 /* High */,
+                  this.projectService.getWatchOptions(this),
+                  WatchType.TypingInstallerLocationFile,
+                  this
+                ) : this.projectService.watchFactory.watchDirectory(
+                  path,
+                  (f) => {
+                    if (this.typingWatchers.isInvoked)
+                      return this.writeLog(`TypingWatchers already invoked`);
+                    if (!fileExtensionIs(f, ".json" /* Json */))
+                      return this.writeLog(`Ignoring files that are not *.json`);
+                    if (comparePaths(f, combinePaths(this.projectService.typingsInstaller.globalTypingsCacheLocation, "package.json"), !this.useCaseSensitiveFileNames()))
+                      return this.writeLog(`Ignoring package.json change at global typings location`);
+                    this.onTypingInstallerWatchInvoke();
+                  },
+                  1 /* Recursive */,
+                  this.projectService.getWatchOptions(this),
+                  WatchType.TypingInstallerLocationDirectory,
+                  this
+                )
+              );
+            }
+          };
+          for (const file of files) {
+            const basename = getBaseFileName(file);
+            if (basename === "package.json" || basename === "bower.json") {
+              createProjectWatcher(file, "FileWatcher" /* FileWatcher */);
+              continue;
+            }
+            if (containsPath(this.currentDirectory, file, this.currentDirectory, !this.useCaseSensitiveFileNames())) {
+              const subDirectory = file.indexOf(directorySeparator, this.currentDirectory.length + 1);
+              if (subDirectory !== -1) {
+                createProjectWatcher(file.substr(0, subDirectory), "DirectoryWatcher" /* DirectoryWatcher */);
+              } else {
+                createProjectWatcher(file, "DirectoryWatcher" /* DirectoryWatcher */);
               }
-              if (useConstructSignatures) {
-                if (signature.flags & 4 /* Abstract */) {
-                  displayParts.push(keywordPart(128 /* AbstractKeyword */));
-                  displayParts.push(spacePart());
+              continue;
+            }
+            if (containsPath(this.projectService.typingsInstaller.globalTypingsCacheLocation, file, this.currentDirectory, !this.useCaseSensitiveFileNames())) {
+              createProjectWatcher(this.projectService.typingsInstaller.globalTypingsCacheLocation, "DirectoryWatcher" /* DirectoryWatcher */);
+              continue;
+            }
+            createProjectWatcher(file, "DirectoryWatcher" /* DirectoryWatcher */);
+          }
+          toRemove.forEach((watch, path) => {
+            watch.close();
+            this.typingWatchers.delete(path);
+          });
+        }
+        /** @internal */
+        getCurrentProgram() {
+          return this.program;
+        }
+        removeExistingTypings(include) {
+          const existing = getAutomaticTypeDirectiveNames(this.getCompilerOptions(), this.directoryStructureHost);
+          return include.filter((i) => !existing.includes(i));
+        }
+        updateGraphWorker() {
+          var _a, _b;
+          const oldProgram = this.languageService.getCurrentProgram();
+          Debug.assert(oldProgram === this.program);
+          Debug.assert(!this.isClosed(), "Called update graph worker of closed project");
+          this.writeLog(`Starting updateGraphWorker: Project: ${this.getProjectName()}`);
+          const start = timestamp();
+          const { hasInvalidatedResolutions, hasInvalidatedLibResolutions } = this.resolutionCache.createHasInvalidatedResolutions(returnFalse, returnFalse);
+          this.hasInvalidatedResolutions = hasInvalidatedResolutions;
+          this.hasInvalidatedLibResolutions = hasInvalidatedLibResolutions;
+          this.resolutionCache.startCachingPerDirectoryResolution();
+          this.program = this.languageService.getProgram();
+          this.dirty = false;
+          (_a = tracing) == null ? void 0 : _a.push(tracing.Phase.Session, "finishCachingPerDirectoryResolution");
+          this.resolutionCache.finishCachingPerDirectoryResolution(this.program, oldProgram);
+          (_b = tracing) == null ? void 0 : _b.pop();
+          Debug.assert(oldProgram === void 0 || this.program !== void 0);
+          let hasNewProgram = false;
+          if (this.program && (!oldProgram || this.program !== oldProgram && this.program.structureIsReused !== 2 /* Completely */)) {
+            hasNewProgram = true;
+            if (oldProgram) {
+              for (const f of oldProgram.getSourceFiles()) {
+                const newFile = this.program.getSourceFileByPath(f.resolvedPath);
+                if (!newFile || f.resolvedPath === f.path && newFile.resolvedPath !== f.path) {
+                  this.detachScriptInfoFromProject(
+                    f.fileName,
+                    !!this.program.getSourceFileByPath(f.path),
+                    /*syncDirWatcherRemove*/
+                    true
+                  );
                 }
-                displayParts.push(keywordPart(105 /* NewKeyword */));
-                displayParts.push(spacePart());
               }
-              addSignatureDisplayParts(signature, allSignatures, 262144 /* WriteArrowStyleSignature */);
-              break;
-            default:
-              addSignatureDisplayParts(signature, allSignatures);
+              oldProgram.forEachResolvedProjectReference((resolvedProjectReference) => {
+                if (!this.program.getResolvedProjectReferenceByPath(resolvedProjectReference.sourceFile.path)) {
+                  this.detachScriptInfoFromProject(
+                    resolvedProjectReference.sourceFile.fileName,
+                    /*noRemoveResolution*/
+                    void 0,
+                    /*syncDirWatcherRemove*/
+                    true
+                  );
+                }
+              });
+            }
+            updateMissingFilePathsWatch(
+              this.program,
+              this.missingFilesMap || (this.missingFilesMap = /* @__PURE__ */ new Map()),
+              // Watch the missing files
+              (missingFilePath) => this.addMissingFileWatcher(missingFilePath)
+            );
+            if (this.generatedFilesMap) {
+              const outPath = outFile(this.compilerOptions);
+              if (isGeneratedFileWatcher(this.generatedFilesMap)) {
+                if (!outPath || !this.isValidGeneratedFileWatcher(
+                  removeFileExtension(outPath) + ".d.ts" /* Dts */,
+                  this.generatedFilesMap
+                )) {
+                  this.clearGeneratedFileWatch();
+                }
+              } else {
+                if (outPath) {
+                  this.clearGeneratedFileWatch();
+                } else {
+                  this.generatedFilesMap.forEach((watcher, source) => {
+                    const sourceFile = this.program.getSourceFileByPath(source);
+                    if (!sourceFile || sourceFile.resolvedPath !== source || !this.isValidGeneratedFileWatcher(
+                      getDeclarationEmitOutputFilePathWorker(sourceFile.fileName, this.compilerOptions, this.currentDirectory, this.program.getCommonSourceDirectory(), this.getCanonicalFileName),
+                      watcher
+                    )) {
+                      closeFileWatcherOf(watcher);
+                      this.generatedFilesMap.delete(source);
+                    }
+                  });
+                }
+              }
+            }
+            if (this.languageServiceEnabled && this.projectService.serverMode === 0 /* Semantic */) {
+              this.resolutionCache.updateTypeRootsWatch();
+            }
+          }
+          this.projectService.verifyProgram(this);
+          if (this.exportMapCache && !this.exportMapCache.isEmpty()) {
+            this.exportMapCache.releaseSymbols();
+            if (this.hasAddedorRemovedFiles || oldProgram && !this.program.structureIsReused) {
+              this.exportMapCache.clear();
+            } else if (this.changedFilesForExportMapCache && oldProgram && this.program) {
+              forEachKey(this.changedFilesForExportMapCache, (fileName) => {
+                const oldSourceFile = oldProgram.getSourceFileByPath(fileName);
+                const sourceFile = this.program.getSourceFileByPath(fileName);
+                if (!oldSourceFile || !sourceFile) {
+                  this.exportMapCache.clear();
+                  return true;
+                }
+                return this.exportMapCache.onFileChanged(oldSourceFile, sourceFile, !!this.getTypeAcquisition().enable);
+              });
+            }
           }
-          hasAddedSymbolInfo = true;
-          hasMultipleSignatures = allSignatures.length > 1;
+          if (this.changedFilesForExportMapCache) {
+            this.changedFilesForExportMapCache.clear();
+          }
+          if (this.hasAddedOrRemovedSymlinks || this.program && !this.program.structureIsReused && this.getCompilerOptions().preserveSymlinks) {
+            this.symlinks = void 0;
+            this.moduleSpecifierCache.clear();
+          }
+          const oldExternalFiles = this.externalFiles || emptyArray2;
+          this.externalFiles = this.getExternalFiles();
+          enumerateInsertsAndDeletes(
+            this.externalFiles,
+            oldExternalFiles,
+            getStringComparer(!this.useCaseSensitiveFileNames()),
+            // Ensure a ScriptInfo is created for new external files. This is performed indirectly
+            // by the host for files in the program when the program is retrieved above but
+            // the program doesn't contain external files so this must be done explicitly.
+            (inserted) => {
+              const scriptInfo = this.projectService.getOrCreateScriptInfoNotOpenedByClient(inserted, this.currentDirectory, this.directoryStructureHost);
+              scriptInfo == null ? void 0 : scriptInfo.attachToProject(this);
+            },
+            (removed) => this.detachScriptInfoFromProject(removed)
+          );
+          const elapsed = timestamp() - start;
+          this.sendPerformanceEvent("UpdateGraph", elapsed);
+          this.writeLog(`Finishing updateGraphWorker: Project: ${this.getProjectName()} Version: ${this.getProjectVersion()} structureChanged: ${hasNewProgram}${this.program ? ` structureIsReused:: ${StructureIsReused[this.program.structureIsReused]}` : ""} Elapsed: ${elapsed}ms`);
+          if (this.projectService.logger.isTestLogger) {
+            if (this.program !== oldProgram) {
+              this.print(
+                /*writeProjectFileNames*/
+                true,
+                this.hasAddedorRemovedFiles,
+                /*writeFileVersionAndText*/
+                true
+              );
+            } else {
+              this.writeLog(`Same program as before`);
+            }
+          } else if (this.hasAddedorRemovedFiles) {
+            this.print(
+              /*writeProjectFileNames*/
+              true,
+              /*writeFileExplaination*/
+              true,
+              /*writeFileVersionAndText*/
+              false
+            );
+          } else if (this.program !== oldProgram) {
+            this.writeLog(`Different program with same set of files`);
+          }
+          this.projectService.verifyDocumentRegistry();
+          return hasNewProgram;
         }
-      } else if (isNameOfFunctionDeclaration(location) && !(symbolFlags & 98304 /* Accessor */) || // name of function declaration
-      location.kind === 137 /* ConstructorKeyword */ && location.parent.kind === 175 /* Constructor */) {
-        const functionDeclaration = location.parent;
-        const locationIsSymbolDeclaration = symbol.declarations && find(symbol.declarations, (declaration) => declaration === (location.kind === 137 /* ConstructorKeyword */ ? functionDeclaration.parent : functionDeclaration));
-        if (locationIsSymbolDeclaration) {
-          const allSignatures = functionDeclaration.kind === 175 /* Constructor */ ? type.getNonNullableType().getConstructSignatures() : type.getNonNullableType().getCallSignatures();
-          if (!typeChecker.isImplementationOfOverload(functionDeclaration)) {
-            signature = typeChecker.getSignatureFromDeclaration(functionDeclaration);
+        /** @internal */
+        sendPerformanceEvent(kind, durationMs) {
+          this.projectService.sendPerformanceEvent(kind, durationMs);
+        }
+        detachScriptInfoFromProject(uncheckedFileName, noRemoveResolution, syncDirWatcherRemove) {
+          const scriptInfoToDetach = this.projectService.getScriptInfo(uncheckedFileName);
+          if (scriptInfoToDetach) {
+            scriptInfoToDetach.detachFromProject(this);
+            if (!noRemoveResolution) {
+              this.resolutionCache.removeResolutionsOfFile(scriptInfoToDetach.path, syncDirWatcherRemove);
+            }
+          }
+        }
+        addMissingFileWatcher(missingFilePath) {
+          var _a;
+          if (isConfiguredProject(this)) {
+            const configFileExistenceInfo = this.projectService.configFileExistenceInfoCache.get(missingFilePath);
+            if ((_a = configFileExistenceInfo == null ? void 0 : configFileExistenceInfo.config) == null ? void 0 : _a.projects.has(this.canonicalConfigFilePath))
+              return noopFileWatcher;
+          }
+          const fileWatcher = this.projectService.watchFactory.watchFile(
+            missingFilePath,
+            (fileName, eventKind) => {
+              if (isConfiguredProject(this)) {
+                this.getCachedDirectoryStructureHost().addOrDeleteFile(fileName, missingFilePath, eventKind);
+              }
+              if (eventKind === 0 /* Created */ && this.missingFilesMap.has(missingFilePath)) {
+                this.missingFilesMap.delete(missingFilePath);
+                fileWatcher.close();
+                this.projectService.delayUpdateProjectGraphAndEnsureProjectStructureForOpenFiles(this);
+              }
+            },
+            500 /* Medium */,
+            this.projectService.getWatchOptions(this),
+            WatchType.MissingFile,
+            this
+          );
+          return fileWatcher;
+        }
+        isWatchedMissingFile(path) {
+          return !!this.missingFilesMap && this.missingFilesMap.has(path);
+        }
+        /** @internal */
+        addGeneratedFileWatch(generatedFile, sourceFile) {
+          if (outFile(this.compilerOptions)) {
+            if (!this.generatedFilesMap) {
+              this.generatedFilesMap = this.createGeneratedFileWatcher(generatedFile);
+            }
           } else {
-            signature = allSignatures[0];
+            const path = this.toPath(sourceFile);
+            if (this.generatedFilesMap) {
+              if (isGeneratedFileWatcher(this.generatedFilesMap)) {
+                Debug.fail(`${this.projectName} Expected to not have --out watcher for generated file with options: ${JSON.stringify(this.compilerOptions)}`);
+                return;
+              }
+              if (this.generatedFilesMap.has(path))
+                return;
+            } else {
+              this.generatedFilesMap = /* @__PURE__ */ new Map();
+            }
+            this.generatedFilesMap.set(path, this.createGeneratedFileWatcher(generatedFile));
           }
-          if (functionDeclaration.kind === 175 /* Constructor */) {
-            symbolKind = "constructor" /* constructorImplementationElement */;
-            addPrefixForAnyFunctionOrVar(type.symbol, symbolKind);
+        }
+        createGeneratedFileWatcher(generatedFile) {
+          return {
+            generatedFilePath: this.toPath(generatedFile),
+            watcher: this.projectService.watchFactory.watchFile(
+              generatedFile,
+              () => {
+                this.clearSourceMapperCache();
+                this.projectService.delayUpdateProjectGraphAndEnsureProjectStructureForOpenFiles(this);
+              },
+              2e3 /* High */,
+              this.projectService.getWatchOptions(this),
+              WatchType.MissingGeneratedFile,
+              this
+            )
+          };
+        }
+        isValidGeneratedFileWatcher(generateFile, watcher) {
+          return this.toPath(generateFile) === watcher.generatedFilePath;
+        }
+        clearGeneratedFileWatch() {
+          if (this.generatedFilesMap) {
+            if (isGeneratedFileWatcher(this.generatedFilesMap)) {
+              closeFileWatcherOf(this.generatedFilesMap);
+            } else {
+              clearMap(this.generatedFilesMap, closeFileWatcherOf);
+            }
+            this.generatedFilesMap = void 0;
+          }
+        }
+        getScriptInfoForNormalizedPath(fileName) {
+          const scriptInfo = this.projectService.getScriptInfoForPath(this.toPath(fileName));
+          if (scriptInfo && !scriptInfo.isAttached(this)) {
+            return Errors.ThrowProjectDoesNotContainDocument(fileName, this);
+          }
+          return scriptInfo;
+        }
+        getScriptInfo(uncheckedFileName) {
+          return this.projectService.getScriptInfo(uncheckedFileName);
+        }
+        filesToString(writeProjectFileNames) {
+          return this.filesToStringWorker(
+            writeProjectFileNames,
+            /*writeFileExplaination*/
+            true,
+            /*writeFileVersionAndText*/
+            false
+          );
+        }
+        /** @internal */
+        filesToStringWorker(writeProjectFileNames, writeFileExplaination, writeFileVersionAndText) {
+          if (this.isInitialLoadPending())
+            return "	Files (0) InitialLoadPending\n";
+          if (!this.program)
+            return "	Files (0) NoProgram\n";
+          const sourceFiles = this.program.getSourceFiles();
+          let strBuilder = `	Files (${sourceFiles.length})
+`;
+          if (writeProjectFileNames) {
+            for (const file of sourceFiles) {
+              strBuilder += `	${file.fileName}${writeFileVersionAndText ? ` ${file.version} ${JSON.stringify(file.text)}` : ""}
+`;
+            }
+            if (writeFileExplaination) {
+              strBuilder += "\n\n";
+              explainFiles(this.program, (s) => strBuilder += `	${s}
+`);
+            }
+          }
+          return strBuilder;
+        }
+        /** @internal */
+        print(writeProjectFileNames, writeFileExplaination, writeFileVersionAndText) {
+          this.writeLog(`Project '${this.projectName}' (${ProjectKind[this.projectKind]})`);
+          this.writeLog(this.filesToStringWorker(
+            writeProjectFileNames && this.projectService.logger.hasLevel(3 /* verbose */),
+            writeFileExplaination && this.projectService.logger.hasLevel(3 /* verbose */),
+            writeFileVersionAndText && this.projectService.logger.hasLevel(3 /* verbose */)
+          ));
+          this.writeLog("-----------------------------------------------");
+          if (this.autoImportProviderHost) {
+            this.autoImportProviderHost.print(
+              /*writeProjectFileNames*/
+              false,
+              /*writeFileExplaination*/
+              false,
+              /*writeFileVersionAndText*/
+              false
+            );
+          }
+        }
+        setCompilerOptions(compilerOptions) {
+          var _a;
+          if (compilerOptions) {
+            compilerOptions.allowNonTsExtensions = true;
+            const oldOptions = this.compilerOptions;
+            this.compilerOptions = compilerOptions;
+            this.setInternalCompilerOptionsForEmittingJsFiles();
+            (_a = this.noDtsResolutionProject) == null ? void 0 : _a.setCompilerOptions(this.getCompilerOptionsForNoDtsResolutionProject());
+            if (changesAffectModuleResolution(oldOptions, compilerOptions)) {
+              this.cachedUnresolvedImportsPerFile.clear();
+              this.lastCachedUnresolvedImportsList = void 0;
+              this.resolutionCache.onChangesAffectModuleResolution();
+              this.moduleSpecifierCache.clear();
+            }
+            this.markAsDirty();
+          }
+        }
+        /** @internal */
+        setWatchOptions(watchOptions) {
+          this.watchOptions = watchOptions;
+        }
+        /** @internal */
+        getWatchOptions() {
+          return this.watchOptions;
+        }
+        setTypeAcquisition(newTypeAcquisition) {
+          if (newTypeAcquisition) {
+            this.typeAcquisition = this.removeLocalTypingsFromTypeAcquisition(newTypeAcquisition);
+          }
+        }
+        getTypeAcquisition() {
+          return this.typeAcquisition || {};
+        }
+        /** @internal */
+        getChangesSinceVersion(lastKnownVersion, includeProjectReferenceRedirectInfo) {
+          var _a, _b;
+          const includeProjectReferenceRedirectInfoIfRequested = includeProjectReferenceRedirectInfo ? (files) => arrayFrom(files.entries(), ([fileName, isSourceOfProjectReferenceRedirect]) => ({
+            fileName,
+            isSourceOfProjectReferenceRedirect
+          })) : (files) => arrayFrom(files.keys());
+          if (!this.isInitialLoadPending()) {
+            updateProjectIfDirty(this);
+          }
+          const info = {
+            projectName: this.getProjectName(),
+            version: this.projectProgramVersion,
+            isInferred: isInferredProject(this),
+            options: this.getCompilationSettings(),
+            languageServiceDisabled: !this.languageServiceEnabled,
+            lastFileExceededProgramSize: this.lastFileExceededProgramSize
+          };
+          const updatedFileNames = this.updatedFileNames;
+          this.updatedFileNames = void 0;
+          if (this.lastReportedFileNames && lastKnownVersion === this.lastReportedVersion) {
+            if (this.projectProgramVersion === this.lastReportedVersion && !updatedFileNames) {
+              return { info, projectErrors: this.getGlobalProjectErrors() };
+            }
+            const lastReportedFileNames = this.lastReportedFileNames;
+            const externalFiles = ((_a = this.externalFiles) == null ? void 0 : _a.map((f) => ({
+              fileName: toNormalizedPath(f),
+              isSourceOfProjectReferenceRedirect: false
+            }))) || emptyArray2;
+            const currentFiles = arrayToMap(
+              this.getFileNamesWithRedirectInfo(!!includeProjectReferenceRedirectInfo).concat(externalFiles),
+              (info2) => info2.fileName,
+              (info2) => info2.isSourceOfProjectReferenceRedirect
+            );
+            const added = /* @__PURE__ */ new Map();
+            const removed = /* @__PURE__ */ new Map();
+            const updated = updatedFileNames ? arrayFrom(updatedFileNames.keys()) : [];
+            const updatedRedirects = [];
+            forEachEntry(currentFiles, (isSourceOfProjectReferenceRedirect, fileName) => {
+              if (!lastReportedFileNames.has(fileName)) {
+                added.set(fileName, isSourceOfProjectReferenceRedirect);
+              } else if (includeProjectReferenceRedirectInfo && isSourceOfProjectReferenceRedirect !== lastReportedFileNames.get(fileName)) {
+                updatedRedirects.push({
+                  fileName,
+                  isSourceOfProjectReferenceRedirect
+                });
+              }
+            });
+            forEachEntry(lastReportedFileNames, (isSourceOfProjectReferenceRedirect, fileName) => {
+              if (!currentFiles.has(fileName)) {
+                removed.set(fileName, isSourceOfProjectReferenceRedirect);
+              }
+            });
+            this.lastReportedFileNames = currentFiles;
+            this.lastReportedVersion = this.projectProgramVersion;
+            return {
+              info,
+              changes: {
+                added: includeProjectReferenceRedirectInfoIfRequested(added),
+                removed: includeProjectReferenceRedirectInfoIfRequested(removed),
+                updated: includeProjectReferenceRedirectInfo ? updated.map((fileName) => ({
+                  fileName,
+                  isSourceOfProjectReferenceRedirect: this.isSourceOfProjectReferenceRedirect(fileName)
+                })) : updated,
+                updatedRedirects: includeProjectReferenceRedirectInfo ? updatedRedirects : void 0
+              },
+              projectErrors: this.getGlobalProjectErrors()
+            };
           } else {
-            addPrefixForAnyFunctionOrVar(functionDeclaration.kind === 178 /* CallSignature */ && !(type.symbol.flags & 2048 /* TypeLiteral */ || type.symbol.flags & 4096 /* ObjectLiteral */) ? type.symbol : symbol, symbolKind);
+            const projectFileNames = this.getFileNamesWithRedirectInfo(!!includeProjectReferenceRedirectInfo);
+            const externalFiles = ((_b = this.externalFiles) == null ? void 0 : _b.map((f) => ({
+              fileName: toNormalizedPath(f),
+              isSourceOfProjectReferenceRedirect: false
+            }))) || emptyArray2;
+            const allFiles = projectFileNames.concat(externalFiles);
+            this.lastReportedFileNames = arrayToMap(
+              allFiles,
+              (info2) => info2.fileName,
+              (info2) => info2.isSourceOfProjectReferenceRedirect
+            );
+            this.lastReportedVersion = this.projectProgramVersion;
+            return {
+              info,
+              files: includeProjectReferenceRedirectInfo ? allFiles : allFiles.map((f) => f.fileName),
+              projectErrors: this.getGlobalProjectErrors()
+            };
           }
-          if (signature) {
-            addSignatureDisplayParts(signature, allSignatures);
+        }
+        // remove a root file from project
+        removeRoot(info) {
+          orderedRemoveItem(this.rootFiles, info);
+          this.rootFilesMap.delete(info.path);
+        }
+        /** @internal */
+        isSourceOfProjectReferenceRedirect(fileName) {
+          return !!this.program && this.program.isSourceOfProjectReferenceRedirect(fileName);
+        }
+        /** @internal */
+        getGlobalPluginSearchPaths() {
+          return [
+            ...this.projectService.pluginProbeLocations,
+            // ../../.. to walk from X/node_modules/typescript/lib/tsserver.js to X/node_modules/
+            combinePaths(this.projectService.getExecutingFilePath(), "../../..")
+          ];
+        }
+        enableGlobalPlugins(options) {
+          if (!this.projectService.globalPlugins.length)
+            return;
+          const host = this.projectService.host;
+          if (!host.require && !host.importPlugin) {
+            this.projectService.logger.info("Plugins were requested but not running in environment that supports 'require'. Nothing will be loaded");
+            return;
+          }
+          const searchPaths = this.getGlobalPluginSearchPaths();
+          for (const globalPluginName of this.projectService.globalPlugins) {
+            if (!globalPluginName)
+              continue;
+            if (options.plugins && options.plugins.some((p) => p.name === globalPluginName))
+              continue;
+            this.projectService.logger.info(`Loading global plugin ${globalPluginName}`);
+            this.enablePlugin({ name: globalPluginName, global: true }, searchPaths);
           }
-          hasAddedSymbolInfo = true;
-          hasMultipleSignatures = allSignatures.length > 1;
         }
-      }
-    }
-    if (symbolFlags & 32 /* Class */ && !hasAddedSymbolInfo && !isThisExpression) {
-      addAliasPrefixIfNecessary();
-      if (getDeclarationOfKind(symbol, 230 /* ClassExpression */)) {
-        pushSymbolKind("local class" /* localClassElement */);
-      } else {
-        displayParts.push(keywordPart(86 /* ClassKeyword */));
-      }
-      displayParts.push(spacePart());
-      addFullSymbolName(symbol);
-      writeTypeParametersOfSymbol(symbol, sourceFile);
-    }
-    if (symbolFlags & 64 /* Interface */ && semanticMeaning & 2 /* Type */) {
-      prefixNextMeaning();
-      displayParts.push(keywordPart(120 /* InterfaceKeyword */));
-      displayParts.push(spacePart());
-      addFullSymbolName(symbol);
-      writeTypeParametersOfSymbol(symbol, sourceFile);
-    }
-    if (symbolFlags & 524288 /* TypeAlias */ && semanticMeaning & 2 /* Type */) {
-      prefixNextMeaning();
-      displayParts.push(keywordPart(156 /* TypeKeyword */));
-      displayParts.push(spacePart());
-      addFullSymbolName(symbol);
-      writeTypeParametersOfSymbol(symbol, sourceFile);
-      displayParts.push(spacePart());
-      displayParts.push(operatorPart(64 /* EqualsToken */));
-      displayParts.push(spacePart());
-      addRange(displayParts, typeToDisplayParts(typeChecker, location.parent && isConstTypeReference(location.parent) ? typeChecker.getTypeAtLocation(location.parent) : typeChecker.getDeclaredTypeOfSymbol(symbol), enclosingDeclaration, 8388608 /* InTypeAlias */));
-    }
-    if (symbolFlags & 384 /* Enum */) {
-      prefixNextMeaning();
-      if (some(symbol.declarations, (d) => isEnumDeclaration(d) && isEnumConst(d))) {
-        displayParts.push(keywordPart(87 /* ConstKeyword */));
-        displayParts.push(spacePart());
-      }
-      displayParts.push(keywordPart(94 /* EnumKeyword */));
-      displayParts.push(spacePart());
-      addFullSymbolName(symbol);
-    }
-    if (symbolFlags & 1536 /* Module */ && !isThisExpression) {
-      prefixNextMeaning();
-      const declaration = getDeclarationOfKind(symbol, 266 /* ModuleDeclaration */);
-      const isNamespace = declaration && declaration.name && declaration.name.kind === 80 /* Identifier */;
-      displayParts.push(keywordPart(isNamespace ? 145 /* NamespaceKeyword */ : 144 /* ModuleKeyword */));
-      displayParts.push(spacePart());
-      addFullSymbolName(symbol);
-    }
-    if (symbolFlags & 262144 /* TypeParameter */ && semanticMeaning & 2 /* Type */) {
-      prefixNextMeaning();
-      displayParts.push(punctuationPart(21 /* OpenParenToken */));
-      displayParts.push(textPart("type parameter"));
-      displayParts.push(punctuationPart(22 /* CloseParenToken */));
-      displayParts.push(spacePart());
-      addFullSymbolName(symbol);
-      if (symbol.parent) {
-        addInPrefix();
-        addFullSymbolName(symbol.parent, enclosingDeclaration);
-        writeTypeParametersOfSymbol(symbol.parent, enclosingDeclaration);
-      } else {
-        const decl = getDeclarationOfKind(symbol, 167 /* TypeParameter */);
-        if (decl === void 0)
-          return Debug.fail();
-        const declaration = decl.parent;
-        if (declaration) {
-          if (isFunctionLike(declaration)) {
-            addInPrefix();
-            const signature = typeChecker.getSignatureFromDeclaration(declaration);
-            if (declaration.kind === 179 /* ConstructSignature */) {
-              displayParts.push(keywordPart(105 /* NewKeyword */));
-              displayParts.push(spacePart());
-            } else if (declaration.kind !== 178 /* CallSignature */ && declaration.name) {
-              addFullSymbolName(declaration.symbol);
+        enablePlugin(pluginConfigEntry, searchPaths) {
+          this.projectService.requestEnablePlugin(this, pluginConfigEntry, searchPaths);
+        }
+        /** @internal */
+        enableProxy(pluginModuleFactory, configEntry) {
+          try {
+            if (typeof pluginModuleFactory !== "function") {
+              this.projectService.logger.info(`Skipped loading plugin ${configEntry.name} because it did not expose a proper factory function`);
+              return;
             }
-            addRange(displayParts, signatureToDisplayParts(typeChecker, signature, sourceFile, 32 /* WriteTypeArgumentsOfSignature */));
-          } else if (isTypeAliasDeclaration(declaration)) {
-            addInPrefix();
-            displayParts.push(keywordPart(156 /* TypeKeyword */));
-            displayParts.push(spacePart());
-            addFullSymbolName(declaration.symbol);
-            writeTypeParametersOfSymbol(declaration.symbol, sourceFile);
+            const info = {
+              config: configEntry,
+              project: this,
+              languageService: this.languageService,
+              languageServiceHost: this,
+              serverHost: this.projectService.host,
+              session: this.projectService.session
+            };
+            const pluginModule = pluginModuleFactory({ typescript: ts_exports2 });
+            const newLS = pluginModule.create(info);
+            for (const k of Object.keys(this.languageService)) {
+              if (!(k in newLS)) {
+                this.projectService.logger.info(`Plugin activation warning: Missing proxied method ${k} in created LS. Patching.`);
+                newLS[k] = this.languageService[k];
+              }
+            }
+            this.projectService.logger.info(`Plugin validation succeeded`);
+            this.languageService = newLS;
+            this.plugins.push({ name: configEntry.name, module: pluginModule });
+          } catch (e) {
+            this.projectService.logger.info(`Plugin activation failed: ${e}`);
+          }
+        }
+        /** @internal */
+        onPluginConfigurationChanged(pluginName, configuration) {
+          this.plugins.filter((plugin) => plugin.name === pluginName).forEach((plugin) => {
+            if (plugin.module.onConfigurationChanged) {
+              plugin.module.onConfigurationChanged(configuration);
+            }
+          });
+        }
+        /** Starts a new check for diagnostics. Call this if some file has updated that would cause diagnostics to be changed. */
+        refreshDiagnostics() {
+          this.projectService.sendProjectsUpdatedInBackgroundEvent();
+        }
+        /** @internal */
+        getPackageJsonsVisibleToFile(fileName, rootDir) {
+          if (this.projectService.serverMode !== 0 /* Semantic */)
+            return emptyArray2;
+          return this.projectService.getPackageJsonsVisibleToFile(fileName, rootDir);
+        }
+        /** @internal */
+        getNearestAncestorDirectoryWithPackageJson(fileName) {
+          return this.projectService.getNearestAncestorDirectoryWithPackageJson(fileName);
+        }
+        /** @internal */
+        getPackageJsonsForAutoImport(rootDir) {
+          const packageJsons = this.getPackageJsonsVisibleToFile(combinePaths(this.currentDirectory, inferredTypesContainingFile), rootDir);
+          this.packageJsonsForAutoImport = new Set(packageJsons.map((p) => p.fileName));
+          return packageJsons;
+        }
+        /** @internal */
+        getPackageJsonCache() {
+          return this.projectService.packageJsonCache;
+        }
+        /** @internal */
+        getCachedExportInfoMap() {
+          return this.exportMapCache || (this.exportMapCache = createCacheableExportInfoMap(this));
+        }
+        /** @internal */
+        clearCachedExportInfoMap() {
+          var _a;
+          (_a = this.exportMapCache) == null ? void 0 : _a.clear();
+        }
+        /** @internal */
+        getModuleSpecifierCache() {
+          return this.moduleSpecifierCache;
+        }
+        /** @internal */
+        includePackageJsonAutoImports() {
+          if (this.projectService.includePackageJsonAutoImports() === 0 /* Off */ || !this.languageServiceEnabled || isInsideNodeModules(this.currentDirectory) || !this.isDefaultProjectForOpenFiles()) {
+            return 0 /* Off */;
+          }
+          return this.projectService.includePackageJsonAutoImports();
+        }
+        /** @internal */
+        getHostForAutoImportProvider() {
+          var _a, _b;
+          if (this.program) {
+            return {
+              fileExists: this.program.fileExists,
+              directoryExists: this.program.directoryExists,
+              realpath: this.program.realpath || ((_a = this.projectService.host.realpath) == null ? void 0 : _a.bind(this.projectService.host)),
+              getCurrentDirectory: this.getCurrentDirectory.bind(this),
+              readFile: this.projectService.host.readFile.bind(this.projectService.host),
+              getDirectories: this.projectService.host.getDirectories.bind(this.projectService.host),
+              trace: (_b = this.projectService.host.trace) == null ? void 0 : _b.bind(this.projectService.host),
+              useCaseSensitiveFileNames: this.program.useCaseSensitiveFileNames(),
+              readDirectory: this.projectService.host.readDirectory.bind(this.projectService.host)
+            };
+          }
+          return this.projectService.host;
+        }
+        /** @internal */
+        getPackageJsonAutoImportProvider() {
+          var _a, _b, _c;
+          if (this.autoImportProviderHost === false) {
+            return void 0;
+          }
+          if (this.projectService.serverMode !== 0 /* Semantic */) {
+            this.autoImportProviderHost = false;
+            return void 0;
+          }
+          if (this.autoImportProviderHost) {
+            updateProjectIfDirty(this.autoImportProviderHost);
+            if (this.autoImportProviderHost.isEmpty()) {
+              this.autoImportProviderHost.close();
+              this.autoImportProviderHost = void 0;
+              return void 0;
+            }
+            return this.autoImportProviderHost.getCurrentProgram();
+          }
+          const dependencySelection = this.includePackageJsonAutoImports();
+          if (dependencySelection) {
+            (_a = tracing) == null ? void 0 : _a.push(tracing.Phase.Session, "getPackageJsonAutoImportProvider");
+            const start = timestamp();
+            this.autoImportProviderHost = AutoImportProviderProject.create(dependencySelection, this, this.getHostForAutoImportProvider(), this.documentRegistry);
+            if (this.autoImportProviderHost) {
+              updateProjectIfDirty(this.autoImportProviderHost);
+              this.sendPerformanceEvent("CreatePackageJsonAutoImportProvider", timestamp() - start);
+              (_b = tracing) == null ? void 0 : _b.pop();
+              return this.autoImportProviderHost.getCurrentProgram();
+            }
+            (_c = tracing) == null ? void 0 : _c.pop();
+          }
+        }
+        /** @internal */
+        isDefaultProjectForOpenFiles() {
+          return !!forEachEntry(
+            this.projectService.openFiles,
+            (_, fileName) => this.projectService.tryGetDefaultProjectForFile(toNormalizedPath(fileName)) === this
+          );
+        }
+        /** @internal */
+        watchNodeModulesForPackageJsonChanges(directoryPath) {
+          return this.projectService.watchPackageJsonsInNodeModules(this.toPath(directoryPath), this);
+        }
+        /** @internal */
+        getIncompleteCompletionsCache() {
+          return this.projectService.getIncompleteCompletionsCache();
+        }
+        /** @internal */
+        getNoDtsResolutionProject(rootFile) {
+          Debug.assert(this.projectService.serverMode === 0 /* Semantic */);
+          if (!this.noDtsResolutionProject) {
+            this.noDtsResolutionProject = new AuxiliaryProject(this.projectService, this.documentRegistry, this.getCompilerOptionsForNoDtsResolutionProject(), this.currentDirectory);
+          }
+          if (this.noDtsResolutionProject.rootFile !== rootFile) {
+            this.projectService.setFileNamesOfAutpImportProviderOrAuxillaryProject(this.noDtsResolutionProject, [rootFile]);
+            this.noDtsResolutionProject.rootFile = rootFile;
+          }
+          return this.noDtsResolutionProject;
+        }
+        /** @internal */
+        getCompilerOptionsForNoDtsResolutionProject() {
+          return {
+            ...this.getCompilerOptions(),
+            noDtsResolution: true,
+            allowJs: true,
+            maxNodeModuleJsDepth: 3,
+            diagnostics: false,
+            skipLibCheck: true,
+            sourceMap: false,
+            types: emptyArray,
+            lib: emptyArray,
+            noLib: true
+          };
+        }
+      };
+      InferredProject2 = class extends Project3 {
+        /** @internal */
+        constructor(projectService, documentRegistry, compilerOptions, watchOptions, projectRootPath, currentDirectory, typeAcquisition) {
+          super(
+            projectService.newInferredProjectName(),
+            0 /* Inferred */,
+            projectService,
+            documentRegistry,
+            // TODO: GH#18217
+            /*files*/
+            void 0,
+            /*lastFileExceededProgramSize*/
+            void 0,
+            compilerOptions,
+            /*compileOnSaveEnabled*/
+            false,
+            watchOptions,
+            projectService.host,
+            currentDirectory
+          );
+          this._isJsInferredProject = false;
+          this.typeAcquisition = typeAcquisition;
+          this.projectRootPath = projectRootPath && projectService.toCanonicalFileName(projectRootPath);
+          if (!projectRootPath && !projectService.useSingleInferredProject) {
+            this.canonicalCurrentDirectory = projectService.toCanonicalFileName(this.currentDirectory);
           }
+          this.enableGlobalPlugins(this.getCompilerOptions());
         }
-      }
-    }
-    if (symbolFlags & 8 /* EnumMember */) {
-      symbolKind = "enum member" /* enumMemberElement */;
-      addPrefixForAnyFunctionOrVar(symbol, "enum member");
-      const declaration = (_a = symbol.declarations) == null ? void 0 : _a[0];
-      if ((declaration == null ? void 0 : declaration.kind) === 305 /* EnumMember */) {
-        const constantValue = typeChecker.getConstantValue(declaration);
-        if (constantValue !== void 0) {
-          displayParts.push(spacePart());
-          displayParts.push(operatorPart(64 /* EqualsToken */));
-          displayParts.push(spacePart());
-          displayParts.push(displayPart(
-            getTextOfConstantValue(constantValue),
-            typeof constantValue === "number" ? 7 /* numericLiteral */ : 8 /* stringLiteral */
-          ));
+        toggleJsInferredProject(isJsInferredProject) {
+          if (isJsInferredProject !== this._isJsInferredProject) {
+            this._isJsInferredProject = isJsInferredProject;
+            this.setCompilerOptions();
+          }
         }
-      }
-    }
-    if (symbol.flags & 2097152 /* Alias */) {
-      prefixNextMeaning();
-      if (!hasAddedSymbolInfo || documentation.length === 0 && tags.length === 0) {
-        const resolvedSymbol = typeChecker.getAliasedSymbol(symbol);
-        if (resolvedSymbol !== symbol && resolvedSymbol.declarations && resolvedSymbol.declarations.length > 0) {
-          const resolvedNode = resolvedSymbol.declarations[0];
-          const declarationName = getNameOfDeclaration(resolvedNode);
-          if (declarationName && !hasAddedSymbolInfo) {
-            const isExternalModuleDeclaration = isModuleWithStringLiteralName(resolvedNode) && hasSyntacticModifier(resolvedNode, 2 /* Ambient */);
-            const shouldUseAliasName = symbol.name !== "default" && !isExternalModuleDeclaration;
-            const resolvedInfo = getSymbolDisplayPartsDocumentationAndSymbolKind(
-              typeChecker,
-              resolvedSymbol,
-              getSourceFileOfNode(resolvedNode),
-              resolvedNode,
-              declarationName,
-              semanticMeaning,
-              shouldUseAliasName ? symbol : resolvedSymbol
+        setCompilerOptions(options) {
+          if (!options && !this.getCompilationSettings()) {
+            return;
+          }
+          const newOptions = cloneCompilerOptions(options || this.getCompilationSettings());
+          if (this._isJsInferredProject && typeof newOptions.maxNodeModuleJsDepth !== "number") {
+            newOptions.maxNodeModuleJsDepth = 2;
+          } else if (!this._isJsInferredProject) {
+            newOptions.maxNodeModuleJsDepth = void 0;
+          }
+          newOptions.allowJs = true;
+          super.setCompilerOptions(newOptions);
+        }
+        addRoot(info) {
+          Debug.assert(info.isScriptOpen());
+          this.projectService.startWatchingConfigFilesForInferredProjectRoot(info);
+          if (!this._isJsInferredProject && info.isJavaScript()) {
+            this.toggleJsInferredProject(
+              /*isJsInferredProject*/
+              true
+            );
+          } else if (this.isOrphan() && this._isJsInferredProject && !info.isJavaScript()) {
+            this.toggleJsInferredProject(
+              /*isJsInferredProject*/
+              false
             );
-            displayParts.push(...resolvedInfo.displayParts);
-            displayParts.push(lineBreakPart());
-            documentationFromAlias = resolvedInfo.documentation;
-            tagsFromAlias = resolvedInfo.tags;
-          } else {
-            documentationFromAlias = resolvedSymbol.getContextualDocumentationComment(resolvedNode, typeChecker);
-            tagsFromAlias = resolvedSymbol.getJsDocTags(typeChecker);
           }
+          super.addRoot(info);
         }
-      }
-      if (symbol.declarations) {
-        switch (symbol.declarations[0].kind) {
-          case 269 /* NamespaceExportDeclaration */:
-            displayParts.push(keywordPart(95 /* ExportKeyword */));
-            displayParts.push(spacePart());
-            displayParts.push(keywordPart(145 /* NamespaceKeyword */));
-            break;
-          case 276 /* ExportAssignment */:
-            displayParts.push(keywordPart(95 /* ExportKeyword */));
-            displayParts.push(spacePart());
-            displayParts.push(keywordPart(symbol.declarations[0].isExportEquals ? 64 /* EqualsToken */ : 90 /* DefaultKeyword */));
-            break;
-          case 280 /* ExportSpecifier */:
-            displayParts.push(keywordPart(95 /* ExportKeyword */));
-            break;
-          default:
-            displayParts.push(keywordPart(102 /* ImportKeyword */));
-        }
-      }
-      displayParts.push(spacePart());
-      addFullSymbolName(symbol);
-      forEach(symbol.declarations, (declaration) => {
-        if (declaration.kind === 270 /* ImportEqualsDeclaration */) {
-          const importEqualsDeclaration = declaration;
-          if (isExternalModuleImportEqualsDeclaration(importEqualsDeclaration)) {
-            displayParts.push(spacePart());
-            displayParts.push(operatorPart(64 /* EqualsToken */));
-            displayParts.push(spacePart());
-            displayParts.push(keywordPart(149 /* RequireKeyword */));
-            displayParts.push(punctuationPart(21 /* OpenParenToken */));
-            displayParts.push(displayPart(getTextOfNode(getExternalModuleImportEqualsDeclarationExpression(importEqualsDeclaration)), 8 /* stringLiteral */));
-            displayParts.push(punctuationPart(22 /* CloseParenToken */));
-          } else {
-            const internalAliasSymbol = typeChecker.getSymbolAtLocation(importEqualsDeclaration.moduleReference);
-            if (internalAliasSymbol) {
-              displayParts.push(spacePart());
-              displayParts.push(operatorPart(64 /* EqualsToken */));
-              displayParts.push(spacePart());
-              addFullSymbolName(internalAliasSymbol, enclosingDeclaration);
+        removeRoot(info) {
+          this.projectService.stopWatchingConfigFilesForInferredProjectRoot(info);
+          super.removeRoot(info);
+          if (!this.isOrphan() && this._isJsInferredProject && info.isJavaScript()) {
+            if (every(this.getRootScriptInfos(), (rootInfo) => !rootInfo.isJavaScript())) {
+              this.toggleJsInferredProject(
+                /*isJsInferredProject*/
+                false
+              );
             }
           }
+        }
+        /** @internal */
+        isOrphan() {
+          return !this.hasRoots();
+        }
+        isProjectWithSingleRoot() {
+          return !this.projectRootPath && !this.projectService.useSingleInferredProject || this.getRootScriptInfos().length === 1;
+        }
+        close() {
+          forEach(this.getRootScriptInfos(), (info) => this.projectService.stopWatchingConfigFilesForInferredProjectRoot(info));
+          super.close();
+        }
+        getTypeAcquisition() {
+          return this.typeAcquisition || {
+            enable: allRootFilesAreJsOrDts(this),
+            include: emptyArray,
+            exclude: emptyArray
+          };
+        }
+      };
+      AuxiliaryProject = class extends Project3 {
+        constructor(projectService, documentRegistry, compilerOptions, currentDirectory) {
+          super(
+            projectService.newAuxiliaryProjectName(),
+            4 /* Auxiliary */,
+            projectService,
+            documentRegistry,
+            /*hasExplicitListOfFiles*/
+            false,
+            /*lastFileExceededProgramSize*/
+            void 0,
+            compilerOptions,
+            /*compileOnSaveEnabled*/
+            false,
+            /*watchOptions*/
+            void 0,
+            projectService.host,
+            currentDirectory
+          );
+        }
+        isOrphan() {
           return true;
         }
-      });
-    }
-    if (!hasAddedSymbolInfo) {
-      if (symbolKind !== "" /* unknown */) {
-        if (type) {
-          if (isThisExpression) {
-            prefixNextMeaning();
-            displayParts.push(keywordPart(110 /* ThisKeyword */));
-          } else {
-            addPrefixForAnyFunctionOrVar(symbol, symbolKind);
+        scheduleInvalidateResolutionsOfFailedLookupLocations() {
+          return;
+        }
+      };
+      _AutoImportProviderProject = class _AutoImportProviderProject extends Project3 {
+        /** @internal */
+        constructor(hostProject, initialRootNames, documentRegistry, compilerOptions) {
+          super(
+            hostProject.projectService.newAutoImportProviderProjectName(),
+            3 /* AutoImportProvider */,
+            hostProject.projectService,
+            documentRegistry,
+            /*hasExplicitListOfFiles*/
+            false,
+            /*lastFileExceededProgramSize*/
+            void 0,
+            compilerOptions,
+            /*compileOnSaveEnabled*/
+            false,
+            hostProject.getWatchOptions(),
+            hostProject.projectService.host,
+            hostProject.currentDirectory
+          );
+          this.hostProject = hostProject;
+          this.rootFileNames = initialRootNames;
+          this.useSourceOfProjectReferenceRedirect = maybeBind(this.hostProject, this.hostProject.useSourceOfProjectReferenceRedirect);
+          this.getParsedCommandLine = maybeBind(this.hostProject, this.hostProject.getParsedCommandLine);
+        }
+        /** @internal */
+        static getRootFileNames(dependencySelection, hostProject, host, compilerOptions) {
+          var _a, _b;
+          if (!dependencySelection) {
+            return emptyArray;
           }
-          if (symbolKind === "property" /* memberVariableElement */ || symbolKind === "accessor" /* memberAccessorVariableElement */ || symbolKind === "getter" /* memberGetAccessorElement */ || symbolKind === "setter" /* memberSetAccessorElement */ || symbolKind === "JSX attribute" /* jsxAttribute */ || symbolFlags & 3 /* Variable */ || symbolKind === "local var" /* localVariableElement */ || symbolKind === "index" /* indexSignatureElement */ || isThisExpression) {
-            displayParts.push(punctuationPart(59 /* ColonToken */));
-            displayParts.push(spacePart());
-            if (type.symbol && type.symbol.flags & 262144 /* TypeParameter */ && symbolKind !== "index" /* indexSignatureElement */) {
-              const typeParameterParts = mapToDisplayParts((writer) => {
-                const param = typeChecker.typeParameterToDeclaration(type, enclosingDeclaration, symbolDisplayNodeBuilderFlags);
-                getPrinter().writeNode(4 /* Unspecified */, param, getSourceFileOfNode(getParseTreeNode(enclosingDeclaration)), writer);
+          const program = hostProject.getCurrentProgram();
+          if (!program) {
+            return emptyArray;
+          }
+          const start = timestamp();
+          let dependencyNames;
+          let rootNames;
+          const rootFileName = combinePaths(hostProject.currentDirectory, inferredTypesContainingFile);
+          const packageJsons = hostProject.getPackageJsonsForAutoImport(combinePaths(hostProject.currentDirectory, rootFileName));
+          for (const packageJson of packageJsons) {
+            (_a = packageJson.dependencies) == null ? void 0 : _a.forEach((_, dependenyName) => addDependency(dependenyName));
+            (_b = packageJson.peerDependencies) == null ? void 0 : _b.forEach((_, dependencyName) => addDependency(dependencyName));
+          }
+          let dependenciesAdded = 0;
+          if (dependencyNames) {
+            const symlinkCache = hostProject.getSymlinkCache();
+            for (const name of arrayFrom(dependencyNames.keys())) {
+              if (dependencySelection === 2 /* Auto */ && dependenciesAdded > this.maxDependencies) {
+                hostProject.log(`AutoImportProviderProject: attempted to add more than ${this.maxDependencies} dependencies. Aborting.`);
+                return emptyArray;
+              }
+              const packageJson = resolvePackageNameToPackageJson(
+                name,
+                hostProject.currentDirectory,
+                compilerOptions,
+                host,
+                program.getModuleResolutionCache()
+              );
+              if (packageJson) {
+                const entrypoints = getRootNamesFromPackageJson(packageJson, program, symlinkCache);
+                if (entrypoints) {
+                  rootNames = concatenate(rootNames, entrypoints);
+                  dependenciesAdded += entrypoints.length ? 1 : 0;
+                  continue;
+                }
+              }
+              const done = forEach([hostProject.currentDirectory, hostProject.getGlobalTypingsCacheLocation()], (directory) => {
+                if (directory) {
+                  const typesPackageJson = resolvePackageNameToPackageJson(
+                    `@types/${name}`,
+                    directory,
+                    compilerOptions,
+                    host,
+                    program.getModuleResolutionCache()
+                  );
+                  if (typesPackageJson) {
+                    const entrypoints = getRootNamesFromPackageJson(typesPackageJson, program, symlinkCache);
+                    rootNames = concatenate(rootNames, entrypoints);
+                    dependenciesAdded += (entrypoints == null ? void 0 : entrypoints.length) ? 1 : 0;
+                    return true;
+                  }
+                }
               });
-              addRange(displayParts, typeParameterParts);
-            } else {
-              addRange(displayParts, typeToDisplayParts(typeChecker, type, enclosingDeclaration));
+              if (done)
+                continue;
+              if (packageJson && compilerOptions.allowJs && compilerOptions.maxNodeModuleJsDepth) {
+                const entrypoints = getRootNamesFromPackageJson(
+                  packageJson,
+                  program,
+                  symlinkCache,
+                  /*resolveJs*/
+                  true
+                );
+                rootNames = concatenate(rootNames, entrypoints);
+                dependenciesAdded += (entrypoints == null ? void 0 : entrypoints.length) ? 1 : 0;
+              }
             }
-            if (isTransientSymbol(symbol) && symbol.links.target && isTransientSymbol(symbol.links.target) && symbol.links.target.links.tupleLabelDeclaration) {
-              const labelDecl = symbol.links.target.links.tupleLabelDeclaration;
-              Debug.assertNode(labelDecl.name, isIdentifier);
-              displayParts.push(spacePart());
-              displayParts.push(punctuationPart(21 /* OpenParenToken */));
-              displayParts.push(textPart(idText(labelDecl.name)));
-              displayParts.push(punctuationPart(22 /* CloseParenToken */));
+          }
+          if (rootNames == null ? void 0 : rootNames.length) {
+            hostProject.log(`AutoImportProviderProject: found ${rootNames.length} root files in ${dependenciesAdded} dependencies in ${timestamp() - start} ms`);
+          }
+          return rootNames || emptyArray;
+          function addDependency(dependency) {
+            if (!startsWith(dependency, "@types/")) {
+              (dependencyNames || (dependencyNames = /* @__PURE__ */ new Set())).add(dependency);
             }
-          } else if (symbolFlags & 16 /* Function */ || symbolFlags & 8192 /* Method */ || symbolFlags & 16384 /* Constructor */ || symbolFlags & 131072 /* Signature */ || symbolFlags & 98304 /* Accessor */ || symbolKind === "method" /* memberFunctionElement */) {
-            const allSignatures = type.getNonNullableType().getCallSignatures();
-            if (allSignatures.length) {
-              addSignatureDisplayParts(allSignatures[0], allSignatures);
-              hasMultipleSignatures = allSignatures.length > 1;
+          }
+          function getRootNamesFromPackageJson(packageJson, program2, symlinkCache, resolveJs) {
+            var _a2;
+            const entrypoints = getEntrypointsFromPackageJsonInfo(
+              packageJson,
+              compilerOptions,
+              host,
+              program2.getModuleResolutionCache(),
+              resolveJs
+            );
+            if (entrypoints) {
+              const real = (_a2 = host.realpath) == null ? void 0 : _a2.call(host, packageJson.packageDirectory);
+              const realPath2 = real ? hostProject.toPath(real) : void 0;
+              const isSymlink = realPath2 && realPath2 !== hostProject.toPath(packageJson.packageDirectory);
+              if (isSymlink) {
+                symlinkCache.setSymlinkedDirectory(packageJson.packageDirectory, {
+                  real: ensureTrailingDirectorySeparator(real),
+                  realPath: ensureTrailingDirectorySeparator(realPath2)
+                });
+              }
+              return mapDefined(entrypoints, (entrypoint) => {
+                const resolvedFileName = isSymlink ? entrypoint.replace(packageJson.packageDirectory, real) : entrypoint;
+                if (!program2.getSourceFile(resolvedFileName) && !(isSymlink && program2.getSourceFile(entrypoint))) {
+                  return resolvedFileName;
+                }
+              });
             }
           }
         }
-      } else {
-        symbolKind = getSymbolKind(typeChecker, symbol, location);
-      }
-    }
-    if (documentation.length === 0 && !hasMultipleSignatures) {
-      documentation = symbol.getContextualDocumentationComment(enclosingDeclaration, typeChecker);
-    }
-    if (documentation.length === 0 && symbolFlags & 4 /* Property */) {
-      if (symbol.parent && symbol.declarations && forEach(symbol.parent.declarations, (declaration) => declaration.kind === 311 /* SourceFile */)) {
-        for (const declaration of symbol.declarations) {
-          if (!declaration.parent || declaration.parent.kind !== 225 /* BinaryExpression */) {
-            continue;
-          }
-          const rhsSymbol = typeChecker.getSymbolAtLocation(declaration.parent.right);
-          if (!rhsSymbol) {
-            continue;
+        /** @internal */
+        static create(dependencySelection, hostProject, host, documentRegistry) {
+          if (dependencySelection === 0 /* Off */) {
+            return void 0;
           }
-          documentation = rhsSymbol.getDocumentationComment(typeChecker);
-          tags = rhsSymbol.getJsDocTags(typeChecker);
-          if (documentation.length > 0) {
-            break;
+          const compilerOptions = {
+            ...hostProject.getCompilerOptions(),
+            ...this.compilerOptionsOverrides
+          };
+          const rootNames = this.getRootFileNames(dependencySelection, hostProject, host, compilerOptions);
+          if (!rootNames.length) {
+            return void 0;
           }
+          return new _AutoImportProviderProject(hostProject, rootNames, documentRegistry, compilerOptions);
         }
-      }
-    }
-    if (documentation.length === 0 && isIdentifier(location) && symbol.valueDeclaration && isBindingElement(symbol.valueDeclaration)) {
-      const declaration = symbol.valueDeclaration;
-      const parent2 = declaration.parent;
-      if (isIdentifier(declaration.name) && isObjectBindingPattern(parent2)) {
-        const name = getTextOfIdentifierOrLiteral(declaration.name);
-        const objectType = typeChecker.getTypeAtLocation(parent2);
-        documentation = firstDefined(objectType.isUnion() ? objectType.types : [objectType], (t) => {
-          const prop = t.getProperty(name);
-          return prop ? prop.getDocumentationComment(typeChecker) : void 0;
-        }) || emptyArray;
-      }
-    }
-    if (tags.length === 0 && !hasMultipleSignatures) {
-      tags = symbol.getContextualJsDocTags(enclosingDeclaration, typeChecker);
-    }
-    if (documentation.length === 0 && documentationFromAlias) {
-      documentation = documentationFromAlias;
-    }
-    if (tags.length === 0 && tagsFromAlias) {
-      tags = tagsFromAlias;
-    }
-    return { displayParts, documentation, symbolKind, tags: tags.length === 0 ? void 0 : tags };
-    function getPrinter() {
-      return createPrinterWithRemoveComments();
-    }
-    function prefixNextMeaning() {
-      if (displayParts.length) {
-        displayParts.push(lineBreakPart());
-      }
-      addAliasPrefixIfNecessary();
-    }
-    function addAliasPrefixIfNecessary() {
-      if (alias) {
-        pushSymbolKind("alias" /* alias */);
-        displayParts.push(spacePart());
-      }
-    }
-    function addInPrefix() {
-      displayParts.push(spacePart());
-      displayParts.push(keywordPart(103 /* InKeyword */));
-      displayParts.push(spacePart());
-    }
-    function addFullSymbolName(symbolToDisplay, enclosingDeclaration2) {
-      let indexInfos;
-      if (alias && symbolToDisplay === symbol) {
-        symbolToDisplay = alias;
-      }
-      if (symbolKind === "index" /* indexSignatureElement */) {
-        indexInfos = typeChecker.getIndexInfosOfIndexSymbol(symbolToDisplay);
-      }
-      let fullSymbolDisplayParts = [];
-      if (symbolToDisplay.flags & 131072 /* Signature */ && indexInfos) {
-        if (symbolToDisplay.parent) {
-          fullSymbolDisplayParts = symbolToDisplayParts(typeChecker, symbolToDisplay.parent);
+        /** @internal */
+        isEmpty() {
+          return !some(this.rootFileNames);
         }
-        fullSymbolDisplayParts.push(punctuationPart(23 /* OpenBracketToken */));
-        indexInfos.forEach((info, i) => {
-          fullSymbolDisplayParts.push(...typeToDisplayParts(typeChecker, info.keyType));
-          if (i !== indexInfos.length - 1) {
-            fullSymbolDisplayParts.push(spacePart());
-            fullSymbolDisplayParts.push(punctuationPart(52 /* BarToken */));
-            fullSymbolDisplayParts.push(spacePart());
+        isOrphan() {
+          return true;
+        }
+        updateGraph() {
+          let rootFileNames = this.rootFileNames;
+          if (!rootFileNames) {
+            rootFileNames = _AutoImportProviderProject.getRootFileNames(
+              this.hostProject.includePackageJsonAutoImports(),
+              this.hostProject,
+              this.hostProject.getHostForAutoImportProvider(),
+              this.getCompilationSettings()
+            );
           }
-        });
-        fullSymbolDisplayParts.push(punctuationPart(24 /* CloseBracketToken */));
-      } else {
-        fullSymbolDisplayParts = symbolToDisplayParts(
-          typeChecker,
-          symbolToDisplay,
-          enclosingDeclaration2 || sourceFile,
-          /*meaning*/
-          void 0,
-          1 /* WriteTypeParametersOrArguments */ | 2 /* UseOnlyExternalAliasing */ | 4 /* AllowAnyNodeKind */
-        );
-      }
-      addRange(displayParts, fullSymbolDisplayParts);
-      if (symbol.flags & 16777216 /* Optional */) {
-        displayParts.push(punctuationPart(58 /* QuestionToken */));
-      }
-    }
-    function addPrefixForAnyFunctionOrVar(symbol2, symbolKind2) {
-      prefixNextMeaning();
-      if (symbolKind2) {
-        pushSymbolKind(symbolKind2);
-        if (symbol2 && !some(symbol2.declarations, (d) => isArrowFunction(d) || (isFunctionExpression(d) || isClassExpression(d)) && !d.name)) {
-          displayParts.push(spacePart());
-          addFullSymbolName(symbol2);
+          this.projectService.setFileNamesOfAutpImportProviderOrAuxillaryProject(this, rootFileNames);
+          this.rootFileNames = rootFileNames;
+          const oldProgram = this.getCurrentProgram();
+          const hasSameSetOfFiles = super.updateGraph();
+          if (oldProgram && oldProgram !== this.getCurrentProgram()) {
+            this.hostProject.clearCachedExportInfoMap();
+          }
+          return hasSameSetOfFiles;
         }
-      }
-    }
-    function pushSymbolKind(symbolKind2) {
-      switch (symbolKind2) {
-        case "var" /* variableElement */:
-        case "function" /* functionElement */:
-        case "let" /* letElement */:
-        case "const" /* constElement */:
-        case "constructor" /* constructorImplementationElement */:
-          displayParts.push(textOrKeywordPart(symbolKind2));
-          return;
-        default:
-          displayParts.push(punctuationPart(21 /* OpenParenToken */));
-          displayParts.push(textOrKeywordPart(symbolKind2));
-          displayParts.push(punctuationPart(22 /* CloseParenToken */));
+        /** @internal */
+        scheduleInvalidateResolutionsOfFailedLookupLocations() {
           return;
-      }
+        }
+        hasRoots() {
+          var _a;
+          return !!((_a = this.rootFileNames) == null ? void 0 : _a.length);
+        }
+        markAsDirty() {
+          this.rootFileNames = void 0;
+          super.markAsDirty();
+        }
+        getScriptFileNames() {
+          return this.rootFileNames || emptyArray;
+        }
+        getLanguageService() {
+          throw new Error("AutoImportProviderProject language service should never be used. To get the program, use `project.getCurrentProgram()`.");
+        }
+        /** @internal */
+        onAutoImportProviderSettingsChanged() {
+          throw new Error("AutoImportProviderProject is an auto import provider; use `markAsDirty()` instead.");
+        }
+        /** @internal */
+        onPackageJsonChange() {
+          throw new Error("package.json changes should be notified on an AutoImportProvider's host project");
+        }
+        getHostForAutoImportProvider() {
+          throw new Error("AutoImportProviderProject cannot provide its own host; use `hostProject.getModuleResolutionHostForAutomImportProvider()` instead.");
+        }
+        getProjectReferences() {
+          return this.hostProject.getProjectReferences();
+        }
+        /** @internal */
+        includePackageJsonAutoImports() {
+          return 0 /* Off */;
+        }
+        /** @internal */
+        getSymlinkCache() {
+          return this.hostProject.getSymlinkCache();
+        }
+        /** @internal */
+        getModuleResolutionCache() {
+          var _a;
+          return (_a = this.hostProject.getCurrentProgram()) == null ? void 0 : _a.getModuleResolutionCache();
+        }
+      };
+      /** @internal */
+      _AutoImportProviderProject.maxDependencies = 10;
+      /** @internal */
+      _AutoImportProviderProject.compilerOptionsOverrides = {
+        diagnostics: false,
+        skipLibCheck: true,
+        sourceMap: false,
+        types: emptyArray,
+        lib: emptyArray,
+        noLib: true
+      };
+      AutoImportProviderProject = _AutoImportProviderProject;
+      ConfiguredProject2 = class extends Project3 {
+        /** @internal */
+        constructor(configFileName, canonicalConfigFilePath, projectService, documentRegistry, cachedDirectoryStructureHost) {
+          super(
+            configFileName,
+            1 /* Configured */,
+            projectService,
+            documentRegistry,
+            /*hasExplicitListOfFiles*/
+            false,
+            /*lastFileExceededProgramSize*/
+            void 0,
+            /*compilerOptions*/
+            {},
+            /*compileOnSaveEnabled*/
+            false,
+            /*watchOptions*/
+            void 0,
+            cachedDirectoryStructureHost,
+            getDirectoryPath(configFileName)
+          );
+          this.canonicalConfigFilePath = canonicalConfigFilePath;
+          /** @internal */
+          this.openFileWatchTriggered = /* @__PURE__ */ new Map();
+          /** @internal */
+          this.canConfigFileJsonReportNoInputFiles = false;
+          /** Ref count to the project when opened from external project */
+          this.externalProjectRefCount = 0;
+          /** @internal */
+          this.isInitialLoadPending = returnTrue;
+          /** @internal */
+          this.sendLoadingProjectFinish = false;
+        }
+        /** @internal */
+        setCompilerHost(host) {
+          this.compilerHost = host;
+        }
+        /** @internal */
+        getCompilerHost() {
+          return this.compilerHost;
+        }
+        /** @internal */
+        useSourceOfProjectReferenceRedirect() {
+          return this.languageServiceEnabled;
+        }
+        /** @internal */
+        getParsedCommandLine(fileName) {
+          const configFileName = asNormalizedPath(normalizePath(fileName));
+          const canonicalConfigFilePath = asNormalizedPath(this.projectService.toCanonicalFileName(configFileName));
+          let configFileExistenceInfo = this.projectService.configFileExistenceInfoCache.get(canonicalConfigFilePath);
+          if (!configFileExistenceInfo) {
+            this.projectService.configFileExistenceInfoCache.set(canonicalConfigFilePath, configFileExistenceInfo = { exists: this.projectService.host.fileExists(configFileName) });
+          }
+          this.projectService.ensureParsedConfigUptoDate(configFileName, canonicalConfigFilePath, configFileExistenceInfo, this);
+          if (this.languageServiceEnabled && this.projectService.serverMode === 0 /* Semantic */) {
+            this.projectService.watchWildcards(configFileName, configFileExistenceInfo, this);
+          }
+          return configFileExistenceInfo.exists ? configFileExistenceInfo.config.parsedCommandLine : void 0;
+        }
+        /** @internal */
+        onReleaseParsedCommandLine(fileName) {
+          this.releaseParsedConfig(asNormalizedPath(this.projectService.toCanonicalFileName(asNormalizedPath(normalizePath(fileName)))));
+        }
+        /** @internal */
+        releaseParsedConfig(canonicalConfigFilePath) {
+          this.projectService.stopWatchingWildCards(canonicalConfigFilePath, this);
+          this.projectService.releaseParsedConfig(canonicalConfigFilePath, this);
+        }
+        /**
+         * If the project has reload from disk pending, it reloads (and then updates graph as part of that) instead of just updating the graph
+         * @returns: true if set of files in the project stays the same and false - otherwise.
+         */
+        updateGraph() {
+          const isInitialLoad = this.isInitialLoadPending();
+          this.isInitialLoadPending = returnFalse;
+          const updateLevel = this.pendingUpdateLevel;
+          this.pendingUpdateLevel = 0 /* Update */;
+          let result;
+          switch (updateLevel) {
+            case 1 /* RootNamesAndUpdate */:
+              this.openFileWatchTriggered.clear();
+              result = this.projectService.reloadFileNamesOfConfiguredProject(this);
+              break;
+            case 2 /* Full */:
+              this.openFileWatchTriggered.clear();
+              const reason = Debug.checkDefined(this.pendingUpdateReason);
+              this.pendingUpdateReason = void 0;
+              this.projectService.reloadConfiguredProject(
+                this,
+                reason,
+                isInitialLoad,
+                /*clearSemanticCache*/
+                false
+              );
+              result = true;
+              break;
+            default:
+              result = super.updateGraph();
+          }
+          this.compilerHost = void 0;
+          this.projectService.sendProjectLoadingFinishEvent(this);
+          this.projectService.sendProjectTelemetry(this);
+          return result;
+        }
+        /** @internal */
+        getCachedDirectoryStructureHost() {
+          return this.directoryStructureHost;
+        }
+        getConfigFilePath() {
+          return asNormalizedPath(this.getProjectName());
+        }
+        getProjectReferences() {
+          return this.projectReferences;
+        }
+        updateReferences(refs) {
+          if (typeof process.versions.pnp !== `undefined`) {
+            const basePath = this.getCurrentDirectory();
+            const getPnpPath = (path) => {
+              try {
+                const pnpApi = getPnpApi(`${path}/`);
+                if (!pnpApi) {
+                  return path;
+                }
+                const targetLocator = pnpApi.findPackageLocator(`${path}/`);
+                const { packageLocation } = pnpApi.getPackageInformation(targetLocator);
+                const request = combinePaths(targetLocator.name, getRelativePathFromDirectory(
+                  packageLocation,
+                  path,
+                  /*ignoreCase*/
+                  false
+                ));
+                return pnpApi.resolveToUnqualified(request, `${basePath}/`);
+              } catch {
+                return path;
+              }
+            };
+            refs = refs == null ? void 0 : refs.map((r) => ({ ...r, path: getPnpPath(r.path) }));
+          }
+          this.projectReferences = refs;
+          this.potentialProjectReferences = void 0;
+        }
+        /** @internal */
+        setPotentialProjectReference(canonicalConfigPath) {
+          Debug.assert(this.isInitialLoadPending());
+          (this.potentialProjectReferences || (this.potentialProjectReferences = /* @__PURE__ */ new Set())).add(canonicalConfigPath);
+        }
+        /** @internal */
+        getResolvedProjectReferenceToRedirect(fileName) {
+          const program = this.getCurrentProgram();
+          return program && program.getResolvedProjectReferenceToRedirect(fileName);
+        }
+        /** @internal */
+        forEachResolvedProjectReference(cb) {
+          var _a;
+          return (_a = this.getCurrentProgram()) == null ? void 0 : _a.forEachResolvedProjectReference(cb);
+        }
+        /** @internal */
+        enablePluginsWithOptions(options) {
+          var _a;
+          this.plugins.length = 0;
+          if (!((_a = options.plugins) == null ? void 0 : _a.length) && !this.projectService.globalPlugins.length)
+            return;
+          const host = this.projectService.host;
+          if (!host.require && !host.importPlugin) {
+            this.projectService.logger.info("Plugins were requested but not running in environment that supports 'require'. Nothing will be loaded");
+            return;
+          }
+          const searchPaths = this.getGlobalPluginSearchPaths();
+          if (this.projectService.allowLocalPluginLoads) {
+            const local = getDirectoryPath(this.canonicalConfigFilePath);
+            this.projectService.logger.info(`Local plugin loading enabled; adding ${local} to search paths`);
+            searchPaths.unshift(local);
+          }
+          if (options.plugins) {
+            for (const pluginConfigEntry of options.plugins) {
+              this.enablePlugin(pluginConfigEntry, searchPaths);
+            }
+          }
+          return this.enableGlobalPlugins(options);
+        }
+        /**
+         * Get the errors that dont have any file name associated
+         */
+        getGlobalProjectErrors() {
+          return filter(this.projectErrors, (diagnostic) => !diagnostic.file) || emptyArray2;
+        }
+        /**
+         * Get all the project errors
+         */
+        getAllProjectErrors() {
+          return this.projectErrors || emptyArray2;
+        }
+        setProjectErrors(projectErrors) {
+          this.projectErrors = projectErrors;
+        }
+        close() {
+          this.projectService.configFileExistenceInfoCache.forEach((_configFileExistenceInfo, canonicalConfigFilePath) => this.releaseParsedConfig(canonicalConfigFilePath));
+          this.projectErrors = void 0;
+          this.openFileWatchTriggered.clear();
+          this.compilerHost = void 0;
+          super.close();
+        }
+        /** @internal */
+        addExternalProjectReference() {
+          this.externalProjectRefCount++;
+        }
+        /** @internal */
+        deleteExternalProjectReference() {
+          this.externalProjectRefCount--;
+        }
+        /** @internal */
+        isSolution() {
+          return this.getRootFilesMap().size === 0 && !this.canConfigFileJsonReportNoInputFiles;
+        }
+        /**
+         * Find the configured project from the project references in project which contains the info directly
+         *
+         * @internal
+         */
+        getDefaultChildProjectFromProjectWithReferences(info) {
+          return forEachResolvedProjectReferenceProject(
+            this,
+            info.path,
+            (child) => projectContainsInfoDirectly(child, info) ? child : void 0,
+            0 /* Find */
+          );
+        }
+        /**
+         * Returns true if the project is needed by any of the open script info/external project
+         *
+         * @internal
+         */
+        hasOpenRef() {
+          var _a;
+          if (!!this.externalProjectRefCount) {
+            return true;
+          }
+          if (this.isClosed()) {
+            return false;
+          }
+          const configFileExistenceInfo = this.projectService.configFileExistenceInfoCache.get(this.canonicalConfigFilePath);
+          if (this.projectService.hasPendingProjectUpdate(this)) {
+            return !!((_a = configFileExistenceInfo.openFilesImpactedByConfigFile) == null ? void 0 : _a.size);
+          }
+          return !!configFileExistenceInfo.openFilesImpactedByConfigFile && forEachEntry(
+            configFileExistenceInfo.openFilesImpactedByConfigFile,
+            (_value, infoPath) => {
+              const info = this.projectService.getScriptInfoForPath(infoPath);
+              return this.containsScriptInfo(info) || !!forEachResolvedProjectReferenceProject(
+                this,
+                info.path,
+                (child) => child.containsScriptInfo(info),
+                0 /* Find */
+              );
+            }
+          ) || false;
+        }
+        /** @internal */
+        hasExternalProjectRef() {
+          return !!this.externalProjectRefCount;
+        }
+        getEffectiveTypeRoots() {
+          return getEffectiveTypeRoots(this.getCompilationSettings(), this) || [];
+        }
+        /** @internal */
+        updateErrorOnNoInputFiles(fileNames) {
+          updateErrorForNoInputFiles(fileNames, this.getConfigFilePath(), this.getCompilerOptions().configFile.configFileSpecs, this.projectErrors, this.canConfigFileJsonReportNoInputFiles);
+        }
+      };
+      ExternalProject2 = class extends Project3 {
+        /** @internal */
+        constructor(externalProjectName, projectService, documentRegistry, compilerOptions, lastFileExceededProgramSize, compileOnSaveEnabled, projectFilePath, watchOptions) {
+          super(
+            externalProjectName,
+            2 /* External */,
+            projectService,
+            documentRegistry,
+            /*hasExplicitListOfFiles*/
+            true,
+            lastFileExceededProgramSize,
+            compilerOptions,
+            compileOnSaveEnabled,
+            watchOptions,
+            projectService.host,
+            getDirectoryPath(projectFilePath || normalizeSlashes(externalProjectName))
+          );
+          this.externalProjectName = externalProjectName;
+          this.compileOnSaveEnabled = compileOnSaveEnabled;
+          this.excludedFiles = [];
+          this.enableGlobalPlugins(this.getCompilerOptions());
+        }
+        updateGraph() {
+          const result = super.updateGraph();
+          this.projectService.sendProjectTelemetry(this);
+          return result;
+        }
+        getExcludedFiles() {
+          return this.excludedFiles;
+        }
+      };
     }
-    function addSignatureDisplayParts(signature, allSignatures, flags = 0 /* None */) {
-      addRange(displayParts, signatureToDisplayParts(typeChecker, signature, enclosingDeclaration, flags | 32 /* WriteTypeArgumentsOfSignature */));
-      if (allSignatures.length > 1) {
-        displayParts.push(spacePart());
-        displayParts.push(punctuationPart(21 /* OpenParenToken */));
-        displayParts.push(operatorPart(40 /* PlusToken */));
-        displayParts.push(displayPart((allSignatures.length - 1).toString(), 7 /* numericLiteral */));
-        displayParts.push(spacePart());
-        displayParts.push(textPart(allSignatures.length === 2 ? "overload" : "overloads"));
-        displayParts.push(punctuationPart(22 /* CloseParenToken */));
-      }
-      documentation = signature.getDocumentationComment(typeChecker);
-      tags = signature.getJsDocTags();
-      if (allSignatures.length > 1 && documentation.length === 0 && tags.length === 0) {
-        documentation = allSignatures[0].getDocumentationComment(typeChecker);
-        tags = allSignatures[0].getJsDocTags().filter((tag) => tag.name !== "deprecated");
+  });
+
+  // src/server/editorServices.ts
+  function prepareConvertersForEnumLikeCompilerOptions(commandLineOptions) {
+    const map2 = /* @__PURE__ */ new Map();
+    for (const option of commandLineOptions) {
+      if (typeof option.type === "object") {
+        const optionMap = option.type;
+        optionMap.forEach((value) => {
+          Debug.assert(typeof value === "number");
+        });
+        map2.set(option.name, optionMap);
       }
     }
-    function writeTypeParametersOfSymbol(symbol2, enclosingDeclaration2) {
-      const typeParameterParts = mapToDisplayParts((writer) => {
-        const params = typeChecker.symbolToTypeParameterDeclarations(symbol2, enclosingDeclaration2, symbolDisplayNodeBuilderFlags);
-        getPrinter().writeList(53776 /* TypeParameters */, params, getSourceFileOfNode(getParseTreeNode(enclosingDeclaration2)), writer);
-      });
-      addRange(displayParts, typeParameterParts);
-    }
+    return map2;
   }
-  function isLocalVariableOrFunction(symbol) {
-    if (symbol.parent) {
-      return false;
+  function convertFormatOptions(protocolOptions) {
+    if (isString(protocolOptions.indentStyle)) {
+      protocolOptions.indentStyle = indentStyle.get(protocolOptions.indentStyle.toLowerCase());
+      Debug.assert(protocolOptions.indentStyle !== void 0);
     }
-    return forEach(symbol.declarations, (declaration) => {
-      if (declaration.kind === 217 /* FunctionExpression */) {
-        return true;
-      }
-      if (declaration.kind !== 259 /* VariableDeclaration */ && declaration.kind !== 261 /* FunctionDeclaration */) {
-        return false;
-      }
-      for (let parent2 = declaration.parent; !isFunctionBlock(parent2); parent2 = parent2.parent) {
-        if (parent2.kind === 311 /* SourceFile */ || parent2.kind === 267 /* ModuleBlock */) {
-          return false;
-        }
+    return protocolOptions;
+  }
+  function convertCompilerOptions(protocolOptions) {
+    compilerOptionConverters.forEach((mappedValues, id) => {
+      const propertyValue = protocolOptions[id];
+      if (isString(propertyValue)) {
+        protocolOptions[id] = mappedValues.get(propertyValue.toLowerCase());
       }
-      return true;
     });
+    return protocolOptions;
   }
-  var symbolDisplayNodeBuilderFlags;
-  var init_symbolDisplay = __esm({
-    "src/services/symbolDisplay.ts"() {
-      "use strict";
-      init_ts4();
-      symbolDisplayNodeBuilderFlags = 8192 /* OmitParameterModifiers */ | 70221824 /* IgnoreErrors */ | 16384 /* UseAliasDefinedOutsideCurrentScope */;
-    }
-  });
-
-  // src/services/_namespaces/ts.SymbolDisplay.ts
-  var ts_SymbolDisplay_exports = {};
-  __export(ts_SymbolDisplay_exports, {
-    getSymbolDisplayPartsDocumentationAndSymbolKind: () => getSymbolDisplayPartsDocumentationAndSymbolKind,
-    getSymbolKind: () => getSymbolKind,
-    getSymbolModifiers: () => getSymbolModifiers
-  });
-  var init_ts_SymbolDisplay = __esm({
-    "src/services/_namespaces/ts.SymbolDisplay.ts"() {
-      "use strict";
-      init_symbolDisplay();
-    }
-  });
-
-  // src/services/textChanges.ts
-  function getPos2(n) {
-    const result = n.__pos;
-    Debug.assert(typeof result === "number");
-    return result;
-  }
-  function setPos(n, pos) {
-    Debug.assert(typeof pos === "number");
-    n.__pos = pos;
+  function convertWatchOptions(protocolOptions, currentDirectory) {
+    let watchOptions;
+    let errors;
+    optionsForWatch.forEach((option) => {
+      const propertyValue = protocolOptions[option.name];
+      if (propertyValue === void 0)
+        return;
+      const mappedValues = watchOptionsConverters.get(option.name);
+      (watchOptions || (watchOptions = {}))[option.name] = mappedValues ? isString(propertyValue) ? mappedValues.get(propertyValue.toLowerCase()) : propertyValue : convertJsonOption(option, propertyValue, currentDirectory || "", errors || (errors = []));
+    });
+    return watchOptions && { watchOptions, errors };
   }
-  function getEnd(n) {
-    const result = n.__end;
-    Debug.assert(typeof result === "number");
+  function convertTypeAcquisition(protocolOptions) {
+    let result;
+    typeAcquisitionDeclarations.forEach((option) => {
+      const propertyValue = protocolOptions[option.name];
+      if (propertyValue === void 0)
+        return;
+      (result || (result = {}))[option.name] = propertyValue;
+    });
     return result;
   }
-  function setEnd(n, end) {
-    Debug.assert(typeof end === "number");
-    n.__end = end;
-  }
-  function skipWhitespacesAndLineBreaks(text, start) {
-    return skipTrivia(
-      text,
-      start,
-      /*stopAfterLineBreak*/
-      false,
-      /*stopAtComments*/
-      true
-    );
+  function tryConvertScriptKindName(scriptKindName) {
+    return isString(scriptKindName) ? convertScriptKindName(scriptKindName) : scriptKindName;
   }
-  function hasCommentsBeforeLineBreak(text, start) {
-    let i = start;
-    while (i < text.length) {
-      const ch = text.charCodeAt(i);
-      if (isWhiteSpaceSingleLine(ch)) {
-        i++;
-        continue;
-      }
-      return ch === 47 /* slash */;
+  function convertScriptKindName(scriptKindName) {
+    switch (scriptKindName) {
+      case "JS":
+        return 1 /* JS */;
+      case "JSX":
+        return 2 /* JSX */;
+      case "TS":
+        return 3 /* TS */;
+      case "TSX":
+        return 4 /* TSX */;
+      default:
+        return 0 /* Unknown */;
     }
-    return false;
   }
-  function getAdjustedRange(sourceFile, startNode2, endNode2, options) {
-    return { pos: getAdjustedStartPosition(sourceFile, startNode2, options), end: getAdjustedEndPosition(sourceFile, endNode2, options) };
+  function convertUserPreferences(preferences) {
+    const { lazyConfiguredProjectsFromExternalProject, ...userPreferences } = preferences;
+    return userPreferences;
   }
-  function getAdjustedStartPosition(sourceFile, node, options, hasTrailingComment = false) {
-    var _a, _b;
-    const { leadingTriviaOption } = options;
-    if (leadingTriviaOption === 0 /* Exclude */) {
-      return node.getStart(sourceFile);
-    }
-    if (leadingTriviaOption === 3 /* StartLine */) {
-      const startPos = node.getStart(sourceFile);
-      const pos = getLineStartPositionForPosition(startPos, sourceFile);
-      return rangeContainsPosition(node, pos) ? pos : startPos;
-    }
-    if (leadingTriviaOption === 2 /* JSDoc */) {
-      const JSDocComments = getJSDocCommentRanges(node, sourceFile.text);
-      if (JSDocComments == null ? void 0 : JSDocComments.length) {
-        return getLineStartPositionForPosition(JSDocComments[0].pos, sourceFile);
-      }
-    }
-    const fullStart = node.getFullStart();
-    const start = node.getStart(sourceFile);
-    if (fullStart === start) {
-      return start;
-    }
-    const fullStartLine = getLineStartPositionForPosition(fullStart, sourceFile);
-    const startLine = getLineStartPositionForPosition(start, sourceFile);
-    if (startLine === fullStartLine) {
-      return leadingTriviaOption === 1 /* IncludeAll */ ? fullStart : start;
-    }
-    if (hasTrailingComment) {
-      const comment = ((_a = getLeadingCommentRanges(sourceFile.text, fullStart)) == null ? void 0 : _a[0]) || ((_b = getTrailingCommentRanges(sourceFile.text, fullStart)) == null ? void 0 : _b[0]);
-      if (comment) {
-        return skipTrivia(
-          sourceFile.text,
-          comment.end,
-          /*stopAfterLineBreak*/
-          true,
-          /*stopAtComments*/
-          true
-        );
+  function findProjectByName(projectName, projects) {
+    for (const proj of projects) {
+      if (proj.getProjectName() === projectName) {
+        return proj;
       }
     }
-    const nextLineStart = fullStart > 0 ? 1 : 0;
-    let adjustedStartPosition = getStartPositionOfLine(getLineOfLocalPosition(sourceFile, fullStartLine) + nextLineStart, sourceFile);
-    adjustedStartPosition = skipWhitespacesAndLineBreaks(sourceFile.text, adjustedStartPosition);
-    return getStartPositionOfLine(getLineOfLocalPosition(sourceFile, adjustedStartPosition), sourceFile);
   }
-  function getEndPositionOfMultilineTrailingComment(sourceFile, node, options) {
-    const { end } = node;
-    const { trailingTriviaOption } = options;
-    if (trailingTriviaOption === 2 /* Include */) {
-      const comments = getTrailingCommentRanges(sourceFile.text, end);
-      if (comments) {
-        const nodeEndLine = getLineOfLocalPosition(sourceFile, node.end);
-        for (const comment of comments) {
-          if (comment.kind === 2 /* SingleLineCommentTrivia */ || getLineOfLocalPosition(sourceFile, comment.pos) > nodeEndLine) {
-            break;
-          }
-          const commentEndLine = getLineOfLocalPosition(sourceFile, comment.end);
-          if (commentEndLine > nodeEndLine) {
-            return skipTrivia(
-              sourceFile.text,
-              comment.end,
-              /*stopAfterLineBreak*/
-              true,
-              /*stopAtComments*/
-              true
-            );
-          }
-        }
-      }
-    }
-    return void 0;
+  function isOpenScriptInfo(infoOrFileNameOrConfig) {
+    return !!infoOrFileNameOrConfig.containingProjects;
   }
-  function getAdjustedEndPosition(sourceFile, node, options) {
+  function isAncestorConfigFileInfo(infoOrFileNameOrConfig) {
+    return !!infoOrFileNameOrConfig.configFileInfo;
+  }
+  function forEachResolvedProjectReferenceProject(project, fileName, cb, projectReferenceProjectLoadKind, reason) {
     var _a;
-    const { end } = node;
-    const { trailingTriviaOption } = options;
-    if (trailingTriviaOption === 0 /* Exclude */) {
-      return end;
-    }
-    if (trailingTriviaOption === 1 /* ExcludeWhitespace */) {
-      const comments = concatenate(getTrailingCommentRanges(sourceFile.text, end), getLeadingCommentRanges(sourceFile.text, end));
-      const realEnd = (_a = comments == null ? void 0 : comments[comments.length - 1]) == null ? void 0 : _a.end;
-      if (realEnd) {
-        return realEnd;
+    const resolvedRefs = (_a = project.getCurrentProgram()) == null ? void 0 : _a.getResolvedProjectReferences();
+    if (!resolvedRefs)
+      return void 0;
+    let seenResolvedRefs;
+    const possibleDefaultRef = fileName ? project.getResolvedProjectReferenceToRedirect(fileName) : void 0;
+    if (possibleDefaultRef) {
+      const configFileName = toNormalizedPath(possibleDefaultRef.sourceFile.fileName);
+      const child = project.projectService.findConfiguredProjectByProjectName(configFileName);
+      if (child) {
+        const result = cb(child);
+        if (result)
+          return result;
+      } else if (projectReferenceProjectLoadKind !== 0 /* Find */) {
+        seenResolvedRefs = /* @__PURE__ */ new Map();
+        const result = forEachResolvedProjectReferenceProjectWorker(
+          resolvedRefs,
+          project.getCompilerOptions(),
+          (ref, loadKind) => possibleDefaultRef === ref ? callback(ref, loadKind) : void 0,
+          projectReferenceProjectLoadKind,
+          project.projectService,
+          seenResolvedRefs
+        );
+        if (result)
+          return result;
+        seenResolvedRefs.clear();
       }
-      return end;
-    }
-    const multilineEndPosition = getEndPositionOfMultilineTrailingComment(sourceFile, node, options);
-    if (multilineEndPosition) {
-      return multilineEndPosition;
     }
-    const newEnd = skipTrivia(
-      sourceFile.text,
-      end,
-      /*stopAfterLineBreak*/
-      true
+    return forEachResolvedProjectReferenceProjectWorker(
+      resolvedRefs,
+      project.getCompilerOptions(),
+      (ref, loadKind) => possibleDefaultRef !== ref ? callback(ref, loadKind) : void 0,
+      projectReferenceProjectLoadKind,
+      project.projectService,
+      seenResolvedRefs
     );
-    return newEnd !== end && (trailingTriviaOption === 2 /* Include */ || isLineBreak(sourceFile.text.charCodeAt(newEnd - 1))) ? newEnd : end;
+    function callback(ref, loadKind) {
+      const configFileName = toNormalizedPath(ref.sourceFile.fileName);
+      const child = project.projectService.findConfiguredProjectByProjectName(configFileName) || (loadKind === 0 /* Find */ ? void 0 : loadKind === 1 /* FindCreate */ ? project.projectService.createConfiguredProject(configFileName) : loadKind === 2 /* FindCreateLoad */ ? project.projectService.createAndLoadConfiguredProject(configFileName, reason) : Debug.assertNever(loadKind));
+      return child && cb(child);
+    }
   }
-  function isSeparator(node, candidate) {
-    return !!candidate && !!node.parent && (candidate.kind === 28 /* CommaToken */ || candidate.kind === 27 /* SemicolonToken */ && node.parent.kind === 209 /* ObjectLiteralExpression */);
+  function forEachResolvedProjectReferenceProjectWorker(resolvedProjectReferences, parentOptions, cb, projectReferenceProjectLoadKind, projectService, seenResolvedRefs) {
+    const loadKind = parentOptions.disableReferencedProjectLoad ? 0 /* Find */ : projectReferenceProjectLoadKind;
+    return forEach(resolvedProjectReferences, (ref) => {
+      if (!ref)
+        return void 0;
+      const configFileName = toNormalizedPath(ref.sourceFile.fileName);
+      const canonicalPath = projectService.toCanonicalFileName(configFileName);
+      const seenValue = seenResolvedRefs == null ? void 0 : seenResolvedRefs.get(canonicalPath);
+      if (seenValue !== void 0 && seenValue >= loadKind) {
+        return void 0;
+      }
+      const result = cb(ref, loadKind);
+      if (result) {
+        return result;
+      }
+      (seenResolvedRefs || (seenResolvedRefs = /* @__PURE__ */ new Map())).set(canonicalPath, loadKind);
+      return ref.references && forEachResolvedProjectReferenceProjectWorker(ref.references, ref.commandLine.options, cb, loadKind, projectService, seenResolvedRefs);
+    });
   }
-  function isThisTypeAnnotatable(containingFunction) {
-    return isFunctionExpression(containingFunction) || isFunctionDeclaration(containingFunction);
+  function forEachPotentialProjectReference(project, cb) {
+    return project.potentialProjectReferences && forEachKey(project.potentialProjectReferences, cb);
   }
-  function updateJSDocHost(parent2) {
-    if (parent2.kind !== 218 /* ArrowFunction */) {
-      return parent2;
-    }
-    const jsDocNode = parent2.parent.kind === 171 /* PropertyDeclaration */ ? parent2.parent : parent2.parent.parent;
-    jsDocNode.jsDoc = parent2.jsDoc;
-    return jsDocNode;
+  function forEachAnyProjectReferenceKind(project, cb, cbProjectRef, cbPotentialProjectRef) {
+    return project.getCurrentProgram() ? project.forEachResolvedProjectReference(cb) : project.isInitialLoadPending() ? forEachPotentialProjectReference(project, cbPotentialProjectRef) : forEach(project.getProjectReferences(), cbProjectRef);
   }
-  function tryMergeJsdocTags(oldTag, newTag) {
-    if (oldTag.kind !== newTag.kind) {
-      return void 0;
-    }
-    switch (oldTag.kind) {
-      case 347 /* JSDocParameterTag */: {
-        const oldParam = oldTag;
-        const newParam = newTag;
-        return isIdentifier(oldParam.name) && isIdentifier(newParam.name) && oldParam.name.escapedText === newParam.name.escapedText ? factory.createJSDocParameterTag(
-          /*tagName*/
-          void 0,
-          newParam.name,
-          /*isBracketed*/
-          false,
-          newParam.typeExpression,
-          newParam.isNameFirst,
-          oldParam.comment
-        ) : void 0;
-      }
-      case 348 /* JSDocReturnTag */:
-        return factory.createJSDocReturnTag(
-          /*tagName*/
-          void 0,
-          newTag.typeExpression,
-          oldTag.comment
-        );
-      case 350 /* JSDocTypeTag */:
-        return factory.createJSDocTypeTag(
-          /*tagName*/
-          void 0,
-          newTag.typeExpression,
-          oldTag.comment
-        );
-    }
+  function callbackRefProject(project, cb, refPath) {
+    const refProject = refPath && project.projectService.configuredProjects.get(refPath);
+    return refProject && cb(refProject);
   }
-  function startPositionToDeleteNodeInList(sourceFile, node) {
-    return skipTrivia(
-      sourceFile.text,
-      getAdjustedStartPosition(sourceFile, node, { leadingTriviaOption: 1 /* IncludeAll */ }),
-      /*stopAfterLineBreak*/
-      false,
-      /*stopAtComments*/
-      true
+  function forEachReferencedProject(project, cb) {
+    return forEachAnyProjectReferenceKind(
+      project,
+      (resolvedRef) => callbackRefProject(project, cb, resolvedRef.sourceFile.path),
+      (projectRef) => callbackRefProject(project, cb, project.toPath(resolveProjectReferencePath(projectRef))),
+      (potentialProjectRef) => callbackRefProject(project, cb, potentialProjectRef)
     );
   }
-  function endPositionToDeleteNodeInList(sourceFile, node, prevNode, nextNode) {
-    const end = startPositionToDeleteNodeInList(sourceFile, nextNode);
-    if (prevNode === void 0 || positionsAreOnSameLine(getAdjustedEndPosition(sourceFile, node, {}), end, sourceFile)) {
-      return end;
-    }
-    const token = findPrecedingToken(nextNode.getStart(sourceFile), sourceFile);
-    if (isSeparator(node, token)) {
-      const prevToken = findPrecedingToken(node.getStart(sourceFile), sourceFile);
-      if (isSeparator(prevNode, prevToken)) {
-        const pos = skipTrivia(
-          sourceFile.text,
-          token.getEnd(),
-          /*stopAfterLineBreak*/
-          true,
-          /*stopAtComments*/
-          true
-        );
-        if (positionsAreOnSameLine(prevToken.getStart(sourceFile), token.getStart(sourceFile), sourceFile)) {
-          return isLineBreak(sourceFile.text.charCodeAt(pos - 1)) ? pos - 1 : pos;
-        }
-        if (isLineBreak(sourceFile.text.charCodeAt(pos))) {
-          return pos;
-        }
-      }
-    }
-    return end;
+  function getDetailWatchInfo(watchType, project) {
+    return `${isString(project) ? `Config: ${project} ` : project ? `Project: ${project.getProjectName()} ` : ""}WatchType: ${watchType}`;
   }
-  function getClassOrObjectBraceEnds(cls, sourceFile) {
-    const open = findChildOfKind(cls, 19 /* OpenBraceToken */, sourceFile);
-    const close = findChildOfKind(cls, 20 /* CloseBraceToken */, sourceFile);
-    return [open == null ? void 0 : open.end, close == null ? void 0 : close.end];
+  function isScriptInfoWatchedFromNodeModules(info) {
+    return !info.isScriptOpen() && info.mTime !== void 0;
   }
-  function getMembersOrProperties(node) {
-    return isObjectLiteralExpression(node) ? node.properties : node.members;
+  function projectContainsInfoDirectly(project, info) {
+    return project.containsScriptInfo(info) && !project.isSourceOfProjectReferenceRedirect(info.path);
   }
-  function applyChanges(text, changes) {
-    for (let i = changes.length - 1; i >= 0; i--) {
-      const { span, newText } = changes[i];
-      text = `${text.substring(0, span.start)}${newText}${text.substring(textSpanEnd(span))}`;
-    }
-    return text;
+  function updateProjectIfDirty(project) {
+    project.invalidateResolutionsOfFailedLookupLocations();
+    return project.dirty && project.updateGraph();
   }
-  function isTrivia2(s) {
-    return skipTrivia(s, 0) === s.length;
+  function setProjectOptionsUsed(project) {
+    if (isConfiguredProject(project)) {
+      project.projectOptions = true;
+    }
   }
-  function assignPositionsToNode(node) {
-    const visited = visitEachChild(node, assignPositionsToNode, textChangesTransformationContext, assignPositionsToNodeArray, assignPositionsToNode);
-    const newNode = nodeIsSynthesized(visited) ? visited : Object.create(visited);
-    setTextRangePosEnd(newNode, getPos2(node), getEnd(node));
-    return newNode;
+  function createProjectNameFactoryWithCounter(nameFactory) {
+    let nextId = 1;
+    return () => nameFactory(nextId++);
   }
-  function assignPositionsToNodeArray(nodes, visitor, test, start, count) {
-    const visited = visitNodes2(nodes, visitor, test, start, count);
-    if (!visited) {
-      return visited;
-    }
-    Debug.assert(nodes);
-    const nodeArray = visited === nodes ? factory.createNodeArray(visited.slice(0)) : visited;
-    setTextRangePosEnd(nodeArray, getPos2(nodes), getEnd(nodes));
-    return nodeArray;
+  function getHostWatcherMap() {
+    return { idToCallbacks: /* @__PURE__ */ new Map(), pathToId: /* @__PURE__ */ new Map() };
   }
-  function createWriter(newLine) {
-    let lastNonTriviaPosition = 0;
-    const writer = createTextWriter(newLine);
-    const onBeforeEmitNode = (node) => {
-      if (node) {
-        setPos(node, lastNonTriviaPosition);
-      }
-    };
-    const onAfterEmitNode = (node) => {
-      if (node) {
-        setEnd(node, lastNonTriviaPosition);
-      }
-    };
-    const onBeforeEmitNodeArray = (nodes) => {
-      if (nodes) {
-        setPos(nodes, lastNonTriviaPosition);
-      }
-    };
-    const onAfterEmitNodeArray = (nodes) => {
-      if (nodes) {
-        setEnd(nodes, lastNonTriviaPosition);
-      }
-    };
-    const onBeforeEmitToken = (node) => {
-      if (node) {
-        setPos(node, lastNonTriviaPosition);
-      }
-    };
-    const onAfterEmitToken = (node) => {
-      if (node) {
-        setEnd(node, lastNonTriviaPosition);
-      }
+  function createWatchFactoryHostUsingWatchEvents(service, canUseWatchEvents) {
+    if (!canUseWatchEvents || !service.eventHandler || !service.session)
+      return void 0;
+    const watchedFiles = getHostWatcherMap();
+    const watchedDirectories = getHostWatcherMap();
+    const watchedDirectoriesRecursive = getHostWatcherMap();
+    let ids = 1;
+    service.session.addProtocolHandler("watchChange" /* WatchChange */, (req) => {
+      onWatchChange(req.arguments);
+      return { responseRequired: false };
+    });
+    return {
+      watchFile: watchFile2,
+      watchDirectory,
+      getCurrentDirectory: () => service.host.getCurrentDirectory(),
+      useCaseSensitiveFileNames: service.host.useCaseSensitiveFileNames
     };
-    function setLastNonTriviaPosition(s, force) {
-      if (force || !isTrivia2(s)) {
-        lastNonTriviaPosition = writer.getTextPos();
-        let i = 0;
-        while (isWhiteSpaceLike(s.charCodeAt(s.length - i - 1))) {
-          i++;
-        }
-        lastNonTriviaPosition -= i;
-      }
-    }
-    function write(s) {
-      writer.write(s);
-      setLastNonTriviaPosition(
-        s,
-        /*force*/
-        false
-      );
-    }
-    function writeComment(s) {
-      writer.writeComment(s);
-    }
-    function writeKeyword(s) {
-      writer.writeKeyword(s);
-      setLastNonTriviaPosition(
-        s,
-        /*force*/
-        false
-      );
-    }
-    function writeOperator(s) {
-      writer.writeOperator(s);
-      setLastNonTriviaPosition(
-        s,
-        /*force*/
-        false
-      );
-    }
-    function writePunctuation(s) {
-      writer.writePunctuation(s);
-      setLastNonTriviaPosition(
-        s,
-        /*force*/
-        false
-      );
-    }
-    function writeTrailingSemicolon(s) {
-      writer.writeTrailingSemicolon(s);
-      setLastNonTriviaPosition(
-        s,
-        /*force*/
-        false
-      );
-    }
-    function writeParameter(s) {
-      writer.writeParameter(s);
-      setLastNonTriviaPosition(
-        s,
-        /*force*/
-        false
-      );
-    }
-    function writeProperty(s) {
-      writer.writeProperty(s);
-      setLastNonTriviaPosition(
-        s,
-        /*force*/
-        false
-      );
-    }
-    function writeSpace(s) {
-      writer.writeSpace(s);
-      setLastNonTriviaPosition(
-        s,
-        /*force*/
-        false
-      );
-    }
-    function writeStringLiteral(s) {
-      writer.writeStringLiteral(s);
-      setLastNonTriviaPosition(
-        s,
-        /*force*/
-        false
-      );
-    }
-    function writeSymbol(s, sym) {
-      writer.writeSymbol(s, sym);
-      setLastNonTriviaPosition(
-        s,
-        /*force*/
-        false
-      );
-    }
-    function writeLine(force) {
-      writer.writeLine(force);
-    }
-    function increaseIndent() {
-      writer.increaseIndent();
-    }
-    function decreaseIndent() {
-      writer.decreaseIndent();
-    }
-    function getText() {
-      return writer.getText();
-    }
-    function rawWrite(s) {
-      writer.rawWrite(s);
-      setLastNonTriviaPosition(
-        s,
-        /*force*/
-        false
+    function watchFile2(path, callback) {
+      return getOrCreateFileWatcher(
+        watchedFiles,
+        path,
+        callback,
+        (id) => ({ eventName: CreateFileWatcherEvent, data: { id, path } })
       );
     }
-    function writeLiteral(s) {
-      writer.writeLiteral(s);
-      setLastNonTriviaPosition(
-        s,
-        /*force*/
-        true
+    function watchDirectory(path, callback, recursive) {
+      return getOrCreateFileWatcher(
+        recursive ? watchedDirectoriesRecursive : watchedDirectories,
+        path,
+        callback,
+        (id) => ({ eventName: CreateDirectoryWatcherEvent, data: { id, path, recursive: !!recursive } })
       );
     }
-    function getTextPos() {
-      return writer.getTextPos();
-    }
-    function getLine() {
-      return writer.getLine();
-    }
-    function getColumn() {
-      return writer.getColumn();
-    }
-    function getIndent() {
-      return writer.getIndent();
-    }
-    function isAtStartOfLine() {
-      return writer.isAtStartOfLine();
-    }
-    function clear2() {
-      writer.clear();
-      lastNonTriviaPosition = 0;
-    }
-    return {
-      onBeforeEmitNode,
-      onAfterEmitNode,
-      onBeforeEmitNodeArray,
-      onAfterEmitNodeArray,
-      onBeforeEmitToken,
-      onAfterEmitToken,
-      write,
-      writeComment,
-      writeKeyword,
-      writeOperator,
-      writePunctuation,
-      writeTrailingSemicolon,
-      writeParameter,
-      writeProperty,
-      writeSpace,
-      writeStringLiteral,
-      writeSymbol,
-      writeLine,
-      increaseIndent,
-      decreaseIndent,
-      getText,
-      rawWrite,
-      writeLiteral,
-      getTextPos,
-      getLine,
-      getColumn,
-      getIndent,
-      isAtStartOfLine,
-      hasTrailingComment: () => writer.hasTrailingComment(),
-      hasTrailingWhitespace: () => writer.hasTrailingWhitespace(),
-      clear: clear2
-    };
-  }
-  function getInsertionPositionAtSourceFileTop(sourceFile) {
-    let lastPrologue;
-    for (const node of sourceFile.statements) {
-      if (isPrologueDirective(node)) {
-        lastPrologue = node;
-      } else {
-        break;
-      }
-    }
-    let position = 0;
-    const text = sourceFile.text;
-    if (lastPrologue) {
-      position = lastPrologue.end;
-      advancePastLineBreak();
-      return position;
-    }
-    const shebang = getShebang(text);
-    if (shebang !== void 0) {
-      position = shebang.length;
-      advancePastLineBreak();
-    }
-    const ranges = getLeadingCommentRanges(text, position);
-    if (!ranges)
-      return position;
-    let lastComment;
-    let firstNodeLine;
-    for (const range of ranges) {
-      if (range.kind === 3 /* MultiLineCommentTrivia */) {
-        if (isPinnedComment(text, range.pos)) {
-          lastComment = { range, pinnedOrTripleSlash: true };
-          continue;
+    function getOrCreateFileWatcher({ pathToId, idToCallbacks }, path, callback, event) {
+      const key = service.toPath(path);
+      let id = pathToId.get(key);
+      if (!id)
+        pathToId.set(key, id = ids++);
+      let callbacks = idToCallbacks.get(id);
+      if (!callbacks) {
+        idToCallbacks.set(id, callbacks = /* @__PURE__ */ new Set());
+        service.eventHandler(event(id));
+      }
+      callbacks.add(callback);
+      return {
+        close() {
+          const callbacks2 = idToCallbacks.get(id);
+          if (!(callbacks2 == null ? void 0 : callbacks2.delete(callback)))
+            return;
+          if (callbacks2.size)
+            return;
+          idToCallbacks.delete(id);
+          pathToId.delete(key);
+          service.eventHandler({ eventName: CloseFileWatcherEvent, data: { id } });
         }
-      } else if (isRecognizedTripleSlashComment(text, range.pos, range.end)) {
-        lastComment = { range, pinnedOrTripleSlash: true };
-        continue;
-      }
-      if (lastComment) {
-        if (lastComment.pinnedOrTripleSlash)
-          break;
-        const commentLine = sourceFile.getLineAndCharacterOfPosition(range.pos).line;
-        const lastCommentEndLine = sourceFile.getLineAndCharacterOfPosition(lastComment.range.end).line;
-        if (commentLine >= lastCommentEndLine + 2)
-          break;
-      }
-      if (sourceFile.statements.length) {
-        if (firstNodeLine === void 0)
-          firstNodeLine = sourceFile.getLineAndCharacterOfPosition(sourceFile.statements[0].getStart()).line;
-        const commentEndLine = sourceFile.getLineAndCharacterOfPosition(range.end).line;
-        if (firstNodeLine < commentEndLine + 2)
-          break;
-      }
-      lastComment = { range, pinnedOrTripleSlash: false };
+      };
     }
-    if (lastComment) {
-      position = lastComment.range.end;
-      advancePastLineBreak();
+    function onWatchChange({ id, path, eventType }) {
+      onFileWatcherCallback(id, path, eventType);
+      onDirectoryWatcherCallback(watchedDirectories, id, path, eventType);
+      onDirectoryWatcherCallback(watchedDirectoriesRecursive, id, path, eventType);
     }
-    return position;
-    function advancePastLineBreak() {
-      if (position < text.length) {
-        const charCode = text.charCodeAt(position);
-        if (isLineBreak(charCode)) {
-          position++;
-          if (position < text.length && charCode === 13 /* carriageReturn */ && text.charCodeAt(position) === 10 /* lineFeed */) {
-            position++;
-          }
-        }
-      }
+    function onFileWatcherCallback(id, eventPath, eventType) {
+      var _a;
+      (_a = watchedFiles.idToCallbacks.get(id)) == null ? void 0 : _a.forEach((callback) => {
+        const eventKind = eventType === "create" ? 0 /* Created */ : eventType === "delete" ? 2 /* Deleted */ : 1 /* Changed */;
+        callback(eventPath, eventKind);
+      });
+    }
+    function onDirectoryWatcherCallback({ idToCallbacks }, id, eventPath, eventType) {
+      var _a;
+      if (eventType === "update")
+        return;
+      (_a = idToCallbacks.get(id)) == null ? void 0 : _a.forEach((callback) => {
+        callback(eventPath);
+      });
     }
   }
-  function isValidLocationToAddComment(sourceFile, position) {
-    return !isInComment(sourceFile, position) && !isInString(sourceFile, position) && !isInTemplateString(sourceFile, position) && !isInJSXText(sourceFile, position);
-  }
-  function needSemicolonBetween(a, b) {
-    return (isPropertySignature(a) || isPropertyDeclaration(a)) && isClassOrTypeElement(b) && b.name.kind === 166 /* ComputedPropertyName */ || isStatementButNotDeclaration(a) && isStatementButNotDeclaration(b);
+  function createIncompleteCompletionsCache() {
+    let info;
+    return {
+      get() {
+        return info;
+      },
+      set(newInfo) {
+        info = newInfo;
+      },
+      clear() {
+        info = void 0;
+      }
+    };
   }
-  function deleteNode(changes, sourceFile, node, options = { leadingTriviaOption: 1 /* IncludeAll */ }) {
-    const startPosition = getAdjustedStartPosition(sourceFile, node, options);
-    const endPosition = getAdjustedEndPosition(sourceFile, node, options);
-    changes.deleteRange(sourceFile, { pos: startPosition, end: endPosition });
+  function isConfigFile(config) {
+    return config.kind !== void 0;
   }
-  function deleteNodeInList(changes, deletedNodesInLists, sourceFile, node) {
-    const containingList = Debug.checkDefined(ts_formatting_exports.SmartIndenter.getContainingList(node, sourceFile));
-    const index = indexOfNode(containingList, node);
-    Debug.assert(index !== -1);
-    if (containingList.length === 1) {
-      deleteNode(changes, sourceFile, node);
-      return;
-    }
-    Debug.assert(!deletedNodesInLists.has(node), "Deleting a node twice");
-    deletedNodesInLists.add(node);
-    changes.deleteRange(sourceFile, {
-      pos: startPositionToDeleteNodeInList(sourceFile, node),
-      end: index === containingList.length - 1 ? getAdjustedEndPosition(sourceFile, node, {}) : endPositionToDeleteNodeInList(sourceFile, node, containingList[index - 1], containingList[index + 1])
-    });
+  function printProjectWithoutFileNames(project) {
+    project.print(
+      /*writeProjectFileNames*/
+      false,
+      /*writeFileExplaination*/
+      false,
+      /*writeFileVersionAndText*/
+      false
+    );
   }
-  var LeadingTriviaOption, TrailingTriviaOption, useNonAdjustedPositions, ChangeTracker, changesToText, textChangesTransformationContext, deleteDeclaration;
-  var init_textChanges = __esm({
-    "src/services/textChanges.ts"() {
+  var maxProgramSizeForNonTsFiles, maxFileSize, ProjectsUpdatedInBackgroundEvent, ProjectLoadingStartEvent, ProjectLoadingFinishEvent, LargeFileReferencedEvent, ConfigFileDiagEvent, ProjectLanguageServiceStateEvent, ProjectInfoTelemetryEvent, OpenFileInfoTelemetryEvent, CreateFileWatcherEvent, CreateDirectoryWatcherEvent, CloseFileWatcherEvent, ensureProjectForOpenFileSchedule, compilerOptionConverters, watchOptionsConverters, indentStyle, defaultTypeSafeList, fileNamePropertyReader, externalFilePropertyReader, noopConfigFileWatcher, ProjectReferenceProjectLoadKind, _ProjectService, ProjectService3;
+  var init_editorServices = __esm({
+    "src/server/editorServices.ts"() {
       "use strict";
-      init_ts4();
-      LeadingTriviaOption = /* @__PURE__ */ ((LeadingTriviaOption2) => {
-        LeadingTriviaOption2[LeadingTriviaOption2["Exclude"] = 0] = "Exclude";
-        LeadingTriviaOption2[LeadingTriviaOption2["IncludeAll"] = 1] = "IncludeAll";
-        LeadingTriviaOption2[LeadingTriviaOption2["JSDoc"] = 2] = "JSDoc";
-        LeadingTriviaOption2[LeadingTriviaOption2["StartLine"] = 3] = "StartLine";
-        return LeadingTriviaOption2;
-      })(LeadingTriviaOption || {});
-      TrailingTriviaOption = /* @__PURE__ */ ((TrailingTriviaOption2) => {
-        TrailingTriviaOption2[TrailingTriviaOption2["Exclude"] = 0] = "Exclude";
-        TrailingTriviaOption2[TrailingTriviaOption2["ExcludeWhitespace"] = 1] = "ExcludeWhitespace";
-        TrailingTriviaOption2[TrailingTriviaOption2["Include"] = 2] = "Include";
-        return TrailingTriviaOption2;
-      })(TrailingTriviaOption || {});
-      useNonAdjustedPositions = {
-        leadingTriviaOption: 0 /* Exclude */,
-        trailingTriviaOption: 0 /* Exclude */
+      init_pnp();
+      init_ts7();
+      init_ts_server3();
+      init_protocol();
+      maxProgramSizeForNonTsFiles = 20 * 1024 * 1024;
+      maxFileSize = 4 * 1024 * 1024;
+      ProjectsUpdatedInBackgroundEvent = "projectsUpdatedInBackground";
+      ProjectLoadingStartEvent = "projectLoadingStart";
+      ProjectLoadingFinishEvent = "projectLoadingFinish";
+      LargeFileReferencedEvent = "largeFileReferenced";
+      ConfigFileDiagEvent = "configFileDiag";
+      ProjectLanguageServiceStateEvent = "projectLanguageServiceState";
+      ProjectInfoTelemetryEvent = "projectInfo";
+      OpenFileInfoTelemetryEvent = "openFileInfo";
+      CreateFileWatcherEvent = "createFileWatcher";
+      CreateDirectoryWatcherEvent = "createDirectoryWatcher";
+      CloseFileWatcherEvent = "closeFileWatcher";
+      ensureProjectForOpenFileSchedule = "*ensureProjectForOpenFiles*";
+      compilerOptionConverters = prepareConvertersForEnumLikeCompilerOptions(optionDeclarations);
+      watchOptionsConverters = prepareConvertersForEnumLikeCompilerOptions(optionsForWatch);
+      indentStyle = new Map(Object.entries({
+        none: 0 /* None */,
+        block: 1 /* Block */,
+        smart: 2 /* Smart */
+      }));
+      defaultTypeSafeList = {
+        "jquery": {
+          // jquery files can have names like "jquery-1.10.2.min.js" (or "jquery.intellisense.js")
+          match: /jquery(-[\d.]+)?(\.intellisense)?(\.min)?\.js$/i,
+          types: ["jquery"]
+        },
+        "WinJS": {
+          // e.g. c:/temp/UWApp1/lib/winjs-4.0.1/js/base.js
+          match: /^(.*\/winjs-[.\d]+)\/js\/base\.js$/i,
+          // If the winjs/base.js file is found..
+          exclude: [["^", 1, "/.*"]],
+          // ..then exclude all files under the winjs folder
+          types: ["winjs"]
+          // And fetch the @types package for WinJS
+        },
+        "Kendo": {
+          // e.g. /Kendo3/wwwroot/lib/kendo/kendo.all.min.js
+          match: /^(.*\/kendo(-ui)?)\/kendo\.all(\.min)?\.js$/i,
+          exclude: [["^", 1, "/.*"]],
+          types: ["kendo-ui"]
+        },
+        "Office Nuget": {
+          // e.g. /scripts/Office/1/excel-15.debug.js
+          match: /^(.*\/office\/1)\/excel-\d+\.debug\.js$/i,
+          // Office NuGet package is installed under a "1/office" folder
+          exclude: [["^", 1, "/.*"]],
+          // Exclude that whole folder if the file indicated above is found in it
+          types: ["office"]
+          // @types package to fetch instead
+        },
+        "References": {
+          match: /^(.*\/_references\.js)$/i,
+          exclude: [["^", 1, "$"]]
+        }
       };
-      ChangeTracker = class {
-        /** Public for tests only. Other callers should use `ChangeTracker.with`. */
-        constructor(newLineCharacter, formatContext) {
-          this.newLineCharacter = newLineCharacter;
-          this.formatContext = formatContext;
-          this.changes = [];
-          this.classesWithNodesInsertedAtStart = /* @__PURE__ */ new Map();
-          // Set implemented as Map
-          this.deletedNodes = [];
+      fileNamePropertyReader = {
+        getFileName: (x) => x,
+        getScriptKind: (fileName, extraFileExtensions) => {
+          let result;
+          if (extraFileExtensions) {
+            const fileExtension = getAnyExtensionFromPath(fileName);
+            if (fileExtension) {
+              some(extraFileExtensions, (info) => {
+                if (info.extension === fileExtension) {
+                  result = info.scriptKind;
+                  return true;
+                }
+                return false;
+              });
+            }
+          }
+          return result;
+        },
+        hasMixedContent: (fileName, extraFileExtensions) => some(extraFileExtensions, (ext) => ext.isMixedContent && fileExtensionIs(fileName, ext.extension))
+      };
+      externalFilePropertyReader = {
+        getFileName: (x) => x.fileName,
+        getScriptKind: (x) => tryConvertScriptKindName(x.scriptKind),
+        // TODO: GH#18217
+        hasMixedContent: (x) => !!x.hasMixedContent
+      };
+      noopConfigFileWatcher = { close: noop };
+      ProjectReferenceProjectLoadKind = /* @__PURE__ */ ((ProjectReferenceProjectLoadKind2) => {
+        ProjectReferenceProjectLoadKind2[ProjectReferenceProjectLoadKind2["Find"] = 0] = "Find";
+        ProjectReferenceProjectLoadKind2[ProjectReferenceProjectLoadKind2["FindCreate"] = 1] = "FindCreate";
+        ProjectReferenceProjectLoadKind2[ProjectReferenceProjectLoadKind2["FindCreateLoad"] = 2] = "FindCreateLoad";
+        return ProjectReferenceProjectLoadKind2;
+      })(ProjectReferenceProjectLoadKind || {});
+      _ProjectService = class _ProjectService {
+        constructor(opts) {
+          /**
+           * Container of all known scripts
+           *
+           * @internal
+           */
+          this.filenameToScriptInfo = /* @__PURE__ */ new Map();
+          this.nodeModulesWatchers = /* @__PURE__ */ new Map();
+          /**
+           * Contains all the deleted script info's version information so that
+           * it does not reset when creating script info again
+           * (and could have potentially collided with version where contents mismatch)
+           */
+          this.filenameToScriptInfoVersion = /* @__PURE__ */ new Map();
+          // Set of all '.js' files ever opened.
+          this.allJsFilesForOpenFileTelemetry = /* @__PURE__ */ new Map();
+          /**
+           * maps external project file name to list of config files that were the part of this project
+           */
+          this.externalProjectToConfiguredProjectMap = /* @__PURE__ */ new Map();
+          /**
+           * external projects (configuration and list of root files is not controlled by tsserver)
+           */
+          this.externalProjects = [];
+          /**
+           * projects built from openFileRoots
+           */
+          this.inferredProjects = [];
+          /**
+           * projects specified by a tsconfig.json file
+           */
+          this.configuredProjects = /* @__PURE__ */ new Map();
+          /** @internal */
+          this.newInferredProjectName = createProjectNameFactoryWithCounter(makeInferredProjectName);
+          /** @internal */
+          this.newAutoImportProviderProjectName = createProjectNameFactoryWithCounter(makeAutoImportProviderProjectName);
+          /** @internal */
+          this.newAuxiliaryProjectName = createProjectNameFactoryWithCounter(makeAuxiliaryProjectName);
+          /**
+           * Open files: with value being project root path, and key being Path of the file that is open
+           */
+          this.openFiles = /* @__PURE__ */ new Map();
+          /** @internal */
+          this.configFileForOpenFiles = /* @__PURE__ */ new Map();
+          /**
+           * Map of open files that are opened without complete path but have projectRoot as current directory
+           */
+          this.openFilesWithNonRootedDiskPath = /* @__PURE__ */ new Map();
+          this.compilerOptionsForInferredProjectsPerProjectRoot = /* @__PURE__ */ new Map();
+          this.watchOptionsForInferredProjectsPerProjectRoot = /* @__PURE__ */ new Map();
+          this.typeAcquisitionForInferredProjectsPerProjectRoot = /* @__PURE__ */ new Map();
+          /**
+           * Project size for configured or external projects
+           */
+          this.projectToSizeMap = /* @__PURE__ */ new Map();
+          /**
+           * This is a map of config file paths existence that doesnt need query to disk
+           * - The entry can be present because there is inferred project that needs to watch addition of config file to directory
+           *   In this case the exists could be true/false based on config file is present or not
+           * - Or it is present if we have configured project open with config file at that location
+           *   In this case the exists property is always true
+           *
+           * @internal
+           */
+          this.configFileExistenceInfoCache = /* @__PURE__ */ new Map();
+          this.safelist = defaultTypeSafeList;
+          this.legacySafelist = /* @__PURE__ */ new Map();
+          this.pendingProjectUpdates = /* @__PURE__ */ new Map();
+          /** @internal */
+          this.pendingEnsureProjectForOpenFiles = false;
+          /** Tracks projects that we have already sent telemetry for. */
+          this.seenProjects = /* @__PURE__ */ new Map();
+          /** @internal */
+          this.sharedExtendedConfigFileWatchers = /* @__PURE__ */ new Map();
+          /** @internal */
+          this.extendedConfigCache = /* @__PURE__ */ new Map();
+          /** @internal */
+          this.verifyDocumentRegistry = noop;
+          /** @internal */
+          this.verifyProgram = noop;
+          /** @internal */
+          this.onProjectCreation = noop;
+          var _a;
+          this.host = opts.host;
+          this.logger = opts.logger;
+          this.cancellationToken = opts.cancellationToken;
+          this.useSingleInferredProject = opts.useSingleInferredProject;
+          this.useInferredProjectPerProjectRoot = opts.useInferredProjectPerProjectRoot;
+          this.typingsInstaller = opts.typingsInstaller || nullTypingsInstaller;
+          this.throttleWaitMilliseconds = opts.throttleWaitMilliseconds;
+          this.eventHandler = opts.eventHandler;
+          this.suppressDiagnosticEvents = opts.suppressDiagnosticEvents;
+          this.globalPlugins = opts.globalPlugins || emptyArray2;
+          this.pluginProbeLocations = opts.pluginProbeLocations || emptyArray2;
+          this.allowLocalPluginLoads = !!opts.allowLocalPluginLoads;
+          this.typesMapLocation = opts.typesMapLocation === void 0 ? combinePaths(getDirectoryPath(this.getExecutingFilePath()), "typesMap.json") : opts.typesMapLocation;
+          this.session = opts.session;
+          this.jsDocParsingMode = opts.jsDocParsingMode;
+          if (opts.serverMode !== void 0) {
+            this.serverMode = opts.serverMode;
+          } else {
+            this.serverMode = 0 /* Semantic */;
+          }
+          if (this.host.realpath) {
+            this.realpathToScriptInfos = createMultiMap();
+          }
+          this.currentDirectory = toNormalizedPath(this.host.getCurrentDirectory());
+          this.toCanonicalFileName = createGetCanonicalFileName(this.host.useCaseSensitiveFileNames);
+          this.globalCacheLocationDirectoryPath = this.typingsInstaller.globalTypingsCacheLocation ? ensureTrailingDirectorySeparator(this.toPath(this.typingsInstaller.globalTypingsCacheLocation)) : void 0;
+          this.throttledOperations = new ThrottledOperations(this.host, this.logger);
+          if (this.typesMapLocation) {
+            this.loadTypesMap();
+          } else {
+            this.logger.info("No types map provided; using the default");
+          }
+          this.typingsInstaller.attach(this);
+          this.typingsCache = new TypingsCache(this.typingsInstaller);
+          this.hostConfiguration = {
+            formatCodeOptions: getDefaultFormatCodeSettings(this.host.newLine),
+            preferences: emptyOptions,
+            hostInfo: "Unknown host",
+            extraFileExtensions: []
+          };
+          this.documentRegistry = createDocumentRegistryInternal(this.host.useCaseSensitiveFileNames, this.currentDirectory, this.jsDocParsingMode, this);
+          const watchLogLevel = this.logger.hasLevel(3 /* verbose */) ? 2 /* Verbose */ : this.logger.loggingEnabled() ? 1 /* TriggerOnly */ : 0 /* None */;
+          const log = watchLogLevel !== 0 /* None */ ? (s) => this.logger.info(s) : noop;
+          this.packageJsonCache = createPackageJsonCache(this);
+          this.watchFactory = this.serverMode !== 0 /* Semantic */ ? {
+            watchFile: returnNoopFileWatcher,
+            watchDirectory: returnNoopFileWatcher
+          } : getWatchFactory(
+            createWatchFactoryHostUsingWatchEvents(this, opts.canUseWatchEvents) || this.host,
+            watchLogLevel,
+            log,
+            getDetailWatchInfo
+          );
+          this.pnpWatcher = this.watchPnpFile();
+          (_a = opts.incrementalVerifier) == null ? void 0 : _a.call(opts, this);
         }
-        static fromContext(context) {
-          return new ChangeTracker(getNewLineOrDefaultFromHost(context.host, context.formatContext.options), context.formatContext);
+        toPath(fileName) {
+          return toPath(fileName, this.currentDirectory, this.toCanonicalFileName);
         }
-        static with(context, cb) {
-          const tracker = ChangeTracker.fromContext(context);
-          cb(tracker);
-          return tracker.getChanges();
+        /** @internal */
+        getExecutingFilePath() {
+          return this.getNormalizedAbsolutePath(this.host.getExecutingFilePath());
         }
-        pushRaw(sourceFile, change) {
-          Debug.assertEqual(sourceFile.fileName, change.fileName);
-          for (const c of change.textChanges) {
-            this.changes.push({
-              kind: 3 /* Text */,
-              sourceFile,
-              text: c.newText,
-              range: createTextRangeFromSpan(c.span)
-            });
-          }
+        /** @internal */
+        getNormalizedAbsolutePath(fileName) {
+          return getNormalizedAbsolutePath(fileName, this.host.getCurrentDirectory());
         }
-        deleteRange(sourceFile, range) {
-          this.changes.push({ kind: 0 /* Remove */, sourceFile, range });
+        /** @internal */
+        setDocument(key, path, sourceFile) {
+          const info = Debug.checkDefined(this.getScriptInfoForPath(path));
+          info.cacheSourceFile = { key, sourceFile };
         }
-        delete(sourceFile, node) {
-          this.deletedNodes.push({ sourceFile, node });
+        /** @internal */
+        getDocument(key, path) {
+          const info = this.getScriptInfoForPath(path);
+          return info && info.cacheSourceFile && info.cacheSourceFile.key === key ? info.cacheSourceFile.sourceFile : void 0;
         }
-        /** Stop! Consider using `delete` instead, which has logic for deleting nodes from delimited lists. */
-        deleteNode(sourceFile, node, options = { leadingTriviaOption: 1 /* IncludeAll */ }) {
-          this.deleteRange(sourceFile, getAdjustedRange(sourceFile, node, node, options));
+        /** @internal */
+        ensureInferredProjectsUpToDate_TestOnly() {
+          this.ensureProjectStructuresUptoDate();
         }
-        deleteNodes(sourceFile, nodes, options = { leadingTriviaOption: 1 /* IncludeAll */ }, hasTrailingComment) {
-          for (const node of nodes) {
-            const pos = getAdjustedStartPosition(sourceFile, node, options, hasTrailingComment);
-            const end = getAdjustedEndPosition(sourceFile, node, options);
-            this.deleteRange(sourceFile, { pos, end });
-            hasTrailingComment = !!getEndPositionOfMultilineTrailingComment(sourceFile, node, options);
+        /** @internal */
+        getCompilerOptionsForInferredProjects() {
+          return this.compilerOptionsForInferredProjects;
+        }
+        /** @internal */
+        onUpdateLanguageServiceStateForProject(project, languageServiceEnabled) {
+          if (!this.eventHandler) {
+            return;
           }
+          const event = {
+            eventName: ProjectLanguageServiceStateEvent,
+            data: { project, languageServiceEnabled }
+          };
+          this.eventHandler(event);
         }
-        deleteModifier(sourceFile, modifier) {
-          this.deleteRange(sourceFile, { pos: modifier.getStart(sourceFile), end: skipTrivia(
-            sourceFile.text,
-            modifier.end,
-            /*stopAfterLineBreak*/
-            true
-          ) });
+        loadTypesMap() {
+          try {
+            const fileContent = this.host.readFile(this.typesMapLocation);
+            if (fileContent === void 0) {
+              this.logger.info(`Provided types map file "${this.typesMapLocation}" doesn't exist`);
+              return;
+            }
+            const raw = JSON.parse(fileContent);
+            for (const k of Object.keys(raw.typesMap)) {
+              raw.typesMap[k].match = new RegExp(raw.typesMap[k].match, "i");
+            }
+            this.safelist = raw.typesMap;
+            for (const key in raw.simpleMap) {
+              if (hasProperty(raw.simpleMap, key)) {
+                this.legacySafelist.set(key, raw.simpleMap[key].toLowerCase());
+              }
+            }
+          } catch (e) {
+            this.logger.info(`Error loading types map: ${e}`);
+            this.safelist = defaultTypeSafeList;
+            this.legacySafelist.clear();
+          }
         }
-        deleteNodeRange(sourceFile, startNode2, endNode2, options = { leadingTriviaOption: 1 /* IncludeAll */ }) {
-          const startPosition = getAdjustedStartPosition(sourceFile, startNode2, options);
-          const endPosition = getAdjustedEndPosition(sourceFile, endNode2, options);
-          this.deleteRange(sourceFile, { pos: startPosition, end: endPosition });
+        // eslint-disable-line @typescript-eslint/unified-signatures
+        updateTypingsForProject(response) {
+          const project = this.findProject(response.projectName);
+          if (!project) {
+            return;
+          }
+          switch (response.kind) {
+            case ActionSet:
+              project.updateTypingFiles(this.typingsCache.updateTypingsForProject(response.projectName, response.compilerOptions, response.typeAcquisition, response.unresolvedImports, response.typings));
+              return;
+            case ActionInvalidate:
+              this.typingsCache.enqueueInstallTypingsForProject(
+                project,
+                project.lastCachedUnresolvedImportsList,
+                /*forceRefresh*/
+                true
+              );
+              return;
+          }
         }
-        deleteNodeRangeExcludingEnd(sourceFile, startNode2, afterEndNode, options = { leadingTriviaOption: 1 /* IncludeAll */ }) {
-          const startPosition = getAdjustedStartPosition(sourceFile, startNode2, options);
-          const endPosition = afterEndNode === void 0 ? sourceFile.text.length : getAdjustedStartPosition(sourceFile, afterEndNode, options);
-          this.deleteRange(sourceFile, { pos: startPosition, end: endPosition });
+        /** @internal */
+        watchTypingLocations(response) {
+          var _a;
+          (_a = this.findProject(response.projectName)) == null ? void 0 : _a.watchTypingLocations(response.files);
         }
-        replaceRange(sourceFile, range, newNode, options = {}) {
-          this.changes.push({ kind: 1 /* ReplaceWithSingleNode */, sourceFile, range, options, node: newNode });
+        /** @internal */
+        delayEnsureProjectForOpenFiles() {
+          if (!this.openFiles.size)
+            return;
+          this.pendingEnsureProjectForOpenFiles = true;
+          this.throttledOperations.schedule(
+            ensureProjectForOpenFileSchedule,
+            /*delay*/
+            2500,
+            () => {
+              if (this.pendingProjectUpdates.size !== 0) {
+                this.delayEnsureProjectForOpenFiles();
+              } else {
+                if (this.pendingEnsureProjectForOpenFiles) {
+                  this.ensureProjectForOpenFiles();
+                  this.sendProjectsUpdatedInBackgroundEvent();
+                }
+              }
+            }
+          );
         }
-        replaceNode(sourceFile, oldNode, newNode, options = useNonAdjustedPositions) {
-          this.replaceRange(sourceFile, getAdjustedRange(sourceFile, oldNode, oldNode, options), newNode, options);
+        delayUpdateProjectGraph(project) {
+          project.markAsDirty();
+          if (isBackgroundProject(project))
+            return;
+          const projectName = project.getProjectName();
+          this.pendingProjectUpdates.set(projectName, project);
+          this.throttledOperations.schedule(
+            projectName,
+            /*delay*/
+            250,
+            () => {
+              if (this.pendingProjectUpdates.delete(projectName)) {
+                updateProjectIfDirty(project);
+              }
+            }
+          );
         }
-        replaceNodeRange(sourceFile, startNode2, endNode2, newNode, options = useNonAdjustedPositions) {
-          this.replaceRange(sourceFile, getAdjustedRange(sourceFile, startNode2, endNode2, options), newNode, options);
+        /** @internal */
+        hasPendingProjectUpdate(project) {
+          return this.pendingProjectUpdates.has(project.getProjectName());
         }
-        replaceRangeWithNodes(sourceFile, range, newNodes, options = {}) {
-          this.changes.push({ kind: 2 /* ReplaceWithMultipleNodes */, sourceFile, range, options, nodes: newNodes });
+        /** @internal */
+        sendProjectsUpdatedInBackgroundEvent() {
+          if (!this.eventHandler) {
+            return;
+          }
+          const event = {
+            eventName: ProjectsUpdatedInBackgroundEvent,
+            data: {
+              openFiles: arrayFrom(this.openFiles.keys(), (path) => this.getScriptInfoForPath(path).fileName)
+            }
+          };
+          this.eventHandler(event);
         }
-        replaceNodeWithNodes(sourceFile, oldNode, newNodes, options = useNonAdjustedPositions) {
-          this.replaceRangeWithNodes(sourceFile, getAdjustedRange(sourceFile, oldNode, oldNode, options), newNodes, options);
+        /** @internal */
+        sendLargeFileReferencedEvent(file, fileSize) {
+          if (!this.eventHandler) {
+            return;
+          }
+          const event = {
+            eventName: LargeFileReferencedEvent,
+            data: { file, fileSize, maxFileSize }
+          };
+          this.eventHandler(event);
         }
-        replaceNodeWithText(sourceFile, oldNode, text) {
-          this.replaceRangeWithText(sourceFile, getAdjustedRange(sourceFile, oldNode, oldNode, useNonAdjustedPositions), text);
+        /** @internal */
+        sendProjectLoadingStartEvent(project, reason) {
+          if (!this.eventHandler) {
+            return;
+          }
+          project.sendLoadingProjectFinish = true;
+          const event = {
+            eventName: ProjectLoadingStartEvent,
+            data: { project, reason }
+          };
+          this.eventHandler(event);
         }
-        replaceNodeRangeWithNodes(sourceFile, startNode2, endNode2, newNodes, options = useNonAdjustedPositions) {
-          this.replaceRangeWithNodes(sourceFile, getAdjustedRange(sourceFile, startNode2, endNode2, options), newNodes, options);
+        /** @internal */
+        sendProjectLoadingFinishEvent(project) {
+          if (!this.eventHandler || !project.sendLoadingProjectFinish) {
+            return;
+          }
+          project.sendLoadingProjectFinish = false;
+          const event = {
+            eventName: ProjectLoadingFinishEvent,
+            data: { project }
+          };
+          this.eventHandler(event);
         }
-        nodeHasTrailingComment(sourceFile, oldNode, configurableEnd = useNonAdjustedPositions) {
-          return !!getEndPositionOfMultilineTrailingComment(sourceFile, oldNode, configurableEnd);
+        /** @internal */
+        sendPerformanceEvent(kind, durationMs) {
+          if (this.performanceEventHandler) {
+            this.performanceEventHandler({ kind, durationMs });
+          }
         }
-        nextCommaToken(sourceFile, node) {
-          const next = findNextToken(node, node.parent, sourceFile);
-          return next && next.kind === 28 /* CommaToken */ ? next : void 0;
+        /** @internal */
+        delayUpdateProjectGraphAndEnsureProjectStructureForOpenFiles(project) {
+          this.delayUpdateProjectGraph(project);
+          this.delayEnsureProjectForOpenFiles();
         }
-        replacePropertyAssignment(sourceFile, oldNode, newNode) {
-          const suffix = this.nextCommaToken(sourceFile, oldNode) ? "" : "," + this.newLineCharacter;
-          this.replaceNode(sourceFile, oldNode, newNode, { suffix });
+        delayUpdateProjectGraphs(projects, clearSourceMapperCache) {
+          if (projects.length) {
+            for (const project of projects) {
+              if (clearSourceMapperCache)
+                project.clearSourceMapperCache();
+              this.delayUpdateProjectGraph(project);
+            }
+            this.delayEnsureProjectForOpenFiles();
+          }
         }
-        insertNodeAt(sourceFile, pos, newNode, options = {}) {
-          this.replaceRange(sourceFile, createRange(pos), newNode, options);
+        setCompilerOptionsForInferredProjects(projectCompilerOptions, projectRootPath) {
+          Debug.assert(projectRootPath === void 0 || this.useInferredProjectPerProjectRoot, "Setting compiler options per project root path is only supported when useInferredProjectPerProjectRoot is enabled");
+          const compilerOptions = convertCompilerOptions(projectCompilerOptions);
+          const watchOptions = convertWatchOptions(projectCompilerOptions, projectRootPath);
+          const typeAcquisition = convertTypeAcquisition(projectCompilerOptions);
+          compilerOptions.allowNonTsExtensions = true;
+          const canonicalProjectRootPath = projectRootPath && this.toCanonicalFileName(projectRootPath);
+          if (canonicalProjectRootPath) {
+            this.compilerOptionsForInferredProjectsPerProjectRoot.set(canonicalProjectRootPath, compilerOptions);
+            this.watchOptionsForInferredProjectsPerProjectRoot.set(canonicalProjectRootPath, watchOptions || false);
+            this.typeAcquisitionForInferredProjectsPerProjectRoot.set(canonicalProjectRootPath, typeAcquisition);
+          } else {
+            this.compilerOptionsForInferredProjects = compilerOptions;
+            this.watchOptionsForInferredProjects = watchOptions;
+            this.typeAcquisitionForInferredProjects = typeAcquisition;
+          }
+          for (const project of this.inferredProjects) {
+            if (canonicalProjectRootPath ? project.projectRootPath === canonicalProjectRootPath : !project.projectRootPath || !this.compilerOptionsForInferredProjectsPerProjectRoot.has(project.projectRootPath)) {
+              project.setCompilerOptions(compilerOptions);
+              project.setTypeAcquisition(typeAcquisition);
+              project.setWatchOptions(watchOptions == null ? void 0 : watchOptions.watchOptions);
+              project.setProjectErrors(watchOptions == null ? void 0 : watchOptions.errors);
+              project.compileOnSaveEnabled = compilerOptions.compileOnSave;
+              project.markAsDirty();
+              this.delayUpdateProjectGraph(project);
+            }
+          }
+          this.delayEnsureProjectForOpenFiles();
         }
-        insertNodesAt(sourceFile, pos, newNodes, options = {}) {
-          this.replaceRangeWithNodes(sourceFile, createRange(pos), newNodes, options);
+        findProject(projectName) {
+          if (projectName === void 0) {
+            return void 0;
+          }
+          if (isInferredProjectName(projectName)) {
+            return findProjectByName(projectName, this.inferredProjects);
+          }
+          return this.findExternalProjectByProjectName(projectName) || this.findConfiguredProjectByProjectName(toNormalizedPath(projectName));
         }
-        insertNodeAtTopOfFile(sourceFile, newNode, blankLineBetween) {
-          this.insertAtTopOfFile(sourceFile, newNode, blankLineBetween);
+        /** @internal */
+        forEachProject(cb) {
+          this.externalProjects.forEach(cb);
+          this.configuredProjects.forEach(cb);
+          this.inferredProjects.forEach(cb);
         }
-        insertNodesAtTopOfFile(sourceFile, newNodes, blankLineBetween) {
-          this.insertAtTopOfFile(sourceFile, newNodes, blankLineBetween);
+        /** @internal */
+        forEachEnabledProject(cb) {
+          this.forEachProject((project) => {
+            if (!project.isOrphan() && project.languageServiceEnabled) {
+              cb(project);
+            }
+          });
         }
-        insertAtTopOfFile(sourceFile, insert, blankLineBetween) {
-          const pos = getInsertionPositionAtSourceFileTop(sourceFile);
-          const options = {
-            prefix: pos === 0 ? void 0 : this.newLineCharacter,
-            suffix: (isLineBreak(sourceFile.text.charCodeAt(pos)) ? "" : this.newLineCharacter) + (blankLineBetween ? this.newLineCharacter : "")
+        getDefaultProjectForFile(fileName, ensureProject) {
+          return ensureProject ? this.ensureDefaultProjectForFile(fileName) : this.tryGetDefaultProjectForFile(fileName);
+        }
+        /** @internal */
+        tryGetDefaultProjectForFile(fileNameOrScriptInfo) {
+          const scriptInfo = isString(fileNameOrScriptInfo) ? this.getScriptInfoForNormalizedPath(fileNameOrScriptInfo) : fileNameOrScriptInfo;
+          return scriptInfo && !scriptInfo.isOrphan() ? scriptInfo.getDefaultProject() : void 0;
+        }
+        /** @internal */
+        ensureDefaultProjectForFile(fileNameOrScriptInfo) {
+          return this.tryGetDefaultProjectForFile(fileNameOrScriptInfo) || this.doEnsureDefaultProjectForFile(fileNameOrScriptInfo);
+        }
+        doEnsureDefaultProjectForFile(fileNameOrScriptInfo) {
+          this.ensureProjectStructuresUptoDate();
+          const scriptInfo = isString(fileNameOrScriptInfo) ? this.getScriptInfoForNormalizedPath(fileNameOrScriptInfo) : fileNameOrScriptInfo;
+          return scriptInfo ? scriptInfo.getDefaultProject() : (this.logErrorForScriptInfoNotFound(isString(fileNameOrScriptInfo) ? fileNameOrScriptInfo : fileNameOrScriptInfo.fileName), Errors.ThrowNoProject());
+        }
+        getScriptInfoEnsuringProjectsUptoDate(uncheckedFileName) {
+          this.ensureProjectStructuresUptoDate();
+          return this.getScriptInfo(uncheckedFileName);
+        }
+        /**
+         * Ensures the project structures are upto date
+         * This means,
+         * - we go through all the projects and update them if they are dirty
+         * - if updates reflect some change in structure or there was pending request to ensure projects for open files
+         *   ensure that each open script info has project
+         */
+        ensureProjectStructuresUptoDate() {
+          let hasChanges = this.pendingEnsureProjectForOpenFiles;
+          this.pendingProjectUpdates.clear();
+          const updateGraph = (project) => {
+            hasChanges = updateProjectIfDirty(project) || hasChanges;
           };
-          if (isArray(insert)) {
-            this.insertNodesAt(sourceFile, pos, insert, options);
-          } else {
-            this.insertNodeAt(sourceFile, pos, insert, options);
+          this.externalProjects.forEach(updateGraph);
+          this.configuredProjects.forEach(updateGraph);
+          this.inferredProjects.forEach(updateGraph);
+          if (hasChanges) {
+            this.ensureProjectForOpenFiles();
+          }
+        }
+        getFormatCodeOptions(file) {
+          const info = this.getScriptInfoForNormalizedPath(file);
+          return info && info.getFormatCodeSettings() || this.hostConfiguration.formatCodeOptions;
+        }
+        getPreferences(file) {
+          const info = this.getScriptInfoForNormalizedPath(file);
+          return { ...this.hostConfiguration.preferences, ...info && info.getPreferences() };
+        }
+        getHostFormatCodeOptions() {
+          return this.hostConfiguration.formatCodeOptions;
+        }
+        getHostPreferences() {
+          return this.hostConfiguration.preferences;
+        }
+        onSourceFileChanged(info, eventKind) {
+          if (eventKind === 2 /* Deleted */) {
+            this.handleDeletedFile(info);
+          } else if (!info.isScriptOpen()) {
+            info.delayReloadNonMixedContentFile();
+            this.delayUpdateProjectGraphs(
+              info.containingProjects,
+              /*clearSourceMapperCache*/
+              false
+            );
+            this.handleSourceMapProjects(info);
           }
         }
-        insertNodesAtEndOfFile(sourceFile, newNodes, blankLineBetween) {
-          this.insertAtEndOfFile(sourceFile, newNodes, blankLineBetween);
+        handleSourceMapProjects(info) {
+          if (info.sourceMapFilePath) {
+            if (isString(info.sourceMapFilePath)) {
+              const sourceMapFileInfo = this.getScriptInfoForPath(info.sourceMapFilePath);
+              this.delayUpdateSourceInfoProjects(sourceMapFileInfo && sourceMapFileInfo.sourceInfos);
+            } else {
+              this.delayUpdateSourceInfoProjects(info.sourceMapFilePath.sourceInfos);
+            }
+          }
+          this.delayUpdateSourceInfoProjects(info.sourceInfos);
+          if (info.declarationInfoPath) {
+            this.delayUpdateProjectsOfScriptInfoPath(info.declarationInfoPath);
+          }
         }
-        insertAtEndOfFile(sourceFile, insert, blankLineBetween) {
-          const pos = sourceFile.end + 1;
-          const options = {
-            prefix: this.newLineCharacter,
-            suffix: this.newLineCharacter + (blankLineBetween ? this.newLineCharacter : "")
-          };
-          this.insertNodesAt(sourceFile, pos, insert, options);
+        delayUpdateSourceInfoProjects(sourceInfos) {
+          if (sourceInfos) {
+            sourceInfos.forEach((_value, path) => this.delayUpdateProjectsOfScriptInfoPath(path));
+          }
         }
-        insertStatementsInNewFile(fileName, statements, oldFile) {
-          if (!this.newFileChanges) {
-            this.newFileChanges = createMultiMap();
+        delayUpdateProjectsOfScriptInfoPath(path) {
+          const info = this.getScriptInfoForPath(path);
+          if (info) {
+            this.delayUpdateProjectGraphs(
+              info.containingProjects,
+              /*clearSourceMapperCache*/
+              true
+            );
           }
-          this.newFileChanges.add(fileName, { oldFile, statements });
         }
-        insertFirstParameter(sourceFile, parameters, newParam) {
-          const p0 = firstOrUndefined(parameters);
-          if (p0) {
-            this.insertNodeBefore(sourceFile, p0, newParam);
+        handleDeletedFile(info) {
+          this.stopWatchingScriptInfo(info);
+          if (!info.isScriptOpen()) {
+            this.deleteScriptInfo(info);
+            const containingProjects = info.containingProjects.slice();
+            info.detachAllProjects();
+            this.delayUpdateProjectGraphs(
+              containingProjects,
+              /*clearSourceMapperCache*/
+              false
+            );
+            this.handleSourceMapProjects(info);
+            info.closeSourceMapFileWatcher();
+            if (info.declarationInfoPath) {
+              const declarationInfo = this.getScriptInfoForPath(info.declarationInfoPath);
+              if (declarationInfo) {
+                declarationInfo.sourceMapFilePath = void 0;
+              }
+            }
+          }
+        }
+        /**
+         * This is to watch whenever files are added or removed to the wildcard directories
+         *
+         * @internal
+         */
+        watchWildcardDirectory(directory, flags, configFileName, config) {
+          return this.watchFactory.watchDirectory(
+            directory,
+            (fileOrDirectory) => {
+              const fileOrDirectoryPath = this.toPath(fileOrDirectory);
+              const fsResult = config.cachedDirectoryStructureHost.addOrDeleteFileOrDirectory(fileOrDirectory, fileOrDirectoryPath);
+              if (getBaseFileName(fileOrDirectoryPath) === "package.json" && !isInsideNodeModules(fileOrDirectoryPath) && (fsResult && fsResult.fileExists || !fsResult && this.host.fileExists(fileOrDirectoryPath))) {
+                this.logger.info(`Config: ${configFileName} Detected new package.json: ${fileOrDirectory}`);
+                this.onAddPackageJson(fileOrDirectoryPath);
+              }
+              const configuredProjectForConfig = this.findConfiguredProjectByProjectName(configFileName);
+              if (isIgnoredFileFromWildCardWatching({
+                watchedDirPath: directory,
+                fileOrDirectory,
+                fileOrDirectoryPath,
+                configFileName,
+                extraFileExtensions: this.hostConfiguration.extraFileExtensions,
+                currentDirectory: this.currentDirectory,
+                options: config.parsedCommandLine.options,
+                program: (configuredProjectForConfig == null ? void 0 : configuredProjectForConfig.getCurrentProgram()) || config.parsedCommandLine.fileNames,
+                useCaseSensitiveFileNames: this.host.useCaseSensitiveFileNames,
+                writeLog: (s) => this.logger.info(s),
+                toPath: (s) => this.toPath(s),
+                getScriptKind: configuredProjectForConfig ? (fileName) => configuredProjectForConfig.getScriptKind(fileName) : void 0
+              }))
+                return;
+              if (config.updateLevel !== 2 /* Full */)
+                config.updateLevel = 1 /* RootNamesAndUpdate */;
+              config.projects.forEach((watchWildcardDirectories, projectCanonicalPath) => {
+                if (!watchWildcardDirectories)
+                  return;
+                const project = this.getConfiguredProjectByCanonicalConfigFilePath(projectCanonicalPath);
+                if (!project)
+                  return;
+                const updateLevel = configuredProjectForConfig === project ? 1 /* RootNamesAndUpdate */ : 0 /* Update */;
+                if (project.pendingUpdateLevel !== void 0 && project.pendingUpdateLevel > updateLevel)
+                  return;
+                if (this.openFiles.has(fileOrDirectoryPath)) {
+                  const info = Debug.checkDefined(this.getScriptInfoForPath(fileOrDirectoryPath));
+                  if (info.isAttached(project)) {
+                    const loadLevelToSet = Math.max(updateLevel, project.openFileWatchTriggered.get(fileOrDirectoryPath) || 0 /* Update */);
+                    project.openFileWatchTriggered.set(fileOrDirectoryPath, loadLevelToSet);
+                  } else {
+                    project.pendingUpdateLevel = updateLevel;
+                    this.delayUpdateProjectGraphAndEnsureProjectStructureForOpenFiles(project);
+                  }
+                } else {
+                  project.pendingUpdateLevel = updateLevel;
+                  this.delayUpdateProjectGraphAndEnsureProjectStructureForOpenFiles(project);
+                }
+              });
+            },
+            flags,
+            this.getWatchOptionsFromProjectWatchOptions(config.parsedCommandLine.watchOptions),
+            WatchType.WildcardDirectory,
+            configFileName
+          );
+        }
+        /** @internal */
+        delayUpdateProjectsFromParsedConfigOnConfigFileChange(canonicalConfigFilePath, loadReason) {
+          const configFileExistenceInfo = this.configFileExistenceInfoCache.get(canonicalConfigFilePath);
+          if (!(configFileExistenceInfo == null ? void 0 : configFileExistenceInfo.config))
+            return false;
+          let scheduledAnyProjectUpdate = false;
+          configFileExistenceInfo.config.updateLevel = 2 /* Full */;
+          configFileExistenceInfo.config.projects.forEach((_watchWildcardDirectories, projectCanonicalPath) => {
+            const project = this.getConfiguredProjectByCanonicalConfigFilePath(projectCanonicalPath);
+            if (!project)
+              return;
+            scheduledAnyProjectUpdate = true;
+            if (projectCanonicalPath === canonicalConfigFilePath) {
+              if (project.isInitialLoadPending())
+                return;
+              project.pendingUpdateLevel = 2 /* Full */;
+              project.pendingUpdateReason = loadReason;
+              this.delayUpdateProjectGraph(project);
+            } else {
+              project.resolutionCache.removeResolutionsFromProjectReferenceRedirects(this.toPath(canonicalConfigFilePath));
+              this.delayUpdateProjectGraph(project);
+            }
+          });
+          return scheduledAnyProjectUpdate;
+        }
+        /** @internal */
+        onConfigFileChanged(canonicalConfigFilePath, eventKind) {
+          var _a;
+          const configFileExistenceInfo = this.configFileExistenceInfoCache.get(canonicalConfigFilePath);
+          if (eventKind === 2 /* Deleted */) {
+            configFileExistenceInfo.exists = false;
+            const project = ((_a = configFileExistenceInfo.config) == null ? void 0 : _a.projects.has(canonicalConfigFilePath)) ? this.getConfiguredProjectByCanonicalConfigFilePath(canonicalConfigFilePath) : void 0;
+            if (project)
+              this.removeProject(project);
           } else {
-            this.insertNodeAt(sourceFile, parameters.pos, newParam);
+            configFileExistenceInfo.exists = true;
           }
+          this.delayUpdateProjectsFromParsedConfigOnConfigFileChange(canonicalConfigFilePath, "Change in config file detected");
+          this.reloadConfiguredProjectForFiles(
+            configFileExistenceInfo.openFilesImpactedByConfigFile,
+            /*clearSemanticCache*/
+            false,
+            /*delayReload*/
+            true,
+            eventKind !== 2 /* Deleted */ ? identity : (
+              // Reload open files if they are root of inferred project
+              returnTrue
+            ),
+            // Reload all the open files impacted by config file
+            "Change in config file detected"
+          );
+          this.delayEnsureProjectForOpenFiles();
         }
-        insertNodeBefore(sourceFile, before, newNode, blankLineBetween = false, options = {}) {
-          this.insertNodeAt(sourceFile, getAdjustedStartPosition(sourceFile, before, options), newNode, this.getOptionsForInsertNodeBefore(before, newNode, blankLineBetween));
+        removeProject(project) {
+          this.logger.info("`remove Project::");
+          project.print(
+            /*writeProjectFileNames*/
+            true,
+            /*writeFileExplaination*/
+            true,
+            /*writeFileVersionAndText*/
+            false
+          );
+          project.close();
+          if (Debug.shouldAssert(1 /* Normal */)) {
+            this.filenameToScriptInfo.forEach(
+              (info) => Debug.assert(
+                !info.isAttached(project),
+                "Found script Info still attached to project",
+                () => `${project.projectName}: ScriptInfos still attached: ${JSON.stringify(
+                  arrayFrom(
+                    mapDefinedIterator(
+                      this.filenameToScriptInfo.values(),
+                      (info2) => info2.isAttached(project) ? {
+                        fileName: info2.fileName,
+                        projects: info2.containingProjects.map((p) => p.projectName),
+                        hasMixedContent: info2.hasMixedContent
+                      } : void 0
+                    )
+                  ),
+                  /*replacer*/
+                  void 0,
+                  " "
+                )}`
+              )
+            );
+          }
+          this.pendingProjectUpdates.delete(project.getProjectName());
+          switch (project.projectKind) {
+            case 2 /* External */:
+              unorderedRemoveItem(this.externalProjects, project);
+              this.projectToSizeMap.delete(project.getProjectName());
+              break;
+            case 1 /* Configured */:
+              this.configuredProjects.delete(project.canonicalConfigFilePath);
+              this.projectToSizeMap.delete(project.canonicalConfigFilePath);
+              break;
+            case 0 /* Inferred */:
+              unorderedRemoveItem(this.inferredProjects, project);
+              break;
+          }
         }
-        insertModifierAt(sourceFile, pos, modifier, options = {}) {
-          this.insertNodeAt(sourceFile, pos, factory.createToken(modifier), options);
+        /** @internal */
+        assignOrphanScriptInfoToInferredProject(info, projectRootPath) {
+          Debug.assert(info.isOrphan());
+          const project = this.getOrCreateInferredProjectForProjectRootPathIfEnabled(info, projectRootPath) || this.getOrCreateSingleInferredProjectIfEnabled() || this.getOrCreateSingleInferredWithoutProjectRoot(
+            info.isDynamic ? projectRootPath || this.currentDirectory : getDirectoryPath(
+              isRootedDiskPath(info.fileName) ? info.fileName : getNormalizedAbsolutePath(
+                info.fileName,
+                projectRootPath ? this.getNormalizedAbsolutePath(projectRootPath) : this.currentDirectory
+              )
+            )
+          );
+          project.addRoot(info);
+          if (info.containingProjects[0] !== project) {
+            info.detachFromProject(project);
+            info.containingProjects.unshift(project);
+          }
+          project.updateGraph();
+          if (!this.useSingleInferredProject && !project.projectRootPath) {
+            for (const inferredProject of this.inferredProjects) {
+              if (inferredProject === project || inferredProject.isOrphan()) {
+                continue;
+              }
+              const roots = inferredProject.getRootScriptInfos();
+              Debug.assert(roots.length === 1 || !!inferredProject.projectRootPath);
+              if (roots.length === 1 && forEach(roots[0].containingProjects, (p) => p !== roots[0].containingProjects[0] && !p.isOrphan())) {
+                inferredProject.removeFile(
+                  roots[0],
+                  /*fileExists*/
+                  true,
+                  /*detachFromProject*/
+                  true
+                );
+              }
+            }
+          }
+          return project;
         }
-        insertModifierBefore(sourceFile, modifier, before) {
-          return this.insertModifierAt(sourceFile, before.getStart(sourceFile), modifier, { suffix: " " });
+        assignOrphanScriptInfosToInferredProject() {
+          this.openFiles.forEach((projectRootPath, path) => {
+            const info = this.getScriptInfoForPath(path);
+            if (info.isOrphan()) {
+              this.assignOrphanScriptInfoToInferredProject(info, projectRootPath);
+            }
+          });
         }
-        insertCommentBeforeLine(sourceFile, lineNumber, position, commentText) {
-          const lineStartPosition = getStartPositionOfLine(lineNumber, sourceFile);
-          const startPosition = getFirstNonSpaceCharacterPosition(sourceFile.text, lineStartPosition);
-          const insertAtLineStart = isValidLocationToAddComment(sourceFile, startPosition);
-          const token = getTouchingToken(sourceFile, insertAtLineStart ? startPosition : position);
-          const indent2 = sourceFile.text.slice(lineStartPosition, startPosition);
-          const text = `${insertAtLineStart ? "" : this.newLineCharacter}//${commentText}${this.newLineCharacter}${indent2}`;
-          this.insertText(sourceFile, token.getStart(sourceFile), text);
+        /**
+         * Remove this file from the set of open, non-configured files.
+         * @param info The file that has been closed or newly configured
+         */
+        closeOpenFile(info, skipAssignOrphanScriptInfosToInferredProject) {
+          const fileExists = info.isDynamic ? false : this.host.fileExists(info.fileName);
+          info.close(fileExists);
+          this.stopWatchingConfigFilesForClosedScriptInfo(info);
+          const canonicalFileName = this.toCanonicalFileName(info.fileName);
+          if (this.openFilesWithNonRootedDiskPath.get(canonicalFileName) === info) {
+            this.openFilesWithNonRootedDiskPath.delete(canonicalFileName);
+          }
+          let ensureProjectsForOpenFiles = false;
+          for (const p of info.containingProjects) {
+            if (isConfiguredProject(p)) {
+              if (info.hasMixedContent) {
+                info.registerFileUpdate();
+              }
+              const updateLevel = p.openFileWatchTriggered.get(info.path);
+              if (updateLevel !== void 0) {
+                p.openFileWatchTriggered.delete(info.path);
+                if (p.pendingUpdateLevel !== void 0 && p.pendingUpdateLevel < updateLevel) {
+                  p.pendingUpdateLevel = updateLevel;
+                  p.markFileAsDirty(info.path);
+                }
+              }
+            } else if (isInferredProject(p) && p.isRoot(info)) {
+              if (p.isProjectWithSingleRoot()) {
+                ensureProjectsForOpenFiles = true;
+              }
+              p.removeFile(
+                info,
+                fileExists,
+                /*detachFromProject*/
+                true
+              );
+            }
+            if (!p.languageServiceEnabled) {
+              p.markAsDirty();
+            }
+          }
+          this.openFiles.delete(info.path);
+          this.configFileForOpenFiles.delete(info.path);
+          if (!skipAssignOrphanScriptInfosToInferredProject && ensureProjectsForOpenFiles) {
+            this.assignOrphanScriptInfosToInferredProject();
+          }
+          if (fileExists) {
+            this.watchClosedScriptInfo(info);
+          } else {
+            this.handleDeletedFile(info);
+          }
+          return ensureProjectsForOpenFiles;
         }
-        insertJsdocCommentBefore(sourceFile, node, tag) {
-          const fnStart = node.getStart(sourceFile);
-          if (node.jsDoc) {
-            for (const jsdoc of node.jsDoc) {
-              this.deleteRange(sourceFile, {
-                pos: getLineStartPositionForPosition(jsdoc.getStart(sourceFile), sourceFile),
-                end: getAdjustedEndPosition(
-                  sourceFile,
-                  jsdoc,
-                  /*options*/
-                  {}
-                )
-              });
+        deleteScriptInfo(info) {
+          this.filenameToScriptInfo.delete(info.path);
+          this.filenameToScriptInfoVersion.set(info.path, info.textStorage.version);
+          const realpath = info.getRealpathIfDifferent();
+          if (realpath) {
+            this.realpathToScriptInfos.remove(realpath, info);
+          }
+        }
+        configFileExists(configFileName, canonicalConfigFilePath, info) {
+          var _a;
+          let configFileExistenceInfo = this.configFileExistenceInfoCache.get(canonicalConfigFilePath);
+          if (configFileExistenceInfo) {
+            if (isOpenScriptInfo(info) && !((_a = configFileExistenceInfo.openFilesImpactedByConfigFile) == null ? void 0 : _a.has(info.path))) {
+              (configFileExistenceInfo.openFilesImpactedByConfigFile || (configFileExistenceInfo.openFilesImpactedByConfigFile = /* @__PURE__ */ new Map())).set(info.path, false);
             }
+            return configFileExistenceInfo.exists;
           }
-          const startPosition = getPrecedingNonSpaceCharacterPosition(sourceFile.text, fnStart - 1);
-          const indent2 = sourceFile.text.slice(startPosition, fnStart);
-          this.insertNodeAt(sourceFile, fnStart, tag, { suffix: this.newLineCharacter + indent2 });
+          const exists = this.host.fileExists(configFileName);
+          let openFilesImpactedByConfigFile;
+          if (isOpenScriptInfo(info)) {
+            (openFilesImpactedByConfigFile || (openFilesImpactedByConfigFile = /* @__PURE__ */ new Map())).set(info.path, false);
+          }
+          configFileExistenceInfo = { exists, openFilesImpactedByConfigFile };
+          this.configFileExistenceInfoCache.set(canonicalConfigFilePath, configFileExistenceInfo);
+          return exists;
         }
-        createJSDocText(sourceFile, node) {
-          const comments = flatMap(node.jsDoc, (jsDoc2) => isString(jsDoc2.comment) ? factory.createJSDocText(jsDoc2.comment) : jsDoc2.comment);
-          const jsDoc = singleOrUndefined(node.jsDoc);
-          return jsDoc && positionsAreOnSameLine(jsDoc.pos, jsDoc.end, sourceFile) && length(comments) === 0 ? void 0 : factory.createNodeArray(intersperse(comments, factory.createJSDocText("\n")));
+        /** @internal */
+        createConfigFileWatcherForParsedConfig(configFileName, canonicalConfigFilePath, forProject) {
+          var _a, _b;
+          const configFileExistenceInfo = this.configFileExistenceInfoCache.get(canonicalConfigFilePath);
+          if (!configFileExistenceInfo.watcher || configFileExistenceInfo.watcher === noopConfigFileWatcher) {
+            configFileExistenceInfo.watcher = this.watchFactory.watchFile(
+              configFileName,
+              (_fileName, eventKind) => this.onConfigFileChanged(canonicalConfigFilePath, eventKind),
+              2e3 /* High */,
+              this.getWatchOptionsFromProjectWatchOptions((_b = (_a = configFileExistenceInfo == null ? void 0 : configFileExistenceInfo.config) == null ? void 0 : _a.parsedCommandLine) == null ? void 0 : _b.watchOptions),
+              WatchType.ConfigFile,
+              forProject
+            );
+          }
+          const projects = configFileExistenceInfo.config.projects;
+          projects.set(forProject.canonicalConfigFilePath, projects.get(forProject.canonicalConfigFilePath) || false);
         }
-        replaceJSDocComment(sourceFile, node, tags) {
-          this.insertJsdocCommentBefore(sourceFile, updateJSDocHost(node), factory.createJSDocComment(this.createJSDocText(sourceFile, node), factory.createNodeArray(tags)));
+        /**
+         * Returns true if the configFileExistenceInfo is needed/impacted by open files that are root of inferred project
+         */
+        configFileExistenceImpactsRootOfInferredProject(configFileExistenceInfo) {
+          return configFileExistenceInfo.openFilesImpactedByConfigFile && forEachEntry(configFileExistenceInfo.openFilesImpactedByConfigFile, identity);
         }
-        addJSDocTags(sourceFile, parent2, newTags) {
-          const oldTags = flatMapToMutable(parent2.jsDoc, (j) => j.tags);
-          const unmergedNewTags = newTags.filter((newTag) => !oldTags.some((tag, i) => {
-            const merged = tryMergeJsdocTags(tag, newTag);
-            if (merged)
-              oldTags[i] = merged;
-            return !!merged;
-          }));
-          this.replaceJSDocComment(sourceFile, parent2, [...oldTags, ...unmergedNewTags]);
+        /** @internal */
+        releaseParsedConfig(canonicalConfigFilePath, forProject) {
+          var _a, _b, _c;
+          const configFileExistenceInfo = this.configFileExistenceInfoCache.get(canonicalConfigFilePath);
+          if (!((_a = configFileExistenceInfo.config) == null ? void 0 : _a.projects.delete(forProject.canonicalConfigFilePath)))
+            return;
+          if ((_b = configFileExistenceInfo.config) == null ? void 0 : _b.projects.size)
+            return;
+          configFileExistenceInfo.config = void 0;
+          clearSharedExtendedConfigFileWatcher(canonicalConfigFilePath, this.sharedExtendedConfigFileWatchers);
+          Debug.checkDefined(configFileExistenceInfo.watcher);
+          if ((_c = configFileExistenceInfo.openFilesImpactedByConfigFile) == null ? void 0 : _c.size) {
+            if (this.configFileExistenceImpactsRootOfInferredProject(configFileExistenceInfo)) {
+              if (!canWatchDirectoryOrFile(getPathComponents(getDirectoryPath(canonicalConfigFilePath)))) {
+                configFileExistenceInfo.watcher.close();
+                configFileExistenceInfo.watcher = noopConfigFileWatcher;
+              }
+            } else {
+              configFileExistenceInfo.watcher.close();
+              configFileExistenceInfo.watcher = void 0;
+            }
+          } else {
+            configFileExistenceInfo.watcher.close();
+            this.configFileExistenceInfoCache.delete(canonicalConfigFilePath);
+          }
         }
-        filterJSDocTags(sourceFile, parent2, predicate) {
-          this.replaceJSDocComment(sourceFile, parent2, filter(flatMapToMutable(parent2.jsDoc, (j) => j.tags), predicate));
+        /**
+         * Close the config file watcher in the cached ConfigFileExistenceInfo
+         *   if there arent any open files that are root of inferred project and there is no parsed config held by any project
+         *
+         * @internal
+         */
+        closeConfigFileWatcherOnReleaseOfOpenFile(configFileExistenceInfo) {
+          if (configFileExistenceInfo.watcher && !configFileExistenceInfo.config && !this.configFileExistenceImpactsRootOfInferredProject(configFileExistenceInfo)) {
+            configFileExistenceInfo.watcher.close();
+            configFileExistenceInfo.watcher = void 0;
+          }
         }
-        replaceRangeWithText(sourceFile, range, text) {
-          this.changes.push({ kind: 3 /* Text */, sourceFile, range, text });
+        /**
+         * This is called on file close, so that we stop watching the config file for this script info
+         */
+        stopWatchingConfigFilesForClosedScriptInfo(info) {
+          Debug.assert(!info.isScriptOpen());
+          this.forEachConfigFileLocation(info, (canonicalConfigFilePath) => {
+            var _a, _b, _c;
+            const configFileExistenceInfo = this.configFileExistenceInfoCache.get(canonicalConfigFilePath);
+            if (configFileExistenceInfo) {
+              const infoIsRootOfInferredProject = (_a = configFileExistenceInfo.openFilesImpactedByConfigFile) == null ? void 0 : _a.get(info.path);
+              (_b = configFileExistenceInfo.openFilesImpactedByConfigFile) == null ? void 0 : _b.delete(info.path);
+              if (infoIsRootOfInferredProject) {
+                this.closeConfigFileWatcherOnReleaseOfOpenFile(configFileExistenceInfo);
+              }
+              if (!((_c = configFileExistenceInfo.openFilesImpactedByConfigFile) == null ? void 0 : _c.size) && !configFileExistenceInfo.config) {
+                Debug.assert(!configFileExistenceInfo.watcher);
+                this.configFileExistenceInfoCache.delete(canonicalConfigFilePath);
+              }
+            }
+          });
         }
-        insertText(sourceFile, pos, text) {
-          this.replaceRangeWithText(sourceFile, createRange(pos), text);
+        /**
+         * This is called by inferred project whenever script info is added as a root
+         *
+         * @internal
+         */
+        startWatchingConfigFilesForInferredProjectRoot(info) {
+          Debug.assert(info.isScriptOpen());
+          this.forEachConfigFileLocation(info, (canonicalConfigFilePath, configFileName) => {
+            let configFileExistenceInfo = this.configFileExistenceInfoCache.get(canonicalConfigFilePath);
+            if (!configFileExistenceInfo) {
+              configFileExistenceInfo = { exists: this.host.fileExists(configFileName) };
+              this.configFileExistenceInfoCache.set(canonicalConfigFilePath, configFileExistenceInfo);
+            }
+            (configFileExistenceInfo.openFilesImpactedByConfigFile || (configFileExistenceInfo.openFilesImpactedByConfigFile = /* @__PURE__ */ new Map())).set(info.path, true);
+            configFileExistenceInfo.watcher || (configFileExistenceInfo.watcher = canWatchDirectoryOrFile(getPathComponents(getDirectoryPath(canonicalConfigFilePath))) ? this.watchFactory.watchFile(
+              configFileName,
+              (_filename, eventKind) => this.onConfigFileChanged(canonicalConfigFilePath, eventKind),
+              2e3 /* High */,
+              this.hostConfiguration.watchOptions,
+              WatchType.ConfigFileForInferredRoot
+            ) : noopConfigFileWatcher);
+          });
         }
-        /** Prefer this over replacing a node with another that has a type annotation, as it avoids reformatting the other parts of the node. */
-        tryInsertTypeAnnotation(sourceFile, node, type) {
-          let endNode2;
-          if (isFunctionLike(node)) {
-            endNode2 = findChildOfKind(node, 22 /* CloseParenToken */, sourceFile);
-            if (!endNode2) {
-              if (!isArrowFunction(node))
-                return false;
-              endNode2 = first(node.parameters);
+        /**
+         * This is called by inferred project whenever root script info is removed from it
+         *
+         * @internal
+         */
+        stopWatchingConfigFilesForInferredProjectRoot(info) {
+          this.forEachConfigFileLocation(info, (canonicalConfigFilePath) => {
+            var _a;
+            const configFileExistenceInfo = this.configFileExistenceInfoCache.get(canonicalConfigFilePath);
+            if ((_a = configFileExistenceInfo == null ? void 0 : configFileExistenceInfo.openFilesImpactedByConfigFile) == null ? void 0 : _a.has(info.path)) {
+              Debug.assert(info.isScriptOpen());
+              configFileExistenceInfo.openFilesImpactedByConfigFile.set(info.path, false);
+              this.closeConfigFileWatcherOnReleaseOfOpenFile(configFileExistenceInfo);
+            }
+          });
+        }
+        /**
+         * This function tries to search for a tsconfig.json for the given file.
+         * This is different from the method the compiler uses because
+         * the compiler can assume it will always start searching in the
+         * current directory (the directory in which tsc was invoked).
+         * The server must start searching from the directory containing
+         * the newly opened file.
+         */
+        forEachConfigFileLocation(info, action) {
+          if (this.serverMode !== 0 /* Semantic */) {
+            return void 0;
+          }
+          Debug.assert(!isOpenScriptInfo(info) || this.openFiles.has(info.path));
+          const projectRootPath = this.openFiles.get(info.path);
+          const scriptInfo = Debug.checkDefined(this.getScriptInfo(info.path));
+          if (scriptInfo.isDynamic)
+            return void 0;
+          let searchPath = asNormalizedPath(getDirectoryPath(info.fileName));
+          const isSearchPathInProjectRoot = () => containsPath(projectRootPath, searchPath, this.currentDirectory, !this.host.useCaseSensitiveFileNames);
+          const anySearchPathOk = !projectRootPath || !isSearchPathInProjectRoot();
+          let searchInDirectory = !isAncestorConfigFileInfo(info);
+          do {
+            if (searchInDirectory) {
+              const canonicalSearchPath = normalizedPathToPath(searchPath, this.currentDirectory, this.toCanonicalFileName);
+              const tsconfigFileName = asNormalizedPath(combinePaths(searchPath, "tsconfig.json"));
+              let result = action(combinePaths(canonicalSearchPath, "tsconfig.json"), tsconfigFileName);
+              if (result)
+                return tsconfigFileName;
+              const jsconfigFileName = asNormalizedPath(combinePaths(searchPath, "jsconfig.json"));
+              result = action(combinePaths(canonicalSearchPath, "jsconfig.json"), jsconfigFileName);
+              if (result)
+                return jsconfigFileName;
+              if (isNodeModulesDirectory(canonicalSearchPath)) {
+                break;
+              }
             }
+            const parentPath = asNormalizedPath(getDirectoryPath(searchPath));
+            if (parentPath === searchPath)
+              break;
+            searchPath = parentPath;
+            searchInDirectory = true;
+          } while (anySearchPathOk || isSearchPathInProjectRoot());
+          return void 0;
+        }
+        /** @internal */
+        findDefaultConfiguredProject(info) {
+          if (!info.isScriptOpen())
+            return void 0;
+          const configFileName = this.getConfigFileNameForFile(info);
+          const project = configFileName && this.findConfiguredProjectByProjectName(configFileName);
+          return project && projectContainsInfoDirectly(project, info) ? project : project == null ? void 0 : project.getDefaultChildProjectFromProjectWithReferences(info);
+        }
+        /**
+         * This function tries to search for a tsconfig.json for the given file.
+         * This is different from the method the compiler uses because
+         * the compiler can assume it will always start searching in the
+         * current directory (the directory in which tsc was invoked).
+         * The server must start searching from the directory containing
+         * the newly opened file.
+         * If script info is passed in, it is asserted to be open script info
+         * otherwise just file name
+         */
+        getConfigFileNameForFile(info) {
+          if (isOpenScriptInfo(info)) {
+            Debug.assert(info.isScriptOpen());
+            const result = this.configFileForOpenFiles.get(info.path);
+            if (result !== void 0)
+              return result || void 0;
+          }
+          this.logger.info(`Search path: ${getDirectoryPath(info.fileName)}`);
+          const configFileName = this.forEachConfigFileLocation(info, (canonicalConfigFilePath, configFileName2) => this.configFileExists(configFileName2, canonicalConfigFilePath, info));
+          if (configFileName) {
+            this.logger.info(`For info: ${info.fileName} :: Config file name: ${configFileName}`);
           } else {
-            endNode2 = (node.kind === 259 /* VariableDeclaration */ ? node.exclamationToken : node.questionToken) ?? node.name;
+            this.logger.info(`For info: ${info.fileName} :: No config files found.`);
           }
-          this.insertNodeAt(sourceFile, endNode2.end, type, { prefix: ": " });
-          return true;
+          if (isOpenScriptInfo(info)) {
+            this.configFileForOpenFiles.set(info.path, configFileName || false);
+          }
+          return configFileName;
         }
-        tryInsertThisTypeAnnotation(sourceFile, node, type) {
-          const start = findChildOfKind(node, 21 /* OpenParenToken */, sourceFile).getStart(sourceFile) + 1;
-          const suffix = node.parameters.length ? ", " : "";
-          this.insertNodeAt(sourceFile, start, type, { prefix: "this: ", suffix });
+        printProjects() {
+          if (!this.logger.hasLevel(1 /* normal */)) {
+            return;
+          }
+          this.logger.startGroup();
+          this.externalProjects.forEach(printProjectWithoutFileNames);
+          this.configuredProjects.forEach(printProjectWithoutFileNames);
+          this.inferredProjects.forEach(printProjectWithoutFileNames);
+          this.logger.info("Open files: ");
+          this.openFiles.forEach((projectRootPath, path) => {
+            const info = this.getScriptInfoForPath(path);
+            this.logger.info(`	FileName: ${info.fileName} ProjectRootPath: ${projectRootPath}`);
+            this.logger.info(`		Projects: ${info.containingProjects.map((p) => p.getProjectName())}`);
+          });
+          this.logger.endGroup();
         }
-        insertTypeParameters(sourceFile, node, typeParameters) {
-          const start = (findChildOfKind(node, 21 /* OpenParenToken */, sourceFile) || first(node.parameters)).getStart(sourceFile);
-          this.insertNodesAt(sourceFile, start, typeParameters, { prefix: "<", suffix: ">", joiner: ", " });
+        /** @internal */
+        findConfiguredProjectByProjectName(configFileName) {
+          const canonicalConfigFilePath = asNormalizedPath(this.toCanonicalFileName(configFileName));
+          return this.getConfiguredProjectByCanonicalConfigFilePath(canonicalConfigFilePath);
         }
-        getOptionsForInsertNodeBefore(before, inserted, blankLineBetween) {
-          if (isStatement(before) || isClassElement(before)) {
-            return { suffix: blankLineBetween ? this.newLineCharacter + this.newLineCharacter : this.newLineCharacter };
-          } else if (isVariableDeclaration(before)) {
-            return { suffix: ", " };
-          } else if (isParameter(before)) {
-            return isParameter(inserted) ? { suffix: ", " } : {};
-          } else if (isStringLiteral(before) && isImportDeclaration(before.parent) || isNamedImports(before)) {
-            return { suffix: ", " };
-          } else if (isImportSpecifier(before)) {
-            return { suffix: "," + (blankLineBetween ? this.newLineCharacter : " ") };
+        getConfiguredProjectByCanonicalConfigFilePath(canonicalConfigFilePath) {
+          return this.configuredProjects.get(canonicalConfigFilePath);
+        }
+        findExternalProjectByProjectName(projectFileName) {
+          return findProjectByName(projectFileName, this.externalProjects);
+        }
+        /** Get a filename if the language service exceeds the maximum allowed program size; otherwise returns undefined. */
+        getFilenameForExceededTotalSizeLimitForNonTsFiles(name, options, fileNames, propertyReader) {
+          if (options && options.disableSizeLimit || !this.host.getFileSize) {
+            return;
           }
-          return Debug.failBadSyntaxKind(before);
+          let availableSpace = maxProgramSizeForNonTsFiles;
+          this.projectToSizeMap.set(name, 0);
+          this.projectToSizeMap.forEach((val) => availableSpace -= val || 0);
+          let totalNonTsFileSize = 0;
+          for (const f of fileNames) {
+            const fileName = propertyReader.getFileName(f);
+            if (hasTSFileExtension(fileName)) {
+              continue;
+            }
+            totalNonTsFileSize += this.host.getFileSize(fileName);
+            if (totalNonTsFileSize > maxProgramSizeForNonTsFiles || totalNonTsFileSize > availableSpace) {
+              const top5LargestFiles = fileNames.map((f2) => propertyReader.getFileName(f2)).filter((name2) => !hasTSFileExtension(name2)).map((name2) => ({ name: name2, size: this.host.getFileSize(name2) })).sort((a, b) => b.size - a.size).slice(0, 5);
+              this.logger.info(`Non TS file size exceeded limit (${totalNonTsFileSize}). Largest files: ${top5LargestFiles.map((file) => `${file.name}:${file.size}`).join(", ")}`);
+              return fileName;
+            }
+          }
+          this.projectToSizeMap.set(name, totalNonTsFileSize);
         }
-        insertNodeAtConstructorStart(sourceFile, ctr, newStatement) {
-          const firstStatement = firstOrUndefined(ctr.body.statements);
-          if (!firstStatement || !ctr.body.multiLine) {
-            this.replaceConstructorBody(sourceFile, ctr, [newStatement, ...ctr.body.statements]);
+        createExternalProject(projectFileName, files, options, typeAcquisition, excludedFiles) {
+          const compilerOptions = convertCompilerOptions(options);
+          const watchOptionsAndErrors = convertWatchOptions(options, getDirectoryPath(normalizeSlashes(projectFileName)));
+          const project = new ExternalProject2(
+            projectFileName,
+            this,
+            this.documentRegistry,
+            compilerOptions,
+            /*lastFileExceededProgramSize*/
+            this.getFilenameForExceededTotalSizeLimitForNonTsFiles(projectFileName, compilerOptions, files, externalFilePropertyReader),
+            options.compileOnSave === void 0 ? true : options.compileOnSave,
+            /*projectFilePath*/
+            void 0,
+            watchOptionsAndErrors == null ? void 0 : watchOptionsAndErrors.watchOptions
+          );
+          project.setProjectErrors(watchOptionsAndErrors == null ? void 0 : watchOptionsAndErrors.errors);
+          project.excludedFiles = excludedFiles;
+          this.addFilesToNonInferredProject(project, files, externalFilePropertyReader, typeAcquisition);
+          this.externalProjects.push(project);
+          return project;
+        }
+        /** @internal */
+        sendProjectTelemetry(project) {
+          if (this.seenProjects.has(project.projectName)) {
+            setProjectOptionsUsed(project);
+            return;
+          }
+          this.seenProjects.set(project.projectName, true);
+          if (!this.eventHandler || !this.host.createSHA256Hash) {
+            setProjectOptionsUsed(project);
+            return;
+          }
+          const projectOptions = isConfiguredProject(project) ? project.projectOptions : void 0;
+          setProjectOptionsUsed(project);
+          const data = {
+            projectId: this.host.createSHA256Hash(project.projectName),
+            fileStats: countEachFileTypes(
+              project.getScriptInfos(),
+              /*includeSizes*/
+              true
+            ),
+            compilerOptions: convertCompilerOptionsForTelemetry(project.getCompilationSettings()),
+            typeAcquisition: convertTypeAcquisition2(project.getTypeAcquisition()),
+            extends: projectOptions && projectOptions.configHasExtendsProperty,
+            files: projectOptions && projectOptions.configHasFilesProperty,
+            include: projectOptions && projectOptions.configHasIncludeProperty,
+            exclude: projectOptions && projectOptions.configHasExcludeProperty,
+            compileOnSave: project.compileOnSaveEnabled,
+            configFileName: configFileName(),
+            projectType: project instanceof ExternalProject2 ? "external" : "configured",
+            languageServiceEnabled: project.languageServiceEnabled,
+            version
+          };
+          this.eventHandler({ eventName: ProjectInfoTelemetryEvent, data });
+          function configFileName() {
+            if (!isConfiguredProject(project)) {
+              return "other";
+            }
+            return getBaseConfigFileName(project.getConfigFilePath()) || "other";
+          }
+          function convertTypeAcquisition2({ enable: enable2, include, exclude }) {
+            return {
+              enable: enable2,
+              include: include !== void 0 && include.length !== 0,
+              exclude: exclude !== void 0 && exclude.length !== 0
+            };
+          }
+        }
+        addFilesToNonInferredProject(project, files, propertyReader, typeAcquisition) {
+          this.updateNonInferredProjectFiles(project, files, propertyReader);
+          project.setTypeAcquisition(typeAcquisition);
+          project.markAsDirty();
+        }
+        /** @internal */
+        createConfiguredProject(configFileName) {
+          var _a;
+          (_a = tracing) == null ? void 0 : _a.instant(tracing.Phase.Session, "createConfiguredProject", { configFilePath: configFileName });
+          this.logger.info(`Creating configuration project ${configFileName}`);
+          const canonicalConfigFilePath = asNormalizedPath(this.toCanonicalFileName(configFileName));
+          let configFileExistenceInfo = this.configFileExistenceInfoCache.get(canonicalConfigFilePath);
+          if (!configFileExistenceInfo) {
+            this.configFileExistenceInfoCache.set(canonicalConfigFilePath, configFileExistenceInfo = { exists: true });
           } else {
-            this.insertNodeBefore(sourceFile, firstStatement, newStatement);
+            configFileExistenceInfo.exists = true;
           }
+          if (!configFileExistenceInfo.config) {
+            configFileExistenceInfo.config = {
+              cachedDirectoryStructureHost: createCachedDirectoryStructureHost(this.host, this.host.getCurrentDirectory(), this.host.useCaseSensitiveFileNames),
+              projects: /* @__PURE__ */ new Map(),
+              updateLevel: 2 /* Full */
+            };
+          }
+          const project = new ConfiguredProject2(
+            configFileName,
+            canonicalConfigFilePath,
+            this,
+            this.documentRegistry,
+            configFileExistenceInfo.config.cachedDirectoryStructureHost
+          );
+          this.configuredProjects.set(canonicalConfigFilePath, project);
+          this.createConfigFileWatcherForParsedConfig(configFileName, canonicalConfigFilePath, project);
+          return project;
         }
-        insertNodeAtConstructorStartAfterSuperCall(sourceFile, ctr, newStatement) {
-          const superCallStatement = find(ctr.body.statements, (stmt) => isExpressionStatement(stmt) && isSuperCall(stmt.expression));
-          if (!superCallStatement || !ctr.body.multiLine) {
-            this.replaceConstructorBody(sourceFile, ctr, [...ctr.body.statements, newStatement]);
+        /** @internal */
+        createConfiguredProjectWithDelayLoad(configFileName, reason) {
+          const project = this.createConfiguredProject(configFileName);
+          project.pendingUpdateLevel = 2 /* Full */;
+          project.pendingUpdateReason = reason;
+          return project;
+        }
+        /** @internal */
+        createAndLoadConfiguredProject(configFileName, reason) {
+          const project = this.createConfiguredProject(configFileName);
+          this.loadConfiguredProject(project, reason);
+          return project;
+        }
+        /** @internal */
+        createLoadAndUpdateConfiguredProject(configFileName, reason) {
+          const project = this.createAndLoadConfiguredProject(configFileName, reason);
+          project.updateGraph();
+          return project;
+        }
+        /**
+         * Read the config file of the project, and update the project root file names.
+         *
+         * @internal
+         */
+        loadConfiguredProject(project, reason) {
+          var _a, _b;
+          (_a = tracing) == null ? void 0 : _a.push(tracing.Phase.Session, "loadConfiguredProject", { configFilePath: project.canonicalConfigFilePath });
+          this.sendProjectLoadingStartEvent(project, reason);
+          const configFilename = asNormalizedPath(normalizePath(project.getConfigFilePath()));
+          const configFileExistenceInfo = this.ensureParsedConfigUptoDate(
+            configFilename,
+            project.canonicalConfigFilePath,
+            this.configFileExistenceInfoCache.get(project.canonicalConfigFilePath),
+            project
+          );
+          const parsedCommandLine = configFileExistenceInfo.config.parsedCommandLine;
+          Debug.assert(!!parsedCommandLine.fileNames);
+          const compilerOptions = parsedCommandLine.options;
+          if (!project.projectOptions) {
+            project.projectOptions = {
+              configHasExtendsProperty: parsedCommandLine.raw.extends !== void 0,
+              configHasFilesProperty: parsedCommandLine.raw.files !== void 0,
+              configHasIncludeProperty: parsedCommandLine.raw.include !== void 0,
+              configHasExcludeProperty: parsedCommandLine.raw.exclude !== void 0
+            };
+          }
+          project.canConfigFileJsonReportNoInputFiles = canJsonReportNoInputFiles(parsedCommandLine.raw);
+          project.setProjectErrors(parsedCommandLine.options.configFile.parseDiagnostics);
+          project.updateReferences(parsedCommandLine.projectReferences);
+          const lastFileExceededProgramSize = this.getFilenameForExceededTotalSizeLimitForNonTsFiles(project.canonicalConfigFilePath, compilerOptions, parsedCommandLine.fileNames, fileNamePropertyReader);
+          if (lastFileExceededProgramSize) {
+            project.disableLanguageService(lastFileExceededProgramSize);
+            this.configFileExistenceInfoCache.forEach((_configFileExistenceInfo, canonicalConfigFilePath) => this.stopWatchingWildCards(canonicalConfigFilePath, project));
           } else {
-            this.insertNodeAfter(sourceFile, superCallStatement, newStatement);
+            project.setCompilerOptions(compilerOptions);
+            project.setWatchOptions(parsedCommandLine.watchOptions);
+            project.enableLanguageService();
+            this.watchWildcards(configFilename, configFileExistenceInfo, project);
           }
+          project.enablePluginsWithOptions(compilerOptions);
+          const filesToAdd = parsedCommandLine.fileNames.concat(project.getExternalFiles(2 /* Full */));
+          this.updateRootAndOptionsOfNonInferredProject(project, filesToAdd, fileNamePropertyReader, compilerOptions, parsedCommandLine.typeAcquisition, parsedCommandLine.compileOnSave, parsedCommandLine.watchOptions);
+          (_b = tracing) == null ? void 0 : _b.pop();
         }
-        insertNodeAtConstructorEnd(sourceFile, ctr, newStatement) {
-          const lastStatement = lastOrUndefined(ctr.body.statements);
-          if (!lastStatement || !ctr.body.multiLine) {
-            this.replaceConstructorBody(sourceFile, ctr, [...ctr.body.statements, newStatement]);
+        /** @internal */
+        ensureParsedConfigUptoDate(configFilename, canonicalConfigFilePath, configFileExistenceInfo, forProject) {
+          var _a, _b, _c;
+          if (configFileExistenceInfo.config) {
+            if (!configFileExistenceInfo.config.updateLevel)
+              return configFileExistenceInfo;
+            if (configFileExistenceInfo.config.updateLevel === 1 /* RootNamesAndUpdate */) {
+              this.reloadFileNamesOfParsedConfig(configFilename, configFileExistenceInfo.config);
+              return configFileExistenceInfo;
+            }
+          }
+          const cachedDirectoryStructureHost = ((_a = configFileExistenceInfo.config) == null ? void 0 : _a.cachedDirectoryStructureHost) || createCachedDirectoryStructureHost(this.host, this.host.getCurrentDirectory(), this.host.useCaseSensitiveFileNames);
+          const configFileContent = tryReadFile(configFilename, (fileName) => this.host.readFile(fileName));
+          const configFile = parseJsonText(configFilename, isString(configFileContent) ? configFileContent : "");
+          const configFileErrors = configFile.parseDiagnostics;
+          if (!isString(configFileContent))
+            configFileErrors.push(configFileContent);
+          const parsedCommandLine = parseJsonSourceFileConfigFileContent(
+            configFile,
+            cachedDirectoryStructureHost,
+            getDirectoryPath(configFilename),
+            /*existingOptions*/
+            {},
+            configFilename,
+            /*resolutionStack*/
+            [],
+            this.hostConfiguration.extraFileExtensions,
+            this.extendedConfigCache
+          );
+          if (parsedCommandLine.errors.length) {
+            configFileErrors.push(...parsedCommandLine.errors);
+          }
+          this.logger.info(`Config: ${configFilename} : ${JSON.stringify(
+            {
+              rootNames: parsedCommandLine.fileNames,
+              options: parsedCommandLine.options,
+              watchOptions: parsedCommandLine.watchOptions,
+              projectReferences: parsedCommandLine.projectReferences
+            },
+            /*replacer*/
+            void 0,
+            " "
+          )}`);
+          const oldCommandLine = (_b = configFileExistenceInfo.config) == null ? void 0 : _b.parsedCommandLine;
+          if (!configFileExistenceInfo.config) {
+            configFileExistenceInfo.config = { parsedCommandLine, cachedDirectoryStructureHost, projects: /* @__PURE__ */ new Map() };
           } else {
-            this.insertNodeAfter(sourceFile, lastStatement, newStatement);
+            configFileExistenceInfo.config.parsedCommandLine = parsedCommandLine;
+            configFileExistenceInfo.config.watchedDirectoriesStale = true;
+            configFileExistenceInfo.config.updateLevel = void 0;
+          }
+          if (!oldCommandLine && !isJsonEqual(
+            // Old options
+            this.getWatchOptionsFromProjectWatchOptions(
+              /*projectOptions*/
+              void 0
+            ),
+            // New options
+            this.getWatchOptionsFromProjectWatchOptions(parsedCommandLine.watchOptions)
+          )) {
+            (_c = configFileExistenceInfo.watcher) == null ? void 0 : _c.close();
+            configFileExistenceInfo.watcher = void 0;
+          }
+          this.createConfigFileWatcherForParsedConfig(configFilename, canonicalConfigFilePath, forProject);
+          updateSharedExtendedConfigFileWatcher(
+            canonicalConfigFilePath,
+            parsedCommandLine.options,
+            this.sharedExtendedConfigFileWatchers,
+            (extendedConfigFileName, extendedConfigFilePath) => this.watchFactory.watchFile(
+              extendedConfigFileName,
+              () => {
+                var _a2;
+                cleanExtendedConfigCache(this.extendedConfigCache, extendedConfigFilePath, (fileName) => this.toPath(fileName));
+                let ensureProjectsForOpenFiles = false;
+                (_a2 = this.sharedExtendedConfigFileWatchers.get(extendedConfigFilePath)) == null ? void 0 : _a2.projects.forEach((canonicalPath) => {
+                  ensureProjectsForOpenFiles = this.delayUpdateProjectsFromParsedConfigOnConfigFileChange(canonicalPath, `Change in extended config file ${extendedConfigFileName} detected`) || ensureProjectsForOpenFiles;
+                });
+                if (ensureProjectsForOpenFiles)
+                  this.delayEnsureProjectForOpenFiles();
+              },
+              2e3 /* High */,
+              this.hostConfiguration.watchOptions,
+              WatchType.ExtendedConfigFile,
+              configFilename
+            ),
+            (fileName) => this.toPath(fileName)
+          );
+          return configFileExistenceInfo;
+        }
+        /** @internal */
+        watchWildcards(configFileName, { exists, config }, forProject) {
+          config.projects.set(forProject.canonicalConfigFilePath, true);
+          if (exists) {
+            if (config.watchedDirectories && !config.watchedDirectoriesStale)
+              return;
+            config.watchedDirectoriesStale = false;
+            updateWatchingWildcardDirectories(
+              config.watchedDirectories || (config.watchedDirectories = /* @__PURE__ */ new Map()),
+              new Map(Object.entries(config.parsedCommandLine.wildcardDirectories)),
+              // Create new directory watcher
+              (directory, flags) => this.watchWildcardDirectory(directory, flags, configFileName, config)
+            );
+          } else {
+            config.watchedDirectoriesStale = false;
+            if (!config.watchedDirectories)
+              return;
+            clearMap(config.watchedDirectories, closeFileWatcherOf);
+            config.watchedDirectories = void 0;
           }
         }
-        replaceConstructorBody(sourceFile, ctr, statements) {
-          this.replaceNode(sourceFile, ctr.body, factory.createBlock(
-            statements,
-            /*multiLine*/
-            true
-          ));
+        /** @internal */
+        stopWatchingWildCards(canonicalConfigFilePath, forProject) {
+          const configFileExistenceInfo = this.configFileExistenceInfoCache.get(canonicalConfigFilePath);
+          if (!configFileExistenceInfo.config || !configFileExistenceInfo.config.projects.get(forProject.canonicalConfigFilePath)) {
+            return;
+          }
+          configFileExistenceInfo.config.projects.set(forProject.canonicalConfigFilePath, false);
+          if (forEachEntry(configFileExistenceInfo.config.projects, identity))
+            return;
+          if (configFileExistenceInfo.config.watchedDirectories) {
+            clearMap(configFileExistenceInfo.config.watchedDirectories, closeFileWatcherOf);
+            configFileExistenceInfo.config.watchedDirectories = void 0;
+          }
+          configFileExistenceInfo.config.watchedDirectoriesStale = void 0;
+        }
+        updateNonInferredProjectFiles(project, files, propertyReader) {
+          const projectRootFilesMap = project.getRootFilesMap();
+          const newRootScriptInfoMap = /* @__PURE__ */ new Map();
+          for (const f of files) {
+            const newRootFile = propertyReader.getFileName(f);
+            const fileName = toNormalizedPath(newRootFile);
+            const isDynamic = isDynamicFileName(fileName);
+            let path;
+            if (!isDynamic && !project.fileExists(newRootFile)) {
+              path = normalizedPathToPath(fileName, this.currentDirectory, this.toCanonicalFileName);
+              const existingValue = projectRootFilesMap.get(path);
+              if (existingValue) {
+                if (existingValue.info) {
+                  project.removeFile(
+                    existingValue.info,
+                    /*fileExists*/
+                    false,
+                    /*detachFromProject*/
+                    true
+                  );
+                  existingValue.info = void 0;
+                }
+                existingValue.fileName = fileName;
+              } else {
+                projectRootFilesMap.set(path, { fileName });
+              }
+            } else {
+              const scriptKind = propertyReader.getScriptKind(f, this.hostConfiguration.extraFileExtensions);
+              const hasMixedContent = propertyReader.hasMixedContent(f, this.hostConfiguration.extraFileExtensions);
+              const scriptInfo = Debug.checkDefined(this.getOrCreateScriptInfoNotOpenedByClientForNormalizedPath(
+                fileName,
+                project.currentDirectory,
+                scriptKind,
+                hasMixedContent,
+                project.directoryStructureHost
+              ));
+              path = scriptInfo.path;
+              const existingValue = projectRootFilesMap.get(path);
+              if (!existingValue || existingValue.info !== scriptInfo) {
+                project.addRoot(scriptInfo, fileName);
+                if (scriptInfo.isScriptOpen()) {
+                  this.removeRootOfInferredProjectIfNowPartOfOtherProject(scriptInfo);
+                }
+              } else {
+                existingValue.fileName = fileName;
+              }
+            }
+            newRootScriptInfoMap.set(path, true);
+          }
+          if (projectRootFilesMap.size > newRootScriptInfoMap.size) {
+            projectRootFilesMap.forEach((value, path) => {
+              if (!newRootScriptInfoMap.has(path)) {
+                if (value.info) {
+                  project.removeFile(
+                    value.info,
+                    project.fileExists(path),
+                    /*detachFromProject*/
+                    true
+                  );
+                } else {
+                  projectRootFilesMap.delete(path);
+                }
+              }
+            });
+          }
         }
-        insertNodeAtEndOfScope(sourceFile, scope, newNode) {
-          const pos = getAdjustedStartPosition(sourceFile, scope.getLastToken(), {});
-          this.insertNodeAt(sourceFile, pos, newNode, {
-            prefix: isLineBreak(sourceFile.text.charCodeAt(scope.getLastToken().pos)) ? this.newLineCharacter : this.newLineCharacter + this.newLineCharacter,
-            suffix: this.newLineCharacter
-          });
+        updateRootAndOptionsOfNonInferredProject(project, newUncheckedFiles, propertyReader, newOptions, newTypeAcquisition, compileOnSave, watchOptions) {
+          project.setCompilerOptions(newOptions);
+          project.setWatchOptions(watchOptions);
+          if (compileOnSave !== void 0) {
+            project.compileOnSaveEnabled = compileOnSave;
+          }
+          this.addFilesToNonInferredProject(project, newUncheckedFiles, propertyReader, newTypeAcquisition);
         }
-        insertMemberAtStart(sourceFile, node, newElement) {
-          this.insertNodeAtStartWorker(sourceFile, node, newElement);
+        /**
+         * Reload the file names from config file specs and update the project graph
+         *
+         * @internal
+         */
+        reloadFileNamesOfConfiguredProject(project) {
+          const fileNames = this.reloadFileNamesOfParsedConfig(project.getConfigFilePath(), this.configFileExistenceInfoCache.get(project.canonicalConfigFilePath).config);
+          project.updateErrorOnNoInputFiles(fileNames);
+          this.updateNonInferredProjectFiles(project, fileNames.concat(project.getExternalFiles(1 /* RootNamesAndUpdate */)), fileNamePropertyReader);
+          project.markAsDirty();
+          return project.updateGraph();
         }
-        insertNodeAtObjectStart(sourceFile, obj, newElement) {
-          this.insertNodeAtStartWorker(sourceFile, obj, newElement);
+        /** @internal */
+        reloadFileNamesOfParsedConfig(configFileName, config) {
+          if (config.updateLevel === void 0)
+            return config.parsedCommandLine.fileNames;
+          Debug.assert(config.updateLevel === 1 /* RootNamesAndUpdate */);
+          const configFileSpecs = config.parsedCommandLine.options.configFile.configFileSpecs;
+          const fileNames = getFileNamesFromConfigSpecs(
+            configFileSpecs,
+            getDirectoryPath(configFileName),
+            config.parsedCommandLine.options,
+            config.cachedDirectoryStructureHost,
+            this.hostConfiguration.extraFileExtensions
+          );
+          config.parsedCommandLine = { ...config.parsedCommandLine, fileNames };
+          return fileNames;
         }
-        insertNodeAtStartWorker(sourceFile, node, newElement) {
-          const indentation = this.guessIndentationFromExistingMembers(sourceFile, node) ?? this.computeIndentationForNewMember(sourceFile, node);
-          this.insertNodeAt(sourceFile, getMembersOrProperties(node).pos, newElement, this.getInsertNodeAtStartInsertOptions(sourceFile, node, indentation));
+        /** @internal */
+        setFileNamesOfAutpImportProviderOrAuxillaryProject(project, fileNames) {
+          this.updateNonInferredProjectFiles(project, fileNames, fileNamePropertyReader);
         }
         /**
-         * Tries to guess the indentation from the existing members of a class/interface/object. All members must be on
-         * new lines and must share the same indentation.
+         * Read the config file of the project again by clearing the cache and update the project graph
+         *
+         * @internal
          */
-        guessIndentationFromExistingMembers(sourceFile, node) {
-          let indentation;
-          let lastRange = node;
-          for (const member of getMembersOrProperties(node)) {
-            if (rangeStartPositionsAreOnSameLine(lastRange, member, sourceFile)) {
-              return void 0;
+        reloadConfiguredProject(project, reason, isInitialLoad, clearSemanticCache) {
+          const host = project.getCachedDirectoryStructureHost();
+          if (clearSemanticCache)
+            this.clearSemanticCache(project);
+          host.clearCache();
+          const configFileName = project.getConfigFilePath();
+          this.logger.info(`${isInitialLoad ? "Loading" : "Reloading"} configured project ${configFileName}`);
+          this.loadConfiguredProject(project, reason);
+          project.updateGraph();
+          this.sendConfigFileDiagEvent(project, configFileName);
+        }
+        /** @internal */
+        clearSemanticCache(project) {
+          project.resolutionCache.clear();
+          project.getLanguageService(
+            /*ensureSynchronized*/
+            false
+          ).cleanupSemanticCache();
+          project.cleanupProgram();
+          project.markAsDirty();
+        }
+        sendConfigFileDiagEvent(project, triggerFile) {
+          if (!this.eventHandler || this.suppressDiagnosticEvents) {
+            return;
+          }
+          const diagnostics = project.getLanguageService().getCompilerOptionsDiagnostics();
+          diagnostics.push(...project.getAllProjectErrors());
+          this.eventHandler(
+            {
+              eventName: ConfigFileDiagEvent,
+              data: { configFileName: project.getConfigFilePath(), diagnostics, triggerFile }
             }
-            const memberStart = member.getStart(sourceFile);
-            const memberIndentation = ts_formatting_exports.SmartIndenter.findFirstNonWhitespaceColumn(getLineStartPositionForPosition(memberStart, sourceFile), memberStart, sourceFile, this.formatContext.options);
-            if (indentation === void 0) {
-              indentation = memberIndentation;
-            } else if (memberIndentation !== indentation) {
-              return void 0;
+          );
+        }
+        getOrCreateInferredProjectForProjectRootPathIfEnabled(info, projectRootPath) {
+          if (!this.useInferredProjectPerProjectRoot || // Its a dynamic info opened without project root
+          info.isDynamic && projectRootPath === void 0) {
+            return void 0;
+          }
+          if (projectRootPath) {
+            const canonicalProjectRootPath = this.toCanonicalFileName(projectRootPath);
+            for (const project of this.inferredProjects) {
+              if (project.projectRootPath === canonicalProjectRootPath) {
+                return project;
+              }
             }
-            lastRange = member;
+            return this.createInferredProject(
+              projectRootPath,
+              /*isSingleInferredProject*/
+              false,
+              projectRootPath
+            );
           }
-          return indentation;
+          let bestMatch;
+          for (const project of this.inferredProjects) {
+            if (!project.projectRootPath)
+              continue;
+            if (!containsPath(project.projectRootPath, info.path, this.host.getCurrentDirectory(), !this.host.useCaseSensitiveFileNames))
+              continue;
+            if (bestMatch && bestMatch.projectRootPath.length > project.projectRootPath.length)
+              continue;
+            bestMatch = project;
+          }
+          return bestMatch;
         }
-        computeIndentationForNewMember(sourceFile, node) {
-          const nodeStart = node.getStart(sourceFile);
-          return ts_formatting_exports.SmartIndenter.findFirstNonWhitespaceColumn(getLineStartPositionForPosition(nodeStart, sourceFile), nodeStart, sourceFile, this.formatContext.options) + (this.formatContext.options.indentSize ?? 4);
+        getOrCreateSingleInferredProjectIfEnabled() {
+          if (!this.useSingleInferredProject) {
+            return void 0;
+          }
+          if (this.inferredProjects.length > 0 && this.inferredProjects[0].projectRootPath === void 0) {
+            return this.inferredProjects[0];
+          }
+          return this.createInferredProject(
+            "",
+            /*isSingleInferredProject*/
+            true
+          );
         }
-        getInsertNodeAtStartInsertOptions(sourceFile, node, indentation) {
-          const members = getMembersOrProperties(node);
-          const isEmpty = members.length === 0;
-          const isFirstInsertion = addToSeen(this.classesWithNodesInsertedAtStart, getNodeId(node), { node, sourceFile });
-          const insertTrailingComma = isObjectLiteralExpression(node) && (!isJsonSourceFile(sourceFile) || !isEmpty);
-          const insertLeadingComma = isObjectLiteralExpression(node) && isJsonSourceFile(sourceFile) && isEmpty && !isFirstInsertion;
-          return {
-            indentation,
-            prefix: (insertLeadingComma ? "," : "") + this.newLineCharacter,
-            suffix: insertTrailingComma ? "," : isInterfaceDeclaration(node) && isEmpty ? ";" : ""
-          };
+        getOrCreateSingleInferredWithoutProjectRoot(currentDirectory) {
+          Debug.assert(!this.useSingleInferredProject);
+          const expectedCurrentDirectory = this.toCanonicalFileName(this.getNormalizedAbsolutePath(currentDirectory));
+          for (const inferredProject of this.inferredProjects) {
+            if (!inferredProject.projectRootPath && inferredProject.isOrphan() && inferredProject.canonicalCurrentDirectory === expectedCurrentDirectory) {
+              return inferredProject;
+            }
+          }
+          return this.createInferredProject(currentDirectory);
         }
-        insertNodeAfterComma(sourceFile, after, newNode) {
-          const endPosition = this.insertNodeAfterWorker(sourceFile, this.nextCommaToken(sourceFile, after) || after, newNode);
-          this.insertNodeAt(sourceFile, endPosition, newNode, this.getInsertNodeAfterOptions(sourceFile, after));
+        createInferredProject(currentDirectory, isSingleInferredProject, projectRootPath) {
+          const compilerOptions = projectRootPath && this.compilerOptionsForInferredProjectsPerProjectRoot.get(projectRootPath) || this.compilerOptionsForInferredProjects;
+          let watchOptionsAndErrors;
+          let typeAcquisition;
+          if (projectRootPath) {
+            watchOptionsAndErrors = this.watchOptionsForInferredProjectsPerProjectRoot.get(projectRootPath);
+            typeAcquisition = this.typeAcquisitionForInferredProjectsPerProjectRoot.get(projectRootPath);
+          }
+          if (watchOptionsAndErrors === void 0) {
+            watchOptionsAndErrors = this.watchOptionsForInferredProjects;
+          }
+          if (typeAcquisition === void 0) {
+            typeAcquisition = this.typeAcquisitionForInferredProjects;
+          }
+          watchOptionsAndErrors = watchOptionsAndErrors || void 0;
+          const project = new InferredProject2(this, this.documentRegistry, compilerOptions, watchOptionsAndErrors == null ? void 0 : watchOptionsAndErrors.watchOptions, projectRootPath, currentDirectory, typeAcquisition);
+          project.setProjectErrors(watchOptionsAndErrors == null ? void 0 : watchOptionsAndErrors.errors);
+          if (isSingleInferredProject) {
+            this.inferredProjects.unshift(project);
+          } else {
+            this.inferredProjects.push(project);
+          }
+          return project;
         }
-        insertNodeAfter(sourceFile, after, newNode) {
-          const endPosition = this.insertNodeAfterWorker(sourceFile, after, newNode);
-          this.insertNodeAt(sourceFile, endPosition, newNode, this.getInsertNodeAfterOptions(sourceFile, after));
+        /** @internal */
+        getOrCreateScriptInfoNotOpenedByClient(uncheckedFileName, currentDirectory, hostToQueryFileExistsOn) {
+          return this.getOrCreateScriptInfoNotOpenedByClientForNormalizedPath(
+            toNormalizedPath(uncheckedFileName),
+            currentDirectory,
+            /*scriptKind*/
+            void 0,
+            /*hasMixedContent*/
+            void 0,
+            hostToQueryFileExistsOn
+          );
         }
-        insertNodeAtEndOfList(sourceFile, list, newNode) {
-          this.insertNodeAt(sourceFile, list.end, newNode, { prefix: ", " });
+        getScriptInfo(uncheckedFileName) {
+          return this.getScriptInfoForNormalizedPath(toNormalizedPath(uncheckedFileName));
         }
-        insertNodesAfter(sourceFile, after, newNodes) {
-          const endPosition = this.insertNodeAfterWorker(sourceFile, after, first(newNodes));
-          this.insertNodesAt(sourceFile, endPosition, newNodes, this.getInsertNodeAfterOptions(sourceFile, after));
+        /** @internal */
+        getScriptInfoOrConfig(uncheckedFileName) {
+          const path = toNormalizedPath(uncheckedFileName);
+          const info = this.getScriptInfoForNormalizedPath(path);
+          if (info)
+            return info;
+          const configProject = this.configuredProjects.get(this.toPath(uncheckedFileName));
+          return configProject && configProject.getCompilerOptions().configFile;
         }
-        insertNodeAfterWorker(sourceFile, after, newNode) {
-          if (needSemicolonBetween(after, newNode)) {
-            if (sourceFile.text.charCodeAt(after.end - 1) !== 59 /* semicolon */) {
-              this.replaceRange(sourceFile, createRange(after.end), factory.createToken(27 /* SemicolonToken */));
+        /** @internal */
+        logErrorForScriptInfoNotFound(fileName) {
+          const names = arrayFrom(this.filenameToScriptInfo.entries(), ([path, scriptInfo]) => ({ path, fileName: scriptInfo.fileName }));
+          this.logger.msg(`Could not find file ${JSON.stringify(fileName)}.
+All files are: ${JSON.stringify(names)}`, "Err" /* Err */);
+        }
+        /**
+         * Returns the projects that contain script info through SymLink
+         * Note that this does not return projects in info.containingProjects
+         *
+         * @internal
+         */
+        getSymlinkedProjects(info) {
+          let projects;
+          if (this.realpathToScriptInfos) {
+            const realpath = info.getRealpathIfDifferent();
+            if (realpath) {
+              forEach(this.realpathToScriptInfos.get(realpath), combineProjects);
+            }
+            forEach(this.realpathToScriptInfos.get(info.path), combineProjects);
+          }
+          return projects;
+          function combineProjects(toAddInfo) {
+            if (toAddInfo !== info) {
+              for (const project of toAddInfo.containingProjects) {
+                if (project.languageServiceEnabled && !project.isOrphan() && !project.getCompilerOptions().preserveSymlinks && !info.isAttached(project)) {
+                  if (!projects) {
+                    projects = createMultiMap();
+                    projects.add(toAddInfo.path, project);
+                  } else if (!forEachEntry(projects, (projs, path) => path === toAddInfo.path ? false : contains(projs, project))) {
+                    projects.add(toAddInfo.path, project);
+                  }
+                }
+              }
             }
           }
-          const endPosition = getAdjustedEndPosition(sourceFile, after, {});
-          return endPosition;
         }
-        getInsertNodeAfterOptions(sourceFile, after) {
-          const options = this.getInsertNodeAfterOptionsWorker(after);
+        watchClosedScriptInfo(info) {
+          Debug.assert(!info.fileWatcher);
+          if (!info.isDynamicOrHasMixedContent() && (!this.globalCacheLocationDirectoryPath || !startsWith(info.path, this.globalCacheLocationDirectoryPath))) {
+            const indexOfNodeModules = info.path.indexOf("/node_modules/");
+            if (!this.host.getModifiedTime || indexOfNodeModules === -1) {
+              info.fileWatcher = this.watchFactory.watchFile(
+                info.fileName,
+                (_fileName, eventKind) => this.onSourceFileChanged(info, eventKind),
+                500 /* Medium */,
+                this.hostConfiguration.watchOptions,
+                WatchType.ClosedScriptInfo
+              );
+            } else {
+              info.mTime = this.getModifiedTime(info);
+              info.fileWatcher = this.watchClosedScriptInfoInNodeModules(info.path.substr(0, indexOfNodeModules));
+            }
+          }
+        }
+        createNodeModulesWatcher(dir) {
+          const watcher = this.watchFactory.watchDirectory(
+            dir,
+            (fileOrDirectory) => {
+              var _a;
+              const fileOrDirectoryPath = removeIgnoredPath(this.toPath(fileOrDirectory));
+              if (!fileOrDirectoryPath)
+                return;
+              const basename = getBaseFileName(fileOrDirectoryPath);
+              if (((_a = result.affectedModuleSpecifierCacheProjects) == null ? void 0 : _a.size) && (basename === "package.json" || basename === "node_modules")) {
+                result.affectedModuleSpecifierCacheProjects.forEach((projectName) => {
+                  var _a2, _b;
+                  (_b = (_a2 = this.findProject(projectName)) == null ? void 0 : _a2.getModuleSpecifierCache()) == null ? void 0 : _b.clear();
+                });
+              }
+              if (result.refreshScriptInfoRefCount) {
+                if (dir === fileOrDirectoryPath) {
+                  this.refreshScriptInfosInDirectory(dir);
+                } else {
+                  const info = this.getScriptInfoForPath(fileOrDirectoryPath);
+                  if (info) {
+                    if (isScriptInfoWatchedFromNodeModules(info)) {
+                      this.refreshScriptInfo(info);
+                    }
+                  } else if (!hasExtension(fileOrDirectoryPath)) {
+                    this.refreshScriptInfosInDirectory(fileOrDirectoryPath);
+                  }
+                }
+              }
+            },
+            1 /* Recursive */,
+            this.hostConfiguration.watchOptions,
+            WatchType.NodeModules
+          );
+          const result = {
+            refreshScriptInfoRefCount: 0,
+            affectedModuleSpecifierCacheProjects: void 0,
+            close: () => {
+              var _a;
+              if (!result.refreshScriptInfoRefCount && !((_a = result.affectedModuleSpecifierCacheProjects) == null ? void 0 : _a.size)) {
+                watcher.close();
+                this.nodeModulesWatchers.delete(dir);
+              }
+            }
+          };
+          this.nodeModulesWatchers.set(dir, result);
+          return result;
+        }
+        /** @internal */
+        watchPackageJsonsInNodeModules(dir, project) {
+          const watcher = this.nodeModulesWatchers.get(dir) || this.createNodeModulesWatcher(dir);
+          (watcher.affectedModuleSpecifierCacheProjects || (watcher.affectedModuleSpecifierCacheProjects = /* @__PURE__ */ new Set())).add(project.getProjectName());
           return {
-            ...options,
-            prefix: after.end === sourceFile.end && isStatement(after) ? options.prefix ? `
-${options.prefix}` : "\n" : options.prefix
+            close: () => {
+              var _a;
+              (_a = watcher.affectedModuleSpecifierCacheProjects) == null ? void 0 : _a.delete(project.getProjectName());
+              watcher.close();
+            }
           };
         }
-        getInsertNodeAfterOptionsWorker(node) {
-          switch (node.kind) {
-            case 262 /* ClassDeclaration */:
-            case 266 /* ModuleDeclaration */:
-              return { prefix: this.newLineCharacter, suffix: this.newLineCharacter };
-            case 259 /* VariableDeclaration */:
-            case 11 /* StringLiteral */:
-            case 80 /* Identifier */:
-              return { prefix: ", " };
-            case 302 /* PropertyAssignment */:
-              return { suffix: "," + this.newLineCharacter };
-            case 95 /* ExportKeyword */:
-              return { prefix: " " };
-            case 168 /* Parameter */:
-              return {};
-            default:
-              Debug.assert(isStatement(node) || isClassOrTypeElement(node));
-              return { suffix: this.newLineCharacter };
+        watchClosedScriptInfoInNodeModules(dir) {
+          const watchDir = dir + "/node_modules";
+          const watcher = this.nodeModulesWatchers.get(watchDir) || this.createNodeModulesWatcher(watchDir);
+          watcher.refreshScriptInfoRefCount++;
+          return {
+            close: () => {
+              watcher.refreshScriptInfoRefCount--;
+              watcher.close();
+            }
+          };
+        }
+        getModifiedTime(info) {
+          return (this.host.getModifiedTime(info.path) || missingFileModifiedTime).getTime();
+        }
+        refreshScriptInfo(info) {
+          const mTime = this.getModifiedTime(info);
+          if (mTime !== info.mTime) {
+            const eventKind = getFileWatcherEventKind(info.mTime, mTime);
+            info.mTime = mTime;
+            this.onSourceFileChanged(info, eventKind);
           }
         }
-        insertName(sourceFile, node, name) {
-          Debug.assert(!node.name);
-          if (node.kind === 218 /* ArrowFunction */) {
-            const arrow = findChildOfKind(node, 39 /* EqualsGreaterThanToken */, sourceFile);
-            const lparen = findChildOfKind(node, 21 /* OpenParenToken */, sourceFile);
-            if (lparen) {
-              this.insertNodesAt(sourceFile, lparen.getStart(sourceFile), [factory.createToken(100 /* FunctionKeyword */), factory.createIdentifier(name)], { joiner: " " });
-              deleteNode(this, sourceFile, arrow);
-            } else {
-              this.insertText(sourceFile, first(node.parameters).getStart(sourceFile), `function ${name}(`);
-              this.replaceRange(sourceFile, arrow, factory.createToken(22 /* CloseParenToken */));
-            }
-            if (node.body.kind !== 240 /* Block */) {
-              this.insertNodesAt(sourceFile, node.body.getStart(sourceFile), [factory.createToken(19 /* OpenBraceToken */), factory.createToken(107 /* ReturnKeyword */)], { joiner: " ", suffix: " " });
-              this.insertNodesAt(sourceFile, node.body.end, [factory.createToken(27 /* SemicolonToken */), factory.createToken(20 /* CloseBraceToken */)], { joiner: " " });
+        refreshScriptInfosInDirectory(dir) {
+          dir = dir + directorySeparator;
+          this.filenameToScriptInfo.forEach((info) => {
+            if (isScriptInfoWatchedFromNodeModules(info) && startsWith(info.path, dir)) {
+              this.refreshScriptInfo(info);
             }
-          } else {
-            const pos = findChildOfKind(node, node.kind === 217 /* FunctionExpression */ ? 100 /* FunctionKeyword */ : 86 /* ClassKeyword */, sourceFile).end;
-            this.insertNodeAt(sourceFile, pos, factory.createIdentifier(name), { prefix: " " });
-          }
+          });
         }
-        insertExportModifier(sourceFile, node) {
-          this.insertText(sourceFile, node.getStart(sourceFile), "export ");
+        stopWatchingScriptInfo(info) {
+          if (info.fileWatcher) {
+            info.fileWatcher.close();
+            info.fileWatcher = void 0;
+          }
         }
-        insertImportSpecifierAtIndex(sourceFile, importSpecifier, namedImports, index) {
-          const prevSpecifier = namedImports.elements[index - 1];
-          if (prevSpecifier) {
-            this.insertNodeInListAfter(sourceFile, prevSpecifier, importSpecifier);
-          } else {
-            this.insertNodeBefore(
-              sourceFile,
-              namedImports.elements[0],
-              importSpecifier,
-              !positionsAreOnSameLine(namedImports.elements[0].getStart(), namedImports.parent.parent.getStart(), sourceFile)
+        getOrCreateScriptInfoNotOpenedByClientForNormalizedPath(fileName, currentDirectory, scriptKind, hasMixedContent, hostToQueryFileExistsOn) {
+          if (isRootedDiskPath(fileName) || isDynamicFileName(fileName)) {
+            return this.getOrCreateScriptInfoWorker(
+              fileName,
+              currentDirectory,
+              /*openedByClient*/
+              false,
+              /*fileContent*/
+              void 0,
+              scriptKind,
+              hasMixedContent,
+              hostToQueryFileExistsOn
             );
           }
+          const info = this.openFilesWithNonRootedDiskPath.get(this.toCanonicalFileName(fileName));
+          if (info) {
+            return info;
+          }
+          return void 0;
+        }
+        getOrCreateScriptInfoOpenedByClientForNormalizedPath(fileName, currentDirectory, fileContent, scriptKind, hasMixedContent) {
+          return this.getOrCreateScriptInfoWorker(
+            fileName,
+            currentDirectory,
+            /*openedByClient*/
+            true,
+            fileContent,
+            scriptKind,
+            hasMixedContent
+          );
+        }
+        getOrCreateScriptInfoForNormalizedPath(fileName, openedByClient, fileContent, scriptKind, hasMixedContent, hostToQueryFileExistsOn) {
+          return this.getOrCreateScriptInfoWorker(fileName, this.currentDirectory, openedByClient, fileContent, scriptKind, hasMixedContent, hostToQueryFileExistsOn);
+        }
+        getOrCreateScriptInfoWorker(fileName, currentDirectory, openedByClient, fileContent, scriptKind, hasMixedContent, hostToQueryFileExistsOn) {
+          Debug.assert(fileContent === void 0 || openedByClient, "ScriptInfo needs to be opened by client to be able to set its user defined content");
+          const path = normalizedPathToPath(fileName, currentDirectory, this.toCanonicalFileName);
+          let info = this.getScriptInfoForPath(path);
+          if (!info) {
+            const isDynamic = isDynamicFileName(fileName);
+            Debug.assert(isRootedDiskPath(fileName) || isDynamic || openedByClient, "", () => `${JSON.stringify({ fileName, currentDirectory, hostCurrentDirectory: this.currentDirectory, openKeys: arrayFrom(this.openFilesWithNonRootedDiskPath.keys()) })}
+Script info with non-dynamic relative file name can only be open script info or in context of host currentDirectory`);
+            Debug.assert(!isRootedDiskPath(fileName) || this.currentDirectory === currentDirectory || !this.openFilesWithNonRootedDiskPath.has(this.toCanonicalFileName(fileName)), "", () => `${JSON.stringify({ fileName, currentDirectory, hostCurrentDirectory: this.currentDirectory, openKeys: arrayFrom(this.openFilesWithNonRootedDiskPath.keys()) })}
+Open script files with non rooted disk path opened with current directory context cannot have same canonical names`);
+            Debug.assert(!isDynamic || this.currentDirectory === currentDirectory || this.useInferredProjectPerProjectRoot, "", () => `${JSON.stringify({ fileName, currentDirectory, hostCurrentDirectory: this.currentDirectory, openKeys: arrayFrom(this.openFilesWithNonRootedDiskPath.keys()) })}
+Dynamic files must always be opened with service's current directory or service should support inferred project per projectRootPath.`);
+            if (!openedByClient && !isDynamic && !(hostToQueryFileExistsOn || this.host).fileExists(fileName)) {
+              return;
+            }
+            info = new ScriptInfo(this.host, fileName, scriptKind, !!hasMixedContent, path, this.filenameToScriptInfoVersion.get(path));
+            this.filenameToScriptInfo.set(info.path, info);
+            this.filenameToScriptInfoVersion.delete(info.path);
+            if (!openedByClient) {
+              this.watchClosedScriptInfo(info);
+            } else if (!isRootedDiskPath(fileName) && (!isDynamic || this.currentDirectory !== currentDirectory)) {
+              this.openFilesWithNonRootedDiskPath.set(this.toCanonicalFileName(fileName), info);
+            }
+          }
+          if (openedByClient) {
+            this.stopWatchingScriptInfo(info);
+            info.open(fileContent);
+            if (hasMixedContent) {
+              info.registerFileUpdate();
+            }
+          }
+          return info;
         }
         /**
-         * This function should be used to insert nodes in lists when nodes don't carry separators as the part of the node range,
-         * i.e. arguments in arguments lists, parameters in parameter lists etc.
-         * Note that separators are part of the node in statements and class elements.
+         * This gets the script info for the normalized path. If the path is not rooted disk path then the open script info with project root context is preferred
          */
-        insertNodeInListAfter(sourceFile, after, newNode, containingList = ts_formatting_exports.SmartIndenter.getContainingList(after, sourceFile)) {
-          if (!containingList) {
-            Debug.fail("node is not a list element");
-            return;
+        getScriptInfoForNormalizedPath(fileName) {
+          return !isRootedDiskPath(fileName) && this.openFilesWithNonRootedDiskPath.get(this.toCanonicalFileName(fileName)) || this.getScriptInfoForPath(normalizedPathToPath(fileName, this.currentDirectory, this.toCanonicalFileName));
+        }
+        getScriptInfoForPath(fileName) {
+          return this.filenameToScriptInfo.get(fileName);
+        }
+        /** @internal */
+        getDocumentPositionMapper(project, generatedFileName, sourceFileName) {
+          const declarationInfo = this.getOrCreateScriptInfoNotOpenedByClient(generatedFileName, project.currentDirectory, this.host);
+          if (!declarationInfo) {
+            if (sourceFileName) {
+              project.addGeneratedFileWatch(generatedFileName, sourceFileName);
+            }
+            return void 0;
           }
-          const index = indexOfNode(containingList, after);
-          if (index < 0) {
-            return;
+          declarationInfo.getSnapshot();
+          if (isString(declarationInfo.sourceMapFilePath)) {
+            const sourceMapFileInfo2 = this.getScriptInfoForPath(declarationInfo.sourceMapFilePath);
+            if (sourceMapFileInfo2) {
+              sourceMapFileInfo2.getSnapshot();
+              if (sourceMapFileInfo2.documentPositionMapper !== void 0) {
+                sourceMapFileInfo2.sourceInfos = this.addSourceInfoToSourceMap(sourceFileName, project, sourceMapFileInfo2.sourceInfos);
+                return sourceMapFileInfo2.documentPositionMapper ? sourceMapFileInfo2.documentPositionMapper : void 0;
+              }
+            }
+            declarationInfo.sourceMapFilePath = void 0;
+          } else if (declarationInfo.sourceMapFilePath) {
+            declarationInfo.sourceMapFilePath.sourceInfos = this.addSourceInfoToSourceMap(sourceFileName, project, declarationInfo.sourceMapFilePath.sourceInfos);
+            return void 0;
+          } else if (declarationInfo.sourceMapFilePath !== void 0) {
+            return void 0;
           }
-          const end = after.getEnd();
-          if (index !== containingList.length - 1) {
-            const nextToken = getTokenAtPosition(sourceFile, after.end);
-            if (nextToken && isSeparator(after, nextToken)) {
-              const nextNode = containingList[index + 1];
-              const startPos = skipWhitespacesAndLineBreaks(sourceFile.text, nextNode.getFullStart());
-              const suffix = `${tokenToString(nextToken.kind)}${sourceFile.text.substring(nextToken.end, startPos)}`;
-              this.insertNodesAt(sourceFile, startPos, [newNode], { suffix });
+          let sourceMapFileInfo;
+          let mapFileNameFromDeclarationInfo;
+          let readMapFile = (mapFileName, mapFileNameFromDts) => {
+            const mapInfo = this.getOrCreateScriptInfoNotOpenedByClient(mapFileName, project.currentDirectory, this.host);
+            if (!mapInfo) {
+              mapFileNameFromDeclarationInfo = mapFileNameFromDts;
+              return void 0;
             }
+            sourceMapFileInfo = mapInfo;
+            const snap = mapInfo.getSnapshot();
+            if (mapInfo.documentPositionMapper !== void 0)
+              return mapInfo.documentPositionMapper;
+            return getSnapshotText(snap);
+          };
+          const projectName = project.projectName;
+          const documentPositionMapper = getDocumentPositionMapper(
+            { getCanonicalFileName: this.toCanonicalFileName, log: (s) => this.logger.info(s), getSourceFileLike: (f) => this.getSourceFileLike(f, projectName, declarationInfo) },
+            declarationInfo.fileName,
+            declarationInfo.textStorage.getLineInfo(),
+            readMapFile
+          );
+          readMapFile = void 0;
+          if (sourceMapFileInfo) {
+            declarationInfo.sourceMapFilePath = sourceMapFileInfo.path;
+            sourceMapFileInfo.declarationInfoPath = declarationInfo.path;
+            sourceMapFileInfo.documentPositionMapper = documentPositionMapper || false;
+            sourceMapFileInfo.sourceInfos = this.addSourceInfoToSourceMap(sourceFileName, project, sourceMapFileInfo.sourceInfos);
+          } else if (mapFileNameFromDeclarationInfo) {
+            declarationInfo.sourceMapFilePath = {
+              watcher: this.addMissingSourceMapFile(
+                project.currentDirectory === this.currentDirectory ? mapFileNameFromDeclarationInfo : getNormalizedAbsolutePath(mapFileNameFromDeclarationInfo, project.currentDirectory),
+                declarationInfo.path
+              ),
+              sourceInfos: this.addSourceInfoToSourceMap(sourceFileName, project)
+            };
           } else {
-            const afterStart = after.getStart(sourceFile);
-            const afterStartLinePosition = getLineStartPositionForPosition(afterStart, sourceFile);
-            let separator;
-            let multilineList = false;
-            if (containingList.length === 1) {
-              separator = 28 /* CommaToken */;
-            } else {
-              const tokenBeforeInsertPosition = findPrecedingToken(after.pos, sourceFile);
-              separator = isSeparator(after, tokenBeforeInsertPosition) ? tokenBeforeInsertPosition.kind : 28 /* CommaToken */;
-              const afterMinusOneStartLinePosition = getLineStartPositionForPosition(containingList[index - 1].getStart(sourceFile), sourceFile);
-              multilineList = afterMinusOneStartLinePosition !== afterStartLinePosition;
+            declarationInfo.sourceMapFilePath = false;
+          }
+          return documentPositionMapper;
+        }
+        addSourceInfoToSourceMap(sourceFileName, project, sourceInfos) {
+          if (sourceFileName) {
+            const sourceInfo = this.getOrCreateScriptInfoNotOpenedByClient(sourceFileName, project.currentDirectory, project.directoryStructureHost);
+            (sourceInfos || (sourceInfos = /* @__PURE__ */ new Set())).add(sourceInfo.path);
+          }
+          return sourceInfos;
+        }
+        addMissingSourceMapFile(mapFileName, declarationInfoPath) {
+          const fileWatcher = this.watchFactory.watchFile(
+            mapFileName,
+            () => {
+              const declarationInfo = this.getScriptInfoForPath(declarationInfoPath);
+              if (declarationInfo && declarationInfo.sourceMapFilePath && !isString(declarationInfo.sourceMapFilePath)) {
+                this.delayUpdateProjectGraphs(
+                  declarationInfo.containingProjects,
+                  /*clearSourceMapperCache*/
+                  true
+                );
+                this.delayUpdateSourceInfoProjects(declarationInfo.sourceMapFilePath.sourceInfos);
+                declarationInfo.closeSourceMapFileWatcher();
+              }
+            },
+            2e3 /* High */,
+            this.hostConfiguration.watchOptions,
+            WatchType.MissingSourceMapFile
+          );
+          return fileWatcher;
+        }
+        /** @internal */
+        getSourceFileLike(fileName, projectNameOrProject, declarationInfo) {
+          const project = projectNameOrProject.projectName ? projectNameOrProject : this.findProject(projectNameOrProject);
+          if (project) {
+            const path = project.toPath(fileName);
+            const sourceFile = project.getSourceFile(path);
+            if (sourceFile && sourceFile.resolvedPath === path)
+              return sourceFile;
+          }
+          const info = this.getOrCreateScriptInfoNotOpenedByClient(fileName, (project || this).currentDirectory, project ? project.directoryStructureHost : this.host);
+          if (!info)
+            return void 0;
+          if (declarationInfo && isString(declarationInfo.sourceMapFilePath) && info !== declarationInfo) {
+            const sourceMapInfo = this.getScriptInfoForPath(declarationInfo.sourceMapFilePath);
+            if (sourceMapInfo) {
+              (sourceMapInfo.sourceInfos || (sourceMapInfo.sourceInfos = /* @__PURE__ */ new Set())).add(info.path);
+            }
+          }
+          if (info.cacheSourceFile)
+            return info.cacheSourceFile.sourceFile;
+          if (!info.sourceFileLike) {
+            info.sourceFileLike = {
+              get text() {
+                Debug.fail("shouldnt need text");
+                return "";
+              },
+              getLineAndCharacterOfPosition: (pos) => {
+                const lineOffset = info.positionToLineOffset(pos);
+                return { line: lineOffset.line - 1, character: lineOffset.offset - 1 };
+              },
+              getPositionOfLineAndCharacter: (line, character, allowEdits) => info.lineOffsetToPosition(line + 1, character + 1, allowEdits)
+            };
+          }
+          return info.sourceFileLike;
+        }
+        /** @internal */
+        setPerformanceEventHandler(performanceEventHandler) {
+          this.performanceEventHandler = performanceEventHandler;
+        }
+        setHostConfiguration(args) {
+          var _a, _b;
+          if (args.file) {
+            const info = this.getScriptInfoForNormalizedPath(toNormalizedPath(args.file));
+            if (info) {
+              info.setOptions(convertFormatOptions(args.formatOptions), args.preferences);
+              this.logger.info(`Host configuration update for file ${args.file}`);
             }
-            if (hasCommentsBeforeLineBreak(sourceFile.text, after.end)) {
-              multilineList = true;
+          } else {
+            if (args.hostInfo !== void 0) {
+              this.hostConfiguration.hostInfo = args.hostInfo;
+              this.logger.info(`Host information ${args.hostInfo}`);
+            }
+            if (args.formatOptions) {
+              this.hostConfiguration.formatCodeOptions = { ...this.hostConfiguration.formatCodeOptions, ...convertFormatOptions(args.formatOptions) };
+              this.logger.info("Format host information updated");
+            }
+            if (args.preferences) {
+              const {
+                lazyConfiguredProjectsFromExternalProject,
+                includePackageJsonAutoImports
+              } = this.hostConfiguration.preferences;
+              this.hostConfiguration.preferences = { ...this.hostConfiguration.preferences, ...args.preferences };
+              if (lazyConfiguredProjectsFromExternalProject && !this.hostConfiguration.preferences.lazyConfiguredProjectsFromExternalProject) {
+                this.configuredProjects.forEach((project) => {
+                  if (project.hasExternalProjectRef() && project.pendingUpdateLevel === 2 /* Full */ && !this.pendingProjectUpdates.has(project.getProjectName())) {
+                    project.updateGraph();
+                  }
+                });
+              }
+              if (includePackageJsonAutoImports !== args.preferences.includePackageJsonAutoImports) {
+                this.invalidateProjectPackageJson(
+                  /*packageJsonPath*/
+                  void 0
+                );
+              }
             }
-            if (multilineList) {
-              this.replaceRange(sourceFile, createRange(end), factory.createToken(separator));
-              const indentation = ts_formatting_exports.SmartIndenter.findFirstNonWhitespaceColumn(afterStartLinePosition, afterStart, sourceFile, this.formatContext.options);
-              let insertPos = skipTrivia(
-                sourceFile.text,
-                end,
-                /*stopAfterLineBreak*/
-                true,
-                /*stopAtComments*/
-                false
+            if (args.extraFileExtensions) {
+              this.hostConfiguration.extraFileExtensions = args.extraFileExtensions;
+              this.reloadProjects();
+              this.logger.info("Host file extension mappings updated");
+            }
+            if (args.watchOptions) {
+              this.hostConfiguration.watchOptions = (_a = convertWatchOptions(args.watchOptions)) == null ? void 0 : _a.watchOptions;
+              this.logger.info(`Host watch options changed to ${JSON.stringify(this.hostConfiguration.watchOptions)}, it will be take effect for next watches.`);
+              (_b = this.pnpWatcher) == null ? void 0 : _b.close();
+              this.watchPnpFile();
+            }
+          }
+        }
+        /** @internal */
+        getWatchOptions(project) {
+          return this.getWatchOptionsFromProjectWatchOptions(project.getWatchOptions());
+        }
+        /** @internal */
+        getWatchOptionsFromProjectWatchOptions(projectOptions) {
+          return projectOptions && this.hostConfiguration.watchOptions ? { ...this.hostConfiguration.watchOptions, ...projectOptions } : projectOptions || this.hostConfiguration.watchOptions;
+        }
+        closeLog() {
+          this.logger.close();
+        }
+        /**
+         * This function rebuilds the project for every file opened by the client
+         * This does not reload contents of open files from disk. But we could do that if needed
+         */
+        reloadProjects() {
+          this.logger.info("reload projects.");
+          this.filenameToScriptInfo.forEach((info) => {
+            if (this.openFiles.has(info.path))
+              return;
+            if (!info.fileWatcher)
+              return;
+            this.onSourceFileChanged(info, this.host.fileExists(info.fileName) ? 1 /* Changed */ : 2 /* Deleted */);
+          });
+          this.pendingProjectUpdates.forEach((_project, projectName) => {
+            this.throttledOperations.cancel(projectName);
+            this.pendingProjectUpdates.delete(projectName);
+          });
+          this.throttledOperations.cancel(ensureProjectForOpenFileSchedule);
+          this.pendingEnsureProjectForOpenFiles = false;
+          this.configFileExistenceInfoCache.forEach((info) => {
+            if (info.config)
+              info.config.updateLevel = 2 /* Full */;
+          });
+          this.reloadConfiguredProjectForFiles(
+            this.openFiles,
+            /*clearSemanticCache*/
+            true,
+            /*delayReload*/
+            false,
+            returnTrue,
+            "User requested reload projects"
+          );
+          this.externalProjects.forEach((project) => {
+            this.clearSemanticCache(project);
+            project.updateGraph();
+          });
+          this.inferredProjects.forEach((project) => this.clearSemanticCache(project));
+          this.ensureProjectForOpenFiles();
+        }
+        /**
+         * This function goes through all the openFiles and tries to file the config file for them.
+         * If the config file is found and it refers to existing project, it reloads it either immediately
+         * or schedules it for reload depending on delayReload option
+         * If there is no existing project it just opens the configured project for the config file
+         * reloadForInfo provides a way to filter out files to reload configured project for
+         */
+        reloadConfiguredProjectForFiles(openFiles, clearSemanticCache, delayReload, shouldReloadProjectFor, reason) {
+          const updatedProjects = /* @__PURE__ */ new Map();
+          const reloadChildProject = (child) => {
+            if (!updatedProjects.has(child.canonicalConfigFilePath)) {
+              updatedProjects.set(child.canonicalConfigFilePath, true);
+              this.reloadConfiguredProject(
+                child,
+                reason,
+                /*isInitialLoad*/
+                false,
+                clearSemanticCache
               );
-              while (insertPos !== end && isLineBreak(sourceFile.text.charCodeAt(insertPos - 1))) {
-                insertPos--;
+            }
+          };
+          openFiles == null ? void 0 : openFiles.forEach((openFileValue, path) => {
+            this.configFileForOpenFiles.delete(path);
+            if (!shouldReloadProjectFor(openFileValue)) {
+              return;
+            }
+            const info = this.getScriptInfoForPath(path);
+            Debug.assert(info.isScriptOpen());
+            const configFileName = this.getConfigFileNameForFile(info);
+            if (configFileName) {
+              const project = this.findConfiguredProjectByProjectName(configFileName) || this.createConfiguredProject(configFileName);
+              if (!updatedProjects.has(project.canonicalConfigFilePath)) {
+                updatedProjects.set(project.canonicalConfigFilePath, true);
+                if (delayReload) {
+                  project.pendingUpdateLevel = 2 /* Full */;
+                  project.pendingUpdateReason = reason;
+                  if (clearSemanticCache)
+                    this.clearSemanticCache(project);
+                  this.delayUpdateProjectGraph(project);
+                } else {
+                  this.reloadConfiguredProject(
+                    project,
+                    reason,
+                    /*isInitialLoad*/
+                    false,
+                    clearSemanticCache
+                  );
+                  if (!projectContainsInfoDirectly(project, info)) {
+                    const referencedProject = forEachResolvedProjectReferenceProject(
+                      project,
+                      info.path,
+                      (child) => {
+                        reloadChildProject(child);
+                        return projectContainsInfoDirectly(child, info);
+                      },
+                      1 /* FindCreate */
+                    );
+                    if (referencedProject) {
+                      forEachResolvedProjectReferenceProject(
+                        project,
+                        /*fileName*/
+                        void 0,
+                        reloadChildProject,
+                        0 /* Find */
+                      );
+                    }
+                  }
+                }
               }
-              this.replaceRange(sourceFile, createRange(insertPos), newNode, { indentation, prefix: this.newLineCharacter });
+            }
+          });
+        }
+        /**
+         * Remove the root of inferred project if script info is part of another project
+         */
+        removeRootOfInferredProjectIfNowPartOfOtherProject(info) {
+          Debug.assert(info.containingProjects.length > 0);
+          const firstProject = info.containingProjects[0];
+          if (!firstProject.isOrphan() && isInferredProject(firstProject) && firstProject.isRoot(info) && forEach(info.containingProjects, (p) => p !== firstProject && !p.isOrphan())) {
+            firstProject.removeFile(
+              info,
+              /*fileExists*/
+              true,
+              /*detachFromProject*/
+              true
+            );
+          }
+        }
+        /**
+         * This function is to update the project structure for every inferred project.
+         * It is called on the premise that all the configured projects are
+         * up to date.
+         * This will go through open files and assign them to inferred project if open file is not part of any other project
+         * After that all the inferred project graphs are updated
+         */
+        ensureProjectForOpenFiles() {
+          this.logger.info("Before ensureProjectForOpenFiles:");
+          this.printProjects();
+          this.openFiles.forEach((projectRootPath, path) => {
+            const info = this.getScriptInfoForPath(path);
+            if (info.isOrphan()) {
+              this.assignOrphanScriptInfoToInferredProject(info, projectRootPath);
             } else {
-              this.replaceRange(sourceFile, createRange(end), newNode, { prefix: `${tokenToString(separator)} ` });
+              this.removeRootOfInferredProjectIfNowPartOfOtherProject(info);
+            }
+          });
+          this.pendingEnsureProjectForOpenFiles = false;
+          this.inferredProjects.forEach(updateProjectIfDirty);
+          this.logger.info("After ensureProjectForOpenFiles:");
+          this.printProjects();
+        }
+        /**
+         * Open file whose contents is managed by the client
+         * @param filename is absolute pathname
+         * @param fileContent is a known version of the file content that is more up to date than the one on disk
+         */
+        openClientFile(fileName, fileContent, scriptKind, projectRootPath) {
+          return this.openClientFileWithNormalizedPath(
+            toNormalizedPath(fileName),
+            fileContent,
+            scriptKind,
+            /*hasMixedContent*/
+            false,
+            projectRootPath ? toNormalizedPath(projectRootPath) : void 0
+          );
+        }
+        /** @internal */
+        getOriginalLocationEnsuringConfiguredProject(project, location) {
+          const isSourceOfProjectReferenceRedirect = project.isSourceOfProjectReferenceRedirect(location.fileName);
+          const originalLocation = isSourceOfProjectReferenceRedirect ? location : project.getSourceMapper().tryGetSourcePosition(location);
+          if (!originalLocation)
+            return void 0;
+          const { fileName } = originalLocation;
+          const scriptInfo = this.getScriptInfo(fileName);
+          if (!scriptInfo && !this.host.fileExists(fileName))
+            return void 0;
+          const originalFileInfo = { fileName: toNormalizedPath(fileName), path: this.toPath(fileName) };
+          const configFileName = this.getConfigFileNameForFile(originalFileInfo);
+          if (!configFileName)
+            return void 0;
+          let configuredProject = this.findConfiguredProjectByProjectName(configFileName);
+          if (!configuredProject) {
+            if (project.getCompilerOptions().disableReferencedProjectLoad) {
+              if (isSourceOfProjectReferenceRedirect) {
+                return location;
+              }
+              return (scriptInfo == null ? void 0 : scriptInfo.containingProjects.length) ? originalLocation : location;
+            }
+            configuredProject = this.createAndLoadConfiguredProject(configFileName, `Creating project for original file: ${originalFileInfo.fileName}${location !== originalLocation ? " for location: " + location.fileName : ""}`);
+          }
+          updateProjectIfDirty(configuredProject);
+          const projectContainsOriginalInfo = (project2) => {
+            const info = this.getScriptInfo(fileName);
+            return info && projectContainsInfoDirectly(project2, info);
+          };
+          if (configuredProject.isSolution() || !projectContainsOriginalInfo(configuredProject)) {
+            configuredProject = forEachResolvedProjectReferenceProject(
+              configuredProject,
+              fileName,
+              (child) => {
+                updateProjectIfDirty(child);
+                return projectContainsOriginalInfo(child) ? child : void 0;
+              },
+              2 /* FindCreateLoad */,
+              `Creating project referenced in solution ${configuredProject.projectName} to find possible configured project for original file: ${originalFileInfo.fileName}${location !== originalLocation ? " for location: " + location.fileName : ""}`
+            );
+            if (!configuredProject)
+              return void 0;
+            if (configuredProject === project)
+              return originalLocation;
+          }
+          addOriginalConfiguredProject(configuredProject);
+          const originalScriptInfo = this.getScriptInfo(fileName);
+          if (!originalScriptInfo || !originalScriptInfo.containingProjects.length)
+            return void 0;
+          originalScriptInfo.containingProjects.forEach((project2) => {
+            if (isConfiguredProject(project2)) {
+              addOriginalConfiguredProject(project2);
+            }
+          });
+          return originalLocation;
+          function addOriginalConfiguredProject(originalProject) {
+            if (!project.originalConfiguredProjects) {
+              project.originalConfiguredProjects = /* @__PURE__ */ new Set();
             }
+            project.originalConfiguredProjects.add(originalProject.canonicalConfigFilePath);
           }
         }
-        parenthesizeExpression(sourceFile, expression) {
-          this.replaceRange(sourceFile, rangeOfNode(expression), factory.createParenthesizedExpression(expression));
+        /** @internal */
+        fileExists(fileName) {
+          return !!this.getScriptInfoForNormalizedPath(fileName) || this.host.fileExists(fileName);
         }
-        finishClassesWithNodesInsertedAtStart() {
-          this.classesWithNodesInsertedAtStart.forEach(({ node, sourceFile }) => {
-            const [openBraceEnd, closeBraceEnd] = getClassOrObjectBraceEnds(node, sourceFile);
-            if (openBraceEnd !== void 0 && closeBraceEnd !== void 0) {
-              const isEmpty = getMembersOrProperties(node).length === 0;
-              const isSingleLine = positionsAreOnSameLine(openBraceEnd, closeBraceEnd, sourceFile);
-              if (isEmpty && isSingleLine && openBraceEnd !== closeBraceEnd - 1) {
-                this.deleteRange(sourceFile, createRange(openBraceEnd, closeBraceEnd - 1));
-              }
-              if (isSingleLine) {
-                this.insertText(sourceFile, closeBraceEnd - 1, this.newLineCharacter);
-              }
-            }
+        findExternalProjectContainingOpenScriptInfo(info) {
+          return find(this.externalProjects, (proj) => {
+            updateProjectIfDirty(proj);
+            return proj.containsScriptInfo(info);
           });
         }
-        finishDeleteDeclarations() {
-          const deletedNodesInLists = /* @__PURE__ */ new Set();
-          for (const { sourceFile, node } of this.deletedNodes) {
-            if (!this.deletedNodes.some((d) => d.sourceFile === sourceFile && rangeContainsRangeExclusive(d.node, node))) {
-              if (isArray(node)) {
-                this.deleteRange(sourceFile, rangeOfTypeParameters(sourceFile, node));
+        getOrCreateOpenScriptInfo(fileName, fileContent, scriptKind, hasMixedContent, projectRootPath) {
+          const info = this.getOrCreateScriptInfoOpenedByClientForNormalizedPath(fileName, projectRootPath ? this.getNormalizedAbsolutePath(projectRootPath) : this.currentDirectory, fileContent, scriptKind, hasMixedContent);
+          this.openFiles.set(info.path, projectRootPath);
+          return info;
+        }
+        assignProjectToOpenedScriptInfo(info) {
+          let configFileName;
+          let configFileErrors;
+          let project = this.findExternalProjectContainingOpenScriptInfo(info);
+          let retainProjects;
+          let projectForConfigFileDiag;
+          let defaultConfigProjectIsCreated = false;
+          if (!project && this.serverMode === 0 /* Semantic */) {
+            configFileName = this.getConfigFileNameForFile(info);
+            if (configFileName) {
+              project = this.findConfiguredProjectByProjectName(configFileName);
+              if (!project) {
+                project = this.createLoadAndUpdateConfiguredProject(configFileName, `Creating possible configured project for ${info.fileName} to open`);
+                defaultConfigProjectIsCreated = true;
               } else {
-                deleteDeclaration.deleteDeclaration(this, deletedNodesInLists, sourceFile, node);
+                updateProjectIfDirty(project);
+              }
+              projectForConfigFileDiag = project.containsScriptInfo(info) ? project : void 0;
+              retainProjects = project;
+              if (!projectContainsInfoDirectly(project, info)) {
+                forEachResolvedProjectReferenceProject(
+                  project,
+                  info.path,
+                  (child) => {
+                    updateProjectIfDirty(child);
+                    if (!isArray(retainProjects)) {
+                      retainProjects = [project, child];
+                    } else {
+                      retainProjects.push(child);
+                    }
+                    if (projectContainsInfoDirectly(child, info)) {
+                      projectForConfigFileDiag = child;
+                      return child;
+                    }
+                    if (!projectForConfigFileDiag && child.containsScriptInfo(info)) {
+                      projectForConfigFileDiag = child;
+                    }
+                  },
+                  2 /* FindCreateLoad */,
+                  `Creating project referenced in solution ${project.projectName} to find possible configured project for ${info.fileName} to open`
+                );
+              }
+              if (projectForConfigFileDiag) {
+                configFileName = projectForConfigFileDiag.getConfigFilePath();
+                if (projectForConfigFileDiag !== project || defaultConfigProjectIsCreated) {
+                  configFileErrors = projectForConfigFileDiag.getAllProjectErrors();
+                  this.sendConfigFileDiagEvent(projectForConfigFileDiag, info.fileName);
+                }
+              } else {
+                configFileName = void 0;
               }
+              this.createAncestorProjects(info, project);
             }
           }
-          deletedNodesInLists.forEach((node) => {
-            const sourceFile = node.getSourceFile();
-            const list = ts_formatting_exports.SmartIndenter.getContainingList(node, sourceFile);
-            if (node !== last(list))
-              return;
-            const lastNonDeletedIndex = findLastIndex(list, (n) => !deletedNodesInLists.has(n), list.length - 2);
-            if (lastNonDeletedIndex !== -1) {
-              this.deleteRange(sourceFile, { pos: list[lastNonDeletedIndex].end, end: startPositionToDeleteNodeInList(sourceFile, list[lastNonDeletedIndex + 1]) });
+          info.containingProjects.forEach(updateProjectIfDirty);
+          if (info.isOrphan()) {
+            if (isArray(retainProjects)) {
+              retainProjects.forEach((project2) => this.sendConfigFileDiagEvent(project2, info.fileName));
+            } else if (retainProjects) {
+              this.sendConfigFileDiagEvent(retainProjects, info.fileName);
             }
-          });
-        }
-        /**
-         * Note: after calling this, the TextChanges object must be discarded!
-         * @param validate only for tests
-         *    The reason we must validate as part of this method is that `getNonFormattedText` changes the node's positions,
-         *    so we can only call this once and can't get the non-formatted text separately.
-         */
-        getChanges(validate) {
-          this.finishDeleteDeclarations();
-          this.finishClassesWithNodesInsertedAtStart();
-          const changes = changesToText.getTextChangesFromChanges(this.changes, this.newLineCharacter, this.formatContext, validate);
-          if (this.newFileChanges) {
-            this.newFileChanges.forEach((insertions, fileName) => {
-              changes.push(changesToText.newFileChanges(fileName, insertions, this.newLineCharacter, this.formatContext));
-            });
+            Debug.assert(this.openFiles.has(info.path));
+            this.assignOrphanScriptInfoToInferredProject(info, this.openFiles.get(info.path));
           }
-          return changes;
-        }
-        createNewFile(oldFile, fileName, statements) {
-          this.insertStatementsInNewFile(fileName, statements, oldFile);
+          Debug.assert(!info.isOrphan());
+          return { configFileName, configFileErrors, retainProjects };
         }
-      };
-      ((changesToText2) => {
-        function getTextChangesFromChanges(changes, newLineCharacter, formatContext, validate) {
-          return mapDefined(group(changes, (c) => c.sourceFile.path), (changesInFile) => {
-            const sourceFile = changesInFile[0].sourceFile;
-            const normalized = stableSort(changesInFile, (a, b) => a.range.pos - b.range.pos || a.range.end - b.range.end);
-            for (let i = 0; i < normalized.length - 1; i++) {
-              Debug.assert(normalized[i].range.end <= normalized[i + 1].range.pos, "Changes overlap", () => `${JSON.stringify(normalized[i].range)} and ${JSON.stringify(normalized[i + 1].range)}`);
-            }
-            const textChanges2 = mapDefined(normalized, (c) => {
-              const span = createTextSpanFromRange(c.range);
-              const targetSourceFile = c.kind === 1 /* ReplaceWithSingleNode */ ? getSourceFileOfNode(getOriginalNode(c.node)) ?? c.sourceFile : c.kind === 2 /* ReplaceWithMultipleNodes */ ? getSourceFileOfNode(getOriginalNode(c.nodes[0])) ?? c.sourceFile : c.sourceFile;
-              const newText = computeNewText(c, targetSourceFile, sourceFile, newLineCharacter, formatContext, validate);
-              if (span.length === newText.length && stringContainsAt(targetSourceFile.text, newText, span.start)) {
-                return void 0;
-              }
-              return createTextChange(span, newText);
+        createAncestorProjects(info, project) {
+          if (!info.isAttached(project))
+            return;
+          while (true) {
+            if (!project.isInitialLoadPending() && (!project.getCompilerOptions().composite || project.getCompilerOptions().disableSolutionSearching))
+              return;
+            const configFileName = this.getConfigFileNameForFile({
+              fileName: project.getConfigFilePath(),
+              path: info.path,
+              configFileInfo: true
             });
-            return textChanges2.length > 0 ? { fileName: sourceFile.fileName, textChanges: textChanges2 } : void 0;
-          });
-        }
-        changesToText2.getTextChangesFromChanges = getTextChangesFromChanges;
-        function newFileChanges(fileName, insertions, newLineCharacter, formatContext) {
-          const text = newFileChangesWorker(getScriptKindFromFileName(fileName), insertions, newLineCharacter, formatContext);
-          return { fileName, textChanges: [createTextChange(createTextSpan(0, 0), text)], isNewFile: true };
+            if (!configFileName)
+              return;
+            const ancestor = this.findConfiguredProjectByProjectName(configFileName) || this.createConfiguredProjectWithDelayLoad(configFileName, `Creating project possibly referencing default composite project ${project.getProjectName()} of open file ${info.fileName}`);
+            if (ancestor.isInitialLoadPending()) {
+              ancestor.setPotentialProjectReference(project.canonicalConfigFilePath);
+            }
+            project = ancestor;
+          }
         }
-        changesToText2.newFileChanges = newFileChanges;
-        function newFileChangesWorker(scriptKind, insertions, newLineCharacter, formatContext) {
-          const nonFormattedText = flatMap(insertions, (insertion) => insertion.statements.map((s) => s === 4 /* NewLineTrivia */ ? "" : getNonformattedText(s, insertion.oldFile, newLineCharacter).text)).join(newLineCharacter);
-          const sourceFile = createSourceFile(
-            "any file name",
-            nonFormattedText,
-            99 /* ESNext */,
-            /*setParentNodes*/
-            true,
-            scriptKind
+        /** @internal */
+        loadAncestorProjectTree(forProjects) {
+          forProjects = forProjects || mapDefinedEntries(
+            this.configuredProjects,
+            (key, project) => !project.isInitialLoadPending() ? [key, true] : void 0
           );
-          const changes = ts_formatting_exports.formatDocument(sourceFile, formatContext);
-          return applyChanges(nonFormattedText, changes) + newLineCharacter;
+          const seenProjects = /* @__PURE__ */ new Set();
+          for (const project of arrayFrom(this.configuredProjects.values())) {
+            if (forEachPotentialProjectReference(project, (potentialRefPath) => forProjects.has(potentialRefPath))) {
+              updateProjectIfDirty(project);
+            }
+            this.ensureProjectChildren(project, forProjects, seenProjects);
+          }
         }
-        changesToText2.newFileChangesWorker = newFileChangesWorker;
-        function computeNewText(change, targetSourceFile, sourceFile, newLineCharacter, formatContext, validate) {
+        ensureProjectChildren(project, forProjects, seenProjects) {
           var _a;
-          if (change.kind === 0 /* Remove */) {
-            return "";
-          }
-          if (change.kind === 3 /* Text */) {
-            return change.text;
+          if (!tryAddToSet(seenProjects, project.canonicalConfigFilePath))
+            return;
+          if (project.getCompilerOptions().disableReferencedProjectLoad)
+            return;
+          const children = (_a = project.getCurrentProgram()) == null ? void 0 : _a.getResolvedProjectReferences();
+          if (!children)
+            return;
+          for (const child of children) {
+            if (!child)
+              continue;
+            const referencedProject = forEachResolvedProjectReference(child.references, (ref) => forProjects.has(ref.sourceFile.path) ? ref : void 0);
+            if (!referencedProject)
+              continue;
+            const configFileName = toNormalizedPath(child.sourceFile.fileName);
+            const childProject = project.projectService.findConfiguredProjectByProjectName(configFileName) || project.projectService.createAndLoadConfiguredProject(configFileName, `Creating project referenced by : ${project.projectName} as it references project ${referencedProject.sourceFile.fileName}`);
+            updateProjectIfDirty(childProject);
+            this.ensureProjectChildren(childProject, forProjects, seenProjects);
           }
-          const { options = {}, range: { pos } } = change;
-          const format = (n) => getFormattedTextOfNode(n, targetSourceFile, sourceFile, pos, options, newLineCharacter, formatContext, validate);
-          const text = change.kind === 2 /* ReplaceWithMultipleNodes */ ? change.nodes.map((n) => removeSuffix(format(n), newLineCharacter)).join(((_a = change.options) == null ? void 0 : _a.joiner) || newLineCharacter) : format(change.node);
-          const noIndent = options.indentation !== void 0 || getLineStartPositionForPosition(pos, targetSourceFile) === pos ? text : text.replace(/^\s+/, "");
-          return (options.prefix || "") + noIndent + (!options.suffix || endsWith(noIndent, options.suffix) ? "" : options.suffix);
         }
-        function getFormattedTextOfNode(nodeIn, targetSourceFile, sourceFile, pos, { indentation, prefix, delta }, newLineCharacter, formatContext, validate) {
-          const { node, text } = getNonformattedText(nodeIn, targetSourceFile, newLineCharacter);
-          if (validate)
-            validate(node, text);
-          const formatOptions = getFormatCodeSettingsForWriting(formatContext, targetSourceFile);
-          const initialIndentation = indentation !== void 0 ? indentation : ts_formatting_exports.SmartIndenter.getIndentation(pos, sourceFile, formatOptions, prefix === newLineCharacter || getLineStartPositionForPosition(pos, targetSourceFile) === pos);
-          if (delta === void 0) {
-            delta = ts_formatting_exports.SmartIndenter.shouldIndentChildNode(formatOptions, nodeIn) ? formatOptions.indentSize || 0 : 0;
+        cleanupAfterOpeningFile(toRetainConfigProjects) {
+          this.removeOrphanConfiguredProjects(toRetainConfigProjects);
+          for (const inferredProject of this.inferredProjects.slice()) {
+            if (inferredProject.isOrphan()) {
+              this.removeProject(inferredProject);
+            }
           }
-          const file = {
-            text,
-            getLineAndCharacterOfPosition(pos2) {
-              return getLineAndCharacterOfPosition(this, pos2);
+          this.removeOrphanScriptInfos();
+        }
+        openClientFileWithNormalizedPath(fileName, fileContent, scriptKind, hasMixedContent, projectRootPath) {
+          const info = this.getOrCreateOpenScriptInfo(fileName, fileContent, scriptKind, hasMixedContent, projectRootPath);
+          const { retainProjects, ...result } = this.assignProjectToOpenedScriptInfo(info);
+          this.cleanupAfterOpeningFile(retainProjects);
+          this.telemetryOnOpenFile(info);
+          this.printProjects();
+          return result;
+        }
+        removeOrphanConfiguredProjects(toRetainConfiguredProjects) {
+          const toRemoveConfiguredProjects = new Map(this.configuredProjects);
+          const markOriginalProjectsAsUsed = (project) => {
+            if (!project.isOrphan() && project.originalConfiguredProjects) {
+              project.originalConfiguredProjects.forEach(
+                (_value, configuredProjectPath) => {
+                  const project2 = this.getConfiguredProjectByCanonicalConfigFilePath(configuredProjectPath);
+                  return project2 && retainConfiguredProject(project2);
+                }
+              );
             }
           };
-          const changes = ts_formatting_exports.formatNodeGivenIndentation(node, file, targetSourceFile.languageVariant, initialIndentation, delta, { ...formatContext, options: formatOptions });
-          return applyChanges(text, changes);
-        }
-        function getNonformattedText(node, sourceFile, newLineCharacter) {
-          const writer = createWriter(newLineCharacter);
-          const newLine = getNewLineKind(newLineCharacter);
-          createPrinter({
-            newLine,
-            neverAsciiEscape: true,
-            preserveSourceNewlines: true,
-            terminateUnterminatedLiterals: true
-          }, writer).writeNode(4 /* Unspecified */, node, sourceFile, writer);
-          return { text: writer.getText(), node: assignPositionsToNode(node) };
+          if (toRetainConfiguredProjects) {
+            if (isArray(toRetainConfiguredProjects)) {
+              toRetainConfiguredProjects.forEach(retainConfiguredProject);
+            } else {
+              retainConfiguredProject(toRetainConfiguredProjects);
+            }
+          }
+          this.inferredProjects.forEach(markOriginalProjectsAsUsed);
+          this.externalProjects.forEach(markOriginalProjectsAsUsed);
+          this.configuredProjects.forEach((project) => {
+            if (project.hasOpenRef()) {
+              retainConfiguredProject(project);
+            } else if (toRemoveConfiguredProjects.has(project.canonicalConfigFilePath)) {
+              forEachReferencedProject(
+                project,
+                (ref) => isRetained(ref) && retainConfiguredProject(project)
+              );
+            }
+          });
+          toRemoveConfiguredProjects.forEach((project) => this.removeProject(project));
+          function isRetained(project) {
+            return project.hasOpenRef() || !toRemoveConfiguredProjects.has(project.canonicalConfigFilePath);
+          }
+          function retainConfiguredProject(project) {
+            if (toRemoveConfiguredProjects.delete(project.canonicalConfigFilePath)) {
+              markOriginalProjectsAsUsed(project);
+              forEachReferencedProject(project, retainConfiguredProject);
+            }
+          }
         }
-        changesToText2.getNonformattedText = getNonformattedText;
-      })(changesToText || (changesToText = {}));
-      textChangesTransformationContext = {
-        ...nullTransformationContext,
-        factory: createNodeFactory(
-          nullTransformationContext.factory.flags | 1 /* NoParenthesizerRules */,
-          nullTransformationContext.factory.baseFactory
-        )
-      };
-      ((_deleteDeclaration) => {
-        function deleteDeclaration2(changes, deletedNodesInLists, sourceFile, node) {
-          switch (node.kind) {
-            case 168 /* Parameter */: {
-              const oldFunction = node.parent;
-              if (isArrowFunction(oldFunction) && oldFunction.parameters.length === 1 && !findChildOfKind(oldFunction, 21 /* OpenParenToken */, sourceFile)) {
-                changes.replaceNodeWithText(sourceFile, node, "()");
+        removeOrphanScriptInfos() {
+          const toRemoveScriptInfos = new Map(this.filenameToScriptInfo);
+          this.filenameToScriptInfo.forEach((info) => {
+            if (!info.isScriptOpen() && info.isOrphan() && !info.isContainedByBackgroundProject()) {
+              if (!info.sourceMapFilePath)
+                return;
+              let sourceInfos;
+              if (isString(info.sourceMapFilePath)) {
+                const sourceMapInfo = this.getScriptInfoForPath(info.sourceMapFilePath);
+                sourceInfos = sourceMapInfo && sourceMapInfo.sourceInfos;
               } else {
-                deleteNodeInList(changes, deletedNodesInLists, sourceFile, node);
+                sourceInfos = info.sourceMapFilePath.sourceInfos;
               }
-              break;
-            }
-            case 271 /* ImportDeclaration */:
-            case 270 /* ImportEqualsDeclaration */:
-              const isFirstImport = sourceFile.imports.length && node === first(sourceFile.imports).parent || node === find(sourceFile.statements, isAnyImportSyntax);
-              deleteNode(changes, sourceFile, node, {
-                leadingTriviaOption: isFirstImport ? 0 /* Exclude */ : hasJSDocNodes(node) ? 2 /* JSDoc */ : 3 /* StartLine */
-              });
-              break;
-            case 207 /* BindingElement */:
-              const pattern = node.parent;
-              const preserveComma = pattern.kind === 206 /* ArrayBindingPattern */ && node !== last(pattern.elements);
-              if (preserveComma) {
-                deleteNode(changes, sourceFile, node);
-              } else {
-                deleteNodeInList(changes, deletedNodesInLists, sourceFile, node);
+              if (!sourceInfos)
+                return;
+              if (!forEachKey(sourceInfos, (path) => {
+                const info2 = this.getScriptInfoForPath(path);
+                return !!info2 && (info2.isScriptOpen() || !info2.isOrphan());
+              })) {
+                return;
               }
-              break;
-            case 259 /* VariableDeclaration */:
-              deleteVariableDeclaration(changes, deletedNodesInLists, sourceFile, node);
-              break;
-            case 167 /* TypeParameter */:
-              deleteNodeInList(changes, deletedNodesInLists, sourceFile, node);
-              break;
-            case 275 /* ImportSpecifier */:
-              const namedImports = node.parent;
-              if (namedImports.elements.length === 1) {
-                deleteImportBinding(changes, sourceFile, namedImports);
+            }
+            toRemoveScriptInfos.delete(info.path);
+            if (info.sourceMapFilePath) {
+              let sourceInfos;
+              if (isString(info.sourceMapFilePath)) {
+                toRemoveScriptInfos.delete(info.sourceMapFilePath);
+                const sourceMapInfo = this.getScriptInfoForPath(info.sourceMapFilePath);
+                sourceInfos = sourceMapInfo && sourceMapInfo.sourceInfos;
               } else {
-                deleteNodeInList(changes, deletedNodesInLists, sourceFile, node);
+                sourceInfos = info.sourceMapFilePath.sourceInfos;
               }
-              break;
-            case 273 /* NamespaceImport */:
-              deleteImportBinding(changes, sourceFile, node);
-              break;
-            case 27 /* SemicolonToken */:
-              deleteNode(changes, sourceFile, node, { trailingTriviaOption: 0 /* Exclude */ });
-              break;
-            case 100 /* FunctionKeyword */:
-              deleteNode(changes, sourceFile, node, { leadingTriviaOption: 0 /* Exclude */ });
-              break;
-            case 262 /* ClassDeclaration */:
-            case 261 /* FunctionDeclaration */:
-              deleteNode(changes, sourceFile, node, { leadingTriviaOption: hasJSDocNodes(node) ? 2 /* JSDoc */ : 3 /* StartLine */ });
-              break;
-            default:
-              if (!node.parent) {
-                deleteNode(changes, sourceFile, node);
-              } else if (isImportClause(node.parent) && node.parent.name === node) {
-                deleteDefaultImport(changes, sourceFile, node.parent);
-              } else if (isCallExpression(node.parent) && contains(node.parent.arguments, node)) {
-                deleteNodeInList(changes, deletedNodesInLists, sourceFile, node);
-              } else {
-                deleteNode(changes, sourceFile, node);
+              if (sourceInfos) {
+                sourceInfos.forEach((_value, path) => toRemoveScriptInfos.delete(path));
               }
-          }
-        }
-        _deleteDeclaration.deleteDeclaration = deleteDeclaration2;
-        function deleteDefaultImport(changes, sourceFile, importClause) {
-          if (!importClause.namedBindings) {
-            deleteNode(changes, sourceFile, importClause.parent);
-          } else {
-            const start = importClause.name.getStart(sourceFile);
-            const nextToken = getTokenAtPosition(sourceFile, importClause.name.end);
-            if (nextToken && nextToken.kind === 28 /* CommaToken */) {
-              const end = skipTrivia(
-                sourceFile.text,
-                nextToken.end,
-                /*stopAfterLineBreak*/
-                false,
-                /*stopAtComments*/
-                true
-              );
-              changes.deleteRange(sourceFile, { pos: start, end });
-            } else {
-              deleteNode(changes, sourceFile, importClause.name);
             }
-          }
-        }
-        function deleteImportBinding(changes, sourceFile, node) {
-          if (node.parent.name) {
-            const previousToken = Debug.checkDefined(getTokenAtPosition(sourceFile, node.pos - 1));
-            changes.deleteRange(sourceFile, { pos: previousToken.getStart(sourceFile), end: node.end });
-          } else {
-            const importDecl = getAncestor(node, 271 /* ImportDeclaration */);
-            deleteNode(changes, sourceFile, importDecl);
-          }
+          });
+          toRemoveScriptInfos.forEach((info) => {
+            this.stopWatchingScriptInfo(info);
+            this.deleteScriptInfo(info);
+            info.closeSourceMapFileWatcher();
+          });
         }
-        function deleteVariableDeclaration(changes, deletedNodesInLists, sourceFile, node) {
-          const { parent: parent2 } = node;
-          if (parent2.kind === 298 /* CatchClause */) {
-            changes.deleteNodeRange(sourceFile, findChildOfKind(parent2, 21 /* OpenParenToken */, sourceFile), findChildOfKind(parent2, 22 /* CloseParenToken */, sourceFile));
+        telemetryOnOpenFile(scriptInfo) {
+          if (this.serverMode !== 0 /* Semantic */ || !this.eventHandler || !scriptInfo.isJavaScript() || !addToSeen(this.allJsFilesForOpenFileTelemetry, scriptInfo.path)) {
             return;
           }
-          if (parent2.declarations.length !== 1) {
-            deleteNodeInList(changes, deletedNodesInLists, sourceFile, node);
+          const project = this.ensureDefaultProjectForFile(scriptInfo);
+          if (!project.languageServiceEnabled) {
             return;
           }
-          const gp = parent2.parent;
-          switch (gp.kind) {
-            case 249 /* ForOfStatement */:
-            case 248 /* ForInStatement */:
-              changes.replaceNode(sourceFile, node, factory.createObjectLiteralExpression());
-              break;
-            case 247 /* ForStatement */:
-              deleteNode(changes, sourceFile, parent2);
-              break;
-            case 242 /* VariableStatement */:
-              deleteNode(changes, sourceFile, gp, { leadingTriviaOption: hasJSDocNodes(gp) ? 2 /* JSDoc */ : 3 /* StartLine */ });
-              break;
-            default:
-              Debug.assertNever(gp);
+          const sourceFile = project.getSourceFile(scriptInfo.path);
+          const checkJs = !!sourceFile && !!sourceFile.checkJsDirective;
+          this.eventHandler({ eventName: OpenFileInfoTelemetryEvent, data: { info: { checkJs } } });
+        }
+        closeClientFile(uncheckedFileName, skipAssignOrphanScriptInfosToInferredProject) {
+          const info = this.getScriptInfoForNormalizedPath(toNormalizedPath(uncheckedFileName));
+          const result = info ? this.closeOpenFile(info, skipAssignOrphanScriptInfosToInferredProject) : false;
+          if (!skipAssignOrphanScriptInfosToInferredProject) {
+            this.printProjects();
           }
+          return result;
         }
-      })(deleteDeclaration || (deleteDeclaration = {}));
-    }
-  });
-
-  // src/services/_namespaces/ts.textChanges.ts
-  var ts_textChanges_exports = {};
-  __export(ts_textChanges_exports, {
-    ChangeTracker: () => ChangeTracker,
-    LeadingTriviaOption: () => LeadingTriviaOption,
-    TrailingTriviaOption: () => TrailingTriviaOption,
-    applyChanges: () => applyChanges,
-    assignPositionsToNode: () => assignPositionsToNode,
-    createWriter: () => createWriter,
-    deleteNode: () => deleteNode,
-    isThisTypeAnnotatable: () => isThisTypeAnnotatable,
-    isValidLocationToAddComment: () => isValidLocationToAddComment
-  });
-  var init_ts_textChanges = __esm({
-    "src/services/_namespaces/ts.textChanges.ts"() {
-      "use strict";
-      init_textChanges();
-    }
-  });
-
-  // src/services/formatting/formattingContext.ts
-  var FormattingRequestKind, FormattingContext;
-  var init_formattingContext = __esm({
-    "src/services/formatting/formattingContext.ts"() {
-      "use strict";
-      init_ts4();
-      FormattingRequestKind = /* @__PURE__ */ ((FormattingRequestKind2) => {
-        FormattingRequestKind2[FormattingRequestKind2["FormatDocument"] = 0] = "FormatDocument";
-        FormattingRequestKind2[FormattingRequestKind2["FormatSelection"] = 1] = "FormatSelection";
-        FormattingRequestKind2[FormattingRequestKind2["FormatOnEnter"] = 2] = "FormatOnEnter";
-        FormattingRequestKind2[FormattingRequestKind2["FormatOnSemicolon"] = 3] = "FormatOnSemicolon";
-        FormattingRequestKind2[FormattingRequestKind2["FormatOnOpeningCurlyBrace"] = 4] = "FormatOnOpeningCurlyBrace";
-        FormattingRequestKind2[FormattingRequestKind2["FormatOnClosingCurlyBrace"] = 5] = "FormatOnClosingCurlyBrace";
-        return FormattingRequestKind2;
-      })(FormattingRequestKind || {});
-      FormattingContext = class {
-        constructor(sourceFile, formattingRequestKind, options) {
-          this.sourceFile = sourceFile;
-          this.formattingRequestKind = formattingRequestKind;
-          this.options = options;
+        collectChanges(lastKnownProjectVersions, currentProjects, includeProjectReferenceRedirectInfo, result) {
+          for (const proj of currentProjects) {
+            const knownProject = find(lastKnownProjectVersions, (p) => p.projectName === proj.getProjectName());
+            result.push(proj.getChangesSinceVersion(knownProject && knownProject.version, includeProjectReferenceRedirectInfo));
+          }
         }
-        updateContext(currentRange, currentTokenParent, nextRange, nextTokenParent, commonParent) {
-          this.currentTokenSpan = Debug.checkDefined(currentRange);
-          this.currentTokenParent = Debug.checkDefined(currentTokenParent);
-          this.nextTokenSpan = Debug.checkDefined(nextRange);
-          this.nextTokenParent = Debug.checkDefined(nextTokenParent);
-          this.contextNode = Debug.checkDefined(commonParent);
-          this.contextNodeAllOnSameLine = void 0;
-          this.nextNodeAllOnSameLine = void 0;
-          this.tokensAreOnSameLine = void 0;
-          this.contextNodeBlockIsOnOneLine = void 0;
-          this.nextNodeBlockIsOnOneLine = void 0;
+        /** @internal */
+        synchronizeProjectList(knownProjects, includeProjectReferenceRedirectInfo) {
+          const files = [];
+          this.collectChanges(knownProjects, this.externalProjects, includeProjectReferenceRedirectInfo, files);
+          this.collectChanges(knownProjects, this.configuredProjects.values(), includeProjectReferenceRedirectInfo, files);
+          this.collectChanges(knownProjects, this.inferredProjects, includeProjectReferenceRedirectInfo, files);
+          return files;
         }
-        ContextNodeAllOnSameLine() {
-          if (this.contextNodeAllOnSameLine === void 0) {
-            this.contextNodeAllOnSameLine = this.NodeIsOnOneLine(this.contextNode);
+        /** @internal */
+        applyChangesInOpenFiles(openFiles, changedFiles, closedFiles) {
+          let openScriptInfos;
+          let assignOrphanScriptInfosToInferredProject = false;
+          if (openFiles) {
+            for (const file of openFiles) {
+              const info = this.getOrCreateOpenScriptInfo(
+                toNormalizedPath(file.fileName),
+                file.content,
+                tryConvertScriptKindName(file.scriptKind),
+                file.hasMixedContent,
+                file.projectRootPath ? toNormalizedPath(file.projectRootPath) : void 0
+              );
+              (openScriptInfos || (openScriptInfos = [])).push(info);
+            }
           }
-          return this.contextNodeAllOnSameLine;
-        }
-        NextNodeAllOnSameLine() {
-          if (this.nextNodeAllOnSameLine === void 0) {
-            this.nextNodeAllOnSameLine = this.NodeIsOnOneLine(this.nextTokenParent);
+          if (changedFiles) {
+            for (const file of changedFiles) {
+              const scriptInfo = this.getScriptInfo(file.fileName);
+              Debug.assert(!!scriptInfo);
+              this.applyChangesToFile(scriptInfo, file.changes);
+            }
           }
-          return this.nextNodeAllOnSameLine;
-        }
-        TokensAreOnSameLine() {
-          if (this.tokensAreOnSameLine === void 0) {
-            const startLine = this.sourceFile.getLineAndCharacterOfPosition(this.currentTokenSpan.pos).line;
-            const endLine = this.sourceFile.getLineAndCharacterOfPosition(this.nextTokenSpan.pos).line;
-            this.tokensAreOnSameLine = startLine === endLine;
+          if (closedFiles) {
+            for (const file of closedFiles) {
+              assignOrphanScriptInfosToInferredProject = this.closeClientFile(
+                file,
+                /*skipAssignOrphanScriptInfosToInferredProject*/
+                true
+              ) || assignOrphanScriptInfosToInferredProject;
+            }
           }
-          return this.tokensAreOnSameLine;
-        }
-        ContextNodeBlockIsOnOneLine() {
-          if (this.contextNodeBlockIsOnOneLine === void 0) {
-            this.contextNodeBlockIsOnOneLine = this.BlockIsOnOneLine(this.contextNode);
+          let retainProjects;
+          if (openScriptInfos) {
+            retainProjects = flatMap(openScriptInfos, (info) => this.assignProjectToOpenedScriptInfo(info).retainProjects);
           }
-          return this.contextNodeBlockIsOnOneLine;
-        }
-        NextNodeBlockIsOnOneLine() {
-          if (this.nextNodeBlockIsOnOneLine === void 0) {
-            this.nextNodeBlockIsOnOneLine = this.BlockIsOnOneLine(this.nextTokenParent);
+          if (assignOrphanScriptInfosToInferredProject) {
+            this.assignOrphanScriptInfosToInferredProject();
+          }
+          if (openScriptInfos) {
+            this.cleanupAfterOpeningFile(retainProjects);
+            openScriptInfos.forEach((info) => this.telemetryOnOpenFile(info));
+            this.printProjects();
+          } else if (length(closedFiles)) {
+            this.printProjects();
           }
-          return this.nextNodeBlockIsOnOneLine;
-        }
-        NodeIsOnOneLine(node) {
-          const startLine = this.sourceFile.getLineAndCharacterOfPosition(node.getStart(this.sourceFile)).line;
-          const endLine = this.sourceFile.getLineAndCharacterOfPosition(node.getEnd()).line;
-          return startLine === endLine;
         }
-        BlockIsOnOneLine(node) {
-          const openBrace = findChildOfKind(node, 19 /* OpenBraceToken */, this.sourceFile);
-          const closeBrace = findChildOfKind(node, 20 /* CloseBraceToken */, this.sourceFile);
-          if (openBrace && closeBrace) {
-            const startLine = this.sourceFile.getLineAndCharacterOfPosition(openBrace.getEnd()).line;
-            const endLine = this.sourceFile.getLineAndCharacterOfPosition(closeBrace.getStart(this.sourceFile)).line;
-            return startLine === endLine;
+        /** @internal */
+        applyChangesToFile(scriptInfo, changes) {
+          for (const change of changes) {
+            scriptInfo.editContent(change.span.start, change.span.start + change.span.length, change.newText);
           }
-          return false;
         }
-      };
-    }
-  });
-
-  // src/services/formatting/formattingScanner.ts
-  function getFormattingScanner(text, languageVariant, startPos, endPos, cb) {
-    const scanner2 = languageVariant === 1 /* JSX */ ? jsxScanner : standardScanner;
-    scanner2.setText(text);
-    scanner2.resetTokenState(startPos);
-    let wasNewLine = true;
-    let leadingTrivia;
-    let trailingTrivia;
-    let savedPos;
-    let lastScanAction;
-    let lastTokenInfo;
-    const res = cb({
-      advance,
-      readTokenInfo,
-      readEOFTokenRange,
-      isOnToken,
-      isOnEOF,
-      getCurrentLeadingTrivia: () => leadingTrivia,
-      lastTrailingTriviaWasNewLine: () => wasNewLine,
-      skipToEndOf,
-      skipToStartOf,
-      getTokenFullStart: () => (lastTokenInfo == null ? void 0 : lastTokenInfo.token.pos) ?? scanner2.getTokenStart(),
-      getStartPos: () => (lastTokenInfo == null ? void 0 : lastTokenInfo.token.pos) ?? scanner2.getTokenStart()
-    });
-    lastTokenInfo = void 0;
-    scanner2.setText(void 0);
-    return res;
-    function advance() {
-      lastTokenInfo = void 0;
-      const isStarted = scanner2.getTokenFullStart() !== startPos;
-      if (isStarted) {
-        wasNewLine = !!trailingTrivia && last(trailingTrivia).kind === 4 /* NewLineTrivia */;
-      } else {
-        scanner2.scan();
-      }
-      leadingTrivia = void 0;
-      trailingTrivia = void 0;
-      let pos = scanner2.getTokenFullStart();
-      while (pos < endPos) {
-        const t = scanner2.getToken();
-        if (!isTrivia(t)) {
-          break;
+        closeConfiguredProjectReferencedFromExternalProject(configFile) {
+          const configuredProject = this.findConfiguredProjectByProjectName(configFile);
+          if (configuredProject) {
+            configuredProject.deleteExternalProjectReference();
+            if (!configuredProject.hasOpenRef()) {
+              this.removeProject(configuredProject);
+              return;
+            }
+          }
         }
-        scanner2.scan();
-        const item = {
-          pos,
-          end: scanner2.getTokenFullStart(),
-          kind: t
-        };
-        pos = scanner2.getTokenFullStart();
-        leadingTrivia = append(leadingTrivia, item);
-      }
-      savedPos = scanner2.getTokenFullStart();
-    }
-    function shouldRescanGreaterThanToken(node) {
-      switch (node.kind) {
-        case 34 /* GreaterThanEqualsToken */:
-        case 72 /* GreaterThanGreaterThanEqualsToken */:
-        case 73 /* GreaterThanGreaterThanGreaterThanEqualsToken */:
-        case 50 /* GreaterThanGreaterThanGreaterThanToken */:
-        case 49 /* GreaterThanGreaterThanToken */:
-          return true;
-      }
-      return false;
-    }
-    function shouldRescanJsxIdentifier(node) {
-      if (node.parent) {
-        switch (node.parent.kind) {
-          case 290 /* JsxAttribute */:
-          case 285 /* JsxOpeningElement */:
-          case 286 /* JsxClosingElement */:
-          case 284 /* JsxSelfClosingElement */:
-            return isKeyword(node.kind) || node.kind === 80 /* Identifier */;
+        closeExternalProject(uncheckedFileName) {
+          const fileName = toNormalizedPath(uncheckedFileName);
+          const configFiles = this.externalProjectToConfiguredProjectMap.get(fileName);
+          if (configFiles) {
+            for (const configFile of configFiles) {
+              this.closeConfiguredProjectReferencedFromExternalProject(configFile);
+            }
+            this.externalProjectToConfiguredProjectMap.delete(fileName);
+          } else {
+            const externalProject = this.findExternalProjectByProjectName(uncheckedFileName);
+            if (externalProject) {
+              this.removeProject(externalProject);
+            }
+          }
         }
-      }
-      return false;
-    }
-    function shouldRescanJsxText(node) {
-      return isJsxText(node) || isJsxElement(node) && (lastTokenInfo == null ? void 0 : lastTokenInfo.token.kind) === 12 /* JsxText */;
-    }
-    function shouldRescanSlashToken(container) {
-      return container.kind === 14 /* RegularExpressionLiteral */;
-    }
-    function shouldRescanTemplateToken(container) {
-      return container.kind === 17 /* TemplateMiddle */ || container.kind === 18 /* TemplateTail */;
-    }
-    function shouldRescanJsxAttributeValue(node) {
-      return node.parent && isJsxAttribute(node.parent) && node.parent.initializer === node;
-    }
-    function startsWithSlashToken(t) {
-      return t === 44 /* SlashToken */ || t === 69 /* SlashEqualsToken */;
-    }
-    function readTokenInfo(n) {
-      Debug.assert(isOnToken());
-      const expectedScanAction = shouldRescanGreaterThanToken(n) ? 1 /* RescanGreaterThanToken */ : shouldRescanSlashToken(n) ? 2 /* RescanSlashToken */ : shouldRescanTemplateToken(n) ? 3 /* RescanTemplateToken */ : shouldRescanJsxIdentifier(n) ? 4 /* RescanJsxIdentifier */ : shouldRescanJsxText(n) ? 5 /* RescanJsxText */ : shouldRescanJsxAttributeValue(n) ? 6 /* RescanJsxAttributeValue */ : 0 /* Scan */;
-      if (lastTokenInfo && expectedScanAction === lastScanAction) {
-        return fixTokenKind(lastTokenInfo, n);
-      }
-      if (scanner2.getTokenFullStart() !== savedPos) {
-        Debug.assert(lastTokenInfo !== void 0);
-        scanner2.resetTokenState(savedPos);
-        scanner2.scan();
-      }
-      let currentToken = getNextToken(n, expectedScanAction);
-      const token = createTextRangeWithKind(
-        scanner2.getTokenFullStart(),
-        scanner2.getTokenEnd(),
-        currentToken
-      );
-      if (trailingTrivia) {
-        trailingTrivia = void 0;
-      }
-      while (scanner2.getTokenFullStart() < endPos) {
-        currentToken = scanner2.scan();
-        if (!isTrivia(currentToken)) {
-          break;
+        openExternalProjects(projects) {
+          const projectsToClose = arrayToMap(this.externalProjects, (p) => p.getProjectName(), (_) => true);
+          forEachKey(this.externalProjectToConfiguredProjectMap, (externalProjectName) => {
+            projectsToClose.set(externalProjectName, true);
+          });
+          for (const externalProject of projects) {
+            this.openExternalProject(externalProject);
+            projectsToClose.delete(externalProject.projectFileName);
+          }
+          forEachKey(projectsToClose, (externalProjectName) => {
+            this.closeExternalProject(externalProjectName);
+          });
         }
-        const trivia = createTextRangeWithKind(
-          scanner2.getTokenFullStart(),
-          scanner2.getTokenEnd(),
-          currentToken
-        );
-        if (!trailingTrivia) {
-          trailingTrivia = [];
+        static escapeFilenameForRegex(filename) {
+          return filename.replace(this.filenameEscapeRegexp, "\\$&");
         }
-        trailingTrivia.push(trivia);
-        if (currentToken === 4 /* NewLineTrivia */) {
-          scanner2.scan();
-          break;
+        resetSafeList() {
+          this.safelist = defaultTypeSafeList;
         }
-      }
-      lastTokenInfo = { leadingTrivia, trailingTrivia, token };
-      return fixTokenKind(lastTokenInfo, n);
-    }
-    function getNextToken(n, expectedScanAction) {
-      const token = scanner2.getToken();
-      lastScanAction = 0 /* Scan */;
-      switch (expectedScanAction) {
-        case 1 /* RescanGreaterThanToken */:
-          if (token === 32 /* GreaterThanToken */) {
-            lastScanAction = 1 /* RescanGreaterThanToken */;
-            const newToken = scanner2.reScanGreaterToken();
-            Debug.assert(n.kind === newToken);
-            return newToken;
+        applySafeList(proj) {
+          const { rootFiles } = proj;
+          const typeAcquisition = proj.typeAcquisition;
+          Debug.assert(!!typeAcquisition, "proj.typeAcquisition should be set by now");
+          if (typeAcquisition.enable === false || typeAcquisition.disableFilenameBasedTypeAcquisition) {
+            return [];
           }
-          break;
-        case 2 /* RescanSlashToken */:
-          if (startsWithSlashToken(token)) {
-            lastScanAction = 2 /* RescanSlashToken */;
-            const newToken = scanner2.reScanSlashToken();
-            Debug.assert(n.kind === newToken);
-            return newToken;
+          const typeAcqInclude = typeAcquisition.include || (typeAcquisition.include = []);
+          const excludeRules = [];
+          const normalizedNames = rootFiles.map((f) => normalizeSlashes(f.fileName));
+          const excludedFiles = [];
+          for (const name of Object.keys(this.safelist)) {
+            const rule2 = this.safelist[name];
+            for (const root of normalizedNames) {
+              if (rule2.match.test(root)) {
+                this.logger.info(`Excluding files based on rule ${name} matching file '${root}'`);
+                if (rule2.types) {
+                  for (const type of rule2.types) {
+                    if (!typeAcqInclude.includes(type)) {
+                      typeAcqInclude.push(type);
+                    }
+                  }
+                }
+                if (rule2.exclude) {
+                  for (const exclude of rule2.exclude) {
+                    const processedRule = root.replace(rule2.match, (...groups) => {
+                      return exclude.map((groupNumberOrString) => {
+                        if (typeof groupNumberOrString === "number") {
+                          if (!isString(groups[groupNumberOrString])) {
+                            this.logger.info(`Incorrect RegExp specification in safelist rule ${name} - not enough groups`);
+                            return "\\*";
+                          }
+                          return _ProjectService.escapeFilenameForRegex(groups[groupNumberOrString]);
+                        }
+                        return groupNumberOrString;
+                      }).join("");
+                    });
+                    if (!excludeRules.includes(processedRule)) {
+                      excludeRules.push(processedRule);
+                    }
+                  }
+                } else {
+                  const escaped = _ProjectService.escapeFilenameForRegex(root);
+                  if (!excludeRules.includes(escaped)) {
+                    excludeRules.push(escaped);
+                  }
+                }
+              }
+            }
           }
-          break;
-        case 3 /* RescanTemplateToken */:
-          if (token === 20 /* CloseBraceToken */) {
-            lastScanAction = 3 /* RescanTemplateToken */;
-            return scanner2.reScanTemplateToken(
-              /*isTaggedTemplate*/
-              false
-            );
+          const excludeRegexes = excludeRules.map((e) => new RegExp(e, "i"));
+          const filesToKeep = [];
+          for (let i = 0; i < proj.rootFiles.length; i++) {
+            if (excludeRegexes.some((re) => re.test(normalizedNames[i]))) {
+              excludedFiles.push(normalizedNames[i]);
+            } else {
+              let exclude = false;
+              if (typeAcquisition.enable) {
+                const baseName = getBaseFileName(toFileNameLowerCase(normalizedNames[i]));
+                if (fileExtensionIs(baseName, "js")) {
+                  const inferredTypingName = removeFileExtension(baseName);
+                  const cleanedTypingName = removeMinAndVersionNumbers(inferredTypingName);
+                  const typeName = this.legacySafelist.get(cleanedTypingName);
+                  if (typeName !== void 0) {
+                    this.logger.info(`Excluded '${normalizedNames[i]}' because it matched ${cleanedTypingName} from the legacy safelist`);
+                    excludedFiles.push(normalizedNames[i]);
+                    exclude = true;
+                    if (!typeAcqInclude.includes(typeName)) {
+                      typeAcqInclude.push(typeName);
+                    }
+                  }
+                }
+              }
+              if (!exclude) {
+                if (/^.+[.-]min\.js$/.test(normalizedNames[i])) {
+                  excludedFiles.push(normalizedNames[i]);
+                } else {
+                  filesToKeep.push(proj.rootFiles[i]);
+                }
+              }
+            }
           }
-          break;
-        case 4 /* RescanJsxIdentifier */:
-          lastScanAction = 4 /* RescanJsxIdentifier */;
-          return scanner2.scanJsxIdentifier();
-        case 5 /* RescanJsxText */:
-          lastScanAction = 5 /* RescanJsxText */;
-          return scanner2.reScanJsxToken(
-            /*allowMultilineJsxText*/
-            false
-          );
-        case 6 /* RescanJsxAttributeValue */:
-          lastScanAction = 6 /* RescanJsxAttributeValue */;
-          return scanner2.reScanJsxAttributeValue();
-        case 0 /* Scan */:
-          break;
-        default:
-          Debug.assertNever(expectedScanAction);
-      }
-      return token;
-    }
-    function readEOFTokenRange() {
-      Debug.assert(isOnEOF());
-      return createTextRangeWithKind(scanner2.getTokenFullStart(), scanner2.getTokenEnd(), 1 /* EndOfFileToken */);
-    }
-    function isOnToken() {
-      const current = lastTokenInfo ? lastTokenInfo.token.kind : scanner2.getToken();
-      return current !== 1 /* EndOfFileToken */ && !isTrivia(current);
-    }
-    function isOnEOF() {
-      const current = lastTokenInfo ? lastTokenInfo.token.kind : scanner2.getToken();
-      return current === 1 /* EndOfFileToken */;
-    }
-    function fixTokenKind(tokenInfo, container) {
-      if (isToken(container) && tokenInfo.token.kind !== container.kind) {
-        tokenInfo.token.kind = container.kind;
-      }
-      return tokenInfo;
-    }
-    function skipToEndOf(node) {
-      scanner2.resetTokenState(node.end);
-      savedPos = scanner2.getTokenFullStart();
-      lastScanAction = void 0;
-      lastTokenInfo = void 0;
-      wasNewLine = false;
-      leadingTrivia = void 0;
-      trailingTrivia = void 0;
-    }
-    function skipToStartOf(node) {
-      scanner2.resetTokenState(node.pos);
-      savedPos = scanner2.getTokenFullStart();
-      lastScanAction = void 0;
-      lastTokenInfo = void 0;
-      wasNewLine = false;
-      leadingTrivia = void 0;
-      trailingTrivia = void 0;
-    }
-  }
-  var standardScanner, jsxScanner;
-  var init_formattingScanner = __esm({
-    "src/services/formatting/formattingScanner.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_formatting();
-      standardScanner = createScanner(
-        99 /* Latest */,
-        /*skipTrivia*/
-        false,
-        0 /* Standard */
-      );
-      jsxScanner = createScanner(
-        99 /* Latest */,
-        /*skipTrivia*/
-        false,
-        1 /* JSX */
-      );
-    }
-  });
-
-  // src/services/formatting/rule.ts
-  var anyContext, RuleAction, RuleFlags;
-  var init_rule = __esm({
-    "src/services/formatting/rule.ts"() {
-      "use strict";
-      init_ts4();
-      anyContext = emptyArray;
-      RuleAction = /* @__PURE__ */ ((RuleAction2) => {
-        RuleAction2[RuleAction2["None"] = 0] = "None";
-        RuleAction2[RuleAction2["StopProcessingSpaceActions"] = 1] = "StopProcessingSpaceActions";
-        RuleAction2[RuleAction2["StopProcessingTokenActions"] = 2] = "StopProcessingTokenActions";
-        RuleAction2[RuleAction2["InsertSpace"] = 4] = "InsertSpace";
-        RuleAction2[RuleAction2["InsertNewLine"] = 8] = "InsertNewLine";
-        RuleAction2[RuleAction2["DeleteSpace"] = 16] = "DeleteSpace";
-        RuleAction2[RuleAction2["DeleteToken"] = 32] = "DeleteToken";
-        RuleAction2[RuleAction2["InsertTrailingSemicolon"] = 64] = "InsertTrailingSemicolon";
-        RuleAction2[RuleAction2["StopAction"] = 3] = "StopAction";
-        RuleAction2[RuleAction2["ModifySpaceAction"] = 28] = "ModifySpaceAction";
-        RuleAction2[RuleAction2["ModifyTokenAction"] = 96] = "ModifyTokenAction";
-        return RuleAction2;
-      })(RuleAction || {});
-      RuleFlags = /* @__PURE__ */ ((RuleFlags2) => {
-        RuleFlags2[RuleFlags2["None"] = 0] = "None";
-        RuleFlags2[RuleFlags2["CanDeleteNewLines"] = 1] = "CanDeleteNewLines";
-        return RuleFlags2;
-      })(RuleFlags || {});
-    }
-  });
-
-  // src/services/formatting/rules.ts
-  function getAllRules() {
-    const allTokens = [];
-    for (let token = 0 /* FirstToken */; token <= 164 /* LastToken */; token++) {
-      if (token !== 1 /* EndOfFileToken */) {
-        allTokens.push(token);
-      }
-    }
-    function anyTokenExcept(...tokens) {
-      return { tokens: allTokens.filter((t) => !tokens.some((t2) => t2 === t)), isSpecific: false };
-    }
-    const anyToken = { tokens: allTokens, isSpecific: false };
-    const anyTokenIncludingMultilineComments = tokenRangeFrom([...allTokens, 3 /* MultiLineCommentTrivia */]);
-    const anyTokenIncludingEOF = tokenRangeFrom([...allTokens, 1 /* EndOfFileToken */]);
-    const keywords = tokenRangeFromRange(83 /* FirstKeyword */, 164 /* LastKeyword */);
-    const binaryOperators = tokenRangeFromRange(30 /* FirstBinaryOperator */, 79 /* LastBinaryOperator */);
-    const binaryKeywordOperators = [
-      103 /* InKeyword */,
-      104 /* InstanceOfKeyword */,
-      164 /* OfKeyword */,
-      130 /* AsKeyword */,
-      142 /* IsKeyword */,
-      152 /* SatisfiesKeyword */
-    ];
-    const unaryPrefixOperators = [46 /* PlusPlusToken */, 47 /* MinusMinusToken */, 55 /* TildeToken */, 54 /* ExclamationToken */];
-    const unaryPrefixExpressions = [
-      9 /* NumericLiteral */,
-      10 /* BigIntLiteral */,
-      80 /* Identifier */,
-      21 /* OpenParenToken */,
-      23 /* OpenBracketToken */,
-      19 /* OpenBraceToken */,
-      110 /* ThisKeyword */,
-      105 /* NewKeyword */
-    ];
-    const unaryPreincrementExpressions = [80 /* Identifier */, 21 /* OpenParenToken */, 110 /* ThisKeyword */, 105 /* NewKeyword */];
-    const unaryPostincrementExpressions = [80 /* Identifier */, 22 /* CloseParenToken */, 24 /* CloseBracketToken */, 105 /* NewKeyword */];
-    const unaryPredecrementExpressions = [80 /* Identifier */, 21 /* OpenParenToken */, 110 /* ThisKeyword */, 105 /* NewKeyword */];
-    const unaryPostdecrementExpressions = [80 /* Identifier */, 22 /* CloseParenToken */, 24 /* CloseBracketToken */, 105 /* NewKeyword */];
-    const comments = [2 /* SingleLineCommentTrivia */, 3 /* MultiLineCommentTrivia */];
-    const typeNames = [80 /* Identifier */, ...typeKeywords];
-    const functionOpenBraceLeftTokenRange = anyTokenIncludingMultilineComments;
-    const typeScriptOpenBraceLeftTokenRange = tokenRangeFrom([80 /* Identifier */, 3 /* MultiLineCommentTrivia */, 86 /* ClassKeyword */, 95 /* ExportKeyword */, 102 /* ImportKeyword */]);
-    const controlOpenBraceLeftTokenRange = tokenRangeFrom([22 /* CloseParenToken */, 3 /* MultiLineCommentTrivia */, 92 /* DoKeyword */, 113 /* TryKeyword */, 98 /* FinallyKeyword */, 93 /* ElseKeyword */]);
-    const highPriorityCommonRules = [
-      // Leave comments alone
-      rule("IgnoreBeforeComment", anyToken, comments, anyContext, 1 /* StopProcessingSpaceActions */),
-      rule("IgnoreAfterLineComment", 2 /* SingleLineCommentTrivia */, anyToken, anyContext, 1 /* StopProcessingSpaceActions */),
-      rule("NotSpaceBeforeColon", anyToken, 59 /* ColonToken */, [isNonJsxSameLineTokenContext, isNotBinaryOpContext, isNotTypeAnnotationContext], 16 /* DeleteSpace */),
-      rule("SpaceAfterColon", 59 /* ColonToken */, anyToken, [isNonJsxSameLineTokenContext, isNotBinaryOpContext], 4 /* InsertSpace */),
-      rule("NoSpaceBeforeQuestionMark", anyToken, 58 /* QuestionToken */, [isNonJsxSameLineTokenContext, isNotBinaryOpContext, isNotTypeAnnotationContext], 16 /* DeleteSpace */),
-      // insert space after '?' only when it is used in conditional operator
-      rule("SpaceAfterQuestionMarkInConditionalOperator", 58 /* QuestionToken */, anyToken, [isNonJsxSameLineTokenContext, isConditionalOperatorContext], 4 /* InsertSpace */),
-      // in other cases there should be no space between '?' and next token
-      rule("NoSpaceAfterQuestionMark", 58 /* QuestionToken */, anyToken, [isNonJsxSameLineTokenContext], 16 /* DeleteSpace */),
-      rule("NoSpaceBeforeDot", anyToken, [25 /* DotToken */, 29 /* QuestionDotToken */], [isNonJsxSameLineTokenContext, isNotPropertyAccessOnIntegerLiteral], 16 /* DeleteSpace */),
-      rule("NoSpaceAfterDot", [25 /* DotToken */, 29 /* QuestionDotToken */], anyToken, [isNonJsxSameLineTokenContext], 16 /* DeleteSpace */),
-      rule("NoSpaceBetweenImportParenInImportType", 102 /* ImportKeyword */, 21 /* OpenParenToken */, [isNonJsxSameLineTokenContext, isImportTypeContext], 16 /* DeleteSpace */),
-      // Special handling of unary operators.
-      // Prefix operators generally shouldn't have a space between
-      // them and their target unary expression.
-      rule("NoSpaceAfterUnaryPrefixOperator", unaryPrefixOperators, unaryPrefixExpressions, [isNonJsxSameLineTokenContext, isNotBinaryOpContext], 16 /* DeleteSpace */),
-      rule("NoSpaceAfterUnaryPreincrementOperator", 46 /* PlusPlusToken */, unaryPreincrementExpressions, [isNonJsxSameLineTokenContext], 16 /* DeleteSpace */),
-      rule("NoSpaceAfterUnaryPredecrementOperator", 47 /* MinusMinusToken */, unaryPredecrementExpressions, [isNonJsxSameLineTokenContext], 16 /* DeleteSpace */),
-      rule("NoSpaceBeforeUnaryPostincrementOperator", unaryPostincrementExpressions, 46 /* PlusPlusToken */, [isNonJsxSameLineTokenContext, isNotStatementConditionContext], 16 /* DeleteSpace */),
-      rule("NoSpaceBeforeUnaryPostdecrementOperator", unaryPostdecrementExpressions, 47 /* MinusMinusToken */, [isNonJsxSameLineTokenContext, isNotStatementConditionContext], 16 /* DeleteSpace */),
-      // More unary operator special-casing.
-      // DevDiv 181814: Be careful when removing leading whitespace
-      // around unary operators.  Examples:
-      //      1 - -2  --X--> 1--2
-      //      a + ++b --X--> a+++b
-      rule("SpaceAfterPostincrementWhenFollowedByAdd", 46 /* PlusPlusToken */, 40 /* PlusToken */, [isNonJsxSameLineTokenContext, isBinaryOpContext], 4 /* InsertSpace */),
-      rule("SpaceAfterAddWhenFollowedByUnaryPlus", 40 /* PlusToken */, 40 /* PlusToken */, [isNonJsxSameLineTokenContext, isBinaryOpContext], 4 /* InsertSpace */),
-      rule("SpaceAfterAddWhenFollowedByPreincrement", 40 /* PlusToken */, 46 /* PlusPlusToken */, [isNonJsxSameLineTokenContext, isBinaryOpContext], 4 /* InsertSpace */),
-      rule("SpaceAfterPostdecrementWhenFollowedBySubtract", 47 /* MinusMinusToken */, 41 /* MinusToken */, [isNonJsxSameLineTokenContext, isBinaryOpContext], 4 /* InsertSpace */),
-      rule("SpaceAfterSubtractWhenFollowedByUnaryMinus", 41 /* MinusToken */, 41 /* MinusToken */, [isNonJsxSameLineTokenContext, isBinaryOpContext], 4 /* InsertSpace */),
-      rule("SpaceAfterSubtractWhenFollowedByPredecrement", 41 /* MinusToken */, 47 /* MinusMinusToken */, [isNonJsxSameLineTokenContext, isBinaryOpContext], 4 /* InsertSpace */),
-      rule("NoSpaceAfterCloseBrace", 20 /* CloseBraceToken */, [28 /* CommaToken */, 27 /* SemicolonToken */], [isNonJsxSameLineTokenContext], 16 /* DeleteSpace */),
-      // For functions and control block place } on a new line [multi-line rule]
-      rule("NewLineBeforeCloseBraceInBlockContext", anyTokenIncludingMultilineComments, 20 /* CloseBraceToken */, [isMultilineBlockContext], 8 /* InsertNewLine */),
-      // Space/new line after }.
-      rule("SpaceAfterCloseBrace", 20 /* CloseBraceToken */, anyTokenExcept(22 /* CloseParenToken */), [isNonJsxSameLineTokenContext, isAfterCodeBlockContext], 4 /* InsertSpace */),
-      // Special case for (}, else) and (}, while) since else & while tokens are not part of the tree which makes SpaceAfterCloseBrace rule not applied
-      // Also should not apply to })
-      rule("SpaceBetweenCloseBraceAndElse", 20 /* CloseBraceToken */, 93 /* ElseKeyword */, [isNonJsxSameLineTokenContext], 4 /* InsertSpace */),
-      rule("SpaceBetweenCloseBraceAndWhile", 20 /* CloseBraceToken */, 117 /* WhileKeyword */, [isNonJsxSameLineTokenContext], 4 /* InsertSpace */),
-      rule("NoSpaceBetweenEmptyBraceBrackets", 19 /* OpenBraceToken */, 20 /* CloseBraceToken */, [isNonJsxSameLineTokenContext, isObjectContext], 16 /* DeleteSpace */),
-      // Add a space after control dec context if the next character is an open bracket ex: 'if (false)[a, b] = [1, 2];' -> 'if (false) [a, b] = [1, 2];'
-      rule("SpaceAfterConditionalClosingParen", 22 /* CloseParenToken */, 23 /* OpenBracketToken */, [isControlDeclContext], 4 /* InsertSpace */),
-      rule("NoSpaceBetweenFunctionKeywordAndStar", 100 /* FunctionKeyword */, 42 /* AsteriskToken */, [isFunctionDeclarationOrFunctionExpressionContext], 16 /* DeleteSpace */),
-      rule("SpaceAfterStarInGeneratorDeclaration", 42 /* AsteriskToken */, 80 /* Identifier */, [isFunctionDeclarationOrFunctionExpressionContext], 4 /* InsertSpace */),
-      rule("SpaceAfterFunctionInFuncDecl", 100 /* FunctionKeyword */, anyToken, [isFunctionDeclContext], 4 /* InsertSpace */),
-      // Insert new line after { and before } in multi-line contexts.
-      rule("NewLineAfterOpenBraceInBlockContext", 19 /* OpenBraceToken */, anyToken, [isMultilineBlockContext], 8 /* InsertNewLine */),
-      // For get/set members, we check for (identifier,identifier) since get/set don't have tokens and they are represented as just an identifier token.
-      // Though, we do extra check on the context to make sure we are dealing with get/set node. Example:
-      //      get x() {}
-      //      set x(val) {}
-      rule("SpaceAfterGetSetInMember", [139 /* GetKeyword */, 153 /* SetKeyword */], 80 /* Identifier */, [isFunctionDeclContext], 4 /* InsertSpace */),
-      rule("NoSpaceBetweenYieldKeywordAndStar", 127 /* YieldKeyword */, 42 /* AsteriskToken */, [isNonJsxSameLineTokenContext, isYieldOrYieldStarWithOperand], 16 /* DeleteSpace */),
-      rule("SpaceBetweenYieldOrYieldStarAndOperand", [127 /* YieldKeyword */, 42 /* AsteriskToken */], anyToken, [isNonJsxSameLineTokenContext, isYieldOrYieldStarWithOperand], 4 /* InsertSpace */),
-      rule("NoSpaceBetweenReturnAndSemicolon", 107 /* ReturnKeyword */, 27 /* SemicolonToken */, [isNonJsxSameLineTokenContext], 16 /* DeleteSpace */),
-      rule("SpaceAfterCertainKeywords", [115 /* VarKeyword */, 111 /* ThrowKeyword */, 105 /* NewKeyword */, 91 /* DeleteKeyword */, 107 /* ReturnKeyword */, 114 /* TypeOfKeyword */, 135 /* AwaitKeyword */], anyToken, [isNonJsxSameLineTokenContext], 4 /* InsertSpace */),
-      rule("SpaceAfterLetConstInVariableDeclaration", [121 /* LetKeyword */, 87 /* ConstKeyword */], anyToken, [isNonJsxSameLineTokenContext, isStartOfVariableDeclarationList], 4 /* InsertSpace */),
-      rule("NoSpaceBeforeOpenParenInFuncCall", anyToken, 21 /* OpenParenToken */, [isNonJsxSameLineTokenContext, isFunctionCallOrNewContext, isPreviousTokenNotComma], 16 /* DeleteSpace */),
-      // Special case for binary operators (that are keywords). For these we have to add a space and shouldn't follow any user options.
-      rule("SpaceBeforeBinaryKeywordOperator", anyToken, binaryKeywordOperators, [isNonJsxSameLineTokenContext, isBinaryOpContext], 4 /* InsertSpace */),
-      rule("SpaceAfterBinaryKeywordOperator", binaryKeywordOperators, anyToken, [isNonJsxSameLineTokenContext, isBinaryOpContext], 4 /* InsertSpace */),
-      rule("SpaceAfterVoidOperator", 116 /* VoidKeyword */, anyToken, [isNonJsxSameLineTokenContext, isVoidOpContext], 4 /* InsertSpace */),
-      // Async-await
-      rule("SpaceBetweenAsyncAndOpenParen", 134 /* AsyncKeyword */, 21 /* OpenParenToken */, [isArrowFunctionContext, isNonJsxSameLineTokenContext], 4 /* InsertSpace */),
-      rule("SpaceBetweenAsyncAndFunctionKeyword", 134 /* AsyncKeyword */, [100 /* FunctionKeyword */, 80 /* Identifier */], [isNonJsxSameLineTokenContext], 4 /* InsertSpace */),
-      // Template string
-      rule("NoSpaceBetweenTagAndTemplateString", [80 /* Identifier */, 22 /* CloseParenToken */], [15 /* NoSubstitutionTemplateLiteral */, 16 /* TemplateHead */], [isNonJsxSameLineTokenContext], 16 /* DeleteSpace */),
-      // JSX opening elements
-      rule("SpaceBeforeJsxAttribute", anyToken, 80 /* Identifier */, [isNextTokenParentJsxAttribute, isNonJsxSameLineTokenContext], 4 /* InsertSpace */),
-      rule("SpaceBeforeSlashInJsxOpeningElement", anyToken, 44 /* SlashToken */, [isJsxSelfClosingElementContext, isNonJsxSameLineTokenContext], 4 /* InsertSpace */),
-      rule("NoSpaceBeforeGreaterThanTokenInJsxOpeningElement", 44 /* SlashToken */, 32 /* GreaterThanToken */, [isJsxSelfClosingElementContext, isNonJsxSameLineTokenContext], 16 /* DeleteSpace */),
-      rule("NoSpaceBeforeEqualInJsxAttribute", anyToken, 64 /* EqualsToken */, [isJsxAttributeContext, isNonJsxSameLineTokenContext], 16 /* DeleteSpace */),
-      rule("NoSpaceAfterEqualInJsxAttribute", 64 /* EqualsToken */, anyToken, [isJsxAttributeContext, isNonJsxSameLineTokenContext], 16 /* DeleteSpace */),
-      // TypeScript-specific rules
-      // Use of module as a function call. e.g.: import m2 = module("m2");
-      rule("NoSpaceAfterModuleImport", [144 /* ModuleKeyword */, 149 /* RequireKeyword */], 21 /* OpenParenToken */, [isNonJsxSameLineTokenContext], 16 /* DeleteSpace */),
-      // Add a space around certain TypeScript keywords
-      rule(
-        "SpaceAfterCertainTypeScriptKeywords",
-        [
-          128 /* AbstractKeyword */,
-          129 /* AccessorKeyword */,
-          86 /* ClassKeyword */,
-          138 /* DeclareKeyword */,
-          90 /* DefaultKeyword */,
-          94 /* EnumKeyword */,
-          95 /* ExportKeyword */,
-          96 /* ExtendsKeyword */,
-          139 /* GetKeyword */,
-          119 /* ImplementsKeyword */,
-          102 /* ImportKeyword */,
-          120 /* InterfaceKeyword */,
-          144 /* ModuleKeyword */,
-          145 /* NamespaceKeyword */,
-          123 /* PrivateKeyword */,
-          125 /* PublicKeyword */,
-          124 /* ProtectedKeyword */,
-          148 /* ReadonlyKeyword */,
-          153 /* SetKeyword */,
-          126 /* StaticKeyword */,
-          156 /* TypeKeyword */,
-          160 /* FromKeyword */,
-          143 /* KeyOfKeyword */,
-          140 /* InferKeyword */
-        ],
-        anyToken,
-        [isNonJsxSameLineTokenContext],
-        4 /* InsertSpace */
-      ),
-      rule(
-        "SpaceBeforeCertainTypeScriptKeywords",
-        anyToken,
-        [96 /* ExtendsKeyword */, 119 /* ImplementsKeyword */, 160 /* FromKeyword */],
-        [isNonJsxSameLineTokenContext],
-        4 /* InsertSpace */
-      ),
-      // Treat string literals in module names as identifiers, and add a space between the literal and the opening Brace braces, e.g.: module "m2" {
-      rule("SpaceAfterModuleName", 11 /* StringLiteral */, 19 /* OpenBraceToken */, [isModuleDeclContext], 4 /* InsertSpace */),
-      // Lambda expressions
-      rule("SpaceBeforeArrow", anyToken, 39 /* EqualsGreaterThanToken */, [isNonJsxSameLineTokenContext], 4 /* InsertSpace */),
-      rule("SpaceAfterArrow", 39 /* EqualsGreaterThanToken */, anyToken, [isNonJsxSameLineTokenContext], 4 /* InsertSpace */),
-      // Optional parameters and let args
-      rule("NoSpaceAfterEllipsis", 26 /* DotDotDotToken */, 80 /* Identifier */, [isNonJsxSameLineTokenContext], 16 /* DeleteSpace */),
-      rule("NoSpaceAfterOptionalParameters", 58 /* QuestionToken */, [22 /* CloseParenToken */, 28 /* CommaToken */], [isNonJsxSameLineTokenContext, isNotBinaryOpContext], 16 /* DeleteSpace */),
-      // Remove spaces in empty interface literals. e.g.: x: {}
-      rule("NoSpaceBetweenEmptyInterfaceBraceBrackets", 19 /* OpenBraceToken */, 20 /* CloseBraceToken */, [isNonJsxSameLineTokenContext, isObjectTypeContext], 16 /* DeleteSpace */),
-      // generics and type assertions
-      rule("NoSpaceBeforeOpenAngularBracket", typeNames, 30 /* LessThanToken */, [isNonJsxSameLineTokenContext, isTypeArgumentOrParameterOrAssertionContext], 16 /* DeleteSpace */),
-      rule("NoSpaceBetweenCloseParenAndAngularBracket", 22 /* CloseParenToken */, 30 /* LessThanToken */, [isNonJsxSameLineTokenContext, isTypeArgumentOrParameterOrAssertionContext], 16 /* DeleteSpace */),
-      rule("NoSpaceAfterOpenAngularBracket", 30 /* LessThanToken */, anyToken, [isNonJsxSameLineTokenContext, isTypeArgumentOrParameterOrAssertionContext], 16 /* DeleteSpace */),
-      rule("NoSpaceBeforeCloseAngularBracket", anyToken, 32 /* GreaterThanToken */, [isNonJsxSameLineTokenContext, isTypeArgumentOrParameterOrAssertionContext], 16 /* DeleteSpace */),
-      rule("NoSpaceAfterCloseAngularBracket", 32 /* GreaterThanToken */, [21 /* OpenParenToken */, 23 /* OpenBracketToken */, 32 /* GreaterThanToken */, 28 /* CommaToken */], [
-        isNonJsxSameLineTokenContext,
-        isTypeArgumentOrParameterOrAssertionContext,
-        isNotFunctionDeclContext,
-        isNonTypeAssertionContext
-      ], 16 /* DeleteSpace */),
-      // decorators
-      rule("SpaceBeforeAt", [22 /* CloseParenToken */, 80 /* Identifier */], 60 /* AtToken */, [isNonJsxSameLineTokenContext], 4 /* InsertSpace */),
-      rule("NoSpaceAfterAt", 60 /* AtToken */, anyToken, [isNonJsxSameLineTokenContext], 16 /* DeleteSpace */),
-      // Insert space after @ in decorator
-      rule(
-        "SpaceAfterDecorator",
-        anyToken,
-        [
-          128 /* AbstractKeyword */,
-          80 /* Identifier */,
-          95 /* ExportKeyword */,
-          90 /* DefaultKeyword */,
-          86 /* ClassKeyword */,
-          126 /* StaticKeyword */,
-          125 /* PublicKeyword */,
-          123 /* PrivateKeyword */,
-          124 /* ProtectedKeyword */,
-          139 /* GetKeyword */,
-          153 /* SetKeyword */,
-          23 /* OpenBracketToken */,
-          42 /* AsteriskToken */
-        ],
-        [isEndOfDecoratorContextOnSameLine],
-        4 /* InsertSpace */
-      ),
-      rule("NoSpaceBeforeNonNullAssertionOperator", anyToken, 54 /* ExclamationToken */, [isNonJsxSameLineTokenContext, isNonNullAssertionContext], 16 /* DeleteSpace */),
-      rule("NoSpaceAfterNewKeywordOnConstructorSignature", 105 /* NewKeyword */, 21 /* OpenParenToken */, [isNonJsxSameLineTokenContext, isConstructorSignatureContext], 16 /* DeleteSpace */),
-      rule("SpaceLessThanAndNonJSXTypeAnnotation", 30 /* LessThanToken */, 30 /* LessThanToken */, [isNonJsxSameLineTokenContext], 4 /* InsertSpace */)
-    ];
-    const userConfigurableRules = [
-      // Treat constructor as an identifier in a function declaration, and remove spaces between constructor and following left parentheses
-      rule("SpaceAfterConstructor", 137 /* ConstructorKeyword */, 21 /* OpenParenToken */, [isOptionEnabled("insertSpaceAfterConstructor"), isNonJsxSameLineTokenContext], 4 /* InsertSpace */),
-      rule("NoSpaceAfterConstructor", 137 /* ConstructorKeyword */, 21 /* OpenParenToken */, [isOptionDisabledOrUndefined("insertSpaceAfterConstructor"), isNonJsxSameLineTokenContext], 16 /* DeleteSpace */),
-      rule("SpaceAfterComma", 28 /* CommaToken */, anyToken, [isOptionEnabled("insertSpaceAfterCommaDelimiter"), isNonJsxSameLineTokenContext, isNonJsxElementOrFragmentContext, isNextTokenNotCloseBracket, isNextTokenNotCloseParen], 4 /* InsertSpace */),
-      rule("NoSpaceAfterComma", 28 /* CommaToken */, anyToken, [isOptionDisabledOrUndefined("insertSpaceAfterCommaDelimiter"), isNonJsxSameLineTokenContext, isNonJsxElementOrFragmentContext], 16 /* DeleteSpace */),
-      // Insert space after function keyword for anonymous functions
-      rule("SpaceAfterAnonymousFunctionKeyword", [100 /* FunctionKeyword */, 42 /* AsteriskToken */], 21 /* OpenParenToken */, [isOptionEnabled("insertSpaceAfterFunctionKeywordForAnonymousFunctions"), isFunctionDeclContext], 4 /* InsertSpace */),
-      rule("NoSpaceAfterAnonymousFunctionKeyword", [100 /* FunctionKeyword */, 42 /* AsteriskToken */], 21 /* OpenParenToken */, [isOptionDisabledOrUndefined("insertSpaceAfterFunctionKeywordForAnonymousFunctions"), isFunctionDeclContext], 16 /* DeleteSpace */),
-      // Insert space after keywords in control flow statements
-      rule("SpaceAfterKeywordInControl", keywords, 21 /* OpenParenToken */, [isOptionEnabled("insertSpaceAfterKeywordsInControlFlowStatements"), isControlDeclContext], 4 /* InsertSpace */),
-      rule("NoSpaceAfterKeywordInControl", keywords, 21 /* OpenParenToken */, [isOptionDisabledOrUndefined("insertSpaceAfterKeywordsInControlFlowStatements"), isControlDeclContext], 16 /* DeleteSpace */),
-      // Insert space after opening and before closing nonempty parenthesis
-      rule("SpaceAfterOpenParen", 21 /* OpenParenToken */, anyToken, [isOptionEnabled("insertSpaceAfterOpeningAndBeforeClosingNonemptyParenthesis"), isNonJsxSameLineTokenContext], 4 /* InsertSpace */),
-      rule("SpaceBeforeCloseParen", anyToken, 22 /* CloseParenToken */, [isOptionEnabled("insertSpaceAfterOpeningAndBeforeClosingNonemptyParenthesis"), isNonJsxSameLineTokenContext], 4 /* InsertSpace */),
-      rule("SpaceBetweenOpenParens", 21 /* OpenParenToken */, 21 /* OpenParenToken */, [isOptionEnabled("insertSpaceAfterOpeningAndBeforeClosingNonemptyParenthesis"), isNonJsxSameLineTokenContext], 4 /* InsertSpace */),
-      rule("NoSpaceBetweenParens", 21 /* OpenParenToken */, 22 /* CloseParenToken */, [isNonJsxSameLineTokenContext], 16 /* DeleteSpace */),
-      rule("NoSpaceAfterOpenParen", 21 /* OpenParenToken */, anyToken, [isOptionDisabledOrUndefined("insertSpaceAfterOpeningAndBeforeClosingNonemptyParenthesis"), isNonJsxSameLineTokenContext], 16 /* DeleteSpace */),
-      rule("NoSpaceBeforeCloseParen", anyToken, 22 /* CloseParenToken */, [isOptionDisabledOrUndefined("insertSpaceAfterOpeningAndBeforeClosingNonemptyParenthesis"), isNonJsxSameLineTokenContext], 16 /* DeleteSpace */),
-      // Insert space after opening and before closing nonempty brackets
-      rule("SpaceAfterOpenBracket", 23 /* OpenBracketToken */, anyToken, [isOptionEnabled("insertSpaceAfterOpeningAndBeforeClosingNonemptyBrackets"), isNonJsxSameLineTokenContext], 4 /* InsertSpace */),
-      rule("SpaceBeforeCloseBracket", anyToken, 24 /* CloseBracketToken */, [isOptionEnabled("insertSpaceAfterOpeningAndBeforeClosingNonemptyBrackets"), isNonJsxSameLineTokenContext], 4 /* InsertSpace */),
-      rule("NoSpaceBetweenBrackets", 23 /* OpenBracketToken */, 24 /* CloseBracketToken */, [isNonJsxSameLineTokenContext], 16 /* DeleteSpace */),
-      rule("NoSpaceAfterOpenBracket", 23 /* OpenBracketToken */, anyToken, [isOptionDisabledOrUndefined("insertSpaceAfterOpeningAndBeforeClosingNonemptyBrackets"), isNonJsxSameLineTokenContext], 16 /* DeleteSpace */),
-      rule("NoSpaceBeforeCloseBracket", anyToken, 24 /* CloseBracketToken */, [isOptionDisabledOrUndefined("insertSpaceAfterOpeningAndBeforeClosingNonemptyBrackets"), isNonJsxSameLineTokenContext], 16 /* DeleteSpace */),
-      // Insert a space after { and before } in single-line contexts, but remove space from empty object literals {}.
-      rule("SpaceAfterOpenBrace", 19 /* OpenBraceToken */, anyToken, [isOptionEnabledOrUndefined("insertSpaceAfterOpeningAndBeforeClosingNonemptyBraces"), isBraceWrappedContext], 4 /* InsertSpace */),
-      rule("SpaceBeforeCloseBrace", anyToken, 20 /* CloseBraceToken */, [isOptionEnabledOrUndefined("insertSpaceAfterOpeningAndBeforeClosingNonemptyBraces"), isBraceWrappedContext], 4 /* InsertSpace */),
-      rule("NoSpaceBetweenEmptyBraceBrackets", 19 /* OpenBraceToken */, 20 /* CloseBraceToken */, [isNonJsxSameLineTokenContext, isObjectContext], 16 /* DeleteSpace */),
-      rule("NoSpaceAfterOpenBrace", 19 /* OpenBraceToken */, anyToken, [isOptionDisabled("insertSpaceAfterOpeningAndBeforeClosingNonemptyBraces"), isNonJsxSameLineTokenContext], 16 /* DeleteSpace */),
-      rule("NoSpaceBeforeCloseBrace", anyToken, 20 /* CloseBraceToken */, [isOptionDisabled("insertSpaceAfterOpeningAndBeforeClosingNonemptyBraces"), isNonJsxSameLineTokenContext], 16 /* DeleteSpace */),
-      // Insert a space after opening and before closing empty brace brackets
-      rule("SpaceBetweenEmptyBraceBrackets", 19 /* OpenBraceToken */, 20 /* CloseBraceToken */, [isOptionEnabled("insertSpaceAfterOpeningAndBeforeClosingEmptyBraces")], 4 /* InsertSpace */),
-      rule("NoSpaceBetweenEmptyBraceBrackets", 19 /* OpenBraceToken */, 20 /* CloseBraceToken */, [isOptionDisabled("insertSpaceAfterOpeningAndBeforeClosingEmptyBraces"), isNonJsxSameLineTokenContext], 16 /* DeleteSpace */),
-      // Insert space after opening and before closing template string braces
-      rule("SpaceAfterTemplateHeadAndMiddle", [16 /* TemplateHead */, 17 /* TemplateMiddle */], anyToken, [isOptionEnabled("insertSpaceAfterOpeningAndBeforeClosingTemplateStringBraces"), isNonJsxTextContext], 4 /* InsertSpace */, 1 /* CanDeleteNewLines */),
-      rule("SpaceBeforeTemplateMiddleAndTail", anyToken, [17 /* TemplateMiddle */, 18 /* TemplateTail */], [isOptionEnabled("insertSpaceAfterOpeningAndBeforeClosingTemplateStringBraces"), isNonJsxSameLineTokenContext], 4 /* InsertSpace */),
-      rule("NoSpaceAfterTemplateHeadAndMiddle", [16 /* TemplateHead */, 17 /* TemplateMiddle */], anyToken, [isOptionDisabledOrUndefined("insertSpaceAfterOpeningAndBeforeClosingTemplateStringBraces"), isNonJsxTextContext], 16 /* DeleteSpace */, 1 /* CanDeleteNewLines */),
-      rule("NoSpaceBeforeTemplateMiddleAndTail", anyToken, [17 /* TemplateMiddle */, 18 /* TemplateTail */], [isOptionDisabledOrUndefined("insertSpaceAfterOpeningAndBeforeClosingTemplateStringBraces"), isNonJsxSameLineTokenContext], 16 /* DeleteSpace */),
-      // No space after { and before } in JSX expression
-      rule("SpaceAfterOpenBraceInJsxExpression", 19 /* OpenBraceToken */, anyToken, [isOptionEnabled("insertSpaceAfterOpeningAndBeforeClosingJsxExpressionBraces"), isNonJsxSameLineTokenContext, isJsxExpressionContext], 4 /* InsertSpace */),
-      rule("SpaceBeforeCloseBraceInJsxExpression", anyToken, 20 /* CloseBraceToken */, [isOptionEnabled("insertSpaceAfterOpeningAndBeforeClosingJsxExpressionBraces"), isNonJsxSameLineTokenContext, isJsxExpressionContext], 4 /* InsertSpace */),
-      rule("NoSpaceAfterOpenBraceInJsxExpression", 19 /* OpenBraceToken */, anyToken, [isOptionDisabledOrUndefined("insertSpaceAfterOpeningAndBeforeClosingJsxExpressionBraces"), isNonJsxSameLineTokenContext, isJsxExpressionContext], 16 /* DeleteSpace */),
-      rule("NoSpaceBeforeCloseBraceInJsxExpression", anyToken, 20 /* CloseBraceToken */, [isOptionDisabledOrUndefined("insertSpaceAfterOpeningAndBeforeClosingJsxExpressionBraces"), isNonJsxSameLineTokenContext, isJsxExpressionContext], 16 /* DeleteSpace */),
-      // Insert space after semicolon in for statement
-      rule("SpaceAfterSemicolonInFor", 27 /* SemicolonToken */, anyToken, [isOptionEnabled("insertSpaceAfterSemicolonInForStatements"), isNonJsxSameLineTokenContext, isForContext], 4 /* InsertSpace */),
-      rule("NoSpaceAfterSemicolonInFor", 27 /* SemicolonToken */, anyToken, [isOptionDisabledOrUndefined("insertSpaceAfterSemicolonInForStatements"), isNonJsxSameLineTokenContext, isForContext], 16 /* DeleteSpace */),
-      // Insert space before and after binary operators
-      rule("SpaceBeforeBinaryOperator", anyToken, binaryOperators, [isOptionEnabled("insertSpaceBeforeAndAfterBinaryOperators"), isNonJsxSameLineTokenContext, isBinaryOpContext], 4 /* InsertSpace */),
-      rule("SpaceAfterBinaryOperator", binaryOperators, anyToken, [isOptionEnabled("insertSpaceBeforeAndAfterBinaryOperators"), isNonJsxSameLineTokenContext, isBinaryOpContext], 4 /* InsertSpace */),
-      rule("NoSpaceBeforeBinaryOperator", anyToken, binaryOperators, [isOptionDisabledOrUndefined("insertSpaceBeforeAndAfterBinaryOperators"), isNonJsxSameLineTokenContext, isBinaryOpContext], 16 /* DeleteSpace */),
-      rule("NoSpaceAfterBinaryOperator", binaryOperators, anyToken, [isOptionDisabledOrUndefined("insertSpaceBeforeAndAfterBinaryOperators"), isNonJsxSameLineTokenContext, isBinaryOpContext], 16 /* DeleteSpace */),
-      rule("SpaceBeforeOpenParenInFuncDecl", anyToken, 21 /* OpenParenToken */, [isOptionEnabled("insertSpaceBeforeFunctionParenthesis"), isNonJsxSameLineTokenContext, isFunctionDeclContext], 4 /* InsertSpace */),
-      rule("NoSpaceBeforeOpenParenInFuncDecl", anyToken, 21 /* OpenParenToken */, [isOptionDisabledOrUndefined("insertSpaceBeforeFunctionParenthesis"), isNonJsxSameLineTokenContext, isFunctionDeclContext], 16 /* DeleteSpace */),
-      // Open Brace braces after control block
-      rule("NewLineBeforeOpenBraceInControl", controlOpenBraceLeftTokenRange, 19 /* OpenBraceToken */, [isOptionEnabled("placeOpenBraceOnNewLineForControlBlocks"), isControlDeclContext, isBeforeMultilineBlockContext], 8 /* InsertNewLine */, 1 /* CanDeleteNewLines */),
-      // Open Brace braces after function
-      // TypeScript: Function can have return types, which can be made of tons of different token kinds
-      rule("NewLineBeforeOpenBraceInFunction", functionOpenBraceLeftTokenRange, 19 /* OpenBraceToken */, [isOptionEnabled("placeOpenBraceOnNewLineForFunctions"), isFunctionDeclContext, isBeforeMultilineBlockContext], 8 /* InsertNewLine */, 1 /* CanDeleteNewLines */),
-      // Open Brace braces after TypeScript module/class/interface
-      rule("NewLineBeforeOpenBraceInTypeScriptDeclWithBlock", typeScriptOpenBraceLeftTokenRange, 19 /* OpenBraceToken */, [isOptionEnabled("placeOpenBraceOnNewLineForFunctions"), isTypeScriptDeclWithBlockContext, isBeforeMultilineBlockContext], 8 /* InsertNewLine */, 1 /* CanDeleteNewLines */),
-      rule("SpaceAfterTypeAssertion", 32 /* GreaterThanToken */, anyToken, [isOptionEnabled("insertSpaceAfterTypeAssertion"), isNonJsxSameLineTokenContext, isTypeAssertionContext], 4 /* InsertSpace */),
-      rule("NoSpaceAfterTypeAssertion", 32 /* GreaterThanToken */, anyToken, [isOptionDisabledOrUndefined("insertSpaceAfterTypeAssertion"), isNonJsxSameLineTokenContext, isTypeAssertionContext], 16 /* DeleteSpace */),
-      rule("SpaceBeforeTypeAnnotation", anyToken, [58 /* QuestionToken */, 59 /* ColonToken */], [isOptionEnabled("insertSpaceBeforeTypeAnnotation"), isNonJsxSameLineTokenContext, isTypeAnnotationContext], 4 /* InsertSpace */),
-      rule("NoSpaceBeforeTypeAnnotation", anyToken, [58 /* QuestionToken */, 59 /* ColonToken */], [isOptionDisabledOrUndefined("insertSpaceBeforeTypeAnnotation"), isNonJsxSameLineTokenContext, isTypeAnnotationContext], 16 /* DeleteSpace */),
-      rule("NoOptionalSemicolon", 27 /* SemicolonToken */, anyTokenIncludingEOF, [optionEquals("semicolons", "remove" /* Remove */), isSemicolonDeletionContext], 32 /* DeleteToken */),
-      rule("OptionalSemicolon", anyToken, anyTokenIncludingEOF, [optionEquals("semicolons", "insert" /* Insert */), isSemicolonInsertionContext], 64 /* InsertTrailingSemicolon */)
-    ];
-    const lowPriorityCommonRules = [
-      // Space after keyword but not before ; or : or ?
-      rule("NoSpaceBeforeSemicolon", anyToken, 27 /* SemicolonToken */, [isNonJsxSameLineTokenContext], 16 /* DeleteSpace */),
-      rule("SpaceBeforeOpenBraceInControl", controlOpenBraceLeftTokenRange, 19 /* OpenBraceToken */, [isOptionDisabledOrUndefinedOrTokensOnSameLine("placeOpenBraceOnNewLineForControlBlocks"), isControlDeclContext, isNotFormatOnEnter, isSameLineTokenOrBeforeBlockContext], 4 /* InsertSpace */, 1 /* CanDeleteNewLines */),
-      rule("SpaceBeforeOpenBraceInFunction", functionOpenBraceLeftTokenRange, 19 /* OpenBraceToken */, [isOptionDisabledOrUndefinedOrTokensOnSameLine("placeOpenBraceOnNewLineForFunctions"), isFunctionDeclContext, isBeforeBlockContext, isNotFormatOnEnter, isSameLineTokenOrBeforeBlockContext], 4 /* InsertSpace */, 1 /* CanDeleteNewLines */),
-      rule("SpaceBeforeOpenBraceInTypeScriptDeclWithBlock", typeScriptOpenBraceLeftTokenRange, 19 /* OpenBraceToken */, [isOptionDisabledOrUndefinedOrTokensOnSameLine("placeOpenBraceOnNewLineForFunctions"), isTypeScriptDeclWithBlockContext, isNotFormatOnEnter, isSameLineTokenOrBeforeBlockContext], 4 /* InsertSpace */, 1 /* CanDeleteNewLines */),
-      rule("NoSpaceBeforeComma", anyToken, 28 /* CommaToken */, [isNonJsxSameLineTokenContext], 16 /* DeleteSpace */),
-      // No space before and after indexer `x[]`
-      rule("NoSpaceBeforeOpenBracket", anyTokenExcept(134 /* AsyncKeyword */, 84 /* CaseKeyword */), 23 /* OpenBracketToken */, [isNonJsxSameLineTokenContext], 16 /* DeleteSpace */),
-      rule("NoSpaceAfterCloseBracket", 24 /* CloseBracketToken */, anyToken, [isNonJsxSameLineTokenContext, isNotBeforeBlockInFunctionDeclarationContext], 16 /* DeleteSpace */),
-      rule("SpaceAfterSemicolon", 27 /* SemicolonToken */, anyToken, [isNonJsxSameLineTokenContext], 4 /* InsertSpace */),
-      // Remove extra space between for and await
-      rule("SpaceBetweenForAndAwaitKeyword", 99 /* ForKeyword */, 135 /* AwaitKeyword */, [isNonJsxSameLineTokenContext], 4 /* InsertSpace */),
-      // Add a space between statements. All keywords except (do,else,case) has open/close parens after them.
-      // So, we have a rule to add a space for [),Any], [do,Any], [else,Any], and [case,Any]
-      rule(
-        "SpaceBetweenStatements",
-        [22 /* CloseParenToken */, 92 /* DoKeyword */, 93 /* ElseKeyword */, 84 /* CaseKeyword */],
-        anyToken,
-        [isNonJsxSameLineTokenContext, isNonJsxElementOrFragmentContext, isNotForContext],
-        4 /* InsertSpace */
-      ),
-      // This low-pri rule takes care of "try {", "catch {" and "finally {" in case the rule SpaceBeforeOpenBraceInControl didn't execute on FormatOnEnter.
-      rule("SpaceAfterTryCatchFinally", [113 /* TryKeyword */, 85 /* CatchKeyword */, 98 /* FinallyKeyword */], 19 /* OpenBraceToken */, [isNonJsxSameLineTokenContext], 4 /* InsertSpace */)
-    ];
-    return [
-      ...highPriorityCommonRules,
-      ...userConfigurableRules,
-      ...lowPriorityCommonRules
-    ];
-  }
-  function rule(debugName, left, right, context, action, flags = 0 /* None */) {
-    return { leftTokenRange: toTokenRange(left), rightTokenRange: toTokenRange(right), rule: { debugName, context, action, flags } };
-  }
-  function tokenRangeFrom(tokens) {
-    return { tokens, isSpecific: true };
-  }
-  function toTokenRange(arg) {
-    return typeof arg === "number" ? tokenRangeFrom([arg]) : isArray(arg) ? tokenRangeFrom(arg) : arg;
-  }
-  function tokenRangeFromRange(from, to, except = []) {
-    const tokens = [];
-    for (let token = from; token <= to; token++) {
-      if (!contains(except, token)) {
-        tokens.push(token);
-      }
+          proj.rootFiles = filesToKeep;
+          return excludedFiles;
+        }
+        openExternalProject(proj) {
+          proj.typeAcquisition = proj.typeAcquisition || {};
+          proj.typeAcquisition.include = proj.typeAcquisition.include || [];
+          proj.typeAcquisition.exclude = proj.typeAcquisition.exclude || [];
+          if (proj.typeAcquisition.enable === void 0) {
+            proj.typeAcquisition.enable = hasNoTypeScriptSource(proj.rootFiles.map((f) => f.fileName));
+          }
+          const excludedFiles = this.applySafeList(proj);
+          let tsConfigFiles;
+          const rootFiles = [];
+          for (const file of proj.rootFiles) {
+            const normalized = toNormalizedPath(file.fileName);
+            if (getBaseConfigFileName(normalized)) {
+              if (this.serverMode === 0 /* Semantic */ && this.host.fileExists(normalized)) {
+                (tsConfigFiles || (tsConfigFiles = [])).push(normalized);
+              }
+            } else {
+              rootFiles.push(file);
+            }
+          }
+          if (tsConfigFiles) {
+            tsConfigFiles.sort();
+          }
+          const externalProject = this.findExternalProjectByProjectName(proj.projectFileName);
+          let exisingConfigFiles;
+          if (externalProject) {
+            externalProject.excludedFiles = excludedFiles;
+            if (!tsConfigFiles) {
+              const compilerOptions = convertCompilerOptions(proj.options);
+              const watchOptionsAndErrors = convertWatchOptions(proj.options, externalProject.getCurrentDirectory());
+              const lastFileExceededProgramSize = this.getFilenameForExceededTotalSizeLimitForNonTsFiles(proj.projectFileName, compilerOptions, proj.rootFiles, externalFilePropertyReader);
+              if (lastFileExceededProgramSize) {
+                externalProject.disableLanguageService(lastFileExceededProgramSize);
+              } else {
+                externalProject.enableLanguageService();
+              }
+              externalProject.setProjectErrors(watchOptionsAndErrors == null ? void 0 : watchOptionsAndErrors.errors);
+              this.updateRootAndOptionsOfNonInferredProject(externalProject, proj.rootFiles, externalFilePropertyReader, compilerOptions, proj.typeAcquisition, proj.options.compileOnSave, watchOptionsAndErrors == null ? void 0 : watchOptionsAndErrors.watchOptions);
+              externalProject.updateGraph();
+              return;
+            }
+            this.closeExternalProject(proj.projectFileName);
+          } else if (this.externalProjectToConfiguredProjectMap.get(proj.projectFileName)) {
+            if (!tsConfigFiles) {
+              this.closeExternalProject(proj.projectFileName);
+            } else {
+              const oldConfigFiles = this.externalProjectToConfiguredProjectMap.get(proj.projectFileName);
+              let iNew = 0;
+              let iOld = 0;
+              while (iNew < tsConfigFiles.length && iOld < oldConfigFiles.length) {
+                const newConfig = tsConfigFiles[iNew];
+                const oldConfig = oldConfigFiles[iOld];
+                if (oldConfig < newConfig) {
+                  this.closeConfiguredProjectReferencedFromExternalProject(oldConfig);
+                  iOld++;
+                } else if (oldConfig > newConfig) {
+                  iNew++;
+                } else {
+                  (exisingConfigFiles || (exisingConfigFiles = [])).push(oldConfig);
+                  iOld++;
+                  iNew++;
+                }
+              }
+              for (let i = iOld; i < oldConfigFiles.length; i++) {
+                this.closeConfiguredProjectReferencedFromExternalProject(oldConfigFiles[i]);
+              }
+            }
+          }
+          if (tsConfigFiles) {
+            this.externalProjectToConfiguredProjectMap.set(proj.projectFileName, tsConfigFiles);
+            for (const tsconfigFile of tsConfigFiles) {
+              let project = this.findConfiguredProjectByProjectName(tsconfigFile);
+              if (!project) {
+                project = this.getHostPreferences().lazyConfiguredProjectsFromExternalProject ? this.createConfiguredProjectWithDelayLoad(tsconfigFile, `Creating configured project in external project: ${proj.projectFileName}`) : this.createLoadAndUpdateConfiguredProject(tsconfigFile, `Creating configured project in external project: ${proj.projectFileName}`);
+              }
+              if (project && !contains(exisingConfigFiles, tsconfigFile)) {
+                project.addExternalProjectReference();
+              }
+            }
+          } else {
+            this.externalProjectToConfiguredProjectMap.delete(proj.projectFileName);
+            const project = this.createExternalProject(proj.projectFileName, rootFiles, proj.options, proj.typeAcquisition, excludedFiles);
+            project.updateGraph();
+          }
+        }
+        hasDeferredExtension() {
+          for (const extension of this.hostConfiguration.extraFileExtensions) {
+            if (extension.scriptKind === 7 /* Deferred */) {
+              return true;
+            }
+          }
+          return false;
+        }
+        /**
+         * Performs the initial steps of enabling a plugin by finding and instantiating the module for a plugin either asynchronously or synchronously
+         * @internal
+         */
+        requestEnablePlugin(project, pluginConfigEntry, searchPaths) {
+          if (!this.host.importPlugin && !this.host.require) {
+            this.logger.info("Plugins were requested but not running in environment that supports 'require'. Nothing will be loaded");
+            return;
+          }
+          this.logger.info(`Enabling plugin ${pluginConfigEntry.name} from candidate paths: ${searchPaths.join(",")}`);
+          if (!pluginConfigEntry.name || parsePackageName(pluginConfigEntry.name).rest) {
+            this.logger.info(`Skipped loading plugin ${pluginConfigEntry.name || JSON.stringify(pluginConfigEntry)} because only package name is allowed plugin name`);
+            return;
+          }
+          if (this.host.importPlugin) {
+            const importPromise = Project3.importServicePluginAsync(
+              pluginConfigEntry,
+              searchPaths,
+              this.host,
+              (s) => this.logger.info(s)
+            );
+            this.pendingPluginEnablements ?? (this.pendingPluginEnablements = /* @__PURE__ */ new Map());
+            let promises = this.pendingPluginEnablements.get(project);
+            if (!promises)
+              this.pendingPluginEnablements.set(project, promises = []);
+            promises.push(importPromise);
+            return;
+          }
+          this.endEnablePlugin(
+            project,
+            Project3.importServicePluginSync(
+              pluginConfigEntry,
+              searchPaths,
+              this.host,
+              (s) => this.logger.info(s)
+            )
+          );
+        }
+        /**
+         * Performs the remaining steps of enabling a plugin after its module has been instantiated.
+         * @internal
+         */
+        endEnablePlugin(project, { pluginConfigEntry, resolvedModule, errorLogs }) {
+          var _a;
+          if (resolvedModule) {
+            const configurationOverride = (_a = this.currentPluginConfigOverrides) == null ? void 0 : _a.get(pluginConfigEntry.name);
+            if (configurationOverride) {
+              const pluginName = pluginConfigEntry.name;
+              pluginConfigEntry = configurationOverride;
+              pluginConfigEntry.name = pluginName;
+            }
+            project.enableProxy(resolvedModule, pluginConfigEntry);
+          } else {
+            forEach(errorLogs, (message) => this.logger.info(message));
+            this.logger.info(`Couldn't find ${pluginConfigEntry.name}`);
+          }
+        }
+        /** @internal */
+        hasNewPluginEnablementRequests() {
+          return !!this.pendingPluginEnablements;
+        }
+        /** @internal */
+        hasPendingPluginEnablements() {
+          return !!this.currentPluginEnablementPromise;
+        }
+        /**
+         * Waits for any ongoing plugin enablement requests to complete.
+         *
+         * @internal
+         */
+        async waitForPendingPlugins() {
+          while (this.currentPluginEnablementPromise) {
+            await this.currentPluginEnablementPromise;
+          }
+        }
+        /**
+         * Starts enabling any requested plugins without waiting for the result.
+         *
+         * @internal
+         */
+        enableRequestedPlugins() {
+          if (this.pendingPluginEnablements) {
+            void this.enableRequestedPluginsAsync();
+          }
+        }
+        async enableRequestedPluginsAsync() {
+          if (this.currentPluginEnablementPromise) {
+            await this.waitForPendingPlugins();
+          }
+          if (!this.pendingPluginEnablements) {
+            return;
+          }
+          const entries = arrayFrom(this.pendingPluginEnablements.entries());
+          this.pendingPluginEnablements = void 0;
+          this.currentPluginEnablementPromise = this.enableRequestedPluginsWorker(entries);
+          await this.currentPluginEnablementPromise;
+        }
+        async enableRequestedPluginsWorker(pendingPlugins) {
+          Debug.assert(this.currentPluginEnablementPromise === void 0);
+          await Promise.all(map(pendingPlugins, ([project, promises]) => this.enableRequestedPluginsForProjectAsync(project, promises)));
+          this.currentPluginEnablementPromise = void 0;
+          this.sendProjectsUpdatedInBackgroundEvent();
+        }
+        async enableRequestedPluginsForProjectAsync(project, promises) {
+          const results = await Promise.all(promises);
+          if (project.isClosed()) {
+            return;
+          }
+          for (const result of results) {
+            this.endEnablePlugin(project, result);
+          }
+          this.delayUpdateProjectGraph(project);
+        }
+        configurePlugin(args) {
+          this.forEachEnabledProject((project) => project.onPluginConfigurationChanged(args.pluginName, args.configuration));
+          this.currentPluginConfigOverrides = this.currentPluginConfigOverrides || /* @__PURE__ */ new Map();
+          this.currentPluginConfigOverrides.set(args.pluginName, args.configuration);
+        }
+        /** @internal */
+        getPackageJsonsVisibleToFile(fileName, rootDir) {
+          const packageJsonCache = this.packageJsonCache;
+          const rootPath = rootDir && this.toPath(rootDir);
+          const filePath = this.toPath(fileName);
+          const result = [];
+          const processDirectory = (directory) => {
+            switch (packageJsonCache.directoryHasPackageJson(directory)) {
+              case 3 /* Maybe */:
+                packageJsonCache.searchDirectoryAndAncestors(directory);
+                return processDirectory(directory);
+              case -1 /* True */:
+                const packageJsonFileName = combinePaths(directory, "package.json");
+                this.watchPackageJsonFile(packageJsonFileName);
+                const info = packageJsonCache.getInDirectory(directory);
+                if (info)
+                  result.push(info);
+            }
+            if (rootPath && rootPath === directory) {
+              return true;
+            }
+          };
+          forEachAncestorDirectory(getDirectoryPath(filePath), processDirectory);
+          return result;
+        }
+        /** @internal */
+        getNearestAncestorDirectoryWithPackageJson(fileName) {
+          return forEachAncestorDirectory(fileName, (directory) => {
+            switch (this.packageJsonCache.directoryHasPackageJson(this.toPath(directory))) {
+              case -1 /* True */:
+                return directory;
+              case 0 /* False */:
+                return void 0;
+              case 3 /* Maybe */:
+                return this.host.fileExists(combinePaths(directory, "package.json")) ? directory : void 0;
+            }
+          });
+        }
+        /** @internal */
+        watchPnpFile() {
+          const pnpApiPath = getPnpApiPath(__filename);
+          if (!pnpApiPath) {
+            return;
+          }
+          return this.watchFactory.watchFile(
+            pnpApiPath,
+            () => {
+              this.forEachProject((project) => {
+                for (const info of project.getScriptInfos()) {
+                  project.resolutionCache.invalidateResolutionOfFile(info.path);
+                }
+                project.markAsDirty();
+                updateProjectIfDirty(project);
+              });
+              this.delayEnsureProjectForOpenFiles();
+            },
+            250 /* Low */,
+            this.hostConfiguration.watchOptions,
+            WatchType.ConfigFile
+          );
+        }
+        /** @internal */
+        watchPackageJsonFile(path) {
+          const watchers = this.packageJsonFilesMap || (this.packageJsonFilesMap = /* @__PURE__ */ new Map());
+          if (!watchers.has(path)) {
+            this.invalidateProjectPackageJson(path);
+            watchers.set(
+              path,
+              this.watchFactory.watchFile(
+                path,
+                (fileName, eventKind) => {
+                  const path2 = this.toPath(fileName);
+                  switch (eventKind) {
+                    case 0 /* Created */:
+                      return Debug.fail();
+                    case 1 /* Changed */:
+                      this.packageJsonCache.addOrUpdate(path2);
+                      this.invalidateProjectPackageJson(path2);
+                      break;
+                    case 2 /* Deleted */:
+                      this.packageJsonCache.delete(path2);
+                      this.invalidateProjectPackageJson(path2);
+                      watchers.get(path2).close();
+                      watchers.delete(path2);
+                  }
+                },
+                250 /* Low */,
+                this.hostConfiguration.watchOptions,
+                WatchType.PackageJson
+              )
+            );
+          }
+        }
+        /** @internal */
+        onAddPackageJson(path) {
+          this.packageJsonCache.addOrUpdate(path);
+          this.watchPackageJsonFile(path);
+        }
+        /** @internal */
+        includePackageJsonAutoImports() {
+          switch (this.hostConfiguration.preferences.includePackageJsonAutoImports) {
+            case "on":
+              return 1 /* On */;
+            case "off":
+              return 0 /* Off */;
+            default:
+              return 2 /* Auto */;
+          }
+        }
+        /** @internal */
+        invalidateProjectPackageJson(packageJsonPath) {
+          this.configuredProjects.forEach(invalidate);
+          this.inferredProjects.forEach(invalidate);
+          this.externalProjects.forEach(invalidate);
+          function invalidate(project) {
+            if (packageJsonPath) {
+              project.onPackageJsonChange(packageJsonPath);
+            } else {
+              project.onAutoImportProviderSettingsChanged();
+            }
+          }
+        }
+        /** @internal */
+        getIncompleteCompletionsCache() {
+          return this.incompleteCompletionsCache || (this.incompleteCompletionsCache = createIncompleteCompletionsCache());
+        }
+      };
+      /** Makes a filename safe to insert in a RegExp */
+      _ProjectService.filenameEscapeRegexp = /[-/\\^$*+?.()|[\]{}]/g;
+      ProjectService3 = _ProjectService;
     }
-    return tokenRangeFrom(tokens);
-  }
-  function optionEquals(optionName, optionValue) {
-    return (context) => context.options && context.options[optionName] === optionValue;
-  }
-  function isOptionEnabled(optionName) {
-    return (context) => context.options && hasProperty(context.options, optionName) && !!context.options[optionName];
-  }
-  function isOptionDisabled(optionName) {
-    return (context) => context.options && hasProperty(context.options, optionName) && !context.options[optionName];
-  }
-  function isOptionDisabledOrUndefined(optionName) {
-    return (context) => !context.options || !hasProperty(context.options, optionName) || !context.options[optionName];
-  }
-  function isOptionDisabledOrUndefinedOrTokensOnSameLine(optionName) {
-    return (context) => !context.options || !hasProperty(context.options, optionName) || !context.options[optionName] || context.TokensAreOnSameLine();
-  }
-  function isOptionEnabledOrUndefined(optionName) {
-    return (context) => !context.options || !hasProperty(context.options, optionName) || !!context.options[optionName];
-  }
-  function isForContext(context) {
-    return context.contextNode.kind === 247 /* ForStatement */;
-  }
-  function isNotForContext(context) {
-    return !isForContext(context);
-  }
-  function isBinaryOpContext(context) {
-    switch (context.contextNode.kind) {
-      case 225 /* BinaryExpression */:
-        return context.contextNode.operatorToken.kind !== 28 /* CommaToken */;
-      case 226 /* ConditionalExpression */:
-      case 193 /* ConditionalType */:
-      case 233 /* AsExpression */:
-      case 280 /* ExportSpecifier */:
-      case 275 /* ImportSpecifier */:
-      case 181 /* TypePredicate */:
-      case 191 /* UnionType */:
-      case 192 /* IntersectionType */:
-      case 237 /* SatisfiesExpression */:
-        return true;
-      case 207 /* BindingElement */:
-      case 264 /* TypeAliasDeclaration */:
-      case 270 /* ImportEqualsDeclaration */:
-      case 276 /* ExportAssignment */:
-      case 259 /* VariableDeclaration */:
-      case 168 /* Parameter */:
-      case 305 /* EnumMember */:
-      case 171 /* PropertyDeclaration */:
-      case 170 /* PropertySignature */:
-        return context.currentTokenSpan.kind === 64 /* EqualsToken */ || context.nextTokenSpan.kind === 64 /* EqualsToken */;
-      case 248 /* ForInStatement */:
-      case 167 /* TypeParameter */:
-        return context.currentTokenSpan.kind === 103 /* InKeyword */ || context.nextTokenSpan.kind === 103 /* InKeyword */ || context.currentTokenSpan.kind === 64 /* EqualsToken */ || context.nextTokenSpan.kind === 64 /* EqualsToken */;
-      case 249 /* ForOfStatement */:
-        return context.currentTokenSpan.kind === 164 /* OfKeyword */ || context.nextTokenSpan.kind === 164 /* OfKeyword */;
+  });
+
+  // src/server/moduleSpecifierCache.ts
+  function createModuleSpecifierCache(host) {
+    let containedNodeModulesWatchers;
+    let cache;
+    let currentKey;
+    const result = {
+      get(fromFileName, toFileName2, preferences, options) {
+        if (!cache || currentKey !== key(fromFileName, preferences, options))
+          return void 0;
+        return cache.get(toFileName2);
+      },
+      set(fromFileName, toFileName2, preferences, options, modulePaths, moduleSpecifiers) {
+        ensureCache(fromFileName, preferences, options).set(toFileName2, createInfo(
+          modulePaths,
+          moduleSpecifiers,
+          /*isBlockedByPackageJsonDependencies*/
+          false
+        ));
+        if (moduleSpecifiers) {
+          for (const p of modulePaths) {
+            if (p.isInNodeModules) {
+              const nodeModulesPath = p.path.substring(0, p.path.indexOf(nodeModulesPathPart) + nodeModulesPathPart.length - 1);
+              if (!(containedNodeModulesWatchers == null ? void 0 : containedNodeModulesWatchers.has(nodeModulesPath))) {
+                (containedNodeModulesWatchers || (containedNodeModulesWatchers = /* @__PURE__ */ new Map())).set(
+                  nodeModulesPath,
+                  host.watchNodeModulesForPackageJsonChanges(nodeModulesPath)
+                );
+              }
+            }
+          }
+        }
+      },
+      setModulePaths(fromFileName, toFileName2, preferences, options, modulePaths) {
+        const cache2 = ensureCache(fromFileName, preferences, options);
+        const info = cache2.get(toFileName2);
+        if (info) {
+          info.modulePaths = modulePaths;
+        } else {
+          cache2.set(toFileName2, createInfo(
+            modulePaths,
+            /*moduleSpecifiers*/
+            void 0,
+            /*isBlockedByPackageJsonDependencies*/
+            void 0
+          ));
+        }
+      },
+      setBlockedByPackageJsonDependencies(fromFileName, toFileName2, preferences, options, isBlockedByPackageJsonDependencies) {
+        const cache2 = ensureCache(fromFileName, preferences, options);
+        const info = cache2.get(toFileName2);
+        if (info) {
+          info.isBlockedByPackageJsonDependencies = isBlockedByPackageJsonDependencies;
+        } else {
+          cache2.set(toFileName2, createInfo(
+            /*modulePaths*/
+            void 0,
+            /*moduleSpecifiers*/
+            void 0,
+            isBlockedByPackageJsonDependencies
+          ));
+        }
+      },
+      clear() {
+        containedNodeModulesWatchers == null ? void 0 : containedNodeModulesWatchers.forEach((watcher) => watcher.close());
+        cache == null ? void 0 : cache.clear();
+        containedNodeModulesWatchers == null ? void 0 : containedNodeModulesWatchers.clear();
+        currentKey = void 0;
+      },
+      count() {
+        return cache ? cache.size : 0;
+      }
+    };
+    if (Debug.isDebugging) {
+      Object.defineProperty(result, "__cache", { get: () => cache });
     }
-    return false;
-  }
-  function isNotBinaryOpContext(context) {
-    return !isBinaryOpContext(context);
-  }
-  function isNotTypeAnnotationContext(context) {
-    return !isTypeAnnotationContext(context);
-  }
-  function isTypeAnnotationContext(context) {
-    const contextKind = context.contextNode.kind;
-    return contextKind === 171 /* PropertyDeclaration */ || contextKind === 170 /* PropertySignature */ || contextKind === 168 /* Parameter */ || contextKind === 259 /* VariableDeclaration */ || isFunctionLikeKind(contextKind);
-  }
-  function isConditionalOperatorContext(context) {
-    return context.contextNode.kind === 226 /* ConditionalExpression */ || context.contextNode.kind === 193 /* ConditionalType */;
-  }
-  function isSameLineTokenOrBeforeBlockContext(context) {
-    return context.TokensAreOnSameLine() || isBeforeBlockContext(context);
-  }
-  function isBraceWrappedContext(context) {
-    return context.contextNode.kind === 205 /* ObjectBindingPattern */ || context.contextNode.kind === 199 /* MappedType */ || isSingleLineBlockContext(context);
-  }
-  function isBeforeMultilineBlockContext(context) {
-    return isBeforeBlockContext(context) && !(context.NextNodeAllOnSameLine() || context.NextNodeBlockIsOnOneLine());
-  }
-  function isMultilineBlockContext(context) {
-    return isBlockContext(context) && !(context.ContextNodeAllOnSameLine() || context.ContextNodeBlockIsOnOneLine());
-  }
-  function isSingleLineBlockContext(context) {
-    return isBlockContext(context) && (context.ContextNodeAllOnSameLine() || context.ContextNodeBlockIsOnOneLine());
-  }
-  function isBlockContext(context) {
-    return nodeIsBlockContext(context.contextNode);
-  }
-  function isBeforeBlockContext(context) {
-    return nodeIsBlockContext(context.nextTokenParent);
-  }
-  function nodeIsBlockContext(node) {
-    if (nodeIsTypeScriptDeclWithBlockContext(node)) {
-      return true;
+    return result;
+    function ensureCache(fromFileName, preferences, options) {
+      const newKey = key(fromFileName, preferences, options);
+      if (cache && currentKey !== newKey) {
+        result.clear();
+      }
+      currentKey = newKey;
+      return cache || (cache = /* @__PURE__ */ new Map());
     }
-    switch (node.kind) {
-      case 240 /* Block */:
-      case 268 /* CaseBlock */:
-      case 209 /* ObjectLiteralExpression */:
-      case 267 /* ModuleBlock */:
-        return true;
+    function key(fromFileName, preferences, options) {
+      return `${fromFileName},${preferences.importModuleSpecifierEnding},${preferences.importModuleSpecifierPreference},${options.overrideImportMode}`;
     }
-    return false;
-  }
-  function isFunctionDeclContext(context) {
-    switch (context.contextNode.kind) {
-      case 261 /* FunctionDeclaration */:
-      case 173 /* MethodDeclaration */:
-      case 172 /* MethodSignature */:
-      case 176 /* GetAccessor */:
-      case 177 /* SetAccessor */:
-      case 178 /* CallSignature */:
-      case 217 /* FunctionExpression */:
-      case 175 /* Constructor */:
-      case 218 /* ArrowFunction */:
-      case 263 /* InterfaceDeclaration */:
-        return true;
+    function createInfo(modulePaths, moduleSpecifiers, isBlockedByPackageJsonDependencies) {
+      return { modulePaths, moduleSpecifiers, isBlockedByPackageJsonDependencies };
     }
-    return false;
-  }
-  function isNotFunctionDeclContext(context) {
-    return !isFunctionDeclContext(context);
-  }
-  function isFunctionDeclarationOrFunctionExpressionContext(context) {
-    return context.contextNode.kind === 261 /* FunctionDeclaration */ || context.contextNode.kind === 217 /* FunctionExpression */;
-  }
-  function isTypeScriptDeclWithBlockContext(context) {
-    return nodeIsTypeScriptDeclWithBlockContext(context.contextNode);
   }
-  function nodeIsTypeScriptDeclWithBlockContext(node) {
-    switch (node.kind) {
-      case 262 /* ClassDeclaration */:
-      case 230 /* ClassExpression */:
-      case 263 /* InterfaceDeclaration */:
-      case 265 /* EnumDeclaration */:
-      case 186 /* TypeLiteral */:
-      case 266 /* ModuleDeclaration */:
-      case 277 /* ExportDeclaration */:
-      case 278 /* NamedExports */:
-      case 271 /* ImportDeclaration */:
-      case 274 /* NamedImports */:
-        return true;
+  var init_moduleSpecifierCache = __esm({
+    "src/server/moduleSpecifierCache.ts"() {
+      "use strict";
+      init_ts7();
     }
-    return false;
-  }
-  function isAfterCodeBlockContext(context) {
-    switch (context.currentTokenParent.kind) {
-      case 262 /* ClassDeclaration */:
-      case 266 /* ModuleDeclaration */:
-      case 265 /* EnumDeclaration */:
-      case 298 /* CatchClause */:
-      case 267 /* ModuleBlock */:
-      case 254 /* SwitchStatement */:
-        return true;
-      case 240 /* Block */: {
-        const blockParent = context.currentTokenParent.parent;
-        if (!blockParent || blockParent.kind !== 218 /* ArrowFunction */ && blockParent.kind !== 217 /* FunctionExpression */) {
-          return true;
-        }
+  });
+
+  // src/server/packageJsonCache.ts
+  function createPackageJsonCache(host) {
+    const packageJsons = /* @__PURE__ */ new Map();
+    const directoriesWithoutPackageJson = /* @__PURE__ */ new Map();
+    return {
+      addOrUpdate,
+      forEach: packageJsons.forEach.bind(packageJsons),
+      get: packageJsons.get.bind(packageJsons),
+      delete: (fileName) => {
+        packageJsons.delete(fileName);
+        directoriesWithoutPackageJson.set(getDirectoryPath(fileName), true);
+      },
+      getInDirectory: (directory) => {
+        return packageJsons.get(combinePaths(directory, "package.json")) || void 0;
+      },
+      directoryHasPackageJson,
+      searchDirectoryAndAncestors: (directory) => {
+        forEachAncestorDirectory(directory, (ancestor) => {
+          if (directoryHasPackageJson(ancestor) !== 3 /* Maybe */) {
+            return true;
+          }
+          const packageJsonFileName = host.toPath(combinePaths(ancestor, "package.json"));
+          if (tryFileExists(host, packageJsonFileName)) {
+            addOrUpdate(packageJsonFileName);
+          } else {
+            directoriesWithoutPackageJson.set(ancestor, true);
+          }
+        });
       }
+    };
+    function addOrUpdate(fileName) {
+      const packageJsonInfo = Debug.checkDefined(createPackageJsonInfo(fileName, host.host));
+      packageJsons.set(fileName, packageJsonInfo);
+      directoriesWithoutPackageJson.delete(getDirectoryPath(fileName));
     }
-    return false;
-  }
-  function isControlDeclContext(context) {
-    switch (context.contextNode.kind) {
-      case 244 /* IfStatement */:
-      case 254 /* SwitchStatement */:
-      case 247 /* ForStatement */:
-      case 248 /* ForInStatement */:
-      case 249 /* ForOfStatement */:
-      case 246 /* WhileStatement */:
-      case 257 /* TryStatement */:
-      case 245 /* DoStatement */:
-      case 253 /* WithStatement */:
-      case 298 /* CatchClause */:
-        return true;
-      default:
-        return false;
+    function directoryHasPackageJson(directory) {
+      return packageJsons.has(combinePaths(directory, "package.json")) ? -1 /* True */ : directoriesWithoutPackageJson.has(directory) ? 0 /* False */ : 3 /* Maybe */;
     }
   }
-  function isObjectContext(context) {
-    return context.contextNode.kind === 209 /* ObjectLiteralExpression */;
-  }
-  function isFunctionCallContext(context) {
-    return context.contextNode.kind === 212 /* CallExpression */;
-  }
-  function isNewContext(context) {
-    return context.contextNode.kind === 213 /* NewExpression */;
-  }
-  function isFunctionCallOrNewContext(context) {
-    return isFunctionCallContext(context) || isNewContext(context);
-  }
-  function isPreviousTokenNotComma(context) {
-    return context.currentTokenSpan.kind !== 28 /* CommaToken */;
-  }
-  function isNextTokenNotCloseBracket(context) {
-    return context.nextTokenSpan.kind !== 24 /* CloseBracketToken */;
-  }
-  function isNextTokenNotCloseParen(context) {
-    return context.nextTokenSpan.kind !== 22 /* CloseParenToken */;
-  }
-  function isArrowFunctionContext(context) {
-    return context.contextNode.kind === 218 /* ArrowFunction */;
-  }
-  function isImportTypeContext(context) {
-    return context.contextNode.kind === 204 /* ImportType */;
-  }
-  function isNonJsxSameLineTokenContext(context) {
-    return context.TokensAreOnSameLine() && context.contextNode.kind !== 12 /* JsxText */;
-  }
-  function isNonJsxTextContext(context) {
-    return context.contextNode.kind !== 12 /* JsxText */;
-  }
-  function isNonJsxElementOrFragmentContext(context) {
-    return context.contextNode.kind !== 283 /* JsxElement */ && context.contextNode.kind !== 287 /* JsxFragment */;
-  }
-  function isJsxExpressionContext(context) {
-    return context.contextNode.kind === 293 /* JsxExpression */ || context.contextNode.kind === 292 /* JsxSpreadAttribute */;
-  }
-  function isNextTokenParentJsxAttribute(context) {
-    return context.nextTokenParent.kind === 290 /* JsxAttribute */;
-  }
-  function isJsxAttributeContext(context) {
-    return context.contextNode.kind === 290 /* JsxAttribute */;
-  }
-  function isJsxSelfClosingElementContext(context) {
-    return context.contextNode.kind === 284 /* JsxSelfClosingElement */;
-  }
-  function isNotBeforeBlockInFunctionDeclarationContext(context) {
-    return !isFunctionDeclContext(context) && !isBeforeBlockContext(context);
-  }
-  function isEndOfDecoratorContextOnSameLine(context) {
-    return context.TokensAreOnSameLine() && hasDecorators(context.contextNode) && nodeIsInDecoratorContext(context.currentTokenParent) && !nodeIsInDecoratorContext(context.nextTokenParent);
-  }
-  function nodeIsInDecoratorContext(node) {
-    while (node && isExpression(node)) {
-      node = node.parent;
+  var init_packageJsonCache = __esm({
+    "src/server/packageJsonCache.ts"() {
+      "use strict";
+      init_ts7();
     }
-    return node && node.kind === 169 /* Decorator */;
-  }
-  function isStartOfVariableDeclarationList(context) {
-    return context.currentTokenParent.kind === 260 /* VariableDeclarationList */ && context.currentTokenParent.getStart(context.sourceFile) === context.currentTokenSpan.pos;
-  }
-  function isNotFormatOnEnter(context) {
-    return context.formattingRequestKind !== 2 /* FormatOnEnter */;
+  });
+
+  // src/server/session.ts
+  function hrTimeToMilliseconds(time) {
+    const seconds = time[0];
+    const nanoseconds = time[1];
+    return (1e9 * seconds + nanoseconds) / 1e6;
   }
-  function isModuleDeclContext(context) {
-    return context.contextNode.kind === 266 /* ModuleDeclaration */;
+  function isDeclarationFileInJSOnlyNonConfiguredProject(project, file) {
+    if ((isInferredProject(project) || isExternalProject(project)) && project.isJsOnlyProject()) {
+      const scriptInfo = project.getScriptInfoForNormalizedPath(file);
+      return scriptInfo && !scriptInfo.isJavaScript();
+    }
+    return false;
   }
-  function isObjectTypeContext(context) {
-    return context.contextNode.kind === 186 /* TypeLiteral */;
+  function dtsChangeCanAffectEmit(compilationSettings) {
+    return getEmitDeclarations(compilationSettings) || !!compilationSettings.emitDecoratorMetadata;
   }
-  function isConstructorSignatureContext(context) {
-    return context.contextNode.kind === 179 /* ConstructSignature */;
+  function formatDiag(fileName, project, diag2) {
+    const scriptInfo = project.getScriptInfoForNormalizedPath(fileName);
+    return {
+      start: scriptInfo.positionToLineOffset(diag2.start),
+      end: scriptInfo.positionToLineOffset(diag2.start + diag2.length),
+      // TODO: GH#18217
+      text: flattenDiagnosticMessageText(diag2.messageText, "\n"),
+      code: diag2.code,
+      category: diagnosticCategoryName(diag2),
+      reportsUnnecessary: diag2.reportsUnnecessary,
+      reportsDeprecated: diag2.reportsDeprecated,
+      source: diag2.source,
+      relatedInformation: map(diag2.relatedInformation, formatRelatedInformation)
+    };
   }
-  function isTypeArgumentOrParameterOrAssertion(token, parent2) {
-    if (token.kind !== 30 /* LessThanToken */ && token.kind !== 32 /* GreaterThanToken */) {
-      return false;
-    }
-    switch (parent2.kind) {
-      case 182 /* TypeReference */:
-      case 215 /* TypeAssertionExpression */:
-      case 264 /* TypeAliasDeclaration */:
-      case 262 /* ClassDeclaration */:
-      case 230 /* ClassExpression */:
-      case 263 /* InterfaceDeclaration */:
-      case 261 /* FunctionDeclaration */:
-      case 217 /* FunctionExpression */:
-      case 218 /* ArrowFunction */:
-      case 173 /* MethodDeclaration */:
-      case 172 /* MethodSignature */:
-      case 178 /* CallSignature */:
-      case 179 /* ConstructSignature */:
-      case 212 /* CallExpression */:
-      case 213 /* NewExpression */:
-      case 232 /* ExpressionWithTypeArguments */:
-        return true;
-      default:
-        return false;
+  function formatRelatedInformation(info) {
+    if (!info.file) {
+      return {
+        message: flattenDiagnosticMessageText(info.messageText, "\n"),
+        category: diagnosticCategoryName(info),
+        code: info.code
+      };
     }
+    return {
+      span: {
+        start: convertToLocation(getLineAndCharacterOfPosition(info.file, info.start)),
+        end: convertToLocation(getLineAndCharacterOfPosition(info.file, info.start + info.length)),
+        // TODO: GH#18217
+        file: info.file.fileName
+      },
+      message: flattenDiagnosticMessageText(info.messageText, "\n"),
+      category: diagnosticCategoryName(info),
+      code: info.code
+    };
   }
-  function isTypeArgumentOrParameterOrAssertionContext(context) {
-    return isTypeArgumentOrParameterOrAssertion(context.currentTokenSpan, context.currentTokenParent) || isTypeArgumentOrParameterOrAssertion(context.nextTokenSpan, context.nextTokenParent);
+  function convertToLocation(lineAndCharacter) {
+    return { line: lineAndCharacter.line + 1, offset: lineAndCharacter.character + 1 };
   }
-  function isTypeAssertionContext(context) {
-    return context.contextNode.kind === 215 /* TypeAssertionExpression */;
+  function formatDiagnosticToProtocol(diag2, includeFileName) {
+    const start = diag2.file && convertToLocation(getLineAndCharacterOfPosition(diag2.file, diag2.start));
+    const end = diag2.file && convertToLocation(getLineAndCharacterOfPosition(diag2.file, diag2.start + diag2.length));
+    const text = flattenDiagnosticMessageText(diag2.messageText, "\n");
+    const { code, source } = diag2;
+    const category = diagnosticCategoryName(diag2);
+    const common = {
+      start,
+      end,
+      text,
+      code,
+      category,
+      reportsUnnecessary: diag2.reportsUnnecessary,
+      reportsDeprecated: diag2.reportsDeprecated,
+      source,
+      relatedInformation: map(diag2.relatedInformation, formatRelatedInformation)
+    };
+    return includeFileName ? { ...common, fileName: diag2.file && diag2.file.fileName } : common;
   }
-  function isNonTypeAssertionContext(context) {
-    return !isTypeAssertionContext(context);
+  function allEditsBeforePos(edits, pos) {
+    return edits.every((edit) => textSpanEnd(edit.span) < pos);
   }
-  function isVoidOpContext(context) {
-    return context.currentTokenSpan.kind === 116 /* VoidKeyword */ && context.currentTokenParent.kind === 221 /* VoidExpression */;
+  function formatMessage2(msg, logger, byteLength, newLine) {
+    const verboseLogging = logger.hasLevel(3 /* verbose */);
+    const json = JSON.stringify(msg);
+    if (verboseLogging) {
+      logger.info(`${msg.type}:${stringifyIndented(msg)}`);
+    }
+    const len = byteLength(json, "utf8");
+    return `Content-Length: ${1 + len}\r
+\r
+${json}${newLine}`;
   }
-  function isYieldOrYieldStarWithOperand(context) {
-    return context.contextNode.kind === 228 /* YieldExpression */ && context.contextNode.expression !== void 0;
+  function toEvent(eventName, body) {
+    return {
+      seq: 0,
+      type: "event",
+      event: eventName,
+      body
+    };
   }
-  function isNonNullAssertionContext(context) {
-    return context.contextNode.kind === 234 /* NonNullExpression */;
+  function combineProjectOutput(defaultValue, getValue, projects, action) {
+    const outputs = flatMapToMutable(isArray(projects) ? projects : projects.projects, (project) => action(project, defaultValue));
+    if (!isArray(projects) && projects.symLinkedProjects) {
+      projects.symLinkedProjects.forEach((projects2, path) => {
+        const value = getValue(path);
+        outputs.push(...flatMap(projects2, (project) => action(project, value)));
+      });
+    }
+    return deduplicate(outputs, equateValues);
   }
-  function isNotStatementConditionContext(context) {
-    return !isStatementConditionContext(context);
+  function createDocumentSpanSet() {
+    return createSet(({ textSpan }) => textSpan.start + 100003 * textSpan.length, documentSpansEqual);
   }
-  function isStatementConditionContext(context) {
-    switch (context.contextNode.kind) {
-      case 244 /* IfStatement */:
-      case 247 /* ForStatement */:
-      case 248 /* ForInStatement */:
-      case 249 /* ForOfStatement */:
-      case 245 /* DoStatement */:
-      case 246 /* WhileStatement */:
-        return true;
-      default:
-        return false;
+  function getRenameLocationsWorker(projects, defaultProject, initialLocation, findInStrings, findInComments, preferences) {
+    const perProjectResults = getPerProjectReferences(
+      projects,
+      defaultProject,
+      initialLocation,
+      /*isForRename*/
+      true,
+      (project, position) => project.getLanguageService().findRenameLocations(position.fileName, position.pos, findInStrings, findInComments, preferences),
+      (renameLocation, cb) => cb(documentSpanLocation(renameLocation))
+    );
+    if (isArray(perProjectResults)) {
+      return perProjectResults;
     }
-  }
-  function isSemicolonDeletionContext(context) {
-    let nextTokenKind = context.nextTokenSpan.kind;
-    let nextTokenStart = context.nextTokenSpan.pos;
-    if (isTrivia(nextTokenKind)) {
-      const nextRealToken = context.nextTokenParent === context.currentTokenParent ? findNextToken(
-        context.currentTokenParent,
-        findAncestor(context.currentTokenParent, (a) => !a.parent),
-        context.sourceFile
-      ) : context.nextTokenParent.getFirstToken(context.sourceFile);
-      if (!nextRealToken) {
-        return true;
+    const results = [];
+    const seen = createDocumentSpanSet();
+    perProjectResults.forEach((projectResults, project) => {
+      for (const result of projectResults) {
+        if (!seen.has(result) && !getMappedLocationForProject(documentSpanLocation(result), project)) {
+          results.push(result);
+          seen.add(result);
+        }
       }
-      nextTokenKind = nextRealToken.kind;
-      nextTokenStart = nextRealToken.getStart(context.sourceFile);
-    }
-    const startLine = context.sourceFile.getLineAndCharacterOfPosition(context.currentTokenSpan.pos).line;
-    const endLine = context.sourceFile.getLineAndCharacterOfPosition(nextTokenStart).line;
-    if (startLine === endLine) {
-      return nextTokenKind === 20 /* CloseBraceToken */ || nextTokenKind === 1 /* EndOfFileToken */;
-    }
-    if (nextTokenKind === 239 /* SemicolonClassElement */ || nextTokenKind === 27 /* SemicolonToken */) {
-      return false;
-    }
-    if (context.contextNode.kind === 263 /* InterfaceDeclaration */ || context.contextNode.kind === 264 /* TypeAliasDeclaration */) {
-      return !isPropertySignature(context.currentTokenParent) || !!context.currentTokenParent.type || nextTokenKind !== 21 /* OpenParenToken */;
-    }
-    if (isPropertyDeclaration(context.currentTokenParent)) {
-      return !context.currentTokenParent.initializer;
-    }
-    return context.currentTokenParent.kind !== 247 /* ForStatement */ && context.currentTokenParent.kind !== 241 /* EmptyStatement */ && context.currentTokenParent.kind !== 239 /* SemicolonClassElement */ && nextTokenKind !== 23 /* OpenBracketToken */ && nextTokenKind !== 21 /* OpenParenToken */ && nextTokenKind !== 40 /* PlusToken */ && nextTokenKind !== 41 /* MinusToken */ && nextTokenKind !== 44 /* SlashToken */ && nextTokenKind !== 14 /* RegularExpressionLiteral */ && nextTokenKind !== 28 /* CommaToken */ && nextTokenKind !== 227 /* TemplateExpression */ && nextTokenKind !== 16 /* TemplateHead */ && nextTokenKind !== 15 /* NoSubstitutionTemplateLiteral */ && nextTokenKind !== 25 /* DotToken */;
-  }
-  function isSemicolonInsertionContext(context) {
-    return positionIsASICandidate(context.currentTokenSpan.end, context.currentTokenParent, context.sourceFile);
+    });
+    return results;
   }
-  function isNotPropertyAccessOnIntegerLiteral(context) {
-    return !isPropertyAccessExpression(context.contextNode) || !isNumericLiteral(context.contextNode.expression) || context.contextNode.expression.getText().indexOf(".") !== -1;
+  function getDefinitionLocation(defaultProject, initialLocation, isForRename) {
+    const infos = defaultProject.getLanguageService().getDefinitionAtPosition(
+      initialLocation.fileName,
+      initialLocation.pos,
+      /*searchOtherFilesOnly*/
+      false,
+      /*stopAtAlias*/
+      isForRename
+    );
+    const info = infos && firstOrUndefined(infos);
+    return info && !info.isLocal ? { fileName: info.fileName, pos: info.textSpan.start } : void 0;
   }
-  var init_rules = __esm({
-    "src/services/formatting/rules.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_formatting();
+  function getReferencesWorker(projects, defaultProject, initialLocation, logger) {
+    var _a, _b;
+    const perProjectResults = getPerProjectReferences(
+      projects,
+      defaultProject,
+      initialLocation,
+      /*isForRename*/
+      false,
+      (project, position) => {
+        logger.info(`Finding references to ${position.fileName} position ${position.pos} in project ${project.getProjectName()}`);
+        return project.getLanguageService().findReferences(position.fileName, position.pos);
+      },
+      (referencedSymbol, cb) => {
+        cb(documentSpanLocation(referencedSymbol.definition));
+        for (const ref of referencedSymbol.references) {
+          cb(documentSpanLocation(ref));
+        }
+      }
+    );
+    if (isArray(perProjectResults)) {
+      return perProjectResults;
     }
-  });
-
-  // src/services/formatting/rulesMap.ts
-  function getFormatContext(options, host) {
-    return { options, getRules: getRulesMap(), host };
-  }
-  function getRulesMap() {
-    if (rulesMapCache === void 0) {
-      rulesMapCache = createRulesMap(getAllRules());
+    const defaultProjectResults = perProjectResults.get(defaultProject);
+    if (((_b = (_a = defaultProjectResults == null ? void 0 : defaultProjectResults[0]) == null ? void 0 : _a.references[0]) == null ? void 0 : _b.isDefinition) === void 0) {
+      perProjectResults.forEach((projectResults) => {
+        for (const referencedSymbol of projectResults) {
+          for (const ref of referencedSymbol.references) {
+            delete ref.isDefinition;
+          }
+        }
+      });
+    } else {
+      const knownSymbolSpans = createDocumentSpanSet();
+      for (const referencedSymbol of defaultProjectResults) {
+        for (const ref of referencedSymbol.references) {
+          if (ref.isDefinition) {
+            knownSymbolSpans.add(ref);
+            break;
+          }
+        }
+      }
+      const updatedProjects = /* @__PURE__ */ new Set();
+      while (true) {
+        let progress = false;
+        perProjectResults.forEach((referencedSymbols, project) => {
+          if (updatedProjects.has(project))
+            return;
+          const updated = project.getLanguageService().updateIsDefinitionOfReferencedSymbols(referencedSymbols, knownSymbolSpans);
+          if (updated) {
+            updatedProjects.add(project);
+            progress = true;
+          }
+        });
+        if (!progress)
+          break;
+      }
+      perProjectResults.forEach((referencedSymbols, project) => {
+        if (updatedProjects.has(project))
+          return;
+        for (const referencedSymbol of referencedSymbols) {
+          for (const ref of referencedSymbol.references) {
+            ref.isDefinition = false;
+          }
+        }
+      });
     }
-    return rulesMapCache;
+    const results = [];
+    const seenRefs = createDocumentSpanSet();
+    perProjectResults.forEach((projectResults, project) => {
+      for (const referencedSymbol of projectResults) {
+        const mappedDefinitionFile = getMappedLocationForProject(documentSpanLocation(referencedSymbol.definition), project);
+        const definition = mappedDefinitionFile === void 0 ? referencedSymbol.definition : {
+          ...referencedSymbol.definition,
+          textSpan: createTextSpan(mappedDefinitionFile.pos, referencedSymbol.definition.textSpan.length),
+          // Why would the length be the same in the original?
+          fileName: mappedDefinitionFile.fileName,
+          contextSpan: getMappedContextSpanForProject(referencedSymbol.definition, project)
+        };
+        let symbolToAddTo = find(results, (o) => documentSpansEqual(o.definition, definition));
+        if (!symbolToAddTo) {
+          symbolToAddTo = { definition, references: [] };
+          results.push(symbolToAddTo);
+        }
+        for (const ref of referencedSymbol.references) {
+          if (!seenRefs.has(ref) && !getMappedLocationForProject(documentSpanLocation(ref), project)) {
+            seenRefs.add(ref);
+            symbolToAddTo.references.push(ref);
+          }
+        }
+      }
+    });
+    return results.filter((o) => o.references.length !== 0);
   }
-  function getRuleActionExclusion(ruleAction) {
-    let mask2 = 0 /* None */;
-    if (ruleAction & 1 /* StopProcessingSpaceActions */) {
-      mask2 |= 28 /* ModifySpaceAction */;
+  function forEachProjectInProjects(projects, path, cb) {
+    for (const project of isArray(projects) ? projects : projects.projects) {
+      cb(project, path);
     }
-    if (ruleAction & 2 /* StopProcessingTokenActions */) {
-      mask2 |= 96 /* ModifyTokenAction */;
-    }
-    if (ruleAction & 28 /* ModifySpaceAction */) {
-      mask2 |= 28 /* ModifySpaceAction */;
-    }
-    if (ruleAction & 96 /* ModifyTokenAction */) {
-      mask2 |= 96 /* ModifyTokenAction */;
+    if (!isArray(projects) && projects.symLinkedProjects) {
+      projects.symLinkedProjects.forEach((symlinkedProjects, symlinkedPath) => {
+        for (const project of symlinkedProjects) {
+          cb(project, symlinkedPath);
+        }
+      });
     }
-    return mask2;
   }
-  function createRulesMap(rules) {
-    const map2 = buildMap(rules);
-    return (context) => {
-      const bucket = map2[getRuleBucketIndex(context.currentTokenSpan.kind, context.nextTokenSpan.kind)];
-      if (bucket) {
-        const rules2 = [];
-        let ruleActionMask = 0;
-        for (const rule2 of bucket) {
-          const acceptRuleActions = ~getRuleActionExclusion(ruleActionMask);
-          if (rule2.action & acceptRuleActions && every(rule2.context, (c) => c(context))) {
-            rules2.push(rule2);
-            ruleActionMask |= rule2.action;
+  function getPerProjectReferences(projects, defaultProject, initialLocation, isForRename, getResultsForPosition, forPositionInResult) {
+    const resultsMap = /* @__PURE__ */ new Map();
+    const queue = createQueue();
+    queue.enqueue({ project: defaultProject, location: initialLocation });
+    forEachProjectInProjects(projects, initialLocation.fileName, (project, path) => {
+      const location = { fileName: path, pos: initialLocation.pos };
+      queue.enqueue({ project, location });
+    });
+    const projectService = defaultProject.projectService;
+    const cancellationToken = defaultProject.getCancellationToken();
+    const defaultDefinition = getDefinitionLocation(defaultProject, initialLocation, isForRename);
+    const getGeneratedDefinition = memoize(
+      () => defaultProject.isSourceOfProjectReferenceRedirect(defaultDefinition.fileName) ? defaultDefinition : defaultProject.getLanguageService().getSourceMapper().tryGetGeneratedPosition(defaultDefinition)
+    );
+    const getSourceDefinition = memoize(
+      () => defaultProject.isSourceOfProjectReferenceRedirect(defaultDefinition.fileName) ? defaultDefinition : defaultProject.getLanguageService().getSourceMapper().tryGetSourcePosition(defaultDefinition)
+    );
+    const searchedProjectKeys = /* @__PURE__ */ new Set();
+    onCancellation:
+      while (!queue.isEmpty()) {
+        while (!queue.isEmpty()) {
+          if (cancellationToken.isCancellationRequested())
+            break onCancellation;
+          const { project, location } = queue.dequeue();
+          if (resultsMap.has(project))
+            continue;
+          if (isLocationProjectReferenceRedirect(project, location))
+            continue;
+          updateProjectIfDirty(project);
+          if (!project.containsFile(toNormalizedPath(location.fileName))) {
+            continue;
           }
+          const projectResults = searchPosition(project, location);
+          resultsMap.set(project, projectResults ?? emptyArray2);
+          searchedProjectKeys.add(getProjectKey(project));
         }
-        if (rules2.length) {
-          return rules2;
+        if (defaultDefinition) {
+          projectService.loadAncestorProjectTree(searchedProjectKeys);
+          projectService.forEachEnabledProject((project) => {
+            if (cancellationToken.isCancellationRequested())
+              return;
+            if (resultsMap.has(project))
+              return;
+            const location = mapDefinitionInProject(defaultDefinition, project, getGeneratedDefinition, getSourceDefinition);
+            if (location) {
+              queue.enqueue({ project, location });
+            }
+          });
         }
       }
-    };
-  }
-  function buildMap(rules) {
-    const map2 = new Array(mapRowLength * mapRowLength);
-    const rulesBucketConstructionStateList = new Array(map2.length);
-    for (const rule2 of rules) {
-      const specificRule = rule2.leftTokenRange.isSpecific && rule2.rightTokenRange.isSpecific;
-      for (const left of rule2.leftTokenRange.tokens) {
-        for (const right of rule2.rightTokenRange.tokens) {
-          const index = getRuleBucketIndex(left, right);
-          let rulesBucket = map2[index];
-          if (rulesBucket === void 0) {
-            rulesBucket = map2[index] = [];
+    if (resultsMap.size === 1) {
+      return firstIterator(resultsMap.values());
+    }
+    return resultsMap;
+    function searchPosition(project, location) {
+      const projectResults = getResultsForPosition(project, location);
+      if (!projectResults)
+        return void 0;
+      for (const result of projectResults) {
+        forPositionInResult(result, (position) => {
+          const originalLocation = projectService.getOriginalLocationEnsuringConfiguredProject(project, position);
+          if (!originalLocation)
+            return;
+          const originalScriptInfo = projectService.getScriptInfo(originalLocation.fileName);
+          for (const project2 of originalScriptInfo.containingProjects) {
+            if (!project2.isOrphan() && !resultsMap.has(project2)) {
+              queue.enqueue({ project: project2, location: originalLocation });
+            }
+          }
+          const symlinkedProjectsMap = projectService.getSymlinkedProjects(originalScriptInfo);
+          if (symlinkedProjectsMap) {
+            symlinkedProjectsMap.forEach((symlinkedProjects, symlinkedPath) => {
+              for (const symlinkedProject of symlinkedProjects) {
+                if (!symlinkedProject.isOrphan() && !resultsMap.has(symlinkedProject)) {
+                  queue.enqueue({ project: symlinkedProject, location: { fileName: symlinkedPath, pos: originalLocation.pos } });
+                }
+              }
+            });
           }
-          addRule(rulesBucket, rule2.rule, specificRule, rulesBucketConstructionStateList, index);
-        }
+        });
       }
+      return projectResults;
     }
-    return map2;
-  }
-  function getRuleBucketIndex(row, column) {
-    Debug.assert(row <= 164 /* LastKeyword */ && column <= 164 /* LastKeyword */, "Must compute formatting context from tokens");
-    return row * mapRowLength + column;
-  }
-  function addRule(rules, rule2, specificTokens, constructionState, rulesBucketIndex) {
-    const position = rule2.action & 3 /* StopAction */ ? specificTokens ? 0 /* StopRulesSpecific */ : RulesPosition.StopRulesAny : rule2.context !== anyContext ? specificTokens ? RulesPosition.ContextRulesSpecific : RulesPosition.ContextRulesAny : specificTokens ? RulesPosition.NoContextRulesSpecific : RulesPosition.NoContextRulesAny;
-    const state = constructionState[rulesBucketIndex] || 0;
-    rules.splice(getInsertionIndex(state, position), 0, rule2);
-    constructionState[rulesBucketIndex] = increaseInsertionIndex(state, position);
   }
-  function getInsertionIndex(indexBitmap, maskPosition) {
-    let index = 0;
-    for (let pos = 0; pos <= maskPosition; pos += maskBitSize) {
-      index += indexBitmap & mask;
-      indexBitmap >>= maskBitSize;
+  function mapDefinitionInProject(definition, project, getGeneratedDefinition, getSourceDefinition) {
+    if (project.containsFile(toNormalizedPath(definition.fileName)) && !isLocationProjectReferenceRedirect(project, definition)) {
+      return definition;
     }
-    return index;
-  }
-  function increaseInsertionIndex(indexBitmap, maskPosition) {
-    const value = (indexBitmap >> maskPosition & mask) + 1;
-    Debug.assert((value & mask) === value, "Adding more rules into the sub-bucket than allowed. Maximum allowed is 32 rules.");
-    return indexBitmap & ~(mask << maskPosition) | value << maskPosition;
+    const generatedDefinition = getGeneratedDefinition();
+    if (generatedDefinition && project.containsFile(toNormalizedPath(generatedDefinition.fileName)))
+      return generatedDefinition;
+    const sourceDefinition = getSourceDefinition();
+    return sourceDefinition && project.containsFile(toNormalizedPath(sourceDefinition.fileName)) ? sourceDefinition : void 0;
   }
-  var rulesMapCache, maskBitSize, mask, mapRowLength, RulesPosition;
-  var init_rulesMap = __esm({
-    "src/services/formatting/rulesMap.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_formatting();
-      maskBitSize = 5;
-      mask = 31;
-      mapRowLength = 164 /* LastToken */ + 1;
-      RulesPosition = ((RulesPosition2) => {
-        RulesPosition2[RulesPosition2["StopRulesSpecific"] = 0] = "StopRulesSpecific";
-        RulesPosition2[RulesPosition2["StopRulesAny"] = maskBitSize * 1] = "StopRulesAny";
-        RulesPosition2[RulesPosition2["ContextRulesSpecific"] = maskBitSize * 2] = "ContextRulesSpecific";
-        RulesPosition2[RulesPosition2["ContextRulesAny"] = maskBitSize * 3] = "ContextRulesAny";
-        RulesPosition2[RulesPosition2["NoContextRulesSpecific"] = maskBitSize * 4] = "NoContextRulesSpecific";
-        RulesPosition2[RulesPosition2["NoContextRulesAny"] = maskBitSize * 5] = "NoContextRulesAny";
-        return RulesPosition2;
-      })(RulesPosition || {});
-    }
-  });
-
-  // src/services/formatting/formatting.ts
-  function createTextRangeWithKind(pos, end, kind) {
-    const textRangeWithKind = { pos, end, kind };
-    if (Debug.isDebugging) {
-      Object.defineProperty(textRangeWithKind, "__debugKind", {
-        get: () => Debug.formatSyntaxKind(kind)
-      });
-    }
-    return textRangeWithKind;
+  function isLocationProjectReferenceRedirect(project, location) {
+    if (!location)
+      return false;
+    const program = project.getLanguageService().getProgram();
+    if (!program)
+      return false;
+    const sourceFile = program.getSourceFile(location.fileName);
+    return !!sourceFile && sourceFile.resolvedPath !== sourceFile.path && sourceFile.resolvedPath !== project.toPath(location.fileName);
   }
-  function formatOnEnter(position, sourceFile, formatContext) {
-    const line = sourceFile.getLineAndCharacterOfPosition(position).line;
-    if (line === 0) {
-      return [];
-    }
-    let endOfFormatSpan = getEndLinePosition(line, sourceFile);
-    while (isWhiteSpaceSingleLine(sourceFile.text.charCodeAt(endOfFormatSpan))) {
-      endOfFormatSpan--;
-    }
-    if (isLineBreak(sourceFile.text.charCodeAt(endOfFormatSpan))) {
-      endOfFormatSpan--;
-    }
-    const span = {
-      // get start position for the previous line
-      pos: getStartPositionOfLine(line - 1, sourceFile),
-      // end value is exclusive so add 1 to the result
-      end: endOfFormatSpan + 1
-    };
-    return formatSpan(span, sourceFile, formatContext, 2 /* FormatOnEnter */);
+  function getProjectKey(project) {
+    return isConfiguredProject(project) ? project.canonicalConfigFilePath : project.getProjectName();
   }
-  function formatOnSemicolon(position, sourceFile, formatContext) {
-    const semicolon = findImmediatelyPrecedingTokenOfKind(position, 27 /* SemicolonToken */, sourceFile);
-    return formatNodeLines(findOutermostNodeWithinListLevel(semicolon), sourceFile, formatContext, 3 /* FormatOnSemicolon */);
+  function documentSpanLocation({ fileName, textSpan }) {
+    return { fileName, pos: textSpan.start };
   }
-  function formatOnOpeningCurly(position, sourceFile, formatContext) {
-    const openingCurly = findImmediatelyPrecedingTokenOfKind(position, 19 /* OpenBraceToken */, sourceFile);
-    if (!openingCurly) {
-      return [];
-    }
-    const curlyBraceRange = openingCurly.parent;
-    const outermostNode = findOutermostNodeWithinListLevel(curlyBraceRange);
-    const textRange = {
-      pos: getLineStartPositionForPosition(outermostNode.getStart(sourceFile), sourceFile),
-      // TODO: GH#18217
-      end: position
-    };
-    return formatSpan(textRange, sourceFile, formatContext, 4 /* FormatOnOpeningCurlyBrace */);
+  function getMappedLocationForProject(location, project) {
+    return getMappedLocation(location, project.getSourceMapper(), (p) => project.projectService.fileExists(p));
   }
-  function formatOnClosingCurly(position, sourceFile, formatContext) {
-    const precedingToken = findImmediatelyPrecedingTokenOfKind(position, 20 /* CloseBraceToken */, sourceFile);
-    return formatNodeLines(findOutermostNodeWithinListLevel(precedingToken), sourceFile, formatContext, 5 /* FormatOnClosingCurlyBrace */);
+  function getMappedDocumentSpanForProject(documentSpan, project) {
+    return getMappedDocumentSpan(documentSpan, project.getSourceMapper(), (p) => project.projectService.fileExists(p));
   }
-  function formatDocument(sourceFile, formatContext) {
-    const span = {
-      pos: 0,
-      end: sourceFile.text.length
-    };
-    return formatSpan(span, sourceFile, formatContext, 0 /* FormatDocument */);
+  function getMappedContextSpanForProject(documentSpan, project) {
+    return getMappedContextSpan(documentSpan, project.getSourceMapper(), (p) => project.projectService.fileExists(p));
   }
-  function formatSelection(start, end, sourceFile, formatContext) {
-    const span = {
-      pos: getLineStartPositionForPosition(start, sourceFile),
-      end
+  function toProtocolTextSpan(textSpan, scriptInfo) {
+    return {
+      start: scriptInfo.positionToLineOffset(textSpan.start),
+      end: scriptInfo.positionToLineOffset(textSpanEnd(textSpan))
     };
-    return formatSpan(span, sourceFile, formatContext, 1 /* FormatSelection */);
   }
-  function findImmediatelyPrecedingTokenOfKind(end, expectedTokenKind, sourceFile) {
-    const precedingToken = findPrecedingToken(end, sourceFile);
-    return precedingToken && precedingToken.kind === expectedTokenKind && end === precedingToken.getEnd() ? precedingToken : void 0;
+  function toProtocolTextSpanWithContext(span, contextSpan, scriptInfo) {
+    const textSpan = toProtocolTextSpan(span, scriptInfo);
+    const contextTextSpan = contextSpan && toProtocolTextSpan(contextSpan, scriptInfo);
+    return contextTextSpan ? { ...textSpan, contextStart: contextTextSpan.start, contextEnd: contextTextSpan.end } : textSpan;
   }
-  function findOutermostNodeWithinListLevel(node) {
-    let current = node;
-    while (current && current.parent && current.parent.end === node.end && !isListElement(current.parent, current)) {
-      current = current.parent;
-    }
-    return current;
+  function convertTextChangeToCodeEdit(change, scriptInfo) {
+    return { start: positionToLineOffset(scriptInfo, change.span.start), end: positionToLineOffset(scriptInfo, textSpanEnd(change.span)), newText: change.newText };
   }
-  function isListElement(parent2, node) {
-    switch (parent2.kind) {
-      case 262 /* ClassDeclaration */:
-      case 263 /* InterfaceDeclaration */:
-        return rangeContainsRange(parent2.members, node);
-      case 266 /* ModuleDeclaration */:
-        const body = parent2.body;
-        return !!body && body.kind === 267 /* ModuleBlock */ && rangeContainsRange(body.statements, node);
-      case 311 /* SourceFile */:
-      case 240 /* Block */:
-      case 267 /* ModuleBlock */:
-        return rangeContainsRange(parent2.statements, node);
-      case 298 /* CatchClause */:
-        return rangeContainsRange(parent2.block.statements, node);
-    }
-    return false;
+  function positionToLineOffset(info, position) {
+    return isConfigFile(info) ? locationFromLineAndCharacter(info.getLineAndCharacterOfPosition(position)) : info.positionToLineOffset(position);
   }
-  function findEnclosingNode(range, sourceFile) {
-    return find2(sourceFile);
-    function find2(n) {
-      const candidate = forEachChild(n, (c) => startEndContainsRange(c.getStart(sourceFile), c.end, range) && c);
-      if (candidate) {
-        const result = find2(candidate);
-        if (result) {
-          return result;
-        }
+  function convertLinkedEditInfoToRanges(linkedEdit, scriptInfo) {
+    const ranges = linkedEdit.ranges.map(
+      (r) => {
+        return {
+          start: scriptInfo.positionToLineOffset(r.start),
+          end: scriptInfo.positionToLineOffset(r.start + r.length)
+        };
       }
-      return n;
-    }
+    );
+    if (!linkedEdit.wordPattern)
+      return { ranges };
+    return { ranges, wordPattern: linkedEdit.wordPattern };
   }
-  function prepareRangeContainsErrorFunction(errors, originalRange) {
-    if (!errors.length) {
-      return rangeHasNoErrors;
-    }
-    const sorted = errors.filter((d) => rangeOverlapsWithStartEnd(originalRange, d.start, d.start + d.length)).sort((e1, e2) => e1.start - e2.start);
-    if (!sorted.length) {
-      return rangeHasNoErrors;
-    }
-    let index = 0;
-    return (r) => {
-      while (true) {
-        if (index >= sorted.length) {
-          return false;
-        }
-        const error = sorted[index];
-        if (r.end <= error.start) {
-          return false;
-        }
-        if (startEndOverlapsWithStartEnd(r.pos, r.end, error.start, error.start + error.length)) {
-          return true;
-        }
-        index++;
-      }
-    };
-    function rangeHasNoErrors() {
-      return false;
-    }
+  function locationFromLineAndCharacter(lc) {
+    return { line: lc.line + 1, offset: lc.character + 1 };
   }
-  function getScanStartPosition(enclosingNode, originalRange, sourceFile) {
-    const start = enclosingNode.getStart(sourceFile);
-    if (start === originalRange.pos && enclosingNode.end === originalRange.end) {
-      return start;
-    }
-    const precedingToken = findPrecedingToken(originalRange.pos, sourceFile);
-    if (!precedingToken) {
-      return enclosingNode.pos;
-    }
-    if (precedingToken.end >= originalRange.pos) {
-      return enclosingNode.pos;
-    }
-    return precedingToken.end;
+  function convertNewFileTextChangeToCodeEdit(textChanges2) {
+    Debug.assert(textChanges2.textChanges.length === 1);
+    const change = first(textChanges2.textChanges);
+    Debug.assert(change.span.start === 0 && change.span.length === 0);
+    return { fileName: textChanges2.fileName, textChanges: [{ start: { line: 0, offset: 0 }, end: { line: 0, offset: 0 }, newText: change.newText }] };
   }
-  function getOwnOrInheritedDelta(n, options, sourceFile) {
-    let previousLine = -1 /* Unknown */;
-    let child;
-    while (n) {
-      const line = sourceFile.getLineAndCharacterOfPosition(n.getStart(sourceFile)).line;
-      if (previousLine !== -1 /* Unknown */ && line !== previousLine) {
-        break;
+  function getLocationInNewDocument(oldText, renameFilename, renameLocation, edits) {
+    const newText = applyEdits(oldText, renameFilename, edits);
+    const { line, character } = computeLineAndCharacterOfPosition(computeLineStarts(newText), renameLocation);
+    return { line: line + 1, offset: character + 1 };
+  }
+  function applyEdits(text, textFilename, edits) {
+    for (const { fileName, textChanges: textChanges2 } of edits) {
+      if (fileName !== textFilename) {
+        continue;
       }
-      if (SmartIndenter.shouldIndentChildNode(options, n, child, sourceFile)) {
-        return options.indentSize;
+      for (let i = textChanges2.length - 1; i >= 0; i--) {
+        const { newText, span: { start, length: length2 } } = textChanges2[i];
+        text = text.slice(0, start) + newText + text.slice(start + length2);
       }
-      previousLine = line;
-      child = n;
-      n = n.parent;
     }
-    return 0;
-  }
-  function formatNodeGivenIndentation(node, sourceFileLike, languageVariant, initialIndentation, delta, formatContext) {
-    const range = { pos: node.pos, end: node.end };
-    return getFormattingScanner(sourceFileLike.text, languageVariant, range.pos, range.end, (scanner2) => formatSpanWorker(
-      range,
-      node,
-      initialIndentation,
-      delta,
-      scanner2,
-      formatContext,
-      1 /* FormatSelection */,
-      (_) => false,
-      // assume that node does not have any errors
-      sourceFileLike
-    ));
+    return text;
   }
-  function formatNodeLines(node, sourceFile, formatContext, requestKind) {
-    if (!node) {
-      return [];
-    }
-    const span = {
-      pos: getLineStartPositionForPosition(node.getStart(sourceFile), sourceFile),
-      end: node.end
+  function referenceEntryToReferencesResponseItem(projectService, { fileName, textSpan, contextSpan, isWriteAccess: isWriteAccess2, isDefinition }, { disableLineTextInReferences }) {
+    const scriptInfo = Debug.checkDefined(projectService.getScriptInfo(fileName));
+    const span = toProtocolTextSpanWithContext(textSpan, contextSpan, scriptInfo);
+    const lineText = disableLineTextInReferences ? void 0 : getLineText(scriptInfo, span);
+    return {
+      file: fileName,
+      ...span,
+      lineText,
+      isWriteAccess: isWriteAccess2,
+      isDefinition
     };
-    return formatSpan(span, sourceFile, formatContext, requestKind);
   }
-  function formatSpan(originalRange, sourceFile, formatContext, requestKind) {
-    const enclosingNode = findEnclosingNode(originalRange, sourceFile);
-    return getFormattingScanner(
-      sourceFile.text,
-      sourceFile.languageVariant,
-      getScanStartPosition(enclosingNode, originalRange, sourceFile),
-      originalRange.end,
-      (scanner2) => formatSpanWorker(
-        originalRange,
-        enclosingNode,
-        SmartIndenter.getIndentationForNode(enclosingNode, originalRange, sourceFile, formatContext.options),
-        getOwnOrInheritedDelta(enclosingNode, formatContext.options, sourceFile),
-        scanner2,
-        formatContext,
-        requestKind,
-        prepareRangeContainsErrorFunction(sourceFile.parseDiagnostics, originalRange),
-        sourceFile
-      )
-    );
+  function getLineText(scriptInfo, span) {
+    const lineSpan = scriptInfo.lineToTextSpan(span.start.line - 1);
+    return scriptInfo.getSnapshot().getText(lineSpan.start, textSpanEnd(lineSpan)).replace(/\r|\n/g, "");
   }
-  function formatSpanWorker(originalRange, enclosingNode, initialIndentation, delta, formattingScanner, { options, getRules, host }, requestKind, rangeContainsError, sourceFile) {
-    var _a;
-    const formattingContext = new FormattingContext(sourceFile, requestKind, options);
-    let previousRangeTriviaEnd;
-    let previousRange;
-    let previousParent;
-    let previousRangeStartLine;
-    let lastIndentedLine;
-    let indentationOnLastIndentedLine = -1 /* Unknown */;
-    const edits = [];
-    formattingScanner.advance();
-    if (formattingScanner.isOnToken()) {
-      const startLine = sourceFile.getLineAndCharacterOfPosition(enclosingNode.getStart(sourceFile)).line;
-      let undecoratedStartLine = startLine;
-      if (hasDecorators(enclosingNode)) {
-        undecoratedStartLine = sourceFile.getLineAndCharacterOfPosition(getNonDecoratorTokenPosOfNode(enclosingNode, sourceFile)).line;
-      }
-      processNode(enclosingNode, enclosingNode, startLine, undecoratedStartLine, initialIndentation, delta);
-    }
-    if (!formattingScanner.isOnToken()) {
-      const indentation = SmartIndenter.nodeWillIndentChild(
-        options,
-        enclosingNode,
-        /*child*/
-        void 0,
-        sourceFile,
-        /*indentByDefault*/
-        false
-      ) ? initialIndentation + options.indentSize : initialIndentation;
-      const leadingTrivia = formattingScanner.getCurrentLeadingTrivia();
-      if (leadingTrivia) {
-        indentTriviaItems(
-          leadingTrivia,
-          indentation,
-          /*indentNextTokenOrTrivia*/
-          false,
-          (item) => processRange(
-            item,
-            sourceFile.getLineAndCharacterOfPosition(item.pos),
-            enclosingNode,
-            enclosingNode,
-            /*dynamicIndentation*/
-            void 0
-          )
-        );
-        if (options.trimTrailingWhitespace !== false) {
-          trimTrailingWhitespacesForRemainingRange(leadingTrivia);
+  function isCompletionEntryData(data) {
+    return data === void 0 || data && typeof data === "object" && typeof data.exportName === "string" && (data.fileName === void 0 || typeof data.fileName === "string") && (data.ambientModuleName === void 0 || typeof data.ambientModuleName === "string" && (data.isPackageJsonImport === void 0 || typeof data.isPackageJsonImport === "boolean"));
+  }
+  var nullCancellationToken, CommandNames, MultistepOperation, invalidPartialSemanticModeCommands, invalidSyntacticModeCommands, Session3;
+  var init_session = __esm({
+    "src/server/session.ts"() {
+      "use strict";
+      init_ts7();
+      init_ts_server3();
+      init_protocol();
+      nullCancellationToken = {
+        isCancellationRequested: () => false,
+        setRequest: () => void 0,
+        resetRequest: () => void 0
+      };
+      CommandNames = CommandTypes;
+      MultistepOperation = class {
+        constructor(operationHost) {
+          this.operationHost = operationHost;
+        }
+        startNew(action) {
+          this.complete();
+          this.requestId = this.operationHost.getCurrentRequestId();
+          this.executeAction(action);
+        }
+        complete() {
+          if (this.requestId !== void 0) {
+            this.operationHost.sendRequestCompletedEvent(this.requestId);
+            this.requestId = void 0;
+          }
+          this.setTimerHandle(void 0);
+          this.setImmediateId(void 0);
+        }
+        immediate(actionType, action) {
+          const requestId = this.requestId;
+          Debug.assert(requestId === this.operationHost.getCurrentRequestId(), "immediate: incorrect request id");
+          this.setImmediateId(
+            this.operationHost.getServerHost().setImmediate(() => {
+              this.immediateId = void 0;
+              this.operationHost.executeWithRequestId(requestId, () => this.executeAction(action));
+            }, actionType)
+          );
         }
-      }
-    }
-    if (previousRange && formattingScanner.getTokenFullStart() >= originalRange.end) {
-      const tokenInfo = formattingScanner.isOnEOF() ? formattingScanner.readEOFTokenRange() : formattingScanner.isOnToken() ? formattingScanner.readTokenInfo(enclosingNode).token : void 0;
-      if (tokenInfo && tokenInfo.pos === previousRangeTriviaEnd) {
-        const parent2 = ((_a = findPrecedingToken(tokenInfo.end, sourceFile, enclosingNode)) == null ? void 0 : _a.parent) || previousParent;
-        processPair(
-          tokenInfo,
-          sourceFile.getLineAndCharacterOfPosition(tokenInfo.pos).line,
-          parent2,
-          previousRange,
-          previousRangeStartLine,
-          previousParent,
-          parent2,
-          /*dynamicIndentation*/
-          void 0
-        );
-      }
-    }
-    return edits;
-    function tryComputeIndentationForListItem(startPos, endPos, parentStartLine, range, inheritedIndentation) {
-      if (rangeOverlapsWithStartEnd(range, startPos, endPos) || rangeContainsStartEnd(range, startPos, endPos)) {
-        if (inheritedIndentation !== -1 /* Unknown */) {
-          return inheritedIndentation;
+        delay(actionType, ms, action) {
+          const requestId = this.requestId;
+          Debug.assert(requestId === this.operationHost.getCurrentRequestId(), "delay: incorrect request id");
+          this.setTimerHandle(
+            this.operationHost.getServerHost().setTimeout(
+              () => {
+                this.timerHandle = void 0;
+                this.operationHost.executeWithRequestId(requestId, () => this.executeAction(action));
+              },
+              ms,
+              actionType
+            )
+          );
         }
-      } else {
-        const startLine = sourceFile.getLineAndCharacterOfPosition(startPos).line;
-        const startLinePosition = getLineStartPositionForPosition(startPos, sourceFile);
-        const column = SmartIndenter.findFirstNonWhitespaceColumn(startLinePosition, startPos, sourceFile, options);
-        if (startLine !== parentStartLine || startPos === column) {
-          const baseIndentSize = SmartIndenter.getBaseIndentation(options);
-          return baseIndentSize > column ? baseIndentSize : column;
+        executeAction(action) {
+          var _a, _b, _c, _d, _e, _f;
+          let stop = false;
+          try {
+            if (this.operationHost.isCancellationRequested()) {
+              stop = true;
+              (_a = tracing) == null ? void 0 : _a.instant(tracing.Phase.Session, "stepCanceled", { seq: this.requestId, early: true });
+            } else {
+              (_b = tracing) == null ? void 0 : _b.push(tracing.Phase.Session, "stepAction", { seq: this.requestId });
+              action(this);
+              (_c = tracing) == null ? void 0 : _c.pop();
+            }
+          } catch (e) {
+            (_d = tracing) == null ? void 0 : _d.popAll();
+            stop = true;
+            if (e instanceof OperationCanceledException) {
+              (_e = tracing) == null ? void 0 : _e.instant(tracing.Phase.Session, "stepCanceled", { seq: this.requestId });
+            } else {
+              (_f = tracing) == null ? void 0 : _f.instant(tracing.Phase.Session, "stepError", { seq: this.requestId, message: e.message });
+              this.operationHost.logError(e, `delayed processing of request ${this.requestId}`);
+            }
+          }
+          if (stop || !this.hasPendingWork()) {
+            this.complete();
+          }
+        }
+        setTimerHandle(timerHandle) {
+          if (this.timerHandle !== void 0) {
+            this.operationHost.getServerHost().clearTimeout(this.timerHandle);
+          }
+          this.timerHandle = timerHandle;
+        }
+        setImmediateId(immediateId) {
+          if (this.immediateId !== void 0) {
+            this.operationHost.getServerHost().clearImmediate(this.immediateId);
+          }
+          this.immediateId = immediateId;
+        }
+        hasPendingWork() {
+          return !!this.timerHandle || !!this.immediateId;
+        }
+      };
+      invalidPartialSemanticModeCommands = [
+        "openExternalProject" /* OpenExternalProject */,
+        "openExternalProjects" /* OpenExternalProjects */,
+        "closeExternalProject" /* CloseExternalProject */,
+        "synchronizeProjectList" /* SynchronizeProjectList */,
+        "emit-output" /* EmitOutput */,
+        "compileOnSaveAffectedFileList" /* CompileOnSaveAffectedFileList */,
+        "compileOnSaveEmitFile" /* CompileOnSaveEmitFile */,
+        "compilerOptionsDiagnostics-full" /* CompilerOptionsDiagnosticsFull */,
+        "encodedSemanticClassifications-full" /* EncodedSemanticClassificationsFull */,
+        "semanticDiagnosticsSync" /* SemanticDiagnosticsSync */,
+        "suggestionDiagnosticsSync" /* SuggestionDiagnosticsSync */,
+        "geterrForProject" /* GeterrForProject */,
+        "reload" /* Reload */,
+        "reloadProjects" /* ReloadProjects */,
+        "getCodeFixes" /* GetCodeFixes */,
+        "getCodeFixes-full" /* GetCodeFixesFull */,
+        "getCombinedCodeFix" /* GetCombinedCodeFix */,
+        "getCombinedCodeFix-full" /* GetCombinedCodeFixFull */,
+        "applyCodeActionCommand" /* ApplyCodeActionCommand */,
+        "getSupportedCodeFixes" /* GetSupportedCodeFixes */,
+        "getApplicableRefactors" /* GetApplicableRefactors */,
+        "getMoveToRefactoringFileSuggestions" /* GetMoveToRefactoringFileSuggestions */,
+        "getEditsForRefactor" /* GetEditsForRefactor */,
+        "getEditsForRefactor-full" /* GetEditsForRefactorFull */,
+        "organizeImports" /* OrganizeImports */,
+        "organizeImports-full" /* OrganizeImportsFull */,
+        "getEditsForFileRename" /* GetEditsForFileRename */,
+        "getEditsForFileRename-full" /* GetEditsForFileRenameFull */,
+        "prepareCallHierarchy" /* PrepareCallHierarchy */,
+        "provideCallHierarchyIncomingCalls" /* ProvideCallHierarchyIncomingCalls */,
+        "provideCallHierarchyOutgoingCalls" /* ProvideCallHierarchyOutgoingCalls */
+      ];
+      invalidSyntacticModeCommands = [
+        ...invalidPartialSemanticModeCommands,
+        "definition" /* Definition */,
+        "definition-full" /* DefinitionFull */,
+        "definitionAndBoundSpan" /* DefinitionAndBoundSpan */,
+        "definitionAndBoundSpan-full" /* DefinitionAndBoundSpanFull */,
+        "typeDefinition" /* TypeDefinition */,
+        "implementation" /* Implementation */,
+        "implementation-full" /* ImplementationFull */,
+        "references" /* References */,
+        "references-full" /* ReferencesFull */,
+        "rename" /* Rename */,
+        "renameLocations-full" /* RenameLocationsFull */,
+        "rename-full" /* RenameInfoFull */,
+        "quickinfo" /* Quickinfo */,
+        "quickinfo-full" /* QuickinfoFull */,
+        "completionInfo" /* CompletionInfo */,
+        "completions" /* Completions */,
+        "completions-full" /* CompletionsFull */,
+        "completionEntryDetails" /* CompletionDetails */,
+        "completionEntryDetails-full" /* CompletionDetailsFull */,
+        "signatureHelp" /* SignatureHelp */,
+        "signatureHelp-full" /* SignatureHelpFull */,
+        "navto" /* Navto */,
+        "navto-full" /* NavtoFull */,
+        "documentHighlights" /* DocumentHighlights */,
+        "documentHighlights-full" /* DocumentHighlightsFull */
+      ];
+      Session3 = class _Session {
+        constructor(opts) {
+          this.changeSeq = 0;
+          this.handlers = new Map(Object.entries({
+            // TODO(jakebailey): correctly type the handlers
+            ["status" /* Status */]: () => {
+              const response = { version };
+              return this.requiredResponse(response);
+            },
+            ["openExternalProject" /* OpenExternalProject */]: (request) => {
+              this.projectService.openExternalProject(request.arguments);
+              return this.requiredResponse(
+                /*response*/
+                true
+              );
+            },
+            ["openExternalProjects" /* OpenExternalProjects */]: (request) => {
+              this.projectService.openExternalProjects(request.arguments.projects);
+              return this.requiredResponse(
+                /*response*/
+                true
+              );
+            },
+            ["closeExternalProject" /* CloseExternalProject */]: (request) => {
+              this.projectService.closeExternalProject(request.arguments.projectFileName);
+              return this.requiredResponse(
+                /*response*/
+                true
+              );
+            },
+            ["synchronizeProjectList" /* SynchronizeProjectList */]: (request) => {
+              const result = this.projectService.synchronizeProjectList(request.arguments.knownProjects, request.arguments.includeProjectReferenceRedirectInfo);
+              if (!result.some((p) => p.projectErrors && p.projectErrors.length !== 0)) {
+                return this.requiredResponse(result);
+              }
+              const converted = map(result, (p) => {
+                if (!p.projectErrors || p.projectErrors.length === 0) {
+                  return p;
+                }
+                return {
+                  info: p.info,
+                  changes: p.changes,
+                  files: p.files,
+                  projectErrors: this.convertToDiagnosticsWithLinePosition(
+                    p.projectErrors,
+                    /*scriptInfo*/
+                    void 0
+                  )
+                };
+              });
+              return this.requiredResponse(converted);
+            },
+            ["updateOpen" /* UpdateOpen */]: (request) => {
+              this.changeSeq++;
+              this.projectService.applyChangesInOpenFiles(
+                request.arguments.openFiles && mapIterator(request.arguments.openFiles, (file) => ({
+                  fileName: file.file,
+                  content: file.fileContent,
+                  scriptKind: file.scriptKindName,
+                  projectRootPath: file.projectRootPath
+                })),
+                request.arguments.changedFiles && mapIterator(request.arguments.changedFiles, (file) => ({
+                  fileName: file.fileName,
+                  changes: mapDefinedIterator(arrayReverseIterator(file.textChanges), (change) => {
+                    const scriptInfo = Debug.checkDefined(this.projectService.getScriptInfo(file.fileName));
+                    const start = scriptInfo.lineOffsetToPosition(change.start.line, change.start.offset);
+                    const end = scriptInfo.lineOffsetToPosition(change.end.line, change.end.offset);
+                    return start >= 0 ? { span: { start, length: end - start }, newText: change.newText } : void 0;
+                  })
+                })),
+                request.arguments.closedFiles
+              );
+              return this.requiredResponse(
+                /*response*/
+                true
+              );
+            },
+            ["applyChangedToOpenFiles" /* ApplyChangedToOpenFiles */]: (request) => {
+              this.changeSeq++;
+              this.projectService.applyChangesInOpenFiles(
+                request.arguments.openFiles,
+                request.arguments.changedFiles && mapIterator(request.arguments.changedFiles, (file) => ({
+                  fileName: file.fileName,
+                  // apply changes in reverse order
+                  changes: arrayReverseIterator(file.changes)
+                })),
+                request.arguments.closedFiles
+              );
+              return this.requiredResponse(
+                /*response*/
+                true
+              );
+            },
+            ["exit" /* Exit */]: () => {
+              this.exit();
+              return this.notRequired();
+            },
+            ["definition" /* Definition */]: (request) => {
+              return this.requiredResponse(this.getDefinition(
+                request.arguments,
+                /*simplifiedResult*/
+                true
+              ));
+            },
+            ["definition-full" /* DefinitionFull */]: (request) => {
+              return this.requiredResponse(this.getDefinition(
+                request.arguments,
+                /*simplifiedResult*/
+                false
+              ));
+            },
+            ["definitionAndBoundSpan" /* DefinitionAndBoundSpan */]: (request) => {
+              return this.requiredResponse(this.getDefinitionAndBoundSpan(
+                request.arguments,
+                /*simplifiedResult*/
+                true
+              ));
+            },
+            ["definitionAndBoundSpan-full" /* DefinitionAndBoundSpanFull */]: (request) => {
+              return this.requiredResponse(this.getDefinitionAndBoundSpan(
+                request.arguments,
+                /*simplifiedResult*/
+                false
+              ));
+            },
+            ["findSourceDefinition" /* FindSourceDefinition */]: (request) => {
+              return this.requiredResponse(this.findSourceDefinition(request.arguments));
+            },
+            ["emit-output" /* EmitOutput */]: (request) => {
+              return this.requiredResponse(this.getEmitOutput(request.arguments));
+            },
+            ["typeDefinition" /* TypeDefinition */]: (request) => {
+              return this.requiredResponse(this.getTypeDefinition(request.arguments));
+            },
+            ["implementation" /* Implementation */]: (request) => {
+              return this.requiredResponse(this.getImplementation(
+                request.arguments,
+                /*simplifiedResult*/
+                true
+              ));
+            },
+            ["implementation-full" /* ImplementationFull */]: (request) => {
+              return this.requiredResponse(this.getImplementation(
+                request.arguments,
+                /*simplifiedResult*/
+                false
+              ));
+            },
+            ["references" /* References */]: (request) => {
+              return this.requiredResponse(this.getReferences(
+                request.arguments,
+                /*simplifiedResult*/
+                true
+              ));
+            },
+            ["references-full" /* ReferencesFull */]: (request) => {
+              return this.requiredResponse(this.getReferences(
+                request.arguments,
+                /*simplifiedResult*/
+                false
+              ));
+            },
+            ["rename" /* Rename */]: (request) => {
+              return this.requiredResponse(this.getRenameLocations(
+                request.arguments,
+                /*simplifiedResult*/
+                true
+              ));
+            },
+            ["renameLocations-full" /* RenameLocationsFull */]: (request) => {
+              return this.requiredResponse(this.getRenameLocations(
+                request.arguments,
+                /*simplifiedResult*/
+                false
+              ));
+            },
+            ["rename-full" /* RenameInfoFull */]: (request) => {
+              return this.requiredResponse(this.getRenameInfo(request.arguments));
+            },
+            ["open" /* Open */]: (request) => {
+              this.openClientFile(
+                toNormalizedPath(request.arguments.file),
+                request.arguments.fileContent,
+                convertScriptKindName(request.arguments.scriptKindName),
+                // TODO: GH#18217
+                request.arguments.projectRootPath ? toNormalizedPath(request.arguments.projectRootPath) : void 0
+              );
+              return this.notRequired();
+            },
+            ["quickinfo" /* Quickinfo */]: (request) => {
+              return this.requiredResponse(this.getQuickInfoWorker(
+                request.arguments,
+                /*simplifiedResult*/
+                true
+              ));
+            },
+            ["quickinfo-full" /* QuickinfoFull */]: (request) => {
+              return this.requiredResponse(this.getQuickInfoWorker(
+                request.arguments,
+                /*simplifiedResult*/
+                false
+              ));
+            },
+            ["getOutliningSpans" /* GetOutliningSpans */]: (request) => {
+              return this.requiredResponse(this.getOutliningSpans(
+                request.arguments,
+                /*simplifiedResult*/
+                true
+              ));
+            },
+            ["outliningSpans" /* GetOutliningSpansFull */]: (request) => {
+              return this.requiredResponse(this.getOutliningSpans(
+                request.arguments,
+                /*simplifiedResult*/
+                false
+              ));
+            },
+            ["todoComments" /* TodoComments */]: (request) => {
+              return this.requiredResponse(this.getTodoComments(request.arguments));
+            },
+            ["indentation" /* Indentation */]: (request) => {
+              return this.requiredResponse(this.getIndentation(request.arguments));
+            },
+            ["nameOrDottedNameSpan" /* NameOrDottedNameSpan */]: (request) => {
+              return this.requiredResponse(this.getNameOrDottedNameSpan(request.arguments));
+            },
+            ["breakpointStatement" /* BreakpointStatement */]: (request) => {
+              return this.requiredResponse(this.getBreakpointStatement(request.arguments));
+            },
+            ["braceCompletion" /* BraceCompletion */]: (request) => {
+              return this.requiredResponse(this.isValidBraceCompletion(request.arguments));
+            },
+            ["docCommentTemplate" /* DocCommentTemplate */]: (request) => {
+              return this.requiredResponse(this.getDocCommentTemplate(request.arguments));
+            },
+            ["getSpanOfEnclosingComment" /* GetSpanOfEnclosingComment */]: (request) => {
+              return this.requiredResponse(this.getSpanOfEnclosingComment(request.arguments));
+            },
+            ["fileReferences" /* FileReferences */]: (request) => {
+              return this.requiredResponse(this.getFileReferences(
+                request.arguments,
+                /*simplifiedResult*/
+                true
+              ));
+            },
+            ["fileReferences-full" /* FileReferencesFull */]: (request) => {
+              return this.requiredResponse(this.getFileReferences(
+                request.arguments,
+                /*simplifiedResult*/
+                false
+              ));
+            },
+            ["format" /* Format */]: (request) => {
+              return this.requiredResponse(this.getFormattingEditsForRange(request.arguments));
+            },
+            ["formatonkey" /* Formatonkey */]: (request) => {
+              return this.requiredResponse(this.getFormattingEditsAfterKeystroke(request.arguments));
+            },
+            ["format-full" /* FormatFull */]: (request) => {
+              return this.requiredResponse(this.getFormattingEditsForDocumentFull(request.arguments));
+            },
+            ["formatonkey-full" /* FormatonkeyFull */]: (request) => {
+              return this.requiredResponse(this.getFormattingEditsAfterKeystrokeFull(request.arguments));
+            },
+            ["formatRange-full" /* FormatRangeFull */]: (request) => {
+              return this.requiredResponse(this.getFormattingEditsForRangeFull(request.arguments));
+            },
+            ["completionInfo" /* CompletionInfo */]: (request) => {
+              return this.requiredResponse(this.getCompletions(request.arguments, "completionInfo" /* CompletionInfo */));
+            },
+            ["completions" /* Completions */]: (request) => {
+              return this.requiredResponse(this.getCompletions(request.arguments, "completions" /* Completions */));
+            },
+            ["completions-full" /* CompletionsFull */]: (request) => {
+              return this.requiredResponse(this.getCompletions(request.arguments, "completions-full" /* CompletionsFull */));
+            },
+            ["completionEntryDetails" /* CompletionDetails */]: (request) => {
+              return this.requiredResponse(this.getCompletionEntryDetails(
+                request.arguments,
+                /*fullResult*/
+                false
+              ));
+            },
+            ["completionEntryDetails-full" /* CompletionDetailsFull */]: (request) => {
+              return this.requiredResponse(this.getCompletionEntryDetails(
+                request.arguments,
+                /*fullResult*/
+                true
+              ));
+            },
+            ["compileOnSaveAffectedFileList" /* CompileOnSaveAffectedFileList */]: (request) => {
+              return this.requiredResponse(this.getCompileOnSaveAffectedFileList(request.arguments));
+            },
+            ["compileOnSaveEmitFile" /* CompileOnSaveEmitFile */]: (request) => {
+              return this.requiredResponse(this.emitFile(request.arguments));
+            },
+            ["signatureHelp" /* SignatureHelp */]: (request) => {
+              return this.requiredResponse(this.getSignatureHelpItems(
+                request.arguments,
+                /*simplifiedResult*/
+                true
+              ));
+            },
+            ["signatureHelp-full" /* SignatureHelpFull */]: (request) => {
+              return this.requiredResponse(this.getSignatureHelpItems(
+                request.arguments,
+                /*simplifiedResult*/
+                false
+              ));
+            },
+            ["compilerOptionsDiagnostics-full" /* CompilerOptionsDiagnosticsFull */]: (request) => {
+              return this.requiredResponse(this.getCompilerOptionsDiagnostics(request.arguments));
+            },
+            ["encodedSyntacticClassifications-full" /* EncodedSyntacticClassificationsFull */]: (request) => {
+              return this.requiredResponse(this.getEncodedSyntacticClassifications(request.arguments));
+            },
+            ["encodedSemanticClassifications-full" /* EncodedSemanticClassificationsFull */]: (request) => {
+              return this.requiredResponse(this.getEncodedSemanticClassifications(request.arguments));
+            },
+            ["cleanup" /* Cleanup */]: () => {
+              this.cleanup();
+              return this.requiredResponse(
+                /*response*/
+                true
+              );
+            },
+            ["semanticDiagnosticsSync" /* SemanticDiagnosticsSync */]: (request) => {
+              return this.requiredResponse(this.getSemanticDiagnosticsSync(request.arguments));
+            },
+            ["syntacticDiagnosticsSync" /* SyntacticDiagnosticsSync */]: (request) => {
+              return this.requiredResponse(this.getSyntacticDiagnosticsSync(request.arguments));
+            },
+            ["suggestionDiagnosticsSync" /* SuggestionDiagnosticsSync */]: (request) => {
+              return this.requiredResponse(this.getSuggestionDiagnosticsSync(request.arguments));
+            },
+            ["geterr" /* Geterr */]: (request) => {
+              this.errorCheck.startNew((next) => this.getDiagnostics(next, request.arguments.delay, request.arguments.files));
+              return this.notRequired();
+            },
+            ["geterrForProject" /* GeterrForProject */]: (request) => {
+              this.errorCheck.startNew((next) => this.getDiagnosticsForProject(next, request.arguments.delay, request.arguments.file));
+              return this.notRequired();
+            },
+            ["change" /* Change */]: (request) => {
+              this.change(request.arguments);
+              return this.notRequired();
+            },
+            ["configure" /* Configure */]: (request) => {
+              this.projectService.setHostConfiguration(request.arguments);
+              this.doOutput(
+                /*info*/
+                void 0,
+                "configure" /* Configure */,
+                request.seq,
+                /*success*/
+                true
+              );
+              return this.notRequired();
+            },
+            ["reload" /* Reload */]: (request) => {
+              this.reload(request.arguments, request.seq);
+              return this.requiredResponse({ reloadFinished: true });
+            },
+            ["saveto" /* Saveto */]: (request) => {
+              const savetoArgs = request.arguments;
+              this.saveToTmp(savetoArgs.file, savetoArgs.tmpfile);
+              return this.notRequired();
+            },
+            ["close" /* Close */]: (request) => {
+              const closeArgs = request.arguments;
+              this.closeClientFile(closeArgs.file);
+              return this.notRequired();
+            },
+            ["navto" /* Navto */]: (request) => {
+              return this.requiredResponse(this.getNavigateToItems(
+                request.arguments,
+                /*simplifiedResult*/
+                true
+              ));
+            },
+            ["navto-full" /* NavtoFull */]: (request) => {
+              return this.requiredResponse(this.getNavigateToItems(
+                request.arguments,
+                /*simplifiedResult*/
+                false
+              ));
+            },
+            ["brace" /* Brace */]: (request) => {
+              return this.requiredResponse(this.getBraceMatching(
+                request.arguments,
+                /*simplifiedResult*/
+                true
+              ));
+            },
+            ["brace-full" /* BraceFull */]: (request) => {
+              return this.requiredResponse(this.getBraceMatching(
+                request.arguments,
+                /*simplifiedResult*/
+                false
+              ));
+            },
+            ["navbar" /* NavBar */]: (request) => {
+              return this.requiredResponse(this.getNavigationBarItems(
+                request.arguments,
+                /*simplifiedResult*/
+                true
+              ));
+            },
+            ["navbar-full" /* NavBarFull */]: (request) => {
+              return this.requiredResponse(this.getNavigationBarItems(
+                request.arguments,
+                /*simplifiedResult*/
+                false
+              ));
+            },
+            ["navtree" /* NavTree */]: (request) => {
+              return this.requiredResponse(this.getNavigationTree(
+                request.arguments,
+                /*simplifiedResult*/
+                true
+              ));
+            },
+            ["navtree-full" /* NavTreeFull */]: (request) => {
+              return this.requiredResponse(this.getNavigationTree(
+                request.arguments,
+                /*simplifiedResult*/
+                false
+              ));
+            },
+            ["documentHighlights" /* DocumentHighlights */]: (request) => {
+              return this.requiredResponse(this.getDocumentHighlights(
+                request.arguments,
+                /*simplifiedResult*/
+                true
+              ));
+            },
+            ["documentHighlights-full" /* DocumentHighlightsFull */]: (request) => {
+              return this.requiredResponse(this.getDocumentHighlights(
+                request.arguments,
+                /*simplifiedResult*/
+                false
+              ));
+            },
+            ["compilerOptionsForInferredProjects" /* CompilerOptionsForInferredProjects */]: (request) => {
+              this.setCompilerOptionsForInferredProjects(request.arguments);
+              return this.requiredResponse(
+                /*response*/
+                true
+              );
+            },
+            ["projectInfo" /* ProjectInfo */]: (request) => {
+              return this.requiredResponse(this.getProjectInfo(request.arguments));
+            },
+            ["reloadProjects" /* ReloadProjects */]: () => {
+              this.projectService.reloadProjects();
+              return this.notRequired();
+            },
+            ["jsxClosingTag" /* JsxClosingTag */]: (request) => {
+              return this.requiredResponse(this.getJsxClosingTag(request.arguments));
+            },
+            ["linkedEditingRange" /* LinkedEditingRange */]: (request) => {
+              return this.requiredResponse(this.getLinkedEditingRange(request.arguments));
+            },
+            ["getCodeFixes" /* GetCodeFixes */]: (request) => {
+              return this.requiredResponse(this.getCodeFixes(
+                request.arguments,
+                /*simplifiedResult*/
+                true
+              ));
+            },
+            ["getCodeFixes-full" /* GetCodeFixesFull */]: (request) => {
+              return this.requiredResponse(this.getCodeFixes(
+                request.arguments,
+                /*simplifiedResult*/
+                false
+              ));
+            },
+            ["getCombinedCodeFix" /* GetCombinedCodeFix */]: (request) => {
+              return this.requiredResponse(this.getCombinedCodeFix(
+                request.arguments,
+                /*simplifiedResult*/
+                true
+              ));
+            },
+            ["getCombinedCodeFix-full" /* GetCombinedCodeFixFull */]: (request) => {
+              return this.requiredResponse(this.getCombinedCodeFix(
+                request.arguments,
+                /*simplifiedResult*/
+                false
+              ));
+            },
+            ["applyCodeActionCommand" /* ApplyCodeActionCommand */]: (request) => {
+              return this.requiredResponse(this.applyCodeActionCommand(request.arguments));
+            },
+            ["getSupportedCodeFixes" /* GetSupportedCodeFixes */]: (request) => {
+              return this.requiredResponse(this.getSupportedCodeFixes(request.arguments));
+            },
+            ["getApplicableRefactors" /* GetApplicableRefactors */]: (request) => {
+              return this.requiredResponse(this.getApplicableRefactors(request.arguments));
+            },
+            ["getEditsForRefactor" /* GetEditsForRefactor */]: (request) => {
+              return this.requiredResponse(this.getEditsForRefactor(
+                request.arguments,
+                /*simplifiedResult*/
+                true
+              ));
+            },
+            ["getMoveToRefactoringFileSuggestions" /* GetMoveToRefactoringFileSuggestions */]: (request) => {
+              return this.requiredResponse(this.getMoveToRefactoringFileSuggestions(request.arguments));
+            },
+            ["getEditsForRefactor-full" /* GetEditsForRefactorFull */]: (request) => {
+              return this.requiredResponse(this.getEditsForRefactor(
+                request.arguments,
+                /*simplifiedResult*/
+                false
+              ));
+            },
+            ["organizeImports" /* OrganizeImports */]: (request) => {
+              return this.requiredResponse(this.organizeImports(
+                request.arguments,
+                /*simplifiedResult*/
+                true
+              ));
+            },
+            ["organizeImports-full" /* OrganizeImportsFull */]: (request) => {
+              return this.requiredResponse(this.organizeImports(
+                request.arguments,
+                /*simplifiedResult*/
+                false
+              ));
+            },
+            ["getEditsForFileRename" /* GetEditsForFileRename */]: (request) => {
+              return this.requiredResponse(this.getEditsForFileRename(
+                request.arguments,
+                /*simplifiedResult*/
+                true
+              ));
+            },
+            ["getEditsForFileRename-full" /* GetEditsForFileRenameFull */]: (request) => {
+              return this.requiredResponse(this.getEditsForFileRename(
+                request.arguments,
+                /*simplifiedResult*/
+                false
+              ));
+            },
+            ["configurePlugin" /* ConfigurePlugin */]: (request) => {
+              this.configurePlugin(request.arguments);
+              this.doOutput(
+                /*info*/
+                void 0,
+                "configurePlugin" /* ConfigurePlugin */,
+                request.seq,
+                /*success*/
+                true
+              );
+              return this.notRequired();
+            },
+            ["selectionRange" /* SelectionRange */]: (request) => {
+              return this.requiredResponse(this.getSmartSelectionRange(
+                request.arguments,
+                /*simplifiedResult*/
+                true
+              ));
+            },
+            ["selectionRange-full" /* SelectionRangeFull */]: (request) => {
+              return this.requiredResponse(this.getSmartSelectionRange(
+                request.arguments,
+                /*simplifiedResult*/
+                false
+              ));
+            },
+            ["prepareCallHierarchy" /* PrepareCallHierarchy */]: (request) => {
+              return this.requiredResponse(this.prepareCallHierarchy(request.arguments));
+            },
+            ["provideCallHierarchyIncomingCalls" /* ProvideCallHierarchyIncomingCalls */]: (request) => {
+              return this.requiredResponse(this.provideCallHierarchyIncomingCalls(request.arguments));
+            },
+            ["provideCallHierarchyOutgoingCalls" /* ProvideCallHierarchyOutgoingCalls */]: (request) => {
+              return this.requiredResponse(this.provideCallHierarchyOutgoingCalls(request.arguments));
+            },
+            ["toggleLineComment" /* ToggleLineComment */]: (request) => {
+              return this.requiredResponse(this.toggleLineComment(
+                request.arguments,
+                /*simplifiedResult*/
+                true
+              ));
+            },
+            ["toggleLineComment-full" /* ToggleLineCommentFull */]: (request) => {
+              return this.requiredResponse(this.toggleLineComment(
+                request.arguments,
+                /*simplifiedResult*/
+                false
+              ));
+            },
+            ["toggleMultilineComment" /* ToggleMultilineComment */]: (request) => {
+              return this.requiredResponse(this.toggleMultilineComment(
+                request.arguments,
+                /*simplifiedResult*/
+                true
+              ));
+            },
+            ["toggleMultilineComment-full" /* ToggleMultilineCommentFull */]: (request) => {
+              return this.requiredResponse(this.toggleMultilineComment(
+                request.arguments,
+                /*simplifiedResult*/
+                false
+              ));
+            },
+            ["commentSelection" /* CommentSelection */]: (request) => {
+              return this.requiredResponse(this.commentSelection(
+                request.arguments,
+                /*simplifiedResult*/
+                true
+              ));
+            },
+            ["commentSelection-full" /* CommentSelectionFull */]: (request) => {
+              return this.requiredResponse(this.commentSelection(
+                request.arguments,
+                /*simplifiedResult*/
+                false
+              ));
+            },
+            ["uncommentSelection" /* UncommentSelection */]: (request) => {
+              return this.requiredResponse(this.uncommentSelection(
+                request.arguments,
+                /*simplifiedResult*/
+                true
+              ));
+            },
+            ["uncommentSelection-full" /* UncommentSelectionFull */]: (request) => {
+              return this.requiredResponse(this.uncommentSelection(
+                request.arguments,
+                /*simplifiedResult*/
+                false
+              ));
+            },
+            ["provideInlayHints" /* ProvideInlayHints */]: (request) => {
+              return this.requiredResponse(this.provideInlayHints(request.arguments));
+            }
+          }));
+          this.host = opts.host;
+          this.cancellationToken = opts.cancellationToken;
+          this.typingsInstaller = opts.typingsInstaller || nullTypingsInstaller;
+          this.byteLength = opts.byteLength;
+          this.hrtime = opts.hrtime;
+          this.logger = opts.logger;
+          this.canUseEvents = opts.canUseEvents;
+          this.suppressDiagnosticEvents = opts.suppressDiagnosticEvents;
+          this.noGetErrOnBackgroundUpdate = opts.noGetErrOnBackgroundUpdate;
+          const { throttleWaitMilliseconds } = opts;
+          this.eventHandler = this.canUseEvents ? opts.eventHandler || ((event) => this.defaultEventHandler(event)) : void 0;
+          const multistepOperationHost = {
+            executeWithRequestId: (requestId, action) => this.executeWithRequestId(requestId, action),
+            getCurrentRequestId: () => this.currentRequestId,
+            getServerHost: () => this.host,
+            logError: (err, cmd) => this.logError(err, cmd),
+            sendRequestCompletedEvent: (requestId) => this.sendRequestCompletedEvent(requestId),
+            isCancellationRequested: () => this.cancellationToken.isCancellationRequested()
+          };
+          this.errorCheck = new MultistepOperation(multistepOperationHost);
+          const settings = {
+            host: this.host,
+            logger: this.logger,
+            cancellationToken: this.cancellationToken,
+            useSingleInferredProject: opts.useSingleInferredProject,
+            useInferredProjectPerProjectRoot: opts.useInferredProjectPerProjectRoot,
+            typingsInstaller: this.typingsInstaller,
+            throttleWaitMilliseconds,
+            eventHandler: this.eventHandler,
+            suppressDiagnosticEvents: this.suppressDiagnosticEvents,
+            globalPlugins: opts.globalPlugins,
+            pluginProbeLocations: opts.pluginProbeLocations,
+            allowLocalPluginLoads: opts.allowLocalPluginLoads,
+            typesMapLocation: opts.typesMapLocation,
+            serverMode: opts.serverMode,
+            session: this,
+            canUseWatchEvents: opts.canUseWatchEvents,
+            incrementalVerifier: opts.incrementalVerifier
+          };
+          this.projectService = new ProjectService3(settings);
+          this.projectService.setPerformanceEventHandler(this.performanceEventHandler.bind(this));
+          this.gcTimer = new GcTimer(
+            this.host,
+            /*delay*/
+            7e3,
+            this.logger
+          );
+          switch (this.projectService.serverMode) {
+            case 0 /* Semantic */:
+              break;
+            case 1 /* PartialSemantic */:
+              invalidPartialSemanticModeCommands.forEach(
+                (commandName) => this.handlers.set(commandName, (request) => {
+                  throw new Error(`Request: ${request.command} not allowed in LanguageServiceMode.PartialSemantic`);
+                })
+              );
+              break;
+            case 2 /* Syntactic */:
+              invalidSyntacticModeCommands.forEach(
+                (commandName) => this.handlers.set(commandName, (request) => {
+                  throw new Error(`Request: ${request.command} not allowed in LanguageServiceMode.Syntactic`);
+                })
+              );
+              break;
+            default:
+              Debug.assertNever(this.projectService.serverMode);
+          }
         }
-      }
-      return -1 /* Unknown */;
-    }
-    function computeIndentation(node, startLine, inheritedIndentation, parent2, parentDynamicIndentation, effectiveParentStartLine) {
-      const delta2 = SmartIndenter.shouldIndentChildNode(options, node) ? options.indentSize : 0;
-      if (effectiveParentStartLine === startLine) {
-        return {
-          indentation: startLine === lastIndentedLine ? indentationOnLastIndentedLine : parentDynamicIndentation.getIndentation(),
-          delta: Math.min(options.indentSize, parentDynamicIndentation.getDelta(node) + delta2)
-        };
-      } else if (inheritedIndentation === -1 /* Unknown */) {
-        if (node.kind === 21 /* OpenParenToken */ && startLine === lastIndentedLine) {
-          return { indentation: indentationOnLastIndentedLine, delta: parentDynamicIndentation.getDelta(node) };
-        } else if (SmartIndenter.childStartsOnTheSameLineWithElseInIfStatement(parent2, node, startLine, sourceFile) || SmartIndenter.childIsUnindentedBranchOfConditionalExpression(parent2, node, startLine, sourceFile) || SmartIndenter.argumentStartsOnSameLineAsPreviousArgument(parent2, node, startLine, sourceFile)) {
-          return { indentation: parentDynamicIndentation.getIndentation(), delta: delta2 };
-        } else {
-          return { indentation: parentDynamicIndentation.getIndentation() + parentDynamicIndentation.getDelta(node), delta: delta2 };
+        sendRequestCompletedEvent(requestId) {
+          this.event({ request_seq: requestId }, "requestCompleted");
         }
-      } else {
-        return { indentation: inheritedIndentation, delta: delta2 };
-      }
-    }
-    function getFirstNonDecoratorTokenOfNode(node) {
-      if (canHaveModifiers(node)) {
-        const modifier = find(node.modifiers, isModifier, findIndex(node.modifiers, isDecorator));
-        if (modifier)
-          return modifier.kind;
-      }
-      switch (node.kind) {
-        case 262 /* ClassDeclaration */:
-          return 86 /* ClassKeyword */;
-        case 263 /* InterfaceDeclaration */:
-          return 120 /* InterfaceKeyword */;
-        case 261 /* FunctionDeclaration */:
-          return 100 /* FunctionKeyword */;
-        case 265 /* EnumDeclaration */:
-          return 265 /* EnumDeclaration */;
-        case 176 /* GetAccessor */:
-          return 139 /* GetKeyword */;
-        case 177 /* SetAccessor */:
-          return 153 /* SetKeyword */;
-        case 173 /* MethodDeclaration */:
-          if (node.asteriskToken) {
-            return 42 /* AsteriskToken */;
+        addPerformanceData(key, value) {
+          if (!this.performanceData) {
+            this.performanceData = {};
           }
-        case 171 /* PropertyDeclaration */:
-        case 168 /* Parameter */:
-          const name = getNameOfDeclaration(node);
-          if (name) {
-            return name.kind;
+          this.performanceData[key] = (this.performanceData[key] ?? 0) + value;
+        }
+        performanceEventHandler(event) {
+          switch (event.kind) {
+            case "UpdateGraph":
+              this.addPerformanceData("updateGraphDurationMs", event.durationMs);
+              break;
+            case "CreatePackageJsonAutoImportProvider":
+              this.addPerformanceData("createAutoImportProviderProgramDurationMs", event.durationMs);
+              break;
           }
-      }
-    }
-    function getDynamicIndentation(node, nodeStartLine, indentation, delta2) {
-      return {
-        getIndentationForComment: (kind, tokenIndentation, container) => {
-          switch (kind) {
-            case 20 /* CloseBraceToken */:
-            case 24 /* CloseBracketToken */:
-            case 22 /* CloseParenToken */:
-              return indentation + getDelta(container);
+        }
+        defaultEventHandler(event) {
+          switch (event.eventName) {
+            case ProjectsUpdatedInBackgroundEvent:
+              this.projectsUpdatedInBackgroundEvent(event.data.openFiles);
+              break;
+            case ProjectLoadingStartEvent:
+              this.event({
+                projectName: event.data.project.getProjectName(),
+                reason: event.data.reason
+              }, event.eventName);
+              break;
+            case ProjectLoadingFinishEvent:
+              this.event({
+                projectName: event.data.project.getProjectName()
+              }, event.eventName);
+              break;
+            case LargeFileReferencedEvent:
+            case CreateFileWatcherEvent:
+            case CreateDirectoryWatcherEvent:
+            case CloseFileWatcherEvent:
+              this.event(event.data, event.eventName);
+              break;
+            case ConfigFileDiagEvent:
+              this.event({
+                triggerFile: event.data.triggerFile,
+                configFile: event.data.configFileName,
+                diagnostics: map(event.data.diagnostics, (diagnostic) => formatDiagnosticToProtocol(
+                  diagnostic,
+                  /*includeFileName*/
+                  true
+                ))
+              }, event.eventName);
+              break;
+            case ProjectLanguageServiceStateEvent: {
+              this.event({
+                projectName: event.data.project.getProjectName(),
+                languageServiceEnabled: event.data.languageServiceEnabled
+              }, event.eventName);
+              break;
+            }
+            case ProjectInfoTelemetryEvent: {
+              const eventName = "telemetry";
+              this.event({
+                telemetryEventName: event.eventName,
+                payload: event.data
+              }, eventName);
+              break;
+            }
           }
-          return tokenIndentation !== -1 /* Unknown */ ? tokenIndentation : indentation;
-        },
-        // if list end token is LessThanToken '>' then its delta should be explicitly suppressed
-        // so that LessThanToken as a binary operator can still be indented.
-        // foo.then
-        //     <
-        //         number,
-        //         string,
-        //     >();
-        // vs
-        // var a = xValue
-        //     > yValue;
-        getIndentationForToken: (line, kind, container, suppressDelta) => !suppressDelta && shouldAddDelta(line, kind, container) ? indentation + getDelta(container) : indentation,
-        getIndentation: () => indentation,
-        getDelta,
-        recomputeIndentation: (lineAdded, parent2) => {
-          if (SmartIndenter.shouldIndentChildNode(options, parent2, node, sourceFile)) {
-            indentation += lineAdded ? options.indentSize : -options.indentSize;
-            delta2 = SmartIndenter.shouldIndentChildNode(options, node) ? options.indentSize : 0;
+        }
+        projectsUpdatedInBackgroundEvent(openFiles) {
+          this.projectService.logger.info(`got projects updated in background, updating diagnostics for ${openFiles}`);
+          if (openFiles.length) {
+            if (!this.suppressDiagnosticEvents && !this.noGetErrOnBackgroundUpdate) {
+              this.errorCheck.startNew((next) => this.updateErrorCheck(
+                next,
+                openFiles,
+                100,
+                /*requireOpen*/
+                true
+              ));
+            }
+            this.event({
+              openFiles
+            }, ProjectsUpdatedInBackgroundEvent);
           }
         }
-      };
-      function shouldAddDelta(line, kind, container) {
-        switch (kind) {
-          case 19 /* OpenBraceToken */:
-          case 20 /* CloseBraceToken */:
-          case 22 /* CloseParenToken */:
-          case 93 /* ElseKeyword */:
-          case 117 /* WhileKeyword */:
-          case 60 /* AtToken */:
-            return false;
-          case 44 /* SlashToken */:
-          case 32 /* GreaterThanToken */:
-            switch (container.kind) {
-              case 285 /* JsxOpeningElement */:
-              case 286 /* JsxClosingElement */:
-              case 284 /* JsxSelfClosingElement */:
-                return false;
+        logError(err, cmd) {
+          this.logErrorWorker(err, cmd);
+        }
+        logErrorWorker(err, cmd, fileRequest) {
+          let msg = "Exception on executing command " + cmd;
+          if (err.message) {
+            msg += ":\n" + indent2(err.message);
+            if (err.stack) {
+              msg += "\n" + indent2(err.stack);
             }
-            break;
-          case 23 /* OpenBracketToken */:
-          case 24 /* CloseBracketToken */:
-            if (container.kind !== 199 /* MappedType */) {
-              return false;
+          }
+          if (this.logger.hasLevel(3 /* verbose */)) {
+            if (fileRequest) {
+              try {
+                const { file, project } = this.getFileAndProject(fileRequest);
+                const scriptInfo = project.getScriptInfoForNormalizedPath(file);
+                if (scriptInfo) {
+                  const text = getSnapshotText(scriptInfo.getSnapshot());
+                  msg += `
+
+File text of ${fileRequest.file}:${indent2(text)}
+`;
+                }
+              } catch {
+              }
             }
-            break;
-        }
-        return nodeStartLine !== line && !(hasDecorators(node) && kind === getFirstNonDecoratorTokenOfNode(node));
-      }
-      function getDelta(child) {
-        return SmartIndenter.nodeWillIndentChild(
-          options,
-          node,
-          child,
-          sourceFile,
-          /*indentByDefault*/
-          true
-        ) ? delta2 : 0;
-      }
-    }
-    function processNode(node, contextNode, nodeStartLine, undecoratedNodeStartLine, indentation, delta2) {
-      if (!rangeOverlapsWithStartEnd(originalRange, node.getStart(sourceFile), node.getEnd())) {
-        return;
-      }
-      const nodeDynamicIndentation = getDynamicIndentation(node, nodeStartLine, indentation, delta2);
-      let childContextNode = contextNode;
-      forEachChild(
-        node,
-        (child) => {
-          processChildNode(
-            child,
-            /*inheritedIndentation*/
-            -1 /* Unknown */,
-            node,
-            nodeDynamicIndentation,
-            nodeStartLine,
-            undecoratedNodeStartLine,
-            /*isListItem*/
-            false
-          );
-        },
-        (nodes) => {
-          processChildNodes(nodes, node, nodeStartLine, nodeDynamicIndentation);
+            if (err.ProgramFiles) {
+              msg += `
+
+Program files: ${JSON.stringify(err.ProgramFiles)}
+`;
+              msg += `
+
+Projects::
+`;
+              let counter = 0;
+              const addProjectInfo = (project) => {
+                msg += `
+Project '${project.projectName}' (${ProjectKind[project.projectKind]}) ${counter}
+`;
+                msg += project.filesToString(
+                  /*writeProjectFileNames*/
+                  true
+                );
+                msg += "\n-----------------------------------------------\n";
+                counter++;
+              };
+              this.projectService.externalProjects.forEach(addProjectInfo);
+              this.projectService.configuredProjects.forEach(addProjectInfo);
+              this.projectService.inferredProjects.forEach(addProjectInfo);
+            }
+          }
+          this.logger.msg(msg, "Err" /* Err */);
         }
-      );
-      while (formattingScanner.isOnToken() && formattingScanner.getTokenFullStart() < originalRange.end) {
-        const tokenInfo = formattingScanner.readTokenInfo(node);
-        if (tokenInfo.token.end > Math.min(node.end, originalRange.end)) {
-          break;
+        send(msg) {
+          if (msg.type === "event" && !this.canUseEvents) {
+            if (this.logger.hasLevel(3 /* verbose */)) {
+              this.logger.info(`Session does not support events: ignored event: ${JSON.stringify(msg)}`);
+            }
+            return;
+          }
+          this.writeMessage(msg);
         }
-        consumeTokenAndAdvanceScanner(tokenInfo, node, nodeDynamicIndentation, node);
-      }
-      function processChildNode(child, inheritedIndentation, parent2, parentDynamicIndentation, parentStartLine, undecoratedParentStartLine, isListItem, isFirstListItem) {
-        Debug.assert(!nodeIsSynthesized(child));
-        if (nodeIsMissing(child) || isGrammarError(parent2, child)) {
-          return inheritedIndentation;
+        writeMessage(msg) {
+          var _a;
+          const msgText = formatMessage2(msg, this.logger, this.byteLength, this.host.newLine);
+          (_a = perfLogger) == null ? void 0 : _a.logEvent(`Response message size: ${msgText.length}`);
+          this.host.write(msgText);
         }
-        const childStartPos = child.getStart(sourceFile);
-        const childStartLine = sourceFile.getLineAndCharacterOfPosition(childStartPos).line;
-        let undecoratedChildStartLine = childStartLine;
-        if (hasDecorators(child)) {
-          undecoratedChildStartLine = sourceFile.getLineAndCharacterOfPosition(getNonDecoratorTokenPosOfNode(child, sourceFile)).line;
+        event(body, eventName) {
+          this.send(toEvent(eventName, body));
         }
-        let childIndentationAmount = -1 /* Unknown */;
-        if (isListItem && rangeContainsRange(originalRange, parent2)) {
-          childIndentationAmount = tryComputeIndentationForListItem(childStartPos, child.end, parentStartLine, originalRange, inheritedIndentation);
-          if (childIndentationAmount !== -1 /* Unknown */) {
-            inheritedIndentation = childIndentationAmount;
+        /** @internal */
+        doOutput(info, cmdName, reqSeq, success, message) {
+          const res = {
+            seq: 0,
+            type: "response",
+            command: cmdName,
+            request_seq: reqSeq,
+            success,
+            performanceData: this.performanceData
+          };
+          if (success) {
+            let metadata;
+            if (isArray(info)) {
+              res.body = info;
+              metadata = info.metadata;
+              delete info.metadata;
+            } else if (typeof info === "object") {
+              if (info.metadata) {
+                const { metadata: infoMetadata, ...body } = info;
+                res.body = body;
+                metadata = infoMetadata;
+              } else {
+                res.body = info;
+              }
+            } else {
+              res.body = info;
+            }
+            if (metadata)
+              res.metadata = metadata;
+          } else {
+            Debug.assert(info === void 0);
           }
-        }
-        if (!rangeOverlapsWithStartEnd(originalRange, child.pos, child.end)) {
-          if (child.end < originalRange.pos) {
-            formattingScanner.skipToEndOf(child);
+          if (message) {
+            res.message = message;
           }
-          return inheritedIndentation;
+          this.send(res);
         }
-        if (child.getFullWidth() === 0) {
-          return inheritedIndentation;
+        semanticCheck(file, project) {
+          var _a, _b;
+          (_a = tracing) == null ? void 0 : _a.push(tracing.Phase.Session, "semanticCheck", { file, configFilePath: project.canonicalConfigFilePath });
+          const diags = isDeclarationFileInJSOnlyNonConfiguredProject(project, file) ? emptyArray2 : project.getLanguageService().getSemanticDiagnostics(file).filter((d) => !!d.file);
+          this.sendDiagnosticsEvent(file, project, diags, "semanticDiag");
+          (_b = tracing) == null ? void 0 : _b.pop();
         }
-        while (formattingScanner.isOnToken() && formattingScanner.getTokenFullStart() < originalRange.end) {
-          const tokenInfo = formattingScanner.readTokenInfo(node);
-          if (tokenInfo.token.end > originalRange.end) {
-            return inheritedIndentation;
+        syntacticCheck(file, project) {
+          var _a, _b;
+          (_a = tracing) == null ? void 0 : _a.push(tracing.Phase.Session, "syntacticCheck", { file, configFilePath: project.canonicalConfigFilePath });
+          this.sendDiagnosticsEvent(file, project, project.getLanguageService().getSyntacticDiagnostics(file), "syntaxDiag");
+          (_b = tracing) == null ? void 0 : _b.pop();
+        }
+        suggestionCheck(file, project) {
+          var _a, _b;
+          (_a = tracing) == null ? void 0 : _a.push(tracing.Phase.Session, "suggestionCheck", { file, configFilePath: project.canonicalConfigFilePath });
+          this.sendDiagnosticsEvent(file, project, project.getLanguageService().getSuggestionDiagnostics(file), "suggestionDiag");
+          (_b = tracing) == null ? void 0 : _b.pop();
+        }
+        sendDiagnosticsEvent(file, project, diagnostics, kind) {
+          try {
+            this.event({ file, diagnostics: diagnostics.map((diag2) => formatDiag(file, project, diag2)) }, kind);
+          } catch (err) {
+            this.logError(err, kind);
           }
-          if (tokenInfo.token.end > childStartPos) {
-            if (tokenInfo.token.pos > childStartPos) {
-              formattingScanner.skipToStartOf(child);
+        }
+        /** It is the caller's responsibility to verify that `!this.suppressDiagnosticEvents`. */
+        updateErrorCheck(next, checkList, ms, requireOpen = true) {
+          Debug.assert(!this.suppressDiagnosticEvents);
+          const seq = this.changeSeq;
+          const followMs = Math.min(ms, 200);
+          let index = 0;
+          const goNext = () => {
+            index++;
+            if (checkList.length > index) {
+              next.delay("checkOne", followMs, checkOne);
             }
-            break;
+          };
+          const checkOne = () => {
+            if (this.changeSeq !== seq) {
+              return;
+            }
+            let item = checkList[index];
+            if (isString(item)) {
+              item = this.toPendingErrorCheck(item);
+              if (!item) {
+                goNext();
+                return;
+              }
+            }
+            const { fileName, project } = item;
+            updateProjectIfDirty(project);
+            if (!project.containsFile(fileName, requireOpen)) {
+              return;
+            }
+            this.syntacticCheck(fileName, project);
+            if (this.changeSeq !== seq) {
+              return;
+            }
+            if (project.projectService.serverMode !== 0 /* Semantic */) {
+              goNext();
+              return;
+            }
+            next.immediate("semanticCheck", () => {
+              this.semanticCheck(fileName, project);
+              if (this.changeSeq !== seq) {
+                return;
+              }
+              if (this.getPreferences(fileName).disableSuggestions) {
+                goNext();
+                return;
+              }
+              next.immediate("suggestionCheck", () => {
+                this.suggestionCheck(fileName, project);
+                goNext();
+              });
+            });
+          };
+          if (checkList.length > index && this.changeSeq === seq) {
+            next.delay("checkOne", ms, checkOne);
           }
-          consumeTokenAndAdvanceScanner(tokenInfo, node, parentDynamicIndentation, node);
         }
-        if (!formattingScanner.isOnToken() || formattingScanner.getTokenFullStart() >= originalRange.end) {
-          return inheritedIndentation;
+        cleanProjects(caption, projects) {
+          if (!projects) {
+            return;
+          }
+          this.logger.info(`cleaning ${caption}`);
+          for (const p of projects) {
+            p.getLanguageService(
+              /*ensureSynchronized*/
+              false
+            ).cleanupSemanticCache();
+            p.cleanupProgram();
+          }
         }
-        if (isToken(child)) {
-          const tokenInfo = formattingScanner.readTokenInfo(child);
-          if (child.kind !== 12 /* JsxText */) {
-            Debug.assert(tokenInfo.token.end === child.end, "Token end is child end");
-            consumeTokenAndAdvanceScanner(tokenInfo, node, parentDynamicIndentation, child);
-            return inheritedIndentation;
+        cleanup() {
+          this.cleanProjects("inferred projects", this.projectService.inferredProjects);
+          this.cleanProjects("configured projects", arrayFrom(this.projectService.configuredProjects.values()));
+          this.cleanProjects("external projects", this.projectService.externalProjects);
+          if (this.host.gc) {
+            this.logger.info(`host.gc()`);
+            this.host.gc();
           }
         }
-        const effectiveParentStartLine = child.kind === 169 /* Decorator */ ? childStartLine : undecoratedParentStartLine;
-        const childIndentation = computeIndentation(child, childStartLine, childIndentationAmount, node, parentDynamicIndentation, effectiveParentStartLine);
-        processNode(child, childContextNode, childStartLine, undecoratedChildStartLine, childIndentation.indentation, childIndentation.delta);
-        childContextNode = node;
-        if (isFirstListItem && parent2.kind === 208 /* ArrayLiteralExpression */ && inheritedIndentation === -1 /* Unknown */) {
-          inheritedIndentation = childIndentation.indentation;
+        getEncodedSyntacticClassifications(args) {
+          const { file, languageService } = this.getFileAndLanguageServiceForSyntacticOperation(args);
+          return languageService.getEncodedSyntacticClassifications(file, args);
         }
-        return inheritedIndentation;
-      }
-      function processChildNodes(nodes, parent2, parentStartLine, parentDynamicIndentation) {
-        Debug.assert(isNodeArray(nodes));
-        Debug.assert(!nodeIsSynthesized(nodes));
-        const listStartToken = getOpenTokenForList(parent2, nodes);
-        let listDynamicIndentation = parentDynamicIndentation;
-        let startLine = parentStartLine;
-        if (!rangeOverlapsWithStartEnd(originalRange, nodes.pos, nodes.end)) {
-          if (nodes.end < originalRange.pos) {
-            formattingScanner.skipToEndOf(nodes);
+        getEncodedSemanticClassifications(args) {
+          const { file, project } = this.getFileAndProject(args);
+          const format = args.format === "2020" ? "2020" /* TwentyTwenty */ : "original" /* Original */;
+          return project.getLanguageService().getEncodedSemanticClassifications(file, args, format);
+        }
+        getProject(projectFileName) {
+          return projectFileName === void 0 ? void 0 : this.projectService.findProject(projectFileName);
+        }
+        getConfigFileAndProject(args) {
+          const project = this.getProject(args.projectFileName);
+          const file = toNormalizedPath(args.file);
+          return {
+            configFile: project && project.hasConfigFile(file) ? file : void 0,
+            project
+          };
+        }
+        getConfigFileDiagnostics(configFile, project, includeLinePosition) {
+          const projectErrors = project.getAllProjectErrors();
+          const optionsErrors = project.getLanguageService().getCompilerOptionsDiagnostics();
+          const diagnosticsForConfigFile = filter(
+            concatenate(projectErrors, optionsErrors),
+            (diagnostic) => !!diagnostic.file && diagnostic.file.fileName === configFile
+          );
+          return includeLinePosition ? this.convertToDiagnosticsWithLinePositionFromDiagnosticFile(diagnosticsForConfigFile) : map(
+            diagnosticsForConfigFile,
+            (diagnostic) => formatDiagnosticToProtocol(
+              diagnostic,
+              /*includeFileName*/
+              false
+            )
+          );
+        }
+        convertToDiagnosticsWithLinePositionFromDiagnosticFile(diagnostics) {
+          return diagnostics.map((d) => ({
+            message: flattenDiagnosticMessageText(d.messageText, this.host.newLine),
+            start: d.start,
+            // TODO: GH#18217
+            length: d.length,
+            // TODO: GH#18217
+            category: diagnosticCategoryName(d),
+            code: d.code,
+            source: d.source,
+            startLocation: d.file && convertToLocation(getLineAndCharacterOfPosition(d.file, d.start)),
+            // TODO: GH#18217
+            endLocation: d.file && convertToLocation(getLineAndCharacterOfPosition(d.file, d.start + d.length)),
+            // TODO: GH#18217
+            reportsUnnecessary: d.reportsUnnecessary,
+            reportsDeprecated: d.reportsDeprecated,
+            relatedInformation: map(d.relatedInformation, formatRelatedInformation)
+          }));
+        }
+        getCompilerOptionsDiagnostics(args) {
+          const project = this.getProject(args.projectFileName);
+          return this.convertToDiagnosticsWithLinePosition(
+            filter(
+              project.getLanguageService().getCompilerOptionsDiagnostics(),
+              (diagnostic) => !diagnostic.file
+            ),
+            /*scriptInfo*/
+            void 0
+          );
+        }
+        convertToDiagnosticsWithLinePosition(diagnostics, scriptInfo) {
+          return diagnostics.map(
+            (d) => ({
+              message: flattenDiagnosticMessageText(d.messageText, this.host.newLine),
+              start: d.start,
+              length: d.length,
+              category: diagnosticCategoryName(d),
+              code: d.code,
+              source: d.source,
+              startLocation: scriptInfo && scriptInfo.positionToLineOffset(d.start),
+              // TODO: GH#18217
+              endLocation: scriptInfo && scriptInfo.positionToLineOffset(d.start + d.length),
+              reportsUnnecessary: d.reportsUnnecessary,
+              reportsDeprecated: d.reportsDeprecated,
+              relatedInformation: map(d.relatedInformation, formatRelatedInformation)
+            })
+          );
+        }
+        getDiagnosticsWorker(args, isSemantic, selector, includeLinePosition) {
+          const { project, file } = this.getFileAndProject(args);
+          if (isSemantic && isDeclarationFileInJSOnlyNonConfiguredProject(project, file)) {
+            return emptyArray2;
+          }
+          const scriptInfo = project.getScriptInfoForNormalizedPath(file);
+          const diagnostics = selector(project, file);
+          return includeLinePosition ? this.convertToDiagnosticsWithLinePosition(diagnostics, scriptInfo) : diagnostics.map((d) => formatDiag(file, project, d));
+        }
+        getDefinition(args, simplifiedResult) {
+          const { file, project } = this.getFileAndProject(args);
+          const position = this.getPositionInFile(args, file);
+          const definitions = this.mapDefinitionInfoLocations(project.getLanguageService().getDefinitionAtPosition(file, position) || emptyArray2, project);
+          return simplifiedResult ? this.mapDefinitionInfo(definitions, project) : definitions.map(_Session.mapToOriginalLocation);
+        }
+        mapDefinitionInfoLocations(definitions, project) {
+          return definitions.map((info) => {
+            const newDocumentSpan = getMappedDocumentSpanForProject(info, project);
+            return !newDocumentSpan ? info : {
+              ...newDocumentSpan,
+              containerKind: info.containerKind,
+              containerName: info.containerName,
+              kind: info.kind,
+              name: info.name,
+              failedAliasResolution: info.failedAliasResolution,
+              ...info.unverified && { unverified: info.unverified }
+            };
+          });
+        }
+        getDefinitionAndBoundSpan(args, simplifiedResult) {
+          const { file, project } = this.getFileAndProject(args);
+          const position = this.getPositionInFile(args, file);
+          const scriptInfo = Debug.checkDefined(project.getScriptInfo(file));
+          const unmappedDefinitionAndBoundSpan = project.getLanguageService().getDefinitionAndBoundSpan(file, position);
+          if (!unmappedDefinitionAndBoundSpan || !unmappedDefinitionAndBoundSpan.definitions) {
+            return {
+              definitions: emptyArray2,
+              textSpan: void 0
+              // TODO: GH#18217
+            };
           }
-          return;
+          const definitions = this.mapDefinitionInfoLocations(unmappedDefinitionAndBoundSpan.definitions, project);
+          const { textSpan } = unmappedDefinitionAndBoundSpan;
+          if (simplifiedResult) {
+            return {
+              definitions: this.mapDefinitionInfo(definitions, project),
+              textSpan: toProtocolTextSpan(textSpan, scriptInfo)
+            };
+          }
+          return {
+            definitions: definitions.map(_Session.mapToOriginalLocation),
+            textSpan
+          };
         }
-        if (listStartToken !== 0 /* Unknown */) {
-          while (formattingScanner.isOnToken() && formattingScanner.getTokenFullStart() < originalRange.end) {
-            const tokenInfo = formattingScanner.readTokenInfo(parent2);
-            if (tokenInfo.token.end > nodes.pos) {
-              break;
-            } else if (tokenInfo.token.kind === listStartToken) {
-              startLine = sourceFile.getLineAndCharacterOfPosition(tokenInfo.token.pos).line;
-              consumeTokenAndAdvanceScanner(tokenInfo, parent2, parentDynamicIndentation, parent2);
-              let indentationOnListStartToken;
-              if (indentationOnLastIndentedLine !== -1 /* Unknown */) {
-                indentationOnListStartToken = indentationOnLastIndentedLine;
-              } else {
-                const startLinePosition = getLineStartPositionForPosition(tokenInfo.token.pos, sourceFile);
-                indentationOnListStartToken = SmartIndenter.findFirstNonWhitespaceColumn(startLinePosition, tokenInfo.token.pos, sourceFile, options);
+        findSourceDefinition(args) {
+          var _a;
+          const { file, project } = this.getFileAndProject(args);
+          const position = this.getPositionInFile(args, file);
+          const unmappedDefinitions = project.getLanguageService().getDefinitionAtPosition(file, position);
+          let definitions = this.mapDefinitionInfoLocations(unmappedDefinitions || emptyArray2, project).slice();
+          const needsJsResolution = this.projectService.serverMode === 0 /* Semantic */ && (!some(definitions, (d) => toNormalizedPath(d.fileName) !== file && !d.isAmbient) || some(definitions, (d) => !!d.failedAliasResolution));
+          if (needsJsResolution) {
+            const definitionSet = createSet((d) => d.textSpan.start, documentSpansEqual);
+            definitions == null ? void 0 : definitions.forEach((d) => definitionSet.add(d));
+            const noDtsProject = project.getNoDtsResolutionProject(file);
+            const ls = noDtsProject.getLanguageService();
+            const jsDefinitions = (_a = ls.getDefinitionAtPosition(
+              file,
+              position,
+              /*searchOtherFilesOnly*/
+              true,
+              /*stopAtAlias*/
+              false
+            )) == null ? void 0 : _a.filter((d) => toNormalizedPath(d.fileName) !== file);
+            if (some(jsDefinitions)) {
+              for (const jsDefinition of jsDefinitions) {
+                if (jsDefinition.unverified) {
+                  const refined = tryRefineDefinition(jsDefinition, project.getLanguageService().getProgram(), ls.getProgram());
+                  if (some(refined)) {
+                    for (const def of refined) {
+                      definitionSet.add(def);
+                    }
+                    continue;
+                  }
+                }
+                definitionSet.add(jsDefinition);
               }
-              listDynamicIndentation = getDynamicIndentation(parent2, parentStartLine, indentationOnListStartToken, options.indentSize);
             } else {
-              consumeTokenAndAdvanceScanner(tokenInfo, parent2, parentDynamicIndentation, parent2);
+              const ambientCandidates = definitions.filter((d) => toNormalizedPath(d.fileName) !== file && d.isAmbient);
+              for (const candidate of some(ambientCandidates) ? ambientCandidates : getAmbientCandidatesByClimbingAccessChain()) {
+                const fileNameToSearch = findImplementationFileFromDtsFileName(candidate.fileName, file, noDtsProject);
+                if (!fileNameToSearch)
+                  continue;
+                const info = this.projectService.getOrCreateScriptInfoNotOpenedByClient(
+                  fileNameToSearch,
+                  noDtsProject.currentDirectory,
+                  noDtsProject.directoryStructureHost
+                );
+                if (!info)
+                  continue;
+                if (!noDtsProject.containsScriptInfo(info)) {
+                  noDtsProject.addRoot(info);
+                  noDtsProject.updateGraph();
+                }
+                const noDtsProgram = ls.getProgram();
+                const fileToSearch = Debug.checkDefined(noDtsProgram.getSourceFile(fileNameToSearch));
+                for (const match of searchForDeclaration(candidate.name, fileToSearch, noDtsProgram)) {
+                  definitionSet.add(match);
+                }
+              }
+            }
+            definitions = arrayFrom(definitionSet.values());
+          }
+          definitions = definitions.filter((d) => !d.isAmbient && !d.failedAliasResolution);
+          return this.mapDefinitionInfo(definitions, project);
+          function findImplementationFileFromDtsFileName(fileName, resolveFromFile, auxiliaryProject) {
+            var _a2, _b, _c;
+            const nodeModulesPathParts = getNodeModulePathParts(fileName);
+            if (nodeModulesPathParts && fileName.lastIndexOf(nodeModulesPathPart) === nodeModulesPathParts.topLevelNodeModulesIndex) {
+              const packageDirectory = fileName.substring(0, nodeModulesPathParts.packageRootIndex);
+              const packageJsonCache = (_a2 = project.getModuleResolutionCache()) == null ? void 0 : _a2.getPackageJsonInfoCache();
+              const compilerOptions = project.getCompilationSettings();
+              const packageJson = getPackageScopeForPath(getNormalizedAbsolutePath(packageDirectory + "/package.json", project.getCurrentDirectory()), getTemporaryModuleResolutionState(packageJsonCache, project, compilerOptions));
+              if (!packageJson)
+                return void 0;
+              const entrypoints = getEntrypointsFromPackageJsonInfo(
+                packageJson,
+                { moduleResolution: 2 /* Node10 */ },
+                project,
+                project.getModuleResolutionCache()
+              );
+              const packageNamePathPart = fileName.substring(
+                nodeModulesPathParts.topLevelPackageNameIndex + 1,
+                nodeModulesPathParts.packageRootIndex
+              );
+              const packageName = getPackageNameFromTypesPackageName(unmangleScopedPackageName(packageNamePathPart));
+              const path = project.toPath(fileName);
+              if (entrypoints && some(entrypoints, (e) => project.toPath(e) === path)) {
+                return (_b = auxiliaryProject.resolutionCache.resolveSingleModuleNameWithoutWatching(packageName, resolveFromFile).resolvedModule) == null ? void 0 : _b.resolvedFileName;
+              } else {
+                const pathToFileInPackage = fileName.substring(nodeModulesPathParts.packageRootIndex + 1);
+                const specifier = `${packageName}/${removeFileExtension(pathToFileInPackage)}`;
+                return (_c = auxiliaryProject.resolutionCache.resolveSingleModuleNameWithoutWatching(specifier, resolveFromFile).resolvedModule) == null ? void 0 : _c.resolvedFileName;
+              }
             }
+            return void 0;
+          }
+          function getAmbientCandidatesByClimbingAccessChain() {
+            const ls = project.getLanguageService();
+            const program = ls.getProgram();
+            const initialNode = getTouchingPropertyName(program.getSourceFile(file), position);
+            if ((isStringLiteralLike(initialNode) || isIdentifier(initialNode)) && isAccessExpression(initialNode.parent)) {
+              return forEachNameInAccessChainWalkingLeft(initialNode, (nameInChain) => {
+                var _a2;
+                if (nameInChain === initialNode)
+                  return void 0;
+                const candidates = (_a2 = ls.getDefinitionAtPosition(
+                  file,
+                  nameInChain.getStart(),
+                  /*searchOtherFilesOnly*/
+                  true,
+                  /*stopAtAlias*/
+                  false
+                )) == null ? void 0 : _a2.filter((d) => toNormalizedPath(d.fileName) !== file && d.isAmbient).map((d) => ({
+                  fileName: d.fileName,
+                  name: getTextOfIdentifierOrLiteral(initialNode)
+                }));
+                if (some(candidates)) {
+                  return candidates;
+                }
+              }) || emptyArray2;
+            }
+            return emptyArray2;
+          }
+          function tryRefineDefinition(definition, program, noDtsProgram) {
+            var _a2;
+            const fileToSearch = noDtsProgram.getSourceFile(definition.fileName);
+            if (!fileToSearch) {
+              return void 0;
+            }
+            const initialNode = getTouchingPropertyName(program.getSourceFile(file), position);
+            const symbol = program.getTypeChecker().getSymbolAtLocation(initialNode);
+            const importSpecifier = symbol && getDeclarationOfKind(symbol, 276 /* ImportSpecifier */);
+            if (!importSpecifier)
+              return void 0;
+            const nameToSearch = ((_a2 = importSpecifier.propertyName) == null ? void 0 : _a2.text) || importSpecifier.name.text;
+            return searchForDeclaration(nameToSearch, fileToSearch, noDtsProgram);
+          }
+          function searchForDeclaration(declarationName, fileToSearch, noDtsProgram) {
+            const matches = ts_FindAllReferences_exports.Core.getTopMostDeclarationNamesInFile(declarationName, fileToSearch);
+            return mapDefined(matches, (match) => {
+              const symbol = noDtsProgram.getTypeChecker().getSymbolAtLocation(match);
+              const decl = getDeclarationFromName(match);
+              if (symbol && decl) {
+                return ts_GoToDefinition_exports.createDefinitionInfo(
+                  decl,
+                  noDtsProgram.getTypeChecker(),
+                  symbol,
+                  decl,
+                  /*unverified*/
+                  true
+                );
+              }
+            });
           }
         }
-        let inheritedIndentation = -1 /* Unknown */;
-        for (let i = 0; i < nodes.length; i++) {
-          const child = nodes[i];
-          inheritedIndentation = processChildNode(
-            child,
-            inheritedIndentation,
-            node,
-            listDynamicIndentation,
-            startLine,
-            startLine,
-            /*isListItem*/
-            true,
-            /*isFirstListItem*/
-            i === 0
-          );
-        }
-        const listEndToken = getCloseTokenForOpenToken(listStartToken);
-        if (listEndToken !== 0 /* Unknown */ && formattingScanner.isOnToken() && formattingScanner.getTokenFullStart() < originalRange.end) {
-          let tokenInfo = formattingScanner.readTokenInfo(parent2);
-          if (tokenInfo.token.kind === 28 /* CommaToken */) {
-            consumeTokenAndAdvanceScanner(tokenInfo, parent2, listDynamicIndentation, parent2);
-            tokenInfo = formattingScanner.isOnToken() ? formattingScanner.readTokenInfo(parent2) : void 0;
+        getEmitOutput(args) {
+          const { file, project } = this.getFileAndProject(args);
+          if (!project.shouldEmitFile(project.getScriptInfo(file))) {
+            return { emitSkipped: true, outputFiles: [], diagnostics: [] };
           }
-          if (tokenInfo && tokenInfo.token.kind === listEndToken && rangeContainsRange(parent2, tokenInfo.token)) {
-            consumeTokenAndAdvanceScanner(
-              tokenInfo,
-              parent2,
-              listDynamicIndentation,
-              parent2,
-              /*isListEndToken*/
+          const result = project.getLanguageService().getEmitOutput(file);
+          return args.richResponse ? {
+            ...result,
+            diagnostics: args.includeLinePosition ? this.convertToDiagnosticsWithLinePositionFromDiagnosticFile(result.diagnostics) : result.diagnostics.map((d) => formatDiagnosticToProtocol(
+              d,
+              /*includeFileName*/
               true
-            );
-          }
+            ))
+          } : result;
         }
-      }
-      function consumeTokenAndAdvanceScanner(currentTokenInfo, parent2, dynamicIndentation, container, isListEndToken) {
-        Debug.assert(rangeContainsRange(parent2, currentTokenInfo.token));
-        const lastTriviaWasNewLine = formattingScanner.lastTrailingTriviaWasNewLine();
-        let indentToken = false;
-        if (currentTokenInfo.leadingTrivia) {
-          processTrivia(currentTokenInfo.leadingTrivia, parent2, childContextNode, dynamicIndentation);
+        mapJSDocTagInfo(tags, project, richResponse) {
+          return tags ? tags.map((tag) => {
+            var _a;
+            return {
+              ...tag,
+              text: richResponse ? this.mapDisplayParts(tag.text, project) : (_a = tag.text) == null ? void 0 : _a.map((part) => part.text).join("")
+            };
+          }) : [];
         }
-        let lineAction = 0 /* None */;
-        const isTokenInRange = rangeContainsRange(originalRange, currentTokenInfo.token);
-        const tokenStart = sourceFile.getLineAndCharacterOfPosition(currentTokenInfo.token.pos);
-        if (isTokenInRange) {
-          const rangeHasError = rangeContainsError(currentTokenInfo.token);
-          const savePreviousRange = previousRange;
-          lineAction = processRange(currentTokenInfo.token, tokenStart, parent2, childContextNode, dynamicIndentation);
-          if (!rangeHasError) {
-            if (lineAction === 0 /* None */) {
-              const prevEndLine = savePreviousRange && sourceFile.getLineAndCharacterOfPosition(savePreviousRange.end).line;
-              indentToken = lastTriviaWasNewLine && tokenStart.line !== prevEndLine;
-            } else {
-              indentToken = lineAction === 1 /* LineAdded */;
+        mapDisplayParts(parts, project) {
+          if (!parts) {
+            return [];
+          }
+          return parts.map(
+            (part) => part.kind !== "linkName" ? part : {
+              ...part,
+              target: this.toFileSpan(part.target.fileName, part.target.textSpan, project)
             }
+          );
+        }
+        mapSignatureHelpItems(items, project, richResponse) {
+          return items.map((item) => ({
+            ...item,
+            documentation: this.mapDisplayParts(item.documentation, project),
+            parameters: item.parameters.map((p) => ({ ...p, documentation: this.mapDisplayParts(p.documentation, project) })),
+            tags: this.mapJSDocTagInfo(item.tags, project, richResponse)
+          }));
+        }
+        mapDefinitionInfo(definitions, project) {
+          return definitions.map((def) => ({ ...this.toFileSpanWithContext(def.fileName, def.textSpan, def.contextSpan, project), ...def.unverified && { unverified: def.unverified } }));
+        }
+        /*
+         * When we map a .d.ts location to .ts, Visual Studio gets confused because there's no associated Roslyn Document in
+         * the same project which corresponds to the file. VS Code has no problem with this, and luckily we have two protocols.
+         * This retains the existing behavior for the "simplified" (VS Code) protocol but stores the .d.ts location in a
+         * set of additional fields, and does the reverse for VS (store the .d.ts location where
+         * it used to be and stores the .ts location in the additional fields).
+         */
+        static mapToOriginalLocation(def) {
+          if (def.originalFileName) {
+            Debug.assert(def.originalTextSpan !== void 0, "originalTextSpan should be present if originalFileName is");
+            return {
+              ...def,
+              fileName: def.originalFileName,
+              textSpan: def.originalTextSpan,
+              targetFileName: def.fileName,
+              targetTextSpan: def.textSpan,
+              contextSpan: def.originalContextSpan,
+              targetContextSpan: def.contextSpan
+            };
           }
+          return def;
         }
-        if (currentTokenInfo.trailingTrivia) {
-          previousRangeTriviaEnd = last(currentTokenInfo.trailingTrivia).end;
-          processTrivia(currentTokenInfo.trailingTrivia, parent2, childContextNode, dynamicIndentation);
+        toFileSpan(fileName, textSpan, project) {
+          const ls = project.getLanguageService();
+          const start = ls.toLineColumnOffset(fileName, textSpan.start);
+          const end = ls.toLineColumnOffset(fileName, textSpanEnd(textSpan));
+          return {
+            file: fileName,
+            start: { line: start.line + 1, offset: start.character + 1 },
+            end: { line: end.line + 1, offset: end.character + 1 }
+          };
         }
-        if (indentToken) {
-          const tokenIndentation = isTokenInRange && !rangeContainsError(currentTokenInfo.token) ? dynamicIndentation.getIndentationForToken(tokenStart.line, currentTokenInfo.token.kind, container, !!isListEndToken) : -1 /* Unknown */;
-          let indentNextTokenOrTrivia = true;
-          if (currentTokenInfo.leadingTrivia) {
-            const commentIndentation = dynamicIndentation.getIndentationForComment(currentTokenInfo.token.kind, tokenIndentation, container);
-            indentNextTokenOrTrivia = indentTriviaItems(
-              currentTokenInfo.leadingTrivia,
-              commentIndentation,
-              indentNextTokenOrTrivia,
-              (item) => insertIndentation(
-                item.pos,
-                commentIndentation,
-                /*lineAdded*/
-                false
-              )
-            );
+        toFileSpanWithContext(fileName, textSpan, contextSpan, project) {
+          const fileSpan = this.toFileSpan(fileName, textSpan, project);
+          const context = contextSpan && this.toFileSpan(fileName, contextSpan, project);
+          return context ? { ...fileSpan, contextStart: context.start, contextEnd: context.end } : fileSpan;
+        }
+        getTypeDefinition(args) {
+          const { file, project } = this.getFileAndProject(args);
+          const position = this.getPositionInFile(args, file);
+          const definitions = this.mapDefinitionInfoLocations(project.getLanguageService().getTypeDefinitionAtPosition(file, position) || emptyArray2, project);
+          return this.mapDefinitionInfo(definitions, project);
+        }
+        mapImplementationLocations(implementations, project) {
+          return implementations.map((info) => {
+            const newDocumentSpan = getMappedDocumentSpanForProject(info, project);
+            return !newDocumentSpan ? info : {
+              ...newDocumentSpan,
+              kind: info.kind,
+              displayParts: info.displayParts
+            };
+          });
+        }
+        getImplementation(args, simplifiedResult) {
+          const { file, project } = this.getFileAndProject(args);
+          const position = this.getPositionInFile(args, file);
+          const implementations = this.mapImplementationLocations(project.getLanguageService().getImplementationAtPosition(file, position) || emptyArray2, project);
+          return simplifiedResult ? implementations.map(({ fileName, textSpan, contextSpan }) => this.toFileSpanWithContext(fileName, textSpan, contextSpan, project)) : implementations.map(_Session.mapToOriginalLocation);
+        }
+        getSyntacticDiagnosticsSync(args) {
+          const { configFile } = this.getConfigFileAndProject(args);
+          if (configFile) {
+            return emptyArray2;
           }
-          if (tokenIndentation !== -1 /* Unknown */ && indentNextTokenOrTrivia) {
-            insertIndentation(currentTokenInfo.token.pos, tokenIndentation, lineAction === 1 /* LineAdded */);
-            lastIndentedLine = tokenStart.line;
-            indentationOnLastIndentedLine = tokenIndentation;
+          return this.getDiagnosticsWorker(
+            args,
+            /*isSemantic*/
+            false,
+            (project, file) => project.getLanguageService().getSyntacticDiagnostics(file),
+            !!args.includeLinePosition
+          );
+        }
+        getSemanticDiagnosticsSync(args) {
+          const { configFile, project } = this.getConfigFileAndProject(args);
+          if (configFile) {
+            return this.getConfigFileDiagnostics(configFile, project, !!args.includeLinePosition);
           }
+          return this.getDiagnosticsWorker(
+            args,
+            /*isSemantic*/
+            true,
+            (project2, file) => project2.getLanguageService().getSemanticDiagnostics(file).filter((d) => !!d.file),
+            !!args.includeLinePosition
+          );
         }
-        formattingScanner.advance();
-        childContextNode = parent2;
-      }
-    }
-    function indentTriviaItems(trivia, commentIndentation, indentNextTokenOrTrivia, indentSingleLine) {
-      for (const triviaItem of trivia) {
-        const triviaInRange = rangeContainsRange(originalRange, triviaItem);
-        switch (triviaItem.kind) {
-          case 3 /* MultiLineCommentTrivia */:
-            if (triviaInRange) {
-              indentMultilineComment(
-                triviaItem,
-                commentIndentation,
-                /*firstLineIsIndented*/
-                !indentNextTokenOrTrivia
-              );
+        getSuggestionDiagnosticsSync(args) {
+          const { configFile } = this.getConfigFileAndProject(args);
+          if (configFile) {
+            return emptyArray2;
+          }
+          return this.getDiagnosticsWorker(
+            args,
+            /*isSemantic*/
+            true,
+            (project, file) => project.getLanguageService().getSuggestionDiagnostics(file),
+            !!args.includeLinePosition
+          );
+        }
+        getJsxClosingTag(args) {
+          const { file, languageService } = this.getFileAndLanguageServiceForSyntacticOperation(args);
+          const position = this.getPositionInFile(args, file);
+          const tag = languageService.getJsxClosingTagAtPosition(file, position);
+          return tag === void 0 ? void 0 : { newText: tag.newText, caretOffset: 0 };
+        }
+        getLinkedEditingRange(args) {
+          const { file, languageService } = this.getFileAndLanguageServiceForSyntacticOperation(args);
+          const position = this.getPositionInFile(args, file);
+          const linkedEditInfo = languageService.getLinkedEditingRangeAtPosition(file, position);
+          const scriptInfo = this.projectService.getScriptInfoForNormalizedPath(file);
+          if (scriptInfo === void 0 || linkedEditInfo === void 0)
+            return void 0;
+          return convertLinkedEditInfoToRanges(linkedEditInfo, scriptInfo);
+        }
+        getDocumentHighlights(args, simplifiedResult) {
+          const { file, project } = this.getFileAndProject(args);
+          const position = this.getPositionInFile(args, file);
+          const documentHighlights = project.getLanguageService().getDocumentHighlights(file, position, args.filesToSearch);
+          if (!documentHighlights)
+            return emptyArray2;
+          if (!simplifiedResult)
+            return documentHighlights;
+          return documentHighlights.map(({ fileName, highlightSpans }) => {
+            const scriptInfo = project.getScriptInfo(fileName);
+            return {
+              file: fileName,
+              highlightSpans: highlightSpans.map(({ textSpan, kind, contextSpan }) => ({
+                ...toProtocolTextSpanWithContext(textSpan, contextSpan, scriptInfo),
+                kind
+              }))
+            };
+          });
+        }
+        provideInlayHints(args) {
+          const { file, project } = this.getFileAndProject(args);
+          const scriptInfo = this.projectService.getScriptInfoForNormalizedPath(file);
+          const hints = project.getLanguageService().provideInlayHints(file, args, this.getPreferences(file));
+          return hints.map((hint) => {
+            const { position, displayParts } = hint;
+            return {
+              ...hint,
+              position: scriptInfo.positionToLineOffset(position),
+              displayParts: displayParts == null ? void 0 : displayParts.map(({ text, span, file: file2 }) => {
+                if (span) {
+                  Debug.assertIsDefined(file2, "Target file should be defined together with its span.");
+                  const scriptInfo2 = this.projectService.getScriptInfo(file2);
+                  return {
+                    text,
+                    span: {
+                      start: scriptInfo2.positionToLineOffset(span.start),
+                      end: scriptInfo2.positionToLineOffset(span.start + span.length),
+                      file: file2
+                    }
+                  };
+                } else {
+                  return { text };
+                }
+              })
+            };
+          });
+        }
+        setCompilerOptionsForInferredProjects(args) {
+          this.projectService.setCompilerOptionsForInferredProjects(args.options, args.projectRootPath);
+        }
+        getProjectInfo(args) {
+          return this.getProjectInfoWorker(
+            args.file,
+            args.projectFileName,
+            args.needFileNameList,
+            /*excludeConfigFiles*/
+            false
+          );
+        }
+        getProjectInfoWorker(uncheckedFileName, projectFileName, needFileNameList, excludeConfigFiles) {
+          const { project } = this.getFileAndProjectWorker(uncheckedFileName, projectFileName);
+          updateProjectIfDirty(project);
+          const projectInfo = {
+            configFileName: project.getProjectName(),
+            languageServiceDisabled: !project.languageServiceEnabled,
+            fileNames: needFileNameList ? project.getFileNames(
+              /*excludeFilesFromExternalLibraries*/
+              false,
+              excludeConfigFiles
+            ) : void 0
+          };
+          return projectInfo;
+        }
+        getRenameInfo(args) {
+          const { file, project } = this.getFileAndProject(args);
+          const position = this.getPositionInFile(args, file);
+          const preferences = this.getPreferences(file);
+          return project.getLanguageService().getRenameInfo(file, position, preferences);
+        }
+        getProjects(args, getScriptInfoEnsuringProjectsUptoDate, ignoreNoProjectError) {
+          let projects;
+          let symLinkedProjects;
+          if (args.projectFileName) {
+            const project = this.getProject(args.projectFileName);
+            if (project) {
+              projects = [project];
             }
-            indentNextTokenOrTrivia = false;
-            break;
-          case 2 /* SingleLineCommentTrivia */:
-            if (indentNextTokenOrTrivia && triviaInRange) {
-              indentSingleLine(triviaItem);
+          } else {
+            const scriptInfo = getScriptInfoEnsuringProjectsUptoDate ? this.projectService.getScriptInfoEnsuringProjectsUptoDate(args.file) : this.projectService.getScriptInfo(args.file);
+            if (!scriptInfo) {
+              if (ignoreNoProjectError)
+                return emptyArray2;
+              this.projectService.logErrorForScriptInfoNotFound(args.file);
+              return Errors.ThrowNoProject();
+            } else if (!getScriptInfoEnsuringProjectsUptoDate) {
+              this.projectService.ensureDefaultProjectForFile(scriptInfo);
+            }
+            projects = scriptInfo.containingProjects;
+            symLinkedProjects = this.projectService.getSymlinkedProjects(scriptInfo);
+          }
+          projects = filter(projects, (p) => p.languageServiceEnabled && !p.isOrphan());
+          if (!ignoreNoProjectError && (!projects || !projects.length) && !symLinkedProjects) {
+            this.projectService.logErrorForScriptInfoNotFound(args.file ?? args.projectFileName);
+            return Errors.ThrowNoProject();
+          }
+          return symLinkedProjects ? { projects, symLinkedProjects } : projects;
+        }
+        getDefaultProject(args) {
+          if (args.projectFileName) {
+            const project = this.getProject(args.projectFileName);
+            if (project) {
+              return project;
+            }
+            if (!args.file) {
+              return Errors.ThrowNoProject();
+            }
+          }
+          const info = this.projectService.getScriptInfo(args.file);
+          return info.getDefaultProject();
+        }
+        getRenameLocations(args, simplifiedResult) {
+          const file = toNormalizedPath(args.file);
+          const position = this.getPositionInFile(args, file);
+          const projects = this.getProjects(args);
+          const defaultProject = this.getDefaultProject(args);
+          const preferences = this.getPreferences(file);
+          const renameInfo = this.mapRenameInfo(
+            defaultProject.getLanguageService().getRenameInfo(file, position, preferences),
+            Debug.checkDefined(this.projectService.getScriptInfo(file))
+          );
+          if (!renameInfo.canRename)
+            return simplifiedResult ? { info: renameInfo, locs: [] } : [];
+          const locations = getRenameLocationsWorker(
+            projects,
+            defaultProject,
+            { fileName: args.file, pos: position },
+            !!args.findInStrings,
+            !!args.findInComments,
+            preferences
+          );
+          if (!simplifiedResult)
+            return locations;
+          return { info: renameInfo, locs: this.toSpanGroups(locations) };
+        }
+        mapRenameInfo(info, scriptInfo) {
+          if (info.canRename) {
+            const { canRename, fileToRename, displayName, fullDisplayName, kind, kindModifiers, triggerSpan } = info;
+            return identity(
+              { canRename, fileToRename, displayName, fullDisplayName, kind, kindModifiers, triggerSpan: toProtocolTextSpan(triggerSpan, scriptInfo) }
+            );
+          } else {
+            return info;
+          }
+        }
+        toSpanGroups(locations) {
+          const map2 = /* @__PURE__ */ new Map();
+          for (const { fileName, textSpan, contextSpan, originalContextSpan: _2, originalTextSpan: _, originalFileName: _1, ...prefixSuffixText } of locations) {
+            let group2 = map2.get(fileName);
+            if (!group2)
+              map2.set(fileName, group2 = { file: fileName, locs: [] });
+            const scriptInfo = Debug.checkDefined(this.projectService.getScriptInfo(fileName));
+            group2.locs.push({ ...toProtocolTextSpanWithContext(textSpan, contextSpan, scriptInfo), ...prefixSuffixText });
+          }
+          return arrayFrom(map2.values());
+        }
+        getReferences(args, simplifiedResult) {
+          const file = toNormalizedPath(args.file);
+          const projects = this.getProjects(args);
+          const position = this.getPositionInFile(args, file);
+          const references = getReferencesWorker(
+            projects,
+            this.getDefaultProject(args),
+            { fileName: args.file, pos: position },
+            this.logger
+          );
+          if (!simplifiedResult)
+            return references;
+          const preferences = this.getPreferences(file);
+          const defaultProject = this.getDefaultProject(args);
+          const scriptInfo = defaultProject.getScriptInfoForNormalizedPath(file);
+          const nameInfo = defaultProject.getLanguageService().getQuickInfoAtPosition(file, position);
+          const symbolDisplayString = nameInfo ? displayPartsToString(nameInfo.displayParts) : "";
+          const nameSpan = nameInfo && nameInfo.textSpan;
+          const symbolStartOffset = nameSpan ? scriptInfo.positionToLineOffset(nameSpan.start).offset : 0;
+          const symbolName2 = nameSpan ? scriptInfo.getSnapshot().getText(nameSpan.start, textSpanEnd(nameSpan)) : "";
+          const refs = flatMap(references, (referencedSymbol) => {
+            return referencedSymbol.references.map((entry) => referenceEntryToReferencesResponseItem(this.projectService, entry, preferences));
+          });
+          return { refs, symbolName: symbolName2, symbolStartOffset, symbolDisplayString };
+        }
+        getFileReferences(args, simplifiedResult) {
+          const projects = this.getProjects(args);
+          const fileName = args.file;
+          const preferences = this.getPreferences(toNormalizedPath(fileName));
+          const references = [];
+          const seen = createDocumentSpanSet();
+          forEachProjectInProjects(
+            projects,
+            /*path*/
+            void 0,
+            (project) => {
+              if (project.getCancellationToken().isCancellationRequested())
+                return;
+              const projectOutputs = project.getLanguageService().getFileReferences(fileName);
+              if (projectOutputs) {
+                for (const referenceEntry of projectOutputs) {
+                  if (!seen.has(referenceEntry)) {
+                    references.push(referenceEntry);
+                    seen.add(referenceEntry);
+                  }
+                }
+              }
             }
-            indentNextTokenOrTrivia = false;
-            break;
-          case 4 /* NewLineTrivia */:
-            indentNextTokenOrTrivia = true;
-            break;
+          );
+          if (!simplifiedResult)
+            return references;
+          const refs = references.map((entry) => referenceEntryToReferencesResponseItem(this.projectService, entry, preferences));
+          return {
+            refs,
+            symbolName: `"${args.file}"`
+          };
         }
-      }
-      return indentNextTokenOrTrivia;
-    }
-    function processTrivia(trivia, parent2, contextNode, dynamicIndentation) {
-      for (const triviaItem of trivia) {
-        if (isComment(triviaItem.kind) && rangeContainsRange(originalRange, triviaItem)) {
-          const triviaItemStart = sourceFile.getLineAndCharacterOfPosition(triviaItem.pos);
-          processRange(triviaItem, triviaItemStart, parent2, contextNode, dynamicIndentation);
+        /**
+         * @param fileName is the name of the file to be opened
+         * @param fileContent is a version of the file content that is known to be more up to date than the one on disk
+         */
+        openClientFile(fileName, fileContent, scriptKind, projectRootPath) {
+          this.projectService.openClientFileWithNormalizedPath(
+            fileName,
+            fileContent,
+            scriptKind,
+            /*hasMixedContent*/
+            false,
+            projectRootPath
+          );
         }
-      }
-    }
-    function processRange(range, rangeStart, parent2, contextNode, dynamicIndentation) {
-      const rangeHasError = rangeContainsError(range);
-      let lineAction = 0 /* None */;
-      if (!rangeHasError) {
-        if (!previousRange) {
-          const originalStart = sourceFile.getLineAndCharacterOfPosition(originalRange.pos);
-          trimTrailingWhitespacesForLines(originalStart.line, rangeStart.line);
-        } else {
-          lineAction = processPair(range, rangeStart.line, parent2, previousRange, previousRangeStartLine, previousParent, contextNode, dynamicIndentation);
+        getPosition(args, scriptInfo) {
+          return args.position !== void 0 ? args.position : scriptInfo.lineOffsetToPosition(args.line, args.offset);
         }
-      }
-      previousRange = range;
-      previousRangeTriviaEnd = range.end;
-      previousParent = parent2;
-      previousRangeStartLine = rangeStart.line;
-      return lineAction;
-    }
-    function processPair(currentItem, currentStartLine, currentParent, previousItem, previousStartLine, previousParent2, contextNode, dynamicIndentation) {
-      formattingContext.updateContext(previousItem, previousParent2, currentItem, currentParent, contextNode);
-      const rules = getRules(formattingContext);
-      let trimTrailingWhitespaces = formattingContext.options.trimTrailingWhitespace !== false;
-      let lineAction = 0 /* None */;
-      if (rules) {
-        forEachRight(rules, (rule2) => {
-          lineAction = applyRuleEdits(rule2, previousItem, previousStartLine, currentItem, currentStartLine);
-          if (dynamicIndentation) {
-            switch (lineAction) {
-              case 2 /* LineRemoved */:
-                if (currentParent.getStart(sourceFile) === currentItem.pos) {
-                  dynamicIndentation.recomputeIndentation(
-                    /*lineAddedByFormatting*/
-                    false,
-                    contextNode
-                  );
-                }
-                break;
-              case 1 /* LineAdded */:
-                if (currentParent.getStart(sourceFile) === currentItem.pos) {
-                  dynamicIndentation.recomputeIndentation(
-                    /*lineAddedByFormatting*/
-                    true,
-                    contextNode
-                  );
+        getPositionInFile(args, file) {
+          const scriptInfo = this.projectService.getScriptInfoForNormalizedPath(file);
+          return this.getPosition(args, scriptInfo);
+        }
+        getFileAndProject(args) {
+          return this.getFileAndProjectWorker(args.file, args.projectFileName);
+        }
+        getFileAndLanguageServiceForSyntacticOperation(args) {
+          const { file, project } = this.getFileAndProject(args);
+          return {
+            file,
+            languageService: project.getLanguageService(
+              /*ensureSynchronized*/
+              false
+            )
+          };
+        }
+        getFileAndProjectWorker(uncheckedFileName, projectFileName) {
+          const file = toNormalizedPath(uncheckedFileName);
+          const project = this.getProject(projectFileName) || this.projectService.ensureDefaultProjectForFile(file);
+          return { file, project };
+        }
+        getOutliningSpans(args, simplifiedResult) {
+          const { file, languageService } = this.getFileAndLanguageServiceForSyntacticOperation(args);
+          const spans = languageService.getOutliningSpans(file);
+          if (simplifiedResult) {
+            const scriptInfo = this.projectService.getScriptInfoForNormalizedPath(file);
+            return spans.map((s) => ({
+              textSpan: toProtocolTextSpan(s.textSpan, scriptInfo),
+              hintSpan: toProtocolTextSpan(s.hintSpan, scriptInfo),
+              bannerText: s.bannerText,
+              autoCollapse: s.autoCollapse,
+              kind: s.kind
+            }));
+          } else {
+            return spans;
+          }
+        }
+        getTodoComments(args) {
+          const { file, project } = this.getFileAndProject(args);
+          return project.getLanguageService().getTodoComments(file, args.descriptors);
+        }
+        getDocCommentTemplate(args) {
+          const { file, languageService } = this.getFileAndLanguageServiceForSyntacticOperation(args);
+          const position = this.getPositionInFile(args, file);
+          return languageService.getDocCommentTemplateAtPosition(file, position, this.getPreferences(file), this.getFormatOptions(file));
+        }
+        getSpanOfEnclosingComment(args) {
+          const { file, languageService } = this.getFileAndLanguageServiceForSyntacticOperation(args);
+          const onlyMultiLine = args.onlyMultiLine;
+          const position = this.getPositionInFile(args, file);
+          return languageService.getSpanOfEnclosingComment(file, position, onlyMultiLine);
+        }
+        getIndentation(args) {
+          const { file, languageService } = this.getFileAndLanguageServiceForSyntacticOperation(args);
+          const position = this.getPositionInFile(args, file);
+          const options = args.options ? convertFormatOptions(args.options) : this.getFormatOptions(file);
+          const indentation = languageService.getIndentationAtPosition(file, position, options);
+          return { position, indentation };
+        }
+        getBreakpointStatement(args) {
+          const { file, languageService } = this.getFileAndLanguageServiceForSyntacticOperation(args);
+          const position = this.getPositionInFile(args, file);
+          return languageService.getBreakpointStatementAtPosition(file, position);
+        }
+        getNameOrDottedNameSpan(args) {
+          const { file, languageService } = this.getFileAndLanguageServiceForSyntacticOperation(args);
+          const position = this.getPositionInFile(args, file);
+          return languageService.getNameOrDottedNameSpan(file, position, position);
+        }
+        isValidBraceCompletion(args) {
+          const { file, languageService } = this.getFileAndLanguageServiceForSyntacticOperation(args);
+          const position = this.getPositionInFile(args, file);
+          return languageService.isValidBraceCompletionAtPosition(file, position, args.openingBrace.charCodeAt(0));
+        }
+        getQuickInfoWorker(args, simplifiedResult) {
+          const { file, project } = this.getFileAndProject(args);
+          const scriptInfo = this.projectService.getScriptInfoForNormalizedPath(file);
+          const quickInfo = project.getLanguageService().getQuickInfoAtPosition(file, this.getPosition(args, scriptInfo));
+          if (!quickInfo) {
+            return void 0;
+          }
+          const useDisplayParts = !!this.getPreferences(file).displayPartsForJSDoc;
+          if (simplifiedResult) {
+            const displayString = displayPartsToString(quickInfo.displayParts);
+            return {
+              kind: quickInfo.kind,
+              kindModifiers: quickInfo.kindModifiers,
+              start: scriptInfo.positionToLineOffset(quickInfo.textSpan.start),
+              end: scriptInfo.positionToLineOffset(textSpanEnd(quickInfo.textSpan)),
+              displayString,
+              documentation: useDisplayParts ? this.mapDisplayParts(quickInfo.documentation, project) : displayPartsToString(quickInfo.documentation),
+              tags: this.mapJSDocTagInfo(quickInfo.tags, project, useDisplayParts)
+            };
+          } else {
+            return useDisplayParts ? quickInfo : {
+              ...quickInfo,
+              tags: this.mapJSDocTagInfo(
+                quickInfo.tags,
+                project,
+                /*richResponse*/
+                false
+              )
+            };
+          }
+        }
+        getFormattingEditsForRange(args) {
+          const { file, languageService } = this.getFileAndLanguageServiceForSyntacticOperation(args);
+          const scriptInfo = this.projectService.getScriptInfoForNormalizedPath(file);
+          const startPosition = scriptInfo.lineOffsetToPosition(args.line, args.offset);
+          const endPosition = scriptInfo.lineOffsetToPosition(args.endLine, args.endOffset);
+          const edits = languageService.getFormattingEditsForRange(file, startPosition, endPosition, this.getFormatOptions(file));
+          if (!edits) {
+            return void 0;
+          }
+          return edits.map((edit) => this.convertTextChangeToCodeEdit(edit, scriptInfo));
+        }
+        getFormattingEditsForRangeFull(args) {
+          const { file, languageService } = this.getFileAndLanguageServiceForSyntacticOperation(args);
+          const options = args.options ? convertFormatOptions(args.options) : this.getFormatOptions(file);
+          return languageService.getFormattingEditsForRange(file, args.position, args.endPosition, options);
+        }
+        getFormattingEditsForDocumentFull(args) {
+          const { file, languageService } = this.getFileAndLanguageServiceForSyntacticOperation(args);
+          const options = args.options ? convertFormatOptions(args.options) : this.getFormatOptions(file);
+          return languageService.getFormattingEditsForDocument(file, options);
+        }
+        getFormattingEditsAfterKeystrokeFull(args) {
+          const { file, languageService } = this.getFileAndLanguageServiceForSyntacticOperation(args);
+          const options = args.options ? convertFormatOptions(args.options) : this.getFormatOptions(file);
+          return languageService.getFormattingEditsAfterKeystroke(file, args.position, args.key, options);
+        }
+        getFormattingEditsAfterKeystroke(args) {
+          const { file, languageService } = this.getFileAndLanguageServiceForSyntacticOperation(args);
+          const scriptInfo = this.projectService.getScriptInfoForNormalizedPath(file);
+          const position = scriptInfo.lineOffsetToPosition(args.line, args.offset);
+          const formatOptions = this.getFormatOptions(file);
+          const edits = languageService.getFormattingEditsAfterKeystroke(file, position, args.key, formatOptions);
+          if (args.key === "\n" && (!edits || edits.length === 0 || allEditsBeforePos(edits, position))) {
+            const { lineText, absolutePosition } = scriptInfo.textStorage.getAbsolutePositionAndLineText(args.line);
+            if (lineText && lineText.search("\\S") < 0) {
+              const preferredIndent = languageService.getIndentationAtPosition(file, position, formatOptions);
+              let hasIndent = 0;
+              let i, len;
+              for (i = 0, len = lineText.length; i < len; i++) {
+                if (lineText.charAt(i) === " ") {
+                  hasIndent++;
+                } else if (lineText.charAt(i) === "	") {
+                  hasIndent += formatOptions.tabSize;
+                } else {
+                  break;
                 }
-                break;
-              default:
-                Debug.assert(lineAction === 0 /* None */);
+              }
+              if (preferredIndent !== hasIndent) {
+                const firstNoWhiteSpacePosition = absolutePosition + i;
+                edits.push({
+                  span: createTextSpanFromBounds(absolutePosition, firstNoWhiteSpacePosition),
+                  newText: ts_formatting_exports.getIndentationString(preferredIndent, formatOptions)
+                });
+              }
             }
           }
-          trimTrailingWhitespaces = trimTrailingWhitespaces && !(rule2.action & 16 /* DeleteSpace */) && rule2.flags !== 1 /* CanDeleteNewLines */;
-        });
-      } else {
-        trimTrailingWhitespaces = trimTrailingWhitespaces && currentItem.kind !== 1 /* EndOfFileToken */;
-      }
-      if (currentStartLine !== previousStartLine && trimTrailingWhitespaces) {
-        trimTrailingWhitespacesForLines(previousStartLine, currentStartLine, previousItem);
-      }
-      return lineAction;
-    }
-    function insertIndentation(pos, indentation, lineAdded) {
-      const indentationString = getIndentationString(indentation, options);
-      if (lineAdded) {
-        recordReplace(pos, 0, indentationString);
-      } else {
-        const tokenStart = sourceFile.getLineAndCharacterOfPosition(pos);
-        const startLinePosition = getStartPositionOfLine(tokenStart.line, sourceFile);
-        if (indentation !== characterToColumn(startLinePosition, tokenStart.character) || indentationIsDifferent(indentationString, startLinePosition)) {
-          recordReplace(startLinePosition, tokenStart.character, indentationString);
+          if (!edits) {
+            return void 0;
+          }
+          return edits.map((edit) => {
+            return {
+              start: scriptInfo.positionToLineOffset(edit.span.start),
+              end: scriptInfo.positionToLineOffset(textSpanEnd(edit.span)),
+              newText: edit.newText ? edit.newText : ""
+            };
+          });
         }
-      }
-    }
-    function characterToColumn(startLinePosition, characterInLine) {
-      let column = 0;
-      for (let i = 0; i < characterInLine; i++) {
-        if (sourceFile.text.charCodeAt(startLinePosition + i) === 9 /* tab */) {
-          column += options.tabSize - column % options.tabSize;
-        } else {
-          column++;
+        getCompletions(args, kind) {
+          const { file, project } = this.getFileAndProject(args);
+          const scriptInfo = this.projectService.getScriptInfoForNormalizedPath(file);
+          const position = this.getPosition(args, scriptInfo);
+          const completions = project.getLanguageService().getCompletionsAtPosition(
+            file,
+            position,
+            {
+              ...convertUserPreferences(this.getPreferences(file)),
+              triggerCharacter: args.triggerCharacter,
+              triggerKind: args.triggerKind,
+              includeExternalModuleExports: args.includeExternalModuleExports,
+              includeInsertTextCompletions: args.includeInsertTextCompletions
+            },
+            project.projectService.getFormatCodeOptions(file)
+          );
+          if (completions === void 0)
+            return void 0;
+          if (kind === "completions-full" /* CompletionsFull */)
+            return completions;
+          const prefix = args.prefix || "";
+          const entries = mapDefined(completions.entries, (entry) => {
+            if (completions.isMemberCompletion || startsWith(entry.name.toLowerCase(), prefix.toLowerCase())) {
+              const {
+                name,
+                kind: kind2,
+                kindModifiers,
+                sortText,
+                insertText,
+                filterText,
+                replacementSpan,
+                hasAction,
+                source,
+                sourceDisplay,
+                labelDetails,
+                isSnippet,
+                isRecommended,
+                isPackageJsonImport,
+                isImportStatementCompletion,
+                data
+              } = entry;
+              const convertedSpan = replacementSpan ? toProtocolTextSpan(replacementSpan, scriptInfo) : void 0;
+              return {
+                name,
+                kind: kind2,
+                kindModifiers,
+                sortText,
+                insertText,
+                filterText,
+                replacementSpan: convertedSpan,
+                isSnippet,
+                hasAction: hasAction || void 0,
+                source,
+                sourceDisplay,
+                labelDetails,
+                isRecommended,
+                isPackageJsonImport,
+                isImportStatementCompletion,
+                data
+              };
+            }
+          });
+          if (kind === "completions" /* Completions */) {
+            if (completions.metadata)
+              entries.metadata = completions.metadata;
+            return entries;
+          }
+          const res = {
+            ...completions,
+            optionalReplacementSpan: completions.optionalReplacementSpan && toProtocolTextSpan(completions.optionalReplacementSpan, scriptInfo),
+            entries
+          };
+          return res;
         }
-      }
-      return column;
-    }
-    function indentationIsDifferent(indentationString, startLinePosition) {
-      return indentationString !== sourceFile.text.substr(startLinePosition, indentationString.length);
-    }
-    function indentMultilineComment(commentRange, indentation, firstLineIsIndented, indentFinalLine = true) {
-      let startLine = sourceFile.getLineAndCharacterOfPosition(commentRange.pos).line;
-      const endLine = sourceFile.getLineAndCharacterOfPosition(commentRange.end).line;
-      if (startLine === endLine) {
-        if (!firstLineIsIndented) {
-          insertIndentation(
-            commentRange.pos,
-            indentation,
-            /*lineAdded*/
+        getCompletionEntryDetails(args, fullResult) {
+          const { file, project } = this.getFileAndProject(args);
+          const scriptInfo = this.projectService.getScriptInfoForNormalizedPath(file);
+          const position = this.getPosition(args, scriptInfo);
+          const formattingOptions = project.projectService.getFormatCodeOptions(file);
+          const useDisplayParts = !!this.getPreferences(file).displayPartsForJSDoc;
+          const result = mapDefined(args.entryNames, (entryName) => {
+            const { name, source, data } = typeof entryName === "string" ? { name: entryName, source: void 0, data: void 0 } : entryName;
+            return project.getLanguageService().getCompletionEntryDetails(file, position, name, formattingOptions, source, this.getPreferences(file), data ? cast(data, isCompletionEntryData) : void 0);
+          });
+          return fullResult ? useDisplayParts ? result : result.map((details) => ({ ...details, tags: this.mapJSDocTagInfo(
+            details.tags,
+            project,
+            /*richResponse*/
             false
+          ) })) : result.map((details) => ({
+            ...details,
+            codeActions: map(details.codeActions, (action) => this.mapCodeAction(action)),
+            documentation: this.mapDisplayParts(details.documentation, project),
+            tags: this.mapJSDocTagInfo(details.tags, project, useDisplayParts)
+          }));
+        }
+        getCompileOnSaveAffectedFileList(args) {
+          const projects = this.getProjects(
+            args,
+            /*getScriptInfoEnsuringProjectsUptoDate*/
+            true,
+            /*ignoreNoProjectError*/
+            true
+          );
+          const info = this.projectService.getScriptInfo(args.file);
+          if (!info) {
+            return emptyArray2;
+          }
+          return combineProjectOutput(
+            info,
+            (path) => this.projectService.getScriptInfoForPath(path),
+            projects,
+            (project, info2) => {
+              if (!project.compileOnSaveEnabled || !project.languageServiceEnabled || project.isOrphan()) {
+                return void 0;
+              }
+              const compilationSettings = project.getCompilationSettings();
+              if (!!compilationSettings.noEmit || isDeclarationFileName(info2.fileName) && !dtsChangeCanAffectEmit(compilationSettings)) {
+                return void 0;
+              }
+              return {
+                projectFileName: project.getProjectName(),
+                fileNames: project.getCompileOnSaveAffectedFileList(info2),
+                projectUsesOutFile: !!outFile(compilationSettings)
+              };
+            }
           );
         }
-        return;
-      }
-      const parts = [];
-      let startPos = commentRange.pos;
-      for (let line = startLine; line < endLine; line++) {
-        const endOfLine = getEndLinePosition(line, sourceFile);
-        parts.push({ pos: startPos, end: endOfLine });
-        startPos = getStartPositionOfLine(line + 1, sourceFile);
-      }
-      if (indentFinalLine) {
-        parts.push({ pos: startPos, end: commentRange.end });
-      }
-      if (parts.length === 0)
-        return;
-      const startLinePos = getStartPositionOfLine(startLine, sourceFile);
-      const nonWhitespaceColumnInFirstPart = SmartIndenter.findFirstNonWhitespaceCharacterAndColumn(startLinePos, parts[0].pos, sourceFile, options);
-      let startIndex = 0;
-      if (firstLineIsIndented) {
-        startIndex = 1;
-        startLine++;
-      }
-      const delta2 = indentation - nonWhitespaceColumnInFirstPart.column;
-      for (let i = startIndex; i < parts.length; i++, startLine++) {
-        const startLinePos2 = getStartPositionOfLine(startLine, sourceFile);
-        const nonWhitespaceCharacterAndColumn = i === 0 ? nonWhitespaceColumnInFirstPart : SmartIndenter.findFirstNonWhitespaceCharacterAndColumn(parts[i].pos, parts[i].end, sourceFile, options);
-        const newIndentation = nonWhitespaceCharacterAndColumn.column + delta2;
-        if (newIndentation > 0) {
-          const indentationString = getIndentationString(newIndentation, options);
-          recordReplace(startLinePos2, nonWhitespaceCharacterAndColumn.character, indentationString);
-        } else {
-          recordDelete(startLinePos2, nonWhitespaceCharacterAndColumn.character);
+        emitFile(args) {
+          const { file, project } = this.getFileAndProject(args);
+          if (!project) {
+            Errors.ThrowNoProject();
+          }
+          if (!project.languageServiceEnabled) {
+            return args.richResponse ? { emitSkipped: true, diagnostics: [] } : false;
+          }
+          const scriptInfo = project.getScriptInfo(file);
+          const { emitSkipped, diagnostics } = project.emitFile(scriptInfo, (path, data, writeByteOrderMark) => this.host.writeFile(path, data, writeByteOrderMark));
+          return args.richResponse ? {
+            emitSkipped,
+            diagnostics: args.includeLinePosition ? this.convertToDiagnosticsWithLinePositionFromDiagnosticFile(diagnostics) : diagnostics.map((d) => formatDiagnosticToProtocol(
+              d,
+              /*includeFileName*/
+              true
+            ))
+          } : !emitSkipped;
+        }
+        getSignatureHelpItems(args, simplifiedResult) {
+          const { file, project } = this.getFileAndProject(args);
+          const scriptInfo = this.projectService.getScriptInfoForNormalizedPath(file);
+          const position = this.getPosition(args, scriptInfo);
+          const helpItems = project.getLanguageService().getSignatureHelpItems(file, position, args);
+          const useDisplayParts = !!this.getPreferences(file).displayPartsForJSDoc;
+          if (helpItems && simplifiedResult) {
+            const span = helpItems.applicableSpan;
+            return {
+              ...helpItems,
+              applicableSpan: {
+                start: scriptInfo.positionToLineOffset(span.start),
+                end: scriptInfo.positionToLineOffset(span.start + span.length)
+              },
+              items: this.mapSignatureHelpItems(helpItems.items, project, useDisplayParts)
+            };
+          } else if (useDisplayParts || !helpItems) {
+            return helpItems;
+          } else {
+            return {
+              ...helpItems,
+              items: helpItems.items.map((item) => ({ ...item, tags: this.mapJSDocTagInfo(
+                item.tags,
+                project,
+                /*richResponse*/
+                false
+              ) }))
+            };
+          }
         }
-      }
-    }
-    function trimTrailingWhitespacesForLines(line1, line2, range) {
-      for (let line = line1; line < line2; line++) {
-        const lineStartPosition = getStartPositionOfLine(line, sourceFile);
-        const lineEndPosition = getEndLinePosition(line, sourceFile);
-        if (range && (isComment(range.kind) || isStringOrRegularExpressionOrTemplateLiteral(range.kind)) && range.pos <= lineEndPosition && range.end > lineEndPosition) {
-          continue;
+        toPendingErrorCheck(uncheckedFileName) {
+          const fileName = toNormalizedPath(uncheckedFileName);
+          const project = this.projectService.tryGetDefaultProjectForFile(fileName);
+          return project && { fileName, project };
         }
-        const whitespaceStart = getTrailingWhitespaceStartPosition(lineStartPosition, lineEndPosition);
-        if (whitespaceStart !== -1) {
-          Debug.assert(whitespaceStart === lineStartPosition || !isWhiteSpaceSingleLine(sourceFile.text.charCodeAt(whitespaceStart - 1)));
-          recordDelete(whitespaceStart, lineEndPosition + 1 - whitespaceStart);
+        getDiagnostics(next, delay, fileNames) {
+          if (this.suppressDiagnosticEvents) {
+            return;
+          }
+          if (fileNames.length > 0) {
+            this.updateErrorCheck(next, fileNames, delay);
+          }
+        }
+        change(args) {
+          const scriptInfo = this.projectService.getScriptInfo(args.file);
+          Debug.assert(!!scriptInfo);
+          scriptInfo.textStorage.switchToScriptVersionCache();
+          const start = scriptInfo.lineOffsetToPosition(args.line, args.offset);
+          const end = scriptInfo.lineOffsetToPosition(args.endLine, args.endOffset);
+          if (start >= 0) {
+            this.changeSeq++;
+            this.projectService.applyChangesToFile(
+              scriptInfo,
+              singleIterator({
+                span: { start, length: end - start },
+                newText: args.insertString
+                // TODO: GH#18217
+              })
+            );
+          }
         }
-      }
-    }
-    function getTrailingWhitespaceStartPosition(start, end) {
-      let pos = end;
-      while (pos >= start && isWhiteSpaceSingleLine(sourceFile.text.charCodeAt(pos))) {
-        pos--;
-      }
-      if (pos !== end) {
-        return pos + 1;
-      }
-      return -1;
-    }
-    function trimTrailingWhitespacesForRemainingRange(trivias) {
-      let startPos = previousRange ? previousRange.end : originalRange.pos;
-      for (const trivia of trivias) {
-        if (isComment(trivia.kind)) {
-          if (startPos < trivia.pos) {
-            trimTrailingWitespacesForPositions(startPos, trivia.pos - 1, previousRange);
+        reload(args, reqSeq) {
+          const file = toNormalizedPath(args.file);
+          const tempFileName = args.tmpfile === void 0 ? void 0 : toNormalizedPath(args.tmpfile);
+          const info = this.projectService.getScriptInfoForNormalizedPath(file);
+          if (info) {
+            this.changeSeq++;
+            if (info.reloadFromFile(tempFileName)) {
+              this.doOutput(
+                /*info*/
+                void 0,
+                "reload" /* Reload */,
+                reqSeq,
+                /*success*/
+                true
+              );
+            }
           }
-          startPos = trivia.end + 1;
         }
-      }
-      if (startPos < originalRange.end) {
-        trimTrailingWitespacesForPositions(startPos, originalRange.end, previousRange);
-      }
-    }
-    function trimTrailingWitespacesForPositions(startPos, endPos, previousRange2) {
-      const startLine = sourceFile.getLineAndCharacterOfPosition(startPos).line;
-      const endLine = sourceFile.getLineAndCharacterOfPosition(endPos).line;
-      trimTrailingWhitespacesForLines(startLine, endLine + 1, previousRange2);
-    }
-    function recordDelete(start, len) {
-      if (len) {
-        edits.push(createTextChangeFromStartLength(start, len, ""));
-      }
-    }
-    function recordReplace(start, len, newText) {
-      if (len || newText) {
-        edits.push(createTextChangeFromStartLength(start, len, newText));
-      }
-    }
-    function recordInsert(start, text) {
-      if (text) {
-        edits.push(createTextChangeFromStartLength(start, 0, text));
-      }
-    }
-    function applyRuleEdits(rule2, previousRange2, previousStartLine, currentRange, currentStartLine) {
-      const onLaterLine = currentStartLine !== previousStartLine;
-      switch (rule2.action) {
-        case 1 /* StopProcessingSpaceActions */:
-          return 0 /* None */;
-        case 16 /* DeleteSpace */:
-          if (previousRange2.end !== currentRange.pos) {
-            recordDelete(previousRange2.end, currentRange.pos - previousRange2.end);
-            return onLaterLine ? 2 /* LineRemoved */ : 0 /* None */;
+        saveToTmp(fileName, tempFileName) {
+          const scriptInfo = this.projectService.getScriptInfo(fileName);
+          if (scriptInfo) {
+            scriptInfo.saveTo(tempFileName);
           }
-          break;
-        case 32 /* DeleteToken */:
-          recordDelete(previousRange2.pos, previousRange2.end - previousRange2.pos);
-          break;
-        case 8 /* InsertNewLine */:
-          if (rule2.flags !== 1 /* CanDeleteNewLines */ && previousStartLine !== currentStartLine) {
-            return 0 /* None */;
+        }
+        closeClientFile(fileName) {
+          if (!fileName) {
+            return;
           }
-          const lineDelta = currentStartLine - previousStartLine;
-          if (lineDelta !== 1) {
-            recordReplace(previousRange2.end, currentRange.pos - previousRange2.end, getNewLineOrDefaultFromHost(host, options));
-            return onLaterLine ? 0 /* None */ : 1 /* LineAdded */;
+          const file = normalizePath(fileName);
+          this.projectService.closeClientFile(file);
+        }
+        mapLocationNavigationBarItems(items, scriptInfo) {
+          return map(items, (item) => ({
+            text: item.text,
+            kind: item.kind,
+            kindModifiers: item.kindModifiers,
+            spans: item.spans.map((span) => toProtocolTextSpan(span, scriptInfo)),
+            childItems: this.mapLocationNavigationBarItems(item.childItems, scriptInfo),
+            indent: item.indent
+          }));
+        }
+        getNavigationBarItems(args, simplifiedResult) {
+          const { file, languageService } = this.getFileAndLanguageServiceForSyntacticOperation(args);
+          const items = languageService.getNavigationBarItems(file);
+          return !items ? void 0 : simplifiedResult ? this.mapLocationNavigationBarItems(items, this.projectService.getScriptInfoForNormalizedPath(file)) : items;
+        }
+        toLocationNavigationTree(tree, scriptInfo) {
+          return {
+            text: tree.text,
+            kind: tree.kind,
+            kindModifiers: tree.kindModifiers,
+            spans: tree.spans.map((span) => toProtocolTextSpan(span, scriptInfo)),
+            nameSpan: tree.nameSpan && toProtocolTextSpan(tree.nameSpan, scriptInfo),
+            childItems: map(tree.childItems, (item) => this.toLocationNavigationTree(item, scriptInfo))
+          };
+        }
+        getNavigationTree(args, simplifiedResult) {
+          const { file, languageService } = this.getFileAndLanguageServiceForSyntacticOperation(args);
+          const tree = languageService.getNavigationTree(file);
+          return !tree ? void 0 : simplifiedResult ? this.toLocationNavigationTree(tree, this.projectService.getScriptInfoForNormalizedPath(file)) : tree;
+        }
+        getNavigateToItems(args, simplifiedResult) {
+          const full = this.getFullNavigateToItems(args);
+          return !simplifiedResult ? flatMap(full, ({ navigateToItems }) => navigateToItems) : flatMap(
+            full,
+            ({ project, navigateToItems }) => navigateToItems.map((navItem) => {
+              const scriptInfo = project.getScriptInfo(navItem.fileName);
+              const bakedItem = {
+                name: navItem.name,
+                kind: navItem.kind,
+                kindModifiers: navItem.kindModifiers,
+                isCaseSensitive: navItem.isCaseSensitive,
+                matchKind: navItem.matchKind,
+                file: navItem.fileName,
+                start: scriptInfo.positionToLineOffset(navItem.textSpan.start),
+                end: scriptInfo.positionToLineOffset(textSpanEnd(navItem.textSpan))
+              };
+              if (navItem.kindModifiers && navItem.kindModifiers !== "") {
+                bakedItem.kindModifiers = navItem.kindModifiers;
+              }
+              if (navItem.containerName && navItem.containerName.length > 0) {
+                bakedItem.containerName = navItem.containerName;
+              }
+              if (navItem.containerKind && navItem.containerKind.length > 0) {
+                bakedItem.containerKind = navItem.containerKind;
+              }
+              return bakedItem;
+            })
+          );
+        }
+        getFullNavigateToItems(args) {
+          const { currentFileOnly, searchValue, maxResultCount, projectFileName } = args;
+          if (currentFileOnly) {
+            Debug.assertIsDefined(args.file);
+            const { file, project } = this.getFileAndProject(args);
+            return [{ project, navigateToItems: project.getLanguageService().getNavigateToItems(searchValue, maxResultCount, file) }];
+          }
+          const preferences = this.getHostPreferences();
+          const outputs = [];
+          const seenItems = /* @__PURE__ */ new Map();
+          if (!args.file && !projectFileName) {
+            this.projectService.loadAncestorProjectTree();
+            this.projectService.forEachEnabledProject((project) => addItemsForProject(project));
+          } else {
+            const projects = this.getProjects(args);
+            forEachProjectInProjects(
+              projects,
+              /*path*/
+              void 0,
+              (project) => addItemsForProject(project)
+            );
           }
-          break;
-        case 4 /* InsertSpace */:
-          if (rule2.flags !== 1 /* CanDeleteNewLines */ && previousStartLine !== currentStartLine) {
-            return 0 /* None */;
+          return outputs;
+          function addItemsForProject(project) {
+            const projectItems = project.getLanguageService().getNavigateToItems(
+              searchValue,
+              maxResultCount,
+              /*fileName*/
+              void 0,
+              /*excludeDts*/
+              project.isNonTsProject(),
+              /*excludeLibFiles*/
+              preferences.excludeLibrarySymbolsInNavTo
+            );
+            const unseenItems = filter(projectItems, (item) => tryAddSeenItem(item) && !getMappedLocationForProject(documentSpanLocation(item), project));
+            if (unseenItems.length) {
+              outputs.push({ project, navigateToItems: unseenItems });
+            }
           }
-          const posDelta = currentRange.pos - previousRange2.end;
-          if (posDelta !== 1 || sourceFile.text.charCodeAt(previousRange2.end) !== 32 /* space */) {
-            recordReplace(previousRange2.end, currentRange.pos - previousRange2.end, " ");
-            return onLaterLine ? 2 /* LineRemoved */ : 0 /* None */;
+          function tryAddSeenItem(item) {
+            const name = item.name;
+            if (!seenItems.has(name)) {
+              seenItems.set(name, [item]);
+              return true;
+            }
+            const seen = seenItems.get(name);
+            for (const seenItem of seen) {
+              if (navigateToItemIsEqualTo(seenItem, item)) {
+                return false;
+              }
+            }
+            seen.push(item);
+            return true;
+          }
+          function navigateToItemIsEqualTo(a, b) {
+            if (a === b) {
+              return true;
+            }
+            if (!a || !b) {
+              return false;
+            }
+            return a.containerKind === b.containerKind && a.containerName === b.containerName && a.fileName === b.fileName && a.isCaseSensitive === b.isCaseSensitive && a.kind === b.kind && a.kindModifiers === b.kindModifiers && a.matchKind === b.matchKind && a.name === b.name && a.textSpan.start === b.textSpan.start && a.textSpan.length === b.textSpan.length;
           }
-          break;
-        case 64 /* InsertTrailingSemicolon */:
-          recordInsert(previousRange2.end, ";");
-      }
-      return 0 /* None */;
-    }
-  }
-  function getRangeOfEnclosingComment(sourceFile, position, precedingToken, tokenAtPosition = getTokenAtPosition(sourceFile, position)) {
-    const jsdoc = findAncestor(tokenAtPosition, isJSDoc);
-    if (jsdoc)
-      tokenAtPosition = jsdoc.parent;
-    const tokenStart = tokenAtPosition.getStart(sourceFile);
-    if (tokenStart <= position && position < tokenAtPosition.getEnd()) {
-      return void 0;
-    }
-    precedingToken = precedingToken === null ? void 0 : precedingToken === void 0 ? findPrecedingToken(position, sourceFile) : precedingToken;
-    const trailingRangesOfPreviousToken = precedingToken && getTrailingCommentRanges(sourceFile.text, precedingToken.end);
-    const leadingCommentRangesOfNextToken = getLeadingCommentRangesOfNode(tokenAtPosition, sourceFile);
-    const commentRanges = concatenate(trailingRangesOfPreviousToken, leadingCommentRangesOfNextToken);
-    return commentRanges && find(commentRanges, (range) => rangeContainsPositionExclusive(range, position) || // The end marker of a single-line comment does not include the newline character.
-    // With caret at `^`, in the following case, we are inside a comment (^ denotes the cursor position):
-    //
-    //    // asdf   ^\n
-    //
-    // But for closed multi-line comments, we don't want to be inside the comment in the following case:
-    //
-    //    /* asdf */^
-    //
-    // However, unterminated multi-line comments *do* contain their end.
-    //
-    // Internally, we represent the end of the comment at the newline and closing '/', respectively.
-    //
-    position === range.end && (range.kind === 2 /* SingleLineCommentTrivia */ || position === sourceFile.getFullWidth()));
-  }
-  function getOpenTokenForList(node, list) {
-    switch (node.kind) {
-      case 175 /* Constructor */:
-      case 261 /* FunctionDeclaration */:
-      case 217 /* FunctionExpression */:
-      case 173 /* MethodDeclaration */:
-      case 172 /* MethodSignature */:
-      case 218 /* ArrowFunction */:
-      case 178 /* CallSignature */:
-      case 179 /* ConstructSignature */:
-      case 183 /* FunctionType */:
-      case 184 /* ConstructorType */:
-      case 176 /* GetAccessor */:
-      case 177 /* SetAccessor */:
-        if (node.typeParameters === list) {
-          return 30 /* LessThanToken */;
-        } else if (node.parameters === list) {
-          return 21 /* OpenParenToken */;
         }
-        break;
-      case 212 /* CallExpression */:
-      case 213 /* NewExpression */:
-        if (node.typeArguments === list) {
-          return 30 /* LessThanToken */;
-        } else if (node.arguments === list) {
-          return 21 /* OpenParenToken */;
+        getSupportedCodeFixes(args) {
+          if (!args)
+            return getSupportedCodeFixes();
+          if (args.file) {
+            const { file, project: project2 } = this.getFileAndProject(args);
+            return project2.getLanguageService().getSupportedCodeFixes(file);
+          }
+          const project = this.getProject(args.projectFileName);
+          if (!project)
+            Errors.ThrowNoProject();
+          return project.getLanguageService().getSupportedCodeFixes();
         }
-        break;
-      case 262 /* ClassDeclaration */:
-      case 230 /* ClassExpression */:
-      case 263 /* InterfaceDeclaration */:
-      case 264 /* TypeAliasDeclaration */:
-        if (node.typeParameters === list) {
-          return 30 /* LessThanToken */;
+        isLocation(locationOrSpan) {
+          return locationOrSpan.line !== void 0;
         }
-        break;
-      case 182 /* TypeReference */:
-      case 214 /* TaggedTemplateExpression */:
-      case 185 /* TypeQuery */:
-      case 232 /* ExpressionWithTypeArguments */:
-      case 204 /* ImportType */:
-        if (node.typeArguments === list) {
-          return 30 /* LessThanToken */;
+        extractPositionOrRange(args, scriptInfo) {
+          let position;
+          let textRange;
+          if (this.isLocation(args)) {
+            position = getPosition(args);
+          } else {
+            textRange = this.getRange(args, scriptInfo);
+          }
+          return Debug.checkDefined(position === void 0 ? textRange : position);
+          function getPosition(loc) {
+            return loc.position !== void 0 ? loc.position : scriptInfo.lineOffsetToPosition(loc.line, loc.offset);
+          }
         }
-        break;
-      case 186 /* TypeLiteral */:
-        return 19 /* OpenBraceToken */;
-    }
-    return 0 /* Unknown */;
-  }
-  function getCloseTokenForOpenToken(kind) {
-    switch (kind) {
-      case 21 /* OpenParenToken */:
-        return 22 /* CloseParenToken */;
-      case 30 /* LessThanToken */:
-        return 32 /* GreaterThanToken */;
-      case 19 /* OpenBraceToken */:
-        return 20 /* CloseBraceToken */;
-    }
-    return 0 /* Unknown */;
-  }
-  function getIndentationString(indentation, options) {
-    const resetInternedStrings = !internedSizes || (internedSizes.tabSize !== options.tabSize || internedSizes.indentSize !== options.indentSize);
-    if (resetInternedStrings) {
-      internedSizes = { tabSize: options.tabSize, indentSize: options.indentSize };
-      internedTabsIndentation = internedSpacesIndentation = void 0;
-    }
-    if (!options.convertTabsToSpaces) {
-      const tabs = Math.floor(indentation / options.tabSize);
-      const spaces = indentation - tabs * options.tabSize;
-      let tabString;
-      if (!internedTabsIndentation) {
-        internedTabsIndentation = [];
-      }
-      if (internedTabsIndentation[tabs] === void 0) {
-        internedTabsIndentation[tabs] = tabString = repeatString("	", tabs);
-      } else {
-        tabString = internedTabsIndentation[tabs];
-      }
-      return spaces ? tabString + repeatString(" ", spaces) : tabString;
-    } else {
-      let spacesString;
-      const quotient = Math.floor(indentation / options.indentSize);
-      const remainder = indentation % options.indentSize;
-      if (!internedSpacesIndentation) {
-        internedSpacesIndentation = [];
-      }
-      if (internedSpacesIndentation[quotient] === void 0) {
-        spacesString = repeatString(" ", options.indentSize * quotient);
-        internedSpacesIndentation[quotient] = spacesString;
-      } else {
-        spacesString = internedSpacesIndentation[quotient];
-      }
-      return remainder ? spacesString + repeatString(" ", remainder) : spacesString;
-    }
-  }
-  var internedSizes, internedTabsIndentation, internedSpacesIndentation;
-  var init_formatting = __esm({
-    "src/services/formatting/formatting.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_formatting();
-    }
-  });
-
-  // src/services/formatting/smartIndenter.ts
-  var SmartIndenter;
-  var init_smartIndenter = __esm({
-    "src/services/formatting/smartIndenter.ts"() {
-      "use strict";
-      init_ts4();
-      init_ts_formatting();
-      ((SmartIndenter2) => {
-        let Value;
-        ((Value2) => {
-          Value2[Value2["Unknown"] = -1] = "Unknown";
-        })(Value || (Value = {}));
-        function getIndentation(position, sourceFile, options, assumeNewLineBeforeCloseBrace = false) {
-          if (position > sourceFile.text.length) {
-            return getBaseIndentation(options);
+        getRange(args, scriptInfo) {
+          const { startPosition, endPosition } = this.getStartAndEndPosition(args, scriptInfo);
+          return { pos: startPosition, end: endPosition };
+        }
+        getApplicableRefactors(args) {
+          const { file, project } = this.getFileAndProject(args);
+          const scriptInfo = project.getScriptInfoForNormalizedPath(file);
+          return project.getLanguageService().getApplicableRefactors(file, this.extractPositionOrRange(args, scriptInfo), this.getPreferences(file), args.triggerReason, args.kind, args.includeInteractiveActions);
+        }
+        getEditsForRefactor(args, simplifiedResult) {
+          const { file, project } = this.getFileAndProject(args);
+          const scriptInfo = project.getScriptInfoForNormalizedPath(file);
+          const result = project.getLanguageService().getEditsForRefactor(
+            file,
+            this.getFormatOptions(file),
+            this.extractPositionOrRange(args, scriptInfo),
+            args.refactor,
+            args.action,
+            this.getPreferences(file),
+            args.interactiveRefactorArguments
+          );
+          if (result === void 0) {
+            return {
+              edits: []
+            };
           }
-          if (options.indentStyle === 0 /* None */) {
-            return 0;
+          if (simplifiedResult) {
+            const { renameFilename, renameLocation, edits } = result;
+            let mappedRenameLocation;
+            if (renameFilename !== void 0 && renameLocation !== void 0) {
+              const renameScriptInfo = project.getScriptInfoForNormalizedPath(toNormalizedPath(renameFilename));
+              mappedRenameLocation = getLocationInNewDocument(getSnapshotText(renameScriptInfo.getSnapshot()), renameFilename, renameLocation, edits);
+            }
+            return {
+              renameLocation: mappedRenameLocation,
+              renameFilename,
+              edits: this.mapTextChangesToCodeEdits(edits),
+              notApplicableReason: result.notApplicableReason
+            };
           }
-          const precedingToken = findPrecedingToken(
-            position,
-            sourceFile,
-            /*startNode*/
+          return result;
+        }
+        getMoveToRefactoringFileSuggestions(args) {
+          const { file, project } = this.getFileAndProject(args);
+          const scriptInfo = project.getScriptInfoForNormalizedPath(file);
+          return project.getLanguageService().getMoveToRefactoringFileSuggestions(file, this.extractPositionOrRange(args, scriptInfo), this.getPreferences(file));
+        }
+        organizeImports(args, simplifiedResult) {
+          Debug.assert(args.scope.type === "file");
+          const { file, project } = this.getFileAndProject(args.scope.args);
+          const changes = project.getLanguageService().organizeImports(
+            {
+              fileName: file,
+              mode: args.mode ?? (args.skipDestructiveCodeActions ? "SortAndCombine" /* SortAndCombine */ : void 0),
+              type: "file"
+            },
+            this.getFormatOptions(file),
+            this.getPreferences(file)
+          );
+          if (simplifiedResult) {
+            return this.mapTextChangesToCodeEdits(changes);
+          } else {
+            return changes;
+          }
+        }
+        getEditsForFileRename(args, simplifiedResult) {
+          const oldPath = toNormalizedPath(args.oldFilePath);
+          const newPath = toNormalizedPath(args.newFilePath);
+          const formatOptions = this.getHostFormatOptions();
+          const preferences = this.getHostPreferences();
+          const seenFiles = /* @__PURE__ */ new Set();
+          const textChanges2 = [];
+          this.projectService.loadAncestorProjectTree();
+          this.projectService.forEachEnabledProject((project) => {
+            const projectTextChanges = project.getLanguageService().getEditsForFileRename(oldPath, newPath, formatOptions, preferences);
+            const projectFiles = [];
+            for (const textChange of projectTextChanges) {
+              if (!seenFiles.has(textChange.fileName)) {
+                textChanges2.push(textChange);
+                projectFiles.push(textChange.fileName);
+              }
+            }
+            for (const file of projectFiles) {
+              seenFiles.add(file);
+            }
+          });
+          return simplifiedResult ? textChanges2.map((c) => this.mapTextChangeToCodeEdit(c)) : textChanges2;
+        }
+        getCodeFixes(args, simplifiedResult) {
+          const { file, project } = this.getFileAndProject(args);
+          const scriptInfo = project.getScriptInfoForNormalizedPath(file);
+          const { startPosition, endPosition } = this.getStartAndEndPosition(args, scriptInfo);
+          let codeActions;
+          try {
+            codeActions = project.getLanguageService().getCodeFixesAtPosition(file, startPosition, endPosition, args.errorCodes, this.getFormatOptions(file), this.getPreferences(file));
+          } catch (e) {
+            const ls = project.getLanguageService();
+            const existingDiagCodes = [
+              ...ls.getSyntacticDiagnostics(file),
+              ...ls.getSemanticDiagnostics(file),
+              ...ls.getSuggestionDiagnostics(file)
+            ].map(
+              (d) => decodedTextSpanIntersectsWith(startPosition, endPosition - startPosition, d.start, d.length) && d.code
+            );
+            const badCode = args.errorCodes.find((c) => !existingDiagCodes.includes(c));
+            if (badCode !== void 0) {
+              e.message = `BADCLIENT: Bad error code, ${badCode} not found in range ${startPosition}..${endPosition} (found: ${existingDiagCodes.join(", ")}); could have caused this error:
+${e.message}`;
+            }
+            throw e;
+          }
+          return simplifiedResult ? codeActions.map((codeAction) => this.mapCodeFixAction(codeAction)) : codeActions;
+        }
+        getCombinedCodeFix({ scope, fixId: fixId52 }, simplifiedResult) {
+          Debug.assert(scope.type === "file");
+          const { file, project } = this.getFileAndProject(scope.args);
+          const res = project.getLanguageService().getCombinedCodeFix({ type: "file", fileName: file }, fixId52, this.getFormatOptions(file), this.getPreferences(file));
+          if (simplifiedResult) {
+            return { changes: this.mapTextChangesToCodeEdits(res.changes), commands: res.commands };
+          } else {
+            return res;
+          }
+        }
+        applyCodeActionCommand(args) {
+          const commands = args.command;
+          for (const command of toArray(commands)) {
+            const { file, project } = this.getFileAndProject(command);
+            project.getLanguageService().applyCodeActionCommand(command, this.getFormatOptions(file)).then(
+              (_result) => {
+              },
+              (_error) => {
+              }
+            );
+          }
+          return {};
+        }
+        getStartAndEndPosition(args, scriptInfo) {
+          let startPosition, endPosition;
+          if (args.startPosition !== void 0) {
+            startPosition = args.startPosition;
+          } else {
+            startPosition = scriptInfo.lineOffsetToPosition(args.startLine, args.startOffset);
+            args.startPosition = startPosition;
+          }
+          if (args.endPosition !== void 0) {
+            endPosition = args.endPosition;
+          } else {
+            endPosition = scriptInfo.lineOffsetToPosition(args.endLine, args.endOffset);
+            args.endPosition = endPosition;
+          }
+          return { startPosition, endPosition };
+        }
+        mapCodeAction({ description: description3, changes, commands }) {
+          return { description: description3, changes: this.mapTextChangesToCodeEdits(changes), commands };
+        }
+        mapCodeFixAction({ fixName: fixName8, description: description3, changes, commands, fixId: fixId52, fixAllDescription }) {
+          return { fixName: fixName8, description: description3, changes: this.mapTextChangesToCodeEdits(changes), commands, fixId: fixId52, fixAllDescription };
+        }
+        mapTextChangesToCodeEdits(textChanges2) {
+          return textChanges2.map((change) => this.mapTextChangeToCodeEdit(change));
+        }
+        mapTextChangeToCodeEdit(textChanges2) {
+          const scriptInfo = this.projectService.getScriptInfoOrConfig(textChanges2.fileName);
+          if (!!textChanges2.isNewFile === !!scriptInfo) {
+            if (!scriptInfo) {
+              this.projectService.logErrorForScriptInfoNotFound(textChanges2.fileName);
+            }
+            Debug.fail("Expected isNewFile for (only) new files. " + JSON.stringify({ isNewFile: !!textChanges2.isNewFile, hasScriptInfo: !!scriptInfo }));
+          }
+          return scriptInfo ? { fileName: textChanges2.fileName, textChanges: textChanges2.textChanges.map((textChange) => convertTextChangeToCodeEdit(textChange, scriptInfo)) } : convertNewFileTextChangeToCodeEdit(textChanges2);
+        }
+        convertTextChangeToCodeEdit(change, scriptInfo) {
+          return {
+            start: scriptInfo.positionToLineOffset(change.span.start),
+            end: scriptInfo.positionToLineOffset(change.span.start + change.span.length),
+            newText: change.newText ? change.newText : ""
+          };
+        }
+        getBraceMatching(args, simplifiedResult) {
+          const { file, languageService } = this.getFileAndLanguageServiceForSyntacticOperation(args);
+          const scriptInfo = this.projectService.getScriptInfoForNormalizedPath(file);
+          const position = this.getPosition(args, scriptInfo);
+          const spans = languageService.getBraceMatchingAtPosition(file, position);
+          return !spans ? void 0 : simplifiedResult ? spans.map((span) => toProtocolTextSpan(span, scriptInfo)) : spans;
+        }
+        getDiagnosticsForProject(next, delay, fileName) {
+          if (this.suppressDiagnosticEvents) {
+            return;
+          }
+          const { fileNames, languageServiceDisabled } = this.getProjectInfoWorker(
+            fileName,
+            /*projectFileName*/
             void 0,
-            /*excludeJsdoc*/
+            /*needFileNameList*/
+            true,
+            /*excludeConfigFiles*/
             true
           );
-          const enclosingCommentRange = getRangeOfEnclosingComment(sourceFile, position, precedingToken || null);
-          if (enclosingCommentRange && enclosingCommentRange.kind === 3 /* MultiLineCommentTrivia */) {
-            return getCommentIndent(sourceFile, position, options, enclosingCommentRange);
+          if (languageServiceDisabled) {
+            return;
           }
-          if (!precedingToken) {
-            return getBaseIndentation(options);
+          const fileNamesInProject = fileNames.filter((value) => !value.includes("lib.d.ts"));
+          if (fileNamesInProject.length === 0) {
+            return;
           }
-          const precedingTokenIsLiteral = isStringOrRegularExpressionOrTemplateLiteral(precedingToken.kind);
-          if (precedingTokenIsLiteral && precedingToken.getStart(sourceFile) <= position && position < precedingToken.end) {
-            return 0;
+          const highPriorityFiles = [];
+          const mediumPriorityFiles = [];
+          const lowPriorityFiles = [];
+          const veryLowPriorityFiles = [];
+          const normalizedFileName = toNormalizedPath(fileName);
+          const project = this.projectService.ensureDefaultProjectForFile(normalizedFileName);
+          for (const fileNameInProject of fileNamesInProject) {
+            if (this.getCanonicalFileName(fileNameInProject) === this.getCanonicalFileName(fileName)) {
+              highPriorityFiles.push(fileNameInProject);
+            } else {
+              const info = this.projectService.getScriptInfo(fileNameInProject);
+              if (!info.isScriptOpen()) {
+                if (isDeclarationFileName(fileNameInProject)) {
+                  veryLowPriorityFiles.push(fileNameInProject);
+                } else {
+                  lowPriorityFiles.push(fileNameInProject);
+                }
+              } else {
+                mediumPriorityFiles.push(fileNameInProject);
+              }
+            }
           }
-          const lineAtPosition = sourceFile.getLineAndCharacterOfPosition(position).line;
-          const currentToken = getTokenAtPosition(sourceFile, position);
-          const isObjectLiteral = currentToken.kind === 19 /* OpenBraceToken */ && currentToken.parent.kind === 209 /* ObjectLiteralExpression */;
-          if (options.indentStyle === 1 /* Block */ || isObjectLiteral) {
-            return getBlockIndent(sourceFile, position, options);
+          const sortedFiles = [...highPriorityFiles, ...mediumPriorityFiles, ...lowPriorityFiles, ...veryLowPriorityFiles];
+          const checkList = sortedFiles.map((fileName2) => ({ fileName: fileName2, project }));
+          this.updateErrorCheck(
+            next,
+            checkList,
+            delay,
+            /*requireOpen*/
+            false
+          );
+        }
+        configurePlugin(args) {
+          this.projectService.configurePlugin(args);
+        }
+        getSmartSelectionRange(args, simplifiedResult) {
+          const { locations } = args;
+          const { file, languageService } = this.getFileAndLanguageServiceForSyntacticOperation(args);
+          const scriptInfo = Debug.checkDefined(this.projectService.getScriptInfo(file));
+          return map(locations, (location) => {
+            const pos = this.getPosition(location, scriptInfo);
+            const selectionRange = languageService.getSmartSelectionRange(file, pos);
+            return simplifiedResult ? this.mapSelectionRange(selectionRange, scriptInfo) : selectionRange;
+          });
+        }
+        toggleLineComment(args, simplifiedResult) {
+          const { file, languageService } = this.getFileAndLanguageServiceForSyntacticOperation(args);
+          const scriptInfo = this.projectService.getScriptInfo(file);
+          const textRange = this.getRange(args, scriptInfo);
+          const textChanges2 = languageService.toggleLineComment(file, textRange);
+          if (simplifiedResult) {
+            const scriptInfo2 = this.projectService.getScriptInfoForNormalizedPath(file);
+            return textChanges2.map((textChange) => this.convertTextChangeToCodeEdit(textChange, scriptInfo2));
+          }
+          return textChanges2;
+        }
+        toggleMultilineComment(args, simplifiedResult) {
+          const { file, languageService } = this.getFileAndLanguageServiceForSyntacticOperation(args);
+          const scriptInfo = this.projectService.getScriptInfoForNormalizedPath(file);
+          const textRange = this.getRange(args, scriptInfo);
+          const textChanges2 = languageService.toggleMultilineComment(file, textRange);
+          if (simplifiedResult) {
+            const scriptInfo2 = this.projectService.getScriptInfoForNormalizedPath(file);
+            return textChanges2.map((textChange) => this.convertTextChangeToCodeEdit(textChange, scriptInfo2));
+          }
+          return textChanges2;
+        }
+        commentSelection(args, simplifiedResult) {
+          const { file, languageService } = this.getFileAndLanguageServiceForSyntacticOperation(args);
+          const scriptInfo = this.projectService.getScriptInfoForNormalizedPath(file);
+          const textRange = this.getRange(args, scriptInfo);
+          const textChanges2 = languageService.commentSelection(file, textRange);
+          if (simplifiedResult) {
+            const scriptInfo2 = this.projectService.getScriptInfoForNormalizedPath(file);
+            return textChanges2.map((textChange) => this.convertTextChangeToCodeEdit(textChange, scriptInfo2));
+          }
+          return textChanges2;
+        }
+        uncommentSelection(args, simplifiedResult) {
+          const { file, languageService } = this.getFileAndLanguageServiceForSyntacticOperation(args);
+          const scriptInfo = this.projectService.getScriptInfoForNormalizedPath(file);
+          const textRange = this.getRange(args, scriptInfo);
+          const textChanges2 = languageService.uncommentSelection(file, textRange);
+          if (simplifiedResult) {
+            const scriptInfo2 = this.projectService.getScriptInfoForNormalizedPath(file);
+            return textChanges2.map((textChange) => this.convertTextChangeToCodeEdit(textChange, scriptInfo2));
+          }
+          return textChanges2;
+        }
+        mapSelectionRange(selectionRange, scriptInfo) {
+          const result = {
+            textSpan: toProtocolTextSpan(selectionRange.textSpan, scriptInfo)
+          };
+          if (selectionRange.parent) {
+            result.parent = this.mapSelectionRange(selectionRange.parent, scriptInfo);
           }
-          if (precedingToken.kind === 28 /* CommaToken */ && precedingToken.parent.kind !== 225 /* BinaryExpression */) {
-            const actualIndentation = getActualIndentationForListItemBeforeComma(precedingToken, sourceFile, options);
-            if (actualIndentation !== -1 /* Unknown */) {
-              return actualIndentation;
-            }
+          return result;
+        }
+        getScriptInfoFromProjectService(file) {
+          const normalizedFile = toNormalizedPath(file);
+          const scriptInfo = this.projectService.getScriptInfoForNormalizedPath(normalizedFile);
+          if (!scriptInfo) {
+            this.projectService.logErrorForScriptInfoNotFound(normalizedFile);
+            return Errors.ThrowNoProject();
           }
-          const containerList = getListByPosition(position, precedingToken.parent, sourceFile);
-          if (containerList && !rangeContainsRange(containerList, precedingToken)) {
-            const useTheSameBaseIndentation = [217 /* FunctionExpression */, 218 /* ArrowFunction */].indexOf(currentToken.parent.kind) !== -1;
-            const indentSize = useTheSameBaseIndentation ? 0 : options.indentSize;
-            return getActualIndentationForListStartLine(containerList, sourceFile, options) + indentSize;
+          return scriptInfo;
+        }
+        toProtocolCallHierarchyItem(item) {
+          const scriptInfo = this.getScriptInfoFromProjectService(item.file);
+          return {
+            name: item.name,
+            kind: item.kind,
+            kindModifiers: item.kindModifiers,
+            file: item.file,
+            containerName: item.containerName,
+            span: toProtocolTextSpan(item.span, scriptInfo),
+            selectionSpan: toProtocolTextSpan(item.selectionSpan, scriptInfo)
+          };
+        }
+        toProtocolCallHierarchyIncomingCall(incomingCall) {
+          const scriptInfo = this.getScriptInfoFromProjectService(incomingCall.from.file);
+          return {
+            from: this.toProtocolCallHierarchyItem(incomingCall.from),
+            fromSpans: incomingCall.fromSpans.map((fromSpan) => toProtocolTextSpan(fromSpan, scriptInfo))
+          };
+        }
+        toProtocolCallHierarchyOutgoingCall(outgoingCall, scriptInfo) {
+          return {
+            to: this.toProtocolCallHierarchyItem(outgoingCall.to),
+            fromSpans: outgoingCall.fromSpans.map((fromSpan) => toProtocolTextSpan(fromSpan, scriptInfo))
+          };
+        }
+        prepareCallHierarchy(args) {
+          const { file, project } = this.getFileAndProject(args);
+          const scriptInfo = this.projectService.getScriptInfoForNormalizedPath(file);
+          if (scriptInfo) {
+            const position = this.getPosition(args, scriptInfo);
+            const result = project.getLanguageService().prepareCallHierarchy(file, position);
+            return result && mapOneOrMany(result, (item) => this.toProtocolCallHierarchyItem(item));
           }
-          return getSmartIndent(sourceFile, position, precedingToken, lineAtPosition, assumeNewLineBeforeCloseBrace, options);
+          return void 0;
         }
-        SmartIndenter2.getIndentation = getIndentation;
-        function getCommentIndent(sourceFile, position, options, enclosingCommentRange) {
-          const previousLine = getLineAndCharacterOfPosition(sourceFile, position).line - 1;
-          const commentStartLine = getLineAndCharacterOfPosition(sourceFile, enclosingCommentRange.pos).line;
-          Debug.assert(commentStartLine >= 0);
-          if (previousLine <= commentStartLine) {
-            return findFirstNonWhitespaceColumn(getStartPositionOfLine(commentStartLine, sourceFile), position, sourceFile, options);
+        provideCallHierarchyIncomingCalls(args) {
+          const { file, project } = this.getFileAndProject(args);
+          const scriptInfo = this.getScriptInfoFromProjectService(file);
+          const incomingCalls = project.getLanguageService().provideCallHierarchyIncomingCalls(file, this.getPosition(args, scriptInfo));
+          return incomingCalls.map((call) => this.toProtocolCallHierarchyIncomingCall(call));
+        }
+        provideCallHierarchyOutgoingCalls(args) {
+          const { file, project } = this.getFileAndProject(args);
+          const scriptInfo = this.getScriptInfoFromProjectService(file);
+          const outgoingCalls = project.getLanguageService().provideCallHierarchyOutgoingCalls(file, this.getPosition(args, scriptInfo));
+          return outgoingCalls.map((call) => this.toProtocolCallHierarchyOutgoingCall(call, scriptInfo));
+        }
+        getCanonicalFileName(fileName) {
+          const name = this.host.useCaseSensitiveFileNames ? fileName : toFileNameLowerCase(fileName);
+          return normalizePath(name);
+        }
+        exit() {
+        }
+        notRequired() {
+          return { responseRequired: false };
+        }
+        requiredResponse(response) {
+          return { response, responseRequired: true };
+        }
+        addProtocolHandler(command, handler) {
+          if (this.handlers.has(command)) {
+            throw new Error(`Protocol handler already exists for command "${command}"`);
           }
-          const startPositionOfLine = getStartPositionOfLine(previousLine, sourceFile);
-          const { column, character } = findFirstNonWhitespaceCharacterAndColumn(startPositionOfLine, position, sourceFile, options);
-          if (column === 0) {
-            return column;
+          this.handlers.set(command, handler);
+        }
+        setCurrentRequest(requestId) {
+          Debug.assert(this.currentRequestId === void 0);
+          this.currentRequestId = requestId;
+          this.cancellationToken.setRequest(requestId);
+        }
+        resetCurrentRequest(requestId) {
+          Debug.assert(this.currentRequestId === requestId);
+          this.currentRequestId = void 0;
+          this.cancellationToken.resetRequest(requestId);
+        }
+        executeWithRequestId(requestId, f) {
+          try {
+            this.setCurrentRequest(requestId);
+            return f();
+          } finally {
+            this.resetCurrentRequest(requestId);
           }
-          const firstNonWhitespaceCharacterCode = sourceFile.text.charCodeAt(startPositionOfLine + character);
-          return firstNonWhitespaceCharacterCode === 42 /* asterisk */ ? column - 1 : column;
         }
-        function getBlockIndent(sourceFile, position, options) {
-          let current = position;
-          while (current > 0) {
-            const char = sourceFile.text.charCodeAt(current);
-            if (!isWhiteSpaceLike(char)) {
-              break;
-            }
-            current--;
+        executeCommand(request) {
+          const handler = this.handlers.get(request.command);
+          if (handler) {
+            const response = this.executeWithRequestId(request.seq, () => handler(request));
+            this.projectService.enableRequestedPlugins();
+            return response;
+          } else {
+            this.logger.msg(`Unrecognized JSON command:${stringifyIndented(request)}`, "Err" /* Err */);
+            this.doOutput(
+              /*info*/
+              void 0,
+              "unknown" /* Unknown */,
+              request.seq,
+              /*success*/
+              false,
+              `Unrecognized JSON command: ${request.command}`
+            );
+            return { responseRequired: false };
           }
-          const lineStart = getLineStartPositionForPosition(current, sourceFile);
-          return findFirstNonWhitespaceColumn(lineStart, current, sourceFile, options);
         }
-        function getSmartIndent(sourceFile, position, precedingToken, lineAtPosition, assumeNewLineBeforeCloseBrace, options) {
-          let previous;
-          let current = precedingToken;
-          while (current) {
-            if (positionBelongsToNode(current, position, sourceFile) && shouldIndentChildNode(
-              options,
-              current,
-              previous,
-              sourceFile,
-              /*isNextChild*/
+        onMessage(message) {
+          var _a, _b, _c, _d, _e, _f, _g, _h, _i, _j, _k;
+          this.gcTimer.scheduleCollect();
+          this.performanceData = void 0;
+          let start;
+          if (this.logger.hasLevel(2 /* requestTime */)) {
+            start = this.hrtime();
+            if (this.logger.hasLevel(3 /* verbose */)) {
+              this.logger.info(`request:${indent2(this.toStringMessage(message))}`);
+            }
+          }
+          let request;
+          let relevantFile;
+          try {
+            request = this.parseMessage(message);
+            relevantFile = request.arguments && request.arguments.file ? request.arguments : void 0;
+            (_a = tracing) == null ? void 0 : _a.instant(tracing.Phase.Session, "request", { seq: request.seq, command: request.command });
+            (_b = perfLogger) == null ? void 0 : _b.logStartCommand("" + request.command, this.toStringMessage(message).substring(0, 100));
+            (_c = tracing) == null ? void 0 : _c.push(
+              tracing.Phase.Session,
+              "executeCommand",
+              { seq: request.seq, command: request.command },
+              /*separateBeginAndEnd*/
               true
-            )) {
-              const currentStart = getStartLineAndCharacterForNode(current, sourceFile);
-              const nextTokenKind = nextTokenIsCurlyBraceOnSameLineAsCursor(precedingToken, current, lineAtPosition, sourceFile);
-              const indentationDelta = nextTokenKind !== 0 /* Unknown */ ? assumeNewLineBeforeCloseBrace && nextTokenKind === 2 /* CloseBrace */ ? options.indentSize : 0 : lineAtPosition !== currentStart.line ? options.indentSize : 0;
-              return getIndentationForNodeWorker(
-                current,
-                currentStart,
-                /*ignoreActualIndentationRange*/
+            );
+            const { response, responseRequired } = this.executeCommand(request);
+            (_d = tracing) == null ? void 0 : _d.pop();
+            if (this.logger.hasLevel(2 /* requestTime */)) {
+              const elapsedTime = hrTimeToMilliseconds(this.hrtime(start)).toFixed(4);
+              if (responseRequired) {
+                this.logger.perftrc(`${request.seq}::${request.command}: elapsed time (in milliseconds) ${elapsedTime}`);
+              } else {
+                this.logger.perftrc(`${request.seq}::${request.command}: async elapsed time (in milliseconds) ${elapsedTime}`);
+              }
+            }
+            (_e = perfLogger) == null ? void 0 : _e.logStopCommand("" + request.command, "Success");
+            (_f = tracing) == null ? void 0 : _f.instant(tracing.Phase.Session, "response", { seq: request.seq, command: request.command, success: !!response });
+            if (response) {
+              this.doOutput(
+                response,
+                request.command,
+                request.seq,
+                /*success*/
+                true
+              );
+            } else if (responseRequired) {
+              this.doOutput(
+                /*info*/
                 void 0,
-                indentationDelta,
-                sourceFile,
-                /*isNextChild*/
-                true,
-                options
+                request.command,
+                request.seq,
+                /*success*/
+                false,
+                "No content available."
               );
             }
-            const actualIndentation = getActualIndentationForListItem(
-              current,
-              sourceFile,
-              options,
-              /*listIndentsChild*/
-              true
-            );
-            if (actualIndentation !== -1 /* Unknown */) {
-              return actualIndentation;
+          } catch (err) {
+            (_g = tracing) == null ? void 0 : _g.popAll();
+            if (err instanceof OperationCanceledException) {
+              (_h = perfLogger) == null ? void 0 : _h.logStopCommand("" + (request && request.command), "Canceled: " + err);
+              (_i = tracing) == null ? void 0 : _i.instant(tracing.Phase.Session, "commandCanceled", { seq: request == null ? void 0 : request.seq, command: request == null ? void 0 : request.command });
+              this.doOutput(
+                { canceled: true },
+                request.command,
+                request.seq,
+                /*success*/
+                true
+              );
+              return;
             }
-            previous = current;
-            current = current.parent;
+            this.logErrorWorker(err, this.toStringMessage(message), relevantFile);
+            (_j = perfLogger) == null ? void 0 : _j.logStopCommand("" + (request && request.command), "Error: " + err);
+            (_k = tracing) == null ? void 0 : _k.instant(tracing.Phase.Session, "commandError", { seq: request == null ? void 0 : request.seq, command: request == null ? void 0 : request.command, message: err.message });
+            this.doOutput(
+              /*info*/
+              void 0,
+              request ? request.command : "unknown" /* Unknown */,
+              request ? request.seq : 0,
+              /*success*/
+              false,
+              "Error processing request. " + err.message + "\n" + err.stack
+            );
           }
-          return getBaseIndentation(options);
         }
-        function getIndentationForNode(n, ignoreActualIndentationRange, sourceFile, options) {
-          const start = sourceFile.getLineAndCharacterOfPosition(n.getStart(sourceFile));
-          return getIndentationForNodeWorker(
-            n,
-            start,
-            ignoreActualIndentationRange,
-            /*indentationDelta*/
-            0,
-            sourceFile,
-            /*isNextChild*/
-            false,
-            options
-          );
+        parseMessage(message) {
+          return JSON.parse(message);
         }
-        SmartIndenter2.getIndentationForNode = getIndentationForNode;
-        function getBaseIndentation(options) {
-          return options.baseIndentSize || 0;
+        toStringMessage(message) {
+          return message;
         }
-        SmartIndenter2.getBaseIndentation = getBaseIndentation;
-        function getIndentationForNodeWorker(current, currentStart, ignoreActualIndentationRange, indentationDelta, sourceFile, isNextChild, options) {
-          var _a;
-          let parent2 = current.parent;
-          while (parent2) {
-            let useActualIndentation = true;
-            if (ignoreActualIndentationRange) {
-              const start = current.getStart(sourceFile);
-              useActualIndentation = start < ignoreActualIndentationRange.pos || start > ignoreActualIndentationRange.end;
+        getFormatOptions(file) {
+          return this.projectService.getFormatCodeOptions(file);
+        }
+        getPreferences(file) {
+          return this.projectService.getPreferences(file);
+        }
+        getHostFormatOptions() {
+          return this.projectService.getHostFormatCodeOptions();
+        }
+        getHostPreferences() {
+          return this.projectService.getHostPreferences();
+        }
+      };
+    }
+  });
+
+  // src/server/scriptVersionCache.ts
+  var lineCollectionCapacity, CharRangeSection, EditWalker, TextChange9, _ScriptVersionCache, ScriptVersionCache, LineIndexSnapshot, LineIndex, LineNode, LineLeaf;
+  var init_scriptVersionCache = __esm({
+    "src/server/scriptVersionCache.ts"() {
+      "use strict";
+      init_ts7();
+      init_ts_server3();
+      lineCollectionCapacity = 4;
+      CharRangeSection = /* @__PURE__ */ ((CharRangeSection2) => {
+        CharRangeSection2[CharRangeSection2["PreStart"] = 0] = "PreStart";
+        CharRangeSection2[CharRangeSection2["Start"] = 1] = "Start";
+        CharRangeSection2[CharRangeSection2["Entire"] = 2] = "Entire";
+        CharRangeSection2[CharRangeSection2["Mid"] = 3] = "Mid";
+        CharRangeSection2[CharRangeSection2["End"] = 4] = "End";
+        CharRangeSection2[CharRangeSection2["PostEnd"] = 5] = "PostEnd";
+        return CharRangeSection2;
+      })(CharRangeSection || {});
+      EditWalker = class {
+        constructor() {
+          this.goSubtree = true;
+          this.lineIndex = new LineIndex();
+          this.endBranch = [];
+          this.state = 2 /* Entire */;
+          this.initialText = "";
+          this.trailingText = "";
+          this.lineIndex.root = new LineNode();
+          this.startPath = [this.lineIndex.root];
+          this.stack = [this.lineIndex.root];
+        }
+        get done() {
+          return false;
+        }
+        insertLines(insertedText, suppressTrailingText) {
+          if (suppressTrailingText) {
+            this.trailingText = "";
+          }
+          if (insertedText) {
+            insertedText = this.initialText + insertedText + this.trailingText;
+          } else {
+            insertedText = this.initialText + this.trailingText;
+          }
+          const lm = LineIndex.linesFromText(insertedText);
+          const lines = lm.lines;
+          if (lines.length > 1 && lines[lines.length - 1] === "") {
+            lines.pop();
+          }
+          let branchParent;
+          let lastZeroCount;
+          for (let k = this.endBranch.length - 1; k >= 0; k--) {
+            this.endBranch[k].updateCounts();
+            if (this.endBranch[k].charCount() === 0) {
+              lastZeroCount = this.endBranch[k];
+              if (k > 0) {
+                branchParent = this.endBranch[k - 1];
+              } else {
+                branchParent = this.branchNode;
+              }
             }
-            const containingListOrParentStart = getContainingListOrParentStart(parent2, current, sourceFile);
-            const parentAndChildShareLine = containingListOrParentStart.line === currentStart.line || childStartsOnTheSameLineWithElseInIfStatement(parent2, current, currentStart.line, sourceFile);
-            if (useActualIndentation) {
-              const firstListChild = (_a = getContainingList(current, sourceFile)) == null ? void 0 : _a[0];
-              const listIndentsChild = !!firstListChild && getStartLineAndCharacterForNode(firstListChild, sourceFile).line > containingListOrParentStart.line;
-              let actualIndentation = getActualIndentationForListItem(current, sourceFile, options, listIndentsChild);
-              if (actualIndentation !== -1 /* Unknown */) {
-                return actualIndentation + indentationDelta;
+          }
+          if (lastZeroCount) {
+            branchParent.remove(lastZeroCount);
+          }
+          const leafNode = this.startPath[this.startPath.length - 1];
+          if (lines.length > 0) {
+            leafNode.text = lines[0];
+            if (lines.length > 1) {
+              let insertedNodes = new Array(lines.length - 1);
+              let startNode2 = leafNode;
+              for (let i = 1; i < lines.length; i++) {
+                insertedNodes[i - 1] = new LineLeaf(lines[i]);
               }
-              actualIndentation = getActualIndentationForNode(current, parent2, currentStart, parentAndChildShareLine, sourceFile, options);
-              if (actualIndentation !== -1 /* Unknown */) {
-                return actualIndentation + indentationDelta;
+              let pathIndex = this.startPath.length - 2;
+              while (pathIndex >= 0) {
+                const insertionNode = this.startPath[pathIndex];
+                insertedNodes = insertionNode.insertAt(startNode2, insertedNodes);
+                pathIndex--;
+                startNode2 = insertionNode;
+              }
+              let insertedNodesLen = insertedNodes.length;
+              while (insertedNodesLen > 0) {
+                const newRoot = new LineNode();
+                newRoot.add(this.lineIndex.root);
+                insertedNodes = newRoot.insertAt(this.lineIndex.root, insertedNodes);
+                insertedNodesLen = insertedNodes.length;
+                this.lineIndex.root = newRoot;
+              }
+              this.lineIndex.root.updateCounts();
+            } else {
+              for (let j = this.startPath.length - 2; j >= 0; j--) {
+                this.startPath[j].updateCounts();
               }
             }
-            if (shouldIndentChildNode(options, parent2, current, sourceFile, isNextChild) && !parentAndChildShareLine) {
-              indentationDelta += options.indentSize;
-            }
-            const useTrueStart = isArgumentAndStartLineOverlapsExpressionBeingCalled(parent2, current, currentStart.line, sourceFile);
-            current = parent2;
-            parent2 = current.parent;
-            currentStart = useTrueStart ? sourceFile.getLineAndCharacterOfPosition(current.getStart(sourceFile)) : containingListOrParentStart;
+          } else {
+            const insertionNode = this.startPath[this.startPath.length - 2];
+            insertionNode.remove(leafNode);
+            for (let j = this.startPath.length - 2; j >= 0; j--) {
+              this.startPath[j].updateCounts();
+            }
+          }
+          return this.lineIndex;
+        }
+        post(_relativeStart, _relativeLength, lineCollection) {
+          if (lineCollection === this.lineCollectionAtBranch) {
+            this.state = 4 /* End */;
+          }
+          this.stack.pop();
+        }
+        pre(_relativeStart, _relativeLength, lineCollection, _parent, nodeType) {
+          const currentNode = this.stack[this.stack.length - 1];
+          if (this.state === 2 /* Entire */ && nodeType === 1 /* Start */) {
+            this.state = 1 /* Start */;
+            this.branchNode = currentNode;
+            this.lineCollectionAtBranch = lineCollection;
+          }
+          let child;
+          function fresh(node) {
+            if (node.isLeaf()) {
+              return new LineLeaf("");
+            } else
+              return new LineNode();
+          }
+          switch (nodeType) {
+            case 0 /* PreStart */:
+              this.goSubtree = false;
+              if (this.state !== 4 /* End */) {
+                currentNode.add(lineCollection);
+              }
+              break;
+            case 1 /* Start */:
+              if (this.state === 4 /* End */) {
+                this.goSubtree = false;
+              } else {
+                child = fresh(lineCollection);
+                currentNode.add(child);
+                this.startPath.push(child);
+              }
+              break;
+            case 2 /* Entire */:
+              if (this.state !== 4 /* End */) {
+                child = fresh(lineCollection);
+                currentNode.add(child);
+                this.startPath.push(child);
+              } else {
+                if (!lineCollection.isLeaf()) {
+                  child = fresh(lineCollection);
+                  currentNode.add(child);
+                  this.endBranch.push(child);
+                }
+              }
+              break;
+            case 3 /* Mid */:
+              this.goSubtree = false;
+              break;
+            case 4 /* End */:
+              if (this.state !== 4 /* End */) {
+                this.goSubtree = false;
+              } else {
+                if (!lineCollection.isLeaf()) {
+                  child = fresh(lineCollection);
+                  currentNode.add(child);
+                  this.endBranch.push(child);
+                }
+              }
+              break;
+            case 5 /* PostEnd */:
+              this.goSubtree = false;
+              if (this.state !== 1 /* Start */) {
+                currentNode.add(lineCollection);
+              }
+              break;
+          }
+          if (this.goSubtree) {
+            this.stack.push(child);
           }
-          return indentationDelta + getBaseIndentation(options);
-        }
-        function getContainingListOrParentStart(parent2, child, sourceFile) {
-          const containingList = getContainingList(child, sourceFile);
-          const startPos = containingList ? containingList.pos : parent2.getStart(sourceFile);
-          return sourceFile.getLineAndCharacterOfPosition(startPos);
         }
-        function getActualIndentationForListItemBeforeComma(commaToken, sourceFile, options) {
-          const commaItemInfo = findListItemInfo(commaToken);
-          if (commaItemInfo && commaItemInfo.listItemIndex > 0) {
-            return deriveActualIndentationFromList(commaItemInfo.list.getChildren(), commaItemInfo.listItemIndex - 1, sourceFile, options);
+        // just gather text from the leaves
+        leaf(relativeStart, relativeLength, ll) {
+          if (this.state === 1 /* Start */) {
+            this.initialText = ll.text.substring(0, relativeStart);
+          } else if (this.state === 2 /* Entire */) {
+            this.initialText = ll.text.substring(0, relativeStart);
+            this.trailingText = ll.text.substring(relativeStart + relativeLength);
           } else {
-            return -1 /* Unknown */;
+            this.trailingText = ll.text.substring(relativeStart + relativeLength);
           }
         }
-        function getActualIndentationForNode(current, parent2, currentLineAndChar, parentAndChildShareLine, sourceFile, options) {
-          const useActualIndentation = (isDeclaration(current) || isStatementButNotDeclaration(current)) && (parent2.kind === 311 /* SourceFile */ || !parentAndChildShareLine);
-          if (!useActualIndentation) {
-            return -1 /* Unknown */;
-          }
-          return findColumnForFirstNonWhitespaceCharacterInLine(currentLineAndChar, sourceFile, options);
+      };
+      TextChange9 = class {
+        constructor(pos, deleteLen, insertedText) {
+          this.pos = pos;
+          this.deleteLen = deleteLen;
+          this.insertedText = insertedText;
         }
-        let NextTokenKind;
-        ((NextTokenKind2) => {
-          NextTokenKind2[NextTokenKind2["Unknown"] = 0] = "Unknown";
-          NextTokenKind2[NextTokenKind2["OpenBrace"] = 1] = "OpenBrace";
-          NextTokenKind2[NextTokenKind2["CloseBrace"] = 2] = "CloseBrace";
-        })(NextTokenKind || (NextTokenKind = {}));
-        function nextTokenIsCurlyBraceOnSameLineAsCursor(precedingToken, current, lineAtPosition, sourceFile) {
-          const nextToken = findNextToken(precedingToken, current, sourceFile);
-          if (!nextToken) {
-            return 0 /* Unknown */;
-          }
-          if (nextToken.kind === 19 /* OpenBraceToken */) {
-            return 1 /* OpenBrace */;
-          } else if (nextToken.kind === 20 /* CloseBraceToken */) {
-            const nextTokenStartLine = getStartLineAndCharacterForNode(nextToken, sourceFile).line;
-            return lineAtPosition === nextTokenStartLine ? 2 /* CloseBrace */ : 0 /* Unknown */;
+        getTextChangeRange() {
+          return createTextChangeRange(createTextSpan(this.pos, this.deleteLen), this.insertedText ? this.insertedText.length : 0);
+        }
+      };
+      _ScriptVersionCache = class _ScriptVersionCache {
+        constructor() {
+          this.changes = [];
+          this.versions = new Array(_ScriptVersionCache.maxVersions);
+          this.minVersion = 0;
+          // no versions earlier than min version will maintain change history
+          this.currentVersion = 0;
+        }
+        versionToIndex(version2) {
+          if (version2 < this.minVersion || version2 > this.currentVersion) {
+            return void 0;
           }
-          return 0 /* Unknown */;
+          return version2 % _ScriptVersionCache.maxVersions;
         }
-        function getStartLineAndCharacterForNode(n, sourceFile) {
-          return sourceFile.getLineAndCharacterOfPosition(n.getStart(sourceFile));
+        currentVersionToIndex() {
+          return this.currentVersion % _ScriptVersionCache.maxVersions;
         }
-        function isArgumentAndStartLineOverlapsExpressionBeingCalled(parent2, child, childStartLine, sourceFile) {
-          if (!(isCallExpression(parent2) && contains(parent2.arguments, child))) {
-            return false;
+        // REVIEW: can optimize by coalescing simple edits
+        edit(pos, deleteLen, insertedText) {
+          this.changes.push(new TextChange9(pos, deleteLen, insertedText));
+          if (this.changes.length > _ScriptVersionCache.changeNumberThreshold || deleteLen > _ScriptVersionCache.changeLengthThreshold || insertedText && insertedText.length > _ScriptVersionCache.changeLengthThreshold) {
+            this.getSnapshot();
           }
-          const expressionOfCallExpressionEnd = parent2.expression.getEnd();
-          const expressionOfCallExpressionEndLine = getLineAndCharacterOfPosition(sourceFile, expressionOfCallExpressionEnd).line;
-          return expressionOfCallExpressionEndLine === childStartLine;
         }
-        SmartIndenter2.isArgumentAndStartLineOverlapsExpressionBeingCalled = isArgumentAndStartLineOverlapsExpressionBeingCalled;
-        function childStartsOnTheSameLineWithElseInIfStatement(parent2, child, childStartLine, sourceFile) {
-          if (parent2.kind === 244 /* IfStatement */ && parent2.elseStatement === child) {
-            const elseKeyword = findChildOfKind(parent2, 93 /* ElseKeyword */, sourceFile);
-            Debug.assert(elseKeyword !== void 0);
-            const elseKeywordStartLine = getStartLineAndCharacterForNode(elseKeyword, sourceFile).line;
-            return elseKeywordStartLine === childStartLine;
+        getSnapshot() {
+          return this._getSnapshot();
+        }
+        _getSnapshot() {
+          let snap = this.versions[this.currentVersionToIndex()];
+          if (this.changes.length > 0) {
+            let snapIndex = snap.index;
+            for (const change of this.changes) {
+              snapIndex = snapIndex.edit(change.pos, change.deleteLen, change.insertedText);
+            }
+            snap = new LineIndexSnapshot(this.currentVersion + 1, this, snapIndex, this.changes);
+            this.currentVersion = snap.version;
+            this.versions[this.currentVersionToIndex()] = snap;
+            this.changes = [];
+            if (this.currentVersion - this.minVersion >= _ScriptVersionCache.maxVersions) {
+              this.minVersion = this.currentVersion - _ScriptVersionCache.maxVersions + 1;
+            }
           }
-          return false;
+          return snap;
         }
-        SmartIndenter2.childStartsOnTheSameLineWithElseInIfStatement = childStartsOnTheSameLineWithElseInIfStatement;
-        function childIsUnindentedBranchOfConditionalExpression(parent2, child, childStartLine, sourceFile) {
-          if (isConditionalExpression(parent2) && (child === parent2.whenTrue || child === parent2.whenFalse)) {
-            const conditionEndLine = getLineAndCharacterOfPosition(sourceFile, parent2.condition.end).line;
-            if (child === parent2.whenTrue) {
-              return childStartLine === conditionEndLine;
+        getSnapshotVersion() {
+          return this._getSnapshot().version;
+        }
+        getAbsolutePositionAndLineText(oneBasedLine) {
+          return this._getSnapshot().index.lineNumberToInfo(oneBasedLine);
+        }
+        lineOffsetToPosition(line, column) {
+          return this._getSnapshot().index.absolutePositionOfStartOfLine(line) + (column - 1);
+        }
+        positionToLineOffset(position) {
+          return this._getSnapshot().index.positionToLineOffset(position);
+        }
+        lineToTextSpan(line) {
+          const index = this._getSnapshot().index;
+          const { lineText, absolutePosition } = index.lineNumberToInfo(line + 1);
+          const len = lineText !== void 0 ? lineText.length : index.absolutePositionOfStartOfLine(line + 2) - absolutePosition;
+          return createTextSpan(absolutePosition, len);
+        }
+        getTextChangesBetweenVersions(oldVersion, newVersion) {
+          if (oldVersion < newVersion) {
+            if (oldVersion >= this.minVersion) {
+              const textChangeRanges = [];
+              for (let i = oldVersion + 1; i <= newVersion; i++) {
+                const snap = this.versions[this.versionToIndex(i)];
+                for (const textChange of snap.changesSincePreviousVersion) {
+                  textChangeRanges.push(textChange.getTextChangeRange());
+                }
+              }
+              return collapseTextChangeRangesAcrossMultipleVersions(textChangeRanges);
             } else {
-              const trueStartLine = getStartLineAndCharacterForNode(parent2.whenTrue, sourceFile).line;
-              const trueEndLine = getLineAndCharacterOfPosition(sourceFile, parent2.whenTrue.end).line;
-              return conditionEndLine === trueStartLine && trueEndLine === childStartLine;
+              return void 0;
             }
+          } else {
+            return unchangedTextChangeRange;
           }
-          return false;
         }
-        SmartIndenter2.childIsUnindentedBranchOfConditionalExpression = childIsUnindentedBranchOfConditionalExpression;
-        function argumentStartsOnSameLineAsPreviousArgument(parent2, child, childStartLine, sourceFile) {
-          if (isCallOrNewExpression(parent2)) {
-            if (!parent2.arguments)
-              return false;
-            const currentNode = find(parent2.arguments, (arg) => arg.pos === child.pos);
-            if (!currentNode)
-              return false;
-            const currentIndex = parent2.arguments.indexOf(currentNode);
-            if (currentIndex === 0)
-              return false;
-            const previousNode = parent2.arguments[currentIndex - 1];
-            const lineOfPreviousNode = getLineAndCharacterOfPosition(sourceFile, previousNode.getEnd()).line;
-            if (childStartLine === lineOfPreviousNode) {
-              return true;
+        getLineCount() {
+          return this._getSnapshot().index.getLineCount();
+        }
+        static fromString(script) {
+          const svc = new _ScriptVersionCache();
+          const snap = new LineIndexSnapshot(0, svc, new LineIndex());
+          svc.versions[svc.currentVersion] = snap;
+          const lm = LineIndex.linesFromText(script);
+          snap.index.load(lm.lines);
+          return svc;
+        }
+      };
+      _ScriptVersionCache.changeNumberThreshold = 8;
+      _ScriptVersionCache.changeLengthThreshold = 256;
+      _ScriptVersionCache.maxVersions = 8;
+      ScriptVersionCache = _ScriptVersionCache;
+      LineIndexSnapshot = class _LineIndexSnapshot {
+        constructor(version2, cache, index, changesSincePreviousVersion = emptyArray2) {
+          this.version = version2;
+          this.cache = cache;
+          this.index = index;
+          this.changesSincePreviousVersion = changesSincePreviousVersion;
+        }
+        getText(rangeStart, rangeEnd) {
+          return this.index.getText(rangeStart, rangeEnd - rangeStart);
+        }
+        getLength() {
+          return this.index.getLength();
+        }
+        getChangeRange(oldSnapshot) {
+          if (oldSnapshot instanceof _LineIndexSnapshot && this.cache === oldSnapshot.cache) {
+            if (this.version <= oldSnapshot.version) {
+              return unchangedTextChangeRange;
+            } else {
+              return this.cache.getTextChangesBetweenVersions(oldSnapshot.version, this.version);
             }
           }
-          return false;
         }
-        SmartIndenter2.argumentStartsOnSameLineAsPreviousArgument = argumentStartsOnSameLineAsPreviousArgument;
-        function getContainingList(node, sourceFile) {
-          return node.parent && getListByRange(node.getStart(sourceFile), node.getEnd(), node.parent, sourceFile);
+      };
+      LineIndex = class _LineIndex {
+        constructor() {
+          // set this to true to check each edit for accuracy
+          this.checkEdits = false;
         }
-        SmartIndenter2.getContainingList = getContainingList;
-        function getListByPosition(pos, node, sourceFile) {
-          return node && getListByRange(pos, pos, node, sourceFile);
+        absolutePositionOfStartOfLine(oneBasedLine) {
+          return this.lineNumberToInfo(oneBasedLine).absolutePosition;
         }
-        function getListByRange(start, end, node, sourceFile) {
-          switch (node.kind) {
-            case 182 /* TypeReference */:
-              return getList(node.typeArguments);
-            case 209 /* ObjectLiteralExpression */:
-              return getList(node.properties);
-            case 208 /* ArrayLiteralExpression */:
-              return getList(node.elements);
-            case 186 /* TypeLiteral */:
-              return getList(node.members);
-            case 261 /* FunctionDeclaration */:
-            case 217 /* FunctionExpression */:
-            case 218 /* ArrowFunction */:
-            case 173 /* MethodDeclaration */:
-            case 172 /* MethodSignature */:
-            case 178 /* CallSignature */:
-            case 175 /* Constructor */:
-            case 184 /* ConstructorType */:
-            case 179 /* ConstructSignature */:
-              return getList(node.typeParameters) || getList(node.parameters);
-            case 176 /* GetAccessor */:
-              return getList(node.parameters);
-            case 262 /* ClassDeclaration */:
-            case 230 /* ClassExpression */:
-            case 263 /* InterfaceDeclaration */:
-            case 264 /* TypeAliasDeclaration */:
-            case 351 /* JSDocTemplateTag */:
-              return getList(node.typeParameters);
-            case 213 /* NewExpression */:
-            case 212 /* CallExpression */:
-              return getList(node.typeArguments) || getList(node.arguments);
-            case 260 /* VariableDeclarationList */:
-              return getList(node.declarations);
-            case 274 /* NamedImports */:
-            case 278 /* NamedExports */:
-              return getList(node.elements);
-            case 205 /* ObjectBindingPattern */:
-            case 206 /* ArrayBindingPattern */:
-              return getList(node.elements);
-          }
-          function getList(list) {
-            return list && rangeContainsStartEnd(getVisualListRange(node, list, sourceFile), start, end) ? list : void 0;
+        positionToLineOffset(position) {
+          const { oneBasedLine, zeroBasedColumn } = this.root.charOffsetToLineInfo(1, position);
+          return { line: oneBasedLine, offset: zeroBasedColumn + 1 };
+        }
+        positionToColumnAndLineText(position) {
+          return this.root.charOffsetToLineInfo(1, position);
+        }
+        getLineCount() {
+          return this.root.lineCount();
+        }
+        lineNumberToInfo(oneBasedLine) {
+          const lineCount = this.getLineCount();
+          if (oneBasedLine <= lineCount) {
+            const { position, leaf } = this.root.lineNumberToInfo(oneBasedLine, 0);
+            return { absolutePosition: position, lineText: leaf && leaf.text };
+          } else {
+            return { absolutePosition: this.root.charCount(), lineText: void 0 };
           }
         }
-        function getVisualListRange(node, list, sourceFile) {
-          const children = node.getChildren(sourceFile);
-          for (let i = 1; i < children.length - 1; i++) {
-            if (children[i].pos === list.pos && children[i].end === list.end) {
-              return { pos: children[i - 1].end, end: children[i + 1].getStart(sourceFile) };
+        load(lines) {
+          if (lines.length > 0) {
+            const leaves = [];
+            for (let i = 0; i < lines.length; i++) {
+              leaves[i] = new LineLeaf(lines[i]);
             }
+            this.root = _LineIndex.buildTreeFromBottom(leaves);
+          } else {
+            this.root = new LineNode();
           }
-          return list;
         }
-        function getActualIndentationForListStartLine(list, sourceFile, options) {
-          if (!list) {
-            return -1 /* Unknown */;
-          }
-          return findColumnForFirstNonWhitespaceCharacterInLine(sourceFile.getLineAndCharacterOfPosition(list.pos), sourceFile, options);
+        walk(rangeStart, rangeLength, walkFns) {
+          this.root.walk(rangeStart, rangeLength, walkFns);
         }
-        function getActualIndentationForListItem(node, sourceFile, options, listIndentsChild) {
-          if (node.parent && node.parent.kind === 260 /* VariableDeclarationList */) {
-            return -1 /* Unknown */;
+        getText(rangeStart, rangeLength) {
+          let accum = "";
+          if (rangeLength > 0 && rangeStart < this.root.charCount()) {
+            this.walk(rangeStart, rangeLength, {
+              goSubtree: true,
+              done: false,
+              leaf: (relativeStart, relativeLength, ll) => {
+                accum = accum.concat(ll.text.substring(relativeStart, relativeStart + relativeLength));
+              }
+            });
           }
-          const containingList = getContainingList(node, sourceFile);
-          if (containingList) {
-            const index = containingList.indexOf(node);
-            if (index !== -1) {
-              const result = deriveActualIndentationFromList(containingList, index, sourceFile, options);
-              if (result !== -1 /* Unknown */) {
-                return result;
+          return accum;
+        }
+        getLength() {
+          return this.root.charCount();
+        }
+        every(f, rangeStart, rangeEnd) {
+          if (!rangeEnd) {
+            rangeEnd = this.root.charCount();
+          }
+          const walkFns = {
+            goSubtree: true,
+            done: false,
+            leaf(relativeStart, relativeLength, ll) {
+              if (!f(ll, relativeStart, relativeLength)) {
+                this.done = true;
               }
             }
-            return getActualIndentationForListStartLine(containingList, sourceFile, options) + (listIndentsChild ? options.indentSize : 0);
-          }
-          return -1 /* Unknown */;
+          };
+          this.walk(rangeStart, rangeEnd - rangeStart, walkFns);
+          return !walkFns.done;
         }
-        function deriveActualIndentationFromList(list, index, sourceFile, options) {
-          Debug.assert(index >= 0 && index < list.length);
-          const node = list[index];
-          let lineAndCharacter = getStartLineAndCharacterForNode(node, sourceFile);
-          for (let i = index - 1; i >= 0; i--) {
-            if (list[i].kind === 28 /* CommaToken */) {
-              continue;
+        edit(pos, deleteLength, newText) {
+          if (this.root.charCount() === 0) {
+            Debug.assert(deleteLength === 0);
+            if (newText !== void 0) {
+              this.load(_LineIndex.linesFromText(newText).lines);
+              return this;
             }
-            const prevEndLine = sourceFile.getLineAndCharacterOfPosition(list[i].end).line;
-            if (prevEndLine !== lineAndCharacter.line) {
-              return findColumnForFirstNonWhitespaceCharacterInLine(lineAndCharacter, sourceFile, options);
+            return void 0;
+          } else {
+            let checkText;
+            if (this.checkEdits) {
+              const source = this.getText(0, this.root.charCount());
+              checkText = source.slice(0, pos) + newText + source.slice(pos + deleteLength);
+            }
+            const walker = new EditWalker();
+            let suppressTrailingText = false;
+            if (pos >= this.root.charCount()) {
+              pos = this.root.charCount() - 1;
+              const endString = this.getText(pos, 1);
+              if (newText) {
+                newText = endString + newText;
+              } else {
+                newText = endString;
+              }
+              deleteLength = 0;
+              suppressTrailingText = true;
+            } else if (deleteLength > 0) {
+              const e = pos + deleteLength;
+              const { zeroBasedColumn, lineText } = this.positionToColumnAndLineText(e);
+              if (zeroBasedColumn === 0) {
+                deleteLength += lineText.length;
+                newText = newText ? newText + lineText : lineText;
+              }
             }
-            lineAndCharacter = getStartLineAndCharacterForNode(list[i], sourceFile);
+            this.root.walk(pos, deleteLength, walker);
+            walker.insertLines(newText, suppressTrailingText);
+            if (this.checkEdits) {
+              const updatedText = walker.lineIndex.getText(0, walker.lineIndex.getLength());
+              Debug.assert(checkText === updatedText, "buffer edit mismatch");
+            }
+            return walker.lineIndex;
           }
-          return -1 /* Unknown */;
         }
-        function findColumnForFirstNonWhitespaceCharacterInLine(lineAndCharacter, sourceFile, options) {
-          const lineStart = sourceFile.getPositionOfLineAndCharacter(lineAndCharacter.line, 0);
-          return findFirstNonWhitespaceColumn(lineStart, lineStart + lineAndCharacter.character, sourceFile, options);
+        static buildTreeFromBottom(nodes) {
+          if (nodes.length < lineCollectionCapacity) {
+            return new LineNode(nodes);
+          }
+          const interiorNodes = new Array(Math.ceil(nodes.length / lineCollectionCapacity));
+          let nodeIndex = 0;
+          for (let i = 0; i < interiorNodes.length; i++) {
+            const end = Math.min(nodeIndex + lineCollectionCapacity, nodes.length);
+            interiorNodes[i] = new LineNode(nodes.slice(nodeIndex, end));
+            nodeIndex = end;
+          }
+          return this.buildTreeFromBottom(interiorNodes);
         }
-        function findFirstNonWhitespaceCharacterAndColumn(startPos, endPos, sourceFile, options) {
-          let character = 0;
-          let column = 0;
-          for (let pos = startPos; pos < endPos; pos++) {
-            const ch = sourceFile.text.charCodeAt(pos);
-            if (!isWhiteSpaceSingleLine(ch)) {
-              break;
-            }
-            if (ch === 9 /* tab */) {
-              column += options.tabSize + column % options.tabSize;
-            } else {
-              column++;
+        static linesFromText(text) {
+          const lineMap = computeLineStarts(text);
+          if (lineMap.length === 0) {
+            return { lines: [], lineMap };
+          }
+          const lines = new Array(lineMap.length);
+          const lc = lineMap.length - 1;
+          for (let lmi = 0; lmi < lc; lmi++) {
+            lines[lmi] = text.substring(lineMap[lmi], lineMap[lmi + 1]);
+          }
+          const endText = text.substring(lineMap[lc]);
+          if (endText.length > 0) {
+            lines[lc] = endText;
+          } else {
+            lines.pop();
+          }
+          return { lines, lineMap };
+        }
+      };
+      LineNode = class _LineNode {
+        constructor(children = []) {
+          this.children = children;
+          this.totalChars = 0;
+          this.totalLines = 0;
+          if (children.length)
+            this.updateCounts();
+        }
+        isLeaf() {
+          return false;
+        }
+        updateCounts() {
+          this.totalChars = 0;
+          this.totalLines = 0;
+          for (const child of this.children) {
+            this.totalChars += child.charCount();
+            this.totalLines += child.lineCount();
+          }
+        }
+        execWalk(rangeStart, rangeLength, walkFns, childIndex, nodeType) {
+          if (walkFns.pre) {
+            walkFns.pre(rangeStart, rangeLength, this.children[childIndex], this, nodeType);
+          }
+          if (walkFns.goSubtree) {
+            this.children[childIndex].walk(rangeStart, rangeLength, walkFns);
+            if (walkFns.post) {
+              walkFns.post(rangeStart, rangeLength, this.children[childIndex], this, nodeType);
             }
-            character++;
+          } else {
+            walkFns.goSubtree = true;
           }
-          return { column, character };
+          return walkFns.done;
         }
-        SmartIndenter2.findFirstNonWhitespaceCharacterAndColumn = findFirstNonWhitespaceCharacterAndColumn;
-        function findFirstNonWhitespaceColumn(startPos, endPos, sourceFile, options) {
-          return findFirstNonWhitespaceCharacterAndColumn(startPos, endPos, sourceFile, options).column;
+        skipChild(relativeStart, relativeLength, childIndex, walkFns, nodeType) {
+          if (walkFns.pre && !walkFns.done) {
+            walkFns.pre(relativeStart, relativeLength, this.children[childIndex], this, nodeType);
+            walkFns.goSubtree = true;
+          }
         }
-        SmartIndenter2.findFirstNonWhitespaceColumn = findFirstNonWhitespaceColumn;
-        function nodeWillIndentChild(settings, parent2, child, sourceFile, indentByDefault) {
-          const childKind = child ? child.kind : 0 /* Unknown */;
-          switch (parent2.kind) {
-            case 243 /* ExpressionStatement */:
-            case 262 /* ClassDeclaration */:
-            case 230 /* ClassExpression */:
-            case 263 /* InterfaceDeclaration */:
-            case 265 /* EnumDeclaration */:
-            case 264 /* TypeAliasDeclaration */:
-            case 208 /* ArrayLiteralExpression */:
-            case 240 /* Block */:
-            case 267 /* ModuleBlock */:
-            case 209 /* ObjectLiteralExpression */:
-            case 186 /* TypeLiteral */:
-            case 199 /* MappedType */:
-            case 188 /* TupleType */:
-            case 216 /* ParenthesizedExpression */:
-            case 210 /* PropertyAccessExpression */:
-            case 212 /* CallExpression */:
-            case 213 /* NewExpression */:
-            case 242 /* VariableStatement */:
-            case 276 /* ExportAssignment */:
-            case 252 /* ReturnStatement */:
-            case 226 /* ConditionalExpression */:
-            case 206 /* ArrayBindingPattern */:
-            case 205 /* ObjectBindingPattern */:
-            case 285 /* JsxOpeningElement */:
-            case 288 /* JsxOpeningFragment */:
-            case 284 /* JsxSelfClosingElement */:
-            case 293 /* JsxExpression */:
-            case 172 /* MethodSignature */:
-            case 178 /* CallSignature */:
-            case 179 /* ConstructSignature */:
-            case 168 /* Parameter */:
-            case 183 /* FunctionType */:
-            case 184 /* ConstructorType */:
-            case 195 /* ParenthesizedType */:
-            case 214 /* TaggedTemplateExpression */:
-            case 222 /* AwaitExpression */:
-            case 278 /* NamedExports */:
-            case 274 /* NamedImports */:
-            case 280 /* ExportSpecifier */:
-            case 275 /* ImportSpecifier */:
-            case 171 /* PropertyDeclaration */:
-            case 295 /* CaseClause */:
-            case 296 /* DefaultClause */:
-              return true;
-            case 268 /* CaseBlock */:
-              return settings.indentSwitchCase ?? true;
-            case 259 /* VariableDeclaration */:
-            case 302 /* PropertyAssignment */:
-            case 225 /* BinaryExpression */:
-              if (!settings.indentMultiLineObjectLiteralBeginningOnBlankLine && sourceFile && childKind === 209 /* ObjectLiteralExpression */) {
-                return rangeIsOnOneLine(sourceFile, child);
-              }
-              if (parent2.kind === 225 /* BinaryExpression */ && sourceFile && child && childKind === 283 /* JsxElement */) {
-                const parentStartLine = sourceFile.getLineAndCharacterOfPosition(skipTrivia(sourceFile.text, parent2.pos)).line;
-                const childStartLine = sourceFile.getLineAndCharacterOfPosition(skipTrivia(sourceFile.text, child.pos)).line;
-                return parentStartLine !== childStartLine;
+        walk(rangeStart, rangeLength, walkFns) {
+          let childIndex = 0;
+          let childCharCount = this.children[childIndex].charCount();
+          let adjustedStart = rangeStart;
+          while (adjustedStart >= childCharCount) {
+            this.skipChild(adjustedStart, rangeLength, childIndex, walkFns, 0 /* PreStart */);
+            adjustedStart -= childCharCount;
+            childIndex++;
+            childCharCount = this.children[childIndex].charCount();
+          }
+          if (adjustedStart + rangeLength <= childCharCount) {
+            if (this.execWalk(adjustedStart, rangeLength, walkFns, childIndex, 2 /* Entire */)) {
+              return;
+            }
+          } else {
+            if (this.execWalk(adjustedStart, childCharCount - adjustedStart, walkFns, childIndex, 1 /* Start */)) {
+              return;
+            }
+            let adjustedLength = rangeLength - (childCharCount - adjustedStart);
+            childIndex++;
+            const child = this.children[childIndex];
+            childCharCount = child.charCount();
+            while (adjustedLength > childCharCount) {
+              if (this.execWalk(0, childCharCount, walkFns, childIndex, 3 /* Mid */)) {
+                return;
               }
-              if (parent2.kind !== 225 /* BinaryExpression */) {
-                return true;
+              adjustedLength -= childCharCount;
+              childIndex++;
+              childCharCount = this.children[childIndex].charCount();
+            }
+            if (adjustedLength > 0) {
+              if (this.execWalk(0, adjustedLength, walkFns, childIndex, 4 /* End */)) {
+                return;
               }
-              break;
-            case 245 /* DoStatement */:
-            case 246 /* WhileStatement */:
-            case 248 /* ForInStatement */:
-            case 249 /* ForOfStatement */:
-            case 247 /* ForStatement */:
-            case 244 /* IfStatement */:
-            case 261 /* FunctionDeclaration */:
-            case 217 /* FunctionExpression */:
-            case 173 /* MethodDeclaration */:
-            case 175 /* Constructor */:
-            case 176 /* GetAccessor */:
-            case 177 /* SetAccessor */:
-              return childKind !== 240 /* Block */;
-            case 218 /* ArrowFunction */:
-              if (sourceFile && childKind === 216 /* ParenthesizedExpression */) {
-                return rangeIsOnOneLine(sourceFile, child);
+            }
+          }
+          if (walkFns.pre) {
+            const clen = this.children.length;
+            if (childIndex < clen - 1) {
+              for (let ej = childIndex + 1; ej < clen; ej++) {
+                this.skipChild(0, 0, ej, walkFns, 5 /* PostEnd */);
               }
-              return childKind !== 240 /* Block */;
-            case 277 /* ExportDeclaration */:
-              return childKind !== 278 /* NamedExports */;
-            case 271 /* ImportDeclaration */:
-              return childKind !== 272 /* ImportClause */ || !!child.namedBindings && child.namedBindings.kind !== 274 /* NamedImports */;
-            case 283 /* JsxElement */:
-              return childKind !== 286 /* JsxClosingElement */;
-            case 287 /* JsxFragment */:
-              return childKind !== 289 /* JsxClosingFragment */;
-            case 192 /* IntersectionType */:
-            case 191 /* UnionType */:
-              if (childKind === 186 /* TypeLiteral */ || childKind === 188 /* TupleType */) {
-                return false;
+            }
+          }
+        }
+        // Input position is relative to the start of this node.
+        // Output line number is absolute.
+        charOffsetToLineInfo(lineNumberAccumulator, relativePosition) {
+          if (this.children.length === 0) {
+            return { oneBasedLine: lineNumberAccumulator, zeroBasedColumn: relativePosition, lineText: void 0 };
+          }
+          for (const child of this.children) {
+            if (child.charCount() > relativePosition) {
+              if (child.isLeaf()) {
+                return { oneBasedLine: lineNumberAccumulator, zeroBasedColumn: relativePosition, lineText: child.text };
+              } else {
+                return child.charOffsetToLineInfo(lineNumberAccumulator, relativePosition);
               }
-              break;
+            } else {
+              relativePosition -= child.charCount();
+              lineNumberAccumulator += child.lineCount();
+            }
           }
-          return indentByDefault;
+          const lineCount = this.lineCount();
+          if (lineCount === 0) {
+            return { oneBasedLine: 1, zeroBasedColumn: 0, lineText: void 0 };
+          }
+          const leaf = Debug.checkDefined(this.lineNumberToInfo(lineCount, 0).leaf);
+          return { oneBasedLine: lineCount, zeroBasedColumn: leaf.charCount(), lineText: void 0 };
         }
-        SmartIndenter2.nodeWillIndentChild = nodeWillIndentChild;
-        function isControlFlowEndingStatement(kind, parent2) {
-          switch (kind) {
-            case 252 /* ReturnStatement */:
-            case 256 /* ThrowStatement */:
-            case 250 /* ContinueStatement */:
-            case 251 /* BreakStatement */:
-              return parent2.kind !== 240 /* Block */;
-            default:
-              return false;
+        /**
+         * Input line number is relative to the start of this node.
+         * Output line number is relative to the child.
+         * positionAccumulator will be an absolute position once relativeLineNumber reaches 0.
+         */
+        lineNumberToInfo(relativeOneBasedLine, positionAccumulator) {
+          for (const child of this.children) {
+            const childLineCount = child.lineCount();
+            if (childLineCount >= relativeOneBasedLine) {
+              return child.isLeaf() ? { position: positionAccumulator, leaf: child } : child.lineNumberToInfo(relativeOneBasedLine, positionAccumulator);
+            } else {
+              relativeOneBasedLine -= childLineCount;
+              positionAccumulator += child.charCount();
+            }
+          }
+          return { position: positionAccumulator, leaf: void 0 };
+        }
+        splitAfter(childIndex) {
+          let splitNode;
+          const clen = this.children.length;
+          childIndex++;
+          const endLength = childIndex;
+          if (childIndex < clen) {
+            splitNode = new _LineNode();
+            while (childIndex < clen) {
+              splitNode.add(this.children[childIndex]);
+              childIndex++;
+            }
+            splitNode.updateCounts();
+          }
+          this.children.length = endLength;
+          return splitNode;
+        }
+        remove(child) {
+          const childIndex = this.findChildIndex(child);
+          const clen = this.children.length;
+          if (childIndex < clen - 1) {
+            for (let i = childIndex; i < clen - 1; i++) {
+              this.children[i] = this.children[i + 1];
+            }
+          }
+          this.children.pop();
+        }
+        findChildIndex(child) {
+          const childIndex = this.children.indexOf(child);
+          Debug.assert(childIndex !== -1);
+          return childIndex;
+        }
+        insertAt(child, nodes) {
+          let childIndex = this.findChildIndex(child);
+          const clen = this.children.length;
+          const nodeCount = nodes.length;
+          if (clen < lineCollectionCapacity && childIndex === clen - 1 && nodeCount === 1) {
+            this.add(nodes[0]);
+            this.updateCounts();
+            return [];
+          } else {
+            const shiftNode = this.splitAfter(childIndex);
+            let nodeIndex = 0;
+            childIndex++;
+            while (childIndex < lineCollectionCapacity && nodeIndex < nodeCount) {
+              this.children[childIndex] = nodes[nodeIndex];
+              childIndex++;
+              nodeIndex++;
+            }
+            let splitNodes = [];
+            let splitNodeCount = 0;
+            if (nodeIndex < nodeCount) {
+              splitNodeCount = Math.ceil((nodeCount - nodeIndex) / lineCollectionCapacity);
+              splitNodes = new Array(splitNodeCount);
+              let splitNodeIndex = 0;
+              for (let i = 0; i < splitNodeCount; i++) {
+                splitNodes[i] = new _LineNode();
+              }
+              let splitNode = splitNodes[0];
+              while (nodeIndex < nodeCount) {
+                splitNode.add(nodes[nodeIndex]);
+                nodeIndex++;
+                if (splitNode.children.length === lineCollectionCapacity) {
+                  splitNodeIndex++;
+                  splitNode = splitNodes[splitNodeIndex];
+                }
+              }
+              for (let i = splitNodes.length - 1; i >= 0; i--) {
+                if (splitNodes[i].children.length === 0) {
+                  splitNodes.pop();
+                }
+              }
+            }
+            if (shiftNode) {
+              splitNodes.push(shiftNode);
+            }
+            this.updateCounts();
+            for (let i = 0; i < splitNodeCount; i++) {
+              splitNodes[i].updateCounts();
+            }
+            return splitNodes;
           }
         }
-        function shouldIndentChildNode(settings, parent2, child, sourceFile, isNextChild = false) {
-          return nodeWillIndentChild(
-            settings,
-            parent2,
-            child,
-            sourceFile,
-            /*indentByDefault*/
-            false
-          ) && !(isNextChild && child && isControlFlowEndingStatement(child.kind, parent2));
+        // assume there is room for the item; return true if more room
+        add(collection) {
+          this.children.push(collection);
+          Debug.assert(this.children.length <= lineCollectionCapacity);
         }
-        SmartIndenter2.shouldIndentChildNode = shouldIndentChildNode;
-        function rangeIsOnOneLine(sourceFile, range) {
-          const rangeStart = skipTrivia(sourceFile.text, range.pos);
-          const startLine = sourceFile.getLineAndCharacterOfPosition(rangeStart).line;
-          const endLine = sourceFile.getLineAndCharacterOfPosition(range.end).line;
-          return startLine === endLine;
+        charCount() {
+          return this.totalChars;
         }
-      })(SmartIndenter || (SmartIndenter = {}));
+        lineCount() {
+          return this.totalLines;
+        }
+      };
+      LineLeaf = class {
+        constructor(text) {
+          this.text = text;
+        }
+        isLeaf() {
+          return true;
+        }
+        walk(rangeStart, rangeLength, walkFns) {
+          walkFns.leaf(rangeStart, rangeLength, this);
+        }
+        charCount() {
+          return this.text.length;
+        }
+        lineCount() {
+          return 1;
+        }
+      };
     }
   });
 
-  // src/services/_namespaces/ts.formatting.ts
-  var ts_formatting_exports = {};
-  __export(ts_formatting_exports, {
-    FormattingContext: () => FormattingContext,
-    FormattingRequestKind: () => FormattingRequestKind,
-    RuleAction: () => RuleAction,
-    RuleFlags: () => RuleFlags,
-    SmartIndenter: () => SmartIndenter,
-    anyContext: () => anyContext,
-    createTextRangeWithKind: () => createTextRangeWithKind,
-    formatDocument: () => formatDocument,
-    formatNodeGivenIndentation: () => formatNodeGivenIndentation,
-    formatOnClosingCurly: () => formatOnClosingCurly,
-    formatOnEnter: () => formatOnEnter,
-    formatOnOpeningCurly: () => formatOnOpeningCurly,
-    formatOnSemicolon: () => formatOnSemicolon,
-    formatSelection: () => formatSelection,
-    getAllRules: () => getAllRules,
-    getFormatContext: () => getFormatContext,
-    getFormattingScanner: () => getFormattingScanner,
-    getIndentationString: () => getIndentationString,
-    getRangeOfEnclosingComment: () => getRangeOfEnclosingComment
+  // src/server/_namespaces/ts.server.ts
+  var ts_server_exports3 = {};
+  __export(ts_server_exports3, {
+    ActionInvalidate: () => ActionInvalidate,
+    ActionPackageInstalled: () => ActionPackageInstalled,
+    ActionSet: () => ActionSet,
+    ActionWatchTypingLocations: () => ActionWatchTypingLocations,
+    Arguments: () => Arguments,
+    AutoImportProviderProject: () => AutoImportProviderProject,
+    AuxiliaryProject: () => AuxiliaryProject,
+    CharRangeSection: () => CharRangeSection,
+    CloseFileWatcherEvent: () => CloseFileWatcherEvent,
+    CommandNames: () => CommandNames,
+    ConfigFileDiagEvent: () => ConfigFileDiagEvent,
+    ConfiguredProject: () => ConfiguredProject2,
+    CreateDirectoryWatcherEvent: () => CreateDirectoryWatcherEvent,
+    CreateFileWatcherEvent: () => CreateFileWatcherEvent,
+    Errors: () => Errors,
+    EventBeginInstallTypes: () => EventBeginInstallTypes,
+    EventEndInstallTypes: () => EventEndInstallTypes,
+    EventInitializationFailed: () => EventInitializationFailed,
+    EventTypesRegistry: () => EventTypesRegistry,
+    ExternalProject: () => ExternalProject2,
+    GcTimer: () => GcTimer,
+    InferredProject: () => InferredProject2,
+    LargeFileReferencedEvent: () => LargeFileReferencedEvent,
+    LineIndex: () => LineIndex,
+    LineLeaf: () => LineLeaf,
+    LineNode: () => LineNode,
+    LogLevel: () => LogLevel2,
+    Msg: () => Msg,
+    OpenFileInfoTelemetryEvent: () => OpenFileInfoTelemetryEvent,
+    Project: () => Project3,
+    ProjectInfoTelemetryEvent: () => ProjectInfoTelemetryEvent,
+    ProjectKind: () => ProjectKind,
+    ProjectLanguageServiceStateEvent: () => ProjectLanguageServiceStateEvent,
+    ProjectLoadingFinishEvent: () => ProjectLoadingFinishEvent,
+    ProjectLoadingStartEvent: () => ProjectLoadingStartEvent,
+    ProjectReferenceProjectLoadKind: () => ProjectReferenceProjectLoadKind,
+    ProjectService: () => ProjectService3,
+    ProjectsUpdatedInBackgroundEvent: () => ProjectsUpdatedInBackgroundEvent,
+    ScriptInfo: () => ScriptInfo,
+    ScriptVersionCache: () => ScriptVersionCache,
+    Session: () => Session3,
+    TextStorage: () => TextStorage,
+    ThrottledOperations: () => ThrottledOperations,
+    TypingsCache: () => TypingsCache,
+    allFilesAreJsOrDts: () => allFilesAreJsOrDts,
+    allRootFilesAreJsOrDts: () => allRootFilesAreJsOrDts,
+    asNormalizedPath: () => asNormalizedPath,
+    convertCompilerOptions: () => convertCompilerOptions,
+    convertFormatOptions: () => convertFormatOptions,
+    convertScriptKindName: () => convertScriptKindName,
+    convertTypeAcquisition: () => convertTypeAcquisition,
+    convertUserPreferences: () => convertUserPreferences,
+    convertWatchOptions: () => convertWatchOptions,
+    countEachFileTypes: () => countEachFileTypes,
+    createInstallTypingsRequest: () => createInstallTypingsRequest,
+    createModuleSpecifierCache: () => createModuleSpecifierCache,
+    createNormalizedPathMap: () => createNormalizedPathMap,
+    createPackageJsonCache: () => createPackageJsonCache,
+    createSortedArray: () => createSortedArray2,
+    emptyArray: () => emptyArray2,
+    findArgument: () => findArgument,
+    forEachResolvedProjectReferenceProject: () => forEachResolvedProjectReferenceProject,
+    formatDiagnosticToProtocol: () => formatDiagnosticToProtocol,
+    formatMessage: () => formatMessage2,
+    getBaseConfigFileName: () => getBaseConfigFileName,
+    getLocationInNewDocument: () => getLocationInNewDocument,
+    hasArgument: () => hasArgument,
+    hasNoTypeScriptSource: () => hasNoTypeScriptSource,
+    indent: () => indent2,
+    isBackgroundProject: () => isBackgroundProject,
+    isConfigFile: () => isConfigFile,
+    isConfiguredProject: () => isConfiguredProject,
+    isDynamicFileName: () => isDynamicFileName,
+    isExternalProject: () => isExternalProject,
+    isInferredProject: () => isInferredProject,
+    isInferredProjectName: () => isInferredProjectName,
+    makeAutoImportProviderProjectName: () => makeAutoImportProviderProjectName,
+    makeAuxiliaryProjectName: () => makeAuxiliaryProjectName,
+    makeInferredProjectName: () => makeInferredProjectName,
+    maxFileSize: () => maxFileSize,
+    maxProgramSizeForNonTsFiles: () => maxProgramSizeForNonTsFiles,
+    normalizedPathToPath: () => normalizedPathToPath,
+    nowString: () => nowString,
+    nullCancellationToken: () => nullCancellationToken,
+    nullTypingsInstaller: () => nullTypingsInstaller,
+    projectContainsInfoDirectly: () => projectContainsInfoDirectly,
+    protocol: () => ts_server_protocol_exports,
+    removeSorted: () => removeSorted,
+    stringifyIndented: () => stringifyIndented,
+    toEvent: () => toEvent,
+    toNormalizedPath: () => toNormalizedPath,
+    tryConvertScriptKindName: () => tryConvertScriptKindName,
+    typingsInstaller: () => ts_server_typingsInstaller_exports,
+    updateProjectIfDirty: () => updateProjectIfDirty
   });
-  var init_ts_formatting = __esm({
-    "src/services/_namespaces/ts.formatting.ts"() {
+  var init_ts_server3 = __esm({
+    "src/server/_namespaces/ts.server.ts"() {
       "use strict";
-      init_formattingContext();
-      init_formattingScanner();
-      init_rule();
-      init_rules();
-      init_rulesMap();
-      init_formatting();
-      init_smartIndenter();
+      init_ts_server();
+      init_ts_server2();
+      init_types4();
+      init_utilitiesPublic3();
+      init_utilities5();
+      init_ts_server_protocol();
+      init_scriptInfo();
+      init_typingsCache();
+      init_project();
+      init_editorServices();
+      init_moduleSpecifierCache();
+      init_packageJsonCache();
+      init_session();
+      init_scriptVersionCache();
     }
   });
-
-  // src/services/_namespaces/ts.ts
-  var init_ts4 = __esm({
-    "src/services/_namespaces/ts.ts"() {
+
+  // src/server/_namespaces/ts.ts
+  var ts_exports2 = {};
+  __export(ts_exports2, {
+    ANONYMOUS: () => ANONYMOUS,
+    AccessFlags: () => AccessFlags,
+    AssertionLevel: () => AssertionLevel,
+    AssignmentDeclarationKind: () => AssignmentDeclarationKind,
+    AssignmentKind: () => AssignmentKind,
+    Associativity: () => Associativity,
+    BreakpointResolver: () => ts_BreakpointResolver_exports,
+    BuilderFileEmit: () => BuilderFileEmit,
+    BuilderProgramKind: () => BuilderProgramKind,
+    BuilderState: () => BuilderState,
+    BundleFileSectionKind: () => BundleFileSectionKind,
+    CallHierarchy: () => ts_CallHierarchy_exports,
+    CharacterCodes: () => CharacterCodes,
+    CheckFlags: () => CheckFlags,
+    CheckMode: () => CheckMode,
+    ClassificationType: () => ClassificationType,
+    ClassificationTypeNames: () => ClassificationTypeNames,
+    CommentDirectiveType: () => CommentDirectiveType,
+    Comparison: () => Comparison,
+    CompletionInfoFlags: () => CompletionInfoFlags,
+    CompletionTriggerKind: () => CompletionTriggerKind,
+    Completions: () => ts_Completions_exports,
+    ContainerFlags: () => ContainerFlags,
+    ContextFlags: () => ContextFlags,
+    Debug: () => Debug,
+    DiagnosticCategory: () => DiagnosticCategory,
+    Diagnostics: () => Diagnostics,
+    DocumentHighlights: () => DocumentHighlights,
+    ElementFlags: () => ElementFlags,
+    EmitFlags: () => EmitFlags,
+    EmitHint: () => EmitHint,
+    EmitOnly: () => EmitOnly,
+    EndOfLineState: () => EndOfLineState,
+    EnumKind: () => EnumKind,
+    ExitStatus: () => ExitStatus,
+    ExportKind: () => ExportKind,
+    Extension: () => Extension,
+    ExternalEmitHelpers: () => ExternalEmitHelpers,
+    FileIncludeKind: () => FileIncludeKind,
+    FilePreprocessingDiagnosticsKind: () => FilePreprocessingDiagnosticsKind,
+    FileSystemEntryKind: () => FileSystemEntryKind,
+    FileWatcherEventKind: () => FileWatcherEventKind,
+    FindAllReferences: () => ts_FindAllReferences_exports,
+    FlattenLevel: () => FlattenLevel,
+    FlowFlags: () => FlowFlags,
+    ForegroundColorEscapeSequences: () => ForegroundColorEscapeSequences,
+    FunctionFlags: () => FunctionFlags,
+    GeneratedIdentifierFlags: () => GeneratedIdentifierFlags,
+    GetLiteralTextFlags: () => GetLiteralTextFlags,
+    GoToDefinition: () => ts_GoToDefinition_exports,
+    HighlightSpanKind: () => HighlightSpanKind,
+    IdentifierNameMap: () => IdentifierNameMap,
+    IdentifierNameMultiMap: () => IdentifierNameMultiMap,
+    ImportKind: () => ImportKind,
+    ImportsNotUsedAsValues: () => ImportsNotUsedAsValues,
+    IndentStyle: () => IndentStyle,
+    IndexFlags: () => IndexFlags,
+    IndexKind: () => IndexKind,
+    InferenceFlags: () => InferenceFlags,
+    InferencePriority: () => InferencePriority,
+    InlayHintKind: () => InlayHintKind,
+    InlayHints: () => ts_InlayHints_exports,
+    InternalEmitFlags: () => InternalEmitFlags,
+    InternalSymbolName: () => InternalSymbolName,
+    InvalidatedProjectKind: () => InvalidatedProjectKind,
+    JSDocParsingMode: () => JSDocParsingMode,
+    JsDoc: () => ts_JsDoc_exports,
+    JsTyping: () => ts_JsTyping_exports,
+    JsxEmit: () => JsxEmit,
+    JsxFlags: () => JsxFlags,
+    JsxReferenceKind: () => JsxReferenceKind,
+    LanguageServiceMode: () => LanguageServiceMode,
+    LanguageVariant: () => LanguageVariant,
+    LexicalEnvironmentFlags: () => LexicalEnvironmentFlags,
+    ListFormat: () => ListFormat,
+    LogLevel: () => LogLevel,
+    MemberOverrideStatus: () => MemberOverrideStatus,
+    ModifierFlags: () => ModifierFlags,
+    ModuleDetectionKind: () => ModuleDetectionKind,
+    ModuleInstanceState: () => ModuleInstanceState,
+    ModuleKind: () => ModuleKind,
+    ModuleResolutionKind: () => ModuleResolutionKind,
+    ModuleSpecifierEnding: () => ModuleSpecifierEnding,
+    NavigateTo: () => ts_NavigateTo_exports,
+    NavigationBar: () => ts_NavigationBar_exports,
+    NewLineKind: () => NewLineKind,
+    NodeBuilderFlags: () => NodeBuilderFlags,
+    NodeCheckFlags: () => NodeCheckFlags,
+    NodeFactoryFlags: () => NodeFactoryFlags,
+    NodeFlags: () => NodeFlags,
+    NodeResolutionFeatures: () => NodeResolutionFeatures,
+    ObjectFlags: () => ObjectFlags,
+    OperationCanceledException: () => OperationCanceledException,
+    OperatorPrecedence: () => OperatorPrecedence,
+    OrganizeImports: () => ts_OrganizeImports_exports,
+    OrganizeImportsMode: () => OrganizeImportsMode,
+    OuterExpressionKinds: () => OuterExpressionKinds,
+    OutliningElementsCollector: () => ts_OutliningElementsCollector_exports,
+    OutliningSpanKind: () => OutliningSpanKind,
+    OutputFileType: () => OutputFileType,
+    PackageJsonAutoImportPreference: () => PackageJsonAutoImportPreference,
+    PackageJsonDependencyGroup: () => PackageJsonDependencyGroup,
+    PatternMatchKind: () => PatternMatchKind,
+    PollingInterval: () => PollingInterval,
+    PollingWatchKind: () => PollingWatchKind,
+    PragmaKindFlags: () => PragmaKindFlags,
+    PrivateIdentifierKind: () => PrivateIdentifierKind,
+    ProcessLevel: () => ProcessLevel,
+    ProgramUpdateLevel: () => ProgramUpdateLevel,
+    QuotePreference: () => QuotePreference,
+    RelationComparisonResult: () => RelationComparisonResult,
+    Rename: () => ts_Rename_exports,
+    ScriptElementKind: () => ScriptElementKind,
+    ScriptElementKindModifier: () => ScriptElementKindModifier,
+    ScriptKind: () => ScriptKind,
+    ScriptSnapshot: () => ScriptSnapshot,
+    ScriptTarget: () => ScriptTarget,
+    SemanticClassificationFormat: () => SemanticClassificationFormat,
+    SemanticMeaning: () => SemanticMeaning,
+    SemicolonPreference: () => SemicolonPreference,
+    SignatureCheckMode: () => SignatureCheckMode,
+    SignatureFlags: () => SignatureFlags,
+    SignatureHelp: () => ts_SignatureHelp_exports,
+    SignatureKind: () => SignatureKind,
+    SmartSelectionRange: () => ts_SmartSelectionRange_exports,
+    SnippetKind: () => SnippetKind,
+    SortKind: () => SortKind,
+    StructureIsReused: () => StructureIsReused,
+    SymbolAccessibility: () => SymbolAccessibility,
+    SymbolDisplay: () => ts_SymbolDisplay_exports,
+    SymbolDisplayPartKind: () => SymbolDisplayPartKind,
+    SymbolFlags: () => SymbolFlags,
+    SymbolFormatFlags: () => SymbolFormatFlags,
+    SyntaxKind: () => SyntaxKind,
+    SyntheticSymbolKind: () => SyntheticSymbolKind,
+    Ternary: () => Ternary,
+    ThrottledCancellationToken: () => ThrottledCancellationToken,
+    TokenClass: () => TokenClass,
+    TokenFlags: () => TokenFlags,
+    TransformFlags: () => TransformFlags,
+    TypeFacts: () => TypeFacts,
+    TypeFlags: () => TypeFlags,
+    TypeFormatFlags: () => TypeFormatFlags,
+    TypeMapKind: () => TypeMapKind,
+    TypePredicateKind: () => TypePredicateKind,
+    TypeReferenceSerializationKind: () => TypeReferenceSerializationKind,
+    UnionReduction: () => UnionReduction,
+    UpToDateStatusType: () => UpToDateStatusType,
+    VarianceFlags: () => VarianceFlags,
+    Version: () => Version,
+    VersionRange: () => VersionRange,
+    WatchDirectoryFlags: () => WatchDirectoryFlags,
+    WatchDirectoryKind: () => WatchDirectoryKind,
+    WatchFileKind: () => WatchFileKind,
+    WatchLogLevel: () => WatchLogLevel,
+    WatchType: () => WatchType,
+    accessPrivateIdentifier: () => accessPrivateIdentifier,
+    addDisposableResourceHelper: () => addDisposableResourceHelper,
+    addEmitFlags: () => addEmitFlags,
+    addEmitHelper: () => addEmitHelper,
+    addEmitHelpers: () => addEmitHelpers,
+    addInternalEmitFlags: () => addInternalEmitFlags,
+    addNodeFactoryPatcher: () => addNodeFactoryPatcher,
+    addObjectAllocatorPatcher: () => addObjectAllocatorPatcher,
+    addRange: () => addRange,
+    addRelatedInfo: () => addRelatedInfo,
+    addSyntheticLeadingComment: () => addSyntheticLeadingComment,
+    addSyntheticTrailingComment: () => addSyntheticTrailingComment,
+    addToSeen: () => addToSeen,
+    advancedAsyncSuperHelper: () => advancedAsyncSuperHelper,
+    affectsDeclarationPathOptionDeclarations: () => affectsDeclarationPathOptionDeclarations,
+    affectsEmitOptionDeclarations: () => affectsEmitOptionDeclarations,
+    allKeysStartWithDot: () => allKeysStartWithDot,
+    altDirectorySeparator: () => altDirectorySeparator,
+    and: () => and,
+    append: () => append,
+    appendIfUnique: () => appendIfUnique,
+    arrayFrom: () => arrayFrom,
+    arrayIsEqualTo: () => arrayIsEqualTo,
+    arrayIsHomogeneous: () => arrayIsHomogeneous,
+    arrayIsSorted: () => arrayIsSorted,
+    arrayOf: () => arrayOf,
+    arrayReverseIterator: () => arrayReverseIterator,
+    arrayToMap: () => arrayToMap,
+    arrayToMultiMap: () => arrayToMultiMap,
+    arrayToNumericMap: () => arrayToNumericMap,
+    arraysEqual: () => arraysEqual,
+    assertType: () => assertType,
+    assign: () => assign,
+    assignHelper: () => assignHelper,
+    asyncDelegator: () => asyncDelegator,
+    asyncGeneratorHelper: () => asyncGeneratorHelper,
+    asyncSuperHelper: () => asyncSuperHelper,
+    asyncValues: () => asyncValues,
+    attachFileToDiagnostics: () => attachFileToDiagnostics,
+    awaitHelper: () => awaitHelper,
+    awaiterHelper: () => awaiterHelper,
+    base64decode: () => base64decode,
+    base64encode: () => base64encode,
+    binarySearch: () => binarySearch,
+    binarySearchKey: () => binarySearchKey,
+    bindSourceFile: () => bindSourceFile,
+    breakIntoCharacterSpans: () => breakIntoCharacterSpans,
+    breakIntoWordSpans: () => breakIntoWordSpans,
+    buildLinkParts: () => buildLinkParts,
+    buildOpts: () => buildOpts,
+    buildOverload: () => buildOverload,
+    bundlerModuleNameResolver: () => bundlerModuleNameResolver,
+    canBeConvertedToAsync: () => canBeConvertedToAsync,
+    canHaveDecorators: () => canHaveDecorators,
+    canHaveExportModifier: () => canHaveExportModifier,
+    canHaveFlowNode: () => canHaveFlowNode,
+    canHaveIllegalDecorators: () => canHaveIllegalDecorators,
+    canHaveIllegalModifiers: () => canHaveIllegalModifiers,
+    canHaveIllegalType: () => canHaveIllegalType,
+    canHaveIllegalTypeParameters: () => canHaveIllegalTypeParameters,
+    canHaveJSDoc: () => canHaveJSDoc,
+    canHaveLocals: () => canHaveLocals,
+    canHaveModifiers: () => canHaveModifiers,
+    canHaveSymbol: () => canHaveSymbol,
+    canJsonReportNoInputFiles: () => canJsonReportNoInputFiles,
+    canProduceDiagnostics: () => canProduceDiagnostics,
+    canUsePropertyAccess: () => canUsePropertyAccess,
+    canWatchAffectingLocation: () => canWatchAffectingLocation,
+    canWatchAtTypes: () => canWatchAtTypes,
+    canWatchDirectoryOrFile: () => canWatchDirectoryOrFile,
+    cartesianProduct: () => cartesianProduct,
+    cast: () => cast,
+    chainBundle: () => chainBundle,
+    chainDiagnosticMessages: () => chainDiagnosticMessages,
+    changeAnyExtension: () => changeAnyExtension,
+    changeCompilerHostLikeToUseCache: () => changeCompilerHostLikeToUseCache,
+    changeExtension: () => changeExtension,
+    changesAffectModuleResolution: () => changesAffectModuleResolution,
+    changesAffectingProgramStructure: () => changesAffectingProgramStructure,
+    childIsDecorated: () => childIsDecorated,
+    classElementOrClassElementParameterIsDecorated: () => classElementOrClassElementParameterIsDecorated,
+    classHasClassThisAssignment: () => classHasClassThisAssignment,
+    classHasDeclaredOrExplicitlyAssignedName: () => classHasDeclaredOrExplicitlyAssignedName,
+    classHasExplicitlyAssignedName: () => classHasExplicitlyAssignedName,
+    classOrConstructorParameterIsDecorated: () => classOrConstructorParameterIsDecorated,
+    classPrivateFieldGetHelper: () => classPrivateFieldGetHelper,
+    classPrivateFieldInHelper: () => classPrivateFieldInHelper,
+    classPrivateFieldSetHelper: () => classPrivateFieldSetHelper,
+    classicNameResolver: () => classicNameResolver,
+    classifier: () => ts_classifier_exports,
+    cleanExtendedConfigCache: () => cleanExtendedConfigCache,
+    clear: () => clear,
+    clearMap: () => clearMap,
+    clearSharedExtendedConfigFileWatcher: () => clearSharedExtendedConfigFileWatcher,
+    climbPastPropertyAccess: () => climbPastPropertyAccess,
+    climbPastPropertyOrElementAccess: () => climbPastPropertyOrElementAccess,
+    clone: () => clone,
+    cloneCompilerOptions: () => cloneCompilerOptions,
+    closeFileWatcher: () => closeFileWatcher,
+    closeFileWatcherOf: () => closeFileWatcherOf,
+    codefix: () => ts_codefix_exports,
+    collapseTextChangeRangesAcrossMultipleVersions: () => collapseTextChangeRangesAcrossMultipleVersions,
+    collectExternalModuleInfo: () => collectExternalModuleInfo,
+    combine: () => combine,
+    combinePaths: () => combinePaths,
+    commentPragmas: () => commentPragmas,
+    commonOptionsWithBuild: () => commonOptionsWithBuild,
+    commonPackageFolders: () => commonPackageFolders,
+    compact: () => compact,
+    compareBooleans: () => compareBooleans,
+    compareDataObjects: () => compareDataObjects,
+    compareDiagnostics: () => compareDiagnostics,
+    compareDiagnosticsSkipRelatedInformation: () => compareDiagnosticsSkipRelatedInformation,
+    compareEmitHelpers: () => compareEmitHelpers,
+    compareNumberOfDirectorySeparators: () => compareNumberOfDirectorySeparators,
+    comparePaths: () => comparePaths,
+    comparePathsCaseInsensitive: () => comparePathsCaseInsensitive,
+    comparePathsCaseSensitive: () => comparePathsCaseSensitive,
+    comparePatternKeys: () => comparePatternKeys,
+    compareProperties: () => compareProperties,
+    compareStringsCaseInsensitive: () => compareStringsCaseInsensitive,
+    compareStringsCaseInsensitiveEslintCompatible: () => compareStringsCaseInsensitiveEslintCompatible,
+    compareStringsCaseSensitive: () => compareStringsCaseSensitive,
+    compareStringsCaseSensitiveUI: () => compareStringsCaseSensitiveUI,
+    compareTextSpans: () => compareTextSpans,
+    compareValues: () => compareValues,
+    compileOnSaveCommandLineOption: () => compileOnSaveCommandLineOption,
+    compilerOptionsAffectDeclarationPath: () => compilerOptionsAffectDeclarationPath,
+    compilerOptionsAffectEmit: () => compilerOptionsAffectEmit,
+    compilerOptionsAffectSemanticDiagnostics: () => compilerOptionsAffectSemanticDiagnostics,
+    compilerOptionsDidYouMeanDiagnostics: () => compilerOptionsDidYouMeanDiagnostics,
+    compilerOptionsIndicateEsModules: () => compilerOptionsIndicateEsModules,
+    compose: () => compose,
+    computeCommonSourceDirectoryOfFilenames: () => computeCommonSourceDirectoryOfFilenames,
+    computeLineAndCharacterOfPosition: () => computeLineAndCharacterOfPosition,
+    computeLineOfPosition: () => computeLineOfPosition,
+    computeLineStarts: () => computeLineStarts,
+    computePositionOfLineAndCharacter: () => computePositionOfLineAndCharacter,
+    computeSignature: () => computeSignature,
+    computeSignatureWithDiagnostics: () => computeSignatureWithDiagnostics,
+    computeSuggestionDiagnostics: () => computeSuggestionDiagnostics,
+    concatenate: () => concatenate,
+    concatenateDiagnosticMessageChains: () => concatenateDiagnosticMessageChains,
+    consumesNodeCoreModules: () => consumesNodeCoreModules,
+    contains: () => contains,
+    containsIgnoredPath: () => containsIgnoredPath,
+    containsObjectRestOrSpread: () => containsObjectRestOrSpread,
+    containsParseError: () => containsParseError,
+    containsPath: () => containsPath,
+    convertCompilerOptionsForTelemetry: () => convertCompilerOptionsForTelemetry,
+    convertCompilerOptionsFromJson: () => convertCompilerOptionsFromJson,
+    convertJsonOption: () => convertJsonOption,
+    convertToBase64: () => convertToBase64,
+    convertToJson: () => convertToJson,
+    convertToObject: () => convertToObject,
+    convertToOptionsWithAbsolutePaths: () => convertToOptionsWithAbsolutePaths,
+    convertToRelativePath: () => convertToRelativePath,
+    convertToTSConfig: () => convertToTSConfig,
+    convertTypeAcquisitionFromJson: () => convertTypeAcquisitionFromJson,
+    copyComments: () => copyComments,
+    copyEntries: () => copyEntries,
+    copyLeadingComments: () => copyLeadingComments,
+    copyProperties: () => copyProperties,
+    copyTrailingAsLeadingComments: () => copyTrailingAsLeadingComments,
+    copyTrailingComments: () => copyTrailingComments,
+    couldStartTrivia: () => couldStartTrivia,
+    countWhere: () => countWhere,
+    createAbstractBuilder: () => createAbstractBuilder,
+    createAccessorPropertyBackingField: () => createAccessorPropertyBackingField,
+    createAccessorPropertyGetRedirector: () => createAccessorPropertyGetRedirector,
+    createAccessorPropertySetRedirector: () => createAccessorPropertySetRedirector,
+    createBaseNodeFactory: () => createBaseNodeFactory,
+    createBinaryExpressionTrampoline: () => createBinaryExpressionTrampoline,
+    createBindingHelper: () => createBindingHelper,
+    createBuildInfo: () => createBuildInfo,
+    createBuilderProgram: () => createBuilderProgram,
+    createBuilderProgramUsingProgramBuildInfo: () => createBuilderProgramUsingProgramBuildInfo,
+    createBuilderStatusReporter: () => createBuilderStatusReporter,
+    createCacheWithRedirects: () => createCacheWithRedirects,
+    createCacheableExportInfoMap: () => createCacheableExportInfoMap,
+    createCachedDirectoryStructureHost: () => createCachedDirectoryStructureHost,
+    createClassNamedEvaluationHelperBlock: () => createClassNamedEvaluationHelperBlock,
+    createClassThisAssignmentBlock: () => createClassThisAssignmentBlock,
+    createClassifier: () => createClassifier,
+    createCommentDirectivesMap: () => createCommentDirectivesMap,
+    createCompilerDiagnostic: () => createCompilerDiagnostic,
+    createCompilerDiagnosticForInvalidCustomType: () => createCompilerDiagnosticForInvalidCustomType,
+    createCompilerDiagnosticFromMessageChain: () => createCompilerDiagnosticFromMessageChain,
+    createCompilerHost: () => createCompilerHost,
+    createCompilerHostFromProgramHost: () => createCompilerHostFromProgramHost,
+    createCompilerHostWorker: () => createCompilerHostWorker,
+    createDetachedDiagnostic: () => createDetachedDiagnostic,
+    createDiagnosticCollection: () => createDiagnosticCollection,
+    createDiagnosticForFileFromMessageChain: () => createDiagnosticForFileFromMessageChain,
+    createDiagnosticForNode: () => createDiagnosticForNode,
+    createDiagnosticForNodeArray: () => createDiagnosticForNodeArray,
+    createDiagnosticForNodeArrayFromMessageChain: () => createDiagnosticForNodeArrayFromMessageChain,
+    createDiagnosticForNodeFromMessageChain: () => createDiagnosticForNodeFromMessageChain,
+    createDiagnosticForNodeInSourceFile: () => createDiagnosticForNodeInSourceFile,
+    createDiagnosticForRange: () => createDiagnosticForRange,
+    createDiagnosticMessageChainFromDiagnostic: () => createDiagnosticMessageChainFromDiagnostic,
+    createDiagnosticReporter: () => createDiagnosticReporter,
+    createDocumentPositionMapper: () => createDocumentPositionMapper,
+    createDocumentRegistry: () => createDocumentRegistry,
+    createDocumentRegistryInternal: () => createDocumentRegistryInternal,
+    createEmitAndSemanticDiagnosticsBuilderProgram: () => createEmitAndSemanticDiagnosticsBuilderProgram,
+    createEmitHelperFactory: () => createEmitHelperFactory,
+    createEmptyExports: () => createEmptyExports,
+    createExpressionForJsxElement: () => createExpressionForJsxElement,
+    createExpressionForJsxFragment: () => createExpressionForJsxFragment,
+    createExpressionForObjectLiteralElementLike: () => createExpressionForObjectLiteralElementLike,
+    createExpressionForPropertyName: () => createExpressionForPropertyName,
+    createExpressionFromEntityName: () => createExpressionFromEntityName,
+    createExternalHelpersImportDeclarationIfNeeded: () => createExternalHelpersImportDeclarationIfNeeded,
+    createFileDiagnostic: () => createFileDiagnostic,
+    createFileDiagnosticFromMessageChain: () => createFileDiagnosticFromMessageChain,
+    createForOfBindingStatement: () => createForOfBindingStatement,
+    createGetCanonicalFileName: () => createGetCanonicalFileName,
+    createGetSourceFile: () => createGetSourceFile,
+    createGetSymbolAccessibilityDiagnosticForNode: () => createGetSymbolAccessibilityDiagnosticForNode,
+    createGetSymbolAccessibilityDiagnosticForNodeName: () => createGetSymbolAccessibilityDiagnosticForNodeName,
+    createGetSymbolWalker: () => createGetSymbolWalker,
+    createIncrementalCompilerHost: () => createIncrementalCompilerHost,
+    createIncrementalProgram: () => createIncrementalProgram,
+    createInputFiles: () => createInputFiles,
+    createInputFilesWithFilePaths: () => createInputFilesWithFilePaths,
+    createInputFilesWithFileTexts: () => createInputFilesWithFileTexts,
+    createJsxFactoryExpression: () => createJsxFactoryExpression,
+    createLanguageService: () => createLanguageService,
+    createLanguageServiceSourceFile: () => createLanguageServiceSourceFile,
+    createMemberAccessForPropertyName: () => createMemberAccessForPropertyName,
+    createModeAwareCache: () => createModeAwareCache,
+    createModeAwareCacheKey: () => createModeAwareCacheKey,
+    createModuleNotFoundChain: () => createModuleNotFoundChain,
+    createModuleResolutionCache: () => createModuleResolutionCache,
+    createModuleResolutionLoader: () => createModuleResolutionLoader,
+    createModuleResolutionLoaderUsingGlobalCache: () => createModuleResolutionLoaderUsingGlobalCache,
+    createModuleSpecifierResolutionHost: () => createModuleSpecifierResolutionHost,
+    createMultiMap: () => createMultiMap,
+    createNodeConverters: () => createNodeConverters,
+    createNodeFactory: () => createNodeFactory,
+    createOptionNameMap: () => createOptionNameMap,
+    createOverload: () => createOverload,
+    createPackageJsonImportFilter: () => createPackageJsonImportFilter,
+    createPackageJsonInfo: () => createPackageJsonInfo,
+    createParenthesizerRules: () => createParenthesizerRules,
+    createPatternMatcher: () => createPatternMatcher,
+    createPrependNodes: () => createPrependNodes,
+    createPrinter: () => createPrinter,
+    createPrinterWithDefaults: () => createPrinterWithDefaults,
+    createPrinterWithRemoveComments: () => createPrinterWithRemoveComments,
+    createPrinterWithRemoveCommentsNeverAsciiEscape: () => createPrinterWithRemoveCommentsNeverAsciiEscape,
+    createPrinterWithRemoveCommentsOmitTrailingSemicolon: () => createPrinterWithRemoveCommentsOmitTrailingSemicolon,
+    createProgram: () => createProgram,
+    createProgramHost: () => createProgramHost,
+    createPropertyNameNodeForIdentifierOrLiteral: () => createPropertyNameNodeForIdentifierOrLiteral,
+    createQueue: () => createQueue,
+    createRange: () => createRange,
+    createRedirectedBuilderProgram: () => createRedirectedBuilderProgram,
+    createResolutionCache: () => createResolutionCache,
+    createRuntimeTypeSerializer: () => createRuntimeTypeSerializer,
+    createScanner: () => createScanner,
+    createSemanticDiagnosticsBuilderProgram: () => createSemanticDiagnosticsBuilderProgram,
+    createSet: () => createSet,
+    createSolutionBuilder: () => createSolutionBuilder,
+    createSolutionBuilderHost: () => createSolutionBuilderHost,
+    createSolutionBuilderWithWatch: () => createSolutionBuilderWithWatch,
+    createSolutionBuilderWithWatchHost: () => createSolutionBuilderWithWatchHost,
+    createSortedArray: () => createSortedArray,
+    createSourceFile: () => createSourceFile,
+    createSourceMapGenerator: () => createSourceMapGenerator,
+    createSourceMapSource: () => createSourceMapSource,
+    createSuperAccessVariableStatement: () => createSuperAccessVariableStatement,
+    createSymbolTable: () => createSymbolTable,
+    createSymlinkCache: () => createSymlinkCache,
+    createSystemWatchFunctions: () => createSystemWatchFunctions,
+    createTextChange: () => createTextChange,
+    createTextChangeFromStartLength: () => createTextChangeFromStartLength,
+    createTextChangeRange: () => createTextChangeRange,
+    createTextRangeFromNode: () => createTextRangeFromNode,
+    createTextRangeFromSpan: () => createTextRangeFromSpan,
+    createTextSpan: () => createTextSpan,
+    createTextSpanFromBounds: () => createTextSpanFromBounds,
+    createTextSpanFromNode: () => createTextSpanFromNode,
+    createTextSpanFromRange: () => createTextSpanFromRange,
+    createTextSpanFromStringLiteralLikeContent: () => createTextSpanFromStringLiteralLikeContent,
+    createTextWriter: () => createTextWriter,
+    createTokenRange: () => createTokenRange,
+    createTypeChecker: () => createTypeChecker,
+    createTypeReferenceDirectiveResolutionCache: () => createTypeReferenceDirectiveResolutionCache,
+    createTypeReferenceResolutionLoader: () => createTypeReferenceResolutionLoader,
+    createUnparsedSourceFile: () => createUnparsedSourceFile,
+    createWatchCompilerHost: () => createWatchCompilerHost2,
+    createWatchCompilerHostOfConfigFile: () => createWatchCompilerHostOfConfigFile,
+    createWatchCompilerHostOfFilesAndCompilerOptions: () => createWatchCompilerHostOfFilesAndCompilerOptions,
+    createWatchFactory: () => createWatchFactory,
+    createWatchHost: () => createWatchHost,
+    createWatchProgram: () => createWatchProgram,
+    createWatchStatusReporter: () => createWatchStatusReporter,
+    createWriteFileMeasuringIO: () => createWriteFileMeasuringIO,
+    declarationNameToString: () => declarationNameToString,
+    decodeMappings: () => decodeMappings,
+    decodedTextSpanIntersectsWith: () => decodedTextSpanIntersectsWith,
+    decorateHelper: () => decorateHelper,
+    deduplicate: () => deduplicate,
+    defaultIncludeSpec: () => defaultIncludeSpec,
+    defaultInitCompilerOptions: () => defaultInitCompilerOptions,
+    defaultMaximumTruncationLength: () => defaultMaximumTruncationLength,
+    detectSortCaseSensitivity: () => detectSortCaseSensitivity,
+    diagnosticCategoryName: () => diagnosticCategoryName,
+    diagnosticToString: () => diagnosticToString,
+    directoryProbablyExists: () => directoryProbablyExists,
+    directorySeparator: () => directorySeparator,
+    displayPart: () => displayPart,
+    displayPartsToString: () => displayPartsToString,
+    disposeEmitNodes: () => disposeEmitNodes,
+    disposeResourcesHelper: () => disposeResourcesHelper,
+    documentSpansEqual: () => documentSpansEqual,
+    dumpTracingLegend: () => dumpTracingLegend,
+    elementAt: () => elementAt,
+    elideNodes: () => elideNodes,
+    emitComments: () => emitComments,
+    emitDetachedComments: () => emitDetachedComments,
+    emitFiles: () => emitFiles,
+    emitFilesAndReportErrors: () => emitFilesAndReportErrors,
+    emitFilesAndReportErrorsAndGetExitStatus: () => emitFilesAndReportErrorsAndGetExitStatus,
+    emitModuleKindIsNonNodeESM: () => emitModuleKindIsNonNodeESM,
+    emitNewLineBeforeLeadingCommentOfPosition: () => emitNewLineBeforeLeadingCommentOfPosition,
+    emitNewLineBeforeLeadingComments: () => emitNewLineBeforeLeadingComments,
+    emitNewLineBeforeLeadingCommentsOfPosition: () => emitNewLineBeforeLeadingCommentsOfPosition,
+    emitSkippedWithNoDiagnostics: () => emitSkippedWithNoDiagnostics,
+    emitUsingBuildInfo: () => emitUsingBuildInfo,
+    emptyArray: () => emptyArray,
+    emptyFileSystemEntries: () => emptyFileSystemEntries,
+    emptyMap: () => emptyMap,
+    emptyOptions: () => emptyOptions,
+    emptySet: () => emptySet,
+    endsWith: () => endsWith,
+    ensurePathIsNonModuleName: () => ensurePathIsNonModuleName,
+    ensureScriptKind: () => ensureScriptKind,
+    ensureTrailingDirectorySeparator: () => ensureTrailingDirectorySeparator,
+    entityNameToString: () => entityNameToString,
+    enumerateInsertsAndDeletes: () => enumerateInsertsAndDeletes,
+    equalOwnProperties: () => equalOwnProperties,
+    equateStringsCaseInsensitive: () => equateStringsCaseInsensitive,
+    equateStringsCaseSensitive: () => equateStringsCaseSensitive,
+    equateValues: () => equateValues,
+    esDecorateHelper: () => esDecorateHelper,
+    escapeJsxAttributeString: () => escapeJsxAttributeString,
+    escapeLeadingUnderscores: () => escapeLeadingUnderscores,
+    escapeNonAsciiString: () => escapeNonAsciiString,
+    escapeSnippetText: () => escapeSnippetText,
+    escapeString: () => escapeString,
+    every: () => every,
+    expandPreOrPostfixIncrementOrDecrementExpression: () => expandPreOrPostfixIncrementOrDecrementExpression,
+    explainFiles: () => explainFiles,
+    explainIfFileIsRedirectAndImpliedFormat: () => explainIfFileIsRedirectAndImpliedFormat,
+    exportAssignmentIsAlias: () => exportAssignmentIsAlias,
+    exportStarHelper: () => exportStarHelper,
+    expressionResultIsUnused: () => expressionResultIsUnused,
+    extend: () => extend,
+    extendsHelper: () => extendsHelper,
+    extensionFromPath: () => extensionFromPath,
+    extensionIsTS: () => extensionIsTS,
+    extensionsNotSupportingExtensionlessResolution: () => extensionsNotSupportingExtensionlessResolution,
+    externalHelpersModuleNameText: () => externalHelpersModuleNameText,
+    factory: () => factory,
+    fileExtensionIs: () => fileExtensionIs,
+    fileExtensionIsOneOf: () => fileExtensionIsOneOf,
+    fileIncludeReasonToDiagnostics: () => fileIncludeReasonToDiagnostics,
+    fileShouldUseJavaScriptRequire: () => fileShouldUseJavaScriptRequire,
+    filter: () => filter,
+    filterMutate: () => filterMutate,
+    filterSemanticDiagnostics: () => filterSemanticDiagnostics,
+    find: () => find,
+    findAncestor: () => findAncestor,
+    findBestPatternMatch: () => findBestPatternMatch,
+    findChildOfKind: () => findChildOfKind,
+    findComputedPropertyNameCacheAssignment: () => findComputedPropertyNameCacheAssignment,
+    findConfigFile: () => findConfigFile,
+    findContainingList: () => findContainingList,
+    findDiagnosticForNode: () => findDiagnosticForNode,
+    findFirstNonJsxWhitespaceToken: () => findFirstNonJsxWhitespaceToken,
+    findIndex: () => findIndex,
+    findLast: () => findLast,
+    findLastIndex: () => findLastIndex,
+    findListItemInfo: () => findListItemInfo,
+    findMap: () => findMap,
+    findModifier: () => findModifier,
+    findNextToken: () => findNextToken,
+    findPackageJson: () => findPackageJson,
+    findPackageJsons: () => findPackageJsons,
+    findPrecedingMatchingToken: () => findPrecedingMatchingToken,
+    findPrecedingToken: () => findPrecedingToken,
+    findSuperStatementIndexPath: () => findSuperStatementIndexPath,
+    findTokenOnLeftOfPosition: () => findTokenOnLeftOfPosition,
+    findUseStrictPrologue: () => findUseStrictPrologue,
+    first: () => first,
+    firstDefined: () => firstDefined,
+    firstDefinedIterator: () => firstDefinedIterator,
+    firstIterator: () => firstIterator,
+    firstOrOnly: () => firstOrOnly,
+    firstOrUndefined: () => firstOrUndefined,
+    firstOrUndefinedIterator: () => firstOrUndefinedIterator,
+    fixupCompilerOptions: () => fixupCompilerOptions,
+    flatMap: () => flatMap,
+    flatMapIterator: () => flatMapIterator,
+    flatMapToMutable: () => flatMapToMutable,
+    flatten: () => flatten,
+    flattenCommaList: () => flattenCommaList,
+    flattenDestructuringAssignment: () => flattenDestructuringAssignment,
+    flattenDestructuringBinding: () => flattenDestructuringBinding,
+    flattenDiagnosticMessageText: () => flattenDiagnosticMessageText,
+    forEach: () => forEach,
+    forEachAncestor: () => forEachAncestor,
+    forEachAncestorDirectory: () => forEachAncestorDirectory,
+    forEachChild: () => forEachChild,
+    forEachChildRecursively: () => forEachChildRecursively,
+    forEachEmittedFile: () => forEachEmittedFile,
+    forEachEnclosingBlockScopeContainer: () => forEachEnclosingBlockScopeContainer,
+    forEachEntry: () => forEachEntry,
+    forEachExternalModuleToImportFrom: () => forEachExternalModuleToImportFrom,
+    forEachImportClauseDeclaration: () => forEachImportClauseDeclaration,
+    forEachKey: () => forEachKey,
+    forEachLeadingCommentRange: () => forEachLeadingCommentRange,
+    forEachNameInAccessChainWalkingLeft: () => forEachNameInAccessChainWalkingLeft,
+    forEachPropertyAssignment: () => forEachPropertyAssignment,
+    forEachResolvedProjectReference: () => forEachResolvedProjectReference,
+    forEachReturnStatement: () => forEachReturnStatement,
+    forEachRight: () => forEachRight,
+    forEachTrailingCommentRange: () => forEachTrailingCommentRange,
+    forEachTsConfigPropArray: () => forEachTsConfigPropArray,
+    forEachUnique: () => forEachUnique,
+    forEachYieldExpression: () => forEachYieldExpression,
+    forSomeAncestorDirectory: () => forSomeAncestorDirectory,
+    formatColorAndReset: () => formatColorAndReset,
+    formatDiagnostic: () => formatDiagnostic,
+    formatDiagnostics: () => formatDiagnostics,
+    formatDiagnosticsWithColorAndContext: () => formatDiagnosticsWithColorAndContext,
+    formatGeneratedName: () => formatGeneratedName,
+    formatGeneratedNamePart: () => formatGeneratedNamePart,
+    formatLocation: () => formatLocation,
+    formatMessage: () => formatMessage,
+    formatStringFromArgs: () => formatStringFromArgs,
+    formatting: () => ts_formatting_exports,
+    fullTripleSlashAMDReferencePathRegEx: () => fullTripleSlashAMDReferencePathRegEx,
+    fullTripleSlashReferencePathRegEx: () => fullTripleSlashReferencePathRegEx,
+    generateDjb2Hash: () => generateDjb2Hash,
+    generateTSConfig: () => generateTSConfig,
+    generatorHelper: () => generatorHelper,
+    getAdjustedReferenceLocation: () => getAdjustedReferenceLocation,
+    getAdjustedRenameLocation: () => getAdjustedRenameLocation,
+    getAliasDeclarationFromName: () => getAliasDeclarationFromName,
+    getAllAccessorDeclarations: () => getAllAccessorDeclarations,
+    getAllDecoratorsOfClass: () => getAllDecoratorsOfClass,
+    getAllDecoratorsOfClassElement: () => getAllDecoratorsOfClassElement,
+    getAllJSDocTags: () => getAllJSDocTags,
+    getAllJSDocTagsOfKind: () => getAllJSDocTagsOfKind,
+    getAllKeys: () => getAllKeys,
+    getAllProjectOutputs: () => getAllProjectOutputs,
+    getAllSuperTypeNodes: () => getAllSuperTypeNodes,
+    getAllUnscopedEmitHelpers: () => getAllUnscopedEmitHelpers,
+    getAllowJSCompilerOption: () => getAllowJSCompilerOption,
+    getAllowSyntheticDefaultImports: () => getAllowSyntheticDefaultImports,
+    getAncestor: () => getAncestor,
+    getAnyExtensionFromPath: () => getAnyExtensionFromPath,
+    getAreDeclarationMapsEnabled: () => getAreDeclarationMapsEnabled,
+    getAssignedExpandoInitializer: () => getAssignedExpandoInitializer,
+    getAssignedName: () => getAssignedName,
+    getAssignedNameOfIdentifier: () => getAssignedNameOfIdentifier,
+    getAssignmentDeclarationKind: () => getAssignmentDeclarationKind,
+    getAssignmentDeclarationPropertyAccessKind: () => getAssignmentDeclarationPropertyAccessKind,
+    getAssignmentTargetKind: () => getAssignmentTargetKind,
+    getAutomaticTypeDirectiveNames: () => getAutomaticTypeDirectiveNames,
+    getBaseFileName: () => getBaseFileName,
+    getBinaryOperatorPrecedence: () => getBinaryOperatorPrecedence,
+    getBuildInfo: () => getBuildInfo,
+    getBuildInfoFileVersionMap: () => getBuildInfoFileVersionMap,
+    getBuildInfoText: () => getBuildInfoText,
+    getBuildOrderFromAnyBuildOrder: () => getBuildOrderFromAnyBuildOrder,
+    getBuilderCreationParameters: () => getBuilderCreationParameters,
+    getBuilderFileEmit: () => getBuilderFileEmit,
+    getCheckFlags: () => getCheckFlags,
+    getClassExtendsHeritageElement: () => getClassExtendsHeritageElement,
+    getClassLikeDeclarationOfSymbol: () => getClassLikeDeclarationOfSymbol,
+    getCombinedLocalAndExportSymbolFlags: () => getCombinedLocalAndExportSymbolFlags,
+    getCombinedModifierFlags: () => getCombinedModifierFlags,
+    getCombinedNodeFlags: () => getCombinedNodeFlags,
+    getCombinedNodeFlagsAlwaysIncludeJSDoc: () => getCombinedNodeFlagsAlwaysIncludeJSDoc,
+    getCommentRange: () => getCommentRange,
+    getCommonSourceDirectory: () => getCommonSourceDirectory,
+    getCommonSourceDirectoryOfConfig: () => getCommonSourceDirectoryOfConfig,
+    getCompilerOptionValue: () => getCompilerOptionValue,
+    getCompilerOptionsDiffValue: () => getCompilerOptionsDiffValue,
+    getConditions: () => getConditions,
+    getConfigFileParsingDiagnostics: () => getConfigFileParsingDiagnostics,
+    getConstantValue: () => getConstantValue,
+    getContainerFlags: () => getContainerFlags,
+    getContainerNode: () => getContainerNode,
+    getContainingClass: () => getContainingClass,
+    getContainingClassExcludingClassDecorators: () => getContainingClassExcludingClassDecorators,
+    getContainingClassStaticBlock: () => getContainingClassStaticBlock,
+    getContainingFunction: () => getContainingFunction,
+    getContainingFunctionDeclaration: () => getContainingFunctionDeclaration,
+    getContainingFunctionOrClassStaticBlock: () => getContainingFunctionOrClassStaticBlock,
+    getContainingNodeArray: () => getContainingNodeArray,
+    getContainingObjectLiteralElement: () => getContainingObjectLiteralElement,
+    getContextualTypeFromParent: () => getContextualTypeFromParent,
+    getContextualTypeFromParentOrAncestorTypeNode: () => getContextualTypeFromParentOrAncestorTypeNode,
+    getCurrentTime: () => getCurrentTime,
+    getDeclarationDiagnostics: () => getDeclarationDiagnostics,
+    getDeclarationEmitExtensionForPath: () => getDeclarationEmitExtensionForPath,
+    getDeclarationEmitOutputFilePath: () => getDeclarationEmitOutputFilePath,
+    getDeclarationEmitOutputFilePathWorker: () => getDeclarationEmitOutputFilePathWorker,
+    getDeclarationFromName: () => getDeclarationFromName,
+    getDeclarationModifierFlagsFromSymbol: () => getDeclarationModifierFlagsFromSymbol,
+    getDeclarationOfKind: () => getDeclarationOfKind,
+    getDeclarationsOfKind: () => getDeclarationsOfKind,
+    getDeclaredExpandoInitializer: () => getDeclaredExpandoInitializer,
+    getDecorators: () => getDecorators,
+    getDefaultCompilerOptions: () => getDefaultCompilerOptions2,
+    getDefaultExportInfoWorker: () => getDefaultExportInfoWorker,
+    getDefaultFormatCodeSettings: () => getDefaultFormatCodeSettings,
+    getDefaultLibFileName: () => getDefaultLibFileName,
+    getDefaultLibFilePath: () => getDefaultLibFilePath,
+    getDefaultLikeExportInfo: () => getDefaultLikeExportInfo,
+    getDiagnosticText: () => getDiagnosticText,
+    getDiagnosticsWithinSpan: () => getDiagnosticsWithinSpan,
+    getDirectoryPath: () => getDirectoryPath,
+    getDirectoryToWatchFailedLookupLocation: () => getDirectoryToWatchFailedLookupLocation,
+    getDirectoryToWatchFailedLookupLocationFromTypeRoot: () => getDirectoryToWatchFailedLookupLocationFromTypeRoot,
+    getDocumentPositionMapper: () => getDocumentPositionMapper,
+    getESModuleInterop: () => getESModuleInterop,
+    getEditsForFileRename: () => getEditsForFileRename,
+    getEffectiveBaseTypeNode: () => getEffectiveBaseTypeNode,
+    getEffectiveConstraintOfTypeParameter: () => getEffectiveConstraintOfTypeParameter,
+    getEffectiveContainerForJSDocTemplateTag: () => getEffectiveContainerForJSDocTemplateTag,
+    getEffectiveImplementsTypeNodes: () => getEffectiveImplementsTypeNodes,
+    getEffectiveInitializer: () => getEffectiveInitializer,
+    getEffectiveJSDocHost: () => getEffectiveJSDocHost,
+    getEffectiveModifierFlags: () => getEffectiveModifierFlags,
+    getEffectiveModifierFlagsAlwaysIncludeJSDoc: () => getEffectiveModifierFlagsAlwaysIncludeJSDoc,
+    getEffectiveModifierFlagsNoCache: () => getEffectiveModifierFlagsNoCache,
+    getEffectiveReturnTypeNode: () => getEffectiveReturnTypeNode,
+    getEffectiveSetAccessorTypeAnnotationNode: () => getEffectiveSetAccessorTypeAnnotationNode,
+    getEffectiveTypeAnnotationNode: () => getEffectiveTypeAnnotationNode,
+    getEffectiveTypeParameterDeclarations: () => getEffectiveTypeParameterDeclarations,
+    getEffectiveTypeRoots: () => getEffectiveTypeRoots,
+    getElementOrPropertyAccessArgumentExpressionOrName: () => getElementOrPropertyAccessArgumentExpressionOrName,
+    getElementOrPropertyAccessName: () => getElementOrPropertyAccessName,
+    getElementsOfBindingOrAssignmentPattern: () => getElementsOfBindingOrAssignmentPattern,
+    getEmitDeclarations: () => getEmitDeclarations,
+    getEmitFlags: () => getEmitFlags,
+    getEmitHelpers: () => getEmitHelpers,
+    getEmitModuleDetectionKind: () => getEmitModuleDetectionKind,
+    getEmitModuleKind: () => getEmitModuleKind,
+    getEmitModuleResolutionKind: () => getEmitModuleResolutionKind,
+    getEmitScriptTarget: () => getEmitScriptTarget,
+    getEmitStandardClassFields: () => getEmitStandardClassFields,
+    getEnclosingBlockScopeContainer: () => getEnclosingBlockScopeContainer,
+    getEnclosingContainer: () => getEnclosingContainer,
+    getEncodedSemanticClassifications: () => getEncodedSemanticClassifications,
+    getEncodedSyntacticClassifications: () => getEncodedSyntacticClassifications,
+    getEndLinePosition: () => getEndLinePosition,
+    getEntityNameFromTypeNode: () => getEntityNameFromTypeNode,
+    getEntrypointsFromPackageJsonInfo: () => getEntrypointsFromPackageJsonInfo,
+    getErrorCountForSummary: () => getErrorCountForSummary,
+    getErrorSpanForNode: () => getErrorSpanForNode,
+    getErrorSummaryText: () => getErrorSummaryText,
+    getEscapedTextOfIdentifierOrLiteral: () => getEscapedTextOfIdentifierOrLiteral,
+    getEscapedTextOfJsxAttributeName: () => getEscapedTextOfJsxAttributeName,
+    getEscapedTextOfJsxNamespacedName: () => getEscapedTextOfJsxNamespacedName,
+    getExpandoInitializer: () => getExpandoInitializer,
+    getExportAssignmentExpression: () => getExportAssignmentExpression,
+    getExportInfoMap: () => getExportInfoMap,
+    getExportNeedsImportStarHelper: () => getExportNeedsImportStarHelper,
+    getExpressionAssociativity: () => getExpressionAssociativity,
+    getExpressionPrecedence: () => getExpressionPrecedence,
+    getExternalHelpersModuleName: () => getExternalHelpersModuleName,
+    getExternalModuleImportEqualsDeclarationExpression: () => getExternalModuleImportEqualsDeclarationExpression,
+    getExternalModuleName: () => getExternalModuleName,
+    getExternalModuleNameFromDeclaration: () => getExternalModuleNameFromDeclaration,
+    getExternalModuleNameFromPath: () => getExternalModuleNameFromPath,
+    getExternalModuleNameLiteral: () => getExternalModuleNameLiteral,
+    getExternalModuleRequireArgument: () => getExternalModuleRequireArgument,
+    getFallbackOptions: () => getFallbackOptions,
+    getFileEmitOutput: () => getFileEmitOutput,
+    getFileMatcherPatterns: () => getFileMatcherPatterns,
+    getFileNamesFromConfigSpecs: () => getFileNamesFromConfigSpecs,
+    getFileWatcherEventKind: () => getFileWatcherEventKind,
+    getFilesInErrorForSummary: () => getFilesInErrorForSummary,
+    getFirstConstructorWithBody: () => getFirstConstructorWithBody,
+    getFirstIdentifier: () => getFirstIdentifier,
+    getFirstNonSpaceCharacterPosition: () => getFirstNonSpaceCharacterPosition,
+    getFirstProjectOutput: () => getFirstProjectOutput,
+    getFixableErrorSpanExpression: () => getFixableErrorSpanExpression,
+    getFormatCodeSettingsForWriting: () => getFormatCodeSettingsForWriting,
+    getFullWidth: () => getFullWidth,
+    getFunctionFlags: () => getFunctionFlags,
+    getHeritageClause: () => getHeritageClause,
+    getHostSignatureFromJSDoc: () => getHostSignatureFromJSDoc,
+    getIdentifierAutoGenerate: () => getIdentifierAutoGenerate,
+    getIdentifierGeneratedImportReference: () => getIdentifierGeneratedImportReference,
+    getIdentifierTypeArguments: () => getIdentifierTypeArguments,
+    getImmediatelyInvokedFunctionExpression: () => getImmediatelyInvokedFunctionExpression,
+    getImpliedNodeFormatForFile: () => getImpliedNodeFormatForFile,
+    getImpliedNodeFormatForFileWorker: () => getImpliedNodeFormatForFileWorker,
+    getImportNeedsImportDefaultHelper: () => getImportNeedsImportDefaultHelper,
+    getImportNeedsImportStarHelper: () => getImportNeedsImportStarHelper,
+    getIndentSize: () => getIndentSize,
+    getIndentString: () => getIndentString,
+    getInferredLibraryNameResolveFrom: () => getInferredLibraryNameResolveFrom,
+    getInitializedVariables: () => getInitializedVariables,
+    getInitializerOfBinaryExpression: () => getInitializerOfBinaryExpression,
+    getInitializerOfBindingOrAssignmentElement: () => getInitializerOfBindingOrAssignmentElement,
+    getInterfaceBaseTypeNodes: () => getInterfaceBaseTypeNodes,
+    getInternalEmitFlags: () => getInternalEmitFlags,
+    getInvokedExpression: () => getInvokedExpression,
+    getIsolatedModules: () => getIsolatedModules,
+    getJSDocAugmentsTag: () => getJSDocAugmentsTag,
+    getJSDocClassTag: () => getJSDocClassTag,
+    getJSDocCommentRanges: () => getJSDocCommentRanges,
+    getJSDocCommentsAndTags: () => getJSDocCommentsAndTags,
+    getJSDocDeprecatedTag: () => getJSDocDeprecatedTag,
+    getJSDocDeprecatedTagNoCache: () => getJSDocDeprecatedTagNoCache,
+    getJSDocEnumTag: () => getJSDocEnumTag,
+    getJSDocHost: () => getJSDocHost,
+    getJSDocImplementsTags: () => getJSDocImplementsTags,
+    getJSDocOverrideTagNoCache: () => getJSDocOverrideTagNoCache,
+    getJSDocParameterTags: () => getJSDocParameterTags,
+    getJSDocParameterTagsNoCache: () => getJSDocParameterTagsNoCache,
+    getJSDocPrivateTag: () => getJSDocPrivateTag,
+    getJSDocPrivateTagNoCache: () => getJSDocPrivateTagNoCache,
+    getJSDocProtectedTag: () => getJSDocProtectedTag,
+    getJSDocProtectedTagNoCache: () => getJSDocProtectedTagNoCache,
+    getJSDocPublicTag: () => getJSDocPublicTag,
+    getJSDocPublicTagNoCache: () => getJSDocPublicTagNoCache,
+    getJSDocReadonlyTag: () => getJSDocReadonlyTag,
+    getJSDocReadonlyTagNoCache: () => getJSDocReadonlyTagNoCache,
+    getJSDocReturnTag: () => getJSDocReturnTag,
+    getJSDocReturnType: () => getJSDocReturnType,
+    getJSDocRoot: () => getJSDocRoot,
+    getJSDocSatisfiesExpressionType: () => getJSDocSatisfiesExpressionType,
+    getJSDocSatisfiesTag: () => getJSDocSatisfiesTag,
+    getJSDocTags: () => getJSDocTags,
+    getJSDocTagsNoCache: () => getJSDocTagsNoCache,
+    getJSDocTemplateTag: () => getJSDocTemplateTag,
+    getJSDocThisTag: () => getJSDocThisTag,
+    getJSDocType: () => getJSDocType,
+    getJSDocTypeAliasName: () => getJSDocTypeAliasName,
+    getJSDocTypeAssertionType: () => getJSDocTypeAssertionType,
+    getJSDocTypeParameterDeclarations: () => getJSDocTypeParameterDeclarations,
+    getJSDocTypeParameterTags: () => getJSDocTypeParameterTags,
+    getJSDocTypeParameterTagsNoCache: () => getJSDocTypeParameterTagsNoCache,
+    getJSDocTypeTag: () => getJSDocTypeTag,
+    getJSXImplicitImportBase: () => getJSXImplicitImportBase,
+    getJSXRuntimeImport: () => getJSXRuntimeImport,
+    getJSXTransformEnabled: () => getJSXTransformEnabled,
+    getKeyForCompilerOptions: () => getKeyForCompilerOptions,
+    getLanguageVariant: () => getLanguageVariant,
+    getLastChild: () => getLastChild,
+    getLeadingCommentRanges: () => getLeadingCommentRanges,
+    getLeadingCommentRangesOfNode: () => getLeadingCommentRangesOfNode,
+    getLeftmostAccessExpression: () => getLeftmostAccessExpression,
+    getLeftmostExpression: () => getLeftmostExpression,
+    getLibraryNameFromLibFileName: () => getLibraryNameFromLibFileName,
+    getLineAndCharacterOfPosition: () => getLineAndCharacterOfPosition,
+    getLineInfo: () => getLineInfo,
+    getLineOfLocalPosition: () => getLineOfLocalPosition,
+    getLineOfLocalPositionFromLineMap: () => getLineOfLocalPositionFromLineMap,
+    getLineStartPositionForPosition: () => getLineStartPositionForPosition,
+    getLineStarts: () => getLineStarts,
+    getLinesBetweenPositionAndNextNonWhitespaceCharacter: () => getLinesBetweenPositionAndNextNonWhitespaceCharacter,
+    getLinesBetweenPositionAndPrecedingNonWhitespaceCharacter: () => getLinesBetweenPositionAndPrecedingNonWhitespaceCharacter,
+    getLinesBetweenPositions: () => getLinesBetweenPositions,
+    getLinesBetweenRangeEndAndRangeStart: () => getLinesBetweenRangeEndAndRangeStart,
+    getLinesBetweenRangeEndPositions: () => getLinesBetweenRangeEndPositions,
+    getLiteralText: () => getLiteralText,
+    getLocalNameForExternalImport: () => getLocalNameForExternalImport,
+    getLocalSymbolForExportDefault: () => getLocalSymbolForExportDefault,
+    getLocaleSpecificMessage: () => getLocaleSpecificMessage,
+    getLocaleTimeString: () => getLocaleTimeString,
+    getMappedContextSpan: () => getMappedContextSpan,
+    getMappedDocumentSpan: () => getMappedDocumentSpan,
+    getMappedLocation: () => getMappedLocation,
+    getMatchedFileSpec: () => getMatchedFileSpec,
+    getMatchedIncludeSpec: () => getMatchedIncludeSpec,
+    getMeaningFromDeclaration: () => getMeaningFromDeclaration,
+    getMeaningFromLocation: () => getMeaningFromLocation,
+    getMembersOfDeclaration: () => getMembersOfDeclaration,
+    getModeForFileReference: () => getModeForFileReference,
+    getModeForResolutionAtIndex: () => getModeForResolutionAtIndex,
+    getModeForUsageLocation: () => getModeForUsageLocation,
+    getModifiedTime: () => getModifiedTime,
+    getModifiers: () => getModifiers,
+    getModuleInstanceState: () => getModuleInstanceState,
+    getModuleNameStringLiteralAt: () => getModuleNameStringLiteralAt,
+    getModuleSpecifierEndingPreference: () => getModuleSpecifierEndingPreference,
+    getModuleSpecifierResolverHost: () => getModuleSpecifierResolverHost,
+    getNameForExportedSymbol: () => getNameForExportedSymbol,
+    getNameFromIndexInfo: () => getNameFromIndexInfo,
+    getNameFromPropertyName: () => getNameFromPropertyName,
+    getNameOfAccessExpression: () => getNameOfAccessExpression,
+    getNameOfCompilerOptionValue: () => getNameOfCompilerOptionValue,
+    getNameOfDeclaration: () => getNameOfDeclaration,
+    getNameOfExpando: () => getNameOfExpando,
+    getNameOfJSDocTypedef: () => getNameOfJSDocTypedef,
+    getNameOrArgument: () => getNameOrArgument,
+    getNameTable: () => getNameTable,
+    getNamesForExportedSymbol: () => getNamesForExportedSymbol,
+    getNamespaceDeclarationNode: () => getNamespaceDeclarationNode,
+    getNewLineCharacter: () => getNewLineCharacter,
+    getNewLineKind: () => getNewLineKind,
+    getNewLineOrDefaultFromHost: () => getNewLineOrDefaultFromHost,
+    getNewTargetContainer: () => getNewTargetContainer,
+    getNextJSDocCommentLocation: () => getNextJSDocCommentLocation,
+    getNodeForGeneratedName: () => getNodeForGeneratedName,
+    getNodeId: () => getNodeId,
+    getNodeKind: () => getNodeKind,
+    getNodeModifiers: () => getNodeModifiers,
+    getNodeModulePathParts: () => getNodeModulePathParts,
+    getNonAssignedNameOfDeclaration: () => getNonAssignedNameOfDeclaration,
+    getNonAssignmentOperatorForCompoundAssignment: () => getNonAssignmentOperatorForCompoundAssignment,
+    getNonAugmentationDeclaration: () => getNonAugmentationDeclaration,
+    getNonDecoratorTokenPosOfNode: () => getNonDecoratorTokenPosOfNode,
+    getNormalizedAbsolutePath: () => getNormalizedAbsolutePath,
+    getNormalizedAbsolutePathWithoutRoot: () => getNormalizedAbsolutePathWithoutRoot,
+    getNormalizedPathComponents: () => getNormalizedPathComponents,
+    getObjectFlags: () => getObjectFlags,
+    getOperator: () => getOperator,
+    getOperatorAssociativity: () => getOperatorAssociativity,
+    getOperatorPrecedence: () => getOperatorPrecedence,
+    getOptionFromName: () => getOptionFromName,
+    getOptionsForLibraryResolution: () => getOptionsForLibraryResolution,
+    getOptionsNameMap: () => getOptionsNameMap,
+    getOrCreateEmitNode: () => getOrCreateEmitNode,
+    getOrCreateExternalHelpersModuleNameIfNeeded: () => getOrCreateExternalHelpersModuleNameIfNeeded,
+    getOrUpdate: () => getOrUpdate,
+    getOriginalNode: () => getOriginalNode,
+    getOriginalNodeId: () => getOriginalNodeId,
+    getOriginalSourceFile: () => getOriginalSourceFile,
+    getOutputDeclarationFileName: () => getOutputDeclarationFileName,
+    getOutputExtension: () => getOutputExtension,
+    getOutputFileNames: () => getOutputFileNames,
+    getOutputPathsFor: () => getOutputPathsFor,
+    getOutputPathsForBundle: () => getOutputPathsForBundle,
+    getOwnEmitOutputFilePath: () => getOwnEmitOutputFilePath,
+    getOwnKeys: () => getOwnKeys,
+    getOwnValues: () => getOwnValues,
+    getPackageJsonInfo: () => getPackageJsonInfo,
+    getPackageJsonTypesVersionsPaths: () => getPackageJsonTypesVersionsPaths,
+    getPackageJsonsVisibleToFile: () => getPackageJsonsVisibleToFile,
+    getPackageNameFromTypesPackageName: () => getPackageNameFromTypesPackageName,
+    getPackageScopeForPath: () => getPackageScopeForPath,
+    getParameterSymbolFromJSDoc: () => getParameterSymbolFromJSDoc,
+    getParameterTypeNode: () => getParameterTypeNode,
+    getParentNodeInSpan: () => getParentNodeInSpan,
+    getParseTreeNode: () => getParseTreeNode,
+    getParsedCommandLineOfConfigFile: () => getParsedCommandLineOfConfigFile,
+    getPathComponents: () => getPathComponents,
+    getPathComponentsRelativeTo: () => getPathComponentsRelativeTo,
+    getPathFromPathComponents: () => getPathFromPathComponents,
+    getPathUpdater: () => getPathUpdater,
+    getPathsBasePath: () => getPathsBasePath,
+    getPatternFromSpec: () => getPatternFromSpec,
+    getPendingEmitKind: () => getPendingEmitKind,
+    getPositionOfLineAndCharacter: () => getPositionOfLineAndCharacter,
+    getPossibleGenericSignatures: () => getPossibleGenericSignatures,
+    getPossibleOriginalInputExtensionForExtension: () => getPossibleOriginalInputExtensionForExtension,
+    getPossibleTypeArgumentsInfo: () => getPossibleTypeArgumentsInfo,
+    getPreEmitDiagnostics: () => getPreEmitDiagnostics,
+    getPrecedingNonSpaceCharacterPosition: () => getPrecedingNonSpaceCharacterPosition,
+    getPrivateIdentifier: () => getPrivateIdentifier,
+    getProperties: () => getProperties,
+    getProperty: () => getProperty,
+    getPropertyArrayElementValue: () => getPropertyArrayElementValue,
+    getPropertyAssignmentAliasLikeExpression: () => getPropertyAssignmentAliasLikeExpression,
+    getPropertyNameForPropertyNameNode: () => getPropertyNameForPropertyNameNode,
+    getPropertyNameForUniqueESSymbol: () => getPropertyNameForUniqueESSymbol,
+    getPropertyNameFromType: () => getPropertyNameFromType,
+    getPropertyNameOfBindingOrAssignmentElement: () => getPropertyNameOfBindingOrAssignmentElement,
+    getPropertySymbolFromBindingElement: () => getPropertySymbolFromBindingElement,
+    getPropertySymbolsFromContextualType: () => getPropertySymbolsFromContextualType,
+    getQuoteFromPreference: () => getQuoteFromPreference,
+    getQuotePreference: () => getQuotePreference,
+    getRangesWhere: () => getRangesWhere,
+    getRefactorContextSpan: () => getRefactorContextSpan,
+    getReferencedFileLocation: () => getReferencedFileLocation,
+    getRegexFromPattern: () => getRegexFromPattern,
+    getRegularExpressionForWildcard: () => getRegularExpressionForWildcard,
+    getRegularExpressionsForWildcards: () => getRegularExpressionsForWildcards,
+    getRelativePathFromDirectory: () => getRelativePathFromDirectory,
+    getRelativePathFromFile: () => getRelativePathFromFile,
+    getRelativePathToDirectoryOrUrl: () => getRelativePathToDirectoryOrUrl,
+    getRenameLocation: () => getRenameLocation,
+    getReplacementSpanForContextToken: () => getReplacementSpanForContextToken,
+    getResolutionDiagnostic: () => getResolutionDiagnostic,
+    getResolutionModeOverride: () => getResolutionModeOverride,
+    getResolveJsonModule: () => getResolveJsonModule,
+    getResolvePackageJsonExports: () => getResolvePackageJsonExports,
+    getResolvePackageJsonImports: () => getResolvePackageJsonImports,
+    getResolvedExternalModuleName: () => getResolvedExternalModuleName,
+    getRestIndicatorOfBindingOrAssignmentElement: () => getRestIndicatorOfBindingOrAssignmentElement,
+    getRestParameterElementType: () => getRestParameterElementType,
+    getRightMostAssignedExpression: () => getRightMostAssignedExpression,
+    getRootDeclaration: () => getRootDeclaration,
+    getRootDirectoryOfResolutionCache: () => getRootDirectoryOfResolutionCache,
+    getRootLength: () => getRootLength,
+    getRootPathSplitLength: () => getRootPathSplitLength,
+    getScriptKind: () => getScriptKind,
+    getScriptKindFromFileName: () => getScriptKindFromFileName,
+    getScriptTargetFeatures: () => getScriptTargetFeatures,
+    getSelectedEffectiveModifierFlags: () => getSelectedEffectiveModifierFlags,
+    getSelectedSyntacticModifierFlags: () => getSelectedSyntacticModifierFlags,
+    getSemanticClassifications: () => getSemanticClassifications,
+    getSemanticJsxChildren: () => getSemanticJsxChildren,
+    getSetAccessorTypeAnnotationNode: () => getSetAccessorTypeAnnotationNode,
+    getSetAccessorValueParameter: () => getSetAccessorValueParameter,
+    getSetExternalModuleIndicator: () => getSetExternalModuleIndicator,
+    getShebang: () => getShebang,
+    getSingleInitializerOfVariableStatementOrPropertyDeclaration: () => getSingleInitializerOfVariableStatementOrPropertyDeclaration,
+    getSingleVariableOfVariableStatement: () => getSingleVariableOfVariableStatement,
+    getSnapshotText: () => getSnapshotText,
+    getSnippetElement: () => getSnippetElement,
+    getSourceFileOfModule: () => getSourceFileOfModule,
+    getSourceFileOfNode: () => getSourceFileOfNode,
+    getSourceFilePathInNewDir: () => getSourceFilePathInNewDir,
+    getSourceFilePathInNewDirWorker: () => getSourceFilePathInNewDirWorker,
+    getSourceFileVersionAsHashFromText: () => getSourceFileVersionAsHashFromText,
+    getSourceFilesToEmit: () => getSourceFilesToEmit,
+    getSourceMapRange: () => getSourceMapRange,
+    getSourceMapper: () => getSourceMapper,
+    getSourceTextOfNodeFromSourceFile: () => getSourceTextOfNodeFromSourceFile,
+    getSpanOfTokenAtPosition: () => getSpanOfTokenAtPosition,
+    getSpellingSuggestion: () => getSpellingSuggestion,
+    getStartPositionOfLine: () => getStartPositionOfLine,
+    getStartPositionOfRange: () => getStartPositionOfRange,
+    getStartsOnNewLine: () => getStartsOnNewLine,
+    getStaticPropertiesAndClassStaticBlock: () => getStaticPropertiesAndClassStaticBlock,
+    getStrictOptionValue: () => getStrictOptionValue,
+    getStringComparer: () => getStringComparer,
+    getSuperCallFromStatement: () => getSuperCallFromStatement,
+    getSuperContainer: () => getSuperContainer,
+    getSupportedCodeFixes: () => getSupportedCodeFixes,
+    getSupportedExtensions: () => getSupportedExtensions,
+    getSupportedExtensionsWithJsonIfResolveJsonModule: () => getSupportedExtensionsWithJsonIfResolveJsonModule,
+    getSwitchedType: () => getSwitchedType,
+    getSymbolId: () => getSymbolId,
+    getSymbolNameForPrivateIdentifier: () => getSymbolNameForPrivateIdentifier,
+    getSymbolTarget: () => getSymbolTarget,
+    getSyntacticClassifications: () => getSyntacticClassifications,
+    getSyntacticModifierFlags: () => getSyntacticModifierFlags,
+    getSyntacticModifierFlagsNoCache: () => getSyntacticModifierFlagsNoCache,
+    getSynthesizedDeepClone: () => getSynthesizedDeepClone,
+    getSynthesizedDeepCloneWithReplacements: () => getSynthesizedDeepCloneWithReplacements,
+    getSynthesizedDeepClones: () => getSynthesizedDeepClones,
+    getSynthesizedDeepClonesWithReplacements: () => getSynthesizedDeepClonesWithReplacements,
+    getSyntheticLeadingComments: () => getSyntheticLeadingComments,
+    getSyntheticTrailingComments: () => getSyntheticTrailingComments,
+    getTargetLabel: () => getTargetLabel,
+    getTargetOfBindingOrAssignmentElement: () => getTargetOfBindingOrAssignmentElement,
+    getTemporaryModuleResolutionState: () => getTemporaryModuleResolutionState,
+    getTextOfConstantValue: () => getTextOfConstantValue,
+    getTextOfIdentifierOrLiteral: () => getTextOfIdentifierOrLiteral,
+    getTextOfJSDocComment: () => getTextOfJSDocComment,
+    getTextOfJsxAttributeName: () => getTextOfJsxAttributeName,
+    getTextOfJsxNamespacedName: () => getTextOfJsxNamespacedName,
+    getTextOfNode: () => getTextOfNode,
+    getTextOfNodeFromSourceText: () => getTextOfNodeFromSourceText,
+    getTextOfPropertyName: () => getTextOfPropertyName,
+    getThisContainer: () => getThisContainer,
+    getThisParameter: () => getThisParameter,
+    getTokenAtPosition: () => getTokenAtPosition,
+    getTokenPosOfNode: () => getTokenPosOfNode,
+    getTokenSourceMapRange: () => getTokenSourceMapRange,
+    getTouchingPropertyName: () => getTouchingPropertyName,
+    getTouchingToken: () => getTouchingToken,
+    getTrailingCommentRanges: () => getTrailingCommentRanges,
+    getTrailingSemicolonDeferringWriter: () => getTrailingSemicolonDeferringWriter,
+    getTransformFlagsSubtreeExclusions: () => getTransformFlagsSubtreeExclusions,
+    getTransformers: () => getTransformers,
+    getTsBuildInfoEmitOutputFilePath: () => getTsBuildInfoEmitOutputFilePath,
+    getTsConfigObjectLiteralExpression: () => getTsConfigObjectLiteralExpression,
+    getTsConfigPropArrayElementValue: () => getTsConfigPropArrayElementValue,
+    getTypeAnnotationNode: () => getTypeAnnotationNode,
+    getTypeArgumentOrTypeParameterList: () => getTypeArgumentOrTypeParameterList,
+    getTypeKeywordOfTypeOnlyImport: () => getTypeKeywordOfTypeOnlyImport,
+    getTypeNode: () => getTypeNode,
+    getTypeNodeIfAccessible: () => getTypeNodeIfAccessible,
+    getTypeParameterFromJsDoc: () => getTypeParameterFromJsDoc,
+    getTypeParameterOwner: () => getTypeParameterOwner,
+    getTypesPackageName: () => getTypesPackageName,
+    getUILocale: () => getUILocale,
+    getUniqueName: () => getUniqueName,
+    getUniqueSymbolId: () => getUniqueSymbolId,
+    getUseDefineForClassFields: () => getUseDefineForClassFields,
+    getWatchErrorSummaryDiagnosticMessage: () => getWatchErrorSummaryDiagnosticMessage,
+    getWatchFactory: () => getWatchFactory,
+    group: () => group,
+    groupBy: () => groupBy,
+    guessIndentation: () => guessIndentation,
+    handleNoEmitOptions: () => handleNoEmitOptions,
+    hasAbstractModifier: () => hasAbstractModifier,
+    hasAccessorModifier: () => hasAccessorModifier,
+    hasAmbientModifier: () => hasAmbientModifier,
+    hasChangesInResolutions: () => hasChangesInResolutions,
+    hasChildOfKind: () => hasChildOfKind,
+    hasContextSensitiveParameters: () => hasContextSensitiveParameters,
+    hasDecorators: () => hasDecorators,
+    hasDocComment: () => hasDocComment,
+    hasDynamicName: () => hasDynamicName,
+    hasEffectiveModifier: () => hasEffectiveModifier,
+    hasEffectiveModifiers: () => hasEffectiveModifiers,
+    hasEffectiveReadonlyModifier: () => hasEffectiveReadonlyModifier,
+    hasExtension: () => hasExtension,
+    hasIndexSignature: () => hasIndexSignature,
+    hasInitializer: () => hasInitializer,
+    hasInvalidEscape: () => hasInvalidEscape,
+    hasJSDocNodes: () => hasJSDocNodes,
+    hasJSDocParameterTags: () => hasJSDocParameterTags,
+    hasJSFileExtension: () => hasJSFileExtension,
+    hasJsonModuleEmitEnabled: () => hasJsonModuleEmitEnabled,
+    hasOnlyExpressionInitializer: () => hasOnlyExpressionInitializer,
+    hasOverrideModifier: () => hasOverrideModifier,
+    hasPossibleExternalModuleReference: () => hasPossibleExternalModuleReference,
+    hasProperty: () => hasProperty,
+    hasPropertyAccessExpressionWithName: () => hasPropertyAccessExpressionWithName,
+    hasQuestionToken: () => hasQuestionToken,
+    hasRecordedExternalHelpers: () => hasRecordedExternalHelpers,
+    hasResolutionModeOverride: () => hasResolutionModeOverride,
+    hasRestParameter: () => hasRestParameter,
+    hasScopeMarker: () => hasScopeMarker,
+    hasStaticModifier: () => hasStaticModifier,
+    hasSyntacticModifier: () => hasSyntacticModifier,
+    hasSyntacticModifiers: () => hasSyntacticModifiers,
+    hasTSFileExtension: () => hasTSFileExtension,
+    hasTabstop: () => hasTabstop,
+    hasTrailingDirectorySeparator: () => hasTrailingDirectorySeparator,
+    hasType: () => hasType,
+    hasTypeArguments: () => hasTypeArguments,
+    hasZeroOrOneAsteriskCharacter: () => hasZeroOrOneAsteriskCharacter,
+    helperString: () => helperString,
+    hostGetCanonicalFileName: () => hostGetCanonicalFileName,
+    hostUsesCaseSensitiveFileNames: () => hostUsesCaseSensitiveFileNames,
+    idText: () => idText,
+    identifierIsThisKeyword: () => identifierIsThisKeyword,
+    identifierToKeywordKind: () => identifierToKeywordKind,
+    identity: () => identity,
+    identitySourceMapConsumer: () => identitySourceMapConsumer,
+    ignoreSourceNewlines: () => ignoreSourceNewlines,
+    ignoredPaths: () => ignoredPaths,
+    importDefaultHelper: () => importDefaultHelper,
+    importFromModuleSpecifier: () => importFromModuleSpecifier,
+    importNameElisionDisabled: () => importNameElisionDisabled,
+    importStarHelper: () => importStarHelper,
+    indexOfAnyCharCode: () => indexOfAnyCharCode,
+    indexOfNode: () => indexOfNode,
+    indicesOf: () => indicesOf,
+    inferredTypesContainingFile: () => inferredTypesContainingFile,
+    injectClassNamedEvaluationHelperBlockIfMissing: () => injectClassNamedEvaluationHelperBlockIfMissing,
+    injectClassThisAssignmentIfMissing: () => injectClassThisAssignmentIfMissing,
+    insertImports: () => insertImports,
+    insertLeadingStatement: () => insertLeadingStatement,
+    insertSorted: () => insertSorted,
+    insertStatementAfterCustomPrologue: () => insertStatementAfterCustomPrologue,
+    insertStatementAfterStandardPrologue: () => insertStatementAfterStandardPrologue,
+    insertStatementsAfterCustomPrologue: () => insertStatementsAfterCustomPrologue,
+    insertStatementsAfterStandardPrologue: () => insertStatementsAfterStandardPrologue,
+    intersperse: () => intersperse,
+    intrinsicTagNameToString: () => intrinsicTagNameToString,
+    introducesArgumentsExoticObject: () => introducesArgumentsExoticObject,
+    inverseJsxOptionMap: () => inverseJsxOptionMap,
+    isAbstractConstructorSymbol: () => isAbstractConstructorSymbol,
+    isAbstractModifier: () => isAbstractModifier,
+    isAccessExpression: () => isAccessExpression,
+    isAccessibilityModifier: () => isAccessibilityModifier,
+    isAccessor: () => isAccessor,
+    isAccessorModifier: () => isAccessorModifier,
+    isAliasSymbolDeclaration: () => isAliasSymbolDeclaration,
+    isAliasableExpression: () => isAliasableExpression,
+    isAmbientModule: () => isAmbientModule,
+    isAmbientPropertyDeclaration: () => isAmbientPropertyDeclaration,
+    isAnonymousFunctionDefinition: () => isAnonymousFunctionDefinition,
+    isAnyDirectorySeparator: () => isAnyDirectorySeparator,
+    isAnyImportOrBareOrAccessedRequire: () => isAnyImportOrBareOrAccessedRequire,
+    isAnyImportOrReExport: () => isAnyImportOrReExport,
+    isAnyImportSyntax: () => isAnyImportSyntax,
+    isAnySupportedFileExtension: () => isAnySupportedFileExtension,
+    isApplicableVersionedTypesKey: () => isApplicableVersionedTypesKey,
+    isArgumentExpressionOfElementAccess: () => isArgumentExpressionOfElementAccess,
+    isArray: () => isArray,
+    isArrayBindingElement: () => isArrayBindingElement,
+    isArrayBindingOrAssignmentElement: () => isArrayBindingOrAssignmentElement,
+    isArrayBindingOrAssignmentPattern: () => isArrayBindingOrAssignmentPattern,
+    isArrayBindingPattern: () => isArrayBindingPattern,
+    isArrayLiteralExpression: () => isArrayLiteralExpression,
+    isArrayLiteralOrObjectLiteralDestructuringPattern: () => isArrayLiteralOrObjectLiteralDestructuringPattern,
+    isArrayTypeNode: () => isArrayTypeNode,
+    isArrowFunction: () => isArrowFunction,
+    isAsExpression: () => isAsExpression,
+    isAssertClause: () => isAssertClause,
+    isAssertEntry: () => isAssertEntry,
+    isAssertionExpression: () => isAssertionExpression,
+    isAssertsKeyword: () => isAssertsKeyword,
+    isAssignmentDeclaration: () => isAssignmentDeclaration,
+    isAssignmentExpression: () => isAssignmentExpression,
+    isAssignmentOperator: () => isAssignmentOperator,
+    isAssignmentPattern: () => isAssignmentPattern,
+    isAssignmentTarget: () => isAssignmentTarget,
+    isAsteriskToken: () => isAsteriskToken,
+    isAsyncFunction: () => isAsyncFunction,
+    isAsyncModifier: () => isAsyncModifier,
+    isAutoAccessorPropertyDeclaration: () => isAutoAccessorPropertyDeclaration,
+    isAwaitExpression: () => isAwaitExpression,
+    isAwaitKeyword: () => isAwaitKeyword,
+    isBigIntLiteral: () => isBigIntLiteral,
+    isBinaryExpression: () => isBinaryExpression,
+    isBinaryOperatorToken: () => isBinaryOperatorToken,
+    isBindableObjectDefinePropertyCall: () => isBindableObjectDefinePropertyCall,
+    isBindableStaticAccessExpression: () => isBindableStaticAccessExpression,
+    isBindableStaticElementAccessExpression: () => isBindableStaticElementAccessExpression,
+    isBindableStaticNameExpression: () => isBindableStaticNameExpression,
+    isBindingElement: () => isBindingElement,
+    isBindingElementOfBareOrAccessedRequire: () => isBindingElementOfBareOrAccessedRequire,
+    isBindingName: () => isBindingName,
+    isBindingOrAssignmentElement: () => isBindingOrAssignmentElement,
+    isBindingOrAssignmentPattern: () => isBindingOrAssignmentPattern,
+    isBindingPattern: () => isBindingPattern,
+    isBlock: () => isBlock,
+    isBlockOrCatchScoped: () => isBlockOrCatchScoped,
+    isBlockScope: () => isBlockScope,
+    isBlockScopedContainerTopLevel: () => isBlockScopedContainerTopLevel,
+    isBooleanLiteral: () => isBooleanLiteral,
+    isBreakOrContinueStatement: () => isBreakOrContinueStatement,
+    isBreakStatement: () => isBreakStatement,
+    isBuildInfoFile: () => isBuildInfoFile,
+    isBuilderProgram: () => isBuilderProgram2,
+    isBundle: () => isBundle,
+    isBundleFileTextLike: () => isBundleFileTextLike,
+    isCallChain: () => isCallChain,
+    isCallExpression: () => isCallExpression,
+    isCallExpressionTarget: () => isCallExpressionTarget,
+    isCallLikeExpression: () => isCallLikeExpression,
+    isCallLikeOrFunctionLikeExpression: () => isCallLikeOrFunctionLikeExpression,
+    isCallOrNewExpression: () => isCallOrNewExpression,
+    isCallOrNewExpressionTarget: () => isCallOrNewExpressionTarget,
+    isCallSignatureDeclaration: () => isCallSignatureDeclaration,
+    isCallToHelper: () => isCallToHelper,
+    isCaseBlock: () => isCaseBlock,
+    isCaseClause: () => isCaseClause,
+    isCaseKeyword: () => isCaseKeyword,
+    isCaseOrDefaultClause: () => isCaseOrDefaultClause,
+    isCatchClause: () => isCatchClause,
+    isCatchClauseVariableDeclaration: () => isCatchClauseVariableDeclaration,
+    isCatchClauseVariableDeclarationOrBindingElement: () => isCatchClauseVariableDeclarationOrBindingElement,
+    isCheckJsEnabledForFile: () => isCheckJsEnabledForFile,
+    isChildOfNodeWithKind: () => isChildOfNodeWithKind,
+    isCircularBuildOrder: () => isCircularBuildOrder,
+    isClassDeclaration: () => isClassDeclaration,
+    isClassElement: () => isClassElement,
+    isClassExpression: () => isClassExpression,
+    isClassInstanceProperty: () => isClassInstanceProperty,
+    isClassLike: () => isClassLike,
+    isClassMemberModifier: () => isClassMemberModifier,
+    isClassNamedEvaluationHelperBlock: () => isClassNamedEvaluationHelperBlock,
+    isClassOrTypeElement: () => isClassOrTypeElement,
+    isClassStaticBlockDeclaration: () => isClassStaticBlockDeclaration,
+    isClassThisAssignmentBlock: () => isClassThisAssignmentBlock,
+    isCollapsedRange: () => isCollapsedRange,
+    isColonToken: () => isColonToken,
+    isCommaExpression: () => isCommaExpression,
+    isCommaListExpression: () => isCommaListExpression,
+    isCommaSequence: () => isCommaSequence,
+    isCommaToken: () => isCommaToken,
+    isComment: () => isComment,
+    isCommonJsExportPropertyAssignment: () => isCommonJsExportPropertyAssignment,
+    isCommonJsExportedExpression: () => isCommonJsExportedExpression,
+    isCompoundAssignment: () => isCompoundAssignment,
+    isComputedNonLiteralName: () => isComputedNonLiteralName,
+    isComputedPropertyName: () => isComputedPropertyName,
+    isConciseBody: () => isConciseBody,
+    isConditionalExpression: () => isConditionalExpression,
+    isConditionalTypeNode: () => isConditionalTypeNode,
+    isConstTypeReference: () => isConstTypeReference,
+    isConstructSignatureDeclaration: () => isConstructSignatureDeclaration,
+    isConstructorDeclaration: () => isConstructorDeclaration,
+    isConstructorTypeNode: () => isConstructorTypeNode,
+    isContextualKeyword: () => isContextualKeyword,
+    isContinueStatement: () => isContinueStatement,
+    isCustomPrologue: () => isCustomPrologue,
+    isDebuggerStatement: () => isDebuggerStatement,
+    isDeclaration: () => isDeclaration,
+    isDeclarationBindingElement: () => isDeclarationBindingElement,
+    isDeclarationFileName: () => isDeclarationFileName,
+    isDeclarationName: () => isDeclarationName,
+    isDeclarationNameOfEnumOrNamespace: () => isDeclarationNameOfEnumOrNamespace,
+    isDeclarationReadonly: () => isDeclarationReadonly,
+    isDeclarationStatement: () => isDeclarationStatement,
+    isDeclarationWithTypeParameterChildren: () => isDeclarationWithTypeParameterChildren,
+    isDeclarationWithTypeParameters: () => isDeclarationWithTypeParameters,
+    isDecorator: () => isDecorator,
+    isDecoratorTarget: () => isDecoratorTarget,
+    isDefaultClause: () => isDefaultClause,
+    isDefaultImport: () => isDefaultImport,
+    isDefaultModifier: () => isDefaultModifier,
+    isDefaultedExpandoInitializer: () => isDefaultedExpandoInitializer,
+    isDeleteExpression: () => isDeleteExpression,
+    isDeleteTarget: () => isDeleteTarget,
+    isDeprecatedDeclaration: () => isDeprecatedDeclaration,
+    isDestructuringAssignment: () => isDestructuringAssignment,
+    isDiagnosticWithLocation: () => isDiagnosticWithLocation,
+    isDiskPathRoot: () => isDiskPathRoot,
+    isDoStatement: () => isDoStatement,
+    isDocumentRegistryEntry: () => isDocumentRegistryEntry,
+    isDotDotDotToken: () => isDotDotDotToken,
+    isDottedName: () => isDottedName,
+    isDynamicName: () => isDynamicName,
+    isESSymbolIdentifier: () => isESSymbolIdentifier,
+    isEffectiveExternalModule: () => isEffectiveExternalModule,
+    isEffectiveModuleDeclaration: () => isEffectiveModuleDeclaration,
+    isEffectiveStrictModeSourceFile: () => isEffectiveStrictModeSourceFile,
+    isElementAccessChain: () => isElementAccessChain,
+    isElementAccessExpression: () => isElementAccessExpression,
+    isEmittedFileOfProgram: () => isEmittedFileOfProgram,
+    isEmptyArrayLiteral: () => isEmptyArrayLiteral,
+    isEmptyBindingElement: () => isEmptyBindingElement,
+    isEmptyBindingPattern: () => isEmptyBindingPattern,
+    isEmptyObjectLiteral: () => isEmptyObjectLiteral,
+    isEmptyStatement: () => isEmptyStatement,
+    isEmptyStringLiteral: () => isEmptyStringLiteral,
+    isEntityName: () => isEntityName,
+    isEntityNameExpression: () => isEntityNameExpression,
+    isEnumConst: () => isEnumConst,
+    isEnumDeclaration: () => isEnumDeclaration,
+    isEnumMember: () => isEnumMember,
+    isEqualityOperatorKind: () => isEqualityOperatorKind,
+    isEqualsGreaterThanToken: () => isEqualsGreaterThanToken,
+    isExclamationToken: () => isExclamationToken,
+    isExcludedFile: () => isExcludedFile,
+    isExclusivelyTypeOnlyImportOrExport: () => isExclusivelyTypeOnlyImportOrExport,
+    isExpandoPropertyDeclaration: () => isExpandoPropertyDeclaration,
+    isExportAssignment: () => isExportAssignment,
+    isExportDeclaration: () => isExportDeclaration,
+    isExportModifier: () => isExportModifier,
+    isExportName: () => isExportName,
+    isExportNamespaceAsDefaultDeclaration: () => isExportNamespaceAsDefaultDeclaration,
+    isExportOrDefaultModifier: () => isExportOrDefaultModifier,
+    isExportSpecifier: () => isExportSpecifier,
+    isExportsIdentifier: () => isExportsIdentifier,
+    isExportsOrModuleExportsOrAlias: () => isExportsOrModuleExportsOrAlias,
+    isExpression: () => isExpression,
+    isExpressionNode: () => isExpressionNode,
+    isExpressionOfExternalModuleImportEqualsDeclaration: () => isExpressionOfExternalModuleImportEqualsDeclaration,
+    isExpressionOfOptionalChainRoot: () => isExpressionOfOptionalChainRoot,
+    isExpressionStatement: () => isExpressionStatement,
+    isExpressionWithTypeArguments: () => isExpressionWithTypeArguments,
+    isExpressionWithTypeArgumentsInClassExtendsClause: () => isExpressionWithTypeArgumentsInClassExtendsClause,
+    isExternalModule: () => isExternalModule,
+    isExternalModuleAugmentation: () => isExternalModuleAugmentation,
+    isExternalModuleImportEqualsDeclaration: () => isExternalModuleImportEqualsDeclaration,
+    isExternalModuleIndicator: () => isExternalModuleIndicator,
+    isExternalModuleNameRelative: () => isExternalModuleNameRelative,
+    isExternalModuleReference: () => isExternalModuleReference,
+    isExternalModuleSymbol: () => isExternalModuleSymbol,
+    isExternalOrCommonJsModule: () => isExternalOrCommonJsModule,
+    isFileLevelReservedGeneratedIdentifier: () => isFileLevelReservedGeneratedIdentifier,
+    isFileLevelUniqueName: () => isFileLevelUniqueName,
+    isFileProbablyExternalModule: () => isFileProbablyExternalModule,
+    isFirstDeclarationOfSymbolParameter: () => isFirstDeclarationOfSymbolParameter,
+    isFixablePromiseHandler: () => isFixablePromiseHandler,
+    isForInOrOfStatement: () => isForInOrOfStatement,
+    isForInStatement: () => isForInStatement,
+    isForInitializer: () => isForInitializer,
+    isForOfStatement: () => isForOfStatement,
+    isForStatement: () => isForStatement,
+    isFunctionBlock: () => isFunctionBlock,
+    isFunctionBody: () => isFunctionBody,
+    isFunctionDeclaration: () => isFunctionDeclaration,
+    isFunctionExpression: () => isFunctionExpression,
+    isFunctionExpressionOrArrowFunction: () => isFunctionExpressionOrArrowFunction,
+    isFunctionLike: () => isFunctionLike,
+    isFunctionLikeDeclaration: () => isFunctionLikeDeclaration,
+    isFunctionLikeKind: () => isFunctionLikeKind,
+    isFunctionLikeOrClassStaticBlockDeclaration: () => isFunctionLikeOrClassStaticBlockDeclaration,
+    isFunctionOrConstructorTypeNode: () => isFunctionOrConstructorTypeNode,
+    isFunctionOrModuleBlock: () => isFunctionOrModuleBlock,
+    isFunctionSymbol: () => isFunctionSymbol,
+    isFunctionTypeNode: () => isFunctionTypeNode,
+    isFutureReservedKeyword: () => isFutureReservedKeyword,
+    isGeneratedIdentifier: () => isGeneratedIdentifier,
+    isGeneratedPrivateIdentifier: () => isGeneratedPrivateIdentifier,
+    isGetAccessor: () => isGetAccessor,
+    isGetAccessorDeclaration: () => isGetAccessorDeclaration,
+    isGetOrSetAccessorDeclaration: () => isGetOrSetAccessorDeclaration,
+    isGlobalDeclaration: () => isGlobalDeclaration,
+    isGlobalScopeAugmentation: () => isGlobalScopeAugmentation,
+    isGrammarError: () => isGrammarError,
+    isHeritageClause: () => isHeritageClause,
+    isHoistedFunction: () => isHoistedFunction,
+    isHoistedVariableStatement: () => isHoistedVariableStatement,
+    isIdentifier: () => isIdentifier,
+    isIdentifierANonContextualKeyword: () => isIdentifierANonContextualKeyword,
+    isIdentifierName: () => isIdentifierName,
+    isIdentifierOrThisTypeNode: () => isIdentifierOrThisTypeNode,
+    isIdentifierPart: () => isIdentifierPart,
+    isIdentifierStart: () => isIdentifierStart,
+    isIdentifierText: () => isIdentifierText,
+    isIdentifierTypePredicate: () => isIdentifierTypePredicate,
+    isIdentifierTypeReference: () => isIdentifierTypeReference,
+    isIfStatement: () => isIfStatement,
+    isIgnoredFileFromWildCardWatching: () => isIgnoredFileFromWildCardWatching,
+    isImplicitGlob: () => isImplicitGlob,
+    isImportAttribute: () => isImportAttribute,
+    isImportAttributeName: () => isImportAttributeName,
+    isImportAttributes: () => isImportAttributes,
+    isImportCall: () => isImportCall,
+    isImportClause: () => isImportClause,
+    isImportDeclaration: () => isImportDeclaration,
+    isImportEqualsDeclaration: () => isImportEqualsDeclaration,
+    isImportKeyword: () => isImportKeyword,
+    isImportMeta: () => isImportMeta,
+    isImportOrExportSpecifier: () => isImportOrExportSpecifier,
+    isImportOrExportSpecifierName: () => isImportOrExportSpecifierName,
+    isImportSpecifier: () => isImportSpecifier,
+    isImportTypeAssertionContainer: () => isImportTypeAssertionContainer,
+    isImportTypeNode: () => isImportTypeNode,
+    isImportableFile: () => isImportableFile,
+    isInComment: () => isInComment,
+    isInCompoundLikeAssignment: () => isInCompoundLikeAssignment,
+    isInExpressionContext: () => isInExpressionContext,
+    isInJSDoc: () => isInJSDoc,
+    isInJSFile: () => isInJSFile,
+    isInJSXText: () => isInJSXText,
+    isInJsonFile: () => isInJsonFile,
+    isInNonReferenceComment: () => isInNonReferenceComment,
+    isInReferenceComment: () => isInReferenceComment,
+    isInRightSideOfInternalImportEqualsDeclaration: () => isInRightSideOfInternalImportEqualsDeclaration,
+    isInString: () => isInString,
+    isInTemplateString: () => isInTemplateString,
+    isInTopLevelContext: () => isInTopLevelContext,
+    isInTypeQuery: () => isInTypeQuery,
+    isIncrementalCompilation: () => isIncrementalCompilation,
+    isIndexSignatureDeclaration: () => isIndexSignatureDeclaration,
+    isIndexedAccessTypeNode: () => isIndexedAccessTypeNode,
+    isInferTypeNode: () => isInferTypeNode,
+    isInfinityOrNaNString: () => isInfinityOrNaNString,
+    isInitializedProperty: () => isInitializedProperty,
+    isInitializedVariable: () => isInitializedVariable,
+    isInsideJsxElement: () => isInsideJsxElement,
+    isInsideJsxElementOrAttribute: () => isInsideJsxElementOrAttribute,
+    isInsideNodeModules: () => isInsideNodeModules,
+    isInsideTemplateLiteral: () => isInsideTemplateLiteral,
+    isInstanceOfExpression: () => isInstanceOfExpression,
+    isInstantiatedModule: () => isInstantiatedModule,
+    isInterfaceDeclaration: () => isInterfaceDeclaration,
+    isInternalDeclaration: () => isInternalDeclaration,
+    isInternalModuleImportEqualsDeclaration: () => isInternalModuleImportEqualsDeclaration,
+    isInternalName: () => isInternalName,
+    isIntersectionTypeNode: () => isIntersectionTypeNode,
+    isIntrinsicJsxName: () => isIntrinsicJsxName,
+    isIterationStatement: () => isIterationStatement,
+    isJSDoc: () => isJSDoc,
+    isJSDocAllType: () => isJSDocAllType,
+    isJSDocAugmentsTag: () => isJSDocAugmentsTag,
+    isJSDocAuthorTag: () => isJSDocAuthorTag,
+    isJSDocCallbackTag: () => isJSDocCallbackTag,
+    isJSDocClassTag: () => isJSDocClassTag,
+    isJSDocCommentContainingNode: () => isJSDocCommentContainingNode,
+    isJSDocConstructSignature: () => isJSDocConstructSignature,
+    isJSDocDeprecatedTag: () => isJSDocDeprecatedTag,
+    isJSDocEnumTag: () => isJSDocEnumTag,
+    isJSDocFunctionType: () => isJSDocFunctionType,
+    isJSDocImplementsTag: () => isJSDocImplementsTag,
+    isJSDocIndexSignature: () => isJSDocIndexSignature,
+    isJSDocLikeText: () => isJSDocLikeText,
+    isJSDocLink: () => isJSDocLink,
+    isJSDocLinkCode: () => isJSDocLinkCode,
+    isJSDocLinkLike: () => isJSDocLinkLike,
+    isJSDocLinkPlain: () => isJSDocLinkPlain,
+    isJSDocMemberName: () => isJSDocMemberName,
+    isJSDocNameReference: () => isJSDocNameReference,
+    isJSDocNamepathType: () => isJSDocNamepathType,
+    isJSDocNamespaceBody: () => isJSDocNamespaceBody,
+    isJSDocNode: () => isJSDocNode,
+    isJSDocNonNullableType: () => isJSDocNonNullableType,
+    isJSDocNullableType: () => isJSDocNullableType,
+    isJSDocOptionalParameter: () => isJSDocOptionalParameter,
+    isJSDocOptionalType: () => isJSDocOptionalType,
+    isJSDocOverloadTag: () => isJSDocOverloadTag,
+    isJSDocOverrideTag: () => isJSDocOverrideTag,
+    isJSDocParameterTag: () => isJSDocParameterTag,
+    isJSDocPrivateTag: () => isJSDocPrivateTag,
+    isJSDocPropertyLikeTag: () => isJSDocPropertyLikeTag,
+    isJSDocPropertyTag: () => isJSDocPropertyTag,
+    isJSDocProtectedTag: () => isJSDocProtectedTag,
+    isJSDocPublicTag: () => isJSDocPublicTag,
+    isJSDocReadonlyTag: () => isJSDocReadonlyTag,
+    isJSDocReturnTag: () => isJSDocReturnTag,
+    isJSDocSatisfiesExpression: () => isJSDocSatisfiesExpression,
+    isJSDocSatisfiesTag: () => isJSDocSatisfiesTag,
+    isJSDocSeeTag: () => isJSDocSeeTag,
+    isJSDocSignature: () => isJSDocSignature,
+    isJSDocTag: () => isJSDocTag,
+    isJSDocTemplateTag: () => isJSDocTemplateTag,
+    isJSDocThisTag: () => isJSDocThisTag,
+    isJSDocThrowsTag: () => isJSDocThrowsTag,
+    isJSDocTypeAlias: () => isJSDocTypeAlias,
+    isJSDocTypeAssertion: () => isJSDocTypeAssertion,
+    isJSDocTypeExpression: () => isJSDocTypeExpression,
+    isJSDocTypeLiteral: () => isJSDocTypeLiteral,
+    isJSDocTypeTag: () => isJSDocTypeTag,
+    isJSDocTypedefTag: () => isJSDocTypedefTag,
+    isJSDocUnknownTag: () => isJSDocUnknownTag,
+    isJSDocUnknownType: () => isJSDocUnknownType,
+    isJSDocVariadicType: () => isJSDocVariadicType,
+    isJSXTagName: () => isJSXTagName,
+    isJsonEqual: () => isJsonEqual,
+    isJsonSourceFile: () => isJsonSourceFile,
+    isJsxAttribute: () => isJsxAttribute,
+    isJsxAttributeLike: () => isJsxAttributeLike,
+    isJsxAttributeName: () => isJsxAttributeName,
+    isJsxAttributes: () => isJsxAttributes,
+    isJsxChild: () => isJsxChild,
+    isJsxClosingElement: () => isJsxClosingElement,
+    isJsxClosingFragment: () => isJsxClosingFragment,
+    isJsxElement: () => isJsxElement,
+    isJsxExpression: () => isJsxExpression,
+    isJsxFragment: () => isJsxFragment,
+    isJsxNamespacedName: () => isJsxNamespacedName,
+    isJsxOpeningElement: () => isJsxOpeningElement,
+    isJsxOpeningFragment: () => isJsxOpeningFragment,
+    isJsxOpeningLikeElement: () => isJsxOpeningLikeElement,
+    isJsxOpeningLikeElementTagName: () => isJsxOpeningLikeElementTagName,
+    isJsxSelfClosingElement: () => isJsxSelfClosingElement,
+    isJsxSpreadAttribute: () => isJsxSpreadAttribute,
+    isJsxTagNameExpression: () => isJsxTagNameExpression,
+    isJsxText: () => isJsxText,
+    isJumpStatementTarget: () => isJumpStatementTarget,
+    isKeyword: () => isKeyword,
+    isKeywordOrPunctuation: () => isKeywordOrPunctuation,
+    isKnownSymbol: () => isKnownSymbol,
+    isLabelName: () => isLabelName,
+    isLabelOfLabeledStatement: () => isLabelOfLabeledStatement,
+    isLabeledStatement: () => isLabeledStatement,
+    isLateVisibilityPaintedStatement: () => isLateVisibilityPaintedStatement,
+    isLeftHandSideExpression: () => isLeftHandSideExpression,
+    isLeftHandSideOfAssignment: () => isLeftHandSideOfAssignment,
+    isLet: () => isLet,
+    isLineBreak: () => isLineBreak,
+    isLiteralComputedPropertyDeclarationName: () => isLiteralComputedPropertyDeclarationName,
+    isLiteralExpression: () => isLiteralExpression,
+    isLiteralExpressionOfObject: () => isLiteralExpressionOfObject,
+    isLiteralImportTypeNode: () => isLiteralImportTypeNode,
+    isLiteralKind: () => isLiteralKind,
+    isLiteralLikeAccess: () => isLiteralLikeAccess,
+    isLiteralLikeElementAccess: () => isLiteralLikeElementAccess,
+    isLiteralNameOfPropertyDeclarationOrIndexAccess: () => isLiteralNameOfPropertyDeclarationOrIndexAccess,
+    isLiteralTypeLikeExpression: () => isLiteralTypeLikeExpression,
+    isLiteralTypeLiteral: () => isLiteralTypeLiteral,
+    isLiteralTypeNode: () => isLiteralTypeNode,
+    isLocalName: () => isLocalName,
+    isLogicalOperator: () => isLogicalOperator,
+    isLogicalOrCoalescingAssignmentExpression: () => isLogicalOrCoalescingAssignmentExpression,
+    isLogicalOrCoalescingAssignmentOperator: () => isLogicalOrCoalescingAssignmentOperator,
+    isLogicalOrCoalescingBinaryExpression: () => isLogicalOrCoalescingBinaryExpression,
+    isLogicalOrCoalescingBinaryOperator: () => isLogicalOrCoalescingBinaryOperator,
+    isMappedTypeNode: () => isMappedTypeNode,
+    isMemberName: () => isMemberName,
+    isMetaProperty: () => isMetaProperty,
+    isMethodDeclaration: () => isMethodDeclaration,
+    isMethodOrAccessor: () => isMethodOrAccessor,
+    isMethodSignature: () => isMethodSignature,
+    isMinusToken: () => isMinusToken,
+    isMissingDeclaration: () => isMissingDeclaration,
+    isModifier: () => isModifier,
+    isModifierKind: () => isModifierKind,
+    isModifierLike: () => isModifierLike,
+    isModuleAugmentationExternal: () => isModuleAugmentationExternal,
+    isModuleBlock: () => isModuleBlock,
+    isModuleBody: () => isModuleBody,
+    isModuleDeclaration: () => isModuleDeclaration,
+    isModuleExportsAccessExpression: () => isModuleExportsAccessExpression,
+    isModuleIdentifier: () => isModuleIdentifier,
+    isModuleName: () => isModuleName,
+    isModuleOrEnumDeclaration: () => isModuleOrEnumDeclaration,
+    isModuleReference: () => isModuleReference,
+    isModuleSpecifierLike: () => isModuleSpecifierLike,
+    isModuleWithStringLiteralName: () => isModuleWithStringLiteralName,
+    isNameOfFunctionDeclaration: () => isNameOfFunctionDeclaration,
+    isNameOfModuleDeclaration: () => isNameOfModuleDeclaration,
+    isNamedClassElement: () => isNamedClassElement,
+    isNamedDeclaration: () => isNamedDeclaration,
+    isNamedEvaluation: () => isNamedEvaluation,
+    isNamedEvaluationSource: () => isNamedEvaluationSource,
+    isNamedExportBindings: () => isNamedExportBindings,
+    isNamedExports: () => isNamedExports,
+    isNamedImportBindings: () => isNamedImportBindings,
+    isNamedImports: () => isNamedImports,
+    isNamedImportsOrExports: () => isNamedImportsOrExports,
+    isNamedTupleMember: () => isNamedTupleMember,
+    isNamespaceBody: () => isNamespaceBody,
+    isNamespaceExport: () => isNamespaceExport,
+    isNamespaceExportDeclaration: () => isNamespaceExportDeclaration,
+    isNamespaceImport: () => isNamespaceImport,
+    isNamespaceReexportDeclaration: () => isNamespaceReexportDeclaration,
+    isNewExpression: () => isNewExpression,
+    isNewExpressionTarget: () => isNewExpressionTarget,
+    isNoSubstitutionTemplateLiteral: () => isNoSubstitutionTemplateLiteral,
+    isNode: () => isNode,
+    isNodeArray: () => isNodeArray,
+    isNodeArrayMultiLine: () => isNodeArrayMultiLine,
+    isNodeDescendantOf: () => isNodeDescendantOf,
+    isNodeKind: () => isNodeKind,
+    isNodeLikeSystem: () => isNodeLikeSystem,
+    isNodeModulesDirectory: () => isNodeModulesDirectory,
+    isNodeWithPossibleHoistedDeclaration: () => isNodeWithPossibleHoistedDeclaration,
+    isNonContextualKeyword: () => isNonContextualKeyword,
+    isNonExportDefaultModifier: () => isNonExportDefaultModifier,
+    isNonGlobalAmbientModule: () => isNonGlobalAmbientModule,
+    isNonGlobalDeclaration: () => isNonGlobalDeclaration,
+    isNonNullAccess: () => isNonNullAccess,
+    isNonNullChain: () => isNonNullChain,
+    isNonNullExpression: () => isNonNullExpression,
+    isNonStaticMethodOrAccessorWithPrivateName: () => isNonStaticMethodOrAccessorWithPrivateName,
+    isNotEmittedOrPartiallyEmittedNode: () => isNotEmittedOrPartiallyEmittedNode,
+    isNotEmittedStatement: () => isNotEmittedStatement,
+    isNullishCoalesce: () => isNullishCoalesce,
+    isNumber: () => isNumber,
+    isNumericLiteral: () => isNumericLiteral,
+    isNumericLiteralName: () => isNumericLiteralName,
+    isObjectBindingElementWithoutPropertyName: () => isObjectBindingElementWithoutPropertyName,
+    isObjectBindingOrAssignmentElement: () => isObjectBindingOrAssignmentElement,
+    isObjectBindingOrAssignmentPattern: () => isObjectBindingOrAssignmentPattern,
+    isObjectBindingPattern: () => isObjectBindingPattern,
+    isObjectLiteralElement: () => isObjectLiteralElement,
+    isObjectLiteralElementLike: () => isObjectLiteralElementLike,
+    isObjectLiteralExpression: () => isObjectLiteralExpression,
+    isObjectLiteralMethod: () => isObjectLiteralMethod,
+    isObjectLiteralOrClassExpressionMethodOrAccessor: () => isObjectLiteralOrClassExpressionMethodOrAccessor,
+    isObjectTypeDeclaration: () => isObjectTypeDeclaration,
+    isOctalDigit: () => isOctalDigit,
+    isOmittedExpression: () => isOmittedExpression,
+    isOptionalChain: () => isOptionalChain,
+    isOptionalChainRoot: () => isOptionalChainRoot,
+    isOptionalDeclaration: () => isOptionalDeclaration,
+    isOptionalJSDocPropertyLikeTag: () => isOptionalJSDocPropertyLikeTag,
+    isOptionalTypeNode: () => isOptionalTypeNode,
+    isOuterExpression: () => isOuterExpression,
+    isOutermostOptionalChain: () => isOutermostOptionalChain,
+    isOverrideModifier: () => isOverrideModifier,
+    isPackedArrayLiteral: () => isPackedArrayLiteral,
+    isParameter: () => isParameter,
+    isParameterDeclaration: () => isParameterDeclaration,
+    isParameterOrCatchClauseVariable: () => isParameterOrCatchClauseVariable,
+    isParameterPropertyDeclaration: () => isParameterPropertyDeclaration,
+    isParameterPropertyModifier: () => isParameterPropertyModifier,
+    isParenthesizedExpression: () => isParenthesizedExpression,
+    isParenthesizedTypeNode: () => isParenthesizedTypeNode,
+    isParseTreeNode: () => isParseTreeNode,
+    isPartOfTypeNode: () => isPartOfTypeNode,
+    isPartOfTypeQuery: () => isPartOfTypeQuery,
+    isPartiallyEmittedExpression: () => isPartiallyEmittedExpression,
+    isPatternMatch: () => isPatternMatch,
+    isPinnedComment: () => isPinnedComment,
+    isPlainJsFile: () => isPlainJsFile,
+    isPlusToken: () => isPlusToken,
+    isPossiblyTypeArgumentPosition: () => isPossiblyTypeArgumentPosition,
+    isPostfixUnaryExpression: () => isPostfixUnaryExpression,
+    isPrefixUnaryExpression: () => isPrefixUnaryExpression,
+    isPrivateIdentifier: () => isPrivateIdentifier,
+    isPrivateIdentifierClassElementDeclaration: () => isPrivateIdentifierClassElementDeclaration,
+    isPrivateIdentifierPropertyAccessExpression: () => isPrivateIdentifierPropertyAccessExpression,
+    isPrivateIdentifierSymbol: () => isPrivateIdentifierSymbol,
+    isProgramBundleEmitBuildInfo: () => isProgramBundleEmitBuildInfo,
+    isProgramUptoDate: () => isProgramUptoDate,
+    isPrologueDirective: () => isPrologueDirective,
+    isPropertyAccessChain: () => isPropertyAccessChain,
+    isPropertyAccessEntityNameExpression: () => isPropertyAccessEntityNameExpression,
+    isPropertyAccessExpression: () => isPropertyAccessExpression,
+    isPropertyAccessOrQualifiedName: () => isPropertyAccessOrQualifiedName,
+    isPropertyAccessOrQualifiedNameOrImportTypeNode: () => isPropertyAccessOrQualifiedNameOrImportTypeNode,
+    isPropertyAssignment: () => isPropertyAssignment,
+    isPropertyDeclaration: () => isPropertyDeclaration,
+    isPropertyName: () => isPropertyName,
+    isPropertyNameLiteral: () => isPropertyNameLiteral,
+    isPropertySignature: () => isPropertySignature,
+    isProtoSetter: () => isProtoSetter,
+    isPrototypeAccess: () => isPrototypeAccess,
+    isPrototypePropertyAssignment: () => isPrototypePropertyAssignment,
+    isPunctuation: () => isPunctuation,
+    isPushOrUnshiftIdentifier: () => isPushOrUnshiftIdentifier,
+    isQualifiedName: () => isQualifiedName,
+    isQuestionDotToken: () => isQuestionDotToken,
+    isQuestionOrExclamationToken: () => isQuestionOrExclamationToken,
+    isQuestionOrPlusOrMinusToken: () => isQuestionOrPlusOrMinusToken,
+    isQuestionToken: () => isQuestionToken,
+    isRawSourceMap: () => isRawSourceMap,
+    isReadonlyKeyword: () => isReadonlyKeyword,
+    isReadonlyKeywordOrPlusOrMinusToken: () => isReadonlyKeywordOrPlusOrMinusToken,
+    isRecognizedTripleSlashComment: () => isRecognizedTripleSlashComment,
+    isReferenceFileLocation: () => isReferenceFileLocation,
+    isReferencedFile: () => isReferencedFile,
+    isRegularExpressionLiteral: () => isRegularExpressionLiteral,
+    isRequireCall: () => isRequireCall,
+    isRequireVariableStatement: () => isRequireVariableStatement,
+    isRestParameter: () => isRestParameter,
+    isRestTypeNode: () => isRestTypeNode,
+    isReturnStatement: () => isReturnStatement,
+    isReturnStatementWithFixablePromiseHandler: () => isReturnStatementWithFixablePromiseHandler,
+    isRightSideOfAccessExpression: () => isRightSideOfAccessExpression,
+    isRightSideOfInstanceofExpression: () => isRightSideOfInstanceofExpression,
+    isRightSideOfPropertyAccess: () => isRightSideOfPropertyAccess,
+    isRightSideOfQualifiedName: () => isRightSideOfQualifiedName,
+    isRightSideOfQualifiedNameOrPropertyAccess: () => isRightSideOfQualifiedNameOrPropertyAccess,
+    isRightSideOfQualifiedNameOrPropertyAccessOrJSDocMemberName: () => isRightSideOfQualifiedNameOrPropertyAccessOrJSDocMemberName,
+    isRootedDiskPath: () => isRootedDiskPath,
+    isSameEntityName: () => isSameEntityName,
+    isSatisfiesExpression: () => isSatisfiesExpression,
+    isScopeMarker: () => isScopeMarker,
+    isSemicolonClassElement: () => isSemicolonClassElement,
+    isSetAccessor: () => isSetAccessor,
+    isSetAccessorDeclaration: () => isSetAccessorDeclaration,
+    isShebangTrivia: () => isShebangTrivia,
+    isShiftOperatorOrHigher: () => isShiftOperatorOrHigher,
+    isShorthandAmbientModuleSymbol: () => isShorthandAmbientModuleSymbol,
+    isShorthandPropertyAssignment: () => isShorthandPropertyAssignment,
+    isSignedNumericLiteral: () => isSignedNumericLiteral,
+    isSimpleCopiableExpression: () => isSimpleCopiableExpression,
+    isSimpleInlineableExpression: () => isSimpleInlineableExpression,
+    isSingleOrDoubleQuote: () => isSingleOrDoubleQuote,
+    isSourceFile: () => isSourceFile,
+    isSourceFileFromLibrary: () => isSourceFileFromLibrary,
+    isSourceFileJS: () => isSourceFileJS,
+    isSourceFileNotJS: () => isSourceFileNotJS,
+    isSourceFileNotJson: () => isSourceFileNotJson,
+    isSourceMapping: () => isSourceMapping,
+    isSpecialPropertyDeclaration: () => isSpecialPropertyDeclaration,
+    isSpreadAssignment: () => isSpreadAssignment,
+    isSpreadElement: () => isSpreadElement,
+    isStatement: () => isStatement,
+    isStatementButNotDeclaration: () => isStatementButNotDeclaration,
+    isStatementOrBlock: () => isStatementOrBlock,
+    isStatementWithLocals: () => isStatementWithLocals,
+    isStatic: () => isStatic,
+    isStaticModifier: () => isStaticModifier,
+    isString: () => isString,
+    isStringAKeyword: () => isStringAKeyword,
+    isStringANonContextualKeyword: () => isStringANonContextualKeyword,
+    isStringAndEmptyAnonymousObjectIntersection: () => isStringAndEmptyAnonymousObjectIntersection,
+    isStringDoubleQuoted: () => isStringDoubleQuoted,
+    isStringLiteral: () => isStringLiteral,
+    isStringLiteralLike: () => isStringLiteralLike,
+    isStringLiteralOrJsxExpression: () => isStringLiteralOrJsxExpression,
+    isStringLiteralOrTemplate: () => isStringLiteralOrTemplate,
+    isStringOrNumericLiteralLike: () => isStringOrNumericLiteralLike,
+    isStringOrRegularExpressionOrTemplateLiteral: () => isStringOrRegularExpressionOrTemplateLiteral,
+    isStringTextContainingNode: () => isStringTextContainingNode,
+    isSuperCall: () => isSuperCall,
+    isSuperKeyword: () => isSuperKeyword,
+    isSuperOrSuperProperty: () => isSuperOrSuperProperty,
+    isSuperProperty: () => isSuperProperty,
+    isSupportedSourceFileName: () => isSupportedSourceFileName,
+    isSwitchStatement: () => isSwitchStatement,
+    isSyntaxList: () => isSyntaxList,
+    isSyntheticExpression: () => isSyntheticExpression,
+    isSyntheticReference: () => isSyntheticReference,
+    isTagName: () => isTagName,
+    isTaggedTemplateExpression: () => isTaggedTemplateExpression,
+    isTaggedTemplateTag: () => isTaggedTemplateTag,
+    isTemplateExpression: () => isTemplateExpression,
+    isTemplateHead: () => isTemplateHead,
+    isTemplateLiteral: () => isTemplateLiteral,
+    isTemplateLiteralKind: () => isTemplateLiteralKind,
+    isTemplateLiteralToken: () => isTemplateLiteralToken,
+    isTemplateLiteralTypeNode: () => isTemplateLiteralTypeNode,
+    isTemplateLiteralTypeSpan: () => isTemplateLiteralTypeSpan,
+    isTemplateMiddle: () => isTemplateMiddle,
+    isTemplateMiddleOrTemplateTail: () => isTemplateMiddleOrTemplateTail,
+    isTemplateSpan: () => isTemplateSpan,
+    isTemplateTail: () => isTemplateTail,
+    isTextWhiteSpaceLike: () => isTextWhiteSpaceLike,
+    isThis: () => isThis,
+    isThisContainerOrFunctionBlock: () => isThisContainerOrFunctionBlock,
+    isThisIdentifier: () => isThisIdentifier,
+    isThisInTypeQuery: () => isThisInTypeQuery,
+    isThisInitializedDeclaration: () => isThisInitializedDeclaration,
+    isThisInitializedObjectBindingExpression: () => isThisInitializedObjectBindingExpression,
+    isThisProperty: () => isThisProperty,
+    isThisTypeNode: () => isThisTypeNode,
+    isThisTypeParameter: () => isThisTypeParameter,
+    isThisTypePredicate: () => isThisTypePredicate,
+    isThrowStatement: () => isThrowStatement,
+    isToken: () => isToken,
+    isTokenKind: () => isTokenKind,
+    isTraceEnabled: () => isTraceEnabled,
+    isTransientSymbol: () => isTransientSymbol,
+    isTrivia: () => isTrivia,
+    isTryStatement: () => isTryStatement,
+    isTupleTypeNode: () => isTupleTypeNode,
+    isTypeAlias: () => isTypeAlias,
+    isTypeAliasDeclaration: () => isTypeAliasDeclaration,
+    isTypeAssertionExpression: () => isTypeAssertionExpression,
+    isTypeDeclaration: () => isTypeDeclaration,
+    isTypeElement: () => isTypeElement,
+    isTypeKeyword: () => isTypeKeyword,
+    isTypeKeywordToken: () => isTypeKeywordToken,
+    isTypeKeywordTokenOrIdentifier: () => isTypeKeywordTokenOrIdentifier,
+    isTypeLiteralNode: () => isTypeLiteralNode,
+    isTypeNode: () => isTypeNode,
+    isTypeNodeKind: () => isTypeNodeKind,
+    isTypeOfExpression: () => isTypeOfExpression,
+    isTypeOnlyExportDeclaration: () => isTypeOnlyExportDeclaration,
+    isTypeOnlyImportDeclaration: () => isTypeOnlyImportDeclaration,
+    isTypeOnlyImportOrExportDeclaration: () => isTypeOnlyImportOrExportDeclaration,
+    isTypeOperatorNode: () => isTypeOperatorNode,
+    isTypeParameterDeclaration: () => isTypeParameterDeclaration,
+    isTypePredicateNode: () => isTypePredicateNode,
+    isTypeQueryNode: () => isTypeQueryNode,
+    isTypeReferenceNode: () => isTypeReferenceNode,
+    isTypeReferenceType: () => isTypeReferenceType,
+    isTypeUsableAsPropertyName: () => isTypeUsableAsPropertyName,
+    isUMDExportSymbol: () => isUMDExportSymbol,
+    isUnaryExpression: () => isUnaryExpression,
+    isUnaryExpressionWithWrite: () => isUnaryExpressionWithWrite,
+    isUnicodeIdentifierStart: () => isUnicodeIdentifierStart,
+    isUnionTypeNode: () => isUnionTypeNode,
+    isUnparsedNode: () => isUnparsedNode,
+    isUnparsedPrepend: () => isUnparsedPrepend,
+    isUnparsedSource: () => isUnparsedSource,
+    isUnparsedTextLike: () => isUnparsedTextLike,
+    isUrl: () => isUrl,
+    isValidBigIntString: () => isValidBigIntString,
+    isValidESSymbolDeclaration: () => isValidESSymbolDeclaration,
+    isValidTypeOnlyAliasUseSite: () => isValidTypeOnlyAliasUseSite,
+    isValueSignatureDeclaration: () => isValueSignatureDeclaration,
+    isVarAwaitUsing: () => isVarAwaitUsing,
+    isVarConst: () => isVarConst,
+    isVarUsing: () => isVarUsing,
+    isVariableDeclaration: () => isVariableDeclaration,
+    isVariableDeclarationInVariableStatement: () => isVariableDeclarationInVariableStatement,
+    isVariableDeclarationInitializedToBareOrAccessedRequire: () => isVariableDeclarationInitializedToBareOrAccessedRequire,
+    isVariableDeclarationInitializedToRequire: () => isVariableDeclarationInitializedToRequire,
+    isVariableDeclarationList: () => isVariableDeclarationList,
+    isVariableLike: () => isVariableLike,
+    isVariableLikeOrAccessor: () => isVariableLikeOrAccessor,
+    isVariableStatement: () => isVariableStatement,
+    isVoidExpression: () => isVoidExpression,
+    isWatchSet: () => isWatchSet,
+    isWhileStatement: () => isWhileStatement,
+    isWhiteSpaceLike: () => isWhiteSpaceLike,
+    isWhiteSpaceSingleLine: () => isWhiteSpaceSingleLine,
+    isWithStatement: () => isWithStatement,
+    isWriteAccess: () => isWriteAccess,
+    isWriteOnlyAccess: () => isWriteOnlyAccess,
+    isYieldExpression: () => isYieldExpression,
+    jsxModeNeedsExplicitImport: () => jsxModeNeedsExplicitImport,
+    keywordPart: () => keywordPart,
+    last: () => last,
+    lastOrUndefined: () => lastOrUndefined,
+    length: () => length,
+    libMap: () => libMap,
+    libs: () => libs,
+    lineBreakPart: () => lineBreakPart,
+    linkNamePart: () => linkNamePart,
+    linkPart: () => linkPart,
+    linkTextPart: () => linkTextPart,
+    listFiles: () => listFiles,
+    loadModuleFromGlobalCache: () => loadModuleFromGlobalCache,
+    loadWithModeAwareCache: () => loadWithModeAwareCache,
+    makeIdentifierFromModuleName: () => makeIdentifierFromModuleName,
+    makeImport: () => makeImport,
+    makeImportIfNecessary: () => makeImportIfNecessary,
+    makeStringLiteral: () => makeStringLiteral,
+    mangleScopedPackageName: () => mangleScopedPackageName,
+    map: () => map,
+    mapAllOrFail: () => mapAllOrFail,
+    mapDefined: () => mapDefined,
+    mapDefinedEntries: () => mapDefinedEntries,
+    mapDefinedIterator: () => mapDefinedIterator,
+    mapEntries: () => mapEntries,
+    mapIterator: () => mapIterator,
+    mapOneOrMany: () => mapOneOrMany,
+    mapToDisplayParts: () => mapToDisplayParts,
+    matchFiles: () => matchFiles,
+    matchPatternOrExact: () => matchPatternOrExact,
+    matchedText: () => matchedText,
+    matchesExclude: () => matchesExclude,
+    maybeBind: () => maybeBind,
+    maybeSetLocalizedDiagnosticMessages: () => maybeSetLocalizedDiagnosticMessages,
+    memoize: () => memoize,
+    memoizeCached: () => memoizeCached,
+    memoizeOne: () => memoizeOne,
+    memoizeWeak: () => memoizeWeak,
+    metadataHelper: () => metadataHelper,
+    min: () => min,
+    minAndMax: () => minAndMax,
+    missingFileModifiedTime: () => missingFileModifiedTime,
+    modifierToFlag: () => modifierToFlag,
+    modifiersToFlags: () => modifiersToFlags,
+    moduleOptionDeclaration: () => moduleOptionDeclaration,
+    moduleResolutionIsEqualTo: () => moduleResolutionIsEqualTo,
+    moduleResolutionNameAndModeGetter: () => moduleResolutionNameAndModeGetter,
+    moduleResolutionOptionDeclarations: () => moduleResolutionOptionDeclarations,
+    moduleResolutionSupportsPackageJsonExportsAndImports: () => moduleResolutionSupportsPackageJsonExportsAndImports,
+    moduleResolutionUsesNodeModules: () => moduleResolutionUsesNodeModules,
+    moduleSpecifiers: () => ts_moduleSpecifiers_exports,
+    moveEmitHelpers: () => moveEmitHelpers,
+    moveRangeEnd: () => moveRangeEnd,
+    moveRangePastDecorators: () => moveRangePastDecorators,
+    moveRangePastModifiers: () => moveRangePastModifiers,
+    moveRangePos: () => moveRangePos,
+    moveSyntheticComments: () => moveSyntheticComments,
+    mutateMap: () => mutateMap,
+    mutateMapSkippingNewValues: () => mutateMapSkippingNewValues,
+    needsParentheses: () => needsParentheses,
+    needsScopeMarker: () => needsScopeMarker,
+    newCaseClauseTracker: () => newCaseClauseTracker,
+    newPrivateEnvironment: () => newPrivateEnvironment,
+    noEmitNotification: () => noEmitNotification,
+    noEmitSubstitution: () => noEmitSubstitution,
+    noTransformers: () => noTransformers,
+    noTruncationMaximumTruncationLength: () => noTruncationMaximumTruncationLength,
+    nodeCanBeDecorated: () => nodeCanBeDecorated,
+    nodeHasName: () => nodeHasName,
+    nodeIsDecorated: () => nodeIsDecorated,
+    nodeIsMissing: () => nodeIsMissing,
+    nodeIsPresent: () => nodeIsPresent,
+    nodeIsSynthesized: () => nodeIsSynthesized,
+    nodeModuleNameResolver: () => nodeModuleNameResolver,
+    nodeModulesPathPart: () => nodeModulesPathPart,
+    nodeNextJsonConfigResolver: () => nodeNextJsonConfigResolver,
+    nodeOrChildIsDecorated: () => nodeOrChildIsDecorated,
+    nodeOverlapsWithStartEnd: () => nodeOverlapsWithStartEnd,
+    nodePosToString: () => nodePosToString,
+    nodeSeenTracker: () => nodeSeenTracker,
+    nodeStartsNewLexicalEnvironment: () => nodeStartsNewLexicalEnvironment,
+    nodeToDisplayParts: () => nodeToDisplayParts,
+    noop: () => noop,
+    noopFileWatcher: () => noopFileWatcher,
+    normalizePath: () => normalizePath,
+    normalizeSlashes: () => normalizeSlashes,
+    not: () => not,
+    notImplemented: () => notImplemented,
+    notImplementedResolver: () => notImplementedResolver,
+    nullNodeConverters: () => nullNodeConverters,
+    nullParenthesizerRules: () => nullParenthesizerRules,
+    nullTransformationContext: () => nullTransformationContext,
+    objectAllocator: () => objectAllocator,
+    operatorPart: () => operatorPart,
+    optionDeclarations: () => optionDeclarations,
+    optionMapToObject: () => optionMapToObject,
+    optionsAffectingProgramStructure: () => optionsAffectingProgramStructure,
+    optionsForBuild: () => optionsForBuild,
+    optionsForWatch: () => optionsForWatch,
+    optionsHaveChanges: () => optionsHaveChanges,
+    optionsHaveModuleResolutionChanges: () => optionsHaveModuleResolutionChanges,
+    or: () => or,
+    orderedRemoveItem: () => orderedRemoveItem,
+    orderedRemoveItemAt: () => orderedRemoveItemAt,
+    outFile: () => outFile,
+    packageIdToPackageName: () => packageIdToPackageName,
+    packageIdToString: () => packageIdToString,
+    paramHelper: () => paramHelper,
+    parameterIsThisKeyword: () => parameterIsThisKeyword,
+    parameterNamePart: () => parameterNamePart,
+    parseBaseNodeFactory: () => parseBaseNodeFactory,
+    parseBigInt: () => parseBigInt,
+    parseBuildCommand: () => parseBuildCommand,
+    parseCommandLine: () => parseCommandLine,
+    parseCommandLineWorker: () => parseCommandLineWorker,
+    parseConfigFileTextToJson: () => parseConfigFileTextToJson,
+    parseConfigFileWithSystem: () => parseConfigFileWithSystem,
+    parseConfigHostFromCompilerHostLike: () => parseConfigHostFromCompilerHostLike,
+    parseCustomTypeOption: () => parseCustomTypeOption,
+    parseIsolatedEntityName: () => parseIsolatedEntityName,
+    parseIsolatedJSDocComment: () => parseIsolatedJSDocComment,
+    parseJSDocTypeExpressionForTests: () => parseJSDocTypeExpressionForTests,
+    parseJsonConfigFileContent: () => parseJsonConfigFileContent,
+    parseJsonSourceFileConfigFileContent: () => parseJsonSourceFileConfigFileContent,
+    parseJsonText: () => parseJsonText,
+    parseListTypeOption: () => parseListTypeOption,
+    parseNodeFactory: () => parseNodeFactory,
+    parseNodeModuleFromPath: () => parseNodeModuleFromPath,
+    parsePackageName: () => parsePackageName,
+    parsePseudoBigInt: () => parsePseudoBigInt,
+    parseValidBigInt: () => parseValidBigInt,
+    patchWriteFileEnsuringDirectory: () => patchWriteFileEnsuringDirectory,
+    pathContainsNodeModules: () => pathContainsNodeModules,
+    pathIsAbsolute: () => pathIsAbsolute,
+    pathIsBareSpecifier: () => pathIsBareSpecifier,
+    pathIsRelative: () => pathIsRelative,
+    patternText: () => patternText,
+    perfLogger: () => perfLogger,
+    performIncrementalCompilation: () => performIncrementalCompilation,
+    performance: () => ts_performance_exports,
+    plainJSErrors: () => plainJSErrors,
+    positionBelongsToNode: () => positionBelongsToNode,
+    positionIsASICandidate: () => positionIsASICandidate,
+    positionIsSynthesized: () => positionIsSynthesized,
+    positionsAreOnSameLine: () => positionsAreOnSameLine,
+    preProcessFile: () => preProcessFile,
+    probablyUsesSemicolons: () => probablyUsesSemicolons,
+    processCommentPragmas: () => processCommentPragmas,
+    processPragmasIntoFields: () => processPragmasIntoFields,
+    processTaggedTemplateExpression: () => processTaggedTemplateExpression,
+    programContainsEsModules: () => programContainsEsModules,
+    programContainsModules: () => programContainsModules,
+    projectReferenceIsEqualTo: () => projectReferenceIsEqualTo,
+    propKeyHelper: () => propKeyHelper,
+    propertyNamePart: () => propertyNamePart,
+    pseudoBigIntToString: () => pseudoBigIntToString,
+    punctuationPart: () => punctuationPart,
+    pushIfUnique: () => pushIfUnique,
+    quote: () => quote,
+    quotePreferenceFromString: () => quotePreferenceFromString,
+    rangeContainsPosition: () => rangeContainsPosition,
+    rangeContainsPositionExclusive: () => rangeContainsPositionExclusive,
+    rangeContainsRange: () => rangeContainsRange,
+    rangeContainsRangeExclusive: () => rangeContainsRangeExclusive,
+    rangeContainsStartEnd: () => rangeContainsStartEnd,
+    rangeEndIsOnSameLineAsRangeStart: () => rangeEndIsOnSameLineAsRangeStart,
+    rangeEndPositionsAreOnSameLine: () => rangeEndPositionsAreOnSameLine,
+    rangeEquals: () => rangeEquals,
+    rangeIsOnSingleLine: () => rangeIsOnSingleLine,
+    rangeOfNode: () => rangeOfNode,
+    rangeOfTypeParameters: () => rangeOfTypeParameters,
+    rangeOverlapsWithStartEnd: () => rangeOverlapsWithStartEnd,
+    rangeStartIsOnSameLineAsRangeEnd: () => rangeStartIsOnSameLineAsRangeEnd,
+    rangeStartPositionsAreOnSameLine: () => rangeStartPositionsAreOnSameLine,
+    readBuilderProgram: () => readBuilderProgram,
+    readConfigFile: () => readConfigFile,
+    readHelper: () => readHelper,
+    readJson: () => readJson,
+    readJsonConfigFile: () => readJsonConfigFile,
+    readJsonOrUndefined: () => readJsonOrUndefined,
+    reduceEachLeadingCommentRange: () => reduceEachLeadingCommentRange,
+    reduceEachTrailingCommentRange: () => reduceEachTrailingCommentRange,
+    reduceLeft: () => reduceLeft,
+    reduceLeftIterator: () => reduceLeftIterator,
+    reducePathComponents: () => reducePathComponents,
+    refactor: () => ts_refactor_exports,
+    regExpEscape: () => regExpEscape,
+    relativeComplement: () => relativeComplement,
+    removeAllComments: () => removeAllComments,
+    removeEmitHelper: () => removeEmitHelper,
+    removeExtension: () => removeExtension,
+    removeFileExtension: () => removeFileExtension,
+    removeIgnoredPath: () => removeIgnoredPath,
+    removeMinAndVersionNumbers: () => removeMinAndVersionNumbers,
+    removeOptionality: () => removeOptionality,
+    removePrefix: () => removePrefix,
+    removeSuffix: () => removeSuffix,
+    removeTrailingDirectorySeparator: () => removeTrailingDirectorySeparator,
+    repeatString: () => repeatString,
+    replaceElement: () => replaceElement,
+    resolutionExtensionIsTSOrJson: () => resolutionExtensionIsTSOrJson,
+    resolveConfigFileProjectName: () => resolveConfigFileProjectName,
+    resolveJSModule: () => resolveJSModule,
+    resolveLibrary: () => resolveLibrary,
+    resolveModuleName: () => resolveModuleName,
+    resolveModuleNameFromCache: () => resolveModuleNameFromCache,
+    resolvePackageNameToPackageJson: () => resolvePackageNameToPackageJson,
+    resolvePath: () => resolvePath,
+    resolveProjectReferencePath: () => resolveProjectReferencePath,
+    resolveTripleslashReference: () => resolveTripleslashReference,
+    resolveTypeReferenceDirective: () => resolveTypeReferenceDirective,
+    resolvingEmptyArray: () => resolvingEmptyArray,
+    restHelper: () => restHelper,
+    returnFalse: () => returnFalse,
+    returnNoopFileWatcher: () => returnNoopFileWatcher,
+    returnTrue: () => returnTrue,
+    returnUndefined: () => returnUndefined,
+    returnsPromise: () => returnsPromise,
+    runInitializersHelper: () => runInitializersHelper,
+    sameFlatMap: () => sameFlatMap,
+    sameMap: () => sameMap,
+    sameMapping: () => sameMapping,
+    scanShebangTrivia: () => scanShebangTrivia,
+    scanTokenAtPosition: () => scanTokenAtPosition,
+    scanner: () => scanner,
+    screenStartingMessageCodes: () => screenStartingMessageCodes,
+    semanticDiagnosticsOptionDeclarations: () => semanticDiagnosticsOptionDeclarations,
+    serializeCompilerOptions: () => serializeCompilerOptions,
+    server: () => ts_server_exports3,
+    servicesVersion: () => servicesVersion,
+    setCommentRange: () => setCommentRange,
+    setConfigFileInOptions: () => setConfigFileInOptions,
+    setConstantValue: () => setConstantValue,
+    setEachParent: () => setEachParent,
+    setEmitFlags: () => setEmitFlags,
+    setFunctionNameHelper: () => setFunctionNameHelper,
+    setGetSourceFileAsHashVersioned: () => setGetSourceFileAsHashVersioned,
+    setIdentifierAutoGenerate: () => setIdentifierAutoGenerate,
+    setIdentifierGeneratedImportReference: () => setIdentifierGeneratedImportReference,
+    setIdentifierTypeArguments: () => setIdentifierTypeArguments,
+    setInternalEmitFlags: () => setInternalEmitFlags,
+    setLocalizedDiagnosticMessages: () => setLocalizedDiagnosticMessages,
+    setModuleDefaultHelper: () => setModuleDefaultHelper,
+    setNodeFlags: () => setNodeFlags,
+    setObjectAllocator: () => setObjectAllocator,
+    setOriginalNode: () => setOriginalNode,
+    setParent: () => setParent,
+    setParentRecursive: () => setParentRecursive,
+    setPrivateIdentifier: () => setPrivateIdentifier,
+    setSnippetElement: () => setSnippetElement,
+    setSourceMapRange: () => setSourceMapRange,
+    setStackTraceLimit: () => setStackTraceLimit,
+    setStartsOnNewLine: () => setStartsOnNewLine,
+    setSyntheticLeadingComments: () => setSyntheticLeadingComments,
+    setSyntheticTrailingComments: () => setSyntheticTrailingComments,
+    setSys: () => setSys,
+    setSysLog: () => setSysLog,
+    setTextRange: () => setTextRange,
+    setTextRangeEnd: () => setTextRangeEnd,
+    setTextRangePos: () => setTextRangePos,
+    setTextRangePosEnd: () => setTextRangePosEnd,
+    setTextRangePosWidth: () => setTextRangePosWidth,
+    setTokenSourceMapRange: () => setTokenSourceMapRange,
+    setTypeNode: () => setTypeNode,
+    setUILocale: () => setUILocale,
+    setValueDeclaration: () => setValueDeclaration,
+    shouldAllowImportingTsExtension: () => shouldAllowImportingTsExtension,
+    shouldPreserveConstEnums: () => shouldPreserveConstEnums,
+    shouldResolveJsRequire: () => shouldResolveJsRequire,
+    shouldUseUriStyleNodeCoreModules: () => shouldUseUriStyleNodeCoreModules,
+    showModuleSpecifier: () => showModuleSpecifier,
+    signatureHasLiteralTypes: () => signatureHasLiteralTypes,
+    signatureHasRestParameter: () => signatureHasRestParameter,
+    signatureToDisplayParts: () => signatureToDisplayParts,
+    single: () => single,
+    singleElementArray: () => singleElementArray,
+    singleIterator: () => singleIterator,
+    singleOrMany: () => singleOrMany,
+    singleOrUndefined: () => singleOrUndefined,
+    skipAlias: () => skipAlias,
+    skipAssertions: () => skipAssertions,
+    skipConstraint: () => skipConstraint,
+    skipOuterExpressions: () => skipOuterExpressions,
+    skipParentheses: () => skipParentheses,
+    skipPartiallyEmittedExpressions: () => skipPartiallyEmittedExpressions,
+    skipTrivia: () => skipTrivia,
+    skipTypeChecking: () => skipTypeChecking,
+    skipTypeParentheses: () => skipTypeParentheses,
+    skipWhile: () => skipWhile,
+    sliceAfter: () => sliceAfter,
+    some: () => some,
+    sort: () => sort,
+    sortAndDeduplicate: () => sortAndDeduplicate,
+    sortAndDeduplicateDiagnostics: () => sortAndDeduplicateDiagnostics,
+    sourceFileAffectingCompilerOptions: () => sourceFileAffectingCompilerOptions,
+    sourceFileMayBeEmitted: () => sourceFileMayBeEmitted,
+    sourceMapCommentRegExp: () => sourceMapCommentRegExp,
+    sourceMapCommentRegExpDontCareLineStart: () => sourceMapCommentRegExpDontCareLineStart,
+    spacePart: () => spacePart,
+    spanMap: () => spanMap,
+    spreadArrayHelper: () => spreadArrayHelper,
+    stableSort: () => stableSort,
+    startEndContainsRange: () => startEndContainsRange,
+    startEndOverlapsWithStartEnd: () => startEndOverlapsWithStartEnd,
+    startOnNewLine: () => startOnNewLine,
+    startTracing: () => startTracing,
+    startsWith: () => startsWith,
+    startsWithDirectory: () => startsWithDirectory,
+    startsWithUnderscore: () => startsWithUnderscore,
+    startsWithUseStrict: () => startsWithUseStrict,
+    stringContainsAt: () => stringContainsAt,
+    stringToToken: () => stringToToken,
+    stripQuotes: () => stripQuotes,
+    supportedDeclarationExtensions: () => supportedDeclarationExtensions,
+    supportedJSExtensions: () => supportedJSExtensions,
+    supportedJSExtensionsFlat: () => supportedJSExtensionsFlat,
+    supportedLocaleDirectories: () => supportedLocaleDirectories,
+    supportedTSExtensions: () => supportedTSExtensions,
+    supportedTSExtensionsFlat: () => supportedTSExtensionsFlat,
+    supportedTSImplementationExtensions: () => supportedTSImplementationExtensions,
+    suppressLeadingAndTrailingTrivia: () => suppressLeadingAndTrailingTrivia,
+    suppressLeadingTrivia: () => suppressLeadingTrivia,
+    suppressTrailingTrivia: () => suppressTrailingTrivia,
+    symbolEscapedNameNoDefault: () => symbolEscapedNameNoDefault,
+    symbolName: () => symbolName,
+    symbolNameNoDefault: () => symbolNameNoDefault,
+    symbolPart: () => symbolPart,
+    symbolToDisplayParts: () => symbolToDisplayParts,
+    syntaxMayBeASICandidate: () => syntaxMayBeASICandidate,
+    syntaxRequiresTrailingSemicolonOrASI: () => syntaxRequiresTrailingSemicolonOrASI,
+    sys: () => sys,
+    sysLog: () => sysLog,
+    tagNamesAreEquivalent: () => tagNamesAreEquivalent,
+    takeWhile: () => takeWhile,
+    targetOptionDeclaration: () => targetOptionDeclaration,
+    templateObjectHelper: () => templateObjectHelper,
+    testFormatSettings: () => testFormatSettings,
+    textChangeRangeIsUnchanged: () => textChangeRangeIsUnchanged,
+    textChangeRangeNewSpan: () => textChangeRangeNewSpan,
+    textChanges: () => ts_textChanges_exports,
+    textOrKeywordPart: () => textOrKeywordPart,
+    textPart: () => textPart,
+    textRangeContainsPositionInclusive: () => textRangeContainsPositionInclusive,
+    textSpanContainsPosition: () => textSpanContainsPosition,
+    textSpanContainsTextSpan: () => textSpanContainsTextSpan,
+    textSpanEnd: () => textSpanEnd,
+    textSpanIntersection: () => textSpanIntersection,
+    textSpanIntersectsWith: () => textSpanIntersectsWith,
+    textSpanIntersectsWithPosition: () => textSpanIntersectsWithPosition,
+    textSpanIntersectsWithTextSpan: () => textSpanIntersectsWithTextSpan,
+    textSpanIsEmpty: () => textSpanIsEmpty,
+    textSpanOverlap: () => textSpanOverlap,
+    textSpanOverlapsWith: () => textSpanOverlapsWith,
+    textSpansEqual: () => textSpansEqual,
+    textToKeywordObj: () => textToKeywordObj,
+    timestamp: () => timestamp,
+    toArray: () => toArray,
+    toBuilderFileEmit: () => toBuilderFileEmit,
+    toBuilderStateFileInfoForMultiEmit: () => toBuilderStateFileInfoForMultiEmit,
+    toEditorSettings: () => toEditorSettings,
+    toFileNameLowerCase: () => toFileNameLowerCase,
+    toLowerCase: () => toLowerCase,
+    toPath: () => toPath,
+    toProgramEmitPending: () => toProgramEmitPending,
+    tokenIsIdentifierOrKeyword: () => tokenIsIdentifierOrKeyword,
+    tokenIsIdentifierOrKeywordOrGreaterThan: () => tokenIsIdentifierOrKeywordOrGreaterThan,
+    tokenToString: () => tokenToString,
+    trace: () => trace,
+    tracing: () => tracing,
+    tracingEnabled: () => tracingEnabled,
+    transform: () => transform,
+    transformClassFields: () => transformClassFields,
+    transformDeclarations: () => transformDeclarations,
+    transformECMAScriptModule: () => transformECMAScriptModule,
+    transformES2015: () => transformES2015,
+    transformES2016: () => transformES2016,
+    transformES2017: () => transformES2017,
+    transformES2018: () => transformES2018,
+    transformES2019: () => transformES2019,
+    transformES2020: () => transformES2020,
+    transformES2021: () => transformES2021,
+    transformES5: () => transformES5,
+    transformESDecorators: () => transformESDecorators,
+    transformESNext: () => transformESNext,
+    transformGenerators: () => transformGenerators,
+    transformJsx: () => transformJsx,
+    transformLegacyDecorators: () => transformLegacyDecorators,
+    transformModule: () => transformModule,
+    transformNamedEvaluation: () => transformNamedEvaluation,
+    transformNodeModule: () => transformNodeModule,
+    transformNodes: () => transformNodes,
+    transformSystemModule: () => transformSystemModule,
+    transformTypeScript: () => transformTypeScript,
+    transpile: () => transpile,
+    transpileModule: () => transpileModule,
+    transpileOptionValueCompilerOptions: () => transpileOptionValueCompilerOptions,
+    tryAddToSet: () => tryAddToSet,
+    tryAndIgnoreErrors: () => tryAndIgnoreErrors,
+    tryCast: () => tryCast,
+    tryDirectoryExists: () => tryDirectoryExists,
+    tryExtractTSExtension: () => tryExtractTSExtension,
+    tryFileExists: () => tryFileExists,
+    tryGetClassExtendingExpressionWithTypeArguments: () => tryGetClassExtendingExpressionWithTypeArguments,
+    tryGetClassImplementingOrExtendingExpressionWithTypeArguments: () => tryGetClassImplementingOrExtendingExpressionWithTypeArguments,
+    tryGetDirectories: () => tryGetDirectories,
+    tryGetExtensionFromPath: () => tryGetExtensionFromPath2,
+    tryGetImportFromModuleSpecifier: () => tryGetImportFromModuleSpecifier,
+    tryGetJSDocSatisfiesTypeNode: () => tryGetJSDocSatisfiesTypeNode,
+    tryGetModuleNameFromFile: () => tryGetModuleNameFromFile,
+    tryGetModuleSpecifierFromDeclaration: () => tryGetModuleSpecifierFromDeclaration,
+    tryGetNativePerformanceHooks: () => tryGetNativePerformanceHooks,
+    tryGetPropertyAccessOrIdentifierToString: () => tryGetPropertyAccessOrIdentifierToString,
+    tryGetPropertyNameOfBindingOrAssignmentElement: () => tryGetPropertyNameOfBindingOrAssignmentElement,
+    tryGetSourceMappingURL: () => tryGetSourceMappingURL,
+    tryGetTextOfPropertyName: () => tryGetTextOfPropertyName,
+    tryIOAndConsumeErrors: () => tryIOAndConsumeErrors,
+    tryParsePattern: () => tryParsePattern,
+    tryParsePatterns: () => tryParsePatterns,
+    tryParseRawSourceMap: () => tryParseRawSourceMap,
+    tryReadDirectory: () => tryReadDirectory,
+    tryReadFile: () => tryReadFile,
+    tryRemoveDirectoryPrefix: () => tryRemoveDirectoryPrefix,
+    tryRemoveExtension: () => tryRemoveExtension,
+    tryRemovePrefix: () => tryRemovePrefix,
+    tryRemoveSuffix: () => tryRemoveSuffix,
+    typeAcquisitionDeclarations: () => typeAcquisitionDeclarations,
+    typeAliasNamePart: () => typeAliasNamePart,
+    typeDirectiveIsEqualTo: () => typeDirectiveIsEqualTo,
+    typeKeywords: () => typeKeywords,
+    typeParameterNamePart: () => typeParameterNamePart,
+    typeReferenceResolutionNameAndModeGetter: () => typeReferenceResolutionNameAndModeGetter,
+    typeToDisplayParts: () => typeToDisplayParts,
+    unchangedPollThresholds: () => unchangedPollThresholds,
+    unchangedTextChangeRange: () => unchangedTextChangeRange,
+    unescapeLeadingUnderscores: () => unescapeLeadingUnderscores,
+    unmangleScopedPackageName: () => unmangleScopedPackageName,
+    unorderedRemoveItem: () => unorderedRemoveItem,
+    unorderedRemoveItemAt: () => unorderedRemoveItemAt,
+    unreachableCodeIsError: () => unreachableCodeIsError,
+    unusedLabelIsError: () => unusedLabelIsError,
+    unwrapInnermostStatementOfLabel: () => unwrapInnermostStatementOfLabel,
+    updateErrorForNoInputFiles: () => updateErrorForNoInputFiles,
+    updateLanguageServiceSourceFile: () => updateLanguageServiceSourceFile,
+    updateMissingFilePathsWatch: () => updateMissingFilePathsWatch,
+    updatePackageJsonWatch: () => updatePackageJsonWatch,
+    updateResolutionField: () => updateResolutionField,
+    updateSharedExtendedConfigFileWatcher: () => updateSharedExtendedConfigFileWatcher,
+    updateSourceFile: () => updateSourceFile,
+    updateWatchingWildcardDirectories: () => updateWatchingWildcardDirectories,
+    usesExtensionsOnImports: () => usesExtensionsOnImports,
+    usingSingleLineStringWriter: () => usingSingleLineStringWriter,
+    utf16EncodeAsString: () => utf16EncodeAsString,
+    validateLocaleAndSetLanguage: () => validateLocaleAndSetLanguage,
+    valuesHelper: () => valuesHelper,
+    version: () => version,
+    versionMajorMinor: () => versionMajorMinor,
+    visitArray: () => visitArray,
+    visitCommaListElements: () => visitCommaListElements,
+    visitEachChild: () => visitEachChild,
+    visitFunctionBody: () => visitFunctionBody,
+    visitIterationBody: () => visitIterationBody,
+    visitLexicalEnvironment: () => visitLexicalEnvironment,
+    visitNode: () => visitNode,
+    visitNodes: () => visitNodes2,
+    visitParameterList: () => visitParameterList,
+    walkUpBindingElementsAndPatterns: () => walkUpBindingElementsAndPatterns,
+    walkUpLexicalEnvironments: () => walkUpLexicalEnvironments,
+    walkUpOuterExpressions: () => walkUpOuterExpressions,
+    walkUpParenthesizedExpressions: () => walkUpParenthesizedExpressions,
+    walkUpParenthesizedTypes: () => walkUpParenthesizedTypes,
+    walkUpParenthesizedTypesAndGetParentAndChild: () => walkUpParenthesizedTypesAndGetParentAndChild,
+    whitespaceOrMapCommentRegExp: () => whitespaceOrMapCommentRegExp,
+    writeCommentRange: () => writeCommentRange,
+    writeFile: () => writeFile,
+    writeFileEnsuringDirectories: () => writeFileEnsuringDirectories,
+    zipWith: () => zipWith
+  });
+  var init_ts7 = __esm({
+    "src/server/_namespaces/ts.ts"() {
       "use strict";
       init_ts2();
       init_ts3();
-      init_types3();
-      init_utilities4();
-      init_exportInfoMap();
-      init_classifier();
-      init_documentHighlights();
-      init_documentRegistry();
-      init_getEditsForFileRename();
-      init_patternMatcher();
-      init_preProcess();
-      init_sourcemaps();
-      init_suggestionDiagnostics();
-      init_transpile();
-      init_services();
-      init_transform();
-      init_shims();
-      init_ts_BreakpointResolver();
-      init_ts_CallHierarchy();
-      init_ts_classifier();
-      init_ts_codefix();
-      init_ts_Completions();
-      init_ts_FindAllReferences();
-      init_ts_GoToDefinition();
-      init_ts_InlayHints();
-      init_ts_JsDoc();
-      init_ts_NavigateTo();
-      init_ts_NavigationBar();
-      init_ts_OrganizeImports();
-      init_ts_OutliningElementsCollector();
-      init_ts_refactor();
-      init_ts_Rename();
-      init_ts_SignatureHelp();
-      init_ts_SmartSelectionRange();
-      init_ts_SymbolDisplay();
-      init_ts_textChanges();
-      init_ts_formatting();
-    }
-  });
-
-  // src/deprecatedCompat/deprecate.ts
-  function getTypeScriptVersion() {
-    return typeScriptVersion2 ?? (typeScriptVersion2 = new Version(version));
-  }
-  function formatDeprecationMessage(name, error, errorAfter, since, message) {
-    let deprecationMessage = error ? "DeprecationError: " : "DeprecationWarning: ";
-    deprecationMessage += `'${name}' `;
-    deprecationMessage += since ? `has been deprecated since v${since}` : "is deprecated";
-    deprecationMessage += error ? " and can no longer be used." : errorAfter ? ` and will no longer be usable after v${errorAfter}.` : ".";
-    deprecationMessage += message ? ` ${formatStringFromArgs(message, [name], 0)}` : "";
-    return deprecationMessage;
-  }
-  function createErrorDeprecation(name, errorAfter, since, message) {
-    const deprecationMessage = formatDeprecationMessage(
-      name,
-      /*error*/
-      true,
-      errorAfter,
-      since,
-      message
-    );
-    return () => {
-      throw new TypeError(deprecationMessage);
-    };
-  }
-  function createWarningDeprecation(name, errorAfter, since, message) {
-    let hasWrittenDeprecation = false;
-    return () => {
-      if (enableDeprecationWarnings && !hasWrittenDeprecation) {
-        Debug.log.warn(formatDeprecationMessage(
-          name,
-          /*error*/
-          false,
-          errorAfter,
-          since,
-          message
-        ));
-        hasWrittenDeprecation = true;
-      }
-    };
-  }
-  function createDeprecation(name, options = {}) {
-    const version2 = typeof options.typeScriptVersion === "string" ? new Version(options.typeScriptVersion) : options.typeScriptVersion ?? getTypeScriptVersion();
-    const errorAfter = typeof options.errorAfter === "string" ? new Version(options.errorAfter) : options.errorAfter;
-    const warnAfter = typeof options.warnAfter === "string" ? new Version(options.warnAfter) : options.warnAfter;
-    const since = typeof options.since === "string" ? new Version(options.since) : options.since ?? warnAfter;
-    const error = options.error || errorAfter && version2.compareTo(errorAfter) >= 0;
-    const warn = !warnAfter || version2.compareTo(warnAfter) >= 0;
-    return error ? createErrorDeprecation(name, errorAfter, since, options.message) : warn ? createWarningDeprecation(name, errorAfter, since, options.message) : noop;
-  }
-  function wrapFunction(deprecation, func) {
-    return function() {
-      deprecation();
-      return func.apply(this, arguments);
-    };
-  }
-  function deprecate(func, options) {
-    const deprecation = createDeprecation((options == null ? void 0 : options.name) ?? Debug.getFunctionName(func), options);
-    return wrapFunction(deprecation, func);
-  }
-  var enableDeprecationWarnings, typeScriptVersion2;
-  var init_deprecate = __esm({
-    "src/deprecatedCompat/deprecate.ts"() {
-      "use strict";
-      init_ts5();
-      enableDeprecationWarnings = true;
-    }
-  });
-
-  // src/deprecatedCompat/deprecations.ts
-  function createOverload(name, overloads, binder2, deprecations) {
-    Object.defineProperty(call, "name", { ...Object.getOwnPropertyDescriptor(call, "name"), value: name });
-    if (deprecations) {
-      for (const key of Object.keys(deprecations)) {
-        const index = +key;
-        if (!isNaN(index) && hasProperty(overloads, `${index}`)) {
-          overloads[index] = deprecate(overloads[index], { ...deprecations[index], name });
-        }
-      }
-    }
-    const bind = createBinder2(overloads, binder2);
-    return call;
-    function call(...args) {
-      const index = bind(args);
-      const fn = index !== void 0 ? overloads[index] : void 0;
-      if (typeof fn === "function") {
-        return fn(...args);
-      }
-      throw new TypeError("Invalid arguments");
-    }
-  }
-  function createBinder2(overloads, binder2) {
-    return (args) => {
-      for (let i = 0; hasProperty(overloads, `${i}`) && hasProperty(binder2, `${i}`); i++) {
-        const fn = binder2[i];
-        if (fn(args)) {
-          return i;
-        }
-      }
-    };
-  }
-  function buildOverload(name) {
-    return {
-      overload: (overloads) => ({
-        bind: (binder2) => ({
-          finish: () => createOverload(name, overloads, binder2),
-          deprecate: (deprecations) => ({
-            finish: () => createOverload(name, overloads, binder2, deprecations)
-          })
-        })
-      })
-    };
-  }
-  var init_deprecations = __esm({
-    "src/deprecatedCompat/deprecations.ts"() {
-      "use strict";
+      init_ts4();
       init_ts5();
-      init_deprecate();
+      init_ts_server3();
     }
   });
 
-  // src/deprecatedCompat/5.0/identifierProperties.ts
-  var init_identifierProperties = __esm({
-    "src/deprecatedCompat/5.0/identifierProperties.ts"() {
-      "use strict";
-      init_ts5();
-      init_deprecate();
-      addObjectAllocatorPatcher((objectAllocator2) => {
-        const Identifier74 = objectAllocator2.getIdentifierConstructor();
-        if (!hasProperty(Identifier74.prototype, "originalKeywordKind")) {
-          Object.defineProperty(Identifier74.prototype, "originalKeywordKind", {
-            get: deprecate(function() {
-              return identifierToKeywordKind(this);
-            }, {
-              name: "originalKeywordKind",
-              since: "5.0",
-              warnAfter: "5.1",
-              errorAfter: "5.2",
-              message: "Use 'identifierToKeywordKind(identifier)' instead."
-            })
-          });
-        }
-        if (!hasProperty(Identifier74.prototype, "isInJSDocNamespace")) {
-          Object.defineProperty(Identifier74.prototype, "isInJSDocNamespace", {
-            get: deprecate(function() {
-              return this.flags & 2048 /* IdentifierIsInJSDocNamespace */ ? true : void 0;
-            }, {
-              name: "isInJSDocNamespace",
-              since: "5.0",
-              warnAfter: "5.1",
-              errorAfter: "5.2",
-              message: "Use '.parent' or the surrounding context to determine this instead."
-            })
-          });
-        }
-      });
-    }
+  // src/typescript/_namespaces/ts.server.ts
+  var ts_server_exports4 = {};
+  __export(ts_server_exports4, {
+    ActionInvalidate: () => ActionInvalidate,
+    ActionPackageInstalled: () => ActionPackageInstalled,
+    ActionSet: () => ActionSet,
+    ActionWatchTypingLocations: () => ActionWatchTypingLocations,
+    Arguments: () => Arguments,
+    AutoImportProviderProject: () => AutoImportProviderProject,
+    AuxiliaryProject: () => AuxiliaryProject,
+    CharRangeSection: () => CharRangeSection,
+    CloseFileWatcherEvent: () => CloseFileWatcherEvent,
+    CommandNames: () => CommandNames,
+    ConfigFileDiagEvent: () => ConfigFileDiagEvent,
+    ConfiguredProject: () => ConfiguredProject2,
+    CreateDirectoryWatcherEvent: () => CreateDirectoryWatcherEvent,
+    CreateFileWatcherEvent: () => CreateFileWatcherEvent,
+    Errors: () => Errors,
+    EventBeginInstallTypes: () => EventBeginInstallTypes,
+    EventEndInstallTypes: () => EventEndInstallTypes,
+    EventInitializationFailed: () => EventInitializationFailed,
+    EventTypesRegistry: () => EventTypesRegistry,
+    ExternalProject: () => ExternalProject2,
+    GcTimer: () => GcTimer,
+    InferredProject: () => InferredProject2,
+    LargeFileReferencedEvent: () => LargeFileReferencedEvent,
+    LineIndex: () => LineIndex,
+    LineLeaf: () => LineLeaf,
+    LineNode: () => LineNode,
+    LogLevel: () => LogLevel2,
+    Msg: () => Msg,
+    OpenFileInfoTelemetryEvent: () => OpenFileInfoTelemetryEvent,
+    Project: () => Project3,
+    ProjectInfoTelemetryEvent: () => ProjectInfoTelemetryEvent,
+    ProjectKind: () => ProjectKind,
+    ProjectLanguageServiceStateEvent: () => ProjectLanguageServiceStateEvent,
+    ProjectLoadingFinishEvent: () => ProjectLoadingFinishEvent,
+    ProjectLoadingStartEvent: () => ProjectLoadingStartEvent,
+    ProjectReferenceProjectLoadKind: () => ProjectReferenceProjectLoadKind,
+    ProjectService: () => ProjectService3,
+    ProjectsUpdatedInBackgroundEvent: () => ProjectsUpdatedInBackgroundEvent,
+    ScriptInfo: () => ScriptInfo,
+    ScriptVersionCache: () => ScriptVersionCache,
+    Session: () => Session3,
+    TextStorage: () => TextStorage,
+    ThrottledOperations: () => ThrottledOperations,
+    TypingsCache: () => TypingsCache,
+    allFilesAreJsOrDts: () => allFilesAreJsOrDts,
+    allRootFilesAreJsOrDts: () => allRootFilesAreJsOrDts,
+    asNormalizedPath: () => asNormalizedPath,
+    convertCompilerOptions: () => convertCompilerOptions,
+    convertFormatOptions: () => convertFormatOptions,
+    convertScriptKindName: () => convertScriptKindName,
+    convertTypeAcquisition: () => convertTypeAcquisition,
+    convertUserPreferences: () => convertUserPreferences,
+    convertWatchOptions: () => convertWatchOptions,
+    countEachFileTypes: () => countEachFileTypes,
+    createInstallTypingsRequest: () => createInstallTypingsRequest,
+    createModuleSpecifierCache: () => createModuleSpecifierCache,
+    createNormalizedPathMap: () => createNormalizedPathMap,
+    createPackageJsonCache: () => createPackageJsonCache,
+    createSortedArray: () => createSortedArray2,
+    emptyArray: () => emptyArray2,
+    findArgument: () => findArgument,
+    forEachResolvedProjectReferenceProject: () => forEachResolvedProjectReferenceProject,
+    formatDiagnosticToProtocol: () => formatDiagnosticToProtocol,
+    formatMessage: () => formatMessage2,
+    getBaseConfigFileName: () => getBaseConfigFileName,
+    getLocationInNewDocument: () => getLocationInNewDocument,
+    hasArgument: () => hasArgument,
+    hasNoTypeScriptSource: () => hasNoTypeScriptSource,
+    indent: () => indent2,
+    isBackgroundProject: () => isBackgroundProject,
+    isConfigFile: () => isConfigFile,
+    isConfiguredProject: () => isConfiguredProject,
+    isDynamicFileName: () => isDynamicFileName,
+    isExternalProject: () => isExternalProject,
+    isInferredProject: () => isInferredProject,
+    isInferredProjectName: () => isInferredProjectName,
+    makeAutoImportProviderProjectName: () => makeAutoImportProviderProjectName,
+    makeAuxiliaryProjectName: () => makeAuxiliaryProjectName,
+    makeInferredProjectName: () => makeInferredProjectName,
+    maxFileSize: () => maxFileSize,
+    maxProgramSizeForNonTsFiles: () => maxProgramSizeForNonTsFiles,
+    normalizedPathToPath: () => normalizedPathToPath,
+    nowString: () => nowString,
+    nullCancellationToken: () => nullCancellationToken,
+    nullTypingsInstaller: () => nullTypingsInstaller,
+    projectContainsInfoDirectly: () => projectContainsInfoDirectly,
+    protocol: () => ts_server_protocol_exports,
+    removeSorted: () => removeSorted,
+    stringifyIndented: () => stringifyIndented,
+    toEvent: () => toEvent,
+    toNormalizedPath: () => toNormalizedPath,
+    tryConvertScriptKindName: () => tryConvertScriptKindName,
+    typingsInstaller: () => ts_server_typingsInstaller_exports,
+    updateProjectIfDirty: () => updateProjectIfDirty
   });
-
-  // src/deprecatedCompat/_namespaces/ts.ts
-  var init_ts5 = __esm({
-    "src/deprecatedCompat/_namespaces/ts.ts"() {
+  var init_ts_server4 = __esm({
+    "src/typescript/_namespaces/ts.server.ts"() {
       "use strict";
-      init_ts2();
-      init_deprecations();
-      init_identifierProperties();
+      init_ts_server();
+      init_ts_server3();
     }
   });
 
   // src/typescript/_namespaces/ts.ts
-  var ts_exports2 = {};
-  __export(ts_exports2, {
+  var ts_exports3 = {};
+  __export(ts_exports3, {
     ANONYMOUS: () => ANONYMOUS,
     AccessFlags: () => AccessFlags,
     AssertionLevel: () => AssertionLevel,
@@ -268754,9 +268457,8 @@ ${options.prefix}` : "\n" : options.prefix
     CompletionInfoFlags: () => CompletionInfoFlags,
     CompletionTriggerKind: () => CompletionTriggerKind,
     Completions: () => ts_Completions_exports,
-    ConfigFileProgramReloadLevel: () => ConfigFileProgramReloadLevel,
+    ContainerFlags: () => ContainerFlags,
     ContextFlags: () => ContextFlags,
-    CoreServicesShimHostAdapter: () => CoreServicesShimHostAdapter,
     Debug: () => Debug,
     DiagnosticCategory: () => DiagnosticCategory,
     Diagnostics: () => Diagnostics,
@@ -268784,6 +268486,8 @@ ${options.prefix}` : "\n" : options.prefix
     GetLiteralTextFlags: () => GetLiteralTextFlags,
     GoToDefinition: () => ts_GoToDefinition_exports,
     HighlightSpanKind: () => HighlightSpanKind,
+    IdentifierNameMap: () => IdentifierNameMap,
+    IdentifierNameMultiMap: () => IdentifierNameMultiMap,
     ImportKind: () => ImportKind,
     ImportsNotUsedAsValues: () => ImportsNotUsedAsValues,
     IndentStyle: () => IndentStyle,
@@ -268796,13 +268500,13 @@ ${options.prefix}` : "\n" : options.prefix
     InternalEmitFlags: () => InternalEmitFlags,
     InternalSymbolName: () => InternalSymbolName,
     InvalidatedProjectKind: () => InvalidatedProjectKind,
+    JSDocParsingMode: () => JSDocParsingMode,
     JsDoc: () => ts_JsDoc_exports,
     JsTyping: () => ts_JsTyping_exports,
     JsxEmit: () => JsxEmit,
     JsxFlags: () => JsxFlags,
     JsxReferenceKind: () => JsxReferenceKind,
     LanguageServiceMode: () => LanguageServiceMode,
-    LanguageServiceShimHostAdapter: () => LanguageServiceShimHostAdapter,
     LanguageVariant: () => LanguageVariant,
     LexicalEnvironmentFlags: () => LexicalEnvironmentFlags,
     ListFormat: () => ListFormat,
@@ -268839,6 +268543,7 @@ ${options.prefix}` : "\n" : options.prefix
     PragmaKindFlags: () => PragmaKindFlags,
     PrivateIdentifierKind: () => PrivateIdentifierKind,
     ProcessLevel: () => ProcessLevel,
+    ProgramUpdateLevel: () => ProgramUpdateLevel,
     QuotePreference: () => QuotePreference,
     RelationComparisonResult: () => RelationComparisonResult,
     Rename: () => ts_Rename_exports,
@@ -268876,7 +268581,6 @@ ${options.prefix}` : "\n" : options.prefix
     TypeMapKind: () => TypeMapKind,
     TypePredicateKind: () => TypePredicateKind,
     TypeReferenceSerializationKind: () => TypeReferenceSerializationKind,
-    TypeScriptServicesFactory: () => TypeScriptServicesFactory,
     UnionReduction: () => UnionReduction,
     UpToDateStatusType: () => UpToDateStatusType,
     VarianceFlags: () => VarianceFlags,
@@ -268888,6 +268592,7 @@ ${options.prefix}` : "\n" : options.prefix
     WatchLogLevel: () => WatchLogLevel,
     WatchType: () => WatchType,
     accessPrivateIdentifier: () => accessPrivateIdentifier,
+    addDisposableResourceHelper: () => addDisposableResourceHelper,
     addEmitFlags: () => addEmitFlags,
     addEmitHelper: () => addEmitHelper,
     addEmitHelpers: () => addEmitHelpers,
@@ -268967,6 +268672,9 @@ ${options.prefix}` : "\n" : options.prefix
     changesAffectingProgramStructure: () => changesAffectingProgramStructure,
     childIsDecorated: () => childIsDecorated,
     classElementOrClassElementParameterIsDecorated: () => classElementOrClassElementParameterIsDecorated,
+    classHasClassThisAssignment: () => classHasClassThisAssignment,
+    classHasDeclaredOrExplicitlyAssignedName: () => classHasDeclaredOrExplicitlyAssignedName,
+    classHasExplicitlyAssignedName: () => classHasExplicitlyAssignedName,
     classOrConstructorParameterIsDecorated: () => classOrConstructorParameterIsDecorated,
     classPrivateFieldGetHelper: () => classPrivateFieldGetHelper,
     classPrivateFieldInHelper: () => classPrivateFieldInHelper,
@@ -269064,6 +268772,8 @@ ${options.prefix}` : "\n" : options.prefix
     createCacheWithRedirects: () => createCacheWithRedirects,
     createCacheableExportInfoMap: () => createCacheableExportInfoMap,
     createCachedDirectoryStructureHost: () => createCachedDirectoryStructureHost,
+    createClassNamedEvaluationHelperBlock: () => createClassNamedEvaluationHelperBlock,
+    createClassThisAssignmentBlock: () => createClassThisAssignmentBlock,
     createClassifier: () => createClassifier,
     createCommentDirectivesMap: () => createCommentDirectivesMap,
     createCompilerDiagnostic: () => createCompilerDiagnostic,
@@ -269117,6 +268827,7 @@ ${options.prefix}` : "\n" : options.prefix
     createModuleNotFoundChain: () => createModuleNotFoundChain,
     createModuleResolutionCache: () => createModuleResolutionCache,
     createModuleResolutionLoader: () => createModuleResolutionLoader,
+    createModuleResolutionLoaderUsingGlobalCache: () => createModuleResolutionLoaderUsingGlobalCache,
     createModuleSpecifierResolutionHost: () => createModuleSpecifierResolutionHost,
     createMultiMap: () => createMultiMap,
     createNodeConverters: () => createNodeConverters,
@@ -269196,6 +268907,7 @@ ${options.prefix}` : "\n" : options.prefix
     displayPart: () => displayPart,
     displayPartsToString: () => displayPartsToString,
     disposeEmitNodes: () => disposeEmitNodes,
+    disposeResourcesHelper: () => disposeResourcesHelper,
     documentSpansEqual: () => documentSpansEqual,
     dumpTracingLegend: () => dumpTracingLegend,
     elementAt: () => elementAt,
@@ -269273,7 +268985,7 @@ ${options.prefix}` : "\n" : options.prefix
     findPackageJsons: () => findPackageJsons,
     findPrecedingMatchingToken: () => findPrecedingMatchingToken,
     findPrecedingToken: () => findPrecedingToken,
-    findSuperStatementIndex: () => findSuperStatementIndex,
+    findSuperStatementIndexPath: () => findSuperStatementIndexPath,
     findTokenOnLeftOfPosition: () => findTokenOnLeftOfPosition,
     findUseStrictPrologue: () => findUseStrictPrologue,
     first: () => first,
@@ -269348,6 +269060,7 @@ ${options.prefix}` : "\n" : options.prefix
     getAreDeclarationMapsEnabled: () => getAreDeclarationMapsEnabled,
     getAssignedExpandoInitializer: () => getAssignedExpandoInitializer,
     getAssignedName: () => getAssignedName,
+    getAssignedNameOfIdentifier: () => getAssignedNameOfIdentifier,
     getAssignmentDeclarationKind: () => getAssignmentDeclarationKind,
     getAssignmentDeclarationPropertyAccessKind: () => getAssignmentDeclarationPropertyAccessKind,
     getAssignmentTargetKind: () => getAssignmentTargetKind,
@@ -269375,8 +269088,10 @@ ${options.prefix}` : "\n" : options.prefix
     getConditions: () => getConditions,
     getConfigFileParsingDiagnostics: () => getConfigFileParsingDiagnostics,
     getConstantValue: () => getConstantValue,
+    getContainerFlags: () => getContainerFlags,
     getContainerNode: () => getContainerNode,
     getContainingClass: () => getContainingClass,
+    getContainingClassExcludingClassDecorators: () => getContainingClassExcludingClassDecorators,
     getContainingClassStaticBlock: () => getContainingClassStaticBlock,
     getContainingFunction: () => getContainingFunction,
     getContainingFunctionDeclaration: () => getContainingFunctionDeclaration,
@@ -269434,7 +269149,9 @@ ${options.prefix}` : "\n" : options.prefix
     getEmitModuleKind: () => getEmitModuleKind,
     getEmitModuleResolutionKind: () => getEmitModuleResolutionKind,
     getEmitScriptTarget: () => getEmitScriptTarget,
+    getEmitStandardClassFields: () => getEmitStandardClassFields,
     getEnclosingBlockScopeContainer: () => getEnclosingBlockScopeContainer,
+    getEnclosingContainer: () => getEnclosingContainer,
     getEncodedSemanticClassifications: () => getEncodedSemanticClassifications,
     getEncodedSyntacticClassifications: () => getEncodedSyntacticClassifications,
     getEndLinePosition: () => getEndLinePosition,
@@ -269539,6 +269256,7 @@ ${options.prefix}` : "\n" : options.prefix
     getLeadingCommentRangesOfNode: () => getLeadingCommentRangesOfNode,
     getLeftmostAccessExpression: () => getLeftmostAccessExpression,
     getLeftmostExpression: () => getLeftmostExpression,
+    getLibraryNameFromLibFileName: () => getLibraryNameFromLibFileName,
     getLineAndCharacterOfPosition: () => getLineAndCharacterOfPosition,
     getLineInfo: () => getLineInfo,
     getLineOfLocalPosition: () => getLineOfLocalPosition,
@@ -269652,6 +269370,7 @@ ${options.prefix}` : "\n" : options.prefix
     getPropertyAssignmentAliasLikeExpression: () => getPropertyAssignmentAliasLikeExpression,
     getPropertyNameForPropertyNameNode: () => getPropertyNameForPropertyNameNode,
     getPropertyNameForUniqueESSymbol: () => getPropertyNameForUniqueESSymbol,
+    getPropertyNameFromType: () => getPropertyNameFromType,
     getPropertyNameOfBindingOrAssignmentElement: () => getPropertyNameOfBindingOrAssignmentElement,
     getPropertySymbolFromBindingElement: () => getPropertySymbolFromBindingElement,
     getPropertySymbolsFromContextualType: () => getPropertySymbolsFromContextualType,
@@ -269669,13 +269388,11 @@ ${options.prefix}` : "\n" : options.prefix
     getRenameLocation: () => getRenameLocation,
     getReplacementSpanForContextToken: () => getReplacementSpanForContextToken,
     getResolutionDiagnostic: () => getResolutionDiagnostic,
-    getResolutionModeOverrideForClause: () => getResolutionModeOverrideForClause,
+    getResolutionModeOverride: () => getResolutionModeOverride,
     getResolveJsonModule: () => getResolveJsonModule,
     getResolvePackageJsonExports: () => getResolvePackageJsonExports,
     getResolvePackageJsonImports: () => getResolvePackageJsonImports,
     getResolvedExternalModuleName: () => getResolvedExternalModuleName,
-    getResolvedModule: () => getResolvedModule,
-    getResolvedTypeReferenceDirective: () => getResolvedTypeReferenceDirective,
     getRestIndicatorOfBindingOrAssignmentElement: () => getRestIndicatorOfBindingOrAssignmentElement,
     getRestParameterElementType: () => getRestParameterElementType,
     getRightMostAssignedExpression: () => getRightMostAssignedExpression,
@@ -269803,6 +269520,7 @@ ${options.prefix}` : "\n" : options.prefix
     hasPropertyAccessExpressionWithName: () => hasPropertyAccessExpressionWithName,
     hasQuestionToken: () => hasQuestionToken,
     hasRecordedExternalHelpers: () => hasRecordedExternalHelpers,
+    hasResolutionModeOverride: () => hasResolutionModeOverride,
     hasRestParameter: () => hasRestParameter,
     hasScopeMarker: () => hasScopeMarker,
     hasStaticModifier: () => hasStaticModifier,
@@ -269832,6 +269550,8 @@ ${options.prefix}` : "\n" : options.prefix
     indexOfNode: () => indexOfNode,
     indicesOf: () => indicesOf,
     inferredTypesContainingFile: () => inferredTypesContainingFile,
+    injectClassNamedEvaluationHelperBlockIfMissing: () => injectClassNamedEvaluationHelperBlockIfMissing,
+    injectClassThisAssignmentIfMissing: () => injectClassThisAssignmentIfMissing,
     insertImports: () => insertImports,
     insertLeadingStatement: () => insertLeadingStatement,
     insertSorted: () => insertSorted,
@@ -269874,7 +269594,6 @@ ${options.prefix}` : "\n" : options.prefix
     isAssertClause: () => isAssertClause,
     isAssertEntry: () => isAssertEntry,
     isAssertionExpression: () => isAssertionExpression,
-    isAssertionKey: () => isAssertionKey,
     isAssertsKeyword: () => isAssertsKeyword,
     isAssignmentDeclaration: () => isAssignmentDeclaration,
     isAssignmentExpression: () => isAssignmentExpression,
@@ -269915,6 +269634,7 @@ ${options.prefix}` : "\n" : options.prefix
     isCallExpression: () => isCallExpression,
     isCallExpressionTarget: () => isCallExpressionTarget,
     isCallLikeExpression: () => isCallLikeExpression,
+    isCallLikeOrFunctionLikeExpression: () => isCallLikeOrFunctionLikeExpression,
     isCallOrNewExpression: () => isCallOrNewExpression,
     isCallOrNewExpressionTarget: () => isCallOrNewExpressionTarget,
     isCallSignatureDeclaration: () => isCallSignatureDeclaration,
@@ -269932,10 +269652,13 @@ ${options.prefix}` : "\n" : options.prefix
     isClassDeclaration: () => isClassDeclaration,
     isClassElement: () => isClassElement,
     isClassExpression: () => isClassExpression,
+    isClassInstanceProperty: () => isClassInstanceProperty,
     isClassLike: () => isClassLike,
     isClassMemberModifier: () => isClassMemberModifier,
+    isClassNamedEvaluationHelperBlock: () => isClassNamedEvaluationHelperBlock,
     isClassOrTypeElement: () => isClassOrTypeElement,
     isClassStaticBlockDeclaration: () => isClassStaticBlockDeclaration,
+    isClassThisAssignmentBlock: () => isClassThisAssignmentBlock,
     isCollapsedRange: () => isCollapsedRange,
     isColonToken: () => isColonToken,
     isCommaExpression: () => isCommaExpression,
@@ -269981,6 +269704,7 @@ ${options.prefix}` : "\n" : options.prefix
     isDiagnosticWithLocation: () => isDiagnosticWithLocation,
     isDiskPathRoot: () => isDiskPathRoot,
     isDoStatement: () => isDoStatement,
+    isDocumentRegistryEntry: () => isDocumentRegistryEntry,
     isDotDotDotToken: () => isDotDotDotToken,
     isDottedName: () => isDottedName,
     isDynamicName: () => isDynamicName,
@@ -270007,6 +269731,7 @@ ${options.prefix}` : "\n" : options.prefix
     isExclamationToken: () => isExclamationToken,
     isExcludedFile: () => isExcludedFile,
     isExclusivelyTypeOnlyImportOrExport: () => isExclusivelyTypeOnlyImportOrExport,
+    isExpandoPropertyDeclaration: () => isExpandoPropertyDeclaration,
     isExportAssignment: () => isExportAssignment,
     isExportDeclaration: () => isExportDeclaration,
     isExportModifier: () => isExportModifier,
@@ -270031,6 +269756,7 @@ ${options.prefix}` : "\n" : options.prefix
     isExternalModuleReference: () => isExternalModuleReference,
     isExternalModuleSymbol: () => isExternalModuleSymbol,
     isExternalOrCommonJsModule: () => isExternalOrCommonJsModule,
+    isFileLevelReservedGeneratedIdentifier: () => isFileLevelReservedGeneratedIdentifier,
     isFileLevelUniqueName: () => isFileLevelUniqueName,
     isFileProbablyExternalModule: () => isFileProbablyExternalModule,
     isFirstDeclarationOfSymbolParameter: () => isFirstDeclarationOfSymbolParameter,
@@ -270077,6 +269803,9 @@ ${options.prefix}` : "\n" : options.prefix
     isIfStatement: () => isIfStatement,
     isIgnoredFileFromWildCardWatching: () => isIgnoredFileFromWildCardWatching,
     isImplicitGlob: () => isImplicitGlob,
+    isImportAttribute: () => isImportAttribute,
+    isImportAttributeName: () => isImportAttributeName,
+    isImportAttributes: () => isImportAttributes,
     isImportCall: () => isImportCall,
     isImportClause: () => isImportClause,
     isImportDeclaration: () => isImportDeclaration,
@@ -270090,6 +269819,7 @@ ${options.prefix}` : "\n" : options.prefix
     isImportTypeNode: () => isImportTypeNode,
     isImportableFile: () => isImportableFile,
     isInComment: () => isInComment,
+    isInCompoundLikeAssignment: () => isInCompoundLikeAssignment,
     isInExpressionContext: () => isInExpressionContext,
     isInJSDoc: () => isInJSDoc,
     isInJSFile: () => isInJSFile,
@@ -270101,6 +269831,7 @@ ${options.prefix}` : "\n" : options.prefix
     isInString: () => isInString,
     isInTemplateString: () => isInTemplateString,
     isInTopLevelContext: () => isInTopLevelContext,
+    isInTypeQuery: () => isInTypeQuery,
     isIncrementalCompilation: () => isIncrementalCompilation,
     isIndexSignatureDeclaration: () => isIndexSignatureDeclaration,
     isIndexedAccessTypeNode: () => isIndexedAccessTypeNode,
@@ -270112,6 +269843,7 @@ ${options.prefix}` : "\n" : options.prefix
     isInsideJsxElementOrAttribute: () => isInsideJsxElementOrAttribute,
     isInsideNodeModules: () => isInsideNodeModules,
     isInsideTemplateLiteral: () => isInsideTemplateLiteral,
+    isInstanceOfExpression: () => isInstanceOfExpression,
     isInstantiatedModule: () => isInstantiatedModule,
     isInterfaceDeclaration: () => isInterfaceDeclaration,
     isInternalDeclaration: () => isInternalDeclaration,
@@ -270266,7 +269998,6 @@ ${options.prefix}` : "\n" : options.prefix
     isNamespaceReexportDeclaration: () => isNamespaceReexportDeclaration,
     isNewExpression: () => isNewExpression,
     isNewExpressionTarget: () => isNewExpressionTarget,
-    isNightly: () => isNightly,
     isNoSubstitutionTemplateLiteral: () => isNoSubstitutionTemplateLiteral,
     isNode: () => isNode,
     isNodeArray: () => isNodeArray,
@@ -270370,6 +270101,7 @@ ${options.prefix}` : "\n" : options.prefix
     isReturnStatement: () => isReturnStatement,
     isReturnStatementWithFixablePromiseHandler: () => isReturnStatementWithFixablePromiseHandler,
     isRightSideOfAccessExpression: () => isRightSideOfAccessExpression,
+    isRightSideOfInstanceofExpression: () => isRightSideOfInstanceofExpression,
     isRightSideOfPropertyAccess: () => isRightSideOfPropertyAccess,
     isRightSideOfQualifiedName: () => isRightSideOfQualifiedName,
     isRightSideOfQualifiedNameOrPropertyAccess: () => isRightSideOfQualifiedNameOrPropertyAccess,
@@ -270382,6 +270114,7 @@ ${options.prefix}` : "\n" : options.prefix
     isSetAccessor: () => isSetAccessor,
     isSetAccessorDeclaration: () => isSetAccessorDeclaration,
     isShebangTrivia: () => isShebangTrivia,
+    isShiftOperatorOrHigher: () => isShiftOperatorOrHigher,
     isShorthandAmbientModuleSymbol: () => isShorthandAmbientModuleSymbol,
     isShorthandPropertyAssignment: () => isShorthandPropertyAssignment,
     isSignedNumericLiteral: () => isSignedNumericLiteral,
@@ -270478,6 +270211,7 @@ ${options.prefix}` : "\n" : options.prefix
     isTypeQueryNode: () => isTypeQueryNode,
     isTypeReferenceNode: () => isTypeReferenceNode,
     isTypeReferenceType: () => isTypeReferenceType,
+    isTypeUsableAsPropertyName: () => isTypeUsableAsPropertyName,
     isUMDExportSymbol: () => isUMDExportSymbol,
     isUnaryExpression: () => isUnaryExpression,
     isUnaryExpressionWithWrite: () => isUnaryExpressionWithWrite,
@@ -270492,7 +270226,9 @@ ${options.prefix}` : "\n" : options.prefix
     isValidESSymbolDeclaration: () => isValidESSymbolDeclaration,
     isValidTypeOnlyAliasUseSite: () => isValidTypeOnlyAliasUseSite,
     isValueSignatureDeclaration: () => isValueSignatureDeclaration,
+    isVarAwaitUsing: () => isVarAwaitUsing,
     isVarConst: () => isVarConst,
+    isVarUsing: () => isVarUsing,
     isVariableDeclaration: () => isVariableDeclaration,
     isVariableDeclarationInVariableStatement: () => isVariableDeclarationInVariableStatement,
     isVariableDeclarationInitializedToBareOrAccessedRequire: () => isVariableDeclarationInitializedToBareOrAccessedRequire,
@@ -270617,8 +270353,6 @@ ${options.prefix}` : "\n" : options.prefix
     outFile: () => outFile,
     packageIdToPackageName: () => packageIdToPackageName,
     packageIdToString: () => packageIdToString,
-    padLeft: () => padLeft,
-    padRight: () => padRight,
     paramHelper: () => paramHelper,
     parameterIsThisKeyword: () => parameterIsThisKeyword,
     parameterNamePart: () => parameterNamePart,
@@ -270692,7 +270426,6 @@ ${options.prefix}` : "\n" : options.prefix
     readJson: () => readJson,
     readJsonConfigFile: () => readJsonConfigFile,
     readJsonOrUndefined: () => readJsonOrUndefined,
-    realizeDiagnostics: () => realizeDiagnostics,
     reduceEachLeadingCommentRange: () => reduceEachLeadingCommentRange,
     reduceEachTrailingCommentRange: () => reduceEachTrailingCommentRange,
     reduceLeft: () => reduceLeft,
@@ -270741,7 +270474,7 @@ ${options.prefix}` : "\n" : options.prefix
     screenStartingMessageCodes: () => screenStartingMessageCodes,
     semanticDiagnosticsOptionDeclarations: () => semanticDiagnosticsOptionDeclarations,
     serializeCompilerOptions: () => serializeCompilerOptions,
-    server: () => ts_server_exports,
+    server: () => ts_server_exports4,
     servicesVersion: () => servicesVersion,
     setCommentRange: () => setCommentRange,
     setConfigFileInOptions: () => setConfigFileInOptions,
@@ -270762,8 +270495,6 @@ ${options.prefix}` : "\n" : options.prefix
     setParent: () => setParent,
     setParentRecursive: () => setParentRecursive,
     setPrivateIdentifier: () => setPrivateIdentifier,
-    setResolvedModule: () => setResolvedModule,
-    setResolvedTypeReferenceDirective: () => setResolvedTypeReferenceDirective,
     setSnippetElement: () => setSnippetElement,
     setSourceMapRange: () => setSourceMapRange,
     setStackTraceLimit: () => setStackTraceLimit,
@@ -270825,7 +270556,6 @@ ${options.prefix}` : "\n" : options.prefix
     startsWithDirectory: () => startsWithDirectory,
     startsWithUnderscore: () => startsWithUnderscore,
     startsWithUseStrict: () => startsWithUseStrict,
-    stringContains: () => stringContains,
     stringContainsAt: () => stringContainsAt,
     stringToToken: () => stringToToken,
     stripQuotes: () => stripQuotes,
@@ -270904,6 +270634,7 @@ ${options.prefix}` : "\n" : options.prefix
     transformJsx: () => transformJsx,
     transformLegacyDecorators: () => transformLegacyDecorators,
     transformModule: () => transformModule,
+    transformNamedEvaluation: () => transformNamedEvaluation,
     transformNodeModule: () => transformNodeModule,
     transformNodes: () => transformNodes,
     transformSystemModule: () => transformSystemModule,
@@ -270911,9 +270642,6 @@ ${options.prefix}` : "\n" : options.prefix
     transpile: () => transpile,
     transpileModule: () => transpileModule,
     transpileOptionValueCompilerOptions: () => transpileOptionValueCompilerOptions,
-    trimString: () => trimString,
-    trimStringEnd: () => trimStringEnd,
-    trimStringStart: () => trimStringStart,
     tryAddToSet: () => tryAddToSet,
     tryAndIgnoreErrors: () => tryAndIgnoreErrors,
     tryCast: () => tryCast,
@@ -270993,3134 +270721,15036 @@ ${options.prefix}` : "\n" : options.prefix
     writeCommentRange: () => writeCommentRange,
     writeFile: () => writeFile,
     writeFileEnsuringDirectories: () => writeFileEnsuringDirectories,
-    zipToModeAwareCache: () => zipToModeAwareCache,
     zipWith: () => zipWith
   });
-  var init_ts6 = __esm({
+  var init_ts8 = __esm({
     "src/typescript/_namespaces/ts.ts"() {
       "use strict";
       init_ts2();
       init_ts3();
       init_ts4();
-      init_ts5();
+      init_ts7();
+      init_ts_server4();
+    }
+  });
+
+  // src/typescript/typescript.ts
+  var require_typescript = __commonJS({
+    "src/typescript/typescript.ts"(exports, module2) {
+      init_ts8();
+      init_ts8();
+      if (typeof console !== "undefined") {
+        Debug.loggingHost = {
+          log(level, s) {
+            switch (level) {
+              case 1 /* Error */:
+                return console.error(s);
+              case 2 /* Warning */:
+                return console.warn(s);
+              case 3 /* Info */:
+                return console.log(s);
+              case 4 /* Verbose */:
+                return console.log(s);
+            }
+          }
+        };
+      }
+      module2.exports = ts_exports3;
+    }
+  });
+  return require_typescript();
+})();
+
+if ( true && module.exports) { module.exports = ts; }
+//# sourceMappingURL=typescript.js.map
+
+
+/***/ }),
+
+/***/ 63931:
+/***/ ((__unused_webpack_module, exports) => {
+
+"use strict";
+
+
+exports.fromCallback = function (fn) {
+  return Object.defineProperty(function (...args) {
+    if (typeof args[args.length - 1] === 'function') fn.apply(this, args)
+    else {
+      return new Promise((resolve, reject) => {
+        fn.call(
+          this,
+          ...args,
+          (err, res) => (err != null) ? reject(err) : resolve(res)
+        )
+      })
+    }
+  }, 'name', { value: fn.name })
+}
+
+exports.fromPromise = function (fn) {
+  return Object.defineProperty(function (...args) {
+    const cb = args[args.length - 1]
+    if (typeof cb !== 'function') return fn.apply(this, args)
+    else fn.apply(this, args.slice(0, -1)).then(r => cb(null, r), cb)
+  }, 'name', { value: fn.name })
+}
+
+
+/***/ }),
+
+/***/ 96083:
+/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+
+
+/**
+ * For Node.js, simply re-export the core `util.deprecate` function.
+ */
+
+module.exports = __nccwpck_require__(73837).deprecate;
+
+
+/***/ }),
+
+/***/ 37515:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
+
+"use strict";
+
+
+Object.defineProperty(exports, "__esModule", ({
+  value: true
+}));
+Object.defineProperty(exports, "v1", ({
+  enumerable: true,
+  get: function () {
+    return _v.default;
+  }
+}));
+Object.defineProperty(exports, "v3", ({
+  enumerable: true,
+  get: function () {
+    return _v2.default;
+  }
+}));
+Object.defineProperty(exports, "v4", ({
+  enumerable: true,
+  get: function () {
+    return _v3.default;
+  }
+}));
+Object.defineProperty(exports, "v5", ({
+  enumerable: true,
+  get: function () {
+    return _v4.default;
+  }
+}));
+Object.defineProperty(exports, "NIL", ({
+  enumerable: true,
+  get: function () {
+    return _nil.default;
+  }
+}));
+Object.defineProperty(exports, "version", ({
+  enumerable: true,
+  get: function () {
+    return _version.default;
+  }
+}));
+Object.defineProperty(exports, "validate", ({
+  enumerable: true,
+  get: function () {
+    return _validate.default;
+  }
+}));
+Object.defineProperty(exports, "stringify", ({
+  enumerable: true,
+  get: function () {
+    return _stringify.default;
+  }
+}));
+Object.defineProperty(exports, "parse", ({
+  enumerable: true,
+  get: function () {
+    return _parse.default;
+  }
+}));
+
+var _v = _interopRequireDefault(__nccwpck_require__(57635));
+
+var _v2 = _interopRequireDefault(__nccwpck_require__(82839));
+
+var _v3 = _interopRequireDefault(__nccwpck_require__(83189));
+
+var _v4 = _interopRequireDefault(__nccwpck_require__(9798));
+
+var _nil = _interopRequireDefault(__nccwpck_require__(33017));
+
+var _version = _interopRequireDefault(__nccwpck_require__(92450));
+
+var _validate = _interopRequireDefault(__nccwpck_require__(8021));
+
+var _stringify = _interopRequireDefault(__nccwpck_require__(83377));
+
+var _parse = _interopRequireDefault(__nccwpck_require__(41810));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+/***/ }),
+
+/***/ 11923:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
+
+"use strict";
+
+
+Object.defineProperty(exports, "__esModule", ({
+  value: true
+}));
+exports["default"] = void 0;
+
+var _crypto = _interopRequireDefault(__nccwpck_require__(6113));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+function md5(bytes) {
+  if (Array.isArray(bytes)) {
+    bytes = Buffer.from(bytes);
+  } else if (typeof bytes === 'string') {
+    bytes = Buffer.from(bytes, 'utf8');
+  }
+
+  return _crypto.default.createHash('md5').update(bytes).digest();
+}
+
+var _default = md5;
+exports["default"] = _default;
+
+/***/ }),
+
+/***/ 33017:
+/***/ ((__unused_webpack_module, exports) => {
+
+"use strict";
+
+
+Object.defineProperty(exports, "__esModule", ({
+  value: true
+}));
+exports["default"] = void 0;
+var _default = '00000000-0000-0000-0000-000000000000';
+exports["default"] = _default;
+
+/***/ }),
+
+/***/ 41810:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
+
+"use strict";
+
+
+Object.defineProperty(exports, "__esModule", ({
+  value: true
+}));
+exports["default"] = void 0;
+
+var _validate = _interopRequireDefault(__nccwpck_require__(8021));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+function parse(uuid) {
+  if (!(0, _validate.default)(uuid)) {
+    throw TypeError('Invalid UUID');
+  }
+
+  let v;
+  const arr = new Uint8Array(16); // Parse ########-....-....-....-............
+
+  arr[0] = (v = parseInt(uuid.slice(0, 8), 16)) >>> 24;
+  arr[1] = v >>> 16 & 0xff;
+  arr[2] = v >>> 8 & 0xff;
+  arr[3] = v & 0xff; // Parse ........-####-....-....-............
+
+  arr[4] = (v = parseInt(uuid.slice(9, 13), 16)) >>> 8;
+  arr[5] = v & 0xff; // Parse ........-....-####-....-............
+
+  arr[6] = (v = parseInt(uuid.slice(14, 18), 16)) >>> 8;
+  arr[7] = v & 0xff; // Parse ........-....-....-####-............
+
+  arr[8] = (v = parseInt(uuid.slice(19, 23), 16)) >>> 8;
+  arr[9] = v & 0xff; // Parse ........-....-....-....-############
+  // (Use "/" to avoid 32-bit truncation when bit-shifting high-order bytes)
+
+  arr[10] = (v = parseInt(uuid.slice(24, 36), 16)) / 0x10000000000 & 0xff;
+  arr[11] = v / 0x100000000 & 0xff;
+  arr[12] = v >>> 24 & 0xff;
+  arr[13] = v >>> 16 & 0xff;
+  arr[14] = v >>> 8 & 0xff;
+  arr[15] = v & 0xff;
+  return arr;
+}
+
+var _default = parse;
+exports["default"] = _default;
+
+/***/ }),
+
+/***/ 44818:
+/***/ ((__unused_webpack_module, exports) => {
+
+"use strict";
+
+
+Object.defineProperty(exports, "__esModule", ({
+  value: true
+}));
+exports["default"] = void 0;
+var _default = /^(?:[0-9a-f]{8}-[0-9a-f]{4}-[1-5][0-9a-f]{3}-[89ab][0-9a-f]{3}-[0-9a-f]{12}|00000000-0000-0000-0000-000000000000)$/i;
+exports["default"] = _default;
+
+/***/ }),
+
+/***/ 76983:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
+
+"use strict";
+
+
+Object.defineProperty(exports, "__esModule", ({
+  value: true
+}));
+exports["default"] = rng;
+
+var _crypto = _interopRequireDefault(__nccwpck_require__(6113));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+const rnds8Pool = new Uint8Array(256); // # of random values to pre-allocate
+
+let poolPtr = rnds8Pool.length;
+
+function rng() {
+  if (poolPtr > rnds8Pool.length - 16) {
+    _crypto.default.randomFillSync(rnds8Pool);
+
+    poolPtr = 0;
+  }
+
+  return rnds8Pool.slice(poolPtr, poolPtr += 16);
+}
+
+/***/ }),
+
+/***/ 41033:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
+
+"use strict";
+
+
+Object.defineProperty(exports, "__esModule", ({
+  value: true
+}));
+exports["default"] = void 0;
+
+var _crypto = _interopRequireDefault(__nccwpck_require__(6113));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+function sha1(bytes) {
+  if (Array.isArray(bytes)) {
+    bytes = Buffer.from(bytes);
+  } else if (typeof bytes === 'string') {
+    bytes = Buffer.from(bytes, 'utf8');
+  }
+
+  return _crypto.default.createHash('sha1').update(bytes).digest();
+}
+
+var _default = sha1;
+exports["default"] = _default;
+
+/***/ }),
+
+/***/ 83377:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
+
+"use strict";
+
+
+Object.defineProperty(exports, "__esModule", ({
+  value: true
+}));
+exports["default"] = void 0;
+
+var _validate = _interopRequireDefault(__nccwpck_require__(8021));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+/**
+ * Convert array of 16 byte values to UUID string format of the form:
+ * XXXXXXXX-XXXX-XXXX-XXXX-XXXXXXXXXXXX
+ */
+const byteToHex = [];
+
+for (let i = 0; i < 256; ++i) {
+  byteToHex.push((i + 0x100).toString(16).substr(1));
+}
+
+function stringify(arr, offset = 0) {
+  // Note: Be careful editing this code!  It's been tuned for performance
+  // and works in ways you may not expect. See https://github.com/uuidjs/uuid/pull/434
+  const uuid = (byteToHex[arr[offset + 0]] + byteToHex[arr[offset + 1]] + byteToHex[arr[offset + 2]] + byteToHex[arr[offset + 3]] + '-' + byteToHex[arr[offset + 4]] + byteToHex[arr[offset + 5]] + '-' + byteToHex[arr[offset + 6]] + byteToHex[arr[offset + 7]] + '-' + byteToHex[arr[offset + 8]] + byteToHex[arr[offset + 9]] + '-' + byteToHex[arr[offset + 10]] + byteToHex[arr[offset + 11]] + byteToHex[arr[offset + 12]] + byteToHex[arr[offset + 13]] + byteToHex[arr[offset + 14]] + byteToHex[arr[offset + 15]]).toLowerCase(); // Consistency check for valid UUID.  If this throws, it's likely due to one
+  // of the following:
+  // - One or more input array values don't map to a hex octet (leading to
+  // "undefined" in the uuid)
+  // - Invalid input values for the RFC `version` or `variant` fields
+
+  if (!(0, _validate.default)(uuid)) {
+    throw TypeError('Stringified UUID is invalid');
+  }
+
+  return uuid;
+}
+
+var _default = stringify;
+exports["default"] = _default;
+
+/***/ }),
+
+/***/ 57635:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
+
+"use strict";
+
+
+Object.defineProperty(exports, "__esModule", ({
+  value: true
+}));
+exports["default"] = void 0;
+
+var _rng = _interopRequireDefault(__nccwpck_require__(76983));
+
+var _stringify = _interopRequireDefault(__nccwpck_require__(83377));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+// **`v1()` - Generate time-based UUID**
+//
+// Inspired by https://github.com/LiosK/UUID.js
+// and http://docs.python.org/library/uuid.html
+let _nodeId;
+
+let _clockseq; // Previous uuid creation time
+
+
+let _lastMSecs = 0;
+let _lastNSecs = 0; // See https://github.com/uuidjs/uuid for API details
+
+function v1(options, buf, offset) {
+  let i = buf && offset || 0;
+  const b = buf || new Array(16);
+  options = options || {};
+  let node = options.node || _nodeId;
+  let clockseq = options.clockseq !== undefined ? options.clockseq : _clockseq; // node and clockseq need to be initialized to random values if they're not
+  // specified.  We do this lazily to minimize issues related to insufficient
+  // system entropy.  See #189
+
+  if (node == null || clockseq == null) {
+    const seedBytes = options.random || (options.rng || _rng.default)();
+
+    if (node == null) {
+      // Per 4.5, create and 48-bit node id, (47 random bits + multicast bit = 1)
+      node = _nodeId = [seedBytes[0] | 0x01, seedBytes[1], seedBytes[2], seedBytes[3], seedBytes[4], seedBytes[5]];
+    }
+
+    if (clockseq == null) {
+      // Per 4.2.2, randomize (14 bit) clockseq
+      clockseq = _clockseq = (seedBytes[6] << 8 | seedBytes[7]) & 0x3fff;
+    }
+  } // UUID timestamps are 100 nano-second units since the Gregorian epoch,
+  // (1582-10-15 00:00).  JSNumbers aren't precise enough for this, so
+  // time is handled internally as 'msecs' (integer milliseconds) and 'nsecs'
+  // (100-nanoseconds offset from msecs) since unix epoch, 1970-01-01 00:00.
+
+
+  let msecs = options.msecs !== undefined ? options.msecs : Date.now(); // Per 4.2.1.2, use count of uuid's generated during the current clock
+  // cycle to simulate higher resolution clock
+
+  let nsecs = options.nsecs !== undefined ? options.nsecs : _lastNSecs + 1; // Time since last uuid creation (in msecs)
+
+  const dt = msecs - _lastMSecs + (nsecs - _lastNSecs) / 10000; // Per 4.2.1.2, Bump clockseq on clock regression
+
+  if (dt < 0 && options.clockseq === undefined) {
+    clockseq = clockseq + 1 & 0x3fff;
+  } // Reset nsecs if clock regresses (new clockseq) or we've moved onto a new
+  // time interval
+
+
+  if ((dt < 0 || msecs > _lastMSecs) && options.nsecs === undefined) {
+    nsecs = 0;
+  } // Per 4.2.1.2 Throw error if too many uuids are requested
+
+
+  if (nsecs >= 10000) {
+    throw new Error("uuid.v1(): Can't create more than 10M uuids/sec");
+  }
+
+  _lastMSecs = msecs;
+  _lastNSecs = nsecs;
+  _clockseq = clockseq; // Per 4.1.4 - Convert from unix epoch to Gregorian epoch
+
+  msecs += 12219292800000; // `time_low`
+
+  const tl = ((msecs & 0xfffffff) * 10000 + nsecs) % 0x100000000;
+  b[i++] = tl >>> 24 & 0xff;
+  b[i++] = tl >>> 16 & 0xff;
+  b[i++] = tl >>> 8 & 0xff;
+  b[i++] = tl & 0xff; // `time_mid`
+
+  const tmh = msecs / 0x100000000 * 10000 & 0xfffffff;
+  b[i++] = tmh >>> 8 & 0xff;
+  b[i++] = tmh & 0xff; // `time_high_and_version`
+
+  b[i++] = tmh >>> 24 & 0xf | 0x10; // include version
+
+  b[i++] = tmh >>> 16 & 0xff; // `clock_seq_hi_and_reserved` (Per 4.2.2 - include variant)
+
+  b[i++] = clockseq >>> 8 | 0x80; // `clock_seq_low`
+
+  b[i++] = clockseq & 0xff; // `node`
+
+  for (let n = 0; n < 6; ++n) {
+    b[i + n] = node[n];
+  }
+
+  return buf || (0, _stringify.default)(b);
+}
+
+var _default = v1;
+exports["default"] = _default;
+
+/***/ }),
+
+/***/ 82839:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
+
+"use strict";
+
+
+Object.defineProperty(exports, "__esModule", ({
+  value: true
+}));
+exports["default"] = void 0;
+
+var _v = _interopRequireDefault(__nccwpck_require__(43127));
+
+var _md = _interopRequireDefault(__nccwpck_require__(11923));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+const v3 = (0, _v.default)('v3', 0x30, _md.default);
+var _default = v3;
+exports["default"] = _default;
+
+/***/ }),
+
+/***/ 43127:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
+
+"use strict";
+
+
+Object.defineProperty(exports, "__esModule", ({
+  value: true
+}));
+exports["default"] = _default;
+exports.URL = exports.DNS = void 0;
+
+var _stringify = _interopRequireDefault(__nccwpck_require__(83377));
+
+var _parse = _interopRequireDefault(__nccwpck_require__(41810));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+function stringToBytes(str) {
+  str = unescape(encodeURIComponent(str)); // UTF8 escape
+
+  const bytes = [];
+
+  for (let i = 0; i < str.length; ++i) {
+    bytes.push(str.charCodeAt(i));
+  }
+
+  return bytes;
+}
+
+const DNS = '6ba7b810-9dad-11d1-80b4-00c04fd430c8';
+exports.DNS = DNS;
+const URL = '6ba7b811-9dad-11d1-80b4-00c04fd430c8';
+exports.URL = URL;
+
+function _default(name, version, hashfunc) {
+  function generateUUID(value, namespace, buf, offset) {
+    if (typeof value === 'string') {
+      value = stringToBytes(value);
+    }
+
+    if (typeof namespace === 'string') {
+      namespace = (0, _parse.default)(namespace);
+    }
+
+    if (namespace.length !== 16) {
+      throw TypeError('Namespace must be array-like (16 iterable integer values, 0-255)');
+    } // Compute hash of namespace and value, Per 4.3
+    // Future: Use spread syntax when supported on all platforms, e.g. `bytes =
+    // hashfunc([...namespace, ... value])`
+
+
+    let bytes = new Uint8Array(16 + value.length);
+    bytes.set(namespace);
+    bytes.set(value, namespace.length);
+    bytes = hashfunc(bytes);
+    bytes[6] = bytes[6] & 0x0f | version;
+    bytes[8] = bytes[8] & 0x3f | 0x80;
+
+    if (buf) {
+      offset = offset || 0;
+
+      for (let i = 0; i < 16; ++i) {
+        buf[offset + i] = bytes[i];
+      }
+
+      return buf;
+    }
+
+    return (0, _stringify.default)(bytes);
+  } // Function#name is not settable on some platforms (#270)
+
+
+  try {
+    generateUUID.name = name; // eslint-disable-next-line no-empty
+  } catch (err) {} // For CommonJS default export support
+
+
+  generateUUID.DNS = DNS;
+  generateUUID.URL = URL;
+  return generateUUID;
+}
+
+/***/ }),
+
+/***/ 83189:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
+
+"use strict";
+
+
+Object.defineProperty(exports, "__esModule", ({
+  value: true
+}));
+exports["default"] = void 0;
+
+var _rng = _interopRequireDefault(__nccwpck_require__(76983));
+
+var _stringify = _interopRequireDefault(__nccwpck_require__(83377));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+function v4(options, buf, offset) {
+  options = options || {};
+
+  const rnds = options.random || (options.rng || _rng.default)(); // Per 4.4, set bits for version and `clock_seq_hi_and_reserved`
+
+
+  rnds[6] = rnds[6] & 0x0f | 0x40;
+  rnds[8] = rnds[8] & 0x3f | 0x80; // Copy bytes to buffer, if provided
+
+  if (buf) {
+    offset = offset || 0;
+
+    for (let i = 0; i < 16; ++i) {
+      buf[offset + i] = rnds[i];
+    }
+
+    return buf;
+  }
+
+  return (0, _stringify.default)(rnds);
+}
+
+var _default = v4;
+exports["default"] = _default;
+
+/***/ }),
+
+/***/ 9798:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
+
+"use strict";
+
+
+Object.defineProperty(exports, "__esModule", ({
+  value: true
+}));
+exports["default"] = void 0;
+
+var _v = _interopRequireDefault(__nccwpck_require__(43127));
+
+var _sha = _interopRequireDefault(__nccwpck_require__(41033));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+const v5 = (0, _v.default)('v5', 0x50, _sha.default);
+var _default = v5;
+exports["default"] = _default;
+
+/***/ }),
+
+/***/ 8021:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
+
+"use strict";
+
+
+Object.defineProperty(exports, "__esModule", ({
+  value: true
+}));
+exports["default"] = void 0;
+
+var _regex = _interopRequireDefault(__nccwpck_require__(44818));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+function validate(uuid) {
+  return typeof uuid === 'string' && _regex.default.test(uuid);
+}
+
+var _default = validate;
+exports["default"] = _default;
+
+/***/ }),
+
+/***/ 92450:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
+
+"use strict";
+
+
+Object.defineProperty(exports, "__esModule", ({
+  value: true
+}));
+exports["default"] = void 0;
+
+var _validate = _interopRequireDefault(__nccwpck_require__(8021));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+function version(uuid) {
+  if (!(0, _validate.default)(uuid)) {
+    throw TypeError('Invalid UUID');
+  }
+
+  return parseInt(uuid.substr(14, 1), 16);
+}
+
+var _default = version;
+exports["default"] = _default;
+
+/***/ }),
+
+/***/ 26669:
+/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+
+"use strict";
+
+
+const Module = __nccwpck_require__(98188);
+const crypto = __nccwpck_require__(6113);
+const fs = __nccwpck_require__(57147);
+const path = __nccwpck_require__(71017);
+const vm = __nccwpck_require__(26144);
+const os = __nccwpck_require__(22037);
+
+const hasOwnProperty = Object.prototype.hasOwnProperty;
+
+//------------------------------------------------------------------------------
+// FileSystemBlobStore
+//------------------------------------------------------------------------------
+
+class FileSystemBlobStore {
+  constructor(directory, prefix) {
+    const name = prefix ? slashEscape(prefix + '.') : '';
+    this._blobFilename = path.join(directory, name + 'BLOB');
+    this._mapFilename = path.join(directory, name + 'MAP');
+    this._lockFilename = path.join(directory, name + 'LOCK');
+    this._directory = directory;
+    this._load();
+  }
+
+  has(key, invalidationKey) {
+    if (hasOwnProperty.call(this._memoryBlobs, key)) {
+      return this._invalidationKeys[key] === invalidationKey;
+    } else if (hasOwnProperty.call(this._storedMap, key)) {
+      return this._storedMap[key][0] === invalidationKey;
+    }
+    return false;
+  }
+
+  get(key, invalidationKey) {
+    if (hasOwnProperty.call(this._memoryBlobs, key)) {
+      if (this._invalidationKeys[key] === invalidationKey) {
+        return this._memoryBlobs[key];
+      }
+    } else if (hasOwnProperty.call(this._storedMap, key)) {
+      const mapping = this._storedMap[key];
+      if (mapping[0] === invalidationKey) {
+        return this._storedBlob.slice(mapping[1], mapping[2]);
+      }
+    }
+  }
+
+  set(key, invalidationKey, buffer) {
+    this._invalidationKeys[key] = invalidationKey;
+    this._memoryBlobs[key] = buffer;
+    this._dirty = true;
+  }
+
+  delete(key) {
+    if (hasOwnProperty.call(this._memoryBlobs, key)) {
+      this._dirty = true;
+      delete this._memoryBlobs[key];
+    }
+    if (hasOwnProperty.call(this._invalidationKeys, key)) {
+      this._dirty = true;
+      delete this._invalidationKeys[key];
+    }
+    if (hasOwnProperty.call(this._storedMap, key)) {
+      this._dirty = true;
+      delete this._storedMap[key];
+    }
+  }
+
+  isDirty() {
+    return this._dirty;
+  }
+
+  save() {
+    const dump = this._getDump();
+    const blobToStore = Buffer.concat(dump[0]);
+    const mapToStore = JSON.stringify(dump[1]);
+
+    try {
+      mkdirpSync(this._directory);
+      fs.writeFileSync(this._lockFilename, 'LOCK', {flag: 'wx'});
+    } catch (error) {
+      // Swallow the exception if we fail to acquire the lock.
+      return false;
+    }
+
+    try {
+      fs.writeFileSync(this._blobFilename, blobToStore);
+      fs.writeFileSync(this._mapFilename, mapToStore);
+    } finally {
+      fs.unlinkSync(this._lockFilename);
+    }
+
+    return true;
+  }
+
+  _load() {
+    try {
+      this._storedBlob = fs.readFileSync(this._blobFilename);
+      this._storedMap = JSON.parse(fs.readFileSync(this._mapFilename));
+    } catch (e) {
+      this._storedBlob = Buffer.alloc(0);
+      this._storedMap = {};
+    }
+    this._dirty = false;
+    this._memoryBlobs = {};
+    this._invalidationKeys = {};
+  }
+
+  _getDump() {
+    const buffers = [];
+    const newMap = {};
+    let offset = 0;
+
+    function push(key, invalidationKey, buffer) {
+      buffers.push(buffer);
+      newMap[key] = [invalidationKey, offset, offset + buffer.length];
+      offset += buffer.length;
+    }
+
+    for (const key of Object.keys(this._memoryBlobs)) {
+      const buffer = this._memoryBlobs[key];
+      const invalidationKey = this._invalidationKeys[key];
+      push(key, invalidationKey, buffer);
+    }
+
+    for (const key of Object.keys(this._storedMap)) {
+      if (hasOwnProperty.call(newMap, key)) continue;
+      const mapping = this._storedMap[key];
+      const buffer = this._storedBlob.slice(mapping[1], mapping[2]);
+      push(key, mapping[0], buffer);
+    }
+
+    return [buffers, newMap];
+  }
+}
+
+//------------------------------------------------------------------------------
+// NativeCompileCache
+//------------------------------------------------------------------------------
+
+class NativeCompileCache {
+  constructor() {
+    this._cacheStore = null;
+    this._previousModuleCompile = null;
+  }
+
+  setCacheStore(cacheStore) {
+    this._cacheStore = cacheStore;
+  }
+
+  install() {
+    const self = this;
+    const hasRequireResolvePaths = typeof require.resolve.paths === 'function';
+    this._previousModuleCompile = Module.prototype._compile;
+    Module.prototype._compile = this._ownModuleCompile = _ownModuleCompile;
+    self.enabled = true;
+    function _ownModuleCompile(content, filename) {
+      if(!self.enabled) return this._previousModuleCompile.apply(this, arguments);
+      const mod = this;
+
+      function require(id) {
+        return mod.require(id);
+      }
+
+      // https://github.com/nodejs/node/blob/v10.15.3/lib/internal/modules/cjs/helpers.js#L28
+      function resolve(request, options) {
+        return Module._resolveFilename(request, mod, false, options);
+      }
+      require.resolve = resolve;
+
+      // https://github.com/nodejs/node/blob/v10.15.3/lib/internal/modules/cjs/helpers.js#L37
+      // resolve.resolve.paths was added in v8.9.0
+      if (hasRequireResolvePaths) {
+        resolve.paths = function paths(request) {
+          return Module._resolveLookupPaths(request, mod, true);
+        };
+      }
+
+      require.main = process.mainModule;
+
+      // Enable support to add extra extension types
+      require.extensions = Module._extensions;
+      require.cache = Module._cache;
+
+      const dirname = path.dirname(filename);
+
+      const compiledWrapper = self._moduleCompile(filename, content);
+
+      // We skip the debugger setup because by the time we run, node has already
+      // done that itself.
+
+      // `Buffer` is included for Electron.
+      // See https://github.com/zertosh/v8-compile-cache/pull/10#issuecomment-518042543
+      const args = [mod.exports, require, mod, filename, dirname, process, global, Buffer];
+      return compiledWrapper.apply(mod.exports, args);
+    }
+  }
+
+  uninstall() {
+    this.enabled = false;
+    // If something else has since been installed on top of us, we cannot overwrite it.
+    if(Module.prototype._compile === this._ownModuleCompile) {
+      Module.prototype._compile = this._previousModuleCompile;
+    }
+  }
+
+  _moduleCompile(filename, content) {
+    // https://github.com/nodejs/node/blob/v7.5.0/lib/module.js#L511
+
+    // Remove shebang
+    var contLen = content.length;
+    if (contLen >= 2) {
+      if (content.charCodeAt(0) === 35/*#*/ &&
+          content.charCodeAt(1) === 33/*!*/) {
+        if (contLen === 2) {
+          // Exact match
+          content = '';
+        } else {
+          // Find end of shebang line and slice it off
+          var i = 2;
+          for (; i < contLen; ++i) {
+            var code = content.charCodeAt(i);
+            if (code === 10/*\n*/ || code === 13/*\r*/) break;
+          }
+          if (i === contLen) {
+            content = '';
+          } else {
+            // Note that this actually includes the newline character(s) in the
+            // new output. This duplicates the behavior of the regular
+            // expression that was previously used to replace the shebang line
+            content = content.slice(i);
+          }
+        }
+      }
+    }
+
+    // create wrapper function
+    var wrapper = Module.wrap(content);
+
+    var invalidationKey = crypto
+      .createHash('sha1')
+      .update(content, 'utf8')
+      .digest('hex');
+
+    var buffer = this._cacheStore.get(filename, invalidationKey);
+
+    var script = new vm.Script(wrapper, {
+      filename: filename,
+      lineOffset: 0,
+      displayErrors: true,
+      cachedData: buffer,
+      produceCachedData: true,
+    });
+
+    if (script.cachedDataProduced) {
+      this._cacheStore.set(filename, invalidationKey, script.cachedData);
+    } else if (script.cachedDataRejected) {
+      this._cacheStore.delete(filename);
+    }
+
+    var compiledWrapper = script.runInThisContext({
+      filename: filename,
+      lineOffset: 0,
+      columnOffset: 0,
+      displayErrors: true,
+    });
+
+    return compiledWrapper;
+  }
+}
+
+//------------------------------------------------------------------------------
+// utilities
+//
+// https://github.com/substack/node-mkdirp/blob/f2003bb/index.js#L55-L98
+// https://github.com/zertosh/slash-escape/blob/e7ebb99/slash-escape.js
+//------------------------------------------------------------------------------
+
+function mkdirpSync(p_) {
+  _mkdirpSync(path.resolve(p_), 0o777);
+}
+
+function _mkdirpSync(p, mode) {
+  try {
+    fs.mkdirSync(p, mode);
+  } catch (err0) {
+    if (err0.code === 'ENOENT') {
+      _mkdirpSync(path.dirname(p));
+      _mkdirpSync(p);
+    } else {
+      try {
+        const stat = fs.statSync(p);
+        if (!stat.isDirectory()) { throw err0; }
+      } catch (err1) {
+        throw err0;
+      }
+    }
+  }
+}
+
+function slashEscape(str) {
+  const ESCAPE_LOOKUP = {
+    '\\': 'zB',
+    ':': 'zC',
+    '/': 'zS',
+    '\x00': 'z0',
+    'z': 'zZ',
+  };
+  const ESCAPE_REGEX = /[\\:/\x00z]/g; // eslint-disable-line no-control-regex
+  return str.replace(ESCAPE_REGEX, match => ESCAPE_LOOKUP[match]);
+}
+
+function supportsCachedData() {
+  const script = new vm.Script('""', {produceCachedData: true});
+  // chakracore, as of v1.7.1.0, returns `false`.
+  return script.cachedDataProduced === true;
+}
+
+function getCacheDir() {
+  const v8_compile_cache_cache_dir = process.env.V8_COMPILE_CACHE_CACHE_DIR;
+  if (v8_compile_cache_cache_dir) {
+    return v8_compile_cache_cache_dir;
+  }
+
+  // Avoid cache ownership issues on POSIX systems.
+  const dirname = typeof process.getuid === 'function'
+    ? 'v8-compile-cache-' + process.getuid()
+    : 'v8-compile-cache';
+  const version = typeof process.versions.v8 === 'string'
+    ? process.versions.v8
+    : typeof process.versions.chakracore === 'string'
+      ? 'chakracore-' + process.versions.chakracore
+      : 'node-' + process.version;
+  const cacheDir = path.join(os.tmpdir(), dirname, version);
+  return cacheDir;
+}
+
+function getMainName() {
+  // `require.main.filename` is undefined or null when:
+  //    * node -e 'require("v8-compile-cache")'
+  //    * node -r 'v8-compile-cache'
+  //    * Or, requiring from the REPL.
+  const mainName = require.main && typeof require.main.filename === 'string'
+    ? require.main.filename
+    : process.cwd();
+  return mainName;
+}
+
+function install(opts) {
+  if (!process.env.DISABLE_V8_COMPILE_CACHE && supportsCachedData()) {
+    if(typeof opts === 'undefined') opts = {}
+    let cacheDir = opts.cacheDir
+    if(typeof cacheDir === 'undefined') cacheDir = getCacheDir();
+    let prefix = opts.prefix
+    if(typeof prefix === 'undefined') prefix = getMainName();
+    const blobStore = new FileSystemBlobStore(cacheDir, prefix);
+
+    const nativeCompileCache = new NativeCompileCache();
+    nativeCompileCache.setCacheStore(blobStore);
+    nativeCompileCache.install();
+
+    let uninstalled = false;
+    const uninstall = () => {
+      if(uninstalled) return;
+      uninstalled = true;
+      process.removeListener('exit', uninstall);
+      if (blobStore.isDirty()) {
+        blobStore.save();
+      }
+      nativeCompileCache.uninstall();
+    }
+    process.once('exit', uninstall);
+    return {uninstall};
+  }
+}
+
+//------------------------------------------------------------------------------
+// main
+//------------------------------------------------------------------------------
+
+module.exports.install = install;
+
+module.exports.__TEST__ = {
+  FileSystemBlobStore,
+  NativeCompileCache,
+  mkdirpSync,
+  slashEscape,
+  supportsCachedData,
+  getCacheDir,
+  getMainName,
+};
+
+
+/***/ }),
+
+/***/ 92863:
+/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+
+"use strict";
+
+const stringWidth = __nccwpck_require__(24823);
+const stripAnsi = __nccwpck_require__(74817);
+const ansiStyles = __nccwpck_require__(93799);
+
+const ESCAPES = new Set([
+	'\u001B',
+	'\u009B'
+]);
+
+const END_CODE = 39;
+
+const ANSI_ESCAPE_BELL = '\u0007';
+const ANSI_CSI = '[';
+const ANSI_OSC = ']';
+const ANSI_SGR_TERMINATOR = 'm';
+const ANSI_ESCAPE_LINK = `${ANSI_OSC}8;;`;
+
+const wrapAnsi = code => `${ESCAPES.values().next().value}${ANSI_CSI}${code}${ANSI_SGR_TERMINATOR}`;
+const wrapAnsiHyperlink = uri => `${ESCAPES.values().next().value}${ANSI_ESCAPE_LINK}${uri}${ANSI_ESCAPE_BELL}`;
+
+// Calculate the length of words split on ' ', ignoring
+// the extra characters added by ansi escape codes
+const wordLengths = string => string.split(' ').map(character => stringWidth(character));
+
+// Wrap a long word across multiple rows
+// Ansi escape codes do not count towards length
+const wrapWord = (rows, word, columns) => {
+	const characters = [...word];
+
+	let isInsideEscape = false;
+	let isInsideLinkEscape = false;
+	let visible = stringWidth(stripAnsi(rows[rows.length - 1]));
+
+	for (const [index, character] of characters.entries()) {
+		const characterLength = stringWidth(character);
+
+		if (visible + characterLength <= columns) {
+			rows[rows.length - 1] += character;
+		} else {
+			rows.push(character);
+			visible = 0;
+		}
+
+		if (ESCAPES.has(character)) {
+			isInsideEscape = true;
+			isInsideLinkEscape = characters.slice(index + 1).join('').startsWith(ANSI_ESCAPE_LINK);
+		}
+
+		if (isInsideEscape) {
+			if (isInsideLinkEscape) {
+				if (character === ANSI_ESCAPE_BELL) {
+					isInsideEscape = false;
+					isInsideLinkEscape = false;
+				}
+			} else if (character === ANSI_SGR_TERMINATOR) {
+				isInsideEscape = false;
+			}
+
+			continue;
+		}
+
+		visible += characterLength;
+
+		if (visible === columns && index < characters.length - 1) {
+			rows.push('');
+			visible = 0;
+		}
+	}
+
+	// It's possible that the last row we copy over is only
+	// ansi escape characters, handle this edge-case
+	if (!visible && rows[rows.length - 1].length > 0 && rows.length > 1) {
+		rows[rows.length - 2] += rows.pop();
+	}
+};
+
+// Trims spaces from a string ignoring invisible sequences
+const stringVisibleTrimSpacesRight = string => {
+	const words = string.split(' ');
+	let last = words.length;
+
+	while (last > 0) {
+		if (stringWidth(words[last - 1]) > 0) {
+			break;
+		}
+
+		last--;
+	}
+
+	if (last === words.length) {
+		return string;
+	}
+
+	return words.slice(0, last).join(' ') + words.slice(last).join('');
+};
+
+// The wrap-ansi module can be invoked in either 'hard' or 'soft' wrap mode
+//
+// 'hard' will never allow a string to take up more than columns characters
+//
+// 'soft' allows long words to expand past the column length
+const exec = (string, columns, options = {}) => {
+	if (options.trim !== false && string.trim() === '') {
+		return '';
+	}
+
+	let returnValue = '';
+	let escapeCode;
+	let escapeUrl;
+
+	const lengths = wordLengths(string);
+	let rows = [''];
+
+	for (const [index, word] of string.split(' ').entries()) {
+		if (options.trim !== false) {
+			rows[rows.length - 1] = rows[rows.length - 1].trimStart();
+		}
+
+		let rowLength = stringWidth(rows[rows.length - 1]);
+
+		if (index !== 0) {
+			if (rowLength >= columns && (options.wordWrap === false || options.trim === false)) {
+				// If we start with a new word but the current row length equals the length of the columns, add a new row
+				rows.push('');
+				rowLength = 0;
+			}
+
+			if (rowLength > 0 || options.trim === false) {
+				rows[rows.length - 1] += ' ';
+				rowLength++;
+			}
+		}
+
+		// In 'hard' wrap mode, the length of a line is never allowed to extend past 'columns'
+		if (options.hard && lengths[index] > columns) {
+			const remainingColumns = (columns - rowLength);
+			const breaksStartingThisLine = 1 + Math.floor((lengths[index] - remainingColumns - 1) / columns);
+			const breaksStartingNextLine = Math.floor((lengths[index] - 1) / columns);
+			if (breaksStartingNextLine < breaksStartingThisLine) {
+				rows.push('');
+			}
+
+			wrapWord(rows, word, columns);
+			continue;
+		}
+
+		if (rowLength + lengths[index] > columns && rowLength > 0 && lengths[index] > 0) {
+			if (options.wordWrap === false && rowLength < columns) {
+				wrapWord(rows, word, columns);
+				continue;
+			}
+
+			rows.push('');
+		}
+
+		if (rowLength + lengths[index] > columns && options.wordWrap === false) {
+			wrapWord(rows, word, columns);
+			continue;
+		}
+
+		rows[rows.length - 1] += word;
+	}
+
+	if (options.trim !== false) {
+		rows = rows.map(stringVisibleTrimSpacesRight);
+	}
+
+	const pre = [...rows.join('\n')];
+
+	for (const [index, character] of pre.entries()) {
+		returnValue += character;
+
+		if (ESCAPES.has(character)) {
+			const {groups} = new RegExp(`(?:\\${ANSI_CSI}(?\\d+)m|\\${ANSI_ESCAPE_LINK}(?.*)${ANSI_ESCAPE_BELL})`).exec(pre.slice(index).join('')) || {groups: {}};
+			if (groups.code !== undefined) {
+				const code = Number.parseFloat(groups.code);
+				escapeCode = code === END_CODE ? undefined : code;
+			} else if (groups.uri !== undefined) {
+				escapeUrl = groups.uri.length === 0 ? undefined : groups.uri;
+			}
+		}
+
+		const code = ansiStyles.codes.get(Number(escapeCode));
+
+		if (pre[index + 1] === '\n') {
+			if (escapeUrl) {
+				returnValue += wrapAnsiHyperlink('');
+			}
+
+			if (escapeCode && code) {
+				returnValue += wrapAnsi(code);
+			}
+		} else if (character === '\n') {
+			if (escapeCode && code) {
+				returnValue += wrapAnsi(escapeCode);
+			}
+
+			if (escapeUrl) {
+				returnValue += wrapAnsiHyperlink(escapeUrl);
+			}
+		}
+	}
+
+	return returnValue;
+};
+
+// For each newline, invoke the method separately
+module.exports = (string, columns, options) => {
+	return String(string)
+		.normalize()
+		.replace(/\r\n/g, '\n')
+		.split('\n')
+		.map(line => exec(line, columns, options))
+		.join('\n');
+};
+
+
+/***/ }),
+
+/***/ 65173:
+/***/ ((module) => {
+
+// Returns a wrapper function that returns a wrapped callback
+// The wrapper function should do some stuff, and return a
+// presumably different callback function.
+// This makes sure that own properties are retained, so that
+// decorations and such are not lost along the way.
+module.exports = wrappy
+function wrappy (fn, cb) {
+  if (fn && cb) return wrappy(fn)(cb)
+
+  if (typeof fn !== 'function')
+    throw new TypeError('need wrapper function')
+
+  Object.keys(fn).forEach(function (k) {
+    wrapper[k] = fn[k]
+  })
+
+  return wrapper
+
+  function wrapper() {
+    var args = new Array(arguments.length)
+    for (var i = 0; i < args.length; i++) {
+      args[i] = arguments[i]
+    }
+    var ret = fn.apply(this, args)
+    var cb = args[args.length-1]
+    if (typeof ret === 'function' && ret !== cb) {
+      Object.keys(cb).forEach(function (k) {
+        ret[k] = cb[k]
+      })
+    }
+    return ret
+  }
+}
+
+
+/***/ }),
+
+/***/ 89222:
+/***/ ((module) => {
+
+"use strict";
+
+module.exports = function (Yallist) {
+  Yallist.prototype[Symbol.iterator] = function* () {
+    for (let walker = this.head; walker; walker = walker.next) {
+      yield walker.value
+    }
+  }
+}
+
+
+/***/ }),
+
+/***/ 83278:
+/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+
+"use strict";
+
+module.exports = Yallist
+
+Yallist.Node = Node
+Yallist.create = Yallist
+
+function Yallist (list) {
+  var self = this
+  if (!(self instanceof Yallist)) {
+    self = new Yallist()
+  }
+
+  self.tail = null
+  self.head = null
+  self.length = 0
+
+  if (list && typeof list.forEach === 'function') {
+    list.forEach(function (item) {
+      self.push(item)
+    })
+  } else if (arguments.length > 0) {
+    for (var i = 0, l = arguments.length; i < l; i++) {
+      self.push(arguments[i])
+    }
+  }
+
+  return self
+}
+
+Yallist.prototype.removeNode = function (node) {
+  if (node.list !== this) {
+    throw new Error('removing node which does not belong to this list')
+  }
+
+  var next = node.next
+  var prev = node.prev
+
+  if (next) {
+    next.prev = prev
+  }
+
+  if (prev) {
+    prev.next = next
+  }
+
+  if (node === this.head) {
+    this.head = next
+  }
+  if (node === this.tail) {
+    this.tail = prev
+  }
+
+  node.list.length--
+  node.next = null
+  node.prev = null
+  node.list = null
+
+  return next
+}
+
+Yallist.prototype.unshiftNode = function (node) {
+  if (node === this.head) {
+    return
+  }
+
+  if (node.list) {
+    node.list.removeNode(node)
+  }
+
+  var head = this.head
+  node.list = this
+  node.next = head
+  if (head) {
+    head.prev = node
+  }
+
+  this.head = node
+  if (!this.tail) {
+    this.tail = node
+  }
+  this.length++
+}
+
+Yallist.prototype.pushNode = function (node) {
+  if (node === this.tail) {
+    return
+  }
+
+  if (node.list) {
+    node.list.removeNode(node)
+  }
+
+  var tail = this.tail
+  node.list = this
+  node.prev = tail
+  if (tail) {
+    tail.next = node
+  }
+
+  this.tail = node
+  if (!this.head) {
+    this.head = node
+  }
+  this.length++
+}
+
+Yallist.prototype.push = function () {
+  for (var i = 0, l = arguments.length; i < l; i++) {
+    push(this, arguments[i])
+  }
+  return this.length
+}
+
+Yallist.prototype.unshift = function () {
+  for (var i = 0, l = arguments.length; i < l; i++) {
+    unshift(this, arguments[i])
+  }
+  return this.length
+}
+
+Yallist.prototype.pop = function () {
+  if (!this.tail) {
+    return undefined
+  }
+
+  var res = this.tail.value
+  this.tail = this.tail.prev
+  if (this.tail) {
+    this.tail.next = null
+  } else {
+    this.head = null
+  }
+  this.length--
+  return res
+}
+
+Yallist.prototype.shift = function () {
+  if (!this.head) {
+    return undefined
+  }
+
+  var res = this.head.value
+  this.head = this.head.next
+  if (this.head) {
+    this.head.prev = null
+  } else {
+    this.tail = null
+  }
+  this.length--
+  return res
+}
+
+Yallist.prototype.forEach = function (fn, thisp) {
+  thisp = thisp || this
+  for (var walker = this.head, i = 0; walker !== null; i++) {
+    fn.call(thisp, walker.value, i, this)
+    walker = walker.next
+  }
+}
+
+Yallist.prototype.forEachReverse = function (fn, thisp) {
+  thisp = thisp || this
+  for (var walker = this.tail, i = this.length - 1; walker !== null; i--) {
+    fn.call(thisp, walker.value, i, this)
+    walker = walker.prev
+  }
+}
+
+Yallist.prototype.get = function (n) {
+  for (var i = 0, walker = this.head; walker !== null && i < n; i++) {
+    // abort out of the list early if we hit a cycle
+    walker = walker.next
+  }
+  if (i === n && walker !== null) {
+    return walker.value
+  }
+}
+
+Yallist.prototype.getReverse = function (n) {
+  for (var i = 0, walker = this.tail; walker !== null && i < n; i++) {
+    // abort out of the list early if we hit a cycle
+    walker = walker.prev
+  }
+  if (i === n && walker !== null) {
+    return walker.value
+  }
+}
+
+Yallist.prototype.map = function (fn, thisp) {
+  thisp = thisp || this
+  var res = new Yallist()
+  for (var walker = this.head; walker !== null;) {
+    res.push(fn.call(thisp, walker.value, this))
+    walker = walker.next
+  }
+  return res
+}
+
+Yallist.prototype.mapReverse = function (fn, thisp) {
+  thisp = thisp || this
+  var res = new Yallist()
+  for (var walker = this.tail; walker !== null;) {
+    res.push(fn.call(thisp, walker.value, this))
+    walker = walker.prev
+  }
+  return res
+}
+
+Yallist.prototype.reduce = function (fn, initial) {
+  var acc
+  var walker = this.head
+  if (arguments.length > 1) {
+    acc = initial
+  } else if (this.head) {
+    walker = this.head.next
+    acc = this.head.value
+  } else {
+    throw new TypeError('Reduce of empty list with no initial value')
+  }
+
+  for (var i = 0; walker !== null; i++) {
+    acc = fn(acc, walker.value, i)
+    walker = walker.next
+  }
+
+  return acc
+}
+
+Yallist.prototype.reduceReverse = function (fn, initial) {
+  var acc
+  var walker = this.tail
+  if (arguments.length > 1) {
+    acc = initial
+  } else if (this.tail) {
+    walker = this.tail.prev
+    acc = this.tail.value
+  } else {
+    throw new TypeError('Reduce of empty list with no initial value')
+  }
+
+  for (var i = this.length - 1; walker !== null; i--) {
+    acc = fn(acc, walker.value, i)
+    walker = walker.prev
+  }
+
+  return acc
+}
+
+Yallist.prototype.toArray = function () {
+  var arr = new Array(this.length)
+  for (var i = 0, walker = this.head; walker !== null; i++) {
+    arr[i] = walker.value
+    walker = walker.next
+  }
+  return arr
+}
+
+Yallist.prototype.toArrayReverse = function () {
+  var arr = new Array(this.length)
+  for (var i = 0, walker = this.tail; walker !== null; i++) {
+    arr[i] = walker.value
+    walker = walker.prev
+  }
+  return arr
+}
+
+Yallist.prototype.slice = function (from, to) {
+  to = to || this.length
+  if (to < 0) {
+    to += this.length
+  }
+  from = from || 0
+  if (from < 0) {
+    from += this.length
+  }
+  var ret = new Yallist()
+  if (to < from || to < 0) {
+    return ret
+  }
+  if (from < 0) {
+    from = 0
+  }
+  if (to > this.length) {
+    to = this.length
+  }
+  for (var i = 0, walker = this.head; walker !== null && i < from; i++) {
+    walker = walker.next
+  }
+  for (; walker !== null && i < to; i++, walker = walker.next) {
+    ret.push(walker.value)
+  }
+  return ret
+}
+
+Yallist.prototype.sliceReverse = function (from, to) {
+  to = to || this.length
+  if (to < 0) {
+    to += this.length
+  }
+  from = from || 0
+  if (from < 0) {
+    from += this.length
+  }
+  var ret = new Yallist()
+  if (to < from || to < 0) {
+    return ret
+  }
+  if (from < 0) {
+    from = 0
+  }
+  if (to > this.length) {
+    to = this.length
+  }
+  for (var i = this.length, walker = this.tail; walker !== null && i > to; i--) {
+    walker = walker.prev
+  }
+  for (; walker !== null && i > from; i--, walker = walker.prev) {
+    ret.push(walker.value)
+  }
+  return ret
+}
+
+Yallist.prototype.splice = function (start, deleteCount, ...nodes) {
+  if (start > this.length) {
+    start = this.length - 1
+  }
+  if (start < 0) {
+    start = this.length + start;
+  }
+
+  for (var i = 0, walker = this.head; walker !== null && i < start; i++) {
+    walker = walker.next
+  }
+
+  var ret = []
+  for (var i = 0; walker && i < deleteCount; i++) {
+    ret.push(walker.value)
+    walker = this.removeNode(walker)
+  }
+  if (walker === null) {
+    walker = this.tail
+  }
+
+  if (walker !== this.head && walker !== this.tail) {
+    walker = walker.prev
+  }
+
+  for (var i = 0; i < nodes.length; i++) {
+    walker = insert(this, walker, nodes[i])
+  }
+  return ret;
+}
+
+Yallist.prototype.reverse = function () {
+  var head = this.head
+  var tail = this.tail
+  for (var walker = head; walker !== null; walker = walker.prev) {
+    var p = walker.prev
+    walker.prev = walker.next
+    walker.next = p
+  }
+  this.head = tail
+  this.tail = head
+  return this
+}
+
+function insert (self, node, value) {
+  var inserted = node === self.head ?
+    new Node(value, null, node, self) :
+    new Node(value, node, node.next, self)
+
+  if (inserted.next === null) {
+    self.tail = inserted
+  }
+  if (inserted.prev === null) {
+    self.head = inserted
+  }
+
+  self.length++
+
+  return inserted
+}
+
+function push (self, item) {
+  self.tail = new Node(item, self.tail, null, self)
+  if (!self.head) {
+    self.head = self.tail
+  }
+  self.length++
+}
+
+function unshift (self, item) {
+  self.head = new Node(item, null, self.head, self)
+  if (!self.tail) {
+    self.tail = self.head
+  }
+  self.length++
+}
+
+function Node (value, prev, next, list) {
+  if (!(this instanceof Node)) {
+    return new Node(value, prev, next, list)
+  }
+
+  this.list = list
+  this.value = value
+
+  if (prev) {
+    prev.next = this
+    this.prev = prev
+  } else {
+    this.prev = null
+  }
+
+  if (next) {
+    next.prev = this
+    this.next = next
+  } else {
+    this.next = null
+  }
+}
+
+try {
+  // add if support for Symbol.iterator is present
+  __nccwpck_require__(89222)(Yallist)
+} catch (er) {}
+
+
+/***/ }),
+
+/***/ 45001:
+/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+
+"use strict";
+
+const lenient = __nccwpck_require__(88081);
+
+const yn = (input, options) => {
+	input = String(input).trim();
+
+	options = Object.assign({
+		lenient: false,
+		default: null
+	}, options);
+
+	if (options.default !== null && typeof options.default !== 'boolean') {
+		throw new TypeError(`Expected the \`default\` option to be of type \`boolean\`, got \`${typeof options.default}\``);
+	}
+
+	if (/^(?:y|yes|true|1)$/i.test(input)) {
+		return true;
+	}
+
+	if (/^(?:n|no|false|0)$/i.test(input)) {
+		return false;
+	}
+
+	if (options.lenient === true) {
+		return lenient(input, options);
+	}
+
+	return options.default;
+};
+
+module.exports = yn;
+// TODO: Remove this for the next major release
+module.exports["default"] = yn;
+
+
+/***/ }),
+
+/***/ 88081:
+/***/ ((module) => {
+
+"use strict";
+
+
+const YES_MATCH_SCORE_THRESHOLD = 2;
+const NO_MATCH_SCORE_THRESHOLD = 1.25;
+
+const yMatch = new Map([
+	[5, 0.25],
+	[6, 0.25],
+	[7, 0.25],
+	['t', 0.75],
+	['y', 1],
+	['u', 0.75],
+	['g', 0.25],
+	['h', 0.25],
+	['j', 0.25]
+]);
+
+const eMatch = new Map([
+	[2, 0.25],
+	[3, 0.25],
+	[4, 0.25],
+	['w', 0.75],
+	['e', 1],
+	['r', 0.75],
+	['s', 0.25],
+	['d', 0.25],
+	['f', 0.25]
+]);
+
+const sMatch = new Map([
+	['q', 0.25],
+	['w', 0.25],
+	['e', 0.25],
+	['a', 0.75],
+	['s', 1],
+	['d', 0.75],
+	['z', 0.25],
+	['x', 0.25],
+	['c', 0.25]
+]);
+
+const nMatch = new Map([
+	['h', 0.25],
+	['j', 0.25],
+	['k', 0.25],
+	['b', 0.75],
+	['n', 1],
+	['m', 0.75]
+]);
+
+const oMatch = new Map([
+	[9, 0.25],
+	[0, 0.25],
+	['i', 0.75],
+	['o', 1],
+	['p', 0.75],
+	['k', 0.25],
+	['l', 0.25]
+]);
+
+function getYesMatchScore(value) {
+	const [y, e, s] = value;
+	let score = 0;
+
+	if (yMatch.has(y)) {
+		score += yMatch.get(y);
+	}
+
+	if (eMatch.has(e)) {
+		score += eMatch.get(e);
+	}
+
+	if (sMatch.has(s)) {
+		score += sMatch.get(s);
+	}
+
+	return score;
+}
+
+function getNoMatchScore(value) {
+	const [n, o] = value;
+	let score = 0;
+
+	if (nMatch.has(n)) {
+		score += nMatch.get(n);
+	}
+
+	if (oMatch.has(o)) {
+		score += oMatch.get(o);
+	}
+
+	return score;
+}
+
+module.exports = (input, options) => {
+	if (getYesMatchScore(input) >= YES_MATCH_SCORE_THRESHOLD) {
+		return true;
+	}
+
+	if (getNoMatchScore(input) >= NO_MATCH_SCORE_THRESHOLD) {
+		return false;
+	}
+
+	return options.default;
+};
+
+
+/***/ }),
+
+/***/ 28282:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
+
+"use strict";
+
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.argv = void 0;
+const tslib_1 = __nccwpck_require__(41464);
+const core = tslib_1.__importStar(__nccwpck_require__(44712));
+const tree_1 = __nccwpck_require__(11385);
+const project_configuration_1 = __nccwpck_require__(1934);
+const path_1 = __nccwpck_require__(71017);
+const helpers_1 = __nccwpck_require__(61233);
+const yargs_1 = tslib_1.__importDefault(__nccwpck_require__(28701));
+const build_command_1 = __nccwpck_require__(95321);
+const exec_1 = __nccwpck_require__(12953);
+const has_one_of_required_tags_1 = __nccwpck_require__(99982);
+const run_target_1 = __nccwpck_require__(17877);
+exports.argv = (0, yargs_1.default)((0, helpers_1.hideBin)(process.argv))
+    .options({
+    tag: { type: 'string' },
+    config: { type: 'string' },
+    target: { type: 'string' },
+    parallel: { type: 'number' },
+    verbose: { type: 'boolean' },
+    affectedOnly: { type: 'boolean' }
+})
+    .parseSync();
+function run() {
+    return tslib_1.__awaiter(this, void 0, void 0, function* () {
+        try {
+            const nxTree = new tree_1.FsTree(process.cwd(), false);
+            const projects = (0, project_configuration_1.getProjects)(nxTree);
+            // Get all options
+            const tagConditions = (exports.argv.tag ? [exports.argv.tag] : core.getMultilineInput('tag', { trimWhitespace: true }));
+            const target = core.getInput('target', { required: !exports.argv.target }) || exports.argv.target;
+            const affectedOnly = exports.argv.affectedOnly !== undefined ? exports.argv.affectedOnly : core.getBooleanInput('affectedOnly');
+            const config = core.getInput('config') || exports.argv.config;
+            const jobIndex = parseInt(core.getInput('index') || '1', 10);
+            const jobCount = parseInt(core.getInput('count') || '1', 10);
+            const parallel = (core.getInput('parallel') || exports.argv.parallel);
+            const workingDirectory = core.getInput('workingDirectory') || '';
+            const preTargets = core.getMultilineInput('preTargets', {
+                trimWhitespace: true
+            });
+            const postTargets = core.getMultilineInput('postTargets', {
+                trimWhitespace: true
+            });
+            core.debug(`Job index ${jobIndex}`);
+            core.debug(`Job count ${jobCount}`);
+            core.debug(`Pre targets ${JSON.stringify(preTargets, null, 2)}`);
+            core.debug(`Post targets ${JSON.stringify(postTargets, null, 2)}`);
+            if (tagConditions.length > 0) {
+                core.info(`Running all projects with one of the following tags "${tagConditions.join(', ')}"`);
+            }
+            const cwd = (0, path_1.resolve)(process.cwd(), workingDirectory);
+            const projectsNamesToRun = affectedOnly
+                ? JSON.parse((0, exec_1.execCommand)((0, build_command_1.buildCommand)([
+                    'npx nx show projects --affected --json',
+                    `-t ${target}`
+                ]), {
+                    asString: true,
+                    silent: !(core.isDebug() || exports.argv.verbose),
+                    cwd
+                }))
+                : Array.from(projects.keys());
+            // Make sure to still log the project names
+            if (!affectedOnly) {
+                core.debug(JSON.stringify(projectsNamesToRun));
+            }
+            // Get all affected projects
+            const projectsToRun = projectsNamesToRun.filter((projectName) => {
+                if (!projects.has(projectName)) {
+                    return false;
+                }
+                const project = projects.get(projectName);
+                const tags = project.tags || [];
+                // If the project has ci=off then don't run it
+                if (tags.includes('ci=off')) {
+                    core.debug(`[${projectName}]: Has the "ci=off" tag, skipping it.`);
+                    return false;
+                }
+                if (!tagConditions || tagConditions.length === 0) {
+                    return true;
+                }
+                // If a tag is provided the project should have it
+                return (!tagConditions || tagConditions.length === 0) || (0, has_one_of_required_tags_1.hasOneOfRequiredTags)(projectName, tags, tagConditions);
+            }).sort((projectNameA, projectNameB) => (projectNameA.localeCompare(projectNameB)));
+            const sliceSize = Math.max(Math.floor(projectsToRun.length / jobCount), 1);
+            const runProjects = jobIndex < jobCount
+                ? projectsToRun.slice(sliceSize * (jobIndex - 1), sliceSize * jobIndex)
+                : projectsToRun.slice(sliceSize * (jobIndex - 1));
+            if (preTargets.length > 0) {
+                for (const targetParts of preTargets) {
+                    core.info(`Running preTarget "${targetParts}"`);
+                    const [target, targetConfig] = targetParts.split(':');
+                    yield (0, run_target_1.runTarget)(cwd, projects, runProjects, target, targetConfig, parallel);
+                }
+            }
+            yield (0, run_target_1.runTarget)(cwd, projects, runProjects, target, config, parallel, !exports.argv.target);
+            if (postTargets.length > 0) {
+                for (const targetParts of postTargets) {
+                    core.info(`Running postTarget "${targetParts}"`);
+                    const [target, targetConfig] = targetParts.split(':');
+                    yield (0, run_target_1.runTarget)(cwd, projects, runProjects, target, targetConfig, parallel);
+                }
+            }
+        }
+        catch (err) {
+            core.setFailed(err);
+        }
+    });
+}
+run();
+
+
+/***/ }),
+
+/***/ 95321:
+/***/ ((__unused_webpack_module, exports) => {
+
+"use strict";
+
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.buildCommand = void 0;
+const buildCommand = (parts) => {
+    return parts.filter(Boolean).join(' ');
+};
+exports.buildCommand = buildCommand;
+
+
+/***/ }),
+
+/***/ 12953:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
+
+"use strict";
+
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.execCommand = exports.ChildProcess = void 0;
+const tslib_1 = __nccwpck_require__(41464);
+const child_process_1 = __nccwpck_require__(32081);
+Object.defineProperty(exports, "ChildProcess", ({ enumerable: true, get: function () { return child_process_1.ChildProcess; } }));
+const shell = tslib_1.__importStar(__nccwpck_require__(26877));
+const execCommand = (command, options = {
+    asString: false,
+    asJSON: false
+}) => {
+    if (!options.silent) {
+        console.log('\nRunning: ', command);
+    }
+    const result = shell.exec(command, options);
+    if (options.asJSON) {
+        return JSON.parse(result.toString());
+    }
+    if (options.asString) {
+        // eslint-disable-next-line @typescript-eslint/ban-ts-comment
+        // @ts-ignore
+        return result.toString();
+    }
+    // eslint-disable-next-line @typescript-eslint/ban-ts-comment
+    // @ts-ignore
+    return {
+        success: result['code'] === 0,
+        output: result.stdout
+    };
+};
+exports.execCommand = execCommand;
+
+
+/***/ }),
+
+/***/ 93625:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
+
+"use strict";
+
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.generateSummary = void 0;
+const tslib_1 = __nccwpck_require__(41464);
+const core = tslib_1.__importStar(__nccwpck_require__(44712));
+function generateSummary(target, runProjects, output) {
+    return tslib_1.__awaiter(this, void 0, void 0, function* () {
+        const failedProjects = output.split('\n')
+            .filter((line) => line.trim().length > 1)
+            .reduce((projects, line) => {
+            if (projects === undefined && line.includes('Failed tasks')) {
+                return [];
+            }
+            else if (projects !== undefined && line.trim().startsWith('-')) {
+                return projects.concat(line.replace('-', '').split(':').shift().trim());
+            }
+            return projects;
+        }, undefined) || []
+            .map((project) => ({
+            name: project,
+            target,
+            failed: failedProjects.includes(project)
+        }));
+        const summary = core.summary
+            .addHeading(`nx affected:${target}`, 2)
+            .addTable([
+            [{ data: 'Project', header: true }, { data: 'Result', header: true }],
+            ...runProjects.reduce((table, project) => {
+                table.push([
+                    project,
+                    failedProjects.includes(project) ? ':x:' : ':white_check_mark:\t'
+                ]);
+                return table;
+            }, [])
+        ]);
+        // TODO:: Add links to the cloud run / functions / firebase hosting / vercel urls
+        // summary.addLink('View staging deployment!', 'https://github.com')
+        yield summary.write();
+    });
+}
+exports.generateSummary = generateSummary;
+
+
+/***/ }),
+
+/***/ 236:
+/***/ ((__unused_webpack_module, exports) => {
+
+"use strict";
+
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.getProjectsWithTarget = void 0;
+function getProjectsWithTarget(projects, runProjects, target) {
+    // Filter out all projects that are not allowed
+    return Array.from(projects).filter(([project, config]) => {
+        var _a;
+        // Check if the project has the provided target
+        return Object.keys((_a = config === null || config === void 0 ? void 0 : config.targets) !== null && _a !== void 0 ? _a : {}).includes(target)
+            && runProjects.includes(project);
+    }).map(([project]) => project);
+}
+exports.getProjectsWithTarget = getProjectsWithTarget;
+
+
+/***/ }),
+
+/***/ 8664:
+/***/ ((__unused_webpack_module, exports) => {
+
+"use strict";
+
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.getRestArgs = void 0;
+function getRestArgs() {
+    return process.argv
+        .slice(2)
+        .filter((arg) => (!arg.includes('--tag')
+        && !arg.includes('--target')
+        && !arg.includes('--parallel')
+        && !arg.includes('--config')))
+        .map((a) => `"${a}"`)
+        .join(' ');
+}
+exports.getRestArgs = getRestArgs;
+
+
+/***/ }),
+
+/***/ 99982:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
+
+"use strict";
+
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.hasOneOfRequiredTags = void 0;
+const tslib_1 = __nccwpck_require__(41464);
+const core = tslib_1.__importStar(__nccwpck_require__(44712));
+function hasTagMatchingCondition(condition, tags) {
+    if (condition.includes('=')) {
+        // If it includes a "," it's a AND condition
+        if (condition.includes(',')) {
+            const subConditions = condition.split(',').map((subCondition) => subCondition.trim());
+            // It should match all the conditions
+            return subConditions.every((subCondition) => {
+                return hasTagMatchingCondition(subCondition, tags);
+            });
+        }
+        if (condition.includes('!=')) {
+            const [conditionKey, conditionValue] = condition.split('!=');
+            const useTags = tags.filter((tag) => tag.startsWith(`${conditionKey}=`));
+            // If the project does not have any tags with the condition key it's allowed
+            if (useTags.length === 0) {
+                return true;
+            }
+            return useTags.some((tag) => {
+                return tag.split('=').pop().trim() !== conditionValue.trim();
+            }, []);
+        }
+        else {
+            const [conditionKey, conditionValue] = condition.split('=');
+            return tags.some((tag) => {
+                const [key, value] = tag.split('=');
+                if (conditionKey !== key) {
+                    return false;
+                }
+                return conditionValue.trim() === value.trim();
+            });
+        }
+    }
+    else {
+        return tags.some((tag) => tag === condition);
+    }
+}
+function cleanLogConditions(conditions) {
+    return conditions.map((condition) => {
+        if (condition.includes(',')) {
+            return condition.split(',').map((subCondition) => subCondition.trim())
+                .join(' AND ');
+        }
+        return condition;
+    }).join(' OR ');
+}
+function hasOneOfRequiredTags(projectName, tags, requiresOnOfTheseTagConditions) {
+    if (!requiresOnOfTheseTagConditions || requiresOnOfTheseTagConditions.length === 0) {
+        return true;
+    }
+    if (!tags || tags.length === 0) {
+        return false;
+    }
+    const hasMatch = requiresOnOfTheseTagConditions.some((condition) => hasTagMatchingCondition(condition, tags));
+    if (!hasMatch) {
+        core.debug(`[${projectName}]: Does not match any of the provided condition "${cleanLogConditions(requiresOnOfTheseTagConditions)}"`);
+    }
+    return hasMatch;
+}
+exports.hasOneOfRequiredTags = hasOneOfRequiredTags;
+
+
+/***/ }),
+
+/***/ 17877:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
+
+"use strict";
+
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.runTarget = void 0;
+const tslib_1 = __nccwpck_require__(41464);
+const core = tslib_1.__importStar(__nccwpck_require__(44712));
+const run_many_1 = __nccwpck_require__(28282);
+const build_command_1 = __nccwpck_require__(95321);
+const exec_1 = __nccwpck_require__(12953);
+const generate_summary_1 = __nccwpck_require__(93625);
+const get_projects_with_target_1 = __nccwpck_require__(236);
+const get_rest_args_1 = __nccwpck_require__(8664);
+function runTarget(cwd, projects, runProjects, target, config, parallel, withSummary) {
+    return tslib_1.__awaiter(this, void 0, void 0, function* () {
+        const projectsWithTarget = (0, get_projects_with_target_1.getProjectsWithTarget)(projects, runProjects, target);
+        if (projectsWithTarget.length === 0) {
+            core.info(`No projects to run for target "${target}"`);
+            return;
+        }
+        const runManyCommandParts = [
+            'npx nx run-many',
+            `--target=${target}`,
+            `--projects=${projectsWithTarget.join(',')}`,
+            `--output-style=stream`,
+            config && `--configuration=${config}`,
+            (core.isDebug() || run_many_1.argv.verbose) && '--verbose',
+            `${(0, get_rest_args_1.getRestArgs)()}`
+        ];
+        switch (target) {
+            case 'build':
+                if (!config) {
+                    runManyCommandParts.push('--prod');
+                }
+                break;
+            case 'deploy':
+                if (!parallel) {
+                    runManyCommandParts.push('--parallel=2');
+                }
+                break;
+            case 'test':
+                if (!parallel) {
+                    runManyCommandParts.push('--parallel=4');
+                }
+                break;
+        }
+        if (parallel) {
+            runManyCommandParts.push(`--parallel=${parallel}`);
+        }
+        const runManyResult = (0, exec_1.execCommand)((0, build_command_1.buildCommand)(runManyCommandParts), {
+            cwd
+        });
+        if (!runManyResult.success) {
+            core.setFailed('Run many command failed!');
+        }
+        if (withSummary) {
+            try {
+                yield (0, generate_summary_1.generateSummary)(target, projectsWithTarget, runManyResult.output);
+            }
+            catch (err) {
+                core.warning(`Error generating Github summary: ${err.message || err}`);
+            }
+        }
+    });
+}
+exports.runTarget = runTarget;
+
+
+/***/ }),
+
+/***/ 74067:
+/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+
+module.exports = require(__nccwpck_require__.ab + "nx.darwin-arm64.node")
+
+/***/ }),
+
+/***/ 67754:
+/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+
+module.exports = require(__nccwpck_require__.ab + "swc.darwin-arm64.node")
+
+/***/ }),
+
+/***/ 17377:
+/***/ ((module) => {
+
+module.exports = eval("require")("./nx.android-arm-eabi.node");
+
+
+/***/ }),
+
+/***/ 35137:
+/***/ ((module) => {
+
+module.exports = eval("require")("./nx.android-arm64.node");
+
+
+/***/ }),
+
+/***/ 46502:
+/***/ ((module) => {
+
+module.exports = eval("require")("./nx.darwin-arm64.node");
+
+
+/***/ }),
+
+/***/ 52701:
+/***/ ((module) => {
+
+module.exports = eval("require")("./nx.darwin-universal.node");
+
+
+/***/ }),
+
+/***/ 1322:
+/***/ ((module) => {
+
+module.exports = eval("require")("./nx.darwin-x64.node");
+
+
+/***/ }),
+
+/***/ 35488:
+/***/ ((module) => {
+
+module.exports = eval("require")("./nx.freebsd-x64.node");
+
+
+/***/ }),
+
+/***/ 56986:
+/***/ ((module) => {
+
+module.exports = eval("require")("./nx.linux-arm-gnueabihf.node");
+
+
+/***/ }),
+
+/***/ 69480:
+/***/ ((module) => {
+
+module.exports = eval("require")("./nx.linux-arm64-gnu.node");
+
+
+/***/ }),
+
+/***/ 76818:
+/***/ ((module) => {
+
+module.exports = eval("require")("./nx.linux-arm64-musl.node");
+
+
+/***/ }),
+
+/***/ 37202:
+/***/ ((module) => {
+
+module.exports = eval("require")("./nx.linux-x64-gnu.node");
+
+
+/***/ }),
+
+/***/ 76200:
+/***/ ((module) => {
+
+module.exports = eval("require")("./nx.linux-x64-musl.node");
+
+
+/***/ }),
+
+/***/ 16320:
+/***/ ((module) => {
+
+module.exports = eval("require")("./nx.win32-arm64-msvc.node");
+
+
+/***/ }),
+
+/***/ 33821:
+/***/ ((module) => {
+
+module.exports = eval("require")("./nx.win32-ia32-msvc.node");
+
+
+/***/ }),
+
+/***/ 82472:
+/***/ ((module) => {
+
+module.exports = eval("require")("./nx.win32-x64-msvc.node");
+
+
+/***/ }),
+
+/***/ 84384:
+/***/ ((module) => {
+
+module.exports = eval("require")("./swc.android-arm-eabi.node");
+
+
+/***/ }),
+
+/***/ 27607:
+/***/ ((module) => {
+
+module.exports = eval("require")("./swc.android-arm64.node");
+
+
+/***/ }),
+
+/***/ 23827:
+/***/ ((module) => {
+
+module.exports = eval("require")("./swc.darwin-arm64.node");
+
+
+/***/ }),
+
+/***/ 29232:
+/***/ ((module) => {
+
+module.exports = eval("require")("./swc.darwin-universal.node");
+
+
+/***/ }),
+
+/***/ 71110:
+/***/ ((module) => {
+
+module.exports = eval("require")("./swc.darwin-x64.node");
+
+
+/***/ }),
+
+/***/ 96182:
+/***/ ((module) => {
+
+module.exports = eval("require")("./swc.freebsd-x64.node");
+
+
+/***/ }),
+
+/***/ 10645:
+/***/ ((module) => {
+
+module.exports = eval("require")("./swc.linux-arm-gnueabihf.node");
+
+
+/***/ }),
+
+/***/ 7458:
+/***/ ((module) => {
+
+module.exports = eval("require")("./swc.linux-arm64-gnu.node");
+
+
+/***/ }),
+
+/***/ 52614:
+/***/ ((module) => {
+
+module.exports = eval("require")("./swc.linux-arm64-musl.node");
+
+
+/***/ }),
+
+/***/ 79306:
+/***/ ((module) => {
+
+module.exports = eval("require")("./swc.linux-riscv64-gnu.node");
+
+
+/***/ }),
+
+/***/ 899:
+/***/ ((module) => {
+
+module.exports = eval("require")("./swc.linux-riscv64-musl.node");
+
+
+/***/ }),
+
+/***/ 93305:
+/***/ ((module) => {
+
+module.exports = eval("require")("./swc.linux-x64-gnu.node");
+
+
+/***/ }),
+
+/***/ 76885:
+/***/ ((module) => {
+
+module.exports = eval("require")("./swc.linux-x64-musl.node");
+
+
+/***/ }),
+
+/***/ 42395:
+/***/ ((module) => {
+
+module.exports = eval("require")("./swc.win32-arm64-msvc.node");
+
+
+/***/ }),
+
+/***/ 56637:
+/***/ ((module) => {
+
+module.exports = eval("require")("./swc.win32-ia32-msvc.node");
+
+
+/***/ }),
+
+/***/ 48865:
+/***/ ((module) => {
+
+module.exports = eval("require")("./swc.win32-x64-msvc.node");
+
+
+/***/ }),
+
+/***/ 63582:
+/***/ ((module) => {
+
+module.exports = eval("require")("@nx/nx-android-arm-eabi");
+
+
+/***/ }),
+
+/***/ 89581:
+/***/ ((module) => {
+
+module.exports = eval("require")("@nx/nx-android-arm64");
+
+
+/***/ }),
+
+/***/ 18912:
+/***/ ((module) => {
+
+module.exports = eval("require")("@nx/nx-darwin-universal");
+
+
+/***/ }),
+
+/***/ 59194:
+/***/ ((module) => {
+
+module.exports = eval("require")("@nx/nx-darwin-x64");
+
+
+/***/ }),
+
+/***/ 63818:
+/***/ ((module) => {
+
+module.exports = eval("require")("@nx/nx-freebsd-x64");
+
+
+/***/ }),
+
+/***/ 56362:
+/***/ ((module) => {
+
+module.exports = eval("require")("@nx/nx-linux-arm-gnueabihf");
+
+
+/***/ }),
+
+/***/ 99909:
+/***/ ((module) => {
+
+module.exports = eval("require")("@nx/nx-linux-arm64-gnu");
+
+
+/***/ }),
+
+/***/ 67629:
+/***/ ((module) => {
+
+module.exports = eval("require")("@nx/nx-linux-arm64-musl");
+
+
+/***/ }),
+
+/***/ 91136:
+/***/ ((module) => {
+
+module.exports = eval("require")("@nx/nx-linux-x64-gnu");
+
+
+/***/ }),
+
+/***/ 91817:
+/***/ ((module) => {
+
+module.exports = eval("require")("@nx/nx-linux-x64-musl");
+
+
+/***/ }),
+
+/***/ 18146:
+/***/ ((module) => {
+
+module.exports = eval("require")("@nx/nx-win32-arm64-msvc");
+
+
+/***/ }),
+
+/***/ 85420:
+/***/ ((module) => {
+
+module.exports = eval("require")("@nx/nx-win32-ia32-msvc");
+
+
+/***/ }),
+
+/***/ 19959:
+/***/ ((module) => {
+
+module.exports = eval("require")("@nx/nx-win32-x64-msvc");
+
+
+/***/ }),
+
+/***/ 89373:
+/***/ ((module) => {
+
+module.exports = eval("require")("@nx/vue");
+
+
+/***/ }),
+
+/***/ 86670:
+/***/ ((module) => {
+
+module.exports = eval("require")("@swc/core-android-arm-eabi");
+
+
+/***/ }),
+
+/***/ 73543:
+/***/ ((module) => {
+
+module.exports = eval("require")("@swc/core-android-arm64");
+
+
+/***/ }),
+
+/***/ 66749:
+/***/ ((module) => {
+
+module.exports = eval("require")("@swc/core-darwin-universal");
+
+
+/***/ }),
+
+/***/ 62659:
+/***/ ((module) => {
+
+module.exports = eval("require")("@swc/core-darwin-x64");
+
+
+/***/ }),
+
+/***/ 26640:
+/***/ ((module) => {
+
+module.exports = eval("require")("@swc/core-freebsd-x64");
+
+
+/***/ }),
+
+/***/ 19505:
+/***/ ((module) => {
+
+module.exports = eval("require")("@swc/core-linux-arm-gnueabihf");
+
+
+/***/ }),
+
+/***/ 13520:
+/***/ ((module) => {
+
+module.exports = eval("require")("@swc/core-linux-arm64-gnu");
+
+
+/***/ }),
+
+/***/ 93346:
+/***/ ((module) => {
+
+module.exports = eval("require")("@swc/core-linux-arm64-musl");
+
+
+/***/ }),
+
+/***/ 32636:
+/***/ ((module) => {
+
+module.exports = eval("require")("@swc/core-linux-riscv64-gnu");
+
+
+/***/ }),
+
+/***/ 81873:
+/***/ ((module) => {
+
+module.exports = eval("require")("@swc/core-linux-riscv64-musl");
+
+
+/***/ }),
+
+/***/ 69653:
+/***/ ((module) => {
+
+module.exports = eval("require")("@swc/core-linux-x64-gnu");
+
+
+/***/ }),
+
+/***/ 27110:
+/***/ ((module) => {
+
+module.exports = eval("require")("@swc/core-linux-x64-musl");
+
+
+/***/ }),
+
+/***/ 7470:
+/***/ ((module) => {
+
+module.exports = eval("require")("@swc/core-win32-arm64-msvc");
+
+
+/***/ }),
+
+/***/ 46924:
+/***/ ((module) => {
+
+module.exports = eval("require")("@swc/core-win32-ia32-msvc");
+
+
+/***/ }),
+
+/***/ 66995:
+/***/ ((module) => {
+
+module.exports = eval("require")("@swc/core-win32-x64-msvc");
+
+
+/***/ }),
+
+/***/ 7343:
+/***/ ((module) => {
+
+module.exports = eval("require")("@swc/wasm");
+
+
+/***/ }),
+
+/***/ 28701:
+/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+
+// TODO: consolidate on using a helpers file at some point in the future, which
+// is the approach currently used to export Parser and applyExtends for ESM:
+const {applyExtends, cjsPlatformShim, Parser, Yargs, processArgv} = __nccwpck_require__(4565)
+Yargs.applyExtends = (config, cwd, mergeExtends) => {
+  return applyExtends(config, cwd, mergeExtends, cjsPlatformShim)
+}
+Yargs.hideBin = processArgv.hideBin
+Yargs.Parser = Parser
+module.exports = Yargs
+
+
+/***/ }),
+
+/***/ 72939:
+/***/ ((module) => {
+
+function webpackEmptyContext(req) {
+	var e = new Error("Cannot find module '" + req + "'");
+	e.code = 'MODULE_NOT_FOUND';
+	throw e;
+}
+webpackEmptyContext.keys = () => ([]);
+webpackEmptyContext.resolve = webpackEmptyContext;
+webpackEmptyContext.id = 72939;
+module.exports = webpackEmptyContext;
+
+/***/ }),
+
+/***/ 3833:
+/***/ ((module) => {
+
+function webpackEmptyContext(req) {
+	var e = new Error("Cannot find module '" + req + "'");
+	e.code = 'MODULE_NOT_FOUND';
+	throw e;
+}
+webpackEmptyContext.keys = () => ([]);
+webpackEmptyContext.resolve = webpackEmptyContext;
+webpackEmptyContext.id = 3833;
+module.exports = webpackEmptyContext;
+
+/***/ }),
+
+/***/ 35670:
+/***/ ((module) => {
+
+function webpackEmptyContext(req) {
+	var e = new Error("Cannot find module '" + req + "'");
+	e.code = 'MODULE_NOT_FOUND';
+	throw e;
+}
+webpackEmptyContext.keys = () => ([]);
+webpackEmptyContext.resolve = webpackEmptyContext;
+webpackEmptyContext.id = 35670;
+module.exports = webpackEmptyContext;
+
+/***/ }),
+
+/***/ 49167:
+/***/ ((module) => {
+
+function webpackEmptyContext(req) {
+	var e = new Error("Cannot find module '" + req + "'");
+	e.code = 'MODULE_NOT_FOUND';
+	throw e;
+}
+webpackEmptyContext.keys = () => ([]);
+webpackEmptyContext.resolve = webpackEmptyContext;
+webpackEmptyContext.id = 49167;
+module.exports = webpackEmptyContext;
+
+/***/ }),
+
+/***/ 39491:
+/***/ ((module) => {
+
+"use strict";
+module.exports = require("assert");
+
+/***/ }),
+
+/***/ 14300:
+/***/ ((module) => {
+
+"use strict";
+module.exports = require("buffer");
+
+/***/ }),
+
+/***/ 32081:
+/***/ ((module) => {
+
+"use strict";
+module.exports = require("child_process");
+
+/***/ }),
+
+/***/ 96206:
+/***/ ((module) => {
+
+"use strict";
+module.exports = require("console");
+
+/***/ }),
+
+/***/ 22057:
+/***/ ((module) => {
+
+"use strict";
+module.exports = require("constants");
+
+/***/ }),
+
+/***/ 6113:
+/***/ ((module) => {
+
+"use strict";
+module.exports = require("crypto");
+
+/***/ }),
+
+/***/ 82361:
+/***/ ((module) => {
+
+"use strict";
+module.exports = require("events");
+
+/***/ }),
+
+/***/ 57147:
+/***/ ((module) => {
+
+"use strict";
+module.exports = require("fs");
+
+/***/ }),
+
+/***/ 73292:
+/***/ ((module) => {
+
+"use strict";
+module.exports = require("fs/promises");
+
+/***/ }),
+
+/***/ 13685:
+/***/ ((module) => {
+
+"use strict";
+module.exports = require("http");
+
+/***/ }),
+
+/***/ 95687:
+/***/ ((module) => {
+
+"use strict";
+module.exports = require("https");
+
+/***/ }),
+
+/***/ 31405:
+/***/ ((module) => {
+
+"use strict";
+module.exports = require("inspector");
+
+/***/ }),
+
+/***/ 98188:
+/***/ ((module) => {
+
+"use strict";
+module.exports = require("module");
+
+/***/ }),
+
+/***/ 41808:
+/***/ ((module) => {
+
+"use strict";
+module.exports = require("net");
+
+/***/ }),
+
+/***/ 87561:
+/***/ ((module) => {
+
+"use strict";
+module.exports = require("node:fs");
+
+/***/ }),
+
+/***/ 82033:
+/***/ ((module) => {
+
+"use strict";
+module.exports = require("node:module");
+
+/***/ }),
+
+/***/ 49411:
+/***/ ((module) => {
+
+"use strict";
+module.exports = require("node:path");
+
+/***/ }),
+
+/***/ 41041:
+/***/ ((module) => {
+
+"use strict";
+module.exports = require("node:url");
+
+/***/ }),
+
+/***/ 22037:
+/***/ ((module) => {
+
+"use strict";
+module.exports = require("os");
+
+/***/ }),
+
+/***/ 71017:
+/***/ ((module) => {
+
+"use strict";
+module.exports = require("path");
+
+/***/ }),
+
+/***/ 4074:
+/***/ ((module) => {
+
+"use strict";
+module.exports = require("perf_hooks");
+
+/***/ }),
+
+/***/ 14521:
+/***/ ((module) => {
+
+"use strict";
+module.exports = require("readline");
+
+/***/ }),
+
+/***/ 38102:
+/***/ ((module) => {
+
+"use strict";
+module.exports = require("repl");
+
+/***/ }),
+
+/***/ 12781:
+/***/ ((module) => {
+
+"use strict";
+module.exports = require("stream");
+
+/***/ }),
+
+/***/ 71576:
+/***/ ((module) => {
+
+"use strict";
+module.exports = require("string_decoder");
+
+/***/ }),
+
+/***/ 24404:
+/***/ ((module) => {
+
+"use strict";
+module.exports = require("tls");
+
+/***/ }),
+
+/***/ 76224:
+/***/ ((module) => {
+
+"use strict";
+module.exports = require("tty");
+
+/***/ }),
+
+/***/ 57310:
+/***/ ((module) => {
+
+"use strict";
+module.exports = require("url");
+
+/***/ }),
+
+/***/ 73837:
+/***/ ((module) => {
+
+"use strict";
+module.exports = require("util");
+
+/***/ }),
+
+/***/ 26144:
+/***/ ((module) => {
+
+"use strict";
+module.exports = require("vm");
+
+/***/ }),
+
+/***/ 59796:
+/***/ ((module) => {
+
+"use strict";
+module.exports = require("zlib");
+
+/***/ }),
+
+/***/ 63305:
+/***/ ((__unused_webpack_module, exports) => {
+
+"use strict";
+
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.assertValidPattern = void 0;
+const MAX_PATTERN_LENGTH = 1024 * 64;
+const assertValidPattern = (pattern) => {
+    if (typeof pattern !== 'string') {
+        throw new TypeError('invalid pattern');
+    }
+    if (pattern.length > MAX_PATTERN_LENGTH) {
+        throw new TypeError('pattern is too long');
+    }
+};
+exports.assertValidPattern = assertValidPattern;
+//# sourceMappingURL=assert-valid-pattern.js.map
+
+/***/ }),
+
+/***/ 50249:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
+
+"use strict";
+
+// parse a single path portion
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.AST = void 0;
+const brace_expressions_js_1 = __nccwpck_require__(53211);
+const unescape_js_1 = __nccwpck_require__(43612);
+const types = new Set(['!', '?', '+', '*', '@']);
+const isExtglobType = (c) => types.has(c);
+// Patterns that get prepended to bind to the start of either the
+// entire string, or just a single path portion, to prevent dots
+// and/or traversal patterns, when needed.
+// Exts don't need the ^ or / bit, because the root binds that already.
+const startNoTraversal = '(?!(?:^|/)\\.\\.?(?:$|/))';
+const startNoDot = '(?!\\.)';
+// characters that indicate a start of pattern needs the "no dots" bit,
+// because a dot *might* be matched. ( is not in the list, because in
+// the case of a child extglob, it will handle the prevention itself.
+const addPatternStart = new Set(['[', '.']);
+// cases where traversal is A-OK, no dot prevention needed
+const justDots = new Set(['..', '.']);
+const reSpecials = new Set('().*{}+?[]^$\\!');
+const regExpEscape = (s) => s.replace(/[-[\]{}()*+?.,\\^$|#\s]/g, '\\$&');
+// any single thing other than /
+const qmark = '[^/]';
+// * => any number of characters
+const star = qmark + '*?';
+// use + when we need to ensure that *something* matches, because the * is
+// the only thing in the path portion.
+const starNoEmpty = qmark + '+?';
+// remove the \ chars that we added if we end up doing a nonmagic compare
+// const deslash = (s: string) => s.replace(/\\(.)/g, '$1')
+class AST {
+    type;
+    #root;
+    #hasMagic;
+    #uflag = false;
+    #parts = [];
+    #parent;
+    #parentIndex;
+    #negs;
+    #filledNegs = false;
+    #options;
+    #toString;
+    // set to true if it's an extglob with no children
+    // (which really means one child of '')
+    #emptyExt = false;
+    constructor(type, parent, options = {}) {
+        this.type = type;
+        // extglobs are inherently magical
+        if (type)
+            this.#hasMagic = true;
+        this.#parent = parent;
+        this.#root = this.#parent ? this.#parent.#root : this;
+        this.#options = this.#root === this ? options : this.#root.#options;
+        this.#negs = this.#root === this ? [] : this.#root.#negs;
+        if (type === '!' && !this.#root.#filledNegs)
+            this.#negs.push(this);
+        this.#parentIndex = this.#parent ? this.#parent.#parts.length : 0;
+    }
+    get hasMagic() {
+        /* c8 ignore start */
+        if (this.#hasMagic !== undefined)
+            return this.#hasMagic;
+        /* c8 ignore stop */
+        for (const p of this.#parts) {
+            if (typeof p === 'string')
+                continue;
+            if (p.type || p.hasMagic)
+                return (this.#hasMagic = true);
+        }
+        // note: will be undefined until we generate the regexp src and find out
+        return this.#hasMagic;
+    }
+    // reconstructs the pattern
+    toString() {
+        if (this.#toString !== undefined)
+            return this.#toString;
+        if (!this.type) {
+            return (this.#toString = this.#parts.map(p => String(p)).join(''));
+        }
+        else {
+            return (this.#toString =
+                this.type + '(' + this.#parts.map(p => String(p)).join('|') + ')');
+        }
+    }
+    #fillNegs() {
+        /* c8 ignore start */
+        if (this !== this.#root)
+            throw new Error('should only call on root');
+        if (this.#filledNegs)
+            return this;
+        /* c8 ignore stop */
+        // call toString() once to fill this out
+        this.toString();
+        this.#filledNegs = true;
+        let n;
+        while ((n = this.#negs.pop())) {
+            if (n.type !== '!')
+                continue;
+            // walk up the tree, appending everthing that comes AFTER parentIndex
+            let p = n;
+            let pp = p.#parent;
+            while (pp) {
+                for (let i = p.#parentIndex + 1; !pp.type && i < pp.#parts.length; i++) {
+                    for (const part of n.#parts) {
+                        /* c8 ignore start */
+                        if (typeof part === 'string') {
+                            throw new Error('string part in extglob AST??');
+                        }
+                        /* c8 ignore stop */
+                        part.copyIn(pp.#parts[i]);
+                    }
+                }
+                p = pp;
+                pp = p.#parent;
+            }
+        }
+        return this;
+    }
+    push(...parts) {
+        for (const p of parts) {
+            if (p === '')
+                continue;
+            /* c8 ignore start */
+            if (typeof p !== 'string' && !(p instanceof AST && p.#parent === this)) {
+                throw new Error('invalid part: ' + p);
+            }
+            /* c8 ignore stop */
+            this.#parts.push(p);
+        }
+    }
+    toJSON() {
+        const ret = this.type === null
+            ? this.#parts.slice().map(p => (typeof p === 'string' ? p : p.toJSON()))
+            : [this.type, ...this.#parts.map(p => p.toJSON())];
+        if (this.isStart() && !this.type)
+            ret.unshift([]);
+        if (this.isEnd() &&
+            (this === this.#root ||
+                (this.#root.#filledNegs && this.#parent?.type === '!'))) {
+            ret.push({});
+        }
+        return ret;
+    }
+    isStart() {
+        if (this.#root === this)
+            return true;
+        // if (this.type) return !!this.#parent?.isStart()
+        if (!this.#parent?.isStart())
+            return false;
+        if (this.#parentIndex === 0)
+            return true;
+        // if everything AHEAD of this is a negation, then it's still the "start"
+        const p = this.#parent;
+        for (let i = 0; i < this.#parentIndex; i++) {
+            const pp = p.#parts[i];
+            if (!(pp instanceof AST && pp.type === '!')) {
+                return false;
+            }
+        }
+        return true;
+    }
+    isEnd() {
+        if (this.#root === this)
+            return true;
+        if (this.#parent?.type === '!')
+            return true;
+        if (!this.#parent?.isEnd())
+            return false;
+        if (!this.type)
+            return this.#parent?.isEnd();
+        // if not root, it'll always have a parent
+        /* c8 ignore start */
+        const pl = this.#parent ? this.#parent.#parts.length : 0;
+        /* c8 ignore stop */
+        return this.#parentIndex === pl - 1;
+    }
+    copyIn(part) {
+        if (typeof part === 'string')
+            this.push(part);
+        else
+            this.push(part.clone(this));
+    }
+    clone(parent) {
+        const c = new AST(this.type, parent);
+        for (const p of this.#parts) {
+            c.copyIn(p);
+        }
+        return c;
+    }
+    static #parseAST(str, ast, pos, opt) {
+        let escaping = false;
+        let inBrace = false;
+        let braceStart = -1;
+        let braceNeg = false;
+        if (ast.type === null) {
+            // outside of a extglob, append until we find a start
+            let i = pos;
+            let acc = '';
+            while (i < str.length) {
+                const c = str.charAt(i++);
+                // still accumulate escapes at this point, but we do ignore
+                // starts that are escaped
+                if (escaping || c === '\\') {
+                    escaping = !escaping;
+                    acc += c;
+                    continue;
+                }
+                if (inBrace) {
+                    if (i === braceStart + 1) {
+                        if (c === '^' || c === '!') {
+                            braceNeg = true;
+                        }
+                    }
+                    else if (c === ']' && !(i === braceStart + 2 && braceNeg)) {
+                        inBrace = false;
+                    }
+                    acc += c;
+                    continue;
+                }
+                else if (c === '[') {
+                    inBrace = true;
+                    braceStart = i;
+                    braceNeg = false;
+                    acc += c;
+                    continue;
+                }
+                if (!opt.noext && isExtglobType(c) && str.charAt(i) === '(') {
+                    ast.push(acc);
+                    acc = '';
+                    const ext = new AST(c, ast);
+                    i = AST.#parseAST(str, ext, i, opt);
+                    ast.push(ext);
+                    continue;
+                }
+                acc += c;
+            }
+            ast.push(acc);
+            return i;
+        }
+        // some kind of extglob, pos is at the (
+        // find the next | or )
+        let i = pos + 1;
+        let part = new AST(null, ast);
+        const parts = [];
+        let acc = '';
+        while (i < str.length) {
+            const c = str.charAt(i++);
+            // still accumulate escapes at this point, but we do ignore
+            // starts that are escaped
+            if (escaping || c === '\\') {
+                escaping = !escaping;
+                acc += c;
+                continue;
+            }
+            if (inBrace) {
+                if (i === braceStart + 1) {
+                    if (c === '^' || c === '!') {
+                        braceNeg = true;
+                    }
+                }
+                else if (c === ']' && !(i === braceStart + 2 && braceNeg)) {
+                    inBrace = false;
+                }
+                acc += c;
+                continue;
+            }
+            else if (c === '[') {
+                inBrace = true;
+                braceStart = i;
+                braceNeg = false;
+                acc += c;
+                continue;
+            }
+            if (isExtglobType(c) && str.charAt(i) === '(') {
+                part.push(acc);
+                acc = '';
+                const ext = new AST(c, part);
+                part.push(ext);
+                i = AST.#parseAST(str, ext, i, opt);
+                continue;
+            }
+            if (c === '|') {
+                part.push(acc);
+                acc = '';
+                parts.push(part);
+                part = new AST(null, ast);
+                continue;
+            }
+            if (c === ')') {
+                if (acc === '' && ast.#parts.length === 0) {
+                    ast.#emptyExt = true;
+                }
+                part.push(acc);
+                acc = '';
+                ast.push(...parts, part);
+                return i;
+            }
+            acc += c;
+        }
+        // unfinished extglob
+        // if we got here, it was a malformed extglob! not an extglob, but
+        // maybe something else in there.
+        ast.type = null;
+        ast.#hasMagic = undefined;
+        ast.#parts = [str.substring(pos - 1)];
+        return i;
+    }
+    static fromGlob(pattern, options = {}) {
+        const ast = new AST(null, undefined, options);
+        AST.#parseAST(pattern, ast, 0, options);
+        return ast;
+    }
+    // returns the regular expression if there's magic, or the unescaped
+    // string if not.
+    toMMPattern() {
+        // should only be called on root
+        /* c8 ignore start */
+        if (this !== this.#root)
+            return this.#root.toMMPattern();
+        /* c8 ignore stop */
+        const glob = this.toString();
+        const [re, body, hasMagic, uflag] = this.toRegExpSource();
+        // if we're in nocase mode, and not nocaseMagicOnly, then we do
+        // still need a regular expression if we have to case-insensitively
+        // match capital/lowercase characters.
+        const anyMagic = hasMagic ||
+            this.#hasMagic ||
+            (this.#options.nocase &&
+                !this.#options.nocaseMagicOnly &&
+                glob.toUpperCase() !== glob.toLowerCase());
+        if (!anyMagic) {
+            return body;
+        }
+        const flags = (this.#options.nocase ? 'i' : '') + (uflag ? 'u' : '');
+        return Object.assign(new RegExp(`^${re}$`, flags), {
+            _src: re,
+            _glob: glob,
+        });
+    }
+    // returns the string match, the regexp source, whether there's magic
+    // in the regexp (so a regular expression is required) and whether or
+    // not the uflag is needed for the regular expression (for posix classes)
+    // TODO: instead of injecting the start/end at this point, just return
+    // the BODY of the regexp, along with the start/end portions suitable
+    // for binding the start/end in either a joined full-path makeRe context
+    // (where we bind to (^|/), or a standalone matchPart context (where
+    // we bind to ^, and not /).  Otherwise slashes get duped!
+    //
+    // In part-matching mode, the start is:
+    // - if not isStart: nothing
+    // - if traversal possible, but not allowed: ^(?!\.\.?$)
+    // - if dots allowed or not possible: ^
+    // - if dots possible and not allowed: ^(?!\.)
+    // end is:
+    // - if not isEnd(): nothing
+    // - else: $
+    //
+    // In full-path matching mode, we put the slash at the START of the
+    // pattern, so start is:
+    // - if first pattern: same as part-matching mode
+    // - if not isStart(): nothing
+    // - if traversal possible, but not allowed: /(?!\.\.?(?:$|/))
+    // - if dots allowed or not possible: /
+    // - if dots possible and not allowed: /(?!\.)
+    // end is:
+    // - if last pattern, same as part-matching mode
+    // - else nothing
+    //
+    // Always put the (?:$|/) on negated tails, though, because that has to be
+    // there to bind the end of the negated pattern portion, and it's easier to
+    // just stick it in now rather than try to inject it later in the middle of
+    // the pattern.
+    //
+    // We can just always return the same end, and leave it up to the caller
+    // to know whether it's going to be used joined or in parts.
+    // And, if the start is adjusted slightly, can do the same there:
+    // - if not isStart: nothing
+    // - if traversal possible, but not allowed: (?:/|^)(?!\.\.?$)
+    // - if dots allowed or not possible: (?:/|^)
+    // - if dots possible and not allowed: (?:/|^)(?!\.)
+    //
+    // But it's better to have a simpler binding without a conditional, for
+    // performance, so probably better to return both start options.
+    //
+    // Then the caller just ignores the end if it's not the first pattern,
+    // and the start always gets applied.
+    //
+    // But that's always going to be $ if it's the ending pattern, or nothing,
+    // so the caller can just attach $ at the end of the pattern when building.
+    //
+    // So the todo is:
+    // - better detect what kind of start is needed
+    // - return both flavors of starting pattern
+    // - attach $ at the end of the pattern when creating the actual RegExp
+    //
+    // Ah, but wait, no, that all only applies to the root when the first pattern
+    // is not an extglob. If the first pattern IS an extglob, then we need all
+    // that dot prevention biz to live in the extglob portions, because eg
+    // +(*|.x*) can match .xy but not .yx.
+    //
+    // So, return the two flavors if it's #root and the first child is not an
+    // AST, otherwise leave it to the child AST to handle it, and there,
+    // use the (?:^|/) style of start binding.
+    //
+    // Even simplified further:
+    // - Since the start for a join is eg /(?!\.) and the start for a part
+    // is ^(?!\.), we can just prepend (?!\.) to the pattern (either root
+    // or start or whatever) and prepend ^ or / at the Regexp construction.
+    toRegExpSource(allowDot) {
+        const dot = allowDot ?? !!this.#options.dot;
+        if (this.#root === this)
+            this.#fillNegs();
+        if (!this.type) {
+            const noEmpty = this.isStart() && this.isEnd();
+            const src = this.#parts
+                .map(p => {
+                const [re, _, hasMagic, uflag] = typeof p === 'string'
+                    ? AST.#parseGlob(p, this.#hasMagic, noEmpty)
+                    : p.toRegExpSource(allowDot);
+                this.#hasMagic = this.#hasMagic || hasMagic;
+                this.#uflag = this.#uflag || uflag;
+                return re;
+            })
+                .join('');
+            let start = '';
+            if (this.isStart()) {
+                if (typeof this.#parts[0] === 'string') {
+                    // this is the string that will match the start of the pattern,
+                    // so we need to protect against dots and such.
+                    // '.' and '..' cannot match unless the pattern is that exactly,
+                    // even if it starts with . or dot:true is set.
+                    const dotTravAllowed = this.#parts.length === 1 && justDots.has(this.#parts[0]);
+                    if (!dotTravAllowed) {
+                        const aps = addPatternStart;
+                        // check if we have a possibility of matching . or ..,
+                        // and prevent that.
+                        const needNoTrav = 
+                        // dots are allowed, and the pattern starts with [ or .
+                        (dot && aps.has(src.charAt(0))) ||
+                            // the pattern starts with \., and then [ or .
+                            (src.startsWith('\\.') && aps.has(src.charAt(2))) ||
+                            // the pattern starts with \.\., and then [ or .
+                            (src.startsWith('\\.\\.') && aps.has(src.charAt(4)));
+                        // no need to prevent dots if it can't match a dot, or if a
+                        // sub-pattern will be preventing it anyway.
+                        const needNoDot = !dot && !allowDot && aps.has(src.charAt(0));
+                        start = needNoTrav ? startNoTraversal : needNoDot ? startNoDot : '';
+                    }
+                }
+            }
+            // append the "end of path portion" pattern to negation tails
+            let end = '';
+            if (this.isEnd() &&
+                this.#root.#filledNegs &&
+                this.#parent?.type === '!') {
+                end = '(?:$|\\/)';
+            }
+            const final = start + src + end;
+            return [
+                final,
+                (0, unescape_js_1.unescape)(src),
+                (this.#hasMagic = !!this.#hasMagic),
+                this.#uflag,
+            ];
+        }
+        // We need to calculate the body *twice* if it's a repeat pattern
+        // at the start, once in nodot mode, then again in dot mode, so a
+        // pattern like *(?) can match 'x.y'
+        const repeated = this.type === '*' || this.type === '+';
+        // some kind of extglob
+        const start = this.type === '!' ? '(?:(?!(?:' : '(?:';
+        let body = this.#partsToRegExp(dot);
+        if (this.isStart() && this.isEnd() && !body && this.type !== '!') {
+            // invalid extglob, has to at least be *something* present, if it's
+            // the entire path portion.
+            const s = this.toString();
+            this.#parts = [s];
+            this.type = null;
+            this.#hasMagic = undefined;
+            return [s, (0, unescape_js_1.unescape)(this.toString()), false, false];
+        }
+        // XXX abstract out this map method
+        let bodyDotAllowed = !repeated || allowDot || dot || !startNoDot
+            ? ''
+            : this.#partsToRegExp(true);
+        if (bodyDotAllowed === body) {
+            bodyDotAllowed = '';
+        }
+        if (bodyDotAllowed) {
+            body = `(?:${body})(?:${bodyDotAllowed})*?`;
+        }
+        // an empty !() is exactly equivalent to a starNoEmpty
+        let final = '';
+        if (this.type === '!' && this.#emptyExt) {
+            final = (this.isStart() && !dot ? startNoDot : '') + starNoEmpty;
+        }
+        else {
+            const close = this.type === '!'
+                ? // !() must match something,but !(x) can match ''
+                    '))' +
+                        (this.isStart() && !dot && !allowDot ? startNoDot : '') +
+                        star +
+                        ')'
+                : this.type === '@'
+                    ? ')'
+                    : this.type === '?'
+                        ? ')?'
+                        : this.type === '+' && bodyDotAllowed
+                            ? ')'
+                            : this.type === '*' && bodyDotAllowed
+                                ? `)?`
+                                : `)${this.type}`;
+            final = start + body + close;
+        }
+        return [
+            final,
+            (0, unescape_js_1.unescape)(body),
+            (this.#hasMagic = !!this.#hasMagic),
+            this.#uflag,
+        ];
+    }
+    #partsToRegExp(dot) {
+        return this.#parts
+            .map(p => {
+            // extglob ASTs should only contain parent ASTs
+            /* c8 ignore start */
+            if (typeof p === 'string') {
+                throw new Error('string type in extglob ast??');
+            }
+            /* c8 ignore stop */
+            // can ignore hasMagic, because extglobs are already always magic
+            const [re, _, _hasMagic, uflag] = p.toRegExpSource(dot);
+            this.#uflag = this.#uflag || uflag;
+            return re;
+        })
+            .filter(p => !(this.isStart() && this.isEnd()) || !!p)
+            .join('|');
+    }
+    static #parseGlob(glob, hasMagic, noEmpty = false) {
+        let escaping = false;
+        let re = '';
+        let uflag = false;
+        for (let i = 0; i < glob.length; i++) {
+            const c = glob.charAt(i);
+            if (escaping) {
+                escaping = false;
+                re += (reSpecials.has(c) ? '\\' : '') + c;
+                continue;
+            }
+            if (c === '\\') {
+                if (i === glob.length - 1) {
+                    re += '\\\\';
+                }
+                else {
+                    escaping = true;
+                }
+                continue;
+            }
+            if (c === '[') {
+                const [src, needUflag, consumed, magic] = (0, brace_expressions_js_1.parseClass)(glob, i);
+                if (consumed) {
+                    re += src;
+                    uflag = uflag || needUflag;
+                    i += consumed - 1;
+                    hasMagic = hasMagic || magic;
+                    continue;
+                }
+            }
+            if (c === '*') {
+                if (noEmpty && glob === '*')
+                    re += starNoEmpty;
+                else
+                    re += star;
+                hasMagic = true;
+                continue;
+            }
+            if (c === '?') {
+                re += qmark;
+                hasMagic = true;
+                continue;
+            }
+            re += regExpEscape(c);
+        }
+        return [re, (0, unescape_js_1.unescape)(glob), !!hasMagic, uflag];
+    }
+}
+exports.AST = AST;
+//# sourceMappingURL=ast.js.map
+
+/***/ }),
+
+/***/ 53211:
+/***/ ((__unused_webpack_module, exports) => {
+
+"use strict";
+
+// translate the various posix character classes into unicode properties
+// this works across all unicode locales
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.parseClass = void 0;
+// { : [, /u flag required, negated]
+const posixClasses = {
+    '[:alnum:]': ['\\p{L}\\p{Nl}\\p{Nd}', true],
+    '[:alpha:]': ['\\p{L}\\p{Nl}', true],
+    '[:ascii:]': ['\\x' + '00-\\x' + '7f', false],
+    '[:blank:]': ['\\p{Zs}\\t', true],
+    '[:cntrl:]': ['\\p{Cc}', true],
+    '[:digit:]': ['\\p{Nd}', true],
+    '[:graph:]': ['\\p{Z}\\p{C}', true, true],
+    '[:lower:]': ['\\p{Ll}', true],
+    '[:print:]': ['\\p{C}', true],
+    '[:punct:]': ['\\p{P}', true],
+    '[:space:]': ['\\p{Z}\\t\\r\\n\\v\\f', true],
+    '[:upper:]': ['\\p{Lu}', true],
+    '[:word:]': ['\\p{L}\\p{Nl}\\p{Nd}\\p{Pc}', true],
+    '[:xdigit:]': ['A-Fa-f0-9', false],
+};
+// only need to escape a few things inside of brace expressions
+// escapes: [ \ ] -
+const braceEscape = (s) => s.replace(/[[\]\\-]/g, '\\$&');
+// escape all regexp magic characters
+const regexpEscape = (s) => s.replace(/[-[\]{}()*+?.,\\^$|#\s]/g, '\\$&');
+// everything has already been escaped, we just have to join
+const rangesToString = (ranges) => ranges.join('');
+// takes a glob string at a posix brace expression, and returns
+// an equivalent regular expression source, and boolean indicating
+// whether the /u flag needs to be applied, and the number of chars
+// consumed to parse the character class.
+// This also removes out of order ranges, and returns ($.) if the
+// entire class just no good.
+const parseClass = (glob, position) => {
+    const pos = position;
+    /* c8 ignore start */
+    if (glob.charAt(pos) !== '[') {
+        throw new Error('not in a brace expression');
+    }
+    /* c8 ignore stop */
+    const ranges = [];
+    const negs = [];
+    let i = pos + 1;
+    let sawStart = false;
+    let uflag = false;
+    let escaping = false;
+    let negate = false;
+    let endPos = pos;
+    let rangeStart = '';
+    WHILE: while (i < glob.length) {
+        const c = glob.charAt(i);
+        if ((c === '!' || c === '^') && i === pos + 1) {
+            negate = true;
+            i++;
+            continue;
+        }
+        if (c === ']' && sawStart && !escaping) {
+            endPos = i + 1;
+            break;
+        }
+        sawStart = true;
+        if (c === '\\') {
+            if (!escaping) {
+                escaping = true;
+                i++;
+                continue;
+            }
+            // escaped \ char, fall through and treat like normal char
+        }
+        if (c === '[' && !escaping) {
+            // either a posix class, a collation equivalent, or just a [
+            for (const [cls, [unip, u, neg]] of Object.entries(posixClasses)) {
+                if (glob.startsWith(cls, i)) {
+                    // invalid, [a-[] is fine, but not [a-[:alpha]]
+                    if (rangeStart) {
+                        return ['$.', false, glob.length - pos, true];
+                    }
+                    i += cls.length;
+                    if (neg)
+                        negs.push(unip);
+                    else
+                        ranges.push(unip);
+                    uflag = uflag || u;
+                    continue WHILE;
+                }
+            }
+        }
+        // now it's just a normal character, effectively
+        escaping = false;
+        if (rangeStart) {
+            // throw this range away if it's not valid, but others
+            // can still match.
+            if (c > rangeStart) {
+                ranges.push(braceEscape(rangeStart) + '-' + braceEscape(c));
+            }
+            else if (c === rangeStart) {
+                ranges.push(braceEscape(c));
+            }
+            rangeStart = '';
+            i++;
+            continue;
+        }
+        // now might be the start of a range.
+        // can be either c-d or c-] or c] or c] at this point
+        if (glob.startsWith('-]', i + 1)) {
+            ranges.push(braceEscape(c + '-'));
+            i += 2;
+            continue;
+        }
+        if (glob.startsWith('-', i + 1)) {
+            rangeStart = c;
+            i += 2;
+            continue;
+        }
+        // not the start of a range, just a single character
+        ranges.push(braceEscape(c));
+        i++;
+    }
+    if (endPos < i) {
+        // didn't see the end of the class, not a valid class,
+        // but might still be valid as a literal match.
+        return ['', false, 0, false];
+    }
+    // if we got no ranges and no negates, then we have a range that
+    // cannot possibly match anything, and that poisons the whole glob
+    if (!ranges.length && !negs.length) {
+        return ['$.', false, glob.length - pos, true];
+    }
+    // if we got one positive range, and it's a single character, then that's
+    // not actually a magic pattern, it's just that one literal character.
+    // we should not treat that as "magic", we should just return the literal
+    // character. [_] is a perfectly valid way to escape glob magic chars.
+    if (negs.length === 0 &&
+        ranges.length === 1 &&
+        /^\\?.$/.test(ranges[0]) &&
+        !negate) {
+        const r = ranges[0].length === 2 ? ranges[0].slice(-1) : ranges[0];
+        return [regexpEscape(r), false, endPos - pos, false];
+    }
+    const sranges = '[' + (negate ? '^' : '') + rangesToString(ranges) + ']';
+    const snegs = '[' + (negate ? '' : '^') + rangesToString(negs) + ']';
+    const comb = ranges.length && negs.length
+        ? '(' + sranges + '|' + snegs + ')'
+        : ranges.length
+            ? sranges
+            : snegs;
+    return [comb, uflag, endPos - pos, true];
+};
+exports.parseClass = parseClass;
+//# sourceMappingURL=brace-expressions.js.map
+
+/***/ }),
+
+/***/ 9549:
+/***/ ((__unused_webpack_module, exports) => {
+
+"use strict";
+
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.escape = void 0;
+/**
+ * Escape all magic characters in a glob pattern.
+ *
+ * If the {@link windowsPathsNoEscape | GlobOptions.windowsPathsNoEscape}
+ * option is used, then characters are escaped by wrapping in `[]`, because
+ * a magic character wrapped in a character class can only be satisfied by
+ * that exact character.  In this mode, `\` is _not_ escaped, because it is
+ * not interpreted as a magic character, but instead as a path separator.
+ */
+const escape = (s, { windowsPathsNoEscape = false, } = {}) => {
+    // don't need to escape +@! because we escape the parens
+    // that make those magic, and escaping ! as [!] isn't valid,
+    // because [!]] is a valid glob class meaning not ']'.
+    return windowsPathsNoEscape
+        ? s.replace(/[?*()[\]]/g, '[$&]')
+        : s.replace(/[?*()[\]\\]/g, '\\$&');
+};
+exports.escape = escape;
+//# sourceMappingURL=escape.js.map
+
+/***/ }),
+
+/***/ 55224:
+/***/ (function(__unused_webpack_module, exports, __nccwpck_require__) {
+
+"use strict";
+
+var __importDefault = (this && this.__importDefault) || function (mod) {
+    return (mod && mod.__esModule) ? mod : { "default": mod };
+};
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.unescape = exports.escape = exports.AST = exports.Minimatch = exports.match = exports.makeRe = exports.braceExpand = exports.defaults = exports.filter = exports.GLOBSTAR = exports.sep = exports.minimatch = void 0;
+const brace_expansion_1 = __importDefault(__nccwpck_require__(82548));
+const assert_valid_pattern_js_1 = __nccwpck_require__(63305);
+const ast_js_1 = __nccwpck_require__(50249);
+const escape_js_1 = __nccwpck_require__(9549);
+const unescape_js_1 = __nccwpck_require__(43612);
+const minimatch = (p, pattern, options = {}) => {
+    (0, assert_valid_pattern_js_1.assertValidPattern)(pattern);
+    // shortcut: comments match nothing.
+    if (!options.nocomment && pattern.charAt(0) === '#') {
+        return false;
+    }
+    return new Minimatch(pattern, options).match(p);
+};
+exports.minimatch = minimatch;
+// Optimized checking for the most common glob patterns.
+const starDotExtRE = /^\*+([^+@!?\*\[\(]*)$/;
+const starDotExtTest = (ext) => (f) => !f.startsWith('.') && f.endsWith(ext);
+const starDotExtTestDot = (ext) => (f) => f.endsWith(ext);
+const starDotExtTestNocase = (ext) => {
+    ext = ext.toLowerCase();
+    return (f) => !f.startsWith('.') && f.toLowerCase().endsWith(ext);
+};
+const starDotExtTestNocaseDot = (ext) => {
+    ext = ext.toLowerCase();
+    return (f) => f.toLowerCase().endsWith(ext);
+};
+const starDotStarRE = /^\*+\.\*+$/;
+const starDotStarTest = (f) => !f.startsWith('.') && f.includes('.');
+const starDotStarTestDot = (f) => f !== '.' && f !== '..' && f.includes('.');
+const dotStarRE = /^\.\*+$/;
+const dotStarTest = (f) => f !== '.' && f !== '..' && f.startsWith('.');
+const starRE = /^\*+$/;
+const starTest = (f) => f.length !== 0 && !f.startsWith('.');
+const starTestDot = (f) => f.length !== 0 && f !== '.' && f !== '..';
+const qmarksRE = /^\?+([^+@!?\*\[\(]*)?$/;
+const qmarksTestNocase = ([$0, ext = '']) => {
+    const noext = qmarksTestNoExt([$0]);
+    if (!ext)
+        return noext;
+    ext = ext.toLowerCase();
+    return (f) => noext(f) && f.toLowerCase().endsWith(ext);
+};
+const qmarksTestNocaseDot = ([$0, ext = '']) => {
+    const noext = qmarksTestNoExtDot([$0]);
+    if (!ext)
+        return noext;
+    ext = ext.toLowerCase();
+    return (f) => noext(f) && f.toLowerCase().endsWith(ext);
+};
+const qmarksTestDot = ([$0, ext = '']) => {
+    const noext = qmarksTestNoExtDot([$0]);
+    return !ext ? noext : (f) => noext(f) && f.endsWith(ext);
+};
+const qmarksTest = ([$0, ext = '']) => {
+    const noext = qmarksTestNoExt([$0]);
+    return !ext ? noext : (f) => noext(f) && f.endsWith(ext);
+};
+const qmarksTestNoExt = ([$0]) => {
+    const len = $0.length;
+    return (f) => f.length === len && !f.startsWith('.');
+};
+const qmarksTestNoExtDot = ([$0]) => {
+    const len = $0.length;
+    return (f) => f.length === len && f !== '.' && f !== '..';
+};
+/* c8 ignore start */
+const defaultPlatform = (typeof process === 'object' && process
+    ? (typeof process.env === 'object' &&
+        process.env &&
+        process.env.__MINIMATCH_TESTING_PLATFORM__) ||
+        process.platform
+    : 'posix');
+const path = {
+    win32: { sep: '\\' },
+    posix: { sep: '/' },
+};
+/* c8 ignore stop */
+exports.sep = defaultPlatform === 'win32' ? path.win32.sep : path.posix.sep;
+exports.minimatch.sep = exports.sep;
+exports.GLOBSTAR = Symbol('globstar **');
+exports.minimatch.GLOBSTAR = exports.GLOBSTAR;
+// any single thing other than /
+// don't need to escape / when using new RegExp()
+const qmark = '[^/]';
+// * => any number of characters
+const star = qmark + '*?';
+// ** when dots are allowed.  Anything goes, except .. and .
+// not (^ or / followed by one or two dots followed by $ or /),
+// followed by anything, any number of times.
+const twoStarDot = '(?:(?!(?:\\/|^)(?:\\.{1,2})($|\\/)).)*?';
+// not a ^ or / followed by a dot,
+// followed by anything, any number of times.
+const twoStarNoDot = '(?:(?!(?:\\/|^)\\.).)*?';
+const filter = (pattern, options = {}) => (p) => (0, exports.minimatch)(p, pattern, options);
+exports.filter = filter;
+exports.minimatch.filter = exports.filter;
+const ext = (a, b = {}) => Object.assign({}, a, b);
+const defaults = (def) => {
+    if (!def || typeof def !== 'object' || !Object.keys(def).length) {
+        return exports.minimatch;
+    }
+    const orig = exports.minimatch;
+    const m = (p, pattern, options = {}) => orig(p, pattern, ext(def, options));
+    return Object.assign(m, {
+        Minimatch: class Minimatch extends orig.Minimatch {
+            constructor(pattern, options = {}) {
+                super(pattern, ext(def, options));
+            }
+            static defaults(options) {
+                return orig.defaults(ext(def, options)).Minimatch;
+            }
+        },
+        AST: class AST extends orig.AST {
+            /* c8 ignore start */
+            constructor(type, parent, options = {}) {
+                super(type, parent, ext(def, options));
+            }
+            /* c8 ignore stop */
+            static fromGlob(pattern, options = {}) {
+                return orig.AST.fromGlob(pattern, ext(def, options));
+            }
+        },
+        unescape: (s, options = {}) => orig.unescape(s, ext(def, options)),
+        escape: (s, options = {}) => orig.escape(s, ext(def, options)),
+        filter: (pattern, options = {}) => orig.filter(pattern, ext(def, options)),
+        defaults: (options) => orig.defaults(ext(def, options)),
+        makeRe: (pattern, options = {}) => orig.makeRe(pattern, ext(def, options)),
+        braceExpand: (pattern, options = {}) => orig.braceExpand(pattern, ext(def, options)),
+        match: (list, pattern, options = {}) => orig.match(list, pattern, ext(def, options)),
+        sep: orig.sep,
+        GLOBSTAR: exports.GLOBSTAR,
+    });
+};
+exports.defaults = defaults;
+exports.minimatch.defaults = exports.defaults;
+// Brace expansion:
+// a{b,c}d -> abd acd
+// a{b,}c -> abc ac
+// a{0..3}d -> a0d a1d a2d a3d
+// a{b,c{d,e}f}g -> abg acdfg acefg
+// a{b,c}d{e,f}g -> abdeg acdeg abdeg abdfg
+//
+// Invalid sets are not expanded.
+// a{2..}b -> a{2..}b
+// a{b}c -> a{b}c
+const braceExpand = (pattern, options = {}) => {
+    (0, assert_valid_pattern_js_1.assertValidPattern)(pattern);
+    // Thanks to Yeting Li  for
+    // improving this regexp to avoid a ReDOS vulnerability.
+    if (options.nobrace || !/\{(?:(?!\{).)*\}/.test(pattern)) {
+        // shortcut. no need to expand.
+        return [pattern];
+    }
+    return (0, brace_expansion_1.default)(pattern);
+};
+exports.braceExpand = braceExpand;
+exports.minimatch.braceExpand = exports.braceExpand;
+// parse a component of the expanded set.
+// At this point, no pattern may contain "/" in it
+// so we're going to return a 2d array, where each entry is the full
+// pattern, split on '/', and then turned into a regular expression.
+// A regexp is made at the end which joins each array with an
+// escaped /, and another full one which joins each regexp with |.
+//
+// Following the lead of Bash 4.1, note that "**" only has special meaning
+// when it is the *only* thing in a path portion.  Otherwise, any series
+// of * is equivalent to a single *.  Globstar behavior is enabled by
+// default, and can be disabled by setting options.noglobstar.
+const makeRe = (pattern, options = {}) => new Minimatch(pattern, options).makeRe();
+exports.makeRe = makeRe;
+exports.minimatch.makeRe = exports.makeRe;
+const match = (list, pattern, options = {}) => {
+    const mm = new Minimatch(pattern, options);
+    list = list.filter(f => mm.match(f));
+    if (mm.options.nonull && !list.length) {
+        list.push(pattern);
+    }
+    return list;
+};
+exports.match = match;
+exports.minimatch.match = exports.match;
+// replace stuff like \* with *
+const globMagic = /[?*]|[+@!]\(.*?\)|\[|\]/;
+const regExpEscape = (s) => s.replace(/[-[\]{}()*+?.,\\^$|#\s]/g, '\\$&');
+class Minimatch {
+    options;
+    set;
+    pattern;
+    windowsPathsNoEscape;
+    nonegate;
+    negate;
+    comment;
+    empty;
+    preserveMultipleSlashes;
+    partial;
+    globSet;
+    globParts;
+    nocase;
+    isWindows;
+    platform;
+    windowsNoMagicRoot;
+    regexp;
+    constructor(pattern, options = {}) {
+        (0, assert_valid_pattern_js_1.assertValidPattern)(pattern);
+        options = options || {};
+        this.options = options;
+        this.pattern = pattern;
+        this.platform = options.platform || defaultPlatform;
+        this.isWindows = this.platform === 'win32';
+        this.windowsPathsNoEscape =
+            !!options.windowsPathsNoEscape || options.allowWindowsEscape === false;
+        if (this.windowsPathsNoEscape) {
+            this.pattern = this.pattern.replace(/\\/g, '/');
+        }
+        this.preserveMultipleSlashes = !!options.preserveMultipleSlashes;
+        this.regexp = null;
+        this.negate = false;
+        this.nonegate = !!options.nonegate;
+        this.comment = false;
+        this.empty = false;
+        this.partial = !!options.partial;
+        this.nocase = !!this.options.nocase;
+        this.windowsNoMagicRoot =
+            options.windowsNoMagicRoot !== undefined
+                ? options.windowsNoMagicRoot
+                : !!(this.isWindows && this.nocase);
+        this.globSet = [];
+        this.globParts = [];
+        this.set = [];
+        // make the set of regexps etc.
+        this.make();
+    }
+    hasMagic() {
+        if (this.options.magicalBraces && this.set.length > 1) {
+            return true;
+        }
+        for (const pattern of this.set) {
+            for (const part of pattern) {
+                if (typeof part !== 'string')
+                    return true;
+            }
+        }
+        return false;
+    }
+    debug(..._) { }
+    make() {
+        const pattern = this.pattern;
+        const options = this.options;
+        // empty patterns and comments match nothing.
+        if (!options.nocomment && pattern.charAt(0) === '#') {
+            this.comment = true;
+            return;
+        }
+        if (!pattern) {
+            this.empty = true;
+            return;
+        }
+        // step 1: figure out negation, etc.
+        this.parseNegate();
+        // step 2: expand braces
+        this.globSet = [...new Set(this.braceExpand())];
+        if (options.debug) {
+            this.debug = (...args) => console.error(...args);
+        }
+        this.debug(this.pattern, this.globSet);
+        // step 3: now we have a set, so turn each one into a series of
+        // path-portion matching patterns.
+        // These will be regexps, except in the case of "**", which is
+        // set to the GLOBSTAR object for globstar behavior,
+        // and will not contain any / characters
+        //
+        // First, we preprocess to make the glob pattern sets a bit simpler
+        // and deduped.  There are some perf-killing patterns that can cause
+        // problems with a glob walk, but we can simplify them down a bit.
+        const rawGlobParts = this.globSet.map(s => this.slashSplit(s));
+        this.globParts = this.preprocess(rawGlobParts);
+        this.debug(this.pattern, this.globParts);
+        // glob --> regexps
+        let set = this.globParts.map((s, _, __) => {
+            if (this.isWindows && this.windowsNoMagicRoot) {
+                // check if it's a drive or unc path.
+                const isUNC = s[0] === '' &&
+                    s[1] === '' &&
+                    (s[2] === '?' || !globMagic.test(s[2])) &&
+                    !globMagic.test(s[3]);
+                const isDrive = /^[a-z]:/i.test(s[0]);
+                if (isUNC) {
+                    return [...s.slice(0, 4), ...s.slice(4).map(ss => this.parse(ss))];
+                }
+                else if (isDrive) {
+                    return [s[0], ...s.slice(1).map(ss => this.parse(ss))];
+                }
+            }
+            return s.map(ss => this.parse(ss));
+        });
+        this.debug(this.pattern, set);
+        // filter out everything that didn't compile properly.
+        this.set = set.filter(s => s.indexOf(false) === -1);
+        // do not treat the ? in UNC paths as magic
+        if (this.isWindows) {
+            for (let i = 0; i < this.set.length; i++) {
+                const p = this.set[i];
+                if (p[0] === '' &&
+                    p[1] === '' &&
+                    this.globParts[i][2] === '?' &&
+                    typeof p[3] === 'string' &&
+                    /^[a-z]:$/i.test(p[3])) {
+                    p[2] = '?';
+                }
+            }
+        }
+        this.debug(this.pattern, this.set);
+    }
+    // various transforms to equivalent pattern sets that are
+    // faster to process in a filesystem walk.  The goal is to
+    // eliminate what we can, and push all ** patterns as far
+    // to the right as possible, even if it increases the number
+    // of patterns that we have to process.
+    preprocess(globParts) {
+        // if we're not in globstar mode, then turn all ** into *
+        if (this.options.noglobstar) {
+            for (let i = 0; i < globParts.length; i++) {
+                for (let j = 0; j < globParts[i].length; j++) {
+                    if (globParts[i][j] === '**') {
+                        globParts[i][j] = '*';
+                    }
+                }
+            }
+        }
+        const { optimizationLevel = 1 } = this.options;
+        if (optimizationLevel >= 2) {
+            // aggressive optimization for the purpose of fs walking
+            globParts = this.firstPhasePreProcess(globParts);
+            globParts = this.secondPhasePreProcess(globParts);
+        }
+        else if (optimizationLevel >= 1) {
+            // just basic optimizations to remove some .. parts
+            globParts = this.levelOneOptimize(globParts);
+        }
+        else {
+            globParts = this.adjascentGlobstarOptimize(globParts);
+        }
+        return globParts;
+    }
+    // just get rid of adjascent ** portions
+    adjascentGlobstarOptimize(globParts) {
+        return globParts.map(parts => {
+            let gs = -1;
+            while (-1 !== (gs = parts.indexOf('**', gs + 1))) {
+                let i = gs;
+                while (parts[i + 1] === '**') {
+                    i++;
+                }
+                if (i !== gs) {
+                    parts.splice(gs, i - gs);
+                }
+            }
+            return parts;
+        });
+    }
+    // get rid of adjascent ** and resolve .. portions
+    levelOneOptimize(globParts) {
+        return globParts.map(parts => {
+            parts = parts.reduce((set, part) => {
+                const prev = set[set.length - 1];
+                if (part === '**' && prev === '**') {
+                    return set;
+                }
+                if (part === '..') {
+                    if (prev && prev !== '..' && prev !== '.' && prev !== '**') {
+                        set.pop();
+                        return set;
+                    }
+                }
+                set.push(part);
+                return set;
+            }, []);
+            return parts.length === 0 ? [''] : parts;
+        });
+    }
+    levelTwoFileOptimize(parts) {
+        if (!Array.isArray(parts)) {
+            parts = this.slashSplit(parts);
+        }
+        let didSomething = false;
+        do {
+            didSomething = false;
+            // 
// -> 
/
+            if (!this.preserveMultipleSlashes) {
+                for (let i = 1; i < parts.length - 1; i++) {
+                    const p = parts[i];
+                    // don't squeeze out UNC patterns
+                    if (i === 1 && p === '' && parts[0] === '')
+                        continue;
+                    if (p === '.' || p === '') {
+                        didSomething = true;
+                        parts.splice(i, 1);
+                        i--;
+                    }
+                }
+                if (parts[0] === '.' &&
+                    parts.length === 2 &&
+                    (parts[1] === '.' || parts[1] === '')) {
+                    didSomething = true;
+                    parts.pop();
+                }
+            }
+            // 
/

/../ ->

/
+            let dd = 0;
+            while (-1 !== (dd = parts.indexOf('..', dd + 1))) {
+                const p = parts[dd - 1];
+                if (p && p !== '.' && p !== '..' && p !== '**') {
+                    didSomething = true;
+                    parts.splice(dd - 1, 2);
+                    dd -= 2;
+                }
+            }
+        } while (didSomething);
+        return parts.length === 0 ? [''] : parts;
+    }
+    // First phase: single-pattern processing
+    // 
 is 1 or more portions
+    //  is 1 or more portions
+    // 

is any portion other than ., .., '', or ** + // is . or '' + // + // **/.. is *brutal* for filesystem walking performance, because + // it effectively resets the recursive walk each time it occurs, + // and ** cannot be reduced out by a .. pattern part like a regexp + // or most strings (other than .., ., and '') can be. + // + //

/**/../

/

/ -> {

/../

/

/,

/**/

/

/} + //

// -> 
/
+    // 
/

/../ ->

/
+    // **/**/ -> **/
+    //
+    // **/*/ -> */**/ <== not valid because ** doesn't follow
+    // this WOULD be allowed if ** did follow symlinks, or * didn't
+    firstPhasePreProcess(globParts) {
+        let didSomething = false;
+        do {
+            didSomething = false;
+            // 
/**/../

/

/ -> {

/../

/

/,

/**/

/

/} + for (let parts of globParts) { + let gs = -1; + while (-1 !== (gs = parts.indexOf('**', gs + 1))) { + let gss = gs; + while (parts[gss + 1] === '**') { + //

/**/**/ -> 
/**/
+                        gss++;
+                    }
+                    // eg, if gs is 2 and gss is 4, that means we have 3 **
+                    // parts, and can remove 2 of them.
+                    if (gss > gs) {
+                        parts.splice(gs + 1, gss - gs);
+                    }
+                    let next = parts[gs + 1];
+                    const p = parts[gs + 2];
+                    const p2 = parts[gs + 3];
+                    if (next !== '..')
+                        continue;
+                    if (!p ||
+                        p === '.' ||
+                        p === '..' ||
+                        !p2 ||
+                        p2 === '.' ||
+                        p2 === '..') {
+                        continue;
+                    }
+                    didSomething = true;
+                    // edit parts in place, and push the new one
+                    parts.splice(gs, 1);
+                    const other = parts.slice(0);
+                    other[gs] = '**';
+                    globParts.push(other);
+                    gs--;
+                }
+                // 
// -> 
/
+                if (!this.preserveMultipleSlashes) {
+                    for (let i = 1; i < parts.length - 1; i++) {
+                        const p = parts[i];
+                        // don't squeeze out UNC patterns
+                        if (i === 1 && p === '' && parts[0] === '')
+                            continue;
+                        if (p === '.' || p === '') {
+                            didSomething = true;
+                            parts.splice(i, 1);
+                            i--;
+                        }
+                    }
+                    if (parts[0] === '.' &&
+                        parts.length === 2 &&
+                        (parts[1] === '.' || parts[1] === '')) {
+                        didSomething = true;
+                        parts.pop();
+                    }
+                }
+                // 
/

/../ ->

/
+                let dd = 0;
+                while (-1 !== (dd = parts.indexOf('..', dd + 1))) {
+                    const p = parts[dd - 1];
+                    if (p && p !== '.' && p !== '..' && p !== '**') {
+                        didSomething = true;
+                        const needDot = dd === 1 && parts[dd + 1] === '**';
+                        const splin = needDot ? ['.'] : [];
+                        parts.splice(dd - 1, 2, ...splin);
+                        if (parts.length === 0)
+                            parts.push('');
+                        dd -= 2;
+                    }
+                }
+            }
+        } while (didSomething);
+        return globParts;
+    }
+    // second phase: multi-pattern dedupes
+    // {
/*/,
/

/} ->

/*/
+    // {
/,
/} -> 
/
+    // {
/**/,
/} -> 
/**/
+    //
+    // {
/**/,
/**/

/} ->

/**/
+    // ^-- not valid because ** doens't follow symlinks
+    secondPhasePreProcess(globParts) {
+        for (let i = 0; i < globParts.length - 1; i++) {
+            for (let j = i + 1; j < globParts.length; j++) {
+                const matched = this.partsMatch(globParts[i], globParts[j], !this.preserveMultipleSlashes);
+                if (!matched)
+                    continue;
+                globParts[i] = matched;
+                globParts[j] = [];
+            }
+        }
+        return globParts.filter(gs => gs.length);
+    }
+    partsMatch(a, b, emptyGSMatch = false) {
+        let ai = 0;
+        let bi = 0;
+        let result = [];
+        let which = '';
+        while (ai < a.length && bi < b.length) {
+            if (a[ai] === b[bi]) {
+                result.push(which === 'b' ? b[bi] : a[ai]);
+                ai++;
+                bi++;
+            }
+            else if (emptyGSMatch && a[ai] === '**' && b[bi] === a[ai + 1]) {
+                result.push(a[ai]);
+                ai++;
+            }
+            else if (emptyGSMatch && b[bi] === '**' && a[ai] === b[bi + 1]) {
+                result.push(b[bi]);
+                bi++;
+            }
+            else if (a[ai] === '*' &&
+                b[bi] &&
+                (this.options.dot || !b[bi].startsWith('.')) &&
+                b[bi] !== '**') {
+                if (which === 'b')
+                    return false;
+                which = 'a';
+                result.push(a[ai]);
+                ai++;
+                bi++;
+            }
+            else if (b[bi] === '*' &&
+                a[ai] &&
+                (this.options.dot || !a[ai].startsWith('.')) &&
+                a[ai] !== '**') {
+                if (which === 'a')
+                    return false;
+                which = 'b';
+                result.push(b[bi]);
+                ai++;
+                bi++;
+            }
+            else {
+                return false;
+            }
+        }
+        // if we fall out of the loop, it means they two are identical
+        // as long as their lengths match
+        return a.length === b.length && result;
+    }
+    parseNegate() {
+        if (this.nonegate)
+            return;
+        const pattern = this.pattern;
+        let negate = false;
+        let negateOffset = 0;
+        for (let i = 0; i < pattern.length && pattern.charAt(i) === '!'; i++) {
+            negate = !negate;
+            negateOffset++;
+        }
+        if (negateOffset)
+            this.pattern = pattern.slice(negateOffset);
+        this.negate = negate;
+    }
+    // set partial to true to test if, for example,
+    // "/a/b" matches the start of "/*/b/*/d"
+    // Partial means, if you run out of file before you run
+    // out of pattern, then that's fine, as long as all
+    // the parts match.
+    matchOne(file, pattern, partial = false) {
+        const options = this.options;
+        // UNC paths like //?/X:/... can match X:/... and vice versa
+        // Drive letters in absolute drive or unc paths are always compared
+        // case-insensitively.
+        if (this.isWindows) {
+            const fileDrive = typeof file[0] === 'string' && /^[a-z]:$/i.test(file[0]);
+            const fileUNC = !fileDrive &&
+                file[0] === '' &&
+                file[1] === '' &&
+                file[2] === '?' &&
+                /^[a-z]:$/i.test(file[3]);
+            const patternDrive = typeof pattern[0] === 'string' && /^[a-z]:$/i.test(pattern[0]);
+            const patternUNC = !patternDrive &&
+                pattern[0] === '' &&
+                pattern[1] === '' &&
+                pattern[2] === '?' &&
+                typeof pattern[3] === 'string' &&
+                /^[a-z]:$/i.test(pattern[3]);
+            const fdi = fileUNC ? 3 : fileDrive ? 0 : undefined;
+            const pdi = patternUNC ? 3 : patternDrive ? 0 : undefined;
+            if (typeof fdi === 'number' && typeof pdi === 'number') {
+                const [fd, pd] = [file[fdi], pattern[pdi]];
+                if (fd.toLowerCase() === pd.toLowerCase()) {
+                    pattern[pdi] = fd;
+                    if (pdi > fdi) {
+                        pattern = pattern.slice(pdi);
+                    }
+                    else if (fdi > pdi) {
+                        file = file.slice(fdi);
+                    }
+                }
+            }
+        }
+        // resolve and reduce . and .. portions in the file as well.
+        // dont' need to do the second phase, because it's only one string[]
+        const { optimizationLevel = 1 } = this.options;
+        if (optimizationLevel >= 2) {
+            file = this.levelTwoFileOptimize(file);
+        }
+        this.debug('matchOne', this, { file, pattern });
+        this.debug('matchOne', file.length, pattern.length);
+        for (var fi = 0, pi = 0, fl = file.length, pl = pattern.length; fi < fl && pi < pl; fi++, pi++) {
+            this.debug('matchOne loop');
+            var p = pattern[pi];
+            var f = file[fi];
+            this.debug(pattern, p, f);
+            // should be impossible.
+            // some invalid regexp stuff in the set.
+            /* c8 ignore start */
+            if (p === false) {
+                return false;
+            }
+            /* c8 ignore stop */
+            if (p === exports.GLOBSTAR) {
+                this.debug('GLOBSTAR', [pattern, p, f]);
+                // "**"
+                // a/**/b/**/c would match the following:
+                // a/b/x/y/z/c
+                // a/x/y/z/b/c
+                // a/b/x/b/x/c
+                // a/b/c
+                // To do this, take the rest of the pattern after
+                // the **, and see if it would match the file remainder.
+                // If so, return success.
+                // If not, the ** "swallows" a segment, and try again.
+                // This is recursively awful.
+                //
+                // a/**/b/**/c matching a/b/x/y/z/c
+                // - a matches a
+                // - doublestar
+                //   - matchOne(b/x/y/z/c, b/**/c)
+                //     - b matches b
+                //     - doublestar
+                //       - matchOne(x/y/z/c, c) -> no
+                //       - matchOne(y/z/c, c) -> no
+                //       - matchOne(z/c, c) -> no
+                //       - matchOne(c, c) yes, hit
+                var fr = fi;
+                var pr = pi + 1;
+                if (pr === pl) {
+                    this.debug('** at the end');
+                    // a ** at the end will just swallow the rest.
+                    // We have found a match.
+                    // however, it will not swallow /.x, unless
+                    // options.dot is set.
+                    // . and .. are *never* matched by **, for explosively
+                    // exponential reasons.
+                    for (; fi < fl; fi++) {
+                        if (file[fi] === '.' ||
+                            file[fi] === '..' ||
+                            (!options.dot && file[fi].charAt(0) === '.'))
+                            return false;
+                    }
+                    return true;
+                }
+                // ok, let's see if we can swallow whatever we can.
+                while (fr < fl) {
+                    var swallowee = file[fr];
+                    this.debug('\nglobstar while', file, fr, pattern, pr, swallowee);
+                    // XXX remove this slice.  Just pass the start index.
+                    if (this.matchOne(file.slice(fr), pattern.slice(pr), partial)) {
+                        this.debug('globstar found match!', fr, fl, swallowee);
+                        // found a match.
+                        return true;
+                    }
+                    else {
+                        // can't swallow "." or ".." ever.
+                        // can only swallow ".foo" when explicitly asked.
+                        if (swallowee === '.' ||
+                            swallowee === '..' ||
+                            (!options.dot && swallowee.charAt(0) === '.')) {
+                            this.debug('dot detected!', file, fr, pattern, pr);
+                            break;
+                        }
+                        // ** swallows a segment, and continue.
+                        this.debug('globstar swallow a segment, and continue');
+                        fr++;
+                    }
+                }
+                // no match was found.
+                // However, in partial mode, we can't say this is necessarily over.
+                /* c8 ignore start */
+                if (partial) {
+                    // ran out of file
+                    this.debug('\n>>> no match, partial?', file, fr, pattern, pr);
+                    if (fr === fl) {
+                        return true;
+                    }
+                }
+                /* c8 ignore stop */
+                return false;
+            }
+            // something other than **
+            // non-magic patterns just have to match exactly
+            // patterns with magic have been turned into regexps.
+            let hit;
+            if (typeof p === 'string') {
+                hit = f === p;
+                this.debug('string match', p, f, hit);
+            }
+            else {
+                hit = p.test(f);
+                this.debug('pattern match', p, f, hit);
+            }
+            if (!hit)
+                return false;
+        }
+        // Note: ending in / means that we'll get a final ""
+        // at the end of the pattern.  This can only match a
+        // corresponding "" at the end of the file.
+        // If the file ends in /, then it can only match a
+        // a pattern that ends in /, unless the pattern just
+        // doesn't have any more for it. But, a/b/ should *not*
+        // match "a/b/*", even though "" matches against the
+        // [^/]*? pattern, except in partial mode, where it might
+        // simply not be reached yet.
+        // However, a/b/ should still satisfy a/*
+        // now either we fell off the end of the pattern, or we're done.
+        if (fi === fl && pi === pl) {
+            // ran out of pattern and filename at the same time.
+            // an exact hit!
+            return true;
+        }
+        else if (fi === fl) {
+            // ran out of file, but still had pattern left.
+            // this is ok if we're doing the match as part of
+            // a glob fs traversal.
+            return partial;
+        }
+        else if (pi === pl) {
+            // ran out of pattern, still have file left.
+            // this is only acceptable if we're on the very last
+            // empty segment of a file with a trailing slash.
+            // a/* should match a/b/
+            return fi === fl - 1 && file[fi] === '';
+            /* c8 ignore start */
+        }
+        else {
+            // should be unreachable.
+            throw new Error('wtf?');
+        }
+        /* c8 ignore stop */
+    }
+    braceExpand() {
+        return (0, exports.braceExpand)(this.pattern, this.options);
+    }
+    parse(pattern) {
+        (0, assert_valid_pattern_js_1.assertValidPattern)(pattern);
+        const options = this.options;
+        // shortcuts
+        if (pattern === '**')
+            return exports.GLOBSTAR;
+        if (pattern === '')
+            return '';
+        // far and away, the most common glob pattern parts are
+        // *, *.*, and *.  Add a fast check method for those.
+        let m;
+        let fastTest = null;
+        if ((m = pattern.match(starRE))) {
+            fastTest = options.dot ? starTestDot : starTest;
+        }
+        else if ((m = pattern.match(starDotExtRE))) {
+            fastTest = (options.nocase
+                ? options.dot
+                    ? starDotExtTestNocaseDot
+                    : starDotExtTestNocase
+                : options.dot
+                    ? starDotExtTestDot
+                    : starDotExtTest)(m[1]);
+        }
+        else if ((m = pattern.match(qmarksRE))) {
+            fastTest = (options.nocase
+                ? options.dot
+                    ? qmarksTestNocaseDot
+                    : qmarksTestNocase
+                : options.dot
+                    ? qmarksTestDot
+                    : qmarksTest)(m);
+        }
+        else if ((m = pattern.match(starDotStarRE))) {
+            fastTest = options.dot ? starDotStarTestDot : starDotStarTest;
+        }
+        else if ((m = pattern.match(dotStarRE))) {
+            fastTest = dotStarTest;
+        }
+        const re = ast_js_1.AST.fromGlob(pattern, this.options).toMMPattern();
+        return fastTest ? Object.assign(re, { test: fastTest }) : re;
+    }
+    makeRe() {
+        if (this.regexp || this.regexp === false)
+            return this.regexp;
+        // at this point, this.set is a 2d array of partial
+        // pattern strings, or "**".
+        //
+        // It's better to use .match().  This function shouldn't
+        // be used, really, but it's pretty convenient sometimes,
+        // when you just want to work with a regex.
+        const set = this.set;
+        if (!set.length) {
+            this.regexp = false;
+            return this.regexp;
+        }
+        const options = this.options;
+        const twoStar = options.noglobstar
+            ? star
+            : options.dot
+                ? twoStarDot
+                : twoStarNoDot;
+        const flags = new Set(options.nocase ? ['i'] : []);
+        // regexpify non-globstar patterns
+        // if ** is only item, then we just do one twoStar
+        // if ** is first, and there are more, prepend (\/|twoStar\/)? to next
+        // if ** is last, append (\/twoStar|) to previous
+        // if ** is in the middle, append (\/|\/twoStar\/) to previous
+        // then filter out GLOBSTAR symbols
+        let re = set
+            .map(pattern => {
+            const pp = pattern.map(p => {
+                if (p instanceof RegExp) {
+                    for (const f of p.flags.split(''))
+                        flags.add(f);
+                }
+                return typeof p === 'string'
+                    ? regExpEscape(p)
+                    : p === exports.GLOBSTAR
+                        ? exports.GLOBSTAR
+                        : p._src;
+            });
+            pp.forEach((p, i) => {
+                const next = pp[i + 1];
+                const prev = pp[i - 1];
+                if (p !== exports.GLOBSTAR || prev === exports.GLOBSTAR) {
+                    return;
+                }
+                if (prev === undefined) {
+                    if (next !== undefined && next !== exports.GLOBSTAR) {
+                        pp[i + 1] = '(?:\\/|' + twoStar + '\\/)?' + next;
+                    }
+                    else {
+                        pp[i] = twoStar;
+                    }
+                }
+                else if (next === undefined) {
+                    pp[i - 1] = prev + '(?:\\/|' + twoStar + ')?';
+                }
+                else if (next !== exports.GLOBSTAR) {
+                    pp[i - 1] = prev + '(?:\\/|\\/' + twoStar + '\\/)' + next;
+                    pp[i + 1] = exports.GLOBSTAR;
+                }
+            });
+            return pp.filter(p => p !== exports.GLOBSTAR).join('/');
+        })
+            .join('|');
+        // need to wrap in parens if we had more than one thing with |,
+        // otherwise only the first will be anchored to ^ and the last to $
+        const [open, close] = set.length > 1 ? ['(?:', ')'] : ['', ''];
+        // must match entire pattern
+        // ending in a * or ** will make it less strict.
+        re = '^' + open + re + close + '$';
+        // can match anything, as long as it's not this.
+        if (this.negate)
+            re = '^(?!' + re + ').+$';
+        try {
+            this.regexp = new RegExp(re, [...flags].join(''));
+            /* c8 ignore start */
+        }
+        catch (ex) {
+            // should be impossible
+            this.regexp = false;
+        }
+        /* c8 ignore stop */
+        return this.regexp;
+    }
+    slashSplit(p) {
+        // if p starts with // on windows, we preserve that
+        // so that UNC paths aren't broken.  Otherwise, any number of
+        // / characters are coalesced into one, unless
+        // preserveMultipleSlashes is set to true.
+        if (this.preserveMultipleSlashes) {
+            return p.split('/');
+        }
+        else if (this.isWindows && /^\/\/[^\/]+/.test(p)) {
+            // add an extra '' for the one we lose
+            return ['', ...p.split(/\/+/)];
+        }
+        else {
+            return p.split(/\/+/);
+        }
+    }
+    match(f, partial = this.partial) {
+        this.debug('match', f, this.pattern);
+        // short-circuit in the case of busted things.
+        // comments, etc.
+        if (this.comment) {
+            return false;
+        }
+        if (this.empty) {
+            return f === '';
+        }
+        if (f === '/' && partial) {
+            return true;
+        }
+        const options = this.options;
+        // windows: need to use /, not \
+        if (this.isWindows) {
+            f = f.split('\\').join('/');
+        }
+        // treat the test path as a set of pathparts.
+        const ff = this.slashSplit(f);
+        this.debug(this.pattern, 'split', ff);
+        // just ONE of the pattern sets in this.set needs to match
+        // in order for it to be valid.  If negating, then just one
+        // match means that we have failed.
+        // Either way, return on the first hit.
+        const set = this.set;
+        this.debug(this.pattern, 'set', set);
+        // Find the basename of the path by looking for the last non-empty segment
+        let filename = ff[ff.length - 1];
+        if (!filename) {
+            for (let i = ff.length - 2; !filename && i >= 0; i--) {
+                filename = ff[i];
+            }
+        }
+        for (let i = 0; i < set.length; i++) {
+            const pattern = set[i];
+            let file = ff;
+            if (options.matchBase && pattern.length === 1) {
+                file = [filename];
+            }
+            const hit = this.matchOne(file, pattern, partial);
+            if (hit) {
+                if (options.flipNegate) {
+                    return true;
+                }
+                return !this.negate;
+            }
+        }
+        // didn't get any hits.  this is success if it's a negative
+        // pattern, failure otherwise.
+        if (options.flipNegate) {
+            return false;
+        }
+        return this.negate;
+    }
+    static defaults(def) {
+        return exports.minimatch.defaults(def).Minimatch;
+    }
+}
+exports.Minimatch = Minimatch;
+/* c8 ignore start */
+var ast_js_2 = __nccwpck_require__(50249);
+Object.defineProperty(exports, "AST", ({ enumerable: true, get: function () { return ast_js_2.AST; } }));
+var escape_js_2 = __nccwpck_require__(9549);
+Object.defineProperty(exports, "escape", ({ enumerable: true, get: function () { return escape_js_2.escape; } }));
+var unescape_js_2 = __nccwpck_require__(43612);
+Object.defineProperty(exports, "unescape", ({ enumerable: true, get: function () { return unescape_js_2.unescape; } }));
+/* c8 ignore stop */
+exports.minimatch.AST = ast_js_1.AST;
+exports.minimatch.Minimatch = Minimatch;
+exports.minimatch.escape = escape_js_1.escape;
+exports.minimatch.unescape = unescape_js_1.unescape;
+//# sourceMappingURL=index.js.map
+
+/***/ }),
+
+/***/ 43612:
+/***/ ((__unused_webpack_module, exports) => {
+
+"use strict";
+
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.unescape = void 0;
+/**
+ * Un-escape a string that has been escaped with {@link escape}.
+ *
+ * If the {@link windowsPathsNoEscape} option is used, then square-brace
+ * escapes are removed, but not backslash escapes.  For example, it will turn
+ * the string `'[*]'` into `*`, but it will not turn `'\\*'` into `'*'`,
+ * becuase `\` is a path separator in `windowsPathsNoEscape` mode.
+ *
+ * When `windowsPathsNoEscape` is not set, then both brace escapes and
+ * backslash escapes are removed.
+ *
+ * Slashes (and backslashes in `windowsPathsNoEscape` mode) cannot be escaped
+ * or unescaped.
+ */
+const unescape = (s, { windowsPathsNoEscape = false, } = {}) => {
+    return windowsPathsNoEscape
+        ? s.replace(/\[([^\/\\])\]/g, '$1')
+        : s.replace(/((?!\\).|^)\[([^\/\\])\]/g, '$1$2').replace(/\\([^\/])/g, '$1');
+};
+exports.unescape = unescape;
+//# sourceMappingURL=unescape.js.map
+
+/***/ }),
+
+/***/ 44050:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
+
+"use strict";
+
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.renamePropertyWithStableKeys = exports.toOldFormat = exports.toNewFormat = exports.isAngularPluginInstalled = exports.shouldMergeAngularProjects = exports.NxAngularJsonPlugin = exports.NX_ANGULAR_JSON_PLUGIN_NAME = void 0;
+const fs_1 = __nccwpck_require__(57147);
+const path = __nccwpck_require__(71017);
+const fileutils_1 = __nccwpck_require__(83851);
+exports.NX_ANGULAR_JSON_PLUGIN_NAME = 'nx-angular-json-plugin';
+exports.NxAngularJsonPlugin = {
+    name: exports.NX_ANGULAR_JSON_PLUGIN_NAME,
+    createNodes: [
+        'angular.json',
+        (f, _, ctx) => ({
+            projects: readAngularJson(ctx.workspaceRoot),
+        }),
+    ],
+};
+function shouldMergeAngularProjects(root, includeProjectsFromAngularJson) {
+    if ((0, fs_1.existsSync)(path.join(root, 'angular.json')) &&
+        // Include projects from angular.json if explicitly required.
+        // e.g. when invoked from `packages/devkit/src/utils/convert-nx-executor.ts`
+        (includeProjectsFromAngularJson ||
+            // Or if a workspace has `@nrwl/angular`/`@nx/angular` installed then projects from `angular.json` to be considered by Nx.
+            isAngularPluginInstalled())) {
+        return true;
+    }
+    else {
+        return false;
+    }
+}
+exports.shouldMergeAngularProjects = shouldMergeAngularProjects;
+function isAngularPluginInstalled() {
+    try {
+        // nx-ignore-next-line
+        require.resolve('@nx/angular');
+        return true;
+    }
+    catch {
+        try {
+            require.resolve('@nrwl/angular');
+            return true;
+        }
+        catch {
+            return false;
+        }
+    }
+}
+exports.isAngularPluginInstalled = isAngularPluginInstalled;
+function readAngularJson(angularCliWorkspaceRoot) {
+    return toNewFormat((0, fileutils_1.readJsonFile)(path.join(angularCliWorkspaceRoot, 'angular.json'))).projects;
+}
+function toNewFormat(w) {
+    if (!w.projects) {
+        return w;
+    }
+    for (const name in w.projects ?? {}) {
+        const projectConfig = w.projects[name];
+        if (projectConfig.architect) {
+            renamePropertyWithStableKeys(projectConfig, 'architect', 'targets');
+        }
+        if (projectConfig.schematics) {
+            renamePropertyWithStableKeys(projectConfig, 'schematics', 'generators');
+        }
+        if (!projectConfig.name) {
+            projectConfig.name = name;
+        }
+        Object.values(projectConfig.targets || {}).forEach((target) => {
+            if (target.builder !== undefined) {
+                renamePropertyWithStableKeys(target, 'builder', 'executor');
+            }
+        });
+    }
+    if (w.schematics) {
+        renamePropertyWithStableKeys(w, 'schematics', 'generators');
+    }
+    if (w.version !== 2) {
+        w.version = 2;
+    }
+    return w;
+}
+exports.toNewFormat = toNewFormat;
+function toOldFormat(w) {
+    if (w.projects) {
+        for (const name in w.projects) {
+            const projectConfig = w.projects[name];
+            if (typeof projectConfig === 'string') {
+                throw new Error("'project.json' files are incompatible with version 1 workspace schemas.");
+            }
+            if (projectConfig.targets) {
+                renamePropertyWithStableKeys(projectConfig, 'targets', 'architect');
+            }
+            if (projectConfig.generators) {
+                renamePropertyWithStableKeys(projectConfig, 'generators', 'schematics');
+            }
+            delete projectConfig.name;
+            Object.values(projectConfig.architect || {}).forEach((target) => {
+                if (target.executor !== undefined) {
+                    renamePropertyWithStableKeys(target, 'executor', 'builder');
+                }
+            });
+        }
+    }
+    if (w.generators) {
+        renamePropertyWithStableKeys(w, 'generators', 'schematics');
+    }
+    if (w.version !== 1) {
+        w.version = 1;
+    }
+    return w;
+}
+exports.toOldFormat = toOldFormat;
+// we have to do it this way to preserve the order of properties
+// not to screw up the formatting
+function renamePropertyWithStableKeys(obj, from, to) {
+    const copy = { ...obj };
+    Object.keys(obj).forEach((k) => {
+        delete obj[k];
+    });
+    Object.keys(copy).forEach((k) => {
+        if (k === from) {
+            obj[to] = copy[k];
+        }
+        else {
+            obj[k] = copy[k];
+        }
+    });
+}
+exports.renamePropertyWithStableKeys = renamePropertyWithStableKeys;
+
+
+/***/ }),
+
+/***/ 38777:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
+
+"use strict";
+
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.readNxJson = exports.workspaceLayout = void 0;
+const nx_json_1 = __nccwpck_require__(53619);
+/**
+ * Returns information about where apps and libs will be created.
+ */
+function workspaceLayout() {
+    const nxJson = (0, nx_json_1.readNxJson)();
+    return {
+        appsDir: nxJson.workspaceLayout?.appsDir ?? 'apps',
+        libsDir: nxJson.workspaceLayout?.libsDir ?? 'libs',
+    };
+}
+exports.workspaceLayout = workspaceLayout;
+var nx_json_2 = __nccwpck_require__(53619);
+Object.defineProperty(exports, "readNxJson", ({ enumerable: true, get: function () { return nx_json_2.readNxJson; } }));
+
+
+/***/ }),
+
+/***/ 53619:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
+
+"use strict";
+
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.hasNxJson = exports.readNxJson = void 0;
+const fs_1 = __nccwpck_require__(57147);
+const path_1 = __nccwpck_require__(71017);
+const fileutils_1 = __nccwpck_require__(83851);
+const workspace_root_1 = __nccwpck_require__(86708);
+function readNxJson(root = workspace_root_1.workspaceRoot) {
+    const nxJson = (0, path_1.join)(root, 'nx.json');
+    if ((0, fs_1.existsSync)(nxJson)) {
+        const nxJsonConfiguration = (0, fileutils_1.readJsonFile)(nxJson);
+        if (nxJsonConfiguration.extends) {
+            const extendedNxJsonPath = require.resolve(nxJsonConfiguration.extends, {
+                paths: [(0, path_1.dirname)(nxJson)],
+            });
+            const baseNxJson = (0, fileutils_1.readJsonFile)(extendedNxJsonPath);
+            return {
+                ...baseNxJson,
+                ...nxJsonConfiguration,
+            };
+        }
+        else {
+            return nxJsonConfiguration;
+        }
+    }
+    else {
+        try {
+            return (0, fileutils_1.readJsonFile)((0, path_1.join)(__dirname, '..', '..', 'presets', 'core.json'));
+        }
+        catch (e) {
+            return {};
+        }
+    }
+}
+exports.readNxJson = readNxJson;
+function hasNxJson(root) {
+    const nxJson = (0, path_1.join)(root, 'nx.json');
+    return (0, fs_1.existsSync)(nxJson);
+}
+exports.hasNxJson = hasNxJson;
+
+
+/***/ }),
+
+/***/ 2184:
+/***/ ((__unused_webpack_module, exports) => {
+
+"use strict";
+
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.DependencyType = exports.fileDataDepType = exports.fileDataDepTarget = void 0;
+function fileDataDepTarget(dep) {
+    return typeof dep === 'string'
+        ? dep
+        : Array.isArray(dep) && dep.length === 2
+            ? dep[0]
+            : dep[1];
+}
+exports.fileDataDepTarget = fileDataDepTarget;
+function fileDataDepType(dep) {
+    return typeof dep === 'string'
+        ? 'static'
+        : Array.isArray(dep) && dep.length === 2
+            ? dep[1]
+            : dep[2];
+}
+exports.fileDataDepType = fileDataDepType;
+/**
+ * Type of dependency between projects
+ */
+var DependencyType;
+(function (DependencyType) {
+    /**
+     * Static dependencies are tied to the loading of the module
+     */
+    DependencyType["static"] = "static";
+    /**
+     * Dynamic dependencies are brought in by the module at run time
+     */
+    DependencyType["dynamic"] = "dynamic";
+    /**
+     * Implicit dependencies are inferred
+     */
+    DependencyType["implicit"] = "implicit";
+})(DependencyType || (exports.DependencyType = DependencyType = {}));
+
+
+/***/ }),
+
+/***/ 26546:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
+
+"use strict";
+
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.toProjectName = exports.Workspaces = void 0;
+const path_1 = __nccwpck_require__(71017);
+const project_graph_1 = __nccwpck_require__(61371);
+const nx_json_1 = __nccwpck_require__(53619);
+// TODO(v19): remove this class
+/**
+ * @deprecated This will be removed in v19. Use {@link readProjectsConfigurationFromProjectGraph} instead.
+ */
+class Workspaces {
+    constructor(root) {
+        this.root = root;
+    }
+    /**
+     * @deprecated Use {@link readProjectsConfigurationFromProjectGraph} instead.
+     */
+    readWorkspaceConfiguration() {
+        const nxJson = (0, nx_json_1.readNxJson)(this.root);
+        return {
+            ...(0, project_graph_1.readProjectsConfigurationFromProjectGraph)((0, project_graph_1.readCachedProjectGraph)()),
+            ...nxJson,
+        };
+    }
+}
+exports.Workspaces = Workspaces;
+/**
+ * Pulled from toFileName in names from @nx/devkit.
+ * Todo: Should refactor, not duplicate.
+ */
+function toProjectName(fileName) {
+    const parts = (0, path_1.dirname)(fileName).split(/[\/\\]/g);
+    return parts[parts.length - 1].toLowerCase();
+}
+exports.toProjectName = toProjectName;
+
+
+/***/ }),
+
+/***/ 94849:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
+
+"use strict";
+
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.getDaemonProcessIdSync = exports.safelyCleanUpExistingProcess = exports.writeDaemonJsonProcessCache = exports.deleteDaemonJsonProcessCache = exports.readDaemonProcessJsonCache = exports.serverProcessJsonPath = void 0;
+const fs_extra_1 = __nccwpck_require__(27475);
+const path_1 = __nccwpck_require__(71017);
+const tmp_dir_1 = __nccwpck_require__(78543);
+exports.serverProcessJsonPath = (0, path_1.join)(tmp_dir_1.DAEMON_DIR_FOR_CURRENT_WORKSPACE, 'server-process.json');
+async function readDaemonProcessJsonCache() {
+    if (!(0, fs_extra_1.existsSync)(exports.serverProcessJsonPath)) {
+        return null;
+    }
+    return await (0, fs_extra_1.readJson)(exports.serverProcessJsonPath);
+}
+exports.readDaemonProcessJsonCache = readDaemonProcessJsonCache;
+function deleteDaemonJsonProcessCache() {
+    try {
+        if (getDaemonProcessIdSync() === process.pid) {
+            (0, fs_extra_1.unlinkSync)(exports.serverProcessJsonPath);
+        }
+    }
+    catch { }
+}
+exports.deleteDaemonJsonProcessCache = deleteDaemonJsonProcessCache;
+async function writeDaemonJsonProcessCache(daemonJson) {
+    await (0, fs_extra_1.writeJson)(exports.serverProcessJsonPath, daemonJson);
+}
+exports.writeDaemonJsonProcessCache = writeDaemonJsonProcessCache;
+async function safelyCleanUpExistingProcess() {
+    const daemonProcessJson = await readDaemonProcessJsonCache();
+    if (daemonProcessJson && daemonProcessJson.processId) {
+        try {
+            process.kill(daemonProcessJson.processId);
+        }
+        catch { }
+    }
+    deleteDaemonJsonProcessCache();
+}
+exports.safelyCleanUpExistingProcess = safelyCleanUpExistingProcess;
+// Must be sync for the help output use case
+function getDaemonProcessIdSync() {
+    if (!(0, fs_extra_1.existsSync)(exports.serverProcessJsonPath)) {
+        return null;
+    }
+    try {
+        const daemonProcessJson = (0, fs_extra_1.readJsonSync)(exports.serverProcessJsonPath);
+        return daemonProcessJson.processId;
+    }
+    catch {
+        return null;
+    }
+}
+exports.getDaemonProcessIdSync = getDaemonProcessIdSync;
+
+
+/***/ }),
+
+/***/ 36638:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
+
+"use strict";
+
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.daemonClient = exports.DaemonClient = void 0;
+const workspace_root_1 = __nccwpck_require__(86708);
+const child_process_1 = __nccwpck_require__(32081);
+const fs_1 = __nccwpck_require__(57147);
+const promises_1 = __nccwpck_require__(73292);
+const fs_extra_1 = __nccwpck_require__(27475);
+const net_1 = __nccwpck_require__(41808);
+const path_1 = __nccwpck_require__(71017);
+const perf_hooks_1 = __nccwpck_require__(4074);
+const output_1 = __nccwpck_require__(1737);
+const socket_utils_1 = __nccwpck_require__(10023);
+const tmp_dir_1 = __nccwpck_require__(78543);
+const is_ci_1 = __nccwpck_require__(15284);
+const configuration_1 = __nccwpck_require__(38777);
+const promised_based_queue_1 = __nccwpck_require__(71067);
+const nx_json_1 = __nccwpck_require__(53619);
+const daemon_socket_messenger_1 = __nccwpck_require__(30386);
+const cache_1 = __nccwpck_require__(94849);
+const DAEMON_ENV_SETTINGS = {
+    ...process.env,
+    NX_PROJECT_GLOB_CACHE: 'false',
+    NX_CACHE_PROJECTS_CONFIG: 'false',
+};
+var DaemonStatus;
+(function (DaemonStatus) {
+    DaemonStatus[DaemonStatus["CONNECTING"] = 0] = "CONNECTING";
+    DaemonStatus[DaemonStatus["DISCONNECTED"] = 1] = "DISCONNECTED";
+    DaemonStatus[DaemonStatus["CONNECTED"] = 2] = "CONNECTED";
+})(DaemonStatus || (DaemonStatus = {}));
+class DaemonClient {
+    constructor(nxJson) {
+        this.nxJson = nxJson;
+        this._daemonStatus = DaemonStatus.DISCONNECTED;
+        this._waitForDaemonReady = null;
+        this._daemonReady = null;
+        this._out = null;
+        this._err = null;
+        this.reset();
+    }
+    enabled() {
+        if (this._enabled === undefined) {
+            // TODO(v19): Add migration to move it out of existing configs and remove the ?? here.
+            const useDaemonProcessOption = this.nxJson.useDaemonProcess ??
+                this.nxJson.tasksRunnerOptions?.['default']?.options?.useDaemonProcess;
+            const env = process.env.NX_DAEMON;
+            // env takes precedence
+            // option=true,env=false => no daemon
+            // option=false,env=undefined => no daemon
+            // option=false,env=false => no daemon
+            // option=undefined,env=undefined => daemon
+            // option=true,env=true => daemon
+            // option=false,env=true => daemon
+            // CI=true,env=undefined => no daemon
+            // CI=true,env=false => no daemon
+            // CI=true,env=true => daemon
+            if (((0, is_ci_1.isCI)() && env !== 'true') ||
+                isDocker() ||
+                (0, tmp_dir_1.isDaemonDisabled)() ||
+                nxJsonIsNotPresent() ||
+                (useDaemonProcessOption === undefined && env === 'false') ||
+                (useDaemonProcessOption === true && env === 'false') ||
+                (useDaemonProcessOption === false && env === undefined) ||
+                (useDaemonProcessOption === false && env === 'false')) {
+                this._enabled = false;
+            }
+            else {
+                this._enabled = true;
+            }
+        }
+        return this._enabled;
+    }
+    reset() {
+        this.socketMessenger?.close();
+        this.socketMessenger = null;
+        this.queue = new promised_based_queue_1.PromisedBasedQueue();
+        this.currentMessage = null;
+        this.currentResolve = null;
+        this.currentReject = null;
+        this._enabled = undefined;
+        this._out?.close();
+        this._err?.close();
+        this._out = null;
+        this._err = null;
+        this._daemonStatus = DaemonStatus.DISCONNECTED;
+        this._waitForDaemonReady = new Promise((resolve) => (this._daemonReady = resolve));
+    }
+    async requestShutdown() {
+        return this.sendToDaemonViaQueue({ type: 'REQUEST_SHUTDOWN' });
+    }
+    async getProjectGraphAndSourceMaps() {
+        const response = await this.sendToDaemonViaQueue({
+            type: 'REQUEST_PROJECT_GRAPH',
+        });
+        return {
+            projectGraph: response.projectGraph,
+            sourceMaps: response.sourceMaps,
+        };
+    }
+    async getAllFileData() {
+        return await this.sendToDaemonViaQueue({ type: 'REQUEST_FILE_DATA' });
+    }
+    hashTasks(runnerOptions, tasks, taskGraph, env) {
+        return this.sendToDaemonViaQueue({
+            type: 'HASH_TASKS',
+            runnerOptions,
+            env,
+            tasks,
+            taskGraph,
+        });
+    }
+    async registerFileWatcher(config, callback) {
+        await this.getProjectGraphAndSourceMaps();
+        let messenger;
+        await this.queue.sendToQueue(() => {
+            messenger = new daemon_socket_messenger_1.DaemonSocketMessenger((0, net_1.connect)(socket_utils_1.FULL_OS_SOCKET_PATH)).listen((message) => {
+                try {
+                    const parsedMessage = JSON.parse(message);
+                    callback(null, parsedMessage);
+                }
+                catch (e) {
+                    callback(e, null);
+                }
+            }, () => {
+                callback('closed', null);
+            }, (err) => callback(err, null));
+            return messenger.sendMessage({ type: 'REGISTER_FILE_WATCHER', config });
+        });
+        return () => {
+            messenger?.close();
+        };
+    }
+    processInBackground(requirePath, data) {
+        return this.sendToDaemonViaQueue({
+            type: 'PROCESS_IN_BACKGROUND',
+            requirePath,
+            data,
+        });
+    }
+    recordOutputsHash(outputs, hash) {
+        return this.sendToDaemonViaQueue({
+            type: 'RECORD_OUTPUTS_HASH',
+            data: {
+                outputs,
+                hash,
+            },
+        });
+    }
+    outputsHashesMatch(outputs, hash) {
+        return this.sendToDaemonViaQueue({
+            type: 'OUTPUTS_HASHES_MATCH',
+            data: {
+                outputs,
+                hash,
+            },
+        });
+    }
+    async isServerAvailable() {
+        return new Promise((resolve) => {
+            try {
+                const socket = (0, net_1.connect)(socket_utils_1.FULL_OS_SOCKET_PATH, () => {
+                    socket.destroy();
+                    resolve(true);
+                });
+                socket.once('error', () => {
+                    resolve(false);
+                });
+            }
+            catch (err) {
+                resolve(false);
+            }
+        });
+    }
+    async sendToDaemonViaQueue(messageToDaemon) {
+        return this.queue.sendToQueue(() => this.sendMessageToDaemon(messageToDaemon));
+    }
+    setUpConnection() {
+        this.socketMessenger = new daemon_socket_messenger_1.DaemonSocketMessenger((0, net_1.connect)(socket_utils_1.FULL_OS_SOCKET_PATH)).listen((message) => this.handleMessage(message), () => {
+            // it's ok for the daemon to terminate if the client doesn't wait on
+            // any messages from the daemon
+            if (this.queue.isEmpty()) {
+                this.reset();
+            }
+            else {
+                output_1.output.error({
+                    title: 'Daemon process terminated and closed the connection',
+                    bodyLines: [
+                        'Please rerun the command, which will restart the daemon.',
+                        `If you get this error again, check for any errors in the daemon process logs found in: ${tmp_dir_1.DAEMON_OUTPUT_LOG_FILE}`,
+                    ],
+                });
+                this._daemonStatus = DaemonStatus.DISCONNECTED;
+                this.currentReject?.(daemonProcessException('Daemon process terminated and closed the connection'));
+                process.exit(1);
+            }
+        }, (err) => {
+            if (!err.message) {
+                return this.currentReject(daemonProcessException(err.toString()));
+            }
+            if (err.message.startsWith('LOCK-FILES-CHANGED')) {
+                // retry the current message
+                // we cannot send it via the queue because we are in the middle of processing
+                // a message from the queue
+                return this.sendMessageToDaemon(this.currentMessage).then(this.currentResolve, this.currentReject);
+            }
+            let error;
+            if (err.message.startsWith('connect ENOENT')) {
+                error = daemonProcessException('The Daemon Server is not running');
+            }
+            else if (err.message.startsWith('connect ECONNREFUSED')) {
+                error = daemonProcessException(`A server instance had not been fully shut down. Please try running the command again.`);
+                (0, socket_utils_1.killSocketOrPath)();
+            }
+            else if (err.message.startsWith('read ECONNRESET')) {
+                error = daemonProcessException(`Unable to connect to the daemon process.`);
+            }
+            else {
+                error = daemonProcessException(err.toString());
+            }
+            return this.currentReject(error);
+        });
+    }
+    async sendMessageToDaemon(message) {
+        if (this._daemonStatus == DaemonStatus.DISCONNECTED) {
+            this._daemonStatus = DaemonStatus.CONNECTING;
+            if (!(await this.isServerAvailable())) {
+                await this.startInBackground();
+            }
+            this.setUpConnection();
+            this._daemonStatus = DaemonStatus.CONNECTED;
+            this._daemonReady();
+        }
+        else if (this._daemonStatus == DaemonStatus.CONNECTING) {
+            await this._waitForDaemonReady;
+        }
+        return new Promise((resolve, reject) => {
+            perf_hooks_1.performance.mark('sendMessageToDaemon-start');
+            this.currentMessage = message;
+            this.currentResolve = resolve;
+            this.currentReject = reject;
+            this.socketMessenger.sendMessage(message);
+        });
+    }
+    handleMessage(serializedResult) {
+        try {
+            perf_hooks_1.performance.mark('json-parse-start');
+            const parsedResult = JSON.parse(serializedResult);
+            perf_hooks_1.performance.mark('json-parse-end');
+            perf_hooks_1.performance.measure('deserialize daemon response', 'json-parse-start', 'json-parse-end');
+            if (parsedResult.error) {
+                this.currentReject(parsedResult.error);
+            }
+            else {
+                perf_hooks_1.performance.measure('total for sendMessageToDaemon()', 'sendMessageToDaemon-start', 'json-parse-end');
+                return this.currentResolve(parsedResult);
+            }
+        }
+        catch (e) {
+            const endOfResponse = serializedResult.length > 300
+                ? serializedResult.substring(serializedResult.length - 300)
+                : serializedResult;
+            this.currentReject(daemonProcessException([
+                'Could not deserialize response from Nx daemon.',
+                `Message: ${e.message}`,
+                '\n',
+                `Received:`,
+                endOfResponse,
+                '\n',
+            ].join('\n')));
+        }
+    }
+    async startInBackground() {
+        (0, fs_extra_1.ensureDirSync)(tmp_dir_1.DAEMON_DIR_FOR_CURRENT_WORKSPACE);
+        (0, fs_extra_1.ensureFileSync)(tmp_dir_1.DAEMON_OUTPUT_LOG_FILE);
+        this._out = await (0, promises_1.open)(tmp_dir_1.DAEMON_OUTPUT_LOG_FILE, 'a');
+        this._err = await (0, promises_1.open)(tmp_dir_1.DAEMON_OUTPUT_LOG_FILE, 'a');
+        const backgroundProcess = (0, child_process_1.spawn)(process.execPath, [(0, path_1.join)(__dirname, '../server/start.js')], {
+            cwd: workspace_root_1.workspaceRoot,
+            stdio: ['ignore', this._out.fd, this._err.fd],
+            detached: true,
+            windowsHide: true,
+            shell: false,
+            env: DAEMON_ENV_SETTINGS,
+        });
+        backgroundProcess.unref();
+        /**
+         * Ensure the server is actually available to connect to via IPC before resolving
+         */
+        let attempts = 0;
+        return new Promise((resolve, reject) => {
+            const id = setInterval(async () => {
+                if (await this.isServerAvailable()) {
+                    clearInterval(id);
+                    resolve(backgroundProcess.pid);
+                }
+                else if (attempts > 6000) {
+                    // daemon fails to start, the process probably exited
+                    // we print the logs and exit the client
+                    reject(daemonProcessException('Failed to start or connect to the Nx Daemon process.'));
+                }
+                else {
+                    attempts++;
+                }
+            }, 10);
+        });
+    }
+    async stop() {
+        try {
+            await (0, cache_1.safelyCleanUpExistingProcess)();
+        }
+        catch (err) {
+            output_1.output.error({
+                title: err?.message ||
+                    'Something unexpected went wrong when stopping the server',
+            });
+        }
+        (0, tmp_dir_1.removeSocketDir)();
+    }
+}
+exports.DaemonClient = DaemonClient;
+exports.daemonClient = new DaemonClient((0, configuration_1.readNxJson)());
+function isDocker() {
+    try {
+        (0, fs_1.statSync)('/.dockerenv');
+        return true;
+    }
+    catch {
+        try {
+            return (0, fs_1.readFileSync)('/proc/self/cgroup', 'utf8')?.includes('docker');
+        }
+        catch { }
+        return false;
+    }
+}
+function nxJsonIsNotPresent() {
+    return !(0, nx_json_1.hasNxJson)(workspace_root_1.workspaceRoot);
+}
+function daemonProcessException(message) {
+    try {
+        let log = (0, fs_1.readFileSync)(tmp_dir_1.DAEMON_OUTPUT_LOG_FILE).toString().split('\n');
+        if (log.length > 20) {
+            log = log.slice(log.length - 20);
+        }
+        const error = new Error([
+            message,
+            '',
+            'Messages from the log:',
+            ...log,
+            '\n',
+            `More information: ${tmp_dir_1.DAEMON_OUTPUT_LOG_FILE}`,
+        ].join('\n'));
+        error.internalDaemonError = true;
+        return error;
+    }
+    catch (e) {
+        return new Error(message);
+    }
+}
+
+
+/***/ }),
+
+/***/ 30386:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
+
+"use strict";
+
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.DaemonSocketMessenger = void 0;
+const consume_messages_from_socket_1 = __nccwpck_require__(22214);
+class DaemonSocketMessenger {
+    constructor(socket) {
+        this.socket = socket;
+    }
+    async sendMessage(messageToDaemon) {
+        this.socket.write(JSON.stringify(messageToDaemon));
+        // send EOT to indicate that the message has been fully written
+        this.socket.write(String.fromCodePoint(4));
+    }
+    listen(onData, onClose = () => { }, onError = (err) => { }) {
+        this.socket.on('data', (0, consume_messages_from_socket_1.consumeMessagesFromSocket)(async (message) => {
+            onData(message);
+        }));
+        this.socket.on('close', onClose);
+        this.socket.on('error', onError);
+        return this;
+    }
+    close() {
+        this.socket.destroy();
+    }
+}
+exports.DaemonSocketMessenger = DaemonSocketMessenger;
+
+
+/***/ }),
+
+/***/ 10023:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
+
+"use strict";
+
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.serializeResult = exports.killSocketOrPath = exports.FORKED_PROCESS_OS_SOCKET_PATH = exports.FULL_OS_SOCKET_PATH = exports.isWindows = void 0;
+const fs_1 = __nccwpck_require__(57147);
+const os_1 = __nccwpck_require__(22037);
+const path_1 = __nccwpck_require__(71017);
+const tmp_dir_1 = __nccwpck_require__(78543);
+exports.isWindows = (0, os_1.platform)() === 'win32';
+/**
+ * For IPC with the daemon server we use unix sockets or windows named pipes, depending on the user's operating system.
+ *
+ * See https://nodejs.org/dist/latest-v14.x/docs/api/net.html#net_identifying_paths_for_ipc_connections for a full breakdown
+ * of OS differences between Unix domain sockets and named pipes.
+ */
+exports.FULL_OS_SOCKET_PATH = exports.isWindows
+    ? '\\\\.\\pipe\\nx\\' + (0, path_1.resolve)(tmp_dir_1.DAEMON_SOCKET_PATH)
+    : (0, path_1.resolve)(tmp_dir_1.DAEMON_SOCKET_PATH);
+const FORKED_PROCESS_OS_SOCKET_PATH = (id) => {
+    let path = (0, path_1.resolve)((0, path_1.join)(tmp_dir_1.socketDir, 'fp' + id + '.sock'));
+    return exports.isWindows ? '\\\\.\\pipe\\nx\\' + (0, path_1.resolve)(path) : (0, path_1.resolve)(path);
+};
+exports.FORKED_PROCESS_OS_SOCKET_PATH = FORKED_PROCESS_OS_SOCKET_PATH;
+function killSocketOrPath() {
+    try {
+        (0, fs_1.unlinkSync)(exports.FULL_OS_SOCKET_PATH);
+    }
+    catch { }
+}
+exports.killSocketOrPath = killSocketOrPath;
+// Include the original stack trace within the serialized error so that the client can show it to the user.
+function serializeError(error) {
+    if (!error) {
+        return null;
+    }
+    return JSON.stringify(error, Object.getOwnPropertyNames(error));
+}
+// Prepare a serialized project graph result for sending over IPC from the server to the client
+function serializeResult(error, serializedProjectGraph, serializedSourceMaps) {
+    // We do not want to repeat work `JSON.stringify`ing an object containing the potentially large project graph so merge as strings
+    return `{ "error": ${serializeError(error)}, "projectGraph": ${serializedProjectGraph}, "sourceMaps": ${serializedSourceMaps} }`;
+}
+exports.serializeResult = serializeResult;
+
+
+/***/ }),
+
+/***/ 78543:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
+
+"use strict";
+
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.removeSocketDir = exports.isDaemonDisabled = exports.markDaemonAsDisabled = exports.writeDaemonLogs = exports.DAEMON_SOCKET_PATH = exports.socketDir = exports.DAEMON_OUTPUT_LOG_FILE = exports.DAEMON_DIR_FOR_CURRENT_WORKSPACE = void 0;
+/**
+ * Per workspace (to avoid subtle differences and issues), we want to have a deterministic
+ * location within the OS's tmp directory where we write log files for background processes
+ * and where we create the actual unix socket/named pipe for the daemon.
+ */
+const fs_1 = __nccwpck_require__(57147);
+const fs_extra_1 = __nccwpck_require__(27475);
+const path_1 = __nccwpck_require__(71017);
+const cache_directory_1 = __nccwpck_require__(15120);
+const crypto_1 = __nccwpck_require__(6113);
+const tmp_1 = __nccwpck_require__(81866);
+const workspace_root_1 = __nccwpck_require__(86708);
+exports.DAEMON_DIR_FOR_CURRENT_WORKSPACE = (0, path_1.join)(cache_directory_1.projectGraphCacheDirectory, 'd');
+exports.DAEMON_OUTPUT_LOG_FILE = (0, path_1.join)(exports.DAEMON_DIR_FOR_CURRENT_WORKSPACE, 'daemon.log');
+exports.socketDir = process.env.NX_DAEMON_SOCKET_DIR || createSocketDir();
+exports.DAEMON_SOCKET_PATH = (0, path_1.join)(exports.socketDir, 
+// As per notes above on socket/named pipe length limitations, we keep this intentionally short
+'d.sock');
+function writeDaemonLogs(error) {
+    const file = (0, path_1.join)(exports.DAEMON_DIR_FOR_CURRENT_WORKSPACE, 'daemon-error.log');
+    (0, fs_1.writeFileSync)(file, error);
+    return file;
+}
+exports.writeDaemonLogs = writeDaemonLogs;
+function markDaemonAsDisabled() {
+    (0, fs_1.writeFileSync)((0, path_1.join)(exports.DAEMON_DIR_FOR_CURRENT_WORKSPACE, 'disabled'), 'true');
+}
+exports.markDaemonAsDisabled = markDaemonAsDisabled;
+function isDaemonDisabled() {
+    try {
+        (0, fs_1.statSync)((0, path_1.join)(exports.DAEMON_DIR_FOR_CURRENT_WORKSPACE, 'disabled'));
+        return true;
+    }
+    catch (e) {
+        return false;
+    }
+}
+exports.isDaemonDisabled = isDaemonDisabled;
+function socketDirName() {
+    const hasher = (0, crypto_1.createHash)('sha256');
+    hasher.update(workspace_root_1.workspaceRoot.toLowerCase());
+    const unique = hasher.digest('hex').substring(0, 20);
+    return (0, path_1.join)(tmp_1.tmpdir, unique);
+}
+/**
+ * We try to create a socket file in a tmp dir, but if it doesn't work because
+ * for instance we don't have permissions, we create it in DAEMON_DIR_FOR_CURRENT_WORKSPACE
+ */
+function createSocketDir() {
+    try {
+        const dir = socketDirName();
+        (0, fs_extra_1.ensureDirSync)(dir);
+        return dir;
+    }
+    catch (e) {
+        return exports.DAEMON_DIR_FOR_CURRENT_WORKSPACE;
+    }
+}
+function removeSocketDir() {
+    try {
+        (0, fs_extra_1.rmSync)(exports.socketDir, { recursive: true, force: true });
+    }
+    catch (e) { }
+}
+exports.removeSocketDir = removeSocketDir;
+
+
+/***/ }),
+
+/***/ 11385:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
+
+"use strict";
+
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.printChanges = exports.flushChanges = exports.FsTree = void 0;
+const fs_extra_1 = __nccwpck_require__(27475);
+const logger_1 = __nccwpck_require__(39299);
+const output_1 = __nccwpck_require__(1737);
+const path_1 = __nccwpck_require__(71017);
+const chalk = __nccwpck_require__(36662);
+class FsTree {
+    constructor(root, isVerbose, logOperationId) {
+        this.root = root;
+        this.isVerbose = isVerbose;
+        this.logOperationId = logOperationId;
+        this.recordedChanges = {};
+        /**
+         * Signifies if operations on the tree instance
+         * are allowed. Set to false after changes are written
+         * to disk, to prevent someone trying to use the tree to update
+         * files when the tree is no longer effective.
+         */
+        this.locked = false;
+    }
+    read(filePath, encoding) {
+        filePath = this.normalize(filePath);
+        try {
+            let content;
+            if (this.recordedChanges[this.rp(filePath)]) {
+                content = this.recordedChanges[this.rp(filePath)].content;
+            }
+            else {
+                content = this.fsReadFile(filePath);
+            }
+            return encoding ? content.toString(encoding) : content;
+        }
+        catch (e) {
+            if (this.isVerbose) {
+                logger_1.logger.error(e);
+            }
+            return null;
+        }
+    }
+    write(filePath, content, options) {
+        this.assertUnlocked();
+        filePath = this.normalize(filePath);
+        // Remove any recorded changes where a parent directory has been
+        // deleted when writing a new file within the directory.
+        let parent = (0, path_1.dirname)(this.rp(filePath));
+        while (parent !== '.') {
+            if (this.recordedChanges[parent]?.isDeleted) {
+                delete this.recordedChanges[parent];
+            }
+            parent = (0, path_1.dirname)(parent);
+        }
+        if (this.fsExists(this.rp(filePath)) &&
+            Buffer.from(content).equals(this.fsReadFile(filePath))) {
+            // Remove recorded change because the file has been restored to it's original contents
+            delete this.recordedChanges[this.rp(filePath)];
+            return;
+        }
+        try {
+            this.recordedChanges[this.rp(filePath)] = {
+                content: Buffer.from(content),
+                isDeleted: false,
+                options,
+            };
+        }
+        catch (e) {
+            if (this.isVerbose) {
+                logger_1.logger.error(e);
+            }
+        }
+    }
+    overwrite(filePath, content, options) {
+        filePath = this.normalize(filePath);
+        this.write(filePath, content, options);
+    }
+    delete(filePath) {
+        this.assertUnlocked();
+        filePath = this.normalize(filePath);
+        if (this.filesForDir(this.rp(filePath)).length > 0) {
+            this.filesForDir(this.rp(filePath)).forEach((f) => (this.recordedChanges[f] = { content: null, isDeleted: true }));
+        }
+        this.recordedChanges[this.rp(filePath)] = {
+            content: null,
+            isDeleted: true,
+        };
+        // Delete directory when is not root and there are no children
+        if (filePath !== '' &&
+            this.children((0, path_1.dirname)(this.rp(filePath))).length < 1) {
+            this.delete((0, path_1.dirname)(this.rp(filePath)));
+        }
+    }
+    exists(filePath) {
+        filePath = this.normalize(filePath);
+        try {
+            if (this.recordedChanges[this.rp(filePath)]) {
+                return !this.recordedChanges[this.rp(filePath)].isDeleted;
+            }
+            else if (this.filesForDir(this.rp(filePath)).length > 0) {
+                return true;
+            }
+            else {
+                return this.fsExists(filePath);
+            }
+        }
+        catch {
+            return false;
+        }
+    }
+    rename(from, to) {
+        this.assertUnlocked();
+        from = this.normalize(from);
+        to = this.normalize(to);
+        if (from === to) {
+            return;
+        }
+        if (this.isFile(from)) {
+            const content = this.read(this.rp(from));
+            this.write(this.rp(to), content);
+            this.delete(this.rp(from));
+        }
+        else {
+            for (const child of this.children(from)) {
+                this.rename((0, path_1.join)(from, child), (0, path_1.join)(to, child));
+            }
+        }
+    }
+    isFile(filePath) {
+        filePath = this.normalize(filePath);
+        try {
+            if (this.recordedChanges[this.rp(filePath)]) {
+                return !this.recordedChanges[this.rp(filePath)].isDeleted;
+            }
+            else {
+                return this.fsIsFile(filePath);
+            }
+        }
+        catch {
+            return false;
+        }
+    }
+    children(dirPath) {
+        dirPath = this.normalize(dirPath);
+        let res = this.fsReadDir(dirPath);
+        res = [...res, ...this.directChildrenOfDir(this.rp(dirPath))];
+        res = res.filter((q) => {
+            const r = this.recordedChanges[this.normalize((0, path_1.join)(this.rp(dirPath), q))];
+            return !r?.isDeleted;
+        });
+        // Dedupe
+        return Array.from(new Set(res));
+    }
+    listChanges() {
+        const res = [];
+        Object.keys(this.recordedChanges).forEach((f) => {
+            if (this.recordedChanges[f].isDeleted) {
+                if (this.fsExists(f)) {
+                    res.push({ path: f, type: 'DELETE', content: null });
+                }
+            }
+            else {
+                if (this.fsExists(f)) {
+                    res.push({
+                        path: f,
+                        type: 'UPDATE',
+                        content: this.recordedChanges[f].content,
+                        options: this.recordedChanges[f].options,
+                    });
+                }
+                else {
+                    res.push({
+                        path: f,
+                        type: 'CREATE',
+                        content: this.recordedChanges[f].content,
+                        options: this.recordedChanges[f].options,
+                    });
+                }
+            }
+        });
+        return res;
+    }
+    changePermissions(filePath, mode) {
+        this.assertUnlocked();
+        filePath = this.normalize(filePath);
+        const filePathChangeKey = this.rp(filePath);
+        if (this.recordedChanges[filePathChangeKey]) {
+            if (this.recordedChanges[filePathChangeKey].isDeleted) {
+                throw new Error(`Cannot change permissions of deleted file ${filePath}.`);
+            }
+            this.recordedChanges[filePathChangeKey].options = { mode };
+        }
+        else if (!this.fsExists(filePath)) {
+            throw new Error(`Cannot change permissions of non-existing file ${filePath}.`);
+        }
+        else if (!this.fsIsFile(filePath)) {
+            // To fully support directories we'd need to change how we store
+            // changes to keep a record of directories so we can associate
+            // permissions to them.
+            throw new Error(`Cannot change permissions of non-file ${filePath}.`);
+        }
+        else {
+            this.recordedChanges[filePathChangeKey] = {
+                content: this.fsReadFile(filePath),
+                isDeleted: false,
+                options: { mode },
+            };
+        }
+    }
+    // Marks FsTree as final.
+    lock() {
+        this.locked = true;
+    }
+    assertUnlocked() {
+        if (this.locked) {
+            output_1.output.error({
+                title: `File changes have already been written to disk. Further changes were attempted ${this.logOperationId ? ` while running ${this.logOperationId}.` : '.'}`,
+                bodyLines: [
+                    'The file system can no longer be modified. This commonly happens when a generator attempts to make further changes in its callback, or an asynchronous operation is still running after the generator completes.',
+                ],
+            });
+            throw new Error('Tree changed after commit to disk.');
+        }
+    }
+    normalize(path) {
+        return (0, path_1.relative)(this.root, (0, path_1.join)(this.root, path)).split(path_1.sep).join('/');
+    }
+    fsReadDir(dirPath) {
+        try {
+            return (0, fs_extra_1.readdirSync)((0, path_1.join)(this.root, dirPath));
+        }
+        catch {
+            return [];
+        }
+    }
+    fsIsFile(filePath) {
+        const stat = (0, fs_extra_1.statSync)((0, path_1.join)(this.root, filePath));
+        return stat.isFile();
+    }
+    fsReadFile(filePath) {
+        return (0, fs_extra_1.readFileSync)((0, path_1.join)(this.root, filePath));
+    }
+    fsExists(filePath) {
+        try {
+            const stat = (0, fs_extra_1.statSync)((0, path_1.join)(this.root, filePath));
+            return stat.isFile() || stat.isDirectory();
+        }
+        catch {
+            return false;
+        }
+    }
+    filesForDir(path) {
+        return Object.keys(this.recordedChanges).filter((f) => f.startsWith(`${path}/`) && !this.recordedChanges[f].isDeleted);
+    }
+    directChildrenOfDir(path) {
+        const res = {};
+        if (path === '') {
+            return Object.keys(this.recordedChanges).map((file) => file.split('/')[0]);
+        }
+        Object.keys(this.recordedChanges).forEach((f) => {
+            if (f.startsWith(`${path}/`)) {
+                // Remove the current folder's path from the directory
+                const file = f.substring(path.length + 1);
+                // Split the path on segments, and take the first one
+                const basePath = file.split('/')[0];
+                // Mark it as a child of the current directory
+                res[basePath] = true;
+            }
+        });
+        return Object.keys(res);
+    }
+    rp(pp) {
+        return pp.startsWith('/') ? pp.substring(1) : pp;
+    }
+}
+exports.FsTree = FsTree;
+function flushChanges(root, fileChanges) {
+    fileChanges.forEach((f) => {
+        const fpath = (0, path_1.join)(root, f.path);
+        if (f.type === 'CREATE') {
+            (0, fs_extra_1.ensureDirSync)((0, path_1.dirname)(fpath));
+            (0, fs_extra_1.writeFileSync)(fpath, f.content);
+            if (f.options?.mode)
+                (0, fs_extra_1.chmodSync)(fpath, f.options.mode);
+        }
+        else if (f.type === 'UPDATE') {
+            (0, fs_extra_1.writeFileSync)(fpath, f.content);
+            if (f.options?.mode)
+                (0, fs_extra_1.chmodSync)(fpath, f.options.mode);
+        }
+        else if (f.type === 'DELETE') {
+            (0, fs_extra_1.removeSync)(fpath);
+        }
+    });
+}
+exports.flushChanges = flushChanges;
+function printChanges(fileChanges, indent = '') {
+    fileChanges.forEach((f) => {
+        if (f.type === 'CREATE') {
+            console.log(`${indent}${chalk.green('CREATE')} ${f.path}`);
+        }
+        else if (f.type === 'UPDATE') {
+            console.log(`${indent}${chalk.white('UPDATE')} ${f.path}`);
+        }
+        else if (f.type === 'DELETE') {
+            console.log(`${indent}${chalk.yellow('DELETE')} ${f.path}`);
+        }
+    });
+}
+exports.printChanges = printChanges;
+
+
+/***/ }),
+
+/***/ 29855:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
+
+"use strict";
+
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.updateJson = exports.writeJson = exports.readJson = void 0;
+const json_1 = __nccwpck_require__(8314);
+/**
+ * Reads a json file, removes all comments and parses JSON.
+ *
+ * @param tree - file system tree
+ * @param path - file path
+ * @param options - Optional JSON Parse Options
+ */
+function readJson(tree, path, options) {
+    if (!tree.exists(path)) {
+        throw new Error(`Cannot find ${path}`);
+    }
+    try {
+        return (0, json_1.parseJson)(tree.read(path, 'utf-8'), options);
+    }
+    catch (e) {
+        throw new Error(`Cannot parse ${path}: ${e.message}`);
+    }
+}
+exports.readJson = readJson;
+/**
+ * Writes a JSON value to the file system tree
+
+ * @param tree File system tree
+ * @param path Path of JSON file in the Tree
+ * @param value Serializable value to write
+ * @param options Optional JSON Serialize Options
+ */
+function writeJson(tree, path, value, options) {
+    tree.write(path, (0, json_1.serializeJson)(value, options));
+}
+exports.writeJson = writeJson;
+/**
+ * Updates a JSON value to the file system tree
+ *
+ * @param tree File system tree
+ * @param path Path of JSON file in the Tree
+ * @param updater Function that maps the current value of a JSON document to a new value to be written to the document
+ * @param options Optional JSON Parse and Serialize Options
+ */
+function updateJson(tree, path, updater, options) {
+    const updatedValue = updater(readJson(tree, path, options));
+    writeJson(tree, path, updatedValue, options);
+}
+exports.updateJson = updateJson;
+
+
+/***/ }),
+
+/***/ 82938:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
+
+"use strict";
+
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.updateNxJson = exports.readNxJson = void 0;
+const path_1 = __nccwpck_require__(71017);
+const json_1 = __nccwpck_require__(29855);
+const nx_json_1 = __nccwpck_require__(53619);
+/**
+ * Reads nx.json
+ */
+function readNxJson(tree) {
+    if (tree) {
+        if (!tree.exists('nx.json')) {
+            return null;
+        }
+        let nxJson = (0, json_1.readJson)(tree, 'nx.json');
+        if (nxJson.extends) {
+            nxJson = { ...readNxJsonExtends(tree, nxJson.extends), ...nxJson };
+        }
+        return nxJson;
+    }
+    else {
+        return (0, nx_json_1.readNxJson)();
+    }
+}
+exports.readNxJson = readNxJson;
+/**
+ * Update nx.json
+ */
+function updateNxJson(tree, nxJson) {
+    if (tree.exists('nx.json')) {
+        (0, json_1.updateJson)(tree, 'nx.json', (json) => {
+            if (json.extends) {
+                const nxJsonExtends = readNxJsonExtends(tree, json.extends);
+                const changedPropsOfNxJson = {};
+                Object.keys(nxJson).forEach((prop) => {
+                    if (JSON.stringify(nxJson[prop], null, 2) !=
+                        JSON.stringify(nxJsonExtends[prop], null, 2)) {
+                        changedPropsOfNxJson[prop] = nxJson[prop];
+                    }
+                });
+                return changedPropsOfNxJson;
+            }
+            else {
+                return nxJson;
+            }
+        });
+    }
+}
+exports.updateNxJson = updateNxJson;
+function readNxJsonExtends(tree, extendsPath) {
+    try {
+        return (0, json_1.readJson)(tree, (0, path_1.relative)(tree.root, require.resolve(extendsPath, {
+            paths: [tree.root],
+        })));
+    }
+    catch (e) {
+        throw new Error(`Unable to resolve nx.json extends. Error: ${e.message}`);
+    }
+}
+
+
+/***/ }),
+
+/***/ 1934:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
+
+"use strict";
+
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.getRelativeProjectJsonSchemaPath = exports.getProjects = exports.readProjectConfiguration = exports.removeProjectConfiguration = exports.updateProjectConfiguration = exports.addProjectConfiguration = exports.updateNxJson = exports.readNxJson = void 0;
+const minimatch_1 = __nccwpck_require__(55224);
+const path_1 = __nccwpck_require__(71017);
+const package_json_workspaces_1 = __nccwpck_require__(65286);
+const project_json_1 = __nccwpck_require__(76877);
+const angular_json_1 = __nccwpck_require__(44050);
+const project_configuration_utils_1 = __nccwpck_require__(33190);
+const retrieve_workspace_files_1 = __nccwpck_require__(14249);
+const workspace_context_1 = __nccwpck_require__(302);
+const output_1 = __nccwpck_require__(1737);
+const path_2 = __nccwpck_require__(38270);
+const json_1 = __nccwpck_require__(29855);
+const nx_json_1 = __nccwpck_require__(82938);
+var nx_json_2 = __nccwpck_require__(82938);
+Object.defineProperty(exports, "readNxJson", ({ enumerable: true, get: function () { return nx_json_2.readNxJson; } }));
+Object.defineProperty(exports, "updateNxJson", ({ enumerable: true, get: function () { return nx_json_2.updateNxJson; } }));
+/**
+ * Adds project configuration to the Nx workspace.
+ *
+ * @param tree - the file system tree
+ * @param projectName - unique name. Often directories are part of the name (e.g., mydir-mylib)
+ * @param projectConfiguration - project configuration
+ * @param standalone - whether the project is configured in workspace.json or not
+ */
+function addProjectConfiguration(tree, projectName, projectConfiguration, standalone = true) {
+    const projectConfigFile = (0, path_2.joinPathFragments)(projectConfiguration.root, 'project.json');
+    if (!standalone) {
+        output_1.output.warn({
+            title: 'Nx only supports standalone projects. Setting standalone to false is ignored.',
+        });
+    }
+    if (tree.exists(projectConfigFile)) {
+        throw new Error(`Cannot create a new project ${projectName} at ${projectConfiguration.root}. A project already exists in this directory.`);
+    }
+    delete projectConfiguration.$schema;
+    (0, json_1.writeJson)(tree, projectConfigFile, {
+        name: projectName,
+        $schema: getRelativeProjectJsonSchemaPath(tree, projectConfiguration),
+        ...projectConfiguration,
+        root: undefined,
+    });
+}
+exports.addProjectConfiguration = addProjectConfiguration;
+/**
+ * Updates the configuration of an existing project.
+ *
+ * @param tree - the file system tree
+ * @param projectName - unique name. Often directories are part of the name (e.g., mydir-mylib)
+ * @param projectConfiguration - project configuration
+ */
+function updateProjectConfiguration(tree, projectName, projectConfiguration) {
+    const projectConfigFile = (0, path_2.joinPathFragments)(projectConfiguration.root, 'project.json');
+    if (!tree.exists(projectConfigFile)) {
+        throw new Error(`Cannot update Project ${projectName} at ${projectConfiguration.root}. It either doesn't exist yet, or may not use project.json for configuration. Use \`addProjectConfiguration()\` instead if you want to create a new project.`);
+    }
+    (0, json_1.writeJson)(tree, projectConfigFile, {
+        name: projectConfiguration.name ?? projectName,
+        $schema: getRelativeProjectJsonSchemaPath(tree, projectConfiguration),
+        ...projectConfiguration,
+        root: undefined,
+    });
+}
+exports.updateProjectConfiguration = updateProjectConfiguration;
+/**
+ * Removes the configuration of an existing project.
+ *
+ * @param tree - the file system tree
+ * @param projectName - unique name. Often directories are part of the name (e.g., mydir-mylib)
+ */
+function removeProjectConfiguration(tree, projectName) {
+    const projectConfiguration = readProjectConfiguration(tree, projectName);
+    if (!projectConfiguration) {
+        throw new Error(`Cannot delete Project ${projectName}`);
+    }
+    const projectConfigFile = (0, path_2.joinPathFragments)(projectConfiguration.root, 'project.json');
+    if (tree.exists(projectConfigFile)) {
+        tree.delete(projectConfigFile);
+    }
+}
+exports.removeProjectConfiguration = removeProjectConfiguration;
+/**
+ * Reads a project configuration.
+ *
+ * @param tree - the file system tree
+ * @param projectName - unique name. Often directories are part of the name (e.g., mydir-mylib)
+ * @throws If supplied projectName cannot be found
+ */
+function readProjectConfiguration(tree, projectName) {
+    const allProjects = readAndCombineAllProjectConfigurations(tree);
+    if (!allProjects[projectName]) {
+        // temporary polyfill to make sure our generators work for existing angularcli workspaces
+        if (tree.exists('angular.json')) {
+            const angularJson = toNewFormat((0, json_1.readJson)(tree, 'angular.json'));
+            if (angularJson.projects[projectName])
+                return angularJson.projects[projectName];
+        }
+        throw new Error(`Cannot find configuration for '${projectName}'`);
+    }
+    return allProjects[projectName];
+}
+exports.readProjectConfiguration = readProjectConfiguration;
+/**
+ * Get a map of all projects in a workspace.
+ *
+ * Use {@link readProjectConfiguration} if only one project is needed.
+ */
+function getProjects(tree) {
+    let allProjects = readAndCombineAllProjectConfigurations(tree);
+    // temporary polyfill to make sure our generators work for existing angularcli workspaces
+    if (tree.exists('angular.json')) {
+        const angularJson = toNewFormat((0, json_1.readJson)(tree, 'angular.json'));
+        allProjects = { ...allProjects, ...angularJson.projects };
+    }
+    return new Map(Object.keys(allProjects || {}).map((projectName) => {
+        return [projectName, allProjects[projectName]];
+    }));
+}
+exports.getProjects = getProjects;
+function getRelativeProjectJsonSchemaPath(tree, project) {
+    return (0, path_2.normalizePath)((0, path_1.relative)((0, path_1.join)(tree.root, project.root), (0, path_1.join)(tree.root, 'node_modules/nx/schemas/project-schema.json')));
+}
+exports.getRelativeProjectJsonSchemaPath = getRelativeProjectJsonSchemaPath;
+function readAndCombineAllProjectConfigurations(tree) {
+    /**
+     * We can't update projects that come from plugins anyways, so we are going
+     * to ignore them for now. Plugins should add their own add/create/update methods
+     * if they would like to use devkit to update inferred projects.
+     */
+    const patterns = [
+        '**/project.json',
+        'project.json',
+        ...(0, package_json_workspaces_1.getGlobPatternsFromPackageManagerWorkspaces)(tree.root, (p) => (0, json_1.readJson)(tree, p)),
+    ];
+    const projectGlobPatterns = (0, retrieve_workspace_files_1.configurationGlobs)([
+        { plugin: project_json_1.ProjectJsonProjectsPlugin },
+        { plugin: (0, package_json_workspaces_1.getNxPackageJsonWorkspacesPlugin)(tree.root) },
+    ]);
+    const globbedFiles = (0, workspace_context_1.globWithWorkspaceContext)(tree.root, projectGlobPatterns);
+    const createdFiles = findCreatedProjectFiles(tree, patterns);
+    const deletedFiles = findDeletedProjectFiles(tree, patterns);
+    const projectFiles = [...globbedFiles, ...createdFiles].filter((r) => deletedFiles.indexOf(r) === -1);
+    const rootMap = new Map();
+    for (const projectFile of projectFiles) {
+        if ((0, path_1.basename)(projectFile) === 'project.json') {
+            const json = (0, json_1.readJson)(tree, projectFile);
+            const config = (0, project_json_1.buildProjectFromProjectJson)(json, projectFile);
+            (0, project_configuration_utils_1.mergeProjectConfigurationIntoRootMap)(rootMap, config, undefined, undefined, true);
+        }
+        else if ((0, path_1.basename)(projectFile) === 'package.json') {
+            const packageJson = (0, json_1.readJson)(tree, projectFile);
+            const config = (0, package_json_workspaces_1.buildProjectConfigurationFromPackageJson)(packageJson, projectFile, (0, nx_json_1.readNxJson)(tree));
+            if (!rootMap.has(config.root)) {
+                (0, project_configuration_utils_1.mergeProjectConfigurationIntoRootMap)(rootMap, 
+                // Inferred targets, tags, etc don't show up when running generators
+                // This is to help avoid running into issues when trying to update the workspace
+                {
+                    name: config.name,
+                    root: config.root,
+                }, undefined, undefined, true);
+            }
+        }
+    }
+    return (0, project_configuration_utils_1.readProjectConfigurationsFromRootMap)(rootMap);
+}
+/**
+ * Used to ensure that projects created during
+ * the same devkit generator run show up when
+ * there is no project.json file, as `glob`
+ * cannot find them.
+ *
+ * We exclude the root `package.json` from this list unless
+ * considered a project during workspace generation
+ */
+function findCreatedProjectFiles(tree, globPatterns) {
+    const createdProjectFiles = [];
+    for (const change of tree.listChanges()) {
+        if (change.type === 'CREATE') {
+            const fileName = (0, path_1.basename)(change.path);
+            if (globPatterns.some((pattern) => (0, minimatch_1.minimatch)(change.path, pattern, { dot: true }))) {
+                createdProjectFiles.push(change.path);
+            }
+            else if (fileName === 'package.json') {
+                try {
+                    const contents = JSON.parse(change.content.toString());
+                    if (contents.nx) {
+                        createdProjectFiles.push(change.path);
+                    }
+                }
+                catch { }
+            }
+        }
+    }
+    return createdProjectFiles.map(path_2.normalizePath);
+}
+/**
+ * Used to ensure that projects created during
+ * the same devkit generator run show up when
+ * there is no project.json file, as `glob`
+ * cannot find them.
+ */
+function findDeletedProjectFiles(tree, globPatterns) {
+    return tree
+        .listChanges()
+        .filter((f) => {
+        return (f.type === 'DELETE' &&
+            globPatterns.some((pattern) => (0, minimatch_1.minimatch)(f.path, pattern)));
+    })
+        .map((r) => r.path);
+}
+function toNewFormat(w) {
+    const projects = {};
+    Object.keys(w.projects || {}).forEach((name) => {
+        if (typeof w.projects[name] === 'string')
+            return;
+        const projectConfig = w.projects[name];
+        if (projectConfig.architect) {
+            (0, angular_json_1.renamePropertyWithStableKeys)(projectConfig, 'architect', 'targets');
+        }
+        if (projectConfig.schematics) {
+            (0, angular_json_1.renamePropertyWithStableKeys)(projectConfig, 'schematics', 'generators');
+        }
+        Object.values(projectConfig.targets || {}).forEach((target) => {
+            if (target.builder !== undefined) {
+                (0, angular_json_1.renamePropertyWithStableKeys)(target, 'builder', 'executor');
+            }
+        });
+        projects[name] = projectConfig;
+    });
+    w.projects = projects;
+    if (w.schematics) {
+        (0, angular_json_1.renamePropertyWithStableKeys)(w, 'schematics', 'generators');
+    }
+    if (w.version !== 2) {
+        w.version = 2;
+    }
+    return w;
+}
+
+
+/***/ }),
+
+/***/ 50180:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
+
+"use strict";
+
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.hashObject = exports.hashArray = void 0;
+function hashArray(content) {
+    // Import as needed. There is also an issue running unit tests in Nx repo if this is a top-level import.
+    const { hashArray } = __nccwpck_require__(74424);
+    return hashArray(content);
+}
+exports.hashArray = hashArray;
+function hashObject(obj) {
+    const { hashArray } = __nccwpck_require__(74424);
+    const parts = [];
+    for (const key of Object.keys(obj).sort()) {
+        parts.push(key);
+        parts.push(JSON.stringify(obj[key]));
+    }
+    return hashArray(parts);
+}
+exports.hashObject = hashObject;
+
+
+/***/ }),
+
+/***/ 74424:
+/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+
+const { existsSync, readFileSync } = __nccwpck_require__(57147)
+const { join } = __nccwpck_require__(71017)
+
+const { platform, arch } = process
+
+let nativeBinding = null
+let localFileExisted = false
+let loadError = null
+
+function isMusl() {
+  // For Node 10
+  if (!process.report || typeof process.report.getReport !== 'function') {
+    try {
+      const lddPath = (__nccwpck_require__(32081).execSync)('which ldd').toString().trim();
+      return readFileSync(lddPath, 'utf8').includes('musl')
+    } catch (e) {
+      return true
+    }
+  } else {
+    const { glibcVersionRuntime } = process.report.getReport().header
+    return !glibcVersionRuntime
+  }
+}
+
+switch (platform) {
+  case 'android':
+    switch (arch) {
+      case 'arm64':
+        localFileExisted = existsSync(join(__dirname, 'nx.android-arm64.node'))
+        try {
+          if (localFileExisted) {
+            nativeBinding = __nccwpck_require__(35137)
+          } else {
+            nativeBinding = __nccwpck_require__(89581)
+          }
+        } catch (e) {
+          loadError = e
+        }
+        break
+      case 'arm':
+        localFileExisted = existsSync(join(__dirname, 'nx.android-arm-eabi.node'))
+        try {
+          if (localFileExisted) {
+            nativeBinding = __nccwpck_require__(17377)
+          } else {
+            nativeBinding = __nccwpck_require__(63582)
+          }
+        } catch (e) {
+          loadError = e
+        }
+        break
+      default:
+        throw new Error(`Unsupported architecture on Android ${arch}`)
+    }
+    break
+  case 'win32':
+    switch (arch) {
+      case 'x64':
+        localFileExisted = existsSync(
+          join(__dirname, 'nx.win32-x64-msvc.node')
+        )
+        try {
+          if (localFileExisted) {
+            nativeBinding = __nccwpck_require__(82472)
+          } else {
+            nativeBinding = __nccwpck_require__(19959)
+          }
+        } catch (e) {
+          loadError = e
+        }
+        break
+      case 'ia32':
+        localFileExisted = existsSync(
+          join(__dirname, 'nx.win32-ia32-msvc.node')
+        )
+        try {
+          if (localFileExisted) {
+            nativeBinding = __nccwpck_require__(33821)
+          } else {
+            nativeBinding = __nccwpck_require__(85420)
+          }
+        } catch (e) {
+          loadError = e
+        }
+        break
+      case 'arm64':
+        localFileExisted = existsSync(
+          join(__dirname, 'nx.win32-arm64-msvc.node')
+        )
+        try {
+          if (localFileExisted) {
+            nativeBinding = __nccwpck_require__(16320)
+          } else {
+            nativeBinding = __nccwpck_require__(18146)
+          }
+        } catch (e) {
+          loadError = e
+        }
+        break
+      default:
+        throw new Error(`Unsupported architecture on Windows: ${arch}`)
     }
-  });
-
-  // src/typescript/typescript.ts
-  var require_typescript = __commonJS({
-    "src/typescript/typescript.ts"(exports, module2) {
-      init_ts6();
-      init_ts6();
-      if (typeof console !== "undefined") {
-        Debug.loggingHost = {
-          log(level, s) {
-            switch (level) {
-              case 1 /* Error */:
-                return console.error(s);
-              case 2 /* Warning */:
-                return console.warn(s);
-              case 3 /* Info */:
-                return console.log(s);
-              case 4 /* Verbose */:
-                return console.log(s);
-            }
+    break
+  case 'darwin':
+    localFileExisted = existsSync(join(__dirname, 'nx.darwin-universal.node'))
+    try {
+      if (localFileExisted) {
+        nativeBinding = __nccwpck_require__(52701)
+      } else {
+        nativeBinding = __nccwpck_require__(18912)
+      }
+      break
+    } catch {}
+    switch (arch) {
+      case 'x64':
+        localFileExisted = existsSync(join(__dirname, 'nx.darwin-x64.node'))
+        try {
+          if (localFileExisted) {
+            nativeBinding = __nccwpck_require__(1322)
+          } else {
+            nativeBinding = __nccwpck_require__(59194)
           }
-        };
+        } catch (e) {
+          loadError = e
+        }
+        break
+      case 'arm64':
+        localFileExisted = existsSync(
+          join(__dirname, 'nx.darwin-arm64.node')
+        )
+        try {
+          if (localFileExisted) {
+            nativeBinding = __nccwpck_require__(46502)
+          } else {
+            nativeBinding = __nccwpck_require__(74067)
+          }
+        } catch (e) {
+          loadError = e
+        }
+        break
+      default:
+        throw new Error(`Unsupported architecture on macOS: ${arch}`)
+    }
+    break
+  case 'freebsd':
+    if (arch !== 'x64') {
+      throw new Error(`Unsupported architecture on FreeBSD: ${arch}`)
+    }
+    localFileExisted = existsSync(join(__dirname, 'nx.freebsd-x64.node'))
+    try {
+      if (localFileExisted) {
+        nativeBinding = __nccwpck_require__(35488)
+      } else {
+        nativeBinding = __nccwpck_require__(63818)
       }
-      module2.exports = ts_exports2;
+    } catch (e) {
+      loadError = e
     }
-  });
-  return require_typescript();
-})();
+    break
+  case 'linux':
+    switch (arch) {
+      case 'x64':
+        if (isMusl()) {
+          localFileExisted = existsSync(
+            join(__dirname, 'nx.linux-x64-musl.node')
+          )
+          try {
+            if (localFileExisted) {
+              nativeBinding = __nccwpck_require__(76200)
+            } else {
+              nativeBinding = __nccwpck_require__(91817)
+            }
+          } catch (e) {
+            loadError = e
+          }
+        } else {
+          localFileExisted = existsSync(
+            join(__dirname, 'nx.linux-x64-gnu.node')
+          )
+          try {
+            if (localFileExisted) {
+              nativeBinding = __nccwpck_require__(37202)
+            } else {
+              nativeBinding = __nccwpck_require__(91136)
+            }
+          } catch (e) {
+            loadError = e
+          }
+        }
+        break
+      case 'arm64':
+        if (isMusl()) {
+          localFileExisted = existsSync(
+            join(__dirname, 'nx.linux-arm64-musl.node')
+          )
+          try {
+            if (localFileExisted) {
+              nativeBinding = __nccwpck_require__(76818)
+            } else {
+              nativeBinding = __nccwpck_require__(67629)
+            }
+          } catch (e) {
+            loadError = e
+          }
+        } else {
+          localFileExisted = existsSync(
+            join(__dirname, 'nx.linux-arm64-gnu.node')
+          )
+          try {
+            if (localFileExisted) {
+              nativeBinding = __nccwpck_require__(69480)
+            } else {
+              nativeBinding = __nccwpck_require__(99909)
+            }
+          } catch (e) {
+            loadError = e
+          }
+        }
+        break
+      case 'arm':
+        localFileExisted = existsSync(
+          join(__dirname, 'nx.linux-arm-gnueabihf.node')
+        )
+        try {
+          if (localFileExisted) {
+            nativeBinding = __nccwpck_require__(56986)
+          } else {
+            nativeBinding = __nccwpck_require__(56362)
+          }
+        } catch (e) {
+          loadError = e
+        }
+        break
+      default:
+        throw new Error(`Unsupported architecture on Linux: ${arch}`)
+    }
+    break
+  default:
+    throw new Error(`Unsupported OS: ${platform}, architecture: ${arch}`)
+}
 
-if ( true && module.exports) { module.exports = ts; }
-//# sourceMappingURL=typescript.js.map
+if (!nativeBinding) {
+  if (loadError) {
+    throw loadError
+  }
+  throw new Error(`Failed to load native binding`)
+}
+
+const { expandOutputs, getFilesForOutputs, remove, copy, ChildProcess, runCommand, nxFork, hashArray, hashFile, ImportResult, findImports, transferProjectGraph, HashPlanner, TaskHasher, EventType, Watcher, WorkspaceContext, WorkspaceErrors, testOnlyTransferFileMap } = nativeBinding
+
+module.exports.expandOutputs = expandOutputs
+module.exports.getFilesForOutputs = getFilesForOutputs
+module.exports.remove = remove
+module.exports.copy = copy
+module.exports.ChildProcess = ChildProcess
+module.exports.runCommand = runCommand
+module.exports.nxFork = nxFork
+module.exports.hashArray = hashArray
+module.exports.hashFile = hashFile
+module.exports.ImportResult = ImportResult
+module.exports.findImports = findImports
+module.exports.transferProjectGraph = transferProjectGraph
+module.exports.HashPlanner = HashPlanner
+module.exports.TaskHasher = TaskHasher
+module.exports.EventType = EventType
+module.exports.Watcher = Watcher
+module.exports.WorkspaceContext = WorkspaceContext
+module.exports.WorkspaceErrors = WorkspaceErrors
+module.exports.testOnlyTransferFileMap = testOnlyTransferFileMap
 
 
 /***/ }),
 
-/***/ 82787:
-/***/ ((__unused_webpack_module, exports) => {
+/***/ 17797:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
 "use strict";
 
-
-exports.fromCallback = function (fn) {
-  return Object.defineProperty(function (...args) {
-    if (typeof args[args.length - 1] === 'function') fn.apply(this, args)
-    else {
-      return new Promise((resolve, reject) => {
-        fn.call(
-          this,
-          ...args,
-          (err, res) => (err != null) ? reject(err) : resolve(res)
-        )
-      })
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.createDependencies = exports.createNodes = exports.name = void 0;
+const fs_1 = __nccwpck_require__(57147);
+const fs_extra_1 = __nccwpck_require__(27475);
+const path_1 = __nccwpck_require__(71017);
+const perf_hooks_1 = __nccwpck_require__(4074);
+const cache_directory_1 = __nccwpck_require__(15120);
+const globs_1 = __nccwpck_require__(94865);
+const lock_file_1 = __nccwpck_require__(55333);
+const build_dependencies_1 = __nccwpck_require__(37158);
+const config_1 = __nccwpck_require__(13770);
+const file_hasher_1 = __nccwpck_require__(50180);
+const package_manager_1 = __nccwpck_require__(18142);
+const workspace_root_1 = __nccwpck_require__(86708);
+const versions_1 = __nccwpck_require__(92941);
+exports.name = 'nx/js/dependencies-and-lockfile';
+let parsedLockFile = {};
+exports.createNodes = [
+    // Look for all lockfiles
+    (0, globs_1.combineGlobPatterns)(lock_file_1.LOCKFILES),
+    (lockFile, _, context) => {
+        const pluginConfig = (0, config_1.jsPluginConfig)(context.nxJsonConfiguration);
+        if (!pluginConfig.analyzeLockfile) {
+            return {};
+        }
+        const packageManager = (0, package_manager_1.detectPackageManager)(workspace_root_1.workspaceRoot);
+        // Only process the correct lockfile
+        if (lockFile !== (0, lock_file_1.getLockFileName)(packageManager)) {
+            return {};
+        }
+        const lockFilePath = (0, path_1.join)(workspace_root_1.workspaceRoot, lockFile);
+        const lockFileContents = (0, fs_1.readFileSync)(lockFilePath).toString();
+        const lockFileHash = getLockFileHash(lockFileContents);
+        if (!lockFileNeedsReprocessing(lockFileHash)) {
+            const nodes = readCachedParsedLockFile().externalNodes;
+            parsedLockFile.externalNodes = nodes;
+            return {
+                externalNodes: nodes,
+            };
+        }
+        const externalNodes = (0, lock_file_1.getLockFileNodes)(packageManager, lockFileContents, lockFileHash);
+        parsedLockFile.externalNodes = externalNodes;
+        return {
+            externalNodes,
+        };
+    },
+];
+const createDependencies = (_, ctx) => {
+    const pluginConfig = (0, config_1.jsPluginConfig)(ctx.nxJsonConfiguration);
+    const packageManager = (0, package_manager_1.detectPackageManager)(workspace_root_1.workspaceRoot);
+    let lockfileDependencies = [];
+    // lockfile may not exist yet
+    if (pluginConfig.analyzeLockfile &&
+        (0, lock_file_1.lockFileExists)(packageManager) &&
+        parsedLockFile) {
+        const lockFilePath = (0, path_1.join)(workspace_root_1.workspaceRoot, (0, lock_file_1.getLockFileName)(packageManager));
+        const lockFileContents = (0, fs_1.readFileSync)(lockFilePath).toString();
+        const lockFileHash = getLockFileHash(lockFileContents);
+        if (!lockFileNeedsReprocessing(lockFileHash)) {
+            lockfileDependencies = readCachedParsedLockFile().dependencies ?? [];
+        }
+        else {
+            lockfileDependencies = (0, lock_file_1.getLockFileDependencies)(packageManager, lockFileContents, lockFileHash, ctx);
+            parsedLockFile.dependencies = lockfileDependencies;
+            writeLastProcessedLockfileHash(lockFileHash, parsedLockFile);
+        }
     }
-  }, 'name', { value: fn.name })
+    perf_hooks_1.performance.mark('build typescript dependencies - start');
+    const explicitProjectDependencies = (0, build_dependencies_1.buildExplicitDependencies)(pluginConfig, ctx);
+    perf_hooks_1.performance.mark('build typescript dependencies - end');
+    perf_hooks_1.performance.measure('build typescript dependencies', 'build typescript dependencies - start', 'build typescript dependencies - end');
+    return lockfileDependencies.concat(explicitProjectDependencies);
+};
+exports.createDependencies = createDependencies;
+function getLockFileHash(lockFileContents) {
+    return (0, file_hasher_1.hashArray)([versions_1.nxVersion, lockFileContents]);
 }
-
-exports.fromPromise = function (fn) {
-  return Object.defineProperty(function (...args) {
-    const cb = args[args.length - 1]
-    if (typeof cb !== 'function') return fn.apply(this, args)
-    else fn.apply(this, args.slice(0, -1)).then(r => cb(null, r), cb)
-  }, 'name', { value: fn.name })
+function lockFileNeedsReprocessing(lockHash) {
+    try {
+        return (0, fs_1.readFileSync)(lockFileHashFile).toString() !== lockHash;
+    }
+    catch {
+        return true;
+    }
+}
+function writeLastProcessedLockfileHash(hash, lockFile) {
+    (0, fs_extra_1.ensureDirSync)((0, path_1.dirname)(lockFileHashFile));
+    (0, fs_1.writeFileSync)(cachedParsedLockFile, JSON.stringify(lockFile, null, 2));
+    (0, fs_1.writeFileSync)(lockFileHashFile, hash);
+}
+function readCachedParsedLockFile() {
+    return JSON.parse((0, fs_1.readFileSync)(cachedParsedLockFile).toString());
 }
+const lockFileHashFile = (0, path_1.join)(cache_directory_1.projectGraphCacheDirectory, 'lockfile.hash');
+const cachedParsedLockFile = (0, path_1.join)(cache_directory_1.projectGraphCacheDirectory, 'parsed-lock-file.json');
 
 
 /***/ }),
 
-/***/ 40538:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+/***/ 55333:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
+"use strict";
 
 /**
- * For Node.js, simply re-export the core `util.deprecate` function.
+ * This is the main API for accessing the lock file functionality.
+ * It encapsulates the package manager specific logic and implementation details.
  */
-
-module.exports = __nccwpck_require__(73837).deprecate;
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.createLockFile = exports.getLockFileName = exports.lockFileExists = exports.getLockFileDependencies = exports.getLockFileNodes = exports.LOCKFILES = void 0;
+const fs_1 = __nccwpck_require__(57147);
+const path_1 = __nccwpck_require__(71017);
+const package_manager_1 = __nccwpck_require__(18142);
+const workspace_root_1 = __nccwpck_require__(86708);
+const output_1 = __nccwpck_require__(1737);
+const npm_parser_1 = __nccwpck_require__(1443);
+const pnpm_parser_1 = __nccwpck_require__(24573);
+const yarn_parser_1 = __nccwpck_require__(83243);
+const project_graph_pruning_1 = __nccwpck_require__(35765);
+const package_json_1 = __nccwpck_require__(20992);
+const fileutils_1 = __nccwpck_require__(83851);
+const YARN_LOCK_FILE = 'yarn.lock';
+const NPM_LOCK_FILE = 'package-lock.json';
+const PNPM_LOCK_FILE = 'pnpm-lock.yaml';
+exports.LOCKFILES = [YARN_LOCK_FILE, NPM_LOCK_FILE, PNPM_LOCK_FILE];
+const YARN_LOCK_PATH = (0, path_1.join)(workspace_root_1.workspaceRoot, YARN_LOCK_FILE);
+const NPM_LOCK_PATH = (0, path_1.join)(workspace_root_1.workspaceRoot, NPM_LOCK_FILE);
+const PNPM_LOCK_PATH = (0, path_1.join)(workspace_root_1.workspaceRoot, PNPM_LOCK_FILE);
+/**
+ * Parses lock file and maps dependencies and metadata to {@link LockFileGraph}
+ */
+function getLockFileNodes(packageManager, contents, lockFileHash) {
+    try {
+        if (packageManager === 'yarn') {
+            const packageJson = (0, fileutils_1.readJsonFile)('package.json');
+            return (0, yarn_parser_1.getYarnLockfileNodes)(contents, lockFileHash, packageJson);
+        }
+        if (packageManager === 'pnpm') {
+            return (0, pnpm_parser_1.getPnpmLockfileNodes)(contents, lockFileHash);
+        }
+        if (packageManager === 'npm') {
+            return (0, npm_parser_1.getNpmLockfileNodes)(contents, lockFileHash);
+        }
+    }
+    catch (e) {
+        if (!isPostInstallProcess()) {
+            output_1.output.error({
+                title: `Failed to parse ${packageManager} lockfile`,
+                bodyLines: errorBodyLines(e),
+            });
+        }
+        throw e;
+    }
+    throw new Error(`Unknown package manager: ${packageManager}`);
+}
+exports.getLockFileNodes = getLockFileNodes;
+/**
+ * Parses lock file and maps dependencies and metadata to {@link LockFileGraph}
+ */
+function getLockFileDependencies(packageManager, contents, lockFileHash, context) {
+    try {
+        if (packageManager === 'yarn') {
+            return (0, yarn_parser_1.getYarnLockfileDependencies)(contents, lockFileHash, context);
+        }
+        if (packageManager === 'pnpm') {
+            return (0, pnpm_parser_1.getPnpmLockfileDependencies)(contents, lockFileHash, context);
+        }
+        if (packageManager === 'npm') {
+            return (0, npm_parser_1.getNpmLockfileDependencies)(contents, lockFileHash, context);
+        }
+    }
+    catch (e) {
+        if (!isPostInstallProcess()) {
+            output_1.output.error({
+                title: `Failed to parse ${packageManager} lockfile`,
+                bodyLines: errorBodyLines(e),
+            });
+        }
+        throw e;
+    }
+    throw new Error(`Unknown package manager: ${packageManager}`);
+}
+exports.getLockFileDependencies = getLockFileDependencies;
+function lockFileExists(packageManager) {
+    if (packageManager === 'yarn') {
+        return (0, fs_1.existsSync)(YARN_LOCK_PATH);
+    }
+    if (packageManager === 'pnpm') {
+        return (0, fs_1.existsSync)(PNPM_LOCK_PATH);
+    }
+    if (packageManager === 'npm') {
+        return (0, fs_1.existsSync)(NPM_LOCK_PATH);
+    }
+    throw new Error(`Unknown package manager ${packageManager} or lock file missing`);
+}
+exports.lockFileExists = lockFileExists;
+/**
+ * Returns lock file name based on the detected package manager in the root
+ * @param packageManager
+ * @returns
+ */
+function getLockFileName(packageManager) {
+    if (packageManager === 'yarn') {
+        return YARN_LOCK_FILE;
+    }
+    if (packageManager === 'pnpm') {
+        return PNPM_LOCK_FILE;
+    }
+    if (packageManager === 'npm') {
+        return NPM_LOCK_FILE;
+    }
+    throw new Error(`Unknown package manager: ${packageManager}`);
+}
+exports.getLockFileName = getLockFileName;
+/**
+ * Create lock file based on the root level lock file and (pruned) package.json
+ *
+ * @param packageJson
+ * @param isProduction
+ * @param packageManager
+ * @returns
+ */
+function createLockFile(packageJson, graph, packageManager = (0, package_manager_1.detectPackageManager)(workspace_root_1.workspaceRoot)) {
+    const normalizedPackageJson = (0, package_json_1.normalizePackageJson)(packageJson);
+    const content = (0, fs_1.readFileSync)(getLockFileName(packageManager), 'utf8');
+    try {
+        if (packageManager === 'yarn') {
+            const prunedGraph = (0, project_graph_pruning_1.pruneProjectGraph)(graph, packageJson);
+            return (0, yarn_parser_1.stringifyYarnLockfile)(prunedGraph, content, normalizedPackageJson);
+        }
+        if (packageManager === 'pnpm') {
+            const prunedGraph = (0, project_graph_pruning_1.pruneProjectGraph)(graph, packageJson);
+            return (0, pnpm_parser_1.stringifyPnpmLockfile)(prunedGraph, content, normalizedPackageJson);
+        }
+        if (packageManager === 'npm') {
+            const prunedGraph = (0, project_graph_pruning_1.pruneProjectGraph)(graph, packageJson);
+            return (0, npm_parser_1.stringifyNpmLockfile)(prunedGraph, content, normalizedPackageJson);
+        }
+    }
+    catch (e) {
+        if (!isPostInstallProcess()) {
+            const additionalInfo = [
+                'To prevent the build from breaking we are returning the root lock file.',
+            ];
+            if (packageManager === 'npm') {
+                additionalInfo.push('If you run `npm install --package-lock-only` in your output folder it will regenerate the correct pruned lockfile.');
+            }
+            if (packageManager === 'pnpm') {
+                additionalInfo.push('If you run `pnpm install --lockfile-only` in your output folder it will regenerate the correct pruned lockfile.');
+            }
+            output_1.output.error({
+                title: 'An error occured while creating pruned lockfile',
+                bodyLines: errorBodyLines(e, additionalInfo),
+            });
+        }
+        return content;
+    }
+}
+exports.createLockFile = createLockFile;
+// generate body lines for error message
+function errorBodyLines(originalError, additionalInfo = []) {
+    return [
+        'Please open an issue at `https://github.com/nrwl/nx/issues/new?template=1-bug.yml` and provide a reproduction.',
+        ...additionalInfo,
+        `\nOriginal error: ${originalError.message}\n\n`,
+        originalError.stack,
+    ];
+}
+function isPostInstallProcess() {
+    return (process.env.npm_command === 'install' &&
+        process.env.npm_lifecycle_event === 'postinstall');
+}
 
 
 /***/ }),
 
-/***/ 10580:
+/***/ 1443:
 /***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
 "use strict";
 
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.stringifyNpmLockfile = exports.getNpmLockfileDependencies = exports.getNpmLockfileNodes = void 0;
+const fs_1 = __nccwpck_require__(57147);
+const semver_1 = __nccwpck_require__(66195);
+const workspace_root_1 = __nccwpck_require__(86708);
+const operators_1 = __nccwpck_require__(5959);
+const project_graph_builder_1 = __nccwpck_require__(80862);
+const project_graph_1 = __nccwpck_require__(2184);
+const file_hasher_1 = __nccwpck_require__(50180);
+// we use key => node map to avoid duplicate work when parsing keys
+let keyMap = new Map();
+let currentLockFileHash;
+let parsedLockFile;
+function parsePackageLockFile(lockFileContent, lockFileHash) {
+    if (lockFileHash === currentLockFileHash) {
+        return parsedLockFile;
+    }
+    keyMap.clear();
+    const results = JSON.parse(lockFileContent);
+    parsedLockFile = results;
+    currentLockFileHash = lockFileHash;
+    return results;
+}
+function getNpmLockfileNodes(lockFileContent, lockFileHash) {
+    const data = parsePackageLockFile(lockFileContent, lockFileHash);
+    // we use key => node map to avoid duplicate work when parsing keys
+    return getNodes(data, keyMap);
+}
+exports.getNpmLockfileNodes = getNpmLockfileNodes;
+function getNpmLockfileDependencies(lockFileContent, lockFileHash, ctx) {
+    const data = parsePackageLockFile(lockFileContent, lockFileHash);
+    return getDependencies(data, keyMap, ctx);
+}
+exports.getNpmLockfileDependencies = getNpmLockfileDependencies;
+function getNodes(data, keyMap) {
+    const nodes = new Map();
+    if (data.lockfileVersion > 1) {
+        Object.entries(data.packages).forEach(([path, snapshot]) => {
+            // skip workspaces packages
+            if (path === '' || !path.includes('node_modules') || snapshot.link) {
+                return;
+            }
+            const packageName = path.split('node_modules/').pop();
+            const version = findV3Version(snapshot, packageName);
+            createNode(packageName, version, path, nodes, keyMap, snapshot);
+        });
+    }
+    else {
+        Object.entries(data.dependencies).forEach(([packageName, snapshot]) => {
+            // we only care about dependencies of workspace packages
+            if (snapshot.version?.startsWith('file:')) {
+                if (snapshot.dependencies) {
+                    Object.entries(snapshot.dependencies).forEach(([depName, depSnapshot]) => {
+                        addV1Node(depName, depSnapshot, `${snapshot.version.slice(5)}/node_modules/${depName}`, nodes, keyMap);
+                    });
+                }
+            }
+            else {
+                addV1Node(packageName, snapshot, `node_modules/${packageName}`, nodes, keyMap);
+            }
+        });
+    }
+    const results = {};
+    // some packages can be both hoisted and nested
+    // so we need to run this check once we have all the nodes and paths
+    for (const [packageName, versionMap] of nodes.entries()) {
+        const hoistedNode = keyMap.get(`node_modules/${packageName}`);
+        if (hoistedNode) {
+            hoistedNode.name = `npm:${packageName}`;
+        }
+        versionMap.forEach((node) => {
+            results[node.name] = node;
+        });
+    }
+    return results;
+}
+function addV1Node(packageName, snapshot, path, nodes, keyMap) {
+    createNode(packageName, snapshot.version, path, nodes, keyMap, snapshot);
+    // traverse nested dependencies
+    if (snapshot.dependencies) {
+        Object.entries(snapshot.dependencies).forEach(([depName, depSnapshot]) => {
+            addV1Node(depName, depSnapshot, `${path}/node_modules/${depName}`, nodes, keyMap);
+        });
+    }
+}
+function createNode(packageName, version, key, nodes, keyMap, snapshot) {
+    const existingNode = nodes.get(packageName)?.get(version);
+    if (existingNode) {
+        keyMap.set(key, existingNode);
+        return;
+    }
+    const node = {
+        type: 'npm',
+        name: version ? `npm:${packageName}@${version}` : `npm:${packageName}`,
+        data: {
+            version,
+            packageName,
+            hash: snapshot.integrity ||
+                (0, file_hasher_1.hashArray)(snapshot.resolved
+                    ? [snapshot.resolved]
+                    : version
+                        ? [packageName, version]
+                        : [packageName]),
+        },
+    };
+    keyMap.set(key, node);
+    if (!nodes.has(packageName)) {
+        nodes.set(packageName, new Map([[version, node]]));
+    }
+    else {
+        nodes.get(packageName).set(version, node);
+    }
+}
+function findV3Version(snapshot, packageName) {
+    let version = snapshot.version;
+    const resolved = snapshot.resolved;
+    // for tarball packages version might not exist or be useless
+    if (!version || (resolved && !resolved.includes(version))) {
+        version = resolved;
+    }
+    // for alias packages name is set
+    if (snapshot.name && snapshot.name !== packageName) {
+        if (version) {
+            version = `npm:${snapshot.name}@${version}`;
+        }
+        else {
+            version = `npm:${snapshot.name}`;
+        }
+    }
+    return version;
+}
+function getDependencies(data, keyMap, ctx) {
+    const dependencies = [];
+    if (data.lockfileVersion > 1) {
+        Object.entries(data.packages).forEach(([path, snapshot]) => {
+            // we are skipping workspaces packages
+            if (!keyMap.has(path)) {
+                return;
+            }
+            const sourceName = keyMap.get(path).name;
+            [
+                snapshot.peerDependencies,
+                snapshot.dependencies,
+                snapshot.optionalDependencies,
+            ].forEach((section) => {
+                if (section) {
+                    Object.entries(section).forEach(([name, versionRange]) => {
+                        const target = findTarget(path, keyMap, name, versionRange);
+                        if (target) {
+                            const dep = {
+                                source: sourceName,
+                                target: target.name,
+                                type: project_graph_1.DependencyType.static,
+                            };
+                            (0, project_graph_builder_1.validateDependency)(dep, ctx);
+                            dependencies.push(dep);
+                        }
+                    });
+                }
+            });
+        });
+    }
+    else {
+        Object.entries(data.dependencies).forEach(([packageName, snapshot]) => {
+            addV1NodeDependencies(`node_modules/${packageName}`, snapshot, dependencies, keyMap, ctx);
+        });
+    }
+    return dependencies;
+}
+function findTarget(sourcePath, keyMap, targetName, versionRange) {
+    if (sourcePath && !sourcePath.endsWith('/')) {
+        sourcePath = `${sourcePath}/`;
+    }
+    const searchPath = `${sourcePath}node_modules/${targetName}`;
+    if (keyMap.has(searchPath)) {
+        const child = keyMap.get(searchPath);
+        if (child.data.version === versionRange ||
+            (0, semver_1.satisfies)(child.data.version, versionRange)) {
+            return child;
+        }
+    }
+    // the hoisted package did not match, this dependency is missing
+    if (!sourcePath) {
+        return;
+    }
+    return findTarget(sourcePath.split('node_modules/').slice(0, -1).join('node_modules/'), keyMap, targetName, versionRange);
+}
+function addV1NodeDependencies(path, snapshot, dependencies, keyMap, ctx) {
+    if (keyMap.has(path) && snapshot.requires) {
+        const source = keyMap.get(path).name;
+        Object.entries(snapshot.requires).forEach(([name, versionRange]) => {
+            const target = findTarget(path, keyMap, name, versionRange);
+            if (target) {
+                const dep = {
+                    source: source,
+                    target: target.name,
+                    type: project_graph_1.DependencyType.static,
+                };
+                (0, project_graph_builder_1.validateDependency)(dep, ctx);
+                dependencies.push(dep);
+            }
+        });
+    }
+    if (snapshot.dependencies) {
+        Object.entries(snapshot.dependencies).forEach(([depName, depSnapshot]) => {
+            addV1NodeDependencies(`${path}/node_modules/${depName}`, depSnapshot, dependencies, keyMap, ctx);
+        });
+    }
+    const { peerDependencies } = getPeerDependencies(path);
+    if (peerDependencies) {
+        const node = keyMap.get(path);
+        Object.entries(peerDependencies).forEach(([depName, depSpec]) => {
+            const target = findTarget(path, keyMap, depName, depSpec);
+            if (target) {
+                const dep = {
+                    source: node.name,
+                    target: target.name,
+                    type: project_graph_1.DependencyType.static,
+                };
+                (0, project_graph_builder_1.validateDependency)(dep, ctx);
+                dependencies.push(dep);
+            }
+        });
+    }
+}
+function stringifyNpmLockfile(graph, rootLockFileContent, packageJson) {
+    const rootLockFile = JSON.parse(rootLockFileContent);
+    const { lockfileVersion } = JSON.parse(rootLockFileContent);
+    const mappedPackages = mapSnapshots(rootLockFile, graph);
+    const output = {
+        name: packageJson.name || rootLockFile.name,
+        version: packageJson.version || '0.0.1',
+        lockfileVersion: rootLockFile.lockfileVersion,
+    };
+    if (rootLockFile.requires) {
+        output.requires = rootLockFile.requires;
+    }
+    if (lockfileVersion > 1) {
+        output.packages = mapV3Snapshots(mappedPackages, packageJson);
+    }
+    if (lockfileVersion < 3) {
+        output.dependencies = mapV1Snapshots(mappedPackages);
+    }
+    return JSON.stringify(output, null, 2);
+}
+exports.stringifyNpmLockfile = stringifyNpmLockfile;
+function mapV3Snapshots(mappedPackages, packageJson) {
+    const output = {};
+    output[''] = packageJson;
+    mappedPackages.forEach((p) => {
+        output[p.path] = p.valueV3;
+    });
+    return output;
+}
+function mapV1Snapshots(mappedPackages) {
+    const output = {};
+    mappedPackages.forEach((p) => {
+        getPackageParent(p.path, output)[p.name] = p.valueV1;
+    });
+    return output;
+}
+function getPackageParent(path, packages) {
+    const segments = path.split(/\/?node_modules\//).slice(1, -1);
+    if (!segments.length) {
+        return packages;
+    }
+    let parent = packages[segments.shift()];
+    if (!parent.dependencies) {
+        parent.dependencies = {};
+    }
+    while (segments.length) {
+        parent = parent.dependencies[segments.shift()];
+        if (!parent.dependencies) {
+            parent.dependencies = {};
+        }
+    }
+    return parent.dependencies;
+}
+function mapSnapshots(rootLockFile, graph) {
+    const nestedNodes = new Set();
+    const visitedNodes = new Map();
+    const visitedPaths = new Set();
+    const remappedPackages = new Map();
+    // add first level children
+    Object.values(graph.externalNodes).forEach((node) => {
+        if (node.name === `npm:${node.data.packageName}`) {
+            const mappedPackage = mapPackage(rootLockFile, node.data.packageName, node.data.version);
+            remappedPackages.set(mappedPackage.path, mappedPackage);
+            visitedNodes.set(node, new Set([mappedPackage.path]));
+            visitedPaths.add(mappedPackage.path);
+        }
+        else {
+            nestedNodes.add(node);
+        }
+    });
+    let remappedPackagesArray;
+    if (nestedNodes.size) {
+        const invertedGraph = (0, operators_1.reverse)(graph);
+        nestMappedPackages(invertedGraph, remappedPackages, nestedNodes, visitedNodes, visitedPaths, rootLockFile);
+        // initially we naively map package paths to topParent/../parent/child
+        // but some of those should be nested higher up the tree
+        remappedPackagesArray = elevateNestedPaths(remappedPackages);
+    }
+    else {
+        remappedPackagesArray = Array.from(remappedPackages.values());
+    }
+    return remappedPackagesArray.sort((a, b) => a.path.localeCompare(b.path));
+}
+function mapPackage(rootLockFile, packageName, version, parentPath = '') {
+    const lockfileVersion = rootLockFile.lockfileVersion;
+    let valueV3, valueV1;
+    if (lockfileVersion < 3) {
+        valueV1 = findMatchingPackageV1(rootLockFile.dependencies, packageName, version);
+    }
+    if (lockfileVersion > 1) {
+        valueV3 = findMatchingPackageV3(rootLockFile.packages, packageName, version);
+    }
+    return {
+        path: parentPath + `node_modules/${packageName}`,
+        name: packageName,
+        valueV1,
+        valueV3,
+    };
+}
+function nestMappedPackages(invertedGraph, result, nestedNodes, visitedNodes, visitedPaths, rootLockFile) {
+    const initialSize = nestedNodes.size;
+    if (!initialSize) {
+        return;
+    }
+    nestedNodes.forEach((node) => {
+        let unresolvedParents = invertedGraph.dependencies[node.name].length;
+        invertedGraph.dependencies[node.name].forEach(({ target }) => {
+            const targetNode = invertedGraph.externalNodes[target];
+            if (visitedNodes.has(targetNode)) {
+                visitedNodes.get(targetNode).forEach((path) => {
+                    const mappedPackage = mapPackage(rootLockFile, node.data.packageName, node.data.version, path + '/');
+                    result.set(mappedPackage.path, mappedPackage);
+                    if (visitedNodes.has(node)) {
+                        visitedNodes.get(node).add(mappedPackage.path);
+                    }
+                    else {
+                        visitedNodes.set(node, new Set([mappedPackage.path]));
+                    }
+                    visitedPaths.add(mappedPackage.path);
+                });
+                unresolvedParents--;
+            }
+        });
+        if (!unresolvedParents) {
+            nestedNodes.delete(node);
+        }
+    });
+    if (initialSize === nestedNodes.size) {
+        throw new Error([
+            'Following packages could not be mapped to the NPM lockfile:',
+            ...Array.from(nestedNodes).map((n) => `- ${n.name}`),
+        ].join('\n'));
+    }
+    else {
+        nestMappedPackages(invertedGraph, result, nestedNodes, visitedNodes, visitedPaths, rootLockFile);
+    }
+}
+// sort paths by number of segments and then alphabetically
+function sortMappedPackagesPaths(mappedPackages) {
+    return Array.from(mappedPackages.keys()).sort((a, b) => {
+        const aLength = a.split('/node_modules/').length;
+        const bLength = b.split('/node_modules/').length;
+        if (aLength > bLength) {
+            return 1;
+        }
+        if (aLength < bLength) {
+            return -1;
+        }
+        return a.localeCompare(b);
+    });
+}
+function elevateNestedPaths(remappedPackages) {
+    const result = new Map();
+    const sortedPaths = sortMappedPackagesPaths(remappedPackages);
+    sortedPaths.forEach((path) => {
+        const segments = path.split('/node_modules/');
+        const mappedPackage = remappedPackages.get(path);
+        // we keep hoisted packages intact
+        if (segments.length === 1) {
+            result.set(path, mappedPackage);
+            return;
+        }
+        const packageName = segments.pop();
+        const getNewPath = (segs) => `${segs.join('/node_modules/')}/node_modules/${packageName}`;
+        // check if grandparent has the same package
+        const shouldElevate = (segs) => {
+            const elevatedPath = getNewPath(segs.slice(0, -1));
+            if (result.has(elevatedPath)) {
+                const match = result.get(elevatedPath);
+                return (match.valueV1?.version === mappedPackage.valueV1?.version &&
+                    match.valueV3?.version === mappedPackage.valueV3?.version);
+            }
+            return true;
+        };
+        while (segments.length > 1 && shouldElevate(segments)) {
+            segments.pop();
+        }
+        const newPath = getNewPath(segments);
+        if (path !== newPath) {
+            if (!result.has(newPath)) {
+                mappedPackage.path = newPath;
+                result.set(newPath, mappedPackage);
+            }
+        }
+        else {
+            result.set(path, mappedPackage);
+        }
+    });
+    return Array.from(result.values());
+}
+function findMatchingPackageV3(packages, name, version) {
+    for (const [key, { dev, peer, ...snapshot }] of Object.entries(packages)) {
+        if (key.endsWith(`node_modules/${name}`)) {
+            if ([
+                snapshot.version,
+                snapshot.resolved,
+                `npm:${snapshot.name}@${snapshot.version}`,
+            ].includes(version)) {
+                return snapshot;
+            }
+        }
+    }
+}
+function findMatchingPackageV1(packages, name, version) {
+    for (const [packageName, { dev, peer, dependencies, ...snapshot },] of Object.entries(packages)) {
+        if (packageName === name) {
+            if (snapshot.version === version) {
+                return snapshot;
+            }
+        }
+        if (dependencies) {
+            const found = findMatchingPackageV1(dependencies, name, version);
+            if (found) {
+                return found;
+            }
+        }
+    }
+}
+// NPM V1 does not track the peer dependencies in the lock file
+// so we need to parse them directly from the package.json
+function getPeerDependencies(path) {
+    const fullPath = `${workspace_root_1.workspaceRoot}/${path}/package.json`;
+    if ((0, fs_1.existsSync)(fullPath)) {
+        const content = (0, fs_1.readFileSync)(fullPath, 'utf-8');
+        const { peerDependencies, peerDependenciesMeta } = JSON.parse(content);
+        return {
+            ...(peerDependencies && { peerDependencies }),
+            ...(peerDependenciesMeta && { peerDependenciesMeta }),
+        };
+    }
+    else {
+        if (process.env.NX_VERBOSE_LOGGING === 'true') {
+            console.warn(`Could not find package.json at "${path}"`);
+        }
+        return {};
+    }
+}
 
-Object.defineProperty(exports, "__esModule", ({
-  value: true
-}));
-Object.defineProperty(exports, "v1", ({
-  enumerable: true,
-  get: function () {
-    return _v.default;
-  }
-}));
-Object.defineProperty(exports, "v3", ({
-  enumerable: true,
-  get: function () {
-    return _v2.default;
-  }
-}));
-Object.defineProperty(exports, "v4", ({
-  enumerable: true,
-  get: function () {
-    return _v3.default;
-  }
-}));
-Object.defineProperty(exports, "v5", ({
-  enumerable: true,
-  get: function () {
-    return _v4.default;
-  }
-}));
-Object.defineProperty(exports, "NIL", ({
-  enumerable: true,
-  get: function () {
-    return _nil.default;
-  }
-}));
-Object.defineProperty(exports, "version", ({
-  enumerable: true,
-  get: function () {
-    return _version.default;
-  }
-}));
-Object.defineProperty(exports, "validate", ({
-  enumerable: true,
-  get: function () {
-    return _validate.default;
-  }
-}));
-Object.defineProperty(exports, "stringify", ({
-  enumerable: true,
-  get: function () {
-    return _stringify.default;
-  }
-}));
-Object.defineProperty(exports, "parse", ({
-  enumerable: true,
-  get: function () {
-    return _parse.default;
-  }
-}));
-
-var _v = _interopRequireDefault(__nccwpck_require__(85618));
-
-var _v2 = _interopRequireDefault(__nccwpck_require__(34643));
-
-var _v3 = _interopRequireDefault(__nccwpck_require__(39370));
-
-var _v4 = _interopRequireDefault(__nccwpck_require__(93249));
-
-var _nil = _interopRequireDefault(__nccwpck_require__(64829));
-
-var _version = _interopRequireDefault(__nccwpck_require__(14698));
-
-var _validate = _interopRequireDefault(__nccwpck_require__(63498));
-
-var _stringify = _interopRequireDefault(__nccwpck_require__(82332));
-
-var _parse = _interopRequireDefault(__nccwpck_require__(9869));
-
-function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
 
 /***/ }),
 
-/***/ 37342:
+/***/ 24573:
 /***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
 "use strict";
 
-
-Object.defineProperty(exports, "__esModule", ({
-  value: true
-}));
-exports["default"] = void 0;
-
-var _crypto = _interopRequireDefault(__nccwpck_require__(6113));
-
-function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
-
-function md5(bytes) {
-  if (Array.isArray(bytes)) {
-    bytes = Buffer.from(bytes);
-  } else if (typeof bytes === 'string') {
-    bytes = Buffer.from(bytes, 'utf8');
-  }
-
-  return _crypto.default.createHash('md5').update(bytes).digest();
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.stringifyPnpmLockfile = exports.getPnpmLockfileDependencies = exports.getPnpmLockfileNodes = void 0;
+const pnpm_normalizer_1 = __nccwpck_require__(93434);
+const package_json_1 = __nccwpck_require__(20992);
+const object_sort_1 = __nccwpck_require__(84110);
+const project_graph_builder_1 = __nccwpck_require__(80862);
+const project_graph_1 = __nccwpck_require__(2184);
+const file_hasher_1 = __nccwpck_require__(50180);
+// we use key => node map to avoid duplicate work when parsing keys
+let keyMap = new Map();
+let currentLockFileHash;
+let parsedLockFile;
+function parsePnpmLockFile(lockFileContent, lockFileHash) {
+    if (lockFileHash === currentLockFileHash) {
+        return parsedLockFile;
+    }
+    keyMap.clear();
+    const results = (0, pnpm_normalizer_1.parseAndNormalizePnpmLockfile)(lockFileContent);
+    parsedLockFile = results;
+    currentLockFileHash = lockFileHash;
+    return results;
+}
+function getPnpmLockfileNodes(lockFileContent, lockFileHash) {
+    const data = parsePnpmLockFile(lockFileContent, lockFileHash);
+    const isV6 = (0, pnpm_normalizer_1.isV6Lockfile)(data);
+    return getNodes(data, keyMap, isV6);
+}
+exports.getPnpmLockfileNodes = getPnpmLockfileNodes;
+function getPnpmLockfileDependencies(lockFileContent, lockFileHash, ctx) {
+    const data = parsePnpmLockFile(lockFileContent, lockFileHash);
+    const isV6 = (0, pnpm_normalizer_1.isV6Lockfile)(data);
+    return getDependencies(data, keyMap, isV6, ctx);
+}
+exports.getPnpmLockfileDependencies = getPnpmLockfileDependencies;
+function getNodes(data, keyMap, isV6) {
+    const nodes = new Map();
+    Object.entries(data.packages).forEach(([key, snapshot]) => {
+        findPackageNames(key, snapshot, data).forEach((packageName) => {
+            const rawVersion = findVersion(key, packageName);
+            const version = parseBaseVersion(rawVersion, isV6);
+            // we don't need to keep duplicates, we can just track the keys
+            const existingNode = nodes.get(packageName)?.get(version);
+            if (existingNode) {
+                keyMap.set(key, existingNode);
+                return;
+            }
+            const node = {
+                type: 'npm',
+                name: version ? `npm:${packageName}@${version}` : `npm:${packageName}`,
+                data: {
+                    version,
+                    packageName,
+                    hash: snapshot.resolution?.['integrity'] ||
+                        (0, file_hasher_1.hashArray)(snapshot.resolution?.['tarball']
+                            ? [snapshot.resolution['tarball']]
+                            : [packageName, version]),
+                },
+            };
+            keyMap.set(key, node);
+            if (!nodes.has(packageName)) {
+                nodes.set(packageName, new Map([[version, node]]));
+            }
+            else {
+                nodes.get(packageName).set(version, node);
+            }
+        });
+    });
+    const hoistedDeps = (0, pnpm_normalizer_1.loadPnpmHoistedDepsDefinition)();
+    const results = {};
+    for (const [packageName, versionMap] of nodes.entries()) {
+        let hoistedNode;
+        if (versionMap.size === 1) {
+            hoistedNode = versionMap.values().next().value;
+        }
+        else {
+            const hoistedVersion = getHoistedVersion(hoistedDeps, packageName, isV6);
+            hoistedNode = versionMap.get(hoistedVersion);
+        }
+        if (hoistedNode) {
+            hoistedNode.name = `npm:${packageName}`;
+        }
+        versionMap.forEach((node) => {
+            results[node.name] = node;
+        });
+    }
+    return results;
+}
+function getHoistedVersion(hoistedDependencies, packageName, isV6) {
+    let version = (0, package_json_1.getHoistedPackageVersion)(packageName);
+    if (!version) {
+        const key = Object.keys(hoistedDependencies).find((k) => k.startsWith(`/${packageName}/`));
+        if (key) {
+            version = parseBaseVersion(getVersion(key, packageName), isV6);
+        }
+        else {
+            // pnpm might not hoist every package
+            // similarly those packages will not be available to be used via import
+            return;
+        }
+    }
+    return version;
+}
+function getDependencies(data, keyMap, isV6, ctx) {
+    const results = [];
+    Object.entries(data.packages).forEach(([key, snapshot]) => {
+        const node = keyMap.get(key);
+        [snapshot.dependencies, snapshot.optionalDependencies].forEach((section) => {
+            if (section) {
+                Object.entries(section).forEach(([name, versionRange]) => {
+                    const version = parseBaseVersion(findVersion(versionRange, name), isV6);
+                    const target = ctx.externalNodes[`npm:${name}@${version}`] ||
+                        ctx.externalNodes[`npm:${name}`];
+                    if (target) {
+                        const dep = {
+                            source: node.name,
+                            target: target.name,
+                            type: project_graph_1.DependencyType.static,
+                        };
+                        (0, project_graph_builder_1.validateDependency)(dep, ctx);
+                        results.push(dep);
+                    }
+                });
+            }
+        });
+    });
+    return results;
+}
+function parseBaseVersion(rawVersion, isV6) {
+    return isV6 ? rawVersion.split('(')[0] : rawVersion.split('_')[0];
+}
+function stringifyPnpmLockfile(graph, rootLockFileContent, packageJson) {
+    const data = (0, pnpm_normalizer_1.parseAndNormalizePnpmLockfile)(rootLockFileContent);
+    const { lockfileVersion, packages } = data;
+    const output = {
+        lockfileVersion,
+        importers: {
+            '.': mapRootSnapshot(packageJson, packages, graph.externalNodes),
+        },
+        packages: (0, object_sort_1.sortObjectByKeys)(mapSnapshots(data.packages, graph.externalNodes)),
+    };
+    return (0, pnpm_normalizer_1.stringifyToPnpmYaml)(output);
+}
+exports.stringifyPnpmLockfile = stringifyPnpmLockfile;
+function mapSnapshots(packages, nodes) {
+    const result = {};
+    Object.values(nodes).forEach((node) => {
+        const matchedKeys = findOriginalKeys(packages, node, {
+            returnFullKey: true,
+        });
+        // the package manager doesn't check for types of dependencies
+        // so we can safely set all to prod
+        matchedKeys.forEach(([key, snapshot]) => {
+            snapshot.dev = false;
+            result[key] = snapshot;
+        });
+    });
+    return result;
+}
+function findOriginalKeys(packages, { data: { packageName, version } }, { returnFullKey } = {}) {
+    const matchedKeys = [];
+    for (const key of Object.keys(packages)) {
+        const snapshot = packages[key];
+        // standard package
+        if (key.startsWith(`/${packageName}/${version}`)) {
+            matchedKeys.push([
+                returnFullKey ? key : getVersion(key, packageName),
+                snapshot,
+            ]);
+        }
+        // tarball package
+        if (key === version) {
+            matchedKeys.push([version, snapshot]);
+        }
+        // alias package
+        if (versionIsAlias(key, version)) {
+            matchedKeys.push([key, snapshot]);
+        }
+    }
+    return matchedKeys;
+}
+// check if version has a form of npm:packageName@version and
+// key starts with /packageName/version
+function versionIsAlias(key, versionExpr) {
+    const PREFIX = 'npm:';
+    if (!versionExpr.startsWith(PREFIX))
+        return false;
+    const indexOfVersionSeparator = versionExpr.indexOf('@', PREFIX.length + 1);
+    const packageName = versionExpr.slice(PREFIX.length, indexOfVersionSeparator);
+    const version = versionExpr.slice(indexOfVersionSeparator + 1);
+    return key.startsWith(`/${packageName}/${version}`);
+}
+function mapRootSnapshot(packageJson, packages, nodes) {
+    const snapshot = { specifiers: {} };
+    [
+        'dependencies',
+        'optionalDependencies',
+        'devDependencies',
+        'peerDependencies',
+    ].forEach((depType) => {
+        if (packageJson[depType]) {
+            Object.keys(packageJson[depType]).forEach((packageName) => {
+                const version = packageJson[depType][packageName];
+                const node = nodes[`npm:${packageName}@${version}`] || nodes[`npm:${packageName}`];
+                snapshot.specifiers[packageName] = version;
+                // peer dependencies are mapped to dependencies
+                let section = depType === 'peerDependencies' ? 'dependencies' : depType;
+                snapshot[section] = snapshot[section] || {};
+                snapshot[section][packageName] = findOriginalKeys(packages, node)[0][0];
+            });
+        }
+    });
+    Object.keys(snapshot).forEach((key) => {
+        snapshot[key] = (0, object_sort_1.sortObjectByKeys)(snapshot[key]);
+    });
+    return snapshot;
+}
+function findVersion(key, packageName) {
+    if (key.startsWith(`/${packageName}/`)) {
+        return getVersion(key, packageName);
+    }
+    // for alias packages prepend with "npm:"
+    if (key.startsWith('/')) {
+        const aliasName = key.slice(1, key.lastIndexOf('/'));
+        const version = getVersion(key, aliasName);
+        return `npm:${aliasName}@${version}`;
+    }
+    // for tarball package the entire key is the version spec
+    return key;
 }
-
-var _default = md5;
-exports["default"] = _default;
-
-/***/ }),
-
-/***/ 64829:
-/***/ ((__unused_webpack_module, exports) => {
-
-"use strict";
-
-
-Object.defineProperty(exports, "__esModule", ({
-  value: true
-}));
-exports["default"] = void 0;
-var _default = '00000000-0000-0000-0000-000000000000';
-exports["default"] = _default;
-
-/***/ }),
-
-/***/ 9869:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
-
-"use strict";
-
-
-Object.defineProperty(exports, "__esModule", ({
-  value: true
-}));
-exports["default"] = void 0;
-
-var _validate = _interopRequireDefault(__nccwpck_require__(63498));
-
-function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
-
-function parse(uuid) {
-  if (!(0, _validate.default)(uuid)) {
-    throw TypeError('Invalid UUID');
-  }
-
-  let v;
-  const arr = new Uint8Array(16); // Parse ########-....-....-....-............
-
-  arr[0] = (v = parseInt(uuid.slice(0, 8), 16)) >>> 24;
-  arr[1] = v >>> 16 & 0xff;
-  arr[2] = v >>> 8 & 0xff;
-  arr[3] = v & 0xff; // Parse ........-####-....-....-............
-
-  arr[4] = (v = parseInt(uuid.slice(9, 13), 16)) >>> 8;
-  arr[5] = v & 0xff; // Parse ........-....-####-....-............
-
-  arr[6] = (v = parseInt(uuid.slice(14, 18), 16)) >>> 8;
-  arr[7] = v & 0xff; // Parse ........-....-....-####-............
-
-  arr[8] = (v = parseInt(uuid.slice(19, 23), 16)) >>> 8;
-  arr[9] = v & 0xff; // Parse ........-....-....-....-############
-  // (Use "/" to avoid 32-bit truncation when bit-shifting high-order bytes)
-
-  arr[10] = (v = parseInt(uuid.slice(24, 36), 16)) / 0x10000000000 & 0xff;
-  arr[11] = v / 0x100000000 & 0xff;
-  arr[12] = v >>> 24 & 0xff;
-  arr[13] = v >>> 16 & 0xff;
-  arr[14] = v >>> 8 & 0xff;
-  arr[15] = v & 0xff;
-  return arr;
+function findPackageNames(key, snapshot, data) {
+    const packageNames = new Set();
+    const originalPackageName = extractNameFromKey(key);
+    const matchPropValue = (record) => {
+        if (!record) {
+            return undefined;
+        }
+        const index = Object.values(record).findIndex((version) => version === key);
+        if (index > -1) {
+            return Object.keys(record)[index];
+        }
+        // check if non aliased name is found
+        if (record[originalPackageName] &&
+            key.startsWith(`/${originalPackageName}/${record[originalPackageName]}`)) {
+            return originalPackageName;
+        }
+    };
+    const matchedDependencyName = (importer) => {
+        return (matchPropValue(importer.dependencies) ||
+            matchPropValue(importer.optionalDependencies) ||
+            matchPropValue(importer.peerDependencies));
+    };
+    // snapshot already has a name
+    if (snapshot.name) {
+        packageNames.add(snapshot.name);
+    }
+    // it'a a root dependency
+    const rootDependencyName = matchedDependencyName(data.importers['.']) ||
+        // only root importers have devDependencies
+        matchPropValue(data.importers['.'].devDependencies);
+    if (rootDependencyName) {
+        packageNames.add(rootDependencyName);
+    }
+    // find a snapshot that has a dependency that points to this snapshot
+    const snapshots = Object.values(data.packages);
+    for (let i = 0; i < snapshots.length; i++) {
+        const dependencyName = matchedDependencyName(snapshots[i]);
+        if (dependencyName) {
+            packageNames.add(dependencyName);
+        }
+    }
+    if (packageNames.size === 0) {
+        packageNames.add(originalPackageName);
+    }
+    return Array.from(packageNames);
 }
-
-var _default = parse;
-exports["default"] = _default;
-
-/***/ }),
-
-/***/ 65409:
-/***/ ((__unused_webpack_module, exports) => {
-
-"use strict";
-
-
-Object.defineProperty(exports, "__esModule", ({
-  value: true
-}));
-exports["default"] = void 0;
-var _default = /^(?:[0-9a-f]{8}-[0-9a-f]{4}-[1-5][0-9a-f]{3}-[89ab][0-9a-f]{3}-[0-9a-f]{12}|00000000-0000-0000-0000-000000000000)$/i;
-exports["default"] = _default;
-
-/***/ }),
-
-/***/ 64315:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
-
-"use strict";
-
-
-Object.defineProperty(exports, "__esModule", ({
-  value: true
-}));
-exports["default"] = rng;
-
-var _crypto = _interopRequireDefault(__nccwpck_require__(6113));
-
-function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
-
-const rnds8Pool = new Uint8Array(256); // # of random values to pre-allocate
-
-let poolPtr = rnds8Pool.length;
-
-function rng() {
-  if (poolPtr > rnds8Pool.length - 16) {
-    _crypto.default.randomFillSync(rnds8Pool);
-
-    poolPtr = 0;
-  }
-
-  return rnds8Pool.slice(poolPtr, poolPtr += 16);
+function getVersion(key, packageName) {
+    const KEY_NAME_SEPARATOR_LENGTH = 2; // leading and trailing slash
+    return key.slice(packageName.length + KEY_NAME_SEPARATOR_LENGTH);
 }
-
-/***/ }),
-
-/***/ 19843:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
-
-"use strict";
-
-
-Object.defineProperty(exports, "__esModule", ({
-  value: true
-}));
-exports["default"] = void 0;
-
-var _crypto = _interopRequireDefault(__nccwpck_require__(6113));
-
-function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
-
-function sha1(bytes) {
-  if (Array.isArray(bytes)) {
-    bytes = Buffer.from(bytes);
-  } else if (typeof bytes === 'string') {
-    bytes = Buffer.from(bytes, 'utf8');
-  }
-
-  return _crypto.default.createHash('sha1').update(bytes).digest();
+function extractNameFromKey(key) {
+    // if package name contains org e.g. "/@babel/runtime/7.12.5"
+    // we want slice until the third slash
+    if (key.startsWith('/@')) {
+        // find the position of the '/' after org name
+        const startFrom = key.indexOf('/', 1);
+        return key.slice(1, key.indexOf('/', startFrom + 1));
+    }
+    if (key.startsWith('/')) {
+        // if package has just a name e.g. "/react/7.12.5..."
+        return key.slice(1, key.indexOf('/', 1));
+    }
+    return key;
 }
 
-var _default = sha1;
-exports["default"] = _default;
 
 /***/ }),
 
-/***/ 82332:
+/***/ 35765:
 /***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
 "use strict";
 
-
-Object.defineProperty(exports, "__esModule", ({
-  value: true
-}));
-exports["default"] = void 0;
-
-var _validate = _interopRequireDefault(__nccwpck_require__(63498));
-
-function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
-
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.pruneProjectGraph = void 0;
+const semver_1 = __nccwpck_require__(66195);
+const project_graph_builder_1 = __nccwpck_require__(80862);
+const operators_1 = __nccwpck_require__(5959);
 /**
- * Convert array of 16 byte values to UUID string format of the form:
- * XXXXXXXX-XXXX-XXXX-XXXX-XXXXXXXXXXXX
+ * Prune project graph's external nodes and their dependencies
+ * based on the pruned package.json
  */
-const byteToHex = [];
-
-for (let i = 0; i < 256; ++i) {
-  byteToHex.push((i + 0x100).toString(16).substr(1));
+function pruneProjectGraph(graph, prunedPackageJson) {
+    const builder = new project_graph_builder_1.ProjectGraphBuilder();
+    const combinedDependencies = normalizeDependencies(prunedPackageJson, graph);
+    addNodesAndDependencies(graph, combinedDependencies, builder);
+    // for NPM (as well as the graph consistency)
+    // we need to distinguish between hoisted and non-hoisted dependencies
+    rehoistNodes(graph, combinedDependencies, builder);
+    return builder.getUpdatedProjectGraph();
 }
-
-function stringify(arr, offset = 0) {
-  // Note: Be careful editing this code!  It's been tuned for performance
-  // and works in ways you may not expect. See https://github.com/uuidjs/uuid/pull/434
-  const uuid = (byteToHex[arr[offset + 0]] + byteToHex[arr[offset + 1]] + byteToHex[arr[offset + 2]] + byteToHex[arr[offset + 3]] + '-' + byteToHex[arr[offset + 4]] + byteToHex[arr[offset + 5]] + '-' + byteToHex[arr[offset + 6]] + byteToHex[arr[offset + 7]] + '-' + byteToHex[arr[offset + 8]] + byteToHex[arr[offset + 9]] + '-' + byteToHex[arr[offset + 10]] + byteToHex[arr[offset + 11]] + byteToHex[arr[offset + 12]] + byteToHex[arr[offset + 13]] + byteToHex[arr[offset + 14]] + byteToHex[arr[offset + 15]]).toLowerCase(); // Consistency check for valid UUID.  If this throws, it's likely due to one
-  // of the following:
-  // - One or more input array values don't map to a hex octet (leading to
-  // "undefined" in the uuid)
-  // - Invalid input values for the RFC `version` or `variant` fields
-
-  if (!(0, _validate.default)(uuid)) {
-    throw TypeError('Stringified UUID is invalid');
-  }
-
-  return uuid;
+exports.pruneProjectGraph = pruneProjectGraph;
+// ensure that dependency ranges from package.json (e.g. ^1.0.0)
+// are replaced with the actual version based on the available nodes (e.g. 1.0.1)
+function normalizeDependencies(packageJson, graph) {
+    const { dependencies, devDependencies, optionalDependencies, peerDependencies, } = packageJson;
+    const combinedDependencies = {
+        ...dependencies,
+        ...devDependencies,
+        ...optionalDependencies,
+        ...peerDependencies,
+    };
+    Object.entries(combinedDependencies).forEach(([packageName, versionRange]) => {
+        if (graph.externalNodes[`npm:${packageName}@${versionRange}`]) {
+            return;
+        }
+        if (graph.externalNodes[`npm:${packageName}`] &&
+            graph.externalNodes[`npm:${packageName}`].data.version === versionRange) {
+            return;
+        }
+        // otherwise we need to find the correct version
+        const node = findNodeMatchingVersion(graph, packageName, versionRange);
+        if (node) {
+            combinedDependencies[packageName] = node.data.version;
+        }
+        else {
+            throw new Error(`Pruned lock file creation failed. The following package was not found in the root lock file: ${packageName}@${versionRange}`);
+        }
+    });
+    return combinedDependencies;
 }
-
-var _default = stringify;
-exports["default"] = _default;
-
-/***/ }),
-
-/***/ 85618:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
-
-"use strict";
-
-
-Object.defineProperty(exports, "__esModule", ({
-  value: true
-}));
-exports["default"] = void 0;
-
-var _rng = _interopRequireDefault(__nccwpck_require__(64315));
-
-var _stringify = _interopRequireDefault(__nccwpck_require__(82332));
-
-function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
-
-// **`v1()` - Generate time-based UUID**
-//
-// Inspired by https://github.com/LiosK/UUID.js
-// and http://docs.python.org/library/uuid.html
-let _nodeId;
-
-let _clockseq; // Previous uuid creation time
-
-
-let _lastMSecs = 0;
-let _lastNSecs = 0; // See https://github.com/uuidjs/uuid for API details
-
-function v1(options, buf, offset) {
-  let i = buf && offset || 0;
-  const b = buf || new Array(16);
-  options = options || {};
-  let node = options.node || _nodeId;
-  let clockseq = options.clockseq !== undefined ? options.clockseq : _clockseq; // node and clockseq need to be initialized to random values if they're not
-  // specified.  We do this lazily to minimize issues related to insufficient
-  // system entropy.  See #189
-
-  if (node == null || clockseq == null) {
-    const seedBytes = options.random || (options.rng || _rng.default)();
-
-    if (node == null) {
-      // Per 4.5, create and 48-bit node id, (47 random bits + multicast bit = 1)
-      node = _nodeId = [seedBytes[0] | 0x01, seedBytes[1], seedBytes[2], seedBytes[3], seedBytes[4], seedBytes[5]];
+function findNodeMatchingVersion(graph, packageName, versionExpr) {
+    if (versionExpr === '*') {
+        return graph.externalNodes[`npm:${packageName}`];
     }
-
-    if (clockseq == null) {
-      // Per 4.2.2, randomize (14 bit) clockseq
-      clockseq = _clockseq = (seedBytes[6] << 8 | seedBytes[7]) & 0x3fff;
+    const nodes = Object.values(graph.externalNodes)
+        .filter((n) => n.data.packageName === packageName)
+        .sort((a, b) => ((0, semver_1.gte)(b.data.version, a.data.version) ? 1 : -1));
+    if (versionExpr === 'latest') {
+        return nodes.sort((a, b) => +(0, semver_1.gte)(b.data.version, a.data.version))[0];
+    }
+    if (graph.externalNodes[`npm:${packageName}`] &&
+        (0, semver_1.satisfies)(graph.externalNodes[`npm:${packageName}`].data.version, versionExpr)) {
+        return graph.externalNodes[`npm:${packageName}`];
+    }
+    return nodes.find((n) => (0, semver_1.satisfies)(n.data.version, versionExpr));
+}
+function addNodesAndDependencies(graph, packageJsonDeps, builder) {
+    Object.entries(packageJsonDeps).forEach(([name, version]) => {
+        const node = graph.externalNodes[`npm:${name}@${version}`] ||
+            graph.externalNodes[`npm:${name}`];
+        traverseNode(graph, builder, node);
+    });
+}
+function traverseNode(graph, builder, node) {
+    if (builder.graph.externalNodes[node.name]) {
+        return;
+    }
+    builder.addExternalNode(node);
+    graph.dependencies[node.name]?.forEach((dep) => {
+        const depNode = graph.externalNodes[dep.target];
+        traverseNode(graph, builder, depNode);
+        builder.addStaticDependency(node.name, dep.target);
+    });
+}
+function rehoistNodes(graph, packageJsonDeps, builder) {
+    const packagesToRehoist = new Map();
+    // find all packages that need to be rehoisted
+    Object.values(graph.externalNodes).forEach((node) => {
+        if (node.name === `npm:${node.data.packageName}` &&
+            !builder.graph.externalNodes[node.name]) {
+            const nestedNodes = Object.values(builder.graph.externalNodes).filter((n) => n.data.packageName === node.data.packageName);
+            if (nestedNodes.length > 0) {
+                packagesToRehoist.set(node.data.packageName, nestedNodes);
+            }
+        }
+    });
+    // invert dependencies for easier traversal back
+    const invertedGraph = (0, operators_1.reverse)(builder.graph);
+    const invBuilder = new project_graph_builder_1.ProjectGraphBuilder(invertedGraph, {});
+    // find new hoisted version
+    packagesToRehoist.forEach((nestedNodes) => {
+        if (nestedNodes.length === 1) {
+            switchNodeToHoisted(nestedNodes[0], builder, invBuilder);
+        }
+        else {
+            let minDistance = Infinity;
+            let closest;
+            nestedNodes.forEach((node) => {
+                const distance = pathLengthToIncoming(node, packageJsonDeps, builder, invertedGraph);
+                if (distance < minDistance) {
+                    minDistance = distance;
+                    closest = node;
+                }
+            });
+            switchNodeToHoisted(closest, builder, invBuilder);
+        }
+    });
+}
+function switchNodeToHoisted(node, builder, invBuilder) {
+    // make a copy of current name, all the dependencies and dependents
+    const previousName = node.name;
+    const targets = (builder.graph.dependencies[node.name] || []).map((d) => d.target);
+    const sources = Object.keys(builder.graph.dependencies).filter((name) => builder.graph.dependencies[name].some((d) => d.target === previousName));
+    builder.removeNode(node.name);
+    invBuilder.removeNode(node.name);
+    // modify the node and re-add it
+    node.name = `npm:${node.data.packageName}`;
+    builder.addExternalNode(node);
+    invBuilder.addExternalNode(node);
+    targets.forEach((target) => {
+        builder.addStaticDependency(node.name, target);
+        invBuilder.addStaticDependency(target, node.name);
+    });
+    sources.forEach((source) => {
+        builder.addStaticDependency(source, node.name);
+        invBuilder.addStaticDependency(node.name, source);
+    });
+}
+// BFS to find the shortest path to a dependency specified in package.json
+// package version with the shortest path is the one that should be hoisted
+function pathLengthToIncoming(node, packageJsonDeps, builder, invertedGraph) {
+    const visited = new Set([node.name]);
+    const queue = [[node, 0]];
+    while (queue.length > 0) {
+        const [current, distance] = queue.shift();
+        if (packageJsonDeps[current.data.packageName] === current.data.version) {
+            return distance;
+        }
+        for (let { target } of invertedGraph.dependencies[current.name] || []) {
+            if (!visited.has(target)) {
+                visited.add(target);
+                queue.push([builder.graph.externalNodes[target], distance + 1]);
+            }
+        }
     }
-  } // UUID timestamps are 100 nano-second units since the Gregorian epoch,
-  // (1582-10-15 00:00).  JSNumbers aren't precise enough for this, so
-  // time is handled internally as 'msecs' (integer milliseconds) and 'nsecs'
-  // (100-nanoseconds offset from msecs) since unix epoch, 1970-01-01 00:00.
-
-
-  let msecs = options.msecs !== undefined ? options.msecs : Date.now(); // Per 4.2.1.2, use count of uuid's generated during the current clock
-  // cycle to simulate higher resolution clock
-
-  let nsecs = options.nsecs !== undefined ? options.nsecs : _lastNSecs + 1; // Time since last uuid creation (in msecs)
-
-  const dt = msecs - _lastMSecs + (nsecs - _lastNSecs) / 10000; // Per 4.2.1.2, Bump clockseq on clock regression
-
-  if (dt < 0 && options.clockseq === undefined) {
-    clockseq = clockseq + 1 & 0x3fff;
-  } // Reset nsecs if clock regresses (new clockseq) or we've moved onto a new
-  // time interval
-
-
-  if ((dt < 0 || msecs > _lastMSecs) && options.nsecs === undefined) {
-    nsecs = 0;
-  } // Per 4.2.1.2 Throw error if too many uuids are requested
-
-
-  if (nsecs >= 10000) {
-    throw new Error("uuid.v1(): Can't create more than 10M uuids/sec");
-  }
-
-  _lastMSecs = msecs;
-  _lastNSecs = nsecs;
-  _clockseq = clockseq; // Per 4.1.4 - Convert from unix epoch to Gregorian epoch
-
-  msecs += 12219292800000; // `time_low`
-
-  const tl = ((msecs & 0xfffffff) * 10000 + nsecs) % 0x100000000;
-  b[i++] = tl >>> 24 & 0xff;
-  b[i++] = tl >>> 16 & 0xff;
-  b[i++] = tl >>> 8 & 0xff;
-  b[i++] = tl & 0xff; // `time_mid`
-
-  const tmh = msecs / 0x100000000 * 10000 & 0xfffffff;
-  b[i++] = tmh >>> 8 & 0xff;
-  b[i++] = tmh & 0xff; // `time_high_and_version`
-
-  b[i++] = tmh >>> 24 & 0xf | 0x10; // include version
-
-  b[i++] = tmh >>> 16 & 0xff; // `clock_seq_hi_and_reserved` (Per 4.2.2 - include variant)
-
-  b[i++] = clockseq >>> 8 | 0x80; // `clock_seq_low`
-
-  b[i++] = clockseq & 0xff; // `node`
-
-  for (let n = 0; n < 6; ++n) {
-    b[i + n] = node[n];
-  }
-
-  return buf || (0, _stringify.default)(b);
 }
 
-var _default = v1;
-exports["default"] = _default;
 
 /***/ }),
 
-/***/ 34643:
+/***/ 20992:
 /***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
 "use strict";
 
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.normalizePackageJson = exports.getHoistedPackageVersion = void 0;
+const fs_1 = __nccwpck_require__(57147);
+const workspace_root_1 = __nccwpck_require__(86708);
+/**
+ * Get version of hoisted package if available
+ */
+function getHoistedPackageVersion(packageName) {
+    const fullPath = `${workspace_root_1.workspaceRoot}/node_modules/${packageName}/package.json`;
+    if ((0, fs_1.existsSync)(fullPath)) {
+        const content = (0, fs_1.readFileSync)(fullPath, 'utf-8');
+        return JSON.parse(content)?.version;
+    }
+    return;
+}
+exports.getHoistedPackageVersion = getHoistedPackageVersion;
+/**
+ * Strip off non-pruning related fields from package.json
+ */
+function normalizePackageJson(packageJson) {
+    const { name, version, license, dependencies, devDependencies, peerDependencies, peerDependenciesMeta, optionalDependencies, } = packageJson;
+    return {
+        name,
+        version,
+        license,
+        dependencies,
+        devDependencies,
+        peerDependencies,
+        peerDependenciesMeta,
+        optionalDependencies,
+    };
+}
+exports.normalizePackageJson = normalizePackageJson;
 
-Object.defineProperty(exports, "__esModule", ({
-  value: true
-}));
-exports["default"] = void 0;
-
-var _v = _interopRequireDefault(__nccwpck_require__(70181));
-
-var _md = _interopRequireDefault(__nccwpck_require__(37342));
-
-function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
-
-const v3 = (0, _v.default)('v3', 0x30, _md.default);
-var _default = v3;
-exports["default"] = _default;
 
 /***/ }),
 
-/***/ 70181:
+/***/ 93434:
 /***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
 "use strict";
 
-
-Object.defineProperty(exports, "__esModule", ({
-  value: true
-}));
-exports["default"] = _default;
-exports.URL = exports.DNS = void 0;
-
-var _stringify = _interopRequireDefault(__nccwpck_require__(82332));
-
-var _parse = _interopRequireDefault(__nccwpck_require__(9869));
-
-function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
-
-function stringToBytes(str) {
-  str = unescape(encodeURIComponent(str)); // UTF8 escape
-
-  const bytes = [];
-
-  for (let i = 0; i < str.length; ++i) {
-    bytes.push(str.charCodeAt(i));
-  }
-
-  return bytes;
+/**
+ * This file contains the logic to convert pnpm lockfile to a standard format.
+ * It will convert inline specifiers to the separate specifiers format and ensure importers are present.
+ */
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.stringifyToPnpmYaml = exports.parseAndNormalizePnpmLockfile = exports.loadPnpmHoistedDepsDefinition = exports.isV6Lockfile = void 0;
+const fs_1 = __nccwpck_require__(57147);
+const workspace_root_1 = __nccwpck_require__(86708);
+const semver_1 = __nccwpck_require__(66195);
+function isV6Lockfile(data) {
+    return data.lockfileVersion.toString().startsWith('6.');
 }
-
-const DNS = '6ba7b810-9dad-11d1-80b4-00c04fd430c8';
-exports.DNS = DNS;
-const URL = '6ba7b811-9dad-11d1-80b4-00c04fd430c8';
-exports.URL = URL;
-
-function _default(name, version, hashfunc) {
-  function generateUUID(value, namespace, buf, offset) {
-    if (typeof value === 'string') {
-      value = stringToBytes(value);
+exports.isV6Lockfile = isV6Lockfile;
+function loadPnpmHoistedDepsDefinition() {
+    const fullPath = `${workspace_root_1.workspaceRoot}/node_modules/.modules.yaml`;
+    if ((0, fs_1.existsSync)(fullPath)) {
+        const content = (0, fs_1.readFileSync)(fullPath, 'utf-8');
+        const { load } = __nccwpck_require__(74529);
+        return load(content)?.hoistedDependencies ?? {};
     }
-
-    if (typeof namespace === 'string') {
-      namespace = (0, _parse.default)(namespace);
+    else {
+        throw new Error(`Could not find ".modules.yaml" at "${fullPath}"`);
     }
-
-    if (namespace.length !== 16) {
-      throw TypeError('Namespace must be array-like (16 iterable integer values, 0-255)');
-    } // Compute hash of namespace and value, Per 4.3
-    // Future: Use spread syntax when supported on all platforms, e.g. `bytes =
-    // hashfunc([...namespace, ... value])`
-
-
-    let bytes = new Uint8Array(16 + value.length);
-    bytes.set(namespace);
-    bytes.set(value, namespace.length);
-    bytes = hashfunc(bytes);
-    bytes[6] = bytes[6] & 0x0f | version;
-    bytes[8] = bytes[8] & 0x3f | 0x80;
-
-    if (buf) {
-      offset = offset || 0;
-
-      for (let i = 0; i < 16; ++i) {
-        buf[offset + i] = bytes[i];
-      }
-
-      return buf;
+}
+exports.loadPnpmHoistedDepsDefinition = loadPnpmHoistedDepsDefinition;
+/*************************************************************************
+ * THE FOLLOWING CODE IS COPIED & simplified FROM @pnpm/lockfile-file for convenience
+ *************************************************************************/
+/**
+ * Parsing and mapping logic from pnpm lockfile `read` function
+ * https://github.com/pnpm/pnpm/blob/af3e5559d377870d4c3d303429b3ed1a4e64fedc/lockfile/lockfile-file/src/read.ts#L91
+ */
+function parseAndNormalizePnpmLockfile(content) {
+    const { load } = __nccwpck_require__(74529);
+    const lockFileData = load(content);
+    return revertFromInlineSpecifiersFormatIfNecessary(convertFromLockfileFileMutable(lockFileData));
+}
+exports.parseAndNormalizePnpmLockfile = parseAndNormalizePnpmLockfile;
+/**
+ * Reverts changes from the "forceSharedFormat" write option if necessary.
+ * https://github.com/pnpm/pnpm/blob/af3e5559d377870d4c3d303429b3ed1a4e64fedc/lockfile/lockfile-file/src/read.ts#L234
+ */
+function convertFromLockfileFileMutable(lockfileFile) {
+    if (typeof lockfileFile?.['importers'] === 'undefined') {
+        lockfileFile.importers = {
+            '.': {
+                specifiers: lockfileFile['specifiers'] ?? {},
+                dependenciesMeta: lockfileFile['dependenciesMeta'],
+                publishDirectory: lockfileFile['publishDirectory'],
+            },
+        };
+        delete lockfileFile.specifiers;
+        for (const depType of DEPENDENCIES_FIELDS) {
+            if (lockfileFile[depType] != null) {
+                lockfileFile.importers['.'][depType] = lockfileFile[depType];
+                delete lockfileFile[depType];
+            }
+        }
+    }
+    return lockfileFile;
+}
+// https://github.com/pnpm/pnpm/blob/af3e5559d377870d4c3d303429b3ed1a4e64fedc/lockfile/lockfile-file/src/write.ts#L27
+const LOCKFILE_YAML_FORMAT = {
+    blankLines: true,
+    lineWidth: 1000,
+    noCompatMode: true,
+    noRefs: true,
+    sortKeys: false,
+};
+/**
+ * Mapping and writing logic from pnpm lockfile `write` function
+ * https://github.com/pnpm/pnpm/blob/af3e5559d377870d4c3d303429b3ed1a4e64fedc/lockfile/lockfile-file/src/write.ts#L77
+ */
+function stringifyToPnpmYaml(lockfile) {
+    const isLockfileV6 = isV6Lockfile(lockfile);
+    const adaptedLockfile = isLockfileV6
+        ? convertToInlineSpecifiersFormat(lockfile)
+        : lockfile;
+    const { dump } = __nccwpck_require__(74529);
+    return dump(sortLockfileKeys(normalizeLockfile(adaptedLockfile, isLockfileV6)), LOCKFILE_YAML_FORMAT);
+}
+exports.stringifyToPnpmYaml = stringifyToPnpmYaml;
+// https://github.com/pnpm/pnpm/blob/af3e5559d377870d4c3d303429b3ed1a4e64fedc/lockfile/lockfile-file/src/write.ts#L106
+function normalizeLockfile(lockfile, isLockfileV6) {
+    let lockfileToSave;
+    if (Object.keys(lockfile.importers).length === 1 && lockfile.importers['.']) {
+        lockfileToSave = {
+            ...lockfile,
+            ...lockfile.importers['.'],
+        };
+        delete lockfileToSave.importers;
+        for (const depType of DEPENDENCIES_FIELDS) {
+            if (isEmpty(lockfileToSave[depType])) {
+                delete lockfileToSave[depType];
+            }
+        }
+        if (isEmpty(lockfileToSave.packages) || lockfileToSave.packages == null) {
+            delete lockfileToSave.packages;
+        }
+    }
+    else {
+        lockfileToSave = {
+            ...lockfile,
+            importers: mapValues(lockfile.importers, (importer) => {
+                const normalizedImporter = {};
+                if (!isEmpty(importer.specifiers ?? {}) || !isLockfileV6) {
+                    normalizedImporter['specifiers'] = importer.specifiers ?? {};
+                }
+                if (importer.dependenciesMeta != null &&
+                    !isEmpty(importer.dependenciesMeta)) {
+                    normalizedImporter['dependenciesMeta'] = importer.dependenciesMeta;
+                }
+                for (const depType of DEPENDENCIES_FIELDS) {
+                    if (!isEmpty(importer[depType] ?? {})) {
+                        normalizedImporter[depType] = importer[depType];
+                    }
+                }
+                if (importer.publishDirectory) {
+                    normalizedImporter.publishDirectory = importer.publishDirectory;
+                }
+                return normalizedImporter;
+            }),
+        };
+        if (isEmpty(lockfileToSave.packages) || lockfileToSave.packages == null) {
+            delete lockfileToSave.packages;
+        }
+    }
+    if (lockfileToSave.time) {
+        lockfileToSave.time = (isLockfileV6 ? pruneTimeInLockfileV6 : pruneTime)(lockfileToSave.time, lockfile.importers);
+    }
+    if (lockfileToSave.overrides != null && isEmpty(lockfileToSave.overrides)) {
+        delete lockfileToSave.overrides;
+    }
+    if (lockfileToSave.patchedDependencies != null &&
+        isEmpty(lockfileToSave.patchedDependencies)) {
+        delete lockfileToSave.patchedDependencies;
+    }
+    if (lockfileToSave.neverBuiltDependencies != null) {
+        if (isEmpty(lockfileToSave.neverBuiltDependencies)) {
+            delete lockfileToSave.neverBuiltDependencies;
+        }
+        else {
+            lockfileToSave.neverBuiltDependencies =
+                lockfileToSave.neverBuiltDependencies.sort();
+        }
+    }
+    if (lockfileToSave.onlyBuiltDependencies != null) {
+        lockfileToSave.onlyBuiltDependencies =
+            lockfileToSave.onlyBuiltDependencies.sort();
+    }
+    if (!lockfileToSave.packageExtensionsChecksum) {
+        delete lockfileToSave.packageExtensionsChecksum;
+    }
+    return lockfileToSave;
+}
+// https://github.com/pnpm/pnpm/blob/af3e5559d377870d4c3d303429b3ed1a4e64fedc/lockfile/lockfile-file/src/write.ts#L173
+function pruneTimeInLockfileV6(time, importers) {
+    const rootDepPaths = new Set();
+    for (const importer of Object.values(importers)) {
+        for (const depType of DEPENDENCIES_FIELDS) {
+            for (let [depName, ref] of Object.entries(importer[depType] ?? {})) {
+                let version;
+                if (ref['version']) {
+                    version = ref['version'];
+                }
+                else {
+                    version = ref;
+                }
+                const suffixStart = version.indexOf('(');
+                const refWithoutPeerSuffix = suffixStart === -1 ? version : version.slice(0, suffixStart);
+                const depPath = refToRelative(refWithoutPeerSuffix, depName);
+                if (!depPath)
+                    continue;
+                rootDepPaths.add(depPath);
+            }
+        }
+    }
+    return pickBy((prop) => rootDepPaths.has(prop), time);
+}
+// https://github.com/pnpm/pnpm/blob/af3e5559d377870d4c3d303429b3ed1a4e64fedc/lockfile/lockfile-file/src/write.ts#L191
+function refToRelative(reference, pkgName) {
+    if (reference.startsWith('link:')) {
+        return null;
+    }
+    if (reference.startsWith('file:')) {
+        return reference;
+    }
+    if (!reference.includes('/') ||
+        !reference.replace(/(\([^)]+\))+$/, '').includes('/')) {
+        return `/${pkgName}@${reference}`;
+    }
+    return reference;
+}
+// https://github.com/pnpm/pnpm/blob/af3e5559d377870d4c3d303429b3ed1a4e64fedc/lockfile/lockfile-file/src/write.ts#L207
+function pruneTime(time, importers) {
+    const rootDepPaths = new Set();
+    for (const importer of Object.values(importers)) {
+        for (const depType of DEPENDENCIES_FIELDS) {
+            for (let [depName, ref] of Object.entries(importer[depType] ?? {})) {
+                let version;
+                if (ref['version']) {
+                    version = ref['version'];
+                }
+                else {
+                    version = ref;
+                }
+                const suffixStart = version.indexOf('_');
+                const refWithoutPeerSuffix = suffixStart === -1 ? version : version.slice(0, suffixStart);
+                const depPath = dpRefToRelative(refWithoutPeerSuffix, depName);
+                if (!depPath)
+                    continue;
+                rootDepPaths.add(depPath);
+            }
+        }
+    }
+    return pickBy((depPath) => rootDepPaths.has(depPath), time);
+}
+// https://github.com/pnpm/pnpm/blob/af3e5559d377870d4c3d303429b3ed1a4e64fedc/lockfile/lockfile-file/src/sortLockfileKeys.ts#L34
+const ROOT_KEYS_ORDER = {
+    lockfileVersion: 1,
+    // only and never are conflict options.
+    neverBuiltDependencies: 2,
+    onlyBuiltDependencies: 2,
+    overrides: 3,
+    packageExtensionsChecksum: 4,
+    patchedDependencies: 5,
+    specifiers: 10,
+    dependencies: 11,
+    optionalDependencies: 12,
+    devDependencies: 13,
+    dependenciesMeta: 14,
+    importers: 15,
+    packages: 16,
+};
+// https://github.com/pnpm/pnpm/blob/af3e5559d377870d4c3d303429b3ed1a4e64fedc/lockfile/lockfile-file/src/sortLockfileKeys.ts#L60
+function sortLockfileKeys(lockfile) {
+    let sortedLockfile = {};
+    const sortedKeys = Object.keys(lockfile).sort((a, b) => ROOT_KEYS_ORDER[a] - ROOT_KEYS_ORDER[b]);
+    for (const key of sortedKeys) {
+        sortedLockfile[key] = lockfile[key];
+    }
+    return sortedLockfile;
+}
+/**
+ * Types from https://github.com/pnpm/pnpm/blob/af3e5559d377870d4c3d303429b3ed1a4e64fedc/lockfile/lockfile-file/src/experiments/InlineSpecifiersLockfile.ts
+ */
+const INLINE_SPECIFIERS_FORMAT_LOCKFILE_VERSION_SUFFIX = '-inlineSpecifiers';
+// https://github.com/pnpm/pnpm/blob/af3e5559d377870d4c3d303429b3ed1a4e64fedc/lockfile/lockfile-file/src/experiments/inlineSpecifiersLockfileConverters.ts#L10
+function isExperimentalInlineSpecifiersFormat(lockfile) {
+    const { lockfileVersion } = lockfile;
+    return (lockfileVersion.toString().startsWith('6.') ||
+        (typeof lockfileVersion === 'string' &&
+            lockfileVersion.endsWith(INLINE_SPECIFIERS_FORMAT_LOCKFILE_VERSION_SUFFIX)));
+}
+// https://github.com/pnpm/pnpm/blob/af3e5559d377870d4c3d303429b3ed1a4e64fedc/lockfile/lockfile-file/src/experiments/inlineSpecifiersLockfileConverters.ts#L17
+function convertToInlineSpecifiersFormat(lockfile) {
+    let importers = lockfile.importers;
+    let packages = lockfile.packages;
+    if (isV6Lockfile(lockfile)) {
+        importers = Object.fromEntries(Object.entries(lockfile.importers ?? {}).map(([importerId, pkgSnapshot]) => {
+            const newSnapshot = { ...pkgSnapshot };
+            if (newSnapshot.dependencies != null) {
+                newSnapshot.dependencies = mapValues(newSnapshot.dependencies, convertOldRefToNewRef);
+            }
+            if (newSnapshot.optionalDependencies != null) {
+                newSnapshot.optionalDependencies = mapValues(newSnapshot.optionalDependencies, convertOldRefToNewRef);
+            }
+            if (newSnapshot.devDependencies != null) {
+                newSnapshot.devDependencies = mapValues(newSnapshot.devDependencies, convertOldRefToNewRef);
+            }
+            return [importerId, newSnapshot];
+        }));
+        packages = Object.fromEntries(Object.entries(lockfile.packages ?? {}).map(([depPath, pkgSnapshot]) => {
+            const newSnapshot = { ...pkgSnapshot };
+            if (newSnapshot.dependencies != null) {
+                newSnapshot.dependencies = mapValues(newSnapshot.dependencies, convertOldRefToNewRef);
+            }
+            if (newSnapshot.optionalDependencies != null) {
+                newSnapshot.optionalDependencies = mapValues(newSnapshot.optionalDependencies, convertOldRefToNewRef);
+            }
+            return [convertOldDepPathToNewDepPath(depPath), newSnapshot];
+        }));
+    }
+    const newLockfile = {
+        ...lockfile,
+        packages,
+        lockfileVersion: isV6Lockfile(lockfile)
+            ? lockfile.lockfileVersion.toString()
+            : lockfile.lockfileVersion
+                .toString()
+                .endsWith(INLINE_SPECIFIERS_FORMAT_LOCKFILE_VERSION_SUFFIX)
+                ? lockfile.lockfileVersion.toString()
+                : `${lockfile.lockfileVersion}${INLINE_SPECIFIERS_FORMAT_LOCKFILE_VERSION_SUFFIX}`,
+        importers: mapValues(importers, convertProjectSnapshotToInlineSpecifiersFormat),
+    };
+    if (isV6Lockfile(lockfile) && newLockfile.time) {
+        newLockfile.time = Object.fromEntries(Object.entries(newLockfile.time).map(([depPath, time]) => [
+            convertOldDepPathToNewDepPath(depPath),
+            time,
+        ]));
+    }
+    return newLockfile;
+}
+// https://github.com/pnpm/pnpm/blob/af3e5559d377870d4c3d303429b3ed1a4e64fedc/lockfile/lockfile-file/src/experiments/inlineSpecifiersLockfileConverters.ts#L72
+function convertOldDepPathToNewDepPath(oldDepPath) {
+    const parsedDepPath = dpParse(oldDepPath);
+    if (!parsedDepPath.name || !parsedDepPath.version)
+        return oldDepPath;
+    let newDepPath = `/${parsedDepPath.name}@${parsedDepPath.version}`;
+    if (parsedDepPath.peersSuffix) {
+        if (parsedDepPath.peersSuffix.startsWith('(')) {
+            newDepPath += parsedDepPath.peersSuffix;
+        }
+        else {
+            newDepPath += `_${parsedDepPath.peersSuffix}`;
+        }
+    }
+    if (parsedDepPath.host) {
+        newDepPath = `${parsedDepPath.host}${newDepPath}`;
+    }
+    return newDepPath;
+}
+// https://github.com/pnpm/pnpm/blob/af3e5559d377870d4c3d303429b3ed1a4e64fedc/lockfile/lockfile-file/src/experiments/inlineSpecifiersLockfileConverters.ts#L89
+function convertOldRefToNewRef(oldRef) {
+    if (oldRef.startsWith('link:') || oldRef.startsWith('file:')) {
+        return oldRef;
+    }
+    if (oldRef.includes('/')) {
+        return convertOldDepPathToNewDepPath(oldRef);
+    }
+    return oldRef;
+}
+// https://github.com/pnpm/pnpm/blob/af3e5559d377870d4c3d303429b3ed1a4e64fedc/lockfile/lockfile-file/src/experiments/inlineSpecifiersLockfileConverters.ts#L99
+function revertFromInlineSpecifiersFormatIfNecessary(lockfile) {
+    return isExperimentalInlineSpecifiersFormat(lockfile)
+        ? revertFromInlineSpecifiersFormat(lockfile)
+        : lockfile;
+}
+// https://github.com/pnpm/pnpm/blob/af3e5559d377870d4c3d303429b3ed1a4e64fedc/lockfile/lockfile-file/src/experiments/inlineSpecifiersLockfileConverters.ts#L105
+function revertFromInlineSpecifiersFormat(lockfile) {
+    const { lockfileVersion, importers, ...rest } = lockfile;
+    const originalVersionStr = lockfileVersion.replace(INLINE_SPECIFIERS_FORMAT_LOCKFILE_VERSION_SUFFIX, '');
+    const originalVersion = Number(originalVersionStr);
+    if (isNaN(originalVersion)) {
+        throw new Error(`Unable to revert lockfile from inline specifiers format. Invalid version parsed: ${originalVersionStr}`);
+    }
+    let revertedImporters = mapValues(importers, revertProjectSnapshot);
+    let packages = lockfile.packages;
+    if (originalVersionStr.startsWith('6.')) {
+        revertedImporters = Object.fromEntries(Object.entries(revertedImporters ?? {}).map(([importerId, pkgSnapshot]) => {
+            const newSnapshot = { ...pkgSnapshot };
+            if (newSnapshot.dependencies != null) {
+                newSnapshot.dependencies = mapValues(newSnapshot.dependencies, convertNewRefToOldRef);
+            }
+            if (newSnapshot.optionalDependencies != null) {
+                newSnapshot.optionalDependencies = mapValues(newSnapshot.optionalDependencies, convertNewRefToOldRef);
+            }
+            if (newSnapshot.devDependencies != null) {
+                newSnapshot.devDependencies = mapValues(newSnapshot.devDependencies, convertNewRefToOldRef);
+            }
+            return [importerId, newSnapshot];
+        }));
+        packages = Object.fromEntries(Object.entries(lockfile.packages ?? {}).map(([depPath, pkgSnapshot]) => {
+            const newSnapshot = { ...pkgSnapshot };
+            if (newSnapshot.dependencies != null) {
+                newSnapshot.dependencies = mapValues(newSnapshot.dependencies, convertNewRefToOldRef);
+            }
+            if (newSnapshot.optionalDependencies != null) {
+                newSnapshot.optionalDependencies = mapValues(newSnapshot.optionalDependencies, convertNewRefToOldRef);
+            }
+            return [convertNewDepPathToOldDepPath(depPath), newSnapshot];
+        }));
+    }
+    const newLockfile = {
+        ...rest,
+        lockfileVersion: lockfileVersion.endsWith(INLINE_SPECIFIERS_FORMAT_LOCKFILE_VERSION_SUFFIX)
+            ? originalVersion
+            : lockfileVersion,
+        packages,
+        importers: revertedImporters,
+    };
+    if (originalVersionStr.startsWith('6.') && newLockfile.time) {
+        newLockfile.time = Object.fromEntries(Object.entries(newLockfile.time).map(([depPath, time]) => [
+            convertNewDepPathToOldDepPath(depPath),
+            time,
+        ]));
+    }
+    return newLockfile;
+}
+// https://github.com/pnpm/pnpm/blob/af3e5559d377870d4c3d303429b3ed1a4e64fedc/lockfile/lockfile-file/src/experiments/inlineSpecifiersLockfileConverters.ts#L162
+function convertNewDepPathToOldDepPath(oldDepPath) {
+    if (!oldDepPath.includes('@', 2))
+        return oldDepPath;
+    const index = oldDepPath.indexOf('@', oldDepPath.indexOf('/@') + 2);
+    if (oldDepPath.includes('(') && index > oldDepPath.indexOf('('))
+        return oldDepPath;
+    return `${oldDepPath.substring(0, index)}/${oldDepPath.substring(index + 1)}`;
+}
+// https://github.com/pnpm/pnpm/blob/af3e5559d377870d4c3d303429b3ed1a4e64fedc/lockfile/lockfile-file/src/experiments/inlineSpecifiersLockfileConverters.ts#L169
+function convertNewRefToOldRef(oldRef) {
+    if (oldRef.startsWith('link:') || oldRef.startsWith('file:')) {
+        return oldRef;
+    }
+    if (oldRef.includes('@')) {
+        return convertNewDepPathToOldDepPath(oldRef);
+    }
+    return oldRef;
+}
+// https://github.com/pnpm/pnpm/blob/af3e5559d377870d4c3d303429b3ed1a4e64fedc/lockfile/lockfile-file/src/experiments/inlineSpecifiersLockfileConverters.ts#L179
+function convertProjectSnapshotToInlineSpecifiersFormat(projectSnapshot) {
+    const { specifiers, ...rest } = projectSnapshot;
+    const convertBlock = (block) => block != null
+        ? convertResolvedDependenciesToInlineSpecifiersFormat(block, {
+            specifiers,
+        })
+        : block;
+    return {
+        ...rest,
+        dependencies: convertBlock(projectSnapshot.dependencies),
+        optionalDependencies: convertBlock(projectSnapshot.optionalDependencies),
+        devDependencies: convertBlock(projectSnapshot.devDependencies),
+    };
+}
+// https://github.com/pnpm/pnpm/blob/af3e5559d377870d4c3d303429b3ed1a4e64fedc/lockfile/lockfile-file/src/experiments/inlineSpecifiersLockfileConverters.ts#L195
+function convertResolvedDependenciesToInlineSpecifiersFormat(resolvedDependencies, { specifiers }) {
+    return mapValues(resolvedDependencies, (version, depName) => ({
+        specifier: specifiers[depName],
+        version,
+    }));
+}
+// https://github.com/pnpm/pnpm/blob/af3e5559d377870d4c3d303429b3ed1a4e64fedc/lockfile/lockfile-file/src/experiments/inlineSpecifiersLockfileConverters.ts#L205
+function revertProjectSnapshot(from) {
+    const specifiers = {};
+    function moveSpecifiers(from) {
+        const resolvedDependencies = {};
+        for (const [depName, { specifier, version }] of Object.entries(from)) {
+            const existingValue = specifiers[depName];
+            if (existingValue != null && existingValue !== specifier) {
+                throw new Error(`Project snapshot lists the same dependency more than once with conflicting versions: ${depName}`);
+            }
+            specifiers[depName] = specifier;
+            resolvedDependencies[depName] = version;
+        }
+        return resolvedDependencies;
+    }
+    const dependencies = from.dependencies
+        ? moveSpecifiers(from.dependencies)
+        : null;
+    const devDependencies = from.devDependencies
+        ? moveSpecifiers(from.devDependencies)
+        : null;
+    const optionalDependencies = from.optionalDependencies
+        ? moveSpecifiers(from.optionalDependencies)
+        : null;
+    return {
+        ...from,
+        specifiers,
+        dependencies,
+        devDependencies,
+        optionalDependencies,
+    };
+}
+// https://github.com/pnpm/pnpm/blob/af3e5559d377870d4c3d303429b3ed1a4e64fedc/lockfile/lockfile-file/src/experiments/inlineSpecifiersLockfileConverters.ts#L241
+function mapValues(obj, mapper) {
+    const result = {};
+    for (const [key, value] of Object.entries(obj)) {
+        result[key] = mapper(value, key);
+    }
+    return result;
+}
+/*************************************************************************
+ * THE FOLLOWING CODE IS COPIED FROM @pnpm/types for convenience
+ *************************************************************************/
+// https://github.com/pnpm/pnpm/blob/af3e5559d377870d4c3d303429b3ed1a4e64fedc/packages/types/src/misc.ts#L6
+const DEPENDENCIES_FIELDS = [
+    'optionalDependencies',
+    'dependencies',
+    'devDependencies',
+];
+/*************************************************************************
+ * THE FOLLOWING CODE IS COPIED FROM @pnpm/dependency-path for convenience
+ *************************************************************************/
+// https://github.com/pnpm/pnpm/blob/af3e5559d377870d4c3d303429b3ed1a4e64fedc/packages/dependency-path/src/index.ts#L6
+function isAbsolute(dependencyPath) {
+    return dependencyPath[0] !== '/';
+}
+// https://github.com/pnpm/pnpm/blob/af3e5559d377870d4c3d303429b3ed1a4e64fedc/packages/dependency-path/src/index.ts#L80
+function dpRefToRelative(reference, pkgName) {
+    if (reference.startsWith('link:')) {
+        return null;
+    }
+    if (reference.startsWith('file:')) {
+        return reference;
+    }
+    if (!reference.includes('/') ||
+        (reference.includes('(') &&
+            reference.lastIndexOf('/', reference.indexOf('(')) === -1)) {
+        return `/${pkgName}/${reference}`;
+    }
+    return reference;
+}
+// https://github.com/pnpm/pnpm/blob/af3e5559d377870d4c3d303429b3ed1a4e64fedc/packages/dependency-path/src/index.ts#L96
+function dpParse(dependencyPath) {
+    // eslint-disable-next-line: strict-type-predicates
+    if (typeof dependencyPath !== 'string') {
+        throw new TypeError(`Expected \`dependencyPath\` to be of type \`string\`, got \`${
+        // eslint-disable-next-line: strict-type-predicates
+        dependencyPath === null ? 'null' : typeof dependencyPath}\``);
+    }
+    const _isAbsolute = isAbsolute(dependencyPath);
+    const parts = dependencyPath.split('/');
+    if (!_isAbsolute)
+        parts.shift();
+    const host = _isAbsolute ? parts.shift() : undefined;
+    if (parts.length === 0)
+        return {
+            host,
+            isAbsolute: _isAbsolute,
+        };
+    const name = parts[0].startsWith('@')
+        ? `${parts.shift()}/${parts.shift()}` // eslint-disable-line @typescript-eslint/restrict-template-expressions
+        : parts.shift();
+    let version = parts.join('/');
+    if (version) {
+        let peerSepIndex;
+        let peersSuffix;
+        if (version.includes('(') && version.endsWith(')')) {
+            peerSepIndex = version.indexOf('(');
+            if (peerSepIndex !== -1) {
+                peersSuffix = version.substring(peerSepIndex);
+                version = version.substring(0, peerSepIndex);
+            }
+        }
+        else {
+            peerSepIndex = version.indexOf('_');
+            if (peerSepIndex !== -1) {
+                peersSuffix = version.substring(peerSepIndex + 1);
+                version = version.substring(0, peerSepIndex);
+            }
+        }
+        if ((0, semver_1.valid)(version)) {
+            return {
+                host,
+                isAbsolute: _isAbsolute,
+                name,
+                peersSuffix,
+                version,
+            };
+        }
     }
-
-    return (0, _stringify.default)(bytes);
-  } // Function#name is not settable on some platforms (#270)
-
-
-  try {
-    generateUUID.name = name; // eslint-disable-next-line no-empty
-  } catch (err) {} // For CommonJS default export support
-
-
-  generateUUID.DNS = DNS;
-  generateUUID.URL = URL;
-  return generateUUID;
+    if (!_isAbsolute)
+        throw new Error(`${dependencyPath} is an invalid relative dependency path`);
+    return {
+        host,
+        isAbsolute: _isAbsolute,
+    };
 }
-
-/***/ }),
-
-/***/ 39370:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
-
-"use strict";
-
-
-Object.defineProperty(exports, "__esModule", ({
-  value: true
-}));
-exports["default"] = void 0;
-
-var _rng = _interopRequireDefault(__nccwpck_require__(64315));
-
-var _stringify = _interopRequireDefault(__nccwpck_require__(82332));
-
-function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
-
-function v4(options, buf, offset) {
-  options = options || {};
-
-  const rnds = options.random || (options.rng || _rng.default)(); // Per 4.4, set bits for version and `clock_seq_hi_and_reserved`
-
-
-  rnds[6] = rnds[6] & 0x0f | 0x40;
-  rnds[8] = rnds[8] & 0x3f | 0x80; // Copy bytes to buffer, if provided
-
-  if (buf) {
-    offset = offset || 0;
-
-    for (let i = 0; i < 16; ++i) {
-      buf[offset + i] = rnds[i];
+/********************************************************************************
+ * THE FOLLOWING CODE IS COPIED AND SIMPLIFIED FROM @pnpm/ramda for convenience
+ *******************************************************************************/
+// https://github.com/pnpm/ramda/blob/50c6b57110b2f3631ed8633141f12012b7768d85/source/pickBy.js#L24
+function pickBy(test, obj) {
+    let result = {};
+    for (const prop in obj) {
+        if (test(obj[prop])) {
+            result[prop] = obj[prop];
+        }
     }
-
-    return buf;
-  }
-
-  return (0, _stringify.default)(rnds);
+    return result;
 }
-
-var _default = v4;
-exports["default"] = _default;
-
-/***/ }),
-
-/***/ 93249:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
-
-"use strict";
-
-
-Object.defineProperty(exports, "__esModule", ({
-  value: true
-}));
-exports["default"] = void 0;
-
-var _v = _interopRequireDefault(__nccwpck_require__(70181));
-
-var _sha = _interopRequireDefault(__nccwpck_require__(19843));
-
-function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
-
-const v5 = (0, _v.default)('v5', 0x50, _sha.default);
-var _default = v5;
-exports["default"] = _default;
-
-/***/ }),
-
-/***/ 63498:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
-
-"use strict";
-
-
-Object.defineProperty(exports, "__esModule", ({
-  value: true
-}));
-exports["default"] = void 0;
-
-var _regex = _interopRequireDefault(__nccwpck_require__(65409));
-
-function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
-
-function validate(uuid) {
-  return typeof uuid === 'string' && _regex.default.test(uuid);
+// https://github.com/pnpm/ramda/blob/50c6b57110b2f3631ed8633141f12012b7768d85/source/isEmpty.js#L28
+function isEmpty(obj) {
+    return obj != null && Object.keys(obj).length === 0;
 }
 
-var _default = validate;
-exports["default"] = _default;
 
 /***/ }),
 
-/***/ 14698:
+/***/ 83243:
 /***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
 "use strict";
 
-
-Object.defineProperty(exports, "__esModule", ({
-  value: true
-}));
-exports["default"] = void 0;
-
-var _validate = _interopRequireDefault(__nccwpck_require__(63498));
-
-function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
-
-function version(uuid) {
-  if (!(0, _validate.default)(uuid)) {
-    throw TypeError('Invalid UUID');
-  }
-
-  return parseInt(uuid.substr(14, 1), 16);
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.stringifyYarnLockfile = exports.getYarnLockfileDependencies = exports.getYarnLockfileNodes = void 0;
+const package_json_1 = __nccwpck_require__(20992);
+const project_graph_builder_1 = __nccwpck_require__(80862);
+const semver_1 = __nccwpck_require__(66195);
+const project_graph_1 = __nccwpck_require__(2184);
+const file_hasher_1 = __nccwpck_require__(50180);
+const object_sort_1 = __nccwpck_require__(84110);
+let currentLockFileHash;
+let cachedParsedLockFile;
+// we use key => node map to avoid duplicate work when parsing keys
+let keyMap = new Map();
+function parseLockFile(lockFileContent, lockFileHash) {
+    if (currentLockFileHash === lockFileHash) {
+        return cachedParsedLockFile;
+    }
+    const { parseSyml } = __nccwpck_require__(2877);
+    keyMap.clear();
+    const result = parseSyml(lockFileContent);
+    cachedParsedLockFile = result;
+    currentLockFileHash = lockFileHash;
+    return result;
 }
-
-var _default = version;
-exports["default"] = _default;
-
-/***/ }),
-
-/***/ 25476:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
-
-"use strict";
-
-
-const Module = __nccwpck_require__(98188);
-const crypto = __nccwpck_require__(6113);
-const fs = __nccwpck_require__(57147);
-const path = __nccwpck_require__(71017);
-const vm = __nccwpck_require__(26144);
-const os = __nccwpck_require__(22037);
-
-const hasOwnProperty = Object.prototype.hasOwnProperty;
-
-//------------------------------------------------------------------------------
-// FileSystemBlobStore
-//------------------------------------------------------------------------------
-
-class FileSystemBlobStore {
-  constructor(directory, prefix) {
-    const name = prefix ? slashEscape(prefix + '.') : '';
-    this._blobFilename = path.join(directory, name + 'BLOB');
-    this._mapFilename = path.join(directory, name + 'MAP');
-    this._lockFilename = path.join(directory, name + 'LOCK');
-    this._directory = directory;
-    this._load();
-  }
-
-  has(key, invalidationKey) {
-    if (hasOwnProperty.call(this._memoryBlobs, key)) {
-      return this._invalidationKeys[key] === invalidationKey;
-    } else if (hasOwnProperty.call(this._storedMap, key)) {
-      return this._storedMap[key][0] === invalidationKey;
-    }
-    return false;
-  }
-
-  get(key, invalidationKey) {
-    if (hasOwnProperty.call(this._memoryBlobs, key)) {
-      if (this._invalidationKeys[key] === invalidationKey) {
-        return this._memoryBlobs[key];
-      }
-    } else if (hasOwnProperty.call(this._storedMap, key)) {
-      const mapping = this._storedMap[key];
-      if (mapping[0] === invalidationKey) {
-        return this._storedBlob.slice(mapping[1], mapping[2]);
-      }
+function getYarnLockfileNodes(lockFileContent, lockFileHash, packageJson) {
+    const { __metadata, ...dependencies } = parseLockFile(lockFileContent, lockFileHash);
+    const isBerry = !!__metadata;
+    // yarn classic splits keys when parsing so we need to stich them back together
+    const groupedDependencies = groupDependencies(dependencies, isBerry);
+    return getNodes(groupedDependencies, packageJson, keyMap, isBerry);
+}
+exports.getYarnLockfileNodes = getYarnLockfileNodes;
+function getYarnLockfileDependencies(lockFileContent, lockFileHash, ctx) {
+    const { __metadata, ...dependencies } = parseLockFile(lockFileContent, lockFileHash);
+    const isBerry = !!__metadata;
+    // yarn classic splits keys when parsing so we need to stich them back together
+    const groupedDependencies = groupDependencies(dependencies, isBerry);
+    return getDependencies(groupedDependencies, keyMap, ctx);
+}
+exports.getYarnLockfileDependencies = getYarnLockfileDependencies;
+function getPackageNameKeyPairs(keys) {
+    const result = new Map();
+    keys.split(', ').forEach((key) => {
+        const packageName = key.slice(0, key.indexOf('@', 1));
+        if (result.has(packageName)) {
+            result.get(packageName).add(key);
+        }
+        else {
+            result.set(packageName, new Set([key]));
+        }
+    });
+    return result;
+}
+function getNodes(dependencies, packageJson, keyMap, isBerry) {
+    const nodes = new Map();
+    const combinedDeps = {
+        ...packageJson.dependencies,
+        ...packageJson.devDependencies,
+        ...packageJson.peerDependencies,
+        ...packageJson.optionalDependencies,
+    };
+    Object.entries(dependencies).forEach(([keys, snapshot]) => {
+        // ignore workspace projects & patches
+        if (snapshot.linkType === 'soft' || keys.includes('@patch:')) {
+            return;
+        }
+        const nameKeyPairs = getPackageNameKeyPairs(keys);
+        nameKeyPairs.forEach((keySet, packageName) => {
+            const keysArray = Array.from(keySet);
+            // use key relevant to the package name
+            const version = findVersion(packageName, keysArray[0], snapshot, isBerry);
+            // use keys linked to the extracted package name
+            keysArray.forEach((key) => {
+                // we don't need to keep duplicates, we can just track the keys
+                const existingNode = nodes.get(packageName)?.get(version);
+                if (existingNode) {
+                    keyMap.set(key, existingNode);
+                    return;
+                }
+                const node = {
+                    type: 'npm',
+                    name: version
+                        ? `npm:${packageName}@${version}`
+                        : `npm:${packageName}`,
+                    data: {
+                        version,
+                        packageName,
+                        hash: snapshot.integrity ||
+                            snapshot.checksum ||
+                            (0, file_hasher_1.hashArray)([packageName, version]),
+                    },
+                };
+                keyMap.set(key, node);
+                // use actual version so we can detect it later based on npm package's version
+                const mapKey = snapshot.version && version !== snapshot.version
+                    ? snapshot.version
+                    : version;
+                if (!nodes.has(packageName)) {
+                    nodes.set(packageName, new Map([[mapKey, node]]));
+                }
+                else {
+                    nodes.get(packageName).set(mapKey, node);
+                }
+            });
+        });
+    });
+    const externalNodes = {};
+    for (const [packageName, versionMap] of nodes.entries()) {
+        const hoistedNode = findHoistedNode(packageName, versionMap, combinedDeps);
+        if (hoistedNode) {
+            hoistedNode.name = `npm:${packageName}`;
+        }
+        versionMap.forEach((node) => {
+            externalNodes[node.name] = node;
+        });
     }
-  }
-
-  set(key, invalidationKey, buffer) {
-    this._invalidationKeys[key] = invalidationKey;
-    this._memoryBlobs[key] = buffer;
-    this._dirty = true;
-  }
-
-  delete(key) {
-    if (hasOwnProperty.call(this._memoryBlobs, key)) {
-      this._dirty = true;
-      delete this._memoryBlobs[key];
+    return externalNodes;
+}
+function findHoistedNode(packageName, versionMap, combinedDeps) {
+    const hoistedVersion = getHoistedVersion(packageName);
+    if (hoistedVersion) {
+        return versionMap.get(hoistedVersion);
     }
-    if (hasOwnProperty.call(this._invalidationKeys, key)) {
-      this._dirty = true;
-      delete this._invalidationKeys[key];
+    const rootVersionSpecifier = combinedDeps[packageName];
+    if (!rootVersionSpecifier) {
+        return;
     }
-    if (hasOwnProperty.call(this._storedMap, key)) {
-      this._dirty = true;
-      delete this._storedMap[key];
+    const versions = Array.from(versionMap.keys()).sort((a, b) => (0, semver_1.gt)(a, b) ? -1 : 1);
+    // take the highest version found
+    if (rootVersionSpecifier === '*') {
+        return versionMap.get(versions[0]);
     }
-  }
-
-  isDirty() {
-    return this._dirty;
-  }
-
-  save() {
-    const dump = this._getDump();
-    const blobToStore = Buffer.concat(dump[0]);
-    const mapToStore = JSON.stringify(dump[1]);
-
-    try {
-      mkdirpSync(this._directory);
-      fs.writeFileSync(this._lockFilename, 'LOCK', {flag: 'wx'});
-    } catch (error) {
-      // Swallow the exception if we fail to acquire the lock.
-      return false;
+    // take version that satisfies the root version specifier
+    let version = versions.find((v) => (0, semver_1.satisfies)(v, rootVersionSpecifier));
+    if (!version) {
+        // try to find alias version
+        version = versions.find((v) => versionMap.get(v).name === `npm:${packageName}@${rootVersionSpecifier}`);
     }
-
-    try {
-      fs.writeFileSync(this._blobFilename, blobToStore);
-      fs.writeFileSync(this._mapFilename, mapToStore);
-    } finally {
-      fs.unlinkSync(this._lockFilename);
+    if (!version) {
+        // try to find tarball package
+        version = versions.find((v) => versionMap.get(v).data.version !== v);
     }
-
-    return true;
-  }
-
-  _load() {
-    try {
-      this._storedBlob = fs.readFileSync(this._blobFilename);
-      this._storedMap = JSON.parse(fs.readFileSync(this._mapFilename));
-    } catch (e) {
-      this._storedBlob = Buffer.alloc(0);
-      this._storedMap = {};
+    if (version) {
+        return versionMap.get(version);
     }
-    this._dirty = false;
-    this._memoryBlobs = {};
-    this._invalidationKeys = {};
-  }
-
-  _getDump() {
-    const buffers = [];
-    const newMap = {};
-    let offset = 0;
-
-    function push(key, invalidationKey, buffer) {
-      buffers.push(buffer);
-      newMap[key] = [invalidationKey, offset, offset + buffer.length];
-      offset += buffer.length;
+}
+function findVersion(packageName, key, snapshot, isBerry) {
+    const versionRange = key.slice(key.indexOf('@', 1) + 1);
+    // check for alias packages
+    const isAlias = isBerry
+        ? snapshot.resolution && !snapshot.resolution.startsWith(`${packageName}@`)
+        : versionRange.startsWith('npm:');
+    if (isAlias) {
+        return versionRange;
     }
-
-    for (const key of Object.keys(this._memoryBlobs)) {
-      const buffer = this._memoryBlobs[key];
-      const invalidationKey = this._invalidationKeys[key];
-      push(key, invalidationKey, buffer);
+    // check for berry tarball packages
+    if (isBerry &&
+        snapshot.resolution &&
+        // different registry would yield suffix following '::' which we don't need
+        snapshot.resolution.split('::')[0] !==
+            `${packageName}@npm:${snapshot.version}`) {
+        return snapshot.resolution.slice(packageName.length + 1);
     }
-
-    for (const key of Object.keys(this._storedMap)) {
-      if (hasOwnProperty.call(newMap, key)) continue;
-      const mapping = this._storedMap[key];
-      const buffer = this._storedBlob.slice(mapping[1], mapping[2]);
-      push(key, mapping[0], buffer);
+    if (!isBerry && isTarballPackage(versionRange, snapshot)) {
+        return snapshot.resolved;
     }
-
-    return [buffers, newMap];
-  }
+    // otherwise it's a standard version
+    return snapshot.version;
 }
-
-//------------------------------------------------------------------------------
-// NativeCompileCache
-//------------------------------------------------------------------------------
-
-class NativeCompileCache {
-  constructor() {
-    this._cacheStore = null;
-    this._previousModuleCompile = null;
-  }
-
-  setCacheStore(cacheStore) {
-    this._cacheStore = cacheStore;
-  }
-
-  install() {
-    const self = this;
-    const hasRequireResolvePaths = typeof require.resolve.paths === 'function';
-    this._previousModuleCompile = Module.prototype._compile;
-    Module.prototype._compile = this._ownModuleCompile = _ownModuleCompile;
-    self.enabled = true;
-    function _ownModuleCompile(content, filename) {
-      if(!self.enabled) return this._previousModuleCompile.apply(this, arguments);
-      const mod = this;
-
-      function require(id) {
-        return mod.require(id);
-      }
-
-      // https://github.com/nodejs/node/blob/v10.15.3/lib/internal/modules/cjs/helpers.js#L28
-      function resolve(request, options) {
-        return Module._resolveFilename(request, mod, false, options);
-      }
-      require.resolve = resolve;
-
-      // https://github.com/nodejs/node/blob/v10.15.3/lib/internal/modules/cjs/helpers.js#L37
-      // resolve.resolve.paths was added in v8.9.0
-      if (hasRequireResolvePaths) {
-        resolve.paths = function paths(request) {
-          return Module._resolveLookupPaths(request, mod, true);
-        };
-      }
-
-      require.main = process.mainModule;
-
-      // Enable support to add extra extension types
-      require.extensions = Module._extensions;
-      require.cache = Module._cache;
-
-      const dirname = path.dirname(filename);
-
-      const compiledWrapper = self._moduleCompile(filename, content);
-
-      // We skip the debugger setup because by the time we run, node has already
-      // done that itself.
-
-      // `Buffer` is included for Electron.
-      // See https://github.com/zertosh/v8-compile-cache/pull/10#issuecomment-518042543
-      const args = [mod.exports, require, mod, filename, dirname, process, global, Buffer];
-      return compiledWrapper.apply(mod.exports, args);
+// check if snapshot represents tarball package
+function isTarballPackage(versionRange, snapshot) {
+    // if resolved is missing it's internal link
+    if (!snapshot.resolved) {
+        return false;
     }
-  }
-
-  uninstall() {
-    this.enabled = false;
-    // If something else has since been installed on top of us, we cannot overwrite it.
-    if(Module.prototype._compile === this._ownModuleCompile) {
-      Module.prototype._compile = this._previousModuleCompile;
+    // tarballs have no integrity
+    if (snapshot.integrity) {
+        return false;
     }
-  }
-
-  _moduleCompile(filename, content) {
-    // https://github.com/nodejs/node/blob/v7.5.0/lib/module.js#L511
-
-    // Remove shebang
-    var contLen = content.length;
-    if (contLen >= 2) {
-      if (content.charCodeAt(0) === 35/*#*/ &&
-          content.charCodeAt(1) === 33/*!*/) {
-        if (contLen === 2) {
-          // Exact match
-          content = '';
-        } else {
-          // Find end of shebang line and slice it off
-          var i = 2;
-          for (; i < contLen; ++i) {
-            var code = content.charCodeAt(i);
-            if (code === 10/*\n*/ || code === 13/*\r*/) break;
-          }
-          if (i === contLen) {
-            content = '';
-          } else {
-            // Note that this actually includes the newline character(s) in the
-            // new output. This duplicates the behavior of the regular
-            // expression that was previously used to replace the shebang line
-            content = content.slice(i);
-          }
-        }
-      }
+    try {
+        new semver_1.Range(versionRange);
+        // range is a valid semver
+        return false;
     }
-
-    // create wrapper function
-    var wrapper = Module.wrap(content);
-
-    var invalidationKey = crypto
-      .createHash('sha1')
-      .update(content, 'utf8')
-      .digest('hex');
-
-    var buffer = this._cacheStore.get(filename, invalidationKey);
-
-    var script = new vm.Script(wrapper, {
-      filename: filename,
-      lineOffset: 0,
-      displayErrors: true,
-      cachedData: buffer,
-      produceCachedData: true,
-    });
-
-    if (script.cachedDataProduced) {
-      this._cacheStore.set(filename, invalidationKey, script.cachedData);
-    } else if (script.cachedDataRejected) {
-      this._cacheStore.delete(filename);
+    catch {
+        // range is not a valid semver, it can be an npm tag or url part of a tarball
+        return snapshot.version && !snapshot.resolved.includes(snapshot.version);
     }
-
-    var compiledWrapper = script.runInThisContext({
-      filename: filename,
-      lineOffset: 0,
-      columnOffset: 0,
-      displayErrors: true,
+}
+function getHoistedVersion(packageName) {
+    const version = (0, package_json_1.getHoistedPackageVersion)(packageName);
+    if (version) {
+        return version;
+    }
+}
+function getDependencies(dependencies, keyMap, ctx) {
+    const projectGraphDependencies = [];
+    Object.keys(dependencies).forEach((keys) => {
+        const snapshot = dependencies[keys];
+        keys.split(', ').forEach((key) => {
+            if (keyMap.has(key)) {
+                const node = keyMap.get(key);
+                [snapshot.dependencies, snapshot.optionalDependencies].forEach((section) => {
+                    if (section) {
+                        Object.entries(section).forEach(([name, versionRange]) => {
+                            const target = keyMap.get(`${name}@npm:${versionRange}`) ||
+                                keyMap.get(`${name}@${versionRange}`);
+                            if (target) {
+                                const dep = {
+                                    source: node.name,
+                                    target: target.name,
+                                    type: project_graph_1.DependencyType.static,
+                                };
+                                (0, project_graph_builder_1.validateDependency)(dep, ctx);
+                                projectGraphDependencies.push(dep);
+                            }
+                        });
+                    }
+                });
+            }
+        });
     });
-
-    return compiledWrapper;
-  }
+    return projectGraphDependencies;
 }
-
-//------------------------------------------------------------------------------
-// utilities
-//
-// https://github.com/substack/node-mkdirp/blob/f2003bb/index.js#L55-L98
-// https://github.com/zertosh/slash-escape/blob/e7ebb99/slash-escape.js
-//------------------------------------------------------------------------------
-
-function mkdirpSync(p_) {
-  _mkdirpSync(path.resolve(p_), 0o777);
+function stringifyYarnLockfile(graph, rootLockFileContent, packageJson) {
+    const { parseSyml, stringifySyml } = __nccwpck_require__(2877);
+    const { __metadata, ...dependencies } = parseSyml(rootLockFileContent);
+    const isBerry = !!__metadata;
+    const snapshots = mapSnapshots(dependencies, graph.externalNodes, packageJson, isBerry);
+    if (isBerry) {
+        // add root workspace package
+        const workspacePackage = generateRootWorkspacePackage(packageJson);
+        snapshots[workspacePackage.resolution] = workspacePackage;
+        return (BERRY_LOCK_FILE_DISCLAIMER +
+            stringifySyml({
+                __metadata,
+                ...(0, object_sort_1.sortObjectByKeys)(snapshots),
+            }));
+    }
+    else {
+        const { stringify } = __nccwpck_require__(4694);
+        return stringify((0, object_sort_1.sortObjectByKeys)(snapshots));
+    }
 }
-
-function _mkdirpSync(p, mode) {
-  try {
-    fs.mkdirSync(p, mode);
-  } catch (err0) {
-    if (err0.code === 'ENOENT') {
-      _mkdirpSync(path.dirname(p));
-      _mkdirpSync(p);
-    } else {
-      try {
-        const stat = fs.statSync(p);
-        if (!stat.isDirectory()) { throw err0; }
-      } catch (err1) {
-        throw err0;
-      }
+exports.stringifyYarnLockfile = stringifyYarnLockfile;
+function groupDependencies(dependencies, isBerry) {
+    if (isBerry) {
+        return dependencies;
     }
-  }
+    let groupedDependencies;
+    const resolutionMap = new Map();
+    const snapshotMap = new Map();
+    Object.entries(dependencies).forEach(([key, snapshot]) => {
+        const resolutionKey = `${snapshot.resolved}${snapshot.integrity}`;
+        if (resolutionMap.has(resolutionKey)) {
+            const existingSnapshot = resolutionMap.get(resolutionKey);
+            snapshotMap.get(existingSnapshot).add(key);
+        }
+        else {
+            resolutionMap.set(resolutionKey, snapshot);
+            snapshotMap.set(snapshot, new Set([key]));
+        }
+    });
+    groupedDependencies = {};
+    snapshotMap.forEach((keys, snapshot) => {
+        groupedDependencies[Array.from(keys).join(', ')] = snapshot;
+    });
+    return groupedDependencies;
 }
-
-function slashEscape(str) {
-  const ESCAPE_LOOKUP = {
-    '\\': 'zB',
-    ':': 'zC',
-    '/': 'zS',
-    '\x00': 'z0',
-    'z': 'zZ',
-  };
-  const ESCAPE_REGEX = /[\\:/\x00z]/g; // eslint-disable-line no-control-regex
-  return str.replace(ESCAPE_REGEX, match => ESCAPE_LOOKUP[match]);
+function addPackageVersion(packageName, version, collection, isBerry) {
+    if (!collection.has(packageName)) {
+        collection.set(packageName, new Set());
+    }
+    collection.get(packageName).add(`${packageName}@${version}`);
+    if (isBerry && !version.startsWith('npm:')) {
+        collection.get(packageName).add(`${packageName}@npm:${version}`);
+    }
 }
-
-function supportsCachedData() {
-  const script = new vm.Script('""', {produceCachedData: true});
-  // chakracore, as of v1.7.1.0, returns `false`.
-  return script.cachedDataProduced === true;
+function mapSnapshots(dependencies, nodes, packageJson, isBerry) {
+    // map snapshot to set of keys (e.g. `eslint@^7.0.0, eslint@npm:^7.0.0`)
+    const snapshotMap = new Map();
+    // track all existing dependencies's keys
+    const existingKeys = new Map();
+    const combinedDependencies = {
+        ...packageJson.dependencies,
+        ...packageJson.devDependencies,
+        ...packageJson.optionalDependencies,
+        ...packageJson.peerDependencies,
+    };
+    // yarn classic splits keys when parsing so we need to stich them back together
+    const groupedDependencies = groupDependencies(dependencies, isBerry);
+    // collect snapshots and their matching keys
+    Object.values(nodes).forEach((node) => {
+        const foundOriginalKeys = findOriginalKeys(groupedDependencies, node);
+        if (!foundOriginalKeys) {
+            throw new Error(`Original key(s) not found for "${node.data.packageName}@${node.data.version}" while pruning yarn.lock.`);
+        }
+        const [matchedKeys, snapshot] = foundOriginalKeys;
+        snapshotMap.set(snapshot, new Set(matchedKeys));
+        // separately save keys that still exist
+        [snapshot.dependencies, snapshot.optionalDependencies].forEach((section) => {
+            Object.entries(section || {}).forEach(([name, versionSpec]) => addPackageVersion(name, versionSpec, existingKeys, isBerry));
+        });
+        // add package.json requested version to keys
+        const requestedVersion = getPackageJsonVersion(combinedDependencies, node);
+        if (requestedVersion) {
+            addPackageVersion(node.data.packageName, requestedVersion, existingKeys, isBerry);
+            const requestedKey = isBerry
+                ? reverseMapBerryKey(node, requestedVersion, snapshot)
+                : `${node.data.packageName}@${requestedVersion}`;
+            if (!snapshotMap.get(snapshot).has(requestedKey)) {
+                snapshotMap.get(snapshot).add(requestedKey);
+            }
+        }
+        if (isBerry) {
+            // look for patched versions
+            const patch = findPatchedKeys(groupedDependencies, node);
+            if (patch) {
+                const [matchedKeys, snapshot] = patch;
+                snapshotMap.set(snapshot, new Set(matchedKeys));
+            }
+        }
+    });
+    // remove keys that match version ranges that have been pruned away
+    snapshotMap.forEach((snapshotValue, snapshotKey) => {
+        for (const key of snapshotValue.values()) {
+            const packageName = key.slice(0, key.indexOf('@', 1));
+            let normalizedKey = key;
+            if (isBerry && key.includes('@patch:') && key.includes('#')) {
+                normalizedKey = key
+                    .slice(0, key.indexOf('#'))
+                    .replace(`@patch:${packageName}@`, '@npm:');
+            }
+            if (!existingKeys.get(packageName) ||
+                !existingKeys.get(packageName).has(normalizedKey)) {
+                snapshotValue.delete(key);
+            }
+        }
+    });
+    // join mapped snapshots to lock json file
+    const result = {};
+    snapshotMap.forEach((keysSet, snapshot) => {
+        if (isBerry) {
+            result[Array.from(keysSet).sort().join(', ')] = snapshot;
+        }
+        else {
+            for (const key of keysSet.values()) {
+                result[key] = snapshot;
+            }
+        }
+    });
+    return result;
 }
-
-function getCacheDir() {
-  const v8_compile_cache_cache_dir = process.env.V8_COMPILE_CACHE_CACHE_DIR;
-  if (v8_compile_cache_cache_dir) {
-    return v8_compile_cache_cache_dir;
-  }
-
-  // Avoid cache ownership issues on POSIX systems.
-  const dirname = typeof process.getuid === 'function'
-    ? 'v8-compile-cache-' + process.getuid()
-    : 'v8-compile-cache';
-  const version = typeof process.versions.v8 === 'string'
-    ? process.versions.v8
-    : typeof process.versions.chakracore === 'string'
-      ? 'chakracore-' + process.versions.chakracore
-      : 'node-' + process.version;
-  const cacheDir = path.join(os.tmpdir(), dirname, version);
-  return cacheDir;
+function reverseMapBerryKey(node, version, snapshot) {
+    // alias packages already have version
+    if (version.startsWith('npm:')) {
+        `${node.data.packageName}@${version}`;
+    }
+    // check for berry tarball packages
+    if (snapshot.resolution &&
+        snapshot.resolution === `${node.data.packageName}@${version}`) {
+        return snapshot.resolution;
+    }
+    return `${node.data.packageName}@npm:${version}`;
 }
-
-function getMainName() {
-  // `require.main.filename` is undefined or null when:
-  //    * node -e 'require("v8-compile-cache")'
-  //    * node -r 'v8-compile-cache'
-  //    * Or, requiring from the REPL.
-  const mainName = require.main && typeof require.main.filename === 'string'
-    ? require.main.filename
-    : process.cwd();
-  return mainName;
+function getPackageJsonVersion(combinedDependencies, node) {
+    const { packageName, version } = node.data;
+    if (combinedDependencies[packageName]) {
+        if (combinedDependencies[packageName] === version ||
+            (0, semver_1.satisfies)(version, combinedDependencies[packageName])) {
+            return combinedDependencies[packageName];
+        }
+    }
 }
-
-function install(opts) {
-  if (!process.env.DISABLE_V8_COMPILE_CACHE && supportsCachedData()) {
-    if(typeof opts === 'undefined') opts = {}
-    let cacheDir = opts.cacheDir
-    if(typeof cacheDir === 'undefined') cacheDir = getCacheDir();
-    let prefix = opts.prefix
-    if(typeof prefix === 'undefined') prefix = getMainName();
-    const blobStore = new FileSystemBlobStore(cacheDir, prefix);
-
-    const nativeCompileCache = new NativeCompileCache();
-    nativeCompileCache.setCacheStore(blobStore);
-    nativeCompileCache.install();
-
-    let uninstalled = false;
-    const uninstall = () => {
-      if(uninstalled) return;
-      uninstalled = true;
-      process.removeListener('exit', uninstall);
-      if (blobStore.isDirty()) {
-        blobStore.save();
-      }
-      nativeCompileCache.uninstall();
+function findOriginalKeys(dependencies, node) {
+    for (const keyExpr of Object.keys(dependencies)) {
+        const snapshot = dependencies[keyExpr];
+        const keys = keyExpr.split(', ');
+        if (!keys.some((k) => k.startsWith(`${node.data.packageName}@`))) {
+            continue;
+        }
+        // standard package
+        if (snapshot.version === node.data.version) {
+            return [keys, snapshot];
+        }
+        // berry alias package
+        if (snapshot.resolution &&
+            `npm:${snapshot.resolution}` === node.data.version) {
+            return [keys, snapshot];
+        }
+        // classic alias
+        if (node.data.version.startsWith('npm:') &&
+            keys.some((k) => k === `${node.data.packageName}@${node.data.version}`)) {
+            return [keys, snapshot];
+        }
+        // tarball package
+        if (snapshot.resolved === node.data.version ||
+            snapshot.resolution === `${node.data.packageName}@${node.data.version}`) {
+            return [keys, snapshot];
+        }
     }
-    process.once('exit', uninstall);
-    return {uninstall};
-  }
+}
+function findPatchedKeys(dependencies, node) {
+    for (const keyExpr of Object.keys(dependencies)) {
+        const snapshot = dependencies[keyExpr];
+        const keys = keyExpr.split(', ');
+        if (!keys[0].startsWith(`${node.data.packageName}@patch:`)) {
+            continue;
+        }
+        // local patches are currently not supported
+        if (keys[0].includes('.yarn/patches')) {
+            continue;
+        }
+        if (snapshot.version === node.data.version) {
+            return [keys, snapshot];
+        }
+    }
+}
+const BERRY_LOCK_FILE_DISCLAIMER = `# This file is generated by running "yarn install" inside your project.\n# Manual changes might be lost - proceed with caution!\n\n`;
+function generateRootWorkspacePackage(packageJson) {
+    return {
+        version: '0.0.0-use.local',
+        resolution: `${packageJson.name}@workspace:.`,
+        ...(packageJson.dependencies && { dependencies: packageJson.dependencies }),
+        ...(packageJson.peerDependencies && {
+            peerDependencies: packageJson.peerDependencies,
+        }),
+        ...(packageJson.devDependencies && {
+            devDependencies: packageJson.devDependencies,
+        }),
+        ...(packageJson.optionalDependencies && {
+            optionalDependencies: packageJson.optionalDependencies,
+        }),
+        languageName: 'unknown',
+        linkType: 'soft',
+    };
 }
 
-//------------------------------------------------------------------------------
-// main
-//------------------------------------------------------------------------------
-
-module.exports.install = install;
-
-module.exports.__TEST__ = {
-  FileSystemBlobStore,
-  NativeCompileCache,
-  mkdirpSync,
-  slashEscape,
-  supportsCachedData,
-  getCacheDir,
-  getMainName,
-};
-
-
-/***/ }),
-
-/***/ 9398:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
-
-"use strict";
-
-const stringWidth = __nccwpck_require__(32147);
-const stripAnsi = __nccwpck_require__(93847);
-const ansiStyles = __nccwpck_require__(3537);
-
-const ESCAPES = new Set([
-	'\u001B',
-	'\u009B'
-]);
-
-const END_CODE = 39;
-
-const ANSI_ESCAPE_BELL = '\u0007';
-const ANSI_CSI = '[';
-const ANSI_OSC = ']';
-const ANSI_SGR_TERMINATOR = 'm';
-const ANSI_ESCAPE_LINK = `${ANSI_OSC}8;;`;
-
-const wrapAnsi = code => `${ESCAPES.values().next().value}${ANSI_CSI}${code}${ANSI_SGR_TERMINATOR}`;
-const wrapAnsiHyperlink = uri => `${ESCAPES.values().next().value}${ANSI_ESCAPE_LINK}${uri}${ANSI_ESCAPE_BELL}`;
-
-// Calculate the length of words split on ' ', ignoring
-// the extra characters added by ansi escape codes
-const wordLengths = string => string.split(' ').map(character => stringWidth(character));
-
-// Wrap a long word across multiple rows
-// Ansi escape codes do not count towards length
-const wrapWord = (rows, word, columns) => {
-	const characters = [...word];
-
-	let isInsideEscape = false;
-	let isInsideLinkEscape = false;
-	let visible = stringWidth(stripAnsi(rows[rows.length - 1]));
-
-	for (const [index, character] of characters.entries()) {
-		const characterLength = stringWidth(character);
-
-		if (visible + characterLength <= columns) {
-			rows[rows.length - 1] += character;
-		} else {
-			rows.push(character);
-			visible = 0;
-		}
-
-		if (ESCAPES.has(character)) {
-			isInsideEscape = true;
-			isInsideLinkEscape = characters.slice(index + 1).join('').startsWith(ANSI_ESCAPE_LINK);
-		}
-
-		if (isInsideEscape) {
-			if (isInsideLinkEscape) {
-				if (character === ANSI_ESCAPE_BELL) {
-					isInsideEscape = false;
-					isInsideLinkEscape = false;
-				}
-			} else if (character === ANSI_SGR_TERMINATOR) {
-				isInsideEscape = false;
-			}
-
-			continue;
-		}
-
-		visible += characterLength;
-
-		if (visible === columns && index < characters.length - 1) {
-			rows.push('');
-			visible = 0;
-		}
-	}
-
-	// It's possible that the last row we copy over is only
-	// ansi escape characters, handle this edge-case
-	if (!visible && rows[rows.length - 1].length > 0 && rows.length > 1) {
-		rows[rows.length - 2] += rows.pop();
-	}
-};
-
-// Trims spaces from a string ignoring invisible sequences
-const stringVisibleTrimSpacesRight = string => {
-	const words = string.split(' ');
-	let last = words.length;
-
-	while (last > 0) {
-		if (stringWidth(words[last - 1]) > 0) {
-			break;
-		}
-
-		last--;
-	}
-
-	if (last === words.length) {
-		return string;
-	}
-
-	return words.slice(0, last).join(' ') + words.slice(last).join('');
-};
-
-// The wrap-ansi module can be invoked in either 'hard' or 'soft' wrap mode
-//
-// 'hard' will never allow a string to take up more than columns characters
-//
-// 'soft' allows long words to expand past the column length
-const exec = (string, columns, options = {}) => {
-	if (options.trim !== false && string.trim() === '') {
-		return '';
-	}
-
-	let returnValue = '';
-	let escapeCode;
-	let escapeUrl;
-
-	const lengths = wordLengths(string);
-	let rows = [''];
-
-	for (const [index, word] of string.split(' ').entries()) {
-		if (options.trim !== false) {
-			rows[rows.length - 1] = rows[rows.length - 1].trimStart();
-		}
-
-		let rowLength = stringWidth(rows[rows.length - 1]);
-
-		if (index !== 0) {
-			if (rowLength >= columns && (options.wordWrap === false || options.trim === false)) {
-				// If we start with a new word but the current row length equals the length of the columns, add a new row
-				rows.push('');
-				rowLength = 0;
-			}
-
-			if (rowLength > 0 || options.trim === false) {
-				rows[rows.length - 1] += ' ';
-				rowLength++;
-			}
-		}
-
-		// In 'hard' wrap mode, the length of a line is never allowed to extend past 'columns'
-		if (options.hard && lengths[index] > columns) {
-			const remainingColumns = (columns - rowLength);
-			const breaksStartingThisLine = 1 + Math.floor((lengths[index] - remainingColumns - 1) / columns);
-			const breaksStartingNextLine = Math.floor((lengths[index] - 1) / columns);
-			if (breaksStartingNextLine < breaksStartingThisLine) {
-				rows.push('');
-			}
-
-			wrapWord(rows, word, columns);
-			continue;
-		}
-
-		if (rowLength + lengths[index] > columns && rowLength > 0 && lengths[index] > 0) {
-			if (options.wordWrap === false && rowLength < columns) {
-				wrapWord(rows, word, columns);
-				continue;
-			}
-
-			rows.push('');
-		}
-
-		if (rowLength + lengths[index] > columns && options.wordWrap === false) {
-			wrapWord(rows, word, columns);
-			continue;
-		}
-
-		rows[rows.length - 1] += word;
-	}
-
-	if (options.trim !== false) {
-		rows = rows.map(stringVisibleTrimSpacesRight);
-	}
-
-	const pre = [...rows.join('\n')];
-
-	for (const [index, character] of pre.entries()) {
-		returnValue += character;
-
-		if (ESCAPES.has(character)) {
-			const {groups} = new RegExp(`(?:\\${ANSI_CSI}(?\\d+)m|\\${ANSI_ESCAPE_LINK}(?.*)${ANSI_ESCAPE_BELL})`).exec(pre.slice(index).join('')) || {groups: {}};
-			if (groups.code !== undefined) {
-				const code = Number.parseFloat(groups.code);
-				escapeCode = code === END_CODE ? undefined : code;
-			} else if (groups.uri !== undefined) {
-				escapeUrl = groups.uri.length === 0 ? undefined : groups.uri;
-			}
-		}
-
-		const code = ansiStyles.codes.get(Number(escapeCode));
-
-		if (pre[index + 1] === '\n') {
-			if (escapeUrl) {
-				returnValue += wrapAnsiHyperlink('');
-			}
-
-			if (escapeCode && code) {
-				returnValue += wrapAnsi(code);
-			}
-		} else if (character === '\n') {
-			if (escapeCode && code) {
-				returnValue += wrapAnsi(escapeCode);
-			}
-
-			if (escapeUrl) {
-				returnValue += wrapAnsiHyperlink(escapeUrl);
-			}
-		}
-	}
-
-	return returnValue;
-};
-
-// For each newline, invoke the method separately
-module.exports = (string, columns, options) => {
-	return String(string)
-		.normalize()
-		.replace(/\r\n/g, '\n')
-		.split('\n')
-		.map(line => exec(line, columns, options))
-		.join('\n');
-};
-
-
-/***/ }),
-
-/***/ 63180:
-/***/ ((module) => {
-
-// Returns a wrapper function that returns a wrapped callback
-// The wrapper function should do some stuff, and return a
-// presumably different callback function.
-// This makes sure that own properties are retained, so that
-// decorations and such are not lost along the way.
-module.exports = wrappy
-function wrappy (fn, cb) {
-  if (fn && cb) return wrappy(fn)(cb)
-
-  if (typeof fn !== 'function')
-    throw new TypeError('need wrapper function')
 
-  Object.keys(fn).forEach(function (k) {
-    wrapper[k] = fn[k]
-  })
+/***/ }),
 
-  return wrapper
+/***/ 37158:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
-  function wrapper() {
-    var args = new Array(arguments.length)
-    for (var i = 0; i < args.length; i++) {
-      args[i] = arguments[i]
+"use strict";
+
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.buildExplicitDependencies = void 0;
+const explicit_project_dependencies_1 = __nccwpck_require__(14674);
+const explicit_package_json_dependencies_1 = __nccwpck_require__(17403);
+function buildExplicitDependencies(jsPluginConfig, ctx) {
+    if (totalNumberOfFilesToProcess(ctx) === 0)
+        return [];
+    let dependencies = [];
+    if (jsPluginConfig.analyzeSourceFiles === undefined ||
+        jsPluginConfig.analyzeSourceFiles === true) {
+        let tsExists = false;
+        try {
+            __nccwpck_require__.ab + "typescript.js"
+            tsExists = true;
+        }
+        catch { }
+        if (tsExists) {
+            dependencies = dependencies.concat((0, explicit_project_dependencies_1.buildExplicitTypeScriptDependencies)(ctx));
+        }
     }
-    var ret = fn.apply(this, args)
-    var cb = args[args.length-1]
-    if (typeof ret === 'function' && ret !== cb) {
-      Object.keys(cb).forEach(function (k) {
-        ret[k] = cb[k]
-      })
+    if (jsPluginConfig.analyzePackageJson === undefined ||
+        jsPluginConfig.analyzePackageJson === true) {
+        dependencies = dependencies.concat((0, explicit_package_json_dependencies_1.buildExplicitPackageJsonDependencies)(ctx));
     }
-    return ret
-  }
+    return dependencies;
+}
+exports.buildExplicitDependencies = buildExplicitDependencies;
+function totalNumberOfFilesToProcess(ctx) {
+    let totalNumOfFilesToProcess = 0;
+    Object.values(ctx.filesToProcess.projectFileMap).forEach((t) => (totalNumOfFilesToProcess += t.length));
+    return totalNumOfFilesToProcess;
 }
 
 
 /***/ }),
 
-/***/ 17005:
-/***/ ((module) => {
+/***/ 17403:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
 "use strict";
 
-module.exports = function (Yallist) {
-  Yallist.prototype[Symbol.iterator] = function* () {
-    for (let walker = this.head; walker; walker = walker.next) {
-      yield walker.value
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.buildExplicitPackageJsonDependencies = void 0;
+const file_utils_1 = __nccwpck_require__(63260);
+const path_1 = __nccwpck_require__(71017);
+const project_graph_1 = __nccwpck_require__(2184);
+const json_1 = __nccwpck_require__(8314);
+const path_2 = __nccwpck_require__(38270);
+const project_graph_builder_1 = __nccwpck_require__(80862);
+function buildExplicitPackageJsonDependencies(ctx) {
+    const res = [];
+    let packageNameMap = undefined;
+    const nodes = Object.values(ctx.projects);
+    Object.keys(ctx.filesToProcess.projectFileMap).forEach((source) => {
+        Object.values(ctx.filesToProcess.projectFileMap[source]).forEach((f) => {
+            if (isPackageJsonAtProjectRoot(nodes, f.file)) {
+                // we only create the package name map once and only if a package.json file changes
+                packageNameMap = packageNameMap || createPackageNameMap(ctx.projects);
+                processPackageJson(source, f.file, ctx, res, packageNameMap);
+            }
+        });
+    });
+    return res;
+}
+exports.buildExplicitPackageJsonDependencies = buildExplicitPackageJsonDependencies;
+function createPackageNameMap(projects) {
+    const res = {};
+    for (let projectName of Object.keys(projects)) {
+        try {
+            const packageJson = (0, json_1.parseJson)((0, file_utils_1.defaultFileRead)((0, path_1.join)(projects[projectName].root, 'package.json')));
+            res[packageJson.name ?? projectName] = projectName;
+        }
+        catch (e) { }
     }
-  }
+    return res;
+}
+function isPackageJsonAtProjectRoot(nodes, fileName) {
+    return (fileName.endsWith('package.json') &&
+        nodes.find((projectNode) => (0, path_2.joinPathFragments)(projectNode.root, 'package.json') === fileName));
+}
+function processPackageJson(sourceProject, fileName, ctx, collectedDeps, packageNameMap) {
+    try {
+        const deps = readDeps((0, json_1.parseJson)((0, file_utils_1.defaultFileRead)(fileName)));
+        // the name matches the import path
+        deps.forEach((d) => {
+            // package.json refers to another project in the monorepo
+            if (packageNameMap[d]) {
+                const dependency = {
+                    source: sourceProject,
+                    target: packageNameMap[d],
+                    sourceFile: fileName,
+                    type: project_graph_1.DependencyType.static,
+                };
+                (0, project_graph_builder_1.validateDependency)(dependency, ctx);
+                collectedDeps.push(dependency);
+            }
+            else if (ctx.externalNodes[`npm:${d}`]) {
+                const dependency = {
+                    source: sourceProject,
+                    target: `npm:${d}`,
+                    sourceFile: fileName,
+                    type: project_graph_1.DependencyType.static,
+                };
+                (0, project_graph_builder_1.validateDependency)(dependency, ctx);
+                collectedDeps.push(dependency);
+            }
+        });
+    }
+    catch (e) {
+        if (process.env.NX_VERBOSE_LOGGING === 'true') {
+            console.log(e);
+        }
+    }
+}
+function readDeps(packageJson) {
+    return [
+        ...Object.keys(packageJson?.dependencies ?? {}),
+        ...Object.keys(packageJson?.devDependencies ?? {}),
+        ...Object.keys(packageJson?.peerDependencies ?? {}),
+        ...Object.keys(packageJson?.optionalDependencies ?? {}),
+    ];
 }
 
 
 /***/ }),
 
-/***/ 19385:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+/***/ 14674:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
 "use strict";
 
-module.exports = Yallist
-
-Yallist.Node = Node
-Yallist.create = Yallist
-
-function Yallist (list) {
-  var self = this
-  if (!(self instanceof Yallist)) {
-    self = new Yallist()
-  }
-
-  self.tail = null
-  self.head = null
-  self.length = 0
-
-  if (list && typeof list.forEach === 'function') {
-    list.forEach(function (item) {
-      self.push(item)
-    })
-  } else if (arguments.length > 0) {
-    for (var i = 0, l = arguments.length; i < l; i++) {
-      self.push(arguments[i])
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.buildExplicitTypeScriptDependencies = void 0;
+const target_project_locator_1 = __nccwpck_require__(91259);
+const project_graph_1 = __nccwpck_require__(2184);
+const path_1 = __nccwpck_require__(71017);
+const workspace_root_1 = __nccwpck_require__(86708);
+const path_2 = __nccwpck_require__(38270);
+const project_graph_builder_1 = __nccwpck_require__(80862);
+function isRoot(projects, projectName) {
+    return projects[projectName]?.root === '.';
+}
+function convertImportToDependency(importExpr, sourceFile, source, type, targetProjectLocator) {
+    const target = targetProjectLocator.findProjectWithImport(importExpr, sourceFile) ??
+        `npm:${importExpr}`;
+    return {
+        source,
+        target,
+        sourceFile,
+        type,
+    };
+}
+function buildExplicitTypeScriptDependencies(ctx) {
+    // TODO: TargetProjectLocator is a public API, so we can't change the shape of it
+    // We should eventually let it accept Record s.t. we
+    // don't have to reshape the CreateDependenciesContext here.
+    const nodes = Object.fromEntries(Object.entries(ctx.projects).map(([key, config]) => [
+        key,
+        {
+            name: key,
+            type: null,
+            data: config,
+        },
+    ]));
+    const targetProjectLocator = new target_project_locator_1.TargetProjectLocator(nodes, ctx.externalNodes);
+    const res = [];
+    const filesToProcess = {};
+    const moduleExtensions = [
+        '.ts',
+        '.js',
+        '.tsx',
+        '.jsx',
+        '.mts',
+        '.mjs',
+        '.cjs',
+        '.cts',
+    ];
+    // TODO: This can be removed when vue is stable
+    if (isVuePluginInstalled()) {
+        moduleExtensions.push('.vue');
+    }
+    for (const [project, fileData] of Object.entries(ctx.fileMap.projectFileMap)) {
+        filesToProcess[project] ??= [];
+        for (const { file } of fileData) {
+            if (moduleExtensions.some((ext) => file.endsWith(ext))) {
+                filesToProcess[project].push((0, path_1.join)(workspace_root_1.workspaceRoot, file));
+            }
+        }
+    }
+    const { findImports } = __nccwpck_require__(74424);
+    const imports = findImports(filesToProcess);
+    for (const { sourceProject, file, staticImportExpressions, dynamicImportExpressions, } of imports) {
+        const normalizedFilePath = (0, path_2.normalizePath)((0, path_1.relative)(workspace_root_1.workspaceRoot, file));
+        for (const importExpr of staticImportExpressions) {
+            const dependency = convertImportToDependency(importExpr, normalizedFilePath, sourceProject, project_graph_1.DependencyType.static, targetProjectLocator);
+            // TODO: These edges technically should be allowed but we need to figure out how to separate config files out from root
+            if (isRoot(ctx.projects, dependency.source) ||
+                !isRoot(ctx.projects, dependency.target)) {
+                res.push(dependency);
+            }
+        }
+        for (const importExpr of dynamicImportExpressions) {
+            const dependency = convertImportToDependency(importExpr, normalizedFilePath, sourceProject, project_graph_1.DependencyType.dynamic, targetProjectLocator);
+            // TODO: These edges technically should be allowed but we need to figure out how to separate config files out from root
+            if (isRoot(ctx.projects, dependency.source) ||
+                !isRoot(ctx.projects, dependency.target)) {
+                (0, project_graph_builder_1.validateDependency)(dependency, ctx);
+                res.push(dependency);
+            }
+        }
+    }
+    return res;
+}
+exports.buildExplicitTypeScriptDependencies = buildExplicitTypeScriptDependencies;
+function isVuePluginInstalled() {
+    try {
+        // nx-ignore-next-line
+        /*require.resolve*/(89373);
+        return true;
+    }
+    catch {
+        return false;
     }
-  }
-
-  return self
 }
 
-Yallist.prototype.removeNode = function (node) {
-  if (node.list !== this) {
-    throw new Error('removing node which does not belong to this list')
-  }
-
-  var next = node.next
-  var prev = node.prev
-
-  if (next) {
-    next.prev = prev
-  }
 
-  if (prev) {
-    prev.next = next
-  }
+/***/ }),
 
-  if (node === this.head) {
-    this.head = next
-  }
-  if (node === this.tail) {
-    this.tail = prev
-  }
+/***/ 91259:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
-  node.list.length--
-  node.next = null
-  node.prev = null
-  node.list = null
+"use strict";
 
-  return next
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.TargetProjectLocator = void 0;
+const typescript_1 = __nccwpck_require__(37650);
+const fileutils_1 = __nccwpck_require__(83851);
+const path_1 = __nccwpck_require__(71017);
+const workspace_root_1 = __nccwpck_require__(86708);
+const module_1 = __nccwpck_require__(98188);
+const find_project_for_path_1 = __nccwpck_require__(46329);
+const builtInModuleSet = new Set([
+    ...module_1.builtinModules,
+    ...module_1.builtinModules.map((x) => `node:${x}`),
+]);
+class TargetProjectLocator {
+    constructor(nodes, externalNodes) {
+        this.nodes = nodes;
+        this.externalNodes = externalNodes;
+        this.projectRootMappings = (0, find_project_for_path_1.createProjectRootMappings)(this.nodes);
+        this.npmProjects = filterRootExternalDependencies(this.externalNodes);
+        this.tsConfig = this.getRootTsConfig();
+        this.paths = this.tsConfig.config?.compilerOptions?.paths;
+        this.typescriptResolutionCache = new Map();
+        this.npmResolutionCache = new Map();
+    }
+    /**
+     * Find a project based on its import
+     *
+     * @param importExpr
+     * @param filePath
+     */
+    findProjectWithImport(importExpr, filePath) {
+        if ((0, fileutils_1.isRelativePath)(importExpr)) {
+            const resolvedModule = path_1.posix.join((0, path_1.dirname)(filePath), importExpr);
+            return this.findProjectOfResolvedModule(resolvedModule);
+        }
+        // find project using tsconfig paths
+        const results = this.findPaths(importExpr);
+        if (results) {
+            const [path, paths] = results;
+            for (let p of paths) {
+                const r = p.endsWith('/*')
+                    ? (0, path_1.join)((0, path_1.dirname)(p), (0, path_1.relative)(path.replace(/\*$/, ''), importExpr))
+                    : p;
+                const maybeResolvedProject = this.findProjectOfResolvedModule(r);
+                if (maybeResolvedProject) {
+                    return maybeResolvedProject;
+                }
+            }
+        }
+        if (builtInModuleSet.has(importExpr)) {
+            this.npmResolutionCache.set(importExpr, null);
+            return null;
+        }
+        // try to find npm package before using expensive typescript resolution
+        const npmProject = this.findNpmPackage(importExpr);
+        if (npmProject) {
+            return npmProject;
+        }
+        if (this.tsConfig.config) {
+            // TODO(meeroslav): this block is probably obsolete
+            // and existed only because of the incomplete `paths` matching
+            // if import cannot be matched using tsconfig `paths` the compilation would fail anyway
+            const resolvedProject = this.resolveImportWithTypescript(importExpr, filePath);
+            if (resolvedProject) {
+                return resolvedProject;
+            }
+        }
+        try {
+            const resolvedModule = this.resolveImportWithRequire(importExpr, filePath);
+            return this.findProjectOfResolvedModule(resolvedModule);
+        }
+        catch { }
+        // nothing found, cache for later
+        this.npmResolutionCache.set(importExpr, null);
+        return null;
+    }
+    /**
+     * Return file paths matching the import relative to the repo root
+     * @param normalizedImportExpr
+     * @returns
+     */
+    findPaths(normalizedImportExpr) {
+        if (!this.paths) {
+            return undefined;
+        }
+        if (this.paths[normalizedImportExpr]) {
+            return [normalizedImportExpr, this.paths[normalizedImportExpr]];
+        }
+        const wildcardPath = Object.keys(this.paths).find((path) => path.endsWith('/*') &&
+            (normalizedImportExpr.startsWith(path.replace(/\*$/, '')) ||
+                normalizedImportExpr === path.replace(/\/\*$/, '')));
+        if (wildcardPath) {
+            return [wildcardPath, this.paths[wildcardPath]];
+        }
+        return undefined;
+    }
+    resolveImportWithTypescript(normalizedImportExpr, filePath) {
+        let resolvedModule;
+        if (this.typescriptResolutionCache.has(normalizedImportExpr)) {
+            resolvedModule = this.typescriptResolutionCache.get(normalizedImportExpr);
+        }
+        else {
+            resolvedModule = (0, typescript_1.resolveModuleByImport)(normalizedImportExpr, filePath, this.tsConfig.absolutePath);
+            this.typescriptResolutionCache.set(normalizedImportExpr, resolvedModule ? resolvedModule : null);
+        }
+        // TODO: vsavkin temporary workaround. Remove it once we reworking handling of npm packages.
+        if (resolvedModule && resolvedModule.indexOf('node_modules/') === -1) {
+            const resolvedProject = this.findProjectOfResolvedModule(resolvedModule);
+            if (resolvedProject) {
+                return resolvedProject;
+            }
+        }
+        return;
+    }
+    resolveImportWithRequire(normalizedImportExpr, filePath) {
+        return path_1.posix.relative(workspace_root_1.workspaceRoot, require.resolve(normalizedImportExpr, {
+            paths: [(0, path_1.dirname)(filePath)],
+        }));
+    }
+    findNpmPackage(npmImport) {
+        if (this.npmResolutionCache.has(npmImport)) {
+            return this.npmResolutionCache.get(npmImport);
+        }
+        else {
+            const pkg = this.npmProjects.find((pkg) => npmImport === pkg.data.packageName ||
+                npmImport.startsWith(`${pkg.data.packageName}/`));
+            if (pkg) {
+                this.npmResolutionCache.set(npmImport, pkg.name);
+                return pkg.name;
+            }
+        }
+    }
+    findProjectOfResolvedModule(resolvedModule) {
+        if (resolvedModule.startsWith('node_modules/') ||
+            resolvedModule.includes('/node_modules/')) {
+            return undefined;
+        }
+        const normalizedResolvedModule = resolvedModule.startsWith('./')
+            ? resolvedModule.substring(2)
+            : resolvedModule;
+        const importedProject = this.findMatchingProjectFiles(normalizedResolvedModule);
+        return importedProject ? importedProject.name : void 0;
+    }
+    getAbsolutePath(path) {
+        return (0, path_1.join)(workspace_root_1.workspaceRoot, path);
+    }
+    getRootTsConfig() {
+        const path = (0, typescript_1.getRootTsConfigFileName)();
+        if (!path) {
+            return {
+                path: null,
+                absolutePath: null,
+                config: null,
+            };
+        }
+        const absolutePath = this.getAbsolutePath(path);
+        return {
+            absolutePath,
+            path,
+            config: (0, fileutils_1.readJsonFile)(absolutePath),
+        };
+    }
+    findMatchingProjectFiles(file) {
+        const project = (0, find_project_for_path_1.findProjectForPath)(file, this.projectRootMappings);
+        return this.nodes[project];
+    }
 }
-
-Yallist.prototype.unshiftNode = function (node) {
-  if (node === this.head) {
-    return
-  }
-
-  if (node.list) {
-    node.list.removeNode(node)
-  }
-
-  var head = this.head
-  node.list = this
-  node.next = head
-  if (head) {
-    head.prev = node
-  }
-
-  this.head = node
-  if (!this.tail) {
-    this.tail = node
-  }
-  this.length++
+exports.TargetProjectLocator = TargetProjectLocator;
+// matches `npm:@scope/name`, `npm:name` but not `npm:@scope/name@version` and `npm:name@version`
+const ROOT_VERSION_PACKAGE_NAME_REGEX = /^npm:(?!.+@.+)/;
+function filterRootExternalDependencies(externalNodes) {
+    if (!externalNodes) {
+        return [];
+    }
+    const keys = Object.keys(externalNodes);
+    const nodes = [];
+    for (let i = 0; i < keys.length; i++) {
+        if (keys[i].match(ROOT_VERSION_PACKAGE_NAME_REGEX)) {
+            nodes.push(externalNodes[keys[i]]);
+        }
+    }
+    return nodes;
 }
 
-Yallist.prototype.pushNode = function (node) {
-  if (node === this.tail) {
-    return
-  }
 
-  if (node.list) {
-    node.list.removeNode(node)
-  }
+/***/ }),
 
-  var tail = this.tail
-  node.list = this
-  node.prev = tail
-  if (tail) {
-    tail.next = node
-  }
+/***/ 13770:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
-  this.tail = node
-  if (!this.head) {
-    this.head = node
-  }
-  this.length++
-}
+"use strict";
 
-Yallist.prototype.push = function () {
-  for (var i = 0, l = arguments.length; i < l; i++) {
-    push(this, arguments[i])
-  }
-  return this.length
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.jsPluginConfig = void 0;
+const node_path_1 = __nccwpck_require__(49411);
+const fileutils_1 = __nccwpck_require__(83851);
+const workspace_root_1 = __nccwpck_require__(86708);
+const fs_1 = __nccwpck_require__(57147);
+function jsPluginConfig(nxJson) {
+    const nxJsonConfig = nxJson?.pluginsConfig?.['@nx/js'] ?? nxJson?.pluginsConfig?.['@nrwl/js'];
+    // using lerna _before_ installing deps is causing an issue when parsing lockfile.
+    // See: https://github.com/lerna/lerna/issues/3807
+    // Note that previous attempt to fix this caused issues with Nx itself, thus we're checking
+    // for Lerna explicitly.
+    // See: https://github.com/nrwl/nx/pull/18784/commits/5416138e1ddc1945d5b289672dfb468e8c544e14
+    const analyzeLockfile = !(0, fs_1.existsSync)((0, node_path_1.join)(workspace_root_1.workspaceRoot, 'lerna.json')) ||
+        (0, fs_1.existsSync)((0, node_path_1.join)(workspace_root_1.workspaceRoot, 'nx.json'));
+    if (nxJsonConfig) {
+        return {
+            analyzePackageJson: true,
+            analyzeSourceFiles: true,
+            analyzeLockfile,
+            ...nxJsonConfig,
+        };
+    }
+    if (!(0, fileutils_1.fileExists)((0, node_path_1.join)(workspace_root_1.workspaceRoot, 'package.json'))) {
+        return {
+            analyzeLockfile: false,
+            analyzePackageJson: false,
+            analyzeSourceFiles: false,
+        };
+    }
+    const packageJson = (0, fileutils_1.readJsonFile)((0, node_path_1.join)(workspace_root_1.workspaceRoot, 'package.json'));
+    const packageJsonDeps = {
+        ...packageJson.dependencies,
+        ...packageJson.devDependencies,
+    };
+    if (packageJsonDeps['@nx/workspace'] ||
+        packageJsonDeps['@nx/js'] ||
+        packageJsonDeps['@nx/node'] ||
+        packageJsonDeps['@nx/next'] ||
+        packageJsonDeps['@nx/react'] ||
+        packageJsonDeps['@nx/angular'] ||
+        packageJsonDeps['@nx/web'] ||
+        packageJsonDeps['@nrwl/workspace'] ||
+        packageJsonDeps['@nrwl/js'] ||
+        packageJsonDeps['@nrwl/node'] ||
+        packageJsonDeps['@nrwl/next'] ||
+        packageJsonDeps['@nrwl/react'] ||
+        packageJsonDeps['@nrwl/angular'] ||
+        packageJsonDeps['@nrwl/web']) {
+        return {
+            analyzePackageJson: true,
+            analyzeLockfile,
+            analyzeSourceFiles: true,
+        };
+    }
+    else {
+        return {
+            analyzePackageJson: true,
+            analyzeLockfile,
+            analyzeSourceFiles: false,
+        };
+    }
 }
+exports.jsPluginConfig = jsPluginConfig;
 
-Yallist.prototype.unshift = function () {
-  for (var i = 0, l = arguments.length; i < l; i++) {
-    unshift(this, arguments[i])
-  }
-  return this.length
-}
 
-Yallist.prototype.pop = function () {
-  if (!this.tail) {
-    return undefined
-  }
+/***/ }),
 
-  var res = this.tail.value
-  this.tail = this.tail.prev
-  if (this.tail) {
-    this.tail.next = null
-  } else {
-    this.head = null
-  }
-  this.length--
-  return res
-}
+/***/ 44321:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
-Yallist.prototype.shift = function () {
-  if (!this.head) {
-    return undefined
-  }
+"use strict";
 
-  var res = this.head.value
-  this.head = this.head.next
-  if (this.head) {
-    this.head.prev = null
-  } else {
-    this.tail = null
-  }
-  this.length--
-  return res
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.getTsNodeCompilerOptions = exports.registerTsConfigPaths = exports.registerTranspiler = exports.getTranspiler = exports.getTsNodeTranspiler = exports.getSwcTranspiler = exports.registerTsProject = void 0;
+const path_1 = __nccwpck_require__(71017);
+const logger_1 = __nccwpck_require__(39299);
+const fs_1 = __nccwpck_require__(57147);
+const workspace_root_1 = __nccwpck_require__(86708);
+const swcNodeInstalled = packageIsInstalled('@swc-node/register');
+const tsNodeInstalled = packageIsInstalled('ts-node/register');
+let ts;
+let isTsEsmLoaderRegistered = false;
+function registerTsProject(path, configFilename, 
+/**
+ * @deprecated Do not use this.. it's a 1-off exception
+ */
+useForSwcEnvironmentVariable) {
+    const tsConfigPath = configFilename ? (0, path_1.join)(path, configFilename) : path;
+    const compilerOptions = readCompilerOptions(tsConfigPath);
+    const cleanupFunctions = [
+        registerTsConfigPaths(tsConfigPath),
+        registerTranspiler(compilerOptions, useForSwcEnvironmentVariable ? tsConfigPath : undefined),
+    ];
+    // Add ESM support for `.ts` files.
+    // NOTE: There is no cleanup function for this, as it's not possible to unregister the loader.
+    //       Based on limited testing, it doesn't seem to matter if we register it multiple times, but just in
+    //       case let's keep a flag to prevent it.
+    if (!isTsEsmLoaderRegistered) {
+        const module = __nccwpck_require__(82033);
+        if (module.register && packageIsInstalled('ts-node/esm')) {
+            const url = __nccwpck_require__(41041);
+            module.register(url.pathToFileURL(require.resolve('ts-node/esm')));
+        }
+        isTsEsmLoaderRegistered = true;
+    }
+    return () => {
+        for (const fn of cleanupFunctions) {
+            fn();
+        }
+    };
 }
-
-Yallist.prototype.forEach = function (fn, thisp) {
-  thisp = thisp || this
-  for (var walker = this.head, i = 0; walker !== null; i++) {
-    fn.call(thisp, walker.value, i, this)
-    walker = walker.next
-  }
+exports.registerTsProject = registerTsProject;
+function getSwcTranspiler(compilerOptions, tsConfigPath) {
+    // These are requires to prevent it from registering when it shouldn't
+    const register = (__nccwpck_require__(55204).register);
+    if (tsConfigPath) {
+        process.env.SWC_NODE_PROJECT = tsConfigPath;
+    }
+    else {
+        let rootTsConfig = (0, path_1.join)(workspace_root_1.workspaceRoot, 'tsconfig.base.json');
+        if ((0, fs_1.existsSync)(rootTsConfig)) {
+            process.env.SWC_NODE_PROJECT = rootTsConfig;
+        }
+    }
+    const cleanupFn = register(compilerOptions);
+    return typeof cleanupFn === 'function' ? cleanupFn : () => { };
 }
-
-Yallist.prototype.forEachReverse = function (fn, thisp) {
-  thisp = thisp || this
-  for (var walker = this.tail, i = this.length - 1; walker !== null; i--) {
-    fn.call(thisp, walker.value, i, this)
-    walker = walker.prev
-  }
+exports.getSwcTranspiler = getSwcTranspiler;
+function getTsNodeTranspiler(compilerOptions) {
+    const { register } = __nccwpck_require__(94828);
+    // ts-node doesn't provide a cleanup method
+    const service = register({
+        transpileOnly: true,
+        compilerOptions: getTsNodeCompilerOptions(compilerOptions),
+        // we already read and provide the compiler options, so prevent ts-node from reading them again
+        skipProject: true,
+    });
+    const { transpiler, swc } = service.options;
+    // Don't warn if a faster transpiler is enabled
+    if (!transpiler && !swc) {
+        warnTsNodeUsage();
+    }
+    return () => {
+        service.enabled(false);
+    };
 }
-
-Yallist.prototype.get = function (n) {
-  for (var i = 0, walker = this.head; walker !== null && i < n; i++) {
-    // abort out of the list early if we hit a cycle
-    walker = walker.next
-  }
-  if (i === n && walker !== null) {
-    return walker.value
-  }
+exports.getTsNodeTranspiler = getTsNodeTranspiler;
+function getTranspiler(compilerOptions, tsConfigPath) {
+    const preferTsNode = process.env.NX_PREFER_TS_NODE === 'true';
+    if (!ts) {
+        ts = __nccwpck_require__(81151);
+    }
+    compilerOptions.lib = ['es2021'];
+    compilerOptions.module = ts.ModuleKind.CommonJS;
+    compilerOptions.target = ts.ScriptTarget.ES2021;
+    compilerOptions.inlineSourceMap = true;
+    compilerOptions.skipLibCheck = true;
+    if (swcNodeInstalled && !preferTsNode) {
+        return () => getSwcTranspiler(compilerOptions, tsConfigPath);
+    }
+    // We can fall back on ts-node if it's available
+    if (tsNodeInstalled) {
+        return () => getTsNodeTranspiler(compilerOptions);
+    }
 }
-
-Yallist.prototype.getReverse = function (n) {
-  for (var i = 0, walker = this.tail; walker !== null && i < n; i++) {
-    // abort out of the list early if we hit a cycle
-    walker = walker.prev
-  }
-  if (i === n && walker !== null) {
-    return walker.value
-  }
+exports.getTranspiler = getTranspiler;
+/**
+ * Register ts-node or swc-node given a set of compiler options.
+ *
+ * Note: Several options require enums from typescript. To avoid importing typescript,
+ * use import type + raw values
+ *
+ * @returns cleanup method
+ */
+function registerTranspiler(compilerOptions, tsConfigPath) {
+    // Function to register transpiler that returns cleanup function
+    const transpiler = getTranspiler(compilerOptions, tsConfigPath);
+    if (!transpiler) {
+        warnNoTranspiler();
+        return () => { };
+    }
+    return transpiler();
 }
-
-Yallist.prototype.map = function (fn, thisp) {
-  thisp = thisp || this
-  var res = new Yallist()
-  for (var walker = this.head; walker !== null;) {
-    res.push(fn.call(thisp, walker.value, this))
-    walker = walker.next
-  }
-  return res
+exports.registerTranspiler = registerTranspiler;
+/**
+ * @param tsConfigPath Adds the paths from a tsconfig file into node resolutions
+ * @returns cleanup function
+ */
+function registerTsConfigPaths(tsConfigPath) {
+    try {
+        /**
+         * Load the ts config from the source project
+         */
+        const tsconfigPaths = loadTsConfigPaths();
+        const tsConfigResult = tsconfigPaths.loadConfig(tsConfigPath);
+        /**
+         * Register the custom workspace path mappings with node so that workspace libraries
+         * can be imported and used within project
+         */
+        if (tsConfigResult.resultType === 'success') {
+            return tsconfigPaths.register({
+                baseUrl: tsConfigResult.absoluteBaseUrl,
+                paths: tsConfigResult.paths,
+            });
+        }
+    }
+    catch (err) {
+        if (err instanceof Error) {
+            throw new Error(`Unable to load ${tsConfigPath}: ` + err.message);
+        }
+    }
+    throw new Error(`Unable to load ${tsConfigPath}`);
 }
-
-Yallist.prototype.mapReverse = function (fn, thisp) {
-  thisp = thisp || this
-  var res = new Yallist()
-  for (var walker = this.tail; walker !== null;) {
-    res.push(fn.call(thisp, walker.value, this))
-    walker = walker.prev
-  }
-  return res
+exports.registerTsConfigPaths = registerTsConfigPaths;
+function readCompilerOptions(tsConfigPath) {
+    const preferTsNode = process.env.NX_PREFER_TS_NODE === 'true';
+    if (swcNodeInstalled && !preferTsNode) {
+        const { readDefaultTsConfig, } = __nccwpck_require__(66357);
+        return readDefaultTsConfig(tsConfigPath);
+    }
+    else {
+        return readCompilerOptionsWithTypescript(tsConfigPath);
+    }
 }
-
-Yallist.prototype.reduce = function (fn, initial) {
-  var acc
-  var walker = this.head
-  if (arguments.length > 1) {
-    acc = initial
-  } else if (this.head) {
-    walker = this.head.next
-    acc = this.head.value
-  } else {
-    throw new TypeError('Reduce of empty list with no initial value')
-  }
-
-  for (var i = 0; walker !== null; i++) {
-    acc = fn(acc, walker.value, i)
-    walker = walker.next
-  }
-
-  return acc
+function readCompilerOptionsWithTypescript(tsConfigPath) {
+    if (!ts) {
+        ts = __nccwpck_require__(81151);
+    }
+    const { readConfigFile, parseJsonConfigFileContent, sys } = ts;
+    const jsonContent = readConfigFile(tsConfigPath, sys.readFile);
+    const { options } = parseJsonConfigFileContent(jsonContent.config, sys, (0, path_1.dirname)(tsConfigPath));
+    // This property is returned in compiler options for some reason, but not part of the typings.
+    // ts-node fails on unknown props, so we have to remove it.
+    delete options.configFilePath;
+    return options;
 }
-
-Yallist.prototype.reduceReverse = function (fn, initial) {
-  var acc
-  var walker = this.tail
-  if (arguments.length > 1) {
-    acc = initial
-  } else if (this.tail) {
-    walker = this.tail.prev
-    acc = this.tail.value
-  } else {
-    throw new TypeError('Reduce of empty list with no initial value')
-  }
-
-  for (var i = this.length - 1; walker !== null; i--) {
-    acc = fn(acc, walker.value, i)
-    walker = walker.prev
-  }
-
-  return acc
+function loadTsConfigPaths() {
+    try {
+        return __nccwpck_require__(24961);
+    }
+    catch {
+        warnNoTsconfigPaths();
+    }
 }
-
-Yallist.prototype.toArray = function () {
-  var arr = new Array(this.length)
-  for (var i = 0, walker = this.head; walker !== null; i++) {
-    arr[i] = walker.value
-    walker = walker.next
-  }
-  return arr
+function warnTsNodeUsage() {
+    logger_1.logger.warn((0, logger_1.stripIndent)(`${logger_1.NX_PREFIX} Falling back to ts-node for local typescript execution. This may be a little slower.
+  - To fix this, ensure @swc-node/register and @swc/core have been installed`));
 }
-
-Yallist.prototype.toArrayReverse = function () {
-  var arr = new Array(this.length)
-  for (var i = 0, walker = this.tail; walker !== null; i++) {
-    arr[i] = walker.value
-    walker = walker.prev
-  }
-  return arr
+function warnNoTsconfigPaths() {
+    logger_1.logger.warn((0, logger_1.stripIndent)(`${logger_1.NX_PREFIX} Unable to load tsconfig-paths, workspace libraries may be inaccessible.
+  - To fix this, install tsconfig-paths with npm/yarn/pnpm`));
 }
-
-Yallist.prototype.slice = function (from, to) {
-  to = to || this.length
-  if (to < 0) {
-    to += this.length
-  }
-  from = from || 0
-  if (from < 0) {
-    from += this.length
-  }
-  var ret = new Yallist()
-  if (to < from || to < 0) {
-    return ret
-  }
-  if (from < 0) {
-    from = 0
-  }
-  if (to > this.length) {
-    to = this.length
-  }
-  for (var i = 0, walker = this.head; walker !== null && i < from; i++) {
-    walker = walker.next
-  }
-  for (; walker !== null && i < to; i++, walker = walker.next) {
-    ret.push(walker.value)
-  }
-  return ret
+function warnNoTranspiler() {
+    logger_1.logger.warn((0, logger_1.stripIndent)(`${logger_1.NX_PREFIX} Unable to locate swc-node or ts-node. Nx will be unable to run local ts files without transpiling.
+  - To fix this, ensure @swc-node/register and @swc/core have been installed`));
 }
-
-Yallist.prototype.sliceReverse = function (from, to) {
-  to = to || this.length
-  if (to < 0) {
-    to += this.length
-  }
-  from = from || 0
-  if (from < 0) {
-    from += this.length
-  }
-  var ret = new Yallist()
-  if (to < from || to < 0) {
-    return ret
-  }
-  if (from < 0) {
-    from = 0
-  }
-  if (to > this.length) {
-    to = this.length
-  }
-  for (var i = this.length, walker = this.tail; walker !== null && i > to; i--) {
-    walker = walker.prev
-  }
-  for (; walker !== null && i > from; i--, walker = walker.prev) {
-    ret.push(walker.value)
-  }
-  return ret
+function packageIsInstalled(m) {
+    try {
+        const p = require.resolve(m);
+        return true;
+    }
+    catch {
+        return false;
+    }
+}
+/**
+ * ts-node requires string values for enum based typescript options.
+ * `register`'s signature just types the field as `object`, so we
+ * unfortunately do not get any kind of type safety on this.
+ */
+function getTsNodeCompilerOptions(compilerOptions) {
+    if (!ts) {
+        ts = __nccwpck_require__(81151);
+    }
+    const flagMap = {
+        module: 'ModuleKind',
+        target: 'ScriptTarget',
+        moduleDetection: 'ModuleDetectionKind',
+        newLine: 'NewLineKind',
+        moduleResolution: 'ModuleResolutionKind',
+        importsNotUsedAsValues: 'ImportsNotUsedAsValues',
+    };
+    const result = {
+        ...compilerOptions,
+    };
+    for (const flag in flagMap) {
+        if (compilerOptions[flag]) {
+            result[flag] = ts[flagMap[flag]][compilerOptions[flag]];
+        }
+    }
+    delete result.pathsBasePath;
+    delete result.configFilePath;
+    // instead of mapping to enum value we just remove it as it shouldn't ever need to be set for ts-node
+    delete result.jsx;
+    // lib option is in the format `lib.es2022.d.ts`, so we need to remove the leading `lib.` and trailing `.d.ts` to make it valid
+    result.lib = result.lib?.map((value) => {
+        return value.replace(/^lib\./, '').replace(/\.d\.ts$/, '');
+    });
+    if (result.moduleResolution) {
+        result.moduleResolution =
+            result.moduleResolution === 'NodeJs'
+                ? 'node'
+                : result.moduleResolution.toLowerCase();
+    }
+    return result;
 }
+exports.getTsNodeCompilerOptions = getTsNodeCompilerOptions;
 
-Yallist.prototype.splice = function (start, deleteCount, ...nodes) {
-  if (start > this.length) {
-    start = this.length - 1
-  }
-  if (start < 0) {
-    start = this.length + start;
-  }
 
-  for (var i = 0, walker = this.head; walker !== null && i < start; i++) {
-    walker = walker.next
-  }
+/***/ }),
 
-  var ret = []
-  for (var i = 0; walker && i < deleteCount; i++) {
-    ret.push(walker.value)
-    walker = this.removeNode(walker)
-  }
-  if (walker === null) {
-    walker = this.tail
-  }
+/***/ 37650:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
-  if (walker !== this.head && walker !== this.tail) {
-    walker = walker.prev
-  }
+"use strict";
 
-  for (var i = 0; i < nodes.length; i++) {
-    walker = insert(this, walker, nodes[i])
-  }
-  return ret;
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.findNodes = exports.getRootTsConfigPath = exports.getRootTsConfigFileName = exports.resolveModuleByImport = exports.readTsConfig = void 0;
+const workspace_root_1 = __nccwpck_require__(86708);
+const fs_1 = __nccwpck_require__(57147);
+const path_1 = __nccwpck_require__(71017);
+const normalizedAppRoot = workspace_root_1.workspaceRoot.replace(/\\/g, '/');
+let tsModule;
+function readTsConfig(tsConfigPath) {
+    if (!tsModule) {
+        tsModule = __nccwpck_require__(81151);
+    }
+    const readResult = tsModule.readConfigFile(tsConfigPath, tsModule.sys.readFile);
+    return tsModule.parseJsonConfigFileContent(readResult.config, tsModule.sys, (0, path_1.dirname)(tsConfigPath));
 }
-
-Yallist.prototype.reverse = function () {
-  var head = this.head
-  var tail = this.tail
-  for (var walker = head; walker !== null; walker = walker.prev) {
-    var p = walker.prev
-    walker.prev = walker.next
-    walker.next = p
-  }
-  this.head = tail
-  this.tail = head
-  return this
+exports.readTsConfig = readTsConfig;
+function readTsConfigOptions(tsConfigPath) {
+    if (!tsModule) {
+        tsModule = __nccwpck_require__(81151);
+    }
+    const readResult = tsModule.readConfigFile(tsConfigPath, tsModule.sys.readFile);
+    // we don't need to scan the files, we only care about options
+    const host = {
+        readDirectory: () => [],
+        readFile: () => '',
+        fileExists: tsModule.sys.fileExists,
+    };
+    return tsModule.parseJsonConfigFileContent(readResult.config, host, (0, path_1.dirname)(tsConfigPath)).options;
 }
-
-function insert (self, node, value) {
-  var inserted = node === self.head ?
-    new Node(value, null, node, self) :
-    new Node(value, node, node.next, self)
-
-  if (inserted.next === null) {
-    self.tail = inserted
-  }
-  if (inserted.prev === null) {
-    self.head = inserted
-  }
-
-  self.length++
-
-  return inserted
+let compilerHost;
+/**
+ * Find a module based on its import
+ *
+ * @param importExpr Import used to resolve to a module
+ * @param filePath
+ * @param tsConfigPath
+ */
+function resolveModuleByImport(importExpr, filePath, tsConfigPath) {
+    compilerHost = compilerHost || getCompilerHost(tsConfigPath);
+    const { options, host, moduleResolutionCache } = compilerHost;
+    const { resolvedModule } = tsModule.resolveModuleName(importExpr, filePath, options, host, moduleResolutionCache);
+    if (!resolvedModule) {
+        return;
+    }
+    else {
+        return resolvedModule.resolvedFileName.replace(`${normalizedAppRoot}/`, '');
+    }
 }
-
-function push (self, item) {
-  self.tail = new Node(item, self.tail, null, self)
-  if (!self.head) {
-    self.head = self.tail
-  }
-  self.length++
+exports.resolveModuleByImport = resolveModuleByImport;
+function getCompilerHost(tsConfigPath) {
+    const options = readTsConfigOptions(tsConfigPath);
+    const host = tsModule.createCompilerHost(options, true);
+    const moduleResolutionCache = tsModule.createModuleResolutionCache(workspace_root_1.workspaceRoot, host.getCanonicalFileName);
+    return { options, host, moduleResolutionCache };
 }
-
-function unshift (self, item) {
-  self.head = new Node(item, null, self.head, self)
-  if (!self.tail) {
-    self.tail = self.head
-  }
-  self.length++
+function getRootTsConfigFileName() {
+    for (const tsConfigName of ['tsconfig.base.json', 'tsconfig.json']) {
+        const tsConfigPath = (0, path_1.join)(workspace_root_1.workspaceRoot, tsConfigName);
+        if ((0, fs_1.existsSync)(tsConfigPath)) {
+            return tsConfigName;
+        }
+    }
+    return null;
+}
+exports.getRootTsConfigFileName = getRootTsConfigFileName;
+function getRootTsConfigPath() {
+    const tsConfigFileName = getRootTsConfigFileName();
+    return tsConfigFileName ? (0, path_1.join)(workspace_root_1.workspaceRoot, tsConfigFileName) : null;
+}
+exports.getRootTsConfigPath = getRootTsConfigPath;
+function findNodes(node, kind, max = Infinity) {
+    if (!node || max == 0) {
+        return [];
+    }
+    const arr = [];
+    const hasMatch = Array.isArray(kind)
+        ? kind.includes(node.kind)
+        : node.kind === kind;
+    if (hasMatch) {
+        arr.push(node);
+        max--;
+    }
+    if (max > 0) {
+        for (const child of node.getChildren()) {
+            findNodes(child, kind, max).forEach((node) => {
+                if (max > 0) {
+                    arr.push(node);
+                }
+                max--;
+            });
+            if (max <= 0) {
+                break;
+            }
+        }
+    }
+    return arr;
 }
+exports.findNodes = findNodes;
 
-function Node (value, prev, next, list) {
-  if (!(this instanceof Node)) {
-    return new Node(value, prev, next, list)
-  }
 
-  this.list = list
-  this.value = value
+/***/ }),
 
-  if (prev) {
-    prev.next = this
-    this.prev = prev
-  } else {
-    this.prev = null
-  }
+/***/ 26391:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
-  if (next) {
-    next.prev = this
-    this.next = next
-  } else {
-    this.next = null
-  }
+"use strict";
+
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.getGlobPatternsFromPackageManagerWorkspaces = exports.buildProjectConfigurationFromPackageJson = exports.createNodeFromPackageJson = exports.getNxPackageJsonWorkspacesPlugin = void 0;
+const minimatch_1 = __nccwpck_require__(55224);
+const node_fs_1 = __nccwpck_require__(87561);
+const node_path_1 = __nccwpck_require__(49411);
+const nx_json_1 = __nccwpck_require__(53619);
+const workspaces_1 = __nccwpck_require__(26546);
+const fileutils_1 = __nccwpck_require__(83851);
+const globs_1 = __nccwpck_require__(94865);
+const logger_1 = __nccwpck_require__(39299);
+const output_1 = __nccwpck_require__(1737);
+const package_json_1 = __nccwpck_require__(4014);
+const path_1 = __nccwpck_require__(38270);
+function getNxPackageJsonWorkspacesPlugin(root) {
+    const readJson = (f) => (0, fileutils_1.readJsonFile)((0, node_path_1.join)(root, f));
+    const patterns = getGlobPatternsFromPackageManagerWorkspaces(root, readJson);
+    // If the user only specified a negative pattern, we should find all package.json
+    // files and only return those that don't match a negative pattern.
+    const negativePatterns = patterns.filter((p) => p.startsWith('!'));
+    let positivePatterns = patterns.filter((p) => !p.startsWith('!'));
+    if (
+    // There are some negative patterns
+    negativePatterns.length > 0 &&
+        // No positive patterns
+        (positivePatterns.length === 0 ||
+            // Or only a single positive pattern that is the default coming from root package
+            (positivePatterns.length === 1 && positivePatterns[0] === 'package.json'))) {
+        positivePatterns.push('**/package.json');
+    }
+    return {
+        name: 'nx/core/package-json-workspaces',
+        createNodes: [
+            (0, globs_1.combineGlobPatterns)(positivePatterns),
+            (p) => {
+                if (!negativePatterns.some((negative) => (0, minimatch_1.minimatch)(p, negative))) {
+                    return createNodeFromPackageJson(p, root);
+                }
+                // A negative pattern matched, so we should not create a node for this package.json
+                return {};
+            },
+        ],
+    };
+}
+exports.getNxPackageJsonWorkspacesPlugin = getNxPackageJsonWorkspacesPlugin;
+function createNodeFromPackageJson(pkgJsonPath, root) {
+    const json = (0, fileutils_1.readJsonFile)((0, node_path_1.join)(root, pkgJsonPath));
+    const project = buildProjectConfigurationFromPackageJson(json, pkgJsonPath, (0, nx_json_1.readNxJson)(root));
+    return {
+        projects: {
+            [project.root]: project,
+        },
+    };
+}
+exports.createNodeFromPackageJson = createNodeFromPackageJson;
+function buildProjectConfigurationFromPackageJson(packageJson, path, nxJson) {
+    const normalizedPath = path.split('\\').join('/');
+    const directory = (0, node_path_1.dirname)(normalizedPath);
+    if (!packageJson.name && directory === '.') {
+        throw new Error('Nx requires the root package.json to specify a name if it is being used as an Nx project.');
+    }
+    let name = packageJson.name ?? (0, workspaces_1.toProjectName)(normalizedPath);
+    const projectType = nxJson?.workspaceLayout?.appsDir != nxJson?.workspaceLayout?.libsDir &&
+        nxJson?.workspaceLayout?.appsDir &&
+        directory.startsWith(nxJson.workspaceLayout.appsDir)
+        ? 'application'
+        : 'library';
+    return {
+        root: directory,
+        sourceRoot: directory,
+        name,
+        projectType,
+        ...packageJson.nx,
+        targets: (0, package_json_1.readTargetsFromPackageJson)(packageJson),
+    };
+}
+exports.buildProjectConfigurationFromPackageJson = buildProjectConfigurationFromPackageJson;
+/**
+ * Get the package.json globs from package manager workspaces
+ */
+function getGlobPatternsFromPackageManagerWorkspaces(root, readJson = (path) => (0, fileutils_1.readJsonFile)((0, node_path_1.join)(root, path)) // making this an arg allows us to reuse in devkit
+) {
+    try {
+        const patterns = [];
+        const packageJson = readJson('package.json');
+        patterns.push(...normalizePatterns(Array.isArray(packageJson.workspaces)
+            ? packageJson.workspaces
+            : packageJson.workspaces?.packages ?? []));
+        if ((0, node_fs_1.existsSync)((0, node_path_1.join)(root, 'pnpm-workspace.yaml'))) {
+            try {
+                const { packages } = (0, fileutils_1.readYamlFile)((0, node_path_1.join)(root, 'pnpm-workspace.yaml'));
+                patterns.push(...normalizePatterns(packages || []));
+            }
+            catch (e) {
+                output_1.output.warn({
+                    title: `${logger_1.NX_PREFIX} Unable to parse pnpm-workspace.yaml`,
+                    bodyLines: [e.toString()],
+                });
+            }
+        }
+        if ((0, node_fs_1.existsSync)((0, node_path_1.join)(root, 'lerna.json'))) {
+            try {
+                const { packages } = readJson('lerna.json');
+                patterns.push(...normalizePatterns(packages?.length > 0 ? packages : ['packages/*']));
+            }
+            catch (e) {
+                output_1.output.warn({
+                    title: `${logger_1.NX_PREFIX} Unable to parse lerna.json`,
+                    bodyLines: [e.toString()],
+                });
+            }
+        }
+        // Merge patterns from workspaces definitions
+        // TODO(@AgentEnder): update logic after better way to determine root project inclusion
+        // Include the root project
+        return packageJson.nx ? patterns.concat('package.json') : patterns;
+    }
+    catch {
+        return [];
+    }
+}
+exports.getGlobPatternsFromPackageManagerWorkspaces = getGlobPatternsFromPackageManagerWorkspaces;
+function normalizePatterns(patterns) {
+    return patterns.map((pattern) => removeRelativePath(pattern.endsWith('/package.json')
+        ? pattern
+        : (0, path_1.joinPathFragments)(pattern, 'package.json')));
+}
+function removeRelativePath(pattern) {
+    return pattern.startsWith('./') ? pattern.substring(2) : pattern;
 }
-
-try {
-  // add if support for Symbol.iterator is present
-  __nccwpck_require__(17005)(Yallist)
-} catch (er) {}
 
 
 /***/ }),
 
-/***/ 22287:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+/***/ 65286:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
 "use strict";
 
-const lenient = __nccwpck_require__(48234);
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+const tslib_1 = __nccwpck_require__(57265);
+tslib_1.__exportStar(__nccwpck_require__(26391), exports);
 
-const yn = (input, options) => {
-	input = String(input).trim();
 
-	options = Object.assign({
-		lenient: false,
-		default: null
-	}, options);
+/***/ }),
 
-	if (options.default !== null && typeof options.default !== 'boolean') {
-		throw new TypeError(`Expected the \`default\` option to be of type \`boolean\`, got \`${typeof options.default}\``);
-	}
+/***/ 1215:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
-	if (/^(?:y|yes|true|1)$/i.test(input)) {
-		return true;
-	}
+"use strict";
 
-	if (/^(?:n|no|false|0)$/i.test(input)) {
-		return false;
-	}
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.PackageJsonProjectsNextToProjectJsonPlugin = void 0;
+const path_1 = __nccwpck_require__(71017);
+const fs_1 = __nccwpck_require__(57147);
+const fileutils_1 = __nccwpck_require__(83851);
+const package_json_1 = __nccwpck_require__(4014);
+// TODO: Remove this one day, this should not need to be done.
+exports.PackageJsonProjectsNextToProjectJsonPlugin = {
+    // Its not a problem if plugins happen to have same name, and this
+    // will look least confusing in the source map.
+    name: 'nx/core/package-json',
+    createNodes: [
+        '{project.json,**/project.json}',
+        (file, _, { workspaceRoot }) => {
+            const project = createProjectFromPackageJsonNextToProjectJson(file, workspaceRoot);
+            return project
+                ? {
+                    projects: {
+                        [project.name]: project,
+                    },
+                }
+                : {};
+        },
+    ],
+};
+function createProjectFromPackageJsonNextToProjectJson(projectJsonPath, workspaceRoot) {
+    const root = (0, path_1.dirname)(projectJsonPath);
+    const packageJsonPath = (0, path_1.join)(workspaceRoot, root, 'package.json');
+    if (!(0, fs_1.existsSync)(packageJsonPath)) {
+        return null;
+    }
+    try {
+        const packageJson = (0, fileutils_1.readJsonFile)(packageJsonPath);
+        let { nx, name } = packageJson;
+        return {
+            ...nx,
+            name,
+            root,
+            targets: (0, package_json_1.readTargetsFromPackageJson)(packageJson),
+        };
+    }
+    catch (e) {
+        console.log(e);
+        return null;
+    }
+}
 
-	if (options.lenient === true) {
-		return lenient(input, options);
-	}
 
-	return options.default;
-};
+/***/ }),
 
-module.exports = yn;
-// TODO: Remove this for the next major release
-module.exports["default"] = yn;
+/***/ 76877:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
+
+"use strict";
+
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.buildProjectFromProjectJson = exports.ProjectJsonProjectsPlugin = void 0;
+const node_path_1 = __nccwpck_require__(49411);
+const workspaces_1 = __nccwpck_require__(26546);
+const fileutils_1 = __nccwpck_require__(83851);
+exports.ProjectJsonProjectsPlugin = {
+    name: 'nx/core/project-json',
+    createNodes: [
+        '{project.json,**/project.json}',
+        (file, _, { workspaceRoot }) => {
+            const json = (0, fileutils_1.readJsonFile)((0, node_path_1.join)(workspaceRoot, file));
+            const project = buildProjectFromProjectJson(json, file);
+            return {
+                projects: {
+                    [project.root]: project,
+                },
+            };
+        },
+    ],
+};
+function buildProjectFromProjectJson(json, path) {
+    return {
+        name: (0, workspaces_1.toProjectName)(path),
+        root: (0, node_path_1.dirname)(path),
+        ...json,
+    };
+}
+exports.buildProjectFromProjectJson = buildProjectFromProjectJson;
 
 
 /***/ }),
 
-/***/ 48234:
-/***/ ((module) => {
+/***/ 50280:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
 "use strict";
 
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.getTargetInfo = exports.TargetDefaultsPlugin = exports.ONLY_MODIFIES_EXISTING_TARGET = void 0;
+const minimatch_1 = __nccwpck_require__(55224);
+const node_fs_1 = __nccwpck_require__(87561);
+const node_path_1 = __nccwpck_require__(49411);
+const fileutils_1 = __nccwpck_require__(83851);
+const globs_1 = __nccwpck_require__(94865);
+const package_json_workspaces_1 = __nccwpck_require__(65286);
+/**
+ * This symbol marks that a target provides information which should modify a target already registered
+ * on the project via other plugins. If the target has not already been registered, and this symbol is true,
+ * the information provided by it will be discarded.
+ */
+exports.ONLY_MODIFIES_EXISTING_TARGET = Symbol('ONLY_MODIFIES_EXISTING_TARGET');
+exports.TargetDefaultsPlugin = {
+    name: 'nx/core/target-defaults',
+    createNodes: [
+        '{package.json,**/package.json,project.json,**/project.json}',
+        (configFile, _, ctx) => {
+            const fileName = (0, node_path_1.basename)(configFile);
+            const root = (0, node_path_1.dirname)(configFile);
+            const packageManagerWorkspacesGlob = (0, globs_1.combineGlobPatterns)((0, package_json_workspaces_1.getGlobPatternsFromPackageManagerWorkspaces)(ctx.workspaceRoot));
+            // Only process once if package.json + project.json both exist
+            if (fileName === 'package.json' &&
+                (0, node_fs_1.existsSync)((0, node_path_1.join)(ctx.workspaceRoot, root, 'project.json'))) {
+                return {};
+            }
+            else if (fileName === 'package.json' &&
+                !(0, minimatch_1.minimatch)(configFile, packageManagerWorkspacesGlob)) {
+                return {};
+            }
+            // If no target defaults, this does nothing
+            const targetDefaults = ctx.nxJsonConfiguration?.targetDefaults;
+            if (!targetDefaults) {
+                return {};
+            }
+            const projectJson = readJsonOrNull((0, node_path_1.join)(ctx.workspaceRoot, root, 'project.json'));
+            const packageJson = readJsonOrNull((0, node_path_1.join)(ctx.workspaceRoot, root, 'package.json'));
+            const includedScripts = packageJson?.nx?.includedScripts;
+            const projectDefinedTargets = new Set([
+                ...Object.keys(packageJson?.scripts ?? {}).filter((script) => {
+                    if (includedScripts) {
+                        return includedScripts.includes(script);
+                    }
+                    return true;
+                }),
+                ...Object.keys(projectJson?.targets ?? {}),
+                ...Object.keys(packageJson?.nx?.targets ?? {}),
+            ]);
+            const executorToTargetMap = getExecutorToTargetMap(packageJson, projectJson);
+            const modifiedTargets = {};
+            for (const defaultSpecifier in targetDefaults) {
+                const targetNames = executorToTargetMap.get(defaultSpecifier) ?? new Set();
+                targetNames.add(defaultSpecifier);
+                for (const targetName of targetNames) {
+                    // Prevents `build` from overwriting `@nx/js:tsc` if both are present
+                    // and build is specified later in the ordering.
+                    if (!modifiedTargets[targetName] || targetName !== defaultSpecifier) {
+                        const defaults = JSON.parse(JSON.stringify(targetDefaults[defaultSpecifier]));
+                        modifiedTargets[targetName] = {
+                            ...getTargetInfo(targetName, projectJson, packageJson),
+                            ...defaults,
+                        };
+                    }
+                    // TODO: Remove this after we figure out a way to define new targets
+                    // in target defaults
+                    if (!projectDefinedTargets.has(targetName)) {
+                        modifiedTargets[targetName][exports.ONLY_MODIFIES_EXISTING_TARGET] = true;
+                    }
+                }
+            }
+            return {
+                projects: {
+                    [root]: {
+                        targets: modifiedTargets,
+                    },
+                },
+            };
+        },
+    ],
+};
+function getExecutorToTargetMap(packageJson, projectJson) {
+    const executorToTargetMap = new Map();
+    const targets = Object.keys({
+        ...projectJson?.targets,
+        ...packageJson?.scripts,
+        ...packageJson?.nx?.targets,
+    });
+    for (const target of targets) {
+        const executor = projectJson?.targets?.[target]?.executor ??
+            packageJson?.nx?.targets?.[target]?.executor ??
+            'nx:run-script';
+        const targetsForExecutor = executorToTargetMap.get(executor) ?? new Set();
+        targetsForExecutor.add(target);
+        executorToTargetMap.set(executor, targetsForExecutor);
+    }
+    return executorToTargetMap;
+}
+function readJsonOrNull(path) {
+    if ((0, node_fs_1.existsSync)(path)) {
+        return (0, fileutils_1.readJsonFile)(path);
+    }
+    else {
+        return null;
+    }
+}
+/**
+ * This fn gets target info that would make a target uniquely compatible
+ * with what is described by project.json or package.json. As the merge process
+ * for config happens, without this, the target defaults may be compatible
+ * with a config from a plugin and then that combined target be incompatible
+ * with the project json configuration resulting in the target default values
+ * being scrapped. By adding enough information from the project.json / package.json,
+ * we can make sure that the target after merging is compatible with the defined target.
+ */
+function getTargetInfo(target, projectJson, packageJson) {
+    const projectJsonTarget = projectJson?.targets?.[target];
+    const packageJsonTarget = packageJson?.nx?.targets?.[target];
+    const executor = getTargetExecutor(target, projectJson, packageJson);
+    const targetOptions = {
+        ...packageJsonTarget?.options,
+        ...projectJsonTarget?.options,
+    };
+    if (projectJsonTarget?.command) {
+        return {
+            command: projectJsonTarget?.command,
+        };
+    }
+    if (executor === 'nx:run-commands') {
+        if (targetOptions?.command) {
+            return {
+                executor: 'nx:run-commands',
+                options: {
+                    command: projectJsonTarget.options?.command,
+                },
+            };
+        }
+        else if (targetOptions?.commands) {
+            return {
+                executor: 'nx:run-commands',
+                options: {
+                    commands: targetOptions.commands,
+                },
+            };
+        }
+        return {
+            executor: 'nx:run-commands',
+        };
+    }
+    if (executor === 'nx:run-script') {
+        return {
+            executor: 'nx:run-script',
+            options: {
+                script: targetOptions?.script ?? target,
+            },
+        };
+    }
+    if (executor) {
+        return { executor };
+    }
+    return {};
+}
+exports.getTargetInfo = getTargetInfo;
+function getTargetExecutor(target, projectJson, packageJson) {
+    const projectJsonTarget = projectJson?.targets?.[target];
+    const packageJsonTarget = packageJson?.nx?.targets?.[target];
+    const packageJsonScript = packageJson?.scripts?.[target];
+    if (projectJsonTarget?.command) {
+        return 'nx:run-commands';
+    }
+    if (!projectJsonTarget?.executor &&
+        !packageJsonTarget?.executor &&
+        packageJsonScript) {
+        return 'nx:run-script';
+    }
+    return projectJsonTarget?.executor ?? packageJsonTarget?.executor;
+}
 
-const YES_MATCH_SCORE_THRESHOLD = 2;
-const NO_MATCH_SCORE_THRESHOLD = 1.25;
-
-const yMatch = new Map([
-	[5, 0.25],
-	[6, 0.25],
-	[7, 0.25],
-	['t', 0.75],
-	['y', 1],
-	['u', 0.75],
-	['g', 0.25],
-	['h', 0.25],
-	['j', 0.25]
-]);
 
-const eMatch = new Map([
-	[2, 0.25],
-	[3, 0.25],
-	[4, 0.25],
-	['w', 0.75],
-	['e', 1],
-	['r', 0.75],
-	['s', 0.25],
-	['d', 0.25],
-	['f', 0.25]
-]);
+/***/ }),
 
-const sMatch = new Map([
-	['q', 0.25],
-	['w', 0.25],
-	['e', 0.25],
-	['a', 0.75],
-	['s', 1],
-	['d', 0.75],
-	['z', 0.25],
-	['x', 0.25],
-	['c', 0.25]
-]);
+/***/ 71553:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
-const nMatch = new Map([
-	['h', 0.25],
-	['j', 0.25],
-	['k', 0.25],
-	['b', 0.75],
-	['n', 1],
-	['m', 0.75]
-]);
+"use strict";
 
-const oMatch = new Map([
-	[9, 0.25],
-	[0, 0.25],
-	['i', 0.75],
-	['o', 1],
-	['p', 0.75],
-	['k', 0.25],
-	['l', 0.25]
-]);
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.buildProjectGraphUsingProjectFileMap = exports.getFileMap = void 0;
+const workspace_root_1 = __nccwpck_require__(86708);
+const path_1 = __nccwpck_require__(71017);
+const perf_hooks_1 = __nccwpck_require__(4074);
+const assert_workspace_validity_1 = __nccwpck_require__(89208);
+const nx_deps_cache_1 = __nccwpck_require__(57074);
+const implicit_project_dependencies_1 = __nccwpck_require__(85251);
+const normalize_project_nodes_1 = __nccwpck_require__(44852);
+const nx_plugin_1 = __nccwpck_require__(84141);
+const typescript_1 = __nccwpck_require__(37650);
+const fileutils_1 = __nccwpck_require__(83851);
+const project_graph_builder_1 = __nccwpck_require__(80862);
+const configuration_1 = __nccwpck_require__(38777);
+const fs_1 = __nccwpck_require__(57147);
+const installation_directory_1 = __nccwpck_require__(98584);
+const output_1 = __nccwpck_require__(1737);
+let storedFileMap = null;
+let storedAllWorkspaceFiles = null;
+let storedRustReferences = null;
+function getFileMap() {
+    if (!!storedFileMap) {
+        return {
+            fileMap: storedFileMap,
+            allWorkspaceFiles: storedAllWorkspaceFiles,
+            rustReferences: storedRustReferences,
+        };
+    }
+    else {
+        return {
+            fileMap: {
+                nonProjectFiles: [],
+                projectFileMap: {},
+            },
+            allWorkspaceFiles: [],
+            rustReferences: null,
+        };
+    }
+}
+exports.getFileMap = getFileMap;
+async function buildProjectGraphUsingProjectFileMap(projects, externalNodes, fileMap, allWorkspaceFiles, rustReferences, fileMapCache, shouldWriteCache) {
+    storedFileMap = fileMap;
+    storedAllWorkspaceFiles = allWorkspaceFiles;
+    storedRustReferences = rustReferences;
+    const nxJson = (0, configuration_1.readNxJson)();
+    const projectGraphVersion = '6.0';
+    (0, assert_workspace_validity_1.assertWorkspaceValidity)(projects, nxJson);
+    const packageJsonDeps = readCombinedDeps();
+    const rootTsConfig = readRootTsConfig();
+    let filesToProcess;
+    let cachedFileData;
+    const useCacheData = fileMapCache &&
+        !(0, nx_deps_cache_1.shouldRecomputeWholeGraph)(fileMapCache, packageJsonDeps, projects, nxJson, rootTsConfig);
+    if (useCacheData) {
+        const fromCache = (0, nx_deps_cache_1.extractCachedFileData)(fileMap, fileMapCache);
+        filesToProcess = fromCache.filesToProcess;
+        cachedFileData = fromCache.cachedFileData;
+    }
+    else {
+        filesToProcess = fileMap;
+        cachedFileData = {
+            nonProjectFiles: {},
+            projectFileMap: {},
+        };
+    }
+    const context = createContext(projects, nxJson, externalNodes, fileMap, filesToProcess);
+    let projectGraph = await buildProjectGraphUsingContext(nxJson, externalNodes, context, cachedFileData, projectGraphVersion);
+    const projectFileMapCache = (0, nx_deps_cache_1.createProjectFileMapCache)(nxJson, packageJsonDeps, fileMap, rootTsConfig);
+    if (shouldWriteCache) {
+        (0, nx_deps_cache_1.writeCache)(projectFileMapCache, projectGraph);
+    }
+    return {
+        projectGraph,
+        projectFileMapCache,
+    };
+}
+exports.buildProjectGraphUsingProjectFileMap = buildProjectGraphUsingProjectFileMap;
+function readCombinedDeps() {
+    const installationPackageJsonPath = (0, path_1.join)(workspace_root_1.workspaceRoot, '.nx', 'installation', 'package.json');
+    const installationPackageJson = (0, fs_1.existsSync)(installationPackageJsonPath)
+        ? (0, fileutils_1.readJsonFile)(installationPackageJsonPath)
+        : {};
+    const rootPackageJsonPath = (0, path_1.join)(workspace_root_1.workspaceRoot, 'package.json');
+    const rootPackageJson = (0, fs_1.existsSync)(rootPackageJsonPath)
+        ? (0, fileutils_1.readJsonFile)(rootPackageJsonPath)
+        : {};
+    return {
+        ...rootPackageJson.dependencies,
+        ...rootPackageJson.devDependencies,
+        ...installationPackageJson.dependencies,
+        ...installationPackageJson.devDependencies,
+    };
+}
+async function buildProjectGraphUsingContext(nxJson, knownExternalNodes, ctx, cachedFileData, projectGraphVersion) {
+    perf_hooks_1.performance.mark('build project graph:start');
+    const builder = new project_graph_builder_1.ProjectGraphBuilder(null, ctx.fileMap.projectFileMap);
+    builder.setVersion(projectGraphVersion);
+    for (const node in knownExternalNodes) {
+        builder.addExternalNode(knownExternalNodes[node]);
+    }
+    await (0, normalize_project_nodes_1.normalizeProjectNodes)(ctx, builder);
+    const initProjectGraph = builder.getUpdatedProjectGraph();
+    const r = await updateProjectGraphWithPlugins(ctx, initProjectGraph);
+    const updatedBuilder = new project_graph_builder_1.ProjectGraphBuilder(r, ctx.fileMap.projectFileMap);
+    for (const proj of Object.keys(cachedFileData.projectFileMap)) {
+        for (const f of ctx.fileMap.projectFileMap[proj] || []) {
+            const cached = cachedFileData.projectFileMap[proj][f.file];
+            if (cached && cached.deps) {
+                f.deps = [...cached.deps];
+            }
+        }
+    }
+    for (const file of ctx.fileMap.nonProjectFiles) {
+        const cached = cachedFileData.nonProjectFiles[file.file];
+        if (cached?.deps) {
+            file.deps = [...cached.deps];
+        }
+    }
+    (0, implicit_project_dependencies_1.applyImplicitDependencies)(ctx.projects, updatedBuilder);
+    const finalGraph = updatedBuilder.getUpdatedProjectGraph();
+    perf_hooks_1.performance.mark('build project graph:end');
+    perf_hooks_1.performance.measure('build project graph', 'build project graph:start', 'build project graph:end');
+    return finalGraph;
+}
+function createContext(projects, nxJson, externalNodes, fileMap, filesToProcess) {
+    const clonedProjects = Object.keys(projects).reduce((map, projectName) => {
+        map[projectName] = {
+            ...projects[projectName],
+        };
+        return map;
+    }, {});
+    return {
+        nxJsonConfiguration: nxJson,
+        projects: clonedProjects,
+        externalNodes,
+        workspaceRoot: workspace_root_1.workspaceRoot,
+        fileMap,
+        filesToProcess,
+    };
+}
+async function updateProjectGraphWithPlugins(context, initProjectGraph) {
+    const plugins = await (0, nx_plugin_1.loadNxPlugins)(context.nxJsonConfiguration?.plugins, (0, installation_directory_1.getNxRequirePaths)(), context.workspaceRoot, context.projects);
+    let graph = initProjectGraph;
+    for (const { plugin } of plugins) {
+        try {
+            if ((0, nx_plugin_1.isNxPluginV1)(plugin) &&
+                plugin.processProjectGraph &&
+                !plugin.createDependencies) {
+                output_1.output.warn({
+                    title: `${plugin.name} is a v1 plugin.`,
+                    bodyLines: [
+                        'Nx has recently released a v2 model for project graph plugins. The `processProjectGraph` method is deprecated. Plugins should use some combination of `createNodes` and `createDependencies` instead.',
+                    ],
+                });
+                perf_hooks_1.performance.mark(`${plugin.name}:processProjectGraph - start`);
+                graph = await plugin.processProjectGraph(graph, {
+                    ...context,
+                    projectsConfigurations: {
+                        projects: context.projects,
+                        version: 2,
+                    },
+                    fileMap: context.fileMap.projectFileMap,
+                    filesToProcess: context.filesToProcess.projectFileMap,
+                    workspace: {
+                        version: 2,
+                        projects: context.projects,
+                        ...context.nxJsonConfiguration,
+                    },
+                });
+                perf_hooks_1.performance.mark(`${plugin.name}:processProjectGraph - end`);
+                perf_hooks_1.performance.measure(`${plugin.name}:processProjectGraph`, `${plugin.name}:processProjectGraph - start`, `${plugin.name}:processProjectGraph - end`);
+            }
+        }
+        catch (e) {
+            let message = `Failed to process the project graph with "${plugin.name}".`;
+            if (e instanceof Error) {
+                e.message = message + '\n' + e.message;
+                throw e;
+            }
+            throw new Error(message);
+        }
+    }
+    const builder = new project_graph_builder_1.ProjectGraphBuilder(graph, context.fileMap.projectFileMap, context.fileMap.nonProjectFiles);
+    const createDependencyPlugins = plugins.filter(({ plugin }) => (0, nx_plugin_1.isNxPluginV2)(plugin) && plugin.createDependencies);
+    await Promise.all(createDependencyPlugins.map(async ({ plugin, options }) => {
+        perf_hooks_1.performance.mark(`${plugin.name}:createDependencies - start`);
+        // Set this globally to allow plugins to know if they are being called from the project graph creation
+        global.NX_GRAPH_CREATION = true;
+        try {
+            const dependencies = await plugin.createDependencies(options, {
+                ...context,
+            });
+            for (const dep of dependencies) {
+                builder.addDependency(dep.source, dep.target, dep.type, 'sourceFile' in dep ? dep.sourceFile : null);
+            }
+        }
+        catch (e) {
+            let message = `Failed to process project dependencies with "${plugin.name}".`;
+            if (e instanceof Error) {
+                e.message = message + '\n' + e.message;
+                throw e;
+            }
+            throw new Error(message);
+        }
+        delete global.NX_GRAPH_CREATION;
+        perf_hooks_1.performance.mark(`${plugin.name}:createDependencies - end`);
+        perf_hooks_1.performance.measure(`${plugin.name}:createDependencies`, `${plugin.name}:createDependencies - start`, `${plugin.name}:createDependencies - end`);
+    }));
+    return builder.getUpdatedProjectGraph();
+}
+function readRootTsConfig() {
+    try {
+        const tsConfigPath = (0, typescript_1.getRootTsConfigPath)();
+        if (tsConfigPath) {
+            return (0, fileutils_1.readJsonFile)(tsConfigPath, { expectComments: true });
+        }
+    }
+    catch (e) {
+        return {};
+    }
+}
 
-function getYesMatchScore(value) {
-	const [y, e, s] = value;
-	let score = 0;
 
-	if (yMatch.has(y)) {
-		score += yMatch.get(y);
-	}
+/***/ }),
 
-	if (eMatch.has(e)) {
-		score += eMatch.get(e);
-	}
+/***/ 63260:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
-	if (sMatch.has(s)) {
-		score += sMatch.get(s);
-	}
+"use strict";
 
-	return score;
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.workspaceLayout = exports.readNxJson = exports.readPackageJson = exports.defaultFileRead = exports.readWorkspaceConfig = exports.TEN_MEGABYTES = exports.calculateFileChanges = exports.isDeletedFileChange = exports.isWholeFileChange = exports.DeletedFileChange = exports.WholeFileChange = void 0;
+const child_process_1 = __nccwpck_require__(32081);
+const fs_1 = __nccwpck_require__(57147);
+const path_1 = __nccwpck_require__(71017);
+const configuration_1 = __nccwpck_require__(38777);
+const workspace_root_1 = __nccwpck_require__(86708);
+const fileutils_1 = __nccwpck_require__(83851);
+const json_diff_1 = __nccwpck_require__(72517);
+const project_graph_1 = __nccwpck_require__(61371);
+const angular_json_1 = __nccwpck_require__(44050);
+const ignore_1 = __nccwpck_require__(77098);
+const retrieve_workspace_files_1 = __nccwpck_require__(14249);
+const project_configuration_utils_1 = __nccwpck_require__(33190);
+const nx_plugin_deprecated_1 = __nccwpck_require__(32256);
+const minimatch_1 = __nccwpck_require__(55224);
+const package_json_next_to_project_json_1 = __nccwpck_require__(1215);
+class WholeFileChange {
+    constructor() {
+        this.type = 'WholeFileChange';
+    }
+}
+exports.WholeFileChange = WholeFileChange;
+class DeletedFileChange {
+    constructor() {
+        this.type = 'WholeFileDeleted';
+    }
+}
+exports.DeletedFileChange = DeletedFileChange;
+function isWholeFileChange(change) {
+    return change.type === 'WholeFileChange';
+}
+exports.isWholeFileChange = isWholeFileChange;
+function isDeletedFileChange(change) {
+    return change.type === 'WholeFileDeleted';
+}
+exports.isDeletedFileChange = isDeletedFileChange;
+function calculateFileChanges(files, allWorkspaceFiles, nxArgs, readFileAtRevision = defaultReadFileAtRevision, ignore = (0, ignore_1.getIgnoreObject)()) {
+    files = files.filter((f) => !ignore.ignores(f));
+    return files.map((f) => {
+        const ext = (0, path_1.extname)(f);
+        const file = allWorkspaceFiles.find((fileData) => fileData.file == f);
+        const hash = file?.hash;
+        return {
+            file: f,
+            ext,
+            hash,
+            getChanges: () => {
+                if (!(0, fs_1.existsSync)((0, path_1.join)(workspace_root_1.workspaceRoot, f))) {
+                    return [new DeletedFileChange()];
+                }
+                if (!nxArgs) {
+                    return [new WholeFileChange()];
+                }
+                if (nxArgs.files && nxArgs.files.includes(f)) {
+                    return [new WholeFileChange()];
+                }
+                switch (ext) {
+                    case '.json':
+                        try {
+                            const atBase = readFileAtRevision(f, nxArgs.base);
+                            const atHead = readFileAtRevision(f, nxArgs.head);
+                            return (0, json_diff_1.jsonDiff)(JSON.parse(atBase), JSON.parse(atHead));
+                        }
+                        catch (e) {
+                            return [new WholeFileChange()];
+                        }
+                    default:
+                        return [new WholeFileChange()];
+                }
+            },
+        };
+    });
+}
+exports.calculateFileChanges = calculateFileChanges;
+exports.TEN_MEGABYTES = 1024 * 10000;
+function defaultReadFileAtRevision(file, revision) {
+    try {
+        const fileFullPath = `${workspace_root_1.workspaceRoot}${path_1.sep}${file}`;
+        const gitRepositoryPath = (0, child_process_1.execSync)('git rev-parse --show-toplevel')
+            .toString()
+            .trim();
+        const filePathInGitRepository = (0, path_1.relative)(gitRepositoryPath, fileFullPath)
+            .split(path_1.sep)
+            .join('/');
+        return !revision
+            ? (0, fs_1.readFileSync)(file, 'utf-8')
+            : (0, child_process_1.execSync)(`git show ${revision}:${filePathInGitRepository}`, {
+                maxBuffer: exports.TEN_MEGABYTES,
+                stdio: ['pipe', 'pipe', 'ignore'],
+            })
+                .toString()
+                .trim();
+    }
+    catch {
+        return '';
+    }
+}
+/**
+ * TODO(v19): Remove this function
+ * @deprecated To get projects use {@link retrieveProjectConfigurations} instead
+ */
+function readWorkspaceConfig(opts) {
+    let configuration = null;
+    const root = opts.path || process.cwd();
+    const nxJson = (0, configuration_1.readNxJson)(root);
+    try {
+        const projectGraph = (0, project_graph_1.readCachedProjectGraph)();
+        configuration = {
+            ...nxJson,
+            ...(0, project_graph_1.readProjectsConfigurationFromProjectGraph)(projectGraph),
+        };
+    }
+    catch {
+        configuration = {
+            version: 2,
+            projects: getProjectsSyncNoInference(root, nxJson).projects,
+        };
+    }
+    if (opts.format === 'angularCli') {
+        return (0, angular_json_1.toOldFormat)(configuration);
+    }
+    else {
+        return configuration;
+    }
+}
+exports.readWorkspaceConfig = readWorkspaceConfig;
+function defaultFileRead(filePath) {
+    return (0, fs_1.readFileSync)((0, path_1.join)(workspace_root_1.workspaceRoot, filePath), 'utf-8');
+}
+exports.defaultFileRead = defaultFileRead;
+function readPackageJson() {
+    try {
+        return (0, fileutils_1.readJsonFile)(`${workspace_root_1.workspaceRoot}/package.json`);
+    }
+    catch {
+        return {}; // if package.json doesn't exist
+    }
+}
+exports.readPackageJson = readPackageJson;
+// TODO(17): Remove these exports
+var configuration_2 = __nccwpck_require__(38777);
+Object.defineProperty(exports, "readNxJson", ({ enumerable: true, get: function () { return configuration_2.readNxJson; } }));
+Object.defineProperty(exports, "workspaceLayout", ({ enumerable: true, get: function () { return configuration_2.workspaceLayout; } }));
+/**
+ * TODO(v19): Remove this function.
+ */
+function getProjectsSyncNoInference(root, nxJson) {
+    const projectFiles = (0, retrieve_workspace_files_1.retrieveProjectConfigurationPaths)(root, (0, nx_plugin_deprecated_1.getDefaultPluginsSync)(root));
+    const plugins = [
+        { plugin: package_json_next_to_project_json_1.PackageJsonProjectsNextToProjectJsonPlugin },
+        ...(0, nx_plugin_deprecated_1.getDefaultPluginsSync)(root),
+    ];
+    const projectRootMap = new Map();
+    // We iterate over plugins first - this ensures that plugins specified first take precedence.
+    for (const { plugin, options } of plugins) {
+        const [pattern, createNodes] = plugin.createNodes ?? [];
+        if (!pattern) {
+            continue;
+        }
+        for (const file of projectFiles) {
+            if ((0, minimatch_1.minimatch)(file, pattern, { dot: true })) {
+                let r = createNodes(file, options, {
+                    nxJsonConfiguration: nxJson,
+                    workspaceRoot: root,
+                });
+                for (const node in r.projects) {
+                    const project = {
+                        root: node,
+                        ...r.projects[node],
+                    };
+                    (0, project_configuration_utils_1.mergeProjectConfigurationIntoRootMap)(projectRootMap, project);
+                }
+            }
+        }
+    }
+    return {
+        projects: (0, project_configuration_utils_1.readProjectConfigurationsFromRootMap)(projectRootMap),
+    };
 }
 
-function getNoMatchScore(value) {
-	const [n, o] = value;
-	let score = 0;
 
-	if (nMatch.has(n)) {
-		score += nMatch.get(n);
-	}
+/***/ }),
 
-	if (oMatch.has(o)) {
-		score += oMatch.get(o);
-	}
+/***/ 57074:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
-	return score;
+"use strict";
+
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.extractCachedFileData = exports.shouldRecomputeWholeGraph = exports.writeCache = exports.createProjectFileMapCache = exports.readProjectGraphCache = exports.readFileMapCache = exports.ensureCacheDirectory = exports.nxFileMap = exports.nxProjectGraph = void 0;
+const fs_1 = __nccwpck_require__(57147);
+const fs_extra_1 = __nccwpck_require__(27475);
+const path_1 = __nccwpck_require__(71017);
+const perf_hooks_1 = __nccwpck_require__(4074);
+const cache_directory_1 = __nccwpck_require__(15120);
+const fileutils_1 = __nccwpck_require__(83851);
+const versions_1 = __nccwpck_require__(92941);
+exports.nxProjectGraph = (0, path_1.join)(cache_directory_1.projectGraphCacheDirectory, 'project-graph.json');
+exports.nxFileMap = (0, path_1.join)(cache_directory_1.projectGraphCacheDirectory, 'file-map.json');
+function ensureCacheDirectory() {
+    try {
+        if (!(0, fs_1.existsSync)(cache_directory_1.projectGraphCacheDirectory)) {
+            (0, fs_extra_1.ensureDirSync)(cache_directory_1.projectGraphCacheDirectory);
+        }
+    }
+    catch (e) {
+        /*
+         * @jeffbcross: Node JS docs recommend against checking for existence of directory immediately before creating it.
+         * Instead, just try to create the directory and handle the error.
+         *
+         * We ran into race conditions when running scripts concurrently, where multiple scripts were
+         * arriving here simultaneously, checking for directory existence, then trying to create the directory simultaneously.
+         *
+         * In this case, we're creating the directory. If the operation failed, we ensure that the directory
+         * exists before continuing (or raise an exception).
+         */
+        if (!(0, fileutils_1.directoryExists)(cache_directory_1.projectGraphCacheDirectory)) {
+            throw new Error(`Failed to create directory: ${cache_directory_1.projectGraphCacheDirectory}`);
+        }
+    }
+}
+exports.ensureCacheDirectory = ensureCacheDirectory;
+function readFileMapCache() {
+    perf_hooks_1.performance.mark('read cache:start');
+    ensureCacheDirectory();
+    let data = null;
+    try {
+        if ((0, fileutils_1.fileExists)(exports.nxFileMap)) {
+            data = (0, fileutils_1.readJsonFile)(exports.nxFileMap);
+        }
+    }
+    catch (error) {
+        console.log(`Error reading '${exports.nxFileMap}'. Continue the process without the cache.`);
+        console.log(error);
+    }
+    perf_hooks_1.performance.mark('read cache:end');
+    perf_hooks_1.performance.measure('read cache', 'read cache:start', 'read cache:end');
+    return data ?? null;
+}
+exports.readFileMapCache = readFileMapCache;
+function readProjectGraphCache() {
+    perf_hooks_1.performance.mark('read project-graph:start');
+    ensureCacheDirectory();
+    let data = null;
+    try {
+        if ((0, fileutils_1.fileExists)(exports.nxProjectGraph)) {
+            data = (0, fileutils_1.readJsonFile)(exports.nxProjectGraph);
+        }
+    }
+    catch (error) {
+        console.log(`Error reading '${exports.nxProjectGraph}'. Continue the process without the cache.`);
+        console.log(error);
+    }
+    perf_hooks_1.performance.mark('read project-graph:end');
+    perf_hooks_1.performance.measure('read cache', 'read project-graph:start', 'read project-graph:end');
+    return data ?? null;
+}
+exports.readProjectGraphCache = readProjectGraphCache;
+function createProjectFileMapCache(nxJson, packageJsonDeps, fileMap, tsConfig) {
+    const nxJsonPlugins = getNxJsonPluginsData(nxJson, packageJsonDeps);
+    const newValue = {
+        version: '6.0',
+        nxVersion: versions_1.nxVersion,
+        deps: packageJsonDeps, // TODO(v19): We can remove this in favor of nxVersion
+        // compilerOptions may not exist, especially for package-based repos
+        pathMappings: tsConfig?.compilerOptions?.paths || {},
+        nxJsonPlugins,
+        pluginsConfig: nxJson?.pluginsConfig,
+        fileMap,
+    };
+    return newValue;
+}
+exports.createProjectFileMapCache = createProjectFileMapCache;
+function writeCache(cache, projectGraph) {
+    perf_hooks_1.performance.mark('write cache:start');
+    let retry = 1;
+    let done = false;
+    do {
+        // write first to a unique temporary filename and then do a
+        // rename of the file to the correct filename
+        // this is to avoid any problems with half-written files
+        // in case of crash and/or partially written files due
+        // to multiple parallel processes reading and writing this file
+        const unique = (Math.random().toString(16) + '0000000').slice(2, 10);
+        const tmpProjectGraphPath = `${exports.nxProjectGraph}~${unique}`;
+        const tmpFileMapPath = `${exports.nxFileMap}~${unique}`;
+        try {
+            (0, fileutils_1.writeJsonFile)(tmpProjectGraphPath, projectGraph);
+            (0, fs_extra_1.renameSync)(tmpProjectGraphPath, exports.nxProjectGraph);
+            (0, fileutils_1.writeJsonFile)(tmpFileMapPath, cache);
+            (0, fs_extra_1.renameSync)(tmpFileMapPath, exports.nxFileMap);
+            done = true;
+        }
+        catch (err) {
+            if (err instanceof Error) {
+                console.log(`ERROR (${retry}) when writing \n${err.message}\n${err.stack}`);
+            }
+            else {
+                console.log(`ERROR  (${retry}) unknown error when writing ${exports.nxProjectGraph} and ${exports.nxFileMap}`);
+            }
+            ++retry;
+        }
+    } while (!done && retry < 5);
+    perf_hooks_1.performance.mark('write cache:end');
+    perf_hooks_1.performance.measure('write cache', 'write cache:start', 'write cache:end');
+}
+exports.writeCache = writeCache;
+function shouldRecomputeWholeGraph(cache, packageJsonDeps, projects, nxJson, tsConfig) {
+    if (cache.version !== '6.0') {
+        return true;
+    }
+    if (cache.nxVersion !== versions_1.nxVersion) {
+        return true;
+    }
+    // we have a cached project that is no longer present
+    const cachedNodes = Object.keys(cache.fileMap.projectFileMap);
+    if (cachedNodes.some((p) => projects[p] === undefined)) {
+        return true;
+    }
+    // a path mapping for an existing project has changed
+    if (Object.keys(cache.pathMappings).some((t) => {
+        const cached = cache.pathMappings && cache.pathMappings[t]
+            ? JSON.stringify(cache.pathMappings[t])
+            : undefined;
+        const notCached = tsConfig?.compilerOptions?.paths && tsConfig?.compilerOptions?.paths[t]
+            ? JSON.stringify(tsConfig.compilerOptions.paths[t])
+            : undefined;
+        return cached !== notCached;
+    })) {
+        return true;
+    }
+    // a new plugin has been added
+    if (JSON.stringify(getNxJsonPluginsData(nxJson, packageJsonDeps)) !==
+        JSON.stringify(cache.nxJsonPlugins)) {
+        return true;
+    }
+    if (JSON.stringify(nxJson?.pluginsConfig) !==
+        JSON.stringify(cache.pluginsConfig)) {
+        return true;
+    }
+    return false;
+}
+exports.shouldRecomputeWholeGraph = shouldRecomputeWholeGraph;
+/*
+This can only be invoked when the list of projects is either the same
+or new projects have been added, so every project in the cache has a corresponding
+project in fileMap
+*/
+function extractCachedFileData(fileMap, c) {
+    const filesToProcess = {
+        nonProjectFiles: [],
+        projectFileMap: {},
+    };
+    const cachedFileData = {
+        nonProjectFiles: {},
+        projectFileMap: {},
+    };
+    const currentProjects = Object.keys(fileMap.projectFileMap).filter((name) => fileMap.projectFileMap[name].length > 0);
+    currentProjects.forEach((p) => {
+        processProjectNode(p, c.fileMap.projectFileMap, cachedFileData.projectFileMap, filesToProcess.projectFileMap, fileMap);
+    });
+    processNonProjectFiles(c.fileMap.nonProjectFiles, fileMap.nonProjectFiles, filesToProcess.nonProjectFiles, cachedFileData.nonProjectFiles);
+    return {
+        filesToProcess,
+        cachedFileData,
+    };
+}
+exports.extractCachedFileData = extractCachedFileData;
+function processNonProjectFiles(cachedFiles, nonProjectFiles, filesToProcess, cachedFileData) {
+    const cachedHashMap = new Map(cachedFiles.map((f) => [f.file, f]));
+    for (const f of nonProjectFiles) {
+        const cachedFile = cachedHashMap.get(f.file);
+        if (!cachedFile || cachedFile.hash !== f.hash) {
+            filesToProcess.push(f);
+        }
+        else {
+            cachedFileData[f.file] = cachedFile;
+        }
+    }
+}
+function processProjectNode(projectName, cachedFileMap, cachedFileData, filesToProcess, { projectFileMap }) {
+    if (!cachedFileMap[projectName]) {
+        filesToProcess[projectName] = projectFileMap[projectName];
+        return;
+    }
+    const fileDataFromCache = {};
+    for (let f of cachedFileMap[projectName]) {
+        fileDataFromCache[f.file] = f;
+    }
+    if (!cachedFileData[projectName]) {
+        cachedFileData[projectName] = {};
+    }
+    for (let f of projectFileMap[projectName]) {
+        const fromCache = fileDataFromCache[f.file];
+        if (fromCache && fromCache.hash == f.hash) {
+            cachedFileData[projectName][f.file] = fromCache;
+        }
+        else {
+            if (!filesToProcess[projectName]) {
+                filesToProcess[projectName] = [];
+            }
+            filesToProcess[projectName].push(f);
+        }
+    }
+}
+function getNxJsonPluginsData(nxJson, packageJsonDeps) {
+    return (nxJson?.plugins || []).map((p) => {
+        const [plugin, options] = typeof p === 'string' ? [p] : [p.plugin, p.options];
+        return {
+            name: plugin,
+            version: packageJsonDeps[plugin],
+            options,
+        };
+    });
 }
 
-module.exports = (input, options) => {
-	if (getYesMatchScore(input) >= YES_MATCH_SCORE_THRESHOLD) {
-		return true;
-	}
 
-	if (getNoMatchScore(input) >= NO_MATCH_SCORE_THRESHOLD) {
-		return false;
-	}
+/***/ }),
 
-	return options.default;
-};
+/***/ 5959:
+/***/ ((__unused_webpack_module, exports) => {
+
+"use strict";
+
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.withDeps = exports.pruneExternalNodes = exports.isNpmProject = exports.filterNodes = exports.reverse = void 0;
+const reverseMemo = new Map();
+/**
+ * Returns a new project graph where all the edges are reversed.
+ *
+ * For instance, if project A depends on B, in the reversed graph
+ * B will depend on A.
+ */
+function reverse(graph) {
+    const resultFromMemo = reverseMemo.get(graph);
+    if (resultFromMemo) {
+        return resultFromMemo;
+    }
+    const result = {
+        ...graph,
+        nodes: { ...graph.nodes },
+        externalNodes: { ...graph.externalNodes },
+        dependencies: {},
+    };
+    Object.keys(graph.nodes).forEach((n) => (result.dependencies[n] = []));
+    // we need to keep external node's reverse dependencies to trace our route back
+    if (graph.externalNodes) {
+        Object.keys(graph.externalNodes).forEach((n) => (result.dependencies[n] = []));
+    }
+    Object.values(graph.dependencies).forEach((byProject) => {
+        byProject.forEach((dep) => {
+            const dependency = result.dependencies[dep.target];
+            if (dependency) {
+                dependency.push({
+                    type: dep.type,
+                    source: dep.target,
+                    target: dep.source,
+                });
+            }
+        });
+    });
+    reverseMemo.set(graph, result);
+    reverseMemo.set(result, graph);
+    return result;
+}
+exports.reverse = reverse;
+function filterNodes(predicate) {
+    return (original) => {
+        const graph = { nodes: {}, dependencies: {} };
+        const added = new Set();
+        Object.values(original.nodes).forEach((n) => {
+            if (!predicate || predicate(n)) {
+                graph.nodes[n.name] = n;
+                graph.dependencies[n.name] = [];
+                added.add(n.name);
+            }
+        });
+        Object.values(original.dependencies).forEach((ds) => {
+            ds.forEach((d) => {
+                if (added.has(d.source) && added.has(d.target)) {
+                    graph.dependencies[d.source].push(d);
+                }
+            });
+        });
+        return graph;
+    };
+}
+exports.filterNodes = filterNodes;
+function isNpmProject(project) {
+    return project?.type === 'npm';
+}
+exports.isNpmProject = isNpmProject;
+exports.pruneExternalNodes = filterNodes();
+function withDeps(original, subsetNodes) {
+    const res = { nodes: {}, dependencies: {} };
+    const visitedNodes = [];
+    const visitedEdges = [];
+    Object.values(subsetNodes).forEach(recurNodes);
+    Object.values(subsetNodes).forEach(recurEdges);
+    return res;
+    // ---------------------------------------------------------------------------
+    function recurNodes(node) {
+        if (visitedNodes.indexOf(node.name) > -1)
+            return;
+        res.nodes[node.name] = node;
+        if (!res.dependencies[node.name]) {
+            res.dependencies[node.name] = [];
+        }
+        visitedNodes.push(node.name);
+        original.dependencies[node.name].forEach((n) => {
+            if (original.nodes[n.target]) {
+                recurNodes(original.nodes[n.target]);
+            }
+        });
+    }
+    function recurEdges(node) {
+        if (visitedEdges.indexOf(node.name) > -1)
+            return;
+        visitedEdges.push(node.name);
+        const ds = original.dependencies[node.name];
+        ds.forEach((n) => {
+            if (!original.nodes[n.target]) {
+                return;
+            }
+            if (!res.dependencies[n.source]) {
+                res.dependencies[n.source] = [];
+            }
+            res.dependencies[n.source].push(n);
+        });
+        ds.forEach((n) => {
+            if (original.nodes[n.target]) {
+                recurEdges(original.nodes[n.target]);
+            }
+        });
+    }
+}
+exports.withDeps = withDeps;
 
 
 /***/ }),
 
-/***/ 74658:
+/***/ 80862:
 /***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
 "use strict";
 
 Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.argv = void 0;
-const tslib_1 = __nccwpck_require__(65315);
-const core = tslib_1.__importStar(__nccwpck_require__(57896));
-const tree_1 = __nccwpck_require__(75138);
-const project_configuration_1 = __nccwpck_require__(41172);
-const path_1 = __nccwpck_require__(71017);
-const helpers_1 = __nccwpck_require__(30329);
-const yargs_1 = tslib_1.__importDefault(__nccwpck_require__(68654));
-const build_command_1 = __nccwpck_require__(70384);
-const exec_1 = __nccwpck_require__(59902);
-const has_one_of_required_tags_1 = __nccwpck_require__(51922);
-const run_target_1 = __nccwpck_require__(81067);
-exports.argv = (0, yargs_1.default)((0, helpers_1.hideBin)(process.argv))
-    .options({
-    tag: { type: 'string' },
-    config: { type: 'string' },
-    target: { type: 'string' },
-    parallel: { type: 'number' },
-    verbose: { type: 'boolean' },
-    affectedOnly: { type: 'boolean' }
-})
-    .parseSync();
-function run() {
-    return tslib_1.__awaiter(this, void 0, void 0, function* () {
-        try {
-            const nxTree = new tree_1.FsTree(process.cwd(), false);
-            const projects = (0, project_configuration_1.getProjects)(nxTree);
-            // Get all options
-            const tagConditions = (exports.argv.tag ? [exports.argv.tag] : core.getMultilineInput('tag', { trimWhitespace: true }));
-            const target = core.getInput('target', { required: !exports.argv.target }) || exports.argv.target;
-            const affectedOnly = exports.argv.affectedOnly !== undefined ? exports.argv.affectedOnly : core.getBooleanInput('affectedOnly');
-            const config = core.getInput('config') || exports.argv.config;
-            const jobIndex = parseInt(core.getInput('index') || '1', 10);
-            const jobCount = parseInt(core.getInput('count') || '1', 10);
-            const parallel = (core.getInput('parallel') || exports.argv.parallel);
-            const workingDirectory = core.getInput('workingDirectory') || '';
-            const preTargets = core.getMultilineInput('preTargets', {
-                trimWhitespace: true
-            });
-            const postTargets = core.getMultilineInput('postTargets', {
-                trimWhitespace: true
-            });
-            core.debug(`Job index ${jobIndex}`);
-            core.debug(`Job count ${jobCount}`);
-            core.debug(`Pre targets ${JSON.stringify(preTargets, null, 2)}`);
-            core.debug(`Post targets ${JSON.stringify(postTargets, null, 2)}`);
-            if (tagConditions.length > 0) {
-                core.info(`Running all projects with one of the following tags "${tagConditions.join(', ')}"`);
-            }
-            const cwd = (0, path_1.resolve)(process.cwd(), workingDirectory);
-            const projectsNamesToRun = affectedOnly
-                ? JSON.parse((0, exec_1.execCommand)((0, build_command_1.buildCommand)([
-                    'npx nx show projects --affected --json',
-                    `-t ${target}`
-                ]), {
-                    asString: true,
-                    silent: !(core.isDebug() || exports.argv.verbose),
-                    cwd
-                }))
-                : Array.from(projects.keys());
-            // Make sure to still log the project names
-            if (!affectedOnly) {
-                core.debug(JSON.stringify(projectsNamesToRun));
+exports.validateDependency = exports.ProjectGraphBuilder = void 0;
+/**
+ * Builder for adding nodes and dependencies to a {@link ProjectGraph}
+ */
+const project_graph_1 = __nccwpck_require__(2184);
+const build_project_graph_1 = __nccwpck_require__(71553);
+/**
+ * A class which builds up a project graph
+ * @deprecated The {@link ProjectGraphProcessor} has been deprecated. Use a {@link CreateNodes} and/or a {@link CreateDependencies} instead. This will be removed in Nx 19.
+ */
+class ProjectGraphBuilder {
+    constructor(graph, projectFileMap, nonProjectFiles) {
+        this.removedEdges = {};
+        if (!projectFileMap || !nonProjectFiles) {
+            const fileMap = (0, build_project_graph_1.getFileMap)().fileMap;
+            projectFileMap ??= fileMap.projectFileMap;
+            nonProjectFiles ??= fileMap.nonProjectFiles;
+        }
+        if (graph) {
+            this.graph = graph;
+            this.projectFileMap = projectFileMap;
+            this.nonProjectFiles = nonProjectFiles;
+        }
+        else {
+            this.graph = {
+                nodes: {},
+                externalNodes: {},
+                dependencies: {},
+            };
+            this.projectFileMap = projectFileMap || {};
+            this.nonProjectFiles = nonProjectFiles || [];
+        }
+    }
+    /**
+     * Merges the nodes and dependencies of p into the built project graph.
+     */
+    mergeProjectGraph(p) {
+        this.graph.nodes = { ...this.graph.nodes, ...p.nodes };
+        this.graph.externalNodes = {
+            ...this.graph.externalNodes,
+            ...p.externalNodes,
+        };
+        this.graph.dependencies = { ...this.graph.dependencies, ...p.dependencies };
+    }
+    /**
+     * Adds a project node to the project graph
+     */
+    addNode(node) {
+        // Check if project with the same name already exists
+        if (this.graph.nodes[node.name]) {
+            // Throw if existing project is of a different type
+            if (this.graph.nodes[node.name].type !== node.type) {
+                throw new Error(`Multiple projects are named "${node.name}". One is of type "${node.type}" and the other is of type "${this.graph.nodes[node.name].type}". Please resolve the conflicting project names.`);
             }
-            // Get all affected projects
-            const projectsToRun = projectsNamesToRun.filter((projectName) => {
-                if (!projects.has(projectName)) {
-                    return false;
+        }
+        this.graph.nodes[node.name] = node;
+    }
+    /**
+     * Removes a node and all of its dependency edges from the graph
+     */
+    removeNode(name) {
+        if (!this.graph.nodes[name] && !this.graph.externalNodes[name]) {
+            throw new Error(`There is no node named: "${name}"`);
+        }
+        this.removeDependenciesWithNode(name);
+        if (this.graph.nodes[name]) {
+            delete this.graph.nodes[name];
+        }
+        else {
+            delete this.graph.externalNodes[name];
+        }
+    }
+    /**
+     * Adds a external node to the project graph
+     */
+    addExternalNode(node) {
+        // Check if project with the same name already exists
+        if (this.graph.externalNodes[node.name]) {
+            throw new Error(`Multiple projects are named "${node.name}". One has version "${node.data.version}" and the other has version "${this.graph.externalNodes[node.name].data.version}". Please resolve the conflicting package names.`);
+        }
+        this.graph.externalNodes[node.name] = node;
+    }
+    /**
+     * Adds static dependency from source project to target project
+     */
+    addStaticDependency(sourceProjectName, targetProjectName, sourceProjectFile) {
+        this.addDependency(sourceProjectName, targetProjectName, project_graph_1.DependencyType.static, sourceProjectFile);
+    }
+    /**
+     * Adds dynamic dependency from source project to target project
+     */
+    addDynamicDependency(sourceProjectName, targetProjectName, sourceProjectFile) {
+        this.addDependency(sourceProjectName, targetProjectName, project_graph_1.DependencyType.dynamic, sourceProjectFile);
+    }
+    /**
+     * Adds implicit dependency from source project to target project
+     */
+    addImplicitDependency(sourceProjectName, targetProjectName) {
+        this.addDependency(sourceProjectName, targetProjectName, project_graph_1.DependencyType.implicit);
+    }
+    /**
+     * Removes a dependency from source project to target project
+     */
+    removeDependency(sourceProjectName, targetProjectName) {
+        if (sourceProjectName === targetProjectName) {
+            return;
+        }
+        if (!this.graph.nodes[sourceProjectName]) {
+            throw new Error(`Source project does not exist: ${sourceProjectName}`);
+        }
+        if (!this.graph.nodes[targetProjectName] &&
+            !this.graph.externalNodes[targetProjectName]) {
+            throw new Error(`Target project does not exist: ${targetProjectName}`);
+        }
+        // this.graph.dependencies[sourceProjectName] = this.graph.dependencies[
+        //   sourceProjectName
+        // ].filter((d) => d.target !== targetProjectName);
+        if (!this.removedEdges[sourceProjectName]) {
+            this.removedEdges[sourceProjectName] = new Set();
+        }
+        this.removedEdges[sourceProjectName].add(targetProjectName);
+    }
+    /**
+     * Add an explicit dependency from a file in source project to target project
+     * @deprecated this method will be removed in v17. Use {@link addStaticDependency} or {@link addDynamicDependency} instead
+     */
+    addExplicitDependency(sourceProjectName, sourceProjectFile, targetProjectName) {
+        this.addStaticDependency(sourceProjectName, targetProjectName, sourceProjectFile);
+    }
+    /**
+     * Set version of the project graph
+     */
+    setVersion(version) {
+        this.graph.version = version;
+    }
+    getUpdatedProjectGraph() {
+        for (const sourceProject of Object.keys(this.graph.nodes)) {
+            const alreadySetTargetProjects = this.calculateAlreadySetTargetDeps(sourceProject);
+            this.graph.dependencies[sourceProject] = [
+                ...alreadySetTargetProjects.values(),
+            ].flatMap((depsMap) => [...depsMap.values()]);
+            const fileDeps = this.calculateTargetDepsFromFiles(sourceProject);
+            for (const [targetProject, types] of fileDeps.entries()) {
+                // only add known nodes
+                if (!this.graph.nodes[targetProject] &&
+                    !this.graph.externalNodes[targetProject]) {
+                    continue;
                 }
-                const project = projects.get(projectName);
-                const tags = project.tags || [];
-                // If the project has ci=off then don't run it
-                if (tags.includes('ci=off')) {
-                    core.debug(`[${projectName}]: Has the "ci=off" tag, skipping it.`);
-                    return false;
+                for (const type of types.values()) {
+                    if (!alreadySetTargetProjects.has(targetProject) ||
+                        !alreadySetTargetProjects.get(targetProject).has(type)) {
+                        if (!this.removedEdges[sourceProject] ||
+                            !this.removedEdges[sourceProject].has(targetProject)) {
+                            this.graph.dependencies[sourceProject].push({
+                                source: sourceProject,
+                                target: targetProject,
+                                type,
+                            });
+                        }
+                    }
                 }
-                if (!tagConditions || tagConditions.length === 0) {
-                    return true;
+            }
+        }
+        for (const file of this.nonProjectFiles) {
+            if (file.deps) {
+                for (const dep of file.deps) {
+                    if (!Array.isArray(dep)) {
+                        throw new Error('Cached data on non project files should be a tuple');
+                    }
+                    const [source, target, type] = dep;
+                    if (!source || !target || !type) {
+                        throw new Error('Cached dependencies for non project files should be a tuple of length 3.');
+                    }
+                    this.graph.dependencies[source].push({
+                        source,
+                        target,
+                        type,
+                    });
                 }
-                // If a tag is provided the project should have it
-                return (!tagConditions || tagConditions.length === 0) || (0, has_one_of_required_tags_1.hasOneOfRequiredTags)(projectName, tags, tagConditions);
-            }).sort((projectNameA, projectNameB) => (projectNameA.localeCompare(projectNameB)));
-            const sliceSize = Math.max(Math.floor(projectsToRun.length / jobCount), 1);
-            const runProjects = jobIndex < jobCount
-                ? projectsToRun.slice(sliceSize * (jobIndex - 1), sliceSize * jobIndex)
-                : projectsToRun.slice(sliceSize * (jobIndex - 1));
-            if (preTargets.length > 0) {
-                for (const targetParts of preTargets) {
-                    core.info(`Running preTarget "${targetParts}"`);
-                    const [target, targetConfig] = targetParts.split(':');
-                    yield (0, run_target_1.runTarget)(cwd, projects, runProjects, target, targetConfig, parallel);
+            }
+        }
+        return this.graph;
+    }
+    addDependency(source, target, type, sourceFile) {
+        if (source === target) {
+            return;
+        }
+        validateDependency({
+            source,
+            target,
+            type,
+            sourceFile,
+        }, {
+            externalNodes: this.graph.externalNodes,
+            fileMap: {
+                projectFileMap: this.projectFileMap,
+                nonProjectFiles: this.nonProjectFiles,
+            },
+            // the validators only really care about the keys on this.
+            projects: this.graph.nodes,
+            filesToProcess: null,
+            nxJsonConfiguration: null,
+            workspaceRoot: null,
+        });
+        if (!this.graph.dependencies[source]) {
+            this.graph.dependencies[source] = [];
+        }
+        const isDuplicate = !!this.graph.dependencies[source].find((d) => d.target === target && d.type === type);
+        if (sourceFile) {
+            let fileData = getProjectFileData(source, sourceFile, this.projectFileMap);
+            const isProjectFileData = !!fileData;
+            fileData ??= getNonProjectFileData(sourceFile, this.nonProjectFiles);
+            if (!fileData.deps) {
+                fileData.deps = [];
+            }
+            if (!fileData.deps.find((t) => (0, project_graph_1.fileDataDepTarget)(t) === target && (0, project_graph_1.fileDataDepType)(t) === type)) {
+                const dep = isProjectFileData
+                    ? type === 'static'
+                        ? target
+                        : [target, type]
+                    : [source, target, type];
+                fileData.deps.push(dep);
+            }
+        }
+        else if (!isDuplicate) {
+            // only add to dependencies section if the source file is not specified
+            // and not already added
+            this.graph.dependencies[source].push({
+                source: source,
+                target: target,
+                type,
+            });
+        }
+    }
+    removeDependenciesWithNode(name) {
+        // remove all source dependencies
+        delete this.graph.dependencies[name];
+        // remove all target dependencies
+        for (const dependencies of Object.values(this.graph.dependencies)) {
+            for (const [index, { source, target }] of dependencies.entries()) {
+                if (target === name) {
+                    const deps = this.graph.dependencies[source];
+                    this.graph.dependencies[source] = [
+                        ...deps.slice(0, index),
+                        ...deps.slice(index + 1),
+                    ];
+                    if (this.graph.dependencies[source].length === 0) {
+                        delete this.graph.dependencies[source];
+                    }
                 }
             }
-            yield (0, run_target_1.runTarget)(cwd, projects, runProjects, target, config, parallel, !exports.argv.target);
-            if (postTargets.length > 0) {
-                for (const targetParts of postTargets) {
-                    core.info(`Running postTarget "${targetParts}"`);
-                    const [target, targetConfig] = targetParts.split(':');
-                    yield (0, run_target_1.runTarget)(cwd, projects, runProjects, target, targetConfig, parallel);
+        }
+    }
+    calculateTargetDepsFromFiles(sourceProject) {
+        const fileDeps = new Map();
+        const files = this.projectFileMap[sourceProject] || [];
+        if (!files) {
+            return fileDeps;
+        }
+        for (let f of files) {
+            if (f.deps) {
+                for (let d of f.deps) {
+                    const target = (0, project_graph_1.fileDataDepTarget)(d);
+                    if (!fileDeps.has(target)) {
+                        fileDeps.set(target, new Set([(0, project_graph_1.fileDataDepType)(d)]));
+                    }
+                    else {
+                        fileDeps.get(target).add((0, project_graph_1.fileDataDepType)(d));
+                    }
                 }
             }
         }
-        catch (err) {
-            core.setFailed(err);
+        return fileDeps;
+    }
+    calculateAlreadySetTargetDeps(sourceProject) {
+        const alreadySetTargetProjects = new Map();
+        if (this.graph.dependencies[sourceProject]) {
+            const removed = this.removedEdges[sourceProject];
+            for (const d of this.graph.dependencies[sourceProject]) {
+                // static and dynamic dependencies of internal projects
+                // will be rebuilt based on the file dependencies
+                // we only need to keep the implicit dependencies
+                if (d.type === project_graph_1.DependencyType.implicit && !removed?.has(d.target)) {
+                    if (!alreadySetTargetProjects.has(d.target)) {
+                        alreadySetTargetProjects.set(d.target, new Map([[d.type, d]]));
+                    }
+                    else {
+                        alreadySetTargetProjects.get(d.target).set(d.type, d);
+                    }
+                }
+            }
         }
-    });
+        return alreadySetTargetProjects;
+    }
+}
+exports.ProjectGraphBuilder = ProjectGraphBuilder;
+/**
+ * A function to validate dependencies in a {@link CreateDependencies} function
+ * @throws If the dependency is invalid.
+ */
+function validateDependency(dependency, ctx) {
+    if (dependency.type === project_graph_1.DependencyType.implicit) {
+        validateImplicitDependency(dependency, ctx);
+    }
+    else if (dependency.type === project_graph_1.DependencyType.dynamic) {
+        validateDynamicDependency(dependency, ctx);
+    }
+    else if (dependency.type === project_graph_1.DependencyType.static) {
+        validateStaticDependency(dependency, ctx);
+    }
+    validateCommonDependencyRules(dependency, ctx);
+}
+exports.validateDependency = validateDependency;
+function validateCommonDependencyRules(d, { externalNodes, projects, fileMap }) {
+    if (!projects[d.source] && !externalNodes[d.source]) {
+        throw new Error(`Source project does not exist: ${d.source}`);
+    }
+    if (!projects[d.target] &&
+        !externalNodes[d.target] &&
+        !('sourceFile' in d && d.sourceFile)) {
+        throw new Error(`Target project does not exist: ${d.target}`);
+    }
+    if (externalNodes[d.source] && projects[d.target]) {
+        throw new Error(`External projects can't depend on internal projects`);
+    }
+    if ('sourceFile' in d && d.sourceFile) {
+        if (projects[d.source]) {
+            // Throws if source file is not a valid file within the source project.
+            // We can pass empty array for all workspace files here, since its not checked by the impl.
+            // We need all workspace files in here for the TODO comment though, so lets figure that out.
+            getFileData(d.source, d.sourceFile, projects, externalNodes, fileMap.projectFileMap, fileMap.nonProjectFiles);
+        }
+    }
+}
+function validateImplicitDependency(d, { externalNodes }) {
+    if (externalNodes[d.source]) {
+        throw new Error(`External projects can't have "implicit" dependencies`);
+    }
+}
+function validateDynamicDependency(d, { externalNodes }) {
+    if (externalNodes[d.source]) {
+        throw new Error(`External projects can't have "dynamic" dependencies`);
+    }
+    // dynamic dependency is always bound to a file
+    if (!d.sourceFile) {
+        throw new Error(`Source project file is required for "dynamic" dependencies`);
+    }
+}
+function validateStaticDependency(d, { projects }) {
+    // internal nodes must provide sourceProjectFile when creating static dependency
+    // externalNodes do not have sourceProjectFile
+    if (projects[d.source] && !d.sourceFile) {
+        throw new Error(`Source project file is required`);
+    }
+}
+function getProjectFileData(source, sourceFile, fileMap) {
+    let fileData = (fileMap[source] || []).find((f) => f.file === sourceFile);
+    if (fileData) {
+        return fileData;
+    }
+}
+function getNonProjectFileData(sourceFile, files) {
+    const fileData = files.find((f) => f.file === sourceFile);
+    if (!fileData) {
+        throw new Error(`Source file "${sourceFile}" does not exist in the workspace.`);
+    }
+    return fileData;
+}
+function getFileData(source, sourceFile, projects, externalNodes, fileMap, nonProjectFiles) {
+    const sourceProject = projects[source];
+    const matchingExternalNode = externalNodes[source];
+    if (!sourceProject && !matchingExternalNode) {
+        throw new Error(`Source project is not a project node: ${sourceProject}`);
+    }
+    return (getProjectFileData(source, sourceFile, fileMap) ??
+        getNonProjectFileData(sourceFile, nonProjectFiles));
 }
-run();
 
 
 /***/ }),
 
-/***/ 70384:
-/***/ ((__unused_webpack_module, exports) => {
+/***/ 61371:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
 "use strict";
 
 Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.buildCommand = void 0;
-const buildCommand = (parts) => {
-    return parts.filter(Boolean).join(' ');
-};
-exports.buildCommand = buildCommand;
-
-
-/***/ }),
+exports.createProjectGraphAndSourceMapsAsync = exports.createProjectGraphAsync = exports.buildProjectGraphAndSourceMapsWithoutDaemon = exports.readProjectsConfigurationFromProjectGraph = exports.readCachedProjectConfiguration = exports.readCachedProjectGraph = void 0;
+const nx_deps_cache_1 = __nccwpck_require__(57074);
+const build_project_graph_1 = __nccwpck_require__(71553);
+const output_1 = __nccwpck_require__(1737);
+const tmp_dir_1 = __nccwpck_require__(78543);
+const strip_indents_1 = __nccwpck_require__(98487);
+const client_1 = __nccwpck_require__(36638);
+const fileutils_1 = __nccwpck_require__(83851);
+const workspace_root_1 = __nccwpck_require__(86708);
+const perf_hooks_1 = __nccwpck_require__(4074);
+const retrieve_workspace_files_1 = __nccwpck_require__(14249);
+const nx_json_1 = __nccwpck_require__(53619);
+const nx_plugin_1 = __nccwpck_require__(84141);
+/**
+ * Synchronously reads the latest cached copy of the workspace's ProjectGraph.
+ * @throws {Error} if there is no cached ProjectGraph to read from
+ */
+function readCachedProjectGraph() {
+    const projectGraphCache = (0, nx_deps_cache_1.readProjectGraphCache)();
+    if (!projectGraphCache) {
+        const angularSpecificError = (0, fileutils_1.fileExists)(`${workspace_root_1.workspaceRoot}/angular.json`)
+            ? (0, strip_indents_1.stripIndents) `
+      Make sure invoke 'node ./decorate-angular-cli.js' in your postinstall script.
+      The decorated CLI will compute the project graph.
+      'ng --help' should say 'Smart Monorepos · Fast CI'.
+      `
+            : '';
+        throw new Error((0, strip_indents_1.stripIndents) `
+      [readCachedProjectGraph] ERROR: No cached ProjectGraph is available.
 
-/***/ 59902:
-/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
+      If you are leveraging \`readCachedProjectGraph()\` directly then you will need to refactor your usage to first ensure that
+      the ProjectGraph is created by calling \`await createProjectGraphAsync()\` somewhere before attempting to read the data.
 
-"use strict";
+      If you encounter this error as part of running standard \`nx\` commands then please open an issue on https://github.com/nrwl/nx
 
-Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.execCommand = exports.ChildProcess = void 0;
-const tslib_1 = __nccwpck_require__(65315);
-const child_process_1 = __nccwpck_require__(32081);
-Object.defineProperty(exports, "ChildProcess", ({ enumerable: true, get: function () { return child_process_1.ChildProcess; } }));
-const shell = tslib_1.__importStar(__nccwpck_require__(54572));
-const execCommand = (command, options = {
-    asString: false,
-    asJSON: false
-}) => {
-    if (!options.silent) {
-        console.log('\nRunning: ', command);
+      ${angularSpecificError}
+    `);
     }
-    const result = shell.exec(command, options);
-    if (options.asJSON) {
-        return JSON.parse(result.toString());
+    return projectGraphCache;
+}
+exports.readCachedProjectGraph = readCachedProjectGraph;
+function readCachedProjectConfiguration(projectName) {
+    const graph = readCachedProjectGraph();
+    const node = graph.nodes[projectName];
+    try {
+        return node.data;
     }
-    if (options.asString) {
-        // eslint-disable-next-line @typescript-eslint/ban-ts-comment
-        // @ts-ignore
-        return result.toString();
+    catch (e) {
+        throw new Error(`Cannot find project: '${projectName}' in your workspace.`);
     }
-    // eslint-disable-next-line @typescript-eslint/ban-ts-comment
-    // @ts-ignore
+}
+exports.readCachedProjectConfiguration = readCachedProjectConfiguration;
+/**
+ * Get the {@link ProjectsConfigurations} from the {@link ProjectGraph}
+ */
+function readProjectsConfigurationFromProjectGraph(projectGraph) {
     return {
-        success: result['code'] === 0,
-        output: result.stdout
+        projects: Object.fromEntries(Object.entries(projectGraph.nodes).map(([project, { data }]) => [
+            project,
+            data,
+        ])),
+        version: 2,
     };
-};
-exports.execCommand = execCommand;
+}
+exports.readProjectsConfigurationFromProjectGraph = readProjectsConfigurationFromProjectGraph;
+async function buildProjectGraphAndSourceMapsWithoutDaemon() {
+    const nxJson = (0, nx_json_1.readNxJson)();
+    perf_hooks_1.performance.mark('retrieve-project-configurations:start');
+    const { projects, externalNodes, sourceMaps, projectRootMap } = await (0, retrieve_workspace_files_1.retrieveProjectConfigurations)(workspace_root_1.workspaceRoot, nxJson);
+    perf_hooks_1.performance.mark('retrieve-project-configurations:end');
+    perf_hooks_1.performance.mark('retrieve-workspace-files:start');
+    const { allWorkspaceFiles, fileMap, rustReferences } = await (0, retrieve_workspace_files_1.retrieveWorkspaceFiles)(workspace_root_1.workspaceRoot, projectRootMap);
+    perf_hooks_1.performance.mark('retrieve-workspace-files:end');
+    const cacheEnabled = process.env.NX_CACHE_PROJECT_GRAPH !== 'false';
+    perf_hooks_1.performance.mark('build-project-graph-using-project-file-map:start');
+    const projectGraph = (await (0, build_project_graph_1.buildProjectGraphUsingProjectFileMap)(projects, externalNodes, fileMap, allWorkspaceFiles, rustReferences, cacheEnabled ? (0, nx_deps_cache_1.readFileMapCache)() : null, cacheEnabled)).projectGraph;
+    perf_hooks_1.performance.mark('build-project-graph-using-project-file-map:end');
+    (0, nx_plugin_1.unregisterPluginTSTranspiler)();
+    return { projectGraph, sourceMaps };
+}
+exports.buildProjectGraphAndSourceMapsWithoutDaemon = buildProjectGraphAndSourceMapsWithoutDaemon;
+function handleProjectGraphError(opts, e) {
+    if (opts.exitOnError) {
+        const lines = e.message.split('\n');
+        output_1.output.error({
+            title: lines[0],
+            bodyLines: lines.slice(1),
+        });
+        if (process.env.NX_VERBOSE_LOGGING === 'true') {
+            console.error(e);
+        }
+        process.exit(1);
+    }
+    else {
+        throw e;
+    }
+}
+/**
+ * Computes and returns a ProjectGraph.
+ *
+ * Nx will compute the graph either in a daemon process or in the current process.
+ *
+ * Nx will compute it in the current process if:
+ * * The process is running in CI (CI env variable is to true or other common variables used by CI providers are set).
+ * * It is running in the docker container.
+ * * The daemon process is disabled because of the previous error when starting the daemon.
+ * * `NX_DAEMON` is set to `false`.
+ * * `useDaemonProcess` is set to false in the options of the tasks runner inside `nx.json`
+ *
+ * `NX_DAEMON` env variable takes precedence:
+ * * If it is set to true, the daemon will always be used.
+ * * If it is set to false, the graph will always be computed in the current process.
+ *
+ * Tip: If you want to debug project graph creation, run your command with NX_DAEMON=false.
+ *
+ * Nx uses two layers of caching: the information about explicit dependencies stored on the disk and the information
+ * stored in the daemon process. To reset both run: `nx reset`.
+ */
+async function createProjectGraphAsync(opts = {
+    exitOnError: false,
+    resetDaemonClient: false,
+}) {
+    const projectGraphAndSourceMaps = await createProjectGraphAndSourceMapsAsync(opts);
+    return projectGraphAndSourceMaps.projectGraph;
+}
+exports.createProjectGraphAsync = createProjectGraphAsync;
+async function createProjectGraphAndSourceMapsAsync(opts = {
+    exitOnError: false,
+    resetDaemonClient: false,
+}) {
+    perf_hooks_1.performance.mark('create-project-graph-async:start');
+    if (!client_1.daemonClient.enabled()) {
+        try {
+            const res = await buildProjectGraphAndSourceMapsWithoutDaemon();
+            perf_hooks_1.performance.measure('create-project-graph-async >> retrieve-project-configurations', 'retrieve-project-configurations:start', 'retrieve-project-configurations:end');
+            perf_hooks_1.performance.measure('create-project-graph-async >> retrieve-workspace-files', 'retrieve-workspace-files:start', 'retrieve-workspace-files:end');
+            perf_hooks_1.performance.measure('create-project-graph-async >> build-project-graph-using-project-file-map', 'build-project-graph-using-project-file-map:start', 'build-project-graph-using-project-file-map:end');
+            perf_hooks_1.performance.mark('create-project-graph-async:end');
+            perf_hooks_1.performance.measure('create-project-graph-async', 'create-project-graph-async:start', 'create-project-graph-async:end');
+            return res;
+        }
+        catch (e) {
+            handleProjectGraphError(opts, e);
+        }
+    }
+    else {
+        try {
+            const projectGraphAndSourceMaps = await client_1.daemonClient.getProjectGraphAndSourceMaps();
+            if (opts.resetDaemonClient) {
+                client_1.daemonClient.reset();
+            }
+            perf_hooks_1.performance.mark('create-project-graph-async:end');
+            perf_hooks_1.performance.measure('create-project-graph-async', 'create-project-graph-async:start', 'create-project-graph-async:end');
+            return projectGraphAndSourceMaps;
+        }
+        catch (e) {
+            if (e.message.indexOf('inotify_add_watch') > -1) {
+                // common errors with the daemon due to OS settings (cannot watch all the files available)
+                output_1.output.note({
+                    title: `Unable to start Nx Daemon due to the limited amount of inotify watches, continuing without the daemon.`,
+                    bodyLines: [
+                        'For more information read: https://askubuntu.com/questions/1088272/inotify-add-watch-failed-no-space-left-on-device',
+                        'Nx Daemon is going to be disabled until you run "nx reset".',
+                    ],
+                });
+                (0, tmp_dir_1.markDaemonAsDisabled)();
+                return buildProjectGraphAndSourceMapsWithoutDaemon();
+            }
+            if (e.internalDaemonError) {
+                const errorLogFile = (0, tmp_dir_1.writeDaemonLogs)(e.message);
+                output_1.output.warn({
+                    title: `Nx Daemon was not able to compute the project graph.`,
+                    bodyLines: [
+                        `Log file with the error: ${errorLogFile}`,
+                        `Please file an issue at https://github.com/nrwl/nx`,
+                        'Nx Daemon is going to be disabled until you run "nx reset".',
+                    ],
+                });
+                (0, tmp_dir_1.markDaemonAsDisabled)();
+                return buildProjectGraphAndSourceMapsWithoutDaemon();
+            }
+            handleProjectGraphError(opts, e);
+        }
+    }
+}
+exports.createProjectGraphAndSourceMapsAsync = createProjectGraphAndSourceMapsAsync;
 
 
 /***/ }),
 
-/***/ 38971:
+/***/ 71074:
 /***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
 "use strict";
 
 Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.generateSummary = void 0;
-const tslib_1 = __nccwpck_require__(65315);
-const core = tslib_1.__importStar(__nccwpck_require__(57896));
-function generateSummary(target, runProjects, output) {
-    return tslib_1.__awaiter(this, void 0, void 0, function* () {
-        const failedProjects = output.split('\n')
-            .filter((line) => line.trim().length > 1)
-            .reduce((projects, line) => {
-            if (projects === undefined && line.includes('Failed tasks')) {
-                return [];
-            }
-            else if (projects !== undefined && line.trim().startsWith('-')) {
-                return projects.concat(line.replace('-', '').split(':').shift().trim());
-            }
-            return projects;
-        }, undefined) || []
-            .map((project) => ({
-            name: project,
-            target,
-            failed: failedProjects.includes(project)
-        }));
-        const summary = core.summary
-            .addHeading(`nx affected:${target}`, 2)
-            .addTable([
-            [{ data: 'Project', header: true }, { data: 'Result', header: true }],
-            ...runProjects.reduce((table, project) => {
-                table.push([
-                    project,
-                    failedProjects.includes(project) ? ':x:' : ':white_check_mark:\t'
-                ]);
-                return table;
-            }, [])
-        ]);
-        // TODO:: Add links to the cloud run / functions / firebase hosting / vercel urls
-        // summary.addLink('View staging deployment!', 'https://github.com')
-        yield summary.write();
-    });
+exports.buildAllWorkspaceFiles = void 0;
+const perf_hooks_1 = __nccwpck_require__(4074);
+function buildAllWorkspaceFiles(projectFileMap, globalFiles) {
+    perf_hooks_1.performance.mark('get-all-workspace-files:start');
+    let fileData = Object.values(projectFileMap).flat();
+    fileData = fileData
+        .concat(globalFiles)
+        .sort((a, b) => a.file.localeCompare(b.file));
+    perf_hooks_1.performance.mark('get-all-workspace-files:end');
+    perf_hooks_1.performance.measure('get-all-workspace-files', 'get-all-workspace-files:start', 'get-all-workspace-files:end');
+    return fileData;
 }
-exports.generateSummary = generateSummary;
+exports.buildAllWorkspaceFiles = buildAllWorkspaceFiles;
 
 
 /***/ }),
 
-/***/ 97904:
-/***/ ((__unused_webpack_module, exports) => {
+/***/ 46329:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
 "use strict";
 
 Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.getProjectsWithTarget = void 0;
-function getProjectsWithTarget(projects, runProjects, target) {
-    // Filter out all projects that are not allowed
-    return Array.from(projects).filter(([project, config]) => {
-        var _a;
-        // Check if the project has the provided target
-        return Object.keys((_a = config === null || config === void 0 ? void 0 : config.targets) !== null && _a !== void 0 ? _a : {}).includes(target)
-            && runProjects.includes(project);
-    }).map(([project]) => project);
+exports.normalizeProjectRoot = exports.findProjectForPath = exports.createProjectRootMappings = exports.createProjectRootMappingsFromProjectConfigurations = void 0;
+const path_1 = __nccwpck_require__(71017);
+const path_2 = __nccwpck_require__(38270);
+/**
+ * This creates a map of project roots to project names to easily look up the project of a file
+ * @param projects This is the map of project configurations commonly found in "workspace.json"
+ */
+function createProjectRootMappingsFromProjectConfigurations(projects) {
+    const projectRootMappings = new Map();
+    for (const projectName of Object.keys(projects)) {
+        const root = projects[projectName].root;
+        projectRootMappings.set(normalizeProjectRoot(root), projectName);
+    }
+    return projectRootMappings;
 }
-exports.getProjectsWithTarget = getProjectsWithTarget;
+exports.createProjectRootMappingsFromProjectConfigurations = createProjectRootMappingsFromProjectConfigurations;
+/**
+ * This creates a map of project roots to project names to easily look up the project of a file
+ * @param nodes This is the nodes from the project graph
+ */
+function createProjectRootMappings(nodes) {
+    const projectRootMappings = new Map();
+    for (const projectName of Object.keys(nodes)) {
+        let root = nodes[projectName].data.root;
+        projectRootMappings.set(normalizeProjectRoot(root), projectName);
+    }
+    return projectRootMappings;
+}
+exports.createProjectRootMappings = createProjectRootMappings;
+/**
+ * Locates a project in projectRootMap based on a file within it
+ * @param filePath path that is inside of projectName. This should be relative from the workspace root
+ * @param projectRootMap Map Use {@link createProjectRootMappings} to create this
+ */
+function findProjectForPath(filePath, projectRootMap) {
+    /**
+     * Project Mappings are in UNIX-style file paths
+     * Windows may pass Win-style file paths
+     * Ensure filePath is in UNIX-style
+     */
+    let currentPath = (0, path_2.normalizePath)(filePath);
+    for (; currentPath != (0, path_1.dirname)(currentPath); currentPath = (0, path_1.dirname)(currentPath)) {
+        const p = projectRootMap.get(currentPath);
+        if (p) {
+            return p;
+        }
+    }
+    return projectRootMap.get(currentPath);
+}
+exports.findProjectForPath = findProjectForPath;
+function normalizeProjectRoot(root) {
+    root = root === '' ? '.' : root;
+    return root && root.endsWith('/') ? root.substring(0, root.length - 1) : root;
+}
+exports.normalizeProjectRoot = normalizeProjectRoot;
 
 
 /***/ }),
 
-/***/ 70069:
+/***/ 85251:
 /***/ ((__unused_webpack_module, exports) => {
 
 "use strict";
 
 Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.getRestArgs = void 0;
-function getRestArgs() {
-    return process.argv
-        .slice(2)
-        .filter((arg) => (!arg.includes('--tag')
-        && !arg.includes('--target')
-        && !arg.includes('--parallel')
-        && !arg.includes('--config')))
-        .map((a) => `"${a}"`)
-        .join(' ');
+exports.applyImplicitDependencies = void 0;
+function applyImplicitDependencies(projects, builder) {
+    Object.keys(projects).forEach((source) => {
+        const p = projects[source];
+        if (p.implicitDependencies && p.implicitDependencies.length > 0) {
+            p.implicitDependencies.forEach((target) => {
+                if (target.startsWith('!')) {
+                    builder.removeDependency(source, target.slice(1));
+                }
+                else {
+                    builder.addImplicitDependency(source, target);
+                }
+            });
+        }
+    });
 }
-exports.getRestArgs = getRestArgs;
+exports.applyImplicitDependencies = applyImplicitDependencies;
 
 
 /***/ }),
 
-/***/ 51922:
+/***/ 44852:
 /***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
 "use strict";
 
 Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.hasOneOfRequiredTags = void 0;
-const tslib_1 = __nccwpck_require__(65315);
-const core = tslib_1.__importStar(__nccwpck_require__(57896));
-function hasTagMatchingCondition(condition, tags) {
-    if (condition.includes('=')) {
-        // If it includes a "," it's a AND condition
-        if (condition.includes(',')) {
-            const subConditions = condition.split(',').map((subCondition) => subCondition.trim());
-            // It should match all the conditions
-            return subConditions.every((subCondition) => {
-                return hasTagMatchingCondition(subCondition, tags);
-            });
-        }
-        if (condition.includes('!=')) {
-            const [conditionKey, conditionValue] = condition.split('!=');
-            const useTags = tags.filter((tag) => tag.startsWith(`${conditionKey}=`));
-            // If the project does not have any tags with the condition key it's allowed
-            if (useTags.length === 0) {
-                return true;
-            }
-            return useTags.some((tag) => {
-                return tag.split('=').pop().trim() !== conditionValue.trim();
-            }, []);
-        }
-        else {
-            const [conditionKey, conditionValue] = condition.split('=');
-            return tags.some((tag) => {
-                const [key, value] = tag.split('=');
-                if (conditionKey !== key) {
-                    return false;
-                }
-                return conditionValue.trim() === value.trim();
-            });
-        }
-    }
-    else {
-        return tags.some((tag) => tag === condition);
+exports.normalizeImplicitDependencies = exports.normalizeProjectTargets = exports.normalizeProjectNodes = void 0;
+const find_matching_projects_1 = __nccwpck_require__(21521);
+const project_configuration_utils_1 = __nccwpck_require__(33190);
+async function normalizeProjectNodes(ctx, builder) {
+    const toAdd = [];
+    // Sorting projects by name to make sure that the order of projects in the graph is deterministic.
+    // This is important to ensure that expanded properties referencing projects (e.g. implicit dependencies)
+    // are also deterministic, and thus don't cause the calculated project configuration hash to shift.
+    const projects = Object.keys(ctx.projects).sort();
+    // Used for expanding implicit dependencies (e.g. `@proj/*` or `tag:foo`)
+    const partialProjectGraphNodes = projects.reduce((graph, project) => {
+        const projectConfiguration = ctx.projects[project];
+        graph[project] = {
+            name: project,
+            type: projectConfiguration.projectType === 'library' ? 'lib' : 'app', // missing fallback to `e2e`
+            data: {
+                ...projectConfiguration,
+            },
+        };
+        return graph;
+    }, {});
+    for (const key of projects) {
+        const p = ctx.projects[key];
+        p.implicitDependencies = normalizeImplicitDependencies(key, p.implicitDependencies, partialProjectGraphNodes);
+        p.targets = normalizeProjectTargets(p, key);
+        // TODO: remove in v16
+        const projectType = p.projectType === 'application'
+            ? key.endsWith('-e2e') || key === 'e2e'
+                ? 'e2e'
+                : 'app'
+            : 'lib';
+        const tags = ctx.projects?.[key]?.tags || [];
+        toAdd.push({
+            name: key,
+            type: projectType,
+            data: {
+                ...p,
+                tags,
+            },
+        });
     }
+    // Sort by root directory length (do we need this?)
+    toAdd.sort((a, b) => {
+        if (!a.data.root)
+            return -1;
+        if (!b.data.root)
+            return -1;
+        return a.data.root.length > b.data.root.length ? -1 : 1;
+    });
+    toAdd.forEach((n) => {
+        builder.addNode({
+            name: n.name,
+            type: n.type,
+            data: n.data,
+        });
+    });
 }
-function cleanLogConditions(conditions) {
-    return conditions.map((condition) => {
-        if (condition.includes(',')) {
-            return condition.split(',').map((subCondition) => subCondition.trim())
-                .join(' AND ');
+exports.normalizeProjectNodes = normalizeProjectNodes;
+/**
+ * Apply target defaults and normalization
+ */
+function normalizeProjectTargets(project, projectName) {
+    // Any node on the graph will have a targets object, it just may be empty
+    const targets = project.targets ?? {};
+    for (const target in targets) {
+        if (!targets[target].command && !targets[target].executor) {
+            delete targets[target];
+            continue;
+        }
+        targets[target].options = (0, project_configuration_utils_1.resolveNxTokensInOptions)(targets[target].options, project, `${projectName}:${target}`);
+        targets[target].configurations ??= {};
+        for (const configuration in targets[target].configurations) {
+            targets[target].configurations[configuration] = (0, project_configuration_utils_1.resolveNxTokensInOptions)(targets[target].configurations[configuration], project, `${projectName}:${target}:${configuration}`);
         }
-        return condition;
-    }).join(' OR ');
-}
-function hasOneOfRequiredTags(projectName, tags, requiresOnOfTheseTagConditions) {
-    if (!requiresOnOfTheseTagConditions || requiresOnOfTheseTagConditions.length === 0) {
-        return true;
-    }
-    if (!tags || tags.length === 0) {
-        return false;
     }
-    const hasMatch = requiresOnOfTheseTagConditions.some((condition) => hasTagMatchingCondition(condition, tags));
-    if (!hasMatch) {
-        core.debug(`[${projectName}]: Does not match any of the provided condition "${cleanLogConditions(requiresOnOfTheseTagConditions)}"`);
+    return targets;
+}
+exports.normalizeProjectTargets = normalizeProjectTargets;
+function normalizeImplicitDependencies(source, implicitDependencies, projects) {
+    if (!implicitDependencies?.length) {
+        return implicitDependencies ?? [];
     }
-    return hasMatch;
+    const matches = (0, find_matching_projects_1.findMatchingProjects)(implicitDependencies, projects);
+    return (matches
+        .filter((x) => x !== source)
+        // implicit dependencies that start with ! should hang around, to be processed by
+        // implicit-project-dependencies.ts after explicit deps are added to graph.
+        .concat(implicitDependencies.filter((x) => x.startsWith('!'))));
 }
-exports.hasOneOfRequiredTags = hasOneOfRequiredTags;
+exports.normalizeImplicitDependencies = normalizeImplicitDependencies;
 
 
 /***/ }),
 
-/***/ 81067:
+/***/ 33190:
 /***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
 "use strict";
 
 Object.defineProperty(exports, "__esModule", ({ value: true }));
-exports.runTarget = void 0;
-const tslib_1 = __nccwpck_require__(65315);
-const core = tslib_1.__importStar(__nccwpck_require__(57896));
-const run_many_1 = __nccwpck_require__(74658);
-const build_command_1 = __nccwpck_require__(70384);
-const exec_1 = __nccwpck_require__(59902);
-const generate_summary_1 = __nccwpck_require__(38971);
-const get_projects_with_target_1 = __nccwpck_require__(97904);
-const get_rest_args_1 = __nccwpck_require__(70069);
-function runTarget(cwd, projects, runProjects, target, config, parallel, withSummary) {
-    return tslib_1.__awaiter(this, void 0, void 0, function* () {
-        const projectsWithTarget = (0, get_projects_with_target_1.getProjectsWithTarget)(projects, runProjects, target);
-        if (projectsWithTarget.length === 0) {
-            core.info(`No projects to run for target "${target}"`);
-            return;
+exports.readTargetDefaultsForTarget = exports.resolveNxTokensInOptions = exports.isCompatibleTarget = exports.mergeTargetConfigurations = exports.readProjectConfigurationsFromRootMap = exports.buildProjectsConfigurationsFromProjectPathsAndPlugins = exports.mergeProjectConfigurationIntoRootMap = void 0;
+const logger_1 = __nccwpck_require__(39299);
+const fileutils_1 = __nccwpck_require__(83851);
+const workspace_root_1 = __nccwpck_require__(86708);
+const target_defaults_plugin_1 = __nccwpck_require__(50280);
+const minimatch_1 = __nccwpck_require__(55224);
+const path_1 = __nccwpck_require__(71017);
+function mergeProjectConfigurationIntoRootMap(projectRootMap, project, configurationSourceMaps, sourceInformation, 
+// This function is used when reading project configuration
+// in generators, where we don't want to do this.
+skipCommandNormalization) {
+    if (configurationSourceMaps && !configurationSourceMaps[project.root]) {
+        configurationSourceMaps[project.root] = {};
+    }
+    const sourceMap = configurationSourceMaps?.[project.root];
+    let matchingProject = projectRootMap.get(project.root);
+    if (!matchingProject) {
+        projectRootMap.set(project.root, {
+            root: project.root,
+        });
+        matchingProject = projectRootMap.get(project.root);
+        if (sourceMap) {
+            sourceMap[`root`] = sourceInformation;
+        }
+    }
+    // This handles top level properties that are overwritten.
+    // e.g. `srcRoot`, `projectType`, or other fields that shouldn't be extended
+    // Note: `name` is set specifically here to keep it from changing. The name is
+    // always determined by the first inference plugin to ID a project, unless it has
+    // a project.json in which case it was already updated above.
+    const updatedProjectConfiguration = {
+        ...matchingProject,
+        ...project,
+    };
+    if (sourceMap) {
+        for (const property in project) {
+            sourceMap[`${property}`] = sourceInformation;
         }
-        const runManyCommandParts = [
-            'npx nx run-many',
-            `--target=${target}`,
-            `--projects=${projectsWithTarget.join(',')}`,
-            `--output-style=stream`,
-            config && `--configuration=${config}`,
-            (core.isDebug() || run_many_1.argv.verbose) && '--verbose',
-            `${(0, get_rest_args_1.getRestArgs)()}`
-        ];
-        switch (target) {
-            case 'build':
-                if (!config) {
-                    runManyCommandParts.push('--prod');
+    }
+    // The next blocks handle properties that should be themselves merged (e.g. targets, tags, and implicit dependencies)
+    if (project.tags) {
+        updatedProjectConfiguration.tags = Array.from(new Set((matchingProject.tags ?? []).concat(project.tags)));
+        if (sourceMap) {
+            project.tags.forEach((tag) => {
+                sourceMap[`tags.${tag}`] = sourceInformation;
+            });
+        }
+    }
+    if (project.implicitDependencies) {
+        updatedProjectConfiguration.implicitDependencies = (matchingProject.implicitDependencies ?? []).concat(project.implicitDependencies);
+        if (sourceMap) {
+            project.implicitDependencies.forEach((implicitDependency) => {
+                sourceMap[`implicitDependencies.${implicitDependency}`] =
+                    sourceInformation;
+            });
+        }
+    }
+    if (project.generators) {
+        // Start with generators config in new project.
+        updatedProjectConfiguration.generators = { ...project.generators };
+        if (sourceMap) {
+            for (const generator in project.generators) {
+                sourceMap[`generators.${generator}`] = sourceInformation;
+                for (const property in project.generators[generator]) {
+                    sourceMap[`generators.${generator}.${property}`] = sourceInformation;
                 }
-                break;
-            case 'deploy':
-                if (!parallel) {
-                    runManyCommandParts.push('--parallel=2');
+            }
+        }
+        if (matchingProject.generators) {
+            // For each generator that was already defined, shallow merge the options.
+            // Project contains the new info, so it has higher priority.
+            for (const generator in matchingProject.generators) {
+                updatedProjectConfiguration.generators[generator] = {
+                    ...matchingProject.generators[generator],
+                    ...project.generators[generator],
+                };
+            }
+        }
+    }
+    if (project.namedInputs) {
+        updatedProjectConfiguration.namedInputs = {
+            ...matchingProject.namedInputs,
+            ...project.namedInputs,
+        };
+        if (sourceMap) {
+            for (const namedInput in project.namedInputs) {
+                sourceMap[`namedInputs.${namedInput}`] = sourceInformation;
+            }
+        }
+    }
+    if (project.targets) {
+        // We merge the targets with special handling, so clear this back to the
+        // targets as defined originally before merging.
+        updatedProjectConfiguration.targets = matchingProject?.targets ?? {};
+        // For each target defined in the new config
+        for (const targetName in project.targets) {
+            // Always set source map info for the target, but don't overwrite info already there
+            // if augmenting an existing target.
+            const target = project.targets?.[targetName];
+            if (sourceMap && !target?.[target_defaults_plugin_1.ONLY_MODIFIES_EXISTING_TARGET]) {
+                sourceMap[`targets.${targetName}`] = sourceInformation;
+            }
+            // If ONLY_MODIFIES_EXISTING_TARGET is true, and its not on the matching project
+            // we shouldn't merge its info into the graph
+            if (target?.[target_defaults_plugin_1.ONLY_MODIFIES_EXISTING_TARGET] &&
+                !matchingProject.targets?.[targetName]) {
+                continue;
+            }
+            // We don't want the symbol to live on past the merge process
+            if (target?.[target_defaults_plugin_1.ONLY_MODIFIES_EXISTING_TARGET])
+                delete target?.[target_defaults_plugin_1.ONLY_MODIFIES_EXISTING_TARGET];
+            updatedProjectConfiguration.targets[targetName] =
+                mergeTargetConfigurations(skipCommandNormalization
+                    ? target
+                    : resolveCommandSyntacticSugar(target, project.root), matchingProject.targets?.[targetName], sourceMap, sourceInformation, `targets.${targetName}`);
+        }
+    }
+    projectRootMap.set(updatedProjectConfiguration.root, updatedProjectConfiguration);
+}
+exports.mergeProjectConfigurationIntoRootMap = mergeProjectConfigurationIntoRootMap;
+/**
+ * Transforms a list of project paths into a map of project configurations.
+ *
+ * @param nxJson The NxJson configuration
+ * @param projectFiles A list of files identified as projects
+ * @param plugins The plugins that should be used to infer project configuration
+ * @param root The workspace root
+ */
+function buildProjectsConfigurationsFromProjectPathsAndPlugins(nxJson, projectFiles, // making this parameter allows devkit to pick up newly created projects
+plugins, root = workspace_root_1.workspaceRoot) {
+    const results = [];
+    // We iterate over plugins first - this ensures that plugins specified first take precedence.
+    for (const { plugin, options } of plugins) {
+        const [pattern, createNodes] = plugin.createNodes ?? [];
+        const pluginResults = [];
+        performance.mark(`${plugin.name}:createNodes - start`);
+        if (!pattern) {
+            continue;
+        }
+        // Set this globally to allow plugins to know if they are being called from the project graph creation
+        global.NX_GRAPH_CREATION = true;
+        for (const file of projectFiles) {
+            performance.mark(`${plugin.name}:createNodes:${file} - start`);
+            if ((0, minimatch_1.minimatch)(file, pattern, { dot: true })) {
+                try {
+                    let r = createNodes(file, options, {
+                        nxJsonConfiguration: nxJson,
+                        workspaceRoot: root,
+                    });
+                    if (r instanceof Promise) {
+                        pluginResults.push(r
+                            .catch((e) => {
+                            performance.mark(`${plugin.name}:createNodes:${file} - end`);
+                            throw new CreateNodesError(`Unable to create nodes for ${file} using plugin ${plugin.name}.`, e);
+                        })
+                            .then((r) => {
+                            performance.mark(`${plugin.name}:createNodes:${file} - end`);
+                            performance.measure(`${plugin.name}:createNodes:${file}`, `${plugin.name}:createNodes:${file} - start`, `${plugin.name}:createNodes:${file} - end`);
+                            return { ...r, file, pluginName: plugin.name };
+                        }));
+                    }
+                    else {
+                        performance.mark(`${plugin.name}:createNodes:${file} - end`);
+                        performance.measure(`${plugin.name}:createNodes:${file}`, `${plugin.name}:createNodes:${file} - start`, `${plugin.name}:createNodes:${file} - end`);
+                        pluginResults.push({
+                            ...r,
+                            file,
+                            pluginName: plugin.name,
+                        });
+                    }
                 }
-                break;
-            case 'test':
-                if (!parallel) {
-                    runManyCommandParts.push('--parallel=4');
+                catch (e) {
+                    throw new CreateNodesError(`Unable to create nodes for ${file} using plugin ${plugin.name}.`, e);
                 }
-                break;
-        }
-        if (parallel) {
-            runManyCommandParts.push(`--parallel=${parallel}`);
+            }
         }
-        const runManyResult = (0, exec_1.execCommand)((0, build_command_1.buildCommand)(runManyCommandParts), {
-            cwd
-        });
-        if (!runManyResult.success) {
-            core.setFailed('Run many command failed!');
+        // If there are no promises (counter undefined) or all promises have resolved (counter === 0)
+        results.push(Promise.all(pluginResults).then((results) => {
+            delete global.NX_GRAPH_CREATION;
+            performance.mark(`${plugin.name}:createNodes - end`);
+            performance.measure(`${plugin.name}:createNodes`, `${plugin.name}:createNodes - start`, `${plugin.name}:createNodes - end`);
+            return results;
+        }));
+    }
+    return Promise.all(results).then((results) => {
+        performance.mark('createNodes:merge - start');
+        const projectRootMap = new Map();
+        const externalNodes = {};
+        const configurationSourceMaps = {};
+        for (const result of results.flat()) {
+            const { projects: projectNodes, externalNodes: pluginExternalNodes, file, pluginName, } = result;
+            for (const node in projectNodes) {
+                const project = {
+                    root: node,
+                    ...projectNodes[node],
+                };
+                try {
+                    mergeProjectConfigurationIntoRootMap(projectRootMap, project, configurationSourceMaps, [file, pluginName]);
+                }
+                catch (e) {
+                    throw new CreateNodesError(`Unable to merge project information for "${project.root}" from ${result.file} using plugin ${result.pluginName}.`, e);
+                }
+            }
+            Object.assign(externalNodes, pluginExternalNodes);
         }
-        if (withSummary) {
+        const projects = readProjectConfigurationsFromRootMap(projectRootMap);
+        const rootMap = createRootMap(projectRootMap);
+        performance.mark('createNodes:merge - end');
+        performance.measure('createNodes:merge', 'createNodes:merge - start', 'createNodes:merge - end');
+        return {
+            projects,
+            externalNodes,
+            rootMap,
+            sourceMaps: configurationSourceMaps,
+        };
+    });
+}
+exports.buildProjectsConfigurationsFromProjectPathsAndPlugins = buildProjectsConfigurationsFromProjectPathsAndPlugins;
+function readProjectConfigurationsFromRootMap(projectRootMap) {
+    const projects = {};
+    // If there are projects that have the same name, that is an error.
+    // This object tracks name -> (all roots of projects with that name)
+    // to provide better error messaging.
+    const errors = new Map();
+    for (const [root, configuration] of projectRootMap.entries()) {
+        if (!configuration.name) {
             try {
-                yield (0, generate_summary_1.generateSummary)(target, projectsWithTarget, runManyResult.output);
+                const { name } = (0, fileutils_1.readJsonFile)((0, path_1.join)(root, 'package.json'));
+                configuration.name = name;
             }
-            catch (err) {
-                core.warning(`Error generating Github summary: ${err.message || err}`);
+            catch {
+                throw new Error(`Project at ${root} has no name provided.`);
             }
         }
-    });
+        if (configuration.name in projects) {
+            let rootErrors = errors.get(configuration.name) ?? [
+                projects[configuration.name].root,
+            ];
+            rootErrors.push(root);
+            errors.set(configuration.name, rootErrors);
+        }
+        else {
+            projects[configuration.name] = configuration;
+        }
+    }
+    if (errors.size > 0) {
+        throw new Error([
+            `The following projects are defined in multiple locations:`,
+            ...Array.from(errors.entries()).map(([project, roots]) => [`- ${project}: `, ...roots.map((r) => `  - ${r}`)].join('\n')),
+            '',
+            "To fix this, set a unique name for each project in a project.json inside the project's root. If the project does not currently have a project.json, you can create one that contains only a name.",
+        ].join('\n'));
+    }
+    return projects;
+}
+exports.readProjectConfigurationsFromRootMap = readProjectConfigurationsFromRootMap;
+class CreateNodesError extends Error {
+    constructor(msg, cause) {
+        const message = `${msg} ${!cause
+            ? ''
+            : cause instanceof Error
+                ? `\n\n\t Inner Error: ${cause.stack}`
+                : cause}`;
+        // These errors are thrown during a JS callback which is invoked via rust.
+        // The errors messaging gets lost in the rust -> js -> rust transition, but
+        // logging the error here will ensure that it is visible in the console.
+        console.error(message);
+        super(message, { cause });
+    }
+}
+/**
+ * Merges two targets.
+ *
+ * Most properties from `target` will overwrite any properties from `baseTarget`.
+ * Options and configurations are treated differently - they are merged together if the executor definition is compatible.
+ *
+ * @param target The target definition with higher priority
+ * @param baseTarget The target definition that should be overwritten. Can be undefined, in which case the target is returned as-is.
+ * @param projectConfigSourceMap The source map to be filled with metadata about where each property came from
+ * @param sourceInformation The metadata about where the new target was defined
+ * @param targetIdentifier The identifier for the target to merge, used for source map
+ * @returns A merged target configuration
+ */
+function mergeTargetConfigurations(target, baseTarget, projectConfigSourceMap, sourceInformation, targetIdentifier) {
+    const { configurations: defaultConfigurations, options: defaultOptions, ...baseTargetProperties } = baseTarget ?? {};
+    // Target is "compatible", e.g. executor is defined only once or is the same
+    // in both places. This means that it is likely safe to merge
+    const isCompatible = isCompatibleTarget(baseTargetProperties, target);
+    if (!isCompatible && projectConfigSourceMap) {
+        // if the target is not compatible, we will simply override the options
+        // we have to delete old entries from the source map
+        for (const key in projectConfigSourceMap) {
+            if (key.startsWith(`${targetIdentifier}`)) {
+                delete projectConfigSourceMap[key];
+            }
+        }
+    }
+    // merge top level properties if they're compatible
+    const result = {
+        ...(isCompatible ? baseTargetProperties : {}),
+        ...target,
+    };
+    // record top level properties in source map
+    if (projectConfigSourceMap) {
+        projectConfigSourceMap[targetIdentifier] = sourceInformation;
+        // record root level target properties to source map
+        for (const targetProperty in target) {
+            const targetPropertyId = `${targetIdentifier}.${targetProperty}`;
+            projectConfigSourceMap[targetPropertyId] = sourceInformation;
+        }
+    }
+    // merge options if there are any
+    // if the targets aren't compatible, we simply discard the old options during the merge
+    if (target.options || defaultOptions) {
+        result.options = mergeOptions(target.options, isCompatible ? defaultOptions : undefined, projectConfigSourceMap, sourceInformation, targetIdentifier);
+    }
+    // merge configurations if there are any
+    // if the targets aren't compatible, we simply discard the old configurations during the merge
+    if (target.configurations || defaultConfigurations) {
+        result.configurations = mergeConfigurations(target.configurations, isCompatible ? defaultConfigurations : undefined, projectConfigSourceMap, sourceInformation, targetIdentifier);
+    }
+    return result;
+}
+exports.mergeTargetConfigurations = mergeTargetConfigurations;
+/**
+ * Checks if targets options are compatible - used when merging configurations
+ * to avoid merging options for @nx/js:tsc into something like @nx/webpack:webpack.
+ *
+ * If the executors are both specified and don't match, the options aren't considered
+ * "compatible" and shouldn't be merged.
+ */
+function isCompatibleTarget(a, b) {
+    const oneHasNoExecutor = !a.executor || !b.executor;
+    const bothHaveSameExecutor = a.executor === b.executor;
+    if (oneHasNoExecutor)
+        return true;
+    if (!bothHaveSameExecutor)
+        return false;
+    const isRunCommands = a.executor === 'nx:run-commands';
+    if (isRunCommands) {
+        const aCommand = a.options?.command ?? a.options?.commands.join(' && ');
+        const bCommand = b.options?.command ?? b.options?.commands.join(' && ');
+        const oneHasNoCommand = !aCommand || !bCommand;
+        const hasSameCommand = aCommand === bCommand;
+        return oneHasNoCommand || hasSameCommand;
+    }
+    const isRunScript = a.executor === 'nx:run-script';
+    if (isRunScript) {
+        const aScript = a.options?.script;
+        const bScript = b.options?.script;
+        const oneHasNoScript = !aScript || !bScript;
+        const hasSameScript = aScript === bScript;
+        return oneHasNoScript || hasSameScript;
+    }
+    return true;
+}
+exports.isCompatibleTarget = isCompatibleTarget;
+function mergeConfigurations(newConfigurations, baseConfigurations, projectConfigSourceMap, sourceInformation, targetIdentifier) {
+    const mergedConfigurations = {};
+    const configurations = new Set([
+        ...Object.keys(baseConfigurations ?? {}),
+        ...Object.keys(newConfigurations ?? {}),
+    ]);
+    for (const configuration of configurations) {
+        mergedConfigurations[configuration] = {
+            ...(baseConfigurations?.[configuration] ?? {}),
+            ...(newConfigurations?.[configuration] ?? {}),
+        };
+    }
+    // record new configurations & configuration properties in source map
+    if (projectConfigSourceMap) {
+        for (const newConfiguration in newConfigurations) {
+            projectConfigSourceMap[`${targetIdentifier}.configurations.${newConfiguration}`] = sourceInformation;
+            for (const configurationProperty in newConfigurations[newConfiguration]) {
+                projectConfigSourceMap[`${targetIdentifier}.configurations.${newConfiguration}.${configurationProperty}`] = sourceInformation;
+            }
+        }
+    }
+    return mergedConfigurations;
+}
+function mergeOptions(newOptions, baseOptions, projectConfigSourceMap, sourceInformation, targetIdentifier) {
+    const mergedOptions = {
+        ...(baseOptions ?? {}),
+        ...(newOptions ?? {}),
+    };
+    // record new options & option properties in source map
+    if (projectConfigSourceMap) {
+        for (const newOption in newOptions) {
+            projectConfigSourceMap[`${targetIdentifier}.options.${newOption}`] =
+                sourceInformation;
+        }
+    }
+    return mergedOptions;
+}
+function resolveNxTokensInOptions(object, project, key) {
+    const result = Array.isArray(object) ? [...object] : { ...object };
+    for (let [opt, value] of Object.entries(object ?? {})) {
+        if (typeof value === 'string') {
+            const workspaceRootMatch = /^(\{workspaceRoot\}\/?)/.exec(value);
+            if (workspaceRootMatch?.length) {
+                value = value.replace(workspaceRootMatch[0], '');
+            }
+            if (value.includes('{workspaceRoot}')) {
+                throw new Error(`${logger_1.NX_PREFIX} The {workspaceRoot} token is only valid at the beginning of an option. (${key})`);
+            }
+            value = value.replace(/\{projectRoot\}/g, project.root);
+            result[opt] = value.replace(/\{projectName\}/g, project.name);
+        }
+        else if (typeof value === 'object' && value) {
+            result[opt] = resolveNxTokensInOptions(value, project, [key, opt].join('.'));
+        }
+    }
+    return result;
+}
+exports.resolveNxTokensInOptions = resolveNxTokensInOptions;
+function readTargetDefaultsForTarget(targetName, targetDefaults, executor) {
+    if (executor) {
+        // If an executor is defined in project.json, defaults should be read
+        // from the most specific key that matches that executor.
+        // e.g. If executor === run-commands, and the target is named build:
+        // Use, use nx:run-commands if it is present
+        // If not, use build if it is present.
+        const key = [executor, targetName].find((x) => targetDefaults?.[x]);
+        return key ? targetDefaults?.[key] : null;
+    }
+    else {
+        // If the executor is not defined, the only key we have is the target name.
+        return targetDefaults?.[targetName];
+    }
+}
+exports.readTargetDefaultsForTarget = readTargetDefaultsForTarget;
+function createRootMap(projectRootMap) {
+    const map = {};
+    for (const [projectRoot, { name: projectName }] of projectRootMap) {
+        map[projectRoot] = projectName;
+    }
+    return map;
+}
+function resolveCommandSyntacticSugar(target, key) {
+    const { command, ...config } = target ?? {};
+    if (!command) {
+        return target;
+    }
+    if (config.executor) {
+        throw new Error(`${logger_1.NX_PREFIX} Project at ${key} should not have executor and command both configured.`);
+    }
+    else {
+        return {
+            ...config,
+            executor: 'nx:run-commands',
+            options: {
+                ...config.options,
+                command: command,
+            },
+        };
+    }
 }
-exports.runTarget = runTarget;
-
-
-/***/ }),
-
-/***/ 10498:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
-
-module.exports = require(__nccwpck_require__.ab + "nx.darwin-arm64.node")
-
-/***/ }),
-
-/***/ 40679:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
-
-module.exports = require(__nccwpck_require__.ab + "swc.darwin-arm64.node")
-
-/***/ }),
-
-/***/ 3479:
-/***/ ((module) => {
-
-module.exports = eval("require")("./nx.android-arm-eabi.node");
-
-
-/***/ }),
-
-/***/ 68615:
-/***/ ((module) => {
-
-module.exports = eval("require")("./nx.android-arm64.node");
-
-
-/***/ }),
-
-/***/ 64639:
-/***/ ((module) => {
-
-module.exports = eval("require")("./nx.darwin-arm64.node");
-
-
-/***/ }),
-
-/***/ 99829:
-/***/ ((module) => {
-
-module.exports = eval("require")("./nx.darwin-universal.node");
-
-
-/***/ }),
-
-/***/ 79412:
-/***/ ((module) => {
-
-module.exports = eval("require")("./nx.darwin-x64.node");
-
-
-/***/ }),
-
-/***/ 7678:
-/***/ ((module) => {
-
-module.exports = eval("require")("./nx.freebsd-x64.node");
-
-
-/***/ }),
-
-/***/ 50050:
-/***/ ((module) => {
-
-module.exports = eval("require")("./nx.linux-arm-gnueabihf.node");
-
-
-/***/ }),
-
-/***/ 90179:
-/***/ ((module) => {
-
-module.exports = eval("require")("./nx.linux-arm64-gnu.node");
-
-
-/***/ }),
-
-/***/ 32938:
-/***/ ((module) => {
-
-module.exports = eval("require")("./nx.linux-arm64-musl.node");
-
-
-/***/ }),
-
-/***/ 46888:
-/***/ ((module) => {
-
-module.exports = eval("require")("./nx.linux-x64-gnu.node");
-
-
-/***/ }),
-
-/***/ 67479:
-/***/ ((module) => {
-
-module.exports = eval("require")("./nx.linux-x64-musl.node");
-
-
-/***/ }),
-
-/***/ 80491:
-/***/ ((module) => {
-
-module.exports = eval("require")("./nx.win32-arm64-msvc.node");
-
-
-/***/ }),
-
-/***/ 75836:
-/***/ ((module) => {
-
-module.exports = eval("require")("./nx.win32-ia32-msvc.node");
-
-
-/***/ }),
-
-/***/ 23186:
-/***/ ((module) => {
-
-module.exports = eval("require")("./nx.win32-x64-msvc.node");
-
-
-/***/ }),
-
-/***/ 70243:
-/***/ ((module) => {
-
-module.exports = eval("require")("./swc.android-arm-eabi.node");
-
-
-/***/ }),
-
-/***/ 10849:
-/***/ ((module) => {
-
-module.exports = eval("require")("./swc.android-arm64.node");
-
-
-/***/ }),
-
-/***/ 37969:
-/***/ ((module) => {
-
-module.exports = eval("require")("./swc.darwin-arm64.node");
-
-
-/***/ }),
-
-/***/ 9172:
-/***/ ((module) => {
-
-module.exports = eval("require")("./swc.darwin-x64.node");
-
-
-/***/ }),
-
-/***/ 71487:
-/***/ ((module) => {
-
-module.exports = eval("require")("./swc.freebsd-x64.node");
-
-
-/***/ }),
-
-/***/ 21651:
-/***/ ((module) => {
-
-module.exports = eval("require")("./swc.linux-arm-gnueabihf.node");
-
-
-/***/ }),
-
-/***/ 37857:
-/***/ ((module) => {
-
-module.exports = eval("require")("./swc.linux-arm64-gnu.node");
-
-
-/***/ }),
-
-/***/ 2168:
-/***/ ((module) => {
-
-module.exports = eval("require")("./swc.linux-arm64-musl.node");
-
-
-/***/ }),
-
-/***/ 13546:
-/***/ ((module) => {
-
-module.exports = eval("require")("./swc.linux-x64-gnu.node");
-
-
-/***/ }),
-
-/***/ 3394:
-/***/ ((module) => {
-
-module.exports = eval("require")("./swc.linux-x64-musl.node");
-
-
-/***/ }),
-
-/***/ 91156:
-/***/ ((module) => {
-
-module.exports = eval("require")("./swc.win32-arm64-msvc.node");
-
-
-/***/ }),
-
-/***/ 12445:
-/***/ ((module) => {
-
-module.exports = eval("require")("./swc.win32-ia32-msvc.node");
 
 
 /***/ }),
 
-/***/ 1779:
-/***/ ((module) => {
-
-module.exports = eval("require")("./swc.win32-x64-msvc.node");
-
-
-/***/ }),
+/***/ 14249:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
-/***/ 63182:
-/***/ ((module) => {
+"use strict";
 
-module.exports = eval("require")("@nx/nx-android-arm-eabi");
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.configurationGlobs = exports.createProjectConfigurations = exports.retrieveProjectConfigurationsWithoutPluginInference = exports.retrieveProjectConfigurationPaths = exports.retrieveProjectConfigurationsWithAngularProjects = exports.retrieveProjectConfigurations = exports.retrieveWorkspaceFiles = void 0;
+const perf_hooks_1 = __nccwpck_require__(4074);
+const installation_directory_1 = __nccwpck_require__(98584);
+const angular_json_1 = __nccwpck_require__(44050);
+const nx_json_1 = __nccwpck_require__(53619);
+const package_json_workspaces_1 = __nccwpck_require__(65286);
+const project_configuration_utils_1 = __nccwpck_require__(33190);
+const nx_plugin_1 = __nccwpck_require__(84141);
+const project_json_1 = __nccwpck_require__(76877);
+const workspace_context_1 = __nccwpck_require__(302);
+const build_all_workspace_files_1 = __nccwpck_require__(71074);
+/**
+ * Walks the workspace directory to create the `projectFileMap`, `ProjectConfigurations` and `allWorkspaceFiles`
+ * @throws
+ * @param workspaceRoot
+ * @param nxJson
+ */
+async function retrieveWorkspaceFiles(workspaceRoot, projectRootMap) {
+    perf_hooks_1.performance.mark('native-file-deps:start');
+    perf_hooks_1.performance.mark('native-file-deps:end');
+    perf_hooks_1.performance.measure('native-file-deps', 'native-file-deps:start', 'native-file-deps:end');
+    perf_hooks_1.performance.mark('get-workspace-files:start');
+    const { projectFileMap, globalFiles, externalReferences } = (0, workspace_context_1.getNxWorkspaceFilesFromContext)(workspaceRoot, projectRootMap);
+    perf_hooks_1.performance.mark('get-workspace-files:end');
+    perf_hooks_1.performance.measure('get-workspace-files', 'get-workspace-files:start', 'get-workspace-files:end');
+    return {
+        allWorkspaceFiles: (0, build_all_workspace_files_1.buildAllWorkspaceFiles)(projectFileMap, globalFiles),
+        fileMap: {
+            projectFileMap,
+            nonProjectFiles: globalFiles,
+        },
+        rustReferences: externalReferences,
+    };
+}
+exports.retrieveWorkspaceFiles = retrieveWorkspaceFiles;
+/**
+ * Walk through the workspace and return `ProjectConfigurations`. Only use this if the projectFileMap is not needed.
+ *
+ * @param workspaceRoot
+ * @param nxJson
+ */
+async function retrieveProjectConfigurations(workspaceRoot, nxJson) {
+    const plugins = await (0, nx_plugin_1.loadNxPlugins)(nxJson?.plugins ?? [], (0, installation_directory_1.getNxRequirePaths)(workspaceRoot), workspaceRoot);
+    return _retrieveProjectConfigurations(workspaceRoot, nxJson, plugins);
+}
+exports.retrieveProjectConfigurations = retrieveProjectConfigurations;
+async function retrieveProjectConfigurationsWithAngularProjects(workspaceRoot, nxJson) {
+    const plugins = await (0, nx_plugin_1.loadNxPlugins)(nxJson?.plugins ?? [], (0, installation_directory_1.getNxRequirePaths)(workspaceRoot), workspaceRoot);
+    if ((0, angular_json_1.shouldMergeAngularProjects)(workspaceRoot, true) &&
+        !plugins.some((p) => p.plugin.name === angular_json_1.NX_ANGULAR_JSON_PLUGIN_NAME)) {
+        plugins.push({ plugin: angular_json_1.NxAngularJsonPlugin });
+    }
+    return _retrieveProjectConfigurations(workspaceRoot, nxJson, plugins);
+}
+exports.retrieveProjectConfigurationsWithAngularProjects = retrieveProjectConfigurationsWithAngularProjects;
+function _retrieveProjectConfigurations(workspaceRoot, nxJson, plugins) {
+    const globPatterns = configurationGlobs(plugins);
+    const projectFiles = (0, workspace_context_1.globWithWorkspaceContext)(workspaceRoot, globPatterns);
+    return createProjectConfigurations(workspaceRoot, nxJson, projectFiles, plugins);
+}
+function retrieveProjectConfigurationPaths(root, plugins) {
+    const projectGlobPatterns = configurationGlobs(plugins);
+    return (0, workspace_context_1.globWithWorkspaceContext)(root, projectGlobPatterns);
+}
+exports.retrieveProjectConfigurationPaths = retrieveProjectConfigurationPaths;
+const projectsWithoutPluginCache = new Map();
+// TODO: This function is called way too often, it should be optimized without this cache
+async function retrieveProjectConfigurationsWithoutPluginInference(root) {
+    const nxJson = (0, nx_json_1.readNxJson)(root);
+    const plugins = await (0, nx_plugin_1.getDefaultPlugins)(root);
+    const projectGlobPatterns = retrieveProjectConfigurationPaths(root, plugins);
+    const cacheKey = root + ',' + projectGlobPatterns.join(',');
+    if (projectsWithoutPluginCache.has(cacheKey)) {
+        return projectsWithoutPluginCache.get(cacheKey);
+    }
+    const projectFiles = (0, workspace_context_1.globWithWorkspaceContext)(root, projectGlobPatterns);
+    const { projects } = await createProjectConfigurations(root, nxJson, projectFiles, [
+        { plugin: (0, package_json_workspaces_1.getNxPackageJsonWorkspacesPlugin)(root) },
+        { plugin: project_json_1.ProjectJsonProjectsPlugin },
+    ]);
+    projectsWithoutPluginCache.set(cacheKey, projects);
+    return projects;
+}
+exports.retrieveProjectConfigurationsWithoutPluginInference = retrieveProjectConfigurationsWithoutPluginInference;
+async function createProjectConfigurations(workspaceRoot, nxJson, configFiles, plugins) {
+    perf_hooks_1.performance.mark('build-project-configs:start');
+    const { projects, externalNodes, rootMap, sourceMaps } = await (0, project_configuration_utils_1.buildProjectsConfigurationsFromProjectPathsAndPlugins)(nxJson, configFiles, plugins, workspaceRoot);
+    perf_hooks_1.performance.mark('build-project-configs:end');
+    perf_hooks_1.performance.measure('build-project-configs', 'build-project-configs:start', 'build-project-configs:end');
+    return {
+        projects,
+        externalNodes,
+        projectRootMap: rootMap,
+        sourceMaps,
+    };
+}
+exports.createProjectConfigurations = createProjectConfigurations;
+function configurationGlobs(plugins) {
+    const globPatterns = [];
+    for (const { plugin } of plugins) {
+        if (plugin.createNodes) {
+            globPatterns.push(plugin.createNodes[0]);
+        }
+    }
+    return globPatterns;
+}
+exports.configurationGlobs = configurationGlobs;
 
 
 /***/ }),
 
-/***/ 96024:
-/***/ ((module) => {
-
-module.exports = eval("require")("@nx/nx-android-arm64");
-
-
-/***/ }),
+/***/ 89208:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
-/***/ 51641:
-/***/ ((module) => {
+"use strict";
 
-module.exports = eval("require")("@nx/nx-darwin-universal");
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.assertWorkspaceValidity = void 0;
+const find_matching_projects_1 = __nccwpck_require__(21521);
+const output_1 = __nccwpck_require__(1737);
+function assertWorkspaceValidity(projects, nxJson) {
+    const projectNames = Object.keys(projects);
+    const projectGraphNodes = projectNames.reduce((graph, project) => {
+        const projectConfiguration = projects[project];
+        graph[project] = {
+            name: project,
+            type: projectConfiguration.projectType === 'library' ? 'lib' : 'app', // missing fallback to `e2e`
+            data: {
+                ...projectConfiguration,
+            },
+        };
+        return graph;
+    }, {});
+    const invalidImplicitDependencies = new Map();
+    if (nxJson.implicitDependencies) {
+        output_1.output.warn({
+            title: 'Using `implicitDependencies` for global implicit dependencies configuration is no longer supported.',
+            bodyLines: [
+                'Use "namedInputs" instead. You can run "nx repair" to automatically migrate your configuration.',
+                'For more information about the usage of "namedInputs" see https://nx.dev/deprecated/global-implicit-dependencies#global-implicit-dependencies',
+            ],
+        });
+    }
+    const projectsWithNonArrayImplicitDependencies = new Map();
+    projectNames
+        .filter((projectName) => {
+        const project = projects[projectName];
+        // Report if for whatever reason, a project is configured to use implicitDependencies but it is not an array
+        if (!!project.implicitDependencies &&
+            !Array.isArray(project.implicitDependencies)) {
+            projectsWithNonArrayImplicitDependencies.set(projectName, project.implicitDependencies);
+        }
+        return (!!project.implicitDependencies &&
+            Array.isArray(project.implicitDependencies));
+    })
+        .reduce((map, projectName) => {
+        const project = projects[projectName];
+        detectAndSetInvalidProjectGlobValues(map, projectName, project.implicitDependencies, projects, projectGraphNodes);
+        return map;
+    }, invalidImplicitDependencies);
+    if (projectsWithNonArrayImplicitDependencies.size === 0 &&
+        invalidImplicitDependencies.size === 0) {
+        // No issues
+        return;
+    }
+    let message = '';
+    if (projectsWithNonArrayImplicitDependencies.size > 0) {
+        message += `The following implicitDependencies should be an array of strings:\n`;
+        projectsWithNonArrayImplicitDependencies.forEach((implicitDependencies, projectName) => {
+            message += `  ${projectName}.implicitDependencies: "${implicitDependencies}"\n`;
+        });
+        message += '\n';
+    }
+    if (invalidImplicitDependencies.size > 0) {
+        message += `The following implicitDependencies point to non-existent project(s):\n`;
+        message += [...invalidImplicitDependencies.keys()]
+            .map((key) => {
+            const projectNames = invalidImplicitDependencies.get(key);
+            return `  ${key}\n${projectNames
+                .map((projectName) => `    ${projectName}`)
+                .join('\n')}`;
+        })
+            .join('\n\n');
+    }
+    throw new Error(`Configuration Error\n${message}`);
+}
+exports.assertWorkspaceValidity = assertWorkspaceValidity;
+function detectAndSetInvalidProjectGlobValues(map, sourceName, desiredImplicitDeps, projectConfigurations, projects) {
+    const invalidProjectsOrGlobs = desiredImplicitDeps.filter((implicit) => {
+        const projectName = implicit.startsWith('!')
+            ? implicit.substring(1)
+            : implicit;
+        return !(projectConfigurations[projectName] ||
+            (0, find_matching_projects_1.findMatchingProjects)([implicit], projects).length);
+    });
+    if (invalidProjectsOrGlobs.length > 0) {
+        map.set(sourceName, invalidProjectsOrGlobs);
+    }
+}
 
 
 /***/ }),
 
-/***/ 85775:
-/***/ ((module) => {
-
-module.exports = eval("require")("@nx/nx-darwin-x64");
-
-
-/***/ }),
+/***/ 15120:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
-/***/ 64160:
-/***/ ((module) => {
+"use strict";
 
-module.exports = eval("require")("@nx/nx-freebsd-x64");
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.projectGraphCacheDirectory = exports.cacheDirectoryForWorkspace = exports.cacheDir = void 0;
+const fs_1 = __nccwpck_require__(57147);
+const path_1 = __nccwpck_require__(71017);
+const fileutils_1 = __nccwpck_require__(83851);
+const workspace_root_1 = __nccwpck_require__(86708);
+function readCacheDirectoryProperty(root) {
+    try {
+        const nxJson = (0, fileutils_1.readJsonFile)((0, path_1.join)(root, 'nx.json'));
+        return (nxJson.cacheDirectory ??
+            nxJson.tasksRunnerOptions?.default.options.cacheDirectory);
+    }
+    catch {
+        return undefined;
+    }
+}
+function absolutePath(root, path) {
+    if ((0, path_1.isAbsolute)(path)) {
+        return path;
+    }
+    else {
+        return (0, path_1.join)(root, path);
+    }
+}
+function cacheDirectory(root, cacheDirectory) {
+    const cacheDirFromEnv = process.env.NX_CACHE_DIRECTORY;
+    if (cacheDirFromEnv) {
+        cacheDirectory = cacheDirFromEnv;
+    }
+    if (cacheDirectory) {
+        return absolutePath(root, cacheDirectory);
+    }
+    else {
+        return defaultCacheDirectory(root);
+    }
+}
+function defaultCacheDirectory(root) {
+    // If nx.json doesn't exist the repo can't utilize
+    // caching, so .nx/cache is less relevant. Lerna users
+    // that don't want to fully opt in to Nx at this time
+    // may also be caught off guard by the appearance of
+    // a .nx directory, so we are going to special case
+    // this for the time being.
+    if ((0, fs_1.existsSync)((0, path_1.join)(root, 'lerna.json')) &&
+        !(0, fs_1.existsSync)((0, path_1.join)(root, 'nx.json'))) {
+        return (0, path_1.join)(root, 'node_modules', '.cache', 'nx');
+    }
+    return (0, path_1.join)(root, '.nx', 'cache');
+}
+/**
+ * Path to the directory where Nx stores its cache and daemon-related files.
+ */
+exports.cacheDir = cacheDirectory(workspace_root_1.workspaceRoot, readCacheDirectoryProperty(workspace_root_1.workspaceRoot));
+function cacheDirectoryForWorkspace(workspaceRoot) {
+    return cacheDirectory(workspaceRoot, readCacheDirectoryProperty(workspaceRoot));
+}
+exports.cacheDirectoryForWorkspace = cacheDirectoryForWorkspace;
+exports.projectGraphCacheDirectory = absolutePath(workspace_root_1.workspaceRoot, process.env.NX_PROJECT_GRAPH_CACHE_DIRECTORY ??
+    defaultCacheDirectory(workspace_root_1.workspaceRoot));
 
 
 /***/ }),
 
-/***/ 8429:
-/***/ ((module) => {
-
-module.exports = eval("require")("@nx/nx-linux-arm-gnueabihf");
-
-
-/***/ }),
+/***/ 24622:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
-/***/ 36708:
-/***/ ((module) => {
+"use strict";
 
-module.exports = eval("require")("@nx/nx-linux-arm64-gnu");
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.codeFrameColumns = void 0;
+// Adapted from https://raw.githubusercontent.com/babel/babel/4108524/packages/babel-code-frame/src/index.js
+const chalk = __nccwpck_require__(36662);
+/**
+ * Chalk styles for code frame token types.
+ */
+function getDefs(chalk) {
+    return {
+        gutter: chalk.grey,
+        marker: chalk.red.bold,
+        message: chalk.red.bold,
+    };
+}
+/**
+ * RegExp to test for newlines in terminal.
+ */
+const NEWLINE = /\r\n|[\n\r\u2028\u2029]/;
+/**
+ * Extract what lines should be marked and highlighted.
+ */
+function getMarkerLines(loc, source, opts = {}) {
+    const startLoc = {
+        column: 0,
+        line: -1,
+        ...loc.start,
+    };
+    const endLoc = {
+        ...startLoc,
+        ...loc.end,
+    };
+    const { linesAbove = 2, linesBelow = 3 } = opts || {};
+    const startLine = startLoc.line;
+    const startColumn = startLoc.column;
+    const endLine = endLoc.line;
+    const endColumn = endLoc.column;
+    let start = Math.max(startLine - (linesAbove + 1), 0);
+    let end = Math.min(source.length, endLine + linesBelow);
+    if (startLine === -1) {
+        start = 0;
+    }
+    if (endLine === -1) {
+        end = source.length;
+    }
+    const lineDiff = endLine - startLine;
+    const markerLines = {};
+    if (lineDiff) {
+        for (let i = 0; i <= lineDiff; i++) {
+            const lineNumber = i + startLine;
+            if (!startColumn) {
+                markerLines[lineNumber] = true;
+            }
+            else if (i === 0) {
+                const sourceLength = source[lineNumber - 1].length;
+                markerLines[lineNumber] = [startColumn, sourceLength - startColumn + 1];
+            }
+            else if (i === lineDiff) {
+                markerLines[lineNumber] = [0, endColumn];
+            }
+            else {
+                const sourceLength = source[lineNumber - i].length;
+                markerLines[lineNumber] = [0, sourceLength];
+            }
+        }
+    }
+    else {
+        if (startColumn === endColumn) {
+            if (startColumn) {
+                markerLines[startLine] = [startColumn, 0];
+            }
+            else {
+                markerLines[startLine] = true;
+            }
+        }
+        else {
+            markerLines[startLine] = [startColumn, endColumn - startColumn];
+        }
+    }
+    return { start, end, markerLines };
+}
+function codeFrameColumns(rawLines, loc, opts = {}) {
+    const defs = getDefs(chalk);
+    const lines = rawLines.split(NEWLINE);
+    const { start, end, markerLines } = getMarkerLines(loc, lines, opts);
+    const numberMaxWidth = String(end).length;
+    const highlightedLines = opts.highlight ? opts.highlight(rawLines) : rawLines;
+    let frame = highlightedLines
+        .split(NEWLINE)
+        .slice(start, end)
+        .map((line, index) => {
+        const number = start + 1 + index;
+        const paddedNumber = ` ${number}`.slice(-numberMaxWidth);
+        const gutter = ` ${paddedNumber} | `;
+        const hasMarker = markerLines[number];
+        if (hasMarker) {
+            let markerLine = '';
+            if (Array.isArray(hasMarker)) {
+                const markerSpacing = line
+                    .slice(0, Math.max(hasMarker[0] - 1, 0))
+                    .replace(/[^\t]/g, ' ');
+                const numberOfMarkers = hasMarker[1] || 1;
+                markerLine = [
+                    '\n ',
+                    defs.gutter(gutter.replace(/\d/g, ' ')),
+                    markerSpacing,
+                    defs.marker('^').repeat(numberOfMarkers),
+                ].join('');
+            }
+            return [defs.marker('>'), defs.gutter(gutter), line, markerLine].join('');
+        }
+        else {
+            return ` ${defs.gutter(gutter)}${line}`;
+        }
+    })
+        .join('\n');
+    return chalk.reset(frame);
+}
+exports.codeFrameColumns = codeFrameColumns;
 
 
 /***/ }),
 
-/***/ 67311:
-/***/ ((module) => {
-
-module.exports = eval("require")("@nx/nx-linux-arm64-musl");
-
-
-/***/ }),
+/***/ 22214:
+/***/ ((__unused_webpack_module, exports) => {
 
-/***/ 94444:
-/***/ ((module) => {
+"use strict";
 
-module.exports = eval("require")("@nx/nx-linux-x64-gnu");
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.consumeMessagesFromSocket = void 0;
+function consumeMessagesFromSocket(callback) {
+    let message = '';
+    return (data) => {
+        const chunk = data.toString();
+        if (chunk.codePointAt(chunk.length - 1) === 4) {
+            message += chunk.substring(0, chunk.length - 1);
+            // Server may send multiple messages in one chunk, so splitting by 0x4
+            const messages = message.split('');
+            for (const splitMessage of messages) {
+                callback(splitMessage);
+            }
+            message = '';
+        }
+        else {
+            message += chunk;
+        }
+    };
+}
+exports.consumeMessagesFromSocket = consumeMessagesFromSocket;
 
 
 /***/ }),
 
-/***/ 93490:
-/***/ ((module) => {
-
-module.exports = eval("require")("@nx/nx-linux-x64-musl");
-
-
-/***/ }),
+/***/ 83851:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
-/***/ 48358:
-/***/ ((module) => {
+"use strict";
 
-module.exports = eval("require")("@nx/nx-win32-arm64-msvc");
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.readFileIfExisting = exports.extractFileFromTarball = exports.isRelativePath = exports.createDirectory = exports.fileExists = exports.directoryExists = exports.writeJsonFile = exports.readYamlFile = exports.readJsonFile = void 0;
+const json_1 = __nccwpck_require__(8314);
+const fs_1 = __nccwpck_require__(57147);
+const path_1 = __nccwpck_require__(71017);
+const tar = __nccwpck_require__(18571);
+const zlib_1 = __nccwpck_require__(59796);
+/**
+ * Reads a JSON file and returns the object the JSON content represents.
+ *
+ * @param path A path to a file.
+ * @param options JSON parse options
+ * @returns Object the JSON content of the file represents
+ */
+function readJsonFile(path, options) {
+    const content = (0, fs_1.readFileSync)(path, 'utf-8');
+    if (options) {
+        options.endsWithNewline = content.charCodeAt(content.length - 1) === 10;
+    }
+    try {
+        return (0, json_1.parseJson)(content, options);
+    }
+    catch (e) {
+        e.message = e.message.replace('JSON', path);
+        throw e;
+    }
+}
+exports.readJsonFile = readJsonFile;
+/**
+ * Reads a YAML file and returns the object the YAML content represents.
+ *
+ * @param path A path to a file.
+ * @returns
+ */
+function readYamlFile(path, options) {
+    const content = (0, fs_1.readFileSync)(path, 'utf-8');
+    const { load } = __nccwpck_require__(45126);
+    return load(content, { ...options, filename: path });
+}
+exports.readYamlFile = readYamlFile;
+/**
+ * Serializes the given data to JSON and writes it to a file.
+ *
+ * @param path A path to a file.
+ * @param data data which should be serialized to JSON and written to the file
+ * @param options JSON serialize options
+ */
+function writeJsonFile(path, data, options) {
+    (0, fs_1.mkdirSync)((0, path_1.dirname)(path), { recursive: true });
+    const serializedJson = (0, json_1.serializeJson)(data, options);
+    const content = options?.appendNewLine
+        ? `${serializedJson}\n`
+        : serializedJson;
+    (0, fs_1.writeFileSync)(path, content, { encoding: 'utf-8' });
+}
+exports.writeJsonFile = writeJsonFile;
+/**
+ * Check if a directory exists
+ * @param path Path to directory
+ */
+function directoryExists(path) {
+    try {
+        return (0, fs_1.statSync)(path).isDirectory();
+    }
+    catch {
+        return false;
+    }
+}
+exports.directoryExists = directoryExists;
+/**
+ * Check if a file exists.
+ * @param path Path to file
+ */
+function fileExists(path) {
+    try {
+        return (0, fs_1.statSync)(path).isFile();
+    }
+    catch {
+        return false;
+    }
+}
+exports.fileExists = fileExists;
+function createDirectory(path) {
+    (0, fs_1.mkdirSync)(path, { recursive: true });
+}
+exports.createDirectory = createDirectory;
+function isRelativePath(path) {
+    return (path === '.' ||
+        path === '..' ||
+        path.startsWith('./') ||
+        path.startsWith('../'));
+}
+exports.isRelativePath = isRelativePath;
+/**
+ * Extracts a file from a given tarball to the specified destination.
+ * @param tarballPath The path to the tarball from where the file should be extracted.
+ * @param file The path to the file inside the tarball.
+ * @param destinationFilePath The destination file path.
+ * @returns True if the file was extracted successfully, false otherwise.
+ */
+async function extractFileFromTarball(tarballPath, file, destinationFilePath) {
+    return new Promise((resolve, reject) => {
+        (0, fs_1.mkdirSync)((0, path_1.dirname)(destinationFilePath), { recursive: true });
+        var tarExtractStream = tar.extract();
+        const destinationFileStream = (0, fs_1.createWriteStream)(destinationFilePath);
+        let isFileExtracted = false;
+        tarExtractStream.on('entry', function (header, stream, next) {
+            if (header.name === file) {
+                stream.pipe(destinationFileStream);
+                stream.on('end', () => {
+                    isFileExtracted = true;
+                });
+                destinationFileStream.on('close', () => {
+                    resolve(destinationFilePath);
+                });
+            }
+            stream.on('end', function () {
+                next();
+            });
+            stream.resume();
+        });
+        tarExtractStream.on('finish', function () {
+            if (!isFileExtracted) {
+                reject();
+            }
+        });
+        (0, fs_1.createReadStream)(tarballPath).pipe((0, zlib_1.createGunzip)()).pipe(tarExtractStream);
+    });
+}
+exports.extractFileFromTarball = extractFileFromTarball;
+function readFileIfExisting(path) {
+    return (0, fs_1.existsSync)(path) ? (0, fs_1.readFileSync)(path, 'utf-8') : '';
+}
+exports.readFileIfExisting = readFileIfExisting;
 
 
 /***/ }),
 
-/***/ 75323:
-/***/ ((module) => {
-
-module.exports = eval("require")("@nx/nx-win32-ia32-msvc");
-
-
-/***/ }),
+/***/ 21521:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
-/***/ 37840:
-/***/ ((module) => {
+"use strict";
 
-module.exports = eval("require")("@nx/nx-win32-x64-msvc");
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.getMatchingStringsWithCache = exports.findMatchingProjects = void 0;
+const minimatch_1 = __nccwpck_require__(55224);
+const validPatternTypes = [
+    'name', // Pattern is based on the project's name
+    'tag', // Pattern is based on the project's tags
+    'directory', // Pattern is based on the project's root directory
+    'unlabeled', // Pattern was passed without specifying a type
+];
+const globCharacters = ['*', '|', '{', '}', '(', ')'];
+/**
+ * Find matching project names given a list of potential project names or globs.
+ *
+ * @param patterns A list of project names or globs to match against.
+ * @param projects A map of {@link ProjectGraphProjectNode} by project name.
+ * @returns
+ */
+function findMatchingProjects(patterns = [], projects) {
+    if (!patterns.length || patterns.filter((p) => p.length).length === 0) {
+        return []; // Short circuit if called with no patterns
+    }
+    const projectNames = Object.keys(projects);
+    const matchedProjects = new Set();
+    for (const stringPattern of patterns) {
+        if (!stringPattern.length) {
+            continue;
+        }
+        const pattern = parseStringPattern(stringPattern, projects);
+        // Handle wildcard with short-circuit, as its a common case with potentially
+        // large project sets and we can avoid the more expensive glob matching.
+        if (pattern.value === '*') {
+            for (const projectName of projectNames) {
+                if (pattern.exclude) {
+                    matchedProjects.delete(projectName);
+                }
+                else {
+                    matchedProjects.add(projectName);
+                }
+            }
+            continue;
+        }
+        switch (pattern.type) {
+            case 'tag': {
+                addMatchingProjectsByTag(projectNames, projects, pattern, matchedProjects);
+                continue;
+            }
+            case 'name': {
+                addMatchingProjectsByName(projectNames, projects, pattern, matchedProjects);
+                continue;
+            }
+            case 'directory': {
+                addMatchingProjectsByDirectory(projectNames, projects, pattern, matchedProjects);
+                continue;
+            }
+            // Same thing as `type:unlabeled`. If no specific type is set,
+            // we can waterfall through the different types until we find a match
+            default: {
+                // The size of the selected and excluded projects set, before we
+                // start updating it with this pattern. If the size changes, we
+                // know we found a match and can skip the other types.
+                const originalSize = matchedProjects.size;
+                addMatchingProjectsByName(projectNames, projects, pattern, matchedProjects);
+                if (matchedProjects.size !== originalSize) {
+                    // There was some match by name, don't check other types
+                    continue;
+                }
+                addMatchingProjectsByDirectory(projectNames, projects, pattern, matchedProjects);
+                if (matchedProjects.size !== originalSize) {
+                    // There was some match by directory, don't check other types
+                    // Note - this doesn't do anything currently, but preps for future
+                    // types
+                    continue;
+                }
+            }
+        }
+    }
+    return Array.from(matchedProjects);
+}
+exports.findMatchingProjects = findMatchingProjects;
+function addMatchingProjectsByDirectory(projectNames, projects, pattern, matchedProjects) {
+    for (const projectName of projectNames) {
+        const root = projects[projectName].data.root;
+        if ((0, exports.getMatchingStringsWithCache)(pattern.value, [root]).length > 0) {
+            if (pattern.exclude) {
+                matchedProjects.delete(projectName);
+            }
+            else {
+                matchedProjects.add(projectName);
+            }
+        }
+    }
+}
+function addMatchingProjectsByName(projectNames, projects, pattern, matchedProjects) {
+    if (projects[pattern.value]) {
+        if (pattern.exclude) {
+            matchedProjects.delete(pattern.value);
+        }
+        else {
+            matchedProjects.add(pattern.value);
+        }
+        return;
+    }
+    if (!globCharacters.some((c) => pattern.value.includes(c))) {
+        return;
+    }
+    const matchedProjectNames = (0, exports.getMatchingStringsWithCache)(pattern.value, projectNames);
+    for (const projectName of matchedProjectNames) {
+        if (pattern.exclude) {
+            matchedProjects.delete(projectName);
+        }
+        else {
+            matchedProjects.add(projectName);
+        }
+    }
+}
+function addMatchingProjectsByTag(projectNames, projects, pattern, matchedProjects) {
+    for (const projectName of projectNames) {
+        const tags = projects[projectName].data.tags || [];
+        if (tags.includes(pattern.value)) {
+            if (pattern.exclude) {
+                matchedProjects.delete(projectName);
+            }
+            else {
+                matchedProjects.add(projectName);
+            }
+            continue;
+        }
+        if (!globCharacters.some((c) => pattern.value.includes(c))) {
+            continue;
+        }
+        if ((0, exports.getMatchingStringsWithCache)(pattern.value, tags).length) {
+            if (pattern.exclude) {
+                matchedProjects.delete(projectName);
+            }
+            else {
+                matchedProjects.add(projectName);
+            }
+        }
+    }
+}
+function parseStringPattern(pattern, projects) {
+    const isExclude = pattern.startsWith('!');
+    // Support for things like: `!{type}:value`
+    if (isExclude) {
+        pattern = pattern.substring(1);
+    }
+    const indexOfFirstPotentialSeparator = pattern.indexOf(':');
+    // There is a project that matches directly
+    if (projects[pattern]) {
+        return { type: 'name', value: pattern, exclude: isExclude };
+        // The pattern does not contain a label
+    }
+    else if (indexOfFirstPotentialSeparator === -1) {
+        return { type: 'unlabeled', value: pattern, exclude: isExclude };
+        // The pattern may contain a label
+    }
+    else {
+        const potentialType = pattern.substring(0, indexOfFirstPotentialSeparator);
+        return {
+            type: isValidPatternType(potentialType) ? potentialType : 'unlabeled',
+            value: pattern.substring(indexOfFirstPotentialSeparator + 1),
+            exclude: isExclude,
+        };
+    }
+}
+function isValidPatternType(type) {
+    return validPatternTypes.includes(type);
+}
+exports.getMatchingStringsWithCache = (() => {
+    // Map< Pattern, Map< Item, Result >>
+    const minimatchCache = new Map();
+    const regexCache = new Map();
+    return (pattern, items) => {
+        if (!minimatchCache.has(pattern)) {
+            minimatchCache.set(pattern, new Map());
+        }
+        const patternCache = minimatchCache.get(pattern);
+        if (!regexCache.has(pattern)) {
+            const regex = minimatch_1.minimatch.makeRe(pattern, { dot: true });
+            if (regex) {
+                regexCache.set(pattern, regex);
+            }
+            else {
+                throw new Error('Invalid glob pattern ' + pattern);
+            }
+        }
+        const matcher = regexCache.get(pattern);
+        return items.filter((item) => {
+            let entry = patternCache.get(item);
+            if (entry === undefined || entry === null) {
+                entry = item === pattern ? true : matcher.test(item);
+                patternCache.set(item, entry);
+            }
+            return entry;
+        });
+    };
+})();
 
 
 /***/ }),
 
-/***/ 39423:
-/***/ ((module) => {
-
-module.exports = eval("require")("@swc/core-android-arm-eabi");
-
-
-/***/ }),
+/***/ 94865:
+/***/ ((__unused_webpack_module, exports) => {
 
-/***/ 95833:
-/***/ ((module) => {
+"use strict";
 
-module.exports = eval("require")("@swc/core-android-arm64");
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.combineGlobPatterns = void 0;
+function combineGlobPatterns(...patterns) {
+    const p = patterns.flat();
+    return p.length > 1 ? '{' + p.join(',') + '}' : p.length === 1 ? p[0] : '';
+}
+exports.combineGlobPatterns = combineGlobPatterns;
 
 
 /***/ }),
 
-/***/ 5829:
-/***/ ((module) => {
+/***/ 77098:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
-module.exports = eval("require")("@swc/core-darwin-x64");
+"use strict";
+
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.getIgnoreObject = exports.getAlwaysIgnore = exports.getIgnoredGlobs = exports.ALWAYS_IGNORE = void 0;
+const fs_extra_1 = __nccwpck_require__(27475);
+const ignore_1 = __nccwpck_require__(56508);
+const fileutils_1 = __nccwpck_require__(83851);
+const path_1 = __nccwpck_require__(38270);
+const workspace_root_1 = __nccwpck_require__(86708);
+/**
+ * An array of glob patterns that should always be ignored.
+ */
+exports.ALWAYS_IGNORE = getAlwaysIgnore();
+function getIgnoredGlobs(root = workspace_root_1.workspaceRoot, prependRoot = true) {
+    const files = ['.gitignore', '.nxignore'];
+    if (prependRoot) {
+        return [
+            ...getAlwaysIgnore(root),
+            ...files.flatMap((f) => getIgnoredGlobsFromFile((0, path_1.joinPathFragments)(root, f), root)),
+        ];
+    }
+    else {
+        return [
+            ...getAlwaysIgnore(),
+            ...files.flatMap((f) => getIgnoredGlobsFromFile((0, path_1.joinPathFragments)(root, f))),
+        ];
+    }
+}
+exports.getIgnoredGlobs = getIgnoredGlobs;
+function getAlwaysIgnore(root) {
+    const paths = ['node_modules', '**/node_modules', '.git'];
+    return root ? paths.map((x) => (0, path_1.joinPathFragments)(root, x)) : paths;
+}
+exports.getAlwaysIgnore = getAlwaysIgnore;
+function getIgnoreObject(root = workspace_root_1.workspaceRoot) {
+    const ig = (0, ignore_1.default)();
+    ig.add((0, fileutils_1.readFileIfExisting)(`${root}/.gitignore`));
+    ig.add((0, fileutils_1.readFileIfExisting)(`${root}/.nxignore`));
+    return ig;
+}
+exports.getIgnoreObject = getIgnoreObject;
+function getIgnoredGlobsFromFile(file, root) {
+    try {
+        const results = [];
+        const contents = (0, fs_extra_1.readFileSync)(file, 'utf-8');
+        const lines = contents.split('\n');
+        for (const line of lines) {
+            const trimmed = line.trim();
+            if (!trimmed || trimmed.startsWith('#')) {
+                continue;
+            }
+            else if (trimmed.startsWith('/')) {
+                if (root) {
+                    results.push((0, path_1.joinPathFragments)(root, trimmed));
+                }
+                else {
+                    results.push((0, path_1.joinPathFragments)('.', trimmed));
+                }
+            }
+            else {
+                results.push(trimmed);
+            }
+        }
+        return results;
+    }
+    catch (e) {
+        return [];
+    }
+}
 
 
 /***/ }),
 
-/***/ 95212:
-/***/ ((module) => {
+/***/ 98584:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
-module.exports = eval("require")("@swc/core-freebsd-x64");
+"use strict";
+
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.getNxRequirePaths = exports.getNxInstallationPath = void 0;
+const path_1 = __nccwpck_require__(71017);
+const workspace_root_1 = __nccwpck_require__(86708);
+function getNxInstallationPath(root = workspace_root_1.workspaceRoot) {
+    return (0, path_1.join)(root, '.nx', 'installation');
+}
+exports.getNxInstallationPath = getNxInstallationPath;
+function getNxRequirePaths(root = workspace_root_1.workspaceRoot) {
+    return [root, getNxInstallationPath(root)];
+}
+exports.getNxRequirePaths = getNxRequirePaths;
 
 
 /***/ }),
 
-/***/ 70593:
-/***/ ((module) => {
+/***/ 15284:
+/***/ ((__unused_webpack_module, exports) => {
 
-module.exports = eval("require")("@swc/core-linux-arm-gnueabihf");
+"use strict";
+
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.isCI = void 0;
+function isCI() {
+    return (process.env.CI === 'true' ||
+        process.env.TF_BUILD === 'true' ||
+        process.env.GITHUB_ACTIONS === 'true' ||
+        process.env.BUILDKITE === 'true' ||
+        process.env.CIRCLECI === 'true' ||
+        process.env.CIRRUS_CI === 'true' ||
+        process.env.TRAVIS === 'true' ||
+        !!process.env['bamboo.buildKey'] ||
+        !!process.env.CODEBUILD_BUILD_ID ||
+        !!process.env.GITLAB_CI ||
+        !!process.env.HEROKU_TEST_RUN_ID ||
+        !!process.env.BUILD_ID ||
+        !!process.env.BUILD_BUILDID ||
+        !!process.env.TEAMCITY_VERSION);
+}
+exports.isCI = isCI;
 
 
 /***/ }),
 
-/***/ 25670:
-/***/ ((module) => {
+/***/ 72517:
+/***/ ((__unused_webpack_module, exports) => {
 
-module.exports = eval("require")("@swc/core-linux-arm64-gnu");
+"use strict";
+
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.deepEquals = exports.walkJsonTree = exports.jsonDiff = exports.isJsonChange = exports.JsonDiffType = void 0;
+var JsonDiffType;
+(function (JsonDiffType) {
+    JsonDiffType["Deleted"] = "JsonPropertyDeleted";
+    JsonDiffType["Added"] = "JsonPropertyAdded";
+    JsonDiffType["Modified"] = "JsonPropertyModified";
+})(JsonDiffType || (exports.JsonDiffType = JsonDiffType = {}));
+function isJsonChange(change) {
+    return (change.type === JsonDiffType.Added ||
+        change.type === JsonDiffType.Deleted ||
+        change.type === JsonDiffType.Modified);
+}
+exports.isJsonChange = isJsonChange;
+function jsonDiff(lhs, rhs) {
+    const result = [];
+    const seenInLhs = new Set();
+    walkJsonTree(lhs, [], (path, lhsValue) => {
+        seenInLhs.add(hashArray(path));
+        const rhsValue = getJsonValue(path, rhs);
+        if (rhsValue === undefined) {
+            result.push({
+                type: JsonDiffType.Deleted,
+                path,
+                value: {
+                    lhs: lhsValue,
+                    rhs: undefined,
+                },
+            });
+        }
+        else if (!deepEquals(lhsValue, rhsValue)) {
+            result.push({
+                type: JsonDiffType.Modified,
+                path,
+                value: {
+                    lhs: lhsValue,
+                    rhs: rhsValue,
+                },
+            });
+        }
+        return typeof lhsValue === 'object' || Array.isArray(lhsValue);
+    });
+    walkJsonTree(rhs, [], (path, rhsValue) => {
+        const addedInRhs = !seenInLhs.has(hashArray(path));
+        if (addedInRhs) {
+            result.push({
+                type: JsonDiffType.Added,
+                path,
+                value: {
+                    lhs: undefined,
+                    rhs: rhsValue,
+                },
+            });
+        }
+        return typeof rhsValue === 'object' || Array.isArray(rhsValue);
+    });
+    return result;
+}
+exports.jsonDiff = jsonDiff;
+// Depth-first walk down JSON tree.
+function walkJsonTree(json, currPath, visitor) {
+    if (!json || typeof json !== 'object') {
+        return;
+    }
+    Object.keys(json).forEach((key) => {
+        const path = currPath.concat([key]);
+        const shouldContinue = visitor(path, json[key]);
+        if (shouldContinue) {
+            walkJsonTree(json[key], path, visitor);
+        }
+    });
+}
+exports.walkJsonTree = walkJsonTree;
+function hashArray(ary) {
+    return JSON.stringify(ary);
+}
+function getJsonValue(path, json) {
+    let curr = json;
+    for (const k of path) {
+        curr = curr[k];
+        if (curr === undefined) {
+            break;
+        }
+    }
+    return curr;
+}
+function deepEquals(a, b) {
+    if (a === b) {
+        return true;
+    }
+    // Values do not need to be checked for deep equality and the above is false
+    if (
+    // Values are different types
+    typeof a !== typeof b ||
+        // Values are the same type but not an object or array
+        (typeof a !== 'object' && !Array.isArray(a)) ||
+        // Objects are the same type, objects or arrays, but do not have the same number of keys
+        Object.keys(a).length !== Object.keys(b).length) {
+        return false;
+    }
+    // Values need to be checked for deep equality
+    return Object.entries(a).reduce((equal, [key, aValue]) => {
+        // Skip other keys if it is already not equal.
+        if (!equal) {
+            return equal;
+        }
+        // Traverse the object
+        return deepEquals(aValue, b[key]);
+    }, true);
+}
+exports.deepEquals = deepEquals;
 
 
 /***/ }),
 
-/***/ 79914:
-/***/ ((module) => {
+/***/ 8314:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
-module.exports = eval("require")("@swc/core-linux-arm64-musl");
+"use strict";
+
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.serializeJson = exports.parseJson = exports.stripJsonComments = void 0;
+const jsonc_parser_1 = __nccwpck_require__(18875);
+Object.defineProperty(exports, "stripJsonComments", ({ enumerable: true, get: function () { return jsonc_parser_1.stripComments; } }));
+const lines_and_columns_1 = __nccwpck_require__(16106);
+const code_frames_1 = __nccwpck_require__(24622);
+/**
+ * Parses the given JSON string and returns the object the JSON content represents.
+ * By default javascript-style comments and trailing commas are allowed.
+ *
+ * @param input JSON content as string
+ * @param options JSON parse options
+ * @returns Object the JSON content represents
+ */
+function parseJson(input, options) {
+    try {
+        return JSON.parse(input);
+    }
+    catch { }
+    options = { allowTrailingComma: true, ...options };
+    const errors = [];
+    const result = (0, jsonc_parser_1.parse)(input, errors, options);
+    if (errors.length > 0) {
+        throw new Error(formatParseError(input, errors[0]));
+    }
+    return result;
+}
+exports.parseJson = parseJson;
+/**
+ * Nicely formats a JSON error with context
+ *
+ * @param input JSON content as string
+ * @param parseError jsonc ParseError
+ * @returns
+ */
+function formatParseError(input, parseError) {
+    const { error, offset, length } = parseError;
+    let { line, column } = new lines_and_columns_1.LinesAndColumns(input).locationForIndex(offset);
+    line++;
+    column++;
+    return (`${(0, jsonc_parser_1.printParseErrorCode)(error)} in JSON at ${line}:${column}\n` +
+        (0, code_frames_1.codeFrameColumns)(input, {
+            start: { line, column },
+            end: { line, column: column + length },
+        }) +
+        '\n');
+}
+/**
+ * Serializes the given data to a JSON string.
+ * By default the JSON string is formatted with a 2 space indentation to be easy readable.
+ *
+ * @param input Object which should be serialized to JSON
+ * @param options JSON serialize options
+ * @returns the formatted JSON representation of the object
+ */
+function serializeJson(input, options) {
+    return JSON.stringify(input, null, options?.spaces ?? 2) + '\n';
+}
+exports.serializeJson = serializeJson;
 
 
 /***/ }),
 
-/***/ 47663:
-/***/ ((module) => {
+/***/ 39299:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
-module.exports = eval("require")("@swc/core-linux-x64-gnu");
+"use strict";
+
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.stripIndent = exports.logger = exports.NX_ERROR = exports.NX_PREFIX = void 0;
+const chalk = __nccwpck_require__(36662);
+exports.NX_PREFIX = `${chalk.cyan('>')} ${chalk.inverse(chalk.bold(chalk.cyan(' NX ')))}`;
+exports.NX_ERROR = chalk.inverse(chalk.bold(chalk.red(' ERROR ')));
+exports.logger = {
+    warn: (s) => console.warn(chalk.bold(chalk.yellow(s))),
+    error: (s) => {
+        if (typeof s === 'string' && s.startsWith('NX ')) {
+            console.error(`\n${exports.NX_ERROR} ${chalk.bold(chalk.red(s.slice(3)))}\n`);
+        }
+        else if (s instanceof Error && s.stack) {
+            console.error(chalk.bold(chalk.red(s.stack)));
+        }
+        else {
+            console.error(chalk.bold(chalk.red(s)));
+        }
+    },
+    info: (s) => {
+        if (typeof s === 'string' && s.startsWith('NX ')) {
+            console.info(`\n${exports.NX_PREFIX} ${chalk.bold(s.slice(3))}\n`);
+        }
+        else {
+            console.info(s);
+        }
+    },
+    log: (...s) => {
+        console.log(...s);
+    },
+    debug: (...s) => {
+        console.debug(...s);
+    },
+    fatal: (...s) => {
+        console.error(...s);
+    },
+};
+function stripIndent(str) {
+    const match = str.match(/^[ \t]*(?=\S)/gm);
+    if (!match) {
+        return str;
+    }
+    const indent = match.reduce((r, a) => Math.min(r, a.length), Infinity);
+    const regex = new RegExp(`^[ \\t]{${indent}}`, 'gm');
+    return str.replace(regex, '');
+}
+exports.stripIndent = stripIndent;
 
 
 /***/ }),
 
-/***/ 35887:
-/***/ ((module) => {
+/***/ 32256:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
-module.exports = eval("require")("@swc/core-linux-x64-musl");
+"use strict";
+
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.getDefaultPluginsSync = void 0;
+const angular_json_1 = __nccwpck_require__(44050);
+const project_json_1 = __nccwpck_require__(76877);
+const target_defaults_plugin_1 = __nccwpck_require__(50280);
+const package_json_workspaces_1 = __nccwpck_require__(65286);
+/**
+ * @todo(@agentender) v19: Remove this fn when we remove readWorkspaceConfig
+ */
+function getDefaultPluginsSync(root) {
+    const plugins = [
+        __nccwpck_require__(17797),
+        ...((0, angular_json_1.shouldMergeAngularProjects)(root, false)
+            ? [(__nccwpck_require__(44050).NxAngularJsonPlugin)]
+            : []),
+        target_defaults_plugin_1.TargetDefaultsPlugin,
+        (0, package_json_workspaces_1.getNxPackageJsonWorkspacesPlugin)(root),
+        project_json_1.ProjectJsonProjectsPlugin,
+    ];
+    return plugins.map((p) => ({
+        plugin: p,
+    }));
+}
+exports.getDefaultPluginsSync = getDefaultPluginsSync;
 
 
 /***/ }),
 
-/***/ 89962:
-/***/ ((module) => {
+/***/ 84141:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
-module.exports = eval("require")("@swc/core-win32-arm64-msvc");
+"use strict";
+
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.getDefaultPlugins = exports.unregisterPluginTSTranspiler = exports.registerPluginTSTranspiler = exports.resolveLocalNxPlugin = exports.readPluginPackageJson = exports.isNxPluginV1 = exports.isNxPluginV2 = exports.ensurePluginIsV2 = exports.loadNxPlugins = exports.loadNxPluginAsync = exports.getPluginPathAndName = exports.nxPluginCache = void 0;
+const tslib_1 = __nccwpck_require__(57265);
+const fs_1 = __nccwpck_require__(57147);
+const path = __nccwpck_require__(71017);
+const workspaces_1 = __nccwpck_require__(26546);
+const workspace_root_1 = __nccwpck_require__(86708);
+const fileutils_1 = __nccwpck_require__(83851);
+const package_json_1 = __nccwpck_require__(4014);
+const register_1 = __nccwpck_require__(44321);
+const logger_1 = __nccwpck_require__(39299);
+const find_project_for_path_1 = __nccwpck_require__(46329);
+const path_1 = __nccwpck_require__(38270);
+const path_2 = __nccwpck_require__(71017);
+const installation_directory_1 = __nccwpck_require__(98584);
+const typescript_1 = __nccwpck_require__(37650);
+const nx_json_1 = __nccwpck_require__(53619);
+const globs_1 = __nccwpck_require__(94865);
+const angular_json_1 = __nccwpck_require__(44050);
+const package_json_workspaces_1 = __nccwpck_require__(65286);
+const project_json_1 = __nccwpck_require__(76877);
+const package_json_next_to_project_json_1 = __nccwpck_require__(1215);
+const retrieve_workspace_files_1 = __nccwpck_require__(14249);
+const target_defaults_plugin_1 = __nccwpck_require__(50280);
+tslib_1.__exportStar(__nccwpck_require__(32256), exports);
+// Short lived cache (cleared between cmd runs)
+// holding resolved nx plugin objects.
+// Allows loadNxPlugins to be called multiple times w/o
+// executing resolution mulitple times.
+exports.nxPluginCache = new Map();
+function getPluginPathAndName(moduleName, paths, projects, root) {
+    let pluginPath;
+    try {
+        pluginPath = __nccwpck_require__(72939).resolve(moduleName, {
+            paths,
+        });
+    }
+    catch (e) {
+        if (e.code === 'MODULE_NOT_FOUND') {
+            const plugin = resolveLocalNxPlugin(moduleName, (0, nx_json_1.readNxJson)(root), projects, root);
+            if (plugin) {
+                const main = readPluginMainFromProjectConfiguration(plugin.projectConfig);
+                pluginPath = main ? path.join(root, main) : plugin.path;
+            }
+            else {
+                logger_1.logger.error(`Plugin listed in \`nx.json\` not found: ${moduleName}`);
+                throw e;
+            }
+        }
+        else {
+            throw e;
+        }
+    }
+    const packageJsonPath = path.join(pluginPath, 'package.json');
+    const extension = path.extname(pluginPath);
+    // Register the ts-transpiler if we are pointing to a
+    // plain ts file that's not part of a plugin project
+    if (extension === '.ts' && !tsNodeAndPathsUnregisterCallback) {
+        registerPluginTSTranspiler();
+    }
+    const { name } = !['.ts', '.js'].some((x) => x === extension) && // Not trying to point to a ts or js file
+        (0, fs_1.existsSync)(packageJsonPath) // plugin has a package.json
+        ? (0, fileutils_1.readJsonFile)(packageJsonPath) // read name from package.json
+        : { name: moduleName };
+    return { pluginPath, name };
+}
+exports.getPluginPathAndName = getPluginPathAndName;
+async function loadNxPluginAsync(pluginConfiguration, paths, projects, root) {
+    const { plugin: moduleName, options } = typeof pluginConfiguration === 'object'
+        ? pluginConfiguration
+        : { plugin: pluginConfiguration, options: undefined };
+    let pluginModule = exports.nxPluginCache.get(moduleName);
+    if (pluginModule) {
+        return { plugin: pluginModule, options };
+    }
+    performance.mark(`Load Nx Plugin: ${moduleName} - start`);
+    let { pluginPath, name } = await getPluginPathAndName(moduleName, paths, projects, root);
+    const plugin = ensurePluginIsV2((await Promise.resolve(`${pluginPath}`).then(s => __nccwpck_require__(72939)(s))));
+    plugin.name ??= name;
+    exports.nxPluginCache.set(moduleName, plugin);
+    performance.mark(`Load Nx Plugin: ${moduleName} - end`);
+    performance.measure(`Load Nx Plugin: ${moduleName}`, `Load Nx Plugin: ${moduleName} - start`, `Load Nx Plugin: ${moduleName} - end`);
+    return { plugin, options };
+}
+exports.loadNxPluginAsync = loadNxPluginAsync;
+async function loadNxPlugins(plugins, paths = (0, installation_directory_1.getNxRequirePaths)(), root = workspace_root_1.workspaceRoot, projects) {
+    const result = [
+        { plugin: package_json_next_to_project_json_1.PackageJsonProjectsNextToProjectJsonPlugin },
+    ];
+    plugins ??= [];
+    // When loading plugins for `createNodes`, we don't know what projects exist yet.
+    // Try resolving plugins
+    for (const plugin of plugins) {
+        try {
+            /*require.resolve*/(typeof plugin === 'string' ? __nccwpck_require__(72939).resolve(plugin) : __nccwpck_require__(72939).resolve(plugin.plugin));
+        }
+        catch {
+            // If a plugin cannot be resolved, we will need projects to resolve it
+            projects ??= await (0, retrieve_workspace_files_1.retrieveProjectConfigurationsWithoutPluginInference)(root);
+            break;
+        }
+    }
+    for (const plugin of plugins) {
+        result.push(await loadNxPluginAsync(plugin, paths, projects, root));
+    }
+    // We push the nx core node plugins onto the end, s.t. it overwrites any other plugins
+    result.push(...(await getDefaultPlugins(root)));
+    return result;
+}
+exports.loadNxPlugins = loadNxPlugins;
+function ensurePluginIsV2(plugin) {
+    if (isNxPluginV2(plugin)) {
+        return plugin;
+    }
+    if (isNxPluginV1(plugin) && plugin.projectFilePatterns) {
+        return {
+            ...plugin,
+            createNodes: [
+                `*/**/${(0, globs_1.combineGlobPatterns)(plugin.projectFilePatterns)}`,
+                (configFilePath) => {
+                    const root = (0, path_2.dirname)(configFilePath);
+                    return {
+                        projects: {
+                            [root]: {
+                                name: (0, workspaces_1.toProjectName)(configFilePath),
+                                root,
+                                targets: plugin.registerProjectTargets?.(configFilePath),
+                            },
+                        },
+                    };
+                },
+            ],
+        };
+    }
+    return plugin;
+}
+exports.ensurePluginIsV2 = ensurePluginIsV2;
+function isNxPluginV2(plugin) {
+    return 'createNodes' in plugin || 'createDependencies' in plugin;
+}
+exports.isNxPluginV2 = isNxPluginV2;
+function isNxPluginV1(plugin) {
+    return 'processProjectGraph' in plugin || 'projectFilePatterns' in plugin;
+}
+exports.isNxPluginV1 = isNxPluginV1;
+function readPluginPackageJson(pluginName, projects, paths = (0, installation_directory_1.getNxRequirePaths)()) {
+    try {
+        const result = (0, package_json_1.readModulePackageJsonWithoutFallbacks)(pluginName, paths);
+        return {
+            json: result.packageJson,
+            path: result.path,
+        };
+    }
+    catch (e) {
+        if (e.code === 'MODULE_NOT_FOUND') {
+            const nxJson = (0, nx_json_1.readNxJson)();
+            const localPluginPath = resolveLocalNxPlugin(pluginName, nxJson, projects);
+            if (localPluginPath) {
+                const localPluginPackageJson = path.join(localPluginPath.path, 'package.json');
+                return {
+                    path: localPluginPackageJson,
+                    json: (0, fileutils_1.readJsonFile)(localPluginPackageJson),
+                };
+            }
+        }
+        throw e;
+    }
+}
+exports.readPluginPackageJson = readPluginPackageJson;
+/**
+ * Builds a plugin package and returns the path to output
+ * @param importPath What is the import path that refers to a potential plugin?
+ * @returns The path to the built plugin, or null if it doesn't exist
+ */
+const localPluginCache = {};
+function resolveLocalNxPlugin(importPath, nxJsonConfiguration, projects, root = workspace_root_1.workspaceRoot) {
+    localPluginCache[importPath] ??= lookupLocalPlugin(importPath, nxJsonConfiguration, projects, root);
+    return localPluginCache[importPath];
+}
+exports.resolveLocalNxPlugin = resolveLocalNxPlugin;
+let tsNodeAndPathsUnregisterCallback = undefined;
+/**
+ * Register swc-node or ts-node if they are not currently registered
+ * with some default settings which work well for Nx plugins.
+ */
+function registerPluginTSTranspiler() {
+    if (!tsNodeAndPathsUnregisterCallback) {
+        // nx-ignore-next-line
+        const ts = __nccwpck_require__(81151);
+        // Get the first tsconfig that matches the allowed set
+        const tsConfigName = [
+            (0, path_2.join)(workspace_root_1.workspaceRoot, 'tsconfig.base.json'),
+            (0, path_2.join)(workspace_root_1.workspaceRoot, 'tsconfig.json'),
+        ].find((x) => (0, fs_1.existsSync)(x));
+        const tsConfig = tsConfigName
+            ? (0, typescript_1.readTsConfig)(tsConfigName)
+            : {};
+        const unregisterTsConfigPaths = (0, register_1.registerTsConfigPaths)(tsConfigName);
+        const unregisterTranspiler = (0, register_1.registerTranspiler)({
+            experimentalDecorators: true,
+            emitDecoratorMetadata: true,
+            ...tsConfig.options,
+        });
+        tsNodeAndPathsUnregisterCallback = () => {
+            unregisterTsConfigPaths();
+            unregisterTranspiler();
+        };
+    }
+}
+exports.registerPluginTSTranspiler = registerPluginTSTranspiler;
+/**
+ * Unregister the ts-node transpiler if it is registered
+ */
+function unregisterPluginTSTranspiler() {
+    if (tsNodeAndPathsUnregisterCallback) {
+        tsNodeAndPathsUnregisterCallback();
+        tsNodeAndPathsUnregisterCallback = undefined;
+    }
+}
+exports.unregisterPluginTSTranspiler = unregisterPluginTSTranspiler;
+function lookupLocalPlugin(importPath, nxJsonConfiguration, projects, root = workspace_root_1.workspaceRoot) {
+    const plugin = findNxProjectForImportPath(importPath, projects, root);
+    if (!plugin) {
+        return null;
+    }
+    if (!tsNodeAndPathsUnregisterCallback) {
+        registerPluginTSTranspiler();
+    }
+    const projectConfig = projects[plugin];
+    return { path: path.join(root, projectConfig.root), projectConfig };
+}
+function findNxProjectForImportPath(importPath, projects, root = workspace_root_1.workspaceRoot) {
+    const tsConfigPaths = readTsConfigPaths(root);
+    const possiblePaths = tsConfigPaths[importPath]?.map((p) => (0, path_1.normalizePath)(path.relative(root, path.join(root, p))));
+    if (possiblePaths?.length) {
+        const projectRootMappings = (0, find_project_for_path_1.createProjectRootMappingsFromProjectConfigurations)(projects);
+        for (const tsConfigPath of possiblePaths) {
+            const nxProject = (0, find_project_for_path_1.findProjectForPath)(tsConfigPath, projectRootMappings);
+            if (nxProject) {
+                return nxProject;
+            }
+        }
+        if (process.env.NX_VERBOSE_LOGGING) {
+            console.log('Unable to find local plugin', possiblePaths, projectRootMappings);
+        }
+        throw new Error('Unable to resolve local plugin with import path ' + importPath);
+    }
+}
+let tsconfigPaths;
+function readTsConfigPaths(root = workspace_root_1.workspaceRoot) {
+    if (!tsconfigPaths) {
+        const tsconfigPath = ['tsconfig.base.json', 'tsconfig.json']
+            .map((x) => path.join(root, x))
+            .filter((x) => (0, fs_1.existsSync)(x))[0];
+        if (!tsconfigPath) {
+            throw new Error('unable to find tsconfig.base.json or tsconfig.json');
+        }
+        const { compilerOptions } = (0, fileutils_1.readJsonFile)(tsconfigPath);
+        tsconfigPaths = compilerOptions?.paths;
+    }
+    return tsconfigPaths ?? {};
+}
+function readPluginMainFromProjectConfiguration(plugin) {
+    const { main } = Object.values(plugin.targets).find((x) => [
+        '@nx/js:tsc',
+        '@nrwl/js:tsc',
+        '@nx/js:swc',
+        '@nrwl/js:swc',
+        '@nx/node:package',
+        '@nrwl/node:package',
+    ].includes(x.executor))?.options ||
+        plugin.targets?.build?.options ||
+        {};
+    return main;
+}
+async function getDefaultPlugins(root) {
+    const plugins = [
+        await Promise.resolve().then(() => __nccwpck_require__(17797)),
+        target_defaults_plugin_1.TargetDefaultsPlugin,
+        ...((0, angular_json_1.shouldMergeAngularProjects)(root, false)
+            ? [
+                await Promise.resolve().then(() => __nccwpck_require__(44050)).then((m) => m.NxAngularJsonPlugin),
+            ]
+            : []),
+        (0, package_json_workspaces_1.getNxPackageJsonWorkspacesPlugin)(root),
+        project_json_1.ProjectJsonProjectsPlugin,
+    ];
+    return plugins.map((p) => ({
+        plugin: p,
+    }));
+}
+exports.getDefaultPlugins = getDefaultPlugins;
 
 
 /***/ }),
 
-/***/ 48333:
-/***/ ((module) => {
+/***/ 84110:
+/***/ ((__unused_webpack_module, exports) => {
 
-module.exports = eval("require")("@swc/core-win32-ia32-msvc");
+"use strict";
+
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.sortObjectByKeys = void 0;
+function sortObjectByKeys(originalObject) {
+    const keys = Object.keys(originalObject).sort();
+    const sortedObject = {};
+    keys.forEach((key) => (sortedObject[key] = originalObject[key]));
+    return sortedObject;
+}
+exports.sortObjectByKeys = sortObjectByKeys;
 
 
 /***/ }),
 
-/***/ 20250:
-/***/ ((module) => {
+/***/ 1737:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
-module.exports = eval("require")("@swc/core-win32-x64-msvc");
+"use strict";
+
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.output = void 0;
+const chalk = __nccwpck_require__(36662);
+const os_1 = __nccwpck_require__(22037);
+const readline = __nccwpck_require__(14521);
+const is_ci_1 = __nccwpck_require__(15284);
+const GH_GROUP_PREFIX = '::group::';
+const GH_GROUP_SUFFIX = '::endgroup::';
+/**
+ * Automatically disable styling applied by chalk if CI=true
+ */
+const forceColor = process.env.FORCE_COLOR === '' || process.env.FORCE_COLOR === 'true';
+if ((0, is_ci_1.isCI)() && !forceColor) {
+    chalk.level = 0;
+}
+class CLIOutput {
+    constructor() {
+        this.X_PADDING = ' ';
+        this.cliName = 'NX';
+        this.formatCommand = (taskId) => `${chalk.dim('nx run')} ${taskId}`;
+        /**
+         * Expose some color and other utility functions so that other parts of the codebase that need
+         * more fine-grained control of message bodies are still using a centralized
+         * implementation.
+         */
+        this.colors = {
+            gray: chalk.gray,
+            green: chalk.green,
+            red: chalk.red,
+            cyan: chalk.cyan,
+            white: chalk.white,
+        };
+        this.bold = chalk.bold;
+        this.underline = chalk.underline;
+        this.dim = chalk.dim;
+    }
+    /**
+     * Longer dash character which forms more of a continuous line when place side to side
+     * with itself, unlike the standard dash character
+     */
+    get VERTICAL_SEPARATOR() {
+        let divider = '';
+        for (let i = 0; i < process.stdout.columns - this.X_PADDING.length * 2; i++) {
+            divider += '\u2014';
+        }
+        return divider;
+    }
+    writeToStdOut(str) {
+        process.stdout.write(str);
+    }
+    overwriteLine(lineText = '') {
+        // this replaces the existing text up to the new line length
+        process.stdout.write(lineText);
+        // clear whatever text might be left to the right of the cursor (happens
+        // when existing text was longer than new one)
+        readline.clearLine(process.stdout, 1);
+        process.stdout.write(os_1.EOL);
+    }
+    writeOutputTitle({ color, title, }) {
+        this.writeToStdOut(` ${this.applyNxPrefix(color, title)}${os_1.EOL}`);
+    }
+    writeOptionalOutputBody(bodyLines) {
+        if (!bodyLines) {
+            return;
+        }
+        this.addNewline();
+        bodyLines.forEach((bodyLine) => this.writeToStdOut(`   ${bodyLine}${os_1.EOL}`));
+    }
+    applyNxPrefix(color = 'cyan', text) {
+        let nxPrefix = '';
+        if (chalk[color]) {
+            nxPrefix = `${chalk[color]('>')} ${chalk.reset.inverse.bold[color](` ${this.cliName} `)}`;
+        }
+        else {
+            nxPrefix = `${chalk.keyword(color)('>')} ${chalk.reset.inverse.bold.keyword(color)(` ${this.cliName} `)}`;
+        }
+        return `${nxPrefix}  ${text}`;
+    }
+    addNewline() {
+        this.writeToStdOut(os_1.EOL);
+    }
+    addVerticalSeparator(color = 'gray') {
+        this.addNewline();
+        this.addVerticalSeparatorWithoutNewLines(color);
+        this.addNewline();
+    }
+    addVerticalSeparatorWithoutNewLines(color = 'gray') {
+        this.writeToStdOut(`${this.getVerticalSeparator(color)}${os_1.EOL}`);
+    }
+    getVerticalSeparatorLines(color = 'gray') {
+        return ['', this.getVerticalSeparator(color), ''];
+    }
+    getVerticalSeparator(color) {
+        return `${this.X_PADDING}${chalk.dim[color](this.VERTICAL_SEPARATOR)}`;
+    }
+    error({ title, slug, bodyLines }) {
+        this.addNewline();
+        this.writeOutputTitle({
+            color: 'red',
+            title: chalk.red(title),
+        });
+        this.writeOptionalOutputBody(bodyLines);
+        /**
+         * Optional slug to be used in an Nx error message redirect URL
+         */
+        if (slug && typeof slug === 'string') {
+            this.addNewline();
+            this.writeToStdOut(`${chalk.grey('  Learn more about this error: ')}https://errors.nx.dev/${slug}${os_1.EOL}`);
+        }
+        this.addNewline();
+    }
+    warn({ title, slug, bodyLines }) {
+        this.addNewline();
+        this.writeOutputTitle({
+            color: 'yellow',
+            title: chalk.yellow(title),
+        });
+        this.writeOptionalOutputBody(bodyLines);
+        /**
+         * Optional slug to be used in an Nx warning message redirect URL
+         */
+        if (slug && typeof slug === 'string') {
+            this.addNewline();
+            this.writeToStdOut(`${chalk.grey('  Learn more about this warning: ')}https://errors.nx.dev/${slug}${os_1.EOL}`);
+        }
+        this.addNewline();
+    }
+    note({ title, bodyLines }) {
+        this.addNewline();
+        this.writeOutputTitle({
+            color: 'orange',
+            title: chalk.keyword('orange')(title),
+        });
+        this.writeOptionalOutputBody(bodyLines);
+        this.addNewline();
+    }
+    success({ title, bodyLines }) {
+        this.addNewline();
+        this.writeOutputTitle({
+            color: 'green',
+            title: chalk.green(title),
+        });
+        this.writeOptionalOutputBody(bodyLines);
+        this.addNewline();
+    }
+    logSingleLine(message) {
+        this.addNewline();
+        this.writeOutputTitle({
+            color: 'gray',
+            title: message,
+        });
+        this.addNewline();
+    }
+    logCommand(message, taskStatus) {
+        this.addNewline();
+        this.writeToStdOut(this.getCommandWithStatus(message, taskStatus));
+        this.addNewline();
+        this.addNewline();
+    }
+    logCommandOutput(message, taskStatus, output) {
+        let commandOutputWithStatus = this.getCommandWithStatus(message, taskStatus);
+        if (process.env.GITHUB_ACTIONS) {
+            const icon = this.getStatusIcon(taskStatus);
+            commandOutputWithStatus = `${GH_GROUP_PREFIX}${icon} ${commandOutputWithStatus}`;
+        }
+        this.addNewline();
+        this.writeToStdOut(commandOutputWithStatus);
+        this.addNewline();
+        this.addNewline();
+        this.writeToStdOut(output);
+        if (process.env.GITHUB_ACTIONS) {
+            this.writeToStdOut(GH_GROUP_SUFFIX);
+        }
+    }
+    getCommandWithStatus(message, taskStatus) {
+        const commandOutput = chalk.dim('> ') + this.formatCommand(this.normalizeMessage(message));
+        return this.addTaskStatus(taskStatus, commandOutput);
+    }
+    getStatusIcon(taskStatus) {
+        switch (taskStatus) {
+            case 'success':
+                return '✔️';
+            case 'failure':
+                return '❌';
+            case 'skipped':
+            case 'local-cache-kept-existing':
+                return '⏩';
+            case 'local-cache':
+            case 'remote-cache':
+                return '🔁';
+        }
+    }
+    normalizeMessage(message) {
+        if (message.startsWith('nx run ')) {
+            return message.substring('nx run '.length);
+        }
+        else if (message.startsWith('run ')) {
+            return message.substring('run '.length);
+        }
+        else {
+            return message;
+        }
+    }
+    addTaskStatus(taskStatus, commandOutput) {
+        if (taskStatus === 'local-cache') {
+            return `${commandOutput}  ${chalk.dim('[local cache]')}`;
+        }
+        else if (taskStatus === 'remote-cache') {
+            return `${commandOutput}  ${chalk.dim('[remote cache]')}`;
+        }
+        else if (taskStatus === 'local-cache-kept-existing') {
+            return `${commandOutput}  ${chalk.dim('[existing outputs match the cache, left as is]')}`;
+        }
+        else {
+            return commandOutput;
+        }
+    }
+    log({ title, bodyLines, color }) {
+        this.addNewline();
+        this.writeOutputTitle({
+            color: 'cyan',
+            title: color ? chalk[color](title) : title,
+        });
+        this.writeOptionalOutputBody(bodyLines);
+        this.addNewline();
+    }
+    drain() {
+        return new Promise((resolve) => {
+            if (process.stdout.writableNeedDrain) {
+                process.stdout.once('drain', resolve);
+            }
+            else {
+                resolve();
+            }
+        });
+    }
+}
+exports.output = new CLIOutput();
 
 
 /***/ }),
 
-/***/ 80083:
-/***/ ((module) => {
-
-module.exports = eval("require")("@swc/wasm");
-
-
-/***/ }),
+/***/ 4014:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
-/***/ 68654:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+"use strict";
 
-// TODO: consolidate on using a helpers file at some point in the future, which
-// is the approach currently used to export Parser and applyExtends for ESM:
-const {applyExtends, cjsPlatformShim, Parser, Yargs, processArgv} = __nccwpck_require__(21913)
-Yargs.applyExtends = (config, cwd, mergeExtends) => {
-  return applyExtends(config, cwd, mergeExtends, cjsPlatformShim)
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.readModulePackageJson = exports.readModulePackageJsonWithoutFallbacks = exports.readTargetsFromPackageJson = exports.buildTargetFromScript = exports.readNxMigrateConfig = exports.normalizePackageGroup = void 0;
+const fs_1 = __nccwpck_require__(57147);
+const path_1 = __nccwpck_require__(71017);
+const fileutils_1 = __nccwpck_require__(83851);
+const installation_directory_1 = __nccwpck_require__(98584);
+function normalizePackageGroup(packageGroup) {
+    return Array.isArray(packageGroup)
+        ? packageGroup.map((x) => typeof x === 'string' ? { package: x, version: '*' } : x)
+        : Object.entries(packageGroup).map(([pkg, version]) => ({
+            package: pkg,
+            version,
+        }));
 }
-Yargs.hideBin = processArgv.hideBin
-Yargs.Parser = Parser
-module.exports = Yargs
-
-
-/***/ }),
-
-/***/ 3833:
-/***/ ((module) => {
-
-function webpackEmptyContext(req) {
-	var e = new Error("Cannot find module '" + req + "'");
-	e.code = 'MODULE_NOT_FOUND';
-	throw e;
+exports.normalizePackageGroup = normalizePackageGroup;
+function readNxMigrateConfig(json) {
+    const parseNxMigrationsConfig = (fromJson) => {
+        if (!fromJson) {
+            return {};
+        }
+        if (typeof fromJson === 'string') {
+            return { migrations: fromJson, packageGroup: [] };
+        }
+        return {
+            ...(fromJson.migrations ? { migrations: fromJson.migrations } : {}),
+            ...(fromJson.packageGroup
+                ? { packageGroup: normalizePackageGroup(fromJson.packageGroup) }
+                : {}),
+        };
+    };
+    return {
+        ...parseNxMigrationsConfig(json['ng-update']),
+        ...parseNxMigrationsConfig(json['nx-migrations']),
+        // In case there's a `migrations` field in `package.json`
+        ...parseNxMigrationsConfig(json),
+    };
 }
-webpackEmptyContext.keys = () => ([]);
-webpackEmptyContext.resolve = webpackEmptyContext;
-webpackEmptyContext.id = 3833;
-module.exports = webpackEmptyContext;
-
-/***/ }),
-
-/***/ 35670:
-/***/ ((module) => {
-
-function webpackEmptyContext(req) {
-	var e = new Error("Cannot find module '" + req + "'");
-	e.code = 'MODULE_NOT_FOUND';
-	throw e;
+exports.readNxMigrateConfig = readNxMigrateConfig;
+function buildTargetFromScript(script, nx) {
+    const nxTargetConfiguration = nx?.targets?.[script] || {};
+    return {
+        ...nxTargetConfiguration,
+        executor: 'nx:run-script',
+        options: {
+            ...(nxTargetConfiguration.options || {}),
+            script,
+        },
+    };
 }
-webpackEmptyContext.keys = () => ([]);
-webpackEmptyContext.resolve = webpackEmptyContext;
-webpackEmptyContext.id = 35670;
-module.exports = webpackEmptyContext;
-
-/***/ }),
-
-/***/ 49167:
-/***/ ((module) => {
-
-function webpackEmptyContext(req) {
-	var e = new Error("Cannot find module '" + req + "'");
-	e.code = 'MODULE_NOT_FOUND';
-	throw e;
+exports.buildTargetFromScript = buildTargetFromScript;
+function readTargetsFromPackageJson(packageJson) {
+    const { scripts, nx } = packageJson;
+    const res = {};
+    Object.keys(scripts || {}).forEach((script) => {
+        if (!nx?.includedScripts || nx?.includedScripts.includes(script)) {
+            res[script] = buildTargetFromScript(script, nx);
+        }
+    });
+    /**
+     * Add implicit nx-release-publish target for all package.json files that are
+     * not marked as `"private": true` to allow for lightweight configuration for
+     * package based repos.
+     */
+    if (!packageJson.private && !res['nx-release-publish']) {
+        res['nx-release-publish'] = {
+            dependsOn: ['^nx-release-publish'],
+            executor: '@nx/js:release-publish',
+            options: {},
+        };
+    }
+    return res;
 }
-webpackEmptyContext.keys = () => ([]);
-webpackEmptyContext.resolve = webpackEmptyContext;
-webpackEmptyContext.id = 49167;
-module.exports = webpackEmptyContext;
-
-/***/ }),
-
-/***/ 39491:
-/***/ ((module) => {
-
-"use strict";
-module.exports = require("assert");
-
-/***/ }),
-
-/***/ 14300:
-/***/ ((module) => {
-
-"use strict";
-module.exports = require("buffer");
-
-/***/ }),
-
-/***/ 32081:
-/***/ ((module) => {
-
-"use strict";
-module.exports = require("child_process");
-
-/***/ }),
-
-/***/ 96206:
-/***/ ((module) => {
-
-"use strict";
-module.exports = require("console");
-
-/***/ }),
-
-/***/ 22057:
-/***/ ((module) => {
-
-"use strict";
-module.exports = require("constants");
-
-/***/ }),
-
-/***/ 6113:
-/***/ ((module) => {
-
-"use strict";
-module.exports = require("crypto");
-
-/***/ }),
-
-/***/ 82361:
-/***/ ((module) => {
-
-"use strict";
-module.exports = require("events");
-
-/***/ }),
-
-/***/ 57147:
-/***/ ((module) => {
-
-"use strict";
-module.exports = require("fs");
-
-/***/ }),
-
-/***/ 73292:
-/***/ ((module) => {
-
-"use strict";
-module.exports = require("fs/promises");
-
-/***/ }),
-
-/***/ 13685:
-/***/ ((module) => {
-
-"use strict";
-module.exports = require("http");
-
-/***/ }),
-
-/***/ 95687:
-/***/ ((module) => {
-
-"use strict";
-module.exports = require("https");
-
-/***/ }),
-
-/***/ 31405:
-/***/ ((module) => {
-
-"use strict";
-module.exports = require("inspector");
-
-/***/ }),
-
-/***/ 98188:
-/***/ ((module) => {
+exports.readTargetsFromPackageJson = readTargetsFromPackageJson;
+/**
+ * Uses `require.resolve` to read the package.json for a module.
+ *
+ * This will fail if the module doesn't export package.json
+ *
+ * @returns package json contents and path
+ */
+function readModulePackageJsonWithoutFallbacks(moduleSpecifier, requirePaths = (0, installation_directory_1.getNxRequirePaths)()) {
+    const packageJsonPath = require.resolve(`${moduleSpecifier}/package.json`, {
+        paths: requirePaths,
+    });
+    const packageJson = (0, fileutils_1.readJsonFile)(packageJsonPath);
+    return {
+        path: packageJsonPath,
+        packageJson,
+    };
+}
+exports.readModulePackageJsonWithoutFallbacks = readModulePackageJsonWithoutFallbacks;
+/**
+ * Reads the package.json file for a specified module.
+ *
+ * Includes a fallback that accounts for modules that don't export package.json
+ *
+ * @param {string} moduleSpecifier The module to look up
+ * @param {string[]} requirePaths List of paths look in. Pass `module.paths` to ensure non-hoisted dependencies are found.
+ *
+ * @example
+ * // Use the caller's lookup paths for non-hoisted dependencies
+ * readModulePackageJson('http-server', module.paths);
+ *
+ * @returns package json contents and path
+ */
+function readModulePackageJson(moduleSpecifier, requirePaths = (0, installation_directory_1.getNxRequirePaths)()) {
+    let packageJsonPath;
+    let packageJson;
+    try {
+        ({ path: packageJsonPath, packageJson } =
+            readModulePackageJsonWithoutFallbacks(moduleSpecifier, requirePaths));
+    }
+    catch {
+        const entryPoint = require.resolve(moduleSpecifier, {
+            paths: requirePaths,
+        });
+        let moduleRootPath = (0, path_1.dirname)(entryPoint);
+        packageJsonPath = (0, path_1.join)(moduleRootPath, 'package.json');
+        while (!(0, fs_1.existsSync)(packageJsonPath)) {
+            moduleRootPath = (0, path_1.dirname)(moduleRootPath);
+            packageJsonPath = (0, path_1.join)(moduleRootPath, 'package.json');
+        }
+        packageJson = (0, fileutils_1.readJsonFile)(packageJsonPath);
+        if (packageJson.name && packageJson.name !== moduleSpecifier) {
+            throw new Error(`Found module ${packageJson.name} while trying to locate ${moduleSpecifier}/package.json`);
+        }
+    }
+    return {
+        packageJson,
+        path: packageJsonPath,
+    };
+}
+exports.readModulePackageJson = readModulePackageJson;
 
-"use strict";
-module.exports = require("module");
 
 /***/ }),
 
-/***/ 41808:
-/***/ ((module) => {
+/***/ 18142:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
 "use strict";
-module.exports = require("net");
-
-/***/ }),
 
-/***/ 22037:
-/***/ ((module) => {
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.packageRegistryPack = exports.packageRegistryView = exports.resolvePackageVersionUsingInstallation = exports.resolvePackageVersionUsingRegistry = exports.createTempNpmDirectory = exports.copyPackageManagerConfigurationFiles = exports.modifyYarnRcToFitNewDirectory = exports.modifyYarnRcYmlToFitNewDirectory = exports.findFileInPackageJsonDirectory = exports.getPackageManagerVersion = exports.getPackageManagerCommand = exports.detectPackageManager = void 0;
+const child_process_1 = __nccwpck_require__(32081);
+const fs_1 = __nccwpck_require__(57147);
+const fs_extra_1 = __nccwpck_require__(27475);
+const path_1 = __nccwpck_require__(71017);
+const semver_1 = __nccwpck_require__(66195);
+const tmp_1 = __nccwpck_require__(81866);
+const util_1 = __nccwpck_require__(73837);
+const configuration_1 = __nccwpck_require__(38777);
+const fileutils_1 = __nccwpck_require__(83851);
+const package_json_1 = __nccwpck_require__(4014);
+const workspace_root_1 = __nccwpck_require__(86708);
+const execAsync = (0, util_1.promisify)(child_process_1.exec);
+/**
+ * Detects which package manager is used in the workspace based on the lock file.
+ */
+function detectPackageManager(dir = '') {
+    const nxJson = (0, configuration_1.readNxJson)();
+    return (nxJson.cli?.packageManager ??
+        ((0, fs_1.existsSync)((0, path_1.join)(dir, 'yarn.lock'))
+            ? 'yarn'
+            : (0, fs_1.existsSync)((0, path_1.join)(dir, 'pnpm-lock.yaml'))
+                ? 'pnpm'
+                : 'npm'));
+}
+exports.detectPackageManager = detectPackageManager;
+/**
+ * Returns commands for the package manager used in the workspace.
+ * By default, the package manager is derived based on the lock file,
+ * but it can also be passed in explicitly.
+ *
+ * Example:
+ *
+ * ```javascript
+ * execSync(`${getPackageManagerCommand().addDev} my-dev-package`);
+ * ```
+ *
+ * @param packageManager The package manager to use. If not provided, it will be detected based on the lock file.
+ * @param root The directory the commands will be ran inside of. Defaults to the current workspace's root.
+ */
+function getPackageManagerCommand(packageManager = detectPackageManager(), root = workspace_root_1.workspaceRoot) {
+    const commands = {
+        yarn: () => {
+            const yarnVersion = getPackageManagerVersion('yarn', root);
+            const useBerry = (0, semver_1.gte)(yarnVersion, '2.0.0');
+            return {
+                preInstall: `yarn set version ${yarnVersion}`,
+                install: 'yarn',
+                ciInstall: useBerry
+                    ? 'yarn install --immutable'
+                    : 'yarn install --frozen-lockfile',
+                updateLockFile: useBerry
+                    ? 'yarn install --mode update-lockfile'
+                    : 'yarn install',
+                add: useBerry ? 'yarn add' : 'yarn add -W',
+                addDev: useBerry ? 'yarn add -D' : 'yarn add -D -W',
+                rm: 'yarn remove',
+                exec: 'yarn',
+                dlx: useBerry ? 'yarn dlx' : 'yarn',
+                run: (script, args) => `yarn ${script} ${args}`,
+                list: useBerry ? 'yarn info --name-only' : 'yarn list',
+            };
+        },
+        pnpm: () => {
+            const pnpmVersion = getPackageManagerVersion('pnpm', root);
+            const modernPnpm = (0, semver_1.gte)(pnpmVersion, '6.13.0');
+            const includeDoubleDashBeforeArgs = (0, semver_1.lt)(pnpmVersion, '7.0.0');
+            const isPnpmWorkspace = (0, fs_1.existsSync)((0, path_1.join)(root, 'pnpm-workspace.yaml'));
+            return {
+                install: 'pnpm install --no-frozen-lockfile', // explicitly disable in case of CI
+                ciInstall: 'pnpm install --frozen-lockfile',
+                updateLockFile: 'pnpm install --lockfile-only',
+                add: isPnpmWorkspace ? 'pnpm add -w' : 'pnpm add',
+                addDev: isPnpmWorkspace ? 'pnpm add -Dw' : 'pnpm add -D',
+                rm: 'pnpm rm',
+                exec: modernPnpm ? 'pnpm exec' : 'pnpx',
+                dlx: modernPnpm ? 'pnpm dlx' : 'pnpx',
+                run: (script, args) => includeDoubleDashBeforeArgs
+                    ? `pnpm run ${script} -- ${args}`
+                    : `pnpm run ${script} ${args}`,
+                list: 'pnpm ls --depth 100',
+            };
+        },
+        npm: () => {
+            // TODO: Remove this
+            process.env.npm_config_legacy_peer_deps ??= 'true';
+            return {
+                install: 'npm install',
+                ciInstall: 'npm ci',
+                updateLockFile: 'npm install --package-lock-only',
+                add: 'npm install',
+                addDev: 'npm install -D',
+                rm: 'npm rm',
+                exec: 'npx',
+                dlx: 'npx',
+                run: (script, args) => `npm run ${script} -- ${args}`,
+                list: 'npm ls',
+            };
+        },
+    };
+    return commands[packageManager]();
+}
+exports.getPackageManagerCommand = getPackageManagerCommand;
+/**
+ * Returns the version of the package manager used in the workspace.
+ * By default, the package manager is derived based on the lock file,
+ * but it can also be passed in explicitly.
+ */
+function getPackageManagerVersion(packageManager = detectPackageManager(), cwd = process.cwd()) {
+    return (0, child_process_1.execSync)(`${packageManager} --version`, {
+        cwd,
+        encoding: 'utf-8',
+    }).trim();
+}
+exports.getPackageManagerVersion = getPackageManagerVersion;
+/**
+ * Checks for a project level npmrc file by crawling up the file tree until
+ * hitting a package.json file, as this is how npm finds them as well.
+ */
+function findFileInPackageJsonDirectory(file, directory = process.cwd()) {
+    while (!(0, fs_1.existsSync)((0, path_1.join)(directory, 'package.json'))) {
+        directory = (0, path_1.dirname)(directory);
+    }
+    const path = (0, path_1.join)(directory, file);
+    return (0, fs_1.existsSync)(path) ? path : null;
+}
+exports.findFileInPackageJsonDirectory = findFileInPackageJsonDirectory;
+/**
+ * We copy yarnrc.yml to the temporary directory to ensure things like the specified
+ * package registry are still used. However, there are a few relative paths that can
+ * cause issues, so we modify them to fit the new directory.
+ *
+ * Exported for testing - not meant to be used outside of this file.
+ *
+ * @param contents The string contents of the yarnrc.yml file
+ * @returns Updated string contents of the yarnrc.yml file
+ */
+function modifyYarnRcYmlToFitNewDirectory(contents) {
+    const { parseSyml, stringifySyml } = __nccwpck_require__(2877);
+    const parsed = parseSyml(contents);
+    if (parsed.yarnPath) {
+        // yarnPath is relative to the workspace root, so we need to make it relative
+        // to the new directory s.t. it still points to the same yarn binary.
+        delete parsed.yarnPath;
+    }
+    if (parsed.plugins) {
+        // Plugins specified by a string are relative paths from workspace root.
+        // ex: https://yarnpkg.com/advanced/plugin-tutorial#writing-our-first-plugin
+        delete parsed.plugins;
+    }
+    return stringifySyml(parsed);
+}
+exports.modifyYarnRcYmlToFitNewDirectory = modifyYarnRcYmlToFitNewDirectory;
+/**
+ * We copy .yarnrc to the temporary directory to ensure things like the specified
+ * package registry are still used. However, there are a few relative paths that can
+ * cause issues, so we modify them to fit the new directory.
+ *
+ * Exported for testing - not meant to be used outside of this file.
+ *
+ * @param contents The string contents of the yarnrc.yml file
+ * @returns Updated string contents of the yarnrc.yml file
+ */
+function modifyYarnRcToFitNewDirectory(contents) {
+    const lines = contents.split('\n');
+    const yarnPathIndex = lines.findIndex((line) => line.startsWith('yarn-path'));
+    if (yarnPathIndex !== -1) {
+        lines.splice(yarnPathIndex, 1);
+    }
+    return lines.join('\n');
+}
+exports.modifyYarnRcToFitNewDirectory = modifyYarnRcToFitNewDirectory;
+function copyPackageManagerConfigurationFiles(root, destination) {
+    for (const packageManagerConfigFile of ['.npmrc', '.yarnrc', '.yarnrc.yml']) {
+        // f is an absolute path, including the {workspaceRoot}.
+        const f = findFileInPackageJsonDirectory(packageManagerConfigFile, root);
+        if (f) {
+            // Destination should be the same relative path from the {workspaceRoot},
+            // but now relative to the destination. `relative` makes `{workspaceRoot}/some/path`
+            // look like `./some/path`, and joining that gets us `{destination}/some/path
+            const destinationPath = (0, path_1.join)(destination, (0, path_1.relative)(root, f));
+            switch (packageManagerConfigFile) {
+                case '.npmrc': {
+                    (0, fs_1.copyFileSync)(f, destinationPath);
+                    break;
+                }
+                case '.yarnrc': {
+                    const updated = modifyYarnRcToFitNewDirectory((0, fileutils_1.readFileIfExisting)(f));
+                    (0, fs_1.writeFileSync)(destinationPath, updated);
+                    break;
+                }
+                case '.yarnrc.yml': {
+                    const updated = modifyYarnRcYmlToFitNewDirectory((0, fileutils_1.readFileIfExisting)(f));
+                    (0, fs_1.writeFileSync)(destinationPath, updated);
+                    break;
+                }
+            }
+        }
+    }
+}
+exports.copyPackageManagerConfigurationFiles = copyPackageManagerConfigurationFiles;
+/**
+ * Creates a temporary directory where you can run package manager commands safely.
+ *
+ * For cases where you'd want to install packages that require an `.npmrc` set up,
+ * this function looks up for the nearest `.npmrc` (if exists) and copies it over to the
+ * temp directory.
+ */
+function createTempNpmDirectory() {
+    const dir = (0, tmp_1.dirSync)().name;
+    // A package.json is needed for pnpm pack and for .npmrc to resolve
+    (0, fileutils_1.writeJsonFile)(`${dir}/package.json`, {});
+    copyPackageManagerConfigurationFiles(workspace_root_1.workspaceRoot, dir);
+    const cleanup = async () => {
+        try {
+            await (0, fs_extra_1.remove)(dir);
+        }
+        catch {
+            // It's okay if this fails, the OS will clean it up eventually
+        }
+    };
+    return { dir, cleanup };
+}
+exports.createTempNpmDirectory = createTempNpmDirectory;
+/**
+ * Returns the resolved version for a given package and version tag using the
+ * NPM registry (when using Yarn it will fall back to NPM to fetch the info).
+ */
+async function resolvePackageVersionUsingRegistry(packageName, version) {
+    try {
+        const result = await packageRegistryView(packageName, version, 'version');
+        if (!result) {
+            throw new Error(`Unable to resolve version ${packageName}@${version}.`);
+        }
+        // get the last line of the output, strip the package version and quotes
+        const resolvedVersion = result
+            .split('\n')
+            .pop()
+            .split(' ')
+            .pop()
+            .replace(/'/g, '');
+        return resolvedVersion;
+    }
+    catch {
+        throw new Error(`Unable to resolve version ${packageName}@${version}.`);
+    }
+}
+exports.resolvePackageVersionUsingRegistry = resolvePackageVersionUsingRegistry;
+/**
+ * Return the resolved version for a given package and version tag using by
+ * installing it in a temporary directory and fetching the version from the
+ * package.json.
+ */
+async function resolvePackageVersionUsingInstallation(packageName, version) {
+    const { dir, cleanup } = createTempNpmDirectory();
+    try {
+        const pmc = getPackageManagerCommand();
+        await execAsync(`${pmc.add} ${packageName}@${version}`, { cwd: dir });
+        const { packageJson } = (0, package_json_1.readModulePackageJson)(packageName, [dir]);
+        return packageJson.version;
+    }
+    finally {
+        await cleanup();
+    }
+}
+exports.resolvePackageVersionUsingInstallation = resolvePackageVersionUsingInstallation;
+async function packageRegistryView(pkg, version, args) {
+    let pm = detectPackageManager();
+    if (pm === 'yarn') {
+        /**
+         * yarn has `yarn info` but it behaves differently than (p)npm,
+         * which makes it's usage unreliable
+         *
+         * @see https://github.com/nrwl/nx/pull/9667#discussion_r842553994
+         */
+        pm = 'npm';
+    }
+    const { stdout } = await execAsync(`${pm} view ${pkg}@${version} ${args}`);
+    return stdout.toString().trim();
+}
+exports.packageRegistryView = packageRegistryView;
+async function packageRegistryPack(cwd, pkg, version) {
+    let pm = detectPackageManager();
+    if (pm === 'yarn') {
+        /**
+         * `(p)npm pack` will download a tarball of the specified version,
+         * whereas `yarn` pack creates a tarball of the active workspace, so it
+         * does not work for getting the content of a library.
+         *
+         * @see https://github.com/nrwl/nx/pull/9667#discussion_r842553994
+         */
+        pm = 'npm';
+    }
+    const { stdout } = await execAsync(`${pm} pack ${pkg}@${version}`, { cwd });
+    const tarballPath = stdout.trim();
+    return { tarballPath };
+}
+exports.packageRegistryPack = packageRegistryPack;
 
-"use strict";
-module.exports = require("os");
 
 /***/ }),
 
-/***/ 71017:
-/***/ ((module) => {
+/***/ 38270:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
 "use strict";
-module.exports = require("path");
-
-/***/ }),
 
-/***/ 4074:
-/***/ ((module) => {
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.getCwd = exports.joinPathFragments = exports.normalizePath = void 0;
+const path = __nccwpck_require__(71017);
+const workspace_root_1 = __nccwpck_require__(86708);
+function removeWindowsDriveLetter(osSpecificPath) {
+    return osSpecificPath.replace(/^[A-Z]:/, '');
+}
+/**
+ * Coverts an os specific path to a unix style path. Use this when writing paths to config files.
+ * This should not be used to read files on disk because of the removal of Windows drive letters.
+ */
+function normalizePath(osSpecificPath) {
+    return removeWindowsDriveLetter(osSpecificPath).split('\\').join('/');
+}
+exports.normalizePath = normalizePath;
+/**
+ * Normalized path fragments and joins them. Use this when writing paths to config files.
+ * This should not be used to read files on disk because of the removal of Windows drive letters.
+ */
+function joinPathFragments(...fragments) {
+    return normalizePath(path.join(...fragments));
+}
+exports.joinPathFragments = joinPathFragments;
+/**
+ * When running a script with the package manager (e.g. `npm run`), the package manager will
+ * traverse the directory tree upwards until it finds a `package.json` and will set `process.cwd()`
+ * to the folder where it found it. The actual working directory is stored in the INIT_CWD
+ * environment variable (see here: https://docs.npmjs.com/cli/v9/commands/npm-run-script#description).
+ *
+ * @returns The path to the current working directory.
+ */
+function getCwd() {
+    return process.env.INIT_CWD?.startsWith(workspace_root_1.workspaceRoot)
+        ? process.env.INIT_CWD
+        : process.cwd();
+}
+exports.getCwd = getCwd;
 
-"use strict";
-module.exports = require("perf_hooks");
 
 /***/ }),
 
-/***/ 38102:
-/***/ ((module) => {
+/***/ 71067:
+/***/ ((__unused_webpack_module, exports) => {
 
 "use strict";
-module.exports = require("repl");
-
-/***/ }),
 
-/***/ 12781:
-/***/ ((module) => {
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.PromisedBasedQueue = void 0;
+class PromisedBasedQueue {
+    constructor() {
+        this.counter = 0;
+        this.promise = Promise.resolve(null);
+    }
+    sendToQueue(fn) {
+        this.counter++;
+        let res, rej;
+        const r = new Promise((_res, _rej) => {
+            res = _res;
+            rej = _rej;
+        });
+        this.promise = this.promise
+            .then(async () => {
+            try {
+                res(await fn());
+                this.counter--;
+            }
+            catch (e) {
+                rej(e);
+                this.counter--;
+            }
+        })
+            .catch(async () => {
+            try {
+                res(await fn());
+                this.counter--;
+            }
+            catch (e) {
+                rej(e);
+                this.counter--;
+            }
+        });
+        return r;
+    }
+    isEmpty() {
+        return this.counter === 0;
+    }
+}
+exports.PromisedBasedQueue = PromisedBasedQueue;
 
-"use strict";
-module.exports = require("stream");
 
 /***/ }),
 
-/***/ 71576:
-/***/ ((module) => {
+/***/ 98487:
+/***/ ((__unused_webpack_module, exports) => {
 
 "use strict";
-module.exports = require("string_decoder");
-
-/***/ }),
 
-/***/ 24404:
-/***/ ((module) => {
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.stripIndents = void 0;
+/**
+ * Removes indents, which is useful for printing warning and messages.
+ *
+ * Example:
+ *
+ * ```typescript
+ * stripIndents`
+ *  Options:
+ *  - option1
+ *  - option2
+ * `
+ * ```
+ */
+function stripIndents(strings, ...values) {
+    return String.raw(strings, ...values)
+        .split('\n')
+        .map((line) => line.trim())
+        .join('\n')
+        .trim();
+}
+exports.stripIndents = stripIndents;
 
-"use strict";
-module.exports = require("tls");
 
 /***/ }),
 
-/***/ 76224:
-/***/ ((module) => {
+/***/ 92941:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
 "use strict";
-module.exports = require("tty");
-
-/***/ }),
 
-/***/ 57310:
-/***/ ((module) => {
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.nxVersion = void 0;
+exports.nxVersion = __nccwpck_require__(89617).version;
 
-"use strict";
-module.exports = require("url");
 
 /***/ }),
 
-/***/ 73837:
-/***/ ((module) => {
+/***/ 302:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
 "use strict";
-module.exports = require("util");
-
-/***/ }),
 
-/***/ 26144:
-/***/ ((module) => {
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.resetWorkspaceContext = exports.updateProjectFiles = exports.getFilesInDirectoryUsingContext = exports.getAllFileDataInContext = exports.updateFilesInContext = exports.hashWithWorkspaceContext = exports.globWithWorkspaceContext = exports.getNxWorkspaceFilesFromContext = exports.setupWorkspaceContext = void 0;
+const perf_hooks_1 = __nccwpck_require__(4074);
+const cache_directory_1 = __nccwpck_require__(15120);
+let workspaceContext;
+function setupWorkspaceContext(workspaceRoot) {
+    const { WorkspaceContext } = __nccwpck_require__(74424);
+    perf_hooks_1.performance.mark('workspace-context');
+    workspaceContext = new WorkspaceContext(workspaceRoot, (0, cache_directory_1.cacheDirectoryForWorkspace)(workspaceRoot));
+    perf_hooks_1.performance.mark('workspace-context:end');
+    perf_hooks_1.performance.measure('workspace context init', 'workspace-context', 'workspace-context:end');
+}
+exports.setupWorkspaceContext = setupWorkspaceContext;
+function getNxWorkspaceFilesFromContext(workspaceRoot, projectRootMap) {
+    ensureContextAvailable(workspaceRoot);
+    return workspaceContext.getWorkspaceFiles(projectRootMap);
+}
+exports.getNxWorkspaceFilesFromContext = getNxWorkspaceFilesFromContext;
+function globWithWorkspaceContext(workspaceRoot, globs, exclude) {
+    ensureContextAvailable(workspaceRoot);
+    return workspaceContext.glob(globs, exclude);
+}
+exports.globWithWorkspaceContext = globWithWorkspaceContext;
+function hashWithWorkspaceContext(workspaceRoot, globs, exclude) {
+    ensureContextAvailable(workspaceRoot);
+    return workspaceContext.hashFilesMatchingGlob(globs, exclude);
+}
+exports.hashWithWorkspaceContext = hashWithWorkspaceContext;
+function updateFilesInContext(updatedFiles, deletedFiles) {
+    return workspaceContext?.incrementalUpdate(updatedFiles, deletedFiles);
+}
+exports.updateFilesInContext = updateFilesInContext;
+function getAllFileDataInContext(workspaceRoot) {
+    ensureContextAvailable(workspaceRoot);
+    return workspaceContext.allFileData();
+}
+exports.getAllFileDataInContext = getAllFileDataInContext;
+function getFilesInDirectoryUsingContext(workspaceRoot, dir) {
+    ensureContextAvailable(workspaceRoot);
+    return workspaceContext.getFilesInDirectory(dir);
+}
+exports.getFilesInDirectoryUsingContext = getFilesInDirectoryUsingContext;
+function updateProjectFiles(projectRootMappings, rustReferences, updatedFiles, deletedFiles) {
+    return workspaceContext?.updateProjectFiles(projectRootMappings, rustReferences.projectFiles, rustReferences.globalFiles, updatedFiles, deletedFiles);
+}
+exports.updateProjectFiles = updateProjectFiles;
+function ensureContextAvailable(workspaceRoot) {
+    if (!workspaceContext || workspaceContext?.workspaceRoot !== workspaceRoot) {
+        setupWorkspaceContext(workspaceRoot);
+    }
+}
+function resetWorkspaceContext() {
+    workspaceContext = undefined;
+}
+exports.resetWorkspaceContext = resetWorkspaceContext;
 
-"use strict";
-module.exports = require("vm");
 
 /***/ }),
 
-/***/ 71267:
-/***/ ((module) => {
+/***/ 86708:
+/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
 "use strict";
-module.exports = require("worker_threads");
 
-/***/ }),
-
-/***/ 59796:
-/***/ ((module) => {
+Object.defineProperty(exports, "__esModule", ({ value: true }));
+exports.workspaceRootInner = exports.setWorkspaceRoot = exports.workspaceRoot = void 0;
+const path = __nccwpck_require__(71017);
+const fileutils_1 = __nccwpck_require__(83851);
+/**
+ * The root of the workspace
+ */
+exports.workspaceRoot = workspaceRootInner(process.cwd(), process.cwd());
+// Required for integration tests in projects which depend on Nx at runtime, such as lerna and angular-eslint
+function setWorkspaceRoot(root) {
+    exports.workspaceRoot = root;
+}
+exports.setWorkspaceRoot = setWorkspaceRoot;
+function workspaceRootInner(dir, candidateRoot) {
+    if (process.env.NX_WORKSPACE_ROOT_PATH)
+        return process.env.NX_WORKSPACE_ROOT_PATH;
+    if (path.dirname(dir) === dir)
+        return candidateRoot;
+    const matches = [
+        path.join(dir, 'nx.json'),
+        path.join(dir, 'nx'),
+        path.join(dir, 'nx.bat'),
+    ];
+    if (matches.some((x) => (0, fileutils_1.fileExists)(x))) {
+        return dir;
+        // This handles the case where we have a workspace which uses npm / yarn / pnpm
+        // workspaces, and has a project which contains Nx in its dependency tree.
+        // e.g. packages/my-lib/package.json contains @nx/devkit, which references Nx and is
+        // thus located in //packages/my-lib/node_modules/nx/package.json
+    }
+    else if ((0, fileutils_1.fileExists)(path.join(dir, 'node_modules', 'nx', 'package.json'))) {
+        return workspaceRootInner(path.dirname(dir), dir);
+    }
+    else {
+        return workspaceRootInner(path.dirname(dir), candidateRoot);
+    }
+}
+exports.workspaceRootInner = workspaceRootInner;
 
-"use strict";
-module.exports = require("zlib");
 
 /***/ }),
 
-/***/ 30329:
+/***/ 61233:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 const {
@@ -274128,7 +285758,7 @@ const {
   cjsPlatformShim,
   Parser,
   processArgv,
-} = __nccwpck_require__(21913);
+} = __nccwpck_require__(4565);
 
 module.exports = {
   applyExtends: (config, cwd, mergeExtends) => {
@@ -274141,7 +285771,317 @@ module.exports = {
 
 /***/ }),
 
-/***/ 90583:
+/***/ 34855:
+/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
+
+"use strict";
+
+
+const align = {
+    right: alignRight,
+    center: alignCenter
+};
+const top = 0;
+const right = 1;
+const bottom = 2;
+const left = 3;
+class UI {
+    constructor(opts) {
+        var _a;
+        this.width = opts.width;
+        this.wrap = (_a = opts.wrap) !== null && _a !== void 0 ? _a : true;
+        this.rows = [];
+    }
+    span(...args) {
+        const cols = this.div(...args);
+        cols.span = true;
+    }
+    resetOutput() {
+        this.rows = [];
+    }
+    div(...args) {
+        if (args.length === 0) {
+            this.div('');
+        }
+        if (this.wrap && this.shouldApplyLayoutDSL(...args) && typeof args[0] === 'string') {
+            return this.applyLayoutDSL(args[0]);
+        }
+        const cols = args.map(arg => {
+            if (typeof arg === 'string') {
+                return this.colFromString(arg);
+            }
+            return arg;
+        });
+        this.rows.push(cols);
+        return cols;
+    }
+    shouldApplyLayoutDSL(...args) {
+        return args.length === 1 && typeof args[0] === 'string' &&
+            /[\t\n]/.test(args[0]);
+    }
+    applyLayoutDSL(str) {
+        const rows = str.split('\n').map(row => row.split('\t'));
+        let leftColumnWidth = 0;
+        // simple heuristic for layout, make sure the
+        // second column lines up along the left-hand.
+        // don't allow the first column to take up more
+        // than 50% of the screen.
+        rows.forEach(columns => {
+            if (columns.length > 1 && mixin.stringWidth(columns[0]) > leftColumnWidth) {
+                leftColumnWidth = Math.min(Math.floor(this.width * 0.5), mixin.stringWidth(columns[0]));
+            }
+        });
+        // generate a table:
+        //  replacing ' ' with padding calculations.
+        //  using the algorithmically generated width.
+        rows.forEach(columns => {
+            this.div(...columns.map((r, i) => {
+                return {
+                    text: r.trim(),
+                    padding: this.measurePadding(r),
+                    width: (i === 0 && columns.length > 1) ? leftColumnWidth : undefined
+                };
+            }));
+        });
+        return this.rows[this.rows.length - 1];
+    }
+    colFromString(text) {
+        return {
+            text,
+            padding: this.measurePadding(text)
+        };
+    }
+    measurePadding(str) {
+        // measure padding without ansi escape codes
+        const noAnsi = mixin.stripAnsi(str);
+        return [0, noAnsi.match(/\s*$/)[0].length, 0, noAnsi.match(/^\s*/)[0].length];
+    }
+    toString() {
+        const lines = [];
+        this.rows.forEach(row => {
+            this.rowToString(row, lines);
+        });
+        // don't display any lines with the
+        // hidden flag set.
+        return lines
+            .filter(line => !line.hidden)
+            .map(line => line.text)
+            .join('\n');
+    }
+    rowToString(row, lines) {
+        this.rasterize(row).forEach((rrow, r) => {
+            let str = '';
+            rrow.forEach((col, c) => {
+                const { width } = row[c]; // the width with padding.
+                const wrapWidth = this.negatePadding(row[c]); // the width without padding.
+                let ts = col; // temporary string used during alignment/padding.
+                if (wrapWidth > mixin.stringWidth(col)) {
+                    ts += ' '.repeat(wrapWidth - mixin.stringWidth(col));
+                }
+                // align the string within its column.
+                if (row[c].align && row[c].align !== 'left' && this.wrap) {
+                    const fn = align[row[c].align];
+                    ts = fn(ts, wrapWidth);
+                    if (mixin.stringWidth(ts) < wrapWidth) {
+                        ts += ' '.repeat((width || 0) - mixin.stringWidth(ts) - 1);
+                    }
+                }
+                // apply border and padding to string.
+                const padding = row[c].padding || [0, 0, 0, 0];
+                if (padding[left]) {
+                    str += ' '.repeat(padding[left]);
+                }
+                str += addBorder(row[c], ts, '| ');
+                str += ts;
+                str += addBorder(row[c], ts, ' |');
+                if (padding[right]) {
+                    str += ' '.repeat(padding[right]);
+                }
+                // if prior row is span, try to render the
+                // current row on the prior line.
+                if (r === 0 && lines.length > 0) {
+                    str = this.renderInline(str, lines[lines.length - 1]);
+                }
+            });
+            // remove trailing whitespace.
+            lines.push({
+                text: str.replace(/ +$/, ''),
+                span: row.span
+            });
+        });
+        return lines;
+    }
+    // if the full 'source' can render in
+    // the target line, do so.
+    renderInline(source, previousLine) {
+        const match = source.match(/^ */);
+        const leadingWhitespace = match ? match[0].length : 0;
+        const target = previousLine.text;
+        const targetTextWidth = mixin.stringWidth(target.trimRight());
+        if (!previousLine.span) {
+            return source;
+        }
+        // if we're not applying wrapping logic,
+        // just always append to the span.
+        if (!this.wrap) {
+            previousLine.hidden = true;
+            return target + source;
+        }
+        if (leadingWhitespace < targetTextWidth) {
+            return source;
+        }
+        previousLine.hidden = true;
+        return target.trimRight() + ' '.repeat(leadingWhitespace - targetTextWidth) + source.trimLeft();
+    }
+    rasterize(row) {
+        const rrows = [];
+        const widths = this.columnWidths(row);
+        let wrapped;
+        // word wrap all columns, and create
+        // a data-structure that is easy to rasterize.
+        row.forEach((col, c) => {
+            // leave room for left and right padding.
+            col.width = widths[c];
+            if (this.wrap) {
+                wrapped = mixin.wrap(col.text, this.negatePadding(col), { hard: true }).split('\n');
+            }
+            else {
+                wrapped = col.text.split('\n');
+            }
+            if (col.border) {
+                wrapped.unshift('.' + '-'.repeat(this.negatePadding(col) + 2) + '.');
+                wrapped.push("'" + '-'.repeat(this.negatePadding(col) + 2) + "'");
+            }
+            // add top and bottom padding.
+            if (col.padding) {
+                wrapped.unshift(...new Array(col.padding[top] || 0).fill(''));
+                wrapped.push(...new Array(col.padding[bottom] || 0).fill(''));
+            }
+            wrapped.forEach((str, r) => {
+                if (!rrows[r]) {
+                    rrows.push([]);
+                }
+                const rrow = rrows[r];
+                for (let i = 0; i < c; i++) {
+                    if (rrow[i] === undefined) {
+                        rrow.push('');
+                    }
+                }
+                rrow.push(str);
+            });
+        });
+        return rrows;
+    }
+    negatePadding(col) {
+        let wrapWidth = col.width || 0;
+        if (col.padding) {
+            wrapWidth -= (col.padding[left] || 0) + (col.padding[right] || 0);
+        }
+        if (col.border) {
+            wrapWidth -= 4;
+        }
+        return wrapWidth;
+    }
+    columnWidths(row) {
+        if (!this.wrap) {
+            return row.map(col => {
+                return col.width || mixin.stringWidth(col.text);
+            });
+        }
+        let unset = row.length;
+        let remainingWidth = this.width;
+        // column widths can be set in config.
+        const widths = row.map(col => {
+            if (col.width) {
+                unset--;
+                remainingWidth -= col.width;
+                return col.width;
+            }
+            return undefined;
+        });
+        // any unset widths should be calculated.
+        const unsetWidth = unset ? Math.floor(remainingWidth / unset) : 0;
+        return widths.map((w, i) => {
+            if (w === undefined) {
+                return Math.max(unsetWidth, _minWidth(row[i]));
+            }
+            return w;
+        });
+    }
+}
+function addBorder(col, ts, style) {
+    if (col.border) {
+        if (/[.']-+[.']/.test(ts)) {
+            return '';
+        }
+        if (ts.trim().length !== 0) {
+            return style;
+        }
+        return '  ';
+    }
+    return '';
+}
+// calculates the minimum width of
+// a column, based on padding preferences.
+function _minWidth(col) {
+    const padding = col.padding || [];
+    const minWidth = 1 + (padding[left] || 0) + (padding[right] || 0);
+    if (col.border) {
+        return minWidth + 4;
+    }
+    return minWidth;
+}
+function getWindowWidth() {
+    /* istanbul ignore next: depends on terminal */
+    if (typeof process === 'object' && process.stdout && process.stdout.columns) {
+        return process.stdout.columns;
+    }
+    return 80;
+}
+function alignRight(str, width) {
+    str = str.trim();
+    const strWidth = mixin.stringWidth(str);
+    if (strWidth < width) {
+        return ' '.repeat(width - strWidth) + str;
+    }
+    return str;
+}
+function alignCenter(str, width) {
+    str = str.trim();
+    const strWidth = mixin.stringWidth(str);
+    /* istanbul ignore next */
+    if (strWidth >= width) {
+        return str;
+    }
+    return ' '.repeat((width - strWidth) >> 1) + str;
+}
+let mixin;
+function cliui(opts, _mixin) {
+    mixin = _mixin;
+    return new UI({
+        width: (opts === null || opts === void 0 ? void 0 : opts.width) || getWindowWidth(),
+        wrap: opts === null || opts === void 0 ? void 0 : opts.wrap
+    });
+}
+
+// Bootstrap cliui with CommonJS dependencies:
+const stringWidth = __nccwpck_require__(24823);
+const stripAnsi = __nccwpck_require__(74817);
+const wrap = __nccwpck_require__(92863);
+function ui(opts) {
+    return cliui(opts, {
+        stringWidth,
+        stripAnsi,
+        wrap
+    });
+}
+
+module.exports = ui;
+
+
+/***/ }),
+
+/***/ 6613:
 /***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
 "use strict";
@@ -274367,7 +286307,7 @@ exports.yellowBright = yellowBright;
 
 /***/ }),
 
-/***/ 74570:
+/***/ 16106:
 /***/ ((__unused_webpack_module, exports) => {
 
 "use strict";
@@ -274436,7 +286376,7 @@ exports.LinesAndColumns = LinesAndColumns;
 
 /***/ }),
 
-/***/ 32329:
+/***/ 53694:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
@@ -274647,7 +286587,7 @@ module.exports = y18n;
 
 /***/ }),
 
-/***/ 51373:
+/***/ 94844:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
@@ -275700,321 +287640,11 @@ module.exports = yargsParser;
 
 /***/ }),
 
-/***/ 21913:
+/***/ 4565:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
-var t=__nccwpck_require__(39491);class e extends Error{constructor(t){super(t||"yargs error"),this.name="YError",Error.captureStackTrace&&Error.captureStackTrace(this,e)}}let s,i=[];function n(t,o,a,h){s=h;let l={};if(Object.prototype.hasOwnProperty.call(t,"extends")){if("string"!=typeof t.extends)return l;const r=/\.json|\..*rc$/.test(t.extends);let h=null;if(r)h=function(t,e){return s.path.resolve(t,e)}(o,t.extends);else try{h=/*require.resolve*/(__nccwpck_require__(49167).resolve(t.extends))}catch(e){return t}!function(t){if(i.indexOf(t)>-1)throw new e(`Circular extended configurations: '${t}'.`)}(h),i.push(h),l=r?JSON.parse(s.readFileSync(h,"utf8")):__nccwpck_require__(49167)(t.extends),delete t.extends,l=n(l,s.path.dirname(h),a,s)}return i=[],a?r(l,t):Object.assign({},l,t)}function r(t,e){const s={};function i(t){return t&&"object"==typeof t&&!Array.isArray(t)}Object.assign(s,t);for(const n of Object.keys(e))i(e[n])&&i(s[n])?s[n]=r(t[n],e[n]):s[n]=e[n];return s}function o(t){const e=t.replace(/\s{2,}/g," ").split(/\s+(?![^[]*]|[^<]*>)/),s=/\.*[\][<>]/g,i=e.shift();if(!i)throw new Error(`No command found in: ${t}`);const n={cmd:i.replace(s,""),demanded:[],optional:[]};return e.forEach(((t,i)=>{let r=!1;t=t.replace(/\s/g,""),/\.+[\]>]/.test(t)&&i===e.length-1&&(r=!0),/^\[/.test(t)?n.optional.push({cmd:t.replace(s,"").split("|"),variadic:r}):n.demanded.push({cmd:t.replace(s,"").split("|"),variadic:r})})),n}const a=["first","second","third","fourth","fifth","sixth"];function h(t,s,i){try{let n=0;const[r,a,h]="object"==typeof t?[{demanded:[],optional:[]},t,s]:[o(`cmd ${t}`),s,i],f=[].slice.call(a);for(;f.length&&void 0===f[f.length-1];)f.pop();const d=h||f.length;if(du)throw new e(`Too many arguments provided. Expected max ${u} but received ${d}.`);r.demanded.forEach((t=>{const e=l(f.shift());0===t.cmd.filter((t=>t===e||"*"===t)).length&&c(e,t.cmd,n),n+=1})),r.optional.forEach((t=>{if(0===f.length)return;const e=l(f.shift());0===t.cmd.filter((t=>t===e||"*"===t)).length&&c(e,t.cmd,n),n+=1}))}catch(t){console.warn(t.stack)}}function l(t){return Array.isArray(t)?"array":null===t?"null":typeof t}function c(t,s,i){throw new e(`Invalid ${a[i]||"manyith"} argument. Expected ${s.join(" or ")} but received ${t}.`)}function f(t){return!!t&&!!t.then&&"function"==typeof t.then}function d(t,e,s,i){s.assert.notStrictEqual(t,e,i)}function u(t,e){e.assert.strictEqual(typeof t,"string")}function p(t){return Object.keys(t)}function g(t={},e=(()=>!0)){const s={};return p(t).forEach((i=>{e(i,t[i])&&(s[i]=t[i])})),s}function m(){return process.versions.electron&&!process.defaultApp?0:1}function y(){return process.argv[m()]}var b=Object.freeze({__proto__:null,hideBin:function(t){return t.slice(m()+1)},getProcessArgvBin:y});function v(t,e,s,i){if("a"===s&&!i)throw new TypeError("Private accessor was defined without a getter");if("function"==typeof e?t!==e||!i:!e.has(t))throw new TypeError("Cannot read private member from an object whose class did not declare it");return"m"===s?i:"a"===s?i.call(t):i?i.value:e.get(t)}function O(t,e,s,i,n){if("m"===i)throw new TypeError("Private method is not writable");if("a"===i&&!n)throw new TypeError("Private accessor was defined without a setter");if("function"==typeof e?t!==e||!n:!e.has(t))throw new TypeError("Cannot write private member to an object whose class did not declare it");return"a"===i?n.call(t,s):n?n.value=s:e.set(t,s),s}class w{constructor(t){this.globalMiddleware=[],this.frozens=[],this.yargs=t}addMiddleware(t,e,s=!0,i=!1){if(h(" [boolean] [boolean] [boolean]",[t,e,s],arguments.length),Array.isArray(t)){for(let i=0;i{const i=[...s[e]||[],e];return!t.option||!i.includes(t.option)})),t.option=e,this.addMiddleware(t,!0,!0,!0)}getMiddleware(){return this.globalMiddleware}freeze(){this.frozens.push([...this.globalMiddleware])}unfreeze(){const t=this.frozens.pop();void 0!==t&&(this.globalMiddleware=t)}reset(){this.globalMiddleware=this.globalMiddleware.filter((t=>t.global))}}function C(t,e,s,i){return s.reduce(((t,s)=>{if(s.applyBeforeValidation!==i)return t;if(s.mutates){if(s.applied)return t;s.applied=!0}if(f(t))return t.then((t=>Promise.all([t,s(t,e)]))).then((([t,e])=>Object.assign(t,e)));{const i=s(t,e);return f(i)?i.then((e=>Object.assign(t,e))):Object.assign(t,i)}}),t)}function j(t,e,s=(t=>{throw t})){try{const s="function"==typeof t?t():t;return f(s)?s.then((t=>e(t))):e(s)}catch(t){return s(t)}}const M=/(^\*)|(^\$0)/;class _{constructor(t,e,s,i){this.requireCache=new Set,this.handlers={},this.aliasMap={},this.frozens=[],this.shim=i,this.usage=t,this.globalMiddleware=s,this.validation=e}addDirectory(t,e,s,i){"boolean"!=typeof(i=i||{}).recurse&&(i.recurse=!1),Array.isArray(i.extensions)||(i.extensions=["js"]);const n="function"==typeof i.visit?i.visit:t=>t;i.visit=(t,e,s)=>{const i=n(t,e,s);if(i){if(this.requireCache.has(e))return i;this.requireCache.add(e),this.addHandler(i)}return i},this.shim.requireDirectory({require:e,filename:s},t,i)}addHandler(t,e,s,i,n,r){let a=[];const h=function(t){return t?t.map((t=>(t.applyBeforeValidation=!1,t))):[]}(n);if(i=i||(()=>{}),Array.isArray(t))if(function(t){return t.every((t=>"string"==typeof t))}(t))[t,...a]=t;else for(const e of t)this.addHandler(e);else{if(function(t){return"object"==typeof t&&!Array.isArray(t)}(t)){let e=Array.isArray(t.command)||"string"==typeof t.command?t.command:this.moduleName(t);return t.aliases&&(e=[].concat(e).concat(t.aliases)),void this.addHandler(e,this.extractDesc(t),t.builder,t.handler,t.middlewares,t.deprecated)}if(k(s))return void this.addHandler([t].concat(a),e,s.builder,s.handler,s.middlewares,s.deprecated)}if("string"==typeof t){const n=o(t);a=a.map((t=>o(t).cmd));let l=!1;const c=[n.cmd].concat(a).filter((t=>!M.test(t)||(l=!0,!1)));0===c.length&&l&&c.push("$0"),l&&(n.cmd=c[0],a=c.slice(1),t=t.replace(M,n.cmd)),a.forEach((t=>{this.aliasMap[t]=n.cmd})),!1!==e&&this.usage.command(t,e,l,a,r),this.handlers[n.cmd]={original:t,description:e,handler:i,builder:s||{},middlewares:h,deprecated:r,demanded:n.demanded,optional:n.optional},l&&(this.defaultCommand=this.handlers[n.cmd])}}getCommandHandlers(){return this.handlers}getCommands(){return Object.keys(this.handlers).concat(Object.keys(this.aliasMap))}hasDefaultCommand(){return!!this.defaultCommand}runCommand(t,e,s,i,n,r){const o=this.handlers[t]||this.handlers[this.aliasMap[t]]||this.defaultCommand,a=e.getInternalMethods().getContext(),h=a.commands.slice(),l=!t;t&&(a.commands.push(t),a.fullCommands.push(o.original));const c=this.applyBuilderUpdateUsageAndParse(l,o,e,s.aliases,h,i,n,r);return f(c)?c.then((t=>this.applyMiddlewareAndGetResult(l,o,t.innerArgv,a,n,t.aliases,e))):this.applyMiddlewareAndGetResult(l,o,c.innerArgv,a,n,c.aliases,e)}applyBuilderUpdateUsageAndParse(t,e,s,i,n,r,o,a){const h=e.builder;let l=s;if(x(h)){s.getInternalMethods().getUsageInstance().freeze();const c=h(s.getInternalMethods().reset(i),a);if(f(c))return c.then((i=>{var a;return l=(a=i)&&"function"==typeof a.getInternalMethods?i:s,this.parseAndUpdateUsage(t,e,l,n,r,o)}))}else(function(t){return"object"==typeof t})(h)&&(s.getInternalMethods().getUsageInstance().freeze(),l=s.getInternalMethods().reset(i),Object.keys(e.builder).forEach((t=>{l.option(t,h[t])})));return this.parseAndUpdateUsage(t,e,l,n,r,o)}parseAndUpdateUsage(t,e,s,i,n,r){t&&s.getInternalMethods().getUsageInstance().unfreeze(!0),this.shouldUpdateUsage(s)&&s.getInternalMethods().getUsageInstance().usage(this.usageFromParentCommandsCommandHandler(i,e),e.description);const o=s.getInternalMethods().runYargsParserAndExecuteCommands(null,void 0,!0,n,r);return f(o)?o.then((t=>({aliases:s.parsed.aliases,innerArgv:t}))):{aliases:s.parsed.aliases,innerArgv:o}}shouldUpdateUsage(t){return!t.getInternalMethods().getUsageInstance().getUsageDisabled()&&0===t.getInternalMethods().getUsageInstance().getUsage().length}usageFromParentCommandsCommandHandler(t,e){const s=M.test(e.original)?e.original.replace(M,"").trim():e.original,i=t.filter((t=>!M.test(t)));return i.push(s),`$0 ${i.join(" ")}`}handleValidationAndGetResult(t,e,s,i,n,r,o,a){if(!r.getInternalMethods().getHasOutput()){const e=r.getInternalMethods().runValidation(n,a,r.parsed.error,t);s=j(s,(t=>(e(t),t)))}if(e.handler&&!r.getInternalMethods().getHasOutput()){r.getInternalMethods().setHasOutput();const i=!!r.getOptions().configuration["populate--"];r.getInternalMethods().postProcess(s,i,!1,!1),s=j(s=C(s,r,o,!1),(t=>{const s=e.handler(t);return f(s)?s.then((()=>t)):t})),t||r.getInternalMethods().getUsageInstance().cacheHelpMessage(),f(s)&&!r.getInternalMethods().hasParseCallback()&&s.catch((t=>{try{r.getInternalMethods().getUsageInstance().fail(null,t)}catch(t){}}))}return t||(i.commands.pop(),i.fullCommands.pop()),s}applyMiddlewareAndGetResult(t,e,s,i,n,r,o){let a={};if(n)return s;o.getInternalMethods().getHasOutput()||(a=this.populatePositionals(e,s,i,o));const h=this.globalMiddleware.getMiddleware().slice(0).concat(e.middlewares),l=C(s,o,h,!0);return f(l)?l.then((s=>this.handleValidationAndGetResult(t,e,s,i,r,o,h,a))):this.handleValidationAndGetResult(t,e,l,i,r,o,h,a)}populatePositionals(t,e,s,i){e._=e._.slice(s.commands.length);const n=t.demanded.slice(0),r=t.optional.slice(0),o={};for(this.validation.positionalCount(n.length,e._.length);n.length;){const t=n.shift();this.populatePositional(t,e,o)}for(;r.length;){const t=r.shift();this.populatePositional(t,e,o)}return e._=s.commands.concat(e._.map((t=>""+t))),this.postProcessPositionals(e,o,this.cmdToParseOptions(t.original),i),o}populatePositional(t,e,s){const i=t.cmd[0];t.variadic?s[i]=e._.splice(0).map(String):e._.length&&(s[i]=[String(e._.shift())])}cmdToParseOptions(t){const e={array:[],default:{},alias:{},demand:{}},s=o(t);return s.demanded.forEach((t=>{const[s,...i]=t.cmd;t.variadic&&(e.array.push(s),e.default[s]=[]),e.alias[s]=i,e.demand[s]=!0})),s.optional.forEach((t=>{const[s,...i]=t.cmd;t.variadic&&(e.array.push(s),e.default[s]=[]),e.alias[s]=i})),e}postProcessPositionals(t,e,s,i){const n=Object.assign({},i.getOptions());n.default=Object.assign(s.default,n.default);for(const t of Object.keys(s.alias))n.alias[t]=(n.alias[t]||[]).concat(s.alias[t]);n.array=n.array.concat(s.array),n.config={};const r=[];if(Object.keys(e).forEach((t=>{e[t].map((e=>{n.configuration["unknown-options-as-args"]&&(n.key[t]=!0),r.push(`--${t}`),r.push(e)}))})),!r.length)return;const o=Object.assign({},n.configuration,{"populate--":!1}),a=this.shim.Parser.detailed(r,Object.assign({},n,{configuration:o}));if(a.error)i.getInternalMethods().getUsageInstance().fail(a.error.message,a.error);else{const s=Object.keys(e);Object.keys(e).forEach((t=>{s.push(...a.aliases[t])})),Object.keys(a.argv).forEach((n=>{s.includes(n)&&(e[n]||(e[n]=a.argv[n]),!this.isInConfigs(i,n)&&!this.isDefaulted(i,n)&&Object.prototype.hasOwnProperty.call(t,n)&&Object.prototype.hasOwnProperty.call(a.argv,n)&&(Array.isArray(t[n])||Array.isArray(a.argv[n]))?t[n]=[].concat(t[n],a.argv[n]):t[n]=a.argv[n])}))}}isDefaulted(t,e){const{default:s}=t.getOptions();return Object.prototype.hasOwnProperty.call(s,e)||Object.prototype.hasOwnProperty.call(s,this.shim.Parser.camelCase(e))}isInConfigs(t,e){const{configObjects:s}=t.getOptions();return s.some((t=>Object.prototype.hasOwnProperty.call(t,e)))||s.some((t=>Object.prototype.hasOwnProperty.call(t,this.shim.Parser.camelCase(e))))}runDefaultBuilderOn(t){if(!this.defaultCommand)return;if(this.shouldUpdateUsage(t)){const e=M.test(this.defaultCommand.original)?this.defaultCommand.original:this.defaultCommand.original.replace(/^[^[\]<>]*/,"$0 ");t.getInternalMethods().getUsageInstance().usage(e,this.defaultCommand.description)}const e=this.defaultCommand.builder;if(x(e))return e(t,!0);k(e)||Object.keys(e).forEach((s=>{t.option(s,e[s])}))}moduleName(t){const e=function(t){if(false){}for(let e,s=0,i=Object.keys(__nccwpck_require__.c);s{const s=e;s._handle&&s.isTTY&&"function"==typeof s._handle.setBlocking&&s._handle.setBlocking(t)}))}function A(t){return"boolean"==typeof t}function P(t,s){const i=s.y18n.__,n={},r=[];n.failFn=function(t){r.push(t)};let o=null,a=null,h=!0;n.showHelpOnFail=function(e=!0,s){const[i,r]="string"==typeof e?[!0,e]:[e,s];return t.getInternalMethods().isGlobalContext()&&(a=r),o=r,h=i,n};let l=!1;n.fail=function(s,i){const c=t.getInternalMethods().getLoggerInstance();if(!r.length){if(t.getExitProcess()&&E(!0),!l){l=!0,h&&(t.showHelp("error"),c.error()),(s||i)&&c.error(s||i);const e=o||a;e&&((s||i)&&c.error(""),c.error(e))}if(i=i||new e(s),t.getExitProcess())return t.exit(1);if(t.getInternalMethods().hasParseCallback())return t.exit(1,i);throw i}for(let t=r.length-1;t>=0;--t){const e=r[t];if(A(e)){if(i)throw i;if(s)throw Error(s)}else e(s,i,n)}};let c=[],f=!1;n.usage=(t,e)=>null===t?(f=!0,c=[],n):(f=!1,c.push([t,e||""]),n),n.getUsage=()=>c,n.getUsageDisabled=()=>f,n.getPositionalGroupName=()=>i("Positionals:");let d=[];n.example=(t,e)=>{d.push([t,e||""])};let u=[];n.command=function(t,e,s,i,n=!1){s&&(u=u.map((t=>(t[2]=!1,t)))),u.push([t,e||"",s,i,n])},n.getCommands=()=>u;let p={};n.describe=function(t,e){Array.isArray(t)?t.forEach((t=>{n.describe(t,e)})):"object"==typeof t?Object.keys(t).forEach((e=>{n.describe(e,t[e])})):p[t]=e},n.getDescriptions=()=>p;let m=[];n.epilog=t=>{m.push(t)};let y,b=!1;n.wrap=t=>{b=!0,y=t},n.getWrap=()=>s.getEnv("YARGS_DISABLE_WRAP")?null:(b||(y=function(){const t=80;return s.process.stdColumns?Math.min(t,s.process.stdColumns):t}(),b=!0),y);const v="__yargsString__:";function O(t,e,i){let n=0;return Array.isArray(t)||(t=Object.values(t).map((t=>[t]))),t.forEach((t=>{n=Math.max(s.stringWidth(i?`${i} ${I(t[0])}`:I(t[0]))+$(t[0]),n)})),e&&(n=Math.min(n,parseInt((.5*e).toString(),10))),n}let w;function C(e){return t.getOptions().hiddenOptions.indexOf(e)<0||t.parsed.argv[t.getOptions().showHiddenOpt]}function j(t,e){let s=`[${i("default:")} `;if(void 0===t&&!e)return null;if(e)s+=e;else switch(typeof t){case"string":s+=`"${t}"`;break;case"object":s+=JSON.stringify(t);break;default:s+=t}return`${s}]`}n.deferY18nLookup=t=>v+t,n.help=function(){if(w)return w;!function(){const e=t.getDemandedOptions(),s=t.getOptions();(Object.keys(s.alias)||[]).forEach((i=>{s.alias[i].forEach((r=>{p[r]&&n.describe(i,p[r]),r in e&&t.demandOption(i,e[r]),s.boolean.includes(r)&&t.boolean(i),s.count.includes(r)&&t.count(i),s.string.includes(r)&&t.string(i),s.normalize.includes(r)&&t.normalize(i),s.array.includes(r)&&t.array(i),s.number.includes(r)&&t.number(i)}))}))}();const e=t.customScriptName?t.$0:s.path.basename(t.$0),r=t.getDemandedOptions(),o=t.getDemandedCommands(),a=t.getDeprecatedOptions(),h=t.getGroups(),l=t.getOptions();let g=[];g=g.concat(Object.keys(p)),g=g.concat(Object.keys(r)),g=g.concat(Object.keys(o)),g=g.concat(Object.keys(l.default)),g=g.filter(C),g=Object.keys(g.reduce(((t,e)=>("_"!==e&&(t[e]=!0),t)),{}));const y=n.getWrap(),b=s.cliui({width:y,wrap:!!y});if(!f)if(c.length)c.forEach((t=>{b.div({text:`${t[0].replace(/\$0/g,e)}`}),t[1]&&b.div({text:`${t[1]}`,padding:[1,0,0,0]})})),b.div();else if(u.length){let t=null;t=o._?`${e} <${i("command")}>\n`:`${e} [${i("command")}]\n`,b.div(`${t}`)}if(u.length>1||1===u.length&&!u[0][2]){b.div(i("Commands:"));const s=t.getInternalMethods().getContext(),n=s.commands.length?`${s.commands.join(" ")} `:"";!0===t.getInternalMethods().getParserConfiguration()["sort-commands"]&&(u=u.sort(((t,e)=>t[0].localeCompare(e[0]))));const r=e?`${e} `:"";u.forEach((t=>{const s=`${r}${n}${t[0].replace(/^\$0 ?/,"")}`;b.span({text:s,padding:[0,2,0,2],width:O(u,y,`${e}${n}`)+4},{text:t[1]});const o=[];t[2]&&o.push(`[${i("default")}]`),t[3]&&t[3].length&&o.push(`[${i("aliases:")} ${t[3].join(", ")}]`),t[4]&&("string"==typeof t[4]?o.push(`[${i("deprecated: %s",t[4])}]`):o.push(`[${i("deprecated")}]`)),o.length?b.div({text:o.join(" "),padding:[0,0,0,2],align:"right"}):b.div()})),b.div()}const M=(Object.keys(l.alias)||[]).concat(Object.keys(t.parsed.newAliases)||[]);g=g.filter((e=>!t.parsed.newAliases[e]&&M.every((t=>-1===(l.alias[t]||[]).indexOf(e)))));const _=i("Options:");h[_]||(h[_]=[]),function(t,e,s,i){let n=[],r=null;Object.keys(s).forEach((t=>{n=n.concat(s[t])})),t.forEach((t=>{r=[t].concat(e[t]),r.some((t=>-1!==n.indexOf(t)))||s[i].push(t)}))}(g,l.alias,h,_);const k=t=>/^--/.test(I(t)),x=Object.keys(h).filter((t=>h[t].length>0)).map((t=>({groupName:t,normalizedKeys:h[t].filter(C).map((t=>{if(M.includes(t))return t;for(let e,s=0;void 0!==(e=M[s]);s++)if((l.alias[e]||[]).includes(t))return e;return t}))}))).filter((({normalizedKeys:t})=>t.length>0)).map((({groupName:t,normalizedKeys:e})=>{const s=e.reduce(((e,s)=>(e[s]=[s].concat(l.alias[s]||[]).map((e=>t===n.getPositionalGroupName()?e:(/^[0-9]$/.test(e)?l.boolean.includes(s)?"-":"--":e.length>1?"--":"-")+e)).sort(((t,e)=>k(t)===k(e)?0:k(t)?1:-1)).join(", "),e)),{});return{groupName:t,normalizedKeys:e,switches:s}}));if(x.filter((({groupName:t})=>t!==n.getPositionalGroupName())).some((({normalizedKeys:t,switches:e})=>!t.every((t=>k(e[t])))))&&x.filter((({groupName:t})=>t!==n.getPositionalGroupName())).forEach((({normalizedKeys:t,switches:e})=>{t.forEach((t=>{var s,i;k(e[t])&&(e[t]=(s=e[t],i=4,S(s)?{text:s.text,indentation:s.indentation+i}:{text:s,indentation:i}))}))})),x.forEach((({groupName:e,normalizedKeys:s,switches:o})=>{b.div(e),s.forEach((e=>{const s=o[e];let h=p[e]||"",c=null;h.includes(v)&&(h=i(h.substring(16))),l.boolean.includes(e)&&(c=`[${i("boolean")}]`),l.count.includes(e)&&(c=`[${i("count")}]`),l.string.includes(e)&&(c=`[${i("string")}]`),l.normalize.includes(e)&&(c=`[${i("string")}]`),l.array.includes(e)&&(c=`[${i("array")}]`),l.number.includes(e)&&(c=`[${i("number")}]`);const f=[e in a?(d=a[e],"string"==typeof d?`[${i("deprecated: %s",d)}]`:`[${i("deprecated")}]`):null,c,e in r?`[${i("required")}]`:null,l.choices&&l.choices[e]?`[${i("choices:")} ${n.stringifiedValues(l.choices[e])}]`:null,j(l.default[e],l.defaultDescription[e])].filter(Boolean).join(" ");var d;b.span({text:I(s),padding:[0,2,0,2+$(s)],width:O(o,y)+4},h);const u=!0===t.getInternalMethods().getUsageConfiguration()["hide-types"];f&&!u?b.div({text:f,padding:[0,0,0,2],align:"right"}):b.div()})),b.div()})),d.length&&(b.div(i("Examples:")),d.forEach((t=>{t[0]=t[0].replace(/\$0/g,e)})),d.forEach((t=>{""===t[1]?b.div({text:t[0],padding:[0,2,0,2]}):b.div({text:t[0],padding:[0,2,0,2],width:O(d,y)+4},{text:t[1]})})),b.div()),m.length>0){const t=m.map((t=>t.replace(/\$0/g,e))).join("\n");b.div(`${t}\n`)}return b.toString().replace(/\s*$/,"")},n.cacheHelpMessage=function(){w=this.help()},n.clearCachedHelpMessage=function(){w=void 0},n.hasCachedHelpMessage=function(){return!!w},n.showHelp=e=>{const s=t.getInternalMethods().getLoggerInstance();e||(e="error");("function"==typeof e?e:s[e])(n.help())},n.functionDescription=t=>["(",t.name?s.Parser.decamelize(t.name,"-"):i("generated-value"),")"].join(""),n.stringifiedValues=function(t,e){let s="";const i=e||", ",n=[].concat(t);return t&&n.length?(n.forEach((t=>{s.length&&(s+=i),s+=JSON.stringify(t)})),s):s};let M=null;n.version=t=>{M=t},n.showVersion=e=>{const s=t.getInternalMethods().getLoggerInstance();e||(e="error");("function"==typeof e?e:s[e])(M)},n.reset=function(t){return o=null,l=!1,c=[],f=!1,m=[],d=[],u=[],p=g(p,(e=>!t[e])),n};const _=[];return n.freeze=function(){_.push({failMessage:o,failureOutput:l,usages:c,usageDisabled:f,epilogs:m,examples:d,commands:u,descriptions:p})},n.unfreeze=function(t=!1){const e=_.pop();e&&(t?(p={...e.descriptions,...p},u=[...e.commands,...u],c=[...e.usages,...c],d=[...e.examples,...d],m=[...e.epilogs,...m]):({failMessage:o,failureOutput:l,usages:c,usageDisabled:f,epilogs:m,examples:d,commands:u,descriptions:p}=e))},n}function S(t){return"object"==typeof t}function $(t){return S(t)?t.indentation:0}function I(t){return S(t)?t.text:t}class D{constructor(t,e,s,i){var n,r,o;this.yargs=t,this.usage=e,this.command=s,this.shim=i,this.completionKey="get-yargs-completions",this.aliases=null,this.customCompletionFunction=null,this.indexAfterLastReset=0,this.zshShell=null!==(o=(null===(n=this.shim.getEnv("SHELL"))||void 0===n?void 0:n.includes("zsh"))||(null===(r=this.shim.getEnv("ZSH_NAME"))||void 0===r?void 0:r.includes("zsh")))&&void 0!==o&&o}defaultCompletion(t,e,s,i){const n=this.command.getCommandHandlers();for(let e=0,s=t.length;e{const i=o(s[0]).cmd;if(-1===e.indexOf(i))if(this.zshShell){const e=s[1]||"";t.push(i.replace(/:/g,"\\:")+":"+e)}else t.push(i)}))}optionCompletions(t,e,s,i){if((i.match(/^-/)||""===i&&0===t.length)&&!this.previousArgHasChoices(e)){const s=this.yargs.getOptions(),n=this.yargs.getGroups()[this.usage.getPositionalGroupName()]||[];Object.keys(s.key).forEach((r=>{const o=!!s.configuration["boolean-negation"]&&s.boolean.includes(r);n.includes(r)||s.hiddenOptions.includes(r)||this.argsContainKey(e,r,o)||this.completeOptionKey(r,t,i,o&&!!s.default[r])}))}}choicesFromOptionsCompletions(t,e,s,i){if(this.previousArgHasChoices(e)){const s=this.getPreviousArgChoices(e);s&&s.length>0&&t.push(...s.map((t=>t.replace(/:/g,"\\:"))))}}choicesFromPositionalsCompletions(t,e,s,i){if(""===i&&t.length>0&&this.previousArgHasChoices(e))return;const n=this.yargs.getGroups()[this.usage.getPositionalGroupName()]||[],r=Math.max(this.indexAfterLastReset,this.yargs.getInternalMethods().getContext().commands.length+1),o=n[s._.length-r-1];if(!o)return;const a=this.yargs.getOptions().choices[o]||[];for(const e of a)e.startsWith(i)&&t.push(e.replace(/:/g,"\\:"))}getPreviousArgChoices(t){if(t.length<1)return;let e=t[t.length-1],s="";if(!e.startsWith("-")&&t.length>1&&(s=e,e=t[t.length-2]),!e.startsWith("-"))return;const i=e.replace(/^-+/,""),n=this.yargs.getOptions(),r=[i,...this.yargs.getAliases()[i]||[]];let o;for(const t of r)if(Object.prototype.hasOwnProperty.call(n.key,t)&&Array.isArray(n.choices[t])){o=n.choices[t];break}return o?o.filter((t=>!s||t.startsWith(s))):void 0}previousArgHasChoices(t){const e=this.getPreviousArgChoices(t);return void 0!==e&&e.length>0}argsContainKey(t,e,s){const i=e=>-1!==t.indexOf((/^[^0-9]$/.test(e)?"-":"--")+e);if(i(e))return!0;if(s&&i(`no-${e}`))return!0;if(this.aliases)for(const t of this.aliases[e])if(i(t))return!0;return!1}completeOptionKey(t,e,s,i){var n,r,o,a;let h=t;if(this.zshShell){const e=this.usage.getDescriptions(),s=null===(r=null===(n=null==this?void 0:this.aliases)||void 0===n?void 0:n[t])||void 0===r?void 0:r.find((t=>{const s=e[t];return"string"==typeof s&&s.length>0})),i=s?e[s]:void 0,l=null!==(a=null!==(o=e[t])&&void 0!==o?o:i)&&void 0!==a?a:"";h=`${t.replace(/:/g,"\\:")}:${l.replace("__yargsString__:","").replace(/(\r\n|\n|\r)/gm," ")}`}const l=!/^--/.test(s)&&(t=>/^[^0-9]$/.test(t))(t)?"-":"--";e.push(l+h),i&&e.push(l+"no-"+h)}customCompletion(t,e,s,i){if(d(this.customCompletionFunction,null,this.shim),this.customCompletionFunction.length<3){const t=this.customCompletionFunction(s,e);return f(t)?t.then((t=>{this.shim.process.nextTick((()=>{i(null,t)}))})).catch((t=>{this.shim.process.nextTick((()=>{i(t,void 0)}))})):i(null,t)}return function(t){return t.length>3}(this.customCompletionFunction)?this.customCompletionFunction(s,e,((n=i)=>this.defaultCompletion(t,e,s,n)),(t=>{i(null,t)})):this.customCompletionFunction(s,e,(t=>{i(null,t)}))}getCompletion(t,e){const s=t.length?t[t.length-1]:"",i=this.yargs.parse(t,!0),n=this.customCompletionFunction?i=>this.customCompletion(t,i,s,e):i=>this.defaultCompletion(t,i,s,e);return f(i)?i.then(n):n(i)}generateCompletionScript(t,e){let s=this.zshShell?'#compdef {{app_name}}\n###-begin-{{app_name}}-completions-###\n#\n# yargs command completion script\n#\n# Installation: {{app_path}} {{completion_command}} >> ~/.zshrc\n#    or {{app_path}} {{completion_command}} >> ~/.zprofile on OSX.\n#\n_{{app_name}}_yargs_completions()\n{\n  local reply\n  local si=$IFS\n  IFS=$\'\n\' reply=($(COMP_CWORD="$((CURRENT-1))" COMP_LINE="$BUFFER" COMP_POINT="$CURSOR" {{app_path}} --get-yargs-completions "${words[@]}"))\n  IFS=$si\n  _describe \'values\' reply\n}\ncompdef _{{app_name}}_yargs_completions {{app_name}}\n###-end-{{app_name}}-completions-###\n':'###-begin-{{app_name}}-completions-###\n#\n# yargs command completion script\n#\n# Installation: {{app_path}} {{completion_command}} >> ~/.bashrc\n#    or {{app_path}} {{completion_command}} >> ~/.bash_profile on OSX.\n#\n_{{app_name}}_yargs_completions()\n{\n    local cur_word args type_list\n\n    cur_word="${COMP_WORDS[COMP_CWORD]}"\n    args=("${COMP_WORDS[@]}")\n\n    # ask yargs to generate completions.\n    type_list=$({{app_path}} --get-yargs-completions "${args[@]}")\n\n    COMPREPLY=( $(compgen -W "${type_list}" -- ${cur_word}) )\n\n    # if no match was found, fall back to filename completion\n    if [ ${#COMPREPLY[@]} -eq 0 ]; then\n      COMPREPLY=()\n    fi\n\n    return 0\n}\ncomplete -o bashdefault -o default -F _{{app_name}}_yargs_completions {{app_name}}\n###-end-{{app_name}}-completions-###\n';const i=this.shim.path.basename(t);return t.match(/\.js$/)&&(t=`./${t}`),s=s.replace(/{{app_name}}/g,i),s=s.replace(/{{completion_command}}/g,e),s.replace(/{{app_path}}/g,t)}registerFunction(t){this.customCompletionFunction=t}setParsed(t){this.aliases=t.aliases}}function N(t,e){if(0===t.length)return e.length;if(0===e.length)return t.length;const s=[];let i,n;for(i=0;i<=e.length;i++)s[i]=[i];for(n=0;n<=t.length;n++)s[0][n]=n;for(i=1;i<=e.length;i++)for(n=1;n<=t.length;n++)e.charAt(i-1)===t.charAt(n-1)?s[i][n]=s[i-1][n-1]:i>1&&n>1&&e.charAt(i-2)===t.charAt(n-1)&&e.charAt(i-1)===t.charAt(n-2)?s[i][n]=s[i-2][n-2]+1:s[i][n]=Math.min(s[i-1][n-1]+1,Math.min(s[i][n-1]+1,s[i-1][n]+1));return s[e.length][t.length]}const H=["$0","--","_"];var z,W,q,U,F,L,V,G,R,T,B,Y,K,J,Z,X,Q,tt,et,st,it,nt,rt,ot,at,ht,lt,ct,ft,dt,ut,pt,gt,mt,yt;const bt=Symbol("copyDoubleDash"),vt=Symbol("copyDoubleDash"),Ot=Symbol("deleteFromParserHintObject"),wt=Symbol("emitWarning"),Ct=Symbol("freeze"),jt=Symbol("getDollarZero"),Mt=Symbol("getParserConfiguration"),_t=Symbol("getUsageConfiguration"),kt=Symbol("guessLocale"),xt=Symbol("guessVersion"),Et=Symbol("parsePositionalNumbers"),At=Symbol("pkgUp"),Pt=Symbol("populateParserHintArray"),St=Symbol("populateParserHintSingleValueDictionary"),$t=Symbol("populateParserHintArrayDictionary"),It=Symbol("populateParserHintDictionary"),Dt=Symbol("sanitizeKey"),Nt=Symbol("setKey"),Ht=Symbol("unfreeze"),zt=Symbol("validateAsync"),Wt=Symbol("getCommandInstance"),qt=Symbol("getContext"),Ut=Symbol("getHasOutput"),Ft=Symbol("getLoggerInstance"),Lt=Symbol("getParseContext"),Vt=Symbol("getUsageInstance"),Gt=Symbol("getValidationInstance"),Rt=Symbol("hasParseCallback"),Tt=Symbol("isGlobalContext"),Bt=Symbol("postProcess"),Yt=Symbol("rebase"),Kt=Symbol("reset"),Jt=Symbol("runYargsParserAndExecuteCommands"),Zt=Symbol("runValidation"),Xt=Symbol("setHasOutput"),Qt=Symbol("kTrackManuallySetKeys");class te{constructor(t=[],e,s,i){this.customScriptName=!1,this.parsed=!1,z.set(this,void 0),W.set(this,void 0),q.set(this,{commands:[],fullCommands:[]}),U.set(this,null),F.set(this,null),L.set(this,"show-hidden"),V.set(this,null),G.set(this,!0),R.set(this,{}),T.set(this,!0),B.set(this,[]),Y.set(this,void 0),K.set(this,{}),J.set(this,!1),Z.set(this,null),X.set(this,!0),Q.set(this,void 0),tt.set(this,""),et.set(this,void 0),st.set(this,void 0),it.set(this,{}),nt.set(this,null),rt.set(this,null),ot.set(this,{}),at.set(this,{}),ht.set(this,void 0),lt.set(this,!1),ct.set(this,void 0),ft.set(this,!1),dt.set(this,!1),ut.set(this,!1),pt.set(this,void 0),gt.set(this,{}),mt.set(this,null),yt.set(this,void 0),O(this,ct,i,"f"),O(this,ht,t,"f"),O(this,W,e,"f"),O(this,st,s,"f"),O(this,Y,new w(this),"f"),this.$0=this[jt](),this[Kt](),O(this,z,v(this,z,"f"),"f"),O(this,pt,v(this,pt,"f"),"f"),O(this,yt,v(this,yt,"f"),"f"),O(this,et,v(this,et,"f"),"f"),v(this,et,"f").showHiddenOpt=v(this,L,"f"),O(this,Q,this[vt](),"f")}addHelpOpt(t,e){return h("[string|boolean] [string]",[t,e],arguments.length),v(this,Z,"f")&&(this[Ot](v(this,Z,"f")),O(this,Z,null,"f")),!1===t&&void 0===e||(O(this,Z,"string"==typeof t?t:"help","f"),this.boolean(v(this,Z,"f")),this.describe(v(this,Z,"f"),e||v(this,pt,"f").deferY18nLookup("Show help"))),this}help(t,e){return this.addHelpOpt(t,e)}addShowHiddenOpt(t,e){if(h("[string|boolean] [string]",[t,e],arguments.length),!1===t&&void 0===e)return this;const s="string"==typeof t?t:v(this,L,"f");return this.boolean(s),this.describe(s,e||v(this,pt,"f").deferY18nLookup("Show hidden options")),v(this,et,"f").showHiddenOpt=s,this}showHidden(t,e){return this.addShowHiddenOpt(t,e)}alias(t,e){return h(" [string|array]",[t,e],arguments.length),this[$t](this.alias.bind(this),"alias",t,e),this}array(t){return h("",[t],arguments.length),this[Pt]("array",t),this[Qt](t),this}boolean(t){return h("",[t],arguments.length),this[Pt]("boolean",t),this[Qt](t),this}check(t,e){return h(" [boolean]",[t,e],arguments.length),this.middleware(((e,s)=>j((()=>t(e,s.getOptions())),(s=>(s?("string"==typeof s||s instanceof Error)&&v(this,pt,"f").fail(s.toString(),s):v(this,pt,"f").fail(v(this,ct,"f").y18n.__("Argument check failed: %s",t.toString())),e)),(t=>(v(this,pt,"f").fail(t.message?t.message:t.toString(),t),e)))),!1,e),this}choices(t,e){return h(" [string|array]",[t,e],arguments.length),this[$t](this.choices.bind(this),"choices",t,e),this}coerce(t,s){if(h(" [function]",[t,s],arguments.length),Array.isArray(t)){if(!s)throw new e("coerce callback must be provided");for(const e of t)this.coerce(e,s);return this}if("object"==typeof t){for(const e of Object.keys(t))this.coerce(e,t[e]);return this}if(!s)throw new e("coerce callback must be provided");return v(this,et,"f").key[t]=!0,v(this,Y,"f").addCoerceMiddleware(((i,n)=>{let r;return Object.prototype.hasOwnProperty.call(i,t)?j((()=>(r=n.getAliases(),s(i[t]))),(e=>{i[t]=e;const s=n.getInternalMethods().getParserConfiguration()["strip-aliased"];if(r[t]&&!0!==s)for(const s of r[t])i[s]=e;return i}),(t=>{throw new e(t.message)})):i}),t),this}conflicts(t,e){return h(" [string|array]",[t,e],arguments.length),v(this,yt,"f").conflicts(t,e),this}config(t="config",e,s){return h("[object|string] [string|function] [function]",[t,e,s],arguments.length),"object"!=typeof t||Array.isArray(t)?("function"==typeof e&&(s=e,e=void 0),this.describe(t,e||v(this,pt,"f").deferY18nLookup("Path to JSON config file")),(Array.isArray(t)?t:[t]).forEach((t=>{v(this,et,"f").config[t]=s||!0})),this):(t=n(t,v(this,W,"f"),this[Mt]()["deep-merge-config"]||!1,v(this,ct,"f")),v(this,et,"f").configObjects=(v(this,et,"f").configObjects||[]).concat(t),this)}completion(t,e,s){return h("[string] [string|boolean|function] [function]",[t,e,s],arguments.length),"function"==typeof e&&(s=e,e=void 0),O(this,F,t||v(this,F,"f")||"completion","f"),e||!1===e||(e="generate completion script"),this.command(v(this,F,"f"),e),s&&v(this,U,"f").registerFunction(s),this}command(t,e,s,i,n,r){return h(" [string|boolean] [function|object] [function] [array] [boolean|string]",[t,e,s,i,n,r],arguments.length),v(this,z,"f").addHandler(t,e,s,i,n,r),this}commands(t,e,s,i,n,r){return this.command(t,e,s,i,n,r)}commandDir(t,e){h(" [object]",[t,e],arguments.length);const s=v(this,st,"f")||v(this,ct,"f").require;return v(this,z,"f").addDirectory(t,s,v(this,ct,"f").getCallerFile(),e),this}count(t){return h("",[t],arguments.length),this[Pt]("count",t),this[Qt](t),this}default(t,e,s){return h(" [*] [string]",[t,e,s],arguments.length),s&&(u(t,v(this,ct,"f")),v(this,et,"f").defaultDescription[t]=s),"function"==typeof e&&(u(t,v(this,ct,"f")),v(this,et,"f").defaultDescription[t]||(v(this,et,"f").defaultDescription[t]=v(this,pt,"f").functionDescription(e)),e=e.call()),this[St](this.default.bind(this),"default",t,e),this}defaults(t,e,s){return this.default(t,e,s)}demandCommand(t=1,e,s,i){return h("[number] [number|string] [string|null|undefined] [string|null|undefined]",[t,e,s,i],arguments.length),"number"!=typeof e&&(s=e,e=1/0),this.global("_",!1),v(this,et,"f").demandedCommands._={min:t,max:e,minMsg:s,maxMsg:i},this}demand(t,e,s){return Array.isArray(e)?(e.forEach((t=>{d(s,!0,v(this,ct,"f")),this.demandOption(t,s)})),e=1/0):"number"!=typeof e&&(s=e,e=1/0),"number"==typeof t?(d(s,!0,v(this,ct,"f")),this.demandCommand(t,e,s,s)):Array.isArray(t)?t.forEach((t=>{d(s,!0,v(this,ct,"f")),this.demandOption(t,s)})):"string"==typeof s?this.demandOption(t,s):!0!==s&&void 0!==s||this.demandOption(t),this}demandOption(t,e){return h(" [string]",[t,e],arguments.length),this[St](this.demandOption.bind(this),"demandedOptions",t,e),this}deprecateOption(t,e){return h(" [string|boolean]",[t,e],arguments.length),v(this,et,"f").deprecatedOptions[t]=e,this}describe(t,e){return h(" [string]",[t,e],arguments.length),this[Nt](t,!0),v(this,pt,"f").describe(t,e),this}detectLocale(t){return h("",[t],arguments.length),O(this,G,t,"f"),this}env(t){return h("[string|boolean]",[t],arguments.length),!1===t?delete v(this,et,"f").envPrefix:v(this,et,"f").envPrefix=t||"",this}epilogue(t){return h("",[t],arguments.length),v(this,pt,"f").epilog(t),this}epilog(t){return this.epilogue(t)}example(t,e){return h(" [string]",[t,e],arguments.length),Array.isArray(t)?t.forEach((t=>this.example(...t))):v(this,pt,"f").example(t,e),this}exit(t,e){O(this,J,!0,"f"),O(this,V,e,"f"),v(this,T,"f")&&v(this,ct,"f").process.exit(t)}exitProcess(t=!0){return h("[boolean]",[t],arguments.length),O(this,T,t,"f"),this}fail(t){if(h("",[t],arguments.length),"boolean"==typeof t&&!1!==t)throw new e("Invalid first argument. Expected function or boolean 'false'");return v(this,pt,"f").failFn(t),this}getAliases(){return this.parsed?this.parsed.aliases:{}}async getCompletion(t,e){return h(" [function]",[t,e],arguments.length),e?v(this,U,"f").getCompletion(t,e):new Promise(((e,s)=>{v(this,U,"f").getCompletion(t,((t,i)=>{t?s(t):e(i)}))}))}getDemandedOptions(){return h([],0),v(this,et,"f").demandedOptions}getDemandedCommands(){return h([],0),v(this,et,"f").demandedCommands}getDeprecatedOptions(){return h([],0),v(this,et,"f").deprecatedOptions}getDetectLocale(){return v(this,G,"f")}getExitProcess(){return v(this,T,"f")}getGroups(){return Object.assign({},v(this,K,"f"),v(this,at,"f"))}getHelp(){if(O(this,J,!0,"f"),!v(this,pt,"f").hasCachedHelpMessage()){if(!this.parsed){const t=this[Jt](v(this,ht,"f"),void 0,void 0,0,!0);if(f(t))return t.then((()=>v(this,pt,"f").help()))}const t=v(this,z,"f").runDefaultBuilderOn(this);if(f(t))return t.then((()=>v(this,pt,"f").help()))}return Promise.resolve(v(this,pt,"f").help())}getOptions(){return v(this,et,"f")}getStrict(){return v(this,ft,"f")}getStrictCommands(){return v(this,dt,"f")}getStrictOptions(){return v(this,ut,"f")}global(t,e){return h(" [boolean]",[t,e],arguments.length),t=[].concat(t),!1!==e?v(this,et,"f").local=v(this,et,"f").local.filter((e=>-1===t.indexOf(e))):t.forEach((t=>{v(this,et,"f").local.includes(t)||v(this,et,"f").local.push(t)})),this}group(t,e){h(" ",[t,e],arguments.length);const s=v(this,at,"f")[e]||v(this,K,"f")[e];v(this,at,"f")[e]&&delete v(this,at,"f")[e];const i={};return v(this,K,"f")[e]=(s||[]).concat(t).filter((t=>!i[t]&&(i[t]=!0))),this}hide(t){return h("",[t],arguments.length),v(this,et,"f").hiddenOptions.push(t),this}implies(t,e){return h(" [number|string|array]",[t,e],arguments.length),v(this,yt,"f").implies(t,e),this}locale(t){return h("[string]",[t],arguments.length),void 0===t?(this[kt](),v(this,ct,"f").y18n.getLocale()):(O(this,G,!1,"f"),v(this,ct,"f").y18n.setLocale(t),this)}middleware(t,e,s){return v(this,Y,"f").addMiddleware(t,!!e,s)}nargs(t,e){return h(" [number]",[t,e],arguments.length),this[St](this.nargs.bind(this),"narg",t,e),this}normalize(t){return h("",[t],arguments.length),this[Pt]("normalize",t),this}number(t){return h("",[t],arguments.length),this[Pt]("number",t),this[Qt](t),this}option(t,e){if(h(" [object]",[t,e],arguments.length),"object"==typeof t)Object.keys(t).forEach((e=>{this.options(e,t[e])}));else{"object"!=typeof e&&(e={}),this[Qt](t),!v(this,mt,"f")||"version"!==t&&"version"!==(null==e?void 0:e.alias)||this[wt](['"version" is a reserved word.',"Please do one of the following:",'- Disable version with `yargs.version(false)` if using "version" as an option',"- Use the built-in `yargs.version` method instead (if applicable)","- Use a different option key","https://yargs.js.org/docs/#api-reference-version"].join("\n"),void 0,"versionWarning"),v(this,et,"f").key[t]=!0,e.alias&&this.alias(t,e.alias);const s=e.deprecate||e.deprecated;s&&this.deprecateOption(t,s);const i=e.demand||e.required||e.require;i&&this.demand(t,i),e.demandOption&&this.demandOption(t,"string"==typeof e.demandOption?e.demandOption:void 0),e.conflicts&&this.conflicts(t,e.conflicts),"default"in e&&this.default(t,e.default),void 0!==e.implies&&this.implies(t,e.implies),void 0!==e.nargs&&this.nargs(t,e.nargs),e.config&&this.config(t,e.configParser),e.normalize&&this.normalize(t),e.choices&&this.choices(t,e.choices),e.coerce&&this.coerce(t,e.coerce),e.group&&this.group(t,e.group),(e.boolean||"boolean"===e.type)&&(this.boolean(t),e.alias&&this.boolean(e.alias)),(e.array||"array"===e.type)&&(this.array(t),e.alias&&this.array(e.alias)),(e.number||"number"===e.type)&&(this.number(t),e.alias&&this.number(e.alias)),(e.string||"string"===e.type)&&(this.string(t),e.alias&&this.string(e.alias)),(e.count||"count"===e.type)&&this.count(t),"boolean"==typeof e.global&&this.global(t,e.global),e.defaultDescription&&(v(this,et,"f").defaultDescription[t]=e.defaultDescription),e.skipValidation&&this.skipValidation(t);const n=e.describe||e.description||e.desc,r=v(this,pt,"f").getDescriptions();Object.prototype.hasOwnProperty.call(r,t)&&"string"!=typeof n||this.describe(t,n),e.hidden&&this.hide(t),e.requiresArg&&this.requiresArg(t)}return this}options(t,e){return this.option(t,e)}parse(t,e,s){h("[string|array] [function|boolean|object] [function]",[t,e,s],arguments.length),this[Ct](),void 0===t&&(t=v(this,ht,"f")),"object"==typeof e&&(O(this,rt,e,"f"),e=s),"function"==typeof e&&(O(this,nt,e,"f"),e=!1),e||O(this,ht,t,"f"),v(this,nt,"f")&&O(this,T,!1,"f");const i=this[Jt](t,!!e),n=this.parsed;return v(this,U,"f").setParsed(this.parsed),f(i)?i.then((t=>(v(this,nt,"f")&&v(this,nt,"f").call(this,v(this,V,"f"),t,v(this,tt,"f")),t))).catch((t=>{throw v(this,nt,"f")&&v(this,nt,"f")(t,this.parsed.argv,v(this,tt,"f")),t})).finally((()=>{this[Ht](),this.parsed=n})):(v(this,nt,"f")&&v(this,nt,"f").call(this,v(this,V,"f"),i,v(this,tt,"f")),this[Ht](),this.parsed=n,i)}parseAsync(t,e,s){const i=this.parse(t,e,s);return f(i)?i:Promise.resolve(i)}parseSync(t,s,i){const n=this.parse(t,s,i);if(f(n))throw new e(".parseSync() must not be used with asynchronous builders, handlers, or middleware");return n}parserConfiguration(t){return h("",[t],arguments.length),O(this,it,t,"f"),this}pkgConf(t,e){h(" [string]",[t,e],arguments.length);let s=null;const i=this[At](e||v(this,W,"f"));return i[t]&&"object"==typeof i[t]&&(s=n(i[t],e||v(this,W,"f"),this[Mt]()["deep-merge-config"]||!1,v(this,ct,"f")),v(this,et,"f").configObjects=(v(this,et,"f").configObjects||[]).concat(s)),this}positional(t,e){h(" ",[t,e],arguments.length);const s=["default","defaultDescription","implies","normalize","choices","conflicts","coerce","type","describe","desc","description","alias"];e=g(e,((t,e)=>!("type"===t&&!["string","number","boolean"].includes(e))&&s.includes(t)));const i=v(this,q,"f").fullCommands[v(this,q,"f").fullCommands.length-1],n=i?v(this,z,"f").cmdToParseOptions(i):{array:[],alias:{},default:{},demand:{}};return p(n).forEach((s=>{const i=n[s];Array.isArray(i)?-1!==i.indexOf(t)&&(e[s]=!0):i[t]&&!(s in e)&&(e[s]=i[t])})),this.group(t,v(this,pt,"f").getPositionalGroupName()),this.option(t,e)}recommendCommands(t=!0){return h("[boolean]",[t],arguments.length),O(this,lt,t,"f"),this}required(t,e,s){return this.demand(t,e,s)}require(t,e,s){return this.demand(t,e,s)}requiresArg(t){return h(" [number]",[t],arguments.length),"string"==typeof t&&v(this,et,"f").narg[t]||this[St](this.requiresArg.bind(this),"narg",t,NaN),this}showCompletionScript(t,e){return h("[string] [string]",[t,e],arguments.length),t=t||this.$0,v(this,Q,"f").log(v(this,U,"f").generateCompletionScript(t,e||v(this,F,"f")||"completion")),this}showHelp(t){if(h("[string|function]",[t],arguments.length),O(this,J,!0,"f"),!v(this,pt,"f").hasCachedHelpMessage()){if(!this.parsed){const e=this[Jt](v(this,ht,"f"),void 0,void 0,0,!0);if(f(e))return e.then((()=>{v(this,pt,"f").showHelp(t)})),this}const e=v(this,z,"f").runDefaultBuilderOn(this);if(f(e))return e.then((()=>{v(this,pt,"f").showHelp(t)})),this}return v(this,pt,"f").showHelp(t),this}scriptName(t){return this.customScriptName=!0,this.$0=t,this}showHelpOnFail(t,e){return h("[boolean|string] [string]",[t,e],arguments.length),v(this,pt,"f").showHelpOnFail(t,e),this}showVersion(t){return h("[string|function]",[t],arguments.length),v(this,pt,"f").showVersion(t),this}skipValidation(t){return h("",[t],arguments.length),this[Pt]("skipValidation",t),this}strict(t){return h("[boolean]",[t],arguments.length),O(this,ft,!1!==t,"f"),this}strictCommands(t){return h("[boolean]",[t],arguments.length),O(this,dt,!1!==t,"f"),this}strictOptions(t){return h("[boolean]",[t],arguments.length),O(this,ut,!1!==t,"f"),this}string(t){return h("",[t],arguments.length),this[Pt]("string",t),this[Qt](t),this}terminalWidth(){return h([],0),v(this,ct,"f").process.stdColumns}updateLocale(t){return this.updateStrings(t)}updateStrings(t){return h("",[t],arguments.length),O(this,G,!1,"f"),v(this,ct,"f").y18n.updateLocale(t),this}usage(t,s,i,n){if(h(" [string|boolean] [function|object] [function]",[t,s,i,n],arguments.length),void 0!==s){if(d(t,null,v(this,ct,"f")),(t||"").match(/^\$0( |$)/))return this.command(t,s,i,n);throw new e(".usage() description must start with $0 if being used as alias for .command()")}return v(this,pt,"f").usage(t),this}usageConfiguration(t){return h("",[t],arguments.length),O(this,gt,t,"f"),this}version(t,e,s){const i="version";if(h("[boolean|string] [string] [string]",[t,e,s],arguments.length),v(this,mt,"f")&&(this[Ot](v(this,mt,"f")),v(this,pt,"f").version(void 0),O(this,mt,null,"f")),0===arguments.length)s=this[xt](),t=i;else if(1===arguments.length){if(!1===t)return this;s=t,t=i}else 2===arguments.length&&(s=e,e=void 0);return O(this,mt,"string"==typeof t?t:i,"f"),e=e||v(this,pt,"f").deferY18nLookup("Show version number"),v(this,pt,"f").version(s||void 0),this.boolean(v(this,mt,"f")),this.describe(v(this,mt,"f"),e),this}wrap(t){return h("",[t],arguments.length),v(this,pt,"f").wrap(t),this}[(z=new WeakMap,W=new WeakMap,q=new WeakMap,U=new WeakMap,F=new WeakMap,L=new WeakMap,V=new WeakMap,G=new WeakMap,R=new WeakMap,T=new WeakMap,B=new WeakMap,Y=new WeakMap,K=new WeakMap,J=new WeakMap,Z=new WeakMap,X=new WeakMap,Q=new WeakMap,tt=new WeakMap,et=new WeakMap,st=new WeakMap,it=new WeakMap,nt=new WeakMap,rt=new WeakMap,ot=new WeakMap,at=new WeakMap,ht=new WeakMap,lt=new WeakMap,ct=new WeakMap,ft=new WeakMap,dt=new WeakMap,ut=new WeakMap,pt=new WeakMap,gt=new WeakMap,mt=new WeakMap,yt=new WeakMap,bt)](t){if(!t._||!t["--"])return t;t._.push.apply(t._,t["--"]);try{delete t["--"]}catch(t){}return t}[vt](){return{log:(...t)=>{this[Rt]()||console.log(...t),O(this,J,!0,"f"),v(this,tt,"f").length&&O(this,tt,v(this,tt,"f")+"\n","f"),O(this,tt,v(this,tt,"f")+t.join(" "),"f")},error:(...t)=>{this[Rt]()||console.error(...t),O(this,J,!0,"f"),v(this,tt,"f").length&&O(this,tt,v(this,tt,"f")+"\n","f"),O(this,tt,v(this,tt,"f")+t.join(" "),"f")}}}[Ot](t){p(v(this,et,"f")).forEach((e=>{if("configObjects"===e)return;const s=v(this,et,"f")[e];Array.isArray(s)?s.includes(t)&&s.splice(s.indexOf(t),1):"object"==typeof s&&delete s[t]})),delete v(this,pt,"f").getDescriptions()[t]}[wt](t,e,s){v(this,R,"f")[s]||(v(this,ct,"f").process.emitWarning(t,e),v(this,R,"f")[s]=!0)}[Ct](){v(this,B,"f").push({options:v(this,et,"f"),configObjects:v(this,et,"f").configObjects.slice(0),exitProcess:v(this,T,"f"),groups:v(this,K,"f"),strict:v(this,ft,"f"),strictCommands:v(this,dt,"f"),strictOptions:v(this,ut,"f"),completionCommand:v(this,F,"f"),output:v(this,tt,"f"),exitError:v(this,V,"f"),hasOutput:v(this,J,"f"),parsed:this.parsed,parseFn:v(this,nt,"f"),parseContext:v(this,rt,"f")}),v(this,pt,"f").freeze(),v(this,yt,"f").freeze(),v(this,z,"f").freeze(),v(this,Y,"f").freeze()}[jt](){let t,e="";return t=/\b(node|iojs|electron)(\.exe)?$/.test(v(this,ct,"f").process.argv()[0])?v(this,ct,"f").process.argv().slice(1,2):v(this,ct,"f").process.argv().slice(0,1),e=t.map((t=>{const e=this[Yt](v(this,W,"f"),t);return t.match(/^(\/|([a-zA-Z]:)?\\)/)&&e.lengthe.includes("package.json")?"package.json":void 0));d(i,void 0,v(this,ct,"f")),s=JSON.parse(v(this,ct,"f").readFileSync(i,"utf8"))}catch(t){}return v(this,ot,"f")[e]=s||{},v(this,ot,"f")[e]}[Pt](t,e){(e=[].concat(e)).forEach((e=>{e=this[Dt](e),v(this,et,"f")[t].push(e)}))}[St](t,e,s,i){this[It](t,e,s,i,((t,e,s)=>{v(this,et,"f")[t][e]=s}))}[$t](t,e,s,i){this[It](t,e,s,i,((t,e,s)=>{v(this,et,"f")[t][e]=(v(this,et,"f")[t][e]||[]).concat(s)}))}[It](t,e,s,i,n){if(Array.isArray(s))s.forEach((e=>{t(e,i)}));else if((t=>"object"==typeof t)(s))for(const e of p(s))t(e,s[e]);else n(e,this[Dt](s),i)}[Dt](t){return"__proto__"===t?"___proto___":t}[Nt](t,e){return this[St](this[Nt].bind(this),"key",t,e),this}[Ht](){var t,e,s,i,n,r,o,a,h,l,c,f;const u=v(this,B,"f").pop();let p;d(u,void 0,v(this,ct,"f")),t=this,e=this,s=this,i=this,n=this,r=this,o=this,a=this,h=this,l=this,c=this,f=this,({options:{set value(e){O(t,et,e,"f")}}.value,configObjects:p,exitProcess:{set value(t){O(e,T,t,"f")}}.value,groups:{set value(t){O(s,K,t,"f")}}.value,output:{set value(t){O(i,tt,t,"f")}}.value,exitError:{set value(t){O(n,V,t,"f")}}.value,hasOutput:{set value(t){O(r,J,t,"f")}}.value,parsed:this.parsed,strict:{set value(t){O(o,ft,t,"f")}}.value,strictCommands:{set value(t){O(a,dt,t,"f")}}.value,strictOptions:{set value(t){O(h,ut,t,"f")}}.value,completionCommand:{set value(t){O(l,F,t,"f")}}.value,parseFn:{set value(t){O(c,nt,t,"f")}}.value,parseContext:{set value(t){O(f,rt,t,"f")}}.value}=u),v(this,et,"f").configObjects=p,v(this,pt,"f").unfreeze(),v(this,yt,"f").unfreeze(),v(this,z,"f").unfreeze(),v(this,Y,"f").unfreeze()}[zt](t,e){return j(e,(e=>(t(e),e)))}getInternalMethods(){return{getCommandInstance:this[Wt].bind(this),getContext:this[qt].bind(this),getHasOutput:this[Ut].bind(this),getLoggerInstance:this[Ft].bind(this),getParseContext:this[Lt].bind(this),getParserConfiguration:this[Mt].bind(this),getUsageConfiguration:this[_t].bind(this),getUsageInstance:this[Vt].bind(this),getValidationInstance:this[Gt].bind(this),hasParseCallback:this[Rt].bind(this),isGlobalContext:this[Tt].bind(this),postProcess:this[Bt].bind(this),reset:this[Kt].bind(this),runValidation:this[Zt].bind(this),runYargsParserAndExecuteCommands:this[Jt].bind(this),setHasOutput:this[Xt].bind(this)}}[Wt](){return v(this,z,"f")}[qt](){return v(this,q,"f")}[Ut](){return v(this,J,"f")}[Ft](){return v(this,Q,"f")}[Lt](){return v(this,rt,"f")||{}}[Vt](){return v(this,pt,"f")}[Gt](){return v(this,yt,"f")}[Rt](){return!!v(this,nt,"f")}[Tt](){return v(this,X,"f")}[Bt](t,e,s,i){if(s)return t;if(f(t))return t;e||(t=this[bt](t));return(this[Mt]()["parse-positional-numbers"]||void 0===this[Mt]()["parse-positional-numbers"])&&(t=this[Et](t)),i&&(t=C(t,this,v(this,Y,"f").getMiddleware(),!1)),t}[Kt](t={}){O(this,et,v(this,et,"f")||{},"f");const e={};e.local=v(this,et,"f").local||[],e.configObjects=v(this,et,"f").configObjects||[];const s={};e.local.forEach((e=>{s[e]=!0,(t[e]||[]).forEach((t=>{s[t]=!0}))})),Object.assign(v(this,at,"f"),Object.keys(v(this,K,"f")).reduce(((t,e)=>{const i=v(this,K,"f")[e].filter((t=>!(t in s)));return i.length>0&&(t[e]=i),t}),{})),O(this,K,{},"f");return["array","boolean","string","skipValidation","count","normalize","number","hiddenOptions"].forEach((t=>{e[t]=(v(this,et,"f")[t]||[]).filter((t=>!s[t]))})),["narg","key","alias","default","defaultDescription","config","choices","demandedOptions","demandedCommands","deprecatedOptions"].forEach((t=>{e[t]=g(v(this,et,"f")[t],(t=>!s[t]))})),e.envPrefix=v(this,et,"f").envPrefix,O(this,et,e,"f"),O(this,pt,v(this,pt,"f")?v(this,pt,"f").reset(s):P(this,v(this,ct,"f")),"f"),O(this,yt,v(this,yt,"f")?v(this,yt,"f").reset(s):function(t,e,s){const i=s.y18n.__,n=s.y18n.__n,r={nonOptionCount:function(s){const i=t.getDemandedCommands(),r=s._.length+(s["--"]?s["--"].length:0)-t.getInternalMethods().getContext().commands.length;i._&&(ri._.max)&&(ri._.max&&(void 0!==i._.maxMsg?e.fail(i._.maxMsg?i._.maxMsg.replace(/\$0/g,r.toString()).replace(/\$1/,i._.max.toString()):null):e.fail(n("Too many non-option arguments: got %s, maximum of %s","Too many non-option arguments: got %s, maximum of %s",r,r.toString(),i._.max.toString()))))},positionalCount:function(t,s){s{H.includes(e)||Object.prototype.hasOwnProperty.call(o,e)||Object.prototype.hasOwnProperty.call(t.getInternalMethods().getParseContext(),e)||r.isValidAndSomeAliasIsNotNew(e,i)||f.push(e)})),h&&(d.commands.length>0||c.length>0||a)&&s._.slice(d.commands.length).forEach((t=>{c.includes(""+t)||f.push(""+t)})),h){const e=(null===(l=t.getDemandedCommands()._)||void 0===l?void 0:l.max)||0,i=d.commands.length+e;i{t=String(t),d.commands.includes(t)||f.includes(t)||f.push(t)}))}f.length&&e.fail(n("Unknown argument: %s","Unknown arguments: %s",f.length,f.map((t=>t.trim()?t:`"${t}"`)).join(", ")))},unknownCommands:function(s){const i=t.getInternalMethods().getCommandInstance().getCommands(),r=[],o=t.getInternalMethods().getContext();return(o.commands.length>0||i.length>0)&&s._.slice(o.commands.length).forEach((t=>{i.includes(""+t)||r.push(""+t)})),r.length>0&&(e.fail(n("Unknown command: %s","Unknown commands: %s",r.length,r.join(", "))),!0)},isValidAndSomeAliasIsNotNew:function(e,s){if(!Object.prototype.hasOwnProperty.call(s,e))return!1;const i=t.parsed.newAliases;return[e,...s[e]].some((t=>!Object.prototype.hasOwnProperty.call(i,t)||!i[e]))},limitedChoices:function(s){const n=t.getOptions(),r={};if(!Object.keys(n.choices).length)return;Object.keys(s).forEach((t=>{-1===H.indexOf(t)&&Object.prototype.hasOwnProperty.call(n.choices,t)&&[].concat(s[t]).forEach((e=>{-1===n.choices[t].indexOf(e)&&void 0!==e&&(r[t]=(r[t]||[]).concat(e))}))}));const o=Object.keys(r);if(!o.length)return;let a=i("Invalid values:");o.forEach((t=>{a+=`\n  ${i("Argument: %s, Given: %s, Choices: %s",t,e.stringifiedValues(r[t]),e.stringifiedValues(n.choices[t]))}`})),e.fail(a)}};let o={};function a(t,e){const s=Number(e);return"number"==typeof(e=isNaN(s)?e:s)?e=t._.length>=e:e.match(/^--no-.+/)?(e=e.match(/^--no-(.+)/)[1],e=!Object.prototype.hasOwnProperty.call(t,e)):e=Object.prototype.hasOwnProperty.call(t,e),e}r.implies=function(e,i){h(" [array|number|string]",[e,i],arguments.length),"object"==typeof e?Object.keys(e).forEach((t=>{r.implies(t,e[t])})):(t.global(e),o[e]||(o[e]=[]),Array.isArray(i)?i.forEach((t=>r.implies(e,t))):(d(i,void 0,s),o[e].push(i)))},r.getImplied=function(){return o},r.implications=function(t){const s=[];if(Object.keys(o).forEach((e=>{const i=e;(o[e]||[]).forEach((e=>{let n=i;const r=e;n=a(t,n),e=a(t,e),n&&!e&&s.push(` ${i} -> ${r}`)}))})),s.length){let t=`${i("Implications failed:")}\n`;s.forEach((e=>{t+=e})),e.fail(t)}};let l={};r.conflicts=function(e,s){h(" [array|string]",[e,s],arguments.length),"object"==typeof e?Object.keys(e).forEach((t=>{r.conflicts(t,e[t])})):(t.global(e),l[e]||(l[e]=[]),Array.isArray(s)?s.forEach((t=>r.conflicts(e,t))):l[e].push(s))},r.getConflicting=()=>l,r.conflicting=function(n){Object.keys(n).forEach((t=>{l[t]&&l[t].forEach((s=>{s&&void 0!==n[t]&&void 0!==n[s]&&e.fail(i("Arguments %s and %s are mutually exclusive",t,s))}))})),t.getInternalMethods().getParserConfiguration()["strip-dashed"]&&Object.keys(l).forEach((t=>{l[t].forEach((r=>{r&&void 0!==n[s.Parser.camelCase(t)]&&void 0!==n[s.Parser.camelCase(r)]&&e.fail(i("Arguments %s and %s are mutually exclusive",t,r))}))}))},r.recommendCommands=function(t,s){s=s.sort(((t,e)=>e.length-t.length));let n=null,r=1/0;for(let e,i=0;void 0!==(e=s[i]);i++){const s=N(t,e);s<=3&&s!t[e])),l=g(l,(e=>!t[e])),r};const c=[];return r.freeze=function(){c.push({implied:o,conflicting:l})},r.unfreeze=function(){const t=c.pop();d(t,void 0,s),({implied:o,conflicting:l}=t)},r}(this,v(this,pt,"f"),v(this,ct,"f")),"f"),O(this,z,v(this,z,"f")?v(this,z,"f").reset():function(t,e,s,i){return new _(t,e,s,i)}(v(this,pt,"f"),v(this,yt,"f"),v(this,Y,"f"),v(this,ct,"f")),"f"),v(this,U,"f")||O(this,U,function(t,e,s,i){return new D(t,e,s,i)}(this,v(this,pt,"f"),v(this,z,"f"),v(this,ct,"f")),"f"),v(this,Y,"f").reset(),O(this,F,null,"f"),O(this,tt,"","f"),O(this,V,null,"f"),O(this,J,!1,"f"),this.parsed=!1,this}[Yt](t,e){return v(this,ct,"f").path.relative(t,e)}[Jt](t,s,i,n=0,r=!1){let o=!!i||r;t=t||v(this,ht,"f"),v(this,et,"f").__=v(this,ct,"f").y18n.__,v(this,et,"f").configuration=this[Mt]();const a=!!v(this,et,"f").configuration["populate--"],h=Object.assign({},v(this,et,"f").configuration,{"populate--":!0}),l=v(this,ct,"f").Parser.detailed(t,Object.assign({},v(this,et,"f"),{configuration:{"parse-positional-numbers":!1,...h}})),c=Object.assign(l.argv,v(this,rt,"f"));let d;const u=l.aliases;let p=!1,g=!1;Object.keys(c).forEach((t=>{t===v(this,Z,"f")&&c[t]?p=!0:t===v(this,mt,"f")&&c[t]&&(g=!0)})),c.$0=this.$0,this.parsed=l,0===n&&v(this,pt,"f").clearCachedHelpMessage();try{if(this[kt](),s)return this[Bt](c,a,!!i,!1);if(v(this,Z,"f")){[v(this,Z,"f")].concat(u[v(this,Z,"f")]||[]).filter((t=>t.length>1)).includes(""+c._[c._.length-1])&&(c._.pop(),p=!0)}O(this,X,!1,"f");const h=v(this,z,"f").getCommands(),m=v(this,U,"f").completionKey in c,y=p||m||r;if(c._.length){if(h.length){let t;for(let e,s=n||0;void 0!==c._[s];s++){if(e=String(c._[s]),h.includes(e)&&e!==v(this,F,"f")){const t=v(this,z,"f").runCommand(e,this,l,s+1,r,p||g||r);return this[Bt](t,a,!!i,!1)}if(!t&&e!==v(this,F,"f")){t=e;break}}!v(this,z,"f").hasDefaultCommand()&&v(this,lt,"f")&&t&&!y&&v(this,yt,"f").recommendCommands(t,h)}v(this,F,"f")&&c._.includes(v(this,F,"f"))&&!m&&(v(this,T,"f")&&E(!0),this.showCompletionScript(),this.exit(0))}if(v(this,z,"f").hasDefaultCommand()&&!y){const t=v(this,z,"f").runCommand(null,this,l,0,r,p||g||r);return this[Bt](t,a,!!i,!1)}if(m){v(this,T,"f")&&E(!0);const s=(t=[].concat(t)).slice(t.indexOf(`--${v(this,U,"f").completionKey}`)+1);return v(this,U,"f").getCompletion(s,((t,s)=>{if(t)throw new e(t.message);(s||[]).forEach((t=>{v(this,Q,"f").log(t)})),this.exit(0)})),this[Bt](c,!a,!!i,!1)}if(v(this,J,"f")||(p?(v(this,T,"f")&&E(!0),o=!0,this.showHelp("log"),this.exit(0)):g&&(v(this,T,"f")&&E(!0),o=!0,v(this,pt,"f").showVersion("log"),this.exit(0))),!o&&v(this,et,"f").skipValidation.length>0&&(o=Object.keys(c).some((t=>v(this,et,"f").skipValidation.indexOf(t)>=0&&!0===c[t]))),!o){if(l.error)throw new e(l.error.message);if(!m){const t=this[Zt](u,{},l.error);i||(d=C(c,this,v(this,Y,"f").getMiddleware(),!0)),d=this[zt](t,null!=d?d:c),f(d)&&!i&&(d=d.then((()=>C(c,this,v(this,Y,"f").getMiddleware(),!1))))}}}catch(t){if(!(t instanceof e))throw t;v(this,pt,"f").fail(t.message,t)}return this[Bt](null!=d?d:c,a,!!i,!0)}[Zt](t,s,i,n){const r={...this.getDemandedOptions()};return o=>{if(i)throw new e(i.message);v(this,yt,"f").nonOptionCount(o),v(this,yt,"f").requiredArguments(o,r);let a=!1;v(this,dt,"f")&&(a=v(this,yt,"f").unknownCommands(o)),v(this,ft,"f")&&!a?v(this,yt,"f").unknownArguments(o,t,s,!!n):v(this,ut,"f")&&v(this,yt,"f").unknownArguments(o,t,{},!1,!1),v(this,yt,"f").limitedChoices(o),v(this,yt,"f").implications(o),v(this,yt,"f").conflicting(o)}}[Xt](){O(this,J,!0,"f")}[Qt](t){if("string"==typeof t)v(this,et,"f").key[t]=!0;else for(const e of t)v(this,et,"f").key[e]=!0}}var ee,se;const{readFileSync:ie}=__nccwpck_require__(57147),{inspect:ne}=__nccwpck_require__(73837),{resolve:re}=__nccwpck_require__(71017),oe=__nccwpck_require__(32329),ae=__nccwpck_require__(51373);var he,le={assert:{notStrictEqual:t.notStrictEqual,strictEqual:t.strictEqual},cliui:__nccwpck_require__(35747),findUp:__nccwpck_require__(34959),getEnv:t=>process.env[t],getCallerFile:__nccwpck_require__(59466),getProcessArgvBin:y,inspect:ne,mainFilename:null!==(se=null===(ee= false||void 0===__nccwpck_require__(49167)?void 0:__nccwpck_require__.c[__nccwpck_require__.s])||void 0===ee?void 0:ee.filename)&&void 0!==se?se:process.cwd(),Parser:ae,path:__nccwpck_require__(71017),process:{argv:()=>process.argv,cwd:process.cwd,emitWarning:(t,e)=>process.emitWarning(t,e),execPath:()=>process.execPath,exit:t=>{process.exit(t)},nextTick:process.nextTick,stdColumns:void 0!==process.stdout.columns?process.stdout.columns:null},readFileSync:ie,require:__nccwpck_require__(49167),requireDirectory:__nccwpck_require__(14567),stringWidth:__nccwpck_require__(32147),y18n:oe({directory:re(__dirname,"../locales"),updateFiles:!1})};const ce=(null===(he=null===process||void 0===process?void 0:process.env)||void 0===he?void 0:he.YARGS_MIN_NODE_VERSION)?Number(process.env.YARGS_MIN_NODE_VERSION):12;if(process&&process.version){if(Number(process.version.match(/v([^.]+)/)[1]){const i=new te(t,e,s,de);return Object.defineProperty(i,"argv",{get:()=>i.parse(),enumerable:!0}),i.help(),i.version(),i}),argsert:h,isPromise:f,objFilter:g,parseCommand:o,Parser:fe,processArgv:b,YError:e};module.exports=ue;
-
-
-/***/ }),
-
-/***/ 35747:
-/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
-
-"use strict";
-
-
-const align = {
-    right: alignRight,
-    center: alignCenter
-};
-const top = 0;
-const right = 1;
-const bottom = 2;
-const left = 3;
-class UI {
-    constructor(opts) {
-        var _a;
-        this.width = opts.width;
-        this.wrap = (_a = opts.wrap) !== null && _a !== void 0 ? _a : true;
-        this.rows = [];
-    }
-    span(...args) {
-        const cols = this.div(...args);
-        cols.span = true;
-    }
-    resetOutput() {
-        this.rows = [];
-    }
-    div(...args) {
-        if (args.length === 0) {
-            this.div('');
-        }
-        if (this.wrap && this.shouldApplyLayoutDSL(...args) && typeof args[0] === 'string') {
-            return this.applyLayoutDSL(args[0]);
-        }
-        const cols = args.map(arg => {
-            if (typeof arg === 'string') {
-                return this.colFromString(arg);
-            }
-            return arg;
-        });
-        this.rows.push(cols);
-        return cols;
-    }
-    shouldApplyLayoutDSL(...args) {
-        return args.length === 1 && typeof args[0] === 'string' &&
-            /[\t\n]/.test(args[0]);
-    }
-    applyLayoutDSL(str) {
-        const rows = str.split('\n').map(row => row.split('\t'));
-        let leftColumnWidth = 0;
-        // simple heuristic for layout, make sure the
-        // second column lines up along the left-hand.
-        // don't allow the first column to take up more
-        // than 50% of the screen.
-        rows.forEach(columns => {
-            if (columns.length > 1 && mixin.stringWidth(columns[0]) > leftColumnWidth) {
-                leftColumnWidth = Math.min(Math.floor(this.width * 0.5), mixin.stringWidth(columns[0]));
-            }
-        });
-        // generate a table:
-        //  replacing ' ' with padding calculations.
-        //  using the algorithmically generated width.
-        rows.forEach(columns => {
-            this.div(...columns.map((r, i) => {
-                return {
-                    text: r.trim(),
-                    padding: this.measurePadding(r),
-                    width: (i === 0 && columns.length > 1) ? leftColumnWidth : undefined
-                };
-            }));
-        });
-        return this.rows[this.rows.length - 1];
-    }
-    colFromString(text) {
-        return {
-            text,
-            padding: this.measurePadding(text)
-        };
-    }
-    measurePadding(str) {
-        // measure padding without ansi escape codes
-        const noAnsi = mixin.stripAnsi(str);
-        return [0, noAnsi.match(/\s*$/)[0].length, 0, noAnsi.match(/^\s*/)[0].length];
-    }
-    toString() {
-        const lines = [];
-        this.rows.forEach(row => {
-            this.rowToString(row, lines);
-        });
-        // don't display any lines with the
-        // hidden flag set.
-        return lines
-            .filter(line => !line.hidden)
-            .map(line => line.text)
-            .join('\n');
-    }
-    rowToString(row, lines) {
-        this.rasterize(row).forEach((rrow, r) => {
-            let str = '';
-            rrow.forEach((col, c) => {
-                const { width } = row[c]; // the width with padding.
-                const wrapWidth = this.negatePadding(row[c]); // the width without padding.
-                let ts = col; // temporary string used during alignment/padding.
-                if (wrapWidth > mixin.stringWidth(col)) {
-                    ts += ' '.repeat(wrapWidth - mixin.stringWidth(col));
-                }
-                // align the string within its column.
-                if (row[c].align && row[c].align !== 'left' && this.wrap) {
-                    const fn = align[row[c].align];
-                    ts = fn(ts, wrapWidth);
-                    if (mixin.stringWidth(ts) < wrapWidth) {
-                        ts += ' '.repeat((width || 0) - mixin.stringWidth(ts) - 1);
-                    }
-                }
-                // apply border and padding to string.
-                const padding = row[c].padding || [0, 0, 0, 0];
-                if (padding[left]) {
-                    str += ' '.repeat(padding[left]);
-                }
-                str += addBorder(row[c], ts, '| ');
-                str += ts;
-                str += addBorder(row[c], ts, ' |');
-                if (padding[right]) {
-                    str += ' '.repeat(padding[right]);
-                }
-                // if prior row is span, try to render the
-                // current row on the prior line.
-                if (r === 0 && lines.length > 0) {
-                    str = this.renderInline(str, lines[lines.length - 1]);
-                }
-            });
-            // remove trailing whitespace.
-            lines.push({
-                text: str.replace(/ +$/, ''),
-                span: row.span
-            });
-        });
-        return lines;
-    }
-    // if the full 'source' can render in
-    // the target line, do so.
-    renderInline(source, previousLine) {
-        const match = source.match(/^ */);
-        const leadingWhitespace = match ? match[0].length : 0;
-        const target = previousLine.text;
-        const targetTextWidth = mixin.stringWidth(target.trimRight());
-        if (!previousLine.span) {
-            return source;
-        }
-        // if we're not applying wrapping logic,
-        // just always append to the span.
-        if (!this.wrap) {
-            previousLine.hidden = true;
-            return target + source;
-        }
-        if (leadingWhitespace < targetTextWidth) {
-            return source;
-        }
-        previousLine.hidden = true;
-        return target.trimRight() + ' '.repeat(leadingWhitespace - targetTextWidth) + source.trimLeft();
-    }
-    rasterize(row) {
-        const rrows = [];
-        const widths = this.columnWidths(row);
-        let wrapped;
-        // word wrap all columns, and create
-        // a data-structure that is easy to rasterize.
-        row.forEach((col, c) => {
-            // leave room for left and right padding.
-            col.width = widths[c];
-            if (this.wrap) {
-                wrapped = mixin.wrap(col.text, this.negatePadding(col), { hard: true }).split('\n');
-            }
-            else {
-                wrapped = col.text.split('\n');
-            }
-            if (col.border) {
-                wrapped.unshift('.' + '-'.repeat(this.negatePadding(col) + 2) + '.');
-                wrapped.push("'" + '-'.repeat(this.negatePadding(col) + 2) + "'");
-            }
-            // add top and bottom padding.
-            if (col.padding) {
-                wrapped.unshift(...new Array(col.padding[top] || 0).fill(''));
-                wrapped.push(...new Array(col.padding[bottom] || 0).fill(''));
-            }
-            wrapped.forEach((str, r) => {
-                if (!rrows[r]) {
-                    rrows.push([]);
-                }
-                const rrow = rrows[r];
-                for (let i = 0; i < c; i++) {
-                    if (rrow[i] === undefined) {
-                        rrow.push('');
-                    }
-                }
-                rrow.push(str);
-            });
-        });
-        return rrows;
-    }
-    negatePadding(col) {
-        let wrapWidth = col.width || 0;
-        if (col.padding) {
-            wrapWidth -= (col.padding[left] || 0) + (col.padding[right] || 0);
-        }
-        if (col.border) {
-            wrapWidth -= 4;
-        }
-        return wrapWidth;
-    }
-    columnWidths(row) {
-        if (!this.wrap) {
-            return row.map(col => {
-                return col.width || mixin.stringWidth(col.text);
-            });
-        }
-        let unset = row.length;
-        let remainingWidth = this.width;
-        // column widths can be set in config.
-        const widths = row.map(col => {
-            if (col.width) {
-                unset--;
-                remainingWidth -= col.width;
-                return col.width;
-            }
-            return undefined;
-        });
-        // any unset widths should be calculated.
-        const unsetWidth = unset ? Math.floor(remainingWidth / unset) : 0;
-        return widths.map((w, i) => {
-            if (w === undefined) {
-                return Math.max(unsetWidth, _minWidth(row[i]));
-            }
-            return w;
-        });
-    }
-}
-function addBorder(col, ts, style) {
-    if (col.border) {
-        if (/[.']-+[.']/.test(ts)) {
-            return '';
-        }
-        if (ts.trim().length !== 0) {
-            return style;
-        }
-        return '  ';
-    }
-    return '';
-}
-// calculates the minimum width of
-// a column, based on padding preferences.
-function _minWidth(col) {
-    const padding = col.padding || [];
-    const minWidth = 1 + (padding[left] || 0) + (padding[right] || 0);
-    if (col.border) {
-        return minWidth + 4;
-    }
-    return minWidth;
-}
-function getWindowWidth() {
-    /* istanbul ignore next: depends on terminal */
-    if (typeof process === 'object' && process.stdout && process.stdout.columns) {
-        return process.stdout.columns;
-    }
-    return 80;
-}
-function alignRight(str, width) {
-    str = str.trim();
-    const strWidth = mixin.stringWidth(str);
-    if (strWidth < width) {
-        return ' '.repeat(width - strWidth) + str;
-    }
-    return str;
-}
-function alignCenter(str, width) {
-    str = str.trim();
-    const strWidth = mixin.stringWidth(str);
-    /* istanbul ignore next */
-    if (strWidth >= width) {
-        return str;
-    }
-    return ' '.repeat((width - strWidth) >> 1) + str;
-}
-let mixin;
-function cliui(opts, _mixin) {
-    mixin = _mixin;
-    return new UI({
-        width: (opts === null || opts === void 0 ? void 0 : opts.width) || getWindowWidth(),
-        wrap: opts === null || opts === void 0 ? void 0 : opts.wrap
-    });
-}
-
-// Bootstrap cliui with CommonJS dependencies:
-const stringWidth = __nccwpck_require__(32147);
-const stripAnsi = __nccwpck_require__(93847);
-const wrap = __nccwpck_require__(9398);
-function ui(opts) {
-    return cliui(opts, {
-        stringWidth,
-        stripAnsi,
-        wrap
-    });
-}
-
-module.exports = ui;
+var t=__nccwpck_require__(39491);class e extends Error{constructor(t){super(t||"yargs error"),this.name="YError",Error.captureStackTrace&&Error.captureStackTrace(this,e)}}let s,i=[];function n(t,o,a,h){s=h;let l={};if(Object.prototype.hasOwnProperty.call(t,"extends")){if("string"!=typeof t.extends)return l;const r=/\.json|\..*rc$/.test(t.extends);let h=null;if(r)h=function(t,e){return s.path.resolve(t,e)}(o,t.extends);else try{h=/*require.resolve*/(__nccwpck_require__(49167).resolve(t.extends))}catch(e){return t}!function(t){if(i.indexOf(t)>-1)throw new e(`Circular extended configurations: '${t}'.`)}(h),i.push(h),l=r?JSON.parse(s.readFileSync(h,"utf8")):__nccwpck_require__(49167)(t.extends),delete t.extends,l=n(l,s.path.dirname(h),a,s)}return i=[],a?r(l,t):Object.assign({},l,t)}function r(t,e){const s={};function i(t){return t&&"object"==typeof t&&!Array.isArray(t)}Object.assign(s,t);for(const n of Object.keys(e))i(e[n])&&i(s[n])?s[n]=r(t[n],e[n]):s[n]=e[n];return s}function o(t){const e=t.replace(/\s{2,}/g," ").split(/\s+(?![^[]*]|[^<]*>)/),s=/\.*[\][<>]/g,i=e.shift();if(!i)throw new Error(`No command found in: ${t}`);const n={cmd:i.replace(s,""),demanded:[],optional:[]};return e.forEach(((t,i)=>{let r=!1;t=t.replace(/\s/g,""),/\.+[\]>]/.test(t)&&i===e.length-1&&(r=!0),/^\[/.test(t)?n.optional.push({cmd:t.replace(s,"").split("|"),variadic:r}):n.demanded.push({cmd:t.replace(s,"").split("|"),variadic:r})})),n}const a=["first","second","third","fourth","fifth","sixth"];function h(t,s,i){try{let n=0;const[r,a,h]="object"==typeof t?[{demanded:[],optional:[]},t,s]:[o(`cmd ${t}`),s,i],f=[].slice.call(a);for(;f.length&&void 0===f[f.length-1];)f.pop();const d=h||f.length;if(du)throw new e(`Too many arguments provided. Expected max ${u} but received ${d}.`);r.demanded.forEach((t=>{const e=l(f.shift());0===t.cmd.filter((t=>t===e||"*"===t)).length&&c(e,t.cmd,n),n+=1})),r.optional.forEach((t=>{if(0===f.length)return;const e=l(f.shift());0===t.cmd.filter((t=>t===e||"*"===t)).length&&c(e,t.cmd,n),n+=1}))}catch(t){console.warn(t.stack)}}function l(t){return Array.isArray(t)?"array":null===t?"null":typeof t}function c(t,s,i){throw new e(`Invalid ${a[i]||"manyith"} argument. Expected ${s.join(" or ")} but received ${t}.`)}function f(t){return!!t&&!!t.then&&"function"==typeof t.then}function d(t,e,s,i){s.assert.notStrictEqual(t,e,i)}function u(t,e){e.assert.strictEqual(typeof t,"string")}function p(t){return Object.keys(t)}function g(t={},e=(()=>!0)){const s={};return p(t).forEach((i=>{e(i,t[i])&&(s[i]=t[i])})),s}function m(){return process.versions.electron&&!process.defaultApp?0:1}function y(){return process.argv[m()]}var b=Object.freeze({__proto__:null,hideBin:function(t){return t.slice(m()+1)},getProcessArgvBin:y});function v(t,e,s,i){if("a"===s&&!i)throw new TypeError("Private accessor was defined without a getter");if("function"==typeof e?t!==e||!i:!e.has(t))throw new TypeError("Cannot read private member from an object whose class did not declare it");return"m"===s?i:"a"===s?i.call(t):i?i.value:e.get(t)}function O(t,e,s,i,n){if("m"===i)throw new TypeError("Private method is not writable");if("a"===i&&!n)throw new TypeError("Private accessor was defined without a setter");if("function"==typeof e?t!==e||!n:!e.has(t))throw new TypeError("Cannot write private member to an object whose class did not declare it");return"a"===i?n.call(t,s):n?n.value=s:e.set(t,s),s}class w{constructor(t){this.globalMiddleware=[],this.frozens=[],this.yargs=t}addMiddleware(t,e,s=!0,i=!1){if(h(" [boolean] [boolean] [boolean]",[t,e,s],arguments.length),Array.isArray(t)){for(let i=0;i{const i=[...s[e]||[],e];return!t.option||!i.includes(t.option)})),t.option=e,this.addMiddleware(t,!0,!0,!0)}getMiddleware(){return this.globalMiddleware}freeze(){this.frozens.push([...this.globalMiddleware])}unfreeze(){const t=this.frozens.pop();void 0!==t&&(this.globalMiddleware=t)}reset(){this.globalMiddleware=this.globalMiddleware.filter((t=>t.global))}}function C(t,e,s,i){return s.reduce(((t,s)=>{if(s.applyBeforeValidation!==i)return t;if(s.mutates){if(s.applied)return t;s.applied=!0}if(f(t))return t.then((t=>Promise.all([t,s(t,e)]))).then((([t,e])=>Object.assign(t,e)));{const i=s(t,e);return f(i)?i.then((e=>Object.assign(t,e))):Object.assign(t,i)}}),t)}function j(t,e,s=(t=>{throw t})){try{const s="function"==typeof t?t():t;return f(s)?s.then((t=>e(t))):e(s)}catch(t){return s(t)}}const M=/(^\*)|(^\$0)/;class _{constructor(t,e,s,i){this.requireCache=new Set,this.handlers={},this.aliasMap={},this.frozens=[],this.shim=i,this.usage=t,this.globalMiddleware=s,this.validation=e}addDirectory(t,e,s,i){"boolean"!=typeof(i=i||{}).recurse&&(i.recurse=!1),Array.isArray(i.extensions)||(i.extensions=["js"]);const n="function"==typeof i.visit?i.visit:t=>t;i.visit=(t,e,s)=>{const i=n(t,e,s);if(i){if(this.requireCache.has(e))return i;this.requireCache.add(e),this.addHandler(i)}return i},this.shim.requireDirectory({require:e,filename:s},t,i)}addHandler(t,e,s,i,n,r){let a=[];const h=function(t){return t?t.map((t=>(t.applyBeforeValidation=!1,t))):[]}(n);if(i=i||(()=>{}),Array.isArray(t))if(function(t){return t.every((t=>"string"==typeof t))}(t))[t,...a]=t;else for(const e of t)this.addHandler(e);else{if(function(t){return"object"==typeof t&&!Array.isArray(t)}(t)){let e=Array.isArray(t.command)||"string"==typeof t.command?t.command:this.moduleName(t);return t.aliases&&(e=[].concat(e).concat(t.aliases)),void this.addHandler(e,this.extractDesc(t),t.builder,t.handler,t.middlewares,t.deprecated)}if(k(s))return void this.addHandler([t].concat(a),e,s.builder,s.handler,s.middlewares,s.deprecated)}if("string"==typeof t){const n=o(t);a=a.map((t=>o(t).cmd));let l=!1;const c=[n.cmd].concat(a).filter((t=>!M.test(t)||(l=!0,!1)));0===c.length&&l&&c.push("$0"),l&&(n.cmd=c[0],a=c.slice(1),t=t.replace(M,n.cmd)),a.forEach((t=>{this.aliasMap[t]=n.cmd})),!1!==e&&this.usage.command(t,e,l,a,r),this.handlers[n.cmd]={original:t,description:e,handler:i,builder:s||{},middlewares:h,deprecated:r,demanded:n.demanded,optional:n.optional},l&&(this.defaultCommand=this.handlers[n.cmd])}}getCommandHandlers(){return this.handlers}getCommands(){return Object.keys(this.handlers).concat(Object.keys(this.aliasMap))}hasDefaultCommand(){return!!this.defaultCommand}runCommand(t,e,s,i,n,r){const o=this.handlers[t]||this.handlers[this.aliasMap[t]]||this.defaultCommand,a=e.getInternalMethods().getContext(),h=a.commands.slice(),l=!t;t&&(a.commands.push(t),a.fullCommands.push(o.original));const c=this.applyBuilderUpdateUsageAndParse(l,o,e,s.aliases,h,i,n,r);return f(c)?c.then((t=>this.applyMiddlewareAndGetResult(l,o,t.innerArgv,a,n,t.aliases,e))):this.applyMiddlewareAndGetResult(l,o,c.innerArgv,a,n,c.aliases,e)}applyBuilderUpdateUsageAndParse(t,e,s,i,n,r,o,a){const h=e.builder;let l=s;if(x(h)){s.getInternalMethods().getUsageInstance().freeze();const c=h(s.getInternalMethods().reset(i),a);if(f(c))return c.then((i=>{var a;return l=(a=i)&&"function"==typeof a.getInternalMethods?i:s,this.parseAndUpdateUsage(t,e,l,n,r,o)}))}else(function(t){return"object"==typeof t})(h)&&(s.getInternalMethods().getUsageInstance().freeze(),l=s.getInternalMethods().reset(i),Object.keys(e.builder).forEach((t=>{l.option(t,h[t])})));return this.parseAndUpdateUsage(t,e,l,n,r,o)}parseAndUpdateUsage(t,e,s,i,n,r){t&&s.getInternalMethods().getUsageInstance().unfreeze(!0),this.shouldUpdateUsage(s)&&s.getInternalMethods().getUsageInstance().usage(this.usageFromParentCommandsCommandHandler(i,e),e.description);const o=s.getInternalMethods().runYargsParserAndExecuteCommands(null,void 0,!0,n,r);return f(o)?o.then((t=>({aliases:s.parsed.aliases,innerArgv:t}))):{aliases:s.parsed.aliases,innerArgv:o}}shouldUpdateUsage(t){return!t.getInternalMethods().getUsageInstance().getUsageDisabled()&&0===t.getInternalMethods().getUsageInstance().getUsage().length}usageFromParentCommandsCommandHandler(t,e){const s=M.test(e.original)?e.original.replace(M,"").trim():e.original,i=t.filter((t=>!M.test(t)));return i.push(s),`$0 ${i.join(" ")}`}handleValidationAndGetResult(t,e,s,i,n,r,o,a){if(!r.getInternalMethods().getHasOutput()){const e=r.getInternalMethods().runValidation(n,a,r.parsed.error,t);s=j(s,(t=>(e(t),t)))}if(e.handler&&!r.getInternalMethods().getHasOutput()){r.getInternalMethods().setHasOutput();const i=!!r.getOptions().configuration["populate--"];r.getInternalMethods().postProcess(s,i,!1,!1),s=j(s=C(s,r,o,!1),(t=>{const s=e.handler(t);return f(s)?s.then((()=>t)):t})),t||r.getInternalMethods().getUsageInstance().cacheHelpMessage(),f(s)&&!r.getInternalMethods().hasParseCallback()&&s.catch((t=>{try{r.getInternalMethods().getUsageInstance().fail(null,t)}catch(t){}}))}return t||(i.commands.pop(),i.fullCommands.pop()),s}applyMiddlewareAndGetResult(t,e,s,i,n,r,o){let a={};if(n)return s;o.getInternalMethods().getHasOutput()||(a=this.populatePositionals(e,s,i,o));const h=this.globalMiddleware.getMiddleware().slice(0).concat(e.middlewares),l=C(s,o,h,!0);return f(l)?l.then((s=>this.handleValidationAndGetResult(t,e,s,i,r,o,h,a))):this.handleValidationAndGetResult(t,e,l,i,r,o,h,a)}populatePositionals(t,e,s,i){e._=e._.slice(s.commands.length);const n=t.demanded.slice(0),r=t.optional.slice(0),o={};for(this.validation.positionalCount(n.length,e._.length);n.length;){const t=n.shift();this.populatePositional(t,e,o)}for(;r.length;){const t=r.shift();this.populatePositional(t,e,o)}return e._=s.commands.concat(e._.map((t=>""+t))),this.postProcessPositionals(e,o,this.cmdToParseOptions(t.original),i),o}populatePositional(t,e,s){const i=t.cmd[0];t.variadic?s[i]=e._.splice(0).map(String):e._.length&&(s[i]=[String(e._.shift())])}cmdToParseOptions(t){const e={array:[],default:{},alias:{},demand:{}},s=o(t);return s.demanded.forEach((t=>{const[s,...i]=t.cmd;t.variadic&&(e.array.push(s),e.default[s]=[]),e.alias[s]=i,e.demand[s]=!0})),s.optional.forEach((t=>{const[s,...i]=t.cmd;t.variadic&&(e.array.push(s),e.default[s]=[]),e.alias[s]=i})),e}postProcessPositionals(t,e,s,i){const n=Object.assign({},i.getOptions());n.default=Object.assign(s.default,n.default);for(const t of Object.keys(s.alias))n.alias[t]=(n.alias[t]||[]).concat(s.alias[t]);n.array=n.array.concat(s.array),n.config={};const r=[];if(Object.keys(e).forEach((t=>{e[t].map((e=>{n.configuration["unknown-options-as-args"]&&(n.key[t]=!0),r.push(`--${t}`),r.push(e)}))})),!r.length)return;const o=Object.assign({},n.configuration,{"populate--":!1}),a=this.shim.Parser.detailed(r,Object.assign({},n,{configuration:o}));if(a.error)i.getInternalMethods().getUsageInstance().fail(a.error.message,a.error);else{const s=Object.keys(e);Object.keys(e).forEach((t=>{s.push(...a.aliases[t])})),Object.keys(a.argv).forEach((n=>{s.includes(n)&&(e[n]||(e[n]=a.argv[n]),!this.isInConfigs(i,n)&&!this.isDefaulted(i,n)&&Object.prototype.hasOwnProperty.call(t,n)&&Object.prototype.hasOwnProperty.call(a.argv,n)&&(Array.isArray(t[n])||Array.isArray(a.argv[n]))?t[n]=[].concat(t[n],a.argv[n]):t[n]=a.argv[n])}))}}isDefaulted(t,e){const{default:s}=t.getOptions();return Object.prototype.hasOwnProperty.call(s,e)||Object.prototype.hasOwnProperty.call(s,this.shim.Parser.camelCase(e))}isInConfigs(t,e){const{configObjects:s}=t.getOptions();return s.some((t=>Object.prototype.hasOwnProperty.call(t,e)))||s.some((t=>Object.prototype.hasOwnProperty.call(t,this.shim.Parser.camelCase(e))))}runDefaultBuilderOn(t){if(!this.defaultCommand)return;if(this.shouldUpdateUsage(t)){const e=M.test(this.defaultCommand.original)?this.defaultCommand.original:this.defaultCommand.original.replace(/^[^[\]<>]*/,"$0 ");t.getInternalMethods().getUsageInstance().usage(e,this.defaultCommand.description)}const e=this.defaultCommand.builder;if(x(e))return e(t,!0);k(e)||Object.keys(e).forEach((s=>{t.option(s,e[s])}))}moduleName(t){const e=function(t){if(false){}for(let e,s=0,i=Object.keys(__nccwpck_require__.c);s{const s=e;s._handle&&s.isTTY&&"function"==typeof s._handle.setBlocking&&s._handle.setBlocking(t)}))}function A(t){return"boolean"==typeof t}function P(t,s){const i=s.y18n.__,n={},r=[];n.failFn=function(t){r.push(t)};let o=null,a=null,h=!0;n.showHelpOnFail=function(e=!0,s){const[i,r]="string"==typeof e?[!0,e]:[e,s];return t.getInternalMethods().isGlobalContext()&&(a=r),o=r,h=i,n};let l=!1;n.fail=function(s,i){const c=t.getInternalMethods().getLoggerInstance();if(!r.length){if(t.getExitProcess()&&E(!0),!l){l=!0,h&&(t.showHelp("error"),c.error()),(s||i)&&c.error(s||i);const e=o||a;e&&((s||i)&&c.error(""),c.error(e))}if(i=i||new e(s),t.getExitProcess())return t.exit(1);if(t.getInternalMethods().hasParseCallback())return t.exit(1,i);throw i}for(let t=r.length-1;t>=0;--t){const e=r[t];if(A(e)){if(i)throw i;if(s)throw Error(s)}else e(s,i,n)}};let c=[],f=!1;n.usage=(t,e)=>null===t?(f=!0,c=[],n):(f=!1,c.push([t,e||""]),n),n.getUsage=()=>c,n.getUsageDisabled=()=>f,n.getPositionalGroupName=()=>i("Positionals:");let d=[];n.example=(t,e)=>{d.push([t,e||""])};let u=[];n.command=function(t,e,s,i,n=!1){s&&(u=u.map((t=>(t[2]=!1,t)))),u.push([t,e||"",s,i,n])},n.getCommands=()=>u;let p={};n.describe=function(t,e){Array.isArray(t)?t.forEach((t=>{n.describe(t,e)})):"object"==typeof t?Object.keys(t).forEach((e=>{n.describe(e,t[e])})):p[t]=e},n.getDescriptions=()=>p;let m=[];n.epilog=t=>{m.push(t)};let y,b=!1;n.wrap=t=>{b=!0,y=t},n.getWrap=()=>s.getEnv("YARGS_DISABLE_WRAP")?null:(b||(y=function(){const t=80;return s.process.stdColumns?Math.min(t,s.process.stdColumns):t}(),b=!0),y);const v="__yargsString__:";function O(t,e,i){let n=0;return Array.isArray(t)||(t=Object.values(t).map((t=>[t]))),t.forEach((t=>{n=Math.max(s.stringWidth(i?`${i} ${I(t[0])}`:I(t[0]))+$(t[0]),n)})),e&&(n=Math.min(n,parseInt((.5*e).toString(),10))),n}let w;function C(e){return t.getOptions().hiddenOptions.indexOf(e)<0||t.parsed.argv[t.getOptions().showHiddenOpt]}function j(t,e){let s=`[${i("default:")} `;if(void 0===t&&!e)return null;if(e)s+=e;else switch(typeof t){case"string":s+=`"${t}"`;break;case"object":s+=JSON.stringify(t);break;default:s+=t}return`${s}]`}n.deferY18nLookup=t=>v+t,n.help=function(){if(w)return w;!function(){const e=t.getDemandedOptions(),s=t.getOptions();(Object.keys(s.alias)||[]).forEach((i=>{s.alias[i].forEach((r=>{p[r]&&n.describe(i,p[r]),r in e&&t.demandOption(i,e[r]),s.boolean.includes(r)&&t.boolean(i),s.count.includes(r)&&t.count(i),s.string.includes(r)&&t.string(i),s.normalize.includes(r)&&t.normalize(i),s.array.includes(r)&&t.array(i),s.number.includes(r)&&t.number(i)}))}))}();const e=t.customScriptName?t.$0:s.path.basename(t.$0),r=t.getDemandedOptions(),o=t.getDemandedCommands(),a=t.getDeprecatedOptions(),h=t.getGroups(),l=t.getOptions();let g=[];g=g.concat(Object.keys(p)),g=g.concat(Object.keys(r)),g=g.concat(Object.keys(o)),g=g.concat(Object.keys(l.default)),g=g.filter(C),g=Object.keys(g.reduce(((t,e)=>("_"!==e&&(t[e]=!0),t)),{}));const y=n.getWrap(),b=s.cliui({width:y,wrap:!!y});if(!f)if(c.length)c.forEach((t=>{b.div({text:`${t[0].replace(/\$0/g,e)}`}),t[1]&&b.div({text:`${t[1]}`,padding:[1,0,0,0]})})),b.div();else if(u.length){let t=null;t=o._?`${e} <${i("command")}>\n`:`${e} [${i("command")}]\n`,b.div(`${t}`)}if(u.length>1||1===u.length&&!u[0][2]){b.div(i("Commands:"));const s=t.getInternalMethods().getContext(),n=s.commands.length?`${s.commands.join(" ")} `:"";!0===t.getInternalMethods().getParserConfiguration()["sort-commands"]&&(u=u.sort(((t,e)=>t[0].localeCompare(e[0]))));const r=e?`${e} `:"";u.forEach((t=>{const s=`${r}${n}${t[0].replace(/^\$0 ?/,"")}`;b.span({text:s,padding:[0,2,0,2],width:O(u,y,`${e}${n}`)+4},{text:t[1]});const o=[];t[2]&&o.push(`[${i("default")}]`),t[3]&&t[3].length&&o.push(`[${i("aliases:")} ${t[3].join(", ")}]`),t[4]&&("string"==typeof t[4]?o.push(`[${i("deprecated: %s",t[4])}]`):o.push(`[${i("deprecated")}]`)),o.length?b.div({text:o.join(" "),padding:[0,0,0,2],align:"right"}):b.div()})),b.div()}const M=(Object.keys(l.alias)||[]).concat(Object.keys(t.parsed.newAliases)||[]);g=g.filter((e=>!t.parsed.newAliases[e]&&M.every((t=>-1===(l.alias[t]||[]).indexOf(e)))));const _=i("Options:");h[_]||(h[_]=[]),function(t,e,s,i){let n=[],r=null;Object.keys(s).forEach((t=>{n=n.concat(s[t])})),t.forEach((t=>{r=[t].concat(e[t]),r.some((t=>-1!==n.indexOf(t)))||s[i].push(t)}))}(g,l.alias,h,_);const k=t=>/^--/.test(I(t)),x=Object.keys(h).filter((t=>h[t].length>0)).map((t=>({groupName:t,normalizedKeys:h[t].filter(C).map((t=>{if(M.includes(t))return t;for(let e,s=0;void 0!==(e=M[s]);s++)if((l.alias[e]||[]).includes(t))return e;return t}))}))).filter((({normalizedKeys:t})=>t.length>0)).map((({groupName:t,normalizedKeys:e})=>{const s=e.reduce(((e,s)=>(e[s]=[s].concat(l.alias[s]||[]).map((e=>t===n.getPositionalGroupName()?e:(/^[0-9]$/.test(e)?l.boolean.includes(s)?"-":"--":e.length>1?"--":"-")+e)).sort(((t,e)=>k(t)===k(e)?0:k(t)?1:-1)).join(", "),e)),{});return{groupName:t,normalizedKeys:e,switches:s}}));if(x.filter((({groupName:t})=>t!==n.getPositionalGroupName())).some((({normalizedKeys:t,switches:e})=>!t.every((t=>k(e[t])))))&&x.filter((({groupName:t})=>t!==n.getPositionalGroupName())).forEach((({normalizedKeys:t,switches:e})=>{t.forEach((t=>{var s,i;k(e[t])&&(e[t]=(s=e[t],i=4,S(s)?{text:s.text,indentation:s.indentation+i}:{text:s,indentation:i}))}))})),x.forEach((({groupName:e,normalizedKeys:s,switches:o})=>{b.div(e),s.forEach((e=>{const s=o[e];let h=p[e]||"",c=null;h.includes(v)&&(h=i(h.substring(16))),l.boolean.includes(e)&&(c=`[${i("boolean")}]`),l.count.includes(e)&&(c=`[${i("count")}]`),l.string.includes(e)&&(c=`[${i("string")}]`),l.normalize.includes(e)&&(c=`[${i("string")}]`),l.array.includes(e)&&(c=`[${i("array")}]`),l.number.includes(e)&&(c=`[${i("number")}]`);const f=[e in a?(d=a[e],"string"==typeof d?`[${i("deprecated: %s",d)}]`:`[${i("deprecated")}]`):null,c,e in r?`[${i("required")}]`:null,l.choices&&l.choices[e]?`[${i("choices:")} ${n.stringifiedValues(l.choices[e])}]`:null,j(l.default[e],l.defaultDescription[e])].filter(Boolean).join(" ");var d;b.span({text:I(s),padding:[0,2,0,2+$(s)],width:O(o,y)+4},h);const u=!0===t.getInternalMethods().getUsageConfiguration()["hide-types"];f&&!u?b.div({text:f,padding:[0,0,0,2],align:"right"}):b.div()})),b.div()})),d.length&&(b.div(i("Examples:")),d.forEach((t=>{t[0]=t[0].replace(/\$0/g,e)})),d.forEach((t=>{""===t[1]?b.div({text:t[0],padding:[0,2,0,2]}):b.div({text:t[0],padding:[0,2,0,2],width:O(d,y)+4},{text:t[1]})})),b.div()),m.length>0){const t=m.map((t=>t.replace(/\$0/g,e))).join("\n");b.div(`${t}\n`)}return b.toString().replace(/\s*$/,"")},n.cacheHelpMessage=function(){w=this.help()},n.clearCachedHelpMessage=function(){w=void 0},n.hasCachedHelpMessage=function(){return!!w},n.showHelp=e=>{const s=t.getInternalMethods().getLoggerInstance();e||(e="error");("function"==typeof e?e:s[e])(n.help())},n.functionDescription=t=>["(",t.name?s.Parser.decamelize(t.name,"-"):i("generated-value"),")"].join(""),n.stringifiedValues=function(t,e){let s="";const i=e||", ",n=[].concat(t);return t&&n.length?(n.forEach((t=>{s.length&&(s+=i),s+=JSON.stringify(t)})),s):s};let M=null;n.version=t=>{M=t},n.showVersion=e=>{const s=t.getInternalMethods().getLoggerInstance();e||(e="error");("function"==typeof e?e:s[e])(M)},n.reset=function(t){return o=null,l=!1,c=[],f=!1,m=[],d=[],u=[],p=g(p,(e=>!t[e])),n};const _=[];return n.freeze=function(){_.push({failMessage:o,failureOutput:l,usages:c,usageDisabled:f,epilogs:m,examples:d,commands:u,descriptions:p})},n.unfreeze=function(t=!1){const e=_.pop();e&&(t?(p={...e.descriptions,...p},u=[...e.commands,...u],c=[...e.usages,...c],d=[...e.examples,...d],m=[...e.epilogs,...m]):({failMessage:o,failureOutput:l,usages:c,usageDisabled:f,epilogs:m,examples:d,commands:u,descriptions:p}=e))},n}function S(t){return"object"==typeof t}function $(t){return S(t)?t.indentation:0}function I(t){return S(t)?t.text:t}class D{constructor(t,e,s,i){var n,r,o;this.yargs=t,this.usage=e,this.command=s,this.shim=i,this.completionKey="get-yargs-completions",this.aliases=null,this.customCompletionFunction=null,this.indexAfterLastReset=0,this.zshShell=null!==(o=(null===(n=this.shim.getEnv("SHELL"))||void 0===n?void 0:n.includes("zsh"))||(null===(r=this.shim.getEnv("ZSH_NAME"))||void 0===r?void 0:r.includes("zsh")))&&void 0!==o&&o}defaultCompletion(t,e,s,i){const n=this.command.getCommandHandlers();for(let e=0,s=t.length;e{const i=o(s[0]).cmd;if(-1===e.indexOf(i))if(this.zshShell){const e=s[1]||"";t.push(i.replace(/:/g,"\\:")+":"+e)}else t.push(i)}))}optionCompletions(t,e,s,i){if((i.match(/^-/)||""===i&&0===t.length)&&!this.previousArgHasChoices(e)){const s=this.yargs.getOptions(),n=this.yargs.getGroups()[this.usage.getPositionalGroupName()]||[];Object.keys(s.key).forEach((r=>{const o=!!s.configuration["boolean-negation"]&&s.boolean.includes(r);n.includes(r)||s.hiddenOptions.includes(r)||this.argsContainKey(e,r,o)||this.completeOptionKey(r,t,i,o&&!!s.default[r])}))}}choicesFromOptionsCompletions(t,e,s,i){if(this.previousArgHasChoices(e)){const s=this.getPreviousArgChoices(e);s&&s.length>0&&t.push(...s.map((t=>t.replace(/:/g,"\\:"))))}}choicesFromPositionalsCompletions(t,e,s,i){if(""===i&&t.length>0&&this.previousArgHasChoices(e))return;const n=this.yargs.getGroups()[this.usage.getPositionalGroupName()]||[],r=Math.max(this.indexAfterLastReset,this.yargs.getInternalMethods().getContext().commands.length+1),o=n[s._.length-r-1];if(!o)return;const a=this.yargs.getOptions().choices[o]||[];for(const e of a)e.startsWith(i)&&t.push(e.replace(/:/g,"\\:"))}getPreviousArgChoices(t){if(t.length<1)return;let e=t[t.length-1],s="";if(!e.startsWith("-")&&t.length>1&&(s=e,e=t[t.length-2]),!e.startsWith("-"))return;const i=e.replace(/^-+/,""),n=this.yargs.getOptions(),r=[i,...this.yargs.getAliases()[i]||[]];let o;for(const t of r)if(Object.prototype.hasOwnProperty.call(n.key,t)&&Array.isArray(n.choices[t])){o=n.choices[t];break}return o?o.filter((t=>!s||t.startsWith(s))):void 0}previousArgHasChoices(t){const e=this.getPreviousArgChoices(t);return void 0!==e&&e.length>0}argsContainKey(t,e,s){const i=e=>-1!==t.indexOf((/^[^0-9]$/.test(e)?"-":"--")+e);if(i(e))return!0;if(s&&i(`no-${e}`))return!0;if(this.aliases)for(const t of this.aliases[e])if(i(t))return!0;return!1}completeOptionKey(t,e,s,i){var n,r,o,a;let h=t;if(this.zshShell){const e=this.usage.getDescriptions(),s=null===(r=null===(n=null==this?void 0:this.aliases)||void 0===n?void 0:n[t])||void 0===r?void 0:r.find((t=>{const s=e[t];return"string"==typeof s&&s.length>0})),i=s?e[s]:void 0,l=null!==(a=null!==(o=e[t])&&void 0!==o?o:i)&&void 0!==a?a:"";h=`${t.replace(/:/g,"\\:")}:${l.replace("__yargsString__:","").replace(/(\r\n|\n|\r)/gm," ")}`}const l=!/^--/.test(s)&&(t=>/^[^0-9]$/.test(t))(t)?"-":"--";e.push(l+h),i&&e.push(l+"no-"+h)}customCompletion(t,e,s,i){if(d(this.customCompletionFunction,null,this.shim),this.customCompletionFunction.length<3){const t=this.customCompletionFunction(s,e);return f(t)?t.then((t=>{this.shim.process.nextTick((()=>{i(null,t)}))})).catch((t=>{this.shim.process.nextTick((()=>{i(t,void 0)}))})):i(null,t)}return function(t){return t.length>3}(this.customCompletionFunction)?this.customCompletionFunction(s,e,((n=i)=>this.defaultCompletion(t,e,s,n)),(t=>{i(null,t)})):this.customCompletionFunction(s,e,(t=>{i(null,t)}))}getCompletion(t,e){const s=t.length?t[t.length-1]:"",i=this.yargs.parse(t,!0),n=this.customCompletionFunction?i=>this.customCompletion(t,i,s,e):i=>this.defaultCompletion(t,i,s,e);return f(i)?i.then(n):n(i)}generateCompletionScript(t,e){let s=this.zshShell?'#compdef {{app_name}}\n###-begin-{{app_name}}-completions-###\n#\n# yargs command completion script\n#\n# Installation: {{app_path}} {{completion_command}} >> ~/.zshrc\n#    or {{app_path}} {{completion_command}} >> ~/.zprofile on OSX.\n#\n_{{app_name}}_yargs_completions()\n{\n  local reply\n  local si=$IFS\n  IFS=$\'\n\' reply=($(COMP_CWORD="$((CURRENT-1))" COMP_LINE="$BUFFER" COMP_POINT="$CURSOR" {{app_path}} --get-yargs-completions "${words[@]}"))\n  IFS=$si\n  _describe \'values\' reply\n}\ncompdef _{{app_name}}_yargs_completions {{app_name}}\n###-end-{{app_name}}-completions-###\n':'###-begin-{{app_name}}-completions-###\n#\n# yargs command completion script\n#\n# Installation: {{app_path}} {{completion_command}} >> ~/.bashrc\n#    or {{app_path}} {{completion_command}} >> ~/.bash_profile on OSX.\n#\n_{{app_name}}_yargs_completions()\n{\n    local cur_word args type_list\n\n    cur_word="${COMP_WORDS[COMP_CWORD]}"\n    args=("${COMP_WORDS[@]}")\n\n    # ask yargs to generate completions.\n    type_list=$({{app_path}} --get-yargs-completions "${args[@]}")\n\n    COMPREPLY=( $(compgen -W "${type_list}" -- ${cur_word}) )\n\n    # if no match was found, fall back to filename completion\n    if [ ${#COMPREPLY[@]} -eq 0 ]; then\n      COMPREPLY=()\n    fi\n\n    return 0\n}\ncomplete -o bashdefault -o default -F _{{app_name}}_yargs_completions {{app_name}}\n###-end-{{app_name}}-completions-###\n';const i=this.shim.path.basename(t);return t.match(/\.js$/)&&(t=`./${t}`),s=s.replace(/{{app_name}}/g,i),s=s.replace(/{{completion_command}}/g,e),s.replace(/{{app_path}}/g,t)}registerFunction(t){this.customCompletionFunction=t}setParsed(t){this.aliases=t.aliases}}function N(t,e){if(0===t.length)return e.length;if(0===e.length)return t.length;const s=[];let i,n;for(i=0;i<=e.length;i++)s[i]=[i];for(n=0;n<=t.length;n++)s[0][n]=n;for(i=1;i<=e.length;i++)for(n=1;n<=t.length;n++)e.charAt(i-1)===t.charAt(n-1)?s[i][n]=s[i-1][n-1]:i>1&&n>1&&e.charAt(i-2)===t.charAt(n-1)&&e.charAt(i-1)===t.charAt(n-2)?s[i][n]=s[i-2][n-2]+1:s[i][n]=Math.min(s[i-1][n-1]+1,Math.min(s[i][n-1]+1,s[i-1][n]+1));return s[e.length][t.length]}const H=["$0","--","_"];var z,W,q,U,F,L,V,G,R,T,B,Y,K,J,Z,X,Q,tt,et,st,it,nt,rt,ot,at,ht,lt,ct,ft,dt,ut,pt,gt,mt,yt;const bt=Symbol("copyDoubleDash"),vt=Symbol("copyDoubleDash"),Ot=Symbol("deleteFromParserHintObject"),wt=Symbol("emitWarning"),Ct=Symbol("freeze"),jt=Symbol("getDollarZero"),Mt=Symbol("getParserConfiguration"),_t=Symbol("getUsageConfiguration"),kt=Symbol("guessLocale"),xt=Symbol("guessVersion"),Et=Symbol("parsePositionalNumbers"),At=Symbol("pkgUp"),Pt=Symbol("populateParserHintArray"),St=Symbol("populateParserHintSingleValueDictionary"),$t=Symbol("populateParserHintArrayDictionary"),It=Symbol("populateParserHintDictionary"),Dt=Symbol("sanitizeKey"),Nt=Symbol("setKey"),Ht=Symbol("unfreeze"),zt=Symbol("validateAsync"),Wt=Symbol("getCommandInstance"),qt=Symbol("getContext"),Ut=Symbol("getHasOutput"),Ft=Symbol("getLoggerInstance"),Lt=Symbol("getParseContext"),Vt=Symbol("getUsageInstance"),Gt=Symbol("getValidationInstance"),Rt=Symbol("hasParseCallback"),Tt=Symbol("isGlobalContext"),Bt=Symbol("postProcess"),Yt=Symbol("rebase"),Kt=Symbol("reset"),Jt=Symbol("runYargsParserAndExecuteCommands"),Zt=Symbol("runValidation"),Xt=Symbol("setHasOutput"),Qt=Symbol("kTrackManuallySetKeys");class te{constructor(t=[],e,s,i){this.customScriptName=!1,this.parsed=!1,z.set(this,void 0),W.set(this,void 0),q.set(this,{commands:[],fullCommands:[]}),U.set(this,null),F.set(this,null),L.set(this,"show-hidden"),V.set(this,null),G.set(this,!0),R.set(this,{}),T.set(this,!0),B.set(this,[]),Y.set(this,void 0),K.set(this,{}),J.set(this,!1),Z.set(this,null),X.set(this,!0),Q.set(this,void 0),tt.set(this,""),et.set(this,void 0),st.set(this,void 0),it.set(this,{}),nt.set(this,null),rt.set(this,null),ot.set(this,{}),at.set(this,{}),ht.set(this,void 0),lt.set(this,!1),ct.set(this,void 0),ft.set(this,!1),dt.set(this,!1),ut.set(this,!1),pt.set(this,void 0),gt.set(this,{}),mt.set(this,null),yt.set(this,void 0),O(this,ct,i,"f"),O(this,ht,t,"f"),O(this,W,e,"f"),O(this,st,s,"f"),O(this,Y,new w(this),"f"),this.$0=this[jt](),this[Kt](),O(this,z,v(this,z,"f"),"f"),O(this,pt,v(this,pt,"f"),"f"),O(this,yt,v(this,yt,"f"),"f"),O(this,et,v(this,et,"f"),"f"),v(this,et,"f").showHiddenOpt=v(this,L,"f"),O(this,Q,this[vt](),"f")}addHelpOpt(t,e){return h("[string|boolean] [string]",[t,e],arguments.length),v(this,Z,"f")&&(this[Ot](v(this,Z,"f")),O(this,Z,null,"f")),!1===t&&void 0===e||(O(this,Z,"string"==typeof t?t:"help","f"),this.boolean(v(this,Z,"f")),this.describe(v(this,Z,"f"),e||v(this,pt,"f").deferY18nLookup("Show help"))),this}help(t,e){return this.addHelpOpt(t,e)}addShowHiddenOpt(t,e){if(h("[string|boolean] [string]",[t,e],arguments.length),!1===t&&void 0===e)return this;const s="string"==typeof t?t:v(this,L,"f");return this.boolean(s),this.describe(s,e||v(this,pt,"f").deferY18nLookup("Show hidden options")),v(this,et,"f").showHiddenOpt=s,this}showHidden(t,e){return this.addShowHiddenOpt(t,e)}alias(t,e){return h(" [string|array]",[t,e],arguments.length),this[$t](this.alias.bind(this),"alias",t,e),this}array(t){return h("",[t],arguments.length),this[Pt]("array",t),this[Qt](t),this}boolean(t){return h("",[t],arguments.length),this[Pt]("boolean",t),this[Qt](t),this}check(t,e){return h(" [boolean]",[t,e],arguments.length),this.middleware(((e,s)=>j((()=>t(e,s.getOptions())),(s=>(s?("string"==typeof s||s instanceof Error)&&v(this,pt,"f").fail(s.toString(),s):v(this,pt,"f").fail(v(this,ct,"f").y18n.__("Argument check failed: %s",t.toString())),e)),(t=>(v(this,pt,"f").fail(t.message?t.message:t.toString(),t),e)))),!1,e),this}choices(t,e){return h(" [string|array]",[t,e],arguments.length),this[$t](this.choices.bind(this),"choices",t,e),this}coerce(t,s){if(h(" [function]",[t,s],arguments.length),Array.isArray(t)){if(!s)throw new e("coerce callback must be provided");for(const e of t)this.coerce(e,s);return this}if("object"==typeof t){for(const e of Object.keys(t))this.coerce(e,t[e]);return this}if(!s)throw new e("coerce callback must be provided");return v(this,et,"f").key[t]=!0,v(this,Y,"f").addCoerceMiddleware(((i,n)=>{let r;return Object.prototype.hasOwnProperty.call(i,t)?j((()=>(r=n.getAliases(),s(i[t]))),(e=>{i[t]=e;const s=n.getInternalMethods().getParserConfiguration()["strip-aliased"];if(r[t]&&!0!==s)for(const s of r[t])i[s]=e;return i}),(t=>{throw new e(t.message)})):i}),t),this}conflicts(t,e){return h(" [string|array]",[t,e],arguments.length),v(this,yt,"f").conflicts(t,e),this}config(t="config",e,s){return h("[object|string] [string|function] [function]",[t,e,s],arguments.length),"object"!=typeof t||Array.isArray(t)?("function"==typeof e&&(s=e,e=void 0),this.describe(t,e||v(this,pt,"f").deferY18nLookup("Path to JSON config file")),(Array.isArray(t)?t:[t]).forEach((t=>{v(this,et,"f").config[t]=s||!0})),this):(t=n(t,v(this,W,"f"),this[Mt]()["deep-merge-config"]||!1,v(this,ct,"f")),v(this,et,"f").configObjects=(v(this,et,"f").configObjects||[]).concat(t),this)}completion(t,e,s){return h("[string] [string|boolean|function] [function]",[t,e,s],arguments.length),"function"==typeof e&&(s=e,e=void 0),O(this,F,t||v(this,F,"f")||"completion","f"),e||!1===e||(e="generate completion script"),this.command(v(this,F,"f"),e),s&&v(this,U,"f").registerFunction(s),this}command(t,e,s,i,n,r){return h(" [string|boolean] [function|object] [function] [array] [boolean|string]",[t,e,s,i,n,r],arguments.length),v(this,z,"f").addHandler(t,e,s,i,n,r),this}commands(t,e,s,i,n,r){return this.command(t,e,s,i,n,r)}commandDir(t,e){h(" [object]",[t,e],arguments.length);const s=v(this,st,"f")||v(this,ct,"f").require;return v(this,z,"f").addDirectory(t,s,v(this,ct,"f").getCallerFile(),e),this}count(t){return h("",[t],arguments.length),this[Pt]("count",t),this[Qt](t),this}default(t,e,s){return h(" [*] [string]",[t,e,s],arguments.length),s&&(u(t,v(this,ct,"f")),v(this,et,"f").defaultDescription[t]=s),"function"==typeof e&&(u(t,v(this,ct,"f")),v(this,et,"f").defaultDescription[t]||(v(this,et,"f").defaultDescription[t]=v(this,pt,"f").functionDescription(e)),e=e.call()),this[St](this.default.bind(this),"default",t,e),this}defaults(t,e,s){return this.default(t,e,s)}demandCommand(t=1,e,s,i){return h("[number] [number|string] [string|null|undefined] [string|null|undefined]",[t,e,s,i],arguments.length),"number"!=typeof e&&(s=e,e=1/0),this.global("_",!1),v(this,et,"f").demandedCommands._={min:t,max:e,minMsg:s,maxMsg:i},this}demand(t,e,s){return Array.isArray(e)?(e.forEach((t=>{d(s,!0,v(this,ct,"f")),this.demandOption(t,s)})),e=1/0):"number"!=typeof e&&(s=e,e=1/0),"number"==typeof t?(d(s,!0,v(this,ct,"f")),this.demandCommand(t,e,s,s)):Array.isArray(t)?t.forEach((t=>{d(s,!0,v(this,ct,"f")),this.demandOption(t,s)})):"string"==typeof s?this.demandOption(t,s):!0!==s&&void 0!==s||this.demandOption(t),this}demandOption(t,e){return h(" [string]",[t,e],arguments.length),this[St](this.demandOption.bind(this),"demandedOptions",t,e),this}deprecateOption(t,e){return h(" [string|boolean]",[t,e],arguments.length),v(this,et,"f").deprecatedOptions[t]=e,this}describe(t,e){return h(" [string]",[t,e],arguments.length),this[Nt](t,!0),v(this,pt,"f").describe(t,e),this}detectLocale(t){return h("",[t],arguments.length),O(this,G,t,"f"),this}env(t){return h("[string|boolean]",[t],arguments.length),!1===t?delete v(this,et,"f").envPrefix:v(this,et,"f").envPrefix=t||"",this}epilogue(t){return h("",[t],arguments.length),v(this,pt,"f").epilog(t),this}epilog(t){return this.epilogue(t)}example(t,e){return h(" [string]",[t,e],arguments.length),Array.isArray(t)?t.forEach((t=>this.example(...t))):v(this,pt,"f").example(t,e),this}exit(t,e){O(this,J,!0,"f"),O(this,V,e,"f"),v(this,T,"f")&&v(this,ct,"f").process.exit(t)}exitProcess(t=!0){return h("[boolean]",[t],arguments.length),O(this,T,t,"f"),this}fail(t){if(h("",[t],arguments.length),"boolean"==typeof t&&!1!==t)throw new e("Invalid first argument. Expected function or boolean 'false'");return v(this,pt,"f").failFn(t),this}getAliases(){return this.parsed?this.parsed.aliases:{}}async getCompletion(t,e){return h(" [function]",[t,e],arguments.length),e?v(this,U,"f").getCompletion(t,e):new Promise(((e,s)=>{v(this,U,"f").getCompletion(t,((t,i)=>{t?s(t):e(i)}))}))}getDemandedOptions(){return h([],0),v(this,et,"f").demandedOptions}getDemandedCommands(){return h([],0),v(this,et,"f").demandedCommands}getDeprecatedOptions(){return h([],0),v(this,et,"f").deprecatedOptions}getDetectLocale(){return v(this,G,"f")}getExitProcess(){return v(this,T,"f")}getGroups(){return Object.assign({},v(this,K,"f"),v(this,at,"f"))}getHelp(){if(O(this,J,!0,"f"),!v(this,pt,"f").hasCachedHelpMessage()){if(!this.parsed){const t=this[Jt](v(this,ht,"f"),void 0,void 0,0,!0);if(f(t))return t.then((()=>v(this,pt,"f").help()))}const t=v(this,z,"f").runDefaultBuilderOn(this);if(f(t))return t.then((()=>v(this,pt,"f").help()))}return Promise.resolve(v(this,pt,"f").help())}getOptions(){return v(this,et,"f")}getStrict(){return v(this,ft,"f")}getStrictCommands(){return v(this,dt,"f")}getStrictOptions(){return v(this,ut,"f")}global(t,e){return h(" [boolean]",[t,e],arguments.length),t=[].concat(t),!1!==e?v(this,et,"f").local=v(this,et,"f").local.filter((e=>-1===t.indexOf(e))):t.forEach((t=>{v(this,et,"f").local.includes(t)||v(this,et,"f").local.push(t)})),this}group(t,e){h(" ",[t,e],arguments.length);const s=v(this,at,"f")[e]||v(this,K,"f")[e];v(this,at,"f")[e]&&delete v(this,at,"f")[e];const i={};return v(this,K,"f")[e]=(s||[]).concat(t).filter((t=>!i[t]&&(i[t]=!0))),this}hide(t){return h("",[t],arguments.length),v(this,et,"f").hiddenOptions.push(t),this}implies(t,e){return h(" [number|string|array]",[t,e],arguments.length),v(this,yt,"f").implies(t,e),this}locale(t){return h("[string]",[t],arguments.length),void 0===t?(this[kt](),v(this,ct,"f").y18n.getLocale()):(O(this,G,!1,"f"),v(this,ct,"f").y18n.setLocale(t),this)}middleware(t,e,s){return v(this,Y,"f").addMiddleware(t,!!e,s)}nargs(t,e){return h(" [number]",[t,e],arguments.length),this[St](this.nargs.bind(this),"narg",t,e),this}normalize(t){return h("",[t],arguments.length),this[Pt]("normalize",t),this}number(t){return h("",[t],arguments.length),this[Pt]("number",t),this[Qt](t),this}option(t,e){if(h(" [object]",[t,e],arguments.length),"object"==typeof t)Object.keys(t).forEach((e=>{this.options(e,t[e])}));else{"object"!=typeof e&&(e={}),this[Qt](t),!v(this,mt,"f")||"version"!==t&&"version"!==(null==e?void 0:e.alias)||this[wt](['"version" is a reserved word.',"Please do one of the following:",'- Disable version with `yargs.version(false)` if using "version" as an option',"- Use the built-in `yargs.version` method instead (if applicable)","- Use a different option key","https://yargs.js.org/docs/#api-reference-version"].join("\n"),void 0,"versionWarning"),v(this,et,"f").key[t]=!0,e.alias&&this.alias(t,e.alias);const s=e.deprecate||e.deprecated;s&&this.deprecateOption(t,s);const i=e.demand||e.required||e.require;i&&this.demand(t,i),e.demandOption&&this.demandOption(t,"string"==typeof e.demandOption?e.demandOption:void 0),e.conflicts&&this.conflicts(t,e.conflicts),"default"in e&&this.default(t,e.default),void 0!==e.implies&&this.implies(t,e.implies),void 0!==e.nargs&&this.nargs(t,e.nargs),e.config&&this.config(t,e.configParser),e.normalize&&this.normalize(t),e.choices&&this.choices(t,e.choices),e.coerce&&this.coerce(t,e.coerce),e.group&&this.group(t,e.group),(e.boolean||"boolean"===e.type)&&(this.boolean(t),e.alias&&this.boolean(e.alias)),(e.array||"array"===e.type)&&(this.array(t),e.alias&&this.array(e.alias)),(e.number||"number"===e.type)&&(this.number(t),e.alias&&this.number(e.alias)),(e.string||"string"===e.type)&&(this.string(t),e.alias&&this.string(e.alias)),(e.count||"count"===e.type)&&this.count(t),"boolean"==typeof e.global&&this.global(t,e.global),e.defaultDescription&&(v(this,et,"f").defaultDescription[t]=e.defaultDescription),e.skipValidation&&this.skipValidation(t);const n=e.describe||e.description||e.desc,r=v(this,pt,"f").getDescriptions();Object.prototype.hasOwnProperty.call(r,t)&&"string"!=typeof n||this.describe(t,n),e.hidden&&this.hide(t),e.requiresArg&&this.requiresArg(t)}return this}options(t,e){return this.option(t,e)}parse(t,e,s){h("[string|array] [function|boolean|object] [function]",[t,e,s],arguments.length),this[Ct](),void 0===t&&(t=v(this,ht,"f")),"object"==typeof e&&(O(this,rt,e,"f"),e=s),"function"==typeof e&&(O(this,nt,e,"f"),e=!1),e||O(this,ht,t,"f"),v(this,nt,"f")&&O(this,T,!1,"f");const i=this[Jt](t,!!e),n=this.parsed;return v(this,U,"f").setParsed(this.parsed),f(i)?i.then((t=>(v(this,nt,"f")&&v(this,nt,"f").call(this,v(this,V,"f"),t,v(this,tt,"f")),t))).catch((t=>{throw v(this,nt,"f")&&v(this,nt,"f")(t,this.parsed.argv,v(this,tt,"f")),t})).finally((()=>{this[Ht](),this.parsed=n})):(v(this,nt,"f")&&v(this,nt,"f").call(this,v(this,V,"f"),i,v(this,tt,"f")),this[Ht](),this.parsed=n,i)}parseAsync(t,e,s){const i=this.parse(t,e,s);return f(i)?i:Promise.resolve(i)}parseSync(t,s,i){const n=this.parse(t,s,i);if(f(n))throw new e(".parseSync() must not be used with asynchronous builders, handlers, or middleware");return n}parserConfiguration(t){return h("",[t],arguments.length),O(this,it,t,"f"),this}pkgConf(t,e){h(" [string]",[t,e],arguments.length);let s=null;const i=this[At](e||v(this,W,"f"));return i[t]&&"object"==typeof i[t]&&(s=n(i[t],e||v(this,W,"f"),this[Mt]()["deep-merge-config"]||!1,v(this,ct,"f")),v(this,et,"f").configObjects=(v(this,et,"f").configObjects||[]).concat(s)),this}positional(t,e){h(" ",[t,e],arguments.length);const s=["default","defaultDescription","implies","normalize","choices","conflicts","coerce","type","describe","desc","description","alias"];e=g(e,((t,e)=>!("type"===t&&!["string","number","boolean"].includes(e))&&s.includes(t)));const i=v(this,q,"f").fullCommands[v(this,q,"f").fullCommands.length-1],n=i?v(this,z,"f").cmdToParseOptions(i):{array:[],alias:{},default:{},demand:{}};return p(n).forEach((s=>{const i=n[s];Array.isArray(i)?-1!==i.indexOf(t)&&(e[s]=!0):i[t]&&!(s in e)&&(e[s]=i[t])})),this.group(t,v(this,pt,"f").getPositionalGroupName()),this.option(t,e)}recommendCommands(t=!0){return h("[boolean]",[t],arguments.length),O(this,lt,t,"f"),this}required(t,e,s){return this.demand(t,e,s)}require(t,e,s){return this.demand(t,e,s)}requiresArg(t){return h(" [number]",[t],arguments.length),"string"==typeof t&&v(this,et,"f").narg[t]||this[St](this.requiresArg.bind(this),"narg",t,NaN),this}showCompletionScript(t,e){return h("[string] [string]",[t,e],arguments.length),t=t||this.$0,v(this,Q,"f").log(v(this,U,"f").generateCompletionScript(t,e||v(this,F,"f")||"completion")),this}showHelp(t){if(h("[string|function]",[t],arguments.length),O(this,J,!0,"f"),!v(this,pt,"f").hasCachedHelpMessage()){if(!this.parsed){const e=this[Jt](v(this,ht,"f"),void 0,void 0,0,!0);if(f(e))return e.then((()=>{v(this,pt,"f").showHelp(t)})),this}const e=v(this,z,"f").runDefaultBuilderOn(this);if(f(e))return e.then((()=>{v(this,pt,"f").showHelp(t)})),this}return v(this,pt,"f").showHelp(t),this}scriptName(t){return this.customScriptName=!0,this.$0=t,this}showHelpOnFail(t,e){return h("[boolean|string] [string]",[t,e],arguments.length),v(this,pt,"f").showHelpOnFail(t,e),this}showVersion(t){return h("[string|function]",[t],arguments.length),v(this,pt,"f").showVersion(t),this}skipValidation(t){return h("",[t],arguments.length),this[Pt]("skipValidation",t),this}strict(t){return h("[boolean]",[t],arguments.length),O(this,ft,!1!==t,"f"),this}strictCommands(t){return h("[boolean]",[t],arguments.length),O(this,dt,!1!==t,"f"),this}strictOptions(t){return h("[boolean]",[t],arguments.length),O(this,ut,!1!==t,"f"),this}string(t){return h("",[t],arguments.length),this[Pt]("string",t),this[Qt](t),this}terminalWidth(){return h([],0),v(this,ct,"f").process.stdColumns}updateLocale(t){return this.updateStrings(t)}updateStrings(t){return h("",[t],arguments.length),O(this,G,!1,"f"),v(this,ct,"f").y18n.updateLocale(t),this}usage(t,s,i,n){if(h(" [string|boolean] [function|object] [function]",[t,s,i,n],arguments.length),void 0!==s){if(d(t,null,v(this,ct,"f")),(t||"").match(/^\$0( |$)/))return this.command(t,s,i,n);throw new e(".usage() description must start with $0 if being used as alias for .command()")}return v(this,pt,"f").usage(t),this}usageConfiguration(t){return h("",[t],arguments.length),O(this,gt,t,"f"),this}version(t,e,s){const i="version";if(h("[boolean|string] [string] [string]",[t,e,s],arguments.length),v(this,mt,"f")&&(this[Ot](v(this,mt,"f")),v(this,pt,"f").version(void 0),O(this,mt,null,"f")),0===arguments.length)s=this[xt](),t=i;else if(1===arguments.length){if(!1===t)return this;s=t,t=i}else 2===arguments.length&&(s=e,e=void 0);return O(this,mt,"string"==typeof t?t:i,"f"),e=e||v(this,pt,"f").deferY18nLookup("Show version number"),v(this,pt,"f").version(s||void 0),this.boolean(v(this,mt,"f")),this.describe(v(this,mt,"f"),e),this}wrap(t){return h("",[t],arguments.length),v(this,pt,"f").wrap(t),this}[(z=new WeakMap,W=new WeakMap,q=new WeakMap,U=new WeakMap,F=new WeakMap,L=new WeakMap,V=new WeakMap,G=new WeakMap,R=new WeakMap,T=new WeakMap,B=new WeakMap,Y=new WeakMap,K=new WeakMap,J=new WeakMap,Z=new WeakMap,X=new WeakMap,Q=new WeakMap,tt=new WeakMap,et=new WeakMap,st=new WeakMap,it=new WeakMap,nt=new WeakMap,rt=new WeakMap,ot=new WeakMap,at=new WeakMap,ht=new WeakMap,lt=new WeakMap,ct=new WeakMap,ft=new WeakMap,dt=new WeakMap,ut=new WeakMap,pt=new WeakMap,gt=new WeakMap,mt=new WeakMap,yt=new WeakMap,bt)](t){if(!t._||!t["--"])return t;t._.push.apply(t._,t["--"]);try{delete t["--"]}catch(t){}return t}[vt](){return{log:(...t)=>{this[Rt]()||console.log(...t),O(this,J,!0,"f"),v(this,tt,"f").length&&O(this,tt,v(this,tt,"f")+"\n","f"),O(this,tt,v(this,tt,"f")+t.join(" "),"f")},error:(...t)=>{this[Rt]()||console.error(...t),O(this,J,!0,"f"),v(this,tt,"f").length&&O(this,tt,v(this,tt,"f")+"\n","f"),O(this,tt,v(this,tt,"f")+t.join(" "),"f")}}}[Ot](t){p(v(this,et,"f")).forEach((e=>{if("configObjects"===e)return;const s=v(this,et,"f")[e];Array.isArray(s)?s.includes(t)&&s.splice(s.indexOf(t),1):"object"==typeof s&&delete s[t]})),delete v(this,pt,"f").getDescriptions()[t]}[wt](t,e,s){v(this,R,"f")[s]||(v(this,ct,"f").process.emitWarning(t,e),v(this,R,"f")[s]=!0)}[Ct](){v(this,B,"f").push({options:v(this,et,"f"),configObjects:v(this,et,"f").configObjects.slice(0),exitProcess:v(this,T,"f"),groups:v(this,K,"f"),strict:v(this,ft,"f"),strictCommands:v(this,dt,"f"),strictOptions:v(this,ut,"f"),completionCommand:v(this,F,"f"),output:v(this,tt,"f"),exitError:v(this,V,"f"),hasOutput:v(this,J,"f"),parsed:this.parsed,parseFn:v(this,nt,"f"),parseContext:v(this,rt,"f")}),v(this,pt,"f").freeze(),v(this,yt,"f").freeze(),v(this,z,"f").freeze(),v(this,Y,"f").freeze()}[jt](){let t,e="";return t=/\b(node|iojs|electron)(\.exe)?$/.test(v(this,ct,"f").process.argv()[0])?v(this,ct,"f").process.argv().slice(1,2):v(this,ct,"f").process.argv().slice(0,1),e=t.map((t=>{const e=this[Yt](v(this,W,"f"),t);return t.match(/^(\/|([a-zA-Z]:)?\\)/)&&e.lengthe.includes("package.json")?"package.json":void 0));d(i,void 0,v(this,ct,"f")),s=JSON.parse(v(this,ct,"f").readFileSync(i,"utf8"))}catch(t){}return v(this,ot,"f")[e]=s||{},v(this,ot,"f")[e]}[Pt](t,e){(e=[].concat(e)).forEach((e=>{e=this[Dt](e),v(this,et,"f")[t].push(e)}))}[St](t,e,s,i){this[It](t,e,s,i,((t,e,s)=>{v(this,et,"f")[t][e]=s}))}[$t](t,e,s,i){this[It](t,e,s,i,((t,e,s)=>{v(this,et,"f")[t][e]=(v(this,et,"f")[t][e]||[]).concat(s)}))}[It](t,e,s,i,n){if(Array.isArray(s))s.forEach((e=>{t(e,i)}));else if((t=>"object"==typeof t)(s))for(const e of p(s))t(e,s[e]);else n(e,this[Dt](s),i)}[Dt](t){return"__proto__"===t?"___proto___":t}[Nt](t,e){return this[St](this[Nt].bind(this),"key",t,e),this}[Ht](){var t,e,s,i,n,r,o,a,h,l,c,f;const u=v(this,B,"f").pop();let p;d(u,void 0,v(this,ct,"f")),t=this,e=this,s=this,i=this,n=this,r=this,o=this,a=this,h=this,l=this,c=this,f=this,({options:{set value(e){O(t,et,e,"f")}}.value,configObjects:p,exitProcess:{set value(t){O(e,T,t,"f")}}.value,groups:{set value(t){O(s,K,t,"f")}}.value,output:{set value(t){O(i,tt,t,"f")}}.value,exitError:{set value(t){O(n,V,t,"f")}}.value,hasOutput:{set value(t){O(r,J,t,"f")}}.value,parsed:this.parsed,strict:{set value(t){O(o,ft,t,"f")}}.value,strictCommands:{set value(t){O(a,dt,t,"f")}}.value,strictOptions:{set value(t){O(h,ut,t,"f")}}.value,completionCommand:{set value(t){O(l,F,t,"f")}}.value,parseFn:{set value(t){O(c,nt,t,"f")}}.value,parseContext:{set value(t){O(f,rt,t,"f")}}.value}=u),v(this,et,"f").configObjects=p,v(this,pt,"f").unfreeze(),v(this,yt,"f").unfreeze(),v(this,z,"f").unfreeze(),v(this,Y,"f").unfreeze()}[zt](t,e){return j(e,(e=>(t(e),e)))}getInternalMethods(){return{getCommandInstance:this[Wt].bind(this),getContext:this[qt].bind(this),getHasOutput:this[Ut].bind(this),getLoggerInstance:this[Ft].bind(this),getParseContext:this[Lt].bind(this),getParserConfiguration:this[Mt].bind(this),getUsageConfiguration:this[_t].bind(this),getUsageInstance:this[Vt].bind(this),getValidationInstance:this[Gt].bind(this),hasParseCallback:this[Rt].bind(this),isGlobalContext:this[Tt].bind(this),postProcess:this[Bt].bind(this),reset:this[Kt].bind(this),runValidation:this[Zt].bind(this),runYargsParserAndExecuteCommands:this[Jt].bind(this),setHasOutput:this[Xt].bind(this)}}[Wt](){return v(this,z,"f")}[qt](){return v(this,q,"f")}[Ut](){return v(this,J,"f")}[Ft](){return v(this,Q,"f")}[Lt](){return v(this,rt,"f")||{}}[Vt](){return v(this,pt,"f")}[Gt](){return v(this,yt,"f")}[Rt](){return!!v(this,nt,"f")}[Tt](){return v(this,X,"f")}[Bt](t,e,s,i){if(s)return t;if(f(t))return t;e||(t=this[bt](t));return(this[Mt]()["parse-positional-numbers"]||void 0===this[Mt]()["parse-positional-numbers"])&&(t=this[Et](t)),i&&(t=C(t,this,v(this,Y,"f").getMiddleware(),!1)),t}[Kt](t={}){O(this,et,v(this,et,"f")||{},"f");const e={};e.local=v(this,et,"f").local||[],e.configObjects=v(this,et,"f").configObjects||[];const s={};e.local.forEach((e=>{s[e]=!0,(t[e]||[]).forEach((t=>{s[t]=!0}))})),Object.assign(v(this,at,"f"),Object.keys(v(this,K,"f")).reduce(((t,e)=>{const i=v(this,K,"f")[e].filter((t=>!(t in s)));return i.length>0&&(t[e]=i),t}),{})),O(this,K,{},"f");return["array","boolean","string","skipValidation","count","normalize","number","hiddenOptions"].forEach((t=>{e[t]=(v(this,et,"f")[t]||[]).filter((t=>!s[t]))})),["narg","key","alias","default","defaultDescription","config","choices","demandedOptions","demandedCommands","deprecatedOptions"].forEach((t=>{e[t]=g(v(this,et,"f")[t],(t=>!s[t]))})),e.envPrefix=v(this,et,"f").envPrefix,O(this,et,e,"f"),O(this,pt,v(this,pt,"f")?v(this,pt,"f").reset(s):P(this,v(this,ct,"f")),"f"),O(this,yt,v(this,yt,"f")?v(this,yt,"f").reset(s):function(t,e,s){const i=s.y18n.__,n=s.y18n.__n,r={nonOptionCount:function(s){const i=t.getDemandedCommands(),r=s._.length+(s["--"]?s["--"].length:0)-t.getInternalMethods().getContext().commands.length;i._&&(ri._.max)&&(ri._.max&&(void 0!==i._.maxMsg?e.fail(i._.maxMsg?i._.maxMsg.replace(/\$0/g,r.toString()).replace(/\$1/,i._.max.toString()):null):e.fail(n("Too many non-option arguments: got %s, maximum of %s","Too many non-option arguments: got %s, maximum of %s",r,r.toString(),i._.max.toString()))))},positionalCount:function(t,s){s{H.includes(e)||Object.prototype.hasOwnProperty.call(o,e)||Object.prototype.hasOwnProperty.call(t.getInternalMethods().getParseContext(),e)||r.isValidAndSomeAliasIsNotNew(e,i)||f.push(e)})),h&&(d.commands.length>0||c.length>0||a)&&s._.slice(d.commands.length).forEach((t=>{c.includes(""+t)||f.push(""+t)})),h){const e=(null===(l=t.getDemandedCommands()._)||void 0===l?void 0:l.max)||0,i=d.commands.length+e;i{t=String(t),d.commands.includes(t)||f.includes(t)||f.push(t)}))}f.length&&e.fail(n("Unknown argument: %s","Unknown arguments: %s",f.length,f.map((t=>t.trim()?t:`"${t}"`)).join(", ")))},unknownCommands:function(s){const i=t.getInternalMethods().getCommandInstance().getCommands(),r=[],o=t.getInternalMethods().getContext();return(o.commands.length>0||i.length>0)&&s._.slice(o.commands.length).forEach((t=>{i.includes(""+t)||r.push(""+t)})),r.length>0&&(e.fail(n("Unknown command: %s","Unknown commands: %s",r.length,r.join(", "))),!0)},isValidAndSomeAliasIsNotNew:function(e,s){if(!Object.prototype.hasOwnProperty.call(s,e))return!1;const i=t.parsed.newAliases;return[e,...s[e]].some((t=>!Object.prototype.hasOwnProperty.call(i,t)||!i[e]))},limitedChoices:function(s){const n=t.getOptions(),r={};if(!Object.keys(n.choices).length)return;Object.keys(s).forEach((t=>{-1===H.indexOf(t)&&Object.prototype.hasOwnProperty.call(n.choices,t)&&[].concat(s[t]).forEach((e=>{-1===n.choices[t].indexOf(e)&&void 0!==e&&(r[t]=(r[t]||[]).concat(e))}))}));const o=Object.keys(r);if(!o.length)return;let a=i("Invalid values:");o.forEach((t=>{a+=`\n  ${i("Argument: %s, Given: %s, Choices: %s",t,e.stringifiedValues(r[t]),e.stringifiedValues(n.choices[t]))}`})),e.fail(a)}};let o={};function a(t,e){const s=Number(e);return"number"==typeof(e=isNaN(s)?e:s)?e=t._.length>=e:e.match(/^--no-.+/)?(e=e.match(/^--no-(.+)/)[1],e=!Object.prototype.hasOwnProperty.call(t,e)):e=Object.prototype.hasOwnProperty.call(t,e),e}r.implies=function(e,i){h(" [array|number|string]",[e,i],arguments.length),"object"==typeof e?Object.keys(e).forEach((t=>{r.implies(t,e[t])})):(t.global(e),o[e]||(o[e]=[]),Array.isArray(i)?i.forEach((t=>r.implies(e,t))):(d(i,void 0,s),o[e].push(i)))},r.getImplied=function(){return o},r.implications=function(t){const s=[];if(Object.keys(o).forEach((e=>{const i=e;(o[e]||[]).forEach((e=>{let n=i;const r=e;n=a(t,n),e=a(t,e),n&&!e&&s.push(` ${i} -> ${r}`)}))})),s.length){let t=`${i("Implications failed:")}\n`;s.forEach((e=>{t+=e})),e.fail(t)}};let l={};r.conflicts=function(e,s){h(" [array|string]",[e,s],arguments.length),"object"==typeof e?Object.keys(e).forEach((t=>{r.conflicts(t,e[t])})):(t.global(e),l[e]||(l[e]=[]),Array.isArray(s)?s.forEach((t=>r.conflicts(e,t))):l[e].push(s))},r.getConflicting=()=>l,r.conflicting=function(n){Object.keys(n).forEach((t=>{l[t]&&l[t].forEach((s=>{s&&void 0!==n[t]&&void 0!==n[s]&&e.fail(i("Arguments %s and %s are mutually exclusive",t,s))}))})),t.getInternalMethods().getParserConfiguration()["strip-dashed"]&&Object.keys(l).forEach((t=>{l[t].forEach((r=>{r&&void 0!==n[s.Parser.camelCase(t)]&&void 0!==n[s.Parser.camelCase(r)]&&e.fail(i("Arguments %s and %s are mutually exclusive",t,r))}))}))},r.recommendCommands=function(t,s){s=s.sort(((t,e)=>e.length-t.length));let n=null,r=1/0;for(let e,i=0;void 0!==(e=s[i]);i++){const s=N(t,e);s<=3&&s!t[e])),l=g(l,(e=>!t[e])),r};const c=[];return r.freeze=function(){c.push({implied:o,conflicting:l})},r.unfreeze=function(){const t=c.pop();d(t,void 0,s),({implied:o,conflicting:l}=t)},r}(this,v(this,pt,"f"),v(this,ct,"f")),"f"),O(this,z,v(this,z,"f")?v(this,z,"f").reset():function(t,e,s,i){return new _(t,e,s,i)}(v(this,pt,"f"),v(this,yt,"f"),v(this,Y,"f"),v(this,ct,"f")),"f"),v(this,U,"f")||O(this,U,function(t,e,s,i){return new D(t,e,s,i)}(this,v(this,pt,"f"),v(this,z,"f"),v(this,ct,"f")),"f"),v(this,Y,"f").reset(),O(this,F,null,"f"),O(this,tt,"","f"),O(this,V,null,"f"),O(this,J,!1,"f"),this.parsed=!1,this}[Yt](t,e){return v(this,ct,"f").path.relative(t,e)}[Jt](t,s,i,n=0,r=!1){let o=!!i||r;t=t||v(this,ht,"f"),v(this,et,"f").__=v(this,ct,"f").y18n.__,v(this,et,"f").configuration=this[Mt]();const a=!!v(this,et,"f").configuration["populate--"],h=Object.assign({},v(this,et,"f").configuration,{"populate--":!0}),l=v(this,ct,"f").Parser.detailed(t,Object.assign({},v(this,et,"f"),{configuration:{"parse-positional-numbers":!1,...h}})),c=Object.assign(l.argv,v(this,rt,"f"));let d;const u=l.aliases;let p=!1,g=!1;Object.keys(c).forEach((t=>{t===v(this,Z,"f")&&c[t]?p=!0:t===v(this,mt,"f")&&c[t]&&(g=!0)})),c.$0=this.$0,this.parsed=l,0===n&&v(this,pt,"f").clearCachedHelpMessage();try{if(this[kt](),s)return this[Bt](c,a,!!i,!1);if(v(this,Z,"f")){[v(this,Z,"f")].concat(u[v(this,Z,"f")]||[]).filter((t=>t.length>1)).includes(""+c._[c._.length-1])&&(c._.pop(),p=!0)}O(this,X,!1,"f");const h=v(this,z,"f").getCommands(),m=v(this,U,"f").completionKey in c,y=p||m||r;if(c._.length){if(h.length){let t;for(let e,s=n||0;void 0!==c._[s];s++){if(e=String(c._[s]),h.includes(e)&&e!==v(this,F,"f")){const t=v(this,z,"f").runCommand(e,this,l,s+1,r,p||g||r);return this[Bt](t,a,!!i,!1)}if(!t&&e!==v(this,F,"f")){t=e;break}}!v(this,z,"f").hasDefaultCommand()&&v(this,lt,"f")&&t&&!y&&v(this,yt,"f").recommendCommands(t,h)}v(this,F,"f")&&c._.includes(v(this,F,"f"))&&!m&&(v(this,T,"f")&&E(!0),this.showCompletionScript(),this.exit(0))}if(v(this,z,"f").hasDefaultCommand()&&!y){const t=v(this,z,"f").runCommand(null,this,l,0,r,p||g||r);return this[Bt](t,a,!!i,!1)}if(m){v(this,T,"f")&&E(!0);const s=(t=[].concat(t)).slice(t.indexOf(`--${v(this,U,"f").completionKey}`)+1);return v(this,U,"f").getCompletion(s,((t,s)=>{if(t)throw new e(t.message);(s||[]).forEach((t=>{v(this,Q,"f").log(t)})),this.exit(0)})),this[Bt](c,!a,!!i,!1)}if(v(this,J,"f")||(p?(v(this,T,"f")&&E(!0),o=!0,this.showHelp("log"),this.exit(0)):g&&(v(this,T,"f")&&E(!0),o=!0,v(this,pt,"f").showVersion("log"),this.exit(0))),!o&&v(this,et,"f").skipValidation.length>0&&(o=Object.keys(c).some((t=>v(this,et,"f").skipValidation.indexOf(t)>=0&&!0===c[t]))),!o){if(l.error)throw new e(l.error.message);if(!m){const t=this[Zt](u,{},l.error);i||(d=C(c,this,v(this,Y,"f").getMiddleware(),!0)),d=this[zt](t,null!=d?d:c),f(d)&&!i&&(d=d.then((()=>C(c,this,v(this,Y,"f").getMiddleware(),!1))))}}}catch(t){if(!(t instanceof e))throw t;v(this,pt,"f").fail(t.message,t)}return this[Bt](null!=d?d:c,a,!!i,!0)}[Zt](t,s,i,n){const r={...this.getDemandedOptions()};return o=>{if(i)throw new e(i.message);v(this,yt,"f").nonOptionCount(o),v(this,yt,"f").requiredArguments(o,r);let a=!1;v(this,dt,"f")&&(a=v(this,yt,"f").unknownCommands(o)),v(this,ft,"f")&&!a?v(this,yt,"f").unknownArguments(o,t,s,!!n):v(this,ut,"f")&&v(this,yt,"f").unknownArguments(o,t,{},!1,!1),v(this,yt,"f").limitedChoices(o),v(this,yt,"f").implications(o),v(this,yt,"f").conflicting(o)}}[Xt](){O(this,J,!0,"f")}[Qt](t){if("string"==typeof t)v(this,et,"f").key[t]=!0;else for(const e of t)v(this,et,"f").key[e]=!0}}var ee,se;const{readFileSync:ie}=__nccwpck_require__(57147),{inspect:ne}=__nccwpck_require__(73837),{resolve:re}=__nccwpck_require__(71017),oe=__nccwpck_require__(53694),ae=__nccwpck_require__(94844);var he,le={assert:{notStrictEqual:t.notStrictEqual,strictEqual:t.strictEqual},cliui:__nccwpck_require__(34855),findUp:__nccwpck_require__(11149),getEnv:t=>process.env[t],getCallerFile:__nccwpck_require__(455),getProcessArgvBin:y,inspect:ne,mainFilename:null!==(se=null===(ee= false||void 0===__nccwpck_require__(49167)?void 0:__nccwpck_require__.c[__nccwpck_require__.s])||void 0===ee?void 0:ee.filename)&&void 0!==se?se:process.cwd(),Parser:ae,path:__nccwpck_require__(71017),process:{argv:()=>process.argv,cwd:process.cwd,emitWarning:(t,e)=>process.emitWarning(t,e),execPath:()=>process.execPath,exit:t=>{process.exit(t)},nextTick:process.nextTick,stdColumns:void 0!==process.stdout.columns?process.stdout.columns:null},readFileSync:ie,require:__nccwpck_require__(49167),requireDirectory:__nccwpck_require__(30761),stringWidth:__nccwpck_require__(24823),y18n:oe({directory:re(__dirname,"../locales"),updateFiles:!1})};const ce=(null===(he=null===process||void 0===process?void 0:process.env)||void 0===he?void 0:he.YARGS_MIN_NODE_VERSION)?Number(process.env.YARGS_MIN_NODE_VERSION):12;if(process&&process.version){if(Number(process.version.match(/v([^.]+)/)[1]){const i=new te(t,e,s,de);return Object.defineProperty(i,"argv",{get:()=>i.parse(),enumerable:!0}),i.help(),i.version(),i}),argsert:h,isPromise:f,objFilter:g,parseCommand:o,Parser:fe,processArgv:b,YError:e};module.exports=ue;
 
 
 /***/ }),
@@ -276023,7 +287653,7 @@ module.exports = ui;
 /***/ ((module) => {
 
 "use strict";
-module.exports = {"version":"1.3.73"};
+module.exports = {"version":"1.4.0"};
 
 /***/ }),
 
@@ -276063,7 +287693,7 @@ module.exports = JSON.parse('{"$schema":"https://json.schemastore.org/tsconfig",
 /***/ ((module) => {
 
 "use strict";
-module.exports = {"version":"16.3.2"};
+module.exports = {"version":"18.0.2"};
 
 /***/ }),
 
@@ -276071,7 +287701,7 @@ module.exports = {"version":"16.3.2"};
 /***/ ((module) => {
 
 "use strict";
-module.exports = {"version":"10.9.1"};
+module.exports = {"version":"10.9.2"};
 
 /***/ })
 
@@ -276137,7 +287767,7 @@ module.exports = {"version":"10.9.1"};
 /******/ 	// module cache are used so entry inlining is disabled
 /******/ 	// startup
 /******/ 	// Load entry module and return exports
-/******/ 	var __webpack_exports__ = __nccwpck_require__(__nccwpck_require__.s = 74658);
+/******/ 	var __webpack_exports__ = __nccwpck_require__(__nccwpck_require__.s = 28282);
 /******/ 	module.exports = __webpack_exports__;
 /******/ 	
 /******/ })()
diff --git a/actions/set-shas/dist/index.js b/actions/set-shas/dist/index.js
index 0c910eca..502650e0 100644
--- a/actions/set-shas/dist/index.js
+++ b/actions/set-shas/dist/index.js
@@ -1,7 +1,7 @@
 /******/ (() => { // webpackBootstrap
 /******/ 	var __webpack_modules__ = ({
 
-/***/ 7513:
+/***/ 1071:
 /***/ (function(__unused_webpack_module, exports, __nccwpck_require__) {
 
 "use strict";
@@ -28,7 +28,7 @@ var __importStar = (this && this.__importStar) || function (mod) {
 Object.defineProperty(exports, "__esModule", ({ value: true }));
 exports.issue = exports.issueCommand = void 0;
 const os = __importStar(__nccwpck_require__(2037));
-const utils_1 = __nccwpck_require__(7401);
+const utils_1 = __nccwpck_require__(6023);
 /**
  * Commands
  *
@@ -100,7 +100,7 @@ function escapeProperty(s) {
 
 /***/ }),
 
-/***/ 7896:
+/***/ 4712:
 /***/ (function(__unused_webpack_module, exports, __nccwpck_require__) {
 
 "use strict";
@@ -135,12 +135,12 @@ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, ge
 };
 Object.defineProperty(exports, "__esModule", ({ value: true }));
 exports.getIDToken = exports.getState = exports.saveState = exports.group = exports.endGroup = exports.startGroup = exports.info = exports.notice = exports.warning = exports.error = exports.debug = exports.isDebug = exports.setFailed = exports.setCommandEcho = exports.setOutput = exports.getBooleanInput = exports.getMultilineInput = exports.getInput = exports.addPath = exports.setSecret = exports.exportVariable = exports.ExitCode = void 0;
-const command_1 = __nccwpck_require__(7513);
-const file_command_1 = __nccwpck_require__(6802);
-const utils_1 = __nccwpck_require__(7401);
+const command_1 = __nccwpck_require__(1071);
+const file_command_1 = __nccwpck_require__(9034);
+const utils_1 = __nccwpck_require__(6023);
 const os = __importStar(__nccwpck_require__(2037));
 const path = __importStar(__nccwpck_require__(1017));
-const oidc_utils_1 = __nccwpck_require__(4852);
+const oidc_utils_1 = __nccwpck_require__(6963);
 /**
  * The code to exit an action
  */
@@ -425,17 +425,17 @@ exports.getIDToken = getIDToken;
 /**
  * Summary exports
  */
-var summary_1 = __nccwpck_require__(7259);
+var summary_1 = __nccwpck_require__(9140);
 Object.defineProperty(exports, "summary", ({ enumerable: true, get: function () { return summary_1.summary; } }));
 /**
  * @deprecated use core.summary
  */
-var summary_2 = __nccwpck_require__(7259);
+var summary_2 = __nccwpck_require__(9140);
 Object.defineProperty(exports, "markdownSummary", ({ enumerable: true, get: function () { return summary_2.markdownSummary; } }));
 /**
  * Path exports
  */
-var path_utils_1 = __nccwpck_require__(9442);
+var path_utils_1 = __nccwpck_require__(4531);
 Object.defineProperty(exports, "toPosixPath", ({ enumerable: true, get: function () { return path_utils_1.toPosixPath; } }));
 Object.defineProperty(exports, "toWin32Path", ({ enumerable: true, get: function () { return path_utils_1.toWin32Path; } }));
 Object.defineProperty(exports, "toPlatformPath", ({ enumerable: true, get: function () { return path_utils_1.toPlatformPath; } }));
@@ -443,7 +443,7 @@ Object.defineProperty(exports, "toPlatformPath", ({ enumerable: true, get: funct
 
 /***/ }),
 
-/***/ 6802:
+/***/ 9034:
 /***/ (function(__unused_webpack_module, exports, __nccwpck_require__) {
 
 "use strict";
@@ -474,8 +474,8 @@ exports.prepareKeyValueMessage = exports.issueFileCommand = void 0;
 /* eslint-disable @typescript-eslint/no-explicit-any */
 const fs = __importStar(__nccwpck_require__(7147));
 const os = __importStar(__nccwpck_require__(2037));
-const uuid_1 = __nccwpck_require__(580);
-const utils_1 = __nccwpck_require__(7401);
+const uuid_1 = __nccwpck_require__(7515);
+const utils_1 = __nccwpck_require__(6023);
 function issueFileCommand(command, message) {
     const filePath = process.env[`GITHUB_${command}`];
     if (!filePath) {
@@ -508,7 +508,7 @@ exports.prepareKeyValueMessage = prepareKeyValueMessage;
 
 /***/ }),
 
-/***/ 4852:
+/***/ 6963:
 /***/ (function(__unused_webpack_module, exports, __nccwpck_require__) {
 
 "use strict";
@@ -524,9 +524,9 @@ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, ge
 };
 Object.defineProperty(exports, "__esModule", ({ value: true }));
 exports.OidcClient = void 0;
-const http_client_1 = __nccwpck_require__(7281);
-const auth_1 = __nccwpck_require__(2669);
-const core_1 = __nccwpck_require__(7896);
+const http_client_1 = __nccwpck_require__(8158);
+const auth_1 = __nccwpck_require__(2601);
+const core_1 = __nccwpck_require__(4712);
 class OidcClient {
     static createHttpClient(allowRetry = true, maxRetry = 10) {
         const requestOptions = {
@@ -592,7 +592,7 @@ exports.OidcClient = OidcClient;
 
 /***/ }),
 
-/***/ 9442:
+/***/ 4531:
 /***/ (function(__unused_webpack_module, exports, __nccwpck_require__) {
 
 "use strict";
@@ -657,7 +657,7 @@ exports.toPlatformPath = toPlatformPath;
 
 /***/ }),
 
-/***/ 7259:
+/***/ 9140:
 /***/ (function(__unused_webpack_module, exports, __nccwpck_require__) {
 
 "use strict";
@@ -947,7 +947,7 @@ exports.summary = _summary;
 
 /***/ }),
 
-/***/ 7401:
+/***/ 6023:
 /***/ ((__unused_webpack_module, exports) => {
 
 "use strict";
@@ -994,7 +994,7 @@ exports.toCommandProperties = toCommandProperties;
 
 /***/ }),
 
-/***/ 9037:
+/***/ 440:
 /***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
 "use strict";
@@ -1055,7 +1055,7 @@ exports.Context = Context;
 
 /***/ }),
 
-/***/ 7486:
+/***/ 2758:
 /***/ (function(__unused_webpack_module, exports, __nccwpck_require__) {
 
 "use strict";
@@ -1081,8 +1081,8 @@ var __importStar = (this && this.__importStar) || function (mod) {
 };
 Object.defineProperty(exports, "__esModule", ({ value: true }));
 exports.getOctokit = exports.context = void 0;
-const Context = __importStar(__nccwpck_require__(9037));
-const utils_1 = __nccwpck_require__(8683);
+const Context = __importStar(__nccwpck_require__(440));
+const utils_1 = __nccwpck_require__(707);
 exports.context = new Context.Context();
 /**
  * Returns a hydrated octokit ready to use for GitHub Actions
@@ -1099,7 +1099,7 @@ exports.getOctokit = getOctokit;
 
 /***/ }),
 
-/***/ 611:
+/***/ 5798:
 /***/ (function(__unused_webpack_module, exports, __nccwpck_require__) {
 
 "use strict";
@@ -1125,7 +1125,7 @@ var __importStar = (this && this.__importStar) || function (mod) {
 };
 Object.defineProperty(exports, "__esModule", ({ value: true }));
 exports.getApiBaseUrl = exports.getProxyAgent = exports.getAuthString = void 0;
-const httpClient = __importStar(__nccwpck_require__(7281));
+const httpClient = __importStar(__nccwpck_require__(8158));
 function getAuthString(token, options) {
     if (!token && !options.auth) {
         throw new Error('Parameter token or opts.auth is required');
@@ -1149,7 +1149,7 @@ exports.getApiBaseUrl = getApiBaseUrl;
 
 /***/ }),
 
-/***/ 8683:
+/***/ 707:
 /***/ (function(__unused_webpack_module, exports, __nccwpck_require__) {
 
 "use strict";
@@ -1175,12 +1175,12 @@ var __importStar = (this && this.__importStar) || function (mod) {
 };
 Object.defineProperty(exports, "__esModule", ({ value: true }));
 exports.getOctokitOptions = exports.GitHub = exports.defaults = exports.context = void 0;
-const Context = __importStar(__nccwpck_require__(9037));
-const Utils = __importStar(__nccwpck_require__(611));
+const Context = __importStar(__nccwpck_require__(440));
+const Utils = __importStar(__nccwpck_require__(5798));
 // octokit + plugins
-const core_1 = __nccwpck_require__(3382);
-const plugin_rest_endpoint_methods_1 = __nccwpck_require__(1525);
-const plugin_paginate_rest_1 = __nccwpck_require__(7546);
+const core_1 = __nccwpck_require__(1023);
+const plugin_rest_endpoint_methods_1 = __nccwpck_require__(8582);
+const plugin_paginate_rest_1 = __nccwpck_require__(6787);
 exports.context = new Context.Context();
 const baseUrl = Utils.getApiBaseUrl();
 exports.defaults = {
@@ -1210,7 +1210,7 @@ exports.getOctokitOptions = getOctokitOptions;
 
 /***/ }),
 
-/***/ 2669:
+/***/ 2601:
 /***/ (function(__unused_webpack_module, exports) {
 
 "use strict";
@@ -1298,7 +1298,7 @@ exports.PersonalAccessTokenCredentialHandler = PersonalAccessTokenCredentialHand
 
 /***/ }),
 
-/***/ 7281:
+/***/ 8158:
 /***/ (function(__unused_webpack_module, exports, __nccwpck_require__) {
 
 "use strict";
@@ -1336,8 +1336,8 @@ Object.defineProperty(exports, "__esModule", ({ value: true }));
 exports.HttpClient = exports.isHttps = exports.HttpClientResponse = exports.HttpClientError = exports.getProxyUrl = exports.MediaTypes = exports.Headers = exports.HttpCodes = void 0;
 const http = __importStar(__nccwpck_require__(3685));
 const https = __importStar(__nccwpck_require__(5687));
-const pm = __importStar(__nccwpck_require__(2871));
-const tunnel = __importStar(__nccwpck_require__(7383));
+const pm = __importStar(__nccwpck_require__(4321));
+const tunnel = __importStar(__nccwpck_require__(2932));
 var HttpCodes;
 (function (HttpCodes) {
     HttpCodes[HttpCodes["OK"] = 200] = "OK";
@@ -1910,7 +1910,7 @@ const lowercaseKeys = (obj) => Object.keys(obj).reduce((c, k) => ((c[k.toLowerCa
 
 /***/ }),
 
-/***/ 2871:
+/***/ 4321:
 /***/ ((__unused_webpack_module, exports) => {
 
 "use strict";
@@ -1993,7 +1993,7 @@ function isLoopbackAddress(host) {
 
 /***/ }),
 
-/***/ 4285:
+/***/ 5853:
 /***/ ((__unused_webpack_module, exports) => {
 
 "use strict";
@@ -2056,7 +2056,7 @@ exports.createTokenAuth = createTokenAuth;
 
 /***/ }),
 
-/***/ 3382:
+/***/ 1023:
 /***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
 "use strict";
@@ -2064,11 +2064,11 @@ exports.createTokenAuth = createTokenAuth;
 
 Object.defineProperty(exports, "__esModule", ({ value: true }));
 
-var universalUserAgent = __nccwpck_require__(4021);
-var beforeAfterHook = __nccwpck_require__(9313);
-var request = __nccwpck_require__(6824);
-var graphql = __nccwpck_require__(4703);
-var authToken = __nccwpck_require__(4285);
+var universalUserAgent = __nccwpck_require__(9553);
+var beforeAfterHook = __nccwpck_require__(8655);
+var request = __nccwpck_require__(2680);
+var graphql = __nccwpck_require__(8257);
+var authToken = __nccwpck_require__(5853);
 
 function _objectWithoutPropertiesLoose(source, excluded) {
   if (source == null) return {};
@@ -2240,7 +2240,7 @@ exports.Octokit = Octokit;
 
 /***/ }),
 
-/***/ 9779:
+/***/ 7232:
 /***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
 "use strict";
@@ -2248,8 +2248,8 @@ exports.Octokit = Octokit;
 
 Object.defineProperty(exports, "__esModule", ({ value: true }));
 
-var isPlainObject = __nccwpck_require__(1716);
-var universalUserAgent = __nccwpck_require__(4021);
+var isPlainObject = __nccwpck_require__(461);
+var universalUserAgent = __nccwpck_require__(9553);
 
 function lowercaseKeys(object) {
   if (!object) {
@@ -2638,7 +2638,7 @@ exports.endpoint = endpoint;
 
 /***/ }),
 
-/***/ 4703:
+/***/ 8257:
 /***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
 "use strict";
@@ -2646,8 +2646,8 @@ exports.endpoint = endpoint;
 
 Object.defineProperty(exports, "__esModule", ({ value: true }));
 
-var request = __nccwpck_require__(6824);
-var universalUserAgent = __nccwpck_require__(4021);
+var request = __nccwpck_require__(2680);
+var universalUserAgent = __nccwpck_require__(9553);
 
 const VERSION = "4.8.0";
 
@@ -2764,7 +2764,7 @@ exports.withCustomRequest = withCustomRequest;
 
 /***/ }),
 
-/***/ 7546:
+/***/ 6787:
 /***/ ((__unused_webpack_module, exports) => {
 
 "use strict";
@@ -2977,7 +2977,7 @@ exports.paginatingEndpoints = paginatingEndpoints;
 
 /***/ }),
 
-/***/ 1525:
+/***/ 8582:
 /***/ ((__unused_webpack_module, exports) => {
 
 "use strict";
@@ -4092,7 +4092,7 @@ exports.restEndpointMethods = restEndpointMethods;
 
 /***/ }),
 
-/***/ 9167:
+/***/ 5301:
 /***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
 "use strict";
@@ -4102,8 +4102,8 @@ Object.defineProperty(exports, "__esModule", ({ value: true }));
 
 function _interopDefault (ex) { return (ex && (typeof ex === 'object') && 'default' in ex) ? ex['default'] : ex; }
 
-var deprecation = __nccwpck_require__(2377);
-var once = _interopDefault(__nccwpck_require__(7909));
+var deprecation = __nccwpck_require__(5922);
+var once = _interopDefault(__nccwpck_require__(3767));
 
 const logOnceCode = once(deprecation => console.warn(deprecation));
 const logOnceHeaders = once(deprecation => console.warn(deprecation));
@@ -4174,7 +4174,7 @@ exports.RequestError = RequestError;
 
 /***/ }),
 
-/***/ 6824:
+/***/ 2680:
 /***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
 "use strict";
@@ -4184,11 +4184,11 @@ Object.defineProperty(exports, "__esModule", ({ value: true }));
 
 function _interopDefault (ex) { return (ex && (typeof ex === 'object') && 'default' in ex) ? ex['default'] : ex; }
 
-var endpoint = __nccwpck_require__(9779);
-var universalUserAgent = __nccwpck_require__(4021);
-var isPlainObject = __nccwpck_require__(1716);
-var nodeFetch = _interopDefault(__nccwpck_require__(7002));
-var requestError = __nccwpck_require__(9167);
+var endpoint = __nccwpck_require__(7232);
+var universalUserAgent = __nccwpck_require__(9553);
+var isPlainObject = __nccwpck_require__(461);
+var nodeFetch = _interopDefault(__nccwpck_require__(1511));
+var requestError = __nccwpck_require__(5301);
 
 const VERSION = "5.6.3";
 
@@ -4359,7 +4359,7 @@ exports.request = request;
 
 /***/ }),
 
-/***/ 4015:
+/***/ 7524:
 /***/ ((module) => {
 
 "use strict";
@@ -4429,12 +4429,12 @@ function range(a, b, str) {
 
 /***/ }),
 
-/***/ 9313:
+/***/ 8655:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
-var register = __nccwpck_require__(9647);
-var addHook = __nccwpck_require__(5325);
-var removeHook = __nccwpck_require__(9837);
+var register = __nccwpck_require__(6776);
+var addHook = __nccwpck_require__(4502);
+var removeHook = __nccwpck_require__(9789);
 
 // bind with array of arguments: https://stackoverflow.com/a/21792913
 var bind = Function.bind;
@@ -4497,7 +4497,7 @@ module.exports.Collection = Hook.Collection;
 
 /***/ }),
 
-/***/ 5325:
+/***/ 4502:
 /***/ ((module) => {
 
 module.exports = addHook;
@@ -4550,7 +4550,7 @@ function addHook(state, kind, name, hook) {
 
 /***/ }),
 
-/***/ 9647:
+/***/ 6776:
 /***/ ((module) => {
 
 module.exports = register;
@@ -4584,7 +4584,7 @@ function register(state, name, method, options) {
 
 /***/ }),
 
-/***/ 9837:
+/***/ 9789:
 /***/ ((module) => {
 
 module.exports = removeHook;
@@ -4610,7 +4610,7 @@ function removeHook(state, name, method) {
 
 /***/ }),
 
-/***/ 819:
+/***/ 353:
 /***/ ((module) => {
 
 module.exports = function (xs, fn) {
@@ -4630,7 +4630,7 @@ var isArray = Array.isArray || function (xs) {
 
 /***/ }),
 
-/***/ 2377:
+/***/ 5922:
 /***/ ((__unused_webpack_module, exports) => {
 
 "use strict";
@@ -4658,13 +4658,13 @@ exports.Deprecation = Deprecation;
 
 /***/ }),
 
-/***/ 574:
+/***/ 4129:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
 
 
-var iconvLite = __nccwpck_require__(7482);
+var iconvLite = __nccwpck_require__(4318);
 
 // Expose to the world
 module.exports.O = convert;
@@ -4749,12 +4749,12 @@ function checkEncoding(name) {
 
 /***/ }),
 
-/***/ 8732:
+/***/ 6235:
 /***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
 "use strict";
 
-var Buffer = (__nccwpck_require__(5138).Buffer);
+var Buffer = (__nccwpck_require__(1383).Buffer);
 
 // Multibyte codec. In this scheme, a character is represented by 1 or more bytes.
 // Our codec supports UTF-16 surrogates, extensions for GB18030 and unicode sequences.
@@ -5354,7 +5354,7 @@ function findIdx(table, val) {
 
 /***/ }),
 
-/***/ 7581:
+/***/ 5850:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
@@ -5550,7 +5550,7 @@ module.exports = {
 
 /***/ }),
 
-/***/ 372:
+/***/ 6081:
 /***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
 "use strict";
@@ -5559,15 +5559,15 @@ module.exports = {
 // Update this array if you add/rename/remove files in this directory.
 // We support Browserify by skipping automatic module discovery and requiring modules directly.
 var modules = [
-    __nccwpck_require__(9390),
-    __nccwpck_require__(2278),
-    __nccwpck_require__(8824),
-    __nccwpck_require__(2883),
-    __nccwpck_require__(8842),
-    __nccwpck_require__(2526),
-    __nccwpck_require__(9871),
-    __nccwpck_require__(8732),
-    __nccwpck_require__(7581),
+    __nccwpck_require__(772),
+    __nccwpck_require__(7681),
+    __nccwpck_require__(3256),
+    __nccwpck_require__(2097),
+    __nccwpck_require__(815),
+    __nccwpck_require__(8557),
+    __nccwpck_require__(5054),
+    __nccwpck_require__(6235),
+    __nccwpck_require__(5850),
 ];
 
 // Put all encoding/alias/codec definitions to single object and export it.
@@ -5581,12 +5581,12 @@ for (var i = 0; i < modules.length; i++) {
 
 /***/ }),
 
-/***/ 9390:
+/***/ 772:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
 
-var Buffer = (__nccwpck_require__(5138).Buffer);
+var Buffer = (__nccwpck_require__(1383).Buffer);
 
 // Export Node.js internal encodings.
 
@@ -5787,12 +5787,12 @@ InternalDecoderCesu8.prototype.end = function() {
 
 /***/ }),
 
-/***/ 8842:
+/***/ 815:
 /***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
 "use strict";
 
-var Buffer = (__nccwpck_require__(5138).Buffer);
+var Buffer = (__nccwpck_require__(1383).Buffer);
 
 // Single-byte codec. Needs a 'chars' string parameter that contains 256 or 128 chars that
 // correspond to encoded bytes (if 128 - then lower half is ASCII). 
@@ -5867,7 +5867,7 @@ SBCSDecoder.prototype.end = function() {
 
 /***/ }),
 
-/***/ 9871:
+/***/ 5054:
 /***/ ((module) => {
 
 "use strict";
@@ -6325,7 +6325,7 @@ module.exports = {
 
 /***/ }),
 
-/***/ 2526:
+/***/ 8557:
 /***/ ((module) => {
 
 "use strict";
@@ -6512,12 +6512,12 @@ module.exports = {
 
 /***/ }),
 
-/***/ 8824:
+/***/ 3256:
 /***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
 "use strict";
 
-var Buffer = (__nccwpck_require__(5138).Buffer);
+var Buffer = (__nccwpck_require__(1383).Buffer);
 
 // Note: UTF16-LE (or UCS2) codec is Node.js native. See encodings/internal.js
 
@@ -6717,13 +6717,13 @@ function detectEncoding(bufs, defaultEncoding) {
 
 /***/ }),
 
-/***/ 2278:
+/***/ 7681:
 /***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
 "use strict";
 
 
-var Buffer = (__nccwpck_require__(5138).Buffer);
+var Buffer = (__nccwpck_require__(1383).Buffer);
 
 // == UTF32-LE/BE codec. ==========================================================
 
@@ -7044,12 +7044,12 @@ function detectEncoding(bufs, defaultEncoding) {
 
 /***/ }),
 
-/***/ 2883:
+/***/ 2097:
 /***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
 "use strict";
 
-var Buffer = (__nccwpck_require__(5138).Buffer);
+var Buffer = (__nccwpck_require__(1383).Buffer);
 
 // UTF-7 codec, according to https://tools.ietf.org/html/rfc2152
 // See also below a UTF-7-IMAP codec, according to http://tools.ietf.org/html/rfc3501#section-5.1.3
@@ -7342,7 +7342,7 @@ Utf7IMAPDecoder.prototype.end = function() {
 
 /***/ }),
 
-/***/ 1511:
+/***/ 4636:
 /***/ ((__unused_webpack_module, exports) => {
 
 "use strict";
@@ -7402,15 +7402,15 @@ StripBOMWrapper.prototype.end = function() {
 
 /***/ }),
 
-/***/ 7482:
+/***/ 4318:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
 
 
-var Buffer = (__nccwpck_require__(5138).Buffer);
+var Buffer = (__nccwpck_require__(1383).Buffer);
 
-var bomHandling = __nccwpck_require__(1511),
+var bomHandling = __nccwpck_require__(4636),
     iconv = module.exports;
 
 // All codecs and aliases are kept here, keyed by encoding name/alias.
@@ -7468,7 +7468,7 @@ iconv.fromEncoding = iconv.decode;
 iconv._codecDataCache = {};
 iconv.getCodec = function getCodec(encoding) {
     if (!iconv.encodings)
-        iconv.encodings = __nccwpck_require__(372); // Lazy load all encoding definitions.
+        iconv.encodings = __nccwpck_require__(6081); // Lazy load all encoding definitions.
     
     // Canonicalize encoding name: strip all non-alphanumeric chars and appended year.
     var enc = iconv._canonicalizeEncoding(encoding);
@@ -7549,7 +7549,7 @@ iconv.enableStreamingAPI = function enableStreamingAPI(stream_module) {
         return;
 
     // Dependency-inject stream module to create IconvLite stream classes.
-    var streams = __nccwpck_require__(1834)(stream_module);
+    var streams = __nccwpck_require__(7713)(stream_module);
 
     // Not public API yet, but expose the stream classes.
     iconv.IconvLiteEncoderStream = streams.IconvLiteEncoderStream;
@@ -7588,13 +7588,13 @@ if (false) {}
 
 /***/ }),
 
-/***/ 1834:
+/***/ 7713:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
 
 
-var Buffer = (__nccwpck_require__(5138).Buffer);
+var Buffer = (__nccwpck_require__(1383).Buffer);
 
 // NOTE: Due to 'stream' module being pretty large (~100Kb, significant in browser environments), 
 // we opt to dependency-inject it instead of creating a hard dependency.
@@ -7705,7 +7705,7 @@ module.exports = function(stream_module) {
 
 /***/ }),
 
-/***/ 5074:
+/***/ 6318:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 module.exports = realpath
@@ -7721,7 +7721,7 @@ var origRealpathSync = fs.realpathSync
 
 var version = process.version
 var ok = /^v[0-5]\./.test(version)
-var old = __nccwpck_require__(1830)
+var old = __nccwpck_require__(5086)
 
 function newError (er) {
   return er && er.syscall === 'realpath' && (
@@ -7778,7 +7778,7 @@ function unmonkeypatch () {
 
 /***/ }),
 
-/***/ 1830:
+/***/ 5086:
 /***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
 // Copyright Joyent, Inc. and other Node contributors.
@@ -8088,7 +8088,7 @@ exports.realpath = function realpath(p, cache, cb) {
 
 /***/ }),
 
-/***/ 3434:
+/***/ 9299:
 /***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
 exports.setopts = setopts
@@ -8105,8 +8105,8 @@ function ownProp (obj, field) {
 
 var fs = __nccwpck_require__(7147)
 var path = __nccwpck_require__(1017)
-var minimatch = __nccwpck_require__(4546)
-var isAbsolute = __nccwpck_require__(124)
+var minimatch = __nccwpck_require__(491)
+var isAbsolute = __nccwpck_require__(6384)
 var Minimatch = minimatch.Minimatch
 
 function alphasort (a, b) {
@@ -8333,7 +8333,7 @@ function childrenIgnored (self, path) {
 
 /***/ }),
 
-/***/ 557:
+/***/ 9959:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 // Approach:
@@ -8378,24 +8378,24 @@ function childrenIgnored (self, path) {
 
 module.exports = glob
 
-var rp = __nccwpck_require__(5074)
-var minimatch = __nccwpck_require__(4546)
+var rp = __nccwpck_require__(6318)
+var minimatch = __nccwpck_require__(491)
 var Minimatch = minimatch.Minimatch
-var inherits = __nccwpck_require__(2868)
+var inherits = __nccwpck_require__(6401)
 var EE = (__nccwpck_require__(2361).EventEmitter)
 var path = __nccwpck_require__(1017)
 var assert = __nccwpck_require__(9491)
-var isAbsolute = __nccwpck_require__(124)
-var globSync = __nccwpck_require__(9278)
-var common = __nccwpck_require__(3434)
+var isAbsolute = __nccwpck_require__(6384)
+var globSync = __nccwpck_require__(1498)
+var common = __nccwpck_require__(9299)
 var setopts = common.setopts
 var ownProp = common.ownProp
-var inflight = __nccwpck_require__(629)
+var inflight = __nccwpck_require__(8107)
 var util = __nccwpck_require__(3837)
 var childrenIgnored = common.childrenIgnored
 var isIgnored = common.isIgnored
 
-var once = __nccwpck_require__(7909)
+var once = __nccwpck_require__(3767)
 
 function glob (pattern, options, cb) {
   if (typeof options === 'function') cb = options, options = {}
@@ -9130,21 +9130,21 @@ Glob.prototype._stat2 = function (f, abs, er, stat, cb) {
 
 /***/ }),
 
-/***/ 9278:
+/***/ 1498:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 module.exports = globSync
 globSync.GlobSync = GlobSync
 
-var rp = __nccwpck_require__(5074)
-var minimatch = __nccwpck_require__(4546)
+var rp = __nccwpck_require__(6318)
+var minimatch = __nccwpck_require__(491)
 var Minimatch = minimatch.Minimatch
-var Glob = (__nccwpck_require__(557).Glob)
+var Glob = (__nccwpck_require__(9959).Glob)
 var util = __nccwpck_require__(3837)
 var path = __nccwpck_require__(1017)
 var assert = __nccwpck_require__(9491)
-var isAbsolute = __nccwpck_require__(124)
-var common = __nccwpck_require__(3434)
+var isAbsolute = __nccwpck_require__(6384)
+var common = __nccwpck_require__(9299)
 var setopts = common.setopts
 var ownProp = common.ownProp
 var childrenIgnored = common.childrenIgnored
@@ -9623,12 +9623,12 @@ GlobSync.prototype._makeAbs = function (f) {
 
 /***/ }),
 
-/***/ 629:
+/***/ 8107:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
-var wrappy = __nccwpck_require__(3180)
+var wrappy = __nccwpck_require__(5173)
 var reqs = Object.create(null)
-var once = __nccwpck_require__(7909)
+var once = __nccwpck_require__(3767)
 
 module.exports = wrappy(inflight)
 
@@ -9684,7 +9684,7 @@ function slice (args) {
 
 /***/ }),
 
-/***/ 2868:
+/***/ 6401:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 try {
@@ -9694,13 +9694,13 @@ try {
   module.exports = util.inherits;
 } catch (e) {
   /* istanbul ignore next */
-  module.exports = __nccwpck_require__(4278);
+  module.exports = __nccwpck_require__(5195);
 }
 
 
 /***/ }),
 
-/***/ 4278:
+/***/ 5195:
 /***/ ((module) => {
 
 if (typeof Object.create === 'function') {
@@ -9734,7 +9734,7 @@ if (typeof Object.create === 'function') {
 
 /***/ }),
 
-/***/ 1716:
+/***/ 461:
 /***/ ((__unused_webpack_module, exports) => {
 
 "use strict";
@@ -9780,7 +9780,7 @@ exports.isPlainObject = isPlainObject;
 
 /***/ }),
 
-/***/ 4546:
+/***/ 491:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 module.exports = minimatch
@@ -9792,7 +9792,7 @@ var path = (function () { try { return __nccwpck_require__(1017) } catch (e) {}}
 minimatch.sep = path.sep
 
 var GLOBSTAR = minimatch.GLOBSTAR = Minimatch.GLOBSTAR = {}
-var expand = __nccwpck_require__(6265)
+var expand = __nccwpck_require__(4792)
 
 var plTypes = {
   '!': { open: '(?:(?!(?:', close: '))[^/]*?)'},
@@ -10734,11 +10734,11 @@ function regExpEscape (s) {
 
 /***/ }),
 
-/***/ 6265:
+/***/ 4792:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
-var concatMap = __nccwpck_require__(819);
-var balanced = __nccwpck_require__(4015);
+var concatMap = __nccwpck_require__(353);
+var balanced = __nccwpck_require__(7524);
 
 module.exports = expandTop;
 
@@ -10942,7 +10942,7 @@ function expand(str, isTop) {
 
 /***/ }),
 
-/***/ 7002:
+/***/ 1511:
 /***/ ((module, exports, __nccwpck_require__) => {
 
 "use strict";
@@ -10955,7 +10955,7 @@ function _interopDefault (ex) { return (ex && (typeof ex === 'object') && 'defau
 var Stream = _interopDefault(__nccwpck_require__(2781));
 var http = _interopDefault(__nccwpck_require__(3685));
 var Url = _interopDefault(__nccwpck_require__(7310));
-var whatwgUrl = _interopDefault(__nccwpck_require__(9619));
+var whatwgUrl = _interopDefault(__nccwpck_require__(4));
 var https = _interopDefault(__nccwpck_require__(5687));
 var zlib = _interopDefault(__nccwpck_require__(9796));
 
@@ -11108,7 +11108,7 @@ FetchError.prototype.name = 'FetchError';
 
 let convert;
 try {
-	convert = (__nccwpck_require__(574)/* .convert */ .O);
+	convert = (__nccwpck_require__(4129)/* .convert */ .O);
 } catch (e) {}
 
 const INTERNALS = Symbol('Body internals');
@@ -12737,10 +12737,10 @@ exports.FetchError = FetchError;
 
 /***/ }),
 
-/***/ 7909:
+/***/ 3767:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
-var wrappy = __nccwpck_require__(3180)
+var wrappy = __nccwpck_require__(5173)
 module.exports = wrappy(once)
 module.exports.strict = wrappy(onceStrict)
 
@@ -12786,7 +12786,7 @@ function onceStrict (fn) {
 
 /***/ }),
 
-/***/ 124:
+/***/ 6384:
 /***/ ((module) => {
 
 "use strict";
@@ -12814,7 +12814,7 @@ module.exports.win32 = win32;
 
 /***/ }),
 
-/***/ 5138:
+/***/ 1383:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
@@ -12899,7 +12899,7 @@ module.exports = safer
 
 /***/ }),
 
-/***/ 7270:
+/***/ 5907:
 /***/ ((module) => {
 
 module.exports = [
@@ -12935,7 +12935,7 @@ module.exports = [
 
 /***/ }),
 
-/***/ 4572:
+/***/ 6877:
 /***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
 //
@@ -12947,40 +12947,40 @@ module.exports = [
 //
 
 function __ncc_wildcard$0 (arg) {
-  if (arg === "cat.js" || arg === "cat") return __nccwpck_require__(5562);
-  else if (arg === "cd.js" || arg === "cd") return __nccwpck_require__(1829);
-  else if (arg === "chmod.js" || arg === "chmod") return __nccwpck_require__(1072);
-  else if (arg === "common.js" || arg === "common") return __nccwpck_require__(7673);
-  else if (arg === "cp.js" || arg === "cp") return __nccwpck_require__(6135);
-  else if (arg === "dirs.js" || arg === "dirs") return __nccwpck_require__(220);
-  else if (arg === "echo.js" || arg === "echo") return __nccwpck_require__(9534);
-  else if (arg === "error.js" || arg === "error") return __nccwpck_require__(9862);
-  else if (arg === "exec-child.js" || arg === "exec-child") return __nccwpck_require__(4416);
-  else if (arg === "exec.js" || arg === "exec") return __nccwpck_require__(4221);
-  else if (arg === "find.js" || arg === "find") return __nccwpck_require__(9198);
-  else if (arg === "grep.js" || arg === "grep") return __nccwpck_require__(8869);
-  else if (arg === "head.js" || arg === "head") return __nccwpck_require__(1712);
-  else if (arg === "ln.js" || arg === "ln") return __nccwpck_require__(6786);
-  else if (arg === "ls.js" || arg === "ls") return __nccwpck_require__(9644);
-  else if (arg === "mkdir.js" || arg === "mkdir") return __nccwpck_require__(9494);
-  else if (arg === "mv.js" || arg === "mv") return __nccwpck_require__(1285);
-  else if (arg === "popd.js" || arg === "popd") return __nccwpck_require__(2535);
-  else if (arg === "pushd.js" || arg === "pushd") return __nccwpck_require__(7928);
-  else if (arg === "pwd.js" || arg === "pwd") return __nccwpck_require__(4020);
-  else if (arg === "rm.js" || arg === "rm") return __nccwpck_require__(7720);
-  else if (arg === "sed.js" || arg === "sed") return __nccwpck_require__(6926);
-  else if (arg === "set.js" || arg === "set") return __nccwpck_require__(11);
-  else if (arg === "sort.js" || arg === "sort") return __nccwpck_require__(7472);
-  else if (arg === "tail.js" || arg === "tail") return __nccwpck_require__(8968);
-  else if (arg === "tempdir.js" || arg === "tempdir") return __nccwpck_require__(591);
-  else if (arg === "test.js" || arg === "test") return __nccwpck_require__(9063);
-  else if (arg === "to.js" || arg === "to") return __nccwpck_require__(4897);
-  else if (arg === "toEnd.js" || arg === "toEnd") return __nccwpck_require__(228);
-  else if (arg === "touch.js" || arg === "touch") return __nccwpck_require__(8440);
-  else if (arg === "uniq.js" || arg === "uniq") return __nccwpck_require__(5499);
-  else if (arg === "which.js" || arg === "which") return __nccwpck_require__(5405);
-}
-var common = __nccwpck_require__(7673);
+  if (arg === "cat.js" || arg === "cat") return __nccwpck_require__(7587);
+  else if (arg === "cd.js" || arg === "cd") return __nccwpck_require__(9117);
+  else if (arg === "chmod.js" || arg === "chmod") return __nccwpck_require__(9879);
+  else if (arg === "common.js" || arg === "common") return __nccwpck_require__(624);
+  else if (arg === "cp.js" || arg === "cp") return __nccwpck_require__(4395);
+  else if (arg === "dirs.js" || arg === "dirs") return __nccwpck_require__(1060);
+  else if (arg === "echo.js" || arg === "echo") return __nccwpck_require__(607);
+  else if (arg === "error.js" || arg === "error") return __nccwpck_require__(6829);
+  else if (arg === "exec-child.js" || arg === "exec-child") return __nccwpck_require__(148);
+  else if (arg === "exec.js" || arg === "exec") return __nccwpck_require__(5239);
+  else if (arg === "find.js" || arg === "find") return __nccwpck_require__(2388);
+  else if (arg === "grep.js" || arg === "grep") return __nccwpck_require__(7294);
+  else if (arg === "head.js" || arg === "head") return __nccwpck_require__(4902);
+  else if (arg === "ln.js" || arg === "ln") return __nccwpck_require__(8092);
+  else if (arg === "ls.js" || arg === "ls") return __nccwpck_require__(2248);
+  else if (arg === "mkdir.js" || arg === "mkdir") return __nccwpck_require__(7707);
+  else if (arg === "mv.js" || arg === "mv") return __nccwpck_require__(8146);
+  else if (arg === "popd.js" || arg === "popd") return __nccwpck_require__(2425);
+  else if (arg === "pushd.js" || arg === "pushd") return __nccwpck_require__(8943);
+  else if (arg === "pwd.js" || arg === "pwd") return __nccwpck_require__(909);
+  else if (arg === "rm.js" || arg === "rm") return __nccwpck_require__(4369);
+  else if (arg === "sed.js" || arg === "sed") return __nccwpck_require__(3401);
+  else if (arg === "set.js" || arg === "set") return __nccwpck_require__(2833);
+  else if (arg === "sort.js" || arg === "sort") return __nccwpck_require__(2675);
+  else if (arg === "tail.js" || arg === "tail") return __nccwpck_require__(1434);
+  else if (arg === "tempdir.js" || arg === "tempdir") return __nccwpck_require__(8691);
+  else if (arg === "test.js" || arg === "test") return __nccwpck_require__(2766);
+  else if (arg === "to.js" || arg === "to") return __nccwpck_require__(3181);
+  else if (arg === "toEnd.js" || arg === "toEnd") return __nccwpck_require__(5836);
+  else if (arg === "touch.js" || arg === "touch") return __nccwpck_require__(9811);
+  else if (arg === "uniq.js" || arg === "uniq") return __nccwpck_require__(9095);
+  else if (arg === "which.js" || arg === "which") return __nccwpck_require__(858);
+}
+var common = __nccwpck_require__(624);
 
 //@
 //@ All commands run synchronously, unless otherwise stated.
@@ -12995,7 +12995,7 @@ var common = __nccwpck_require__(7673);
 //@commands
 
 // Load all default commands
-(__nccwpck_require__(7270).forEach)(function (command) {
+(__nccwpck_require__(5907).forEach)(function (command) {
   __ncc_wildcard$0(command);
 });
 
@@ -13006,7 +13006,7 @@ var common = __nccwpck_require__(7673);
 exports.exit = process.exit;
 
 //@include ./src/error
-exports.error = __nccwpck_require__(9862);
+exports.error = __nccwpck_require__(6829);
 
 //@include ./src/common
 exports.ShellString = common.ShellString;
@@ -13132,10 +13132,10 @@ exports.config = common.config;
 
 /***/ }),
 
-/***/ 5562:
+/***/ 7587:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
-var common = __nccwpck_require__(7673);
+var common = __nccwpck_require__(624);
 var fs = __nccwpck_require__(7147);
 
 common.register('cat', _cat, {
@@ -13215,11 +13215,11 @@ function numberedLine(n, line) {
 
 /***/ }),
 
-/***/ 1829:
+/***/ 9117:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 var os = __nccwpck_require__(2037);
-var common = __nccwpck_require__(7673);
+var common = __nccwpck_require__(624);
 
 common.register('cd', _cd, {});
 
@@ -13261,10 +13261,10 @@ module.exports = _cd;
 
 /***/ }),
 
-/***/ 1072:
+/***/ 9879:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
-var common = __nccwpck_require__(7673);
+var common = __nccwpck_require__(624);
 var fs = __nccwpck_require__(7147);
 var path = __nccwpck_require__(1017);
 
@@ -13484,7 +13484,7 @@ module.exports = _chmod;
 
 /***/ }),
 
-/***/ 7673:
+/***/ 624:
 /***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
 "use strict";
@@ -13494,8 +13494,8 @@ module.exports = _chmod;
 
 var os = __nccwpck_require__(2037);
 var fs = __nccwpck_require__(7147);
-var glob = __nccwpck_require__(557);
-var shell = __nccwpck_require__(4572);
+var glob = __nccwpck_require__(9959);
+var shell = __nccwpck_require__(6877);
 
 var shellMethods = Object.create(shell);
 
@@ -13960,12 +13960,12 @@ exports.register = _register;
 
 /***/ }),
 
-/***/ 6135:
+/***/ 4395:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 var fs = __nccwpck_require__(7147);
 var path = __nccwpck_require__(1017);
-var common = __nccwpck_require__(7673);
+var common = __nccwpck_require__(624);
 
 common.register('cp', _cp, {
   cmdOptions: {
@@ -14271,11 +14271,11 @@ module.exports = _cp;
 
 /***/ }),
 
-/***/ 220:
+/***/ 1060:
 /***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
-var common = __nccwpck_require__(7673);
-var _cd = __nccwpck_require__(1829);
+var common = __nccwpck_require__(624);
+var _cd = __nccwpck_require__(9117);
 var path = __nccwpck_require__(1017);
 
 common.register('dirs', _dirs, {
@@ -14490,12 +14490,12 @@ exports.dirs = _dirs;
 
 /***/ }),
 
-/***/ 9534:
+/***/ 607:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 var format = (__nccwpck_require__(3837).format);
 
-var common = __nccwpck_require__(7673);
+var common = __nccwpck_require__(624);
 
 common.register('echo', _echo, {
   allowGlobbing: false,
@@ -14560,10 +14560,10 @@ module.exports = _echo;
 
 /***/ }),
 
-/***/ 9862:
+/***/ 6829:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
-var common = __nccwpck_require__(7673);
+var common = __nccwpck_require__(624);
 
 //@
 //@ ### error()
@@ -14582,7 +14582,7 @@ module.exports = error;
 
 /***/ }),
 
-/***/ 4416:
+/***/ 148:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 /* module decorator */ module = __nccwpck_require__.nmd(module);
@@ -14629,12 +14629,12 @@ if (pipe) {
 
 /***/ }),
 
-/***/ 4221:
+/***/ 5239:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
-var common = __nccwpck_require__(7673);
-var _tempDir = (__nccwpck_require__(591).tempDir);
-var _pwd = __nccwpck_require__(4020);
+var common = __nccwpck_require__(624);
+var _tempDir = (__nccwpck_require__(8691).tempDir);
+var _pwd = __nccwpck_require__(909);
 var path = __nccwpck_require__(1017);
 var fs = __nccwpck_require__(7147);
 var child = __nccwpck_require__(2081);
@@ -14862,12 +14862,12 @@ module.exports = _exec;
 
 /***/ }),
 
-/***/ 9198:
+/***/ 2388:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 var path = __nccwpck_require__(1017);
-var common = __nccwpck_require__(7673);
-var _ls = __nccwpck_require__(9644);
+var common = __nccwpck_require__(624);
+var _ls = __nccwpck_require__(2248);
 
 common.register('find', _find, {});
 
@@ -14930,10 +14930,10 @@ module.exports = _find;
 
 /***/ }),
 
-/***/ 8869:
+/***/ 7294:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
-var common = __nccwpck_require__(7673);
+var common = __nccwpck_require__(624);
 var fs = __nccwpck_require__(7147);
 
 common.register('grep', _grep, {
@@ -15010,10 +15010,10 @@ module.exports = _grep;
 
 /***/ }),
 
-/***/ 1712:
+/***/ 4902:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
-var common = __nccwpck_require__(7673);
+var common = __nccwpck_require__(624);
 var fs = __nccwpck_require__(7147);
 
 common.register('head', _head, {
@@ -15124,12 +15124,12 @@ module.exports = _head;
 
 /***/ }),
 
-/***/ 6786:
+/***/ 8092:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 var fs = __nccwpck_require__(7147);
 var path = __nccwpck_require__(1017);
-var common = __nccwpck_require__(7673);
+var common = __nccwpck_require__(624);
 
 common.register('ln', _ln, {
   cmdOptions: {
@@ -15204,13 +15204,13 @@ module.exports = _ln;
 
 /***/ }),
 
-/***/ 9644:
+/***/ 2248:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 var path = __nccwpck_require__(1017);
 var fs = __nccwpck_require__(7147);
-var common = __nccwpck_require__(7673);
-var glob = __nccwpck_require__(557);
+var common = __nccwpck_require__(624);
+var glob = __nccwpck_require__(9959);
 
 var globPatternRecursive = path.sep + '**';
 
@@ -15352,10 +15352,10 @@ module.exports = _ls;
 
 /***/ }),
 
-/***/ 9494:
+/***/ 7707:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
-var common = __nccwpck_require__(7673);
+var common = __nccwpck_require__(624);
 var fs = __nccwpck_require__(7147);
 var path = __nccwpck_require__(1017);
 
@@ -15459,14 +15459,14 @@ module.exports = _mkdir;
 
 /***/ }),
 
-/***/ 1285:
+/***/ 8146:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 var fs = __nccwpck_require__(7147);
 var path = __nccwpck_require__(1017);
-var common = __nccwpck_require__(7673);
-var cp = __nccwpck_require__(6135);
-var rm = __nccwpck_require__(7720);
+var common = __nccwpck_require__(624);
+var cp = __nccwpck_require__(4395);
+var rm = __nccwpck_require__(4369);
 
 common.register('mv', _mv, {
   cmdOptions: {
@@ -15584,7 +15584,7 @@ module.exports = _mv;
 
 /***/ }),
 
-/***/ 2535:
+/***/ 2425:
 /***/ (() => {
 
 // see dirs.js
@@ -15592,7 +15592,7 @@ module.exports = _mv;
 
 /***/ }),
 
-/***/ 7928:
+/***/ 8943:
 /***/ (() => {
 
 // see dirs.js
@@ -15600,11 +15600,11 @@ module.exports = _mv;
 
 /***/ }),
 
-/***/ 4020:
+/***/ 909:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 var path = __nccwpck_require__(1017);
-var common = __nccwpck_require__(7673);
+var common = __nccwpck_require__(624);
 
 common.register('pwd', _pwd, {
   allowGlobbing: false,
@@ -15623,10 +15623,10 @@ module.exports = _pwd;
 
 /***/ }),
 
-/***/ 7720:
+/***/ 4369:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
-var common = __nccwpck_require__(7673);
+var common = __nccwpck_require__(624);
 var fs = __nccwpck_require__(7147);
 
 common.register('rm', _rm, {
@@ -15831,10 +15831,10 @@ module.exports = _rm;
 
 /***/ }),
 
-/***/ 6926:
+/***/ 3401:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
-var common = __nccwpck_require__(7673);
+var common = __nccwpck_require__(624);
 var fs = __nccwpck_require__(7147);
 
 common.register('sed', _sed, {
@@ -15925,10 +15925,10 @@ module.exports = _sed;
 
 /***/ }),
 
-/***/ 11:
+/***/ 2833:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
-var common = __nccwpck_require__(7673);
+var common = __nccwpck_require__(624);
 
 common.register('set', _set, {
   allowGlobbing: false,
@@ -15988,10 +15988,10 @@ module.exports = _set;
 
 /***/ }),
 
-/***/ 7472:
+/***/ 2675:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
-var common = __nccwpck_require__(7673);
+var common = __nccwpck_require__(624);
 var fs = __nccwpck_require__(7147);
 
 common.register('sort', _sort, {
@@ -16092,10 +16092,10 @@ module.exports = _sort;
 
 /***/ }),
 
-/***/ 8968:
+/***/ 1434:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
-var common = __nccwpck_require__(7673);
+var common = __nccwpck_require__(624);
 var fs = __nccwpck_require__(7147);
 
 common.register('tail', _tail, {
@@ -16179,10 +16179,10 @@ module.exports = _tail;
 
 /***/ }),
 
-/***/ 591:
+/***/ 8691:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
-var common = __nccwpck_require__(7673);
+var common = __nccwpck_require__(624);
 var os = __nccwpck_require__(2037);
 var fs = __nccwpck_require__(7147);
 
@@ -16261,10 +16261,10 @@ module.exports.clearCache = clearCache;
 
 /***/ }),
 
-/***/ 9063:
+/***/ 2766:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
-var common = __nccwpck_require__(7673);
+var common = __nccwpck_require__(624);
 var fs = __nccwpck_require__(7147);
 
 common.register('test', _test, {
@@ -16353,10 +16353,10 @@ module.exports = _test;
 
 /***/ }),
 
-/***/ 4897:
+/***/ 3181:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
-var common = __nccwpck_require__(7673);
+var common = __nccwpck_require__(624);
 var fs = __nccwpck_require__(7147);
 var path = __nccwpck_require__(1017);
 
@@ -16397,10 +16397,10 @@ module.exports = _to;
 
 /***/ }),
 
-/***/ 228:
+/***/ 5836:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
-var common = __nccwpck_require__(7673);
+var common = __nccwpck_require__(624);
 var fs = __nccwpck_require__(7147);
 var path = __nccwpck_require__(1017);
 
@@ -16440,10 +16440,10 @@ module.exports = _toEnd;
 
 /***/ }),
 
-/***/ 8440:
+/***/ 9811:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
-var common = __nccwpck_require__(7673);
+var common = __nccwpck_require__(624);
 var fs = __nccwpck_require__(7147);
 
 common.register('touch', _touch, {
@@ -16558,10 +16558,10 @@ function tryStatFile(filePath) {
 
 /***/ }),
 
-/***/ 5499:
+/***/ 9095:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
-var common = __nccwpck_require__(7673);
+var common = __nccwpck_require__(624);
 var fs = __nccwpck_require__(7147);
 
 // add c spaces to the left of str
@@ -16657,10 +16657,10 @@ module.exports = _uniq;
 
 /***/ }),
 
-/***/ 5405:
+/***/ 858:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
-var common = __nccwpck_require__(7673);
+var common = __nccwpck_require__(624);
 var fs = __nccwpck_require__(7147);
 var path = __nccwpck_require__(1017);
 
@@ -16782,7 +16782,7 @@ module.exports = _which;
 
 /***/ }),
 
-/***/ 5534:
+/***/ 2784:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
@@ -16983,7 +16983,7 @@ module.exports.PROCESSING_OPTIONS = PROCESSING_OPTIONS;
 
 /***/ }),
 
-/***/ 5315:
+/***/ 1464:
 /***/ ((module) => {
 
 /******************************************************************************
@@ -17411,15 +17411,15 @@ var __disposeResources;
 
 /***/ }),
 
-/***/ 7383:
+/***/ 2932:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
-module.exports = __nccwpck_require__(9161);
+module.exports = __nccwpck_require__(7146);
 
 
 /***/ }),
 
-/***/ 9161:
+/***/ 7146:
 /***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
 "use strict";
@@ -17691,7 +17691,7 @@ exports.debug = debug; // for test
 
 /***/ }),
 
-/***/ 4021:
+/***/ 9553:
 /***/ ((__unused_webpack_module, exports) => {
 
 "use strict";
@@ -17717,7 +17717,7 @@ exports.getUserAgent = getUserAgent;
 
 /***/ }),
 
-/***/ 580:
+/***/ 7515:
 /***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
 "use strict";
@@ -17781,29 +17781,29 @@ Object.defineProperty(exports, "parse", ({
   }
 }));
 
-var _v = _interopRequireDefault(__nccwpck_require__(5618));
+var _v = _interopRequireDefault(__nccwpck_require__(7635));
 
-var _v2 = _interopRequireDefault(__nccwpck_require__(4643));
+var _v2 = _interopRequireDefault(__nccwpck_require__(2839));
 
-var _v3 = _interopRequireDefault(__nccwpck_require__(9370));
+var _v3 = _interopRequireDefault(__nccwpck_require__(3189));
 
-var _v4 = _interopRequireDefault(__nccwpck_require__(3249));
+var _v4 = _interopRequireDefault(__nccwpck_require__(9798));
 
-var _nil = _interopRequireDefault(__nccwpck_require__(4829));
+var _nil = _interopRequireDefault(__nccwpck_require__(3017));
 
-var _version = _interopRequireDefault(__nccwpck_require__(4698));
+var _version = _interopRequireDefault(__nccwpck_require__(2450));
 
-var _validate = _interopRequireDefault(__nccwpck_require__(3498));
+var _validate = _interopRequireDefault(__nccwpck_require__(8021));
 
-var _stringify = _interopRequireDefault(__nccwpck_require__(2332));
+var _stringify = _interopRequireDefault(__nccwpck_require__(3377));
 
-var _parse = _interopRequireDefault(__nccwpck_require__(9869));
+var _parse = _interopRequireDefault(__nccwpck_require__(1810));
 
 function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
 
 /***/ }),
 
-/***/ 7342:
+/***/ 1923:
 /***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
 "use strict";
@@ -17833,7 +17833,7 @@ exports["default"] = _default;
 
 /***/ }),
 
-/***/ 4829:
+/***/ 3017:
 /***/ ((__unused_webpack_module, exports) => {
 
 "use strict";
@@ -17848,7 +17848,7 @@ exports["default"] = _default;
 
 /***/ }),
 
-/***/ 9869:
+/***/ 1810:
 /***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
 "use strict";
@@ -17859,7 +17859,7 @@ Object.defineProperty(exports, "__esModule", ({
 }));
 exports["default"] = void 0;
 
-var _validate = _interopRequireDefault(__nccwpck_require__(3498));
+var _validate = _interopRequireDefault(__nccwpck_require__(8021));
 
 function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
 
@@ -17900,7 +17900,7 @@ exports["default"] = _default;
 
 /***/ }),
 
-/***/ 5409:
+/***/ 4818:
 /***/ ((__unused_webpack_module, exports) => {
 
 "use strict";
@@ -17915,7 +17915,7 @@ exports["default"] = _default;
 
 /***/ }),
 
-/***/ 4315:
+/***/ 6983:
 /***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
 "use strict";
@@ -17946,7 +17946,7 @@ function rng() {
 
 /***/ }),
 
-/***/ 9843:
+/***/ 1033:
 /***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
 "use strict";
@@ -17976,7 +17976,7 @@ exports["default"] = _default;
 
 /***/ }),
 
-/***/ 2332:
+/***/ 3377:
 /***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
 "use strict";
@@ -17987,7 +17987,7 @@ Object.defineProperty(exports, "__esModule", ({
 }));
 exports["default"] = void 0;
 
-var _validate = _interopRequireDefault(__nccwpck_require__(3498));
+var _validate = _interopRequireDefault(__nccwpck_require__(8021));
 
 function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
 
@@ -18022,7 +18022,7 @@ exports["default"] = _default;
 
 /***/ }),
 
-/***/ 5618:
+/***/ 7635:
 /***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
 "use strict";
@@ -18033,9 +18033,9 @@ Object.defineProperty(exports, "__esModule", ({
 }));
 exports["default"] = void 0;
 
-var _rng = _interopRequireDefault(__nccwpck_require__(4315));
+var _rng = _interopRequireDefault(__nccwpck_require__(6983));
 
-var _stringify = _interopRequireDefault(__nccwpck_require__(2332));
+var _stringify = _interopRequireDefault(__nccwpck_require__(3377));
 
 function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
 
@@ -18136,7 +18136,7 @@ exports["default"] = _default;
 
 /***/ }),
 
-/***/ 4643:
+/***/ 2839:
 /***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
 "use strict";
@@ -18147,9 +18147,9 @@ Object.defineProperty(exports, "__esModule", ({
 }));
 exports["default"] = void 0;
 
-var _v = _interopRequireDefault(__nccwpck_require__(181));
+var _v = _interopRequireDefault(__nccwpck_require__(3127));
 
-var _md = _interopRequireDefault(__nccwpck_require__(7342));
+var _md = _interopRequireDefault(__nccwpck_require__(1923));
 
 function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
 
@@ -18159,7 +18159,7 @@ exports["default"] = _default;
 
 /***/ }),
 
-/***/ 181:
+/***/ 3127:
 /***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
 "use strict";
@@ -18171,9 +18171,9 @@ Object.defineProperty(exports, "__esModule", ({
 exports["default"] = _default;
 exports.URL = exports.DNS = void 0;
 
-var _stringify = _interopRequireDefault(__nccwpck_require__(2332));
+var _stringify = _interopRequireDefault(__nccwpck_require__(3377));
 
-var _parse = _interopRequireDefault(__nccwpck_require__(9869));
+var _parse = _interopRequireDefault(__nccwpck_require__(1810));
 
 function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
 
@@ -18244,7 +18244,7 @@ function _default(name, version, hashfunc) {
 
 /***/ }),
 
-/***/ 9370:
+/***/ 3189:
 /***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
 "use strict";
@@ -18255,9 +18255,9 @@ Object.defineProperty(exports, "__esModule", ({
 }));
 exports["default"] = void 0;
 
-var _rng = _interopRequireDefault(__nccwpck_require__(4315));
+var _rng = _interopRequireDefault(__nccwpck_require__(6983));
 
-var _stringify = _interopRequireDefault(__nccwpck_require__(2332));
+var _stringify = _interopRequireDefault(__nccwpck_require__(3377));
 
 function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
 
@@ -18288,7 +18288,7 @@ exports["default"] = _default;
 
 /***/ }),
 
-/***/ 3249:
+/***/ 9798:
 /***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
 "use strict";
@@ -18299,9 +18299,9 @@ Object.defineProperty(exports, "__esModule", ({
 }));
 exports["default"] = void 0;
 
-var _v = _interopRequireDefault(__nccwpck_require__(181));
+var _v = _interopRequireDefault(__nccwpck_require__(3127));
 
-var _sha = _interopRequireDefault(__nccwpck_require__(9843));
+var _sha = _interopRequireDefault(__nccwpck_require__(1033));
 
 function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
 
@@ -18311,7 +18311,7 @@ exports["default"] = _default;
 
 /***/ }),
 
-/***/ 3498:
+/***/ 8021:
 /***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
 "use strict";
@@ -18322,7 +18322,7 @@ Object.defineProperty(exports, "__esModule", ({
 }));
 exports["default"] = void 0;
 
-var _regex = _interopRequireDefault(__nccwpck_require__(5409));
+var _regex = _interopRequireDefault(__nccwpck_require__(4818));
 
 function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
 
@@ -18335,7 +18335,7 @@ exports["default"] = _default;
 
 /***/ }),
 
-/***/ 4698:
+/***/ 2450:
 /***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
 "use strict";
@@ -18346,7 +18346,7 @@ Object.defineProperty(exports, "__esModule", ({
 }));
 exports["default"] = void 0;
 
-var _validate = _interopRequireDefault(__nccwpck_require__(3498));
+var _validate = _interopRequireDefault(__nccwpck_require__(8021));
 
 function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
 
@@ -18363,12 +18363,12 @@ exports["default"] = _default;
 
 /***/ }),
 
-/***/ 5351:
+/***/ 9777:
 /***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
 "use strict";
 
-const usm = __nccwpck_require__(9358);
+const usm = __nccwpck_require__(8007);
 
 exports.implementation = class URLImpl {
   constructor(constructorArgs) {
@@ -18571,15 +18571,15 @@ exports.implementation = class URLImpl {
 
 /***/ }),
 
-/***/ 1024:
+/***/ 2984:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
 
 
-const conversions = __nccwpck_require__(628);
-const utils = __nccwpck_require__(1187);
-const Impl = __nccwpck_require__(5351);
+const conversions = __nccwpck_require__(4906);
+const utils = __nccwpck_require__(3016);
+const Impl = __nccwpck_require__(9777);
 
 const impl = utils.implSymbol;
 
@@ -18775,32 +18775,32 @@ module.exports = {
 
 /***/ }),
 
-/***/ 9619:
+/***/ 4:
 /***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
 "use strict";
 
 
-exports.URL = __nccwpck_require__(1024)["interface"];
-exports.serializeURL = __nccwpck_require__(9358).serializeURL;
-exports.serializeURLOrigin = __nccwpck_require__(9358).serializeURLOrigin;
-exports.basicURLParse = __nccwpck_require__(9358).basicURLParse;
-exports.setTheUsername = __nccwpck_require__(9358).setTheUsername;
-exports.setThePassword = __nccwpck_require__(9358).setThePassword;
-exports.serializeHost = __nccwpck_require__(9358).serializeHost;
-exports.serializeInteger = __nccwpck_require__(9358).serializeInteger;
-exports.parseURL = __nccwpck_require__(9358).parseURL;
+exports.URL = __nccwpck_require__(2984)["interface"];
+exports.serializeURL = __nccwpck_require__(8007).serializeURL;
+exports.serializeURLOrigin = __nccwpck_require__(8007).serializeURLOrigin;
+exports.basicURLParse = __nccwpck_require__(8007).basicURLParse;
+exports.setTheUsername = __nccwpck_require__(8007).setTheUsername;
+exports.setThePassword = __nccwpck_require__(8007).setThePassword;
+exports.serializeHost = __nccwpck_require__(8007).serializeHost;
+exports.serializeInteger = __nccwpck_require__(8007).serializeInteger;
+exports.parseURL = __nccwpck_require__(8007).parseURL;
 
 
 /***/ }),
 
-/***/ 9358:
+/***/ 8007:
 /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
 
 "use strict";
 
 const punycode = __nccwpck_require__(5477);
-const tr46 = __nccwpck_require__(5534);
+const tr46 = __nccwpck_require__(2784);
 
 const specialSchemes = {
   ftp: 21,
@@ -20099,7 +20099,7 @@ module.exports.parseURL = function (input, options) {
 
 /***/ }),
 
-/***/ 1187:
+/***/ 3016:
 /***/ ((module) => {
 
 "use strict";
@@ -20127,7 +20127,7 @@ module.exports.implForWrapper = function (wrapper) {
 
 /***/ }),
 
-/***/ 628:
+/***/ 4906:
 /***/ ((module) => {
 
 "use strict";
@@ -20324,7 +20324,7 @@ conversions["RegExp"] = function (V, opts) {
 
 /***/ }),
 
-/***/ 3180:
+/***/ 5173:
 /***/ ((module) => {
 
 // Returns a wrapper function that returns a wrapped callback
@@ -20364,15 +20364,15 @@ function wrappy (fn, cb) {
 
 /***/ }),
 
-/***/ 1205:
+/***/ 7523:
 /***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
 
 "use strict";
 
 Object.defineProperty(exports, "__esModule", ({ value: true }));
 exports.execCommand = exports.ChildProcess = exports.ShellString = void 0;
-const shell = __nccwpck_require__(4572);
-const shelljs_1 = __nccwpck_require__(4572);
+const shell = __nccwpck_require__(6877);
+const shelljs_1 = __nccwpck_require__(6877);
 Object.defineProperty(exports, "ShellString", ({ enumerable: true, get: function () { return shelljs_1.ShellString; } }));
 const child_process_1 = __nccwpck_require__(2081);
 Object.defineProperty(exports, "ChildProcess", ({ enumerable: true, get: function () { return child_process_1.ChildProcess; } }));
@@ -20677,10 +20677,10 @@ var __webpack_exports__ = {};
 var exports = __webpack_exports__;
 
 Object.defineProperty(exports, "__esModule", ({ value: true }));
-const tslib_1 = __nccwpck_require__(5315);
-const core = __nccwpck_require__(7896);
-const github = __nccwpck_require__(7486);
-const exec_1 = __nccwpck_require__(1205);
+const tslib_1 = __nccwpck_require__(1464);
+const core = __nccwpck_require__(4712);
+const github = __nccwpck_require__(2758);
+const exec_1 = __nccwpck_require__(7523);
 function run() {
     return tslib_1.__awaiter(this, void 0, void 0, function* () {
         try {